diff --git a/.env.beta b/.env.beta index 88147215258..c4a7c154ffe 100644 --- a/.env.beta +++ b/.env.beta @@ -1,6 +1,6 @@ VITE_BYPASS_LOGIN=0 VITE_BYPASS_TUTORIAL=0 -VITE_SERVER_URL=https://api.beta.pokerogue.net +VITE_SERVER_URL=https://apibeta.pokerogue.net VITE_DISCORD_CLIENT_ID=1248062921129459756 VITE_GOOGLE_CLIENT_ID=955345393540-2k6lfftf0fdnb0krqmpthjnqavfvvf73.apps.googleusercontent.com -VITE_I18N_DEBUG=1 +VITE_I18N_DEBUG=0 diff --git a/.env.development b/.env.development index 6c92036270f..e4e5053016f 100644 --- a/.env.development +++ b/.env.development @@ -3,5 +3,5 @@ VITE_BYPASS_TUTORIAL=0 VITE_SERVER_URL=http://localhost:8001 VITE_DISCORD_CLIENT_ID=1234567890 VITE_GOOGLE_CLIENT_ID=1234567890 -VITE_I18N_DEBUG=1 +VITE_I18N_DEBUG=0 VITE_PORT=8000 diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS index ce942deba5f..8e7606f0a48 100644 --- a/.github/CODEOWNERS +++ b/.github/CODEOWNERS @@ -5,41 +5,3 @@ # github actions/templates etc. - Dev Leads /.github @pagefaultgames/dev-leads - -# --- Translations --- - -# all translations - Translation Leads -/src/locales @pagefaultgames/translation-leads - -# Catalan (Spain/Spanish) -/src/locales/ca_ES @pagefaultgames/catalan-translation-team - -# German -/src/locales/de @pagefaultgames/german-translation-team - -# English -/src/locales/en @pagefaultgames/english-translation-team - -# Spanish -/src/locales/es @pagefaultgames/spanish-translation-team - -# French -/src/locales/fr @pagefaultgames/french-translation-team - -# Italian -/src/locales/it @pagefaultgames/italian-translation-team - -# Japenese -/src/locales/ja @pagefaultgames/japanese-translation-team - -# Korean -/src/locales/ko @pagefaultgames/korean-translation-team - -# Brasilian (Brasil/Portuguese) -/src/locales/pt_BR @pagefaultgames/portuguese_br-translation-team - -# Chinese (simplified) -/src/locales/zh_CN @pagefaultgames/chinese_simplified-translation-team - -# Chinese (traditional) -/src/locales/zh_TW @pagefaultgames/chinese_traditional-translation-team diff --git a/.github/FUNDING.yml b/.github/FUNDING.yml index 180c7af1240..8c724cda762 100644 --- a/.github/FUNDING.yml +++ b/.github/FUNDING.yml @@ -1 +1 @@ -github: patapancakes +github: pagefaultgames diff --git a/.github/workflows/deploy-beta.yml b/.github/workflows/deploy-beta.yml index 3af48b400af..d8d8126193d 100644 --- a/.github/workflows/deploy-beta.yml +++ b/.github/workflows/deploy-beta.yml @@ -11,6 +11,8 @@ jobs: runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 + with: + submodules: 'recursive' - uses: actions/setup-node@v4 with: node-version: "20" diff --git a/.github/workflows/deploy.yml b/.github/workflows/deploy.yml index 2364fff5a35..e40b18eb69b 100644 --- a/.github/workflows/deploy.yml +++ b/.github/workflows/deploy.yml @@ -1,8 +1,12 @@ -name: Deploy +name: Deploy Main on: - push: {} - pull_request: {} + push: + branches: + - main + pull_request: + branches: + - main jobs: deploy: @@ -10,6 +14,8 @@ jobs: runs-on: ubuntu-latest steps: - uses: actions/checkout@v4 + with: + submodules: 'recursive' - uses: actions/setup-node@v4 with: node-version: "20" @@ -20,7 +26,7 @@ jobs: env: NODE_ENV: production - name: Set up SSH - if: github.event_name == 'push' && github.ref_name == github.event.repository.default_branch + if: github.event_name == 'push' && github.ref_name == 'main' run: | mkdir ~/.ssh echo "${{ secrets.SSH_PUBLIC_KEY }}" > ~/.ssh/id_ed25519.pub @@ -28,12 +34,12 @@ jobs: chmod 600 ~/.ssh/* ssh-keyscan -H ${{ secrets.SSH_HOST }} >> ~/.ssh/known_hosts - name: Deploy build on server - if: github.event_name == 'push' && github.ref_name == github.event.repository.default_branch + if: github.event_name == 'push' && github.ref_name == 'main' run: | rsync --del --no-times --checksum -vrm dist/* ${{ secrets.SSH_USER }}@${{ secrets.SSH_HOST }}:${{ secrets.DESTINATION_DIR }} ssh -t ${{ secrets.SSH_USER }}@${{ secrets.SSH_HOST }} "~/prmanifest --inpath ${{ secrets.DESTINATION_DIR }} --outpath ${{ secrets.DESTINATION_DIR }}/manifest.json" - name: Purge Cloudflare Cache - if: github.event_name == 'push' && github.ref_name == github.event.repository.default_branch + if: github.event_name == 'push' && github.ref_name == 'main' id: purge-cache uses: NathanVaughn/actions-cloudflare-purge@v3.1.0 with: diff --git a/.github/workflows/eslint.yml b/.github/workflows/eslint.yml index a8eea069ba6..d863c96a643 100644 --- a/.github/workflows/eslint.yml +++ b/.github/workflows/eslint.yml @@ -22,6 +22,8 @@ jobs: steps: - name: Check out Git repository # Step to check out the repository uses: actions/checkout@v4 # Use the checkout action version 4 + with: + submodules: 'recursive' - name: Set up Node.js # Step to set up Node.js environment uses: actions/setup-node@v4 # Use the setup-node action version 4 diff --git a/.github/workflows/github-pages.yml b/.github/workflows/github-pages.yml index a092ccb425a..58067ac81ac 100644 --- a/.github/workflows/github-pages.yml +++ b/.github/workflows/github-pages.yml @@ -26,6 +26,7 @@ jobs: - name: Checkout repository for Typedoc uses: actions/checkout@v3 with: + submodules: 'recursive' path: pokerogue_docs - name: Install OS package diff --git a/.github/workflows/test-shard-template.yml b/.github/workflows/test-shard-template.yml index ac89b503f0c..185764c86a8 100644 --- a/.github/workflows/test-shard-template.yml +++ b/.github/workflows/test-shard-template.yml @@ -20,6 +20,8 @@ jobs: steps: - name: Check out Git repository uses: actions/checkout@v4 + with: + submodules: 'recursive' - name: Set up Node.js uses: actions/setup-node@v4 with: diff --git a/.github/workflows/tests.yml b/.github/workflows/tests.yml index 66cc3ecc139..d30d8adba38 100644 --- a/.github/workflows/tests.yml +++ b/.github/workflows/tests.yml @@ -22,6 +22,7 @@ jobs: - name: Check out Git repository uses: actions/checkout@v4 with: + submodules: 'recursive' path: tests-action - name: Set up Node.js uses: actions/setup-node@v4 diff --git a/.gitmodules b/.gitmodules new file mode 100644 index 00000000000..9df14115297 --- /dev/null +++ b/.gitmodules @@ -0,0 +1,3 @@ +[submodule "public/locales"] + path = public/locales + url = https://github.com/pagefaultgames/pokerogue-locales diff --git a/README.md b/README.md index f3ec1c793bd..866687d54b7 100644 --- a/README.md +++ b/README.md @@ -17,13 +17,21 @@ If you have the motivation and experience with Typescript/Javascript (or are wil 2. Run `npm run start:dev` to locally run the project in `localhost:8000` #### Linting -We're using ESLint as our common linter and formatter. It will run automatically during the pre-commit hook but if you would like to manually run it, use the `npm run eslint` script. +We're using ESLint as our common linter and formatter. It will run automatically during the pre-commit hook but if you would like to manually run it, use the `npm run eslint` script. To view the complete rules, check out the [eslint.config.js](./eslint.config.js) file. + +### 📚 Documentation +You can find the auto-generated documentation [here](https://pagefaultgames.github.io/pokerogue/main/index.html). +For information on enemy AI, check out the [enemy-ai.md](./docs/enemy-ai.md) file. +For detailed guidelines on documenting your code, refer to the [comments.md](./docs/comments.md) file. ### ❔ FAQ **How do I test a new _______?** - In the `src/overrides.ts` file there are overrides for most values you'll need to change for testing +**How do I retrieve the translations?** +- The translations were moved to the [dedicated translation repository](https://github.com/pagefaultgames/pokerogue-locales) and are now applied as a submodule in this project. +- The command to retrieve the translations is `git submodule update --init --recursive`. If you still struggle to get it working, please reach out to #dev-corner channel in Discord. ## 🪧 To Do Check out [Github Issues](https://github.com/pagefaultgames/pokerogue/issues) to see how can you help us! @@ -56,7 +64,7 @@ Check out [Github Issues](https://github.com/pagefaultgames/pokerogue/issues) to - Pokémon Legends: Arceus - Pokémon Scarlet/Violet - Firel (Custom Ice Cave, Laboratory, Metropolis, Plains, Power Plant, Seabed, Space, and Volcano biome music) - - Lmz (Custom Jungle biome music) + - Lmz (Custom Ancient Ruins, Jungle, and Lake biome music) - Andr06 (Custom Slum and Sea biome music) ### 🎵 Sound Effects diff --git a/create-test-boilerplate.js b/create-test-boilerplate.js index d9cdbd4e7cf..a365999c623 100644 --- a/create-test-boilerplate.js +++ b/create-test-boilerplate.js @@ -1,82 +1,120 @@ -import fs from 'fs'; -import path from 'path'; -import { fileURLToPath } from 'url'; - /** - * This script creates a test boilerplate file for a move or ability. - * @param {string} type - The type of test to create. Either "move", "ability", - * or "item". - * @param {string} fileName - The name of the file to create. - * @example npm run create-test move tackle + * This script creates a test boilerplate file in the appropriate + * directory based on the type selected. + * @example npm run create-test */ +import fs from "fs"; +import inquirer from "inquirer"; +import path from "path"; +import { fileURLToPath } from "url"; + // Get the directory name of the current module file const __filename = fileURLToPath(import.meta.url); const __dirname = path.dirname(__filename); +const typeChoices = ["Move", "Ability", "Item", "Mystery Encounter"]; -// Get the arguments from the command line -const args = process.argv.slice(2); -const type = args[0]; // "move" or "ability" -let fileName = args[1]; // The file name +/** + * Prompts the user to select a type via list. + * @returns {Promise<{selectedOption: string}>} the selected type + */ +async function promptTestType() { + const typeAnswer = await inquirer.prompt([ + { + type: "list", + name: "selectedOption", + message: "What type of test would you like to create:", + choices: [...typeChoices, "EXIT"], + }, + ]); -if (!type || !fileName) { - console.error('Please provide a type ("move", "ability", or "item") and a file name.'); - process.exit(1); + if (typeAnswer.selectedOption === "EXIT") { + console.log("Exiting..."); + return process.exit(); + } else if (!typeChoices.includes(typeAnswer.selectedOption)) { + console.error(`Please provide a valid type (${typeChoices.join(", ")})!`); + return await promptTestType(); + } + + return typeAnswer; } -// Convert fileName from kebab-case or camelCase to snake_case -fileName = fileName - .replace(/-+/g, '_') // Convert kebab-case (dashes) to underscores - .replace(/([a-z])([A-Z])/g, '$1_$2') // Convert camelCase to snake_case - .toLowerCase(); // Ensure all lowercase +/** + * Prompts the user to provide a file name. + * @param {string} selectedType + * @returns {Promise<{userInput: string}>} the selected file name + */ +async function promptFileName(selectedType) { + const fileNameAnswer = await inquirer.prompt([ + { + type: "input", + name: "userInput", + message: `Please provide the name of the ${selectedType}:`, + }, + ]); -// Format the description for the test case -const formattedName = fileName - .replace(/_/g, ' ') - .replace(/\b\w/g, char => char.toUpperCase()); + if (!fileNameAnswer.userInput || fileNameAnswer.userInput.trim().length === 0) { + console.error("Please provide a valid file name!"); + return await promptFileName(selectedType); + } -// Determine the directory based on the type -let dir; -let description; -if (type === 'move') { - dir = path.join(__dirname, 'src', 'test', 'moves'); - description = `Moves - ${formattedName}`; -} else if (type === 'ability') { - dir = path.join(__dirname, 'src', 'test', 'abilities'); - description = `Abilities - ${formattedName}`; -} else if (type === "item") { - dir = path.join(__dirname, 'src', 'test', 'items'); - description = `Items - ${formattedName}`; -} else { - console.error('Invalid type. Please use "move", "ability", or "item".'); - process.exit(1); + return fileNameAnswer; } -// Ensure the directory exists -if (!fs.existsSync(dir)) { - fs.mkdirSync(dir, { recursive: true }); -} +/** + * Runs the interactive create-test "CLI" + * @returns {Promise} + */ +async function runInteractive() { + const typeAnswer = await promptTestType(); + const fileNameAnswer = await promptFileName(typeAnswer.selectedOption); -// Create the file with the given name -const filePath = path.join(dir, `${fileName}.test.ts`); + const type = typeAnswer.selectedOption.toLowerCase(); + // Convert fileName from kebab-case or camelCase to snake_case + const fileName = fileNameAnswer.userInput + .replace(/-+/g, "_") // Convert kebab-case (dashes) to underscores + .replace(/([a-z])([A-Z])/g, "$1_$2") // Convert camelCase to snake_case + .replace(/\s+/g, '_') // Replace spaces with underscores + .toLowerCase(); // Ensure all lowercase + // Format the description for the test case -if (fs.existsSync(filePath)) { - console.error(`File "${fileName}.test.ts" already exists.`); - process.exit(1); -} + const formattedName = fileName.replace(/_/g, " ").replace(/\b\w/g, (char) => char.toUpperCase()); + // Determine the directory based on the type + let dir; + let description; + switch (type) { + case "move": + dir = path.join(__dirname, "src", "test", "moves"); + description = `Moves - ${formattedName}`; + break; + case "ability": + dir = path.join(__dirname, "src", "test", "abilities"); + description = `Abilities - ${formattedName}`; + break; + case "item": + dir = path.join(__dirname, "src", "test", "items"); + description = `Items - ${formattedName}`; + break; + case "mystery encounter": + dir = path.join(__dirname, "src", "test", "mystery-encounter", "encounters"); + description = `Mystery Encounter - ${formattedName}`; + break; + default: + console.error(`Invalid type. Please use one of the following: ${typeChoices.join(", ")}.`); + process.exit(1); + } -// Define the content template -const content = `import { Abilities } from "#enums/abilities"; + // Define the content template + const content = `import { Abilities } from "#enums/abilities"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; -import { afterEach, beforeAll, beforeEach, describe, it, expect } from "vitest"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; describe("${description}", () => { let phaserGame: Phaser.Game; let game: GameManager; - const TIMEOUT = 20 * 1000; beforeAll(() => { phaserGame = new Phaser.Game({ @@ -91,20 +129,43 @@ describe("${description}", () => { beforeEach(() => { game = new GameManager(phaserGame); game.override - .moveset([Moves.SPLASH]) + .moveset([ Moves.SPLASH ]) + .ability(Abilities.BALL_FETCH) .battleType("single") + .disableCrits() + .enemySpecies(Species.MAGIKARP) .enemyAbility(Abilities.BALL_FETCH) .enemyMoveset(Moves.SPLASH); }); - it("test case", async () => { - // await game.classicMode.startBattle([Species.MAGIKARP]); - // game.move.select(Moves.SPLASH); - }, TIMEOUT); + it("should do X", async () => { + await game.classicMode.startBattle([ Species.FEEBAS ]); + + game.move.select(Moves.SPLASH); + await game.phaseInterceptor.to("BerryPhase"); + + expect(true).toBe(true); + }); }); `; -// Write the template content to the file -fs.writeFileSync(filePath, content, 'utf8'); + // Ensure the directory exists + if (!fs.existsSync(dir)) { + fs.mkdirSync(dir, { recursive: true }); + } -console.log(`File created at: ${filePath}`); + // Create the file with the given name + const filePath = path.join(dir, `${fileName}.test.ts`); + + if (fs.existsSync(filePath)) { + console.error(`File "${fileName}.test.ts" already exists.`); + process.exit(1); + } + + // Write the template content to the file + fs.writeFileSync(filePath, content, "utf8"); + + console.log(`File created at: ${filePath}`); +} + +runInteractive(); diff --git a/eslint.config.js b/eslint.config.js index 80e9e67b525..2f2b466c66f 100644 --- a/eslint.config.js +++ b/eslint.config.js @@ -1,5 +1,5 @@ import tseslint from '@typescript-eslint/eslint-plugin'; -import stylisticTs from '@stylistic/eslint-plugin-ts' +import stylisticTs from '@stylistic/eslint-plugin-ts'; import parser from '@typescript-eslint/parser'; import importX from 'eslint-plugin-import-x'; @@ -16,15 +16,15 @@ export default [ '@typescript-eslint': tseslint }, rules: { - "eqeqeq": ["error", "always"], // Enforces the use of === and !== instead of == and != - "indent": ["error", 2], // Enforces a 2-space indentation + "eqeqeq": ["error", "always"], // Enforces the use of `===` and `!==` instead of `==` and `!=` + "indent": ["error", 2, { "SwitchCase": 1 }], // Enforces a 2-space indentation, enforces indentation of `case ...:` statements "quotes": ["error", "double"], // Enforces the use of double quotes for strings - "no-var": "error", // Disallows the use of var, enforcing let or const instead - "prefer-const": "error", // Prefers the use of const for variables that are never reassigned + "no-var": "error", // Disallows the use of `var`, enforcing `let` or `const` instead + "prefer-const": "error", // Enforces the use of `const` for variables that are never reassigned "no-undef": "off", // Disables the rule that disallows the use of undeclared variables (TypeScript handles this) "@typescript-eslint/no-unused-vars": [ "error", { "args": "none", // Allows unused function parameters. Useful for functions with specific signatures where not all parameters are always used. - "ignoreRestSiblings": true // Allows unused variables that are part of a rest property in object destructuring. Useful for excluding certain properties from an object while using the rest. + "ignoreRestSiblings": true // Allows unused variables that are part of a rest property in object destructuring. Useful for excluding certain properties from an object while using the others. }], "eol-last": ["error", "always"], // Enforces at least one newline at the end of files "@stylistic/ts/semi": ["error", "always"], // Requires semicolons for TypeScript-specific syntax @@ -32,15 +32,20 @@ export default [ "no-extra-semi": ["error"], // Disallows unnecessary semicolons for TypeScript-specific syntax "brace-style": "off", // Note: you must disable the base rule as it can report incorrect errors "curly": ["error", "all"], // Enforces the use of curly braces for all control statements - "@stylistic/ts/brace-style": ["error", "1tbs"], + "@stylistic/ts/brace-style": ["error", "1tbs"], // Enforces the following brace style: https://eslint.style/rules/js/brace-style#_1tbs "no-trailing-spaces": ["error", { // Disallows trailing whitespace at the end of lines "skipBlankLines": false, // Enforces the rule even on blank lines "ignoreComments": false // Enforces the rule on lines containing comments }], "space-before-blocks": ["error", "always"], // Enforces a space before blocks "keyword-spacing": ["error", { "before": true, "after": true }], // Enforces spacing before and after keywords - "comma-spacing": ["error", { "before": false, "after": true }], // Enforces spacing after comma + "comma-spacing": ["error", { "before": false, "after": true }], // Enforces spacing after commas "import-x/extensions": ["error", "never", { "json": "always" }], // Enforces no extension for imports unless json + "array-bracket-spacing": ["error", "always", { "objectsInArrays": false, "arraysInArrays": false }], // Enforces consistent spacing inside array brackets + "object-curly-spacing": ["error", "always", { "arraysInObjects": false, "objectsInObjects": false }], // Enforces consistent spacing inside braces of object literals, destructuring assignments, and import/export specifiers + "computed-property-spacing": ["error", "never" ], // Enforces consistent spacing inside computed property brackets + "space-infix-ops": ["error", { "int32Hint": false }], // Enforces spacing around infix operators + "no-multiple-empty-lines": ["error", { "max": 2, "maxEOF": 1, "maxBOF": 0 }], // Disallows multiple empty lines } } ] diff --git a/global.d.ts b/global.d.ts new file mode 100644 index 00000000000..c896a4983e4 --- /dev/null +++ b/global.d.ts @@ -0,0 +1,14 @@ +import type { SetupServerApi } from "msw/node"; + +export {}; + +declare global { + /** + * Only used in testing. + * Can technically be undefined/null but for ease of use we are going to assume it is always defined. + * Used to load i18n files exclusively. + * + * To set up your own server in a test see `game_data.test.ts` + */ + var server: SetupServerApi; +} diff --git a/lefthook.yml b/lefthook.yml index 662d3b5617b..06eb0446ee5 100644 --- a/lefthook.yml +++ b/lefthook.yml @@ -13,4 +13,9 @@ pre-push: commands: eslint: glob: "*.{js,ts,jsx,tsx}" - run: npx eslint --fix {push_files} \ No newline at end of file + run: npx eslint --fix {push_files} + +post-merge: + commands: + update-submodules: + run: git submodule update --init --recursive \ No newline at end of file diff --git a/package-lock.json b/package-lock.json index 4a447554819..792720200a9 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,17 +1,19 @@ { "name": "pokemon-rogue-battle", - "version": "1.0.4", + "version": "1.2.0", "lockfileVersion": 3, "requires": true, "packages": { "": { "name": "pokemon-rogue-battle", - "version": "1.0.4", + "version": "1.2.0", + "hasInstallScript": true, "dependencies": { "@material/material-color-utilities": "^0.2.7", "crypto-js": "^4.2.0", "i18next": "^23.11.1", "i18next-browser-languagedetector": "^7.2.1", + "i18next-http-backend": "^2.6.1", "i18next-korean-postposition-processor": "^1.0.0", "json-stable-stringify": "^1.1.0", "phaser": "^3.70.0", @@ -29,13 +31,15 @@ "dependency-cruiser": "^16.3.10", "eslint": "^9.7.0", "eslint-plugin-import-x": "^4.2.1", + "inquirer": "^11.0.2", "jsdom": "^24.0.0", "lefthook": "^1.6.12", + "msw": "^2.4.9", "phaser3spectorjs": "^0.0.8", "typedoc": "^0.26.4", "typescript": "^5.5.3", "typescript-eslint": "^8.0.0-alpha.54", - "vite": "^5.3.5", + "vite": "^5.4.8", "vite-tsconfig-paths": "^4.3.2", "vitest": "^2.0.4", "vitest-canvas-mock": "^0.3.3" @@ -485,6 +489,37 @@ "node": ">=6.9.0" } }, + "node_modules/@bundled-es-modules/cookie": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/@bundled-es-modules/cookie/-/cookie-2.0.0.tgz", + "integrity": "sha512-Or6YHg/kamKHpxULAdSqhGqnWFneIXu1NKvvfBBzKGwpVsYuFIQ5aBPHDnnoR3ghW1nvSkALd+EF9iMtY7Vjxw==", + "dev": true, + "license": "ISC", + "dependencies": { + "cookie": "^0.5.0" + } + }, + "node_modules/@bundled-es-modules/statuses": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/@bundled-es-modules/statuses/-/statuses-1.0.1.tgz", + "integrity": "sha512-yn7BklA5acgcBr+7w064fGV+SGIFySjCKpqjcWgBAIfrAkY+4GQTJJHQMeT3V/sgz23VTEVV8TtOmkvJAhFVfg==", + "dev": true, + "license": "ISC", + "dependencies": { + "statuses": "^2.0.1" + } + }, + "node_modules/@bundled-es-modules/tough-cookie": { + "version": "0.1.6", + "resolved": "https://registry.npmjs.org/@bundled-es-modules/tough-cookie/-/tough-cookie-0.1.6.tgz", + "integrity": "sha512-dvMHbL464C0zI+Yqxbz6kZ5TOEp7GLW+pry/RWndAR8MJQAXZ2rPmIs8tziTZjeIyhSNZgZbCePtfSbdWqStJw==", + "dev": true, + "license": "ISC", + "dependencies": { + "@types/tough-cookie": "^4.0.5", + "tough-cookie": "^4.1.4" + } + }, "node_modules/@esbuild/aix-ppc64": { "version": "0.21.5", "resolved": "https://registry.npmjs.org/@esbuild/aix-ppc64/-/aix-ppc64-0.21.5.tgz", @@ -1070,6 +1105,281 @@ "url": "https://github.com/sponsors/nzakas" } }, + "node_modules/@inquirer/checkbox": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/@inquirer/checkbox/-/checkbox-3.0.1.tgz", + "integrity": "sha512-0hm2nrToWUdD6/UHnel/UKGdk1//ke5zGUpHIvk5ZWmaKezlGxZkOJXNSWsdxO/rEqTkbB3lNC2J6nBElV2aAQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "@inquirer/core": "^9.2.1", + "@inquirer/figures": "^1.0.6", + "@inquirer/type": "^2.0.0", + "ansi-escapes": "^4.3.2", + "yoctocolors-cjs": "^2.1.2" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@inquirer/confirm": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/@inquirer/confirm/-/confirm-4.0.1.tgz", + "integrity": "sha512-46yL28o2NJ9doViqOy0VDcoTzng7rAb6yPQKU7VDLqkmbCaH4JqK4yk4XqlzNWy9PVC5pG1ZUXPBQv+VqnYs2w==", + "dev": true, + "license": "MIT", + "dependencies": { + "@inquirer/core": "^9.2.1", + "@inquirer/type": "^2.0.0" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@inquirer/core": { + "version": "9.2.1", + "resolved": "https://registry.npmjs.org/@inquirer/core/-/core-9.2.1.tgz", + "integrity": "sha512-F2VBt7W/mwqEU4bL0RnHNZmC/OxzNx9cOYxHqnXX3MP6ruYvZUZAW9imgN9+h/uBT/oP8Gh888J2OZSbjSeWcg==", + "dev": true, + "license": "MIT", + "dependencies": { + "@inquirer/figures": "^1.0.6", + "@inquirer/type": "^2.0.0", + "@types/mute-stream": "^0.0.4", + "@types/node": "^22.5.5", + "@types/wrap-ansi": "^3.0.0", + "ansi-escapes": "^4.3.2", + "cli-width": "^4.1.0", + "mute-stream": "^1.0.0", + "signal-exit": "^4.1.0", + "strip-ansi": "^6.0.1", + "wrap-ansi": "^6.2.0", + "yoctocolors-cjs": "^2.1.2" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@inquirer/core/node_modules/@types/node": { + "version": "22.5.5", + "resolved": "https://registry.npmjs.org/@types/node/-/node-22.5.5.tgz", + "integrity": "sha512-Xjs4y5UPO/CLdzpgR6GirZJx36yScjh73+2NlLlkFRSoQN8B0DpfXPdZGnvVmLRLOsqDpOfTNv7D9trgGhmOIA==", + "dev": true, + "license": "MIT", + "dependencies": { + "undici-types": "~6.19.2" + } + }, + "node_modules/@inquirer/core/node_modules/emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "dev": true, + "license": "MIT" + }, + "node_modules/@inquirer/core/node_modules/string-width": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", + "dev": true, + "license": "MIT", + "dependencies": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/@inquirer/core/node_modules/undici-types": { + "version": "6.19.8", + "resolved": "https://registry.npmjs.org/undici-types/-/undici-types-6.19.8.tgz", + "integrity": "sha512-ve2KP6f/JnbPBFyobGHuerC9g1FYGn/F8n1LWTwNxCEzd6IfqTwUQcNXgEtmmQ6DlRrC1hrSrBnCZPokRrDHjw==", + "dev": true, + "license": "MIT" + }, + "node_modules/@inquirer/core/node_modules/wrap-ansi": { + "version": "6.2.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-6.2.0.tgz", + "integrity": "sha512-r6lPcBGxZXlIcymEu7InxDMhdW0KDxpLgoFLcguasxCaJ/SOIZwINatK9KY/tf+ZrlywOKU0UDj3ATXUBfxJXA==", + "dev": true, + "license": "MIT", + "dependencies": { + "ansi-styles": "^4.0.0", + "string-width": "^4.1.0", + "strip-ansi": "^6.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/@inquirer/editor": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/@inquirer/editor/-/editor-3.0.1.tgz", + "integrity": "sha512-VA96GPFaSOVudjKFraokEEmUQg/Lub6OXvbIEZU1SDCmBzRkHGhxoFAVaF30nyiB4m5cEbDgiI2QRacXZ2hw9Q==", + "dev": true, + "license": "MIT", + "dependencies": { + "@inquirer/core": "^9.2.1", + "@inquirer/type": "^2.0.0", + "external-editor": "^3.1.0" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@inquirer/expand": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/@inquirer/expand/-/expand-3.0.1.tgz", + "integrity": "sha512-ToG8d6RIbnVpbdPdiN7BCxZGiHOTomOX94C2FaT5KOHupV40tKEDozp12res6cMIfRKrXLJyexAZhWVHgbALSQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "@inquirer/core": "^9.2.1", + "@inquirer/type": "^2.0.0", + "yoctocolors-cjs": "^2.1.2" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@inquirer/figures": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/@inquirer/figures/-/figures-1.0.6.tgz", + "integrity": "sha512-yfZzps3Cso2UbM7WlxKwZQh2Hs6plrbjs1QnzQDZhK2DgyCo6D8AaHps9olkNcUFlcYERMqU3uJSp1gmy3s/qQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=18" + } + }, + "node_modules/@inquirer/input": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/@inquirer/input/-/input-3.0.1.tgz", + "integrity": "sha512-BDuPBmpvi8eMCxqC5iacloWqv+5tQSJlUafYWUe31ow1BVXjW2a5qe3dh4X/Z25Wp22RwvcaLCc2siHobEOfzg==", + "dev": true, + "license": "MIT", + "dependencies": { + "@inquirer/core": "^9.2.1", + "@inquirer/type": "^2.0.0" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@inquirer/number": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/@inquirer/number/-/number-2.0.1.tgz", + "integrity": "sha512-QpR8jPhRjSmlr/mD2cw3IR8HRO7lSVOnqUvQa8scv1Lsr3xoAMMworcYW3J13z3ppjBFBD2ef1Ci6AE5Qn8goQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "@inquirer/core": "^9.2.1", + "@inquirer/type": "^2.0.0" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@inquirer/password": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/@inquirer/password/-/password-3.0.1.tgz", + "integrity": "sha512-haoeEPUisD1NeE2IanLOiFr4wcTXGWrBOyAyPZi1FfLJuXOzNmxCJPgUrGYKVh+Y8hfGJenIfz5Wb/DkE9KkMQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "@inquirer/core": "^9.2.1", + "@inquirer/type": "^2.0.0", + "ansi-escapes": "^4.3.2" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@inquirer/prompts": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/@inquirer/prompts/-/prompts-6.0.1.tgz", + "integrity": "sha512-yl43JD/86CIj3Mz5mvvLJqAOfIup7ncxfJ0Btnl0/v5TouVUyeEdcpknfgc+yMevS/48oH9WAkkw93m7otLb/A==", + "dev": true, + "license": "MIT", + "dependencies": { + "@inquirer/checkbox": "^3.0.1", + "@inquirer/confirm": "^4.0.1", + "@inquirer/editor": "^3.0.1", + "@inquirer/expand": "^3.0.1", + "@inquirer/input": "^3.0.1", + "@inquirer/number": "^2.0.1", + "@inquirer/password": "^3.0.1", + "@inquirer/rawlist": "^3.0.1", + "@inquirer/search": "^2.0.1", + "@inquirer/select": "^3.0.1" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@inquirer/rawlist": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/@inquirer/rawlist/-/rawlist-3.0.1.tgz", + "integrity": "sha512-VgRtFIwZInUzTiPLSfDXK5jLrnpkuSOh1ctfaoygKAdPqjcjKYmGh6sCY1pb0aGnCGsmhUxoqLDUAU0ud+lGXQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "@inquirer/core": "^9.2.1", + "@inquirer/type": "^2.0.0", + "yoctocolors-cjs": "^2.1.2" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@inquirer/search": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/@inquirer/search/-/search-2.0.1.tgz", + "integrity": "sha512-r5hBKZk3g5MkIzLVoSgE4evypGqtOannnB3PKTG9NRZxyFRKcfzrdxXXPcoJQsxJPzvdSU2Rn7pB7lw0GCmGAg==", + "dev": true, + "license": "MIT", + "dependencies": { + "@inquirer/core": "^9.2.1", + "@inquirer/figures": "^1.0.6", + "@inquirer/type": "^2.0.0", + "yoctocolors-cjs": "^2.1.2" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@inquirer/select": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/@inquirer/select/-/select-3.0.1.tgz", + "integrity": "sha512-lUDGUxPhdWMkN/fHy1Lk7pF3nK1fh/gqeyWXmctefhxLYxlDsc7vsPBEpxrfVGDsVdyYJsiJoD4bJ1b623cV1Q==", + "dev": true, + "license": "MIT", + "dependencies": { + "@inquirer/core": "^9.2.1", + "@inquirer/figures": "^1.0.6", + "@inquirer/type": "^2.0.0", + "ansi-escapes": "^4.3.2", + "yoctocolors-cjs": "^2.1.2" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@inquirer/type": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/@inquirer/type/-/type-2.0.0.tgz", + "integrity": "sha512-XvJRx+2KR3YXyYtPUUy+qd9i7p+GO9Ko6VIIpWlBrpWwXDv8WLFeHTxz35CfQFUiBMLXlGHhGzys7lqit9gWag==", + "dev": true, + "license": "MIT", + "dependencies": { + "mute-stream": "^1.0.0" + }, + "engines": { + "node": ">=18" + } + }, "node_modules/@isaacs/cliui": { "version": "8.0.2", "resolved": "https://registry.npmjs.org/@isaacs/cliui/-/cliui-8.0.2.tgz", @@ -1185,6 +1495,24 @@ "integrity": "sha512-0FCeqG6WvK4/Cc06F/xXMd/pv4FeisI0c1tUpBbfhA2n9Y8eZEv4Karjbmf2ZqQCPUWMrGp8A571tCjizxoTiQ==", "license": "Apache-2.0" }, + "node_modules/@mswjs/interceptors": { + "version": "0.35.8", + "resolved": "https://registry.npmjs.org/@mswjs/interceptors/-/interceptors-0.35.8.tgz", + "integrity": "sha512-PFfqpHplKa7KMdoQdj5td03uG05VK2Ng1dG0sP4pT9h0dGSX2v9txYt/AnrzPb/vAmfyBBC0NQV7VaBEX+efgQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "@open-draft/deferred-promise": "^2.2.0", + "@open-draft/logger": "^0.3.0", + "@open-draft/until": "^2.0.0", + "is-node-process": "^1.2.0", + "outvariant": "^1.4.3", + "strict-event-emitter": "^0.5.1" + }, + "engines": { + "node": ">=18" + } + }, "node_modules/@nodelib/fs.scandir": { "version": "2.1.5", "resolved": "https://registry.npmjs.org/@nodelib/fs.scandir/-/fs.scandir-2.1.5.tgz", @@ -1223,6 +1551,31 @@ "node": ">= 8" } }, + "node_modules/@open-draft/deferred-promise": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/@open-draft/deferred-promise/-/deferred-promise-2.2.0.tgz", + "integrity": "sha512-CecwLWx3rhxVQF6V4bAgPS5t+So2sTbPgAzafKkVizyi7tlwpcFpdFqq+wqF2OwNBmqFuu6tOyouTuxgpMfzmA==", + "dev": true, + "license": "MIT" + }, + "node_modules/@open-draft/logger": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/@open-draft/logger/-/logger-0.3.0.tgz", + "integrity": "sha512-X2g45fzhxH238HKO4xbSr7+wBS8Fvw6ixhTDuvLd5mqh6bJJCFAPwU9mPDxbcrRtfxv4u5IHCEH77BmxvXmmxQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "is-node-process": "^1.2.0", + "outvariant": "^1.4.0" + } + }, + "node_modules/@open-draft/until": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/@open-draft/until/-/until-2.1.0.tgz", + "integrity": "sha512-U69T3ItWHvLwGg5eJ0n3I62nWuE6ilHlmz7zM0npLBRvPRd7e6NYmg54vvRtP5mZG7kZqZCFVdsTWo7BPtBujg==", + "dev": true, + "license": "MIT" + }, "node_modules/@pkgjs/parseargs": { "version": "0.11.0", "resolved": "https://registry.npmjs.org/@pkgjs/parseargs/-/parseargs-0.11.0.tgz", @@ -1235,224 +1588,208 @@ } }, "node_modules/@rollup/rollup-android-arm-eabi": { - "version": "4.18.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.18.1.tgz", - "integrity": "sha512-lncuC4aHicncmbORnx+dUaAgzee9cm/PbIqgWz1PpXuwc+sa1Ct83tnqUDy/GFKleLiN7ZIeytM6KJ4cAn1SxA==", + "version": "4.22.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.22.4.tgz", + "integrity": "sha512-Fxamp4aEZnfPOcGA8KSNEohV8hX7zVHOemC8jVBoBUHu5zpJK/Eu3uJwt6BMgy9fkvzxDaurgj96F/NiLukF2w==", "cpu": [ "arm" ], "dev": true, - "license": "MIT", "optional": true, "os": [ "android" ] }, "node_modules/@rollup/rollup-android-arm64": { - "version": "4.18.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.18.1.tgz", - "integrity": "sha512-F/tkdw0WSs4ojqz5Ovrw5r9odqzFjb5LIgHdHZG65dFI1lWTWRVy32KDJLKRISHgJvqUeUhdIvy43fX41znyDg==", + "version": "4.22.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.22.4.tgz", + "integrity": "sha512-VXoK5UMrgECLYaMuGuVTOx5kcuap1Jm8g/M83RnCHBKOqvPPmROFJGQaZhGccnsFtfXQ3XYa4/jMCJvZnbJBdA==", "cpu": [ "arm64" ], "dev": true, - "license": "MIT", "optional": true, "os": [ "android" ] }, "node_modules/@rollup/rollup-darwin-arm64": { - "version": "4.18.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.18.1.tgz", - "integrity": "sha512-vk+ma8iC1ebje/ahpxpnrfVQJibTMyHdWpOGZ3JpQ7Mgn/3QNHmPq7YwjZbIE7km73dH5M1e6MRRsnEBW7v5CQ==", + "version": "4.22.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.22.4.tgz", + "integrity": "sha512-xMM9ORBqu81jyMKCDP+SZDhnX2QEVQzTcC6G18KlTQEzWK8r/oNZtKuZaCcHhnsa6fEeOBionoyl5JsAbE/36Q==", "cpu": [ "arm64" ], "dev": true, - "license": "MIT", "optional": true, "os": [ "darwin" ] }, "node_modules/@rollup/rollup-darwin-x64": { - "version": "4.18.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.18.1.tgz", - "integrity": "sha512-IgpzXKauRe1Tafcej9STjSSuG0Ghu/xGYH+qG6JwsAUxXrnkvNHcq/NL6nz1+jzvWAnQkuAJ4uIwGB48K9OCGA==", + "version": "4.22.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.22.4.tgz", + "integrity": "sha512-aJJyYKQwbHuhTUrjWjxEvGnNNBCnmpHDvrb8JFDbeSH3m2XdHcxDd3jthAzvmoI8w/kSjd2y0udT+4okADsZIw==", "cpu": [ "x64" ], "dev": true, - "license": "MIT", "optional": true, "os": [ "darwin" ] }, "node_modules/@rollup/rollup-linux-arm-gnueabihf": { - "version": "4.18.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.18.1.tgz", - "integrity": "sha512-P9bSiAUnSSM7EmyRK+e5wgpqai86QOSv8BwvkGjLwYuOpaeomiZWifEos517CwbG+aZl1T4clSE1YqqH2JRs+g==", + "version": "4.22.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.22.4.tgz", + "integrity": "sha512-j63YtCIRAzbO+gC2L9dWXRh5BFetsv0j0va0Wi9epXDgU/XUi5dJKo4USTttVyK7fGw2nPWK0PbAvyliz50SCQ==", "cpu": [ "arm" ], "dev": true, - "license": "MIT", "optional": true, "os": [ "linux" ] }, "node_modules/@rollup/rollup-linux-arm-musleabihf": { - "version": "4.18.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-musleabihf/-/rollup-linux-arm-musleabihf-4.18.1.tgz", - "integrity": "sha512-5RnjpACoxtS+aWOI1dURKno11d7krfpGDEn19jI8BuWmSBbUC4ytIADfROM1FZrFhQPSoP+KEa3NlEScznBTyQ==", + "version": "4.22.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-musleabihf/-/rollup-linux-arm-musleabihf-4.22.4.tgz", + "integrity": "sha512-dJnWUgwWBX1YBRsuKKMOlXCzh2Wu1mlHzv20TpqEsfdZLb3WoJW2kIEsGwLkroYf24IrPAvOT/ZQ2OYMV6vlrg==", "cpu": [ "arm" ], "dev": true, - "license": "MIT", "optional": true, "os": [ "linux" ] }, "node_modules/@rollup/rollup-linux-arm64-gnu": { - "version": "4.18.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.18.1.tgz", - "integrity": "sha512-8mwmGD668m8WaGbthrEYZ9CBmPug2QPGWxhJxh/vCgBjro5o96gL04WLlg5BA233OCWLqERy4YUzX3bJGXaJgQ==", + "version": "4.22.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.22.4.tgz", + "integrity": "sha512-AdPRoNi3NKVLolCN/Sp4F4N1d98c4SBnHMKoLuiG6RXgoZ4sllseuGioszumnPGmPM2O7qaAX/IJdeDU8f26Aw==", "cpu": [ "arm64" ], "dev": true, - "license": "MIT", "optional": true, "os": [ "linux" ] }, "node_modules/@rollup/rollup-linux-arm64-musl": { - "version": "4.18.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.18.1.tgz", - "integrity": "sha512-dJX9u4r4bqInMGOAQoGYdwDP8lQiisWb9et+T84l2WXk41yEej8v2iGKodmdKimT8cTAYt0jFb+UEBxnPkbXEQ==", + "version": "4.22.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.22.4.tgz", + "integrity": "sha512-Gl0AxBtDg8uoAn5CCqQDMqAx22Wx22pjDOjBdmG0VIWX3qUBHzYmOKh8KXHL4UpogfJ14G4wk16EQogF+v8hmA==", "cpu": [ "arm64" ], "dev": true, - "license": "MIT", "optional": true, "os": [ "linux" ] }, "node_modules/@rollup/rollup-linux-powerpc64le-gnu": { - "version": "4.18.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-powerpc64le-gnu/-/rollup-linux-powerpc64le-gnu-4.18.1.tgz", - "integrity": "sha512-V72cXdTl4EI0x6FNmho4D502sy7ed+LuVW6Ym8aI6DRQ9hQZdp5sj0a2usYOlqvFBNKQnLQGwmYnujo2HvjCxQ==", + "version": "4.22.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-powerpc64le-gnu/-/rollup-linux-powerpc64le-gnu-4.22.4.tgz", + "integrity": "sha512-3aVCK9xfWW1oGQpTsYJJPF6bfpWfhbRnhdlyhak2ZiyFLDaayz0EP5j9V1RVLAAxlmWKTDfS9wyRyY3hvhPoOg==", "cpu": [ "ppc64" ], "dev": true, - "license": "MIT", "optional": true, "os": [ "linux" ] }, "node_modules/@rollup/rollup-linux-riscv64-gnu": { - "version": "4.18.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.18.1.tgz", - "integrity": "sha512-f+pJih7sxoKmbjghrM2RkWo2WHUW8UbfxIQiWo5yeCaCM0TveMEuAzKJte4QskBp1TIinpnRcxkquY+4WuY/tg==", + "version": "4.22.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.22.4.tgz", + "integrity": "sha512-ePYIir6VYnhgv2C5Xe9u+ico4t8sZWXschR6fMgoPUK31yQu7hTEJb7bCqivHECwIClJfKgE7zYsh1qTP3WHUA==", "cpu": [ "riscv64" ], "dev": true, - "license": "MIT", "optional": true, "os": [ "linux" ] }, "node_modules/@rollup/rollup-linux-s390x-gnu": { - "version": "4.18.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-s390x-gnu/-/rollup-linux-s390x-gnu-4.18.1.tgz", - "integrity": "sha512-qb1hMMT3Fr/Qz1OKovCuUM11MUNLUuHeBC2DPPAWUYYUAOFWaxInaTwTQmc7Fl5La7DShTEpmYwgdt2hG+4TEg==", + "version": "4.22.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-s390x-gnu/-/rollup-linux-s390x-gnu-4.22.4.tgz", + "integrity": "sha512-GqFJ9wLlbB9daxhVlrTe61vJtEY99/xB3C8e4ULVsVfflcpmR6c8UZXjtkMA6FhNONhj2eA5Tk9uAVw5orEs4Q==", "cpu": [ "s390x" ], "dev": true, - "license": "MIT", "optional": true, "os": [ "linux" ] }, "node_modules/@rollup/rollup-linux-x64-gnu": { - "version": "4.18.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.18.1.tgz", - "integrity": "sha512-7O5u/p6oKUFYjRbZkL2FLbwsyoJAjyeXHCU3O4ndvzg2OFO2GinFPSJFGbiwFDaCFc+k7gs9CF243PwdPQFh5g==", + "version": "4.22.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.22.4.tgz", + "integrity": "sha512-87v0ol2sH9GE3cLQLNEy0K/R0pz1nvg76o8M5nhMR0+Q+BBGLnb35P0fVz4CQxHYXaAOhE8HhlkaZfsdUOlHwg==", "cpu": [ "x64" ], "dev": true, - "license": "MIT", "optional": true, "os": [ "linux" ] }, "node_modules/@rollup/rollup-linux-x64-musl": { - "version": "4.18.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.18.1.tgz", - "integrity": "sha512-pDLkYITdYrH/9Cv/Vlj8HppDuLMDUBmgsM0+N+xLtFd18aXgM9Nyqupb/Uw+HeidhfYg2lD6CXvz6CjoVOaKjQ==", + "version": "4.22.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.22.4.tgz", + "integrity": "sha512-UV6FZMUgePDZrFjrNGIWzDo/vABebuXBhJEqrHxrGiU6HikPy0Z3LfdtciIttEUQfuDdCn8fqh7wiFJjCNwO+g==", "cpu": [ "x64" ], "dev": true, - "license": "MIT", "optional": true, "os": [ "linux" ] }, "node_modules/@rollup/rollup-win32-arm64-msvc": { - "version": "4.18.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.18.1.tgz", - "integrity": "sha512-W2ZNI323O/8pJdBGil1oCauuCzmVd9lDmWBBqxYZcOqWD6aWqJtVBQ1dFrF4dYpZPks6F+xCZHfzG5hYlSHZ6g==", + "version": "4.22.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.22.4.tgz", + "integrity": "sha512-BjI+NVVEGAXjGWYHz/vv0pBqfGoUH0IGZ0cICTn7kB9PyjrATSkX+8WkguNjWoj2qSr1im/+tTGRaY+4/PdcQw==", "cpu": [ "arm64" ], "dev": true, - "license": "MIT", "optional": true, "os": [ "win32" ] }, "node_modules/@rollup/rollup-win32-ia32-msvc": { - "version": "4.18.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.18.1.tgz", - "integrity": "sha512-ELfEX1/+eGZYMaCIbK4jqLxO1gyTSOIlZr6pbC4SRYFaSIDVKOnZNMdoZ+ON0mrFDp4+H5MhwNC1H/AhE3zQLg==", + "version": "4.22.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.22.4.tgz", + "integrity": "sha512-SiWG/1TuUdPvYmzmYnmd3IEifzR61Tragkbx9D3+R8mzQqDBz8v+BvZNDlkiTtI9T15KYZhP0ehn3Dld4n9J5g==", "cpu": [ "ia32" ], "dev": true, - "license": "MIT", "optional": true, "os": [ "win32" ] }, "node_modules/@rollup/rollup-win32-x64-msvc": { - "version": "4.18.1", - "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.18.1.tgz", - "integrity": "sha512-yjk2MAkQmoaPYCSu35RLJ62+dz358nE83VfTePJRp8CG7aMg25mEJYpXFiD+NcevhX8LxD5OP5tktPXnXN7GDw==", + "version": "4.22.4", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.22.4.tgz", + "integrity": "sha512-j8pPKp53/lq9lMXN57S8cFz0MynJk8OWNuUnXct/9KCpKU7DgU3bYMJhwWmcqC0UU29p8Lr0/7KEVcaM6bf47Q==", "cpu": [ "x64" ], "dev": true, - "license": "MIT", "optional": true, "os": [ "win32" @@ -1517,6 +1854,13 @@ "eslint": ">=8.40.0" } }, + "node_modules/@types/cookie": { + "version": "0.6.0", + "resolved": "https://registry.npmjs.org/@types/cookie/-/cookie-0.6.0.tgz", + "integrity": "sha512-4Kh9a6B2bQciAhf7FSuMRRkUWecJgJu9nPnx3yzpsfXX/c50REIqpHY4C82bXP90qrLtXtkDxTZosYO3UpOwlA==", + "dev": true, + "license": "MIT" + }, "node_modules/@types/eslint": { "version": "8.56.11", "resolved": "https://registry.npmjs.org/@types/eslint/-/eslint-8.56.11.tgz", @@ -1563,6 +1907,16 @@ "dev": true, "license": "MIT" }, + "node_modules/@types/mute-stream": { + "version": "0.0.4", + "resolved": "https://registry.npmjs.org/@types/mute-stream/-/mute-stream-0.0.4.tgz", + "integrity": "sha512-CPM9nzrCPPJHQNA9keH9CVkVI+WR5kMa+7XEs5jcGQ0VoAGnLv242w8lIVgwAEfmE4oufJRaTc9PNLQl0ioAow==", + "dev": true, + "license": "MIT", + "dependencies": { + "@types/node": "*" + } + }, "node_modules/@types/node": { "version": "20.14.11", "resolved": "https://registry.npmjs.org/@types/node/-/node-20.14.11.tgz", @@ -1572,6 +1926,13 @@ "undici-types": "~5.26.4" } }, + "node_modules/@types/statuses": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/@types/statuses/-/statuses-2.0.5.tgz", + "integrity": "sha512-jmIUGWrAiwu3dZpxntxieC+1n/5c3mjrImkmOSQ2NC5uP6cYO4aAZDdSmRcI5C1oiTmqlZGHC+/NmJrKogbP5A==", + "dev": true, + "license": "MIT" + }, "node_modules/@types/tough-cookie": { "version": "4.0.5", "resolved": "https://registry.npmjs.org/@types/tough-cookie/-/tough-cookie-4.0.5.tgz", @@ -1585,6 +1946,13 @@ "integrity": "sha512-dqId9J8K/vGi5Zr7oo212BGii5m3q5Hxlkwy3WpYuKPklmBEvsbMYYyLxAQpSffdLl/gdW0XUpKWFvYmyoWCoQ==", "dev": true }, + "node_modules/@types/wrap-ansi": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/@types/wrap-ansi/-/wrap-ansi-3.0.0.tgz", + "integrity": "sha512-ltIpx+kM7g/MLRZfkbL7EsCEjfzCcScLpkg37eXEtx5kmrAKBkTJwd1GIAjDSL8wTpM6Hzn5YO4pSb91BEwu1g==", + "dev": true, + "license": "MIT" + }, "node_modules/@typescript-eslint/eslint-plugin": { "version": "8.0.0-alpha.58", "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-8.0.0-alpha.58.tgz", @@ -1970,6 +2338,22 @@ "url": "https://github.com/sponsors/epoberezkin" } }, + "node_modules/ansi-escapes": { + "version": "4.3.2", + "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.2.tgz", + "integrity": "sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "type-fest": "^0.21.3" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, "node_modules/ansi-regex": { "version": "5.0.1", "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.1.tgz", @@ -2192,6 +2576,13 @@ "url": "https://github.com/chalk/chalk?sponsor=1" } }, + "node_modules/chardet": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", + "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==", + "dev": true, + "license": "MIT" + }, "node_modules/check-error": { "version": "2.1.1", "resolved": "https://registry.npmjs.org/check-error/-/check-error-2.1.1.tgz", @@ -2202,6 +2593,16 @@ "node": ">= 16" } }, + "node_modules/cli-width": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-4.1.0.tgz", + "integrity": "sha512-ouuZd4/dm2Sw5Gmqy6bGyNNNe1qt9RpmxveLSO7KcgsTnU7RXfsw+/bukWGo1abgBiMAic068rclZsO4IWmmxQ==", + "dev": true, + "license": "ISC", + "engines": { + "node": ">= 12" + } + }, "node_modules/cliui": { "version": "8.0.1", "resolved": "https://registry.npmjs.org/cliui/-/cliui-8.0.1.tgz", @@ -2312,6 +2713,16 @@ "dev": true, "license": "MIT" }, + "node_modules/cookie": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.5.0.tgz", + "integrity": "sha512-YZ3GUyn/o8gfKJlnlX7g7xq4gyO6OSuhGPKaaGssGB2qgDUS0gPgtTvoyZLTt9Ab6dC4hfc9dV5arkvc/OCmrw==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, "node_modules/cross-fetch": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/cross-fetch/-/cross-fetch-4.0.0.tgz", @@ -3057,6 +3468,21 @@ "url": "https://github.com/sindresorhus/execa?sponsor=1" } }, + "node_modules/external-editor": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.1.0.tgz", + "integrity": "sha512-hMQ4CX1p1izmuLYyZqLMO/qGNw10wSv9QDCPfzXfyFrOaCSSoRfqE1Kf1s5an66J5JZC62NewG+mK49jOCtQew==", + "dev": true, + "license": "MIT", + "dependencies": { + "chardet": "^0.7.0", + "iconv-lite": "^0.4.24", + "tmp": "^0.0.33" + }, + "engines": { + "node": ">=4" + } + }, "node_modules/fast-deep-equal": { "version": "3.1.3", "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", @@ -3226,7 +3652,6 @@ "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", "dev": true, "hasInstallScript": true, - "license": "MIT", "optional": true, "os": [ "darwin" @@ -3415,6 +3840,16 @@ "dev": true, "license": "MIT" }, + "node_modules/graphql": { + "version": "16.9.0", + "resolved": "https://registry.npmjs.org/graphql/-/graphql-16.9.0.tgz", + "integrity": "sha512-GGTKBX4SD7Wdb8mqeDLni2oaRGYQWjWHGKPQ24ZMnUtKfcsVoiv4uX8+LJr1K6U5VW2Lu1BwJnj7uiori0YtRw==", + "dev": true, + "license": "MIT", + "engines": { + "node": "^12.22.0 || ^14.16.0 || ^16.0.0 || >=17.0.0" + } + }, "node_modules/has-flag": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", @@ -3472,6 +3907,13 @@ "node": ">= 0.4" } }, + "node_modules/headers-polyfill": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/headers-polyfill/-/headers-polyfill-4.0.3.tgz", + "integrity": "sha512-IScLbePpkvO846sIwOtOTDjutRMWdXdJmXdMvk6gCBHxFO8d+QKOQedyZSxFTTFYRSmlgSTDtXqqq4pcenBXLQ==", + "dev": true, + "license": "MIT" + }, "node_modules/html-encoding-sniffer": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/html-encoding-sniffer/-/html-encoding-sniffer-4.0.0.tgz", @@ -3563,9 +4005,10 @@ } }, "node_modules/i18next-http-backend": { - "version": "2.5.2", - "resolved": "https://registry.npmjs.org/i18next-http-backend/-/i18next-http-backend-2.5.2.tgz", - "integrity": "sha512-+K8HbDfrvc1/2X8jpb7RLhI9ZxBDpx3xogYkQwGKlWAUXLSEGXzgdt3EcUjLlBCdMwdQY+K+EUF6oh8oB6rwHw==", + "version": "2.6.1", + "resolved": "https://registry.npmjs.org/i18next-http-backend/-/i18next-http-backend-2.6.1.tgz", + "integrity": "sha512-rCilMAnlEQNeKOZY1+x8wLM5IpYOj10guGvEpeC59tNjj6MMreLIjIW8D1RclhD3ifLwn6d/Y9HEM1RUE6DSog==", + "license": "MIT", "dependencies": { "cross-fetch": "4.0.0" } @@ -3579,6 +4022,19 @@ "i18next": ">=8.4.0" } }, + "node_modules/iconv-lite": { + "version": "0.4.24", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", + "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", + "dev": true, + "license": "MIT", + "dependencies": { + "safer-buffer": ">= 2.1.2 < 3" + }, + "engines": { + "node": ">=0.10.0" + } + }, "node_modules/ignore": { "version": "5.3.1", "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.1.tgz", @@ -3626,6 +4082,26 @@ "node": "^14.17.0 || ^16.13.0 || >=18.0.0" } }, + "node_modules/inquirer": { + "version": "11.0.2", + "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-11.0.2.tgz", + "integrity": "sha512-pnbn3nL+JFrTw/pLhzyE/IQ3+gA3n5JxTAZQDjB6qu4gbjOaiTnpZbxT6HY2DDCT7bzDjTTsd3snRP+B6N//Pg==", + "dev": true, + "license": "MIT", + "dependencies": { + "@inquirer/core": "^9.2.1", + "@inquirer/prompts": "^6.0.1", + "@inquirer/type": "^2.0.0", + "@types/mute-stream": "^0.0.4", + "ansi-escapes": "^4.3.2", + "mute-stream": "^1.0.0", + "run-async": "^3.0.0", + "rxjs": "^7.8.1" + }, + "engines": { + "node": ">=18" + } + }, "node_modules/interpret": { "version": "3.1.1", "resolved": "https://registry.npmjs.org/interpret/-/interpret-3.1.1.tgz", @@ -3714,6 +4190,13 @@ "url": "https://github.com/sponsors/sindresorhus" } }, + "node_modules/is-node-process": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/is-node-process/-/is-node-process-1.2.0.tgz", + "integrity": "sha512-Vg4o6/fqPxIjtxgUH5QLJhwZ7gW5diGCVlXpuUfELC62CuxM1iHcRe51f2W1FDy04Ai4KJkagKjx3XaqyfRKXw==", + "dev": true, + "license": "MIT" + }, "node_modules/is-number": { "version": "7.0.0", "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", @@ -4447,6 +4930,90 @@ "dev": true, "license": "MIT" }, + "node_modules/msw": { + "version": "2.4.9", + "resolved": "https://registry.npmjs.org/msw/-/msw-2.4.9.tgz", + "integrity": "sha512-1m8xccT6ipN4PTqLinPwmzhxQREuxaEJYdx4nIbggxP8aM7r1e71vE7RtOUSQoAm1LydjGfZKy7370XD/tsuYg==", + "dev": true, + "hasInstallScript": true, + "license": "MIT", + "dependencies": { + "@bundled-es-modules/cookie": "^2.0.0", + "@bundled-es-modules/statuses": "^1.0.1", + "@bundled-es-modules/tough-cookie": "^0.1.6", + "@inquirer/confirm": "^3.0.0", + "@mswjs/interceptors": "^0.35.8", + "@open-draft/until": "^2.1.0", + "@types/cookie": "^0.6.0", + "@types/statuses": "^2.0.4", + "chalk": "^4.1.2", + "graphql": "^16.8.1", + "headers-polyfill": "^4.0.2", + "is-node-process": "^1.2.0", + "outvariant": "^1.4.2", + "path-to-regexp": "^6.3.0", + "strict-event-emitter": "^0.5.1", + "type-fest": "^4.9.0", + "yargs": "^17.7.2" + }, + "bin": { + "msw": "cli/index.js" + }, + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/mswjs" + }, + "peerDependencies": { + "typescript": ">= 4.8.x" + }, + "peerDependenciesMeta": { + "typescript": { + "optional": true + } + } + }, + "node_modules/msw/node_modules/@inquirer/confirm": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/@inquirer/confirm/-/confirm-3.2.0.tgz", + "integrity": "sha512-oOIwPs0Dvq5220Z8lGL/6LHRTEr9TgLHmiI99Rj1PJ1p1czTys+olrgBqZk4E2qC0YTzeHprxSQmoHioVdJ7Lw==", + "dev": true, + "license": "MIT", + "dependencies": { + "@inquirer/core": "^9.1.0", + "@inquirer/type": "^1.5.3" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/msw/node_modules/@inquirer/type": { + "version": "1.5.5", + "resolved": "https://registry.npmjs.org/@inquirer/type/-/type-1.5.5.tgz", + "integrity": "sha512-MzICLu4yS7V8AA61sANROZ9vT1H3ooca5dSmI1FjZkzq7o/koMsRfQSzRtFo+F3Ao4Sf1C0bpLKejpKB/+j6MA==", + "dev": true, + "license": "MIT", + "dependencies": { + "mute-stream": "^1.0.0" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/msw/node_modules/type-fest": { + "version": "4.26.1", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-4.26.1.tgz", + "integrity": "sha512-yOGpmOAL7CkKe/91I5O3gPICmJNLJ1G4zFYVAsRHg7M64biSnPtRj0WNQt++bRkjYOqjWXrhnUw1utzmVErAdg==", + "dev": true, + "license": "(MIT OR CC0-1.0)", + "engines": { + "node": ">=16" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, "node_modules/mustache": { "version": "4.2.0", "resolved": "https://registry.npmjs.org/mustache/-/mustache-4.2.0.tgz", @@ -4456,6 +5023,16 @@ "mustache": "bin/mustache" } }, + "node_modules/mute-stream": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-1.0.0.tgz", + "integrity": "sha512-avsJQhyd+680gKXyG/sQc0nXaC6rBkPOfyHYcFb9+hdkqQkR9bdnkJ0AMZhke0oesPqIO+mFFJ+IdBc7mst4IA==", + "dev": true, + "license": "ISC", + "engines": { + "node": "^14.17.0 || ^16.13.0 || >=18.0.0" + } + }, "node_modules/nanoid": { "version": "3.3.7", "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.7.tgz", @@ -4467,7 +5044,6 @@ "url": "https://github.com/sponsors/ai" } ], - "license": "MIT", "bin": { "nanoid": "bin/nanoid.cjs" }, @@ -4605,6 +5181,23 @@ "node": ">= 0.8.0" } }, + "node_modules/os-tmpdir": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", + "integrity": "sha512-D2FR03Vir7FIu45XBY20mTb+/ZSWB00sjU9jdQXt83gDrI4Ztz5Fs7/yy74g2N5SVQY4xY1qDr4rNddwYRVX0g==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/outvariant": { + "version": "1.4.3", + "resolved": "https://registry.npmjs.org/outvariant/-/outvariant-1.4.3.tgz", + "integrity": "sha512-+Sl2UErvtsoajRDKCE5/dBz4DIvHXQQnAxtQTF04OJxY0+DyZXSo5P5Bb7XYWOh81syohlYL24hbDwxedPUJCA==", + "dev": true, + "license": "MIT" + }, "node_modules/p-limit": { "version": "3.1.0", "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", @@ -4727,6 +5320,13 @@ "dev": true, "license": "ISC" }, + "node_modules/path-to-regexp": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-6.3.0.tgz", + "integrity": "sha512-Yhpw4T9C6hPpgPeA28us07OJeqZ5EzQTkbfwuhsUg0c237RomFoETJgmp2sa3F/41gfLE6G5cqcYwznmeEeOlQ==", + "dev": true, + "license": "MIT" + }, "node_modules/path-type": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", @@ -4842,9 +5442,9 @@ } }, "node_modules/postcss": { - "version": "8.4.39", - "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.39.tgz", - "integrity": "sha512-0vzE+lAiG7hZl1/9I8yzKLx3aR9Xbof3fBHKunvMfOCYAtMhrsnccJY2iTURb9EZd5+pLuiNV9/c/GZJOHsgIw==", + "version": "8.4.47", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.47.tgz", + "integrity": "sha512-56rxCq7G/XfB4EkXq9Egn5GCqugWvDFjafDOThIdMBsI15iqPqR5r15TfSr1YPYeEI19YeaXMCbY6u88Y76GLQ==", "dev": true, "funding": [ { @@ -4860,16 +5460,21 @@ "url": "https://github.com/sponsors/ai" } ], - "license": "MIT", "dependencies": { "nanoid": "^3.3.7", - "picocolors": "^1.0.1", - "source-map-js": "^1.2.0" + "picocolors": "^1.1.0", + "source-map-js": "^1.2.1" }, "engines": { "node": "^10 || ^12 || >=14" } }, + "node_modules/postcss/node_modules/picocolors": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/picocolors/-/picocolors-1.1.0.tgz", + "integrity": "sha512-TQ92mBOW0l3LeMeyLV6mzy/kWr8lkd/hp3mTg7wYK7zJhuBStmGMBG0BdeDZS/dZx1IukaX6Bk11zcln25o1Aw==", + "dev": true + }, "node_modules/prelude-ls": { "version": "1.2.1", "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.2.1.tgz", @@ -5052,9 +5657,9 @@ } }, "node_modules/rollup": { - "version": "4.18.1", - "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.18.1.tgz", - "integrity": "sha512-Elx2UT8lzxxOXMpy5HWQGZqkrQOtrVDDa/bm9l10+U4rQnVzbL/LgZ4NOM1MPIDyHk69W4InuYDF5dzRh4Kw1A==", + "version": "4.22.4", + "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.22.4.tgz", + "integrity": "sha512-vD8HJ5raRcWOyymsR6Z3o6+RzfEPCnVLMFJ6vRslO1jt4LO6dUo5Qnpg7y4RkZFM2DMe3WUirkI5c16onjrc6A==", "dev": true, "dependencies": { "@types/estree": "1.0.5" @@ -5067,22 +5672,22 @@ "npm": ">=8.0.0" }, "optionalDependencies": { - "@rollup/rollup-android-arm-eabi": "4.18.1", - "@rollup/rollup-android-arm64": "4.18.1", - "@rollup/rollup-darwin-arm64": "4.18.1", - "@rollup/rollup-darwin-x64": "4.18.1", - "@rollup/rollup-linux-arm-gnueabihf": "4.18.1", - "@rollup/rollup-linux-arm-musleabihf": "4.18.1", - "@rollup/rollup-linux-arm64-gnu": "4.18.1", - "@rollup/rollup-linux-arm64-musl": "4.18.1", - "@rollup/rollup-linux-powerpc64le-gnu": "4.18.1", - "@rollup/rollup-linux-riscv64-gnu": "4.18.1", - "@rollup/rollup-linux-s390x-gnu": "4.18.1", - "@rollup/rollup-linux-x64-gnu": "4.18.1", - "@rollup/rollup-linux-x64-musl": "4.18.1", - "@rollup/rollup-win32-arm64-msvc": "4.18.1", - "@rollup/rollup-win32-ia32-msvc": "4.18.1", - "@rollup/rollup-win32-x64-msvc": "4.18.1", + "@rollup/rollup-android-arm-eabi": "4.22.4", + "@rollup/rollup-android-arm64": "4.22.4", + "@rollup/rollup-darwin-arm64": "4.22.4", + "@rollup/rollup-darwin-x64": "4.22.4", + "@rollup/rollup-linux-arm-gnueabihf": "4.22.4", + "@rollup/rollup-linux-arm-musleabihf": "4.22.4", + "@rollup/rollup-linux-arm64-gnu": "4.22.4", + "@rollup/rollup-linux-arm64-musl": "4.22.4", + "@rollup/rollup-linux-powerpc64le-gnu": "4.22.4", + "@rollup/rollup-linux-riscv64-gnu": "4.22.4", + "@rollup/rollup-linux-s390x-gnu": "4.22.4", + "@rollup/rollup-linux-x64-gnu": "4.22.4", + "@rollup/rollup-linux-x64-musl": "4.22.4", + "@rollup/rollup-win32-arm64-msvc": "4.22.4", + "@rollup/rollup-win32-ia32-msvc": "4.22.4", + "@rollup/rollup-win32-x64-msvc": "4.22.4", "fsevents": "~2.3.2" } }, @@ -5092,6 +5697,16 @@ "integrity": "sha512-TrEMa7JGdVm0UThDJSx7ddw5nVm3UJS9o9CCIZ72B1vSyEZoziDqBYP3XIoi/12lKrJR8rE3jeFHMok2F/Mnsg==", "dev": true }, + "node_modules/run-async": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/run-async/-/run-async-3.0.0.tgz", + "integrity": "sha512-540WwVDOMxA6dN6We19EcT9sc3hkXPw5mzRNGM3FkdN/vtE9NFvj5lFAPNwUDmJjXidm3v7TC1cTE7t17Ulm1Q==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=0.12.0" + } + }, "node_modules/run-parallel": { "version": "1.2.0", "resolved": "https://registry.npmjs.org/run-parallel/-/run-parallel-1.2.0.tgz", @@ -5116,6 +5731,16 @@ "queue-microtask": "^1.2.2" } }, + "node_modules/rxjs": { + "version": "7.8.1", + "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-7.8.1.tgz", + "integrity": "sha512-AA3TVj+0A2iuIoQkWEK/tqFjBq2j+6PO6Y0zJcvzLAFhEFIO3HL0vls9hWLncZbAAbK0mar7oZ4V079I/qPMxg==", + "dev": true, + "license": "Apache-2.0", + "dependencies": { + "tslib": "^2.1.0" + } + }, "node_modules/safe-regex": { "version": "2.1.1", "resolved": "https://registry.npmjs.org/safe-regex/-/safe-regex-2.1.1.tgz", @@ -5246,11 +5871,10 @@ } }, "node_modules/source-map-js": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.2.0.tgz", - "integrity": "sha512-itJW8lvSA0TXEphiRoawsCksnlf8SyvmFzIhltqAHluXd88pkCd+cXJVHTDwdCr0IzwptSm035IHQktUu1QUMg==", + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.2.1.tgz", + "integrity": "sha512-UXWMKhLOwVKb728IUtQPXxfYU+usdybtUrK/8uGE8CQMvrhOpwvzDBwj0QhSL7MQc7vIsISBG8VQ8+IDQxpfQA==", "dev": true, - "license": "BSD-3-Clause", "engines": { "node": ">=0.10.0" } @@ -5269,6 +5893,16 @@ "dev": true, "license": "MIT" }, + "node_modules/statuses": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", + "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, "node_modules/std-env": { "version": "3.7.0", "resolved": "https://registry.npmjs.org/std-env/-/std-env-3.7.0.tgz", @@ -5276,6 +5910,13 @@ "dev": true, "license": "MIT" }, + "node_modules/strict-event-emitter": { + "version": "0.5.1", + "resolved": "https://registry.npmjs.org/strict-event-emitter/-/strict-event-emitter-0.5.1.tgz", + "integrity": "sha512-vMgjE/GGEPEFnhFub6pa4FmJBRBVOLpIII2hvCZ8Kzb7K0hlHo7mQv6xYrBvCL2LtAIBwFUK8wvuJgTVSQ5MFQ==", + "dev": true, + "license": "MIT" + }, "node_modules/string-width": { "version": "5.1.2", "resolved": "https://registry.npmjs.org/string-width/-/string-width-5.1.2.tgz", @@ -5538,6 +6179,19 @@ "node": ">=14.0.0" } }, + "node_modules/tmp": { + "version": "0.0.33", + "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", + "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", + "dev": true, + "license": "MIT", + "dependencies": { + "os-tmpdir": "~1.0.2" + }, + "engines": { + "node": ">=0.6.0" + } + }, "node_modules/to-fast-properties": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", @@ -5673,6 +6327,19 @@ "node": ">= 0.8.0" } }, + "node_modules/type-fest": { + "version": "0.21.3", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.21.3.tgz", + "integrity": "sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==", + "dev": true, + "license": "(MIT OR CC0-1.0)", + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, "node_modules/typedoc": { "version": "0.26.5", "resolved": "https://registry.npmjs.org/typedoc/-/typedoc-0.26.5.tgz", @@ -5807,15 +6474,14 @@ } }, "node_modules/vite": { - "version": "5.3.5", - "resolved": "https://registry.npmjs.org/vite/-/vite-5.3.5.tgz", - "integrity": "sha512-MdjglKR6AQXQb9JGiS7Rc2wC6uMjcm7Go/NHNO63EwiJXfuk9PgqiP/n5IDJCziMkfw9n4Ubp7lttNwz+8ZVKA==", + "version": "5.4.8", + "resolved": "https://registry.npmjs.org/vite/-/vite-5.4.8.tgz", + "integrity": "sha512-FqrItQ4DT1NC4zCUqMB4c4AZORMKIa0m8/URVCZ77OZ/QSNeJ54bU1vrFADbDsuwfIPcgknRkmqakQcgnL4GiQ==", "dev": true, - "license": "MIT", "dependencies": { "esbuild": "^0.21.3", - "postcss": "^8.4.39", - "rollup": "^4.13.0" + "postcss": "^8.4.43", + "rollup": "^4.20.0" }, "bin": { "vite": "bin/vite.js" @@ -5834,6 +6500,7 @@ "less": "*", "lightningcss": "^1.21.0", "sass": "*", + "sass-embedded": "*", "stylus": "*", "sugarss": "*", "terser": "^5.4.0" @@ -5851,6 +6518,9 @@ "sass": { "optional": true }, + "sass-embedded": { + "optional": true + }, "stylus": { "optional": true }, @@ -6346,6 +7016,19 @@ "funding": { "url": "https://github.com/sponsors/sindresorhus" } + }, + "node_modules/yoctocolors-cjs": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/yoctocolors-cjs/-/yoctocolors-cjs-2.1.2.tgz", + "integrity": "sha512-cYVsTjKl8b+FrnidjibDWskAv7UKOfcwaVZdp/it9n1s9fU3IkgDbhdIRKCW4JDsAlECJY0ytoVPT3sK6kideA==", + "dev": true, + "license": "MIT", + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } } } } diff --git a/package.json b/package.json index dddf5aedebd..3c65fe1a8b9 100644 --- a/package.json +++ b/package.json @@ -1,7 +1,7 @@ { "name": "pokemon-rogue-battle", "private": true, - "version": "1.0.4", + "version": "1.2.0", "type": "module", "scripts": { "start": "vite", @@ -19,7 +19,8 @@ "docs": "typedoc", "depcruise": "depcruise src", "depcruise:graph": "depcruise src --output-type dot | node dependency-graph.js > dependency-graph.svg", - "create-test": "node ./create-test-boilerplate.js" + "create-test": "node ./create-test-boilerplate.js", + "postinstall": "npx lefthook install && npx lefthook run post-merge" }, "devDependencies": { "@eslint/js": "^9.3.0", @@ -33,13 +34,15 @@ "dependency-cruiser": "^16.3.10", "eslint": "^9.7.0", "eslint-plugin-import-x": "^4.2.1", + "inquirer": "^11.0.2", "jsdom": "^24.0.0", "lefthook": "^1.6.12", + "msw": "^2.4.9", "phaser3spectorjs": "^0.0.8", "typedoc": "^0.26.4", "typescript": "^5.5.3", "typescript-eslint": "^8.0.0-alpha.54", - "vite": "^5.3.5", + "vite": "^5.4.8", "vite-tsconfig-paths": "^4.3.2", "vitest": "^2.0.4", "vitest-canvas-mock": "^0.3.3" @@ -49,6 +52,7 @@ "crypto-js": "^4.2.0", "i18next": "^23.11.1", "i18next-browser-languagedetector": "^7.2.1", + "i18next-http-backend": "^2.6.1", "i18next-korean-postposition-processor": "^1.0.0", "json-stable-stringify": "^1.1.0", "phaser": "^3.70.0", diff --git a/public/audio/bgm/battle_star_admin.mp3 b/public/audio/bgm/battle_star_admin.mp3 new file mode 100644 index 00000000000..461a9a2b262 Binary files /dev/null and b/public/audio/bgm/battle_star_admin.mp3 differ diff --git a/public/audio/bgm/battle_star_boss.mp3 b/public/audio/bgm/battle_star_boss.mp3 new file mode 100644 index 00000000000..51cb33139c6 Binary files /dev/null and b/public/audio/bgm/battle_star_boss.mp3 differ diff --git a/public/audio/bgm/battle_star_grunt.mp3 b/public/audio/bgm/battle_star_grunt.mp3 new file mode 100644 index 00000000000..13da4900eed Binary files /dev/null and b/public/audio/bgm/battle_star_grunt.mp3 differ diff --git a/public/audio/bgm/graveyard.mp3 b/public/audio/bgm/graveyard.mp3 index 48092fa3ec2..45571f16d09 100644 Binary files a/public/audio/bgm/graveyard.mp3 and b/public/audio/bgm/graveyard.mp3 differ diff --git a/public/audio/bgm/jungle.mp3 b/public/audio/bgm/jungle.mp3 index 3a21c9bdb41..fbb770b0ad3 100644 Binary files a/public/audio/bgm/jungle.mp3 and b/public/audio/bgm/jungle.mp3 differ diff --git a/public/audio/bgm/laboratory.mp3 b/public/audio/bgm/laboratory.mp3 index e2b617e590a..1eba66ef56f 100644 Binary files a/public/audio/bgm/laboratory.mp3 and b/public/audio/bgm/laboratory.mp3 differ diff --git a/public/audio/bgm/lake.mp3 b/public/audio/bgm/lake.mp3 index c61fef15e42..e6762935770 100644 Binary files a/public/audio/bgm/lake.mp3 and b/public/audio/bgm/lake.mp3 differ diff --git a/public/audio/bgm/metropolis.mp3 b/public/audio/bgm/metropolis.mp3 index 98c2eb396b6..514c9ae15b1 100644 Binary files a/public/audio/bgm/metropolis.mp3 and b/public/audio/bgm/metropolis.mp3 differ diff --git a/public/audio/bgm/mystery_encounter_delibirdy.mp3 b/public/audio/bgm/mystery_encounter_delibirdy.mp3 new file mode 100644 index 00000000000..515a429aaba Binary files /dev/null and b/public/audio/bgm/mystery_encounter_delibirdy.mp3 differ diff --git a/public/audio/bgm/mystery_encounter_fun_and_games.mp3 b/public/audio/bgm/mystery_encounter_fun_and_games.mp3 index a9660d75e90..7864bf7a73d 100644 Binary files a/public/audio/bgm/mystery_encounter_fun_and_games.mp3 and b/public/audio/bgm/mystery_encounter_fun_and_games.mp3 differ diff --git a/public/audio/bgm/mystery_encounter_gen_5_gts.mp3 b/public/audio/bgm/mystery_encounter_gen_5_gts.mp3 index 989a7f9c598..d03c8f8d4d5 100644 Binary files a/public/audio/bgm/mystery_encounter_gen_5_gts.mp3 and b/public/audio/bgm/mystery_encounter_gen_5_gts.mp3 differ diff --git a/public/audio/bgm/mystery_encounter_gen_6_gts.mp3 b/public/audio/bgm/mystery_encounter_gen_6_gts.mp3 index 2c574da66ae..c921a01c204 100644 Binary files a/public/audio/bgm/mystery_encounter_gen_6_gts.mp3 and b/public/audio/bgm/mystery_encounter_gen_6_gts.mp3 differ diff --git a/public/audio/bgm/mystery_encounter_weird_dream.mp3 b/public/audio/bgm/mystery_encounter_weird_dream.mp3 index a630fe549db..433e07bab08 100644 Binary files a/public/audio/bgm/mystery_encounter_weird_dream.mp3 and b/public/audio/bgm/mystery_encounter_weird_dream.mp3 differ diff --git a/public/audio/bgm/ruins.mp3 b/public/audio/bgm/ruins.mp3 index 62f31893423..3692c71562f 100644 Binary files a/public/audio/bgm/ruins.mp3 and b/public/audio/bgm/ruins.mp3 differ diff --git a/public/audio/cry/718-10-complete.m4a b/public/audio/cry/718-10-complete.m4a new file mode 100644 index 00000000000..94d95360553 Binary files /dev/null and b/public/audio/cry/718-10-complete.m4a differ diff --git a/public/exp-sprites.json b/public/exp-sprites.json index d514814d3f6..947bffd399d 100644 --- a/public/exp-sprites.json +++ b/public/exp-sprites.json @@ -4633,11 +4633,7 @@ "690", "691", "696", - "696_3", - "696_3", "697", - "697_3", - "697_3", "700", "704", "705_2", diff --git a/public/fonts/pkmnems.ttf b/public/fonts/pkmnems.ttf index 0aa3a19b417..b0b50d0f10f 100644 Binary files a/public/fonts/pkmnems.ttf and b/public/fonts/pkmnems.ttf differ diff --git a/public/fonts/pokemon-emerald-pro.ttf b/public/fonts/pokemon-emerald-pro.ttf index 509bd1aae86..84e49ebbc40 100644 Binary files a/public/fonts/pokemon-emerald-pro.ttf and b/public/fonts/pokemon-emerald-pro.ttf differ diff --git a/public/images/events/halloween2024-event-de.png b/public/images/events/halloween2024-event-de.png new file mode 100644 index 00000000000..a56053c73cc Binary files /dev/null and b/public/images/events/halloween2024-event-de.png differ diff --git a/public/images/events/halloween2024-event-en.png b/public/images/events/halloween2024-event-en.png new file mode 100644 index 00000000000..3886fa796ae Binary files /dev/null and b/public/images/events/halloween2024-event-en.png differ diff --git a/public/images/events/halloween2024-event-es-ES.png b/public/images/events/halloween2024-event-es-ES.png new file mode 100644 index 00000000000..dc9bac86cd0 Binary files /dev/null and b/public/images/events/halloween2024-event-es-ES.png differ diff --git a/public/images/events/halloween2024-event-fr.png b/public/images/events/halloween2024-event-fr.png new file mode 100644 index 00000000000..21df18c7471 Binary files /dev/null and b/public/images/events/halloween2024-event-fr.png differ diff --git a/public/images/events/halloween2024-event-it.png b/public/images/events/halloween2024-event-it.png new file mode 100644 index 00000000000..ce2316b2ce5 Binary files /dev/null and b/public/images/events/halloween2024-event-it.png differ diff --git a/public/images/events/halloween2024-event-ja.png b/public/images/events/halloween2024-event-ja.png new file mode 100644 index 00000000000..363f3b33b0d Binary files /dev/null and b/public/images/events/halloween2024-event-ja.png differ diff --git a/public/images/events/halloween2024-event-ko.png b/public/images/events/halloween2024-event-ko.png new file mode 100644 index 00000000000..3f52526a296 Binary files /dev/null and b/public/images/events/halloween2024-event-ko.png differ diff --git a/public/images/events/halloween2024-event-pt-BR.png b/public/images/events/halloween2024-event-pt-BR.png new file mode 100644 index 00000000000..764a9c1daa9 Binary files /dev/null and b/public/images/events/halloween2024-event-pt-BR.png differ diff --git a/public/images/events/halloween2024-event-zh-CN.png b/public/images/events/halloween2024-event-zh-CN.png new file mode 100644 index 00000000000..c2096a05d98 Binary files /dev/null and b/public/images/events/halloween2024-event-zh-CN.png differ diff --git a/public/images/items.json b/public/images/items.json index 779823d1293..9d84476a8a0 100644 --- a/public/images/items.json +++ b/public/images/items.json @@ -3353,12 +3353,12 @@ "rotated": false, "trimmed": true, "sourceSize": { - "w": 24, - "h": 23 + "w": 32, + "h": 32 }, "spriteSourceSize": { - "x": 1, - "y": 1, + "x": 5, + "y": 5, "w": 22, "h": 21 }, @@ -3416,12 +3416,12 @@ "rotated": false, "trimmed": true, "sourceSize": { - "w": 24, - "h": 24 + "w": 32, + "h": 32 }, "spriteSourceSize": { - "x": 1, - "y": 2, + "x": 5, + "y": 7, "w": 22, "h": 19 }, @@ -6583,7 +6583,7 @@ } }, { - "filename": "rb", + "filename": "pb_silver", "rotated": false, "trimmed": true, "sourceSize": { @@ -6666,6 +6666,27 @@ "h": 19 } }, + { + "filename": "rb", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 32, + "h": 32 + }, + "spriteSourceSize": { + "x": 6, + "y": 6, + "w": 20, + "h": 20 + }, + "frame": { + "x": 254, + "y": 320, + "w": 20, + "h": 20 + } + }, { "filename": "smooth_meteorite", "rotated": false, @@ -6680,27 +6701,6 @@ "w": 20, "h": 20 }, - "frame": { - "x": 254, - "y": 320, - "w": 20, - "h": 20 - } - }, - { - "filename": "strange_ball", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 32, - "h": 32 - }, - "spriteSourceSize": { - "x": 6, - "y": 6, - "w": 20, - "h": 20 - }, "frame": { "x": 274, "y": 325, @@ -6709,7 +6709,7 @@ } }, { - "filename": "ub", + "filename": "strange_ball", "rotated": false, "trimmed": true, "sourceSize": { @@ -6751,7 +6751,7 @@ } }, { - "filename": "apicot_berry", + "filename": "ub", "rotated": false, "trimmed": true, "sourceSize": { @@ -6761,13 +6761,13 @@ "spriteSourceSize": { "x": 6, "y": 6, - "w": 19, + "w": 20, "h": 20 }, "frame": { "x": 221, "y": 337, - "w": 19, + "w": 20, "h": 20 } }, @@ -6793,7 +6793,7 @@ } }, { - "filename": "big_mushroom", + "filename": "apicot_berry", "rotated": false, "trimmed": true, "sourceSize": { @@ -6804,13 +6804,13 @@ "x": 6, "y": 6, "w": 19, - "h": 19 + "h": 20 }, "frame": { "x": 343, "y": 287, "w": 19, - "h": 19 + "h": 20 } }, { @@ -6834,6 +6834,27 @@ "h": 20 } }, + { + "filename": "big_mushroom", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 32, + "h": 32 + }, + "spriteSourceSize": { + "x": 6, + "y": 6, + "w": 19, + "h": 19 + }, + "frame": { + "x": 318, + "y": 306, + "w": 19, + "h": 19 + } + }, { "filename": "hard_stone", "rotated": false, @@ -6849,33 +6870,12 @@ "h": 20 }, "frame": { - "x": 318, - "y": 306, + "x": 314, + "y": 325, "w": 19, "h": 20 } }, - { - "filename": "miracle_seed", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 32, - "h": 32 - }, - "spriteSourceSize": { - "x": 6, - "y": 7, - "w": 19, - "h": 19 - }, - "frame": { - "x": 337, - "y": 306, - "w": 19, - "h": 19 - } - }, { "filename": "wl_ability_urge", "rotated": false, @@ -6891,12 +6891,33 @@ "h": 18 }, "frame": { - "x": 314, - "y": 326, + "x": 337, + "y": 307, "w": 20, "h": 18 } }, + { + "filename": "miracle_seed", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 32, + "h": 32 + }, + "spriteSourceSize": { + "x": 6, + "y": 7, + "w": 19, + "h": 19 + }, + "frame": { + "x": 333, + "y": 325, + "w": 19, + "h": 19 + } + }, { "filename": "wl_antidote", "rotated": false, @@ -6912,12 +6933,54 @@ "h": 18 }, "frame": { - "x": 356, + "x": 357, "y": 307, "w": 20, "h": 18 } }, + { + "filename": "wl_awakening", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 32, + "h": 32 + }, + "spriteSourceSize": { + "x": 6, + "y": 8, + "w": 20, + "h": 18 + }, + "frame": { + "x": 352, + "y": 325, + "w": 20, + "h": 18 + } + }, + { + "filename": "wl_burn_heal", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 32, + "h": 32 + }, + "spriteSourceSize": { + "x": 6, + "y": 8, + "w": 20, + "h": 18 + }, + "frame": { + "x": 241, + "y": 340, + "w": 20, + "h": 18 + } + }, { "filename": "golden_egg", "rotated": false, @@ -6933,33 +6996,12 @@ "h": 20 }, "frame": { - "x": 376, - "y": 307, + "x": 372, + "y": 325, "w": 17, "h": 20 } }, - { - "filename": "wl_awakening", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 32, - "h": 32 - }, - "spriteSourceSize": { - "x": 6, - "y": 8, - "w": 20, - "h": 18 - }, - "frame": { - "x": 393, - "y": 241, - "w": 20, - "h": 18 - } - }, { "filename": "toxic_orb", "rotated": false, @@ -6975,96 +7017,12 @@ "h": 18 }, "frame": { - "x": 413, - "y": 258, + "x": 377, + "y": 307, "w": 18, "h": 18 } }, - { - "filename": "wl_burn_heal", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 32, - "h": 32 - }, - "spriteSourceSize": { - "x": 6, - "y": 8, - "w": 20, - "h": 18 - }, - "frame": { - "x": 393, - "y": 259, - "w": 20, - "h": 18 - } - }, - { - "filename": "ampharosite", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 32, - "h": 32 - }, - "spriteSourceSize": { - "x": 8, - "y": 8, - "w": 16, - "h": 16 - }, - "frame": { - "x": 377, - "y": 243, - "w": 16, - "h": 16 - } - }, - { - "filename": "audinite", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 32, - "h": 32 - }, - "spriteSourceSize": { - "x": 8, - "y": 8, - "w": 16, - "h": 16 - }, - "frame": { - "x": 377, - "y": 259, - "w": 16, - "h": 16 - } - }, - { - "filename": "relic_gold", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 32, - "h": 32 - }, - "spriteSourceSize": { - "x": 9, - "y": 11, - "w": 15, - "h": 11 - }, - "frame": { - "x": 377, - "y": 275, - "w": 15, - "h": 11 - } - }, { "filename": "lucky_egg", "rotated": false, @@ -7080,8 +7038,8 @@ "h": 20 }, "frame": { - "x": 381, - "y": 286, + "x": 389, + "y": 325, "w": 17, "h": 20 } @@ -7101,8 +7059,8 @@ "h": 18 }, "frame": { - "x": 398, - "y": 277, + "x": 352, + "y": 343, "w": 20, "h": 18 } @@ -7122,8 +7080,8 @@ "h": 18 }, "frame": { - "x": 398, - "y": 295, + "x": 372, + "y": 345, "w": 20, "h": 18 } @@ -7143,8 +7101,8 @@ "h": 18 }, "frame": { - "x": 393, - "y": 313, + "x": 392, + "y": 345, "w": 20, "h": 18 } @@ -7164,14 +7122,14 @@ "h": 18 }, "frame": { - "x": 240, - "y": 340, + "x": 378, + "y": 241, "w": 20, "h": 18 } }, { - "filename": "banettite", + "filename": "relic_gold", "rotated": false, "trimmed": true, "sourceSize": { @@ -7179,16 +7137,16 @@ "h": 32 }, "spriteSourceSize": { - "x": 8, - "y": 8, - "w": 16, - "h": 16 + "x": 9, + "y": 11, + "w": 15, + "h": 11 }, "frame": { - "x": 413, - "y": 313, - "w": 16, - "h": 16 + "x": 398, + "y": 241, + "w": 15, + "h": 11 } }, { @@ -7206,8 +7164,8 @@ "h": 18 }, "frame": { - "x": 202, - "y": 358, + "x": 377, + "y": 259, "w": 20, "h": 18 } @@ -7227,8 +7185,8 @@ "h": 18 }, "frame": { - "x": 201, - "y": 376, + "x": 381, + "y": 277, "w": 20, "h": 18 } @@ -7248,8 +7206,8 @@ "h": 18 }, "frame": { - "x": 201, - "y": 394, + "x": 397, + "y": 259, "w": 20, "h": 18 } @@ -7269,33 +7227,12 @@ "h": 18 }, "frame": { - "x": 201, - "y": 412, + "x": 401, + "y": 277, "w": 20, "h": 18 } }, - { - "filename": "beedrillite", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 32, - "h": 32 - }, - "spriteSourceSize": { - "x": 8, - "y": 8, - "w": 16, - "h": 16 - }, - "frame": { - "x": 222, - "y": 357, - "w": 16, - "h": 16 - } - }, { "filename": "wl_ice_heal", "rotated": false, @@ -7311,14 +7248,14 @@ "h": 18 }, "frame": { - "x": 238, - "y": 358, + "x": 395, + "y": 295, "w": 20, "h": 18 } }, { - "filename": "blastoisinite", + "filename": "ampharosite", "rotated": false, "trimmed": true, "sourceSize": { @@ -7332,8 +7269,29 @@ "h": 16 }, "frame": { - "x": 222, - "y": 373, + "x": 415, + "y": 295, + "w": 16, + "h": 16 + } + }, + { + "filename": "audinite", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 32, + "h": 32 + }, + "spriteSourceSize": { + "x": 8, + "y": 8, + "w": 16, + "h": 16 + }, + "frame": { + "x": 415, + "y": 311, "w": 16, "h": 16 } @@ -7353,12 +7311,33 @@ "h": 18 }, "frame": { - "x": 221, - "y": 389, + "x": 406, + "y": 327, "w": 20, "h": 18 } }, + { + "filename": "banettite", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 32, + "h": 32 + }, + "spriteSourceSize": { + "x": 8, + "y": 8, + "w": 16, + "h": 16 + }, + "frame": { + "x": 412, + "y": 345, + "w": 16, + "h": 16 + } + }, { "filename": "wl_item_urge", "rotated": false, @@ -7375,7 +7354,7 @@ }, "frame": { "x": 221, - "y": 407, + "y": 357, "w": 20, "h": 18 } @@ -7396,7 +7375,7 @@ }, "frame": { "x": 241, - "y": 376, + "y": 358, "w": 20, "h": 18 } @@ -7416,8 +7395,8 @@ "h": 18 }, "frame": { - "x": 241, - "y": 394, + "x": 201, + "y": 360, "w": 20, "h": 18 } @@ -7437,8 +7416,8 @@ "h": 18 }, "frame": { - "x": 241, - "y": 412, + "x": 201, + "y": 378, "w": 20, "h": 18 } @@ -7458,8 +7437,8 @@ "h": 18 }, "frame": { - "x": 258, - "y": 358, + "x": 221, + "y": 375, "w": 20, "h": 18 } @@ -7479,8 +7458,8 @@ "h": 18 }, "frame": { - "x": 261, - "y": 376, + "x": 201, + "y": 396, "w": 20, "h": 18 } @@ -7500,8 +7479,8 @@ "h": 18 }, "frame": { - "x": 261, - "y": 394, + "x": 221, + "y": 393, "w": 20, "h": 18 } @@ -7521,8 +7500,8 @@ "h": 18 }, "frame": { - "x": 261, - "y": 412, + "x": 241, + "y": 376, "w": 20, "h": 18 } @@ -7542,12 +7521,33 @@ "h": 18 }, "frame": { - "x": 278, - "y": 345, + "x": 241, + "y": 394, "w": 20, "h": 18 } }, + { + "filename": "beedrillite", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 32, + "h": 32 + }, + "spriteSourceSize": { + "x": 8, + "y": 8, + "w": 16, + "h": 16 + }, + "frame": { + "x": 201, + "y": 414, + "w": 16, + "h": 16 + } + }, { "filename": "wl_super_potion", "rotated": false, @@ -7563,12 +7563,33 @@ "h": 18 }, "frame": { - "x": 298, + "x": 261, "y": 345, "w": 20, "h": 18 } }, + { + "filename": "blastoisinite", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 32, + "h": 32 + }, + "spriteSourceSize": { + "x": 8, + "y": 8, + "w": 16, + "h": 16 + }, + "frame": { + "x": 261, + "y": 363, + "w": 16, + "h": 16 + } + }, { "filename": "blazikenite", "rotated": false, @@ -7584,8 +7605,8 @@ "h": 16 }, "frame": { - "x": 318, - "y": 344, + "x": 281, + "y": 345, "w": 16, "h": 16 } @@ -7605,8 +7626,8 @@ "h": 16 }, "frame": { - "x": 334, - "y": 326, + "x": 261, + "y": 379, "w": 16, "h": 16 } @@ -7626,8 +7647,8 @@ "h": 16 }, "frame": { - "x": 334, - "y": 342, + "x": 297, + "y": 345, "w": 16, "h": 16 } @@ -7647,8 +7668,8 @@ "h": 16 }, "frame": { - "x": 350, - "y": 325, + "x": 261, + "y": 395, "w": 16, "h": 16 } @@ -7668,8 +7689,8 @@ "h": 16 }, "frame": { - "x": 350, - "y": 341, + "x": 313, + "y": 345, "w": 16, "h": 16 } @@ -7689,8 +7710,8 @@ "h": 16 }, "frame": { - "x": 366, - "y": 327, + "x": 217, + "y": 414, "w": 16, "h": 16 } @@ -7710,8 +7731,8 @@ "h": 16 }, "frame": { - "x": 366, - "y": 343, + "x": 233, + "y": 412, "w": 16, "h": 16 } @@ -7731,8 +7752,8 @@ "h": 16 }, "frame": { - "x": 382, - "y": 331, + "x": 249, + "y": 412, "w": 16, "h": 16 } @@ -7752,8 +7773,8 @@ "h": 16 }, "frame": { - "x": 398, - "y": 331, + "x": 265, + "y": 411, "w": 16, "h": 16 } @@ -7773,8 +7794,8 @@ "h": 16 }, "frame": { - "x": 414, - "y": 329, + "x": 329, + "y": 345, "w": 16, "h": 16 } @@ -7794,8 +7815,8 @@ "h": 16 }, "frame": { - "x": 382, - "y": 347, + "x": 277, + "y": 363, "w": 16, "h": 16 } @@ -7815,8 +7836,8 @@ "h": 16 }, "frame": { - "x": 398, - "y": 347, + "x": 277, + "y": 379, "w": 16, "h": 16 } @@ -7836,8 +7857,8 @@ "h": 16 }, "frame": { - "x": 414, - "y": 345, + "x": 277, + "y": 395, "w": 16, "h": 16 } @@ -7857,8 +7878,8 @@ "h": 16 }, "frame": { - "x": 281, - "y": 363, + "x": 293, + "y": 361, "w": 16, "h": 16 } @@ -7878,8 +7899,8 @@ "h": 16 }, "frame": { - "x": 281, - "y": 379, + "x": 309, + "y": 361, "w": 16, "h": 16 } @@ -7899,8 +7920,8 @@ "h": 16 }, "frame": { - "x": 297, - "y": 363, + "x": 293, + "y": 377, "w": 16, "h": 16 } @@ -7920,8 +7941,8 @@ "h": 16 }, "frame": { - "x": 281, - "y": 395, + "x": 325, + "y": 361, "w": 16, "h": 16 } @@ -7941,8 +7962,8 @@ "h": 16 }, "frame": { - "x": 297, - "y": 379, + "x": 293, + "y": 393, "w": 16, "h": 16 } @@ -7961,6 +7982,90 @@ "w": 16, "h": 16 }, + "frame": { + "x": 309, + "y": 377, + "w": 16, + "h": 16 + } + }, + { + "filename": "mawilite", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 32, + "h": 32 + }, + "spriteSourceSize": { + "x": 8, + "y": 8, + "w": 16, + "h": 16 + }, + "frame": { + "x": 309, + "y": 393, + "w": 16, + "h": 16 + } + }, + { + "filename": "medichamite", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 32, + "h": 32 + }, + "spriteSourceSize": { + "x": 8, + "y": 8, + "w": 16, + "h": 16 + }, + "frame": { + "x": 325, + "y": 377, + "w": 16, + "h": 16 + } + }, + { + "filename": "metagrossite", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 32, + "h": 32 + }, + "spriteSourceSize": { + "x": 8, + "y": 8, + "w": 16, + "h": 16 + }, + "frame": { + "x": 325, + "y": 393, + "w": 16, + "h": 16 + } + }, + { + "filename": "mewtwonite_x", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 32, + "h": 32 + }, + "spriteSourceSize": { + "x": 8, + "y": 8, + "w": 16, + "h": 16 + }, "frame": { "x": 281, "y": 411, @@ -7968,90 +8073,6 @@ "h": 16 } }, - { - "filename": "mawilite", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 32, - "h": 32 - }, - "spriteSourceSize": { - "x": 8, - "y": 8, - "w": 16, - "h": 16 - }, - "frame": { - "x": 297, - "y": 395, - "w": 16, - "h": 16 - } - }, - { - "filename": "medichamite", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 32, - "h": 32 - }, - "spriteSourceSize": { - "x": 8, - "y": 8, - "w": 16, - "h": 16 - }, - "frame": { - "x": 297, - "y": 411, - "w": 16, - "h": 16 - } - }, - { - "filename": "metagrossite", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 32, - "h": 32 - }, - "spriteSourceSize": { - "x": 8, - "y": 8, - "w": 16, - "h": 16 - }, - "frame": { - "x": 313, - "y": 363, - "w": 16, - "h": 16 - } - }, - { - "filename": "mewtwonite_x", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 32, - "h": 32 - }, - "spriteSourceSize": { - "x": 8, - "y": 8, - "w": 16, - "h": 16 - }, - "frame": { - "x": 313, - "y": 379, - "w": 16, - "h": 16 - } - }, { "filename": "mewtwonite_y", "rotated": false, @@ -8067,8 +8088,8 @@ "h": 16 }, "frame": { - "x": 313, - "y": 395, + "x": 297, + "y": 409, "w": 16, "h": 16 } @@ -8089,7 +8110,7 @@ }, "frame": { "x": 313, - "y": 411, + "y": 409, "w": 16, "h": 16 } @@ -8109,8 +8130,8 @@ "h": 16 }, "frame": { - "x": 350, - "y": 357, + "x": 329, + "y": 409, "w": 16, "h": 16 } @@ -8130,8 +8151,8 @@ "h": 16 }, "frame": { - "x": 366, - "y": 359, + "x": 341, + "y": 361, "w": 16, "h": 16 } @@ -8151,8 +8172,8 @@ "h": 16 }, "frame": { - "x": 334, - "y": 358, + "x": 341, + "y": 377, "w": 16, "h": 16 } @@ -8172,8 +8193,8 @@ "h": 16 }, "frame": { - "x": 382, - "y": 363, + "x": 341, + "y": 393, "w": 16, "h": 16 } @@ -8193,8 +8214,8 @@ "h": 16 }, "frame": { - "x": 398, - "y": 363, + "x": 345, + "y": 409, "w": 16, "h": 16 } @@ -8214,7 +8235,7 @@ "h": 16 }, "frame": { - "x": 414, + "x": 412, "y": 361, "w": 16, "h": 16 @@ -8235,8 +8256,8 @@ "h": 16 }, "frame": { - "x": 329, - "y": 374, + "x": 357, + "y": 363, "w": 16, "h": 16 } @@ -8256,8 +8277,8 @@ "h": 16 }, "frame": { - "x": 329, - "y": 390, + "x": 357, + "y": 379, "w": 16, "h": 16 } @@ -8277,8 +8298,8 @@ "h": 16 }, "frame": { - "x": 329, - "y": 406, + "x": 373, + "y": 363, "w": 16, "h": 16 } @@ -8298,8 +8319,8 @@ "h": 16 }, "frame": { - "x": 345, - "y": 374, + "x": 373, + "y": 379, "w": 16, "h": 16 } @@ -8319,8 +8340,8 @@ "h": 16 }, "frame": { - "x": 345, - "y": 390, + "x": 389, + "y": 363, "w": 16, "h": 16 } @@ -8340,8 +8361,8 @@ "h": 16 }, "frame": { - "x": 345, - "y": 406, + "x": 389, + "y": 379, "w": 16, "h": 16 } @@ -8361,8 +8382,8 @@ "h": 16 }, "frame": { - "x": 361, - "y": 375, + "x": 405, + "y": 377, "w": 16, "h": 16 } @@ -8383,7 +8404,7 @@ }, "frame": { "x": 361, - "y": 391, + "y": 395, "w": 16, "h": 16 } @@ -8403,8 +8424,8 @@ "h": 16 }, "frame": { - "x": 361, - "y": 407, + "x": 377, + "y": 395, "w": 16, "h": 16 } @@ -8415,6 +8436,6 @@ "meta": { "app": "https://www.codeandweb.com/texturepacker", "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:934ea4080bad980d4fea720cc771f133:ed564bc47b79b15a763de57045178e88:110e074689c9edd2c54833ce2e4d9270$" + "smartupdate": "$TexturePacker:SmartUpdate:d91a46c431ace3f09f5ca68916a2171e:1e84369d9a13e1416fa58028d629d116:110e074689c9edd2c54833ce2e4d9270$" } } diff --git a/public/images/items.png b/public/images/items.png index 5f032b30cfb..191766f520e 100644 Binary files a/public/images/items.png and b/public/images/items.png differ diff --git a/public/images/items/berry_juice.png b/public/images/items/berry_juice.png index c0986b804f9..127fa458906 100644 Binary files a/public/images/items/berry_juice.png and b/public/images/items/berry_juice.png differ diff --git a/public/images/items/black_sludge.png b/public/images/items/black_sludge.png index 39684a40310..37aa31de43e 100644 Binary files a/public/images/items/black_sludge.png and b/public/images/items/black_sludge.png differ diff --git a/public/images/items/catching_charm.png b/public/images/items/catching_charm.png index 9d72fe465e3..c220ff70c03 100644 Binary files a/public/images/items/catching_charm.png and b/public/images/items/catching_charm.png differ diff --git a/public/images/items/pb_silver.png b/public/images/items/pb_silver.png new file mode 100644 index 00000000000..f60a8348a94 Binary files /dev/null and b/public/images/items/pb_silver.png differ diff --git a/public/images/mystery-encounters/berry_bush.json b/public/images/mystery-encounters/berries_abound_bush.json similarity index 94% rename from public/images/mystery-encounters/berry_bush.json rename to public/images/mystery-encounters/berries_abound_bush.json index 397538d8af2..749031d7da8 100644 --- a/public/images/mystery-encounters/berry_bush.json +++ b/public/images/mystery-encounters/berries_abound_bush.json @@ -1,7 +1,7 @@ { "textures": [ { - "image": "berry_bush.png", + "image": "berries_abound_bush.png", "format": "RGBA8888", "size": { "w": 49, diff --git a/public/images/mystery-encounters/berry_bush.png b/public/images/mystery-encounters/berries_abound_bush.png similarity index 100% rename from public/images/mystery-encounters/berry_bush.png rename to public/images/mystery-encounters/berries_abound_bush.png diff --git a/public/images/mystery-encounters/mad_scientist_m.json b/public/images/mystery-encounters/dark_deal_scientist.json similarity index 94% rename from public/images/mystery-encounters/mad_scientist_m.json rename to public/images/mystery-encounters/dark_deal_scientist.json index 10aa3d6f42a..95db5d1b71a 100644 --- a/public/images/mystery-encounters/mad_scientist_m.json +++ b/public/images/mystery-encounters/dark_deal_scientist.json @@ -1,7 +1,7 @@ { "textures": [ { - "image": "mad_scientist_m.png", + "image": "dark_deal_scientist.png", "format": "RGBA8888", "size": { "w": 46, diff --git a/public/images/mystery-encounters/mad_scientist_m.png b/public/images/mystery-encounters/dark_deal_scientist.png similarity index 100% rename from public/images/mystery-encounters/mad_scientist_m.png rename to public/images/mystery-encounters/dark_deal_scientist.png diff --git a/public/images/mystery-encounters/b2w2_lady.json b/public/images/mystery-encounters/department_store_sale_lady.json similarity index 99% rename from public/images/mystery-encounters/b2w2_lady.json rename to public/images/mystery-encounters/department_store_sale_lady.json index e143086e157..5ba5b2019ff 100644 --- a/public/images/mystery-encounters/b2w2_lady.json +++ b/public/images/mystery-encounters/department_store_sale_lady.json @@ -1,7 +1,7 @@ { "textures": [ { - "image": "b2w2_lady.png", + "image": "department_store_sale_lady.png", "format": "RGBA8888", "size": { "w": 399, diff --git a/public/images/mystery-encounters/b2w2_lady.png b/public/images/mystery-encounters/department_store_sale_lady.png similarity index 100% rename from public/images/mystery-encounters/b2w2_lady.png rename to public/images/mystery-encounters/department_store_sale_lady.png diff --git a/public/images/mystery-encounters/exclaim.png b/public/images/mystery-encounters/encounter_exclaim.png similarity index 100% rename from public/images/mystery-encounters/exclaim.png rename to public/images/mystery-encounters/encounter_exclaim.png diff --git a/public/images/mystery-encounters/teacher.json b/public/images/mystery-encounters/field_trip_teacher.json similarity index 94% rename from public/images/mystery-encounters/teacher.json rename to public/images/mystery-encounters/field_trip_teacher.json index 457d440a010..52a304b3421 100644 --- a/public/images/mystery-encounters/teacher.json +++ b/public/images/mystery-encounters/field_trip_teacher.json @@ -1,7 +1,7 @@ { "textures": [ { - "image": "teacher.png", + "image": "field_trip_teacher.png", "format": "RGBA8888", "size": { "w": 43, diff --git a/public/images/mystery-encounters/teacher.png b/public/images/mystery-encounters/field_trip_teacher.png similarity index 100% rename from public/images/mystery-encounters/teacher.png rename to public/images/mystery-encounters/field_trip_teacher.png diff --git a/public/images/mystery-encounters/carnival_game.json b/public/images/mystery-encounters/fun_and_games_game.json similarity index 94% rename from public/images/mystery-encounters/carnival_game.json rename to public/images/mystery-encounters/fun_and_games_game.json index 0572b95990c..71fb30fda33 100644 --- a/public/images/mystery-encounters/carnival_game.json +++ b/public/images/mystery-encounters/fun_and_games_game.json @@ -1,7 +1,7 @@ { "textures": [ { - "image": "carnival_game.png", + "image": "fun_and_games_game.png", "format": "RGBA8888", "size": { "w": 38, diff --git a/public/images/mystery-encounters/carnival_game.png b/public/images/mystery-encounters/fun_and_games_game.png similarity index 100% rename from public/images/mystery-encounters/carnival_game.png rename to public/images/mystery-encounters/fun_and_games_game.png diff --git a/public/images/mystery-encounters/carnival_man.json b/public/images/mystery-encounters/fun_and_games_man.json similarity index 94% rename from public/images/mystery-encounters/carnival_man.json rename to public/images/mystery-encounters/fun_and_games_man.json index 3e77765bbce..9536e108055 100644 --- a/public/images/mystery-encounters/carnival_man.json +++ b/public/images/mystery-encounters/fun_and_games_man.json @@ -1,7 +1,7 @@ { "textures": [ { - "image": "carnival_man.png", + "image": "fun_and_games_man.png", "format": "RGBA8888", "size": { "w": 50, diff --git a/public/images/mystery-encounters/carnival_man.png b/public/images/mystery-encounters/fun_and_games_man.png similarity index 100% rename from public/images/mystery-encounters/carnival_man.png rename to public/images/mystery-encounters/fun_and_games_man.png diff --git a/public/images/mystery-encounters/carnival_wobbuffet.json b/public/images/mystery-encounters/fun_and_games_wobbuffet.json similarity index 94% rename from public/images/mystery-encounters/carnival_wobbuffet.json rename to public/images/mystery-encounters/fun_and_games_wobbuffet.json index c059bb35a96..2f218cd208b 100644 --- a/public/images/mystery-encounters/carnival_wobbuffet.json +++ b/public/images/mystery-encounters/fun_and_games_wobbuffet.json @@ -1,7 +1,7 @@ { "textures": [ { - "image": "carnival_wobbuffet.png", + "image": "fun_and_games_wobbuffet.png", "format": "RGBA8888", "size": { "w": 45, diff --git a/public/images/mystery-encounters/carnival_wobbuffet.png b/public/images/mystery-encounters/fun_and_games_wobbuffet.png similarity index 100% rename from public/images/mystery-encounters/carnival_wobbuffet.png rename to public/images/mystery-encounters/fun_and_games_wobbuffet.png diff --git a/public/images/mystery-encounters/buoy.json b/public/images/mystery-encounters/lost_at_sea_buoy.json similarity index 100% rename from public/images/mystery-encounters/buoy.json rename to public/images/mystery-encounters/lost_at_sea_buoy.json diff --git a/public/images/mystery-encounters/buoy.png b/public/images/mystery-encounters/lost_at_sea_buoy.png similarity index 100% rename from public/images/mystery-encounters/buoy.png rename to public/images/mystery-encounters/lost_at_sea_buoy.png diff --git a/public/images/mystery-encounters/chest_blue.json b/public/images/mystery-encounters/mysterious_chest_blue.json similarity index 98% rename from public/images/mystery-encounters/chest_blue.json rename to public/images/mystery-encounters/mysterious_chest_blue.json index 916afc3242c..c55294a7bdc 100644 --- a/public/images/mystery-encounters/chest_blue.json +++ b/public/images/mystery-encounters/mysterious_chest_blue.json @@ -1,7 +1,7 @@ { "textures": [ { - "image": "chest_blue.png", + "image": "mysterious_chest_blue.png", "format": "RGBA8888", "size": { "w": 54, diff --git a/public/images/mystery-encounters/chest_blue.png b/public/images/mystery-encounters/mysterious_chest_blue.png similarity index 100% rename from public/images/mystery-encounters/chest_blue.png rename to public/images/mystery-encounters/mysterious_chest_blue.png diff --git a/public/images/mystery-encounters/chest_red.json b/public/images/mystery-encounters/mysterious_chest_red.json similarity index 98% rename from public/images/mystery-encounters/chest_red.json rename to public/images/mystery-encounters/mysterious_chest_red.json index 579cf7bda06..fe560ecf43c 100644 --- a/public/images/mystery-encounters/chest_red.json +++ b/public/images/mystery-encounters/mysterious_chest_red.json @@ -1,7 +1,7 @@ { "textures": [ { - "image": "chest_red.png", + "image": "mysterious_chest_red.png", "format": "RGBA8888", "size": { "w": 54, diff --git a/public/images/mystery-encounters/chest_red.png b/public/images/mystery-encounters/mysterious_chest_red.png similarity index 100% rename from public/images/mystery-encounters/chest_red.png rename to public/images/mystery-encounters/mysterious_chest_red.png diff --git a/public/images/mystery-encounters/warehouse_crate.json b/public/images/mystery-encounters/part_timer_crate.json similarity index 95% rename from public/images/mystery-encounters/warehouse_crate.json rename to public/images/mystery-encounters/part_timer_crate.json index fa86d1a511d..0bc67774770 100644 --- a/public/images/mystery-encounters/warehouse_crate.json +++ b/public/images/mystery-encounters/part_timer_crate.json @@ -1,7 +1,7 @@ { "textures": [ { - "image": "warehouse_crate.png", + "image": "part_timer_crate.png", "format": "RGBA8888", "size": { "w": 71, diff --git a/public/images/mystery-encounters/warehouse_crate.png b/public/images/mystery-encounters/part_timer_crate.png similarity index 100% rename from public/images/mystery-encounters/warehouse_crate.png rename to public/images/mystery-encounters/part_timer_crate.png diff --git a/public/images/mystery-encounters/bait.json b/public/images/mystery-encounters/safari_zone_bait.json similarity index 97% rename from public/images/mystery-encounters/bait.json rename to public/images/mystery-encounters/safari_zone_bait.json index ae9ee38ee13..4786dd34840 100644 --- a/public/images/mystery-encounters/bait.json +++ b/public/images/mystery-encounters/safari_zone_bait.json @@ -1,7 +1,7 @@ { "textures": [ { - "image": "bait.png", + "image": "safari_zone_bait.png", "format": "RGBA8888", "size": { "w": 14, diff --git a/public/images/mystery-encounters/bait.png b/public/images/mystery-encounters/safari_zone_bait.png similarity index 100% rename from public/images/mystery-encounters/bait.png rename to public/images/mystery-encounters/safari_zone_bait.png diff --git a/public/images/mystery-encounters/mud.json b/public/images/mystery-encounters/safari_zone_mud.json similarity index 97% rename from public/images/mystery-encounters/mud.json rename to public/images/mystery-encounters/safari_zone_mud.json index 505a6fadd27..8f58857351e 100644 --- a/public/images/mystery-encounters/mud.json +++ b/public/images/mystery-encounters/safari_zone_mud.json @@ -1,7 +1,7 @@ { "textures": [ { - "image": "mud.png", + "image": "safari_zone_mud.png", "format": "RGBA8888", "size": { "w": 14, diff --git a/public/images/mystery-encounters/mud.png b/public/images/mystery-encounters/safari_zone_mud.png similarity index 100% rename from public/images/mystery-encounters/mud.png rename to public/images/mystery-encounters/safari_zone_mud.png diff --git a/public/images/mystery-encounters/b2w2_veteran_m.json b/public/images/mystery-encounters/shady_vitamin_dealer.json similarity index 99% rename from public/images/mystery-encounters/b2w2_veteran_m.json rename to public/images/mystery-encounters/shady_vitamin_dealer.json index 8f07c7d44e2..43c707d05ca 100644 --- a/public/images/mystery-encounters/b2w2_veteran_m.json +++ b/public/images/mystery-encounters/shady_vitamin_dealer.json @@ -1,7 +1,7 @@ { "textures": [ { - "image": "b2w2_veteran_m.png", + "image": "shady_vitamin_dealer.png", "format": "RGBA8888", "size": { "w": 424, diff --git a/public/images/mystery-encounters/b2w2_veteran_m.png b/public/images/mystery-encounters/shady_vitamin_dealer.png similarity index 100% rename from public/images/mystery-encounters/b2w2_veteran_m.png rename to public/images/mystery-encounters/shady_vitamin_dealer.png diff --git a/public/images/mystery-encounters/teleporter.json b/public/images/mystery-encounters/teleporting_hijinks_teleporter.json similarity index 93% rename from public/images/mystery-encounters/teleporter.json rename to public/images/mystery-encounters/teleporting_hijinks_teleporter.json index 4fe45807be2..04a3acd4369 100644 --- a/public/images/mystery-encounters/teleporter.json +++ b/public/images/mystery-encounters/teleporting_hijinks_teleporter.json @@ -1,7 +1,7 @@ { "textures": [ { - "image": "teleporter.png", + "image": "teleporting_hijinks_teleporter.png", "format": "RGBA8888", "size": { "w": 74, diff --git a/public/images/mystery-encounters/teleporter.png b/public/images/mystery-encounters/teleporting_hijinks_teleporter.png similarity index 100% rename from public/images/mystery-encounters/teleporter.png rename to public/images/mystery-encounters/teleporting_hijinks_teleporter.png diff --git a/public/images/mystery-encounters/training_gear.json b/public/images/mystery-encounters/training_session_gear.json similarity index 94% rename from public/images/mystery-encounters/training_gear.json rename to public/images/mystery-encounters/training_session_gear.json index fb8f4ec9c8e..8196c03f305 100644 --- a/public/images/mystery-encounters/training_gear.json +++ b/public/images/mystery-encounters/training_session_gear.json @@ -1,7 +1,7 @@ { "textures": [ { - "image": "training_gear.png", + "image": "training_session_gear.png", "format": "RGBA8888", "size": { "w": 76, diff --git a/public/images/mystery-encounters/training_gear.png b/public/images/mystery-encounters/training_session_gear.png similarity index 100% rename from public/images/mystery-encounters/training_gear.png rename to public/images/mystery-encounters/training_session_gear.png diff --git a/public/images/mystery-encounters/weird_dream_woman.json b/public/images/mystery-encounters/weird_dream_woman.json index 66a9b8d68db..49ebc001d18 100644 --- a/public/images/mystery-encounters/weird_dream_woman.json +++ b/public/images/mystery-encounters/weird_dream_woman.json @@ -5,29 +5,29 @@ "format": "RGBA8888", "size": { "w": 78, - "h": 87 + "h": 86 }, "scale": 1, "frames": [ { "filename": "0001.png", "rotated": false, - "trimmed": true, + "trimmed": false, "sourceSize": { - "w": 80, - "h": 87 + "w": 78, + "h": 86 }, "spriteSourceSize": { - "x": 1, + "x": 0, "y": 0, "w": 78, - "h": 87 + "h": 86 }, "frame": { "x": 0, "y": 0, "w": 78, - "h": 87 + "h": 86 } } ] @@ -36,6 +36,6 @@ "meta": { "app": "https://www.codeandweb.com/texturepacker", "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:d3cce87ee0e3a880d840bffe9373d5d4:7c776d33b75abad1fe36b14a5e5734af:56468b7a2883e66dadcd2af13ebd8010$" + "smartupdate": "$TexturePacker:SmartUpdate:65266da62e9d2953511c0d68ae431345:c1ca63690bed8dd5af71bb443910c830:56468b7a2883e66dadcd2af13ebd8010$" } } diff --git a/public/images/mystery-encounters/weird_dream_woman.png b/public/images/mystery-encounters/weird_dream_woman.png index 1b8d142ed5b..50d04667152 100644 Binary files a/public/images/mystery-encounters/weird_dream_woman.png and b/public/images/mystery-encounters/weird_dream_woman.png differ diff --git a/public/images/pokemon/1012-counterfeit.png b/public/images/pokemon/1012-counterfeit.png index 2482debd312..32d9c1790c9 100644 Binary files a/public/images/pokemon/1012-counterfeit.png and b/public/images/pokemon/1012-counterfeit.png differ diff --git a/public/images/pokemon/1013-unremarkable.png b/public/images/pokemon/1013-unremarkable.png index a70954685ed..aaf57aa1a02 100644 Binary files a/public/images/pokemon/1013-unremarkable.png and b/public/images/pokemon/1013-unremarkable.png differ diff --git a/public/images/pokemon/154.png b/public/images/pokemon/154.png index 74370115aa6..7547d4c573a 100644 Binary files a/public/images/pokemon/154.png and b/public/images/pokemon/154.png differ diff --git a/public/images/pokemon/172-spiky.png b/public/images/pokemon/172-spiky.png index 2a02c6fb268..f74c6574344 100644 Binary files a/public/images/pokemon/172-spiky.png and b/public/images/pokemon/172-spiky.png differ diff --git a/public/images/pokemon/172.png b/public/images/pokemon/172.png index 435ebbe4c63..9e96ff34936 100644 Binary files a/public/images/pokemon/172.png and b/public/images/pokemon/172.png differ diff --git a/public/images/pokemon/194.png b/public/images/pokemon/194.png index 589c2ae155a..d126190685b 100644 Binary files a/public/images/pokemon/194.png and b/public/images/pokemon/194.png differ diff --git a/public/images/pokemon/198.png b/public/images/pokemon/198.png index 3d6c15f1a1d..5a310216129 100644 Binary files a/public/images/pokemon/198.png and b/public/images/pokemon/198.png differ diff --git a/public/images/pokemon/2026.png b/public/images/pokemon/2026.png index 78c881eb10d..fde7405f65a 100644 Binary files a/public/images/pokemon/2026.png and b/public/images/pokemon/2026.png differ diff --git a/public/images/pokemon/25-beauty-cosplay.png b/public/images/pokemon/25-beauty-cosplay.png index a0c4c5717b2..0db73184c8e 100644 Binary files a/public/images/pokemon/25-beauty-cosplay.png and b/public/images/pokemon/25-beauty-cosplay.png differ diff --git a/public/images/pokemon/25-cool-cosplay.png b/public/images/pokemon/25-cool-cosplay.png index 209509f12fc..123ae257598 100644 Binary files a/public/images/pokemon/25-cool-cosplay.png and b/public/images/pokemon/25-cool-cosplay.png differ diff --git a/public/images/pokemon/25-cosplay.png b/public/images/pokemon/25-cosplay.png index 9a70984cc8b..217ab730cc4 100644 Binary files a/public/images/pokemon/25-cosplay.png and b/public/images/pokemon/25-cosplay.png differ diff --git a/public/images/pokemon/25-cute-cosplay.png b/public/images/pokemon/25-cute-cosplay.png index 5c4adce2304..17fdfd32609 100644 Binary files a/public/images/pokemon/25-cute-cosplay.png and b/public/images/pokemon/25-cute-cosplay.png differ diff --git a/public/images/pokemon/25-gigantamax.png b/public/images/pokemon/25-gigantamax.png index b9f3f037788..e39511341a3 100644 Binary files a/public/images/pokemon/25-gigantamax.png and b/public/images/pokemon/25-gigantamax.png differ diff --git a/public/images/pokemon/25-partner.png b/public/images/pokemon/25-partner.png index 7b1104a3a55..f1cb33f9701 100644 Binary files a/public/images/pokemon/25-partner.png and b/public/images/pokemon/25-partner.png differ diff --git a/public/images/pokemon/25-smart-cosplay.png b/public/images/pokemon/25-smart-cosplay.png index edafa4d2a21..603837dd34f 100644 Binary files a/public/images/pokemon/25-smart-cosplay.png and b/public/images/pokemon/25-smart-cosplay.png differ diff --git a/public/images/pokemon/25-tough-cosplay.png b/public/images/pokemon/25-tough-cosplay.png index ecadee4ff27..380269b87e7 100644 Binary files a/public/images/pokemon/25-tough-cosplay.png and b/public/images/pokemon/25-tough-cosplay.png differ diff --git a/public/images/pokemon/25.png b/public/images/pokemon/25.png index 7b1104a3a55..f1cb33f9701 100644 Binary files a/public/images/pokemon/25.png and b/public/images/pokemon/25.png differ diff --git a/public/images/pokemon/26.png b/public/images/pokemon/26.png index ae0a7aeab62..f2cdf63c718 100644 Binary files a/public/images/pokemon/26.png and b/public/images/pokemon/26.png differ diff --git a/public/images/pokemon/275.png b/public/images/pokemon/275.png index 07a6fe725ad..61f98ed1655 100644 Binary files a/public/images/pokemon/275.png and b/public/images/pokemon/275.png differ diff --git a/public/images/pokemon/276.png b/public/images/pokemon/276.png index 1b24f59d105..a191440497c 100644 Binary files a/public/images/pokemon/276.png and b/public/images/pokemon/276.png differ diff --git a/public/images/pokemon/277.png b/public/images/pokemon/277.png index 3c4475e5fce..2ec0b9b8a9a 100644 Binary files a/public/images/pokemon/277.png and b/public/images/pokemon/277.png differ diff --git a/public/images/pokemon/280.png b/public/images/pokemon/280.png index 47b4a0c32d4..7ec5a339757 100644 Binary files a/public/images/pokemon/280.png and b/public/images/pokemon/280.png differ diff --git a/public/images/pokemon/281.json b/public/images/pokemon/281.json index 8e865cdc935..cb1a43f256f 100644 --- a/public/images/pokemon/281.json +++ b/public/images/pokemon/281.json @@ -399,13 +399,13 @@ "x": 0, "y": 6, "w": 36, - "h": 55 + "h": 54 }, "frame": { "x": 72, "y": 55, "w": 36, - "h": 55 + "h": 54 } }, { @@ -420,13 +420,13 @@ "x": 0, "y": 6, "w": 36, - "h": 55 + "h": 54 }, "frame": { "x": 72, "y": 55, "w": 36, - "h": 55 + "h": 54 } }, { diff --git a/public/images/pokemon/281.png b/public/images/pokemon/281.png index 48293ca0bc1..15b9eecb9ec 100644 Binary files a/public/images/pokemon/281.png and b/public/images/pokemon/281.png differ diff --git a/public/images/pokemon/282.png b/public/images/pokemon/282.png index 8d795bd6927..7b2460756b6 100644 Binary files a/public/images/pokemon/282.png and b/public/images/pokemon/282.png differ diff --git a/public/images/pokemon/359-mega.png b/public/images/pokemon/359-mega.png index 99e95151b79..9c026d78779 100644 Binary files a/public/images/pokemon/359-mega.png and b/public/images/pokemon/359-mega.png differ diff --git a/public/images/pokemon/359.png b/public/images/pokemon/359.png index bb02f52637e..e5a1d168ad2 100644 Binary files a/public/images/pokemon/359.png and b/public/images/pokemon/359.png differ diff --git a/public/images/pokemon/379.png b/public/images/pokemon/379.png index dd430eb9d70..3a4185ffaf6 100644 Binary files a/public/images/pokemon/379.png and b/public/images/pokemon/379.png differ diff --git a/public/images/pokemon/390.png b/public/images/pokemon/390.png index 7bd6fd2de90..e96b6631c8a 100644 Binary files a/public/images/pokemon/390.png and b/public/images/pokemon/390.png differ diff --git a/public/images/pokemon/391.png b/public/images/pokemon/391.png index 480894c9373..bb6abefada7 100644 Binary files a/public/images/pokemon/391.png and b/public/images/pokemon/391.png differ diff --git a/public/images/pokemon/392.png b/public/images/pokemon/392.png index 5c65d92889b..b65da9eecb4 100644 Binary files a/public/images/pokemon/392.png and b/public/images/pokemon/392.png differ diff --git a/public/images/pokemon/40.png b/public/images/pokemon/40.png index 4d2cc4f1d60..e6b59c51bfe 100644 Binary files a/public/images/pokemon/40.png and b/public/images/pokemon/40.png differ diff --git a/public/images/pokemon/4145.png b/public/images/pokemon/4145.png index 6d17b0e7adb..7988a7b4f01 100644 Binary files a/public/images/pokemon/4145.png and b/public/images/pokemon/4145.png differ diff --git a/public/images/pokemon/4146.png b/public/images/pokemon/4146.png index 524bd5f10c3..1c18e4c1b65 100644 Binary files a/public/images/pokemon/4146.png and b/public/images/pokemon/4146.png differ diff --git a/public/images/pokemon/430.png b/public/images/pokemon/430.png index 07aca365e02..5ed0fb19c20 100644 Binary files a/public/images/pokemon/430.png and b/public/images/pokemon/430.png differ diff --git a/public/images/pokemon/436.json b/public/images/pokemon/436.json index dc6c1d23770..6206c5e66cb 100644 --- a/public/images/pokemon/436.json +++ b/public/images/pokemon/436.json @@ -1,2666 +1,1019 @@ -{ - "textures": [ - { - "image": "436.png", - "format": "RGBA8888", - "size": { - "w": 97, - "h": 97 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 5, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 5, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 5, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 5, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 5, - "y": 9, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 5, - "y": 9, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 10, - "y": 8, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 10, - "y": 8, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 5, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 5, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 4, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 4, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 3, - "y": 8, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 3, - "y": 8, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 5, - "y": 6, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 5, - "y": 6, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 5, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 5, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 9, - "y": 6, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 9, - "y": 6, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 11, - "y": 8, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 11, - "y": 8, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 10, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 10, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 9, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 9, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 4, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 4, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 3, - "y": 9, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 3, - "y": 9, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 1, - "y": 6, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 1, - "y": 6, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 4, - "y": 3, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 4, - "y": 3, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 2, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 2, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 10, - "y": 3, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 10, - "y": 3, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 13, - "y": 6, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 13, - "y": 6, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 11, - "y": 9, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 11, - "y": 9, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 10, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 10, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 3, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 3, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 1, - "y": 8, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 1, - "y": 8, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 11, - "y": 4, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 11, - "y": 4, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 13, - "y": 14, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 13, - "y": 14, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 10, - "y": 17, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 10, - "y": 17, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 15, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 15, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 8, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 8, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 9, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 9, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 6, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 6, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 8, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 8, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 0, - "y": 4, - "w": 32, - "h": 39 - }, - "frame": { - "x": 33, - "y": 0, - "w": 32, - "h": 39 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 0, - "y": 4, - "w": 32, - "h": 39 - }, - "frame": { - "x": 33, - "y": 0, - "w": 32, - "h": 39 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 15, - "y": 9, - "w": 32, - "h": 39 - }, - "frame": { - "x": 65, - "y": 0, - "w": 32, - "h": 39 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 15, - "y": 9, - "w": 32, - "h": 39 - }, - "frame": { - "x": 65, - "y": 0, - "w": 32, - "h": 39 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 0, - "w": 33, - "h": 38 - }, - "frame": { - "x": 0, - "y": 39, - "w": 33, - "h": 38 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 0, - "w": 33, - "h": 38 - }, - "frame": { - "x": 0, - "y": 39, - "w": 33, - "h": 38 - } - }, - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 5, - "y": 21, - "w": 33, - "h": 38 - }, - "frame": { - "x": 33, - "y": 39, - "w": 33, - "h": 38 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 5, - "y": 21, - "w": 33, - "h": 38 - }, - "frame": { - "x": 33, - "y": 39, - "w": 33, - "h": 38 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:2b46b60048375cd75fb24de5f2dd05a3:de64de523e63943f7f5dc5a59d03e108:0a3bacf3d680738b160c4c8ace3cda59$" - } -} +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0002.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0003.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0004.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0005.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0006.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0007.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0008.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0009.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0010.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0011.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0012.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0013.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0014.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0015.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0016.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0017.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0018.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0019.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0020.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0021.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0022.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0023.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0024.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0025.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0026.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0027.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0028.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0029.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0030.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0031.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0032.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0033.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0034.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0035.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0036.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0037.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 10, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0038.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 10, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0039.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0040.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0041.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0042.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0043.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0044.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0045.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 11, "y": 9, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0046.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 11, "y": 9, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0047.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0048.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0049.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0050.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0051.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0052.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0053.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0054.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0055.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 9, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0056.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 9, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0057.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 7, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0058.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 7, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0059.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 6, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0060.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 6, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0061.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 7, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0062.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 7, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0063.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 9, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0064.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 9, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0065.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 11, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0066.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 11, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0067.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0068.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0069.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0070.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0071.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0072.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0073.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 10, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0074.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 10, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0075.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 2, "y": 7, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0076.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 2, "y": 7, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0077.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 4, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0078.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 4, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0079.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 3, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0080.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 3, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0081.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 11, "y": 4, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0082.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 11, "y": 4, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0083.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 14, "y": 7, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0084.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 14, "y": 7, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0085.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 10, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0086.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 10, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0087.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 11, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0088.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 11, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0089.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0090.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0091.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0092.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0093.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 2, "y": 9, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0094.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 2, "y": 9, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0095.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 0, "y": 5, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0096.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 0, "y": 5, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0097.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 1, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0098.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 1, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0099.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 0, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0100.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 0, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0101.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 5, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0102.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 5, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0103.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 16, "y": 10, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0104.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 16, "y": 10, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0105.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 14, "y": 15, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0106.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 14, "y": 15, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0107.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 11, "y": 18, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0108.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 11, "y": 18, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0109.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 22, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0110.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 22, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0111.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 19, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0112.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 19, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0113.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 16, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0114.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 16, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0115.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0116.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0117.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 10, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0118.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 10, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0119.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 7, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0120.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 7, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0121.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 9, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0122.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 9, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0123.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0124.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0125.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0126.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.7-dev", + "image": "436.png", + "format": "RGBA8888", + "size": { "w": 31, "h": 37 }, + "scale": "1" + } +} diff --git a/public/images/pokemon/436.png b/public/images/pokemon/436.png index 1ca185baecd..0308cb7303a 100644 Binary files a/public/images/pokemon/436.png and b/public/images/pokemon/436.png differ diff --git a/public/images/pokemon/454.png b/public/images/pokemon/454.png index 482c334bd99..bf41f256575 100644 Binary files a/public/images/pokemon/454.png and b/public/images/pokemon/454.png differ diff --git a/public/images/pokemon/455.png b/public/images/pokemon/455.png index 9518bc019fe..731abfec4e6 100644 Binary files a/public/images/pokemon/455.png and b/public/images/pokemon/455.png differ diff --git a/public/images/pokemon/486.png b/public/images/pokemon/486.png index aaee1287a47..328ed80c995 100644 Binary files a/public/images/pokemon/486.png and b/public/images/pokemon/486.png differ diff --git a/public/images/pokemon/493-fairy.json b/public/images/pokemon/493-fairy.json index 10a2c1b8936..b48a4d31370 100644 --- a/public/images/pokemon/493-fairy.json +++ b/public/images/pokemon/493-fairy.json @@ -4,30 +4,1773 @@ "image": "493-fairy.png", "format": "RGBA8888", "size": { - "w": 73, - "h": 73 + "w": 380, + "h": 380 }, "scale": 1, "frames": [ { - "filename": "0001.png", + "filename": "0056.png", "rotated": false, - "trimmed": false, + "trimmed": true, "sourceSize": { - "w": 68, - "h": 73 + "w": 69, + "h": 82 }, "spriteSourceSize": { - "x": 0, + "x": 2, "y": 0, - "w": 68, - "h": 73 + "w": 67, + "h": 81 }, "frame": { "x": 0, "y": 0, + "w": 67, + "h": 81 + } + }, + { + "filename": "0055.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 3, + "y": 0, + "w": 66, + "h": 81 + }, + "frame": { + "x": 0, + "y": 81, + "w": 66, + "h": 81 + } + }, + { + "filename": "0057.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 3, + "y": 0, + "w": 66, + "h": 81 + }, + "frame": { + "x": 67, + "y": 0, + "w": 66, + "h": 81 + } + }, + { + "filename": "0052.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 3, + "y": 1, + "w": 66, + "h": 80 + }, + "frame": { + "x": 0, + "y": 162, + "w": 66, + "h": 80 + } + }, + { + "filename": "0002.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 5, + "w": 69, + "h": 76 + }, + "frame": { + "x": 133, + "y": 0, + "w": 69, + "h": 76 + } + }, + { + "filename": "0014.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 5, + "w": 69, + "h": 76 + }, + "frame": { + "x": 133, + "y": 0, + "w": 69, + "h": 76 + } + }, + { + "filename": "0026.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 5, + "w": 69, + "h": 76 + }, + "frame": { + "x": 133, + "y": 0, + "w": 69, + "h": 76 + } + }, + { + "filename": "0038.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 5, + "w": 69, + "h": 76 + }, + "frame": { + "x": 133, + "y": 0, + "w": 69, + "h": 76 + } + }, + { + "filename": "0061.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 5, + "w": 69, + "h": 76 + }, + "frame": { + "x": 133, + "y": 0, + "w": 69, + "h": 76 + } + }, + { + "filename": "0073.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 5, + "w": 69, + "h": 76 + }, + "frame": { + "x": 133, + "y": 0, + "w": 69, + "h": 76 + } + }, + { + "filename": "0051.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 3, + "y": 2, + "w": 66, + "h": 79 + }, + "frame": { + "x": 66, + "y": 81, + "w": 66, + "h": 79 + } + }, + { + "filename": "0053.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 5, + "y": 0, + "w": 64, + "h": 81 + }, + "frame": { + "x": 0, + "y": 242, + "w": 64, + "h": 81 + } + }, + { + "filename": "0054.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 5, + "y": 0, + "w": 64, + "h": 81 + }, + "frame": { + "x": 66, + "y": 160, + "w": 64, + "h": 81 + } + }, + { + "filename": "0001.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 5, "w": 68, + "h": 76 + }, + "frame": { + "x": 202, + "y": 0, + "w": 68, + "h": 76 + } + }, + { + "filename": "0013.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 5, + "w": 68, + "h": 76 + }, + "frame": { + "x": 202, + "y": 0, + "w": 68, + "h": 76 + } + }, + { + "filename": "0025.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 5, + "w": 68, + "h": 76 + }, + "frame": { + "x": 202, + "y": 0, + "w": 68, + "h": 76 + } + }, + { + "filename": "0037.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 5, + "w": 68, + "h": 76 + }, + "frame": { + "x": 202, + "y": 0, + "w": 68, + "h": 76 + } + }, + { + "filename": "0049.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 5, + "w": 68, + "h": 76 + }, + "frame": { + "x": 202, + "y": 0, + "w": 68, + "h": 76 + } + }, + { + "filename": "0060.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 5, + "w": 68, + "h": 76 + }, + "frame": { + "x": 202, + "y": 0, + "w": 68, + "h": 76 + } + }, + { + "filename": "0072.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 5, + "w": 68, + "h": 76 + }, + "frame": { + "x": 202, + "y": 0, + "w": 68, + "h": 76 + } + }, + { + "filename": "0084.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 5, + "w": 68, + "h": 76 + }, + "frame": { + "x": 202, + "y": 0, + "w": 68, + "h": 76 + } + }, + { + "filename": "0003.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 1, + "y": 5, + "w": 68, + "h": 76 + }, + "frame": { + "x": 270, + "y": 0, + "w": 68, + "h": 76 + } + }, + { + "filename": "0015.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 1, + "y": 5, + "w": 68, + "h": 76 + }, + "frame": { + "x": 270, + "y": 0, + "w": 68, + "h": 76 + } + }, + { + "filename": "0027.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 1, + "y": 5, + "w": 68, + "h": 76 + }, + "frame": { + "x": 270, + "y": 0, + "w": 68, + "h": 76 + } + }, + { + "filename": "0039.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 1, + "y": 5, + "w": 68, + "h": 76 + }, + "frame": { + "x": 270, + "y": 0, + "w": 68, + "h": 76 + } + }, + { + "filename": "0062.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 1, + "y": 5, + "w": 68, + "h": 76 + }, + "frame": { + "x": 270, + "y": 0, + "w": 68, + "h": 76 + } + }, + { + "filename": "0074.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 1, + "y": 5, + "w": 68, + "h": 76 + }, + "frame": { + "x": 270, + "y": 0, + "w": 68, + "h": 76 + } + }, + { + "filename": "0058.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 3, + "y": 2, + "w": 66, + "h": 79 + }, + "frame": { + "x": 64, + "y": 242, + "w": 66, + "h": 79 + } + }, + { + "filename": "0050.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 1, + "y": 4, + "w": 68, + "h": 77 + }, + "frame": { + "x": 130, + "y": 160, + "w": 68, + "h": 77 + } + }, + { + "filename": "0059.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 1, + "y": 5, + "w": 68, + "h": 77 + }, + "frame": { + "x": 130, + "y": 237, + "w": 68, + "h": 77 + } + }, + { + "filename": "0004.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 1, + "y": 5, + "w": 68, + "h": 76 + }, + "frame": { + "x": 132, + "y": 81, + "w": 68, + "h": 76 + } + }, + { + "filename": "0016.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 1, + "y": 5, + "w": 68, + "h": 76 + }, + "frame": { + "x": 132, + "y": 81, + "w": 68, + "h": 76 + } + }, + { + "filename": "0028.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 1, + "y": 5, + "w": 68, + "h": 76 + }, + "frame": { + "x": 132, + "y": 81, + "w": 68, + "h": 76 + } + }, + { + "filename": "0040.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 1, + "y": 5, + "w": 68, + "h": 76 + }, + "frame": { + "x": 132, + "y": 81, + "w": 68, + "h": 76 + } + }, + { + "filename": "0063.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 1, + "y": 5, + "w": 68, + "h": 76 + }, + "frame": { + "x": 132, + "y": 81, + "w": 68, + "h": 76 + } + }, + { + "filename": "0075.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 1, + "y": 5, + "w": 68, + "h": 76 + }, + "frame": { + "x": 132, + "y": 81, + "w": 68, + "h": 76 + } + }, + { + "filename": "0012.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 5, + "w": 68, + "h": 76 + }, + "frame": { + "x": 200, + "y": 76, + "w": 68, + "h": 76 + } + }, + { + "filename": "0024.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 5, + "w": 68, + "h": 76 + }, + "frame": { + "x": 200, + "y": 76, + "w": 68, + "h": 76 + } + }, + { + "filename": "0036.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 5, + "w": 68, + "h": 76 + }, + "frame": { + "x": 200, + "y": 76, + "w": 68, + "h": 76 + } + }, + { + "filename": "0048.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 5, + "w": 68, + "h": 76 + }, + "frame": { + "x": 200, + "y": 76, + "w": 68, + "h": 76 + } + }, + { + "filename": "0071.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 5, + "w": 68, + "h": 76 + }, + "frame": { + "x": 200, + "y": 76, + "w": 68, + "h": 76 + } + }, + { + "filename": "0083.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 5, + "w": 68, + "h": 76 + }, + "frame": { + "x": 200, + "y": 76, + "w": 68, + "h": 76 + } + }, + { + "filename": "0005.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 6, + "w": 68, + "h": 75 + }, + "frame": { + "x": 268, + "y": 76, + "w": 68, + "h": 75 + } + }, + { + "filename": "0017.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 6, + "w": 68, + "h": 75 + }, + "frame": { + "x": 268, + "y": 76, + "w": 68, + "h": 75 + } + }, + { + "filename": "0029.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 6, + "w": 68, + "h": 75 + }, + "frame": { + "x": 268, + "y": 76, + "w": 68, + "h": 75 + } + }, + { + "filename": "0041.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 6, + "w": 68, + "h": 75 + }, + "frame": { + "x": 268, + "y": 76, + "w": 68, + "h": 75 + } + }, + { + "filename": "0064.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 6, + "w": 68, + "h": 75 + }, + "frame": { + "x": 268, + "y": 76, + "w": 68, + "h": 75 + } + }, + { + "filename": "0076.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 6, + "w": 68, + "h": 75 + }, + "frame": { + "x": 268, + "y": 76, + "w": 68, + "h": 75 + } + }, + { + "filename": "0006.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 6, + "w": 67, + "h": 75 + }, + "frame": { + "x": 198, + "y": 157, + "w": 67, + "h": 75 + } + }, + { + "filename": "0018.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 6, + "w": 67, + "h": 75 + }, + "frame": { + "x": 198, + "y": 157, + "w": 67, + "h": 75 + } + }, + { + "filename": "0030.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 6, + "w": 67, + "h": 75 + }, + "frame": { + "x": 198, + "y": 157, + "w": 67, + "h": 75 + } + }, + { + "filename": "0042.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 6, + "w": 67, + "h": 75 + }, + "frame": { + "x": 198, + "y": 157, + "w": 67, + "h": 75 + } + }, + { + "filename": "0065.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 6, + "w": 67, + "h": 75 + }, + "frame": { + "x": 198, + "y": 157, + "w": 67, + "h": 75 + } + }, + { + "filename": "0077.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 6, + "w": 67, + "h": 75 + }, + "frame": { + "x": 198, + "y": 157, + "w": 67, + "h": 75 + } + }, + { + "filename": "0010.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 6, + "w": 67, + "h": 75 + }, + "frame": { + "x": 198, + "y": 232, + "w": 67, + "h": 75 + } + }, + { + "filename": "0022.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 6, + "w": 67, + "h": 75 + }, + "frame": { + "x": 198, + "y": 232, + "w": 67, + "h": 75 + } + }, + { + "filename": "0034.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 6, + "w": 67, + "h": 75 + }, + "frame": { + "x": 198, + "y": 232, + "w": 67, + "h": 75 + } + }, + { + "filename": "0046.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 6, + "w": 67, + "h": 75 + }, + "frame": { + "x": 198, + "y": 232, + "w": 67, + "h": 75 + } + }, + { + "filename": "0069.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 6, + "w": 67, + "h": 75 + }, + "frame": { + "x": 198, + "y": 232, + "w": 67, + "h": 75 + } + }, + { + "filename": "0081.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 6, + "w": 67, + "h": 75 + }, + "frame": { + "x": 198, + "y": 232, + "w": 67, + "h": 75 + } + }, + { + "filename": "0008.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 66, "h": 73 + }, + "frame": { + "x": 198, + "y": 307, + "w": 66, + "h": 73 + } + }, + { + "filename": "0020.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 66, + "h": 73 + }, + "frame": { + "x": 198, + "y": 307, + "w": 66, + "h": 73 + } + }, + { + "filename": "0032.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 66, + "h": 73 + }, + "frame": { + "x": 198, + "y": 307, + "w": 66, + "h": 73 + } + }, + { + "filename": "0044.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 66, + "h": 73 + }, + "frame": { + "x": 198, + "y": 307, + "w": 66, + "h": 73 + } + }, + { + "filename": "0067.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 66, + "h": 73 + }, + "frame": { + "x": 198, + "y": 307, + "w": 66, + "h": 73 + } + }, + { + "filename": "0079.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 66, + "h": 73 + }, + "frame": { + "x": 198, + "y": 307, + "w": 66, + "h": 73 + } + }, + { + "filename": "0007.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 65, + "h": 73 + }, + "frame": { + "x": 264, + "y": 307, + "w": 65, + "h": 73 + } + }, + { + "filename": "0019.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 65, + "h": 73 + }, + "frame": { + "x": 264, + "y": 307, + "w": 65, + "h": 73 + } + }, + { + "filename": "0031.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 65, + "h": 73 + }, + "frame": { + "x": 264, + "y": 307, + "w": 65, + "h": 73 + } + }, + { + "filename": "0043.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 65, + "h": 73 + }, + "frame": { + "x": 264, + "y": 307, + "w": 65, + "h": 73 + } + }, + { + "filename": "0066.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 65, + "h": 73 + }, + "frame": { + "x": 264, + "y": 307, + "w": 65, + "h": 73 + } + }, + { + "filename": "0078.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 65, + "h": 73 + }, + "frame": { + "x": 264, + "y": 307, + "w": 65, + "h": 73 + } + }, + { + "filename": "0011.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 6, + "w": 67, + "h": 75 + }, + "frame": { + "x": 265, + "y": 152, + "w": 67, + "h": 75 + } + }, + { + "filename": "0023.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 6, + "w": 67, + "h": 75 + }, + "frame": { + "x": 265, + "y": 152, + "w": 67, + "h": 75 + } + }, + { + "filename": "0035.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 6, + "w": 67, + "h": 75 + }, + "frame": { + "x": 265, + "y": 152, + "w": 67, + "h": 75 + } + }, + { + "filename": "0047.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 6, + "w": 67, + "h": 75 + }, + "frame": { + "x": 265, + "y": 152, + "w": 67, + "h": 75 + } + }, + { + "filename": "0070.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 6, + "w": 67, + "h": 75 + }, + "frame": { + "x": 265, + "y": 152, + "w": 67, + "h": 75 + } + }, + { + "filename": "0082.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 6, + "w": 67, + "h": 75 + }, + "frame": { + "x": 265, + "y": 152, + "w": 67, + "h": 75 + } + }, + { + "filename": "0009.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 7, + "w": 66, + "h": 74 + }, + "frame": { + "x": 265, + "y": 227, + "w": 66, + "h": 74 + } + }, + { + "filename": "0021.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 7, + "w": 66, + "h": 74 + }, + "frame": { + "x": 265, + "y": 227, + "w": 66, + "h": 74 + } + }, + { + "filename": "0033.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 7, + "w": 66, + "h": 74 + }, + "frame": { + "x": 265, + "y": 227, + "w": 66, + "h": 74 + } + }, + { + "filename": "0045.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 7, + "w": 66, + "h": 74 + }, + "frame": { + "x": 265, + "y": 227, + "w": 66, + "h": 74 + } + }, + { + "filename": "0068.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 7, + "w": 66, + "h": 74 + }, + "frame": { + "x": 265, + "y": 227, + "w": 66, + "h": 74 + } + }, + { + "filename": "0080.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 82 + }, + "spriteSourceSize": { + "x": 0, + "y": 7, + "w": 66, + "h": 74 + }, + "frame": { + "x": 265, + "y": 227, + "w": 66, + "h": 74 } } ] @@ -35,7 +1778,6 @@ ], "meta": { "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:5b3c4c1d3d26a1f1c81f0aef0dc7bcd6:cdf309fe296f918d57d87e1ebe515b1f:9ab527962e79006eb780a43bbf3afdac$" + "version": "3.0" } } diff --git a/public/images/pokemon/493-fairy.png b/public/images/pokemon/493-fairy.png index 1c05a66e017..43fb67108c9 100644 Binary files a/public/images/pokemon/493-fairy.png and b/public/images/pokemon/493-fairy.png differ diff --git a/public/images/pokemon/501.png b/public/images/pokemon/501.png index ac4c5d9fbf0..79a012cadd5 100644 Binary files a/public/images/pokemon/501.png and b/public/images/pokemon/501.png differ diff --git a/public/images/pokemon/502.png b/public/images/pokemon/502.png index 8a7c2636894..ef1291a2520 100644 Binary files a/public/images/pokemon/502.png and b/public/images/pokemon/502.png differ diff --git a/public/images/pokemon/503.png b/public/images/pokemon/503.png index d9cf94f3c6f..3571e64156c 100644 Binary files a/public/images/pokemon/503.png and b/public/images/pokemon/503.png differ diff --git a/public/images/pokemon/528.png b/public/images/pokemon/528.png index d1806f17f70..fd6e0c54a77 100644 Binary files a/public/images/pokemon/528.png and b/public/images/pokemon/528.png differ diff --git a/public/images/pokemon/582.json b/public/images/pokemon/582.json index d5d8ca59815..4c4897e92f4 100644 --- a/public/images/pokemon/582.json +++ b/public/images/pokemon/582.json @@ -1,2267 +1,867 @@ -{ - "textures": [ - { - "image": "582.png", - "format": "RGBA8888", - "size": { - "w": 188, - "h": 188 - }, - "scale": 1, - "frames": [ - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 0, - "y": 5, - "w": 50, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 50, - "h": 40 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 0, - "y": 5, - "w": 50, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 50, - "h": 40 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 2, - "y": 5, - "w": 50, - "h": 40 - }, - "frame": { - "x": 0, - "y": 40, - "w": 50, - "h": 40 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 2, - "y": 5, - "w": 50, - "h": 40 - }, - "frame": { - "x": 0, - "y": 40, - "w": 50, - "h": 40 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 6, - "y": 4, - "w": 48, - "h": 41 - }, - "frame": { - "x": 50, - "y": 0, - "w": 48, - "h": 41 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 6, - "y": 4, - "w": 48, - "h": 41 - }, - "frame": { - "x": 50, - "y": 0, - "w": 48, - "h": 41 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 9, - "y": 4, - "w": 47, - "h": 41 - }, - "frame": { - "x": 0, - "y": 80, - "w": 47, - "h": 41 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 9, - "y": 4, - "w": 47, - "h": 41 - }, - "frame": { - "x": 0, - "y": 80, - "w": 47, - "h": 41 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 14, - "y": 3, - "w": 42, - "h": 39 - }, - "frame": { - "x": 50, - "y": 41, - "w": 42, - "h": 39 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 14, - "y": 3, - "w": 42, - "h": 39 - }, - "frame": { - "x": 50, - "y": 41, - "w": 42, - "h": 39 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 5, - "w": 40, - "h": 39 - }, - "frame": { - "x": 98, - "y": 0, - "w": 40, - "h": 39 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 5, - "w": 40, - "h": 39 - }, - "frame": { - "x": 98, - "y": 0, - "w": 40, - "h": 39 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 17, - "y": 2, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 121, - "w": 39, - "h": 38 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 17, - "y": 2, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 121, - "w": 39, - "h": 38 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 5, - "w": 38, - "h": 38 - }, - "frame": { - "x": 47, - "y": 80, - "w": 38, - "h": 38 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 5, - "w": 38, - "h": 38 - }, - "frame": { - "x": 47, - "y": 80, - "w": 38, - "h": 38 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 18, - "y": 1, - "w": 38, - "h": 38 - }, - "frame": { - "x": 138, - "y": 0, - "w": 38, - "h": 38 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 18, - "y": 1, - "w": 38, - "h": 38 - }, - "frame": { - "x": 138, - "y": 0, - "w": 38, - "h": 38 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 2, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 2, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 4, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 4, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 5, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 5, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 2, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 2, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 4, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 4, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 5, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 5, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 2, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 2, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 4, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 4, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 5, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 5, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 29, - "y": 2, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 29, - "y": 2, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 14, - "y": 5, - "w": 34, - "h": 39 - }, - "frame": { - "x": 65, - "y": 118, - "w": 34, - "h": 39 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 14, - "y": 5, - "w": 34, - "h": 39 - }, - "frame": { - "x": 65, - "y": 118, - "w": 34, - "h": 39 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 85, - "y": 80, - "w": 26, - "h": 38 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 85, - "y": 80, - "w": 26, - "h": 38 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 85, - "y": 80, - "w": 26, - "h": 38 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 85, - "y": 80, - "w": 26, - "h": 38 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 85, - "y": 80, - "w": 26, - "h": 38 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 85, - "y": 80, - "w": 26, - "h": 38 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 99, - "y": 118, - "w": 26, - "h": 38 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 99, - "y": 118, - "w": 26, - "h": 38 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 99, - "y": 118, - "w": 26, - "h": 38 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 99, - "y": 118, - "w": 26, - "h": 38 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 99, - "y": 118, - "w": 26, - "h": 38 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 99, - "y": 118, - "w": 26, - "h": 38 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 99, - "y": 118, - "w": 26, - "h": 38 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 99, - "y": 118, - "w": 26, - "h": 38 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 99, - "y": 118, - "w": 26, - "h": 38 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 99, - "y": 118, - "w": 26, - "h": 38 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 99, - "y": 118, - "w": 26, - "h": 38 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 99, - "y": 118, - "w": 26, - "h": 38 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 92, - "y": 41, - "w": 26, - "h": 38 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 92, - "y": 41, - "w": 26, - "h": 38 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 92, - "y": 41, - "w": 26, - "h": 38 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 92, - "y": 41, - "w": 26, - "h": 38 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 92, - "y": 41, - "w": 26, - "h": 38 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 92, - "y": 41, - "w": 26, - "h": 38 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 27, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 118, - "y": 39, - "w": 26, - "h": 38 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 27, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 118, - "y": 39, - "w": 26, - "h": 38 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 21, - "y": 1, - "w": 35, - "h": 38 - }, - "frame": { - "x": 144, - "y": 38, - "w": 35, - "h": 38 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 21, - "y": 1, - "w": 35, - "h": 38 - }, - "frame": { - "x": 144, - "y": 38, - "w": 35, - "h": 38 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 22, - "y": 1, - "w": 34, - "h": 38 - }, - "frame": { - "x": 111, - "y": 79, - "w": 34, - "h": 38 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 22, - "y": 1, - "w": 34, - "h": 38 - }, - "frame": { - "x": 111, - "y": 79, - "w": 34, - "h": 38 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 24, - "y": 1, - "w": 32, - "h": 38 - }, - "frame": { - "x": 145, - "y": 76, - "w": 32, - "h": 38 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 0, - "w": 26, - "h": 37 - }, - "frame": { - "x": 125, - "y": 117, - "w": 26, - "h": 37 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 0, - "w": 26, - "h": 37 - }, - "frame": { - "x": 125, - "y": 117, - "w": 26, - "h": 37 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 0, - "w": 26, - "h": 37 - }, - "frame": { - "x": 125, - "y": 117, - "w": 26, - "h": 37 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 0, - "w": 26, - "h": 37 - }, - "frame": { - "x": 125, - "y": 117, - "w": 26, - "h": 37 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 0, - "w": 26, - "h": 37 - }, - "frame": { - "x": 125, - "y": 117, - "w": 26, - "h": 37 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 0, - "w": 26, - "h": 37 - }, - "frame": { - "x": 125, - "y": 117, - "w": 26, - "h": 37 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 0, - "w": 26, - "h": 37 - }, - "frame": { - "x": 125, - "y": 117, - "w": 26, - "h": 37 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 0, - "w": 26, - "h": 37 - }, - "frame": { - "x": 125, - "y": 117, - "w": 26, - "h": 37 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 0, - "w": 26, - "h": 37 - }, - "frame": { - "x": 125, - "y": 117, - "w": 26, - "h": 37 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 0, - "w": 26, - "h": 37 - }, - "frame": { - "x": 125, - "y": 117, - "w": 26, - "h": 37 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 0, - "w": 26, - "h": 37 - }, - "frame": { - "x": 125, - "y": 117, - "w": 26, - "h": 37 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 0, - "w": 26, - "h": 37 - }, - "frame": { - "x": 125, - "y": 117, - "w": 26, - "h": 37 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 25, - "y": 4, - "w": 26, - "h": 37 - }, - "frame": { - "x": 151, - "y": 114, - "w": 26, - "h": 37 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 25, - "y": 4, - "w": 26, - "h": 37 - }, - "frame": { - "x": 151, - "y": 114, - "w": 26, - "h": 37 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 20, - "y": 4, - "w": 26, - "h": 37 - }, - "frame": { - "x": 151, - "y": 151, - "w": 26, - "h": 37 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 20, - "y": 4, - "w": 26, - "h": 37 - }, - "frame": { - "x": 151, - "y": 151, - "w": 26, - "h": 37 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:9ec145734ed4b10c14da8f0cddbb274f:df4fd09786b310c451f1209d128e5539:537948334556891ed421a4fc828e3e53$" - } +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0002.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0003.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 3, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0004.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 3, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0005.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0006.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0007.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 5, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0008.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 5, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0009.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 6, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0010.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 6, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0011.png", + "frame": { "x": 0, "y": 76, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0012.png", + "frame": { "x": 0, "y": 76, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0013.png", + "frame": { "x": 24, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0014.png", + "frame": { "x": 24, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0015.png", + "frame": { "x": 48, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 0, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0016.png", + "frame": { "x": 48, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 0, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0017.png", + "frame": { "x": 106, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0018.png", + "frame": { "x": 106, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0019.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0020.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0021.png", + "frame": { "x": 24, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0022.png", + "frame": { "x": 24, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0023.png", + "frame": { "x": 48, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 0, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0024.png", + "frame": { "x": 48, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 0, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0025.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0026.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0027.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 3, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0028.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 3, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0029.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0030.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0031.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 5, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0032.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 5, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0033.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 6, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0034.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 6, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0035.png", + "frame": { "x": 0, "y": 76, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0036.png", + "frame": { "x": 0, "y": 76, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0037.png", + "frame": { "x": 24, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0038.png", + "frame": { "x": 24, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0039.png", + "frame": { "x": 48, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 0, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0040.png", + "frame": { "x": 48, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 0, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0041.png", + "frame": { "x": 106, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0042.png", + "frame": { "x": 106, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0043.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0044.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0045.png", + "frame": { "x": 24, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0046.png", + "frame": { "x": 24, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0047.png", + "frame": { "x": 48, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 0, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0048.png", + "frame": { "x": 48, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 0, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0049.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0050.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0051.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 3, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0052.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 3, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0053.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0054.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0055.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 5, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0056.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 5, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0057.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 6, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0058.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 6, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0059.png", + "frame": { "x": 0, "y": 76, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0060.png", + "frame": { "x": 0, "y": 76, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0061.png", + "frame": { "x": 24, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0062.png", + "frame": { "x": 24, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0063.png", + "frame": { "x": 48, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 0, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0064.png", + "frame": { "x": 48, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 0, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0065.png", + "frame": { "x": 106, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0066.png", + "frame": { "x": 106, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0067.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0068.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0069.png", + "frame": { "x": 24, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0070.png", + "frame": { "x": 24, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0071.png", + "frame": { "x": 48, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 0, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0072.png", + "frame": { "x": 48, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 0, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0073.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0074.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0075.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 39, "y": 3, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0076.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 39, "y": 3, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0077.png", + "frame": { "x": 130, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 37, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0078.png", + "frame": { "x": 130, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 37, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0079.png", + "frame": { "x": 154, "y": 111, "w": 24, "h": 35 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 35, "y": 5, "w": 24, "h": 35 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0080.png", + "frame": { "x": 154, "y": 111, "w": 24, "h": 35 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 35, "y": 5, "w": 24, "h": 35 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0081.png", + "frame": { "x": 0, "y": 112, "w": 24, "h": 35 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 30, "y": 5, "w": 24, "h": 35 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0082.png", + "frame": { "x": 0, "y": 112, "w": 24, "h": 35 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 30, "y": 5, "w": 24, "h": 35 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0083.png", + "frame": { "x": 74, "y": 75, "w": 32, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 24, "y": 6, "w": 32, "h": 37 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0084.png", + "frame": { "x": 74, "y": 75, "w": 32, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 24, "y": 6, "w": 32, "h": 37 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0085.png", + "frame": { "x": 127, "y": 39, "w": 36, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 18, "y": 6, "w": 36, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0086.png", + "frame": { "x": 127, "y": 39, "w": 36, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 18, "y": 6, "w": 36, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0087.png", + "frame": { "x": 0, "y": 39, "w": 38, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 17, "y": 6, "w": 38, "h": 37 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0088.png", + "frame": { "x": 0, "y": 39, "w": 38, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 17, "y": 6, "w": 38, "h": 37 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0089.png", + "frame": { "x": 48, "y": 0, "w": 49, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 6, "w": 49, "h": 38 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0090.png", + "frame": { "x": 48, "y": 0, "w": 49, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 6, "w": 49, "h": 38 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0091.png", + "frame": { "x": 0, "y": 0, "w": 48, "h": 39 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 6, "w": 48, "h": 39 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0092.png", + "frame": { "x": 0, "y": 0, "w": 48, "h": 39 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 6, "w": 48, "h": 39 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0093.png", + "frame": { "x": 97, "y": 0, "w": 46, "h": 39 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 16, "y": 5, "w": 46, "h": 39 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0094.png", + "frame": { "x": 97, "y": 0, "w": 46, "h": 39 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 16, "y": 5, "w": 46, "h": 39 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0095.png", + "frame": { "x": 143, "y": 0, "w": 46, "h": 39 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 19, "y": 5, "w": 46, "h": 39 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0096.png", + "frame": { "x": 143, "y": 0, "w": 46, "h": 39 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 19, "y": 5, "w": 46, "h": 39 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0097.png", + "frame": { "x": 48, "y": 38, "w": 41, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 24, "y": 4, "w": 41, "h": 37 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0098.png", + "frame": { "x": 48, "y": 38, "w": 41, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 24, "y": 4, "w": 41, "h": 37 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0099.png", + "frame": { "x": 89, "y": 39, "w": 38, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 27, "y": 3, "w": 38, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0100.png", + "frame": { "x": 89, "y": 39, "w": 38, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 27, "y": 3, "w": 38, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0101.png", + "frame": { "x": 38, "y": 75, "w": 36, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 28, "y": 2, "w": 36, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0102.png", + "frame": { "x": 38, "y": 75, "w": 36, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 28, "y": 2, "w": 36, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0103.png", + "frame": { "x": 163, "y": 39, "w": 33, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 31, "y": 2, "w": 33, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0104.png", + "frame": { "x": 163, "y": 39, "w": 33, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 31, "y": 2, "w": 33, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0105.png", + "frame": { "x": 106, "y": 75, "w": 32, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 32, "y": 2, "w": 32, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0106.png", + "frame": { "x": 106, "y": 75, "w": 32, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 32, "y": 2, "w": 32, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0107.png", + "frame": { "x": 138, "y": 75, "w": 30, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 34, "y": 2, "w": 30, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.8.1-x64", + "image": "582.png", + "format": "RGBA8888", + "size": { "w": 196, "h": 147 }, + "scale": "1" + } } diff --git a/public/images/pokemon/582.png b/public/images/pokemon/582.png index 38b2b6049a7..306d04a01aa 100644 Binary files a/public/images/pokemon/582.png and b/public/images/pokemon/582.png differ diff --git a/public/images/pokemon/587.png b/public/images/pokemon/587.png index 409b423c13b..6a870170219 100644 Binary files a/public/images/pokemon/587.png and b/public/images/pokemon/587.png differ diff --git a/public/images/pokemon/590.png b/public/images/pokemon/590.png index 2cf97f1fe69..0908b46cd83 100644 Binary files a/public/images/pokemon/590.png and b/public/images/pokemon/590.png differ diff --git a/public/images/pokemon/591.png b/public/images/pokemon/591.png index 179e3b4160f..a294749149f 100644 Binary files a/public/images/pokemon/591.png and b/public/images/pokemon/591.png differ diff --git a/public/images/pokemon/60.png b/public/images/pokemon/60.png index b599f97ca96..15328684bdf 100644 Binary files a/public/images/pokemon/60.png and b/public/images/pokemon/60.png differ diff --git a/public/images/pokemon/616.png b/public/images/pokemon/616.png index 5d4e04e31fd..aff43388faf 100644 Binary files a/public/images/pokemon/616.png and b/public/images/pokemon/616.png differ diff --git a/public/images/pokemon/62.png b/public/images/pokemon/62.png index c142b63cb70..bfbdf9ce733 100644 Binary files a/public/images/pokemon/62.png and b/public/images/pokemon/62.png differ diff --git a/public/images/pokemon/6503.png b/public/images/pokemon/6503.png index 906fcb9115b..71d6e27d855 100644 Binary files a/public/images/pokemon/6503.png and b/public/images/pokemon/6503.png differ diff --git a/public/images/pokemon/656.png b/public/images/pokemon/656.png index 1f0f181712b..b653616955d 100644 Binary files a/public/images/pokemon/656.png and b/public/images/pokemon/656.png differ diff --git a/public/images/pokemon/657.png b/public/images/pokemon/657.png index 8c0f2b9a15f..031c9404805 100644 Binary files a/public/images/pokemon/657.png and b/public/images/pokemon/657.png differ diff --git a/public/images/pokemon/658-ash.json b/public/images/pokemon/658-ash.json index 8fbe19f5ccb..c2b8eede9ef 100644 --- a/public/images/pokemon/658-ash.json +++ b/public/images/pokemon/658-ash.json @@ -1,41 +1,19 @@ -{ - "textures": [ - { - "image": "658-ash.png", - "format": "RGBA8888", - "size": { - "w": 79, - "h": 79 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 79, - "h": 74 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 79, - "h": 74 - }, - "frame": { - "x": 0, - "y": 0, - "w": 79, - "h": 74 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:936f62fa49ba4d6e402bb2e2eaf2afd0:ed00ba047a44b4bf1309bc147dd000e3:bfbf521a5c7bd80bcd95a96d9789c0dd$" - } +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.7-x64", + "format": "I8", + "size": { "w": 79, "h": 74 }, + "scale": "1" + } } diff --git a/public/images/pokemon/658-ash.png b/public/images/pokemon/658-ash.png index 8daaaa02063..a122df859bd 100644 Binary files a/public/images/pokemon/658-ash.png and b/public/images/pokemon/658-ash.png differ diff --git a/public/images/pokemon/658.json b/public/images/pokemon/658.json index 4fd918e0f50..219645ec240 100644 --- a/public/images/pokemon/658.json +++ b/public/images/pokemon/658.json @@ -1,41 +1,19 @@ -{ - "textures": [ - { - "image": "658.png", - "format": "RGBA8888", - "size": { - "w": 75, - "h": 75 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 65 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 65 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 65 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:e0b10df331bd4ce6760edab61dee144b:061561c45beff89a92bf0158d065204f:5affcab976148657d36bf4ff3410f92d$" - } +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 85, "h": 67 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 85, "h": 67 }, + "sourceSize": { "w": 85, "h": 67 }, + "duration": 100 + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.7-x64", + "format": "I8", + "size": { "w": 85, "h": 67 }, + "scale": "1" + } } diff --git a/public/images/pokemon/658.png b/public/images/pokemon/658.png index 095b8c0039d..ed730c8b81c 100644 Binary files a/public/images/pokemon/658.png and b/public/images/pokemon/658.png differ diff --git a/public/images/pokemon/6706.png b/public/images/pokemon/6706.png index 44f627acd10..e967b550871 100644 Binary files a/public/images/pokemon/6706.png and b/public/images/pokemon/6706.png differ diff --git a/public/images/pokemon/676-dandy.png b/public/images/pokemon/676-dandy.png index 1e9f9b7bb2c..54e36574b2a 100644 Binary files a/public/images/pokemon/676-dandy.png and b/public/images/pokemon/676-dandy.png differ diff --git a/public/images/pokemon/676-debutante.png b/public/images/pokemon/676-debutante.png index 92390b17f34..30d5bcafec5 100644 Binary files a/public/images/pokemon/676-debutante.png and b/public/images/pokemon/676-debutante.png differ diff --git a/public/images/pokemon/676-diamond.png b/public/images/pokemon/676-diamond.png index 3915b78ec26..953581d7bb7 100644 Binary files a/public/images/pokemon/676-diamond.png and b/public/images/pokemon/676-diamond.png differ diff --git a/public/images/pokemon/676-heart.png b/public/images/pokemon/676-heart.png index 99327208605..9e6950cc36c 100644 Binary files a/public/images/pokemon/676-heart.png and b/public/images/pokemon/676-heart.png differ diff --git a/public/images/pokemon/676-kabuki.png b/public/images/pokemon/676-kabuki.png index c4f6473c75b..0d7323a520c 100644 Binary files a/public/images/pokemon/676-kabuki.png and b/public/images/pokemon/676-kabuki.png differ diff --git a/public/images/pokemon/676-la-reine.png b/public/images/pokemon/676-la-reine.png index e649e6d74c8..c2f0eb72d75 100644 Binary files a/public/images/pokemon/676-la-reine.png and b/public/images/pokemon/676-la-reine.png differ diff --git a/public/images/pokemon/676-matron.png b/public/images/pokemon/676-matron.png index 98142c41661..1f93b11a277 100644 Binary files a/public/images/pokemon/676-matron.png and b/public/images/pokemon/676-matron.png differ diff --git a/public/images/pokemon/676-pharaoh.png b/public/images/pokemon/676-pharaoh.png index cced072318b..e0f48c46bab 100644 Binary files a/public/images/pokemon/676-pharaoh.png and b/public/images/pokemon/676-pharaoh.png differ diff --git a/public/images/pokemon/676-star.png b/public/images/pokemon/676-star.png index 7a1044bda75..566aa713aee 100644 Binary files a/public/images/pokemon/676-star.png and b/public/images/pokemon/676-star.png differ diff --git a/public/images/pokemon/682.png b/public/images/pokemon/682.png index 41ecd482b14..2a83ceedaa9 100644 Binary files a/public/images/pokemon/682.png and b/public/images/pokemon/682.png differ diff --git a/public/images/pokemon/683.png b/public/images/pokemon/683.png index bf559a07929..1b16b038c51 100644 Binary files a/public/images/pokemon/683.png and b/public/images/pokemon/683.png differ diff --git a/public/images/pokemon/684.png b/public/images/pokemon/684.png index 8bf8f765465..a3f7e544f89 100644 Binary files a/public/images/pokemon/684.png and b/public/images/pokemon/684.png differ diff --git a/public/images/pokemon/685.png b/public/images/pokemon/685.png index 521b7560182..957cd5d815b 100644 Binary files a/public/images/pokemon/685.png and b/public/images/pokemon/685.png differ diff --git a/public/images/pokemon/688.json b/public/images/pokemon/688.json index 84ec62d4211..3d9aa902a54 100644 --- a/public/images/pokemon/688.json +++ b/public/images/pokemon/688.json @@ -1,41 +1,18 @@ -{ - "textures": [ - { - "image": "688.png", - "format": "RGBA8888", - "size": { - "w": 52, - "h": 52 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 41, - "h": 52 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 41, - "h": 52 - }, - "frame": { - "x": 0, - "y": 0, - "w": 41, - "h": 52 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:f328f72c414efc6cf463a1254afa75ac:50168e1a7077626f41bdaf5d0b35af74:176060351d0044923af938ba7932a6ef$" - } +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 64, "h": 63 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 64, "h": 63 }, + "sourceSize": { "w": 64, "h": 63 } + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.7-x64", + "format": "I8", + "size": { "w": 64, "h": 63 }, + "scale": "1" + } } diff --git a/public/images/pokemon/688.png b/public/images/pokemon/688.png index 2ac1b5d5fb1..2e65d4beb6f 100644 Binary files a/public/images/pokemon/688.png and b/public/images/pokemon/688.png differ diff --git a/public/images/pokemon/689.json b/public/images/pokemon/689.json index 2ff881f55c0..488ef54de71 100644 --- a/public/images/pokemon/689.json +++ b/public/images/pokemon/689.json @@ -1,41 +1,19 @@ -{ - "textures": [ - { - "image": "689.png", - "format": "RGBA8888", - "size": { - "w": 86, - "h": 86 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 86, - "h": 79 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 86, - "h": 79 - }, - "frame": { - "x": 0, - "y": 0, - "w": 86, - "h": 79 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:1825183d2cc847c000400501e055918b:af535bb92b1490f3ab69be674b3b6fe0:bd0c58ecddcb4af9a0c6e7b39821d971$" - } +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 79, "h": 82 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 82 }, + "sourceSize": { "w": 79, "h": 82 }, + "duration": 100 + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.7-x64", + "format": "I8", + "size": { "w": 79, "h": 82 }, + "scale": "1" + } } diff --git a/public/images/pokemon/689.png b/public/images/pokemon/689.png index 75fa0b474d7..1ec1bcec98a 100644 Binary files a/public/images/pokemon/689.png and b/public/images/pokemon/689.png differ diff --git a/public/images/pokemon/696.png b/public/images/pokemon/696.png index 5bfce9fa508..8d6b387b4fd 100644 Binary files a/public/images/pokemon/696.png and b/public/images/pokemon/696.png differ diff --git a/public/images/pokemon/697.png b/public/images/pokemon/697.png index 986f0b184f0..6a9b70d8ac7 100644 Binary files a/public/images/pokemon/697.png and b/public/images/pokemon/697.png differ diff --git a/public/images/pokemon/773-bug.png b/public/images/pokemon/773-bug.png index e513daee557..8a2fba0585f 100644 Binary files a/public/images/pokemon/773-bug.png and b/public/images/pokemon/773-bug.png differ diff --git a/public/images/pokemon/773-dark.png b/public/images/pokemon/773-dark.png index 3e79d88e660..3580d6c5f43 100644 Binary files a/public/images/pokemon/773-dark.png and b/public/images/pokemon/773-dark.png differ diff --git a/public/images/pokemon/773-dragon.png b/public/images/pokemon/773-dragon.png index 50f7b63ec7e..f27c696b33b 100644 Binary files a/public/images/pokemon/773-dragon.png and b/public/images/pokemon/773-dragon.png differ diff --git a/public/images/pokemon/773-electric.png b/public/images/pokemon/773-electric.png index b70187b987f..cd8ec8ee74f 100644 Binary files a/public/images/pokemon/773-electric.png and b/public/images/pokemon/773-electric.png differ diff --git a/public/images/pokemon/773-fairy.png b/public/images/pokemon/773-fairy.png index 989ff6ebcd4..54a59751c87 100644 Binary files a/public/images/pokemon/773-fairy.png and b/public/images/pokemon/773-fairy.png differ diff --git a/public/images/pokemon/773-fighting.png b/public/images/pokemon/773-fighting.png index 0258f0819ac..2ee950f4bb7 100644 Binary files a/public/images/pokemon/773-fighting.png and b/public/images/pokemon/773-fighting.png differ diff --git a/public/images/pokemon/773-fire.png b/public/images/pokemon/773-fire.png index 62ca174eaba..dd58ec8a3f0 100644 Binary files a/public/images/pokemon/773-fire.png and b/public/images/pokemon/773-fire.png differ diff --git a/public/images/pokemon/773-flying.png b/public/images/pokemon/773-flying.png index ecb565e65ca..f28eddafb92 100644 Binary files a/public/images/pokemon/773-flying.png and b/public/images/pokemon/773-flying.png differ diff --git a/public/images/pokemon/773-ghost.png b/public/images/pokemon/773-ghost.png index 2cb5eb4a44d..2634a92b49e 100644 Binary files a/public/images/pokemon/773-ghost.png and b/public/images/pokemon/773-ghost.png differ diff --git a/public/images/pokemon/773-grass.png b/public/images/pokemon/773-grass.png index 3fc2d1e9141..159f2d2faef 100644 Binary files a/public/images/pokemon/773-grass.png and b/public/images/pokemon/773-grass.png differ diff --git a/public/images/pokemon/773-ground.png b/public/images/pokemon/773-ground.png index 08ece537554..a55d0932ad7 100644 Binary files a/public/images/pokemon/773-ground.png and b/public/images/pokemon/773-ground.png differ diff --git a/public/images/pokemon/773-ice.png b/public/images/pokemon/773-ice.png index ce324ad45e2..8c0c173b1c3 100644 Binary files a/public/images/pokemon/773-ice.png and b/public/images/pokemon/773-ice.png differ diff --git a/public/images/pokemon/773-poison.png b/public/images/pokemon/773-poison.png index 3a847058d90..6491f0d471e 100644 Binary files a/public/images/pokemon/773-poison.png and b/public/images/pokemon/773-poison.png differ diff --git a/public/images/pokemon/773-psychic.png b/public/images/pokemon/773-psychic.png index e77a373f347..cdcfab97ba8 100644 Binary files a/public/images/pokemon/773-psychic.png and b/public/images/pokemon/773-psychic.png differ diff --git a/public/images/pokemon/773-rock.png b/public/images/pokemon/773-rock.png index 292e2cc5d17..e59849cda82 100644 Binary files a/public/images/pokemon/773-rock.png and b/public/images/pokemon/773-rock.png differ diff --git a/public/images/pokemon/773-steel.png b/public/images/pokemon/773-steel.png index 759ef8f0f48..75f940fe96b 100644 Binary files a/public/images/pokemon/773-steel.png and b/public/images/pokemon/773-steel.png differ diff --git a/public/images/pokemon/773-water.png b/public/images/pokemon/773-water.png index 3dfcfcf10a8..1f126cfb55c 100644 Binary files a/public/images/pokemon/773-water.png and b/public/images/pokemon/773-water.png differ diff --git a/public/images/pokemon/773.png b/public/images/pokemon/773.png index 9735e24134d..da3752b27a4 100644 Binary files a/public/images/pokemon/773.png and b/public/images/pokemon/773.png differ diff --git a/public/images/pokemon/774-blue.png b/public/images/pokemon/774-blue.png index a30ab481135..7d7aecedfeb 100644 Binary files a/public/images/pokemon/774-blue.png and b/public/images/pokemon/774-blue.png differ diff --git a/public/images/pokemon/774-green.png b/public/images/pokemon/774-green.png index d922587ff65..7297beac72d 100644 Binary files a/public/images/pokemon/774-green.png and b/public/images/pokemon/774-green.png differ diff --git a/public/images/pokemon/774-indigo.png b/public/images/pokemon/774-indigo.png index bd2a52b4f24..a727cd98617 100644 Binary files a/public/images/pokemon/774-indigo.png and b/public/images/pokemon/774-indigo.png differ diff --git a/public/images/pokemon/774-orange.png b/public/images/pokemon/774-orange.png index e7d87231bcf..cae4aa11012 100644 Binary files a/public/images/pokemon/774-orange.png and b/public/images/pokemon/774-orange.png differ diff --git a/public/images/pokemon/774-red.png b/public/images/pokemon/774-red.png index 8ca4fce0ecd..869e1a73af3 100644 Binary files a/public/images/pokemon/774-red.png and b/public/images/pokemon/774-red.png differ diff --git a/public/images/pokemon/774-violet.png b/public/images/pokemon/774-violet.png index 92196ba7e47..d7b578e0e48 100644 Binary files a/public/images/pokemon/774-violet.png and b/public/images/pokemon/774-violet.png differ diff --git a/public/images/pokemon/774-yellow.png b/public/images/pokemon/774-yellow.png index f5f7fa783fa..66ee87b4c12 100644 Binary files a/public/images/pokemon/774-yellow.png and b/public/images/pokemon/774-yellow.png differ diff --git a/public/images/pokemon/894.png b/public/images/pokemon/894.png index ea82d8bd82e..5f5b0535e8a 100644 Binary files a/public/images/pokemon/894.png and b/public/images/pokemon/894.png differ diff --git a/public/images/pokemon/945.png b/public/images/pokemon/945.png index 280ad17b152..74c43b6d32e 100644 Binary files a/public/images/pokemon/945.png and b/public/images/pokemon/945.png differ diff --git a/public/images/pokemon/966-caph-starmobile.json b/public/images/pokemon/966-caph-starmobile.json new file mode 100644 index 00000000000..96c5aada282 --- /dev/null +++ b/public/images/pokemon/966-caph-starmobile.json @@ -0,0 +1,19 @@ +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 94, "h": 94 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 26, "y": 0, "w": 94, "h": 94 }, + "sourceSize": { "w": 120, "h": 94 } + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.8.1-x64", + "image": "966-caph-starmobile.png", + "format": "RGBA8888", + "size": { "w": 94, "h": 94 }, + "scale": "1" + } +} diff --git a/public/images/pokemon/966-caph-starmobile.png b/public/images/pokemon/966-caph-starmobile.png new file mode 100644 index 00000000000..987782e529e Binary files /dev/null and b/public/images/pokemon/966-caph-starmobile.png differ diff --git a/public/images/pokemon/966-navi-starmobile.json b/public/images/pokemon/966-navi-starmobile.json new file mode 100644 index 00000000000..6a39310af00 --- /dev/null +++ b/public/images/pokemon/966-navi-starmobile.json @@ -0,0 +1,19 @@ +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 94, "h": 94 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 26, "y": 0, "w": 94, "h": 94 }, + "sourceSize": { "w": 120, "h": 94 } + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.8.1-x64", + "image": "966-navi-starmobile.png", + "format": "RGBA8888", + "size": { "w": 94, "h": 94 }, + "scale": "1" + } +} diff --git a/public/images/pokemon/966-navi-starmobile.png b/public/images/pokemon/966-navi-starmobile.png new file mode 100644 index 00000000000..41d0fd4690c Binary files /dev/null and b/public/images/pokemon/966-navi-starmobile.png differ diff --git a/public/images/pokemon/966-ruchbah-starmobile.json b/public/images/pokemon/966-ruchbah-starmobile.json new file mode 100644 index 00000000000..c75a5630f45 --- /dev/null +++ b/public/images/pokemon/966-ruchbah-starmobile.json @@ -0,0 +1,19 @@ +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 94, "h": 94 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 26, "y": 0, "w": 94, "h": 94 }, + "sourceSize": { "w": 120, "h": 94 } + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.8.1-x64", + "image": "966-ruchbah-starmobile.png", + "format": "RGBA8888", + "size": { "w": 94, "h": 94 }, + "scale": "1" + } +} diff --git a/public/images/pokemon/966-ruchbah-starmobile.png b/public/images/pokemon/966-ruchbah-starmobile.png new file mode 100644 index 00000000000..765f1fe5eaa Binary files /dev/null and b/public/images/pokemon/966-ruchbah-starmobile.png differ diff --git a/public/images/pokemon/966-schedar-starmobile.json b/public/images/pokemon/966-schedar-starmobile.json new file mode 100644 index 00000000000..59f77f3c975 --- /dev/null +++ b/public/images/pokemon/966-schedar-starmobile.json @@ -0,0 +1,19 @@ +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 94, "h": 94 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 26, "y": 0, "w": 94, "h": 94 }, + "sourceSize": { "w": 120, "h": 94 } + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.8.1-x64", + "image": "966-schedar-starmobile.png", + "format": "RGBA8888", + "size": { "w": 94, "h": 94 }, + "scale": "1" + } +} diff --git a/public/images/pokemon/966-schedar-starmobile.png b/public/images/pokemon/966-schedar-starmobile.png new file mode 100644 index 00000000000..4cbc60f581f Binary files /dev/null and b/public/images/pokemon/966-schedar-starmobile.png differ diff --git a/public/images/pokemon/966-segin-starmobile.json b/public/images/pokemon/966-segin-starmobile.json new file mode 100644 index 00000000000..98b3938643b --- /dev/null +++ b/public/images/pokemon/966-segin-starmobile.json @@ -0,0 +1,19 @@ +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 94, "h": 94 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 26, "y": 0, "w": 94, "h": 94 }, + "sourceSize": { "w": 120, "h": 94 } + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.8.1-x64", + "image": "966-segin-starmobile.png", + "format": "RGBA8888", + "size": { "w": 94, "h": 94 }, + "scale": "1" + } +} diff --git a/public/images/pokemon/966-segin-starmobile.png b/public/images/pokemon/966-segin-starmobile.png new file mode 100644 index 00000000000..fab6b1f62ee Binary files /dev/null and b/public/images/pokemon/966-segin-starmobile.png differ diff --git a/public/images/pokemon/back/1012-counterfeit.png b/public/images/pokemon/back/1012-counterfeit.png index 8ab1941187d..e6deb02c70c 100644 Binary files a/public/images/pokemon/back/1012-counterfeit.png and b/public/images/pokemon/back/1012-counterfeit.png differ diff --git a/public/images/pokemon/back/1013-unremarkable.png b/public/images/pokemon/back/1013-unremarkable.png index b8532d049fc..479f0e51cff 100644 Binary files a/public/images/pokemon/back/1013-unremarkable.png and b/public/images/pokemon/back/1013-unremarkable.png differ diff --git a/public/images/pokemon/back/172-spiky.png b/public/images/pokemon/back/172-spiky.png index 37b2d401f17..d038e0d3661 100644 Binary files a/public/images/pokemon/back/172-spiky.png and b/public/images/pokemon/back/172-spiky.png differ diff --git a/public/images/pokemon/back/172.png b/public/images/pokemon/back/172.png index 9f4c8f4f1bd..775a42dd948 100644 Binary files a/public/images/pokemon/back/172.png and b/public/images/pokemon/back/172.png differ diff --git a/public/images/pokemon/back/198.png b/public/images/pokemon/back/198.png index dbae4ffdfed..dc92c8b1d59 100644 Binary files a/public/images/pokemon/back/198.png and b/public/images/pokemon/back/198.png differ diff --git a/public/images/pokemon/back/2026.png b/public/images/pokemon/back/2026.png index 4e1e16c6207..1f0411ffcd8 100644 Binary files a/public/images/pokemon/back/2026.png and b/public/images/pokemon/back/2026.png differ diff --git a/public/images/pokemon/back/25-beauty-cosplay.png b/public/images/pokemon/back/25-beauty-cosplay.png index 30c51863f9f..8a57b642aa7 100644 Binary files a/public/images/pokemon/back/25-beauty-cosplay.png and b/public/images/pokemon/back/25-beauty-cosplay.png differ diff --git a/public/images/pokemon/back/25-cool-cosplay.png b/public/images/pokemon/back/25-cool-cosplay.png index fe8e67a27cd..1c9528eb350 100644 Binary files a/public/images/pokemon/back/25-cool-cosplay.png and b/public/images/pokemon/back/25-cool-cosplay.png differ diff --git a/public/images/pokemon/back/25-cosplay.png b/public/images/pokemon/back/25-cosplay.png index 54c1dca4925..38e573f5784 100644 Binary files a/public/images/pokemon/back/25-cosplay.png and b/public/images/pokemon/back/25-cosplay.png differ diff --git a/public/images/pokemon/back/25-cute-cosplay.png b/public/images/pokemon/back/25-cute-cosplay.png index 9436bad0863..64b180067d5 100644 Binary files a/public/images/pokemon/back/25-cute-cosplay.png and b/public/images/pokemon/back/25-cute-cosplay.png differ diff --git a/public/images/pokemon/back/25-gigantamax.png b/public/images/pokemon/back/25-gigantamax.png index 70bf85129da..c80b3d5d486 100644 Binary files a/public/images/pokemon/back/25-gigantamax.png and b/public/images/pokemon/back/25-gigantamax.png differ diff --git a/public/images/pokemon/back/25-partner.png b/public/images/pokemon/back/25-partner.png index 8085a963e28..ae6133aefff 100644 Binary files a/public/images/pokemon/back/25-partner.png and b/public/images/pokemon/back/25-partner.png differ diff --git a/public/images/pokemon/back/25-smart-cosplay.png b/public/images/pokemon/back/25-smart-cosplay.png index 81a6d938154..6f23b7f4df0 100644 Binary files a/public/images/pokemon/back/25-smart-cosplay.png and b/public/images/pokemon/back/25-smart-cosplay.png differ diff --git a/public/images/pokemon/back/25-tough-cosplay.png b/public/images/pokemon/back/25-tough-cosplay.png index e70757866a5..cfc9392efe8 100644 Binary files a/public/images/pokemon/back/25-tough-cosplay.png and b/public/images/pokemon/back/25-tough-cosplay.png differ diff --git a/public/images/pokemon/back/25.png b/public/images/pokemon/back/25.png index 8085a963e28..ae6133aefff 100644 Binary files a/public/images/pokemon/back/25.png and b/public/images/pokemon/back/25.png differ diff --git a/public/images/pokemon/back/26.png b/public/images/pokemon/back/26.png index 21b3a5fa9c1..454c581edae 100644 Binary files a/public/images/pokemon/back/26.png and b/public/images/pokemon/back/26.png differ diff --git a/public/images/pokemon/back/276.png b/public/images/pokemon/back/276.png index 64c4a4d22ee..fef264f004e 100644 Binary files a/public/images/pokemon/back/276.png and b/public/images/pokemon/back/276.png differ diff --git a/public/images/pokemon/back/277.png b/public/images/pokemon/back/277.png index 0e173bc54fb..ced72a75a73 100644 Binary files a/public/images/pokemon/back/277.png and b/public/images/pokemon/back/277.png differ diff --git a/public/images/pokemon/back/280.png b/public/images/pokemon/back/280.png index 6547190dede..b14179df4e3 100644 Binary files a/public/images/pokemon/back/280.png and b/public/images/pokemon/back/280.png differ diff --git a/public/images/pokemon/back/281.png b/public/images/pokemon/back/281.png index 9bf40c564f2..a26c4638688 100644 Binary files a/public/images/pokemon/back/281.png and b/public/images/pokemon/back/281.png differ diff --git a/public/images/pokemon/back/282.png b/public/images/pokemon/back/282.png index 0eee09bf908..0cd51fca3a0 100644 Binary files a/public/images/pokemon/back/282.png and b/public/images/pokemon/back/282.png differ diff --git a/public/images/pokemon/back/379.png b/public/images/pokemon/back/379.png index 586a19a5916..b4f282d5989 100644 Binary files a/public/images/pokemon/back/379.png and b/public/images/pokemon/back/379.png differ diff --git a/public/images/pokemon/back/390.png b/public/images/pokemon/back/390.png index 65b5595cfbe..d6dcc990c48 100644 Binary files a/public/images/pokemon/back/390.png and b/public/images/pokemon/back/390.png differ diff --git a/public/images/pokemon/back/391.png b/public/images/pokemon/back/391.png index e89d79720ab..9b41cd2bd89 100644 Binary files a/public/images/pokemon/back/391.png and b/public/images/pokemon/back/391.png differ diff --git a/public/images/pokemon/back/392.png b/public/images/pokemon/back/392.png index e15396669ce..2e7466294da 100644 Binary files a/public/images/pokemon/back/392.png and b/public/images/pokemon/back/392.png differ diff --git a/public/images/pokemon/back/4144.png b/public/images/pokemon/back/4144.png index 1ae3757a9ca..a8270354def 100644 Binary files a/public/images/pokemon/back/4144.png and b/public/images/pokemon/back/4144.png differ diff --git a/public/images/pokemon/back/4145.png b/public/images/pokemon/back/4145.png index 4eae16ea0a3..a9735fb171a 100644 Binary files a/public/images/pokemon/back/4145.png and b/public/images/pokemon/back/4145.png differ diff --git a/public/images/pokemon/back/4146.png b/public/images/pokemon/back/4146.png index 71103ef66c4..a93c746d8a9 100644 Binary files a/public/images/pokemon/back/4146.png and b/public/images/pokemon/back/4146.png differ diff --git a/public/images/pokemon/back/430.png b/public/images/pokemon/back/430.png index 6c0fc8a5166..383685fa816 100644 Binary files a/public/images/pokemon/back/430.png and b/public/images/pokemon/back/430.png differ diff --git a/public/images/pokemon/back/436.json b/public/images/pokemon/back/436.json index 78014a69936..3342cc6577c 100644 --- a/public/images/pokemon/back/436.json +++ b/public/images/pokemon/back/436.json @@ -1,2666 +1,1019 @@ -{ - "textures": [ - { - "image": "436.png", - "format": "RGBA8888", - "size": { - "w": 100, - "h": 100 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 5, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 5, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 5, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 5, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 9, - "y": 9, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 9, - "y": 9, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 5, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 5, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 4, - "y": 8, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 4, - "y": 8, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 5, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 5, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 9, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 9, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 10, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 10, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 11, - "y": 8, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 11, - "y": 8, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 9, - "y": 6, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 9, - "y": 6, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 5, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 5, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 5, - "y": 6, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 5, - "y": 6, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 8, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 8, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 4, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 4, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 5, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 5, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 10, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 10, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 11, - "y": 9, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 11, - "y": 9, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 13, - "y": 6, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 13, - "y": 6, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 10, - "y": 3, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 10, - "y": 3, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 2, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 2, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 4, - "y": 3, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 4, - "y": 3, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 6, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 6, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 9, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 9, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 4, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 4, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 11, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 11, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 13, - "y": 8, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 13, - "y": 8, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 11, - "y": 0, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 11, - "y": 0, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 4, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 4, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 14, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 14, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 4, - "y": 17, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 4, - "y": 17, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 8, - "y": 18, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 8, - "y": 18, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 15, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 15, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 6, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 6, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 9, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 9, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 6, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 6, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 8, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 8, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 15, - "y": 4, - "w": 33, - "h": 40 - }, - "frame": { - "x": 34, - "y": 0, - "w": 33, - "h": 40 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 15, - "y": 4, - "w": 33, - "h": 40 - }, - "frame": { - "x": 34, - "y": 0, - "w": 33, - "h": 40 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 33, - "h": 40 - }, - "frame": { - "x": 67, - "y": 0, - "w": 33, - "h": 40 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 33, - "h": 40 - }, - "frame": { - "x": 67, - "y": 0, - "w": 33, - "h": 40 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 0, - "w": 34, - "h": 39 - }, - "frame": { - "x": 0, - "y": 40, - "w": 34, - "h": 39 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 0, - "w": 34, - "h": 39 - }, - "frame": { - "x": 0, - "y": 40, - "w": 34, - "h": 39 - } - }, - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 9, - "y": 21, - "w": 34, - "h": 39 - }, - "frame": { - "x": 34, - "y": 40, - "w": 34, - "h": 39 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 9, - "y": 21, - "w": 34, - "h": 39 - }, - "frame": { - "x": 34, - "y": 40, - "w": 34, - "h": 39 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:6e466fdd2b62b8024ea52be04133391d:67fd60bf8d57184b168ae25f93bafcc2:0a3bacf3d680738b160c4c8ace3cda59$" - } -} +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0002.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0003.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0004.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0005.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0006.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0007.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0008.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0009.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0010.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0011.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0012.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0013.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0014.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0015.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0016.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0017.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0018.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0019.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0020.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0021.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0022.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0023.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0024.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0025.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0026.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0027.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0028.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0029.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0030.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0031.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0032.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0033.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0034.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0035.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0036.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0037.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 10, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0038.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 10, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0039.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0040.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0041.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0042.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0043.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0044.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0045.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 9, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0046.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 9, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0047.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0048.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0049.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0050.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0051.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0052.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0053.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 11, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0054.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 11, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0055.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 9, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0056.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 9, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0057.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 7, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0058.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 7, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0059.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 6, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0060.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 6, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0061.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 7, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0062.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 7, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0063.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 9, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0064.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 9, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0065.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0066.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0067.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0068.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0069.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0070.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0071.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 11, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0072.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 11, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0073.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 10, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0074.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 10, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0075.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 14, "y": 7, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0076.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 14, "y": 7, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0077.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 11, "y": 4, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0078.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 11, "y": 4, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0079.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 3, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0080.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 3, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0081.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 4, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0082.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 4, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0083.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 2, "y": 7, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0084.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 2, "y": 7, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0085.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 10, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0086.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 10, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0087.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0088.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0089.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0090.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0091.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0092.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0093.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 14, "y": 9, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0094.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 14, "y": 9, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0095.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 16, "y": 5, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0096.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 16, "y": 5, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0097.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 1, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0098.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 1, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0099.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 0, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0100.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 0, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0101.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 5, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0102.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 5, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0103.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 0, "y": 10, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0104.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 0, "y": 10, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0105.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 2, "y": 15, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0106.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 2, "y": 15, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0107.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 18, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0108.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 18, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0109.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 22, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0110.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 22, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0111.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 19, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0112.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 19, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0113.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 16, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0114.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 16, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0115.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0116.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0117.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 10, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0118.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 10, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0119.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 7, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0120.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 7, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0121.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 9, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0122.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 9, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0123.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0124.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0125.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0126.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.7-dev", + "image": "436.png", + "format": "I8", + "size": { "w": 32, "h": 38 }, + "scale": "1" + } +} diff --git a/public/images/pokemon/back/436.png b/public/images/pokemon/back/436.png index de9a217f0cf..5d08304bff1 100644 Binary files a/public/images/pokemon/back/436.png and b/public/images/pokemon/back/436.png differ diff --git a/public/images/pokemon/back/451.json b/public/images/pokemon/back/451.json index 0f618fa2853..21979943520 100644 --- a/public/images/pokemon/back/451.json +++ b/public/images/pokemon/back/451.json @@ -1,2330 +1,715 @@ -{ - "textures": [ - { - "image": "451.png", - "format": "RGBA8888", - "size": { - "w": 284, - "h": 284 - }, - "scale": 1, - "frames": [ - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 68, - "h": 36 - }, - "frame": { - "x": 0, - "y": 0, - "w": 68, - "h": 36 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 68, - "h": 36 - }, - "frame": { - "x": 0, - "y": 0, - "w": 68, - "h": 36 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 68, - "h": 36 - }, - "frame": { - "x": 0, - "y": 0, - "w": 68, - "h": 36 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 68, - "h": 36 - }, - "frame": { - "x": 0, - "y": 0, - "w": 68, - "h": 36 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 68, - "h": 37 - }, - "frame": { - "x": 68, - "y": 0, - "w": 68, - "h": 37 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 68, - "h": 37 - }, - "frame": { - "x": 68, - "y": 0, - "w": 68, - "h": 37 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 68, - "h": 37 - }, - "frame": { - "x": 68, - "y": 0, - "w": 68, - "h": 37 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 68, - "h": 37 - }, - "frame": { - "x": 68, - "y": 0, - "w": 68, - "h": 37 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 1, - "y": 7, - "w": 67, - "h": 38 - }, - "frame": { - "x": 136, - "y": 0, - "w": 67, - "h": 38 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 1, - "y": 7, - "w": 67, - "h": 38 - }, - "frame": { - "x": 136, - "y": 0, - "w": 67, - "h": 38 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 1, - "y": 7, - "w": 67, - "h": 38 - }, - "frame": { - "x": 136, - "y": 0, - "w": 67, - "h": 38 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 1, - "y": 7, - "w": 67, - "h": 38 - }, - "frame": { - "x": 136, - "y": 0, - "w": 67, - "h": 38 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 1, - "y": 7, - "w": 67, - "h": 38 - }, - "frame": { - "x": 203, - "y": 0, - "w": 67, - "h": 38 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 1, - "y": 7, - "w": 67, - "h": 38 - }, - "frame": { - "x": 203, - "y": 0, - "w": 67, - "h": 38 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 1, - "y": 7, - "w": 67, - "h": 38 - }, - "frame": { - "x": 203, - "y": 0, - "w": 67, - "h": 38 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 1, - "y": 7, - "w": 67, - "h": 38 - }, - "frame": { - "x": 203, - "y": 0, - "w": 67, - "h": 38 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 2, - "y": 6, - "w": 66, - "h": 39 - }, - "frame": { - "x": 0, - "y": 36, - "w": 66, - "h": 39 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 2, - "y": 6, - "w": 66, - "h": 39 - }, - "frame": { - "x": 0, - "y": 36, - "w": 66, - "h": 39 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 2, - "y": 6, - "w": 66, - "h": 39 - }, - "frame": { - "x": 0, - "y": 36, - "w": 66, - "h": 39 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 2, - "y": 6, - "w": 66, - "h": 39 - }, - "frame": { - "x": 0, - "y": 36, - "w": 66, - "h": 39 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 2, - "y": 6, - "w": 66, - "h": 39 - }, - "frame": { - "x": 0, - "y": 36, - "w": 66, - "h": 39 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 2, - "y": 6, - "w": 66, - "h": 39 - }, - "frame": { - "x": 0, - "y": 36, - "w": 66, - "h": 39 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 2, - "y": 6, - "w": 66, - "h": 39 - }, - "frame": { - "x": 0, - "y": 36, - "w": 66, - "h": 39 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 2, - "y": 6, - "w": 66, - "h": 39 - }, - "frame": { - "x": 0, - "y": 36, - "w": 66, - "h": 39 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 3, - "y": 5, - "w": 64, - "h": 40 - }, - "frame": { - "x": 66, - "y": 37, - "w": 64, - "h": 40 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 3, - "y": 5, - "w": 64, - "h": 40 - }, - "frame": { - "x": 66, - "y": 37, - "w": 64, - "h": 40 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 3, - "y": 5, - "w": 64, - "h": 40 - }, - "frame": { - "x": 66, - "y": 37, - "w": 64, - "h": 40 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 3, - "y": 5, - "w": 64, - "h": 40 - }, - "frame": { - "x": 66, - "y": 37, - "w": 64, - "h": 40 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 3, - "y": 5, - "w": 65, - "h": 40 - }, - "frame": { - "x": 130, - "y": 38, - "w": 65, - "h": 40 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 3, - "y": 5, - "w": 65, - "h": 40 - }, - "frame": { - "x": 130, - "y": 38, - "w": 65, - "h": 40 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 3, - "y": 5, - "w": 65, - "h": 40 - }, - "frame": { - "x": 130, - "y": 38, - "w": 65, - "h": 40 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 3, - "y": 5, - "w": 65, - "h": 40 - }, - "frame": { - "x": 130, - "y": 38, - "w": 65, - "h": 40 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 4, - "y": 4, - "w": 63, - "h": 41 - }, - "frame": { - "x": 195, - "y": 38, - "w": 63, - "h": 41 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 4, - "y": 4, - "w": 63, - "h": 41 - }, - "frame": { - "x": 195, - "y": 38, - "w": 63, - "h": 41 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 4, - "y": 4, - "w": 63, - "h": 41 - }, - "frame": { - "x": 195, - "y": 38, - "w": 63, - "h": 41 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 4, - "y": 4, - "w": 63, - "h": 41 - }, - "frame": { - "x": 195, - "y": 38, - "w": 63, - "h": 41 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 4, - "y": 4, - "w": 63, - "h": 41 - }, - "frame": { - "x": 195, - "y": 38, - "w": 63, - "h": 41 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 4, - "y": 4, - "w": 63, - "h": 41 - }, - "frame": { - "x": 195, - "y": 38, - "w": 63, - "h": 41 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 4, - "y": 4, - "w": 63, - "h": 41 - }, - "frame": { - "x": 195, - "y": 38, - "w": 63, - "h": 41 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 4, - "y": 4, - "w": 63, - "h": 41 - }, - "frame": { - "x": 195, - "y": 38, - "w": 63, - "h": 41 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 5, - "y": 3, - "w": 61, - "h": 42 - }, - "frame": { - "x": 0, - "y": 75, - "w": 61, - "h": 42 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 5, - "y": 3, - "w": 61, - "h": 42 - }, - "frame": { - "x": 0, - "y": 75, - "w": 61, - "h": 42 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 5, - "y": 3, - "w": 61, - "h": 42 - }, - "frame": { - "x": 0, - "y": 75, - "w": 61, - "h": 42 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 5, - "y": 3, - "w": 61, - "h": 42 - }, - "frame": { - "x": 0, - "y": 75, - "w": 61, - "h": 42 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 5, - "y": 3, - "w": 63, - "h": 42 - }, - "frame": { - "x": 61, - "y": 77, - "w": 63, - "h": 42 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 5, - "y": 3, - "w": 63, - "h": 42 - }, - "frame": { - "x": 61, - "y": 77, - "w": 63, - "h": 42 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 5, - "y": 3, - "w": 63, - "h": 42 - }, - "frame": { - "x": 61, - "y": 77, - "w": 63, - "h": 42 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 5, - "y": 3, - "w": 63, - "h": 42 - }, - "frame": { - "x": 61, - "y": 77, - "w": 63, - "h": 42 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 61, - "h": 43 - }, - "frame": { - "x": 124, - "y": 78, - "w": 61, - "h": 43 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 61, - "h": 43 - }, - "frame": { - "x": 124, - "y": 78, - "w": 61, - "h": 43 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 61, - "h": 43 - }, - "frame": { - "x": 124, - "y": 78, - "w": 61, - "h": 43 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 61, - "h": 43 - }, - "frame": { - "x": 124, - "y": 78, - "w": 61, - "h": 43 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 61, - "h": 43 - }, - "frame": { - "x": 124, - "y": 78, - "w": 61, - "h": 43 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 61, - "h": 43 - }, - "frame": { - "x": 124, - "y": 78, - "w": 61, - "h": 43 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 61, - "h": 43 - }, - "frame": { - "x": 124, - "y": 78, - "w": 61, - "h": 43 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 61, - "h": 43 - }, - "frame": { - "x": 124, - "y": 78, - "w": 61, - "h": 43 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 1, - "w": 58, - "h": 44 - }, - "frame": { - "x": 185, - "y": 79, - "w": 58, - "h": 44 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 1, - "w": 58, - "h": 44 - }, - "frame": { - "x": 185, - "y": 79, - "w": 58, - "h": 44 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 1, - "w": 58, - "h": 44 - }, - "frame": { - "x": 185, - "y": 79, - "w": 58, - "h": 44 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 1, - "w": 58, - "h": 44 - }, - "frame": { - "x": 185, - "y": 79, - "w": 58, - "h": 44 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 1, - "w": 61, - "h": 44 - }, - "frame": { - "x": 0, - "y": 117, - "w": 61, - "h": 44 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 1, - "w": 61, - "h": 44 - }, - "frame": { - "x": 0, - "y": 117, - "w": 61, - "h": 44 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 1, - "w": 61, - "h": 44 - }, - "frame": { - "x": 0, - "y": 117, - "w": 61, - "h": 44 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 1, - "w": 61, - "h": 44 - }, - "frame": { - "x": 0, - "y": 117, - "w": 61, - "h": 44 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 17, - "y": 1, - "w": 53, - "h": 44 - }, - "frame": { - "x": 61, - "y": 119, - "w": 53, - "h": 44 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 17, - "y": 1, - "w": 53, - "h": 44 - }, - "frame": { - "x": 61, - "y": 119, - "w": 53, - "h": 44 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 56, - "h": 45 - }, - "frame": { - "x": 114, - "y": 121, - "w": 56, - "h": 45 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 56, - "h": 45 - }, - "frame": { - "x": 114, - "y": 121, - "w": 56, - "h": 45 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 56, - "h": 45 - }, - "frame": { - "x": 114, - "y": 121, - "w": 56, - "h": 45 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 56, - "h": 45 - }, - "frame": { - "x": 114, - "y": 121, - "w": 56, - "h": 45 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 56, - "h": 45 - }, - "frame": { - "x": 114, - "y": 121, - "w": 56, - "h": 45 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 56, - "h": 45 - }, - "frame": { - "x": 114, - "y": 121, - "w": 56, - "h": 45 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 56, - "h": 45 - }, - "frame": { - "x": 114, - "y": 121, - "w": 56, - "h": 45 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 56, - "h": 45 - }, - "frame": { - "x": 114, - "y": 121, - "w": 56, - "h": 45 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 56, - "h": 45 - }, - "frame": { - "x": 114, - "y": 121, - "w": 56, - "h": 45 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 56, - "h": 45 - }, - "frame": { - "x": 114, - "y": 121, - "w": 56, - "h": 45 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 56, - "h": 45 - }, - "frame": { - "x": 114, - "y": 121, - "w": 56, - "h": 45 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 56, - "h": 45 - }, - "frame": { - "x": 114, - "y": 121, - "w": 56, - "h": 45 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 0, - "w": 58, - "h": 45 - }, - "frame": { - "x": 170, - "y": 123, - "w": 58, - "h": 45 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 0, - "w": 58, - "h": 45 - }, - "frame": { - "x": 170, - "y": 123, - "w": 58, - "h": 45 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 0, - "w": 58, - "h": 45 - }, - "frame": { - "x": 170, - "y": 123, - "w": 58, - "h": 45 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 0, - "w": 58, - "h": 45 - }, - "frame": { - "x": 170, - "y": 123, - "w": 58, - "h": 45 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 0, - "w": 58, - "h": 45 - }, - "frame": { - "x": 170, - "y": 123, - "w": 58, - "h": 45 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 0, - "w": 58, - "h": 45 - }, - "frame": { - "x": 170, - "y": 123, - "w": 58, - "h": 45 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 0, - "w": 58, - "h": 45 - }, - "frame": { - "x": 170, - "y": 123, - "w": 58, - "h": 45 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 0, - "w": 58, - "h": 45 - }, - "frame": { - "x": 170, - "y": 123, - "w": 58, - "h": 45 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 14, - "y": 0, - "w": 56, - "h": 45 - }, - "frame": { - "x": 228, - "y": 123, - "w": 56, - "h": 45 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 14, - "y": 0, - "w": 56, - "h": 45 - }, - "frame": { - "x": 228, - "y": 123, - "w": 56, - "h": 45 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 60, - "h": 45 - }, - "frame": { - "x": 0, - "y": 161, - "w": 60, - "h": 45 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 60, - "h": 45 - }, - "frame": { - "x": 0, - "y": 161, - "w": 60, - "h": 45 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 60, - "h": 45 - }, - "frame": { - "x": 0, - "y": 161, - "w": 60, - "h": 45 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 60, - "h": 45 - }, - "frame": { - "x": 0, - "y": 161, - "w": 60, - "h": 45 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 16, - "y": 0, - "w": 54, - "h": 45 - }, - "frame": { - "x": 60, - "y": 163, - "w": 54, - "h": 45 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 16, - "y": 0, - "w": 54, - "h": 45 - }, - "frame": { - "x": 60, - "y": 163, - "w": 54, - "h": 45 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 16, - "y": 0, - "w": 54, - "h": 45 - }, - "frame": { - "x": 114, - "y": 166, - "w": 54, - "h": 45 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 16, - "y": 0, - "w": 54, - "h": 45 - }, - "frame": { - "x": 114, - "y": 166, - "w": 54, - "h": 45 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 9, - "y": 0, - "w": 60, - "h": 45 - }, - "frame": { - "x": 168, - "y": 168, - "w": 60, - "h": 45 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 9, - "y": 0, - "w": 60, - "h": 45 - }, - "frame": { - "x": 168, - "y": 168, - "w": 60, - "h": 45 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 14, - "y": 0, - "w": 55, - "h": 45 - }, - "frame": { - "x": 228, - "y": 168, - "w": 55, - "h": 45 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 14, - "y": 0, - "w": 55, - "h": 45 - }, - "frame": { - "x": 228, - "y": 168, - "w": 55, - "h": 45 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 11, - "y": 0, - "w": 58, - "h": 45 - }, - "frame": { - "x": 0, - "y": 206, - "w": 58, - "h": 45 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 11, - "y": 0, - "w": 58, - "h": 45 - }, - "frame": { - "x": 0, - "y": 206, - "w": 58, - "h": 45 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 13, - "y": 0, - "w": 54, - "h": 45 - }, - "frame": { - "x": 58, - "y": 208, - "w": 54, - "h": 45 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 13, - "y": 0, - "w": 54, - "h": 45 - }, - "frame": { - "x": 58, - "y": 208, - "w": 54, - "h": 45 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 11, - "y": 0, - "w": 55, - "h": 45 - }, - "frame": { - "x": 112, - "y": 211, - "w": 55, - "h": 45 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 11, - "y": 0, - "w": 55, - "h": 45 - }, - "frame": { - "x": 112, - "y": 211, - "w": 55, - "h": 45 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 13, - "y": 0, - "w": 57, - "h": 45 - }, - "frame": { - "x": 167, - "y": 213, - "w": 57, - "h": 45 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 13, - "y": 0, - "w": 57, - "h": 45 - }, - "frame": { - "x": 167, - "y": 213, - "w": 57, - "h": 45 - } - }, - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 9, - "y": 0, - "w": 56, - "h": 45 - }, - "frame": { - "x": 224, - "y": 213, - "w": 56, - "h": 45 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 9, - "y": 0, - "w": 56, - "h": 45 - }, - "frame": { - "x": 224, - "y": 213, - "w": 56, - "h": 45 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:9b55e8d258902c055cb6f58ff78681c7:0900d307ca16c511d3fa2282dd5aaba5:c79e17c206de27e3b7f1ce96f7df8e51$" - } +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 348, "y": 79, "w": 54, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 0, "w": 54, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0002.png", + "frame": { "x": 348, "y": 79, "w": 54, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 0, "w": 54, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0003.png", + "frame": { "x": 231, "y": 40, "w": 56, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 1, "w": 56, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0004.png", + "frame": { "x": 231, "y": 40, "w": 56, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 1, "w": 56, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0005.png", + "frame": { "x": 292, "y": 38, "w": 59, "h": 41 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 3, "w": 59, "h": 41 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0006.png", + "frame": { "x": 292, "y": 38, "w": 59, "h": 41 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 3, "w": 59, "h": 41 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0007.png", + "frame": { "x": 287, "y": 79, "w": 61, "h": 39 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 5, "w": 61, "h": 39 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0008.png", + "frame": { "x": 287, "y": 79, "w": 61, "h": 39 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 5, "w": 61, "h": 39 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0009.png", + "frame": { "x": 292, "y": 0, "w": 64, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 3, "y": 7, "w": 64, "h": 38 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0010.png", + "frame": { "x": 292, "y": 0, "w": 64, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 3, "y": 7, "w": 64, "h": 38 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0011.png", + "frame": { "x": 0, "y": 81, "w": 66, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 1, "y": 9, "w": 66, "h": 36 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0012.png", + "frame": { "x": 0, "y": 81, "w": 66, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 1, "y": 9, "w": 66, "h": 36 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0013.png", + "frame": { "x": 292, "y": 0, "w": 64, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 3, "y": 7, "w": 64, "h": 38 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0014.png", + "frame": { "x": 292, "y": 0, "w": 64, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 3, "y": 7, "w": 64, "h": 38 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0015.png", + "frame": { "x": 287, "y": 79, "w": 61, "h": 39 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 5, "w": 61, "h": 39 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0016.png", + "frame": { "x": 287, "y": 79, "w": 61, "h": 39 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 5, "w": 61, "h": 39 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0017.png", + "frame": { "x": 292, "y": 38, "w": 59, "h": 41 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 3, "w": 59, "h": 41 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0018.png", + "frame": { "x": 292, "y": 38, "w": 59, "h": 41 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 3, "w": 59, "h": 41 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0019.png", + "frame": { "x": 231, "y": 40, "w": 56, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 1, "w": 56, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0020.png", + "frame": { "x": 231, "y": 40, "w": 56, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 1, "w": 56, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0021.png", + "frame": { "x": 348, "y": 79, "w": 54, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 0, "w": 54, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0022.png", + "frame": { "x": 348, "y": 79, "w": 54, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 0, "w": 54, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0023.png", + "frame": { "x": 348, "y": 79, "w": 54, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 0, "w": 54, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0024.png", + "frame": { "x": 348, "y": 79, "w": 54, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 0, "w": 54, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0025.png", + "frame": { "x": 231, "y": 40, "w": 56, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 1, "w": 56, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0026.png", + "frame": { "x": 231, "y": 40, "w": 56, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 1, "w": 56, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0027.png", + "frame": { "x": 292, "y": 38, "w": 59, "h": 41 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 3, "w": 59, "h": 41 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0028.png", + "frame": { "x": 292, "y": 38, "w": 59, "h": 41 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 3, "w": 59, "h": 41 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0029.png", + "frame": { "x": 287, "y": 79, "w": 61, "h": 39 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 5, "w": 61, "h": 39 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0030.png", + "frame": { "x": 287, "y": 79, "w": 61, "h": 39 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 5, "w": 61, "h": 39 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0031.png", + "frame": { "x": 292, "y": 0, "w": 64, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 3, "y": 7, "w": 64, "h": 38 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0032.png", + "frame": { "x": 292, "y": 0, "w": 64, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 3, "y": 7, "w": 64, "h": 38 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0033.png", + "frame": { "x": 0, "y": 81, "w": 66, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 1, "y": 9, "w": 66, "h": 36 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0034.png", + "frame": { "x": 0, "y": 81, "w": 66, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 1, "y": 9, "w": 66, "h": 36 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0035.png", + "frame": { "x": 292, "y": 0, "w": 64, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 3, "y": 7, "w": 64, "h": 38 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0036.png", + "frame": { "x": 292, "y": 0, "w": 64, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 3, "y": 7, "w": 64, "h": 38 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0037.png", + "frame": { "x": 287, "y": 79, "w": 61, "h": 39 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 5, "w": 61, "h": 39 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0038.png", + "frame": { "x": 287, "y": 79, "w": 61, "h": 39 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 5, "w": 61, "h": 39 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0039.png", + "frame": { "x": 292, "y": 38, "w": 59, "h": 41 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 3, "w": 59, "h": 41 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0040.png", + "frame": { "x": 292, "y": 38, "w": 59, "h": 41 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 3, "w": 59, "h": 41 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0041.png", + "frame": { "x": 231, "y": 40, "w": 56, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 1, "w": 56, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0042.png", + "frame": { "x": 231, "y": 40, "w": 56, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 1, "w": 56, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0043.png", + "frame": { "x": 348, "y": 79, "w": 54, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 0, "w": 54, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0044.png", + "frame": { "x": 348, "y": 79, "w": 54, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 0, "w": 54, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0045.png", + "frame": { "x": 348, "y": 79, "w": 54, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 0, "w": 54, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0046.png", + "frame": { "x": 348, "y": 79, "w": 54, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 0, "w": 54, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0047.png", + "frame": { "x": 234, "y": 118, "w": 56, "h": 42 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 2, "w": 56, "h": 42 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0048.png", + "frame": { "x": 234, "y": 118, "w": 56, "h": 42 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 2, "w": 56, "h": 42 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0049.png", + "frame": { "x": 175, "y": 83, "w": 59, "h": 40 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 4, "w": 59, "h": 40 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0050.png", + "frame": { "x": 175, "y": 83, "w": 59, "h": 40 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 4, "w": 59, "h": 40 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0051.png", + "frame": { "x": 0, "y": 117, "w": 62, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 6, "w": 62, "h": 38 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0052.png", + "frame": { "x": 0, "y": 117, "w": 62, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 6, "w": 62, "h": 38 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0053.png", + "frame": { "x": 0, "y": 44, "w": 65, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 2, "y": 8, "w": 65, "h": 37 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0054.png", + "frame": { "x": 0, "y": 44, "w": 65, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 2, "y": 8, "w": 65, "h": 37 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0055.png", + "frame": { "x": 290, "y": 123, "w": 67, "h": 35 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 0, "y": 10, "w": 67, "h": 35 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0056.png", + "frame": { "x": 290, "y": 123, "w": 67, "h": 35 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 0, "y": 10, "w": 67, "h": 35 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0057.png", + "frame": { "x": 65, "y": 44, "w": 65, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 2, "y": 8, "w": 65, "h": 37 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0058.png", + "frame": { "x": 65, "y": 44, "w": 65, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 2, "y": 8, "w": 65, "h": 37 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0059.png", + "frame": { "x": 130, "y": 44, "w": 63, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 6, "w": 63, "h": 38 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0060.png", + "frame": { "x": 130, "y": 44, "w": 63, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 6, "w": 63, "h": 38 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0061.png", + "frame": { "x": 231, "y": 0, "w": 61, "h": 40 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 4, "w": 61, "h": 40 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0062.png", + "frame": { "x": 231, "y": 0, "w": 61, "h": 40 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 4, "w": 61, "h": 40 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0063.png", + "frame": { "x": 116, "y": 0, "w": 59, "h": 42 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 2, "w": 59, "h": 42 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0064.png", + "frame": { "x": 116, "y": 0, "w": 59, "h": 42 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 2, "w": 59, "h": 42 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0065.png", + "frame": { "x": 0, "y": 0, "w": 58, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 0, "w": 58, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0066.png", + "frame": { "x": 0, "y": 0, "w": 58, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 0, "w": 58, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0067.png", + "frame": { "x": 58, "y": 0, "w": 58, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 0, "w": 58, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0068.png", + "frame": { "x": 58, "y": 0, "w": 58, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 0, "w": 58, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0069.png", + "frame": { "x": 175, "y": 0, "w": 56, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 0, "w": 56, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0070.png", + "frame": { "x": 175, "y": 0, "w": 56, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 0, "w": 56, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0071.png", + "frame": { "x": 120, "y": 82, "w": 55, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 14, "y": 1, "w": 55, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0072.png", + "frame": { "x": 120, "y": 82, "w": 55, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 14, "y": 1, "w": 55, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0073.png", + "frame": { "x": 62, "y": 125, "w": 54, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 15, "y": 1, "w": 54, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0074.png", + "frame": { "x": 62, "y": 125, "w": 54, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 15, "y": 1, "w": 54, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0075.png", + "frame": { "x": 0, "y": 155, "w": 52, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 17, "y": 1, "w": 52, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0076.png", + "frame": { "x": 0, "y": 155, "w": 52, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 17, "y": 1, "w": 52, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0077.png", + "frame": { "x": 228, "y": 160, "w": 52, "h": 42 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 18, "y": 2, "w": 52, "h": 42 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0078.png", + "frame": { "x": 228, "y": 160, "w": 52, "h": 42 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 18, "y": 2, "w": 52, "h": 42 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0079.png", + "frame": { "x": 290, "y": 158, "w": 52, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 17, "y": 1, "w": 52, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0080.png", + "frame": { "x": 290, "y": 158, "w": 52, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 17, "y": 1, "w": 52, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0081.png", + "frame": { "x": 116, "y": 125, "w": 53, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 15, "y": 1, "w": 53, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0082.png", + "frame": { "x": 116, "y": 125, "w": 53, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 15, "y": 1, "w": 53, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0083.png", + "frame": { "x": 342, "y": 158, "w": 52, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 14, "y": 1, "w": 52, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0084.png", + "frame": { "x": 342, "y": 158, "w": 52, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 14, "y": 1, "w": 52, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0085.png", + "frame": { "x": 175, "y": 123, "w": 53, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 0, "w": 53, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0086.png", + "frame": { "x": 175, "y": 123, "w": 53, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 0, "w": 53, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0087.png", + "frame": { "x": 66, "y": 81, "w": 54, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 0, "w": 54, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0088.png", + "frame": { "x": 66, "y": 81, "w": 54, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 0, "w": 54, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.8.1-x64", + "image": "451.png", + "format": "RGBA8888", + "size": { "w": 402, "h": 202 }, + "scale": "1" + } } diff --git a/public/images/pokemon/back/451.png b/public/images/pokemon/back/451.png index 1c89885a1b0..03fc0d8f723 100644 Binary files a/public/images/pokemon/back/451.png and b/public/images/pokemon/back/451.png differ diff --git a/public/images/pokemon/back/455.png b/public/images/pokemon/back/455.png index 116faf6f090..2191905e2ce 100644 Binary files a/public/images/pokemon/back/455.png and b/public/images/pokemon/back/455.png differ diff --git a/public/images/pokemon/back/486.png b/public/images/pokemon/back/486.png index 041b03e5790..4df438f6320 100644 Binary files a/public/images/pokemon/back/486.png and b/public/images/pokemon/back/486.png differ diff --git a/public/images/pokemon/back/493-fairy.json b/public/images/pokemon/back/493-fairy.json index 80a3980e65e..d49b40c8937 100644 --- a/public/images/pokemon/back/493-fairy.json +++ b/public/images/pokemon/back/493-fairy.json @@ -4,29 +4,3389 @@ "image": "493-fairy.png", "format": "RGBA8888", "size": { - "w": 76, - "h": 76 + "w": 391, + "h": 391 }, "scale": 1, "frames": [ { - "filename": "0001.png", + "filename": "0110.png", "rotated": false, "trimmed": false, "sourceSize": { - "w": 66, - "h": 76 + "w": 72, + "h": 86 }, "spriteSourceSize": { "x": 0, "y": 0, - "w": 66, - "h": 76 + "w": 72, + "h": 86 }, "frame": { "x": 0, "y": 0, + "w": 72, + "h": 86 + } + }, + { + "filename": "0111.png", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 72, + "h": 86 + }, + "frame": { + "x": 0, + "y": 0, + "w": 72, + "h": 86 + } + }, + { + "filename": "0108.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 71, + "h": 86 + }, + "frame": { + "x": 0, + "y": 86, + "w": 71, + "h": 86 + } + }, + { + "filename": "0109.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 71, + "h": 86 + }, + "frame": { + "x": 0, + "y": 86, + "w": 71, + "h": 86 + } + }, + { + "filename": "0112.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 71, + "h": 86 + }, + "frame": { + "x": 0, + "y": 172, + "w": 71, + "h": 86 + } + }, + { + "filename": "0113.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 71, + "h": 86 + }, + "frame": { + "x": 0, + "y": 172, + "w": 71, + "h": 86 + } + }, + { + "filename": "0106.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 69, + "h": 86 + }, + "frame": { + "x": 0, + "y": 258, + "w": 69, + "h": 86 + } + }, + { + "filename": "0107.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 69, + "h": 86 + }, + "frame": { + "x": 0, + "y": 258, + "w": 69, + "h": 86 + } + }, + { + "filename": "0114.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 3, + "w": 71, + "h": 83 + }, + "frame": { + "x": 69, + "y": 258, + "w": 71, + "h": 83 + } + }, + { + "filename": "0115.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 3, + "w": 71, + "h": 83 + }, + "frame": { + "x": 69, + "y": 258, + "w": 71, + "h": 83 + } + }, + { + "filename": "0104.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 67, + "h": 86 + }, + "frame": { + "x": 71, + "y": 86, + "w": 67, + "h": 86 + } + }, + { + "filename": "0105.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 67, + "h": 86 + }, + "frame": { + "x": 71, + "y": 86, + "w": 67, + "h": 86 + } + }, + { + "filename": "0100.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 4, + "w": 68, + "h": 82 + }, + "frame": { + "x": 72, + "y": 0, + "w": 68, + "h": 82 + } + }, + { + "filename": "0101.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 4, + "w": 68, + "h": 82 + }, + "frame": { + "x": 72, + "y": 0, + "w": 68, + "h": 82 + } + }, + { + "filename": "0102.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 3, + "w": 67, + "h": 83 + }, + "frame": { + "x": 71, + "y": 172, + "w": 67, + "h": 83 + } + }, + { + "filename": "0103.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 3, + "w": 67, + "h": 83 + }, + "frame": { + "x": 71, + "y": 172, + "w": 67, + "h": 83 + } + }, + { + "filename": "0004.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 138, + "y": 82, + "w": 70, + "h": 78 + } + }, + { + "filename": "0005.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 138, + "y": 82, + "w": 70, + "h": 78 + } + }, + { + "filename": "0028.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 138, + "y": 82, + "w": 70, + "h": 78 + } + }, + { + "filename": "0029.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 138, + "y": 82, + "w": 70, + "h": 78 + } + }, + { + "filename": "0052.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 138, + "y": 82, + "w": 70, + "h": 78 + } + }, + { + "filename": "0053.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 138, + "y": 82, + "w": 70, + "h": 78 + } + }, + { + "filename": "0076.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 138, + "y": 82, + "w": 70, + "h": 78 + } + }, + { + "filename": "0077.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 138, + "y": 82, + "w": 70, + "h": 78 + } + }, + { + "filename": "0124.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 138, + "y": 82, + "w": 70, + "h": 78 + } + }, + { + "filename": "0125.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 138, + "y": 82, + "w": 70, + "h": 78 + } + }, + { + "filename": "0148.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 138, + "y": 82, + "w": 70, + "h": 78 + } + }, + { + "filename": "0149.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 138, + "y": 82, + "w": 70, + "h": 78 + } + }, + { + "filename": "0006.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 140, + "y": 0, + "w": 70, + "h": 78 + } + }, + { + "filename": "0007.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 140, + "y": 0, + "w": 70, + "h": 78 + } + }, + { + "filename": "0030.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 140, + "y": 0, + "w": 70, + "h": 78 + } + }, + { + "filename": "0031.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 140, + "y": 0, + "w": 70, + "h": 78 + } + }, + { + "filename": "0054.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 140, + "y": 0, + "w": 70, + "h": 78 + } + }, + { + "filename": "0055.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 140, + "y": 0, + "w": 70, + "h": 78 + } + }, + { + "filename": "0078.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 140, + "y": 0, + "w": 70, + "h": 78 + } + }, + { + "filename": "0079.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 140, + "y": 0, + "w": 70, + "h": 78 + } + }, + { + "filename": "0126.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 140, + "y": 0, + "w": 70, + "h": 78 + } + }, + { + "filename": "0127.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 140, + "y": 0, + "w": 70, + "h": 78 + } + }, + { + "filename": "0150.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 140, + "y": 0, + "w": 70, + "h": 78 + } + }, + { + "filename": "0151.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 140, + "y": 0, + "w": 70, + "h": 78 + } + }, + { + "filename": "0098.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 6, + "w": 68, + "h": 80 + }, + "frame": { + "x": 138, + "y": 160, + "w": 68, + "h": 80 + } + }, + { + "filename": "0099.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 6, + "w": 68, + "h": 80 + }, + "frame": { + "x": 138, + "y": 160, + "w": 68, + "h": 80 + } + }, + { + "filename": "0002.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 69, + "h": 78 + }, + "frame": { + "x": 140, + "y": 240, + "w": 69, + "h": 78 + } + }, + { + "filename": "0003.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 69, + "h": 78 + }, + "frame": { + "x": 140, + "y": 240, + "w": 69, + "h": 78 + } + }, + { + "filename": "0026.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 69, + "h": 78 + }, + "frame": { + "x": 140, + "y": 240, + "w": 69, + "h": 78 + } + }, + { + "filename": "0027.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 69, + "h": 78 + }, + "frame": { + "x": 140, + "y": 240, + "w": 69, + "h": 78 + } + }, + { + "filename": "0050.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 69, + "h": 78 + }, + "frame": { + "x": 140, + "y": 240, + "w": 69, + "h": 78 + } + }, + { + "filename": "0051.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 69, + "h": 78 + }, + "frame": { + "x": 140, + "y": 240, + "w": 69, + "h": 78 + } + }, + { + "filename": "0074.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 69, + "h": 78 + }, + "frame": { + "x": 140, + "y": 240, + "w": 69, + "h": 78 + } + }, + { + "filename": "0075.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 69, + "h": 78 + }, + "frame": { + "x": 140, + "y": 240, + "w": 69, + "h": 78 + } + }, + { + "filename": "0122.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 69, + "h": 78 + }, + "frame": { + "x": 140, + "y": 240, + "w": 69, + "h": 78 + } + }, + { + "filename": "0123.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 69, + "h": 78 + }, + "frame": { + "x": 140, + "y": 240, + "w": 69, + "h": 78 + } + }, + { + "filename": "0146.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 69, + "h": 78 + }, + "frame": { + "x": 140, + "y": 240, + "w": 69, + "h": 78 + } + }, + { + "filename": "0147.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 69, + "h": 78 + }, + "frame": { + "x": 140, + "y": 240, + "w": 69, + "h": 78 + } + }, + { + "filename": "0001.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 2, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 206, + "y": 160, + "w": 68, + "h": 78 + } + }, + { + "filename": "0024.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 2, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 206, + "y": 160, + "w": 68, + "h": 78 + } + }, + { + "filename": "0025.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 2, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 206, + "y": 160, + "w": 68, + "h": 78 + } + }, + { + "filename": "0048.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 2, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 206, + "y": 160, + "w": 68, + "h": 78 + } + }, + { + "filename": "0049.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 2, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 206, + "y": 160, + "w": 68, + "h": 78 + } + }, + { + "filename": "0072.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 2, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 206, + "y": 160, + "w": 68, + "h": 78 + } + }, + { + "filename": "0073.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 2, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 206, + "y": 160, + "w": 68, + "h": 78 + } + }, + { + "filename": "0096.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 2, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 206, + "y": 160, + "w": 68, + "h": 78 + } + }, + { + "filename": "0097.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 2, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 206, + "y": 160, + "w": 68, + "h": 78 + } + }, + { + "filename": "0118.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 2, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 206, + "y": 160, + "w": 68, + "h": 78 + } + }, + { + "filename": "0119.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 2, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 206, + "y": 160, + "w": 68, + "h": 78 + } + }, + { + "filename": "0120.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 2, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 206, + "y": 160, + "w": 68, + "h": 78 + } + }, + { + "filename": "0121.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 2, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 206, + "y": 160, + "w": 68, + "h": 78 + } + }, + { + "filename": "0144.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 2, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 206, + "y": 160, + "w": 68, + "h": 78 + } + }, + { + "filename": "0145.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 2, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 206, + "y": 160, + "w": 68, + "h": 78 + } + }, + { + "filename": "0116.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 208, + "y": 78, + "w": 68, + "h": 78 + } + }, + { + "filename": "0117.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 208, + "y": 78, + "w": 68, + "h": 78 + } + }, + { + "filename": "0008.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 9, + "w": 68, + "h": 77 + }, + "frame": { + "x": 210, + "y": 0, + "w": 68, + "h": 77 + } + }, + { + "filename": "0009.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 9, + "w": 68, + "h": 77 + }, + "frame": { + "x": 210, + "y": 0, + "w": 68, + "h": 77 + } + }, + { + "filename": "0032.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 9, + "w": 68, + "h": 77 + }, + "frame": { + "x": 210, + "y": 0, + "w": 68, + "h": 77 + } + }, + { + "filename": "0033.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 9, + "w": 68, + "h": 77 + }, + "frame": { + "x": 210, + "y": 0, + "w": 68, + "h": 77 + } + }, + { + "filename": "0056.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 9, + "w": 68, + "h": 77 + }, + "frame": { + "x": 210, + "y": 0, + "w": 68, + "h": 77 + } + }, + { + "filename": "0057.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 9, + "w": 68, + "h": 77 + }, + "frame": { + "x": 210, + "y": 0, + "w": 68, + "h": 77 + } + }, + { + "filename": "0080.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 9, + "w": 68, + "h": 77 + }, + "frame": { + "x": 210, + "y": 0, + "w": 68, + "h": 77 + } + }, + { + "filename": "0081.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 9, + "w": 68, + "h": 77 + }, + "frame": { + "x": 210, + "y": 0, + "w": 68, + "h": 77 + } + }, + { + "filename": "0128.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 9, + "w": 68, + "h": 77 + }, + "frame": { + "x": 210, + "y": 0, + "w": 68, + "h": 77 + } + }, + { + "filename": "0129.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 9, + "w": 68, + "h": 77 + }, + "frame": { + "x": 210, + "y": 0, + "w": 68, + "h": 77 + } + }, + { + "filename": "0152.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 9, + "w": 68, + "h": 77 + }, + "frame": { + "x": 210, + "y": 0, + "w": 68, + "h": 77 + } + }, + { + "filename": "0153.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 9, + "w": 68, + "h": 77 + }, + "frame": { + "x": 210, + "y": 0, + "w": 68, + "h": 77 + } + }, + { + "filename": "0018.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 156, + "w": 67, + "h": 78 + } + }, + { + "filename": "0019.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 156, + "w": 67, + "h": 78 + } + }, + { + "filename": "0042.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 156, + "w": 67, + "h": 78 + } + }, + { + "filename": "0043.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 156, + "w": 67, + "h": 78 + } + }, + { + "filename": "0066.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 156, + "w": 67, + "h": 78 + } + }, + { + "filename": "0067.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 156, + "w": 67, + "h": 78 + } + }, + { + "filename": "0090.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 156, + "w": 67, + "h": 78 + } + }, + { + "filename": "0091.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 156, + "w": 67, + "h": 78 + } + }, + { + "filename": "0138.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 156, + "w": 67, + "h": 78 + } + }, + { + "filename": "0139.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 156, + "w": 67, + "h": 78 + } + }, + { + "filename": "0020.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 4, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 276, + "y": 77, + "w": 67, + "h": 78 + } + }, + { + "filename": "0021.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 4, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 276, + "y": 77, + "w": 67, + "h": 78 + } + }, + { + "filename": "0044.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 4, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 276, + "y": 77, + "w": 67, + "h": 78 + } + }, + { + "filename": "0045.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 4, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 276, + "y": 77, + "w": 67, + "h": 78 + } + }, + { + "filename": "0068.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 4, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 276, + "y": 77, + "w": 67, + "h": 78 + } + }, + { + "filename": "0069.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 4, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 276, + "y": 77, + "w": 67, + "h": 78 + } + }, + { + "filename": "0092.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 4, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 276, + "y": 77, + "w": 67, + "h": 78 + } + }, + { + "filename": "0093.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 4, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 276, + "y": 77, + "w": 67, + "h": 78 + } + }, + { + "filename": "0140.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 4, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 276, + "y": 77, + "w": 67, + "h": 78 + } + }, + { + "filename": "0141.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 4, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 276, + "y": 77, + "w": 67, + "h": 78 + } + }, + { + "filename": "0010.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 9, + "w": 67, + "h": 77 + }, + "frame": { + "x": 278, + "y": 0, + "w": 67, + "h": 77 + } + }, + { + "filename": "0011.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 9, + "w": 67, + "h": 77 + }, + "frame": { + "x": 278, + "y": 0, + "w": 67, + "h": 77 + } + }, + { + "filename": "0034.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 9, + "w": 67, + "h": 77 + }, + "frame": { + "x": 278, + "y": 0, + "w": 67, + "h": 77 + } + }, + { + "filename": "0035.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 9, + "w": 67, + "h": 77 + }, + "frame": { + "x": 278, + "y": 0, + "w": 67, + "h": 77 + } + }, + { + "filename": "0058.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 9, + "w": 67, + "h": 77 + }, + "frame": { + "x": 278, + "y": 0, + "w": 67, + "h": 77 + } + }, + { + "filename": "0059.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 9, + "w": 67, + "h": 77 + }, + "frame": { + "x": 278, + "y": 0, + "w": 67, + "h": 77 + } + }, + { + "filename": "0082.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 9, + "w": 67, + "h": 77 + }, + "frame": { + "x": 278, + "y": 0, + "w": 67, + "h": 77 + } + }, + { + "filename": "0083.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 9, + "w": 67, + "h": 77 + }, + "frame": { + "x": 278, + "y": 0, + "w": 67, + "h": 77 + } + }, + { + "filename": "0130.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 9, + "w": 67, + "h": 77 + }, + "frame": { + "x": 278, + "y": 0, + "w": 67, + "h": 77 + } + }, + { + "filename": "0131.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 9, + "w": 67, + "h": 77 + }, + "frame": { + "x": 278, + "y": 0, + "w": 67, + "h": 77 + } + }, + { + "filename": "0154.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 9, + "w": 67, + "h": 77 + }, + "frame": { + "x": 278, + "y": 0, + "w": 67, + "h": 77 + } + }, + { + "filename": "0155.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 9, + "w": 67, + "h": 77 + }, + "frame": { + "x": 278, + "y": 0, + "w": 67, + "h": 77 + } + }, + { + "filename": "0022.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 234, + "w": 67, + "h": 78 + } + }, + { + "filename": "0023.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 234, + "w": 67, + "h": 78 + } + }, + { + "filename": "0046.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 234, + "w": 67, + "h": 78 + } + }, + { + "filename": "0047.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 234, + "w": 67, + "h": 78 + } + }, + { + "filename": "0070.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 234, + "w": 67, + "h": 78 + } + }, + { + "filename": "0071.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 234, + "w": 67, + "h": 78 + } + }, + { + "filename": "0094.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 234, + "w": 67, + "h": 78 + } + }, + { + "filename": "0095.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 234, + "w": 67, + "h": 78 + } + }, + { + "filename": "0142.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 234, + "w": 67, + "h": 78 + } + }, + { + "filename": "0143.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 234, + "w": 67, + "h": 78 + } + }, + { + "filename": "0014.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 7, + "y": 9, + "w": 65, + "h": 77 + }, + "frame": { + "x": 209, + "y": 238, + "w": 65, + "h": 77 + } + }, + { + "filename": "0015.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 7, + "y": 9, + "w": 65, + "h": 77 + }, + "frame": { + "x": 209, + "y": 238, + "w": 65, + "h": 77 + } + }, + { + "filename": "0038.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 7, + "y": 9, + "w": 65, + "h": 77 + }, + "frame": { + "x": 209, + "y": 238, + "w": 65, + "h": 77 + } + }, + { + "filename": "0039.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 7, + "y": 9, + "w": 65, + "h": 77 + }, + "frame": { + "x": 209, + "y": 238, + "w": 65, + "h": 77 + } + }, + { + "filename": "0062.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 7, + "y": 9, + "w": 65, + "h": 77 + }, + "frame": { + "x": 209, + "y": 238, + "w": 65, + "h": 77 + } + }, + { + "filename": "0063.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 7, + "y": 9, + "w": 65, + "h": 77 + }, + "frame": { + "x": 209, + "y": 238, + "w": 65, + "h": 77 + } + }, + { + "filename": "0086.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 7, + "y": 9, + "w": 65, + "h": 77 + }, + "frame": { + "x": 209, + "y": 238, + "w": 65, + "h": 77 + } + }, + { + "filename": "0087.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 7, + "y": 9, + "w": 65, + "h": 77 + }, + "frame": { + "x": 209, + "y": 238, + "w": 65, + "h": 77 + } + }, + { + "filename": "0134.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 7, + "y": 9, + "w": 65, + "h": 77 + }, + "frame": { + "x": 209, + "y": 238, + "w": 65, + "h": 77 + } + }, + { + "filename": "0135.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 7, + "y": 9, + "w": 65, + "h": 77 + }, + "frame": { + "x": 209, + "y": 238, + "w": 65, + "h": 77 + } + }, + { + "filename": "0158.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 7, + "y": 9, + "w": 65, + "h": 77 + }, + "frame": { + "x": 209, + "y": 238, + "w": 65, + "h": 77 + } + }, + { + "filename": "0159.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 7, + "y": 9, + "w": 65, + "h": 77 + }, + "frame": { + "x": 209, + "y": 238, + "w": 65, + "h": 77 + } + }, + { + "filename": "0016.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 6, + "y": 8, "w": 66, + "h": 78 + }, + "frame": { + "x": 274, + "y": 312, + "w": 66, + "h": 78 + } + }, + { + "filename": "0017.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 6, + "y": 8, + "w": 66, + "h": 78 + }, + "frame": { + "x": 274, + "y": 312, + "w": 66, + "h": 78 + } + }, + { + "filename": "0040.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 6, + "y": 8, + "w": 66, + "h": 78 + }, + "frame": { + "x": 274, + "y": 312, + "w": 66, + "h": 78 + } + }, + { + "filename": "0041.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 6, + "y": 8, + "w": 66, + "h": 78 + }, + "frame": { + "x": 274, + "y": 312, + "w": 66, + "h": 78 + } + }, + { + "filename": "0064.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 6, + "y": 8, + "w": 66, + "h": 78 + }, + "frame": { + "x": 274, + "y": 312, + "w": 66, + "h": 78 + } + }, + { + "filename": "0065.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 6, + "y": 8, + "w": 66, + "h": 78 + }, + "frame": { + "x": 274, + "y": 312, + "w": 66, + "h": 78 + } + }, + { + "filename": "0088.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 6, + "y": 8, + "w": 66, + "h": 78 + }, + "frame": { + "x": 274, + "y": 312, + "w": 66, + "h": 78 + } + }, + { + "filename": "0089.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 6, + "y": 8, + "w": 66, + "h": 78 + }, + "frame": { + "x": 274, + "y": 312, + "w": 66, + "h": 78 + } + }, + { + "filename": "0136.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 6, + "y": 8, + "w": 66, + "h": 78 + }, + "frame": { + "x": 274, + "y": 312, + "w": 66, + "h": 78 + } + }, + { + "filename": "0137.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 6, + "y": 8, + "w": 66, + "h": 78 + }, + "frame": { + "x": 274, + "y": 312, + "w": 66, + "h": 78 + } + }, + { + "filename": "0160.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 6, + "y": 8, + "w": 66, + "h": 78 + }, + "frame": { + "x": 274, + "y": 312, + "w": 66, + "h": 78 + } + }, + { + "filename": "0161.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 6, + "y": 8, + "w": 66, + "h": 78 + }, + "frame": { + "x": 274, + "y": 312, + "w": 66, + "h": 78 + } + }, + { + "filename": "0012.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 8, + "y": 10, + "w": 64, + "h": 76 + }, + "frame": { + "x": 209, + "y": 315, + "w": 64, + "h": 76 + } + }, + { + "filename": "0013.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 8, + "y": 10, + "w": 64, + "h": 76 + }, + "frame": { + "x": 209, + "y": 315, + "w": 64, + "h": 76 + } + }, + { + "filename": "0036.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 8, + "y": 10, + "w": 64, + "h": 76 + }, + "frame": { + "x": 209, + "y": 315, + "w": 64, + "h": 76 + } + }, + { + "filename": "0037.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 8, + "y": 10, + "w": 64, + "h": 76 + }, + "frame": { + "x": 209, + "y": 315, + "w": 64, + "h": 76 + } + }, + { + "filename": "0060.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 8, + "y": 10, + "w": 64, + "h": 76 + }, + "frame": { + "x": 209, + "y": 315, + "w": 64, + "h": 76 + } + }, + { + "filename": "0061.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 8, + "y": 10, + "w": 64, + "h": 76 + }, + "frame": { + "x": 209, + "y": 315, + "w": 64, + "h": 76 + } + }, + { + "filename": "0084.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 8, + "y": 10, + "w": 64, + "h": 76 + }, + "frame": { + "x": 209, + "y": 315, + "w": 64, + "h": 76 + } + }, + { + "filename": "0085.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 8, + "y": 10, + "w": 64, + "h": 76 + }, + "frame": { + "x": 209, + "y": 315, + "w": 64, + "h": 76 + } + }, + { + "filename": "0132.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 8, + "y": 10, + "w": 64, + "h": 76 + }, + "frame": { + "x": 209, + "y": 315, + "w": 64, + "h": 76 + } + }, + { + "filename": "0133.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 8, + "y": 10, + "w": 64, + "h": 76 + }, + "frame": { + "x": 209, + "y": 315, + "w": 64, + "h": 76 + } + }, + { + "filename": "0156.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 8, + "y": 10, + "w": 64, + "h": 76 + }, + "frame": { + "x": 209, + "y": 315, + "w": 64, + "h": 76 + } + }, + { + "filename": "0157.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 8, + "y": 10, + "w": 64, + "h": 76 + }, + "frame": { + "x": 209, + "y": 315, + "w": 64, "h": 76 } } @@ -35,7 +3395,6 @@ ], "meta": { "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:535108d0866fd3226c8d5a14ee4e2ce6:fcabf226d186bb04dc0d1d01b1453616:9ab527962e79006eb780a43bbf3afdac$" + "version": "3.0" } } diff --git a/public/images/pokemon/back/493-fairy.png b/public/images/pokemon/back/493-fairy.png index 4606899fca8..b335c1dcb17 100644 Binary files a/public/images/pokemon/back/493-fairy.png and b/public/images/pokemon/back/493-fairy.png differ diff --git a/public/images/pokemon/back/502.png b/public/images/pokemon/back/502.png index 4857186bd7e..5225cb803e0 100644 Binary files a/public/images/pokemon/back/502.png and b/public/images/pokemon/back/502.png differ diff --git a/public/images/pokemon/back/503.png b/public/images/pokemon/back/503.png index 96a901b2bdc..8b38780da27 100644 Binary files a/public/images/pokemon/back/503.png and b/public/images/pokemon/back/503.png differ diff --git a/public/images/pokemon/back/527.png b/public/images/pokemon/back/527.png index 61eab42c767..ce061ffe60a 100644 Binary files a/public/images/pokemon/back/527.png and b/public/images/pokemon/back/527.png differ diff --git a/public/images/pokemon/back/528.png b/public/images/pokemon/back/528.png index 1b7733cd4db..81fc8414dd8 100644 Binary files a/public/images/pokemon/back/528.png and b/public/images/pokemon/back/528.png differ diff --git a/public/images/pokemon/back/587.png b/public/images/pokemon/back/587.png index e7304b754ce..8932c1f480a 100644 Binary files a/public/images/pokemon/back/587.png and b/public/images/pokemon/back/587.png differ diff --git a/public/images/pokemon/back/590.png b/public/images/pokemon/back/590.png index 9874d4e216d..6e7685b2ced 100644 Binary files a/public/images/pokemon/back/590.png and b/public/images/pokemon/back/590.png differ diff --git a/public/images/pokemon/back/591.png b/public/images/pokemon/back/591.png index af87fdf527e..2f2d9f34f08 100644 Binary files a/public/images/pokemon/back/591.png and b/public/images/pokemon/back/591.png differ diff --git a/public/images/pokemon/back/616.png b/public/images/pokemon/back/616.png index 751eaf485da..7033e50a0dd 100644 Binary files a/public/images/pokemon/back/616.png and b/public/images/pokemon/back/616.png differ diff --git a/public/images/pokemon/back/6503.png b/public/images/pokemon/back/6503.png index 3953d5d6c66..c88de28046e 100644 Binary files a/public/images/pokemon/back/6503.png and b/public/images/pokemon/back/6503.png differ diff --git a/public/images/pokemon/back/656.png b/public/images/pokemon/back/656.png index 5f6ce42c63b..62362337762 100644 Binary files a/public/images/pokemon/back/656.png and b/public/images/pokemon/back/656.png differ diff --git a/public/images/pokemon/back/657.png b/public/images/pokemon/back/657.png index c7655a643b2..1e61b595e49 100644 Binary files a/public/images/pokemon/back/657.png and b/public/images/pokemon/back/657.png differ diff --git a/public/images/pokemon/back/658-ash.json b/public/images/pokemon/back/658-ash.json index 4ddab1765b2..51a722070b3 100644 --- a/public/images/pokemon/back/658-ash.json +++ b/public/images/pokemon/back/658-ash.json @@ -1,41 +1,19 @@ -{ - "textures": [ - { - "image": "658-ash.png", - "format": "RGBA8888", - "size": { - "w": 73, - "h": 73 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 73, - "h": 69 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 73, - "h": 69 - }, - "frame": { - "x": 0, - "y": 0, - "w": 73, - "h": 69 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:4f38801bb3afeda5faff04bdcf6a666f:0c78ce2715e7510bf55da0a92b42661c:bfbf521a5c7bd80bcd95a96d9789c0dd$" - } +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.7-x64", + "format": "I8", + "size": { "w": 73, "h": 73 }, + "scale": "1" + } } diff --git a/public/images/pokemon/back/658-ash.png b/public/images/pokemon/back/658-ash.png index e574e888fac..382b06fd6cb 100644 Binary files a/public/images/pokemon/back/658-ash.png and b/public/images/pokemon/back/658-ash.png differ diff --git a/public/images/pokemon/back/658.json b/public/images/pokemon/back/658.json index 119002876a6..050b63e3592 100644 --- a/public/images/pokemon/back/658.json +++ b/public/images/pokemon/back/658.json @@ -1,41 +1,19 @@ -{ - "textures": [ - { - "image": "658.png", - "format": "RGBA8888", - "size": { - "w": 77, - "h": 77 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 77, - "h": 65 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 77, - "h": 65 - }, - "frame": { - "x": 0, - "y": 0, - "w": 77, - "h": 65 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:acdb9925f3f23b947504eec7cc28c92d:1a13d9d418f6c107bb9e5d621d9154bb:5affcab976148657d36bf4ff3410f92d$" - } +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 77, "h": 77 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 77, "h": 77 }, + "sourceSize": { "w": 77, "h": 77 }, + "duration": 100 + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.7-x64", + "format": "I8", + "size": { "w": 77, "h": 77 }, + "scale": "1" + } } diff --git a/public/images/pokemon/back/658.png b/public/images/pokemon/back/658.png index a8128e1c73f..ea24d9a6336 100644 Binary files a/public/images/pokemon/back/658.png and b/public/images/pokemon/back/658.png differ diff --git a/public/images/pokemon/back/6706.png b/public/images/pokemon/back/6706.png index e7620078a5b..82c64e98535 100644 Binary files a/public/images/pokemon/back/6706.png and b/public/images/pokemon/back/6706.png differ diff --git a/public/images/pokemon/back/676-dandy.png b/public/images/pokemon/back/676-dandy.png index f8052549668..8a4f26e17b2 100644 Binary files a/public/images/pokemon/back/676-dandy.png and b/public/images/pokemon/back/676-dandy.png differ diff --git a/public/images/pokemon/back/676-debutante.png b/public/images/pokemon/back/676-debutante.png index 507ea4addbe..bed3f323a6b 100644 Binary files a/public/images/pokemon/back/676-debutante.png and b/public/images/pokemon/back/676-debutante.png differ diff --git a/public/images/pokemon/back/676-diamond.png b/public/images/pokemon/back/676-diamond.png index 9498e4e75be..436d9b6dbde 100644 Binary files a/public/images/pokemon/back/676-diamond.png and b/public/images/pokemon/back/676-diamond.png differ diff --git a/public/images/pokemon/back/676-heart.png b/public/images/pokemon/back/676-heart.png index 49c83c6c113..57d472c3834 100644 Binary files a/public/images/pokemon/back/676-heart.png and b/public/images/pokemon/back/676-heart.png differ diff --git a/public/images/pokemon/back/676-kabuki.png b/public/images/pokemon/back/676-kabuki.png index 2aa6fccce61..d602c607643 100644 Binary files a/public/images/pokemon/back/676-kabuki.png and b/public/images/pokemon/back/676-kabuki.png differ diff --git a/public/images/pokemon/back/676-la-reine.png b/public/images/pokemon/back/676-la-reine.png index 2147e5cab01..de1b1a15b90 100644 Binary files a/public/images/pokemon/back/676-la-reine.png and b/public/images/pokemon/back/676-la-reine.png differ diff --git a/public/images/pokemon/back/676-matron.png b/public/images/pokemon/back/676-matron.png index 38092e4fefe..e01a8f273af 100644 Binary files a/public/images/pokemon/back/676-matron.png and b/public/images/pokemon/back/676-matron.png differ diff --git a/public/images/pokemon/back/676-pharaoh.png b/public/images/pokemon/back/676-pharaoh.png index a7ca046406f..13952c58c68 100644 Binary files a/public/images/pokemon/back/676-pharaoh.png and b/public/images/pokemon/back/676-pharaoh.png differ diff --git a/public/images/pokemon/back/676-star.png b/public/images/pokemon/back/676-star.png index 9b082488381..5b188f33498 100644 Binary files a/public/images/pokemon/back/676-star.png and b/public/images/pokemon/back/676-star.png differ diff --git a/public/images/pokemon/back/682.png b/public/images/pokemon/back/682.png index a801a3be1d4..60f869b2f2c 100644 Binary files a/public/images/pokemon/back/682.png and b/public/images/pokemon/back/682.png differ diff --git a/public/images/pokemon/back/683.png b/public/images/pokemon/back/683.png index 2183bc34796..38247067a25 100644 Binary files a/public/images/pokemon/back/683.png and b/public/images/pokemon/back/683.png differ diff --git a/public/images/pokemon/back/684.png b/public/images/pokemon/back/684.png index 1ba17e86bac..3f02f312123 100644 Binary files a/public/images/pokemon/back/684.png and b/public/images/pokemon/back/684.png differ diff --git a/public/images/pokemon/back/685.png b/public/images/pokemon/back/685.png index b1a18694193..eab453253cc 100644 Binary files a/public/images/pokemon/back/685.png and b/public/images/pokemon/back/685.png differ diff --git a/public/images/pokemon/back/688.json b/public/images/pokemon/back/688.json index 872fbc1f9db..d9f30db34a8 100644 --- a/public/images/pokemon/back/688.json +++ b/public/images/pokemon/back/688.json @@ -1,41 +1,19 @@ -{ - "textures": [ - { - "image": "688.png", - "format": "RGBA8888", - "size": { - "w": 52, - "h": 52 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 41, - "h": 52 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 41, - "h": 52 - }, - "frame": { - "x": 0, - "y": 0, - "w": 41, - "h": 52 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:ea462f2b1b46327e3b8fcb7ec5e44f08:2d2598cc03dec73182dbea237ad83b34:176060351d0044923af938ba7932a6ef$" - } +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 51, "h": 65 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 51, "h": 65 }, + "sourceSize": { "w": 51, "h": 65 } + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.7-dev", + "image": "688.png", + "format": "I8", + "size": { "w": 51, "h": 65 }, + "scale": "1" + } } diff --git a/public/images/pokemon/back/688.png b/public/images/pokemon/back/688.png index 33602c624a7..bb22ceed75e 100644 Binary files a/public/images/pokemon/back/688.png and b/public/images/pokemon/back/688.png differ diff --git a/public/images/pokemon/back/696.png b/public/images/pokemon/back/696.png index 369f2d38188..a8ba08aa6ab 100644 Binary files a/public/images/pokemon/back/696.png and b/public/images/pokemon/back/696.png differ diff --git a/public/images/pokemon/back/697.png b/public/images/pokemon/back/697.png index dbf491bf1e8..c3883f76b72 100644 Binary files a/public/images/pokemon/back/697.png and b/public/images/pokemon/back/697.png differ diff --git a/public/images/pokemon/back/773-bug.png b/public/images/pokemon/back/773-bug.png index 8c7278b743f..d0bb3a6df96 100644 Binary files a/public/images/pokemon/back/773-bug.png and b/public/images/pokemon/back/773-bug.png differ diff --git a/public/images/pokemon/back/773-dark.png b/public/images/pokemon/back/773-dark.png index bd872066110..38cbb671d36 100644 Binary files a/public/images/pokemon/back/773-dark.png and b/public/images/pokemon/back/773-dark.png differ diff --git a/public/images/pokemon/back/773-dragon.png b/public/images/pokemon/back/773-dragon.png index 554ce6fbdc8..7853bacc32a 100644 Binary files a/public/images/pokemon/back/773-dragon.png and b/public/images/pokemon/back/773-dragon.png differ diff --git a/public/images/pokemon/back/773-electric.png b/public/images/pokemon/back/773-electric.png index 0f36dc51b8a..69fa1e7a569 100644 Binary files a/public/images/pokemon/back/773-electric.png and b/public/images/pokemon/back/773-electric.png differ diff --git a/public/images/pokemon/back/773-fairy.png b/public/images/pokemon/back/773-fairy.png index 70a61741005..4ee19812296 100644 Binary files a/public/images/pokemon/back/773-fairy.png and b/public/images/pokemon/back/773-fairy.png differ diff --git a/public/images/pokemon/back/773-fighting.png b/public/images/pokemon/back/773-fighting.png index 4762f086f97..af01b260684 100644 Binary files a/public/images/pokemon/back/773-fighting.png and b/public/images/pokemon/back/773-fighting.png differ diff --git a/public/images/pokemon/back/773-fire.png b/public/images/pokemon/back/773-fire.png index f695290d96a..ee604c52a8e 100644 Binary files a/public/images/pokemon/back/773-fire.png and b/public/images/pokemon/back/773-fire.png differ diff --git a/public/images/pokemon/back/773-flying.png b/public/images/pokemon/back/773-flying.png index d5a780d5ef2..70101d4ce73 100644 Binary files a/public/images/pokemon/back/773-flying.png and b/public/images/pokemon/back/773-flying.png differ diff --git a/public/images/pokemon/back/773-ghost.png b/public/images/pokemon/back/773-ghost.png index aad344a9fc1..717ce1bd5b2 100644 Binary files a/public/images/pokemon/back/773-ghost.png and b/public/images/pokemon/back/773-ghost.png differ diff --git a/public/images/pokemon/back/773-grass.png b/public/images/pokemon/back/773-grass.png index 36e938e5df0..0df3177ede0 100644 Binary files a/public/images/pokemon/back/773-grass.png and b/public/images/pokemon/back/773-grass.png differ diff --git a/public/images/pokemon/back/773-ground.png b/public/images/pokemon/back/773-ground.png index caad391ce30..247fc277f24 100644 Binary files a/public/images/pokemon/back/773-ground.png and b/public/images/pokemon/back/773-ground.png differ diff --git a/public/images/pokemon/back/773-ice.png b/public/images/pokemon/back/773-ice.png index 89dd181f02f..9d336ec248f 100644 Binary files a/public/images/pokemon/back/773-ice.png and b/public/images/pokemon/back/773-ice.png differ diff --git a/public/images/pokemon/back/773-poison.png b/public/images/pokemon/back/773-poison.png index 861526dfed4..68af7bee299 100644 Binary files a/public/images/pokemon/back/773-poison.png and b/public/images/pokemon/back/773-poison.png differ diff --git a/public/images/pokemon/back/773-psychic.png b/public/images/pokemon/back/773-psychic.png index a2da865fbf2..e9f37a2f583 100644 Binary files a/public/images/pokemon/back/773-psychic.png and b/public/images/pokemon/back/773-psychic.png differ diff --git a/public/images/pokemon/back/773-rock.png b/public/images/pokemon/back/773-rock.png index 080f749350b..79eb24d99bb 100644 Binary files a/public/images/pokemon/back/773-rock.png and b/public/images/pokemon/back/773-rock.png differ diff --git a/public/images/pokemon/back/773-steel.png b/public/images/pokemon/back/773-steel.png index 1ffa4d750d0..f686581903b 100644 Binary files a/public/images/pokemon/back/773-steel.png and b/public/images/pokemon/back/773-steel.png differ diff --git a/public/images/pokemon/back/773-water.png b/public/images/pokemon/back/773-water.png index bb53bcb91e8..f9a5afacd7e 100644 Binary files a/public/images/pokemon/back/773-water.png and b/public/images/pokemon/back/773-water.png differ diff --git a/public/images/pokemon/back/773.png b/public/images/pokemon/back/773.png index 42a69116b27..7e264ef335f 100644 Binary files a/public/images/pokemon/back/773.png and b/public/images/pokemon/back/773.png differ diff --git a/public/images/pokemon/back/774-blue.png b/public/images/pokemon/back/774-blue.png index bafde223e4f..f76de90107c 100644 Binary files a/public/images/pokemon/back/774-blue.png and b/public/images/pokemon/back/774-blue.png differ diff --git a/public/images/pokemon/back/774-green.png b/public/images/pokemon/back/774-green.png index 56f1d17599b..dd6df86f25a 100644 Binary files a/public/images/pokemon/back/774-green.png and b/public/images/pokemon/back/774-green.png differ diff --git a/public/images/pokemon/back/774-indigo.png b/public/images/pokemon/back/774-indigo.png index 2db483cc5e0..c1d38a7ce7b 100644 Binary files a/public/images/pokemon/back/774-indigo.png and b/public/images/pokemon/back/774-indigo.png differ diff --git a/public/images/pokemon/back/774-orange.png b/public/images/pokemon/back/774-orange.png index df2ef4e32e8..ce78418883e 100644 Binary files a/public/images/pokemon/back/774-orange.png and b/public/images/pokemon/back/774-orange.png differ diff --git a/public/images/pokemon/back/774-red.png b/public/images/pokemon/back/774-red.png index f736d702aa9..cd3be03a55f 100644 Binary files a/public/images/pokemon/back/774-red.png and b/public/images/pokemon/back/774-red.png differ diff --git a/public/images/pokemon/back/774-violet.png b/public/images/pokemon/back/774-violet.png index 4c752d2d9f6..e01614d4a5d 100644 Binary files a/public/images/pokemon/back/774-violet.png and b/public/images/pokemon/back/774-violet.png differ diff --git a/public/images/pokemon/back/774-yellow.png b/public/images/pokemon/back/774-yellow.png index 887a6cf313a..2453b68aaf6 100644 Binary files a/public/images/pokemon/back/774-yellow.png and b/public/images/pokemon/back/774-yellow.png differ diff --git a/public/images/pokemon/back/894.png b/public/images/pokemon/back/894.png index 337cba1cc71..b4cc4974ce2 100644 Binary files a/public/images/pokemon/back/894.png and b/public/images/pokemon/back/894.png differ diff --git a/public/images/pokemon/back/945.png b/public/images/pokemon/back/945.png index a89963b7cc3..6359f2cd77a 100644 Binary files a/public/images/pokemon/back/945.png and b/public/images/pokemon/back/945.png differ diff --git a/public/images/pokemon/back/966-caph-starmobile.json b/public/images/pokemon/back/966-caph-starmobile.json new file mode 100644 index 00000000000..d71eccd11d7 --- /dev/null +++ b/public/images/pokemon/back/966-caph-starmobile.json @@ -0,0 +1,41 @@ +{ + "textures": [ + { + "image": "966-caph-starmobile.png", + "format": "RGBA8888", + "size": { + "w": 84, + "h": 84 + }, + "scale": 0.333, + "frames": [ + { + "filename": "0001.png", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 96, + "h": 96 + }, + "spriteSourceSize": { + "x": 6, + "y": 20, + "w": 84, + "h": 56 + }, + "frame": { + "x": 0, + "y": 0, + "w": 84, + "h": 56 + } + } + ] + } + ], + "meta": { + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0", + "smartupdate": "$TexturePacker:SmartUpdate:0226ae22b7a4822d78e38df4af1f59a7:01ce69442faf54e54474cd349cad2f7d:f9a0366e304d666e4262fa0af369d1f4$" + } +} diff --git a/public/images/pokemon/back/966-caph-starmobile.png b/public/images/pokemon/back/966-caph-starmobile.png new file mode 100644 index 00000000000..d1e67365454 Binary files /dev/null and b/public/images/pokemon/back/966-caph-starmobile.png differ diff --git a/public/images/pokemon/back/966-navi-starmobile.json b/public/images/pokemon/back/966-navi-starmobile.json new file mode 100644 index 00000000000..99059aa6edb --- /dev/null +++ b/public/images/pokemon/back/966-navi-starmobile.json @@ -0,0 +1,41 @@ +{ + "textures": [ + { + "image": "966-navi-starmobile.png", + "format": "RGBA8888", + "size": { + "w": 84, + "h": 84 + }, + "scale": 0.333, + "frames": [ + { + "filename": "0001.png", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 96, + "h": 96 + }, + "spriteSourceSize": { + "x": 6, + "y": 20, + "w": 84, + "h": 56 + }, + "frame": { + "x": 0, + "y": 0, + "w": 84, + "h": 56 + } + } + ] + } + ], + "meta": { + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0", + "smartupdate": "$TexturePacker:SmartUpdate:0226ae22b7a4822d78e38df4af1f59a7:01ce69442faf54e54474cd349cad2f7d:f9a0366e304d666e4262fa0af369d1f4$" + } +} diff --git a/public/images/pokemon/back/966-navi-starmobile.png b/public/images/pokemon/back/966-navi-starmobile.png new file mode 100644 index 00000000000..d1e67365454 Binary files /dev/null and b/public/images/pokemon/back/966-navi-starmobile.png differ diff --git a/public/images/pokemon/back/966-ruchbah-starmobile.json b/public/images/pokemon/back/966-ruchbah-starmobile.json new file mode 100644 index 00000000000..b3bb8463eac --- /dev/null +++ b/public/images/pokemon/back/966-ruchbah-starmobile.json @@ -0,0 +1,41 @@ +{ + "textures": [ + { + "image": "966-ruchbah-starmobile.png", + "format": "RGBA8888", + "size": { + "w": 84, + "h": 84 + }, + "scale": 0.333, + "frames": [ + { + "filename": "0001.png", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 96, + "h": 96 + }, + "spriteSourceSize": { + "x": 6, + "y": 20, + "w": 84, + "h": 56 + }, + "frame": { + "x": 0, + "y": 0, + "w": 84, + "h": 56 + } + } + ] + } + ], + "meta": { + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0", + "smartupdate": "$TexturePacker:SmartUpdate:0226ae22b7a4822d78e38df4af1f59a7:01ce69442faf54e54474cd349cad2f7d:f9a0366e304d666e4262fa0af369d1f4$" + } +} diff --git a/public/images/pokemon/back/966-ruchbah-starmobile.png b/public/images/pokemon/back/966-ruchbah-starmobile.png new file mode 100644 index 00000000000..d1e67365454 Binary files /dev/null and b/public/images/pokemon/back/966-ruchbah-starmobile.png differ diff --git a/public/images/pokemon/back/966-schedar-starmobile.json b/public/images/pokemon/back/966-schedar-starmobile.json new file mode 100644 index 00000000000..9832835b3ce --- /dev/null +++ b/public/images/pokemon/back/966-schedar-starmobile.json @@ -0,0 +1,41 @@ +{ + "textures": [ + { + "image": "966-schedar-starmobile.png", + "format": "RGBA8888", + "size": { + "w": 84, + "h": 84 + }, + "scale": 0.333, + "frames": [ + { + "filename": "0001.png", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 96, + "h": 96 + }, + "spriteSourceSize": { + "x": 6, + "y": 20, + "w": 84, + "h": 56 + }, + "frame": { + "x": 0, + "y": 0, + "w": 84, + "h": 56 + } + } + ] + } + ], + "meta": { + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0", + "smartupdate": "$TexturePacker:SmartUpdate:0226ae22b7a4822d78e38df4af1f59a7:01ce69442faf54e54474cd349cad2f7d:f9a0366e304d666e4262fa0af369d1f4$" + } +} diff --git a/public/images/pokemon/back/966-schedar-starmobile.png b/public/images/pokemon/back/966-schedar-starmobile.png new file mode 100644 index 00000000000..d1e67365454 Binary files /dev/null and b/public/images/pokemon/back/966-schedar-starmobile.png differ diff --git a/public/images/pokemon/back/966-segin-starmobile.json b/public/images/pokemon/back/966-segin-starmobile.json new file mode 100644 index 00000000000..75bd4d8f304 --- /dev/null +++ b/public/images/pokemon/back/966-segin-starmobile.json @@ -0,0 +1,41 @@ +{ + "textures": [ + { + "image": "966-segin-starmobile.png", + "format": "RGBA8888", + "size": { + "w": 84, + "h": 84 + }, + "scale": 0.333, + "frames": [ + { + "filename": "0001.png", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 96, + "h": 96 + }, + "spriteSourceSize": { + "x": 6, + "y": 20, + "w": 84, + "h": 56 + }, + "frame": { + "x": 0, + "y": 0, + "w": 84, + "h": 56 + } + } + ] + } + ], + "meta": { + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0", + "smartupdate": "$TexturePacker:SmartUpdate:0226ae22b7a4822d78e38df4af1f59a7:01ce69442faf54e54474cd349cad2f7d:f9a0366e304d666e4262fa0af369d1f4$" + } +} diff --git a/public/images/pokemon/back/966-segin-starmobile.png b/public/images/pokemon/back/966-segin-starmobile.png new file mode 100644 index 00000000000..d1e67365454 Binary files /dev/null and b/public/images/pokemon/back/966-segin-starmobile.png differ diff --git a/public/images/pokemon/back/female/198.png b/public/images/pokemon/back/female/198.png index 4f3f5d5c1a4..01489a05fb0 100644 Binary files a/public/images/pokemon/back/female/198.png and b/public/images/pokemon/back/female/198.png differ diff --git a/public/images/pokemon/back/female/25-beauty-cosplay.png b/public/images/pokemon/back/female/25-beauty-cosplay.png index b33e374aa6d..161cc301f7b 100644 Binary files a/public/images/pokemon/back/female/25-beauty-cosplay.png and b/public/images/pokemon/back/female/25-beauty-cosplay.png differ diff --git a/public/images/pokemon/back/female/25-cool-cosplay.png b/public/images/pokemon/back/female/25-cool-cosplay.png index e672040eaab..d10328785c8 100644 Binary files a/public/images/pokemon/back/female/25-cool-cosplay.png and b/public/images/pokemon/back/female/25-cool-cosplay.png differ diff --git a/public/images/pokemon/back/female/25-cosplay.png b/public/images/pokemon/back/female/25-cosplay.png index 2ebb0fe2285..644aec70f50 100644 Binary files a/public/images/pokemon/back/female/25-cosplay.png and b/public/images/pokemon/back/female/25-cosplay.png differ diff --git a/public/images/pokemon/back/female/25-cute-cosplay.png b/public/images/pokemon/back/female/25-cute-cosplay.png index 998a41f7396..552d816e142 100644 Binary files a/public/images/pokemon/back/female/25-cute-cosplay.png and b/public/images/pokemon/back/female/25-cute-cosplay.png differ diff --git a/public/images/pokemon/back/female/25-partner.png b/public/images/pokemon/back/female/25-partner.png index 97ceaa8bb2f..e65e58ec131 100644 Binary files a/public/images/pokemon/back/female/25-partner.png and b/public/images/pokemon/back/female/25-partner.png differ diff --git a/public/images/pokemon/back/female/25-smart-cosplay.png b/public/images/pokemon/back/female/25-smart-cosplay.png index 983f49e7024..c84c0b556aa 100644 Binary files a/public/images/pokemon/back/female/25-smart-cosplay.png and b/public/images/pokemon/back/female/25-smart-cosplay.png differ diff --git a/public/images/pokemon/back/female/25-tough-cosplay.png b/public/images/pokemon/back/female/25-tough-cosplay.png index a043231f172..73be0c8fb85 100644 Binary files a/public/images/pokemon/back/female/25-tough-cosplay.png and b/public/images/pokemon/back/female/25-tough-cosplay.png differ diff --git a/public/images/pokemon/back/female/25.png b/public/images/pokemon/back/female/25.png index 97ceaa8bb2f..e65e58ec131 100644 Binary files a/public/images/pokemon/back/female/25.png and b/public/images/pokemon/back/female/25.png differ diff --git a/public/images/pokemon/back/female/26.png b/public/images/pokemon/back/female/26.png index 40d39589660..2a6a3e41b2f 100644 Binary files a/public/images/pokemon/back/female/26.png and b/public/images/pokemon/back/female/26.png differ diff --git a/public/images/pokemon/back/shiny/280.png b/public/images/pokemon/back/shiny/280.png index c4ca1fe7dfb..17d519f6ea1 100644 Binary files a/public/images/pokemon/back/shiny/280.png and b/public/images/pokemon/back/shiny/280.png differ diff --git a/public/images/pokemon/back/shiny/281.png b/public/images/pokemon/back/shiny/281.png index 4b8a3c9d27e..642b9bb27bd 100644 Binary files a/public/images/pokemon/back/shiny/281.png and b/public/images/pokemon/back/shiny/281.png differ diff --git a/public/images/pokemon/back/shiny/282.png b/public/images/pokemon/back/shiny/282.png index 61b8e084fed..cc8370730c0 100644 Binary files a/public/images/pokemon/back/shiny/282.png and b/public/images/pokemon/back/shiny/282.png differ diff --git a/public/images/pokemon/back/shiny/378.png b/public/images/pokemon/back/shiny/378.png index ecaa26564c3..7bb24f1edfe 100644 Binary files a/public/images/pokemon/back/shiny/378.png and b/public/images/pokemon/back/shiny/378.png differ diff --git a/public/images/pokemon/back/shiny/4144.png b/public/images/pokemon/back/shiny/4144.png index eed3e0e0718..0554889b35d 100644 Binary files a/public/images/pokemon/back/shiny/4144.png and b/public/images/pokemon/back/shiny/4144.png differ diff --git a/public/images/pokemon/back/shiny/4145.png b/public/images/pokemon/back/shiny/4145.png index 1127ab8a3be..6d970b27913 100644 Binary files a/public/images/pokemon/back/shiny/4145.png and b/public/images/pokemon/back/shiny/4145.png differ diff --git a/public/images/pokemon/back/shiny/4146.png b/public/images/pokemon/back/shiny/4146.png index 599b3573951..04db4c69673 100644 Binary files a/public/images/pokemon/back/shiny/4146.png and b/public/images/pokemon/back/shiny/4146.png differ diff --git a/public/images/pokemon/back/shiny/436.json b/public/images/pokemon/back/shiny/436.json index 4091e1a2e49..3342cc6577c 100644 --- a/public/images/pokemon/back/shiny/436.json +++ b/public/images/pokemon/back/shiny/436.json @@ -1,2666 +1,1019 @@ -{ - "textures": [ - { - "image": "436.png", - "format": "RGBA8888", - "size": { - "w": 100, - "h": 100 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 5, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 5, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 5, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 5, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 9, - "y": 9, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 9, - "y": 9, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 5, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 5, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 4, - "y": 8, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 4, - "y": 8, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 5, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 5, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 9, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 9, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 10, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 10, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 11, - "y": 8, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 11, - "y": 8, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 9, - "y": 6, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 9, - "y": 6, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 5, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 5, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 5, - "y": 6, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 5, - "y": 6, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 8, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 8, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 4, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 4, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 5, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 5, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 10, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 10, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 11, - "y": 9, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 11, - "y": 9, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 13, - "y": 6, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 13, - "y": 6, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 10, - "y": 3, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 10, - "y": 3, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 2, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 2, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 4, - "y": 3, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 4, - "y": 3, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 6, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 6, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 9, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 9, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 4, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 4, - "y": 11, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 11, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 11, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 13, - "y": 8, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 13, - "y": 8, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 11, - "y": 0, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 11, - "y": 0, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 4, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 4, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 14, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 14, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 4, - "y": 17, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 4, - "y": 17, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 8, - "y": 18, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 8, - "y": 18, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 15, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 15, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 6, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 6, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 9, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 9, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 6, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 6, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 8, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 8, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 10, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 34, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 34, - "h": 40 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 15, - "y": 4, - "w": 33, - "h": 40 - }, - "frame": { - "x": 34, - "y": 0, - "w": 33, - "h": 40 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 15, - "y": 4, - "w": 33, - "h": 40 - }, - "frame": { - "x": 34, - "y": 0, - "w": 33, - "h": 40 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 33, - "h": 40 - }, - "frame": { - "x": 67, - "y": 0, - "w": 33, - "h": 40 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 33, - "h": 40 - }, - "frame": { - "x": 67, - "y": 0, - "w": 33, - "h": 40 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 0, - "w": 34, - "h": 39 - }, - "frame": { - "x": 0, - "y": 40, - "w": 34, - "h": 39 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 7, - "y": 0, - "w": 34, - "h": 39 - }, - "frame": { - "x": 0, - "y": 40, - "w": 34, - "h": 39 - } - }, - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 9, - "y": 21, - "w": 34, - "h": 39 - }, - "frame": { - "x": 34, - "y": 40, - "w": 34, - "h": 39 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 48, - "h": 60 - }, - "spriteSourceSize": { - "x": 9, - "y": 21, - "w": 34, - "h": 39 - }, - "frame": { - "x": 34, - "y": 40, - "w": 34, - "h": 39 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:810e866f20256a6beca964ab2fe2f997:4d42b12e9664d852f2391c8b56845681:0a3bacf3d680738b160c4c8ace3cda59$" - } -} +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0002.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0003.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0004.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0005.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0006.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0007.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0008.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0009.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0010.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0011.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0012.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0013.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0014.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0015.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0016.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0017.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0018.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0019.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0020.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0021.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0022.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0023.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0024.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0025.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0026.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0027.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0028.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0029.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0030.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0031.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0032.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0033.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0034.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0035.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0036.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0037.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 10, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0038.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 10, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0039.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0040.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0041.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0042.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0043.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0044.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0045.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 9, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0046.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 9, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0047.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0048.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0049.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0050.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0051.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0052.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0053.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 11, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0054.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 11, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0055.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 9, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0056.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 9, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0057.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 7, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0058.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 7, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0059.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 6, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0060.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 6, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0061.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 7, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0062.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 7, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0063.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 9, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0064.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 9, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0065.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0066.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0067.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0068.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0069.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0070.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0071.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 11, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0072.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 11, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0073.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 10, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0074.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 10, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0075.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 14, "y": 7, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0076.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 14, "y": 7, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0077.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 11, "y": 4, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0078.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 11, "y": 4, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0079.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 3, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0080.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 3, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0081.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 4, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0082.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 4, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0083.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 2, "y": 7, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0084.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 2, "y": 7, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0085.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 10, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0086.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 10, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0087.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0088.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 12, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0089.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0090.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0091.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0092.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0093.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 14, "y": 9, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0094.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 14, "y": 9, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0095.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 16, "y": 5, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0096.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 16, "y": 5, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0097.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 1, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0098.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 1, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0099.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 0, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0100.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 0, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0101.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 5, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0102.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 5, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0103.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 0, "y": 10, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0104.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 0, "y": 10, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0105.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 2, "y": 15, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0106.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 2, "y": 15, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0107.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 18, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0108.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 18, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0109.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 22, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0110.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 22, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0111.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 19, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0112.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 19, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0113.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 16, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0114.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 16, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0115.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0116.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0117.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 10, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0118.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 10, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0119.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 7, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0120.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 7, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0121.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 9, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0122.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 9, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0123.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0124.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 11, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0125.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + }, + { + "filename": "0126.png", + "frame": { "x": 0, "y": 0, "w": 32, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 32, "h": 38 }, + "sourceSize": { "w": 48, "h": 60 } + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.7-dev", + "image": "436.png", + "format": "I8", + "size": { "w": 32, "h": 38 }, + "scale": "1" + } +} diff --git a/public/images/pokemon/back/shiny/436.png b/public/images/pokemon/back/shiny/436.png index b3d6dc4df61..d766a912555 100644 Binary files a/public/images/pokemon/back/shiny/436.png and b/public/images/pokemon/back/shiny/436.png differ diff --git a/public/images/pokemon/back/shiny/451.json b/public/images/pokemon/back/shiny/451.json index 235500ead7e..dc8ad642286 100644 --- a/public/images/pokemon/back/shiny/451.json +++ b/public/images/pokemon/back/shiny/451.json @@ -1,2330 +1,715 @@ -{ - "textures": [ - { - "image": "451.png", - "format": "RGBA8888", - "size": { - "w": 284, - "h": 284 - }, - "scale": 1, - "frames": [ - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 68, - "h": 36 - }, - "frame": { - "x": 0, - "y": 0, - "w": 68, - "h": 36 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 68, - "h": 36 - }, - "frame": { - "x": 0, - "y": 0, - "w": 68, - "h": 36 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 68, - "h": 36 - }, - "frame": { - "x": 0, - "y": 0, - "w": 68, - "h": 36 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 68, - "h": 36 - }, - "frame": { - "x": 0, - "y": 0, - "w": 68, - "h": 36 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 68, - "h": 37 - }, - "frame": { - "x": 68, - "y": 0, - "w": 68, - "h": 37 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 68, - "h": 37 - }, - "frame": { - "x": 68, - "y": 0, - "w": 68, - "h": 37 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 68, - "h": 37 - }, - "frame": { - "x": 68, - "y": 0, - "w": 68, - "h": 37 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 68, - "h": 37 - }, - "frame": { - "x": 68, - "y": 0, - "w": 68, - "h": 37 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 1, - "y": 7, - "w": 67, - "h": 38 - }, - "frame": { - "x": 136, - "y": 0, - "w": 67, - "h": 38 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 1, - "y": 7, - "w": 67, - "h": 38 - }, - "frame": { - "x": 136, - "y": 0, - "w": 67, - "h": 38 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 1, - "y": 7, - "w": 67, - "h": 38 - }, - "frame": { - "x": 136, - "y": 0, - "w": 67, - "h": 38 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 1, - "y": 7, - "w": 67, - "h": 38 - }, - "frame": { - "x": 136, - "y": 0, - "w": 67, - "h": 38 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 1, - "y": 7, - "w": 67, - "h": 38 - }, - "frame": { - "x": 203, - "y": 0, - "w": 67, - "h": 38 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 1, - "y": 7, - "w": 67, - "h": 38 - }, - "frame": { - "x": 203, - "y": 0, - "w": 67, - "h": 38 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 1, - "y": 7, - "w": 67, - "h": 38 - }, - "frame": { - "x": 203, - "y": 0, - "w": 67, - "h": 38 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 1, - "y": 7, - "w": 67, - "h": 38 - }, - "frame": { - "x": 203, - "y": 0, - "w": 67, - "h": 38 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 2, - "y": 6, - "w": 66, - "h": 39 - }, - "frame": { - "x": 0, - "y": 36, - "w": 66, - "h": 39 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 2, - "y": 6, - "w": 66, - "h": 39 - }, - "frame": { - "x": 0, - "y": 36, - "w": 66, - "h": 39 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 2, - "y": 6, - "w": 66, - "h": 39 - }, - "frame": { - "x": 0, - "y": 36, - "w": 66, - "h": 39 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 2, - "y": 6, - "w": 66, - "h": 39 - }, - "frame": { - "x": 0, - "y": 36, - "w": 66, - "h": 39 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 2, - "y": 6, - "w": 66, - "h": 39 - }, - "frame": { - "x": 0, - "y": 36, - "w": 66, - "h": 39 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 2, - "y": 6, - "w": 66, - "h": 39 - }, - "frame": { - "x": 0, - "y": 36, - "w": 66, - "h": 39 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 2, - "y": 6, - "w": 66, - "h": 39 - }, - "frame": { - "x": 0, - "y": 36, - "w": 66, - "h": 39 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 2, - "y": 6, - "w": 66, - "h": 39 - }, - "frame": { - "x": 0, - "y": 36, - "w": 66, - "h": 39 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 3, - "y": 5, - "w": 64, - "h": 40 - }, - "frame": { - "x": 66, - "y": 37, - "w": 64, - "h": 40 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 3, - "y": 5, - "w": 64, - "h": 40 - }, - "frame": { - "x": 66, - "y": 37, - "w": 64, - "h": 40 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 3, - "y": 5, - "w": 64, - "h": 40 - }, - "frame": { - "x": 66, - "y": 37, - "w": 64, - "h": 40 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 3, - "y": 5, - "w": 64, - "h": 40 - }, - "frame": { - "x": 66, - "y": 37, - "w": 64, - "h": 40 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 3, - "y": 5, - "w": 65, - "h": 40 - }, - "frame": { - "x": 130, - "y": 38, - "w": 65, - "h": 40 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 3, - "y": 5, - "w": 65, - "h": 40 - }, - "frame": { - "x": 130, - "y": 38, - "w": 65, - "h": 40 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 3, - "y": 5, - "w": 65, - "h": 40 - }, - "frame": { - "x": 130, - "y": 38, - "w": 65, - "h": 40 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 3, - "y": 5, - "w": 65, - "h": 40 - }, - "frame": { - "x": 130, - "y": 38, - "w": 65, - "h": 40 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 4, - "y": 4, - "w": 63, - "h": 41 - }, - "frame": { - "x": 195, - "y": 38, - "w": 63, - "h": 41 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 4, - "y": 4, - "w": 63, - "h": 41 - }, - "frame": { - "x": 195, - "y": 38, - "w": 63, - "h": 41 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 4, - "y": 4, - "w": 63, - "h": 41 - }, - "frame": { - "x": 195, - "y": 38, - "w": 63, - "h": 41 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 4, - "y": 4, - "w": 63, - "h": 41 - }, - "frame": { - "x": 195, - "y": 38, - "w": 63, - "h": 41 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 4, - "y": 4, - "w": 63, - "h": 41 - }, - "frame": { - "x": 195, - "y": 38, - "w": 63, - "h": 41 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 4, - "y": 4, - "w": 63, - "h": 41 - }, - "frame": { - "x": 195, - "y": 38, - "w": 63, - "h": 41 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 4, - "y": 4, - "w": 63, - "h": 41 - }, - "frame": { - "x": 195, - "y": 38, - "w": 63, - "h": 41 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 4, - "y": 4, - "w": 63, - "h": 41 - }, - "frame": { - "x": 195, - "y": 38, - "w": 63, - "h": 41 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 5, - "y": 3, - "w": 61, - "h": 42 - }, - "frame": { - "x": 0, - "y": 75, - "w": 61, - "h": 42 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 5, - "y": 3, - "w": 61, - "h": 42 - }, - "frame": { - "x": 0, - "y": 75, - "w": 61, - "h": 42 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 5, - "y": 3, - "w": 61, - "h": 42 - }, - "frame": { - "x": 0, - "y": 75, - "w": 61, - "h": 42 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 5, - "y": 3, - "w": 61, - "h": 42 - }, - "frame": { - "x": 0, - "y": 75, - "w": 61, - "h": 42 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 5, - "y": 3, - "w": 63, - "h": 42 - }, - "frame": { - "x": 61, - "y": 77, - "w": 63, - "h": 42 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 5, - "y": 3, - "w": 63, - "h": 42 - }, - "frame": { - "x": 61, - "y": 77, - "w": 63, - "h": 42 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 5, - "y": 3, - "w": 63, - "h": 42 - }, - "frame": { - "x": 61, - "y": 77, - "w": 63, - "h": 42 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 5, - "y": 3, - "w": 63, - "h": 42 - }, - "frame": { - "x": 61, - "y": 77, - "w": 63, - "h": 42 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 61, - "h": 43 - }, - "frame": { - "x": 124, - "y": 78, - "w": 61, - "h": 43 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 61, - "h": 43 - }, - "frame": { - "x": 124, - "y": 78, - "w": 61, - "h": 43 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 61, - "h": 43 - }, - "frame": { - "x": 124, - "y": 78, - "w": 61, - "h": 43 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 61, - "h": 43 - }, - "frame": { - "x": 124, - "y": 78, - "w": 61, - "h": 43 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 61, - "h": 43 - }, - "frame": { - "x": 124, - "y": 78, - "w": 61, - "h": 43 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 61, - "h": 43 - }, - "frame": { - "x": 124, - "y": 78, - "w": 61, - "h": 43 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 61, - "h": 43 - }, - "frame": { - "x": 124, - "y": 78, - "w": 61, - "h": 43 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 61, - "h": 43 - }, - "frame": { - "x": 124, - "y": 78, - "w": 61, - "h": 43 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 1, - "w": 58, - "h": 44 - }, - "frame": { - "x": 185, - "y": 79, - "w": 58, - "h": 44 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 1, - "w": 58, - "h": 44 - }, - "frame": { - "x": 185, - "y": 79, - "w": 58, - "h": 44 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 1, - "w": 58, - "h": 44 - }, - "frame": { - "x": 185, - "y": 79, - "w": 58, - "h": 44 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 1, - "w": 58, - "h": 44 - }, - "frame": { - "x": 185, - "y": 79, - "w": 58, - "h": 44 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 1, - "w": 61, - "h": 44 - }, - "frame": { - "x": 0, - "y": 117, - "w": 61, - "h": 44 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 1, - "w": 61, - "h": 44 - }, - "frame": { - "x": 0, - "y": 117, - "w": 61, - "h": 44 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 1, - "w": 61, - "h": 44 - }, - "frame": { - "x": 0, - "y": 117, - "w": 61, - "h": 44 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 1, - "w": 61, - "h": 44 - }, - "frame": { - "x": 0, - "y": 117, - "w": 61, - "h": 44 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 17, - "y": 1, - "w": 53, - "h": 44 - }, - "frame": { - "x": 61, - "y": 119, - "w": 53, - "h": 44 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 17, - "y": 1, - "w": 53, - "h": 44 - }, - "frame": { - "x": 61, - "y": 119, - "w": 53, - "h": 44 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 56, - "h": 45 - }, - "frame": { - "x": 114, - "y": 121, - "w": 56, - "h": 45 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 56, - "h": 45 - }, - "frame": { - "x": 114, - "y": 121, - "w": 56, - "h": 45 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 56, - "h": 45 - }, - "frame": { - "x": 114, - "y": 121, - "w": 56, - "h": 45 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 56, - "h": 45 - }, - "frame": { - "x": 114, - "y": 121, - "w": 56, - "h": 45 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 56, - "h": 45 - }, - "frame": { - "x": 114, - "y": 121, - "w": 56, - "h": 45 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 56, - "h": 45 - }, - "frame": { - "x": 114, - "y": 121, - "w": 56, - "h": 45 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 56, - "h": 45 - }, - "frame": { - "x": 114, - "y": 121, - "w": 56, - "h": 45 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 56, - "h": 45 - }, - "frame": { - "x": 114, - "y": 121, - "w": 56, - "h": 45 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 56, - "h": 45 - }, - "frame": { - "x": 114, - "y": 121, - "w": 56, - "h": 45 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 56, - "h": 45 - }, - "frame": { - "x": 114, - "y": 121, - "w": 56, - "h": 45 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 56, - "h": 45 - }, - "frame": { - "x": 114, - "y": 121, - "w": 56, - "h": 45 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 56, - "h": 45 - }, - "frame": { - "x": 114, - "y": 121, - "w": 56, - "h": 45 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 0, - "w": 58, - "h": 45 - }, - "frame": { - "x": 170, - "y": 123, - "w": 58, - "h": 45 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 0, - "w": 58, - "h": 45 - }, - "frame": { - "x": 170, - "y": 123, - "w": 58, - "h": 45 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 0, - "w": 58, - "h": 45 - }, - "frame": { - "x": 170, - "y": 123, - "w": 58, - "h": 45 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 0, - "w": 58, - "h": 45 - }, - "frame": { - "x": 170, - "y": 123, - "w": 58, - "h": 45 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 0, - "w": 58, - "h": 45 - }, - "frame": { - "x": 170, - "y": 123, - "w": 58, - "h": 45 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 0, - "w": 58, - "h": 45 - }, - "frame": { - "x": 170, - "y": 123, - "w": 58, - "h": 45 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 0, - "w": 58, - "h": 45 - }, - "frame": { - "x": 170, - "y": 123, - "w": 58, - "h": 45 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 0, - "w": 58, - "h": 45 - }, - "frame": { - "x": 170, - "y": 123, - "w": 58, - "h": 45 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 14, - "y": 0, - "w": 56, - "h": 45 - }, - "frame": { - "x": 228, - "y": 123, - "w": 56, - "h": 45 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 14, - "y": 0, - "w": 56, - "h": 45 - }, - "frame": { - "x": 228, - "y": 123, - "w": 56, - "h": 45 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 60, - "h": 45 - }, - "frame": { - "x": 0, - "y": 161, - "w": 60, - "h": 45 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 60, - "h": 45 - }, - "frame": { - "x": 0, - "y": 161, - "w": 60, - "h": 45 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 60, - "h": 45 - }, - "frame": { - "x": 0, - "y": 161, - "w": 60, - "h": 45 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 60, - "h": 45 - }, - "frame": { - "x": 0, - "y": 161, - "w": 60, - "h": 45 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 16, - "y": 0, - "w": 54, - "h": 45 - }, - "frame": { - "x": 60, - "y": 163, - "w": 54, - "h": 45 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 16, - "y": 0, - "w": 54, - "h": 45 - }, - "frame": { - "x": 60, - "y": 163, - "w": 54, - "h": 45 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 16, - "y": 0, - "w": 54, - "h": 45 - }, - "frame": { - "x": 114, - "y": 166, - "w": 54, - "h": 45 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 16, - "y": 0, - "w": 54, - "h": 45 - }, - "frame": { - "x": 114, - "y": 166, - "w": 54, - "h": 45 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 9, - "y": 0, - "w": 60, - "h": 45 - }, - "frame": { - "x": 168, - "y": 168, - "w": 60, - "h": 45 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 9, - "y": 0, - "w": 60, - "h": 45 - }, - "frame": { - "x": 168, - "y": 168, - "w": 60, - "h": 45 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 14, - "y": 0, - "w": 55, - "h": 45 - }, - "frame": { - "x": 228, - "y": 168, - "w": 55, - "h": 45 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 14, - "y": 0, - "w": 55, - "h": 45 - }, - "frame": { - "x": 228, - "y": 168, - "w": 55, - "h": 45 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 11, - "y": 0, - "w": 58, - "h": 45 - }, - "frame": { - "x": 0, - "y": 206, - "w": 58, - "h": 45 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 11, - "y": 0, - "w": 58, - "h": 45 - }, - "frame": { - "x": 0, - "y": 206, - "w": 58, - "h": 45 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 13, - "y": 0, - "w": 54, - "h": 45 - }, - "frame": { - "x": 58, - "y": 208, - "w": 54, - "h": 45 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 13, - "y": 0, - "w": 54, - "h": 45 - }, - "frame": { - "x": 58, - "y": 208, - "w": 54, - "h": 45 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 11, - "y": 0, - "w": 55, - "h": 45 - }, - "frame": { - "x": 112, - "y": 211, - "w": 55, - "h": 45 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 11, - "y": 0, - "w": 55, - "h": 45 - }, - "frame": { - "x": 112, - "y": 211, - "w": 55, - "h": 45 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 13, - "y": 0, - "w": 57, - "h": 45 - }, - "frame": { - "x": 167, - "y": 213, - "w": 57, - "h": 45 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 13, - "y": 0, - "w": 57, - "h": 45 - }, - "frame": { - "x": 167, - "y": 213, - "w": 57, - "h": 45 - } - }, - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 9, - "y": 0, - "w": 56, - "h": 45 - }, - "frame": { - "x": 224, - "y": 213, - "w": 56, - "h": 45 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 70, - "h": 45 - }, - "spriteSourceSize": { - "x": 9, - "y": 0, - "w": 56, - "h": 45 - }, - "frame": { - "x": 224, - "y": 213, - "w": 56, - "h": 45 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:264d5fe9bb10d16b3ee529403984b747:1057050202e425b393bddf58040a14ea:c79e17c206de27e3b7f1ce96f7df8e51$" - } +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 348, "y": 79, "w": 54, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 0, "w": 54, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0002.png", + "frame": { "x": 348, "y": 79, "w": 54, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 0, "w": 54, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0003.png", + "frame": { "x": 231, "y": 40, "w": 56, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 1, "w": 56, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0004.png", + "frame": { "x": 231, "y": 40, "w": 56, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 1, "w": 56, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0005.png", + "frame": { "x": 292, "y": 38, "w": 59, "h": 41 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 3, "w": 59, "h": 41 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0006.png", + "frame": { "x": 292, "y": 38, "w": 59, "h": 41 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 3, "w": 59, "h": 41 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0007.png", + "frame": { "x": 287, "y": 79, "w": 61, "h": 39 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 5, "w": 61, "h": 39 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0008.png", + "frame": { "x": 287, "y": 79, "w": 61, "h": 39 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 5, "w": 61, "h": 39 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0009.png", + "frame": { "x": 292, "y": 0, "w": 64, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 3, "y": 7, "w": 64, "h": 38 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0010.png", + "frame": { "x": 292, "y": 0, "w": 64, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 3, "y": 7, "w": 64, "h": 38 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0011.png", + "frame": { "x": 0, "y": 81, "w": 66, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 1, "y": 9, "w": 66, "h": 36 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0012.png", + "frame": { "x": 0, "y": 81, "w": 66, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 1, "y": 9, "w": 66, "h": 36 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0013.png", + "frame": { "x": 292, "y": 0, "w": 64, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 3, "y": 7, "w": 64, "h": 38 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0014.png", + "frame": { "x": 292, "y": 0, "w": 64, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 3, "y": 7, "w": 64, "h": 38 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0015.png", + "frame": { "x": 287, "y": 79, "w": 61, "h": 39 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 5, "w": 61, "h": 39 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0016.png", + "frame": { "x": 287, "y": 79, "w": 61, "h": 39 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 5, "w": 61, "h": 39 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0017.png", + "frame": { "x": 292, "y": 38, "w": 59, "h": 41 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 3, "w": 59, "h": 41 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0018.png", + "frame": { "x": 292, "y": 38, "w": 59, "h": 41 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 3, "w": 59, "h": 41 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0019.png", + "frame": { "x": 231, "y": 40, "w": 56, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 1, "w": 56, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0020.png", + "frame": { "x": 231, "y": 40, "w": 56, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 1, "w": 56, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0021.png", + "frame": { "x": 348, "y": 79, "w": 54, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 0, "w": 54, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0022.png", + "frame": { "x": 348, "y": 79, "w": 54, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 0, "w": 54, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0023.png", + "frame": { "x": 348, "y": 79, "w": 54, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 0, "w": 54, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0024.png", + "frame": { "x": 348, "y": 79, "w": 54, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 0, "w": 54, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0025.png", + "frame": { "x": 231, "y": 40, "w": 56, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 1, "w": 56, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0026.png", + "frame": { "x": 231, "y": 40, "w": 56, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 1, "w": 56, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0027.png", + "frame": { "x": 292, "y": 38, "w": 59, "h": 41 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 3, "w": 59, "h": 41 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0028.png", + "frame": { "x": 292, "y": 38, "w": 59, "h": 41 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 3, "w": 59, "h": 41 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0029.png", + "frame": { "x": 287, "y": 79, "w": 61, "h": 39 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 5, "w": 61, "h": 39 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0030.png", + "frame": { "x": 287, "y": 79, "w": 61, "h": 39 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 5, "w": 61, "h": 39 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0031.png", + "frame": { "x": 292, "y": 0, "w": 64, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 3, "y": 7, "w": 64, "h": 38 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0032.png", + "frame": { "x": 292, "y": 0, "w": 64, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 3, "y": 7, "w": 64, "h": 38 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0033.png", + "frame": { "x": 0, "y": 81, "w": 66, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 1, "y": 9, "w": 66, "h": 36 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0034.png", + "frame": { "x": 0, "y": 81, "w": 66, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 1, "y": 9, "w": 66, "h": 36 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0035.png", + "frame": { "x": 292, "y": 0, "w": 64, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 3, "y": 7, "w": 64, "h": 38 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0036.png", + "frame": { "x": 292, "y": 0, "w": 64, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 3, "y": 7, "w": 64, "h": 38 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0037.png", + "frame": { "x": 287, "y": 79, "w": 61, "h": 39 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 5, "w": 61, "h": 39 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0038.png", + "frame": { "x": 287, "y": 79, "w": 61, "h": 39 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 5, "w": 61, "h": 39 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0039.png", + "frame": { "x": 292, "y": 38, "w": 59, "h": 41 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 3, "w": 59, "h": 41 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0040.png", + "frame": { "x": 292, "y": 38, "w": 59, "h": 41 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 3, "w": 59, "h": 41 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0041.png", + "frame": { "x": 231, "y": 40, "w": 56, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 1, "w": 56, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0042.png", + "frame": { "x": 231, "y": 40, "w": 56, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 1, "w": 56, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0043.png", + "frame": { "x": 348, "y": 79, "w": 54, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 0, "w": 54, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0044.png", + "frame": { "x": 348, "y": 79, "w": 54, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 0, "w": 54, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0045.png", + "frame": { "x": 348, "y": 79, "w": 54, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 0, "w": 54, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0046.png", + "frame": { "x": 348, "y": 79, "w": 54, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 0, "w": 54, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0047.png", + "frame": { "x": 234, "y": 118, "w": 56, "h": 42 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 2, "w": 56, "h": 42 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0048.png", + "frame": { "x": 234, "y": 118, "w": 56, "h": 42 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 2, "w": 56, "h": 42 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0049.png", + "frame": { "x": 175, "y": 83, "w": 59, "h": 40 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 4, "w": 59, "h": 40 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0050.png", + "frame": { "x": 175, "y": 83, "w": 59, "h": 40 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 4, "w": 59, "h": 40 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0051.png", + "frame": { "x": 0, "y": 117, "w": 62, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 6, "w": 62, "h": 38 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0052.png", + "frame": { "x": 0, "y": 117, "w": 62, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 6, "w": 62, "h": 38 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0053.png", + "frame": { "x": 0, "y": 44, "w": 65, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 2, "y": 8, "w": 65, "h": 37 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0054.png", + "frame": { "x": 0, "y": 44, "w": 65, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 2, "y": 8, "w": 65, "h": 37 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0055.png", + "frame": { "x": 290, "y": 123, "w": 67, "h": 35 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 0, "y": 10, "w": 67, "h": 35 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0056.png", + "frame": { "x": 290, "y": 123, "w": 67, "h": 35 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 0, "y": 10, "w": 67, "h": 35 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0057.png", + "frame": { "x": 65, "y": 44, "w": 65, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 2, "y": 8, "w": 65, "h": 37 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0058.png", + "frame": { "x": 65, "y": 44, "w": 65, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 2, "y": 8, "w": 65, "h": 37 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0059.png", + "frame": { "x": 130, "y": 44, "w": 63, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 6, "w": 63, "h": 38 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0060.png", + "frame": { "x": 130, "y": 44, "w": 63, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 6, "w": 63, "h": 38 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0061.png", + "frame": { "x": 231, "y": 0, "w": 61, "h": 40 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 4, "w": 61, "h": 40 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0062.png", + "frame": { "x": 231, "y": 0, "w": 61, "h": 40 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 4, "w": 61, "h": 40 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0063.png", + "frame": { "x": 116, "y": 0, "w": 59, "h": 42 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 2, "w": 59, "h": 42 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0064.png", + "frame": { "x": 116, "y": 0, "w": 59, "h": 42 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 2, "w": 59, "h": 42 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0065.png", + "frame": { "x": 0, "y": 0, "w": 58, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 0, "w": 58, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0066.png", + "frame": { "x": 0, "y": 0, "w": 58, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 0, "w": 58, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0067.png", + "frame": { "x": 58, "y": 0, "w": 58, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 0, "w": 58, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0068.png", + "frame": { "x": 58, "y": 0, "w": 58, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 0, "w": 58, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0069.png", + "frame": { "x": 175, "y": 0, "w": 56, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 0, "w": 56, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0070.png", + "frame": { "x": 175, "y": 0, "w": 56, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 0, "w": 56, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0071.png", + "frame": { "x": 120, "y": 82, "w": 55, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 14, "y": 1, "w": 55, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0072.png", + "frame": { "x": 120, "y": 82, "w": 55, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 14, "y": 1, "w": 55, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0073.png", + "frame": { "x": 62, "y": 125, "w": 54, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 15, "y": 1, "w": 54, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0074.png", + "frame": { "x": 62, "y": 125, "w": 54, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 15, "y": 1, "w": 54, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0075.png", + "frame": { "x": 0, "y": 155, "w": 52, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 17, "y": 1, "w": 52, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0076.png", + "frame": { "x": 0, "y": 155, "w": 52, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 17, "y": 1, "w": 52, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0077.png", + "frame": { "x": 228, "y": 160, "w": 52, "h": 42 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 18, "y": 2, "w": 52, "h": 42 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0078.png", + "frame": { "x": 228, "y": 160, "w": 52, "h": 42 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 18, "y": 2, "w": 52, "h": 42 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0079.png", + "frame": { "x": 290, "y": 158, "w": 52, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 17, "y": 1, "w": 52, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0080.png", + "frame": { "x": 290, "y": 158, "w": 52, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 17, "y": 1, "w": 52, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0081.png", + "frame": { "x": 116, "y": 125, "w": 53, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 15, "y": 1, "w": 53, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0082.png", + "frame": { "x": 116, "y": 125, "w": 53, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 15, "y": 1, "w": 53, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0083.png", + "frame": { "x": 342, "y": 158, "w": 52, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 14, "y": 1, "w": 52, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0084.png", + "frame": { "x": 342, "y": 158, "w": 52, "h": 43 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 14, "y": 1, "w": 52, "h": 43 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0085.png", + "frame": { "x": 175, "y": 123, "w": 53, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 0, "w": 53, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0086.png", + "frame": { "x": 175, "y": 123, "w": 53, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 0, "w": 53, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0087.png", + "frame": { "x": 66, "y": 81, "w": 54, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 0, "w": 54, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + }, + { + "filename": "0088.png", + "frame": { "x": 66, "y": 81, "w": 54, "h": 44 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 0, "w": 54, "h": 44 }, + "sourceSize": { "w": 70, "h": 45 } + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.8.1-x64", + "image": "451.png", + "format": "I8", + "size": { "w": 402, "h": 202 }, + "scale": "1" + } } diff --git a/public/images/pokemon/back/shiny/451.png b/public/images/pokemon/back/shiny/451.png index 1518445bc79..dcc3a1a023a 100644 Binary files a/public/images/pokemon/back/shiny/451.png and b/public/images/pokemon/back/shiny/451.png differ diff --git a/public/images/pokemon/back/shiny/493-fairy.json b/public/images/pokemon/back/shiny/493-fairy.json index 1fe61e9d586..d49b40c8937 100644 --- a/public/images/pokemon/back/shiny/493-fairy.json +++ b/public/images/pokemon/back/shiny/493-fairy.json @@ -4,29 +4,3389 @@ "image": "493-fairy.png", "format": "RGBA8888", "size": { - "w": 76, - "h": 76 + "w": 391, + "h": 391 }, "scale": 1, "frames": [ { - "filename": "0001.png", + "filename": "0110.png", "rotated": false, "trimmed": false, "sourceSize": { - "w": 66, - "h": 76 + "w": 72, + "h": 86 }, "spriteSourceSize": { "x": 0, "y": 0, - "w": 66, - "h": 76 + "w": 72, + "h": 86 }, "frame": { "x": 0, "y": 0, + "w": 72, + "h": 86 + } + }, + { + "filename": "0111.png", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 72, + "h": 86 + }, + "frame": { + "x": 0, + "y": 0, + "w": 72, + "h": 86 + } + }, + { + "filename": "0108.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 71, + "h": 86 + }, + "frame": { + "x": 0, + "y": 86, + "w": 71, + "h": 86 + } + }, + { + "filename": "0109.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 71, + "h": 86 + }, + "frame": { + "x": 0, + "y": 86, + "w": 71, + "h": 86 + } + }, + { + "filename": "0112.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 71, + "h": 86 + }, + "frame": { + "x": 0, + "y": 172, + "w": 71, + "h": 86 + } + }, + { + "filename": "0113.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 71, + "h": 86 + }, + "frame": { + "x": 0, + "y": 172, + "w": 71, + "h": 86 + } + }, + { + "filename": "0106.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 69, + "h": 86 + }, + "frame": { + "x": 0, + "y": 258, + "w": 69, + "h": 86 + } + }, + { + "filename": "0107.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 69, + "h": 86 + }, + "frame": { + "x": 0, + "y": 258, + "w": 69, + "h": 86 + } + }, + { + "filename": "0114.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 3, + "w": 71, + "h": 83 + }, + "frame": { + "x": 69, + "y": 258, + "w": 71, + "h": 83 + } + }, + { + "filename": "0115.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 3, + "w": 71, + "h": 83 + }, + "frame": { + "x": 69, + "y": 258, + "w": 71, + "h": 83 + } + }, + { + "filename": "0104.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 67, + "h": 86 + }, + "frame": { + "x": 71, + "y": 86, + "w": 67, + "h": 86 + } + }, + { + "filename": "0105.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 67, + "h": 86 + }, + "frame": { + "x": 71, + "y": 86, + "w": 67, + "h": 86 + } + }, + { + "filename": "0100.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 4, + "w": 68, + "h": 82 + }, + "frame": { + "x": 72, + "y": 0, + "w": 68, + "h": 82 + } + }, + { + "filename": "0101.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 4, + "w": 68, + "h": 82 + }, + "frame": { + "x": 72, + "y": 0, + "w": 68, + "h": 82 + } + }, + { + "filename": "0102.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 3, + "w": 67, + "h": 83 + }, + "frame": { + "x": 71, + "y": 172, + "w": 67, + "h": 83 + } + }, + { + "filename": "0103.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 3, + "w": 67, + "h": 83 + }, + "frame": { + "x": 71, + "y": 172, + "w": 67, + "h": 83 + } + }, + { + "filename": "0004.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 138, + "y": 82, + "w": 70, + "h": 78 + } + }, + { + "filename": "0005.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 138, + "y": 82, + "w": 70, + "h": 78 + } + }, + { + "filename": "0028.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 138, + "y": 82, + "w": 70, + "h": 78 + } + }, + { + "filename": "0029.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 138, + "y": 82, + "w": 70, + "h": 78 + } + }, + { + "filename": "0052.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 138, + "y": 82, + "w": 70, + "h": 78 + } + }, + { + "filename": "0053.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 138, + "y": 82, + "w": 70, + "h": 78 + } + }, + { + "filename": "0076.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 138, + "y": 82, + "w": 70, + "h": 78 + } + }, + { + "filename": "0077.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 138, + "y": 82, + "w": 70, + "h": 78 + } + }, + { + "filename": "0124.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 138, + "y": 82, + "w": 70, + "h": 78 + } + }, + { + "filename": "0125.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 138, + "y": 82, + "w": 70, + "h": 78 + } + }, + { + "filename": "0148.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 138, + "y": 82, + "w": 70, + "h": 78 + } + }, + { + "filename": "0149.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 0, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 138, + "y": 82, + "w": 70, + "h": 78 + } + }, + { + "filename": "0006.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 140, + "y": 0, + "w": 70, + "h": 78 + } + }, + { + "filename": "0007.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 140, + "y": 0, + "w": 70, + "h": 78 + } + }, + { + "filename": "0030.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 140, + "y": 0, + "w": 70, + "h": 78 + } + }, + { + "filename": "0031.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 140, + "y": 0, + "w": 70, + "h": 78 + } + }, + { + "filename": "0054.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 140, + "y": 0, + "w": 70, + "h": 78 + } + }, + { + "filename": "0055.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 140, + "y": 0, + "w": 70, + "h": 78 + } + }, + { + "filename": "0078.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 140, + "y": 0, + "w": 70, + "h": 78 + } + }, + { + "filename": "0079.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 140, + "y": 0, + "w": 70, + "h": 78 + } + }, + { + "filename": "0126.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 140, + "y": 0, + "w": 70, + "h": 78 + } + }, + { + "filename": "0127.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 140, + "y": 0, + "w": 70, + "h": 78 + } + }, + { + "filename": "0150.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 140, + "y": 0, + "w": 70, + "h": 78 + } + }, + { + "filename": "0151.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 70, + "h": 78 + }, + "frame": { + "x": 140, + "y": 0, + "w": 70, + "h": 78 + } + }, + { + "filename": "0098.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 6, + "w": 68, + "h": 80 + }, + "frame": { + "x": 138, + "y": 160, + "w": 68, + "h": 80 + } + }, + { + "filename": "0099.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 6, + "w": 68, + "h": 80 + }, + "frame": { + "x": 138, + "y": 160, + "w": 68, + "h": 80 + } + }, + { + "filename": "0002.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 69, + "h": 78 + }, + "frame": { + "x": 140, + "y": 240, + "w": 69, + "h": 78 + } + }, + { + "filename": "0003.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 69, + "h": 78 + }, + "frame": { + "x": 140, + "y": 240, + "w": 69, + "h": 78 + } + }, + { + "filename": "0026.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 69, + "h": 78 + }, + "frame": { + "x": 140, + "y": 240, + "w": 69, + "h": 78 + } + }, + { + "filename": "0027.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 69, + "h": 78 + }, + "frame": { + "x": 140, + "y": 240, + "w": 69, + "h": 78 + } + }, + { + "filename": "0050.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 69, + "h": 78 + }, + "frame": { + "x": 140, + "y": 240, + "w": 69, + "h": 78 + } + }, + { + "filename": "0051.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 69, + "h": 78 + }, + "frame": { + "x": 140, + "y": 240, + "w": 69, + "h": 78 + } + }, + { + "filename": "0074.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 69, + "h": 78 + }, + "frame": { + "x": 140, + "y": 240, + "w": 69, + "h": 78 + } + }, + { + "filename": "0075.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 69, + "h": 78 + }, + "frame": { + "x": 140, + "y": 240, + "w": 69, + "h": 78 + } + }, + { + "filename": "0122.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 69, + "h": 78 + }, + "frame": { + "x": 140, + "y": 240, + "w": 69, + "h": 78 + } + }, + { + "filename": "0123.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 69, + "h": 78 + }, + "frame": { + "x": 140, + "y": 240, + "w": 69, + "h": 78 + } + }, + { + "filename": "0146.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 69, + "h": 78 + }, + "frame": { + "x": 140, + "y": 240, + "w": 69, + "h": 78 + } + }, + { + "filename": "0147.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 69, + "h": 78 + }, + "frame": { + "x": 140, + "y": 240, + "w": 69, + "h": 78 + } + }, + { + "filename": "0001.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 2, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 206, + "y": 160, + "w": 68, + "h": 78 + } + }, + { + "filename": "0024.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 2, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 206, + "y": 160, + "w": 68, + "h": 78 + } + }, + { + "filename": "0025.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 2, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 206, + "y": 160, + "w": 68, + "h": 78 + } + }, + { + "filename": "0048.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 2, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 206, + "y": 160, + "w": 68, + "h": 78 + } + }, + { + "filename": "0049.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 2, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 206, + "y": 160, + "w": 68, + "h": 78 + } + }, + { + "filename": "0072.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 2, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 206, + "y": 160, + "w": 68, + "h": 78 + } + }, + { + "filename": "0073.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 2, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 206, + "y": 160, + "w": 68, + "h": 78 + } + }, + { + "filename": "0096.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 2, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 206, + "y": 160, + "w": 68, + "h": 78 + } + }, + { + "filename": "0097.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 2, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 206, + "y": 160, + "w": 68, + "h": 78 + } + }, + { + "filename": "0118.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 2, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 206, + "y": 160, + "w": 68, + "h": 78 + } + }, + { + "filename": "0119.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 2, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 206, + "y": 160, + "w": 68, + "h": 78 + } + }, + { + "filename": "0120.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 2, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 206, + "y": 160, + "w": 68, + "h": 78 + } + }, + { + "filename": "0121.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 2, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 206, + "y": 160, + "w": 68, + "h": 78 + } + }, + { + "filename": "0144.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 2, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 206, + "y": 160, + "w": 68, + "h": 78 + } + }, + { + "filename": "0145.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 2, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 206, + "y": 160, + "w": 68, + "h": 78 + } + }, + { + "filename": "0116.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 208, + "y": 78, + "w": 68, + "h": 78 + } + }, + { + "filename": "0117.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 1, + "y": 8, + "w": 68, + "h": 78 + }, + "frame": { + "x": 208, + "y": 78, + "w": 68, + "h": 78 + } + }, + { + "filename": "0008.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 9, + "w": 68, + "h": 77 + }, + "frame": { + "x": 210, + "y": 0, + "w": 68, + "h": 77 + } + }, + { + "filename": "0009.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 9, + "w": 68, + "h": 77 + }, + "frame": { + "x": 210, + "y": 0, + "w": 68, + "h": 77 + } + }, + { + "filename": "0032.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 9, + "w": 68, + "h": 77 + }, + "frame": { + "x": 210, + "y": 0, + "w": 68, + "h": 77 + } + }, + { + "filename": "0033.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 9, + "w": 68, + "h": 77 + }, + "frame": { + "x": 210, + "y": 0, + "w": 68, + "h": 77 + } + }, + { + "filename": "0056.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 9, + "w": 68, + "h": 77 + }, + "frame": { + "x": 210, + "y": 0, + "w": 68, + "h": 77 + } + }, + { + "filename": "0057.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 9, + "w": 68, + "h": 77 + }, + "frame": { + "x": 210, + "y": 0, + "w": 68, + "h": 77 + } + }, + { + "filename": "0080.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 9, + "w": 68, + "h": 77 + }, + "frame": { + "x": 210, + "y": 0, + "w": 68, + "h": 77 + } + }, + { + "filename": "0081.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 9, + "w": 68, + "h": 77 + }, + "frame": { + "x": 210, + "y": 0, + "w": 68, + "h": 77 + } + }, + { + "filename": "0128.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 9, + "w": 68, + "h": 77 + }, + "frame": { + "x": 210, + "y": 0, + "w": 68, + "h": 77 + } + }, + { + "filename": "0129.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 9, + "w": 68, + "h": 77 + }, + "frame": { + "x": 210, + "y": 0, + "w": 68, + "h": 77 + } + }, + { + "filename": "0152.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 9, + "w": 68, + "h": 77 + }, + "frame": { + "x": 210, + "y": 0, + "w": 68, + "h": 77 + } + }, + { + "filename": "0153.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 9, + "w": 68, + "h": 77 + }, + "frame": { + "x": 210, + "y": 0, + "w": 68, + "h": 77 + } + }, + { + "filename": "0018.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 156, + "w": 67, + "h": 78 + } + }, + { + "filename": "0019.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 156, + "w": 67, + "h": 78 + } + }, + { + "filename": "0042.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 156, + "w": 67, + "h": 78 + } + }, + { + "filename": "0043.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 156, + "w": 67, + "h": 78 + } + }, + { + "filename": "0066.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 156, + "w": 67, + "h": 78 + } + }, + { + "filename": "0067.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 156, + "w": 67, + "h": 78 + } + }, + { + "filename": "0090.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 156, + "w": 67, + "h": 78 + } + }, + { + "filename": "0091.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 156, + "w": 67, + "h": 78 + } + }, + { + "filename": "0138.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 156, + "w": 67, + "h": 78 + } + }, + { + "filename": "0139.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 156, + "w": 67, + "h": 78 + } + }, + { + "filename": "0020.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 4, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 276, + "y": 77, + "w": 67, + "h": 78 + } + }, + { + "filename": "0021.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 4, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 276, + "y": 77, + "w": 67, + "h": 78 + } + }, + { + "filename": "0044.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 4, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 276, + "y": 77, + "w": 67, + "h": 78 + } + }, + { + "filename": "0045.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 4, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 276, + "y": 77, + "w": 67, + "h": 78 + } + }, + { + "filename": "0068.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 4, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 276, + "y": 77, + "w": 67, + "h": 78 + } + }, + { + "filename": "0069.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 4, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 276, + "y": 77, + "w": 67, + "h": 78 + } + }, + { + "filename": "0092.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 4, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 276, + "y": 77, + "w": 67, + "h": 78 + } + }, + { + "filename": "0093.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 4, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 276, + "y": 77, + "w": 67, + "h": 78 + } + }, + { + "filename": "0140.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 4, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 276, + "y": 77, + "w": 67, + "h": 78 + } + }, + { + "filename": "0141.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 4, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 276, + "y": 77, + "w": 67, + "h": 78 + } + }, + { + "filename": "0010.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 9, + "w": 67, + "h": 77 + }, + "frame": { + "x": 278, + "y": 0, + "w": 67, + "h": 77 + } + }, + { + "filename": "0011.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 9, + "w": 67, + "h": 77 + }, + "frame": { + "x": 278, + "y": 0, + "w": 67, + "h": 77 + } + }, + { + "filename": "0034.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 9, + "w": 67, + "h": 77 + }, + "frame": { + "x": 278, + "y": 0, + "w": 67, + "h": 77 + } + }, + { + "filename": "0035.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 9, + "w": 67, + "h": 77 + }, + "frame": { + "x": 278, + "y": 0, + "w": 67, + "h": 77 + } + }, + { + "filename": "0058.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 9, + "w": 67, + "h": 77 + }, + "frame": { + "x": 278, + "y": 0, + "w": 67, + "h": 77 + } + }, + { + "filename": "0059.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 9, + "w": 67, + "h": 77 + }, + "frame": { + "x": 278, + "y": 0, + "w": 67, + "h": 77 + } + }, + { + "filename": "0082.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 9, + "w": 67, + "h": 77 + }, + "frame": { + "x": 278, + "y": 0, + "w": 67, + "h": 77 + } + }, + { + "filename": "0083.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 9, + "w": 67, + "h": 77 + }, + "frame": { + "x": 278, + "y": 0, + "w": 67, + "h": 77 + } + }, + { + "filename": "0130.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 9, + "w": 67, + "h": 77 + }, + "frame": { + "x": 278, + "y": 0, + "w": 67, + "h": 77 + } + }, + { + "filename": "0131.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 9, + "w": 67, + "h": 77 + }, + "frame": { + "x": 278, + "y": 0, + "w": 67, + "h": 77 + } + }, + { + "filename": "0154.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 9, + "w": 67, + "h": 77 + }, + "frame": { + "x": 278, + "y": 0, + "w": 67, + "h": 77 + } + }, + { + "filename": "0155.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 5, + "y": 9, + "w": 67, + "h": 77 + }, + "frame": { + "x": 278, + "y": 0, + "w": 67, + "h": 77 + } + }, + { + "filename": "0022.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 234, + "w": 67, + "h": 78 + } + }, + { + "filename": "0023.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 234, + "w": 67, + "h": 78 + } + }, + { + "filename": "0046.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 234, + "w": 67, + "h": 78 + } + }, + { + "filename": "0047.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 234, + "w": 67, + "h": 78 + } + }, + { + "filename": "0070.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 234, + "w": 67, + "h": 78 + } + }, + { + "filename": "0071.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 234, + "w": 67, + "h": 78 + } + }, + { + "filename": "0094.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 234, + "w": 67, + "h": 78 + } + }, + { + "filename": "0095.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 234, + "w": 67, + "h": 78 + } + }, + { + "filename": "0142.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 234, + "w": 67, + "h": 78 + } + }, + { + "filename": "0143.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 3, + "y": 8, + "w": 67, + "h": 78 + }, + "frame": { + "x": 274, + "y": 234, + "w": 67, + "h": 78 + } + }, + { + "filename": "0014.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 7, + "y": 9, + "w": 65, + "h": 77 + }, + "frame": { + "x": 209, + "y": 238, + "w": 65, + "h": 77 + } + }, + { + "filename": "0015.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 7, + "y": 9, + "w": 65, + "h": 77 + }, + "frame": { + "x": 209, + "y": 238, + "w": 65, + "h": 77 + } + }, + { + "filename": "0038.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 7, + "y": 9, + "w": 65, + "h": 77 + }, + "frame": { + "x": 209, + "y": 238, + "w": 65, + "h": 77 + } + }, + { + "filename": "0039.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 7, + "y": 9, + "w": 65, + "h": 77 + }, + "frame": { + "x": 209, + "y": 238, + "w": 65, + "h": 77 + } + }, + { + "filename": "0062.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 7, + "y": 9, + "w": 65, + "h": 77 + }, + "frame": { + "x": 209, + "y": 238, + "w": 65, + "h": 77 + } + }, + { + "filename": "0063.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 7, + "y": 9, + "w": 65, + "h": 77 + }, + "frame": { + "x": 209, + "y": 238, + "w": 65, + "h": 77 + } + }, + { + "filename": "0086.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 7, + "y": 9, + "w": 65, + "h": 77 + }, + "frame": { + "x": 209, + "y": 238, + "w": 65, + "h": 77 + } + }, + { + "filename": "0087.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 7, + "y": 9, + "w": 65, + "h": 77 + }, + "frame": { + "x": 209, + "y": 238, + "w": 65, + "h": 77 + } + }, + { + "filename": "0134.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 7, + "y": 9, + "w": 65, + "h": 77 + }, + "frame": { + "x": 209, + "y": 238, + "w": 65, + "h": 77 + } + }, + { + "filename": "0135.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 7, + "y": 9, + "w": 65, + "h": 77 + }, + "frame": { + "x": 209, + "y": 238, + "w": 65, + "h": 77 + } + }, + { + "filename": "0158.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 7, + "y": 9, + "w": 65, + "h": 77 + }, + "frame": { + "x": 209, + "y": 238, + "w": 65, + "h": 77 + } + }, + { + "filename": "0159.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 7, + "y": 9, + "w": 65, + "h": 77 + }, + "frame": { + "x": 209, + "y": 238, + "w": 65, + "h": 77 + } + }, + { + "filename": "0016.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 6, + "y": 8, "w": 66, + "h": 78 + }, + "frame": { + "x": 274, + "y": 312, + "w": 66, + "h": 78 + } + }, + { + "filename": "0017.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 6, + "y": 8, + "w": 66, + "h": 78 + }, + "frame": { + "x": 274, + "y": 312, + "w": 66, + "h": 78 + } + }, + { + "filename": "0040.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 6, + "y": 8, + "w": 66, + "h": 78 + }, + "frame": { + "x": 274, + "y": 312, + "w": 66, + "h": 78 + } + }, + { + "filename": "0041.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 6, + "y": 8, + "w": 66, + "h": 78 + }, + "frame": { + "x": 274, + "y": 312, + "w": 66, + "h": 78 + } + }, + { + "filename": "0064.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 6, + "y": 8, + "w": 66, + "h": 78 + }, + "frame": { + "x": 274, + "y": 312, + "w": 66, + "h": 78 + } + }, + { + "filename": "0065.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 6, + "y": 8, + "w": 66, + "h": 78 + }, + "frame": { + "x": 274, + "y": 312, + "w": 66, + "h": 78 + } + }, + { + "filename": "0088.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 6, + "y": 8, + "w": 66, + "h": 78 + }, + "frame": { + "x": 274, + "y": 312, + "w": 66, + "h": 78 + } + }, + { + "filename": "0089.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 6, + "y": 8, + "w": 66, + "h": 78 + }, + "frame": { + "x": 274, + "y": 312, + "w": 66, + "h": 78 + } + }, + { + "filename": "0136.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 6, + "y": 8, + "w": 66, + "h": 78 + }, + "frame": { + "x": 274, + "y": 312, + "w": 66, + "h": 78 + } + }, + { + "filename": "0137.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 6, + "y": 8, + "w": 66, + "h": 78 + }, + "frame": { + "x": 274, + "y": 312, + "w": 66, + "h": 78 + } + }, + { + "filename": "0160.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 6, + "y": 8, + "w": 66, + "h": 78 + }, + "frame": { + "x": 274, + "y": 312, + "w": 66, + "h": 78 + } + }, + { + "filename": "0161.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 6, + "y": 8, + "w": 66, + "h": 78 + }, + "frame": { + "x": 274, + "y": 312, + "w": 66, + "h": 78 + } + }, + { + "filename": "0012.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 8, + "y": 10, + "w": 64, + "h": 76 + }, + "frame": { + "x": 209, + "y": 315, + "w": 64, + "h": 76 + } + }, + { + "filename": "0013.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 8, + "y": 10, + "w": 64, + "h": 76 + }, + "frame": { + "x": 209, + "y": 315, + "w": 64, + "h": 76 + } + }, + { + "filename": "0036.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 8, + "y": 10, + "w": 64, + "h": 76 + }, + "frame": { + "x": 209, + "y": 315, + "w": 64, + "h": 76 + } + }, + { + "filename": "0037.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 8, + "y": 10, + "w": 64, + "h": 76 + }, + "frame": { + "x": 209, + "y": 315, + "w": 64, + "h": 76 + } + }, + { + "filename": "0060.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 8, + "y": 10, + "w": 64, + "h": 76 + }, + "frame": { + "x": 209, + "y": 315, + "w": 64, + "h": 76 + } + }, + { + "filename": "0061.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 8, + "y": 10, + "w": 64, + "h": 76 + }, + "frame": { + "x": 209, + "y": 315, + "w": 64, + "h": 76 + } + }, + { + "filename": "0084.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 8, + "y": 10, + "w": 64, + "h": 76 + }, + "frame": { + "x": 209, + "y": 315, + "w": 64, + "h": 76 + } + }, + { + "filename": "0085.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 8, + "y": 10, + "w": 64, + "h": 76 + }, + "frame": { + "x": 209, + "y": 315, + "w": 64, + "h": 76 + } + }, + { + "filename": "0132.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 8, + "y": 10, + "w": 64, + "h": 76 + }, + "frame": { + "x": 209, + "y": 315, + "w": 64, + "h": 76 + } + }, + { + "filename": "0133.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 8, + "y": 10, + "w": 64, + "h": 76 + }, + "frame": { + "x": 209, + "y": 315, + "w": 64, + "h": 76 + } + }, + { + "filename": "0156.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 8, + "y": 10, + "w": 64, + "h": 76 + }, + "frame": { + "x": 209, + "y": 315, + "w": 64, + "h": 76 + } + }, + { + "filename": "0157.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 72, + "h": 86 + }, + "spriteSourceSize": { + "x": 8, + "y": 10, + "w": 64, + "h": 76 + }, + "frame": { + "x": 209, + "y": 315, + "w": 64, "h": 76 } } @@ -35,7 +3395,6 @@ ], "meta": { "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:2cc5522ad69edd3a28c7903c3abdd6ce:c667466f91fef6d10b81ef8f64ee4fb6:9ab527962e79006eb780a43bbf3afdac$" + "version": "3.0" } } diff --git a/public/images/pokemon/back/shiny/493-fairy.png b/public/images/pokemon/back/shiny/493-fairy.png index b49949930af..9285347f211 100644 Binary files a/public/images/pokemon/back/shiny/493-fairy.png and b/public/images/pokemon/back/shiny/493-fairy.png differ diff --git a/public/images/pokemon/back/shiny/658-ash.json b/public/images/pokemon/back/shiny/658-ash.json index a796ad08246..51a722070b3 100644 --- a/public/images/pokemon/back/shiny/658-ash.json +++ b/public/images/pokemon/back/shiny/658-ash.json @@ -1,41 +1,19 @@ -{ - "textures": [ - { - "image": "658-ash.png", - "format": "RGBA8888", - "size": { - "w": 73, - "h": 73 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 73, - "h": 69 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 73, - "h": 69 - }, - "frame": { - "x": 0, - "y": 0, - "w": 73, - "h": 69 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:d474b821316a87dfe09b397bdc2db5ef:497de0c2ec59ceba163e870b3226c76c:bfbf521a5c7bd80bcd95a96d9789c0dd$" - } +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.7-x64", + "format": "I8", + "size": { "w": 73, "h": 73 }, + "scale": "1" + } } diff --git a/public/images/pokemon/back/shiny/658-ash.png b/public/images/pokemon/back/shiny/658-ash.png index e41efb2c7ad..6e10e834731 100644 Binary files a/public/images/pokemon/back/shiny/658-ash.png and b/public/images/pokemon/back/shiny/658-ash.png differ diff --git a/public/images/pokemon/back/shiny/658.json b/public/images/pokemon/back/shiny/658.json index cc5d3c5b9ff..050b63e3592 100644 --- a/public/images/pokemon/back/shiny/658.json +++ b/public/images/pokemon/back/shiny/658.json @@ -1,41 +1,19 @@ -{ - "textures": [ - { - "image": "658.png", - "format": "RGBA8888", - "size": { - "w": 77, - "h": 77 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 77, - "h": 65 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 77, - "h": 65 - }, - "frame": { - "x": 0, - "y": 0, - "w": 77, - "h": 65 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:5891f87a78022cde3402e7d9714cc7bf:756360084290e39c139e3fef91c81759:5affcab976148657d36bf4ff3410f92d$" - } +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 77, "h": 77 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 77, "h": 77 }, + "sourceSize": { "w": 77, "h": 77 }, + "duration": 100 + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.7-x64", + "format": "I8", + "size": { "w": 77, "h": 77 }, + "scale": "1" + } } diff --git a/public/images/pokemon/back/shiny/658.png b/public/images/pokemon/back/shiny/658.png index 8b7f9c7e4fb..21519b6a145 100644 Binary files a/public/images/pokemon/back/shiny/658.png and b/public/images/pokemon/back/shiny/658.png differ diff --git a/public/images/pokemon/back/shiny/688.json b/public/images/pokemon/back/shiny/688.json index 56cf47aab5a..d9f30db34a8 100644 --- a/public/images/pokemon/back/shiny/688.json +++ b/public/images/pokemon/back/shiny/688.json @@ -1,41 +1,19 @@ -{ - "textures": [ - { - "image": "688.png", - "format": "RGBA8888", - "size": { - "w": 52, - "h": 52 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 41, - "h": 52 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 41, - "h": 52 - }, - "frame": { - "x": 0, - "y": 0, - "w": 41, - "h": 52 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:0261b6c9242bba728fcfbfc515875b27:de0d9ddceed9311b33ae50ba86e969d1:176060351d0044923af938ba7932a6ef$" - } +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 51, "h": 65 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 51, "h": 65 }, + "sourceSize": { "w": 51, "h": 65 } + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.7-dev", + "image": "688.png", + "format": "I8", + "size": { "w": 51, "h": 65 }, + "scale": "1" + } } diff --git a/public/images/pokemon/back/shiny/688.png b/public/images/pokemon/back/shiny/688.png index c4aff6eb12d..bfff80c4925 100644 Binary files a/public/images/pokemon/back/shiny/688.png and b/public/images/pokemon/back/shiny/688.png differ diff --git a/public/images/pokemon/back/shiny/773-bug.png b/public/images/pokemon/back/shiny/773-bug.png index 6e7d76f029a..5c10f205fe9 100644 Binary files a/public/images/pokemon/back/shiny/773-bug.png and b/public/images/pokemon/back/shiny/773-bug.png differ diff --git a/public/images/pokemon/back/shiny/773-dark.png b/public/images/pokemon/back/shiny/773-dark.png index 3f663cedd5a..0d469fa448e 100644 Binary files a/public/images/pokemon/back/shiny/773-dark.png and b/public/images/pokemon/back/shiny/773-dark.png differ diff --git a/public/images/pokemon/back/shiny/773-dragon.png b/public/images/pokemon/back/shiny/773-dragon.png index 1aea7b2e09b..d573f3f3a9d 100644 Binary files a/public/images/pokemon/back/shiny/773-dragon.png and b/public/images/pokemon/back/shiny/773-dragon.png differ diff --git a/public/images/pokemon/back/shiny/773-electric.png b/public/images/pokemon/back/shiny/773-electric.png index a55ed64866e..ffc58500637 100644 Binary files a/public/images/pokemon/back/shiny/773-electric.png and b/public/images/pokemon/back/shiny/773-electric.png differ diff --git a/public/images/pokemon/back/shiny/773-fairy.png b/public/images/pokemon/back/shiny/773-fairy.png index 5e4bde74525..cf73ecd51db 100644 Binary files a/public/images/pokemon/back/shiny/773-fairy.png and b/public/images/pokemon/back/shiny/773-fairy.png differ diff --git a/public/images/pokemon/back/shiny/773-fighting.png b/public/images/pokemon/back/shiny/773-fighting.png index f8d57df9f70..a3301ad2225 100644 Binary files a/public/images/pokemon/back/shiny/773-fighting.png and b/public/images/pokemon/back/shiny/773-fighting.png differ diff --git a/public/images/pokemon/back/shiny/773-fire.png b/public/images/pokemon/back/shiny/773-fire.png index f2d365f7972..c7e9cac0048 100644 Binary files a/public/images/pokemon/back/shiny/773-fire.png and b/public/images/pokemon/back/shiny/773-fire.png differ diff --git a/public/images/pokemon/back/shiny/773-flying.png b/public/images/pokemon/back/shiny/773-flying.png index b74b047884a..e5d51566755 100644 Binary files a/public/images/pokemon/back/shiny/773-flying.png and b/public/images/pokemon/back/shiny/773-flying.png differ diff --git a/public/images/pokemon/back/shiny/773-ghost.png b/public/images/pokemon/back/shiny/773-ghost.png index 23a12fad630..86ba0a7d25f 100644 Binary files a/public/images/pokemon/back/shiny/773-ghost.png and b/public/images/pokemon/back/shiny/773-ghost.png differ diff --git a/public/images/pokemon/back/shiny/773-grass.png b/public/images/pokemon/back/shiny/773-grass.png index 2e33c6eeffc..6602acf8d7e 100644 Binary files a/public/images/pokemon/back/shiny/773-grass.png and b/public/images/pokemon/back/shiny/773-grass.png differ diff --git a/public/images/pokemon/back/shiny/773-ground.png b/public/images/pokemon/back/shiny/773-ground.png index 61448499f81..595494c4fae 100644 Binary files a/public/images/pokemon/back/shiny/773-ground.png and b/public/images/pokemon/back/shiny/773-ground.png differ diff --git a/public/images/pokemon/back/shiny/773-ice.png b/public/images/pokemon/back/shiny/773-ice.png index bb267ca8c5a..65e5525f120 100644 Binary files a/public/images/pokemon/back/shiny/773-ice.png and b/public/images/pokemon/back/shiny/773-ice.png differ diff --git a/public/images/pokemon/back/shiny/773-poison.png b/public/images/pokemon/back/shiny/773-poison.png index ac1ae49957d..60974b37cf2 100644 Binary files a/public/images/pokemon/back/shiny/773-poison.png and b/public/images/pokemon/back/shiny/773-poison.png differ diff --git a/public/images/pokemon/back/shiny/773-psychic.png b/public/images/pokemon/back/shiny/773-psychic.png index 757f747f8c7..0b6c2397ca7 100644 Binary files a/public/images/pokemon/back/shiny/773-psychic.png and b/public/images/pokemon/back/shiny/773-psychic.png differ diff --git a/public/images/pokemon/back/shiny/773-rock.png b/public/images/pokemon/back/shiny/773-rock.png index a8ef40d4070..75af92d1691 100644 Binary files a/public/images/pokemon/back/shiny/773-rock.png and b/public/images/pokemon/back/shiny/773-rock.png differ diff --git a/public/images/pokemon/back/shiny/773-steel.png b/public/images/pokemon/back/shiny/773-steel.png index 37aabe131e2..5155256a271 100644 Binary files a/public/images/pokemon/back/shiny/773-steel.png and b/public/images/pokemon/back/shiny/773-steel.png differ diff --git a/public/images/pokemon/back/shiny/773-water.png b/public/images/pokemon/back/shiny/773-water.png index a4660711555..936b19f728f 100644 Binary files a/public/images/pokemon/back/shiny/773-water.png and b/public/images/pokemon/back/shiny/773-water.png differ diff --git a/public/images/pokemon/back/shiny/774-blue.png b/public/images/pokemon/back/shiny/774-blue.png index c8477c91c2a..7ed82f85030 100644 Binary files a/public/images/pokemon/back/shiny/774-blue.png and b/public/images/pokemon/back/shiny/774-blue.png differ diff --git a/public/images/pokemon/back/shiny/774-green.png b/public/images/pokemon/back/shiny/774-green.png index 843aadb94e8..cc354d82628 100644 Binary files a/public/images/pokemon/back/shiny/774-green.png and b/public/images/pokemon/back/shiny/774-green.png differ diff --git a/public/images/pokemon/back/shiny/774-indigo.png b/public/images/pokemon/back/shiny/774-indigo.png index 0c1502ac073..c02598b1de5 100644 Binary files a/public/images/pokemon/back/shiny/774-indigo.png and b/public/images/pokemon/back/shiny/774-indigo.png differ diff --git a/public/images/pokemon/back/shiny/774-orange.png b/public/images/pokemon/back/shiny/774-orange.png index a1287c12d2e..ef6d161584d 100644 Binary files a/public/images/pokemon/back/shiny/774-orange.png and b/public/images/pokemon/back/shiny/774-orange.png differ diff --git a/public/images/pokemon/back/shiny/774-red.png b/public/images/pokemon/back/shiny/774-red.png index 596cd35f078..600012bbe6f 100644 Binary files a/public/images/pokemon/back/shiny/774-red.png and b/public/images/pokemon/back/shiny/774-red.png differ diff --git a/public/images/pokemon/back/shiny/774-violet.png b/public/images/pokemon/back/shiny/774-violet.png index a52b3be04b2..4b75f7ee3e0 100644 Binary files a/public/images/pokemon/back/shiny/774-violet.png and b/public/images/pokemon/back/shiny/774-violet.png differ diff --git a/public/images/pokemon/back/shiny/774-yellow.png b/public/images/pokemon/back/shiny/774-yellow.png index 3f0370b713f..01e980b9edf 100644 Binary files a/public/images/pokemon/back/shiny/774-yellow.png and b/public/images/pokemon/back/shiny/774-yellow.png differ diff --git a/public/images/pokemon/back/shiny/944.png b/public/images/pokemon/back/shiny/944.png index 24957073d46..a33c2a39c2f 100644 Binary files a/public/images/pokemon/back/shiny/944.png and b/public/images/pokemon/back/shiny/944.png differ diff --git a/public/images/pokemon/back/shiny/945.png b/public/images/pokemon/back/shiny/945.png index a1cc685f008..38be3590480 100644 Binary files a/public/images/pokemon/back/shiny/945.png and b/public/images/pokemon/back/shiny/945.png differ diff --git a/public/images/pokemon/back/shiny/966-caph-starmobile.json b/public/images/pokemon/back/shiny/966-caph-starmobile.json new file mode 100644 index 00000000000..d71eccd11d7 --- /dev/null +++ b/public/images/pokemon/back/shiny/966-caph-starmobile.json @@ -0,0 +1,41 @@ +{ + "textures": [ + { + "image": "966-caph-starmobile.png", + "format": "RGBA8888", + "size": { + "w": 84, + "h": 84 + }, + "scale": 0.333, + "frames": [ + { + "filename": "0001.png", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 96, + "h": 96 + }, + "spriteSourceSize": { + "x": 6, + "y": 20, + "w": 84, + "h": 56 + }, + "frame": { + "x": 0, + "y": 0, + "w": 84, + "h": 56 + } + } + ] + } + ], + "meta": { + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0", + "smartupdate": "$TexturePacker:SmartUpdate:0226ae22b7a4822d78e38df4af1f59a7:01ce69442faf54e54474cd349cad2f7d:f9a0366e304d666e4262fa0af369d1f4$" + } +} diff --git a/public/images/pokemon/back/shiny/966-caph-starmobile.png b/public/images/pokemon/back/shiny/966-caph-starmobile.png new file mode 100644 index 00000000000..64e72d6793f Binary files /dev/null and b/public/images/pokemon/back/shiny/966-caph-starmobile.png differ diff --git a/public/images/pokemon/back/shiny/966-navi-starmobile.json b/public/images/pokemon/back/shiny/966-navi-starmobile.json new file mode 100644 index 00000000000..99059aa6edb --- /dev/null +++ b/public/images/pokemon/back/shiny/966-navi-starmobile.json @@ -0,0 +1,41 @@ +{ + "textures": [ + { + "image": "966-navi-starmobile.png", + "format": "RGBA8888", + "size": { + "w": 84, + "h": 84 + }, + "scale": 0.333, + "frames": [ + { + "filename": "0001.png", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 96, + "h": 96 + }, + "spriteSourceSize": { + "x": 6, + "y": 20, + "w": 84, + "h": 56 + }, + "frame": { + "x": 0, + "y": 0, + "w": 84, + "h": 56 + } + } + ] + } + ], + "meta": { + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0", + "smartupdate": "$TexturePacker:SmartUpdate:0226ae22b7a4822d78e38df4af1f59a7:01ce69442faf54e54474cd349cad2f7d:f9a0366e304d666e4262fa0af369d1f4$" + } +} diff --git a/public/images/pokemon/back/shiny/966-navi-starmobile.png b/public/images/pokemon/back/shiny/966-navi-starmobile.png new file mode 100644 index 00000000000..64e72d6793f Binary files /dev/null and b/public/images/pokemon/back/shiny/966-navi-starmobile.png differ diff --git a/public/images/pokemon/back/shiny/966-ruchbah-starmobile.json b/public/images/pokemon/back/shiny/966-ruchbah-starmobile.json new file mode 100644 index 00000000000..b3bb8463eac --- /dev/null +++ b/public/images/pokemon/back/shiny/966-ruchbah-starmobile.json @@ -0,0 +1,41 @@ +{ + "textures": [ + { + "image": "966-ruchbah-starmobile.png", + "format": "RGBA8888", + "size": { + "w": 84, + "h": 84 + }, + "scale": 0.333, + "frames": [ + { + "filename": "0001.png", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 96, + "h": 96 + }, + "spriteSourceSize": { + "x": 6, + "y": 20, + "w": 84, + "h": 56 + }, + "frame": { + "x": 0, + "y": 0, + "w": 84, + "h": 56 + } + } + ] + } + ], + "meta": { + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0", + "smartupdate": "$TexturePacker:SmartUpdate:0226ae22b7a4822d78e38df4af1f59a7:01ce69442faf54e54474cd349cad2f7d:f9a0366e304d666e4262fa0af369d1f4$" + } +} diff --git a/public/images/pokemon/back/shiny/966-ruchbah-starmobile.png b/public/images/pokemon/back/shiny/966-ruchbah-starmobile.png new file mode 100644 index 00000000000..64e72d6793f Binary files /dev/null and b/public/images/pokemon/back/shiny/966-ruchbah-starmobile.png differ diff --git a/public/images/pokemon/back/shiny/966-schedar-starmobile.json b/public/images/pokemon/back/shiny/966-schedar-starmobile.json new file mode 100644 index 00000000000..9832835b3ce --- /dev/null +++ b/public/images/pokemon/back/shiny/966-schedar-starmobile.json @@ -0,0 +1,41 @@ +{ + "textures": [ + { + "image": "966-schedar-starmobile.png", + "format": "RGBA8888", + "size": { + "w": 84, + "h": 84 + }, + "scale": 0.333, + "frames": [ + { + "filename": "0001.png", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 96, + "h": 96 + }, + "spriteSourceSize": { + "x": 6, + "y": 20, + "w": 84, + "h": 56 + }, + "frame": { + "x": 0, + "y": 0, + "w": 84, + "h": 56 + } + } + ] + } + ], + "meta": { + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0", + "smartupdate": "$TexturePacker:SmartUpdate:0226ae22b7a4822d78e38df4af1f59a7:01ce69442faf54e54474cd349cad2f7d:f9a0366e304d666e4262fa0af369d1f4$" + } +} diff --git a/public/images/pokemon/back/shiny/966-schedar-starmobile.png b/public/images/pokemon/back/shiny/966-schedar-starmobile.png new file mode 100644 index 00000000000..64e72d6793f Binary files /dev/null and b/public/images/pokemon/back/shiny/966-schedar-starmobile.png differ diff --git a/public/images/pokemon/back/shiny/966-segin-starmobile.json b/public/images/pokemon/back/shiny/966-segin-starmobile.json new file mode 100644 index 00000000000..75bd4d8f304 --- /dev/null +++ b/public/images/pokemon/back/shiny/966-segin-starmobile.json @@ -0,0 +1,41 @@ +{ + "textures": [ + { + "image": "966-segin-starmobile.png", + "format": "RGBA8888", + "size": { + "w": 84, + "h": 84 + }, + "scale": 0.333, + "frames": [ + { + "filename": "0001.png", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 96, + "h": 96 + }, + "spriteSourceSize": { + "x": 6, + "y": 20, + "w": 84, + "h": 56 + }, + "frame": { + "x": 0, + "y": 0, + "w": 84, + "h": 56 + } + } + ] + } + ], + "meta": { + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0", + "smartupdate": "$TexturePacker:SmartUpdate:0226ae22b7a4822d78e38df4af1f59a7:01ce69442faf54e54474cd349cad2f7d:f9a0366e304d666e4262fa0af369d1f4$" + } +} diff --git a/public/images/pokemon/back/shiny/966-segin-starmobile.png b/public/images/pokemon/back/shiny/966-segin-starmobile.png new file mode 100644 index 00000000000..64e72d6793f Binary files /dev/null and b/public/images/pokemon/back/shiny/966-segin-starmobile.png differ diff --git a/public/images/pokemon/exp/2026.png b/public/images/pokemon/exp/2026.png index 80ac591cd62..718fb8957b3 100644 Binary files a/public/images/pokemon/exp/2026.png and b/public/images/pokemon/exp/2026.png differ diff --git a/public/images/pokemon/exp/359-mega.png b/public/images/pokemon/exp/359-mega.png index 8b6d0dd2b4a..10787a35a8b 100644 Binary files a/public/images/pokemon/exp/359-mega.png and b/public/images/pokemon/exp/359-mega.png differ diff --git a/public/images/pokemon/exp/4144.png b/public/images/pokemon/exp/4144.png index 85106042b2a..5f2be320991 100644 Binary files a/public/images/pokemon/exp/4144.png and b/public/images/pokemon/exp/4144.png differ diff --git a/public/images/pokemon/exp/4145.png b/public/images/pokemon/exp/4145.png index acdc9bd12c3..1afe5bf5d37 100644 Binary files a/public/images/pokemon/exp/4145.png and b/public/images/pokemon/exp/4145.png differ diff --git a/public/images/pokemon/exp/4146.png b/public/images/pokemon/exp/4146.png index 4104328836f..09c8e1a0803 100644 Binary files a/public/images/pokemon/exp/4146.png and b/public/images/pokemon/exp/4146.png differ diff --git a/public/images/pokemon/exp/6503.png b/public/images/pokemon/exp/6503.png index 28d3a366fef..d1a698254cb 100644 Binary files a/public/images/pokemon/exp/6503.png and b/public/images/pokemon/exp/6503.png differ diff --git a/public/images/pokemon/exp/656.png b/public/images/pokemon/exp/656.png index 4f4af590a45..7afec8b08ee 100644 Binary files a/public/images/pokemon/exp/656.png and b/public/images/pokemon/exp/656.png differ diff --git a/public/images/pokemon/exp/657.png b/public/images/pokemon/exp/657.png index 6cfff5af3f7..404fb30a2b2 100644 Binary files a/public/images/pokemon/exp/657.png and b/public/images/pokemon/exp/657.png differ diff --git a/public/images/pokemon/exp/658-ash.json b/public/images/pokemon/exp/658-ash.json index f3a02cb1774..52dbac8366a 100644 --- a/public/images/pokemon/exp/658-ash.json +++ b/public/images/pokemon/exp/658-ash.json @@ -1,671 +1,299 @@ -{ - "textures": [ - { - "image": "658-ash.png", - "format": "RGBA8888", - "size": { - "w": 150, - "h": 150 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 75, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 75, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 75, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 75, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 75, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 75, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 75, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 75, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 75, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 75, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 75, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 0, - "y": 66, - "w": 75, - "h": 66 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 0, - "y": 66, - "w": 75, - "h": 66 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 0, - "y": 66, - "w": 75, - "h": 66 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 0, - "y": 66, - "w": 75, - "h": 66 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 75, - "h": 65 - }, - "frame": { - "x": 75, - "y": 66, - "w": 75, - "h": 65 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 75, - "h": 65 - }, - "frame": { - "x": 75, - "y": 66, - "w": 75, - "h": 65 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 75, - "h": 65 - }, - "frame": { - "x": 75, - "y": 66, - "w": 75, - "h": 65 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 75, - "h": 65 - }, - "frame": { - "x": 75, - "y": 66, - "w": 75, - "h": 65 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 75, - "h": 65 - }, - "frame": { - "x": 75, - "y": 66, - "w": 75, - "h": 65 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 75, - "h": 65 - }, - "frame": { - "x": 75, - "y": 66, - "w": 75, - "h": 65 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 75, - "h": 65 - }, - "frame": { - "x": 75, - "y": 66, - "w": 75, - "h": 65 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 75, - "h": 65 - }, - "frame": { - "x": 75, - "y": 66, - "w": 75, - "h": 65 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:cfb009f1af61ea752bdb3266bffd0fd0:e1abe8d09d1fe3c1ec758293b0a4bed5:f09eeed5adc5ec50aec50218e03662c2$" - } +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0002.png", + "frame": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0003.png", + "frame": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0004.png", + "frame": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0005.png", + "frame": { "x": 79, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0006.png", + "frame": { "x": 79, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0007.png", + "frame": { "x": 79, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0008.png", + "frame": { "x": 79, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0009.png", + "frame": { "x": 158, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0010.png", + "frame": { "x": 158, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0011.png", + "frame": { "x": 158, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0012.png", + "frame": { "x": 158, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0013.png", + "frame": { "x": 0, "y": 74, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0014.png", + "frame": { "x": 0, "y": 74, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0015.png", + "frame": { "x": 0, "y": 74, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0016.png", + "frame": { "x": 0, "y": 74, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0017.png", + "frame": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0018.png", + "frame": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0019.png", + "frame": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0020.png", + "frame": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0021.png", + "frame": { "x": 79, "y": 74, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0022.png", + "frame": { "x": 79, "y": 74, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0023.png", + "frame": { "x": 79, "y": 74, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0024.png", + "frame": { "x": 79, "y": 74, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0025.png", + "frame": { "x": 158, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0026.png", + "frame": { "x": 158, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0027.png", + "frame": { "x": 158, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0028.png", + "frame": { "x": 158, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0029.png", + "frame": { "x": 0, "y": 74, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0030.png", + "frame": { "x": 0, "y": 74, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0031.png", + "frame": { "x": 0, "y": 74, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0032.png", + "frame": { "x": 0, "y": 74, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.7-x64", + "image": "658-ash.png", + "format": "I8", + "size": { "w": 237, "h": 148 }, + "scale": "1" + } } diff --git a/public/images/pokemon/exp/658-ash.png b/public/images/pokemon/exp/658-ash.png index 5d80ca1ad0e..6bb84f3e4fd 100644 Binary files a/public/images/pokemon/exp/658-ash.png and b/public/images/pokemon/exp/658-ash.png differ diff --git a/public/images/pokemon/exp/658.png b/public/images/pokemon/exp/658.png index ab2e30592f6..83b2f5fab89 100644 Binary files a/public/images/pokemon/exp/658.png and b/public/images/pokemon/exp/658.png differ diff --git a/public/images/pokemon/exp/662.png b/public/images/pokemon/exp/662.png index 090e6e4c91f..e47863f724b 100644 Binary files a/public/images/pokemon/exp/662.png and b/public/images/pokemon/exp/662.png differ diff --git a/public/images/pokemon/exp/6706.png b/public/images/pokemon/exp/6706.png index ea745dfb04b..77b10183ec7 100644 Binary files a/public/images/pokemon/exp/6706.png and b/public/images/pokemon/exp/6706.png differ diff --git a/public/images/pokemon/exp/682.png b/public/images/pokemon/exp/682.png index 35ab3a5c315..104dc143677 100644 Binary files a/public/images/pokemon/exp/682.png and b/public/images/pokemon/exp/682.png differ diff --git a/public/images/pokemon/exp/683.png b/public/images/pokemon/exp/683.png index 5e8ff5acd30..d657a0ee5fd 100644 Binary files a/public/images/pokemon/exp/683.png and b/public/images/pokemon/exp/683.png differ diff --git a/public/images/pokemon/exp/684.png b/public/images/pokemon/exp/684.png index d7d6b29f730..84f06ee4f3c 100644 Binary files a/public/images/pokemon/exp/684.png and b/public/images/pokemon/exp/684.png differ diff --git a/public/images/pokemon/exp/685.png b/public/images/pokemon/exp/685.png index cfccc4f119b..2a1ab94bc22 100644 Binary files a/public/images/pokemon/exp/685.png and b/public/images/pokemon/exp/685.png differ diff --git a/public/images/pokemon/exp/696.png b/public/images/pokemon/exp/696.png index 26017b1e06f..8dd6b2cf6c7 100644 Binary files a/public/images/pokemon/exp/696.png and b/public/images/pokemon/exp/696.png differ diff --git a/public/images/pokemon/exp/697.png b/public/images/pokemon/exp/697.png index 8548ca8aa17..136007c2892 100644 Binary files a/public/images/pokemon/exp/697.png and b/public/images/pokemon/exp/697.png differ diff --git a/public/images/pokemon/exp/705.png b/public/images/pokemon/exp/705.png index 3413bcd9fa3..670e8be5d51 100644 Binary files a/public/images/pokemon/exp/705.png and b/public/images/pokemon/exp/705.png differ diff --git a/public/images/pokemon/exp/773-bug.png b/public/images/pokemon/exp/773-bug.png index 281f1467730..e511e648338 100644 Binary files a/public/images/pokemon/exp/773-bug.png and b/public/images/pokemon/exp/773-bug.png differ diff --git a/public/images/pokemon/exp/773-dark.png b/public/images/pokemon/exp/773-dark.png index 5c95c669800..7b6c2b6dce9 100644 Binary files a/public/images/pokemon/exp/773-dark.png and b/public/images/pokemon/exp/773-dark.png differ diff --git a/public/images/pokemon/exp/773-dragon.png b/public/images/pokemon/exp/773-dragon.png index 6e5231c067d..dbc3e89a698 100644 Binary files a/public/images/pokemon/exp/773-dragon.png and b/public/images/pokemon/exp/773-dragon.png differ diff --git a/public/images/pokemon/exp/773-electric.png b/public/images/pokemon/exp/773-electric.png index 708fc551ad0..7610647c214 100644 Binary files a/public/images/pokemon/exp/773-electric.png and b/public/images/pokemon/exp/773-electric.png differ diff --git a/public/images/pokemon/exp/773-fairy.png b/public/images/pokemon/exp/773-fairy.png index 3e04b17df6c..d365459c3fd 100644 Binary files a/public/images/pokemon/exp/773-fairy.png and b/public/images/pokemon/exp/773-fairy.png differ diff --git a/public/images/pokemon/exp/773-fighting.png b/public/images/pokemon/exp/773-fighting.png index 18a25a1aed9..dd5cea7cc25 100644 Binary files a/public/images/pokemon/exp/773-fighting.png and b/public/images/pokemon/exp/773-fighting.png differ diff --git a/public/images/pokemon/exp/773-fire.png b/public/images/pokemon/exp/773-fire.png index a1745cdaf05..291c9d21183 100644 Binary files a/public/images/pokemon/exp/773-fire.png and b/public/images/pokemon/exp/773-fire.png differ diff --git a/public/images/pokemon/exp/773-flying.png b/public/images/pokemon/exp/773-flying.png index aacf1346248..780184915e6 100644 Binary files a/public/images/pokemon/exp/773-flying.png and b/public/images/pokemon/exp/773-flying.png differ diff --git a/public/images/pokemon/exp/773-ghost.png b/public/images/pokemon/exp/773-ghost.png index b0893298762..64484c31fae 100644 Binary files a/public/images/pokemon/exp/773-ghost.png and b/public/images/pokemon/exp/773-ghost.png differ diff --git a/public/images/pokemon/exp/773-grass.png b/public/images/pokemon/exp/773-grass.png index f9eb0838eab..e563d9d57c6 100644 Binary files a/public/images/pokemon/exp/773-grass.png and b/public/images/pokemon/exp/773-grass.png differ diff --git a/public/images/pokemon/exp/773-ground.png b/public/images/pokemon/exp/773-ground.png index 31022ff98cd..84889d89242 100644 Binary files a/public/images/pokemon/exp/773-ground.png and b/public/images/pokemon/exp/773-ground.png differ diff --git a/public/images/pokemon/exp/773-ice.png b/public/images/pokemon/exp/773-ice.png index bbdd48211eb..3798d41cefb 100644 Binary files a/public/images/pokemon/exp/773-ice.png and b/public/images/pokemon/exp/773-ice.png differ diff --git a/public/images/pokemon/exp/773-poison.png b/public/images/pokemon/exp/773-poison.png index 772ab8c1f29..70a64e6375f 100644 Binary files a/public/images/pokemon/exp/773-poison.png and b/public/images/pokemon/exp/773-poison.png differ diff --git a/public/images/pokemon/exp/773-psychic.png b/public/images/pokemon/exp/773-psychic.png index 8d76edcc44b..2ec15fa4867 100644 Binary files a/public/images/pokemon/exp/773-psychic.png and b/public/images/pokemon/exp/773-psychic.png differ diff --git a/public/images/pokemon/exp/773-rock.png b/public/images/pokemon/exp/773-rock.png index 812abc8dd13..c0503467175 100644 Binary files a/public/images/pokemon/exp/773-rock.png and b/public/images/pokemon/exp/773-rock.png differ diff --git a/public/images/pokemon/exp/773-steel.png b/public/images/pokemon/exp/773-steel.png index 6347d267c1a..e2c5a28d97a 100644 Binary files a/public/images/pokemon/exp/773-steel.png and b/public/images/pokemon/exp/773-steel.png differ diff --git a/public/images/pokemon/exp/773-water.png b/public/images/pokemon/exp/773-water.png index fc3c27f7b37..5e830fad8cb 100644 Binary files a/public/images/pokemon/exp/773-water.png and b/public/images/pokemon/exp/773-water.png differ diff --git a/public/images/pokemon/exp/773.png b/public/images/pokemon/exp/773.png index 4a1758b52b3..51a8195c043 100644 Binary files a/public/images/pokemon/exp/773.png and b/public/images/pokemon/exp/773.png differ diff --git a/public/images/pokemon/exp/774-blue.json b/public/images/pokemon/exp/774-blue.json index 97461cb5df4..b0c94749eaa 100644 --- a/public/images/pokemon/exp/774-blue.json +++ b/public/images/pokemon/exp/774-blue.json @@ -3,1068 +3,563 @@ { "image": "774-blue.png", "format": "RGBA8888", - "size": { - "w": 274, - "h": 274 - }, + "size": {"w": 274, "h": 274}, "scale": 1, "frames": [ { "filename": "0013.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 1, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 1,"w": 39,"h": 38}, + "frame": + {"x": 0,"y": 0,"w": 39,"h": 38} }, { "filename": "0036.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 18, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 18,"w": 39,"h": 38}, + "frame": + {"x": 39,"y": 0,"w": 39,"h": 38} }, { "filename": "0040.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 22, - "w": 39, - "h": 38 - }, - "frame": { - "x": 78, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 22,"w": 39,"h": 38}, + "frame": + {"x": 78,"y": 0,"w": 39,"h": 38} }, { "filename": "0044.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 20, - "w": 39, - "h": 38 - }, - "frame": { - "x": 117, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 20,"w": 39,"h": 38}, + "frame": + {"x": 117,"y": 0,"w": 39,"h": 38} }, { "filename": "0006.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 8, - "w": 40, - "h": 37 - }, - "frame": { - "x": 156, - "y": 0, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 40,"h": 37}, + "frame": + {"x": 156,"y": 0,"w": 40,"h": 37} }, { "filename": "0010.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 4, - "w": 40, - "h": 37 - }, - "frame": { - "x": 196, - "y": 0, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 4,"w": 40,"h": 37}, + "frame": + {"x": 196,"y": 0,"w": 40,"h": 37} }, { "filename": "0035.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 38, - "h": 38 - }, - "frame": { - "x": 236, - "y": 0, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 38,"h": 38}, + "frame": + {"x": 236,"y": 0,"w": 38,"h": 38} }, { "filename": "0018.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 40, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 0,"w": 40,"h": 37}, + "frame": + {"x": 156,"y": 37,"w": 40,"h": 37} }, { "filename": "0021.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 3, - "w": 40, - "h": 37 - }, - "frame": { - "x": 196, - "y": 37, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 3,"w": 40,"h": 37}, + "frame": + {"x": 196,"y": 37,"w": 40,"h": 37} }, { "filename": "0039.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 21, - "w": 38, - "h": 38 - }, - "frame": { - "x": 236, - "y": 38, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 21,"w": 38,"h": 38}, + "frame": + {"x": 236,"y": 38,"w": 38,"h": 38} }, { "filename": "0024.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 6, - "w": 40, - "h": 37 - }, - "frame": { - "x": 0, - "y": 38, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 6,"w": 40,"h": 37}, + "frame": + {"x": 0,"y": 38,"w": 40,"h": 37} }, { "filename": "0045.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 38, - "h": 38 - }, - "frame": { - "x": 40, - "y": 38, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 18,"w": 38,"h": 38}, + "frame": + {"x": 40,"y": 38,"w": 38,"h": 38} }, { "filename": "0047.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 38, - "h": 38 - }, - "frame": { - "x": 0, - "y": 75, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 38,"h": 38}, + "frame": + {"x": 0,"y": 75,"w": 38,"h": 38} }, { "filename": "0001.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 14, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 38,"w": 39,"h": 37} }, { "filename": "0002.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 13, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 13,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 38,"w": 39,"h": 37} }, { "filename": "0004.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 11,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 38,"w": 39,"h": 37} }, { "filename": "0049.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 16, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 16,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 38,"w": 39,"h": 37} }, { "filename": "0005.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 156,"y": 74,"w": 39,"h": 37} }, { "filename": "0008.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 7,"w": 39,"h": 37}, + "frame": + {"x": 195,"y": 74,"w": 39,"h": 37} }, { "filename": "0009.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 5, - "w": 39, - "h": 37 - }, - "frame": { - "x": 234, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 5,"w": 39,"h": 37}, + "frame": + {"x": 234,"y": 76,"w": 39,"h": 37} }, { "filename": "0011.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 3, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 75, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 3,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 75,"w": 39,"h": 37} }, { "filename": "0012.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 75, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 75,"w": 39,"h": 37} }, { "filename": "0014.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 37 - }, - "frame": { - "x": 38, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 37}, + "frame": + {"x": 38,"y": 76,"w": 39,"h": 37} }, { "filename": "0017.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 37}, + "frame": + {"x": 156,"y": 111,"w": 39,"h": 37} }, { "filename": "0019.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 1, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 1,"w": 39,"h": 37}, + "frame": + {"x": 195,"y": 111,"w": 39,"h": 37} }, { "filename": "0022.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 4, - "w": 39, - "h": 37 - }, - "frame": { - "x": 234, - "y": 113, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 4,"w": 39,"h": 37}, + "frame": + {"x": 234,"y": 113,"w": 39,"h": 37} }, { "filename": "0025.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 77, - "y": 112, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 7,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 112,"w": 39,"h": 37} }, { "filename": "0026.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 116, - "y": 112, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 112,"w": 39,"h": 37} }, { "filename": "0027.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 155, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 155,"y": 148,"w": 39,"h": 37} }, { "filename": "0028.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 194, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 194,"y": 148,"w": 39,"h": 37} }, { "filename": "0029.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 233, - "y": 150, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 11,"w": 39,"h": 37}, + "frame": + {"x": 233,"y": 150,"w": 39,"h": 37} }, { "filename": "0030.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 12, - "w": 39, - "h": 37 - }, - "frame": { - "x": 0, - "y": 113, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 12,"w": 39,"h": 37}, + "frame": + {"x": 0,"y": 113,"w": 39,"h": 37} }, { "filename": "0038.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 21, - "w": 38, - "h": 37 - }, - "frame": { - "x": 39, - "y": 113, - "w": 38, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 21,"w": 38,"h": 37}, + "frame": + {"x": 39,"y": 113,"w": 38,"h": 37} }, { "filename": "0031.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 14, - "w": 39, - "h": 37 - }, - "frame": { - "x": 77, - "y": 149, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 149,"w": 39,"h": 37} }, { "filename": "0032.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 14, - "w": 39, - "h": 37 - }, - "frame": { - "x": 116, - "y": 149, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 149,"w": 39,"h": 37} }, { "filename": "0033.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 15, - "w": 39, - "h": 37 - }, - "frame": { - "x": 155, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 15,"w": 39,"h": 37}, + "frame": + {"x": 155,"y": 185,"w": 39,"h": 37} }, { "filename": "0034.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 17, - "w": 39, - "h": 37 - }, - "frame": { - "x": 194, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 17,"w": 39,"h": 37}, + "frame": + {"x": 194,"y": 185,"w": 39,"h": 37} }, { "filename": "0037.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 20, - "w": 39, - "h": 37 - }, - "frame": { - "x": 233, - "y": 187, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 20,"w": 39,"h": 37}, + "frame": + {"x": 233,"y": 187,"w": 39,"h": 37} }, { "filename": "0046.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 39, - "h": 37 - }, - "frame": { - "x": 0, - "y": 150, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 18,"w": 39,"h": 37}, + "frame": + {"x": 0,"y": 150,"w": 39,"h": 37} }, { "filename": "0042.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 22, - "w": 38, - "h": 37 - }, - "frame": { - "x": 39, - "y": 150, - "w": 38, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 22,"w": 38,"h": 37}, + "frame": + {"x": 39,"y": 150,"w": 38,"h": 37} }, { "filename": "0048.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 39, - "h": 37 - }, - "frame": { - "x": 77, - "y": 186, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 186,"w": 39,"h": 37} }, { "filename": "0050.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 15, - "w": 39, - "h": 37 - }, - "frame": { - "x": 116, - "y": 186, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 15,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 186,"w": 39,"h": 37} }, { "filename": "0020.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 3, - "w": 40, - "h": 36 - }, - "frame": { - "x": 155, - "y": 222, - "w": 40, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 3,"w": 40,"h": 36}, + "frame": + {"x": 155,"y": 222,"w": 40,"h": 36} }, { "filename": "0043.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 21, - "w": 38, - "h": 37 - }, - "frame": { - "x": 195, - "y": 222, - "w": 38, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 21,"w": 38,"h": 37}, + "frame": + {"x": 195,"y": 222,"w": 38,"h": 37} }, { "filename": "0003.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 12, - "w": 39, - "h": 36 - }, - "frame": { - "x": 233, - "y": 224, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 12,"w": 39,"h": 36}, + "frame": + {"x": 233,"y": 224,"w": 39,"h": 36} }, { "filename": "0007.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 8, - "w": 39, - "h": 36 - }, - "frame": { - "x": 0, - "y": 187, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 39,"h": 36}, + "frame": + {"x": 0,"y": 187,"w": 39,"h": 36} }, { "filename": "0041.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 24, - "w": 38, - "h": 36 - }, - "frame": { - "x": 39, - "y": 187, - "w": 38, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 24,"w": 38,"h": 36}, + "frame": + {"x": 39,"y": 187,"w": 38,"h": 36} }, { "filename": "0015.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 36 - }, - "frame": { - "x": 0, - "y": 223, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 36}, + "frame": + {"x": 0,"y": 223,"w": 39,"h": 36} }, { "filename": "0016.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 36 - }, - "frame": { - "x": 39, - "y": 223, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 36}, + "frame": + {"x": 39,"y": 223,"w": 39,"h": 36} }, { "filename": "0023.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 5, - "w": 39, - "h": 36 - }, - "frame": { - "x": 78, - "y": 223, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 5,"w": 39,"h": 36}, + "frame": + {"x": 78,"y": 223,"w": 39,"h": 36} } ] } ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:923edc13fa89ac2437b1174c95d4ff5a:62260d5eb9ff1fb9aa2b993de070968b:0787168dbe37404ac3aa22b487979d47$" - } + "meta": + {"app": "https://www.codeandweb.com/texturepacker", + "version": "3.0"} } diff --git a/public/images/pokemon/exp/774-blue.png b/public/images/pokemon/exp/774-blue.png index 82b53ea3d81..5678427bf7c 100644 Binary files a/public/images/pokemon/exp/774-blue.png and b/public/images/pokemon/exp/774-blue.png differ diff --git a/public/images/pokemon/exp/774-green.json b/public/images/pokemon/exp/774-green.json index 8b1616d76a5..90220f4dd67 100644 --- a/public/images/pokemon/exp/774-green.json +++ b/public/images/pokemon/exp/774-green.json @@ -3,1992 +3,563 @@ { "image": "774-green.png", "format": "RGBA8888", - "size": { - "w": 264, - "h": 264 - }, + "size": {"w": 274, "h": 274}, "scale": 1, "frames": [ { - "filename": "0001.png", + "filename": "0013.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 65 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 65 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 2, - "y": 19, - "w": 40, - "h": 40 - }, - "frame": { - "x": 0, - "y": 65, - "w": 40, - "h": 40 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 2, - "y": 19, - "w": 40, - "h": 40 - }, - "frame": { - "x": 0, - "y": 65, - "w": 40, - "h": 40 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 21, - "w": 40, - "h": 40 - }, - "frame": { - "x": 64, - "y": 0, - "w": 40, - "h": 40 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 21, - "w": 40, - "h": 40 - }, - "frame": { - "x": 64, - "y": 0, - "w": 40, - "h": 40 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 21, - "w": 40, - "h": 40 - }, - "frame": { - "x": 0, - "y": 105, - "w": 40, - "h": 40 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 21, - "w": 40, - "h": 40 - }, - "frame": { - "x": 0, - "y": 105, - "w": 40, - "h": 40 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 2, - "y": 26, - "w": 40, - "h": 40 - }, - "frame": { - "x": 104, - "y": 0, - "w": 40, - "h": 40 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 2, - "y": 26, - "w": 40, - "h": 40 - }, - "frame": { - "x": 104, - "y": 0, - "w": 40, - "h": 40 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 2, - "y": 19, - "w": 40, - "h": 40 - }, - "frame": { - "x": 0, - "y": 145, - "w": 40, - "h": 40 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 2, - "y": 19, - "w": 40, - "h": 40 - }, - "frame": { - "x": 0, - "y": 145, - "w": 40, - "h": 40 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 21, - "w": 40, - "h": 40 - }, - "frame": { - "x": 144, - "y": 0, - "w": 40, - "h": 40 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 21, - "w": 40, - "h": 40 - }, - "frame": { - "x": 144, - "y": 0, - "w": 40, - "h": 40 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 1,"w": 39,"h": 38}, + "frame": + {"x": 0,"y": 0,"w": 39,"h": 38} }, { "filename": "0036.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 21, - "w": 40, - "h": 40 - }, - "frame": { - "x": 0, - "y": 185, - "w": 40, - "h": 40 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 21, - "w": 40, - "h": 40 - }, - "frame": { - "x": 0, - "y": 185, - "w": 40, - "h": 40 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 27, - "y": 31, - "w": 40, - "h": 39 - }, - "frame": { - "x": 0, - "y": 225, - "w": 40, - "h": 39 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 27, - "y": 31, - "w": 40, - "h": 39 - }, - "frame": { - "x": 0, - "y": 225, - "w": 40, - "h": 39 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 2, - "y": 26, - "w": 40, - "h": 40 - }, - "frame": { - "x": 184, - "y": 0, - "w": 40, - "h": 40 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 2, - "y": 26, - "w": 40, - "h": 40 - }, - "frame": { - "x": 184, - "y": 0, - "w": 40, - "h": 40 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 25, - "y": 28, - "w": 39, - "h": 38 - }, - "frame": { - "x": 224, - "y": 0, - "w": 39, - "h": 38 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 25, - "y": 28, - "w": 39, - "h": 38 - }, - "frame": { - "x": 224, - "y": 0, - "w": 39, - "h": 38 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 43, - "y": 28, - "w": 42, - "h": 36 - }, - "frame": { - "x": 64, - "y": 40, - "w": 42, - "h": 36 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 42, - "y": 31, - "w": 42, - "h": 36 - }, - "frame": { - "x": 106, - "y": 40, - "w": 42, - "h": 36 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 42, - "y": 31, - "w": 42, - "h": 36 - }, - "frame": { - "x": 106, - "y": 40, - "w": 42, - "h": 36 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 42, - "y": 31, - "w": 42, - "h": 36 - }, - "frame": { - "x": 106, - "y": 40, - "w": 42, - "h": 36 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 42, - "y": 31, - "w": 42, - "h": 36 - }, - "frame": { - "x": 106, - "y": 40, - "w": 42, - "h": 36 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 43, - "y": 28, - "w": 42, - "h": 36 - }, - "frame": { - "x": 148, - "y": 40, - "w": 42, - "h": 36 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 43, - "y": 28, - "w": 42, - "h": 36 - }, - "frame": { - "x": 148, - "y": 40, - "w": 42, - "h": 36 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 43, - "y": 28, - "w": 42, - "h": 36 - }, - "frame": { - "x": 148, - "y": 40, - "w": 42, - "h": 36 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 25, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 190, - "y": 40, - "w": 39, - "h": 37 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 25, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 190, - "y": 40, - "w": 39, - "h": 37 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 25, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 190, - "y": 40, - "w": 39, - "h": 37 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 25, - "y": 33, - "w": 42, - "h": 36 - }, - "frame": { - "x": 40, - "y": 76, - "w": 42, - "h": 36 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 25, - "y": 33, - "w": 42, - "h": 36 - }, - "frame": { - "x": 40, - "y": 76, - "w": 42, - "h": 36 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 44, - "y": 29, - "w": 41, - "h": 36 - }, - "frame": { - "x": 40, - "y": 112, - "w": 41, - "h": 36 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 44, - "y": 29, - "w": 41, - "h": 36 - }, - "frame": { - "x": 40, - "y": 112, - "w": 41, - "h": 36 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 44, - "y": 29, - "w": 41, - "h": 36 - }, - "frame": { - "x": 40, - "y": 112, - "w": 41, - "h": 36 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 44, - "y": 29, - "w": 41, - "h": 36 - }, - "frame": { - "x": 40, - "y": 112, - "w": 41, - "h": 36 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 44, - "y": 29, - "w": 41, - "h": 36 - }, - "frame": { - "x": 82, - "y": 76, - "w": 41, - "h": 36 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 44, - "y": 29, - "w": 41, - "h": 36 - }, - "frame": { - "x": 82, - "y": 76, - "w": 41, - "h": 36 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 44, - "y": 29, - "w": 41, - "h": 36 - }, - "frame": { - "x": 82, - "y": 76, - "w": 41, - "h": 36 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 44, - "y": 29, - "w": 41, - "h": 36 - }, - "frame": { - "x": 82, - "y": 76, - "w": 41, - "h": 36 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 38, - "y": 35, - "w": 42, - "h": 35 - }, - "frame": { - "x": 81, - "y": 112, - "w": 42, - "h": 35 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 38, - "y": 35, - "w": 42, - "h": 35 - }, - "frame": { - "x": 81, - "y": 112, - "w": 42, - "h": 35 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 14, - "y": 21, - "w": 39, - "h": 38 - }, - "frame": { - "x": 40, - "y": 148, - "w": 39, - "h": 38 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 7, - "y": 29, - "w": 39, - "h": 38 - }, - "frame": { - "x": 40, - "y": 148, - "w": 39, - "h": 38 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 14, - "y": 21, - "w": 39, - "h": 38 - }, - "frame": { - "x": 40, - "y": 148, - "w": 39, - "h": 38 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 7, - "y": 29, - "w": 39, - "h": 38 - }, - "frame": { - "x": 40, - "y": 148, - "w": 39, - "h": 38 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 7, - "y": 29, - "w": 39, - "h": 38 - }, - "frame": { - "x": 123, - "y": 76, - "w": 39, - "h": 38 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 14, - "y": 21, - "w": 39, - "h": 38 - }, - "frame": { - "x": 123, - "y": 76, - "w": 39, - "h": 38 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 7, - "y": 29, - "w": 39, - "h": 38 - }, - "frame": { - "x": 123, - "y": 76, - "w": 39, - "h": 38 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 14, - "y": 21, - "w": 39, - "h": 38 - }, - "frame": { - "x": 123, - "y": 76, - "w": 39, - "h": 38 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 25, - "y": 28, - "w": 39, - "h": 38 - }, - "frame": { - "x": 40, - "y": 186, - "w": 39, - "h": 38 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 25, - "y": 28, - "w": 39, - "h": 38 - }, - "frame": { - "x": 40, - "y": 186, - "w": 39, - "h": 38 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 25, - "y": 28, - "w": 39, - "h": 38 - }, - "frame": { - "x": 40, - "y": 224, - "w": 39, - "h": 38 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 25, - "y": 28, - "w": 39, - "h": 38 - }, - "frame": { - "x": 40, - "y": 224, - "w": 39, - "h": 38 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 26, - "y": 26, - "w": 39, - "h": 37 - }, - "frame": { - "x": 123, - "y": 114, - "w": 39, - "h": 37 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 26, - "y": 26, - "w": 39, - "h": 37 - }, - "frame": { - "x": 123, - "y": 114, - "w": 39, - "h": 37 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 38, - "y": 35, - "w": 42, - "h": 35 - }, - "frame": { - "x": 162, - "y": 77, - "w": 42, - "h": 35 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 38, - "y": 35, - "w": 42, - "h": 35 - }, - "frame": { - "x": 162, - "y": 77, - "w": 42, - "h": 35 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 30, - "y": 31, - "w": 39, - "h": 38 - }, - "frame": { - "x": 162, - "y": 112, - "w": 39, - "h": 38 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 35, - "y": 23, - "w": 39, - "h": 37 - }, - "frame": { - "x": 204, - "y": 77, - "w": 39, - "h": 37 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 35, - "y": 23, - "w": 39, - "h": 37 - }, - "frame": { - "x": 204, - "y": 77, - "w": 39, - "h": 37 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 31, - "y": 31, - "w": 39, - "h": 37 - }, - "frame": { - "x": 201, - "y": 114, - "w": 39, - "h": 37 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 31, - "y": 31, - "w": 39, - "h": 37 - }, - "frame": { - "x": 201, - "y": 114, - "w": 39, - "h": 37 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 29, - "y": 31, - "w": 39, - "h": 37 - }, - "frame": { - "x": 162, - "y": 150, - "w": 39, - "h": 37 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 29, - "y": 31, - "w": 39, - "h": 37 - }, - "frame": { - "x": 162, - "y": 150, - "w": 39, - "h": 37 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 29, - "y": 31, - "w": 39, - "h": 37 - }, - "frame": { - "x": 162, - "y": 150, - "w": 39, - "h": 37 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 21, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 201, - "y": 151, - "w": 39, - "h": 37 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 21, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 201, - "y": 151, - "w": 39, - "h": 37 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 21, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 81, - "y": 147, - "w": 39, - "h": 37 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 21, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 81, - "y": 147, - "w": 39, - "h": 37 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 25, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 79, - "y": 184, - "w": 39, - "h": 37 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 25, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 79, - "y": 184, - "w": 39, - "h": 37 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 26, - "y": 26, - "w": 39, - "h": 37 - }, - "frame": { - "x": 79, - "y": 221, - "w": 39, - "h": 37 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 26, - "y": 26, - "w": 39, - "h": 37 - }, - "frame": { - "x": 79, - "y": 221, - "w": 39, - "h": 37 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 35, - "y": 23, - "w": 39, - "h": 37 - }, - "frame": { - "x": 120, - "y": 151, - "w": 39, - "h": 37 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 35, - "y": 23, - "w": 39, - "h": 37 - }, - "frame": { - "x": 120, - "y": 151, - "w": 39, - "h": 37 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 31, - "y": 31, - "w": 39, - "h": 37 - }, - "frame": { - "x": 118, - "y": 188, - "w": 39, - "h": 37 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 31, - "y": 31, - "w": 39, - "h": 37 - }, - "frame": { - "x": 118, - "y": 188, - "w": 39, - "h": 37 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 21, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 118, - "y": 225, - "w": 39, - "h": 37 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 21, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 118, - "y": 225, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 18,"w": 39,"h": 38}, + "frame": + {"x": 39,"y": 0,"w": 39,"h": 38} }, { "filename": "0040.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 21, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 157, - "y": 188, - "w": 39, - "h": 37 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 21, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 157, - "y": 188, - "w": 39, - "h": 37 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 25, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 157, - "y": 225, - "w": 39, - "h": 37 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 25, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 157, - "y": 225, - "w": 39, - "h": 37 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 25, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 157, - "y": 225, - "w": 39, - "h": 37 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 25, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 157, - "y": 225, - "w": 39, - "h": 37 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 25, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 157, - "y": 225, - "w": 39, - "h": 37 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 25, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 157, - "y": 225, - "w": 39, - "h": 37 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 25, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 157, - "y": 225, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 22,"w": 39,"h": 38}, + "frame": + {"x": 78,"y": 0,"w": 39,"h": 38} }, { "filename": "0044.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 25, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 196, - "y": 188, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 20,"w": 39,"h": 38}, + "frame": + {"x": 117,"y": 0,"w": 39,"h": 38} }, { - "filename": "0094.png", + "filename": "0006.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 25, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 196, - "y": 188, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 40,"h": 37}, + "frame": + {"x": 156,"y": 0,"w": 40,"h": 37} }, { - "filename": "0088.png", + "filename": "0010.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 85, - "h": 70 - }, - "spriteSourceSize": { - "x": 25, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 196, - "y": 225, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 4,"w": 40,"h": 37}, + "frame": + {"x": 196,"y": 0,"w": 40,"h": 37} + }, + { + "filename": "0035.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 38,"h": 38}, + "frame": + {"x": 236,"y": 0,"w": 38,"h": 38} + }, + { + "filename": "0018.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 0,"w": 40,"h": 37}, + "frame": + {"x": 156,"y": 37,"w": 40,"h": 37} + }, + { + "filename": "0021.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 3,"w": 40,"h": 37}, + "frame": + {"x": 196,"y": 37,"w": 40,"h": 37} + }, + { + "filename": "0039.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 21,"w": 38,"h": 38}, + "frame": + {"x": 236,"y": 38,"w": 38,"h": 38} + }, + { + "filename": "0024.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 6,"w": 40,"h": 37}, + "frame": + {"x": 0,"y": 38,"w": 40,"h": 37} + }, + { + "filename": "0045.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 18,"w": 38,"h": 38}, + "frame": + {"x": 40,"y": 38,"w": 38,"h": 38} + }, + { + "filename": "0047.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 38,"h": 38}, + "frame": + {"x": 0,"y": 75,"w": 38,"h": 38} + }, + { + "filename": "0001.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 38,"w": 39,"h": 37} + }, + { + "filename": "0002.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 13,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 38,"w": 39,"h": 37} + }, + { + "filename": "0004.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 11,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 38,"w": 39,"h": 37} + }, + { + "filename": "0049.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 16,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 38,"w": 39,"h": 37} + }, + { + "filename": "0005.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 156,"y": 74,"w": 39,"h": 37} + }, + { + "filename": "0008.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 7,"w": 39,"h": 37}, + "frame": + {"x": 195,"y": 74,"w": 39,"h": 37} + }, + { + "filename": "0009.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 5,"w": 39,"h": 37}, + "frame": + {"x": 234,"y": 76,"w": 39,"h": 37} + }, + { + "filename": "0011.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 3,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 75,"w": 39,"h": 37} + }, + { + "filename": "0012.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 75,"w": 39,"h": 37} + }, + { + "filename": "0014.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 37}, + "frame": + {"x": 38,"y": 76,"w": 39,"h": 37} + }, + { + "filename": "0017.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 37}, + "frame": + {"x": 156,"y": 111,"w": 39,"h": 37} + }, + { + "filename": "0019.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 1,"w": 39,"h": 37}, + "frame": + {"x": 195,"y": 111,"w": 39,"h": 37} + }, + { + "filename": "0022.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 4,"w": 39,"h": 37}, + "frame": + {"x": 234,"y": 113,"w": 39,"h": 37} + }, + { + "filename": "0025.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 7,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 112,"w": 39,"h": 37} + }, + { + "filename": "0026.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 112,"w": 39,"h": 37} + }, + { + "filename": "0027.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 155,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0028.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 194,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0029.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 11,"w": 39,"h": 37}, + "frame": + {"x": 233,"y": 150,"w": 39,"h": 37} + }, + { + "filename": "0030.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 12,"w": 39,"h": 37}, + "frame": + {"x": 0,"y": 113,"w": 39,"h": 37} + }, + { + "filename": "0038.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 21,"w": 38,"h": 37}, + "frame": + {"x": 39,"y": 113,"w": 38,"h": 37} + }, + { + "filename": "0031.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 149,"w": 39,"h": 37} + }, + { + "filename": "0032.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 149,"w": 39,"h": 37} + }, + { + "filename": "0033.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 15,"w": 39,"h": 37}, + "frame": + {"x": 155,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0034.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 17,"w": 39,"h": 37}, + "frame": + {"x": 194,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0037.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 20,"w": 39,"h": 37}, + "frame": + {"x": 233,"y": 187,"w": 39,"h": 37} + }, + { + "filename": "0046.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 18,"w": 39,"h": 37}, + "frame": + {"x": 0,"y": 150,"w": 39,"h": 37} + }, + { + "filename": "0042.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 22,"w": 38,"h": 37}, + "frame": + {"x": 39,"y": 150,"w": 38,"h": 37} + }, + { + "filename": "0048.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 186,"w": 39,"h": 37} + }, + { + "filename": "0050.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 15,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 186,"w": 39,"h": 37} + }, + { + "filename": "0020.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 3,"w": 40,"h": 36}, + "frame": + {"x": 155,"y": 222,"w": 40,"h": 36} + }, + { + "filename": "0043.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 21,"w": 38,"h": 37}, + "frame": + {"x": 195,"y": 222,"w": 38,"h": 37} + }, + { + "filename": "0003.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 12,"w": 39,"h": 36}, + "frame": + {"x": 233,"y": 224,"w": 39,"h": 36} + }, + { + "filename": "0007.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 39,"h": 36}, + "frame": + {"x": 0,"y": 187,"w": 39,"h": 36} + }, + { + "filename": "0041.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 24,"w": 38,"h": 36}, + "frame": + {"x": 39,"y": 187,"w": 38,"h": 36} + }, + { + "filename": "0015.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 36}, + "frame": + {"x": 0,"y": 223,"w": 39,"h": 36} + }, + { + "filename": "0016.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 36}, + "frame": + {"x": 39,"y": 223,"w": 39,"h": 36} + }, + { + "filename": "0023.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 5,"w": 39,"h": 36}, + "frame": + {"x": 78,"y": 223,"w": 39,"h": 36} } ] } ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:ca4a3f0c0275176768e1866694bbf83b:0a0ab1a8d37c5a421e16540ffc516219:e4b1fffb78b8c0cdc557670bcee043ca$" - } + "meta": + {"app": "https://www.codeandweb.com/texturepacker", + "version": "3.0"} } diff --git a/public/images/pokemon/exp/774-green.png b/public/images/pokemon/exp/774-green.png index 93e6dd85e5c..e09fdab20c2 100644 Binary files a/public/images/pokemon/exp/774-green.png and b/public/images/pokemon/exp/774-green.png differ diff --git a/public/images/pokemon/exp/774-indigo.json b/public/images/pokemon/exp/774-indigo.json index dd002b831f6..d54b0a91175 100644 --- a/public/images/pokemon/exp/774-indigo.json +++ b/public/images/pokemon/exp/774-indigo.json @@ -3,1068 +3,563 @@ { "image": "774-indigo.png", "format": "RGBA8888", - "size": { - "w": 274, - "h": 274 - }, + "size": {"w": 274, "h": 274}, "scale": 1, "frames": [ { "filename": "0013.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 1, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 1,"w": 39,"h": 38}, + "frame": + {"x": 0,"y": 0,"w": 39,"h": 38} }, { "filename": "0036.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 18, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 18,"w": 39,"h": 38}, + "frame": + {"x": 39,"y": 0,"w": 39,"h": 38} }, { "filename": "0040.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 22, - "w": 39, - "h": 38 - }, - "frame": { - "x": 78, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 22,"w": 39,"h": 38}, + "frame": + {"x": 78,"y": 0,"w": 39,"h": 38} }, { "filename": "0044.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 20, - "w": 39, - "h": 38 - }, - "frame": { - "x": 117, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 20,"w": 39,"h": 38}, + "frame": + {"x": 117,"y": 0,"w": 39,"h": 38} }, { "filename": "0006.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 8, - "w": 40, - "h": 37 - }, - "frame": { - "x": 156, - "y": 0, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 40,"h": 37}, + "frame": + {"x": 156,"y": 0,"w": 40,"h": 37} }, { "filename": "0010.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 4, - "w": 40, - "h": 37 - }, - "frame": { - "x": 196, - "y": 0, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 4,"w": 40,"h": 37}, + "frame": + {"x": 196,"y": 0,"w": 40,"h": 37} }, { "filename": "0035.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 38, - "h": 38 - }, - "frame": { - "x": 236, - "y": 0, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 38,"h": 38}, + "frame": + {"x": 236,"y": 0,"w": 38,"h": 38} }, { "filename": "0018.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 40, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 0,"w": 40,"h": 37}, + "frame": + {"x": 156,"y": 37,"w": 40,"h": 37} }, { "filename": "0021.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 3, - "w": 40, - "h": 37 - }, - "frame": { - "x": 196, - "y": 37, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 3,"w": 40,"h": 37}, + "frame": + {"x": 196,"y": 37,"w": 40,"h": 37} }, { "filename": "0039.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 21, - "w": 38, - "h": 38 - }, - "frame": { - "x": 236, - "y": 38, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 21,"w": 38,"h": 38}, + "frame": + {"x": 236,"y": 38,"w": 38,"h": 38} }, { "filename": "0024.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 6, - "w": 40, - "h": 37 - }, - "frame": { - "x": 0, - "y": 38, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 6,"w": 40,"h": 37}, + "frame": + {"x": 0,"y": 38,"w": 40,"h": 37} }, { "filename": "0045.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 38, - "h": 38 - }, - "frame": { - "x": 40, - "y": 38, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 18,"w": 38,"h": 38}, + "frame": + {"x": 40,"y": 38,"w": 38,"h": 38} }, { "filename": "0047.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 38, - "h": 38 - }, - "frame": { - "x": 0, - "y": 75, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 38,"h": 38}, + "frame": + {"x": 0,"y": 75,"w": 38,"h": 38} }, { "filename": "0001.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 14, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 38,"w": 39,"h": 37} }, { "filename": "0002.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 13, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 13,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 38,"w": 39,"h": 37} }, { "filename": "0004.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 11,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 38,"w": 39,"h": 37} }, { "filename": "0049.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 16, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 16,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 38,"w": 39,"h": 37} }, { "filename": "0005.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 156,"y": 74,"w": 39,"h": 37} }, { "filename": "0008.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 7,"w": 39,"h": 37}, + "frame": + {"x": 195,"y": 74,"w": 39,"h": 37} }, { "filename": "0009.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 5, - "w": 39, - "h": 37 - }, - "frame": { - "x": 234, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 5,"w": 39,"h": 37}, + "frame": + {"x": 234,"y": 76,"w": 39,"h": 37} }, { "filename": "0011.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 3, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 75, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 3,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 75,"w": 39,"h": 37} }, { "filename": "0012.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 75, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 75,"w": 39,"h": 37} }, { "filename": "0014.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 37 - }, - "frame": { - "x": 38, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 37}, + "frame": + {"x": 38,"y": 76,"w": 39,"h": 37} }, { "filename": "0017.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 37}, + "frame": + {"x": 156,"y": 111,"w": 39,"h": 37} }, { "filename": "0019.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 1, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 1,"w": 39,"h": 37}, + "frame": + {"x": 195,"y": 111,"w": 39,"h": 37} }, { "filename": "0022.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 4, - "w": 39, - "h": 37 - }, - "frame": { - "x": 234, - "y": 113, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 4,"w": 39,"h": 37}, + "frame": + {"x": 234,"y": 113,"w": 39,"h": 37} }, { "filename": "0025.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 77, - "y": 112, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 7,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 112,"w": 39,"h": 37} }, { "filename": "0026.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 116, - "y": 112, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 112,"w": 39,"h": 37} }, { "filename": "0027.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 155, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 155,"y": 148,"w": 39,"h": 37} }, { "filename": "0028.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 194, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 194,"y": 148,"w": 39,"h": 37} }, { "filename": "0029.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 233, - "y": 150, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 11,"w": 39,"h": 37}, + "frame": + {"x": 233,"y": 150,"w": 39,"h": 37} }, { "filename": "0030.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 12, - "w": 39, - "h": 37 - }, - "frame": { - "x": 0, - "y": 113, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 12,"w": 39,"h": 37}, + "frame": + {"x": 0,"y": 113,"w": 39,"h": 37} }, { "filename": "0038.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 21, - "w": 38, - "h": 37 - }, - "frame": { - "x": 39, - "y": 113, - "w": 38, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 21,"w": 38,"h": 37}, + "frame": + {"x": 39,"y": 113,"w": 38,"h": 37} }, { "filename": "0031.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 14, - "w": 39, - "h": 37 - }, - "frame": { - "x": 77, - "y": 149, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 149,"w": 39,"h": 37} }, { "filename": "0032.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 14, - "w": 39, - "h": 37 - }, - "frame": { - "x": 116, - "y": 149, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 149,"w": 39,"h": 37} }, { "filename": "0033.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 15, - "w": 39, - "h": 37 - }, - "frame": { - "x": 155, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 15,"w": 39,"h": 37}, + "frame": + {"x": 155,"y": 185,"w": 39,"h": 37} }, { "filename": "0034.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 17, - "w": 39, - "h": 37 - }, - "frame": { - "x": 194, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 17,"w": 39,"h": 37}, + "frame": + {"x": 194,"y": 185,"w": 39,"h": 37} }, { "filename": "0037.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 20, - "w": 39, - "h": 37 - }, - "frame": { - "x": 233, - "y": 187, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 20,"w": 39,"h": 37}, + "frame": + {"x": 233,"y": 187,"w": 39,"h": 37} }, { "filename": "0046.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 39, - "h": 37 - }, - "frame": { - "x": 0, - "y": 150, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 18,"w": 39,"h": 37}, + "frame": + {"x": 0,"y": 150,"w": 39,"h": 37} }, { "filename": "0042.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 22, - "w": 38, - "h": 37 - }, - "frame": { - "x": 39, - "y": 150, - "w": 38, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 22,"w": 38,"h": 37}, + "frame": + {"x": 39,"y": 150,"w": 38,"h": 37} }, { "filename": "0048.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 39, - "h": 37 - }, - "frame": { - "x": 77, - "y": 186, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 186,"w": 39,"h": 37} }, { "filename": "0050.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 15, - "w": 39, - "h": 37 - }, - "frame": { - "x": 116, - "y": 186, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 15,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 186,"w": 39,"h": 37} }, { "filename": "0020.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 3, - "w": 40, - "h": 36 - }, - "frame": { - "x": 155, - "y": 222, - "w": 40, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 3,"w": 40,"h": 36}, + "frame": + {"x": 155,"y": 222,"w": 40,"h": 36} }, { "filename": "0043.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 21, - "w": 38, - "h": 37 - }, - "frame": { - "x": 195, - "y": 222, - "w": 38, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 21,"w": 38,"h": 37}, + "frame": + {"x": 195,"y": 222,"w": 38,"h": 37} }, { "filename": "0003.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 12, - "w": 39, - "h": 36 - }, - "frame": { - "x": 233, - "y": 224, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 12,"w": 39,"h": 36}, + "frame": + {"x": 233,"y": 224,"w": 39,"h": 36} }, { "filename": "0007.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 8, - "w": 39, - "h": 36 - }, - "frame": { - "x": 0, - "y": 187, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 39,"h": 36}, + "frame": + {"x": 0,"y": 187,"w": 39,"h": 36} }, { "filename": "0041.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 24, - "w": 38, - "h": 36 - }, - "frame": { - "x": 39, - "y": 187, - "w": 38, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 24,"w": 38,"h": 36}, + "frame": + {"x": 39,"y": 187,"w": 38,"h": 36} }, { "filename": "0015.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 36 - }, - "frame": { - "x": 0, - "y": 223, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 36}, + "frame": + {"x": 0,"y": 223,"w": 39,"h": 36} }, { "filename": "0016.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 36 - }, - "frame": { - "x": 39, - "y": 223, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 36}, + "frame": + {"x": 39,"y": 223,"w": 39,"h": 36} }, { "filename": "0023.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 5, - "w": 39, - "h": 36 - }, - "frame": { - "x": 78, - "y": 223, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 5,"w": 39,"h": 36}, + "frame": + {"x": 78,"y": 223,"w": 39,"h": 36} } ] } ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:f315d1bc69bb4d0d853aae0e9386da77:eaad56c1320913dd19370508918d9cfd:f6d3104f6cc09a16e2cbfcba30e4d78a$" - } + "meta": + {"app": "https://www.codeandweb.com/texturepacker", + "version": "3.0"} } diff --git a/public/images/pokemon/exp/774-indigo.png b/public/images/pokemon/exp/774-indigo.png index f378b828450..ad750e0f000 100644 Binary files a/public/images/pokemon/exp/774-indigo.png and b/public/images/pokemon/exp/774-indigo.png differ diff --git a/public/images/pokemon/exp/774-orange.json b/public/images/pokemon/exp/774-orange.json index 281c5b1e06f..77e0908b690 100644 --- a/public/images/pokemon/exp/774-orange.json +++ b/public/images/pokemon/exp/774-orange.json @@ -3,1068 +3,563 @@ { "image": "774-orange.png", "format": "RGBA8888", - "size": { - "w": 274, - "h": 274 - }, + "size": {"w": 274, "h": 274}, "scale": 1, "frames": [ { "filename": "0013.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 1, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 1,"w": 39,"h": 38}, + "frame": + {"x": 0,"y": 0,"w": 39,"h": 38} }, { "filename": "0036.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 18, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 18,"w": 39,"h": 38}, + "frame": + {"x": 39,"y": 0,"w": 39,"h": 38} }, { "filename": "0040.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 22, - "w": 39, - "h": 38 - }, - "frame": { - "x": 78, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 22,"w": 39,"h": 38}, + "frame": + {"x": 78,"y": 0,"w": 39,"h": 38} }, { "filename": "0044.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 20, - "w": 39, - "h": 38 - }, - "frame": { - "x": 117, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 20,"w": 39,"h": 38}, + "frame": + {"x": 117,"y": 0,"w": 39,"h": 38} }, { "filename": "0006.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 8, - "w": 40, - "h": 37 - }, - "frame": { - "x": 156, - "y": 0, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 40,"h": 37}, + "frame": + {"x": 156,"y": 0,"w": 40,"h": 37} }, { "filename": "0010.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 4, - "w": 40, - "h": 37 - }, - "frame": { - "x": 196, - "y": 0, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 4,"w": 40,"h": 37}, + "frame": + {"x": 196,"y": 0,"w": 40,"h": 37} }, { "filename": "0035.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 38, - "h": 38 - }, - "frame": { - "x": 236, - "y": 0, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 38,"h": 38}, + "frame": + {"x": 236,"y": 0,"w": 38,"h": 38} }, { "filename": "0018.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 40, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 0,"w": 40,"h": 37}, + "frame": + {"x": 156,"y": 37,"w": 40,"h": 37} }, { "filename": "0021.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 3, - "w": 40, - "h": 37 - }, - "frame": { - "x": 196, - "y": 37, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 3,"w": 40,"h": 37}, + "frame": + {"x": 196,"y": 37,"w": 40,"h": 37} }, { "filename": "0039.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 21, - "w": 38, - "h": 38 - }, - "frame": { - "x": 236, - "y": 38, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 21,"w": 38,"h": 38}, + "frame": + {"x": 236,"y": 38,"w": 38,"h": 38} }, { "filename": "0024.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 6, - "w": 40, - "h": 37 - }, - "frame": { - "x": 0, - "y": 38, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 6,"w": 40,"h": 37}, + "frame": + {"x": 0,"y": 38,"w": 40,"h": 37} }, { "filename": "0045.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 38, - "h": 38 - }, - "frame": { - "x": 40, - "y": 38, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 18,"w": 38,"h": 38}, + "frame": + {"x": 40,"y": 38,"w": 38,"h": 38} }, { "filename": "0047.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 38, - "h": 38 - }, - "frame": { - "x": 0, - "y": 75, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 38,"h": 38}, + "frame": + {"x": 0,"y": 75,"w": 38,"h": 38} }, { "filename": "0001.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 14, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 38,"w": 39,"h": 37} }, { "filename": "0002.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 13, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 13,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 38,"w": 39,"h": 37} }, { "filename": "0004.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 11,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 38,"w": 39,"h": 37} }, { "filename": "0049.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 16, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 16,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 38,"w": 39,"h": 37} }, { "filename": "0005.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 156,"y": 74,"w": 39,"h": 37} }, { "filename": "0008.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 7,"w": 39,"h": 37}, + "frame": + {"x": 195,"y": 74,"w": 39,"h": 37} }, { "filename": "0009.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 5, - "w": 39, - "h": 37 - }, - "frame": { - "x": 234, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 5,"w": 39,"h": 37}, + "frame": + {"x": 234,"y": 76,"w": 39,"h": 37} }, { "filename": "0011.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 3, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 75, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 3,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 75,"w": 39,"h": 37} }, { "filename": "0012.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 75, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 75,"w": 39,"h": 37} }, { "filename": "0014.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 37 - }, - "frame": { - "x": 38, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 37}, + "frame": + {"x": 38,"y": 76,"w": 39,"h": 37} }, { "filename": "0017.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 37}, + "frame": + {"x": 156,"y": 111,"w": 39,"h": 37} }, { "filename": "0019.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 1, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 1,"w": 39,"h": 37}, + "frame": + {"x": 195,"y": 111,"w": 39,"h": 37} }, { "filename": "0022.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 4, - "w": 39, - "h": 37 - }, - "frame": { - "x": 234, - "y": 113, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 4,"w": 39,"h": 37}, + "frame": + {"x": 234,"y": 113,"w": 39,"h": 37} }, { "filename": "0025.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 77, - "y": 112, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 7,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 112,"w": 39,"h": 37} }, { "filename": "0026.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 116, - "y": 112, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 112,"w": 39,"h": 37} }, { "filename": "0027.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 155, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 155,"y": 148,"w": 39,"h": 37} }, { "filename": "0028.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 194, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 194,"y": 148,"w": 39,"h": 37} }, { "filename": "0029.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 233, - "y": 150, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 11,"w": 39,"h": 37}, + "frame": + {"x": 233,"y": 150,"w": 39,"h": 37} }, { "filename": "0030.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 12, - "w": 39, - "h": 37 - }, - "frame": { - "x": 0, - "y": 113, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 12,"w": 39,"h": 37}, + "frame": + {"x": 0,"y": 113,"w": 39,"h": 37} }, { "filename": "0038.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 21, - "w": 38, - "h": 37 - }, - "frame": { - "x": 39, - "y": 113, - "w": 38, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 21,"w": 38,"h": 37}, + "frame": + {"x": 39,"y": 113,"w": 38,"h": 37} }, { "filename": "0031.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 14, - "w": 39, - "h": 37 - }, - "frame": { - "x": 77, - "y": 149, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 149,"w": 39,"h": 37} }, { "filename": "0032.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 14, - "w": 39, - "h": 37 - }, - "frame": { - "x": 116, - "y": 149, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 149,"w": 39,"h": 37} }, { "filename": "0033.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 15, - "w": 39, - "h": 37 - }, - "frame": { - "x": 155, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 15,"w": 39,"h": 37}, + "frame": + {"x": 155,"y": 185,"w": 39,"h": 37} }, { "filename": "0034.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 17, - "w": 39, - "h": 37 - }, - "frame": { - "x": 194, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 17,"w": 39,"h": 37}, + "frame": + {"x": 194,"y": 185,"w": 39,"h": 37} }, { "filename": "0037.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 20, - "w": 39, - "h": 37 - }, - "frame": { - "x": 233, - "y": 187, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 20,"w": 39,"h": 37}, + "frame": + {"x": 233,"y": 187,"w": 39,"h": 37} }, { "filename": "0046.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 39, - "h": 37 - }, - "frame": { - "x": 0, - "y": 150, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 18,"w": 39,"h": 37}, + "frame": + {"x": 0,"y": 150,"w": 39,"h": 37} }, { "filename": "0042.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 22, - "w": 38, - "h": 37 - }, - "frame": { - "x": 39, - "y": 150, - "w": 38, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 22,"w": 38,"h": 37}, + "frame": + {"x": 39,"y": 150,"w": 38,"h": 37} }, { "filename": "0048.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 39, - "h": 37 - }, - "frame": { - "x": 77, - "y": 186, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 186,"w": 39,"h": 37} }, { "filename": "0050.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 15, - "w": 39, - "h": 37 - }, - "frame": { - "x": 116, - "y": 186, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 15,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 186,"w": 39,"h": 37} }, { "filename": "0020.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 3, - "w": 40, - "h": 36 - }, - "frame": { - "x": 155, - "y": 222, - "w": 40, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 3,"w": 40,"h": 36}, + "frame": + {"x": 155,"y": 222,"w": 40,"h": 36} }, { "filename": "0043.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 21, - "w": 38, - "h": 37 - }, - "frame": { - "x": 195, - "y": 222, - "w": 38, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 21,"w": 38,"h": 37}, + "frame": + {"x": 195,"y": 222,"w": 38,"h": 37} }, { "filename": "0003.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 12, - "w": 39, - "h": 36 - }, - "frame": { - "x": 233, - "y": 224, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 12,"w": 39,"h": 36}, + "frame": + {"x": 233,"y": 224,"w": 39,"h": 36} }, { "filename": "0007.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 8, - "w": 39, - "h": 36 - }, - "frame": { - "x": 0, - "y": 187, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 39,"h": 36}, + "frame": + {"x": 0,"y": 187,"w": 39,"h": 36} }, { "filename": "0041.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 24, - "w": 38, - "h": 36 - }, - "frame": { - "x": 39, - "y": 187, - "w": 38, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 24,"w": 38,"h": 36}, + "frame": + {"x": 39,"y": 187,"w": 38,"h": 36} }, { "filename": "0015.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 36 - }, - "frame": { - "x": 0, - "y": 223, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 36}, + "frame": + {"x": 0,"y": 223,"w": 39,"h": 36} }, { "filename": "0016.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 36 - }, - "frame": { - "x": 39, - "y": 223, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 36}, + "frame": + {"x": 39,"y": 223,"w": 39,"h": 36} }, { "filename": "0023.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 5, - "w": 39, - "h": 36 - }, - "frame": { - "x": 78, - "y": 223, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 5,"w": 39,"h": 36}, + "frame": + {"x": 78,"y": 223,"w": 39,"h": 36} } ] } ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:829616b78f2873e1d1af8ed98b4b667f:8224eff22fdf2c2099b58405e40be55d:44d5ed9bf64302a0edf6c65ea8033c12$" - } + "meta": + {"app": "https://www.codeandweb.com/texturepacker", + "version": "3.0"} } diff --git a/public/images/pokemon/exp/774-orange.png b/public/images/pokemon/exp/774-orange.png index a1b7a79afb7..134ae52d05a 100644 Binary files a/public/images/pokemon/exp/774-orange.png and b/public/images/pokemon/exp/774-orange.png differ diff --git a/public/images/pokemon/exp/774-red.json b/public/images/pokemon/exp/774-red.json index 9092682ff6c..bba5c5e837f 100644 --- a/public/images/pokemon/exp/774-red.json +++ b/public/images/pokemon/exp/774-red.json @@ -3,1068 +3,563 @@ { "image": "774-red.png", "format": "RGBA8888", - "size": { - "w": 274, - "h": 274 - }, + "size": {"w": 274, "h": 274}, "scale": 1, "frames": [ { "filename": "0013.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 1, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 1,"w": 39,"h": 38}, + "frame": + {"x": 0,"y": 0,"w": 39,"h": 38} }, { "filename": "0036.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 18, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 18,"w": 39,"h": 38}, + "frame": + {"x": 39,"y": 0,"w": 39,"h": 38} }, { "filename": "0040.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 22, - "w": 39, - "h": 38 - }, - "frame": { - "x": 78, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 22,"w": 39,"h": 38}, + "frame": + {"x": 78,"y": 0,"w": 39,"h": 38} }, { "filename": "0044.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 20, - "w": 39, - "h": 38 - }, - "frame": { - "x": 117, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 20,"w": 39,"h": 38}, + "frame": + {"x": 117,"y": 0,"w": 39,"h": 38} }, { "filename": "0006.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 8, - "w": 40, - "h": 37 - }, - "frame": { - "x": 156, - "y": 0, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 40,"h": 37}, + "frame": + {"x": 156,"y": 0,"w": 40,"h": 37} }, { "filename": "0010.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 4, - "w": 40, - "h": 37 - }, - "frame": { - "x": 196, - "y": 0, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 4,"w": 40,"h": 37}, + "frame": + {"x": 196,"y": 0,"w": 40,"h": 37} }, { "filename": "0035.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 38, - "h": 38 - }, - "frame": { - "x": 236, - "y": 0, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 38,"h": 38}, + "frame": + {"x": 236,"y": 0,"w": 38,"h": 38} }, { "filename": "0018.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 40, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 0,"w": 40,"h": 37}, + "frame": + {"x": 156,"y": 37,"w": 40,"h": 37} }, { "filename": "0021.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 3, - "w": 40, - "h": 37 - }, - "frame": { - "x": 196, - "y": 37, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 3,"w": 40,"h": 37}, + "frame": + {"x": 196,"y": 37,"w": 40,"h": 37} }, { "filename": "0039.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 21, - "w": 38, - "h": 38 - }, - "frame": { - "x": 236, - "y": 38, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 21,"w": 38,"h": 38}, + "frame": + {"x": 236,"y": 38,"w": 38,"h": 38} }, { "filename": "0024.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 6, - "w": 40, - "h": 37 - }, - "frame": { - "x": 0, - "y": 38, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 6,"w": 40,"h": 37}, + "frame": + {"x": 0,"y": 38,"w": 40,"h": 37} }, { "filename": "0045.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 38, - "h": 38 - }, - "frame": { - "x": 40, - "y": 38, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 18,"w": 38,"h": 38}, + "frame": + {"x": 40,"y": 38,"w": 38,"h": 38} }, { "filename": "0047.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 38, - "h": 38 - }, - "frame": { - "x": 0, - "y": 75, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 38,"h": 38}, + "frame": + {"x": 0,"y": 75,"w": 38,"h": 38} }, { "filename": "0001.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 14, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 38,"w": 39,"h": 37} }, { "filename": "0002.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 13, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 13,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 38,"w": 39,"h": 37} }, { "filename": "0004.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 11,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 38,"w": 39,"h": 37} }, { "filename": "0049.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 16, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 16,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 38,"w": 39,"h": 37} }, { "filename": "0005.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 156,"y": 74,"w": 39,"h": 37} }, { "filename": "0008.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 7,"w": 39,"h": 37}, + "frame": + {"x": 195,"y": 74,"w": 39,"h": 37} }, { "filename": "0009.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 5, - "w": 39, - "h": 37 - }, - "frame": { - "x": 234, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 5,"w": 39,"h": 37}, + "frame": + {"x": 234,"y": 76,"w": 39,"h": 37} }, { "filename": "0011.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 3, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 75, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 3,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 75,"w": 39,"h": 37} }, { "filename": "0012.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 75, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 75,"w": 39,"h": 37} }, { "filename": "0014.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 37 - }, - "frame": { - "x": 38, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 37}, + "frame": + {"x": 38,"y": 76,"w": 39,"h": 37} }, { "filename": "0017.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 37}, + "frame": + {"x": 156,"y": 111,"w": 39,"h": 37} }, { "filename": "0019.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 1, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 1,"w": 39,"h": 37}, + "frame": + {"x": 195,"y": 111,"w": 39,"h": 37} }, { "filename": "0022.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 4, - "w": 39, - "h": 37 - }, - "frame": { - "x": 234, - "y": 113, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 4,"w": 39,"h": 37}, + "frame": + {"x": 234,"y": 113,"w": 39,"h": 37} }, { "filename": "0025.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 77, - "y": 112, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 7,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 112,"w": 39,"h": 37} }, { "filename": "0026.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 116, - "y": 112, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 112,"w": 39,"h": 37} }, { "filename": "0027.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 155, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 155,"y": 148,"w": 39,"h": 37} }, { "filename": "0028.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 194, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 194,"y": 148,"w": 39,"h": 37} }, { "filename": "0029.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 233, - "y": 150, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 11,"w": 39,"h": 37}, + "frame": + {"x": 233,"y": 150,"w": 39,"h": 37} }, { "filename": "0030.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 12, - "w": 39, - "h": 37 - }, - "frame": { - "x": 0, - "y": 113, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 12,"w": 39,"h": 37}, + "frame": + {"x": 0,"y": 113,"w": 39,"h": 37} }, { "filename": "0038.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 21, - "w": 38, - "h": 37 - }, - "frame": { - "x": 39, - "y": 113, - "w": 38, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 21,"w": 38,"h": 37}, + "frame": + {"x": 39,"y": 113,"w": 38,"h": 37} }, { "filename": "0031.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 14, - "w": 39, - "h": 37 - }, - "frame": { - "x": 77, - "y": 149, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 149,"w": 39,"h": 37} }, { "filename": "0032.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 14, - "w": 39, - "h": 37 - }, - "frame": { - "x": 116, - "y": 149, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 149,"w": 39,"h": 37} }, { "filename": "0033.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 15, - "w": 39, - "h": 37 - }, - "frame": { - "x": 155, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 15,"w": 39,"h": 37}, + "frame": + {"x": 155,"y": 185,"w": 39,"h": 37} }, { "filename": "0034.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 17, - "w": 39, - "h": 37 - }, - "frame": { - "x": 194, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 17,"w": 39,"h": 37}, + "frame": + {"x": 194,"y": 185,"w": 39,"h": 37} }, { "filename": "0037.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 20, - "w": 39, - "h": 37 - }, - "frame": { - "x": 233, - "y": 187, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 20,"w": 39,"h": 37}, + "frame": + {"x": 233,"y": 187,"w": 39,"h": 37} }, { "filename": "0046.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 39, - "h": 37 - }, - "frame": { - "x": 0, - "y": 150, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 18,"w": 39,"h": 37}, + "frame": + {"x": 0,"y": 150,"w": 39,"h": 37} }, { "filename": "0042.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 22, - "w": 38, - "h": 37 - }, - "frame": { - "x": 39, - "y": 150, - "w": 38, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 22,"w": 38,"h": 37}, + "frame": + {"x": 39,"y": 150,"w": 38,"h": 37} }, { "filename": "0048.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 39, - "h": 37 - }, - "frame": { - "x": 77, - "y": 186, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 186,"w": 39,"h": 37} }, { "filename": "0050.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 15, - "w": 39, - "h": 37 - }, - "frame": { - "x": 116, - "y": 186, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 15,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 186,"w": 39,"h": 37} }, { "filename": "0020.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 3, - "w": 40, - "h": 36 - }, - "frame": { - "x": 155, - "y": 222, - "w": 40, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 3,"w": 40,"h": 36}, + "frame": + {"x": 155,"y": 222,"w": 40,"h": 36} }, { "filename": "0043.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 21, - "w": 38, - "h": 37 - }, - "frame": { - "x": 195, - "y": 222, - "w": 38, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 21,"w": 38,"h": 37}, + "frame": + {"x": 195,"y": 222,"w": 38,"h": 37} }, { "filename": "0003.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 12, - "w": 39, - "h": 36 - }, - "frame": { - "x": 233, - "y": 224, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 12,"w": 39,"h": 36}, + "frame": + {"x": 233,"y": 224,"w": 39,"h": 36} }, { "filename": "0007.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 8, - "w": 39, - "h": 36 - }, - "frame": { - "x": 0, - "y": 187, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 39,"h": 36}, + "frame": + {"x": 0,"y": 187,"w": 39,"h": 36} }, { "filename": "0041.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 24, - "w": 38, - "h": 36 - }, - "frame": { - "x": 39, - "y": 187, - "w": 38, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 24,"w": 38,"h": 36}, + "frame": + {"x": 39,"y": 187,"w": 38,"h": 36} }, { "filename": "0015.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 36 - }, - "frame": { - "x": 0, - "y": 223, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 36}, + "frame": + {"x": 0,"y": 223,"w": 39,"h": 36} }, { "filename": "0016.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 36 - }, - "frame": { - "x": 39, - "y": 223, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 36}, + "frame": + {"x": 39,"y": 223,"w": 39,"h": 36} }, { "filename": "0023.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 5, - "w": 39, - "h": 36 - }, - "frame": { - "x": 78, - "y": 223, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 5,"w": 39,"h": 36}, + "frame": + {"x": 78,"y": 223,"w": 39,"h": 36} } ] } ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:f40b3a5fa0f1b8473c59be65abdc665d:06aa41bea05ce4124465746e260c145d:cda0147f4d676691e1699693bc0ee567$" - } + "meta": + {"app": "https://www.codeandweb.com/texturepacker", + "version": "3.0"} } diff --git a/public/images/pokemon/exp/774-red.png b/public/images/pokemon/exp/774-red.png index 4c64c6c68f7..41804ecea1a 100644 Binary files a/public/images/pokemon/exp/774-red.png and b/public/images/pokemon/exp/774-red.png differ diff --git a/public/images/pokemon/exp/774-violet.json b/public/images/pokemon/exp/774-violet.json index 2d0622504e8..42c0105da2d 100644 --- a/public/images/pokemon/exp/774-violet.json +++ b/public/images/pokemon/exp/774-violet.json @@ -3,1068 +3,563 @@ { "image": "774-violet.png", "format": "RGBA8888", - "size": { - "w": 274, - "h": 274 - }, + "size": {"w": 274, "h": 274}, "scale": 1, "frames": [ { "filename": "0013.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 1, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 1,"w": 39,"h": 38}, + "frame": + {"x": 0,"y": 0,"w": 39,"h": 38} }, { "filename": "0036.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 18, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 18,"w": 39,"h": 38}, + "frame": + {"x": 39,"y": 0,"w": 39,"h": 38} }, { "filename": "0040.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 22, - "w": 39, - "h": 38 - }, - "frame": { - "x": 78, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 22,"w": 39,"h": 38}, + "frame": + {"x": 78,"y": 0,"w": 39,"h": 38} }, { "filename": "0044.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 20, - "w": 39, - "h": 38 - }, - "frame": { - "x": 117, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 20,"w": 39,"h": 38}, + "frame": + {"x": 117,"y": 0,"w": 39,"h": 38} }, { "filename": "0006.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 8, - "w": 40, - "h": 37 - }, - "frame": { - "x": 156, - "y": 0, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 40,"h": 37}, + "frame": + {"x": 156,"y": 0,"w": 40,"h": 37} }, { "filename": "0010.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 4, - "w": 40, - "h": 37 - }, - "frame": { - "x": 196, - "y": 0, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 4,"w": 40,"h": 37}, + "frame": + {"x": 196,"y": 0,"w": 40,"h": 37} }, { "filename": "0035.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 38, - "h": 38 - }, - "frame": { - "x": 236, - "y": 0, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 38,"h": 38}, + "frame": + {"x": 236,"y": 0,"w": 38,"h": 38} }, { "filename": "0018.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 40, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 0,"w": 40,"h": 37}, + "frame": + {"x": 156,"y": 37,"w": 40,"h": 37} }, { "filename": "0021.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 3, - "w": 40, - "h": 37 - }, - "frame": { - "x": 196, - "y": 37, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 3,"w": 40,"h": 37}, + "frame": + {"x": 196,"y": 37,"w": 40,"h": 37} }, { "filename": "0039.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 21, - "w": 38, - "h": 38 - }, - "frame": { - "x": 236, - "y": 38, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 21,"w": 38,"h": 38}, + "frame": + {"x": 236,"y": 38,"w": 38,"h": 38} }, { "filename": "0024.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 6, - "w": 40, - "h": 37 - }, - "frame": { - "x": 0, - "y": 38, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 6,"w": 40,"h": 37}, + "frame": + {"x": 0,"y": 38,"w": 40,"h": 37} }, { "filename": "0045.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 38, - "h": 38 - }, - "frame": { - "x": 40, - "y": 38, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 18,"w": 38,"h": 38}, + "frame": + {"x": 40,"y": 38,"w": 38,"h": 38} }, { "filename": "0047.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 38, - "h": 38 - }, - "frame": { - "x": 0, - "y": 75, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 38,"h": 38}, + "frame": + {"x": 0,"y": 75,"w": 38,"h": 38} }, { "filename": "0001.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 14, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 38,"w": 39,"h": 37} }, { "filename": "0002.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 13, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 13,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 38,"w": 39,"h": 37} }, { "filename": "0004.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 11,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 38,"w": 39,"h": 37} }, { "filename": "0049.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 16, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 16,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 38,"w": 39,"h": 37} }, { "filename": "0005.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 156,"y": 74,"w": 39,"h": 37} }, { "filename": "0008.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 7,"w": 39,"h": 37}, + "frame": + {"x": 195,"y": 74,"w": 39,"h": 37} }, { "filename": "0009.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 5, - "w": 39, - "h": 37 - }, - "frame": { - "x": 234, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 5,"w": 39,"h": 37}, + "frame": + {"x": 234,"y": 76,"w": 39,"h": 37} }, { "filename": "0011.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 3, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 75, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 3,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 75,"w": 39,"h": 37} }, { "filename": "0012.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 75, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 75,"w": 39,"h": 37} }, { "filename": "0014.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 37 - }, - "frame": { - "x": 38, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 37}, + "frame": + {"x": 38,"y": 76,"w": 39,"h": 37} }, { "filename": "0017.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 37}, + "frame": + {"x": 156,"y": 111,"w": 39,"h": 37} }, { "filename": "0019.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 1, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 1,"w": 39,"h": 37}, + "frame": + {"x": 195,"y": 111,"w": 39,"h": 37} }, { "filename": "0022.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 4, - "w": 39, - "h": 37 - }, - "frame": { - "x": 234, - "y": 113, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 4,"w": 39,"h": 37}, + "frame": + {"x": 234,"y": 113,"w": 39,"h": 37} }, { "filename": "0025.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 77, - "y": 112, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 7,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 112,"w": 39,"h": 37} }, { "filename": "0026.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 116, - "y": 112, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 112,"w": 39,"h": 37} }, { "filename": "0027.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 155, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 155,"y": 148,"w": 39,"h": 37} }, { "filename": "0028.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 194, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 194,"y": 148,"w": 39,"h": 37} }, { "filename": "0029.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 233, - "y": 150, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 11,"w": 39,"h": 37}, + "frame": + {"x": 233,"y": 150,"w": 39,"h": 37} }, { "filename": "0030.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 12, - "w": 39, - "h": 37 - }, - "frame": { - "x": 0, - "y": 113, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 12,"w": 39,"h": 37}, + "frame": + {"x": 0,"y": 113,"w": 39,"h": 37} }, { "filename": "0038.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 21, - "w": 38, - "h": 37 - }, - "frame": { - "x": 39, - "y": 113, - "w": 38, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 21,"w": 38,"h": 37}, + "frame": + {"x": 39,"y": 113,"w": 38,"h": 37} }, { "filename": "0031.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 14, - "w": 39, - "h": 37 - }, - "frame": { - "x": 77, - "y": 149, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 149,"w": 39,"h": 37} }, { "filename": "0032.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 14, - "w": 39, - "h": 37 - }, - "frame": { - "x": 116, - "y": 149, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 149,"w": 39,"h": 37} }, { "filename": "0033.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 15, - "w": 39, - "h": 37 - }, - "frame": { - "x": 155, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 15,"w": 39,"h": 37}, + "frame": + {"x": 155,"y": 185,"w": 39,"h": 37} }, { "filename": "0034.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 17, - "w": 39, - "h": 37 - }, - "frame": { - "x": 194, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 17,"w": 39,"h": 37}, + "frame": + {"x": 194,"y": 185,"w": 39,"h": 37} }, { "filename": "0037.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 20, - "w": 39, - "h": 37 - }, - "frame": { - "x": 233, - "y": 187, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 20,"w": 39,"h": 37}, + "frame": + {"x": 233,"y": 187,"w": 39,"h": 37} }, { "filename": "0046.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 39, - "h": 37 - }, - "frame": { - "x": 0, - "y": 150, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 18,"w": 39,"h": 37}, + "frame": + {"x": 0,"y": 150,"w": 39,"h": 37} }, { "filename": "0042.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 22, - "w": 38, - "h": 37 - }, - "frame": { - "x": 39, - "y": 150, - "w": 38, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 22,"w": 38,"h": 37}, + "frame": + {"x": 39,"y": 150,"w": 38,"h": 37} }, { "filename": "0048.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 39, - "h": 37 - }, - "frame": { - "x": 77, - "y": 186, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 186,"w": 39,"h": 37} }, { "filename": "0050.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 15, - "w": 39, - "h": 37 - }, - "frame": { - "x": 116, - "y": 186, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 15,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 186,"w": 39,"h": 37} }, { "filename": "0020.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 3, - "w": 40, - "h": 36 - }, - "frame": { - "x": 155, - "y": 222, - "w": 40, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 3,"w": 40,"h": 36}, + "frame": + {"x": 155,"y": 222,"w": 40,"h": 36} }, { "filename": "0043.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 21, - "w": 38, - "h": 37 - }, - "frame": { - "x": 195, - "y": 222, - "w": 38, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 21,"w": 38,"h": 37}, + "frame": + {"x": 195,"y": 222,"w": 38,"h": 37} }, { "filename": "0003.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 12, - "w": 39, - "h": 36 - }, - "frame": { - "x": 233, - "y": 224, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 12,"w": 39,"h": 36}, + "frame": + {"x": 233,"y": 224,"w": 39,"h": 36} }, { "filename": "0007.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 8, - "w": 39, - "h": 36 - }, - "frame": { - "x": 0, - "y": 187, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 39,"h": 36}, + "frame": + {"x": 0,"y": 187,"w": 39,"h": 36} }, { "filename": "0041.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 24, - "w": 38, - "h": 36 - }, - "frame": { - "x": 39, - "y": 187, - "w": 38, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 24,"w": 38,"h": 36}, + "frame": + {"x": 39,"y": 187,"w": 38,"h": 36} }, { "filename": "0015.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 36 - }, - "frame": { - "x": 0, - "y": 223, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 36}, + "frame": + {"x": 0,"y": 223,"w": 39,"h": 36} }, { "filename": "0016.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 36 - }, - "frame": { - "x": 39, - "y": 223, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 36}, + "frame": + {"x": 39,"y": 223,"w": 39,"h": 36} }, { "filename": "0023.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 5, - "w": 39, - "h": 36 - }, - "frame": { - "x": 78, - "y": 223, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 5,"w": 39,"h": 36}, + "frame": + {"x": 78,"y": 223,"w": 39,"h": 36} } ] } ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:b89f815067b5f5227c236c2fc0b001f7:2a6b34947247eb150e2ebd7d9b5aa73c:cafe7bbce21f2b95187ef35011084eca$" - } + "meta": + {"app": "https://www.codeandweb.com/texturepacker", + "version": "3.0"} } diff --git a/public/images/pokemon/exp/774-violet.png b/public/images/pokemon/exp/774-violet.png index 840e8dbaeb8..85372ec1ec8 100644 Binary files a/public/images/pokemon/exp/774-violet.png and b/public/images/pokemon/exp/774-violet.png differ diff --git a/public/images/pokemon/exp/774-yellow.json b/public/images/pokemon/exp/774-yellow.json index 03cae44dc90..6f5d0a8121c 100644 --- a/public/images/pokemon/exp/774-yellow.json +++ b/public/images/pokemon/exp/774-yellow.json @@ -3,1068 +3,563 @@ { "image": "774-yellow.png", "format": "RGBA8888", - "size": { - "w": 274, - "h": 274 - }, + "size": {"w": 274, "h": 274}, "scale": 1, "frames": [ { "filename": "0013.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 1, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 1,"w": 39,"h": 38}, + "frame": + {"x": 0,"y": 0,"w": 39,"h": 38} }, { "filename": "0036.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 18, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 18,"w": 39,"h": 38}, + "frame": + {"x": 39,"y": 0,"w": 39,"h": 38} }, { "filename": "0040.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 22, - "w": 39, - "h": 38 - }, - "frame": { - "x": 78, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 22,"w": 39,"h": 38}, + "frame": + {"x": 78,"y": 0,"w": 39,"h": 38} }, { "filename": "0044.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 20, - "w": 39, - "h": 38 - }, - "frame": { - "x": 117, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 20,"w": 39,"h": 38}, + "frame": + {"x": 117,"y": 0,"w": 39,"h": 38} }, { "filename": "0006.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 8, - "w": 40, - "h": 37 - }, - "frame": { - "x": 156, - "y": 0, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 40,"h": 37}, + "frame": + {"x": 156,"y": 0,"w": 40,"h": 37} }, { "filename": "0010.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 4, - "w": 40, - "h": 37 - }, - "frame": { - "x": 196, - "y": 0, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 4,"w": 40,"h": 37}, + "frame": + {"x": 196,"y": 0,"w": 40,"h": 37} }, { "filename": "0035.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 38, - "h": 38 - }, - "frame": { - "x": 236, - "y": 0, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 38,"h": 38}, + "frame": + {"x": 236,"y": 0,"w": 38,"h": 38} }, { "filename": "0018.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 40, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 0,"w": 40,"h": 37}, + "frame": + {"x": 156,"y": 37,"w": 40,"h": 37} }, { "filename": "0021.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 3, - "w": 40, - "h": 37 - }, - "frame": { - "x": 196, - "y": 37, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 3,"w": 40,"h": 37}, + "frame": + {"x": 196,"y": 37,"w": 40,"h": 37} }, { "filename": "0039.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 21, - "w": 38, - "h": 38 - }, - "frame": { - "x": 236, - "y": 38, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 21,"w": 38,"h": 38}, + "frame": + {"x": 236,"y": 38,"w": 38,"h": 38} }, { "filename": "0024.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 6, - "w": 40, - "h": 37 - }, - "frame": { - "x": 0, - "y": 38, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 6,"w": 40,"h": 37}, + "frame": + {"x": 0,"y": 38,"w": 40,"h": 37} }, { "filename": "0045.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 38, - "h": 38 - }, - "frame": { - "x": 40, - "y": 38, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 18,"w": 38,"h": 38}, + "frame": + {"x": 40,"y": 38,"w": 38,"h": 38} }, { "filename": "0047.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 38, - "h": 38 - }, - "frame": { - "x": 0, - "y": 75, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 38,"h": 38}, + "frame": + {"x": 0,"y": 75,"w": 38,"h": 38} }, { "filename": "0001.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 14, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 38,"w": 39,"h": 37} }, { "filename": "0002.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 13, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 13,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 38,"w": 39,"h": 37} }, { "filename": "0004.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 11,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 38,"w": 39,"h": 37} }, { "filename": "0049.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 16, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 16,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 38,"w": 39,"h": 37} }, { "filename": "0005.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 156,"y": 74,"w": 39,"h": 37} }, { "filename": "0008.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 7,"w": 39,"h": 37}, + "frame": + {"x": 195,"y": 74,"w": 39,"h": 37} }, { "filename": "0009.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 5, - "w": 39, - "h": 37 - }, - "frame": { - "x": 234, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 5,"w": 39,"h": 37}, + "frame": + {"x": 234,"y": 76,"w": 39,"h": 37} }, { "filename": "0011.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 3, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 75, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 3,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 75,"w": 39,"h": 37} }, { "filename": "0012.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 75, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 75,"w": 39,"h": 37} }, { "filename": "0014.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 37 - }, - "frame": { - "x": 38, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 37}, + "frame": + {"x": 38,"y": 76,"w": 39,"h": 37} }, { "filename": "0017.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 37}, + "frame": + {"x": 156,"y": 111,"w": 39,"h": 37} }, { "filename": "0019.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 1, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 1,"w": 39,"h": 37}, + "frame": + {"x": 195,"y": 111,"w": 39,"h": 37} }, { "filename": "0022.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 4, - "w": 39, - "h": 37 - }, - "frame": { - "x": 234, - "y": 113, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 4,"w": 39,"h": 37}, + "frame": + {"x": 234,"y": 113,"w": 39,"h": 37} }, { "filename": "0025.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 77, - "y": 112, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 7,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 112,"w": 39,"h": 37} }, { "filename": "0026.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 116, - "y": 112, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 112,"w": 39,"h": 37} }, { "filename": "0027.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 155, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 155,"y": 148,"w": 39,"h": 37} }, { "filename": "0028.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 194, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 194,"y": 148,"w": 39,"h": 37} }, { "filename": "0029.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 233, - "y": 150, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 11,"w": 39,"h": 37}, + "frame": + {"x": 233,"y": 150,"w": 39,"h": 37} }, { "filename": "0030.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 12, - "w": 39, - "h": 37 - }, - "frame": { - "x": 0, - "y": 113, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 12,"w": 39,"h": 37}, + "frame": + {"x": 0,"y": 113,"w": 39,"h": 37} }, { "filename": "0038.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 21, - "w": 38, - "h": 37 - }, - "frame": { - "x": 39, - "y": 113, - "w": 38, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 21,"w": 38,"h": 37}, + "frame": + {"x": 39,"y": 113,"w": 38,"h": 37} }, { "filename": "0031.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 14, - "w": 39, - "h": 37 - }, - "frame": { - "x": 77, - "y": 149, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 149,"w": 39,"h": 37} }, { "filename": "0032.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 14, - "w": 39, - "h": 37 - }, - "frame": { - "x": 116, - "y": 149, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 149,"w": 39,"h": 37} }, { "filename": "0033.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 15, - "w": 39, - "h": 37 - }, - "frame": { - "x": 155, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 15,"w": 39,"h": 37}, + "frame": + {"x": 155,"y": 185,"w": 39,"h": 37} }, { "filename": "0034.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 17, - "w": 39, - "h": 37 - }, - "frame": { - "x": 194, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 17,"w": 39,"h": 37}, + "frame": + {"x": 194,"y": 185,"w": 39,"h": 37} }, { "filename": "0037.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 20, - "w": 39, - "h": 37 - }, - "frame": { - "x": 233, - "y": 187, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 20,"w": 39,"h": 37}, + "frame": + {"x": 233,"y": 187,"w": 39,"h": 37} }, { "filename": "0046.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 39, - "h": 37 - }, - "frame": { - "x": 0, - "y": 150, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 18,"w": 39,"h": 37}, + "frame": + {"x": 0,"y": 150,"w": 39,"h": 37} }, { "filename": "0042.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 22, - "w": 38, - "h": 37 - }, - "frame": { - "x": 39, - "y": 150, - "w": 38, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 22,"w": 38,"h": 37}, + "frame": + {"x": 39,"y": 150,"w": 38,"h": 37} }, { "filename": "0048.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 39, - "h": 37 - }, - "frame": { - "x": 77, - "y": 186, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 186,"w": 39,"h": 37} }, { "filename": "0050.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 15, - "w": 39, - "h": 37 - }, - "frame": { - "x": 116, - "y": 186, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 15,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 186,"w": 39,"h": 37} }, { "filename": "0020.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 3, - "w": 40, - "h": 36 - }, - "frame": { - "x": 155, - "y": 222, - "w": 40, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 3,"w": 40,"h": 36}, + "frame": + {"x": 155,"y": 222,"w": 40,"h": 36} }, { "filename": "0043.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 21, - "w": 38, - "h": 37 - }, - "frame": { - "x": 195, - "y": 222, - "w": 38, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 21,"w": 38,"h": 37}, + "frame": + {"x": 195,"y": 222,"w": 38,"h": 37} }, { "filename": "0003.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 12, - "w": 39, - "h": 36 - }, - "frame": { - "x": 233, - "y": 224, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 12,"w": 39,"h": 36}, + "frame": + {"x": 233,"y": 224,"w": 39,"h": 36} }, { "filename": "0007.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 8, - "w": 39, - "h": 36 - }, - "frame": { - "x": 0, - "y": 187, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 39,"h": 36}, + "frame": + {"x": 0,"y": 187,"w": 39,"h": 36} }, { "filename": "0041.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 24, - "w": 38, - "h": 36 - }, - "frame": { - "x": 39, - "y": 187, - "w": 38, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 24,"w": 38,"h": 36}, + "frame": + {"x": 39,"y": 187,"w": 38,"h": 36} }, { "filename": "0015.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 36 - }, - "frame": { - "x": 0, - "y": 223, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 36}, + "frame": + {"x": 0,"y": 223,"w": 39,"h": 36} }, { "filename": "0016.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 36 - }, - "frame": { - "x": 39, - "y": 223, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 36}, + "frame": + {"x": 39,"y": 223,"w": 39,"h": 36} }, { "filename": "0023.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 5, - "w": 39, - "h": 36 - }, - "frame": { - "x": 78, - "y": 223, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 5,"w": 39,"h": 36}, + "frame": + {"x": 78,"y": 223,"w": 39,"h": 36} } ] } ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:1d47c45ca53b9944efdbc9e22e413393:28311be4e6c1974c59b88f18043a1002:a0f9f47b818f7e67dd381af2f205c265$" - } + "meta": + {"app": "https://www.codeandweb.com/texturepacker", + "version": "3.0"} } diff --git a/public/images/pokemon/exp/774-yellow.png b/public/images/pokemon/exp/774-yellow.png index d9de341765e..e38e4ff8e99 100644 Binary files a/public/images/pokemon/exp/774-yellow.png and b/public/images/pokemon/exp/774-yellow.png differ diff --git a/public/images/pokemon/exp/865.json b/public/images/pokemon/exp/865.json index 16dcd426cb1..b204a053406 100644 --- a/public/images/pokemon/exp/865.json +++ b/public/images/pokemon/exp/865.json @@ -4,639 +4,1143 @@ "image": "865.png", "format": "RGBA8888", "size": { - "w": 400, - "h": 400 + "w": 285, + "h": 285 }, "scale": 1, "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 80, - "h": 111 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 80, - "h": 111 - }, - "frame": { - "x": 0, - "y": 0, - "w": 80, - "h": 111 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 80, - "h": 111 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 80, - "h": 111 - }, - "frame": { - "x": 0, - "y": 0, - "w": 80, - "h": 111 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 80, - "h": 111 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 80, - "h": 111 - }, - "frame": { - "x": 0, - "y": 0, - "w": 80, - "h": 111 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 80, - "h": 111 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 80, - "h": 111 - }, - "frame": { - "x": 0, - "y": 111, - "w": 80, - "h": 111 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 80, - "h": 111 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 80, - "h": 111 - }, - "frame": { - "x": 0, - "y": 222, - "w": 80, - "h": 111 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 80, - "h": 111 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 80, - "h": 111 - }, - "frame": { - "x": 0, - "y": 222, - "w": 80, - "h": 111 - } - }, { "filename": "0004.png", "rotated": false, - "trimmed": false, + "trimmed": true, "sourceSize": { - "w": 80, - "h": 111 + "w": 82, + "h": 96 }, "spriteSourceSize": { - "x": 0, + "x": 5, "y": 0, - "w": 80, - "h": 111 + "w": 77, + "h": 96 }, "frame": { - "x": 80, - "y": 0, - "w": 80, - "h": 111 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 80, - "h": 111 - }, - "spriteSourceSize": { "x": 0, "y": 0, - "w": 80, - "h": 111 - }, - "frame": { - "x": 80, - "y": 0, - "w": 80, - "h": 111 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 80, - "h": 111 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 80, - "h": 111 - }, - "frame": { - "x": 80, - "y": 0, - "w": 80, - "h": 111 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 80, - "h": 111 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 80, - "h": 111 - }, - "frame": { - "x": 160, - "y": 0, - "w": 80, - "h": 111 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 80, - "h": 111 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 80, - "h": 111 - }, - "frame": { - "x": 240, - "y": 0, - "w": 80, - "h": 111 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 80, - "h": 111 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 80, - "h": 111 - }, - "frame": { - "x": 320, - "y": 0, - "w": 80, - "h": 111 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 80, - "h": 111 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 80, - "h": 111 - }, - "frame": { - "x": 320, - "y": 0, - "w": 80, - "h": 111 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 80, - "h": 111 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 80, - "h": 111 - }, - "frame": { - "x": 320, - "y": 0, - "w": 80, - "h": 111 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 80, - "h": 111 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 80, - "h": 111 - }, - "frame": { - "x": 80, - "y": 111, - "w": 80, - "h": 111 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 80, - "h": 111 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 80, - "h": 111 - }, - "frame": { - "x": 80, - "y": 111, - "w": 80, - "h": 111 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 80, - "h": 111 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 80, - "h": 111 - }, - "frame": { - "x": 80, - "y": 111, - "w": 80, - "h": 111 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 80, - "h": 111 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 80, - "h": 111 - }, - "frame": { - "x": 80, - "y": 222, - "w": 80, - "h": 111 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 80, - "h": 111 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 80, - "h": 111 - }, - "frame": { - "x": 80, - "y": 222, - "w": 80, - "h": 111 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 80, - "h": 111 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 80, - "h": 111 - }, - "frame": { - "x": 80, - "y": 222, - "w": 80, - "h": 111 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 80, - "h": 111 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 80, - "h": 111 - }, - "frame": { - "x": 160, - "y": 111, - "w": 80, - "h": 111 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 80, - "h": 111 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 80, - "h": 111 - }, - "frame": { - "x": 160, - "y": 111, - "w": 80, - "h": 111 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 80, - "h": 111 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 80, - "h": 111 - }, - "frame": { - "x": 160, - "y": 111, - "w": 80, - "h": 111 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 80, - "h": 111 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 80, - "h": 111 - }, - "frame": { - "x": 160, - "y": 222, - "w": 80, - "h": 111 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 80, - "h": 111 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 80, - "h": 111 - }, - "frame": { - "x": 160, - "y": 222, - "w": 80, - "h": 111 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 80, - "h": 111 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 80, - "h": 111 - }, - "frame": { - "x": 240, - "y": 111, - "w": 80, - "h": 111 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 80, - "h": 111 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 80, - "h": 111 - }, - "frame": { - "x": 240, - "y": 111, - "w": 80, - "h": 111 + "w": 77, + "h": 96 } }, { "filename": "0016.png", "rotated": false, - "trimmed": false, + "trimmed": true, "sourceSize": { - "w": 80, - "h": 111 + "w": 82, + "h": 96 }, "spriteSourceSize": { - "x": 0, + "x": 5, "y": 0, - "w": 80, - "h": 111 + "w": 77, + "h": 96 }, "frame": { - "x": 320, - "y": 111, - "w": 80, - "h": 111 + "x": 0, + "y": 0, + "w": 77, + "h": 96 } }, { - "filename": "0026.png", + "filename": "0022.png", "rotated": false, - "trimmed": false, + "trimmed": true, "sourceSize": { - "w": 80, - "h": 111 + "w": 82, + "h": 96 }, "spriteSourceSize": { - "x": 0, + "x": 5, "y": 0, - "w": 80, - "h": 111 + "w": 77, + "h": 96 }, "frame": { - "x": 320, - "y": 111, - "w": 80, - "h": 111 + "x": 0, + "y": 0, + "w": 77, + "h": 96 + } + }, + { + "filename": "0040.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 5, + "y": 0, + "w": 77, + "h": 96 + }, + "frame": { + "x": 0, + "y": 0, + "w": 77, + "h": 96 + } + }, + { + "filename": "0052.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 5, + "y": 0, + "w": 77, + "h": 96 + }, + "frame": { + "x": 0, + "y": 0, + "w": 77, + "h": 96 + } + }, + { + "filename": "0034.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 5, + "y": 0, + "w": 77, + "h": 96 + }, + "frame": { + "x": 0, + "y": 96, + "w": 77, + "h": 96 + } + }, + { + "filename": "0002.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 1, + "y": 4, + "w": 79, + "h": 92 + }, + "frame": { + "x": 0, + "y": 192, + "w": 79, + "h": 92 + } + }, + { + "filename": "0018.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 1, + "y": 4, + "w": 79, + "h": 92 + }, + "frame": { + "x": 0, + "y": 192, + "w": 79, + "h": 92 + } + }, + { + "filename": "0020.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 1, + "y": 4, + "w": 79, + "h": 92 + }, + "frame": { + "x": 0, + "y": 192, + "w": 79, + "h": 92 + } + }, + { + "filename": "0036.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 1, + "y": 4, + "w": 79, + "h": 92 + }, + "frame": { + "x": 0, + "y": 192, + "w": 79, + "h": 92 + } + }, + { + "filename": "0038.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 1, + "y": 4, + "w": 79, + "h": 92 + }, + "frame": { + "x": 0, + "y": 192, + "w": 79, + "h": 92 + } + }, + { + "filename": "0054.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 1, + "y": 4, + "w": 79, + "h": 92 + }, + "frame": { + "x": 0, + "y": 192, + "w": 79, + "h": 92 + } + }, + { + "filename": "0005.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 10, + "y": 0, + "w": 72, + "h": 96 + }, + "frame": { + "x": 77, + "y": 0, + "w": 72, + "h": 96 + } + }, + { + "filename": "0015.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 10, + "y": 0, + "w": 72, + "h": 96 + }, + "frame": { + "x": 77, + "y": 0, + "w": 72, + "h": 96 } }, { "filename": "0023.png", "rotated": false, - "trimmed": false, + "trimmed": true, "sourceSize": { - "w": 80, - "h": 111 + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 10, + "y": 0, + "w": 72, + "h": 96 + }, + "frame": { + "x": 77, + "y": 0, + "w": 72, + "h": 96 + } + }, + { + "filename": "0033.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 10, + "y": 0, + "w": 72, + "h": 96 + }, + "frame": { + "x": 77, + "y": 0, + "w": 72, + "h": 96 + } + }, + { + "filename": "0041.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 10, + "y": 0, + "w": 72, + "h": 96 + }, + "frame": { + "x": 77, + "y": 0, + "w": 72, + "h": 96 + } + }, + { + "filename": "0051.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 10, + "y": 0, + "w": 72, + "h": 96 + }, + "frame": { + "x": 77, + "y": 0, + "w": 72, + "h": 96 + } + }, + { + "filename": "0006.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 19, + "y": 0, + "w": 63, + "h": 96 + }, + "frame": { + "x": 77, + "y": 96, + "w": 63, + "h": 96 + } + }, + { + "filename": "0014.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 19, + "y": 0, + "w": 63, + "h": 96 + }, + "frame": { + "x": 77, + "y": 96, + "w": 63, + "h": 96 + } + }, + { + "filename": "0024.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 19, + "y": 0, + "w": 63, + "h": 96 + }, + "frame": { + "x": 77, + "y": 96, + "w": 63, + "h": 96 + } + }, + { + "filename": "0032.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 19, + "y": 0, + "w": 63, + "h": 96 + }, + "frame": { + "x": 77, + "y": 96, + "w": 63, + "h": 96 + } + }, + { + "filename": "0042.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 19, + "y": 0, + "w": 63, + "h": 96 + }, + "frame": { + "x": 77, + "y": 96, + "w": 63, + "h": 96 + } + }, + { + "filename": "0050.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 19, + "y": 0, + "w": 63, + "h": 96 + }, + "frame": { + "x": 77, + "y": 96, + "w": 63, + "h": 96 + } + }, + { + "filename": "0001.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 }, "spriteSourceSize": { "x": 0, - "y": 0, - "w": 80, - "h": 111 + "y": 7, + "w": 79, + "h": 89 }, "frame": { - "x": 240, - "y": 222, - "w": 80, - "h": 111 + "x": 79, + "y": 192, + "w": 79, + "h": 89 + } + }, + { + "filename": "0019.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 0, + "y": 7, + "w": 79, + "h": 89 + }, + "frame": { + "x": 79, + "y": 192, + "w": 79, + "h": 89 + } + }, + { + "filename": "0037.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 0, + "y": 7, + "w": 79, + "h": 89 + }, + "frame": { + "x": 79, + "y": 192, + "w": 79, + "h": 89 + } + }, + { + "filename": "0007.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 21, + "y": 0, + "w": 59, + "h": 96 + }, + "frame": { + "x": 140, + "y": 96, + "w": 59, + "h": 96 + } + }, + { + "filename": "0013.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 21, + "y": 0, + "w": 59, + "h": 96 + }, + "frame": { + "x": 140, + "y": 96, + "w": 59, + "h": 96 + } + }, + { + "filename": "0025.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 21, + "y": 0, + "w": 59, + "h": 96 + }, + "frame": { + "x": 140, + "y": 96, + "w": 59, + "h": 96 + } + }, + { + "filename": "0031.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 21, + "y": 0, + "w": 59, + "h": 96 + }, + "frame": { + "x": 140, + "y": 96, + "w": 59, + "h": 96 + } + }, + { + "filename": "0043.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 21, + "y": 0, + "w": 59, + "h": 96 + }, + "frame": { + "x": 140, + "y": 96, + "w": 59, + "h": 96 + } + }, + { + "filename": "0049.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 21, + "y": 0, + "w": 59, + "h": 96 + }, + "frame": { + "x": 140, + "y": 96, + "w": 59, + "h": 96 + } + }, + { + "filename": "0008.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 20, + "y": 0, + "w": 58, + "h": 96 + }, + "frame": { + "x": 149, + "y": 0, + "w": 58, + "h": 96 + } + }, + { + "filename": "0012.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 20, + "y": 0, + "w": 58, + "h": 96 + }, + "frame": { + "x": 149, + "y": 0, + "w": 58, + "h": 96 + } + }, + { + "filename": "0026.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 20, + "y": 0, + "w": 58, + "h": 96 + }, + "frame": { + "x": 149, + "y": 0, + "w": 58, + "h": 96 + } + }, + { + "filename": "0030.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 20, + "y": 0, + "w": 58, + "h": 96 + }, + "frame": { + "x": 149, + "y": 0, + "w": 58, + "h": 96 + } + }, + { + "filename": "0044.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 20, + "y": 0, + "w": 58, + "h": 96 + }, + "frame": { + "x": 149, + "y": 0, + "w": 58, + "h": 96 + } + }, + { + "filename": "0048.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 20, + "y": 0, + "w": 58, + "h": 96 + }, + "frame": { + "x": 149, + "y": 0, + "w": 58, + "h": 96 + } + }, + { + "filename": "0003.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 2, + "y": 2, + "w": 79, + "h": 94 + }, + "frame": { + "x": 199, + "y": 96, + "w": 79, + "h": 94 + } + }, + { + "filename": "0017.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 2, + "y": 2, + "w": 79, + "h": 94 + }, + "frame": { + "x": 199, + "y": 96, + "w": 79, + "h": 94 + } + }, + { + "filename": "0021.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 2, + "y": 2, + "w": 79, + "h": 94 + }, + "frame": { + "x": 199, + "y": 96, + "w": 79, + "h": 94 + } + }, + { + "filename": "0035.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 2, + "y": 2, + "w": 79, + "h": 94 + }, + "frame": { + "x": 199, + "y": 96, + "w": 79, + "h": 94 + } + }, + { + "filename": "0039.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 2, + "y": 2, + "w": 79, + "h": 94 + }, + "frame": { + "x": 199, + "y": 96, + "w": 79, + "h": 94 + } + }, + { + "filename": "0053.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 2, + "y": 2, + "w": 79, + "h": 94 + }, + "frame": { + "x": 199, + "y": 96, + "w": 79, + "h": 94 + } + }, + { + "filename": "0009.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 22, + "y": 0, + "w": 52, + "h": 96 + }, + "frame": { + "x": 207, + "y": 0, + "w": 52, + "h": 96 + } + }, + { + "filename": "0011.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 22, + "y": 0, + "w": 52, + "h": 96 + }, + "frame": { + "x": 207, + "y": 0, + "w": 52, + "h": 96 + } + }, + { + "filename": "0027.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 22, + "y": 0, + "w": 52, + "h": 96 + }, + "frame": { + "x": 207, + "y": 0, + "w": 52, + "h": 96 + } + }, + { + "filename": "0029.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 22, + "y": 0, + "w": 52, + "h": 96 + }, + "frame": { + "x": 207, + "y": 0, + "w": 52, + "h": 96 + } + }, + { + "filename": "0045.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 22, + "y": 0, + "w": 52, + "h": 96 + }, + "frame": { + "x": 207, + "y": 0, + "w": 52, + "h": 96 + } + }, + { + "filename": "0047.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 22, + "y": 0, + "w": 52, + "h": 96 + }, + "frame": { + "x": 207, + "y": 0, + "w": 52, + "h": 96 + } + }, + { + "filename": "0010.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 21, + "y": 1, + "w": 53, + "h": 95 + }, + "frame": { + "x": 199, + "y": 190, + "w": 53, + "h": 95 + } + }, + { + "filename": "0028.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 21, + "y": 1, + "w": 53, + "h": 95 + }, + "frame": { + "x": 199, + "y": 190, + "w": 53, + "h": 95 + } + }, + { + "filename": "0046.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 82, + "h": 96 + }, + "spriteSourceSize": { + "x": 21, + "y": 1, + "w": 53, + "h": 95 + }, + "frame": { + "x": 199, + "y": 190, + "w": 53, + "h": 95 } } ] @@ -645,6 +1149,6 @@ "meta": { "app": "https://www.codeandweb.com/texturepacker", "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:dbbc7976911621e1d876d7e8ad805633:03f0391b0ea7e652408b22d3fc88c1f3:c7693032eafd40ba9028aebf1b6abbfa$" + "smartupdate": "$TexturePacker:SmartUpdate:a1464f05009f1be2ce8d1c3fd2ff65e3:98bcf35a71d7d1dceea57ad6e2a92474:c7693032eafd40ba9028aebf1b6abbfa$" } } diff --git a/public/images/pokemon/exp/865.png b/public/images/pokemon/exp/865.png index bf1e4a11d9f..8326e41ccc6 100644 Binary files a/public/images/pokemon/exp/865.png and b/public/images/pokemon/exp/865.png differ diff --git a/public/images/pokemon/exp/894.png b/public/images/pokemon/exp/894.png index 4879a1ca5ec..749eec38e5e 100644 Binary files a/public/images/pokemon/exp/894.png and b/public/images/pokemon/exp/894.png differ diff --git a/public/images/pokemon/exp/945.png b/public/images/pokemon/exp/945.png index 074c03fda29..b50e1a9af52 100644 Binary files a/public/images/pokemon/exp/945.png and b/public/images/pokemon/exp/945.png differ diff --git a/public/images/pokemon/exp/back/2026.png b/public/images/pokemon/exp/back/2026.png index 007e4bee3e0..0624bb2c5e7 100644 Binary files a/public/images/pokemon/exp/back/2026.png and b/public/images/pokemon/exp/back/2026.png differ diff --git a/public/images/pokemon/exp/back/359-mega.png b/public/images/pokemon/exp/back/359-mega.png index 4ba1dd3ff81..1659752a571 100644 Binary files a/public/images/pokemon/exp/back/359-mega.png and b/public/images/pokemon/exp/back/359-mega.png differ diff --git a/public/images/pokemon/exp/back/4144.png b/public/images/pokemon/exp/back/4144.png index d92209cc168..de643227ebb 100644 Binary files a/public/images/pokemon/exp/back/4144.png and b/public/images/pokemon/exp/back/4144.png differ diff --git a/public/images/pokemon/exp/back/4145.png b/public/images/pokemon/exp/back/4145.png index f3e50eddaa5..5c5ded10a5c 100644 Binary files a/public/images/pokemon/exp/back/4145.png and b/public/images/pokemon/exp/back/4145.png differ diff --git a/public/images/pokemon/exp/back/4146.png b/public/images/pokemon/exp/back/4146.png index 24628f7be72..5c1e2fb0f95 100644 Binary files a/public/images/pokemon/exp/back/4146.png and b/public/images/pokemon/exp/back/4146.png differ diff --git a/public/images/pokemon/exp/back/6503.png b/public/images/pokemon/exp/back/6503.png index f5a2395826a..39b93590981 100644 Binary files a/public/images/pokemon/exp/back/6503.png and b/public/images/pokemon/exp/back/6503.png differ diff --git a/public/images/pokemon/exp/back/656.png b/public/images/pokemon/exp/back/656.png index 3a7b6fcec5c..99119d2e96e 100644 Binary files a/public/images/pokemon/exp/back/656.png and b/public/images/pokemon/exp/back/656.png differ diff --git a/public/images/pokemon/exp/back/657.png b/public/images/pokemon/exp/back/657.png index 7484a85289c..72e8367e10d 100644 Binary files a/public/images/pokemon/exp/back/657.png and b/public/images/pokemon/exp/back/657.png differ diff --git a/public/images/pokemon/exp/back/658-ash.json b/public/images/pokemon/exp/back/658-ash.json index 9c2e394a89d..8e360497b8d 100644 --- a/public/images/pokemon/exp/back/658-ash.json +++ b/public/images/pokemon/exp/back/658-ash.json @@ -1,188 +1,155 @@ -{ - "textures": [ - { - "image": "658-ash.png", - "format": "RGBA8888", - "size": { - "w": 150, - "h": 150 - }, - "scale": 1, - "frames": [ - { - "filename": "0003.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 62 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 62 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 62 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 62 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 62 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - }, - "frame": { - "x": 75, - "y": 0, - "w": 75, - "h": 62 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 62 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - }, - "frame": { - "x": 75, - "y": 0, - "w": 75, - "h": 62 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 75, - "h": 62 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 75, - "h": 61 - }, - "frame": { - "x": 0, - "y": 62, - "w": 75, - "h": 61 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 75, - "h": 62 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 75, - "h": 61 - }, - "frame": { - "x": 75, - "y": 62, - "w": 75, - "h": 61 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:0121f3850f8a57a4a046524a1a5974dd:168ffc856b6fea872641e8672304766c:f09eeed5adc5ec50aec50218e03662c2$" - } +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + }, + { + "filename": "0002.png", + "frame": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + }, + { + "filename": "0003.png", + "frame": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + }, + { + "filename": "0004.png", + "frame": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + }, + { + "filename": "0005.png", + "frame": { "x": 73, "y": 0, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + }, + { + "filename": "0006.png", + "frame": { "x": 73, "y": 0, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + }, + { + "filename": "0007.png", + "frame": { "x": 73, "y": 0, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + }, + { + "filename": "0008.png", + "frame": { "x": 73, "y": 0, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + }, + { + "filename": "0009.png", + "frame": { "x": 0, "y": 73, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + }, + { + "filename": "0010.png", + "frame": { "x": 0, "y": 73, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + }, + { + "filename": "0011.png", + "frame": { "x": 0, "y": 73, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + }, + { + "filename": "0012.png", + "frame": { "x": 0, "y": 73, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + }, + { + "filename": "0013.png", + "frame": { "x": 73, "y": 0, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + }, + { + "filename": "0014.png", + "frame": { "x": 73, "y": 0, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + }, + { + "filename": "0015.png", + "frame": { "x": 73, "y": 0, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + }, + { + "filename": "0016.png", + "frame": { "x": 73, "y": 0, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.7-x64", + "image": "658-ash.png", + "format": "I8", + "size": { "w": 146, "h": 146 }, + "scale": "1" + } } diff --git a/public/images/pokemon/exp/back/658-ash.png b/public/images/pokemon/exp/back/658-ash.png index 8921ea65270..5d8794a1c0f 100644 Binary files a/public/images/pokemon/exp/back/658-ash.png and b/public/images/pokemon/exp/back/658-ash.png differ diff --git a/public/images/pokemon/exp/back/658.json b/public/images/pokemon/exp/back/658.json index 2fa50a7d23f..453f6c16dc6 100644 --- a/public/images/pokemon/exp/back/658.json +++ b/public/images/pokemon/exp/back/658.json @@ -1,188 +1,92 @@ -{ - "textures": [ - { - "image": "658.png", - "format": "RGBA8888", - "size": { - "w": 150, - "h": 150 - }, - "scale": 1, - "frames": [ - { - "filename": "0003.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 62 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 62 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 62 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 62 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 62 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - }, - "frame": { - "x": 75, - "y": 0, - "w": 75, - "h": 62 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 62 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - }, - "frame": { - "x": 75, - "y": 0, - "w": 75, - "h": 62 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 75, - "h": 62 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 75, - "h": 61 - }, - "frame": { - "x": 0, - "y": 62, - "w": 75, - "h": 61 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 75, - "h": 62 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 75, - "h": 61 - }, - "frame": { - "x": 0, - "y": 62, - "w": 75, - "h": 61 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:63845d55db2350ed7cd6956836dc9510:7129df11a518cdd74572c2016d5f8ed8:5affcab976148657d36bf4ff3410f92d$" - } +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 77, "h": 77 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 77, "h": 77 }, + "sourceSize": { "w": 77, "h": 77 }, + "duration": 100 + }, + { + "filename": "0002.png", + "frame": { "x": 0, "y": 0, "w": 77, "h": 77 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 77, "h": 77 }, + "sourceSize": { "w": 77, "h": 77 }, + "duration": 100 + }, + { + "filename": "0003.png", + "frame": { "x": 0, "y": 0, "w": 77, "h": 77 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 77, "h": 77 }, + "sourceSize": { "w": 77, "h": 77 }, + "duration": 100 + }, + { + "filename": "0004.png", + "frame": { "x": 77, "y": 0, "w": 77, "h": 77 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 77, "h": 77 }, + "sourceSize": { "w": 77, "h": 77 }, + "duration": 100 + }, + { + "filename": "0005.png", + "frame": { "x": 77, "y": 0, "w": 77, "h": 77 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 77, "h": 77 }, + "sourceSize": { "w": 77, "h": 77 }, + "duration": 100 + }, + { + "filename": "0006.png", + "frame": { "x": 0, "y": 77, "w": 77, "h": 77 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 77, "h": 77 }, + "sourceSize": { "w": 77, "h": 77 }, + "duration": 100 + }, + { + "filename": "0007.png", + "frame": { "x": 0, "y": 77, "w": 77, "h": 77 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 77, "h": 77 }, + "sourceSize": { "w": 77, "h": 77 }, + "duration": 100 + }, + { + "filename": "0008.png", + "frame": { "x": 77, "y": 0, "w": 77, "h": 77 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 77, "h": 77 }, + "sourceSize": { "w": 77, "h": 77 }, + "duration": 100 + }, + { + "filename": "0009.png", + "frame": { "x": 77, "y": 0, "w": 77, "h": 77 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 77, "h": 77 }, + "sourceSize": { "w": 77, "h": 77 }, + "duration": 100 + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.7-x64", + "image": "658.png", + "format": "I8", + "size": { "w": 154, "h": 154 }, + "scale": "1" + } } diff --git a/public/images/pokemon/exp/back/658.png b/public/images/pokemon/exp/back/658.png index edcfa15b9f3..07b9084c43e 100644 Binary files a/public/images/pokemon/exp/back/658.png and b/public/images/pokemon/exp/back/658.png differ diff --git a/public/images/pokemon/exp/back/662.png b/public/images/pokemon/exp/back/662.png index e2a3111062f..4e6a3c88277 100644 Binary files a/public/images/pokemon/exp/back/662.png and b/public/images/pokemon/exp/back/662.png differ diff --git a/public/images/pokemon/exp/back/6706.png b/public/images/pokemon/exp/back/6706.png index 4bda5b08d10..7842bbbffad 100644 Binary files a/public/images/pokemon/exp/back/6706.png and b/public/images/pokemon/exp/back/6706.png differ diff --git a/public/images/pokemon/exp/back/682.png b/public/images/pokemon/exp/back/682.png index 9f713bfb828..d926cdc22a8 100644 Binary files a/public/images/pokemon/exp/back/682.png and b/public/images/pokemon/exp/back/682.png differ diff --git a/public/images/pokemon/exp/back/683.png b/public/images/pokemon/exp/back/683.png index 76aa9914d20..e65d213eaf2 100644 Binary files a/public/images/pokemon/exp/back/683.png and b/public/images/pokemon/exp/back/683.png differ diff --git a/public/images/pokemon/exp/back/684.png b/public/images/pokemon/exp/back/684.png index a58d2c77eb8..517cc69f8ee 100644 Binary files a/public/images/pokemon/exp/back/684.png and b/public/images/pokemon/exp/back/684.png differ diff --git a/public/images/pokemon/exp/back/685.png b/public/images/pokemon/exp/back/685.png index c791e4e92d7..d05cf54fb63 100644 Binary files a/public/images/pokemon/exp/back/685.png and b/public/images/pokemon/exp/back/685.png differ diff --git a/public/images/pokemon/exp/back/696.png b/public/images/pokemon/exp/back/696.png index 2be9fe01e77..1c4f2f8c835 100644 Binary files a/public/images/pokemon/exp/back/696.png and b/public/images/pokemon/exp/back/696.png differ diff --git a/public/images/pokemon/exp/back/697.png b/public/images/pokemon/exp/back/697.png index 072a4734df2..44a73042829 100644 Binary files a/public/images/pokemon/exp/back/697.png and b/public/images/pokemon/exp/back/697.png differ diff --git a/public/images/pokemon/exp/back/773-bug.png b/public/images/pokemon/exp/back/773-bug.png index 322f4dbc2f1..f55d45d56bf 100644 Binary files a/public/images/pokemon/exp/back/773-bug.png and b/public/images/pokemon/exp/back/773-bug.png differ diff --git a/public/images/pokemon/exp/back/773-dark.png b/public/images/pokemon/exp/back/773-dark.png index cc69ffb6cc0..e4f92ff85d8 100644 Binary files a/public/images/pokemon/exp/back/773-dark.png and b/public/images/pokemon/exp/back/773-dark.png differ diff --git a/public/images/pokemon/exp/back/773-dragon.png b/public/images/pokemon/exp/back/773-dragon.png index 1a80d5e1983..b4ae3bf78e5 100644 Binary files a/public/images/pokemon/exp/back/773-dragon.png and b/public/images/pokemon/exp/back/773-dragon.png differ diff --git a/public/images/pokemon/exp/back/773-electric.png b/public/images/pokemon/exp/back/773-electric.png index ebec2f1e4d5..debc8eb21e5 100644 Binary files a/public/images/pokemon/exp/back/773-electric.png and b/public/images/pokemon/exp/back/773-electric.png differ diff --git a/public/images/pokemon/exp/back/773-fairy.png b/public/images/pokemon/exp/back/773-fairy.png index 46eb2b92546..2a154cc9053 100644 Binary files a/public/images/pokemon/exp/back/773-fairy.png and b/public/images/pokemon/exp/back/773-fairy.png differ diff --git a/public/images/pokemon/exp/back/773-fighting.png b/public/images/pokemon/exp/back/773-fighting.png index 53ad206374e..854aeb8d16f 100644 Binary files a/public/images/pokemon/exp/back/773-fighting.png and b/public/images/pokemon/exp/back/773-fighting.png differ diff --git a/public/images/pokemon/exp/back/773-fire.png b/public/images/pokemon/exp/back/773-fire.png index 4b73b96dae8..19f81ffa2a8 100644 Binary files a/public/images/pokemon/exp/back/773-fire.png and b/public/images/pokemon/exp/back/773-fire.png differ diff --git a/public/images/pokemon/exp/back/773-flying.png b/public/images/pokemon/exp/back/773-flying.png index 4b16693a806..35797a5775a 100644 Binary files a/public/images/pokemon/exp/back/773-flying.png and b/public/images/pokemon/exp/back/773-flying.png differ diff --git a/public/images/pokemon/exp/back/773-ghost.png b/public/images/pokemon/exp/back/773-ghost.png index 3d61e58d6d0..6d20decd560 100644 Binary files a/public/images/pokemon/exp/back/773-ghost.png and b/public/images/pokemon/exp/back/773-ghost.png differ diff --git a/public/images/pokemon/exp/back/773-grass.png b/public/images/pokemon/exp/back/773-grass.png index 424528d35b9..647bd0ff269 100644 Binary files a/public/images/pokemon/exp/back/773-grass.png and b/public/images/pokemon/exp/back/773-grass.png differ diff --git a/public/images/pokemon/exp/back/773-ground.png b/public/images/pokemon/exp/back/773-ground.png index e6f562ef149..bc1917a0bf1 100644 Binary files a/public/images/pokemon/exp/back/773-ground.png and b/public/images/pokemon/exp/back/773-ground.png differ diff --git a/public/images/pokemon/exp/back/773-ice.png b/public/images/pokemon/exp/back/773-ice.png index 1a07f4c409d..0777e84600a 100644 Binary files a/public/images/pokemon/exp/back/773-ice.png and b/public/images/pokemon/exp/back/773-ice.png differ diff --git a/public/images/pokemon/exp/back/773-poison.png b/public/images/pokemon/exp/back/773-poison.png index c1671ed4e7e..87b6a0565ef 100644 Binary files a/public/images/pokemon/exp/back/773-poison.png and b/public/images/pokemon/exp/back/773-poison.png differ diff --git a/public/images/pokemon/exp/back/773-psychic.png b/public/images/pokemon/exp/back/773-psychic.png index 536ae0dc094..ec237babefe 100644 Binary files a/public/images/pokemon/exp/back/773-psychic.png and b/public/images/pokemon/exp/back/773-psychic.png differ diff --git a/public/images/pokemon/exp/back/773-rock.png b/public/images/pokemon/exp/back/773-rock.png index df9896c3474..fd39b9b2d57 100644 Binary files a/public/images/pokemon/exp/back/773-rock.png and b/public/images/pokemon/exp/back/773-rock.png differ diff --git a/public/images/pokemon/exp/back/773-steel.png b/public/images/pokemon/exp/back/773-steel.png index 90d784486b9..1f103026a1b 100644 Binary files a/public/images/pokemon/exp/back/773-steel.png and b/public/images/pokemon/exp/back/773-steel.png differ diff --git a/public/images/pokemon/exp/back/773-water.png b/public/images/pokemon/exp/back/773-water.png index af2332e315a..48c32f74998 100644 Binary files a/public/images/pokemon/exp/back/773-water.png and b/public/images/pokemon/exp/back/773-water.png differ diff --git a/public/images/pokemon/exp/back/773.png b/public/images/pokemon/exp/back/773.png index ab0a7285c8c..ac35cb8a7ec 100644 Binary files a/public/images/pokemon/exp/back/773.png and b/public/images/pokemon/exp/back/773.png differ diff --git a/public/images/pokemon/exp/back/774-blue.json b/public/images/pokemon/exp/back/774-blue.json index ef8a07357cc..3cc29d809f8 100644 --- a/public/images/pokemon/exp/back/774-blue.json +++ b/public/images/pokemon/exp/back/774-blue.json @@ -3,1992 +3,765 @@ { "image": "774-blue.png", "format": "RGBA8888", - "size": { - "w": 328, - "h": 328 - }, + "size": {"w": 328,"h": 328}, "scale": 1, "frames": [ { "filename": "0011.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 11, - "y": 10, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 11,"y": 10,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 0,"w": 41,"h": 37} }, { "filename": "0012.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 0,"w": 41,"h": 37} }, { "filename": "0013.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 41, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 41,"y": 0,"w": 41,"h": 37} }, { "filename": "0018.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 35, - "y": 8, - "w": 41, - "h": 37 - }, - "frame": { - "x": 82, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 35,"y": 8,"w": 41,"h": 37}, + "frame": {"x": 82,"y": 0,"w": 41,"h": 37} }, { "filename": "0032.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 123, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 123,"y": 0,"w": 41,"h": 37} }, { "filename": "0033.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 164, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 164,"y": 0,"w": 41,"h": 37} }, { "filename": "0044.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 16, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 205, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 16,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 205,"y": 0,"w": 41,"h": 37} }, { "filename": "0058.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 11, - "y": 10, - "w": 41, - "h": 37 - }, - "frame": { - "x": 246, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 11,"y": 10,"w": 41,"h": 37}, + "frame": {"x": 246,"y": 0,"w": 41,"h": 37} }, { "filename": "0059.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 287, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 287,"y": 0,"w": 41,"h": 37} }, { "filename": "0079.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 287, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 287,"y": 0,"w": 41,"h": 37} }, { "filename": "0060.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 37, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 37,"w": 41,"h": 37} }, { "filename": "0080.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 37, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 37,"w": 41,"h": 37} }, { "filename": "0065.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 35, - "y": 8, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 74, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 35,"y": 8,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 74,"w": 41,"h": 37} }, { "filename": "0094.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 14, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 111, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 111,"w": 41,"h": 37} }, { "filename": "0017.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 6, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 148, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 148,"w": 37,"h": 39} }, { "filename": "0037.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 6, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 187, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 187,"w": 37,"h": 39} }, { "filename": "0045.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 9, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 226, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 9,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 226,"w": 37,"h": 39} }, { "filename": "0064.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 6, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 265, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 265,"w": 37,"h": 39} }, { "filename": "0084.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 7, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 265, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 7,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 265,"w": 37,"h": 39} }, { "filename": "0081.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 39 - }, - "frame": { - "x": 37, - "y": 148, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 39}, + "frame": {"x": 37,"y": 148,"w": 37,"h": 39} }, { "filename": "0093.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 16, - "y": 9, - "w": 37, - "h": 39 - }, - "frame": { - "x": 41, - "y": 37, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 16,"y": 9,"w": 37,"h": 39}, + "frame": {"x": 41,"y": 37,"w": 37,"h": 39} }, { "filename": "0001.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 41, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 41,"y": 76,"w": 39,"h": 37} }, { "filename": "0086.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 41, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 41,"y": 76,"w": 39,"h": 37} }, { "filename": "0002.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 78,"y": 37,"w": 39,"h": 37} }, { "filename": "0087.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 78,"y": 37,"w": 39,"h": 37} }, { "filename": "0009.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 5, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 41, - "y": 113, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 41,"y": 113,"w": 39,"h": 35} }, { "filename": "0003.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 4, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 187, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 4,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 187,"w": 39,"h": 37} }, { "filename": "0004.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 3, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 74, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 74,"y": 148,"w": 39,"h": 37} }, { "filename": "0024.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 74, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 74,"y": 148,"w": 39,"h": 37} }, { "filename": "0010.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 10, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 80, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 10,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 80,"y": 74,"w": 39,"h": 37} }, { "filename": "0019.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 117,"y": 37,"w": 39,"h": 37} }, { "filename": "0089.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 117,"y": 37,"w": 39,"h": 37} }, { "filename": "0020.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 80, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 80,"y": 111,"w": 39,"h": 37} }, { "filename": "0021.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 224, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 224,"w": 39,"h": 37} }, { "filename": "0066.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 224, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 224,"w": 39,"h": 37} }, { "filename": "0022.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 261, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 261,"w": 39,"h": 37} }, { "filename": "0067.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 261, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 261,"w": 39,"h": 37} }, { "filename": "0023.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 14, - "y": 5, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 5,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 185,"w": 39,"h": 37} }, { "filename": "0030.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 113, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 9,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 113,"y": 148,"w": 39,"h": 37} }, { "filename": "0031.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 119, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 119,"y": 74,"w": 39,"h": 37} }, { "filename": "0038.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 36, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 36,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0068.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0078.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0088.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0039.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 119, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 119,"y": 111,"w": 39,"h": 37} }, { "filename": "0040.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 222, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 222,"w": 39,"h": 37} }, { "filename": "0085.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 36, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 222, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 36,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 222,"w": 39,"h": 37} }, { "filename": "0041.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} }, { "filename": "0042.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} }, { "filename": "0043.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} }, { "filename": "0048.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} }, { "filename": "0049.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} }, { "filename": "0047.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 6,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} }, { "filename": "0051.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 3, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} }, { "filename": "0091.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 6,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} }, { "filename": "0050.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 4, - "w": 39, - "h": 37 - }, - "frame": { - "x": 152, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 4,"w": 39,"h": 37}, + "frame": {"x": 152,"y": 148,"w": 39,"h": 37} }, { "filename": "0057.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 10, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 158, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 10,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 158,"y": 74,"w": 39,"h": 37} }, { "filename": "0069.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 195,"y": 37,"w": 39,"h": 37} }, { "filename": "0070.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 14, - "y": 5, - "w": 39, - "h": 37 - }, - "frame": { - "x": 158, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 5,"w": 39,"h": 37}, + "frame": {"x": 158,"y": 111,"w": 39,"h": 37} }, { "filename": "0071.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 222, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 222,"w": 39,"h": 37} }, { "filename": "0077.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 259, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 9,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 259,"w": 39,"h": 37} }, { "filename": "0090.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 191, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 191,"y": 148,"w": 39,"h": 37} }, { "filename": "0014.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 38 - }, - "frame": { - "x": 197, - "y": 74, - "w": 37, - "h": 38 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 197,"y": 74,"w": 37,"h": 38} }, { "filename": "0034.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 38 - }, - "frame": { - "x": 197, - "y": 74, - "w": 37, - "h": 38 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 197,"y": 74,"w": 37,"h": 38} }, { "filename": "0005.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 39, - "h": 36 - }, - "frame": { - "x": 197, - "y": 112, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 39,"h": 36}, + "frame": {"x": 197,"y": 112,"w": 39,"h": 36} }, { "filename": "0061.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 38 - }, - "frame": { - "x": 234, - "y": 37, - "w": 37, - "h": 38 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 234,"y": 37,"w": 37,"h": 38} }, { "filename": "0008.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 234, - "y": 75, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 1,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 234,"y": 75,"w": 39,"h": 36} }, { "filename": "0028.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 234, - "y": 75, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 234,"y": 75,"w": 39,"h": 36} }, { "filename": "0025.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 7, - "w": 39, - "h": 36 - }, - "frame": { - "x": 271, - "y": 37, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 7,"w": 39,"h": 36}, + "frame": {"x": 271,"y": 37,"w": 39,"h": 36} }, { "filename": "0046.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 19, - "y": 10, - "w": 39, - "h": 36 - }, - "frame": { - "x": 273, - "y": 73, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 19,"y": 10,"w": 39,"h": 36}, + "frame": {"x": 273,"y": 73,"w": 39,"h": 36} }, { "filename": "0052.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 8, - "w": 39, - "h": 36 - }, - "frame": { - "x": 273, - "y": 109, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 1,"y": 8,"w": 39,"h": 36}, + "frame": {"x": 273,"y": 109,"w": 39,"h": 36} }, { "filename": "0015.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 236, - "y": 111, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 236,"y": 111,"w": 36,"h": 39} }, { "filename": "0035.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 236, - "y": 111, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 236,"y": 111,"w": 36,"h": 39} }, { "filename": "0053.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 39, - "h": 36 - }, - "frame": { - "x": 272, - "y": 145, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 39,"h": 36}, + "frame": {"x": 272,"y": 145,"w": 39,"h": 36} }, { "filename": "0054.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 39, - "h": 36 - }, - "frame": { - "x": 230, - "y": 150, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 39,"h": 36}, + "frame": {"x": 230,"y": 150,"w": 39,"h": 36} }, { "filename": "0055.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 269, - "y": 181, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 269,"y": 181,"w": 39,"h": 36} }, { "filename": "0075.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 269, - "y": 181, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 269,"y": 181,"w": 39,"h": 36} }, { "filename": "0072.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 7, - "w": 39, - "h": 36 - }, - "frame": { - "x": 154, - "y": 185, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 7,"w": 39,"h": 36}, + "frame": {"x": 154,"y": 185,"w": 39,"h": 36} }, { "filename": "0016.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 193, - "y": 185, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 185,"w": 36,"h": 39} }, { "filename": "0036.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 193, - "y": 185, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 185,"w": 36,"h": 39} }, { "filename": "0092.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 18, - "y": 10, - "w": 39, - "h": 36 - }, - "frame": { - "x": 154, - "y": 221, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 18,"y": 10,"w": 39,"h": 36}, + "frame": {"x": 154,"y": 221,"w": 39,"h": 36} }, { "filename": "0062.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 229, - "y": 186, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 229,"y": 186,"w": 36,"h": 39} }, { "filename": "0082.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 2, - "w": 36, - "h": 39 - }, - "frame": { - "x": 229, - "y": 186, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 2,"w": 36,"h": 39}, + "frame": {"x": 229,"y": 186,"w": 36,"h": 39} }, { "filename": "0063.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 193, - "y": 224, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 224,"w": 36,"h": 39} }, { "filename": "0083.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 2, - "w": 36, - "h": 39 - }, - "frame": { - "x": 193, - "y": 224, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 2,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 224,"w": 36,"h": 39} }, { "filename": "0006.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 38, - "h": 36 - }, - "frame": { - "x": 154, - "y": 257, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 38,"h": 36}, + "frame": {"x": 154,"y": 257,"w": 38,"h": 36} }, { "filename": "0029.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 154, - "y": 293, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 154,"y": 293,"w": 39,"h": 35} }, { "filename": "0007.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 38, - "h": 36 - }, - "frame": { - "x": 265, - "y": 217, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 38,"h": 36}, + "frame": {"x": 265,"y": 217,"w": 38,"h": 36} }, { "filename": "0026.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 265, - "y": 217, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 265,"y": 217,"w": 38,"h": 36} }, { "filename": "0027.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 229, - "y": 253, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 229,"y": 253,"w": 38,"h": 36} }, { "filename": "0073.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 267, - "y": 253, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 267,"y": 253,"w": 38,"h": 36} }, { "filename": "0074.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 193, - "y": 289, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 193,"y": 289,"w": 38,"h": 36} }, { "filename": "0056.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 231, - "y": 289, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 231,"y": 289,"w": 39,"h": 35} }, { "filename": "0076.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 231, - "y": 289, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 231,"y": 289,"w": 39,"h": 35} } ] } ], - "meta": { + "meta": { "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:5cc4fec83f16203e48fd66be4a79dd92:517dfd4a1b1fe0a77013b770107f6610:0787168dbe37404ac3aa22b487979d47$" + "version": "3.0"} } -} diff --git a/public/images/pokemon/exp/back/774-blue.png b/public/images/pokemon/exp/back/774-blue.png index 11e561a7843..934cc4b461d 100644 Binary files a/public/images/pokemon/exp/back/774-blue.png and b/public/images/pokemon/exp/back/774-blue.png differ diff --git a/public/images/pokemon/exp/back/774-green.json b/public/images/pokemon/exp/back/774-green.json index e4b5d15db4e..21c0498db65 100644 --- a/public/images/pokemon/exp/back/774-green.json +++ b/public/images/pokemon/exp/back/774-green.json @@ -3,1992 +3,765 @@ { "image": "774-green.png", "format": "RGBA8888", - "size": { - "w": 362, - "h": 362 - }, + "size": {"w": 328,"h": 328}, "scale": 1, "frames": [ - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 96, - "h": 64 - }, - "frame": { - "x": 0, - "y": 0, - "w": 96, - "h": 64 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 21, - "w": 93, - "h": 39 - }, - "frame": { - "x": 96, - "y": 0, - "w": 93, - "h": 39 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 21, - "w": 93, - "h": 39 - }, - "frame": { - "x": 96, - "y": 0, - "w": 93, - "h": 39 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 21, - "w": 93, - "h": 39 - }, - "frame": { - "x": 189, - "y": 0, - "w": 93, - "h": 39 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 21, - "w": 93, - "h": 39 - }, - "frame": { - "x": 189, - "y": 0, - "w": 93, - "h": 39 - } - }, { "filename": "0011.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 23, - "y": 30, - "w": 41, - "h": 37 - }, - "frame": { - "x": 282, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 11,"y": 10,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 0,"w": 41,"h": 37} }, { "filename": "0012.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 29, - "y": 27, - "w": 41, - "h": 37 - }, - "frame": { - "x": 282, - "y": 0, - "w": 41, - "h": 37 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 25, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 323, - "y": 0, - "w": 39, - "h": 37 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 33, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 323, - "y": 0, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 0,"w": 41,"h": 37} }, { "filename": "0013.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 40, - "y": 20, - "w": 41, - "h": 37 - }, - "frame": { - "x": 282, - "y": 37, - "w": 41, - "h": 37 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 25, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 323, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 33, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 323, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 21, - "w": 93, - "h": 39 - }, - "frame": { - "x": 96, - "y": 39, - "w": 93, - "h": 39 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 22, - "w": 93, - "h": 39 - }, - "frame": { - "x": 96, - "y": 39, - "w": 93, - "h": 39 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 21, - "w": 93, - "h": 39 - }, - "frame": { - "x": 0, - "y": 64, - "w": 93, - "h": 39 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 22, - "w": 93, - "h": 39 - }, - "frame": { - "x": 0, - "y": 64, - "w": 93, - "h": 39 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 19, - "w": 91, - "h": 39 - }, - "frame": { - "x": 189, - "y": 39, - "w": 91, - "h": 39 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 19, - "w": 91, - "h": 39 - }, - "frame": { - "x": 189, - "y": 39, - "w": 91, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 41,"y": 0,"w": 41,"h": 37} }, { "filename": "0018.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 47, - "y": 28, - "w": 41, - "h": 37 - }, - "frame": { - "x": 280, - "y": 74, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 35,"y": 8,"w": 41,"h": 37}, + "frame": {"x": 82,"y": 0,"w": 41,"h": 37} }, { "filename": "0032.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 29, - "y": 27, - "w": 41, - "h": 37 - }, - "frame": { - "x": 321, - "y": 74, - "w": 41, - "h": 37 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 26, - "w": 91, - "h": 39 - }, - "frame": { - "x": 93, - "y": 78, - "w": 91, - "h": 39 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 26, - "w": 91, - "h": 39 - }, - "frame": { - "x": 0, - "y": 103, - "w": 91, - "h": 39 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 19, - "w": 91, - "h": 39 - }, - "frame": { - "x": 184, - "y": 78, - "w": 91, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 123,"y": 0,"w": 41,"h": 37} }, { "filename": "0033.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 40, - "y": 20, - "w": 41, - "h": 37 - }, - "frame": { - "x": 275, - "y": 111, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 164,"y": 0,"w": 41,"h": 37} }, { "filename": "0044.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 28, - "y": 27, - "w": 41, - "h": 37 - }, - "frame": { - "x": 316, - "y": 111, - "w": 41, - "h": 37 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 26, - "w": 91, - "h": 39 - }, - "frame": { - "x": 91, - "y": 117, - "w": 91, - "h": 39 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 27, - "w": 91, - "h": 39 - }, - "frame": { - "x": 91, - "y": 117, - "w": 91, - "h": 39 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 20, - "w": 91, - "h": 39 - }, - "frame": { - "x": 0, - "y": 142, - "w": 91, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 16,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 205,"y": 0,"w": 41,"h": 37} }, { "filename": "0058.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 23, - "y": 30, - "w": 41, - "h": 37 - }, - "frame": { - "x": 182, - "y": 117, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 11,"y": 10,"w": 41,"h": 37}, + "frame": {"x": 246,"y": 0,"w": 41,"h": 37} }, { "filename": "0059.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 29, - "y": 27, - "w": 41, - "h": 37 - }, - "frame": { - "x": 223, - "y": 117, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 287,"y": 0,"w": 41,"h": 37} }, { "filename": "0079.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 29, - "y": 27, - "w": 41, - "h": 37 - }, - "frame": { - "x": 223, - "y": 117, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 287,"y": 0,"w": 41,"h": 37} }, { "filename": "0060.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 40, - "y": 20, - "w": 41, - "h": 37 - }, - "frame": { - "x": 264, - "y": 148, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 37,"w": 41,"h": 37} }, { "filename": "0080.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 40, - "y": 20, - "w": 41, - "h": 37 - }, - "frame": { - "x": 264, - "y": 148, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 37,"w": 41,"h": 37} }, { "filename": "0065.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 47, - "y": 28, - "w": 41, - "h": 37 - }, - "frame": { - "x": 305, - "y": 148, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 35,"y": 8,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 74,"w": 41,"h": 37} }, { - "filename": "0003.png", + "filename": "0094.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 25, - "y": 24, - "w": 39, - "h": 37 - }, - "frame": { - "x": 182, - "y": 154, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 111,"w": 41,"h": 37} }, { - "filename": "0004.png", + "filename": "0017.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 15, - "y": 22, - "w": 39, - "h": 37 - }, - "frame": { - "x": 221, - "y": 154, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 148,"w": 37,"h": 39} }, { - "filename": "0024.png", + "filename": "0037.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 17, - "y": 22, - "w": 39, - "h": 37 - }, - "frame": { - "x": 221, - "y": 154, - "w": 39, - "h": 37 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 22, - "y": 30, - "w": 39, - "h": 37 - }, - "frame": { - "x": 260, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 33, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 299, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 29, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 299, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 33, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 91, - "y": 156, - "w": 39, - "h": 37 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 29, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 130, - "y": 156, - "w": 39, - "h": 37 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 33, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 130, - "y": 156, - "w": 39, - "h": 37 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 29, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 169, - "y": 191, - "w": 39, - "h": 37 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 33, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 169, - "y": 191, - "w": 39, - "h": 37 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 26, - "y": 25, - "w": 39, - "h": 37 - }, - "frame": { - "x": 208, - "y": 191, - "w": 39, - "h": 37 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 21, - "y": 30, - "w": 39, - "h": 37 - }, - "frame": { - "x": 247, - "y": 222, - "w": 39, - "h": 37 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 25, - "y": 30, - "w": 39, - "h": 37 - }, - "frame": { - "x": 286, - "y": 222, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 187,"w": 37,"h": 39} }, { "filename": "0045.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 29, - "y": 29, - "w": 37, - "h": 39 - }, - "frame": { - "x": 325, - "y": 222, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 9,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 226,"w": 37,"h": 39} }, { - "filename": "0038.png", + "filename": "0064.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 48, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 0, - "y": 181, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 265,"w": 37,"h": 39} }, { - "filename": "0068.png", + "filename": "0084.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 29, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 0, - "y": 181, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 7,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 265,"w": 37,"h": 39} }, { - "filename": "0078.png", + "filename": "0081.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 25, - "y": 30, - "w": 39, - "h": 37 - }, - "frame": { - "x": 0, - "y": 181, - "w": 39, - "h": 37 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 29, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 0, - "y": 181, - "w": 39, - "h": 37 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 33, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 39, - "y": 181, - "w": 39, - "h": 37 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 33, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 193, - "w": 39, - "h": 37 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 48, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 193, - "w": 39, - "h": 37 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 29, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 193, - "w": 39, - "h": 37 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 29, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 193, - "w": 39, - "h": 37 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 29, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 193, - "w": 39, - "h": 37 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 29, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 193, - "w": 39, - "h": 37 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 29, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 193, - "w": 39, - "h": 37 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 29, - "y": 26, - "w": 39, - "h": 37 - }, - "frame": { - "x": 0, - "y": 218, - "w": 39, - "h": 37 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 15, - "y": 22, - "w": 39, - "h": 37 - }, - "frame": { - "x": 0, - "y": 218, - "w": 39, - "h": 37 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 29, - "y": 26, - "w": 39, - "h": 37 - }, - "frame": { - "x": 0, - "y": 218, - "w": 39, - "h": 37 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 25, - "y": 24, - "w": 39, - "h": 37 - }, - "frame": { - "x": 39, - "y": 218, - "w": 39, - "h": 37 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 22, - "y": 30, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 228, - "w": 39, - "h": 37 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 29, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 228, - "w": 39, - "h": 37 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 26, - "y": 25, - "w": 39, - "h": 37 - }, - "frame": { - "x": 234, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 17, - "y": 22, - "w": 39, - "h": 37 - }, - "frame": { - "x": 273, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 21, - "y": 30, - "w": 39, - "h": 37 - }, - "frame": { - "x": 312, - "y": 261, - "w": 39, - "h": 37 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 29, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 230, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 39}, + "frame": {"x": 37,"y": 148,"w": 37,"h": 39} }, { "filename": "0093.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 28, - "y": 29, - "w": 37, - "h": 39 - }, - "frame": { - "x": 117, - "y": 230, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 16,"y": 9,"w": 37,"h": 39}, + "frame": {"x": 41,"y": 37,"w": 37,"h": 39} }, { - "filename": "0005.png", + "filename": "0001.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 12, - "y": 28, - "w": 39, - "h": 36 - }, - "frame": { - "x": 154, - "y": 265, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 41,"y": 76,"w": 39,"h": 37} }, { - "filename": "0006.png", + "filename": "0086.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 11, - "y": 29, - "w": 39, - "h": 36 - }, - "frame": { - "x": 193, - "y": 265, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 41,"y": 76,"w": 39,"h": 37} }, { - "filename": "0052.png", + "filename": "0002.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 13, - "y": 28, - "w": 39, - "h": 36 - }, - "frame": { - "x": 193, - "y": 265, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 78,"y": 37,"w": 39,"h": 37} }, { - "filename": "0007.png", + "filename": "0087.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 11, - "y": 29, - "w": 39, - "h": 36 - }, - "frame": { - "x": 232, - "y": 296, - "w": 39, - "h": 36 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 12, - "y": 27, - "w": 39, - "h": 36 - }, - "frame": { - "x": 232, - "y": 296, - "w": 39, - "h": 36 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 11, - "y": 28, - "w": 39, - "h": 36 - }, - "frame": { - "x": 232, - "y": 296, - "w": 39, - "h": 36 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 13, - "y": 31, - "w": 39, - "h": 36 - }, - "frame": { - "x": 271, - "y": 296, - "w": 39, - "h": 36 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 14, - "y": 31, - "w": 39, - "h": 36 - }, - "frame": { - "x": 271, - "y": 296, - "w": 39, - "h": 36 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 11, - "y": 28, - "w": 39, - "h": 36 - }, - "frame": { - "x": 271, - "y": 296, - "w": 39, - "h": 36 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 11, - "y": 28, - "w": 39, - "h": 36 - }, - "frame": { - "x": 310, - "y": 298, - "w": 39, - "h": 36 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 31, - "y": 30, - "w": 39, - "h": 36 - }, - "frame": { - "x": 0, - "y": 255, - "w": 39, - "h": 36 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 12, - "y": 29, - "w": 39, - "h": 36 - }, - "frame": { - "x": 39, - "y": 255, - "w": 39, - "h": 36 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 12, - "y": 29, - "w": 39, - "h": 36 - }, - "frame": { - "x": 78, - "y": 267, - "w": 39, - "h": 36 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 14, - "y": 31, - "w": 39, - "h": 36 - }, - "frame": { - "x": 0, - "y": 291, - "w": 39, - "h": 36 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 14, - "y": 31, - "w": 39, - "h": 36 - }, - "frame": { - "x": 0, - "y": 291, - "w": 39, - "h": 36 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 12, - "y": 27, - "w": 39, - "h": 36 - }, - "frame": { - "x": 39, - "y": 291, - "w": 39, - "h": 36 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 11, - "y": 28, - "w": 39, - "h": 36 - }, - "frame": { - "x": 117, - "y": 301, - "w": 39, - "h": 36 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 30, - "y": 30, - "w": 39, - "h": 36 - }, - "frame": { - "x": 78, - "y": 303, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 78,"y": 37,"w": 39,"h": 37} }, { "filename": "0009.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 17, - "y": 35, - "w": 39, - "h": 35 - }, - "frame": { - "x": 0, - "y": 327, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 41,"y": 113,"w": 39,"h": 35} + }, + { + "filename": "0003.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 4,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 187,"w": 39,"h": 37} + }, + { + "filename": "0004.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 74,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0024.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 74,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0010.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 10,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 80,"y": 74,"w": 39,"h": 37} + }, + { + "filename": "0019.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 117,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0089.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 117,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0020.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 80,"y": 111,"w": 39,"h": 37} + }, + { + "filename": "0021.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 224,"w": 39,"h": 37} + }, + { + "filename": "0066.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 224,"w": 39,"h": 37} + }, + { + "filename": "0022.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 261,"w": 39,"h": 37} + }, + { + "filename": "0067.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 261,"w": 39,"h": 37} + }, + { + "filename": "0023.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 5,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0030.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 9,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 113,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0031.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 119,"y": 74,"w": 39,"h": 37} + }, + { + "filename": "0038.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 36,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0068.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0078.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0088.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0039.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 119,"y": 111,"w": 39,"h": 37} + }, + { + "filename": "0040.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 222,"w": 39,"h": 37} + }, + { + "filename": "0085.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 36,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 222,"w": 39,"h": 37} + }, + { + "filename": "0041.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0042.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0043.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0048.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0049.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0047.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 6,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0051.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0091.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 6,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0050.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 4,"w": 39,"h": 37}, + "frame": {"x": 152,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0057.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 10,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 158,"y": 74,"w": 39,"h": 37} + }, + { + "filename": "0069.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 195,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0070.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 5,"w": 39,"h": 37}, + "frame": {"x": 158,"y": 111,"w": 39,"h": 37} + }, + { + "filename": "0071.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 222,"w": 39,"h": 37} + }, + { + "filename": "0077.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 9,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0090.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 191,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0014.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 197,"y": 74,"w": 37,"h": 38} + }, + { + "filename": "0034.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 197,"y": 74,"w": 37,"h": 38} + }, + { + "filename": "0005.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 39,"h": 36}, + "frame": {"x": 197,"y": 112,"w": 39,"h": 36} + }, + { + "filename": "0061.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 234,"y": 37,"w": 37,"h": 38} + }, + { + "filename": "0008.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 1,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 234,"y": 75,"w": 39,"h": 36} + }, + { + "filename": "0028.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 234,"y": 75,"w": 39,"h": 36} + }, + { + "filename": "0025.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 7,"w": 39,"h": 36}, + "frame": {"x": 271,"y": 37,"w": 39,"h": 36} + }, + { + "filename": "0046.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 19,"y": 10,"w": 39,"h": 36}, + "frame": {"x": 273,"y": 73,"w": 39,"h": 36} + }, + { + "filename": "0052.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 1,"y": 8,"w": 39,"h": 36}, + "frame": {"x": 273,"y": 109,"w": 39,"h": 36} + }, + { + "filename": "0015.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 236,"y": 111,"w": 36,"h": 39} + }, + { + "filename": "0035.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 236,"y": 111,"w": 36,"h": 39} + }, + { + "filename": "0053.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 39,"h": 36}, + "frame": {"x": 272,"y": 145,"w": 39,"h": 36} + }, + { + "filename": "0054.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 39,"h": 36}, + "frame": {"x": 230,"y": 150,"w": 39,"h": 36} + }, + { + "filename": "0055.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 269,"y": 181,"w": 39,"h": 36} + }, + { + "filename": "0075.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 269,"y": 181,"w": 39,"h": 36} + }, + { + "filename": "0072.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 7,"w": 39,"h": 36}, + "frame": {"x": 154,"y": 185,"w": 39,"h": 36} + }, + { + "filename": "0016.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 185,"w": 36,"h": 39} + }, + { + "filename": "0036.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 185,"w": 36,"h": 39} + }, + { + "filename": "0092.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 18,"y": 10,"w": 39,"h": 36}, + "frame": {"x": 154,"y": 221,"w": 39,"h": 36} + }, + { + "filename": "0062.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 229,"y": 186,"w": 36,"h": 39} + }, + { + "filename": "0082.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 2,"w": 36,"h": 39}, + "frame": {"x": 229,"y": 186,"w": 36,"h": 39} + }, + { + "filename": "0063.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 224,"w": 36,"h": 39} + }, + { + "filename": "0083.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 2,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 224,"w": 36,"h": 39} + }, + { + "filename": "0006.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 38,"h": 36}, + "frame": {"x": 154,"y": 257,"w": 38,"h": 36} }, { "filename": "0029.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 18, - "y": 35, - "w": 39, - "h": 35 - }, - "frame": { - "x": 39, - "y": 327, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 154,"y": 293,"w": 39,"h": 35} + }, + { + "filename": "0007.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 38,"h": 36}, + "frame": {"x": 265,"y": 217,"w": 38,"h": 36} + }, + { + "filename": "0026.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 265,"y": 217,"w": 38,"h": 36} + }, + { + "filename": "0027.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 229,"y": 253,"w": 38,"h": 36} + }, + { + "filename": "0073.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 267,"y": 253,"w": 38,"h": 36} + }, + { + "filename": "0074.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 193,"y": 289,"w": 38,"h": 36} }, { "filename": "0056.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 18, - "y": 35, - "w": 39, - "h": 35 - }, - "frame": { - "x": 156, - "y": 301, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 231,"y": 289,"w": 39,"h": 35} }, { "filename": "0076.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 96, - "h": 70 - }, - "spriteSourceSize": { - "x": 18, - "y": 35, - "w": 39, - "h": 35 - }, - "frame": { - "x": 156, - "y": 301, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 231,"y": 289,"w": 39,"h": 35} } ] } ], "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:ddef2960f0a7ae13fcca5b140cab05e2:9a9de1aafb09ba600bd13369099c4c49:e4b1fffb78b8c0cdc557670bcee043ca$" - } + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0"} } diff --git a/public/images/pokemon/exp/back/774-green.png b/public/images/pokemon/exp/back/774-green.png index fdb51432509..b79aaef0a14 100644 Binary files a/public/images/pokemon/exp/back/774-green.png and b/public/images/pokemon/exp/back/774-green.png differ diff --git a/public/images/pokemon/exp/back/774-indigo.json b/public/images/pokemon/exp/back/774-indigo.json index b4112d07692..bd7fb18a9ea 100644 --- a/public/images/pokemon/exp/back/774-indigo.json +++ b/public/images/pokemon/exp/back/774-indigo.json @@ -3,1992 +3,765 @@ { "image": "774-indigo.png", "format": "RGBA8888", - "size": { - "w": 322, - "h": 322 - }, + "size": {"w": 328,"h": 328}, "scale": 1, "frames": [ - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 58, - "h": 65 - }, - "frame": { - "x": 0, - "y": 0, - "w": 58, - "h": 65 - } - }, { "filename": "0011.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 14, - "y": 31, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 65, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 11,"y": 10,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 0,"w": 41,"h": 37} }, { "filename": "0012.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 20, - "y": 28, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 65, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 0,"w": 41,"h": 37} }, { "filename": "0013.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 31, - "y": 21, - "w": 41, - "h": 37 - }, - "frame": { - "x": 58, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 41,"y": 0,"w": 41,"h": 37} }, { "filename": "0018.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 38, - "y": 29, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 102, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 35,"y": 8,"w": 41,"h": 37}, + "frame": {"x": 82,"y": 0,"w": 41,"h": 37} }, { "filename": "0032.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 20, - "y": 28, - "w": 41, - "h": 37 - }, - "frame": { - "x": 99, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 123,"y": 0,"w": 41,"h": 37} }, { "filename": "0033.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 31, - "y": 21, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 139, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 164,"y": 0,"w": 41,"h": 37} }, { "filename": "0044.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 19, - "y": 28, - "w": 41, - "h": 37 - }, - "frame": { - "x": 140, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 16,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 205,"y": 0,"w": 41,"h": 37} }, { "filename": "0058.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 14, - "y": 31, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 176, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 11,"y": 10,"w": 41,"h": 37}, + "frame": {"x": 246,"y": 0,"w": 41,"h": 37} }, { "filename": "0059.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 20, - "y": 28, - "w": 41, - "h": 37 - }, - "frame": { - "x": 181, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 287,"y": 0,"w": 41,"h": 37} }, { "filename": "0079.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 20, - "y": 28, - "w": 41, - "h": 37 - }, - "frame": { - "x": 181, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 287,"y": 0,"w": 41,"h": 37} }, { "filename": "0060.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 31, - "y": 21, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 213, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 37,"w": 41,"h": 37} }, { "filename": "0080.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 31, - "y": 21, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 213, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 37,"w": 41,"h": 37} }, { "filename": "0065.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 38, - "y": 29, - "w": 41, - "h": 37 - }, - "frame": { - "x": 222, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 35,"y": 8,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 74,"w": 41,"h": 37} }, { - "filename": "0001.png", + "filename": "0094.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 16, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 0, - "y": 250, - "w": 39, - "h": 37 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 24, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 0, - "y": 250, - "w": 39, - "h": 37 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 8, - "y": 36, - "w": 39, - "h": 35 - }, - "frame": { - "x": 0, - "y": 287, - "w": 39, - "h": 35 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 16, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 263, - "y": 0, - "w": 39, - "h": 37 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 24, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 263, - "y": 0, - "w": 39, - "h": 37 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 16, - "y": 25, - "w": 39, - "h": 37 - }, - "frame": { - "x": 58, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 6, - "y": 23, - "w": 39, - "h": 37 - }, - "frame": { - "x": 97, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 8, - "y": 23, - "w": 39, - "h": 37 - }, - "frame": { - "x": 97, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 13, - "y": 31, - "w": 39, - "h": 37 - }, - "frame": { - "x": 136, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 24, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 175, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 20, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 175, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 24, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 214, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 20, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 253, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 24, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 253, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 45, - "y": 20, - "w": 37, - "h": 39 - }, - "frame": { - "x": 41, - "y": 74, - "w": 37, - "h": 39 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 45, - "y": 20, - "w": 37, - "h": 39 - }, - "frame": { - "x": 41, - "y": 74, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 111,"w": 41,"h": 37} }, { "filename": "0017.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 45, - "y": 27, - "w": 37, - "h": 39 - }, - "frame": { - "x": 41, - "y": 113, - "w": 37, - "h": 39 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 20, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 74, - "w": 39, - "h": 37 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 24, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 74, - "w": 39, - "h": 37 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 17, - "y": 26, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 111, - "w": 39, - "h": 37 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 12, - "y": 31, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 74, - "w": 39, - "h": 37 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 16, - "y": 31, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 148,"w": 37,"h": 39} }, { "filename": "0037.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 45, - "y": 27, - "w": 37, - "h": 39 - }, - "frame": { - "x": 41, - "y": 152, - "w": 37, - "h": 39 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 39, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 148, - "w": 39, - "h": 37 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 20, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 148, - "w": 39, - "h": 37 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 16, - "y": 31, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 148, - "w": 39, - "h": 37 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 20, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 148, - "w": 39, - "h": 37 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 24, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 74, - "w": 39, - "h": 37 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 24, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 148, - "w": 39, - "h": 37 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 39, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 148, - "w": 39, - "h": 37 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 20, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 111, - "w": 39, - "h": 37 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 20, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 111, - "w": 39, - "h": 37 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 20, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 111, - "w": 39, - "h": 37 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 20, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 111, - "w": 39, - "h": 37 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 20, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 187,"w": 37,"h": 39} }, { "filename": "0045.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 20, - "y": 30, - "w": 37, - "h": 39 - }, - "frame": { - "x": 41, - "y": 191, - "w": 37, - "h": 39 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 20, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 6, - "y": 23, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 20, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 16, - "y": 25, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 74, - "w": 39, - "h": 37 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 13, - "y": 31, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 148, - "w": 39, - "h": 37 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 45, - "y": 20, - "w": 37, - "h": 39 - }, - "frame": { - "x": 195, - "y": 111, - "w": 37, - "h": 39 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 20, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 17, - "y": 26, - "w": 39, - "h": 37 - }, - "frame": { - "x": 234, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 9,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 226,"w": 37,"h": 39} }, { "filename": "0064.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 45, - "y": 27, - "w": 37, - "h": 39 - }, - "frame": { - "x": 232, - "y": 111, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 265,"w": 37,"h": 39} }, { "filename": "0084.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 45, - "y": 28, - "w": 37, - "h": 39 - }, - "frame": { - "x": 232, - "y": 111, - "w": 37, - "h": 39 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 8, - "y": 23, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 12, - "y": 31, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 150, - "w": 39, - "h": 37 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 3, - "y": 29, - "w": 39, - "h": 36 - }, - "frame": { - "x": 195, - "y": 187, - "w": 39, - "h": 36 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 47, - "y": 22, - "w": 36, - "h": 39 - }, - "frame": { - "x": 234, - "y": 150, - "w": 36, - "h": 39 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 47, - "y": 22, - "w": 36, - "h": 39 - }, - "frame": { - "x": 234, - "y": 150, - "w": 36, - "h": 39 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 2, - "y": 30, - "w": 39, - "h": 36 - }, - "frame": { - "x": 234, - "y": 189, - "w": 39, - "h": 36 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 4, - "y": 29, - "w": 39, - "h": 36 - }, - "frame": { - "x": 234, - "y": 189, - "w": 39, - "h": 36 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 2, - "y": 30, - "w": 39, - "h": 36 - }, - "frame": { - "x": 41, - "y": 230, - "w": 39, - "h": 36 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 3, - "y": 28, - "w": 39, - "h": 36 - }, - "frame": { - "x": 41, - "y": 230, - "w": 39, - "h": 36 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 2, - "y": 29, - "w": 39, - "h": 36 - }, - "frame": { - "x": 41, - "y": 230, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 7,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 265,"w": 37,"h": 39} }, { "filename": "0081.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 45, - "y": 21, - "w": 37, - "h": 39 - }, - "frame": { - "x": 39, - "y": 266, - "w": 37, - "h": 39 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 20, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 80, - "y": 222, - "w": 39, - "h": 37 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 4, - "y": 32, - "w": 39, - "h": 36 - }, - "frame": { - "x": 119, - "y": 222, - "w": 39, - "h": 36 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 5, - "y": 32, - "w": 39, - "h": 36 - }, - "frame": { - "x": 119, - "y": 222, - "w": 39, - "h": 36 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 2, - "y": 29, - "w": 39, - "h": 36 - }, - "frame": { - "x": 119, - "y": 222, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 39}, + "frame": {"x": 37,"y": 148,"w": 37,"h": 39} }, { "filename": "0093.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 19, - "y": 30, - "w": 37, - "h": 39 - }, - "frame": { - "x": 158, - "y": 222, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 16,"y": 9,"w": 37,"h": 39}, + "frame": {"x": 41,"y": 37,"w": 37,"h": 39} }, { - "filename": "0027.png", + "filename": "0001.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 2, - "y": 29, - "w": 39, - "h": 36 - }, - "frame": { - "x": 195, - "y": 223, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 41,"y": 76,"w": 39,"h": 37} }, { - "filename": "0029.png", + "filename": "0086.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 9, - "y": 36, - "w": 39, - "h": 35 - }, - "frame": { - "x": 234, - "y": 225, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 41,"y": 76,"w": 39,"h": 37} }, { - "filename": "0016.png", + "filename": "0002.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 47, - "y": 22, - "w": 36, - "h": 39 - }, - "frame": { - "x": 273, - "y": 74, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 78,"y": 37,"w": 39,"h": 37} }, { - "filename": "0036.png", + "filename": "0087.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 47, - "y": 22, - "w": 36, - "h": 39 - }, - "frame": { - "x": 273, - "y": 74, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 78,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0009.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 41,"y": 113,"w": 39,"h": 35} + }, + { + "filename": "0003.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 4,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 187,"w": 39,"h": 37} + }, + { + "filename": "0004.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 74,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0024.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 74,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0010.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 10,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 80,"y": 74,"w": 39,"h": 37} + }, + { + "filename": "0019.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 117,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0089.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 117,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0020.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 80,"y": 111,"w": 39,"h": 37} + }, + { + "filename": "0021.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 224,"w": 39,"h": 37} + }, + { + "filename": "0066.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 224,"w": 39,"h": 37} + }, + { + "filename": "0022.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 261,"w": 39,"h": 37} + }, + { + "filename": "0067.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 261,"w": 39,"h": 37} + }, + { + "filename": "0023.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 5,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0030.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 9,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 113,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0031.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 119,"y": 74,"w": 39,"h": 37} + }, + { + "filename": "0038.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 36,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0068.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0078.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0088.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0039.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 119,"y": 111,"w": 39,"h": 37} + }, + { + "filename": "0040.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 222,"w": 39,"h": 37} + }, + { + "filename": "0085.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 36,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 222,"w": 39,"h": 37} + }, + { + "filename": "0041.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0042.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0043.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0048.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0049.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0047.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 6,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0051.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0091.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 6,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0050.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 4,"w": 39,"h": 37}, + "frame": {"x": 152,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0057.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 10,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 158,"y": 74,"w": 39,"h": 37} + }, + { + "filename": "0069.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 195,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0070.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 5,"w": 39,"h": 37}, + "frame": {"x": 158,"y": 111,"w": 39,"h": 37} + }, + { + "filename": "0071.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 222,"w": 39,"h": 37} + }, + { + "filename": "0077.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 9,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0090.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 191,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0014.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 197,"y": 74,"w": 37,"h": 38} + }, + { + "filename": "0034.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 197,"y": 74,"w": 37,"h": 38} + }, + { + "filename": "0005.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 39,"h": 36}, + "frame": {"x": 197,"y": 112,"w": 39,"h": 36} + }, + { + "filename": "0061.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 234,"y": 37,"w": 37,"h": 38} + }, + { + "filename": "0008.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 1,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 234,"y": 75,"w": 39,"h": 36} + }, + { + "filename": "0028.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 234,"y": 75,"w": 39,"h": 36} + }, + { + "filename": "0025.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 7,"w": 39,"h": 36}, + "frame": {"x": 271,"y": 37,"w": 39,"h": 36} }, { "filename": "0046.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 22, - "y": 31, - "w": 39, - "h": 36 - }, - "frame": { - "x": 269, - "y": 113, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 19,"y": 10,"w": 39,"h": 36}, + "frame": {"x": 273,"y": 73,"w": 39,"h": 36} }, { - "filename": "0062.png", + "filename": "0052.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 47, - "y": 22, - "w": 36, - "h": 39 - }, - "frame": { - "x": 270, - "y": 149, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 1,"y": 8,"w": 39,"h": 36}, + "frame": {"x": 273,"y": 109,"w": 39,"h": 36} }, { - "filename": "0082.png", + "filename": "0015.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 47, - "y": 23, - "w": 36, - "h": 39 - }, - "frame": { - "x": 270, - "y": 149, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 236,"y": 111,"w": 36,"h": 39} }, { - "filename": "0063.png", + "filename": "0035.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 47, - "y": 22, - "w": 36, - "h": 39 - }, - "frame": { - "x": 273, - "y": 188, - "w": 36, - "h": 39 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 47, - "y": 23, - "w": 36, - "h": 39 - }, - "frame": { - "x": 273, - "y": 188, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 236,"y": 111,"w": 36,"h": 39} }, { "filename": "0053.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 3, - "y": 30, - "w": 39, - "h": 36 - }, - "frame": { - "x": 273, - "y": 227, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 39,"h": 36}, + "frame": {"x": 272,"y": 145,"w": 39,"h": 36} }, { "filename": "0054.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 3, - "y": 30, - "w": 39, - "h": 36 - }, - "frame": { - "x": 80, - "y": 259, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 39,"h": 36}, + "frame": {"x": 230,"y": 150,"w": 39,"h": 36} }, { "filename": "0055.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 5, - "y": 32, - "w": 39, - "h": 36 - }, - "frame": { - "x": 119, - "y": 258, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 269,"y": 181,"w": 39,"h": 36} }, { "filename": "0075.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 5, - "y": 32, - "w": 39, - "h": 36 - }, - "frame": { - "x": 119, - "y": 258, - "w": 39, - "h": 36 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 9, - "y": 36, - "w": 39, - "h": 35 - }, - "frame": { - "x": 158, - "y": 261, - "w": 39, - "h": 35 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 9, - "y": 36, - "w": 39, - "h": 35 - }, - "frame": { - "x": 158, - "y": 261, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 269,"y": 181,"w": 39,"h": 36} }, { "filename": "0072.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 3, - "y": 28, - "w": 39, - "h": 36 - }, - "frame": { - "x": 197, - "y": 260, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 7,"w": 39,"h": 36}, + "frame": {"x": 154,"y": 185,"w": 39,"h": 36} }, { - "filename": "0074.png", + "filename": "0016.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 2, - "y": 29, - "w": 39, - "h": 36 - }, - "frame": { - "x": 236, - "y": 263, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 185,"w": 36,"h": 39} + }, + { + "filename": "0036.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 185,"w": 36,"h": 39} }, { "filename": "0092.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 71 - }, - "spriteSourceSize": { - "x": 21, - "y": 31, - "w": 39, - "h": 36 - }, - "frame": { - "x": 275, - "y": 263, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 18,"y": 10,"w": 39,"h": 36}, + "frame": {"x": 154,"y": 221,"w": 39,"h": 36} + }, + { + "filename": "0062.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 229,"y": 186,"w": 36,"h": 39} + }, + { + "filename": "0082.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 2,"w": 36,"h": 39}, + "frame": {"x": 229,"y": 186,"w": 36,"h": 39} + }, + { + "filename": "0063.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 224,"w": 36,"h": 39} + }, + { + "filename": "0083.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 2,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 224,"w": 36,"h": 39} + }, + { + "filename": "0006.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 38,"h": 36}, + "frame": {"x": 154,"y": 257,"w": 38,"h": 36} + }, + { + "filename": "0029.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 154,"y": 293,"w": 39,"h": 35} + }, + { + "filename": "0007.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 38,"h": 36}, + "frame": {"x": 265,"y": 217,"w": 38,"h": 36} + }, + { + "filename": "0026.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 265,"y": 217,"w": 38,"h": 36} + }, + { + "filename": "0027.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 229,"y": 253,"w": 38,"h": 36} + }, + { + "filename": "0073.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 267,"y": 253,"w": 38,"h": 36} + }, + { + "filename": "0074.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 193,"y": 289,"w": 38,"h": 36} + }, + { + "filename": "0056.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 231,"y": 289,"w": 39,"h": 35} + }, + { + "filename": "0076.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 231,"y": 289,"w": 39,"h": 35} } ] } ], "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:cd71281138861f274ba265b778865b28:fde6f36d6539077e0b88de1c550a9f3f:f6d3104f6cc09a16e2cbfcba30e4d78a$" - } + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0"} } diff --git a/public/images/pokemon/exp/back/774-indigo.png b/public/images/pokemon/exp/back/774-indigo.png index a5130352f4f..979fe3c83a8 100644 Binary files a/public/images/pokemon/exp/back/774-indigo.png and b/public/images/pokemon/exp/back/774-indigo.png differ diff --git a/public/images/pokemon/exp/back/774-orange.json b/public/images/pokemon/exp/back/774-orange.json index 359393f9a78..45e2604bf4e 100644 --- a/public/images/pokemon/exp/back/774-orange.json +++ b/public/images/pokemon/exp/back/774-orange.json @@ -3,1992 +3,765 @@ { "image": "774-orange.png", "format": "RGBA8888", - "size": { - "w": 320, - "h": 320 - }, + "size": {"w": 328,"h": 328}, "scale": 1, "frames": [ - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 58, - "h": 63 - }, - "frame": { - "x": 0, - "y": 0, - "w": 58, - "h": 63 - } - }, { "filename": "0011.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 14, - "y": 29, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 63, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 11,"y": 10,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 0,"w": 41,"h": 37} }, { "filename": "0012.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 20, - "y": 26, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 63, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 0,"w": 41,"h": 37} }, { "filename": "0013.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 31, - "y": 19, - "w": 41, - "h": 37 - }, - "frame": { - "x": 58, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 41,"y": 0,"w": 41,"h": 37} }, { "filename": "0018.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 38, - "y": 27, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 100, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 35,"y": 8,"w": 41,"h": 37}, + "frame": {"x": 82,"y": 0,"w": 41,"h": 37} }, { "filename": "0032.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 20, - "y": 26, - "w": 41, - "h": 37 - }, - "frame": { - "x": 99, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 123,"y": 0,"w": 41,"h": 37} }, { "filename": "0033.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 31, - "y": 19, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 137, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 164,"y": 0,"w": 41,"h": 37} }, { "filename": "0044.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 19, - "y": 26, - "w": 41, - "h": 37 - }, - "frame": { - "x": 140, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 16,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 205,"y": 0,"w": 41,"h": 37} }, { "filename": "0058.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 14, - "y": 29, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 174, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 11,"y": 10,"w": 41,"h": 37}, + "frame": {"x": 246,"y": 0,"w": 41,"h": 37} }, { "filename": "0059.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 20, - "y": 26, - "w": 41, - "h": 37 - }, - "frame": { - "x": 181, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 287,"y": 0,"w": 41,"h": 37} }, { "filename": "0079.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 20, - "y": 26, - "w": 41, - "h": 37 - }, - "frame": { - "x": 181, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 287,"y": 0,"w": 41,"h": 37} }, { "filename": "0060.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 31, - "y": 19, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 211, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 37,"w": 41,"h": 37} }, { "filename": "0080.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 31, - "y": 19, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 211, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 37,"w": 41,"h": 37} }, { "filename": "0065.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 38, - "y": 27, - "w": 41, - "h": 37 - }, - "frame": { - "x": 222, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 35,"y": 8,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 74,"w": 41,"h": 37} }, { - "filename": "0001.png", + "filename": "0094.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 16, - "y": 26, - "w": 39, - "h": 37 - }, - "frame": { - "x": 0, - "y": 248, - "w": 39, - "h": 37 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 24, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 0, - "y": 248, - "w": 39, - "h": 37 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 8, - "y": 34, - "w": 39, - "h": 35 - }, - "frame": { - "x": 0, - "y": 285, - "w": 39, - "h": 35 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 16, - "y": 26, - "w": 39, - "h": 37 - }, - "frame": { - "x": 263, - "y": 0, - "w": 39, - "h": 37 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 24, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 263, - "y": 0, - "w": 39, - "h": 37 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 16, - "y": 23, - "w": 39, - "h": 37 - }, - "frame": { - "x": 58, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 6, - "y": 21, - "w": 39, - "h": 37 - }, - "frame": { - "x": 97, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 8, - "y": 21, - "w": 39, - "h": 37 - }, - "frame": { - "x": 97, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 13, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 136, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 24, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 175, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 20, - "y": 26, - "w": 39, - "h": 37 - }, - "frame": { - "x": 175, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 24, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 214, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 20, - "y": 26, - "w": 39, - "h": 37 - }, - "frame": { - "x": 253, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 24, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 253, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 45, - "y": 18, - "w": 37, - "h": 39 - }, - "frame": { - "x": 41, - "y": 74, - "w": 37, - "h": 39 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 45, - "y": 18, - "w": 37, - "h": 39 - }, - "frame": { - "x": 41, - "y": 74, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 111,"w": 41,"h": 37} }, { "filename": "0017.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 45, - "y": 25, - "w": 37, - "h": 39 - }, - "frame": { - "x": 41, - "y": 113, - "w": 37, - "h": 39 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 20, - "y": 26, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 74, - "w": 39, - "h": 37 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 24, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 74, - "w": 39, - "h": 37 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 17, - "y": 24, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 111, - "w": 39, - "h": 37 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 12, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 74, - "w": 39, - "h": 37 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 16, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 148,"w": 37,"h": 39} }, { "filename": "0037.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 45, - "y": 25, - "w": 37, - "h": 39 - }, - "frame": { - "x": 41, - "y": 152, - "w": 37, - "h": 39 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 39, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 148, - "w": 39, - "h": 37 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 20, - "y": 26, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 148, - "w": 39, - "h": 37 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 16, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 148, - "w": 39, - "h": 37 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 20, - "y": 26, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 148, - "w": 39, - "h": 37 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 24, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 74, - "w": 39, - "h": 37 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 24, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 148, - "w": 39, - "h": 37 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 39, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 148, - "w": 39, - "h": 37 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 20, - "y": 26, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 111, - "w": 39, - "h": 37 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 20, - "y": 26, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 111, - "w": 39, - "h": 37 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 20, - "y": 26, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 111, - "w": 39, - "h": 37 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 20, - "y": 26, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 111, - "w": 39, - "h": 37 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 20, - "y": 26, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 187,"w": 37,"h": 39} }, { "filename": "0045.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 20, - "y": 28, - "w": 37, - "h": 39 - }, - "frame": { - "x": 41, - "y": 191, - "w": 37, - "h": 39 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 20, - "y": 25, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 6, - "y": 21, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 20, - "y": 25, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 16, - "y": 23, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 74, - "w": 39, - "h": 37 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 13, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 148, - "w": 39, - "h": 37 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 45, - "y": 18, - "w": 37, - "h": 39 - }, - "frame": { - "x": 195, - "y": 111, - "w": 37, - "h": 39 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 20, - "y": 26, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 17, - "y": 24, - "w": 39, - "h": 37 - }, - "frame": { - "x": 234, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 9,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 226,"w": 37,"h": 39} }, { "filename": "0064.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 45, - "y": 25, - "w": 37, - "h": 39 - }, - "frame": { - "x": 232, - "y": 111, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 265,"w": 37,"h": 39} }, { "filename": "0084.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 45, - "y": 26, - "w": 37, - "h": 39 - }, - "frame": { - "x": 232, - "y": 111, - "w": 37, - "h": 39 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 8, - "y": 21, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 12, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 150, - "w": 39, - "h": 37 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 3, - "y": 27, - "w": 39, - "h": 36 - }, - "frame": { - "x": 195, - "y": 187, - "w": 39, - "h": 36 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 47, - "y": 20, - "w": 36, - "h": 39 - }, - "frame": { - "x": 234, - "y": 150, - "w": 36, - "h": 39 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 47, - "y": 20, - "w": 36, - "h": 39 - }, - "frame": { - "x": 234, - "y": 150, - "w": 36, - "h": 39 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 2, - "y": 28, - "w": 39, - "h": 36 - }, - "frame": { - "x": 234, - "y": 189, - "w": 39, - "h": 36 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 4, - "y": 27, - "w": 39, - "h": 36 - }, - "frame": { - "x": 234, - "y": 189, - "w": 39, - "h": 36 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 47, - "y": 20, - "w": 36, - "h": 39 - }, - "frame": { - "x": 273, - "y": 74, - "w": 36, - "h": 39 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 47, - "y": 20, - "w": 36, - "h": 39 - }, - "frame": { - "x": 273, - "y": 74, - "w": 36, - "h": 39 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 20, - "y": 26, - "w": 39, - "h": 37 - }, - "frame": { - "x": 269, - "y": 113, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 7,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 265,"w": 37,"h": 39} }, { "filename": "0081.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 45, - "y": 19, - "w": 37, - "h": 39 - }, - "frame": { - "x": 270, - "y": 150, - "w": 37, - "h": 39 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 2, - "y": 28, - "w": 39, - "h": 36 - }, - "frame": { - "x": 273, - "y": 189, - "w": 39, - "h": 36 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 3, - "y": 26, - "w": 39, - "h": 36 - }, - "frame": { - "x": 273, - "y": 189, - "w": 39, - "h": 36 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 2, - "y": 27, - "w": 39, - "h": 36 - }, - "frame": { - "x": 273, - "y": 189, - "w": 39, - "h": 36 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 4, - "y": 30, - "w": 39, - "h": 36 - }, - "frame": { - "x": 41, - "y": 230, - "w": 39, - "h": 36 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 5, - "y": 30, - "w": 39, - "h": 36 - }, - "frame": { - "x": 41, - "y": 230, - "w": 39, - "h": 36 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 2, - "y": 27, - "w": 39, - "h": 36 - }, - "frame": { - "x": 41, - "y": 230, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 39}, + "frame": {"x": 37,"y": 148,"w": 37,"h": 39} }, { "filename": "0093.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 19, - "y": 28, - "w": 37, - "h": 39 - }, - "frame": { - "x": 39, - "y": 266, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 16,"y": 9,"w": 37,"h": 39}, + "frame": {"x": 41,"y": 37,"w": 37,"h": 39} }, { - "filename": "0027.png", + "filename": "0001.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 2, - "y": 27, - "w": 39, - "h": 36 - }, - "frame": { - "x": 80, - "y": 222, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 41,"y": 76,"w": 39,"h": 37} + }, + { + "filename": "0086.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 41,"y": 76,"w": 39,"h": 37} + }, + { + "filename": "0002.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 78,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0087.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 78,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0009.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 41,"y": 113,"w": 39,"h": 35} + }, + { + "filename": "0003.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 4,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 187,"w": 39,"h": 37} + }, + { + "filename": "0004.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 74,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0024.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 74,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0010.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 10,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 80,"y": 74,"w": 39,"h": 37} + }, + { + "filename": "0019.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 117,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0089.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 117,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0020.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 80,"y": 111,"w": 39,"h": 37} + }, + { + "filename": "0021.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 224,"w": 39,"h": 37} + }, + { + "filename": "0066.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 224,"w": 39,"h": 37} + }, + { + "filename": "0022.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 261,"w": 39,"h": 37} + }, + { + "filename": "0067.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 261,"w": 39,"h": 37} + }, + { + "filename": "0023.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 5,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0030.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 9,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 113,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0031.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 119,"y": 74,"w": 39,"h": 37} + }, + { + "filename": "0038.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 36,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0068.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0078.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0088.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0039.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 119,"y": 111,"w": 39,"h": 37} + }, + { + "filename": "0040.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 222,"w": 39,"h": 37} + }, + { + "filename": "0085.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 36,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 222,"w": 39,"h": 37} + }, + { + "filename": "0041.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0042.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0043.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0048.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0049.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0047.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 6,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0051.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0091.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 6,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0050.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 4,"w": 39,"h": 37}, + "frame": {"x": 152,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0057.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 10,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 158,"y": 74,"w": 39,"h": 37} + }, + { + "filename": "0069.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 195,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0070.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 5,"w": 39,"h": 37}, + "frame": {"x": 158,"y": 111,"w": 39,"h": 37} + }, + { + "filename": "0071.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 222,"w": 39,"h": 37} + }, + { + "filename": "0077.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 9,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0090.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 191,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0014.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 197,"y": 74,"w": 37,"h": 38} + }, + { + "filename": "0034.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 197,"y": 74,"w": 37,"h": 38} + }, + { + "filename": "0005.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 39,"h": 36}, + "frame": {"x": 197,"y": 112,"w": 39,"h": 36} + }, + { + "filename": "0061.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 234,"y": 37,"w": 37,"h": 38} + }, + { + "filename": "0008.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 1,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 234,"y": 75,"w": 39,"h": 36} + }, + { + "filename": "0028.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 234,"y": 75,"w": 39,"h": 36} + }, + { + "filename": "0025.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 7,"w": 39,"h": 36}, + "frame": {"x": 271,"y": 37,"w": 39,"h": 36} }, { "filename": "0046.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 22, - "y": 29, - "w": 39, - "h": 36 - }, - "frame": { - "x": 119, - "y": 222, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 19,"y": 10,"w": 39,"h": 36}, + "frame": {"x": 273,"y": 73,"w": 39,"h": 36} }, { - "filename": "0062.png", + "filename": "0052.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 47, - "y": 20, - "w": 36, - "h": 39 - }, - "frame": { - "x": 158, - "y": 222, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 1,"y": 8,"w": 39,"h": 36}, + "frame": {"x": 273,"y": 109,"w": 39,"h": 36} }, { - "filename": "0082.png", + "filename": "0015.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 47, - "y": 21, - "w": 36, - "h": 39 - }, - "frame": { - "x": 158, - "y": 222, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 236,"y": 111,"w": 36,"h": 39} + }, + { + "filename": "0035.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 236,"y": 111,"w": 36,"h": 39} }, { "filename": "0053.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 3, - "y": 28, - "w": 39, - "h": 36 - }, - "frame": { - "x": 194, - "y": 223, - "w": 39, - "h": 36 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 9, - "y": 34, - "w": 39, - "h": 35 - }, - "frame": { - "x": 233, - "y": 225, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 39,"h": 36}, + "frame": {"x": 272,"y": 145,"w": 39,"h": 36} }, { "filename": "0054.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 3, - "y": 28, - "w": 39, - "h": 36 - }, - "frame": { - "x": 272, - "y": 225, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 39,"h": 36}, + "frame": {"x": 230,"y": 150,"w": 39,"h": 36} }, { "filename": "0055.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 5, - "y": 30, - "w": 39, - "h": 36 - }, - "frame": { - "x": 80, - "y": 258, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 269,"y": 181,"w": 39,"h": 36} }, { "filename": "0075.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 5, - "y": 30, - "w": 39, - "h": 36 - }, - "frame": { - "x": 80, - "y": 258, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 269,"y": 181,"w": 39,"h": 36} }, { "filename": "0072.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 3, - "y": 26, - "w": 39, - "h": 36 - }, - "frame": { - "x": 119, - "y": 258, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 7,"w": 39,"h": 36}, + "frame": {"x": 154,"y": 185,"w": 39,"h": 36} }, { - "filename": "0056.png", + "filename": "0016.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 9, - "y": 34, - "w": 39, - "h": 35 - }, - "frame": { - "x": 158, - "y": 261, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 185,"w": 36,"h": 39} }, { - "filename": "0076.png", + "filename": "0036.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 9, - "y": 34, - "w": 39, - "h": 35 - }, - "frame": { - "x": 158, - "y": 261, - "w": 39, - "h": 35 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 47, - "y": 20, - "w": 36, - "h": 39 - }, - "frame": { - "x": 197, - "y": 259, - "w": 36, - "h": 39 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 47, - "y": 21, - "w": 36, - "h": 39 - }, - "frame": { - "x": 197, - "y": 259, - "w": 36, - "h": 39 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 2, - "y": 27, - "w": 39, - "h": 36 - }, - "frame": { - "x": 233, - "y": 260, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 185,"w": 36,"h": 39} }, { "filename": "0092.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 83, - "h": 69 - }, - "spriteSourceSize": { - "x": 21, - "y": 29, - "w": 39, - "h": 36 - }, - "frame": { - "x": 272, - "y": 261, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 18,"y": 10,"w": 39,"h": 36}, + "frame": {"x": 154,"y": 221,"w": 39,"h": 36} + }, + { + "filename": "0062.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 229,"y": 186,"w": 36,"h": 39} + }, + { + "filename": "0082.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 2,"w": 36,"h": 39}, + "frame": {"x": 229,"y": 186,"w": 36,"h": 39} + }, + { + "filename": "0063.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 224,"w": 36,"h": 39} + }, + { + "filename": "0083.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 2,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 224,"w": 36,"h": 39} + }, + { + "filename": "0006.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 38,"h": 36}, + "frame": {"x": 154,"y": 257,"w": 38,"h": 36} + }, + { + "filename": "0029.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 154,"y": 293,"w": 39,"h": 35} + }, + { + "filename": "0007.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 38,"h": 36}, + "frame": {"x": 265,"y": 217,"w": 38,"h": 36} + }, + { + "filename": "0026.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 265,"y": 217,"w": 38,"h": 36} + }, + { + "filename": "0027.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 229,"y": 253,"w": 38,"h": 36} + }, + { + "filename": "0073.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 267,"y": 253,"w": 38,"h": 36} + }, + { + "filename": "0074.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 193,"y": 289,"w": 38,"h": 36} + }, + { + "filename": "0056.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 231,"y": 289,"w": 39,"h": 35} + }, + { + "filename": "0076.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 231,"y": 289,"w": 39,"h": 35} } ] } ], "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:ab4fe2e8d3bfec6b8e7e055e4c528089:fd82d5c8238b032ad6da670791bc6592:44d5ed9bf64302a0edf6c65ea8033c12$" - } + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0"} } diff --git a/public/images/pokemon/exp/back/774-orange.png b/public/images/pokemon/exp/back/774-orange.png index 9dcbff296fd..60b8fb76f4e 100644 Binary files a/public/images/pokemon/exp/back/774-orange.png and b/public/images/pokemon/exp/back/774-orange.png differ diff --git a/public/images/pokemon/exp/back/774-red.json b/public/images/pokemon/exp/back/774-red.json index f5859c4140a..94c5d8ddf83 100644 --- a/public/images/pokemon/exp/back/774-red.json +++ b/public/images/pokemon/exp/back/774-red.json @@ -3,1992 +3,765 @@ { "image": "774-red.png", "format": "RGBA8888", - "size": { - "w": 328, - "h": 328 - }, + "size": {"w": 328,"h": 328}, "scale": 1, "frames": [ { "filename": "0011.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 11, - "y": 10, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 11,"y": 10,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 0,"w": 41,"h": 37} }, { "filename": "0012.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 0,"w": 41,"h": 37} }, { "filename": "0013.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 41, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 41,"y": 0,"w": 41,"h": 37} }, { "filename": "0018.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 35, - "y": 8, - "w": 41, - "h": 37 - }, - "frame": { - "x": 82, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 35,"y": 8,"w": 41,"h": 37}, + "frame": {"x": 82,"y": 0,"w": 41,"h": 37} }, { "filename": "0032.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 123, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 123,"y": 0,"w": 41,"h": 37} }, { "filename": "0033.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 164, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 164,"y": 0,"w": 41,"h": 37} }, { "filename": "0044.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 16, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 205, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 16,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 205,"y": 0,"w": 41,"h": 37} }, { "filename": "0058.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 11, - "y": 10, - "w": 41, - "h": 37 - }, - "frame": { - "x": 246, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 11,"y": 10,"w": 41,"h": 37}, + "frame": {"x": 246,"y": 0,"w": 41,"h": 37} }, { "filename": "0059.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 287, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 287,"y": 0,"w": 41,"h": 37} }, { "filename": "0079.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 287, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 287,"y": 0,"w": 41,"h": 37} }, { "filename": "0060.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 37, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 37,"w": 41,"h": 37} }, { "filename": "0080.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 37, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 37,"w": 41,"h": 37} }, { "filename": "0065.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 35, - "y": 8, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 74, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 35,"y": 8,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 74,"w": 41,"h": 37} }, { "filename": "0094.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 14, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 111, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 111,"w": 41,"h": 37} }, { "filename": "0017.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 6, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 148, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 148,"w": 37,"h": 39} }, { "filename": "0037.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 6, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 187, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 187,"w": 37,"h": 39} }, { "filename": "0045.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 9, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 226, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 9,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 226,"w": 37,"h": 39} }, { "filename": "0064.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 6, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 265, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 265,"w": 37,"h": 39} }, { "filename": "0084.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 7, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 265, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 7,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 265,"w": 37,"h": 39} }, { "filename": "0081.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 39 - }, - "frame": { - "x": 37, - "y": 148, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 39}, + "frame": {"x": 37,"y": 148,"w": 37,"h": 39} }, { "filename": "0093.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 16, - "y": 9, - "w": 37, - "h": 39 - }, - "frame": { - "x": 41, - "y": 37, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 16,"y": 9,"w": 37,"h": 39}, + "frame": {"x": 41,"y": 37,"w": 37,"h": 39} }, { "filename": "0001.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 41, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 41,"y": 76,"w": 39,"h": 37} }, { "filename": "0086.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 41, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 41,"y": 76,"w": 39,"h": 37} }, { "filename": "0002.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 78,"y": 37,"w": 39,"h": 37} }, { "filename": "0087.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 78,"y": 37,"w": 39,"h": 37} }, { "filename": "0009.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 5, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 41, - "y": 113, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 41,"y": 113,"w": 39,"h": 35} }, { "filename": "0003.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 4, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 187, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 4,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 187,"w": 39,"h": 37} }, { "filename": "0004.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 3, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 74, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 74,"y": 148,"w": 39,"h": 37} }, { "filename": "0024.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 74, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 74,"y": 148,"w": 39,"h": 37} }, { "filename": "0010.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 10, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 80, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 10,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 80,"y": 74,"w": 39,"h": 37} }, { "filename": "0019.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 117,"y": 37,"w": 39,"h": 37} }, { "filename": "0089.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 117,"y": 37,"w": 39,"h": 37} }, { "filename": "0020.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 80, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 80,"y": 111,"w": 39,"h": 37} }, { "filename": "0021.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 224, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 224,"w": 39,"h": 37} }, { "filename": "0066.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 224, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 224,"w": 39,"h": 37} }, { "filename": "0022.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 261, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 261,"w": 39,"h": 37} }, { "filename": "0067.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 261, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 261,"w": 39,"h": 37} }, { "filename": "0023.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 14, - "y": 5, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 5,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 185,"w": 39,"h": 37} }, { "filename": "0030.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 113, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 9,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 113,"y": 148,"w": 39,"h": 37} }, { "filename": "0031.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 119, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 119,"y": 74,"w": 39,"h": 37} }, { "filename": "0038.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 36, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 36,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0068.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0078.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0088.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0039.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 119, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 119,"y": 111,"w": 39,"h": 37} }, { "filename": "0040.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 222, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 222,"w": 39,"h": 37} }, { "filename": "0085.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 36, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 222, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 36,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 222,"w": 39,"h": 37} }, { "filename": "0041.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} }, { "filename": "0042.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} }, { "filename": "0043.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} }, { "filename": "0048.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} }, { "filename": "0049.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} }, { "filename": "0047.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 6,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} }, { "filename": "0051.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 3, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} }, { "filename": "0091.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 6,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} }, { "filename": "0050.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 4, - "w": 39, - "h": 37 - }, - "frame": { - "x": 152, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 4,"w": 39,"h": 37}, + "frame": {"x": 152,"y": 148,"w": 39,"h": 37} }, { "filename": "0057.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 10, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 158, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 10,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 158,"y": 74,"w": 39,"h": 37} }, { "filename": "0069.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 195,"y": 37,"w": 39,"h": 37} }, { "filename": "0070.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 14, - "y": 5, - "w": 39, - "h": 37 - }, - "frame": { - "x": 158, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 5,"w": 39,"h": 37}, + "frame": {"x": 158,"y": 111,"w": 39,"h": 37} }, { "filename": "0071.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 222, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 222,"w": 39,"h": 37} }, { "filename": "0077.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 259, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 9,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 259,"w": 39,"h": 37} }, { "filename": "0090.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 191, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 191,"y": 148,"w": 39,"h": 37} }, { "filename": "0014.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 38 - }, - "frame": { - "x": 197, - "y": 74, - "w": 37, - "h": 38 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 197,"y": 74,"w": 37,"h": 38} }, { "filename": "0034.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 38 - }, - "frame": { - "x": 197, - "y": 74, - "w": 37, - "h": 38 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 197,"y": 74,"w": 37,"h": 38} }, { "filename": "0005.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 39, - "h": 36 - }, - "frame": { - "x": 197, - "y": 112, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 39,"h": 36}, + "frame": {"x": 197,"y": 112,"w": 39,"h": 36} }, { "filename": "0061.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 38 - }, - "frame": { - "x": 234, - "y": 37, - "w": 37, - "h": 38 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 234,"y": 37,"w": 37,"h": 38} }, { "filename": "0008.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 234, - "y": 75, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 1,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 234,"y": 75,"w": 39,"h": 36} }, { "filename": "0028.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 234, - "y": 75, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 234,"y": 75,"w": 39,"h": 36} }, { "filename": "0025.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 7, - "w": 39, - "h": 36 - }, - "frame": { - "x": 271, - "y": 37, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 7,"w": 39,"h": 36}, + "frame": {"x": 271,"y": 37,"w": 39,"h": 36} }, { "filename": "0046.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 19, - "y": 10, - "w": 39, - "h": 36 - }, - "frame": { - "x": 273, - "y": 73, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 19,"y": 10,"w": 39,"h": 36}, + "frame": {"x": 273,"y": 73,"w": 39,"h": 36} }, { "filename": "0052.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 8, - "w": 39, - "h": 36 - }, - "frame": { - "x": 273, - "y": 109, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 1,"y": 8,"w": 39,"h": 36}, + "frame": {"x": 273,"y": 109,"w": 39,"h": 36} }, { "filename": "0015.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 236, - "y": 111, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 236,"y": 111,"w": 36,"h": 39} }, { "filename": "0035.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 236, - "y": 111, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 236,"y": 111,"w": 36,"h": 39} }, { "filename": "0053.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 39, - "h": 36 - }, - "frame": { - "x": 272, - "y": 145, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 39,"h": 36}, + "frame": {"x": 272,"y": 145,"w": 39,"h": 36} }, { "filename": "0054.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 39, - "h": 36 - }, - "frame": { - "x": 230, - "y": 150, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 39,"h": 36}, + "frame": {"x": 230,"y": 150,"w": 39,"h": 36} }, { "filename": "0055.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 269, - "y": 181, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 269,"y": 181,"w": 39,"h": 36} }, { "filename": "0075.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 269, - "y": 181, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 269,"y": 181,"w": 39,"h": 36} }, { "filename": "0072.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 7, - "w": 39, - "h": 36 - }, - "frame": { - "x": 154, - "y": 185, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 7,"w": 39,"h": 36}, + "frame": {"x": 154,"y": 185,"w": 39,"h": 36} }, { "filename": "0016.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 193, - "y": 185, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 185,"w": 36,"h": 39} }, { "filename": "0036.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 193, - "y": 185, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 185,"w": 36,"h": 39} }, { "filename": "0092.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 18, - "y": 10, - "w": 39, - "h": 36 - }, - "frame": { - "x": 154, - "y": 221, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 18,"y": 10,"w": 39,"h": 36}, + "frame": {"x": 154,"y": 221,"w": 39,"h": 36} }, { "filename": "0062.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 229, - "y": 186, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 229,"y": 186,"w": 36,"h": 39} }, { "filename": "0082.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 2, - "w": 36, - "h": 39 - }, - "frame": { - "x": 229, - "y": 186, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 2,"w": 36,"h": 39}, + "frame": {"x": 229,"y": 186,"w": 36,"h": 39} }, { "filename": "0063.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 193, - "y": 224, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 224,"w": 36,"h": 39} }, { "filename": "0083.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 2, - "w": 36, - "h": 39 - }, - "frame": { - "x": 193, - "y": 224, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 2,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 224,"w": 36,"h": 39} }, { "filename": "0006.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 38, - "h": 36 - }, - "frame": { - "x": 154, - "y": 257, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 38,"h": 36}, + "frame": {"x": 154,"y": 257,"w": 38,"h": 36} }, { "filename": "0029.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 154, - "y": 293, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 154,"y": 293,"w": 39,"h": 35} }, { "filename": "0007.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 38, - "h": 36 - }, - "frame": { - "x": 265, - "y": 217, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 38,"h": 36}, + "frame": {"x": 265,"y": 217,"w": 38,"h": 36} }, { "filename": "0026.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 265, - "y": 217, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 265,"y": 217,"w": 38,"h": 36} }, { "filename": "0027.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 229, - "y": 253, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 229,"y": 253,"w": 38,"h": 36} }, { "filename": "0073.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 267, - "y": 253, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 267,"y": 253,"w": 38,"h": 36} }, { "filename": "0074.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 193, - "y": 289, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 193,"y": 289,"w": 38,"h": 36} }, { "filename": "0056.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 231, - "y": 289, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 231,"y": 289,"w": 39,"h": 35} }, { "filename": "0076.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 231, - "y": 289, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 231,"y": 289,"w": 39,"h": 35} } ] } ], "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:369fbda05d5091787e9fb4bcf8b8b8a7:e97b539e8775c2502d24834eed725991:cda0147f4d676691e1699693bc0ee567$" - } + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0"} } diff --git a/public/images/pokemon/exp/back/774-red.png b/public/images/pokemon/exp/back/774-red.png index 2c7f3727f95..fc4ff65dfba 100644 Binary files a/public/images/pokemon/exp/back/774-red.png and b/public/images/pokemon/exp/back/774-red.png differ diff --git a/public/images/pokemon/exp/back/774-violet.json b/public/images/pokemon/exp/back/774-violet.json index 4c8bff16d75..f8f45e31468 100644 --- a/public/images/pokemon/exp/back/774-violet.json +++ b/public/images/pokemon/exp/back/774-violet.json @@ -3,1992 +3,765 @@ { "image": "774-violet.png", "format": "RGBA8888", - "size": { - "w": 333, - "h": 333 - }, + "size": {"w": 328,"h": 328}, "scale": 1, "frames": [ - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 14, - "y": 0, - "w": 64, - "h": 96 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 96 - } - }, { "filename": "0011.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 11, - "y": 31, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 96, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 11,"y": 10,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 0,"w": 41,"h": 37} }, { "filename": "0012.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 17, - "y": 28, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 96, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 0,"w": 41,"h": 37} }, { "filename": "0013.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 28, - "y": 21, - "w": 41, - "h": 37 - }, - "frame": { - "x": 64, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 41,"y": 0,"w": 41,"h": 37} }, { "filename": "0018.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 35, - "y": 29, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 133, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 35,"y": 8,"w": 41,"h": 37}, + "frame": {"x": 82,"y": 0,"w": 41,"h": 37} }, { "filename": "0032.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 17, - "y": 28, - "w": 41, - "h": 37 - }, - "frame": { - "x": 64, - "y": 37, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 123,"y": 0,"w": 41,"h": 37} }, { "filename": "0033.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 28, - "y": 21, - "w": 41, - "h": 37 - }, - "frame": { - "x": 105, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 164,"y": 0,"w": 41,"h": 37} }, { "filename": "0044.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 16, - "y": 28, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 170, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 16,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 205,"y": 0,"w": 41,"h": 37} }, { "filename": "0058.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 11, - "y": 31, - "w": 41, - "h": 37 - }, - "frame": { - "x": 105, - "y": 37, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 11,"y": 10,"w": 41,"h": 37}, + "frame": {"x": 246,"y": 0,"w": 41,"h": 37} }, { "filename": "0059.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 17, - "y": 28, - "w": 41, - "h": 37 - }, - "frame": { - "x": 146, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 287,"y": 0,"w": 41,"h": 37} }, { "filename": "0079.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 17, - "y": 28, - "w": 41, - "h": 37 - }, - "frame": { - "x": 146, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 287,"y": 0,"w": 41,"h": 37} }, { "filename": "0060.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 28, - "y": 21, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 207, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 37,"w": 41,"h": 37} }, { "filename": "0080.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 28, - "y": 21, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 207, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 37,"w": 41,"h": 37} }, { "filename": "0065.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 35, - "y": 29, - "w": 41, - "h": 37 - }, - "frame": { - "x": 146, - "y": 37, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 35,"y": 8,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 74,"w": 41,"h": 37} }, { - "filename": "0001.png", + "filename": "0094.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 13, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 187, - "y": 0, - "w": 39, - "h": 37 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 21, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 187, - "y": 0, - "w": 39, - "h": 37 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 13, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 0, - "y": 244, - "w": 39, - "h": 37 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 21, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 0, - "y": 244, - "w": 39, - "h": 37 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 13, - "y": 25, - "w": 39, - "h": 37 - }, - "frame": { - "x": 187, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 3, - "y": 23, - "w": 39, - "h": 37 - }, - "frame": { - "x": 226, - "y": 0, - "w": 39, - "h": 37 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 5, - "y": 23, - "w": 39, - "h": 37 - }, - "frame": { - "x": 226, - "y": 0, - "w": 39, - "h": 37 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 10, - "y": 31, - "w": 39, - "h": 37 - }, - "frame": { - "x": 0, - "y": 281, - "w": 39, - "h": 37 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 21, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 226, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 17, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 226, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 42, - "y": 20, - "w": 37, - "h": 39 - }, - "frame": { - "x": 265, - "y": 0, - "w": 37, - "h": 39 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 42, - "y": 20, - "w": 37, - "h": 39 - }, - "frame": { - "x": 265, - "y": 0, - "w": 37, - "h": 39 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 0, - "y": 29, - "w": 39, - "h": 36 - }, - "frame": { - "x": 265, - "y": 39, - "w": 39, - "h": 36 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 44, - "y": 22, - "w": 36, - "h": 39 - }, - "frame": { - "x": 41, - "y": 96, - "w": 36, - "h": 39 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 44, - "y": 22, - "w": 36, - "h": 39 - }, - "frame": { - "x": 41, - "y": 96, - "w": 36, - "h": 39 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 44, - "y": 22, - "w": 36, - "h": 39 - }, - "frame": { - "x": 41, - "y": 135, - "w": 36, - "h": 39 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 44, - "y": 22, - "w": 36, - "h": 39 - }, - "frame": { - "x": 41, - "y": 135, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 111,"w": 41,"h": 37} }, { "filename": "0017.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 42, - "y": 27, - "w": 37, - "h": 39 - }, - "frame": { - "x": 41, - "y": 174, - "w": 37, - "h": 39 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 0, - "y": 30, - "w": 38, - "h": 36 - }, - "frame": { - "x": 41, - "y": 213, - "w": 38, - "h": 36 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 21, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 39, - "y": 249, - "w": 39, - "h": 37 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 1, - "y": 32, - "w": 39, - "h": 36 - }, - "frame": { - "x": 39, - "y": 286, - "w": 39, - "h": 36 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 2, - "y": 32, - "w": 39, - "h": 36 - }, - "frame": { - "x": 39, - "y": 286, - "w": 39, - "h": 36 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 17, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 77, - "y": 74, - "w": 39, - "h": 37 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 21, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 77, - "y": 74, - "w": 39, - "h": 37 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 17, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 77, - "y": 111, - "w": 39, - "h": 37 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 21, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 77, - "y": 111, - "w": 39, - "h": 37 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 14, - "y": 26, - "w": 39, - "h": 37 - }, - "frame": { - "x": 116, - "y": 74, - "w": 39, - "h": 37 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 9, - "y": 31, - "w": 39, - "h": 37 - }, - "frame": { - "x": 116, - "y": 111, - "w": 39, - "h": 37 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 13, - "y": 31, - "w": 39, - "h": 37 - }, - "frame": { - "x": 155, - "y": 74, - "w": 39, - "h": 37 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 36, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 155, - "y": 111, - "w": 39, - "h": 37 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 17, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 155, - "y": 111, - "w": 39, - "h": 37 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 13, - "y": 31, - "w": 39, - "h": 37 - }, - "frame": { - "x": 155, - "y": 111, - "w": 39, - "h": 37 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 17, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 155, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 148,"w": 37,"h": 39} }, { "filename": "0037.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 42, - "y": 27, - "w": 37, - "h": 39 - }, - "frame": { - "x": 194, - "y": 74, - "w": 37, - "h": 39 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 0, - "y": 30, - "w": 38, - "h": 36 - }, - "frame": { - "x": 194, - "y": 113, - "w": 38, - "h": 36 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 0, - "y": 29, - "w": 38, - "h": 36 - }, - "frame": { - "x": 194, - "y": 113, - "w": 38, - "h": 36 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 21, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 148, - "w": 39, - "h": 37 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 21, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 148, - "w": 39, - "h": 37 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 36, - "y": 29, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 148, - "w": 39, - "h": 37 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 0, - "y": 29, - "w": 38, - "h": 36 - }, - "frame": { - "x": 156, - "y": 148, - "w": 38, - "h": 36 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 5, - "y": 36, - "w": 39, - "h": 36 - }, - "frame": { - "x": 194, - "y": 149, - "w": 39, - "h": 36 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 17, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 79, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 17, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 79, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 17, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 79, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 17, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 79, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 17, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 79, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 17, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 118, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 3, - "y": 23, - "w": 39, - "h": 37 - }, - "frame": { - "x": 118, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 17, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 118, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 187,"w": 37,"h": 39} }, { "filename": "0045.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 17, - "y": 30, - "w": 37, - "h": 39 - }, - "frame": { - "x": 157, - "y": 184, - "w": 37, - "h": 39 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 13, - "y": 25, - "w": 39, - "h": 37 - }, - "frame": { - "x": 194, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 0, - "y": 28, - "w": 39, - "h": 36 - }, - "frame": { - "x": 79, - "y": 222, - "w": 39, - "h": 36 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 6, - "y": 36, - "w": 39, - "h": 36 - }, - "frame": { - "x": 118, - "y": 222, - "w": 39, - "h": 36 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 10, - "y": 31, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 258, - "w": 39, - "h": 37 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 17, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 258, - "w": 39, - "h": 37 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 19, - "y": 31, - "w": 39, - "h": 36 - }, - "frame": { - "x": 157, - "y": 223, - "w": 39, - "h": 36 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 1, - "y": 29, - "w": 39, - "h": 36 - }, - "frame": { - "x": 156, - "y": 259, - "w": 39, - "h": 36 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 42, - "y": 20, - "w": 37, - "h": 39 - }, - "frame": { - "x": 196, - "y": 222, - "w": 37, - "h": 39 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 0, - "y": 30, - "w": 39, - "h": 36 - }, - "frame": { - "x": 195, - "y": 261, - "w": 39, - "h": 36 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 0, - "y": 30, - "w": 39, - "h": 36 - }, - "frame": { - "x": 78, - "y": 295, - "w": 39, - "h": 36 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 2, - "y": 32, - "w": 39, - "h": 36 - }, - "frame": { - "x": 117, - "y": 295, - "w": 39, - "h": 36 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 2, - "y": 32, - "w": 39, - "h": 36 - }, - "frame": { - "x": 117, - "y": 295, - "w": 39, - "h": 36 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 6, - "y": 36, - "w": 39, - "h": 36 - }, - "frame": { - "x": 156, - "y": 295, - "w": 39, - "h": 36 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 6, - "y": 36, - "w": 39, - "h": 36 - }, - "frame": { - "x": 156, - "y": 295, - "w": 39, - "h": 36 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 0, - "y": 28, - "w": 39, - "h": 36 - }, - "frame": { - "x": 195, - "y": 297, - "w": 39, - "h": 36 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 14, - "y": 26, - "w": 39, - "h": 37 - }, - "frame": { - "x": 231, - "y": 75, - "w": 39, - "h": 37 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 5, - "y": 23, - "w": 39, - "h": 37 - }, - "frame": { - "x": 232, - "y": 112, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 9,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 226,"w": 37,"h": 39} }, { "filename": "0064.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 42, - "y": 27, - "w": 37, - "h": 39 - }, - "frame": { - "x": 233, - "y": 149, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 265,"w": 37,"h": 39} }, { "filename": "0084.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 42, - "y": 28, - "w": 37, - "h": 39 - }, - "frame": { - "x": 233, - "y": 149, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 7,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 265,"w": 37,"h": 39} }, { "filename": "0081.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 42, - "y": 21, - "w": 37, - "h": 39 - }, - "frame": { - "x": 233, - "y": 188, - "w": 37, - "h": 39 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 9, - "y": 31, - "w": 39, - "h": 37 - }, - "frame": { - "x": 270, - "y": 75, - "w": 39, - "h": 37 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 17, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 271, - "y": 112, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 39}, + "frame": {"x": 37,"y": 148,"w": 37,"h": 39} }, { "filename": "0093.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 16, - "y": 30, - "w": 37, - "h": 39 - }, - "frame": { - "x": 270, - "y": 149, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 16,"y": 9,"w": 37,"h": 39}, + "frame": {"x": 41,"y": 37,"w": 37,"h": 39} }, { - "filename": "0062.png", + "filename": "0001.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 44, - "y": 22, - "w": 36, - "h": 39 - }, - "frame": { - "x": 270, - "y": 188, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 41,"y": 76,"w": 39,"h": 37} }, { - "filename": "0082.png", + "filename": "0086.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 44, - "y": 23, - "w": 36, - "h": 39 - }, - "frame": { - "x": 270, - "y": 188, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 41,"y": 76,"w": 39,"h": 37} }, { - "filename": "0063.png", + "filename": "0002.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 44, - "y": 22, - "w": 36, - "h": 39 - }, - "frame": { - "x": 234, - "y": 227, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 78,"y": 37,"w": 39,"h": 37} }, { - "filename": "0083.png", + "filename": "0087.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 44, - "y": 23, - "w": 36, - "h": 39 - }, - "frame": { - "x": 234, - "y": 227, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 78,"y": 37,"w": 39,"h": 37} }, { - "filename": "0073.png", + "filename": "0009.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 0, - "y": 29, - "w": 38, - "h": 36 - }, - "frame": { - "x": 234, - "y": 266, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 41,"y": 113,"w": 39,"h": 35} }, { - "filename": "0074.png", + "filename": "0003.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 0, - "y": 29, - "w": 38, - "h": 36 - }, - "frame": { - "x": 270, - "y": 227, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 4,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 187,"w": 39,"h": 37} + }, + { + "filename": "0004.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 74,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0024.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 74,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0010.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 10,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 80,"y": 74,"w": 39,"h": 37} + }, + { + "filename": "0019.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 117,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0089.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 117,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0020.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 80,"y": 111,"w": 39,"h": 37} + }, + { + "filename": "0021.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 224,"w": 39,"h": 37} + }, + { + "filename": "0066.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 224,"w": 39,"h": 37} + }, + { + "filename": "0022.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 261,"w": 39,"h": 37} + }, + { + "filename": "0067.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 261,"w": 39,"h": 37} + }, + { + "filename": "0023.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 5,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0030.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 9,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 113,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0031.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 119,"y": 74,"w": 39,"h": 37} + }, + { + "filename": "0038.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 36,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0068.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0078.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0088.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0039.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 119,"y": 111,"w": 39,"h": 37} + }, + { + "filename": "0040.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 222,"w": 39,"h": 37} + }, + { + "filename": "0085.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 36,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 222,"w": 39,"h": 37} + }, + { + "filename": "0041.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0042.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0043.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0048.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0049.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0047.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 6,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0051.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0091.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 6,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0050.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 4,"w": 39,"h": 37}, + "frame": {"x": 152,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0057.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 10,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 158,"y": 74,"w": 39,"h": 37} + }, + { + "filename": "0069.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 195,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0070.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 5,"w": 39,"h": 37}, + "frame": {"x": 158,"y": 111,"w": 39,"h": 37} + }, + { + "filename": "0071.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 222,"w": 39,"h": 37} + }, + { + "filename": "0077.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 9,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0090.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 191,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0014.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 197,"y": 74,"w": 37,"h": 38} + }, + { + "filename": "0034.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 197,"y": 74,"w": 37,"h": 38} + }, + { + "filename": "0005.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 39,"h": 36}, + "frame": {"x": 197,"y": 112,"w": 39,"h": 36} + }, + { + "filename": "0061.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 234,"y": 37,"w": 37,"h": 38} + }, + { + "filename": "0008.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 1,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 234,"y": 75,"w": 39,"h": 36} + }, + { + "filename": "0028.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 234,"y": 75,"w": 39,"h": 36} + }, + { + "filename": "0025.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 7,"w": 39,"h": 36}, + "frame": {"x": 271,"y": 37,"w": 39,"h": 36} + }, + { + "filename": "0046.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 19,"y": 10,"w": 39,"h": 36}, + "frame": {"x": 273,"y": 73,"w": 39,"h": 36} + }, + { + "filename": "0052.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 1,"y": 8,"w": 39,"h": 36}, + "frame": {"x": 273,"y": 109,"w": 39,"h": 36} + }, + { + "filename": "0015.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 236,"y": 111,"w": 36,"h": 39} + }, + { + "filename": "0035.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 236,"y": 111,"w": 36,"h": 39} + }, + { + "filename": "0053.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 39,"h": 36}, + "frame": {"x": 272,"y": 145,"w": 39,"h": 36} + }, + { + "filename": "0054.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 39,"h": 36}, + "frame": {"x": 230,"y": 150,"w": 39,"h": 36} + }, + { + "filename": "0055.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 269,"y": 181,"w": 39,"h": 36} + }, + { + "filename": "0075.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 269,"y": 181,"w": 39,"h": 36} + }, + { + "filename": "0072.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 7,"w": 39,"h": 36}, + "frame": {"x": 154,"y": 185,"w": 39,"h": 36} + }, + { + "filename": "0016.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 185,"w": 36,"h": 39} + }, + { + "filename": "0036.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 185,"w": 36,"h": 39} }, { "filename": "0092.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 96 - }, - "spriteSourceSize": { - "x": 18, - "y": 31, - "w": 39, - "h": 36 - }, - "frame": { - "x": 272, - "y": 263, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 18,"y": 10,"w": 39,"h": 36}, + "frame": {"x": 154,"y": 221,"w": 39,"h": 36} + }, + { + "filename": "0062.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 229,"y": 186,"w": 36,"h": 39} + }, + { + "filename": "0082.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 2,"w": 36,"h": 39}, + "frame": {"x": 229,"y": 186,"w": 36,"h": 39} + }, + { + "filename": "0063.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 224,"w": 36,"h": 39} + }, + { + "filename": "0083.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 2,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 224,"w": 36,"h": 39} + }, + { + "filename": "0006.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 38,"h": 36}, + "frame": {"x": 154,"y": 257,"w": 38,"h": 36} + }, + { + "filename": "0029.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 154,"y": 293,"w": 39,"h": 35} + }, + { + "filename": "0007.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 38,"h": 36}, + "frame": {"x": 265,"y": 217,"w": 38,"h": 36} + }, + { + "filename": "0026.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 265,"y": 217,"w": 38,"h": 36} + }, + { + "filename": "0027.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 229,"y": 253,"w": 38,"h": 36} + }, + { + "filename": "0073.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 267,"y": 253,"w": 38,"h": 36} + }, + { + "filename": "0074.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 193,"y": 289,"w": 38,"h": 36} + }, + { + "filename": "0056.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 231,"y": 289,"w": 39,"h": 35} + }, + { + "filename": "0076.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 231,"y": 289,"w": 39,"h": 35} } ] } ], "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:6a37bab657d0a60a597a371946968d10:9e708ff76767bc0eacbaec37643926ac:cafe7bbce21f2b95187ef35011084eca$" - } + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0"} } diff --git a/public/images/pokemon/exp/back/774-violet.png b/public/images/pokemon/exp/back/774-violet.png index 079989db654..05de1971526 100644 Binary files a/public/images/pokemon/exp/back/774-violet.png and b/public/images/pokemon/exp/back/774-violet.png differ diff --git a/public/images/pokemon/exp/back/774-yellow.json b/public/images/pokemon/exp/back/774-yellow.json index d0d55e6ed22..56b702ab22f 100644 --- a/public/images/pokemon/exp/back/774-yellow.json +++ b/public/images/pokemon/exp/back/774-yellow.json @@ -3,1992 +3,765 @@ { "image": "774-yellow.png", "format": "RGBA8888", - "size": { - "w": 331, - "h": 331 - }, + "size": {"w": 328,"h": 328}, "scale": 1, "frames": [ - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 14, - "y": 0, - "w": 64, - "h": 64 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 64 - } - }, { "filename": "0011.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 11, - "y": 30, - "w": 41, - "h": 37 - }, - "frame": { - "x": 64, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 11,"y": 10,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 0,"w": 41,"h": 37} }, { "filename": "0012.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 17, - "y": 27, - "w": 41, - "h": 37 - }, - "frame": { - "x": 64, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 0,"w": 41,"h": 37} }, { "filename": "0013.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 28, - "y": 20, - "w": 41, - "h": 37 - }, - "frame": { - "x": 105, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 41,"y": 0,"w": 41,"h": 37} }, { "filename": "0018.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 35, - "y": 28, - "w": 41, - "h": 37 - }, - "frame": { - "x": 146, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 35,"y": 8,"w": 41,"h": 37}, + "frame": {"x": 82,"y": 0,"w": 41,"h": 37} }, { "filename": "0032.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 17, - "y": 27, - "w": 41, - "h": 37 - }, - "frame": { - "x": 187, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 123,"y": 0,"w": 41,"h": 37} }, { "filename": "0033.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 28, - "y": 20, - "w": 41, - "h": 37 - }, - "frame": { - "x": 228, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 164,"y": 0,"w": 41,"h": 37} }, { "filename": "0044.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 16, - "y": 27, - "w": 41, - "h": 37 - }, - "frame": { - "x": 269, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 16,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 205,"y": 0,"w": 41,"h": 37} }, { "filename": "0058.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 11, - "y": 30, - "w": 41, - "h": 37 - }, - "frame": { - "x": 64, - "y": 37, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 11,"y": 10,"w": 41,"h": 37}, + "frame": {"x": 246,"y": 0,"w": 41,"h": 37} }, { "filename": "0059.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 17, - "y": 27, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 64, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 287,"y": 0,"w": 41,"h": 37} }, { "filename": "0079.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 17, - "y": 27, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 64, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 287,"y": 0,"w": 41,"h": 37} }, { "filename": "0060.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 28, - "y": 20, - "w": 41, - "h": 37 - }, - "frame": { - "x": 105, - "y": 37, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 37,"w": 41,"h": 37} }, { "filename": "0080.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 28, - "y": 20, - "w": 41, - "h": 37 - }, - "frame": { - "x": 105, - "y": 37, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 37,"w": 41,"h": 37} }, { "filename": "0065.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 35, - "y": 28, - "w": 41, - "h": 37 - }, - "frame": { - "x": 146, - "y": 37, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 35,"y": 8,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 74,"w": 41,"h": 37} }, { - "filename": "0001.png", + "filename": "0094.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 13, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 187, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 21, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 187, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 13, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 226, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 21, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 226, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 13, - "y": 24, - "w": 39, - "h": 37 - }, - "frame": { - "x": 265, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 42, - "y": 19, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 101, - "w": 37, - "h": 39 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 42, - "y": 19, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 101, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 111,"w": 41,"h": 37} }, { "filename": "0017.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 42, - "y": 26, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 140, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 148,"w": 37,"h": 39} }, { "filename": "0037.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 42, - "y": 26, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 179, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 187,"w": 37,"h": 39} }, { "filename": "0045.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 17, - "y": 29, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 218, - "w": 37, - "h": 39 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 42, - "y": 19, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 257, - "w": 37, - "h": 39 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 5, - "y": 35, - "w": 39, - "h": 35 - }, - "frame": { - "x": 0, - "y": 296, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 9,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 226,"w": 37,"h": 39} }, { "filename": "0064.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 42, - "y": 26, - "w": 37, - "h": 39 - }, - "frame": { - "x": 37, - "y": 101, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 265,"w": 37,"h": 39} }, { "filename": "0084.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 42, - "y": 27, - "w": 37, - "h": 39 - }, - "frame": { - "x": 37, - "y": 101, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 7,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 265,"w": 37,"h": 39} }, { "filename": "0081.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 42, - "y": 20, - "w": 37, - "h": 39 - }, - "frame": { - "x": 37, - "y": 140, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 39}, + "frame": {"x": 37,"y": 148,"w": 37,"h": 39} }, { "filename": "0093.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 16, - "y": 29, - "w": 37, - "h": 39 - }, - "frame": { - "x": 37, - "y": 179, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 16,"y": 9,"w": 37,"h": 39}, + "frame": {"x": 41,"y": 37,"w": 37,"h": 39} }, { - "filename": "0015.png", + "filename": "0001.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 44, - "y": 21, - "w": 36, - "h": 39 - }, - "frame": { - "x": 37, - "y": 218, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 41,"y": 76,"w": 39,"h": 37} }, { - "filename": "0035.png", + "filename": "0086.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 44, - "y": 21, - "w": 36, - "h": 39 - }, - "frame": { - "x": 37, - "y": 218, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 41,"y": 76,"w": 39,"h": 37} }, { - "filename": "0016.png", + "filename": "0002.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 44, - "y": 21, - "w": 36, - "h": 39 - }, - "frame": { - "x": 37, - "y": 257, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 78,"y": 37,"w": 39,"h": 37} }, { - "filename": "0036.png", + "filename": "0087.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 44, - "y": 21, - "w": 36, - "h": 39 - }, - "frame": { - "x": 37, - "y": 257, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 78,"y": 37,"w": 39,"h": 37} }, { - "filename": "0029.png", + "filename": "0009.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 6, - "y": 35, - "w": 39, - "h": 35 - }, - "frame": { - "x": 39, - "y": 296, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 41,"y": 113,"w": 39,"h": 35} }, { - "filename": "0062.png", + "filename": "0003.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 44, - "y": 21, - "w": 36, - "h": 39 - }, - "frame": { - "x": 73, - "y": 218, - "w": 36, - "h": 39 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 44, - "y": 22, - "w": 36, - "h": 39 - }, - "frame": { - "x": 73, - "y": 218, - "w": 36, - "h": 39 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 44, - "y": 21, - "w": 36, - "h": 39 - }, - "frame": { - "x": 73, - "y": 257, - "w": 36, - "h": 39 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 44, - "y": 22, - "w": 36, - "h": 39 - }, - "frame": { - "x": 73, - "y": 257, - "w": 36, - "h": 39 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 6, - "y": 35, - "w": 39, - "h": 35 - }, - "frame": { - "x": 78, - "y": 296, - "w": 39, - "h": 35 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 6, - "y": 35, - "w": 39, - "h": 35 - }, - "frame": { - "x": 78, - "y": 296, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 4,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 187,"w": 39,"h": 37} }, { "filename": "0004.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 3, - "y": 22, - "w": 39, - "h": 37 - }, - "frame": { - "x": 74, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 74,"y": 148,"w": 39,"h": 37} }, { "filename": "0024.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 5, - "y": 22, - "w": 39, - "h": 37 - }, - "frame": { - "x": 74, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 74,"y": 148,"w": 39,"h": 37} }, { "filename": "0010.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 10, - "y": 30, - "w": 39, - "h": 37 - }, - "frame": { - "x": 74, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 10,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 80,"y": 74,"w": 39,"h": 37} }, { "filename": "0019.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 21, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 74, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 117,"y": 37,"w": 39,"h": 37} }, { "filename": "0089.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 17, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 74, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 117,"y": 37,"w": 39,"h": 37} }, { "filename": "0020.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 21, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 109, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 80,"y": 111,"w": 39,"h": 37} }, { "filename": "0021.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 17, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 109, - "y": 222, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 224,"w": 39,"h": 37} }, { "filename": "0066.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 21, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 109, - "y": 222, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 224,"w": 39,"h": 37} }, { "filename": "0022.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 17, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 109, - "y": 259, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 261,"w": 39,"h": 37} }, { "filename": "0067.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 21, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 109, - "y": 259, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 261,"w": 39,"h": 37} }, { "filename": "0023.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 14, - "y": 25, - "w": 39, - "h": 37 - }, - "frame": { - "x": 113, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 5,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 185,"w": 39,"h": 37} }, { "filename": "0030.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 9, - "y": 30, - "w": 39, - "h": 37 - }, - "frame": { - "x": 113, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 9,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 113,"y": 148,"w": 39,"h": 37} }, { "filename": "0031.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 13, - "y": 30, - "w": 39, - "h": 37 - }, - "frame": { - "x": 113, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 119,"y": 74,"w": 39,"h": 37} }, { "filename": "0038.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 36, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 148, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 36,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0068.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 17, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 148, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0078.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 13, - "y": 30, - "w": 39, - "h": 37 - }, - "frame": { - "x": 148, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0088.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 17, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 148, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0039.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 21, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 148, - "y": 222, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 119,"y": 111,"w": 39,"h": 37} }, { "filename": "0040.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 21, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 148, - "y": 259, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 222,"w": 39,"h": 37} }, { "filename": "0085.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 36, - "y": 28, - "w": 39, - "h": 37 - }, - "frame": { - "x": 148, - "y": 259, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 36,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 222,"w": 39,"h": 37} }, { "filename": "0041.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 17, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 152, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} }, { "filename": "0042.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 17, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 152, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} }, { "filename": "0043.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 17, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 152, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} }, { "filename": "0048.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 17, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 152, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} }, { "filename": "0049.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 17, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 152, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} }, { "filename": "0047.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 17, - "y": 26, - "w": 39, - "h": 37 - }, - "frame": { - "x": 152, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 6,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} }, { "filename": "0051.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 3, - "y": 22, - "w": 39, - "h": 37 - }, - "frame": { - "x": 152, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} }, { "filename": "0091.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 17, - "y": 26, - "w": 39, - "h": 37 - }, - "frame": { - "x": 152, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 6,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} }, { "filename": "0050.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 13, - "y": 24, - "w": 39, - "h": 37 - }, - "frame": { - "x": 152, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 4,"w": 39,"h": 37}, + "frame": {"x": 152,"y": 148,"w": 39,"h": 37} }, { "filename": "0057.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 10, - "y": 30, - "w": 39, - "h": 37 - }, - "frame": { - "x": 191, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 10,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 158,"y": 74,"w": 39,"h": 37} }, { "filename": "0069.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 17, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 230, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 195,"y": 37,"w": 39,"h": 37} }, { "filename": "0070.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 14, - "y": 25, - "w": 39, - "h": 37 - }, - "frame": { - "x": 269, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 5,"w": 39,"h": 37}, + "frame": {"x": 158,"y": 111,"w": 39,"h": 37} }, { "filename": "0071.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 5, - "y": 22, - "w": 39, - "h": 37 - }, - "frame": { - "x": 191, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 222,"w": 39,"h": 37} }, { "filename": "0077.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 9, - "y": 30, - "w": 39, - "h": 37 - }, - "frame": { - "x": 230, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 9,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 259,"w": 39,"h": 37} }, { "filename": "0090.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 17, - "y": 27, - "w": 39, - "h": 37 - }, - "frame": { - "x": 269, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 191,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0014.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 197,"y": 74,"w": 37,"h": 38} + }, + { + "filename": "0034.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 197,"y": 74,"w": 37,"h": 38} }, { "filename": "0005.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 28, - "w": 39, - "h": 36 - }, - "frame": { - "x": 191, - "y": 148, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 39,"h": 36}, + "frame": {"x": 197,"y": 112,"w": 39,"h": 36} + }, + { + "filename": "0061.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 234,"y": 37,"w": 37,"h": 38} }, { "filename": "0008.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 1, - "y": 31, - "w": 39, - "h": 36 - }, - "frame": { - "x": 230, - "y": 148, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 1,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 234,"y": 75,"w": 39,"h": 36} }, { "filename": "0028.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 2, - "y": 31, - "w": 39, - "h": 36 - }, - "frame": { - "x": 230, - "y": 148, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 234,"y": 75,"w": 39,"h": 36} }, { "filename": "0025.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 27, - "w": 39, - "h": 36 - }, - "frame": { - "x": 269, - "y": 148, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 7,"w": 39,"h": 36}, + "frame": {"x": 271,"y": 37,"w": 39,"h": 36} }, { "filename": "0046.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 19, - "y": 30, - "w": 39, - "h": 36 - }, - "frame": { - "x": 191, - "y": 184, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 19,"y": 10,"w": 39,"h": 36}, + "frame": {"x": 273,"y": 73,"w": 39,"h": 36} }, { "filename": "0052.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 1, - "y": 28, - "w": 39, - "h": 36 - }, - "frame": { - "x": 230, - "y": 184, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 1,"y": 8,"w": 39,"h": 36}, + "frame": {"x": 273,"y": 109,"w": 39,"h": 36} + }, + { + "filename": "0015.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 236,"y": 111,"w": 36,"h": 39} + }, + { + "filename": "0035.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 236,"y": 111,"w": 36,"h": 39} }, { "filename": "0053.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 29, - "w": 39, - "h": 36 - }, - "frame": { - "x": 269, - "y": 184, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 39,"h": 36}, + "frame": {"x": 272,"y": 145,"w": 39,"h": 36} }, { "filename": "0054.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 29, - "w": 39, - "h": 36 - }, - "frame": { - "x": 187, - "y": 220, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 39,"h": 36}, + "frame": {"x": 230,"y": 150,"w": 39,"h": 36} }, { "filename": "0055.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 2, - "y": 31, - "w": 39, - "h": 36 - }, - "frame": { - "x": 187, - "y": 256, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 269,"y": 181,"w": 39,"h": 36} }, { "filename": "0075.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 2, - "y": 31, - "w": 39, - "h": 36 - }, - "frame": { - "x": 187, - "y": 256, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 269,"y": 181,"w": 39,"h": 36} }, { "filename": "0072.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 27, - "w": 39, - "h": 36 - }, - "frame": { - "x": 187, - "y": 292, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 7,"w": 39,"h": 36}, + "frame": {"x": 154,"y": 185,"w": 39,"h": 36} + }, + { + "filename": "0016.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 185,"w": 36,"h": 39} + }, + { + "filename": "0036.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 185,"w": 36,"h": 39} }, { "filename": "0092.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 18, - "y": 30, - "w": 39, - "h": 36 - }, - "frame": { - "x": 226, - "y": 220, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 18,"y": 10,"w": 39,"h": 36}, + "frame": {"x": 154,"y": 221,"w": 39,"h": 36} + }, + { + "filename": "0062.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 229,"y": 186,"w": 36,"h": 39} + }, + { + "filename": "0082.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 2,"w": 36,"h": 39}, + "frame": {"x": 229,"y": 186,"w": 36,"h": 39} + }, + { + "filename": "0063.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 224,"w": 36,"h": 39} + }, + { + "filename": "0083.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 2,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 224,"w": 36,"h": 39} }, { "filename": "0006.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 29, - "w": 38, - "h": 36 - }, - "frame": { - "x": 265, - "y": 220, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 38,"h": 36}, + "frame": {"x": 154,"y": 257,"w": 38,"h": 36} + }, + { + "filename": "0029.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 154,"y": 293,"w": 39,"h": 35} }, { "filename": "0007.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 29, - "w": 38, - "h": 36 - }, - "frame": { - "x": 226, - "y": 256, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 38,"h": 36}, + "frame": {"x": 265,"y": 217,"w": 38,"h": 36} }, { "filename": "0026.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 28, - "w": 38, - "h": 36 - }, - "frame": { - "x": 226, - "y": 256, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 265,"y": 217,"w": 38,"h": 36} }, { "filename": "0027.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 28, - "w": 38, - "h": 36 - }, - "frame": { - "x": 226, - "y": 292, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 229,"y": 253,"w": 38,"h": 36} }, { "filename": "0073.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 28, - "w": 38, - "h": 36 - }, - "frame": { - "x": 264, - "y": 256, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 267,"y": 253,"w": 38,"h": 36} }, { "filename": "0074.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 70 - }, - "spriteSourceSize": { - "x": 0, - "y": 28, - "w": 38, - "h": 36 - }, - "frame": { - "x": 264, - "y": 292, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 193,"y": 289,"w": 38,"h": 36} + }, + { + "filename": "0056.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 231,"y": 289,"w": 39,"h": 35} + }, + { + "filename": "0076.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 231,"y": 289,"w": 39,"h": 35} } ] } ], "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:c34e2767018a0a04a86f0f3187fe2550:da4fa5da9c6cc244a887294935dba4a3:a0f9f47b818f7e67dd381af2f205c265$" - } + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0"} } diff --git a/public/images/pokemon/exp/back/774-yellow.png b/public/images/pokemon/exp/back/774-yellow.png index f315cda8639..869d04c553b 100644 Binary files a/public/images/pokemon/exp/back/774-yellow.png and b/public/images/pokemon/exp/back/774-yellow.png differ diff --git a/public/images/pokemon/exp/back/894.png b/public/images/pokemon/exp/back/894.png index c83851c2d54..e82e8dc0183 100644 Binary files a/public/images/pokemon/exp/back/894.png and b/public/images/pokemon/exp/back/894.png differ diff --git a/public/images/pokemon/exp/back/944.png b/public/images/pokemon/exp/back/944.png index 1f4139b4128..5162fa285be 100644 Binary files a/public/images/pokemon/exp/back/944.png and b/public/images/pokemon/exp/back/944.png differ diff --git a/public/images/pokemon/exp/back/945.png b/public/images/pokemon/exp/back/945.png index 98e56cc2468..74d4e56a598 100644 Binary files a/public/images/pokemon/exp/back/945.png and b/public/images/pokemon/exp/back/945.png differ diff --git a/public/images/pokemon/exp/back/shiny/4144.png b/public/images/pokemon/exp/back/shiny/4144.png index a3859cff886..ac5d3e8d2f2 100644 Binary files a/public/images/pokemon/exp/back/shiny/4144.png and b/public/images/pokemon/exp/back/shiny/4144.png differ diff --git a/public/images/pokemon/exp/back/shiny/4145.png b/public/images/pokemon/exp/back/shiny/4145.png index 4839e2254c2..e543479a57c 100644 Binary files a/public/images/pokemon/exp/back/shiny/4145.png and b/public/images/pokemon/exp/back/shiny/4145.png differ diff --git a/public/images/pokemon/exp/back/shiny/4146.png b/public/images/pokemon/exp/back/shiny/4146.png index f0e16a8f43e..038303f5b0d 100644 Binary files a/public/images/pokemon/exp/back/shiny/4146.png and b/public/images/pokemon/exp/back/shiny/4146.png differ diff --git a/public/images/pokemon/exp/back/shiny/658-ash.json b/public/images/pokemon/exp/back/shiny/658-ash.json index db9e546af7f..8e360497b8d 100644 --- a/public/images/pokemon/exp/back/shiny/658-ash.json +++ b/public/images/pokemon/exp/back/shiny/658-ash.json @@ -1,188 +1,155 @@ -{ - "textures": [ - { - "image": "658-ash.png", - "format": "RGBA8888", - "size": { - "w": 150, - "h": 150 - }, - "scale": 1, - "frames": [ - { - "filename": "0003.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 62 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 62 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 62 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 62 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 62 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - }, - "frame": { - "x": 75, - "y": 0, - "w": 75, - "h": 62 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 62 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - }, - "frame": { - "x": 75, - "y": 0, - "w": 75, - "h": 62 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 75, - "h": 62 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 75, - "h": 61 - }, - "frame": { - "x": 0, - "y": 62, - "w": 75, - "h": 61 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 75, - "h": 62 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 75, - "h": 61 - }, - "frame": { - "x": 75, - "y": 62, - "w": 75, - "h": 61 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:d9855568004fd93bcd73aa782894b172:d7e4656a720ccca08a26ed4485129bb3:f09eeed5adc5ec50aec50218e03662c2$" - } +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + }, + { + "filename": "0002.png", + "frame": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + }, + { + "filename": "0003.png", + "frame": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + }, + { + "filename": "0004.png", + "frame": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + }, + { + "filename": "0005.png", + "frame": { "x": 73, "y": 0, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + }, + { + "filename": "0006.png", + "frame": { "x": 73, "y": 0, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + }, + { + "filename": "0007.png", + "frame": { "x": 73, "y": 0, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + }, + { + "filename": "0008.png", + "frame": { "x": 73, "y": 0, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + }, + { + "filename": "0009.png", + "frame": { "x": 0, "y": 73, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + }, + { + "filename": "0010.png", + "frame": { "x": 0, "y": 73, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + }, + { + "filename": "0011.png", + "frame": { "x": 0, "y": 73, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + }, + { + "filename": "0012.png", + "frame": { "x": 0, "y": 73, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + }, + { + "filename": "0013.png", + "frame": { "x": 73, "y": 0, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + }, + { + "filename": "0014.png", + "frame": { "x": 73, "y": 0, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + }, + { + "filename": "0015.png", + "frame": { "x": 73, "y": 0, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + }, + { + "filename": "0016.png", + "frame": { "x": 73, "y": 0, "w": 73, "h": 73 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 73, "h": 73 }, + "sourceSize": { "w": 73, "h": 73 }, + "duration": 100 + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.7-x64", + "image": "658-ash.png", + "format": "I8", + "size": { "w": 146, "h": 146 }, + "scale": "1" + } } diff --git a/public/images/pokemon/exp/back/shiny/658-ash.png b/public/images/pokemon/exp/back/shiny/658-ash.png index a2a53dbdbc7..3269d435c94 100644 Binary files a/public/images/pokemon/exp/back/shiny/658-ash.png and b/public/images/pokemon/exp/back/shiny/658-ash.png differ diff --git a/public/images/pokemon/exp/back/shiny/658.json b/public/images/pokemon/exp/back/shiny/658.json index 8dc315c768e..453f6c16dc6 100644 --- a/public/images/pokemon/exp/back/shiny/658.json +++ b/public/images/pokemon/exp/back/shiny/658.json @@ -1,188 +1,92 @@ -{ - "textures": [ - { - "image": "658.png", - "format": "RGBA8888", - "size": { - "w": 150, - "h": 150 - }, - "scale": 1, - "frames": [ - { - "filename": "0003.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 62 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 62 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 62 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 62 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 62 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - }, - "frame": { - "x": 75, - "y": 0, - "w": 75, - "h": 62 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 62 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 62 - }, - "frame": { - "x": 75, - "y": 0, - "w": 75, - "h": 62 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 75, - "h": 62 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 75, - "h": 61 - }, - "frame": { - "x": 0, - "y": 62, - "w": 75, - "h": 61 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 75, - "h": 62 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 75, - "h": 61 - }, - "frame": { - "x": 0, - "y": 62, - "w": 75, - "h": 61 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:661efcc0c742bc0d4b4e26900a59332f:d0aa0f579971d046660bf77b4044aa35:5affcab976148657d36bf4ff3410f92d$" - } +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 77, "h": 77 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 77, "h": 77 }, + "sourceSize": { "w": 77, "h": 77 }, + "duration": 100 + }, + { + "filename": "0002.png", + "frame": { "x": 0, "y": 0, "w": 77, "h": 77 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 77, "h": 77 }, + "sourceSize": { "w": 77, "h": 77 }, + "duration": 100 + }, + { + "filename": "0003.png", + "frame": { "x": 0, "y": 0, "w": 77, "h": 77 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 77, "h": 77 }, + "sourceSize": { "w": 77, "h": 77 }, + "duration": 100 + }, + { + "filename": "0004.png", + "frame": { "x": 77, "y": 0, "w": 77, "h": 77 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 77, "h": 77 }, + "sourceSize": { "w": 77, "h": 77 }, + "duration": 100 + }, + { + "filename": "0005.png", + "frame": { "x": 77, "y": 0, "w": 77, "h": 77 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 77, "h": 77 }, + "sourceSize": { "w": 77, "h": 77 }, + "duration": 100 + }, + { + "filename": "0006.png", + "frame": { "x": 0, "y": 77, "w": 77, "h": 77 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 77, "h": 77 }, + "sourceSize": { "w": 77, "h": 77 }, + "duration": 100 + }, + { + "filename": "0007.png", + "frame": { "x": 0, "y": 77, "w": 77, "h": 77 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 77, "h": 77 }, + "sourceSize": { "w": 77, "h": 77 }, + "duration": 100 + }, + { + "filename": "0008.png", + "frame": { "x": 77, "y": 0, "w": 77, "h": 77 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 77, "h": 77 }, + "sourceSize": { "w": 77, "h": 77 }, + "duration": 100 + }, + { + "filename": "0009.png", + "frame": { "x": 77, "y": 0, "w": 77, "h": 77 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 77, "h": 77 }, + "sourceSize": { "w": 77, "h": 77 }, + "duration": 100 + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.7-x64", + "image": "658.png", + "format": "I8", + "size": { "w": 154, "h": 154 }, + "scale": "1" + } } diff --git a/public/images/pokemon/exp/back/shiny/658.png b/public/images/pokemon/exp/back/shiny/658.png index 416f1145463..bb0ee7accdf 100644 Binary files a/public/images/pokemon/exp/back/shiny/658.png and b/public/images/pokemon/exp/back/shiny/658.png differ diff --git a/public/images/pokemon/exp/back/shiny/662.png b/public/images/pokemon/exp/back/shiny/662.png index b4e6c703eab..e662b3198a6 100644 Binary files a/public/images/pokemon/exp/back/shiny/662.png and b/public/images/pokemon/exp/back/shiny/662.png differ diff --git a/public/images/pokemon/exp/back/shiny/696.png b/public/images/pokemon/exp/back/shiny/696.png index ad6d95f99a8..9b905155cf1 100644 Binary files a/public/images/pokemon/exp/back/shiny/696.png and b/public/images/pokemon/exp/back/shiny/696.png differ diff --git a/public/images/pokemon/exp/back/shiny/773-bug.png b/public/images/pokemon/exp/back/shiny/773-bug.png index 0ab0a87913c..0485a61c66b 100644 Binary files a/public/images/pokemon/exp/back/shiny/773-bug.png and b/public/images/pokemon/exp/back/shiny/773-bug.png differ diff --git a/public/images/pokemon/exp/back/shiny/773-dark.png b/public/images/pokemon/exp/back/shiny/773-dark.png index a444ff50bbb..7e83dbf919e 100644 Binary files a/public/images/pokemon/exp/back/shiny/773-dark.png and b/public/images/pokemon/exp/back/shiny/773-dark.png differ diff --git a/public/images/pokemon/exp/back/shiny/773-dragon.png b/public/images/pokemon/exp/back/shiny/773-dragon.png index 1a105381a91..296cd6c2c5a 100644 Binary files a/public/images/pokemon/exp/back/shiny/773-dragon.png and b/public/images/pokemon/exp/back/shiny/773-dragon.png differ diff --git a/public/images/pokemon/exp/back/shiny/773-electric.png b/public/images/pokemon/exp/back/shiny/773-electric.png index 8bb3a148252..63448886494 100644 Binary files a/public/images/pokemon/exp/back/shiny/773-electric.png and b/public/images/pokemon/exp/back/shiny/773-electric.png differ diff --git a/public/images/pokemon/exp/back/shiny/773-fairy.png b/public/images/pokemon/exp/back/shiny/773-fairy.png index cb55030dacd..c0d86f884cd 100644 Binary files a/public/images/pokemon/exp/back/shiny/773-fairy.png and b/public/images/pokemon/exp/back/shiny/773-fairy.png differ diff --git a/public/images/pokemon/exp/back/shiny/773-fighting.png b/public/images/pokemon/exp/back/shiny/773-fighting.png index 1846390d7c8..1bcc56a5eb9 100644 Binary files a/public/images/pokemon/exp/back/shiny/773-fighting.png and b/public/images/pokemon/exp/back/shiny/773-fighting.png differ diff --git a/public/images/pokemon/exp/back/shiny/773-fire.png b/public/images/pokemon/exp/back/shiny/773-fire.png index aa8d3c1af27..5a68353c338 100644 Binary files a/public/images/pokemon/exp/back/shiny/773-fire.png and b/public/images/pokemon/exp/back/shiny/773-fire.png differ diff --git a/public/images/pokemon/exp/back/shiny/773-flying.png b/public/images/pokemon/exp/back/shiny/773-flying.png index f943cf75e65..f88f6643725 100644 Binary files a/public/images/pokemon/exp/back/shiny/773-flying.png and b/public/images/pokemon/exp/back/shiny/773-flying.png differ diff --git a/public/images/pokemon/exp/back/shiny/773-ghost.png b/public/images/pokemon/exp/back/shiny/773-ghost.png index d721ce0e89c..9f34535b028 100644 Binary files a/public/images/pokemon/exp/back/shiny/773-ghost.png and b/public/images/pokemon/exp/back/shiny/773-ghost.png differ diff --git a/public/images/pokemon/exp/back/shiny/773-grass.png b/public/images/pokemon/exp/back/shiny/773-grass.png index 6a903eb5c33..97336814818 100644 Binary files a/public/images/pokemon/exp/back/shiny/773-grass.png and b/public/images/pokemon/exp/back/shiny/773-grass.png differ diff --git a/public/images/pokemon/exp/back/shiny/773-ground.png b/public/images/pokemon/exp/back/shiny/773-ground.png index d871126e25e..074746d3e86 100644 Binary files a/public/images/pokemon/exp/back/shiny/773-ground.png and b/public/images/pokemon/exp/back/shiny/773-ground.png differ diff --git a/public/images/pokemon/exp/back/shiny/773-ice.png b/public/images/pokemon/exp/back/shiny/773-ice.png index 045b07ceb22..b59a3d15684 100644 Binary files a/public/images/pokemon/exp/back/shiny/773-ice.png and b/public/images/pokemon/exp/back/shiny/773-ice.png differ diff --git a/public/images/pokemon/exp/back/shiny/773-poison.png b/public/images/pokemon/exp/back/shiny/773-poison.png index db32789fe4e..3b72b45c7be 100644 Binary files a/public/images/pokemon/exp/back/shiny/773-poison.png and b/public/images/pokemon/exp/back/shiny/773-poison.png differ diff --git a/public/images/pokemon/exp/back/shiny/773-psychic.png b/public/images/pokemon/exp/back/shiny/773-psychic.png index 3899a7ff34e..d3480a88344 100644 Binary files a/public/images/pokemon/exp/back/shiny/773-psychic.png and b/public/images/pokemon/exp/back/shiny/773-psychic.png differ diff --git a/public/images/pokemon/exp/back/shiny/773-rock.png b/public/images/pokemon/exp/back/shiny/773-rock.png index ff5654a9e49..9464836c7a3 100644 Binary files a/public/images/pokemon/exp/back/shiny/773-rock.png and b/public/images/pokemon/exp/back/shiny/773-rock.png differ diff --git a/public/images/pokemon/exp/back/shiny/773-steel.png b/public/images/pokemon/exp/back/shiny/773-steel.png index adf516cc98c..e36b261412b 100644 Binary files a/public/images/pokemon/exp/back/shiny/773-steel.png and b/public/images/pokemon/exp/back/shiny/773-steel.png differ diff --git a/public/images/pokemon/exp/back/shiny/773-water.png b/public/images/pokemon/exp/back/shiny/773-water.png index 1b83d5dae41..824608d0971 100644 Binary files a/public/images/pokemon/exp/back/shiny/773-water.png and b/public/images/pokemon/exp/back/shiny/773-water.png differ diff --git a/public/images/pokemon/exp/back/shiny/774-blue.json b/public/images/pokemon/exp/back/shiny/774-blue.json index a8bb929e2f2..d10223fe4b2 100644 --- a/public/images/pokemon/exp/back/shiny/774-blue.json +++ b/public/images/pokemon/exp/back/shiny/774-blue.json @@ -3,1992 +3,765 @@ { "image": "774-blue.png", "format": "RGBA8888", - "size": { - "w": 331, - "h": 331 - }, + "size": {"w": 328,"h": 328}, "scale": 1, "frames": [ { "filename": "0011.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 11, - "y": 10, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 11,"y": 10,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 0,"w": 41,"h": 37} }, { "filename": "0012.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 0,"w": 41,"h": 37} }, { "filename": "0013.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 41, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 41,"y": 0,"w": 41,"h": 37} }, { "filename": "0018.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 35, - "y": 8, - "w": 41, - "h": 37 - }, - "frame": { - "x": 82, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 35,"y": 8,"w": 41,"h": 37}, + "frame": {"x": 82,"y": 0,"w": 41,"h": 37} }, { "filename": "0032.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 123, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 123,"y": 0,"w": 41,"h": 37} }, { "filename": "0033.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 164, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 164,"y": 0,"w": 41,"h": 37} }, { "filename": "0044.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 16, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 205, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 16,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 205,"y": 0,"w": 41,"h": 37} }, { "filename": "0058.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 11, - "y": 10, - "w": 41, - "h": 37 - }, - "frame": { - "x": 246, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 11,"y": 10,"w": 41,"h": 37}, + "frame": {"x": 246,"y": 0,"w": 41,"h": 37} }, { "filename": "0059.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 287, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 287,"y": 0,"w": 41,"h": 37} }, { "filename": "0079.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 287, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 287,"y": 0,"w": 41,"h": 37} }, { "filename": "0060.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 37, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 37,"w": 41,"h": 37} }, { "filename": "0080.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 37, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 37,"w": 41,"h": 37} }, { "filename": "0065.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 35, - "y": 8, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 74, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 35,"y": 8,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 74,"w": 41,"h": 37} }, { "filename": "0094.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 14, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 111, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 111,"w": 41,"h": 37} }, { "filename": "0017.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 6, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 148, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 148,"w": 37,"h": 39} }, { "filename": "0037.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 6, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 187, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 187,"w": 37,"h": 39} }, { "filename": "0045.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 9, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 226, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 9,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 226,"w": 37,"h": 39} }, { "filename": "0064.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 6, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 265, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 265,"w": 37,"h": 39} }, { "filename": "0084.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 7, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 265, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 7,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 265,"w": 37,"h": 39} }, { "filename": "0081.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 39 - }, - "frame": { - "x": 37, - "y": 148, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 39}, + "frame": {"x": 37,"y": 148,"w": 37,"h": 39} }, { "filename": "0093.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 16, - "y": 9, - "w": 37, - "h": 39 - }, - "frame": { - "x": 41, - "y": 37, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 16,"y": 9,"w": 37,"h": 39}, + "frame": {"x": 41,"y": 37,"w": 37,"h": 39} }, { "filename": "0001.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 41, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 41,"y": 76,"w": 39,"h": 37} }, { "filename": "0086.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 41, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 41,"y": 76,"w": 39,"h": 37} }, { "filename": "0002.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 78,"y": 37,"w": 39,"h": 37} }, { "filename": "0087.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 78,"y": 37,"w": 39,"h": 37} }, { "filename": "0009.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 5, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 41, - "y": 113, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 41,"y": 113,"w": 39,"h": 35} }, { "filename": "0003.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 4, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 187, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 4,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 187,"w": 39,"h": 37} }, { "filename": "0004.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 3, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 74, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 74,"y": 148,"w": 39,"h": 37} }, { "filename": "0024.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 74, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 74,"y": 148,"w": 39,"h": 37} }, { "filename": "0010.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 10, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 80, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 10,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 80,"y": 74,"w": 39,"h": 37} }, { "filename": "0019.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 117,"y": 37,"w": 39,"h": 37} }, { "filename": "0089.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 117,"y": 37,"w": 39,"h": 37} }, { "filename": "0020.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 80, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 80,"y": 111,"w": 39,"h": 37} }, { "filename": "0021.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 224, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 224,"w": 39,"h": 37} }, { "filename": "0066.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 224, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 224,"w": 39,"h": 37} }, { "filename": "0022.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 261, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 261,"w": 39,"h": 37} }, { "filename": "0067.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 261, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 261,"w": 39,"h": 37} }, { "filename": "0023.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 14, - "y": 5, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 5,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 185,"w": 39,"h": 37} }, { "filename": "0030.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 113, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 9,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 113,"y": 148,"w": 39,"h": 37} }, { "filename": "0031.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 119, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 119,"y": 74,"w": 39,"h": 37} }, { "filename": "0038.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 36, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 36,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0068.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0078.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0088.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0039.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 119, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 119,"y": 111,"w": 39,"h": 37} }, { "filename": "0040.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 222, - "w": 39, - "h": 37 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 76, - "y": 296, - "w": 39, - "h": 35 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 3, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 4, - "w": 39, - "h": 37 - }, - "frame": { - "x": 152, - "y": 148, - "w": 39, - "h": 37 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 10, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 158, - "y": 74, - "w": 39, - "h": 37 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 14, - "y": 5, - "w": 39, - "h": 37 - }, - "frame": { - "x": 158, - "y": 111, - "w": 39, - "h": 37 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 222, - "w": 39, - "h": 37 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 115, - "y": 296, - "w": 39, - "h": 35 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 115, - "y": 296, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 222,"w": 39,"h": 37} }, { "filename": "0085.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 36, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 191, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 36,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 222,"w": 39,"h": 37} + }, + { + "filename": "0041.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0042.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0043.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0048.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0049.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0047.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 6,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0051.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0091.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 6,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0050.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 4,"w": 39,"h": 37}, + "frame": {"x": 152,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0057.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 10,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 158,"y": 74,"w": 39,"h": 37} + }, + { + "filename": "0069.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 195,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0070.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 5,"w": 39,"h": 37}, + "frame": {"x": 158,"y": 111,"w": 39,"h": 37} + }, + { + "filename": "0071.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 222,"w": 39,"h": 37} + }, + { + "filename": "0077.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 9,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 259,"w": 39,"h": 37} }, { "filename": "0090.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 197, - "y": 74, - "w": 39, - "h": 37 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 39, - "h": 36 - }, - "frame": { - "x": 234, - "y": 37, - "w": 39, - "h": 36 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 197, - "y": 111, - "w": 39, - "h": 36 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 197, - "y": 111, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 191,"y": 148,"w": 39,"h": 37} }, { "filename": "0014.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 38 - }, - "frame": { - "x": 273, - "y": 37, - "w": 37, - "h": 38 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 197,"y": 74,"w": 37,"h": 38} }, { "filename": "0034.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 38 - }, - "frame": { - "x": 273, - "y": 37, - "w": 37, - "h": 38 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 197,"y": 74,"w": 37,"h": 38} + }, + { + "filename": "0005.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 39,"h": 36}, + "frame": {"x": 197,"y": 112,"w": 39,"h": 36} }, { "filename": "0061.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 38 - }, - "frame": { - "x": 236, - "y": 73, - "w": 37, - "h": 38 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 234,"y": 37,"w": 37,"h": 38} + }, + { + "filename": "0008.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 1,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 234,"y": 75,"w": 39,"h": 36} + }, + { + "filename": "0028.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 234,"y": 75,"w": 39,"h": 36} }, { "filename": "0025.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 7, - "w": 39, - "h": 36 - }, - "frame": { - "x": 273, - "y": 75, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 7,"w": 39,"h": 36}, + "frame": {"x": 271,"y": 37,"w": 39,"h": 36} }, { "filename": "0046.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 19, - "y": 10, - "w": 39, - "h": 36 - }, - "frame": { - "x": 230, - "y": 147, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 19,"y": 10,"w": 39,"h": 36}, + "frame": {"x": 273,"y": 73,"w": 39,"h": 36} }, { "filename": "0052.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 8, - "w": 39, - "h": 36 - }, - "frame": { - "x": 236, - "y": 111, - "w": 39, - "h": 36 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 39, - "h": 36 - }, - "frame": { - "x": 269, - "y": 147, - "w": 39, - "h": 36 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 39, - "h": 36 - }, - "frame": { - "x": 275, - "y": 111, - "w": 39, - "h": 36 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 230, - "y": 183, - "w": 39, - "h": 36 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 230, - "y": 183, - "w": 39, - "h": 36 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 7, - "w": 39, - "h": 36 - }, - "frame": { - "x": 269, - "y": 183, - "w": 39, - "h": 36 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 18, - "y": 10, - "w": 39, - "h": 36 - }, - "frame": { - "x": 154, - "y": 185, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 1,"y": 8,"w": 39,"h": 36}, + "frame": {"x": 273,"y": 109,"w": 39,"h": 36} }, { "filename": "0015.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 193, - "y": 185, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 236,"y": 111,"w": 36,"h": 39} }, { "filename": "0035.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 193, - "y": 185, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 236,"y": 111,"w": 36,"h": 39} + }, + { + "filename": "0053.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 39,"h": 36}, + "frame": {"x": 272,"y": 145,"w": 39,"h": 36} + }, + { + "filename": "0054.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 39,"h": 36}, + "frame": {"x": 230,"y": 150,"w": 39,"h": 36} + }, + { + "filename": "0055.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 269,"y": 181,"w": 39,"h": 36} + }, + { + "filename": "0075.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 269,"y": 181,"w": 39,"h": 36} + }, + { + "filename": "0072.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 7,"w": 39,"h": 36}, + "frame": {"x": 154,"y": 185,"w": 39,"h": 36} }, { "filename": "0016.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 154, - "y": 221, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 185,"w": 36,"h": 39} }, { "filename": "0036.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 154, - "y": 221, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 185,"w": 36,"h": 39} + }, + { + "filename": "0092.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 18,"y": 10,"w": 39,"h": 36}, + "frame": {"x": 154,"y": 221,"w": 39,"h": 36} }, { "filename": "0062.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 229, - "y": 219, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 229,"y": 186,"w": 36,"h": 39} }, { "filename": "0082.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 2, - "w": 36, - "h": 39 - }, - "frame": { - "x": 229, - "y": 219, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 2,"w": 36,"h": 39}, + "frame": {"x": 229,"y": 186,"w": 36,"h": 39} }, { "filename": "0063.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 190, - "y": 224, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 224,"w": 36,"h": 39} }, { "filename": "0083.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 2, - "w": 36, - "h": 39 - }, - "frame": { - "x": 190, - "y": 224, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 2,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 224,"w": 36,"h": 39} }, { "filename": "0006.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 38, - "h": 36 - }, - "frame": { - "x": 265, - "y": 219, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 38,"h": 36}, + "frame": {"x": 154,"y": 257,"w": 38,"h": 36} + }, + { + "filename": "0029.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 154,"y": 293,"w": 39,"h": 35} }, { "filename": "0007.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 38, - "h": 36 - }, - "frame": { - "x": 265, - "y": 255, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 38,"h": 36}, + "frame": {"x": 265,"y": 217,"w": 38,"h": 36} }, { "filename": "0026.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 265, - "y": 255, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 265,"y": 217,"w": 38,"h": 36} }, { "filename": "0027.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 226, - "y": 258, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 229,"y": 253,"w": 38,"h": 36} }, { "filename": "0073.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 264, - "y": 291, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 267,"y": 253,"w": 38,"h": 36} }, { "filename": "0074.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 154, - "y": 294, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 193,"y": 289,"w": 38,"h": 36} + }, + { + "filename": "0056.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 231,"y": 289,"w": 39,"h": 35} + }, + { + "filename": "0076.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 231,"y": 289,"w": 39,"h": 35} } ] } ], "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:fac9dddfb1c0198c451e87a54c96301e:6930fc5fe37e2424fbaca28167f16d18:0787168dbe37404ac3aa22b487979d47$" - } + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0"} } diff --git a/public/images/pokemon/exp/back/shiny/774-blue.png b/public/images/pokemon/exp/back/shiny/774-blue.png index bffbc41e81c..447f203e371 100644 Binary files a/public/images/pokemon/exp/back/shiny/774-blue.png and b/public/images/pokemon/exp/back/shiny/774-blue.png differ diff --git a/public/images/pokemon/exp/back/shiny/774-green.json b/public/images/pokemon/exp/back/shiny/774-green.json index c0ba2a0af04..21c0498db65 100644 --- a/public/images/pokemon/exp/back/shiny/774-green.json +++ b/public/images/pokemon/exp/back/shiny/774-green.json @@ -3,1992 +3,765 @@ { "image": "774-green.png", "format": "RGBA8888", - "size": { - "w": 331, - "h": 331 - }, + "size": {"w": 328,"h": 328}, "scale": 1, "frames": [ { "filename": "0011.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 11, - "y": 10, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 11,"y": 10,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 0,"w": 41,"h": 37} }, { "filename": "0012.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 0,"w": 41,"h": 37} }, { "filename": "0013.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 41, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 41,"y": 0,"w": 41,"h": 37} }, { "filename": "0018.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 35, - "y": 8, - "w": 41, - "h": 37 - }, - "frame": { - "x": 82, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 35,"y": 8,"w": 41,"h": 37}, + "frame": {"x": 82,"y": 0,"w": 41,"h": 37} }, { "filename": "0032.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 123, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 123,"y": 0,"w": 41,"h": 37} }, { "filename": "0033.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 164, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 164,"y": 0,"w": 41,"h": 37} }, { "filename": "0044.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 16, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 205, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 16,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 205,"y": 0,"w": 41,"h": 37} }, { "filename": "0058.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 11, - "y": 10, - "w": 41, - "h": 37 - }, - "frame": { - "x": 246, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 11,"y": 10,"w": 41,"h": 37}, + "frame": {"x": 246,"y": 0,"w": 41,"h": 37} }, { "filename": "0059.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 287, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 287,"y": 0,"w": 41,"h": 37} }, { "filename": "0079.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 287, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 287,"y": 0,"w": 41,"h": 37} }, { "filename": "0060.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 37, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 37,"w": 41,"h": 37} }, { "filename": "0080.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 37, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 37,"w": 41,"h": 37} }, { "filename": "0065.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 35, - "y": 8, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 74, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 35,"y": 8,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 74,"w": 41,"h": 37} }, { "filename": "0094.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 14, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 111, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 111,"w": 41,"h": 37} }, { "filename": "0017.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 6, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 148, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 148,"w": 37,"h": 39} }, { "filename": "0037.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 6, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 187, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 187,"w": 37,"h": 39} }, { "filename": "0045.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 9, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 226, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 9,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 226,"w": 37,"h": 39} }, { "filename": "0064.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 6, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 265, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 265,"w": 37,"h": 39} }, { "filename": "0084.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 7, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 265, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 7,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 265,"w": 37,"h": 39} }, { "filename": "0081.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 39 - }, - "frame": { - "x": 37, - "y": 148, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 39}, + "frame": {"x": 37,"y": 148,"w": 37,"h": 39} }, { "filename": "0093.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 16, - "y": 9, - "w": 37, - "h": 39 - }, - "frame": { - "x": 41, - "y": 37, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 16,"y": 9,"w": 37,"h": 39}, + "frame": {"x": 41,"y": 37,"w": 37,"h": 39} }, { "filename": "0001.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 41, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 41,"y": 76,"w": 39,"h": 37} }, { "filename": "0086.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 41, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 41,"y": 76,"w": 39,"h": 37} }, { "filename": "0002.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 78,"y": 37,"w": 39,"h": 37} }, { "filename": "0087.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 78,"y": 37,"w": 39,"h": 37} }, { "filename": "0009.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 5, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 41, - "y": 113, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 41,"y": 113,"w": 39,"h": 35} }, { "filename": "0003.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 4, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 187, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 4,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 187,"w": 39,"h": 37} }, { "filename": "0004.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 3, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 74, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 74,"y": 148,"w": 39,"h": 37} }, { "filename": "0024.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 74, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 74,"y": 148,"w": 39,"h": 37} }, { "filename": "0010.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 10, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 80, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 10,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 80,"y": 74,"w": 39,"h": 37} }, { "filename": "0019.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 117,"y": 37,"w": 39,"h": 37} }, { "filename": "0089.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 117,"y": 37,"w": 39,"h": 37} }, { "filename": "0020.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 80, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 80,"y": 111,"w": 39,"h": 37} }, { "filename": "0021.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 224, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 224,"w": 39,"h": 37} }, { "filename": "0066.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 224, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 224,"w": 39,"h": 37} }, { "filename": "0022.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 261, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 261,"w": 39,"h": 37} }, { "filename": "0067.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 261, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 261,"w": 39,"h": 37} }, { "filename": "0023.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 14, - "y": 5, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 5,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 185,"w": 39,"h": 37} }, { "filename": "0030.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 113, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 9,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 113,"y": 148,"w": 39,"h": 37} }, { "filename": "0031.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 119, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 119,"y": 74,"w": 39,"h": 37} }, { "filename": "0038.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 36, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 36,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0068.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0078.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0088.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0039.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 119, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 119,"y": 111,"w": 39,"h": 37} }, { "filename": "0040.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 222, - "w": 39, - "h": 37 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 76, - "y": 296, - "w": 39, - "h": 35 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 3, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 4, - "w": 39, - "h": 37 - }, - "frame": { - "x": 152, - "y": 148, - "w": 39, - "h": 37 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 10, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 158, - "y": 74, - "w": 39, - "h": 37 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 14, - "y": 5, - "w": 39, - "h": 37 - }, - "frame": { - "x": 158, - "y": 111, - "w": 39, - "h": 37 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 222, - "w": 39, - "h": 37 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 115, - "y": 296, - "w": 39, - "h": 35 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 115, - "y": 296, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 222,"w": 39,"h": 37} }, { "filename": "0085.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 36, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 191, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 36,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 222,"w": 39,"h": 37} + }, + { + "filename": "0041.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0042.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0043.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0048.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0049.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0047.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 6,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0051.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0091.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 6,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0050.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 4,"w": 39,"h": 37}, + "frame": {"x": 152,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0057.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 10,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 158,"y": 74,"w": 39,"h": 37} + }, + { + "filename": "0069.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 195,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0070.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 5,"w": 39,"h": 37}, + "frame": {"x": 158,"y": 111,"w": 39,"h": 37} + }, + { + "filename": "0071.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 222,"w": 39,"h": 37} + }, + { + "filename": "0077.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 9,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 259,"w": 39,"h": 37} }, { "filename": "0090.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 197, - "y": 74, - "w": 39, - "h": 37 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 39, - "h": 36 - }, - "frame": { - "x": 234, - "y": 37, - "w": 39, - "h": 36 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 197, - "y": 111, - "w": 39, - "h": 36 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 197, - "y": 111, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 191,"y": 148,"w": 39,"h": 37} }, { "filename": "0014.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 38 - }, - "frame": { - "x": 273, - "y": 37, - "w": 37, - "h": 38 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 197,"y": 74,"w": 37,"h": 38} }, { "filename": "0034.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 38 - }, - "frame": { - "x": 273, - "y": 37, - "w": 37, - "h": 38 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 197,"y": 74,"w": 37,"h": 38} + }, + { + "filename": "0005.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 39,"h": 36}, + "frame": {"x": 197,"y": 112,"w": 39,"h": 36} }, { "filename": "0061.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 38 - }, - "frame": { - "x": 236, - "y": 73, - "w": 37, - "h": 38 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 234,"y": 37,"w": 37,"h": 38} + }, + { + "filename": "0008.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 1,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 234,"y": 75,"w": 39,"h": 36} + }, + { + "filename": "0028.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 234,"y": 75,"w": 39,"h": 36} }, { "filename": "0025.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 7, - "w": 39, - "h": 36 - }, - "frame": { - "x": 273, - "y": 75, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 7,"w": 39,"h": 36}, + "frame": {"x": 271,"y": 37,"w": 39,"h": 36} }, { "filename": "0046.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 19, - "y": 10, - "w": 39, - "h": 36 - }, - "frame": { - "x": 230, - "y": 147, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 19,"y": 10,"w": 39,"h": 36}, + "frame": {"x": 273,"y": 73,"w": 39,"h": 36} }, { "filename": "0052.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 8, - "w": 39, - "h": 36 - }, - "frame": { - "x": 236, - "y": 111, - "w": 39, - "h": 36 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 39, - "h": 36 - }, - "frame": { - "x": 269, - "y": 147, - "w": 39, - "h": 36 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 39, - "h": 36 - }, - "frame": { - "x": 275, - "y": 111, - "w": 39, - "h": 36 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 230, - "y": 183, - "w": 39, - "h": 36 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 230, - "y": 183, - "w": 39, - "h": 36 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 7, - "w": 39, - "h": 36 - }, - "frame": { - "x": 269, - "y": 183, - "w": 39, - "h": 36 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 18, - "y": 10, - "w": 39, - "h": 36 - }, - "frame": { - "x": 154, - "y": 185, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 1,"y": 8,"w": 39,"h": 36}, + "frame": {"x": 273,"y": 109,"w": 39,"h": 36} }, { "filename": "0015.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 193, - "y": 185, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 236,"y": 111,"w": 36,"h": 39} }, { "filename": "0035.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 193, - "y": 185, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 236,"y": 111,"w": 36,"h": 39} + }, + { + "filename": "0053.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 39,"h": 36}, + "frame": {"x": 272,"y": 145,"w": 39,"h": 36} + }, + { + "filename": "0054.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 39,"h": 36}, + "frame": {"x": 230,"y": 150,"w": 39,"h": 36} + }, + { + "filename": "0055.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 269,"y": 181,"w": 39,"h": 36} + }, + { + "filename": "0075.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 269,"y": 181,"w": 39,"h": 36} + }, + { + "filename": "0072.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 7,"w": 39,"h": 36}, + "frame": {"x": 154,"y": 185,"w": 39,"h": 36} }, { "filename": "0016.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 154, - "y": 221, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 185,"w": 36,"h": 39} }, { "filename": "0036.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 154, - "y": 221, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 185,"w": 36,"h": 39} + }, + { + "filename": "0092.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 18,"y": 10,"w": 39,"h": 36}, + "frame": {"x": 154,"y": 221,"w": 39,"h": 36} }, { "filename": "0062.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 229, - "y": 219, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 229,"y": 186,"w": 36,"h": 39} }, { "filename": "0082.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 2, - "w": 36, - "h": 39 - }, - "frame": { - "x": 229, - "y": 219, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 2,"w": 36,"h": 39}, + "frame": {"x": 229,"y": 186,"w": 36,"h": 39} }, { "filename": "0063.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 190, - "y": 224, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 224,"w": 36,"h": 39} }, { "filename": "0083.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 2, - "w": 36, - "h": 39 - }, - "frame": { - "x": 190, - "y": 224, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 2,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 224,"w": 36,"h": 39} }, { "filename": "0006.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 38, - "h": 36 - }, - "frame": { - "x": 265, - "y": 219, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 38,"h": 36}, + "frame": {"x": 154,"y": 257,"w": 38,"h": 36} + }, + { + "filename": "0029.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 154,"y": 293,"w": 39,"h": 35} }, { "filename": "0007.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 38, - "h": 36 - }, - "frame": { - "x": 265, - "y": 255, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 38,"h": 36}, + "frame": {"x": 265,"y": 217,"w": 38,"h": 36} }, { "filename": "0026.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 265, - "y": 255, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 265,"y": 217,"w": 38,"h": 36} }, { "filename": "0027.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 226, - "y": 258, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 229,"y": 253,"w": 38,"h": 36} }, { "filename": "0073.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 264, - "y": 291, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 267,"y": 253,"w": 38,"h": 36} }, { "filename": "0074.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 154, - "y": 294, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 193,"y": 289,"w": 38,"h": 36} + }, + { + "filename": "0056.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 231,"y": 289,"w": 39,"h": 35} + }, + { + "filename": "0076.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 231,"y": 289,"w": 39,"h": 35} } ] } ], "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:43704649632960bb944a604d7a5e28dd:a87f7ed76b9cceb327a50caa5e95ad94:e4b1fffb78b8c0cdc557670bcee043ca$" - } + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0"} } diff --git a/public/images/pokemon/exp/back/shiny/774-green.png b/public/images/pokemon/exp/back/shiny/774-green.png index f5a85c1ba0f..0694ac2c83f 100644 Binary files a/public/images/pokemon/exp/back/shiny/774-green.png and b/public/images/pokemon/exp/back/shiny/774-green.png differ diff --git a/public/images/pokemon/exp/back/shiny/774-indigo.json b/public/images/pokemon/exp/back/shiny/774-indigo.json index 984fff68202..bd7fb18a9ea 100644 --- a/public/images/pokemon/exp/back/shiny/774-indigo.json +++ b/public/images/pokemon/exp/back/shiny/774-indigo.json @@ -3,1992 +3,765 @@ { "image": "774-indigo.png", "format": "RGBA8888", - "size": { - "w": 331, - "h": 331 - }, + "size": {"w": 328,"h": 328}, "scale": 1, "frames": [ { "filename": "0011.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 11, - "y": 10, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 11,"y": 10,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 0,"w": 41,"h": 37} }, { "filename": "0012.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 0,"w": 41,"h": 37} }, { "filename": "0013.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 41, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 41,"y": 0,"w": 41,"h": 37} }, { "filename": "0018.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 35, - "y": 8, - "w": 41, - "h": 37 - }, - "frame": { - "x": 82, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 35,"y": 8,"w": 41,"h": 37}, + "frame": {"x": 82,"y": 0,"w": 41,"h": 37} }, { "filename": "0032.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 123, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 123,"y": 0,"w": 41,"h": 37} }, { "filename": "0033.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 164, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 164,"y": 0,"w": 41,"h": 37} }, { "filename": "0044.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 16, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 205, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 16,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 205,"y": 0,"w": 41,"h": 37} }, { "filename": "0058.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 11, - "y": 10, - "w": 41, - "h": 37 - }, - "frame": { - "x": 246, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 11,"y": 10,"w": 41,"h": 37}, + "frame": {"x": 246,"y": 0,"w": 41,"h": 37} }, { "filename": "0059.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 287, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 287,"y": 0,"w": 41,"h": 37} }, { "filename": "0079.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 287, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 287,"y": 0,"w": 41,"h": 37} }, { "filename": "0060.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 37, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 37,"w": 41,"h": 37} }, { "filename": "0080.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 37, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 37,"w": 41,"h": 37} }, { "filename": "0065.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 35, - "y": 8, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 74, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 35,"y": 8,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 74,"w": 41,"h": 37} }, { "filename": "0094.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 14, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 111, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 111,"w": 41,"h": 37} }, { "filename": "0017.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 6, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 148, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 148,"w": 37,"h": 39} }, { "filename": "0037.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 6, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 187, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 187,"w": 37,"h": 39} }, { "filename": "0045.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 9, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 226, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 9,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 226,"w": 37,"h": 39} }, { "filename": "0064.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 6, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 265, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 265,"w": 37,"h": 39} }, { "filename": "0084.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 7, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 265, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 7,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 265,"w": 37,"h": 39} }, { "filename": "0081.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 39 - }, - "frame": { - "x": 37, - "y": 148, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 39}, + "frame": {"x": 37,"y": 148,"w": 37,"h": 39} }, { "filename": "0093.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 16, - "y": 9, - "w": 37, - "h": 39 - }, - "frame": { - "x": 41, - "y": 37, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 16,"y": 9,"w": 37,"h": 39}, + "frame": {"x": 41,"y": 37,"w": 37,"h": 39} }, { "filename": "0001.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 41, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 41,"y": 76,"w": 39,"h": 37} }, { "filename": "0086.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 41, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 41,"y": 76,"w": 39,"h": 37} }, { "filename": "0002.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 78,"y": 37,"w": 39,"h": 37} }, { "filename": "0087.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 78,"y": 37,"w": 39,"h": 37} }, { "filename": "0009.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 5, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 41, - "y": 113, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 41,"y": 113,"w": 39,"h": 35} }, { "filename": "0003.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 4, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 187, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 4,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 187,"w": 39,"h": 37} }, { "filename": "0004.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 3, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 74, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 74,"y": 148,"w": 39,"h": 37} }, { "filename": "0024.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 74, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 74,"y": 148,"w": 39,"h": 37} }, { "filename": "0010.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 10, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 80, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 10,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 80,"y": 74,"w": 39,"h": 37} }, { "filename": "0019.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 117,"y": 37,"w": 39,"h": 37} }, { "filename": "0089.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 117,"y": 37,"w": 39,"h": 37} }, { "filename": "0020.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 80, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 80,"y": 111,"w": 39,"h": 37} }, { "filename": "0021.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 224, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 224,"w": 39,"h": 37} }, { "filename": "0066.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 224, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 224,"w": 39,"h": 37} }, { "filename": "0022.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 261, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 261,"w": 39,"h": 37} }, { "filename": "0067.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 261, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 261,"w": 39,"h": 37} }, { "filename": "0023.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 14, - "y": 5, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 5,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 185,"w": 39,"h": 37} }, { "filename": "0030.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 113, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 9,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 113,"y": 148,"w": 39,"h": 37} }, { "filename": "0031.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 119, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 119,"y": 74,"w": 39,"h": 37} }, { "filename": "0038.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 36, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 36,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0068.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0078.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0088.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0039.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 119, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 119,"y": 111,"w": 39,"h": 37} }, { "filename": "0040.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 222, - "w": 39, - "h": 37 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 76, - "y": 296, - "w": 39, - "h": 35 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 3, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 4, - "w": 39, - "h": 37 - }, - "frame": { - "x": 152, - "y": 148, - "w": 39, - "h": 37 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 10, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 158, - "y": 74, - "w": 39, - "h": 37 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 14, - "y": 5, - "w": 39, - "h": 37 - }, - "frame": { - "x": 158, - "y": 111, - "w": 39, - "h": 37 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 222, - "w": 39, - "h": 37 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 115, - "y": 296, - "w": 39, - "h": 35 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 115, - "y": 296, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 222,"w": 39,"h": 37} }, { "filename": "0085.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 36, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 191, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 36,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 222,"w": 39,"h": 37} + }, + { + "filename": "0041.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0042.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0043.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0048.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0049.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0047.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 6,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0051.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0091.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 6,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0050.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 4,"w": 39,"h": 37}, + "frame": {"x": 152,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0057.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 10,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 158,"y": 74,"w": 39,"h": 37} + }, + { + "filename": "0069.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 195,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0070.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 5,"w": 39,"h": 37}, + "frame": {"x": 158,"y": 111,"w": 39,"h": 37} + }, + { + "filename": "0071.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 222,"w": 39,"h": 37} + }, + { + "filename": "0077.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 9,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 259,"w": 39,"h": 37} }, { "filename": "0090.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 197, - "y": 74, - "w": 39, - "h": 37 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 39, - "h": 36 - }, - "frame": { - "x": 234, - "y": 37, - "w": 39, - "h": 36 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 197, - "y": 111, - "w": 39, - "h": 36 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 197, - "y": 111, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 191,"y": 148,"w": 39,"h": 37} }, { "filename": "0014.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 38 - }, - "frame": { - "x": 273, - "y": 37, - "w": 37, - "h": 38 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 197,"y": 74,"w": 37,"h": 38} }, { "filename": "0034.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 38 - }, - "frame": { - "x": 273, - "y": 37, - "w": 37, - "h": 38 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 197,"y": 74,"w": 37,"h": 38} + }, + { + "filename": "0005.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 39,"h": 36}, + "frame": {"x": 197,"y": 112,"w": 39,"h": 36} }, { "filename": "0061.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 38 - }, - "frame": { - "x": 236, - "y": 73, - "w": 37, - "h": 38 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 234,"y": 37,"w": 37,"h": 38} + }, + { + "filename": "0008.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 1,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 234,"y": 75,"w": 39,"h": 36} + }, + { + "filename": "0028.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 234,"y": 75,"w": 39,"h": 36} }, { "filename": "0025.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 7, - "w": 39, - "h": 36 - }, - "frame": { - "x": 273, - "y": 75, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 7,"w": 39,"h": 36}, + "frame": {"x": 271,"y": 37,"w": 39,"h": 36} }, { "filename": "0046.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 19, - "y": 10, - "w": 39, - "h": 36 - }, - "frame": { - "x": 230, - "y": 147, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 19,"y": 10,"w": 39,"h": 36}, + "frame": {"x": 273,"y": 73,"w": 39,"h": 36} }, { "filename": "0052.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 8, - "w": 39, - "h": 36 - }, - "frame": { - "x": 236, - "y": 111, - "w": 39, - "h": 36 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 39, - "h": 36 - }, - "frame": { - "x": 269, - "y": 147, - "w": 39, - "h": 36 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 39, - "h": 36 - }, - "frame": { - "x": 275, - "y": 111, - "w": 39, - "h": 36 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 230, - "y": 183, - "w": 39, - "h": 36 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 230, - "y": 183, - "w": 39, - "h": 36 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 7, - "w": 39, - "h": 36 - }, - "frame": { - "x": 269, - "y": 183, - "w": 39, - "h": 36 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 18, - "y": 10, - "w": 39, - "h": 36 - }, - "frame": { - "x": 154, - "y": 185, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 1,"y": 8,"w": 39,"h": 36}, + "frame": {"x": 273,"y": 109,"w": 39,"h": 36} }, { "filename": "0015.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 193, - "y": 185, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 236,"y": 111,"w": 36,"h": 39} }, { "filename": "0035.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 193, - "y": 185, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 236,"y": 111,"w": 36,"h": 39} + }, + { + "filename": "0053.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 39,"h": 36}, + "frame": {"x": 272,"y": 145,"w": 39,"h": 36} + }, + { + "filename": "0054.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 39,"h": 36}, + "frame": {"x": 230,"y": 150,"w": 39,"h": 36} + }, + { + "filename": "0055.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 269,"y": 181,"w": 39,"h": 36} + }, + { + "filename": "0075.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 269,"y": 181,"w": 39,"h": 36} + }, + { + "filename": "0072.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 7,"w": 39,"h": 36}, + "frame": {"x": 154,"y": 185,"w": 39,"h": 36} }, { "filename": "0016.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 154, - "y": 221, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 185,"w": 36,"h": 39} }, { "filename": "0036.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 154, - "y": 221, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 185,"w": 36,"h": 39} + }, + { + "filename": "0092.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 18,"y": 10,"w": 39,"h": 36}, + "frame": {"x": 154,"y": 221,"w": 39,"h": 36} }, { "filename": "0062.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 229, - "y": 219, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 229,"y": 186,"w": 36,"h": 39} }, { "filename": "0082.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 2, - "w": 36, - "h": 39 - }, - "frame": { - "x": 229, - "y": 219, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 2,"w": 36,"h": 39}, + "frame": {"x": 229,"y": 186,"w": 36,"h": 39} }, { "filename": "0063.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 190, - "y": 224, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 224,"w": 36,"h": 39} }, { "filename": "0083.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 2, - "w": 36, - "h": 39 - }, - "frame": { - "x": 190, - "y": 224, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 2,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 224,"w": 36,"h": 39} }, { "filename": "0006.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 38, - "h": 36 - }, - "frame": { - "x": 265, - "y": 219, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 38,"h": 36}, + "frame": {"x": 154,"y": 257,"w": 38,"h": 36} + }, + { + "filename": "0029.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 154,"y": 293,"w": 39,"h": 35} }, { "filename": "0007.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 38, - "h": 36 - }, - "frame": { - "x": 265, - "y": 255, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 38,"h": 36}, + "frame": {"x": 265,"y": 217,"w": 38,"h": 36} }, { "filename": "0026.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 265, - "y": 255, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 265,"y": 217,"w": 38,"h": 36} }, { "filename": "0027.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 226, - "y": 258, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 229,"y": 253,"w": 38,"h": 36} }, { "filename": "0073.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 264, - "y": 291, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 267,"y": 253,"w": 38,"h": 36} }, { "filename": "0074.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 154, - "y": 294, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 193,"y": 289,"w": 38,"h": 36} + }, + { + "filename": "0056.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 231,"y": 289,"w": 39,"h": 35} + }, + { + "filename": "0076.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 231,"y": 289,"w": 39,"h": 35} } ] } ], "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:926ac4842be99bfd50528ae312a3d976:7284e512a285e0bd298174144d17104f:f6d3104f6cc09a16e2cbfcba30e4d78a$" - } + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0"} } diff --git a/public/images/pokemon/exp/back/shiny/774-indigo.png b/public/images/pokemon/exp/back/shiny/774-indigo.png index 115365f11b8..6e511400fbe 100644 Binary files a/public/images/pokemon/exp/back/shiny/774-indigo.png and b/public/images/pokemon/exp/back/shiny/774-indigo.png differ diff --git a/public/images/pokemon/exp/back/shiny/774-orange.json b/public/images/pokemon/exp/back/shiny/774-orange.json index c70854397b3..45e2604bf4e 100644 --- a/public/images/pokemon/exp/back/shiny/774-orange.json +++ b/public/images/pokemon/exp/back/shiny/774-orange.json @@ -3,1992 +3,765 @@ { "image": "774-orange.png", "format": "RGBA8888", - "size": { - "w": 331, - "h": 331 - }, + "size": {"w": 328,"h": 328}, "scale": 1, "frames": [ { "filename": "0011.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 11, - "y": 10, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 11,"y": 10,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 0,"w": 41,"h": 37} }, { "filename": "0012.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 0,"w": 41,"h": 37} }, { "filename": "0013.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 41, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 41,"y": 0,"w": 41,"h": 37} }, { "filename": "0018.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 35, - "y": 8, - "w": 41, - "h": 37 - }, - "frame": { - "x": 82, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 35,"y": 8,"w": 41,"h": 37}, + "frame": {"x": 82,"y": 0,"w": 41,"h": 37} }, { "filename": "0032.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 123, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 123,"y": 0,"w": 41,"h": 37} }, { "filename": "0033.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 164, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 164,"y": 0,"w": 41,"h": 37} }, { "filename": "0044.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 16, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 205, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 16,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 205,"y": 0,"w": 41,"h": 37} }, { "filename": "0058.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 11, - "y": 10, - "w": 41, - "h": 37 - }, - "frame": { - "x": 246, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 11,"y": 10,"w": 41,"h": 37}, + "frame": {"x": 246,"y": 0,"w": 41,"h": 37} }, { "filename": "0059.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 287, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 287,"y": 0,"w": 41,"h": 37} }, { "filename": "0079.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 287, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 287,"y": 0,"w": 41,"h": 37} }, { "filename": "0060.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 37, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 37,"w": 41,"h": 37} }, { "filename": "0080.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 37, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 37,"w": 41,"h": 37} }, { "filename": "0065.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 35, - "y": 8, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 74, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 35,"y": 8,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 74,"w": 41,"h": 37} }, { "filename": "0094.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 14, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 111, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 111,"w": 41,"h": 37} }, { "filename": "0017.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 6, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 148, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 148,"w": 37,"h": 39} }, { "filename": "0037.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 6, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 187, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 187,"w": 37,"h": 39} }, { "filename": "0045.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 9, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 226, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 9,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 226,"w": 37,"h": 39} }, { "filename": "0064.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 6, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 265, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 265,"w": 37,"h": 39} }, { "filename": "0084.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 7, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 265, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 7,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 265,"w": 37,"h": 39} }, { "filename": "0081.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 39 - }, - "frame": { - "x": 37, - "y": 148, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 39}, + "frame": {"x": 37,"y": 148,"w": 37,"h": 39} }, { "filename": "0093.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 16, - "y": 9, - "w": 37, - "h": 39 - }, - "frame": { - "x": 41, - "y": 37, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 16,"y": 9,"w": 37,"h": 39}, + "frame": {"x": 41,"y": 37,"w": 37,"h": 39} }, { "filename": "0001.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 41, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 41,"y": 76,"w": 39,"h": 37} }, { "filename": "0086.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 41, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 41,"y": 76,"w": 39,"h": 37} }, { "filename": "0002.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 78,"y": 37,"w": 39,"h": 37} }, { "filename": "0087.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 78,"y": 37,"w": 39,"h": 37} }, { "filename": "0009.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 5, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 41, - "y": 113, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 41,"y": 113,"w": 39,"h": 35} }, { "filename": "0003.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 4, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 187, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 4,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 187,"w": 39,"h": 37} }, { "filename": "0004.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 3, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 74, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 74,"y": 148,"w": 39,"h": 37} }, { "filename": "0024.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 74, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 74,"y": 148,"w": 39,"h": 37} }, { "filename": "0010.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 10, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 80, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 10,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 80,"y": 74,"w": 39,"h": 37} }, { "filename": "0019.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 117,"y": 37,"w": 39,"h": 37} }, { "filename": "0089.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 117,"y": 37,"w": 39,"h": 37} }, { "filename": "0020.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 80, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 80,"y": 111,"w": 39,"h": 37} }, { "filename": "0021.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 224, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 224,"w": 39,"h": 37} }, { "filename": "0066.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 224, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 224,"w": 39,"h": 37} }, { "filename": "0022.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 261, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 261,"w": 39,"h": 37} }, { "filename": "0067.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 261, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 261,"w": 39,"h": 37} }, { "filename": "0023.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 14, - "y": 5, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 5,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 185,"w": 39,"h": 37} }, { "filename": "0030.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 113, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 9,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 113,"y": 148,"w": 39,"h": 37} }, { "filename": "0031.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 119, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 119,"y": 74,"w": 39,"h": 37} }, { "filename": "0038.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 36, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 36,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0068.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0078.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0088.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0039.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 119, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 119,"y": 111,"w": 39,"h": 37} }, { "filename": "0040.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 222, - "w": 39, - "h": 37 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 76, - "y": 296, - "w": 39, - "h": 35 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 3, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 4, - "w": 39, - "h": 37 - }, - "frame": { - "x": 152, - "y": 148, - "w": 39, - "h": 37 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 10, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 158, - "y": 74, - "w": 39, - "h": 37 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 14, - "y": 5, - "w": 39, - "h": 37 - }, - "frame": { - "x": 158, - "y": 111, - "w": 39, - "h": 37 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 222, - "w": 39, - "h": 37 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 115, - "y": 296, - "w": 39, - "h": 35 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 115, - "y": 296, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 222,"w": 39,"h": 37} }, { "filename": "0085.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 36, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 191, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 36,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 222,"w": 39,"h": 37} + }, + { + "filename": "0041.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0042.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0043.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0048.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0049.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0047.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 6,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0051.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0091.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 6,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0050.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 4,"w": 39,"h": 37}, + "frame": {"x": 152,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0057.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 10,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 158,"y": 74,"w": 39,"h": 37} + }, + { + "filename": "0069.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 195,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0070.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 5,"w": 39,"h": 37}, + "frame": {"x": 158,"y": 111,"w": 39,"h": 37} + }, + { + "filename": "0071.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 222,"w": 39,"h": 37} + }, + { + "filename": "0077.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 9,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 259,"w": 39,"h": 37} }, { "filename": "0090.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 197, - "y": 74, - "w": 39, - "h": 37 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 39, - "h": 36 - }, - "frame": { - "x": 234, - "y": 37, - "w": 39, - "h": 36 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 197, - "y": 111, - "w": 39, - "h": 36 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 197, - "y": 111, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 191,"y": 148,"w": 39,"h": 37} }, { "filename": "0014.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 38 - }, - "frame": { - "x": 273, - "y": 37, - "w": 37, - "h": 38 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 197,"y": 74,"w": 37,"h": 38} }, { "filename": "0034.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 38 - }, - "frame": { - "x": 273, - "y": 37, - "w": 37, - "h": 38 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 197,"y": 74,"w": 37,"h": 38} + }, + { + "filename": "0005.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 39,"h": 36}, + "frame": {"x": 197,"y": 112,"w": 39,"h": 36} }, { "filename": "0061.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 38 - }, - "frame": { - "x": 236, - "y": 73, - "w": 37, - "h": 38 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 234,"y": 37,"w": 37,"h": 38} + }, + { + "filename": "0008.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 1,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 234,"y": 75,"w": 39,"h": 36} + }, + { + "filename": "0028.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 234,"y": 75,"w": 39,"h": 36} }, { "filename": "0025.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 7, - "w": 39, - "h": 36 - }, - "frame": { - "x": 273, - "y": 75, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 7,"w": 39,"h": 36}, + "frame": {"x": 271,"y": 37,"w": 39,"h": 36} }, { "filename": "0046.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 19, - "y": 10, - "w": 39, - "h": 36 - }, - "frame": { - "x": 230, - "y": 147, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 19,"y": 10,"w": 39,"h": 36}, + "frame": {"x": 273,"y": 73,"w": 39,"h": 36} }, { "filename": "0052.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 8, - "w": 39, - "h": 36 - }, - "frame": { - "x": 236, - "y": 111, - "w": 39, - "h": 36 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 39, - "h": 36 - }, - "frame": { - "x": 269, - "y": 147, - "w": 39, - "h": 36 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 39, - "h": 36 - }, - "frame": { - "x": 275, - "y": 111, - "w": 39, - "h": 36 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 230, - "y": 183, - "w": 39, - "h": 36 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 230, - "y": 183, - "w": 39, - "h": 36 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 7, - "w": 39, - "h": 36 - }, - "frame": { - "x": 269, - "y": 183, - "w": 39, - "h": 36 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 18, - "y": 10, - "w": 39, - "h": 36 - }, - "frame": { - "x": 154, - "y": 185, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 1,"y": 8,"w": 39,"h": 36}, + "frame": {"x": 273,"y": 109,"w": 39,"h": 36} }, { "filename": "0015.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 193, - "y": 185, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 236,"y": 111,"w": 36,"h": 39} }, { "filename": "0035.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 193, - "y": 185, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 236,"y": 111,"w": 36,"h": 39} + }, + { + "filename": "0053.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 39,"h": 36}, + "frame": {"x": 272,"y": 145,"w": 39,"h": 36} + }, + { + "filename": "0054.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 39,"h": 36}, + "frame": {"x": 230,"y": 150,"w": 39,"h": 36} + }, + { + "filename": "0055.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 269,"y": 181,"w": 39,"h": 36} + }, + { + "filename": "0075.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 269,"y": 181,"w": 39,"h": 36} + }, + { + "filename": "0072.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 7,"w": 39,"h": 36}, + "frame": {"x": 154,"y": 185,"w": 39,"h": 36} }, { "filename": "0016.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 154, - "y": 221, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 185,"w": 36,"h": 39} }, { "filename": "0036.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 154, - "y": 221, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 185,"w": 36,"h": 39} + }, + { + "filename": "0092.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 18,"y": 10,"w": 39,"h": 36}, + "frame": {"x": 154,"y": 221,"w": 39,"h": 36} }, { "filename": "0062.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 229, - "y": 219, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 229,"y": 186,"w": 36,"h": 39} }, { "filename": "0082.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 2, - "w": 36, - "h": 39 - }, - "frame": { - "x": 229, - "y": 219, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 2,"w": 36,"h": 39}, + "frame": {"x": 229,"y": 186,"w": 36,"h": 39} }, { "filename": "0063.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 190, - "y": 224, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 224,"w": 36,"h": 39} }, { "filename": "0083.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 2, - "w": 36, - "h": 39 - }, - "frame": { - "x": 190, - "y": 224, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 2,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 224,"w": 36,"h": 39} }, { "filename": "0006.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 38, - "h": 36 - }, - "frame": { - "x": 265, - "y": 219, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 38,"h": 36}, + "frame": {"x": 154,"y": 257,"w": 38,"h": 36} + }, + { + "filename": "0029.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 154,"y": 293,"w": 39,"h": 35} }, { "filename": "0007.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 38, - "h": 36 - }, - "frame": { - "x": 265, - "y": 255, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 38,"h": 36}, + "frame": {"x": 265,"y": 217,"w": 38,"h": 36} }, { "filename": "0026.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 265, - "y": 255, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 265,"y": 217,"w": 38,"h": 36} }, { "filename": "0027.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 226, - "y": 258, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 229,"y": 253,"w": 38,"h": 36} }, { "filename": "0073.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 264, - "y": 291, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 267,"y": 253,"w": 38,"h": 36} }, { "filename": "0074.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 154, - "y": 294, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 193,"y": 289,"w": 38,"h": 36} + }, + { + "filename": "0056.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 231,"y": 289,"w": 39,"h": 35} + }, + { + "filename": "0076.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 231,"y": 289,"w": 39,"h": 35} } ] } ], "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:2e07adf5981f632b0e41ac020e4990ce:61f845ae9c580a50936f96eeb312f00a:44d5ed9bf64302a0edf6c65ea8033c12$" - } + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0"} } diff --git a/public/images/pokemon/exp/back/shiny/774-orange.png b/public/images/pokemon/exp/back/shiny/774-orange.png index bf3db830ef8..61ffc375ab5 100644 Binary files a/public/images/pokemon/exp/back/shiny/774-orange.png and b/public/images/pokemon/exp/back/shiny/774-orange.png differ diff --git a/public/images/pokemon/exp/back/shiny/774-red.json b/public/images/pokemon/exp/back/shiny/774-red.json index 939127af914..94c5d8ddf83 100644 --- a/public/images/pokemon/exp/back/shiny/774-red.json +++ b/public/images/pokemon/exp/back/shiny/774-red.json @@ -3,1992 +3,765 @@ { "image": "774-red.png", "format": "RGBA8888", - "size": { - "w": 331, - "h": 331 - }, + "size": {"w": 328,"h": 328}, "scale": 1, "frames": [ { "filename": "0011.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 11, - "y": 10, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 11,"y": 10,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 0,"w": 41,"h": 37} }, { "filename": "0012.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 0,"w": 41,"h": 37} }, { "filename": "0013.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 41, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 41,"y": 0,"w": 41,"h": 37} }, { "filename": "0018.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 35, - "y": 8, - "w": 41, - "h": 37 - }, - "frame": { - "x": 82, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 35,"y": 8,"w": 41,"h": 37}, + "frame": {"x": 82,"y": 0,"w": 41,"h": 37} }, { "filename": "0032.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 123, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 123,"y": 0,"w": 41,"h": 37} }, { "filename": "0033.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 164, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 164,"y": 0,"w": 41,"h": 37} }, { "filename": "0044.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 16, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 205, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 16,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 205,"y": 0,"w": 41,"h": 37} }, { "filename": "0058.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 11, - "y": 10, - "w": 41, - "h": 37 - }, - "frame": { - "x": 246, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 11,"y": 10,"w": 41,"h": 37}, + "frame": {"x": 246,"y": 0,"w": 41,"h": 37} }, { "filename": "0059.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 287, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 287,"y": 0,"w": 41,"h": 37} }, { "filename": "0079.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 287, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 287,"y": 0,"w": 41,"h": 37} }, { "filename": "0060.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 37, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 37,"w": 41,"h": 37} }, { "filename": "0080.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 37, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 37,"w": 41,"h": 37} }, { "filename": "0065.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 35, - "y": 8, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 74, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 35,"y": 8,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 74,"w": 41,"h": 37} }, { "filename": "0094.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 14, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 111, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 111,"w": 41,"h": 37} }, { "filename": "0017.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 6, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 148, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 148,"w": 37,"h": 39} }, { "filename": "0037.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 6, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 187, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 187,"w": 37,"h": 39} }, { "filename": "0045.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 9, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 226, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 9,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 226,"w": 37,"h": 39} }, { "filename": "0064.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 6, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 265, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 265,"w": 37,"h": 39} }, { "filename": "0084.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 7, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 265, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 7,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 265,"w": 37,"h": 39} }, { "filename": "0081.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 39 - }, - "frame": { - "x": 37, - "y": 148, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 39}, + "frame": {"x": 37,"y": 148,"w": 37,"h": 39} }, { "filename": "0093.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 16, - "y": 9, - "w": 37, - "h": 39 - }, - "frame": { - "x": 41, - "y": 37, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 16,"y": 9,"w": 37,"h": 39}, + "frame": {"x": 41,"y": 37,"w": 37,"h": 39} }, { "filename": "0001.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 41, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 41,"y": 76,"w": 39,"h": 37} }, { "filename": "0086.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 41, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 41,"y": 76,"w": 39,"h": 37} }, { "filename": "0002.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 78,"y": 37,"w": 39,"h": 37} }, { "filename": "0087.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 78,"y": 37,"w": 39,"h": 37} }, { "filename": "0009.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 5, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 41, - "y": 113, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 41,"y": 113,"w": 39,"h": 35} }, { "filename": "0003.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 4, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 187, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 4,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 187,"w": 39,"h": 37} }, { "filename": "0004.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 3, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 74, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 74,"y": 148,"w": 39,"h": 37} }, { "filename": "0024.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 74, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 74,"y": 148,"w": 39,"h": 37} }, { "filename": "0010.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 10, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 80, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 10,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 80,"y": 74,"w": 39,"h": 37} }, { "filename": "0019.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 117,"y": 37,"w": 39,"h": 37} }, { "filename": "0089.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 117,"y": 37,"w": 39,"h": 37} }, { "filename": "0020.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 80, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 80,"y": 111,"w": 39,"h": 37} }, { "filename": "0021.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 224, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 224,"w": 39,"h": 37} }, { "filename": "0066.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 224, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 224,"w": 39,"h": 37} }, { "filename": "0022.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 261, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 261,"w": 39,"h": 37} }, { "filename": "0067.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 261, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 261,"w": 39,"h": 37} }, { "filename": "0023.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 14, - "y": 5, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 5,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 185,"w": 39,"h": 37} }, { "filename": "0030.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 113, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 9,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 113,"y": 148,"w": 39,"h": 37} }, { "filename": "0031.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 119, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 119,"y": 74,"w": 39,"h": 37} }, { "filename": "0038.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 36, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 36,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0068.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0078.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0088.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0039.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 119, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 119,"y": 111,"w": 39,"h": 37} }, { "filename": "0040.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 222, - "w": 39, - "h": 37 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 76, - "y": 296, - "w": 39, - "h": 35 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 3, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 4, - "w": 39, - "h": 37 - }, - "frame": { - "x": 152, - "y": 148, - "w": 39, - "h": 37 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 10, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 158, - "y": 74, - "w": 39, - "h": 37 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 14, - "y": 5, - "w": 39, - "h": 37 - }, - "frame": { - "x": 158, - "y": 111, - "w": 39, - "h": 37 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 222, - "w": 39, - "h": 37 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 115, - "y": 296, - "w": 39, - "h": 35 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 115, - "y": 296, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 222,"w": 39,"h": 37} }, { "filename": "0085.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 36, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 191, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 36,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 222,"w": 39,"h": 37} + }, + { + "filename": "0041.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0042.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0043.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0048.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0049.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0047.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 6,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0051.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0091.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 6,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0050.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 4,"w": 39,"h": 37}, + "frame": {"x": 152,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0057.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 10,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 158,"y": 74,"w": 39,"h": 37} + }, + { + "filename": "0069.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 195,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0070.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 5,"w": 39,"h": 37}, + "frame": {"x": 158,"y": 111,"w": 39,"h": 37} + }, + { + "filename": "0071.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 222,"w": 39,"h": 37} + }, + { + "filename": "0077.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 9,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 259,"w": 39,"h": 37} }, { "filename": "0090.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 197, - "y": 74, - "w": 39, - "h": 37 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 39, - "h": 36 - }, - "frame": { - "x": 234, - "y": 37, - "w": 39, - "h": 36 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 197, - "y": 111, - "w": 39, - "h": 36 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 197, - "y": 111, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 191,"y": 148,"w": 39,"h": 37} }, { "filename": "0014.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 38 - }, - "frame": { - "x": 273, - "y": 37, - "w": 37, - "h": 38 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 197,"y": 74,"w": 37,"h": 38} }, { "filename": "0034.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 38 - }, - "frame": { - "x": 273, - "y": 37, - "w": 37, - "h": 38 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 197,"y": 74,"w": 37,"h": 38} + }, + { + "filename": "0005.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 39,"h": 36}, + "frame": {"x": 197,"y": 112,"w": 39,"h": 36} }, { "filename": "0061.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 38 - }, - "frame": { - "x": 236, - "y": 73, - "w": 37, - "h": 38 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 234,"y": 37,"w": 37,"h": 38} + }, + { + "filename": "0008.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 1,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 234,"y": 75,"w": 39,"h": 36} + }, + { + "filename": "0028.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 234,"y": 75,"w": 39,"h": 36} }, { "filename": "0025.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 7, - "w": 39, - "h": 36 - }, - "frame": { - "x": 273, - "y": 75, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 7,"w": 39,"h": 36}, + "frame": {"x": 271,"y": 37,"w": 39,"h": 36} }, { "filename": "0046.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 19, - "y": 10, - "w": 39, - "h": 36 - }, - "frame": { - "x": 230, - "y": 147, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 19,"y": 10,"w": 39,"h": 36}, + "frame": {"x": 273,"y": 73,"w": 39,"h": 36} }, { "filename": "0052.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 8, - "w": 39, - "h": 36 - }, - "frame": { - "x": 236, - "y": 111, - "w": 39, - "h": 36 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 39, - "h": 36 - }, - "frame": { - "x": 269, - "y": 147, - "w": 39, - "h": 36 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 39, - "h": 36 - }, - "frame": { - "x": 275, - "y": 111, - "w": 39, - "h": 36 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 230, - "y": 183, - "w": 39, - "h": 36 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 230, - "y": 183, - "w": 39, - "h": 36 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 7, - "w": 39, - "h": 36 - }, - "frame": { - "x": 269, - "y": 183, - "w": 39, - "h": 36 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 18, - "y": 10, - "w": 39, - "h": 36 - }, - "frame": { - "x": 154, - "y": 185, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 1,"y": 8,"w": 39,"h": 36}, + "frame": {"x": 273,"y": 109,"w": 39,"h": 36} }, { "filename": "0015.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 193, - "y": 185, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 236,"y": 111,"w": 36,"h": 39} }, { "filename": "0035.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 193, - "y": 185, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 236,"y": 111,"w": 36,"h": 39} + }, + { + "filename": "0053.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 39,"h": 36}, + "frame": {"x": 272,"y": 145,"w": 39,"h": 36} + }, + { + "filename": "0054.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 39,"h": 36}, + "frame": {"x": 230,"y": 150,"w": 39,"h": 36} + }, + { + "filename": "0055.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 269,"y": 181,"w": 39,"h": 36} + }, + { + "filename": "0075.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 269,"y": 181,"w": 39,"h": 36} + }, + { + "filename": "0072.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 7,"w": 39,"h": 36}, + "frame": {"x": 154,"y": 185,"w": 39,"h": 36} }, { "filename": "0016.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 154, - "y": 221, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 185,"w": 36,"h": 39} }, { "filename": "0036.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 154, - "y": 221, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 185,"w": 36,"h": 39} + }, + { + "filename": "0092.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 18,"y": 10,"w": 39,"h": 36}, + "frame": {"x": 154,"y": 221,"w": 39,"h": 36} }, { "filename": "0062.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 229, - "y": 219, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 229,"y": 186,"w": 36,"h": 39} }, { "filename": "0082.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 2, - "w": 36, - "h": 39 - }, - "frame": { - "x": 229, - "y": 219, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 2,"w": 36,"h": 39}, + "frame": {"x": 229,"y": 186,"w": 36,"h": 39} }, { "filename": "0063.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 190, - "y": 224, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 224,"w": 36,"h": 39} }, { "filename": "0083.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 2, - "w": 36, - "h": 39 - }, - "frame": { - "x": 190, - "y": 224, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 2,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 224,"w": 36,"h": 39} }, { "filename": "0006.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 38, - "h": 36 - }, - "frame": { - "x": 265, - "y": 219, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 38,"h": 36}, + "frame": {"x": 154,"y": 257,"w": 38,"h": 36} + }, + { + "filename": "0029.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 154,"y": 293,"w": 39,"h": 35} }, { "filename": "0007.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 38, - "h": 36 - }, - "frame": { - "x": 265, - "y": 255, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 38,"h": 36}, + "frame": {"x": 265,"y": 217,"w": 38,"h": 36} }, { "filename": "0026.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 265, - "y": 255, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 265,"y": 217,"w": 38,"h": 36} }, { "filename": "0027.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 226, - "y": 258, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 229,"y": 253,"w": 38,"h": 36} }, { "filename": "0073.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 264, - "y": 291, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 267,"y": 253,"w": 38,"h": 36} }, { "filename": "0074.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 154, - "y": 294, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 193,"y": 289,"w": 38,"h": 36} + }, + { + "filename": "0056.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 231,"y": 289,"w": 39,"h": 35} + }, + { + "filename": "0076.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 231,"y": 289,"w": 39,"h": 35} } ] } ], "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:994e0686e371722e752d0d8f780e8ed8:30386beb7cd4508b46ce30c2652e2ef7:cda0147f4d676691e1699693bc0ee567$" - } + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0"} } diff --git a/public/images/pokemon/exp/back/shiny/774-red.png b/public/images/pokemon/exp/back/shiny/774-red.png index bc3407019f8..14f362e1266 100644 Binary files a/public/images/pokemon/exp/back/shiny/774-red.png and b/public/images/pokemon/exp/back/shiny/774-red.png differ diff --git a/public/images/pokemon/exp/back/shiny/774-violet.json b/public/images/pokemon/exp/back/shiny/774-violet.json index ef77ba1763e..f8f45e31468 100644 --- a/public/images/pokemon/exp/back/shiny/774-violet.json +++ b/public/images/pokemon/exp/back/shiny/774-violet.json @@ -3,1992 +3,765 @@ { "image": "774-violet.png", "format": "RGBA8888", - "size": { - "w": 331, - "h": 331 - }, + "size": {"w": 328,"h": 328}, "scale": 1, "frames": [ { "filename": "0011.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 11, - "y": 10, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 11,"y": 10,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 0,"w": 41,"h": 37} }, { "filename": "0012.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 0,"w": 41,"h": 37} }, { "filename": "0013.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 41, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 41,"y": 0,"w": 41,"h": 37} }, { "filename": "0018.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 35, - "y": 8, - "w": 41, - "h": 37 - }, - "frame": { - "x": 82, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 35,"y": 8,"w": 41,"h": 37}, + "frame": {"x": 82,"y": 0,"w": 41,"h": 37} }, { "filename": "0032.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 123, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 123,"y": 0,"w": 41,"h": 37} }, { "filename": "0033.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 164, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 164,"y": 0,"w": 41,"h": 37} }, { "filename": "0044.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 16, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 205, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 16,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 205,"y": 0,"w": 41,"h": 37} }, { "filename": "0058.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 11, - "y": 10, - "w": 41, - "h": 37 - }, - "frame": { - "x": 246, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 11,"y": 10,"w": 41,"h": 37}, + "frame": {"x": 246,"y": 0,"w": 41,"h": 37} }, { "filename": "0059.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 287, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 287,"y": 0,"w": 41,"h": 37} }, { "filename": "0079.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 287, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 287,"y": 0,"w": 41,"h": 37} }, { "filename": "0060.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 37, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 37,"w": 41,"h": 37} }, { "filename": "0080.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 37, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 37,"w": 41,"h": 37} }, { "filename": "0065.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 35, - "y": 8, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 74, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 35,"y": 8,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 74,"w": 41,"h": 37} }, { "filename": "0094.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 14, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 111, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 111,"w": 41,"h": 37} }, { "filename": "0017.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 6, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 148, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 148,"w": 37,"h": 39} }, { "filename": "0037.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 6, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 187, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 187,"w": 37,"h": 39} }, { "filename": "0045.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 9, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 226, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 9,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 226,"w": 37,"h": 39} }, { "filename": "0064.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 6, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 265, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 265,"w": 37,"h": 39} }, { "filename": "0084.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 7, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 265, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 7,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 265,"w": 37,"h": 39} }, { "filename": "0081.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 39 - }, - "frame": { - "x": 37, - "y": 148, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 39}, + "frame": {"x": 37,"y": 148,"w": 37,"h": 39} }, { "filename": "0093.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 16, - "y": 9, - "w": 37, - "h": 39 - }, - "frame": { - "x": 41, - "y": 37, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 16,"y": 9,"w": 37,"h": 39}, + "frame": {"x": 41,"y": 37,"w": 37,"h": 39} }, { "filename": "0001.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 41, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 41,"y": 76,"w": 39,"h": 37} }, { "filename": "0086.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 41, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 41,"y": 76,"w": 39,"h": 37} }, { "filename": "0002.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 78,"y": 37,"w": 39,"h": 37} }, { "filename": "0087.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 78,"y": 37,"w": 39,"h": 37} }, { "filename": "0009.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 5, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 41, - "y": 113, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 41,"y": 113,"w": 39,"h": 35} }, { "filename": "0003.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 4, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 187, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 4,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 187,"w": 39,"h": 37} }, { "filename": "0004.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 3, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 74, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 74,"y": 148,"w": 39,"h": 37} }, { "filename": "0024.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 74, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 74,"y": 148,"w": 39,"h": 37} }, { "filename": "0010.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 10, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 80, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 10,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 80,"y": 74,"w": 39,"h": 37} }, { "filename": "0019.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 117,"y": 37,"w": 39,"h": 37} }, { "filename": "0089.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 117,"y": 37,"w": 39,"h": 37} }, { "filename": "0020.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 80, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 80,"y": 111,"w": 39,"h": 37} }, { "filename": "0021.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 224, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 224,"w": 39,"h": 37} }, { "filename": "0066.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 224, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 224,"w": 39,"h": 37} }, { "filename": "0022.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 261, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 261,"w": 39,"h": 37} }, { "filename": "0067.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 261, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 261,"w": 39,"h": 37} }, { "filename": "0023.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 14, - "y": 5, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 5,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 185,"w": 39,"h": 37} }, { "filename": "0030.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 113, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 9,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 113,"y": 148,"w": 39,"h": 37} }, { "filename": "0031.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 119, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 119,"y": 74,"w": 39,"h": 37} }, { "filename": "0038.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 36, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 36,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0068.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0078.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0088.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0039.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 119, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 119,"y": 111,"w": 39,"h": 37} }, { "filename": "0040.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 222, - "w": 39, - "h": 37 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 76, - "y": 296, - "w": 39, - "h": 35 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 3, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 4, - "w": 39, - "h": 37 - }, - "frame": { - "x": 152, - "y": 148, - "w": 39, - "h": 37 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 10, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 158, - "y": 74, - "w": 39, - "h": 37 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 14, - "y": 5, - "w": 39, - "h": 37 - }, - "frame": { - "x": 158, - "y": 111, - "w": 39, - "h": 37 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 222, - "w": 39, - "h": 37 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 115, - "y": 296, - "w": 39, - "h": 35 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 115, - "y": 296, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 222,"w": 39,"h": 37} }, { "filename": "0085.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 36, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 191, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 36,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 222,"w": 39,"h": 37} + }, + { + "filename": "0041.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0042.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0043.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0048.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0049.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0047.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 6,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0051.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0091.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 6,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0050.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 4,"w": 39,"h": 37}, + "frame": {"x": 152,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0057.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 10,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 158,"y": 74,"w": 39,"h": 37} + }, + { + "filename": "0069.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 195,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0070.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 5,"w": 39,"h": 37}, + "frame": {"x": 158,"y": 111,"w": 39,"h": 37} + }, + { + "filename": "0071.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 222,"w": 39,"h": 37} + }, + { + "filename": "0077.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 9,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 259,"w": 39,"h": 37} }, { "filename": "0090.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 197, - "y": 74, - "w": 39, - "h": 37 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 39, - "h": 36 - }, - "frame": { - "x": 234, - "y": 37, - "w": 39, - "h": 36 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 197, - "y": 111, - "w": 39, - "h": 36 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 197, - "y": 111, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 191,"y": 148,"w": 39,"h": 37} }, { "filename": "0014.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 38 - }, - "frame": { - "x": 273, - "y": 37, - "w": 37, - "h": 38 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 197,"y": 74,"w": 37,"h": 38} }, { "filename": "0034.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 38 - }, - "frame": { - "x": 273, - "y": 37, - "w": 37, - "h": 38 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 197,"y": 74,"w": 37,"h": 38} + }, + { + "filename": "0005.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 39,"h": 36}, + "frame": {"x": 197,"y": 112,"w": 39,"h": 36} }, { "filename": "0061.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 38 - }, - "frame": { - "x": 236, - "y": 73, - "w": 37, - "h": 38 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 234,"y": 37,"w": 37,"h": 38} + }, + { + "filename": "0008.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 1,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 234,"y": 75,"w": 39,"h": 36} + }, + { + "filename": "0028.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 234,"y": 75,"w": 39,"h": 36} }, { "filename": "0025.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 7, - "w": 39, - "h": 36 - }, - "frame": { - "x": 273, - "y": 75, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 7,"w": 39,"h": 36}, + "frame": {"x": 271,"y": 37,"w": 39,"h": 36} }, { "filename": "0046.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 19, - "y": 10, - "w": 39, - "h": 36 - }, - "frame": { - "x": 230, - "y": 147, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 19,"y": 10,"w": 39,"h": 36}, + "frame": {"x": 273,"y": 73,"w": 39,"h": 36} }, { "filename": "0052.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 8, - "w": 39, - "h": 36 - }, - "frame": { - "x": 236, - "y": 111, - "w": 39, - "h": 36 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 39, - "h": 36 - }, - "frame": { - "x": 269, - "y": 147, - "w": 39, - "h": 36 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 39, - "h": 36 - }, - "frame": { - "x": 275, - "y": 111, - "w": 39, - "h": 36 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 230, - "y": 183, - "w": 39, - "h": 36 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 230, - "y": 183, - "w": 39, - "h": 36 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 7, - "w": 39, - "h": 36 - }, - "frame": { - "x": 269, - "y": 183, - "w": 39, - "h": 36 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 18, - "y": 10, - "w": 39, - "h": 36 - }, - "frame": { - "x": 154, - "y": 185, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 1,"y": 8,"w": 39,"h": 36}, + "frame": {"x": 273,"y": 109,"w": 39,"h": 36} }, { "filename": "0015.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 193, - "y": 185, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 236,"y": 111,"w": 36,"h": 39} }, { "filename": "0035.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 193, - "y": 185, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 236,"y": 111,"w": 36,"h": 39} + }, + { + "filename": "0053.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 39,"h": 36}, + "frame": {"x": 272,"y": 145,"w": 39,"h": 36} + }, + { + "filename": "0054.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 39,"h": 36}, + "frame": {"x": 230,"y": 150,"w": 39,"h": 36} + }, + { + "filename": "0055.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 269,"y": 181,"w": 39,"h": 36} + }, + { + "filename": "0075.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 269,"y": 181,"w": 39,"h": 36} + }, + { + "filename": "0072.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 7,"w": 39,"h": 36}, + "frame": {"x": 154,"y": 185,"w": 39,"h": 36} }, { "filename": "0016.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 154, - "y": 221, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 185,"w": 36,"h": 39} }, { "filename": "0036.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 154, - "y": 221, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 185,"w": 36,"h": 39} + }, + { + "filename": "0092.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 18,"y": 10,"w": 39,"h": 36}, + "frame": {"x": 154,"y": 221,"w": 39,"h": 36} }, { "filename": "0062.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 229, - "y": 219, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 229,"y": 186,"w": 36,"h": 39} }, { "filename": "0082.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 2, - "w": 36, - "h": 39 - }, - "frame": { - "x": 229, - "y": 219, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 2,"w": 36,"h": 39}, + "frame": {"x": 229,"y": 186,"w": 36,"h": 39} }, { "filename": "0063.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 190, - "y": 224, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 224,"w": 36,"h": 39} }, { "filename": "0083.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 2, - "w": 36, - "h": 39 - }, - "frame": { - "x": 190, - "y": 224, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 2,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 224,"w": 36,"h": 39} }, { "filename": "0006.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 38, - "h": 36 - }, - "frame": { - "x": 265, - "y": 219, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 38,"h": 36}, + "frame": {"x": 154,"y": 257,"w": 38,"h": 36} + }, + { + "filename": "0029.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 154,"y": 293,"w": 39,"h": 35} }, { "filename": "0007.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 38, - "h": 36 - }, - "frame": { - "x": 265, - "y": 255, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 38,"h": 36}, + "frame": {"x": 265,"y": 217,"w": 38,"h": 36} }, { "filename": "0026.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 265, - "y": 255, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 265,"y": 217,"w": 38,"h": 36} }, { "filename": "0027.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 226, - "y": 258, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 229,"y": 253,"w": 38,"h": 36} }, { "filename": "0073.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 264, - "y": 291, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 267,"y": 253,"w": 38,"h": 36} }, { "filename": "0074.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 154, - "y": 294, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 193,"y": 289,"w": 38,"h": 36} + }, + { + "filename": "0056.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 231,"y": 289,"w": 39,"h": 35} + }, + { + "filename": "0076.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 231,"y": 289,"w": 39,"h": 35} } ] } ], "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:1162c9d5a4c772fc36a9efb070235eeb:7284e512a285e0bd298174144d17104f:cafe7bbce21f2b95187ef35011084eca$" - } + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0"} } diff --git a/public/images/pokemon/exp/back/shiny/774-violet.png b/public/images/pokemon/exp/back/shiny/774-violet.png index 68da27cc960..b2beec5b705 100644 Binary files a/public/images/pokemon/exp/back/shiny/774-violet.png and b/public/images/pokemon/exp/back/shiny/774-violet.png differ diff --git a/public/images/pokemon/exp/back/shiny/774-yellow.json b/public/images/pokemon/exp/back/shiny/774-yellow.json index 1011626e981..56b702ab22f 100644 --- a/public/images/pokemon/exp/back/shiny/774-yellow.json +++ b/public/images/pokemon/exp/back/shiny/774-yellow.json @@ -3,1992 +3,765 @@ { "image": "774-yellow.png", "format": "RGBA8888", - "size": { - "w": 331, - "h": 331 - }, + "size": {"w": 328,"h": 328}, "scale": 1, "frames": [ { "filename": "0011.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 11, - "y": 10, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 11,"y": 10,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 0,"w": 41,"h": 37} }, { "filename": "0012.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 0,"w": 41,"h": 37} }, { "filename": "0013.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 41, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 41,"y": 0,"w": 41,"h": 37} }, { "filename": "0018.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 35, - "y": 8, - "w": 41, - "h": 37 - }, - "frame": { - "x": 82, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 35,"y": 8,"w": 41,"h": 37}, + "frame": {"x": 82,"y": 0,"w": 41,"h": 37} }, { "filename": "0032.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 123, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 123,"y": 0,"w": 41,"h": 37} }, { "filename": "0033.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 164, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 164,"y": 0,"w": 41,"h": 37} }, { "filename": "0044.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 16, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 205, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 16,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 205,"y": 0,"w": 41,"h": 37} }, { "filename": "0058.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 11, - "y": 10, - "w": 41, - "h": 37 - }, - "frame": { - "x": 246, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 11,"y": 10,"w": 41,"h": 37}, + "frame": {"x": 246,"y": 0,"w": 41,"h": 37} }, { "filename": "0059.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 287, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 287,"y": 0,"w": 41,"h": 37} }, { "filename": "0079.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 287, - "y": 0, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 287,"y": 0,"w": 41,"h": 37} }, { "filename": "0060.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 37, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 37,"w": 41,"h": 37} }, { "filename": "0080.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 0, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 37, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 28,"y": 0,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 37,"w": 41,"h": 37} }, { "filename": "0065.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 35, - "y": 8, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 74, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 35,"y": 8,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 74,"w": 41,"h": 37} }, { "filename": "0094.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 14, - "y": 7, - "w": 41, - "h": 37 - }, - "frame": { - "x": 0, - "y": 111, - "w": 41, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 7,"w": 41,"h": 37}, + "frame": {"x": 0,"y": 111,"w": 41,"h": 37} }, { "filename": "0017.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 6, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 148, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 148,"w": 37,"h": 39} }, { "filename": "0037.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 6, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 187, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 187,"w": 37,"h": 39} }, { "filename": "0045.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 9, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 226, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 9,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 226,"w": 37,"h": 39} }, { "filename": "0064.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 6, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 265, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 6,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 265,"w": 37,"h": 39} }, { "filename": "0084.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 7, - "w": 37, - "h": 39 - }, - "frame": { - "x": 0, - "y": 265, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 7,"w": 37,"h": 39}, + "frame": {"x": 0,"y": 265,"w": 37,"h": 39} }, { "filename": "0081.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 39 - }, - "frame": { - "x": 37, - "y": 148, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 39}, + "frame": {"x": 37,"y": 148,"w": 37,"h": 39} }, { "filename": "0093.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 16, - "y": 9, - "w": 37, - "h": 39 - }, - "frame": { - "x": 41, - "y": 37, - "w": 37, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 16,"y": 9,"w": 37,"h": 39}, + "frame": {"x": 41,"y": 37,"w": 37,"h": 39} }, { "filename": "0001.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 41, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 41,"y": 76,"w": 39,"h": 37} }, { "filename": "0086.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 41, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 41,"y": 76,"w": 39,"h": 37} }, { "filename": "0002.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 78,"y": 37,"w": 39,"h": 37} }, { "filename": "0087.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 78,"y": 37,"w": 39,"h": 37} }, { "filename": "0009.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 5, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 41, - "y": 113, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 41,"y": 113,"w": 39,"h": 35} }, { "filename": "0003.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 4, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 187, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 4,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 187,"w": 39,"h": 37} }, { "filename": "0004.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 3, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 74, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 74,"y": 148,"w": 39,"h": 37} }, { "filename": "0024.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 74, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 74,"y": 148,"w": 39,"h": 37} }, { "filename": "0010.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 10, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 80, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 10,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 80,"y": 74,"w": 39,"h": 37} }, { "filename": "0019.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 117,"y": 37,"w": 39,"h": 37} }, { "filename": "0089.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 117,"y": 37,"w": 39,"h": 37} }, { "filename": "0020.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 80, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 80,"y": 111,"w": 39,"h": 37} }, { "filename": "0021.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 224, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 224,"w": 39,"h": 37} }, { "filename": "0066.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 224, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 224,"w": 39,"h": 37} }, { "filename": "0022.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 261, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 261,"w": 39,"h": 37} }, { "filename": "0067.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 37, - "y": 261, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 37,"y": 261,"w": 39,"h": 37} }, { "filename": "0023.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 14, - "y": 5, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 5,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 185,"w": 39,"h": 37} }, { "filename": "0030.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 113, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 9,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 113,"y": 148,"w": 39,"h": 37} }, { "filename": "0031.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 119, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 119,"y": 74,"w": 39,"h": 37} }, { "filename": "0038.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 36, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 36,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0068.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0078.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0088.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 156,"y": 37,"w": 39,"h": 37} }, { "filename": "0039.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 119, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 119,"y": 111,"w": 39,"h": 37} }, { "filename": "0040.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 21, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 222, - "w": 39, - "h": 37 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 76, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 76, - "y": 296, - "w": 39, - "h": 35 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 3, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 185, - "w": 39, - "h": 37 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 4, - "w": 39, - "h": 37 - }, - "frame": { - "x": 152, - "y": 148, - "w": 39, - "h": 37 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 10, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 158, - "y": 74, - "w": 39, - "h": 37 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 37, - "w": 39, - "h": 37 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 14, - "y": 5, - "w": 39, - "h": 37 - }, - "frame": { - "x": 158, - "y": 111, - "w": 39, - "h": 37 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 5, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 222, - "w": 39, - "h": 37 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 115, - "y": 259, - "w": 39, - "h": 37 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 115, - "y": 296, - "w": 39, - "h": 35 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 15, - "w": 39, - "h": 35 - }, - "frame": { - "x": 115, - "y": 296, - "w": 39, - "h": 35 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 21,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 222,"w": 39,"h": 37} }, { "filename": "0085.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 36, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 191, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 36,"y": 8,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 222,"w": 39,"h": 37} + }, + { + "filename": "0041.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0042.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0043.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0048.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0049.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 76,"y": 259,"w": 39,"h": 37} + }, + { + "filename": "0047.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 6,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0051.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0091.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 6,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0050.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 13,"y": 4,"w": 39,"h": 37}, + "frame": {"x": 152,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0057.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 10,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 158,"y": 74,"w": 39,"h": 37} + }, + { + "filename": "0069.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 195,"y": 37,"w": 39,"h": 37} + }, + { + "filename": "0070.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 14,"y": 5,"w": 39,"h": 37}, + "frame": {"x": 158,"y": 111,"w": 39,"h": 37} + }, + { + "filename": "0071.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 5,"y": 2,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 222,"w": 39,"h": 37} + }, + { + "filename": "0077.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 9,"y": 10,"w": 39,"h": 37}, + "frame": {"x": 115,"y": 259,"w": 39,"h": 37} }, { "filename": "0090.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 17, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 197, - "y": 74, - "w": 39, - "h": 37 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 39, - "h": 36 - }, - "frame": { - "x": 234, - "y": 37, - "w": 39, - "h": 36 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 197, - "y": 111, - "w": 39, - "h": 36 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 197, - "y": 111, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 17,"y": 7,"w": 39,"h": 37}, + "frame": {"x": 191,"y": 148,"w": 39,"h": 37} }, { "filename": "0014.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 38 - }, - "frame": { - "x": 273, - "y": 37, - "w": 37, - "h": 38 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 197,"y": 74,"w": 37,"h": 38} }, { "filename": "0034.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 38 - }, - "frame": { - "x": 273, - "y": 37, - "w": 37, - "h": 38 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 197,"y": 74,"w": 37,"h": 38} + }, + { + "filename": "0005.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 39,"h": 36}, + "frame": {"x": 197,"y": 112,"w": 39,"h": 36} }, { "filename": "0061.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 0, - "w": 37, - "h": 38 - }, - "frame": { - "x": 236, - "y": 73, - "w": 37, - "h": 38 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 42,"y": 0,"w": 37,"h": 38}, + "frame": {"x": 234,"y": 37,"w": 37,"h": 38} + }, + { + "filename": "0008.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 1,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 234,"y": 75,"w": 39,"h": 36} + }, + { + "filename": "0028.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 234,"y": 75,"w": 39,"h": 36} }, { "filename": "0025.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 7, - "w": 39, - "h": 36 - }, - "frame": { - "x": 273, - "y": 75, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 7,"w": 39,"h": 36}, + "frame": {"x": 271,"y": 37,"w": 39,"h": 36} }, { "filename": "0046.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 19, - "y": 10, - "w": 39, - "h": 36 - }, - "frame": { - "x": 230, - "y": 147, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 19,"y": 10,"w": 39,"h": 36}, + "frame": {"x": 273,"y": 73,"w": 39,"h": 36} }, { "filename": "0052.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 8, - "w": 39, - "h": 36 - }, - "frame": { - "x": 236, - "y": 111, - "w": 39, - "h": 36 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 39, - "h": 36 - }, - "frame": { - "x": 269, - "y": 147, - "w": 39, - "h": 36 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 39, - "h": 36 - }, - "frame": { - "x": 275, - "y": 111, - "w": 39, - "h": 36 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 230, - "y": 183, - "w": 39, - "h": 36 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 36 - }, - "frame": { - "x": 230, - "y": 183, - "w": 39, - "h": 36 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 7, - "w": 39, - "h": 36 - }, - "frame": { - "x": 269, - "y": 183, - "w": 39, - "h": 36 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 18, - "y": 10, - "w": 39, - "h": 36 - }, - "frame": { - "x": 154, - "y": 185, - "w": 39, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 1,"y": 8,"w": 39,"h": 36}, + "frame": {"x": 273,"y": 109,"w": 39,"h": 36} }, { "filename": "0015.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 193, - "y": 185, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 236,"y": 111,"w": 36,"h": 39} }, { "filename": "0035.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 193, - "y": 185, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 236,"y": 111,"w": 36,"h": 39} + }, + { + "filename": "0053.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 39,"h": 36}, + "frame": {"x": 272,"y": 145,"w": 39,"h": 36} + }, + { + "filename": "0054.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 39,"h": 36}, + "frame": {"x": 230,"y": 150,"w": 39,"h": 36} + }, + { + "filename": "0055.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 269,"y": 181,"w": 39,"h": 36} + }, + { + "filename": "0075.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 2,"y": 11,"w": 39,"h": 36}, + "frame": {"x": 269,"y": 181,"w": 39,"h": 36} + }, + { + "filename": "0072.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 7,"w": 39,"h": 36}, + "frame": {"x": 154,"y": 185,"w": 39,"h": 36} }, { "filename": "0016.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 154, - "y": 221, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 185,"w": 36,"h": 39} }, { "filename": "0036.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 154, - "y": 221, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 185,"w": 36,"h": 39} + }, + { + "filename": "0092.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 18,"y": 10,"w": 39,"h": 36}, + "frame": {"x": 154,"y": 221,"w": 39,"h": 36} }, { "filename": "0062.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 229, - "y": 219, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 229,"y": 186,"w": 36,"h": 39} }, { "filename": "0082.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 2, - "w": 36, - "h": 39 - }, - "frame": { - "x": 229, - "y": 219, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 2,"w": 36,"h": 39}, + "frame": {"x": 229,"y": 186,"w": 36,"h": 39} }, { "filename": "0063.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 1, - "w": 36, - "h": 39 - }, - "frame": { - "x": 190, - "y": 224, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 1,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 224,"w": 36,"h": 39} }, { "filename": "0083.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 44, - "y": 2, - "w": 36, - "h": 39 - }, - "frame": { - "x": 190, - "y": 224, - "w": 36, - "h": 39 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 44,"y": 2,"w": 36,"h": 39}, + "frame": {"x": 193,"y": 224,"w": 36,"h": 39} }, { "filename": "0006.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 38, - "h": 36 - }, - "frame": { - "x": 265, - "y": 219, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 38,"h": 36}, + "frame": {"x": 154,"y": 257,"w": 38,"h": 36} + }, + { + "filename": "0029.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 154,"y": 293,"w": 39,"h": 35} }, { "filename": "0007.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 9, - "w": 38, - "h": 36 - }, - "frame": { - "x": 265, - "y": 255, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 9,"w": 38,"h": 36}, + "frame": {"x": 265,"y": 217,"w": 38,"h": 36} }, { "filename": "0026.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 265, - "y": 255, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 265,"y": 217,"w": 38,"h": 36} }, { "filename": "0027.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 226, - "y": 258, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 229,"y": 253,"w": 38,"h": 36} }, { "filename": "0073.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 264, - "y": 291, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 267,"y": 253,"w": 38,"h": 36} }, { "filename": "0074.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 80, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 8, - "w": 38, - "h": 36 - }, - "frame": { - "x": 154, - "y": 294, - "w": 38, - "h": 36 - } + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 0,"y": 8,"w": 38,"h": 36}, + "frame": {"x": 193,"y": 289,"w": 38,"h": 36} + }, + { + "filename": "0056.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 231,"y": 289,"w": 39,"h": 35} + }, + { + "filename": "0076.png", + "rotated": false, + "trimmed": true, + "sourceSize": {"w": 80,"h": 50}, + "spriteSourceSize": {"x": 6,"y": 15,"w": 39,"h": 35}, + "frame": {"x": 231,"y": 289,"w": 39,"h": 35} } ] } ], "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:808f33fa67ae57d7a9fb290b7966c9e6:7e1e62ca4e702f4f9b8bb6d6c2ab43b8:a0f9f47b818f7e67dd381af2f205c265$" - } + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0"} } diff --git a/public/images/pokemon/exp/back/shiny/774-yellow.png b/public/images/pokemon/exp/back/shiny/774-yellow.png index 569b836a207..89fa0ae789c 100644 Binary files a/public/images/pokemon/exp/back/shiny/774-yellow.png and b/public/images/pokemon/exp/back/shiny/774-yellow.png differ diff --git a/public/images/pokemon/exp/back/shiny/944.png b/public/images/pokemon/exp/back/shiny/944.png index a0d96282076..060e8a99545 100644 Binary files a/public/images/pokemon/exp/back/shiny/944.png and b/public/images/pokemon/exp/back/shiny/944.png differ diff --git a/public/images/pokemon/exp/back/shiny/945.png b/public/images/pokemon/exp/back/shiny/945.png index dabe70fdb31..71644f57479 100644 Binary files a/public/images/pokemon/exp/back/shiny/945.png and b/public/images/pokemon/exp/back/shiny/945.png differ diff --git a/public/images/pokemon/exp/shiny/4144.png b/public/images/pokemon/exp/shiny/4144.png index 3ef084000f3..09a4c5802f3 100644 Binary files a/public/images/pokemon/exp/shiny/4144.png and b/public/images/pokemon/exp/shiny/4144.png differ diff --git a/public/images/pokemon/exp/shiny/4145.png b/public/images/pokemon/exp/shiny/4145.png index bcc4c6f91c2..78aa2abb4ad 100644 Binary files a/public/images/pokemon/exp/shiny/4145.png and b/public/images/pokemon/exp/shiny/4145.png differ diff --git a/public/images/pokemon/exp/shiny/4146.png b/public/images/pokemon/exp/shiny/4146.png index ba4e62192de..758dd3877ec 100644 Binary files a/public/images/pokemon/exp/shiny/4146.png and b/public/images/pokemon/exp/shiny/4146.png differ diff --git a/public/images/pokemon/exp/shiny/658-ash.json b/public/images/pokemon/exp/shiny/658-ash.json index 5101079ce90..52dbac8366a 100644 --- a/public/images/pokemon/exp/shiny/658-ash.json +++ b/public/images/pokemon/exp/shiny/658-ash.json @@ -1,671 +1,299 @@ -{ - "textures": [ - { - "image": "658-ash.png", - "format": "RGBA8888", - "size": { - "w": 150, - "h": 150 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 75, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 75, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 75, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 75, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 75, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 75, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 75, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 75, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 75, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 75, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 75, - "y": 0, - "w": 75, - "h": 66 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 0, - "y": 66, - "w": 75, - "h": 66 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 0, - "y": 66, - "w": 75, - "h": 66 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 0, - "y": 66, - "w": 75, - "h": 66 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 66 - }, - "frame": { - "x": 0, - "y": 66, - "w": 75, - "h": 66 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 75, - "h": 65 - }, - "frame": { - "x": 75, - "y": 66, - "w": 75, - "h": 65 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 75, - "h": 65 - }, - "frame": { - "x": 75, - "y": 66, - "w": 75, - "h": 65 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 75, - "h": 65 - }, - "frame": { - "x": 75, - "y": 66, - "w": 75, - "h": 65 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 75, - "h": 65 - }, - "frame": { - "x": 75, - "y": 66, - "w": 75, - "h": 65 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 75, - "h": 65 - }, - "frame": { - "x": 75, - "y": 66, - "w": 75, - "h": 65 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 75, - "h": 65 - }, - "frame": { - "x": 75, - "y": 66, - "w": 75, - "h": 65 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 75, - "h": 65 - }, - "frame": { - "x": 75, - "y": 66, - "w": 75, - "h": 65 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 75, - "h": 66 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 75, - "h": 65 - }, - "frame": { - "x": 75, - "y": 66, - "w": 75, - "h": 65 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:0875c2204eeabc96bd1f034bcc69210b:e1abe8d09d1fe3c1ec758293b0a4bed5:f09eeed5adc5ec50aec50218e03662c2$" - } +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0002.png", + "frame": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0003.png", + "frame": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0004.png", + "frame": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0005.png", + "frame": { "x": 79, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0006.png", + "frame": { "x": 79, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0007.png", + "frame": { "x": 79, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0008.png", + "frame": { "x": 79, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0009.png", + "frame": { "x": 158, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0010.png", + "frame": { "x": 158, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0011.png", + "frame": { "x": 158, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0012.png", + "frame": { "x": 158, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0013.png", + "frame": { "x": 0, "y": 74, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0014.png", + "frame": { "x": 0, "y": 74, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0015.png", + "frame": { "x": 0, "y": 74, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0016.png", + "frame": { "x": 0, "y": 74, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0017.png", + "frame": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0018.png", + "frame": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0019.png", + "frame": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0020.png", + "frame": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0021.png", + "frame": { "x": 79, "y": 74, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0022.png", + "frame": { "x": 79, "y": 74, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0023.png", + "frame": { "x": 79, "y": 74, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0024.png", + "frame": { "x": 79, "y": 74, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0025.png", + "frame": { "x": 158, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0026.png", + "frame": { "x": 158, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0027.png", + "frame": { "x": 158, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0028.png", + "frame": { "x": 158, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0029.png", + "frame": { "x": 0, "y": 74, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0030.png", + "frame": { "x": 0, "y": 74, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0031.png", + "frame": { "x": 0, "y": 74, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + }, + { + "filename": "0032.png", + "frame": { "x": 0, "y": 74, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.7-x64", + "image": "658-ash.png", + "format": "I8", + "size": { "w": 237, "h": 148 }, + "scale": "1" + } } diff --git a/public/images/pokemon/exp/shiny/658-ash.png b/public/images/pokemon/exp/shiny/658-ash.png index 5d80ca1ad0e..5b25ec9e021 100644 Binary files a/public/images/pokemon/exp/shiny/658-ash.png and b/public/images/pokemon/exp/shiny/658-ash.png differ diff --git a/public/images/pokemon/exp/shiny/658.png b/public/images/pokemon/exp/shiny/658.png index 999bc74c659..e7278458f2c 100644 Binary files a/public/images/pokemon/exp/shiny/658.png and b/public/images/pokemon/exp/shiny/658.png differ diff --git a/public/images/pokemon/exp/shiny/662.png b/public/images/pokemon/exp/shiny/662.png index ec0100f3e96..e45e79556c5 100644 Binary files a/public/images/pokemon/exp/shiny/662.png and b/public/images/pokemon/exp/shiny/662.png differ diff --git a/public/images/pokemon/exp/shiny/684.png b/public/images/pokemon/exp/shiny/684.png index 96fbea5e395..ed7b392cd6d 100644 Binary files a/public/images/pokemon/exp/shiny/684.png and b/public/images/pokemon/exp/shiny/684.png differ diff --git a/public/images/pokemon/exp/shiny/696.png b/public/images/pokemon/exp/shiny/696.png index 43f898256f2..0a11f7b7ec7 100644 Binary files a/public/images/pokemon/exp/shiny/696.png and b/public/images/pokemon/exp/shiny/696.png differ diff --git a/public/images/pokemon/exp/shiny/773-bug.png b/public/images/pokemon/exp/shiny/773-bug.png index 6019608a76a..eed158c66dd 100644 Binary files a/public/images/pokemon/exp/shiny/773-bug.png and b/public/images/pokemon/exp/shiny/773-bug.png differ diff --git a/public/images/pokemon/exp/shiny/773-dark.png b/public/images/pokemon/exp/shiny/773-dark.png index c904bacf35a..a83de242ef3 100644 Binary files a/public/images/pokemon/exp/shiny/773-dark.png and b/public/images/pokemon/exp/shiny/773-dark.png differ diff --git a/public/images/pokemon/exp/shiny/773-dragon.png b/public/images/pokemon/exp/shiny/773-dragon.png index 8438e49c23d..4fc9b8fd50f 100644 Binary files a/public/images/pokemon/exp/shiny/773-dragon.png and b/public/images/pokemon/exp/shiny/773-dragon.png differ diff --git a/public/images/pokemon/exp/shiny/773-electric.png b/public/images/pokemon/exp/shiny/773-electric.png index 4a36fc54944..6be46f8f66b 100644 Binary files a/public/images/pokemon/exp/shiny/773-electric.png and b/public/images/pokemon/exp/shiny/773-electric.png differ diff --git a/public/images/pokemon/exp/shiny/773-fairy.png b/public/images/pokemon/exp/shiny/773-fairy.png index 9f814b72fa8..16a0af45fcd 100644 Binary files a/public/images/pokemon/exp/shiny/773-fairy.png and b/public/images/pokemon/exp/shiny/773-fairy.png differ diff --git a/public/images/pokemon/exp/shiny/773-fighting.png b/public/images/pokemon/exp/shiny/773-fighting.png index 8d2724759d1..ad2c784db03 100644 Binary files a/public/images/pokemon/exp/shiny/773-fighting.png and b/public/images/pokemon/exp/shiny/773-fighting.png differ diff --git a/public/images/pokemon/exp/shiny/773-fire.png b/public/images/pokemon/exp/shiny/773-fire.png index 89928a13c10..144b6140412 100644 Binary files a/public/images/pokemon/exp/shiny/773-fire.png and b/public/images/pokemon/exp/shiny/773-fire.png differ diff --git a/public/images/pokemon/exp/shiny/773-flying.png b/public/images/pokemon/exp/shiny/773-flying.png index aae4f9b7b76..69844543843 100644 Binary files a/public/images/pokemon/exp/shiny/773-flying.png and b/public/images/pokemon/exp/shiny/773-flying.png differ diff --git a/public/images/pokemon/exp/shiny/773-ghost.png b/public/images/pokemon/exp/shiny/773-ghost.png index 6d79bf774bc..89405e0a7ca 100644 Binary files a/public/images/pokemon/exp/shiny/773-ghost.png and b/public/images/pokemon/exp/shiny/773-ghost.png differ diff --git a/public/images/pokemon/exp/shiny/773-grass.png b/public/images/pokemon/exp/shiny/773-grass.png index 601419751c8..dd3cb842ca0 100644 Binary files a/public/images/pokemon/exp/shiny/773-grass.png and b/public/images/pokemon/exp/shiny/773-grass.png differ diff --git a/public/images/pokemon/exp/shiny/773-ground.png b/public/images/pokemon/exp/shiny/773-ground.png index fcc06261bc5..3ce87abe562 100644 Binary files a/public/images/pokemon/exp/shiny/773-ground.png and b/public/images/pokemon/exp/shiny/773-ground.png differ diff --git a/public/images/pokemon/exp/shiny/773-ice.png b/public/images/pokemon/exp/shiny/773-ice.png index b5c3ff2198d..8e255027270 100644 Binary files a/public/images/pokemon/exp/shiny/773-ice.png and b/public/images/pokemon/exp/shiny/773-ice.png differ diff --git a/public/images/pokemon/exp/shiny/773-poison.png b/public/images/pokemon/exp/shiny/773-poison.png index 1ee3bc911d7..0ff4ee2ae27 100644 Binary files a/public/images/pokemon/exp/shiny/773-poison.png and b/public/images/pokemon/exp/shiny/773-poison.png differ diff --git a/public/images/pokemon/exp/shiny/773-psychic.png b/public/images/pokemon/exp/shiny/773-psychic.png index 8c16bc691da..301ba2aa960 100644 Binary files a/public/images/pokemon/exp/shiny/773-psychic.png and b/public/images/pokemon/exp/shiny/773-psychic.png differ diff --git a/public/images/pokemon/exp/shiny/773-rock.png b/public/images/pokemon/exp/shiny/773-rock.png index 9fe2622771e..b0112ed5249 100644 Binary files a/public/images/pokemon/exp/shiny/773-rock.png and b/public/images/pokemon/exp/shiny/773-rock.png differ diff --git a/public/images/pokemon/exp/shiny/773-steel.png b/public/images/pokemon/exp/shiny/773-steel.png index 5fa7e509f6d..d6cccc50220 100644 Binary files a/public/images/pokemon/exp/shiny/773-steel.png and b/public/images/pokemon/exp/shiny/773-steel.png differ diff --git a/public/images/pokemon/exp/shiny/773-water.png b/public/images/pokemon/exp/shiny/773-water.png index 223c33b4a56..93b34532111 100644 Binary files a/public/images/pokemon/exp/shiny/773-water.png and b/public/images/pokemon/exp/shiny/773-water.png differ diff --git a/public/images/pokemon/exp/shiny/774-blue.json b/public/images/pokemon/exp/shiny/774-blue.json index 68f0cbb0589..b0c94749eaa 100644 --- a/public/images/pokemon/exp/shiny/774-blue.json +++ b/public/images/pokemon/exp/shiny/774-blue.json @@ -3,1068 +3,563 @@ { "image": "774-blue.png", "format": "RGBA8888", - "size": { - "w": 274, - "h": 274 - }, + "size": {"w": 274, "h": 274}, "scale": 1, "frames": [ { "filename": "0013.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 1, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 1,"w": 39,"h": 38}, + "frame": + {"x": 0,"y": 0,"w": 39,"h": 38} }, { "filename": "0036.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 18, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 18,"w": 39,"h": 38}, + "frame": + {"x": 39,"y": 0,"w": 39,"h": 38} }, { "filename": "0040.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 22, - "w": 39, - "h": 38 - }, - "frame": { - "x": 78, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 22,"w": 39,"h": 38}, + "frame": + {"x": 78,"y": 0,"w": 39,"h": 38} }, { "filename": "0044.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 20, - "w": 39, - "h": 38 - }, - "frame": { - "x": 117, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 20,"w": 39,"h": 38}, + "frame": + {"x": 117,"y": 0,"w": 39,"h": 38} }, { "filename": "0006.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 8, - "w": 40, - "h": 37 - }, - "frame": { - "x": 156, - "y": 0, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 40,"h": 37}, + "frame": + {"x": 156,"y": 0,"w": 40,"h": 37} }, { "filename": "0010.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 4, - "w": 40, - "h": 37 - }, - "frame": { - "x": 196, - "y": 0, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 4,"w": 40,"h": 37}, + "frame": + {"x": 196,"y": 0,"w": 40,"h": 37} }, { "filename": "0035.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 38, - "h": 38 - }, - "frame": { - "x": 236, - "y": 0, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 38,"h": 38}, + "frame": + {"x": 236,"y": 0,"w": 38,"h": 38} }, { "filename": "0018.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 40, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 0,"w": 40,"h": 37}, + "frame": + {"x": 156,"y": 37,"w": 40,"h": 37} }, { "filename": "0021.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 3, - "w": 40, - "h": 37 - }, - "frame": { - "x": 196, - "y": 37, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 3,"w": 40,"h": 37}, + "frame": + {"x": 196,"y": 37,"w": 40,"h": 37} }, { "filename": "0039.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 21, - "w": 38, - "h": 38 - }, - "frame": { - "x": 236, - "y": 38, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 21,"w": 38,"h": 38}, + "frame": + {"x": 236,"y": 38,"w": 38,"h": 38} }, { "filename": "0024.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 6, - "w": 40, - "h": 37 - }, - "frame": { - "x": 0, - "y": 38, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 6,"w": 40,"h": 37}, + "frame": + {"x": 0,"y": 38,"w": 40,"h": 37} }, { "filename": "0045.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 38, - "h": 38 - }, - "frame": { - "x": 40, - "y": 38, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 18,"w": 38,"h": 38}, + "frame": + {"x": 40,"y": 38,"w": 38,"h": 38} }, { "filename": "0047.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 38, - "h": 38 - }, - "frame": { - "x": 0, - "y": 75, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 38,"h": 38}, + "frame": + {"x": 0,"y": 75,"w": 38,"h": 38} }, { "filename": "0001.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 14, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 38,"w": 39,"h": 37} }, { "filename": "0002.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 13, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 13,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 38,"w": 39,"h": 37} }, { "filename": "0004.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 11,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 38,"w": 39,"h": 37} }, { "filename": "0049.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 16, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 16,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 38,"w": 39,"h": 37} }, { "filename": "0005.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 156,"y": 74,"w": 39,"h": 37} }, { "filename": "0008.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 7,"w": 39,"h": 37}, + "frame": + {"x": 195,"y": 74,"w": 39,"h": 37} }, { "filename": "0009.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 5, - "w": 39, - "h": 37 - }, - "frame": { - "x": 234, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 5,"w": 39,"h": 37}, + "frame": + {"x": 234,"y": 76,"w": 39,"h": 37} }, { "filename": "0011.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 3, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 75, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 3,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 75,"w": 39,"h": 37} }, { "filename": "0012.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 75, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 75,"w": 39,"h": 37} }, { "filename": "0014.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 37 - }, - "frame": { - "x": 38, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 37}, + "frame": + {"x": 38,"y": 76,"w": 39,"h": 37} }, { "filename": "0017.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 37}, + "frame": + {"x": 156,"y": 111,"w": 39,"h": 37} }, { "filename": "0019.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 1, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 1,"w": 39,"h": 37}, + "frame": + {"x": 195,"y": 111,"w": 39,"h": 37} }, { "filename": "0022.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 4, - "w": 39, - "h": 37 - }, - "frame": { - "x": 234, - "y": 113, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 4,"w": 39,"h": 37}, + "frame": + {"x": 234,"y": 113,"w": 39,"h": 37} }, { "filename": "0025.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 77, - "y": 112, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 7,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 112,"w": 39,"h": 37} }, { "filename": "0026.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 116, - "y": 112, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 112,"w": 39,"h": 37} }, { "filename": "0027.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 155, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 155,"y": 148,"w": 39,"h": 37} }, { "filename": "0028.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 194, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 194,"y": 148,"w": 39,"h": 37} }, { "filename": "0029.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 233, - "y": 150, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 11,"w": 39,"h": 37}, + "frame": + {"x": 233,"y": 150,"w": 39,"h": 37} }, { "filename": "0030.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 12, - "w": 39, - "h": 37 - }, - "frame": { - "x": 0, - "y": 113, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 12,"w": 39,"h": 37}, + "frame": + {"x": 0,"y": 113,"w": 39,"h": 37} }, { "filename": "0038.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 21, - "w": 38, - "h": 37 - }, - "frame": { - "x": 39, - "y": 113, - "w": 38, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 21,"w": 38,"h": 37}, + "frame": + {"x": 39,"y": 113,"w": 38,"h": 37} }, { "filename": "0031.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 14, - "w": 39, - "h": 37 - }, - "frame": { - "x": 77, - "y": 149, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 149,"w": 39,"h": 37} }, { "filename": "0032.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 14, - "w": 39, - "h": 37 - }, - "frame": { - "x": 116, - "y": 149, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 149,"w": 39,"h": 37} }, { "filename": "0033.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 15, - "w": 39, - "h": 37 - }, - "frame": { - "x": 155, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 15,"w": 39,"h": 37}, + "frame": + {"x": 155,"y": 185,"w": 39,"h": 37} }, { "filename": "0034.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 17, - "w": 39, - "h": 37 - }, - "frame": { - "x": 194, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 17,"w": 39,"h": 37}, + "frame": + {"x": 194,"y": 185,"w": 39,"h": 37} }, { "filename": "0037.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 20, - "w": 39, - "h": 37 - }, - "frame": { - "x": 233, - "y": 187, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 20,"w": 39,"h": 37}, + "frame": + {"x": 233,"y": 187,"w": 39,"h": 37} }, { "filename": "0046.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 39, - "h": 37 - }, - "frame": { - "x": 0, - "y": 150, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 18,"w": 39,"h": 37}, + "frame": + {"x": 0,"y": 150,"w": 39,"h": 37} }, { "filename": "0042.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 22, - "w": 38, - "h": 37 - }, - "frame": { - "x": 39, - "y": 150, - "w": 38, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 22,"w": 38,"h": 37}, + "frame": + {"x": 39,"y": 150,"w": 38,"h": 37} }, { "filename": "0048.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 39, - "h": 37 - }, - "frame": { - "x": 77, - "y": 186, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 186,"w": 39,"h": 37} }, { "filename": "0050.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 15, - "w": 39, - "h": 37 - }, - "frame": { - "x": 116, - "y": 186, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 15,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 186,"w": 39,"h": 37} }, { "filename": "0020.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 3, - "w": 40, - "h": 36 - }, - "frame": { - "x": 155, - "y": 222, - "w": 40, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 3,"w": 40,"h": 36}, + "frame": + {"x": 155,"y": 222,"w": 40,"h": 36} }, { "filename": "0043.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 21, - "w": 38, - "h": 37 - }, - "frame": { - "x": 195, - "y": 222, - "w": 38, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 21,"w": 38,"h": 37}, + "frame": + {"x": 195,"y": 222,"w": 38,"h": 37} }, { "filename": "0003.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 12, - "w": 39, - "h": 36 - }, - "frame": { - "x": 233, - "y": 224, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 12,"w": 39,"h": 36}, + "frame": + {"x": 233,"y": 224,"w": 39,"h": 36} }, { "filename": "0007.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 8, - "w": 39, - "h": 36 - }, - "frame": { - "x": 0, - "y": 187, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 39,"h": 36}, + "frame": + {"x": 0,"y": 187,"w": 39,"h": 36} }, { "filename": "0041.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 24, - "w": 38, - "h": 36 - }, - "frame": { - "x": 39, - "y": 187, - "w": 38, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 24,"w": 38,"h": 36}, + "frame": + {"x": 39,"y": 187,"w": 38,"h": 36} }, { "filename": "0015.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 36 - }, - "frame": { - "x": 0, - "y": 223, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 36}, + "frame": + {"x": 0,"y": 223,"w": 39,"h": 36} }, { "filename": "0016.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 36 - }, - "frame": { - "x": 39, - "y": 223, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 36}, + "frame": + {"x": 39,"y": 223,"w": 39,"h": 36} }, { "filename": "0023.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 5, - "w": 39, - "h": 36 - }, - "frame": { - "x": 78, - "y": 223, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 5,"w": 39,"h": 36}, + "frame": + {"x": 78,"y": 223,"w": 39,"h": 36} } ] } ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:acb305015c2a45d3261928a18f05772e:62260d5eb9ff1fb9aa2b993de070968b:0787168dbe37404ac3aa22b487979d47$" - } + "meta": + {"app": "https://www.codeandweb.com/texturepacker", + "version": "3.0"} } diff --git a/public/images/pokemon/exp/shiny/774-blue.png b/public/images/pokemon/exp/shiny/774-blue.png index a6d5fd10f18..89b28356173 100644 Binary files a/public/images/pokemon/exp/shiny/774-blue.png and b/public/images/pokemon/exp/shiny/774-blue.png differ diff --git a/public/images/pokemon/exp/shiny/774-green.json b/public/images/pokemon/exp/shiny/774-green.json index f66a0c3eb50..90220f4dd67 100644 --- a/public/images/pokemon/exp/shiny/774-green.json +++ b/public/images/pokemon/exp/shiny/774-green.json @@ -3,1992 +3,563 @@ { "image": "774-green.png", "format": "RGBA8888", - "size": { - "w": 258, - "h": 258 - }, + "size": {"w": 274, "h": 274}, "scale": 1, "frames": [ { - "filename": "0017.png", + "filename": "0013.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 6, - "w": 40, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 40, - "h": 40 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 6, - "w": 40, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 40, - "h": 40 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 6, - "w": 40, - "h": 40 - }, - "frame": { - "x": 0, - "y": 40, - "w": 40, - "h": 40 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 6, - "w": 40, - "h": 40 - }, - "frame": { - "x": 0, - "y": 40, - "w": 40, - "h": 40 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 0, - "w": 40, - "h": 39 - }, - "frame": { - "x": 40, - "y": 0, - "w": 40, - "h": 39 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 0, - "w": 40, - "h": 39 - }, - "frame": { - "x": 40, - "y": 0, - "w": 40, - "h": 39 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 39, - "h": 40 - }, - "frame": { - "x": 0, - "y": 80, - "w": 39, - "h": 40 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 39, - "h": 40 - }, - "frame": { - "x": 0, - "y": 80, - "w": 39, - "h": 40 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 39, - "h": 40 - }, - "frame": { - "x": 40, - "y": 39, - "w": 39, - "h": 40 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 39, - "h": 40 - }, - "frame": { - "x": 40, - "y": 39, - "w": 39, - "h": 40 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 0, - "w": 40, - "h": 39 - }, - "frame": { - "x": 80, - "y": 0, - "w": 40, - "h": 39 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 0, - "w": 40, - "h": 39 - }, - "frame": { - "x": 80, - "y": 0, - "w": 40, - "h": 39 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 39, - "h": 40 - }, - "frame": { - "x": 0, - "y": 120, - "w": 39, - "h": 40 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 39, - "h": 40 - }, - "frame": { - "x": 0, - "y": 120, - "w": 39, - "h": 40 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 1,"w": 39,"h": 38}, + "frame": + {"x": 0,"y": 0,"w": 39,"h": 38} }, { "filename": "0036.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 39, - "h": 40 - }, - "frame": { - "x": 79, - "y": 39, - "w": 39, - "h": 40 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 39, - "h": 40 - }, - "frame": { - "x": 79, - "y": 39, - "w": 39, - "h": 40 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 26, - "y": 11, - "w": 40, - "h": 39 - }, - "frame": { - "x": 120, - "y": 0, - "w": 40, - "h": 39 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 26, - "y": 11, - "w": 40, - "h": 39 - }, - "frame": { - "x": 120, - "y": 0, - "w": 40, - "h": 39 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 8, - "w": 42, - "h": 36 - }, - "frame": { - "x": 118, - "y": 39, - "w": 42, - "h": 36 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 41, - "y": 11, - "w": 42, - "h": 36 - }, - "frame": { - "x": 160, - "y": 0, - "w": 42, - "h": 36 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 41, - "y": 11, - "w": 42, - "h": 36 - }, - "frame": { - "x": 160, - "y": 0, - "w": 42, - "h": 36 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 41, - "y": 11, - "w": 42, - "h": 36 - }, - "frame": { - "x": 160, - "y": 0, - "w": 42, - "h": 36 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 41, - "y": 11, - "w": 42, - "h": 36 - }, - "frame": { - "x": 160, - "y": 0, - "w": 42, - "h": 36 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 8, - "w": 42, - "h": 36 - }, - "frame": { - "x": 160, - "y": 36, - "w": 42, - "h": 36 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 8, - "w": 42, - "h": 36 - }, - "frame": { - "x": 160, - "y": 36, - "w": 42, - "h": 36 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 8, - "w": 42, - "h": 36 - }, - "frame": { - "x": 160, - "y": 36, - "w": 42, - "h": 36 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 13, - "w": 42, - "h": 36 - }, - "frame": { - "x": 202, - "y": 0, - "w": 42, - "h": 36 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 13, - "w": 42, - "h": 36 - }, - "frame": { - "x": 202, - "y": 0, - "w": 42, - "h": 36 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 43, - "y": 9, - "w": 41, - "h": 36 - }, - "frame": { - "x": 202, - "y": 36, - "w": 41, - "h": 36 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 43, - "y": 9, - "w": 41, - "h": 36 - }, - "frame": { - "x": 202, - "y": 36, - "w": 41, - "h": 36 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 43, - "y": 9, - "w": 41, - "h": 36 - }, - "frame": { - "x": 202, - "y": 36, - "w": 41, - "h": 36 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 43, - "y": 9, - "w": 41, - "h": 36 - }, - "frame": { - "x": 202, - "y": 36, - "w": 41, - "h": 36 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 160, - "w": 39, - "h": 38 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 160, - "w": 39, - "h": 38 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 1, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 198, - "w": 39, - "h": 38 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 9, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 198, - "w": 39, - "h": 38 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 1, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 198, - "w": 39, - "h": 38 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 9, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 198, - "w": 39, - "h": 38 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 37, - "y": 15, - "w": 42, - "h": 35 - }, - "frame": { - "x": 118, - "y": 75, - "w": 42, - "h": 35 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 37, - "y": 15, - "w": 42, - "h": 35 - }, - "frame": { - "x": 118, - "y": 75, - "w": 42, - "h": 35 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 43, - "y": 9, - "w": 41, - "h": 36 - }, - "frame": { - "x": 160, - "y": 72, - "w": 41, - "h": 36 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 43, - "y": 9, - "w": 41, - "h": 36 - }, - "frame": { - "x": 160, - "y": 72, - "w": 41, - "h": 36 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 43, - "y": 9, - "w": 41, - "h": 36 - }, - "frame": { - "x": 160, - "y": 72, - "w": 41, - "h": 36 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 43, - "y": 9, - "w": 41, - "h": 36 - }, - "frame": { - "x": 160, - "y": 72, - "w": 41, - "h": 36 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 37, - "y": 15, - "w": 42, - "h": 35 - }, - "frame": { - "x": 201, - "y": 72, - "w": 42, - "h": 35 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 37, - "y": 15, - "w": 42, - "h": 35 - }, - "frame": { - "x": 201, - "y": 72, - "w": 42, - "h": 35 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 160, - "y": 108, - "w": 39, - "h": 37 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 160, - "y": 108, - "w": 39, - "h": 37 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 160, - "y": 108, - "w": 39, - "h": 37 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 40, - "y": 79, - "w": 39, - "h": 37 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 40, - "y": 79, - "w": 39, - "h": 37 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 40, - "y": 79, - "w": 39, - "h": 37 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 25, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 79, - "y": 79, - "w": 39, - "h": 37 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 25, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 79, - "y": 79, - "w": 39, - "h": 37 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 9, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 116, - "w": 39, - "h": 38 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 1, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 116, - "w": 39, - "h": 38 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 9, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 116, - "w": 39, - "h": 38 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 1, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 116, - "w": 39, - "h": 38 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 154, - "w": 39, - "h": 38 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 154, - "w": 39, - "h": 38 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 38 - }, - "frame": { - "x": 78, - "y": 116, - "w": 39, - "h": 38 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 38 - }, - "frame": { - "x": 78, - "y": 116, - "w": 39, - "h": 38 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 29, - "y": 11, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 192, - "w": 39, - "h": 38 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 34, - "y": 3, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 154, - "w": 39, - "h": 37 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 34, - "y": 3, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 154, - "w": 39, - "h": 37 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 30, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 191, - "w": 39, - "h": 37 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 30, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 191, - "w": 39, - "h": 37 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 118, - "y": 110, - "w": 39, - "h": 37 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 118, - "y": 110, - "w": 39, - "h": 37 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 118, - "y": 110, - "w": 39, - "h": 37 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 20, - "y": 9, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 147, - "w": 39, - "h": 37 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 20, - "y": 9, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 147, - "w": 39, - "h": 37 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 20, - "y": 9, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 184, - "w": 39, - "h": 37 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 20, - "y": 9, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 184, - "w": 39, - "h": 37 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 25, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 221, - "w": 39, - "h": 37 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 25, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 221, - "w": 39, - "h": 37 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 34, - "y": 3, - "w": 39, - "h": 37 - }, - "frame": { - "x": 201, - "y": 107, - "w": 39, - "h": 37 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 34, - "y": 3, - "w": 39, - "h": 37 - }, - "frame": { - "x": 201, - "y": 107, - "w": 39, - "h": 37 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 30, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 157, - "y": 145, - "w": 39, - "h": 37 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 30, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 157, - "y": 145, - "w": 39, - "h": 37 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 20, - "y": 9, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 182, - "w": 39, - "h": 37 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 20, - "y": 9, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 182, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 18,"w": 39,"h": 38}, + "frame": + {"x": 39,"y": 0,"w": 39,"h": 38} }, { "filename": "0040.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 20, - "y": 9, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 219, - "w": 39, - "h": 37 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 20, - "y": 9, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 219, - "w": 39, - "h": 37 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 196, - "y": 145, - "w": 39, - "h": 37 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 196, - "y": 145, - "w": 39, - "h": 37 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 196, - "y": 145, - "w": 39, - "h": 37 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 196, - "y": 145, - "w": 39, - "h": 37 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 196, - "y": 145, - "w": 39, - "h": 37 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 196, - "y": 145, - "w": 39, - "h": 37 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 196, - "y": 145, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 22,"w": 39,"h": 38}, + "frame": + {"x": 78,"y": 0,"w": 39,"h": 38} }, { "filename": "0044.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 182, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 20,"w": 39,"h": 38}, + "frame": + {"x": 117,"y": 0,"w": 39,"h": 38} }, { - "filename": "0094.png", + "filename": "0006.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 182, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 40,"h": 37}, + "frame": + {"x": 156,"y": 0,"w": 40,"h": 37} }, { - "filename": "0088.png", + "filename": "0010.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 219, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 4,"w": 40,"h": 37}, + "frame": + {"x": 196,"y": 0,"w": 40,"h": 37} + }, + { + "filename": "0035.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 38,"h": 38}, + "frame": + {"x": 236,"y": 0,"w": 38,"h": 38} + }, + { + "filename": "0018.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 0,"w": 40,"h": 37}, + "frame": + {"x": 156,"y": 37,"w": 40,"h": 37} + }, + { + "filename": "0021.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 3,"w": 40,"h": 37}, + "frame": + {"x": 196,"y": 37,"w": 40,"h": 37} + }, + { + "filename": "0039.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 21,"w": 38,"h": 38}, + "frame": + {"x": 236,"y": 38,"w": 38,"h": 38} + }, + { + "filename": "0024.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 6,"w": 40,"h": 37}, + "frame": + {"x": 0,"y": 38,"w": 40,"h": 37} + }, + { + "filename": "0045.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 18,"w": 38,"h": 38}, + "frame": + {"x": 40,"y": 38,"w": 38,"h": 38} + }, + { + "filename": "0047.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 38,"h": 38}, + "frame": + {"x": 0,"y": 75,"w": 38,"h": 38} + }, + { + "filename": "0001.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 38,"w": 39,"h": 37} + }, + { + "filename": "0002.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 13,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 38,"w": 39,"h": 37} + }, + { + "filename": "0004.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 11,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 38,"w": 39,"h": 37} + }, + { + "filename": "0049.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 16,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 38,"w": 39,"h": 37} + }, + { + "filename": "0005.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 156,"y": 74,"w": 39,"h": 37} + }, + { + "filename": "0008.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 7,"w": 39,"h": 37}, + "frame": + {"x": 195,"y": 74,"w": 39,"h": 37} + }, + { + "filename": "0009.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 5,"w": 39,"h": 37}, + "frame": + {"x": 234,"y": 76,"w": 39,"h": 37} + }, + { + "filename": "0011.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 3,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 75,"w": 39,"h": 37} + }, + { + "filename": "0012.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 75,"w": 39,"h": 37} + }, + { + "filename": "0014.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 37}, + "frame": + {"x": 38,"y": 76,"w": 39,"h": 37} + }, + { + "filename": "0017.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 37}, + "frame": + {"x": 156,"y": 111,"w": 39,"h": 37} + }, + { + "filename": "0019.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 1,"w": 39,"h": 37}, + "frame": + {"x": 195,"y": 111,"w": 39,"h": 37} + }, + { + "filename": "0022.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 4,"w": 39,"h": 37}, + "frame": + {"x": 234,"y": 113,"w": 39,"h": 37} + }, + { + "filename": "0025.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 7,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 112,"w": 39,"h": 37} + }, + { + "filename": "0026.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 112,"w": 39,"h": 37} + }, + { + "filename": "0027.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 155,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0028.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 194,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0029.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 11,"w": 39,"h": 37}, + "frame": + {"x": 233,"y": 150,"w": 39,"h": 37} + }, + { + "filename": "0030.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 12,"w": 39,"h": 37}, + "frame": + {"x": 0,"y": 113,"w": 39,"h": 37} + }, + { + "filename": "0038.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 21,"w": 38,"h": 37}, + "frame": + {"x": 39,"y": 113,"w": 38,"h": 37} + }, + { + "filename": "0031.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 149,"w": 39,"h": 37} + }, + { + "filename": "0032.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 149,"w": 39,"h": 37} + }, + { + "filename": "0033.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 15,"w": 39,"h": 37}, + "frame": + {"x": 155,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0034.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 17,"w": 39,"h": 37}, + "frame": + {"x": 194,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0037.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 20,"w": 39,"h": 37}, + "frame": + {"x": 233,"y": 187,"w": 39,"h": 37} + }, + { + "filename": "0046.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 18,"w": 39,"h": 37}, + "frame": + {"x": 0,"y": 150,"w": 39,"h": 37} + }, + { + "filename": "0042.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 22,"w": 38,"h": 37}, + "frame": + {"x": 39,"y": 150,"w": 38,"h": 37} + }, + { + "filename": "0048.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 186,"w": 39,"h": 37} + }, + { + "filename": "0050.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 15,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 186,"w": 39,"h": 37} + }, + { + "filename": "0020.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 3,"w": 40,"h": 36}, + "frame": + {"x": 155,"y": 222,"w": 40,"h": 36} + }, + { + "filename": "0043.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 21,"w": 38,"h": 37}, + "frame": + {"x": 195,"y": 222,"w": 38,"h": 37} + }, + { + "filename": "0003.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 12,"w": 39,"h": 36}, + "frame": + {"x": 233,"y": 224,"w": 39,"h": 36} + }, + { + "filename": "0007.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 39,"h": 36}, + "frame": + {"x": 0,"y": 187,"w": 39,"h": 36} + }, + { + "filename": "0041.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 24,"w": 38,"h": 36}, + "frame": + {"x": 39,"y": 187,"w": 38,"h": 36} + }, + { + "filename": "0015.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 36}, + "frame": + {"x": 0,"y": 223,"w": 39,"h": 36} + }, + { + "filename": "0016.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 36}, + "frame": + {"x": 39,"y": 223,"w": 39,"h": 36} + }, + { + "filename": "0023.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 5,"w": 39,"h": 36}, + "frame": + {"x": 78,"y": 223,"w": 39,"h": 36} } ] } ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:c4861fa521665a2011b35defd4782e07:4c960b9742bee4226c07a4620b6a1d2f:e4b1fffb78b8c0cdc557670bcee043ca$" - } + "meta": + {"app": "https://www.codeandweb.com/texturepacker", + "version": "3.0"} } diff --git a/public/images/pokemon/exp/shiny/774-green.png b/public/images/pokemon/exp/shiny/774-green.png index ed8deff92bd..781e176c43d 100644 Binary files a/public/images/pokemon/exp/shiny/774-green.png and b/public/images/pokemon/exp/shiny/774-green.png differ diff --git a/public/images/pokemon/exp/shiny/774-indigo.json b/public/images/pokemon/exp/shiny/774-indigo.json index 84c579c51b5..d54b0a91175 100644 --- a/public/images/pokemon/exp/shiny/774-indigo.json +++ b/public/images/pokemon/exp/shiny/774-indigo.json @@ -3,1068 +3,563 @@ { "image": "774-indigo.png", "format": "RGBA8888", - "size": { - "w": 274, - "h": 274 - }, + "size": {"w": 274, "h": 274}, "scale": 1, "frames": [ { "filename": "0013.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 1, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 1,"w": 39,"h": 38}, + "frame": + {"x": 0,"y": 0,"w": 39,"h": 38} }, { "filename": "0036.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 18, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 18,"w": 39,"h": 38}, + "frame": + {"x": 39,"y": 0,"w": 39,"h": 38} }, { "filename": "0040.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 22, - "w": 39, - "h": 38 - }, - "frame": { - "x": 78, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 22,"w": 39,"h": 38}, + "frame": + {"x": 78,"y": 0,"w": 39,"h": 38} }, { "filename": "0044.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 20, - "w": 39, - "h": 38 - }, - "frame": { - "x": 117, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 20,"w": 39,"h": 38}, + "frame": + {"x": 117,"y": 0,"w": 39,"h": 38} }, { "filename": "0006.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 8, - "w": 40, - "h": 37 - }, - "frame": { - "x": 156, - "y": 0, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 40,"h": 37}, + "frame": + {"x": 156,"y": 0,"w": 40,"h": 37} }, { "filename": "0010.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 4, - "w": 40, - "h": 37 - }, - "frame": { - "x": 196, - "y": 0, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 4,"w": 40,"h": 37}, + "frame": + {"x": 196,"y": 0,"w": 40,"h": 37} }, { "filename": "0035.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 38, - "h": 38 - }, - "frame": { - "x": 236, - "y": 0, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 38,"h": 38}, + "frame": + {"x": 236,"y": 0,"w": 38,"h": 38} }, { "filename": "0018.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 40, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 0,"w": 40,"h": 37}, + "frame": + {"x": 156,"y": 37,"w": 40,"h": 37} }, { "filename": "0021.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 3, - "w": 40, - "h": 37 - }, - "frame": { - "x": 196, - "y": 37, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 3,"w": 40,"h": 37}, + "frame": + {"x": 196,"y": 37,"w": 40,"h": 37} }, { "filename": "0039.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 21, - "w": 38, - "h": 38 - }, - "frame": { - "x": 236, - "y": 38, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 21,"w": 38,"h": 38}, + "frame": + {"x": 236,"y": 38,"w": 38,"h": 38} }, { "filename": "0024.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 6, - "w": 40, - "h": 37 - }, - "frame": { - "x": 0, - "y": 38, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 6,"w": 40,"h": 37}, + "frame": + {"x": 0,"y": 38,"w": 40,"h": 37} }, { "filename": "0045.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 38, - "h": 38 - }, - "frame": { - "x": 40, - "y": 38, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 18,"w": 38,"h": 38}, + "frame": + {"x": 40,"y": 38,"w": 38,"h": 38} }, { "filename": "0047.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 38, - "h": 38 - }, - "frame": { - "x": 0, - "y": 75, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 38,"h": 38}, + "frame": + {"x": 0,"y": 75,"w": 38,"h": 38} }, { "filename": "0001.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 14, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 38,"w": 39,"h": 37} }, { "filename": "0002.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 13, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 13,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 38,"w": 39,"h": 37} }, { "filename": "0004.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 11,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 38,"w": 39,"h": 37} }, { "filename": "0049.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 16, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 16,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 38,"w": 39,"h": 37} }, { "filename": "0005.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 156,"y": 74,"w": 39,"h": 37} }, { "filename": "0008.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 7,"w": 39,"h": 37}, + "frame": + {"x": 195,"y": 74,"w": 39,"h": 37} }, { "filename": "0009.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 5, - "w": 39, - "h": 37 - }, - "frame": { - "x": 234, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 5,"w": 39,"h": 37}, + "frame": + {"x": 234,"y": 76,"w": 39,"h": 37} }, { "filename": "0011.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 3, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 75, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 3,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 75,"w": 39,"h": 37} }, { "filename": "0012.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 75, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 75,"w": 39,"h": 37} }, { "filename": "0014.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 37 - }, - "frame": { - "x": 38, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 37}, + "frame": + {"x": 38,"y": 76,"w": 39,"h": 37} }, { "filename": "0017.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 37}, + "frame": + {"x": 156,"y": 111,"w": 39,"h": 37} }, { "filename": "0019.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 1, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 1,"w": 39,"h": 37}, + "frame": + {"x": 195,"y": 111,"w": 39,"h": 37} }, { "filename": "0022.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 4, - "w": 39, - "h": 37 - }, - "frame": { - "x": 234, - "y": 113, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 4,"w": 39,"h": 37}, + "frame": + {"x": 234,"y": 113,"w": 39,"h": 37} }, { "filename": "0025.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 77, - "y": 112, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 7,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 112,"w": 39,"h": 37} }, { "filename": "0026.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 116, - "y": 112, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 112,"w": 39,"h": 37} }, { "filename": "0027.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 155, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 155,"y": 148,"w": 39,"h": 37} }, { "filename": "0028.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 194, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 194,"y": 148,"w": 39,"h": 37} }, { "filename": "0029.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 233, - "y": 150, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 11,"w": 39,"h": 37}, + "frame": + {"x": 233,"y": 150,"w": 39,"h": 37} }, { "filename": "0030.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 12, - "w": 39, - "h": 37 - }, - "frame": { - "x": 0, - "y": 113, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 12,"w": 39,"h": 37}, + "frame": + {"x": 0,"y": 113,"w": 39,"h": 37} }, { "filename": "0038.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 21, - "w": 38, - "h": 37 - }, - "frame": { - "x": 39, - "y": 113, - "w": 38, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 21,"w": 38,"h": 37}, + "frame": + {"x": 39,"y": 113,"w": 38,"h": 37} }, { "filename": "0031.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 14, - "w": 39, - "h": 37 - }, - "frame": { - "x": 77, - "y": 149, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 149,"w": 39,"h": 37} }, { "filename": "0032.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 14, - "w": 39, - "h": 37 - }, - "frame": { - "x": 116, - "y": 149, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 149,"w": 39,"h": 37} }, { "filename": "0033.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 15, - "w": 39, - "h": 37 - }, - "frame": { - "x": 155, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 15,"w": 39,"h": 37}, + "frame": + {"x": 155,"y": 185,"w": 39,"h": 37} }, { "filename": "0034.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 17, - "w": 39, - "h": 37 - }, - "frame": { - "x": 194, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 17,"w": 39,"h": 37}, + "frame": + {"x": 194,"y": 185,"w": 39,"h": 37} }, { "filename": "0037.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 20, - "w": 39, - "h": 37 - }, - "frame": { - "x": 233, - "y": 187, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 20,"w": 39,"h": 37}, + "frame": + {"x": 233,"y": 187,"w": 39,"h": 37} }, { "filename": "0046.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 39, - "h": 37 - }, - "frame": { - "x": 0, - "y": 150, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 18,"w": 39,"h": 37}, + "frame": + {"x": 0,"y": 150,"w": 39,"h": 37} }, { "filename": "0042.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 22, - "w": 38, - "h": 37 - }, - "frame": { - "x": 39, - "y": 150, - "w": 38, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 22,"w": 38,"h": 37}, + "frame": + {"x": 39,"y": 150,"w": 38,"h": 37} }, { "filename": "0048.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 39, - "h": 37 - }, - "frame": { - "x": 77, - "y": 186, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 186,"w": 39,"h": 37} }, { "filename": "0050.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 15, - "w": 39, - "h": 37 - }, - "frame": { - "x": 116, - "y": 186, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 15,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 186,"w": 39,"h": 37} }, { "filename": "0020.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 3, - "w": 40, - "h": 36 - }, - "frame": { - "x": 155, - "y": 222, - "w": 40, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 3,"w": 40,"h": 36}, + "frame": + {"x": 155,"y": 222,"w": 40,"h": 36} }, { "filename": "0043.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 21, - "w": 38, - "h": 37 - }, - "frame": { - "x": 195, - "y": 222, - "w": 38, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 21,"w": 38,"h": 37}, + "frame": + {"x": 195,"y": 222,"w": 38,"h": 37} }, { "filename": "0003.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 12, - "w": 39, - "h": 36 - }, - "frame": { - "x": 233, - "y": 224, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 12,"w": 39,"h": 36}, + "frame": + {"x": 233,"y": 224,"w": 39,"h": 36} }, { "filename": "0007.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 8, - "w": 39, - "h": 36 - }, - "frame": { - "x": 0, - "y": 187, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 39,"h": 36}, + "frame": + {"x": 0,"y": 187,"w": 39,"h": 36} }, { "filename": "0041.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 24, - "w": 38, - "h": 36 - }, - "frame": { - "x": 39, - "y": 187, - "w": 38, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 24,"w": 38,"h": 36}, + "frame": + {"x": 39,"y": 187,"w": 38,"h": 36} }, { "filename": "0015.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 36 - }, - "frame": { - "x": 0, - "y": 223, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 36}, + "frame": + {"x": 0,"y": 223,"w": 39,"h": 36} }, { "filename": "0016.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 36 - }, - "frame": { - "x": 39, - "y": 223, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 36}, + "frame": + {"x": 39,"y": 223,"w": 39,"h": 36} }, { "filename": "0023.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 5, - "w": 39, - "h": 36 - }, - "frame": { - "x": 78, - "y": 223, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 5,"w": 39,"h": 36}, + "frame": + {"x": 78,"y": 223,"w": 39,"h": 36} } ] } ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:88a2e05beb93e9531c39129adb1ac305:eaad56c1320913dd19370508918d9cfd:f6d3104f6cc09a16e2cbfcba30e4d78a$" - } + "meta": + {"app": "https://www.codeandweb.com/texturepacker", + "version": "3.0"} } diff --git a/public/images/pokemon/exp/shiny/774-indigo.png b/public/images/pokemon/exp/shiny/774-indigo.png index 4c2c954f2e7..b78e2baa7b7 100644 Binary files a/public/images/pokemon/exp/shiny/774-indigo.png and b/public/images/pokemon/exp/shiny/774-indigo.png differ diff --git a/public/images/pokemon/exp/shiny/774-orange.json b/public/images/pokemon/exp/shiny/774-orange.json index 40872ab007c..77e0908b690 100644 --- a/public/images/pokemon/exp/shiny/774-orange.json +++ b/public/images/pokemon/exp/shiny/774-orange.json @@ -3,1992 +3,563 @@ { "image": "774-orange.png", "format": "RGBA8888", - "size": { - "w": 258, - "h": 258 - }, + "size": {"w": 274, "h": 274}, "scale": 1, "frames": [ { - "filename": "0017.png", + "filename": "0013.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 6, - "w": 40, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 40, - "h": 40 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 6, - "w": 40, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 40, - "h": 40 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 6, - "w": 40, - "h": 40 - }, - "frame": { - "x": 0, - "y": 40, - "w": 40, - "h": 40 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 6, - "w": 40, - "h": 40 - }, - "frame": { - "x": 0, - "y": 40, - "w": 40, - "h": 40 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 0, - "w": 40, - "h": 39 - }, - "frame": { - "x": 40, - "y": 0, - "w": 40, - "h": 39 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 0, - "w": 40, - "h": 39 - }, - "frame": { - "x": 40, - "y": 0, - "w": 40, - "h": 39 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 39, - "h": 40 - }, - "frame": { - "x": 0, - "y": 80, - "w": 39, - "h": 40 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 39, - "h": 40 - }, - "frame": { - "x": 0, - "y": 80, - "w": 39, - "h": 40 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 39, - "h": 40 - }, - "frame": { - "x": 40, - "y": 39, - "w": 39, - "h": 40 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 39, - "h": 40 - }, - "frame": { - "x": 40, - "y": 39, - "w": 39, - "h": 40 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 0, - "w": 40, - "h": 39 - }, - "frame": { - "x": 80, - "y": 0, - "w": 40, - "h": 39 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 0, - "w": 40, - "h": 39 - }, - "frame": { - "x": 80, - "y": 0, - "w": 40, - "h": 39 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 39, - "h": 40 - }, - "frame": { - "x": 0, - "y": 120, - "w": 39, - "h": 40 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 39, - "h": 40 - }, - "frame": { - "x": 0, - "y": 120, - "w": 39, - "h": 40 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 1,"w": 39,"h": 38}, + "frame": + {"x": 0,"y": 0,"w": 39,"h": 38} }, { "filename": "0036.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 39, - "h": 40 - }, - "frame": { - "x": 79, - "y": 39, - "w": 39, - "h": 40 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 39, - "h": 40 - }, - "frame": { - "x": 79, - "y": 39, - "w": 39, - "h": 40 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 26, - "y": 11, - "w": 40, - "h": 39 - }, - "frame": { - "x": 120, - "y": 0, - "w": 40, - "h": 39 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 26, - "y": 11, - "w": 40, - "h": 39 - }, - "frame": { - "x": 120, - "y": 0, - "w": 40, - "h": 39 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 8, - "w": 42, - "h": 36 - }, - "frame": { - "x": 118, - "y": 39, - "w": 42, - "h": 36 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 41, - "y": 11, - "w": 42, - "h": 36 - }, - "frame": { - "x": 160, - "y": 0, - "w": 42, - "h": 36 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 41, - "y": 11, - "w": 42, - "h": 36 - }, - "frame": { - "x": 160, - "y": 0, - "w": 42, - "h": 36 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 41, - "y": 11, - "w": 42, - "h": 36 - }, - "frame": { - "x": 160, - "y": 0, - "w": 42, - "h": 36 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 41, - "y": 11, - "w": 42, - "h": 36 - }, - "frame": { - "x": 160, - "y": 0, - "w": 42, - "h": 36 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 8, - "w": 42, - "h": 36 - }, - "frame": { - "x": 160, - "y": 36, - "w": 42, - "h": 36 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 8, - "w": 42, - "h": 36 - }, - "frame": { - "x": 160, - "y": 36, - "w": 42, - "h": 36 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 8, - "w": 42, - "h": 36 - }, - "frame": { - "x": 160, - "y": 36, - "w": 42, - "h": 36 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 13, - "w": 42, - "h": 36 - }, - "frame": { - "x": 202, - "y": 0, - "w": 42, - "h": 36 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 13, - "w": 42, - "h": 36 - }, - "frame": { - "x": 202, - "y": 0, - "w": 42, - "h": 36 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 43, - "y": 9, - "w": 41, - "h": 36 - }, - "frame": { - "x": 202, - "y": 36, - "w": 41, - "h": 36 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 43, - "y": 9, - "w": 41, - "h": 36 - }, - "frame": { - "x": 202, - "y": 36, - "w": 41, - "h": 36 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 43, - "y": 9, - "w": 41, - "h": 36 - }, - "frame": { - "x": 202, - "y": 36, - "w": 41, - "h": 36 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 43, - "y": 9, - "w": 41, - "h": 36 - }, - "frame": { - "x": 202, - "y": 36, - "w": 41, - "h": 36 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 160, - "w": 39, - "h": 38 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 160, - "w": 39, - "h": 38 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 1, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 198, - "w": 39, - "h": 38 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 9, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 198, - "w": 39, - "h": 38 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 1, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 198, - "w": 39, - "h": 38 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 9, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 198, - "w": 39, - "h": 38 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 37, - "y": 15, - "w": 42, - "h": 35 - }, - "frame": { - "x": 118, - "y": 75, - "w": 42, - "h": 35 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 37, - "y": 15, - "w": 42, - "h": 35 - }, - "frame": { - "x": 118, - "y": 75, - "w": 42, - "h": 35 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 43, - "y": 9, - "w": 41, - "h": 36 - }, - "frame": { - "x": 160, - "y": 72, - "w": 41, - "h": 36 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 43, - "y": 9, - "w": 41, - "h": 36 - }, - "frame": { - "x": 160, - "y": 72, - "w": 41, - "h": 36 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 43, - "y": 9, - "w": 41, - "h": 36 - }, - "frame": { - "x": 160, - "y": 72, - "w": 41, - "h": 36 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 43, - "y": 9, - "w": 41, - "h": 36 - }, - "frame": { - "x": 160, - "y": 72, - "w": 41, - "h": 36 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 37, - "y": 15, - "w": 42, - "h": 35 - }, - "frame": { - "x": 201, - "y": 72, - "w": 42, - "h": 35 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 37, - "y": 15, - "w": 42, - "h": 35 - }, - "frame": { - "x": 201, - "y": 72, - "w": 42, - "h": 35 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 160, - "y": 108, - "w": 39, - "h": 37 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 160, - "y": 108, - "w": 39, - "h": 37 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 160, - "y": 108, - "w": 39, - "h": 37 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 40, - "y": 79, - "w": 39, - "h": 37 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 40, - "y": 79, - "w": 39, - "h": 37 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 40, - "y": 79, - "w": 39, - "h": 37 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 25, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 79, - "y": 79, - "w": 39, - "h": 37 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 25, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 79, - "y": 79, - "w": 39, - "h": 37 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 9, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 116, - "w": 39, - "h": 38 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 1, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 116, - "w": 39, - "h": 38 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 9, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 116, - "w": 39, - "h": 38 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 1, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 116, - "w": 39, - "h": 38 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 154, - "w": 39, - "h": 38 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 154, - "w": 39, - "h": 38 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 38 - }, - "frame": { - "x": 78, - "y": 116, - "w": 39, - "h": 38 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 38 - }, - "frame": { - "x": 78, - "y": 116, - "w": 39, - "h": 38 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 29, - "y": 11, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 192, - "w": 39, - "h": 38 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 34, - "y": 3, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 154, - "w": 39, - "h": 37 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 34, - "y": 3, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 154, - "w": 39, - "h": 37 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 30, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 191, - "w": 39, - "h": 37 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 30, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 191, - "w": 39, - "h": 37 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 118, - "y": 110, - "w": 39, - "h": 37 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 118, - "y": 110, - "w": 39, - "h": 37 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 118, - "y": 110, - "w": 39, - "h": 37 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 20, - "y": 9, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 147, - "w": 39, - "h": 37 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 20, - "y": 9, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 147, - "w": 39, - "h": 37 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 20, - "y": 9, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 184, - "w": 39, - "h": 37 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 20, - "y": 9, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 184, - "w": 39, - "h": 37 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 25, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 221, - "w": 39, - "h": 37 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 25, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 221, - "w": 39, - "h": 37 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 34, - "y": 3, - "w": 39, - "h": 37 - }, - "frame": { - "x": 201, - "y": 107, - "w": 39, - "h": 37 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 34, - "y": 3, - "w": 39, - "h": 37 - }, - "frame": { - "x": 201, - "y": 107, - "w": 39, - "h": 37 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 30, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 157, - "y": 145, - "w": 39, - "h": 37 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 30, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 157, - "y": 145, - "w": 39, - "h": 37 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 20, - "y": 9, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 182, - "w": 39, - "h": 37 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 20, - "y": 9, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 182, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 18,"w": 39,"h": 38}, + "frame": + {"x": 39,"y": 0,"w": 39,"h": 38} }, { "filename": "0040.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 20, - "y": 9, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 219, - "w": 39, - "h": 37 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 20, - "y": 9, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 219, - "w": 39, - "h": 37 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 196, - "y": 145, - "w": 39, - "h": 37 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 196, - "y": 145, - "w": 39, - "h": 37 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 196, - "y": 145, - "w": 39, - "h": 37 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 196, - "y": 145, - "w": 39, - "h": 37 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 196, - "y": 145, - "w": 39, - "h": 37 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 196, - "y": 145, - "w": 39, - "h": 37 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 196, - "y": 145, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 22,"w": 39,"h": 38}, + "frame": + {"x": 78,"y": 0,"w": 39,"h": 38} }, { "filename": "0044.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 182, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 20,"w": 39,"h": 38}, + "frame": + {"x": 117,"y": 0,"w": 39,"h": 38} }, { - "filename": "0094.png", + "filename": "0006.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 182, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 40,"h": 37}, + "frame": + {"x": 156,"y": 0,"w": 40,"h": 37} }, { - "filename": "0088.png", + "filename": "0010.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 219, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 4,"w": 40,"h": 37}, + "frame": + {"x": 196,"y": 0,"w": 40,"h": 37} + }, + { + "filename": "0035.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 38,"h": 38}, + "frame": + {"x": 236,"y": 0,"w": 38,"h": 38} + }, + { + "filename": "0018.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 0,"w": 40,"h": 37}, + "frame": + {"x": 156,"y": 37,"w": 40,"h": 37} + }, + { + "filename": "0021.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 3,"w": 40,"h": 37}, + "frame": + {"x": 196,"y": 37,"w": 40,"h": 37} + }, + { + "filename": "0039.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 21,"w": 38,"h": 38}, + "frame": + {"x": 236,"y": 38,"w": 38,"h": 38} + }, + { + "filename": "0024.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 6,"w": 40,"h": 37}, + "frame": + {"x": 0,"y": 38,"w": 40,"h": 37} + }, + { + "filename": "0045.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 18,"w": 38,"h": 38}, + "frame": + {"x": 40,"y": 38,"w": 38,"h": 38} + }, + { + "filename": "0047.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 38,"h": 38}, + "frame": + {"x": 0,"y": 75,"w": 38,"h": 38} + }, + { + "filename": "0001.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 38,"w": 39,"h": 37} + }, + { + "filename": "0002.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 13,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 38,"w": 39,"h": 37} + }, + { + "filename": "0004.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 11,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 38,"w": 39,"h": 37} + }, + { + "filename": "0049.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 16,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 38,"w": 39,"h": 37} + }, + { + "filename": "0005.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 156,"y": 74,"w": 39,"h": 37} + }, + { + "filename": "0008.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 7,"w": 39,"h": 37}, + "frame": + {"x": 195,"y": 74,"w": 39,"h": 37} + }, + { + "filename": "0009.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 5,"w": 39,"h": 37}, + "frame": + {"x": 234,"y": 76,"w": 39,"h": 37} + }, + { + "filename": "0011.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 3,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 75,"w": 39,"h": 37} + }, + { + "filename": "0012.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 75,"w": 39,"h": 37} + }, + { + "filename": "0014.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 37}, + "frame": + {"x": 38,"y": 76,"w": 39,"h": 37} + }, + { + "filename": "0017.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 37}, + "frame": + {"x": 156,"y": 111,"w": 39,"h": 37} + }, + { + "filename": "0019.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 1,"w": 39,"h": 37}, + "frame": + {"x": 195,"y": 111,"w": 39,"h": 37} + }, + { + "filename": "0022.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 4,"w": 39,"h": 37}, + "frame": + {"x": 234,"y": 113,"w": 39,"h": 37} + }, + { + "filename": "0025.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 7,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 112,"w": 39,"h": 37} + }, + { + "filename": "0026.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 112,"w": 39,"h": 37} + }, + { + "filename": "0027.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 155,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0028.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 194,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0029.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 11,"w": 39,"h": 37}, + "frame": + {"x": 233,"y": 150,"w": 39,"h": 37} + }, + { + "filename": "0030.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 12,"w": 39,"h": 37}, + "frame": + {"x": 0,"y": 113,"w": 39,"h": 37} + }, + { + "filename": "0038.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 21,"w": 38,"h": 37}, + "frame": + {"x": 39,"y": 113,"w": 38,"h": 37} + }, + { + "filename": "0031.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 149,"w": 39,"h": 37} + }, + { + "filename": "0032.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 149,"w": 39,"h": 37} + }, + { + "filename": "0033.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 15,"w": 39,"h": 37}, + "frame": + {"x": 155,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0034.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 17,"w": 39,"h": 37}, + "frame": + {"x": 194,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0037.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 20,"w": 39,"h": 37}, + "frame": + {"x": 233,"y": 187,"w": 39,"h": 37} + }, + { + "filename": "0046.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 18,"w": 39,"h": 37}, + "frame": + {"x": 0,"y": 150,"w": 39,"h": 37} + }, + { + "filename": "0042.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 22,"w": 38,"h": 37}, + "frame": + {"x": 39,"y": 150,"w": 38,"h": 37} + }, + { + "filename": "0048.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 186,"w": 39,"h": 37} + }, + { + "filename": "0050.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 15,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 186,"w": 39,"h": 37} + }, + { + "filename": "0020.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 3,"w": 40,"h": 36}, + "frame": + {"x": 155,"y": 222,"w": 40,"h": 36} + }, + { + "filename": "0043.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 21,"w": 38,"h": 37}, + "frame": + {"x": 195,"y": 222,"w": 38,"h": 37} + }, + { + "filename": "0003.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 12,"w": 39,"h": 36}, + "frame": + {"x": 233,"y": 224,"w": 39,"h": 36} + }, + { + "filename": "0007.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 39,"h": 36}, + "frame": + {"x": 0,"y": 187,"w": 39,"h": 36} + }, + { + "filename": "0041.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 24,"w": 38,"h": 36}, + "frame": + {"x": 39,"y": 187,"w": 38,"h": 36} + }, + { + "filename": "0015.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 36}, + "frame": + {"x": 0,"y": 223,"w": 39,"h": 36} + }, + { + "filename": "0016.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 36}, + "frame": + {"x": 39,"y": 223,"w": 39,"h": 36} + }, + { + "filename": "0023.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 5,"w": 39,"h": 36}, + "frame": + {"x": 78,"y": 223,"w": 39,"h": 36} } ] } ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:9220bd7e64b3b998c1dda01f5e530505:24317794261a2e3fc3206fefaa4fe6f5:44d5ed9bf64302a0edf6c65ea8033c12$" - } + "meta": + {"app": "https://www.codeandweb.com/texturepacker", + "version": "3.0"} } diff --git a/public/images/pokemon/exp/shiny/774-orange.png b/public/images/pokemon/exp/shiny/774-orange.png index 4edcc654418..f19ec226224 100644 Binary files a/public/images/pokemon/exp/shiny/774-orange.png and b/public/images/pokemon/exp/shiny/774-orange.png differ diff --git a/public/images/pokemon/exp/shiny/774-red.json b/public/images/pokemon/exp/shiny/774-red.json index 3d3ca604862..bba5c5e837f 100644 --- a/public/images/pokemon/exp/shiny/774-red.json +++ b/public/images/pokemon/exp/shiny/774-red.json @@ -3,1992 +3,563 @@ { "image": "774-red.png", "format": "RGBA8888", - "size": { - "w": 258, - "h": 258 - }, + "size": {"w": 274, "h": 274}, "scale": 1, "frames": [ { - "filename": "0017.png", + "filename": "0013.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 6, - "w": 40, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 40, - "h": 40 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 6, - "w": 40, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 40, - "h": 40 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 6, - "w": 40, - "h": 40 - }, - "frame": { - "x": 0, - "y": 40, - "w": 40, - "h": 40 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 6, - "w": 40, - "h": 40 - }, - "frame": { - "x": 0, - "y": 40, - "w": 40, - "h": 40 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 0, - "w": 40, - "h": 39 - }, - "frame": { - "x": 40, - "y": 0, - "w": 40, - "h": 39 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 0, - "w": 40, - "h": 39 - }, - "frame": { - "x": 40, - "y": 0, - "w": 40, - "h": 39 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 39, - "h": 40 - }, - "frame": { - "x": 0, - "y": 80, - "w": 39, - "h": 40 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 39, - "h": 40 - }, - "frame": { - "x": 0, - "y": 80, - "w": 39, - "h": 40 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 39, - "h": 40 - }, - "frame": { - "x": 40, - "y": 39, - "w": 39, - "h": 40 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 39, - "h": 40 - }, - "frame": { - "x": 40, - "y": 39, - "w": 39, - "h": 40 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 0, - "w": 40, - "h": 39 - }, - "frame": { - "x": 80, - "y": 0, - "w": 40, - "h": 39 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 0, - "w": 40, - "h": 39 - }, - "frame": { - "x": 80, - "y": 0, - "w": 40, - "h": 39 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 39, - "h": 40 - }, - "frame": { - "x": 0, - "y": 120, - "w": 39, - "h": 40 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 39, - "h": 40 - }, - "frame": { - "x": 0, - "y": 120, - "w": 39, - "h": 40 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 1,"w": 39,"h": 38}, + "frame": + {"x": 0,"y": 0,"w": 39,"h": 38} }, { "filename": "0036.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 39, - "h": 40 - }, - "frame": { - "x": 79, - "y": 39, - "w": 39, - "h": 40 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 39, - "h": 40 - }, - "frame": { - "x": 79, - "y": 39, - "w": 39, - "h": 40 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 26, - "y": 11, - "w": 40, - "h": 39 - }, - "frame": { - "x": 120, - "y": 0, - "w": 40, - "h": 39 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 26, - "y": 11, - "w": 40, - "h": 39 - }, - "frame": { - "x": 120, - "y": 0, - "w": 40, - "h": 39 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 8, - "w": 42, - "h": 36 - }, - "frame": { - "x": 118, - "y": 39, - "w": 42, - "h": 36 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 41, - "y": 11, - "w": 42, - "h": 36 - }, - "frame": { - "x": 160, - "y": 0, - "w": 42, - "h": 36 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 41, - "y": 11, - "w": 42, - "h": 36 - }, - "frame": { - "x": 160, - "y": 0, - "w": 42, - "h": 36 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 41, - "y": 11, - "w": 42, - "h": 36 - }, - "frame": { - "x": 160, - "y": 0, - "w": 42, - "h": 36 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 41, - "y": 11, - "w": 42, - "h": 36 - }, - "frame": { - "x": 160, - "y": 0, - "w": 42, - "h": 36 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 8, - "w": 42, - "h": 36 - }, - "frame": { - "x": 160, - "y": 36, - "w": 42, - "h": 36 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 8, - "w": 42, - "h": 36 - }, - "frame": { - "x": 160, - "y": 36, - "w": 42, - "h": 36 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 8, - "w": 42, - "h": 36 - }, - "frame": { - "x": 160, - "y": 36, - "w": 42, - "h": 36 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 13, - "w": 42, - "h": 36 - }, - "frame": { - "x": 202, - "y": 0, - "w": 42, - "h": 36 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 13, - "w": 42, - "h": 36 - }, - "frame": { - "x": 202, - "y": 0, - "w": 42, - "h": 36 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 43, - "y": 9, - "w": 41, - "h": 36 - }, - "frame": { - "x": 202, - "y": 36, - "w": 41, - "h": 36 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 43, - "y": 9, - "w": 41, - "h": 36 - }, - "frame": { - "x": 202, - "y": 36, - "w": 41, - "h": 36 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 43, - "y": 9, - "w": 41, - "h": 36 - }, - "frame": { - "x": 202, - "y": 36, - "w": 41, - "h": 36 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 43, - "y": 9, - "w": 41, - "h": 36 - }, - "frame": { - "x": 202, - "y": 36, - "w": 41, - "h": 36 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 160, - "w": 39, - "h": 38 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 160, - "w": 39, - "h": 38 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 1, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 198, - "w": 39, - "h": 38 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 9, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 198, - "w": 39, - "h": 38 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 1, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 198, - "w": 39, - "h": 38 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 9, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 198, - "w": 39, - "h": 38 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 37, - "y": 15, - "w": 42, - "h": 35 - }, - "frame": { - "x": 118, - "y": 75, - "w": 42, - "h": 35 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 37, - "y": 15, - "w": 42, - "h": 35 - }, - "frame": { - "x": 118, - "y": 75, - "w": 42, - "h": 35 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 43, - "y": 9, - "w": 41, - "h": 36 - }, - "frame": { - "x": 160, - "y": 72, - "w": 41, - "h": 36 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 43, - "y": 9, - "w": 41, - "h": 36 - }, - "frame": { - "x": 160, - "y": 72, - "w": 41, - "h": 36 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 43, - "y": 9, - "w": 41, - "h": 36 - }, - "frame": { - "x": 160, - "y": 72, - "w": 41, - "h": 36 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 43, - "y": 9, - "w": 41, - "h": 36 - }, - "frame": { - "x": 160, - "y": 72, - "w": 41, - "h": 36 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 37, - "y": 15, - "w": 42, - "h": 35 - }, - "frame": { - "x": 201, - "y": 72, - "w": 42, - "h": 35 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 37, - "y": 15, - "w": 42, - "h": 35 - }, - "frame": { - "x": 201, - "y": 72, - "w": 42, - "h": 35 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 160, - "y": 108, - "w": 39, - "h": 37 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 160, - "y": 108, - "w": 39, - "h": 37 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 160, - "y": 108, - "w": 39, - "h": 37 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 40, - "y": 79, - "w": 39, - "h": 37 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 40, - "y": 79, - "w": 39, - "h": 37 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 40, - "y": 79, - "w": 39, - "h": 37 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 25, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 79, - "y": 79, - "w": 39, - "h": 37 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 25, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 79, - "y": 79, - "w": 39, - "h": 37 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 9, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 116, - "w": 39, - "h": 38 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 1, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 116, - "w": 39, - "h": 38 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 9, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 116, - "w": 39, - "h": 38 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 1, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 116, - "w": 39, - "h": 38 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 154, - "w": 39, - "h": 38 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 154, - "w": 39, - "h": 38 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 38 - }, - "frame": { - "x": 78, - "y": 116, - "w": 39, - "h": 38 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 38 - }, - "frame": { - "x": 78, - "y": 116, - "w": 39, - "h": 38 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 29, - "y": 11, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 192, - "w": 39, - "h": 38 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 34, - "y": 3, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 154, - "w": 39, - "h": 37 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 34, - "y": 3, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 154, - "w": 39, - "h": 37 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 30, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 191, - "w": 39, - "h": 37 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 30, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 191, - "w": 39, - "h": 37 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 118, - "y": 110, - "w": 39, - "h": 37 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 118, - "y": 110, - "w": 39, - "h": 37 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 118, - "y": 110, - "w": 39, - "h": 37 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 20, - "y": 9, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 147, - "w": 39, - "h": 37 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 20, - "y": 9, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 147, - "w": 39, - "h": 37 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 20, - "y": 9, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 184, - "w": 39, - "h": 37 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 20, - "y": 9, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 184, - "w": 39, - "h": 37 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 25, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 221, - "w": 39, - "h": 37 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 25, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 221, - "w": 39, - "h": 37 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 34, - "y": 3, - "w": 39, - "h": 37 - }, - "frame": { - "x": 201, - "y": 107, - "w": 39, - "h": 37 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 34, - "y": 3, - "w": 39, - "h": 37 - }, - "frame": { - "x": 201, - "y": 107, - "w": 39, - "h": 37 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 30, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 157, - "y": 145, - "w": 39, - "h": 37 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 30, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 157, - "y": 145, - "w": 39, - "h": 37 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 20, - "y": 9, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 182, - "w": 39, - "h": 37 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 20, - "y": 9, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 182, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 18,"w": 39,"h": 38}, + "frame": + {"x": 39,"y": 0,"w": 39,"h": 38} }, { "filename": "0040.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 20, - "y": 9, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 219, - "w": 39, - "h": 37 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 20, - "y": 9, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 219, - "w": 39, - "h": 37 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 196, - "y": 145, - "w": 39, - "h": 37 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 196, - "y": 145, - "w": 39, - "h": 37 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 196, - "y": 145, - "w": 39, - "h": 37 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 196, - "y": 145, - "w": 39, - "h": 37 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 196, - "y": 145, - "w": 39, - "h": 37 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 196, - "y": 145, - "w": 39, - "h": 37 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 196, - "y": 145, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 22,"w": 39,"h": 38}, + "frame": + {"x": 78,"y": 0,"w": 39,"h": 38} }, { "filename": "0044.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 182, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 20,"w": 39,"h": 38}, + "frame": + {"x": 117,"y": 0,"w": 39,"h": 38} }, { - "filename": "0094.png", + "filename": "0006.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 182, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 40,"h": 37}, + "frame": + {"x": 156,"y": 0,"w": 40,"h": 37} }, { - "filename": "0088.png", + "filename": "0010.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 219, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 4,"w": 40,"h": 37}, + "frame": + {"x": 196,"y": 0,"w": 40,"h": 37} + }, + { + "filename": "0035.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 38,"h": 38}, + "frame": + {"x": 236,"y": 0,"w": 38,"h": 38} + }, + { + "filename": "0018.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 0,"w": 40,"h": 37}, + "frame": + {"x": 156,"y": 37,"w": 40,"h": 37} + }, + { + "filename": "0021.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 3,"w": 40,"h": 37}, + "frame": + {"x": 196,"y": 37,"w": 40,"h": 37} + }, + { + "filename": "0039.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 21,"w": 38,"h": 38}, + "frame": + {"x": 236,"y": 38,"w": 38,"h": 38} + }, + { + "filename": "0024.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 6,"w": 40,"h": 37}, + "frame": + {"x": 0,"y": 38,"w": 40,"h": 37} + }, + { + "filename": "0045.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 18,"w": 38,"h": 38}, + "frame": + {"x": 40,"y": 38,"w": 38,"h": 38} + }, + { + "filename": "0047.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 38,"h": 38}, + "frame": + {"x": 0,"y": 75,"w": 38,"h": 38} + }, + { + "filename": "0001.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 38,"w": 39,"h": 37} + }, + { + "filename": "0002.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 13,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 38,"w": 39,"h": 37} + }, + { + "filename": "0004.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 11,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 38,"w": 39,"h": 37} + }, + { + "filename": "0049.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 16,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 38,"w": 39,"h": 37} + }, + { + "filename": "0005.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 156,"y": 74,"w": 39,"h": 37} + }, + { + "filename": "0008.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 7,"w": 39,"h": 37}, + "frame": + {"x": 195,"y": 74,"w": 39,"h": 37} + }, + { + "filename": "0009.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 5,"w": 39,"h": 37}, + "frame": + {"x": 234,"y": 76,"w": 39,"h": 37} + }, + { + "filename": "0011.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 3,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 75,"w": 39,"h": 37} + }, + { + "filename": "0012.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 75,"w": 39,"h": 37} + }, + { + "filename": "0014.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 37}, + "frame": + {"x": 38,"y": 76,"w": 39,"h": 37} + }, + { + "filename": "0017.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 37}, + "frame": + {"x": 156,"y": 111,"w": 39,"h": 37} + }, + { + "filename": "0019.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 1,"w": 39,"h": 37}, + "frame": + {"x": 195,"y": 111,"w": 39,"h": 37} + }, + { + "filename": "0022.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 4,"w": 39,"h": 37}, + "frame": + {"x": 234,"y": 113,"w": 39,"h": 37} + }, + { + "filename": "0025.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 7,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 112,"w": 39,"h": 37} + }, + { + "filename": "0026.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 112,"w": 39,"h": 37} + }, + { + "filename": "0027.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 155,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0028.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 194,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0029.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 11,"w": 39,"h": 37}, + "frame": + {"x": 233,"y": 150,"w": 39,"h": 37} + }, + { + "filename": "0030.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 12,"w": 39,"h": 37}, + "frame": + {"x": 0,"y": 113,"w": 39,"h": 37} + }, + { + "filename": "0038.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 21,"w": 38,"h": 37}, + "frame": + {"x": 39,"y": 113,"w": 38,"h": 37} + }, + { + "filename": "0031.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 149,"w": 39,"h": 37} + }, + { + "filename": "0032.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 149,"w": 39,"h": 37} + }, + { + "filename": "0033.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 15,"w": 39,"h": 37}, + "frame": + {"x": 155,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0034.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 17,"w": 39,"h": 37}, + "frame": + {"x": 194,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0037.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 20,"w": 39,"h": 37}, + "frame": + {"x": 233,"y": 187,"w": 39,"h": 37} + }, + { + "filename": "0046.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 18,"w": 39,"h": 37}, + "frame": + {"x": 0,"y": 150,"w": 39,"h": 37} + }, + { + "filename": "0042.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 22,"w": 38,"h": 37}, + "frame": + {"x": 39,"y": 150,"w": 38,"h": 37} + }, + { + "filename": "0048.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 186,"w": 39,"h": 37} + }, + { + "filename": "0050.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 15,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 186,"w": 39,"h": 37} + }, + { + "filename": "0020.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 3,"w": 40,"h": 36}, + "frame": + {"x": 155,"y": 222,"w": 40,"h": 36} + }, + { + "filename": "0043.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 21,"w": 38,"h": 37}, + "frame": + {"x": 195,"y": 222,"w": 38,"h": 37} + }, + { + "filename": "0003.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 12,"w": 39,"h": 36}, + "frame": + {"x": 233,"y": 224,"w": 39,"h": 36} + }, + { + "filename": "0007.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 39,"h": 36}, + "frame": + {"x": 0,"y": 187,"w": 39,"h": 36} + }, + { + "filename": "0041.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 24,"w": 38,"h": 36}, + "frame": + {"x": 39,"y": 187,"w": 38,"h": 36} + }, + { + "filename": "0015.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 36}, + "frame": + {"x": 0,"y": 223,"w": 39,"h": 36} + }, + { + "filename": "0016.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 36}, + "frame": + {"x": 39,"y": 223,"w": 39,"h": 36} + }, + { + "filename": "0023.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 5,"w": 39,"h": 36}, + "frame": + {"x": 78,"y": 223,"w": 39,"h": 36} } ] } ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:dc3952af7db09cd836a369dca41b99fe:f827e92a06528fa06113bbe2b63708a4:cda0147f4d676691e1699693bc0ee567$" - } + "meta": + {"app": "https://www.codeandweb.com/texturepacker", + "version": "3.0"} } diff --git a/public/images/pokemon/exp/shiny/774-red.png b/public/images/pokemon/exp/shiny/774-red.png index d04e4468df9..9992e1c495f 100644 Binary files a/public/images/pokemon/exp/shiny/774-red.png and b/public/images/pokemon/exp/shiny/774-red.png differ diff --git a/public/images/pokemon/exp/shiny/774-violet.json b/public/images/pokemon/exp/shiny/774-violet.json index 4a10eac8051..42c0105da2d 100644 --- a/public/images/pokemon/exp/shiny/774-violet.json +++ b/public/images/pokemon/exp/shiny/774-violet.json @@ -3,1068 +3,563 @@ { "image": "774-violet.png", "format": "RGBA8888", - "size": { - "w": 274, - "h": 274 - }, + "size": {"w": 274, "h": 274}, "scale": 1, "frames": [ { "filename": "0013.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 1, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 1,"w": 39,"h": 38}, + "frame": + {"x": 0,"y": 0,"w": 39,"h": 38} }, { "filename": "0036.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 18, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 18,"w": 39,"h": 38}, + "frame": + {"x": 39,"y": 0,"w": 39,"h": 38} }, { "filename": "0040.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 22, - "w": 39, - "h": 38 - }, - "frame": { - "x": 78, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 22,"w": 39,"h": 38}, + "frame": + {"x": 78,"y": 0,"w": 39,"h": 38} }, { "filename": "0044.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 20, - "w": 39, - "h": 38 - }, - "frame": { - "x": 117, - "y": 0, - "w": 39, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 20,"w": 39,"h": 38}, + "frame": + {"x": 117,"y": 0,"w": 39,"h": 38} }, { "filename": "0006.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 8, - "w": 40, - "h": 37 - }, - "frame": { - "x": 156, - "y": 0, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 40,"h": 37}, + "frame": + {"x": 156,"y": 0,"w": 40,"h": 37} }, { "filename": "0010.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 4, - "w": 40, - "h": 37 - }, - "frame": { - "x": 196, - "y": 0, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 4,"w": 40,"h": 37}, + "frame": + {"x": 196,"y": 0,"w": 40,"h": 37} }, { "filename": "0035.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 38, - "h": 38 - }, - "frame": { - "x": 236, - "y": 0, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 38,"h": 38}, + "frame": + {"x": 236,"y": 0,"w": 38,"h": 38} }, { "filename": "0018.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 40, - "h": 37 - }, - "frame": { - "x": 156, - "y": 37, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 0,"w": 40,"h": 37}, + "frame": + {"x": 156,"y": 37,"w": 40,"h": 37} }, { "filename": "0021.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 3, - "w": 40, - "h": 37 - }, - "frame": { - "x": 196, - "y": 37, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 3,"w": 40,"h": 37}, + "frame": + {"x": 196,"y": 37,"w": 40,"h": 37} }, { "filename": "0039.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 21, - "w": 38, - "h": 38 - }, - "frame": { - "x": 236, - "y": 38, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 21,"w": 38,"h": 38}, + "frame": + {"x": 236,"y": 38,"w": 38,"h": 38} }, { "filename": "0024.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 6, - "w": 40, - "h": 37 - }, - "frame": { - "x": 0, - "y": 38, - "w": 40, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 6,"w": 40,"h": 37}, + "frame": + {"x": 0,"y": 38,"w": 40,"h": 37} }, { "filename": "0045.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 38, - "h": 38 - }, - "frame": { - "x": 40, - "y": 38, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 18,"w": 38,"h": 38}, + "frame": + {"x": 40,"y": 38,"w": 38,"h": 38} }, { "filename": "0047.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 38, - "h": 38 - }, - "frame": { - "x": 0, - "y": 75, - "w": 38, - "h": 38 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 38,"h": 38}, + "frame": + {"x": 0,"y": 75,"w": 38,"h": 38} }, { "filename": "0001.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 14, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 38,"w": 39,"h": 37} }, { "filename": "0002.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 13, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 13,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 38,"w": 39,"h": 37} }, { "filename": "0004.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 11,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 38,"w": 39,"h": 37} }, { "filename": "0049.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 16, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 38, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 16,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 38,"w": 39,"h": 37} }, { "filename": "0005.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 156,"y": 74,"w": 39,"h": 37} }, { "filename": "0008.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 74, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 7,"w": 39,"h": 37}, + "frame": + {"x": 195,"y": 74,"w": 39,"h": 37} }, { "filename": "0009.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 5, - "w": 39, - "h": 37 - }, - "frame": { - "x": 234, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 5,"w": 39,"h": 37}, + "frame": + {"x": 234,"y": 76,"w": 39,"h": 37} }, { "filename": "0011.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 3, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 75, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 3,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 75,"w": 39,"h": 37} }, { "filename": "0012.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 2, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 75, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 75,"w": 39,"h": 37} }, { "filename": "0014.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 37 - }, - "frame": { - "x": 38, - "y": 76, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 37}, + "frame": + {"x": 38,"y": 76,"w": 39,"h": 37} }, { "filename": "0017.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 37}, + "frame": + {"x": 156,"y": 111,"w": 39,"h": 37} }, { "filename": "0019.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 1, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 111, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 1,"w": 39,"h": 37}, + "frame": + {"x": 195,"y": 111,"w": 39,"h": 37} }, { "filename": "0022.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 4, - "w": 39, - "h": 37 - }, - "frame": { - "x": 234, - "y": 113, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 4,"w": 39,"h": 37}, + "frame": + {"x": 234,"y": 113,"w": 39,"h": 37} }, { "filename": "0025.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 7, - "w": 39, - "h": 37 - }, - "frame": { - "x": 77, - "y": 112, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 7,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 112,"w": 39,"h": 37} }, { "filename": "0026.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 116, - "y": 112, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 112,"w": 39,"h": 37} }, { "filename": "0027.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 155, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 155,"y": 148,"w": 39,"h": 37} }, { "filename": "0028.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 10, - "w": 39, - "h": 37 - }, - "frame": { - "x": 194, - "y": 148, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 194,"y": 148,"w": 39,"h": 37} }, { "filename": "0029.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 233, - "y": 150, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 11,"w": 39,"h": 37}, + "frame": + {"x": 233,"y": 150,"w": 39,"h": 37} }, { "filename": "0030.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 12, - "w": 39, - "h": 37 - }, - "frame": { - "x": 0, - "y": 113, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 12,"w": 39,"h": 37}, + "frame": + {"x": 0,"y": 113,"w": 39,"h": 37} }, { "filename": "0038.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 21, - "w": 38, - "h": 37 - }, - "frame": { - "x": 39, - "y": 113, - "w": 38, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 21,"w": 38,"h": 37}, + "frame": + {"x": 39,"y": 113,"w": 38,"h": 37} }, { "filename": "0031.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 14, - "w": 39, - "h": 37 - }, - "frame": { - "x": 77, - "y": 149, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 149,"w": 39,"h": 37} }, { "filename": "0032.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 14, - "w": 39, - "h": 37 - }, - "frame": { - "x": 116, - "y": 149, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 149,"w": 39,"h": 37} }, { "filename": "0033.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 15, - "w": 39, - "h": 37 - }, - "frame": { - "x": 155, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 15,"w": 39,"h": 37}, + "frame": + {"x": 155,"y": 185,"w": 39,"h": 37} }, { "filename": "0034.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 17, - "w": 39, - "h": 37 - }, - "frame": { - "x": 194, - "y": 185, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 17,"w": 39,"h": 37}, + "frame": + {"x": 194,"y": 185,"w": 39,"h": 37} }, { "filename": "0037.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 20, - "w": 39, - "h": 37 - }, - "frame": { - "x": 233, - "y": 187, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 20,"w": 39,"h": 37}, + "frame": + {"x": 233,"y": 187,"w": 39,"h": 37} }, { "filename": "0046.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 39, - "h": 37 - }, - "frame": { - "x": 0, - "y": 150, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 18,"w": 39,"h": 37}, + "frame": + {"x": 0,"y": 150,"w": 39,"h": 37} }, { "filename": "0042.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 22, - "w": 38, - "h": 37 - }, - "frame": { - "x": 39, - "y": 150, - "w": 38, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 22,"w": 38,"h": 37}, + "frame": + {"x": 39,"y": 150,"w": 38,"h": 37} }, { "filename": "0048.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 39, - "h": 37 - }, - "frame": { - "x": 77, - "y": 186, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 186,"w": 39,"h": 37} }, { "filename": "0050.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 15, - "w": 39, - "h": 37 - }, - "frame": { - "x": 116, - "y": 186, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 15,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 186,"w": 39,"h": 37} }, { "filename": "0020.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 3, - "w": 40, - "h": 36 - }, - "frame": { - "x": 155, - "y": 222, - "w": 40, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 3,"w": 40,"h": 36}, + "frame": + {"x": 155,"y": 222,"w": 40,"h": 36} }, { "filename": "0043.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 21, - "w": 38, - "h": 37 - }, - "frame": { - "x": 195, - "y": 222, - "w": 38, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 21,"w": 38,"h": 37}, + "frame": + {"x": 195,"y": 222,"w": 38,"h": 37} }, { "filename": "0003.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 1, - "y": 12, - "w": 39, - "h": 36 - }, - "frame": { - "x": 233, - "y": 224, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 12,"w": 39,"h": 36}, + "frame": + {"x": 233,"y": 224,"w": 39,"h": 36} }, { "filename": "0007.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 8, - "w": 39, - "h": 36 - }, - "frame": { - "x": 0, - "y": 187, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 39,"h": 36}, + "frame": + {"x": 0,"y": 187,"w": 39,"h": 36} }, { "filename": "0041.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 0, - "y": 24, - "w": 38, - "h": 36 - }, - "frame": { - "x": 39, - "y": 187, - "w": 38, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 24,"w": 38,"h": 36}, + "frame": + {"x": 39,"y": 187,"w": 38,"h": 36} }, { "filename": "0015.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 36 - }, - "frame": { - "x": 0, - "y": 223, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 36}, + "frame": + {"x": 0,"y": 223,"w": 39,"h": 36} }, { "filename": "0016.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 39, - "h": 36 - }, - "frame": { - "x": 39, - "y": 223, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 36}, + "frame": + {"x": 39,"y": 223,"w": 39,"h": 36} }, { "filename": "0023.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 42, - "h": 60 - }, - "spriteSourceSize": { - "x": 2, - "y": 5, - "w": 39, - "h": 36 - }, - "frame": { - "x": 78, - "y": 223, - "w": 39, - "h": 36 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 5,"w": 39,"h": 36}, + "frame": + {"x": 78,"y": 223,"w": 39,"h": 36} } ] } ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:995bddce8cd8d4c2676ac6cfc46fdc00:2a6b34947247eb150e2ebd7d9b5aa73c:cafe7bbce21f2b95187ef35011084eca$" - } + "meta": + {"app": "https://www.codeandweb.com/texturepacker", + "version": "3.0"} } diff --git a/public/images/pokemon/exp/shiny/774-violet.png b/public/images/pokemon/exp/shiny/774-violet.png index d0721c118a0..3e1b3411da8 100644 Binary files a/public/images/pokemon/exp/shiny/774-violet.png and b/public/images/pokemon/exp/shiny/774-violet.png differ diff --git a/public/images/pokemon/exp/shiny/774-yellow.json b/public/images/pokemon/exp/shiny/774-yellow.json index 212302a9678..6f5d0a8121c 100644 --- a/public/images/pokemon/exp/shiny/774-yellow.json +++ b/public/images/pokemon/exp/shiny/774-yellow.json @@ -3,1992 +3,563 @@ { "image": "774-yellow.png", "format": "RGBA8888", - "size": { - "w": 258, - "h": 258 - }, + "size": {"w": 274, "h": 274}, "scale": 1, "frames": [ { - "filename": "0017.png", + "filename": "0013.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 6, - "w": 40, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 40, - "h": 40 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 6, - "w": 40, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 40, - "h": 40 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 6, - "w": 40, - "h": 40 - }, - "frame": { - "x": 0, - "y": 40, - "w": 40, - "h": 40 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 6, - "w": 40, - "h": 40 - }, - "frame": { - "x": 0, - "y": 40, - "w": 40, - "h": 40 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 0, - "w": 40, - "h": 39 - }, - "frame": { - "x": 40, - "y": 0, - "w": 40, - "h": 39 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 0, - "w": 40, - "h": 39 - }, - "frame": { - "x": 40, - "y": 0, - "w": 40, - "h": 39 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 39, - "h": 40 - }, - "frame": { - "x": 0, - "y": 80, - "w": 39, - "h": 40 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 39, - "h": 40 - }, - "frame": { - "x": 0, - "y": 80, - "w": 39, - "h": 40 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 39, - "h": 40 - }, - "frame": { - "x": 40, - "y": 39, - "w": 39, - "h": 40 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 39, - "h": 40 - }, - "frame": { - "x": 40, - "y": 39, - "w": 39, - "h": 40 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 0, - "w": 40, - "h": 39 - }, - "frame": { - "x": 80, - "y": 0, - "w": 40, - "h": 39 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 1, - "y": 0, - "w": 40, - "h": 39 - }, - "frame": { - "x": 80, - "y": 0, - "w": 40, - "h": 39 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 39, - "h": 40 - }, - "frame": { - "x": 0, - "y": 120, - "w": 39, - "h": 40 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 39, - "h": 40 - }, - "frame": { - "x": 0, - "y": 120, - "w": 39, - "h": 40 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 1,"w": 39,"h": 38}, + "frame": + {"x": 0,"y": 0,"w": 39,"h": 38} }, { "filename": "0036.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 39, - "h": 40 - }, - "frame": { - "x": 79, - "y": 39, - "w": 39, - "h": 40 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 39, - "h": 40 - }, - "frame": { - "x": 79, - "y": 39, - "w": 39, - "h": 40 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 26, - "y": 11, - "w": 40, - "h": 39 - }, - "frame": { - "x": 120, - "y": 0, - "w": 40, - "h": 39 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 26, - "y": 11, - "w": 40, - "h": 39 - }, - "frame": { - "x": 120, - "y": 0, - "w": 40, - "h": 39 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 8, - "w": 42, - "h": 36 - }, - "frame": { - "x": 118, - "y": 39, - "w": 42, - "h": 36 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 41, - "y": 11, - "w": 42, - "h": 36 - }, - "frame": { - "x": 160, - "y": 0, - "w": 42, - "h": 36 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 41, - "y": 11, - "w": 42, - "h": 36 - }, - "frame": { - "x": 160, - "y": 0, - "w": 42, - "h": 36 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 41, - "y": 11, - "w": 42, - "h": 36 - }, - "frame": { - "x": 160, - "y": 0, - "w": 42, - "h": 36 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 41, - "y": 11, - "w": 42, - "h": 36 - }, - "frame": { - "x": 160, - "y": 0, - "w": 42, - "h": 36 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 8, - "w": 42, - "h": 36 - }, - "frame": { - "x": 160, - "y": 36, - "w": 42, - "h": 36 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 8, - "w": 42, - "h": 36 - }, - "frame": { - "x": 160, - "y": 36, - "w": 42, - "h": 36 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 42, - "y": 8, - "w": 42, - "h": 36 - }, - "frame": { - "x": 160, - "y": 36, - "w": 42, - "h": 36 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 13, - "w": 42, - "h": 36 - }, - "frame": { - "x": 202, - "y": 0, - "w": 42, - "h": 36 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 13, - "w": 42, - "h": 36 - }, - "frame": { - "x": 202, - "y": 0, - "w": 42, - "h": 36 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 43, - "y": 9, - "w": 41, - "h": 36 - }, - "frame": { - "x": 202, - "y": 36, - "w": 41, - "h": 36 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 43, - "y": 9, - "w": 41, - "h": 36 - }, - "frame": { - "x": 202, - "y": 36, - "w": 41, - "h": 36 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 43, - "y": 9, - "w": 41, - "h": 36 - }, - "frame": { - "x": 202, - "y": 36, - "w": 41, - "h": 36 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 43, - "y": 9, - "w": 41, - "h": 36 - }, - "frame": { - "x": 202, - "y": 36, - "w": 41, - "h": 36 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 160, - "w": 39, - "h": 38 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 160, - "w": 39, - "h": 38 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 1, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 198, - "w": 39, - "h": 38 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 9, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 198, - "w": 39, - "h": 38 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 1, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 198, - "w": 39, - "h": 38 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 9, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 198, - "w": 39, - "h": 38 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 37, - "y": 15, - "w": 42, - "h": 35 - }, - "frame": { - "x": 118, - "y": 75, - "w": 42, - "h": 35 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 37, - "y": 15, - "w": 42, - "h": 35 - }, - "frame": { - "x": 118, - "y": 75, - "w": 42, - "h": 35 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 43, - "y": 9, - "w": 41, - "h": 36 - }, - "frame": { - "x": 160, - "y": 72, - "w": 41, - "h": 36 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 43, - "y": 9, - "w": 41, - "h": 36 - }, - "frame": { - "x": 160, - "y": 72, - "w": 41, - "h": 36 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 43, - "y": 9, - "w": 41, - "h": 36 - }, - "frame": { - "x": 160, - "y": 72, - "w": 41, - "h": 36 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 43, - "y": 9, - "w": 41, - "h": 36 - }, - "frame": { - "x": 160, - "y": 72, - "w": 41, - "h": 36 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 37, - "y": 15, - "w": 42, - "h": 35 - }, - "frame": { - "x": 201, - "y": 72, - "w": 42, - "h": 35 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 37, - "y": 15, - "w": 42, - "h": 35 - }, - "frame": { - "x": 201, - "y": 72, - "w": 42, - "h": 35 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 160, - "y": 108, - "w": 39, - "h": 37 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 160, - "y": 108, - "w": 39, - "h": 37 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 160, - "y": 108, - "w": 39, - "h": 37 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 40, - "y": 79, - "w": 39, - "h": 37 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 40, - "y": 79, - "w": 39, - "h": 37 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 40, - "y": 79, - "w": 39, - "h": 37 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 25, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 79, - "y": 79, - "w": 39, - "h": 37 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 25, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 79, - "y": 79, - "w": 39, - "h": 37 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 9, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 116, - "w": 39, - "h": 38 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 1, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 116, - "w": 39, - "h": 38 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 6, - "y": 9, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 116, - "w": 39, - "h": 38 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 13, - "y": 1, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 116, - "w": 39, - "h": 38 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 154, - "w": 39, - "h": 38 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 154, - "w": 39, - "h": 38 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 38 - }, - "frame": { - "x": 78, - "y": 116, - "w": 39, - "h": 38 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 38 - }, - "frame": { - "x": 78, - "y": 116, - "w": 39, - "h": 38 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 29, - "y": 11, - "w": 39, - "h": 38 - }, - "frame": { - "x": 39, - "y": 192, - "w": 39, - "h": 38 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 34, - "y": 3, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 154, - "w": 39, - "h": 37 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 34, - "y": 3, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 154, - "w": 39, - "h": 37 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 30, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 191, - "w": 39, - "h": 37 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 30, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 78, - "y": 191, - "w": 39, - "h": 37 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 118, - "y": 110, - "w": 39, - "h": 37 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 118, - "y": 110, - "w": 39, - "h": 37 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 28, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 118, - "y": 110, - "w": 39, - "h": 37 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 20, - "y": 9, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 147, - "w": 39, - "h": 37 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 20, - "y": 9, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 147, - "w": 39, - "h": 37 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 20, - "y": 9, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 184, - "w": 39, - "h": 37 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 20, - "y": 9, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 184, - "w": 39, - "h": 37 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 25, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 221, - "w": 39, - "h": 37 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 25, - "y": 6, - "w": 39, - "h": 37 - }, - "frame": { - "x": 117, - "y": 221, - "w": 39, - "h": 37 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 34, - "y": 3, - "w": 39, - "h": 37 - }, - "frame": { - "x": 201, - "y": 107, - "w": 39, - "h": 37 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 34, - "y": 3, - "w": 39, - "h": 37 - }, - "frame": { - "x": 201, - "y": 107, - "w": 39, - "h": 37 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 30, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 157, - "y": 145, - "w": 39, - "h": 37 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 30, - "y": 11, - "w": 39, - "h": 37 - }, - "frame": { - "x": 157, - "y": 145, - "w": 39, - "h": 37 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 20, - "y": 9, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 182, - "w": 39, - "h": 37 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 20, - "y": 9, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 182, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 18,"w": 39,"h": 38}, + "frame": + {"x": 39,"y": 0,"w": 39,"h": 38} }, { "filename": "0040.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 20, - "y": 9, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 219, - "w": 39, - "h": 37 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 20, - "y": 9, - "w": 39, - "h": 37 - }, - "frame": { - "x": 156, - "y": 219, - "w": 39, - "h": 37 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 196, - "y": 145, - "w": 39, - "h": 37 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 196, - "y": 145, - "w": 39, - "h": 37 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 196, - "y": 145, - "w": 39, - "h": 37 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 196, - "y": 145, - "w": 39, - "h": 37 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 196, - "y": 145, - "w": 39, - "h": 37 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 196, - "y": 145, - "w": 39, - "h": 37 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 196, - "y": 145, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 22,"w": 39,"h": 38}, + "frame": + {"x": 78,"y": 0,"w": 39,"h": 38} }, { "filename": "0044.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 182, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 20,"w": 39,"h": 38}, + "frame": + {"x": 117,"y": 0,"w": 39,"h": 38} }, { - "filename": "0094.png", + "filename": "0006.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 182, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 40,"h": 37}, + "frame": + {"x": 156,"y": 0,"w": 40,"h": 37} }, { - "filename": "0088.png", + "filename": "0010.png", "rotated": false, "trimmed": true, - "sourceSize": { - "w": 84, - "h": 50 - }, - "spriteSourceSize": { - "x": 24, - "y": 8, - "w": 39, - "h": 37 - }, - "frame": { - "x": 195, - "y": 219, - "w": 39, - "h": 37 - } + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 4,"w": 40,"h": 37}, + "frame": + {"x": 196,"y": 0,"w": 40,"h": 37} + }, + { + "filename": "0035.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 38,"h": 38}, + "frame": + {"x": 236,"y": 0,"w": 38,"h": 38} + }, + { + "filename": "0018.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 0,"w": 40,"h": 37}, + "frame": + {"x": 156,"y": 37,"w": 40,"h": 37} + }, + { + "filename": "0021.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 3,"w": 40,"h": 37}, + "frame": + {"x": 196,"y": 37,"w": 40,"h": 37} + }, + { + "filename": "0039.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 21,"w": 38,"h": 38}, + "frame": + {"x": 236,"y": 38,"w": 38,"h": 38} + }, + { + "filename": "0024.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 6,"w": 40,"h": 37}, + "frame": + {"x": 0,"y": 38,"w": 40,"h": 37} + }, + { + "filename": "0045.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 18,"w": 38,"h": 38}, + "frame": + {"x": 40,"y": 38,"w": 38,"h": 38} + }, + { + "filename": "0047.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 38,"h": 38}, + "frame": + {"x": 0,"y": 75,"w": 38,"h": 38} + }, + { + "filename": "0001.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 38,"w": 39,"h": 37} + }, + { + "filename": "0002.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 13,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 38,"w": 39,"h": 37} + }, + { + "filename": "0004.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 11,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 38,"w": 39,"h": 37} + }, + { + "filename": "0049.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 16,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 38,"w": 39,"h": 37} + }, + { + "filename": "0005.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 156,"y": 74,"w": 39,"h": 37} + }, + { + "filename": "0008.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 7,"w": 39,"h": 37}, + "frame": + {"x": 195,"y": 74,"w": 39,"h": 37} + }, + { + "filename": "0009.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 5,"w": 39,"h": 37}, + "frame": + {"x": 234,"y": 76,"w": 39,"h": 37} + }, + { + "filename": "0011.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 3,"w": 39,"h": 37}, + "frame": + {"x": 78,"y": 75,"w": 39,"h": 37} + }, + { + "filename": "0012.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 2,"w": 39,"h": 37}, + "frame": + {"x": 117,"y": 75,"w": 39,"h": 37} + }, + { + "filename": "0014.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 37}, + "frame": + {"x": 38,"y": 76,"w": 39,"h": 37} + }, + { + "filename": "0017.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 37}, + "frame": + {"x": 156,"y": 111,"w": 39,"h": 37} + }, + { + "filename": "0019.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 1,"w": 39,"h": 37}, + "frame": + {"x": 195,"y": 111,"w": 39,"h": 37} + }, + { + "filename": "0022.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 4,"w": 39,"h": 37}, + "frame": + {"x": 234,"y": 113,"w": 39,"h": 37} + }, + { + "filename": "0025.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 7,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 112,"w": 39,"h": 37} + }, + { + "filename": "0026.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 112,"w": 39,"h": 37} + }, + { + "filename": "0027.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 155,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0028.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 10,"w": 39,"h": 37}, + "frame": + {"x": 194,"y": 148,"w": 39,"h": 37} + }, + { + "filename": "0029.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 11,"w": 39,"h": 37}, + "frame": + {"x": 233,"y": 150,"w": 39,"h": 37} + }, + { + "filename": "0030.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 12,"w": 39,"h": 37}, + "frame": + {"x": 0,"y": 113,"w": 39,"h": 37} + }, + { + "filename": "0038.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 21,"w": 38,"h": 37}, + "frame": + {"x": 39,"y": 113,"w": 38,"h": 37} + }, + { + "filename": "0031.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 149,"w": 39,"h": 37} + }, + { + "filename": "0032.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 14,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 149,"w": 39,"h": 37} + }, + { + "filename": "0033.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 15,"w": 39,"h": 37}, + "frame": + {"x": 155,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0034.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 17,"w": 39,"h": 37}, + "frame": + {"x": 194,"y": 185,"w": 39,"h": 37} + }, + { + "filename": "0037.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 20,"w": 39,"h": 37}, + "frame": + {"x": 233,"y": 187,"w": 39,"h": 37} + }, + { + "filename": "0046.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 18,"w": 39,"h": 37}, + "frame": + {"x": 0,"y": 150,"w": 39,"h": 37} + }, + { + "filename": "0042.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 22,"w": 38,"h": 37}, + "frame": + {"x": 39,"y": 150,"w": 38,"h": 37} + }, + { + "filename": "0048.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 17,"w": 39,"h": 37}, + "frame": + {"x": 77,"y": 186,"w": 39,"h": 37} + }, + { + "filename": "0050.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 15,"w": 39,"h": 37}, + "frame": + {"x": 116,"y": 186,"w": 39,"h": 37} + }, + { + "filename": "0020.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 3,"w": 40,"h": 36}, + "frame": + {"x": 155,"y": 222,"w": 40,"h": 36} + }, + { + "filename": "0043.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 21,"w": 38,"h": 37}, + "frame": + {"x": 195,"y": 222,"w": 38,"h": 37} + }, + { + "filename": "0003.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 1,"y": 12,"w": 39,"h": 36}, + "frame": + {"x": 233,"y": 224,"w": 39,"h": 36} + }, + { + "filename": "0007.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 8,"w": 39,"h": 36}, + "frame": + {"x": 0,"y": 187,"w": 39,"h": 36} + }, + { + "filename": "0041.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 0,"y": 24,"w": 38,"h": 36}, + "frame": + {"x": 39,"y": 187,"w": 38,"h": 36} + }, + { + "filename": "0015.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 36}, + "frame": + {"x": 0,"y": 223,"w": 39,"h": 36} + }, + { + "filename": "0016.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 3,"y": 0,"w": 39,"h": 36}, + "frame": + {"x": 39,"y": 223,"w": 39,"h": 36} + }, + { + "filename": "0023.png", + "rotated": false, + "trimmed": true, + "sourceSize": + {"w": 42,"h": 60}, + "spriteSourceSize": + {"x": 2,"y": 5,"w": 39,"h": 36}, + "frame": + {"x": 78,"y": 223,"w": 39,"h": 36} } ] } ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:2dee80dde3cead8f29a3dcf5b5c4ef5d:74dd5b1bb9285c2b0404381b05ba1d66:a0f9f47b818f7e67dd381af2f205c265$" - } + "meta": + {"app": "https://www.codeandweb.com/texturepacker", + "version": "3.0"} } diff --git a/public/images/pokemon/exp/shiny/774-yellow.png b/public/images/pokemon/exp/shiny/774-yellow.png index ab2f44c185a..e08aa86a32b 100644 Binary files a/public/images/pokemon/exp/shiny/774-yellow.png and b/public/images/pokemon/exp/shiny/774-yellow.png differ diff --git a/public/images/pokemon/exp/shiny/944.png b/public/images/pokemon/exp/shiny/944.png index fdb0f2ecb68..ee13a988a2b 100644 Binary files a/public/images/pokemon/exp/shiny/944.png and b/public/images/pokemon/exp/shiny/944.png differ diff --git a/public/images/pokemon/exp/shiny/945.png b/public/images/pokemon/exp/shiny/945.png index 9b938dfcfdd..3dba64c6ee8 100644 Binary files a/public/images/pokemon/exp/shiny/945.png and b/public/images/pokemon/exp/shiny/945.png differ diff --git a/public/images/pokemon/female/154.png b/public/images/pokemon/female/154.png index 4921f1556aa..f671d6b75aa 100644 Binary files a/public/images/pokemon/female/154.png and b/public/images/pokemon/female/154.png differ diff --git a/public/images/pokemon/female/194.png b/public/images/pokemon/female/194.png index 39c18727c2d..c0066f051ee 100644 Binary files a/public/images/pokemon/female/194.png and b/public/images/pokemon/female/194.png differ diff --git a/public/images/pokemon/female/198.png b/public/images/pokemon/female/198.png index 29bf2a296a5..9cead4fcbe0 100644 Binary files a/public/images/pokemon/female/198.png and b/public/images/pokemon/female/198.png differ diff --git a/public/images/pokemon/female/25-beauty-cosplay.png b/public/images/pokemon/female/25-beauty-cosplay.png index 018d0011254..26887468559 100644 Binary files a/public/images/pokemon/female/25-beauty-cosplay.png and b/public/images/pokemon/female/25-beauty-cosplay.png differ diff --git a/public/images/pokemon/female/25-cool-cosplay.png b/public/images/pokemon/female/25-cool-cosplay.png index 5936a9042ed..ae1e7c76d44 100644 Binary files a/public/images/pokemon/female/25-cool-cosplay.png and b/public/images/pokemon/female/25-cool-cosplay.png differ diff --git a/public/images/pokemon/female/25-cosplay.png b/public/images/pokemon/female/25-cosplay.png index 1f8f381419b..145d32e5130 100644 Binary files a/public/images/pokemon/female/25-cosplay.png and b/public/images/pokemon/female/25-cosplay.png differ diff --git a/public/images/pokemon/female/25-cute-cosplay.png b/public/images/pokemon/female/25-cute-cosplay.png index f559198f7ac..675a141b0fd 100644 Binary files a/public/images/pokemon/female/25-cute-cosplay.png and b/public/images/pokemon/female/25-cute-cosplay.png differ diff --git a/public/images/pokemon/female/25-partner.png b/public/images/pokemon/female/25-partner.png index e500db2a3be..8ce8d01c937 100644 Binary files a/public/images/pokemon/female/25-partner.png and b/public/images/pokemon/female/25-partner.png differ diff --git a/public/images/pokemon/female/25-smart-cosplay.png b/public/images/pokemon/female/25-smart-cosplay.png index b5c979e78ec..8306fb17dea 100644 Binary files a/public/images/pokemon/female/25-smart-cosplay.png and b/public/images/pokemon/female/25-smart-cosplay.png differ diff --git a/public/images/pokemon/female/25-tough-cosplay.png b/public/images/pokemon/female/25-tough-cosplay.png index 2896e27c8a9..a12d4a40a88 100644 Binary files a/public/images/pokemon/female/25-tough-cosplay.png and b/public/images/pokemon/female/25-tough-cosplay.png differ diff --git a/public/images/pokemon/female/25.png b/public/images/pokemon/female/25.png index e500db2a3be..8ce8d01c937 100644 Binary files a/public/images/pokemon/female/25.png and b/public/images/pokemon/female/25.png differ diff --git a/public/images/pokemon/female/26.png b/public/images/pokemon/female/26.png index 3f8c46ac761..242785a81cc 100644 Binary files a/public/images/pokemon/female/26.png and b/public/images/pokemon/female/26.png differ diff --git a/public/images/pokemon/female/275.png b/public/images/pokemon/female/275.png index 7f251793a15..c3c358716b2 100644 Binary files a/public/images/pokemon/female/275.png and b/public/images/pokemon/female/275.png differ diff --git a/public/images/pokemon/female/454.png b/public/images/pokemon/female/454.png index 010a7c3cb95..62b4c58558d 100644 Binary files a/public/images/pokemon/female/454.png and b/public/images/pokemon/female/454.png differ diff --git a/public/images/pokemon/icons/1/25-beauty-cosplay.png b/public/images/pokemon/icons/1/25-beauty-cosplay.png index 19fd467ebd7..f9b6f3dcc82 100644 Binary files a/public/images/pokemon/icons/1/25-beauty-cosplay.png and b/public/images/pokemon/icons/1/25-beauty-cosplay.png differ diff --git a/public/images/pokemon/icons/1/25-cool-cosplay.png b/public/images/pokemon/icons/1/25-cool-cosplay.png index 7d1b0954524..6436dff6dbb 100644 Binary files a/public/images/pokemon/icons/1/25-cool-cosplay.png and b/public/images/pokemon/icons/1/25-cool-cosplay.png differ diff --git a/public/images/pokemon/icons/1/25-cosplay.png b/public/images/pokemon/icons/1/25-cosplay.png index 74f0b993ce4..580805ef797 100644 Binary files a/public/images/pokemon/icons/1/25-cosplay.png and b/public/images/pokemon/icons/1/25-cosplay.png differ diff --git a/public/images/pokemon/icons/1/25-cute-cosplay.png b/public/images/pokemon/icons/1/25-cute-cosplay.png index 76488be18fe..71822acab8b 100644 Binary files a/public/images/pokemon/icons/1/25-cute-cosplay.png and b/public/images/pokemon/icons/1/25-cute-cosplay.png differ diff --git a/public/images/pokemon/icons/1/25-gigantamax.png b/public/images/pokemon/icons/1/25-gigantamax.png index ee10d68fd92..8650a88a62e 100644 Binary files a/public/images/pokemon/icons/1/25-gigantamax.png and b/public/images/pokemon/icons/1/25-gigantamax.png differ diff --git a/public/images/pokemon/icons/1/25-smart-cosplay.png b/public/images/pokemon/icons/1/25-smart-cosplay.png index 7eb69c5a17e..90aba5ddbf0 100644 Binary files a/public/images/pokemon/icons/1/25-smart-cosplay.png and b/public/images/pokemon/icons/1/25-smart-cosplay.png differ diff --git a/public/images/pokemon/icons/1/25-tough-cosplay.png b/public/images/pokemon/icons/1/25-tough-cosplay.png index 45c95ada80e..18101b5b497 100644 Binary files a/public/images/pokemon/icons/1/25-tough-cosplay.png and b/public/images/pokemon/icons/1/25-tough-cosplay.png differ diff --git a/public/images/pokemon/icons/1/25s-beauty-cosplay.png b/public/images/pokemon/icons/1/25s-beauty-cosplay.png index 19fd467ebd7..3b524dfcb06 100644 Binary files a/public/images/pokemon/icons/1/25s-beauty-cosplay.png and b/public/images/pokemon/icons/1/25s-beauty-cosplay.png differ diff --git a/public/images/pokemon/icons/1/25s-cool-cosplay.png b/public/images/pokemon/icons/1/25s-cool-cosplay.png index 7d1b0954524..0a3fc2d11ac 100644 Binary files a/public/images/pokemon/icons/1/25s-cool-cosplay.png and b/public/images/pokemon/icons/1/25s-cool-cosplay.png differ diff --git a/public/images/pokemon/icons/1/25s-cosplay.png b/public/images/pokemon/icons/1/25s-cosplay.png index 74f0b993ce4..218977fd454 100644 Binary files a/public/images/pokemon/icons/1/25s-cosplay.png and b/public/images/pokemon/icons/1/25s-cosplay.png differ diff --git a/public/images/pokemon/icons/1/25s-cute-cosplay.png b/public/images/pokemon/icons/1/25s-cute-cosplay.png index 76488be18fe..07df252aeb9 100644 Binary files a/public/images/pokemon/icons/1/25s-cute-cosplay.png and b/public/images/pokemon/icons/1/25s-cute-cosplay.png differ diff --git a/public/images/pokemon/icons/1/25s-smart-cosplay.png b/public/images/pokemon/icons/1/25s-smart-cosplay.png index 7eb69c5a17e..5742bb2718a 100644 Binary files a/public/images/pokemon/icons/1/25s-smart-cosplay.png and b/public/images/pokemon/icons/1/25s-smart-cosplay.png differ diff --git a/public/images/pokemon/icons/1/25s-tough-cosplay.png b/public/images/pokemon/icons/1/25s-tough-cosplay.png index 45c95ada80e..7e49d494573 100644 Binary files a/public/images/pokemon/icons/1/25s-tough-cosplay.png and b/public/images/pokemon/icons/1/25s-tough-cosplay.png differ diff --git a/public/images/pokemon/icons/2/154-f.png b/public/images/pokemon/icons/2/154-f.png new file mode 100644 index 00000000000..6481cdd8a00 Binary files /dev/null and b/public/images/pokemon/icons/2/154-f.png differ diff --git a/public/images/pokemon/icons/2/154s-f.png b/public/images/pokemon/icons/2/154s-f.png new file mode 100644 index 00000000000..44ded711dcd Binary files /dev/null and b/public/images/pokemon/icons/2/154s-f.png differ diff --git a/public/images/pokemon/icons/2/172s.png b/public/images/pokemon/icons/2/172s.png index 27a11014758..a1def7089ba 100644 Binary files a/public/images/pokemon/icons/2/172s.png and b/public/images/pokemon/icons/2/172s.png differ diff --git a/public/images/pokemon/icons/2/198-f.png b/public/images/pokemon/icons/2/198-f.png new file mode 100644 index 00000000000..bfc3e9bea4c Binary files /dev/null and b/public/images/pokemon/icons/2/198-f.png differ diff --git a/public/images/pokemon/icons/2/198s-f.png b/public/images/pokemon/icons/2/198s-f.png new file mode 100644 index 00000000000..ccc258cafac Binary files /dev/null and b/public/images/pokemon/icons/2/198s-f.png differ diff --git a/public/images/pokemon/icons/3/255-f.png b/public/images/pokemon/icons/3/255-f.png new file mode 100644 index 00000000000..bb221be21e7 Binary files /dev/null and b/public/images/pokemon/icons/3/255-f.png differ diff --git a/public/images/pokemon/icons/3/255s-f.png b/public/images/pokemon/icons/3/255s-f.png new file mode 100644 index 00000000000..898b17c163c Binary files /dev/null and b/public/images/pokemon/icons/3/255s-f.png differ diff --git a/public/images/pokemon/icons/3/256-f.png b/public/images/pokemon/icons/3/256-f.png new file mode 100644 index 00000000000..72800cc5e25 Binary files /dev/null and b/public/images/pokemon/icons/3/256-f.png differ diff --git a/public/images/pokemon/icons/3/256s-f.png b/public/images/pokemon/icons/3/256s-f.png new file mode 100644 index 00000000000..ce6608f7bc5 Binary files /dev/null and b/public/images/pokemon/icons/3/256s-f.png differ diff --git a/public/images/pokemon/icons/3/257-f-mega.png b/public/images/pokemon/icons/3/257-f-mega.png new file mode 100644 index 00000000000..ed64fe8f41f Binary files /dev/null and b/public/images/pokemon/icons/3/257-f-mega.png differ diff --git a/public/images/pokemon/icons/3/257-f.png b/public/images/pokemon/icons/3/257-f.png new file mode 100644 index 00000000000..ee42a9f75c0 Binary files /dev/null and b/public/images/pokemon/icons/3/257-f.png differ diff --git a/public/images/pokemon/icons/3/257s-f-mega.png b/public/images/pokemon/icons/3/257s-f-mega.png new file mode 100644 index 00000000000..faf5e5aa30c Binary files /dev/null and b/public/images/pokemon/icons/3/257s-f-mega.png differ diff --git a/public/images/pokemon/icons/3/257s-f.png b/public/images/pokemon/icons/3/257s-f.png new file mode 100644 index 00000000000..bf59393972f Binary files /dev/null and b/public/images/pokemon/icons/3/257s-f.png differ diff --git a/public/images/pokemon/icons/3/350s.png b/public/images/pokemon/icons/3/350s.png index eaed5c4bd11..4f5de9f5d57 100644 Binary files a/public/images/pokemon/icons/3/350s.png and b/public/images/pokemon/icons/3/350s.png differ diff --git a/public/images/pokemon/icons/3/378s.png b/public/images/pokemon/icons/3/378s.png index e2fc99bbc87..b52709493e7 100644 Binary files a/public/images/pokemon/icons/3/378s.png and b/public/images/pokemon/icons/3/378s.png differ diff --git a/public/images/pokemon/icons/7/2026.png b/public/images/pokemon/icons/7/2026.png index 5bc49abc790..cd8db24dd8b 100644 Binary files a/public/images/pokemon/icons/7/2026.png and b/public/images/pokemon/icons/7/2026.png differ diff --git a/public/images/pokemon/icons/7/2026s.png b/public/images/pokemon/icons/7/2026s.png index ecc11b878ab..94ce33a124f 100644 Binary files a/public/images/pokemon/icons/7/2026s.png and b/public/images/pokemon/icons/7/2026s.png differ diff --git a/public/images/pokemon/icons/9/1012-artisan.png b/public/images/pokemon/icons/9/1012-artisan.png index 96a215e47de..0eed79df1f2 100644 Binary files a/public/images/pokemon/icons/9/1012-artisan.png and b/public/images/pokemon/icons/9/1012-artisan.png differ diff --git a/public/images/pokemon/icons/9/1012-counterfeit.png b/public/images/pokemon/icons/9/1012-counterfeit.png index ff79d615db7..0eed79df1f2 100644 Binary files a/public/images/pokemon/icons/9/1012-counterfeit.png and b/public/images/pokemon/icons/9/1012-counterfeit.png differ diff --git a/public/images/pokemon/icons/9/1013-unremarkable.png b/public/images/pokemon/icons/9/1013-unremarkable.png index 3aa144b6d5c..9f4ec0cce34 100644 Binary files a/public/images/pokemon/icons/9/1013-unremarkable.png and b/public/images/pokemon/icons/9/1013-unremarkable.png differ diff --git a/public/images/pokemon/icons/9/966-caph-starmobile.png b/public/images/pokemon/icons/9/966-caph-starmobile.png new file mode 100644 index 00000000000..fba351495bd Binary files /dev/null and b/public/images/pokemon/icons/9/966-caph-starmobile.png differ diff --git a/public/images/pokemon/icons/9/966-navi-starmobile.png b/public/images/pokemon/icons/9/966-navi-starmobile.png new file mode 100644 index 00000000000..fba351495bd Binary files /dev/null and b/public/images/pokemon/icons/9/966-navi-starmobile.png differ diff --git a/public/images/pokemon/icons/9/966-ruchbah-starmobile.png b/public/images/pokemon/icons/9/966-ruchbah-starmobile.png new file mode 100644 index 00000000000..fba351495bd Binary files /dev/null and b/public/images/pokemon/icons/9/966-ruchbah-starmobile.png differ diff --git a/public/images/pokemon/icons/9/966-schedar-starmobile.png b/public/images/pokemon/icons/9/966-schedar-starmobile.png new file mode 100644 index 00000000000..fba351495bd Binary files /dev/null and b/public/images/pokemon/icons/9/966-schedar-starmobile.png differ diff --git a/public/images/pokemon/icons/9/966-segin-starmobile.png b/public/images/pokemon/icons/9/966-segin-starmobile.png new file mode 100644 index 00000000000..fba351495bd Binary files /dev/null and b/public/images/pokemon/icons/9/966-segin-starmobile.png differ diff --git a/public/images/pokemon/icons/9/966s-caph-starmobile.png b/public/images/pokemon/icons/9/966s-caph-starmobile.png new file mode 100644 index 00000000000..e54e5c90e4a Binary files /dev/null and b/public/images/pokemon/icons/9/966s-caph-starmobile.png differ diff --git a/public/images/pokemon/icons/9/966s-navi-starmobile.png b/public/images/pokemon/icons/9/966s-navi-starmobile.png new file mode 100644 index 00000000000..e54e5c90e4a Binary files /dev/null and b/public/images/pokemon/icons/9/966s-navi-starmobile.png differ diff --git a/public/images/pokemon/icons/9/966s-ruchbah-starmobile.png b/public/images/pokemon/icons/9/966s-ruchbah-starmobile.png new file mode 100644 index 00000000000..e54e5c90e4a Binary files /dev/null and b/public/images/pokemon/icons/9/966s-ruchbah-starmobile.png differ diff --git a/public/images/pokemon/icons/9/966s-schedar-starmobile.png b/public/images/pokemon/icons/9/966s-schedar-starmobile.png new file mode 100644 index 00000000000..e54e5c90e4a Binary files /dev/null and b/public/images/pokemon/icons/9/966s-schedar-starmobile.png differ diff --git a/public/images/pokemon/icons/9/966s-segin-starmobile.png b/public/images/pokemon/icons/9/966s-segin-starmobile.png new file mode 100644 index 00000000000..e54e5c90e4a Binary files /dev/null and b/public/images/pokemon/icons/9/966s-segin-starmobile.png differ diff --git a/public/images/pokemon/icons/variant/1/102_2.png b/public/images/pokemon/icons/variant/1/102_2.png new file mode 100644 index 00000000000..9d96f087919 Binary files /dev/null and b/public/images/pokemon/icons/variant/1/102_2.png differ diff --git a/public/images/pokemon/icons/variant/1/102_3.png b/public/images/pokemon/icons/variant/1/102_3.png new file mode 100644 index 00000000000..65272284ea8 Binary files /dev/null and b/public/images/pokemon/icons/variant/1/102_3.png differ diff --git a/public/images/pokemon/icons/variant/1/103_2.png b/public/images/pokemon/icons/variant/1/103_2.png new file mode 100644 index 00000000000..046d2b1bb6a Binary files /dev/null and b/public/images/pokemon/icons/variant/1/103_2.png differ diff --git a/public/images/pokemon/icons/variant/1/103_3.png b/public/images/pokemon/icons/variant/1/103_3.png new file mode 100644 index 00000000000..b68fdd50318 Binary files /dev/null and b/public/images/pokemon/icons/variant/1/103_3.png differ diff --git a/public/images/pokemon/icons/variant/1/128_2.png b/public/images/pokemon/icons/variant/1/128_2.png new file mode 100644 index 00000000000..0a44d5bbfad Binary files /dev/null and b/public/images/pokemon/icons/variant/1/128_2.png differ diff --git a/public/images/pokemon/icons/variant/1/128_3.png b/public/images/pokemon/icons/variant/1/128_3.png new file mode 100644 index 00000000000..8f6b25c2c18 Binary files /dev/null and b/public/images/pokemon/icons/variant/1/128_3.png differ diff --git a/public/images/pokemon/icons/variant/1/133-partner_2.png b/public/images/pokemon/icons/variant/1/133-partner_2.png new file mode 100644 index 00000000000..3e082ae0bd4 Binary files /dev/null and b/public/images/pokemon/icons/variant/1/133-partner_2.png differ diff --git a/public/images/pokemon/icons/variant/1/133-partner_3.png b/public/images/pokemon/icons/variant/1/133-partner_3.png new file mode 100644 index 00000000000..57c969d855c Binary files /dev/null and b/public/images/pokemon/icons/variant/1/133-partner_3.png differ diff --git a/public/images/pokemon/icons/variant/1/133_2.png b/public/images/pokemon/icons/variant/1/133_2.png index 7ab496699f7..b17979df07a 100644 Binary files a/public/images/pokemon/icons/variant/1/133_2.png and b/public/images/pokemon/icons/variant/1/133_2.png differ diff --git a/public/images/pokemon/icons/variant/1/133_3.png b/public/images/pokemon/icons/variant/1/133_3.png index f999dd0fff7..fa4d99879ae 100644 Binary files a/public/images/pokemon/icons/variant/1/133_3.png and b/public/images/pokemon/icons/variant/1/133_3.png differ diff --git a/public/images/pokemon/icons/variant/1/25-beauty-cosplay_2.png b/public/images/pokemon/icons/variant/1/25-beauty-cosplay_2.png new file mode 100644 index 00000000000..19c61af5069 Binary files /dev/null and b/public/images/pokemon/icons/variant/1/25-beauty-cosplay_2.png differ diff --git a/public/images/pokemon/icons/variant/1/25-beauty-cosplay_3.png b/public/images/pokemon/icons/variant/1/25-beauty-cosplay_3.png new file mode 100644 index 00000000000..1da79229795 Binary files /dev/null and b/public/images/pokemon/icons/variant/1/25-beauty-cosplay_3.png differ diff --git a/public/images/pokemon/icons/variant/1/25-cool-cosplay_2.png b/public/images/pokemon/icons/variant/1/25-cool-cosplay_2.png new file mode 100644 index 00000000000..8dc1e27acab Binary files /dev/null and b/public/images/pokemon/icons/variant/1/25-cool-cosplay_2.png differ diff --git a/public/images/pokemon/icons/variant/1/25-cool-cosplay_3.png b/public/images/pokemon/icons/variant/1/25-cool-cosplay_3.png new file mode 100644 index 00000000000..7a603219649 Binary files /dev/null and b/public/images/pokemon/icons/variant/1/25-cool-cosplay_3.png differ diff --git a/public/images/pokemon/icons/variant/1/25-cosplay_2.png b/public/images/pokemon/icons/variant/1/25-cosplay_2.png new file mode 100644 index 00000000000..c47e9ef7d18 Binary files /dev/null and b/public/images/pokemon/icons/variant/1/25-cosplay_2.png differ diff --git a/public/images/pokemon/icons/variant/1/25-cosplay_3.png b/public/images/pokemon/icons/variant/1/25-cosplay_3.png new file mode 100644 index 00000000000..16332db9041 Binary files /dev/null and b/public/images/pokemon/icons/variant/1/25-cosplay_3.png differ diff --git a/public/images/pokemon/icons/variant/1/25-cute-cosplay_2.png b/public/images/pokemon/icons/variant/1/25-cute-cosplay_2.png new file mode 100644 index 00000000000..3f606da7bb0 Binary files /dev/null and b/public/images/pokemon/icons/variant/1/25-cute-cosplay_2.png differ diff --git a/public/images/pokemon/icons/variant/1/25-cute-cosplay_3.png b/public/images/pokemon/icons/variant/1/25-cute-cosplay_3.png new file mode 100644 index 00000000000..8560b6f04b5 Binary files /dev/null and b/public/images/pokemon/icons/variant/1/25-cute-cosplay_3.png differ diff --git a/public/images/pokemon/icons/variant/1/25-gigantamax_2.png b/public/images/pokemon/icons/variant/1/25-gigantamax_2.png new file mode 100644 index 00000000000..6bc267b55fa Binary files /dev/null and b/public/images/pokemon/icons/variant/1/25-gigantamax_2.png differ diff --git a/public/images/pokemon/icons/variant/1/25-gigantamax_3.png b/public/images/pokemon/icons/variant/1/25-gigantamax_3.png new file mode 100644 index 00000000000..8c4ff760bcd Binary files /dev/null and b/public/images/pokemon/icons/variant/1/25-gigantamax_3.png differ diff --git a/public/images/pokemon/icons/variant/1/25-partner_2.png b/public/images/pokemon/icons/variant/1/25-partner_2.png new file mode 100644 index 00000000000..eaa2cfb610f Binary files /dev/null and b/public/images/pokemon/icons/variant/1/25-partner_2.png differ diff --git a/public/images/pokemon/icons/variant/1/25-partner_3.png b/public/images/pokemon/icons/variant/1/25-partner_3.png new file mode 100644 index 00000000000..1faf330ef51 Binary files /dev/null and b/public/images/pokemon/icons/variant/1/25-partner_3.png differ diff --git a/public/images/pokemon/icons/variant/1/25-smart-cosplay_2.png b/public/images/pokemon/icons/variant/1/25-smart-cosplay_2.png new file mode 100644 index 00000000000..4ecae1f73a2 Binary files /dev/null and b/public/images/pokemon/icons/variant/1/25-smart-cosplay_2.png differ diff --git a/public/images/pokemon/icons/variant/1/25-smart-cosplay_3.png b/public/images/pokemon/icons/variant/1/25-smart-cosplay_3.png new file mode 100644 index 00000000000..ea41daf34e6 Binary files /dev/null and b/public/images/pokemon/icons/variant/1/25-smart-cosplay_3.png differ diff --git a/public/images/pokemon/icons/variant/1/25-tough-cosplay_2.png b/public/images/pokemon/icons/variant/1/25-tough-cosplay_2.png new file mode 100644 index 00000000000..3f7072c4138 Binary files /dev/null and b/public/images/pokemon/icons/variant/1/25-tough-cosplay_2.png differ diff --git a/public/images/pokemon/icons/variant/1/25-tough-cosplay_3.png b/public/images/pokemon/icons/variant/1/25-tough-cosplay_3.png new file mode 100644 index 00000000000..e671ff98639 Binary files /dev/null and b/public/images/pokemon/icons/variant/1/25-tough-cosplay_3.png differ diff --git a/public/images/pokemon/icons/variant/1/25_2.png b/public/images/pokemon/icons/variant/1/25_2.png new file mode 100644 index 00000000000..5e987ffe777 Binary files /dev/null and b/public/images/pokemon/icons/variant/1/25_2.png differ diff --git a/public/images/pokemon/icons/variant/1/25_3.png b/public/images/pokemon/icons/variant/1/25_3.png new file mode 100644 index 00000000000..b04af012bec Binary files /dev/null and b/public/images/pokemon/icons/variant/1/25_3.png differ diff --git a/public/images/pokemon/icons/variant/1/26_2.png b/public/images/pokemon/icons/variant/1/26_2.png new file mode 100644 index 00000000000..f21ebe42b16 Binary files /dev/null and b/public/images/pokemon/icons/variant/1/26_2.png differ diff --git a/public/images/pokemon/icons/variant/1/26_3.png b/public/images/pokemon/icons/variant/1/26_3.png new file mode 100644 index 00000000000..adbe9c212b3 Binary files /dev/null and b/public/images/pokemon/icons/variant/1/26_3.png differ diff --git a/public/images/pokemon/icons/variant/1/39_2.png b/public/images/pokemon/icons/variant/1/39_2.png new file mode 100644 index 00000000000..f4b85b201cf Binary files /dev/null and b/public/images/pokemon/icons/variant/1/39_2.png differ diff --git a/public/images/pokemon/icons/variant/1/39_3.png b/public/images/pokemon/icons/variant/1/39_3.png new file mode 100644 index 00000000000..137f3dc083c Binary files /dev/null and b/public/images/pokemon/icons/variant/1/39_3.png differ diff --git a/public/images/pokemon/icons/variant/1/40_2.png b/public/images/pokemon/icons/variant/1/40_2.png new file mode 100644 index 00000000000..09ffdcd5757 Binary files /dev/null and b/public/images/pokemon/icons/variant/1/40_2.png differ diff --git a/public/images/pokemon/icons/variant/1/40_3.png b/public/images/pokemon/icons/variant/1/40_3.png new file mode 100644 index 00000000000..09333136c19 Binary files /dev/null and b/public/images/pokemon/icons/variant/1/40_3.png differ diff --git a/public/images/pokemon/icons/variant/1/42_1.png b/public/images/pokemon/icons/variant/1/42_1.png index 17c82d9dd9e..91d7fae345d 100644 Binary files a/public/images/pokemon/icons/variant/1/42_1.png and b/public/images/pokemon/icons/variant/1/42_1.png differ diff --git a/public/images/pokemon/icons/variant/1/42_2.png b/public/images/pokemon/icons/variant/1/42_2.png index 91d7fae345d..17c82d9dd9e 100644 Binary files a/public/images/pokemon/icons/variant/1/42_2.png and b/public/images/pokemon/icons/variant/1/42_2.png differ diff --git a/public/images/pokemon/icons/variant/2/152_2.png b/public/images/pokemon/icons/variant/2/152_2.png new file mode 100644 index 00000000000..3815a4dbf49 Binary files /dev/null and b/public/images/pokemon/icons/variant/2/152_2.png differ diff --git a/public/images/pokemon/icons/variant/2/152_3.png b/public/images/pokemon/icons/variant/2/152_3.png new file mode 100644 index 00000000000..be0fffab10c Binary files /dev/null and b/public/images/pokemon/icons/variant/2/152_3.png differ diff --git a/public/images/pokemon/icons/variant/2/153_2.png b/public/images/pokemon/icons/variant/2/153_2.png new file mode 100644 index 00000000000..020fc80d8b9 Binary files /dev/null and b/public/images/pokemon/icons/variant/2/153_2.png differ diff --git a/public/images/pokemon/icons/variant/2/153_3.png b/public/images/pokemon/icons/variant/2/153_3.png new file mode 100644 index 00000000000..681acfa2db1 Binary files /dev/null and b/public/images/pokemon/icons/variant/2/153_3.png differ diff --git a/public/images/pokemon/icons/variant/2/154-f_2.png b/public/images/pokemon/icons/variant/2/154-f_2.png new file mode 100644 index 00000000000..5ba8c458cf5 Binary files /dev/null and b/public/images/pokemon/icons/variant/2/154-f_2.png differ diff --git a/public/images/pokemon/icons/variant/2/154-f_3.png b/public/images/pokemon/icons/variant/2/154-f_3.png new file mode 100644 index 00000000000..c278d045c38 Binary files /dev/null and b/public/images/pokemon/icons/variant/2/154-f_3.png differ diff --git a/public/images/pokemon/icons/variant/2/154_2.png b/public/images/pokemon/icons/variant/2/154_2.png new file mode 100644 index 00000000000..323e2331a77 Binary files /dev/null and b/public/images/pokemon/icons/variant/2/154_2.png differ diff --git a/public/images/pokemon/icons/variant/2/154_3.png b/public/images/pokemon/icons/variant/2/154_3.png new file mode 100644 index 00000000000..aef1e4d633e Binary files /dev/null and b/public/images/pokemon/icons/variant/2/154_3.png differ diff --git a/public/images/pokemon/icons/variant/2/158_2.png b/public/images/pokemon/icons/variant/2/158_2.png new file mode 100644 index 00000000000..c6b75ed6c20 Binary files /dev/null and b/public/images/pokemon/icons/variant/2/158_2.png differ diff --git a/public/images/pokemon/icons/variant/2/158_3.png b/public/images/pokemon/icons/variant/2/158_3.png new file mode 100644 index 00000000000..073e3faa2e2 Binary files /dev/null and b/public/images/pokemon/icons/variant/2/158_3.png differ diff --git a/public/images/pokemon/icons/variant/2/159_2.png b/public/images/pokemon/icons/variant/2/159_2.png new file mode 100644 index 00000000000..95d74728073 Binary files /dev/null and b/public/images/pokemon/icons/variant/2/159_2.png differ diff --git a/public/images/pokemon/icons/variant/2/159_3.png b/public/images/pokemon/icons/variant/2/159_3.png new file mode 100644 index 00000000000..a73818d0c3a Binary files /dev/null and b/public/images/pokemon/icons/variant/2/159_3.png differ diff --git a/public/images/pokemon/icons/variant/2/160_2.png b/public/images/pokemon/icons/variant/2/160_2.png new file mode 100644 index 00000000000..7b7ba6e7231 Binary files /dev/null and b/public/images/pokemon/icons/variant/2/160_2.png differ diff --git a/public/images/pokemon/icons/variant/2/160_3.png b/public/images/pokemon/icons/variant/2/160_3.png new file mode 100644 index 00000000000..62a4ab22fd2 Binary files /dev/null and b/public/images/pokemon/icons/variant/2/160_3.png differ diff --git a/public/images/pokemon/icons/variant/2/167_2.png b/public/images/pokemon/icons/variant/2/167_2.png new file mode 100644 index 00000000000..a6bd15c0eef Binary files /dev/null and b/public/images/pokemon/icons/variant/2/167_2.png differ diff --git a/public/images/pokemon/icons/variant/2/167_3.png b/public/images/pokemon/icons/variant/2/167_3.png new file mode 100644 index 00000000000..88d84eec2a9 Binary files /dev/null and b/public/images/pokemon/icons/variant/2/167_3.png differ diff --git a/public/images/pokemon/icons/variant/2/168_2.png b/public/images/pokemon/icons/variant/2/168_2.png new file mode 100644 index 00000000000..cf34c26be21 Binary files /dev/null and b/public/images/pokemon/icons/variant/2/168_2.png differ diff --git a/public/images/pokemon/icons/variant/2/168_3.png b/public/images/pokemon/icons/variant/2/168_3.png new file mode 100644 index 00000000000..7a62c58d299 Binary files /dev/null and b/public/images/pokemon/icons/variant/2/168_3.png differ diff --git a/public/images/pokemon/icons/variant/2/170_2.png b/public/images/pokemon/icons/variant/2/170_2.png new file mode 100644 index 00000000000..1ecdfda6eb8 Binary files /dev/null and b/public/images/pokemon/icons/variant/2/170_2.png differ diff --git a/public/images/pokemon/icons/variant/2/170_3.png b/public/images/pokemon/icons/variant/2/170_3.png new file mode 100644 index 00000000000..01cb78568ed Binary files /dev/null and b/public/images/pokemon/icons/variant/2/170_3.png differ diff --git a/public/images/pokemon/icons/variant/2/171_2.png b/public/images/pokemon/icons/variant/2/171_2.png new file mode 100644 index 00000000000..3ff5792e2d2 Binary files /dev/null and b/public/images/pokemon/icons/variant/2/171_2.png differ diff --git a/public/images/pokemon/icons/variant/2/171_3.png b/public/images/pokemon/icons/variant/2/171_3.png new file mode 100644 index 00000000000..11a3996da80 Binary files /dev/null and b/public/images/pokemon/icons/variant/2/171_3.png differ diff --git a/public/images/pokemon/icons/variant/2/172-spiky_2.png b/public/images/pokemon/icons/variant/2/172-spiky_2.png new file mode 100644 index 00000000000..b293ee3283a Binary files /dev/null and b/public/images/pokemon/icons/variant/2/172-spiky_2.png differ diff --git a/public/images/pokemon/icons/variant/2/172-spiky_3.png b/public/images/pokemon/icons/variant/2/172-spiky_3.png new file mode 100644 index 00000000000..ff9a4229421 Binary files /dev/null and b/public/images/pokemon/icons/variant/2/172-spiky_3.png differ diff --git a/public/images/pokemon/icons/variant/2/172_2.png b/public/images/pokemon/icons/variant/2/172_2.png new file mode 100644 index 00000000000..4fa282f9297 Binary files /dev/null and b/public/images/pokemon/icons/variant/2/172_2.png differ diff --git a/public/images/pokemon/icons/variant/2/172_3.png b/public/images/pokemon/icons/variant/2/172_3.png new file mode 100644 index 00000000000..95f0c9bdc6d Binary files /dev/null and b/public/images/pokemon/icons/variant/2/172_3.png differ diff --git a/public/images/pokemon/icons/variant/2/174_2.png b/public/images/pokemon/icons/variant/2/174_2.png new file mode 100644 index 00000000000..e7ffddb1f57 Binary files /dev/null and b/public/images/pokemon/icons/variant/2/174_2.png differ diff --git a/public/images/pokemon/icons/variant/2/174_3.png b/public/images/pokemon/icons/variant/2/174_3.png new file mode 100644 index 00000000000..58d98aab99a Binary files /dev/null and b/public/images/pokemon/icons/variant/2/174_3.png differ diff --git a/public/images/pokemon/icons/variant/2/194_2.png b/public/images/pokemon/icons/variant/2/194_2.png new file mode 100644 index 00000000000..043c11ce065 Binary files /dev/null and b/public/images/pokemon/icons/variant/2/194_2.png differ diff --git a/public/images/pokemon/icons/variant/2/194_3.png b/public/images/pokemon/icons/variant/2/194_3.png new file mode 100644 index 00000000000..f5d792b141f Binary files /dev/null and b/public/images/pokemon/icons/variant/2/194_3.png differ diff --git a/public/images/pokemon/icons/variant/2/195_2.png b/public/images/pokemon/icons/variant/2/195_2.png new file mode 100644 index 00000000000..7fd5ba2792f Binary files /dev/null and b/public/images/pokemon/icons/variant/2/195_2.png differ diff --git a/public/images/pokemon/icons/variant/2/195_3.png b/public/images/pokemon/icons/variant/2/195_3.png new file mode 100644 index 00000000000..99da4dfe12e Binary files /dev/null and b/public/images/pokemon/icons/variant/2/195_3.png differ diff --git a/public/images/pokemon/icons/variant/2/198-f_2.png b/public/images/pokemon/icons/variant/2/198-f_2.png new file mode 100644 index 00000000000..35e5c2e75ea Binary files /dev/null and b/public/images/pokemon/icons/variant/2/198-f_2.png differ diff --git a/public/images/pokemon/icons/variant/2/198-f_3.png b/public/images/pokemon/icons/variant/2/198-f_3.png new file mode 100644 index 00000000000..f2920cd1d0e Binary files /dev/null and b/public/images/pokemon/icons/variant/2/198-f_3.png differ diff --git a/public/images/pokemon/icons/variant/2/198_2.png b/public/images/pokemon/icons/variant/2/198_2.png new file mode 100644 index 00000000000..35e5c2e75ea Binary files /dev/null and b/public/images/pokemon/icons/variant/2/198_2.png differ diff --git a/public/images/pokemon/icons/variant/2/198_3.png b/public/images/pokemon/icons/variant/2/198_3.png new file mode 100644 index 00000000000..f2920cd1d0e Binary files /dev/null and b/public/images/pokemon/icons/variant/2/198_3.png differ diff --git a/public/images/pokemon/icons/variant/2/211_2.png b/public/images/pokemon/icons/variant/2/211_2.png new file mode 100644 index 00000000000..c042910bc17 Binary files /dev/null and b/public/images/pokemon/icons/variant/2/211_2.png differ diff --git a/public/images/pokemon/icons/variant/2/211_3.png b/public/images/pokemon/icons/variant/2/211_3.png new file mode 100644 index 00000000000..3548893b6ec Binary files /dev/null and b/public/images/pokemon/icons/variant/2/211_3.png differ diff --git a/public/images/pokemon/icons/variant/3/255_2.png b/public/images/pokemon/icons/variant/3/255_2.png index adf8c6ea8bc..b40b8f1607c 100644 Binary files a/public/images/pokemon/icons/variant/3/255_2.png and b/public/images/pokemon/icons/variant/3/255_2.png differ diff --git a/public/images/pokemon/icons/variant/3/255_3.png b/public/images/pokemon/icons/variant/3/255_3.png index 6ed47e69afa..2ae8ef351f5 100644 Binary files a/public/images/pokemon/icons/variant/3/255_3.png and b/public/images/pokemon/icons/variant/3/255_3.png differ diff --git a/public/images/pokemon/icons/variant/3/256_2.png b/public/images/pokemon/icons/variant/3/256_2.png index b372f1ff981..43919a2db06 100644 Binary files a/public/images/pokemon/icons/variant/3/256_2.png and b/public/images/pokemon/icons/variant/3/256_2.png differ diff --git a/public/images/pokemon/icons/variant/3/256_3.png b/public/images/pokemon/icons/variant/3/256_3.png index 0c529f838ba..bb1cbfe0809 100644 Binary files a/public/images/pokemon/icons/variant/3/256_3.png and b/public/images/pokemon/icons/variant/3/256_3.png differ diff --git a/public/images/pokemon/icons/variant/3/257_3.png b/public/images/pokemon/icons/variant/3/257_3.png index c7853c73d4f..cccaab5db12 100644 Binary files a/public/images/pokemon/icons/variant/3/257_3.png and b/public/images/pokemon/icons/variant/3/257_3.png differ diff --git a/public/images/pokemon/icons/variant/3/276_2.png b/public/images/pokemon/icons/variant/3/276_2.png new file mode 100644 index 00000000000..d7e8a3aa9ca Binary files /dev/null and b/public/images/pokemon/icons/variant/3/276_2.png differ diff --git a/public/images/pokemon/icons/variant/3/276_3.png b/public/images/pokemon/icons/variant/3/276_3.png new file mode 100644 index 00000000000..b9cfa276eb2 Binary files /dev/null and b/public/images/pokemon/icons/variant/3/276_3.png differ diff --git a/public/images/pokemon/icons/variant/3/277_2.png b/public/images/pokemon/icons/variant/3/277_2.png new file mode 100644 index 00000000000..f4d58f259c3 Binary files /dev/null and b/public/images/pokemon/icons/variant/3/277_2.png differ diff --git a/public/images/pokemon/icons/variant/3/277_3.png b/public/images/pokemon/icons/variant/3/277_3.png new file mode 100644 index 00000000000..69ccce9069b Binary files /dev/null and b/public/images/pokemon/icons/variant/3/277_3.png differ diff --git a/public/images/pokemon/icons/variant/3/359-mega_2.png b/public/images/pokemon/icons/variant/3/359-mega_2.png new file mode 100644 index 00000000000..35290c15aa9 Binary files /dev/null and b/public/images/pokemon/icons/variant/3/359-mega_2.png differ diff --git a/public/images/pokemon/icons/variant/3/359-mega_3.png b/public/images/pokemon/icons/variant/3/359-mega_3.png new file mode 100644 index 00000000000..5a3250b944d Binary files /dev/null and b/public/images/pokemon/icons/variant/3/359-mega_3.png differ diff --git a/public/images/pokemon/icons/variant/3/359_2.png b/public/images/pokemon/icons/variant/3/359_2.png new file mode 100644 index 00000000000..0fa229141fd Binary files /dev/null and b/public/images/pokemon/icons/variant/3/359_2.png differ diff --git a/public/images/pokemon/icons/variant/3/359_3.png b/public/images/pokemon/icons/variant/3/359_3.png new file mode 100644 index 00000000000..54ba72028ac Binary files /dev/null and b/public/images/pokemon/icons/variant/3/359_3.png differ diff --git a/public/images/pokemon/icons/variant/3/377_2.png b/public/images/pokemon/icons/variant/3/377_2.png new file mode 100644 index 00000000000..f90f337c32e Binary files /dev/null and b/public/images/pokemon/icons/variant/3/377_2.png differ diff --git a/public/images/pokemon/icons/variant/3/377_3.png b/public/images/pokemon/icons/variant/3/377_3.png new file mode 100644 index 00000000000..0957178662a Binary files /dev/null and b/public/images/pokemon/icons/variant/3/377_3.png differ diff --git a/public/images/pokemon/variant/back/6706_2.png b/public/images/pokemon/icons/variant/3/378_1.png similarity index 56% rename from public/images/pokemon/variant/back/6706_2.png rename to public/images/pokemon/icons/variant/3/378_1.png index e52f1af4ba5..32bc37d9e33 100644 Binary files a/public/images/pokemon/variant/back/6706_2.png and b/public/images/pokemon/icons/variant/3/378_1.png differ diff --git a/public/images/pokemon/icons/variant/3/378_2.png b/public/images/pokemon/icons/variant/3/378_2.png new file mode 100644 index 00000000000..9f310bc92c8 Binary files /dev/null and b/public/images/pokemon/icons/variant/3/378_2.png differ diff --git a/public/images/pokemon/icons/variant/3/378_3.png b/public/images/pokemon/icons/variant/3/378_3.png new file mode 100644 index 00000000000..45afe9a71a9 Binary files /dev/null and b/public/images/pokemon/icons/variant/3/378_3.png differ diff --git a/public/images/pokemon/icons/variant/3/379_2.png b/public/images/pokemon/icons/variant/3/379_2.png new file mode 100644 index 00000000000..ad928fd752e Binary files /dev/null and b/public/images/pokemon/icons/variant/3/379_2.png differ diff --git a/public/images/pokemon/icons/variant/3/379_3.png b/public/images/pokemon/icons/variant/3/379_3.png new file mode 100644 index 00000000000..acb86b4f665 Binary files /dev/null and b/public/images/pokemon/icons/variant/3/379_3.png differ diff --git a/public/images/pokemon/icons/variant/3/427_2.png b/public/images/pokemon/icons/variant/3/427_2.png deleted file mode 100644 index ceaf11acb48..00000000000 Binary files a/public/images/pokemon/icons/variant/3/427_2.png and /dev/null differ diff --git a/public/images/pokemon/icons/variant/3/427_3.png b/public/images/pokemon/icons/variant/3/427_3.png deleted file mode 100644 index 5972f5e9489..00000000000 Binary files a/public/images/pokemon/icons/variant/3/427_3.png and /dev/null differ diff --git a/public/images/pokemon/icons/variant/3/428-mega_2.png b/public/images/pokemon/icons/variant/3/428-mega_2.png deleted file mode 100644 index 32c3293a796..00000000000 Binary files a/public/images/pokemon/icons/variant/3/428-mega_2.png and /dev/null differ diff --git a/public/images/pokemon/icons/variant/3/428_2.png b/public/images/pokemon/icons/variant/3/428_2.png deleted file mode 100644 index 5b325f3256a..00000000000 Binary files a/public/images/pokemon/icons/variant/3/428_2.png and /dev/null differ diff --git a/public/images/pokemon/icons/variant/3/429_1.png b/public/images/pokemon/icons/variant/3/429_1.png deleted file mode 100644 index 667f389f5c1..00000000000 Binary files a/public/images/pokemon/icons/variant/3/429_1.png and /dev/null differ diff --git a/public/images/pokemon/icons/variant/3/429_2.png b/public/images/pokemon/icons/variant/3/429_2.png deleted file mode 100644 index 85cd47bd85f..00000000000 Binary files a/public/images/pokemon/icons/variant/3/429_2.png and /dev/null differ diff --git a/public/images/pokemon/icons/variant/3/429_3.png b/public/images/pokemon/icons/variant/3/429_3.png deleted file mode 100644 index bb9b2384514..00000000000 Binary files a/public/images/pokemon/icons/variant/3/429_3.png and /dev/null differ diff --git a/public/images/pokemon/icons/variant/3/475-mega_3.png b/public/images/pokemon/icons/variant/3/475-mega_3.png deleted file mode 100644 index c067c36c836..00000000000 Binary files a/public/images/pokemon/icons/variant/3/475-mega_3.png and /dev/null differ diff --git a/public/images/pokemon/icons/variant/3/475_3.png b/public/images/pokemon/icons/variant/3/475_3.png deleted file mode 100644 index 4a8f5bdb56d..00000000000 Binary files a/public/images/pokemon/icons/variant/3/475_3.png and /dev/null differ diff --git a/public/images/pokemon/icons/variant/4/390_2.png b/public/images/pokemon/icons/variant/4/390_2.png new file mode 100644 index 00000000000..f29d3561210 Binary files /dev/null and b/public/images/pokemon/icons/variant/4/390_2.png differ diff --git a/public/images/pokemon/icons/variant/4/390_3.png b/public/images/pokemon/icons/variant/4/390_3.png new file mode 100644 index 00000000000..7634f2e8639 Binary files /dev/null and b/public/images/pokemon/icons/variant/4/390_3.png differ diff --git a/public/images/pokemon/icons/variant/4/391_2.png b/public/images/pokemon/icons/variant/4/391_2.png new file mode 100644 index 00000000000..470de43c7bc Binary files /dev/null and b/public/images/pokemon/icons/variant/4/391_2.png differ diff --git a/public/images/pokemon/icons/variant/4/391_3.png b/public/images/pokemon/icons/variant/4/391_3.png new file mode 100644 index 00000000000..8996fdb025c Binary files /dev/null and b/public/images/pokemon/icons/variant/4/391_3.png differ diff --git a/public/images/pokemon/icons/variant/4/392_2.png b/public/images/pokemon/icons/variant/4/392_2.png new file mode 100644 index 00000000000..0550a20e94d Binary files /dev/null and b/public/images/pokemon/icons/variant/4/392_2.png differ diff --git a/public/images/pokemon/icons/variant/4/392_3.png b/public/images/pokemon/icons/variant/4/392_3.png new file mode 100644 index 00000000000..7a66926b533 Binary files /dev/null and b/public/images/pokemon/icons/variant/4/392_3.png differ diff --git a/public/images/pokemon/icons/variant/4/427_2.png b/public/images/pokemon/icons/variant/4/427_2.png index 1b5d9271624..ceaf11acb48 100644 Binary files a/public/images/pokemon/icons/variant/4/427_2.png and b/public/images/pokemon/icons/variant/4/427_2.png differ diff --git a/public/images/pokemon/icons/variant/4/427_3.png b/public/images/pokemon/icons/variant/4/427_3.png index a3f90ea6dfa..5972f5e9489 100644 Binary files a/public/images/pokemon/icons/variant/4/427_3.png and b/public/images/pokemon/icons/variant/4/427_3.png differ diff --git a/public/images/pokemon/icons/variant/4/428-mega_2.png b/public/images/pokemon/icons/variant/4/428-mega_2.png index 43dfa05d438..32c3293a796 100644 Binary files a/public/images/pokemon/icons/variant/4/428-mega_2.png and b/public/images/pokemon/icons/variant/4/428-mega_2.png differ diff --git a/public/images/pokemon/icons/variant/4/428_2.png b/public/images/pokemon/icons/variant/4/428_2.png index 1e42720c78b..5b325f3256a 100644 Binary files a/public/images/pokemon/icons/variant/4/428_2.png and b/public/images/pokemon/icons/variant/4/428_2.png differ diff --git a/public/images/pokemon/icons/variant/4/429_1.png b/public/images/pokemon/icons/variant/4/429_1.png index 7354a6a6be7..667f389f5c1 100644 Binary files a/public/images/pokemon/icons/variant/4/429_1.png and b/public/images/pokemon/icons/variant/4/429_1.png differ diff --git a/public/images/pokemon/icons/variant/4/429_2.png b/public/images/pokemon/icons/variant/4/429_2.png index 9ec7cd5e76e..85cd47bd85f 100644 Binary files a/public/images/pokemon/icons/variant/4/429_2.png and b/public/images/pokemon/icons/variant/4/429_2.png differ diff --git a/public/images/pokemon/icons/variant/4/429_3.png b/public/images/pokemon/icons/variant/4/429_3.png index 48f7068ced8..bb9b2384514 100644 Binary files a/public/images/pokemon/icons/variant/4/429_3.png and b/public/images/pokemon/icons/variant/4/429_3.png differ diff --git a/public/images/pokemon/icons/variant/4/430_2.png b/public/images/pokemon/icons/variant/4/430_2.png new file mode 100644 index 00000000000..8026dd75141 Binary files /dev/null and b/public/images/pokemon/icons/variant/4/430_2.png differ diff --git a/public/images/pokemon/icons/variant/4/430_3.png b/public/images/pokemon/icons/variant/4/430_3.png new file mode 100644 index 00000000000..d83a4f349f0 Binary files /dev/null and b/public/images/pokemon/icons/variant/4/430_3.png differ diff --git a/public/images/pokemon/icons/variant/4/455_2.png b/public/images/pokemon/icons/variant/4/455_2.png new file mode 100644 index 00000000000..206ba13205f Binary files /dev/null and b/public/images/pokemon/icons/variant/4/455_2.png differ diff --git a/public/images/pokemon/icons/variant/4/455_3.png b/public/images/pokemon/icons/variant/4/455_3.png new file mode 100644 index 00000000000..199976e2f67 Binary files /dev/null and b/public/images/pokemon/icons/variant/4/455_3.png differ diff --git a/public/images/pokemon/icons/variant/4/486_2.png b/public/images/pokemon/icons/variant/4/486_2.png new file mode 100644 index 00000000000..d13c4861a4b Binary files /dev/null and b/public/images/pokemon/icons/variant/4/486_2.png differ diff --git a/public/images/pokemon/icons/variant/4/486_3.png b/public/images/pokemon/icons/variant/4/486_3.png new file mode 100644 index 00000000000..cf33b01869a Binary files /dev/null and b/public/images/pokemon/icons/variant/4/486_3.png differ diff --git a/public/images/pokemon/icons/variant/5/501_2.png b/public/images/pokemon/icons/variant/5/501_2.png new file mode 100644 index 00000000000..d92f57a8399 Binary files /dev/null and b/public/images/pokemon/icons/variant/5/501_2.png differ diff --git a/public/images/pokemon/icons/variant/5/501_3.png b/public/images/pokemon/icons/variant/5/501_3.png new file mode 100644 index 00000000000..50bbb59a545 Binary files /dev/null and b/public/images/pokemon/icons/variant/5/501_3.png differ diff --git a/public/images/pokemon/icons/variant/5/502_2.png b/public/images/pokemon/icons/variant/5/502_2.png new file mode 100644 index 00000000000..3d327da2129 Binary files /dev/null and b/public/images/pokemon/icons/variant/5/502_2.png differ diff --git a/public/images/pokemon/icons/variant/5/502_3.png b/public/images/pokemon/icons/variant/5/502_3.png new file mode 100644 index 00000000000..a10810daed9 Binary files /dev/null and b/public/images/pokemon/icons/variant/5/502_3.png differ diff --git a/public/images/pokemon/icons/variant/5/503_2.png b/public/images/pokemon/icons/variant/5/503_2.png new file mode 100644 index 00000000000..b3611139d87 Binary files /dev/null and b/public/images/pokemon/icons/variant/5/503_2.png differ diff --git a/public/images/pokemon/icons/variant/5/503_3.png b/public/images/pokemon/icons/variant/5/503_3.png new file mode 100644 index 00000000000..da3aa967ab5 Binary files /dev/null and b/public/images/pokemon/icons/variant/5/503_3.png differ diff --git a/public/images/pokemon/icons/variant/5/527_2.png b/public/images/pokemon/icons/variant/5/527_2.png new file mode 100644 index 00000000000..3a0b284bfde Binary files /dev/null and b/public/images/pokemon/icons/variant/5/527_2.png differ diff --git a/public/images/pokemon/icons/variant/5/527_3.png b/public/images/pokemon/icons/variant/5/527_3.png new file mode 100644 index 00000000000..39b54a23b1e Binary files /dev/null and b/public/images/pokemon/icons/variant/5/527_3.png differ diff --git a/public/images/pokemon/icons/variant/5/528_2.png b/public/images/pokemon/icons/variant/5/528_2.png new file mode 100644 index 00000000000..4d209760134 Binary files /dev/null and b/public/images/pokemon/icons/variant/5/528_2.png differ diff --git a/public/images/pokemon/icons/variant/5/528_3.png b/public/images/pokemon/icons/variant/5/528_3.png new file mode 100644 index 00000000000..1c887443660 Binary files /dev/null and b/public/images/pokemon/icons/variant/5/528_3.png differ diff --git a/public/images/pokemon/icons/variant/5/587_2.png b/public/images/pokemon/icons/variant/5/587_2.png new file mode 100644 index 00000000000..1e522a31676 Binary files /dev/null and b/public/images/pokemon/icons/variant/5/587_2.png differ diff --git a/public/images/pokemon/icons/variant/5/587_3.png b/public/images/pokemon/icons/variant/5/587_3.png new file mode 100644 index 00000000000..c26066605cd Binary files /dev/null and b/public/images/pokemon/icons/variant/5/587_3.png differ diff --git a/public/images/pokemon/icons/variant/5/588_2.png b/public/images/pokemon/icons/variant/5/588_2.png new file mode 100644 index 00000000000..df99218cedd Binary files /dev/null and b/public/images/pokemon/icons/variant/5/588_2.png differ diff --git a/public/images/pokemon/icons/variant/5/588_3.png b/public/images/pokemon/icons/variant/5/588_3.png new file mode 100644 index 00000000000..3d9277308c7 Binary files /dev/null and b/public/images/pokemon/icons/variant/5/588_3.png differ diff --git a/public/images/pokemon/icons/variant/5/589_2.png b/public/images/pokemon/icons/variant/5/589_2.png new file mode 100644 index 00000000000..ada32c980c1 Binary files /dev/null and b/public/images/pokemon/icons/variant/5/589_2.png differ diff --git a/public/images/pokemon/icons/variant/5/589_3.png b/public/images/pokemon/icons/variant/5/589_3.png new file mode 100644 index 00000000000..1f612c4e8a5 Binary files /dev/null and b/public/images/pokemon/icons/variant/5/589_3.png differ diff --git a/public/images/pokemon/icons/variant/5/590_2.png b/public/images/pokemon/icons/variant/5/590_2.png new file mode 100644 index 00000000000..66c3767024b Binary files /dev/null and b/public/images/pokemon/icons/variant/5/590_2.png differ diff --git a/public/images/pokemon/icons/variant/5/590_3.png b/public/images/pokemon/icons/variant/5/590_3.png new file mode 100644 index 00000000000..d18ccb42e21 Binary files /dev/null and b/public/images/pokemon/icons/variant/5/590_3.png differ diff --git a/public/images/pokemon/icons/variant/5/591_2.png b/public/images/pokemon/icons/variant/5/591_2.png new file mode 100644 index 00000000000..dad56af2559 Binary files /dev/null and b/public/images/pokemon/icons/variant/5/591_2.png differ diff --git a/public/images/pokemon/icons/variant/5/591_3.png b/public/images/pokemon/icons/variant/5/591_3.png new file mode 100644 index 00000000000..a407a14b83a Binary files /dev/null and b/public/images/pokemon/icons/variant/5/591_3.png differ diff --git a/public/images/pokemon/icons/variant/5/616_2.png b/public/images/pokemon/icons/variant/5/616_2.png new file mode 100644 index 00000000000..88e45da0238 Binary files /dev/null and b/public/images/pokemon/icons/variant/5/616_2.png differ diff --git a/public/images/pokemon/icons/variant/5/616_3.png b/public/images/pokemon/icons/variant/5/616_3.png new file mode 100644 index 00000000000..b1767da8fdd Binary files /dev/null and b/public/images/pokemon/icons/variant/5/616_3.png differ diff --git a/public/images/pokemon/icons/variant/5/617_2.png b/public/images/pokemon/icons/variant/5/617_2.png new file mode 100644 index 00000000000..fff02c3f344 Binary files /dev/null and b/public/images/pokemon/icons/variant/5/617_2.png differ diff --git a/public/images/pokemon/icons/variant/5/617_3.png b/public/images/pokemon/icons/variant/5/617_3.png new file mode 100644 index 00000000000..b3f05f31db2 Binary files /dev/null and b/public/images/pokemon/icons/variant/5/617_3.png differ diff --git a/public/images/pokemon/icons/variant/5/621_2.png b/public/images/pokemon/icons/variant/5/621_2.png new file mode 100644 index 00000000000..dbaa26325d8 Binary files /dev/null and b/public/images/pokemon/icons/variant/5/621_2.png differ diff --git a/public/images/pokemon/icons/variant/5/621_3.png b/public/images/pokemon/icons/variant/5/621_3.png new file mode 100644 index 00000000000..190ffb11dc3 Binary files /dev/null and b/public/images/pokemon/icons/variant/5/621_3.png differ diff --git a/public/images/pokemon/icons/variant/6/656_2.png b/public/images/pokemon/icons/variant/6/656_2.png new file mode 100644 index 00000000000..612386a5d1e Binary files /dev/null and b/public/images/pokemon/icons/variant/6/656_2.png differ diff --git a/public/images/pokemon/icons/variant/6/656_3.png b/public/images/pokemon/icons/variant/6/656_3.png new file mode 100644 index 00000000000..575cf3aef3a Binary files /dev/null and b/public/images/pokemon/icons/variant/6/656_3.png differ diff --git a/public/images/pokemon/icons/variant/6/657_2.png b/public/images/pokemon/icons/variant/6/657_2.png new file mode 100644 index 00000000000..9f26c5f85bf Binary files /dev/null and b/public/images/pokemon/icons/variant/6/657_2.png differ diff --git a/public/images/pokemon/icons/variant/6/657_3.png b/public/images/pokemon/icons/variant/6/657_3.png new file mode 100644 index 00000000000..fde76bb8d1c Binary files /dev/null and b/public/images/pokemon/icons/variant/6/657_3.png differ diff --git a/public/images/pokemon/icons/variant/6/658-ash_2.png b/public/images/pokemon/icons/variant/6/658-ash_2.png new file mode 100644 index 00000000000..b788b336efe Binary files /dev/null and b/public/images/pokemon/icons/variant/6/658-ash_2.png differ diff --git a/public/images/pokemon/icons/variant/6/658-ash_3.png b/public/images/pokemon/icons/variant/6/658-ash_3.png new file mode 100644 index 00000000000..52ac4fe0ede Binary files /dev/null and b/public/images/pokemon/icons/variant/6/658-ash_3.png differ diff --git a/public/images/pokemon/icons/variant/6/658_2.png b/public/images/pokemon/icons/variant/6/658_2.png new file mode 100644 index 00000000000..eaf9da8a9ce Binary files /dev/null and b/public/images/pokemon/icons/variant/6/658_2.png differ diff --git a/public/images/pokemon/icons/variant/6/658_3.png b/public/images/pokemon/icons/variant/6/658_3.png new file mode 100644 index 00000000000..027dda592f0 Binary files /dev/null and b/public/images/pokemon/icons/variant/6/658_3.png differ diff --git a/public/images/pokemon/icons/variant/6/676-dandy_2.png b/public/images/pokemon/icons/variant/6/676-dandy_2.png new file mode 100644 index 00000000000..2fb1a1a01b6 Binary files /dev/null and b/public/images/pokemon/icons/variant/6/676-dandy_2.png differ diff --git a/public/images/pokemon/icons/variant/6/676-dandy_3.png b/public/images/pokemon/icons/variant/6/676-dandy_3.png new file mode 100644 index 00000000000..ac05ae8dd3a Binary files /dev/null and b/public/images/pokemon/icons/variant/6/676-dandy_3.png differ diff --git a/public/images/pokemon/icons/variant/6/676-debutante_2.png b/public/images/pokemon/icons/variant/6/676-debutante_2.png new file mode 100644 index 00000000000..9ec13ca1964 Binary files /dev/null and b/public/images/pokemon/icons/variant/6/676-debutante_2.png differ diff --git a/public/images/pokemon/icons/variant/6/676-debutante_3.png b/public/images/pokemon/icons/variant/6/676-debutante_3.png new file mode 100644 index 00000000000..aef6da0a1fd Binary files /dev/null and b/public/images/pokemon/icons/variant/6/676-debutante_3.png differ diff --git a/public/images/pokemon/icons/variant/6/676-diamond_2.png b/public/images/pokemon/icons/variant/6/676-diamond_2.png new file mode 100644 index 00000000000..1406640a69c Binary files /dev/null and b/public/images/pokemon/icons/variant/6/676-diamond_2.png differ diff --git a/public/images/pokemon/icons/variant/6/676-diamond_3.png b/public/images/pokemon/icons/variant/6/676-diamond_3.png new file mode 100644 index 00000000000..ccf477d6819 Binary files /dev/null and b/public/images/pokemon/icons/variant/6/676-diamond_3.png differ diff --git a/public/images/pokemon/icons/variant/6/676-heart_2.png b/public/images/pokemon/icons/variant/6/676-heart_2.png new file mode 100644 index 00000000000..7f3607f8579 Binary files /dev/null and b/public/images/pokemon/icons/variant/6/676-heart_2.png differ diff --git a/public/images/pokemon/icons/variant/6/676-heart_3.png b/public/images/pokemon/icons/variant/6/676-heart_3.png new file mode 100644 index 00000000000..e8256f783ba Binary files /dev/null and b/public/images/pokemon/icons/variant/6/676-heart_3.png differ diff --git a/public/images/pokemon/icons/variant/6/676-kabuki_2.png b/public/images/pokemon/icons/variant/6/676-kabuki_2.png new file mode 100644 index 00000000000..ea78810582a Binary files /dev/null and b/public/images/pokemon/icons/variant/6/676-kabuki_2.png differ diff --git a/public/images/pokemon/icons/variant/6/676-kabuki_3.png b/public/images/pokemon/icons/variant/6/676-kabuki_3.png new file mode 100644 index 00000000000..f8501bec610 Binary files /dev/null and b/public/images/pokemon/icons/variant/6/676-kabuki_3.png differ diff --git a/public/images/pokemon/icons/variant/6/676-la-reine_2.png b/public/images/pokemon/icons/variant/6/676-la-reine_2.png new file mode 100644 index 00000000000..5d4cb6bbea0 Binary files /dev/null and b/public/images/pokemon/icons/variant/6/676-la-reine_2.png differ diff --git a/public/images/pokemon/icons/variant/6/676-la-reine_3.png b/public/images/pokemon/icons/variant/6/676-la-reine_3.png new file mode 100644 index 00000000000..57488ba17e2 Binary files /dev/null and b/public/images/pokemon/icons/variant/6/676-la-reine_3.png differ diff --git a/public/images/pokemon/icons/variant/6/676-matron_2.png b/public/images/pokemon/icons/variant/6/676-matron_2.png new file mode 100644 index 00000000000..e7bd18d5a10 Binary files /dev/null and b/public/images/pokemon/icons/variant/6/676-matron_2.png differ diff --git a/public/images/pokemon/icons/variant/6/676-matron_3.png b/public/images/pokemon/icons/variant/6/676-matron_3.png new file mode 100644 index 00000000000..a8870d9ed20 Binary files /dev/null and b/public/images/pokemon/icons/variant/6/676-matron_3.png differ diff --git a/public/images/pokemon/icons/variant/6/676-pharaoh_2.png b/public/images/pokemon/icons/variant/6/676-pharaoh_2.png new file mode 100644 index 00000000000..96d60fa6d4c Binary files /dev/null and b/public/images/pokemon/icons/variant/6/676-pharaoh_2.png differ diff --git a/public/images/pokemon/icons/variant/6/676-pharaoh_3.png b/public/images/pokemon/icons/variant/6/676-pharaoh_3.png new file mode 100644 index 00000000000..db2de83c8ef Binary files /dev/null and b/public/images/pokemon/icons/variant/6/676-pharaoh_3.png differ diff --git a/public/images/pokemon/icons/variant/6/676-star_2.png b/public/images/pokemon/icons/variant/6/676-star_2.png new file mode 100644 index 00000000000..e2a58c698f6 Binary files /dev/null and b/public/images/pokemon/icons/variant/6/676-star_2.png differ diff --git a/public/images/pokemon/icons/variant/6/676-star_3.png b/public/images/pokemon/icons/variant/6/676-star_3.png new file mode 100644 index 00000000000..7c4fdc4efb1 Binary files /dev/null and b/public/images/pokemon/icons/variant/6/676-star_3.png differ diff --git a/public/images/pokemon/icons/variant/6/676_2.png b/public/images/pokemon/icons/variant/6/676_2.png new file mode 100644 index 00000000000..56bcc1a7a34 Binary files /dev/null and b/public/images/pokemon/icons/variant/6/676_2.png differ diff --git a/public/images/pokemon/icons/variant/6/676_3.png b/public/images/pokemon/icons/variant/6/676_3.png new file mode 100644 index 00000000000..accb6f96f66 Binary files /dev/null and b/public/images/pokemon/icons/variant/6/676_3.png differ diff --git a/public/images/pokemon/icons/variant/6/682_2.png b/public/images/pokemon/icons/variant/6/682_2.png new file mode 100644 index 00000000000..59c05cce665 Binary files /dev/null and b/public/images/pokemon/icons/variant/6/682_2.png differ diff --git a/public/images/pokemon/icons/variant/6/682_3.png b/public/images/pokemon/icons/variant/6/682_3.png new file mode 100644 index 00000000000..a7c73e94eef Binary files /dev/null and b/public/images/pokemon/icons/variant/6/682_3.png differ diff --git a/public/images/pokemon/icons/variant/6/683_2.png b/public/images/pokemon/icons/variant/6/683_2.png new file mode 100644 index 00000000000..7f64665f9d7 Binary files /dev/null and b/public/images/pokemon/icons/variant/6/683_2.png differ diff --git a/public/images/pokemon/icons/variant/6/683_3.png b/public/images/pokemon/icons/variant/6/683_3.png new file mode 100644 index 00000000000..b09a0be5fd2 Binary files /dev/null and b/public/images/pokemon/icons/variant/6/683_3.png differ diff --git a/public/images/pokemon/icons/variant/6/684_2.png b/public/images/pokemon/icons/variant/6/684_2.png new file mode 100644 index 00000000000..2fccca23416 Binary files /dev/null and b/public/images/pokemon/icons/variant/6/684_2.png differ diff --git a/public/images/pokemon/icons/variant/6/684_3.png b/public/images/pokemon/icons/variant/6/684_3.png new file mode 100644 index 00000000000..9c09475db49 Binary files /dev/null and b/public/images/pokemon/icons/variant/6/684_3.png differ diff --git a/public/images/pokemon/icons/variant/6/685_2.png b/public/images/pokemon/icons/variant/6/685_2.png new file mode 100644 index 00000000000..8f52850dd2d Binary files /dev/null and b/public/images/pokemon/icons/variant/6/685_2.png differ diff --git a/public/images/pokemon/icons/variant/6/685_3.png b/public/images/pokemon/icons/variant/6/685_3.png new file mode 100644 index 00000000000..ebad502551e Binary files /dev/null and b/public/images/pokemon/icons/variant/6/685_3.png differ diff --git a/public/images/pokemon/icons/variant/6/688_2.png b/public/images/pokemon/icons/variant/6/688_2.png new file mode 100644 index 00000000000..6fe8ba9c770 Binary files /dev/null and b/public/images/pokemon/icons/variant/6/688_2.png differ diff --git a/public/images/pokemon/icons/variant/6/688_3.png b/public/images/pokemon/icons/variant/6/688_3.png new file mode 100644 index 00000000000..9586c3203a9 Binary files /dev/null and b/public/images/pokemon/icons/variant/6/688_3.png differ diff --git a/public/images/pokemon/icons/variant/6/689_2.png b/public/images/pokemon/icons/variant/6/689_2.png new file mode 100644 index 00000000000..66305ef69e8 Binary files /dev/null and b/public/images/pokemon/icons/variant/6/689_2.png differ diff --git a/public/images/pokemon/icons/variant/6/689_3.png b/public/images/pokemon/icons/variant/6/689_3.png new file mode 100644 index 00000000000..2bdfea0ddd0 Binary files /dev/null and b/public/images/pokemon/icons/variant/6/689_3.png differ diff --git a/public/images/pokemon/icons/variant/7/2026_2.png b/public/images/pokemon/icons/variant/7/2026_2.png new file mode 100644 index 00000000000..3b939a6c1fc Binary files /dev/null and b/public/images/pokemon/icons/variant/7/2026_2.png differ diff --git a/public/images/pokemon/icons/variant/7/2026_3.png b/public/images/pokemon/icons/variant/7/2026_3.png new file mode 100644 index 00000000000..f530b9cfcb3 Binary files /dev/null and b/public/images/pokemon/icons/variant/7/2026_3.png differ diff --git a/public/images/pokemon/icons/variant/7/2103_2.png b/public/images/pokemon/icons/variant/7/2103_2.png new file mode 100644 index 00000000000..d3795c35070 Binary files /dev/null and b/public/images/pokemon/icons/variant/7/2103_2.png differ diff --git a/public/images/pokemon/icons/variant/7/2103_3.png b/public/images/pokemon/icons/variant/7/2103_3.png new file mode 100644 index 00000000000..e24ba1eb917 Binary files /dev/null and b/public/images/pokemon/icons/variant/7/2103_3.png differ diff --git a/public/images/pokemon/icons/variant/7/807_2.png b/public/images/pokemon/icons/variant/7/807_2.png new file mode 100644 index 00000000000..6e070af347d Binary files /dev/null and b/public/images/pokemon/icons/variant/7/807_2.png differ diff --git a/public/images/pokemon/icons/variant/7/807_3.png b/public/images/pokemon/icons/variant/7/807_3.png new file mode 100644 index 00000000000..19e59272f86 Binary files /dev/null and b/public/images/pokemon/icons/variant/7/807_3.png differ diff --git a/public/images/pokemon/icons/variant/8/6503_2.png b/public/images/pokemon/icons/variant/8/6503_2.png new file mode 100644 index 00000000000..0098615187e Binary files /dev/null and b/public/images/pokemon/icons/variant/8/6503_2.png differ diff --git a/public/images/pokemon/icons/variant/8/6503_3.png b/public/images/pokemon/icons/variant/8/6503_3.png new file mode 100644 index 00000000000..64428182df0 Binary files /dev/null and b/public/images/pokemon/icons/variant/8/6503_3.png differ diff --git a/public/images/pokemon/icons/variant/8/851-gigantamax.png b/public/images/pokemon/icons/variant/8/851-gigantamax.png new file mode 100644 index 00000000000..e757af7b4fa Binary files /dev/null and b/public/images/pokemon/icons/variant/8/851-gigantamax.png differ diff --git a/public/images/pokemon/icons/variant/8/851-gigantamax_2.png b/public/images/pokemon/icons/variant/8/851-gigantamax_2.png new file mode 100644 index 00000000000..081d8284b3d Binary files /dev/null and b/public/images/pokemon/icons/variant/8/851-gigantamax_2.png differ diff --git a/public/images/pokemon/icons/variant/8/851-gigantamax_3.png b/public/images/pokemon/icons/variant/8/851-gigantamax_3.png new file mode 100644 index 00000000000..6d26a7395f2 Binary files /dev/null and b/public/images/pokemon/icons/variant/8/851-gigantamax_3.png differ diff --git a/public/images/pokemon/icons/variant/8/851s-gigantamax.png b/public/images/pokemon/icons/variant/8/851s-gigantamax.png new file mode 100644 index 00000000000..73fb57b8a5a Binary files /dev/null and b/public/images/pokemon/icons/variant/8/851s-gigantamax.png differ diff --git a/public/images/pokemon/icons/variant/8/894_2.png b/public/images/pokemon/icons/variant/8/894_2.png new file mode 100644 index 00000000000..2b4754d56a0 Binary files /dev/null and b/public/images/pokemon/icons/variant/8/894_2.png differ diff --git a/public/images/pokemon/icons/variant/8/894_3.png b/public/images/pokemon/icons/variant/8/894_3.png new file mode 100644 index 00000000000..cc5baef46cc Binary files /dev/null and b/public/images/pokemon/icons/variant/8/894_3.png differ diff --git a/public/images/pokemon/icons/variant/8/895_2.png b/public/images/pokemon/icons/variant/8/895_2.png new file mode 100644 index 00000000000..bdacf0683ee Binary files /dev/null and b/public/images/pokemon/icons/variant/8/895_2.png differ diff --git a/public/images/pokemon/icons/variant/8/895_3.png b/public/images/pokemon/icons/variant/8/895_3.png new file mode 100644 index 00000000000..9ac023e2e89 Binary files /dev/null and b/public/images/pokemon/icons/variant/8/895_3.png differ diff --git a/public/images/pokemon/icons/variant/8/909_2.png b/public/images/pokemon/icons/variant/8/909_2.png deleted file mode 100644 index 73f71bd49d3..00000000000 Binary files a/public/images/pokemon/icons/variant/8/909_2.png and /dev/null differ diff --git a/public/images/pokemon/icons/variant/8/909_3.png b/public/images/pokemon/icons/variant/8/909_3.png deleted file mode 100644 index 5fb79e5b917..00000000000 Binary files a/public/images/pokemon/icons/variant/8/909_3.png and /dev/null differ diff --git a/public/images/pokemon/icons/variant/8/1003_2.png b/public/images/pokemon/icons/variant/9/1003_2.png similarity index 100% rename from public/images/pokemon/icons/variant/8/1003_2.png rename to public/images/pokemon/icons/variant/9/1003_2.png diff --git a/public/images/pokemon/icons/variant/8/1003_3.png b/public/images/pokemon/icons/variant/9/1003_3.png similarity index 100% rename from public/images/pokemon/icons/variant/8/1003_3.png rename to public/images/pokemon/icons/variant/9/1003_3.png diff --git a/public/images/pokemon/icons/variant/8/1006_2.png b/public/images/pokemon/icons/variant/9/1006_2.png similarity index 100% rename from public/images/pokemon/icons/variant/8/1006_2.png rename to public/images/pokemon/icons/variant/9/1006_2.png diff --git a/public/images/pokemon/icons/variant/8/1006_3.png b/public/images/pokemon/icons/variant/9/1006_3.png similarity index 100% rename from public/images/pokemon/icons/variant/8/1006_3.png rename to public/images/pokemon/icons/variant/9/1006_3.png diff --git a/public/images/pokemon/icons/variant/8/1010_2.png b/public/images/pokemon/icons/variant/9/1010_2.png similarity index 100% rename from public/images/pokemon/icons/variant/8/1010_2.png rename to public/images/pokemon/icons/variant/9/1010_2.png diff --git a/public/images/pokemon/icons/variant/8/1010_3.png b/public/images/pokemon/icons/variant/9/1010_3.png similarity index 100% rename from public/images/pokemon/icons/variant/8/1010_3.png rename to public/images/pokemon/icons/variant/9/1010_3.png diff --git a/public/images/pokemon/icons/variant/9/1012-counterfeit_2.png b/public/images/pokemon/icons/variant/9/1012-counterfeit_2.png new file mode 100644 index 00000000000..19fa8603c69 Binary files /dev/null and b/public/images/pokemon/icons/variant/9/1012-counterfeit_2.png differ diff --git a/public/images/pokemon/icons/variant/9/1012-counterfeit_3.png b/public/images/pokemon/icons/variant/9/1012-counterfeit_3.png new file mode 100644 index 00000000000..04f74b0fd3a Binary files /dev/null and b/public/images/pokemon/icons/variant/9/1012-counterfeit_3.png differ diff --git a/public/images/pokemon/icons/variant/9/1013-unremarkable_2.png b/public/images/pokemon/icons/variant/9/1013-unremarkable_2.png new file mode 100644 index 00000000000..3588b5e2641 Binary files /dev/null and b/public/images/pokemon/icons/variant/9/1013-unremarkable_2.png differ diff --git a/public/images/pokemon/icons/variant/9/1013-unremarkable_3.png b/public/images/pokemon/icons/variant/9/1013-unremarkable_3.png new file mode 100644 index 00000000000..acdb6716ab8 Binary files /dev/null and b/public/images/pokemon/icons/variant/9/1013-unremarkable_3.png differ diff --git a/public/images/pokemon/icons/variant/9/909_2.png b/public/images/pokemon/icons/variant/9/909_2.png index 95cf5e14d4e..73f71bd49d3 100644 Binary files a/public/images/pokemon/icons/variant/9/909_2.png and b/public/images/pokemon/icons/variant/9/909_2.png differ diff --git a/public/images/pokemon/icons/variant/9/909_3.png b/public/images/pokemon/icons/variant/9/909_3.png index d4d7a9593a4..5fb79e5b917 100644 Binary files a/public/images/pokemon/icons/variant/9/909_3.png and b/public/images/pokemon/icons/variant/9/909_3.png differ diff --git a/public/images/pokemon/icons/variant/8/912_2.png b/public/images/pokemon/icons/variant/9/912_2.png similarity index 100% rename from public/images/pokemon/icons/variant/8/912_2.png rename to public/images/pokemon/icons/variant/9/912_2.png diff --git a/public/images/pokemon/icons/variant/8/912_3.png b/public/images/pokemon/icons/variant/9/912_3.png similarity index 100% rename from public/images/pokemon/icons/variant/8/912_3.png rename to public/images/pokemon/icons/variant/9/912_3.png diff --git a/public/images/pokemon/icons/variant/8/913_2.png b/public/images/pokemon/icons/variant/9/913_2.png similarity index 100% rename from public/images/pokemon/icons/variant/8/913_2.png rename to public/images/pokemon/icons/variant/9/913_2.png diff --git a/public/images/pokemon/icons/variant/8/913_3.png b/public/images/pokemon/icons/variant/9/913_3.png similarity index 100% rename from public/images/pokemon/icons/variant/8/913_3.png rename to public/images/pokemon/icons/variant/9/913_3.png diff --git a/public/images/pokemon/icons/variant/8/914_2.png b/public/images/pokemon/icons/variant/9/914_2.png similarity index 100% rename from public/images/pokemon/icons/variant/8/914_2.png rename to public/images/pokemon/icons/variant/9/914_2.png diff --git a/public/images/pokemon/icons/variant/8/914_3.png b/public/images/pokemon/icons/variant/9/914_3.png similarity index 100% rename from public/images/pokemon/icons/variant/8/914_3.png rename to public/images/pokemon/icons/variant/9/914_3.png diff --git a/public/images/pokemon/icons/variant/8/940_2.png b/public/images/pokemon/icons/variant/9/940_2.png similarity index 100% rename from public/images/pokemon/icons/variant/8/940_2.png rename to public/images/pokemon/icons/variant/9/940_2.png diff --git a/public/images/pokemon/icons/variant/8/940_3.png b/public/images/pokemon/icons/variant/9/940_3.png similarity index 100% rename from public/images/pokemon/icons/variant/8/940_3.png rename to public/images/pokemon/icons/variant/9/940_3.png diff --git a/public/images/pokemon/icons/variant/8/941_2.png b/public/images/pokemon/icons/variant/9/941_2.png similarity index 100% rename from public/images/pokemon/icons/variant/8/941_2.png rename to public/images/pokemon/icons/variant/9/941_2.png diff --git a/public/images/pokemon/icons/variant/8/941_3.png b/public/images/pokemon/icons/variant/9/941_3.png similarity index 100% rename from public/images/pokemon/icons/variant/8/941_3.png rename to public/images/pokemon/icons/variant/9/941_3.png diff --git a/public/images/pokemon/variant/back/6706_3.png b/public/images/pokemon/icons/variant/9/944_2.png similarity index 56% rename from public/images/pokemon/variant/back/6706_3.png rename to public/images/pokemon/icons/variant/9/944_2.png index fb780d01499..70af4937c8f 100644 Binary files a/public/images/pokemon/variant/back/6706_3.png and b/public/images/pokemon/icons/variant/9/944_2.png differ diff --git a/public/images/pokemon/variant/6706_2.png b/public/images/pokemon/icons/variant/9/944_3.png similarity index 51% rename from public/images/pokemon/variant/6706_2.png rename to public/images/pokemon/icons/variant/9/944_3.png index 7cf1495d1a3..ef7618c9a9c 100644 Binary files a/public/images/pokemon/variant/6706_2.png and b/public/images/pokemon/icons/variant/9/944_3.png differ diff --git a/public/images/pokemon/variant/6706_3.png b/public/images/pokemon/icons/variant/9/945_2.png similarity index 51% rename from public/images/pokemon/variant/6706_3.png rename to public/images/pokemon/icons/variant/9/945_2.png index 001cab641f1..5a4a7c6ebe5 100644 Binary files a/public/images/pokemon/variant/6706_3.png and b/public/images/pokemon/icons/variant/9/945_2.png differ diff --git a/public/images/pokemon/icons/variant/9/945_3.png b/public/images/pokemon/icons/variant/9/945_3.png new file mode 100644 index 00000000000..1dad94c543c Binary files /dev/null and b/public/images/pokemon/icons/variant/9/945_3.png differ diff --git a/public/images/pokemon/icons/variant/8/953_2.png b/public/images/pokemon/icons/variant/9/953_2.png similarity index 100% rename from public/images/pokemon/icons/variant/8/953_2.png rename to public/images/pokemon/icons/variant/9/953_2.png diff --git a/public/images/pokemon/icons/variant/8/953_3.png b/public/images/pokemon/icons/variant/9/953_3.png similarity index 100% rename from public/images/pokemon/icons/variant/8/953_3.png rename to public/images/pokemon/icons/variant/9/953_3.png diff --git a/public/images/pokemon/icons/variant/8/954_2.png b/public/images/pokemon/icons/variant/9/954_2.png similarity index 100% rename from public/images/pokemon/icons/variant/8/954_2.png rename to public/images/pokemon/icons/variant/9/954_2.png diff --git a/public/images/pokemon/icons/variant/8/954_3.png b/public/images/pokemon/icons/variant/9/954_3.png similarity index 100% rename from public/images/pokemon/icons/variant/8/954_3.png rename to public/images/pokemon/icons/variant/9/954_3.png diff --git a/public/images/pokemon/icons/variant/8/981_2.png b/public/images/pokemon/icons/variant/9/981_2.png similarity index 100% rename from public/images/pokemon/icons/variant/8/981_2.png rename to public/images/pokemon/icons/variant/9/981_2.png diff --git a/public/images/pokemon/icons/variant/8/981_3.png b/public/images/pokemon/icons/variant/9/981_3.png similarity index 100% rename from public/images/pokemon/icons/variant/8/981_3.png rename to public/images/pokemon/icons/variant/9/981_3.png diff --git a/public/images/pokemon/shiny/194.png b/public/images/pokemon/shiny/194.png index 2e33bbfd005..38800a7d545 100644 Binary files a/public/images/pokemon/shiny/194.png and b/public/images/pokemon/shiny/194.png differ diff --git a/public/images/pokemon/shiny/275.png b/public/images/pokemon/shiny/275.png index fee57d64804..de8271cdbd2 100644 Binary files a/public/images/pokemon/shiny/275.png and b/public/images/pokemon/shiny/275.png differ diff --git a/public/images/pokemon/shiny/280.png b/public/images/pokemon/shiny/280.png index 368bb2dca70..918c84b9ee8 100644 Binary files a/public/images/pokemon/shiny/280.png and b/public/images/pokemon/shiny/280.png differ diff --git a/public/images/pokemon/shiny/281.json b/public/images/pokemon/shiny/281.json index 684be77edf9..64e10c7f9a6 100644 --- a/public/images/pokemon/shiny/281.json +++ b/public/images/pokemon/shiny/281.json @@ -399,13 +399,13 @@ "x": 0, "y": 6, "w": 36, - "h": 55 + "h": 54 }, "frame": { "x": 72, "y": 55, "w": 36, - "h": 55 + "h": 54 } }, { @@ -420,13 +420,13 @@ "x": 0, "y": 6, "w": 36, - "h": 55 + "h": 54 }, "frame": { "x": 72, "y": 55, "w": 36, - "h": 55 + "h": 54 } }, { diff --git a/public/images/pokemon/shiny/281.png b/public/images/pokemon/shiny/281.png index a658631150b..97ca88d5c64 100644 Binary files a/public/images/pokemon/shiny/281.png and b/public/images/pokemon/shiny/281.png differ diff --git a/public/images/pokemon/shiny/282.png b/public/images/pokemon/shiny/282.png index 5628732c8df..01fb6e5d7ef 100644 Binary files a/public/images/pokemon/shiny/282.png and b/public/images/pokemon/shiny/282.png differ diff --git a/public/images/pokemon/shiny/378.png b/public/images/pokemon/shiny/378.png index 62322276ec1..7674ac1873a 100644 Binary files a/public/images/pokemon/shiny/378.png and b/public/images/pokemon/shiny/378.png differ diff --git a/public/images/pokemon/shiny/4144.png b/public/images/pokemon/shiny/4144.png index 16bd3df256d..a17083ade49 100644 Binary files a/public/images/pokemon/shiny/4144.png and b/public/images/pokemon/shiny/4144.png differ diff --git a/public/images/pokemon/shiny/4145.png b/public/images/pokemon/shiny/4145.png index 2750db6fd6f..bd6e602d32f 100644 Binary files a/public/images/pokemon/shiny/4145.png and b/public/images/pokemon/shiny/4145.png differ diff --git a/public/images/pokemon/shiny/4146.png b/public/images/pokemon/shiny/4146.png index b1b5aec78a5..b7a3157782b 100644 Binary files a/public/images/pokemon/shiny/4146.png and b/public/images/pokemon/shiny/4146.png differ diff --git a/public/images/pokemon/shiny/436.json b/public/images/pokemon/shiny/436.json index 945a840b477..6206c5e66cb 100644 --- a/public/images/pokemon/shiny/436.json +++ b/public/images/pokemon/shiny/436.json @@ -1,2666 +1,1019 @@ -{ - "textures": [ - { - "image": "436.png", - "format": "RGBA8888", - "size": { - "w": 97, - "h": 97 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 5, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 5, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 5, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 5, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 8, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 5, - "y": 9, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 5, - "y": 9, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 10, - "y": 8, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 10, - "y": 8, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 9, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 5, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 5, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 4, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 4, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 3, - "y": 8, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 3, - "y": 8, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 5, - "y": 6, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 5, - "y": 6, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 5, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 5, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 9, - "y": 6, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 9, - "y": 6, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 11, - "y": 8, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 11, - "y": 8, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 10, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 10, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 9, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 9, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 4, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 4, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 3, - "y": 9, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 3, - "y": 9, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 1, - "y": 6, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 1, - "y": 6, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 4, - "y": 3, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 4, - "y": 3, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 2, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 2, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 10, - "y": 3, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 10, - "y": 3, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 13, - "y": 6, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 13, - "y": 6, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 11, - "y": 9, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 11, - "y": 9, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 10, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 10, - "y": 11, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 3, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 3, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 1, - "y": 8, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 1, - "y": 8, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 11, - "y": 4, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 11, - "y": 4, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 13, - "y": 14, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 13, - "y": 14, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 10, - "y": 17, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 10, - "y": 17, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 15, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 15, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 8, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 8, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 9, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 9, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 6, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 6, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 8, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 8, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 10, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 12, - "w": 33, - "h": 39 - }, - "frame": { - "x": 0, - "y": 0, - "w": 33, - "h": 39 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 0, - "y": 4, - "w": 32, - "h": 39 - }, - "frame": { - "x": 33, - "y": 0, - "w": 32, - "h": 39 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 0, - "y": 4, - "w": 32, - "h": 39 - }, - "frame": { - "x": 33, - "y": 0, - "w": 32, - "h": 39 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 15, - "y": 9, - "w": 32, - "h": 39 - }, - "frame": { - "x": 65, - "y": 0, - "w": 32, - "h": 39 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 15, - "y": 9, - "w": 32, - "h": 39 - }, - "frame": { - "x": 65, - "y": 0, - "w": 32, - "h": 39 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 0, - "w": 33, - "h": 38 - }, - "frame": { - "x": 0, - "y": 39, - "w": 33, - "h": 38 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 7, - "y": 0, - "w": 33, - "h": 38 - }, - "frame": { - "x": 0, - "y": 39, - "w": 33, - "h": 38 - } - }, - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 5, - "y": 21, - "w": 33, - "h": 38 - }, - "frame": { - "x": 33, - "y": 39, - "w": 33, - "h": 38 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 47, - "h": 59 - }, - "spriteSourceSize": { - "x": 5, - "y": 21, - "w": 33, - "h": 38 - }, - "frame": { - "x": 33, - "y": 39, - "w": 33, - "h": 38 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:de8b910298717773b7a2a224a56b3553:df42ff52dc55f342b76506445413ffee:0a3bacf3d680738b160c4c8ace3cda59$" - } -} +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0002.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0003.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0004.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0005.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0006.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0007.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0008.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0009.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0010.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0011.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0012.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0013.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0014.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0015.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0016.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0017.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0018.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0019.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0020.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0021.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0022.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0023.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0024.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0025.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0026.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0027.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0028.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0029.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0030.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0031.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0032.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0033.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0034.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0035.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0036.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0037.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 10, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0038.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 10, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0039.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0040.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0041.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0042.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0043.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0044.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0045.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 11, "y": 9, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0046.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 11, "y": 9, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0047.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0048.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0049.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0050.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0051.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0052.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0053.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0054.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0055.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 9, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0056.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 9, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0057.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 7, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0058.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 7, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0059.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 6, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0060.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 6, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0061.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 7, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0062.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 7, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0063.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 9, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0064.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 9, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0065.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 11, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0066.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 11, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0067.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0068.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 10, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0069.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0070.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0071.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0072.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0073.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 10, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0074.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 10, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0075.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 2, "y": 7, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0076.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 2, "y": 7, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0077.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 4, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0078.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 5, "y": 4, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0079.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 3, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0080.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 3, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0081.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 11, "y": 4, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0082.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 11, "y": 4, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0083.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 14, "y": 7, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0084.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 14, "y": 7, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0085.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 10, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0086.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 10, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0087.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 11, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0088.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 11, "y": 12, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0089.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0090.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0091.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0092.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0093.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 2, "y": 9, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0094.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 2, "y": 9, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0095.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 0, "y": 5, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0096.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 0, "y": 5, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0097.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 1, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0098.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 4, "y": 1, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0099.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 0, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0100.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 0, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0101.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 5, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0102.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 5, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0103.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 16, "y": 10, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0104.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 16, "y": 10, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0105.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 14, "y": 15, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0106.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 14, "y": 15, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0107.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 11, "y": 18, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0108.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 11, "y": 18, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0109.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 22, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0110.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 6, "y": 22, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0111.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 19, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0112.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 7, "y": 19, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0113.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 16, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0114.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 16, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0115.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0116.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0117.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 10, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0118.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 10, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0119.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 7, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0120.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 7, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0121.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 9, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0122.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 9, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0123.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0124.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 11, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0125.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + }, + { + "filename": "0126.png", + "frame": { "x": 0, "y": 0, "w": 31, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 8, "y": 13, "w": 31, "h": 37 }, + "sourceSize": { "w": 47, "h": 59 } + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.7-dev", + "image": "436.png", + "format": "RGBA8888", + "size": { "w": 31, "h": 37 }, + "scale": "1" + } +} diff --git a/public/images/pokemon/shiny/436.png b/public/images/pokemon/shiny/436.png index 59003ba85dc..87263bbbe6c 100644 Binary files a/public/images/pokemon/shiny/436.png and b/public/images/pokemon/shiny/436.png differ diff --git a/public/images/pokemon/shiny/454.png b/public/images/pokemon/shiny/454.png index 355fdf035cd..232c3cb30a0 100644 Binary files a/public/images/pokemon/shiny/454.png and b/public/images/pokemon/shiny/454.png differ diff --git a/public/images/pokemon/shiny/493_fairy.png b/public/images/pokemon/shiny/493_fairy.png deleted file mode 100644 index f8b09991951..00000000000 Binary files a/public/images/pokemon/shiny/493_fairy.png and /dev/null differ diff --git a/public/images/pokemon/shiny/582.json b/public/images/pokemon/shiny/582.json index e9ee1633280..4c4897e92f4 100644 --- a/public/images/pokemon/shiny/582.json +++ b/public/images/pokemon/shiny/582.json @@ -1,2267 +1,867 @@ -{ - "textures": [ - { - "image": "582.png", - "format": "RGBA8888", - "size": { - "w": 188, - "h": 188 - }, - "scale": 1, - "frames": [ - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 0, - "y": 5, - "w": 50, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 50, - "h": 40 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 0, - "y": 5, - "w": 50, - "h": 40 - }, - "frame": { - "x": 0, - "y": 0, - "w": 50, - "h": 40 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 2, - "y": 5, - "w": 50, - "h": 40 - }, - "frame": { - "x": 0, - "y": 40, - "w": 50, - "h": 40 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 2, - "y": 5, - "w": 50, - "h": 40 - }, - "frame": { - "x": 0, - "y": 40, - "w": 50, - "h": 40 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 6, - "y": 4, - "w": 48, - "h": 41 - }, - "frame": { - "x": 50, - "y": 0, - "w": 48, - "h": 41 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 6, - "y": 4, - "w": 48, - "h": 41 - }, - "frame": { - "x": 50, - "y": 0, - "w": 48, - "h": 41 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 9, - "y": 4, - "w": 47, - "h": 41 - }, - "frame": { - "x": 0, - "y": 80, - "w": 47, - "h": 41 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 9, - "y": 4, - "w": 47, - "h": 41 - }, - "frame": { - "x": 0, - "y": 80, - "w": 47, - "h": 41 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 14, - "y": 3, - "w": 42, - "h": 39 - }, - "frame": { - "x": 50, - "y": 41, - "w": 42, - "h": 39 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 14, - "y": 3, - "w": 42, - "h": 39 - }, - "frame": { - "x": 50, - "y": 41, - "w": 42, - "h": 39 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 5, - "w": 40, - "h": 39 - }, - "frame": { - "x": 98, - "y": 0, - "w": 40, - "h": 39 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 7, - "y": 5, - "w": 40, - "h": 39 - }, - "frame": { - "x": 98, - "y": 0, - "w": 40, - "h": 39 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 17, - "y": 2, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 121, - "w": 39, - "h": 38 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 17, - "y": 2, - "w": 39, - "h": 38 - }, - "frame": { - "x": 0, - "y": 121, - "w": 39, - "h": 38 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 5, - "w": 38, - "h": 38 - }, - "frame": { - "x": 47, - "y": 80, - "w": 38, - "h": 38 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 8, - "y": 5, - "w": 38, - "h": 38 - }, - "frame": { - "x": 47, - "y": 80, - "w": 38, - "h": 38 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 18, - "y": 1, - "w": 38, - "h": 38 - }, - "frame": { - "x": 138, - "y": 0, - "w": 38, - "h": 38 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 18, - "y": 1, - "w": 38, - "h": 38 - }, - "frame": { - "x": 138, - "y": 0, - "w": 38, - "h": 38 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 2, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 2, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 4, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 4, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 5, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 5, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 2, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 2, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 4, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 4, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 5, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 5, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 2, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 2, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 4, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 4, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 5, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 5, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 29, - "y": 2, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 29, - "y": 2, - "w": 26, - "h": 38 - }, - "frame": { - "x": 39, - "y": 121, - "w": 26, - "h": 38 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 14, - "y": 5, - "w": 34, - "h": 39 - }, - "frame": { - "x": 65, - "y": 118, - "w": 34, - "h": 39 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 14, - "y": 5, - "w": 34, - "h": 39 - }, - "frame": { - "x": 65, - "y": 118, - "w": 34, - "h": 39 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 85, - "y": 80, - "w": 26, - "h": 38 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 85, - "y": 80, - "w": 26, - "h": 38 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 85, - "y": 80, - "w": 26, - "h": 38 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 85, - "y": 80, - "w": 26, - "h": 38 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 85, - "y": 80, - "w": 26, - "h": 38 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 85, - "y": 80, - "w": 26, - "h": 38 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 99, - "y": 118, - "w": 26, - "h": 38 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 99, - "y": 118, - "w": 26, - "h": 38 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 99, - "y": 118, - "w": 26, - "h": 38 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 99, - "y": 118, - "w": 26, - "h": 38 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 99, - "y": 118, - "w": 26, - "h": 38 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 99, - "y": 118, - "w": 26, - "h": 38 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 99, - "y": 118, - "w": 26, - "h": 38 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 99, - "y": 118, - "w": 26, - "h": 38 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 99, - "y": 118, - "w": 26, - "h": 38 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 99, - "y": 118, - "w": 26, - "h": 38 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 99, - "y": 118, - "w": 26, - "h": 38 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 99, - "y": 118, - "w": 26, - "h": 38 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 92, - "y": 41, - "w": 26, - "h": 38 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 92, - "y": 41, - "w": 26, - "h": 38 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 92, - "y": 41, - "w": 26, - "h": 38 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 92, - "y": 41, - "w": 26, - "h": 38 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 92, - "y": 41, - "w": 26, - "h": 38 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 1, - "w": 26, - "h": 38 - }, - "frame": { - "x": 92, - "y": 41, - "w": 26, - "h": 38 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 27, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 118, - "y": 39, - "w": 26, - "h": 38 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 27, - "y": 3, - "w": 26, - "h": 38 - }, - "frame": { - "x": 118, - "y": 39, - "w": 26, - "h": 38 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 21, - "y": 1, - "w": 35, - "h": 38 - }, - "frame": { - "x": 144, - "y": 38, - "w": 35, - "h": 38 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 21, - "y": 1, - "w": 35, - "h": 38 - }, - "frame": { - "x": 144, - "y": 38, - "w": 35, - "h": 38 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 22, - "y": 1, - "w": 34, - "h": 38 - }, - "frame": { - "x": 111, - "y": 79, - "w": 34, - "h": 38 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 22, - "y": 1, - "w": 34, - "h": 38 - }, - "frame": { - "x": 111, - "y": 79, - "w": 34, - "h": 38 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 24, - "y": 1, - "w": 32, - "h": 38 - }, - "frame": { - "x": 145, - "y": 76, - "w": 32, - "h": 38 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 0, - "w": 26, - "h": 37 - }, - "frame": { - "x": 125, - "y": 117, - "w": 26, - "h": 37 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 0, - "w": 26, - "h": 37 - }, - "frame": { - "x": 125, - "y": 117, - "w": 26, - "h": 37 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 0, - "w": 26, - "h": 37 - }, - "frame": { - "x": 125, - "y": 117, - "w": 26, - "h": 37 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 0, - "w": 26, - "h": 37 - }, - "frame": { - "x": 125, - "y": 117, - "w": 26, - "h": 37 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 0, - "w": 26, - "h": 37 - }, - "frame": { - "x": 125, - "y": 117, - "w": 26, - "h": 37 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 0, - "w": 26, - "h": 37 - }, - "frame": { - "x": 125, - "y": 117, - "w": 26, - "h": 37 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 0, - "w": 26, - "h": 37 - }, - "frame": { - "x": 125, - "y": 117, - "w": 26, - "h": 37 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 0, - "w": 26, - "h": 37 - }, - "frame": { - "x": 125, - "y": 117, - "w": 26, - "h": 37 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 0, - "w": 26, - "h": 37 - }, - "frame": { - "x": 125, - "y": 117, - "w": 26, - "h": 37 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 0, - "w": 26, - "h": 37 - }, - "frame": { - "x": 125, - "y": 117, - "w": 26, - "h": 37 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 0, - "w": 26, - "h": 37 - }, - "frame": { - "x": 125, - "y": 117, - "w": 26, - "h": 37 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 30, - "y": 0, - "w": 26, - "h": 37 - }, - "frame": { - "x": 125, - "y": 117, - "w": 26, - "h": 37 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 25, - "y": 4, - "w": 26, - "h": 37 - }, - "frame": { - "x": 151, - "y": 114, - "w": 26, - "h": 37 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 25, - "y": 4, - "w": 26, - "h": 37 - }, - "frame": { - "x": 151, - "y": 114, - "w": 26, - "h": 37 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 20, - "y": 4, - "w": 26, - "h": 37 - }, - "frame": { - "x": 151, - "y": 151, - "w": 26, - "h": 37 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 56, - "h": 45 - }, - "spriteSourceSize": { - "x": 20, - "y": 4, - "w": 26, - "h": 37 - }, - "frame": { - "x": 151, - "y": 151, - "w": 26, - "h": 37 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:f5205e9bbe4b21a350374c6d51dc8048:e639cc2e542e4cea00e37486ad8c758d:537948334556891ed421a4fc828e3e53$" - } +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0002.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0003.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 3, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0004.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 3, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0005.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0006.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0007.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 5, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0008.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 5, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0009.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 6, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0010.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 6, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0011.png", + "frame": { "x": 0, "y": 76, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0012.png", + "frame": { "x": 0, "y": 76, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0013.png", + "frame": { "x": 24, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0014.png", + "frame": { "x": 24, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0015.png", + "frame": { "x": 48, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 0, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0016.png", + "frame": { "x": 48, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 0, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0017.png", + "frame": { "x": 106, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0018.png", + "frame": { "x": 106, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0019.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0020.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0021.png", + "frame": { "x": 24, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0022.png", + "frame": { "x": 24, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0023.png", + "frame": { "x": 48, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 0, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0024.png", + "frame": { "x": 48, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 0, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0025.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0026.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0027.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 3, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0028.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 3, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0029.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0030.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0031.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 5, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0032.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 5, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0033.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 6, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0034.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 6, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0035.png", + "frame": { "x": 0, "y": 76, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0036.png", + "frame": { "x": 0, "y": 76, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0037.png", + "frame": { "x": 24, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0038.png", + "frame": { "x": 24, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0039.png", + "frame": { "x": 48, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 0, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0040.png", + "frame": { "x": 48, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 0, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0041.png", + "frame": { "x": 106, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0042.png", + "frame": { "x": 106, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0043.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0044.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0045.png", + "frame": { "x": 24, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0046.png", + "frame": { "x": 24, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0047.png", + "frame": { "x": 48, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 0, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0048.png", + "frame": { "x": 48, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 0, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0049.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0050.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0051.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 3, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0052.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 3, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0053.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0054.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0055.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 5, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0056.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 5, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0057.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 6, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0058.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 6, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0059.png", + "frame": { "x": 0, "y": 76, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0060.png", + "frame": { "x": 0, "y": 76, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0061.png", + "frame": { "x": 24, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0062.png", + "frame": { "x": 24, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0063.png", + "frame": { "x": 48, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 0, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0064.png", + "frame": { "x": 48, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 0, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0065.png", + "frame": { "x": 106, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0066.png", + "frame": { "x": 106, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0067.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0068.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0069.png", + "frame": { "x": 24, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0070.png", + "frame": { "x": 24, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0071.png", + "frame": { "x": 48, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 0, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0072.png", + "frame": { "x": 48, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 0, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0073.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0074.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 40, "y": 2, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0075.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 39, "y": 3, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0076.png", + "frame": { "x": 168, "y": 75, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 39, "y": 3, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0077.png", + "frame": { "x": 130, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 37, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0078.png", + "frame": { "x": 130, "y": 111, "w": 24, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 37, "y": 4, "w": 24, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0079.png", + "frame": { "x": 154, "y": 111, "w": 24, "h": 35 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 35, "y": 5, "w": 24, "h": 35 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0080.png", + "frame": { "x": 154, "y": 111, "w": 24, "h": 35 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 35, "y": 5, "w": 24, "h": 35 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0081.png", + "frame": { "x": 0, "y": 112, "w": 24, "h": 35 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 30, "y": 5, "w": 24, "h": 35 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0082.png", + "frame": { "x": 0, "y": 112, "w": 24, "h": 35 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 30, "y": 5, "w": 24, "h": 35 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0083.png", + "frame": { "x": 74, "y": 75, "w": 32, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 24, "y": 6, "w": 32, "h": 37 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0084.png", + "frame": { "x": 74, "y": 75, "w": 32, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 24, "y": 6, "w": 32, "h": 37 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0085.png", + "frame": { "x": 127, "y": 39, "w": 36, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 18, "y": 6, "w": 36, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0086.png", + "frame": { "x": 127, "y": 39, "w": 36, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 18, "y": 6, "w": 36, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0087.png", + "frame": { "x": 0, "y": 39, "w": 38, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 17, "y": 6, "w": 38, "h": 37 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0088.png", + "frame": { "x": 0, "y": 39, "w": 38, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 17, "y": 6, "w": 38, "h": 37 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0089.png", + "frame": { "x": 48, "y": 0, "w": 49, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 6, "w": 49, "h": 38 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0090.png", + "frame": { "x": 48, "y": 0, "w": 49, "h": 38 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 9, "y": 6, "w": 49, "h": 38 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0091.png", + "frame": { "x": 0, "y": 0, "w": 48, "h": 39 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 6, "w": 48, "h": 39 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0092.png", + "frame": { "x": 0, "y": 0, "w": 48, "h": 39 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 12, "y": 6, "w": 48, "h": 39 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0093.png", + "frame": { "x": 97, "y": 0, "w": 46, "h": 39 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 16, "y": 5, "w": 46, "h": 39 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0094.png", + "frame": { "x": 97, "y": 0, "w": 46, "h": 39 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 16, "y": 5, "w": 46, "h": 39 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0095.png", + "frame": { "x": 143, "y": 0, "w": 46, "h": 39 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 19, "y": 5, "w": 46, "h": 39 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0096.png", + "frame": { "x": 143, "y": 0, "w": 46, "h": 39 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 19, "y": 5, "w": 46, "h": 39 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0097.png", + "frame": { "x": 48, "y": 38, "w": 41, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 24, "y": 4, "w": 41, "h": 37 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0098.png", + "frame": { "x": 48, "y": 38, "w": 41, "h": 37 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 24, "y": 4, "w": 41, "h": 37 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0099.png", + "frame": { "x": 89, "y": 39, "w": 38, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 27, "y": 3, "w": 38, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0100.png", + "frame": { "x": 89, "y": 39, "w": 38, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 27, "y": 3, "w": 38, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0101.png", + "frame": { "x": 38, "y": 75, "w": 36, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 28, "y": 2, "w": 36, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0102.png", + "frame": { "x": 38, "y": 75, "w": 36, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 28, "y": 2, "w": 36, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0103.png", + "frame": { "x": 163, "y": 39, "w": 33, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 31, "y": 2, "w": 33, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0104.png", + "frame": { "x": 163, "y": 39, "w": 33, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 31, "y": 2, "w": 33, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0105.png", + "frame": { "x": 106, "y": 75, "w": 32, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 32, "y": 2, "w": 32, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0106.png", + "frame": { "x": 106, "y": 75, "w": 32, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 32, "y": 2, "w": 32, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + }, + { + "filename": "0107.png", + "frame": { "x": 138, "y": 75, "w": 30, "h": 36 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 34, "y": 2, "w": 30, "h": 36 }, + "sourceSize": { "w": 96, "h": 45 } + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.8.1-x64", + "image": "582.png", + "format": "RGBA8888", + "size": { "w": 196, "h": 147 }, + "scale": "1" + } } diff --git a/public/images/pokemon/shiny/582.png b/public/images/pokemon/shiny/582.png index b26791658d7..b96387186c7 100644 Binary files a/public/images/pokemon/shiny/582.png and b/public/images/pokemon/shiny/582.png differ diff --git a/public/images/pokemon/shiny/60.png b/public/images/pokemon/shiny/60.png index 16ff5adffba..1a92e9a24ed 100644 Binary files a/public/images/pokemon/shiny/60.png and b/public/images/pokemon/shiny/60.png differ diff --git a/public/images/pokemon/shiny/62.png b/public/images/pokemon/shiny/62.png index 69d5586d273..d25b4087015 100644 Binary files a/public/images/pokemon/shiny/62.png and b/public/images/pokemon/shiny/62.png differ diff --git a/public/images/pokemon/shiny/658-ash.json b/public/images/pokemon/shiny/658-ash.json index 7ac419b1686..c2b8eede9ef 100644 --- a/public/images/pokemon/shiny/658-ash.json +++ b/public/images/pokemon/shiny/658-ash.json @@ -1,41 +1,19 @@ -{ - "textures": [ - { - "image": "658-ash.png", - "format": "RGBA8888", - "size": { - "w": 79, - "h": 79 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 79, - "h": 74 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 79, - "h": 74 - }, - "frame": { - "x": 0, - "y": 0, - "w": 79, - "h": 74 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:3dd081ba5490f090a73de8423aac2f6b:f088fafaea755476f2abf488e7340cab:bfbf521a5c7bd80bcd95a96d9789c0dd$" - } +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 74 }, + "sourceSize": { "w": 79, "h": 74 }, + "duration": 100 + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.7-x64", + "format": "I8", + "size": { "w": 79, "h": 74 }, + "scale": "1" + } } diff --git a/public/images/pokemon/shiny/658-ash.png b/public/images/pokemon/shiny/658-ash.png index 0d65f0bb900..f5de608708e 100644 Binary files a/public/images/pokemon/shiny/658-ash.png and b/public/images/pokemon/shiny/658-ash.png differ diff --git a/public/images/pokemon/shiny/658.json b/public/images/pokemon/shiny/658.json index 92f9b29175c..219645ec240 100644 --- a/public/images/pokemon/shiny/658.json +++ b/public/images/pokemon/shiny/658.json @@ -1,41 +1,19 @@ -{ - "textures": [ - { - "image": "658.png", - "format": "RGBA8888", - "size": { - "w": 75, - "h": 75 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 75, - "h": 65 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 75, - "h": 65 - }, - "frame": { - "x": 0, - "y": 0, - "w": 75, - "h": 65 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:be07c062265a19e890f1e2d2d1b5527d:ad4583a5a0498c496e9a93574c55ee03:5affcab976148657d36bf4ff3410f92d$" - } +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 85, "h": 67 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 85, "h": 67 }, + "sourceSize": { "w": 85, "h": 67 }, + "duration": 100 + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.7-x64", + "format": "I8", + "size": { "w": 85, "h": 67 }, + "scale": "1" + } } diff --git a/public/images/pokemon/shiny/658.png b/public/images/pokemon/shiny/658.png index 6fb80fd57cc..100d2a02f4a 100644 Binary files a/public/images/pokemon/shiny/658.png and b/public/images/pokemon/shiny/658.png differ diff --git a/public/images/pokemon/shiny/688.json b/public/images/pokemon/shiny/688.json index 8d34a857f65..3d9aa902a54 100644 --- a/public/images/pokemon/shiny/688.json +++ b/public/images/pokemon/shiny/688.json @@ -1,41 +1,18 @@ -{ - "textures": [ - { - "image": "688.png", - "format": "RGBA8888", - "size": { - "w": 52, - "h": 52 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 41, - "h": 52 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 41, - "h": 52 - }, - "frame": { - "x": 0, - "y": 0, - "w": 41, - "h": 52 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:e78487a241bfd62ebbe53b20c731d2c3:77b6de2bb0929c9cd5328c501256413b:176060351d0044923af938ba7932a6ef$" - } +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 64, "h": 63 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 64, "h": 63 }, + "sourceSize": { "w": 64, "h": 63 } + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.7-x64", + "format": "I8", + "size": { "w": 64, "h": 63 }, + "scale": "1" + } } diff --git a/public/images/pokemon/shiny/688.png b/public/images/pokemon/shiny/688.png index e87b981aa45..42565cb09b2 100644 Binary files a/public/images/pokemon/shiny/688.png and b/public/images/pokemon/shiny/688.png differ diff --git a/public/images/pokemon/shiny/689.json b/public/images/pokemon/shiny/689.json index c388441a207..488ef54de71 100644 --- a/public/images/pokemon/shiny/689.json +++ b/public/images/pokemon/shiny/689.json @@ -1,41 +1,19 @@ -{ - "textures": [ - { - "image": "689.png", - "format": "RGBA8888", - "size": { - "w": 86, - "h": 86 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 86, - "h": 79 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 86, - "h": 79 - }, - "frame": { - "x": 0, - "y": 0, - "w": 86, - "h": 79 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:182cf1643b5020735212d8aa4db1c48e:ceb6ea59b420d8893e991d5545fbb7c7:bd0c58ecddcb4af9a0c6e7b39821d971$" - } +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 79, "h": 82 }, + "rotated": false, + "trimmed": false, + "spriteSourceSize": { "x": 0, "y": 0, "w": 79, "h": 82 }, + "sourceSize": { "w": 79, "h": 82 }, + "duration": 100 + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.7-x64", + "format": "I8", + "size": { "w": 79, "h": 82 }, + "scale": "1" + } } diff --git a/public/images/pokemon/shiny/689.png b/public/images/pokemon/shiny/689.png index faf533459d0..c58ed341e75 100644 Binary files a/public/images/pokemon/shiny/689.png and b/public/images/pokemon/shiny/689.png differ diff --git a/public/images/pokemon/shiny/773-bug.png b/public/images/pokemon/shiny/773-bug.png index 65bd8cdb3b9..3b394f2e790 100644 Binary files a/public/images/pokemon/shiny/773-bug.png and b/public/images/pokemon/shiny/773-bug.png differ diff --git a/public/images/pokemon/shiny/773-dark.png b/public/images/pokemon/shiny/773-dark.png index e684ff9be0f..da630322594 100644 Binary files a/public/images/pokemon/shiny/773-dark.png and b/public/images/pokemon/shiny/773-dark.png differ diff --git a/public/images/pokemon/shiny/773-dragon.png b/public/images/pokemon/shiny/773-dragon.png index 56775c80ec4..68748f6b459 100644 Binary files a/public/images/pokemon/shiny/773-dragon.png and b/public/images/pokemon/shiny/773-dragon.png differ diff --git a/public/images/pokemon/shiny/773-electric.png b/public/images/pokemon/shiny/773-electric.png index 4e7ed586995..95052609b5b 100644 Binary files a/public/images/pokemon/shiny/773-electric.png and b/public/images/pokemon/shiny/773-electric.png differ diff --git a/public/images/pokemon/shiny/773-fairy.png b/public/images/pokemon/shiny/773-fairy.png index 90597e3a1ec..e56452c69e1 100644 Binary files a/public/images/pokemon/shiny/773-fairy.png and b/public/images/pokemon/shiny/773-fairy.png differ diff --git a/public/images/pokemon/shiny/773-fighting.png b/public/images/pokemon/shiny/773-fighting.png index a8d013ef69d..be088dcc9a7 100644 Binary files a/public/images/pokemon/shiny/773-fighting.png and b/public/images/pokemon/shiny/773-fighting.png differ diff --git a/public/images/pokemon/shiny/773-fire.png b/public/images/pokemon/shiny/773-fire.png index 179eb5d02c7..4965ec5095b 100644 Binary files a/public/images/pokemon/shiny/773-fire.png and b/public/images/pokemon/shiny/773-fire.png differ diff --git a/public/images/pokemon/shiny/773-flying.png b/public/images/pokemon/shiny/773-flying.png index 3da3a83f295..b99b93656be 100644 Binary files a/public/images/pokemon/shiny/773-flying.png and b/public/images/pokemon/shiny/773-flying.png differ diff --git a/public/images/pokemon/shiny/773-ghost.png b/public/images/pokemon/shiny/773-ghost.png index 40abbd293e3..6910ede97b5 100644 Binary files a/public/images/pokemon/shiny/773-ghost.png and b/public/images/pokemon/shiny/773-ghost.png differ diff --git a/public/images/pokemon/shiny/773-grass.png b/public/images/pokemon/shiny/773-grass.png index b73d6757973..6e855f965ef 100644 Binary files a/public/images/pokemon/shiny/773-grass.png and b/public/images/pokemon/shiny/773-grass.png differ diff --git a/public/images/pokemon/shiny/773-ground.png b/public/images/pokemon/shiny/773-ground.png index 4fd067a06c5..42662a76f90 100644 Binary files a/public/images/pokemon/shiny/773-ground.png and b/public/images/pokemon/shiny/773-ground.png differ diff --git a/public/images/pokemon/shiny/773-ice.png b/public/images/pokemon/shiny/773-ice.png index e01e9ac0249..823f8af572d 100644 Binary files a/public/images/pokemon/shiny/773-ice.png and b/public/images/pokemon/shiny/773-ice.png differ diff --git a/public/images/pokemon/shiny/773-poison.png b/public/images/pokemon/shiny/773-poison.png index 28b319e0dce..76606bf058c 100644 Binary files a/public/images/pokemon/shiny/773-poison.png and b/public/images/pokemon/shiny/773-poison.png differ diff --git a/public/images/pokemon/shiny/773-psychic.png b/public/images/pokemon/shiny/773-psychic.png index 4a56828c859..4b014987a9b 100644 Binary files a/public/images/pokemon/shiny/773-psychic.png and b/public/images/pokemon/shiny/773-psychic.png differ diff --git a/public/images/pokemon/shiny/773-rock.png b/public/images/pokemon/shiny/773-rock.png index 5df759f46dc..1993dd8bc18 100644 Binary files a/public/images/pokemon/shiny/773-rock.png and b/public/images/pokemon/shiny/773-rock.png differ diff --git a/public/images/pokemon/shiny/773-steel.png b/public/images/pokemon/shiny/773-steel.png index 7e7e7518e99..6bcf5c178f3 100644 Binary files a/public/images/pokemon/shiny/773-steel.png and b/public/images/pokemon/shiny/773-steel.png differ diff --git a/public/images/pokemon/shiny/773-water.png b/public/images/pokemon/shiny/773-water.png index ebcdf8f7ccf..7e9b1b6cd15 100644 Binary files a/public/images/pokemon/shiny/773-water.png and b/public/images/pokemon/shiny/773-water.png differ diff --git a/public/images/pokemon/shiny/774-blue.png b/public/images/pokemon/shiny/774-blue.png index c7d4c058ac5..4526f830810 100644 Binary files a/public/images/pokemon/shiny/774-blue.png and b/public/images/pokemon/shiny/774-blue.png differ diff --git a/public/images/pokemon/shiny/774-green.png b/public/images/pokemon/shiny/774-green.png index c55108b43cc..1797510a6e1 100644 Binary files a/public/images/pokemon/shiny/774-green.png and b/public/images/pokemon/shiny/774-green.png differ diff --git a/public/images/pokemon/shiny/774-indigo.png b/public/images/pokemon/shiny/774-indigo.png index 88fc59c14a5..b1d01fb952f 100644 Binary files a/public/images/pokemon/shiny/774-indigo.png and b/public/images/pokemon/shiny/774-indigo.png differ diff --git a/public/images/pokemon/shiny/774-orange.png b/public/images/pokemon/shiny/774-orange.png index 47ec08ed3e3..32d659ecd56 100644 Binary files a/public/images/pokemon/shiny/774-orange.png and b/public/images/pokemon/shiny/774-orange.png differ diff --git a/public/images/pokemon/shiny/774-red.png b/public/images/pokemon/shiny/774-red.png index 0fa7e812fa2..074f04e3660 100644 Binary files a/public/images/pokemon/shiny/774-red.png and b/public/images/pokemon/shiny/774-red.png differ diff --git a/public/images/pokemon/shiny/774-violet.png b/public/images/pokemon/shiny/774-violet.png index 47904247bb1..5acae56a03e 100644 Binary files a/public/images/pokemon/shiny/774-violet.png and b/public/images/pokemon/shiny/774-violet.png differ diff --git a/public/images/pokemon/shiny/774-yellow.png b/public/images/pokemon/shiny/774-yellow.png index 9130fb4dbc2..0612a851314 100644 Binary files a/public/images/pokemon/shiny/774-yellow.png and b/public/images/pokemon/shiny/774-yellow.png differ diff --git a/public/images/pokemon/shiny/944.png b/public/images/pokemon/shiny/944.png index 5b5a264755f..e410629b535 100644 Binary files a/public/images/pokemon/shiny/944.png and b/public/images/pokemon/shiny/944.png differ diff --git a/public/images/pokemon/shiny/945.png b/public/images/pokemon/shiny/945.png index f458bf630d6..ab3fb485bb2 100644 Binary files a/public/images/pokemon/shiny/945.png and b/public/images/pokemon/shiny/945.png differ diff --git a/public/images/pokemon/shiny/966-caph-starmobile.json b/public/images/pokemon/shiny/966-caph-starmobile.json new file mode 100644 index 00000000000..96c5aada282 --- /dev/null +++ b/public/images/pokemon/shiny/966-caph-starmobile.json @@ -0,0 +1,19 @@ +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 94, "h": 94 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 26, "y": 0, "w": 94, "h": 94 }, + "sourceSize": { "w": 120, "h": 94 } + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.8.1-x64", + "image": "966-caph-starmobile.png", + "format": "RGBA8888", + "size": { "w": 94, "h": 94 }, + "scale": "1" + } +} diff --git a/public/images/pokemon/shiny/966-caph-starmobile.png b/public/images/pokemon/shiny/966-caph-starmobile.png new file mode 100644 index 00000000000..6107a426ff6 Binary files /dev/null and b/public/images/pokemon/shiny/966-caph-starmobile.png differ diff --git a/public/images/pokemon/shiny/966-navi-starmobile.json b/public/images/pokemon/shiny/966-navi-starmobile.json new file mode 100644 index 00000000000..6a39310af00 --- /dev/null +++ b/public/images/pokemon/shiny/966-navi-starmobile.json @@ -0,0 +1,19 @@ +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 94, "h": 94 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 26, "y": 0, "w": 94, "h": 94 }, + "sourceSize": { "w": 120, "h": 94 } + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.8.1-x64", + "image": "966-navi-starmobile.png", + "format": "RGBA8888", + "size": { "w": 94, "h": 94 }, + "scale": "1" + } +} diff --git a/public/images/pokemon/shiny/966-navi-starmobile.png b/public/images/pokemon/shiny/966-navi-starmobile.png new file mode 100644 index 00000000000..74999d4fa13 Binary files /dev/null and b/public/images/pokemon/shiny/966-navi-starmobile.png differ diff --git a/public/images/pokemon/shiny/966-ruchbah-starmobile.json b/public/images/pokemon/shiny/966-ruchbah-starmobile.json new file mode 100644 index 00000000000..c75a5630f45 --- /dev/null +++ b/public/images/pokemon/shiny/966-ruchbah-starmobile.json @@ -0,0 +1,19 @@ +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 94, "h": 94 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 26, "y": 0, "w": 94, "h": 94 }, + "sourceSize": { "w": 120, "h": 94 } + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.8.1-x64", + "image": "966-ruchbah-starmobile.png", + "format": "RGBA8888", + "size": { "w": 94, "h": 94 }, + "scale": "1" + } +} diff --git a/public/images/pokemon/shiny/966-ruchbah-starmobile.png b/public/images/pokemon/shiny/966-ruchbah-starmobile.png new file mode 100644 index 00000000000..9de01ac6a73 Binary files /dev/null and b/public/images/pokemon/shiny/966-ruchbah-starmobile.png differ diff --git a/public/images/pokemon/shiny/966-schedar-starmobile.json b/public/images/pokemon/shiny/966-schedar-starmobile.json new file mode 100644 index 00000000000..59f77f3c975 --- /dev/null +++ b/public/images/pokemon/shiny/966-schedar-starmobile.json @@ -0,0 +1,19 @@ +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 94, "h": 94 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 26, "y": 0, "w": 94, "h": 94 }, + "sourceSize": { "w": 120, "h": 94 } + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.8.1-x64", + "image": "966-schedar-starmobile.png", + "format": "RGBA8888", + "size": { "w": 94, "h": 94 }, + "scale": "1" + } +} diff --git a/public/images/pokemon/shiny/966-schedar-starmobile.png b/public/images/pokemon/shiny/966-schedar-starmobile.png new file mode 100644 index 00000000000..79033bb123c Binary files /dev/null and b/public/images/pokemon/shiny/966-schedar-starmobile.png differ diff --git a/public/images/pokemon/shiny/966-segin-starmobile.json b/public/images/pokemon/shiny/966-segin-starmobile.json new file mode 100644 index 00000000000..98b3938643b --- /dev/null +++ b/public/images/pokemon/shiny/966-segin-starmobile.json @@ -0,0 +1,19 @@ +{ "frames": [ + { + "filename": "0001.png", + "frame": { "x": 0, "y": 0, "w": 94, "h": 94 }, + "rotated": false, + "trimmed": true, + "spriteSourceSize": { "x": 26, "y": 0, "w": 94, "h": 94 }, + "sourceSize": { "w": 120, "h": 94 } + } + ], + "meta": { + "app": "https://www.aseprite.org/", + "version": "1.3.8.1-x64", + "image": "966-segin-starmobile.png", + "format": "RGBA8888", + "size": { "w": 94, "h": 94 }, + "scale": "1" + } +} diff --git a/public/images/pokemon/shiny/966-segin-starmobile.png b/public/images/pokemon/shiny/966-segin-starmobile.png new file mode 100644 index 00000000000..f4cab89a203 Binary files /dev/null and b/public/images/pokemon/shiny/966-segin-starmobile.png differ diff --git a/public/images/pokemon/shiny/female/194.png b/public/images/pokemon/shiny/female/194.png index 01c071ee41d..23e55c52190 100644 Binary files a/public/images/pokemon/shiny/female/194.png and b/public/images/pokemon/shiny/female/194.png differ diff --git a/public/images/pokemon/shiny/female/275.png b/public/images/pokemon/shiny/female/275.png index c8f9a90b721..a0571493279 100644 Binary files a/public/images/pokemon/shiny/female/275.png and b/public/images/pokemon/shiny/female/275.png differ diff --git a/public/images/pokemon/shiny/female/454.png b/public/images/pokemon/shiny/female/454.png index 7325131a115..7d2fc47429c 100644 Binary files a/public/images/pokemon/shiny/female/454.png and b/public/images/pokemon/shiny/female/454.png differ diff --git a/public/images/pokemon/variant/1012-counterfeit.json b/public/images/pokemon/variant/1012-counterfeit.json new file mode 100644 index 00000000000..114c3811ba1 --- /dev/null +++ b/public/images/pokemon/variant/1012-counterfeit.json @@ -0,0 +1,44 @@ +{ + "1": { + "5d9e4a": "dda08a", + "a09750": "acbedf", + "423232": "626a96", + "827b74": "848fb8", + "613f19": "7b86ad", + "ccc374": "def7ff", + "a7ba72": "c87079", + "c1b9ae": "c8ddf1", + "69441b": "3a44a4", + "878278": "8a96c0", + "f7da67": "94386a", + "78c463": "f7dfc5", + "ede9e4": "f5fdff", + "261919": "222078", + "396725": "b0654a", + "251b1b": "404ec8", + "4d3635": "174593", + "87847e": "a1b0e6", + "4c3a3a": "667fe9" + }, + "2": { + "5d9e4a": "978dc7", + "a09750": "1b2556", + "423232": "020109", + "827b74": "6fbb45", + "613f19": "0d1030", + "ccc374": "242f66", + "a7ba72": "647c9a", + "c1b9ae": "111039", + "69441b": "44244b", + "878278": "070722", + "f7da67": "0f5627", + "78c463": "c3b4e0", + "ede9e4": "212b5e", + "261919": "1c0b1f", + "396725": "7a5aa7", + "251b1b": "37183f", + "4d3635": "aae16c", + "87847e": "443666", + "4c3a3a": "563f5b" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/1013-unremarkable.json b/public/images/pokemon/variant/1013-unremarkable.json new file mode 100644 index 00000000000..cd988febd87 --- /dev/null +++ b/public/images/pokemon/variant/1013-unremarkable.json @@ -0,0 +1,48 @@ +{ + "1": { + "5d9e4a": "dda08a", + "786354": "7987bd", + "403030": "1c4b9c", + "7b8764": "c58c85", + "ccc374": "eefbff", + "a7ba72": "b75267", + "7b6f6c": "939ec4", + "c1b9ae": "cbe1f5", + "69441b": "3a44a4", + "342405": "616a8a", + "78c463": "f7dfc5", + "453636": "667fe9", + "988975": "acbedf", + "295217": "b0654a", + "e6e1db": "e6f9ff", + "9e8574": "b36171", + "251b1b": "404ec8", + "6a5b20": "8a96c0", + "a09750": "c3d7eb", + "291a0d": "222078", + "f7da67": "94386a" + }, + "2": { + "5d9e4a": "978dc7", + "786354": "5fb352", + "403030": "aae16c", + "7b8764": "716d99", + "ccc374": "263665", + "a7ba72": "647c9a", + "7b6f6c": "0f102d", + "c1b9ae": "111039", + "69441b": "44244b", + "342405": "08081f", + "78c463": "c3b4e0", + "453636": "563f5b", + "988975": "212e57", + "295217": "7a5aa7", + "e6e1db": "212b5e", + "9e8574": "585d81", + "251b1b": "37183f", + "6a5b20": "0b0c21", + "a09750": "131238", + "291a0d": "170d26", + "f7da67": "0f5627" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/102.json b/public/images/pokemon/variant/102.json new file mode 100644 index 00000000000..987f6046458 --- /dev/null +++ b/public/images/pokemon/variant/102.json @@ -0,0 +1,20 @@ +{ + "1": { + "ffce4a": "cea573", + "e69c00": "a0694c", + "ffe6ce": "7ae49f", + "943131": "193662", + "ffb58c": "369b96", + "ef8463": "26647e", + "ffd6ad": "4fba94" + }, + "2": { + "ffce4a": "92394b", + "e69c00": "6d2341", + "ffe6ce": "ebb6f8", + "943131": "414189", + "ffb58c": "9475ce", + "ef8463": "6c5fb6", + "ffd6ad": "b98fe4" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/103.json b/public/images/pokemon/variant/103.json new file mode 100644 index 00000000000..2b6a1f13f79 --- /dev/null +++ b/public/images/pokemon/variant/103.json @@ -0,0 +1,28 @@ +{ + "1": { + "ffde6b": "a3c4ed", + "e6ad5a": "869fdc", + "8c7342": "283f5b", + "73ad31": "dea44c", + "526329": "c8592a", + "9cd64a": "f4e774", + "a56b21": "6072ba", + "b59c4a": "426378", + "734210": "373e85", + "ffefa5": "d3efff", + "524210": "131d33" + }, + "2": { + "ffde6b": "eb748d", + "e6ad5a": "c84e7f", + "8c7342": "d59cba", + "73ad31": "3d324b", + "526329": "1f1a31", + "9cd64a": "6a5b73", + "a56b21": "83295f", + "b59c4a": "ffdbe7", + "734210": "4e1044", + "ffefa5": "ffa29d", + "524210": "925b81" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/128.json b/public/images/pokemon/variant/128.json new file mode 100644 index 00000000000..cd6a7d64f3a --- /dev/null +++ b/public/images/pokemon/variant/128.json @@ -0,0 +1,32 @@ +{ + "1": { + "dea54a": "56b393", + "634a31": "173e0d", + "9c9cad": "997059", + "e6c57b": "8fcaaa", + "4a3a29": "072b05", + "8c6321": "215c72", + "8c6b52": "355816", + "b58431": "2e8a85", + "ad8c73": "5f722a", + "3a3a4a": "4d2324", + "6b6b84": "75413b", + "cecede": "c2a082", + "523a10": "102d4b" + }, + "2": { + "dea54a": "872b3b", + "634a31": "bc9681", + "9c9cad": "edda95", + "e6c57b": "a84d52", + "4a3a29": "966959", + "8c6321": "461029", + "8c6b52": "d6c3aa", + "b58431": "5e172e", + "ad8c73": "faf9ed", + "3a3a4a": "996537", + "6b6b84": "cca45e", + "cecede": "fffcc1", + "523a10": "2f0e21" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/152.json b/public/images/pokemon/variant/152.json new file mode 100644 index 00000000000..f3c1d446fa7 --- /dev/null +++ b/public/images/pokemon/variant/152.json @@ -0,0 +1,28 @@ +{ + "1": { + "efffc5": "f7f1fb", + "849452": "7373b4", + "c52929": "77b3af", + "b5ce6b": "aca1d7", + "d6f78c": "ded2f1", + "84e631": "8074fa", + "ef7b7b": "9bd5c1", + "6bb529": "6f4be2", + "425a19": "505d8d", + "426319": "5d2398", + "638c29": "6633bc" + }, + "2": { + "efffc5": "f4b2ad", + "849452": "a62775", + "c52929": "4eac60", + "b5ce6b": "c83c74", + "d6f78c": "e7617d", + "84e631": "feeeaf", + "ef7b7b": "71cf71", + "6bb529": "f0d187", + "425a19": "801a69", + "426319": "b4814b", + "638c29": "d8a864" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/153.json b/public/images/pokemon/variant/153.json new file mode 100644 index 00000000000..3456ca16513 --- /dev/null +++ b/public/images/pokemon/variant/153.json @@ -0,0 +1,28 @@ +{ + "1": { + "ffff8c": "cbe0fa", + "a58419": "5961ce", + "6b5200": "493fa6", + "ad3100": "47d0d1", + "8cbd31": "8251dc", + "debd29": "7b8ce6", + "527b08": "4d36be", + "6b9c10": "6740c9", + "295208": "232699", + "f7e64a": "a2bbf8", + "d68c52": "80f5e6" + }, + "2": { + "ffff8c": "f5c095", + "a58419": "a8244d", + "6b5200": "891b4f", + "ad3100": "439227", + "8cbd31": "fae084", + "debd29": "ca333d", + "527b08": "e8bc5e", + "6b9c10": "edc870", + "295208": "c58c48", + "f7e64a": "ea704a", + "d68c52": "8ec349" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/154.json b/public/images/pokemon/variant/154.json new file mode 100644 index 00000000000..90311122029 --- /dev/null +++ b/public/images/pokemon/variant/154.json @@ -0,0 +1,30 @@ +{ + "1": { + "634a00": "519aa7", + "f7a59c": "739ed4", + "e6ad00": "7bcfc6", + "ff3a5a": "3542a7", + "ffde21": "b1f2dc", + "ce213a": "27217d", + "63bd42": "9d86d9", + "bdff7b": "dadffe", + "7b103a": "23124e", + "107b31": "8057b2", + "fefefe": "9cfeff", + "9ce652": "b7afee" + }, + "2": { + "634a00": "488939", + "f7a59c": "fff6a9", + "e6ad00": "6bac4b", + "ff3a5a": "f9db74", + "ffde21": "92c462", + "ce213a": "e5b650", + "63bd42": "a31f60", + "bdff7b": "f57382", + "7b103a": "b7873b", + "107b31": "761858", + "fefefe": "ffffee", + "9ce652": "cd3b6b" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/158.json b/public/images/pokemon/variant/158.json new file mode 100644 index 00000000000..779c7ea69b4 --- /dev/null +++ b/public/images/pokemon/variant/158.json @@ -0,0 +1,27 @@ +{ + "1": { + "7b1900": "4f0332", + "6bb5e6": "dd8e59", + "94d6ff": "fdc17e", + "ffc552": "99d4d9", + "ad8429": "4798ab", + "3184c5": "ae5139", + "e67b7b": "749e9e", + "b54a52": "1d5d6c", + "ce4221": "772c52", + "315a84": "73131e" + }, + "2": { + "000000": "ffffff", + "7b1900": "a66b14", + "6bb5e6": "97ac5b", + "94d6ff": "ccd198", + "ffc552": "2f5365", + "ad8429": "1c314f", + "3184c5": "4f854a", + "e67b7b": "e4b843", + "b54a52": "c48b27", + "ce4221": "ce8c20", + "315a84": "2b4a30" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/159.json b/public/images/pokemon/variant/159.json new file mode 100644 index 00000000000..c6563e4204c --- /dev/null +++ b/public/images/pokemon/variant/159.json @@ -0,0 +1,33 @@ +{ + "1": { + "3a4a84": "973027", + "e64221": "749e9e", + "ce293a": "682c4e", + "5aade6": "e5a354", + "84ceff": "ffcf72", + "cebd63": "56b3bd", + "ffe68c": "a9e4e5", + "840008": "4f1037", + "3184c5": "cd6537", + "6b5200": "085d75", + "840009": "1d5d6c", + "ff8c84": "926877", + "f7525a": "774860" + }, + "2": { + "000000": "ffffff", + "3a4a84": "26472b", + "e64221": "e4b843", + "ce293a": "ce8c20", + "5aade6": "8fa54e", + "84ceff": "c2c78a", + "cebd63": "1c314f", + "ffe68c": "2f5365", + "840008": "a66b14", + "3184c5": "468040", + "6b5200": "112034", + "840009": "c48b27", + "ff8c84": "fff284", + "f7525a": "f3b649" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/160.json b/public/images/pokemon/variant/160.json new file mode 100644 index 00000000000..adb897ae5f5 --- /dev/null +++ b/public/images/pokemon/variant/160.json @@ -0,0 +1,27 @@ +{ + "1": { + "8cd6ff": "ffcf72", + "6b5200": "085d75", + "5ab5f7": "eda857", + "cebd63": "56b3bd", + "ffe68c": "a9e4e5", + "840008": "4f1037", + "294a8c": "973027", + "3a8cce": "d26738", + "ff8c84": "926877", + "f7525a": "774860" + }, + "2": { + "000000": "ffffff", + "8cd6ff": "d1d692", + "6b5200": "112034", + "5ab5f7": "9ab350", + "cebd63": "1c314f", + "ffe68c": "2f5365", + "840008": "a66b14", + "294a8c": "274c2d", + "3a8cce": "498a42", + "ff8c84": "fff284", + "f7525a": "f3b649" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/167.json b/public/images/pokemon/variant/167.json new file mode 100644 index 00000000000..20f954a4a55 --- /dev/null +++ b/public/images/pokemon/variant/167.json @@ -0,0 +1,31 @@ +{ + "1": { + "52b56b": "e06c19", + "b5424a": "861d1d", + "ef5a5a": "b92222", + "7b3142": "651218", + "c5b519": "3f2e71", + "314a10": "732202", + "846b29": "231a58", + "8ce631": "f1b940", + "527b29": "d54f19", + "ffe64a": "624095", + "adef63": "f5da68" + }, + "2": { + "52b56b": "8c2848", + "b5424a": "1f1d3f", + "bdc5c5": "a1b7de", + "ef5a5a": "313659", + "7b3142": "181729", + "c5b519": "7d95b9", + "314a10": "481229", + "846b29": "565e8d", + "8ce631": "b54158", + "527b29": "6a1b37", + "ffe64a": "aac3d6", + "ffffff": "cde6fc", + "6b6b73": "62657d", + "adef63": "dd7081" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/168.json b/public/images/pokemon/variant/168.json new file mode 100644 index 00000000000..4c8fcf5f4f5 --- /dev/null +++ b/public/images/pokemon/variant/168.json @@ -0,0 +1,32 @@ +{ + "1": { + "c54242": "62b943", + "6b5219": "043435", + "63319c": "af4900", + "9c5ac5": "e28220", + "bdbdbd": "b5d3dc", + "ffffff": "fffef9", + "ff8c73": "dce24b", + "c5b54a": "15463c", + "ff5a4a": "a8d919", + "ffde42": "186c45", + "8c2100": "317945", + "bd84e6": "f1b940", + "6b6b6b": "552718" + }, + "2": { + "c54242": "7ca5c6", + "6b5219": "161437", + "63319c": "291013", + "9c5ac5": "96304a", + "bdbdbd": "c09fa1", + "ffffff": "fae8e7", + "ff8c73": "c4e8e7", + "c5b54a": "1f2150", + "ff5a4a": "a3c8d1", + "ffde42": "313b60", + "8c2100": "2d3d72", + "bd84e6": "c8545d", + "6b6b6b": "3e538a" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/170.json b/public/images/pokemon/variant/170.json new file mode 100644 index 00000000000..c83ca6836db --- /dev/null +++ b/public/images/pokemon/variant/170.json @@ -0,0 +1,34 @@ +{ + "1": { + "08295a": "691f03", + "ffce52": "a1dbba", + "b50000": "efde5a", + "94cee6": "ffeabf", + "295294": "a14713", + "ffef84": "ccffd7", + "5a73c5": "bf6924", + "c59400": "609a8a", + "522919": "052b38", + "ffffde": "f2fff5", + "7bbde6": "f6e37f", + "846352": "45757a", + "6ba5e6": "dda13d", + "e6b529": "84bda9" + }, + "2": { + "08295a": "1b072f", + "ffce52": "e25765", + "b50000": "f0d050", + "94cee6": "a15b8d", + "295294": "321648", + "ffef84": "f97f7f", + "5a73c5": "441e56", + "c59400": "931b3c", + "522919": "720b3a", + "ffffde": "ffc4be", + "7bbde6": "89498d", + "846352": "720b3a", + "6ba5e6": "693373", + "e6b529": "b62b51" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/171.json b/public/images/pokemon/variant/171.json new file mode 100644 index 00000000000..8a9cafe4265 --- /dev/null +++ b/public/images/pokemon/variant/171.json @@ -0,0 +1,30 @@ +{ + "1": { + "a5314a": "bf882c", + "4a7bce": "bc3c4c", + "423110": "05333a", + "ef635a": "efde5a", + "7badef": "f6907f", + "a5ceff": "fbcdb3", + "e6b552": "82ca4f", + "6394e6": "e86062", + "ffde63": "c3e875", + "ad9442": "2a8d3d", + "293173": "872341", + "7b634a": "0c5540" + }, + "2": { + "a5314a": "c3851d", + "4a7bce": "9781b3", + "423110": "040529", + "ef635a": "f0d050", + "7badef": "eecfed", + "a5ceff": "fbf5fa", + "e6b552": "3294b8", + "6394e6": "c5a5d0", + "ffde63": "4dd5d9", + "ad9442": "23689e", + "293173": "4b426c", + "7b634a": "0c1d4c" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/172-spiky.json b/public/images/pokemon/variant/172-spiky.json new file mode 100644 index 00000000000..81a1d9bdcd6 --- /dev/null +++ b/public/images/pokemon/variant/172-spiky.json @@ -0,0 +1,30 @@ +{ + "1": { + "f7ef94": "c4e3c3", + "7d1c1c": "992424", + "e77b94": "bd4d5e", + "e36481": "d45976", + "292929": "242424", + "c5ad10": "6cab9a", + "845a29": "45818a", + "f7e652": "a3d1a8", + "a57b08": "5ca390", + "634a10": "30536b" + }, + "2": { + "f7ef94": "8aa5ad", + "7d1c1c": "c38218", + "212131": "d48d61", + "e77b94": "f5dd94", + "e36481": "b35b6d", + "292929": "242424", + "c5ad10": "4a6a90", + "845a29": "283567", + "8c2121": "772c49", + "424252": "e7c17c", + "f7e652": "7095ab", + "171721": "9a4440", + "a57b08": "486a8e", + "634a10": "2f335b" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/172.json b/public/images/pokemon/variant/172.json new file mode 100644 index 00000000000..7df41b99457 --- /dev/null +++ b/public/images/pokemon/variant/172.json @@ -0,0 +1,29 @@ +{ + "1": { + "f7ef94": "c4e3c3", + "a57b08": "5ca390", + "d1667f": "d45976", + "e77b94": "bd4d5e", + "292929": "242424", + "c5ad10": "6cab9a", + "845a29": "45818a", + "f7e652": "a3d1a8", + "7d1c1c": "992424", + "634a10": "30536b" + }, + "2": { + "f7ef94": "8aa5ad", + "a57b08": "486a8e", + "d1667f": "b35b6d", + "8c2121": "772c49", + "e77b94": "f5dd94", + "c5ad10": "4a6a90", + "845a29": "283567", + "212131": "d48d61", + "424252": "e7c17c", + "f7e652": "7095ab", + "7d1c1c": "c38218", + "171721": "9a4440", + "634a10": "2f335b" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/174.json b/public/images/pokemon/variant/174.json new file mode 100644 index 00000000000..65b9af81dde --- /dev/null +++ b/public/images/pokemon/variant/174.json @@ -0,0 +1,20 @@ +{ + "1": { + "9c1952": "3a6472", + "e6849c": "81c2b8", + "bd0000": "f18fc4", + "630000": "6f305b", + "b55273": "43737d", + "e62910": "ae93d9", + "ffced6": "e5ffec", + "ffadbd": "c5ebd5" + }, + "2": { + "9c1952": "9c5200", + "e6849c": "f5c45b", + "b55273": "a16b30", + "e62910": "c43f3f", + "ffced6": "fff9bf", + "ffadbd": "f5e884" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/194.json b/public/images/pokemon/variant/194.json new file mode 100644 index 00000000000..47604b8228d --- /dev/null +++ b/public/images/pokemon/variant/194.json @@ -0,0 +1,24 @@ +{ + "1": { + "104a84": "7a150a", + "b54242": "23768d", + "ff6b73": "52c1e0", + "633a6b": "204954", + "3a7bc5": "d5682e", + "ef73e6": "81e2f7", + "73bdff": "ffc355", + "d65ad6": "65b1c2", + "529ce6": "e8983d" + }, + "2": { + "104a84": "180d42", + "b54242": "b96228", + "ff6b73": "e9cb52", + "633a6b": "80301c", + "3a7bc5": "3f377e", + "ef73e6": "e9cb52", + "73bdff": "5c66c4", + "d65ad6": "cf933b", + "529ce6": "564daa" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/195.json b/public/images/pokemon/variant/195.json new file mode 100644 index 00000000000..3bf5ea7844a --- /dev/null +++ b/public/images/pokemon/variant/195.json @@ -0,0 +1,26 @@ +{ + "1": { + "ade6ff": "f6dfa8", + "84d6f7": "ed9e4f", + "f7f7f7": "fffbea", + "637ba5": "936e66", + "639cbd": "dc6a4d", + "3194a5": "81e2f7", + "19423a": "204954", + "425284": "b03844", + "195a6b": "54aec2", + "6b5a8c": "23768d" + }, + "2": { + "ade6ff": "9864c2", + "84d6f7": "724ba7", + "f7f7f7": "e8b6ff", + "637ba5": "6f2d4b", + "639cbd": "493a8d", + "3194a5": "e9cb52", + "19423a": "b96228", + "425284": "240830", + "195a6b": "cf933b", + "6b5a8c": "80301c" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/198.json b/public/images/pokemon/variant/198.json new file mode 100644 index 00000000000..ab9084619f3 --- /dev/null +++ b/public/images/pokemon/variant/198.json @@ -0,0 +1,34 @@ +{ + "1": { + "d94352": "7a101c", + "314263": "462b20", + "d64252": "b3986b", + "73293a": "755237", + "ffad8c": "ad2e24", + "73283a": "630c17", + "d6404f": "8c1b23", + "efd684": "a6a6b3", + "42639c": "694c30", + "5a4a21": "25253b", + "292942": "2a1512", + "b59c21": "57566f", + "752a3c": "4d0419", + "d6bd52": "838098" + }, + "2": { + "d94352": "5939a9", + "314263": "0e4333", + "d64252": "bc4b84", + "73293a": "7b2363", + "ffad8c": "b164e6", + "73283a": "630c17", + "d6404f": "8c1b23", + "efd684": "c2723a", + "42639c": "1d6e47", + "5a4a21": "4e1915", + "292942": "091e16", + "b59c21": "85412d", + "752a3c": "1e1764", + "d6bd52": "9a5524" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/2026.json b/public/images/pokemon/variant/2026.json new file mode 100644 index 00000000000..995e3a1a6e8 --- /dev/null +++ b/public/images/pokemon/variant/2026.json @@ -0,0 +1,34 @@ +{ + "1": { + "e3882d": "3d7375", + "965821": "2f4e6b", + "846b5b": "467f85", + "fffdfb": "d6d9ca", + "552720": "142c48", + "602c24": "162f4b", + "fef443": "c48081", + "b45f25": "2d5261", + "fef652": "eb999a", + "1a73cc": "b85346", + "174680": "2b1307", + "e9be14": "945c7b", + "646124": "492652", + "9c5430": "1d3a57", + "ecd8b7": "b4c2a5" + }, + "2": { + "e3882d": "d3b06f", + "965821": "9cb3ca", + "846b5b": "202746", + "fffdfb": "6d8297", + "552720": "43617f", + "fef443": "3a5873", + "b45f25": "bd8551", + "fef652": "faee9e", + "1a73cc": "c26400", + "174680": "2b0606", + "e9be14": "1a3551", + "646124": "122140", + "ecd8b7": "5a6f90" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/2103.json b/public/images/pokemon/variant/2103.json new file mode 100644 index 00000000000..2e97727835a --- /dev/null +++ b/public/images/pokemon/variant/2103.json @@ -0,0 +1,28 @@ +{ + "1": { + "2f9934": "dea44c", + "9f6b41": "426378", + "70442e": "283f5b", + "e6ac5a": "869fdc", + "522f16": "131d33", + "9cbd4a": "9977dd", + "fff68b": "a3c4ed", + "36cc36": "f4e774", + "2d5826": "c8592a", + "7b5210": "373e85", + "ffffcd": "d3efff" + }, + "2": { + "2f9934": "3d324b", + "9f6b41": "ffdbe7", + "70442e": "d59cba", + "e6ac5a": "c84e7f", + "522f16": "925b81", + "9cbd4a": "824a96", + "fff68b": "eb748d", + "36cc36": "6a5b73", + "2d5826": "1f1a31", + "7b5210": "4e1044", + "ffffcd": "ffa29d" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/211.json b/public/images/pokemon/variant/211.json new file mode 100644 index 00000000000..cc2b3ba9209 --- /dev/null +++ b/public/images/pokemon/variant/211.json @@ -0,0 +1,28 @@ +{ + "1": { + "940000": "1c6449", + "194a52": "321128", + "dede94": "f1c17c", + "428494": "80294b", + "c5c57b": "dc9565", + "a5ad6b": "ad6643", + "3a6363": "611a42", + "d65263": "48be87", + "ffa594": "9ee79b", + "6b5231": "6d2c2c", + "73adb5": "a0415e" + }, + "2": { + "940000": "385881", + "194a52": "1c2f5b", + "dede94": "365492", + "428494": "60abdc", + "c5c57b": "2b3e7b", + "a5ad6b": "1e275b", + "3a6363": "396796", + "d65263": "a9cfd7", + "ffa594": "cafefd", + "6b5231": "181f46", + "73adb5": "8bd9ee" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/25-beauty-cosplay.json b/public/images/pokemon/variant/25-beauty-cosplay.json new file mode 100644 index 00000000000..0e5a6a1bad2 --- /dev/null +++ b/public/images/pokemon/variant/25-beauty-cosplay.json @@ -0,0 +1,49 @@ +{ + "1": { + "c52119": "ad4e76", + "5e5e6b": "6c6e60", + "f7e652": "a3d1a8", + "52525a": "4f454c", + "cecab9": "cfc8aa", + "e65137": "c95578", + "fffabf": "f4f7ab", + "b52821": "ad4469", + "292929": "1e1526", + "39509d": "47449c", + "f7e860": "f2ea50", + "e65a42": "cf6182", + "4d88c4": "7976c6", + "f7bd21": "79b5a5", + "2d276d": "2f2768", + "242323": "282030", + "585861": "443e6c", + "fff7a5": "c4e3c3", + "9c5200": "315c75", + "f7cc2f": "f7bd21", + "fffdea": "f8ffe3" + }, + "2": { + "c52119": "ebc67c", + "5e5e6b": "8a2554", + "f7e652": "577b98", + "52525a": "f1b571", + "cecab9": "b84084", + "e65137": "b95b6e", + "fffabf": "f5efd1", + "b52821": "6a253f", + "292929": "a45233", + "39509d": "9ec4cd", + "f7e860": "eddc78", + "e65a42": "eedd9c", + "4d88c4": "e4f6f1", + "f7bd21": "486689", + "2d276d": "454a61", + "242323": "282030", + "585861": "3f4246", + "fff7a5": "7b96aa", + "9c5200": "283361", + "965b0e": "96500e", + "f7cc2f": "d5ac44", + "fffdea": "ea82a6" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/25-cool-cosplay.json b/public/images/pokemon/variant/25-cool-cosplay.json new file mode 100644 index 00000000000..de4a138b690 --- /dev/null +++ b/public/images/pokemon/variant/25-cool-cosplay.json @@ -0,0 +1,49 @@ +{ + "1": { + "171717": "2a1d36", + "e8b127": "f5ca2f", + "52525a": "55555e", + "c52119": "ad4e76", + "842222": "7b1f18", + "f7e652": "a3d1a8", + "fff7a5": "c4e3c3", + "2baf23": "76a848", + "f7bd21": "79b5a5", + "e65a42": "cf6182", + "ba2b23": "b73850", + "f5e193": "f4f7ab", + "e66953": "b95b6e", + "6f6c8e": "656f86", + "a6adb6": "a5b0b6", + "8c4e22": "965b0e", + "9c5200": "1c4f75", + "c43129": "6a253f", + "d95b45": "cf6887", + "45484d": "443e6c", + "3b3b40": "4a3e46", + "292929": "272b2b" + }, + "2": { + "171717": "a45233", + "e8b127": "e7b432", + "52525a": "8f4b32", + "c52119": "ebc67c", + "842222": "1e1e43", + "f7e652": "577b98", + "fff7a5": "7b96aa", + "2baf23": "572626", + "f7bd21": "445f8a", + "e65a42": "eedd9c", + "ba2b23": "2c2c47", + "f5e193": "eadbb3", + "e66953": "b95b6e", + "6f6c8e": "cf752b", + "a6adb6": "f0b541", + "8c4e22": "b1632b", + "9c5200": "22325c", + "c43129": "6a253f", + "d95b45": "3a3f5e", + "3b3b40": "f1b571", + "292929": "7d3833" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/25-cosplay.json b/public/images/pokemon/variant/25-cosplay.json new file mode 100644 index 00000000000..e324c094019 --- /dev/null +++ b/public/images/pokemon/variant/25-cosplay.json @@ -0,0 +1,36 @@ +{ + "1": { + "f7e652": "a3d1a8", + "212121": "30263b", + "c43129": "6a253f", + "171717": "1e1526", + "292929": "282030", + "e65a42": "cf6182", + "c52119": "ad4e76", + "42424a": "443e6c", + "fff7a5": "c4e3c3", + "f7bd21": "79b5a5", + "45454a": "4f454c", + "9c5200": "315c75", + "633108": "09406b", + "e66953": "b95b6e", + "de9400": "338087" + }, + "2": { + "f7e652": "577b98", + "212121": "d8805b", + "c43129": "6a253f", + "171717": "a45233", + "292929": "282030", + "e65a42": "eedd9c", + "c52119": "ebc67c", + "42424a": "3f4246", + "fff7a5": "7b96aa", + "f7bd21": "445f8a", + "45454a": "f1b571", + "9c5200": "23345e", + "633108": "22244f", + "e66953": "b95b6e", + "de9400": "324472" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/25-cute-cosplay.json b/public/images/pokemon/variant/25-cute-cosplay.json new file mode 100644 index 00000000000..251530a0892 --- /dev/null +++ b/public/images/pokemon/variant/25-cute-cosplay.json @@ -0,0 +1,53 @@ +{ + "1": { + "e65a42": "cf6182", + "cf4770": "cf4a59", + "52525a": "30263b", + "c52119": "ad4e76", + "292929": "30263b", + "fff7a5": "f0eaa8", + "9c5200": "255e8a", + "752bd0": "5452b7", + "e66953": "b95b6e", + "c43129": "6a253f", + "42424a": "443e6c", + "f7e652": "a3d1a8", + "ea82a6": "e8848e", + "29292a": "1e1526", + "f3bace": "f2bbbb", + "853247": "85323c", + "52525c": "bab699", + "fff7a6": "c4e3c3", + "101011": "101010", + "baa998": "bab699", + "f7bd21": "79b5a5", + "101010": "1e1526", + "52525b": "4f454c" + }, + "2": { + "e65a42": "eedd9c", + "cf4770": "739b55", + "52525a": "d8805b", + "52525d": "d3ab5a", + "c52119": "ebc67c", + "292929": "d8805b", + "fff7a5": "ebe7b7", + "9c5200": "1e2d52", + "752bd0": "7751c2", + "e66953": "b95b6e", + "c43129": "6a253f", + "42424a": "373d45", + "f7e652": "577b98", + "ea82a6": "a4b95f", + "29292a": "a45233", + "f3bace": "c5cc85", + "853247": "254b30", + "52525c": "706053", + "fff7a6": "7b96aa", + "101011": "101010", + "baa998": "d3ab5a", + "f7bd21": "445f8a", + "101010": "a45233", + "52525b": "f1b571" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/25-gigantamax.json b/public/images/pokemon/variant/25-gigantamax.json new file mode 100644 index 00000000000..554b93c5bfa --- /dev/null +++ b/public/images/pokemon/variant/25-gigantamax.json @@ -0,0 +1,35 @@ +{ + "1": { + "212121": "1e1526", + "c52018": "ad4e76", + "f6e652": "a3d1a8", + "f6bd20": "79b5a5", + "fff9c2": "b8ffd9", + "e65a41": "cf6182", + "de9400": "338087", + "623108": "09406b", + "fff6a4": "c4e3c3", + "292929": "282030", + "323133": "30263b", + "f8fc4b": "5bc28b", + "9c5200": "315c75", + "41414a": "4f454c", + "61616d": "443e6c" + }, + "2": { + "212121": "a45233", + "c52018": "ebc67c", + "f6e652": "577b98", + "f6bd20": "445f8a", + "fff9c2": "83b1d2", + "e65a41": "eedd9c", + "de9400": "324472", + "623108": "09406b", + "fff6a4": "7b96aa", + "323133": "d8805b", + "695d65": "737383", + "f8fc4b": "326a9f", + "9c5200": "23345e", + "41414a": "d99362" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/25-partner.json b/public/images/pokemon/variant/25-partner.json new file mode 100644 index 00000000000..4363facf947 --- /dev/null +++ b/public/images/pokemon/variant/25-partner.json @@ -0,0 +1,36 @@ +{ + "1": { + "212121": "30263b", + "c52119": "ad4e76", + "fff7a5": "c4e3c3", + "f7e652": "a3d1a8", + "633108": "09406b", + "de9400": "338087", + "42424a": "443e6c", + "c43129": "6a253f", + "45454a": "4f454c", + "9c5200": "315c75", + "e66953": "b95b6e", + "e65a42": "cf6182", + "171717": "1e1526", + "f7bd21": "79b5a5", + "292929": "282030" + }, + "2": { + "212121": "d8805b", + "c52119": "ebc67c", + "fff7a5": "7b96aa", + "f7e652": "577b98", + "633108": "22244f", + "de9400": "324472", + "42424a": "3f4246", + "c43129": "6a253f", + "45454a": "f1b571", + "9c5200": "23345e", + "e66953": "b95b6e", + "e65a42": "eedd9c", + "171717": "a45233", + "f7bd21": "445f8a", + "292929": "282030" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/25-smart-cosplay.json b/public/images/pokemon/variant/25-smart-cosplay.json new file mode 100644 index 00000000000..4ba98883f16 --- /dev/null +++ b/public/images/pokemon/variant/25-smart-cosplay.json @@ -0,0 +1,42 @@ +{ + "1": { + "212121": "30263b", + "b7a599": "bab699", + "60b553": "76a848", + "366635": "3e5b2f", + "e35252": "d16b9a", + "c52119": "ad4e76", + "292929": "272b2b", + "9c5200": "315c75", + "f7e652": "a3d1a8", + "95635b": "91685f", + "171717": "1e1526", + "ba2525": "993f70", + "e65a42": "cf6182", + "54545c": "55555e", + "52525a": "4f454c", + "fffdea": "f8ffe3", + "f7bd21": "79b5a5", + "5f3434": "573b38" + }, + "2": { + "212121": "d8805b", + "b7a599": "a7b6b9", + "60b553": "dfb053", + "366635": "ab5130", + "e35252": "3a3f5e", + "c52119": "ebc67c", + "292929": "202937", + "9c5200": "23345e", + "f7e652": "577b98", + "95635b": "a09ea3", + "171717": "a45233", + "ba2525": "2b2b45", + "e65a42": "eedd9c", + "54545c": "45525c", + "52525a": "f1b571", + "fffdea": "f2f0df", + "f7bd21": "445f8a", + "5f3434": "666060" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/25-tough-cosplay.json b/public/images/pokemon/variant/25-tough-cosplay.json new file mode 100644 index 00000000000..620ac882643 --- /dev/null +++ b/public/images/pokemon/variant/25-tough-cosplay.json @@ -0,0 +1,43 @@ +{ + "1": { + "e37511": "d1694f", + "bf2629": "bf3638", + "303030": "30263b", + "b8282b": "753652", + "8d2b1d": "8e2525", + "424242": "443e6c", + "c52119": "ad4e76", + "292929": "1e1526", + "f7bd21": "79b5a5", + "fbab33": "de9764", + "db4a37": "ad4c60", + "e65a42": "cf6182", + "9c5200": "315c75", + "db5b42": "cf6a59", + "52525a": "4f454c", + "cecab9": "cfc8aa", + "f7e652": "a3d1a8" + }, + "2": { + "e37511": "644794", + "bf2629": "8e6fa1", + "f8ffe3": "e8e3e4", + "303030": "d8805b", + "b8282b": "6a253f", + "8d2b1d": "242866", + "424242": "3f4246", + "c52119": "e8be68", + "292929": "a45233", + "f7bd21": "445f8a", + "fbab33": "845ea1", + "db4a37": "b95b6e", + "e65a42": "edda8c", + "9c5200": "23345e", + "db5b42": "624780", + "52525a": "f1b571", + "4d4d4d": "2b3340", + "272b2b": "162231", + "cecab9": "cfc0c3", + "f7e652": "577b98" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/25.json b/public/images/pokemon/variant/25.json new file mode 100644 index 00000000000..0542587ba6d --- /dev/null +++ b/public/images/pokemon/variant/25.json @@ -0,0 +1,36 @@ +{ + "1": { + "42424a": "443e6c", + "fff7a5": "c4e3c3", + "c52119": "ad4e76", + "de9400": "338087", + "e65a42": "cf6182", + "f7e652": "a3d1a8", + "e66953": "b95b6e", + "45454a": "4f454c", + "292929": "282030", + "c43129": "6a253f", + "212121": "30263b", + "171717": "1e1526", + "f7bd21": "79b5a5", + "9c5200": "315c75", + "633108": "09406b" + }, + "2": { + "42424a": "3f4246", + "fff7a5": "7b96aa", + "c52119": "ebc67c", + "de9400": "324472", + "e65a42": "eedd9c", + "f7e652": "577b98", + "e66953": "b95b6e", + "45454a": "f1b571", + "292929": "282030", + "c43129": "6a253f", + "212121": "d8805b", + "171717": "a45233", + "f7bd21": "445f8a", + "9c5200": "23345e", + "633108": "22244f" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/26.json b/public/images/pokemon/variant/26.json new file mode 100644 index 00000000000..c078c38570f --- /dev/null +++ b/public/images/pokemon/variant/26.json @@ -0,0 +1,36 @@ +{ + "1": { + "ffefd6": "c8d4ba", + "bd1908": "ad4e76", + "944242": "395a80", + "bd5a31": "386d82", + "e6bd84": "a4bda7", + "ffbd00": "b3596b", + "5a2929": "293059", + "3a3a42": "30263b", + "8c6310": "8c3c4c", + "ffde5a": "cf7878", + "8d5911": "983e50", + "734231": "6e2f33", + "63636b": "4f454c", + "de7b31": "539190", + "f7ad29": "76a68b" + }, + "2": { + "ffefd6": "cfc4b5", + "542127": "905331", + "bd1908": "a44c5d", + "944242": "2d3b80", + "bd5a31": "375681", + "e6bd84": "a6b5ab", + "ffbd00": "f3cf91", + "5a2929": "202a60", + "8c6310": "c79b5a", + "ffde5a": "f2e4b6", + "8d5911": "dea96e", + "734231": "bd8447", + "de7b31": "4d6f98", + "f7ad29": "6385ab", + "643034": "2e4685" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/276.json b/public/images/pokemon/variant/276.json new file mode 100644 index 00000000000..d7c6c1268ec --- /dev/null +++ b/public/images/pokemon/variant/276.json @@ -0,0 +1,32 @@ +{ + "1": { + "bdbdce": "26523c", + "ffffff": "3c6a3d", + "efbd63": "e7a562", + "524a29": "4b210d", + "bdbdcd": "b5b5d5", + "a57331": "784524", + "212952": "12223d", + "3a3a31": "3e3e3e", + "314a7b": "1a385a", + "e69410": "bc7532", + "943a52": "ad8634", + "5a6b9c": "2a596b", + "ce5273": "cebf49" + }, + "2": { + "bdbdce": "453f63", + "ffffff": "635d81", + "efbd63": "89787c", + "524a29": "381f2c", + "bdbdcd": "b5b5d5", + "a57331": "4a323a", + "212952": "191222", + "3a3a31": "442c34", + "314a7b": "282037", + "e69410": "63414f", + "943a52": "8ec08b", + "5a6b9c": "3c2f48", + "ce5273": "bcd59d" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/277.json b/public/images/pokemon/variant/277.json new file mode 100644 index 00000000000..84d689cab9a --- /dev/null +++ b/public/images/pokemon/variant/277.json @@ -0,0 +1,34 @@ +{ + "1": { + "dea531": "bc7532", + "425a7b": "2a596b", + "ffffff": "3c6a3d", + "b5b5d6": "26523c", + "9c3152": "ad8634", + "945a10": "784524", + "5a5a5a": "b58251", + "63213a": "603c1d", + "c55a73": "cebf49", + "31313a": "89572a", + "e6b563": "e7a562", + "524221": "4b210d", + "292952": "12223d", + "294263": "1a385a" + }, + "2": { + "dea531": "63414f", + "425a7b": "3c2f48", + "ffffff": "635d81", + "b5b5d6": "453f63", + "9c3152": "8ec08b", + "945a10": "4a323a", + "5a5a5a": "5d454d", + "63213a": "5d9469", + "c55a73": "bcd59d", + "31313a": "442c34", + "e6b563": "89787c", + "524221": "381f2c", + "292952": "191222", + "294263": "282037" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/280.json b/public/images/pokemon/variant/280.json index b7b04951c43..d06d4b8a605 100644 --- a/public/images/pokemon/variant/280.json +++ b/public/images/pokemon/variant/280.json @@ -1,30 +1,24 @@ { "1": { + "7b8cb5": "d59c80", + "73bd73": "c08f44", + "9c94c5": "222222", + "cecee6": "ffc4a6", + "8ce68c": "ebc984", + "b5f794": "fff1c0", + "317b42": "89461a", + "d64a73": "da3e4f", "84294a": "b80e2f", "ff7b94": "ca2033", - "d64a73": "da3e4f", - "101010": "101010", - "73bd73": "c08f44", - "317b42": "89461a", - "b5f794": "fff1c0", - "8ce68c": "ebc984", - "cecee6": "ffc4a6", - "9c94c5": "222222", - "f7f7ff": "f8efde", - "7b8cb5": "d59c80" + "f7f7ff": "f8efde" }, "2": { - "84294a": "9e2a7c", - "ff7b94": "b035ae", - "d64a73": "d846c1", - "101010": "101010", "73bd73": "282c5d", - "317b42": "242745", - "b5f794": "5b5790", "8ce68c": "3f427f", - "cecee6": "cecee6", - "9c94c5": "9c94c5", - "f7f7ff": "f7f7ff", - "7b8cb5": "7b8cb5" + "b5f794": "5b5790", + "317b42": "242745", + "d64a73": "d846c1", + "84294a": "9e2a7c", + "ff7b94": "b035ae" } } \ No newline at end of file diff --git a/public/images/pokemon/variant/280_2.png b/public/images/pokemon/variant/280_2.png index 1d342f178e6..593d968b107 100644 Binary files a/public/images/pokemon/variant/280_2.png and b/public/images/pokemon/variant/280_2.png differ diff --git a/public/images/pokemon/variant/280_3.png b/public/images/pokemon/variant/280_3.png index 6803b7d4a40..63de10e023e 100644 Binary files a/public/images/pokemon/variant/280_3.png and b/public/images/pokemon/variant/280_3.png differ diff --git a/public/images/pokemon/variant/281.json b/public/images/pokemon/variant/281.json index fb2c33b2954..09336e01c54 100644 --- a/public/images/pokemon/variant/281.json +++ b/public/images/pokemon/variant/281.json @@ -1,28 +1,23 @@ { "1": { - "84294a": "b80e2f", - "317b42": "89461a", - "101010": "101010", - "ff7b94": "ca2033", - "d64a73": "da3e4f", - "b5f794": "fff1c0", "73bd73": "c08f44", - "8ce68c": "ebc984", "ffffff": "f8efde", - "7384ad": "d59c80", - "cecee6": "ffc4a6" + "cecee6": "ffc4a6", + "8ce68c": "ebc984", + "b5f794": "fff1c0", + "317b42": "89461a", + "84294a": "b80e2f", + "d64a73": "da3e4f", + "ff7b94": "ca2033", + "7384ad": "d59c80" }, "2": { - "84294a": "9e2a7c", - "317b42": "242745", - "101010": "101010", - "ff7b94": "b035ae", - "d64a73": "d846c1", - "b5f794": "5b5790", "73bd73": "282c5d", "8ce68c": "3f427f", - "ffffff": "ffffff", - "7384ad": "7384ad", - "cecee6": "cecee6" + "b5f794": "5b5790", + "317b42": "242745", + "84294a": "9e2a7c", + "d64a73": "d846c1", + "ff7b94": "b035ae" } } \ No newline at end of file diff --git a/public/images/pokemon/variant/281_2.png b/public/images/pokemon/variant/281_2.png index e461a6bc565..dd30df8fe71 100644 Binary files a/public/images/pokemon/variant/281_2.png and b/public/images/pokemon/variant/281_2.png differ diff --git a/public/images/pokemon/variant/281_3.png b/public/images/pokemon/variant/281_3.png index bc83ede10d0..0d9c802535d 100644 Binary files a/public/images/pokemon/variant/281_3.png and b/public/images/pokemon/variant/281_3.png differ diff --git a/public/images/pokemon/variant/282_2.png b/public/images/pokemon/variant/282_2.png index edb797c095a..98421dbc47d 100644 Binary files a/public/images/pokemon/variant/282_2.png and b/public/images/pokemon/variant/282_2.png differ diff --git a/public/images/pokemon/variant/282_3.png b/public/images/pokemon/variant/282_3.png index 614f68cc220..3156aa6d28e 100644 Binary files a/public/images/pokemon/variant/282_3.png and b/public/images/pokemon/variant/282_3.png differ diff --git a/public/images/pokemon/variant/359-mega.json b/public/images/pokemon/variant/359-mega.json new file mode 100644 index 00000000000..3e76a8e6ee6 --- /dev/null +++ b/public/images/pokemon/variant/359-mega.json @@ -0,0 +1,30 @@ +{ + "1": { + "273535": "2b3266", + "7b2931": "c9824b", + "414a6a": "421e4a", + "b4b4d5": "458196", + "cd2920": "f7c26d", + "293939": "27122b", + "fdfdfd": "61a8ab", + "525a7b": "59274e", + "d5deee": "589aa6", + "737bac": "874267", + "8b8bac": "3b6987", + "626283": "2a3163" + }, + "2": { + "273535": "420918", + "7b2931": "0f4391", + "414a6a": "b39279", + "b4b4d5": "752f40", + "cd2920": "2a96ce", + "293939": "996e5f", + "fdfdfd": "9e363b", + "525a7b": "e0c79f", + "d5deee": "8f2f41", + "737bac": "f5f1cb", + "8b8bac": "59213b", + "626283": "42122d" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/359.json b/public/images/pokemon/variant/359.json new file mode 100644 index 00000000000..936b3567c67 --- /dev/null +++ b/public/images/pokemon/variant/359.json @@ -0,0 +1,34 @@ +{ + "1": { + "424a6b": "421e4a", + "293a3a": "27122b", + "ce2921": "f7c26d", + "7b2931": "c9824b", + "ff7b73": "fff291", + "737bad": "874267", + "d6deef": "589aa6", + "283838": "101f30", + "525a7b": "612b54", + "b5b5d6": "458196", + "636384": "2a3163", + "7179ab": "2b3266", + "ffffff": "61a8ab", + "8c8cad": "3b6987" + }, + "2": { + "424a6b": "b39279", + "293a3a": "996e5f", + "ce2921": "2a96ce", + "7b2931": "0f4391", + "ff7b73": "96eeff", + "737bad": "f5f1cb", + "d6deef": "8f2f41", + "283838": "31101f", + "525a7b": "e0c79f", + "b5b5d6": "752f40", + "636384": "42122d", + "7179ab": "7d1d36", + "ffffff": "9e363b", + "8c8cad": "59213b" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/377.json b/public/images/pokemon/variant/377.json new file mode 100644 index 00000000000..84f8851b9a8 --- /dev/null +++ b/public/images/pokemon/variant/377.json @@ -0,0 +1,28 @@ +{ + "1": { + "b54200": "13512f", + "efad6b": "aac669", + "948c73": "2e4e7b", + "cec5ad": "4d8ba8", + "bd633a": "22773f", + "ef733a": "72b645", + "ef843a": "56963a", + "524a29": "182238", + "e6dead": "659db5", + "b5ad94": "3d6d8d", + "efe6de": "84c7ca" + }, + "2": { + "b54200": "3d0933", + "efad6b": "a54c5e", + "948c73": "262847", + "cec5ad": "303353", + "bd633a": "561934", + "ef733a": "c1271f", + "ef843a": "722a41", + "524a29": "161129", + "e6dead": "383e6a", + "b5ad94": "394170", + "efe6de": "4d5784" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/378.json b/public/images/pokemon/variant/378.json new file mode 100644 index 00000000000..c7d2816a024 --- /dev/null +++ b/public/images/pokemon/variant/378.json @@ -0,0 +1,38 @@ +{ + "0": { + "ffffff": "d7b6f1", + "293a7b": "101238", + "9cceff": "6f66a7", + "ceb521": "ca5846", + "6bb5d6": "414184", + "ffffad": "ffd6a7", + "ffe600": "e58b64", + "5a84ad": "282e64", + "3a6b8c": "191d4c", + "bdefff": "9983c4" + }, + "1": { + "6bb5d6": "bf344a", + "bdefff": "ffb88d", + "293a7b": "400b1c", + "ffe600": "7a5d98", + "5a84ad": "981d43", + "ffffff": "fff7d3", + "ffffad": "c39bd0", + "ceb521": "43356c", + "3a6b8c": "64132c", + "9cceff": "eb5d56" + }, + "2": { + "6bb5d6": "323232", + "bdefff": "5b5b5b", + "293a7b": "100f17", + "ffe600": "73e6f6", + "5a84ad": "212121", + "ffffff": "8c8c8c", + "ffffad": "e5fffd", + "ceb521": "319ce2", + "3a6b8c": "14131a", + "9cceff": "424242" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/379.json b/public/images/pokemon/variant/379.json new file mode 100644 index 00000000000..926acc7d987 --- /dev/null +++ b/public/images/pokemon/variant/379.json @@ -0,0 +1,30 @@ +{ + "1": { + "4a5a5a": "34366f", + "ff4242": "5cbed3", + "3a4252": "292960", + "ff9ca5": "d2d3c9", + "d6ced6": "cc9c65", + "b5adad": "a66f52", + "ffffff": "fff3aa", + "dedede": "f0d185", + "848c84": "4c5c91", + "4a4a4a": "533329", + "84847b": "80503b", + "bdbdbd": "7a9ee5" + }, + "2": { + "4a5a5a": "df8533", + "ff4242": "1e1e1e", + "3a4252": "e29631", + "ff9ca5": "a0a0a0", + "d6ced6": "cd5521", + "b5adad": "ad2d1e", + "ffffff": "ffb056", + "dedede": "e87537", + "848c84": "ffcd49", + "4a4a4a": "521328", + "84847b": "81222b", + "bdbdbd": "ffff7e" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/39.json b/public/images/pokemon/variant/39.json new file mode 100644 index 00000000000..c72887bdf9d --- /dev/null +++ b/public/images/pokemon/variant/39.json @@ -0,0 +1,26 @@ +{ + "1": { + "d63a31": "f18fc4", + "a53100": "6f305b", + "ffada5": "c5ebd5", + "e67384": "81c2b8", + "10b5ef": "a17ed9", + "ffcec5": "e5ffec", + "104a8c": "393178", + "1973c5": "604ea1", + "a51021": "3a6472", + "6b5263": "153427", + "ceefff": "d9d3e3" + }, + "2": { + "ffada5": "f5e884", + "e67384": "f5c45b", + "10b5ef": "d14b4b", + "ffcec5": "fff9bf", + "104a8c": "8a2f2f", + "1973c5": "c45c54", + "a51021": "9c5200", + "6b5263": "737454", + "ceefff": "ffe9ed" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/390.json b/public/images/pokemon/variant/390.json new file mode 100644 index 00000000000..ba0119974de --- /dev/null +++ b/public/images/pokemon/variant/390.json @@ -0,0 +1,34 @@ +{ + "1": { + "e63131": "1db978", + "b56b29": "64464d", + "9c3131": "174c48", + "947308": "a86256", + "7b4210": "382029", + "ef6b6b": "5db95b", + "ffd631": "eafe67", + "f06e6e": "81dc3f", + "ffe6ad": "edc6a4", + "7e4410": "994943", + "ffad52": "a88d8d", + "e63a42": "2d8766", + "de8400": "876766", + "deb552": "cc9176" + }, + "2": { + "e63131": "b5b0f3", + "b56b29": "293b69", + "9c3131": "422e6f", + "947308": "818596", + "7b4210": "171f46", + "ef6b6b": "cb96e5", + "ffd631": "f3f8fe", + "f06e6e": "cbcfff", + "ffe6ad": "d3d5e0", + "7e4410": "626678", + "ffad52": "6995b5", + "e63a42": "8457b0", + "de8400": "3e5f8a", + "deb552": "a5a9b8" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/391.json b/public/images/pokemon/variant/391.json new file mode 100644 index 00000000000..c3503dec40a --- /dev/null +++ b/public/images/pokemon/variant/391.json @@ -0,0 +1,40 @@ +{ + "1": { + "8c7342": "994943", + "dfe5e7": "dac99d", + "c59463": "cc9176", + "cf3419": "2d8766", + "9c5219": "64464d", + "ffffff": "faf7d4", + "735a10": "a86256", + "cf2b19": "c9537e", + "ffce47": "f69044", + "efa542": "cd5528", + "ffce42": "eafe67", + "1052b5": "751a2f", + "1073de": "cc3140", + "6b3a08": "382029", + "d68c29": "876766", + "ce4219": "1db978", + "efce94": "edc6a4" + }, + "2": { + "8c7342": "818596", + "dfe5e7": "dca15d", + "c59463": "a5a9b8", + "cf3419": "8457b0", + "9c5219": "293b69", + "ffffff": "ffe175", + "735a10": "626678", + "cf2b19": "552b94", + "ffce47": "e8fdff", + "efa542": "b0cbd4", + "ffce42": "f3f8fe", + "1052b5": "e09f2f", + "1073de": "ffd745", + "6b3a08": "171f46", + "d68c29": "3e5f8a", + "ce4219": "b5b0f3", + "efce94": "d3d5e0" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/392.json b/public/images/pokemon/variant/392.json new file mode 100644 index 00000000000..78a9777736a --- /dev/null +++ b/public/images/pokemon/variant/392.json @@ -0,0 +1,54 @@ +{ + "1": { + "000000": "ffffff", + "a96442": "1a8251", + "a56240": "10916d", + "e68c5a": "876766", + "6b3a10": "382029", + "cfa423": "c9601e", + "bdc5de": "dac99d", + "a56342": "64464d", + "c9a022": "b7e350", + "737384": "9f8876", + "e63a42": "1db978", + "c59c21": "cd5528", + "875d08": "b03813", + "ffde4a": "e8a82a", + "ffde52": "f69044", + "e6353e": "2d8766", + "19427b": "581225", + "f88c49": "5db95b", + "ffffff": "faf7d4", + "845a08": "9b2719", + "3a73a5": "972733", + "f78c4a": "81dc3f", + "ffde4d": "eafe67", + "842931": "174c48" + }, + "2": { + "000000": "ffffff", + "a96442": "4c2985", + "a56240": "9595db", + "e68c5a": "3e5f8a", + "6b3a10": "171f46", + "cfa423": "c8af9b", + "bdc5de": "dca15d", + "a56342": "293b69", + "c9a022": "cbd0e3", + "737384": "a15a34", + "e63a42": "b5b0f3", + "c59c21": "a0c0cd", + "875d08": "8a5954", + "ffde4a": "fff8e5", + "ffde52": "e8fdff", + "e6353e": "8457b0", + "19427b": "4d5196", + "f88c49": "cb96e5", + "ffffff": "ffe175", + "845a08": "617995", + "3a73a5": "9c96e2", + "f78c4a": "cbcfff", + "ffde4d": "f3f8fe", + "842931": "422e6f" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/40.json b/public/images/pokemon/variant/40.json new file mode 100644 index 00000000000..9ec866694ca --- /dev/null +++ b/public/images/pokemon/variant/40.json @@ -0,0 +1,27 @@ +{ + "1": { + "737373": "1f2e3b", + "ffb3db": "f18fc4", + "9c6b21": "153139", + "8c4242": "3a6472", + "52a58c": "a17ed9", + "f77b94": "81c2b8", + "734219": "214f4f", + "ffadbd": "c5ebd5", + "ce6b63": "82b8a9", + "215a63": "393178" + }, + "2": { + "737373": "3b1f24", + "e6dee6": "bc4e24", + "9c6b21": "612719", + "8c4242": "9c5200", + "52a58c": "c45c54", + "f77b94": "f5c45b", + "ffffff": "d07439", + "734219": "68311a", + "ffadbd": "f5e884", + "ce6b63": "e6a54c", + "215a63": "8a2f2f" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/4144.json b/public/images/pokemon/variant/4144.json new file mode 100644 index 00000000000..7b298e34f24 --- /dev/null +++ b/public/images/pokemon/variant/4144.json @@ -0,0 +1,40 @@ +{ + "1": { + "43458b": "8cb0d3", + "60748a": "090a2e", + "bbc9d9": "39579a", + "282a5d": "48638c", + "b27fd4": "ffb725", + "080808": "101010", + "2f2f2f": "4da0c9", + "5fbddc": "ffb725", + "754691": "08092d", + "a695ea": "d5f1ff", + "1a1a1a": "254f89", + "6f65c5": "afd4ee", + "b480d6": "181f54", + "d9b5fb": "29336f", + "060606": "101010", + "74458f": "bd5a2c", + "eef0f2": "5678a9" + }, + "2": { + "43458b": "75151e", + "60748a": "a37f56", + "bbc9d9": "ead9b8", + "282a5d": "540916", + "b27fd4": "ce2488", + "080808": "101010", + "2f2f2f": "ffefe5", + "5fbddc": "ce2488", + "754691": "873c0f", + "a695ea": "c0443d", + "1a1a1a": "bb826c", + "6f65c5": "a2282c", + "b480d6": "d58639", + "d9b5fb": "f4b260", + "060606": "101010", + "74458f": "952274", + "eef0f2": "fff9e7" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/4145.json b/public/images/pokemon/variant/4145.json new file mode 100644 index 00000000000..9800b1a00dc --- /dev/null +++ b/public/images/pokemon/variant/4145.json @@ -0,0 +1,26 @@ +{ + "1": { + "50453c": "334c7f", + "863716": "7e98ad", + "ffd541": "f28b41", + "272320": "111742", + "38322d": "22253b", + "de6e33": "d85b26", + "c24814": "b3cdd9", + "3e352b": "1e2e5f", + "f76c1a": "daf6f6", + "5f2311": "5c6f8e" + }, + "2": { + "50453c": "d2ddea", + "863716": "871858", + "ffd541": "3cd96c", + "272320": "3c445e", + "38322d": "202231", + "de6e33": "25b165", + "c24814": "ba276d", + "3e352b": "9da9bd", + "f76c1a": "e14589", + "5f2311": "630645" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/4145_2.png b/public/images/pokemon/variant/4145_2.png index 34776b586a9..3bee1a58c06 100644 Binary files a/public/images/pokemon/variant/4145_2.png and b/public/images/pokemon/variant/4145_2.png differ diff --git a/public/images/pokemon/variant/4145_3.png b/public/images/pokemon/variant/4145_3.png index 0b78ce12747..a255a4b6894 100644 Binary files a/public/images/pokemon/variant/4145_3.png and b/public/images/pokemon/variant/4145_3.png differ diff --git a/public/images/pokemon/variant/4146.json b/public/images/pokemon/variant/4146.json new file mode 100644 index 00000000000..e35636cb6d3 --- /dev/null +++ b/public/images/pokemon/variant/4146.json @@ -0,0 +1,31 @@ +{ + "1": { + "00bfbf": "ff78a6", + "35454d": "f774a0", + "b51c39": "77a7bb", + "6b8895": "2b5584", + "f15888": "73e1e6", + "35454b": "0d1e54", + "e82f52": "24a8d3", + "ffd5f0": "e4fff6", + "840020": "1f557c", + "ffaedc": "a5f5e7", + "262e30": "000240", + "54656c": "163269", + "de3859": "cdf0f1" + }, + "2": { + "00bfbf": "db7640", + "35454d": "db743c", + "b51c39": "004634", + "6b8895": "fff9de", + "f15888": "6acf42", + "35454b": "adb981", + "e82f52": "058323", + "ffd5f0": "f4ff90", + "840020": "00312d", + "ffaedc": "c2f75f", + "54656c": "e4e8bb", + "de3859": "04723a" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/4146_2.png b/public/images/pokemon/variant/4146_2.png index 8cc32387d4b..4c260c7ef42 100644 Binary files a/public/images/pokemon/variant/4146_2.png and b/public/images/pokemon/variant/4146_2.png differ diff --git a/public/images/pokemon/variant/4146_3.png b/public/images/pokemon/variant/4146_3.png index c0ff71bcdd4..27d05c91a0a 100644 Binary files a/public/images/pokemon/variant/4146_3.png and b/public/images/pokemon/variant/4146_3.png differ diff --git a/public/images/pokemon/variant/430.json b/public/images/pokemon/variant/430.json new file mode 100644 index 00000000000..e6771e34524 --- /dev/null +++ b/public/images/pokemon/variant/430.json @@ -0,0 +1,40 @@ +{ + "1": { + "31313a": "1d1d2b", + "efeff7": "b9382d", + "8c313a": "b3986b", + "5a5a3a": "1e1e2c", + "545454": "3c3b4d", + "29213a": "271b1a", + "3a5a9c": "694c30", + "8c3039": "9e2933", + "de5057": "bd392d", + "a3a3b5": "60606c", + "a5a5b5": "7a1e21", + "de525a": "f3e3b3", + "4a2121": "755237", + "ad943a": "3f3e50", + "3a3a5a": "422e26", + "525252": "380514", + "f7de3a": "61616d" + }, + "2": { + "31313a": "521a16", + "efeff7": "975bc2", + "8c313a": "bc4b84", + "5a5a3a": "4e1915", + "545454": "87432e", + "29213a": "091e16", + "3a5a9c": "1d6e47", + "8c3039": "9e2933", + "de5057": "bd392d", + "a3a3b5": "c4743b", + "a5a5b5": "4f358e", + "de525a": "f17f9c", + "4a2121": "7b2363", + "ad943a": "85412d", + "3a3a5a": "0e4333", + "525252": "1c1754", + "f7de3a": "c2723a" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/453.json b/public/images/pokemon/variant/453.json index 54703fa28c3..208dda05920 100644 --- a/public/images/pokemon/variant/453.json +++ b/public/images/pokemon/variant/453.json @@ -1,23 +1,21 @@ { "1": { - "4a4a8c": "701221", - "101010": "101010", - "849cff": "c45447", - "6b73d6": "9e1e23", - "525252": "502424", - "313142": "2c0f0f", + "4a4a8c": "701237", + "849cff": "c43658", + "6b73d6": "9e1e4e", + "525252": "50242f", + "313142": "2f0419", "ffd619": "c1e65a", "b58c19": "8ac43c", - "9c3a3a": "d07320", - "e6525a": "f2b64c", - "ff9ca5": "f7db86", + "9c3a3a": "ca5925", + "e6525a": "e58837", + "ff9ca5": "ffc15b", "ffffff": "ffe29b", "b5b5c5": "af7953", "7b7b8c": "794032" }, "2": { "4a4a8c": "d88f77", - "101010": "101010", "849cff": "fff2c9", "6b73d6": "f0ce8b", "525252": "75204b", diff --git a/public/images/pokemon/variant/454.json b/public/images/pokemon/variant/454.json index b59a3c2f680..f14ca9fd93b 100644 --- a/public/images/pokemon/variant/454.json +++ b/public/images/pokemon/variant/454.json @@ -1,24 +1,22 @@ { "1": { - "4a4a8c": "701221", - "101010": "101010", - "6b73d6": "9e1e23", - "849cff": "c45447", - "313142": "2c0f0f", - "525252": "502424", + "4a4a8c": "701237", + "6b73d6": "9e1e4e", + "849cff": "c43658", + "313142": "2f0419", + "525252": "50242f", "b58c19": "8ac43c", "ffd619": "c1e65a", - "e6525a": "f2b64c", - "9c3a3a": "d07320", + "e6525a": "e58837", + "9c3a3a": "ca5925", "b5b5c5": "af7953", "ffffff": "ffe29b", "3a3a52": "4c0914", - "ff9ca5": "f7db86", + "ff9ca5": "ffc15b", "7b7b8c": "794032" }, "2": { "4a4a8c": "d88f77", - "101010": "101010", "6b73d6": "f0ce8b", "849cff": "fff2c9", "313142": "610d31", @@ -29,7 +27,7 @@ "9c3a3a": "16729b", "b5b5c5": "b1798c", "ffffff": "f0e3e5", - "3a3a52": "4c0914", + "3a3a52": "b15248", "ff9ca5": "a9ebeb", "7b7b8c": "7e3a6a" } diff --git a/public/images/pokemon/variant/455.json b/public/images/pokemon/variant/455.json new file mode 100644 index 00000000000..1483b02ef5b --- /dev/null +++ b/public/images/pokemon/variant/455.json @@ -0,0 +1,35 @@ +{ + "1": { + "f7ce31": "7c5d53", + "c59c31": "4d3432", + "9c214a": "451e14", + "2b453d": "523b3c", + "3a5a3a": "b34a82", + "5a6342": "826660", + "8c9452": "b89d8c", + "846b31": "301e20", + "bdc57b": "efd9ba", + "422919": "300c0c", + "e62919": "775331", + "63843a": "e880ab", + "29423a": "7e3b67", + "8f9653": "e2b0bc" + }, + "2": { + "f7ce31": "518078", + "ffffff": "affffe", + "c59c31": "244a45", + "9c214a": "1e4340", + "2b453d": "151926", + "3a5a3a": "37818a", + "5a6342": "2d304e", + "8c9452": "424d6e", + "846b31": "122e2f", + "bdc57b": "6679a1", + "422919": "0d2626", + "e62919": "406b64", + "63843a": "74ddcd", + "29423a": "123247", + "8f9653": "3d909b" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/486.json b/public/images/pokemon/variant/486.json new file mode 100644 index 00000000000..32082b03337 --- /dev/null +++ b/public/images/pokemon/variant/486.json @@ -0,0 +1,41 @@ +{ + "1": { + "364859": "611d2a", + "adadc5": "ca7426", + "374859": "6b76a4", + "3a4a5a": "5e1e33", + "4aa563": "e2f2ff", + "5f6d7d": "7b2a19", + "ef7b8c": "7741a1", + "b5bdc5": "0d6696", + "5ac5f7": "5f94d9", + "d6ced6": "e89b34", + "3c4d5e": "3f031d", + "ffffff": "eb8746", + "21846b": "90a7cd", + "fafafa": "ffc245", + "c59c52": "a12612", + "f7d65a": "ce5129", + "7b6321": "3d021b", + "8c94ad": "13081a" + }, + "2": { + "364859": "24293f", + "adadc5": "4f673a", + "374859": "2f1a18", + "3a4a5a": "3b1930", + "4aa563": "755648", + "5f6d7d": "374427", + "ef7b8c": "811745", + "b5bdc5": "f1c832", + "5ac5f7": "d3271a", + "d6ced6": "6e884b", + "ffffff": "a8afaf", + "21846b": "492f29", + "fafafa": "88b06f", + "c59c52": "5d717a", + "f7d65a": "8f9b9e", + "7b6321": "384751", + "8c94ad": "494922" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/501.json b/public/images/pokemon/variant/501.json new file mode 100644 index 00000000000..e70d0319842 --- /dev/null +++ b/public/images/pokemon/variant/501.json @@ -0,0 +1,33 @@ +{ + "1": { + "c59429": "ff9ef3", + "efce84": "f2d5ee", + "294252": "241e44", + "c49529": "b73891", + "215a63": "1e1a35", + "c5c5ce": "e3c2ca", + "4a6bad": "9660d1", + "21949c": "373049", + "29bdc5": "5d4a70", + "8c5a31": "af62ac", + "31426b": "4b349e", + "8a5830": "681d49" + }, + "2": { + "8c8c9c": "8f7491", + "c59429": "4e8787", + "efce84": "8abfb1", + "4a4a4a": "715b72", + "294252": "104432", + "c49529": "4e8787", + "215a63": "000000", + "c5c5ce": "ba9bc1", + "4a6bad": "589787", + "21949c": "321e1e", + "ffffff": "f5e9f4", + "29bdc5": "5e3e38", + "8c5a31": "0c4848", + "31426b": "3c706b", + "8a5830": "0c4848" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/502.json b/public/images/pokemon/variant/502.json new file mode 100644 index 00000000000..4227d277216 --- /dev/null +++ b/public/images/pokemon/variant/502.json @@ -0,0 +1,33 @@ +{ + "1": { + "7b5a10": "d877cd", + "31528c": "9d5bc9", + "4a4a4a": "20193d", + "efd68c": "f2d5ee", + "293a6b": "503e8e", + "c5525a": "b73891", + "52bdbd": "624060", + "c59429": "ff9ef3", + "733a3a": "6b1d42", + "313131": "120f33", + "315a73": "1e1624", + "218c94": "39273d", + "fffdfd": "ebb9c4" + }, + "2": { + "7b5a10": "0d5656", + "31528c": "5e3e38", + "4a4a4a": "2c3940", + "efd68c": "63c7bd", + "293a6b": "321e1e", + "c5525a": "519785", + "52bdbd": "8b7566", + "c59429": "488383", + "733a3a": "377667", + "313131": "1f2b36", + "315a73": "483026", + "218c94": "684f44", + "fffdfd": "ffffc2", + "ffffff": "ffffc2" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/503.json b/public/images/pokemon/variant/503.json new file mode 100644 index 00000000000..16447be5cca --- /dev/null +++ b/public/images/pokemon/variant/503.json @@ -0,0 +1,37 @@ +{ + "1": { + "84a5a5": "563785", + "4a4a4a": "5e283e", + "215a9c": "4c234a", + "c5c5ce": "b57ea1", + "8aa3a3": "a05982", + "d65263": "b73891", + "8da8a8": "a58b90", + "7b6342": "975fad", + "fffeff": "ebb9c4", + "213a63": "28142c", + "4a4a4c": "6b3e51", + "d6c57b": "f2d5ee", + "5a7373": "332a59", + "ad945a": "db87d1" + }, + "2": { + "84a5a5": "41857b", + "4a4a4a": "c2700d", + "215a9c": "5e3e38", + "c5c5ce": "efa838", + "8aa3a3": "d3a51f", + "d65263": "41857b", + "8da8a8": "bdbdbd", + "7b6342": "0d5656", + "fdfdff": "ffffff", + "fffeff": "f9df58", + "213a63": "321e1e", + "4a4a4c": "c2700d", + "d6c57b": "63c7bd", + "5a7373": "2a5c57", + "9ab2af": "2a5c57", + "494644": "1a5451", + "ad945a": "488383" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/527.json b/public/images/pokemon/variant/527.json new file mode 100644 index 00000000000..460a954874f --- /dev/null +++ b/public/images/pokemon/variant/527.json @@ -0,0 +1,28 @@ +{ + "1": { + "191921": "24224f", + "424a5a": "866ca1", + "6b94ad": "6e315e", + "f7adb5": "8ffff9", + "73adc5": "853d6f", + "292931": "55457a", + "ce2942": "a3ffed", + "8c4a52": "4874b8", + "84193a": "5fd4d0", + "c56b7b": "6bc7e8", + "4a6b7b": "361538", + "addef7": "914a6e" + }, + "2": { + "191921": "45234d", + "424a5a": "bf3f75", + "6b94ad": "db843d", + "f7adb5": "b682e0", + "73adc5": "e8b04f", + "292931": "8c2961", + "8c4a52": "393582", + "c56b7b": "7b5ebf", + "4a6b7b": "994d22", + "addef7": "f7e05c" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/528.json b/public/images/pokemon/variant/528.json new file mode 100644 index 00000000000..86dd66a4344 --- /dev/null +++ b/public/images/pokemon/variant/528.json @@ -0,0 +1,38 @@ +{ + "1": { + "bdbdce": "76debd", + "313131": "55457a", + "ceefff": "a6ffd7", + "425aa5": "451b41", + "4a4a52": "866ca1", + "2b2b2b": "2b4182", + "2e2e2e": "2f1236", + "f7a59c": "8ffff9", + "317b94": "6e315e", + "54546d": "582253", + "de8c84": "6bc7e8", + "19a5ce": "914a6e", + "944a4a": "4874b8", + "494950": "3b53a3", + "6b7b84": "439ca1", + "363636": "2e6f7a" + }, + "2": { + "bdbdce": "db843d", + "313131": "701c4c", + "ceefff": "f7e05c", + "425aa5": "d6a178", + "4a4a52": "bf3f75", + "2b2b2b": "1d1c4f", + "2e2e2e": "a6705e", + "f7a59c": "b682e0", + "317b94": "e0b49a", + "54546d": "a87354", + "de8c84": "7b5ebf", + "19a5ce": "f9fae3", + "944a4a": "393582", + "494950": "1b1f4d", + "6b7b84": "994d22", + "363636": "6b2314" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/587.json b/public/images/pokemon/variant/587.json new file mode 100644 index 00000000000..34831752444 --- /dev/null +++ b/public/images/pokemon/variant/587.json @@ -0,0 +1,33 @@ +{ + "1": { + "d6a531": "a84223", + "fffbf6": "8bd5dc", + "917d53": "16223d", + "ffd600": "d55b19", + "313131": "1d352a", + "212121": "091814", + "b58c08": "681c0e", + "cec5ad": "5a9fbf", + "6b5a31": "3b1c1b", + "a09478": "406da4", + "414141": "2b5d3f", + "434141": "2b5d3f" + }, + "2": { + "c56b63": "5046a7", + "d6a531": "6597cd", + "fffbf6": "c4658e", + "917d53": "321832", + "ffd600": "8bcaee", + "943a42": "462060", + "313131": "372a5b", + "212121": "15132f", + "e69484": "8166c6", + "b58c08": "4879af", + "cec5ad": "9b4072", + "6b5a31": "28273d", + "a09478": "7b3760", + "414141": "5e3a86", + "434141": "5e3a86" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/588.json b/public/images/pokemon/variant/588.json new file mode 100644 index 00000000000..86aa0e118f7 --- /dev/null +++ b/public/images/pokemon/variant/588.json @@ -0,0 +1,33 @@ +{ + "1": { + "213a5a": "2f185b", + "316bff": "8150a7", + "73d6ff": "e8aa48", + "313131": "38131d", + "736321": "8188b0", + "c55200": "b9262c", + "528cff": "c682d6", + "b59c19": "b8c5e5", + "4a4a4a": "64242d", + "000000": "ffffff", + "3a5284": "492c72", + "ffde19": "eef5ff", + "4294ad": "cd6a31" + }, + "2": { + "213a5a": "44446f", + "316bff": "d2cdeb", + "73d6ff": "ffe28d", + "313131": "182138", + "736321": "6f1b34", + "c55200": "ffe8c3", + "528cff": "f9f3ff", + "ce5263": "df6b99", + "b59c19": "a42641", + "4a4a4a": "28334f", + "000000": "ffffff", + "3a5284": "7777a7", + "ffde19": "d0413f", + "4294ad": "d9a35c" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/589.json b/public/images/pokemon/variant/589.json new file mode 100644 index 00000000000..486088d13d3 --- /dev/null +++ b/public/images/pokemon/variant/589.json @@ -0,0 +1,32 @@ +{ + "1": { + "c5c5c5": "f9c347", + "ef2952": "eb8343", + "e65a10": "614593", + "bd2152": "c44126", + "736321": "7b8bb3", + "840808": "931119", + "000000": "ffffff", + "6b6b6b": "b34516", + "bd9c19": "b8c5e5", + "195abd": "7436a4", + "94949c": "dc862d", + "ffde19": "eef5ff", + "3a424a": "69130d" + }, + "2": { + "c5c5c5": "6e8e99", + "ef2952": "f7efff", + "e65a10": "ffe8c3", + "bd2152": "beb7df", + "736321": "6f1b34", + "840808": "72709e", + "000000": "ffffff", + "6b6b6b": "293a52", + "bd9c19": "a42641", + "195abd": "4f3d33", + "94949c": "3f6372", + "ffde19": "d0413f", + "3a424a": "1b253d" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/590.json b/public/images/pokemon/variant/590.json new file mode 100644 index 00000000000..d17924e966c --- /dev/null +++ b/public/images/pokemon/variant/590.json @@ -0,0 +1,30 @@ +{ + "1": { + "826b61": "348999", + "9c3a3a": "71de8c", + "846b63": "348999", + "6b4a31": "0d9999", + "684b30": "0d9999", + "422929": "0a5870", + "9c3a7b": "88af70", + "de5a52": "e6ffc1", + "d6639c": "f4ebba", + "7b3131": "49ad77", + "c5b59c": "47d1b5", + "fff7e6": "afecc6" + }, + "2": { + "826b61": "86b8cc", + "9c3a3a": "e098cd", + "846b63": "404f6b", + "6b4a31": "f2f7f9", + "684b30": "2b5caf", + "422929": "b9d9e5", + "9c3a7b": "b1c4dd", + "de5a52": "ffbfcb", + "d6639c": "f2f7f9", + "7b3131": "ce88bb", + "c5b59c": "498cd3", + "fff7e6": "6ac2e2" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/591.json b/public/images/pokemon/variant/591.json new file mode 100644 index 00000000000..d0290501b39 --- /dev/null +++ b/public/images/pokemon/variant/591.json @@ -0,0 +1,42 @@ +{ + "1": { + "423231": "0c7588", + "533f3a": "094164", + "604740": "0b7f79", + "6b314a": "49ad77", + "423131": "0a5870", + "8c735a": "348999", + "cec5c5": "afecc6", + "634b42": "094164", + "9c9484": "47d1b5", + "423331": "0c7588", + "634c42": "348999", + "291919": "094164", + "ad3163": "71de8c", + "de8ca5": "d8cfa0", + "634a42": "0d9999", + "6b314c": "749660", + "ffadce": "f4ebba", + "de528c": "e6ffc1" + }, + "2": { + "423231": "404f6b", + "533f3a": "223656", + "604740": "3b6aa0", + "6b314a": "ad629a", + "423131": "9bb6c1", + "8c735a": "2b5caf", + "cec5c5": "6ac2e2", + "634b42": "223656", + "9c9484": "56a1e2", + "423331": "9bb6c1", + "634c42": "3f7dc7", + "291919": "5e718e", + "ad3163": "e098cd", + "de8ca5": "b1c4dd", + "634a42": "f2f7f9", + "6b314c": "65788e", + "ffadce": "f4f8f9", + "de528c": "ffbfcb" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/616.json b/public/images/pokemon/variant/616.json new file mode 100644 index 00000000000..184360b3734 --- /dev/null +++ b/public/images/pokemon/variant/616.json @@ -0,0 +1,30 @@ +{ + "1": { + "3a8442": "4e3671", + "42bd31": "775998", + "313131": "491722", + "c5c5d6": "f9c347", + "9494ad": "dc862d", + "ff4a7b": "6ba779", + "630021": "204b4f", + "b5214a": "346c65", + "de3163": "4a8474", + "000000": "ffffff", + "29315a": "69130d", + "5a5a7b": "b34516" + }, + "2": { + "3a8442": "dfa75c", + "42bd31": "fff07e", + "313131": "171e2f", + "c5c5d6": "6e8e99", + "9494ad": "3f6372", + "ff4a7b": "8cb0d6", + "630021": "2e3469", + "b5214a": "4f62a4", + "de3163": "6b8bbf", + "000000": "ffffff", + "29315a": "1b253d", + "5a5a7b": "293a52" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/617.json b/public/images/pokemon/variant/617.json new file mode 100644 index 00000000000..7c2951b5571 --- /dev/null +++ b/public/images/pokemon/variant/617.json @@ -0,0 +1,30 @@ +{ + "1": { + "ffffff": "fff47e", + "a5846b": "5a6675", + "42b55a": "4e3671", + "c53a6b": "427b6b", + "bdbdce": "df9847", + "527b42": "362658", + "732931": "214c49", + "ff4a7b": "6ba779", + "6b84c5": "eef5ff", + "3a2919": "192638", + "000000": "ffffff", + "293a6b": "69719e", + "5a6384": "b8c5e5" + }, + "2": { + "a5846b": "637974", + "42b55a": "415c69", + "c53a6b": "dcaa47", + "527b42": "1d2a3b", + "732931": "8a5727", + "ff4a7b": "ffee72", + "6b84c5": "b43d40", + "3a2919": "2a2235", + "000000": "ffffff", + "293a6b": "461b2e", + "5a6384": "7b2c3d" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/621.json b/public/images/pokemon/variant/621.json new file mode 100644 index 00000000000..1c347dcadc8 --- /dev/null +++ b/public/images/pokemon/variant/621.json @@ -0,0 +1,28 @@ +{ + "1": { + "d6bd6b": "ac8b5e", + "940042": "1a2248", + "635231": "605127", + "104a8c": "7e231b", + "8c7b5a": "73654b", + "efc500": "5c7886", + "103163": "601111", + "521031": "0f1330", + "d60042": "26335d", + "316bad": "a13b2c", + "d65273": "be5b5e" + }, + "2": { + "d6bd6b": "ffbc30", + "940042": "177297", + "635231": "be6e18", + "104a8c": "c9bb9a", + "8c7b5a": "da8921", + "efc500": "ffd437", + "103163": "a0896b", + "521031": "0f4973", + "d60042": "24aec0", + "316bad": "e3ddbd", + "d65273": "c583a5" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/6503.json b/public/images/pokemon/variant/6503.json new file mode 100644 index 00000000000..c6cc21b45db --- /dev/null +++ b/public/images/pokemon/variant/6503.json @@ -0,0 +1,34 @@ +{ + "1": { + "282f62": "f7d9de", + "c4c5cf": "e3c2ca", + "84a4a7": "563785", + "a82c47": "d45b9e", + "8aa3a3": "6b415b", + "494a48": "3d2439", + "1d3962": "28142c", + "d75063": "b73891", + "1e224e": "dc95ae", + "1e5b9b": "4d244b", + "181531": "a26579", + "6b1c34": "8f3396", + "597471": "332a59", + "8da8a8": "a58b90" + }, + "2": { + "282f62": "efdfee", + "c4c5cf": "232d2e", + "84a4a7": "41857b", + "a82c47": "8abfb1", + "8aa3a3": "181f20", + "faf9f9": "2c3940", + "494a48": "0b0f18", + "1d3962": "321e1e", + "d75063": "8f65d8", + "1e224e": "ba9bc1", + "1e5b9b": "5e3e38", + "181531": "715b72", + "6b1c34": "6d9d9a", + "597471": "2a5c57" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/656.json b/public/images/pokemon/variant/656.json new file mode 100644 index 00000000000..68743a4c9f1 --- /dev/null +++ b/public/images/pokemon/variant/656.json @@ -0,0 +1,32 @@ +{ + "1": { + "838394": "4d7dc5", + "62ace6": "8363af", + "7bcdff": "9c75c2", + "ffec8c": "ddfff9", + "a1a1c4": "7ab7ec", + "c9b241": "97d6e2", + "dfcf77": "bae7e8", + "174592": "37408c", + "fdfdfd": "b1e5ff", + "9c9cc5": "5385c7", + "cdcde6": "7eb7e8", + "396a83": "362864", + "5a94cd": "7054a4" + }, + "2": { + "838394": "cc6845", + "62ace6": "c44848", + "7bcdff": "dd6155", + "ffec8c": "ddfff9", + "a1a1c4": "f7c685", + "c9b241": "97d6e2", + "dfcf77": "bae7e8", + "174592": "198158", + "fdfdfd": "fff4bd", + "9c9cc5": "c96a48", + "cdcde6": "f7b785", + "396a83": "5c0d33", + "5a94cd": "a92f3f" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/657.json b/public/images/pokemon/variant/657.json new file mode 100644 index 00000000000..773b4d2efc1 --- /dev/null +++ b/public/images/pokemon/variant/657.json @@ -0,0 +1,32 @@ +{ + "1": { + "f8f8f8": "8dcfff", + "efc653": "abd7db", + "737373": "0f3f82", + "0b566a": "281f52", + "ffec72": "c9fff5", + "002c58": "1c0726", + "bfbfbf": "4386df", + "006ba6": "4e1852", + "009dd5": "61255e", + "0b4a7a": "340f3d", + "e1a03a": "78c7c7", + "41ccf5": "7755a7", + "2896b5": "4b3578" + }, + "2": { + "f8f8f8": "fff6c7", + "efc653": "abd7db", + "737373": "df6a50", + "0b566a": "7e1628", + "ffec72": "ddfff9", + "002c58": "0c3b54", + "bfbfbf": "ffc996", + "006ba6": "239c91", + "009dd5": "37b8ac", + "0b4a7a": "156f78", + "e1a03a": "86abbb", + "41ccf5": "dd7355", + "2896b5": "a92f3a" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/658-ash.json b/public/images/pokemon/variant/658-ash.json new file mode 100644 index 00000000000..29b5bd2560b --- /dev/null +++ b/public/images/pokemon/variant/658-ash.json @@ -0,0 +1,44 @@ +{ + "1": { + "265595": "432b6c", + "3f4447": "466698", + "de3431": "3fca9f", + "f8f8f8": "a1e9f0", + "7b282e": "0e3e81", + "6b1d1d": "206d74", + "4ebdd9": "41a7b0", + "bfb169": "165e78", + "bfbfbf": "8cc7d4", + "ffb2bf": "b7e9ff", + "bf4c60": "4386df", + "fff0a6": "271f4c", + "3e7acc": "6b4592", + "18335c": "170738", + "f2798d": "8dcfff", + "f01818": "39b88f", + "7ddeff": "7ddcd6", + "268794": "1c3e58", + "282c35": "271f4c" + }, + "2": { + "265595": "cc7251", + "3f4447": "466698", + "de3431": "9ceec6", + "f8f8f8": "89d2b8", + "7b282e": "152a5c", + "6b1d1d": "356e8d", + "4ebdd9": "2f6e74", + "bfb169": "431022", + "bfbfbf": "8cc7d4", + "ffb2bf": "86d6b6", + "bf4c60": "32738b", + "fff0a6": "4d2637", + "3e7acc": "ecbb7a", + "18335c": "9f2727", + "f2798d": "5eb4a9", + "f01818": "ffe88d", + "7ddeff": "46988d", + "268794": "1c3e58", + "282c35": "4d2637" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/658.json b/public/images/pokemon/variant/658.json new file mode 100644 index 00000000000..25a6dad359d --- /dev/null +++ b/public/images/pokemon/variant/658.json @@ -0,0 +1,34 @@ +{ + "1": { + "ffb2bf": "b7e9ff", + "bf4c60": "4386df", + "66d9ff": "7ddcd6", + "3d61cc": "6b4592", + "fff0a6": "208698", + "c92e2e": "73c5ff", + "937f69": "406695", + "c2c1bc": "89b0d7", + "f2798d": "8dcfff", + "f7f7f7": "d8ffff", + "2e4999": "432b6c", + "bfb169": "165e78", + "803340": "0e3e81", + "1b2a59": "170738" + }, + "2": { + "ffb2bf": "86d6b6", + "bf4c60": "32738b", + "66d9ff": "48968c", + "3d61cc": "ecbb7a", + "fff0a6": "652240", + "c92e2e": "63bf9b", + "937f69": "466698", + "c2c1bc": "8cc7d4", + "f2798d": "5eb4a9", + "f7f7f7": "d7eff4", + "2e4999": "cc7251", + "bfb169": "431022", + "803340": "152a5c", + "1b2a59": "9f2727" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/6706.json b/public/images/pokemon/variant/6706.json new file mode 100644 index 00000000000..2b9ead28219 --- /dev/null +++ b/public/images/pokemon/variant/6706.json @@ -0,0 +1,40 @@ +{ + "1": { + "566678": "0e6296", + "e0e4f4": "513981", + "625287": "4e4094", + "536273": "1f1233", + "988b98": "b24c86", + "9170b9": "8b69c3", + "c4cce1": "3b235c", + "e6d3e9": "f1a4c5", + "bfacc1": "da75a5", + "515f70": "197497", + "c5cee3": "63cee1", + "8e96aa": "301848", + "8b93a6": "3aa8c4", + "80737f": "8a2166", + "4b454f": "6f1357", + "36404c": "0c5474", + "b791f2": "c7a1e5" + }, + "2": { + "566678": "8e480b", + "e0e4f4": "176463", + "625287": "274159", + "536273": "02262c", + "988b98": "2a6563", + "9170b9": "2f667c", + "c4cce1": "0d484a", + "e6d3e9": "9cead8", + "bfacc1": "5db6a9", + "515f70": "a34205", + "c5cee3": "f7af58", + "8e96aa": "073338", + "8b93a6": "d27e26", + "80737f": "2b736f", + "4b454f": "194f51", + "36404c": "842401", + "b791f2": "4a9699" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/676-dandy.json b/public/images/pokemon/variant/676-dandy.json new file mode 100644 index 00000000000..ac18c8446d9 --- /dev/null +++ b/public/images/pokemon/variant/676-dandy.json @@ -0,0 +1,30 @@ +{ + "1": { + "594d46": "788087", + "30552b": "423839", + "b8bcaf": "5e0f16", + "f1f2ee": "8a1d1d", + "376277": "4f8fe3", + "9c9f94": "42090e", + "4b4b46": "2b040f", + "508a3c": "aa9999", + "816e64": "a6afb3", + "6eb92b": "eddddd", + "453434": "313439" + }, + "2": { + "594d46": "9c7aca", + "30552b": "6a102e", + "b8bcaf": "ce9ede", + "f1f2ee": "e6c3f8", + "376277": "314173", + "fe3c31": "8362b4", + "9c9f94": "ad76bc", + "4b4b46": "6b3f77", + "508a3c": "ac254b", + "a83c31": "473085", + "816e64": "ae95dc", + "6eb92b": "e44a62", + "453434": "593173" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/676-debutante.json b/public/images/pokemon/variant/676-debutante.json new file mode 100644 index 00000000000..bf3d0dfe212 --- /dev/null +++ b/public/images/pokemon/variant/676-debutante.json @@ -0,0 +1,30 @@ +{ + "1": { + "594d46": "788087", + "376277": "4f8fe3", + "9c9f94": "42090e", + "f8f9f7": "8a1d1d", + "dfb76a": "aa9999", + "4b4b46": "2b040f", + "bcc0b3": "5e0f16", + "453434": "313439", + "816e64": "a6afb3", + "ac6d40": "423839", + "fbf588": "e3d6d6" + }, + "2": { + "594d46": "48a7d0", + "376277": "717171", + "fe3c31": "762ea8", + "9c9f94": "122a39", + "f8f9f7": "0e728e", + "dfb76a": "c6a65c", + "4b4b46": "021a2f", + "bcc0b3": "0b4b68", + "453434": "122a39", + "a83c31": "521073", + "816e64": "74ccec", + "ac6d40": "684d24", + "fbf588": "ffe998" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/676-diamond.json b/public/images/pokemon/variant/676-diamond.json new file mode 100644 index 00000000000..72e19d6a853 --- /dev/null +++ b/public/images/pokemon/variant/676-diamond.json @@ -0,0 +1,28 @@ +{ + "1": { + "594d46": "788087", + "aa3e2b": "423839", + "b8bcaf": "5e0f16", + "f1f2ee": "8a1d1d", + "376277": "4f8fe3", + "645e55": "2b040f", + "d95b37": "aa9999", + "e68a4d": "eddddd", + "453434": "313439", + "816e64": "a6afb3" + }, + "2": { + "594d46": "bd9462", + "aa3e2b": "642c0a", + "b8bcaf": "319c6a", + "f1f2ee": "6abd81", + "376277": "c56e34", + "fe3c31": "b37e47", + "645e55": "1b684b", + "d95b37": "935927", + "e68a4d": "b37e47", + "453434": "6c4b2d", + "a83c31": "642c0a", + "816e64": "eed59c" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/676-heart.json b/public/images/pokemon/variant/676-heart.json new file mode 100644 index 00000000000..895b5b49e99 --- /dev/null +++ b/public/images/pokemon/variant/676-heart.json @@ -0,0 +1,28 @@ +{ + "1": { + "594d46": "788087", + "f18598": "48474c", + "b8bcaf": "5e0f16", + "f1f2ee": "8a1d1d", + "e0546c": "2a2a2f", + "376277": "4f8fe3", + "645e55": "2b040f", + "453434": "313439", + "816e64": "a6afb3", + "a73f4f": "19181f" + }, + "2": { + "594d46": "aca49c", + "f18598": "5f5953", + "b8bcaf": "bfc7e8", + "f1f2ee": "e4eafc", + "e0546c": "4c413c", + "376277": "1b1c21", + "fe3c31": "9475de", + "645e55": "7a81b7", + "453434": "837373", + "a83c31": "7249b7", + "816e64": "dadace", + "a73f4f": "2c2320" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/676-kabuki.json b/public/images/pokemon/variant/676-kabuki.json new file mode 100644 index 00000000000..9d57fc830be --- /dev/null +++ b/public/images/pokemon/variant/676-kabuki.json @@ -0,0 +1,36 @@ +{ + "1": { + "816e64": "a6afb3", + "8f2121": "19181f", + "b01a1a": "2a2a2f", + "d02f2e": "262629", + "594d46": "788087", + "f44b3d": "48474c", + "376277": "4f8fe3", + "68675c": "2b040f", + "453434": "313439", + "8a7d79": "a6afb3", + "9c9f94": "42090e", + "534343": "313439", + "bcc0b3": "5e0f16", + "f1f2ee": "8a1d1d" + }, + "2": { + "816e64": "506e7b", + "8f2121": "1b1d39", + "b01a1a": "305d9e", + "d02f2e": "48578e", + "594d46": "3e5368", + "f66559": "9890ec", + "f44b3d": "4c89d9", + "376277": "436ca1", + "68675c": "192b42", + "453434": "17242f", + "8a7d79": "425a70", + "9c9f94": "468197", + "534343": "233342", + "bcc0b3": "549ab8", + "f1f2ee": "6bcfd9", + "b32524": "8067c6" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/676-la-reine.json b/public/images/pokemon/variant/676-la-reine.json new file mode 100644 index 00000000000..ae73038cfb2 --- /dev/null +++ b/public/images/pokemon/variant/676-la-reine.json @@ -0,0 +1,32 @@ +{ + "1": { + "816e64": "a6afb3", + "31a7bb": "aa9999", + "594d46": "788087", + "2f7387": "423839", + "453434": "313439", + "4b4b46": "2b040f", + "8a7d79": "a6afb3", + "9c9f94": "42090e", + "376277": "4f8fe3", + "56d1d8": "eddddd", + "bcc0b3": "5e0f16", + "f1f2ee": "8a1d1d" + }, + "2": { + "816e64": "973721", + "a83c31": "3041b7", + "31a7bb": "e3b876", + "594d46": "711e1e", + "2f7387": "8e673e", + "453434": "360608", + "4b4b46": "550b0c", + "8a7d79": "a11e24", + "9c9f94": "c63b31", + "376277": "221755", + "56d1d8": "ffec9b", + "bcc0b3": "d9533c", + "f1f2ee": "ee724b", + "fe3c31": "4b77e1" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/676-matron.json b/public/images/pokemon/variant/676-matron.json new file mode 100644 index 00000000000..8fdf48c14a8 --- /dev/null +++ b/public/images/pokemon/variant/676-matron.json @@ -0,0 +1,30 @@ +{ + "1": { + "594d46": "788087", + "b8bcaf": "5e0f16", + "873a5b": "19181f", + "376277": "4f8fe3", + "9c9f94": "42090e", + "f8f9f7": "8a1d1d", + "d07da9": "48474c", + "5f5951": "2b040f", + "816e64": "a6afb3", + "453434": "313439", + "b95b83": "2a2a2f" + }, + "2": { + "594d46": "d0b5b5", + "b8bcaf": "d95e7e", + "873a5b": "1b447b", + "376277": "2246aa", + "fe3c31": "64edf3", + "9c9f94": "bd4d6a", + "f8f9f7": "fa8c9f", + "d07da9": "64c8f3", + "5f5951": "8a2843", + "a83c31": "45a6d0", + "816e64": "e3d6d6", + "453434": "715456", + "b95b83": "528fcc" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/676-pharaoh.json b/public/images/pokemon/variant/676-pharaoh.json new file mode 100644 index 00000000000..cf6694aa348 --- /dev/null +++ b/public/images/pokemon/variant/676-pharaoh.json @@ -0,0 +1,30 @@ +{ + "1": { + "594d46": "788087", + "25559c": "2a2a2f", + "217fc4": "48474c", + "f1f2ee": "8a1d1d", + "376277": "4f8fe3", + "9c9f94": "42090e", + "bcc0b3": "5e0f16", + "68675c": "2b040f", + "453434": "313439", + "816e64": "a6afb3", + "243a6f": "19181f" + }, + "2": { + "594d46": "1c1c30", + "25559c": "d0902d", + "217fc4": "eed552", + "f1f2ee": "5e5e75", + "376277": "5e0808", + "fe3c31": "ec4d3e", + "9c9f94": "332b48", + "bcc0b3": "3b3955", + "68675c": "17122f", + "453434": "130b1c", + "a83c31": "a11717", + "816e64": "312c42", + "243a6f": "a15317" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/676-star.json b/public/images/pokemon/variant/676-star.json new file mode 100644 index 00000000000..e0b0e330676 --- /dev/null +++ b/public/images/pokemon/variant/676-star.json @@ -0,0 +1,28 @@ +{ + "1": { + "594d46": "788087", + "376277": "4f8fe3", + "645e55": "2b040f", + "b8bcaf": "5e0f16", + "3e8ebf": "2a2a2f", + "f1f2ee": "8a1d1d", + "453434": "313439", + "3a5078": "19181f", + "816e64": "a6afb3", + "7dc2e8": "48474c" + }, + "2": { + "594d46": "d7bc4d", + "376277": "647bb1", + "fe3c31": "b5e0f3", + "645e55": "848e75", + "a83c31": "6192aa", + "b8bcaf": "d6dec2", + "3e8ebf": "ac802f", + "f1f2ee": "fcfef5", + "453434": "836329", + "3a5078": "613d11", + "816e64": "f7e784", + "7dc2e8": "cdac4a" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/676.json b/public/images/pokemon/variant/676.json new file mode 100644 index 00000000000..8c9199960c9 --- /dev/null +++ b/public/images/pokemon/variant/676.json @@ -0,0 +1,21 @@ +{ + "1": { + "bcbca8": "5e0f16", + "606056": "2b040f", + "8e8e7b": "42090e", + "f2f2da": "8a1d1d", + "3f6273": "4f8fe3", + "494340": "788087", + "736b67": "a6afb3" + }, + "2": { + "bcbca8": "a4624a", + "cc2929": "3a240e", + "606056": "4a281b", + "8e8e7b": "805145", + "f2f2da": "c18960", + "3f6273": "4a281b", + "494340": "e6c594", + "736b67": "ffe6ac" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/682.json b/public/images/pokemon/variant/682.json new file mode 100644 index 00000000000..03337345194 --- /dev/null +++ b/public/images/pokemon/variant/682.json @@ -0,0 +1,26 @@ +{ + "1": { + "661f1f": "cd6132", + "bf5f9f": "7c48a1", + "6b3962": "30185d", + "cc7087": "318759", + "993d80": "4f297e", + "ff99b3": "48ab61", + "f24949": "ffa24f", + "7f4d59": "20644e" + }, + "2": { + "661f1f": "daa235", + "bf5f9f": "f0ebdd", + "6b3962": "b89477", + "cc7087": "c3561a", + "993d80": "d2bfa1", + "ff99b3": "da7e29", + "a6a6a6": "503851", + "f24949": "ffe664", + "e5e5e5": "6b4767", + "737373": "422f46", + "4d4d4d": "332539", + "7f4d59": "a23812" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/683.json b/public/images/pokemon/variant/683.json new file mode 100644 index 00000000000..42abc0856ad --- /dev/null +++ b/public/images/pokemon/variant/683.json @@ -0,0 +1,32 @@ +{ + "1": { + "661f1f": "b64d29", + "cc7087": "318759", + "ff99b3": "48ab61", + "fff0a6": "fec04b", + "f24949": "ffa24f", + "6b3962": "30185d", + "e5c37e": "d6872c", + "993d80": "4f297e", + "404040": "2c283b", + "b33636": "f4863f", + "7f4d59": "20644e", + "bf5f9f": "7c48a1" + }, + "2": { + "661f1f": "c78925", + "cc7087": "c3561a", + "ff99b3": "da7e29", + "fff0a6": "6d8719", + "a6a6a6": "503851", + "f24949": "ffe664", + "6b3962": "b89477", + "e5c37e": "376d11", + "993d80": "d2bfa1", + "e5e5e5": "6b4767", + "404040": "2a2234", + "b33636": "f0c150", + "7f4d59": "a23812", + "bf5f9f": "f0ebdd" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/684.json b/public/images/pokemon/variant/684.json new file mode 100644 index 00000000000..df4240c57d6 --- /dev/null +++ b/public/images/pokemon/variant/684.json @@ -0,0 +1,24 @@ +{ + "1": { + "805963": "2d0c42", + "661a2d": "205025", + "e53964": "689b52", + "ffccd9": "814db1", + "f8f8f8": "caff90", + "cc99a6": "613b84", + "fff2f2": "f39f62", + "7b5760": "b13924", + "ccadad": "df6b40" + }, + "2": { + "805963": "679baa", + "661a2d": "26061b", + "e53964": "612747", + "ffccd9": "cbf6da", + "f8f8f8": "e4819d", + "cc99a6": "93d6ce", + "fff2f2": "746998", + "7b5760": "3c2f51", + "ccadad": "4b4876" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/685.json b/public/images/pokemon/variant/685.json new file mode 100644 index 00000000000..99d52263178 --- /dev/null +++ b/public/images/pokemon/variant/685.json @@ -0,0 +1,28 @@ +{ + "1": { + "f8f8f8": "caff90", + "661a2d": "13391c", + "7b5760": "b13924", + "a62949": "26592b", + "ffccd9": "8961c6", + "ff8ca9": "8dbe6d", + "cc99a6": "613b84", + "e53964": "689b52", + "fff2f2": "f39f62", + "ccadad": "df6b40", + "805963": "2d0c42" + }, + "2": { + "f8f8f8": "e4819d", + "661a2d": "26061b", + "7b5760": "3c2f51", + "a62949": "441838", + "ffccd9": "cbf6da", + "ff8ca9": "8c4264", + "cc99a6": "93d6ce", + "e53964": "612747", + "fff2f2": "746998", + "ccadad": "4b4876", + "805963": "679baa" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/688.json b/public/images/pokemon/variant/688.json new file mode 100644 index 00000000000..e5749f6bb3f --- /dev/null +++ b/public/images/pokemon/variant/688.json @@ -0,0 +1,33 @@ +{ + "1": { + "5890b0": "a9582e", + "385860": "70240f", + "372e27": "220a56", + "6b503b": "373295", + "d0d0d0": "d3bc8c", + "c0e0e8": "e8d37b", + "8a6d45": "4557b5", + "101010": "37160a", + "b7653f": "459aac", + "fcffff": "e8e5c6", + "808080": "7c582e", + "88c0c8": "cd8a50", + "ef8955": "70cccf" + }, + "2": { + "5890b0": "4b0038", + "385860": "2c052a", + "372e27": "1e1324", + "6b503b": "ba9fba", + "d0d0d0": "7eac4e", + "c0e0e8": "a74083", + "8a6d45": "f6eefc", + "101010": "0a391b", + "b7653f": "332149", + "fcffff": "caea77", + "f8f8f8": "ffffff", + "808080": "2a5524", + "88c0c8": "731f5c", + "ef8955": "4a376e" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/689.json b/public/images/pokemon/variant/689.json new file mode 100644 index 00000000000..cd6db09c8d2 --- /dev/null +++ b/public/images/pokemon/variant/689.json @@ -0,0 +1,31 @@ +{ + "1": { + "bfeaff": "e8d37b", + "f2f2f2": "e8e5c6", + "5b8da6": "8d5030", + "595959": "7c582e", + "403410": "220a56", + "3f6273": "672e1e", + "b3b3b3": "d3bc8c", + "cc7f70": "459aac", + "85b4cc": "cd8a50", + "ff9f8c": "70cccf", + "66541f": "373295", + "997e2e": "4557b5" + }, + "2": { + "bfeaff": "a74083", + "f2f2f2": "caea77", + "5b8da6": "4b0038", + "595959": "2a5524", + "403410": "3f2a4b", + "3f6273": "3e073b", + "b3b3b3": "7eac4e", + "cc7f70": "332149", + "85b4cc": "731f5c", + "f8f8f8": "dbaf67", + "ff9f8c": "4a376e", + "66541f": "ccb6cc", + "997e2e": "f6eefc" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/696.json b/public/images/pokemon/variant/696.json index c01732c8454..19a14cea4ea 100644 --- a/public/images/pokemon/variant/696.json +++ b/public/images/pokemon/variant/696.json @@ -1,14 +1,53 @@ { "1": { - "734517": "5e0b0b", - "ffa64c": "a50d0d", - "4a322c": "023425", - "404040": "4c3216", - "101010": "101010", - "65483a": "0b4c29", - "966858": "1b6430", - "f8f8f8": "dfdea7", - "8c8c8c": "ad8c63", - "bfbfbf": "cbbe8c" + "734517":"5e0b0b", + "ffa64c":"a50d0d", + "4a322c":"023425", + "404040":"4c3216", + "101010":"101010", + "65483a":"0b4c29", + "966858":"1b6430", + "f8f8f8":"dfdea7", + "8c8c8c":"ad8c63", + "bfbfbf":"cbbe8c", + "121212":"121212", + "bdbdbd":"cfc28f" + }, + "2": { + "734517":"395cb7", + "ffa64c":"d2e9ff", + "4a322c":"3e1f18", + "404040":"250860", + "101010":"101010", + "65483a":"644943", + "966858":"83726e", + "f8f8f8":"6e46a7", + "8c8c8c":"411684", + "bfbfbf":"593097", + "121212":"decaff", + "bdbdbd":"79c8d3" } -} \ No newline at end of file +} + + + + + + + + + + + + + + + + + + + + + + + diff --git a/public/images/pokemon/variant/697.json b/public/images/pokemon/variant/697.json index b0accaa45c0..5932ca714e4 100644 --- a/public/images/pokemon/variant/697.json +++ b/public/images/pokemon/variant/697.json @@ -1,16 +1,39 @@ { "1": { - "54434c": "4c3216", - "080808": "080808", - "fafafa": "dfdea7", - "964b1c": "5e0b0b", - "f19d5a": "b52424", - "bf7545": "971c1c", - "cccccc": "cbbe8c", - "50131e": "0b241e", - "963e4e": "285234", - "722533": "153626", - "32252c": "3e1e17", - "9f9d98": "ad8c63" + "54434c":"4c3216", + "080808":"080808", + "fafafa":"dfdea7", + "964b1c":"5e0b0b", + "f19d5a":"b52424", + "bf7545":"971c1c", + "cccccc":"cbbe8c", + "50131e":"0b241e", + "963e4e":"285234", + "722533":"153626", + "32252c":"401f18", + "c9c9c9":"cfc28f", + "f7f7f7":"e0dfa8", + "9f9d98":"ad8c63", + "2f2329":"3e1e17", + "584650":"4a3115" + }, + "2": { + "54434c":"170c25", + "080808":"080808", + "fafafa":"4b2e64", + "964b1c":"9d5390", + "f19d5a":"f3daf5", + "bf7545":"cd7aca", + "cccccc":"33214f", + "50131e":"52352f", + "963e4e":"ab9b97", + "722533":"83726e", + "32252c":"0d0124", + "c9c9c9":"ce7ecc", + "f7f7f7":"f4dbf6", + "9f9d98":"26173b", + "2f2329":"c979c7", + "584650":"eed5f0" } -} \ No newline at end of file +} + diff --git a/public/images/pokemon/variant/773-bug.json b/public/images/pokemon/variant/773-bug.json new file mode 100644 index 00000000000..963111d6c63 --- /dev/null +++ b/public/images/pokemon/variant/773-bug.json @@ -0,0 +1,44 @@ +{ + "1": { + "297321": "267763", + "73c957": "73c956", + "e3e6ec": "bdd1e5", + "483c39": "3a2d53", + "41ac36": "44b3aa", + "b7e586": "f4ff9c", + "0073bf": "7a4949", + "565969": "30365c", + "73c956": "99d569", + "251845": "753c32", + "bcbbc5": "788fb5", + "9618e0": "dc9c4d", + "125d4b": "ce7f3f", + "e64f5e": "f1944a", + "1e9378": "f8ce64", + "5399df": "b59489", + "3f3b50": "1e172a", + "aba7bc": "493d55", + "79615e": "504a75" + }, + "2": { + "297321": "3d5542", + "73c957": "73c956", + "e3e6ec": "444455", + "483c39": "778894", + "41ac36": "92d374", + "b7e586": "ababab", + "0073bf": "6a6c75", + "565969": "0f0f1b", + "1d1845": "41434e", + "73c956": "e7eef2", + "251845": "3d5542", + "bcbbc5": "242433", + "9618e0": "ade265", + "125d4b": "317e27", + "e64f5e": "98ce58", + "1e9378": "73c956", + "5399df": "92949e", + "aba7bc": "dbd8e8", + "79615e": "d6d4d4" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-bug_2.json b/public/images/pokemon/variant/773-bug_2.json deleted file mode 100644 index 9a6ea7d6a8a..00000000000 --- a/public/images/pokemon/variant/773-bug_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-bug_2.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:bf64cbae011fb438589101089097a872:0e78e79027eef1aa92d0909fe34152d9:1786a671c3b9676c87853a0a70567554$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-bug_2.png b/public/images/pokemon/variant/773-bug_2.png deleted file mode 100644 index 5e83ece4e21..00000000000 Binary files a/public/images/pokemon/variant/773-bug_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-bug_3.json b/public/images/pokemon/variant/773-bug_3.json deleted file mode 100644 index 21fc5c511fe..00000000000 --- a/public/images/pokemon/variant/773-bug_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-bug_3.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:bf64cbae011fb438589101089097a872:0e78e79027eef1aa92d0909fe34152d9:1786a671c3b9676c87853a0a70567554$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-bug_3.png b/public/images/pokemon/variant/773-bug_3.png deleted file mode 100644 index a76f21af38b..00000000000 Binary files a/public/images/pokemon/variant/773-bug_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-dark.json b/public/images/pokemon/variant/773-dark.json new file mode 100644 index 00000000000..af86da38211 --- /dev/null +++ b/public/images/pokemon/variant/773-dark.json @@ -0,0 +1,45 @@ +{ + "1": { + "574646": "735c5c", + "79615e": "504a75", + "aba7bc": "493d55", + "3f3b50": "1e172a", + "332327": "512351", + "bcbbc5": "788fb5", + "483c39": "3a2d53", + "e3e6ec": "bdd1e5", + "e64f5e": "f1944a", + "565969": "30365c", + "5399df": "b59489", + "574647": "655454", + "9618e0": "dc9c4d", + "1d1845": "2e191f", + "1e9378": "f8ce64", + "125d4b": "ce7f3f", + "8a7d7a": "dcc0b2", + "251845": "753c32", + "0073bf": "7a4949", + "21151a": "250d25" + }, + "2": { + "574646": "f0f7fb", + "79615e": "d6d4d4", + "aba7bc": "dbd8e8", + "332327": "f2cc45", + "bcbbc5": "242433", + "483c39": "778894", + "e3e6ec": "444455", + "e64f5e": "98ce58", + "565969": "0f0f1b", + "5399df": "92949e", + "574647": "574646", + "9618e0": "ade265", + "1d1845": "41434e", + "1e9378": "574646", + "125d4b": "3b282a", + "8a7d7a": "9360c8", + "251845": "425735", + "0073bf": "6a6c75", + "21151a": "494057" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-dark_2.json b/public/images/pokemon/variant/773-dark_2.json deleted file mode 100644 index 4eff915b95f..00000000000 --- a/public/images/pokemon/variant/773-dark_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-dark_2.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:e5010b29372802d71f5806de2c47e39a:7b0e34a025b67e5e90f322b7b3f079af:267125b3b5f5d18142ae5fffbef27592$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-dark_2.png b/public/images/pokemon/variant/773-dark_2.png deleted file mode 100644 index f4a24be8ac9..00000000000 Binary files a/public/images/pokemon/variant/773-dark_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-dark_3.json b/public/images/pokemon/variant/773-dark_3.json deleted file mode 100644 index 822d9e26bbc..00000000000 --- a/public/images/pokemon/variant/773-dark_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-dark_3.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:e5010b29372802d71f5806de2c47e39a:7b0e34a025b67e5e90f322b7b3f079af:267125b3b5f5d18142ae5fffbef27592$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-dark_3.png b/public/images/pokemon/variant/773-dark_3.png deleted file mode 100644 index 2a39118439a..00000000000 Binary files a/public/images/pokemon/variant/773-dark_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-dragon.json b/public/images/pokemon/variant/773-dragon.json new file mode 100644 index 00000000000..44fd391d23c --- /dev/null +++ b/public/images/pokemon/variant/773-dragon.json @@ -0,0 +1,45 @@ +{ + "1": { + "5399df": "b59489", + "e3e6ec": "bdd1e5", + "1975a3": "756cc8", + "483c39": "3a2d53", + "3f3b50": "1e172a", + "0073bf": "7a4949", + "565969": "30365c", + "6ee0e8": "c1ffd7", + "79615e": "504a75", + "251845": "753c32", + "bcbbc5": "788fb5", + "9618e0": "dc9c4d", + "125d4b": "ce7f3f", + "e64f5e": "f1944a", + "1e9378": "f8ce64", + "1eadd1": "2fd0da", + "1d1845": "2e191f", + "aba7bc": "493d55", + "14487e": "3f4085", + "1eadd2": "37b5be" + }, + "2": { + "5399df": "92949e", + "e3e6ec": "444455", + "1975a3": "61c5ff", + "483c39": "778894", + "0073bf": "6a6c75", + "565969": "0f0f1b", + "6ee0e8": "ffffff", + "79615e": "d6d4d4", + "251845": "425735", + "bcbbc5": "242433", + "9618e0": "ade265", + "125d4b": "0f5493", + "e64f5e": "98ce58", + "1e9378": "1eadd1", + "1eadd1": "ffa1ec", + "1d1845": "41434e", + "aba7bc": "dbd8e8", + "14487e": "3e354e", + "1eadd2": "1eadd1" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-dragon_2.json b/public/images/pokemon/variant/773-dragon_2.json deleted file mode 100644 index 0b8c32c52d1..00000000000 --- a/public/images/pokemon/variant/773-dragon_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-dragon_2.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:f6d84e4243fdee8eddd6e0597d855d94:537fa40f266dc62e130af348ea1771f8:59453f2ad0e681735b3b15ab728caa7c$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-dragon_2.png b/public/images/pokemon/variant/773-dragon_2.png deleted file mode 100644 index 1b4e089e74e..00000000000 Binary files a/public/images/pokemon/variant/773-dragon_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-dragon_3.json b/public/images/pokemon/variant/773-dragon_3.json deleted file mode 100644 index 1b3ae8c2f6c..00000000000 --- a/public/images/pokemon/variant/773-dragon_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-dragon_3.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:f6d84e4243fdee8eddd6e0597d855d94:537fa40f266dc62e130af348ea1771f8:59453f2ad0e681735b3b15ab728caa7c$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-dragon_3.png b/public/images/pokemon/variant/773-dragon_3.png deleted file mode 100644 index 2ef7d3888e6..00000000000 Binary files a/public/images/pokemon/variant/773-dragon_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-electric.json b/public/images/pokemon/variant/773-electric.json new file mode 100644 index 00000000000..ff29faa6fb6 --- /dev/null +++ b/public/images/pokemon/variant/773-electric.json @@ -0,0 +1,45 @@ +{ + "1": { + "5399df": "b59489", + "e3e6ec": "bdd1e5", + "483c39": "3a2d53", + "3f3b50": "1e172a", + "0073bf": "7a4949", + "565969": "30365c", + "ca972c": "ff935c", + "79615e": "504a75", + "251845": "753c32", + "bcbbc5": "788fb5", + "f5eb18": "faf256", + "9618e0": "dc9c4d", + "125d4b": "ce7f3f", + "e64f5e": "f1944a", + "1e9378": "f8ce64", + "f5eb19": "fff97e", + "f8ffc5": "fdfee0", + "8e6113": "a55a50", + "aba7bc": "493d55", + "1d1845": "2e191f" + }, + "2": { + "5399df": "92949e", + "e3e6ec": "444455", + "483c39": "778894", + "0073bf": "6a6c75", + "565969": "0f0f1b", + "ca972c": "ffd900", + "79615e": "d6d4d4", + "251845": "425735", + "bcbbc5": "242433", + "f5eb18": "864593", + "9618e0": "ade265", + "125d4b": "b3620e", + "e64f5e": "98ce58", + "1e9378": "f5eb18", + "f5eb19": "f5eb18", + "f8ffc5": "ffd900", + "8e6113": "422a45", + "aba7bc": "dbd8e8", + "1d1845": "41434e" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-electric_2.json b/public/images/pokemon/variant/773-electric_2.json deleted file mode 100644 index b85eeeb32bb..00000000000 --- a/public/images/pokemon/variant/773-electric_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-electric_2.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:24e2686eb3e38ace457e83aff292317b:35c1f3320090d294afe853fc19c0838a:e9f7f627b4aa057d8a352e938221d903$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-electric_2.png b/public/images/pokemon/variant/773-electric_2.png deleted file mode 100644 index 26539899d51..00000000000 Binary files a/public/images/pokemon/variant/773-electric_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-electric_3.json b/public/images/pokemon/variant/773-electric_3.json deleted file mode 100644 index 4ed33ea0e2d..00000000000 --- a/public/images/pokemon/variant/773-electric_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-electric_3.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:24e2686eb3e38ace457e83aff292317b:35c1f3320090d294afe853fc19c0838a:e9f7f627b4aa057d8a352e938221d903$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-electric_3.png b/public/images/pokemon/variant/773-electric_3.png deleted file mode 100644 index 2e9f7285d7c..00000000000 Binary files a/public/images/pokemon/variant/773-electric_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-fairy.json b/public/images/pokemon/variant/773-fairy.json new file mode 100644 index 00000000000..b9270f3a06a --- /dev/null +++ b/public/images/pokemon/variant/773-fairy.json @@ -0,0 +1,45 @@ +{ + "1": { + "5399df": "b59489", + "e3e6ec": "bdd1e5", + "483c39": "3a2d53", + "3f3b50": "1e172a", + "0073bf": "7a4949", + "565969": "30365c", + "ffe8ef": "fce9c7", + "f9bfe1": "e5a5c9", + "79615e": "504a75", + "251845": "753c32", + "bcbbc5": "788fb5", + "9618e0": "dc9c4d", + "125d4b": "ce7f3f", + "e64f5e": "f1944a", + "1e9378": "f8ce64", + "f9bfe0": "ecaecb", + "1d1845": "2e191f", + "a15296": "833671", + "aba7bc": "493d55", + "e183c7": "d3559a" + }, + "2": { + "5399df": "92949e", + "e3e6ec": "444455", + "483c39": "778894", + "0073bf": "6a6c75", + "565969": "0f0f1b", + "ffe8ef": "acb4bd", + "f9bfe1": "f9bfe0", + "79615e": "d6d4d4", + "251845": "425735", + "bcbbc5": "242433", + "9618e0": "ade265", + "125d4b": "ad628c", + "e64f5e": "98ce58", + "1e9378": "f9bfe0", + "f9bfe0": "f0f7fb", + "1d1845": "41434e", + "a15296": "3f3b50", + "aba7bc": "dbd8e8", + "e183c7": "fca4ea" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-fairy_2.json b/public/images/pokemon/variant/773-fairy_2.json deleted file mode 100644 index fc6c2fb258d..00000000000 --- a/public/images/pokemon/variant/773-fairy_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-fairy_2.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:9d1073d5e324f3164a68296e1c76fe9a:5f054b1628c09b44b4d60480d07c0a63:50e5ca45ea677d44a2fea72d4ec14fc2$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-fairy_2.png b/public/images/pokemon/variant/773-fairy_2.png deleted file mode 100644 index 15a499b07d8..00000000000 Binary files a/public/images/pokemon/variant/773-fairy_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-fairy_3.json b/public/images/pokemon/variant/773-fairy_3.json deleted file mode 100644 index 528be34aca2..00000000000 --- a/public/images/pokemon/variant/773-fairy_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-fairy_3.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:9d1073d5e324f3164a68296e1c76fe9a:5f054b1628c09b44b4d60480d07c0a63:50e5ca45ea677d44a2fea72d4ec14fc2$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-fairy_3.png b/public/images/pokemon/variant/773-fairy_3.png deleted file mode 100644 index 422fdb6bd9f..00000000000 Binary files a/public/images/pokemon/variant/773-fairy_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-fighting.json b/public/images/pokemon/variant/773-fighting.json new file mode 100644 index 00000000000..0b71c4d58b7 --- /dev/null +++ b/public/images/pokemon/variant/773-fighting.json @@ -0,0 +1,45 @@ +{ + "1": { + "3f3b50": "1e172a", + "483c39": "3a2d53", + "0073bf": "7a4949", + "1e9378": "f8ce64", + "565969": "30365c", + "79615e": "504a75", + "125d4b": "ce7f3f", + "bcbbc5": "788fb5", + "9618e0": "dc9c4d", + "f18a36": "f1964c", + "251845": "753c32", + "aba7bc": "493d55", + "f18a37": "e37637", + "5399df": "b59489", + "d55223": "da4b2f", + "a34828": "a33b26", + "e64f5e": "f1944a", + "f8b076": "ffcd8a", + "e3e6ec": "bdd1e5", + "1d1845": "2e191f" + }, + "2": { + "483c39": "778894", + "0073bf": "6a6c75", + "1e9378": "f18a36", + "565969": "0f0f1b", + "79615e": "d6d4d4", + "125d4b": "b8411d", + "bcbbc5": "242433", + "9618e0": "ade265", + "f18a36": "e7eef2", + "251845": "425735", + "aba7bc": "dbd8e8", + "f18a37": "f18a36", + "5399df": "92949e", + "d55223": "eccd00", + "a34828": "2f4453", + "e64f5e": "98ce58", + "f8b076": "65abdb", + "e3e6ec": "444455", + "1d1845": "41434e" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-fighting_2.json b/public/images/pokemon/variant/773-fighting_2.json deleted file mode 100644 index be5a1a46e92..00000000000 --- a/public/images/pokemon/variant/773-fighting_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-fighting_2.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:42c101a54fd0dc2fe7a4cf33ea5d29ad:c4c4f509074a0f015d20c2018d42c9cb:70f70b07c9d5b3013cbd3b3f25c7f7fa$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-fighting_2.png b/public/images/pokemon/variant/773-fighting_2.png deleted file mode 100644 index f4d3af408e6..00000000000 Binary files a/public/images/pokemon/variant/773-fighting_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-fighting_3.json b/public/images/pokemon/variant/773-fighting_3.json deleted file mode 100644 index 7d51c9ec493..00000000000 --- a/public/images/pokemon/variant/773-fighting_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-fighting_3.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:42c101a54fd0dc2fe7a4cf33ea5d29ad:c4c4f509074a0f015d20c2018d42c9cb:70f70b07c9d5b3013cbd3b3f25c7f7fa$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-fighting_3.png b/public/images/pokemon/variant/773-fighting_3.png deleted file mode 100644 index f2430eddfb9..00000000000 Binary files a/public/images/pokemon/variant/773-fighting_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-fire.json b/public/images/pokemon/variant/773-fire.json new file mode 100644 index 00000000000..42fa1dbc3b3 --- /dev/null +++ b/public/images/pokemon/variant/773-fire.json @@ -0,0 +1,45 @@ +{ + "1": { + "5399df": "b59489", + "e3e6ec": "bdd1e5", + "b50d36": "ae1361", + "3f3b50": "1e172a", + "0073bf": "7a4949", + "565969": "30365c", + "1e9378": "f8ce64", + "79615e": "504a75", + "251845": "753c32", + "bcbbc5": "788fb5", + "125d4b": "ce7f3f", + "9618e0": "dc9c4d", + "f32141": "ee3652", + "e64f5e": "f1944a", + "fa7351": "fc9e5d", + "f32142": "ba2e2c", + "483c39": "3a2d53", + "81132d": "6e1441", + "aba7bc": "493d55", + "1d1845": "2e191f" + }, + "2": { + "5399df": "92949e", + "e3e6ec": "444455", + "b50d36": "fa9955", + "0073bf": "6a6c75", + "565969": "0f0f1b", + "1e9378": "d92b00", + "79615e": "d6d4d4", + "251845": "425735", + "bcbbc5": "242433", + "125d4b": "7a151a", + "9618e0": "ade265", + "f32141": "e7eef2", + "e64f5e": "98ce58", + "fa7351": "d063a2", + "f32142": "d92b00", + "483c39": "778894", + "81132d": "7e3354", + "aba7bc": "dbd8e8", + "1d1845": "41434e" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-fire_2.json b/public/images/pokemon/variant/773-fire_2.json deleted file mode 100644 index a08e08ff1ea..00000000000 --- a/public/images/pokemon/variant/773-fire_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-fire_2.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:b6cfaa82accfdac376c8980846dc1b5c:b4a618a0c497424ae576ad7fa24cc820:690c285b19cb1e8f7b7aa9dfafbe36b2$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-fire_2.png b/public/images/pokemon/variant/773-fire_2.png deleted file mode 100644 index d81ad03151d..00000000000 Binary files a/public/images/pokemon/variant/773-fire_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-fire_3.json b/public/images/pokemon/variant/773-fire_3.json deleted file mode 100644 index 03469bebaa6..00000000000 --- a/public/images/pokemon/variant/773-fire_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-fire_3.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:b6cfaa82accfdac376c8980846dc1b5c:b4a618a0c497424ae576ad7fa24cc820:690c285b19cb1e8f7b7aa9dfafbe36b2$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-fire_3.png b/public/images/pokemon/variant/773-fire_3.png deleted file mode 100644 index ba54e3ab8cf..00000000000 Binary files a/public/images/pokemon/variant/773-fire_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-flying.json b/public/images/pokemon/variant/773-flying.json new file mode 100644 index 00000000000..ed70b13853a --- /dev/null +++ b/public/images/pokemon/variant/773-flying.json @@ -0,0 +1,45 @@ +{ + "1": { + "5399df": "b59489", + "e3e6ec": "bdd1e5", + "483c39": "3a2d53", + "3f3b50": "1e172a", + "0073bf": "7a4949", + "0557bd": "1e509e", + "79615e": "504a75", + "5082c1": "8bc4e1", + "251845": "753c32", + "bcbbc5": "788fb5", + "072c85": "402795", + "125d4b": "ce7f3f", + "9618e0": "dc9c4d", + "e64f5e": "f1944a", + "1e9378": "f8ce64", + "1d1845": "2e191f", + "565969": "30365c", + "081b4a": "17195a", + "aba7bc": "493d55", + "0557bc": "296cbe" + }, + "2": { + "5399df": "92949e", + "e3e6ec": "444455", + "483c39": "778894", + "0073bf": "6a6c75", + "0557bd": "0557bc", + "79615e": "d6d4d4", + "5082c1": "acb4bd", + "251845": "425735", + "bcbbc5": "242433", + "072c85": "97c7fe", + "125d4b": "0a298c", + "9618e0": "ade265", + "e64f5e": "98ce58", + "1e9378": "0557bc", + "1d1845": "41434e", + "565969": "0f0f1b", + "081b4a": "2f4453", + "aba7bc": "dbd8e8", + "0557bc": "e7eef2" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-flying_2.json b/public/images/pokemon/variant/773-flying_2.json deleted file mode 100644 index a36d78d96c5..00000000000 --- a/public/images/pokemon/variant/773-flying_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-flying_2.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:4a783ce82c207cfac0a91d8a7585bd2a:a9680e08457413d4bd4fa0c590feb6fb:fd9cc965ca8a0f017385425d924045d6$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-flying_2.png b/public/images/pokemon/variant/773-flying_2.png deleted file mode 100644 index 3d752716a98..00000000000 Binary files a/public/images/pokemon/variant/773-flying_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-flying_3.json b/public/images/pokemon/variant/773-flying_3.json deleted file mode 100644 index a5429c18d3e..00000000000 --- a/public/images/pokemon/variant/773-flying_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-flying_3.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:4a783ce82c207cfac0a91d8a7585bd2a:a9680e08457413d4bd4fa0c590feb6fb:fd9cc965ca8a0f017385425d924045d6$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-flying_3.png b/public/images/pokemon/variant/773-flying_3.png deleted file mode 100644 index 2c2ae37da99..00000000000 Binary files a/public/images/pokemon/variant/773-flying_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-ghost.json b/public/images/pokemon/variant/773-ghost.json new file mode 100644 index 00000000000..862732f94ca --- /dev/null +++ b/public/images/pokemon/variant/773-ghost.json @@ -0,0 +1,45 @@ +{ + "1": { + "a75bc0": "7b5498", + "5399df": "b59489", + "d68ce5": "ecc9f3", + "483c39": "3a2d53", + "3f3b50": "1e172a", + "0073bf": "7a4949", + "565969": "30365c", + "a75bbf": "b36bca", + "251845": "753c32", + "bcbbc5": "788fb5", + "503775": "392e4c", + "9618e0": "dc9c4d", + "125d4b": "ce7f3f", + "e64f5e": "f1944a", + "1e9378": "f8ce64", + "79615e": "504a75", + "e3e6ec": "bdd1e5", + "753d9a": "504681", + "aba7bc": "493d55", + "1d1845": "2e191f" + }, + "2": { + "a75bc0": "a75bbf", + "5399df": "92949e", + "d68ce5": "5876bd", + "483c39": "778894", + "0073bf": "6a6c75", + "565969": "0f0f1b", + "a75bbf": "c8b5e2", + "251845": "425735", + "bcbbc5": "242433", + "503775": "383c6a", + "9618e0": "ade265", + "125d4b": "653785", + "e64f5e": "98ce58", + "1e9378": "a75bbf", + "79615e": "d6d4d4", + "e3e6ec": "444455", + "753d9a": "cd6fa4", + "aba7bc": "dbd8e8", + "1d1845": "41434e" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-ghost_2.json b/public/images/pokemon/variant/773-ghost_2.json deleted file mode 100644 index f9fd197ee53..00000000000 --- a/public/images/pokemon/variant/773-ghost_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-ghost_2.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:0187e6a29f9e47b36ff518910cfa5a3b:5217988d03f6a259878a7f6330a8c8f3:dff8d338685b93339ecf30f1d807fbe6$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-ghost_2.png b/public/images/pokemon/variant/773-ghost_2.png deleted file mode 100644 index 5bc5c5eb238..00000000000 Binary files a/public/images/pokemon/variant/773-ghost_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-ghost_3.json b/public/images/pokemon/variant/773-ghost_3.json deleted file mode 100644 index a72a6cc6ed3..00000000000 --- a/public/images/pokemon/variant/773-ghost_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-ghost_3.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:0187e6a29f9e47b36ff518910cfa5a3b:5217988d03f6a259878a7f6330a8c8f3:dff8d338685b93339ecf30f1d807fbe6$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-ghost_3.png b/public/images/pokemon/variant/773-ghost_3.png deleted file mode 100644 index 2bcb3253254..00000000000 Binary files a/public/images/pokemon/variant/773-ghost_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-grass.json b/public/images/pokemon/variant/773-grass.json new file mode 100644 index 00000000000..80f1f799e45 --- /dev/null +++ b/public/images/pokemon/variant/773-grass.json @@ -0,0 +1,45 @@ +{ + "1": { + "50d354": "8bf360", + "565969": "30365c", + "3f3b50": "1e172a", + "aba7bc": "493d55", + "1e9378": "f8ce64", + "01a326": "1b9143", + "e64f5e": "f1944a", + "0073bf": "7a4949", + "e3e6ec": "bdd1e5", + "125d4b": "ce7f3f", + "064a28": "043541", + "79615e": "504a75", + "bcbbc5": "788fb5", + "251845": "753c32", + "01a325": "18b12f", + "03753c": "086c6b", + "483c39": "3a2d53", + "9618e0": "dc9c4d", + "5399df": "b59489", + "1d1845": "2e191f" + }, + "2": { + "50d354": "2b6e2d", + "565969": "0f0f1b", + "aba7bc": "dbd8e8", + "1e9378": "01a325", + "01a326": "01a325", + "e64f5e": "98ce58", + "0073bf": "6a6c75", + "e3e6ec": "444455", + "125d4b": "0c592f", + "064a28": "283331", + "79615e": "d6d4d4", + "bcbbc5": "242433", + "251845": "425735", + "01a325": "e7eef2", + "03753c": "c77fe2", + "483c39": "778894", + "9618e0": "ade265", + "5399df": "92949e", + "1d1845": "41434e" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-grass_2.json b/public/images/pokemon/variant/773-grass_2.json deleted file mode 100644 index 1610b458f1a..00000000000 --- a/public/images/pokemon/variant/773-grass_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-grass_2.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:1b83cb2851c54b5912a9540b69583425:94d90bc5c7284c47f0de55761bfbf43e:c892d42603d88b410862efcb4f750000$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-grass_2.png b/public/images/pokemon/variant/773-grass_2.png deleted file mode 100644 index 3d1e5567f3b..00000000000 Binary files a/public/images/pokemon/variant/773-grass_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-grass_3.json b/public/images/pokemon/variant/773-grass_3.json deleted file mode 100644 index ede74cb8bab..00000000000 --- a/public/images/pokemon/variant/773-grass_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-grass_3.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:1b83cb2851c54b5912a9540b69583425:94d90bc5c7284c47f0de55761bfbf43e:c892d42603d88b410862efcb4f750000$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-grass_3.png b/public/images/pokemon/variant/773-grass_3.png deleted file mode 100644 index d77fc49d802..00000000000 Binary files a/public/images/pokemon/variant/773-grass_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-ground.json b/public/images/pokemon/variant/773-ground.json new file mode 100644 index 00000000000..7293fabfaf0 --- /dev/null +++ b/public/images/pokemon/variant/773-ground.json @@ -0,0 +1,45 @@ +{ + "1": { + "125d4b": "ce7f3f", + "aba7bc": "493d55", + "565969": "30365c", + "3f3b50": "1e172a", + "bcbbc5": "788fb5", + "5399df": "b59489", + "1e9378": "f8ce64", + "e59b4a": "f3daa4", + "cf5c08": "b55711", + "9618e0": "dc9c4d", + "e3e6ec": "bdd1e5", + "251845": "753c32", + "cf5c07": "d36b1f", + "1d1845": "2e191f", + "0073bf": "7a4949", + "a3410c": "95174b", + "613016": "61191e", + "e64f5e": "f1944a", + "483c39": "3a2d53", + "79615e": "504a75" + }, + "2": { + "125d4b": "a32004", + "aba7bc": "dbd8e8", + "565969": "0f0f1b", + "bcbbc5": "242433", + "5399df": "92949e", + "1e9378": "cf5c07", + "e59b4a": "44b3e3", + "cf5c08": "cf5c07", + "9618e0": "ade265", + "e3e6ec": "444455", + "251845": "425735", + "cf5c07": "ffd963", + "1d1845": "41434e", + "0073bf": "6a6c75", + "a3410c": "e1497e", + "613016": "653653", + "e64f5e": "98ce58", + "483c39": "778894", + "79615e": "d6d4d4" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-ground_2.json b/public/images/pokemon/variant/773-ground_2.json deleted file mode 100644 index 93ea259ec3a..00000000000 --- a/public/images/pokemon/variant/773-ground_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-ground_2.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:c65c6c5c6cc3e8a7878ca5817e283881:51d311b8dfbb1977a1c68a05261c1907:a8b1ae37d6ef4c526891c3cd392866cd$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-ground_2.png b/public/images/pokemon/variant/773-ground_2.png deleted file mode 100644 index fab45e3f898..00000000000 Binary files a/public/images/pokemon/variant/773-ground_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-ground_3.json b/public/images/pokemon/variant/773-ground_3.json deleted file mode 100644 index 165ebe06884..00000000000 --- a/public/images/pokemon/variant/773-ground_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-ground_3.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:c65c6c5c6cc3e8a7878ca5817e283881:51d311b8dfbb1977a1c68a05261c1907:a8b1ae37d6ef4c526891c3cd392866cd$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-ground_3.png b/public/images/pokemon/variant/773-ground_3.png deleted file mode 100644 index 9d41832c27a..00000000000 Binary files a/public/images/pokemon/variant/773-ground_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-ice.json b/public/images/pokemon/variant/773-ice.json new file mode 100644 index 00000000000..efb6223b71a --- /dev/null +++ b/public/images/pokemon/variant/773-ice.json @@ -0,0 +1,45 @@ +{ + "1": { + "5399df": "b59489", + "e3e6ec": "bdd1e5", + "483c39": "3a2d53", + "416b7e": "575693", + "0073bf": "7a4949", + "565969": "30365c", + "251845": "753c32", + "79615e": "504a75", + "aef9f9": "b8f8f8", + "bcbbc5": "788fb5", + "7bb3cc": "a197f3", + "125d4b": "ce7f3f", + "9618e0": "dc9c4d", + "e64f5e": "f1944a", + "1e9378": "f8ce64", + "1d1845": "2e191f", + "ecfffc": "eafffb", + "3f3b50": "1e172a", + "aba7bc": "493d55", + "aef9fa": "aef9f9" + }, + "2": { + "5399df": "92949e", + "e3e6ec": "444455", + "483c39": "778894", + "416b7e": "414f65", + "0073bf": "6a6c75", + "565969": "0f0f1b", + "251845": "425735", + "79615e": "d6d4d4", + "aef9f9": "e7eef2", + "bcbbc5": "242433", + "7bb3cc": "38cfb0", + "125d4b": "5c94a6", + "9618e0": "ade265", + "e64f5e": "98ce58", + "1e9378": "aef9f9", + "1d1845": "41434e", + "ecfffc": "7cadde", + "aba7bc": "dbd8e8", + "aef9fa": "aef9f9" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-ice_2.json b/public/images/pokemon/variant/773-ice_2.json deleted file mode 100644 index 9c8cf9b3bdb..00000000000 --- a/public/images/pokemon/variant/773-ice_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-ice_2.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:1d23efa5e9b3d275d4a3f1a7f9eeac2c:df7e8bd7cd5bdc82656537e9b98c5301:bbb81164af15638f1aae91f14ca0ac1d$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-ice_2.png b/public/images/pokemon/variant/773-ice_2.png deleted file mode 100644 index 90f429ab6f6..00000000000 Binary files a/public/images/pokemon/variant/773-ice_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-ice_3.json b/public/images/pokemon/variant/773-ice_3.json deleted file mode 100644 index 909c816a588..00000000000 --- a/public/images/pokemon/variant/773-ice_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-ice_3.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:1d23efa5e9b3d275d4a3f1a7f9eeac2c:df7e8bd7cd5bdc82656537e9b98c5301:bbb81164af15638f1aae91f14ca0ac1d$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-ice_3.png b/public/images/pokemon/variant/773-ice_3.png deleted file mode 100644 index 63abf3d3095..00000000000 Binary files a/public/images/pokemon/variant/773-ice_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-poison.json b/public/images/pokemon/variant/773-poison.json new file mode 100644 index 00000000000..f2f97d07bdc --- /dev/null +++ b/public/images/pokemon/variant/773-poison.json @@ -0,0 +1,45 @@ +{ + "1": { + "5399df": "b59489", + "e3e6ec": "bdd1e5", + "483c39": "3a2d53", + "3f3b50": "1e172a", + "0073bf": "7a4949", + "565969": "30365c", + "7234bc": "874dcc", + "4e229c": "4641b5", + "79615e": "504a75", + "251845": "753c32", + "bcbbc5": "788fb5", + "125d4b": "ce7f3f", + "30175c": "2f1b77", + "e64f5e": "f1944a", + "1e9378": "f8ce64", + "9618e0": "dc9c4d", + "9c71ce": "d089ee", + "1d1845": "2e191f", + "aba7bc": "493d55", + "7234bd": "7b4bb5" + }, + "2": { + "5399df": "92949e", + "e3e6ec": "444455", + "483c39": "778894", + "0073bf": "6a6c75", + "565969": "0f0f1b", + "7234bc": "8e4da8", + "4e229c": "e3508d", + "79615e": "d6d4d4", + "251845": "425735", + "bcbbc5": "242433", + "125d4b": "4b1f7e", + "30175c": "34284a", + "e64f5e": "98ce58", + "1e9378": "7234bc", + "9618e0": "ade265", + "9c71ce": "2752b5", + "1d1845": "41434e", + "aba7bc": "dbd8e8", + "7234bd": "7234bc" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-poison_2.json b/public/images/pokemon/variant/773-poison_2.json deleted file mode 100644 index 0f7de42c9a1..00000000000 --- a/public/images/pokemon/variant/773-poison_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-poison_2.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:dfe035db7a0f7cf612f32bd2f5c4eb04:888201f6fcde4f12dac2ceea3b7ac2a5:2e43d6e4a409b7aabc1efd3ec3981f96$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-poison_2.png b/public/images/pokemon/variant/773-poison_2.png deleted file mode 100644 index 92bc0f8a3d1..00000000000 Binary files a/public/images/pokemon/variant/773-poison_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-poison_3.json b/public/images/pokemon/variant/773-poison_3.json deleted file mode 100644 index 4b769c97c9e..00000000000 --- a/public/images/pokemon/variant/773-poison_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-poison_3.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:dfe035db7a0f7cf612f32bd2f5c4eb04:888201f6fcde4f12dac2ceea3b7ac2a5:2e43d6e4a409b7aabc1efd3ec3981f96$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-poison_3.png b/public/images/pokemon/variant/773-poison_3.png deleted file mode 100644 index 47091d9cb8a..00000000000 Binary files a/public/images/pokemon/variant/773-poison_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-psychic.json b/public/images/pokemon/variant/773-psychic.json new file mode 100644 index 00000000000..02a42c53088 --- /dev/null +++ b/public/images/pokemon/variant/773-psychic.json @@ -0,0 +1,45 @@ +{ + "1": { + "565969": "30365c", + "7a2656": "812c6e", + "aba7bc": "493d55", + "f3a1b8": "ffccc3", + "ea6aa5": "c14e82", + "251845": "753c32", + "125d4b": "ce7f3f", + "c1448c": "b3388f", + "bcbbc5": "788fb5", + "79615e": "504a75", + "0073bf": "7a4949", + "1d1845": "2e191f", + "3f3b50": "1e172a", + "9618e0": "dc9c4d", + "ea6aa4": "ec81b2", + "5399df": "b59489", + "483c39": "3a2d53", + "1e9378": "f8ce64", + "e3e6ec": "bdd1e5", + "e64f5e": "f1944a" + }, + "2": { + "565969": "0f0f1b", + "7a2656": "6a3851", + "aba7bc": "dbd8e8", + "f3a1b8": "ed77a7", + "ea6aa5": "ea6aa4", + "251845": "425735", + "125d4b": "9f3351", + "c1448c": "91d4b0", + "bcbbc5": "242433", + "79615e": "d6d4d4", + "0073bf": "6a6c75", + "1d1845": "41434e", + "9618e0": "ade265", + "ea6aa4": "e7eef2", + "5399df": "92949e", + "483c39": "778894", + "1e9378": "ea6aa4", + "e3e6ec": "444455", + "e64f5e": "98ce58" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-psychic_2.json b/public/images/pokemon/variant/773-psychic_2.json deleted file mode 100644 index 4a253910382..00000000000 --- a/public/images/pokemon/variant/773-psychic_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-psychic_2.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:8033b35ef569ca4c4c6d2ad1ae519b70:5293c3498393ac01d648a935b942dded:9fb489b40d17b047a9dacb47533ceda4$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-psychic_2.png b/public/images/pokemon/variant/773-psychic_2.png deleted file mode 100644 index b7f56fae94f..00000000000 Binary files a/public/images/pokemon/variant/773-psychic_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-psychic_3.json b/public/images/pokemon/variant/773-psychic_3.json deleted file mode 100644 index 8e4b8ede99d..00000000000 --- a/public/images/pokemon/variant/773-psychic_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-psychic_3.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:8033b35ef569ca4c4c6d2ad1ae519b70:5293c3498393ac01d648a935b942dded:9fb489b40d17b047a9dacb47533ceda4$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-psychic_3.png b/public/images/pokemon/variant/773-psychic_3.png deleted file mode 100644 index 8a254486e7e..00000000000 Binary files a/public/images/pokemon/variant/773-psychic_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-rock.json b/public/images/pokemon/variant/773-rock.json new file mode 100644 index 00000000000..f15a1bd6e4d --- /dev/null +++ b/public/images/pokemon/variant/773-rock.json @@ -0,0 +1,45 @@ +{ + "1": { + "7a5c52": "775d73", + "e3e6ec": "bdd1e5", + "d6c4b2": "c8b19a", + "483c39": "3a2d53", + "3f3b50": "1e172a", + "0073bf": "7a4949", + "565969": "30365c", + "79615e": "504a75", + "a38479": "c18cb8", + "251845": "753c32", + "bcbbc5": "788fb5", + "125d4b": "ce7f3f", + "9618e0": "dc9c4d", + "e64f5e": "f1944a", + "1e9378": "f8ce64", + "5399df": "b59489", + "1d1845": "2e191f", + "d6c4b1": "e5d2bd", + "aba7bc": "493d55", + "f3ebdc": "fff5d8" + }, + "2": { + "7a5c52": "50433d", + "e3e6ec": "444455", + "d6c4b2": "d6c4b1", + "483c39": "778894", + "0073bf": "6a6c75", + "565969": "0f0f1b", + "79615e": "d6d4d4", + "a38479": "f9de6c", + "251845": "425735", + "bcbbc5": "242433", + "125d4b": "816f5b", + "9618e0": "ade265", + "e64f5e": "98ce58", + "1e9378": "d6c4b1", + "5399df": "92949e", + "1d1845": "41434e", + "d6c4b1": "e7eef2", + "aba7bc": "dbd8e8", + "f3ebdc": "acb4bd" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-rock_2.json b/public/images/pokemon/variant/773-rock_2.json deleted file mode 100644 index 18244ffef66..00000000000 --- a/public/images/pokemon/variant/773-rock_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-rock_2.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:922747a62af7e365b70407e0760a23e7:656409d4ba7bef1578674365e77b4408:b6fcb5d1ff917a13e5e912a7f40fcbe2$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-rock_2.png b/public/images/pokemon/variant/773-rock_2.png deleted file mode 100644 index cb75da9cbea..00000000000 Binary files a/public/images/pokemon/variant/773-rock_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-rock_3.json b/public/images/pokemon/variant/773-rock_3.json deleted file mode 100644 index fe77e866a1d..00000000000 --- a/public/images/pokemon/variant/773-rock_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-rock_3.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:922747a62af7e365b70407e0760a23e7:656409d4ba7bef1578674365e77b4408:b6fcb5d1ff917a13e5e912a7f40fcbe2$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-rock_3.png b/public/images/pokemon/variant/773-rock_3.png deleted file mode 100644 index 0baff166415..00000000000 Binary files a/public/images/pokemon/variant/773-rock_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-steel.json b/public/images/pokemon/variant/773-steel.json new file mode 100644 index 00000000000..7a8a40d6399 --- /dev/null +++ b/public/images/pokemon/variant/773-steel.json @@ -0,0 +1,45 @@ +{ + "1": { + "5399df": "b59489", + "cfc7c7": "dcd1d1", + "483c39": "3a2d53", + "3f3b50": "1e172a", + "0073bf": "7a4949", + "565969": "30365c", + "595467": "565071", + "79615e": "504a75", + "251845": "753c32", + "bcbbc5": "788fb5", + "cfc7c8": "b8aeab", + "1e9378": "f8ce64", + "125d4b": "ce7f3f", + "e64f5e": "f1944a", + "e5e0de": "f1efe5", + "9618e0": "dc9c4d", + "9d98aa": "8f89aa", + "e3e6ec": "bdd1e5", + "aba7bc": "493d55", + "1d1845": "2e191f" + }, + "2": { + "5399df": "92949e", + "cfc7c7": "e7eef2", + "483c39": "778894", + "0073bf": "6a6c75", + "565969": "0f0f1b", + "595467": "3b253e", + "79615e": "d6d4d4", + "251845": "425735", + "bcbbc5": "242433", + "cfc7c8": "cfc7c7", + "1e9378": "cfc7c7", + "125d4b": "705a5f", + "e64f5e": "98ce58", + "e5e0de": "a5a5a5", + "9618e0": "ade265", + "9d98aa": "98099c", + "e3e6ec": "444455", + "aba7bc": "dbd8e8", + "1d1845": "41434e" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-steel_2.json b/public/images/pokemon/variant/773-steel_2.json deleted file mode 100644 index ed81bc3f2f3..00000000000 --- a/public/images/pokemon/variant/773-steel_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-steel_2.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:457a0cbf13798ec9abc1d1ef475cc61b:2312082b81a525c2b4d2beddc123c92f:28dcfb1ac7091bec326d67f7b8d4eaa6$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-steel_2.png b/public/images/pokemon/variant/773-steel_2.png deleted file mode 100644 index 9923e26d937..00000000000 Binary files a/public/images/pokemon/variant/773-steel_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-steel_3.json b/public/images/pokemon/variant/773-steel_3.json deleted file mode 100644 index d2f18cfe976..00000000000 --- a/public/images/pokemon/variant/773-steel_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-steel_3.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:457a0cbf13798ec9abc1d1ef475cc61b:2312082b81a525c2b4d2beddc123c92f:28dcfb1ac7091bec326d67f7b8d4eaa6$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-steel_3.png b/public/images/pokemon/variant/773-steel_3.png deleted file mode 100644 index 694dace6bb7..00000000000 Binary files a/public/images/pokemon/variant/773-steel_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-water.json b/public/images/pokemon/variant/773-water.json new file mode 100644 index 00000000000..4be5ae1c03b --- /dev/null +++ b/public/images/pokemon/variant/773-water.json @@ -0,0 +1,44 @@ +{ + "1": { + "5399df": "b59489", + "175477": "34508a", + "483c39": "3a2d53", + "3ed3ee": "4fd4ec", + "0073bf": "7a4949", + "565969": "30365c", + "3ed3ef": "59d6ec", + "79615e": "504a75", + "251845": "753c32", + "bcbbc5": "788fb5", + "125d4b": "ce7f3f", + "9618e0": "dc9c4d", + "e64f5e": "f1944a", + "1e9378": "f8ce64", + "e3e6ec": "bdd1e5", + "92f1f3": "93f8e9", + "3f3b50": "1e172a", + "aba7bc": "493d55", + "2786bc": "4661cc" + }, + "2": { + "5399df": "92949e", + "175477": "3a182f", + "483c39": "778894", + "3ed3ee": "e7eef2", + "0073bf": "6a6c75", + "565969": "0f0f1b", + "3ed3ef": "2866ba", + "79615e": "d6d4d4", + "251845": "425735", + "bcbbc5": "242433", + "125d4b": "162c81", + "9618e0": "ade265", + "1d1845": "444455", + "e64f5e": "98ce58", + "1e9378": "2866ba", + "e3e6ec": "444455", + "92f1f3": "b82db2", + "aba7bc": "dbd8e8", + "2786bc": "fe75a3" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-water_2.json b/public/images/pokemon/variant/773-water_2.json deleted file mode 100644 index fdadc5fa173..00000000000 --- a/public/images/pokemon/variant/773-water_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-water_2.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:641069390eb79c5af35647b55879f603:0626f05d3311e8fe5ccaf77a20eaa741:609e3c1a2aa54ec6d5110acf831a822b$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-water_2.png b/public/images/pokemon/variant/773-water_2.png deleted file mode 100644 index 933bd9b6076..00000000000 Binary files a/public/images/pokemon/variant/773-water_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/773-water_3.json b/public/images/pokemon/variant/773-water_3.json deleted file mode 100644 index 5dbc11657f6..00000000000 --- a/public/images/pokemon/variant/773-water_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-water_3.png", - "format": "RGBA8888", - "size": { - "w": 83, - "h": 83 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 65, - "h": 83 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - }, - "frame": { - "x": 0, - "y": 0, - "w": 65, - "h": 83 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:641069390eb79c5af35647b55879f603:0626f05d3311e8fe5ccaf77a20eaa741:609e3c1a2aa54ec6d5110acf831a822b$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/773-water_3.png b/public/images/pokemon/variant/773-water_3.png deleted file mode 100644 index 568eac10857..00000000000 Binary files a/public/images/pokemon/variant/773-water_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/807.json b/public/images/pokemon/variant/807.json new file mode 100644 index 00000000000..bfb72f3cd42 --- /dev/null +++ b/public/images/pokemon/variant/807.json @@ -0,0 +1,28 @@ +{ + "1": { + "ef8a4e": "4f7bb6", + "484f57": "243058", + "000000": "ffffff", + "727678": "3e5277", + "2759a5": "736599", + "5bd0f2": "ebceff", + "daa936": "5a96b6", + "9d682d": "3c648d", + "f9e455": "7fc7d9", + "2394d8": "b298d8", + "31343e": "14193f" + }, + "2": { + "ef8a4e": "834b95", + "484f57": "cda4cb", + "000000": "ffffff", + "727678": "e8cae3", + "2759a5": "a4378a", + "5bd0f2": "e17197", + "daa936": "331b53", + "9d682d": "1d1044", + "f9e455": "56306f", + "2394d8": "c05192", + "31343e": "a981b1" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/894.json b/public/images/pokemon/variant/894.json new file mode 100644 index 00000000000..99756eea4d5 --- /dev/null +++ b/public/images/pokemon/variant/894.json @@ -0,0 +1,28 @@ +{ + "1": { + "fffbfc": "fefaef", + "e5ee1a": "6ad7f3", + "8eacdd": "caffd1", + "7d542a": "2769aa", + "fefac7": "dffff6", + "bc8b2f": "124b78", + "fffbfb": "dffff6", + "2e3967": "357b84", + "4e7cc9": "9bf1c4", + "375395": "5fcaad", + "ff9dc2": "2c3072", + "d7ad0d": "45a3d6" + }, + "2": { + "e5ee1a": "d4ffd0", + "8eacdd": "c693d8", + "7d542a": "429877", + "fefac7": "ffffff", + "bc8b2f": "2a6f5d", + "2e3967": "514199", + "4e7cc9": "b67cd6", + "375395": "815bad", + "ff9dc2": "382875", + "d7ad0d": "7cd395" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/895.json b/public/images/pokemon/variant/895.json new file mode 100644 index 00000000000..90e3ec96f99 --- /dev/null +++ b/public/images/pokemon/variant/895.json @@ -0,0 +1,32 @@ +{ + "1": { + "641e2c": "722123", + "b63650": "bc623e", + "872c3c": "93372d", + "608d99": "fae5bf", + "2b3d40": "754f47", + "2261ca": "561a5b", + "4b6f78": "f1d4b6", + "e05276": "ef8429", + "242e35": "512c25", + "f27a99": "efb55a", + "76dff5": "ffe8f7", + "3f545f": "ad8473", + "139ee1": "9b407f" + }, + "2": { + "641e2c": "15553b", + "b63650": "3bb349", + "872c3c": "227843", + "608d99": "9b7ebc", + "2b3d40": "241951", + "2261ca": "640e0b", + "4b6f78": "5a4382", + "e05276": "8aea41", + "242e35": "0f0c1e", + "f27a99": "dfff75", + "76dff5": "fffcdf", + "3f545f": "3a2a67", + "139ee1": "98301c" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/944.json b/public/images/pokemon/variant/944.json new file mode 100644 index 00000000000..56fc21986f7 --- /dev/null +++ b/public/images/pokemon/variant/944.json @@ -0,0 +1,42 @@ +{ + "1": { + "b5eab2": "75a0d0", + "d4eac7": "8bcfe5", + "bdb2bd": "53a164", + "ceceb7": "3ec295", + "726766": "4f985c", + "4a4860": "372869", + "8ce1b2": "6383c4", + "564a49": "286943", + "000000": "ffffff", + "4ca391": "3a4a8a", + "a571e6": "ffe269", + "774d9b": "d09139", + "97859b": "3f8d59", + "afc6d8": "8056a7", + "efeee1": "88eeab", + "869fad": "5e4090", + "918772": "1c9b8d", + "3a2b2f": "18493f" + }, + "2": { + "b5eab2": "a9c6dc", + "d4eac7": "e2f8ff", + "bdb2bd": "78b0c2", + "ceceb7": "abc1df", + "726766": "5386b9", + "4a4860": "4f133f", + "8ce1b2": "8397c4", + "564a49": "2c4f8a", + "000000": "ffffff", + "4ca391": "6974ad", + "a571e6": "4c5372", + "774d9b": "2c2c46", + "97859b": "5582a4", + "afc6d8": "c23f4f", + "efeee1": "e2f3ff", + "869fad": "902a4b", + "918772": "6777aa", + "3a2b2f": "1e3072" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/945.json b/public/images/pokemon/variant/945.json new file mode 100644 index 00000000000..e22743030f9 --- /dev/null +++ b/public/images/pokemon/variant/945.json @@ -0,0 +1,53 @@ +{ + "1": { + "403f4f": "357747", + "1f2635": "1c193d", + "dcdcc3": "5ddcb2", + "282434": "14463f", + "ebe4e2": "ade273", + "a491a4": "499833", + "e6e2e1": "fffbf3", + "671544": "0f4e67", + "584698": "18153d", + "134175": "a74d2a", + "4f483f": "1b727b", + "323d4a": "2e2452", + "000000": "ffffff", + "8ac2a2": "1a355d", + "d73875": "29ad89", + "e0ebf1": "7ddfee", + "2481b0": "d09139", + "4b616b": "473869", + "38bdda": "ffe269", + "695575": "16613d", + "aca699": "2db3a4", + "8d2151": "157375", + "cedaaa": "2f5b7b" + }, + "2": { + "403f4f": "3b6b9e", + "1f2635": "3b091c", + "dcdcc3": "edf0f1", + "282434": "2d427e", + "ebe4e2": "c23f4f", + "a491a4": "902a4b", + "e6e2e1": "ebf4f9", + "671544": "223969", + "584698": "1f1e43", + "134175": "1c182f", + "4f483f": "5d7487", + "323d4a": "580f1d", + "000000": "ffffff", + "a599a8": "bf888f", + "8ac2a2": "8397c4", + "7c6a84": "965b6f", + "d73875": "68adca", + "2481b0": "2c2c46", + "4b616b": "8a2029", + "38bdda": "494e64", + "695575": "4f133f", + "aca699": "acbfc7", + "8d2151": "4676aa", + "cedaaa": "bad4e8" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/_masterlist.json b/public/images/pokemon/variant/_masterlist.json index 938c92f5056..11f8e9cb7ec 100644 --- a/public/images/pokemon/variant/_masterlist.json +++ b/public/images/pokemon/variant/_masterlist.json @@ -1,11113 +1,2474 @@ { - "1": [ - 0, - 1, - 1 - ], - "2": [ - 0, - 2, - 1 - ], - "3-gigantamax": [ - 0, - 1, - 1 - ], - "3-mega": [ - 0, - 2, - 2 - ], - "3": [ - 0, - 1, - 1 - ], - "4": [ - 0, - 1, - 1 - ], - "5": [ - 0, - 1, - 1 - ], - "6-mega-x": [ - 0, - 1, - 2 - ], - "6-gigantamax": [ - 0, - 1, - 2 - ], - "6-mega-y": [ - 0, - 1, - 2 - ], - "6": [ - 0, - 2, - 2 - ], - "7": [ - 0, - 2, - 2 - ], - "8": [ - 0, - 2, - 2 - ], - "9-gigantamax": [ - 0, - 1, - 2 - ], - "9-mega": [ - 0, - 2, - 2 - ], - "9": [ - 0, - 2, - 2 - ], - "19": [ - 0, - 1, - 1 - ], - "20": [ - 0, - 1, - 1 - ], - "23": [ - 0, - 1, - 1 - ], - "24": [ - 0, - 1, - 1 - ], - "29": [ - 0, - 1, - 1 - ], - "30": [ - 0, - 1, - 1 - ], - "31": [ - 1, - 1, - 1 - ], - "35": [ - 0, - 1, - 2 - ], - "36": [ - 0, - 1, - 1 - ], - "37": [ - 0, - 1, - 1 - ], - "38": [ - 0, - 1, - 1 - ], - "41": [ - 0, - 1, - 1 - ], - "42": [ - 0, - 1, - 1 - ], - "43": [ - 0, - 1, - 1 - ], - "44": [ - 0, - 1, - 1 - ], - "45": [ - 0, - 1, - 1 - ], - "46": [ - 1, - 1, - 1 - ], - "47": [ - 1, - 1, - 1 - ], - "50": [ - 0, - 1, - 1 - ], - "51": [ - 0, - 1, - 1 - ], - "52-gigantamax": [ - 1, - 1, - 1 - ], - "52": [ - 1, - 1, - 1 - ], - "53": [ - 1, - 1, - 1 - ], - "56": [ - 1, - 2, - 2 - ], - "57": [ - 2, - 2, - 2 - ], - "69": [ - 0, - 2, - 2 - ], - "70": [ - 0, - 1, - 1 - ], - "71": [ - 0, - 1, - 1 - ], - "77": [ - 0, - 1, - 1 - ], - "78": [ - 0, - 1, - 1 - ], - "79": [ - 1, - 1, - 1 - ], - "80": [ - 0, - 1, - 1 - ], - "80-mega": [ - 0, - 1, - 1 - ], - "81": [ - 0, - 1, - 1 - ], - "82": [ - 0, - 1, - 1 - ], - "83": [ - 0, - 2, - 2 - ], - "84": [ - 1, - 1, - 1 - ], - "85": [ - 1, - 1, - 1 - ], - "86": [ - 1, - 1, - 1 - ], - "87": [ - 1, - 1, - 1 - ], - "92": [ - 2, - 2, - 2 - ], - "93": [ - 1, - 1, - 1 - ], - "94-gigantamax": [ - 1, - 2, - 2 - ], - "94-mega": [ - 2, - 2, - 2 - ], - "94": [ - 1, - 1, - 1 - ], - "98": [ - 0, - 1, - 1 - ], - "99": [ - 0, - 1, - 1 - ], - "99-gigantamax": [ - 0, - 1, - 1 - ], - "100": [ - 0, - 1, - 1 - ], - "101": [ - 0, - 1, - 1 - ], - "111": [ - 0, - 1, - 1 - ], - "112": [ - 0, - 1, - 1 - ], - "113": [ - 2, - 2, - 2 - ], - "114": [ - 0, - 1, - 1 - ], - "116": [ - 0, - 1, - 1 - ], - "117": [ - 0, - 1, - 1 - ], - "118": [ - 1, - 1, - 1 - ], - "119": [ - 1, - 1, - 1 - ], - "120": [ - 0, - 1, - 1 - ], - "121": [ - 0, - 1, - 1 - ], - "123": [ - 1, - 1, - 1 - ], - "125": [ - 1, - 1, - 2 - ], - "126": [ - 0, - 2, - 1 - ], - "127-mega": [ - 0, - 1, - 1 - ], - "127": [ - 0, - 1, - 1 - ], - "129": [ - 0, - 1, - 1 - ], - "130-mega": [ - 0, - 1, - 1 - ], - "130": [ - 0, - 1, - 1 - ], - "131-gigantamax": [ - 0, - 1, - 1 - ], - "131": [ - 0, - 1, - 1 - ], - "132": [ - 0, - 1, - 1 - ], - "133": [ - 0, - 1, - 1 - ], - "133-partner": [ - 0, - 1, - 1 - ], - "134": [ - 0, - 1, - 1 - ], - "135": [ - 1, - 1, - 1 - ], - "136": [ - 1, - 1, - 1 - ], - "137": [ - 0, - 1, - 1 - ], - "138": [ - 0, - 1, - 1 - ], - "139": [ - 0, - 1, - 2 - ], - "140": [ - 0, - 1, - 1 - ], - "141": [ - 0, - 2, - 2 - ], - "142-mega": [ - 0, - 1, - 1 - ], - "142": [ - 0, - 1, - 1 - ], - "144": [ - 1, - 2, - 2 - ], - "145": [ - 1, - 1, - 1 - ], - "146": [ - 1, - 1, - 1 - ], - "147": [ - 0, - 1, - 1 - ], - "148": [ - 0, - 1, - 1 - ], - "149": [ - 0, - 1, - 1 - ], - "150-mega-x": [ - 0, - 1, - 1 - ], - "150-mega-y": [ - 0, - 1, - 1 - ], - "150": [ - 0, - 1, - 1 - ], - "151": [ - 0, - 1, - 1 - ], - "161": [ - 0, - 1, - 2 - ], - "162": [ - 0, - 1, - 1 - ], - "163": [ - 0, - 1, - 1 - ], - "164": [ - 0, - 2, - 2 - ], - "169": [ - 0, - 1, - 1 - ], - "173": [ - 0, - 1, - 2 - ], - "175": [ - 1, - 1, - 1 - ], - "176": [ - 1, - 1, - 1 - ], - "177": [ - 0, - 1, - 1 - ], - "178": [ - 0, - 2, - 2 - ], - "179": [ - 0, - 1, - 1 - ], - "180": [ - 0, - 2, - 2 - ], - "181-mega": [ - 0, - 1, - 2 - ], - "181": [ - 0, - 1, - 1 - ], - "182": [ - 0, - 1, - 1 - ], - "183": [ - 0, - 1, - 2 - ], - "184": [ - 0, - 2, - 2 - ], - "185": [ - 0, - 1, - 1 - ], - "190": [ - 0, - 1, - 1 - ], - "193": [ - 0, - 1, - 1 - ], - "196": [ - 1, - 1, - 1 - ], - "197": [ - 0, - 1, - 1 - ], - "199": [ - 2, - 1, - 1 - ], - "200": [ - 1, - 1, - 1 - ], - "201-m": [ - 0, - 1, - 1 - ], - "201-question": [ - 0, - 1, - 1 - ], - "201-j": [ - 0, - 1, - 1 - ], - "201-l": [ - 0, - 1, - 1 - ], - "201-h": [ - 0, - 1, - 1 - ], - "201-x": [ - 0, - 1, - 1 - ], - "201-exclamation": [ - 0, - 1, - 1 - ], - "201-q": [ - 0, - 1, - 1 - ], - "201-s": [ - 0, - 1, - 1 - ], - "201-c": [ - 0, - 1, - 1 - ], - "201-u": [ - 0, - 1, - 1 - ], - "201-t": [ - 0, - 1, - 1 - ], - "201-z": [ - 0, - 1, - 1 - ], - "201-d": [ - 0, - 1, - 1 - ], - "201-b": [ - 0, - 1, - 1 - ], - "201-g": [ - 0, - 1, - 1 - ], - "201-k": [ - 0, - 1, - 1 - ], - "201-i": [ - 0, - 1, - 1 - ], - "201-p": [ - 0, - 1, - 1 - ], - "201-e": [ - 0, - 1, - 1 - ], - "201-y": [ - 0, - 1, - 1 - ], - "201-r": [ - 0, - 1, - 1 - ], - "201-f": [ - 0, - 1, - 1 - ], - "201-n": [ - 0, - 1, - 1 - ], - "201-v": [ - 0, - 1, - 1 - ], - "201-a": [ - 0, - 1, - 1 - ], - "201-w": [ - 0, - 1, - 1 - ], - "201-o": [ - 0, - 1, - 1 - ], - "203": [ - 0, - 1, - 1 - ], - "206": [ - 0, - 1, - 1 - ], - "207": [ - 0, - 1, - 1 - ], - "212-mega": [ - 1, - 1, - 1 - ], - "212": [ - 1, - 1, - 1 - ], - "213": [ - 0, - 1, - 1 - ], - "215": [ - 0, - 1, - 1 - ], - "216": [ - 1, - 1, - 1 - ], - "217": [ - 1, - 1, - 1 - ], - "222": [ - 0, - 1, - 1 - ], - "226": [ - 0, - 2, - 2 - ], - "227": [ - 0, - 1, - 1 - ], - "228": [ - 0, - 1, - 1 - ], - "229": [ - 0, - 1, - 1 - ], - "229-mega": [ - 0, - 1, - 1 - ], - "230": [ - 0, - 1, - 1 - ], - "231": [ - 0, - 1, - 1 - ], - "232": [ - 0, - 1, - 1 - ], - "233": [ - 0, - 1, - 1 - ], - "235": [ - 0, - 1, - 1 - ], - "239": [ - 1, - 1, - 2 - ], - "240": [ - 0, - 1, - 1 - ], - "242": [ - 2, - 2, - 2 - ], - "243": [ - 0, - 1, - 1 - ], - "244": [ - 0, - 2, - 2 - ], - "245": [ - 0, - 1, - 1 - ], - "246": [ - 0, - 1, - 1 - ], - "247": [ - 0, - 1, - 1 - ], - "248": [ - 0, - 1, - 1 - ], - "248-mega": [ - 0, - 2, - 1 - ], - "249": [ - 0, - 2, - 2 - ], - "250": [ - 0, - 2, - 2 - ], - "251": [ - 0, - 1, - 1 - ], - "255": [ - 0, - 1, - 1 - ], - "256": [ - 0, - 1, - 1 - ], - "257": [ - 0, - 1, - 2 - ], - "257-mega": [ - 0, - 1, - 1 - ], - "261": [ - 0, - 1, - 1 - ], - "262": [ - 0, - 1, - 1 - ], - "263": [ - 0, - 1, - 1 - ], - "264": [ - 0, - 1, - 1 - ], - "278": [ - 1, - 1, - 1 - ], - "279": [ - 1, - 1, - 1 - ], - "280": [ - 0, - 1, - 1 - ], - "281": [ - 0, - 1, - 1 - ], - "282-mega": [ - 0, - 2, - 2 - ], - "282": [ - 0, - 1, - 1 - ], - "285": [ - 0, - 1, - 1 - ], - "286": [ - 0, - 1, - 1 - ], - "290": [ - 1, - 1, - 1 - ], - "291": [ - 2, - 2, - 2 - ], - "292": [ - 2, - 1, - 2 - ], - "298": [ - 0, - 2, - 2 - ], - "300": [ - 1, - 1, - 1 - ], - "301": [ - 1, - 1, - 1 - ], - "302": [ - 0, - 1, - 1 - ], - "302-mega": [ - 0, - 1, - 1 - ], - "303-mega": [ - 1, - 1, - 1 - ], - "303": [ - 0, - 1, - 1 - ], - "304": [ - 1, - 1, - 1 - ], - "305": [ - 1, - 1, - 1 - ], - "306-mega": [ - 1, - 1, - 1 - ], - "306": [ - 1, - 1, - 1 - ], - "307": [ - 0, - 1, - 1 - ], - "308-mega": [ - 0, - 1, - 1 - ], - "308": [ - 0, - 2, - 1 - ], - "309": [ - 0, - 1, - 1 - ], - "310-mega": [ - 0, - 1, - 1 - ], - "310": [ - 0, - 1, - 1 - ], - "311": [ - 1, - 1, - 1 - ], - "312": [ - 0, - 1, - 1 - ], - "315": [ - 0, - 1, - 1 - ], - "320": [ - 0, - 1, - 1 - ], - "321": [ - 0, - 1, - 1 - ], - "327": [ - 0, - 1, - 1 - ], - "328": [ - 0, - 1, - 1 - ], - "329": [ - 0, - 1, - 2 - ], - "330": [ - 0, - 1, - 1 - ], - "333": [ - 0, - 1, - 1 - ], - "334-mega": [ - 0, - 2, - 1 - ], - "334": [ - 0, - 2, - 2 - ], - "335": [ - 0, - 2, - 2 - ], - "336": [ - 0, - 1, - 1 - ], - "337": [ - 0, - 1, - 1 - ], - "338": [ - 0, - 1, - 1 - ], - "339": [ - 0, - 1, - 1 - ], - "340": [ - 0, - 1, - 2 - ], - "341": [ - 0, - 2, - 2 - ], - "342": [ - 0, - 2, - 2 - ], - "351-rainy": [ - 1, - 2, - 2 - ], - "351-snowy": [ - 1, - 1, - 1 - ], - "351-sunny": [ - 1, - 2, - 2 - ], - "351": [ - 0, - 2, - 2 - ], - "352": [ - 1, - 1, - 1 - ], - "353": [ - 0, - 1, - 1 - ], - "354": [ - 0, - 1, - 1 - ], - "354-mega": [ - 0, - 1, - 1 - ], - "357": [ - 0, - 1, - 1 - ], - "358": [ - 2, - 1, - 1 - ], - "361": [ - 0, - 1, - 1 - ], - "362": [ - 0, - 2, - 2 - ], - "362-mega": [ - 0, - 1, - 1 - ], - "369": [ - 0, - 1, - 1 - ], - "370": [ - 0, - 1, - 1 - ], - "371": [ - 0, - 1, - 1 - ], - "372": [ - 0, - 1, - 1 - ], - "373-mega": [ - 0, - 2, - 2 - ], - "373": [ - 0, - 1, - 1 - ], - "374": [ - 0, - 1, - 1 - ], - "375": [ - 0, - 1, - 1 - ], - "376-mega": [ - 0, - 1, - 1 - ], - "376": [ - 0, - 1, - 1 - ], - "380-mega": [ - 0, - 1, - 1 - ], - "380": [ - 0, - 1, - 1 - ], - "381-mega": [ - 0, - 1, - 1 - ], - "381": [ - 0, - 1, - 1 - ], - "382-primal": [ - 0, - 1, - 1 - ], - "382": [ - 0, - 1, - 1 - ], - "383-primal": [ - 0, - 1, - 1 - ], - "383": [ - 0, - 1, - 1 - ], - "384-mega": [ - 0, - 2, - 1 - ], - "384": [ - 0, - 1, - 1 - ], - "385": [ - 1, - 1, - 1 - ], - "387": [ - 0, - 1, - 1 - ], - "388": [ - 0, - 1, - 1 - ], - "389": [ - 0, - 1, - 1 - ], - "393": [ - 0, - 1, - 1 - ], - "394": [ - 0, - 1, - 1 - ], - "395": [ - 0, - 1, - 1 - ], - "399": [ - 0, - 1, - 1 - ], - "400": [ - 0, - 1, - 1 - ], - "401": [ - 0, - 1, - 1 - ], - "402": [ - 0, - 1, - 1 - ], - "406": [ - 0, - 1, - 1 - ], - "407": [ - 0, - 1, - 1 - ], - "412-sandy": [ - 2, - 2, - 2 - ], - "412-plant": [ - 1, - 1, - 1 - ], - "412-trash": [ - 1, - 1, - 1 - ], - "413-plant": [ - 2, - 2, - 2 - ], - "413-trash": [ - 1, - 1, - 1 - ], - "413-sandy": [ - 1, - 1, - 1 - ], - "414": [ - 0, - 1, - 1 - ], - "418": [ - 0, - 1, - 1 - ], - "419": [ - 0, - 1, - 1 - ], - "422-west": [ - 1, - 1, - 1 - ], - "422-east": [ - 1, - 1, - 1 - ], - "423-west": [ - 1, - 1, - 1 - ], - "423-east": [ - 1, - 1, - 1 - ], - "424": [ - 0, - 1, - 1 - ], - "425": [ - 0, - 1, - 1 - ], - "426": [ - 0, - 1, - 1 - ], - "427": [ - 0, - 1, - 1 - ], - "428-mega": [ - 0, - 1, - 1 - ], - "428": [ - 0, - 1, - 1 - ], - "429": [ - 1, - 1, - 1 - ], - "433": [ - 1, - 1, - 1 - ], - "436": [ - 0, - 1, - 1 - ], - "437": [ - 0, - 1, - 1 - ], - "438": [ - 0, - 1, - 1 - ], - "440": [ - 1, - 1, - 2 - ], - "441": [ - 0, - 1, - 1 - ], - "442": [ - 0, - 1, - 1 - ], - "443": [ - 1, - 1, - 1 - ], - "444": [ - 1, - 1, - 1 - ], - "445-mega": [ - 1, - 1, - 1 - ], - "445": [ - 1, - 1, - 1 - ], - "447": [ - 1, - 1, - 1 - ], - "448-mega": [ - 1, - 1, - 1 - ], - "448": [ - 1, - 1, - 1 - ], - "453": [ - 0, - 1, - 1 - ], - "454": [ - 0, - 1, - 1 - ], - "456": [ - 0, - 1, - 1 - ], - "457": [ - 0, - 1, - 1 - ], - "458": [ - 0, - 1, - 1 - ], - "461": [ - 0, - 1, - 1 - ], - "462": [ - 0, - 1, - 1 - ], - "464": [ - 0, - 1, - 1 - ], - "465": [ - 0, - 1, - 1 - ], - "466": [ - 1, - 1, - 2 - ], - "467": [ - 0, - 1, - 1 - ], - "468": [ - 1, - 1, - 1 - ], - "469": [ - 0, - 1, - 1 - ], - "470": [ - 1, - 1, - 1 - ], - "471": [ - 1, - 2, - 2 - ], - "472": [ - 0, - 1, - 1 - ], - "474": [ - 0, - 1, - 1 - ], - "475-mega": [ - 0, - 2, - 2 - ], - "475": [ - 0, - 1, - 1 - ], - "478": [ - 0, - 2, - 1 - ], - "479-heat": [ - 0, - 1, - 1 - ], - "479-wash": [ - 0, - 1, - 1 - ], - "479-mow": [ - 0, - 1, - 1 - ], - "479-frost": [ - 0, - 1, - 1 - ], - "479": [ - 0, - 1, - 1 - ], - "479-fan": [ - 0, - 1, - 1 - ], - "480": [ - 1, - 1, - 1 - ], - "481": [ - 1, - 1, - 1 - ], - "482": [ - 1, - 1, - 1 - ], - "485": [ - 0, - 1, - 1 - ], - "487-altered": [ - 0, - 1, - 1 - ], - "487-origin": [ - 0, - 1, - 1 - ], - "488": [ - 0, - 1, - 1 - ], - "489": [ - 1, - 1, - 1 - ], - "490": [ - 1, - 1, - 1 - ], - "491": [ - 0, - 1, - 1 - ], - "492-land": [ - 0, - 2, - 1 - ], - "492-sky": [ - 0, - 1, - 1 - ], - "494": [ - 0, - 1, - 1 - ], - "495": [ - 0, - 1, - 1 - ], - "496": [ - 0, - 1, - 1 - ], - "497": [ - 0, - 1, - 1 - ], - "517": [ - 0, - 1, - 1 - ], - "518": [ - 0, - 1, - 1 - ], - "524": [ - 0, - 1, - 1 - ], - "525": [ - 0, - 1, - 1 - ], - "526": [ - 0, - 2, - 2 - ], - "529": [ - 0, - 2, - 2 - ], - "530": [ - 0, - 2, - 2 - ], - "531": [ - 0, - 1, - 1 - ], - "531-mega": [ - 0, - 1, - 1 - ], - "532": [ - 0, - 1, - 1 - ], - "533": [ - 0, - 1, - 1 - ], - "534": [ - 0, - 1, - 1 - ], - "538": [ - 0, - 1, - 1 - ], - "539": [ - 0, - 2, - 2 - ], - "540": [ - 0, - 1, - 1 - ], - "541": [ - 0, - 1, - 1 - ], - "542": [ - 0, - 1, - 1 - ], - "543": [ - 0, - 1, - 2 - ], - "544": [ - 0, - 1, - 2 - ], - "545": [ - 0, - 1, - 1 - ], - "546": [ - 0, - 1, - 1 - ], - "547": [ - 0, - 1, - 1 - ], - "548": [ - 1, - 1, - 1 - ], - "549": [ - 0, - 1, - 2 - ], - "551": [ - 0, - 1, - 1 - ], - "552": [ - 0, - 1, - 1 - ], - "553": [ - 0, - 1, - 1 - ], - "556": [ - 0, - 1, - 1 - ], - "559": [ - 1, - 1, - 1 - ], - "560": [ - 1, - 1, - 1 - ], - "562": [ - 0, - 1, - 1 - ], - "563": [ - 0, - 1, - 1 - ], - "568": [ - 0, - 2, - 2 - ], - "569-gigantamax": [ - 0, - 1, - 1 - ], - "569": [ - 0, - 1, - 1 - ], - "570": [ - 0, - 1, - 1 - ], - "571": [ - 0, - 1, - 1 - ], - "572": [ - 0, - 1, - 1 - ], - "577": [ - 1, - 1, - 1 - ], - "578": [ - 1, - 1, - 1 - ], - "579": [ - 1, - 1, - 1 - ], - "585-autumn": [ - 2, - 0, - 0 - ], - "585-spring": [ - 2, - 0, - 0 - ], - "585-summer": [ - 2, - 0, - 0 - ], - "585-winter": [ - 2, - 0, - 0 - ], - "586-autumn": [ - 1, - 0, - 0 - ], - "586-spring": [ - 1, - 0, - 0 - ], - "586-summer": [ - 1, - 0, - 0 - ], - "586-winter": [ - 1, - 0, - 0 - ], - "592": [ - 0, - 1, - 2 - ], - "593": [ - 0, - 1, - 1 - ], - "594": [ - 0, - 1, - 2 - ], - "595": [ - 0, - 1, - 1 - ], - "596": [ - 0, - 1, - 1 - ], - "602": [ - 0, - 1, - 1 - ], - "603": [ - 0, - 1, - 1 - ], - "604": [ - 0, - 1, - 1 - ], - "605": [ - 1, - 1, - 1 - ], - "606": [ - 1, - 1, - 1 - ], - "607": [ - 0, - 1, - 1 - ], - "608": [ - 0, - 1, - 1 - ], - "609": [ - 0, - 1, - 1 - ], - "610": [ - 0, - 1, - 1 - ], - "611": [ - 0, - 1, - 1 - ], - "612": [ - 0, - 1, - 2 - ], - "618": [ - 0, - 1, - 1 - ], - "619": [ - 0, - 1, - 1 - ], - "620": [ - 0, - 1, - 1 - ], - "622": [ - 0, - 1, - 1 - ], - "623": [ - 0, - 1, - 1 - ], - "631": [ - 0, - 2, - 2 - ], - "632": [ - 0, - 1, - 1 - ], - "633": [ - 0, - 1, - 1 - ], - "634": [ - 0, - 1, - 1 - ], - "635": [ - 0, - 1, - 1 - ], - "636": [ - 0, - 1, - 1 - ], - "637": [ - 0, - 1, - 1 - ], - "640": [ - 0, - 1, - 1 - ], - "647-resolute": [ - 0, - 1, - 1 - ], - "647-ordinary": [ - 0, - 1, - 1 - ], - "648-aria": [ - 0, - 1, - 1 - ], - "648-pirouette": [ - 0, - 1, - 1 - ], - "649-burn": [ - 0, - 1, - 1 - ], - "649-chill": [ - 0, - 1, - 1 - ], - "649-douse": [ - 0, - 1, - 1 - ], - "649-shock": [ - 0, - 1, - 1 - ], - "649": [ - 0, - 1, - 1 - ], - "653": [ - 0, - 1, - 1 - ], - "654": [ - 0, - 1, - 1 - ], - "655": [ - 0, - 1, - 1 - ], - "664": [ - 0, - 1, - 1 - ], - "665": [ - 0, - 1, - 1 - ], - "666-archipelago": [ - 0, - 1, - 1 - ], - "666-continental": [ - 0, - 1, - 2 - ], - "666-elegant": [ - 0, - 1, - 1 - ], - "666-fancy": [ - 0, - 2, - 2 - ], - "666-garden": [ - 0, - 1, - 1 - ], - "666-high-plains": [ - 0, - 1, - 1 - ], - "666-icy-snow": [ - 0, - 1, - 1 - ], - "666-jungle": [ - 0, - 1, - 1 - ], - "666-marine": [ - 0, - 1, - 1 - ], - "666-meadow": [ - 0, - 1, - 1 - ], - "666-modern": [ - 0, - 1, - 1 - ], - "666-monsoon": [ - 0, - 1, - 1 - ], - "666-ocean": [ - 0, - 1, - 1 - ], - "666-poke-ball": [ - 0, - 1, - 2 - ], - "666-polar": [ - 0, - 1, - 1 - ], - "666-river": [ - 0, - 2, - 1 - ], - "666-sandstorm": [ - 0, - 1, - 1 - ], - "666-savanna": [ - 0, - 1, - 1 - ], - "666-sun": [ - 0, - 1, - 1 - ], - "666-tundra": [ - 0, - 1, - 1 - ], - "669-red": [ - 0, - 2, - 1 - ], - "669-blue": [ - 0, - 2, - 2 - ], - "669-white": [ - 0, - 1, - 1 - ], - "669-yellow": [ - 0, - 2, - 1 - ], - "669-orange": [ - 0, - 2, - 1 - ], - "670-white": [ - 0, - 2, - 2 - ], - "670-blue": [ - 0, - 2, - 2 - ], - "670-orange": [ - 0, - 2, - 2 - ], - "670-red": [ - 0, - 2, - 2 - ], - "670-yellow": [ - 0, - 2, - 2 - ], - "671-red": [ - 0, - 1, - 2 - ], - "671-blue": [ - 0, - 1, - 2 - ], - "671-yellow": [ - 0, - 1, - 2 - ], - "671-white": [ - 0, - 1, - 2 - ], - "671-orange": [ - 0, - 1, - 1 - ], - "672": [ - 0, - 1, - 2 - ], - "673": [ - 0, - 1, - 1 - ], - "677": [ - 0, - 1, - 1 - ], - "678-female": [ - 0, - 1, - 1 - ], - "678": [ - 0, - 1, - 1 - ], - "690": [ - 0, - 1, - 1 - ], - "691": [ - 0, - 1, - 1 - ], - "696": [ - 0, - 1, - 2 - ], - "697": [ - 0, - 1, - 2 - ], - "698": [ - 0, - 1, - 1 - ], - "699": [ - 0, - 1, - 1 - ], - "700": [ - 0, - 1, - 1 - ], - "702": [ - 0, - 1, - 1 - ], - "703": [ - 0, - 1, - 1 - ], - "704": [ - 0, - 1, - 1 - ], - "705": [ - 0, - 1, - 1 - ], - "706": [ - 0, - 1, - 1 - ], - "708": [ - 0, - 1, - 1 - ], - "709": [ - 0, - 1, - 1 - ], - "710": [ - 0, - 1, - 1 - ], - "711": [ - 1, - 1, - 1 - ], - "712": [ - 0, - 1, - 1 - ], - "713": [ - 0, - 1, - 1 - ], - "714": [ - 0, - 1, - 1 - ], - "715": [ - 0, - 2, - 2 - ], - "716-active": [ - 0, - 1, - 1 - ], - "716-neutral": [ - 0, - 1, - 1 - ], - "717": [ - 0, - 1, - 1 - ], - "720-unbound": [ - 1, - 1, - 1 - ], - "720": [ - 1, - 1, - 1 - ], - "728": [ - 0, - 1, - 1 - ], - "729": [ - 0, - 1, - 1 - ], - "730": [ - 0, - 1, - 1 - ], - "734": [ - 0, - 1, - 1 - ], - "735": [ - 0, - 1, - 1 - ], - "742": [ - 0, - 2, - 2 - ], - "743": [ - 0, - 2, - 2 - ], - "747": [ - 0, - 1, - 1 - ], - "748": [ - 0, - 1, - 1 - ], - "751": [ - 0, - 1, - 1 - ], - "752": [ - 0, - 1, - 1 - ], - "753": [ - 0, - 1, - 1 - ], - "754": [ - 0, - 1, - 1 - ], - "755": [ - 0, - 1, - 1 - ], - "756": [ - 0, - 1, - 2 - ], - "761": [ - 0, - 1, - 1 - ], - "762": [ - 0, - 1, - 1 - ], - "763": [ - 0, - 1, - 1 - ], - "767": [ - 0, - 1, - 1 - ], - "768": [ - 0, - 1, - 1 - ], - "771": [ - 0, - 1, - 1 - ], - "772": [ - 0, - 1, - 1 - ], - "773-fighting": [ - 0, - 2, - 2 - ], - "773-psychic": [ - 0, - 2, - 2 - ], - "773-poison": [ - 0, - 2, - 2 - ], - "773-ground": [ - 0, - 2, - 2 - ], - "773-ghost": [ - 0, - 2, - 2 - ], - "773-steel": [ - 0, - 2, - 2 - ], - "773-rock": [ - 0, - 2, - 2 - ], - "773-grass": [ - 0, - 2, - 2 - ], - "773-dragon": [ - 0, - 2, - 2 - ], - "773-bug": [ - 0, - 2, - 2 - ], - "773-ice": [ - 0, - 2, - 2 - ], - "773-dark": [ - 0, - 2, - 2 - ], - "773": [ - 0, - 1, - 1 - ], - "773-fairy": [ - 0, - 2, - 2 - ], - "773-water": [ - 0, - 2, - 2 - ], - "773-electric": [ - 0, - 2, - 2 - ], - "773-flying": [ - 0, - 2, - 2 - ], - "773-fire": [ - 0, - 2, - 2 - ], - "776": [ - 0, - 1, - 1 - ], - "777": [ - 0, - 1, - 1 - ], - "778-busted": [ - 0, - 1, - 1 - ], - "778-disguised": [ - 0, - 1, - 1 - ], - "779": [ - 0, - 1, - 1 - ], - "789": [ - 1, - 1, - 1 - ], - "790": [ - 0, - 1, - 1 - ], - "791-radiant-sun": [ - 0, - 1, - 1 - ], - "791": [ - 2, - 1, - 1 - ], - "792-full-moon": [ - 0, - 1, - 1 - ], - "792": [ - 0, - 1, - 1 - ], - "793": [ - 0, - 1, - 1 - ], - "797": [ - 0, - 1, - 1 - ], - "798": [ - 0, - 1, - 1 - ], - "800-dawn-wings": [ - 0, - 1, - 1 - ], - "800-dusk-mane": [ - 0, - 1, - 1 - ], - "800-ultra": [ - 0, - 1, - 1 - ], - "800": [ - 0, - 1, - 1 - ], - "802": [ - 1, - 1, - 1 - ], - "803": [ - 0, - 1, - 1 - ], - "804": [ - 0, - 1, - 1 - ], - "808": [ - 0, - 1, - 1 - ], - "809-gigantamax": [ - 0, - 1, - 1 - ], - "809": [ - 0, - 1, - 1 - ], - "816": [ - 0, - 1, - 1 - ], - "817": [ - 0, - 1, - 1 - ], - "818-gigantamax": [ - 1, - 1, - 1 - ], - "818": [ - 0, - 1, - 1 - ], - "821": [ - 0, - 1, - 1 - ], - "822": [ - 0, - 1, - 1 - ], - "823-gigantamax": [ - 0, - 2, - 2 - ], - "823": [ - 0, - 1, - 1 - ], - "829": [ - 0, - 1, - 1 - ], - "830": [ - 0, - 1, - 1 - ], - "835": [ - 0, - 1, - 1 - ], - "836": [ - 0, - 2, - 2 - ], - "850": [ - 0, - 1, - 1 - ], - "851-gigantamax": [ - 0, - 1, - 1 - ], - "851": [ - 0, - 1, - 1 - ], - "854": [ - 0, - 1, - 1 - ], - "855": [ - 0, - 1, - 1 - ], - "856": [ - 0, - 1, - 1 - ], - "857": [ - 0, - 2, - 2 - ], - "858-gigantamax": [ - 0, - 1, - 1 - ], - "858": [ - 0, - 1, - 1 - ], - "859": [ - 0, - 2, - 2 - ], - "860": [ - 0, - 1, - 1 - ], - "861-gigantamax": [ - 0, - 1, - 1 - ], - "861": [ - 0, - 1, - 1 - ], - "862": [ - 0, - 1, - 1 - ], - "863": [ - 0, - 1, - 1 - ], - "864": [ - 0, - 1, - 1 - ], - "867": [ - 0, - 1, - 1 - ], - "872": [ - 1, - 1, - 1 - ], - "873": [ - 1, - 1, - 1 - ], - "876-female": [ - 0, - 1, - 1 - ], - "876": [ - 0, - 1, - 1 - ], - "877-hangry": [ - 1, - 1, - 1 - ], - "877": [ - 1, - 1, - 1 - ], - "880": [ - 0, - 1, - 1 - ], - "881": [ - 0, - 1, - 1 - ], - "882": [ - 0, - 1, - 1 - ], - "883": [ - 0, - 1, - 1 - ], - "884-gigantamax": [ - 0, - 1, - 1 - ], - "884": [ - 0, - 1, - 1 - ], - "885": [ - 1, - 1, - 1 - ], - "886": [ - 1, - 1, - 1 - ], - "887": [ - 2, - 1, - 1 - ], - "888": [ - 0, - 1, - 1 - ], - "888-crowned": [ - 0, - 1, - 1 - ], - "889": [ - 0, - 1, - 1 - ], - "889-crowned": [ - 0, - 1, - 1 - ], - "890-eternamax": [ - 0, - 1, - 1 - ], - "890": [ - 0, - 1, - 1 - ], - "891": [ - 1, - 1, - 1 - ], - "892-gigantamax-rapid": [ - 1, - 2, - 2 - ], - "892-rapid-strike": [ - 1, - 1, - 1 - ], - "892": [ - 1, - 1, - 1 - ], - "892-gigantamax-single": [ - 1, - 2, - 2 - ], - "896": [ - 1, - 1, - 1 - ], - "897": [ - 2, - 1, - 1 - ], - "898": [ - 1, - 1, - 1 - ], - "898-ice": [ - 1, - 1, - 1 - ], - "898-shadow": [ - 1, - 1, - 1 - ], - "900": [ - 0, - 1, - 1 - ], - "901": [ - 0, - 1, - 2 - ], - "903": [ - 0, - 1, - 1 - ], - "909": [ - 0, - 2, - 2 - ], - "910": [ - 0, - 2, - 2 - ], - "911": [ - 0, - 1, - 1 - ], - "912": [ - 0, - 1, - 1 - ], - "913": [ - 0, - 2, - 2 - ], - "914": [ - 0, - 2, - 1 - ], - "919": [ - 1, - 1, - 1 - ], - "920": [ - 2, - 2, - 2 - ], - "924": [ - 1, - 1, - 1 - ], - "925-four": [ - 1, - 1, - 1 - ], - "925-three": [ - 1, - 1, - 1 - ], - "932": [ - 0, - 1, - 2 - ], - "933": [ - 0, - 1, - 1 - ], - "934": [ - 0, - 1, - 1 - ], - "935": [ - 2, - 2, - 2 - ], - "936": [ - 2, - 2, - 2 - ], - "937": [ - 2, - 2, - 2 - ], - "940": [ - 0, - 1, - 1 - ], - "941": [ - 0, - 1, - 1 - ], - "948": [ - 0, - 1, - 1 - ], - "949": [ - 0, - 1, - 1 - ], - "951": [ - 0, - 1, - 1 - ], - "952": [ - 0, - 1, - 1 - ], - "953": [ - 0, - 1, - 1 - ], - "954": [ - 0, - 1, - 1 - ], - "957": [ - 1, - 2, - 2 - ], - "958": [ - 2, - 2, - 1 - ], - "959": [ - 2, - 2, - 2 - ], - "962": [ - 1, - 1, - 1 - ], - "967": [ - 0, - 1, - 1 - ], - "968": [ - 0, - 2, - 2 - ], - "969": [ - 0, - 1, - 1 - ], - "970": [ - 0, - 1, - 1 - ], - "973": [ - 2, - 2, - 2 - ], - "974": [ - 0, - 1, - 1 - ], - "975": [ - 0, - 2, - 2 - ], - "978-curly": [ - 0, - 2, - 2 - ], - "978-droopy": [ - 0, - 2, - 2 - ], - "978-stretchy": [ - 0, - 2, - 2 - ], - "979": [ - 2, - 2, - 2 - ], - "981": [ - 0, - 1, - 1 - ], - "982": [ - 0, - 1, - 1 - ], - "982-three-segment": [ - 0, - 1, - 1 - ], - "987": [ - 1, - 1, - 1 - ], - "988": [ - 0, - 1, - 2 - ], - "993": [ - 0, - 1, - 1 - ], - "994": [ - 0, - 1, - 1 - ], - "995": [ - 0, - 1, - 1 - ], - "996": [ - 0, - 1, - 1 - ], - "997": [ - 0, - 1, - 1 - ], - "998": [ - 0, - 1, - 1 - ], - "999": [ - 1, - 1, - 1 - ], - "1000": [ - 1, - 1, - 1 - ], - "1001": [ - 0, - 1, - 1 - ], - "1003": [ - 0, - 1, - 1 - ], - "1004": [ - 0, - 1, - 1 - ], - "1006": [ - 0, - 2, - 1 - ], - "1007-apex-build": [ - 0, - 2, - 2 - ], - "1008-ultimate-mode": [ - 1, - 1, - 1 - ], - "1010": [ - 0, - 1, - 1 - ], - "1018": [ - 0, - 1, - 1 - ], - "1022": [ - 0, - 1, - 1 - ], - "1023": [ - 0, - 1, - 1 - ], - "2027": [ - 0, - 1, - 1 - ], - "2028": [ - 0, - 1, - 1 - ], - "2052": [ - 0, - 1, - 1 - ], - "2053": [ - 0, - 1, - 1 - ], - "2670": [ - 0, - 1, - 1 - ], - "4052": [ - 0, - 1, - 1 - ], - "4077": [ - 0, - 1, - 1 - ], - "4078": [ - 0, - 1, - 1 - ], - "4079": [ - 0, - 1, - 1 - ], - "4080": [ - 2, - 1, - 1 - ], - "4144": [ - 0, - 2, - 2 - ], - "4145": [ - 0, - 2, - 2 - ], - "4146": [ - 0, - 2, - 2 - ], - "4199": [ - 2, - 1, - 1 - ], - "4222": [ - 0, - 1, - 1 - ], - "4263": [ - 0, - 1, - 1 - ], - "4264": [ - 0, - 1, - 1 - ], - "4562": [ - 0, - 1, - 1 - ], - "6100": [ - 0, - 1, - 1 - ], - "6101": [ - 0, - 1, - 1 - ], - "6215": [ - 0, - 1, - 1 - ], - "6549": [ - 0, - 1, - 1 - ], - "6570": [ - 0, - 1, - 1 - ], - "6571": [ - 0, - 1, - 1 - ], - "6705": [ - 0, - 1, - 1 - ], - "6706": [ - 0, - 2, - 2 - ], - "6713": [ - 0, - 1, - 1 - ], - "8901": [ - 1, - 1, - 1 - ], + "1": [0, 1, 1], + "2": [0, 2, 1], + "3-gigantamax": [0, 1, 1], + "3-mega": [0, 2, 2], + "3": [0, 1, 1], + "4": [0, 1, 1], + "5": [0, 1, 1], + "6-mega-x": [0, 1, 2], + "6-gigantamax": [0, 1, 2], + "6-mega-y": [0, 1, 2], + "6": [0, 2, 2], + "7": [0, 2, 2], + "8": [0, 2, 2], + "9-gigantamax": [0, 1, 2], + "9-mega": [0, 2, 2], + "9": [0, 2, 2], + "19": [0, 1, 1], + "20": [0, 1, 1], + "23": [0, 1, 1], + "24": [0, 1, 1], + "25": [0, 1, 1], + "25-beauty-cosplay": [0, 1, 1], + "25-cool-cosplay": [0, 1, 1], + "25-cosplay": [0, 1, 1], + "25-cute-cosplay": [0, 1, 1], + "25-gigantamax": [0, 1, 1], + "25-partner": [0, 1, 1], + "25-smart-cosplay": [0, 1, 1], + "25-tough-cosplay": [0, 1, 1], + "26": [0, 1, 1], + "29": [0, 1, 1], + "30": [0, 1, 1], + "31": [1, 1, 1], + "35": [0, 1, 2], + "36": [0, 1, 1], + "37": [0, 1, 1], + "38": [0, 1, 1], + "39": [0, 1, 1], + "40": [0, 1, 1], + "41": [0, 1, 1], + "42": [0, 1, 1], + "43": [0, 1, 1], + "44": [0, 1, 1], + "45": [0, 1, 1], + "46": [1, 1, 1], + "47": [1, 1, 1], + "50": [0, 1, 1], + "51": [0, 1, 1], + "52-gigantamax": [1, 1, 1], + "52": [1, 1, 1], + "53": [1, 1, 1], + "56": [1, 2, 2], + "57": [2, 2, 2], + "69": [0, 2, 2], + "70": [0, 1, 1], + "71": [0, 1, 1], + "77": [0, 1, 1], + "78": [0, 1, 1], + "79": [1, 1, 1], + "80": [0, 1, 1], + "80-mega": [0, 1, 1], + "81": [0, 1, 1], + "82": [0, 1, 1], + "83": [0, 2, 2], + "84": [1, 1, 1], + "85": [1, 1, 1], + "86": [1, 1, 1], + "87": [1, 1, 1], + "92": [2, 2, 2], + "93": [1, 1, 1], + "94-gigantamax": [1, 2, 2], + "94-mega": [2, 2, 2], + "94": [1, 1, 1], + "98": [0, 1, 1], + "99": [0, 1, 1], + "99-gigantamax": [0, 1, 1], + "100": [0, 1, 1], + "101": [0, 1, 1], + "102": [0, 1, 1], + "103": [0, 1, 1], + "111": [0, 1, 1], + "112": [0, 1, 1], + "113": [2, 2, 2], + "114": [0, 1, 1], + "116": [0, 1, 1], + "117": [0, 1, 1], + "118": [1, 1, 1], + "119": [1, 1, 1], + "120": [0, 1, 1], + "121": [0, 1, 1], + "123": [1, 1, 1], + "125": [1, 1, 2], + "126": [0, 2, 1], + "127-mega": [0, 1, 1], + "127": [0, 1, 1], + "128": [0, 1, 1], + "129": [0, 1, 1], + "130-mega": [0, 1, 1], + "130": [0, 1, 1], + "131-gigantamax": [0, 1, 1], + "131": [0, 1, 1], + "132": [0, 1, 1], + "133": [0, 1, 1], + "133-partner": [0, 1, 1], + "134": [0, 1, 1], + "135": [1, 1, 1], + "136": [1, 1, 1], + "137": [0, 1, 1], + "138": [0, 1, 1], + "139": [0, 1, 2], + "140": [0, 1, 1], + "141": [0, 2, 2], + "142-mega": [0, 1, 1], + "142": [0, 1, 1], + "144": [1, 2, 2], + "145": [1, 1, 1], + "146": [1, 1, 1], + "147": [0, 1, 1], + "148": [0, 1, 1], + "149": [0, 1, 1], + "150-mega-x": [0, 1, 1], + "150-mega-y": [0, 1, 1], + "150": [0, 1, 1], + "151": [0, 1, 1], + "152": [0, 1, 1], + "153": [0, 1, 1], + "154": [0, 1, 1], + "158": [0, 1, 1], + "159": [0, 1, 1], + "160": [0, 1, 1], + "161": [0, 1, 2], + "162": [0, 1, 1], + "163": [0, 1, 1], + "164": [0, 2, 2], + "167": [0, 1, 1], + "168": [0, 1, 1], + "169": [0, 1, 1], + "170": [0, 1, 1], + "171": [0, 1, 1], + "172": [0, 1, 1], + "172-spiky": [0, 1, 1], + "173": [0, 1, 2], + "174": [0, 1, 1], + "175": [1, 1, 1], + "176": [1, 1, 1], + "177": [0, 1, 1], + "178": [0, 2, 2], + "179": [0, 1, 1], + "180": [0, 2, 2], + "181-mega": [0, 1, 2], + "181": [0, 1, 1], + "182": [0, 1, 1], + "183": [0, 1, 2], + "184": [0, 2, 2], + "185": [0, 1, 1], + "190": [0, 1, 1], + "193": [0, 1, 1], + "194": [0, 1, 1], + "195": [0, 1, 1], + "196": [1, 1, 1], + "197": [0, 1, 1], + "198": [0, 1, 1], + "199": [2, 1, 1], + "200": [1, 1, 1], + "201-m": [0, 1, 1], + "201-question": [0, 1, 1], + "201-j": [0, 1, 1], + "201-l": [0, 1, 1], + "201-h": [0, 1, 1], + "201-x": [0, 1, 1], + "201-exclamation": [0, 1, 1], + "201-q": [0, 1, 1], + "201-s": [0, 1, 1], + "201-c": [0, 1, 1], + "201-u": [0, 1, 1], + "201-t": [0, 1, 1], + "201-z": [0, 1, 1], + "201-d": [0, 1, 1], + "201-b": [0, 1, 1], + "201-g": [0, 1, 1], + "201-k": [0, 1, 1], + "201-i": [0, 1, 1], + "201-p": [0, 1, 1], + "201-e": [0, 1, 1], + "201-y": [0, 1, 1], + "201-r": [0, 1, 1], + "201-f": [0, 1, 1], + "201-n": [0, 1, 1], + "201-v": [0, 1, 1], + "201-a": [0, 1, 1], + "201-w": [0, 1, 1], + "201-o": [0, 1, 1], + "203": [0, 1, 1], + "206": [0, 1, 1], + "207": [0, 1, 1], + "211": [0, 1, 1], + "212-mega": [1, 1, 1], + "212": [1, 1, 1], + "213": [0, 1, 1], + "215": [0, 1, 1], + "216": [1, 1, 1], + "217": [1, 1, 1], + "222": [0, 1, 1], + "226": [0, 2, 2], + "227": [0, 1, 1], + "228": [0, 1, 1], + "229": [0, 1, 1], + "229-mega": [0, 1, 1], + "230": [0, 1, 1], + "231": [0, 1, 1], + "232": [0, 1, 1], + "233": [0, 1, 1], + "235": [0, 1, 1], + "239": [1, 1, 2], + "240": [0, 1, 1], + "242": [2, 2, 2], + "243": [0, 1, 1], + "244": [0, 2, 2], + "245": [0, 1, 1], + "246": [0, 1, 1], + "247": [0, 1, 1], + "248": [0, 1, 1], + "248-mega": [0, 2, 1], + "249": [0, 2, 2], + "250": [0, 2, 2], + "251": [0, 1, 1], + "255": [0, 1, 1], + "256": [0, 1, 1], + "257": [0, 1, 2], + "257-mega": [0, 1, 1], + "261": [0, 1, 1], + "262": [0, 1, 1], + "263": [0, 1, 1], + "264": [0, 1, 1], + "276": [0, 1, 1], + "277": [0, 1, 1], + "278": [1, 1, 1], + "279": [1, 1, 1], + "280": [0, 1, 1], + "281": [0, 1, 1], + "282-mega": [0, 2, 2], + "282": [0, 1, 1], + "285": [0, 1, 1], + "286": [0, 1, 1], + "290": [1, 1, 1], + "291": [2, 2, 2], + "292": [2, 1, 2], + "298": [0, 2, 2], + "300": [1, 1, 1], + "301": [1, 1, 1], + "302": [0, 1, 1], + "302-mega": [0, 1, 1], + "303-mega": [1, 1, 1], + "303": [0, 1, 1], + "304": [1, 1, 1], + "305": [1, 1, 1], + "306-mega": [1, 1, 1], + "306": [1, 1, 1], + "307": [0, 1, 1], + "308-mega": [0, 1, 1], + "308": [0, 2, 1], + "309": [0, 1, 1], + "310-mega": [0, 1, 1], + "310": [0, 1, 1], + "311": [1, 1, 1], + "312": [0, 1, 1], + "315": [0, 1, 1], + "320": [0, 1, 1], + "321": [0, 1, 1], + "327": [0, 1, 1], + "328": [0, 1, 1], + "329": [0, 1, 2], + "330": [0, 1, 1], + "333": [0, 1, 1], + "334-mega": [0, 2, 1], + "334": [0, 2, 2], + "335": [0, 2, 2], + "336": [0, 1, 1], + "337": [0, 1, 1], + "338": [0, 1, 1], + "339": [0, 1, 1], + "340": [0, 1, 2], + "341": [0, 2, 2], + "342": [0, 2, 2], + "351-rainy": [1, 2, 2], + "351-snowy": [1, 1, 1], + "351-sunny": [1, 2, 2], + "351": [0, 2, 2], + "352": [1, 1, 1], + "353": [0, 1, 1], + "354": [0, 1, 1], + "354-mega": [0, 1, 1], + "357": [0, 1, 1], + "358": [2, 1, 1], + "359": [0, 1, 1], + "359-mega": [0, 1, 1], + "361": [0, 1, 1], + "362": [0, 2, 2], + "362-mega": [0, 1, 1], + "369": [0, 1, 1], + "370": [0, 1, 1], + "371": [0, 1, 1], + "372": [0, 1, 1], + "373-mega": [0, 2, 2], + "373": [0, 1, 1], + "374": [0, 1, 1], + "375": [0, 1, 1], + "376-mega": [0, 1, 1], + "376": [0, 1, 1], + "377": [0, 1, 1], + "378": [1, 1, 1], + "379": [0, 1, 1], + "380-mega": [0, 1, 1], + "380": [0, 1, 1], + "381-mega": [0, 1, 1], + "381": [0, 1, 1], + "382-primal": [0, 1, 1], + "382": [0, 1, 1], + "383-primal": [0, 1, 1], + "383": [0, 1, 1], + "384-mega": [0, 2, 1], + "384": [0, 1, 1], + "385": [1, 1, 1], + "387": [0, 1, 1], + "388": [0, 1, 1], + "389": [0, 1, 1], + "390": [0, 1, 1], + "391": [0, 1, 1], + "392": [0, 1, 1], + "393": [0, 1, 1], + "394": [0, 1, 1], + "395": [0, 1, 1], + "399": [0, 1, 1], + "400": [0, 1, 1], + "401": [0, 1, 1], + "402": [0, 1, 1], + "406": [0, 1, 1], + "407": [0, 1, 1], + "412-sandy": [2, 2, 2], + "412-plant": [1, 1, 1], + "412-trash": [1, 1, 1], + "413-plant": [2, 2, 2], + "413-trash": [1, 1, 1], + "413-sandy": [1, 1, 1], + "414": [0, 1, 1], + "418": [0, 1, 1], + "419": [0, 1, 1], + "422-west": [1, 1, 1], + "422-east": [1, 1, 1], + "423-west": [1, 1, 1], + "423-east": [1, 1, 1], + "424": [0, 1, 1], + "425": [0, 1, 1], + "426": [0, 1, 1], + "427": [0, 1, 1], + "428-mega": [0, 1, 1], + "428": [0, 1, 1], + "429": [1, 1, 1], + "430": [0, 1, 1], + "433": [1, 1, 1], + "436": [0, 1, 1], + "437": [0, 1, 1], + "438": [0, 1, 1], + "440": [1, 1, 2], + "441": [0, 1, 1], + "442": [0, 1, 1], + "443": [1, 1, 1], + "444": [1, 1, 1], + "445-mega": [1, 1, 1], + "445": [1, 1, 1], + "447": [1, 1, 1], + "448-mega": [1, 1, 1], + "448": [1, 1, 1], + "453": [0, 1, 1], + "454": [0, 1, 1], + "455": [0, 1, 1], + "456": [0, 1, 1], + "457": [0, 1, 1], + "458": [0, 1, 1], + "461": [0, 1, 1], + "462": [0, 1, 1], + "464": [0, 1, 1], + "465": [0, 1, 1], + "466": [1, 1, 2], + "467": [0, 1, 1], + "468": [1, 1, 1], + "469": [0, 1, 1], + "470": [1, 1, 1], + "471": [1, 2, 2], + "472": [0, 1, 1], + "474": [0, 1, 1], + "475-mega": [0, 2, 2], + "475": [0, 1, 1], + "478": [0, 2, 1], + "479-heat": [0, 1, 1], + "479-wash": [0, 1, 1], + "479-mow": [0, 1, 1], + "479-frost": [0, 1, 1], + "479": [0, 1, 1], + "479-fan": [0, 1, 1], + "480": [1, 1, 1], + "481": [1, 1, 1], + "482": [1, 1, 1], + "485": [0, 1, 1], + "486": [0, 1, 1], + "487-altered": [0, 1, 1], + "487-origin": [0, 1, 1], + "488": [0, 1, 1], + "489": [1, 1, 1], + "490": [1, 1, 1], + "491": [0, 1, 1], + "492-land": [0, 2, 1], + "492-sky": [0, 1, 1], + "494": [0, 1, 1], + "495": [0, 1, 1], + "496": [0, 1, 1], + "497": [0, 1, 1], + "501": [0, 1, 1], + "502": [0, 1, 1], + "503": [0, 1, 1], + "517": [0, 1, 1], + "518": [0, 1, 1], + "524": [0, 1, 1], + "525": [0, 1, 1], + "526": [0, 2, 2], + "527": [0, 1, 1], + "528": [0, 1, 1], + "529": [0, 2, 2], + "530": [0, 2, 2], + "531": [0, 1, 1], + "531-mega": [0, 1, 1], + "532": [0, 1, 1], + "533": [0, 1, 1], + "534": [0, 1, 1], + "538": [0, 1, 1], + "539": [0, 2, 2], + "540": [0, 1, 1], + "541": [0, 1, 1], + "542": [0, 1, 1], + "543": [0, 1, 2], + "544": [0, 1, 2], + "545": [0, 1, 1], + "546": [0, 1, 1], + "547": [0, 1, 1], + "548": [1, 1, 1], + "549": [0, 1, 2], + "551": [0, 1, 1], + "552": [0, 1, 1], + "553": [0, 1, 1], + "556": [0, 1, 1], + "559": [1, 1, 1], + "560": [1, 1, 1], + "562": [0, 1, 1], + "563": [0, 1, 1], + "568": [0, 2, 2], + "569-gigantamax": [0, 1, 1], + "569": [0, 1, 1], + "570": [0, 1, 1], + "571": [0, 1, 1], + "572": [0, 1, 1], + "577": [1, 1, 1], + "578": [1, 1, 1], + "579": [1, 1, 1], + "585-autumn": [2, 0, 0], + "585-spring": [2, 0, 0], + "585-summer": [2, 0, 0], + "585-winter": [2, 0, 0], + "586-autumn": [1, 0, 0], + "586-spring": [1, 0, 0], + "586-summer": [1, 0, 0], + "586-winter": [1, 0, 0], + "587": [0, 1, 1], + "588": [0, 1, 1], + "589": [0, 1, 1], + "590": [0, 1, 1], + "591": [0, 1, 1], + "592": [0, 1, 2], + "593": [0, 1, 1], + "594": [0, 1, 2], + "595": [0, 1, 1], + "596": [0, 1, 1], + "602": [0, 1, 1], + "603": [0, 1, 1], + "604": [0, 1, 1], + "605": [1, 1, 1], + "606": [1, 1, 1], + "607": [0, 1, 1], + "608": [0, 1, 1], + "609": [0, 1, 1], + "610": [0, 1, 1], + "611": [0, 1, 1], + "612": [0, 1, 2], + "616": [0, 1, 1], + "617": [0, 1, 1], + "618": [0, 1, 1], + "619": [0, 1, 1], + "620": [0, 1, 1], + "621": [0, 1, 1], + "622": [0, 1, 1], + "623": [0, 1, 1], + "631": [0, 2, 2], + "632": [0, 1, 1], + "633": [0, 1, 1], + "634": [0, 1, 1], + "635": [0, 1, 1], + "636": [0, 1, 1], + "637": [0, 1, 1], + "640": [0, 1, 1], + "647-resolute": [0, 1, 1], + "647-ordinary": [0, 1, 1], + "648-aria": [0, 1, 1], + "648-pirouette": [0, 1, 1], + "649-burn": [0, 1, 1], + "649-chill": [0, 1, 1], + "649-douse": [0, 1, 1], + "649-shock": [0, 1, 1], + "649": [0, 1, 1], + "653": [0, 1, 1], + "654": [0, 1, 1], + "655": [0, 1, 1], + "656": [0, 1, 1], + "657": [0, 1, 1], + "658": [0, 1, 1], + "658-ash": [0, 1, 1], + "664": [0, 1, 1], + "665": [0, 1, 1], + "666-archipelago": [0, 1, 1], + "666-continental": [0, 1, 2], + "666-elegant": [0, 1, 1], + "666-fancy": [0, 2, 2], + "666-garden": [0, 1, 1], + "666-high-plains": [0, 1, 1], + "666-icy-snow": [0, 1, 1], + "666-jungle": [0, 1, 1], + "666-marine": [0, 1, 1], + "666-meadow": [0, 1, 1], + "666-modern": [0, 1, 1], + "666-monsoon": [0, 1, 1], + "666-ocean": [0, 1, 1], + "666-poke-ball": [0, 1, 2], + "666-polar": [0, 1, 1], + "666-river": [0, 2, 1], + "666-sandstorm": [0, 1, 1], + "666-savanna": [0, 1, 1], + "666-sun": [0, 1, 1], + "666-tundra": [0, 1, 1], + "669-red": [0, 2, 1], + "669-blue": [0, 2, 2], + "669-white": [0, 1, 1], + "669-yellow": [0, 2, 1], + "669-orange": [0, 2, 1], + "670-white": [0, 2, 2], + "670-blue": [0, 2, 2], + "670-orange": [0, 2, 2], + "670-red": [0, 2, 2], + "670-yellow": [0, 2, 2], + "671-red": [0, 1, 2], + "671-blue": [0, 1, 2], + "671-yellow": [0, 1, 2], + "671-white": [0, 1, 2], + "671-orange": [0, 1, 1], + "672": [0, 1, 2], + "673": [0, 1, 1], + "676": [0, 1, 1], + "676-dandy": [0, 1, 1], + "676-debutante": [0, 1, 1], + "676-diamond": [0, 1, 1], + "676-heart": [0, 1, 1], + "676-kabuki": [0, 1, 1], + "676-la-reine": [0, 1, 1], + "676-matron": [0, 1, 1], + "676-pharaoh": [0, 1, 1], + "676-star": [0, 1, 1], + "677": [0, 1, 1], + "678-female": [0, 1, 1], + "678": [0, 1, 1], + "682": [0, 1, 1], + "683": [0, 1, 1], + "684": [0, 1, 1], + "685": [0, 1, 1], + "688": [0, 1, 1], + "689": [0, 1, 1], + "690": [0, 1, 1], + "691": [0, 1, 1], + "696": [0, 1, 1], + "697": [0, 1, 1], + "698": [0, 1, 1], + "699": [0, 1, 1], + "700": [0, 1, 1], + "702": [0, 1, 1], + "703": [0, 1, 1], + "704": [0, 1, 1], + "705": [0, 1, 1], + "706": [0, 1, 1], + "708": [0, 1, 1], + "709": [0, 1, 1], + "710": [0, 1, 1], + "711": [1, 1, 1], + "712": [0, 1, 1], + "713": [0, 1, 1], + "714": [0, 1, 1], + "715": [0, 2, 2], + "716-active": [0, 1, 1], + "716-neutral": [0, 1, 1], + "717": [0, 1, 1], + "720-unbound": [1, 1, 1], + "720": [1, 1, 1], + "728": [0, 1, 1], + "729": [0, 1, 1], + "730": [0, 1, 1], + "734": [0, 1, 1], + "735": [0, 1, 1], + "742": [0, 2, 2], + "743": [0, 2, 2], + "747": [0, 1, 1], + "748": [0, 1, 1], + "751": [0, 1, 1], + "752": [0, 1, 1], + "753": [0, 1, 1], + "754": [0, 1, 1], + "755": [0, 1, 1], + "756": [0, 1, 2], + "761": [0, 1, 1], + "762": [0, 1, 1], + "763": [0, 1, 1], + "767": [0, 1, 1], + "768": [0, 1, 1], + "771": [0, 1, 1], + "772": [0, 1, 1], + "773-fighting": [0, 1, 1], + "773-psychic": [0, 1, 1], + "773-poison": [0, 1, 1], + "773-ground": [0, 1, 1], + "773-ghost": [0, 1, 1], + "773-steel": [0, 1, 1], + "773-rock": [0, 1, 1], + "773-grass": [0, 1, 1], + "773-dragon": [0, 1, 1], + "773-bug": [0, 1, 1], + "773-ice": [0, 1, 1], + "773-dark": [0, 1, 1], + "773": [0, 1, 1], + "773-fairy": [0, 1, 1], + "773-water": [0, 1, 1], + "773-electric": [0, 1, 1], + "773-flying": [0, 1, 1], + "773-fire": [0, 1, 1], + "776": [0, 1, 1], + "777": [0, 1, 1], + "778-busted": [0, 1, 1], + "778-disguised": [0, 1, 1], + "779": [0, 1, 1], + "789": [1, 1, 1], + "790": [0, 1, 1], + "791-radiant-sun": [0, 1, 1], + "791": [2, 1, 1], + "792-full-moon": [0, 1, 1], + "792": [0, 1, 1], + "793": [0, 1, 1], + "797": [0, 1, 1], + "798": [0, 1, 1], + "800-dawn-wings": [0, 1, 1], + "800-dusk-mane": [0, 1, 1], + "800-ultra": [0, 1, 1], + "800": [0, 1, 1], + "802": [1, 1, 1], + "803": [0, 1, 1], + "804": [0, 1, 1], + "807": [0, 1, 1], + "808": [0, 1, 1], + "809-gigantamax": [0, 1, 1], + "809": [0, 1, 1], + "816": [0, 1, 1], + "817": [0, 1, 1], + "818-gigantamax": [1, 1, 1], + "818": [0, 1, 1], + "821": [0, 1, 1], + "822": [0, 1, 1], + "823-gigantamax": [0, 2, 2], + "823": [0, 1, 1], + "829": [0, 1, 1], + "830": [0, 1, 1], + "835": [0, 1, 1], + "836": [0, 2, 2], + "850": [0, 1, 1], + "851-gigantamax": [0, 1, 1], + "851": [0, 1, 1], + "854": [0, 1, 1], + "855": [0, 1, 1], + "856": [0, 1, 1], + "857": [0, 2, 2], + "858-gigantamax": [0, 1, 1], + "858": [0, 1, 1], + "859": [0, 2, 2], + "860": [0, 1, 1], + "861-gigantamax": [0, 1, 1], + "861": [0, 1, 1], + "862": [0, 1, 1], + "863": [0, 1, 1], + "864": [0, 1, 1], + "867": [0, 1, 1], + "872": [1, 1, 1], + "873": [1, 1, 1], + "876-female": [0, 1, 1], + "876": [0, 1, 1], + "877-hangry": [1, 1, 1], + "877": [1, 1, 1], + "880": [0, 1, 1], + "881": [0, 1, 1], + "882": [0, 1, 1], + "883": [0, 1, 1], + "884-gigantamax": [0, 1, 1], + "884": [0, 1, 1], + "885": [1, 1, 1], + "886": [1, 1, 1], + "887": [2, 1, 1], + "888": [0, 1, 1], + "888-crowned": [0, 1, 1], + "889": [0, 1, 1], + "889-crowned": [0, 1, 1], + "890-eternamax": [0, 1, 1], + "890": [0, 1, 1], + "891": [1, 1, 1], + "892-gigantamax-rapid": [1, 2, 2], + "892-rapid-strike": [1, 1, 1], + "892": [1, 1, 1], + "892-gigantamax-single": [1, 2, 2], + "894": [0, 1, 1], + "895": [0, 1, 1], + "896": [1, 1, 1], + "897": [2, 1, 1], + "898": [1, 1, 1], + "898-ice": [1, 1, 1], + "898-shadow": [1, 1, 1], + "900": [0, 1, 1], + "901": [0, 1, 2], + "903": [0, 1, 1], + "909": [0, 2, 2], + "910": [0, 2, 2], + "911": [0, 1, 1], + "912": [0, 1, 1], + "913": [0, 2, 2], + "914": [0, 2, 1], + "919": [1, 1, 1], + "920": [2, 2, 2], + "924": [1, 1, 1], + "925-four": [1, 1, 1], + "925-three": [1, 1, 1], + "932": [0, 1, 2], + "933": [0, 1, 1], + "934": [0, 1, 1], + "935": [2, 2, 2], + "936": [2, 2, 2], + "937": [2, 2, 2], + "940": [0, 1, 1], + "941": [0, 1, 1], + "944": [0, 1, 1], + "945": [0, 1, 1], + "948": [0, 1, 1], + "949": [0, 1, 1], + "951": [0, 1, 1], + "952": [0, 1, 1], + "953": [0, 1, 1], + "954": [0, 1, 1], + "957": [1, 2, 2], + "958": [2, 2, 1], + "959": [2, 2, 2], + "962": [1, 1, 1], + "967": [0, 1, 1], + "968": [0, 2, 2], + "969": [0, 1, 1], + "970": [0, 1, 1], + "973": [2, 2, 2], + "974": [0, 1, 1], + "975": [0, 2, 2], + "978-curly": [0, 2, 2], + "978-droopy": [0, 2, 2], + "978-stretchy": [0, 2, 2], + "979": [2, 2, 2], + "981": [0, 1, 1], + "982": [0, 1, 1], + "982-three-segment": [0, 1, 1], + "987": [1, 1, 1], + "988": [0, 1, 2], + "993": [0, 1, 1], + "994": [0, 1, 1], + "995": [0, 1, 1], + "996": [0, 1, 1], + "997": [0, 1, 1], + "998": [0, 1, 1], + "999": [1, 1, 1], + "1000": [1, 1, 1], + "1001": [0, 1, 1], + "1003": [0, 1, 1], + "1004": [0, 1, 1], + "1006": [0, 2, 1], + "1007-apex-build": [0, 2, 2], + "1008-ultimate-mode": [1, 1, 1], + "1010": [0, 1, 1], + "1012-counterfeit": [0, 1, 1], + "1013-unremarkable": [0, 1, 1], + "1018": [0, 1, 1], + "1022": [0, 1, 1], + "1023": [0, 1, 1], + "2026": [0, 1, 1], + "2027": [0, 1, 1], + "2028": [0, 1, 1], + "2052": [0, 1, 1], + "2053": [0, 1, 1], + "2103": [0, 1, 1], + "2670": [0, 1, 1], + "4052": [0, 1, 1], + "4077": [0, 1, 1], + "4078": [0, 1, 1], + "4079": [0, 1, 1], + "4080": [2, 1, 1], + "4144": [0, 1, 1], + "4145": [0, 1, 1], + "4146": [0, 1, 1], + "4199": [2, 1, 1], + "4222": [0, 1, 1], + "4263": [0, 1, 1], + "4264": [0, 1, 1], + "4562": [0, 1, 1], + "6100": [0, 1, 1], + "6101": [0, 1, 1], + "6215": [0, 1, 1], + "6503": [0, 1, 1], + "6549": [0, 1, 1], + "6570": [0, 1, 1], + "6571": [0, 1, 1], + "6705": [0, 1, 1], + "6706": [0, 1, 1], + "6713": [0, 1, 1], + "8901": [1, 1, 1], "female": { - "3": [ - 0, - 2, - 1 - ], - "19": [ - 0, - 1, - 1 - ], - "20": [ - 0, - 1, - 1 - ], - "41": [ - 0, - 1, - 1 - ], - "42": [ - 0, - 1, - 1 - ], - "44": [ - 0, - 1, - 1 - ], - "45": [ - 0, - 1, - 1 - ], - "84": [ - 1, - 1, - 1 - ], - "85": [ - 1, - 1, - 1 - ], - "111": [ - 0, - 1, - 1 - ], - "112": [ - 0, - 1, - 1 - ], - "118": [ - 0, - 1, - 1 - ], - "119": [ - 0, - 1, - 1 - ], - "123": [ - 1, - 1, - 1 - ], - "129": [ - 0, - 1, - 1 - ], - "130": [ - 0, - 1, - 1 - ], - "178": [ - 0, - 2, - 2 - ], - "185": [ - 0, - 1, - 1 - ], - "190": [ - 0, - 1, - 1 - ], - "203": [ - 0, - 1, - 1 - ], - "207": [ - 0, - 1, - 1 - ], - "215": [ - 0, - 1, - 1 - ], - "217": [ - 1, - 1, - 1 - ], - "229": [ - 0, - 1, - 1 - ], - "232": [ - 0, - 1, - 1 - ], - "255": [ - 0, - 1, - 1 - ], - "256": [ - 0, - 1, - 1 - ], - "257": [ - 0, - 1, - 1 - ], - "307": [ - 0, - 1, - 1 - ], - "308": [ - 0, - 1, - 1 - ], - "315": [ - 0, - 1, - 1 - ], - "369": [ - 0, - 1, - 1 - ], - "399": [ - 0, - 1, - 1 - ], - "400": [ - 0, - 1, - 1 - ], - "401": [ - 0, - 1, - 1 - ], - "402": [ - 0, - 2, - 2 - ], - "407": [ - 0, - 1, - 1 - ], - "418": [ - 0, - 1, - 1 - ], - "419": [ - 0, - 2, - 1 - ], - "424": [ - 0, - 1, - 1 - ], - "443": [ - 1, - 1, - 1 - ], - "444": [ - 1, - 1, - 1 - ], - "445": [ - 1, - 1, - 1 - ], - "453": [ - 0, - 1, - 1 - ], - "454": [ - 0, - 1, - 1 - ], - "456": [ - 0, - 1, - 1 - ], - "457": [ - 0, - 1, - 1 - ], - "461": [ - 0, - 1, - 1 - ], - "464": [ - 0, - 1, - 1 - ], - "465": [ - 0, - 1, - 1 - ], - "592": [ - 1, - 1, - 1 - ], - "593": [ - 1, - 1, - 1 - ], - "6215": [ - 0, - 1, - 1 - ] + "3": [0, 2, 1], + "19": [0, 1, 1], + "20": [0, 1, 1], + "25": [0, 1, 1], + "25-beauty-cosplay": [0, 1, 1], + "25-cool-cosplay": [0, 1, 1], + "25-cosplay": [0, 1, 1], + "25-cute-cosplay": [0, 1, 1], + "25-partner": [0, 1, 1], + "25-smart-cosplay": [0, 1, 1], + "25-tough-cosplay": [0, 1, 1], + "26": [0, 1, 1], + "41": [0, 1, 1], + "42": [0, 1, 1], + "44": [0, 1, 1], + "45": [0, 1, 1], + "84": [1, 1, 1], + "85": [1, 1, 1], + "111": [0, 1, 1], + "112": [0, 1, 1], + "118": [0, 1, 1], + "119": [0, 1, 1], + "123": [1, 1, 1], + "129": [0, 1, 1], + "130": [0, 1, 1], + "154": [0, 1, 1], + "178": [0, 2, 2], + "185": [0, 1, 1], + "190": [0, 1, 1], + "194": [0, 1, 1], + "195": [0, 1, 1], + "198": [0, 1, 1], + "203": [0, 1, 1], + "207": [0, 1, 1], + "215": [0, 1, 1], + "217": [1, 1, 1], + "229": [0, 1, 1], + "232": [0, 1, 1], + "255": [0, 1, 1], + "256": [0, 1, 1], + "257": [0, 1, 1], + "307": [0, 1, 1], + "308": [0, 1, 1], + "315": [0, 1, 1], + "369": [0, 1, 1], + "399": [0, 1, 1], + "400": [0, 1, 1], + "401": [0, 1, 1], + "402": [0, 2, 2], + "407": [0, 1, 1], + "418": [0, 1, 1], + "419": [0, 2, 1], + "424": [0, 1, 1], + "443": [1, 1, 1], + "444": [1, 1, 1], + "445": [1, 1, 1], + "453": [0, 1, 1], + "454": [0, 1, 1], + "456": [0, 1, 1], + "457": [0, 1, 1], + "461": [0, 1, 1], + "464": [0, 1, 1], + "465": [0, 1, 1], + "592": [1, 1, 1], + "593": [1, 1, 1], + "6215": [0, 1, 1] }, "back": { - "1": [ - 0, - 1, - 1 - ], - "2": [ - 0, - 1, - 1 - ], - "3-gigantamax": [ - 0, - 1, - 1 - ], - "3-mega": [ - 0, - 2, - 2 - ], - "3": [ - 0, - 1, - 1 - ], - "4": [ - 0, - 1, - 1 - ], - "5": [ - 0, - 1, - 1 - ], - "6-mega-x": [ - 0, - 1, - 2 - ], - "6-gigantamax": [ - 0, - 1, - 2 - ], - "6-mega-y": [ - 0, - 1, - 2 - ], - "6": [ - 0, - 2, - 2 - ], - "7": [ - 0, - 2, - 2 - ], - "8": [ - 0, - 2, - 2 - ], - "9-gigantamax": [ - 0, - 1, - 2 - ], - "9-mega": [ - 0, - 2, - 2 - ], - "9": [ - 0, - 2, - 2 - ], - "19": [ - 0, - 1, - 1 - ], - "20": [ - 0, - 1, - 1 - ], - "23": [ - 0, - 1, - 1 - ], - "24": [ - 0, - 1, - 1 - ], - "29": [ - 0, - 1, - 1 - ], - "30": [ - 0, - 1, - 1 - ], - "31": [ - 1, - 1, - 1 - ], - "35": [ - 0, - 1, - 1 - ], - "36": [ - 0, - 2, - 1 - ], - "37": [ - 0, - 1, - 1 - ], - "38": [ - 0, - 1, - 1 - ], - "41": [ - 0, - 1, - 1 - ], - "42": [ - 0, - 1, - 1 - ], - "43": [ - 0, - 1, - 1 - ], - "44": [ - 0, - 1, - 1 - ], - "45": [ - 0, - 1, - 1 - ], - "46": [ - 1, - 1, - 1 - ], - "47": [ - 1, - 1, - 1 - ], - "50": [ - 0, - 1, - 1 - ], - "51": [ - 0, - 1, - 1 - ], - "52-gigantamax": [ - 1, - 1, - 1 - ], - "52": [ - 1, - 1, - 1 - ], - "53": [ - 1, - 1, - 1 - ], - "56": [ - 1, - 1, - 1 - ], - "57": [ - 1, - 1, - 1 - ], - "69": [ - 0, - 1, - 1 - ], - "70": [ - 0, - 1, - 1 - ], - "71": [ - 0, - 1, - 1 - ], - "77": [ - 0, - 1, - 1 - ], - "78": [ - 0, - 1, - 1 - ], - "79": [ - 1, - 1, - 1 - ], - "80": [ - 0, - 1, - 1 - ], - "80-mega": [ - 0, - 1, - 1 - ], - "81": [ - 0, - 1, - 1 - ], - "82": [ - 0, - 1, - 1 - ], - "83": [ - 0, - 2, - 2 - ], - "84": [ - 1, - 1, - 1 - ], - "85": [ - 1, - 1, - 1 - ], - "86": [ - 1, - 1, - 1 - ], - "87": [ - 1, - 1, - 1 - ], - "92": [ - 2, - 2, - 2 - ], - "93": [ - 1, - 1, - 1 - ], - "94-gigantamax": [ - 1, - 1, - 1 - ], - "94-mega": [ - 1, - 1, - 1 - ], - "94": [ - 1, - 1, - 1 - ], - "98": [ - 0, - 1, - 1 - ], - "99": [ - 0, - 1, - 1 - ], - "99-gigantamax": [ - 0, - 1, - 1 - ], - "100": [ - 0, - 1, - 1 - ], - "101": [ - 0, - 1, - 1 - ], - "111": [ - 0, - 1, - 1 - ], - "112": [ - 0, - 1, - 1 - ], - "113": [ - 1, - 1, - 1 - ], - "114": [ - 0, - 1, - 1 - ], - "116": [ - 0, - 1, - 1 - ], - "117": [ - 0, - 1, - 1 - ], - "118": [ - 1, - 1, - 1 - ], - "119": [ - 1, - 1, - 1 - ], - "120": [ - 0, - 1, - 1 - ], - "121": [ - 0, - 1, - 1 - ], - "123": [ - 1, - 1, - 1 - ], - "125": [ - 1, - 1, - 2 - ], - "126": [ - 0, - 2, - 1 - ], - "127-mega": [ - 0, - 1, - 1 - ], - "127": [ - 0, - 1, - 1 - ], - "129": [ - 0, - 1, - 1 - ], - "130-mega": [ - 0, - 1, - 1 - ], - "130": [ - 0, - 1, - 1 - ], - "131-gigantamax": [ - 0, - 1, - 1 - ], - "131": [ - 0, - 1, - 1 - ], - "132": [ - 0, - 1, - 1 - ], - "133": [ - 0, - 1, - 1 - ], - "133-partner": [ - 0, - 1, - 1 - ], - "134": [ - 0, - 1, - 1 - ], - "135": [ - 1, - 1, - 1 - ], - "136": [ - 1, - 1, - 1 - ], - "137": [ - 0, - 1, - 1 - ], - "138": [ - 0, - 1, - 1 - ], - "139": [ - 0, - 1, - 1 - ], - "140": [ - 0, - 1, - 1 - ], - "141": [ - 0, - 1, - 1 - ], - "142-mega": [ - 0, - 1, - 1 - ], - "142": [ - 0, - 1, - 1 - ], - "144": [ - 1, - 1, - 1 - ], - "145": [ - 1, - 1, - 1 - ], - "146": [ - 1, - 1, - 1 - ], - "147": [ - 0, - 1, - 1 - ], - "148": [ - 0, - 1, - 1 - ], - "149": [ - 0, - 1, - 1 - ], - "150-mega-x": [ - 0, - 1, - 1 - ], - "150-mega-y": [ - 0, - 1, - 1 - ], - "150": [ - 0, - 1, - 1 - ], - "151": [ - 0, - 1, - 1 - ], - "161": [ - 0, - 1, - 1 - ], - "162": [ - 0, - 1, - 1 - ], - "163": [ - 0, - 1, - 1 - ], - "164": [ - 0, - 1, - 1 - ], - "169": [ - 0, - 1, - 1 - ], - "173": [ - 0, - 1, - 1 - ], - "175": [ - 1, - 1, - 1 - ], - "176": [ - 1, - 1, - 1 - ], - "177": [ - 0, - 1, - 1 - ], - "178": [ - 0, - 2, - 2 - ], - "179": [ - 0, - 1, - 1 - ], - "180": [ - 0, - 1, - 2 - ], - "181-mega": [ - 0, - 1, - 2 - ], - "181": [ - 0, - 1, - 1 - ], - "182": [ - 0, - 1, - 1 - ], - "183": [ - 0, - 1, - 1 - ], - "184": [ - 0, - 1, - 1 - ], - "185": [ - 0, - 1, - 1 - ], - "190": [ - 0, - 1, - 1 - ], - "193": [ - 0, - 1, - 1 - ], - "196": [ - 1, - 1, - 1 - ], - "197": [ - 0, - 1, - 1 - ], - "199": [ - 2, - 1, - 1 - ], - "200": [ - 1, - 2, - 2 - ], - "201-m": [ - 0, - 1, - 1 - ], - "201-question": [ - 0, - 1, - 1 - ], - "201-j": [ - 0, - 1, - 1 - ], - "201-l": [ - 0, - 1, - 1 - ], - "201-h": [ - 0, - 1, - 1 - ], - "201-x": [ - 0, - 1, - 1 - ], - "201-exclamation": [ - 0, - 1, - 1 - ], - "201-q": [ - 0, - 1, - 1 - ], - "201-s": [ - 0, - 1, - 1 - ], - "201-c": [ - 0, - 1, - 1 - ], - "201-u": [ - 0, - 1, - 1 - ], - "201-t": [ - 0, - 1, - 1 - ], - "201-z": [ - 0, - 1, - 1 - ], - "201-d": [ - 0, - 1, - 1 - ], - "201-b": [ - 0, - 1, - 1 - ], - "201-g": [ - 0, - 1, - 1 - ], - "201-k": [ - 0, - 1, - 1 - ], - "201-i": [ - 0, - 1, - 1 - ], - "201-p": [ - 0, - 1, - 1 - ], - "201-e": [ - 0, - 1, - 1 - ], - "201-y": [ - 0, - 1, - 1 - ], - "201-r": [ - 0, - 1, - 1 - ], - "201-f": [ - 0, - 1, - 1 - ], - "201-n": [ - 0, - 1, - 1 - ], - "201-v": [ - 0, - 1, - 1 - ], - "201-a": [ - 0, - 1, - 1 - ], - "201-w": [ - 0, - 1, - 1 - ], - "201-o": [ - 0, - 1, - 1 - ], - "203": [ - 0, - 1, - 1 - ], - "206": [ - 0, - 1, - 1 - ], - "207": [ - 0, - 1, - 1 - ], - "212-mega": [ - 1, - 2, - 1 - ], - "212": [ - 1, - 1, - 1 - ], - "213": [ - 0, - 1, - 1 - ], - "215": [ - 0, - 1, - 1 - ], - "216": [ - 1, - 1, - 1 - ], - "217": [ - 1, - 1, - 1 - ], - "222": [ - 0, - 1, - 1 - ], - "226": [ - 0, - 1, - 1 - ], - "227": [ - 0, - 1, - 1 - ], - "228": [ - 0, - 1, - 1 - ], - "229": [ - 0, - 1, - 1 - ], - "229-mega": [ - 0, - 1, - 1 - ], - "230": [ - 0, - 1, - 1 - ], - "231": [ - 0, - 1, - 1 - ], - "232": [ - 0, - 1, - 1 - ], - "233": [ - 0, - 1, - 1 - ], - "235": [ - 0, - 1, - 1 - ], - "239": [ - 1, - 1, - 2 - ], - "240": [ - 0, - 1, - 1 - ], - "242": [ - 1, - 1, - 1 - ], - "243": [ - 0, - 1, - 1 - ], - "244": [ - 0, - 2, - 2 - ], - "245": [ - 0, - 1, - 1 - ], - "246": [ - 0, - 1, - 1 - ], - "247": [ - 0, - 1, - 1 - ], - "248": [ - 0, - 1, - 1 - ], - "248-mega": [ - 0, - 1, - 1 - ], - "249": [ - 0, - 1, - 1 - ], - "250": [ - 0, - 1, - 1 - ], - "251": [ - 0, - 1, - 1 - ], - "255": [ - 0, - 1, - 1 - ], - "256": [ - 0, - 1, - 1 - ], - "257": [ - 0, - 1, - 1 - ], - "257-mega": [ - 0, - 1, - 1 - ], - "261": [ - 0, - 1, - 1 - ], - "262": [ - 0, - 1, - 1 - ], - "263": [ - 0, - 1, - 1 - ], - "264": [ - 0, - 1, - 1 - ], - "278": [ - 1, - 1, - 1 - ], - "279": [ - 1, - 1, - 1 - ], - "280": [ - 0, - 1, - 1 - ], - "281": [ - 0, - 1, - 1 - ], - "282-mega": [ - 0, - 1, - 1 - ], - "282": [ - 0, - 1, - 1 - ], - "285": [ - 0, - 1, - 1 - ], - "286": [ - 0, - 1, - 1 - ], - "290": [ - 1, - 1, - 1 - ], - "291": [ - 2, - 2, - 2 - ], - "292": [ - 2, - 2, - 2 - ], - "298": [ - 0, - 1, - 1 - ], - "300": [ - 1, - 1, - 1 - ], - "301": [ - 1, - 1, - 1 - ], - "302": [ - 0, - 1, - 1 - ], - "302-mega": [ - 0, - 1, - 1 - ], - "303-mega": [ - 1, - 1, - 1 - ], - "303": [ - 1, - 1, - 1 - ], - "304": [ - 1, - 1, - 1 - ], - "305": [ - 1, - 1, - 1 - ], - "306-mega": [ - 1, - 1, - 1 - ], - "306": [ - 1, - 1, - 1 - ], - "307": [ - 0, - 1, - 1 - ], - "308-mega": [ - 0, - 1, - 1 - ], - "308": [ - 0, - 1, - 1 - ], - "309": [ - 0, - 1, - 1 - ], - "310-mega": [ - 0, - 1, - 1 - ], - "310": [ - 0, - 1, - 1 - ], - "311": [ - 1, - 1, - 1 - ], - "312": [ - 0, - 1, - 1 - ], - "315": [ - 0, - 1, - 1 - ], - "320": [ - 0, - 1, - 1 - ], - "321": [ - 0, - 1, - 1 - ], - "327": [ - 0, - 1, - 1 - ], - "328": [ - 0, - 1, - 1 - ], - "329": [ - 0, - 1, - 1 - ], - "330": [ - 0, - 1, - 1 - ], - "333": [ - 0, - 1, - 1 - ], - "334-mega": [ - 0, - 1, - 1 - ], - "334": [ - 0, - 1, - 1 - ], - "335": [ - 0, - 2, - 2 - ], - "336": [ - 0, - 1, - 1 - ], - "337": [ - 0, - 1, - 1 - ], - "338": [ - 0, - 1, - 1 - ], - "339": [ - 0, - 2, - 1 - ], - "340": [ - 0, - 1, - 2 - ], - "341": [ - 0, - 1, - 1 - ], - "342": [ - 0, - 2, - 2 - ], - "351-rainy": [ - 1, - 1, - 1 - ], - "351-snowy": [ - 1, - 1, - 1 - ], - "351-sunny": [ - 1, - 1, - 2 - ], - "351": [ - 0, - 1, - 1 - ], - "352": [ - 1, - 1, - 1 - ], - "353": [ - 0, - 1, - 1 - ], - "354": [ - 0, - 1, - 1 - ], - "354-mega": [ - 0, - 1, - 1 - ], - "357": [ - 0, - 1, - 1 - ], - "358": [ - 1, - 1, - 1 - ], - "361": [ - 0, - 1, - 1 - ], - "362": [ - 0, - 1, - 1 - ], - "362-mega": [ - 0, - 1, - 1 - ], - "369": [ - 0, - 2, - 2 - ], - "370": [ - 0, - 2, - 2 - ], - "371": [ - 0, - 1, - 1 - ], - "372": [ - 0, - 1, - 1 - ], - "373-mega": [ - 0, - 1, - 1 - ], - "373": [ - 0, - 1, - 1 - ], - "374": [ - 0, - 1, - 1 - ], - "375": [ - 0, - 1, - 1 - ], - "376-mega": [ - 0, - 1, - 1 - ], - "376": [ - 0, - 1, - 1 - ], - "380-mega": [ - 0, - 1, - 1 - ], - "380": [ - 0, - 1, - 1 - ], - "381-mega": [ - 0, - 1, - 1 - ], - "381": [ - 0, - 1, - 1 - ], - "382-primal": [ - 0, - 1, - 1 - ], - "382": [ - 0, - 1, - 1 - ], - "383-primal": [ - 0, - 1, - 1 - ], - "383": [ - 0, - 1, - 1 - ], - "384-mega": [ - 0, - 1, - 1 - ], - "384": [ - 0, - 1, - 1 - ], - "385": [ - 1, - 1, - 1 - ], - "387": [ - 0, - 2, - 1 - ], - "388": [ - 0, - 1, - 1 - ], - "389": [ - 0, - 1, - 1 - ], - "393": [ - 0, - 1, - 1 - ], - "394": [ - 0, - 1, - 1 - ], - "395": [ - 0, - 1, - 1 - ], - "399": [ - 0, - 2, - 1 - ], - "400": [ - 0, - 1, - 1 - ], - "401": [ - 0, - 1, - 1 - ], - "402": [ - 0, - 1, - 1 - ], - "406": [ - 0, - 1, - 1 - ], - "407": [ - 0, - 1, - 1 - ], - "412-sandy": [ - 2, - 2, - 2 - ], - "412-plant": [ - 1, - 1, - 1 - ], - "412-trash": [ - 1, - 1, - 1 - ], - "413-plant": [ - 1, - 1, - 1 - ], - "413-trash": [ - 1, - 1, - 1 - ], - "413-sandy": [ - 1, - 1, - 1 - ], - "414": [ - 0, - 1, - 1 - ], - "418": [ - 0, - 1, - 1 - ], - "419": [ - 0, - 1, - 1 - ], - "422-west": [ - 1, - 1, - 1 - ], - "422-east": [ - 1, - 1, - 1 - ], - "423-west": [ - 1, - 1, - 1 - ], - "423-east": [ - 1, - 1, - 1 - ], - "424": [ - 0, - 1, - 1 - ], - "425": [ - 0, - 1, - 1 - ], - "426": [ - 0, - 1, - 1 - ], - "427": [ - 0, - 1, - 1 - ], - "428-mega": [ - 0, - 1, - 1 - ], - "428": [ - 0, - 1, - 1 - ], - "429": [ - 1, - 1, - 1 - ], - "433": [ - 1, - 1, - 1 - ], - "436": [ - 0, - 1, - 1 - ], - "437": [ - 0, - 1, - 1 - ], - "438": [ - 0, - 1, - 1 - ], - "440": [ - 1, - 1, - 1 - ], - "441": [ - 0, - 1, - 2 - ], - "442": [ - 0, - 1, - 1 - ], - "443": [ - 1, - 1, - 1 - ], - "444": [ - 1, - 1, - 1 - ], - "445-mega": [ - 1, - 1, - 1 - ], - "445": [ - 1, - 1, - 1 - ], - "447": [ - 1, - 1, - 1 - ], - "448-mega": [ - 1, - 1, - 1 - ], - "448": [ - 1, - 1, - 1 - ], - "453": [ - 0, - 1, - 1 - ], - "454": [ - 0, - 1, - 1 - ], - "456": [ - 0, - 1, - 1 - ], - "457": [ - 0, - 2, - 1 - ], - "458": [ - 0, - 2, - 2 - ], - "461": [ - 0, - 1, - 1 - ], - "462": [ - 0, - 1, - 1 - ], - "464": [ - 0, - 1, - 1 - ], - "465": [ - 0, - 1, - 1 - ], - "466": [ - 2, - 1, - 1 - ], - "467": [ - 0, - 1, - 1 - ], - "468": [ - 1, - 1, - 1 - ], - "469": [ - 0, - 1, - 1 - ], - "470": [ - 2, - 2, - 1 - ], - "471": [ - 1, - 1, - 1 - ], - "472": [ - 0, - 1, - 1 - ], - "474": [ - 0, - 1, - 1 - ], - "475-mega": [ - 0, - 2, - 2 - ], - "475": [ - 0, - 1, - 1 - ], - "478": [ - 0, - 2, - 1 - ], - "479-heat": [ - 0, - 1, - 1 - ], - "479-wash": [ - 0, - 1, - 1 - ], - "479-mow": [ - 0, - 1, - 1 - ], - "479-frost": [ - 0, - 1, - 1 - ], - "479": [ - 0, - 1, - 1 - ], - "479-fan": [ - 0, - 1, - 1 - ], - "480": [ - 1, - 1, - 1 - ], - "481": [ - 1, - 1, - 1 - ], - "482": [ - 1, - 1, - 1 - ], - "485": [ - 0, - 1, - 1 - ], - "487-altered": [ - 0, - 1, - 1 - ], - "487-origin": [ - 0, - 1, - 1 - ], - "488": [ - 0, - 1, - 1 - ], - "489": [ - 1, - 1, - 1 - ], - "490": [ - 1, - 1, - 1 - ], - "491": [ - 0, - 1, - 1 - ], - "492-land": [ - 0, - 1, - 1 - ], - "492-sky": [ - 0, - 1, - 1 - ], - "494": [ - 0, - 1, - 1 - ], - "495": [ - 0, - 1, - 1 - ], - "496": [ - 0, - 1, - 1 - ], - "497": [ - 0, - 1, - 1 - ], - "517": [ - 0, - 1, - 1 - ], - "518": [ - 0, - 1, - 1 - ], - "524": [ - 0, - 1, - 1 - ], - "525": [ - 0, - 1, - 1 - ], - "526": [ - 0, - 1, - 1 - ], - "529": [ - 0, - 2, - 2 - ], - "530": [ - 0, - 1, - 2 - ], - "531": [ - 0, - 1, - 1 - ], - "531-mega": [ - 0, - 1, - 1 - ], - "532": [ - 0, - 1, - 1 - ], - "533": [ - 0, - 1, - 1 - ], - "534": [ - 0, - 1, - 1 - ], - "538": [ - 0, - 1, - 1 - ], - "539": [ - 0, - 2, - 2 - ], - "540": [ - 0, - 1, - 1 - ], - "541": [ - 0, - 1, - 1 - ], - "542": [ - 0, - 1, - 1 - ], - "543": [ - 0, - 1, - 1 - ], - "544": [ - 0, - 1, - 1 - ], - "545": [ - 0, - 1, - 1 - ], - "546": [ - 0, - 1, - 1 - ], - "547": [ - 0, - 1, - 1 - ], - "548": [ - 1, - 1, - 1 - ], - "549": [ - 0, - 1, - 1 - ], - "551": [ - 0, - 1, - 1 - ], - "552": [ - 0, - 1, - 1 - ], - "553": [ - 0, - 1, - 1 - ], - "556": [ - 0, - 1, - 1 - ], - "559": [ - 1, - 1, - 1 - ], - "560": [ - 1, - 1, - 1 - ], - "562": [ - 0, - 1, - 1 - ], - "563": [ - 0, - 1, - 1 - ], - "568": [ - 0, - 1, - 1 - ], - "569-gigantamax": [ - 0, - 1, - 1 - ], - "569": [ - 0, - 1, - 1 - ], - "570": [ - 0, - 1, - 1 - ], - "571": [ - 0, - 1, - 1 - ], - "572": [ - 0, - 1, - 1 - ], - "577": [ - 1, - 1, - 1 - ], - "578": [ - 1, - 1, - 1 - ], - "579": [ - 1, - 1, - 1 - ], - "585-autumn": [ - 2, - 0, - 0 - ], - "585-spring": [ - 2, - 0, - 0 - ], - "585-summer": [ - 1, - 0, - 0 - ], - "585-winter": [ - 2, - 0, - 0 - ], - "586-autumn": [ - 1, - 0, - 0 - ], - "586-spring": [ - 1, - 0, - 0 - ], - "586-summer": [ - 1, - 0, - 0 - ], - "586-winter": [ - 1, - 0, - 0 - ], - "592": [ - 0, - 1, - 2 - ], - "593": [ - 0, - 1, - 1 - ], - "594": [ - 0, - 1, - 2 - ], - "595": [ - 0, - 1, - 1 - ], - "596": [ - 0, - 1, - 1 - ], - "602": [ - 0, - 1, - 1 - ], - "603": [ - 0, - 1, - 1 - ], - "604": [ - 0, - 1, - 1 - ], - "605": [ - 1, - 1, - 1 - ], - "606": [ - 1, - 1, - 1 - ], - "607": [ - 0, - 1, - 1 - ], - "608": [ - 0, - 1, - 1 - ], - "609": [ - 0, - 1, - 1 - ], - "610": [ - 0, - 1, - 1 - ], - "611": [ - 0, - 1, - 1 - ], - "612": [ - 0, - 1, - 1 - ], - "618": [ - 0, - 2, - 2 - ], - "619": [ - 0, - 1, - 1 - ], - "620": [ - 0, - 1, - 1 - ], - "622": [ - 0, - 1, - 1 - ], - "623": [ - 0, - 1, - 1 - ], - "631": [ - 0, - 2, - 2 - ], - "632": [ - 0, - 1, - 1 - ], - "633": [ - 0, - 1, - 1 - ], - "634": [ - 0, - 1, - 1 - ], - "635": [ - 0, - 1, - 1 - ], - "636": [ - 0, - 1, - 1 - ], - "637": [ - 0, - 1, - 1 - ], - "640": [ - 0, - 1, - 1 - ], - "641-incarnate": [ - 0, - 0, - 0 - ], - "641-therian": [ - 0, - 0, - 0 - ], - "642-incarnate": [ - 0, - 0, - 0 - ], - "642-therian": [ - 0, - 0, - 0 - ], - "645-incarnate": [ - 0, - 0, - 0 - ], - "645-therian": [ - 0, - 0, - 0 - ], - "647-resolute": [ - 0, - 1, - 1 - ], - "647-ordinary": [ - 0, - 1, - 1 - ], - "648-aria": [ - 0, - 1, - 1 - ], - "648-pirouette": [ - 0, - 1, - 1 - ], - "649-burn": [ - 0, - 1, - 1 - ], - "649-chill": [ - 0, - 1, - 1 - ], - "649-douse": [ - 0, - 1, - 1 - ], - "649-shock": [ - 0, - 1, - 1 - ], - "649": [ - 0, - 1, - 1 - ], - "653": [ - 0, - 1, - 1 - ], - "654": [ - 0, - 1, - 1 - ], - "655": [ - 0, - 1, - 1 - ], - "664": [ - 0, - 1, - 1 - ], - "665": [ - 0, - 1, - 1 - ], - "666-archipelago": [ - 0, - 1, - 1 - ], - "666-continental": [ - 0, - 1, - 1 - ], - "666-elegant": [ - 0, - 1, - 1 - ], - "666-fancy": [ - 0, - 2, - 2 - ], - "666-garden": [ - 0, - 1, - 1 - ], - "666-high-plains": [ - 0, - 1, - 1 - ], - "666-icy-snow": [ - 0, - 1, - 1 - ], - "666-jungle": [ - 0, - 1, - 1 - ], - "666-marine": [ - 0, - 1, - 1 - ], - "666-meadow": [ - 0, - 1, - 1 - ], - "666-modern": [ - 0, - 1, - 1 - ], - "666-monsoon": [ - 0, - 1, - 1 - ], - "666-ocean": [ - 0, - 1, - 1 - ], - "666-poke-ball": [ - 0, - 1, - 1 - ], - "666-polar": [ - 0, - 1, - 1 - ], - "666-river": [ - 0, - 2, - 1 - ], - "666-sandstorm": [ - 0, - 1, - 1 - ], - "666-savanna": [ - 0, - 1, - 1 - ], - "666-sun": [ - 0, - 1, - 1 - ], - "666-tundra": [ - 0, - 1, - 1 - ], - "669-red": [ - 0, - 1, - 1 - ], - "669-blue": [ - 0, - 1, - 1 - ], - "669-white": [ - 0, - 1, - 1 - ], - "669-yellow": [ - 0, - 1, - 1 - ], - "669-orange": [ - 0, - 1, - 1 - ], - "670-white": [ - 0, - 1, - 1 - ], - "670-blue": [ - 0, - 1, - 1 - ], - "670-orange": [ - 0, - 1, - 1 - ], - "670-red": [ - 0, - 1, - 1 - ], - "670-yellow": [ - 0, - 1, - 1 - ], - "671-red": [ - 0, - 1, - 1 - ], - "671-blue": [ - 0, - 1, - 1 - ], - "671-yellow": [ - 0, - 1, - 1 - ], - "671-white": [ - 0, - 1, - 1 - ], - "671-orange": [ - 0, - 1, - 1 - ], - "672": [ - 0, - 1, - 1 - ], - "673": [ - 0, - 1, - 1 - ], - "677": [ - 0, - 1, - 1 - ], - "678-female": [ - 0, - 1, - 1 - ], - "678": [ - 0, - 1, - 1 - ], - "690": [ - 0, - 1, - 1 - ], - "691": [ - 0, - 1, - 1 - ], - "696": [ - 0, - 1, - 2 - ], - "697": [ - 0, - 1, - 2 - ], - "698": [ - 0, - 1, - 1 - ], - "699": [ - 0, - 1, - 1 - ], - "700": [ - 0, - 1, - 1 - ], - "702": [ - 0, - 1, - 1 - ], - "703": [ - 0, - 1, - 1 - ], - "704": [ - 0, - 1, - 1 - ], - "705": [ - 0, - 1, - 1 - ], - "706": [ - 0, - 1, - 1 - ], - "708": [ - 0, - 1, - 1 - ], - "709": [ - 0, - 1, - 1 - ], - "710": [ - 0, - 1, - 1 - ], - "711": [ - 1, - 1, - 1 - ], - "712": [ - 0, - 1, - 1 - ], - "713": [ - 0, - 1, - 1 - ], - "714": [ - 0, - 1, - 1 - ], - "715": [ - 0, - 2, - 2 - ], - "716-active": [ - 0, - 1, - 1 - ], - "716-neutral": [ - 0, - 1, - 1 - ], - "717": [ - 0, - 1, - 1 - ], - "720-unbound": [ - 1, - 1, - 1 - ], - "720": [ - 1, - 1, - 1 - ], - "728": [ - 0, - 1, - 1 - ], - "729": [ - 0, - 1, - 1 - ], - "730": [ - 0, - 1, - 1 - ], - "734": [ - 0, - 1, - 1 - ], - "735": [ - 0, - 1, - 1 - ], - "742": [ - 0, - 2, - 2 - ], - "743": [ - 0, - 2, - 2 - ], - "747": [ - 0, - 1, - 1 - ], - "748": [ - 0, - 1, - 1 - ], - "751": [ - 0, - 1, - 1 - ], - "752": [ - 0, - 1, - 1 - ], - "753": [ - 0, - 1, - 1 - ], - "754": [ - 0, - 2, - 2 - ], - "755": [ - 0, - 1, - 1 - ], - "756": [ - 0, - 1, - 1 - ], - "761": [ - 0, - 1, - 1 - ], - "762": [ - 0, - 1, - 1 - ], - "763": [ - 0, - 1, - 1 - ], - "767": [ - 0, - 1, - 1 - ], - "768": [ - 0, - 1, - 1 - ], - "771": [ - 0, - 1, - 1 - ], - "772": [ - 0, - 1, - 1 - ], - "773-fighting": [ - 0, - 2, - 2 - ], - "773-psychic": [ - 0, - 2, - 2 - ], - "773-poison": [ - 0, - 2, - 2 - ], - "773-ground": [ - 0, - 2, - 2 - ], - "773-ghost": [ - 0, - 2, - 2 - ], - "773-steel": [ - 0, - 2, - 2 - ], - "773-rock": [ - 0, - 2, - 2 - ], - "773-grass": [ - 0, - 2, - 2 - ], - "773-dragon": [ - 0, - 2, - 2 - ], - "773-bug": [ - 0, - 2, - 2 - ], - "773-ice": [ - 0, - 2, - 2 - ], - "773-dark": [ - 0, - 2, - 2 - ], - "773": [ - 0, - 1, - 1 - ], - "773-fairy": [ - 0, - 2, - 2 - ], - "773-water": [ - 0, - 2, - 2 - ], - "773-electric": [ - 0, - 2, - 2 - ], - "773-flying": [ - 0, - 2, - 2 - ], - "773-fire": [ - 0, - 2, - 2 - ], - "776": [ - 0, - 1, - 1 - ], - "777": [ - 0, - 1, - 1 - ], - "778-busted": [ - 0, - 1, - 1 - ], - "778-disguised": [ - 0, - 1, - 1 - ], - "779": [ - 0, - 1, - 1 - ], - "789": [ - 1, - 1, - 1 - ], - "790": [ - 0, - 1, - 1 - ], - "791-radiant-sun": [ - 0, - 1, - 1 - ], - "791": [ - 2, - 1, - 1 - ], - "792-full-moon": [ - 0, - 1, - 1 - ], - "792": [ - 0, - 1, - 1 - ], - "793": [ - 0, - 1, - 1 - ], - "797": [ - 0, - 1, - 1 - ], - "798": [ - 0, - 1, - 1 - ], - "800-dawn-wings": [ - 0, - 1, - 1 - ], - "800-dusk-mane": [ - 0, - 1, - 1 - ], - "800-ultra": [ - 0, - 1, - 1 - ], - "800": [ - 0, - 1, - 1 - ], - "802": [ - 1, - 1, - 1 - ], - "803": [ - 0, - 1, - 1 - ], - "804": [ - 0, - 1, - 1 - ], - "808": [ - 0, - 1, - 1 - ], - "809-gigantamax": [ - 0, - 1, - 1 - ], - "809": [ - 0, - 1, - 1 - ], - "816": [ - 0, - 1, - 1 - ], - "817": [ - 0, - 1, - 1 - ], - "818-gigantamax": [ - 1, - 1, - 1 - ], - "818": [ - 0, - 1, - 1 - ], - "821": [ - 0, - 1, - 1 - ], - "822": [ - 0, - 1, - 1 - ], - "823-gigantamax": [ - 0, - 2, - 2 - ], - "823": [ - 0, - 1, - 1 - ], - "829": [ - 0, - 1, - 1 - ], - "830": [ - 0, - 1, - 1 - ], - "835": [ - 0, - 1, - 1 - ], - "836": [ - 0, - 1, - 1 - ], - "850": [ - 0, - 1, - 1 - ], - "851-gigantamax": [ - 0, - 1, - 1 - ], - "851": [ - 0, - 1, - 1 - ], - "854": [ - 0, - 1, - 1 - ], - "855": [ - 0, - 1, - 1 - ], - "856": [ - 0, - 1, - 1 - ], - "857": [ - 0, - 2, - 2 - ], - "858-gigantamax": [ - 0, - 1, - 1 - ], - "858": [ - 0, - 1, - 1 - ], - "859": [ - 0, - 1, - 1 - ], - "860": [ - 0, - 1, - 1 - ], - "861-gigantamax": [ - 0, - 1, - 1 - ], - "861": [ - 0, - 1, - 1 - ], - "862": [ - 0, - 1, - 1 - ], - "863": [ - 0, - 1, - 1 - ], - "864": [ - 0, - 1, - 1 - ], - "867": [ - 0, - 1, - 1 - ], - "872": [ - 1, - 1, - 1 - ], - "873": [ - 1, - 1, - 1 - ], - "876-female": [ - 0, - 1, - 1 - ], - "876": [ - 0, - 1, - 1 - ], - "877-hangry": [ - 1, - 1, - 1 - ], - "877": [ - 1, - 1, - 1 - ], - "880": [ - 0, - 1, - 1 - ], - "881": [ - 0, - 2, - 2 - ], - "882": [ - 0, - 1, - 1 - ], - "883": [ - 0, - 1, - 1 - ], - "884-gigantamax": [ - 0, - 1, - 1 - ], - "884": [ - 0, - 1, - 1 - ], - "885": [ - 1, - 1, - 1 - ], - "886": [ - 1, - 1, - 1 - ], - "887": [ - 1, - 1, - 1 - ], - "888": [ - 0, - 1, - 1 - ], - "888-crowned": [ - 0, - 1, - 1 - ], - "889": [ - 0, - 1, - 1 - ], - "889-crowned": [ - 0, - 1, - 1 - ], - "890-eternamax": [ - 0, - 1, - 1 - ], - "890": [ - 0, - 1, - 1 - ], - "891": [ - 1, - 1, - 1 - ], - "892-gigantamax-rapid": [ - 1, - 2, - 2 - ], - "892-rapid-strike": [ - 1, - 1, - 1 - ], - "892": [ - 1, - 1, - 1 - ], - "892-gigantamax-single": [ - 1, - 2, - 2 - ], - "896": [ - 1, - 1, - 1 - ], - "897": [ - 1, - 1, - 1 - ], - "898": [ - 1, - 1, - 1 - ], - "898-ice": [ - 1, - 1, - 1 - ], - "898-shadow": [ - 1, - 1, - 1 - ], - "900": [ - 0, - 1, - 1 - ], - "901": [ - 0, - 1, - 1 - ], - "903": [ - 0, - 1, - 1 - ], - "909": [ - 0, - 1, - 1 - ], - "910": [ - 0, - 2, - 2 - ], - "911": [ - 0, - 1, - 1 - ], - "912": [ - 0, - 1, - 1 - ], - "913": [ - 0, - 1, - 1 - ], - "914": [ - 0, - 1, - 1 - ], - "919": [ - 1, - 1, - 1 - ], - "920": [ - 1, - 1, - 1 - ], - "924": [ - 1, - 1, - 1 - ], - "925-four": [ - 1, - 1, - 1 - ], - "925-three": [ - 1, - 1, - 1 - ], - "932": [ - 0, - 1, - 1 - ], - "933": [ - 0, - 1, - 1 - ], - "934": [ - 0, - 1, - 1 - ], - "935": [ - 2, - 2, - 2 - ], - "936": [ - 1, - 1, - 1 - ], - "937": [ - 1, - 1, - 1 - ], - "940": [ - 0, - 1, - 1 - ], - "941": [ - 0, - 1, - 1 - ], - "948": [ - 0, - 1, - 1 - ], - "949": [ - 0, - 1, - 1 - ], - "951": [ - 0, - 1, - 1 - ], - "952": [ - 0, - 1, - 1 - ], - "953": [ - 0, - 1, - 1 - ], - "954": [ - 0, - 1, - 1 - ], - "957": [ - 1, - 1, - 1 - ], - "958": [ - 1, - 1, - 1 - ], - "959": [ - 1, - 1, - 1 - ], - "962": [ - 1, - 1, - 1 - ], - "967": [ - 0, - 1, - 1 - ], - "968": [ - 0, - 1, - 1 - ], - "969": [ - 0, - 1, - 1 - ], - "970": [ - 0, - 1, - 1 - ], - "973": [ - 1, - 1, - 1 - ], - "974": [ - 0, - 1, - 1 - ], - "975": [ - 0, - 1, - 1 - ], - "978-curly": [ - 0, - 2, - 2 - ], - "978-droopy": [ - 0, - 2, - 2 - ], - "978-stretchy": [ - 0, - 1, - 1 - ], - "979": [ - 1, - 1, - 1 - ], - "981": [ - 0, - 1, - 1 - ], - "982": [ - 0, - 1, - 2 - ], - "982-three-segment": [ - 0, - 1, - 2 - ], - "987": [ - 1, - 1, - 1 - ], - "988": [ - 0, - 1, - 1 - ], - "993": [ - 0, - 1, - 1 - ], - "994": [ - 0, - 1, - 1 - ], - "995": [ - 0, - 1, - 1 - ], - "996": [ - 0, - 1, - 1 - ], - "997": [ - 0, - 1, - 1 - ], - "998": [ - 0, - 1, - 1 - ], - "999": [ - 1, - 1, - 1 - ], - "1000": [ - 1, - 1, - 1 - ], - "1001": [ - 0, - 1, - 1 - ], - "1003": [ - 0, - 1, - 1 - ], - "1004": [ - 0, - 1, - 1 - ], - "1006": [ - 0, - 2, - 1 - ], - "1007-apex-build": [ - 0, - 2, - 2 - ], - "1008-ultimate-mode": [ - 1, - 1, - 1 - ], - "1010": [ - 0, - 1, - 1 - ], - "1018": [ - 0, - 1, - 1 - ], - "1022": [ - 0, - 2, - 2 - ], - "1023": [ - 0, - 1, - 1 - ], - "2027": [ - 0, - 1, - 1 - ], - "2028": [ - 0, - 1, - 1 - ], - "2052": [ - 0, - 1, - 1 - ], - "2053": [ - 0, - 1, - 1 - ], - "2670": [ - 0, - 1, - 1 - ], - "4052": [ - 0, - 1, - 1 - ], - "4077": [ - 0, - 1, - 1 - ], - "4078": [ - 0, - 1, - 1 - ], - "4079": [ - 0, - 1, - 1 - ], - "4080": [ - 2, - 1, - 1 - ], - "4144": [ - 0, - 2, - 2 - ], - "4145": [ - 0, - 2, - 2 - ], - "4146": [ - 0, - 2, - 2 - ], - "4199": [ - 2, - 1, - 1 - ], - "4222": [ - 0, - 1, - 1 - ], - "4263": [ - 0, - 1, - 1 - ], - "4264": [ - 0, - 1, - 1 - ], - "4562": [ - 0, - 1, - 1 - ], - "6100": [ - 0, - 1, - 1 - ], - "6101": [ - 0, - 1, - 1 - ], - "6215": [ - 0, - 1, - 1 - ], - "6549": [ - 0, - 1, - 1 - ], - "6570": [ - 0, - 1, - 1 - ], - "6571": [ - 0, - 1, - 1 - ], - "6705": [ - 0, - 1, - 1 - ], - "6706": [ - 0, - 2, - 2 - ], - "6713": [ - 0, - 1, - 1 - ], - "8901": [ - 1, - 1, - 1 - ], + "1": [0, 1, 1], + "2": [0, 1, 1], + "3-gigantamax": [0, 1, 1], + "3-mega": [0, 2, 2], + "3": [0, 1, 1], + "4": [0, 1, 1], + "5": [0, 1, 1], + "6-mega-x": [0, 1, 2], + "6-gigantamax": [0, 1, 2], + "6-mega-y": [0, 1, 2], + "6": [0, 2, 2], + "7": [0, 2, 2], + "8": [0, 2, 2], + "9-gigantamax": [0, 1, 2], + "9-mega": [0, 2, 2], + "9": [0, 2, 2], + "19": [0, 1, 1], + "20": [0, 1, 1], + "23": [0, 1, 1], + "24": [0, 1, 1], + "25": [0, 1, 1], + "25-beauty-cosplay": [0, 1, 1], + "25-cool-cosplay": [0, 1, 1], + "25-cosplay": [0, 1, 1], + "25-cute-cosplay": [0, 1, 1], + "25-gigantamax": [0, 1, 1], + "25-partner": [0, 1, 1], + "25-smart-cosplay": [0, 1, 1], + "25-tough-cosplay": [0, 1, 1], + "26": [0, 1, 1], + "29": [0, 1, 1], + "30": [0, 1, 1], + "31": [1, 1, 1], + "35": [0, 1, 1], + "36": [0, 2, 1], + "37": [0, 1, 1], + "38": [0, 1, 1], + "39": [0, 1, 1], + "40": [0, 1, 1], + "41": [0, 1, 1], + "42": [0, 1, 1], + "43": [0, 1, 1], + "44": [0, 1, 1], + "45": [0, 1, 1], + "46": [1, 1, 1], + "47": [1, 1, 1], + "50": [0, 1, 1], + "51": [0, 1, 1], + "52-gigantamax": [1, 1, 1], + "52": [1, 1, 1], + "53": [1, 1, 1], + "56": [1, 1, 1], + "57": [1, 1, 1], + "69": [0, 1, 1], + "70": [0, 1, 1], + "71": [0, 1, 1], + "77": [0, 1, 1], + "78": [0, 1, 1], + "79": [1, 1, 1], + "80": [0, 1, 1], + "80-mega": [0, 1, 1], + "81": [0, 1, 1], + "82": [0, 1, 1], + "83": [0, 2, 2], + "84": [1, 1, 1], + "85": [1, 1, 1], + "86": [1, 1, 1], + "87": [1, 1, 1], + "92": [2, 2, 2], + "93": [1, 1, 1], + "94-gigantamax": [1, 1, 1], + "94-mega": [1, 1, 1], + "94": [1, 1, 1], + "98": [0, 1, 1], + "99": [0, 1, 1], + "99-gigantamax": [0, 1, 1], + "100": [0, 1, 1], + "101": [0, 1, 1], + "102": [0, 1, 1], + "103": [0, 1, 1], + "111": [0, 1, 1], + "112": [0, 1, 1], + "113": [1, 1, 1], + "114": [0, 1, 1], + "116": [0, 1, 1], + "117": [0, 1, 1], + "118": [1, 1, 1], + "119": [1, 1, 1], + "120": [0, 1, 1], + "121": [0, 1, 1], + "123": [1, 1, 1], + "125": [1, 1, 2], + "126": [0, 2, 1], + "127-mega": [0, 1, 1], + "127": [0, 1, 1], + "128": [0, 1, 1], + "129": [0, 1, 1], + "130-mega": [0, 1, 1], + "130": [0, 1, 1], + "131-gigantamax": [0, 1, 1], + "131": [0, 1, 1], + "132": [0, 1, 1], + "133": [0, 1, 1], + "133-partner": [0, 1, 1], + "134": [0, 1, 1], + "135": [1, 1, 1], + "136": [1, 1, 1], + "137": [0, 1, 1], + "138": [0, 1, 1], + "139": [0, 1, 1], + "140": [0, 1, 1], + "141": [0, 1, 1], + "142-mega": [0, 1, 1], + "142": [0, 1, 1], + "144": [1, 1, 1], + "145": [1, 1, 1], + "146": [1, 1, 1], + "147": [0, 1, 1], + "148": [0, 1, 1], + "149": [0, 1, 1], + "150-mega-x": [0, 1, 1], + "150-mega-y": [0, 1, 1], + "150": [0, 1, 1], + "151": [0, 1, 1], + "152": [0, 1, 1], + "153": [0, 1, 1], + "154": [0, 1, 1], + "158": [0, 1, 1], + "159": [0, 1, 1], + "160": [0, 1, 1], + "161": [0, 1, 1], + "162": [0, 1, 1], + "163": [0, 1, 1], + "164": [0, 1, 1], + "167": [0, 1, 1], + "168": [0, 1, 1], + "169": [0, 1, 1], + "170": [0, 1, 1], + "171": [0, 1, 1], + "172": [0, 1, 1], + "172-spiky": [0, 1, 1], + "173": [0, 1, 1], + "174": [0, 1, 1], + "175": [1, 1, 1], + "176": [1, 1, 1], + "177": [0, 1, 1], + "178": [0, 2, 2], + "179": [0, 1, 1], + "180": [0, 1, 2], + "181-mega": [0, 1, 2], + "181": [0, 1, 1], + "182": [0, 1, 1], + "183": [0, 1, 1], + "184": [0, 1, 1], + "185": [0, 1, 1], + "190": [0, 1, 1], + "193": [0, 1, 1], + "194": [0, 1, 1], + "195": [0, 1, 1], + "196": [1, 1, 1], + "197": [0, 1, 1], + "198": [0, 1, 1], + "199": [2, 1, 1], + "200": [1, 2, 2], + "201-m": [0, 1, 1], + "201-question": [0, 1, 1], + "201-j": [0, 1, 1], + "201-l": [0, 1, 1], + "201-h": [0, 1, 1], + "201-x": [0, 1, 1], + "201-exclamation": [0, 1, 1], + "201-q": [0, 1, 1], + "201-s": [0, 1, 1], + "201-c": [0, 1, 1], + "201-u": [0, 1, 1], + "201-t": [0, 1, 1], + "201-z": [0, 1, 1], + "201-d": [0, 1, 1], + "201-b": [0, 1, 1], + "201-g": [0, 1, 1], + "201-k": [0, 1, 1], + "201-i": [0, 1, 1], + "201-p": [0, 1, 1], + "201-e": [0, 1, 1], + "201-y": [0, 1, 1], + "201-r": [0, 1, 1], + "201-f": [0, 1, 1], + "201-n": [0, 1, 1], + "201-v": [0, 1, 1], + "201-a": [0, 1, 1], + "201-w": [0, 1, 1], + "201-o": [0, 1, 1], + "203": [0, 1, 1], + "206": [0, 1, 1], + "207": [0, 1, 1], + "211": [0, 1, 1], + "212-mega": [1, 2, 1], + "212": [1, 1, 1], + "213": [0, 1, 1], + "215": [0, 1, 1], + "216": [1, 1, 1], + "217": [1, 1, 1], + "222": [0, 1, 1], + "226": [0, 1, 1], + "227": [0, 1, 1], + "228": [0, 1, 1], + "229": [0, 1, 1], + "229-mega": [0, 1, 1], + "230": [0, 1, 1], + "231": [0, 1, 1], + "232": [0, 1, 1], + "233": [0, 1, 1], + "235": [0, 1, 1], + "239": [1, 1, 2], + "240": [0, 1, 1], + "242": [1, 1, 1], + "243": [0, 1, 1], + "244": [0, 2, 2], + "245": [0, 1, 1], + "246": [0, 1, 1], + "247": [0, 1, 1], + "248": [0, 1, 1], + "248-mega": [0, 1, 1], + "249": [0, 1, 1], + "250": [0, 1, 1], + "251": [0, 1, 1], + "255": [0, 1, 1], + "256": [0, 1, 1], + "257": [0, 1, 1], + "257-mega": [0, 1, 1], + "261": [0, 1, 1], + "262": [0, 1, 1], + "263": [0, 1, 1], + "264": [0, 1, 1], + "276": [0, 1, 1], + "277": [0, 1, 1], + "278": [1, 1, 1], + "279": [1, 1, 1], + "280": [0, 1, 1], + "281": [0, 1, 1], + "282-mega": [0, 1, 1], + "282": [0, 1, 1], + "285": [0, 1, 1], + "286": [0, 1, 1], + "290": [1, 1, 1], + "291": [2, 2, 2], + "292": [2, 2, 2], + "298": [0, 1, 1], + "300": [1, 1, 1], + "301": [1, 1, 1], + "302": [0, 1, 1], + "302-mega": [0, 1, 1], + "303-mega": [1, 1, 1], + "303": [1, 1, 1], + "304": [1, 1, 1], + "305": [1, 1, 1], + "306-mega": [1, 1, 1], + "306": [1, 1, 1], + "307": [0, 1, 1], + "308-mega": [0, 1, 1], + "308": [0, 1, 1], + "309": [0, 1, 1], + "310-mega": [0, 1, 1], + "310": [0, 1, 1], + "311": [1, 1, 1], + "312": [0, 1, 1], + "315": [0, 1, 1], + "320": [0, 1, 1], + "321": [0, 1, 1], + "327": [0, 1, 1], + "328": [0, 1, 1], + "329": [0, 1, 1], + "330": [0, 1, 1], + "333": [0, 1, 1], + "334-mega": [0, 1, 1], + "334": [0, 1, 1], + "335": [0, 2, 2], + "336": [0, 1, 1], + "337": [0, 1, 1], + "338": [0, 1, 1], + "339": [0, 2, 1], + "340": [0, 1, 2], + "341": [0, 1, 1], + "342": [0, 2, 2], + "351-rainy": [1, 1, 1], + "351-snowy": [1, 1, 1], + "351-sunny": [1, 1, 2], + "351": [0, 1, 1], + "352": [1, 1, 1], + "353": [0, 1, 1], + "354": [0, 1, 1], + "354-mega": [0, 1, 1], + "357": [0, 1, 1], + "358": [1, 1, 1], + "359": [0, 1, 1], + "359-mega": [0, 1, 1], + "361": [0, 1, 1], + "362": [0, 1, 1], + "362-mega": [0, 1, 1], + "369": [0, 2, 2], + "370": [0, 2, 2], + "371": [0, 1, 1], + "372": [0, 1, 1], + "373-mega": [0, 1, 1], + "373": [0, 1, 1], + "374": [0, 1, 1], + "375": [0, 1, 1], + "376-mega": [0, 1, 1], + "376": [0, 1, 1], + "377": [0, 1, 1], + "378": [1, 1, 1], + "379": [0, 1, 1], + "380-mega": [0, 1, 1], + "380": [0, 1, 1], + "381-mega": [0, 1, 1], + "381": [0, 1, 1], + "382-primal": [0, 1, 1], + "382": [0, 1, 1], + "383-primal": [0, 1, 1], + "383": [0, 1, 1], + "384-mega": [0, 1, 1], + "384": [0, 1, 1], + "385": [1, 1, 1], + "387": [0, 2, 1], + "388": [0, 1, 1], + "389": [0, 1, 1], + "390": [0, 1, 1], + "391": [0, 1, 1], + "392": [0, 1, 1], + "393": [0, 1, 1], + "394": [0, 1, 1], + "395": [0, 1, 1], + "399": [0, 2, 1], + "400": [0, 1, 1], + "401": [0, 1, 1], + "402": [0, 1, 1], + "406": [0, 1, 1], + "407": [0, 1, 1], + "412-sandy": [2, 2, 2], + "412-plant": [1, 1, 1], + "412-trash": [1, 1, 1], + "413-plant": [1, 1, 1], + "413-trash": [1, 1, 1], + "413-sandy": [1, 1, 1], + "414": [0, 1, 1], + "418": [0, 1, 1], + "419": [0, 1, 1], + "422-west": [1, 1, 1], + "422-east": [1, 1, 1], + "423-west": [1, 1, 1], + "423-east": [1, 1, 1], + "424": [0, 1, 1], + "425": [0, 1, 1], + "426": [0, 1, 1], + "427": [0, 1, 1], + "428-mega": [0, 1, 1], + "428": [0, 1, 1], + "429": [1, 1, 1], + "430": [0, 1, 1], + "433": [1, 1, 1], + "436": [0, 1, 1], + "437": [0, 1, 1], + "438": [0, 1, 1], + "440": [1, 1, 1], + "441": [0, 1, 2], + "442": [0, 1, 1], + "443": [1, 1, 1], + "444": [1, 1, 1], + "445-mega": [1, 1, 1], + "445": [1, 1, 1], + "447": [1, 1, 1], + "448-mega": [1, 1, 1], + "448": [1, 1, 1], + "453": [0, 1, 1], + "454": [0, 1, 1], + "455": [0, 1, 1], + "456": [0, 1, 1], + "457": [0, 2, 1], + "458": [0, 2, 2], + "461": [0, 1, 1], + "462": [0, 1, 1], + "464": [0, 1, 1], + "465": [0, 1, 1], + "466": [2, 1, 1], + "467": [0, 1, 1], + "468": [1, 1, 1], + "469": [0, 1, 1], + "470": [2, 2, 1], + "471": [1, 1, 1], + "472": [0, 1, 1], + "474": [0, 1, 1], + "475-mega": [0, 2, 2], + "475": [0, 1, 1], + "478": [0, 2, 1], + "479-heat": [0, 1, 1], + "479-wash": [0, 1, 1], + "479-mow": [0, 1, 1], + "479-frost": [0, 1, 1], + "479": [0, 1, 1], + "479-fan": [0, 1, 1], + "480": [1, 1, 1], + "481": [1, 1, 1], + "482": [1, 1, 1], + "485": [0, 1, 1], "486": [0, 1 , 1 + ] ,"487-altered": [0, 1, 1], + "487-origin": [0, 1, 1], + "488": [0, 1, 1], + "489": [1, 1, 1], + "490": [1, 1, 1], + "491": [0, 1, 1], + "492-land": [0, 1, 1], + "492-sky": [0, 1, 1], + "494": [0, 1, 1], + "495": [0, 1, 1], + "496": [0, 1, 1], + "497": [0, 1, 1], + "501": [0, 1, 1], + "502": [0, 1, 1], + "503": [0, 1, 1], + "517": [0, 1, 1], + "518": [0, 1, 1], + "524": [0, 1, 1], + "525": [0, 1, 1], + "526": [0, 1, 1], + "527": [0, 1, 1], + "528": [0, 1, 1], + "529": [0, 2, 2], + "530": [0, 1, 2], + "531": [0, 1, 1], + "531-mega": [0, 1, 1], + "532": [0, 1, 1], + "533": [0, 1, 1], + "534": [0, 1, 1], + "538": [0, 1, 1], + "539": [0, 2, 2], + "540": [0, 1, 1], + "541": [0, 1, 1], + "542": [0, 1, 1], + "543": [0, 1, 1], + "544": [0, 1, 1], + "545": [0, 1, 1], + "546": [0, 1, 1], + "547": [0, 1, 1], + "548": [1, 1, 1], + "549": [0, 1, 1], + "551": [0, 1, 1], + "552": [0, 1, 1], + "553": [0, 1, 1], + "556": [0, 1, 1], + "559": [1, 1, 1], + "560": [1, 1, 1], + "562": [0, 1, 1], + "563": [0, 1, 1], + "568": [0, 1, 1], + "569-gigantamax": [0, 1, 1], + "569": [0, 1, 1], + "570": [0, 1, 1], + "571": [0, 1, 1], + "572": [0, 1, 1], + "577": [1, 1, 1], + "578": [1, 1, 1], + "579": [1, 1, 1], + "585-autumn": [2, 0, 0], + "585-spring": [2, 0, 0], + "585-summer": [1, 0, 0], + "585-winter": [2, 0, 0], + "586-autumn": [1, 0, 0], + "586-spring": [1, 0, 0], + "586-summer": [1, 0, 0], + "586-winter": [1, 0, 0], + "587": [0, 1, 1], + "588": [0, 1, 1], + "589": [0, 1, 1], + "590": [0, 1, 1], + "591": [0, 1, 1], + "592": [0, 1, 2], + "593": [0, 1, 1], + "594": [0, 1, 2], + "595": [0, 1, 1], + "596": [0, 1, 1], + "602": [0, 1, 1], + "603": [0, 1, 1], + "604": [0, 1, 1], + "605": [1, 1, 1], + "606": [1, 1, 1], + "607": [0, 1, 1], + "608": [0, 1, 1], + "609": [0, 1, 1], + "610": [0, 1, 1], + "611": [0, 1, 1], + "612": [0, 1, 1], + "616": [0, 1, 1], + "617": [0, 1, 1], + "618": [0, 2, 2], + "619": [0, 1, 1], + "620": [0, 1, 1], + "621": [0, 1, 1], + "622": [0, 1, 1], + "623": [0, 1, 1], + "631": [0, 2, 2], + "632": [0, 1, 1], + "633": [0, 1, 1], + "634": [0, 1, 1], + "635": [0, 1, 1], + "636": [0, 1, 1], + "637": [0, 1, 1], + "640": [0, 1, 1], + "641-incarnate": [0, 0, 0], + "641-therian": [0, 0, 0], + "642-incarnate": [0, 0, 0], + "642-therian": [0, 0, 0], + "645-incarnate": [0, 0, 0], + "645-therian": [0, 0, 0], + "647-resolute": [0, 1, 1], + "647-ordinary": [0, 1, 1], + "648-aria": [0, 1, 1], + "648-pirouette": [0, 1, 1], + "649-burn": [0, 1, 1], + "649-chill": [0, 1, 1], + "649-douse": [0, 1, 1], + "649-shock": [0, 1, 1], + "649": [0, 1, 1], + "653": [0, 1, 1], + "654": [0, 1, 1], + "655": [0, 1, 1], + "656": [0, 1, 1], + "657": [0, 1, 1], + "658": [0, 1, 1], + "658-ash": [0, 1, 1], + "664": [0, 1, 1], + "665": [0, 1, 1], + "666-archipelago": [0, 1, 1], + "666-continental": [0, 1, 1], + "666-elegant": [0, 1, 1], + "666-fancy": [0, 2, 2], + "666-garden": [0, 1, 1], + "666-high-plains": [0, 1, 1], + "666-icy-snow": [0, 1, 1], + "666-jungle": [0, 1, 1], + "666-marine": [0, 1, 1], + "666-meadow": [0, 1, 1], + "666-modern": [0, 1, 1], + "666-monsoon": [0, 1, 1], + "666-ocean": [0, 1, 1], + "666-poke-ball": [0, 1, 1], + "666-polar": [0, 1, 1], + "666-river": [0, 2, 1], + "666-sandstorm": [0, 1, 1], + "666-savanna": [0, 1, 1], + "666-sun": [0, 1, 1], + "666-tundra": [0, 1, 1], + "669-red": [0, 1, 1], + "669-blue": [0, 1, 1], + "669-white": [0, 1, 1], + "669-yellow": [0, 1, 1], + "669-orange": [0, 1, 1], + "670-white": [0, 1, 1], + "670-blue": [0, 1, 1], + "670-orange": [0, 1, 1], + "670-red": [0, 1, 1], + "670-yellow": [0, 1, 1], + "671-red": [0, 1, 1], + "671-blue": [0, 1, 1], + "671-yellow": [0, 1, 1], + "671-white": [0, 1, 1], + "671-orange": [0, 1, 1], + "672": [0, 1, 1], + "673": [0, 1, 1], + "676": [0, 1, 1], + "676-dandy": [0, 1, 1], + "676-debutante": [0, 1, 1], + "676-diamond": [0, 1, 1], + "676-heart": [0, 1, 1], + "676-kabuki": [0, 1, 1], + "676-la-reine": [0, 1, 1], + "676-matron": [0, 1, 1], + "676-pharaoh": [0, 1, 1], + "676-star": [0, 1, 1], + "677": [0, 1, 1], + "678-female": [0, 1, 1], + "678": [0, 1, 1], + "682": [0, 1, 1], + "683": [0, 1, 1], + "684": [0, 1, 1], + "685": [0, 1, 1], + "688": [0, 1, 1], + "689": [0, 1, 1], + "690": [0, 1, 1], + "691": [0, 1, 1], + "696": [0, 1, 1], + "697": [0, 1, 1], + "698": [0, 1, 1], + "699": [0, 1, 1], + "700": [0, 1, 1], + "702": [0, 1, 1], + "703": [0, 1, 1], + "704": [0, 1, 1], + "705": [0, 1, 1], + "706": [0, 1, 1], + "708": [0, 1, 1], + "709": [0, 1, 1], + "710": [0, 1, 1], + "711": [1, 1, 1], + "712": [0, 1, 1], + "713": [0, 1, 1], + "714": [0, 1, 1], + "715": [0, 2, 2], + "716-active": [0, 1, 1], + "716-neutral": [0, 1, 1], + "717": [0, 1, 1], + "720-unbound": [1, 1, 1], + "720": [1, 1, 1], + "728": [0, 1, 1], + "729": [0, 1, 1], + "730": [0, 1, 1], + "734": [0, 1, 1], + "735": [0, 1, 1], + "742": [0, 2, 2], + "743": [0, 2, 2], + "747": [0, 1, 1], + "748": [0, 1, 1], + "751": [0, 1, 1], + "752": [0, 1, 1], + "753": [0, 1, 1], + "754": [0, 2, 2], + "755": [0, 1, 1], + "756": [0, 1, 1], + "761": [0, 1, 1], + "762": [0, 1, 1], + "763": [0, 1, 1], + "767": [0, 1, 1], + "768": [0, 1, 1], + "771": [0, 1, 1], + "772": [0, 1, 1], + "773-fighting": [0, 1, 1], + "773-psychic": [0, 1, 1], + "773-poison": [0, 1, 1], + "773-ground": [0, 1, 1], + "773-ghost": [0, 1, 1], + "773-steel": [0, 1, 1], + "773-rock": [0, 1, 1], + "773-grass": [0, 1, 1], + "773-dragon": [0, 1, 1], + "773-bug": [0, 1, 1], + "773-ice": [0, 1, 1], + "773-dark": [0, 1, 1], + "773": [0, 1, 1], + "773-fairy": [0, 1, 1], + "773-water": [0, 1, 1], + "773-electric": [0, 1, 1], + "773-flying": [0, 1, 1], + "773-fire": [0, 1, 1], + "776": [0, 1, 1], + "777": [0, 1, 1], + "778-busted": [0, 1, 1], + "778-disguised": [0, 1, 1], + "779": [0, 1, 1], + "789": [1, 1, 1], + "790": [0, 1, 1], + "791-radiant-sun": [0, 1, 1], + "791": [2, 1, 1], + "792-full-moon": [0, 1, 1], + "792": [0, 1, 1], + "793": [0, 1, 1], + "797": [0, 1, 1], + "798": [0, 1, 1], + "800-dawn-wings": [0, 1, 1], + "800-dusk-mane": [0, 1, 1], + "800-ultra": [0, 1, 1], + "800": [0, 1, 1], + "802": [1, 1, 1], + "803": [0, 1, 1], + "804": [0, 1, 1], + "807": [0, 1, 1], + "808": [0, 1, 1], + "809-gigantamax": [0, 1, 1], + "809": [0, 1, 1], + "816": [0, 1, 1], + "817": [0, 1, 1], + "818-gigantamax": [1, 1, 1], + "818": [0, 1, 1], + "821": [0, 1, 1], + "822": [0, 1, 1], + "823-gigantamax": [0, 2, 2], + "823": [0, 1, 1], + "829": [0, 1, 1], + "830": [0, 1, 1], + "835": [0, 1, 1], + "836": [0, 1, 1], + "850": [0, 1, 1], + "851-gigantamax": [0, 1, 1], + "851": [0, 1, 1], + "854": [0, 1, 1], + "855": [0, 1, 1], + "856": [0, 1, 1], + "857": [0, 2, 2], + "858-gigantamax": [0, 1, 1], + "858": [0, 1, 1], + "859": [0, 1, 1], + "860": [0, 1, 1], + "861-gigantamax": [0, 1, 1], + "861": [0, 1, 1], + "862": [0, 1, 1], + "863": [0, 1, 1], + "864": [0, 1, 1], + "867": [0, 1, 1], + "872": [1, 1, 1], + "873": [1, 1, 1], + "876-female": [0, 1, 1], + "876": [0, 1, 1], + "877-hangry": [1, 1, 1], + "877": [1, 1, 1], + "880": [0, 1, 1], + "881": [0, 2, 2], + "882": [0, 1, 1], + "883": [0, 1, 1], + "884-gigantamax": [0, 1, 1], + "884": [0, 1, 1], + "885": [1, 1, 1], + "886": [1, 1, 1], + "887": [1, 1, 1], + "888": [0, 1, 1], + "888-crowned": [0, 1, 1], + "889": [0, 1, 1], + "889-crowned": [0, 1, 1], + "890-eternamax": [0, 1, 1], + "890": [0, 1, 1], + "891": [1, 1, 1], + "892-gigantamax-rapid": [1, 2, 2], + "892-rapid-strike": [1, 1, 1], + "892": [1, 1, 1], + "892-gigantamax-single": [1, 2, 2], + "894": [0, 1, 1], + "895": [0, 1, 1], + "896": [1, 1, 1], + "897": [1, 1, 1], + "898": [1, 1, 1], + "898-ice": [1, 1, 1], + "898-shadow": [1, 1, 1], + "900": [0, 1, 1], + "901": [0, 1, 1], + "903": [0, 1, 1], + "909": [0, 1, 1], + "910": [0, 2, 2], + "911": [0, 1, 1], + "912": [0, 1, 1], + "913": [0, 1, 1], + "914": [0, 1, 1], + "919": [1, 1, 1], + "920": [1, 1, 1], + "924": [1, 1, 1], + "925-four": [1, 1, 1], + "925-three": [1, 1, 1], + "932": [0, 1, 1], + "933": [0, 1, 1], + "934": [0, 1, 1], + "935": [2, 2, 2], + "936": [1, 1, 1], + "937": [1, 1, 1], + "940": [0, 1, 1], + "941": [0, 1, 1], + "944": [0, 1, 1], + "945": [0, 1, 1], + "948": [0, 1, 1], + "949": [0, 1, 1], + "951": [0, 1, 1], + "952": [0, 1, 1], + "953": [0, 1, 1], + "954": [0, 1, 1], + "957": [1, 1, 1], + "958": [1, 1, 1], + "959": [1, 1, 1], + "962": [1, 1, 1], + "967": [0, 1, 1], + "968": [0, 1, 1], + "969": [0, 1, 1], + "970": [0, 1, 1], + "973": [1, 1, 1], + "974": [0, 1, 1], + "975": [0, 1, 1], + "978-curly": [0, 2, 2], + "978-droopy": [0, 2, 2], + "978-stretchy": [0, 1, 1], + "979": [1, 1, 1], + "981": [0, 1, 1], + "982": [0, 1, 2], + "982-three-segment": [0, 1, 2], + "987": [1, 1, 1], + "988": [0, 1, 1], + "993": [0, 1, 1], + "994": [0, 1, 1], + "995": [0, 1, 1], + "996": [0, 1, 1], + "997": [0, 1, 1], + "998": [0, 1, 1], + "999": [1, 1, 1], + "1000": [1, 1, 1], + "1001": [0, 1, 1], + "1003": [0, 1, 1], + "1004": [0, 1, 1], + "1006": [0, 2, 1], + "1007-apex-build": [0, 2, 2], + "1008-ultimate-mode": [1, 1, 1], + "1010": [0, 1, 1], + "1012-counterfeit": [0, 1, 1], + "1013-unremarkable": [0, 1, 1], + "1018": [0, 1, 1], + "1022": [0, 2, 2], + "1023": [0, 1, 1], + "2026": [0, 1, 1], + "2027": [0, 1, 1], + "2028": [0, 1, 1], + "2052": [0, 1, 1], + "2053": [0, 1, 1], + "2103": [0, 1, 1], + "2670": [0, 1, 1], + "4052": [0, 1, 1], + "4077": [0, 1, 1], + "4078": [0, 1, 1], + "4079": [0, 1, 1], + "4080": [2, 1, 1], + "4144": [0, 1, 1], + "4145": [0, 1, 1], + "4146": [0, 1, 1], + "4199": [2, 1, 1], + "4222": [0, 1, 1], + "4263": [0, 1, 1], + "4264": [0, 1, 1], + "4562": [0, 1, 1], + "6100": [0, 1, 1], + "6101": [0, 1, 1], + "6215": [0, 1, 1], + "6503": [0, 1, 1], + "6549": [0, 1, 1], + "6570": [0, 1, 1], + "6571": [0, 1, 1], + "6705": [0, 1, 1], + "6706": [0, 1, 1], + "6713": [0, 1, 1], + "8901": [1, 1, 1], "female": { - "3": [ - 0, - 1, - 1 - ], - "19": [ - 0, - 1, - 1 - ], - "20": [ - 0, - 1, - 1 - ], - "41": [ - 0, - 1, - 1 - ], - "42": [ - 0, - 1, - 1 - ], - "44": [ - 0, - 1, - 1 - ], - "45": [ - 0, - 1, - 1 - ], - "84": [ - 1, - 1, - 1 - ], - "85": [ - 1, - 1, - 1 - ], - "111": [ - 0, - 1, - 1 - ], - "112": [ - 0, - 1, - 1 - ], - "118": [ - 0, - 1, - 1 - ], - "119": [ - 0, - 1, - 1 - ], - "123": [ - 1, - 1, - 1 - ], - "129": [ - 0, - 1, - 1 - ], - "130": [ - 0, - 1, - 1 - ], - "178": [ - 0, - 2, - 2 - ], - "185": [ - 0, - 1, - 1 - ], - "190": [ - 0, - 1, - 1 - ], - "203": [ - 0, - 1, - 1 - ], - "207": [ - 0, - 1, - 1 - ], - "215": [ - 0, - 1, - 1 - ], - "217": [ - 1, - 1, - 1 - ], - "229": [ - 0, - 1, - 1 - ], - "232": [ - 0, - 1, - 1 - ], - "255": [ - 0, - 1, - 1 - ], - "256": [ - 0, - 1, - 1 - ], - "257": [ - 0, - 1, - 1 - ], - "307": [ - 0, - 1, - 1 - ], - "308": [ - 0, - 1, - 1 - ], - "315": [ - 0, - 1, - 1 - ], - "369": [ - 0, - 1, - 1 - ], - "399": [ - 0, - 2, - 1 - ], - "400": [ - 0, - 1, - 1 - ], - "401": [ - 0, - 1, - 1 - ], - "402": [ - 0, - 1, - 1 - ], - "407": [ - 0, - 1, - 1 - ], - "418": [ - 0, - 2, - 2 - ], - "419": [ - 0, - 1, - 1 - ], - "424": [ - 0, - 1, - 1 - ], - "443": [ - 1, - 1, - 1 - ], - "444": [ - 1, - 1, - 1 - ], - "445": [ - 1, - 1, - 1 - ], - "453": [ - 0, - 1, - 1 - ], - "454": [ - 0, - 1, - 1 - ], - "456": [ - 0, - 1, - 1 - ], - "457": [ - 0, - 1, - 1 - ], - "461": [ - 0, - 1, - 1 - ], - "464": [ - 0, - 1, - 1 - ], - "465": [ - 0, - 1, - 1 - ], - "592": [ - 1, - 1, - 1 - ], - "593": [ - 1, - 1, - 1 - ], - "6215": [ - 0, - 1, - 1 - ] + "3": [0,1, 1], + "19": [0, 1, 1], + "20": [0, 1, 1], + "25": [0, 1, 1], + "25-beauty-cosplay": [0, 1, 1], + "25-cool-cosplay": [0, 1, 1], + "25-cosplay": [0, 1, 1], + "25-cute-cosplay": [0, 1, 1], + "25-partner": [0, 1, 1], + "25-smart-cosplay": [0, 1, 1], + "25-tough-cosplay": [0, 1, 1], + "26": [0, 1, 1], + "41": [0, 1, 1], + "42": [0, 1, 1], + "44": [0, 1, 1], + "45": [0, 1, 1], + "84": [1, 1, 1], + "85": [1, 1, 1], + "111": [0, 1, 1], + "112": [0, 1, 1], + "118": [0, 1, 1], + "119": [0, 1, 1], + "123": [1, 1, 1], + "129": [0, 1, 1], + "130": [0, 1, 1], + "154": [0, 1, 1], + "178": [0, 2, 2], + "185": [0, 1, 1], + "190": [0, 1, 1], + "194": [0, 1, 1], + "195": [0, 1, 1], + "198": [0, 1, 1], + "203": [0, 1, 1], + "207": [0, 1, 1], + "215": [0, 1, 1], + "217": [1, 1, 1], + "229": [0, 1, 1], + "232": [0, 1, 1], + "255": [0, 1, 1], + "256": [0, 1, 1], + "257": [0, 1, 1], + "307": [0, 1, 1], + "308": [0, 1, 1], + "315": [0, 1, 1], + "369": [0, 1, 1], + "399": [0, 2, 1], + "400": [0, 1, 1], + "401": [0, 1, 1], + "402": [0, 1, 1], + "407": [0, 1, 1], + "418": [0, 2, 2], + "419": [0, 1, 1], + "424": [0, 1, 1], + "443": [1, 1, 1], + "444": [1, 1, 1], + "445": [1, 1, 1], + "453": [0, 1, 1], + "454": [0, 1, 1], + "456": [0, 1, 1], + "457": [0, 1, 1], + "461": [0, 1, 1], + "464": [0, 1, 1], + "465": [0, 1, 1], + "592": [1, 1, 1], + "593": [1, 1, 1], + "6215": [0, 1, 1] } }, "exp": { - "3-mega": [ - 0, - 2, - 2 - ], - "6-mega-x": [ - 0, - 2, - 2 - ], - "6-mega-y": [ - 0, - 2, - 2 - ], - "80-mega": [ - 0, - 1, - 1 - ], - "94-mega": [ - 2, - 2, - 2 - ], - "127-mega": [ - 0, - 1, - 1 - ], - "130-mega": [ - 0, - 1, - 1 - ], - "142-mega": [ - 0, - 1, - 1 - ], - "150-mega-x": [ - 0, - 1, - 1 - ], - "150-mega-y": [ - 0, - 1, - 1 - ], - "181-mega": [ - 0, - 1, - 2 - ], - "212-mega": [ - 1, - 1, - 2 - ], - "229-mega": [ - 0, - 1, - 1 - ], - "248-mega": [ - 0, - 1, - 1 - ], - "257-mega": [ - 0, - 1, - 1 - ], - "282-mega": [ - 0, - 2, - 2 - ], - "302-mega": [ - 0, - 1, - 1 - ], - "303-mega": [ - 0, - 1, - 1 - ], - "306-mega": [ - 1, - 1, - 1 - ], - "308-mega": [ - 0, - 1, - 1 - ], - "310-mega": [ - 0, - 1, - 1 - ], - "334-mega": [ - 0, - 2, - 1 - ], - "354-mega": [ - 0, - 1, - 1 - ], - "362-mega": [ - 0, - 1, - 1 - ], - "373-mega": [ - 0, - 1, - 1 - ], - "376-mega": [ - 0, - 1, - 1 - ], - "380-mega": [ - 0, - 1, - 1 - ], - "381-mega": [ - 0, - 1, - 1 - ], - "382-primal": [ - 0, - 1, - 1 - ], - "383-primal": [ - 0, - 1, - 1 - ], - "384-mega": [ - 0, - 2, - 1 - ], - "428-mega": [ - 0, - 1, - 1 - ], - "445-mega": [ - 1, - 1, - 1 - ], - "448-mega": [ - 1, - 1, - 1 - ], - "475-mega": [ - 0, - 2, - 2 - ], - "531-mega": [ - 0, - 1, - 1 - ], - "653": [ - 0, - 1, - 1 - ], - "654": [ - 0, - 1, - 1 - ], - "655": [ - 0, - 1, - 1 - ], - "664": [ - 0, - 1, - 1 - ], - "665": [ - 0, - 1, - 1 - ], - "666-archipelago": [ - 0, - 1, - 1 - ], - "666-continental": [ - 0, - 1, - 1 - ], - "666-elegant": [ - 0, - 1, - 1 - ], - "666-fancy": [ - 0, - 2, - 2 - ], - "666-garden": [ - 0, - 1, - 1 - ], - "666-high-plains": [ - 0, - 1, - 1 - ], - "666-icy-snow": [ - 0, - 1, - 1 - ], - "666-jungle": [ - 0, - 1, - 1 - ], - "666-marine": [ - 0, - 1, - 1 - ], - "666-meadow": [ - 0, - 2, - 2 - ], - "666-modern": [ - 0, - 1, - 1 - ], - "666-monsoon": [ - 0, - 1, - 1 - ], - "666-ocean": [ - 0, - 1, - 1 - ], - "666-poke-ball": [ - 0, - 1, - 2 - ], - "666-polar": [ - 0, - 1, - 1 - ], - "666-river": [ - 0, - 2, - 1 - ], - "666-sandstorm": [ - 0, - 1, - 1 - ], - "666-savanna": [ - 0, - 1, - 1 - ], - "666-sun": [ - 0, - 1, - 1 - ], - "666-tundra": [ - 0, - 1, - 1 - ], - "669-red": [ - 0, - 2, - 2 - ], - "669-blue": [ - 0, - 1, - 1 - ], - "669-white": [ - 0, - 1, - 1 - ], - "669-yellow": [ - 0, - 1, - 1 - ], - "669-orange": [ - 0, - 2, - 2 - ], - "670-white": [ - 0, - 1, - 1 - ], - "670-blue": [ - 0, - 1, - 1 - ], - "670-orange": [ - 0, - 1, - 1 - ], - "670-red": [ - 0, - 1, - 1 - ], - "670-yellow": [ - 0, - 1, - 1 - ], - "671-red": [ - 0, - 1, - 2 - ], - "671-blue": [ - 0, - 1, - 2 - ], - "671-yellow": [ - 0, - 1, - 1 - ], - "671-white": [ - 0, - 1, - 2 - ], - "671-orange": [ - 0, - 1, - 2 - ], - "672": [ - 0, - 1, - 1 - ], - "673": [ - 0, - 1, - 1 - ], - "677": [ - 0, - 1, - 1 - ], - "678-female": [ - 0, - 1, - 1 - ], - "678": [ - 0, - 1, - 1 - ], - "690": [ - 0, - 1, - 1 - ], - "691": [ - 0, - 1, - 1 - ], - "696": [ - 0, - 2, - 2 - ], - "697": [ - 0, - 1, - 2 - ], - "698": [ - 0, - 1, - 1 - ], - "699": [ - 0, - 1, - 1 - ], - "700": [ - 0, - 1, - 1 - ], - "702": [ - 0, - 1, - 1 - ], - "703": [ - 0, - 1, - 1 - ], - "704": [ - 0, - 1, - 1 - ], - "705": [ - 0, - 2, - 2 - ], - "706": [ - 0, - 1, - 1 - ], - "708": [ - 0, - 1, - 1 - ], - "709": [ - 0, - 1, - 1 - ], - "710": [ - 0, - 1, - 1 - ], - "711": [ - 1, - 1, - 1 - ], - "712": [ - 0, - 1, - 1 - ], - "713": [ - 0, - 1, - 1 - ], - "714": [ - 0, - 1, - 1 - ], - "715": [ - 0, - 2, - 1 - ], - "716-active": [ - 0, - 1, - 1 - ], - "716-neutral": [ - 0, - 1, - 1 - ], - "717": [ - 0, - 2, - 2 - ], - "720-unbound": [ - 1, - 1, - 1 - ], - "720": [ - 1, - 1, - 1 - ], - "728": [ - 0, - 1, - 1 - ], - "729": [ - 0, - 2, - 2 - ], - "730": [ - 0, - 2, - 1 - ], - "734": [ - 0, - 1, - 1 - ], - "735": [ - 0, - 1, - 1 - ], - "742": [ - 0, - 2, - 2 - ], - "743": [ - 0, - 2, - 2 - ], - "747": [ - 0, - 2, - 2 - ], - "748": [ - 0, - 1, - 1 - ], - "751": [ - 0, - 1, - 1 - ], - "752": [ - 0, - 1, - 1 - ], - "753": [ - 0, - 1, - 1 - ], - "754": [ - 0, - 2, - 2 - ], - "755": [ - 0, - 1, - 1 - ], - "756": [ - 0, - 1, - 1 - ], - "761": [ - 0, - 1, - 1 - ], - "762": [ - 0, - 1, - 1 - ], - "763": [ - 0, - 1, - 1 - ], - "767": [ - 0, - 1, - 1 - ], - "768": [ - 0, - 1, - 1 - ], - "770": [ - 0, - 0, - 0 - ], - "771": [ - 0, - 2, - 2 - ], - "772": [ - 0, - 1, - 1 - ], - "773-fighting": [ - 0, - 2, - 2 - ], - "773-psychic": [ - 0, - 2, - 2 - ], - "773-poison": [ - 0, - 2, - 2 - ], - "773-ground": [ - 0, - 2, - 2 - ], - "773-ghost": [ - 0, - 2, - 2 - ], - "773-steel": [ - 0, - 2, - 2 - ], - "773-rock": [ - 0, - 2, - 2 - ], - "773-grass": [ - 0, - 2, - 2 - ], - "773-dragon": [ - 0, - 2, - 2 - ], - "773-bug": [ - 0, - 2, - 2 - ], - "773-ice": [ - 0, - 2, - 2 - ], - "773-dark": [ - 0, - 2, - 2 - ], - "773": [ - 0, - 2, - 2 - ], - "773-fairy": [ - 0, - 2, - 2 - ], - "773-water": [ - 0, - 2, - 2 - ], - "773-electric": [ - 0, - 2, - 2 - ], - "773-flying": [ - 0, - 2, - 2 - ], - "773-fire": [ - 0, - 2, - 2 - ], - "776": [ - 0, - 1, - 1 - ], - "777": [ - 0, - 1, - 1 - ], - "778-busted": [ - 0, - 1, - 1 - ], - "778-disguised": [ - 0, - 1, - 1 - ], - "779": [ - 0, - 1, - 1 - ], - "789": [ - 1, - 1, - 1 - ], - "790": [ - 0, - 1, - 1 - ], - "791": [ - 2, - 1, - 1 - ], - "792": [ - 0, - 1, - 1 - ], - "793": [ - 0, - 2, - 2 - ], - "797": [ - 0, - 1, - 1 - ], - "798": [ - 0, - 1, - 1 - ], - "800-dawn-wings": [ - 0, - 1, - 1 - ], - "800-dusk-mane": [ - 0, - 1, - 1 - ], - "800-ultra": [ - 0, - 1, - 1 - ], - "800": [ - 0, - 1, - 1 - ], - "802": [ - 1, - 1, - 1 - ], - "803": [ - 0, - 1, - 1 - ], - "804": [ - 0, - 1, - 1 - ], - "808": [ - 0, - 1, - 1 - ], - "809": [ - 0, - 1, - 1 - ], - "816": [ - 0, - 1, - 1 - ], - "817": [ - 0, - 1, - 1 - ], - "818": [ - 1, - 1, - 1 - ], - "821": [ - 0, - 2, - 2 - ], - "822": [ - 0, - 1, - 1 - ], - "823": [ - 0, - 1, - 1 - ], - "829": [ - 0, - 1, - 1 - ], - "830": [ - 0, - 1, - 1 - ], - "835": [ - 0, - 1, - 1 - ], - "836": [ - 0, - 2, - 2 - ], - "850": [ - 0, - 1, - 1 - ], - "851": [ - 0, - 1, - 1 - ], - "854": [ - 0, - 1, - 1 - ], - "855": [ - 0, - 1, - 1 - ], - "856": [ - 0, - 1, - 1 - ], - "857": [ - 0, - 2, - 2 - ], - "858": [ - 0, - 1, - 1 - ], - "859": [ - 0, - 1, - 1 - ], - "860": [ - 0, - 1, - 1 - ], - "861": [ - 0, - 1, - 1 - ], - "862": [ - 0, - 1, - 1 - ], - "863": [ - 0, - 1, - 1 - ], - "864": [ - 0, - 1, - 1 - ], - "867": [ - 0, - 1, - 1 - ], - "872": [ - 1, - 1, - 1 - ], - "873": [ - 1, - 1, - 1 - ], - "876-female": [ - 0, - 1, - 1 - ], - "876": [ - 0, - 1, - 1 - ], - "877-hangry": [ - 1, - 1, - 1 - ], - "877": [ - 1, - 1, - 1 - ], - "880": [ - 0, - 1, - 1 - ], - "881": [ - 0, - 1, - 1 - ], - "882": [ - 0, - 2, - 1 - ], - "883": [ - 0, - 1, - 1 - ], - "884": [ - 0, - 1, - 1 - ], - "885": [ - 1, - 1, - 1 - ], - "886": [ - 1, - 1, - 1 - ], - "887": [ - 1, - 1, - 1 - ], - "888": [ - 0, - 1, - 1 - ], - "888-crowned": [ - 0, - 1, - 1 - ], - "889": [ - 0, - 1, - 1 - ], - "889-crowned": [ - 0, - 1, - 1 - ], - "890": [ - 0, - 2, - 1 - ], - "890-eternamax": [ - 0, - 1, - 1 - ], - "891": [ - 1, - 1, - 1 - ], - "892-rapid-strike": [ - 1, - 1, - 1 - ], - "892": [ - 1, - 1, - 1 - ], - "896": [ - 1, - 1, - 1 - ], - "897": [ - 1, - 1, - 1 - ], - "898": [ - 1, - 1, - 1 - ], - "898-ice": [ - 1, - 1, - 1 - ], - "898-shadow": [ - 1, - 1, - 1 - ], - "900": [ - 0, - 1, - 1 - ], - "901": [ - 0, - 1, - 1 - ], - "903": [ - 0, - 1, - 1 - ], - "909": [ - 0, - 1, - 1 - ], - "910": [ - 0, - 2, - 2 - ], - "911": [ - 0, - 2, - 2 - ], - "912": [ - 0, - 1, - 2 - ], - "913": [ - 0, - 1, - 2 - ], - "914": [ - 0, - 2, - 1 - ], - "919": [ - 1, - 1, - 1 - ], - "920": [ - 1, - 1, - 1 - ], - "924": [ - 1, - 1, - 1 - ], - "925-four": [ - 1, - 2, - 2 - ], - "925-three": [ - 1, - 2, - 2 - ], - "932": [ - 0, - 2, - 2 - ], - "933": [ - 0, - 2, - 2 - ], - "934": [ - 0, - 1, - 1 - ], - "935": [ - 1, - 1, - 2 - ], - "936": [ - 2, - 2, - 2 - ], - "937": [ - 2, - 2, - 2 - ], - "940": [ - 0, - 1, - 1 - ], - "941": [ - 0, - 1, - 1 - ], - "948": [ - 0, - 1, - 1 - ], - "949": [ - 0, - 1, - 1 - ], - "951": [ - 0, - 1, - 1 - ], - "952": [ - 0, - 1, - 1 - ], - "953": [ - 0, - 1, - 1 - ], - "954": [ - 0, - 1, - 1 - ], - "957": [ - 2, - 2, - 2 - ], - "958": [ - 2, - 2, - 2 - ], - "959": [ - 2, - 2, - 2 - ], - "962": [ - 1, - 1, - 1 - ], - "967": [ - 0, - 1, - 1 - ], - "968": [ - 0, - 1, - 1 - ], - "969": [ - 0, - 1, - 1 - ], - "970": [ - 0, - 1, - 1 - ], - "973": [ - 1, - 1, - 1 - ], - "974": [ - 0, - 1, - 1 - ], - "975": [ - 0, - 1, - 1 - ], - "978-curly": [ - 0, - 2, - 2 - ], - "978-droopy": [ - 0, - 2, - 2 - ], - "978-stretchy": [ - 0, - 2, - 2 - ], - "979": [ - 2, - 2, - 2 - ], - "981": [ - 0, - 1, - 1 - ], - "982": [ - 0, - 1, - 1 - ], - "982-three-segment": [ - 0, - 1, - 1 - ], - "987": [ - 1, - 1, - 1 - ], - "988": [ - 0, - 1, - 2 - ], - "993": [ - 0, - 1, - 1 - ], - "994": [ - 0, - 1, - 2 - ], - "995": [ - 0, - 1, - 1 - ], - "996": [ - 0, - 1, - 1 - ], - "997": [ - 0, - 2, - 2 - ], - "998": [ - 0, - 2, - 2 - ], - "999": [ - 2, - 1, - 1 - ], - "1000": [ - 1, - 1, - 1 - ], - "1001": [ - 0, - 1, - 1 - ], - "1003": [ - 0, - 1, - 1 - ], - "1004": [ - 0, - 1, - 1 - ], - "1006": [ - 0, - 2, - 1 - ], - "1007-apex-build": [ - 0, - 2, - 2 - ], - "1008-ultimate-mode": [ - 1, - 1, - 1 - ], - "2027": [ - 0, - 1, - 1 - ], - "2028": [ - 0, - 1, - 1 - ], - "2052": [ - 0, - 1, - 1 - ], - "2053": [ - 0, - 1, - 0 - ], - "4052": [ - 0, - 1, - 1 - ], - "4077": [ - 0, - 1, - 1 - ], - "4078": [ - 0, - 1, - 1 - ], - "4079": [ - 0, - 1, - 1 - ], - "4080": [ - 2, - 1, - 1 - ], - "4144": [ - 0, - 2, - 2 - ], - "4145": [ - 0, - 2, - 2 - ], - "4146": [ - 0, - 2, - 2 - ], - "4199": [ - 2, - 1, - 1 - ], - "4222": [ - 0, - 1, - 1 - ], - "4263": [ - 0, - 1, - 1 - ], - "4264": [ - 0, - 1, - 1 - ], - "4562": [ - 0, - 1, - 1 - ], - "6100": [ - 0, - 1, - 1 - ], - "6101": [ - 0, - 1, - 1 - ], - "6215": [ - 0, - 1, - 1 - ], - "6549": [ - 0, - 1, - 1 - ], - "6570": [ - 0, - 1, - 1 - ], - "6571": [ - 0, - 1, - 1 - ], - "6705": [ - 0, - 1, - 1 - ], - "6706": [ - 0, - 2, - 2 - ], + "3-mega": [0, 2, 2], + "6-mega-x": [0, 2, 2], + "6-mega-y": [0, 2, 2], + "80-mega": [0, 1, 1], + "94-mega": [2, 2, 2], + "127-mega": [0, 1, 1], + "130-mega": [0, 1, 1], + "142-mega": [0, 1, 1], + "150-mega-x": [0, 1, 1], + "150-mega-y": [0, 1, 1], + "181-mega": [0, 1, 2], + "212-mega": [1, 1, 2], + "229-mega": [0, 1, 1], + "248-mega": [0, 1, 1], + "257-mega": [0, 1, 1], + "282-mega": [0, 2, 2], + "302-mega": [0, 1, 1], + "303-mega": [0, 1, 1], + "306-mega": [1, 1, 1], + "308-mega": [0, 1, 1], + "310-mega": [0, 1, 1], + "334-mega": [0, 2, 1], + "354-mega": [0, 1, 1], + "359-mega": [0, 1, 1], + "362-mega": [0, 1, 1], + "373-mega": [0, 1, 1], + "376-mega": [0, 1, 1], + "380-mega": [0, 1, 1], + "381-mega": [0, 1, 1], + "382-primal": [0, 1, 1], + "383-primal": [0, 1, 1], + "384-mega": [0, 2, 1], + "428-mega": [0, 1, 1], + "445-mega": [1, 1, 1], + "448-mega": [1, 1, 1], + "475-mega": [0, 2, 2], + "531-mega": [0, 1, 1], + "653": [0, 1, 1], + "654": [0, 1, 1], + "655": [0, 1, 1], + "656": [0, 1, 1], + "657": [0, 1, 1], + "658": [0, 1, 1], + "658-ash": [0, 1, 1], + "664": [0, 1, 1], + "665": [0, 1, 1], + "666-archipelago": [0, 1, 1], + "666-continental": [0, 1, 1], + "666-elegant": [0, 1, 1], + "666-fancy": [0, 2, 2], + "666-garden": [0, 1, 1], + "666-high-plains": [0, 1, 1], + "666-icy-snow": [0, 1, 1], + "666-jungle": [0, 1, 1], + "666-marine": [0, 1, 1], + "666-meadow": [0, 2, 2], + "666-modern": [0, 1, 1], + "666-monsoon": [0, 1, 1], + "666-ocean": [0, 1, 1], + "666-poke-ball": [0, 1, 2], + "666-polar": [0, 1, 1], + "666-river": [0, 2, 1], + "666-sandstorm": [0, 1, 1], + "666-savanna": [0, 1, 1], + "666-sun": [0, 1, 1], + "666-tundra": [0, 1, 1], + "669-red": [0, 2, 2], + "669-blue": [0, 1, 1], + "669-white": [0, 1, 1], + "669-yellow": [0, 1, 1], + "669-orange": [0, 2, 2], + "670-white": [0, 1, 1], + "670-blue": [0, 1, 1], + "670-orange": [0, 1, 1], + "670-red": [0, 1, 1], + "670-yellow": [0, 1, 1], + "671-red": [0, 1, 2], + "671-blue": [0, 1, 2], + "671-yellow": [0, 1, 1], + "671-white": [0, 1, 2], + "671-orange": [0, 1, 2], + "672": [0, 1, 1], + "673": [0, 1, 1], + "676": [0, 1, 1], + "677": [0, 1, 1], + "678-female": [0, 1, 1], + "678": [0, 1, 1], + "682": [0, 1, 1], + "683": [0, 1, 1], + "684": [0, 1, 1], + "685": [0, 1, 1], + "688": [0, 1, 1], + "689": [0, 1, 1], + "690": [0, 1, 1], + "691": [0, 1, 1], + "696": [0, 1, 1], + "697": [0, 1, 1], + "698": [0, 1, 1], + "699": [0, 1, 1], + "700": [0, 1, 1], + "702": [0, 1, 1], + "703": [0, 1, 1], + "704": [0, 1, 1], + "705": [0, 1, 1], + "706": [0, 1, 1], + "708": [0, 1, 1], + "709": [0, 1, 1], + "710": [0, 1, 1], + "711": [1, 1, 1], + "712": [0, 1, 1], + "713": [0, 1, 1], + "714": [0, 1, 1], + "715": [0, 2, 1], + "716-active": [0, 1, 1], + "716-neutral": [0, 1, 1], + "717": [0, 2, 2], + "720-unbound": [1, 1, 1], + "720": [1, 1, 1], + "728": [0, 1, 1], + "729": [0, 2, 2], + "730": [0, 2, 1], + "734": [0, 1, 1], + "735": [0, 1, 1], + "742": [0, 2, 2], + "743": [0, 2, 2], + "747": [0, 2, 2], + "748": [0, 1, 1], + "751": [0, 1, 1], + "752": [0, 1, 1], + "753": [0, 1, 1], + "754": [0, 2, 2], + "755": [0, 1, 1], + "756": [0, 1, 1], + "761": [0, 1, 1], + "762": [0, 1, 1], + "763": [0, 1, 1], + "767": [0, 1, 1], + "768": [0, 1, 1], + "770": [0, 0, 0], + "771": [0, 2, 2], + "772": [0, 1, 1], + "773-fighting": [0, 1, 1], + "773-psychic": [0, 1, 1], + "773-poison": [0, 1, 1], + "773-ground": [0, 1, 1], + "773-ghost": [0, 1, 1], + "773-steel": [0, 1, 1], + "773-rock": [0, 1, 1], + "773-grass": [0, 1, 1], + "773-dragon": [0, 1, 1], + "773-bug": [0, 1, 1], + "773-ice": [0, 1, 1], + "773-dark": [0, 1, 1], + "773": [0, 1, 1], + "773-fairy": [0, 1, 1], + "773-water": [0, 1, 1], + "773-electric": [0, 1, 1], + "773-flying": [0, 1, 1], + "773-fire": [0, 1, 1], + "776": [0, 1, 1], + "777": [0, 1, 1], + "778-busted": [0, 1, 1], + "778-disguised": [0, 1, 1], + "779": [0, 1, 1], + "789": [1, 1, 1], + "790": [0, 1, 1], + "791": [2, 1, 1], + "792": [0, 1, 1], + "793": [0, 2, 2], + "797": [0, 1, 1], + "798": [0, 1, 1], + "800-dawn-wings": [0, 1, 1], + "800-dusk-mane": [0, 1, 1], + "800-ultra": [0, 1, 1], + "800": [0, 1, 1], + "802": [1, 1, 1], + "803": [0, 1, 1], + "804": [0, 1, 1], + "807": [0, 1, 1], + "808": [0, 1, 1], + "809": [0, 1, 1], + "816": [0, 1, 1], + "817": [0, 1, 1], + "818": [1, 1, 1], + "821": [0, 2, 2], + "822": [0, 1, 1], + "823": [0, 1, 1], + "829": [0, 1, 1], + "830": [0, 1, 1], + "835": [0, 1, 1], + "836": [0, 2, 2], + "850": [0, 1, 1], + "851": [0, 1, 1], + "854": [0, 1, 1], + "855": [0, 1, 1], + "856": [0, 1, 1], + "857": [0, 2, 2], + "858": [0, 1, 1], + "859": [0, 1, 1], + "860": [0, 1, 1], + "861": [0, 1, 1], + "862": [0, 1, 1], + "863": [0, 1, 1], + "864": [0, 1, 1], + "867": [0, 1, 1], + "872": [1, 1, 1], + "873": [1, 1, 1], + "876-female": [0, 1, 1], + "876": [0, 1, 1], + "877-hangry": [1, 1, 1], + "877": [1, 1, 1], + "880": [0, 1, 1], + "881": [0, 1, 1], + "882": [0, 2, 1], + "883": [0, 1, 1], + "884": [0, 1, 1], + "885": [1, 1, 1], + "886": [1, 1, 1], + "887": [1, 1, 1], + "888": [0, 1, 1], + "888-crowned": [0, 1, 1], + "889": [0, 1, 1], + "889-crowned": [0, 1, 1], + "890": [0, 2, 1], + "890-eternamax": [0, 1, 1], + "891": [1, 1, 1], + "892-rapid-strike": [1, 1, 1], + "892": [1, 1, 1], + "894": [0, 1, 1], + "895": [0, 1, 1], + "896": [1, 1, 1], + "897": [1, 1, 1], + "898": [1, 1, 1], + "898-ice": [1, 1, 1], + "898-shadow": [1, 1, 1], + "900": [0, 1, 1], + "901": [0, 1, 1], + "903": [0, 1, 1], + "909": [0, 1, 1], + "910": [0, 2, 2], + "911": [0, 2, 2], + "912": [0, 1, 2], + "913": [0, 1, 2], + "914": [0, 2, 1], + "919": [1, 1, 1], + "920": [1, 1, 1], + "924": [1, 1, 1], + "925-four": [1, 2, 2], + "925-three": [1, 2, 2], + "932": [0, 2, 2], + "933": [0, 2, 2], + "934": [0, 1, 1], + "935": [1, 1, 2], + "936": [2, 2, 2], + "937": [2, 2, 2], + "940": [0, 1, 1], + "941": [0, 1, 1], + "944": [0, 1, 1], + "945": [0, 1, 1], + "948": [0, 1, 1], + "949": [0, 1, 1], + "951": [0, 1, 1], + "952": [0, 1, 1], + "953": [0, 1, 1], + "954": [0, 1, 1], + "957": [2, 2, 2], + "958": [2, 2, 2], + "959": [2, 2, 2], + "962": [1, 1, 1], + "967": [0, 1, 1], + "968": [0, 1, 1], + "969": [0, 1, 1], + "970": [0, 1, 1], + "973": [1, 1, 1], + "974": [0, 1, 1], + "975": [0, 1, 1], + "978-curly": [0, 2, 2], + "978-droopy": [0, 2, 2], + "978-stretchy": [0, 2, 2], + "979": [2, 2, 2], + "981": [0, 1, 1], + "982": [0, 1, 1], + "982-three-segment": [0, 1, 1], + "987": [1, 1, 1], + "988": [0, 1, 2], + "993": [0, 1, 1], + "994": [0, 1, 2], + "995": [0, 1, 1], + "996": [0, 1, 1], + "997": [0, 2, 2], + "998": [0, 2, 2], + "999": [2, 1, 1], + "1000": [1, 1, 1], + "1001": [0, 1, 1], + "1003": [0, 1, 1], + "1004": [0, 1, 1], + "1006": [0, 2, 1], + "1007-apex-build": [0, 2, 2], + "1008-ultimate-mode": [1, 1, 1], + "2026": [0, 1, 1], + "2027": [0, 1, 1], + "2028": [0, 1, 1], + "2052": [0, 1, 1], + "2053": [0, 1, 0], + "2103": [0, 1, 1], + "4052": [0, 1, 1], + "4077": [0, 1, 1], + "4078": [0, 1, 1], + "4079": [0, 1, 1], + "4080": [2, 1, 1], + "4144": [0, 1, 1], + "4145": [0, 1, 1], + "4146": [0, 1, 1], + "4199": [2, 1, 1], + "4222": [0, 1, 1], + "4263": [0, 1, 1], + "4264": [0, 1, 1], + "4562": [0, 1, 1], + "6100": [0, 1, 1], + "6101": [0, 1, 1], + "6215": [0, 1, 1], + "6503": [0, 1, 1], + "6549": [0, 1, 1], + "6570": [0, 1, 1], + "6571": [0, 1, 1], + "6705": [0, 1, 1], + "6706": [0, 1, 1], + "6713": [0, 1, 1], "female": {}, "back": { - "3-mega": [ - 0, - 2, - 2 - ], - "6-mega-x": [ - 0, - 2, - 2 - ], - "6-mega-y": [ - 0, - 1, - 2 - ], - "80-mega": [ - 0, - 1, - 1 - ], - "94-mega": [ - 1, - 1, - 1 - ], - "127-mega": [ - 0, - 1, - 1 - ], - "130-mega": [ - 0, - 1, - 1 - ], - "142-mega": [ - 0, - 1, - 1 - ], - "150-mega-x": [ - 0, - 1, - 1 - ], - "150-mega-y": [ - 0, - 1, - 1 - ], - "181-mega": [ - 0, - 1, - 2 - ], - "212-mega": [ - 1, - 2, - 2 - ], - "229-mega": [ - 0, - 1, - 1 - ], - "248-mega": [ - 0, - 2, - 1 - ], - "257-mega": [ - 0, - 1, - 1 - ], - "282-mega": [ - 0, - 1, - 1 - ], - "302-mega": [ - 0, - 1, - 1 - ], - "303-mega": [ - 0, - 1, - 1 - ], - "306-mega": [ - 1, - 1, - 1 - ], - "308-mega": [ - 0, - 1, - 1 - ], - "310-mega": [ - 0, - 1, - 1 - ], - "334-mega": [ - 0, - 1, - 1 - ], - "354-mega": [ - 0, - 1, - 1 - ], - "362-mega": [ - 0, - 1, - 1 - ], - "373-mega": [ - 0, - 1, - 1 - ], - "376-mega": [ - 0, - 1, - 1 - ], - "380-mega": [ - 0, - 1, - 1 - ], - "381-mega": [ - 0, - 1, - 1 - ], - "382-primal": [ - 0, - 1, - 1 - ], - "383-primal": [ - 0, - 1, - 1 - ], - "384-mega": [ - 0, - 1, - 1 - ], - "428-mega": [ - 0, - 1, - 1 - ], - "445-mega": [ - 1, - 1, - 1 - ], - "448-mega": [ - 1, - 1, - 1 - ], - "475-mega": [ - 0, - 2, - 2 - ], - "531-mega": [ - 0, - 1, - 1 - ], - "653": [ - 0, - 1, - 1 - ], - "654": [ - 0, - 1, - 1 - ], - "655": [ - 0, - 1, - 1 - ], - "664": [ - 0, - 1, - 1 - ], - "665": [ - 0, - 2, - 1 - ], - "666-archipelago": [ - 0, - 2, - 2 - ], - "666-continental": [ - 0, - 2, - 2 - ], - "666-elegant": [ - 0, - 2, - 2 - ], - "666-fancy": [ - 0, - 2, - 2 - ], - "666-garden": [ - 0, - 2, - 2 - ], - "666-high-plains": [ - 0, - 2, - 2 - ], - "666-icy-snow": [ - 0, - 2, - 2 - ], - "666-jungle": [ - 0, - 2, - 2 - ], - "666-marine": [ - 0, - 2, - 2 - ], - "666-meadow": [ - 0, - 2, - 2 - ], - "666-modern": [ - 0, - 2, - 2 - ], - "666-monsoon": [ - 0, - 2, - 2 - ], - "666-ocean": [ - 0, - 2, - 2 - ], - "666-poke-ball": [ - 0, - 2, - 2 - ], - "666-polar": [ - 0, - 2, - 2 - ], - "666-river": [ - 0, - 2, - 2 - ], - "666-sandstorm": [ - 0, - 2, - 2 - ], - "666-savanna": [ - 0, - 2, - 2 - ], - "666-sun": [ - 0, - 2, - 2 - ], - "666-tundra": [ - 0, - 2, - 2 - ], - "669-red": [ - 0, - 2, - 2 - ], - "669-blue": [ - 0, - 2, - 2 - ], - "669-white": [ - 0, - 2, - 2 - ], - "669-yellow": [ - 0, - 2, - 2 - ], - "669-orange": [ - 0, - 2, - 2 - ], - "670-white": [ - 0, - 1, - 1 - ], - "670-blue": [ - 0, - 2, - 2 - ], - "670-orange": [ - 0, - 1, - 1 - ], - "670-red": [ - 0, - 1, - 1 - ], - "670-yellow": [ - 0, - 1, - 1 - ], - "671-red": [ - 0, - 1, - 1 - ], - "671-blue": [ - 0, - 1, - 1 - ], - "671-yellow": [ - 0, - 1, - 1 - ], - "671-white": [ - 0, - 1, - 1 - ], - "671-orange": [ - 0, - 1, - 1 - ], - "672": [ - 0, - 1, - 1 - ], - "673": [ - 0, - 1, - 1 - ], - "677": [ - 0, - 1, - 1 - ], - "678-female": [ - 0, - 1, - 1 - ], - "678": [ - 0, - 1, - 1 - ], - "690": [ - 0, - 1, - 1 - ], - "691": [ - 0, - 1, - 1 - ], - "696": [ - 2, - 2, - 2 - ], - "697": [ - 0, - 1, - 2 - ], - "698": [ - 0, - 1, - 1 - ], - "699": [ - 0, - 2, - 2 - ], - "700": [ - 0, - 1, - 1 - ], - "702": [ - 0, - 1, - 1 - ], - "703": [ - 0, - 1, - 1 - ], - "704": [ - 0, - 1, - 1 - ], - "705": [ - 0, - 1, - 1 - ], - "706": [ - 0, - 1, - 1 - ], - "708": [ - 0, - 1, - 1 - ], - "709": [ - 0, - 1, - 1 - ], - "710": [ - 0, - 1, - 1 - ], - "711": [ - 1, - 1, - 1 - ], - "712": [ - 0, - 1, - 1 - ], - "713": [ - 0, - 1, - 1 - ], - "714": [ - 0, - 1, - 1 - ], - "715": [ - 0, - 1, - 1 - ], - "716-active": [ - 0, - 1, - 1 - ], - "716-neutral": [ - 0, - 1, - 1 - ], - "717": [ - 0, - 1, - 1 - ], - "720-unbound": [ - 1, - 1, - 1 - ], - "720": [ - 1, - 1, - 1 - ], - "728": [ - 0, - 1, - 1 - ], - "729": [ - 0, - 2, - 2 - ], - "730": [ - 0, - 2, - 1 - ], - "734": [ - 0, - 1, - 1 - ], - "735": [ - 0, - 1, - 1 - ], - "742": [ - 0, - 2, - 2 - ], - "743": [ - 0, - 2, - 2 - ], - "747": [ - 0, - 2, - 2 - ], - "748": [ - 0, - 1, - 1 - ], - "751": [ - 0, - 1, - 1 - ], - "752": [ - 0, - 1, - 1 - ], - "753": [ - 0, - 1, - 1 - ], - "754": [ - 0, - 2, - 2 - ], - "755": [ - 0, - 1, - 1 - ], - "756": [ - 0, - 1, - 1 - ], - "761": [ - 0, - 1, - 1 - ], - "762": [ - 0, - 1, - 1 - ], - "763": [ - 0, - 1, - 1 - ], - "767": [ - 0, - 1, - 1 - ], - "768": [ - 0, - 1, - 1 - ], - "771": [ - 0, - 1, - 1 - ], - "772": [ - 0, - 1, - 1 - ], - "773-fighting": [ - 0, - 2, - 2 - ], - "773-psychic": [ - 0, - 2, - 2 - ], - "773-poison": [ - 0, - 2, - 2 - ], - "773-ground": [ - 0, - 2, - 2 - ], - "773-ghost": [ - 0, - 2, - 2 - ], - "773-steel": [ - 0, - 2, - 2 - ], - "773-rock": [ - 0, - 2, - 2 - ], - "773-grass": [ - 0, - 2, - 2 - ], - "773-dragon": [ - 0, - 2, - 2 - ], - "773-bug": [ - 0, - 2, - 2 - ], - "773-ice": [ - 0, - 2, - 2 - ], - "773-dark": [ - 0, - 2, - 2 - ], - "773": [ - 0, - 1, - 1 - ], - "773-fairy": [ - 0, - 2, - 2 - ], - "773-water": [ - 0, - 2, - 2 - ], - "773-electric": [ - 0, - 2, - 2 - ], - "773-flying": [ - 0, - 2, - 2 - ], - "773-fire": [ - 0, - 2, - 2 - ], - "776": [ - 0, - 2, - 2 - ], - "777": [ - 0, - 1, - 1 - ], - "778-busted": [ - 0, - 1, - 1 - ], - "778-disguised": [ - 0, - 1, - 1 - ], - "779": [ - 0, - 1, - 1 - ], - "789": [ - 1, - 1, - 1 - ], - "790": [ - 0, - 1, - 1 - ], - "791": [ - 1, - 1, - 1 - ], - "792": [ - 0, - 1, - 1 - ], - "793": [ - 0, - 1, - 1 - ], - "797": [ - 0, - 1, - 1 - ], - "798": [ - 0, - 1, - 1 - ], - "800-dawn-wings": [ - 0, - 1, - 1 - ], - "800-dusk-mane": [ - 0, - 1, - 1 - ], - "800-ultra": [ - 0, - 1, - 1 - ], - "800": [ - 0, - 1, - 1 - ], - "802": [ - 1, - 1, - 1 - ], - "803": [ - 0, - 1, - 1 - ], - "804": [ - 0, - 1, - 1 - ], - "808": [ - 0, - 1, - 1 - ], - "809": [ - 0, - 1, - 1 - ], - "816": [ - 0, - 1, - 1 - ], - "817": [ - 0, - 1, - 1 - ], - "818": [ - 0, - 1, - 1 - ], - "821": [ - 0, - 1, - 1 - ], - "822": [ - 0, - 1, - 1 - ], - "823": [ - 0, - 1, - 1 - ], - "829": [ - 0, - 1, - 1 - ], - "830": [ - 0, - 1, - 1 - ], - "835": [ - 0, - 1, - 1 - ], - "836": [ - 0, - 1, - 1 - ], - "850": [ - 0, - 1, - 1 - ], - "851": [ - 0, - 1, - 1 - ], - "854": [ - 0, - 1, - 1 - ], - "855": [ - 0, - 1, - 1 - ], - "856": [ - 0, - 1, - 1 - ], - "857": [ - 0, - 2, - 2 - ], - "858": [ - 0, - 1, - 1 - ], - "859": [ - 0, - 1, - 1 - ], - "860": [ - 0, - 1, - 1 - ], - "861": [ - 0, - 1, - 1 - ], - "862": [ - 0, - 1, - 1 - ], - "863": [ - 0, - 1, - 1 - ], - "864": [ - 0, - 1, - 1 - ], - "867": [ - 0, - 1, - 1 - ], - "872": [ - 1, - 1, - 1 - ], - "873": [ - 1, - 1, - 1 - ], - "876-female": [ - 0, - 1, - 1 - ], - "876": [ - 0, - 1, - 1 - ], - "877-hangry": [ - 1, - 1, - 1 - ], - "877": [ - 1, - 1, - 1 - ], - "880": [ - 0, - 1, - 1 - ], - "881": [ - 0, - 1, - 1 - ], - "882": [ - 0, - 1, - 1 - ], - "883": [ - 0, - 1, - 1 - ], - "884": [ - 0, - 1, - 1 - ], - "885": [ - 1, - 1, - 1 - ], - "886": [ - 1, - 1, - 1 - ], - "887": [ - 1, - 1, - 1 - ], - "888": [ - 0, - 1, - 1 - ], - "888-crowned": [ - 0, - 1, - 1 - ], - "889": [ - 0, - 1, - 1 - ], - "889-crowned": [ - 0, - 1, - 1 - ], - "890": [ - 0, - 1, - 1 - ], - "891": [ - 1, - 1, - 1 - ], - "892-rapid-strike": [ - 1, - 1, - 1 - ], - "892": [ - 1, - 1, - 1 - ], - "896": [ - 1, - 1, - 1 - ], - "897": [ - 1, - 1, - 1 - ], - "898": [ - 1, - 1, - 1 - ], - "898-ice": [ - 1, - 1, - 1 - ], - "898-shadow": [ - 1, - 1, - 1 - ], - "900": [ - 0, - 1, - 1 - ], - "901": [ - 0, - 1, - 1 - ], - "903": [ - 0, - 1, - 1 - ], - "909": [ - 0, - 1, - 1 - ], - "910": [ - 0, - 2, - 2 - ], - "911": [ - 0, - 1, - 1 - ], - "912": [ - 0, - 1, - 1 - ], - "913": [ - 0, - 1, - 1 - ], - "914": [ - 0, - 2, - 2 - ], - "919": [ - 1, - 1, - 1 - ], - "920": [ - 1, - 1, - 1 - ], - "924": [ - 1, - 1, - 1 - ], - "925-four": [ - 1, - 2, - 2 - ], - "925-three": [ - 1, - 2, - 2 - ], - "932": [ - 0, - 1, - 1 - ], - "933": [ - 0, - 1, - 1 - ], - "934": [ - 0, - 1, - 1 - ], - "935": [ - 2, - 2, - 2 - ], - "936": [ - 2, - 2, - 2 - ], - "937": [ - 2, - 2, - 2 - ], - "940": [ - 0, - 1, - 1 - ], - "941": [ - 0, - 1, - 1 - ], - "948": [ - 0, - 1, - 1 - ], - "949": [ - 0, - 1, - 1 - ], - "951": [ - 0, - 1, - 1 - ], - "952": [ - 0, - 2, - 1 - ], - "953": [ - 0, - 1, - 1 - ], - "954": [ - 0, - 1, - 1 - ], - "957": [ - 1, - 1, - 1 - ], - "958": [ - 1, - 1, - 1 - ], - "959": [ - 1, - 1, - 1 - ], - "962": [ - 1, - 1, - 1 - ], - "967": [ - 0, - 1, - 1 - ], - "968": [ - 0, - 2, - 2 - ], - "969": [ - 0, - 1, - 1 - ], - "970": [ - 0, - 1, - 1 - ], - "973": [ - 1, - 1, - 1 - ], - "974": [ - 0, - 1, - 1 - ], - "975": [ - 0, - 1, - 1 - ], - "978-curly": [ - 0, - 2, - 2 - ], - "978-droopy": [ - 0, - 2, - 2 - ], - "978-stretchy": [ - 0, - 1, - 1 - ], - "979": [ - 1, - 1, - 1 - ], - "981": [ - 0, - 1, - 1 - ], - "982": [ - 0, - 1, - 1 - ], - "982-three-segment": [ - 0, - 1, - 1 - ], - "987": [ - 1, - 1, - 1 - ], - "988": [ - 0, - 1, - 1 - ], - "993": [ - 0, - 1, - 1 - ], - "994": [ - 0, - 1, - 1 - ], - "995": [ - 0, - 1, - 1 - ], - "996": [ - 0, - 1, - 1 - ], - "997": [ - 0, - 1, - 1 - ], - "998": [ - 0, - 1, - 1 - ], - "999": [ - 1, - 1, - 1 - ], - "1000": [ - 1, - 1, - 1 - ], - "1001": [ - 0, - 1, - 1 - ], - "1003": [ - 0, - 1, - 1 - ], - "1004": [ - 0, - 1, - 1 - ], - "1006": [ - 0, - 2, - 2 - ], - "1007-apex-build": [ - 0, - 2, - 2 - ], - "1008-ultimate-mode": [ - 1, - 1, - 1 - ], - "2027": [ - 0, - 1, - 1 - ], - "2028": [ - 0, - 1, - 1 - ], - "2052": [ - 0, - 1, - 1 - ], - "2053": [ - 0, - 1, - 1 - ], - "4052": [ - 0, - 1, - 1 - ], - "4077": [ - 0, - 1, - 1 - ], - "4078": [ - 0, - 1, - 1 - ], - "4079": [ - 0, - 1, - 1 - ], - "4080": [ - 2, - 2, - 2 - ], - "4144": [ - 0, - 1, - 1 - ], - "4145": [ - 0, - 1, - 1 - ], - "4146": [ - 0, - 1, - 1 - ], - "4199": [ - 2, - 1, - 1 - ], - "4222": [ - 0, - 1, - 1 - ], - "4263": [ - 0, - 1, - 1 - ], - "4264": [ - 0, - 1, - 1 - ], - "4562": [ - 0, - 1, - 1 - ], - "6100": [ - 0, - 1, - 1 - ], - "6101": [ - 0, - 1, - 1 - ], - "6215": [ - 0, - 1, - 1 - ], - "6549": [ - 0, - 1, - 1 - ], - "6570": [ - 0, - 1, - 1 - ], - "6571": [ - 0, - 1, - 1 - ], - "6705": [ - 0, - 1, - 1 - ], - "6706": [ - 0, - 2, - 2 - ], - "6713": [ - 0, - 1, - 1 - ] - }, - "6713": [ - 0, - 1, - 1 - ] + "3-mega": [0, 2, 2], + "6-mega-x": [0, 2, 2], + "6-mega-y": [0, 1, 2], + "80-mega": [0, 1, 1], + "94-mega": [1, 1, 1], + "127-mega": [0, 1, 1], + "130-mega": [0, 1, 1], + "142-mega": [0, 1, 1], + "150-mega-x": [0, 1, 1], + "150-mega-y": [0, 1, 1], + "181-mega": [0, 1, 2], + "212-mega": [1, 2, 2], + "229-mega": [0, 1, 1], + "248-mega": [0, 2, 1], + "257-mega": [0, 1, 1], + "282-mega": [0, 1, 1], + "302-mega": [0, 1, 1], + "303-mega": [0, 1, 1], + "306-mega": [1, 1, 1], + "308-mega": [0, 1, 1], + "310-mega": [0, 1, 1], + "334-mega": [0, 1, 1], + "354-mega": [0, 1, 1], + "359-mega": [0, 1, 1], + "362-mega": [0, 1, 1], + "373-mega": [0, 1, 1], + "376-mega": [0, 1, 1], + "380-mega": [0, 1, 1], + "381-mega": [0, 1, 1], + "382-primal": [0, 1, 1], + "383-primal": [0, 1, 1], + "384-mega": [0, 1, 1], + "428-mega": [0, 1, 1], + "445-mega": [1, 1, 1], + "448-mega": [1, 1, 1], + "475-mega": [0, 2, 2], + "531-mega": [0, 1, 1], + "653": [0, 1, 1], + "654": [0, 1, 1], + "655": [0, 1, 1], + "656": [0, 1, 1], + "657": [0, 1, 1], + "658": [0, 1, 1], + "658-ash": [0, 1, 1], + "664": [0, 1, 1], + "665": [0, 2, 1], + "666-archipelago": [0, 2, 2], + "666-continental": [0, 2, 2], + "666-elegant": [0, 2, 2], + "666-fancy": [0, 2, 2], + "666-garden": [0, 2, 2], + "666-high-plains": [0, 2, 2], + "666-icy-snow": [0, 2, 2], + "666-jungle": [0, 2, 2], + "666-marine": [0, 2, 2], + "666-meadow": [0, 2, 2], + "666-modern": [0, 2, 2], + "666-monsoon": [0, 2, 2], + "666-ocean": [0, 2, 2], + "666-poke-ball": [0, 2, 2], + "666-polar": [0, 2, 2], + "666-river": [0, 2, 2], + "666-sandstorm": [0, 2, 2], + "666-savanna": [0, 2, 2], + "666-sun": [0, 2, 2], + "666-tundra": [0, 2, 2], + "669-red": [0, 2, 2], + "669-blue": [0, 2, 2], + "669-white": [0, 2, 2], + "669-yellow": [0, 2, 2], + "669-orange": [0, 2, 2], + "670-white": [0, 1, 1], + "670-blue": [0, 2, 2], + "670-orange": [0, 1, 1], + "670-red": [0, 1, 1], + "670-yellow": [0, 1, 1], + "671-red": [0, 1, 1], + "671-blue": [0, 1, 1], + "671-yellow": [0, 1, 1], + "671-white": [0, 1, 1], + "671-orange": [0, 1, 1], + "672": [0, 1, 1], + "673": [0, 1, 1], + "676": [0, 1, 1], + "677": [0, 1, 1], + "678-female": [0, 1, 1], + "678": [0, 1, 1], + "682": [0, 1, 1], + "683": [0, 1, 1], + "684": [0, 1, 1], + "685": [0, 1, 1], + "688": [0, 1, 1], + "689": [0, 1, 1], + "690": [0, 1, 1], + "691": [0, 1, 1], + "696": [0, 1, 1], + "697": [0, 1, 1], + "698": [0, 1, 1], + "699": [0, 2, 2], + "700": [0, 1, 1], + "702": [0, 1, 1], + "703": [0, 1, 1], + "704": [0, 1, 1], + "705": [0, 1, 1], + "706": [0, 1, 1], + "708": [0, 1, 1], + "709": [0, 1, 1], + "710": [0, 1, 1], + "711": [1, 1, 1], + "712": [0, 1, 1], + "713": [0, 1, 1], + "714": [0, 1, 1], + "715": [0, 1, 1], + "716-active": [0, 1, 1], + "716-neutral": [0, 1, 1], + "717": [0, 1, 1], + "720-unbound": [1, 1, 1], + "720": [1, 1, 1], + "728": [0, 1, 1], + "729": [0, 2, 2], + "730": [0, 2, 1], + "734": [0, 1, 1], + "735": [0, 1, 1], + "742": [0, 2, 2], + "743": [0, 2, 2], + "747": [0, 2, 2], + "748": [0, 1, 1], + "751": [0, 1, 1], + "752": [0, 1, 1], + "753": [0, 1, 1], + "754": [0, 2, 2], + "755": [0, 1, 1], + "756": [0, 1, 1], + "761": [0, 1, 1], + "762": [0, 1, 1], + "763": [0, 1, 1], + "767": [0, 1, 1], + "768": [0, 1, 1], + "771": [0, 1, 1], + "772": [0, 1, 1], + "773-fighting": [0, 1, 1], + "773-psychic": [0, 1, 1], + "773-poison": [0, 1, 1], + "773-ground": [0, 1, 1], + "773-ghost": [0, 1, 1], + "773-steel": [0, 1, 1], + "773-rock": [0, 1, 1], + "773-grass": [0, 1, 1], + "773-dragon": [0, 1, 1], + "773-bug": [0, 1, 1], + "773-ice": [0, 1, 1], + "773-dark": [0, 1, 1], + "773": [0, 1, 1], + "773-fairy": [0, 1, 1], + "773-water": [0, 1, 1], + "773-electric": [0, 1, 1], + "773-flying": [0, 1, 1], + "773-fire": [0, 1, 1], + "776": [0, 2, 2], + "777": [0, 1, 1], + "778-busted": [0, 1, 1], + "778-disguised": [0, 1, 1], + "779": [0, 1, 1], + "789": [1, 1, 1], + "790": [0, 1, 1], + "791": [1, 1, 1], + "792": [0, 1, 1], + "793": [0, 1, 1], + "797": [0, 1, 1], + "798": [0, 1, 1], + "800-dawn-wings": [0, 1, 1], + "800-dusk-mane": [0, 1, 1], + "800-ultra": [0, 1, 1], + "800": [0, 1, 1], + "802": [1, 1, 1], + "803": [0, 1, 1], + "804": [0, 1, 1], + "807": [0, 1, 1], + "808": [0, 1, 1], + "809": [0, 1, 1], + "816": [0, 1, 1], + "817": [0, 1, 1], + "818": [0, 1, 1], + "821": [0, 1, 1], + "822": [0, 1, 1], + "823": [0, 1, 1], + "829": [0, 1, 1], + "830": [0, 1, 1], + "835": [0, 1, 1], + "836": [0, 1, 1], + "850": [0, 1, 1], + "851": [0, 1, 1], + "854": [0, 1, 1], + "855": [0, 1, 1], + "856": [0, 1, 1], + "857": [0, 2, 2], + "858": [0, 1, 1], + "859": [0, 1, 1], + "860": [0, 1, 1], + "861": [0, 1, 1], + "862": [0, 1, 1], + "863": [0, 1, 1], + "864": [0, 1, 1], + "867": [0, 1, 1], + "872": [1, 1, 1], + "873": [1, 1, 1], + "876-female": [0, 1, 1], + "876": [0, 1, 1], + "877-hangry": [1, 1, 1], + "877": [1, 1, 1], + "880": [0, 1, 1], + "881": [0, 1, 1], + "882": [0, 1, 1], + "883": [0, 1, 1], + "884": [0, 1, 1], + "885": [1, 1, 1], + "886": [1, 1, 1], + "887": [1, 1, 1], + "888": [0, 1, 1], + "888-crowned": [0, 1, 1], + "889": [0, 1, 1], + "889-crowned": [0, 1, 1], + "890": [0, 1, 1], + "891": [1, 1, 1], + "892-rapid-strike": [1, 1, 1], + "892": [1, 1, 1], + "894": [0, 1, 1], + "895": [0, 1, 1], + "896": [1, 1, 1], + "897": [1, 1, 1], + "898": [1, 1, 1], + "898-ice": [1, 1, 1], + "898-shadow": [1, 1, 1], + "900": [0, 1, 1], + "901": [0, 1, 1], + "903": [0, 1, 1], + "909": [0, 1, 1], + "910": [0, 2, 2], + "911": [0, 1, 1], + "912": [0, 1, 1], + "913": [0, 1, 1], + "914": [0, 2, 2], + "919": [1, 1, 1], + "920": [1, 1, 1], + "924": [1, 1, 1], + "925-four": [1, 2, 2], + "925-three": [1, 2, 2], + "932": [0, 1, 1], + "933": [0, 1, 1], + "934": [0, 1, 1], + "935": [2, 2, 2], + "936": [2, 2, 2], + "937": [2, 2, 2], + "940": [0, 1, 1], + "941": [0, 1, 1], + "944": [0, 1, 1], + "945": [0, 1, 1], + "948": [0, 1, 1], + "949": [0, 1, 1], + "951": [0, 1, 1], + "952": [0, 2, 1], + "953": [0, 1, 1], + "954": [0, 1, 1], + "957": [1, 1, 1], + "958": [1, 1, 1], + "959": [1, 1, 1], + "962": [1, 1, 1], + "967": [0, 1, 1], + "968": [0, 2, 2], + "969": [0, 1, 1], + "970": [0, 1, 1], + "973": [1, 1, 1], + "974": [0, 1, 1], + "975": [0, 1, 1], + "978-curly": [0, 2, 2], + "978-droopy": [0, 2, 2], + "978-stretchy": [0, 1, 1], + "979": [1, 1, 1], + "981": [0, 1, 1], + "982": [0, 1, 1], + "982-three-segment": [0, 1, 1], + "987": [1, 1, 1], + "988": [0, 1, 1], + "993": [0, 1, 1], + "994": [0, 1, 1], + "995": [0, 1, 1], + "996": [0, 1, 1], + "997": [0, 1, 1], + "998": [0, 1, 1], + "999": [1, 1, 1], + "1000": [1, 1, 1], + "1001": [0, 1, 1], + "1003": [0, 1, 1], + "1004": [0, 1, 1], + "1006": [0, 2, 2], + "1007-apex-build": [0, 2, 2], + "1008-ultimate-mode": [1, 1, 1], + "2026": [0, 1, 1], + "2027": [0, 1, 1], + "2028": [0, 1, 1], + "2052": [0, 1, 1], + "2053": [0, 1, 1], + "2103": [0, 1, 1], + "4052": [0, 1, 1], + "4077": [0, 1, 1], + "4078": [0, 1, 1], + "4079": [0, 1, 1], + "4080": [2, 2, 2], + "4144": [0, 1, 1], + "4145": [0, 1, 1], + "4146": [0, 1, 1], + "4199": [2, 1, 1], + "4222": [0, 1, 1], + "4263": [0, 1, 1], + "4264": [0, 1, 1], + "4562": [0, 1, 1], + "6100": [0, 1, 1], + "6101": [0, 1, 1], + "6215": [0, 1, 1], + "6503": [0, 1, 1], + "6549": [0, 1, 1], + "6570": [0, 1, 1], + "6571": [0, 1, 1], + "6705": [0, 1, 1], + "6706": [0, 1, 1], + "6713": [0, 1, 1] + } } } diff --git a/public/images/pokemon/variant/back/1012-counterfeit.json b/public/images/pokemon/variant/back/1012-counterfeit.json new file mode 100644 index 00000000000..10255311fe0 --- /dev/null +++ b/public/images/pokemon/variant/back/1012-counterfeit.json @@ -0,0 +1,34 @@ +{ + "1": { + "291e1e": "404ec8", + "87847e": "8a96c0", + "78c463": "f7dfc5", + "4c3a3a": "667fe9", + "5d9e4a": "dda08a", + "251b1b": "222078", + "a09750": "acbedf", + "e6e1db": "f5fdff", + "396725": "b0654a", + "ccc374": "e9f4f7", + "613f19": "7b86ad", + "544040": "626a96", + "c1b9ae": "c8ddf1", + "69441b": "3a44a4" + }, + "2": { + "291e1e": "37183f", + "87847e": "070722", + "78c463": "c3b4e0", + "4c3a3a": "563f5b", + "5d9e4a": "978dc7", + "251b1b": "1c0b1f", + "a09750": "1b2556", + "e6e1db": "212b5e", + "396725": "7a5aa7", + "ccc374": "293363", + "613f19": "0d1030", + "544040": "020109", + "c1b9ae": "111039", + "69441b": "44244b" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/1013-unremarkable.json b/public/images/pokemon/variant/back/1013-unremarkable.json new file mode 100644 index 00000000000..2a6de98db5a --- /dev/null +++ b/public/images/pokemon/variant/back/1013-unremarkable.json @@ -0,0 +1,36 @@ +{ + "1": { + "5d9e4a": "dda08a", + "a09750": "c3d7eb", + "251b1b": "404ec8", + "7b6f6c": "acbedf", + "c1b9ae": "cbe1f5", + "69441b": "3a44a4", + "342405": "565e7a", + "78c463": "f7dfc5", + "9e8574": "b36171", + "988975": "939ec4", + "295217": "b0654a", + "e6e1db": "e6f9ff", + "6a5b20": "8a96c0", + "291a0d": "222078", + "453636": "667fe9" + }, + "2": { + "5d9e4a": "978dc7", + "a09750": "263665", + "251b1b": "37183f", + "7b6f6c": "0f102d", + "c1b9ae": "111039", + "69441b": "44244b", + "342405": "0b0c21", + "78c463": "c3b4e0", + "9e8574": "585d81", + "988975": "212e57", + "295217": "7a5aa7", + "e6e1db": "212b5e", + "6a5b20": "171542", + "291a0d": "170d26", + "453636": "563f5b" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/102.json b/public/images/pokemon/variant/back/102.json new file mode 100644 index 00000000000..61035a495c9 --- /dev/null +++ b/public/images/pokemon/variant/back/102.json @@ -0,0 +1,20 @@ +{ + "1": { + "943131": "193662", + "e69c00": "a0694c", + "ffe6ce": "7ae49f", + "ffce4a": "cea573", + "ffb58c": "369b96", + "ef8463": "26647e", + "ffd6ad": "4fba94" + }, + "2": { + "943131": "414189", + "e69c00": "6d2341", + "ffe6ce": "ebb6f8", + "ffce4a": "92394b", + "ffb58c": "9475ce", + "ef8463": "6c5fb6", + "ffd6ad": "b98fe4" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/103.json b/public/images/pokemon/variant/back/103.json new file mode 100644 index 00000000000..492bc14b102 --- /dev/null +++ b/public/images/pokemon/variant/back/103.json @@ -0,0 +1,28 @@ +{ + "1": { + "ffde6b": "a3c4ed", + "e6ad5a": "869fdc", + "73ad31": "dea44c", + "8c7342": "283f5b", + "526329": "c8592a", + "9cd64a": "f4e774", + "a56b21": "6072ba", + "b59c4a": "426378", + "734210": "373e85", + "ffefa5": "d3efff", + "524210": "131d33" + }, + "2": { + "ffde6b": "eb748d", + "e6ad5a": "c84e7f", + "73ad31": "3d324b", + "8c7342": "d59cba", + "526329": "1f1a31", + "9cd64a": "6a5b73", + "a56b21": "83295f", + "b59c4a": "ffdbe7", + "734210": "4e1044", + "ffefa5": "ffa29d", + "524210": "925b81" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/128.json b/public/images/pokemon/variant/back/128.json new file mode 100644 index 00000000000..ef61b186930 --- /dev/null +++ b/public/images/pokemon/variant/back/128.json @@ -0,0 +1,30 @@ +{ + "1": { + "dea54a": "56b393", + "634a31": "173e0d", + "9c9cad": "997059", + "6b6b84": "75413b", + "b58431": "2e8a85", + "8c6b52": "355816", + "523a10": "102d4b", + "ad8c73": "5f722a", + "4a3a29": "072b05", + "8c6321": "215c72", + "cecede": "c2a082", + "3a3a4a": "4d2324" + }, + "2": { + "dea54a": "872b3b", + "634a31": "bc9681", + "9c9cad": "edda95", + "6b6b84": "cca45e", + "b58431": "5e172e", + "8c6b52": "d6c3aa", + "523a10": "2f0e21", + "ad8c73": "faf9ed", + "4a3a29": "966959", + "8c6321": "461029", + "cecede": "fffcc1", + "3a3a4a": "996537" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/152.json b/public/images/pokemon/variant/back/152.json new file mode 100644 index 00000000000..2460f5977d5 --- /dev/null +++ b/public/images/pokemon/variant/back/152.json @@ -0,0 +1,26 @@ +{ + "1": { + "849452": "7373b4", + "b5ce6b": "aca1d7", + "d6f78c": "ded2f1", + "84e631": "8074fa", + "ef7b7b": "9bd5c1", + "c52929": "77b3af", + "6bb529": "6f4be2", + "425a19": "505d8d", + "638c29": "6633bc", + "426319": "5d2398" + }, + "2": { + "849452": "a62775", + "b5ce6b": "c83c74", + "d6f78c": "e7617d", + "84e631": "feeeaf", + "ef7b7b": "71cf71", + "c52929": "4eac60", + "6bb529": "f0d187", + "425a19": "801a69", + "638c29": "d8a864", + "426319": "b4814b" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/153.json b/public/images/pokemon/variant/back/153.json new file mode 100644 index 00000000000..8495177fbaa --- /dev/null +++ b/public/images/pokemon/variant/back/153.json @@ -0,0 +1,26 @@ +{ + "1": { + "a58419": "5961ce", + "ad3100": "47d0d1", + "295208": "232699", + "8cbd31": "8251dc", + "debd29": "7b8ce6", + "527b08": "4d36be", + "6b9c10": "6b41cc", + "f7e64a": "a2bbf8", + "6b5200": "493fa6", + "d68c52": "80f5e6" + }, + "2": { + "a58419": "a8244d", + "ad3100": "439227", + "295208": "c58c48", + "8cbd31": "fae084", + "debd29": "ca333d", + "527b08": "e8bc5e", + "6b9c10": "edc870", + "f7e64a": "ea704a", + "6b5200": "891b4f", + "d68c52": "8ec349" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/154.json b/public/images/pokemon/variant/back/154.json new file mode 100644 index 00000000000..a667f36b9c1 --- /dev/null +++ b/public/images/pokemon/variant/back/154.json @@ -0,0 +1,26 @@ +{ + "1": { + "634a00": "519aa7", + "ff3a5a": "3542a7", + "e6ad00": "7bcfc6", + "ce213a": "27217d", + "63bd42": "9d86d9", + "f7a59c": "72d1da", + "7b103a": "23124e", + "107b31": "8057b2", + "ffde21": "b1f2dc", + "9ce652": "b7afee" + }, + "2": { + "634a00": "488939", + "ff3a5a": "f9db74", + "e6ad00": "6bac4b", + "ce213a": "e5b650", + "63bd42": "a31f60", + "f7a59c": "fff6a9", + "7b103a": "b7873b", + "107b31": "761858", + "ffde21": "92c462", + "9ce652": "cd3b6b" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/158.json b/public/images/pokemon/variant/back/158.json new file mode 100644 index 00000000000..a6c54577e98 --- /dev/null +++ b/public/images/pokemon/variant/back/158.json @@ -0,0 +1,29 @@ +{ + "1": { + "b54a52": "1d5d6c", + "6bb5e6": "dd8e59", + "94d6ff": "fdc17e", + "ffc552": "99d4d9", + "ad8429": "4798ab", + "ce4221": "772c52", + "3184c5": "ae5139", + "e67b7b": "749e9e", + "ef735a": "ad5778", + "7b1900": "4f0332", + "315a84": "73131e" + }, + "2": { + "000000": "ffffff", + "b54a52": "c48b27", + "6bb5e6": "97ac5b", + "94d6ff": "ccd198", + "ffc552": "2f5365", + "ad8429": "1c314f", + "ce4221": "ce8c20", + "3184c5": "4f854a", + "e67b7b": "e4b843", + "ef735a": "f3b649", + "7b1900": "a66b14", + "315a84": "2b4a30" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/159.json b/public/images/pokemon/variant/back/159.json new file mode 100644 index 00000000000..c1124bb8d42 --- /dev/null +++ b/public/images/pokemon/variant/back/159.json @@ -0,0 +1,29 @@ +{ + "1": { + "3a4a84": "973027", + "e64221": "749e9e", + "ce293a": "682c4e", + "5aade6": "e5a354", + "ffe68c": "a9e4e5", + "840008": "4f1037", + "3184c5": "cd6537", + "cebd63": "56b3bd", + "6b5200": "085d75", + "840009": "1d5d6c", + "f7525a": "774860" + }, + "2": { + "000000": "ffffff", + "3a4a84": "26472b", + "e64221": "e4b843", + "ce293a": "ce8c20", + "5aade6": "8fa54e", + "ffe68c": "2f5365", + "840008": "a66b14", + "3184c5": "468040", + "cebd63": "1c314f", + "6b5200": "112034", + "840009": "c48b27", + "f7525a": "f3b649" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/160.json b/public/images/pokemon/variant/back/160.json new file mode 100644 index 00000000000..ac9067df672 --- /dev/null +++ b/public/images/pokemon/variant/back/160.json @@ -0,0 +1,29 @@ +{ + "1": { + "8cd6ff": "ffcf72", + "6b5200": "085d75", + "ce293a": "682c4e", + "5ab5f7": "eda857", + "cebd63": "56b3bd", + "ffe68c": "a9e4e5", + "840008": "4f1037", + "294a8c": "973027", + "3a8cce": "d26738", + "ff8c84": "926877", + "f7525a": "774860" + }, + "2": { + "000000": "ffffff", + "8cd6ff": "d1d692", + "6b5200": "112034", + "ce293a": "ce8c20", + "5ab5f7": "9ab350", + "cebd63": "1c314f", + "ffe68c": "2f5365", + "840008": "a66b14", + "294a8c": "274c2d", + "3a8cce": "498a42", + "ff8c84": "fff284", + "f7525a": "f3b649" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/167.json b/public/images/pokemon/variant/back/167.json new file mode 100644 index 00000000000..65a2a2dedf9 --- /dev/null +++ b/public/images/pokemon/variant/back/167.json @@ -0,0 +1,24 @@ +{ + "1": { + "52b56b": "e5812a", + "000000": "ffffff", + "c5b519": "3f2e71", + "314a10": "641218", + "8ce631": "f2ba40", + "527b29": "d54f1a", + "846b29": "221b57", + "ffe64a": "624095" + }, + "2": { + "52b56b": "b54158", + "bdc5c5": "a1b7de", + "c5b519": "7d95b9", + "314a10": "481229", + "ffffff": "cde6fc", + "8ce631": "dd7081", + "527b29": "8c2848", + "846b29": "565e8d", + "ffe64a": "aac3d6", + "6b6b73": "62657d" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/168.json b/public/images/pokemon/variant/back/168.json new file mode 100644 index 00000000000..7a4270ff9c0 --- /dev/null +++ b/public/images/pokemon/variant/back/168.json @@ -0,0 +1,29 @@ +{ + "1": { + "c54242": "62b943", + "6b5219": "043435", + "63319c": "e28220", + "bdbdbd": "b5d3dc", + "520000": "317945", + "ff5a4a": "a8d919", + "c5b54a": "15463c", + "ffde42": "186c45", + "ff8c73": "dce24b", + "bd84e6": "f1b940", + "6b6b6b": "5f7980" + }, + "2": { + "c54242": "7ca5c6", + "6b5219": "161437", + "63319c": "96304a", + "bdbdbd": "c09fa1", + "520000": "2d3d72", + "ff5a4a": "a3c8d1", + "c5b54a": "1f2150", + "ffffff": "fae8e7", + "ffde42": "313b60", + "ff8c73": "c4e8e7", + "bd84e6": "c8545d", + "6b6b6b": "605050" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/170.json b/public/images/pokemon/variant/back/170.json new file mode 100644 index 00000000000..6f6317314fb --- /dev/null +++ b/public/images/pokemon/variant/back/170.json @@ -0,0 +1,30 @@ +{ + "1": { + "08295a": "691f03", + "ffce52": "a1dbba", + "295294": "a14713", + "ffef84": "ccffd7", + "5a73c5": "dda13d", + "94cee6": "ffeabf", + "522919": "052b38", + "ffffde": "f2fff5", + "c59400": "84bda9", + "7bbde6": "ffe0a2", + "846352": "45757a", + "6ba5e6": "f6e37f" + }, + "2": { + "08295a": "1b072f", + "ffce52": "e25765", + "295294": "441e56", + "ffef84": "f97f7f", + "5a73c5": "693373", + "94cee6": "a15b8d", + "522919": "720b3a", + "ffffde": "ffc4be", + "c59400": "b62b51", + "7bbde6": "9f5a9b", + "846352": "931b3c", + "6ba5e6": "89498d" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/171.json b/public/images/pokemon/variant/back/171.json new file mode 100644 index 00000000000..8a9cafe4265 --- /dev/null +++ b/public/images/pokemon/variant/back/171.json @@ -0,0 +1,30 @@ +{ + "1": { + "a5314a": "bf882c", + "4a7bce": "bc3c4c", + "423110": "05333a", + "ef635a": "efde5a", + "7badef": "f6907f", + "a5ceff": "fbcdb3", + "e6b552": "82ca4f", + "6394e6": "e86062", + "ffde63": "c3e875", + "ad9442": "2a8d3d", + "293173": "872341", + "7b634a": "0c5540" + }, + "2": { + "a5314a": "c3851d", + "4a7bce": "9781b3", + "423110": "040529", + "ef635a": "f0d050", + "7badef": "eecfed", + "a5ceff": "fbf5fa", + "e6b552": "3294b8", + "6394e6": "c5a5d0", + "ffde63": "4dd5d9", + "ad9442": "23689e", + "293173": "4b426c", + "7b634a": "0c1d4c" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/172-spiky.json b/public/images/pokemon/variant/back/172-spiky.json new file mode 100644 index 00000000000..f4c5e28b61a --- /dev/null +++ b/public/images/pokemon/variant/back/172-spiky.json @@ -0,0 +1,23 @@ +{ + "1": { + "c5ad10": "6cab9a", + "845a29": "45818a", + "a57b08": "5ca390", + "7d1c1c": "992424", + "e77b94": "bd4d5e", + "634a10": "30536b", + "f7e652": "a3d1a8" + }, + "2": { + "c5ad10": "4a6a90", + "845a29": "283567", + "171721": "9a4440", + "a57b08": "486a8e", + "212131": "d48d61", + "7d1c1c": "c38218", + "424252": "e7c17c", + "e77b94": "f5dd94", + "634a10": "2b2f54", + "f7e652": "7095ab" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/172-spiky_2.png b/public/images/pokemon/variant/back/172-spiky_2.png new file mode 100644 index 00000000000..9e9994d6b19 Binary files /dev/null and b/public/images/pokemon/variant/back/172-spiky_2.png differ diff --git a/public/images/pokemon/variant/back/172-spiky_3.png b/public/images/pokemon/variant/back/172-spiky_3.png new file mode 100644 index 00000000000..260de86af53 Binary files /dev/null and b/public/images/pokemon/variant/back/172-spiky_3.png differ diff --git a/public/images/pokemon/variant/back/172.json b/public/images/pokemon/variant/back/172.json new file mode 100644 index 00000000000..18c7f5bdee4 --- /dev/null +++ b/public/images/pokemon/variant/back/172.json @@ -0,0 +1,23 @@ +{ + "1": { + "c5ad10": "6cab9a", + "845a29": "45818a", + "a57b08": "5ca390", + "7d1c1c": "992424", + "e77b94": "bd4d5e", + "634a10": "30536b", + "f7e652": "a3d1a8" + }, + "2": { + "c5ad10": "4a6a90", + "845a29": "283567", + "171721": "9a4440", + "a57b08": "486a8e", + "212131": "d48d61", + "7d1c1c": "c38218", + "424252": "e7c17c", + "e77b94": "f5dd94", + "634a10": "2f335b", + "f7e652": "7095ab" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/172_2.png b/public/images/pokemon/variant/back/172_2.png new file mode 100644 index 00000000000..84a35b18ead Binary files /dev/null and b/public/images/pokemon/variant/back/172_2.png differ diff --git a/public/images/pokemon/variant/back/172_3.png b/public/images/pokemon/variant/back/172_3.png new file mode 100644 index 00000000000..b94789940f5 Binary files /dev/null and b/public/images/pokemon/variant/back/172_3.png differ diff --git a/public/images/pokemon/variant/back/174.json b/public/images/pokemon/variant/back/174.json new file mode 100644 index 00000000000..eaabbbc574d --- /dev/null +++ b/public/images/pokemon/variant/back/174.json @@ -0,0 +1,14 @@ +{ + "1": { + "9c1952": "3a6472", + "b55273": "43737d", + "e6849c": "81c2b8", + "ffadbd": "c5ebd5" + }, + "2": { + "9c1952": "9c5200", + "b55273": "a16b30", + "e6849c": "f5c45b", + "ffadbd": "f5e884" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/194.json b/public/images/pokemon/variant/back/194.json new file mode 100644 index 00000000000..83297ce4e5b --- /dev/null +++ b/public/images/pokemon/variant/back/194.json @@ -0,0 +1,20 @@ +{ + "1": { + "529ce6": "e8983d", + "9463a5": "65b1c2", + "633a6b": "204954", + "3a7bc5": "d5682e", + "73bdff": "ffc355", + "d65ad6": "81e2f7", + "104a84": "7a150a" + }, + "2": { + "529ce6": "564daa", + "9463a5": "cf933b", + "633a6b": "80301c", + "3a7bc5": "3f377e", + "73bdff": "5c66c4", + "d65ad6": "e9cb52", + "104a84": "180d42" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/195.json b/public/images/pokemon/variant/back/195.json new file mode 100644 index 00000000000..f79c398dc81 --- /dev/null +++ b/public/images/pokemon/variant/back/195.json @@ -0,0 +1,26 @@ +{ + "1": { + "ade6ff": "f6dfa8", + "84d6f7": "ed9e4f", + "637ba5": "936e66", + "639cbd": "dc6a4d", + "3194a5": "81e2f7", + "6b5a8c": "23768d", + "425284": "b03844", + "426b84": "af4237", + "195a6b": "54aec2", + "19423a": "204954" + }, + "2": { + "ade6ff": "9864c2", + "84d6f7": "724ba7", + "637ba5": "692d5d", + "639cbd": "493a8d", + "3194a5": "e9cb52", + "6b5a8c": "742f3d", + "425284": "240830", + "426b84": "3d237b", + "195a6b": "cf933b", + "19423a": "b96228" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/198.json b/public/images/pokemon/variant/back/198.json new file mode 100644 index 00000000000..eed8404265c --- /dev/null +++ b/public/images/pokemon/variant/back/198.json @@ -0,0 +1,26 @@ +{ + "1": { + "d94352": "8c1b23", + "314263": "462b20", + "efd684": "a6a6b3", + "d64252": "b3986b", + "42639c": "694c30", + "5a4a21": "25253b", + "292942": "2a1512", + "b59c21": "57566f", + "73293a": "755237", + "d6bd52": "838098" + }, + "2": { + "d94352": "8c1b23", + "314263": "0e4333", + "efd684": "c2723a", + "d64252": "bc4b84", + "42639c": "1d6e47", + "5a4a21": "4e1915", + "292942": "091e16", + "b59c21": "85412d", + "73293a": "7b2363", + "d6bd52": "9a5524" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/2026.json b/public/images/pokemon/variant/back/2026.json new file mode 100644 index 00000000000..4fb224dd489 --- /dev/null +++ b/public/images/pokemon/variant/back/2026.json @@ -0,0 +1,31 @@ +{ + "1": { + "b45f25": "2d5261", + "552720": "162f4b", + "f9ed9f": "eb999a", + "e9be14": "945c7b", + "e3882d": "3d7375", + "646124": "492652", + "ecd8b7": "b4c2a5", + "fffdfb": "d6d9ca", + "846b5b": "467f85", + "965821": "2f4e6b", + "dfc043": "d17577", + "602c24": "162f4b", + "fef443": "c48081", + "993c20": "1d3a57" + }, + "2": { + "b45f25": "bd8551", + "552720": "43617f", + "e9be14": "1a3551", + "e3882d": "d3b06f", + "646124": "122140", + "ecd8b7": "5a6f90", + "fffdfb": "6d8297", + "846b5b": "202746", + "965821": "9cb3ca", + "fef443": "3a5873", + "993c20": "965636" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/2103.json b/public/images/pokemon/variant/back/2103.json new file mode 100644 index 00000000000..2e97727835a --- /dev/null +++ b/public/images/pokemon/variant/back/2103.json @@ -0,0 +1,28 @@ +{ + "1": { + "2f9934": "dea44c", + "9f6b41": "426378", + "70442e": "283f5b", + "e6ac5a": "869fdc", + "522f16": "131d33", + "9cbd4a": "9977dd", + "fff68b": "a3c4ed", + "36cc36": "f4e774", + "2d5826": "c8592a", + "7b5210": "373e85", + "ffffcd": "d3efff" + }, + "2": { + "2f9934": "3d324b", + "9f6b41": "ffdbe7", + "70442e": "d59cba", + "e6ac5a": "c84e7f", + "522f16": "925b81", + "9cbd4a": "824a96", + "fff68b": "eb748d", + "36cc36": "6a5b73", + "2d5826": "1f1a31", + "7b5210": "4e1044", + "ffffcd": "ffa29d" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/211.json b/public/images/pokemon/variant/back/211.json new file mode 100644 index 00000000000..01ae33500a4 --- /dev/null +++ b/public/images/pokemon/variant/back/211.json @@ -0,0 +1,22 @@ +{ + "1": { + "a5ad6b": "ad6643", + "194a52": "321128", + "dede94": "f1c17c", + "428494": "80294b", + "c5c57b": "dc9565", + "3a6363": "611a42", + "6b5231": "6d2c2c", + "73adb5": "a0415e" + }, + "2": { + "a5ad6b": "1e275b", + "194a52": "1c2f5b", + "dede94": "365492", + "428494": "60abdc", + "c5c57b": "2b3e7b", + "3a6363": "396796", + "6b5231": "181f46", + "73adb5": "8bd9ee" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/25-beauty-cosplay.json b/public/images/pokemon/variant/back/25-beauty-cosplay.json new file mode 100644 index 00000000000..216262b149b --- /dev/null +++ b/public/images/pokemon/variant/back/25-beauty-cosplay.json @@ -0,0 +1,30 @@ +{ + "1": { + "5e5e6b": "6c6e60", + "f7e652": "a3d1a8", + "cecab9": "cfc8aa", + "f7e860": "eddc78", + "4d88c4": "7976c6", + "f7bd21": "79b5a5", + "2d276d": "2f2768", + "9c5200": "315c75", + "39509d": "47449c", + "fffdea": "f8ffe3", + "f7cc2f": "d5ac44" + }, + "2": { + "1e1526": "a45233", + "5e5e6b": "8a2554", + "f7e652": "577b98", + "cecab9": "b84084", + "f7e860": "eddc78", + "4d88c4": "e4f6f1", + "f7bd21": "486689", + "2d276d": "454a61", + "9c5200": "283361", + "39509d": "9ec4cd", + "fffdea": "ea82a6", + "4f454c": "f1b571", + "f7cc2f": "d5ac44" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/25-cool-cosplay.json b/public/images/pokemon/variant/back/25-cool-cosplay.json new file mode 100644 index 00000000000..278feb070bd --- /dev/null +++ b/public/images/pokemon/variant/back/25-cool-cosplay.json @@ -0,0 +1,31 @@ +{ + "1": { + "171717": "2a1d36", + "c52119": "ad4e76", + "842222": "7b1f18", + "f7e652": "a3d1a8", + "fff7a5": "c4e3c3", + "f7bd21": "79b5a5", + "ba2b23": "b73850", + "9c5200": "1c4f75", + "d95b45": "cf6887", + "3b3b40": "4a3e46" + }, + "2": { + "171717": "a45233", + "656f86": "cf752b", + "a5b0b6": "f0b541", + "c52119": "ebc67c", + "842222": "1e1e43", + "f7e652": "577b98", + "fff7a5": "7b96aa", + "f7bd21": "445f8a", + "ba2b23": "2c2c47", + "55555e": "8f4b32", + "9c5200": "22325c", + "f4f7ab": "eadbb3", + "d95b45": "3a3f5e", + "3b3b40": "f1b571", + "272b2b": "7d3833" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/25-cosplay.json b/public/images/pokemon/variant/back/25-cosplay.json new file mode 100644 index 00000000000..c574d63d743 --- /dev/null +++ b/public/images/pokemon/variant/back/25-cosplay.json @@ -0,0 +1,26 @@ +{ + "1": { + "f7e652": "a3d1a8", + "fff7a5": "c4e3c3", + "c52119": "ad4e76", + "f7bd21": "79b5a5", + "52525a": "4f454c", + "9c5200": "315c75", + "292929": "1e1526", + "633108": "09406b", + "e65a42": "cf6182", + "de9400": "338087" + }, + "2": { + "f7e652": "577b98", + "fff7a5": "7b96aa", + "c52119": "ebc67c", + "f7bd21": "445f8a", + "52525a": "f1b571", + "9c5200": "23345e", + "292929": "a45233", + "633108": "22244f", + "e65a42": "eedd9c", + "de9400": "324472" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/25-cute-cosplay.json b/public/images/pokemon/variant/back/25-cute-cosplay.json new file mode 100644 index 00000000000..7b26b79d08f --- /dev/null +++ b/public/images/pokemon/variant/back/25-cute-cosplay.json @@ -0,0 +1,32 @@ +{ + "1": { + "752bd0": "5452b7", + "baa998": "bab699", + "fff7a5": "c4e3c3", + "f7e652": "a3d1a8", + "ea82a6": "e8848e", + "cf4770": "cf4a59", + "f3bace": "f2bbbb", + "853247": "85323c", + "f7ef97": "f0eaa8", + "52525a": "4f454c", + "292929": "30263b", + "f7bd21": "79b5a5", + "9c5200": "255e8a" + }, + "2": { + "752bd0": "7751c2", + "baa998": "d3ab5a", + "fff7a5": "7b96aa", + "f7e652": "577b98", + "ea82a6": "a4b95f", + "cf4770": "739b55", + "f3bace": "c5cc85", + "853247": "254b30", + "f7ef97": "ebe7b7", + "52525a": "f1b571", + "292929": "a45233", + "f7bd21": "445f8a", + "9c5200": "23345e" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/25-gigantamax.json b/public/images/pokemon/variant/back/25-gigantamax.json new file mode 100644 index 00000000000..1c47104e04d --- /dev/null +++ b/public/images/pokemon/variant/back/25-gigantamax.json @@ -0,0 +1,30 @@ +{ + "1": { + "623108": "09406b", + "c52018": "ad4e76", + "de9400": "338087", + "fefefe": "ffffff", + "f6bd20": "79b5a5", + "fff6a4": "c4e3c3", + "fff9c2": "b8ffd9", + "e65a41": "cf6182", + "9c5200": "315c75", + "f8fc4b": "5bc28b", + "f6e652": "a3d1a8" + }, + "2": { + "623108": "22244f", + "c52018": "ebc67c", + "de9400": "324472", + "fefefe": "ffffff", + "f6bd20": "445f8a", + "fff6a4": "7b96aa", + "fff9c2": "83b1d2", + "e65a41": "eedd9c", + "9c5200": "23345e", + "f8fc4b": "326a9f", + "695d65": "f1b571", + "f6e652": "577b98", + "323133": "d99362" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/25-partner.json b/public/images/pokemon/variant/back/25-partner.json new file mode 100644 index 00000000000..c20fae48a34 --- /dev/null +++ b/public/images/pokemon/variant/back/25-partner.json @@ -0,0 +1,26 @@ +{ + "1": { + "45454a": "4f454c", + "9c5200": "315c75", + "de9400": "338087", + "171717": "1e1526", + "c52119": "ad4e76", + "633108": "09406b", + "e65a42": "cf6182", + "f7e652": "a3d1a8", + "fff7a5": "c4e3c3", + "f7bd21": "79b5a5" + }, + "2": { + "45454a": "f1b571", + "9c5200": "23345e", + "de9400": "324472", + "171717": "a45233", + "c52119": "ebc67c", + "633108": "22244f", + "e65a42": "eedd9c", + "f7e652": "577b98", + "fff7a5": "7b96aa", + "f7bd21": "445f8a" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/25-smart-cosplay.json b/public/images/pokemon/variant/back/25-smart-cosplay.json new file mode 100644 index 00000000000..50749b31d8b --- /dev/null +++ b/public/images/pokemon/variant/back/25-smart-cosplay.json @@ -0,0 +1,32 @@ +{ + "1": { + "fffdea": "f8ffe3", + "b7a599": "bab699", + "60b553": "76a848", + "f7e652": "a3d1a8", + "366635": "3e5b2f", + "95635b": "91685f", + "171717": "1e1526", + "5f3434": "573b38", + "54545c": "55555e", + "52525a": "4f454c", + "292929": "272b2b", + "f7bd21": "79b5a5", + "9c5200": "315c75" + }, + "2": { + "fffdea": "f2f0df", + "b7a599": "a7b6b9", + "60b553": "dfb053", + "f7e652": "577b98", + "366635": "ab5130", + "95635b": "a09ea3", + "171717": "a45233", + "5f3434": "666060", + "54545c": "45525c", + "52525a": "f1b571", + "292929": "202937", + "f7bd21": "445f8a", + "9c5200": "23345e" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/25-tough-cosplay.json b/public/images/pokemon/variant/back/25-tough-cosplay.json new file mode 100644 index 00000000000..49c50d17ad2 --- /dev/null +++ b/public/images/pokemon/variant/back/25-tough-cosplay.json @@ -0,0 +1,35 @@ +{ + "1": { + "e37511": "d1694f", + "bf2629": "cf6a59", + "8d2b1d": "bf3638", + "c52119": "ad4e76", + "46464d": "2b3340", + "292929": "1e1526", + "f7bd21": "79b5a5", + "fbab33": "de9764", + "e65a42": "cf6182", + "cecab9": "cfc8aa", + "52525a": "4f454c", + "f7e652": "a3d1a8", + "9c5200": "315c75" + }, + "2": { + "e37511": "60448d", + "bf2629": "826694", + "f8ffe3": "e8e3e4", + "8d2b1d": "3d3f7d", + "c52119": "ebc67c", + "46464d": "2b3340", + "292929": "a45233", + "f7bd21": "445f8a", + "fbab33": "845ea1", + "e65a42": "eedd9c", + "cecab9": "beb1b4", + "8e2525": "242866", + "52525a": "f1b571", + "f7e652": "577b98", + "272b2b": "162231", + "9c5200": "23345e" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/25.json b/public/images/pokemon/variant/back/25.json new file mode 100644 index 00000000000..c20fae48a34 --- /dev/null +++ b/public/images/pokemon/variant/back/25.json @@ -0,0 +1,26 @@ +{ + "1": { + "45454a": "4f454c", + "9c5200": "315c75", + "de9400": "338087", + "171717": "1e1526", + "c52119": "ad4e76", + "633108": "09406b", + "e65a42": "cf6182", + "f7e652": "a3d1a8", + "fff7a5": "c4e3c3", + "f7bd21": "79b5a5" + }, + "2": { + "45454a": "f1b571", + "9c5200": "23345e", + "de9400": "324472", + "171717": "a45233", + "c52119": "ebc67c", + "633108": "22244f", + "e65a42": "eedd9c", + "f7e652": "577b98", + "fff7a5": "7b96aa", + "f7bd21": "445f8a" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/26.json b/public/images/pokemon/variant/back/26.json new file mode 100644 index 00000000000..758faf12c97 --- /dev/null +++ b/public/images/pokemon/variant/back/26.json @@ -0,0 +1,34 @@ +{ + "1": { + "63636b": "4f454c", + "101011": "293059", + "944242": "395a80", + "bd5a31": "386d82", + "e6bd84": "a4bda7", + "ffbd00": "b3596b", + "5a2929": "293059", + "3a3a42": "30263b", + "8c6310": "8c3c4c", + "ffde5a": "cf7878", + "f7ad29": "76a68b", + "734231": "6e2f33", + "ffefd6": "c8d4ba", + "de7b31": "539190" + }, + "2": { + "542127": "905331", + "101011": "202a60", + "944242": "2d3b80", + "bd5a31": "375681", + "e6bd84": "a6b5ab", + "ffbd00": "f3cf91", + "5a2929": "202a60", + "8c6310": "c79b5a", + "ffde5a": "f2e4b6", + "f7ad29": "6385ab", + "734231": "bf8445", + "ffefd6": "cfc4b5", + "de7b31": "4d6f98", + "643034": "2e4685" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/276.json b/public/images/pokemon/variant/back/276.json new file mode 100644 index 00000000000..e0fb6b93467 --- /dev/null +++ b/public/images/pokemon/variant/back/276.json @@ -0,0 +1,32 @@ +{ + "1": { + "bdbdcc": "b5b5d5", + "bdbdce": "26523c", + "943a52": "ad8634", + "ffffff": "3c6a3d", + "a57331": "784524", + "212952": "12223d", + "3a3a31": "3e3e3e", + "5a6b9c": "2a596b", + "e69410": "bc7532", + "524a29": "4b210d", + "fffffd": "fffffe", + "314a7b": "1a385a", + "ce5273": "cebf49" + }, + "2": { + "bdbdcc": "b5b5d5", + "bdbdce": "453f63", + "943a52": "8ec08b", + "ffffff": "635d81", + "a57331": "4a323a", + "212952": "191222", + "3a3a31": "442c34", + "5a6b9c": "3c2f48", + "e69410": "63414f", + "524a29": "381f2c", + "fffffd": "fffffe", + "314a7b": "282037", + "ce5273": "bcd59d" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/277.json b/public/images/pokemon/variant/back/277.json new file mode 100644 index 00000000000..5a3e049f5f5 --- /dev/null +++ b/public/images/pokemon/variant/back/277.json @@ -0,0 +1,36 @@ +{ + "1": { + "dea531": "bc7532", + "425a7b": "2a596b", + "ffffff": "3c6a3d", + "b5b5d6": "26523c", + "9c3152": "ad8634", + "945a10": "784524", + "5a5a5a": "b58251", + "63213a": "603c1d", + "c55a73": "cebf49", + "294263": "1a385a", + "292952": "12223d", + "fffffd": "fffffe", + "524221": "4b210d", + "b5b5d4": "b5b5d5", + "31313a": "89572a" + }, + "2": { + "dea531": "63414f", + "425a7b": "3c2f48", + "ffffff": "635d81", + "b5b5d6": "453f63", + "9c3152": "8ec08b", + "945a10": "4a323a", + "5a5a5a": "5d454d", + "63213a": "5d9469", + "c55a73": "bcd59d", + "294263": "282037", + "292952": "191222", + "fffffd": "fffffe", + "524221": "381f2c", + "b5b5d4": "b5b5d5", + "31313a": "442c34" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/280.json b/public/images/pokemon/variant/back/280.json index 26ee8b358a3..3e140c953b2 100644 --- a/public/images/pokemon/variant/back/280.json +++ b/public/images/pokemon/variant/back/280.json @@ -1,28 +1,22 @@ { "1": { - "84294a": "b80e2f", - "ff7b94": "ca2033", - "d64a73": "da3e4f", - "73bd73": "c08f44", - "101010": "101010", "8ce68c": "ebc984", - "317b42": "89461a", + "9c94c5": "222222", "cecee6": "ffc4a6", "7b8cb5": "d59c80", - "9c94c5": "d59c80", + "84294a": "b80e2f", + "317b42": "89461a", + "d64a73": "da3e4f", + "73bd73": "c08f44", + "ff7b94": "ca2033", "f7f7ff": "f8efde" }, "2": { + "8ce68c": "3f427f", "84294a": "9e2a7c", - "ff7b94": "b035ae", + "317b42": "242745", "d64a73": "d846c1", - "73bd73": "3f427f", - "101010": "101010", - "8ce68c": "5b5790", - "317b42": "282c5d", - "cecee6": "cecee6", - "7b8cb5": "7b8cb5", - "9c94c5": "9c94c5", - "f7f7ff": "f7f7ff" + "73bd73": "282c5d", + "ff7b94": "b035ae" } } \ No newline at end of file diff --git a/public/images/pokemon/variant/back/280_2.png b/public/images/pokemon/variant/back/280_2.png index fcd4b0f8dc7..ef334d3e002 100644 Binary files a/public/images/pokemon/variant/back/280_2.png and b/public/images/pokemon/variant/back/280_2.png differ diff --git a/public/images/pokemon/variant/back/280_3.png b/public/images/pokemon/variant/back/280_3.png index 977b872ce4c..8a1b586d9a9 100644 Binary files a/public/images/pokemon/variant/back/280_3.png and b/public/images/pokemon/variant/back/280_3.png differ diff --git a/public/images/pokemon/variant/back/281.json b/public/images/pokemon/variant/back/281.json index 58f22e01996..b165ddf1974 100644 --- a/public/images/pokemon/variant/back/281.json +++ b/public/images/pokemon/variant/back/281.json @@ -1,28 +1,23 @@ { "1": { - "84294a": "b80e2f", - "101010": "101010", - "ff7b94": "ca2033", - "317b42": "89461a", - "d64a73": "da3e4f", - "8ce68c": "ebc984", "73bd73": "c08f44", - "b5f794": "fff1c0", - "7384ad": "d59c80", + "ffffff": "f8efde", + "317b42": "89461a", "cecee6": "ffc4a6", - "ffffff": "f8efde" + "b5f794": "fff1c0", + "8ce68c": "ebc984", + "84294a": "b80e2f", + "d64a73": "da3e4f", + "ff7b94": "ca2033", + "7384ad": "d59c80" }, "2": { - "84294a": "9e2a7c", - "101010": "101010", - "ff7b94": "b035ae", - "317b42": "242745", - "d64a73": "d846c1", - "8ce68c": "3f427f", "73bd73": "282c5d", + "317b42": "242745", "b5f794": "5b5790", - "7384ad": "7384ad", - "cecee6": "cecee6", - "ffffff": "ffffff" + "8ce68c": "3f427f", + "84294a": "9e2a7c", + "d64a73": "d846c1", + "ff7b94": "b035ae" } } \ No newline at end of file diff --git a/public/images/pokemon/variant/back/281_2.png b/public/images/pokemon/variant/back/281_2.png index a09255d48c5..68fa5a14532 100644 Binary files a/public/images/pokemon/variant/back/281_2.png and b/public/images/pokemon/variant/back/281_2.png differ diff --git a/public/images/pokemon/variant/back/281_3.png b/public/images/pokemon/variant/back/281_3.png index 725caa8b2a2..afa24decdba 100644 Binary files a/public/images/pokemon/variant/back/281_3.png and b/public/images/pokemon/variant/back/281_3.png differ diff --git a/public/images/pokemon/variant/back/282_2.png b/public/images/pokemon/variant/back/282_2.png index f65c59993b1..ba94124ab49 100644 Binary files a/public/images/pokemon/variant/back/282_2.png and b/public/images/pokemon/variant/back/282_2.png differ diff --git a/public/images/pokemon/variant/back/282_3.png b/public/images/pokemon/variant/back/282_3.png index a5d393d5783..9decafe23b8 100644 Binary files a/public/images/pokemon/variant/back/282_3.png and b/public/images/pokemon/variant/back/282_3.png differ diff --git a/public/images/pokemon/variant/back/359-mega.json b/public/images/pokemon/variant/back/359-mega.json new file mode 100644 index 00000000000..d81d313a1de --- /dev/null +++ b/public/images/pokemon/variant/back/359-mega.json @@ -0,0 +1,24 @@ +{ + "1": { + "ffffff": "61a8ab", + "414a6a": "421e4a", + "b4b4d5": "458196", + "293939": "27122b", + "8b8bac": "3b6987", + "525a7b": "59274e", + "d5deee": "589aa6", + "737bac": "874267", + "626283": "2a3163" + }, + "2": { + "ffffff": "9e363b", + "414a6a": "b39279", + "b4b4d5": "752f40", + "293939": "996e5f", + "8b8bac": "59213b", + "525a7b": "dfd1ae", + "d5deee": "8f2f41", + "737bac": "f5f1cb", + "626283": "42122d" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/359.json b/public/images/pokemon/variant/back/359.json new file mode 100644 index 00000000000..4ccca6800b3 --- /dev/null +++ b/public/images/pokemon/variant/back/359.json @@ -0,0 +1,24 @@ +{ + "1": { + "424a6b": "421e4a", + "293a3a": "27122b", + "737bad": "874267", + "d6deef": "589aa6", + "525a7b": "612b54", + "8c8cad": "3b6987", + "636384": "2a3163", + "b5b5d6": "458196", + "ffffff": "61a8ab" + }, + "2": { + "424a6b": "b39279", + "293a3a": "996e5f", + "737bad": "f5f1cb", + "d6deef": "8f2f41", + "525a7b": "e0c79f", + "8c8cad": "59213b", + "636384": "42122d", + "b5b5d6": "752f40", + "ffffff": "9e363b" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/377.json b/public/images/pokemon/variant/back/377.json new file mode 100644 index 00000000000..1ab9bce073f --- /dev/null +++ b/public/images/pokemon/variant/back/377.json @@ -0,0 +1,26 @@ +{ + "1": { + "b54200": "13512f", + "efad6b": "aac669", + "948c73": "2e4e7b", + "cec5ad": "4d8ba8", + "bd633a": "22773f", + "ef843a": "56963a", + "b5ad94": "3d6d8d", + "e6dead": "659db5", + "524a29": "182238", + "efe6de": "84c7ca" + }, + "2": { + "b54200": "3d0933", + "efad6b": "a54c5e", + "948c73": "262847", + "cec5ad": "303353", + "bd633a": "561934", + "ef843a": "722a41", + "b5ad94": "394170", + "e6dead": "383e6a", + "524a29": "161129", + "efe6de": "4d5784" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/378.json b/public/images/pokemon/variant/back/378.json new file mode 100644 index 00000000000..74ef70cbcec --- /dev/null +++ b/public/images/pokemon/variant/back/378.json @@ -0,0 +1,29 @@ +{ + "0": { + "ffffff": "d7b6f1", + "6bb5d6": "414184", + "293a7b": "101238", + "9cceff": "6f66a7", + "3a6b8c": "191d4c", + "bdefff": "9983c4", + "5a84ad": "282e64" + }, + "1": { + "6bb5d6": "bf344a", + "bdefff": "ffb88d", + "9cceff": "eb5d56", + "293a7b": "400b1c", + "ffffff": "fff7d3", + "3a6b8c": "64132c", + "5a84ad": "981d43" + }, + "2": { + "6bb5d6": "323232", + "bdefff": "5b5b5b", + "9cceff": "424242", + "293a7b": "100f17", + "ffffff": "8c8c8c", + "3a6b8c": "14131a", + "5a84ad": "212121" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/379.json b/public/images/pokemon/variant/back/379.json new file mode 100644 index 00000000000..e99b7d8c171 --- /dev/null +++ b/public/images/pokemon/variant/back/379.json @@ -0,0 +1,26 @@ +{ + "1": { + "4a5a5a": "34366f", + "3a4252": "292960", + "d6ced6": "cc9c65", + "848c84": "4c5c91", + "ffffff": "fff3aa", + "dedede": "f0d185", + "b5adad": "a66f52", + "4a4a4a": "533329", + "84847b": "80503b", + "3e4f4f": "542618" + }, + "2": { + "4a5a5a": "df8533", + "3a4252": "e29631", + "d6ced6": "cd5521", + "848c84": "ffcd49", + "ffffff": "ffb056", + "dedede": "e87537", + "b5adad": "ad2d1e", + "4a4a4a": "521328", + "84847b": "81222b", + "3e4f4f": "54051f" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/39.json b/public/images/pokemon/variant/back/39.json new file mode 100644 index 00000000000..59d78f7958a --- /dev/null +++ b/public/images/pokemon/variant/back/39.json @@ -0,0 +1,16 @@ +{ + "1": { + "6b5263": "153427", + "ffada5": "c5ebd5", + "e67384": "81c2b8", + "a51021": "3a6472", + "ffcec5": "e5ffec" + }, + "2": { + "6b5263": "737454", + "ffada5": "f5e884", + "e67384": "f5c45b", + "a51021": "9c5200", + "ffcec5": "fff9bf" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/390.json b/public/images/pokemon/variant/back/390.json new file mode 100644 index 00000000000..94bfe837547 --- /dev/null +++ b/public/images/pokemon/variant/back/390.json @@ -0,0 +1,32 @@ +{ + "1": { + "7a410f": "994943", + "e63131": "1db978", + "b56b29": "64464d", + "9c3131": "2d8766", + "947308": "a86256", + "7b4210": "382029", + "ef6b6b": "81dc3f", + "f06e6e": "76c96d", + "ffd631": "eafe67", + "ffe6ad": "edc6a4", + "e63a42": "5db95b", + "de8400": "876766", + "deb552": "cc9176" + }, + "2": { + "7a410f": "626678", + "e63131": "b5b0f3", + "b56b29": "293b69", + "9c3131": "422e6f", + "947308": "818596", + "7b4210": "171f46", + "ef6b6b": "cbcfff", + "f06e6e": "cb96e5", + "ffd631": "f3f8fe", + "ffe6ad": "d3d5e0", + "e63a42": "8457b0", + "de8400": "3e5f8a", + "deb552": "a5a9b8" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/391.json b/public/images/pokemon/variant/back/391.json new file mode 100644 index 00000000000..6c21033ceba --- /dev/null +++ b/public/images/pokemon/variant/back/391.json @@ -0,0 +1,36 @@ +{ + "1": { + "8c7342": "a86256", + "cf451b": "2d8766", + "c59463": "cc9176", + "dee6e6": "dac99d", + "9c5219": "64464d", + "ffffff": "faf7d4", + "735a10": "6b2b28", + "efce94": "edc6a4", + "ffce42": "eafe67", + "ffcd45": "f69044", + "1052b5": "ba2342", + "6b3a08": "382029", + "d68c29": "876766", + "ce4219": "1db978", + "efa542": "cd5528" + }, + "2": { + "8c7342": "818596", + "cf451b": "8457b0", + "c59463": "a5a9b8", + "dee6e6": "dca15d", + "9c5219": "293b69", + "ffffff": "ffe175", + "735a10": "626678", + "efce94": "d3d5e0", + "ffce42": "f3f8fe", + "ffcd45": "e8fdff", + "1052b5": "e09f2f", + "6b3a08": "171f46", + "d68c29": "3e5f8a", + "ce4219": "b5b0f3", + "efa542": "b0cbd4" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/392.json b/public/images/pokemon/variant/back/392.json new file mode 100644 index 00000000000..44c2930f77d --- /dev/null +++ b/public/images/pokemon/variant/back/392.json @@ -0,0 +1,42 @@ +{ + "1": { + "e68c5a": "876766", + "6b3a10": "382029", + "e63740": "2d8766", + "bdc5de": "dac99d", + "a56342": "64464d", + "845a08": "9b2719", + "737384": "9f8876", + "ffdf4f": "eafe67", + "e63a42": "1db978", + "c59c21": "cd5528", + "ffde52": "f69044", + "ffdd47": "e8a82a", + "c79e22": "cf8021", + "ffffff": "faf7d4", + "19427b": "581225", + "f78c4a": "81dc3f", + "3a73a5": "972733", + "842931": "174c48" + }, + "2": { + "e68c5a": "3e5f8a", + "6b3a10": "171f46", + "e63740": "8457b0", + "bdc5de": "dca15d", + "a56342": "293b69", + "845a08": "617995", + "737384": "a15a34", + "ffdf4f": "f3f8fe", + "e63a42": "b5b0f3", + "c59c21": "a0c0cd", + "ffde52": "e8fdff", + "ffdd47": "fff8e5", + "c79e22": "ccbdab", + "ffffff": "ffe175", + "19427b": "4d5196", + "f78c4a": "cbcfff", + "3a73a5": "9c96e2", + "842931": "422e6f" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/40.json b/public/images/pokemon/variant/back/40.json new file mode 100644 index 00000000000..21e5ef69cd1 --- /dev/null +++ b/public/images/pokemon/variant/back/40.json @@ -0,0 +1,17 @@ +{ + "1": { + "f77b94": "81c2b8", + "ce6b63": "82b8a9", + "8c4242": "3a6472", + "ffadbd": "c5ebd5" + }, + "2": { + "737373": "3b1f24", + "f77b94": "f5c45b", + "ffffff": "d07439", + "ce6b63": "e6a54c", + "e6dee6": "bc4e24", + "8c4242": "9c5200", + "ffadbd": "f5e884" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/4144.json b/public/images/pokemon/variant/back/4144.json new file mode 100644 index 00000000000..a9f6cca6693 --- /dev/null +++ b/public/images/pokemon/variant/back/4144.json @@ -0,0 +1,38 @@ +{ + "1": { + "43458b": "7ea0c1", + "60748a": "18255b", + "bbc9d9": "39579a", + "282a5d": "324b75", + "b27fd4": "ffb525", + "5fbddc": "ffb725", + "2f2f2f": "4da0c9", + "d9b5fb": "29336f", + "171717": "0e1043", + "a695ea": "d5f1ff", + "1a1a1a": "254f89", + "6f65c5": "afd4ee", + "b480d6": "181f54", + "754691": "08092d", + "74458f": "bd5a2c", + "eef0f2": "5678a9" + }, + "2": { + "43458b": "75151e", + "60748a": "a37f56", + "bbc9d9": "ead9b8", + "282a5d": "540916", + "b27fd4": "ce2488", + "5fbddc": "e949a7", + "2f2f2f": "ffefe5", + "d9b5fb": "f4b260", + "171717": "bc6321", + "a695ea": "c0443d", + "1a1a1a": "bb826c", + "6f65c5": "a2282c", + "b480d6": "cb7a2c", + "754691": "873c0f", + "74458f": "952274", + "eef0f2": "fff9e7" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/4144_2.png b/public/images/pokemon/variant/back/4144_2.png index 15b9c4effd1..12232202dfd 100644 Binary files a/public/images/pokemon/variant/back/4144_2.png and b/public/images/pokemon/variant/back/4144_2.png differ diff --git a/public/images/pokemon/variant/back/4144_3.png b/public/images/pokemon/variant/back/4144_3.png index d5a9bb3be73..31e8ec54f42 100644 Binary files a/public/images/pokemon/variant/back/4144_3.png and b/public/images/pokemon/variant/back/4144_3.png differ diff --git a/public/images/pokemon/variant/back/4145.json b/public/images/pokemon/variant/back/4145.json new file mode 100644 index 00000000000..9800b1a00dc --- /dev/null +++ b/public/images/pokemon/variant/back/4145.json @@ -0,0 +1,26 @@ +{ + "1": { + "50453c": "334c7f", + "863716": "7e98ad", + "ffd541": "f28b41", + "272320": "111742", + "38322d": "22253b", + "de6e33": "d85b26", + "c24814": "b3cdd9", + "3e352b": "1e2e5f", + "f76c1a": "daf6f6", + "5f2311": "5c6f8e" + }, + "2": { + "50453c": "d2ddea", + "863716": "871858", + "ffd541": "3cd96c", + "272320": "3c445e", + "38322d": "202231", + "de6e33": "25b165", + "c24814": "ba276d", + "3e352b": "9da9bd", + "f76c1a": "e14589", + "5f2311": "630645" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/4145_2.png b/public/images/pokemon/variant/back/4145_2.png index 34c2a7dd590..78af235b8ec 100644 Binary files a/public/images/pokemon/variant/back/4145_2.png and b/public/images/pokemon/variant/back/4145_2.png differ diff --git a/public/images/pokemon/variant/back/4145_3.png b/public/images/pokemon/variant/back/4145_3.png index 5fec0c38330..d97d93b7a22 100644 Binary files a/public/images/pokemon/variant/back/4145_3.png and b/public/images/pokemon/variant/back/4145_3.png differ diff --git a/public/images/pokemon/variant/back/4146.json b/public/images/pokemon/variant/back/4146.json new file mode 100644 index 00000000000..bbb217f7114 --- /dev/null +++ b/public/images/pokemon/variant/back/4146.json @@ -0,0 +1,31 @@ +{ + "1": { + "ffd5ed": "e4fff6", + "de384e": "cdf0f1", + "35454d": "f774a0", + "6b8895": "2b5584", + "e82f46": "24a8d3", + "35454b": "0d1e54", + "00bfbf": "ff78a6", + "840017": "1f557c", + "b51c2f": "77a7bb", + "ffaed7": "a5f5e7", + "f1587e": "73e1e6", + "262e30": "000240", + "54656c": "163269" + }, + "2": { + "ffd5ed": "f4ff90", + "de384e": "04723a", + "35454d": "db743c", + "6b8895": "fff9de", + "e82f46": "058323", + "35454b": "adb981", + "00bfbf": "db7640", + "840017": "00312d", + "b51c2f": "004634", + "ffaed7": "c2f75f", + "f1587e": "6acf42", + "54656c": "e4e8bb" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/4146_2.png b/public/images/pokemon/variant/back/4146_2.png index e85324322ae..37eec77a76c 100644 Binary files a/public/images/pokemon/variant/back/4146_2.png and b/public/images/pokemon/variant/back/4146_2.png differ diff --git a/public/images/pokemon/variant/back/4146_3.png b/public/images/pokemon/variant/back/4146_3.png index 9abfaca67fe..bf82c240925 100644 Binary files a/public/images/pokemon/variant/back/4146_3.png and b/public/images/pokemon/variant/back/4146_3.png differ diff --git a/public/images/pokemon/variant/back/430.json b/public/images/pokemon/variant/back/430.json new file mode 100644 index 00000000000..2edd26708c9 --- /dev/null +++ b/public/images/pokemon/variant/back/430.json @@ -0,0 +1,34 @@ +{ + "1": { + "31313a": "280113", + "8c313a": "b3986b", + "5a5a3a": "1e1e2c", + "545454": "3c3b4d", + "a3a3b5": "7a1e21", + "3a5a9c": "694c30", + "525151": "380514", + "a7a7b8": "60606c", + "efeff8": "b9382d", + "4a2121": "755237", + "ad943a": "3f3e50", + "f7de3a": "61616d", + "3a3a5a": "422e26", + "29213a": "271b1a" + }, + "2": { + "31313a": "080735", + "8c313a": "bc4b84", + "5a5a3a": "4e1915", + "545454": "85412d", + "a3a3b5": "4f358e", + "3a5a9c": "1d6e47", + "525151": "1c1754", + "a7a7b8": "c27238", + "efeff8": "975bc2", + "4a2121": "7b2363", + "ad943a": "85402c", + "f7de3a": "c2723a", + "3a3a5a": "0e4333", + "29213a": "091e16" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/453.json b/public/images/pokemon/variant/back/453.json index 1c9ccc9189c..436da3d191f 100644 --- a/public/images/pokemon/variant/back/453.json +++ b/public/images/pokemon/variant/back/453.json @@ -1,15 +1,14 @@ { "1": { "3a3a52": "4c0914", - "4a4a8c": "701221", - "6b73d6": "9e1e23", - "849cff": "c45447", - "101010": "101010", - "9c3a3a": "d07320", - "e6525a": "f2b64c", - "ff9ca5": "f7db86", - "313142": "2c0f0f", - "525252": "502424", + "4a4a8c": "701237", + "6b73d6": "9e1e4e", + "849cff": "c43658", + "9c3a3a": "ca5925", + "e6525a": "e58837", + "ff9ca5": "ffc15b", + "313142": "2f0419", + "525252": "50242f", "b5b5c5": "af7953", "7b7b8c": "794032", "ffffff": "ffe29b" diff --git a/public/images/pokemon/variant/back/454.json b/public/images/pokemon/variant/back/454.json index 52d91504c9f..0f96173cbfd 100644 --- a/public/images/pokemon/variant/back/454.json +++ b/public/images/pokemon/variant/back/454.json @@ -1,16 +1,15 @@ { "1": { "3a3a52": "4c0914", - "101010": "101010", - "6b73d6": "9e1e23", - "4a4a8c": "701221", - "849cff": "c45447", - "313142": "2c0f0f", + "6b73d6": "9e1e4e", + "4a4a8c": "701237", + "849cff": "c43658", + "313142": "2f0419", "ffd619": "c1e65a", "b58c19": "8ac43c", - "525252": "502424", - "9c3a3a": "d07320", - "e6525a": "f2b64c", + "525252": "50242f", + "9c3a3a": "ca5925", + "e6525a": "e58837", "7b7b8c": "794032", "b5b5c5": "af7953" }, diff --git a/public/images/pokemon/variant/back/455.json b/public/images/pokemon/variant/back/455.json new file mode 100644 index 00000000000..d10a2ff0741 --- /dev/null +++ b/public/images/pokemon/variant/back/455.json @@ -0,0 +1,34 @@ +{ + "1": { + "f7ce31": "7c5d53", + "9c214a": "451e14", + "2b453d": "523b3c", + "3a5a3a": "b34a82", + "5a6342": "826660", + "8c9452": "b89d8c", + "846b31": "301e20", + "bdc57b": "efd9ba", + "e62919": "775331", + "63843a": "e880ab", + "8f9653": "e2b0bc", + "29423a": "7e3b67", + "c59c31": "4d3432" + }, + "2": { + "f7ce31": "518078", + "ffffff": "affffe", + "9c214a": "1e4340", + "2b453d": "151926", + "3a5a3a": "37818a", + "5a6342": "2d304e", + "8c9452": "424d6e", + "846b31": "122e2f", + "bdc57b": "6679a1", + "e62919": "406b64", + "63843a": "74ddcd", + "422919": "0d2626", + "8f9653": "3d909b", + "29423a": "123247", + "c59c31": "244a45" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/486.json b/public/images/pokemon/variant/back/486.json new file mode 100644 index 00000000000..36a343a2966 --- /dev/null +++ b/public/images/pokemon/variant/back/486.json @@ -0,0 +1,32 @@ +{ + "1": { + "fafafa": "ffc245", + "adadc5": "ca7426", + "8c94ad": "13081a", + "374859": "6b76a4", + "d6ced6": "e89b34", + "f7d65a": "ce5129", + "5f6d7d": "7b2a19", + "ffffff": "eb8746", + "21846b": "90a7cd", + "3a4a5a": "5e1e33", + "c59c52": "a12612", + "7b6321": "3d021b", + "4aa563": "e2f2ff" + }, + "2": { + "fafafa": "88b06f", + "adadc5": "4f673a", + "8c94ad": "494922", + "374859": "2f1a18", + "d6ced6": "6e884b", + "f7d65a": "8f9b9e", + "5f6d7d": "374427", + "ffffff": "a8afaf", + "21846b": "492f29", + "3a4a5a": "3b1930", + "c59c52": "5d717a", + "7b6321": "384751", + "4aa563": "755648" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/501.json b/public/images/pokemon/variant/back/501.json new file mode 100644 index 00000000000..3476b2710b1 --- /dev/null +++ b/public/images/pokemon/variant/back/501.json @@ -0,0 +1,24 @@ +{ + "1": { + "215a63": "1e1a35", + "c5c5ce": "e3c2ca", + "4a6bad": "9660d1", + "294252": "241e44", + "21949c": "373049", + "29bdc5": "5d4a70", + "31426b": "4b349e", + "212142": "241e44" + }, + "2": { + "8c8c9c": "8f7491", + "4a4a4a": "715b72", + "215a63": "000000", + "c5c5ce": "ba9bc1", + "4a6bad": "589787", + "21949c": "321e1e", + "29bdc5": "5e3e38", + "31426b": "3c706b", + "ffffff": "f5e9f4", + "212142": "104432" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/502.json b/public/images/pokemon/variant/back/502.json new file mode 100644 index 00000000000..26772013df7 --- /dev/null +++ b/public/images/pokemon/variant/back/502.json @@ -0,0 +1,28 @@ +{ + "1": { + "4a4a4a": "20193d", + "31528c": "9d5bc9", + "293a6b": "503e8e", + "7b5a10": "d877cd", + "52bdbd": "624060", + "c59429": "ff9ef3", + "efd68c": "f2d5ee", + "313131": "120f33", + "315a73": "1e1624", + "218c94": "39273d", + "fffdfd": "ebb9c4" + }, + "2": { + "4a4a4a": "2c3940", + "31528c": "5e3e38", + "293a6b": "321e1e", + "7b5a10": "0d5656", + "52bdbd": "8b7566", + "c59429": "488383", + "efd68c": "63c7bd", + "313131": "1f2b36", + "315a73": "483026", + "218c94": "684f44", + "fffdfd": "ffffc2" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/503.json b/public/images/pokemon/variant/back/503.json new file mode 100644 index 00000000000..9eb2168dd5b --- /dev/null +++ b/public/images/pokemon/variant/back/503.json @@ -0,0 +1,33 @@ +{ + "1": { + "84a5a5": "563785", + "4a4a4a": "5e283e", + "215a9c": "4d244b", + "8aa3a3": "a05982", + "d65263": "b73891", + "ad945a": "db87d1", + "7b6342": "975fad", + "474a46": "2b1838", + "fffeff": "ebb9c4", + "213a63": "28142c", + "4a4a4c": "6b3e51", + "d6c57b": "f2d5ee", + "5a7373": "332a59", + "8da8a8": "a58b90" + }, + "2": { + "4a4a4a": "c2700d", + "215a9c": "5e3e38", + "8aa3a3": "efa838", + "d65263": "41857b", + "ad945a": "488383", + "7b6342": "0d5656", + "474a46": "462d27", + "fffeff": "f9df58", + "213a63": "321e1e", + "4a4a4c": "c2700d", + "d6c57b": "63c7bd", + "5a7373": "2a5c57", + "8da8a8": "84a5a5" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/527.json b/public/images/pokemon/variant/back/527.json new file mode 100644 index 00000000000..67767eefcb3 --- /dev/null +++ b/public/images/pokemon/variant/back/527.json @@ -0,0 +1,20 @@ +{ + "1": { + "424a5a": "866ca1", + "6b94ad": "6e315e", + "73adc5": "853e66", + "292931": "55457a", + "addef7": "914a6e", + "4a6b7b": "562259", + "27272f": "361538" + }, + "2": { + "424a5a": "bf3f75", + "6b94ad": "db843d", + "73adc5": "e8b04f", + "292931": "8c2961", + "addef7": "f7e05c", + "4a6b7b": "994d22", + "27272f": "7c3622" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/528.json b/public/images/pokemon/variant/back/528.json new file mode 100644 index 00000000000..fb91d0318a5 --- /dev/null +++ b/public/images/pokemon/variant/back/528.json @@ -0,0 +1,30 @@ +{ + "1": { + "317b94": "6e315e", + "4c4c54": "582253", + "313131": "55457a", + "de8c84": "6bc7e8", + "6b7b84": "439ca1", + "ceefff": "a6ffd7", + "bdbdce": "76debd", + "19a5ce": "914a6e", + "944a4a": "4874b8", + "313132": "451b41", + "4a4a52": "866ca1", + "47474f": "2e6f7a" + }, + "2": { + "317b94": "e0b49a", + "4c4c54": "a6705e", + "313131": "701c4c", + "de8c84": "7b5ebf", + "6b7b84": "994d22", + "ceefff": "f7e05c", + "bdbdce": "db843d", + "19a5ce": "f9fae3", + "944a4a": "393582", + "313132": "a87354", + "4a4a52": "bf3f75", + "47474f": "6b2314" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/587.json b/public/images/pokemon/variant/back/587.json new file mode 100644 index 00000000000..85c4c20f4f0 --- /dev/null +++ b/public/images/pokemon/variant/back/587.json @@ -0,0 +1,28 @@ +{ + "1": { + "212121": "1d352a", + "d6a531": "a84223", + "b58c08": "681c0e", + "bda573": "5a9fbf", + "6b5a31": "16223d", + "cec5ad": "8bd5dc", + "7f6b0d": "3b1c1b", + "846e07": "35708c", + "ffd600": "d55b19", + "9c9c73": "406da4", + "313131": "2b5d3f" + }, + "2": { + "212121": "372a5b", + "d6a531": "6597cd", + "b58c08": "4879af", + "bda573": "9b4072", + "6b5a31": "321832", + "cec5ad": "c4658e", + "7f6b0d": "355c90", + "846e07": "723158", + "ffd600": "8bcaee", + "9c9c73": "7b3760", + "313131": "5e3a86" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/588.json b/public/images/pokemon/variant/back/588.json new file mode 100644 index 00000000000..c00f1886940 --- /dev/null +++ b/public/images/pokemon/variant/back/588.json @@ -0,0 +1,20 @@ +{ + "1": { + "213a5a": "2f185b", + "316bff": "8150a7", + "4a4a4a": "64242d", + "313131": "38131d", + "000000": "ffffff", + "528cff": "c682d6", + "3a5284": "492c72" + }, + "2": { + "213a5a": "44446f", + "316bff": "d2cdeb", + "4a4a4a": "28334f", + "313131": "182138", + "000000": "ffffff", + "528cff": "f9f3ff", + "3a5284": "7777a7" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/589.json b/public/images/pokemon/variant/back/589.json new file mode 100644 index 00000000000..b499504daa3 --- /dev/null +++ b/public/images/pokemon/variant/back/589.json @@ -0,0 +1,30 @@ +{ + "1": { + "c5c5c5": "f9c347", + "ef2952": "eb8343", + "bd2152": "c44126", + "840808": "931119", + "bd9c19": "b8c5e5", + "e65a10": "614593", + "6b6b6b": "b34516", + "294a84": "7436a4", + "195abd": "9448bf", + "94949c": "dc862d", + "000000": "ffffff", + "3a424a": "69130d" + }, + "2": { + "c5c5c5": "6e8e99", + "ef2952": "f7efff", + "bd2152": "beb7df", + "840808": "72709e", + "bd9c19": "a42641", + "e65a10": "ffe8c3", + "6b6b6b": "293a52", + "294a84": "4f3d33", + "195abd": "785442", + "94949c": "3f6372", + "000000": "ffffff", + "3a424a": "1b253d" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/590.json b/public/images/pokemon/variant/back/590.json new file mode 100644 index 00000000000..7d19153ec2c --- /dev/null +++ b/public/images/pokemon/variant/back/590.json @@ -0,0 +1,30 @@ +{ + "1": { + "684c30": "0d9999", + "9c3a3a": "71de8c", + "846b63": "0fad9a", + "9c3a7b": "88af70", + "6b4a31": "0d9999", + "422929": "0a5870", + "7b3131": "49ad77", + "de5a52": "e6ffc1", + "d6639c": "f4ebba", + "7a3730": "49aa87", + "c5b59c": "47d1b5", + "fff7e6": "afecc6" + }, + "2": { + "684c30": "2b5caf", + "9c3a3a": "e098cd", + "846b63": "64a3bc", + "9c3a7b": "b1c4dd", + "6b4a31": "f2f7f9", + "422929": "b9d9e5", + "7b3131": "ad629a", + "de5a52": "ffbfcb", + "d6639c": "f2f7f9", + "7a3730": "404f6b", + "c5b59c": "498cd3", + "fff7e6": "6ac2e2" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/591.json b/public/images/pokemon/variant/back/591.json new file mode 100644 index 00000000000..0d369a42c02 --- /dev/null +++ b/public/images/pokemon/variant/back/591.json @@ -0,0 +1,28 @@ +{ + "1": { + "cec5c5": "afecc6", + "291919": "094164", + "de528c": "e6ffc1", + "634c42": "348999", + "423331": "094164", + "9c9484": "47d1b5", + "634d42": "0c7588", + "634a42": "0d9999", + "423131": "0a5870", + "6b314a": "49ad77", + "ad3163": "71de8c" + }, + "2": { + "cec5c5": "6ac2e2", + "291919": "5e718e", + "de528c": "ffbfcb", + "634c42": "3f7dc7", + "423331": "223656", + "9c9484": "56a1e2", + "634d42": "2b5caf", + "634a42": "f2f7f9", + "423131": "9bb6c1", + "6b314a": "ad629a", + "ad3163": "e098cd" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/616.json b/public/images/pokemon/variant/back/616.json new file mode 100644 index 00000000000..a883b42edc8 --- /dev/null +++ b/public/images/pokemon/variant/back/616.json @@ -0,0 +1,26 @@ +{ + "1": { + "3a8442": "4e3671", + "5a5a7b": "b34516", + "9494ad": "dc862d", + "630021": "204b4f", + "b5214a": "346c65", + "ff4a7b": "6ba779", + "de3163": "4a8474", + "29315a": "69130d", + "c5c5d6": "f9c347", + "000000": "ffffff" + }, + "2": { + "3a8442": "d6aa53", + "5a5a7b": "293a52", + "9494ad": "3f6372", + "630021": "2e3469", + "b5214a": "4f62a4", + "ff4a7b": "8cb0d6", + "de3163": "6b8bbf", + "29315a": "1b253d", + "c5c5d6": "6e8e99", + "000000": "ffffff" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/617.json b/public/images/pokemon/variant/back/617.json new file mode 100644 index 00000000000..93310065d35 --- /dev/null +++ b/public/images/pokemon/variant/back/617.json @@ -0,0 +1,30 @@ +{ + "1": { + "ffffff": "fff47e", + "a5846b": "5a6675", + "42b55a": "4e3671", + "c53a6b": "427b6b", + "636363": "c46d31", + "bdbdce": "df9847", + "527b42": "362658", + "732931": "214c49", + "ff4a7b": "6ba779", + "6b84c5": "eef5ff", + "293a6b": "69719e", + "000000": "ffffff", + "3a2919": "192638", + "5a6384": "b8c5e5" + }, + "2": { + "a5846b": "637974", + "42b55a": "415c69", + "c53a6b": "dcaa47", + "527b42": "2d3d52", + "ff4a7b": "ffee72", + "6b84c5": "b43d40", + "293a6b": "461b2e", + "000000": "ffffff", + "3a2919": "2a2235", + "5a6384": "7b2c3d" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/621.json b/public/images/pokemon/variant/back/621.json new file mode 100644 index 00000000000..cf80562d31f --- /dev/null +++ b/public/images/pokemon/variant/back/621.json @@ -0,0 +1,26 @@ +{ + "1": { + "8c7b5a": "73654b", + "940042": "1a2248", + "104a8c": "7e231b", + "635231": "605127", + "efc500": "5c7886", + "103163": "601111", + "521031": "0f1330", + "d60042": "26335d", + "316bad": "a13b2c", + "d65273": "be5b5e" + }, + "2": { + "8c7b5a": "da8921", + "940042": "177297", + "104a8c": "c9bb9a", + "635231": "be6e18", + "efc500": "ffd437", + "103163": "a0896b", + "521031": "0f4973", + "d60042": "24aec0", + "316bad": "e3ddbd", + "d65273": "c583a5" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/6503.json b/public/images/pokemon/variant/back/6503.json new file mode 100644 index 00000000000..455b06a69d6 --- /dev/null +++ b/public/images/pokemon/variant/back/6503.json @@ -0,0 +1,38 @@ +{ + "1": { + "282f62": "f7d9de", + "84a5a5": "563785", + "a82c47": "d45b9e", + "8aa3a3": "d3a0bb", + "faf9f9": "f6f4f4", + "494a48": "3d2439", + "1d3962": "28142c", + "474a46": "2b1838", + "d75063": "b73891", + "fbfcfa": "fafcf9", + "324149": "363442", + "1e224e": "dc95ae", + "6b1c34": "8f3396", + "181531": "a26579", + "5a7373": "332a59", + "8da8a8": "a58b90", + "1e5b9b": "4d244b" + }, + "2": { + "282f62": "efdfee", + "84a5a5": "41857b", + "a82c47": "8abfb1", + "8aa3a3": "232d2e", + "faf9f9": "2c3940", + "494a48": "181f20", + "1d3962": "321e1e", + "474a46": "181f20", + "d75063": "8f65d8", + "fbfcfa": "fcfdfc", + "1e224e": "ba9bc1", + "6b1c34": "6d9d9a", + "181531": "715b72", + "5a7373": "2a5c57", + "1e5b9b": "5e3e38" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/656.json b/public/images/pokemon/variant/back/656.json new file mode 100644 index 00000000000..34b11bfab78 --- /dev/null +++ b/public/images/pokemon/variant/back/656.json @@ -0,0 +1,24 @@ +{ + "1": { + "838394": "4d7dc5", + "7bcdff": "9c75c2", + "62ace6": "8363af", + "ffffff": "b1e5ff", + "396a83": "362864", + "9c9cc5": "5385c7", + "cdcde6": "7eb7e8", + "174592": "198158", + "5a94cd": "7054a4" + }, + "2": { + "838394": "cc6845", + "7bcdff": "dd6155", + "62ace6": "c44848", + "ffffff": "fff4bd", + "396a83": "5c0d33", + "9c9cc5": "c96a48", + "cdcde6": "f7b785", + "174592": "198158", + "5a94cd": "a92f3f" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/657.json b/public/images/pokemon/variant/back/657.json new file mode 100644 index 00000000000..083a9dba0a6 --- /dev/null +++ b/public/images/pokemon/variant/back/657.json @@ -0,0 +1,24 @@ +{ + "1": { + "f8f8f8": "8dcfff", + "737373": "0f3f82", + "0b566a": "281f52", + "002c58": "1c0726", + "bfbfbf": "4386df", + "006ba6": "4e1852", + "0b4a7a": "340f3d", + "41ccf5": "7755a7", + "2896b5": "4b3578" + }, + "2": { + "f8f8f8": "fff6c7", + "737373": "df6a50", + "0b566a": "7e1628", + "002c58": "0c3b54", + "bfbfbf": "ffc996", + "006ba6": "239c91", + "0b4a7a": "156f78", + "41ccf5": "dd7355", + "2896b5": "a92f3a" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/658-ash.json b/public/images/pokemon/variant/back/658-ash.json new file mode 100644 index 00000000000..370d5df8081 --- /dev/null +++ b/public/images/pokemon/variant/back/658-ash.json @@ -0,0 +1,38 @@ +{ + "1": { + "265595": "432b6c", + "de3431": "3fca9f", + "f8f8f8": "a1e9f0", + "7b282e": "0e3e81", + "6b1d1d": "206d74", + "134e52": "062e3c", + "bfb169": "165e78", + "ffb2bf": "b7e9ff", + "bf4c60": "4386df", + "282c35": "271f4c", + "f2798d": "8dcfff", + "268794": "1c3e58", + "3e7acc": "6b4592", + "7ddeff": "7ddcd6", + "4ebdd9": "41a7b0", + "18335c": "170738" + }, + "2": { + "265595": "cc7251", + "de3431": "9ceec6", + "f8f8f8": "89d2b8", + "7b282e": "152a5c", + "6b1d1d": "356e8d", + "134e52": "0d1e3e", + "bfb169": "4d2637", + "ffb2bf": "86d6b6", + "bf4c60": "32738b", + "282c35": "4d2637", + "f2798d": "5eb4a9", + "268794": "1c3e58", + "3e7acc": "ecbb7a", + "7ddeff": "46988d", + "4ebdd9": "2f6e74", + "18335c": "9f2727" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/658.json b/public/images/pokemon/variant/back/658.json new file mode 100644 index 00000000000..c1bb4222ce4 --- /dev/null +++ b/public/images/pokemon/variant/back/658.json @@ -0,0 +1,26 @@ +{ + "1": { + "ffb2bf": "b7e9ff", + "bf4c60": "4386df", + "3d61cc": "6b4592", + "fff0a6": "208698", + "2e4999": "432b6c", + "f2798d": "8dcfff", + "803340": "0e3e81", + "1b2a59": "170738", + "66d9ff": "7ddcd6", + "bfb169": "165e78" + }, + "2": { + "ffb2bf": "86d6b6", + "bf4c60": "32738b", + "3d61cc": "ecbb7a", + "fff0a6": "652240", + "2e4999": "cc7251", + "f2798d": "5eb4a9", + "803340": "152a5c", + "1b2a59": "9f2727", + "66d9ff": "48968c", + "bfb169": "431022" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/6706.json b/public/images/pokemon/variant/back/6706.json new file mode 100644 index 00000000000..2de5352e936 --- /dev/null +++ b/public/images/pokemon/variant/back/6706.json @@ -0,0 +1,38 @@ +{ + "1": { + "566678": "197497", + "8e96aa": "3b235c", + "929aad": "3aa8c4", + "625287": "4e4094", + "536273": "301848", + "988b98": "b24c86", + "36404c": "0c5474", + "c4cce1": "513981", + "e6d3e9": "f1a4c5", + "bfacc1": "d074a0", + "546475": "0e6296", + "c5cee3": "63cee1", + "80737f": "8a2166", + "4b454f": "6f1357", + "9170b9": "8b69c3", + "b791f2": "c7a1e5" + }, + "2": { + "566678": "a34205", + "8e96aa": "073338", + "929aad": "d27e26", + "625287": "0e3f47", + "536273": "042329", + "988b98": "2b736f", + "36404c": "842401", + "c4cce1": "0d484a", + "e6d3e9": "9cead8", + "bfacc1": "5db6a9", + "546475": "8e480b", + "c5cee3": "f7af58", + "80737f": "194f51", + "4b454f": "274159", + "9170b9": "2f667c", + "b791f2": "4a9699" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/6706_2.json b/public/images/pokemon/variant/back/6706_2.json deleted file mode 100644 index dccfbce60c5..00000000000 --- a/public/images/pokemon/variant/back/6706_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "6706_2.png", - "format": "RGBA8888", - "size": { - "w": 79, - "h": 79 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 79, - "h": 73 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 79, - "h": 73 - }, - "frame": { - "x": 0, - "y": 0, - "w": 79, - "h": 73 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:64f7e6dfa489012922487e45ba53d557:4d24652b372939abe499497c4b6647b0:d60cc2e5ae2bd18de8ee3ab0649593ee$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/6706_3.json b/public/images/pokemon/variant/back/6706_3.json deleted file mode 100644 index 9a97ce27059..00000000000 --- a/public/images/pokemon/variant/back/6706_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "6706_3.png", - "format": "RGBA8888", - "size": { - "w": 79, - "h": 79 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 79, - "h": 73 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 79, - "h": 73 - }, - "frame": { - "x": 0, - "y": 0, - "w": 79, - "h": 73 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:64f7e6dfa489012922487e45ba53d557:4d24652b372939abe499497c4b6647b0:d60cc2e5ae2bd18de8ee3ab0649593ee$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/676-dandy.json b/public/images/pokemon/variant/back/676-dandy.json new file mode 100644 index 00000000000..f73bd90f690 --- /dev/null +++ b/public/images/pokemon/variant/back/676-dandy.json @@ -0,0 +1,28 @@ +{ + "1": { + "594d46": "788087", + "376277": "4f8fe3", + "9c9f94": "42090e", + "30552b": "423839", + "b8bcaf": "5e0f16", + "508a3c": "aa9999", + "f1f2ee": "8a1d1d", + "816e64": "a6afb3", + "6eb92b": "eddddd", + "4b4b46": "2b040f" + }, + "2": { + "594d46": "9c7aca", + "376277": "314173", + "fe3c31": "8362b4", + "9c9f94": "ad76bc", + "30552b": "6a102e", + "b8bcaf": "ce9ede", + "508a3c": "ac254b", + "f1f2ee": "e6c3f8", + "a83c31": "473085", + "816e64": "ae95dc", + "6eb92b": "e44a62", + "4b4b46": "6b3f77" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/676-debutante.json b/public/images/pokemon/variant/back/676-debutante.json new file mode 100644 index 00000000000..cad1f7792f0 --- /dev/null +++ b/public/images/pokemon/variant/back/676-debutante.json @@ -0,0 +1,28 @@ +{ + "1": { + "594d46": "788087", + "376277": "4f8fe3", + "9c9f94": "42090e", + "dfb76a": "aa9999", + "4b4b46": "2b040f", + "bcc0b3": "5e0f16", + "816e64": "a6afb3", + "ac6d40": "423839", + "f8f9f7": "8a1d1d", + "fbf588": "eddddd" + }, + "2": { + "594d46": "48a7d0", + "376277": "717171", + "fe3c31": "762ea8", + "9c9f94": "0b374f", + "dfb76a": "c6a65c", + "4b4b46": "021a2f", + "bcc0b3": "0b4b68", + "a83c31": "521073", + "816e64": "74ccec", + "ac6d40": "684d24", + "f8f9f7": "0e728e", + "fbf588": "ffe998" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/676-diamond.json b/public/images/pokemon/variant/back/676-diamond.json new file mode 100644 index 00000000000..35876619287 --- /dev/null +++ b/public/images/pokemon/variant/back/676-diamond.json @@ -0,0 +1,30 @@ +{ + "1": { + "594d46": "788087", + "aa3e2b": "423839", + "b8bcaf": "5e0f16", + "f1f2ee": "8a1d1d", + "376277": "4f8fe3", + "645e55": "2b040f", + "d95b37": "aa9999", + "e68a4d": "eddddd", + "453434": "313439", + "816e64": "a6afb3", + "9c9f94": "42090e" + }, + "2": { + "594d46": "bd9462", + "aa3e2b": "642c0a", + "b8bcaf": "319c6a", + "f1f2ee": "6abd81", + "376277": "c56e34", + "fe3c31": "b37e47", + "645e55": "10573c", + "d95b37": "935927", + "e68a4d": "b37e47", + "453434": "6c4b2d", + "a83c31": "642c0a", + "816e64": "eed59c", + "9c9f94": "288c66" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/676-heart.json b/public/images/pokemon/variant/back/676-heart.json new file mode 100644 index 00000000000..abb8ed1a9b3 --- /dev/null +++ b/public/images/pokemon/variant/back/676-heart.json @@ -0,0 +1,30 @@ +{ + "1": { + "594d46": "788087", + "f18598": "48474c", + "b8bcaf": "5e0f16", + "f1f2ee": "8a1d1d", + "e0546c": "2a2a2f", + "376277": "4f8fe3", + "645e55": "2b040f", + "453434": "313439", + "816e64": "a6afb3", + "a73f4f": "19181f", + "9c9f94": "42090e" + }, + "2": { + "594d46": "aca49c", + "f18598": "5f5953", + "b8bcaf": "bfc7e8", + "f1f2ee": "e4eafc", + "e0546c": "4c413c", + "376277": "1b1c21", + "fe3c31": "9475de", + "645e55": "7a81b7", + "453434": "837373", + "a83c31": "7249b7", + "816e64": "dadace", + "a73f4f": "2c2320", + "9c9f94": "9fa7c8" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/676-kabuki.json b/public/images/pokemon/variant/back/676-kabuki.json new file mode 100644 index 00000000000..54e87ca19b2 --- /dev/null +++ b/public/images/pokemon/variant/back/676-kabuki.json @@ -0,0 +1,36 @@ +{ + "1": { + "811d1d": "240b12", + "8f2121": "19181f", + "b01a1a": "17161c", + "d02f2e": "2a2a2f", + "594d46": "a6afb3", + "f66559": "fe3c31", + "f44b3d": "313439", + "376277": "436ca1", + "8a7d79": "788087", + "68675c": "2b040f", + "9c9f94": "42090e", + "534343": "360513", + "bcc0b3": "5e0f16", + "f1f2ee": "8a1d1d", + "b32524": "a83c31" + }, + "2": { + "811d1d": "181a38", + "8f2121": "191b38", + "b01a1a": "48578e", + "d02f2e": "305d9e", + "594d46": "3e5368", + "f66559": "9890ec", + "f44b3d": "4c89d9", + "376277": "436ca1", + "8a7d79": "233342", + "68675c": "1b1d39", + "9c9f94": "468197", + "534343": "192b42", + "bcc0b3": "549ab8", + "f1f2ee": "6bcfd9", + "b32524": "8067c6" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/676-la-reine.json b/public/images/pokemon/variant/back/676-la-reine.json new file mode 100644 index 00000000000..a464639a025 --- /dev/null +++ b/public/images/pokemon/variant/back/676-la-reine.json @@ -0,0 +1,28 @@ +{ + "1": { + "8a7d79": "788087", + "376277": "4f8fe3", + "31a7bb": "aa9999", + "594d46": "a6afb3", + "4b4b46": "2b040f", + "9c9f94": "42090e", + "56d1d8": "eddddd", + "bcc0b3": "5e0f16", + "2f7387": "423839", + "f1f2ee": "8a1d1d" + }, + "2": { + "a83c31": "3041b7", + "8a7d79": "a11e24", + "376277": "221755", + "31a7bb": "e3b876", + "594d46": "973721", + "4b4b46": "550b0c", + "9c9f94": "c63b31", + "56d1d8": "ffec9b", + "bcc0b3": "d9533c", + "2f7387": "8e673e", + "f1f2ee": "ee724b", + "fe3c31": "4b77e1" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/676-matron.json b/public/images/pokemon/variant/back/676-matron.json new file mode 100644 index 00000000000..70a32e09a19 --- /dev/null +++ b/public/images/pokemon/variant/back/676-matron.json @@ -0,0 +1,29 @@ +{ + "1": { + "873a5b": "19181f", + "376277": "4f8fe3", + "9c9f94": "42090e", + "594d46": "788087", + "b8bcaf": "5e0f16", + "5f5951": "2b040f", + "121212": "101010", + "b95b83": "2a2a2f", + "816e64": "a6afb3", + "f8f9f7": "8a1d1d", + "d07da9": "313439" + }, + "2": { + "873a5b": "1b447b", + "376277": "2246aa", + "fe3c31": "64edf3", + "9c9f94": "bd4d6a", + "594d46": "d0b5b5", + "b8bcaf": "d95e7e", + "5f5951": "8a2843", + "b95b83": "528fcc", + "816e64": "e3d6d6", + "a83c31": "45a6d0", + "f8f9f7": "fa8c9f", + "d07da9": "64c8f3" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/676-pharaoh.json b/public/images/pokemon/variant/back/676-pharaoh.json new file mode 100644 index 00000000000..fa9c60533b6 --- /dev/null +++ b/public/images/pokemon/variant/back/676-pharaoh.json @@ -0,0 +1,30 @@ +{ + "1": { + "594d46": "788087", + "376277": "4f8fe3", + "9c9f94": "42090e", + "bcc0b3": "5e0f16", + "25559c": "2a2a2f", + "484640": "2b040f", + "217fc4": "313439", + "68675c": "2b040f", + "816e64": "42090e", + "243a6f": "19181f", + "f1f2ee": "8a1d1d" + }, + "2": { + "594d46": "22172f", + "376277": "5e0808", + "fe3c31": "ec4d3e", + "9c9f94": "332b42", + "bcc0b3": "3b3955", + "25559c": "d0902d", + "484640": "17122f", + "217fc4": "eed552", + "68675c": "17122f", + "a83c31": "a11717", + "816e64": "332b42", + "243a6f": "a15317", + "f1f2ee": "5a5a71" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/676-star.json b/public/images/pokemon/variant/back/676-star.json new file mode 100644 index 00000000000..f6bdec0ca9e --- /dev/null +++ b/public/images/pokemon/variant/back/676-star.json @@ -0,0 +1,30 @@ +{ + "1": { + "594d46": "788087", + "b8bcaf": "5e0f16", + "f1f2ee": "8a1d1d", + "3a5078": "19181f", + "376277": "4f8fe3", + "645e55": "2b040f", + "3e8ebf": "2a2a2f", + "9c9f94": "42090e", + "453434": "48474c", + "816e64": "a6afb3", + "7dc2e8": "313439" + }, + "2": { + "594d46": "d7bc4d", + "b8bcaf": "d6dec2", + "f1f2ee": "fcfef5", + "3a5078": "613d11", + "376277": "647bb1", + "fe3c31": "b5e0f3", + "645e55": "848e75", + "3e8ebf": "ac802f", + "9c9f94": "c3cdab", + "453434": "836329", + "a83c31": "6192aa", + "816e64": "f7e784", + "7dc2e8": "cdac4a" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/676.json b/public/images/pokemon/variant/back/676.json new file mode 100644 index 00000000000..9a8ab0f7aa3 --- /dev/null +++ b/public/images/pokemon/variant/back/676.json @@ -0,0 +1,23 @@ +{ + "1": { + "bcbca8": "5e0f16", + "606056": "2b040f", + "8e8e7b": "42090e", + "f2f2da": "8a1d1d", + "3f6273": "2b040f", + "736b67": "a6afb3", + "494340": "788087", + "3f6274": "4f8fe3" + }, + "2": { + "bcbca8": "a4624a", + "cc2929": "3a240e", + "606056": "4a281b", + "8e8e7b": "805145", + "f2f2da": "c18960", + "3f6273": "4a281b", + "736b67": "ffe6ac", + "494340": "e6c594", + "3f6274": "4a2e23" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/682.json b/public/images/pokemon/variant/back/682.json new file mode 100644 index 00000000000..5b3a6821f1f --- /dev/null +++ b/public/images/pokemon/variant/back/682.json @@ -0,0 +1,20 @@ +{ + "1": { + "6b3962": "30185d", + "cc7087": "318759", + "993d80": "4f297e", + "ff99b3": "48ab61", + "7f4d59": "20644e" + }, + "2": { + "6b3962": "b89477", + "cc7087": "c3561a", + "993d80": "d2bfa1", + "ff99b3": "da7e29", + "7f4d59": "a23812", + "a6a6a6": "503851", + "737373": "422f46", + "4d4d4d": "332539", + "e5e5e5": "6b4767" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/683.json b/public/images/pokemon/variant/back/683.json new file mode 100644 index 00000000000..9d7f4682b9a --- /dev/null +++ b/public/images/pokemon/variant/back/683.json @@ -0,0 +1,20 @@ +{ + "1": { + "6b3962": "30185d", + "cc7087": "318759", + "993d80": "4f297e", + "ff99b3": "48ab61", + "404040": "2c283b", + "7f4d59": "20644e", + "bf5f9f": "7c48a1" + }, + "2": { + "6b3962": "b89477", + "cc7087": "c3561a", + "993d80": "d2bfa1", + "ff99b3": "da7e29", + "404040": "2a2234", + "7f4d59": "a23812", + "bf5f9f": "f0ebdd" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/684.json b/public/images/pokemon/variant/back/684.json new file mode 100644 index 00000000000..18afd91b4a2 --- /dev/null +++ b/public/images/pokemon/variant/back/684.json @@ -0,0 +1,18 @@ +{ + "1": { + "805963": "3c195b", + "7b5760": "8f1d15", + "cc99a6": "814db1", + "ffccd9": "8961c6", + "fff2f2": "f39f62", + "ccadad": "e6774a" + }, + "2": { + "805963": "679baa", + "7b5760": "3c2f51", + "cc99a6": "93d6ce", + "ffccd9": "cbf6da", + "fff2f2": "746998", + "ccadad": "4b4876" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/685.json b/public/images/pokemon/variant/back/685.json new file mode 100644 index 00000000000..87b0bad9422 --- /dev/null +++ b/public/images/pokemon/variant/back/685.json @@ -0,0 +1,28 @@ +{ + "1": { + "f8f8f8": "caff90", + "661a2d": "13391c", + "805963": "2d0c42", + "7b5760": "b13924", + "ffccd9": "8961c6", + "ff8ca9": "8dbe6d", + "cc99a6": "613b84", + "e53964": "689b52", + "fff2f2": "f39f62", + "ccadad": "df6b40", + "a62949": "26592b" + }, + "2": { + "f8f8f8": "e4819d", + "661a2d": "26061b", + "805963": "679baa", + "7b5760": "3c2f51", + "ffccd9": "cbf6da", + "ff8ca9": "8c4264", + "cc99a6": "93d6ce", + "e53964": "612747", + "fff2f2": "746998", + "ccadad": "4b4876", + "a62949": "441838" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/688.json b/public/images/pokemon/variant/back/688.json new file mode 100644 index 00000000000..ac388cd384e --- /dev/null +++ b/public/images/pokemon/variant/back/688.json @@ -0,0 +1,30 @@ +{ + "1": { + "b7653f": "459aac", + "385860": "70240f", + "6b503b": "373295", + "372e27": "220a56", + "c0e0e8": "e8d37b", + "8a6d45": "4557b5", + "808080": "7c582e", + "5890b0": "a9582e", + "fcffff": "e8e5c6", + "d0d0d0": "d3bc8c", + "88c0c8": "cd8a50", + "ef8955": "70cccf" + }, + "2": { + "b7653f": "332149", + "385860": "2c052a", + "6b503b": "ba9fba", + "372e27": "1e1324", + "c0e0e8": "a74083", + "8a6d45": "f6eefc", + "808080": "4d6a09", + "5890b0": "4b0038", + "fcffff": "d1ec8c", + "d0d0d0": "94c268", + "88c0c8": "731f5c", + "ef8955": "4a376e" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/689.json b/public/images/pokemon/variant/back/689.json new file mode 100644 index 00000000000..6c47b57f35b --- /dev/null +++ b/public/images/pokemon/variant/back/689.json @@ -0,0 +1,31 @@ +{ + "1": { + "cc7f70": "459aac", + "f2f2f2": "e8e5c6", + "5b8da6": "8d5030", + "595959": "7c582e", + "403410": "220a56", + "3f6273": "672e1e", + "b3b3b3": "d3bc8c", + "bfeaff": "e8d37b", + "85b4cc": "cd8a50", + "ff9f8c": "70cccf", + "66541f": "373295", + "997e2e": "4557b5" + }, + "2": { + "cc7f70": "332149", + "f2f2f2": "caea77", + "5b8da6": "4b0038", + "595959": "2a5524", + "403410": "3f2a4b", + "3f6273": "3e073b", + "b3b3b3": "7eac4e", + "bfeaff": "a74083", + "85b4cc": "731f5c", + "f8f8f8": "dbaf67", + "ff9f8c": "4a376e", + "66541f": "ccb6cc", + "997e2e": "f6eefc" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/696.json b/public/images/pokemon/variant/back/696.json index c4af966a10a..a953f1b1cb3 100644 --- a/public/images/pokemon/variant/back/696.json +++ b/public/images/pokemon/variant/back/696.json @@ -1,14 +1,53 @@ { "1": { - "734517": "5e0b0b", - "ffa64c": "a50d0d", - "4a322c": "023425", - "101010": "101010", - "404040": "4c3216", - "966858": "1b6430", - "f8f8f8": "dfdea7", - "65483a": "0b4c29", - "bfbfbf": "cbbe8c", - "8c8c8c": "ad8c63" + "734517":"5e0b0b", + "ffa64c":"a50d0d", + "4a322c":"023425", + "101010":"101010", + "404040":"4c3216", + "966858":"1b6430", + "f8f8f8":"dfdea7", + "65483a":"0b4c29", + "bfbfbf":"cbbe8c", + "8c8c8c":"ad8c63", + "121212":"121212", + "bdbdbd":"cfc28f" + }, + "2": { + "734517":"395cb7", + "ffa64c":"d2e9ff", + "4a322c":"3e1f18", + "101010":"101010", + "404040":"250860", + "966858":"83726e", + "f8f8f8":"6e46a7", + "65483a":"644943", + "bfbfbf":"593097", + "8c8c8c":"411684", + "121212":"decaff", + "bdbdbd":"79c8d3" } -} \ No newline at end of file +} + + + + + + + + + + + + + + + + + + + + + + + diff --git a/public/images/pokemon/variant/back/697.json b/public/images/pokemon/variant/back/697.json index d0fcb85853a..392be597d2e 100644 --- a/public/images/pokemon/variant/back/697.json +++ b/public/images/pokemon/variant/back/697.json @@ -1,16 +1,32 @@ { "1": { - "54434c": "4c3216", - "080808": "080808", - "fafafa": "dfdea7", - "cccccc": "cbbe8c", - "964b1c": "5e0b0b", - "f19d5a": "b52424", - "bf7545": "971c1c", - "50131e": "0b241e", - "963e4e": "285234", - "722533": "153626", - "9f9d98": "ad8c63", - "32252c": "32252c" + "54434c":"4c3216", + "080808":"080808", + "fafafa":"dfdea7", + "cccccc":"cbbe8c", + "964b1c":"5e0b0b", + "f19d5a":"b52424", + "bf7545":"971c1c", + "50131e":"0b241e", + "963e4e":"285234", + "722533":"153626", + "9f9d98":"ad8c63", + "35272e":"36282f", + "584650":"4f3417" + }, + "2": { + "54434c":"170c25", + "080808":"080808", + "fafafa":"4b2e64", + "cccccc":"33214f", + "964b1c":"9d5390", + "f19d5a":"f4dbf6", + "bf7545":"ce7ecc", + "50131e":"52352f", + "963e4e":"ab9b97", + "722533":"83726e", + "9f9d98":"26173b", + "35272e":"a15593", + "584650":"cc7cc9" } -} \ No newline at end of file +} diff --git a/public/images/pokemon/variant/back/773-bug.json b/public/images/pokemon/variant/back/773-bug.json new file mode 100644 index 00000000000..bcd2bdc015f --- /dev/null +++ b/public/images/pokemon/variant/back/773-bug.json @@ -0,0 +1,44 @@ +{ + "1": { + "41ac36": "44b3aa", + "0073bf": "7a4949", + "e64f5e": "f1944a", + "1e9378": "f8ce64", + "9618e0": "dc9c4d", + "aba7bc": "493d55", + "b7e586": "f4ff9c", + "3f3b50": "1e172a", + "73c956": "99d569", + "5399df": "b59489", + "297321": "267763", + "125d4b": "ce7f3f", + "73c957": "73c956", + "251845": "753c32", + "79615e": "504a75", + "565969": "30365c", + "bcbbc5": "788fb5", + "483c39": "3a2d53", + "e3e6ec": "bdd1e5" + }, + "2": { + "41ac36": "92d374", + "0073bf": "6a6c75", + "e64f5e": "98ce58", + "1e9378": "73c956", + "9618e0": "ade265", + "aba7bc": "dbd8e8", + "b7e586": "ababab", + "73c956": "e7eef2", + "5399df": "92949e", + "297321": "3d5542", + "125d4b": "317e27", + "73c957": "73c956", + "251845": "3d5542", + "79615e": "d6d4d4", + "1d1845": "41434e", + "565969": "0f0f1b", + "bcbbc5": "242433", + "483c39": "778894", + "e3e6ec": "444455" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-bug_2.json b/public/images/pokemon/variant/back/773-bug_2.json deleted file mode 100644 index d1259b111de..00000000000 --- a/public/images/pokemon/variant/back/773-bug_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-bug_2.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:f7f9ddb017581440eb23f718cdf48bd9:28b14a74d4787e677a4b6e1cca53c65b:1786a671c3b9676c87853a0a70567554$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-bug_2.png b/public/images/pokemon/variant/back/773-bug_2.png deleted file mode 100644 index c75d821a154..00000000000 Binary files a/public/images/pokemon/variant/back/773-bug_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-bug_3.json b/public/images/pokemon/variant/back/773-bug_3.json deleted file mode 100644 index f0af4a121c2..00000000000 --- a/public/images/pokemon/variant/back/773-bug_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-bug_3.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:f7f9ddb017581440eb23f718cdf48bd9:28b14a74d4787e677a4b6e1cca53c65b:1786a671c3b9676c87853a0a70567554$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-bug_3.png b/public/images/pokemon/variant/back/773-bug_3.png deleted file mode 100644 index c4eb8aa2833..00000000000 Binary files a/public/images/pokemon/variant/back/773-bug_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-dark.json b/public/images/pokemon/variant/back/773-dark.json new file mode 100644 index 00000000000..2e7bb88fb16 --- /dev/null +++ b/public/images/pokemon/variant/back/773-dark.json @@ -0,0 +1,45 @@ +{ + "1": { + "e64f5e": "f1944a", + "bcbbc5": "788fb5", + "9618e0": "dc9c4d", + "565969": "30365c", + "1e9378": "f8ce64", + "0073bf": "7a4949", + "332327": "512351", + "574647": "655454", + "125d4b": "ce7f3f", + "21151a": "250d25", + "79615e": "504a75", + "5399df": "b59489", + "3f3b50": "1e172a", + "251845": "753c32", + "574646": "735c5c", + "aba7bc": "493d55", + "8a7d7a": "dcc0b2", + "e3e6ec": "bdd1e5", + "483c39": "3a2d53", + "1d1845": "2e191f" + }, + "2": { + "e64f5e": "98ce58", + "bcbbc5": "242433", + "9618e0": "ade265", + "565969": "0f0f1b", + "1e9378": "574646", + "0073bf": "6a6c75", + "332327": "f2cc45", + "574647": "574646", + "125d4b": "3b282a", + "21151a": "494057", + "79615e": "d6d4d4", + "5399df": "92949e", + "251845": "425735", + "574646": "f0f7fb", + "aba7bc": "dbd8e8", + "8a7d7a": "9360c8", + "e3e6ec": "444455", + "483c39": "778894", + "1d1845": "41434e" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-dark_2.json b/public/images/pokemon/variant/back/773-dark_2.json deleted file mode 100644 index f946dcc7877..00000000000 --- a/public/images/pokemon/variant/back/773-dark_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-dark_2.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:480a35a9101a568a9ed88e3bfcee7da4:da04c38a9bdeb5a00d2cf2c074f9df0e:267125b3b5f5d18142ae5fffbef27592$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-dark_2.png b/public/images/pokemon/variant/back/773-dark_2.png deleted file mode 100644 index 6bf24788182..00000000000 Binary files a/public/images/pokemon/variant/back/773-dark_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-dark_3.json b/public/images/pokemon/variant/back/773-dark_3.json deleted file mode 100644 index 4dc448fe3da..00000000000 --- a/public/images/pokemon/variant/back/773-dark_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-dark_3.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:480a35a9101a568a9ed88e3bfcee7da4:da04c38a9bdeb5a00d2cf2c074f9df0e:267125b3b5f5d18142ae5fffbef27592$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-dark_3.png b/public/images/pokemon/variant/back/773-dark_3.png deleted file mode 100644 index 5c4918d277b..00000000000 Binary files a/public/images/pokemon/variant/back/773-dark_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-dragon.json b/public/images/pokemon/variant/back/773-dragon.json new file mode 100644 index 00000000000..eccb031b1a4 --- /dev/null +++ b/public/images/pokemon/variant/back/773-dragon.json @@ -0,0 +1,45 @@ +{ + "1": { + "1975a3": "756cc8", + "14487e": "3f4085", + "251845": "753c32", + "6ee0e8": "c1ffd7", + "1d1845": "2e191f", + "3f3b50": "1e172a", + "aba7bc": "493d55", + "e64f5e": "f1944a", + "9618e0": "dc9c4d", + "125d4b": "ce7f3f", + "1e9378": "f8ce64", + "79615e": "504a75", + "5399df": "b59489", + "565969": "30365c", + "bcbbc5": "788fb5", + "1eadd2": "37b5be", + "0073bf": "7a4949", + "e3e6ec": "bdd1e5", + "1eadd1": "2fd0da", + "483c39": "3a2d53" + }, + "2": { + "1975a3": "61c5ff", + "14487e": "3e354e", + "251845": "425735", + "6ee0e8": "ffffff", + "1d1845": "41434e", + "aba7bc": "dbd8e8", + "e64f5e": "98ce58", + "9618e0": "ade265", + "125d4b": "0f5493", + "1e9378": "1eadd1", + "79615e": "d6d4d4", + "5399df": "92949e", + "565969": "0f0f1b", + "bcbbc5": "242433", + "1eadd2": "1eadd1", + "0073bf": "6a6c75", + "e3e6ec": "444455", + "1eadd1": "ffa1ec", + "483c39": "778894" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-dragon_2.json b/public/images/pokemon/variant/back/773-dragon_2.json deleted file mode 100644 index 5e4734096be..00000000000 --- a/public/images/pokemon/variant/back/773-dragon_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-dragon_2.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:6cfc6e922b9668b26bc32845b0989af1:78fd49f8ede01a8e4d67f82656dbdcd6:59453f2ad0e681735b3b15ab728caa7c$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-dragon_2.png b/public/images/pokemon/variant/back/773-dragon_2.png deleted file mode 100644 index b95aad50cc7..00000000000 Binary files a/public/images/pokemon/variant/back/773-dragon_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-dragon_3.json b/public/images/pokemon/variant/back/773-dragon_3.json deleted file mode 100644 index 88cefccc59a..00000000000 --- a/public/images/pokemon/variant/back/773-dragon_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-dragon_3.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:6cfc6e922b9668b26bc32845b0989af1:78fd49f8ede01a8e4d67f82656dbdcd6:59453f2ad0e681735b3b15ab728caa7c$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-dragon_3.png b/public/images/pokemon/variant/back/773-dragon_3.png deleted file mode 100644 index 3e7a5ff249a..00000000000 Binary files a/public/images/pokemon/variant/back/773-dragon_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-electric.json b/public/images/pokemon/variant/back/773-electric.json new file mode 100644 index 00000000000..ed972b10127 --- /dev/null +++ b/public/images/pokemon/variant/back/773-electric.json @@ -0,0 +1,45 @@ +{ + "1": { + "aba7bc": "493d55", + "e64f5e": "f1944a", + "1d1845": "2e191f", + "f8ffc5": "fdfee0", + "5399df": "b59489", + "e3e6ec": "bdd1e5", + "1e9378": "f8ce64", + "f5eb18": "faf256", + "0073bf": "7a4949", + "483c39": "3a2d53", + "8e6113": "a55a50", + "125d4b": "ce7f3f", + "3f3b50": "1e172a", + "ca972c": "ff935c", + "565969": "30365c", + "9618e0": "dc9c4d", + "251845": "753c32", + "bcbbc5": "788fb5", + "79615e": "504a75", + "f5eb19": "fff97e" + }, + "2": { + "aba7bc": "dbd8e8", + "e64f5e": "98ce58", + "1d1845": "41434e", + "f8ffc5": "ffd900", + "5399df": "92949e", + "e3e6ec": "444455", + "1e9378": "f5eb18", + "f5eb18": "864593", + "0073bf": "6a6c75", + "483c39": "778894", + "8e6113": "422a45", + "125d4b": "b3620e", + "ca972c": "ffd900", + "565969": "0f0f1b", + "9618e0": "ade265", + "251845": "425735", + "bcbbc5": "242433", + "79615e": "d6d4d4", + "f5eb19": "f5eb18" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-electric_2.json b/public/images/pokemon/variant/back/773-electric_2.json deleted file mode 100644 index e15d66ee895..00000000000 --- a/public/images/pokemon/variant/back/773-electric_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-electric_2.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:c439955af04bedc326c7d3be6c26988a:5ff7fe75002e55911c7611487d217375:e9f7f627b4aa057d8a352e938221d903$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-electric_2.png b/public/images/pokemon/variant/back/773-electric_2.png deleted file mode 100644 index 68d076df7b0..00000000000 Binary files a/public/images/pokemon/variant/back/773-electric_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-electric_3.json b/public/images/pokemon/variant/back/773-electric_3.json deleted file mode 100644 index 3f72ec91021..00000000000 --- a/public/images/pokemon/variant/back/773-electric_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-electric_3.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:c439955af04bedc326c7d3be6c26988a:5ff7fe75002e55911c7611487d217375:e9f7f627b4aa057d8a352e938221d903$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-electric_3.png b/public/images/pokemon/variant/back/773-electric_3.png deleted file mode 100644 index fb096f261a2..00000000000 Binary files a/public/images/pokemon/variant/back/773-electric_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-fairy.json b/public/images/pokemon/variant/back/773-fairy.json new file mode 100644 index 00000000000..27f96ca115c --- /dev/null +++ b/public/images/pokemon/variant/back/773-fairy.json @@ -0,0 +1,45 @@ +{ + "1": { + "a15296": "833671", + "ffe8ef": "fce9c7", + "e3e6ec": "bdd1e5", + "125d4b": "ce7f3f", + "1e9378": "f8ce64", + "9618e0": "dc9c4d", + "251845": "753c32", + "79615e": "504a75", + "bcbbc5": "788fb5", + "5399df": "b59489", + "1d1845": "2e191f", + "565969": "30365c", + "f9bfe0": "ecaecb", + "e64f5e": "f1944a", + "483c39": "3a2d53", + "aba7bc": "493d55", + "f9bfe1": "e5a5c9", + "3f3b50": "1e172a", + "e183c7": "d3559a", + "0073bf": "7a4949" + }, + "2": { + "a15296": "3f3b50", + "ffe8ef": "acb4bd", + "e3e6ec": "444455", + "125d4b": "ad628c", + "1e9378": "f9bfe0", + "9618e0": "ade265", + "251845": "425735", + "79615e": "d6d4d4", + "bcbbc5": "242433", + "5399df": "92949e", + "1d1845": "41434e", + "565969": "0f0f1b", + "f9bfe0": "f0f7fb", + "e64f5e": "98ce58", + "483c39": "778894", + "aba7bc": "dbd8e8", + "f9bfe1": "f9bfe0", + "e183c7": "fca4ea", + "0073bf": "6a6c75" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-fairy_2.json b/public/images/pokemon/variant/back/773-fairy_2.json deleted file mode 100644 index 98b375c5f45..00000000000 --- a/public/images/pokemon/variant/back/773-fairy_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-fairy_2.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:d6f47b3bab34009ef5dc5f4ea6b381bb:d04fa9480f8f14f1de8fa1b72067b54e:50e5ca45ea677d44a2fea72d4ec14fc2$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-fairy_2.png b/public/images/pokemon/variant/back/773-fairy_2.png deleted file mode 100644 index fe209811598..00000000000 Binary files a/public/images/pokemon/variant/back/773-fairy_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-fairy_3.json b/public/images/pokemon/variant/back/773-fairy_3.json deleted file mode 100644 index 5f1f542f447..00000000000 --- a/public/images/pokemon/variant/back/773-fairy_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-fairy_3.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:d6f47b3bab34009ef5dc5f4ea6b381bb:d04fa9480f8f14f1de8fa1b72067b54e:50e5ca45ea677d44a2fea72d4ec14fc2$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-fairy_3.png b/public/images/pokemon/variant/back/773-fairy_3.png deleted file mode 100644 index e4dd02063be..00000000000 Binary files a/public/images/pokemon/variant/back/773-fairy_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-fighting.json b/public/images/pokemon/variant/back/773-fighting.json new file mode 100644 index 00000000000..c29d7e645b5 --- /dev/null +++ b/public/images/pokemon/variant/back/773-fighting.json @@ -0,0 +1,45 @@ +{ + "1": { + "f8b076": "ffcd8a", + "125d4b": "ce7f3f", + "1e9378": "f8ce64", + "f18a37": "e37637", + "251845": "753c32", + "f18a36": "f1964c", + "1d1845": "2e191f", + "483c39": "3a2d53", + "5399df": "b59489", + "d55223": "da4b2f", + "e3e6ec": "bdd1e5", + "aba7bc": "493d55", + "79615e": "504a75", + "0073bf": "7a4949", + "a34828": "a33b26", + "e64f5e": "f1944a", + "9618e0": "dc9c4d", + "bcbbc5": "788fb5", + "565969": "30365c", + "3f3b50": "1e172a" + }, + "2": { + "f8b076": "65abdb", + "125d4b": "b8411d", + "1e9378": "f18a36", + "f18a37": "f18a36", + "251845": "425735", + "f18a36": "e7eef2", + "1d1845": "41434e", + "483c39": "778894", + "5399df": "92949e", + "d55223": "eccd00", + "e3e6ec": "444455", + "aba7bc": "dbd8e8", + "79615e": "d6d4d4", + "0073bf": "6a6c75", + "a34828": "2f4453", + "e64f5e": "98ce58", + "9618e0": "ade265", + "bcbbc5": "242433", + "565969": "0f0f1b" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-fighting_2.json b/public/images/pokemon/variant/back/773-fighting_2.json deleted file mode 100644 index fb36788f6c8..00000000000 --- a/public/images/pokemon/variant/back/773-fighting_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-fighting_2.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:6d1e675b193a41d267b024051c64bdaa:38a0b08046054adb42784f0dc0660893:70f70b07c9d5b3013cbd3b3f25c7f7fa$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-fighting_2.png b/public/images/pokemon/variant/back/773-fighting_2.png deleted file mode 100644 index 909e1364cd1..00000000000 Binary files a/public/images/pokemon/variant/back/773-fighting_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-fighting_3.json b/public/images/pokemon/variant/back/773-fighting_3.json deleted file mode 100644 index 6ad0f058f77..00000000000 --- a/public/images/pokemon/variant/back/773-fighting_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-fighting_3.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:6d1e675b193a41d267b024051c64bdaa:38a0b08046054adb42784f0dc0660893:70f70b07c9d5b3013cbd3b3f25c7f7fa$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-fighting_3.png b/public/images/pokemon/variant/back/773-fighting_3.png deleted file mode 100644 index b6218cfa969..00000000000 Binary files a/public/images/pokemon/variant/back/773-fighting_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-fire.json b/public/images/pokemon/variant/back/773-fire.json new file mode 100644 index 00000000000..302ec952415 --- /dev/null +++ b/public/images/pokemon/variant/back/773-fire.json @@ -0,0 +1,45 @@ +{ + "1": { + "bcbbc5": "788fb5", + "483c39": "3a2d53", + "e64f5e": "f1944a", + "e3e6ec": "bdd1e5", + "aba7bc": "493d55", + "fa7351": "fc9e5d", + "1d1845": "2e191f", + "f32142": "ba2e2c", + "125d4b": "ce7f3f", + "0073bf": "7a4949", + "565969": "30365c", + "1e9378": "f8ce64", + "81132d": "6e1441", + "3f3b50": "1e172a", + "9618e0": "dc9c4d", + "251845": "753c32", + "f32141": "ee3652", + "79615e": "504a75", + "5399df": "b59489", + "b50d36": "ae1361" + }, + "2": { + "bcbbc5": "242433", + "483c39": "778894", + "e64f5e": "98ce58", + "e3e6ec": "444455", + "aba7bc": "dbd8e8", + "fa7351": "d063a2", + "1d1845": "41434e", + "f32142": "d92b00", + "125d4b": "7a151a", + "0073bf": "6a6c75", + "565969": "0f0f1b", + "1e9378": "d92b00", + "81132d": "7e3354", + "9618e0": "ade265", + "251845": "425735", + "f32141": "e7eef2", + "79615e": "d6d4d4", + "5399df": "92949e", + "b50d36": "fa9955" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-fire_2.json b/public/images/pokemon/variant/back/773-fire_2.json deleted file mode 100644 index 4b35b1549a4..00000000000 --- a/public/images/pokemon/variant/back/773-fire_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-fire_2.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:6e80b11b982f722e388545ccee4f8968:646af571a7a39f56e61262c2a0624953:690c285b19cb1e8f7b7aa9dfafbe36b2$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-fire_2.png b/public/images/pokemon/variant/back/773-fire_2.png deleted file mode 100644 index b97fa38321b..00000000000 Binary files a/public/images/pokemon/variant/back/773-fire_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-fire_3.json b/public/images/pokemon/variant/back/773-fire_3.json deleted file mode 100644 index ee8c62ade3f..00000000000 --- a/public/images/pokemon/variant/back/773-fire_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-fire_3.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:6e80b11b982f722e388545ccee4f8968:646af571a7a39f56e61262c2a0624953:690c285b19cb1e8f7b7aa9dfafbe36b2$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-fire_3.png b/public/images/pokemon/variant/back/773-fire_3.png deleted file mode 100644 index f30a14d9d09..00000000000 Binary files a/public/images/pokemon/variant/back/773-fire_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-flying.json b/public/images/pokemon/variant/back/773-flying.json new file mode 100644 index 00000000000..7787b1e8208 --- /dev/null +++ b/public/images/pokemon/variant/back/773-flying.json @@ -0,0 +1,45 @@ +{ + "1": { + "5082c1": "8bc4e1", + "125d4b": "ce7f3f", + "081b4a": "17195a", + "9618e0": "dc9c4d", + "bcbbc5": "788fb5", + "565969": "30365c", + "79615e": "504a75", + "0073bf": "7a4949", + "e3e6ec": "bdd1e5", + "072c85": "402795", + "251845": "753c32", + "e64f5e": "f1944a", + "5399df": "b59489", + "0557bc": "296cbe", + "483c39": "3a2d53", + "1d1845": "2e191f", + "1e9378": "f8ce64", + "aba7bc": "493d55", + "0557bd": "1e509e", + "3f3b50": "1e172a" + }, + "2": { + "5082c1": "acb4bd", + "125d4b": "0a298c", + "081b4a": "2f4453", + "9618e0": "ade265", + "bcbbc5": "242433", + "565969": "0f0f1b", + "79615e": "d6d4d4", + "0073bf": "6a6c75", + "e3e6ec": "444455", + "072c85": "97c7fe", + "251845": "425735", + "e64f5e": "98ce58", + "5399df": "92949e", + "0557bc": "e7eef2", + "483c39": "778894", + "1d1845": "41434e", + "1e9378": "0557bc", + "aba7bc": "dbd8e8", + "0557bd": "0557bc" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-flying_2.json b/public/images/pokemon/variant/back/773-flying_2.json deleted file mode 100644 index 4defa0bcd9b..00000000000 --- a/public/images/pokemon/variant/back/773-flying_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-flying_2.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:6df6a83b02e02bdf559b519ab64315f1:eb39e07af66501d77f50784797319c52:fd9cc965ca8a0f017385425d924045d6$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-flying_2.png b/public/images/pokemon/variant/back/773-flying_2.png deleted file mode 100644 index 7767c172826..00000000000 Binary files a/public/images/pokemon/variant/back/773-flying_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-flying_3.json b/public/images/pokemon/variant/back/773-flying_3.json deleted file mode 100644 index 859009c1bbd..00000000000 --- a/public/images/pokemon/variant/back/773-flying_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-flying_3.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:6df6a83b02e02bdf559b519ab64315f1:eb39e07af66501d77f50784797319c52:fd9cc965ca8a0f017385425d924045d6$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-flying_3.png b/public/images/pokemon/variant/back/773-flying_3.png deleted file mode 100644 index dfa5b8bb81c..00000000000 Binary files a/public/images/pokemon/variant/back/773-flying_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-ghost.json b/public/images/pokemon/variant/back/773-ghost.json new file mode 100644 index 00000000000..26826f8857b --- /dev/null +++ b/public/images/pokemon/variant/back/773-ghost.json @@ -0,0 +1,45 @@ +{ + "1": { + "483c39": "3a2d53", + "d68ce5": "ecc9f3", + "125d4b": "ce7f3f", + "5399df": "b59489", + "e3e6ec": "bdd1e5", + "1d1845": "2e191f", + "1e9378": "f8ce64", + "9618e0": "dc9c4d", + "a75bbf": "b36bca", + "79615e": "504a75", + "251845": "753c32", + "a75bc0": "7b5498", + "565969": "30365c", + "3f3b50": "1e172a", + "503775": "392e4c", + "0073bf": "7a4949", + "e64f5e": "f1944a", + "753d9a": "504681", + "aba7bc": "493d55", + "bcbbc5": "788fb5" + }, + "2": { + "483c39": "778894", + "d68ce5": "5876bd", + "125d4b": "653785", + "5399df": "92949e", + "e3e6ec": "444455", + "1d1845": "41434e", + "1e9378": "a75bbf", + "9618e0": "ade265", + "a75bbf": "c8b5e2", + "79615e": "d6d4d4", + "251845": "425735", + "a75bc0": "a75bbf", + "565969": "0f0f1b", + "503775": "383c6a", + "0073bf": "6a6c75", + "e64f5e": "98ce58", + "753d9a": "cd6fa4", + "aba7bc": "dbd8e8", + "bcbbc5": "242433" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-ghost_2.json b/public/images/pokemon/variant/back/773-ghost_2.json deleted file mode 100644 index 6f1b9f5dae5..00000000000 --- a/public/images/pokemon/variant/back/773-ghost_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-ghost_2.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:ae82863a2f5d819a20ff6bde3925330b:e48ac8252ba2c97208f37a50158dcf1b:dff8d338685b93339ecf30f1d807fbe6$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-ghost_2.png b/public/images/pokemon/variant/back/773-ghost_2.png deleted file mode 100644 index d75d265ff87..00000000000 Binary files a/public/images/pokemon/variant/back/773-ghost_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-ghost_3.json b/public/images/pokemon/variant/back/773-ghost_3.json deleted file mode 100644 index 3e04e334b43..00000000000 --- a/public/images/pokemon/variant/back/773-ghost_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-ghost_3.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:ae82863a2f5d819a20ff6bde3925330b:e48ac8252ba2c97208f37a50158dcf1b:dff8d338685b93339ecf30f1d807fbe6$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-ghost_3.png b/public/images/pokemon/variant/back/773-ghost_3.png deleted file mode 100644 index 991b2b2a18e..00000000000 Binary files a/public/images/pokemon/variant/back/773-ghost_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-grass.json b/public/images/pokemon/variant/back/773-grass.json new file mode 100644 index 00000000000..4099a183dc0 --- /dev/null +++ b/public/images/pokemon/variant/back/773-grass.json @@ -0,0 +1,45 @@ +{ + "1": { + "03753c": "086c6b", + "483c39": "3a2d53", + "01a326": "1b9143", + "e64f5e": "f1944a", + "0073bf": "7a4949", + "251845": "753c32", + "79615e": "504a75", + "064a28": "043541", + "125d4b": "ce7f3f", + "3f3b50": "1e172a", + "bcbbc5": "788fb5", + "01a325": "18b12f", + "1e9378": "f8ce64", + "9618e0": "dc9c4d", + "5399df": "b59489", + "565969": "30365c", + "e3e6ec": "bdd1e5", + "50d354": "8bf360", + "aba7bc": "493d55", + "1d1845": "2e191f" + }, + "2": { + "03753c": "c77fe2", + "483c39": "778894", + "01a326": "01a325", + "e64f5e": "98ce58", + "0073bf": "6a6c75", + "251845": "425735", + "79615e": "d6d4d4", + "064a28": "283331", + "125d4b": "0c592f", + "bcbbc5": "242433", + "01a325": "e7eef2", + "1e9378": "01a325", + "9618e0": "ade265", + "5399df": "92949e", + "565969": "0f0f1b", + "e3e6ec": "444455", + "50d354": "2b6e2d", + "aba7bc": "dbd8e8", + "1d1845": "41434e" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-grass_2.json b/public/images/pokemon/variant/back/773-grass_2.json deleted file mode 100644 index f18dccf3f25..00000000000 --- a/public/images/pokemon/variant/back/773-grass_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-grass_2.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:ade83101b436abb70288e4cd94ff5592:63cdb8f6e74efc570f81dea1385e7606:c892d42603d88b410862efcb4f750000$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-grass_2.png b/public/images/pokemon/variant/back/773-grass_2.png deleted file mode 100644 index c1cd23a53ba..00000000000 Binary files a/public/images/pokemon/variant/back/773-grass_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-grass_3.json b/public/images/pokemon/variant/back/773-grass_3.json deleted file mode 100644 index 773e3688662..00000000000 --- a/public/images/pokemon/variant/back/773-grass_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-grass_3.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:ade83101b436abb70288e4cd94ff5592:63cdb8f6e74efc570f81dea1385e7606:c892d42603d88b410862efcb4f750000$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-grass_3.png b/public/images/pokemon/variant/back/773-grass_3.png deleted file mode 100644 index ce5e6ced229..00000000000 Binary files a/public/images/pokemon/variant/back/773-grass_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-ground.json b/public/images/pokemon/variant/back/773-ground.json new file mode 100644 index 00000000000..d57e1508946 --- /dev/null +++ b/public/images/pokemon/variant/back/773-ground.json @@ -0,0 +1,45 @@ +{ + "1": { + "1e9378": "f8ce64", + "bcbbc5": "788fb5", + "cf5c07": "d36b1f", + "5399df": "b59489", + "cf5c08": "b55711", + "9618e0": "dc9c4d", + "1d1845": "2e191f", + "3f3b50": "1e172a", + "565969": "30365c", + "e3e6ec": "bdd1e5", + "a3410c": "95174b", + "e59b4a": "f3daa4", + "125d4b": "ce7f3f", + "251845": "753c32", + "483c39": "3a2d53", + "79615e": "504a75", + "e64f5e": "f1944a", + "613016": "61191e", + "0073bf": "7a4949", + "aba7bc": "493d55" + }, + "2": { + "1e9378": "cf5c07", + "bcbbc5": "242433", + "cf5c07": "ffd963", + "5399df": "92949e", + "cf5c08": "cf5c07", + "9618e0": "ade265", + "1d1845": "41434e", + "565969": "0f0f1b", + "e3e6ec": "444455", + "a3410c": "e1497e", + "e59b4a": "44b3e3", + "125d4b": "a32004", + "251845": "425735", + "483c39": "778894", + "79615e": "d6d4d4", + "e64f5e": "98ce58", + "613016": "653653", + "0073bf": "6a6c75", + "aba7bc": "dbd8e8" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-ground_2.json b/public/images/pokemon/variant/back/773-ground_2.json deleted file mode 100644 index 0f4cbe72836..00000000000 --- a/public/images/pokemon/variant/back/773-ground_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-ground_2.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:66e22c74c60049c804b1dd1a21e832ad:56b76fceb24ac15c97e2e1c036070bcb:a8b1ae37d6ef4c526891c3cd392866cd$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-ground_2.png b/public/images/pokemon/variant/back/773-ground_2.png deleted file mode 100644 index bc2d1bde847..00000000000 Binary files a/public/images/pokemon/variant/back/773-ground_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-ground_3.json b/public/images/pokemon/variant/back/773-ground_3.json deleted file mode 100644 index fb8c3e88cd8..00000000000 --- a/public/images/pokemon/variant/back/773-ground_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-ground_3.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:66e22c74c60049c804b1dd1a21e832ad:56b76fceb24ac15c97e2e1c036070bcb:a8b1ae37d6ef4c526891c3cd392866cd$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-ground_3.png b/public/images/pokemon/variant/back/773-ground_3.png deleted file mode 100644 index 41512f481cf..00000000000 Binary files a/public/images/pokemon/variant/back/773-ground_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-ice.json b/public/images/pokemon/variant/back/773-ice.json new file mode 100644 index 00000000000..11a2edc1457 --- /dev/null +++ b/public/images/pokemon/variant/back/773-ice.json @@ -0,0 +1,45 @@ +{ + "1": { + "5399df": "b59489", + "1e9378": "f8ce64", + "0073bf": "7a4949", + "79615e": "504a75", + "bcbbc5": "788fb5", + "ecfffc": "eafffb", + "e3e6ec": "bdd1e5", + "1d1845": "2e191f", + "125d4b": "ce7f3f", + "9618e0": "dc9c4d", + "aef9fa": "aef9f9", + "e64f5e": "f1944a", + "251845": "753c32", + "565969": "30365c", + "7bb3cc": "a197f3", + "aba7bc": "493d55", + "aef9f9": "b8f8f8", + "3f3b50": "1e172a", + "416b7e": "575693", + "483c39": "3a2d53" + }, + "2": { + "5399df": "92949e", + "1e9378": "aef9f9", + "0073bf": "6a6c75", + "79615e": "d6d4d4", + "bcbbc5": "242433", + "ecfffc": "7cadde", + "e3e6ec": "444455", + "1d1845": "41434e", + "125d4b": "5c94a6", + "9618e0": "ade265", + "aef9fa": "aef9f9", + "e64f5e": "98ce58", + "251845": "425735", + "565969": "0f0f1b", + "7bb3cc": "38cfb0", + "aba7bc": "dbd8e8", + "aef9f9": "e7eef2", + "416b7e": "414f65", + "483c39": "778894" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-ice_2.json b/public/images/pokemon/variant/back/773-ice_2.json deleted file mode 100644 index bfa08d90ff2..00000000000 --- a/public/images/pokemon/variant/back/773-ice_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-ice_2.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:bef2035e1fedd0b00de78ff0478bf168:b5c0b82104adca9c2fa8621d61e276ae:bbb81164af15638f1aae91f14ca0ac1d$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-ice_2.png b/public/images/pokemon/variant/back/773-ice_2.png deleted file mode 100644 index 272338a61c9..00000000000 Binary files a/public/images/pokemon/variant/back/773-ice_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-ice_3.json b/public/images/pokemon/variant/back/773-ice_3.json deleted file mode 100644 index da095257172..00000000000 --- a/public/images/pokemon/variant/back/773-ice_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-ice_3.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:bef2035e1fedd0b00de78ff0478bf168:b5c0b82104adca9c2fa8621d61e276ae:bbb81164af15638f1aae91f14ca0ac1d$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-ice_3.png b/public/images/pokemon/variant/back/773-ice_3.png deleted file mode 100644 index e523cba4a1b..00000000000 Binary files a/public/images/pokemon/variant/back/773-ice_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-poison.json b/public/images/pokemon/variant/back/773-poison.json new file mode 100644 index 00000000000..e42a2e9aece --- /dev/null +++ b/public/images/pokemon/variant/back/773-poison.json @@ -0,0 +1,45 @@ +{ + "1": { + "1d1845": "2e191f", + "9c71ce": "d089ee", + "4e229c": "4641b5", + "0073bf": "7a4949", + "79615e": "504a75", + "1e9378": "f8ce64", + "251845": "753c32", + "7234bd": "7b4bb5", + "9618e0": "dc9c4d", + "5399df": "b59489", + "565969": "30365c", + "483c39": "3a2d53", + "30175c": "2f1b77", + "e3e6ec": "bdd1e5", + "bcbbc5": "788fb5", + "e64f5e": "f1944a", + "3f3b50": "1e172a", + "125d4b": "ce7f3f", + "aba7bc": "493d55", + "7234bc": "874dcc" + }, + "2": { + "1d1845": "41434e", + "9c71ce": "2752b5", + "4e229c": "e3508d", + "0073bf": "6a6c75", + "79615e": "d6d4d4", + "1e9378": "7234bc", + "251845": "425735", + "7234bd": "7234bc", + "9618e0": "ade265", + "5399df": "92949e", + "565969": "0f0f1b", + "483c39": "778894", + "30175c": "34284a", + "e3e6ec": "444455", + "bcbbc5": "242433", + "e64f5e": "98ce58", + "125d4b": "4b1f7e", + "aba7bc": "dbd8e8", + "7234bc": "8e4da8" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-poison_2.json b/public/images/pokemon/variant/back/773-poison_2.json deleted file mode 100644 index e5032708fa1..00000000000 --- a/public/images/pokemon/variant/back/773-poison_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-poison_2.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:623460b2a2e54347e8bbc45cea13a8d1:c297e8e8e5d250a948a1d3471cec8e0e:2e43d6e4a409b7aabc1efd3ec3981f96$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-poison_2.png b/public/images/pokemon/variant/back/773-poison_2.png deleted file mode 100644 index d980ced2c30..00000000000 Binary files a/public/images/pokemon/variant/back/773-poison_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-poison_3.json b/public/images/pokemon/variant/back/773-poison_3.json deleted file mode 100644 index 4a319d7738e..00000000000 --- a/public/images/pokemon/variant/back/773-poison_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-poison_3.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:623460b2a2e54347e8bbc45cea13a8d1:c297e8e8e5d250a948a1d3471cec8e0e:2e43d6e4a409b7aabc1efd3ec3981f96$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-poison_3.png b/public/images/pokemon/variant/back/773-poison_3.png deleted file mode 100644 index 30c1d866ea0..00000000000 Binary files a/public/images/pokemon/variant/back/773-poison_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-psychic.json b/public/images/pokemon/variant/back/773-psychic.json new file mode 100644 index 00000000000..d20475ab1ae --- /dev/null +++ b/public/images/pokemon/variant/back/773-psychic.json @@ -0,0 +1,45 @@ +{ + "1": { + "ea6aa4": "ec81b2", + "1d1845": "2e191f", + "9618e0": "dc9c4d", + "565969": "30365c", + "e64f5e": "f1944a", + "bcbbc5": "788fb5", + "0073bf": "7a4949", + "7a2656": "812c6e", + "aba7bc": "493d55", + "ea6aa5": "c14e82", + "5399df": "b59489", + "e3e6ec": "bdd1e5", + "79615e": "504a75", + "125d4b": "ce7f3f", + "3f3b50": "1e172a", + "f3a1b8": "ffccc3", + "1e9378": "f8ce64", + "c1448c": "b3388f", + "251845": "753c32", + "483c39": "3a2d53" + }, + "2": { + "ea6aa4": "e7eef2", + "1d1845": "41434e", + "9618e0": "ade265", + "565969": "0f0f1b", + "e64f5e": "98ce58", + "bcbbc5": "242433", + "0073bf": "6a6c75", + "7a2656": "6a3851", + "aba7bc": "dbd8e8", + "ea6aa5": "ea6aa4", + "5399df": "92949e", + "e3e6ec": "444455", + "79615e": "d6d4d4", + "125d4b": "9f3351", + "f3a1b8": "ed77a7", + "1e9378": "ea6aa4", + "c1448c": "91d4b0", + "251845": "425735", + "483c39": "778894" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-psychic_2.json b/public/images/pokemon/variant/back/773-psychic_2.json deleted file mode 100644 index bbea6924cd8..00000000000 --- a/public/images/pokemon/variant/back/773-psychic_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-psychic_2.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:076140ebda30b6ad19473e55cc5498c2:15077ada33ea6ff7f34c502e66f38cb9:9fb489b40d17b047a9dacb47533ceda4$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-psychic_2.png b/public/images/pokemon/variant/back/773-psychic_2.png deleted file mode 100644 index 1cc713d702e..00000000000 Binary files a/public/images/pokemon/variant/back/773-psychic_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-psychic_3.json b/public/images/pokemon/variant/back/773-psychic_3.json deleted file mode 100644 index 37619cdbe18..00000000000 --- a/public/images/pokemon/variant/back/773-psychic_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-psychic_3.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:076140ebda30b6ad19473e55cc5498c2:15077ada33ea6ff7f34c502e66f38cb9:9fb489b40d17b047a9dacb47533ceda4$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-psychic_3.png b/public/images/pokemon/variant/back/773-psychic_3.png deleted file mode 100644 index 37c87fa3e24..00000000000 Binary files a/public/images/pokemon/variant/back/773-psychic_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-rock.json b/public/images/pokemon/variant/back/773-rock.json new file mode 100644 index 00000000000..89e714adc9e --- /dev/null +++ b/public/images/pokemon/variant/back/773-rock.json @@ -0,0 +1,45 @@ +{ + "1": { + "f3ebdc": "fff5d8", + "5399df": "b59489", + "251845": "753c32", + "125d4b": "ce7f3f", + "0073bf": "7a4949", + "a38479": "c18cb8", + "3f3b50": "1e172a", + "bcbbc5": "788fb5", + "aba7bc": "493d55", + "d6c4b1": "e5d2bd", + "e3e6ec": "bdd1e5", + "1e9378": "f8ce64", + "565969": "30365c", + "7a5c52": "775d73", + "1d1845": "2e191f", + "e64f5e": "f1944a", + "79615e": "504a75", + "483c39": "3a2d53", + "9618e0": "dc9c4d", + "d6c4b2": "c8b19a" + }, + "2": { + "f3ebdc": "acb4bd", + "5399df": "92949e", + "251845": "425735", + "125d4b": "816f5b", + "0073bf": "6a6c75", + "a38479": "f9de6c", + "bcbbc5": "242433", + "aba7bc": "dbd8e8", + "d6c4b1": "e7eef2", + "e3e6ec": "444455", + "1e9378": "d6c4b1", + "565969": "0f0f1b", + "7a5c52": "50433d", + "1d1845": "41434e", + "e64f5e": "98ce58", + "79615e": "d6d4d4", + "483c39": "778894", + "9618e0": "ade265", + "d6c4b2": "d6c4b1" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-rock_2.json b/public/images/pokemon/variant/back/773-rock_2.json deleted file mode 100644 index 3c82a376544..00000000000 --- a/public/images/pokemon/variant/back/773-rock_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-rock_2.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:40aafe2781f7ccb60801c3dc205c2462:78709b437e1fffc8f971a34f3f5303db:b6fcb5d1ff917a13e5e912a7f40fcbe2$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-rock_2.png b/public/images/pokemon/variant/back/773-rock_2.png deleted file mode 100644 index a2430527c74..00000000000 Binary files a/public/images/pokemon/variant/back/773-rock_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-rock_3.json b/public/images/pokemon/variant/back/773-rock_3.json deleted file mode 100644 index e0376bf5569..00000000000 --- a/public/images/pokemon/variant/back/773-rock_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-rock_3.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:40aafe2781f7ccb60801c3dc205c2462:78709b437e1fffc8f971a34f3f5303db:b6fcb5d1ff917a13e5e912a7f40fcbe2$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-rock_3.png b/public/images/pokemon/variant/back/773-rock_3.png deleted file mode 100644 index 8f347b580bf..00000000000 Binary files a/public/images/pokemon/variant/back/773-rock_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-steel.json b/public/images/pokemon/variant/back/773-steel.json new file mode 100644 index 00000000000..91e5335bcc5 --- /dev/null +++ b/public/images/pokemon/variant/back/773-steel.json @@ -0,0 +1,45 @@ +{ + "1": { + "1d1845": "2e191f", + "e5e0de": "f1efe5", + "565969": "30365c", + "9d98aa": "8f89aa", + "e64f5e": "f1944a", + "3f3b50": "1e172a", + "79615e": "504a75", + "125d4b": "ce7f3f", + "9618e0": "dc9c4d", + "aba7bc": "493d55", + "bcbbc5": "788fb5", + "1e9378": "f8ce64", + "251845": "753c32", + "5399df": "b59489", + "e3e6ec": "bdd1e5", + "0073bf": "7a4949", + "cfc7c7": "dcd1d1", + "483c39": "3a2d53", + "cfc7c8": "b8aeab", + "595467": "565071" + }, + "2": { + "1d1845": "41434e", + "e5e0de": "a5a5a5", + "565969": "0f0f1b", + "9d98aa": "98099c", + "e64f5e": "98ce58", + "79615e": "d6d4d4", + "125d4b": "705a5f", + "9618e0": "ade265", + "aba7bc": "dbd8e8", + "bcbbc5": "242433", + "1e9378": "cfc7c7", + "251845": "425735", + "5399df": "92949e", + "e3e6ec": "444455", + "0073bf": "6a6c75", + "cfc7c7": "e7eef2", + "483c39": "778894", + "cfc7c8": "cfc7c7", + "595467": "3b253e" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-steel_2.json b/public/images/pokemon/variant/back/773-steel_2.json deleted file mode 100644 index 19e2baf2f0b..00000000000 --- a/public/images/pokemon/variant/back/773-steel_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-steel_2.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:337b01484fad266b75efd72e86bebee2:0527d8e3f21b9fc9f840090ea062b642:28dcfb1ac7091bec326d67f7b8d4eaa6$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-steel_2.png b/public/images/pokemon/variant/back/773-steel_2.png deleted file mode 100644 index 12244f7dbe4..00000000000 Binary files a/public/images/pokemon/variant/back/773-steel_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-steel_3.json b/public/images/pokemon/variant/back/773-steel_3.json deleted file mode 100644 index 54a7553bcb5..00000000000 --- a/public/images/pokemon/variant/back/773-steel_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-steel_3.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:337b01484fad266b75efd72e86bebee2:0527d8e3f21b9fc9f840090ea062b642:28dcfb1ac7091bec326d67f7b8d4eaa6$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-steel_3.png b/public/images/pokemon/variant/back/773-steel_3.png deleted file mode 100644 index da0ce3d7c43..00000000000 Binary files a/public/images/pokemon/variant/back/773-steel_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-water.json b/public/images/pokemon/variant/back/773-water.json new file mode 100644 index 00000000000..d7316c66d04 --- /dev/null +++ b/public/images/pokemon/variant/back/773-water.json @@ -0,0 +1,44 @@ +{ + "1": { + "175477": "34508a", + "5399df": "b59489", + "aba7bc": "493d55", + "92f1f3": "93f8e9", + "3f3b50": "1e172a", + "0073bf": "7a4949", + "483c39": "3a2d53", + "3ed3ef": "59d6ec", + "2786bc": "4661cc", + "3ed3ee": "4fd4ec", + "9618e0": "dc9c4d", + "251845": "753c32", + "e3e6ec": "bdd1e5", + "1e9378": "f8ce64", + "79615e": "504a75", + "125d4b": "ce7f3f", + "bcbbc5": "788fb5", + "565969": "30365c", + "e64f5e": "f1944a" + }, + "2": { + "175477": "3a182f", + "5399df": "92949e", + "aba7bc": "dbd8e8", + "92f1f3": "b82db2", + "0073bf": "6a6c75", + "483c39": "778894", + "3ed3ef": "2866ba", + "2786bc": "fe75a3", + "1d1845": "444455", + "3ed3ee": "e7eef2", + "9618e0": "ade265", + "251845": "425735", + "e3e6ec": "444455", + "1e9378": "2866ba", + "79615e": "d6d4d4", + "125d4b": "162c81", + "bcbbc5": "242433", + "565969": "0f0f1b", + "e64f5e": "98ce58" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-water_2.json b/public/images/pokemon/variant/back/773-water_2.json deleted file mode 100644 index 9df99a16888..00000000000 --- a/public/images/pokemon/variant/back/773-water_2.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-water_2.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:f94551f1224191b67e0ae587e065ec6b:d24addb57cd174d5ef9826fb0720f71f:609e3c1a2aa54ec6d5110acf831a822b$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-water_2.png b/public/images/pokemon/variant/back/773-water_2.png deleted file mode 100644 index 26cba80cd72..00000000000 Binary files a/public/images/pokemon/variant/back/773-water_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/773-water_3.json b/public/images/pokemon/variant/back/773-water_3.json deleted file mode 100644 index 2bd2476645d..00000000000 --- a/public/images/pokemon/variant/back/773-water_3.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "textures": [ - { - "image": "773-water_3.png", - "format": "RGBA8888", - "size": { - "w": 85, - "h": 85 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 63, - "h": 85 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - }, - "frame": { - "x": 0, - "y": 0, - "w": 63, - "h": 85 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:f94551f1224191b67e0ae587e065ec6b:d24addb57cd174d5ef9826fb0720f71f:609e3c1a2aa54ec6d5110acf831a822b$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/773-water_3.png b/public/images/pokemon/variant/back/773-water_3.png deleted file mode 100644 index b631825b370..00000000000 Binary files a/public/images/pokemon/variant/back/773-water_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/back/807.json b/public/images/pokemon/variant/back/807.json new file mode 100644 index 00000000000..4471a1b5b50 --- /dev/null +++ b/public/images/pokemon/variant/back/807.json @@ -0,0 +1,28 @@ +{ + "1": { + "484f57": "243058", + "5bd0f2": "ebceff", + "2759a5": "736599", + "727678": "3f5277", + "daa936": "5c96b4", + "ef8a4e": "517bb5", + "f9e455": "80c7d7", + "9d682d": "3d648c", + "000000": "ffffff", + "2394d8": "b298d8", + "31343e": "14193f" + }, + "2": { + "484f57": "cba3ca", + "5bd0f2": "df7298", + "2759a5": "a3378a", + "727678": "e7c9e2", + "daa936": "351d53", + "ef8a4e": "844c94", + "f9e455": "58326f", + "9d682d": "1f1144", + "000000": "ffffff", + "2394d8": "be5293", + "31343e": "a880b0" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/894.json b/public/images/pokemon/variant/back/894.json new file mode 100644 index 00000000000..d213b87dcf4 --- /dev/null +++ b/public/images/pokemon/variant/back/894.json @@ -0,0 +1,24 @@ +{ + "1": { + "e5ee1a": "6ad7f3", + "7d542a": "2769aa", + "bc8b2f": "124b78", + "fefac7": "dffff6", + "2e3967": "357b84", + "8eacdd": "caffd1", + "375395": "5fcaad", + "4e7cc9": "9bf1c4", + "d7ad0d": "45a3d6" + }, + "2": { + "e5ee1a": "d4ffd0", + "7d542a": "429877", + "bc8b2f": "2a6f5d", + "fefac7": "ffffff", + "2e3967": "514199", + "8eacdd": "c693d8", + "375395": "815bad", + "4e7cc9": "b67cd6", + "d7ad0d": "7cd395" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/895.json b/public/images/pokemon/variant/back/895.json new file mode 100644 index 00000000000..d9a7f49ae44 --- /dev/null +++ b/public/images/pokemon/variant/back/895.json @@ -0,0 +1,26 @@ +{ + "1": { + "641e2c": "722123", + "b63650": "bc623e", + "608d99": "fae5bf", + "2b3d40": "754f47", + "4b6f78": "f1d4b6", + "e05276": "ef8429", + "f27a99": "efb55a", + "3f545f": "ad8473", + "872c3c": "93372d", + "242e35": "512c25" + }, + "2": { + "641e2c": "15553b", + "b63650": "3bb349", + "608d99": "9b7ebc", + "2b3d40": "241951", + "4b6f78": "5a4382", + "e05276": "8aea41", + "f27a99": "dfff75", + "3f545f": "3a2a67", + "872c3c": "227843", + "242e35": "0f0c1e" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/944.json b/public/images/pokemon/variant/back/944.json new file mode 100644 index 00000000000..6f41f91c4d6 --- /dev/null +++ b/public/images/pokemon/variant/back/944.json @@ -0,0 +1,44 @@ +{ + "1": { + "b5eab2": "75a0d0", + "d4eac7": "8bcfe5", + "bdb2bd": "53a164", + "ceceb7": "3ec295", + "726766": "4f985c", + "4a4860": "372869", + "8ce1b2": "6383c4", + "564a49": "286943", + "000000": "ffffff", + "4ca391": "3a4a8a", + "97859b": "3f8d59", + "a571e6": "ffe269", + "774d9b": "d09139", + "efeee1": "88eeab", + "afc6d8": "8056a7", + "c9e1f4": "b782cd", + "918772": "1c9b8d", + "869fad": "5e4090", + "3a2b2f": "18493f" + }, + "2": { + "b5eab2": "a9c6dc", + "d4eac7": "e2f8ff", + "bdb2bd": "78b0c2", + "ceceb7": "abc1df", + "726766": "5386b9", + "4a4860": "4f133f", + "8ce1b2": "8397c4", + "564a49": "2c4f8a", + "000000": "ffffff", + "4ca391": "6974ad", + "97859b": "5582a4", + "a571e6": "4c5372", + "774d9b": "2c2c46", + "efeee1": "e2f3ff", + "afc6d8": "c23f4f", + "c9e1f4": "f98381", + "918772": "6777aa", + "869fad": "902a4b", + "3a2b2f": "1e3072" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/945.json b/public/images/pokemon/variant/back/945.json new file mode 100644 index 00000000000..500e68e3812 --- /dev/null +++ b/public/images/pokemon/variant/back/945.json @@ -0,0 +1,38 @@ +{ + "1": { + "403f4f": "357747", + "1f2635": "1c193d", + "dcdcc3": "5ddcb2", + "d6d3ca": "499833", + "e0ebf1": "7ddfee", + "e6e2e1": "fffbf3", + "8d2151": "4676aa", + "4f483f": "1b727b", + "323d4a": "2e2452", + "000000": "ffffff", + "d73875": "68adca", + "aebec7": "62b0d0", + "38bdda": "494e64", + "282434": "14463f", + "aca699": "2db3a4", + "a4988b": "16613d", + "4b616b": "473869" + }, + "2": { + "403f4f": "3b6b9e", + "1f2635": "3b091c", + "dcdcc3": "edf0f1", + "e6e2e1": "ebf4f9", + "8d2151": "4676aa", + "4f483f": "5d7487", + "323d4a": "580f1d", + "000000": "ffffff", + "a599a8": "bf888f", + "d73875": "68adca", + "7c6a84": "965b6f", + "38bdda": "494e64", + "282434": "2d427e", + "aca699": "acbfc7", + "4b616b": "8a2029" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/female/154.json b/public/images/pokemon/variant/back/female/154.json new file mode 100644 index 00000000000..d7463ebee9d --- /dev/null +++ b/public/images/pokemon/variant/back/female/154.json @@ -0,0 +1,26 @@ +{ + "1": { + "634a00": "6da0df", + "ff3a5a": "234d81", + "e6ad00": "90c6f8", + "ce213a": "192e5e", + "63bd42": "9d86d9", + "f7a59c": "78d38b", + "7b103a": "111c44", + "107b31": "8057b2", + "ffde21": "b9e2ff", + "9ce652": "b7afee" + }, + "2": { + "634a00": "144627", + "ff3a5a": "9ed662", + "e6ad00": "1e632b", + "ce213a": "81c65c", + "63bd42": "a31f60", + "f7a59c": "ddf2b5", + "7b103a": "59ac45", + "107b31": "761858", + "ffde21": "288028", + "9ce652": "cd3b6b" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/female/194.json b/public/images/pokemon/variant/back/female/194.json new file mode 100644 index 00000000000..db649381d14 --- /dev/null +++ b/public/images/pokemon/variant/back/female/194.json @@ -0,0 +1,20 @@ +{ + "1": { + "529ce6": "e8983d", + "9463a5": "2ea380", + "633a6b": "09484f", + "3a7bc5": "d5682e", + "73bdff": "ffc355", + "d65ad6": "44d77f", + "104a84": "7a150a" + }, + "2": { + "529ce6": "564daa", + "9463a5": "aeccdf", + "633a6b": "444c7e", + "3a7bc5": "3f377e", + "73bdff": "5c66c4", + "d65ad6": "e8faff", + "104a84": "180d42" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/female/195.json b/public/images/pokemon/variant/back/female/195.json new file mode 100644 index 00000000000..a097ea3eac4 --- /dev/null +++ b/public/images/pokemon/variant/back/female/195.json @@ -0,0 +1,24 @@ +{ + "1": { + "ade6ff": "f6dfa8", + "84d6f7": "ed9e4f", + "637ba5": "816251", + "639cbd": "dc6a4d", + "3194a5": "44d77f", + "6b5a8c": "1b5a55", + "425284": "b03844", + "426b84": "b8453b", + "195a6b": "2ea380" + }, + "2": { + "ade6ff": "9864c2", + "84d6f7": "724ba7", + "637ba5": "504a8a", + "639cbd": "493a8d", + "3194a5": "ebf5ff", + "6b5a8c": "5e649b", + "425284": "240830", + "195a6b": "aebbdf", + "19423a": "747aae" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/female/198.json b/public/images/pokemon/variant/back/female/198.json new file mode 100644 index 00000000000..eed8404265c --- /dev/null +++ b/public/images/pokemon/variant/back/female/198.json @@ -0,0 +1,26 @@ +{ + "1": { + "d94352": "8c1b23", + "314263": "462b20", + "efd684": "a6a6b3", + "d64252": "b3986b", + "42639c": "694c30", + "5a4a21": "25253b", + "292942": "2a1512", + "b59c21": "57566f", + "73293a": "755237", + "d6bd52": "838098" + }, + "2": { + "d94352": "8c1b23", + "314263": "0e4333", + "efd684": "c2723a", + "d64252": "bc4b84", + "42639c": "1d6e47", + "5a4a21": "4e1915", + "292942": "091e16", + "b59c21": "85412d", + "73293a": "7b2363", + "d6bd52": "9a5524" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/female/25-beauty-cosplay.json b/public/images/pokemon/variant/back/female/25-beauty-cosplay.json new file mode 100644 index 00000000000..34a087f71cd --- /dev/null +++ b/public/images/pokemon/variant/back/female/25-beauty-cosplay.json @@ -0,0 +1,32 @@ +{ + "1": { + "f7cc2f": "d5ac44", + "9c5200": "315c75", + "f7e860": "eddc78", + "cecab9": "b84084", + "2d276d": "454a61", + "4d88c4": "e4f6f1", + "39509d": "9ec4cd", + "fffdea": "ea82a6", + "f7e652": "a3d1a8", + "f7bd21": "79b5a5", + "5e5e6b": "8a2554" + }, + "2": { + "4f454c": "f1b571", + "f7cc2f": "d5ac44", + "fffabf": "f5efd1", + "9c5200": "283361", + "f7e860": "eddc78", + "965b0e": "96500e", + "cecab9": "b84084", + "2d276d": "454a61", + "4d88c4": "e4f6f1", + "39509d": "9ec4cd", + "fffdea": "ea82a6", + "1e1526": "a45233", + "f7e652": "577b98", + "f7bd21": "486689", + "5e5e6b": "8a2554" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/female/25-cool-cosplay.json b/public/images/pokemon/variant/back/female/25-cool-cosplay.json new file mode 100644 index 00000000000..278feb070bd --- /dev/null +++ b/public/images/pokemon/variant/back/female/25-cool-cosplay.json @@ -0,0 +1,31 @@ +{ + "1": { + "171717": "2a1d36", + "c52119": "ad4e76", + "842222": "7b1f18", + "f7e652": "a3d1a8", + "fff7a5": "c4e3c3", + "f7bd21": "79b5a5", + "ba2b23": "b73850", + "9c5200": "1c4f75", + "d95b45": "cf6887", + "3b3b40": "4a3e46" + }, + "2": { + "171717": "a45233", + "656f86": "cf752b", + "a5b0b6": "f0b541", + "c52119": "ebc67c", + "842222": "1e1e43", + "f7e652": "577b98", + "fff7a5": "7b96aa", + "f7bd21": "445f8a", + "ba2b23": "2c2c47", + "55555e": "8f4b32", + "9c5200": "22325c", + "f4f7ab": "eadbb3", + "d95b45": "3a3f5e", + "3b3b40": "f1b571", + "272b2b": "7d3833" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/female/25-cosplay.json b/public/images/pokemon/variant/back/female/25-cosplay.json new file mode 100644 index 00000000000..c574d63d743 --- /dev/null +++ b/public/images/pokemon/variant/back/female/25-cosplay.json @@ -0,0 +1,26 @@ +{ + "1": { + "f7e652": "a3d1a8", + "fff7a5": "c4e3c3", + "c52119": "ad4e76", + "f7bd21": "79b5a5", + "52525a": "4f454c", + "9c5200": "315c75", + "292929": "1e1526", + "633108": "09406b", + "e65a42": "cf6182", + "de9400": "338087" + }, + "2": { + "f7e652": "577b98", + "fff7a5": "7b96aa", + "c52119": "ebc67c", + "f7bd21": "445f8a", + "52525a": "f1b571", + "9c5200": "23345e", + "292929": "a45233", + "633108": "22244f", + "e65a42": "eedd9c", + "de9400": "324472" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/female/25-cute-cosplay.json b/public/images/pokemon/variant/back/female/25-cute-cosplay.json new file mode 100644 index 00000000000..7b26b79d08f --- /dev/null +++ b/public/images/pokemon/variant/back/female/25-cute-cosplay.json @@ -0,0 +1,32 @@ +{ + "1": { + "752bd0": "5452b7", + "baa998": "bab699", + "fff7a5": "c4e3c3", + "f7e652": "a3d1a8", + "ea82a6": "e8848e", + "cf4770": "cf4a59", + "f3bace": "f2bbbb", + "853247": "85323c", + "f7ef97": "f0eaa8", + "52525a": "4f454c", + "292929": "30263b", + "f7bd21": "79b5a5", + "9c5200": "255e8a" + }, + "2": { + "752bd0": "7751c2", + "baa998": "d3ab5a", + "fff7a5": "7b96aa", + "f7e652": "577b98", + "ea82a6": "a4b95f", + "cf4770": "739b55", + "f3bace": "c5cc85", + "853247": "254b30", + "f7ef97": "ebe7b7", + "52525a": "f1b571", + "292929": "a45233", + "f7bd21": "445f8a", + "9c5200": "23345e" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/female/25-partner.json b/public/images/pokemon/variant/back/female/25-partner.json new file mode 100644 index 00000000000..affebee3c8b --- /dev/null +++ b/public/images/pokemon/variant/back/female/25-partner.json @@ -0,0 +1,26 @@ +{ + "1": { + "9c5200": "315c75", + "171717": "1e1526", + "fff7a5": "c4e3c3", + "f7bd21": "79b5a5", + "f7e652": "a3d1a8", + "c52119": "ad4e76", + "e65a42": "cf6182", + "633108": "09406b", + "45454a": "4f454c", + "de9400": "338087" + }, + "2": { + "9c5200": "23345e", + "171717": "a45233", + "fff7a5": "7b96aa", + "f7bd21": "445f8a", + "f7e652": "577b98", + "c52119": "ebc67c", + "e65a42": "eedd9c", + "633108": "22244f", + "45454a": "f1b571", + "de9400": "324472" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/female/25-smart-cosplay.json b/public/images/pokemon/variant/back/female/25-smart-cosplay.json new file mode 100644 index 00000000000..50749b31d8b --- /dev/null +++ b/public/images/pokemon/variant/back/female/25-smart-cosplay.json @@ -0,0 +1,32 @@ +{ + "1": { + "fffdea": "f8ffe3", + "b7a599": "bab699", + "60b553": "76a848", + "f7e652": "a3d1a8", + "366635": "3e5b2f", + "95635b": "91685f", + "171717": "1e1526", + "5f3434": "573b38", + "54545c": "55555e", + "52525a": "4f454c", + "292929": "272b2b", + "f7bd21": "79b5a5", + "9c5200": "315c75" + }, + "2": { + "fffdea": "f2f0df", + "b7a599": "a7b6b9", + "60b553": "dfb053", + "f7e652": "577b98", + "366635": "ab5130", + "95635b": "a09ea3", + "171717": "a45233", + "5f3434": "666060", + "54545c": "45525c", + "52525a": "f1b571", + "292929": "202937", + "f7bd21": "445f8a", + "9c5200": "23345e" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/female/25-tough-cosplay.json b/public/images/pokemon/variant/back/female/25-tough-cosplay.json new file mode 100644 index 00000000000..49c50d17ad2 --- /dev/null +++ b/public/images/pokemon/variant/back/female/25-tough-cosplay.json @@ -0,0 +1,35 @@ +{ + "1": { + "e37511": "d1694f", + "bf2629": "cf6a59", + "8d2b1d": "bf3638", + "c52119": "ad4e76", + "46464d": "2b3340", + "292929": "1e1526", + "f7bd21": "79b5a5", + "fbab33": "de9764", + "e65a42": "cf6182", + "cecab9": "cfc8aa", + "52525a": "4f454c", + "f7e652": "a3d1a8", + "9c5200": "315c75" + }, + "2": { + "e37511": "60448d", + "bf2629": "826694", + "f8ffe3": "e8e3e4", + "8d2b1d": "3d3f7d", + "c52119": "ebc67c", + "46464d": "2b3340", + "292929": "a45233", + "f7bd21": "445f8a", + "fbab33": "845ea1", + "e65a42": "eedd9c", + "cecab9": "beb1b4", + "8e2525": "242866", + "52525a": "f1b571", + "f7e652": "577b98", + "272b2b": "162231", + "9c5200": "23345e" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/female/25.json b/public/images/pokemon/variant/back/female/25.json new file mode 100644 index 00000000000..affebee3c8b --- /dev/null +++ b/public/images/pokemon/variant/back/female/25.json @@ -0,0 +1,26 @@ +{ + "1": { + "9c5200": "315c75", + "171717": "1e1526", + "fff7a5": "c4e3c3", + "f7bd21": "79b5a5", + "f7e652": "a3d1a8", + "c52119": "ad4e76", + "e65a42": "cf6182", + "633108": "09406b", + "45454a": "4f454c", + "de9400": "338087" + }, + "2": { + "9c5200": "23345e", + "171717": "a45233", + "fff7a5": "7b96aa", + "f7bd21": "445f8a", + "f7e652": "577b98", + "c52119": "ebc67c", + "e65a42": "eedd9c", + "633108": "22244f", + "45454a": "f1b571", + "de9400": "324472" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/female/26.json b/public/images/pokemon/variant/back/female/26.json new file mode 100644 index 00000000000..6a29870fc8b --- /dev/null +++ b/public/images/pokemon/variant/back/female/26.json @@ -0,0 +1,33 @@ +{ + "1": { + "63636b": "4f454c", + "944242": "395a80", + "bd5a31": "386d82", + "e6bd84": "a4bda7", + "ffbd00": "b3596b", + "5a2929": "293059", + "3a3a42": "30263b", + "8c6310": "8c3c4c", + "ffde5a": "cf7878", + "f7ad29": "76a68b", + "734231": "6e2f33", + "ffefd6": "c8d4ba", + "de7b31": "539190" + }, + "2": { + "101010": "000000", + "542127": "905331", + "944242": "2d3b80", + "bd5a31": "375681", + "e6bd84": "a6b5ab", + "ffbd00": "f3cf91", + "5a2929": "202a60", + "8c6310": "c79b5a", + "ffde5a": "f2e4b6", + "f7ad29": "6385ab", + "734231": "bf8445", + "ffefd6": "cfc4b5", + "de7b31": "4d6f98", + "643034": "2e4685" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/back/female/453.json b/public/images/pokemon/variant/back/female/453.json index f95eb45cdfc..8fab3b26995 100644 --- a/public/images/pokemon/variant/back/female/453.json +++ b/public/images/pokemon/variant/back/female/453.json @@ -19,12 +19,11 @@ "4a4a8c": "d88f77", "6b73d6": "f0ce8b", "849cff": "fff2c9", - "101010": "101010", - "9c3a3a": "16729b", - "e6525a": "40adbb", - "ff9ca5": "a9ebeb", - "313142": "40061f", - "525252": "75204b", + "9c3a3a": "098a70", + "e6525a": "2ec276", + "ff9ca5": "92f194", + "313142": "43102b", + "525252": "6c1b54", "7b7b8c": "7e3a6a", "b5b5c5": "b1798c", "ffffff": "f0e3e5" diff --git a/public/images/pokemon/variant/back/female/454.json b/public/images/pokemon/variant/back/female/454.json index 52d91504c9f..c9a44500cec 100644 --- a/public/images/pokemon/variant/back/female/454.json +++ b/public/images/pokemon/variant/back/female/454.json @@ -16,16 +16,15 @@ }, "2": { "3a3a52": "b15248", - "101010": "101010", "6b73d6": "f0ce8b", "4a4a8c": "d88f77", "849cff": "fff2c9", - "313142": "610d31", + "313142": "610d48", "ffd619": "ff81ae", "b58c19": "d0498c", - "525252": "af465d", - "9c3a3a": "16729b", - "e6525a": "40adbb", + "525252": "af467d", + "9c3a3a": "098a70", + "e6525a": "2ec276", "7b7b8c": "7e3a6a", "b5b5c5": "b1798c" } diff --git a/public/images/pokemon/variant/exp/2026.json b/public/images/pokemon/variant/exp/2026.json new file mode 100644 index 00000000000..287b16fb52b --- /dev/null +++ b/public/images/pokemon/variant/exp/2026.json @@ -0,0 +1,34 @@ +{ + "1": { + "ecd8b7": "b4c2a5", + "646124": "492652", + "602c24": "162f4b", + "fef652": "eb999a", + "846b5b": "467f85", + "1a73cc": "b85346", + "9c5430": "1d3a57", + "174680": "2b1307", + "fef443": "c48081", + "b45f25": "2d5261", + "fffdfb": "d6d9ca", + "e9be14": "945c7b", + "e3882d": "3d7375", + "965821": "2f4e6b", + "552720": "142c48" + }, + "2": { + "ecd8b7": "5a6f90", + "646124": "122140", + "fef652": "faee9e", + "846b5b": "202746", + "1a73cc": "c26400", + "174680": "2b0606", + "fef443": "3a5873", + "b45f25": "bd8551", + "fffdfb": "6d8297", + "e9be14": "1a3551", + "e3882d": "d3b06f", + "965821": "9cb3ca", + "552720": "43617f" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/2103.json b/public/images/pokemon/variant/exp/2103.json new file mode 100644 index 00000000000..2e97727835a --- /dev/null +++ b/public/images/pokemon/variant/exp/2103.json @@ -0,0 +1,28 @@ +{ + "1": { + "2f9934": "dea44c", + "9f6b41": "426378", + "70442e": "283f5b", + "e6ac5a": "869fdc", + "522f16": "131d33", + "9cbd4a": "9977dd", + "fff68b": "a3c4ed", + "36cc36": "f4e774", + "2d5826": "c8592a", + "7b5210": "373e85", + "ffffcd": "d3efff" + }, + "2": { + "2f9934": "3d324b", + "9f6b41": "ffdbe7", + "70442e": "d59cba", + "e6ac5a": "c84e7f", + "522f16": "925b81", + "9cbd4a": "824a96", + "fff68b": "eb748d", + "36cc36": "6a5b73", + "2d5826": "1f1a31", + "7b5210": "4e1044", + "ffffcd": "ffa29d" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/359-mega.json b/public/images/pokemon/variant/exp/359-mega.json new file mode 100644 index 00000000000..084ba24477b --- /dev/null +++ b/public/images/pokemon/variant/exp/359-mega.json @@ -0,0 +1,34 @@ +{ + "1": { + "ffffff": "61a8ab", + "253334": "27122b", + "253333": "2b3266", + "273636": "101f30", + "7b2931": "c9824b", + "414a6a": "421e4a", + "b4b4d5": "458196", + "cd2920": "f7c26d", + "293939": "27122b", + "525a7b": "59274e", + "d5deee": "589aa6", + "737bac": "874267", + "8b8bac": "3b6987", + "626283": "2a3163" + }, + "2": { + "ffffff": "9e363b", + "253334": "996e5f", + "253333": "420b26", + "273636": "420918", + "7b2931": "0f4391", + "414a6a": "b39279", + "b4b4d5": "752f40", + "cd2920": "2a96ce", + "293939": "996e5f", + "525a7b": "e0c79f", + "d5deee": "8f2f41", + "737bac": "f5f1cb", + "8b8bac": "59213b", + "626283": "42122d" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/4144.json b/public/images/pokemon/variant/exp/4144.json new file mode 100644 index 00000000000..b217265ec54 --- /dev/null +++ b/public/images/pokemon/variant/exp/4144.json @@ -0,0 +1,38 @@ +{ + "1": { + "43458b": "8cb0d3", + "60748a": "090a2e", + "bbc9d9": "39579a", + "282a5d": "48638c", + "6f65c5": "afd4ee", + "2f2f2f": "4da0c9", + "d9b5fb": "29336f", + "754691": "08092d", + "a695ea": "d5f1ff", + "1a1a1a": "254f89", + "754692": "bd5a2c", + "b480d7": "ffb725", + "b480d6": "181f54", + "080808": "101010", + "5fbddc": "ffb725", + "eef0f2": "5678a9" + }, + "2": { + "43458b": "75151e", + "60748a": "a37f56", + "bbc9d9": "ead9b8", + "282a5d": "540916", + "6f65c5": "a2282c", + "2f2f2f": "ffefe5", + "d9b5fb": "f4b260", + "754691": "873c0f", + "a695ea": "c0443d", + "1a1a1a": "bb826c", + "754692": "952274", + "b480d7": "ce2488", + "b480d6": "d58639", + "080808": "101010", + "5fbddc": "ce2488", + "eef0f2": "fff9e7" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/4144_2.png b/public/images/pokemon/variant/exp/4144_2.png index d001fc89e71..dcce06c2d85 100644 Binary files a/public/images/pokemon/variant/exp/4144_2.png and b/public/images/pokemon/variant/exp/4144_2.png differ diff --git a/public/images/pokemon/variant/exp/4144_3.png b/public/images/pokemon/variant/exp/4144_3.png index 08145ce9ba0..6662ba42119 100644 Binary files a/public/images/pokemon/variant/exp/4144_3.png and b/public/images/pokemon/variant/exp/4144_3.png differ diff --git a/public/images/pokemon/variant/exp/4145.json b/public/images/pokemon/variant/exp/4145.json new file mode 100644 index 00000000000..9800b1a00dc --- /dev/null +++ b/public/images/pokemon/variant/exp/4145.json @@ -0,0 +1,26 @@ +{ + "1": { + "50453c": "334c7f", + "863716": "7e98ad", + "ffd541": "f28b41", + "272320": "111742", + "38322d": "22253b", + "de6e33": "d85b26", + "c24814": "b3cdd9", + "3e352b": "1e2e5f", + "f76c1a": "daf6f6", + "5f2311": "5c6f8e" + }, + "2": { + "50453c": "d2ddea", + "863716": "871858", + "ffd541": "3cd96c", + "272320": "3c445e", + "38322d": "202231", + "de6e33": "25b165", + "c24814": "ba276d", + "3e352b": "9da9bd", + "f76c1a": "e14589", + "5f2311": "630645" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/4145_2.png b/public/images/pokemon/variant/exp/4145_2.png index c76a7a34493..d2a89e1b11e 100644 Binary files a/public/images/pokemon/variant/exp/4145_2.png and b/public/images/pokemon/variant/exp/4145_2.png differ diff --git a/public/images/pokemon/variant/exp/4145_3.png b/public/images/pokemon/variant/exp/4145_3.png index c1110107837..b04a5307c58 100644 Binary files a/public/images/pokemon/variant/exp/4145_3.png and b/public/images/pokemon/variant/exp/4145_3.png differ diff --git a/public/images/pokemon/variant/exp/4146.json b/public/images/pokemon/variant/exp/4146.json new file mode 100644 index 00000000000..269c41803ac --- /dev/null +++ b/public/images/pokemon/variant/exp/4146.json @@ -0,0 +1,31 @@ +{ + "1": { + "00bfbf": "ff78a6", + "35454d": "f774a0", + "35454b": "0d1e54", + "6b8895": "2b5584", + "f15888": "73e1e6", + "e82f52": "24a8d3", + "b51c39": "77a7bb", + "ffd5f0": "e4fff6", + "840020": "1f557c", + "ffaedc": "a5f5e7", + "262e30": "000240", + "54656c": "163269", + "de3859": "cdf0f1" + }, + "2": { + "00bfbf": "db7640", + "35454d": "db743c", + "35454b": "adb981", + "6b8895": "fff9de", + "f15888": "6acf42", + "e82f52": "058323", + "b51c39": "004634", + "ffd5f0": "f4ff90", + "840020": "00312d", + "ffaedc": "c2f75f", + "54656c": "e4e8bb", + "de3859": "04723a" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/4146_2.png b/public/images/pokemon/variant/exp/4146_2.png index 6f353468796..c596814d273 100644 Binary files a/public/images/pokemon/variant/exp/4146_2.png and b/public/images/pokemon/variant/exp/4146_2.png differ diff --git a/public/images/pokemon/variant/exp/4146_3.png b/public/images/pokemon/variant/exp/4146_3.png index 0513bdbadca..03d1872ee45 100644 Binary files a/public/images/pokemon/variant/exp/4146_3.png and b/public/images/pokemon/variant/exp/4146_3.png differ diff --git a/public/images/pokemon/variant/exp/6503.json b/public/images/pokemon/variant/exp/6503.json new file mode 100644 index 00000000000..62c6cb628b2 --- /dev/null +++ b/public/images/pokemon/variant/exp/6503.json @@ -0,0 +1,37 @@ +{ + "1": { + "282f62": "f7d9de", + "c4c5cf": "e3c2ca", + "84a4a7": "563785", + "a82c47": "d45b9e", + "8aa3a3": "6b415b", + "8da8a8": "a58b90", + "1d3962": "28142c", + "d75063": "b73891", + "d9cacd": "f7d9de", + "808280": "020501", + "1e224e": "dc95ae", + "1e5b9b": "4d244b", + "181531": "a26579", + "6b1c34": "8f3396", + "597471": "332a59", + "494a48": "3d2439" + }, + "2": { + "282f62": "efdfee", + "c4c5cf": "232d2e", + "84a4a7": "41857b", + "a82c47": "8abfb1", + "8aa3a3": "181f20", + "faf9f9": "2c3940", + "8da8a8": "bdbdbd", + "1d3962": "321e1e", + "d75063": "8f65d8", + "1e224e": "ba9bc1", + "1e5b9b": "5e3e38", + "181531": "715b72", + "6b1c34": "6d9d9a", + "597471": "2a5c57", + "494a48": "0b0f18" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/656.json b/public/images/pokemon/variant/exp/656.json new file mode 100644 index 00000000000..68743a4c9f1 --- /dev/null +++ b/public/images/pokemon/variant/exp/656.json @@ -0,0 +1,32 @@ +{ + "1": { + "838394": "4d7dc5", + "62ace6": "8363af", + "7bcdff": "9c75c2", + "ffec8c": "ddfff9", + "a1a1c4": "7ab7ec", + "c9b241": "97d6e2", + "dfcf77": "bae7e8", + "174592": "37408c", + "fdfdfd": "b1e5ff", + "9c9cc5": "5385c7", + "cdcde6": "7eb7e8", + "396a83": "362864", + "5a94cd": "7054a4" + }, + "2": { + "838394": "cc6845", + "62ace6": "c44848", + "7bcdff": "dd6155", + "ffec8c": "ddfff9", + "a1a1c4": "f7c685", + "c9b241": "97d6e2", + "dfcf77": "bae7e8", + "174592": "198158", + "fdfdfd": "fff4bd", + "9c9cc5": "c96a48", + "cdcde6": "f7b785", + "396a83": "5c0d33", + "5a94cd": "a92f3f" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/657.json b/public/images/pokemon/variant/exp/657.json new file mode 100644 index 00000000000..773b4d2efc1 --- /dev/null +++ b/public/images/pokemon/variant/exp/657.json @@ -0,0 +1,32 @@ +{ + "1": { + "f8f8f8": "8dcfff", + "efc653": "abd7db", + "737373": "0f3f82", + "0b566a": "281f52", + "ffec72": "c9fff5", + "002c58": "1c0726", + "bfbfbf": "4386df", + "006ba6": "4e1852", + "009dd5": "61255e", + "0b4a7a": "340f3d", + "e1a03a": "78c7c7", + "41ccf5": "7755a7", + "2896b5": "4b3578" + }, + "2": { + "f8f8f8": "fff6c7", + "efc653": "abd7db", + "737373": "df6a50", + "0b566a": "7e1628", + "ffec72": "ddfff9", + "002c58": "0c3b54", + "bfbfbf": "ffc996", + "006ba6": "239c91", + "009dd5": "37b8ac", + "0b4a7a": "156f78", + "e1a03a": "86abbb", + "41ccf5": "dd7355", + "2896b5": "a92f3a" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/658-ash.json b/public/images/pokemon/variant/exp/658-ash.json new file mode 100644 index 00000000000..96b60b02adf --- /dev/null +++ b/public/images/pokemon/variant/exp/658-ash.json @@ -0,0 +1,44 @@ +{ + "1": { + "265595": "432b6c", + "3f4447": "466698", + "de3431": "3fca9f", + "f8f8f8": "a1e9f0", + "7b282e": "0e3e81", + "6b1d1d": "206d74", + "4ebdd9": "41a7b0", + "bfb169": "165e78", + "bfbfbf": "8cc7d4", + "ffb2bf": "b7e9ff", + "bf4c60": "4386df", + "fff0a6": "208698", + "3e7acc": "6b4592", + "18335c": "170738", + "f2798d": "8dcfff", + "f01818": "39b88f", + "7ddeff": "7ddcd6", + "268794": "1c3e58", + "282c35": "271f4c" + }, + "2": { + "265595": "cc7251", + "3f4447": "466698", + "de3431": "9ceec6", + "f8f8f8": "89d2b8", + "7b282e": "152a5c", + "6b1d1d": "356e8d", + "4ebdd9": "2f6e74", + "bfb169": "431022", + "bfbfbf": "8cc7d4", + "ffb2bf": "86d6b6", + "bf4c60": "32738b", + "fff0a6": "472333", + "3e7acc": "ecbb7a", + "18335c": "9f2727", + "f2798d": "5eb4a9", + "f01818": "ffe88d", + "7ddeff": "46988d", + "268794": "1c3e58", + "282c35": "4d2637" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/658.json b/public/images/pokemon/variant/exp/658.json new file mode 100644 index 00000000000..826e31b4e21 --- /dev/null +++ b/public/images/pokemon/variant/exp/658.json @@ -0,0 +1,34 @@ +{ + "1": { + "ffb2bf": "b7e9ff", + "bf4c60": "4386df", + "66d9ff": "7ddcd6", + "3d61cc": "6b4592", + "fff0a6": "208698", + "c92e2e": "73c5ff", + "937f69": "406695", + "c2c1bc": "89b0d7", + "f2798d": "8dcfff", + "f7f7f7": "d8ffff", + "bfb169": "165e78", + "1b2a59": "170738", + "803340": "0e3e81", + "2e4999": "432b6c" + }, + "2": { + "ffb2bf": "86d6b6", + "bf4c60": "32738b", + "66d9ff": "48968c", + "3d61cc": "ecbb7a", + "fff0a6": "652240", + "c92e2e": "63bf9b", + "937f69": "466698", + "c2c1bc": "8cc7d4", + "f2798d": "5eb4a9", + "f7f7f7": "d7eff4", + "bfb169": "431022", + "1b2a59": "9f2727", + "803340": "152a5c", + "2e4999": "cc7251" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/6706.json b/public/images/pokemon/variant/exp/6706.json new file mode 100644 index 00000000000..2a5f8e112ee --- /dev/null +++ b/public/images/pokemon/variant/exp/6706.json @@ -0,0 +1,40 @@ +{ + "1": { + "566678": "0e6296", + "e0e4f4": "513981", + "625287": "4e4094", + "536273": "1f1233", + "988b98": "b24c86", + "36404c": "0c5474", + "c4cce1": "3b235c", + "e6d3e9": "f1a4c5", + "bfacc1": "da75a5", + "515f70": "197497", + "c5cee3": "63cee1", + "b791f2": "c7a1e5", + "8b93a6": "3aa8c4", + "80737f": "8a2166", + "4b454f": "6f1357", + "9170b9": "8b69c3", + "8e96aa": "301848" + }, + "2": { + "566678": "8e480b", + "e0e4f4": "176463", + "625287": "274159", + "536273": "02262c", + "988b98": "2a6563", + "36404c": "842401", + "c4cce1": "0d484a", + "e6d3e9": "9cead8", + "bfacc1": "5db6a9", + "515f70": "a34205", + "c5cee3": "f7af58", + "b791f2": "4a9699", + "8b93a6": "d27e26", + "80737f": "2b736f", + "4b454f": "194f51", + "9170b9": "2f667c", + "8e96aa": "073338" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/6706_2.json b/public/images/pokemon/variant/exp/6706_2.json deleted file mode 100644 index cb2ddfb1a12..00000000000 --- a/public/images/pokemon/variant/exp/6706_2.json +++ /dev/null @@ -1,2015 +0,0 @@ -{ - "textures": [ - { - "image": "6706_2.png", - "format": "RGBA8888", - "size": { - "w": 508, - "h": 508 - }, - "scale": 1, - "frames": [ - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 28, - "y": 26, - "w": 59, - "h": 61 - }, - "frame": { - "x": 0, - "y": 0, - "w": 59, - "h": 61 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 26, - "y": 25, - "w": 56, - "h": 63 - }, - "frame": { - "x": 59, - "y": 0, - "w": 56, - "h": 63 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 26, - "y": 25, - "w": 56, - "h": 63 - }, - "frame": { - "x": 59, - "y": 0, - "w": 56, - "h": 63 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 28, - "y": 21, - "w": 53, - "h": 65 - }, - "frame": { - "x": 115, - "y": 0, - "w": 53, - "h": 65 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 28, - "y": 21, - "w": 53, - "h": 65 - }, - "frame": { - "x": 115, - "y": 0, - "w": 53, - "h": 65 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 29, - "y": 21, - "w": 54, - "h": 65 - }, - "frame": { - "x": 168, - "y": 0, - "w": 54, - "h": 65 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 29, - "y": 21, - "w": 54, - "h": 65 - }, - "frame": { - "x": 168, - "y": 0, - "w": 54, - "h": 65 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 28, - "y": 21, - "w": 53, - "h": 65 - }, - "frame": { - "x": 222, - "y": 0, - "w": 53, - "h": 65 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 28, - "y": 21, - "w": 53, - "h": 65 - }, - "frame": { - "x": 222, - "y": 0, - "w": 53, - "h": 65 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 25, - "y": 21, - "w": 55, - "h": 66 - }, - "frame": { - "x": 275, - "y": 0, - "w": 55, - "h": 66 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 25, - "y": 21, - "w": 55, - "h": 66 - }, - "frame": { - "x": 275, - "y": 0, - "w": 55, - "h": 66 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 23, - "y": 23, - "w": 54, - "h": 66 - }, - "frame": { - "x": 330, - "y": 0, - "w": 54, - "h": 66 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 23, - "y": 23, - "w": 54, - "h": 66 - }, - "frame": { - "x": 330, - "y": 0, - "w": 54, - "h": 66 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 25, - "y": 21, - "w": 54, - "h": 67 - }, - "frame": { - "x": 384, - "y": 0, - "w": 54, - "h": 67 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 25, - "y": 21, - "w": 54, - "h": 67 - }, - "frame": { - "x": 384, - "y": 0, - "w": 54, - "h": 67 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 23, - "y": 21, - "w": 52, - "h": 68 - }, - "frame": { - "x": 438, - "y": 0, - "w": 52, - "h": 68 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 23, - "y": 21, - "w": 52, - "h": 68 - }, - "frame": { - "x": 438, - "y": 0, - "w": 52, - "h": 68 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 21, - "y": 21, - "w": 53, - "h": 68 - }, - "frame": { - "x": 0, - "y": 61, - "w": 53, - "h": 68 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 21, - "y": 21, - "w": 53, - "h": 68 - }, - "frame": { - "x": 0, - "y": 61, - "w": 53, - "h": 68 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 18, - "y": 22, - "w": 52, - "h": 68 - }, - "frame": { - "x": 53, - "y": 63, - "w": 52, - "h": 68 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 18, - "y": 22, - "w": 52, - "h": 68 - }, - "frame": { - "x": 53, - "y": 63, - "w": 52, - "h": 68 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 19, - "y": 21, - "w": 55, - "h": 69 - }, - "frame": { - "x": 105, - "y": 65, - "w": 55, - "h": 69 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 19, - "y": 21, - "w": 55, - "h": 69 - }, - "frame": { - "x": 105, - "y": 65, - "w": 55, - "h": 69 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 21, - "y": 21, - "w": 53, - "h": 69 - }, - "frame": { - "x": 160, - "y": 65, - "w": 53, - "h": 69 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 21, - "y": 21, - "w": 53, - "h": 69 - }, - "frame": { - "x": 160, - "y": 65, - "w": 53, - "h": 69 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 16, - "y": 21, - "w": 53, - "h": 69 - }, - "frame": { - "x": 213, - "y": 65, - "w": 53, - "h": 69 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 16, - "y": 21, - "w": 53, - "h": 69 - }, - "frame": { - "x": 213, - "y": 65, - "w": 53, - "h": 69 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 15, - "y": 21, - "w": 52, - "h": 70 - }, - "frame": { - "x": 266, - "y": 66, - "w": 52, - "h": 70 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 15, - "y": 21, - "w": 52, - "h": 70 - }, - "frame": { - "x": 266, - "y": 66, - "w": 52, - "h": 70 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 19, - "w": 87, - "h": 71 - }, - "frame": { - "x": 318, - "y": 67, - "w": 87, - "h": 71 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 19, - "w": 87, - "h": 71 - }, - "frame": { - "x": 318, - "y": 67, - "w": 87, - "h": 71 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 19, - "w": 87, - "h": 71 - }, - "frame": { - "x": 318, - "y": 67, - "w": 87, - "h": 71 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 0, - "y": 18, - "w": 87, - "h": 71 - }, - "frame": { - "x": 405, - "y": 68, - "w": 87, - "h": 71 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 2, - "y": 19, - "w": 86, - "h": 72 - }, - "frame": { - "x": 0, - "y": 131, - "w": 86, - "h": 72 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 19, - "w": 87, - "h": 72 - }, - "frame": { - "x": 86, - "y": 134, - "w": 87, - "h": 72 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 87, - "h": 72 - }, - "frame": { - "x": 86, - "y": 134, - "w": 87, - "h": 72 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 87, - "h": 72 - }, - "frame": { - "x": 86, - "y": 134, - "w": 87, - "h": 72 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 19, - "w": 87, - "h": 72 - }, - "frame": { - "x": 173, - "y": 134, - "w": 87, - "h": 72 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 87, - "h": 72 - }, - "frame": { - "x": 173, - "y": 134, - "w": 87, - "h": 72 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 87, - "h": 72 - }, - "frame": { - "x": 173, - "y": 134, - "w": 87, - "h": 72 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 87, - "h": 72 - }, - "frame": { - "x": 260, - "y": 138, - "w": 87, - "h": 72 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 87, - "h": 72 - }, - "frame": { - "x": 260, - "y": 138, - "w": 87, - "h": 72 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 87, - "h": 72 - }, - "frame": { - "x": 260, - "y": 138, - "w": 87, - "h": 72 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 87, - "h": 72 - }, - "frame": { - "x": 347, - "y": 139, - "w": 87, - "h": 72 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 87, - "h": 72 - }, - "frame": { - "x": 347, - "y": 139, - "w": 87, - "h": 72 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 87, - "h": 72 - }, - "frame": { - "x": 347, - "y": 139, - "w": 87, - "h": 72 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 5, - "y": 5, - "w": 74, - "h": 80 - }, - "frame": { - "x": 434, - "y": 139, - "w": 74, - "h": 80 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 5, - "y": 5, - "w": 74, - "h": 80 - }, - "frame": { - "x": 434, - "y": 139, - "w": 74, - "h": 80 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 2, - "y": 17, - "w": 85, - "h": 72 - }, - "frame": { - "x": 0, - "y": 203, - "w": 85, - "h": 72 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 3, - "y": 13, - "w": 83, - "h": 72 - }, - "frame": { - "x": 85, - "y": 206, - "w": 83, - "h": 72 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 3, - "y": 18, - "w": 84, - "h": 73 - }, - "frame": { - "x": 168, - "y": 206, - "w": 84, - "h": 73 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 2, - "y": 17, - "w": 85, - "h": 73 - }, - "frame": { - "x": 252, - "y": 210, - "w": 85, - "h": 73 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 86, - "h": 73 - }, - "frame": { - "x": 337, - "y": 211, - "w": 86, - "h": 73 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 86, - "h": 73 - }, - "frame": { - "x": 337, - "y": 211, - "w": 86, - "h": 73 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 86, - "h": 73 - }, - "frame": { - "x": 337, - "y": 211, - "w": 86, - "h": 73 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 2, - "y": 17, - "w": 85, - "h": 73 - }, - "frame": { - "x": 423, - "y": 219, - "w": 85, - "h": 73 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 2, - "y": 17, - "w": 85, - "h": 73 - }, - "frame": { - "x": 423, - "y": 219, - "w": 85, - "h": 73 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 16, - "w": 85, - "h": 74 - }, - "frame": { - "x": 0, - "y": 275, - "w": 85, - "h": 74 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 16, - "w": 85, - "h": 74 - }, - "frame": { - "x": 0, - "y": 275, - "w": 85, - "h": 74 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 16, - "w": 85, - "h": 74 - }, - "frame": { - "x": 0, - "y": 275, - "w": 85, - "h": 74 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 0, - "y": 17, - "w": 86, - "h": 73 - }, - "frame": { - "x": 85, - "y": 279, - "w": 86, - "h": 73 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 0, - "y": 17, - "w": 86, - "h": 73 - }, - "frame": { - "x": 85, - "y": 279, - "w": 86, - "h": 73 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 0, - "y": 17, - "w": 86, - "h": 73 - }, - "frame": { - "x": 85, - "y": 279, - "w": 86, - "h": 73 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 3, - "y": 4, - "w": 81, - "h": 74 - }, - "frame": { - "x": 171, - "y": 279, - "w": 81, - "h": 74 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 3, - "y": 4, - "w": 81, - "h": 74 - }, - "frame": { - "x": 171, - "y": 279, - "w": 81, - "h": 74 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 3, - "y": 16, - "w": 84, - "h": 74 - }, - "frame": { - "x": 252, - "y": 283, - "w": 84, - "h": 74 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 3, - "y": 16, - "w": 84, - "h": 74 - }, - "frame": { - "x": 252, - "y": 283, - "w": 84, - "h": 74 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 2, - "y": 17, - "w": 86, - "h": 73 - }, - "frame": { - "x": 336, - "y": 284, - "w": 86, - "h": 73 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 2, - "y": 17, - "w": 86, - "h": 73 - }, - "frame": { - "x": 336, - "y": 284, - "w": 86, - "h": 73 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 80, - "h": 74 - }, - "frame": { - "x": 422, - "y": 292, - "w": 80, - "h": 74 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 80, - "h": 74 - }, - "frame": { - "x": 422, - "y": 292, - "w": 80, - "h": 74 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 79, - "h": 74 - }, - "frame": { - "x": 0, - "y": 349, - "w": 79, - "h": 74 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 79, - "h": 74 - }, - "frame": { - "x": 0, - "y": 349, - "w": 79, - "h": 74 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 80, - "h": 74 - }, - "frame": { - "x": 79, - "y": 352, - "w": 80, - "h": 74 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 80, - "h": 74 - }, - "frame": { - "x": 79, - "y": 352, - "w": 80, - "h": 74 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 2, - "y": 15, - "w": 83, - "h": 75 - }, - "frame": { - "x": 159, - "y": 353, - "w": 83, - "h": 75 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 2, - "y": 15, - "w": 83, - "h": 75 - }, - "frame": { - "x": 159, - "y": 353, - "w": 83, - "h": 75 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 2, - "y": 15, - "w": 83, - "h": 75 - }, - "frame": { - "x": 159, - "y": 353, - "w": 83, - "h": 75 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 4, - "y": 15, - "w": 81, - "h": 75 - }, - "frame": { - "x": 242, - "y": 357, - "w": 81, - "h": 75 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 4, - "y": 15, - "w": 81, - "h": 75 - }, - "frame": { - "x": 242, - "y": 357, - "w": 81, - "h": 75 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 4, - "y": 15, - "w": 81, - "h": 75 - }, - "frame": { - "x": 242, - "y": 357, - "w": 81, - "h": 75 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 4, - "y": 15, - "w": 81, - "h": 75 - }, - "frame": { - "x": 323, - "y": 357, - "w": 81, - "h": 75 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 4, - "y": 15, - "w": 81, - "h": 75 - }, - "frame": { - "x": 323, - "y": 357, - "w": 81, - "h": 75 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 4, - "y": 15, - "w": 81, - "h": 75 - }, - "frame": { - "x": 323, - "y": 357, - "w": 81, - "h": 75 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 4, - "y": 15, - "w": 82, - "h": 75 - }, - "frame": { - "x": 404, - "y": 366, - "w": 82, - "h": 75 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 4, - "y": 15, - "w": 82, - "h": 75 - }, - "frame": { - "x": 404, - "y": 366, - "w": 82, - "h": 75 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 4, - "y": 15, - "w": 82, - "h": 75 - }, - "frame": { - "x": 404, - "y": 366, - "w": 82, - "h": 75 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 79, - "h": 75 - }, - "frame": { - "x": 0, - "y": 423, - "w": 79, - "h": 75 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 79, - "h": 75 - }, - "frame": { - "x": 0, - "y": 423, - "w": 79, - "h": 75 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 78, - "h": 75 - }, - "frame": { - "x": 79, - "y": 426, - "w": 78, - "h": 75 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 78, - "h": 75 - }, - "frame": { - "x": 79, - "y": 426, - "w": 78, - "h": 75 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 2, - "y": 15, - "w": 85, - "h": 75 - }, - "frame": { - "x": 157, - "y": 428, - "w": 85, - "h": 75 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 5, - "y": 14, - "w": 79, - "h": 76 - }, - "frame": { - "x": 242, - "y": 432, - "w": 79, - "h": 76 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 5, - "y": 14, - "w": 79, - "h": 76 - }, - "frame": { - "x": 242, - "y": 432, - "w": 79, - "h": 76 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 5, - "y": 14, - "w": 79, - "h": 76 - }, - "frame": { - "x": 242, - "y": 432, - "w": 79, - "h": 76 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:62a4a665074efb5def1545546995dc5b:de2788ebeab6b42f331926f332da5125:d60cc2e5ae2bd18de8ee3ab0649593ee$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/6706_2.png b/public/images/pokemon/variant/exp/6706_2.png deleted file mode 100644 index 7e7dfa8e05a..00000000000 Binary files a/public/images/pokemon/variant/exp/6706_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/6706_3.json b/public/images/pokemon/variant/exp/6706_3.json deleted file mode 100644 index 8c9b16b80ab..00000000000 --- a/public/images/pokemon/variant/exp/6706_3.json +++ /dev/null @@ -1,2015 +0,0 @@ -{ - "textures": [ - { - "image": "6706_3.png", - "format": "RGBA8888", - "size": { - "w": 508, - "h": 508 - }, - "scale": 1, - "frames": [ - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 28, - "y": 26, - "w": 59, - "h": 61 - }, - "frame": { - "x": 0, - "y": 0, - "w": 59, - "h": 61 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 26, - "y": 25, - "w": 56, - "h": 63 - }, - "frame": { - "x": 59, - "y": 0, - "w": 56, - "h": 63 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 26, - "y": 25, - "w": 56, - "h": 63 - }, - "frame": { - "x": 59, - "y": 0, - "w": 56, - "h": 63 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 28, - "y": 21, - "w": 53, - "h": 65 - }, - "frame": { - "x": 115, - "y": 0, - "w": 53, - "h": 65 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 28, - "y": 21, - "w": 53, - "h": 65 - }, - "frame": { - "x": 115, - "y": 0, - "w": 53, - "h": 65 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 29, - "y": 21, - "w": 54, - "h": 65 - }, - "frame": { - "x": 168, - "y": 0, - "w": 54, - "h": 65 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 29, - "y": 21, - "w": 54, - "h": 65 - }, - "frame": { - "x": 168, - "y": 0, - "w": 54, - "h": 65 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 28, - "y": 21, - "w": 53, - "h": 65 - }, - "frame": { - "x": 222, - "y": 0, - "w": 53, - "h": 65 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 28, - "y": 21, - "w": 53, - "h": 65 - }, - "frame": { - "x": 222, - "y": 0, - "w": 53, - "h": 65 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 25, - "y": 21, - "w": 55, - "h": 66 - }, - "frame": { - "x": 275, - "y": 0, - "w": 55, - "h": 66 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 25, - "y": 21, - "w": 55, - "h": 66 - }, - "frame": { - "x": 275, - "y": 0, - "w": 55, - "h": 66 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 23, - "y": 23, - "w": 54, - "h": 66 - }, - "frame": { - "x": 330, - "y": 0, - "w": 54, - "h": 66 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 23, - "y": 23, - "w": 54, - "h": 66 - }, - "frame": { - "x": 330, - "y": 0, - "w": 54, - "h": 66 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 25, - "y": 21, - "w": 54, - "h": 67 - }, - "frame": { - "x": 384, - "y": 0, - "w": 54, - "h": 67 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 25, - "y": 21, - "w": 54, - "h": 67 - }, - "frame": { - "x": 384, - "y": 0, - "w": 54, - "h": 67 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 23, - "y": 21, - "w": 52, - "h": 68 - }, - "frame": { - "x": 438, - "y": 0, - "w": 52, - "h": 68 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 23, - "y": 21, - "w": 52, - "h": 68 - }, - "frame": { - "x": 438, - "y": 0, - "w": 52, - "h": 68 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 21, - "y": 21, - "w": 53, - "h": 68 - }, - "frame": { - "x": 0, - "y": 61, - "w": 53, - "h": 68 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 21, - "y": 21, - "w": 53, - "h": 68 - }, - "frame": { - "x": 0, - "y": 61, - "w": 53, - "h": 68 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 18, - "y": 22, - "w": 52, - "h": 68 - }, - "frame": { - "x": 53, - "y": 63, - "w": 52, - "h": 68 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 18, - "y": 22, - "w": 52, - "h": 68 - }, - "frame": { - "x": 53, - "y": 63, - "w": 52, - "h": 68 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 19, - "y": 21, - "w": 55, - "h": 69 - }, - "frame": { - "x": 105, - "y": 65, - "w": 55, - "h": 69 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 19, - "y": 21, - "w": 55, - "h": 69 - }, - "frame": { - "x": 105, - "y": 65, - "w": 55, - "h": 69 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 21, - "y": 21, - "w": 53, - "h": 69 - }, - "frame": { - "x": 160, - "y": 65, - "w": 53, - "h": 69 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 21, - "y": 21, - "w": 53, - "h": 69 - }, - "frame": { - "x": 160, - "y": 65, - "w": 53, - "h": 69 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 16, - "y": 21, - "w": 53, - "h": 69 - }, - "frame": { - "x": 213, - "y": 65, - "w": 53, - "h": 69 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 16, - "y": 21, - "w": 53, - "h": 69 - }, - "frame": { - "x": 213, - "y": 65, - "w": 53, - "h": 69 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 15, - "y": 21, - "w": 52, - "h": 70 - }, - "frame": { - "x": 266, - "y": 66, - "w": 52, - "h": 70 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 15, - "y": 21, - "w": 52, - "h": 70 - }, - "frame": { - "x": 266, - "y": 66, - "w": 52, - "h": 70 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 19, - "w": 87, - "h": 71 - }, - "frame": { - "x": 318, - "y": 67, - "w": 87, - "h": 71 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 19, - "w": 87, - "h": 71 - }, - "frame": { - "x": 318, - "y": 67, - "w": 87, - "h": 71 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 19, - "w": 87, - "h": 71 - }, - "frame": { - "x": 318, - "y": 67, - "w": 87, - "h": 71 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 0, - "y": 18, - "w": 87, - "h": 71 - }, - "frame": { - "x": 405, - "y": 68, - "w": 87, - "h": 71 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 2, - "y": 19, - "w": 86, - "h": 72 - }, - "frame": { - "x": 0, - "y": 131, - "w": 86, - "h": 72 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 19, - "w": 87, - "h": 72 - }, - "frame": { - "x": 86, - "y": 134, - "w": 87, - "h": 72 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 87, - "h": 72 - }, - "frame": { - "x": 86, - "y": 134, - "w": 87, - "h": 72 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 87, - "h": 72 - }, - "frame": { - "x": 86, - "y": 134, - "w": 87, - "h": 72 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 19, - "w": 87, - "h": 72 - }, - "frame": { - "x": 173, - "y": 134, - "w": 87, - "h": 72 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 87, - "h": 72 - }, - "frame": { - "x": 173, - "y": 134, - "w": 87, - "h": 72 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 87, - "h": 72 - }, - "frame": { - "x": 173, - "y": 134, - "w": 87, - "h": 72 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 87, - "h": 72 - }, - "frame": { - "x": 260, - "y": 138, - "w": 87, - "h": 72 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 87, - "h": 72 - }, - "frame": { - "x": 260, - "y": 138, - "w": 87, - "h": 72 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 87, - "h": 72 - }, - "frame": { - "x": 260, - "y": 138, - "w": 87, - "h": 72 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 87, - "h": 72 - }, - "frame": { - "x": 347, - "y": 139, - "w": 87, - "h": 72 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 87, - "h": 72 - }, - "frame": { - "x": 347, - "y": 139, - "w": 87, - "h": 72 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 18, - "w": 87, - "h": 72 - }, - "frame": { - "x": 347, - "y": 139, - "w": 87, - "h": 72 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 5, - "y": 5, - "w": 74, - "h": 80 - }, - "frame": { - "x": 434, - "y": 139, - "w": 74, - "h": 80 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 5, - "y": 5, - "w": 74, - "h": 80 - }, - "frame": { - "x": 434, - "y": 139, - "w": 74, - "h": 80 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 2, - "y": 17, - "w": 85, - "h": 72 - }, - "frame": { - "x": 0, - "y": 203, - "w": 85, - "h": 72 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 3, - "y": 13, - "w": 83, - "h": 72 - }, - "frame": { - "x": 85, - "y": 206, - "w": 83, - "h": 72 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 3, - "y": 18, - "w": 84, - "h": 73 - }, - "frame": { - "x": 168, - "y": 206, - "w": 84, - "h": 73 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 2, - "y": 17, - "w": 85, - "h": 73 - }, - "frame": { - "x": 252, - "y": 210, - "w": 85, - "h": 73 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 86, - "h": 73 - }, - "frame": { - "x": 337, - "y": 211, - "w": 86, - "h": 73 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 86, - "h": 73 - }, - "frame": { - "x": 337, - "y": 211, - "w": 86, - "h": 73 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 17, - "w": 86, - "h": 73 - }, - "frame": { - "x": 337, - "y": 211, - "w": 86, - "h": 73 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 2, - "y": 17, - "w": 85, - "h": 73 - }, - "frame": { - "x": 423, - "y": 219, - "w": 85, - "h": 73 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 2, - "y": 17, - "w": 85, - "h": 73 - }, - "frame": { - "x": 423, - "y": 219, - "w": 85, - "h": 73 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 16, - "w": 85, - "h": 74 - }, - "frame": { - "x": 0, - "y": 275, - "w": 85, - "h": 74 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 16, - "w": 85, - "h": 74 - }, - "frame": { - "x": 0, - "y": 275, - "w": 85, - "h": 74 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 1, - "y": 16, - "w": 85, - "h": 74 - }, - "frame": { - "x": 0, - "y": 275, - "w": 85, - "h": 74 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 0, - "y": 17, - "w": 86, - "h": 73 - }, - "frame": { - "x": 85, - "y": 279, - "w": 86, - "h": 73 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 0, - "y": 17, - "w": 86, - "h": 73 - }, - "frame": { - "x": 85, - "y": 279, - "w": 86, - "h": 73 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 0, - "y": 17, - "w": 86, - "h": 73 - }, - "frame": { - "x": 85, - "y": 279, - "w": 86, - "h": 73 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 3, - "y": 4, - "w": 81, - "h": 74 - }, - "frame": { - "x": 171, - "y": 279, - "w": 81, - "h": 74 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 3, - "y": 4, - "w": 81, - "h": 74 - }, - "frame": { - "x": 171, - "y": 279, - "w": 81, - "h": 74 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 3, - "y": 16, - "w": 84, - "h": 74 - }, - "frame": { - "x": 252, - "y": 283, - "w": 84, - "h": 74 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 3, - "y": 16, - "w": 84, - "h": 74 - }, - "frame": { - "x": 252, - "y": 283, - "w": 84, - "h": 74 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 2, - "y": 17, - "w": 86, - "h": 73 - }, - "frame": { - "x": 336, - "y": 284, - "w": 86, - "h": 73 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 2, - "y": 17, - "w": 86, - "h": 73 - }, - "frame": { - "x": 336, - "y": 284, - "w": 86, - "h": 73 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 80, - "h": 74 - }, - "frame": { - "x": 422, - "y": 292, - "w": 80, - "h": 74 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 80, - "h": 74 - }, - "frame": { - "x": 422, - "y": 292, - "w": 80, - "h": 74 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 79, - "h": 74 - }, - "frame": { - "x": 0, - "y": 349, - "w": 79, - "h": 74 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 79, - "h": 74 - }, - "frame": { - "x": 0, - "y": 349, - "w": 79, - "h": 74 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 80, - "h": 74 - }, - "frame": { - "x": 79, - "y": 352, - "w": 80, - "h": 74 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 80, - "h": 74 - }, - "frame": { - "x": 79, - "y": 352, - "w": 80, - "h": 74 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 2, - "y": 15, - "w": 83, - "h": 75 - }, - "frame": { - "x": 159, - "y": 353, - "w": 83, - "h": 75 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 2, - "y": 15, - "w": 83, - "h": 75 - }, - "frame": { - "x": 159, - "y": 353, - "w": 83, - "h": 75 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 2, - "y": 15, - "w": 83, - "h": 75 - }, - "frame": { - "x": 159, - "y": 353, - "w": 83, - "h": 75 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 4, - "y": 15, - "w": 81, - "h": 75 - }, - "frame": { - "x": 242, - "y": 357, - "w": 81, - "h": 75 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 4, - "y": 15, - "w": 81, - "h": 75 - }, - "frame": { - "x": 242, - "y": 357, - "w": 81, - "h": 75 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 4, - "y": 15, - "w": 81, - "h": 75 - }, - "frame": { - "x": 242, - "y": 357, - "w": 81, - "h": 75 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 4, - "y": 15, - "w": 81, - "h": 75 - }, - "frame": { - "x": 323, - "y": 357, - "w": 81, - "h": 75 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 4, - "y": 15, - "w": 81, - "h": 75 - }, - "frame": { - "x": 323, - "y": 357, - "w": 81, - "h": 75 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 4, - "y": 15, - "w": 81, - "h": 75 - }, - "frame": { - "x": 323, - "y": 357, - "w": 81, - "h": 75 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 4, - "y": 15, - "w": 82, - "h": 75 - }, - "frame": { - "x": 404, - "y": 366, - "w": 82, - "h": 75 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 4, - "y": 15, - "w": 82, - "h": 75 - }, - "frame": { - "x": 404, - "y": 366, - "w": 82, - "h": 75 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 4, - "y": 15, - "w": 82, - "h": 75 - }, - "frame": { - "x": 404, - "y": 366, - "w": 82, - "h": 75 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 79, - "h": 75 - }, - "frame": { - "x": 0, - "y": 423, - "w": 79, - "h": 75 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 79, - "h": 75 - }, - "frame": { - "x": 0, - "y": 423, - "w": 79, - "h": 75 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 78, - "h": 75 - }, - "frame": { - "x": 79, - "y": 426, - "w": 78, - "h": 75 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 78, - "h": 75 - }, - "frame": { - "x": 79, - "y": 426, - "w": 78, - "h": 75 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 2, - "y": 15, - "w": 85, - "h": 75 - }, - "frame": { - "x": 157, - "y": 428, - "w": 85, - "h": 75 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 5, - "y": 14, - "w": 79, - "h": 76 - }, - "frame": { - "x": 242, - "y": 432, - "w": 79, - "h": 76 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 5, - "y": 14, - "w": 79, - "h": 76 - }, - "frame": { - "x": 242, - "y": 432, - "w": 79, - "h": 76 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 88, - "h": 91 - }, - "spriteSourceSize": { - "x": 5, - "y": 14, - "w": 79, - "h": 76 - }, - "frame": { - "x": 242, - "y": 432, - "w": 79, - "h": 76 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:62a4a665074efb5def1545546995dc5b:de2788ebeab6b42f331926f332da5125:d60cc2e5ae2bd18de8ee3ab0649593ee$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/6706_3.png b/public/images/pokemon/variant/exp/6706_3.png deleted file mode 100644 index 3ad44f4bbf5..00000000000 Binary files a/public/images/pokemon/variant/exp/6706_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/676.json b/public/images/pokemon/variant/exp/676.json new file mode 100644 index 00000000000..d5ec3013e8e --- /dev/null +++ b/public/images/pokemon/variant/exp/676.json @@ -0,0 +1,22 @@ +{ + "1": { + "a8a592": "42090e", + "376277": "2b040f", + "ccc8b1": "5e0f16", + "59463c": "aaaec1", + "97362c": "a83c31", + "68675c": "2b040f", + "fc362c": "cc2929", + "efeeda": "8a1d1d" + }, + "2": { + "a8a592": "805145", + "376277": "4a281b", + "ccc8b1": "a4624a", + "59463c": "ffe6ac", + "97362c": "3a240e", + "68675c": "4a281b", + "fc362c": "50351b", + "efeeda": "c18960" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/682.json b/public/images/pokemon/variant/exp/682.json new file mode 100644 index 00000000000..a8a7caf46b1 --- /dev/null +++ b/public/images/pokemon/variant/exp/682.json @@ -0,0 +1,28 @@ +{ + "1": { + "661f1f": "cd6132", + "bf5f9f": "7c48a1", + "ff99b3": "48ab61", + "f24949": "ffa24f", + "6b3962": "30185d", + "993d80": "4f297e", + "ffb6c2": "62c45f", + "7f4d59": "20644e", + "cc7087": "318759" + }, + "2": { + "661f1f": "daa235", + "bf5f9f": "f0ebdd", + "ff99b3": "da7e29", + "a6a6a6": "503851", + "737373": "422f46", + "f24949": "ffe664", + "6b3962": "b89477", + "993d80": "d2bfa1", + "ffb6c2": "ed9f3a", + "e5e5e5": "6b4767", + "7f4d59": "a23812", + "4d4d4d": "332539", + "cc7087": "c3561a" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/683.json b/public/images/pokemon/variant/exp/683.json new file mode 100644 index 00000000000..f9485702936 --- /dev/null +++ b/public/images/pokemon/variant/exp/683.json @@ -0,0 +1,32 @@ +{ + "1": { + "661f1f": "b64d29", + "cc7087": "318759", + "ff99b3": "48ab61", + "fff0a6": "fec04b", + "f24949": "ffa24f", + "6b3962": "30185d", + "e5c37e": "d6872c", + "993d80": "4f297e", + "7f4d59": "20644e", + "404040": "2c283b", + "b33636": "f4863f", + "bf5f9f": "7c48a1" + }, + "2": { + "661f1f": "c78925", + "cc7087": "c3561a", + "ff99b3": "da7e29", + "fff0a6": "6d8719", + "e5e5e5": "6b4767", + "f24949": "ffe664", + "6b3962": "b89477", + "e5c37e": "376d11", + "993d80": "d2bfa1", + "7f4d59": "a23812", + "a6a6a6": "503851", + "404040": "2a2234", + "b33636": "f0c150", + "bf5f9f": "f0ebdd" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/684.json b/public/images/pokemon/variant/exp/684.json new file mode 100644 index 00000000000..fb88bb28c70 --- /dev/null +++ b/public/images/pokemon/variant/exp/684.json @@ -0,0 +1,30 @@ +{ + "1": { + "805963": "2d0c42", + "553a41": "8f1d15", + "661a2d": "13391c", + "e53964": "8dbe6d", + "ffccd9": "8961c6", + "5e4048": "260b37", + "cc99a6": "613b84", + "f8f8f8": "caff90", + "fff2f2": "f39f62", + "a62949": "689b52", + "7b5760": "b13924", + "ccadad": "df6b40" + }, + "2": { + "805963": "6796aa", + "553a41": "1d1426", + "661a2d": "26061b", + "e53964": "8c4264", + "ffccd9": "cbf6da", + "5e4048": "52718e", + "cc99a6": "93d6ce", + "f8f8f8": "ffe5ec", + "fff2f2": "746998", + "a62949": "612747", + "7b5760": "3c2f51", + "ccadad": "4b4876" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/685.json b/public/images/pokemon/variant/exp/685.json new file mode 100644 index 00000000000..24ead59428a --- /dev/null +++ b/public/images/pokemon/variant/exp/685.json @@ -0,0 +1,28 @@ +{ + "1": { + "f8f8f8": "caff90", + "661a2d": "13391c", + "7b5760": "b13924", + "ffccd9": "8961c6", + "ff8ca9": "8dbe6d", + "cc99a6": "613b84", + "e53964": "689b52", + "fff2f2": "f39f62", + "a62949": "26592b", + "ccadad": "df6b40", + "805963": "2d0c42" + }, + "2": { + "f8f8f8": "e4819d", + "661a2d": "26061b", + "7b5760": "3c2f51", + "ffccd9": "cbf6da", + "ff8ca9": "8c4264", + "cc99a6": "93d6ce", + "e53964": "612747", + "fff2f2": "746998", + "a62949": "441838", + "ccadad": "4b4876", + "805963": "52718e" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/688.json b/public/images/pokemon/variant/exp/688.json new file mode 100644 index 00000000000..e5749f6bb3f --- /dev/null +++ b/public/images/pokemon/variant/exp/688.json @@ -0,0 +1,33 @@ +{ + "1": { + "5890b0": "a9582e", + "385860": "70240f", + "372e27": "220a56", + "6b503b": "373295", + "d0d0d0": "d3bc8c", + "c0e0e8": "e8d37b", + "8a6d45": "4557b5", + "101010": "37160a", + "b7653f": "459aac", + "fcffff": "e8e5c6", + "808080": "7c582e", + "88c0c8": "cd8a50", + "ef8955": "70cccf" + }, + "2": { + "5890b0": "4b0038", + "385860": "2c052a", + "372e27": "1e1324", + "6b503b": "ba9fba", + "d0d0d0": "7eac4e", + "c0e0e8": "a74083", + "8a6d45": "f6eefc", + "101010": "0a391b", + "b7653f": "332149", + "fcffff": "caea77", + "f8f8f8": "ffffff", + "808080": "2a5524", + "88c0c8": "731f5c", + "ef8955": "4a376e" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/689.json b/public/images/pokemon/variant/exp/689.json new file mode 100644 index 00000000000..cd6db09c8d2 --- /dev/null +++ b/public/images/pokemon/variant/exp/689.json @@ -0,0 +1,31 @@ +{ + "1": { + "bfeaff": "e8d37b", + "f2f2f2": "e8e5c6", + "5b8da6": "8d5030", + "595959": "7c582e", + "403410": "220a56", + "3f6273": "672e1e", + "b3b3b3": "d3bc8c", + "cc7f70": "459aac", + "85b4cc": "cd8a50", + "ff9f8c": "70cccf", + "66541f": "373295", + "997e2e": "4557b5" + }, + "2": { + "bfeaff": "a74083", + "f2f2f2": "caea77", + "5b8da6": "4b0038", + "595959": "2a5524", + "403410": "3f2a4b", + "3f6273": "3e073b", + "b3b3b3": "7eac4e", + "cc7f70": "332149", + "85b4cc": "731f5c", + "f8f8f8": "dbaf67", + "ff9f8c": "4a376e", + "66541f": "ccb6cc", + "997e2e": "f6eefc" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/696.json b/public/images/pokemon/variant/exp/696.json index 6522379fc3b..3a4b4480673 100644 --- a/public/images/pokemon/variant/exp/696.json +++ b/public/images/pokemon/variant/exp/696.json @@ -1,21 +1,53 @@ { "1": { - "774411": "5e0b0b", - "101010": "101010", - "ff8f1f": "a50d0d", - "4f2f1f": "023425", - "5f4f4f": "0b4c29", - "af8f7f": "478136", - "3f3f44": "4c3216", - "8f6f5f": "1b6430", - "f8f7f9": "dfdea7", - "77440f": "5e0b0b", - "bfbfcc": "cbbe8c", - "ff8f1d": "a50d0d", - "0c0c0c": "0c0c0c", - "4f2e1d": "4f2e1d", - "8f8f99": "ad8c63", - "772d34": "77452d", - "ff9bd5": "c98c68" + "774411":"5e0b0b", + "101010":"101010", + "ff8f1f":"a50d0d", + "4f2e1d":"023425", + "5f4f4f":"0b4c29", + "af8f7f":"478136", + "3f3f44":"4c3216", + "8f6f5f":"1b6430", + "f8f7f9":"dfdea7", + "bfbfcc":"cbbe8c", + "121212":"121212", + "8f8f99":"ad8c63", + "c2c2cf":"c9bc87", + "fbfafc":"dddca1", + "772d34":"77452d", + "ff9bd5":"c98c68" + }, + "2": { + "774411":"395cb7", + "101010":"101010", + "ff8f1f":"d2e9ff", + "4f2e1d":"3e1f18", + "5f4f4f":"644943", + "af8f7f":"a59e9a", + "3f3f44":"250860", + "8f6f5f":"83726e", + "f8f7f9":"6e46a7", + "bfbfcc":"593097", + "121212":"decaff", + "8f8f99":"411684", + "c2c2cf":"7ccad5", + "fbfafc":"fbfafc", + "772d34":"375ab3", + "ff9bd5":"79c8d3" } -} \ No newline at end of file +} + + + + + + + + + + + + + + + diff --git a/public/images/pokemon/variant/exp/697.json b/public/images/pokemon/variant/exp/697.json index 21034cbcf1f..dae4554a1b7 100644 --- a/public/images/pokemon/variant/exp/697.json +++ b/public/images/pokemon/variant/exp/697.json @@ -1,18 +1,45 @@ { "1": { - "756b66": "ad8c63", - "653510": "5e0b0b", - "e39f33": "b52424", - "f0f0f2": "dfdea7", - "471515": "0a1b17", - "1f0a0a": "080808", - "b56726": "971c1c", - "b1b0b5": "cbbe8c", - "b45250": "285234", - "621e1d": "0b241e", - "902e2c": "153626", - "d16c6b": "416a45", - "573b43": "4c3216", - "ac628a": "9d5d18" + "1f0a0a":"1f0a0a", + "471515":"0a1b17", + "621e1d":"0b241e", + "902e2c":"153626", + "b45250":"285234", + "d16c6b":"416a45", + "653510":"5e0b0b", + "b56726":"971c1c", + "e39f33":"b52424", + "756b66":"ad8c63", + "b1b0b5":"cbbe8c", + "f0f0f2":"dfdea7", + "573b43":"4c3216", + "736964":"ab885f", + "ac628a":"9d5d18", + "aeadb3":"a88860", + "ededf0":"dbdaa4" + }, + "2": { + "1f0a0a":"1f0a0a", + "471515":"191124", + "621e1d":"52352f", + "902e2c":"83726e", + "b45250":"ab9b97", + "d16c6b":"c7bcb9", + "653510":"9d5390", + "b56726":"ce7ecc", + "e39f33":"f4dbf6", + "756b66":"26173b", + "b1b0b5":"33214f", + "f0f0f2":"4b2e64", + "573b43":"cc7cc9", + "736964":"f6dcf7", + "ac628a":"eed5f0", + "aeadb3":"c779c4", + "ededf0":"f8defa" } -} \ No newline at end of file +} + + + + + diff --git a/public/images/pokemon/variant/exp/705.json b/public/images/pokemon/variant/exp/705.json new file mode 100644 index 00000000000..a29b8f124dc --- /dev/null +++ b/public/images/pokemon/variant/exp/705.json @@ -0,0 +1,33 @@ +{ + "1": { + "101010":"101010", + "4d454d":"8a2166", + "807380":"b93f84", + "bfacbf":"e56ca6", + "f2daf2":"fbb3d2", + "665980":"4e4094", + "8f7db3":"8b69c3", + "b8a1e5":"c7a1e5", + "4d993d":"aa6a00", + "66cc52":"ffd047", + "4e9c3e":"0c5474", + "67cf53":"3aa8c4", + "b6f2aa":"63cee1" + }, + "2": { + "101010":"101010", + "4d454d":"194f51", + "807380":"2b736f", + "bfacbf":"5db6a9", + "f2daf2":"9cead8", + "665980":"274159", + "8f7db3":"2f667c", + "b8a1e5":"4a9699", + "4d993d":"007d61", + "66cc52":"49ffbf", + "4e9c3e":"842401", + "67cf53":"a34205", + "b6f2aa":"d27e26" + } +} + diff --git a/public/images/pokemon/variant/exp/705_2.json b/public/images/pokemon/variant/exp/705_2.json deleted file mode 100644 index bf9fd104c5d..00000000000 --- a/public/images/pokemon/variant/exp/705_2.json +++ /dev/null @@ -1,272 +0,0 @@ -{ - "textures": [ - { - "image": "705_2.png", - "format": "RGBA8888", - "size": { - "w": 154, - "h": 154 - }, - "scale": 1, - "frames": [ - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 49, - "h": 58 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 46, - "h": 58 - }, - "frame": { - "x": 0, - "y": 0, - "w": 46, - "h": 58 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 49, - "h": 58 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 46, - "h": 58 - }, - "frame": { - "x": 0, - "y": 0, - "w": 46, - "h": 58 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 49, - "h": 58 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 45, - "h": 58 - }, - "frame": { - "x": 46, - "y": 0, - "w": 45, - "h": 58 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 49, - "h": 58 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 45, - "h": 58 - }, - "frame": { - "x": 46, - "y": 0, - "w": 45, - "h": 58 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 49, - "h": 58 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 45, - "h": 58 - }, - "frame": { - "x": 91, - "y": 0, - "w": 45, - "h": 58 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 49, - "h": 58 - }, - "spriteSourceSize": { - "x": 1, - "y": 0, - "w": 42, - "h": 58 - }, - "frame": { - "x": 0, - "y": 58, - "w": 42, - "h": 58 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 49, - "h": 58 - }, - "spriteSourceSize": { - "x": 1, - "y": 0, - "w": 42, - "h": 58 - }, - "frame": { - "x": 0, - "y": 58, - "w": 42, - "h": 58 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 49, - "h": 58 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 41, - "h": 58 - }, - "frame": { - "x": 42, - "y": 58, - "w": 41, - "h": 58 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 49, - "h": 58 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 41, - "h": 58 - }, - "frame": { - "x": 42, - "y": 58, - "w": 41, - "h": 58 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 49, - "h": 58 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 36, - "h": 58 - }, - "frame": { - "x": 83, - "y": 58, - "w": 36, - "h": 58 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 49, - "h": 58 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 36, - "h": 58 - }, - "frame": { - "x": 83, - "y": 58, - "w": 36, - "h": 58 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 49, - "h": 58 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 35, - "h": 58 - }, - "frame": { - "x": 119, - "y": 58, - "w": 35, - "h": 58 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:4bf155254b23c88780e7eee282256589:82bb727988054c3064e203b6908ff464:6b57e983626c7fc9144ab67f30c66814$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/705_2.png b/public/images/pokemon/variant/exp/705_2.png deleted file mode 100644 index 8256ebc7fdb..00000000000 Binary files a/public/images/pokemon/variant/exp/705_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/705_3.json b/public/images/pokemon/variant/exp/705_3.json deleted file mode 100644 index 199d7bc9c3e..00000000000 --- a/public/images/pokemon/variant/exp/705_3.json +++ /dev/null @@ -1,272 +0,0 @@ -{ - "textures": [ - { - "image": "705_3.png", - "format": "RGBA8888", - "size": { - "w": 154, - "h": 154 - }, - "scale": 1, - "frames": [ - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 49, - "h": 58 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 46, - "h": 58 - }, - "frame": { - "x": 0, - "y": 0, - "w": 46, - "h": 58 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 49, - "h": 58 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 46, - "h": 58 - }, - "frame": { - "x": 0, - "y": 0, - "w": 46, - "h": 58 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 49, - "h": 58 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 45, - "h": 58 - }, - "frame": { - "x": 46, - "y": 0, - "w": 45, - "h": 58 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 49, - "h": 58 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 45, - "h": 58 - }, - "frame": { - "x": 46, - "y": 0, - "w": 45, - "h": 58 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 49, - "h": 58 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 45, - "h": 58 - }, - "frame": { - "x": 91, - "y": 0, - "w": 45, - "h": 58 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 49, - "h": 58 - }, - "spriteSourceSize": { - "x": 1, - "y": 0, - "w": 42, - "h": 58 - }, - "frame": { - "x": 0, - "y": 58, - "w": 42, - "h": 58 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 49, - "h": 58 - }, - "spriteSourceSize": { - "x": 1, - "y": 0, - "w": 42, - "h": 58 - }, - "frame": { - "x": 0, - "y": 58, - "w": 42, - "h": 58 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 49, - "h": 58 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 41, - "h": 58 - }, - "frame": { - "x": 42, - "y": 58, - "w": 41, - "h": 58 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 49, - "h": 58 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 41, - "h": 58 - }, - "frame": { - "x": 42, - "y": 58, - "w": 41, - "h": 58 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 49, - "h": 58 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 36, - "h": 58 - }, - "frame": { - "x": 83, - "y": 58, - "w": 36, - "h": 58 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 49, - "h": 58 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 36, - "h": 58 - }, - "frame": { - "x": 83, - "y": 58, - "w": 36, - "h": 58 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 49, - "h": 58 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 35, - "h": 58 - }, - "frame": { - "x": 119, - "y": 58, - "w": 35, - "h": 58 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:4bf155254b23c88780e7eee282256589:82bb727988054c3064e203b6908ff464:6b57e983626c7fc9144ab67f30c66814$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/705_3.png b/public/images/pokemon/variant/exp/705_3.png deleted file mode 100644 index 66b43956bdf..00000000000 Binary files a/public/images/pokemon/variant/exp/705_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-bug.json b/public/images/pokemon/variant/exp/773-bug.json new file mode 100644 index 00000000000..963111d6c63 --- /dev/null +++ b/public/images/pokemon/variant/exp/773-bug.json @@ -0,0 +1,44 @@ +{ + "1": { + "297321": "267763", + "73c957": "73c956", + "e3e6ec": "bdd1e5", + "483c39": "3a2d53", + "41ac36": "44b3aa", + "b7e586": "f4ff9c", + "0073bf": "7a4949", + "565969": "30365c", + "73c956": "99d569", + "251845": "753c32", + "bcbbc5": "788fb5", + "9618e0": "dc9c4d", + "125d4b": "ce7f3f", + "e64f5e": "f1944a", + "1e9378": "f8ce64", + "5399df": "b59489", + "3f3b50": "1e172a", + "aba7bc": "493d55", + "79615e": "504a75" + }, + "2": { + "297321": "3d5542", + "73c957": "73c956", + "e3e6ec": "444455", + "483c39": "778894", + "41ac36": "92d374", + "b7e586": "ababab", + "0073bf": "6a6c75", + "565969": "0f0f1b", + "1d1845": "41434e", + "73c956": "e7eef2", + "251845": "3d5542", + "bcbbc5": "242433", + "9618e0": "ade265", + "125d4b": "317e27", + "e64f5e": "98ce58", + "1e9378": "73c956", + "5399df": "92949e", + "aba7bc": "dbd8e8", + "79615e": "d6d4d4" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-bug_2.json b/public/images/pokemon/variant/exp/773-bug_2.json deleted file mode 100644 index b8c856e7671..00000000000 --- a/public/images/pokemon/variant/exp/773-bug_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-bug_2.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:e2907473475c1192913e48eb8ab5755a:427e3f500215054e2d2989f4755f229b:1786a671c3b9676c87853a0a70567554$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-bug_2.png b/public/images/pokemon/variant/exp/773-bug_2.png deleted file mode 100644 index 95c5b7071d8..00000000000 Binary files a/public/images/pokemon/variant/exp/773-bug_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-bug_3.json b/public/images/pokemon/variant/exp/773-bug_3.json deleted file mode 100644 index 8a6fd45ca56..00000000000 --- a/public/images/pokemon/variant/exp/773-bug_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-bug_3.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:e2907473475c1192913e48eb8ab5755a:427e3f500215054e2d2989f4755f229b:1786a671c3b9676c87853a0a70567554$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-bug_3.png b/public/images/pokemon/variant/exp/773-bug_3.png deleted file mode 100644 index d274170f676..00000000000 Binary files a/public/images/pokemon/variant/exp/773-bug_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-dark.json b/public/images/pokemon/variant/exp/773-dark.json new file mode 100644 index 00000000000..af86da38211 --- /dev/null +++ b/public/images/pokemon/variant/exp/773-dark.json @@ -0,0 +1,45 @@ +{ + "1": { + "574646": "735c5c", + "79615e": "504a75", + "aba7bc": "493d55", + "3f3b50": "1e172a", + "332327": "512351", + "bcbbc5": "788fb5", + "483c39": "3a2d53", + "e3e6ec": "bdd1e5", + "e64f5e": "f1944a", + "565969": "30365c", + "5399df": "b59489", + "574647": "655454", + "9618e0": "dc9c4d", + "1d1845": "2e191f", + "1e9378": "f8ce64", + "125d4b": "ce7f3f", + "8a7d7a": "dcc0b2", + "251845": "753c32", + "0073bf": "7a4949", + "21151a": "250d25" + }, + "2": { + "574646": "f0f7fb", + "79615e": "d6d4d4", + "aba7bc": "dbd8e8", + "332327": "f2cc45", + "bcbbc5": "242433", + "483c39": "778894", + "e3e6ec": "444455", + "e64f5e": "98ce58", + "565969": "0f0f1b", + "5399df": "92949e", + "574647": "574646", + "9618e0": "ade265", + "1d1845": "41434e", + "1e9378": "574646", + "125d4b": "3b282a", + "8a7d7a": "9360c8", + "251845": "425735", + "0073bf": "6a6c75", + "21151a": "494057" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-dark_2.json b/public/images/pokemon/variant/exp/773-dark_2.json deleted file mode 100644 index 8c55fe0e56b..00000000000 --- a/public/images/pokemon/variant/exp/773-dark_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-dark_2.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:18cb8e89831d39e3509e75edbc790ec6:4c332c4bb4e4e507cc92538929421ad7:267125b3b5f5d18142ae5fffbef27592$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-dark_2.png b/public/images/pokemon/variant/exp/773-dark_2.png deleted file mode 100644 index 436fd56ac50..00000000000 Binary files a/public/images/pokemon/variant/exp/773-dark_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-dark_3.json b/public/images/pokemon/variant/exp/773-dark_3.json deleted file mode 100644 index 30a44fe6595..00000000000 --- a/public/images/pokemon/variant/exp/773-dark_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-dark_3.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:18cb8e89831d39e3509e75edbc790ec6:4c332c4bb4e4e507cc92538929421ad7:267125b3b5f5d18142ae5fffbef27592$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-dark_3.png b/public/images/pokemon/variant/exp/773-dark_3.png deleted file mode 100644 index 0e6e3b38101..00000000000 Binary files a/public/images/pokemon/variant/exp/773-dark_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-dragon.json b/public/images/pokemon/variant/exp/773-dragon.json new file mode 100644 index 00000000000..44fd391d23c --- /dev/null +++ b/public/images/pokemon/variant/exp/773-dragon.json @@ -0,0 +1,45 @@ +{ + "1": { + "5399df": "b59489", + "e3e6ec": "bdd1e5", + "1975a3": "756cc8", + "483c39": "3a2d53", + "3f3b50": "1e172a", + "0073bf": "7a4949", + "565969": "30365c", + "6ee0e8": "c1ffd7", + "79615e": "504a75", + "251845": "753c32", + "bcbbc5": "788fb5", + "9618e0": "dc9c4d", + "125d4b": "ce7f3f", + "e64f5e": "f1944a", + "1e9378": "f8ce64", + "1eadd1": "2fd0da", + "1d1845": "2e191f", + "aba7bc": "493d55", + "14487e": "3f4085", + "1eadd2": "37b5be" + }, + "2": { + "5399df": "92949e", + "e3e6ec": "444455", + "1975a3": "61c5ff", + "483c39": "778894", + "0073bf": "6a6c75", + "565969": "0f0f1b", + "6ee0e8": "ffffff", + "79615e": "d6d4d4", + "251845": "425735", + "bcbbc5": "242433", + "9618e0": "ade265", + "125d4b": "0f5493", + "e64f5e": "98ce58", + "1e9378": "1eadd1", + "1eadd1": "ffa1ec", + "1d1845": "41434e", + "aba7bc": "dbd8e8", + "14487e": "3e354e", + "1eadd2": "1eadd1" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-dragon_2.json b/public/images/pokemon/variant/exp/773-dragon_2.json deleted file mode 100644 index 02764770e33..00000000000 --- a/public/images/pokemon/variant/exp/773-dragon_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-dragon_2.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:de5acd724aeca00d5e03b7d95e6d1752:038f038ff46af2e5d09ff00b0f4227f2:59453f2ad0e681735b3b15ab728caa7c$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-dragon_2.png b/public/images/pokemon/variant/exp/773-dragon_2.png deleted file mode 100644 index ff4381e8543..00000000000 Binary files a/public/images/pokemon/variant/exp/773-dragon_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-dragon_3.json b/public/images/pokemon/variant/exp/773-dragon_3.json deleted file mode 100644 index bd66828c0d0..00000000000 --- a/public/images/pokemon/variant/exp/773-dragon_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-dragon_3.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:de5acd724aeca00d5e03b7d95e6d1752:038f038ff46af2e5d09ff00b0f4227f2:59453f2ad0e681735b3b15ab728caa7c$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-dragon_3.png b/public/images/pokemon/variant/exp/773-dragon_3.png deleted file mode 100644 index 9365cf457f2..00000000000 Binary files a/public/images/pokemon/variant/exp/773-dragon_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-electric.json b/public/images/pokemon/variant/exp/773-electric.json new file mode 100644 index 00000000000..ff29faa6fb6 --- /dev/null +++ b/public/images/pokemon/variant/exp/773-electric.json @@ -0,0 +1,45 @@ +{ + "1": { + "5399df": "b59489", + "e3e6ec": "bdd1e5", + "483c39": "3a2d53", + "3f3b50": "1e172a", + "0073bf": "7a4949", + "565969": "30365c", + "ca972c": "ff935c", + "79615e": "504a75", + "251845": "753c32", + "bcbbc5": "788fb5", + "f5eb18": "faf256", + "9618e0": "dc9c4d", + "125d4b": "ce7f3f", + "e64f5e": "f1944a", + "1e9378": "f8ce64", + "f5eb19": "fff97e", + "f8ffc5": "fdfee0", + "8e6113": "a55a50", + "aba7bc": "493d55", + "1d1845": "2e191f" + }, + "2": { + "5399df": "92949e", + "e3e6ec": "444455", + "483c39": "778894", + "0073bf": "6a6c75", + "565969": "0f0f1b", + "ca972c": "ffd900", + "79615e": "d6d4d4", + "251845": "425735", + "bcbbc5": "242433", + "f5eb18": "864593", + "9618e0": "ade265", + "125d4b": "b3620e", + "e64f5e": "98ce58", + "1e9378": "f5eb18", + "f5eb19": "f5eb18", + "f8ffc5": "ffd900", + "8e6113": "422a45", + "aba7bc": "dbd8e8", + "1d1845": "41434e" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-electric_2.json b/public/images/pokemon/variant/exp/773-electric_2.json deleted file mode 100644 index 6f0f16618bd..00000000000 --- a/public/images/pokemon/variant/exp/773-electric_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-electric_2.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:6c9dad4e2de3823c74a6249f264fabdd:e2f8eae994f012a9d105d4b8029cc903:e9f7f627b4aa057d8a352e938221d903$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-electric_2.png b/public/images/pokemon/variant/exp/773-electric_2.png deleted file mode 100644 index 8915a2642f6..00000000000 Binary files a/public/images/pokemon/variant/exp/773-electric_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-electric_3.json b/public/images/pokemon/variant/exp/773-electric_3.json deleted file mode 100644 index 5faef0cc77e..00000000000 --- a/public/images/pokemon/variant/exp/773-electric_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-electric_3.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:6c9dad4e2de3823c74a6249f264fabdd:e2f8eae994f012a9d105d4b8029cc903:e9f7f627b4aa057d8a352e938221d903$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-electric_3.png b/public/images/pokemon/variant/exp/773-electric_3.png deleted file mode 100644 index a75171c91d1..00000000000 Binary files a/public/images/pokemon/variant/exp/773-electric_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-fairy.json b/public/images/pokemon/variant/exp/773-fairy.json new file mode 100644 index 00000000000..b9270f3a06a --- /dev/null +++ b/public/images/pokemon/variant/exp/773-fairy.json @@ -0,0 +1,45 @@ +{ + "1": { + "5399df": "b59489", + "e3e6ec": "bdd1e5", + "483c39": "3a2d53", + "3f3b50": "1e172a", + "0073bf": "7a4949", + "565969": "30365c", + "ffe8ef": "fce9c7", + "f9bfe1": "e5a5c9", + "79615e": "504a75", + "251845": "753c32", + "bcbbc5": "788fb5", + "9618e0": "dc9c4d", + "125d4b": "ce7f3f", + "e64f5e": "f1944a", + "1e9378": "f8ce64", + "f9bfe0": "ecaecb", + "1d1845": "2e191f", + "a15296": "833671", + "aba7bc": "493d55", + "e183c7": "d3559a" + }, + "2": { + "5399df": "92949e", + "e3e6ec": "444455", + "483c39": "778894", + "0073bf": "6a6c75", + "565969": "0f0f1b", + "ffe8ef": "acb4bd", + "f9bfe1": "f9bfe0", + "79615e": "d6d4d4", + "251845": "425735", + "bcbbc5": "242433", + "9618e0": "ade265", + "125d4b": "ad628c", + "e64f5e": "98ce58", + "1e9378": "f9bfe0", + "f9bfe0": "f0f7fb", + "1d1845": "41434e", + "a15296": "3f3b50", + "aba7bc": "dbd8e8", + "e183c7": "fca4ea" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-fairy_2.json b/public/images/pokemon/variant/exp/773-fairy_2.json deleted file mode 100644 index ddac1aa45a6..00000000000 --- a/public/images/pokemon/variant/exp/773-fairy_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-fairy_2.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:28d2f609ef335b80b06f8d37a08c3b51:1220d3f33f1dad29f00e7f3de087b847:50e5ca45ea677d44a2fea72d4ec14fc2$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-fairy_2.png b/public/images/pokemon/variant/exp/773-fairy_2.png deleted file mode 100644 index 1237e1848e9..00000000000 Binary files a/public/images/pokemon/variant/exp/773-fairy_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-fairy_3.json b/public/images/pokemon/variant/exp/773-fairy_3.json deleted file mode 100644 index 54fbfe04d67..00000000000 --- a/public/images/pokemon/variant/exp/773-fairy_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-fairy_3.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:28d2f609ef335b80b06f8d37a08c3b51:1220d3f33f1dad29f00e7f3de087b847:50e5ca45ea677d44a2fea72d4ec14fc2$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-fairy_3.png b/public/images/pokemon/variant/exp/773-fairy_3.png deleted file mode 100644 index a6a9d1ba208..00000000000 Binary files a/public/images/pokemon/variant/exp/773-fairy_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-fighting.json b/public/images/pokemon/variant/exp/773-fighting.json new file mode 100644 index 00000000000..0b71c4d58b7 --- /dev/null +++ b/public/images/pokemon/variant/exp/773-fighting.json @@ -0,0 +1,45 @@ +{ + "1": { + "3f3b50": "1e172a", + "483c39": "3a2d53", + "0073bf": "7a4949", + "1e9378": "f8ce64", + "565969": "30365c", + "79615e": "504a75", + "125d4b": "ce7f3f", + "bcbbc5": "788fb5", + "9618e0": "dc9c4d", + "f18a36": "f1964c", + "251845": "753c32", + "aba7bc": "493d55", + "f18a37": "e37637", + "5399df": "b59489", + "d55223": "da4b2f", + "a34828": "a33b26", + "e64f5e": "f1944a", + "f8b076": "ffcd8a", + "e3e6ec": "bdd1e5", + "1d1845": "2e191f" + }, + "2": { + "483c39": "778894", + "0073bf": "6a6c75", + "1e9378": "f18a36", + "565969": "0f0f1b", + "79615e": "d6d4d4", + "125d4b": "b8411d", + "bcbbc5": "242433", + "9618e0": "ade265", + "f18a36": "e7eef2", + "251845": "425735", + "aba7bc": "dbd8e8", + "f18a37": "f18a36", + "5399df": "92949e", + "d55223": "eccd00", + "a34828": "2f4453", + "e64f5e": "98ce58", + "f8b076": "65abdb", + "e3e6ec": "444455", + "1d1845": "41434e" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-fighting_2.json b/public/images/pokemon/variant/exp/773-fighting_2.json deleted file mode 100644 index bf11019dbc5..00000000000 --- a/public/images/pokemon/variant/exp/773-fighting_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-fighting_2.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:ee832e230de7f46b1c0ea11a0e9872a4:8c9f579e60e4d7eaf74c6d28c0006496:70f70b07c9d5b3013cbd3b3f25c7f7fa$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-fighting_2.png b/public/images/pokemon/variant/exp/773-fighting_2.png deleted file mode 100644 index fc7890923fd..00000000000 Binary files a/public/images/pokemon/variant/exp/773-fighting_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-fighting_3.json b/public/images/pokemon/variant/exp/773-fighting_3.json deleted file mode 100644 index f4fb23d7dbb..00000000000 --- a/public/images/pokemon/variant/exp/773-fighting_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-fighting_3.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:ee832e230de7f46b1c0ea11a0e9872a4:8c9f579e60e4d7eaf74c6d28c0006496:70f70b07c9d5b3013cbd3b3f25c7f7fa$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-fighting_3.png b/public/images/pokemon/variant/exp/773-fighting_3.png deleted file mode 100644 index 5e08a1e737a..00000000000 Binary files a/public/images/pokemon/variant/exp/773-fighting_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-fire.json b/public/images/pokemon/variant/exp/773-fire.json new file mode 100644 index 00000000000..42fa1dbc3b3 --- /dev/null +++ b/public/images/pokemon/variant/exp/773-fire.json @@ -0,0 +1,45 @@ +{ + "1": { + "5399df": "b59489", + "e3e6ec": "bdd1e5", + "b50d36": "ae1361", + "3f3b50": "1e172a", + "0073bf": "7a4949", + "565969": "30365c", + "1e9378": "f8ce64", + "79615e": "504a75", + "251845": "753c32", + "bcbbc5": "788fb5", + "125d4b": "ce7f3f", + "9618e0": "dc9c4d", + "f32141": "ee3652", + "e64f5e": "f1944a", + "fa7351": "fc9e5d", + "f32142": "ba2e2c", + "483c39": "3a2d53", + "81132d": "6e1441", + "aba7bc": "493d55", + "1d1845": "2e191f" + }, + "2": { + "5399df": "92949e", + "e3e6ec": "444455", + "b50d36": "fa9955", + "0073bf": "6a6c75", + "565969": "0f0f1b", + "1e9378": "d92b00", + "79615e": "d6d4d4", + "251845": "425735", + "bcbbc5": "242433", + "125d4b": "7a151a", + "9618e0": "ade265", + "f32141": "e7eef2", + "e64f5e": "98ce58", + "fa7351": "d063a2", + "f32142": "d92b00", + "483c39": "778894", + "81132d": "7e3354", + "aba7bc": "dbd8e8", + "1d1845": "41434e" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-fire_2.json b/public/images/pokemon/variant/exp/773-fire_2.json deleted file mode 100644 index 9b6cbc21067..00000000000 --- a/public/images/pokemon/variant/exp/773-fire_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-fire_2.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:a1fbcb7a6e4557190af17ef59d12ba52:916ac60fecdffe42ad54b8bba4f0c271:690c285b19cb1e8f7b7aa9dfafbe36b2$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-fire_2.png b/public/images/pokemon/variant/exp/773-fire_2.png deleted file mode 100644 index d14239bdd75..00000000000 Binary files a/public/images/pokemon/variant/exp/773-fire_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-fire_3.json b/public/images/pokemon/variant/exp/773-fire_3.json deleted file mode 100644 index 631ce807d18..00000000000 --- a/public/images/pokemon/variant/exp/773-fire_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-fire_3.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:a1fbcb7a6e4557190af17ef59d12ba52:916ac60fecdffe42ad54b8bba4f0c271:690c285b19cb1e8f7b7aa9dfafbe36b2$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-fire_3.png b/public/images/pokemon/variant/exp/773-fire_3.png deleted file mode 100644 index b2af9bf4af9..00000000000 Binary files a/public/images/pokemon/variant/exp/773-fire_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-flying.json b/public/images/pokemon/variant/exp/773-flying.json new file mode 100644 index 00000000000..ed70b13853a --- /dev/null +++ b/public/images/pokemon/variant/exp/773-flying.json @@ -0,0 +1,45 @@ +{ + "1": { + "5399df": "b59489", + "e3e6ec": "bdd1e5", + "483c39": "3a2d53", + "3f3b50": "1e172a", + "0073bf": "7a4949", + "0557bd": "1e509e", + "79615e": "504a75", + "5082c1": "8bc4e1", + "251845": "753c32", + "bcbbc5": "788fb5", + "072c85": "402795", + "125d4b": "ce7f3f", + "9618e0": "dc9c4d", + "e64f5e": "f1944a", + "1e9378": "f8ce64", + "1d1845": "2e191f", + "565969": "30365c", + "081b4a": "17195a", + "aba7bc": "493d55", + "0557bc": "296cbe" + }, + "2": { + "5399df": "92949e", + "e3e6ec": "444455", + "483c39": "778894", + "0073bf": "6a6c75", + "0557bd": "0557bc", + "79615e": "d6d4d4", + "5082c1": "acb4bd", + "251845": "425735", + "bcbbc5": "242433", + "072c85": "97c7fe", + "125d4b": "0a298c", + "9618e0": "ade265", + "e64f5e": "98ce58", + "1e9378": "0557bc", + "1d1845": "41434e", + "565969": "0f0f1b", + "081b4a": "2f4453", + "aba7bc": "dbd8e8", + "0557bc": "e7eef2" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-flying_2.json b/public/images/pokemon/variant/exp/773-flying_2.json deleted file mode 100644 index 398a6031101..00000000000 --- a/public/images/pokemon/variant/exp/773-flying_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-flying_2.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:1efe82810ac75f65fe0b72d41000d3c3:b227bd80e066d588b7929f71e1c1c903:fd9cc965ca8a0f017385425d924045d6$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-flying_2.png b/public/images/pokemon/variant/exp/773-flying_2.png deleted file mode 100644 index ef98ec821cf..00000000000 Binary files a/public/images/pokemon/variant/exp/773-flying_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-flying_3.json b/public/images/pokemon/variant/exp/773-flying_3.json deleted file mode 100644 index 1d743d0046a..00000000000 --- a/public/images/pokemon/variant/exp/773-flying_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-flying_3.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:1efe82810ac75f65fe0b72d41000d3c3:b227bd80e066d588b7929f71e1c1c903:fd9cc965ca8a0f017385425d924045d6$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-flying_3.png b/public/images/pokemon/variant/exp/773-flying_3.png deleted file mode 100644 index 0a88dbe3bbd..00000000000 Binary files a/public/images/pokemon/variant/exp/773-flying_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-ghost.json b/public/images/pokemon/variant/exp/773-ghost.json new file mode 100644 index 00000000000..862732f94ca --- /dev/null +++ b/public/images/pokemon/variant/exp/773-ghost.json @@ -0,0 +1,45 @@ +{ + "1": { + "a75bc0": "7b5498", + "5399df": "b59489", + "d68ce5": "ecc9f3", + "483c39": "3a2d53", + "3f3b50": "1e172a", + "0073bf": "7a4949", + "565969": "30365c", + "a75bbf": "b36bca", + "251845": "753c32", + "bcbbc5": "788fb5", + "503775": "392e4c", + "9618e0": "dc9c4d", + "125d4b": "ce7f3f", + "e64f5e": "f1944a", + "1e9378": "f8ce64", + "79615e": "504a75", + "e3e6ec": "bdd1e5", + "753d9a": "504681", + "aba7bc": "493d55", + "1d1845": "2e191f" + }, + "2": { + "a75bc0": "a75bbf", + "5399df": "92949e", + "d68ce5": "5876bd", + "483c39": "778894", + "0073bf": "6a6c75", + "565969": "0f0f1b", + "a75bbf": "c8b5e2", + "251845": "425735", + "bcbbc5": "242433", + "503775": "383c6a", + "9618e0": "ade265", + "125d4b": "653785", + "e64f5e": "98ce58", + "1e9378": "a75bbf", + "79615e": "d6d4d4", + "e3e6ec": "444455", + "753d9a": "cd6fa4", + "aba7bc": "dbd8e8", + "1d1845": "41434e" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-ghost_2.json b/public/images/pokemon/variant/exp/773-ghost_2.json deleted file mode 100644 index 3dab9935666..00000000000 --- a/public/images/pokemon/variant/exp/773-ghost_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-ghost_2.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:e82fe1b788d9fd224eb3910a95277ca7:b208e2ac33e6f2c523b403321ad9a8ea:dff8d338685b93339ecf30f1d807fbe6$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-ghost_2.png b/public/images/pokemon/variant/exp/773-ghost_2.png deleted file mode 100644 index 3997e7cecf1..00000000000 Binary files a/public/images/pokemon/variant/exp/773-ghost_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-ghost_3.json b/public/images/pokemon/variant/exp/773-ghost_3.json deleted file mode 100644 index 1846d5969e6..00000000000 --- a/public/images/pokemon/variant/exp/773-ghost_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-ghost_3.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:e82fe1b788d9fd224eb3910a95277ca7:b208e2ac33e6f2c523b403321ad9a8ea:dff8d338685b93339ecf30f1d807fbe6$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-ghost_3.png b/public/images/pokemon/variant/exp/773-ghost_3.png deleted file mode 100644 index 7f05136b786..00000000000 Binary files a/public/images/pokemon/variant/exp/773-ghost_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-grass.json b/public/images/pokemon/variant/exp/773-grass.json new file mode 100644 index 00000000000..80f1f799e45 --- /dev/null +++ b/public/images/pokemon/variant/exp/773-grass.json @@ -0,0 +1,45 @@ +{ + "1": { + "50d354": "8bf360", + "565969": "30365c", + "3f3b50": "1e172a", + "aba7bc": "493d55", + "1e9378": "f8ce64", + "01a326": "1b9143", + "e64f5e": "f1944a", + "0073bf": "7a4949", + "e3e6ec": "bdd1e5", + "125d4b": "ce7f3f", + "064a28": "043541", + "79615e": "504a75", + "bcbbc5": "788fb5", + "251845": "753c32", + "01a325": "18b12f", + "03753c": "086c6b", + "483c39": "3a2d53", + "9618e0": "dc9c4d", + "5399df": "b59489", + "1d1845": "2e191f" + }, + "2": { + "50d354": "2b6e2d", + "565969": "0f0f1b", + "aba7bc": "dbd8e8", + "1e9378": "01a325", + "01a326": "01a325", + "e64f5e": "98ce58", + "0073bf": "6a6c75", + "e3e6ec": "444455", + "125d4b": "0c592f", + "064a28": "283331", + "79615e": "d6d4d4", + "bcbbc5": "242433", + "251845": "425735", + "01a325": "e7eef2", + "03753c": "c77fe2", + "483c39": "778894", + "9618e0": "ade265", + "5399df": "92949e", + "1d1845": "41434e" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-grass_2.json b/public/images/pokemon/variant/exp/773-grass_2.json deleted file mode 100644 index d2db6dd2058..00000000000 --- a/public/images/pokemon/variant/exp/773-grass_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-grass_2.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:64583917485b2306d8116c137fefba57:056b7a9c0b52b33bbd4ff422e297363a:c892d42603d88b410862efcb4f750000$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-grass_2.png b/public/images/pokemon/variant/exp/773-grass_2.png deleted file mode 100644 index fbb25d0d0dc..00000000000 Binary files a/public/images/pokemon/variant/exp/773-grass_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-grass_3.json b/public/images/pokemon/variant/exp/773-grass_3.json deleted file mode 100644 index d8785066ce2..00000000000 --- a/public/images/pokemon/variant/exp/773-grass_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-grass_3.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:64583917485b2306d8116c137fefba57:056b7a9c0b52b33bbd4ff422e297363a:c892d42603d88b410862efcb4f750000$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-grass_3.png b/public/images/pokemon/variant/exp/773-grass_3.png deleted file mode 100644 index 65b123fe530..00000000000 Binary files a/public/images/pokemon/variant/exp/773-grass_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-ground.json b/public/images/pokemon/variant/exp/773-ground.json new file mode 100644 index 00000000000..7293fabfaf0 --- /dev/null +++ b/public/images/pokemon/variant/exp/773-ground.json @@ -0,0 +1,45 @@ +{ + "1": { + "125d4b": "ce7f3f", + "aba7bc": "493d55", + "565969": "30365c", + "3f3b50": "1e172a", + "bcbbc5": "788fb5", + "5399df": "b59489", + "1e9378": "f8ce64", + "e59b4a": "f3daa4", + "cf5c08": "b55711", + "9618e0": "dc9c4d", + "e3e6ec": "bdd1e5", + "251845": "753c32", + "cf5c07": "d36b1f", + "1d1845": "2e191f", + "0073bf": "7a4949", + "a3410c": "95174b", + "613016": "61191e", + "e64f5e": "f1944a", + "483c39": "3a2d53", + "79615e": "504a75" + }, + "2": { + "125d4b": "a32004", + "aba7bc": "dbd8e8", + "565969": "0f0f1b", + "bcbbc5": "242433", + "5399df": "92949e", + "1e9378": "cf5c07", + "e59b4a": "44b3e3", + "cf5c08": "cf5c07", + "9618e0": "ade265", + "e3e6ec": "444455", + "251845": "425735", + "cf5c07": "ffd963", + "1d1845": "41434e", + "0073bf": "6a6c75", + "a3410c": "e1497e", + "613016": "653653", + "e64f5e": "98ce58", + "483c39": "778894", + "79615e": "d6d4d4" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-ground_2.json b/public/images/pokemon/variant/exp/773-ground_2.json deleted file mode 100644 index 60a07eb0d0e..00000000000 --- a/public/images/pokemon/variant/exp/773-ground_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-ground_2.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:d8c6d082f56bea68130237d2f0408272:19a82aac79e67571460aaec5a9bb839c:a8b1ae37d6ef4c526891c3cd392866cd$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-ground_2.png b/public/images/pokemon/variant/exp/773-ground_2.png deleted file mode 100644 index 16d86f8e051..00000000000 Binary files a/public/images/pokemon/variant/exp/773-ground_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-ground_3.json b/public/images/pokemon/variant/exp/773-ground_3.json deleted file mode 100644 index e86e9f44fd2..00000000000 --- a/public/images/pokemon/variant/exp/773-ground_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-ground_3.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:d8c6d082f56bea68130237d2f0408272:19a82aac79e67571460aaec5a9bb839c:a8b1ae37d6ef4c526891c3cd392866cd$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-ground_3.png b/public/images/pokemon/variant/exp/773-ground_3.png deleted file mode 100644 index 24c0ccf595e..00000000000 Binary files a/public/images/pokemon/variant/exp/773-ground_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-ice.json b/public/images/pokemon/variant/exp/773-ice.json new file mode 100644 index 00000000000..efb6223b71a --- /dev/null +++ b/public/images/pokemon/variant/exp/773-ice.json @@ -0,0 +1,45 @@ +{ + "1": { + "5399df": "b59489", + "e3e6ec": "bdd1e5", + "483c39": "3a2d53", + "416b7e": "575693", + "0073bf": "7a4949", + "565969": "30365c", + "251845": "753c32", + "79615e": "504a75", + "aef9f9": "b8f8f8", + "bcbbc5": "788fb5", + "7bb3cc": "a197f3", + "125d4b": "ce7f3f", + "9618e0": "dc9c4d", + "e64f5e": "f1944a", + "1e9378": "f8ce64", + "1d1845": "2e191f", + "ecfffc": "eafffb", + "3f3b50": "1e172a", + "aba7bc": "493d55", + "aef9fa": "aef9f9" + }, + "2": { + "5399df": "92949e", + "e3e6ec": "444455", + "483c39": "778894", + "416b7e": "414f65", + "0073bf": "6a6c75", + "565969": "0f0f1b", + "251845": "425735", + "79615e": "d6d4d4", + "aef9f9": "e7eef2", + "bcbbc5": "242433", + "7bb3cc": "38cfb0", + "125d4b": "5c94a6", + "9618e0": "ade265", + "e64f5e": "98ce58", + "1e9378": "aef9f9", + "1d1845": "41434e", + "ecfffc": "7cadde", + "aba7bc": "dbd8e8", + "aef9fa": "aef9f9" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-ice_2.json b/public/images/pokemon/variant/exp/773-ice_2.json deleted file mode 100644 index f9799474482..00000000000 --- a/public/images/pokemon/variant/exp/773-ice_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-ice_2.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:8d42c8e3fd04f674b0524bfd6e743071:53b56322b7fa7324f1d2f161f63fac1b:bbb81164af15638f1aae91f14ca0ac1d$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-ice_2.png b/public/images/pokemon/variant/exp/773-ice_2.png deleted file mode 100644 index 6e7f395e288..00000000000 Binary files a/public/images/pokemon/variant/exp/773-ice_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-ice_3.json b/public/images/pokemon/variant/exp/773-ice_3.json deleted file mode 100644 index d1889278f14..00000000000 --- a/public/images/pokemon/variant/exp/773-ice_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-ice_3.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:8d42c8e3fd04f674b0524bfd6e743071:53b56322b7fa7324f1d2f161f63fac1b:bbb81164af15638f1aae91f14ca0ac1d$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-ice_3.png b/public/images/pokemon/variant/exp/773-ice_3.png deleted file mode 100644 index e1fdb9345fa..00000000000 Binary files a/public/images/pokemon/variant/exp/773-ice_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-poison.json b/public/images/pokemon/variant/exp/773-poison.json new file mode 100644 index 00000000000..f2f97d07bdc --- /dev/null +++ b/public/images/pokemon/variant/exp/773-poison.json @@ -0,0 +1,45 @@ +{ + "1": { + "5399df": "b59489", + "e3e6ec": "bdd1e5", + "483c39": "3a2d53", + "3f3b50": "1e172a", + "0073bf": "7a4949", + "565969": "30365c", + "7234bc": "874dcc", + "4e229c": "4641b5", + "79615e": "504a75", + "251845": "753c32", + "bcbbc5": "788fb5", + "125d4b": "ce7f3f", + "30175c": "2f1b77", + "e64f5e": "f1944a", + "1e9378": "f8ce64", + "9618e0": "dc9c4d", + "9c71ce": "d089ee", + "1d1845": "2e191f", + "aba7bc": "493d55", + "7234bd": "7b4bb5" + }, + "2": { + "5399df": "92949e", + "e3e6ec": "444455", + "483c39": "778894", + "0073bf": "6a6c75", + "565969": "0f0f1b", + "7234bc": "8e4da8", + "4e229c": "e3508d", + "79615e": "d6d4d4", + "251845": "425735", + "bcbbc5": "242433", + "125d4b": "4b1f7e", + "30175c": "34284a", + "e64f5e": "98ce58", + "1e9378": "7234bc", + "9618e0": "ade265", + "9c71ce": "2752b5", + "1d1845": "41434e", + "aba7bc": "dbd8e8", + "7234bd": "7234bc" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-poison_2.json b/public/images/pokemon/variant/exp/773-poison_2.json deleted file mode 100644 index 7182f55b492..00000000000 --- a/public/images/pokemon/variant/exp/773-poison_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-poison_2.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:9c6805004641ba1aec9211c31b452689:9ac142cbe192d67b4a9e79d871fbbb2e:2e43d6e4a409b7aabc1efd3ec3981f96$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-poison_2.png b/public/images/pokemon/variant/exp/773-poison_2.png deleted file mode 100644 index 9417a32cb65..00000000000 Binary files a/public/images/pokemon/variant/exp/773-poison_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-poison_3.json b/public/images/pokemon/variant/exp/773-poison_3.json deleted file mode 100644 index 1ea56f54825..00000000000 --- a/public/images/pokemon/variant/exp/773-poison_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-poison_3.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:9c6805004641ba1aec9211c31b452689:9ac142cbe192d67b4a9e79d871fbbb2e:2e43d6e4a409b7aabc1efd3ec3981f96$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-poison_3.png b/public/images/pokemon/variant/exp/773-poison_3.png deleted file mode 100644 index 992c06a9fb3..00000000000 Binary files a/public/images/pokemon/variant/exp/773-poison_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-psychic.json b/public/images/pokemon/variant/exp/773-psychic.json new file mode 100644 index 00000000000..02a42c53088 --- /dev/null +++ b/public/images/pokemon/variant/exp/773-psychic.json @@ -0,0 +1,45 @@ +{ + "1": { + "565969": "30365c", + "7a2656": "812c6e", + "aba7bc": "493d55", + "f3a1b8": "ffccc3", + "ea6aa5": "c14e82", + "251845": "753c32", + "125d4b": "ce7f3f", + "c1448c": "b3388f", + "bcbbc5": "788fb5", + "79615e": "504a75", + "0073bf": "7a4949", + "1d1845": "2e191f", + "3f3b50": "1e172a", + "9618e0": "dc9c4d", + "ea6aa4": "ec81b2", + "5399df": "b59489", + "483c39": "3a2d53", + "1e9378": "f8ce64", + "e3e6ec": "bdd1e5", + "e64f5e": "f1944a" + }, + "2": { + "565969": "0f0f1b", + "7a2656": "6a3851", + "aba7bc": "dbd8e8", + "f3a1b8": "ed77a7", + "ea6aa5": "ea6aa4", + "251845": "425735", + "125d4b": "9f3351", + "c1448c": "91d4b0", + "bcbbc5": "242433", + "79615e": "d6d4d4", + "0073bf": "6a6c75", + "1d1845": "41434e", + "9618e0": "ade265", + "ea6aa4": "e7eef2", + "5399df": "92949e", + "483c39": "778894", + "1e9378": "ea6aa4", + "e3e6ec": "444455", + "e64f5e": "98ce58" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-psychic_2.json b/public/images/pokemon/variant/exp/773-psychic_2.json deleted file mode 100644 index 1c38c2359ea..00000000000 --- a/public/images/pokemon/variant/exp/773-psychic_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-psychic_2.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:4c64b849353c83def601bfcbb4ee960e:011431e65299810bff87dcb56dfdcc10:9fb489b40d17b047a9dacb47533ceda4$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-psychic_2.png b/public/images/pokemon/variant/exp/773-psychic_2.png deleted file mode 100644 index 3ffcd3c35fd..00000000000 Binary files a/public/images/pokemon/variant/exp/773-psychic_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-psychic_3.json b/public/images/pokemon/variant/exp/773-psychic_3.json deleted file mode 100644 index d8df8e6968a..00000000000 --- a/public/images/pokemon/variant/exp/773-psychic_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-psychic_3.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:4c64b849353c83def601bfcbb4ee960e:011431e65299810bff87dcb56dfdcc10:9fb489b40d17b047a9dacb47533ceda4$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-psychic_3.png b/public/images/pokemon/variant/exp/773-psychic_3.png deleted file mode 100644 index 03fe6c56646..00000000000 Binary files a/public/images/pokemon/variant/exp/773-psychic_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-rock.json b/public/images/pokemon/variant/exp/773-rock.json new file mode 100644 index 00000000000..f15a1bd6e4d --- /dev/null +++ b/public/images/pokemon/variant/exp/773-rock.json @@ -0,0 +1,45 @@ +{ + "1": { + "7a5c52": "775d73", + "e3e6ec": "bdd1e5", + "d6c4b2": "c8b19a", + "483c39": "3a2d53", + "3f3b50": "1e172a", + "0073bf": "7a4949", + "565969": "30365c", + "79615e": "504a75", + "a38479": "c18cb8", + "251845": "753c32", + "bcbbc5": "788fb5", + "125d4b": "ce7f3f", + "9618e0": "dc9c4d", + "e64f5e": "f1944a", + "1e9378": "f8ce64", + "5399df": "b59489", + "1d1845": "2e191f", + "d6c4b1": "e5d2bd", + "aba7bc": "493d55", + "f3ebdc": "fff5d8" + }, + "2": { + "7a5c52": "50433d", + "e3e6ec": "444455", + "d6c4b2": "d6c4b1", + "483c39": "778894", + "0073bf": "6a6c75", + "565969": "0f0f1b", + "79615e": "d6d4d4", + "a38479": "f9de6c", + "251845": "425735", + "bcbbc5": "242433", + "125d4b": "816f5b", + "9618e0": "ade265", + "e64f5e": "98ce58", + "1e9378": "d6c4b1", + "5399df": "92949e", + "1d1845": "41434e", + "d6c4b1": "e7eef2", + "aba7bc": "dbd8e8", + "f3ebdc": "acb4bd" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-rock_2.json b/public/images/pokemon/variant/exp/773-rock_2.json deleted file mode 100644 index fd01815d85c..00000000000 --- a/public/images/pokemon/variant/exp/773-rock_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-rock_2.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:1dbb200c8839b5b434a12ee845afd228:b1ceb056eb1933d502cfa229df41cae8:b6fcb5d1ff917a13e5e912a7f40fcbe2$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-rock_2.png b/public/images/pokemon/variant/exp/773-rock_2.png deleted file mode 100644 index a59e0cf43b2..00000000000 Binary files a/public/images/pokemon/variant/exp/773-rock_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-rock_3.json b/public/images/pokemon/variant/exp/773-rock_3.json deleted file mode 100644 index a66b3ab05eb..00000000000 --- a/public/images/pokemon/variant/exp/773-rock_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-rock_3.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:1dbb200c8839b5b434a12ee845afd228:b1ceb056eb1933d502cfa229df41cae8:b6fcb5d1ff917a13e5e912a7f40fcbe2$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-rock_3.png b/public/images/pokemon/variant/exp/773-rock_3.png deleted file mode 100644 index 79874ef4407..00000000000 Binary files a/public/images/pokemon/variant/exp/773-rock_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-steel.json b/public/images/pokemon/variant/exp/773-steel.json new file mode 100644 index 00000000000..7a8a40d6399 --- /dev/null +++ b/public/images/pokemon/variant/exp/773-steel.json @@ -0,0 +1,45 @@ +{ + "1": { + "5399df": "b59489", + "cfc7c7": "dcd1d1", + "483c39": "3a2d53", + "3f3b50": "1e172a", + "0073bf": "7a4949", + "565969": "30365c", + "595467": "565071", + "79615e": "504a75", + "251845": "753c32", + "bcbbc5": "788fb5", + "cfc7c8": "b8aeab", + "1e9378": "f8ce64", + "125d4b": "ce7f3f", + "e64f5e": "f1944a", + "e5e0de": "f1efe5", + "9618e0": "dc9c4d", + "9d98aa": "8f89aa", + "e3e6ec": "bdd1e5", + "aba7bc": "493d55", + "1d1845": "2e191f" + }, + "2": { + "5399df": "92949e", + "cfc7c7": "e7eef2", + "483c39": "778894", + "0073bf": "6a6c75", + "565969": "0f0f1b", + "595467": "3b253e", + "79615e": "d6d4d4", + "251845": "425735", + "bcbbc5": "242433", + "cfc7c8": "cfc7c7", + "1e9378": "cfc7c7", + "125d4b": "705a5f", + "e64f5e": "98ce58", + "e5e0de": "a5a5a5", + "9618e0": "ade265", + "9d98aa": "98099c", + "e3e6ec": "444455", + "aba7bc": "dbd8e8", + "1d1845": "41434e" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-steel_2.json b/public/images/pokemon/variant/exp/773-steel_2.json deleted file mode 100644 index 89ebe9986a6..00000000000 --- a/public/images/pokemon/variant/exp/773-steel_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-steel_2.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:02bbb45df2739fda0172ed1e6bf4b14b:102ef6037d53e8bb26a40306dd0105dc:28dcfb1ac7091bec326d67f7b8d4eaa6$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-steel_2.png b/public/images/pokemon/variant/exp/773-steel_2.png deleted file mode 100644 index f09527c7e85..00000000000 Binary files a/public/images/pokemon/variant/exp/773-steel_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-steel_3.json b/public/images/pokemon/variant/exp/773-steel_3.json deleted file mode 100644 index d5c504afe5d..00000000000 --- a/public/images/pokemon/variant/exp/773-steel_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-steel_3.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:02bbb45df2739fda0172ed1e6bf4b14b:102ef6037d53e8bb26a40306dd0105dc:28dcfb1ac7091bec326d67f7b8d4eaa6$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-steel_3.png b/public/images/pokemon/variant/exp/773-steel_3.png deleted file mode 100644 index 37502bbe3be..00000000000 Binary files a/public/images/pokemon/variant/exp/773-steel_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-water.json b/public/images/pokemon/variant/exp/773-water.json new file mode 100644 index 00000000000..4be5ae1c03b --- /dev/null +++ b/public/images/pokemon/variant/exp/773-water.json @@ -0,0 +1,44 @@ +{ + "1": { + "5399df": "b59489", + "175477": "34508a", + "483c39": "3a2d53", + "3ed3ee": "4fd4ec", + "0073bf": "7a4949", + "565969": "30365c", + "3ed3ef": "59d6ec", + "79615e": "504a75", + "251845": "753c32", + "bcbbc5": "788fb5", + "125d4b": "ce7f3f", + "9618e0": "dc9c4d", + "e64f5e": "f1944a", + "1e9378": "f8ce64", + "e3e6ec": "bdd1e5", + "92f1f3": "93f8e9", + "3f3b50": "1e172a", + "aba7bc": "493d55", + "2786bc": "4661cc" + }, + "2": { + "5399df": "92949e", + "175477": "3a182f", + "483c39": "778894", + "3ed3ee": "e7eef2", + "0073bf": "6a6c75", + "565969": "0f0f1b", + "3ed3ef": "2866ba", + "79615e": "d6d4d4", + "251845": "425735", + "bcbbc5": "242433", + "125d4b": "162c81", + "9618e0": "ade265", + "1d1845": "444455", + "e64f5e": "98ce58", + "1e9378": "2866ba", + "e3e6ec": "444455", + "92f1f3": "b82db2", + "aba7bc": "dbd8e8", + "2786bc": "fe75a3" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-water_2.json b/public/images/pokemon/variant/exp/773-water_2.json deleted file mode 100644 index fb635e17e5a..00000000000 --- a/public/images/pokemon/variant/exp/773-water_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-water_2.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:8e4b51563159c17e49b2a80a859937d3:32a8821bc6c535a84d08d31dd22c306d:609e3c1a2aa54ec6d5110acf831a822b$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-water_2.png b/public/images/pokemon/variant/exp/773-water_2.png deleted file mode 100644 index 843aa772361..00000000000 Binary files a/public/images/pokemon/variant/exp/773-water_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773-water_3.json b/public/images/pokemon/variant/exp/773-water_3.json deleted file mode 100644 index 2ac3e190b70..00000000000 --- a/public/images/pokemon/variant/exp/773-water_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-water_3.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:8e4b51563159c17e49b2a80a859937d3:32a8821bc6c535a84d08d31dd22c306d:609e3c1a2aa54ec6d5110acf831a822b$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773-water_3.png b/public/images/pokemon/variant/exp/773-water_3.png deleted file mode 100644 index 39d52ff579d..00000000000 Binary files a/public/images/pokemon/variant/exp/773-water_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773.json b/public/images/pokemon/variant/exp/773.json new file mode 100644 index 00000000000..b64796b9bf9 --- /dev/null +++ b/public/images/pokemon/variant/exp/773.json @@ -0,0 +1,50 @@ +{ + "1": { + "939f9e": "738093", + "ededed": "eef1f3", + "f9f9f9": "cdd6dc", + "d3d7df": "98a8be", + "565969": "30365c", + "bcbbc5": "788fb5", + "e3e6ec": "bdd1e5", + "3f3b50": "1e172a", + "aba7bc": "493d55", + "080808": "080808", + "e64f5e": "f1944a", + "483c39": "3a2d53", + "79615e": "504a75", + "1d1845": "2e191f", + "e9eaf8": "e7ebed", + "0073bf": "7a4949", + "5399df": "b59489", + "fffef5": "fffef5", + "251845": "753c32", + "9618e0": "dc9c4d", + "125d4b": "ce7f3f", + "1e9378": "f8ce64" + }, + "2": { + "939f9e": "738093", + "ededed": "ffffff", + "f9f9f9": "e7eef2", + "d3d7df": "b4bcc4", + "565969": "0f0f1b", + "bcbbc5": "242433", + "e3e6ec": "444455", + "3f3b50": "3f3b50", + "aba7bc": "dbd8e8", + "080808": "080808", + "e64f5e": "98ce58", + "483c39": "778894", + "79615e": "d6d4d4", + "1d1845": "41434e", + "e9eaf8": "eef4f8", + "0073bf": "6a6c75", + "5399df": "92949e", + "fffef5": "fffef5", + "251845": "425735", + "9618e0": "ade265", + "125d4b": "686981", + "1e9378": "eef4f8" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773_2.json b/public/images/pokemon/variant/exp/773_2.json deleted file mode 100644 index 9d8d82b12c4..00000000000 --- a/public/images/pokemon/variant/exp/773_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773_2.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:83975825c18432b27c00e1a53366fb13:03c41a3cbd3deabcd6f094e8da3e13eb:4db3598909fd9e3f8759f1832ec8e58f$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773_2.png b/public/images/pokemon/variant/exp/773_2.png deleted file mode 100644 index fa35cf82be1..00000000000 Binary files a/public/images/pokemon/variant/exp/773_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/773_3.json b/public/images/pokemon/variant/exp/773_3.json deleted file mode 100644 index d2e9703d697..00000000000 --- a/public/images/pokemon/variant/exp/773_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773_3.png", - "format": "RGBA8888", - "size": { - "w": 335, - "h": 335 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 0, - "w": 66, - "h": 86 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 86, - "w": 66, - "h": 86 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 0, - "w": 66, - "h": 86 - }, - "frame": { - "x": 0, - "y": 172, - "w": 66, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 66, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 84 - }, - "frame": { - "x": 134, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 68, - "h": 84 - }, - "frame": { - "x": 202, - "y": 0, - "w": 68, - "h": 84 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 66, - "y": 169, - "w": 66, - "h": 85 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 81 - }, - "frame": { - "x": 66, - "y": 254, - "w": 68, - "h": 81 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 66, - "h": 85 - }, - "frame": { - "x": 132, - "y": 84, - "w": 66, - "h": 85 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 67, - "h": 84 - }, - "frame": { - "x": 132, - "y": 169, - "w": 67, - "h": 84 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 134, - "y": 253, - "w": 68, - "h": 82 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 198, - "y": 84, - "w": 66, - "h": 84 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 2, - "y": 2, - "w": 66, - "h": 84 - }, - "frame": { - "x": 199, - "y": 168, - "w": 66, - "h": 84 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 68, - "h": 83 - }, - "frame": { - "x": 202, - "y": 252, - "w": 68, - "h": 83 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 1, - "y": 3, - "w": 67, - "h": 83 - }, - "frame": { - "x": 264, - "y": 84, - "w": 67, - "h": 83 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 68, - "h": 86 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 68, - "h": 82 - }, - "frame": { - "x": 265, - "y": 167, - "w": 68, - "h": 82 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:83975825c18432b27c00e1a53366fb13:03c41a3cbd3deabcd6f094e8da3e13eb:4db3598909fd9e3f8759f1832ec8e58f$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/773_3.png b/public/images/pokemon/variant/exp/773_3.png deleted file mode 100644 index d21eb3a4126..00000000000 Binary files a/public/images/pokemon/variant/exp/773_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/807.json b/public/images/pokemon/variant/exp/807.json new file mode 100644 index 00000000000..8344e88090b --- /dev/null +++ b/public/images/pokemon/variant/exp/807.json @@ -0,0 +1,36 @@ +{ + "1": { + "53e4f9": "d7a7de", + "ef8a4e": "4f7bb6", + "2759a5": "736599", + "14bdea": "c987e3", + "2394d8": "b298d8", + "31343e": "14193f", + "1f73b4": "995fc0", + "4cf4fe": "f4a7ff", + "484f57": "243058", + "000000": "ffffff", + "727678": "3e5277", + "9d682d": "3c648d", + "f9e455": "7fc7d9", + "daa936": "5a96b6", + "5bd0f2": "ebceff" + }, + "2": { + "53e4f9": "d967a2", + "ef8a4e": "834b95", + "2759a5": "a4378a", + "14bdea": "c02f8d", + "2394d8": "c05192", + "31343e": "a981b1", + "1f73b4": "9a1d82", + "4cf4fe": "e3418f", + "484f57": "cda4cb", + "000000": "ffffff", + "727678": "e8cae3", + "9d682d": "1d1044", + "f9e455": "56306f", + "daa936": "331b53", + "5bd0f2": "e17197" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/894.json b/public/images/pokemon/variant/exp/894.json new file mode 100644 index 00000000000..dd270f3bc0e --- /dev/null +++ b/public/images/pokemon/variant/exp/894.json @@ -0,0 +1,27 @@ +{ + "1": { + "e5ee1a": "6ad7f3", + "ff9dc2": "2c3072", + "7d542a": "2769aa", + "8eacdd": "caffd1", + "bc8b2f": "124b78", + "fffbfb": "dffff6", + "2e3967": "357b84", + "fefac7": "dffff6", + "375395": "5fcaad", + "4e7cc9": "9bf1c4", + "d7ad0d": "45a3d6" + }, + "2": { + "e5ee1a": "d4ffd0", + "ff9dc2": "382875", + "7d542a": "429877", + "8eacdd": "c693d8", + "bc8b2f": "2a6f5d", + "2e3967": "514199", + "fefac7": "ffffff", + "375395": "815bad", + "4e7cc9": "b67cd6", + "d7ad0d": "7cd395" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/895.json b/public/images/pokemon/variant/exp/895.json new file mode 100644 index 00000000000..7c37283fee7 --- /dev/null +++ b/public/images/pokemon/variant/exp/895.json @@ -0,0 +1,34 @@ +{ + "1": { + "2261ca": "561a5b", + "641e2c": "722123", + "ff92ae": "edca71", + "242e35": "512c25", + "608d99": "fae5bf", + "2b3d40": "754f47", + "76dff5": "ffe8f7", + "4b6f78": "f1d4b6", + "e05276": "ef8429", + "b63650": "bc623e", + "f27a99": "efb55a", + "872c3c": "93372d", + "3f545f": "ad8473", + "139ee1": "9b407f" + }, + "2": { + "2261ca": "640e0b", + "641e2c": "15553b", + "ff92ae": "f1ff8d", + "242e35": "0f0c1e", + "608d99": "9b7ebc", + "2b3d40": "241951", + "76dff5": "fffcdf", + "4b6f78": "5a4382", + "e05276": "8aea41", + "b63650": "3bb349", + "f27a99": "dfff75", + "872c3c": "227843", + "3f545f": "3a2a67", + "139ee1": "98301c" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/944.json b/public/images/pokemon/variant/exp/944.json new file mode 100644 index 00000000000..4f1707ae85c --- /dev/null +++ b/public/images/pokemon/variant/exp/944.json @@ -0,0 +1,42 @@ +{ + "1": { + "b5eab2": "75a0d0", + "d4eac7": "8bcfe5", + "bdb2bd": "53a164", + "ceceb7": "3ec295", + "726766": "4f985c", + "4a4860": "372869", + "8ce1b2": "6383c4", + "564a49": "286943", + "000000": "ffffff", + "4ca391": "3a4a8a", + "a571e6": "ffe269", + "774d9b": "d09139", + "97859b": "3f8d59", + "afc6d8": "8056a7", + "efeee1": "88eeab", + "869fad": "5e4090", + "918772": "1c9b8d", + "3a2b2f": "18493f" + }, + "2": { + "b5eab2": "a9c6dc", + "d4eac7": "e2f8ff", + "bdb2bd": "78b0c2", + "ceceb7": "abc1df", + "726766": "5386b9", + "4a4860": "4f133f", + "8ce1b2": "8397c4", + "564a49": "2c4f8a", + "000000": "ffffff", + "4ca391": "3a4a8a", + "a571e6": "4c5372", + "774d9b": "2c2c46", + "97859b": "5582a4", + "afc6d8": "c23f4f", + "efeee1": "e2f3ff", + "869fad": "902a4b", + "918772": "6777aa", + "3a2b2f": "1e3072" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/945.json b/public/images/pokemon/variant/exp/945.json new file mode 100644 index 00000000000..e22743030f9 --- /dev/null +++ b/public/images/pokemon/variant/exp/945.json @@ -0,0 +1,53 @@ +{ + "1": { + "403f4f": "357747", + "1f2635": "1c193d", + "dcdcc3": "5ddcb2", + "282434": "14463f", + "ebe4e2": "ade273", + "a491a4": "499833", + "e6e2e1": "fffbf3", + "671544": "0f4e67", + "584698": "18153d", + "134175": "a74d2a", + "4f483f": "1b727b", + "323d4a": "2e2452", + "000000": "ffffff", + "8ac2a2": "1a355d", + "d73875": "29ad89", + "e0ebf1": "7ddfee", + "2481b0": "d09139", + "4b616b": "473869", + "38bdda": "ffe269", + "695575": "16613d", + "aca699": "2db3a4", + "8d2151": "157375", + "cedaaa": "2f5b7b" + }, + "2": { + "403f4f": "3b6b9e", + "1f2635": "3b091c", + "dcdcc3": "edf0f1", + "282434": "2d427e", + "ebe4e2": "c23f4f", + "a491a4": "902a4b", + "e6e2e1": "ebf4f9", + "671544": "223969", + "584698": "1f1e43", + "134175": "1c182f", + "4f483f": "5d7487", + "323d4a": "580f1d", + "000000": "ffffff", + "a599a8": "bf888f", + "8ac2a2": "8397c4", + "7c6a84": "965b6f", + "d73875": "68adca", + "2481b0": "2c2c46", + "4b616b": "8a2029", + "38bdda": "494e64", + "695575": "4f133f", + "aca699": "acbfc7", + "8d2151": "4676aa", + "cedaaa": "bad4e8" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/2026.json b/public/images/pokemon/variant/exp/back/2026.json new file mode 100644 index 00000000000..5758dcc8c6c --- /dev/null +++ b/public/images/pokemon/variant/exp/back/2026.json @@ -0,0 +1,31 @@ +{ + "1": { + "552720": "162f4b", + "ecd8b7": "b4c2a5", + "dfc043": "d17577", + "fffdfb": "d6d9ca", + "993c20": "1d3a57", + "b45f25": "2d5261", + "965821": "2f4e6b", + "e9be14": "945c7b", + "846b5b": "467f85", + "602c24": "162f4b", + "f9ed9f": "eb999a", + "e3882d": "3d7375", + "646124": "492652", + "fef443": "c48081" + }, + "2": { + "552720": "43617f", + "ecd8b7": "5a6f90", + "fffdfb": "6d8297", + "993c20": "965636", + "b45f25": "bd8551", + "965821": "9cb3ca", + "e9be14": "1a3551", + "846b5b": "202746", + "e3882d": "d3b06f", + "646124": "122140", + "fef443": "3a5873" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/2103.json b/public/images/pokemon/variant/exp/back/2103.json new file mode 100644 index 00000000000..2e97727835a --- /dev/null +++ b/public/images/pokemon/variant/exp/back/2103.json @@ -0,0 +1,28 @@ +{ + "1": { + "2f9934": "dea44c", + "9f6b41": "426378", + "70442e": "283f5b", + "e6ac5a": "869fdc", + "522f16": "131d33", + "9cbd4a": "9977dd", + "fff68b": "a3c4ed", + "36cc36": "f4e774", + "2d5826": "c8592a", + "7b5210": "373e85", + "ffffcd": "d3efff" + }, + "2": { + "2f9934": "3d324b", + "9f6b41": "ffdbe7", + "70442e": "d59cba", + "e6ac5a": "c84e7f", + "522f16": "925b81", + "9cbd4a": "824a96", + "fff68b": "eb748d", + "36cc36": "6a5b73", + "2d5826": "1f1a31", + "7b5210": "4e1044", + "ffffcd": "ffa29d" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/359-mega.json b/public/images/pokemon/variant/exp/back/359-mega.json new file mode 100644 index 00000000000..5ae5a7477e7 --- /dev/null +++ b/public/images/pokemon/variant/exp/back/359-mega.json @@ -0,0 +1,24 @@ +{ + "1": { + "ffffff": "61a8ab", + "414a6a": "421e4a", + "b4b4d5": "458196", + "293939": "27122b", + "525a7b": "59274e", + "d5deee": "589aa6", + "737bac": "874267", + "626283": "2a3163", + "8b8bac": "3b6987" + }, + "2": { + "ffffff": "9e363b", + "414a6a": "b39279", + "b4b4d5": "752f40", + "293939": "996e5f", + "525a7b": "e0c79f", + "d5deee": "8f2f41", + "737bac": "f5f1cb", + "626283": "42122d", + "8b8bac": "59213b" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/4144.json b/public/images/pokemon/variant/exp/back/4144.json index f4f327927cd..1d4f24e4648 100644 --- a/public/images/pokemon/variant/exp/back/4144.json +++ b/public/images/pokemon/variant/exp/back/4144.json @@ -1,38 +1,36 @@ { "1": { - "282a5d": "324b75", - "a695ea": "d5f1ff", - "000000": "000000", - "6f65c5": "afd4ee", - "1a1a1a": "254f89", - "2f2f2f": "4da0c9", "43458b": "7ea0c1", - "5fbddc": "ffb725", - "b480d6": "181f54", - "754691": "08092d", - "d9b5fb": "29336f", - "60748a": "0e173f", + "60748a": "18255b", "bbc9d9": "39579a", - "eef0f2": "5678a9", - "703f8e": "bd5a2c", - "af7ad1": "ffb725" + "282a5d": "324b75", + "b27fd4": "ffb525", + "2f2f2f": "4da0c9", + "5fbddc": "ffb725", + "754691": "08092d", + "a695ea": "d5f1ff", + "1a1a1a": "254f89", + "6f65c5": "afd4ee", + "b480d6": "181f54", + "d9b5fb": "29336f", + "74458f": "bd5a2c", + "eef0f2": "5678a9" }, "2": { - "282a5d": "540916", - "a695ea": "cb4d46", - "000000": "000000", - "6f65c5": "a2282c", - "1a1a1a": "98624d", - "2f2f2f": "ead8cd", "43458b": "75151e", - "5fbddc": "ce2488", - "b480d6": "cb7a2c", - "754691": "873c0f", - "d9b5fb": "f4b260", - "60748a": "84643f", + "60748a": "a37f56", "bbc9d9": "ead9b8", - "eef0f2": "fff9e7", - "703f8e": "952274", - "af7ad1": "ce2488" + "282a5d": "540916", + "b27fd4": "ce2488", + "2f2f2f": "ffefe5", + "5fbddc": "e949a7", + "754691": "873c0f", + "a695ea": "c0443d", + "1a1a1a": "bb826c", + "6f65c5": "a2282c", + "b480d6": "cb7a2c", + "d9b5fb": "f4b260", + "74458f": "952274", + "eef0f2": "fff9e7" } } \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/4145.json b/public/images/pokemon/variant/exp/back/4145.json index 2c38e9cce5b..9800b1a00dc 100644 --- a/public/images/pokemon/variant/exp/back/4145.json +++ b/public/images/pokemon/variant/exp/back/4145.json @@ -1,28 +1,26 @@ { "1": { - "863716": "638295", - "5f2311": "364d62", - "de7333": "daf6f6", - "ab582b": "90b2c2", - "101010": "101010", - "38322d": "22253b", "50453c": "334c7f", - "3e352b": "1e2e5f", - "272320": "272320", + "863716": "7e98ad", + "ffd541": "f28b41", + "272320": "111742", + "38322d": "22253b", "de6e33": "d85b26", - "ffd541": "f28b41" + "c24814": "b3cdd9", + "3e352b": "1e2e5f", + "f76c1a": "daf6f6", + "5f2311": "5c6f8e" }, "2": { - "863716": "871858", - "5f2311": "630645", - "de7333": "e14589", - "ab582b": "ba276d", - "101010": "101010", - "38322d": "202231", "50453c": "d2ddea", - "3e352b": "7b899f", - "272320": "272320", + "863716": "871858", + "ffd541": "3cd96c", + "272320": "3c445e", + "38322d": "202231", "de6e33": "25b165", - "ffd541": "3cd96c" + "c24814": "ba276d", + "3e352b": "9da9bd", + "f76c1a": "e14589", + "5f2311": "630645" } } \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/4146.json b/public/images/pokemon/variant/exp/back/4146.json index 2b785a64f4b..56d19fe5bfa 100644 --- a/public/images/pokemon/variant/exp/back/4146.json +++ b/public/images/pokemon/variant/exp/back/4146.json @@ -1,34 +1,31 @@ { "1": { - "262e30": "000240", - "54656c": "163269", - "101010": "101010", - "35454b": "0d1e54", - "e82f46": "24a8d3", - "ffaed7": "a5f5e7", "ffd5ed": "e4fff6", - "f1587e": "73e1e6", - "6b8895": "2b5584", - "b51c2f": "77a7bb", "de384e": "cdf0f1", - "00bfbf": "ff78a6", + "35454d": "f774a0", + "6b8895": "2b5584", + "e82f46": "24a8d3", + "35454b": "0d1e54", "840017": "1f557c", - "28333a": "e04f8e" + "00bfbf": "ff78a6", + "b51c2f": "77a7bb", + "ffaed7": "a5f5e7", + "f1587e": "73e1e6", + "262e30": "000240", + "54656c": "163269" }, "2": { - "262e30": "262e30", - "54656c": "dae0a4", - "101010": "101010", - "35454b": "abbd6a", - "e82f46": "058323", - "ffaed7": "6acf42", "ffd5ed": "f4ff90", - "f1587e": "6acf42", - "6b8895": "fff9de", - "b51c2f": "004634", "de384e": "04723a", - "00bfbf": "db743c", + "35454d": "db743c", + "6b8895": "fff9de", + "e82f46": "058323", + "35454b": "adb981", "840017": "00312d", - "28333a": "db743c" + "00bfbf": "db7640", + "b51c2f": "004634", + "ffaed7": "c2f75f", + "f1587e": "6acf42", + "54656c": "e4e8bb" } } \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/6503.json b/public/images/pokemon/variant/exp/back/6503.json new file mode 100644 index 00000000000..a977e095e71 --- /dev/null +++ b/public/images/pokemon/variant/exp/back/6503.json @@ -0,0 +1,35 @@ +{ + "1": { + "181531": "a26579", + "fafcf9": "f6f4f4", + "84a4a7": "563785", + "a82c47": "d45b9e", + "8aa3a3": "d3a0bb", + "494a48": "3d2439", + "1d3962": "28142c", + "474a46": "2b1838", + "d75063": "b73891", + "6b1c34": "8f3396", + "1e224e": "dc95ae", + "1e5b9b": "4d244b", + "8da8a8": "a58b90", + "597471": "332a59", + "282f62": "f7d9de" + }, + "2": { + "181531": "715b72", + "fafcf9": "2c3940", + "84a4a7": "41857b", + "a82c47": "8abfb1", + "8aa3a3": "232d2e", + "494a48": "181f20", + "1d3962": "321e1e", + "474a46": "181f20", + "d75063": "8f65d8", + "6b1c34": "6d9d9a", + "1e224e": "ba9bc1", + "1e5b9b": "5e3e38", + "597471": "2a5c57", + "282f62": "efdfee" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/656.json b/public/images/pokemon/variant/exp/back/656.json new file mode 100644 index 00000000000..34b11bfab78 --- /dev/null +++ b/public/images/pokemon/variant/exp/back/656.json @@ -0,0 +1,24 @@ +{ + "1": { + "838394": "4d7dc5", + "7bcdff": "9c75c2", + "62ace6": "8363af", + "ffffff": "b1e5ff", + "396a83": "362864", + "9c9cc5": "5385c7", + "cdcde6": "7eb7e8", + "174592": "198158", + "5a94cd": "7054a4" + }, + "2": { + "838394": "cc6845", + "7bcdff": "dd6155", + "62ace6": "c44848", + "ffffff": "fff4bd", + "396a83": "5c0d33", + "9c9cc5": "c96a48", + "cdcde6": "f7b785", + "174592": "198158", + "5a94cd": "a92f3f" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/657.json b/public/images/pokemon/variant/exp/back/657.json new file mode 100644 index 00000000000..083a9dba0a6 --- /dev/null +++ b/public/images/pokemon/variant/exp/back/657.json @@ -0,0 +1,24 @@ +{ + "1": { + "f8f8f8": "8dcfff", + "737373": "0f3f82", + "0b566a": "281f52", + "002c58": "1c0726", + "bfbfbf": "4386df", + "006ba6": "4e1852", + "0b4a7a": "340f3d", + "41ccf5": "7755a7", + "2896b5": "4b3578" + }, + "2": { + "f8f8f8": "fff6c7", + "737373": "df6a50", + "0b566a": "7e1628", + "002c58": "0c3b54", + "bfbfbf": "ffc996", + "006ba6": "239c91", + "0b4a7a": "156f78", + "41ccf5": "dd7355", + "2896b5": "a92f3a" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/658-ash.json b/public/images/pokemon/variant/exp/back/658-ash.json new file mode 100644 index 00000000000..370d5df8081 --- /dev/null +++ b/public/images/pokemon/variant/exp/back/658-ash.json @@ -0,0 +1,38 @@ +{ + "1": { + "265595": "432b6c", + "de3431": "3fca9f", + "f8f8f8": "a1e9f0", + "7b282e": "0e3e81", + "6b1d1d": "206d74", + "134e52": "062e3c", + "bfb169": "165e78", + "ffb2bf": "b7e9ff", + "bf4c60": "4386df", + "282c35": "271f4c", + "f2798d": "8dcfff", + "268794": "1c3e58", + "3e7acc": "6b4592", + "7ddeff": "7ddcd6", + "4ebdd9": "41a7b0", + "18335c": "170738" + }, + "2": { + "265595": "cc7251", + "de3431": "9ceec6", + "f8f8f8": "89d2b8", + "7b282e": "152a5c", + "6b1d1d": "356e8d", + "134e52": "0d1e3e", + "bfb169": "4d2637", + "ffb2bf": "86d6b6", + "bf4c60": "32738b", + "282c35": "4d2637", + "f2798d": "5eb4a9", + "268794": "1c3e58", + "3e7acc": "ecbb7a", + "7ddeff": "46988d", + "4ebdd9": "2f6e74", + "18335c": "9f2727" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/658.json b/public/images/pokemon/variant/exp/back/658.json new file mode 100644 index 00000000000..c1bb4222ce4 --- /dev/null +++ b/public/images/pokemon/variant/exp/back/658.json @@ -0,0 +1,26 @@ +{ + "1": { + "ffb2bf": "b7e9ff", + "bf4c60": "4386df", + "3d61cc": "6b4592", + "fff0a6": "208698", + "2e4999": "432b6c", + "f2798d": "8dcfff", + "803340": "0e3e81", + "1b2a59": "170738", + "66d9ff": "7ddcd6", + "bfb169": "165e78" + }, + "2": { + "ffb2bf": "86d6b6", + "bf4c60": "32738b", + "3d61cc": "ecbb7a", + "fff0a6": "652240", + "2e4999": "cc7251", + "f2798d": "5eb4a9", + "803340": "152a5c", + "1b2a59": "9f2727", + "66d9ff": "48968c", + "bfb169": "431022" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/6706.json b/public/images/pokemon/variant/exp/back/6706.json new file mode 100644 index 00000000000..2de5352e936 --- /dev/null +++ b/public/images/pokemon/variant/exp/back/6706.json @@ -0,0 +1,38 @@ +{ + "1": { + "566678": "197497", + "8e96aa": "3b235c", + "929aad": "3aa8c4", + "625287": "4e4094", + "536273": "301848", + "988b98": "b24c86", + "36404c": "0c5474", + "c4cce1": "513981", + "e6d3e9": "f1a4c5", + "bfacc1": "d074a0", + "546475": "0e6296", + "c5cee3": "63cee1", + "80737f": "8a2166", + "4b454f": "6f1357", + "9170b9": "8b69c3", + "b791f2": "c7a1e5" + }, + "2": { + "566678": "a34205", + "8e96aa": "073338", + "929aad": "d27e26", + "625287": "0e3f47", + "536273": "042329", + "988b98": "2b736f", + "36404c": "842401", + "c4cce1": "0d484a", + "e6d3e9": "9cead8", + "bfacc1": "5db6a9", + "546475": "8e480b", + "c5cee3": "f7af58", + "80737f": "194f51", + "4b454f": "274159", + "9170b9": "2f667c", + "b791f2": "4a9699" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/6706_2.json b/public/images/pokemon/variant/exp/back/6706_2.json deleted file mode 100644 index 5c916aeb664..00000000000 --- a/public/images/pokemon/variant/exp/back/6706_2.json +++ /dev/null @@ -1,776 +0,0 @@ -{ - "textures": [ - { - "image": "6706_2.png", - "format": "RGBA8888", - "size": { - "w": 358, - "h": 358 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 0, - "y": 4, - "w": 84, - "h": 69 - }, - "frame": { - "x": 0, - "y": 0, - "w": 84, - "h": 69 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 0, - "y": 4, - "w": 84, - "h": 69 - }, - "frame": { - "x": 0, - "y": 0, - "w": 84, - "h": 69 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 3, - "y": 1, - "w": 83, - "h": 72 - }, - "frame": { - "x": 84, - "y": 0, - "w": 83, - "h": 72 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 3, - "y": 1, - "w": 83, - "h": 72 - }, - "frame": { - "x": 84, - "y": 0, - "w": 83, - "h": 72 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 3, - "y": 1, - "w": 83, - "h": 72 - }, - "frame": { - "x": 0, - "y": 69, - "w": 83, - "h": 72 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 2, - "y": 3, - "w": 83, - "h": 70 - }, - "frame": { - "x": 167, - "y": 0, - "w": 83, - "h": 70 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 2, - "y": 3, - "w": 83, - "h": 70 - }, - "frame": { - "x": 167, - "y": 0, - "w": 83, - "h": 70 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 2, - "y": 3, - "w": 83, - "h": 70 - }, - "frame": { - "x": 250, - "y": 0, - "w": 83, - "h": 70 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 2, - "y": 3, - "w": 83, - "h": 70 - }, - "frame": { - "x": 250, - "y": 0, - "w": 83, - "h": 70 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 4, - "y": 0, - "w": 82, - "h": 73 - }, - "frame": { - "x": 167, - "y": 70, - "w": 82, - "h": 73 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 4, - "y": 0, - "w": 82, - "h": 73 - }, - "frame": { - "x": 167, - "y": 70, - "w": 82, - "h": 73 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 82, - "h": 73 - }, - "frame": { - "x": 83, - "y": 72, - "w": 82, - "h": 73 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 82, - "h": 73 - }, - "frame": { - "x": 83, - "y": 72, - "w": 82, - "h": 73 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 82, - "h": 73 - }, - "frame": { - "x": 0, - "y": 141, - "w": 82, - "h": 73 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 82, - "h": 73 - }, - "frame": { - "x": 0, - "y": 141, - "w": 82, - "h": 73 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 82, - "h": 73 - }, - "frame": { - "x": 0, - "y": 141, - "w": 82, - "h": 73 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 4, - "y": 0, - "w": 82, - "h": 73 - }, - "frame": { - "x": 249, - "y": 70, - "w": 82, - "h": 73 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 4, - "y": 0, - "w": 82, - "h": 73 - }, - "frame": { - "x": 249, - "y": 70, - "w": 82, - "h": 73 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 5, - "y": 0, - "w": 81, - "h": 73 - }, - "frame": { - "x": 0, - "y": 214, - "w": 81, - "h": 73 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 5, - "y": 0, - "w": 81, - "h": 73 - }, - "frame": { - "x": 0, - "y": 214, - "w": 81, - "h": 73 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 81, - "h": 71 - }, - "frame": { - "x": 0, - "y": 287, - "w": 81, - "h": 71 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 81, - "h": 71 - }, - "frame": { - "x": 0, - "y": 287, - "w": 81, - "h": 71 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 5, - "y": 0, - "w": 81, - "h": 73 - }, - "frame": { - "x": 81, - "y": 214, - "w": 81, - "h": 73 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 5, - "y": 0, - "w": 81, - "h": 73 - }, - "frame": { - "x": 81, - "y": 214, - "w": 81, - "h": 73 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 81, - "h": 71 - }, - "frame": { - "x": 81, - "y": 287, - "w": 81, - "h": 71 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 81, - "h": 71 - }, - "frame": { - "x": 81, - "y": 287, - "w": 81, - "h": 71 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 82, - "h": 72 - }, - "frame": { - "x": 165, - "y": 143, - "w": 82, - "h": 72 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 82, - "h": 72 - }, - "frame": { - "x": 165, - "y": 143, - "w": 82, - "h": 72 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 82, - "h": 72 - }, - "frame": { - "x": 247, - "y": 143, - "w": 82, - "h": 72 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 82, - "h": 72 - }, - "frame": { - "x": 247, - "y": 143, - "w": 82, - "h": 72 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 6, - "y": 0, - "w": 80, - "h": 73 - }, - "frame": { - "x": 162, - "y": 215, - "w": 80, - "h": 73 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 6, - "y": 0, - "w": 80, - "h": 73 - }, - "frame": { - "x": 162, - "y": 215, - "w": 80, - "h": 73 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 81, - "h": 70 - }, - "frame": { - "x": 162, - "y": 288, - "w": 81, - "h": 70 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 81, - "h": 70 - }, - "frame": { - "x": 162, - "y": 288, - "w": 81, - "h": 70 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 6, - "y": 0, - "w": 80, - "h": 73 - }, - "frame": { - "x": 242, - "y": 215, - "w": 80, - "h": 73 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 6, - "y": 0, - "w": 80, - "h": 73 - }, - "frame": { - "x": 242, - "y": 215, - "w": 80, - "h": 73 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:5d65e2c5a6a97b7c7014a175ce3592af:3255e87f637a475d82734fc7d93baf71:d60cc2e5ae2bd18de8ee3ab0649593ee$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/6706_2.png b/public/images/pokemon/variant/exp/back/6706_2.png deleted file mode 100644 index cb793478420..00000000000 Binary files a/public/images/pokemon/variant/exp/back/6706_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/6706_3.json b/public/images/pokemon/variant/exp/back/6706_3.json deleted file mode 100644 index 3bb1dc426b2..00000000000 --- a/public/images/pokemon/variant/exp/back/6706_3.json +++ /dev/null @@ -1,776 +0,0 @@ -{ - "textures": [ - { - "image": "6706_3.png", - "format": "RGBA8888", - "size": { - "w": 358, - "h": 358 - }, - "scale": 1, - "frames": [ - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 0, - "y": 4, - "w": 84, - "h": 69 - }, - "frame": { - "x": 0, - "y": 0, - "w": 84, - "h": 69 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 0, - "y": 4, - "w": 84, - "h": 69 - }, - "frame": { - "x": 0, - "y": 0, - "w": 84, - "h": 69 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 3, - "y": 1, - "w": 83, - "h": 72 - }, - "frame": { - "x": 84, - "y": 0, - "w": 83, - "h": 72 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 3, - "y": 1, - "w": 83, - "h": 72 - }, - "frame": { - "x": 84, - "y": 0, - "w": 83, - "h": 72 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 3, - "y": 1, - "w": 83, - "h": 72 - }, - "frame": { - "x": 0, - "y": 69, - "w": 83, - "h": 72 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 2, - "y": 3, - "w": 83, - "h": 70 - }, - "frame": { - "x": 167, - "y": 0, - "w": 83, - "h": 70 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 2, - "y": 3, - "w": 83, - "h": 70 - }, - "frame": { - "x": 167, - "y": 0, - "w": 83, - "h": 70 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 2, - "y": 3, - "w": 83, - "h": 70 - }, - "frame": { - "x": 250, - "y": 0, - "w": 83, - "h": 70 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 2, - "y": 3, - "w": 83, - "h": 70 - }, - "frame": { - "x": 250, - "y": 0, - "w": 83, - "h": 70 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 4, - "y": 0, - "w": 82, - "h": 73 - }, - "frame": { - "x": 167, - "y": 70, - "w": 82, - "h": 73 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 4, - "y": 0, - "w": 82, - "h": 73 - }, - "frame": { - "x": 167, - "y": 70, - "w": 82, - "h": 73 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 82, - "h": 73 - }, - "frame": { - "x": 83, - "y": 72, - "w": 82, - "h": 73 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 82, - "h": 73 - }, - "frame": { - "x": 83, - "y": 72, - "w": 82, - "h": 73 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 82, - "h": 73 - }, - "frame": { - "x": 0, - "y": 141, - "w": 82, - "h": 73 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 82, - "h": 73 - }, - "frame": { - "x": 0, - "y": 141, - "w": 82, - "h": 73 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 3, - "y": 0, - "w": 82, - "h": 73 - }, - "frame": { - "x": 0, - "y": 141, - "w": 82, - "h": 73 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 4, - "y": 0, - "w": 82, - "h": 73 - }, - "frame": { - "x": 249, - "y": 70, - "w": 82, - "h": 73 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 4, - "y": 0, - "w": 82, - "h": 73 - }, - "frame": { - "x": 249, - "y": 70, - "w": 82, - "h": 73 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 5, - "y": 0, - "w": 81, - "h": 73 - }, - "frame": { - "x": 0, - "y": 214, - "w": 81, - "h": 73 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 5, - "y": 0, - "w": 81, - "h": 73 - }, - "frame": { - "x": 0, - "y": 214, - "w": 81, - "h": 73 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 81, - "h": 71 - }, - "frame": { - "x": 0, - "y": 287, - "w": 81, - "h": 71 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 81, - "h": 71 - }, - "frame": { - "x": 0, - "y": 287, - "w": 81, - "h": 71 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 5, - "y": 0, - "w": 81, - "h": 73 - }, - "frame": { - "x": 81, - "y": 214, - "w": 81, - "h": 73 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 5, - "y": 0, - "w": 81, - "h": 73 - }, - "frame": { - "x": 81, - "y": 214, - "w": 81, - "h": 73 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 81, - "h": 71 - }, - "frame": { - "x": 81, - "y": 287, - "w": 81, - "h": 71 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 1, - "y": 2, - "w": 81, - "h": 71 - }, - "frame": { - "x": 81, - "y": 287, - "w": 81, - "h": 71 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 82, - "h": 72 - }, - "frame": { - "x": 165, - "y": 143, - "w": 82, - "h": 72 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 82, - "h": 72 - }, - "frame": { - "x": 165, - "y": 143, - "w": 82, - "h": 72 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 82, - "h": 72 - }, - "frame": { - "x": 247, - "y": 143, - "w": 82, - "h": 72 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 2, - "y": 1, - "w": 82, - "h": 72 - }, - "frame": { - "x": 247, - "y": 143, - "w": 82, - "h": 72 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 6, - "y": 0, - "w": 80, - "h": 73 - }, - "frame": { - "x": 162, - "y": 215, - "w": 80, - "h": 73 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 6, - "y": 0, - "w": 80, - "h": 73 - }, - "frame": { - "x": 162, - "y": 215, - "w": 80, - "h": 73 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 81, - "h": 70 - }, - "frame": { - "x": 162, - "y": 288, - "w": 81, - "h": 70 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 81, - "h": 70 - }, - "frame": { - "x": 162, - "y": 288, - "w": 81, - "h": 70 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 6, - "y": 0, - "w": 80, - "h": 73 - }, - "frame": { - "x": 242, - "y": 215, - "w": 80, - "h": 73 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 86, - "h": 73 - }, - "spriteSourceSize": { - "x": 6, - "y": 0, - "w": 80, - "h": 73 - }, - "frame": { - "x": 242, - "y": 215, - "w": 80, - "h": 73 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:5d65e2c5a6a97b7c7014a175ce3592af:3255e87f637a475d82734fc7d93baf71:d60cc2e5ae2bd18de8ee3ab0649593ee$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/6706_3.png b/public/images/pokemon/variant/exp/back/6706_3.png deleted file mode 100644 index 6390c20799f..00000000000 Binary files a/public/images/pokemon/variant/exp/back/6706_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/676.json b/public/images/pokemon/variant/exp/back/676.json new file mode 100644 index 00000000000..7e64f6b0f61 --- /dev/null +++ b/public/images/pokemon/variant/exp/back/676.json @@ -0,0 +1,21 @@ +{ + "1": { + "f2f2da": "8a1d1d", + "3f6273": "2b040f", + "595350": "788087", + "736b67": "a6afb3", + "ccccb8": "5e0f16", + "66665c": "2b040f", + "a6a695": "42090e" + }, + "2": { + "cc2929": "3a240e", + "f2f2da": "c18960", + "3f6273": "4a281b", + "595350": "e6c594", + "736b67": "ffe6ac", + "ccccb8": "a4624a", + "66665c": "4a281b", + "a6a695": "805145" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/682.json b/public/images/pokemon/variant/exp/back/682.json new file mode 100644 index 00000000000..bc2111153cf --- /dev/null +++ b/public/images/pokemon/variant/exp/back/682.json @@ -0,0 +1,21 @@ +{ + "1": { + "6b3962": "30185d", + "cc7087": "318759", + "993d80": "4f297e", + "ff99b3": "48ab61", + "7f4d59": "20644e", + "4d4d4d": "a6a6a6" + }, + "2": { + "4f4c4f": "332539", + "6b3962": "b89477", + "cc7087": "c3561a", + "993d80": "d2bfa1", + "ff99b3": "da7e29", + "7f4d59": "a23812", + "e5e5e5": "6b4767", + "4d4d4d": "503851", + "737373": "422f46" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/683.json b/public/images/pokemon/variant/exp/back/683.json new file mode 100644 index 00000000000..9d7f4682b9a --- /dev/null +++ b/public/images/pokemon/variant/exp/back/683.json @@ -0,0 +1,20 @@ +{ + "1": { + "6b3962": "30185d", + "cc7087": "318759", + "993d80": "4f297e", + "ff99b3": "48ab61", + "404040": "2c283b", + "7f4d59": "20644e", + "bf5f9f": "7c48a1" + }, + "2": { + "6b3962": "b89477", + "cc7087": "c3561a", + "993d80": "d2bfa1", + "ff99b3": "da7e29", + "404040": "2a2234", + "7f4d59": "a23812", + "bf5f9f": "f0ebdd" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/684.json b/public/images/pokemon/variant/exp/back/684.json new file mode 100644 index 00000000000..25de3aa838f --- /dev/null +++ b/public/images/pokemon/variant/exp/back/684.json @@ -0,0 +1,22 @@ +{ + "1": { + "805963": "2d0c42", + "553a41": "8f1d15", + "ffccd9": "8961c6", + "cc99a6": "613b84", + "fff2f2": "f39f62", + "5e4048": "260b37", + "ccadad": "df6b40", + "7b5760": "b13924" + }, + "2": { + "805963": "6796aa", + "553a41": "1d1426", + "ffccd9": "cbf6da", + "cc99a6": "93d6ce", + "fff2f2": "746998", + "5e4048": "52718e", + "ccadad": "4b4876", + "7b5760": "3c2f51" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/685.json b/public/images/pokemon/variant/exp/back/685.json new file mode 100644 index 00000000000..a144e0d45ff --- /dev/null +++ b/public/images/pokemon/variant/exp/back/685.json @@ -0,0 +1,26 @@ +{ + "1": { + "f8f8f8": "caff90", + "661a2d": "13391c", + "805963": "2d0c42", + "ffccd9": "8961c6", + "ff8ca9": "8dbe6d", + "cc99a6": "613b84", + "e53964": "689b52", + "fff2f2": "f39f62", + "ccadad": "df6b40", + "a62949": "26592b" + }, + "2": { + "f8f8f8": "e4819d", + "661a2d": "26061b", + "805963": "679baa", + "ffccd9": "cbf6da", + "ff8ca9": "8c4264", + "cc99a6": "93d6ce", + "e53964": "612747", + "fff2f2": "746998", + "ccadad": "4b4876", + "a62949": "441838" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/688.json b/public/images/pokemon/variant/exp/back/688.json new file mode 100644 index 00000000000..e3d15e60fed --- /dev/null +++ b/public/images/pokemon/variant/exp/back/688.json @@ -0,0 +1,30 @@ +{ + "1": { + "bfeaff": "e8d37b", + "f2f2f2": "e8e5c6", + "5b8da6": "a9582e", + "595959": "7c582e", + "403410": "220a56", + "3f6273": "70240f", + "b3b3b3": "d3bc8c", + "ffac59": "70cccf", + "85b4cc": "cd8a50", + "997e2e": "4557b5", + "cc8a47": "459aac", + "66541f": "373295" + }, + "2": { + "bfeaff": "a74083", + "f2f2f2": "d1ec8c", + "5b8da6": "4b0038", + "595959": "4d6a09", + "403410": "1e1324", + "3f6273": "2c052a", + "b3b3b3": "94c268", + "ffac59": "4a376e", + "85b4cc": "731f5c", + "997e2e": "f6eefc", + "cc8a47": "332149", + "66541f": "ba9fba" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/689.json b/public/images/pokemon/variant/exp/back/689.json new file mode 100644 index 00000000000..6c47b57f35b --- /dev/null +++ b/public/images/pokemon/variant/exp/back/689.json @@ -0,0 +1,31 @@ +{ + "1": { + "cc7f70": "459aac", + "f2f2f2": "e8e5c6", + "5b8da6": "8d5030", + "595959": "7c582e", + "403410": "220a56", + "3f6273": "672e1e", + "b3b3b3": "d3bc8c", + "bfeaff": "e8d37b", + "85b4cc": "cd8a50", + "ff9f8c": "70cccf", + "66541f": "373295", + "997e2e": "4557b5" + }, + "2": { + "cc7f70": "332149", + "f2f2f2": "caea77", + "5b8da6": "4b0038", + "595959": "2a5524", + "403410": "3f2a4b", + "3f6273": "3e073b", + "b3b3b3": "7eac4e", + "bfeaff": "a74083", + "85b4cc": "731f5c", + "f8f8f8": "dbaf67", + "ff9f8c": "4a376e", + "66541f": "ccb6cc", + "997e2e": "f6eefc" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/696.json b/public/images/pokemon/variant/exp/back/696.json new file mode 100644 index 00000000000..b58bfea922f --- /dev/null +++ b/public/images/pokemon/variant/exp/back/696.json @@ -0,0 +1,35 @@ +{ + "1": { + "734517":"5e0b0b", + "ffa64c":"a50d0d", + "3e1f18":"023425", + "966858":"1b6430", + "404040":"4c3216", + "65483a":"0b4c29", + "101010":"101010", + "f8f8f8":"dfdea7", + "bfbfbf":"cbbe8c", + "8c8c8c":"ad8c63", + "121212":"121212", + "bdbdbd":"c9bd8b", + "f5f5f5":"dbdaa4", + "b73b6b":"77452d" + }, + "2": { + "734517":"395cb7", + "ffa64c":"d2e9ff", + "3e1f18":"3e1f18", + "966858":"83726e", + "404040":"250860", + "65483a":"644943", + "101010":"101010", + "f8f8f8":"6e46a7", + "bfbfbf":"593097", + "8c8c8c":"411684", + "121212":"decaff", + "bdbdbd":"79c8d3", + "f5f5f5":"cce6ff", + "b73b6b":"385cb5" + } +} + diff --git a/public/images/pokemon/variant/exp/back/697.json b/public/images/pokemon/variant/exp/back/697.json index edb368cc0fc..61a5f16551b 100644 --- a/public/images/pokemon/variant/exp/back/697.json +++ b/public/images/pokemon/variant/exp/back/697.json @@ -1,18 +1,37 @@ { "1": { - "653510": "5e0b0b", - "443e3c": "4c3216", - "e39f33": "b52424", - "f0f0f2": "dfdea7", - "b56726": "971c1c", - "471515": "080808", - "b45250": "285234", - "902f2d": "153626", - "adaaae": "cbbe8c", - "756b66": "ad8c63", - "46413f": "4c3216", - "766c67": "ad8c63", - "621e1d": "0b241e", - "b56827": "971c1c" + "080808":"080808", + "621e1d":"0b241e", + "902f2d":"153626", + "b45250":"285234", + "653510":"5e0b0b", + "b56827":"971c1c", + "e39f33":"b52424", + "46413f":"4c3216", + "766c67":"ad8c63", + "adaaae":"cbbe8c", + "f0f0f2":"dfdea7", + "3d3937":"ab8a61", + "786d68":"cfc28f", + "afacb0":"c9bd8b", + "ededf0":"e0dfa8" + }, + "2": { + "080808":"080808", + "621e1d":"52352f", + "902f2d":"83726e", + "b45250":"ab9b97", + "653510":"9d5390", + "b56827":"ce7ecc", + "e39f33":"f4dbf6", + "46413f":"170c25", + "766c67":"26173b", + "adaaae":"33214f", + "f0f0f2":"4b2e64", + "3d3937":"c97bc7", + "786d68":"e5a9ea", + "afacb0":"d180ce", + "ededf0":"ededf0" } -} \ No newline at end of file +} + diff --git a/public/images/pokemon/variant/exp/back/773-bug.json b/public/images/pokemon/variant/exp/back/773-bug.json new file mode 100644 index 00000000000..bcd2bdc015f --- /dev/null +++ b/public/images/pokemon/variant/exp/back/773-bug.json @@ -0,0 +1,44 @@ +{ + "1": { + "41ac36": "44b3aa", + "0073bf": "7a4949", + "e64f5e": "f1944a", + "1e9378": "f8ce64", + "9618e0": "dc9c4d", + "aba7bc": "493d55", + "b7e586": "f4ff9c", + "3f3b50": "1e172a", + "73c956": "99d569", + "5399df": "b59489", + "297321": "267763", + "125d4b": "ce7f3f", + "73c957": "73c956", + "251845": "753c32", + "79615e": "504a75", + "565969": "30365c", + "bcbbc5": "788fb5", + "483c39": "3a2d53", + "e3e6ec": "bdd1e5" + }, + "2": { + "41ac36": "92d374", + "0073bf": "6a6c75", + "e64f5e": "98ce58", + "1e9378": "73c956", + "9618e0": "ade265", + "aba7bc": "dbd8e8", + "b7e586": "ababab", + "73c956": "e7eef2", + "5399df": "92949e", + "297321": "3d5542", + "125d4b": "317e27", + "73c957": "73c956", + "251845": "3d5542", + "79615e": "d6d4d4", + "1d1845": "41434e", + "565969": "0f0f1b", + "bcbbc5": "242433", + "483c39": "778894", + "e3e6ec": "444455" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-bug_2.json b/public/images/pokemon/variant/exp/back/773-bug_2.json deleted file mode 100644 index 4b57edfb1df..00000000000 --- a/public/images/pokemon/variant/exp/back/773-bug_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-bug_2.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:cc6f9e1f7b1c88ec3accff83c0b55beb:2556df34a2fde34fd4ed8dcbc56982fa:1786a671c3b9676c87853a0a70567554$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-bug_2.png b/public/images/pokemon/variant/exp/back/773-bug_2.png deleted file mode 100644 index 3be9f5a7f22..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-bug_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-bug_3.json b/public/images/pokemon/variant/exp/back/773-bug_3.json deleted file mode 100644 index e76a73d5523..00000000000 --- a/public/images/pokemon/variant/exp/back/773-bug_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-bug_3.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:cc6f9e1f7b1c88ec3accff83c0b55beb:2556df34a2fde34fd4ed8dcbc56982fa:1786a671c3b9676c87853a0a70567554$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-bug_3.png b/public/images/pokemon/variant/exp/back/773-bug_3.png deleted file mode 100644 index 13c6e2b5274..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-bug_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-dark.json b/public/images/pokemon/variant/exp/back/773-dark.json new file mode 100644 index 00000000000..2e7bb88fb16 --- /dev/null +++ b/public/images/pokemon/variant/exp/back/773-dark.json @@ -0,0 +1,45 @@ +{ + "1": { + "e64f5e": "f1944a", + "bcbbc5": "788fb5", + "9618e0": "dc9c4d", + "565969": "30365c", + "1e9378": "f8ce64", + "0073bf": "7a4949", + "332327": "512351", + "574647": "655454", + "125d4b": "ce7f3f", + "21151a": "250d25", + "79615e": "504a75", + "5399df": "b59489", + "3f3b50": "1e172a", + "251845": "753c32", + "574646": "735c5c", + "aba7bc": "493d55", + "8a7d7a": "dcc0b2", + "e3e6ec": "bdd1e5", + "483c39": "3a2d53", + "1d1845": "2e191f" + }, + "2": { + "e64f5e": "98ce58", + "bcbbc5": "242433", + "9618e0": "ade265", + "565969": "0f0f1b", + "1e9378": "574646", + "0073bf": "6a6c75", + "332327": "f2cc45", + "574647": "574646", + "125d4b": "3b282a", + "21151a": "494057", + "79615e": "d6d4d4", + "5399df": "92949e", + "251845": "425735", + "574646": "f0f7fb", + "aba7bc": "dbd8e8", + "8a7d7a": "9360c8", + "e3e6ec": "444455", + "483c39": "778894", + "1d1845": "41434e" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-dark_2.json b/public/images/pokemon/variant/exp/back/773-dark_2.json deleted file mode 100644 index 0a067f30361..00000000000 --- a/public/images/pokemon/variant/exp/back/773-dark_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-dark_2.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:1a47341c624818bb2b8ddb5e70ff16d0:111d4a9df8316c4e1d32d2a93b5ec0f1:267125b3b5f5d18142ae5fffbef27592$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-dark_2.png b/public/images/pokemon/variant/exp/back/773-dark_2.png deleted file mode 100644 index fbcf144f4f0..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-dark_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-dark_3.json b/public/images/pokemon/variant/exp/back/773-dark_3.json deleted file mode 100644 index 846af3d6560..00000000000 --- a/public/images/pokemon/variant/exp/back/773-dark_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-dark_3.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:1a47341c624818bb2b8ddb5e70ff16d0:111d4a9df8316c4e1d32d2a93b5ec0f1:267125b3b5f5d18142ae5fffbef27592$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-dark_3.png b/public/images/pokemon/variant/exp/back/773-dark_3.png deleted file mode 100644 index 0c56d7bf8ff..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-dark_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-dragon.json b/public/images/pokemon/variant/exp/back/773-dragon.json new file mode 100644 index 00000000000..eccb031b1a4 --- /dev/null +++ b/public/images/pokemon/variant/exp/back/773-dragon.json @@ -0,0 +1,45 @@ +{ + "1": { + "1975a3": "756cc8", + "14487e": "3f4085", + "251845": "753c32", + "6ee0e8": "c1ffd7", + "1d1845": "2e191f", + "3f3b50": "1e172a", + "aba7bc": "493d55", + "e64f5e": "f1944a", + "9618e0": "dc9c4d", + "125d4b": "ce7f3f", + "1e9378": "f8ce64", + "79615e": "504a75", + "5399df": "b59489", + "565969": "30365c", + "bcbbc5": "788fb5", + "1eadd2": "37b5be", + "0073bf": "7a4949", + "e3e6ec": "bdd1e5", + "1eadd1": "2fd0da", + "483c39": "3a2d53" + }, + "2": { + "1975a3": "61c5ff", + "14487e": "3e354e", + "251845": "425735", + "6ee0e8": "ffffff", + "1d1845": "41434e", + "aba7bc": "dbd8e8", + "e64f5e": "98ce58", + "9618e0": "ade265", + "125d4b": "0f5493", + "1e9378": "1eadd1", + "79615e": "d6d4d4", + "5399df": "92949e", + "565969": "0f0f1b", + "bcbbc5": "242433", + "1eadd2": "1eadd1", + "0073bf": "6a6c75", + "e3e6ec": "444455", + "1eadd1": "ffa1ec", + "483c39": "778894" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-dragon_2.json b/public/images/pokemon/variant/exp/back/773-dragon_2.json deleted file mode 100644 index c1ef79e0cd2..00000000000 --- a/public/images/pokemon/variant/exp/back/773-dragon_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-dragon_2.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:b9aa0234511bbc7c93c7668482879ef9:b376eee3a7c33ea1e5e2165c883ba8f3:59453f2ad0e681735b3b15ab728caa7c$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-dragon_2.png b/public/images/pokemon/variant/exp/back/773-dragon_2.png deleted file mode 100644 index 8ff8380a724..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-dragon_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-dragon_3.json b/public/images/pokemon/variant/exp/back/773-dragon_3.json deleted file mode 100644 index 812d14c1adb..00000000000 --- a/public/images/pokemon/variant/exp/back/773-dragon_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-dragon_3.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:b9aa0234511bbc7c93c7668482879ef9:b376eee3a7c33ea1e5e2165c883ba8f3:59453f2ad0e681735b3b15ab728caa7c$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-dragon_3.png b/public/images/pokemon/variant/exp/back/773-dragon_3.png deleted file mode 100644 index fc476dc8f0a..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-dragon_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-electric.json b/public/images/pokemon/variant/exp/back/773-electric.json new file mode 100644 index 00000000000..ed972b10127 --- /dev/null +++ b/public/images/pokemon/variant/exp/back/773-electric.json @@ -0,0 +1,45 @@ +{ + "1": { + "aba7bc": "493d55", + "e64f5e": "f1944a", + "1d1845": "2e191f", + "f8ffc5": "fdfee0", + "5399df": "b59489", + "e3e6ec": "bdd1e5", + "1e9378": "f8ce64", + "f5eb18": "faf256", + "0073bf": "7a4949", + "483c39": "3a2d53", + "8e6113": "a55a50", + "125d4b": "ce7f3f", + "3f3b50": "1e172a", + "ca972c": "ff935c", + "565969": "30365c", + "9618e0": "dc9c4d", + "251845": "753c32", + "bcbbc5": "788fb5", + "79615e": "504a75", + "f5eb19": "fff97e" + }, + "2": { + "aba7bc": "dbd8e8", + "e64f5e": "98ce58", + "1d1845": "41434e", + "f8ffc5": "ffd900", + "5399df": "92949e", + "e3e6ec": "444455", + "1e9378": "f5eb18", + "f5eb18": "864593", + "0073bf": "6a6c75", + "483c39": "778894", + "8e6113": "422a45", + "125d4b": "b3620e", + "ca972c": "ffd900", + "565969": "0f0f1b", + "9618e0": "ade265", + "251845": "425735", + "bcbbc5": "242433", + "79615e": "d6d4d4", + "f5eb19": "f5eb18" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-electric_2.json b/public/images/pokemon/variant/exp/back/773-electric_2.json deleted file mode 100644 index ae9a63905fe..00000000000 --- a/public/images/pokemon/variant/exp/back/773-electric_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-electric_2.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:a7971d80066edd2518184e437f177a6f:0acf2e3142ccc10310889552f5c5c56e:e9f7f627b4aa057d8a352e938221d903$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-electric_2.png b/public/images/pokemon/variant/exp/back/773-electric_2.png deleted file mode 100644 index 94cd6d77a30..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-electric_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-electric_3.json b/public/images/pokemon/variant/exp/back/773-electric_3.json deleted file mode 100644 index 49373baafc3..00000000000 --- a/public/images/pokemon/variant/exp/back/773-electric_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-electric_3.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:a7971d80066edd2518184e437f177a6f:0acf2e3142ccc10310889552f5c5c56e:e9f7f627b4aa057d8a352e938221d903$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-electric_3.png b/public/images/pokemon/variant/exp/back/773-electric_3.png deleted file mode 100644 index e54715131af..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-electric_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-fairy.json b/public/images/pokemon/variant/exp/back/773-fairy.json new file mode 100644 index 00000000000..27f96ca115c --- /dev/null +++ b/public/images/pokemon/variant/exp/back/773-fairy.json @@ -0,0 +1,45 @@ +{ + "1": { + "a15296": "833671", + "ffe8ef": "fce9c7", + "e3e6ec": "bdd1e5", + "125d4b": "ce7f3f", + "1e9378": "f8ce64", + "9618e0": "dc9c4d", + "251845": "753c32", + "79615e": "504a75", + "bcbbc5": "788fb5", + "5399df": "b59489", + "1d1845": "2e191f", + "565969": "30365c", + "f9bfe0": "ecaecb", + "e64f5e": "f1944a", + "483c39": "3a2d53", + "aba7bc": "493d55", + "f9bfe1": "e5a5c9", + "3f3b50": "1e172a", + "e183c7": "d3559a", + "0073bf": "7a4949" + }, + "2": { + "a15296": "3f3b50", + "ffe8ef": "acb4bd", + "e3e6ec": "444455", + "125d4b": "ad628c", + "1e9378": "f9bfe0", + "9618e0": "ade265", + "251845": "425735", + "79615e": "d6d4d4", + "bcbbc5": "242433", + "5399df": "92949e", + "1d1845": "41434e", + "565969": "0f0f1b", + "f9bfe0": "f0f7fb", + "e64f5e": "98ce58", + "483c39": "778894", + "aba7bc": "dbd8e8", + "f9bfe1": "f9bfe0", + "e183c7": "fca4ea", + "0073bf": "6a6c75" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-fairy_2.json b/public/images/pokemon/variant/exp/back/773-fairy_2.json deleted file mode 100644 index cac13eb5b34..00000000000 --- a/public/images/pokemon/variant/exp/back/773-fairy_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-fairy_2.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:5e1c3a760868419260d9e8a02c56af28:56214faae85a6e93b04d271a6befaf4b:50e5ca45ea677d44a2fea72d4ec14fc2$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-fairy_2.png b/public/images/pokemon/variant/exp/back/773-fairy_2.png deleted file mode 100644 index 1f7fe16a3d4..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-fairy_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-fairy_3.json b/public/images/pokemon/variant/exp/back/773-fairy_3.json deleted file mode 100644 index 1524f32b9db..00000000000 --- a/public/images/pokemon/variant/exp/back/773-fairy_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-fairy_3.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:5e1c3a760868419260d9e8a02c56af28:56214faae85a6e93b04d271a6befaf4b:50e5ca45ea677d44a2fea72d4ec14fc2$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-fairy_3.png b/public/images/pokemon/variant/exp/back/773-fairy_3.png deleted file mode 100644 index 578dba2dfc6..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-fairy_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-fighting.json b/public/images/pokemon/variant/exp/back/773-fighting.json new file mode 100644 index 00000000000..c29d7e645b5 --- /dev/null +++ b/public/images/pokemon/variant/exp/back/773-fighting.json @@ -0,0 +1,45 @@ +{ + "1": { + "f8b076": "ffcd8a", + "125d4b": "ce7f3f", + "1e9378": "f8ce64", + "f18a37": "e37637", + "251845": "753c32", + "f18a36": "f1964c", + "1d1845": "2e191f", + "483c39": "3a2d53", + "5399df": "b59489", + "d55223": "da4b2f", + "e3e6ec": "bdd1e5", + "aba7bc": "493d55", + "79615e": "504a75", + "0073bf": "7a4949", + "a34828": "a33b26", + "e64f5e": "f1944a", + "9618e0": "dc9c4d", + "bcbbc5": "788fb5", + "565969": "30365c", + "3f3b50": "1e172a" + }, + "2": { + "f8b076": "65abdb", + "125d4b": "b8411d", + "1e9378": "f18a36", + "f18a37": "f18a36", + "251845": "425735", + "f18a36": "e7eef2", + "1d1845": "41434e", + "483c39": "778894", + "5399df": "92949e", + "d55223": "eccd00", + "e3e6ec": "444455", + "aba7bc": "dbd8e8", + "79615e": "d6d4d4", + "0073bf": "6a6c75", + "a34828": "2f4453", + "e64f5e": "98ce58", + "9618e0": "ade265", + "bcbbc5": "242433", + "565969": "0f0f1b" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-fighting_2.json b/public/images/pokemon/variant/exp/back/773-fighting_2.json deleted file mode 100644 index ee3e8997f86..00000000000 --- a/public/images/pokemon/variant/exp/back/773-fighting_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-fighting_2.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:f0f0b4b6a65b45aee25738b7272ec85a:9df016059ef5b89c2d1da7c1a6fdb902:70f70b07c9d5b3013cbd3b3f25c7f7fa$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-fighting_2.png b/public/images/pokemon/variant/exp/back/773-fighting_2.png deleted file mode 100644 index b627a56931b..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-fighting_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-fighting_3.json b/public/images/pokemon/variant/exp/back/773-fighting_3.json deleted file mode 100644 index 44c2f9fff17..00000000000 --- a/public/images/pokemon/variant/exp/back/773-fighting_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-fighting_3.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:f0f0b4b6a65b45aee25738b7272ec85a:9df016059ef5b89c2d1da7c1a6fdb902:70f70b07c9d5b3013cbd3b3f25c7f7fa$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-fighting_3.png b/public/images/pokemon/variant/exp/back/773-fighting_3.png deleted file mode 100644 index fadb3117107..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-fighting_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-fire.json b/public/images/pokemon/variant/exp/back/773-fire.json new file mode 100644 index 00000000000..302ec952415 --- /dev/null +++ b/public/images/pokemon/variant/exp/back/773-fire.json @@ -0,0 +1,45 @@ +{ + "1": { + "bcbbc5": "788fb5", + "483c39": "3a2d53", + "e64f5e": "f1944a", + "e3e6ec": "bdd1e5", + "aba7bc": "493d55", + "fa7351": "fc9e5d", + "1d1845": "2e191f", + "f32142": "ba2e2c", + "125d4b": "ce7f3f", + "0073bf": "7a4949", + "565969": "30365c", + "1e9378": "f8ce64", + "81132d": "6e1441", + "3f3b50": "1e172a", + "9618e0": "dc9c4d", + "251845": "753c32", + "f32141": "ee3652", + "79615e": "504a75", + "5399df": "b59489", + "b50d36": "ae1361" + }, + "2": { + "bcbbc5": "242433", + "483c39": "778894", + "e64f5e": "98ce58", + "e3e6ec": "444455", + "aba7bc": "dbd8e8", + "fa7351": "d063a2", + "1d1845": "41434e", + "f32142": "d92b00", + "125d4b": "7a151a", + "0073bf": "6a6c75", + "565969": "0f0f1b", + "1e9378": "d92b00", + "81132d": "7e3354", + "9618e0": "ade265", + "251845": "425735", + "f32141": "e7eef2", + "79615e": "d6d4d4", + "5399df": "92949e", + "b50d36": "fa9955" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-fire_2.json b/public/images/pokemon/variant/exp/back/773-fire_2.json deleted file mode 100644 index 47dafb71818..00000000000 --- a/public/images/pokemon/variant/exp/back/773-fire_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-fire_2.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:a1770b4d3a8eff9c57d3d974b95f57d2:0cbcb675d6b570c94848233c26b8760c:690c285b19cb1e8f7b7aa9dfafbe36b2$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-fire_2.png b/public/images/pokemon/variant/exp/back/773-fire_2.png deleted file mode 100644 index e665f87d5fc..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-fire_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-fire_3.json b/public/images/pokemon/variant/exp/back/773-fire_3.json deleted file mode 100644 index fa386266743..00000000000 --- a/public/images/pokemon/variant/exp/back/773-fire_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-fire_3.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:a1770b4d3a8eff9c57d3d974b95f57d2:0cbcb675d6b570c94848233c26b8760c:690c285b19cb1e8f7b7aa9dfafbe36b2$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-fire_3.png b/public/images/pokemon/variant/exp/back/773-fire_3.png deleted file mode 100644 index 274ea77e7b8..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-fire_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-flying.json b/public/images/pokemon/variant/exp/back/773-flying.json new file mode 100644 index 00000000000..7787b1e8208 --- /dev/null +++ b/public/images/pokemon/variant/exp/back/773-flying.json @@ -0,0 +1,45 @@ +{ + "1": { + "5082c1": "8bc4e1", + "125d4b": "ce7f3f", + "081b4a": "17195a", + "9618e0": "dc9c4d", + "bcbbc5": "788fb5", + "565969": "30365c", + "79615e": "504a75", + "0073bf": "7a4949", + "e3e6ec": "bdd1e5", + "072c85": "402795", + "251845": "753c32", + "e64f5e": "f1944a", + "5399df": "b59489", + "0557bc": "296cbe", + "483c39": "3a2d53", + "1d1845": "2e191f", + "1e9378": "f8ce64", + "aba7bc": "493d55", + "0557bd": "1e509e", + "3f3b50": "1e172a" + }, + "2": { + "5082c1": "acb4bd", + "125d4b": "0a298c", + "081b4a": "2f4453", + "9618e0": "ade265", + "bcbbc5": "242433", + "565969": "0f0f1b", + "79615e": "d6d4d4", + "0073bf": "6a6c75", + "e3e6ec": "444455", + "072c85": "97c7fe", + "251845": "425735", + "e64f5e": "98ce58", + "5399df": "92949e", + "0557bc": "e7eef2", + "483c39": "778894", + "1d1845": "41434e", + "1e9378": "0557bc", + "aba7bc": "dbd8e8", + "0557bd": "0557bc" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-flying_2.json b/public/images/pokemon/variant/exp/back/773-flying_2.json deleted file mode 100644 index 55415a787ba..00000000000 --- a/public/images/pokemon/variant/exp/back/773-flying_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-flying_2.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:f6a20c453240fbd83239a85ecf4f14f2:796217ca49c345806c31368c8a952073:fd9cc965ca8a0f017385425d924045d6$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-flying_2.png b/public/images/pokemon/variant/exp/back/773-flying_2.png deleted file mode 100644 index 1083cb116e8..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-flying_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-flying_3.json b/public/images/pokemon/variant/exp/back/773-flying_3.json deleted file mode 100644 index bc6ceb06a2f..00000000000 --- a/public/images/pokemon/variant/exp/back/773-flying_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-flying_3.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:f6a20c453240fbd83239a85ecf4f14f2:796217ca49c345806c31368c8a952073:fd9cc965ca8a0f017385425d924045d6$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-flying_3.png b/public/images/pokemon/variant/exp/back/773-flying_3.png deleted file mode 100644 index 19164ea2726..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-flying_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-ghost.json b/public/images/pokemon/variant/exp/back/773-ghost.json new file mode 100644 index 00000000000..26826f8857b --- /dev/null +++ b/public/images/pokemon/variant/exp/back/773-ghost.json @@ -0,0 +1,45 @@ +{ + "1": { + "483c39": "3a2d53", + "d68ce5": "ecc9f3", + "125d4b": "ce7f3f", + "5399df": "b59489", + "e3e6ec": "bdd1e5", + "1d1845": "2e191f", + "1e9378": "f8ce64", + "9618e0": "dc9c4d", + "a75bbf": "b36bca", + "79615e": "504a75", + "251845": "753c32", + "a75bc0": "7b5498", + "565969": "30365c", + "3f3b50": "1e172a", + "503775": "392e4c", + "0073bf": "7a4949", + "e64f5e": "f1944a", + "753d9a": "504681", + "aba7bc": "493d55", + "bcbbc5": "788fb5" + }, + "2": { + "483c39": "778894", + "d68ce5": "5876bd", + "125d4b": "653785", + "5399df": "92949e", + "e3e6ec": "444455", + "1d1845": "41434e", + "1e9378": "a75bbf", + "9618e0": "ade265", + "a75bbf": "c8b5e2", + "79615e": "d6d4d4", + "251845": "425735", + "a75bc0": "a75bbf", + "565969": "0f0f1b", + "503775": "383c6a", + "0073bf": "6a6c75", + "e64f5e": "98ce58", + "753d9a": "cd6fa4", + "aba7bc": "dbd8e8", + "bcbbc5": "242433" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-ghost_2.json b/public/images/pokemon/variant/exp/back/773-ghost_2.json deleted file mode 100644 index 86afaed87d9..00000000000 --- a/public/images/pokemon/variant/exp/back/773-ghost_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-ghost_2.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:0474b69f98e304b26d88860f41abe308:8969ed1ff2b47be1c2a595c7cd58740e:dff8d338685b93339ecf30f1d807fbe6$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-ghost_2.png b/public/images/pokemon/variant/exp/back/773-ghost_2.png deleted file mode 100644 index 618753e9324..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-ghost_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-ghost_3.json b/public/images/pokemon/variant/exp/back/773-ghost_3.json deleted file mode 100644 index d2f3cfd3b26..00000000000 --- a/public/images/pokemon/variant/exp/back/773-ghost_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-ghost_3.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:0474b69f98e304b26d88860f41abe308:8969ed1ff2b47be1c2a595c7cd58740e:dff8d338685b93339ecf30f1d807fbe6$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-ghost_3.png b/public/images/pokemon/variant/exp/back/773-ghost_3.png deleted file mode 100644 index eca8babc28d..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-ghost_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-grass.json b/public/images/pokemon/variant/exp/back/773-grass.json new file mode 100644 index 00000000000..4099a183dc0 --- /dev/null +++ b/public/images/pokemon/variant/exp/back/773-grass.json @@ -0,0 +1,45 @@ +{ + "1": { + "03753c": "086c6b", + "483c39": "3a2d53", + "01a326": "1b9143", + "e64f5e": "f1944a", + "0073bf": "7a4949", + "251845": "753c32", + "79615e": "504a75", + "064a28": "043541", + "125d4b": "ce7f3f", + "3f3b50": "1e172a", + "bcbbc5": "788fb5", + "01a325": "18b12f", + "1e9378": "f8ce64", + "9618e0": "dc9c4d", + "5399df": "b59489", + "565969": "30365c", + "e3e6ec": "bdd1e5", + "50d354": "8bf360", + "aba7bc": "493d55", + "1d1845": "2e191f" + }, + "2": { + "03753c": "c77fe2", + "483c39": "778894", + "01a326": "01a325", + "e64f5e": "98ce58", + "0073bf": "6a6c75", + "251845": "425735", + "79615e": "d6d4d4", + "064a28": "283331", + "125d4b": "0c592f", + "bcbbc5": "242433", + "01a325": "e7eef2", + "1e9378": "01a325", + "9618e0": "ade265", + "5399df": "92949e", + "565969": "0f0f1b", + "e3e6ec": "444455", + "50d354": "2b6e2d", + "aba7bc": "dbd8e8", + "1d1845": "41434e" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-grass_2.json b/public/images/pokemon/variant/exp/back/773-grass_2.json deleted file mode 100644 index 6c834d72fff..00000000000 --- a/public/images/pokemon/variant/exp/back/773-grass_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-grass_2.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:d6114db1830a0be30bb703504ed3ed66:96e3f9b2c128c90248e2a611a7c53cbd:c892d42603d88b410862efcb4f750000$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-grass_2.png b/public/images/pokemon/variant/exp/back/773-grass_2.png deleted file mode 100644 index 2b36529c20b..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-grass_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-grass_3.json b/public/images/pokemon/variant/exp/back/773-grass_3.json deleted file mode 100644 index 12daa1993b8..00000000000 --- a/public/images/pokemon/variant/exp/back/773-grass_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-grass_3.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:d6114db1830a0be30bb703504ed3ed66:96e3f9b2c128c90248e2a611a7c53cbd:c892d42603d88b410862efcb4f750000$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-grass_3.png b/public/images/pokemon/variant/exp/back/773-grass_3.png deleted file mode 100644 index a5d2b58ef87..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-grass_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-ground.json b/public/images/pokemon/variant/exp/back/773-ground.json new file mode 100644 index 00000000000..d57e1508946 --- /dev/null +++ b/public/images/pokemon/variant/exp/back/773-ground.json @@ -0,0 +1,45 @@ +{ + "1": { + "1e9378": "f8ce64", + "bcbbc5": "788fb5", + "cf5c07": "d36b1f", + "5399df": "b59489", + "cf5c08": "b55711", + "9618e0": "dc9c4d", + "1d1845": "2e191f", + "3f3b50": "1e172a", + "565969": "30365c", + "e3e6ec": "bdd1e5", + "a3410c": "95174b", + "e59b4a": "f3daa4", + "125d4b": "ce7f3f", + "251845": "753c32", + "483c39": "3a2d53", + "79615e": "504a75", + "e64f5e": "f1944a", + "613016": "61191e", + "0073bf": "7a4949", + "aba7bc": "493d55" + }, + "2": { + "1e9378": "cf5c07", + "bcbbc5": "242433", + "cf5c07": "ffd963", + "5399df": "92949e", + "cf5c08": "cf5c07", + "9618e0": "ade265", + "1d1845": "41434e", + "565969": "0f0f1b", + "e3e6ec": "444455", + "a3410c": "e1497e", + "e59b4a": "44b3e3", + "125d4b": "a32004", + "251845": "425735", + "483c39": "778894", + "79615e": "d6d4d4", + "e64f5e": "98ce58", + "613016": "653653", + "0073bf": "6a6c75", + "aba7bc": "dbd8e8" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-ground_2.json b/public/images/pokemon/variant/exp/back/773-ground_2.json deleted file mode 100644 index d26efb07bbf..00000000000 --- a/public/images/pokemon/variant/exp/back/773-ground_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-ground_2.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:b8fb9cc9fd3eab6e6f58fd555c5ffbcf:035ac7b983998262c220c0cb2dfb033b:a8b1ae37d6ef4c526891c3cd392866cd$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-ground_2.png b/public/images/pokemon/variant/exp/back/773-ground_2.png deleted file mode 100644 index ee98bf25ba2..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-ground_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-ground_3.json b/public/images/pokemon/variant/exp/back/773-ground_3.json deleted file mode 100644 index 91a52527c68..00000000000 --- a/public/images/pokemon/variant/exp/back/773-ground_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-ground_3.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:b8fb9cc9fd3eab6e6f58fd555c5ffbcf:035ac7b983998262c220c0cb2dfb033b:a8b1ae37d6ef4c526891c3cd392866cd$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-ground_3.png b/public/images/pokemon/variant/exp/back/773-ground_3.png deleted file mode 100644 index a8e740c80d3..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-ground_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-ice.json b/public/images/pokemon/variant/exp/back/773-ice.json new file mode 100644 index 00000000000..11a2edc1457 --- /dev/null +++ b/public/images/pokemon/variant/exp/back/773-ice.json @@ -0,0 +1,45 @@ +{ + "1": { + "5399df": "b59489", + "1e9378": "f8ce64", + "0073bf": "7a4949", + "79615e": "504a75", + "bcbbc5": "788fb5", + "ecfffc": "eafffb", + "e3e6ec": "bdd1e5", + "1d1845": "2e191f", + "125d4b": "ce7f3f", + "9618e0": "dc9c4d", + "aef9fa": "aef9f9", + "e64f5e": "f1944a", + "251845": "753c32", + "565969": "30365c", + "7bb3cc": "a197f3", + "aba7bc": "493d55", + "aef9f9": "b8f8f8", + "3f3b50": "1e172a", + "416b7e": "575693", + "483c39": "3a2d53" + }, + "2": { + "5399df": "92949e", + "1e9378": "aef9f9", + "0073bf": "6a6c75", + "79615e": "d6d4d4", + "bcbbc5": "242433", + "ecfffc": "7cadde", + "e3e6ec": "444455", + "1d1845": "41434e", + "125d4b": "5c94a6", + "9618e0": "ade265", + "aef9fa": "aef9f9", + "e64f5e": "98ce58", + "251845": "425735", + "565969": "0f0f1b", + "7bb3cc": "38cfb0", + "aba7bc": "dbd8e8", + "aef9f9": "e7eef2", + "416b7e": "414f65", + "483c39": "778894" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-ice_2.json b/public/images/pokemon/variant/exp/back/773-ice_2.json deleted file mode 100644 index 3a2d452034a..00000000000 --- a/public/images/pokemon/variant/exp/back/773-ice_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-ice_2.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:443053ac3c53cd338b75e0df4dcb301b:a3de57a8e3314116c9fcd75fc74f6984:bbb81164af15638f1aae91f14ca0ac1d$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-ice_2.png b/public/images/pokemon/variant/exp/back/773-ice_2.png deleted file mode 100644 index 2f8a65beb40..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-ice_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-ice_3.json b/public/images/pokemon/variant/exp/back/773-ice_3.json deleted file mode 100644 index 79b57c9664d..00000000000 --- a/public/images/pokemon/variant/exp/back/773-ice_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-ice_3.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:443053ac3c53cd338b75e0df4dcb301b:a3de57a8e3314116c9fcd75fc74f6984:bbb81164af15638f1aae91f14ca0ac1d$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-ice_3.png b/public/images/pokemon/variant/exp/back/773-ice_3.png deleted file mode 100644 index 5ae46333616..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-ice_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-poison.json b/public/images/pokemon/variant/exp/back/773-poison.json new file mode 100644 index 00000000000..e42a2e9aece --- /dev/null +++ b/public/images/pokemon/variant/exp/back/773-poison.json @@ -0,0 +1,45 @@ +{ + "1": { + "1d1845": "2e191f", + "9c71ce": "d089ee", + "4e229c": "4641b5", + "0073bf": "7a4949", + "79615e": "504a75", + "1e9378": "f8ce64", + "251845": "753c32", + "7234bd": "7b4bb5", + "9618e0": "dc9c4d", + "5399df": "b59489", + "565969": "30365c", + "483c39": "3a2d53", + "30175c": "2f1b77", + "e3e6ec": "bdd1e5", + "bcbbc5": "788fb5", + "e64f5e": "f1944a", + "3f3b50": "1e172a", + "125d4b": "ce7f3f", + "aba7bc": "493d55", + "7234bc": "874dcc" + }, + "2": { + "1d1845": "41434e", + "9c71ce": "2752b5", + "4e229c": "e3508d", + "0073bf": "6a6c75", + "79615e": "d6d4d4", + "1e9378": "7234bc", + "251845": "425735", + "7234bd": "7234bc", + "9618e0": "ade265", + "5399df": "92949e", + "565969": "0f0f1b", + "483c39": "778894", + "30175c": "34284a", + "e3e6ec": "444455", + "bcbbc5": "242433", + "e64f5e": "98ce58", + "125d4b": "4b1f7e", + "aba7bc": "dbd8e8", + "7234bc": "8e4da8" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-poison_2.json b/public/images/pokemon/variant/exp/back/773-poison_2.json deleted file mode 100644 index 6f65f59f37a..00000000000 --- a/public/images/pokemon/variant/exp/back/773-poison_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-poison_2.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:d407f096a1cef259c3b4dfe006f94271:811b20f66fdb4eec8e5a4d6a85f0b9d9:2e43d6e4a409b7aabc1efd3ec3981f96$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-poison_2.png b/public/images/pokemon/variant/exp/back/773-poison_2.png deleted file mode 100644 index 4268dff871b..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-poison_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-poison_3.json b/public/images/pokemon/variant/exp/back/773-poison_3.json deleted file mode 100644 index b0ce4a19137..00000000000 --- a/public/images/pokemon/variant/exp/back/773-poison_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-poison_3.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:d407f096a1cef259c3b4dfe006f94271:811b20f66fdb4eec8e5a4d6a85f0b9d9:2e43d6e4a409b7aabc1efd3ec3981f96$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-poison_3.png b/public/images/pokemon/variant/exp/back/773-poison_3.png deleted file mode 100644 index fdce2fba3c6..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-poison_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-psychic.json b/public/images/pokemon/variant/exp/back/773-psychic.json new file mode 100644 index 00000000000..d20475ab1ae --- /dev/null +++ b/public/images/pokemon/variant/exp/back/773-psychic.json @@ -0,0 +1,45 @@ +{ + "1": { + "ea6aa4": "ec81b2", + "1d1845": "2e191f", + "9618e0": "dc9c4d", + "565969": "30365c", + "e64f5e": "f1944a", + "bcbbc5": "788fb5", + "0073bf": "7a4949", + "7a2656": "812c6e", + "aba7bc": "493d55", + "ea6aa5": "c14e82", + "5399df": "b59489", + "e3e6ec": "bdd1e5", + "79615e": "504a75", + "125d4b": "ce7f3f", + "3f3b50": "1e172a", + "f3a1b8": "ffccc3", + "1e9378": "f8ce64", + "c1448c": "b3388f", + "251845": "753c32", + "483c39": "3a2d53" + }, + "2": { + "ea6aa4": "e7eef2", + "1d1845": "41434e", + "9618e0": "ade265", + "565969": "0f0f1b", + "e64f5e": "98ce58", + "bcbbc5": "242433", + "0073bf": "6a6c75", + "7a2656": "6a3851", + "aba7bc": "dbd8e8", + "ea6aa5": "ea6aa4", + "5399df": "92949e", + "e3e6ec": "444455", + "79615e": "d6d4d4", + "125d4b": "9f3351", + "f3a1b8": "ed77a7", + "1e9378": "ea6aa4", + "c1448c": "91d4b0", + "251845": "425735", + "483c39": "778894" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-psychic_2.json b/public/images/pokemon/variant/exp/back/773-psychic_2.json deleted file mode 100644 index 48a3f774d67..00000000000 --- a/public/images/pokemon/variant/exp/back/773-psychic_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-psychic_2.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:45f7cc42f452e5d9d435761ed660a526:758b94ac0c294efd1b460a47a135ed47:9fb489b40d17b047a9dacb47533ceda4$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-psychic_2.png b/public/images/pokemon/variant/exp/back/773-psychic_2.png deleted file mode 100644 index 6509f56549a..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-psychic_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-psychic_3.json b/public/images/pokemon/variant/exp/back/773-psychic_3.json deleted file mode 100644 index 66b1579cc65..00000000000 --- a/public/images/pokemon/variant/exp/back/773-psychic_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-psychic_3.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:45f7cc42f452e5d9d435761ed660a526:758b94ac0c294efd1b460a47a135ed47:9fb489b40d17b047a9dacb47533ceda4$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-psychic_3.png b/public/images/pokemon/variant/exp/back/773-psychic_3.png deleted file mode 100644 index 86e8308ec60..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-psychic_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-rock.json b/public/images/pokemon/variant/exp/back/773-rock.json new file mode 100644 index 00000000000..89e714adc9e --- /dev/null +++ b/public/images/pokemon/variant/exp/back/773-rock.json @@ -0,0 +1,45 @@ +{ + "1": { + "f3ebdc": "fff5d8", + "5399df": "b59489", + "251845": "753c32", + "125d4b": "ce7f3f", + "0073bf": "7a4949", + "a38479": "c18cb8", + "3f3b50": "1e172a", + "bcbbc5": "788fb5", + "aba7bc": "493d55", + "d6c4b1": "e5d2bd", + "e3e6ec": "bdd1e5", + "1e9378": "f8ce64", + "565969": "30365c", + "7a5c52": "775d73", + "1d1845": "2e191f", + "e64f5e": "f1944a", + "79615e": "504a75", + "483c39": "3a2d53", + "9618e0": "dc9c4d", + "d6c4b2": "c8b19a" + }, + "2": { + "f3ebdc": "acb4bd", + "5399df": "92949e", + "251845": "425735", + "125d4b": "816f5b", + "0073bf": "6a6c75", + "a38479": "f9de6c", + "bcbbc5": "242433", + "aba7bc": "dbd8e8", + "d6c4b1": "e7eef2", + "e3e6ec": "444455", + "1e9378": "d6c4b1", + "565969": "0f0f1b", + "7a5c52": "50433d", + "1d1845": "41434e", + "e64f5e": "98ce58", + "79615e": "d6d4d4", + "483c39": "778894", + "9618e0": "ade265", + "d6c4b2": "d6c4b1" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-rock_2.json b/public/images/pokemon/variant/exp/back/773-rock_2.json deleted file mode 100644 index 835465d44a4..00000000000 --- a/public/images/pokemon/variant/exp/back/773-rock_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-rock_2.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:a9392af064c5ae80d334870c6a304b70:a2f30d4d81427d75edaa901098097d9c:b6fcb5d1ff917a13e5e912a7f40fcbe2$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-rock_2.png b/public/images/pokemon/variant/exp/back/773-rock_2.png deleted file mode 100644 index 4a387720c8d..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-rock_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-rock_3.json b/public/images/pokemon/variant/exp/back/773-rock_3.json deleted file mode 100644 index 5a6a68b5738..00000000000 --- a/public/images/pokemon/variant/exp/back/773-rock_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-rock_3.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:a9392af064c5ae80d334870c6a304b70:a2f30d4d81427d75edaa901098097d9c:b6fcb5d1ff917a13e5e912a7f40fcbe2$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-rock_3.png b/public/images/pokemon/variant/exp/back/773-rock_3.png deleted file mode 100644 index 7eb8b8665e2..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-rock_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-steel.json b/public/images/pokemon/variant/exp/back/773-steel.json new file mode 100644 index 00000000000..91e5335bcc5 --- /dev/null +++ b/public/images/pokemon/variant/exp/back/773-steel.json @@ -0,0 +1,45 @@ +{ + "1": { + "1d1845": "2e191f", + "e5e0de": "f1efe5", + "565969": "30365c", + "9d98aa": "8f89aa", + "e64f5e": "f1944a", + "3f3b50": "1e172a", + "79615e": "504a75", + "125d4b": "ce7f3f", + "9618e0": "dc9c4d", + "aba7bc": "493d55", + "bcbbc5": "788fb5", + "1e9378": "f8ce64", + "251845": "753c32", + "5399df": "b59489", + "e3e6ec": "bdd1e5", + "0073bf": "7a4949", + "cfc7c7": "dcd1d1", + "483c39": "3a2d53", + "cfc7c8": "b8aeab", + "595467": "565071" + }, + "2": { + "1d1845": "41434e", + "e5e0de": "a5a5a5", + "565969": "0f0f1b", + "9d98aa": "98099c", + "e64f5e": "98ce58", + "79615e": "d6d4d4", + "125d4b": "705a5f", + "9618e0": "ade265", + "aba7bc": "dbd8e8", + "bcbbc5": "242433", + "1e9378": "cfc7c7", + "251845": "425735", + "5399df": "92949e", + "e3e6ec": "444455", + "0073bf": "6a6c75", + "cfc7c7": "e7eef2", + "483c39": "778894", + "cfc7c8": "cfc7c7", + "595467": "3b253e" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-steel_2.json b/public/images/pokemon/variant/exp/back/773-steel_2.json deleted file mode 100644 index 3254cce4389..00000000000 --- a/public/images/pokemon/variant/exp/back/773-steel_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-steel_2.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:acce26ec8db80708da21e57d191c1edb:a2f30d4d81427d75edaa901098097d9c:28dcfb1ac7091bec326d67f7b8d4eaa6$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-steel_2.png b/public/images/pokemon/variant/exp/back/773-steel_2.png deleted file mode 100644 index 0eb28ba4017..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-steel_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-steel_3.json b/public/images/pokemon/variant/exp/back/773-steel_3.json deleted file mode 100644 index 4107391fb7a..00000000000 --- a/public/images/pokemon/variant/exp/back/773-steel_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-steel_3.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:acce26ec8db80708da21e57d191c1edb:a2f30d4d81427d75edaa901098097d9c:28dcfb1ac7091bec326d67f7b8d4eaa6$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-steel_3.png b/public/images/pokemon/variant/exp/back/773-steel_3.png deleted file mode 100644 index 07dd1dc4751..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-steel_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-water.json b/public/images/pokemon/variant/exp/back/773-water.json new file mode 100644 index 00000000000..d7316c66d04 --- /dev/null +++ b/public/images/pokemon/variant/exp/back/773-water.json @@ -0,0 +1,44 @@ +{ + "1": { + "175477": "34508a", + "5399df": "b59489", + "aba7bc": "493d55", + "92f1f3": "93f8e9", + "3f3b50": "1e172a", + "0073bf": "7a4949", + "483c39": "3a2d53", + "3ed3ef": "59d6ec", + "2786bc": "4661cc", + "3ed3ee": "4fd4ec", + "9618e0": "dc9c4d", + "251845": "753c32", + "e3e6ec": "bdd1e5", + "1e9378": "f8ce64", + "79615e": "504a75", + "125d4b": "ce7f3f", + "bcbbc5": "788fb5", + "565969": "30365c", + "e64f5e": "f1944a" + }, + "2": { + "175477": "3a182f", + "5399df": "92949e", + "aba7bc": "dbd8e8", + "92f1f3": "b82db2", + "0073bf": "6a6c75", + "483c39": "778894", + "3ed3ef": "2866ba", + "2786bc": "fe75a3", + "1d1845": "444455", + "3ed3ee": "e7eef2", + "9618e0": "ade265", + "251845": "425735", + "e3e6ec": "444455", + "1e9378": "2866ba", + "79615e": "d6d4d4", + "125d4b": "162c81", + "bcbbc5": "242433", + "565969": "0f0f1b", + "e64f5e": "98ce58" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-water_2.json b/public/images/pokemon/variant/exp/back/773-water_2.json deleted file mode 100644 index ad56e9190e8..00000000000 --- a/public/images/pokemon/variant/exp/back/773-water_2.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-water_2.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:1d7560d86d6c95422664f1ffa4e60412:ae04b46b6c3615cd1d1722afe6063e89:609e3c1a2aa54ec6d5110acf831a822b$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-water_2.png b/public/images/pokemon/variant/exp/back/773-water_2.png deleted file mode 100644 index f691dafe21f..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-water_2.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/773-water_3.json b/public/images/pokemon/variant/exp/back/773-water_3.json deleted file mode 100644 index 6e131ad849f..00000000000 --- a/public/images/pokemon/variant/exp/back/773-water_3.json +++ /dev/null @@ -1,2834 +0,0 @@ -{ - "textures": [ - { - "image": "773-water_3.png", - "format": "RGBA8888", - "size": { - "w": 344, - "h": 344 - }, - "scale": 1, - "frames": [ - { - "filename": "0109.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0129.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0130.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0110.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0127.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0128.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 88, - "w": 64, - "h": 88 - } - }, - { - "filename": "0111.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0112.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0113.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0114.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0115.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0116.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0117.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0118.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0119.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0120.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0121.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0122.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0123.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0124.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0125.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0126.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 64, - "y": 0, - "w": 64, - "h": 88 - } - }, - { - "filename": "0131.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0132.png", - "rotated": false, - "trimmed": false, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 64, - "h": 88 - }, - "frame": { - "x": 0, - "y": 176, - "w": 64, - "h": 88 - } - }, - { - "filename": "0001.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0071.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0072.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0073.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0074.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0089.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0090.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0091.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0092.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0107.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0108.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0133.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0134.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 88, - "w": 64, - "h": 87 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0075.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0076.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0077.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0078.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 64, - "y": 175, - "w": 64, - "h": 87 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0079.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0080.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 87, - "w": 64, - "h": 87 - } - }, - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0081.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0082.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 192, - "y": 0, - "w": 64, - "h": 87 - } - }, - { - "filename": "0093.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0094.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 1, - "w": 64, - "h": 87 - }, - "frame": { - "x": 128, - "y": 174, - "w": 64, - "h": 87 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0083.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0084.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 87, - "w": 64, - "h": 86 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0085.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0086.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 0, - "w": 64, - "h": 86 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0070.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0087.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0088.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 192, - "y": 173, - "w": 64, - "h": 86 - } - }, - { - "filename": "0095.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0096.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0105.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 86, - "w": 64, - "h": 86 - } - }, - { - "filename": "0097.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0098.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 172, - "w": 64, - "h": 86 - } - }, - { - "filename": "0099.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0100.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0101.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0102.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0103.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0104.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 3, - "w": 64, - "h": 85 - }, - "frame": { - "x": 192, - "y": 259, - "w": 64, - "h": 85 - } - }, - { - "filename": "0106.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 64, - "h": 88 - }, - "spriteSourceSize": { - "x": 0, - "y": 2, - "w": 64, - "h": 86 - }, - "frame": { - "x": 256, - "y": 258, - "w": 64, - "h": 86 - } - } - ] - } - ], - "meta": { - "app": "https://www.codeandweb.com/texturepacker", - "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:1d7560d86d6c95422664f1ffa4e60412:ae04b46b6c3615cd1d1722afe6063e89:609e3c1a2aa54ec6d5110acf831a822b$" - } -} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/773-water_3.png b/public/images/pokemon/variant/exp/back/773-water_3.png deleted file mode 100644 index 6dbaf1fee17..00000000000 Binary files a/public/images/pokemon/variant/exp/back/773-water_3.png and /dev/null differ diff --git a/public/images/pokemon/variant/exp/back/807.json b/public/images/pokemon/variant/exp/back/807.json new file mode 100644 index 00000000000..aff6a52c9b2 --- /dev/null +++ b/public/images/pokemon/variant/exp/back/807.json @@ -0,0 +1,38 @@ +{ + "1": { + "53e4f9": "eac1eb", + "ef8a4e": "4f7bb6", + "2759a5": "736599", + "5bd0f2": "ebceff", + "2394d8": "b298d8", + "31343e": "14193f", + "1f73b4": "995fc0", + "4cf4fe": "f4a7ff", + "484f57": "243058", + "daa936": "5c96b4", + "727678": "3e5277", + "30cff1": "d7a7de", + "f9e455": "80c7d7", + "000000": "ffffff", + "9d682d": "3d648c", + "14bdea": "c987e3" + }, + "2": { + "53e4f9": "e688af", + "ef8a4e": "844c94", + "2759a5": "a3378a", + "5bd0f2": "df7298", + "2394d8": "be5293", + "31343e": "a880b0", + "1f73b4": "9a1d82", + "4cf4fe": "e3418f", + "484f57": "cba3ca", + "daa936": "351d53", + "727678": "e7c9e2", + "30cff1": "d967a2", + "f9e455": "58326f", + "000000": "ffffff", + "9d682d": "1f1144", + "14bdea": "c02f8d" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/894.json b/public/images/pokemon/variant/exp/back/894.json new file mode 100644 index 00000000000..276133a842a --- /dev/null +++ b/public/images/pokemon/variant/exp/back/894.json @@ -0,0 +1,24 @@ +{ + "1": { + "e5ee1a": "6ad7f3", + "7d542a": "2769aa", + "bc8b2f": "124b78", + "8eacdd": "caffd1", + "2e3967": "357b84", + "fefac7": "dffff6", + "375395": "5fcaad", + "4e7cc9": "9bf1c4", + "d7ad0d": "45a3d6" + }, + "2": { + "e5ee1a": "d4ffd0", + "7d542a": "429877", + "bc8b2f": "2a6f5d", + "8eacdd": "c693d8", + "2e3967": "514199", + "fefac7": "ffffff", + "375395": "815bad", + "4e7cc9": "b67cd6", + "d7ad0d": "7cd395" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/895.json b/public/images/pokemon/variant/exp/back/895.json new file mode 100644 index 00000000000..d6859edafb3 --- /dev/null +++ b/public/images/pokemon/variant/exp/back/895.json @@ -0,0 +1,28 @@ +{ + "1": { + "641e2c": "722123", + "b63650": "bc623e", + "608d99": "fae5bf", + "2b3d40": "754f47", + "4b6f78": "f1d4b6", + "e05276": "ef8429", + "f27a99": "efb55a", + "ff92ae": "edca71", + "3f545f": "ad8473", + "872c3c": "93372d", + "242e35": "512c25" + }, + "2": { + "641e2c": "15553b", + "b63650": "3bb349", + "608d99": "9b7ebc", + "2b3d40": "241951", + "4b6f78": "5a4382", + "e05276": "8aea41", + "f27a99": "dfff75", + "ff92ae": "f1ff8d", + "3f545f": "3a2a67", + "872c3c": "227843", + "242e35": "0f0c1e" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/944.json b/public/images/pokemon/variant/exp/back/944.json new file mode 100644 index 00000000000..6de6bc5e833 --- /dev/null +++ b/public/images/pokemon/variant/exp/back/944.json @@ -0,0 +1,34 @@ +{ + "1": { + "403f4f": "33784a", + "dcdcc3": "88eeab", + "484441": "286943", + "282434": "16402d", + "2f2826": "18493f", + "774d9b": "d09139", + "8095a8": "5e4090", + "e6e2e1": "53a164", + "a599a8": "3f8d59", + "211e28": "103833", + "bbd2e3": "8056a7", + "aca699": "3ec295", + "000000": "ffffff", + "6c5c4d": "1c9b8d" + }, + "2": { + "403f4f": "395d87", + "dcdcc3": "e2f3ff", + "484441": "2c4f8a", + "282434": "1d2f5b", + "2f2826": "1e3072", + "774d9b": "4c5372", + "8095a8": "902a4b", + "e6e2e1": "78b0c2", + "a599a8": "5582a4", + "211e28": "17255b", + "bbd2e3": "c23f4f", + "aca699": "abc1df", + "000000": "ffffff", + "6c5c4d": "6777aa" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/exp/back/945.json b/public/images/pokemon/variant/exp/back/945.json new file mode 100644 index 00000000000..6590d0b67ed --- /dev/null +++ b/public/images/pokemon/variant/exp/back/945.json @@ -0,0 +1,43 @@ +{ + "1": { + "403f4f": "357747", + "1f2635": "1c193d", + "dcdcc3": "5ddcb2", + "282434": "14463f", + "a491a4": "499833", + "e6e2e1": "fffbf3", + "671544": "0f4e67", + "134175": "a74d2a", + "4f483f": "1b727b", + "323d4a": "2e2452", + "000000": "ffffff", + "4b616b": "473869", + "d73875": "29ad89", + "2481b0": "d09139", + "38bdda": "ffe269", + "695575": "16613d", + "aca699": "2db3a4", + "8d2151": "157375" + }, + "2": { + "403f4f": "3b6b9e", + "1f2635": "3b091c", + "dcdcc3": "edf0f1", + "282434": "2d427e", + "a491a4": "902a4b", + "e6e2e1": "ebf4f9", + "671544": "223969", + "134175": "1c182f", + "4f483f": "5d7487", + "323d4a": "580f1d", + "000000": "ffffff", + "4b616b": "8a2029", + "a599a8": "bf888f", + "d73875": "68adca", + "2481b0": "2c2c46", + "38bdda": "494e64", + "695575": "4f133f", + "aca699": "acbfc7", + "8d2151": "4676aa" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/female/154.json b/public/images/pokemon/variant/female/154.json new file mode 100644 index 00000000000..c02d214d834 --- /dev/null +++ b/public/images/pokemon/variant/female/154.json @@ -0,0 +1,30 @@ +{ + "1": { + "634a00": "6da0df", + "f7a59c": "3c88ac", + "e6ad00": "90c6f8", + "ff3a5a": "234d81", + "ffde21": "b9e2ff", + "ce213a": "192e5e", + "63bd42": "9d86d9", + "bdff7b": "dadffe", + "7b103a": "111c44", + "107b31": "8057b2", + "fefefe": "a6f5af", + "9ce652": "b7afee" + }, + "2": { + "634a00": "144627", + "f7a59c": "ddf2b5", + "e6ad00": "1e632b", + "ff3a5a": "9ed662", + "ffde21": "288028", + "ce213a": "81c65c", + "63bd42": "a31f60", + "bdff7b": "f57382", + "7b103a": "59ac45", + "107b31": "761858", + "fefefe": "f6ffdf", + "9ce652": "cd3b6b" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/female/194.json b/public/images/pokemon/variant/female/194.json new file mode 100644 index 00000000000..5824dec5029 --- /dev/null +++ b/public/images/pokemon/variant/female/194.json @@ -0,0 +1,24 @@ +{ + "1": { + "104a84": "7a150a", + "b54242": "1a6a62", + "ff6b73": "4db983", + "633a6b": "09484f", + "3a7bc5": "d5682e", + "ef73e6": "44d77f", + "73bdff": "ffc355", + "529ce6": "e8983d", + "d65ad6": "2ea380" + }, + "2": { + "104a84": "180d42", + "b54242": "8a9fc2", + "ff6b73": "e8faff", + "633a6b": "444c7e", + "3a7bc5": "3f377e", + "ef73e6": "e8faff", + "73bdff": "5c66c4", + "529ce6": "564daa", + "d65ad6": "aeccdf" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/female/195.json b/public/images/pokemon/variant/female/195.json new file mode 100644 index 00000000000..ff25261d120 --- /dev/null +++ b/public/images/pokemon/variant/female/195.json @@ -0,0 +1,25 @@ +{ + "1": { + "ade6ff": "f6dfa8", + "84d6f7": "ed9e4f", + "f7f7f7": "fffbea", + "637ba5": "816251", + "639cbd": "dc6a4d", + "3194a5": "44d77f", + "425284": "b03844", + "195a6b": "2ea380", + "6b5a8c": "1b5a55" + }, + "2": { + "ade6ff": "9864c2", + "84d6f7": "724ba7", + "f7f7f7": "e8b6ff", + "637ba5": "504a8a", + "639cbd": "493a8d", + "3194a5": "ebf5ff", + "19423a": "747aae", + "425284": "240830", + "195a6b": "aebbdf", + "6b5a8c": "5e649b" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/female/198.json b/public/images/pokemon/variant/female/198.json new file mode 100644 index 00000000000..b0386502899 --- /dev/null +++ b/public/images/pokemon/variant/female/198.json @@ -0,0 +1,34 @@ +{ + "1": { + "d94352": "b3986b", + "314263": "462b20", + "d64252": "7a101c", + "73293a": "4d0419", + "ffad8c": "ad2e24", + "73283a": "630c17", + "d6404f": "8c1b23", + "efd684": "a6a6b3", + "42639c": "694c30", + "5a4a21": "25253b", + "292942": "2a1512", + "b59c21": "57566f", + "752a3c": "755237", + "d6bd52": "838098" + }, + "2": { + "d94352": "bc4b84", + "314263": "0e4333", + "d64252": "5939a9", + "73293a": "1e1764", + "ffad8c": "b164e6", + "73283a": "630c17", + "d6404f": "8c1b23", + "efd684": "c2723a", + "42639c": "1d6e47", + "5a4a21": "4e1915", + "292942": "091e16", + "b59c21": "85412d", + "752a3c": "7b2363", + "d6bd52": "9a5524" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/female/25-beauty-cosplay.json b/public/images/pokemon/variant/female/25-beauty-cosplay.json new file mode 100644 index 00000000000..0e5a6a1bad2 --- /dev/null +++ b/public/images/pokemon/variant/female/25-beauty-cosplay.json @@ -0,0 +1,49 @@ +{ + "1": { + "c52119": "ad4e76", + "5e5e6b": "6c6e60", + "f7e652": "a3d1a8", + "52525a": "4f454c", + "cecab9": "cfc8aa", + "e65137": "c95578", + "fffabf": "f4f7ab", + "b52821": "ad4469", + "292929": "1e1526", + "39509d": "47449c", + "f7e860": "f2ea50", + "e65a42": "cf6182", + "4d88c4": "7976c6", + "f7bd21": "79b5a5", + "2d276d": "2f2768", + "242323": "282030", + "585861": "443e6c", + "fff7a5": "c4e3c3", + "9c5200": "315c75", + "f7cc2f": "f7bd21", + "fffdea": "f8ffe3" + }, + "2": { + "c52119": "ebc67c", + "5e5e6b": "8a2554", + "f7e652": "577b98", + "52525a": "f1b571", + "cecab9": "b84084", + "e65137": "b95b6e", + "fffabf": "f5efd1", + "b52821": "6a253f", + "292929": "a45233", + "39509d": "9ec4cd", + "f7e860": "eddc78", + "e65a42": "eedd9c", + "4d88c4": "e4f6f1", + "f7bd21": "486689", + "2d276d": "454a61", + "242323": "282030", + "585861": "3f4246", + "fff7a5": "7b96aa", + "9c5200": "283361", + "965b0e": "96500e", + "f7cc2f": "d5ac44", + "fffdea": "ea82a6" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/female/25-cool-cosplay.json b/public/images/pokemon/variant/female/25-cool-cosplay.json new file mode 100644 index 00000000000..de4a138b690 --- /dev/null +++ b/public/images/pokemon/variant/female/25-cool-cosplay.json @@ -0,0 +1,49 @@ +{ + "1": { + "171717": "2a1d36", + "e8b127": "f5ca2f", + "52525a": "55555e", + "c52119": "ad4e76", + "842222": "7b1f18", + "f7e652": "a3d1a8", + "fff7a5": "c4e3c3", + "2baf23": "76a848", + "f7bd21": "79b5a5", + "e65a42": "cf6182", + "ba2b23": "b73850", + "f5e193": "f4f7ab", + "e66953": "b95b6e", + "6f6c8e": "656f86", + "a6adb6": "a5b0b6", + "8c4e22": "965b0e", + "9c5200": "1c4f75", + "c43129": "6a253f", + "d95b45": "cf6887", + "45484d": "443e6c", + "3b3b40": "4a3e46", + "292929": "272b2b" + }, + "2": { + "171717": "a45233", + "e8b127": "e7b432", + "52525a": "8f4b32", + "c52119": "ebc67c", + "842222": "1e1e43", + "f7e652": "577b98", + "fff7a5": "7b96aa", + "2baf23": "572626", + "f7bd21": "445f8a", + "e65a42": "eedd9c", + "ba2b23": "2c2c47", + "f5e193": "eadbb3", + "e66953": "b95b6e", + "6f6c8e": "cf752b", + "a6adb6": "f0b541", + "8c4e22": "b1632b", + "9c5200": "22325c", + "c43129": "6a253f", + "d95b45": "3a3f5e", + "3b3b40": "f1b571", + "292929": "7d3833" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/female/25-cosplay.json b/public/images/pokemon/variant/female/25-cosplay.json new file mode 100644 index 00000000000..e324c094019 --- /dev/null +++ b/public/images/pokemon/variant/female/25-cosplay.json @@ -0,0 +1,36 @@ +{ + "1": { + "f7e652": "a3d1a8", + "212121": "30263b", + "c43129": "6a253f", + "171717": "1e1526", + "292929": "282030", + "e65a42": "cf6182", + "c52119": "ad4e76", + "42424a": "443e6c", + "fff7a5": "c4e3c3", + "f7bd21": "79b5a5", + "45454a": "4f454c", + "9c5200": "315c75", + "633108": "09406b", + "e66953": "b95b6e", + "de9400": "338087" + }, + "2": { + "f7e652": "577b98", + "212121": "d8805b", + "c43129": "6a253f", + "171717": "a45233", + "292929": "282030", + "e65a42": "eedd9c", + "c52119": "ebc67c", + "42424a": "3f4246", + "fff7a5": "7b96aa", + "f7bd21": "445f8a", + "45454a": "f1b571", + "9c5200": "23345e", + "633108": "22244f", + "e66953": "b95b6e", + "de9400": "324472" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/female/25-cute-cosplay.json b/public/images/pokemon/variant/female/25-cute-cosplay.json new file mode 100644 index 00000000000..26bebb4143d --- /dev/null +++ b/public/images/pokemon/variant/female/25-cute-cosplay.json @@ -0,0 +1,43 @@ +{ + "1": { + "212121": "30263b", + "e65a42": "cf6182", + "fff7a5": "c4e3c3", + "45454a": "4f454c", + "c52119": "ad4e76", + "9c5200": "255e8a", + "752bd0": "5452b7", + "f3bace": "f2bbbb", + "f7e652": "a3d1a8", + "ea82a6": "e8848e", + "e66953": "b95b6e", + "853247": "85323c", + "c43129": "6a253f", + "baa998": "bab699", + "42424a": "443e6c", + "fff9ba": "f0eaa8", + "f7bd21": "79b5a5", + "cf4770": "cf4a59" + }, + "2": { + "212121": "d8805b", + "e65a42": "eedd9c", + "fff7a5": "7b96aa", + "45454a": "f1b571", + "c52119": "ebc67c", + "9c5200": "1e2d52", + "752bd0": "7751c2", + "f3bace": "c5cc85", + "f7e652": "577b98", + "ea82a6": "a4b95f", + "e66953": "b95b6e", + "171717": "a45233", + "853247": "254b30", + "c43129": "6a253f", + "baa998": "d3ab5a", + "42424a": "373d45", + "fff9ba": "ebe7b7", + "f7bd21": "445f8a", + "cf4770": "739b55" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/female/25-partner.json b/public/images/pokemon/variant/female/25-partner.json new file mode 100644 index 00000000000..0542587ba6d --- /dev/null +++ b/public/images/pokemon/variant/female/25-partner.json @@ -0,0 +1,36 @@ +{ + "1": { + "42424a": "443e6c", + "fff7a5": "c4e3c3", + "c52119": "ad4e76", + "de9400": "338087", + "e65a42": "cf6182", + "f7e652": "a3d1a8", + "e66953": "b95b6e", + "45454a": "4f454c", + "292929": "282030", + "c43129": "6a253f", + "212121": "30263b", + "171717": "1e1526", + "f7bd21": "79b5a5", + "9c5200": "315c75", + "633108": "09406b" + }, + "2": { + "42424a": "3f4246", + "fff7a5": "7b96aa", + "c52119": "ebc67c", + "de9400": "324472", + "e65a42": "eedd9c", + "f7e652": "577b98", + "e66953": "b95b6e", + "45454a": "f1b571", + "292929": "282030", + "c43129": "6a253f", + "212121": "d8805b", + "171717": "a45233", + "f7bd21": "445f8a", + "9c5200": "23345e", + "633108": "22244f" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/female/25-smart-cosplay.json b/public/images/pokemon/variant/female/25-smart-cosplay.json new file mode 100644 index 00000000000..4ba98883f16 --- /dev/null +++ b/public/images/pokemon/variant/female/25-smart-cosplay.json @@ -0,0 +1,42 @@ +{ + "1": { + "212121": "30263b", + "b7a599": "bab699", + "60b553": "76a848", + "366635": "3e5b2f", + "e35252": "d16b9a", + "c52119": "ad4e76", + "292929": "272b2b", + "9c5200": "315c75", + "f7e652": "a3d1a8", + "95635b": "91685f", + "171717": "1e1526", + "ba2525": "993f70", + "e65a42": "cf6182", + "54545c": "55555e", + "52525a": "4f454c", + "fffdea": "f8ffe3", + "f7bd21": "79b5a5", + "5f3434": "573b38" + }, + "2": { + "212121": "d8805b", + "b7a599": "a7b6b9", + "60b553": "dfb053", + "366635": "ab5130", + "e35252": "3a3f5e", + "c52119": "ebc67c", + "292929": "202937", + "9c5200": "23345e", + "f7e652": "577b98", + "95635b": "a09ea3", + "171717": "a45233", + "ba2525": "2b2b45", + "e65a42": "eedd9c", + "54545c": "45525c", + "52525a": "f1b571", + "fffdea": "f2f0df", + "f7bd21": "445f8a", + "5f3434": "666060" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/female/25-tough-cosplay.json b/public/images/pokemon/variant/female/25-tough-cosplay.json new file mode 100644 index 00000000000..620ac882643 --- /dev/null +++ b/public/images/pokemon/variant/female/25-tough-cosplay.json @@ -0,0 +1,43 @@ +{ + "1": { + "e37511": "d1694f", + "bf2629": "bf3638", + "303030": "30263b", + "b8282b": "753652", + "8d2b1d": "8e2525", + "424242": "443e6c", + "c52119": "ad4e76", + "292929": "1e1526", + "f7bd21": "79b5a5", + "fbab33": "de9764", + "db4a37": "ad4c60", + "e65a42": "cf6182", + "9c5200": "315c75", + "db5b42": "cf6a59", + "52525a": "4f454c", + "cecab9": "cfc8aa", + "f7e652": "a3d1a8" + }, + "2": { + "e37511": "644794", + "bf2629": "8e6fa1", + "f8ffe3": "e8e3e4", + "303030": "d8805b", + "b8282b": "6a253f", + "8d2b1d": "242866", + "424242": "3f4246", + "c52119": "e8be68", + "292929": "a45233", + "f7bd21": "445f8a", + "fbab33": "845ea1", + "db4a37": "b95b6e", + "e65a42": "edda8c", + "9c5200": "23345e", + "db5b42": "624780", + "52525a": "f1b571", + "4d4d4d": "2b3340", + "272b2b": "162231", + "cecab9": "cfc0c3", + "f7e652": "577b98" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/female/25.json b/public/images/pokemon/variant/female/25.json new file mode 100644 index 00000000000..0542587ba6d --- /dev/null +++ b/public/images/pokemon/variant/female/25.json @@ -0,0 +1,36 @@ +{ + "1": { + "42424a": "443e6c", + "fff7a5": "c4e3c3", + "c52119": "ad4e76", + "de9400": "338087", + "e65a42": "cf6182", + "f7e652": "a3d1a8", + "e66953": "b95b6e", + "45454a": "4f454c", + "292929": "282030", + "c43129": "6a253f", + "212121": "30263b", + "171717": "1e1526", + "f7bd21": "79b5a5", + "9c5200": "315c75", + "633108": "09406b" + }, + "2": { + "42424a": "3f4246", + "fff7a5": "7b96aa", + "c52119": "ebc67c", + "de9400": "324472", + "e65a42": "eedd9c", + "f7e652": "577b98", + "e66953": "b95b6e", + "45454a": "f1b571", + "292929": "282030", + "c43129": "6a253f", + "212121": "d8805b", + "171717": "a45233", + "f7bd21": "445f8a", + "9c5200": "23345e", + "633108": "22244f" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/female/26.json b/public/images/pokemon/variant/female/26.json new file mode 100644 index 00000000000..40921512c4b --- /dev/null +++ b/public/images/pokemon/variant/female/26.json @@ -0,0 +1,39 @@ +{ + "1": { + "101010": "000000", + "ffefd6": "c8d4ba", + "bd1908": "ad4e76", + "944242": "643034", + "bd5a31": "386d82", + "e6bd84": "a4bda7", + "ffbd00": "b3596b", + "5a2929": "293059", + "3a3a42": "30263b", + "8c6310": "8c3c4c", + "ffde5a": "cf7878", + "8d5911": "983e50", + "734231": "6e2f33", + "63636b": "4f454c", + "de7b31": "539190", + "f7ad29": "76a68b", + "643034": "395a80" + }, + "2": { + "101010": "000000", + "ffefd6": "cfc4b5", + "542127": "905331", + "bd1908": "a44c5d", + "944242": "2e4685", + "bd5a31": "375681", + "e6bd84": "a6b5ab", + "ffbd00": "f3cf91", + "5a2929": "202a60", + "8c6310": "c79b5a", + "ffde5a": "f2e4b6", + "8d5911": "dea96e", + "734231": "bd8447", + "de7b31": "4d6f98", + "f7ad29": "6385ab", + "643034": "2d3b80" + } +} \ No newline at end of file diff --git a/public/images/pokemon/variant/female/453.json b/public/images/pokemon/variant/female/453.json index 54703fa28c3..d559555ff45 100644 --- a/public/images/pokemon/variant/female/453.json +++ b/public/images/pokemon/variant/female/453.json @@ -1,7 +1,6 @@ { "1": { "4a4a8c": "701221", - "101010": "101010", "849cff": "c45447", "6b73d6": "9e1e23", "525252": "502424", @@ -17,16 +16,15 @@ }, "2": { "4a4a8c": "d88f77", - "101010": "101010", "849cff": "fff2c9", "6b73d6": "f0ce8b", - "525252": "75204b", - "313142": "40061f", + "525252": "6c1b54", + "313142": "43102b", "ffd619": "ff81ae", "b58c19": "d0498c", - "9c3a3a": "16729b", - "e6525a": "40adbb", - "ff9ca5": "a9ebeb", + "9c3a3a": "098a70", + "e6525a": "2ec276", + "ff9ca5": "92f194", "ffffff": "f0e3e5", "b5b5c5": "b1798c", "7b7b8c": "7e3a6a" diff --git a/public/images/pokemon/variant/female/454.json b/public/images/pokemon/variant/female/454.json index 60fff870be6..6f6b51d1cb2 100644 --- a/public/images/pokemon/variant/female/454.json +++ b/public/images/pokemon/variant/female/454.json @@ -1,7 +1,6 @@ { "1": { "4a4a8c": "701221", - "101010": "101010", "6b73d6": "9e1e23", "849cff": "c45447", "313142": "2c0f0f", @@ -18,19 +17,18 @@ }, "2": { "4a4a8c": "d88f77", - "101010": "101010", "6b73d6": "f0ce8b", "849cff": "fff2c9", - "313142": "610d31", - "525252": "af465d", + "313142": "610d48", + "525252": "af467d", "b58c19": "d0498c", "ffd619": "ff81ae", - "e6525a": "40adbb", - "9c3a3a": "16729b", + "e6525a": "2ec276", + "9c3a3a": "098a70", "b5b5c5": "b1798c", "ffffff": "f0e3e5", "3a3a52": "b15248", - "ff9ca5": "a9ebeb", + "ff9ca5": "92f194", "7b7b8c": "7e3a6a" } } \ No newline at end of file diff --git a/public/images/pokemon_icons_1.json b/public/images/pokemon_icons_1.json index 49e471514cd..12e26b380a5 100644 --- a/public/images/pokemon_icons_1.json +++ b/public/images/pokemon_icons_1.json @@ -1647,6 +1647,27 @@ "h": 25 } }, + { + "filename": "85-f", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 5, + "y": 3, + "w": 29, + "h": 25 + }, + "frame": { + "x": 55, + "y": 270, + "w": 29, + "h": 25 + } + }, { "filename": "22s", "rotated": false, @@ -1731,6 +1752,27 @@ "h": 25 } }, + { + "filename": "85s-f", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 5, + "y": 3, + "w": 29, + "h": 25 + }, + "frame": { + "x": 56, + "y": 317, + "w": 29, + "h": 25 + } + }, { "filename": "9s", "rotated": false, @@ -6456,6 +6498,27 @@ "h": 18 } }, + { + "filename": "84-f", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 9, + "y": 10, + "w": 21, + "h": 18 + }, + "frame": { + "x": 98, + "y": 712, + "w": 21, + "h": 18 + } + }, { "filename": "107", "rotated": false, @@ -6519,6 +6582,27 @@ "h": 18 } }, + { + "filename": "84s-f", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 9, + "y": 10, + "w": 21, + "h": 18 + }, + "frame": { + "x": 96, + "y": 770, + "w": 21, + "h": 18 + } + }, { "filename": "88", "rotated": false, diff --git a/public/images/pokemon_icons_1v.json b/public/images/pokemon_icons_1v.json index 4400b9d0213..de66db65eb7 100644 --- a/public/images/pokemon_icons_1v.json +++ b/public/images/pokemon_icons_1v.json @@ -1,1740 +1,2299 @@ -{ "frames": { - "100_2": { - "frame": { "x": 390, "y": 53, "w": 14, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 14, "w": 14, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "100_3": { - "frame": { "x": 328, "y": 30, "w": 14, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 14, "w": 14, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "101_2": { - "frame": { "x": 287, "y": 172, "w": 16, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 12, "w": 16, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "101_3": { - "frame": { "x": 263, "y": 156, "w": 16, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 12, "w": 16, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "111_2": { - "frame": { "x": 211, "y": 226, "w": 24, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 8, "w": 24, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "111_3": { - "frame": { "x": 265, "y": 233, "w": 24, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 8, "w": 24, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "112_2": { - "frame": { "x": 347, "y": 125, "w": 25, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 25, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "112_3": { - "frame": { "x": 322, "y": 125, "w": 25, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 25, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "113_1": { - "frame": { "x": 421, "y": 158, "w": 19, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 8, "w": 19, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "113_2": { - "frame": { "x": 299, "y": 277, "w": 19, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 8, "w": 19, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "113_3": { - "frame": { "x": 280, "y": 276, "w": 19, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 8, "w": 19, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "114_2": { - "frame": { "x": 212, "y": 297, "w": 19, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 10, "w": 19, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "114_3": { - "frame": { "x": 336, "y": 298, "w": 19, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 10, "w": 19, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "116_2": { - "frame": { "x": 142, "y": 303, "w": 18, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 11, "w": 18, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "116_3": { - "frame": { "x": 17, "y": 303, "w": 18, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 11, "w": 18, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "117_2": { - "frame": { "x": 92, "y": 226, "w": 24, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 8, "w": 24, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "117_3": { - "frame": { "x": 376, "y": 223, "w": 24, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 8, "w": 24, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "118_1": { - "frame": { "x": 400, "y": 241, "w": 24, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 9, "w": 24, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "118_2": { - "frame": { "x": 20, "y": 242, "w": 24, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 9, "w": 24, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "118_3": { - "frame": { "x": 372, "y": 243, "w": 24, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 9, "w": 24, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "119_1": { - "frame": { "x": 400, "y": 200, "w": 25, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 8, "w": 25, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "119_2": { - "frame": { "x": 196, "y": 199, "w": 25, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 8, "w": 25, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "119_3": { - "frame": { "x": 0, "y": 199, "w": 25, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 8, "w": 25, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "120_2": { - "frame": { "x": 77, "y": 306, "w": 17, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 11, "w": 17, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "120_3": { - "frame": { "x": 94, "y": 311, "w": 17, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 11, "w": 17, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "121_2": { - "frame": { "x": 355, "y": 300, "w": 19, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 10, "w": 19, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "121_3": { - "frame": { "x": 58, "y": 296, "w": 19, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 10, "w": 19, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "123_1": { - "frame": { "x": 148, "y": 284, "w": 19, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 9, "w": 19, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "123_2": { - "frame": { "x": 0, "y": 284, "w": 19, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 9, "w": 19, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "123_3": { - "frame": { "x": 173, "y": 283, "w": 19, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 9, "w": 19, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "125_1": { - "frame": { "x": 69, "y": 235, "w": 21, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 21, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "125_2": { - "frame": { "x": 311, "y": 235, "w": 21, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 21, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "125_3": { - "frame": { "x": 235, "y": 234, "w": 21, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 21, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "126_2": { - "frame": { "x": 287, "y": 188, "w": 22, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 5, "w": 22, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "126_3": { - "frame": { "x": 378, "y": 178, "w": 22, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 5, "w": 22, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "127-mega_2": { - "frame": { "x": 0, "y": 54, "w": 31, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 4, "w": 31, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "127-mega_3": { - "frame": { "x": 359, "y": 53, "w": 31, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 4, "w": 31, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "127_2": { - "frame": { "x": 0, "y": 219, "w": 23, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 7, "w": 23, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "127_3": { - "frame": { "x": 46, "y": 223, "w": 23, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 7, "w": 23, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "129_2": { - "frame": { "x": 213, "y": 175, "w": 22, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 5, "w": 22, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "129_3": { - "frame": { "x": 418, "y": 0, "w": 22, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 5, "w": 22, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "130-mega_2": { - "frame": { "x": 30, "y": 25, "w": 30, "h": 29 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 1, "w": 30, "h": 29 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "130-mega_3": { - "frame": { "x": 0, "y": 25, "w": 30, "h": 29 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 1, "w": 30, "h": 29 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "130_2": { - "frame": { "x": 210, "y": 30, "w": 29, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 2, "w": 29, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "130_3": { - "frame": { "x": 239, "y": 30, "w": 29, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 2, "w": 29, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "131-gigantamax_2": { - "frame": { "x": 373, "y": 25, "w": 31, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 0, "w": 31, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "131-gigantamax_3": { - "frame": { "x": 342, "y": 25, "w": 31, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 0, "w": 31, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "131_2": { - "frame": { "x": 172, "y": 198, "w": 24, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 7, "w": 24, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "131_3": { - "frame": { "x": 354, "y": 194, "w": 24, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 7, "w": 24, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "132_2": { - "frame": { "x": 231, "y": 311, "w": 16, "h": 13 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 15, "w": 16, "h": 13 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "132_3": { - "frame": { "x": 247, "y": 312, "w": 16, "h": 13 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 15, "w": 16, "h": 13 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "133_2": { - "frame": { "x": 0, "y": 303, "w": 17, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 10, "w": 17, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "133_3": { - "frame": { "x": 35, "y": 305, "w": 17, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 10, "w": 17, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "134_2": { - "frame": { "x": 165, "y": 219, "w": 23, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 7, "w": 23, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "134_3": { - "frame": { "x": 69, "y": 214, "w": 23, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 7, "w": 23, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "135_1": { - "frame": { "x": 20, "y": 261, "w": 20, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 7, "w": 20, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "135_2": { - "frame": { "x": 153, "y": 263, "w": 20, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 7, "w": 20, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "135_3": { - "frame": { "x": 396, "y": 260, "w": 20, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 7, "w": 20, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "136_1": { - "frame": { "x": 23, "y": 221, "w": 23, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 7, "w": 23, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "136_2": { - "frame": { "x": 400, "y": 220, "w": 23, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 7, "w": 23, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "136_3": { - "frame": { "x": 142, "y": 217, "w": 23, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 7, "w": 23, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "137_2": { - "frame": { "x": 280, "y": 296, "w": 19, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 10, "w": 19, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "137_3": { - "frame": { "x": 299, "y": 297, "w": 19, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 10, "w": 19, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "138_2": { - "frame": { "x": 415, "y": 301, "w": 18, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 10, "w": 18, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "138_3": { - "frame": { "x": 167, "y": 302, "w": 18, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 10, "w": 18, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "139_2": { - "frame": { "x": 47, "y": 201, "w": 22, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 6, "w": 22, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "139_3": { - "frame": { "x": 243, "y": 212, "w": 22, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 6, "w": 22, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "140_2": { - "frame": { "x": 263, "y": 312, "w": 16, "h": 13 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 15, "w": 16, "h": 13 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "140_3": { - "frame": { "x": 424, "y": 239, "w": 16, "h": 13 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 15, "w": 16, "h": 13 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "141_2": { - "frame": { "x": 261, "y": 276, "w": 19, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 7, "w": 19, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "141_3": { - "frame": { "x": 214, "y": 276, "w": 19, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 7, "w": 19, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "142-mega_2": { - "frame": { "x": 268, "y": 56, "w": 32, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 5, "w": 32, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "142-mega_3": { - "frame": { "x": 62, "y": 57, "w": 32, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 5, "w": 32, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "142_2": { - "frame": { "x": 322, "y": 103, "w": 29, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 5, "w": 29, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "142_3": { - "frame": { "x": 351, "y": 103, "w": 29, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 5, "w": 29, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "144_1": { - "frame": { "x": 304, "y": 168, "w": 27, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 7, "w": 27, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "144_2": { - "frame": { "x": 49, "y": 158, "w": 27, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 7, "w": 27, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "144_3": { - "frame": { "x": 394, "y": 158, "w": 27, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 7, "w": 27, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "145_1": { - "frame": { "x": 77, "y": 155, "w": 29, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 7, "w": 29, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "145_2": { - "frame": { "x": 130, "y": 153, "w": 29, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 7, "w": 29, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "145_3": { - "frame": { "x": 159, "y": 153, "w": 29, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 7, "w": 29, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "146_1": { - "frame": { "x": 70, "y": 196, "w": 28, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 8, "w": 28, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "146_2": { - "frame": { "x": 122, "y": 195, "w": 28, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 8, "w": 28, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "146_3": { - "frame": { "x": 258, "y": 194, "w": 28, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 8, "w": 28, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "147_2": { - "frame": { "x": 192, "y": 287, "w": 20, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 10, "w": 20, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "147_3": { - "frame": { "x": 38, "y": 287, "w": 20, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 10, "w": 20, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "148_2": { - "frame": { "x": 98, "y": 204, "w": 22, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 22, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "148_3": { - "frame": { "x": 378, "y": 201, "w": 22, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 22, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "149_2": { - "frame": { "x": 188, "y": 155, "w": 25, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 6, "w": 25, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "149_3": { - "frame": { "x": 24, "y": 156, "w": 25, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 6, "w": 25, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "150-mega-x_2": { - "frame": { "x": 106, "y": 155, "w": 21, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 2, "w": 21, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "150-mega-x_3": { - "frame": { "x": 242, "y": 156, "w": 21, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 2, "w": 21, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "150-mega-y_2": { - "frame": { "x": 175, "y": 107, "w": 20, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 0, "w": 20, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "150-mega-y_3": { - "frame": { "x": 407, "y": 108, "w": 20, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 0, "w": 20, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "150_2": { - "frame": { "x": 352, "y": 236, "w": 20, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 5, "w": 20, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "150_3": { - "frame": { "x": 332, "y": 235, "w": 20, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 5, "w": 20, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "151_2": { - "frame": { "x": 195, "y": 130, "w": 23, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 2, "w": 23, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "151_3": { - "frame": { "x": 231, "y": 127, "w": 23, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 2, "w": 23, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "19_2": { - "frame": { "x": 321, "y": 258, "w": 20, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 7, "w": 20, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "19_3": { - "frame": { "x": 0, "y": 263, "w": 20, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 7, "w": 20, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "1_2": { - "frame": { "x": 338, "y": 279, "w": 20, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 9, "w": 20, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "1_3": { - "frame": { "x": 318, "y": 279, "w": 20, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 9, "w": 20, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "20_2": { - "frame": { "x": 174, "y": 177, "w": 25, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 7, "w": 25, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "20_3": { - "frame": { "x": 23, "y": 178, "w": 25, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 7, "w": 25, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "23_2": { - "frame": { "x": 416, "y": 280, "w": 18, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 7, "w": 18, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "23_3": { - "frame": { "x": 20, "y": 282, "w": 18, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 7, "w": 18, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "24_2": { - "frame": { "x": 138, "y": 238, "w": 20, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 5, "w": 20, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "24_3": { - "frame": { "x": 0, "y": 240, "w": 20, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 5, "w": 20, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "29_1": { - "frame": { "x": 130, "y": 133, "w": 18, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 9, "w": 18, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "29_2": { - "frame": { "x": 397, "y": 299, "w": 18, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 9, "w": 18, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "29_3": { - "frame": { "x": 379, "y": 299, "w": 18, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 9, "w": 18, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "2_2": { - "frame": { "x": 362, "y": 262, "w": 21, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 8, "w": 21, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "2_3": { - "frame": { "x": 173, "y": 263, "w": 21, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 8, "w": 21, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "3-gigantamax_2": { - "frame": { "x": 214, "y": 0, "w": 32, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 0, "w": 32, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "3-gigantamax_3": { - "frame": { "x": 246, "y": 0, "w": 32, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 0, "w": 32, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "3-mega_2": { - "frame": { "x": 181, "y": 58, "w": 29, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 2, "w": 29, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "3-mega_3": { - "frame": { "x": 152, "y": 57, "w": 29, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 2, "w": 29, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "30_2": { - "frame": { "x": 87, "y": 267, "w": 19, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 6, "w": 19, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "30_3": { - "frame": { "x": 40, "y": 265, "w": 19, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 6, "w": 19, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "31_1": { - "frame": { "x": 331, "y": 168, "w": 23, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 23, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "31_2": { - "frame": { "x": 0, "y": 172, "w": 23, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 23, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "31_3": { - "frame": { "x": 127, "y": 172, "w": 23, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 23, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "35_2": { - "frame": { "x": 318, "y": 298, "w": 18, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 9, "w": 18, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "35_3": { - "frame": { "x": 124, "y": 299, "w": 18, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 9, "w": 18, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "36_2": { - "frame": { "x": 178, "y": 240, "w": 20, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 5, "w": 20, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "36_3": { - "frame": { "x": 158, "y": 240, "w": 20, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 5, "w": 20, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "37_2": { - "frame": { "x": 194, "y": 267, "w": 20, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 8, "w": 20, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "37_3": { - "frame": { "x": 241, "y": 274, "w": 20, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 8, "w": 20, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "38_2": { - "frame": { "x": 370, "y": 149, "w": 24, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 24, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "38_3": { - "frame": { "x": 218, "y": 152, "w": 24, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 24, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "3_2": { - "frame": { "x": 0, "y": 79, "w": 30, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 4, "w": 30, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "3_3": { - "frame": { "x": 240, "y": 80, "w": 30, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 4, "w": 30, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "41_1": { - "frame": { "x": 341, "y": 259, "w": 21, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 7, "w": 21, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "41_2": { - "frame": { "x": 416, "y": 260, "w": 21, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 7, "w": 21, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "41_3": { - "frame": { "x": 132, "y": 261, "w": 21, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 7, "w": 21, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "42_1": { - "frame": { "x": 104, "y": 133, "w": 26, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 5, "w": 26, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "42_2": { - "frame": { "x": 25, "y": 134, "w": 26, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 5, "w": 26, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "42_3": { - "frame": { "x": 51, "y": 136, "w": 26, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 5, "w": 26, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "43_2": { - "frame": { "x": 423, "y": 220, "w": 17, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 9, "w": 17, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "43_3": { - "frame": { "x": 423, "y": 178, "w": 17, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 9, "w": 17, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "44_2": { - "frame": { "x": 116, "y": 235, "w": 22, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 7, "w": 22, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "44_3": { - "frame": { "x": 289, "y": 235, "w": 22, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 7, "w": 22, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "45_2": { - "frame": { "x": 100, "y": 181, "w": 22, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 22, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "45_3": { - "frame": { "x": 48, "y": 178, "w": 22, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 22, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "46_1": { - "frame": { "x": 65, "y": 257, "w": 22, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 8, "w": 22, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "46_2": { - "frame": { "x": 299, "y": 257, "w": 22, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 8, "w": 22, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "46_3": { - "frame": { "x": 78, "y": 113, "w": 22, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 8, "w": 22, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "47_1": { - "frame": { "x": 25, "y": 199, "w": 22, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 6, "w": 22, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "47_2": { - "frame": { "x": 308, "y": 213, "w": 22, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 6, "w": 22, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "47_3": { - "frame": { "x": 120, "y": 213, "w": 22, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 6, "w": 22, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "4_2": { - "frame": { "x": 59, "y": 277, "w": 21, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 9, "w": 21, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "4_3": { - "frame": { "x": 106, "y": 277, "w": 21, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 9, "w": 21, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "50_2": { - "frame": { "x": 425, "y": 138, "w": 15, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 14, "w": 15, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "50_3": { - "frame": { "x": 425, "y": 197, "w": 15, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 14, "w": 15, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "51_2": { - "frame": { "x": 286, "y": 211, "w": 22, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 6, "w": 22, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "51_3": { - "frame": { "x": 221, "y": 204, "w": 22, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 6, "w": 22, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "52-gigantamax_1": { - "frame": { "x": 77, "y": 83, "w": 23, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 23, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "52-gigantamax_2": { - "frame": { "x": 54, "y": 81, "w": 23, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 23, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "52-gigantamax_3": { - "frame": { "x": 417, "y": 78, "w": 23, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 23, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "52_1": { - "frame": { "x": 44, "y": 244, "w": 21, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 7, "w": 21, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "52_2": { - "frame": { "x": 90, "y": 246, "w": 21, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 7, "w": 21, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "52_3": { - "frame": { "x": 198, "y": 246, "w": 21, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 7, "w": 21, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "53_1": { - "frame": { "x": 235, "y": 182, "w": 23, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 23, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "53_2": { - "frame": { "x": 400, "y": 178, "w": 23, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 23, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "53_3": { - "frame": { "x": 309, "y": 191, "w": 23, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 23, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "56_1": { - "frame": { "x": 342, "y": 148, "w": 28, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 8, "w": 28, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "56_2": { - "frame": { "x": 314, "y": 148, "w": 28, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 8, "w": 28, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "56_3": { - "frame": { "x": 397, "y": 138, "w": 28, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 8, "w": 28, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "57_1": { - "frame": { "x": 150, "y": 83, "w": 28, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 5, "w": 28, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "57_2": { - "frame": { "x": 294, "y": 103, "w": 28, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 5, "w": 28, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "57_3": { - "frame": { "x": 0, "y": 103, "w": 28, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 5, "w": 28, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "5_2": { - "frame": { "x": 332, "y": 191, "w": 22, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 22, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "5_3": { - "frame": { "x": 150, "y": 194, "w": 22, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 22, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "6-gigantamax_2": { - "frame": { "x": 270, "y": 80, "w": 24, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 0, "w": 24, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "6-gigantamax_3": { - "frame": { "x": 30, "y": 81, "w": 24, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 0, "w": 24, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "6-mega-x_2": { - "frame": { "x": 40, "y": 0, "w": 40, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 0, "y": 2, "w": 40, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "6-mega-x_3": { - "frame": { "x": 0, "y": 0, "w": 40, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 0, "y": 2, "w": 40, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "6-mega-y_2": { - "frame": { "x": 380, "y": 0, "w": 38, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 1, "y": 2, "w": 38, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "6-mega-y_3": { - "frame": { "x": 342, "y": 0, "w": 38, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 1, "y": 2, "w": 38, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "69_2": { - "frame": { "x": 173, "y": 137, "w": 20, "h": 15 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 13, "w": 20, "h": 15 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "69_3": { - "frame": { "x": 185, "y": 305, "w": 20, "h": 15 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 13, "w": 20, "h": 15 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "6_2": { - "frame": { "x": 60, "y": 29, "w": 32, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 1, "w": 32, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "6_3": { - "frame": { "x": 404, "y": 25, "w": 32, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 1, "w": 32, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "70_2": { - "frame": { "x": 277, "y": 256, "w": 22, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 8, "w": 22, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "70_3": { - "frame": { "x": 219, "y": 256, "w": 22, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 8, "w": 22, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "71_2": { - "frame": { "x": 178, "y": 84, "w": 28, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 5, "w": 28, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "71_3": { - "frame": { "x": 210, "y": 83, "w": 28, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 5, "w": 28, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "77_2": { - "frame": { "x": 280, "y": 149, "w": 24, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 24, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "77_3": { - "frame": { "x": 0, "y": 149, "w": 24, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 24, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "78_2": { - "frame": { "x": 123, "y": 57, "w": 29, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 2, "w": 29, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "78_3": { - "frame": { "x": 94, "y": 57, "w": 29, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 2, "w": 29, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "79_1": { - "frame": { "x": 265, "y": 212, "w": 21, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 7, "w": 21, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "79_2": { - "frame": { "x": 256, "y": 253, "w": 21, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 7, "w": 21, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "79_3": { - "frame": { "x": 111, "y": 256, "w": 21, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 7, "w": 21, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "7_2": { - "frame": { "x": 233, "y": 294, "w": 21, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 11, "w": 21, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "7_3": { - "frame": { "x": 80, "y": 289, "w": 21, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 11, "w": 21, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "80-mega_2": { - "frame": { "x": 125, "y": 83, "w": 25, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 2, "w": 25, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "80-mega_3": { - "frame": { "x": 100, "y": 83, "w": 25, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 2, "w": 25, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "80_2": { - "frame": { "x": 238, "y": 104, "w": 27, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 27, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "80_3": { - "frame": { "x": 380, "y": 103, "w": 27, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 27, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "81_2": { - "frame": { "x": 101, "y": 296, "w": 23, "h": 15 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 12, "w": 23, "h": 15 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "81_3": { - "frame": { "x": 254, "y": 297, "w": 23, "h": 15 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 12, "w": 23, "h": 15 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "82_2": { - "frame": { "x": 354, "y": 172, "w": 24, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 24, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "82_3": { - "frame": { "x": 76, "y": 174, "w": 24, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 24, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "83_2": { - "frame": { "x": 78, "y": 133, "w": 26, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 26, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "83_3": { - "frame": { "x": 254, "y": 134, "w": 26, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 26, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "84_1": { - "frame": { "x": 358, "y": 282, "w": 21, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 10, "w": 21, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "84_2": { - "frame": { "x": 383, "y": 281, "w": 21, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 10, "w": 21, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "84_3": { - "frame": { "x": 127, "y": 281, "w": 21, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 10, "w": 21, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "85_1": { - "frame": { "x": 388, "y": 78, "w": 29, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 3, "w": 29, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "85_2": { - "frame": { "x": 359, "y": 78, "w": 29, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 3, "w": 29, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "85_3": { - "frame": { "x": 330, "y": 78, "w": 29, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 3, "w": 29, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "86_1": { - "frame": { "x": 53, "y": 113, "w": 25, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 25, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "86_2": { - "frame": { "x": 28, "y": 111, "w": 25, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 25, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "86_3": { - "frame": { "x": 148, "y": 130, "w": 25, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 25, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "87_1": { - "frame": { "x": 372, "y": 126, "w": 25, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 25, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "87_2": { - "frame": { "x": 0, "y": 126, "w": 25, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 25, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "87_3": { - "frame": { "x": 289, "y": 126, "w": 25, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 25, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "8_2": { - "frame": { "x": 150, "y": 172, "w": 24, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 24, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "8_3": { - "frame": { "x": 263, "y": 172, "w": 24, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 24, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "9-gigantamax_2": { - "frame": { "x": 181, "y": 30, "w": 29, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 0, "w": 29, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "9-gigantamax_3": { - "frame": { "x": 152, "y": 29, "w": 29, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 0, "w": 29, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "9-mega_2": { - "frame": { "x": 122, "y": 29, "w": 30, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 1, "w": 30, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "9-mega_3": { - "frame": { "x": 92, "y": 29, "w": 30, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 1, "w": 30, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "92_1": { - "frame": { "x": 188, "y": 219, "w": 23, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 7, "w": 23, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "92_2": { - "frame": { "x": 330, "y": 214, "w": 23, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 7, "w": 23, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "92_3": { - "frame": { "x": 353, "y": 215, "w": 23, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 7, "w": 23, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "93_1": { - "frame": { "x": 404, "y": 52, "w": 30, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 3, "y": 2, "w": 30, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "93_2": { - "frame": { "x": 268, "y": 30, "w": 30, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 3, "y": 2, "w": 30, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "93_3": { - "frame": { "x": 298, "y": 30, "w": 30, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 3, "y": 2, "w": 30, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "94-gigantamax_1": { - "frame": { "x": 182, "y": 0, "w": 32, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 0, "w": 32, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "94-gigantamax_2": { - "frame": { "x": 310, "y": 0, "w": 32, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 0, "w": 32, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "94-gigantamax_3": { - "frame": { "x": 278, "y": 0, "w": 32, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 0, "w": 32, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "94-mega_1": { - "frame": { "x": 148, "y": 0, "w": 34, "h": 29 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 3, "y": 1, "w": 34, "h": 29 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "94-mega_2": { - "frame": { "x": 114, "y": 0, "w": 34, "h": 29 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 3, "y": 1, "w": 34, "h": 29 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "94-mega_3": { - "frame": { "x": 80, "y": 0, "w": 34, "h": 29 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 3, "y": 1, "w": 34, "h": 29 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "94_1": { - "frame": { "x": 265, "y": 110, "w": 24, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 4, "w": 24, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "94_2": { - "frame": { "x": 124, "y": 109, "w": 24, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 4, "w": 24, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "94_3": { - "frame": { "x": 100, "y": 109, "w": 24, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 4, "w": 24, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "98_2": { - "frame": { "x": 240, "y": 58, "w": 28, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 7, "w": 28, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "98_3": { - "frame": { "x": 300, "y": 56, "w": 28, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 7, "w": 28, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "99-gigantamax_2": { - "frame": { "x": 328, "y": 53, "w": 31, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 3, "w": 31, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "99-gigantamax_3": { - "frame": { "x": 31, "y": 56, "w": 31, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 3, "w": 31, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "99_2": { - "frame": { "x": 300, "y": 78, "w": 30, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 5, "w": 30, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "99_3": { - "frame": { "x": 210, "y": 58, "w": 30, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 5, "w": 30, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "9_2": { - "frame": { "x": 150, "y": 106, "w": 25, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 4, "w": 25, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "9_3": { - "frame": { "x": 206, "y": 106, "w": 25, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 4, "w": 25, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - } - }, - "meta": { - "app": "https://www.aseprite.org/", - "version": "1.3.7-dev", - "image": "pokemon_icons_1v.png", - "format": "RGBA8888", - "size": { "w": 440, "h": 328 }, - "scale": "1" - } +{ + "textures": [ + { + "image": "pokemon_icons_1v.png", + "format": "RGBA8888", + "size": { + "w": 600, + "h": 600 + }, + "scale": 1, + "frames": [ + { + "filename": "1_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 0, "y": 0, "w": 40, "h": 30} + }, + { + "filename": "1_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 40, "y": 0, "w": 40, "h": 30} + }, + { + "filename": "2_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 80, "y": 0, "w": 40, "h": 30} + }, + { + "filename": "2_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 120, "y": 0, "w": 40, "h": 30} + }, + { + "filename": "3-gigantamax_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 160, "y": 0, "w": 40, "h": 30} + }, + { + "filename": "3-gigantamax_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 200, "y": 0, "w": 40, "h": 30} + }, + { + "filename": "3-mega_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 240, "y": 0, "w": 40, "h": 30} + }, + { + "filename": "3-mega_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 280, "y": 0, "w": 40, "h": 30} + }, + { + "filename": "3_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 320, "y": 0, "w": 40, "h": 30} + }, + { + "filename": "3_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 360, "y": 0, "w": 40, "h": 30} + }, + { + "filename": "4_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 400, "y": 0, "w": 40, "h": 30} + }, + { + "filename": "4_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 440, "y": 0, "w": 40, "h": 30} + }, + { + "filename": "5_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 480, "y": 0, "w": 40, "h": 30} + }, + { + "filename": "5_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 520, "y": 0, "w": 40, "h": 30} + }, + { + "filename": "6-gigantamax_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 560, "y": 0, "w": 40, "h": 30} + }, + { + "filename": "6-gigantamax_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 0, "y": 30, "w": 40, "h": 30} + }, + { + "filename": "6-mega-x_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 40, "y": 30, "w": 40, "h": 30} + }, + { + "filename": "6-mega-x_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 80, "y": 30, "w": 40, "h": 30} + }, + { + "filename": "6-mega-y_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 120, "y": 30, "w": 40, "h": 30} + }, + { + "filename": "6-mega-y_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 160, "y": 30, "w": 40, "h": 30} + }, + { + "filename": "6_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 200, "y": 30, "w": 40, "h": 30} + }, + { + "filename": "6_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 240, "y": 30, "w": 40, "h": 30} + }, + { + "filename": "7_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 280, "y": 30, "w": 40, "h": 30} + }, + { + "filename": "7_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 320, "y": 30, "w": 40, "h": 30} + }, + { + "filename": "8_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 360, "y": 30, "w": 40, "h": 30} + }, + { + "filename": "8_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 400, "y": 30, "w": 40, "h": 30} + }, + { + "filename": "9-gigantamax_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 440, "y": 30, "w": 40, "h": 30} + }, + { + "filename": "9-gigantamax_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 480, "y": 30, "w": 40, "h": 30} + }, + { + "filename": "9-mega_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 520, "y": 30, "w": 40, "h": 30} + }, + { + "filename": "9-mega_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 560, "y": 30, "w": 40, "h": 30} + }, + { + "filename": "9_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 0, "y": 60, "w": 40, "h": 30} + }, + { + "filename": "9_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 40, "y": 60, "w": 40, "h": 30} + }, + { + "filename": "19_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 80, "y": 60, "w": 40, "h": 30} + }, + { + "filename": "19_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 120, "y": 60, "w": 40, "h": 30} + }, + { + "filename": "20_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 160, "y": 60, "w": 40, "h": 30} + }, + { + "filename": "20_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 200, "y": 60, "w": 40, "h": 30} + }, + { + "filename": "23_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 240, "y": 60, "w": 40, "h": 30} + }, + { + "filename": "23_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 280, "y": 60, "w": 40, "h": 30} + }, + { + "filename": "24_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 320, "y": 60, "w": 40, "h": 30} + }, + { + "filename": "24_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 360, "y": 60, "w": 40, "h": 30} + }, + { + "filename": "25-beauty-cosplay_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 400, "y": 60, "w": 40, "h": 30} + }, + { + "filename": "25-beauty-cosplay_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 440, "y": 60, "w": 40, "h": 30} + }, + { + "filename": "25-cool-cosplay_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 480, "y": 60, "w": 40, "h": 30} + }, + { + "filename": "25-cool-cosplay_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 520, "y": 60, "w": 40, "h": 30} + }, + { + "filename": "25-cosplay_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 560, "y": 60, "w": 40, "h": 30} + }, + { + "filename": "25-cosplay_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 0, "y": 90, "w": 40, "h": 30} + }, + { + "filename": "25-cute-cosplay_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 40, "y": 90, "w": 40, "h": 30} + }, + { + "filename": "25-cute-cosplay_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 80, "y": 90, "w": 40, "h": 30} + }, + { + "filename": "25-gigantamax_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 120, "y": 90, "w": 40, "h": 30} + }, + { + "filename": "25-gigantamax_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 160, "y": 90, "w": 40, "h": 30} + }, + { + "filename": "25-partner_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 200, "y": 90, "w": 40, "h": 30} + }, + { + "filename": "25-partner_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 240, "y": 90, "w": 40, "h": 30} + }, + { + "filename": "25-smart-cosplay_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 280, "y": 90, "w": 40, "h": 30} + }, + { + "filename": "25-smart-cosplay_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 320, "y": 90, "w": 40, "h": 30} + }, + { + "filename": "25-tough-cosplay_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 360, "y": 90, "w": 40, "h": 30} + }, + { + "filename": "25-tough-cosplay_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 400, "y": 90, "w": 40, "h": 30} + }, + { + "filename": "25_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 440, "y": 90, "w": 40, "h": 30} + }, + { + "filename": "25_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 480, "y": 90, "w": 40, "h": 30} + }, + { + "filename": "26_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 520, "y": 90, "w": 40, "h": 30} + }, + { + "filename": "26_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 560, "y": 90, "w": 40, "h": 30} + }, + { + "filename": "29_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 0, "y": 120, "w": 40, "h": 30} + }, + { + "filename": "29_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 40, "y": 120, "w": 40, "h": 30} + }, + { + "filename": "29_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 80, "y": 120, "w": 40, "h": 30} + }, + { + "filename": "30_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 120, "y": 120, "w": 40, "h": 30} + }, + { + "filename": "30_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 160, "y": 120, "w": 40, "h": 30} + }, + { + "filename": "31_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 200, "y": 120, "w": 40, "h": 30} + }, + { + "filename": "31_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 240, "y": 120, "w": 40, "h": 30} + }, + { + "filename": "31_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 280, "y": 120, "w": 40, "h": 30} + }, + { + "filename": "35_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 320, "y": 120, "w": 40, "h": 30} + }, + { + "filename": "35_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 360, "y": 120, "w": 40, "h": 30} + }, + { + "filename": "36_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 400, "y": 120, "w": 40, "h": 30} + }, + { + "filename": "36_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 440, "y": 120, "w": 40, "h": 30} + }, + { + "filename": "37_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 480, "y": 120, "w": 40, "h": 30} + }, + { + "filename": "37_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 520, "y": 120, "w": 40, "h": 30} + }, + { + "filename": "38_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 560, "y": 120, "w": 40, "h": 30} + }, + { + "filename": "38_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 0, "y": 150, "w": 40, "h": 30} + }, + { + "filename": "39_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 40, "y": 150, "w": 40, "h": 30} + }, + { + "filename": "39_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 80, "y": 150, "w": 40, "h": 30} + }, + { + "filename": "40_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 120, "y": 150, "w": 40, "h": 30} + }, + { + "filename": "40_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 160, "y": 150, "w": 40, "h": 30} + }, + { + "filename": "41_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 200, "y": 150, "w": 40, "h": 30} + }, + { + "filename": "41_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 240, "y": 150, "w": 40, "h": 30} + }, + { + "filename": "41_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 280, "y": 150, "w": 40, "h": 30} + }, + { + "filename": "42_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 320, "y": 150, "w": 40, "h": 30} + }, + { + "filename": "42_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 360, "y": 150, "w": 40, "h": 30} + }, + { + "filename": "42_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 400, "y": 150, "w": 40, "h": 30} + }, + { + "filename": "43_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 440, "y": 150, "w": 40, "h": 30} + }, + { + "filename": "43_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 480, "y": 150, "w": 40, "h": 30} + }, + { + "filename": "44_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 520, "y": 150, "w": 40, "h": 30} + }, + { + "filename": "44_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 560, "y": 150, "w": 40, "h": 30} + }, + { + "filename": "45_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 0, "y": 180, "w": 40, "h": 30} + }, + { + "filename": "45_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 40, "y": 180, "w": 40, "h": 30} + }, + { + "filename": "46_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 80, "y": 180, "w": 40, "h": 30} + }, + { + "filename": "46_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 120, "y": 180, "w": 40, "h": 30} + }, + { + "filename": "46_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 160, "y": 180, "w": 40, "h": 30} + }, + { + "filename": "47_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 200, "y": 180, "w": 40, "h": 30} + }, + { + "filename": "47_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 240, "y": 180, "w": 40, "h": 30} + }, + { + "filename": "47_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 280, "y": 180, "w": 40, "h": 30} + }, + { + "filename": "50_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 320, "y": 180, "w": 40, "h": 30} + }, + { + "filename": "50_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 360, "y": 180, "w": 40, "h": 30} + }, + { + "filename": "51_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 400, "y": 180, "w": 40, "h": 30} + }, + { + "filename": "51_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 440, "y": 180, "w": 40, "h": 30} + }, + { + "filename": "52-gigantamax_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 480, "y": 180, "w": 40, "h": 30} + }, + { + "filename": "52-gigantamax_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 520, "y": 180, "w": 40, "h": 30} + }, + { + "filename": "52-gigantamax_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 560, "y": 180, "w": 40, "h": 30} + }, + { + "filename": "52_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 0, "y": 210, "w": 40, "h": 30} + }, + { + "filename": "52_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 40, "y": 210, "w": 40, "h": 30} + }, + { + "filename": "52_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 80, "y": 210, "w": 40, "h": 30} + }, + { + "filename": "53_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 120, "y": 210, "w": 40, "h": 30} + }, + { + "filename": "53_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 160, "y": 210, "w": 40, "h": 30} + }, + { + "filename": "53_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 200, "y": 210, "w": 40, "h": 30} + }, + { + "filename": "56_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 240, "y": 210, "w": 40, "h": 30} + }, + { + "filename": "56_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 280, "y": 210, "w": 40, "h": 30} + }, + { + "filename": "56_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 320, "y": 210, "w": 40, "h": 30} + }, + { + "filename": "57_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 360, "y": 210, "w": 40, "h": 30} + }, + { + "filename": "57_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 400, "y": 210, "w": 40, "h": 30} + }, + { + "filename": "57_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 440, "y": 210, "w": 40, "h": 30} + }, + { + "filename": "69_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 480, "y": 210, "w": 40, "h": 30} + }, + { + "filename": "69_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 520, "y": 210, "w": 40, "h": 30} + }, + { + "filename": "70_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 560, "y": 210, "w": 40, "h": 30} + }, + { + "filename": "70_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 0, "y": 240, "w": 40, "h": 30} + }, + { + "filename": "71_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 40, "y": 240, "w": 40, "h": 30} + }, + { + "filename": "71_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 80, "y": 240, "w": 40, "h": 30} + }, + { + "filename": "77_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 120, "y": 240, "w": 40, "h": 30} + }, + { + "filename": "77_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 160, "y": 240, "w": 40, "h": 30} + }, + { + "filename": "78_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 200, "y": 240, "w": 40, "h": 30} + }, + { + "filename": "78_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 240, "y": 240, "w": 40, "h": 30} + }, + { + "filename": "79_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 280, "y": 240, "w": 40, "h": 30} + }, + { + "filename": "79_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 320, "y": 240, "w": 40, "h": 30} + }, + { + "filename": "79_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 360, "y": 240, "w": 40, "h": 30} + }, + { + "filename": "80-mega_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 400, "y": 240, "w": 40, "h": 30} + }, + { + "filename": "80-mega_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 440, "y": 240, "w": 40, "h": 30} + }, + { + "filename": "80_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 480, "y": 240, "w": 40, "h": 30} + }, + { + "filename": "80_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 520, "y": 240, "w": 40, "h": 30} + }, + { + "filename": "81_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 560, "y": 240, "w": 40, "h": 30} + }, + { + "filename": "81_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 0, "y": 270, "w": 40, "h": 30} + }, + { + "filename": "82_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 40, "y": 270, "w": 40, "h": 30} + }, + { + "filename": "82_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 80, "y": 270, "w": 40, "h": 30} + }, + { + "filename": "83_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 120, "y": 270, "w": 40, "h": 30} + }, + { + "filename": "83_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 160, "y": 270, "w": 40, "h": 30} + }, + { + "filename": "84-f_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 200, "y": 270, "w": 40, "h": 30} + }, + { + "filename": "84-f_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 240, "y": 270, "w": 40, "h": 30} + }, + { + "filename": "84-f_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 280, "y": 270, "w": 40, "h": 30} + }, + { + "filename": "84_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 320, "y": 270, "w": 40, "h": 30} + }, + { + "filename": "84_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 360, "y": 270, "w": 40, "h": 30} + }, + { + "filename": "84_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 400, "y": 270, "w": 40, "h": 30} + }, + { + "filename": "85-f_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 440, "y": 270, "w": 40, "h": 30} + }, + { + "filename": "85-f_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 480, "y": 270, "w": 40, "h": 30} + }, + { + "filename": "85-f_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 520, "y": 270, "w": 40, "h": 30} + }, + { + "filename": "85_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 560, "y": 270, "w": 40, "h": 30} + }, + { + "filename": "85_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 0, "y": 300, "w": 40, "h": 30} + }, + { + "filename": "85_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 40, "y": 300, "w": 40, "h": 30} + }, + { + "filename": "86_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 80, "y": 300, "w": 40, "h": 30} + }, + { + "filename": "86_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 120, "y": 300, "w": 40, "h": 30} + }, + { + "filename": "86_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 160, "y": 300, "w": 40, "h": 30} + }, + { + "filename": "87_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 200, "y": 300, "w": 40, "h": 30} + }, + { + "filename": "87_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 240, "y": 300, "w": 40, "h": 30} + }, + { + "filename": "87_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 280, "y": 300, "w": 40, "h": 30} + }, + { + "filename": "92_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 320, "y": 300, "w": 40, "h": 30} + }, + { + "filename": "92_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 360, "y": 300, "w": 40, "h": 30} + }, + { + "filename": "92_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 400, "y": 300, "w": 40, "h": 30} + }, + { + "filename": "93_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 440, "y": 300, "w": 40, "h": 30} + }, + { + "filename": "93_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 480, "y": 300, "w": 40, "h": 30} + }, + { + "filename": "93_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 520, "y": 300, "w": 40, "h": 30} + }, + { + "filename": "94-gigantamax_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 560, "y": 300, "w": 40, "h": 30} + }, + { + "filename": "94-gigantamax_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 0, "y": 330, "w": 40, "h": 30} + }, + { + "filename": "94-gigantamax_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 40, "y": 330, "w": 40, "h": 30} + }, + { + "filename": "94-mega_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 80, "y": 330, "w": 40, "h": 30} + }, + { + "filename": "94-mega_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 120, "y": 330, "w": 40, "h": 30} + }, + { + "filename": "94-mega_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 160, "y": 330, "w": 40, "h": 30} + }, + { + "filename": "94_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 200, "y": 330, "w": 40, "h": 30} + }, + { + "filename": "94_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 240, "y": 330, "w": 40, "h": 30} + }, + { + "filename": "94_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 280, "y": 330, "w": 40, "h": 30} + }, + { + "filename": "98_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 320, "y": 330, "w": 40, "h": 30} + }, + { + "filename": "98_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 360, "y": 330, "w": 40, "h": 30} + }, + { + "filename": "99-gigantamax_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 400, "y": 330, "w": 40, "h": 30} + }, + { + "filename": "99-gigantamax_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 440, "y": 330, "w": 40, "h": 30} + }, + { + "filename": "99_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 480, "y": 330, "w": 40, "h": 30} + }, + { + "filename": "99_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 520, "y": 330, "w": 40, "h": 30} + }, + { + "filename": "100_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 560, "y": 330, "w": 40, "h": 30} + }, + { + "filename": "100_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 0, "y": 360, "w": 40, "h": 30} + }, + { + "filename": "101_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 40, "y": 360, "w": 40, "h": 30} + }, + { + "filename": "101_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 80, "y": 360, "w": 40, "h": 30} + }, + { + "filename": "102_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 120, "y": 360, "w": 40, "h": 30} + }, + { + "filename": "102_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 160, "y": 360, "w": 40, "h": 30} + }, + { + "filename": "103_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 200, "y": 360, "w": 40, "h": 30} + }, + { + "filename": "103_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 240, "y": 360, "w": 40, "h": 30} + }, + { + "filename": "111_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 280, "y": 360, "w": 40, "h": 30} + }, + { + "filename": "111_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 320, "y": 360, "w": 40, "h": 30} + }, + { + "filename": "112_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 360, "y": 360, "w": 40, "h": 30} + }, + { + "filename": "112_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 400, "y": 360, "w": 40, "h": 30} + }, + { + "filename": "113_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 440, "y": 360, "w": 40, "h": 30} + }, + { + "filename": "113_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 480, "y": 360, "w": 40, "h": 30} + }, + { + "filename": "113_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 520, "y": 360, "w": 40, "h": 30} + }, + { + "filename": "114_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 560, "y": 360, "w": 40, "h": 30} + }, + { + "filename": "114_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 0, "y": 390, "w": 40, "h": 30} + }, + { + "filename": "116_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 40, "y": 390, "w": 40, "h": 30} + }, + { + "filename": "116_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 80, "y": 390, "w": 40, "h": 30} + }, + { + "filename": "117_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 120, "y": 390, "w": 40, "h": 30} + }, + { + "filename": "117_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 160, "y": 390, "w": 40, "h": 30} + }, + { + "filename": "118_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 200, "y": 390, "w": 40, "h": 30} + }, + { + "filename": "118_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 240, "y": 390, "w": 40, "h": 30} + }, + { + "filename": "118_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 280, "y": 390, "w": 40, "h": 30} + }, + { + "filename": "119_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 320, "y": 390, "w": 40, "h": 30} + }, + { + "filename": "119_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 360, "y": 390, "w": 40, "h": 30} + }, + { + "filename": "119_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 400, "y": 390, "w": 40, "h": 30} + }, + { + "filename": "120_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 440, "y": 390, "w": 40, "h": 30} + }, + { + "filename": "120_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 480, "y": 390, "w": 40, "h": 30} + }, + { + "filename": "121_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 520, "y": 390, "w": 40, "h": 30} + }, + { + "filename": "121_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 560, "y": 390, "w": 40, "h": 30} + }, + { + "filename": "123_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 0, "y": 420, "w": 40, "h": 30} + }, + { + "filename": "123_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 40, "y": 420, "w": 40, "h": 30} + }, + { + "filename": "123_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 80, "y": 420, "w": 40, "h": 30} + }, + { + "filename": "125_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 120, "y": 420, "w": 40, "h": 30} + }, + { + "filename": "125_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 160, "y": 420, "w": 40, "h": 30} + }, + { + "filename": "125_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 200, "y": 420, "w": 40, "h": 30} + }, + { + "filename": "126_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 240, "y": 420, "w": 40, "h": 30} + }, + { + "filename": "126_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 280, "y": 420, "w": 40, "h": 30} + }, + { + "filename": "127-mega_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 320, "y": 420, "w": 40, "h": 30} + }, + { + "filename": "127-mega_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 360, "y": 420, "w": 40, "h": 30} + }, + { + "filename": "127_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 400, "y": 420, "w": 40, "h": 30} + }, + { + "filename": "127_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 440, "y": 420, "w": 40, "h": 30} + }, + { + "filename": "128_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 480, "y": 420, "w": 40, "h": 30} + }, + { + "filename": "128_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 520, "y": 420, "w": 40, "h": 30} + }, + { + "filename": "129_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 560, "y": 420, "w": 40, "h": 30} + }, + { + "filename": "129_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 0, "y": 450, "w": 40, "h": 30} + }, + { + "filename": "130-mega_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 40, "y": 450, "w": 40, "h": 30} + }, + { + "filename": "130-mega_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 80, "y": 450, "w": 40, "h": 30} + }, + { + "filename": "130_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 120, "y": 450, "w": 40, "h": 30} + }, + { + "filename": "130_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 160, "y": 450, "w": 40, "h": 30} + }, + { + "filename": "131-gigantamax_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 200, "y": 450, "w": 40, "h": 30} + }, + { + "filename": "131-gigantamax_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 240, "y": 450, "w": 40, "h": 30} + }, + { + "filename": "131_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 280, "y": 450, "w": 40, "h": 30} + }, + { + "filename": "131_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 320, "y": 450, "w": 40, "h": 30} + }, + { + "filename": "132_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 360, "y": 450, "w": 40, "h": 30} + }, + { + "filename": "132_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 400, "y": 450, "w": 40, "h": 30} + }, + { + "filename": "133-partner_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 440, "y": 450, "w": 40, "h": 30} + }, + { + "filename": "133-partner_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 480, "y": 450, "w": 40, "h": 30} + }, + { + "filename": "133_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 520, "y": 450, "w": 40, "h": 30} + }, + { + "filename": "133_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 560, "y": 450, "w": 40, "h": 30} + }, + { + "filename": "134_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 0, "y": 480, "w": 40, "h": 30} + }, + { + "filename": "134_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 40, "y": 480, "w": 40, "h": 30} + }, + { + "filename": "135_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 80, "y": 480, "w": 40, "h": 30} + }, + { + "filename": "135_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 120, "y": 480, "w": 40, "h": 30} + }, + { + "filename": "135_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 160, "y": 480, "w": 40, "h": 30} + }, + { + "filename": "136_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 200, "y": 480, "w": 40, "h": 30} + }, + { + "filename": "136_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 240, "y": 480, "w": 40, "h": 30} + }, + { + "filename": "136_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 280, "y": 480, "w": 40, "h": 30} + }, + { + "filename": "137_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 320, "y": 480, "w": 40, "h": 30} + }, + { + "filename": "137_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 360, "y": 480, "w": 40, "h": 30} + }, + { + "filename": "138_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 400, "y": 480, "w": 40, "h": 30} + }, + { + "filename": "138_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 440, "y": 480, "w": 40, "h": 30} + }, + { + "filename": "139_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 480, "y": 480, "w": 40, "h": 30} + }, + { + "filename": "139_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 520, "y": 480, "w": 40, "h": 30} + }, + { + "filename": "140_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 560, "y": 480, "w": 40, "h": 30} + }, + { + "filename": "140_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 0, "y": 510, "w": 40, "h": 30} + }, + { + "filename": "141_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 40, "y": 510, "w": 40, "h": 30} + }, + { + "filename": "141_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 80, "y": 510, "w": 40, "h": 30} + }, + { + "filename": "142-mega_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 120, "y": 510, "w": 40, "h": 30} + }, + { + "filename": "142-mega_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 160, "y": 510, "w": 40, "h": 30} + }, + { + "filename": "142_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 200, "y": 510, "w": 40, "h": 30} + }, + { + "filename": "142_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 240, "y": 510, "w": 40, "h": 30} + }, + { + "filename": "144_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 280, "y": 510, "w": 40, "h": 30} + }, + { + "filename": "144_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 320, "y": 510, "w": 40, "h": 30} + }, + { + "filename": "144_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 360, "y": 510, "w": 40, "h": 30} + }, + { + "filename": "145_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 400, "y": 510, "w": 40, "h": 30} + }, + { + "filename": "145_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 440, "y": 510, "w": 40, "h": 30} + }, + { + "filename": "145_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 480, "y": 510, "w": 40, "h": 30} + }, + { + "filename": "146_1", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 520, "y": 510, "w": 40, "h": 30} + }, + { + "filename": "146_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 560, "y": 510, "w": 40, "h": 30} + }, + { + "filename": "146_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 0, "y": 540, "w": 40, "h": 30} + }, + { + "filename": "147_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 40, "y": 540, "w": 40, "h": 30} + }, + { + "filename": "147_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 80, "y": 540, "w": 40, "h": 30} + }, + { + "filename": "148_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 120, "y": 540, "w": 40, "h": 30} + }, + { + "filename": "148_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 160, "y": 540, "w": 40, "h": 30} + }, + { + "filename": "149_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 200, "y": 540, "w": 40, "h": 30} + }, + { + "filename": "149_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 240, "y": 540, "w": 40, "h": 30} + }, + { + "filename": "150-mega-x_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 280, "y": 540, "w": 40, "h": 30} + }, + { + "filename": "150-mega-x_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 320, "y": 540, "w": 40, "h": 30} + }, + { + "filename": "150-mega-y_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 360, "y": 540, "w": 40, "h": 30} + }, + { + "filename": "150-mega-y_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 400, "y": 540, "w": 40, "h": 30} + }, + { + "filename": "150_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 440, "y": 540, "w": 40, "h": 30} + }, + { + "filename": "150_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 480, "y": 540, "w": 40, "h": 30} + }, + { + "filename": "151_2", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 520, "y": 540, "w": 40, "h": 30} + }, + { + "filename": "151_3", + "rotated": false, + "trimmed": false, + "sourceSize": {"w": 40, "h": 30}, + "spriteSourceSize": {"x": 0, "y": 0, "w": 40, "h": 30}, + "frame": {"x": 560, "y": 540, "w": 40, "h": 30} + } + ] + } + ], + "meta": { + "app": "texturepacker", + "version": "3.0" + } } diff --git a/public/images/pokemon_icons_1v.png b/public/images/pokemon_icons_1v.png index 2aa0433b3f6..d6b1bc0cf7e 100644 Binary files a/public/images/pokemon_icons_1v.png and b/public/images/pokemon_icons_1v.png differ diff --git a/public/images/pokemon_icons_2.json b/public/images/pokemon_icons_2.json index 5a389362bc0..c5ebfe61487 100644 --- a/public/images/pokemon_icons_2.json +++ b/public/images/pokemon_icons_2.json @@ -786,6 +786,27 @@ "h": 27 } }, + { + "filename": "154-f", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 8, + "y": 1, + "w": 23, + "h": 27 + }, + "frame": { + "x": 29, + "y": 147, + "w": 23, + "h": 27 + } + }, { "filename": "154s", "rotated": false, @@ -807,6 +828,27 @@ "h": 27 } }, + { + "filename": "154s-f", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 8, + "y": 1, + "w": 23, + "h": 27 + }, + "frame": { + "x": 29, + "y": 174, + "w": 23, + "h": 27 + } + }, { "filename": "229-mega", "rotated": false, diff --git a/public/images/pokemon_icons_2v.json b/public/images/pokemon_icons_2v.json index ac38ebbcf6b..23eec483b42 100644 --- a/public/images/pokemon_icons_2v.json +++ b/public/images/pokemon_icons_2v.json @@ -1,1271 +1,4640 @@ -{ "frames": { - "161_2": { - "frame": { "x": 225, "y": 163, "w": 15, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 4, "w": 15, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "161_3": { - "frame": { "x": 82, "y": 162, "w": 15, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 4, "w": 15, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "162_2": { - "frame": { "x": 22, "y": 102, "w": 23, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 7, "w": 23, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "162_3": { - "frame": { "x": 45, "y": 103, "w": 23, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 7, "w": 23, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "163_2": { - "frame": { "x": 0, "y": 184, "w": 17, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 8, "w": 17, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "163_3": { - "frame": { "x": 240, "y": 183, "w": 17, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 8, "w": 17, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "164_2": { - "frame": { "x": 64, "y": 145, "w": 18, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 5, "w": 18, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "164_3": { - "frame": { "x": 186, "y": 145, "w": 18, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 5, "w": 18, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "169_1": { - "frame": { "x": 148, "y": 29, "w": 30, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 6, "w": 30, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "169_2": { - "frame": { "x": 55, "y": 30, "w": 30, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 6, "w": 30, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "169_3": { - "frame": { "x": 85, "y": 30, "w": 30, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 6, "w": 30, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "173_3": { - "frame": { "x": 64, "y": 223, "w": 16, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 12, "w": 16, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "175_1": { - "frame": { "x": 185, "y": 206, "w": 16, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 10, "w": 16, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "175_2": { - "frame": { "x": 31, "y": 207, "w": 16, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 10, "w": 16, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "175_3": { - "frame": { "x": 169, "y": 207, "w": 16, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 10, "w": 16, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "176_1": { - "frame": { "x": 54, "y": 168, "w": 17, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 7, "w": 17, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "176_2": { - "frame": { "x": 37, "y": 166, "w": 17, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 7, "w": 17, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "176_3": { - "frame": { "x": 261, "y": 99, "w": 17, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 7, "w": 17, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "177_2": { - "frame": { "x": 135, "y": 196, "w": 17, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 10, "w": 17, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "177_3": { - "frame": { "x": 152, "y": 196, "w": 17, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 10, "w": 17, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "178_2": { - "frame": { "x": 276, "y": 164, "w": 17, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 7, "w": 17, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "178_3": { - "frame": { "x": 293, "y": 164, "w": 17, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 7, "w": 17, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "179_2": { - "frame": { "x": 226, "y": 143, "w": 22, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 8, "w": 22, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "179_3": { - "frame": { "x": 88, "y": 142, "w": 22, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 8, "w": 22, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "180_2": { - "frame": { "x": 116, "y": 122, "w": 21, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 21, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "180_3": { - "frame": { "x": 239, "y": 121, "w": 21, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 21, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "181-mega_2": { - "frame": { "x": 262, "y": 0, "w": 29, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 29, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "181-mega_3": { - "frame": { "x": 291, "y": 0, "w": 29, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 29, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "181_2": { - "frame": { "x": 200, "y": 96, "w": 20, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 3, "w": 20, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "181_3": { - "frame": { "x": 124, "y": 97, "w": 20, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 3, "w": 20, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "182_2": { - "frame": { "x": 97, "y": 184, "w": 16, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 7, "w": 16, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "182_3": { - "frame": { "x": 17, "y": 184, "w": 16, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 7, "w": 16, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "183_2": { - "frame": { "x": 154, "y": 160, "w": 23, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 11, "w": 23, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "183_3": { - "frame": { "x": 131, "y": 156, "w": 23, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 11, "w": 23, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "184_2": { - "frame": { "x": 25, "y": 56, "w": 25, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 4, "w": 25, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "184_3": { - "frame": { "x": 202, "y": 53, "w": 25, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 4, "w": 25, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "185_2": { - "frame": { "x": 22, "y": 123, "w": 22, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 8, "w": 22, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "185_3": { - "frame": { "x": 0, "y": 123, "w": 22, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 8, "w": 22, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "190_2": { - "frame": { "x": 284, "y": 124, "w": 24, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 9, "w": 24, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "190_3": { - "frame": { "x": 260, "y": 124, "w": 24, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 9, "w": 24, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "193_2": { - "frame": { "x": 137, "y": 140, "w": 28, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 12, "w": 28, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "193_3": { - "frame": { "x": 88, "y": 126, "w": 28, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 12, "w": 28, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "196_1": { - "frame": { "x": 251, "y": 78, "w": 27, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 7, "w": 27, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "196_2": { - "frame": { "x": 0, "y": 80, "w": 27, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 7, "w": 27, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "196_3": { - "frame": { "x": 289, "y": 77, "w": 27, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 7, "w": 27, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "197_2": { - "frame": { "x": 289, "y": 143, "w": 20, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 7, "w": 20, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "197_3": { - "frame": { "x": 269, "y": 143, "w": 20, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 7, "w": 20, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "199_1": { - "frame": { "x": 220, "y": 97, "w": 19, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 2, "w": 19, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "199_2": { - "frame": { "x": 297, "y": 98, "w": 19, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 2, "w": 19, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "199_3": { - "frame": { "x": 278, "y": 98, "w": 19, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 2, "w": 19, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "200_1": { - "frame": { "x": 69, "y": 204, "w": 16, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 9, "w": 16, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "200_2": { - "frame": { "x": 257, "y": 202, "w": 16, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 9, "w": 16, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "200_3": { - "frame": { "x": 211, "y": 203, "w": 16, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 9, "w": 16, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-a_2": { - "frame": { "x": 148, "y": 233, "w": 10, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 15, "y": 7, "w": 10, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-a_3": { - "frame": { "x": 128, "y": 230, "w": 10, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 15, "y": 7, "w": 10, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-b_2": { - "frame": { "x": 13, "y": 225, "w": 12, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 14, "y": 7, "w": 12, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-b_3": { - "frame": { "x": 271, "y": 224, "w": 12, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 14, "y": 7, "w": 12, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-c_2": { - "frame": { "x": 85, "y": 205, "w": 15, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 8, "w": 15, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-c_3": { - "frame": { "x": 304, "y": 205, "w": 15, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 8, "w": 15, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-d_2": { - "frame": { "x": 201, "y": 222, "w": 14, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 14, "y": 9, "w": 14, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-d_3": { - "frame": { "x": 215, "y": 222, "w": 14, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 14, "y": 9, "w": 14, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-exclamation_2": { - "frame": { "x": 227, "y": 53, "w": 10, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 14, "y": 8, "w": 10, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-exclamation_3": { - "frame": { "x": 103, "y": 241, "w": 10, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 14, "y": 8, "w": 10, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-e_2": { - "frame": { "x": 257, "y": 221, "w": 14, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 8, "w": 14, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-e_3": { - "frame": { "x": 243, "y": 203, "w": 14, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 8, "w": 14, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-f_2": { - "frame": { "x": 152, "y": 214, "w": 15, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 9, "w": 15, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-f_3": { - "frame": { "x": 212, "y": 77, "w": 15, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 9, "w": 15, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-g_2": { - "frame": { "x": 310, "y": 145, "w": 10, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 15, "y": 7, "w": 10, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-g_3": { - "frame": { "x": 138, "y": 230, "w": 10, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 15, "y": 7, "w": 10, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-h_2": { - "frame": { "x": 177, "y": 168, "w": 18, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 9, "w": 18, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-h_3": { - "frame": { "x": 115, "y": 173, "w": 18, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 9, "w": 18, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-i_2": { - "frame": { "x": 113, "y": 241, "w": 10, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 15, "y": 8, "w": 10, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-i_3": { - "frame": { "x": 199, "y": 241, "w": 10, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 15, "y": 8, "w": 10, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-j_2": { - "frame": { "x": 62, "y": 239, "w": 11, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 15, "y": 9, "w": 11, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-j_3": { - "frame": { "x": 92, "y": 241, "w": 11, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 15, "y": 9, "w": 11, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-k_2": { - "frame": { "x": 229, "y": 222, "w": 13, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 8, "w": 13, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-k_3": { - "frame": { "x": 226, "y": 123, "w": 13, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 8, "w": 13, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-l_2": { - "frame": { "x": 291, "y": 208, "w": 13, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 8, "w": 13, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-l_3": { - "frame": { "x": 0, "y": 223, "w": 13, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 8, "w": 13, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-m_2": { - "frame": { "x": 97, "y": 164, "w": 18, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 8, "w": 18, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-m_3": { - "frame": { "x": 19, "y": 164, "w": 18, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 8, "w": 18, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-n_2": { - "frame": { "x": 211, "y": 189, "w": 22, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 13, "w": 22, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-n_3": { - "frame": { "x": 113, "y": 192, "w": 22, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 13, "w": 22, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-o_2": { - "frame": { "x": 151, "y": 177, "w": 18, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 9, "w": 18, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-o_3": { - "frame": { "x": 133, "y": 173, "w": 18, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 9, "w": 18, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-p_2": { - "frame": { "x": 71, "y": 168, "w": 11, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 15, "y": 8, "w": 11, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-p_3": { - "frame": { "x": 278, "y": 78, "w": 11, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 15, "y": 8, "w": 11, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-question_2": { - "frame": { "x": 309, "y": 124, "w": 11, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 14, "y": 7, "w": 11, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-question_3": { - "frame": { "x": 51, "y": 225, "w": 11, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 14, "y": 7, "w": 11, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-q_2": { - "frame": { "x": 304, "y": 225, "w": 14, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 12, "w": 14, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-q_3": { - "frame": { "x": 283, "y": 228, "w": 14, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 12, "w": 14, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-r_2": { - "frame": { "x": 255, "y": 241, "w": 10, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 16, "y": 10, "w": 10, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-r_3": { - "frame": { "x": 297, "y": 241, "w": 10, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 16, "y": 10, "w": 10, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-s_2": { - "frame": { "x": 290, "y": 185, "w": 14, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 5, "w": 14, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-s_3": { - "frame": { "x": 276, "y": 185, "w": 14, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 5, "w": 14, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-t_2": { - "frame": { "x": 167, "y": 225, "w": 12, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 9, "w": 12, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-t_3": { - "frame": { "x": 80, "y": 225, "w": 12, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 9, "w": 12, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-u_2": { - "frame": { "x": 273, "y": 208, "w": 18, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 12, "w": 18, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-u_3": { - "frame": { "x": 134, "y": 214, "w": 18, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 12, "w": 18, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-v_2": { - "frame": { "x": 100, "y": 223, "w": 14, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 10, "w": 14, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-v_3": { - "frame": { "x": 185, "y": 224, "w": 14, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 10, "w": 14, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-w_2": { - "frame": { "x": 100, "y": 206, "w": 17, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 11, "w": 17, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-w_3": { - "frame": { "x": 117, "y": 206, "w": 17, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 11, "w": 17, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-x_2": { - "frame": { "x": 242, "y": 241, "w": 13, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 14, "y": 14, "w": 13, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-x_3": { - "frame": { "x": 209, "y": 241, "w": 13, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 14, "y": 14, "w": 13, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-y_2": { - "frame": { "x": 25, "y": 225, "w": 13, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 14, "y": 9, "w": 13, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-y_3": { - "frame": { "x": 38, "y": 225, "w": 13, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 14, "y": 9, "w": 13, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-z_2": { - "frame": { "x": 310, "y": 166, "w": 10, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 15, "y": 9, "w": 10, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "201-z_3": { - "frame": { "x": 185, "y": 187, "w": 10, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 15, "y": 9, "w": 10, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "203_2": { - "frame": { "x": 102, "y": 80, "w": 22, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 22, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "203_3": { - "frame": { "x": 51, "y": 80, "w": 22, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 22, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "206_2": { - "frame": { "x": 204, "y": 146, "w": 21, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 9, "w": 21, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "206_3": { - "frame": { "x": 42, "y": 147, "w": 21, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 9, "w": 21, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "207_2": { - "frame": { "x": 227, "y": 73, "w": 24, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 24, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "207_3": { - "frame": { "x": 103, "y": 56, "w": 24, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 24, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "212-mega_1": { - "frame": { "x": 234, "y": 0, "w": 28, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 1, "w": 28, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "212-mega_2": { - "frame": { "x": 206, "y": 0, "w": 28, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 1, "w": 28, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "212-mega_3": { - "frame": { "x": 178, "y": 0, "w": 28, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 1, "w": 28, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "212_1": { - "frame": { "x": 122, "y": 29, "w": 26, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 1, "w": 26, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "212_2": { - "frame": { "x": 292, "y": 26, "w": 26, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 1, "w": 26, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "212_3": { - "frame": { "x": 29, "y": 29, "w": 26, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 1, "w": 26, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "213_2": { - "frame": { "x": 27, "y": 80, "w": 24, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 7, "w": 24, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "213_3": { - "frame": { "x": 78, "y": 77, "w": 24, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 7, "w": 24, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "215_2": { - "frame": { "x": 259, "y": 164, "w": 17, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 7, "w": 17, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "215_3": { - "frame": { "x": 204, "y": 165, "w": 17, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 7, "w": 17, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "216_2": { - "frame": { "x": 304, "y": 185, "w": 16, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 8, "w": 16, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "216_3": { - "frame": { "x": 169, "y": 187, "w": 16, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 8, "w": 16, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "217_1": { - "frame": { "x": 95, "y": 103, "w": 21, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 21, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "217_2": { - "frame": { "x": 144, "y": 117, "w": 21, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 21, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "217_3": { - "frame": { "x": 165, "y": 117, "w": 21, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 21, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "222_2": { - "frame": { "x": 248, "y": 143, "w": 21, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 8, "w": 21, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "222_3": { - "frame": { "x": 110, "y": 144, "w": 21, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 8, "w": 21, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "226_2": { - "frame": { "x": 182, "y": 77, "w": 30, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 9, "w": 30, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "226_3": { - "frame": { "x": 152, "y": 77, "w": 30, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 9, "w": 30, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "227_2": { - "frame": { "x": 127, "y": 74, "w": 25, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 25, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "227_3": { - "frame": { "x": 237, "y": 28, "w": 25, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 25, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "228_2": { - "frame": { "x": 0, "y": 164, "w": 19, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 8, "w": 19, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "228_3": { - "frame": { "x": 240, "y": 163, "w": 19, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 8, "w": 19, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "229-mega_2": { - "frame": { "x": 266, "y": 51, "w": 23, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 2, "w": 23, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "229-mega_3": { - "frame": { "x": 55, "y": 53, "w": 23, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 2, "w": 23, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "229_2": { - "frame": { "x": 44, "y": 124, "w": 20, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 5, "w": 20, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "229_3": { - "frame": { "x": 206, "y": 123, "w": 20, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 5, "w": 20, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "230_2": { - "frame": { "x": 68, "y": 121, "w": 20, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 4, "w": 20, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "230_3": { - "frame": { "x": 186, "y": 121, "w": 20, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 4, "w": 20, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "231_2": { - "frame": { "x": 49, "y": 189, "w": 20, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 12, "w": 20, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "231_3": { - "frame": { "x": 71, "y": 188, "w": 20, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 12, "w": 20, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "232_2": { - "frame": { "x": 237, "y": 51, "w": 29, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 6, "w": 29, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "232_3": { - "frame": { "x": 148, "y": 52, "w": 29, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 6, "w": 29, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "233_2": { - "frame": { "x": 257, "y": 185, "w": 19, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 11, "w": 19, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "233_3": { - "frame": { "x": 127, "y": 56, "w": 19, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 11, "w": 19, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "235_2": { - "frame": { "x": 176, "y": 96, "w": 24, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 7, "w": 24, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "235_3": { - "frame": { "x": 152, "y": 96, "w": 24, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 7, "w": 24, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "239_1": { - "frame": { "x": 0, "y": 144, "w": 21, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 8, "w": 21, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "239_2": { - "frame": { "x": 21, "y": 144, "w": 21, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 8, "w": 21, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "239_3": { - "frame": { "x": 165, "y": 140, "w": 21, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 8, "w": 21, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "240_2": { - "frame": { "x": 33, "y": 187, "w": 16, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 8, "w": 16, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "240_3": { - "frame": { "x": 195, "y": 186, "w": 16, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 8, "w": 16, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "242_1": { - "frame": { "x": 239, "y": 99, "w": 22, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 22, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "242_2": { - "frame": { "x": 0, "y": 101, "w": 22, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 22, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "242_3": { - "frame": { "x": 73, "y": 99, "w": 22, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 22, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "243_2": { - "frame": { "x": 262, "y": 26, "w": 30, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 3, "w": 30, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "243_3": { - "frame": { "x": 178, "y": 28, "w": 30, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 3, "w": 30, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "244_2": { - "frame": { "x": 289, "y": 53, "w": 25, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 4, "w": 25, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "244_3": { - "frame": { "x": 0, "y": 54, "w": 25, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 4, "w": 25, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "245_2": { - "frame": { "x": 208, "y": 28, "w": 29, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 3, "w": 29, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "245_3": { - "frame": { "x": 0, "y": 29, "w": 29, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 3, "w": 29, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "246_2": { - "frame": { "x": 49, "y": 205, "w": 15, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 8, "w": 15, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "246_3": { - "frame": { "x": 16, "y": 205, "w": 15, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 8, "w": 15, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "247_2": { - "frame": { "x": 0, "y": 204, "w": 16, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 9, "w": 16, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "247_3": { - "frame": { "x": 227, "y": 203, "w": 16, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 9, "w": 16, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "248-mega_2": { - "frame": { "x": 122, "y": 0, "w": 28, "h": 29 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 1, "w": 28, "h": 29 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "248-mega_3": { - "frame": { "x": 150, "y": 0, "w": 28, "h": 29 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 1, "w": 28, "h": 29 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "248_2": { - "frame": { "x": 177, "y": 53, "w": 25, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 4, "w": 25, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "248_3": { - "frame": { "x": 78, "y": 53, "w": 25, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 4, "w": 25, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "249_2": { - "frame": { "x": 0, "y": 0, "w": 32, "h": 29 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 0, "w": 32, "h": 29 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "249_3": { - "frame": { "x": 32, "y": 0, "w": 32, "h": 29 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 0, "w": 32, "h": 29 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "250_2": { - "frame": { "x": 93, "y": 0, "w": 29, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 0, "w": 29, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "250_3": { - "frame": { "x": 64, "y": 0, "w": 29, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 0, "w": 29, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "251_2": { - "frame": { "x": 114, "y": 223, "w": 14, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 9, "w": 14, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "251_3": { - "frame": { "x": 242, "y": 223, "w": 14, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 9, "w": 14, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - } - }, - "meta": { - "app": "https://www.aseprite.org/", - "version": "1.3.7-dev", - "image": "pokemon_icons_2v.png", - "format": "RGBA8888", - "size": { "w": 320, "h": 261 }, - "scale": "1" - } +{ + "textures": [ + { + "image": "pokemon_icons_2v.png", + "format": "RGBA8888", + "size": { + "w": 520, + "h": 520 + }, + "scale": 1, + "frames": [ + { + "filename": "152_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "152_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "153_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "153_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "154-f_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "154-f_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "154_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "154_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "158_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "158_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "159_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "159_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "160_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "160_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "161_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "161_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "162_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "162_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "163_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "163_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "164_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "164_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "167_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "167_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "168_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "168_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "169_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "169_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "169_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "170_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "170_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "171_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "171_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "172-spiky_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "172-spiky_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "172_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "172_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "173_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "173_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "174_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "174_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "175_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "175_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "175_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "176_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "176_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "176_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "177_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "177_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "178_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "178_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "179_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "179_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "180_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "180_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "181-mega_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "181-mega_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "181_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "181_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "182_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "182_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "183_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "183_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "184_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "184_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "185_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "185_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "190_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "190_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "193_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "193_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "194_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "194_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "195_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "195_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "196_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "196_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "196_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "197_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "197_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "198-f_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "198_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "198-f_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "198_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "199_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "199_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "199_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "200_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "200_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "200_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-a_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-a_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-b_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-b_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-c_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-c_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-d_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-d_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-e_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-e_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-exclamation_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-exclamation_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-f_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-f_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-g_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-g_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-h_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-h_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-i_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-i_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-j_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-j_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-k_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-k_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-l_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-l_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-m_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-m_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-n_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-n_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-o_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-o_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-p_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-p_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-q_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-q_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-question_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-question_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-r_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-r_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-s_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-s_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-t_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-t_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-u_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-u_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-v_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-v_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-w_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-w_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-x_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-x_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-y_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-y_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-z_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "201-z_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "203_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "203_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "206_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "206_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "207_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "207_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "211_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "211_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "212-mega_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "212-mega_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "212-mega_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "212_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "212_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "212_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "213_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "213_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "215_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "215_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "216_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "216_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "216_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "217_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "217_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "217_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "222_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "222_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "226_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "226_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "227_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "227_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "228_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "228_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "229-mega_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "229-mega_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "229_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "229_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "230_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "230_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "231_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "231_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "232_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "232_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "233_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "233_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "235_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "235_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "239_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "239_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "239_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "240_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "240_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "242_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "242_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "242_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "243_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "243_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "244_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "244_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "245_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "245_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "246_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "246_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "247_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "247_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "248-mega_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "248-mega_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "248_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "248_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "249_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "249_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "250_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "250_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "251_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "251_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 480, + "w": 40, + "h": 30 + } + } + ] + } + ], + "meta": { + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0", + "smartupdate": "$TexturePacker:SmartUpdate:cb87bf48266ab3d893dbbd24a52f875f:d37e73561b49b4fe831e3fcaee67b851:63b368599cdc6e139499267117e91cd5$" + } } diff --git a/public/images/pokemon_icons_2v.png b/public/images/pokemon_icons_2v.png index 443d14b176d..e74840b647b 100644 Binary files a/public/images/pokemon_icons_2v.png and b/public/images/pokemon_icons_2v.png differ diff --git a/public/images/pokemon_icons_3.json b/public/images/pokemon_icons_3.json index 220d91f5222..a1aefa0ff0b 100644 --- a/public/images/pokemon_icons_3.json +++ b/public/images/pokemon_icons_3.json @@ -198,6 +198,27 @@ "h": 27 } }, + { + "filename": "257-f-mega", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 4, + "y": 2, + "w": 32, + "h": 27 + }, + "frame": { + "x": 0, + "y": 79, + "w": 32, + "h": 27 + } + }, { "filename": "257s-mega", "rotated": false, @@ -219,6 +240,27 @@ "h": 27 } }, + { + "filename": "257s-f-mega", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 4, + "y": 2, + "w": 32, + "h": 27 + }, + "frame": { + "x": 0, + "y": 106, + "w": 32, + "h": 27 + } + }, { "filename": "323-mega", "rotated": false, @@ -1248,6 +1290,27 @@ "h": 26 } }, + { + "filename": "257-f", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 7, + "y": 2, + "w": 25, + "h": 26 + }, + "frame": { + "x": 28, + "y": 556, + "w": 25, + "h": 26 + } + }, { "filename": "257s", "rotated": false, @@ -1269,6 +1332,27 @@ "h": 26 } }, + { + "filename": "257s-f", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 7, + "y": 2, + "w": 25, + "h": 26 + }, + "frame": { + "x": 28, + "y": 582, + "w": 25, + "h": 26 + } + }, { "filename": "359-mega", "rotated": false, @@ -1605,6 +1689,27 @@ "h": 25 } }, + { + "filename": "256-f", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 8, + "y": 3, + "w": 23, + "h": 25 + }, + "frame": { + "x": 98, + "y": 72, + "w": 23, + "h": 25 + } + }, { "filename": "282s-mega", "rotated": false, @@ -5553,6 +5658,27 @@ "h": 19 } }, + { + "filename": "255-f", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 13, + "y": 9, + "w": 13, + "h": 19 + }, + "frame": { + "x": 204, + "y": 342, + "w": 13, + "h": 19 + } + }, { "filename": "307s", "rotated": false, diff --git a/public/images/pokemon_icons_3v.json b/public/images/pokemon_icons_3v.json index 2cd15286a81..2500eebbff8 100644 --- a/public/images/pokemon_icons_3v.json +++ b/public/images/pokemon_icons_3v.json @@ -1,1411 +1,4661 @@ -{ "frames": { - "255_2": { - "frame": { "x": 167, "y": 275, "w": 13, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 9, "w": 13, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "255_3": { - "frame": { "x": 367, "y": 186, "w": 13, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 9, "w": 13, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "256_2": { - "frame": { "x": 106, "y": 124, "w": 23, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 3, "w": 23, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "256_3": { - "frame": { "x": 51, "y": 124, "w": 23, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 3, "w": 23, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "257-mega_2": { - "frame": { "x": 146, "y": 0, "w": 32, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 2, "w": 32, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "257-mega_3": { - "frame": { "x": 178, "y": 0, "w": 32, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 2, "w": 32, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "257_2": { - "frame": { "x": 0, "y": 81, "w": 25, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 2, "w": 25, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "257_3": { - "frame": { "x": 150, "y": 78, "w": 25, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 2, "w": 25, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "261_2": { - "frame": { "x": 17, "y": 232, "w": 21, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 10, "w": 21, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "261_3": { - "frame": { "x": 38, "y": 232, "w": 21, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 10, "w": 21, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "262_2": { - "frame": { "x": 48, "y": 149, "w": 25, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 7, "w": 25, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "262_3": { - "frame": { "x": 96, "y": 149, "w": 25, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 7, "w": 25, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "263_2": { - "frame": { "x": 123, "y": 243, "w": 22, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 12, "w": 22, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "263_3": { - "frame": { "x": 252, "y": 243, "w": 22, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 12, "w": 22, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "264_2": { - "frame": { "x": 115, "y": 193, "w": 22, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 8, "w": 22, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "264_3": { - "frame": { "x": 66, "y": 192, "w": 22, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 8, "w": 22, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "278_1": { - "frame": { "x": 275, "y": 78, "w": 26, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 14, "w": 26, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "278_2": { - "frame": { "x": 151, "y": 232, "w": 26, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 14, "w": 26, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "278_3": { - "frame": { "x": 97, "y": 233, "w": 26, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 14, "w": 26, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "279_1": { - "frame": { "x": 178, "y": 165, "w": 23, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 7, "w": 23, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "279_2": { - "frame": { "x": 144, "y": 166, "w": 23, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 7, "w": 23, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "279_3": { - "frame": { "x": 254, "y": 161, "w": 23, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 7, "w": 23, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "280_2": { - "frame": { "x": 122, "y": 275, "w": 14, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 10, "w": 14, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "280_3": { - "frame": { "x": 108, "y": 275, "w": 14, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 10, "w": 14, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "281_2": { - "frame": { "x": 159, "y": 209, "w": 18, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 5, "w": 18, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "281_3": { - "frame": { "x": 177, "y": 210, "w": 18, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 5, "w": 18, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "282-mega_2": { - "frame": { "x": 227, "y": 99, "w": 26, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 4, "w": 26, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "282-mega_3": { - "frame": { "x": 352, "y": 0, "w": 26, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 4, "w": 26, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "282_2": { - "frame": { "x": 201, "y": 98, "w": 26, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 4, "w": 26, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "282_3": { - "frame": { "x": 175, "y": 98, "w": 26, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 4, "w": 26, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "285_2": { - "frame": { "x": 15, "y": 271, "w": 18, "h": 15 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 13, "w": 18, "h": 15 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "285_3": { - "frame": { "x": 307, "y": 269, "w": 18, "h": 15 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 13, "w": 18, "h": 15 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "286_2": { - "frame": { "x": 220, "y": 123, "w": 23, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 3, "w": 23, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "286_3": { - "frame": { "x": 0, "y": 107, "w": 23, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 3, "w": 23, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "290_1": { - "frame": { "x": 291, "y": 249, "w": 23, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 14, "w": 23, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "290_2": { - "frame": { "x": 353, "y": 248, "w": 23, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 14, "w": 23, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "290_3": { - "frame": { "x": 97, "y": 247, "w": 23, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 14, "w": 23, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "291_1": { - "frame": { "x": 277, "y": 180, "w": 23, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 8, "w": 23, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "291_2": { - "frame": { "x": 245, "y": 182, "w": 23, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 8, "w": 23, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "291_3": { - "frame": { "x": 222, "y": 180, "w": 23, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 8, "w": 23, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "292_1": { - "frame": { "x": 357, "y": 229, "w": 20, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 9, "w": 20, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "292_2": { - "frame": { "x": 77, "y": 231, "w": 20, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 9, "w": 20, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "292_3": { - "frame": { "x": 296, "y": 230, "w": 20, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 9, "w": 20, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "298_2": { - "frame": { "x": 139, "y": 263, "w": 15, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 9, "w": 15, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "298_3": { - "frame": { "x": 277, "y": 263, "w": 15, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 9, "w": 15, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "300_1": { - "frame": { "x": 108, "y": 213, "w": 20, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 8, "w": 20, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "300_2": { - "frame": { "x": 17, "y": 212, "w": 20, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 8, "w": 20, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "300_3": { - "frame": { "x": 88, "y": 211, "w": 20, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 8, "w": 20, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "301_1": { - "frame": { "x": 115, "y": 172, "w": 22, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 7, "w": 22, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "301_2": { - "frame": { "x": 0, "y": 178, "w": 22, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 7, "w": 22, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "301_3": { - "frame": { "x": 93, "y": 170, "w": 22, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 7, "w": 22, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "302-mega_2": { - "frame": { "x": 274, "y": 51, "w": 28, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 1, "w": 28, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "302-mega_3": { - "frame": { "x": 150, "y": 51, "w": 28, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 1, "w": 28, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "302_2": { - "frame": { "x": 338, "y": 166, "w": 23, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 7, "w": 23, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "302_3": { - "frame": { "x": 315, "y": 166, "w": 23, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 7, "w": 23, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "303-mega_1": { - "frame": { "x": 26, "y": 51, "w": 30, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 3, "w": 30, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "303-mega_2": { - "frame": { "x": 56, "y": 51, "w": 30, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 3, "w": 30, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "303-mega_3": { - "frame": { "x": 342, "y": 50, "w": 30, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 3, "w": 30, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "303_1": { - "frame": { "x": 315, "y": 145, "w": 26, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 7, "w": 26, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "303_2": { - "frame": { "x": 341, "y": 145, "w": 26, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 7, "w": 26, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "303_3": { - "frame": { "x": 178, "y": 144, "w": 26, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 7, "w": 26, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "304_1": { - "frame": { "x": 196, "y": 275, "w": 16, "h": 12 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 16, "w": 16, "h": 12 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "304_2": { - "frame": { "x": 180, "y": 275, "w": 16, "h": 12 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 16, "w": 16, "h": 12 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "304_3": { - "frame": { "x": 252, "y": 202, "w": 16, "h": 12 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 16, "w": 16, "h": 12 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "305_1": { - "frame": { "x": 334, "y": 227, "w": 23, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 11, "w": 23, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "305_2": { - "frame": { "x": 128, "y": 226, "w": 23, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 11, "w": 23, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "305_3": { - "frame": { "x": 273, "y": 226, "w": 23, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 11, "w": 23, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "306-mega_1": { - "frame": { "x": 62, "y": 25, "w": 31, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 3, "w": 31, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "306-mega_2": { - "frame": { "x": 93, "y": 25, "w": 31, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 3, "w": 31, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "306-mega_3": { - "frame": { "x": 342, "y": 24, "w": 31, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 3, "w": 31, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "306_1": { - "frame": { "x": 55, "y": 77, "w": 29, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 4, "w": 29, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "306_2": { - "frame": { "x": 338, "y": 76, "w": 29, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 4, "w": 29, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "306_3": { - "frame": { "x": 26, "y": 77, "w": 29, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 4, "w": 29, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "307_2": { - "frame": { "x": 215, "y": 241, "w": 17, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 8, "w": 17, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "307_3": { - "frame": { "x": 274, "y": 243, "w": 17, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 8, "w": 17, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "308-mega_2": { - "frame": { "x": 190, "y": 48, "w": 29, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 2, "w": 29, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "308-mega_3": { - "frame": { "x": 219, "y": 48, "w": 29, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 2, "w": 29, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "308_2": { - "frame": { "x": 0, "y": 199, "w": 17, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 3, "w": 17, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "308_3": { - "frame": { "x": 235, "y": 202, "w": 17, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 3, "w": 17, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "309_2": { - "frame": { "x": 45, "y": 268, "w": 19, "h": 15 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 13, "w": 19, "h": 15 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "309_3": { - "frame": { "x": 253, "y": 99, "w": 19, "h": 15 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 13, "w": 19, "h": 15 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "310-mega_2": { - "frame": { "x": 25, "y": 101, "w": 26, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 5, "w": 26, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "310-mega_3": { - "frame": { "x": 338, "y": 100, "w": 26, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 5, "w": 26, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "310_2": { - "frame": { "x": 323, "y": 187, "w": 20, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 5, "w": 20, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "310_3": { - "frame": { "x": 167, "y": 186, "w": 20, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 5, "w": 20, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "311_1": { - "frame": { "x": 164, "y": 256, "w": 16, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 9, "w": 16, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "311_2": { - "frame": { "x": 77, "y": 250, "w": 16, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 9, "w": 16, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "311_3": { - "frame": { "x": 314, "y": 250, "w": 16, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 9, "w": 16, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "312_2": { - "frame": { "x": 196, "y": 256, "w": 16, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 9, "w": 16, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "312_3": { - "frame": { "x": 180, "y": 256, "w": 16, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 9, "w": 16, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "315_2": { - "frame": { "x": 153, "y": 144, "w": 25, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 25, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "315_3": { - "frame": { "x": 290, "y": 138, "w": 25, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 25, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "320_2": { - "frame": { "x": 211, "y": 200, "w": 24, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 10, "w": 24, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "320_3": { - "frame": { "x": 268, "y": 200, "w": 24, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 10, "w": 24, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "321_2": { - "frame": { "x": 84, "y": 98, "w": 30, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 5, "w": 30, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "321_3": { - "frame": { "x": 308, "y": 93, "w": 30, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 5, "w": 30, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "327_2": { - "frame": { "x": 364, "y": 100, "w": 15, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 7, "w": 15, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "327_3": { - "frame": { "x": 0, "y": 247, "w": 15, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 7, "w": 15, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "328_2": { - "frame": { "x": 177, "y": 237, "w": 19, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 9, "w": 19, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "328_3": { - "frame": { "x": 196, "y": 237, "w": 19, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 9, "w": 19, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "329_2": { - "frame": { "x": 229, "y": 160, "w": 25, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 8, "w": 25, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "329_3": { - "frame": { "x": 290, "y": 160, "w": 25, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 8, "w": 25, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "330_2": { - "frame": { "x": 51, "y": 101, "w": 27, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 27, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "330_3": { - "frame": { "x": 139, "y": 104, "w": 27, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 27, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "333_2": { - "frame": { "x": 45, "y": 252, "w": 19, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 11, "w": 19, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "333_3": { - "frame": { "x": 120, "y": 259, "w": 19, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 11, "w": 19, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "334-mega_2": { - "frame": { "x": 280, "y": 114, "w": 27, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 5, "w": 27, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "334-mega_3": { - "frame": { "x": 253, "y": 114, "w": 27, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 5, "w": 27, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "334_2": { - "frame": { "x": 73, "y": 168, "w": 20, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 4, "w": 20, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "334_3": { - "frame": { "x": 23, "y": 167, "w": 20, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 4, "w": 20, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "335_2": { - "frame": { "x": 0, "y": 156, "w": 23, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 6, "w": 23, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "335_3": { - "frame": { "x": 121, "y": 150, "w": 23, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 6, "w": 23, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "336_2": { - "frame": { "x": 137, "y": 187, "w": 23, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 8, "w": 23, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "336_3": { - "frame": { "x": 300, "y": 187, "w": 23, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 8, "w": 23, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "337_2": { - "frame": { "x": 277, "y": 161, "w": 13, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 14, "y": 9, "w": 13, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "337_3": { - "frame": { "x": 154, "y": 275, "w": 13, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 14, "y": 9, "w": 13, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "338_2": { - "frame": { "x": 43, "y": 170, "w": 21, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 21, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "338_3": { - "frame": { "x": 201, "y": 169, "w": 21, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 21, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "339_2": { - "frame": { "x": 226, "y": 268, "w": 21, "h": 13 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 14, "w": 21, "h": 13 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "339_3": { - "frame": { "x": 64, "y": 269, "w": 21, "h": 13 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 14, "w": 21, "h": 13 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "340_2": { - "frame": { "x": 187, "y": 191, "w": 24, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 10, "w": 24, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "340_3": { - "frame": { "x": 343, "y": 187, "w": 24, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 10, "w": 24, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "341_2": { - "frame": { "x": 252, "y": 218, "w": 21, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 9, "w": 21, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "341_3": { - "frame": { "x": 195, "y": 218, "w": 21, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 9, "w": 21, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "342_2": { - "frame": { "x": 129, "y": 127, "w": 24, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 24, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "342_3": { - "frame": { "x": 243, "y": 137, "w": 24, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 24, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "351-rainy_1": { - "frame": { "x": 330, "y": 261, "w": 14, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 7, "w": 14, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "351-rainy_2": { - "frame": { "x": 344, "y": 262, "w": 14, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 7, "w": 14, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "351-rainy_3": { - "frame": { "x": 212, "y": 261, "w": 14, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 7, "w": 14, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "351-snowy_1": { - "frame": { "x": 216, "y": 218, "w": 17, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 5, "w": 17, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "351-snowy_2": { - "frame": { "x": 363, "y": 206, "w": 17, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 5, "w": 17, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "351-snowy_3": { - "frame": { "x": 0, "y": 224, "w": 17, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 5, "w": 17, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "351-sunny_1": { - "frame": { "x": 59, "y": 232, "w": 18, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 8, "w": 18, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "351-sunny_2": { - "frame": { "x": 316, "y": 230, "w": 18, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 8, "w": 18, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "351-sunny_3": { - "frame": { "x": 362, "y": 124, "w": 18, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 8, "w": 18, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "351_2": { - "frame": { "x": 367, "y": 76, "w": 13, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 8, "w": 13, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "351_3": { - "frame": { "x": 367, "y": 144, "w": 13, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 8, "w": 13, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "352_1": { - "frame": { "x": 37, "y": 212, "w": 20, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 8, "w": 20, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "352_2": { - "frame": { "x": 57, "y": 212, "w": 20, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 8, "w": 20, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "352_3": { - "frame": { "x": 314, "y": 210, "w": 20, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 8, "w": 20, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "353_2": { - "frame": { "x": 262, "y": 263, "w": 15, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 8, "w": 15, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "353_3": { - "frame": { "x": 292, "y": 263, "w": 15, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 8, "w": 15, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "354-mega_2": { - "frame": { "x": 0, "y": 51, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "354-mega_3": { - "frame": { "x": 248, "y": 48, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "354_2": { - "frame": { "x": 137, "y": 207, "w": 22, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 9, "w": 22, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "354_3": { - "frame": { "x": 292, "y": 207, "w": 22, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 9, "w": 22, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "357_2": { - "frame": { "x": 31, "y": 25, "w": 31, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 2, "w": 31, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "357_3": { - "frame": { "x": 0, "y": 25, "w": 31, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 2, "w": 31, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "358_1": { - "frame": { "x": 232, "y": 247, "w": 15, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 8, "w": 15, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "358_2": { - "frame": { "x": 15, "y": 250, "w": 15, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 8, "w": 15, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "358_3": { - "frame": { "x": 30, "y": 250, "w": 15, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 8, "w": 15, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "361_2": { - "frame": { "x": 0, "y": 268, "w": 15, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 9, "w": 15, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "361_3": { - "frame": { "x": 358, "y": 262, "w": 15, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 9, "w": 15, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "362-mega_2": { - "frame": { "x": 0, "y": 132, "w": 23, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 4, "w": 23, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "362-mega_3": { - "frame": { "x": 267, "y": 137, "w": 23, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 4, "w": 23, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "362_2": { - "frame": { "x": 233, "y": 227, "w": 19, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 8, "w": 19, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "362_3": { - "frame": { "x": 361, "y": 166, "w": 19, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 8, "w": 19, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "369_2": { - "frame": { "x": 204, "y": 148, "w": 25, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 7, "w": 25, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "369_3": { - "frame": { "x": 23, "y": 146, "w": 25, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 7, "w": 25, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "371_2": { - "frame": { "x": 247, "y": 259, "w": 15, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 8, "w": 15, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "371_3": { - "frame": { "x": 93, "y": 261, "w": 15, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 8, "w": 15, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "372_2": { - "frame": { "x": 343, "y": 206, "w": 20, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 7, "w": 20, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "372_3": { - "frame": { "x": 190, "y": 27, "w": 20, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 7, "w": 20, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "373-mega_2": { - "frame": { "x": 111, "y": 0, "w": 35, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 2, "y": 3, "w": 35, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "373-mega_3": { - "frame": { "x": 76, "y": 0, "w": 35, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 2, "y": 3, "w": 35, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "373_2": { - "frame": { "x": 86, "y": 75, "w": 32, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 5, "w": 32, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "373_3": { - "frame": { "x": 118, "y": 75, "w": 32, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 5, "w": 32, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "374_2": { - "frame": { "x": 145, "y": 246, "w": 19, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 10, "w": 19, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "374_3": { - "frame": { "x": 334, "y": 244, "w": 19, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 10, "w": 19, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "375_2": { - "frame": { "x": 166, "y": 122, "w": 27, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 8, "w": 27, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "375_3": { - "frame": { "x": 193, "y": 122, "w": 27, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 8, "w": 27, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "376-mega_2": { - "frame": { "x": 118, "y": 51, "w": 32, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 3, "y": 5, "w": 32, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "376-mega_3": { - "frame": { "x": 86, "y": 51, "w": 32, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 3, "y": 5, "w": 32, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "376_2": { - "frame": { "x": 178, "y": 75, "w": 32, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 7, "w": 32, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "376_3": { - "frame": { "x": 210, "y": 75, "w": 32, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 7, "w": 32, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "380-mega_2": { - "frame": { "x": 282, "y": 0, "w": 35, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 4, "w": 35, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "380-mega_3": { - "frame": { "x": 317, "y": 0, "w": 35, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 4, "w": 35, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "380_2": { - "frame": { "x": 23, "y": 125, "w": 27, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 6, "w": 27, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "380_3": { - "frame": { "x": 335, "y": 124, "w": 27, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 6, "w": 27, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "381-mega_2": { - "frame": { "x": 210, "y": 24, "w": 35, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 4, "w": 35, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "381-mega_3": { - "frame": { "x": 245, "y": 24, "w": 35, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 4, "w": 35, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "381_2": { - "frame": { "x": 78, "y": 121, "w": 28, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 5, "w": 28, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "381_3": { - "frame": { "x": 307, "y": 116, "w": 28, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 5, "w": 28, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "382-primal_2": { - "frame": { "x": 302, "y": 72, "w": 36, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 3, "y": 8, "w": 36, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "382-primal_3": { - "frame": { "x": 302, "y": 51, "w": 36, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 3, "y": 8, "w": 36, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "382_2": { - "frame": { "x": 275, "y": 93, "w": 33, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 8, "w": 33, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "382_3": { - "frame": { "x": 242, "y": 78, "w": 33, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 8, "w": 33, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "383-primal_2": { - "frame": { "x": 246, "y": 0, "w": 36, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 3, "y": 4, "w": 36, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "383-primal_3": { - "frame": { "x": 210, "y": 0, "w": 36, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 3, "y": 4, "w": 36, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "383_2": { - "frame": { "x": 157, "y": 27, "w": 33, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 4, "w": 33, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "383_3": { - "frame": { "x": 124, "y": 27, "w": 33, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 4, "w": 33, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "384-mega_2": { - "frame": { "x": 38, "y": 0, "w": 38, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 1, "y": 3, "w": 38, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "384-mega_3": { - "frame": { "x": 0, "y": 0, "w": 38, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 1, "y": 3, "w": 38, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "384_2": { - "frame": { "x": 311, "y": 24, "w": 31, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 2, "w": 31, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "384_3": { - "frame": { "x": 280, "y": 24, "w": 31, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 2, "w": 31, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "385_1": { - "frame": { "x": 22, "y": 192, "w": 22, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 8, "w": 22, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "385_2": { - "frame": { "x": 93, "y": 191, "w": 22, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 8, "w": 22, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "385_3": { - "frame": { "x": 44, "y": 192, "w": 22, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 8, "w": 22, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "475-mega_3": { - "frame": { "x": 114, "y": 98, "w": 25, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 2, "w": 25, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "475_3": { - "frame": { "x": 74, "y": 143, "w": 22, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 3, "w": 22, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - } - }, - "meta": { - "app": "https://www.aseprite.org/", - "version": "1.3.7-dev", - "image": "pokemon_icons_3v.png", - "format": "RGBA8888", - "size": { "w": 380, "h": 294 }, - "scale": "1" - } +{ + "textures": [ + { + "image": "pokemon_icons_3v.png", + "format": "RGBA8888", + "size": { + "w": 520, + "h": 520 + }, + "scale": 1, + "frames": [ + { + "filename": "255-f_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "255-f_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "255_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "255_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "256-f_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "256-f_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "256_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "256_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "257-f_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "257-f_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "257-mega_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "257-mega_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "257_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "257_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "261_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "261_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "262_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "262_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "263_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "263_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "264_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "264_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "276_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "276_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "277_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "277_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "278_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "278_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "278_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "279_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "279_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "279_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "280_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "280_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "281_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "281_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "282-mega_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "282-mega_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "282_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "282_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "285_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "285_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "286_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "286_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "290_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "290_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "290_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "291_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "291_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "291_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "292_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "292_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "292_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "298_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "298_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "300_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "300_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "300_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "301_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "301_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "301_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "302-mega_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "302-mega_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "302_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "302_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "303-mega_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "303-mega_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "303-mega_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "303_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "303_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "303_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "304_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "304_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "304_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "305_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "305_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "305_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "306-mega_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "306-mega_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "306-mega_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "306_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "306_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "306_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "307_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "307_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "308-mega_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "308-mega_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "308_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "308_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "309_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "309_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "310-mega_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "310-mega_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "310_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "310_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "311_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "311_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "311_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "312_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "312_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "315_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "315_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "320_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "320_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "321_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "321_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "327_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "327_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "328_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "328_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "329_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "329_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "330_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "330_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "333_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "333_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "334-mega_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "334-mega_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "334_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "334_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "335_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "335_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "336_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "336_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "337_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "337_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "338_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "338_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "339_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "339_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "340_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "340_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "341_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "341_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "342_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "342_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "351-rainy_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "351-rainy_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "351-rainy_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "351-snowy_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "351-snowy_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "351-snowy_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "351-sunny_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "351-sunny_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "351-sunny_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "351_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "351_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "352_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "352_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "352_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "353_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "353_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "354-mega_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "354-mega_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "354_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "354_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "357_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "357_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "358_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "358_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "358_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "359-mega_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "359-mega_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "359_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "359_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "361_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "361_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "362-mega_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "362-mega_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "362_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "362_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "369_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "369_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "370_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "370_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "371_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "371_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "372_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "372_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "373-mega_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "373-mega_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "373_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "373_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "374_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "374_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "375_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "375_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "376-mega_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "376-mega_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "376_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "376_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "377_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "377_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "378_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "378_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "378_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "379_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "379_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "380-mega_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "380-mega_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "380_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "380_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "381-mega_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "381-mega_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "381_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "381_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "382-primal_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "382-primal_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "382_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "382_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "383-primal_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "383-primal_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "383_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "383_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "384-mega_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "384-mega_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "384_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "384_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "385_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "385_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "385_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 480, + "w": 40, + "h": 30 + } + } + ] + } + ], + "meta": { + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0", + "smartupdate": "$TexturePacker:SmartUpdate:673055e796ec5f9913fd1dd04284765c:1804ddee68059c3372bf99289c91dd89:039b026190bf1878996b3e03190bcdf3$" + } } diff --git a/public/images/pokemon_icons_3v.png b/public/images/pokemon_icons_3v.png index 51a1707ea35..6b699b3bfa9 100644 Binary files a/public/images/pokemon_icons_3v.png and b/public/images/pokemon_icons_3v.png differ diff --git a/public/images/pokemon_icons_4v.json b/public/images/pokemon_icons_4v.json index 9113fe89dc8..2f171915e01 100644 --- a/public/images/pokemon_icons_4v.json +++ b/public/images/pokemon_icons_4v.json @@ -1,1390 +1,4409 @@ -{ "frames": { - "387_2": { - "frame": { "x": 39, "y": 225, "w": 18, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 6, "w": 18, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "387_3": { - "frame": { "x": 148, "y": 225, "w": 18, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 6, "w": 18, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "388_2": { - "frame": { "x": 261, "y": 187, "w": 22, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 7, "w": 22, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "388_3": { - "frame": { "x": 64, "y": 190, "w": 22, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 7, "w": 22, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "389_2": { - "frame": { "x": 272, "y": 47, "w": 28, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 5, "w": 28, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "389_3": { - "frame": { "x": 244, "y": 47, "w": 28, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 5, "w": 28, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "393_2": { - "frame": { "x": 69, "y": 275, "w": 13, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 14, "y": 9, "w": 13, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "393_3": { - "frame": { "x": 285, "y": 275, "w": 13, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 14, "y": 9, "w": 13, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "394_2": { - "frame": { "x": 321, "y": 232, "w": 17, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 6, "w": 17, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "394_3": { - "frame": { "x": 0, "y": 244, "w": 17, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 6, "w": 17, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "395_2": { - "frame": { "x": 340, "y": 95, "w": 23, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 3, "w": 23, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "395_3": { - "frame": { "x": 24, "y": 98, "w": 23, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 3, "w": 23, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "399_2": { - "frame": { "x": 24, "y": 123, "w": 20, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 12, "w": 20, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "399_3": { - "frame": { "x": 108, "y": 267, "w": 20, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 12, "w": 20, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "400_2": { - "frame": { "x": 217, "y": 180, "w": 22, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 6, "w": 22, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "400_3": { - "frame": { "x": 239, "y": 180, "w": 22, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 6, "w": 22, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "401_2": { - "frame": { "x": 279, "y": 243, "w": 17, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 5, "w": 17, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "401_3": { - "frame": { "x": 201, "y": 243, "w": 17, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 5, "w": 17, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "402_2": { - "frame": { "x": 97, "y": 186, "w": 20, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 4, "w": 20, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "402_3": { - "frame": { "x": 289, "y": 182, "w": 20, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 4, "w": 20, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "406_2": { - "frame": { "x": 298, "y": 275, "w": 12, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 14, "y": 10, "w": 12, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "406_3": { - "frame": { "x": 184, "y": 225, "w": 12, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 14, "y": 10, "w": 12, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "407_2": { - "frame": { "x": 177, "y": 203, "w": 20, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 20, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "407_3": { - "frame": { "x": 86, "y": 210, "w": 20, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 20, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "412-plant_1": { - "frame": { "x": 338, "y": 232, "w": 17, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 6, "w": 17, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "412-plant_2": { - "frame": { "x": 184, "y": 243, "w": 17, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 6, "w": 17, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "412-plant_3": { - "frame": { "x": 99, "y": 242, "w": 17, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 6, "w": 17, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "412-sandy_1": { - "frame": { "x": 164, "y": 247, "w": 15, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 5, "w": 15, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "412-sandy_2": { - "frame": { "x": 76, "y": 252, "w": 15, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 5, "w": 15, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "412-sandy_3": { - "frame": { "x": 296, "y": 252, "w": 15, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 5, "w": 15, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "412-trash_1": { - "frame": { "x": 218, "y": 245, "w": 16, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 5, "w": 16, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "412-trash_2": { - "frame": { "x": 132, "y": 244, "w": 16, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 5, "w": 16, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "412-trash_3": { - "frame": { "x": 116, "y": 244, "w": 16, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 5, "w": 16, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "413-plant_1": { - "frame": { "x": 333, "y": 168, "w": 22, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 22, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "413-plant_2": { - "frame": { "x": 311, "y": 168, "w": 22, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 22, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "413-plant_3": { - "frame": { "x": 75, "y": 167, "w": 22, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 22, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "413-sandy_1": { - "frame": { "x": 0, "y": 117, "w": 24, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 24, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "413-sandy_2": { - "frame": { "x": 292, "y": 117, "w": 24, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 24, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "413-sandy_3": { - "frame": { "x": 316, "y": 117, "w": 24, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 24, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "413-trash_1": { - "frame": { "x": 125, "y": 157, "w": 23, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 5, "w": 23, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "413-trash_2": { - "frame": { "x": 319, "y": 145, "w": 23, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 5, "w": 23, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "413-trash_3": { - "frame": { "x": 266, "y": 142, "w": 23, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 5, "w": 23, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "414_2": { - "frame": { "x": 120, "y": 180, "w": 25, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 7, "w": 25, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "414_3": { - "frame": { "x": 145, "y": 180, "w": 25, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 7, "w": 25, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "418_2": { - "frame": { "x": 127, "y": 224, "w": 21, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 8, "w": 21, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "418_3": { - "frame": { "x": 0, "y": 224, "w": 21, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 8, "w": 21, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "419_2": { - "frame": { "x": 221, "y": 159, "w": 25, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 7, "w": 25, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "419_3": { - "frame": { "x": 50, "y": 158, "w": 25, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 7, "w": 25, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "422-east_1": { - "frame": { "x": 197, "y": 203, "w": 19, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 8, "w": 19, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "422-east_2": { - "frame": { "x": 302, "y": 232, "w": 19, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 8, "w": 19, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "422-east_3": { - "frame": { "x": 80, "y": 232, "w": 19, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 8, "w": 19, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "422-west_1": { - "frame": { "x": 36, "y": 265, "w": 17, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 8, "w": 17, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "422-west_2": { - "frame": { "x": 91, "y": 264, "w": 17, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 8, "w": 17, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "422-west_3": { - "frame": { "x": 253, "y": 264, "w": 17, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 8, "w": 17, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "423-east_1": { - "frame": { "x": 148, "y": 157, "w": 23, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 23, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "423-east_2": { - "frame": { "x": 266, "y": 165, "w": 23, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 23, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "423-east_3": { - "frame": { "x": 41, "y": 179, "w": 23, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 23, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "423-west_1": { - "frame": { "x": 97, "y": 164, "w": 23, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 23, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "423-west_2": { - "frame": { "x": 194, "y": 160, "w": 23, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 23, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "423-west_3": { - "frame": { "x": 171, "y": 160, "w": 23, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 23, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "424_2": { - "frame": { "x": 303, "y": 0, "w": 29, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 3, "w": 29, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "424_3": { - "frame": { "x": 274, "y": 0, "w": 29, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 3, "w": 29, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "425_2": { - "frame": { "x": 270, "y": 265, "w": 15, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 7, "w": 15, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "425_3": { - "frame": { "x": 234, "y": 265, "w": 15, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 7, "w": 15, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "426_2": { - "frame": { "x": 110, "y": 96, "w": 24, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 4, "w": 24, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "426_3": { - "frame": { "x": 268, "y": 96, "w": 24, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 4, "w": 24, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "427_2": { - "frame": { "x": 21, "y": 225, "w": 18, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 6, "w": 18, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "427_3": { - "frame": { "x": 166, "y": 225, "w": 18, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 6, "w": 18, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "428-mega_2": { - "frame": { "x": 95, "y": 0, "w": 33, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 5, "w": 33, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "428-mega_3": { - "frame": { "x": 62, "y": 0, "w": 33, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 5, "w": 33, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "428_2": { - "frame": { "x": 47, "y": 117, "w": 26, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 26, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "428_3": { - "frame": { "x": 73, "y": 117, "w": 26, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 26, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "429_1": { - "frame": { "x": 247, "y": 138, "w": 19, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 2, "w": 19, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "429_2": { - "frame": { "x": 0, "y": 140, "w": 19, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 2, "w": 19, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "429_3": { - "frame": { "x": 78, "y": 139, "w": 19, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 2, "w": 19, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "433_1": { - "frame": { "x": 328, "y": 213, "w": 23, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 9, "w": 23, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "433_2": { - "frame": { "x": 305, "y": 213, "w": 23, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 9, "w": 23, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "433_3": { - "frame": { "x": 61, "y": 211, "w": 23, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 9, "w": 23, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "436_2": { - "frame": { "x": 0, "y": 284, "w": 13, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 12, "w": 13, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "436_3": { - "frame": { "x": 108, "y": 283, "w": 13, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 12, "w": 13, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "437_2": { - "frame": { "x": 239, "y": 117, "w": 27, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 6, "w": 27, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "437_3": { - "frame": { "x": 212, "y": 117, "w": 27, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 6, "w": 27, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "438_2": { - "frame": { "x": 351, "y": 211, "w": 12, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 14, "y": 8, "w": 12, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "438_3": { - "frame": { "x": 351, "y": 191, "w": 12, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 14, "y": 8, "w": 12, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "440_1": { - "frame": { "x": 163, "y": 270, "w": 14, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 9, "w": 14, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "440_2": { - "frame": { "x": 343, "y": 271, "w": 14, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 9, "w": 14, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "440_3": { - "frame": { "x": 329, "y": 271, "w": 14, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 9, "w": 14, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "441_2": { - "frame": { "x": 157, "y": 203, "w": 20, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 20, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "441_3": { - "frame": { "x": 237, "y": 202, "w": 20, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 20, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "442_2": { - "frame": { "x": 106, "y": 222, "w": 21, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 8, "w": 21, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "442_3": { - "frame": { "x": 197, "y": 223, "w": 21, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 8, "w": 21, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "443_1": { - "frame": { "x": 256, "y": 245, "w": 19, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 9, "w": 19, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "443_2": { - "frame": { "x": 17, "y": 247, "w": 19, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 9, "w": 19, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "443_3": { - "frame": { "x": 234, "y": 246, "w": 19, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 9, "w": 19, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "444_1": { - "frame": { "x": 170, "y": 182, "w": 23, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 7, "w": 23, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "444_2": { - "frame": { "x": 0, "y": 183, "w": 23, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 7, "w": 23, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "444_3": { - "frame": { "x": 193, "y": 182, "w": 23, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 7, "w": 23, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "445-mega_1": { - "frame": { "x": 214, "y": 0, "w": 30, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 5, "w": 30, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "445-mega_2": { - "frame": { "x": 184, "y": 0, "w": 30, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 5, "w": 30, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "445-mega_3": { - "frame": { "x": 244, "y": 0, "w": 30, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 5, "w": 30, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "445_1": { - "frame": { "x": 207, "y": 48, "w": 29, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 29, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "445_2": { - "frame": { "x": 87, "y": 49, "w": 29, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 29, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "445_3": { - "frame": { "x": 331, "y": 49, "w": 29, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 29, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "447_1": { - "frame": { "x": 23, "y": 183, "w": 18, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 10, "w": 18, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "447_2": { - "frame": { "x": 0, "y": 266, "w": 18, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 10, "w": 18, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "447_3": { - "frame": { "x": 18, "y": 266, "w": 18, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 10, "w": 18, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "448-mega_1": { - "frame": { "x": 138, "y": 200, "w": 19, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 4, "w": 19, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "448-mega_2": { - "frame": { "x": 42, "y": 201, "w": 19, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 4, "w": 19, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "448-mega_3": { - "frame": { "x": 23, "y": 201, "w": 19, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 4, "w": 19, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "448_1": { - "frame": { "x": 195, "y": 265, "w": 16, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 7, "w": 16, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "448_2": { - "frame": { "x": 179, "y": 265, "w": 16, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 7, "w": 16, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "448_3": { - "frame": { "x": 53, "y": 265, "w": 16, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 7, "w": 16, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "453_2": { - "frame": { "x": 128, "y": 267, "w": 17, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 11, "w": 17, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "453_3": { - "frame": { "x": 211, "y": 268, "w": 17, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 11, "w": 17, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "454_2": { - "frame": { "x": 330, "y": 191, "w": 21, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 6, "w": 21, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "454_3": { - "frame": { "x": 342, "y": 145, "w": 21, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 6, "w": 21, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "456_2": { - "frame": { "x": 56, "y": 247, "w": 20, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 9, "w": 20, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "456_3": { - "frame": { "x": 36, "y": 247, "w": 20, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 9, "w": 20, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "457_2": { - "frame": { "x": 19, "y": 160, "w": 22, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 5, "w": 22, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "457_3": { - "frame": { "x": 289, "y": 159, "w": 22, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 5, "w": 22, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "458_2": { - "frame": { "x": 311, "y": 254, "w": 20, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 10, "w": 20, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "458_3": { - "frame": { "x": 331, "y": 254, "w": 20, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 10, "w": 20, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "461_2": { - "frame": { "x": 218, "y": 223, "w": 19, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 19, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "461_3": { - "frame": { "x": 237, "y": 224, "w": 19, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 19, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "462_2": { - "frame": { "x": 58, "y": 70, "w": 26, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 4, "w": 26, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "462_3": { - "frame": { "x": 329, "y": 71, "w": 26, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 4, "w": 26, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "464_2": { - "frame": { "x": 83, "y": 95, "w": 27, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 6, "w": 27, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "464_3": { - "frame": { "x": 313, "y": 95, "w": 27, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 6, "w": 27, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "465_2": { - "frame": { "x": 145, "y": 53, "w": 29, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 6, "w": 29, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "465_3": { - "frame": { "x": 300, "y": 51, "w": 29, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 6, "w": 29, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "466_1": { - "frame": { "x": 216, "y": 94, "w": 26, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 5, "w": 26, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "466_2": { - "frame": { "x": 242, "y": 94, "w": 26, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 5, "w": 26, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "466_3": { - "frame": { "x": 57, "y": 94, "w": 26, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 5, "w": 26, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "467_2": { - "frame": { "x": 171, "y": 138, "w": 25, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 6, "w": 25, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "467_3": { - "frame": { "x": 121, "y": 120, "w": 25, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 6, "w": 25, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "468_1": { - "frame": { "x": 97, "y": 145, "w": 28, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 7, "w": 28, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "468_2": { - "frame": { "x": 291, "y": 140, "w": 28, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 7, "w": 28, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "468_3": { - "frame": { "x": 50, "y": 139, "w": 28, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 7, "w": 28, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "469_2": { - "frame": { "x": 204, "y": 70, "w": 30, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 6, "w": 30, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "469_3": { - "frame": { "x": 174, "y": 70, "w": 30, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 6, "w": 30, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "470_1": { - "frame": { "x": 266, "y": 120, "w": 25, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 25, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "470_2": { - "frame": { "x": 146, "y": 135, "w": 25, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 25, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "470_3": { - "frame": { "x": 196, "y": 138, "w": 25, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 25, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "471_1": { - "frame": { "x": 110, "y": 73, "w": 27, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 5, "w": 27, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "471_2": { - "frame": { "x": 286, "y": 73, "w": 27, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 5, "w": 27, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "471_3": { - "frame": { "x": 137, "y": 75, "w": 27, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 5, "w": 27, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "472_2": { - "frame": { "x": 275, "y": 25, "w": 31, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 6, "w": 31, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "472_3": { - "frame": { "x": 244, "y": 25, "w": 31, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 6, "w": 31, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "474_2": { - "frame": { "x": 292, "y": 96, "w": 21, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 6, "w": 21, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "474_3": { - "frame": { "x": 216, "y": 202, "w": 21, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 6, "w": 21, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "475-mega_2": { - "frame": { "x": 120, "y": 47, "w": 25, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 2, "w": 25, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "475-mega_3": { - "frame": { "x": 33, "y": 28, "w": 25, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 2, "w": 25, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "475_2": { - "frame": { "x": 99, "y": 120, "w": 22, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 3, "w": 22, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "475_3": { - "frame": { "x": 340, "y": 120, "w": 22, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 3, "w": 22, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "478_2": { - "frame": { "x": 148, "y": 247, "w": 16, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 6, "w": 16, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "478_3": { - "frame": { "x": 313, "y": 73, "w": 16, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 6, "w": 16, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "479-fan_2": { - "frame": { "x": 221, "y": 138, "w": 26, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 7, "w": 26, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "479-fan_3": { - "frame": { "x": 24, "y": 139, "w": 26, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 7, "w": 26, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "479-frost_2": { - "frame": { "x": 214, "y": 25, "w": 30, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 5, "w": 30, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "479-frost_3": { - "frame": { "x": 184, "y": 25, "w": 30, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 5, "w": 30, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "479-heat_2": { - "frame": { "x": 58, "y": 48, "w": 29, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 6, "w": 29, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "479-heat_3": { - "frame": { "x": 0, "y": 70, "w": 29, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 6, "w": 29, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "479-mow_2": { - "frame": { "x": 192, "y": 91, "w": 24, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 24, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "479-mow_3": { - "frame": { "x": 0, "y": 92, "w": 24, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 24, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "479-wash_2": { - "frame": { "x": 164, "y": 91, "w": 28, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 28, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "479-wash_3": { - "frame": { "x": 29, "y": 76, "w": 28, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 28, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "479_2": { - "frame": { "x": 156, "y": 0, "w": 28, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 3, "w": 28, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "479_3": { - "frame": { "x": 128, "y": 0, "w": 28, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 3, "w": 28, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "480_1": { - "frame": { "x": 186, "y": 116, "w": 26, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 26, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "480_2": { - "frame": { "x": 160, "y": 113, "w": 26, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 26, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "480_3": { - "frame": { "x": 134, "y": 98, "w": 26, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 26, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "481_1": { - "frame": { "x": 178, "y": 48, "w": 29, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 6, "w": 29, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "481_2": { - "frame": { "x": 0, "y": 48, "w": 29, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 6, "w": 29, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "481_3": { - "frame": { "x": 29, "y": 54, "w": 29, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 6, "w": 29, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "482_1": { - "frame": { "x": 84, "y": 71, "w": 26, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 4, "w": 26, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "482_2": { - "frame": { "x": 260, "y": 70, "w": 26, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 4, "w": 26, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "482_3": { - "frame": { "x": 234, "y": 70, "w": 26, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 4, "w": 26, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "485_2": { - "frame": { "x": 0, "y": 28, "w": 33, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 8, "w": 33, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "485_3": { - "frame": { "x": 120, "y": 27, "w": 33, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 8, "w": 33, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "487-altered_2": { - "frame": { "x": 332, "y": 0, "w": 30, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 4, "w": 30, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "487-altered_3": { - "frame": { "x": 62, "y": 24, "w": 30, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 4, "w": 30, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "487-origin_2": { - "frame": { "x": 92, "y": 24, "w": 28, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 2, "w": 28, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "487-origin_3": { - "frame": { "x": 332, "y": 24, "w": 28, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 2, "w": 28, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "488_2": { - "frame": { "x": 153, "y": 27, "w": 25, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 25, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "488_3": { - "frame": { "x": 306, "y": 25, "w": 25, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 25, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "489_1": { - "frame": { "x": 57, "y": 230, "w": 23, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 11, "w": 23, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "489_2": { - "frame": { "x": 279, "y": 226, "w": 23, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 11, "w": 23, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "489_3": { - "frame": { "x": 256, "y": 228, "w": 23, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 11, "w": 23, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "490_1": { - "frame": { "x": 257, "y": 208, "w": 22, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 8, "w": 22, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "490_2": { - "frame": { "x": 283, "y": 206, "w": 22, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 8, "w": 22, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "490_3": { - "frame": { "x": 0, "y": 204, "w": 22, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 8, "w": 22, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "491_2": { - "frame": { "x": 0, "y": 0, "w": 31, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 1, "w": 31, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "491_3": { - "frame": { "x": 31, "y": 0, "w": 31, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 1, "w": 31, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "492-land_2": { - "frame": { "x": 145, "y": 269, "w": 18, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 12, "w": 18, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "492-land_3": { - "frame": { "x": 311, "y": 271, "w": 18, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 12, "w": 18, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "492-sky_2": { - "frame": { "x": 117, "y": 200, "w": 21, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 6, "w": 21, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "492-sky_3": { - "frame": { "x": 309, "y": 191, "w": 21, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 6, "w": 21, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - } - }, - "meta": { - "app": "https://www.aseprite.org/", - "version": "1.3.7-dev", - "image": "pokemon_icons_4v.png", - "format": "RGBA8888", - "size": { "w": 363, "h": 300 }, - "scale": "1" - } +{ + "textures": [ + { + "image": "pokemon_icons_4v.png", + "format": "RGBA8888", + "size": { + "w": 520, + "h": 520 + }, + "scale": 1, + "frames": [ + { + "filename": "387_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "387_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "388_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "388_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "389_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "389_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "390_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "390_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "391_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "391_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "392_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "392_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "393_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "393_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "394_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "394_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "395_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "395_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "399_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "399_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "400_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "400_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "401_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "401_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "402_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "402_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "406_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "406_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "407_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "407_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "412-plant_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "412-plant_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "412-plant_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "412-sandy_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "412-sandy_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "412-sandy_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "412-trash_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "412-trash_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "412-trash_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "413-plant_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "413-plant_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "413-plant_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "413-sandy_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "413-sandy_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "413-sandy_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "413-trash_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "413-trash_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "413-trash_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "414_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "414_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "418_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "418_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "419_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "419_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "422-east_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "422-east_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "422-east_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "422-west_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "422-west_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "422-west_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "423-east_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "423-east_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "423-east_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "423-west_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "423-west_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "423-west_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "424_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "424_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "425_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "425_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "426_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "426_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "427_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "427_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "428-mega_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "428-mega_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "428_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "428_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "429_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "429_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "429_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "430_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "430_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "433_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "433_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "433_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "436_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "436_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "437_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "437_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "438_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "438_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "440_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "440_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "440_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "441_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "441_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "442_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "442_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "443_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "443_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "443_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "444_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "444_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "444_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "445-mega_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "445-mega_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "445-mega_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "445_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "445_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "445_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "447_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "447_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "447_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "448-mega_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "448-mega_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "448-mega_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "448_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "448_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "448_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "453_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "453_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "454_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "454_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "455_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "455_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "456_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "456_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "457_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "457_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "458_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "458_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "461_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "461_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "462_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "462_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "464_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "464_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "465_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "465_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "466_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "466_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "466_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "467_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "467_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "468_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "468_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "468_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "469_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "469_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "470_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "470_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "470_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "471_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "471_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "471_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "472_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "472_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "474_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "474_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "475-mega_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "475-mega_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "475_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "475_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "478_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "478_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "479-fan_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "479-fan_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "479-frost_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "479-frost_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "479-heat_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "479-heat_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "479-mow_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "479-mow_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "479-wash_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "479-wash_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "479_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "479_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "480_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "480_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "480_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "481_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "481_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "481_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "482_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "482_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "482_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "485_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "485_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "486_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "486_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "487-altered_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "487-altered_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "487-origin_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "487-origin_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "488_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "488_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "489_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "489_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "489_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "490_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "490_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "490_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "491_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "491_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "492-land_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "492-land_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "492-sky_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "492-sky_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 480, + "w": 40, + "h": 30 + } + } + ] + } + ], + "meta": { + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0", + "smartupdate": "$TexturePacker:SmartUpdate:2288ca6bd49f36a5ca5b49f1bcaab17a:e83f40529aad7883718910695eafd075:ebc3f8ec5b2480b298192d752b6e57dc$" + } } diff --git a/public/images/pokemon_icons_4v.png b/public/images/pokemon_icons_4v.png index 4dbf5cc6918..7cfab80312a 100644 Binary files a/public/images/pokemon_icons_4v.png and b/public/images/pokemon_icons_4v.png differ diff --git a/public/images/pokemon_icons_5v.json b/public/images/pokemon_icons_5v.json index ef3ce80e8ef..7da5a765c0c 100644 --- a/public/images/pokemon_icons_5v.json +++ b/public/images/pokemon_icons_5v.json @@ -1,1341 +1,4640 @@ -{ "frames": { - "494_2": { - "frame": { "x": 251, "y": 190, "w": 18, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 6, "w": 18, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "494_3": { - "frame": { "x": 212, "y": 186, "w": 18, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 6, "w": 18, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "495_2": { - "frame": { "x": 192, "y": 225, "w": 20, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 11, "w": 20, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "495_3": { - "frame": { "x": 103, "y": 224, "w": 20, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 11, "w": 20, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "496_2": { - "frame": { "x": 138, "y": 180, "w": 22, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 8, "w": 22, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "496_3": { - "frame": { "x": 95, "y": 183, "w": 22, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 8, "w": 22, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "497_2": { - "frame": { "x": 28, "y": 94, "w": 28, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 6, "w": 28, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "497_3": { - "frame": { "x": 242, "y": 74, "w": 28, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 6, "w": 28, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "517_2": { - "frame": { "x": 92, "y": 260, "w": 15, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 14, "w": 15, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "517_3": { - "frame": { "x": 62, "y": 260, "w": 15, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 14, "w": 15, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "518_2": { - "frame": { "x": 288, "y": 149, "w": 23, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 6, "w": 23, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "518_3": { - "frame": { "x": 0, "y": 164, "w": 23, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 6, "w": 23, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "524_2": { - "frame": { "x": 88, "y": 140, "w": 11, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 15, "y": 11, "w": 11, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "524_3": { - "frame": { "x": 99, "y": 118, "w": 11, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 15, "y": 11, "w": 11, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "525_2": { - "frame": { "x": 47, "y": 164, "w": 24, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 7, "w": 24, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "525_3": { - "frame": { "x": 23, "y": 164, "w": 24, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 7, "w": 24, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "526_2": { - "frame": { "x": 95, "y": 26, "w": 29, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 3, "w": 29, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "526_3": { - "frame": { "x": 157, "y": 26, "w": 29, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 3, "w": 29, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "529_2": { - "frame": { "x": 202, "y": 208, "w": 21, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 11, "w": 21, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "529_3": { - "frame": { "x": 269, "y": 209, "w": 21, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 11, "w": 21, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "530_2": { - "frame": { "x": 183, "y": 71, "w": 29, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 6, "w": 29, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "530_3": { - "frame": { "x": 0, "y": 51, "w": 29, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 6, "w": 29, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "531-mega_2": { - "frame": { "x": 292, "y": 97, "w": 22, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 2, "w": 22, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "531-mega_3": { - "frame": { "x": 270, "y": 74, "w": 22, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 2, "w": 22, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "531_2": { - "frame": { "x": 311, "y": 169, "w": 22, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 6, "w": 22, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "531_3": { - "frame": { "x": 263, "y": 168, "w": 22, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 6, "w": 22, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "532_2": { - "frame": { "x": 71, "y": 179, "w": 24, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 9, "w": 24, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "532_3": { - "frame": { "x": 60, "y": 75, "w": 24, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 9, "w": 24, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "533_2": { - "frame": { "x": 242, "y": 50, "w": 27, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 4, "w": 27, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "533_3": { - "frame": { "x": 269, "y": 50, "w": 27, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 4, "w": 27, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "534_2": { - "frame": { "x": 249, "y": 0, "w": 31, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 5, "w": 31, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "534_3": { - "frame": { "x": 218, "y": 0, "w": 31, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 5, "w": 31, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "538_2": { - "frame": { "x": 166, "y": 115, "w": 28, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 8, "w": 28, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "538_3": { - "frame": { "x": 0, "y": 116, "w": 28, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 8, "w": 28, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "539_2": { - "frame": { "x": 169, "y": 165, "w": 22, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 22, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "539_3": { - "frame": { "x": 208, "y": 164, "w": 22, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 22, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "540_2": { - "frame": { "x": 16, "y": 248, "w": 15, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 11, "w": 15, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "540_3": { - "frame": { "x": 297, "y": 245, "w": 15, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 11, "w": 15, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "541_2": { - "frame": { "x": 288, "y": 229, "w": 20, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 12, "w": 20, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "541_3": { - "frame": { "x": 57, "y": 230, "w": 20, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 12, "w": 20, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "542_2": { - "frame": { "x": 195, "y": 242, "w": 14, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 7, "w": 14, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "542_3": { - "frame": { "x": 181, "y": 242, "w": 14, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 7, "w": 14, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "543_2": { - "frame": { "x": 312, "y": 249, "w": 18, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 14, "w": 18, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "543_3": { - "frame": { "x": 241, "y": 249, "w": 18, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 14, "w": 18, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "544_2": { - "frame": { "x": 223, "y": 213, "w": 22, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 12, "w": 22, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "544_3": { - "frame": { "x": 245, "y": 213, "w": 22, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 12, "w": 22, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "545_2": { - "frame": { "x": 154, "y": 51, "w": 29, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 6, "w": 29, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "545_3": { - "frame": { "x": 115, "y": 71, "w": 29, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 6, "w": 29, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "546_2": { - "frame": { "x": 160, "y": 242, "w": 21, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 14, "w": 21, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "546_3": { - "frame": { "x": 139, "y": 242, "w": 21, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 14, "w": 21, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "547_2": { - "frame": { "x": 230, "y": 171, "w": 21, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 6, "w": 21, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "547_3": { - "frame": { "x": 285, "y": 171, "w": 21, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 6, "w": 21, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "548_1": { - "frame": { "x": 251, "y": 171, "w": 12, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 14, "y": 10, "w": 12, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "548_2": { - "frame": { "x": 340, "y": 97, "w": 12, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 14, "y": 10, "w": 12, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "548_3": { - "frame": { "x": 228, "y": 97, "w": 12, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 14, "y": 10, "w": 12, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "549_2": { - "frame": { "x": 191, "y": 165, "w": 17, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 7, "w": 17, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "549_3": { - "frame": { "x": 335, "y": 119, "w": 17, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 7, "w": 17, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "551_2": { - "frame": { "x": 324, "y": 211, "w": 22, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 13, "w": 22, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "551_3": { - "frame": { "x": 62, "y": 214, "w": 22, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 13, "w": 22, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "552_2": { - "frame": { "x": 88, "y": 158, "w": 25, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 7, "w": 25, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "552_3": { - "frame": { "x": 144, "y": 159, "w": 25, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 7, "w": 25, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "553_2": { - "frame": { "x": 324, "y": 50, "w": 28, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 5, "w": 28, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "553_3": { - "frame": { "x": 296, "y": 50, "w": 28, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 5, "w": 28, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "556_2": { - "frame": { "x": 99, "y": 135, "w": 23, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 23, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "556_3": { - "frame": { "x": 253, "y": 124, "w": 23, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 23, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "559_1": { - "frame": { "x": 166, "y": 256, "w": 15, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 12, "w": 15, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "559_2": { - "frame": { "x": 136, "y": 256, "w": 15, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 12, "w": 15, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "559_3": { - "frame": { "x": 151, "y": 256, "w": 15, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 12, "w": 15, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "560_1": { - "frame": { "x": 144, "y": 138, "w": 20, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 7, "w": 20, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "560_2": { - "frame": { "x": 117, "y": 183, "w": 20, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 7, "w": 20, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "560_3": { - "frame": { "x": 23, "y": 185, "w": 20, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 7, "w": 20, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "562_2": { - "frame": { "x": 127, "y": 220, "w": 22, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 12, "w": 22, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "562_3": { - "frame": { "x": 290, "y": 213, "w": 22, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 12, "w": 22, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "563_2": { - "frame": { "x": 218, "y": 25, "w": 30, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 3, "w": 30, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "563_3": { - "frame": { "x": 307, "y": 0, "w": 30, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 3, "w": 30, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "568_2": { - "frame": { "x": 181, "y": 205, "w": 21, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 10, "w": 21, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "568_3": { - "frame": { "x": 0, "y": 205, "w": 21, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 10, "w": 21, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "569-gigantamax_2": { - "frame": { "x": 32, "y": 0, "w": 32, "h": 29 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 0, "w": 32, "h": 29 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "569-gigantamax_3": { - "frame": { "x": 0, "y": 0, "w": 32, "h": 29 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 0, "w": 32, "h": 29 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "569_2": { - "frame": { "x": 277, "y": 28, "w": 30, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 6, "w": 30, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "569_3": { - "frame": { "x": 0, "y": 29, "w": 30, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 6, "w": 30, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "570_2": { - "frame": { "x": 209, "y": 247, "w": 16, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 11, "w": 16, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "570_3": { - "frame": { "x": 225, "y": 247, "w": 16, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 11, "w": 16, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "571_2": { - "frame": { "x": 86, "y": 51, "w": 29, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 6, "w": 29, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "571_3": { - "frame": { "x": 29, "y": 51, "w": 29, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 6, "w": 29, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "572_2": { - "frame": { "x": 43, "y": 185, "w": 22, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 9, "w": 22, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "572_3": { - "frame": { "x": 0, "y": 186, "w": 22, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 9, "w": 22, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "577_1": { - "frame": { "x": 47, "y": 260, "w": 15, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 14, "w": 15, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "577_2": { - "frame": { "x": 71, "y": 164, "w": 15, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 14, "w": 15, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "577_3": { - "frame": { "x": 77, "y": 260, "w": 15, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 14, "w": 15, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "578_1": { - "frame": { "x": 0, "y": 241, "w": 16, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 9, "w": 16, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "578_2": { - "frame": { "x": 93, "y": 241, "w": 16, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 9, "w": 16, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "578_3": { - "frame": { "x": 77, "y": 241, "w": 16, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 9, "w": 16, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "579_1": { - "frame": { "x": 0, "y": 73, "w": 30, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 7, "w": 30, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "579_2": { - "frame": { "x": 30, "y": 73, "w": 30, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 7, "w": 30, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "579_3": { - "frame": { "x": 144, "y": 73, "w": 30, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 7, "w": 30, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "585-autumn_1": { - "frame": { "x": 333, "y": 145, "w": 18, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 18, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "585-spring_1": { - "frame": { "x": 333, "y": 167, "w": 18, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 18, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "585-summer_1": { - "frame": { "x": 333, "y": 189, "w": 18, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 18, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "585-winter_1": { - "frame": { "x": 306, "y": 191, "w": 18, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 18, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "586-autumn_1": { - "frame": { "x": 86, "y": 73, "w": 25, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 3, "w": 25, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "586-spring_1": { - "frame": { "x": 51, "y": 116, "w": 23, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 4, "w": 23, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "586-summer_1": { - "frame": { "x": 28, "y": 116, "w": 23, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 4, "w": 23, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "586-winter_1": { - "frame": { "x": 267, "y": 100, "w": 23, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 4, "w": 23, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "592-f_1": { - "frame": { "x": 89, "y": 203, "w": 19, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 8, "w": 19, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "592-f_2": { - "frame": { "x": 43, "y": 204, "w": 19, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 8, "w": 19, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "592-f_3": { - "frame": { "x": 108, "y": 204, "w": 19, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 8, "w": 19, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "592_2": { - "frame": { "x": 137, "y": 200, "w": 19, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 8, "w": 19, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "592_3": { - "frame": { "x": 230, "y": 193, "w": 19, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 8, "w": 19, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "593-f_1": { - "frame": { "x": 56, "y": 94, "w": 27, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 6, "w": 27, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "593-f_2": { - "frame": { "x": 139, "y": 94, "w": 27, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 6, "w": 27, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "593-f_3": { - "frame": { "x": 240, "y": 96, "w": 27, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 6, "w": 27, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "593_2": { - "frame": { "x": 0, "y": 94, "w": 28, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 6, "w": 28, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "593_3": { - "frame": { "x": 212, "y": 75, "w": 28, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 6, "w": 28, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "594_2": { - "frame": { "x": 264, "y": 242, "w": 13, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 6, "w": 13, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "594_3": { - "frame": { "x": 34, "y": 243, "w": 13, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 6, "w": 13, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "595_2": { - "frame": { "x": 149, "y": 226, "w": 21, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 12, "w": 21, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "595_3": { - "frame": { "x": 267, "y": 226, "w": 21, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 12, "w": 21, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "596_2": { - "frame": { "x": 174, "y": 93, "w": 28, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 6, "w": 28, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "596_3": { - "frame": { "x": 111, "y": 93, "w": 28, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 6, "w": 28, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "602_2": { - "frame": { "x": 107, "y": 262, "w": 14, "h": 11 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 17, "w": 14, "h": 11 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "602_3": { - "frame": { "x": 290, "y": 262, "w": 14, "h": 11 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 17, "w": 14, "h": 11 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "603_2": { - "frame": { "x": 191, "y": 186, "w": 21, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 9, "w": 21, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "603_3": { - "frame": { "x": 160, "y": 187, "w": 21, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 9, "w": 21, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "604_2": { - "frame": { "x": 186, "y": 49, "w": 30, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 7, "w": 30, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "604_3": { - "frame": { "x": 124, "y": 49, "w": 30, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 7, "w": 30, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "605_1": { - "frame": { "x": 123, "y": 256, "w": 13, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 9, "w": 13, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "605_2": { - "frame": { "x": 330, "y": 249, "w": 13, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 9, "w": 13, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "605_3": { - "frame": { "x": 293, "y": 193, "w": 13, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 9, "w": 13, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "606_1": { - "frame": { "x": 19, "y": 226, "w": 15, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 6, "w": 15, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "606_2": { - "frame": { "x": 312, "y": 227, "w": 15, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 6, "w": 15, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "606_3": { - "frame": { "x": 327, "y": 227, "w": 15, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 6, "w": 15, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "607_2": { - "frame": { "x": 0, "y": 260, "w": 13, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 14, "y": 10, "w": 13, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "607_3": { - "frame": { "x": 277, "y": 259, "w": 13, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 14, "y": 10, "w": 13, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "608_2": { - "frame": { "x": 0, "y": 223, "w": 19, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 10, "w": 19, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "608_3": { - "frame": { "x": 84, "y": 223, "w": 19, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 10, "w": 19, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "609_2": { - "frame": { "x": 64, "y": 27, "w": 29, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 5, "w": 29, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "609_3": { - "frame": { "x": 186, "y": 26, "w": 29, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 5, "w": 29, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "610_2": { - "frame": { "x": 21, "y": 206, "w": 18, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 8, "w": 18, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "610_3": { - "frame": { "x": 156, "y": 206, "w": 18, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 8, "w": 18, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "611_2": { - "frame": { "x": 113, "y": 162, "w": 25, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 7, "w": 25, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "611_3": { - "frame": { "x": 263, "y": 147, "w": 25, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 7, "w": 25, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "612_2": { - "frame": { "x": 322, "y": 73, "w": 26, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 4, "w": 26, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "612_3": { - "frame": { "x": 296, "y": 73, "w": 26, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 4, "w": 26, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "618_2": { - "frame": { "x": 277, "y": 245, "w": 20, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 14, "w": 20, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "618_3": { - "frame": { "x": 47, "y": 246, "w": 20, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 14, "w": 20, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "619_2": { - "frame": { "x": 39, "y": 224, "w": 18, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 9, "w": 18, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "619_3": { - "frame": { "x": 174, "y": 223, "w": 18, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 9, "w": 18, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "620_2": { - "frame": { "x": 228, "y": 118, "w": 25, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 25, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "620_3": { - "frame": { "x": 74, "y": 118, "w": 25, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 25, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "622_2": { - "frame": { "x": 212, "y": 229, "w": 18, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 10, "w": 18, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "622_3": { - "frame": { "x": 230, "y": 229, "w": 18, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 10, "w": 18, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "623_2": { - "frame": { "x": 60, "y": 50, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 3, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "623_3": { - "frame": { "x": 216, "y": 50, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 3, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "631_2": { - "frame": { "x": 83, "y": 98, "w": 28, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 8, "w": 28, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "631_3": { - "frame": { "x": 111, "y": 115, "w": 28, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 8, "w": 28, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "632_2": { - "frame": { "x": 65, "y": 198, "w": 24, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 12, "w": 24, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "632_3": { - "frame": { "x": 269, "y": 193, "w": 24, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 12, "w": 24, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "633_2": { - "frame": { "x": 248, "y": 229, "w": 16, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 8, "w": 16, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "633_3": { - "frame": { "x": 123, "y": 236, "w": 16, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 8, "w": 16, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "634_2": { - "frame": { "x": 202, "y": 97, "w": 26, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 6, "w": 26, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "634_3": { - "frame": { "x": 314, "y": 97, "w": 26, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 6, "w": 26, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "635_2": { - "frame": { "x": 307, "y": 25, "w": 29, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 3, "w": 29, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "635_3": { - "frame": { "x": 248, "y": 25, "w": 29, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 3, "w": 29, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "640_2": { - "frame": { "x": 290, "y": 123, "w": 21, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 2, "w": 21, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "640_3": { - "frame": { "x": 314, "y": 119, "w": 21, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 2, "w": 21, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "641-incarnate_1": { - "frame": { "x": 188, "y": 0, "w": 30, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 2, "w": 30, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "641-therian_1": { - "frame": { "x": 127, "y": 0, "w": 30, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 1, "w": 30, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "642-incarnate_1": { - "frame": { "x": 64, "y": 0, "w": 31, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 1, "w": 31, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "642-therian_1": { - "frame": { "x": 95, "y": 0, "w": 32, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 3, "w": 32, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "645-incarnate_1": { - "frame": { "x": 157, "y": 0, "w": 31, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 2, "w": 31, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "645-therian_1": { - "frame": { "x": 280, "y": 0, "w": 27, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 27, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "647-ordinary_2": { - "frame": { "x": 194, "y": 119, "w": 25, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 25, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "647-ordinary_3": { - "frame": { "x": 139, "y": 116, "w": 25, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 25, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "647-resolute_2": { - "frame": { "x": 124, "y": 27, "w": 30, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 6, "w": 30, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "647-resolute_3": { - "frame": { "x": 30, "y": 29, "w": 30, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 6, "w": 30, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "648-aria_2": { - "frame": { "x": 109, "y": 241, "w": 14, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 7, "w": 14, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "648-aria_3": { - "frame": { "x": 276, "y": 124, "w": 14, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 7, "w": 14, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "648-pirouette_2": { - "frame": { "x": 337, "y": 23, "w": 15, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 5, "w": 15, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "648-pirouette_3": { - "frame": { "x": 337, "y": 0, "w": 15, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 5, "w": 15, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "649-burn_2": { - "frame": { "x": 22, "y": 140, "w": 22, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 22, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "649-burn_3": { - "frame": { "x": 122, "y": 138, "w": 22, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 22, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "649-chill_2": { - "frame": { "x": 0, "y": 136, "w": 22, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 22, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "649-chill_3": { - "frame": { "x": 164, "y": 135, "w": 22, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 22, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "649-douse_2": { - "frame": { "x": 241, "y": 147, "w": 22, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 22, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "649-douse_3": { - "frame": { "x": 311, "y": 145, "w": 22, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 22, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "649-shock_2": { - "frame": { "x": 186, "y": 141, "w": 22, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 22, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "649-shock_3": { - "frame": { "x": 219, "y": 140, "w": 22, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 22, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "649_2": { - "frame": { "x": 66, "y": 140, "w": 22, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 22, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "649_3": { - "frame": { "x": 44, "y": 140, "w": 22, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 22, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - } - }, - "meta": { - "app": "https://www.aseprite.org/", - "version": "1.3.7-dev", - "image": "pokemon_icons_5v.png", - "format": "RGBA8888", - "size": { "w": 352, "h": 278 }, - "scale": "1" - } +{ + "textures": [ + { + "image": "pokemon_icons_5v.png", + "format": "RGBA8888", + "size": { + "w": 520, + "h": 520 + }, + "scale": 1, + "frames": [ + { + "filename": "494_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "494_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "495_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "495_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "496_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "496_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "497_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "497_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "501_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "501_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "502_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "502_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "503_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "503_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "517_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "517_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "518_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "518_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "524_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "524_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "525_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "525_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "526_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "526_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "527_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "527_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "528_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "528_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "529_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "529_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "530_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "530_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "531-mega_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "531-mega_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "531_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "531_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "532_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "532_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "533_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "533_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "534_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "534_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "538_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "538_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "539_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "539_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "540_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "540_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "541_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "541_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "542_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "542_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "543_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "543_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "544_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "544_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "545_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "545_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "546_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "546_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "547_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "547_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "548_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "548_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "548_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "549_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "549_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "551_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "551_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "552_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "552_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "553_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "553_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "556_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "556_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "559_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "559_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "559_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "560_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "560_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "560_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "562_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "562_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "563_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "563_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "568_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "568_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "569-gigantamax_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "569-gigantamax_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "569_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "569_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "570_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "570_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "571_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "571_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "572_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "572_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "577_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "577_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "577_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "578_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "578_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "578_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "579_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "579_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "579_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "585-autumn_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "585-spring_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "585-summer_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "585-winter_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "586-autumn_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "586-spring_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "586-summer_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "586-winter_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "587_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "587_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "588_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "588_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "589_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "589_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "590_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "590_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "591_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "591_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "592-f_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "592-f_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "592-f_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "592_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "592_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "593-f_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "593-f_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "593-f_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "593_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "593_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "594_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "594_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "595_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "595_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "596_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "596_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "602_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "602_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "603_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "603_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "604_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "604_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "605_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "605_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "605_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "606_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "606_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "606_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "607_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "607_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "608_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "608_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "609_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "609_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "610_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "610_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "611_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "611_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "612_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "612_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "616_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "616_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "617_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "617_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "618_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "618_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "619_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "619_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "620_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "620_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "621_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "621_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "622_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "622_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "623_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "623_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "631_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "631_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "632_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "632_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "633_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "633_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "634_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "634_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "635_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "635_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "636_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "636_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "637_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "637_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "640_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "640_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "641-incarnate_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "641-therian_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "642-incarnate_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "642-therian_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "645-incarnate_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "645-therian_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "647-ordinary_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "647-ordinary_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "647-resolute_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "647-resolute_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "648-aria_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "648-aria_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 480, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "648-pirouette_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "648-pirouette_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "649-burn_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "649-burn_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "649-chill_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "649-chill_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "649-douse_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "649-douse_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "649-shock_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "649-shock_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "649_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "649_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 480, + "w": 40, + "h": 30 + } + } + ] + } + ], + "meta": { + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0", + "smartupdate": "$TexturePacker:SmartUpdate:b615ea9a62bec26b97d0171030d11a55:35fd8571f91311ef2e9944578f979466:f1931bc28ee7f32dba7543723757cf2a$" + } } diff --git a/public/images/pokemon_icons_5v.png b/public/images/pokemon_icons_5v.png index 917e0621263..9dd1b278ac1 100644 Binary files a/public/images/pokemon_icons_5v.png and b/public/images/pokemon_icons_5v.png differ diff --git a/public/images/pokemon_icons_6v.json b/public/images/pokemon_icons_6v.json index 600624ca730..8061ed9152b 100644 --- a/public/images/pokemon_icons_6v.json +++ b/public/images/pokemon_icons_6v.json @@ -1,1026 +1,3905 @@ -{ "frames": { - "2670_2": { - "frame": { "x": 119, "y": 159, "w": 23, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 7, "w": 23, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "2670_3": { - "frame": { "x": 175, "y": 157, "w": 23, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 7, "w": 23, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "653_2": { - "frame": { "x": 142, "y": 204, "w": 17, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 9, "w": 17, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "653_3": { - "frame": { "x": 304, "y": 210, "w": 17, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 9, "w": 17, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "654_2": { - "frame": { "x": 322, "y": 22, "w": 20, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 20, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "654_3": { - "frame": { "x": 322, "y": 0, "w": 20, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 20, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "655_2": { - "frame": { "x": 287, "y": 145, "w": 27, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 5, "w": 27, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "655_3": { - "frame": { "x": 260, "y": 145, "w": 27, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 5, "w": 27, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "664_2": { - "frame": { "x": 38, "y": 214, "w": 14, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 7, "w": 14, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "664_3": { - "frame": { "x": 159, "y": 204, "w": 14, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 7, "w": 14, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "665_2": { - "frame": { "x": 173, "y": 217, "w": 16, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 11, "w": 16, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "665_3": { - "frame": { "x": 52, "y": 218, "w": 16, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 11, "w": 16, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-archipelago_2": { - "frame": { "x": 78, "y": 105, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-archipelago_3": { - "frame": { "x": 130, "y": 107, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-continental_2": { - "frame": { "x": 156, "y": 107, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-continental_3": { - "frame": { "x": 182, "y": 107, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-elegant_2": { - "frame": { "x": 260, "y": 120, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-elegant_3": { - "frame": { "x": 286, "y": 120, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-fancy_2": { - "frame": { "x": 52, "y": 105, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-fancy_3": { - "frame": { "x": 208, "y": 126, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-garden_2": { - "frame": { "x": 156, "y": 82, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-garden_3": { - "frame": { "x": 234, "y": 126, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-high-plains_2": { - "frame": { "x": 0, "y": 130, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-high-plains_3": { - "frame": { "x": 26, "y": 130, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-icy-snow_2": { - "frame": { "x": 0, "y": 55, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-icy-snow_3": { - "frame": { "x": 26, "y": 55, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-jungle_2": { - "frame": { "x": 52, "y": 55, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-jungle_3": { - "frame": { "x": 78, "y": 55, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-marine_2": { - "frame": { "x": 104, "y": 57, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-marine_3": { - "frame": { "x": 130, "y": 57, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-meadow_2": { - "frame": { "x": 156, "y": 57, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-meadow_3": { - "frame": { "x": 182, "y": 57, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-modern_2": { - "frame": { "x": 268, "y": 70, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-modern_3": { - "frame": { "x": 294, "y": 70, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-monsoon_2": { - "frame": { "x": 208, "y": 76, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-monsoon_3": { - "frame": { "x": 234, "y": 76, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-ocean_2": { - "frame": { "x": 312, "y": 120, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-ocean_3": { - "frame": { "x": 0, "y": 80, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-poke-ball_2": { - "frame": { "x": 26, "y": 80, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-poke-ball_3": { - "frame": { "x": 52, "y": 80, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-polar_2": { - "frame": { "x": 78, "y": 80, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-polar_3": { - "frame": { "x": 104, "y": 82, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-river_2": { - "frame": { "x": 130, "y": 82, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-river_3": { - "frame": { "x": 104, "y": 107, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-sandstorm_2": { - "frame": { "x": 182, "y": 82, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-sandstorm_3": { - "frame": { "x": 260, "y": 95, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-savanna_2": { - "frame": { "x": 286, "y": 95, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-savanna_3": { - "frame": { "x": 312, "y": 95, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-sun_2": { - "frame": { "x": 208, "y": 101, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-sun_3": { - "frame": { "x": 234, "y": 101, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-tundra_2": { - "frame": { "x": 0, "y": 105, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "666-tundra_3": { - "frame": { "x": 26, "y": 105, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "669-blue_2": { - "frame": { "x": 0, "y": 220, "w": 15, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 10, "w": 15, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "669-blue_3": { - "frame": { "x": 142, "y": 223, "w": 15, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 10, "w": 15, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "669-orange_2": { - "frame": { "x": 83, "y": 223, "w": 15, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 10, "w": 15, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "669-orange_3": { - "frame": { "x": 113, "y": 224, "w": 15, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 10, "w": 15, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "669-red_2": { - "frame": { "x": 157, "y": 225, "w": 15, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 10, "w": 15, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "669-red_3": { - "frame": { "x": 229, "y": 229, "w": 15, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 10, "w": 15, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "669-white_2": { - "frame": { "x": 296, "y": 229, "w": 15, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 10, "w": 15, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "669-white_3": { - "frame": { "x": 189, "y": 218, "w": 15, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 10, "w": 15, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "669-yellow_2": { - "frame": { "x": 98, "y": 219, "w": 15, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 10, "w": 15, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "669-yellow_3": { - "frame": { "x": 68, "y": 223, "w": 15, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 10, "w": 15, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "670-blue_2": { - "frame": { "x": 175, "y": 178, "w": 19, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 19, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "670-blue_3": { - "frame": { "x": 138, "y": 180, "w": 19, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 19, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "670-orage_2": { - "frame": { "x": 86, "y": 182, "w": 19, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 19, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "670-orage_3": { - "frame": { "x": 268, "y": 190, "w": 19, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 19, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "670-red_2": { - "frame": { "x": 67, "y": 179, "w": 19, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 19, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "670-red_3": { - "frame": { "x": 119, "y": 180, "w": 19, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 19, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "670-white_2": { - "frame": { "x": 249, "y": 190, "w": 19, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 19, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "670-white_3": { - "frame": { "x": 198, "y": 175, "w": 19, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 19, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "670-yellow_2": { - "frame": { "x": 0, "y": 177, "w": 19, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 19, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "670-yellow_3": { - "frame": { "x": 19, "y": 177, "w": 19, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 19, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "671-blue_2": { - "frame": { "x": 230, "y": 27, "w": 26, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 3, "w": 26, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "671-blue_3": { - "frame": { "x": 182, "y": 30, "w": 26, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 3, "w": 26, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "671-orange_2": { - "frame": { "x": 156, "y": 30, "w": 26, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 3, "w": 26, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "671-orange_3": { - "frame": { "x": 256, "y": 27, "w": 26, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 3, "w": 26, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "671-red_2": { - "frame": { "x": 0, "y": 28, "w": 26, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 3, "w": 26, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "671-red_3": { - "frame": { "x": 26, "y": 28, "w": 26, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 3, "w": 26, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "671-white_2": { - "frame": { "x": 52, "y": 28, "w": 26, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 3, "w": 26, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "671-white_3": { - "frame": { "x": 130, "y": 30, "w": 26, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 3, "w": 26, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "671-yellow_2": { - "frame": { "x": 78, "y": 28, "w": 26, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 3, "w": 26, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "671-yellow_3": { - "frame": { "x": 104, "y": 30, "w": 26, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 3, "w": 26, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "672_2": { - "frame": { "x": 263, "y": 212, "w": 17, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 10, "w": 17, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "672_3": { - "frame": { "x": 321, "y": 213, "w": 17, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 10, "w": 17, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "673_2": { - "frame": { "x": 23, "y": 155, "w": 23, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 23, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "673_3": { - "frame": { "x": 0, "y": 155, "w": 23, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 23, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "677_2": { - "frame": { "x": 280, "y": 215, "w": 16, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 10, "w": 16, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "677_3": { - "frame": { "x": 18, "y": 216, "w": 16, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 10, "w": 16, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "678-female_2": { - "frame": { "x": 316, "y": 169, "w": 21, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 21, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "678-female_3": { - "frame": { "x": 253, "y": 168, "w": 21, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 21, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "678_2": { - "frame": { "x": 295, "y": 169, "w": 21, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 21, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "678_3": { - "frame": { "x": 274, "y": 168, "w": 21, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 21, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "690_2": { - "frame": { "x": 194, "y": 197, "w": 18, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 7, "w": 18, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "690_3": { - "frame": { "x": 0, "y": 199, "w": 18, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 7, "w": 18, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "691_2": { - "frame": { "x": 290, "y": 0, "w": 32, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 5, "w": 32, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "691_3": { - "frame": { "x": 290, "y": 23, "w": 32, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 5, "w": 32, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "696_2": { - "frame": { "x": 174, "y": 200, "w": 20, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 12, "w": 20, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "696_3": { - "frame": { "x": 18, "y": 199, "w": 20, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 12, "w": 20, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "697_2": { - "frame": { "x": 208, "y": 54, "w": 30, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 6, "w": 30, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "697_3": { - "frame": { "x": 238, "y": 54, "w": 30, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 6, "w": 30, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "698_2": { - "frame": { "x": 157, "y": 180, "w": 17, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 4, "w": 17, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "698_3": { - "frame": { "x": 287, "y": 191, "w": 17, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 4, "w": 17, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "699_2": { - "frame": { "x": 130, "y": 132, "w": 24, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 1, "w": 24, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "699_3": { - "frame": { "x": 106, "y": 132, "w": 24, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 1, "w": 24, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "700_2": { - "frame": { "x": 320, "y": 70, "w": 22, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 5, "w": 22, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "700_3": { - "frame": { "x": 208, "y": 30, "w": 22, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 5, "w": 22, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "702_2": { - "frame": { "x": 105, "y": 202, "w": 22, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 11, "w": 22, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "702_3": { - "frame": { "x": 59, "y": 201, "w": 22, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 11, "w": 22, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "703_2": { - "frame": { "x": 105, "y": 182, "w": 14, "h": 13 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 15, "w": 14, "h": 13 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "703_3": { - "frame": { "x": 268, "y": 54, "w": 14, "h": 13 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 15, "w": 14, "h": 13 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "704_2": { - "frame": { "x": 142, "y": 159, "w": 12, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 14, "y": 14, "w": 12, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "704_3": { - "frame": { "x": 128, "y": 224, "w": 12, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 14, "y": 14, "w": 12, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "705_2": { - "frame": { "x": 325, "y": 191, "w": 15, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 6, "w": 15, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "705_3": { - "frame": { "x": 127, "y": 202, "w": 15, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 6, "w": 15, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "706_2": { - "frame": { "x": 204, "y": 151, "w": 24, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 24, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "706_3": { - "frame": { "x": 314, "y": 145, "w": 24, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 24, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "708_2": { - "frame": { "x": 228, "y": 151, "w": 25, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 7, "w": 25, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "708_3": { - "frame": { "x": 52, "y": 154, "w": 25, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 7, "w": 25, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "709_2": { - "frame": { "x": 154, "y": 132, "w": 25, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 3, "w": 25, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "709_3": { - "frame": { "x": 179, "y": 132, "w": 25, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 3, "w": 25, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "710_2": { - "frame": { "x": 81, "y": 204, "w": 17, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 9, "w": 17, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "710_3": { - "frame": { "x": 212, "y": 211, "w": 17, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 9, "w": 17, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "711_1": { - "frame": { "x": 77, "y": 156, "w": 21, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 5, "w": 21, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "711_2": { - "frame": { "x": 154, "y": 157, "w": 21, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 5, "w": 21, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "711_3": { - "frame": { "x": 98, "y": 159, "w": 21, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 5, "w": 21, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "712_2": { - "frame": { "x": 229, "y": 211, "w": 17, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 10, "w": 17, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "712_3": { - "frame": { "x": 246, "y": 212, "w": 17, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 10, "w": 17, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "713_2": { - "frame": { "x": 52, "y": 130, "w": 27, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 4, "w": 27, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "713_3": { - "frame": { "x": 79, "y": 132, "w": 27, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 4, "w": 27, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "714_2": { - "frame": { "x": 46, "y": 175, "w": 21, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 6, "w": 21, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "714_3": { - "frame": { "x": 228, "y": 172, "w": 21, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 6, "w": 21, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "715_2": { - "frame": { "x": 310, "y": 46, "w": 28, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 4, "w": 28, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "715_3": { - "frame": { "x": 282, "y": 46, "w": 28, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 4, "w": 28, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "716-active_2": { - "frame": { "x": 114, "y": 0, "w": 29, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 0, "w": 29, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "716-active_3": { - "frame": { "x": 143, "y": 0, "w": 29, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 0, "w": 29, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "716-neutral_2": { - "frame": { "x": 172, "y": 0, "w": 29, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 0, "w": 29, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "716-neutral_3": { - "frame": { "x": 201, "y": 0, "w": 29, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 0, "w": 29, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "717_2": { - "frame": { "x": 230, "y": 0, "w": 30, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 3, "w": 30, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "717_3": { - "frame": { "x": 260, "y": 0, "w": 30, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 3, "w": 30, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "720-unbound_1": { - "frame": { "x": 38, "y": 0, "w": 38, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 1, "y": 2, "w": 38, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "720-unbound_2": { - "frame": { "x": 76, "y": 0, "w": 38, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 1, "y": 2, "w": 38, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "720-unbound_3": { - "frame": { "x": 0, "y": 0, "w": 38, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 1, "y": 2, "w": 38, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "720_1": { - "frame": { "x": 217, "y": 192, "w": 21, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 8, "w": 21, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "720_2": { - "frame": { "x": 38, "y": 195, "w": 21, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 8, "w": 21, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "720_3": { - "frame": { "x": 304, "y": 191, "w": 21, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 8, "w": 21, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - } - }, - "meta": { - "app": "https://www.aseprite.org/", - "version": "1.3.7-dev", - "image": "pokemon_icons_6v.png", - "format": "RGBA8888", - "size": { "w": 342, "h": 247 }, - "scale": "1" - } +{ + "textures": [ + { + "image": "pokemon_icons_6v.png", + "format": "RGBA8888", + "size": { + "w": 480, + "h": 480 + }, + "scale": 1, + "frames": [ + { + "filename": "653_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "653_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "654_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "654_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "655_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "655_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "656_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "656_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "657_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "657_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "658-ash_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "658-ash_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "658_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "658_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "664_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "664_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "665_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "665_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-archipelago_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-archipelago_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-continental_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-continental_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-elegant_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-elegant_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-fancy_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-fancy_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-garden_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-garden_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-high-plains_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-high-plains_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-icy-snow_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-icy-snow_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-jungle_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-jungle_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-marine_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-marine_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-meadow_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-meadow_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-modern_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-modern_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-monsoon_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-monsoon_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-ocean_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-ocean_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-poke-ball_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-poke-ball_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-polar_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-polar_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-river_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-river_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-sandstorm_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-sandstorm_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-savanna_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-savanna_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-sun_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-sun_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-tundra_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "666-tundra_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "669-blue_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "669-blue_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "669-orange_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "669-orange_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "669-red_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "669-red_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "669-white_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "669-white_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "669-yellow_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "669-yellow_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "670-blue_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "670-blue_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "670-orange_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "670-orange_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "670-red_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "670-red_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "670-white_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "670-white_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "670-yellow_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "670-yellow_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "671-blue_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "671-blue_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "671-orange_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "671-orange_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "671-red_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "671-red_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "671-white_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "671-white_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "671-yellow_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "671-yellow_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "672_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "672_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "673_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "673_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "676-dandy_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "676-dandy_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "676-debutante_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "676-debutante_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "676-diamond_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "676-diamond_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "676-heart_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "676-heart_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "676-kabuki_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "676-kabuki_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "676-la-reine_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "676-la-reine_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "676-matron_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "676-matron_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "676-pharaoh_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "676-pharaoh_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "676-star_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "676-star_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "676_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "676_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "677_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "677_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "678-female_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "678-female_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "678_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "678_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "682_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "682_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "683_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "683_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "684_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "684_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "685_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "685_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "688_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "688_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "689_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "689_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "690_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "690_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "691_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "691_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "696_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "696_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "697_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "697_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "698_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "698_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "699_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "699_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "700_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "700_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "702_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "702_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "703_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "703_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "704_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "704_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "705_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "705_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "706_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "706_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "708_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "708_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "709_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "709_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "710_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "710_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "711_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "711_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "711_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "712_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "712_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "713_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "713_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "714_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "714_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "715_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "715_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "716-active_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "716-active_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "716-neutral_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "716-neutral_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "717_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "717_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "720-unbound_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "720-unbound_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "720-unbound_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "720_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "720_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "720_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "2670_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "2670_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 450, + "w": 40, + "h": 30 + } + } + ] + } + ], + "meta": { + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0", + "smartupdate": "$TexturePacker:SmartUpdate:41960148e7a74c451d8ed1c46adc4e09:5dc2b45aa8a432e966da6c4070905be6:8a74f769af240f74b0e67390bbb36c14$" + } } diff --git a/public/images/pokemon_icons_6v.png b/public/images/pokemon_icons_6v.png index 83e29e28738..29d00876b50 100644 Binary files a/public/images/pokemon_icons_6v.png and b/public/images/pokemon_icons_6v.png differ diff --git a/public/images/pokemon_icons_7v.json b/public/images/pokemon_icons_7v.json index a7f828a0fe1..30e12ce3bb4 100644 --- a/public/images/pokemon_icons_7v.json +++ b/public/images/pokemon_icons_7v.json @@ -1,956 +1,2981 @@ -{ "frames": { - "2027_2": { - "frame": { "x": 160, "y": 218, "w": 21, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 10, "w": 21, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "2027_3": { - "frame": { "x": 91, "y": 218, "w": 21, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 10, "w": 21, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "2028_2": { - "frame": { "x": 26, "y": 148, "w": 25, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 4, "w": 25, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "2028_3": { - "frame": { "x": 104, "y": 148, "w": 25, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 4, "w": 25, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "2052_2": { - "frame": { "x": 144, "y": 195, "w": 21, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 7, "w": 21, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "2052_3": { - "frame": { "x": 331, "y": 195, "w": 21, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 7, "w": 21, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "2053_2": { - "frame": { "x": 121, "y": 172, "w": 24, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 6, "w": 24, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "2053_3": { - "frame": { "x": 312, "y": 172, "w": 24, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 6, "w": 24, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "728_2": { - "frame": { "x": 62, "y": 219, "w": 17, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 8, "w": 17, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "728_3": { - "frame": { "x": 45, "y": 219, "w": 17, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 8, "w": 17, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "729_2": { - "frame": { "x": 158, "y": 171, "w": 23, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 5, "w": 23, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "729_3": { - "frame": { "x": 98, "y": 172, "w": 23, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 5, "w": 23, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "730_2": { - "frame": { "x": 130, "y": 145, "w": 28, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 2, "w": 28, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "730_3": { - "frame": { "x": 234, "y": 147, "w": 28, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 2, "w": 28, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "734_2": { - "frame": { "x": 306, "y": 214, "w": 25, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 10, "w": 25, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "734_3": { - "frame": { "x": 20, "y": 215, "w": 25, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 10, "w": 25, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "735_2": { - "frame": { "x": 268, "y": 175, "w": 20, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 4, "w": 20, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "735_3": { - "frame": { "x": 288, "y": 175, "w": 20, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 4, "w": 20, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "742_2": { - "frame": { "x": 187, "y": 217, "w": 19, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 5, "w": 19, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "742_3": { - "frame": { "x": 283, "y": 217, "w": 19, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 5, "w": 19, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "743_2": { - "frame": { "x": 0, "y": 197, "w": 20, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 5, "w": 20, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "743_3": { - "frame": { "x": 96, "y": 196, "w": 20, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 5, "w": 20, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "747_2": { - "frame": { "x": 165, "y": 198, "w": 22, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 7, "w": 22, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "747_3": { - "frame": { "x": 202, "y": 197, "w": 22, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 7, "w": 22, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "748_2": { - "frame": { "x": 0, "y": 148, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 5, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "748_3": { - "frame": { "x": 312, "y": 147, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 5, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "751_2": { - "frame": { "x": 104, "y": 60, "w": 14, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 8, "w": 14, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "751_3": { - "frame": { "x": 130, "y": 88, "w": 14, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 8, "w": 14, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "752_2": { - "frame": { "x": 283, "y": 199, "w": 23, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 8, "w": 23, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "752_3": { - "frame": { "x": 116, "y": 214, "w": 23, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 8, "w": 23, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "753_2": { - "frame": { "x": 187, "y": 198, "w": 14, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 14, "y": 8, "w": 14, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "753_3": { - "frame": { "x": 234, "y": 118, "w": 14, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 14, "y": 8, "w": 14, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "754_2": { - "frame": { "x": 71, "y": 197, "w": 20, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 20, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "754_3": { - "frame": { "x": 224, "y": 198, "w": 20, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 20, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "755_2": { - "frame": { "x": 346, "y": 52, "w": 13, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 14, "y": 4, "w": 13, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "755_3": { - "frame": { "x": 268, "y": 30, "w": 13, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 14, "y": 4, "w": 13, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "756_2": { - "frame": { "x": 338, "y": 171, "w": 22, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 22, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "756_3": { - "frame": { "x": 0, "y": 173, "w": 22, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 22, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "761_2": { - "frame": { "x": 323, "y": 235, "w": 16, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 8, "w": 16, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "761_3": { - "frame": { "x": 129, "y": 235, "w": 16, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 8, "w": 16, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "762_2": { - "frame": { "x": 342, "y": 29, "w": 18, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 4, "w": 18, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "762_3": { - "frame": { "x": 265, "y": 199, "w": 18, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 4, "w": 18, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "763_2": { - "frame": { "x": 50, "y": 175, "w": 21, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 4, "w": 21, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "763_3": { - "frame": { "x": 181, "y": 174, "w": 21, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 4, "w": 21, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "767_2": { - "frame": { "x": 223, "y": 220, "w": 24, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 11, "w": 24, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "767_3": { - "frame": { "x": 17, "y": 231, "w": 24, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 11, "w": 24, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "768_2": { - "frame": { "x": 26, "y": 172, "w": 24, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 24, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "768_3": { - "frame": { "x": 74, "y": 150, "w": 24, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 24, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "771_2": { - "frame": { "x": 163, "y": 236, "w": 18, "h": 13 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 11, "w": 18, "h": 13 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "771_3": { - "frame": { "x": 145, "y": 236, "w": 18, "h": 13 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 11, "w": 18, "h": 13 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "772_2": { - "frame": { "x": 262, "y": 147, "w": 25, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 25, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "772_3": { - "frame": { "x": 287, "y": 147, "w": 25, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 25, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-bug_2": { - "frame": { "x": 0, "y": 118, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-bug_3": { - "frame": { "x": 26, "y": 118, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-dark_2": { - "frame": { "x": 104, "y": 118, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-dark_3": { - "frame": { "x": 182, "y": 118, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-dragon_2": { - "frame": { "x": 208, "y": 118, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-dragon_3": { - "frame": { "x": 52, "y": 120, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-electric_2": { - "frame": { "x": 78, "y": 120, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-electric_3": { - "frame": { "x": 268, "y": 57, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-fairy_2": { - "frame": { "x": 294, "y": 57, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-fairy_3": { - "frame": { "x": 320, "y": 57, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-fighting_2": { - "frame": { "x": 0, "y": 58, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-fighting_3": { - "frame": { "x": 26, "y": 58, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-fire_2": { - "frame": { "x": 118, "y": 58, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-fire_3": { - "frame": { "x": 203, "y": 58, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-flying_2": { - "frame": { "x": 229, "y": 58, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-flying_3": { - "frame": { "x": 326, "y": 117, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-ghost_2": { - "frame": { "x": 78, "y": 60, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-ghost_3": { - "frame": { "x": 144, "y": 85, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-grass_2": { - "frame": { "x": 170, "y": 85, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-grass_3": { - "frame": { "x": 255, "y": 87, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-ground_2": { - "frame": { "x": 281, "y": 87, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-ground_3": { - "frame": { "x": 307, "y": 87, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-ice_2": { - "frame": { "x": 333, "y": 87, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-ice_3": { - "frame": { "x": 0, "y": 88, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-poison_2": { - "frame": { "x": 26, "y": 88, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-poison_3": { - "frame": { "x": 104, "y": 88, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-psychic_2": { - "frame": { "x": 196, "y": 88, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-psychic_3": { - "frame": { "x": 222, "y": 88, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-rock_2": { - "frame": { "x": 52, "y": 90, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-rock_3": { - "frame": { "x": 78, "y": 90, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-steel_2": { - "frame": { "x": 130, "y": 115, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-steel_3": { - "frame": { "x": 52, "y": 60, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-water_2": { - "frame": { "x": 156, "y": 115, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773-water_3": { - "frame": { "x": 248, "y": 117, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773_2": { - "frame": { "x": 274, "y": 117, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "773_3": { - "frame": { "x": 300, "y": 117, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "776_2": { - "frame": { "x": 181, "y": 148, "w": 23, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 4, "w": 23, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "776_3": { - "frame": { "x": 158, "y": 145, "w": 23, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 4, "w": 23, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "777_2": { - "frame": { "x": 223, "y": 234, "w": 17, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 8, "w": 17, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "777_3": { - "frame": { "x": 112, "y": 232, "w": 17, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 8, "w": 17, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "778-busted_2": { - "frame": { "x": 302, "y": 230, "w": 21, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 12, "w": 21, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "778-busted_3": { - "frame": { "x": 247, "y": 222, "w": 21, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 12, "w": 21, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "778-disguised_2": { - "frame": { "x": 206, "y": 217, "w": 17, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 5, "w": 17, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "778-disguised_3": { - "frame": { "x": 0, "y": 219, "w": 17, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 5, "w": 17, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "779_2": { - "frame": { "x": 244, "y": 199, "w": 21, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 7, "w": 21, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "779_3": { - "frame": { "x": 45, "y": 199, "w": 21, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 7, "w": 21, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "789_1": { - "frame": { "x": 308, "y": 194, "w": 23, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 23, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "789_2": { - "frame": { "x": 22, "y": 195, "w": 23, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 23, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "789_3": { - "frame": { "x": 121, "y": 194, "w": 23, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 6, "w": 23, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "790_2": { - "frame": { "x": 331, "y": 216, "w": 21, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 7, "w": 21, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "790_3": { - "frame": { "x": 139, "y": 216, "w": 21, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 7, "w": 21, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "791_1": { - "frame": { "x": 239, "y": 30, "w": 29, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 2, "w": 29, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "791_2": { - "frame": { "x": 210, "y": 30, "w": 29, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 2, "w": 29, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "791_3": { - "frame": { "x": 118, "y": 30, "w": 29, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 2, "w": 29, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "792_2": { - "frame": { "x": 175, "y": 57, "w": 28, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 1, "w": 28, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "792_3": { - "frame": { "x": 147, "y": 57, "w": 28, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 1, "w": 28, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "793_2": { - "frame": { "x": 247, "y": 175, "w": 21, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 4, "w": 21, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "793_3": { - "frame": { "x": 226, "y": 174, "w": 21, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 4, "w": 21, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "797_2": { - "frame": { "x": 250, "y": 0, "w": 32, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 0, "w": 32, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "797_3": { - "frame": { "x": 218, "y": 0, "w": 32, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 0, "w": 32, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "798_2": { - "frame": { "x": 179, "y": 28, "w": 31, "h": 29 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 1, "w": 31, "h": 29 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "798_3": { - "frame": { "x": 148, "y": 28, "w": 31, "h": 29 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 1, "w": 31, "h": 29 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "800-dawn-wings_2": { - "frame": { "x": 31, "y": 28, "w": 31, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 0, "w": 31, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "800-dawn-wings_3": { - "frame": { "x": 0, "y": 28, "w": 31, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 0, "w": 31, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "800-dusk-mane_2": { - "frame": { "x": 114, "y": 0, "w": 34, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 3, "y": 0, "w": 34, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "800-dusk-mane_3": { - "frame": { "x": 80, "y": 0, "w": 34, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 3, "y": 0, "w": 34, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "800-ultra_2": { - "frame": { "x": 183, "y": 0, "w": 35, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 3, "y": 1, "w": 35, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "800-ultra_3": { - "frame": { "x": 148, "y": 0, "w": 35, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 3, "y": 1, "w": 35, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "800_2": { - "frame": { "x": 90, "y": 30, "w": 28, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 28, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "800_3": { - "frame": { "x": 62, "y": 30, "w": 28, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 28, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "802_1": { - "frame": { "x": 74, "y": 173, "w": 22, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 4, "w": 22, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "802_2": { - "frame": { "x": 204, "y": 173, "w": 22, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 4, "w": 22, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "802_3": { - "frame": { "x": 338, "y": 147, "w": 22, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 4, "w": 22, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "803_2": { - "frame": { "x": 51, "y": 150, "w": 23, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 3, "w": 23, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "803_3": { - "frame": { "x": 204, "y": 148, "w": 23, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 3, "w": 23, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "804_2": { - "frame": { "x": 315, "y": 0, "w": 33, "h": 29 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 1, "w": 33, "h": 29 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "804_3": { - "frame": { "x": 282, "y": 0, "w": 33, "h": 29 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 1, "w": 33, "h": 29 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "808_2": { - "frame": { "x": 339, "y": 235, "w": 17, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 11, "w": 17, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "808_3": { - "frame": { "x": 79, "y": 236, "w": 17, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 11, "w": 17, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "809-gigantamax_2": { - "frame": { "x": 312, "y": 29, "w": 30, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 0, "w": 30, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "809-gigantamax_3": { - "frame": { "x": 282, "y": 29, "w": 30, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 0, "w": 30, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "809_2": { - "frame": { "x": 40, "y": 0, "w": 40, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 0, "y": 1, "w": 40, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "809_3": { - "frame": { "x": 0, "y": 0, "w": 40, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 0, "y": 1, "w": 40, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - } - }, - "meta": { - "app": "https://www.aseprite.org/", - "version": "1.3.7-dev", - "image": "pokemon_icons_6v.png", - "format": "RGBA8888", - "size": { "w": 360, "h": 254 }, - "scale": "1" - } +{ + "textures": [ + { + "image": "pokemon_icons_7v.png", + "format": "RGBA8888", + "size": { + "w": 440, + "h": 440 + }, + "scale": 1, + "frames": [ + { + "filename": "728_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "728_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "729_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "729_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "730_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "730_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "734_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "734_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "735_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "735_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "742_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "742_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "743_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "743_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "747_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "747_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "748_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "748_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "751_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "751_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "752_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "752_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "753_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "753_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "754_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "754_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "755_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "755_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "756_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "756_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "761_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "761_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "762_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "762_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "763_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "763_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "767_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "767_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "768_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "768_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "771_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "771_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "772_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "772_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-bug_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-bug_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-dark_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-dark_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-dragon_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-dragon_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-electric_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-electric_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-fairy_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-fairy_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-fighting_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-fighting_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-fire_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-fire_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-flying_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-flying_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-ghost_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-ghost_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-grass_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-grass_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-ground_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-ground_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-ice_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-ice_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-poison_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-poison_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-psychic_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-psychic_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-rock_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-rock_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-steel_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-steel_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-water_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "773-water_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "773_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "773_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "776_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "776_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "777_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "777_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "778-busted_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "778-busted_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "778-disguised_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "778-disguised_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "779_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "779_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "789_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "789_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "789_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "790_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "790_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "791_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "791_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "791_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "792_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "792_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "793_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "793_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "797_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "797_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "798_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "798_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "800-dawn-wings_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "800-dawn-wings_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "800-dusk-mane_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "800-dusk-mane_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "800-ultra_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "800-ultra_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "800_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "800_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "802_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "802_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "802_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "803_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "803_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "804_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "804_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "807_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "807_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "808_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "808_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "809-gigantamax_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "809-gigantamax_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "809_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "809_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "2026_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "2026_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "2027_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "2027_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "2028_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "2028_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "2052_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "2052_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "2053_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "2053_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "2103_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "2103_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 360, + "w": 40, + "h": 30 + } + } + ] + } + ], + "meta": { + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0", + "smartupdate": "$TexturePacker:SmartUpdate:914c9869d6dab145bbbe443bdc3f932c:80b9ecf9647b68af17c07b88e1a1856e:d5975df27e1e94206a68aa1fd3c2c8d0$" + } } diff --git a/public/images/pokemon_icons_7v.png b/public/images/pokemon_icons_7v.png index 50fee6de396..1f7d6e5f826 100644 Binary files a/public/images/pokemon_icons_7v.png and b/public/images/pokemon_icons_7v.png differ diff --git a/public/images/pokemon_icons_8v.json b/public/images/pokemon_icons_8v.json index 002957bba0c..a33f88e9d9b 100644 --- a/public/images/pokemon_icons_8v.json +++ b/public/images/pokemon_icons_8v.json @@ -1,1306 +1,4115 @@ -{ "frames": { - "4052_2": { - "frame": { "x": 85, "y": 209, "w": 21, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 4, "w": 21, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "4052_3": { - "frame": { "x": 106, "y": 210, "w": 21, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 4, "w": 21, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "4077_2": { - "frame": { "x": 203, "y": 112, "w": 24, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 4, "w": 24, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "4077_3": { - "frame": { "x": 48, "y": 112, "w": 24, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 4, "w": 24, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "4078_2": { - "frame": { "x": 230, "y": 133, "w": 27, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 3, "w": 27, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "4078_3": { - "frame": { "x": 203, "y": 133, "w": 27, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 3, "w": 27, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "4079_2": { - "frame": { "x": 79, "y": 250, "w": 26, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 8, "w": 26, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "4079_3": { - "frame": { "x": 351, "y": 250, "w": 26, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 8, "w": 26, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "4080_1": { - "frame": { "x": 352, "y": 161, "w": 24, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 3, "w": 24, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "4080_2": { - "frame": { "x": 23, "y": 161, "w": 24, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 3, "w": 24, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "4080_3": { - "frame": { "x": 328, "y": 160, "w": 24, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 3, "w": 24, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "4144_2": { - "frame": { "x": 146, "y": 230, "w": 22, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 22, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "4144_3": { - "frame": { "x": 85, "y": 231, "w": 22, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 22, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "4145_2": { - "frame": { "x": 228, "y": 110, "w": 28, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 3, "w": 28, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "4145_3": { - "frame": { "x": 97, "y": 89, "w": 28, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 3, "w": 28, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "4146_2": { - "frame": { "x": 240, "y": 200, "w": 28, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 6, "w": 28, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "4146_3": { - "frame": { "x": 212, "y": 200, "w": 28, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 6, "w": 28, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "4199_1": { - "frame": { "x": 360, "y": 30, "w": 20, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 1, "w": 20, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "4199_2": { - "frame": { "x": 96, "y": 182, "w": 20, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 1, "w": 20, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "4199_3": { - "frame": { "x": 192, "y": 179, "w": 20, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 1, "w": 20, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "4222_2": { - "frame": { "x": 309, "y": 228, "w": 21, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 21, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "4222_3": { - "frame": { "x": 330, "y": 228, "w": 21, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 21, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "4263_2": { - "frame": { "x": 216, "y": 258, "w": 22, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 7, "w": 22, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "4263_3": { - "frame": { "x": 304, "y": 265, "w": 22, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 7, "w": 22, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "4264_2": { - "frame": { "x": 287, "y": 210, "w": 22, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 22, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "4264_3": { - "frame": { "x": 160, "y": 210, "w": 22, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 22, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "4562_2": { - "frame": { "x": 76, "y": 264, "w": 22, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 7, "w": 22, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "4562_3": { - "frame": { "x": 351, "y": 264, "w": 22, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 7, "w": 22, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "6100_2": { - "frame": { "x": 168, "y": 230, "w": 14, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 14, "w": 14, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "6100_3": { - "frame": { "x": 49, "y": 277, "w": 14, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 14, "w": 14, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "6101_2": { - "frame": { "x": 312, "y": 187, "w": 16, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 12, "w": 16, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "6101_3": { - "frame": { "x": 266, "y": 271, "w": 16, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 12, "w": 16, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "6215_2": { - "frame": { "x": 182, "y": 251, "w": 17, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 7, "w": 17, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "6215_3": { - "frame": { "x": 126, "y": 250, "w": 17, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 7, "w": 17, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "6549_2": { - "frame": { "x": 288, "y": 249, "w": 16, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 5, "w": 16, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "6549_3": { - "frame": { "x": 286, "y": 58, "w": 16, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 5, "w": 16, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "6570_2": { - "frame": { "x": 146, "y": 249, "w": 18, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 6, "w": 18, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "6570_3": { - "frame": { "x": 333, "y": 248, "w": 18, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 6, "w": 18, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "6571_2": { - "frame": { "x": 193, "y": 156, "w": 25, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 5, "w": 25, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "6571_3": { - "frame": { "x": 23, "y": 138, "w": 25, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 5, "w": 25, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "6705_2": { - "frame": { "x": 125, "y": 89, "w": 15, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 6, "w": 15, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "6705_3": { - "frame": { "x": 34, "y": 271, "w": 15, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 6, "w": 15, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "6706_2": { - "frame": { "x": 234, "y": 85, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 4, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "6706_3": { - "frame": { "x": 260, "y": 85, "w": 26, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 4, "w": 26, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "6713_2": { - "frame": { "x": 257, "y": 133, "w": 27, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 5, "w": 27, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "6713_3": { - "frame": { "x": 48, "y": 134, "w": 27, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 5, "w": 27, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "816_2": { - "frame": { "x": 0, "y": 188, "w": 22, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 3, "w": 22, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "816_3": { - "frame": { "x": 290, "y": 187, "w": 22, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 3, "w": 22, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "817_2": { - "frame": { "x": 308, "y": 136, "w": 24, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 3, "w": 24, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "817_3": { - "frame": { "x": 332, "y": 136, "w": 24, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 3, "w": 24, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "818-gigantamax_2": { - "frame": { "x": 214, "y": 28, "w": 30, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 0, "w": 30, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "818-gigantamax_3": { - "frame": { "x": 348, "y": 0, "w": 30, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 0, "w": 30, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "818_2": { - "frame": { "x": 75, "y": 134, "w": 22, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 1, "w": 22, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "818_3": { - "frame": { "x": 123, "y": 135, "w": 22, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 1, "w": 22, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "821_2": { - "frame": { "x": 139, "y": 271, "w": 19, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 7, "w": 19, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "821_3": { - "frame": { "x": 158, "y": 271, "w": 19, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 7, "w": 19, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "822_2": { - "frame": { "x": 0, "y": 231, "w": 22, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 22, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "822_3": { - "frame": { "x": 287, "y": 230, "w": 22, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 22, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "823-gigantamax_2": { - "frame": { "x": 302, "y": 28, "w": 32, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 1, "w": 32, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "823-gigantamax_3": { - "frame": { "x": 0, "y": 30, "w": 32, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 1, "w": 32, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "823_2": { - "frame": { "x": 140, "y": 87, "w": 27, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 3, "w": 27, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "823_3": { - "frame": { "x": 201, "y": 88, "w": 27, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 3, "w": 27, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "829_2": { - "frame": { "x": 270, "y": 231, "w": 17, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 6, "w": 17, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "829_3": { - "frame": { "x": 122, "y": 271, "w": 17, "h": 18 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 6, "w": 17, "h": 18 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "830_2": { - "frame": { "x": 42, "y": 226, "w": 19, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 3, "w": 19, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "830_3": { - "frame": { "x": 233, "y": 218, "w": 19, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 3, "w": 19, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "835_2": { - "frame": { "x": 211, "y": 218, "w": 22, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 22, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "835_3": { - "frame": { "x": 0, "y": 211, "w": 22, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 22, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "836_2": { - "frame": { "x": 189, "y": 206, "w": 22, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 4, "w": 22, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "836_3": { - "frame": { "x": 138, "y": 205, "w": 22, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 4, "w": 22, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "850_2": { - "frame": { "x": 194, "y": 276, "w": 21, "h": 10 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 10, "w": 21, "h": 10 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "850_3": { - "frame": { "x": 233, "y": 275, "w": 21, "h": 10 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 10, "w": 21, "h": 10 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "851_2": { - "frame": { "x": 113, "y": 0, "w": 37, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 1, "y": 0, "w": 37, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "851_3": { - "frame": { "x": 76, "y": 0, "w": 37, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 1, "y": 0, "w": 37, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "854_2": { - "frame": { "x": 98, "y": 274, "w": 17, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 8, "w": 17, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "854_3": { - "frame": { "x": 177, "y": 272, "w": 17, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 8, "w": 17, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "855_2": { - "frame": { "x": 116, "y": 187, "w": 22, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 3, "w": 22, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "855_3": { - "frame": { "x": 167, "y": 187, "w": 22, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 3, "w": 22, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "856_2": { - "frame": { "x": 127, "y": 227, "w": 19, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 3, "w": 19, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "856_3": { - "frame": { "x": 182, "y": 228, "w": 19, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 3, "w": 19, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "857_2": { - "frame": { "x": 312, "y": 206, "w": 22, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 4, "w": 22, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "857_3": { - "frame": { "x": 44, "y": 204, "w": 22, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 4, "w": 22, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "858-gigantamax_2": { - "frame": { "x": 273, "y": 28, "w": 29, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 0, "w": 29, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "858-gigantamax_3": { - "frame": { "x": 244, "y": 28, "w": 29, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 0, "w": 29, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "858_2": { - "frame": { "x": 47, "y": 179, "w": 22, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 2, "w": 22, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "858_3": { - "frame": { "x": 74, "y": 161, "w": 22, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 2, "w": 22, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "859_2": { - "frame": { "x": 326, "y": 270, "w": 17, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 5, "w": 17, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "859_3": { - "frame": { "x": 0, "y": 271, "w": 17, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 5, "w": 17, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "860_2": { - "frame": { "x": 22, "y": 184, "w": 22, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 3, "w": 22, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "860_3": { - "frame": { "x": 69, "y": 186, "w": 22, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 3, "w": 22, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "861-gigantamax_2": { - "frame": { "x": 0, "y": 57, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "861-gigantamax_3": { - "frame": { "x": 302, "y": 55, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "861_2": { - "frame": { "x": 286, "y": 85, "w": 25, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 2, "w": 25, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "861_3": { - "frame": { "x": 72, "y": 83, "w": 25, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 2, "w": 25, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "863_2": { - "frame": { "x": 22, "y": 207, "w": 20, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 3, "w": 20, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "863_3": { - "frame": { "x": 360, "y": 112, "w": 20, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 3, "w": 20, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "864_2": { - "frame": { "x": 94, "y": 30, "w": 30, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 1, "w": 30, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "864_3": { - "frame": { "x": 151, "y": 30, "w": 30, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 1, "w": 30, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "867_2": { - "frame": { "x": 32, "y": 30, "w": 31, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 1, "w": 31, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "867_3": { - "frame": { "x": 63, "y": 30, "w": 31, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 1, "w": 31, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "872_1": { - "frame": { "x": 282, "y": 272, "w": 17, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 8, "w": 17, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "872_2": { - "frame": { "x": 216, "y": 274, "w": 17, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 8, "w": 17, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "872_3": { - "frame": { "x": 17, "y": 274, "w": 17, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 8, "w": 17, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "873_1": { - "frame": { "x": 243, "y": 178, "w": 25, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 4, "w": 25, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "873_2": { - "frame": { "x": 218, "y": 178, "w": 25, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 4, "w": 25, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "873_3": { - "frame": { "x": 270, "y": 162, "w": 25, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 4, "w": 25, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "876-female_2": { - "frame": { "x": 350, "y": 184, "w": 22, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 3, "w": 22, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "876-female_3": { - "frame": { "x": 268, "y": 184, "w": 22, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 3, "w": 22, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "876_2": { - "frame": { "x": 268, "y": 207, "w": 19, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 3, "w": 19, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "876_3": { - "frame": { "x": 66, "y": 209, "w": 19, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 3, "w": 19, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "877-hangry_1": { - "frame": { "x": 105, "y": 253, "w": 17, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 4, "w": 17, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "877-hangry_2": { - "frame": { "x": 249, "y": 254, "w": 17, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 4, "w": 17, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "877-hangry_3": { - "frame": { "x": 199, "y": 255, "w": 17, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 4, "w": 17, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "877_1": { - "frame": { "x": 59, "y": 256, "w": 17, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 4, "w": 17, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "877_2": { - "frame": { "x": 0, "y": 250, "w": 17, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 4, "w": 17, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "877_3": { - "frame": { "x": 17, "y": 253, "w": 17, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 4, "w": 17, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "880_2": { - "frame": { "x": 244, "y": 156, "w": 26, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 4, "w": 26, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "880_3": { - "frame": { "x": 218, "y": 156, "w": 26, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 4, "w": 26, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "881_2": { - "frame": { "x": 252, "y": 231, "w": 18, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 3, "w": 18, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "881_3": { - "frame": { "x": 61, "y": 233, "w": 18, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 3, "w": 18, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "882_2": { - "frame": { "x": 328, "y": 183, "w": 22, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 3, "w": 22, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "882_3": { - "frame": { "x": 145, "y": 182, "w": 22, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 3, "w": 22, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "883_2": { - "frame": { "x": 357, "y": 207, "w": 23, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 4, "w": 23, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "883_3": { - "frame": { "x": 334, "y": 207, "w": 23, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 4, "w": 23, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "884-gigantamax_2": { - "frame": { "x": 124, "y": 30, "w": 27, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 0, "w": 27, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "884-gigantamax_3": { - "frame": { "x": 181, "y": 30, "w": 27, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 0, "w": 27, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "884_2": { - "frame": { "x": 123, "y": 162, "w": 22, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 2, "w": 22, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "884_3": { - "frame": { "x": 0, "y": 163, "w": 22, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 2, "w": 22, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "885_1": { - "frame": { "x": 201, "y": 238, "w": 24, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 24, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "885_2": { - "frame": { "x": 225, "y": 241, "w": 24, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 24, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "885_3": { - "frame": { "x": 309, "y": 248, "w": 24, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 6, "w": 24, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "886_1": { - "frame": { "x": 308, "y": 112, "w": 26, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 3, "w": 26, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "886_2": { - "frame": { "x": 125, "y": 111, "w": 26, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 3, "w": 26, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "886_3": { - "frame": { "x": 177, "y": 112, "w": 26, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 3, "w": 26, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "887_1": { - "frame": { "x": 86, "y": 57, "w": 30, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 2, "w": 30, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "887_2": { - "frame": { "x": 56, "y": 57, "w": 30, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 2, "w": 30, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "887_3": { - "frame": { "x": 26, "y": 57, "w": 30, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 2, "w": 30, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "888-crowned_2": { - "frame": { "x": 182, "y": 0, "w": 32, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 0, "w": 32, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "888-crowned_3": { - "frame": { "x": 150, "y": 0, "w": 32, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 0, "w": 32, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "888_2": { - "frame": { "x": 167, "y": 89, "w": 28, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 3, "w": 28, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "888_3": { - "frame": { "x": 311, "y": 89, "w": 28, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 3, "w": 28, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "889-crowned_2": { - "frame": { "x": 214, "y": 0, "w": 34, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 3, "y": 1, "w": 34, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "889-crowned_3": { - "frame": { "x": 248, "y": 0, "w": 34, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 3, "y": 1, "w": 34, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "889_2": { - "frame": { "x": 260, "y": 58, "w": 26, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 1, "w": 26, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "889_3": { - "frame": { "x": 234, "y": 58, "w": 26, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 1, "w": 26, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "890-eternamax_2": { - "frame": { "x": 0, "y": 0, "w": 38, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 1, "y": 0, "w": 38, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "890-eternamax_3": { - "frame": { "x": 38, "y": 0, "w": 38, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 1, "y": 0, "w": 38, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "890_2": { - "frame": { "x": 282, "y": 0, "w": 33, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 3, "y": 1, "w": 33, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "890_3": { - "frame": { "x": 315, "y": 0, "w": 33, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 3, "y": 1, "w": 33, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "891_1": { - "frame": { "x": 164, "y": 249, "w": 18, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 4, "w": 18, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "891_2": { - "frame": { "x": 270, "y": 249, "w": 18, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 4, "w": 18, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "891_3": { - "frame": { "x": 41, "y": 249, "w": 18, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 4, "w": 18, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "892-gigantamax-rapid_1": { - "frame": { "x": 284, "y": 111, "w": 24, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 24, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "892-gigantamax-rapid_2": { - "frame": { "x": 0, "y": 112, "w": 24, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 24, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "892-gigantamax-rapid_3": { - "frame": { "x": 24, "y": 112, "w": 24, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 24, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "892-gigantamax-single_1": { - "frame": { "x": 26, "y": 83, "w": 23, "h": 29 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 0, "w": 23, "h": 29 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "892-gigantamax-single_2": { - "frame": { "x": 49, "y": 83, "w": 23, "h": 29 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 0, "w": 23, "h": 29 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "892-gigantamax-single_3": { - "frame": { "x": 352, "y": 60, "w": 23, "h": 29 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 0, "w": 23, "h": 29 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "892-rapid-strike_1": { - "frame": { "x": 48, "y": 157, "w": 26, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 4, "w": 26, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "892-rapid-strike_2": { - "frame": { "x": 97, "y": 160, "w": 26, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 4, "w": 26, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "892-rapid-strike_3": { - "frame": { "x": 145, "y": 160, "w": 26, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 4, "w": 26, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "892_1": { - "frame": { "x": 356, "y": 136, "w": 23, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 23, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "892_2": { - "frame": { "x": 284, "y": 137, "w": 23, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 23, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "892_3": { - "frame": { "x": 0, "y": 138, "w": 23, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 2, "w": 23, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "896_1": { - "frame": { "x": 97, "y": 136, "w": 24, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 3, "w": 24, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "896_2": { - "frame": { "x": 145, "y": 136, "w": 24, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 3, "w": 24, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "896_3": { - "frame": { "x": 169, "y": 136, "w": 24, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 3, "w": 24, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "897_1": { - "frame": { "x": 151, "y": 112, "w": 26, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 3, "w": 26, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "897_2": { - "frame": { "x": 97, "y": 112, "w": 26, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 3, "w": 26, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "897_3": { - "frame": { "x": 334, "y": 112, "w": 26, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 3, "w": 26, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "898-ice_1": { - "frame": { "x": 328, "y": 60, "w": 24, "h": 29 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 0, "w": 24, "h": 29 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "898-ice_2": { - "frame": { "x": 116, "y": 60, "w": 24, "h": 29 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 0, "w": 24, "h": 29 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "898-ice_3": { - "frame": { "x": 177, "y": 60, "w": 24, "h": 29 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 0, "w": 24, "h": 29 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "898-shadow_1": { - "frame": { "x": 151, "y": 57, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "898-shadow_2": { - "frame": { "x": 208, "y": 58, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "898-shadow_3": { - "frame": { "x": 334, "y": 30, "w": 26, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 0, "w": 26, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "898_1": { - "frame": { "x": 351, "y": 228, "w": 19, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 4, "w": 19, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "898_2": { - "frame": { "x": 22, "y": 231, "w": 19, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 4, "w": 19, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "898_3": { - "frame": { "x": 107, "y": 231, "w": 19, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 4, "w": 19, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "900_2": { - "frame": { "x": 0, "y": 87, "w": 25, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 3, "w": 25, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "900_3": { - "frame": { "x": 72, "y": 109, "w": 25, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 3, "w": 25, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "901_2": { - "frame": { "x": 256, "y": 110, "w": 28, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 5, "w": 28, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "901_3": { - "frame": { "x": 339, "y": 89, "w": 28, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 5, "w": 28, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "903_2": { - "frame": { "x": 307, "y": 160, "w": 21, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 1, "w": 21, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "903_3": { - "frame": { "x": 171, "y": 160, "w": 21, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 1, "w": 21, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - } - }, - "meta": { - "app": "https://www.aseprite.org/", - "version": "1.3.7-dev", - "image": "pokemon_icons_8v.png", - "format": "RGBA8888", - "size": { "w": 380, "h": 293 }, - "scale": "1" - } +{ + "textures": [ + { + "image": "pokemon_icons_8v.png", + "format": "RGBA8888", + "size": { + "w": 510, + "h": 510 + }, + "scale": 1, + "frames": [ + { + "filename": "816_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "816_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "817_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "817_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "818-gigantamax_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "818-gigantamax_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "818_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "818_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "821_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "821_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "822_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "822_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "823-gigantamax_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "823-gigantamax_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "823_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "823_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "829_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "829_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "830_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "830_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "835_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "835_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "836_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "836_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "850_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "850_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "851-gigantamax", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "851-gigantamax_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "851-gigantamax_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "851_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "851_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "851s-gigantamax", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "854_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "854_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "855_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "855_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "856_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "856_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "857_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "857_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "858-gigantamax_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "858-gigantamax_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "858_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "858_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "859_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "859_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "860_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "860_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "861-gigantamax_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "861-gigantamax_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "861_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "861_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "863_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "863_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "864_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "864_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "867_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "867_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "872_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "872_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "872_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "873_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "873_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "873_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "876-female_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "876-female_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "876_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "876_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "877-hangry_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "877-hangry_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "877-hangry_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "877_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "877_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "877_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "880_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "880_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "881_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "881_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "882_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "882_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "883_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "883_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "884-gigantamax_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "884-gigantamax_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "884_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "884_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "885_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "885_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "885_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "886_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "886_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "886_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "887_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "887_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "887_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "888-crowned_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "888-crowned_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "888_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "888_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "889-crowned_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "889-crowned_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "889_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "889_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "890-eternamax_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "890-eternamax_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "890_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "890_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "891_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "891_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "891_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "892-gigantamax-rapid_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "892-gigantamax-rapid_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "892-gigantamax-rapid_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "892-gigantamax-single_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "892-gigantamax-single_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "892-gigantamax-single_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "892-rapid-strike_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "892-rapid-strike_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "892-rapid-strike_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "892_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "892_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "892_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "894_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "894_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "895_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "895_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "896_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "896_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "896_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "897_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "897_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "897_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "898-ice_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "898-ice_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "898-ice_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "898-shadow_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "898-shadow_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "898-shadow_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "898_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "898_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "898_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "900_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "900_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "901_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "901_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "903_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "903_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "4052_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "4052_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "4077_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "4077_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "4078_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "4078_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "4079_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "4079_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "4080_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "4080_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "4080_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "4144_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "4144_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "4145_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "4145_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "4146_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "4146_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "4199_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "4199_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "4199_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "4222_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "4222_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "4263_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "4263_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "4264_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "4264_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "4562_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "4562_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "6100_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "6100_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "6101_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "6101_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "6215_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "6215_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "6503_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "6503_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "6549_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "6549_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "6570_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "6570_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "6571_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "6571_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "6705_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "6705_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "6706_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 440, + "y": 450, + "w": 40, + "h": 30 + } + }, + { + "filename": "6706_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "6713_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 480, + "w": 40, + "h": 30 + } + }, + { + "filename": "6713_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 480, + "w": 40, + "h": 30 + } + } + ] + } + ], + "meta": { + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0", + "smartupdate": "$TexturePacker:SmartUpdate:c6192164d1b1971f54a6c5864e11748d:46b3adcf2a25bfb824db3d24cd1c96a9:ec5f05e7f30cd98f74db0c2326109fd3$" + } } diff --git a/public/images/pokemon_icons_8v.png b/public/images/pokemon_icons_8v.png index 1968bfe6214..2af86ac656f 100644 Binary files a/public/images/pokemon_icons_8v.png and b/public/images/pokemon_icons_8v.png differ diff --git a/public/images/pokemon_icons_9.json b/public/images/pokemon_icons_9.json index 26e28eedae0..01994a41a02 100644 --- a/public/images/pokemon_icons_9.json +++ b/public/images/pokemon_icons_9.json @@ -4,8 +4,8 @@ "image": "pokemon_icons_9.png", "format": "RGBA8888", "size": { - "w": 252, - "h": 591 + "w": 255, + "h": 646 }, "scale": 1, "frames": [ @@ -382,7 +382,7 @@ }, "frame": { "x": 0, - "y": 270, + "y": 300, "w": 30, "h": 30 } @@ -429,27 +429,6 @@ "h": 27 } }, - { - "filename": "8901", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 5, - "y": 1, - "w": 30, - "h": 28 - }, - "frame": { - "x": 222, - "y": 0, - "w": 30, - "h": 28 - } - }, { "filename": "1020", "rotated": false, @@ -528,12 +507,33 @@ "h": 26 }, "frame": { - "x": 126, - "y": 28, + "x": 222, + "y": 0, "w": 32, "h": 26 } }, + { + "filename": "8901", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 5, + "y": 1, + "w": 30, + "h": 28 + }, + "frame": { + "x": 0, + "y": 330, + "w": 30, + "h": 28 + } + }, { "filename": "8901s", "rotated": false, @@ -550,7 +550,7 @@ }, "frame": { "x": 0, - "y": 300, + "y": 358, "w": 30, "h": 28 } @@ -571,7 +571,7 @@ }, "frame": { "x": 0, - "y": 328, + "y": 386, "w": 27, "h": 30 } @@ -592,7 +592,7 @@ }, "frame": { "x": 0, - "y": 358, + "y": 416, "w": 27, "h": 30 } @@ -611,6 +611,27 @@ "w": 32, "h": 25 }, + "frame": { + "x": 126, + "y": 28, + "w": 32, + "h": 25 + } + }, + { + "filename": "984s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 4, + "y": 3, + "w": 32, + "h": 25 + }, "frame": { "x": 158, "y": 27, @@ -619,7 +640,7 @@ } }, { - "filename": "984s", + "filename": "1014", "rotated": false, "trimmed": true, "sourceSize": { @@ -640,7 +661,7 @@ } }, { - "filename": "992", + "filename": "1014s", "rotated": false, "trimmed": true, "sourceSize": { @@ -648,16 +669,16 @@ "h": 30 }, "spriteSourceSize": { - "x": 6, - "y": 2, - "w": 30, - "h": 26 + "x": 4, + "y": 3, + "w": 32, + "h": 25 }, "frame": { "x": 222, - "y": 28, - "w": 30, - "h": 26 + "y": 26, + "w": 32, + "h": 25 } }, { @@ -676,7 +697,7 @@ }, "frame": { "x": 0, - "y": 388, + "y": 446, "w": 27, "h": 29 } @@ -697,7 +718,7 @@ }, "frame": { "x": 0, - "y": 417, + "y": 475, "w": 27, "h": 29 } @@ -718,7 +739,7 @@ }, "frame": { "x": 0, - "y": 446, + "y": 504, "w": 29, "h": 28 } @@ -739,7 +760,7 @@ }, "frame": { "x": 0, - "y": 474, + "y": 532, "w": 29, "h": 28 } @@ -760,7 +781,7 @@ }, "frame": { "x": 0, - "y": 502, + "y": 560, "w": 29, "h": 27 } @@ -781,7 +802,7 @@ }, "frame": { "x": 0, - "y": 529, + "y": 587, "w": 29, "h": 27 } @@ -802,7 +823,7 @@ }, "frame": { "x": 0, - "y": 556, + "y": 614, "w": 28, "h": 28 } @@ -828,90 +849,6 @@ "h": 21 } }, - { - "filename": "975s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 4, - "y": 7, - "w": 32, - "h": 21 - }, - "frame": { - "x": 126, - "y": 54, - "w": 32, - "h": 21 - } - }, - { - "filename": "1014", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 4, - "y": 3, - "w": 32, - "h": 25 - }, - "frame": { - "x": 158, - "y": 52, - "w": 32, - "h": 25 - } - }, - { - "filename": "1014s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 4, - "y": 3, - "w": 32, - "h": 25 - }, - "frame": { - "x": 190, - "y": 52, - "w": 32, - "h": 25 - } - }, - { - "filename": "992s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 6, - "y": 2, - "w": 30, - "h": 26 - }, - "frame": { - "x": 222, - "y": 54, - "w": 30, - "h": 26 - } - }, { "filename": "1024-terastal", "rotated": false, @@ -926,11 +863,95 @@ "w": 32, "h": 22 }, + "frame": { + "x": 126, + "y": 53, + "w": 32, + "h": 22 + } + }, + { + "filename": "1025", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 4, + "y": 4, + "w": 32, + "h": 24 + }, + "frame": { + "x": 158, + "y": 52, + "w": 32, + "h": 24 + } + }, + { + "filename": "1025s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 4, + "y": 4, + "w": 32, + "h": 24 + }, + "frame": { + "x": 190, + "y": 52, + "w": 32, + "h": 24 + } + }, + { + "filename": "992", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 6, + "y": 2, + "w": 30, + "h": 26 + }, + "frame": { + "x": 222, + "y": 51, + "w": 30, + "h": 26 + } + }, + { + "filename": "975s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 4, + "y": 7, + "w": 32, + "h": 21 + }, "frame": { "x": 93, "y": 75, "w": 32, - "h": 22 + "h": 21 } }, { @@ -955,7 +976,7 @@ } }, { - "filename": "1025", + "filename": "992s", "rotated": false, "trimmed": true, "sourceSize": { @@ -963,37 +984,16 @@ "h": 30 }, "spriteSourceSize": { - "x": 4, - "y": 4, - "w": 32, - "h": 24 + "x": 6, + "y": 2, + "w": 30, + "h": 26 }, "frame": { "x": 157, - "y": 77, - "w": 32, - "h": 24 - } - }, - { - "filename": "1025s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 4, - "y": 4, - "w": 32, - "h": 24 - }, - "frame": { - "x": 189, - "y": 77, - "w": 32, - "h": 24 + "y": 76, + "w": 30, + "h": 26 } }, { @@ -1011,8 +1011,29 @@ "h": 25 }, "frame": { - "x": 221, - "y": 80, + "x": 187, + "y": 76, + "w": 30, + "h": 25 + } + }, + { + "filename": "993s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 6, + "y": 2, + "w": 30, + "h": 25 + }, + "frame": { + "x": 217, + "y": 77, "w": 30, "h": 25 } @@ -1033,7 +1054,7 @@ }, "frame": { "x": 27, - "y": 328, + "y": 386, "w": 23, "h": 30 } @@ -1054,7 +1075,7 @@ }, "frame": { "x": 27, - "y": 358, + "y": 416, "w": 23, "h": 30 } @@ -1075,7 +1096,7 @@ }, "frame": { "x": 27, - "y": 388, + "y": 446, "w": 25, "h": 30 } @@ -1096,7 +1117,7 @@ }, "frame": { "x": 27, - "y": 418, + "y": 476, "w": 25, "h": 28 } @@ -1117,7 +1138,7 @@ }, "frame": { "x": 29, - "y": 446, + "y": 504, "w": 25, "h": 30 } @@ -1138,7 +1159,7 @@ }, "frame": { "x": 29, - "y": 476, + "y": 534, "w": 25, "h": 28 } @@ -1159,7 +1180,7 @@ }, "frame": { "x": 29, - "y": 504, + "y": 562, "w": 26, "h": 28 } @@ -1180,7 +1201,7 @@ }, "frame": { "x": 29, - "y": 532, + "y": 590, "w": 27, "h": 26 } @@ -1201,32 +1222,11 @@ }, "frame": { "x": 28, - "y": 558, + "y": 616, "w": 28, "h": 28 } }, - { - "filename": "993s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 6, - "y": 2, - "w": 30, - "h": 25 - }, - "frame": { - "x": 62, - "y": 86, - "w": 30, - "h": 25 - } - }, { "filename": "924", "rotated": false, @@ -1242,8 +1242,8 @@ "h": 20 }, "frame": { - "x": 92, - "y": 97, + "x": 62, + "y": 86, "w": 29, "h": 20 } @@ -1263,8 +1263,8 @@ "h": 20 }, "frame": { - "x": 121, - "y": 97, + "x": 61, + "y": 106, "w": 29, "h": 20 } @@ -1284,8 +1284,8 @@ "h": 22 }, "frame": { - "x": 150, - "y": 101, + "x": 91, + "y": 96, "w": 29, "h": 22 } @@ -1305,33 +1305,12 @@ "h": 22 }, "frame": { - "x": 179, - "y": 101, + "x": 120, + "y": 97, "w": 29, "h": 22 } }, - { - "filename": "935", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 13, - "y": 7, - "w": 13, - "h": 21 - }, - "frame": { - "x": 208, - "y": 101, - "w": 13, - "h": 21 - } - }, { "filename": "925-three", "rotated": false, @@ -1347,8 +1326,8 @@ "h": 20 }, "frame": { - "x": 221, - "y": 105, + "x": 149, + "y": 102, "w": 29, "h": 20 } @@ -1368,54 +1347,12 @@ "h": 20 }, "frame": { - "x": 61, - "y": 111, + "x": 90, + "y": 118, "w": 29, "h": 20 } }, - { - "filename": "976", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 5, - "y": 10, - "w": 29, - "h": 18 - }, - "frame": { - "x": 90, - "y": 117, - "w": 29, - "h": 18 - } - }, - { - "filename": "976s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 5, - "y": 10, - "w": 29, - "h": 18 - }, - "frame": { - "x": 119, - "y": 117, - "w": 29, - "h": 18 - } - }, { "filename": "1022", "rotated": false, @@ -1431,8 +1368,8 @@ "h": 25 }, "frame": { - "x": 148, - "y": 123, + "x": 119, + "y": 119, "w": 29, "h": 25 } @@ -1452,12 +1389,33 @@ "h": 25 }, "frame": { - "x": 177, - "y": 123, + "x": 148, + "y": 122, "w": 29, "h": 25 } }, + { + "filename": "976", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 5, + "y": 10, + "w": 29, + "h": 18 + }, + "frame": { + "x": 31, + "y": 118, + "w": 29, + "h": 18 + } + }, { "filename": "8128-blaze", "rotated": false, @@ -1473,54 +1431,12 @@ "h": 27 }, "frame": { - "x": 206, - "y": 125, + "x": 30, + "y": 136, "w": 29, "h": 27 } }, - { - "filename": "913", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 11, - "y": 5, - "w": 17, - "h": 23 - }, - "frame": { - "x": 235, - "y": 125, - "w": 17, - "h": 23 - } - }, - { - "filename": "913s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 11, - "y": 5, - "w": 17, - "h": 23 - }, - "frame": { - "x": 235, - "y": 148, - "w": 17, - "h": 23 - } - }, { "filename": "8128s-blaze", "rotated": false, @@ -1536,8 +1452,8 @@ "h": 27 }, "frame": { - "x": 31, - "y": 118, + "x": 30, + "y": 163, "w": 29, "h": 27 } @@ -1558,7 +1474,7 @@ }, "frame": { "x": 30, - "y": 145, + "y": 190, "w": 27, "h": 28 } @@ -1579,7 +1495,7 @@ }, "frame": { "x": 30, - "y": 173, + "y": 218, "w": 27, "h": 28 } @@ -1600,7 +1516,7 @@ }, "frame": { "x": 30, - "y": 201, + "y": 246, "w": 26, "h": 28 } @@ -1621,7 +1537,7 @@ }, "frame": { "x": 30, - "y": 229, + "y": 274, "w": 27, "h": 26 } @@ -1642,7 +1558,7 @@ }, "frame": { "x": 30, - "y": 255, + "y": 300, "w": 25, "h": 27 } @@ -1663,13 +1579,13 @@ }, "frame": { "x": 30, - "y": 282, + "y": 327, "w": 25, "h": 27 } }, { - "filename": "916", + "filename": "964-hero", "rotated": false, "trimmed": true, "sourceSize": { @@ -1677,20 +1593,20 @@ "h": 30 }, "spriteSourceSize": { - "x": 7, - "y": 9, - "w": 25, - "h": 19 + "x": 9, + "y": 0, + "w": 22, + "h": 29 }, "frame": { "x": 30, - "y": 309, - "w": 25, - "h": 19 + "y": 354, + "w": 22, + "h": 29 } }, { - "filename": "911", + "filename": "976s", "rotated": false, "trimmed": true, "sourceSize": { @@ -1698,16 +1614,16 @@ "h": 30 }, "spriteSourceSize": { - "x": 6, - "y": 5, - "w": 28, - "h": 23 + "x": 5, + "y": 10, + "w": 29, + "h": 18 }, "frame": { "x": 60, - "y": 131, - "w": 28, - "h": 23 + "y": 126, + "w": 29, + "h": 18 } }, { @@ -1724,9 +1640,51 @@ "w": 28, "h": 24 }, + "frame": { + "x": 59, + "y": 144, + "w": 28, + "h": 24 + } + }, + { + "filename": "911", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 6, + "y": 5, + "w": 28, + "h": 23 + }, + "frame": { + "x": 59, + "y": 168, + "w": 28, + "h": 23 + } + }, + { + "filename": "8128s-aqua", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 5, + "w": 28, + "h": 24 + }, "frame": { "x": 57, - "y": 154, + "y": 191, "w": 28, "h": 24 } @@ -1747,13 +1705,13 @@ }, "frame": { "x": 57, - "y": 178, + "y": 215, "w": 28, "h": 23 } }, { - "filename": "968", + "filename": "950", "rotated": false, "trimmed": true, "sourceSize": { @@ -1761,37 +1719,58 @@ "h": 30 }, "spriteSourceSize": { - "x": 8, - "y": 0, - "w": 23, - "h": 28 - }, - "frame": { - "x": 56, - "y": 201, - "w": 23, - "h": 28 - } - }, - { - "filename": "964-hero", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 9, - "y": 0, - "w": 22, - "h": 29 + "x": 6, + "y": 11, + "w": 28, + "h": 17 }, "frame": { "x": 57, - "y": 229, - "w": 22, - "h": 29 + "y": 238, + "w": 28, + "h": 17 + } + }, + { + "filename": "916", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 7, + "y": 9, + "w": 25, + "h": 19 + }, + "frame": { + "x": 56, + "y": 255, + "w": 25, + "h": 19 + } + }, + { + "filename": "998", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 7, + "y": 2, + "w": 25, + "h": 26 + }, + "frame": { + "x": 57, + "y": 274, + "w": 25, + "h": 26 } }, { @@ -1810,13 +1789,55 @@ }, "frame": { "x": 55, - "y": 258, + "y": 300, "w": 22, "h": 29 } }, { - "filename": "999", + "filename": "914", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 8, + "y": 3, + "w": 24, + "h": 25 + }, + "frame": { + "x": 55, + "y": 329, + "w": 24, + "h": 25 + } + }, + { + "filename": "968", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 8, + "y": 0, + "w": 23, + "h": 28 + }, + "frame": { + "x": 52, + "y": 354, + "w": 23, + "h": 28 + } + }, + { + "filename": "954", "rotated": false, "trimmed": true, "sourceSize": { @@ -1826,16 +1847,100 @@ "spriteSourceSize": { "x": 9, "y": 0, - "w": 22, + "w": 21, "h": 29 }, "frame": { - "x": 55, - "y": 287, - "w": 22, + "x": 77, + "y": 300, + "w": 21, "h": 29 } }, + { + "filename": "908", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 2, + "w": 20, + "h": 26 + }, + "frame": { + "x": 79, + "y": 329, + "w": 20, + "h": 26 + } + }, + { + "filename": "1016", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 8, + "y": 1, + "w": 24, + "h": 27 + }, + "frame": { + "x": 75, + "y": 355, + "w": 24, + "h": 27 + } + }, + { + "filename": "950s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 6, + "y": 11, + "w": 28, + "h": 17 + }, + "frame": { + "x": 89, + "y": 138, + "w": 28, + "h": 17 + } + }, + { + "filename": "968s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 8, + "y": 0, + "w": 23, + "h": 28 + }, + "frame": { + "x": 87, + "y": 155, + "w": 23, + "h": 28 + } + }, { "filename": "990", "rotated": false, @@ -1851,8 +1956,8 @@ "h": 23 }, "frame": { - "x": 88, - "y": 135, + "x": 117, + "y": 144, "w": 28, "h": 23 } @@ -1872,33 +1977,12 @@ "h": 23 }, "frame": { - "x": 116, - "y": 135, + "x": 145, + "y": 147, "w": 28, "h": 23 } }, - { - "filename": "8128s-aqua", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 10, - "y": 5, - "w": 28, - "h": 24 - }, - "frame": { - "x": 85, - "y": 158, - "w": 28, - "h": 24 - } - }, { "filename": "972", "rotated": false, @@ -1914,8 +1998,8 @@ "h": 22 }, "frame": { - "x": 113, - "y": 158, + "x": 110, + "y": 167, "w": 27, "h": 22 } @@ -1935,14 +2019,14 @@ "h": 22 }, "frame": { - "x": 85, - "y": 182, + "x": 137, + "y": 170, "w": 27, "h": 22 } }, { - "filename": "968s", + "filename": "947", "rotated": false, "trimmed": true, "sourceSize": { @@ -1951,36 +2035,15 @@ }, "spriteSourceSize": { "x": 8, - "y": 0, + "y": 6, "w": 23, - "h": 28 + "h": 22 }, "frame": { - "x": 79, - "y": 204, + "x": 87, + "y": 183, "w": 23, - "h": 28 - } - }, - { - "filename": "998", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 7, - "y": 2, - "w": 25, - "h": 26 - }, - "frame": { - "x": 79, - "y": 232, - "w": 25, - "h": 26 + "h": 22 } }, { @@ -1998,14 +2061,14 @@ "h": 26 }, "frame": { - "x": 77, - "y": 258, + "x": 85, + "y": 205, "w": 25, "h": 26 } }, { - "filename": "999s", + "filename": "985", "rotated": false, "trimmed": true, "sourceSize": { @@ -2014,120 +2077,15 @@ }, "spriteSourceSize": { "x": 9, - "y": 0, - "w": 22, - "h": 29 + "y": 7, + "w": 27, + "h": 21 }, "frame": { - "x": 77, - "y": 284, - "w": 22, - "h": 29 - } - }, - { - "filename": "936", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 10, - "y": 0, - "w": 20, - "h": 28 - }, - "frame": { - "x": 102, - "y": 204, - "w": 20, - "h": 28 - } - }, - { - "filename": "908", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 10, - "y": 2, - "w": 20, - "h": 26 - }, - "frame": { - "x": 104, - "y": 232, - "w": 20, - "h": 26 - } - }, - { - "filename": "982", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 10, - "y": 2, - "w": 22, - "h": 26 - }, - "frame": { - "x": 102, - "y": 258, - "w": 22, - "h": 26 - } - }, - { - "filename": "1016", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 8, - "y": 1, - "w": 24, - "h": 27 - }, - "frame": { - "x": 99, - "y": 284, - "w": 24, - "h": 27 - } - }, - { - "filename": "1017-hearthflame-mask", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 7, - "y": 4, - "w": 25, - "h": 24 - }, - "frame": { - "x": 113, - "y": 180, - "w": 25, - "h": 24 + "x": 110, + "y": 189, + "w": 27, + "h": 21 } }, { @@ -2145,77 +2103,14 @@ "h": 24 }, "frame": { - "x": 113, - "y": 180, + "x": 85, + "y": 231, "w": 25, "h": 24 } }, { - "filename": "1017s-hearthflame-mask", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 7, - "y": 4, - "w": 25, - "h": 24 - }, - "frame": { - "x": 113, - "y": 180, - "w": 25, - "h": 24 - } - }, - { - "filename": "1017s-hearthflame-mask-tera", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 7, - "y": 4, - "w": 25, - "h": 24 - }, - "frame": { - "x": 113, - "y": 180, - "w": 25, - "h": 24 - } - }, - { - "filename": "936s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 10, - "y": 0, - "w": 20, - "h": 28 - }, - "frame": { - "x": 122, - "y": 204, - "w": 20, - "h": 28 - } - }, - { - "filename": "954", + "filename": "999", "rotated": false, "trimmed": true, "sourceSize": { @@ -2225,18 +2120,18 @@ "spriteSourceSize": { "x": 9, "y": 0, - "w": 21, + "w": 22, "h": 29 }, "frame": { - "x": 124, - "y": 232, - "w": 21, + "x": 110, + "y": 210, + "w": 22, "h": 29 } }, { - "filename": "914", + "filename": "916s", "rotated": false, "trimmed": true, "sourceSize": { @@ -2244,57 +2139,57 @@ "h": 30 }, "spriteSourceSize": { - "x": 8, - "y": 3, - "w": 24, - "h": 25 - }, - "frame": { - "x": 124, - "y": 261, - "w": 24, - "h": 25 - } - }, - { - "filename": "914s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 8, - "y": 3, - "w": 24, - "h": 25 - }, - "frame": { - "x": 123, - "y": 286, - "w": 24, - "h": 25 - } - }, - { - "filename": "916-female", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 6, - "y": 7, + "x": 7, + "y": 9, "w": 25, + "h": 19 + }, + "frame": { + "x": 81, + "y": 255, + "w": 25, + "h": 19 + } + }, + { + "filename": "982", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 2, + "w": 22, + "h": 26 + }, + "frame": { + "x": 82, + "y": 274, + "w": 22, + "h": 26 + } + }, + { + "filename": "985s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 9, + "y": 7, + "w": 27, "h": 21 }, "frame": { - "x": 55, - "y": 316, - "w": 25, + "x": 137, + "y": 192, + "w": 27, "h": 21 } }, @@ -2313,14 +2208,182 @@ "h": 27 }, "frame": { - "x": 50, - "y": 337, + "x": 132, + "y": 213, "w": 24, "h": 27 } }, { - "filename": "987", + "filename": "917", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 9, + "y": 6, + "w": 22, + "h": 22 + }, + "frame": { + "x": 110, + "y": 239, + "w": 22, + "h": 22 + } + }, + { + "filename": "914s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 8, + "y": 3, + "w": 24, + "h": 25 + }, + "frame": { + "x": 132, + "y": 240, + "w": 24, + "h": 25 + } + }, + { + "filename": "956", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 7, + "y": 6, + "w": 26, + "h": 22 + }, + "frame": { + "x": 106, + "y": 261, + "w": 26, + "h": 22 + } + }, + { + "filename": "916-female", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 6, + "y": 7, + "w": 25, + "h": 21 + }, + "frame": { + "x": 132, + "y": 265, + "w": 25, + "h": 21 + } + }, + { + "filename": "1002", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 6, + "y": 7, + "w": 27, + "h": 21 + }, + "frame": { + "x": 104, + "y": 283, + "w": 27, + "h": 21 + } + }, + { + "filename": "956s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 7, + "y": 6, + "w": 26, + "h": 22 + }, + "frame": { + "x": 131, + "y": 286, + "w": 26, + "h": 22 + } + }, + { + "filename": "1017-hearthflame-mask", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 7, + "y": 4, + "w": 25, + "h": 24 + }, + "frame": { + "x": 98, + "y": 304, + "w": 25, + "h": 24 + } + }, + { + "filename": "999s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 9, + "y": 0, + "w": 22, + "h": 29 + }, + "frame": { + "x": 99, + "y": 328, + "w": 22, + "h": 29 + } + }, + { + "filename": "982s", "rotated": false, "trimmed": true, "sourceSize": { @@ -2329,15 +2392,36 @@ }, "spriteSourceSize": { "x": 10, - "y": 4, - "w": 24, - "h": 24 + "y": 2, + "w": 22, + "h": 26 }, "frame": { - "x": 50, - "y": 364, - "w": 24, - "h": 24 + "x": 99, + "y": 357, + "w": 22, + "h": 26 + } + }, + { + "filename": "1002s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 6, + "y": 7, + "w": 27, + "h": 21 + }, + "frame": { + "x": 123, + "y": 308, + "w": 27, + "h": 21 } }, { @@ -2355,8 +2439,8 @@ "h": 29 }, "frame": { - "x": 52, - "y": 388, + "x": 121, + "y": 329, "w": 21, "h": 29 } @@ -2376,14 +2460,14 @@ "h": 27 }, "frame": { - "x": 52, - "y": 417, + "x": 121, + "y": 358, "w": 22, "h": 27 } }, { - "filename": "1023", + "filename": "936", "rotated": false, "trimmed": true, "sourceSize": { @@ -2392,19 +2476,19 @@ }, "spriteSourceSize": { "x": 10, - "y": 1, + "y": 0, "w": 20, "h": 28 }, "frame": { - "x": 54, - "y": 444, + "x": 164, + "y": 170, "w": 20, "h": 28 } }, { - "filename": "1023s", + "filename": "913", "rotated": false, "trimmed": true, "sourceSize": { @@ -2412,583 +2496,16 @@ "h": 30 }, "spriteSourceSize": { - "x": 10, - "y": 1, - "w": 20, - "h": 28 + "x": 11, + "y": 5, + "w": 17, + "h": 23 }, "frame": { - "x": 54, - "y": 472, - "w": 20, - "h": 28 - } - }, - { - "filename": "1000s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 9, - "y": 1, - "w": 22, - "h": 27 - }, - "frame": { - "x": 55, - "y": 500, - "w": 22, - "h": 27 - } - }, - { - "filename": "1006", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 10, - "y": 1, - "w": 22, - "h": 27 - }, - "frame": { - "x": 56, - "y": 527, - "w": 22, - "h": 27 - } - }, - { - "filename": "1006s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 10, - "y": 1, - "w": 22, - "h": 27 - }, - "frame": { - "x": 56, - "y": 554, - "w": 22, - "h": 27 - } - }, - { - "filename": "908s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 10, - "y": 2, - "w": 20, - "h": 26 - }, - "frame": { - "x": 80, - "y": 313, - "w": 20, - "h": 26 - } - }, - { - "filename": "956", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 7, - "y": 6, - "w": 26, - "h": 22 - }, - "frame": { - "x": 100, - "y": 311, - "w": 26, - "h": 22 - } - }, - { - "filename": "917", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 9, - "y": 6, - "w": 22, - "h": 22 - }, - "frame": { - "x": 126, - "y": 311, - "w": 22, - "h": 22 - } - }, - { - "filename": "956s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 7, - "y": 6, - "w": 26, - "h": 22 - }, - "frame": { - "x": 74, - "y": 339, - "w": 26, - "h": 22 - } - }, - { - "filename": "982s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 10, - "y": 2, - "w": 22, - "h": 26 - }, - "frame": { - "x": 100, - "y": 333, - "w": 22, - "h": 26 - } - }, - { - "filename": "987s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 10, - "y": 4, - "w": 24, - "h": 24 - }, - "frame": { - "x": 74, - "y": 361, - "w": 24, - "h": 24 - } - }, - { - "filename": "1012-artisan", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 7, - "y": 6, - "w": 26, - "h": 22 - }, - "frame": { - "x": 122, - "y": 333, - "w": 26, - "h": 22 - } - }, - { - "filename": "1012-counterfeit", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 7, - "y": 6, - "w": 26, - "h": 22 - }, - "frame": { - "x": 122, - "y": 333, - "w": 26, - "h": 22 - } - }, - { - "filename": "950", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 28, - "h": 17 - }, - "frame": { - "x": 144, - "y": 148, - "w": 28, - "h": 17 - } - }, - { - "filename": "950s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 6, - "y": 11, - "w": 28, - "h": 17 - }, - "frame": { - "x": 172, - "y": 148, - "w": 28, - "h": 17 - } - }, - { - "filename": "985", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 9, - "y": 7, - "w": 27, - "h": 21 - }, - "frame": { - "x": 140, - "y": 165, - "w": 27, - "h": 21 - } - }, - { - "filename": "985s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 9, - "y": 7, - "w": 27, - "h": 21 - }, - "frame": { - "x": 167, - "y": 165, - "w": 27, - "h": 21 - } - }, - { - "filename": "953", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 8, - "y": 12, - "w": 24, - "h": 16 - }, - "frame": { - "x": 138, - "y": 186, - "w": 24, - "h": 16 - } - }, - { - "filename": "1010", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 9, - "y": 2, - "w": 21, - "h": 26 - }, - "frame": { - "x": 142, - "y": 202, - "w": 21, - "h": 26 - } - }, - { - "filename": "953s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 8, - "y": 12, - "w": 24, - "h": 16 - }, - "frame": { - "x": 162, - "y": 186, - "w": 24, - "h": 16 - } - }, - { - "filename": "1010s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 9, - "y": 2, - "w": 21, - "h": 26 - }, - "frame": { - "x": 163, - "y": 202, - "w": 21, - "h": 26 - } - }, - { - "filename": "1002", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 6, - "y": 7, - "w": 27, - "h": 21 - }, - "frame": { - "x": 145, - "y": 228, - "w": 27, - "h": 21 - } - }, - { - "filename": "1017-cornerstone-mask", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 8, - "y": 4, - "w": 24, - "h": 24 - }, - "frame": { - "x": 148, - "y": 249, - "w": 24, - "h": 24 - } - }, - { - "filename": "1017-cornerstone-mask-tera", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 8, - "y": 4, - "w": 24, - "h": 24 - }, - "frame": { - "x": 148, - "y": 249, - "w": 24, - "h": 24 - } - }, - { - "filename": "1017s-cornerstone-mask", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 8, - "y": 4, - "w": 24, - "h": 24 - }, - "frame": { - "x": 148, - "y": 249, - "w": 24, - "h": 24 - } - }, - { - "filename": "1017s-cornerstone-mask-tera", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 8, - "y": 4, - "w": 24, - "h": 24 - }, - "frame": { - "x": 148, - "y": 249, - "w": 24, - "h": 24 - } - }, - { - "filename": "973", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 12, - "y": 2, - "w": 15, - "h": 26 - }, - "frame": { - "x": 172, - "y": 228, - "w": 15, - "h": 26 - } - }, - { - "filename": "916s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 7, - "y": 9, - "w": 25, - "h": 19 - }, - "frame": { - "x": 148, - "y": 273, - "w": 25, - "h": 19 - } - }, - { - "filename": "997", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 9, - "y": 9, - "w": 21, - "h": 19 - }, - "frame": { - "x": 147, - "y": 292, - "w": 21, - "h": 19 + "x": 173, + "y": 147, + "w": 17, + "h": 23 } }, { @@ -3006,428 +2523,8 @@ "h": 25 }, "frame": { - "x": 148, - "y": 311, - "w": 20, - "h": 25 - } - }, - { - "filename": "910", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 9, - "y": 7, - "w": 21, - "h": 21 - }, - "frame": { - "x": 148, - "y": 336, - "w": 21, - "h": 21 - } - }, - { - "filename": "906", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 11, - "y": 9, - "w": 18, - "h": 19 - }, - "frame": { - "x": 172, - "y": 254, - "w": 18, - "h": 19 - } - }, - { - "filename": "906s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 11, - "y": 9, - "w": 18, - "h": 19 - }, - "frame": { - "x": 173, - "y": 273, - "w": 18, - "h": 19 - } - }, - { - "filename": "1017-teal-mask", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 8, - "y": 4, - "w": 24, - "h": 24 - }, - "frame": { - "x": 168, - "y": 292, - "w": 24, - "h": 24 - } - }, - { - "filename": "1017-teal-mask-tera", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 8, - "y": 4, - "w": 24, - "h": 24 - }, - "frame": { - "x": 168, - "y": 292, - "w": 24, - "h": 24 - } - }, - { - "filename": "1017s-teal-mask", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 8, - "y": 4, - "w": 24, - "h": 24 - }, - "frame": { - "x": 168, - "y": 292, - "w": 24, - "h": 24 - } - }, - { - "filename": "1017s-teal-mask-tera", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 8, - "y": 4, - "w": 24, - "h": 24 - }, - "frame": { - "x": 168, - "y": 292, - "w": 24, - "h": 24 - } - }, - { - "filename": "943", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 8, - "y": 8, - "w": 24, - "h": 20 - }, - "frame": { - "x": 168, - "y": 316, - "w": 24, - "h": 20 - } - }, - { - "filename": "916s-female", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 6, - "y": 7, - "w": 25, - "h": 21 - }, - "frame": { - "x": 169, - "y": 336, - "w": 25, - "h": 21 - } - }, - { - "filename": "1002s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 6, - "y": 7, - "w": 27, - "h": 21 - }, - "frame": { - "x": 200, - "y": 152, - "w": 27, - "h": 21 - } - }, - { - "filename": "945", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 7, - "y": 6, - "w": 25, - "h": 22 - }, - "frame": { - "x": 227, - "y": 171, - "w": 25, - "h": 22 - } - }, - { - "filename": "1012s-artisan", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 7, - "y": 6, - "w": 26, - "h": 22 - }, - "frame": { - "x": 194, - "y": 173, - "w": 26, - "h": 22 - } - }, - { - "filename": "1012s-counterfeit", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 7, - "y": 6, - "w": 26, - "h": 22 - }, - "frame": { - "x": 194, - "y": 173, - "w": 26, - "h": 22 - } - }, - { - "filename": "973s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 12, - "y": 2, - "w": 15, - "h": 26 - }, - "frame": { - "x": 184, - "y": 202, - "w": 15, - "h": 26 - } - }, - { - "filename": "918", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 9, - "y": 4, - "w": 22, - "h": 24 - }, - "frame": { - "x": 199, - "y": 195, - "w": 22, - "h": 24 - } - }, - { - "filename": "1017-wellspring-mask", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 8, - "y": 4, - "w": 24, - "h": 24 - }, - "frame": { - "x": 221, - "y": 193, - "w": 24, - "h": 24 - } - }, - { - "filename": "1017-wellspring-mask-tera", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 8, - "y": 4, - "w": 24, - "h": 24 - }, - "frame": { - "x": 221, - "y": 193, - "w": 24, - "h": 24 - } - }, - { - "filename": "1017s-wellspring-mask", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 8, - "y": 4, - "w": 24, - "h": 24 - }, - "frame": { - "x": 221, - "y": 193, - "w": 24, - "h": 24 - } - }, - { - "filename": "1017s-wellspring-mask-tera", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 8, - "y": 4, - "w": 24, - "h": 24 - }, - "frame": { - "x": 221, - "y": 193, - "w": 24, - "h": 24 - } - }, - { - "filename": "949s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 10, - "y": 3, - "w": 20, - "h": 25 - }, - "frame": { - "x": 187, - "y": 228, + "x": 177, + "y": 122, "w": 20, "h": 25 } @@ -3447,138 +2544,12 @@ "h": 20 }, "frame": { - "x": 190, - "y": 253, + "x": 178, + "y": 102, "w": 20, "h": 20 } }, - { - "filename": "967", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 10, - "y": 9, - "w": 20, - "h": 19 - }, - "frame": { - "x": 191, - "y": 273, - "w": 20, - "h": 19 - } - }, - { - "filename": "962", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 10, - "y": 3, - "w": 19, - "h": 25 - }, - "frame": { - "x": 192, - "y": 292, - "w": 19, - "h": 25 - } - }, - { - "filename": "967s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 10, - "y": 9, - "w": 20, - "h": 19 - }, - "frame": { - "x": 192, - "y": 317, - "w": 20, - "h": 19 - } - }, - { - "filename": "910s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 9, - "y": 7, - "w": 21, - "h": 21 - }, - "frame": { - "x": 194, - "y": 336, - "w": 21, - "h": 21 - } - }, - { - "filename": "962s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 10, - "y": 3, - "w": 19, - "h": 25 - }, - "frame": { - "x": 207, - "y": 219, - "w": 19, - "h": 25 - } - }, - { - "filename": "918s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 9, - "y": 4, - "w": 22, - "h": 24 - }, - "frame": { - "x": 226, - "y": 217, - "w": 22, - "h": 24 - } - }, { "filename": "923", "rotated": false, @@ -3594,77 +2565,14 @@ "h": 24 }, "frame": { - "x": 210, - "y": 244, + "x": 198, + "y": 101, "w": 19, "h": 24 } }, { - "filename": "961", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 8, - "y": 5, - "w": 23, - "h": 23 - }, - "frame": { - "x": 229, - "y": 241, - "w": 23, - "h": 23 - } - }, - { - "filename": "961s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 8, - "y": 5, - "w": 23, - "h": 23 - }, - "frame": { - "x": 229, - "y": 264, - "w": 23, - "h": 23 - } - }, - { - "filename": "909", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 11, - "y": 9, - "w": 18, - "h": 19 - }, - "frame": { - "x": 211, - "y": 268, - "w": 18, - "h": 19 - } - }, - { - "filename": "945s", + "filename": "1012-artisan", "rotated": false, "trimmed": true, "sourceSize": { @@ -3674,16 +2582,58 @@ "spriteSourceSize": { "x": 7, "y": 6, - "w": 25, + "w": 26, "h": 22 }, "frame": { - "x": 211, - "y": 287, - "w": 25, + "x": 217, + "y": 102, + "w": 26, "h": 22 } }, + { + "filename": "908s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 2, + "w": 20, + "h": 26 + }, + "frame": { + "x": 197, + "y": 125, + "w": 20, + "h": 26 + } + }, + { + "filename": "1000s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 9, + "y": 1, + "w": 22, + "h": 27 + }, + "frame": { + "x": 217, + "y": 124, + "w": 22, + "h": 27 + } + }, { "filename": "948", "rotated": false, @@ -3699,8 +2649,8 @@ "h": 21 }, "frame": { - "x": 236, - "y": 287, + "x": 239, + "y": 124, "w": 16, "h": 21 } @@ -3720,14 +2670,35 @@ "h": 21 }, "frame": { - "x": 236, - "y": 308, + "x": 239, + "y": 145, "w": 16, "h": 21 } }, { - "filename": "927", + "filename": "1012-counterfeit", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 7, + "y": 6, + "w": 26, + "h": 22 + }, + "frame": { + "x": 190, + "y": 151, + "w": 26, + "h": 22 + } + }, + { + "filename": "947s", "rotated": false, "trimmed": true, "sourceSize": { @@ -3736,19 +2707,82 @@ }, "spriteSourceSize": { "x": 8, - "y": 7, - "w": 24, - "h": 21 + "y": 6, + "w": 23, + "h": 22 }, "frame": { - "x": 212, - "y": 309, - "w": 24, - "h": 21 + "x": 216, + "y": 151, + "w": 23, + "h": 22 } }, { - "filename": "920", + "filename": "951", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 12, + "y": 8, + "w": 16, + "h": 20 + }, + "frame": { + "x": 239, + "y": 166, + "w": 16, + "h": 20 + } + }, + { + "filename": "1017s-hearthflame-mask-tera", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 7, + "y": 4, + "w": 25, + "h": 24 + }, + "frame": { + "x": 184, + "y": 173, + "w": 25, + "h": 24 + } + }, + { + "filename": "1017s-hearthflame-mask", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 7, + "y": 4, + "w": 25, + "h": 24 + }, + "frame": { + "x": 209, + "y": 173, + "w": 25, + "h": 24 + } + }, + { + "filename": "1010", "rotated": false, "trimmed": true, "sourceSize": { @@ -3757,19 +2791,19 @@ }, "spriteSourceSize": { "x": 9, - "y": 5, - "w": 22, - "h": 23 + "y": 2, + "w": 21, + "h": 26 }, "frame": { - "x": 215, - "y": 330, - "w": 22, - "h": 23 + "x": 234, + "y": 186, + "w": 21, + "h": 26 } }, { - "filename": "912", + "filename": "936s", "rotated": false, "trimmed": true, "sourceSize": { @@ -3777,20 +2811,20 @@ "h": 30 }, "spriteSourceSize": { - "x": 13, - "y": 9, - "w": 15, - "h": 19 + "x": 10, + "y": 0, + "w": 20, + "h": 28 }, "frame": { - "x": 237, - "y": 329, - "w": 15, - "h": 19 + "x": 156, + "y": 213, + "w": 20, + "h": 28 } }, { - "filename": "912s", + "filename": "963", "rotated": false, "trimmed": true, "sourceSize": { @@ -3798,16 +2832,79 @@ "h": 30 }, "spriteSourceSize": { - "x": 13, - "y": 9, - "w": 15, - "h": 19 + "x": 9, + "y": 13, + "w": 22, + "h": 15 }, "frame": { - "x": 237, - "y": 348, - "w": 15, - "h": 19 + "x": 164, + "y": 198, + "w": 22, + "h": 15 + } + }, + { + "filename": "918", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 9, + "y": 4, + "w": 22, + "h": 24 + }, + "frame": { + "x": 156, + "y": 241, + "w": 22, + "h": 24 + } + }, + { + "filename": "1006", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 1, + "w": 22, + "h": 27 + }, + "frame": { + "x": 157, + "y": 265, + "w": 22, + "h": 27 + } + }, + { + "filename": "1012s-artisan", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 7, + "y": 6, + "w": 26, + "h": 22 + }, + "frame": { + "x": 186, + "y": 197, + "w": 26, + "h": 22 } }, { @@ -3825,14 +2922,14 @@ "h": 22 }, "frame": { - "x": 215, - "y": 353, + "x": 212, + "y": 197, "w": 22, "h": 22 } }, { - "filename": "960", + "filename": "1010s", "rotated": false, "trimmed": true, "sourceSize": { @@ -3840,16 +2937,268 @@ "h": 30 }, "spriteSourceSize": { - "x": 12, - "y": 10, - "w": 15, - "h": 18 + "x": 9, + "y": 2, + "w": 21, + "h": 26 }, "frame": { - "x": 237, - "y": 367, - "w": 15, - "h": 18 + "x": 234, + "y": 212, + "w": 21, + "h": 26 + } + }, + { + "filename": "1012s-counterfeit", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 7, + "y": 6, + "w": 26, + "h": 22 + }, + "frame": { + "x": 176, + "y": 219, + "w": 26, + "h": 22 + } + }, + { + "filename": "987", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 4, + "w": 24, + "h": 24 + }, + "frame": { + "x": 178, + "y": 241, + "w": 24, + "h": 24 + } + }, + { + "filename": "1006s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 1, + "w": 22, + "h": 27 + }, + "frame": { + "x": 202, + "y": 219, + "w": 22, + "h": 27 + } + }, + { + "filename": "987s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 4, + "w": 24, + "h": 24 + }, + "frame": { + "x": 179, + "y": 265, + "w": 24, + "h": 24 + } + }, + { + "filename": "997", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 9, + "y": 9, + "w": 21, + "h": 19 + }, + "frame": { + "x": 202, + "y": 246, + "w": 21, + "h": 19 + } + }, + { + "filename": "918s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 9, + "y": 4, + "w": 22, + "h": 24 + }, + "frame": { + "x": 203, + "y": 265, + "w": 22, + "h": 24 + } + }, + { + "filename": "916s-female", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 6, + "y": 7, + "w": 25, + "h": 21 + }, + "frame": { + "x": 157, + "y": 292, + "w": 25, + "h": 21 + } + }, + { + "filename": "1017-cornerstone-mask-tera", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 8, + "y": 4, + "w": 24, + "h": 24 + }, + "frame": { + "x": 182, + "y": 289, + "w": 24, + "h": 24 + } + }, + { + "filename": "923s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 4, + "w": 19, + "h": 24 + }, + "frame": { + "x": 206, + "y": 289, + "w": 19, + "h": 24 + } + }, + { + "filename": "1023", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 1, + "w": 20, + "h": 28 + }, + "frame": { + "x": 142, + "y": 329, + "w": 20, + "h": 28 + } + }, + { + "filename": "1023s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 1, + "w": 20, + "h": 28 + }, + "frame": { + "x": 143, + "y": 357, + "w": 20, + "h": 28 + } + }, + { + "filename": "953", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 8, + "y": 12, + "w": 24, + "h": 16 + }, + "frame": { + "x": 150, + "y": 313, + "w": 24, + "h": 16 } }, { @@ -3867,8 +3216,8 @@ "h": 21 }, "frame": { - "x": 122, - "y": 355, + "x": 174, + "y": 313, "w": 25, "h": 21 } @@ -3888,12 +3237,264 @@ "h": 21 }, "frame": { - "x": 147, - "y": 357, + "x": 199, + "y": 313, "w": 25, "h": 21 } }, + { + "filename": "945", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 7, + "y": 6, + "w": 25, + "h": 22 + }, + "frame": { + "x": 162, + "y": 334, + "w": 25, + "h": 22 + } + }, + { + "filename": "945s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 7, + "y": 6, + "w": 25, + "h": 22 + }, + "frame": { + "x": 187, + "y": 334, + "w": 25, + "h": 22 + } + }, + { + "filename": "1017-cornerstone-mask", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 8, + "y": 4, + "w": 24, + "h": 24 + }, + "frame": { + "x": 163, + "y": 356, + "w": 24, + "h": 24 + } + }, + { + "filename": "1017-teal-mask-tera", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 8, + "y": 4, + "w": 24, + "h": 24 + }, + "frame": { + "x": 187, + "y": 356, + "w": 24, + "h": 24 + } + }, + { + "filename": "907", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 11, + "y": 6, + "w": 17, + "h": 22 + }, + "frame": { + "x": 212, + "y": 334, + "w": 17, + "h": 22 + } + }, + { + "filename": "949s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 3, + "w": 20, + "h": 25 + }, + "frame": { + "x": 211, + "y": 356, + "w": 20, + "h": 25 + } + }, + { + "filename": "1017-teal-mask", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 8, + "y": 4, + "w": 24, + "h": 24 + }, + "frame": { + "x": 231, + "y": 238, + "w": 24, + "h": 24 + } + }, + { + "filename": "1017-wellspring-mask-tera", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 8, + "y": 4, + "w": 24, + "h": 24 + }, + "frame": { + "x": 231, + "y": 262, + "w": 24, + "h": 24 + } + }, + { + "filename": "1017-wellspring-mask", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 8, + "y": 4, + "w": 24, + "h": 24 + }, + "frame": { + "x": 231, + "y": 286, + "w": 24, + "h": 24 + } + }, + { + "filename": "1017s-cornerstone-mask-tera", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 8, + "y": 4, + "w": 24, + "h": 24 + }, + "frame": { + "x": 231, + "y": 310, + "w": 24, + "h": 24 + } + }, + { + "filename": "1017s-cornerstone-mask", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 8, + "y": 4, + "w": 24, + "h": 24 + }, + "frame": { + "x": 231, + "y": 334, + "w": 24, + "h": 24 + } + }, + { + "filename": "1017s-teal-mask-tera", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 8, + "y": 4, + "w": 24, + "h": 24 + }, + "frame": { + "x": 231, + "y": 358, + "w": 24, + "h": 24 + } + }, { "filename": "952", "rotated": false, @@ -3909,182 +3510,14 @@ "h": 22 }, "frame": { - "x": 172, - "y": 357, + "x": 163, + "y": 380, "w": 25, "h": 22 } }, { - "filename": "909s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 11, - "y": 9, - "w": 18, - "h": 19 - }, - "frame": { - "x": 197, - "y": 357, - "w": 18, - "h": 19 - } - }, - { - "filename": "920s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 9, - "y": 5, - "w": 22, - "h": 23 - }, - "frame": { - "x": 100, - "y": 359, - "w": 22, - "h": 23 - } - }, - { - "filename": "952s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 7, - "y": 6, - "w": 25, - "h": 22 - }, - "frame": { - "x": 122, - "y": 376, - "w": 25, - "h": 22 - } - }, - { - "filename": "966", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 7, - "y": 7, - "w": 25, - "h": 21 - }, - "frame": { - "x": 147, - "y": 378, - "w": 25, - "h": 21 - } - }, - { - "filename": "966s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 7, - "y": 7, - "w": 25, - "h": 21 - }, - "frame": { - "x": 172, - "y": 379, - "w": 25, - "h": 21 - } - }, - { - "filename": "923s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 10, - "y": 4, - "w": 19, - "h": 24 - }, - "frame": { - "x": 197, - "y": 376, - "w": 19, - "h": 24 - } - }, - { - "filename": "941", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 9, - "y": 7, - "w": 21, - "h": 21 - }, - "frame": { - "x": 216, - "y": 375, - "w": 21, - "h": 21 - } - }, - { - "filename": "960s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 12, - "y": 10, - "w": 15, - "h": 18 - }, - "frame": { - "x": 237, - "y": 385, - "w": 15, - "h": 18 - } - }, - { - "filename": "927s", + "filename": "961", "rotated": false, "trimmed": true, "sourceSize": { @@ -4093,122 +3526,17 @@ }, "spriteSourceSize": { "x": 8, - "y": 7, - "w": 24, - "h": 21 - }, - "frame": { - "x": 98, - "y": 382, - "w": 24, - "h": 21 - } - }, - { - "filename": "943s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 8, - "y": 8, - "w": 24, - "h": 20 - }, - "frame": { - "x": 74, - "y": 385, - "w": 24, - "h": 20 - } - }, - { - "filename": "986", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 9, "y": 5, "w": 23, "h": 23 }, "frame": { - "x": 74, - "y": 405, + "x": 188, + "y": 380, "w": 23, "h": 23 } }, - { - "filename": "986s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 9, - "y": 5, - "w": 23, - "h": 23 - }, - "frame": { - "x": 74, - "y": 428, - "w": 23, - "h": 23 - } - }, - { - "filename": "947", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 8, - "y": 6, - "w": 23, - "h": 22 - }, - "frame": { - "x": 74, - "y": 451, - "w": 23, - "h": 22 - } - }, - { - "filename": "947s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 8, - "y": 6, - "w": 23, - "h": 22 - }, - "frame": { - "x": 74, - "y": 473, - "w": 23, - "h": 22 - } - }, { "filename": "991", "rotated": false, @@ -4224,12 +3552,453 @@ "h": 24 }, "frame": { - "x": 77, - "y": 495, + "x": 211, + "y": 381, "w": 20, "h": 24 } }, + { + "filename": "1017s-teal-mask", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 8, + "y": 4, + "w": 24, + "h": 24 + }, + "frame": { + "x": 231, + "y": 382, + "w": 24, + "h": 24 + } + }, + { + "filename": "952s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 7, + "y": 6, + "w": 25, + "h": 22 + }, + "frame": { + "x": 52, + "y": 382, + "w": 25, + "h": 22 + } + }, + { + "filename": "1017s-wellspring-mask-tera", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 8, + "y": 4, + "w": 24, + "h": 24 + }, + "frame": { + "x": 50, + "y": 404, + "w": 24, + "h": 24 + } + }, + { + "filename": "920", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 9, + "y": 5, + "w": 22, + "h": 23 + }, + "frame": { + "x": 77, + "y": 382, + "w": 22, + "h": 23 + } + }, + { + "filename": "920s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 9, + "y": 5, + "w": 22, + "h": 23 + }, + "frame": { + "x": 99, + "y": 383, + "w": 22, + "h": 23 + } + }, + { + "filename": "966-caph-starmobile", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 7, + "y": 7, + "w": 25, + "h": 21 + }, + "frame": { + "x": 121, + "y": 385, + "w": 25, + "h": 21 + } + }, + { + "filename": "907s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 11, + "y": 6, + "w": 17, + "h": 22 + }, + "frame": { + "x": 146, + "y": 385, + "w": 17, + "h": 22 + } + }, + { + "filename": "966-navi-starmobile", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 7, + "y": 7, + "w": 25, + "h": 21 + }, + "frame": { + "x": 74, + "y": 405, + "w": 25, + "h": 21 + } + }, + { + "filename": "966-ruchbah-starmobile", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 7, + "y": 7, + "w": 25, + "h": 21 + }, + "frame": { + "x": 99, + "y": 406, + "w": 25, + "h": 21 + } + }, + { + "filename": "910", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 9, + "y": 7, + "w": 21, + "h": 21 + }, + "frame": { + "x": 124, + "y": 406, + "w": 21, + "h": 21 + } + }, + { + "filename": "953s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 8, + "y": 12, + "w": 24, + "h": 16 + }, + "frame": { + "x": 50, + "y": 428, + "w": 24, + "h": 16 + } + }, + { + "filename": "966-schedar-starmobile", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 7, + "y": 7, + "w": 25, + "h": 21 + }, + "frame": { + "x": 74, + "y": 426, + "w": 25, + "h": 21 + } + }, + { + "filename": "966-segin-starmobile", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 7, + "y": 7, + "w": 25, + "h": 21 + }, + "frame": { + "x": 99, + "y": 427, + "w": 25, + "h": 21 + } + }, + { + "filename": "910s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 9, + "y": 7, + "w": 21, + "h": 21 + }, + "frame": { + "x": 124, + "y": 427, + "w": 21, + "h": 21 + } + }, + { + "filename": "962", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 3, + "w": 19, + "h": 25 + }, + "frame": { + "x": 145, + "y": 407, + "w": 19, + "h": 25 + } + }, + { + "filename": "1017s-wellspring-mask", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 8, + "y": 4, + "w": 24, + "h": 24 + }, + "frame": { + "x": 164, + "y": 402, + "w": 24, + "h": 24 + } + }, + { + "filename": "961s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 8, + "y": 5, + "w": 23, + "h": 23 + }, + "frame": { + "x": 188, + "y": 403, + "w": 23, + "h": 23 + } + }, + { + "filename": "939", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 7, + "w": 20, + "h": 21 + }, + "frame": { + "x": 211, + "y": 405, + "w": 20, + "h": 21 + } + }, + { + "filename": "927", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 8, + "y": 7, + "w": 24, + "h": 21 + }, + "frame": { + "x": 231, + "y": 406, + "w": 24, + "h": 21 + } + }, + { + "filename": "962s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 3, + "w": 19, + "h": 25 + }, + "frame": { + "x": 52, + "y": 444, + "w": 19, + "h": 25 + } + }, + { + "filename": "966", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 7, + "y": 7, + "w": 25, + "h": 21 + }, + "frame": { + "x": 71, + "y": 447, + "w": 25, + "h": 21 + } + }, { "filename": "991s", "rotated": false, @@ -4245,12 +4014,117 @@ "h": 24 }, "frame": { - "x": 78, - "y": 519, + "x": 52, + "y": 469, "w": 20, "h": 24 } }, + { + "filename": "986", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 9, + "y": 5, + "w": 23, + "h": 23 + }, + "frame": { + "x": 72, + "y": 468, + "w": 23, + "h": 23 + } + }, + { + "filename": "966s-caph-starmobile", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 7, + "y": 7, + "w": 25, + "h": 21 + }, + "frame": { + "x": 96, + "y": 448, + "w": 25, + "h": 21 + } + }, + { + "filename": "927s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 8, + "y": 7, + "w": 24, + "h": 21 + }, + "frame": { + "x": 121, + "y": 448, + "w": 24, + "h": 21 + } + }, + { + "filename": "966s-navi-starmobile", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 7, + "y": 7, + "w": 25, + "h": 21 + }, + "frame": { + "x": 95, + "y": 469, + "w": 25, + "h": 21 + } + }, + { + "filename": "966s-ruchbah-starmobile", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 7, + "y": 7, + "w": 25, + "h": 21 + }, + "frame": { + "x": 120, + "y": 469, + "w": 25, + "h": 21 + } + }, { "filename": "1013-masterpiece", "rotated": false, @@ -4266,8 +4140,8 @@ "h": 24 }, "frame": { - "x": 78, - "y": 543, + "x": 145, + "y": 432, "w": 20, "h": 24 } @@ -4287,14 +4161,14 @@ "h": 24 }, "frame": { - "x": 78, - "y": 543, + "x": 145, + "y": 456, "w": 20, "h": 24 } }, { - "filename": "1013s-masterpiece", + "filename": "966s-schedar-starmobile", "rotated": false, "trimmed": true, "sourceSize": { @@ -4302,62 +4176,20 @@ "h": 30 }, "spriteSourceSize": { - "x": 10, - "y": 4, - "w": 20, - "h": 24 - }, - "frame": { - "x": 78, - "y": 567, - "w": 20, - "h": 24 - } - }, - { - "filename": "1013s-unremarkable", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 10, - "y": 4, - "w": 20, - "h": 24 - }, - "frame": { - "x": 78, - "y": 567, - "w": 20, - "h": 24 - } - }, - { - "filename": "941s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 9, + "x": 7, "y": 7, - "w": 21, + "w": 25, "h": 21 }, "frame": { - "x": 216, - "y": 396, - "w": 21, + "x": 165, + "y": 426, + "w": 25, "h": 21 } }, { - "filename": "996", + "filename": "966s-segin-starmobile", "rotated": false, "trimmed": true, "sourceSize": { @@ -4365,16 +4197,37 @@ "h": 30 }, "spriteSourceSize": { - "x": 12, - "y": 12, - "w": 15, - "h": 16 + "x": 7, + "y": 7, + "w": 25, + "h": 21 }, "frame": { - "x": 237, - "y": 403, - "w": 15, - "h": 16 + "x": 165, + "y": 447, + "w": 25, + "h": 21 + } + }, + { + "filename": "966s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 7, + "y": 7, + "w": 25, + "h": 21 + }, + "frame": { + "x": 190, + "y": 426, + "w": 25, + "h": 21 } }, { @@ -4392,12 +4245,33 @@ "h": 21 }, "frame": { - "x": 122, - "y": 398, + "x": 190, + "y": 447, "w": 25, "h": 21 } }, + { + "filename": "973", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 12, + "y": 2, + "w": 15, + "h": 26 + }, + "frame": { + "x": 215, + "y": 426, + "w": 15, + "h": 26 + } + }, { "filename": "8128s", "rotated": false, @@ -4413,14 +4287,14 @@ "h": 21 }, "frame": { - "x": 147, - "y": 399, + "x": 230, + "y": 427, "w": 25, "h": 21 } }, { - "filename": "1024", + "filename": "943", "rotated": false, "trimmed": true, "sourceSize": { @@ -4434,8 +4308,29 @@ "h": 20 }, "frame": { - "x": 172, - "y": 400, + "x": 165, + "y": 468, + "w": 24, + "h": 20 + } + }, + { + "filename": "943s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 8, + "y": 8, + "w": 24, + "h": 20 + }, + "frame": { + "x": 189, + "y": 468, "w": 24, "h": 20 } @@ -4455,12 +4350,33 @@ "h": 20 }, "frame": { - "x": 196, - "y": 400, + "x": 145, + "y": 480, "w": 20, "h": 20 } }, + { + "filename": "1024", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 8, + "y": 8, + "w": 24, + "h": 20 + }, + "frame": { + "x": 165, + "y": 488, + "w": 24, + "h": 20 + } + }, { "filename": "1024s", "rotated": false, @@ -4476,476 +4392,14 @@ "h": 20 }, "frame": { - "x": 98, - "y": 403, + "x": 189, + "y": 488, "w": 24, "h": 20 } }, { - "filename": "939", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 10, - "y": 7, - "w": 20, - "h": 21 - }, - "frame": { - "x": 97, - "y": 423, - "w": 20, - "h": 21 - } - }, - { - "filename": "939s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 10, - "y": 7, - "w": 20, - "h": 21 - }, - "frame": { - "x": 97, - "y": 444, - "w": 20, - "h": 21 - } - }, - { - "filename": "971", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 10, - "y": 7, - "w": 20, - "h": 21 - }, - "frame": { - "x": 97, - "y": 465, - "w": 20, - "h": 21 - } - }, - { - "filename": "971s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 10, - "y": 7, - "w": 20, - "h": 21 - }, - "frame": { - "x": 97, - "y": 486, - "w": 20, - "h": 21 - } - }, - { - "filename": "969", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 11, - "y": 16, - "w": 18, - "h": 12 - }, - "frame": { - "x": 97, - "y": 507, - "w": 18, - "h": 12 - } - }, - { - "filename": "907", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 11, - "y": 6, - "w": 17, - "h": 22 - }, - "frame": { - "x": 98, - "y": 519, - "w": 17, - "h": 22 - } - }, - { - "filename": "907s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 11, - "y": 6, - "w": 17, - "h": 22 - }, - "frame": { - "x": 98, - "y": 541, - "w": 17, - "h": 22 - } - }, - { - "filename": "929", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 11, - "y": 6, - "w": 17, - "h": 22 - }, - "frame": { - "x": 98, - "y": 563, - "w": 17, - "h": 22 - } - }, - { - "filename": "929s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 11, - "y": 6, - "w": 17, - "h": 22 - }, - "frame": { - "x": 117, - "y": 423, - "w": 17, - "h": 22 - } - }, - { - "filename": "1011", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 11, - "y": 5, - "w": 19, - "h": 22 - }, - "frame": { - "x": 117, - "y": 445, - "w": 19, - "h": 22 - } - }, - { - "filename": "1011s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 11, - "y": 5, - "w": 19, - "h": 22 - }, - "frame": { - "x": 117, - "y": 467, - "w": 19, - "h": 22 - } - }, - { - "filename": "931-white-plumage", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 10, - "y": 8, - "w": 20, - "h": 20 - }, - "frame": { - "x": 117, - "y": 489, - "w": 20, - "h": 20 - } - }, - { - "filename": "1004", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 9, - "y": 8, - "w": 21, - "h": 20 - }, - "frame": { - "x": 115, - "y": 509, - "w": 21, - "h": 20 - } - }, - { - "filename": "1004s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 9, - "y": 8, - "w": 21, - "h": 20 - }, - "frame": { - "x": 115, - "y": 529, - "w": 21, - "h": 20 - } - }, - { - "filename": "931-yellow-plumage", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 10, - "y": 8, - "w": 20, - "h": 20 - }, - "frame": { - "x": 115, - "y": 549, - "w": 20, - "h": 20 - } - }, - { - "filename": "931s-blue-plumage", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 10, - "y": 8, - "w": 20, - "h": 20 - }, - "frame": { - "x": 115, - "y": 569, - "w": 20, - "h": 20 - } - }, - { - "filename": "935s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 13, - "y": 7, - "w": 13, - "h": 21 - }, - "frame": { - "x": 134, - "y": 419, - "w": 13, - "h": 21 - } - }, - { - "filename": "931s-green-plumage", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 10, - "y": 8, - "w": 20, - "h": 20 - }, - "frame": { - "x": 147, - "y": 420, - "w": 20, - "h": 20 - } - }, - { - "filename": "931s-white-plumage", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 10, - "y": 8, - "w": 20, - "h": 20 - }, - "frame": { - "x": 167, - "y": 420, - "w": 20, - "h": 20 - } - }, - { - "filename": "931s-yellow-plumage", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 10, - "y": 8, - "w": 20, - "h": 20 - }, - "frame": { - "x": 187, - "y": 420, - "w": 20, - "h": 20 - } - }, - { - "filename": "997s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 9, - "y": 9, - "w": 21, - "h": 19 - }, - "frame": { - "x": 136, - "y": 440, - "w": 21, - "h": 19 - } - }, - { - "filename": "1015", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 11, - "y": 7, - "w": 17, - "h": 21 - }, - "frame": { - "x": 136, - "y": 459, - "w": 17, - "h": 21 - } - }, - { - "filename": "932", + "filename": "906", "rotated": false, "trimmed": true, "sourceSize": { @@ -4959,222 +4413,12 @@ "h": 19 }, "frame": { - "x": 157, - "y": 440, + "x": 215, + "y": 452, "w": 18, "h": 19 } }, - { - "filename": "1015s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 11, - "y": 7, - "w": 17, - "h": 21 - }, - "frame": { - "x": 153, - "y": 459, - "w": 17, - "h": 21 - } - }, - { - "filename": "932s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 11, - "y": 9, - "w": 18, - "h": 19 - }, - "frame": { - "x": 175, - "y": 440, - "w": 18, - "h": 19 - } - }, - { - "filename": "958", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 11, - "y": 8, - "w": 17, - "h": 20 - }, - "frame": { - "x": 170, - "y": 459, - "w": 17, - "h": 20 - } - }, - { - "filename": "922", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 12, - "y": 9, - "w": 17, - "h": 19 - }, - "frame": { - "x": 193, - "y": 440, - "w": 17, - "h": 19 - } - }, - { - "filename": "958s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 11, - "y": 8, - "w": 17, - "h": 20 - }, - "frame": { - "x": 187, - "y": 459, - "w": 17, - "h": 20 - } - }, - { - "filename": "951", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 12, - "y": 8, - "w": 16, - "h": 20 - }, - "frame": { - "x": 207, - "y": 420, - "w": 16, - "h": 20 - } - }, - { - "filename": "922s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 12, - "y": 9, - "w": 17, - "h": 19 - }, - "frame": { - "x": 210, - "y": 440, - "w": 17, - "h": 19 - } - }, - { - "filename": "963", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 9, - "y": 13, - "w": 22, - "h": 15 - }, - "frame": { - "x": 204, - "y": 459, - "w": 22, - "h": 15 - } - }, - { - "filename": "999-roaming", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 13, - "y": 10, - "w": 14, - "h": 18 - }, - "frame": { - "x": 223, - "y": 417, - "w": 14, - "h": 18 - } - }, - { - "filename": "996s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 12, - "y": 12, - "w": 15, - "h": 16 - }, - "frame": { - "x": 237, - "y": 419, - "w": 15, - "h": 16 - } - }, { "filename": "963s", "rotated": false, @@ -5190,8 +4434,8 @@ "h": 15 }, "frame": { - "x": 227, - "y": 435, + "x": 233, + "y": 448, "w": 22, "h": 15 } @@ -5211,12 +4455,33 @@ "h": 15 }, "frame": { - "x": 227, - "y": 450, + "x": 233, + "y": 463, "w": 22, "h": 15 } }, + { + "filename": "1013s-masterpiece", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 4, + "w": 20, + "h": 24 + }, + "frame": { + "x": 213, + "y": 471, + "w": 20, + "h": 24 + } + }, { "filename": "964s-zero", "rotated": false, @@ -5232,8 +4497,8 @@ "h": 15 }, "frame": { - "x": 226, - "y": 465, + "x": 233, + "y": 478, "w": 22, "h": 15 } @@ -5253,12 +4518,33 @@ "h": 15 }, "frame": { - "x": 204, - "y": 474, + "x": 233, + "y": 493, "w": 22, "h": 15 } }, + { + "filename": "931-white-plumage", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 8, + "w": 20, + "h": 20 + }, + "frame": { + "x": 213, + "y": 495, + "w": 20, + "h": 20 + } + }, { "filename": "974s", "rotated": false, @@ -5274,12 +4560,390 @@ "h": 15 }, "frame": { - "x": 226, - "y": 480, + "x": 233, + "y": 508, "w": 22, "h": 15 } }, + { + "filename": "1013s-unremarkable", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 4, + "w": 20, + "h": 24 + }, + "frame": { + "x": 54, + "y": 493, + "w": 20, + "h": 24 + } + }, + { + "filename": "986s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 9, + "y": 5, + "w": 23, + "h": 23 + }, + "frame": { + "x": 54, + "y": 517, + "w": 23, + "h": 23 + } + }, + { + "filename": "941", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 9, + "y": 7, + "w": 21, + "h": 21 + }, + "frame": { + "x": 54, + "y": 540, + "w": 21, + "h": 21 + } + }, + { + "filename": "973s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 12, + "y": 2, + "w": 15, + "h": 26 + }, + "frame": { + "x": 74, + "y": 491, + "w": 15, + "h": 26 + } + }, + { + "filename": "939s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 7, + "w": 20, + "h": 21 + }, + "frame": { + "x": 55, + "y": 561, + "w": 20, + "h": 21 + } + }, + { + "filename": "913s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 11, + "y": 5, + "w": 17, + "h": 23 + }, + "frame": { + "x": 77, + "y": 517, + "w": 17, + "h": 23 + } + }, + { + "filename": "1011", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 11, + "y": 5, + "w": 19, + "h": 22 + }, + "frame": { + "x": 75, + "y": 540, + "w": 19, + "h": 22 + } + }, + { + "filename": "931-yellow-plumage", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 8, + "w": 20, + "h": 20 + }, + "frame": { + "x": 75, + "y": 562, + "w": 20, + "h": 20 + } + }, + { + "filename": "941s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 9, + "y": 7, + "w": 21, + "h": 21 + }, + "frame": { + "x": 56, + "y": 582, + "w": 21, + "h": 21 + } + }, + { + "filename": "971", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 7, + "w": 20, + "h": 21 + }, + "frame": { + "x": 56, + "y": 603, + "w": 20, + "h": 21 + } + }, + { + "filename": "1011s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 11, + "y": 5, + "w": 19, + "h": 22 + }, + "frame": { + "x": 56, + "y": 624, + "w": 19, + "h": 22 + } + }, + { + "filename": "929", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 11, + "y": 6, + "w": 17, + "h": 22 + }, + "frame": { + "x": 75, + "y": 624, + "w": 17, + "h": 22 + } + }, + { + "filename": "971s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 7, + "w": 20, + "h": 21 + }, + "frame": { + "x": 77, + "y": 582, + "w": 20, + "h": 21 + } + }, + { + "filename": "1015", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 11, + "y": 7, + "w": 17, + "h": 21 + }, + "frame": { + "x": 76, + "y": 603, + "w": 17, + "h": 21 + } + }, + { + "filename": "929s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 11, + "y": 6, + "w": 17, + "h": 22 + }, + "frame": { + "x": 92, + "y": 624, + "w": 17, + "h": 22 + } + }, + { + "filename": "1015s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 11, + "y": 7, + "w": 17, + "h": 21 + }, + "frame": { + "x": 93, + "y": 603, + "w": 17, + "h": 21 + } + }, + { + "filename": "935", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 13, + "y": 7, + "w": 13, + "h": 21 + }, + "frame": { + "x": 89, + "y": 491, + "w": 13, + "h": 21 + } + }, + { + "filename": "1004", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 9, + "y": 8, + "w": 21, + "h": 20 + }, + "frame": { + "x": 102, + "y": 490, + "w": 21, + "h": 20 + } + }, { "filename": "980", "rotated": false, @@ -5295,12 +4959,33 @@ "h": 15 }, "frame": { - "x": 137, - "y": 480, + "x": 123, + "y": 490, "w": 22, "h": 15 } }, + { + "filename": "931s-blue-plumage", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 8, + "w": 20, + "h": 20 + }, + "frame": { + "x": 145, + "y": 500, + "w": 20, + "h": 20 + } + }, { "filename": "980s", "rotated": false, @@ -5316,12 +5001,285 @@ "h": 15 }, "frame": { - "x": 137, - "y": 495, + "x": 123, + "y": 505, "w": 22, "h": 15 } }, + { + "filename": "997s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 9, + "y": 9, + "w": 21, + "h": 19 + }, + "frame": { + "x": 165, + "y": 508, + "w": 21, + "h": 19 + } + }, + { + "filename": "1004s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 9, + "y": 8, + "w": 21, + "h": 20 + }, + "frame": { + "x": 186, + "y": 508, + "w": 21, + "h": 20 + } + }, + { + "filename": "931s-green-plumage", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 8, + "w": 20, + "h": 20 + }, + "frame": { + "x": 207, + "y": 515, + "w": 20, + "h": 20 + } + }, + { + "filename": "931s-white-plumage", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 8, + "w": 20, + "h": 20 + }, + "frame": { + "x": 227, + "y": 523, + "w": 20, + "h": 20 + } + }, + { + "filename": "935s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 13, + "y": 7, + "w": 13, + "h": 21 + }, + "frame": { + "x": 94, + "y": 512, + "w": 13, + "h": 21 + } + }, + { + "filename": "951s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 12, + "y": 8, + "w": 16, + "h": 20 + }, + "frame": { + "x": 107, + "y": 510, + "w": 16, + "h": 20 + } + }, + { + "filename": "931s-yellow-plumage", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 8, + "w": 20, + "h": 20 + }, + "frame": { + "x": 94, + "y": 533, + "w": 20, + "h": 20 + } + }, + { + "filename": "967", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 9, + "w": 20, + "h": 19 + }, + "frame": { + "x": 123, + "y": 520, + "w": 20, + "h": 19 + } + }, + { + "filename": "967s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 9, + "w": 20, + "h": 19 + }, + "frame": { + "x": 143, + "y": 520, + "w": 20, + "h": 19 + } + }, + { + "filename": "970", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 12, + "w": 20, + "h": 16 + }, + "frame": { + "x": 163, + "y": 527, + "w": 20, + "h": 16 + } + }, + { + "filename": "970s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 12, + "w": 20, + "h": 16 + }, + "frame": { + "x": 183, + "y": 528, + "w": 20, + "h": 16 + } + }, + { + "filename": "906s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 11, + "y": 9, + "w": 18, + "h": 19 + }, + "frame": { + "x": 95, + "y": 553, + "w": 18, + "h": 19 + } + }, + { + "filename": "958", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 11, + "y": 8, + "w": 17, + "h": 20 + }, + "frame": { + "x": 97, + "y": 572, + "w": 17, + "h": 20 + } + }, { "filename": "915", "rotated": false, @@ -5337,8 +5295,8 @@ "h": 17 }, "frame": { - "x": 136, - "y": 510, + "x": 114, + "y": 539, "w": 19, "h": 17 } @@ -5358,96 +5316,12 @@ "h": 17 }, "frame": { - "x": 136, - "y": 527, + "x": 133, + "y": 539, "w": 19, "h": 17 } }, - { - "filename": "951s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 12, - "y": 8, - "w": 16, - "h": 20 - }, - "frame": { - "x": 159, - "y": 480, - "w": 16, - "h": 20 - } - }, - { - "filename": "970", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 10, - "y": 12, - "w": 20, - "h": 16 - }, - "frame": { - "x": 175, - "y": 479, - "w": 20, - "h": 16 - } - }, - { - "filename": "919", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 12, - "y": 13, - "w": 16, - "h": 15 - }, - "frame": { - "x": 159, - "y": 500, - "w": 16, - "h": 15 - } - }, - { - "filename": "970s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 10, - "y": 12, - "w": 20, - "h": 16 - }, - "frame": { - "x": 175, - "y": 495, - "w": 20, - "h": 16 - } - }, { "filename": "946", "rotated": false, @@ -5463,12 +5337,96 @@ "h": 16 }, "frame": { - "x": 155, - "y": 515, + "x": 113, + "y": 556, "w": 19, "h": 16 } }, + { + "filename": "909", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 11, + "y": 9, + "w": 18, + "h": 19 + }, + "frame": { + "x": 114, + "y": 572, + "w": 18, + "h": 19 + } + }, + { + "filename": "909s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 11, + "y": 9, + "w": 18, + "h": 19 + }, + "frame": { + "x": 132, + "y": 556, + "w": 18, + "h": 19 + } + }, + { + "filename": "932", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 11, + "y": 9, + "w": 18, + "h": 19 + }, + "frame": { + "x": 132, + "y": 575, + "w": 18, + "h": 19 + } + }, + { + "filename": "938", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 14, + "y": 12, + "w": 11, + "h": 16 + }, + "frame": { + "x": 152, + "y": 539, + "w": 11, + "h": 16 + } + }, { "filename": "942", "rotated": false, @@ -5484,8 +5442,8 @@ "h": 15 }, "frame": { - "x": 155, - "y": 531, + "x": 163, + "y": 543, "w": 19, "h": 15 } @@ -5505,14 +5463,14 @@ "h": 15 }, "frame": { - "x": 136, + "x": 182, "y": 544, "w": 19, "h": 15 } }, { - "filename": "946s", + "filename": "932s", "rotated": false, "trimmed": true, "sourceSize": { @@ -5520,58 +5478,16 @@ "h": 30 }, "spriteSourceSize": { - "x": 10, - "y": 12, - "w": 19, - "h": 16 + "x": 11, + "y": 9, + "w": 18, + "h": 19 }, "frame": { - "x": 135, - "y": 559, - "w": 19, - "h": 16 - } - }, - { - "filename": "965", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 10, - "y": 12, - "w": 19, - "h": 16 - }, - "frame": { - "x": 135, - "y": 575, - "w": 19, - "h": 16 - } - }, - { - "filename": "965s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 10, - "y": 12, - "w": 19, - "h": 16 - }, - "frame": { - "x": 155, - "y": 546, - "w": 19, - "h": 16 + "x": 150, + "y": 558, + "w": 18, + "h": 19 } }, { @@ -5589,12 +5505,327 @@ "h": 17 }, "frame": { - "x": 154, - "y": 562, + "x": 150, + "y": 577, "w": 18, "h": 17 } }, + { + "filename": "999-roaming", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 13, + "y": 10, + "w": 14, + "h": 18 + }, + "frame": { + "x": 168, + "y": 558, + "w": 14, + "h": 18 + } + }, + { + "filename": "946s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 12, + "w": 19, + "h": 16 + }, + "frame": { + "x": 182, + "y": 559, + "w": 19, + "h": 16 + } + }, + { + "filename": "912", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 13, + "y": 9, + "w": 15, + "h": 19 + }, + "frame": { + "x": 168, + "y": 576, + "w": 15, + "h": 19 + } + }, + { + "filename": "958s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 11, + "y": 8, + "w": 17, + "h": 20 + }, + "frame": { + "x": 183, + "y": 575, + "w": 17, + "h": 20 + } + }, + { + "filename": "965", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 12, + "w": 19, + "h": 16 + }, + "frame": { + "x": 203, + "y": 535, + "w": 19, + "h": 16 + } + }, + { + "filename": "922", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 12, + "y": 9, + "w": 17, + "h": 19 + }, + "frame": { + "x": 201, + "y": 551, + "w": 17, + "h": 19 + } + }, + { + "filename": "912s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 13, + "y": 9, + "w": 15, + "h": 19 + }, + "frame": { + "x": 218, + "y": 551, + "w": 15, + "h": 19 + } + }, + { + "filename": "922s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 12, + "y": 9, + "w": 17, + "h": 19 + }, + "frame": { + "x": 233, + "y": 543, + "w": 17, + "h": 19 + } + }, + { + "filename": "926", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 11, + "y": 13, + "w": 17, + "h": 15 + }, + "frame": { + "x": 233, + "y": 562, + "w": 17, + "h": 15 + } + }, + { + "filename": "965s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 10, + "y": 12, + "w": 19, + "h": 16 + }, + "frame": { + "x": 201, + "y": 570, + "w": 19, + "h": 16 + } + }, + { + "filename": "928", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 13, + "y": 10, + "w": 13, + "h": 18 + }, + "frame": { + "x": 220, + "y": 570, + "w": 13, + "h": 18 + } + }, + { + "filename": "926s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 11, + "y": 13, + "w": 17, + "h": 15 + }, + "frame": { + "x": 233, + "y": 577, + "w": 17, + "h": 15 + } + }, + { + "filename": "969", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 11, + "y": 16, + "w": 18, + "h": 12 + }, + "frame": { + "x": 200, + "y": 586, + "w": 18, + "h": 12 + } + }, + { + "filename": "960", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 12, + "y": 10, + "w": 15, + "h": 18 + }, + "frame": { + "x": 218, + "y": 588, + "w": 15, + "h": 18 + } + }, + { + "filename": "940", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 11, + "y": 14, + "w": 17, + "h": 14 + }, + "frame": { + "x": 233, + "y": 592, + "w": 17, + "h": 14 + } + }, { "filename": "969s", "rotated": false, @@ -5610,8 +5841,8 @@ "h": 12 }, "frame": { - "x": 154, - "y": 579, + "x": 114, + "y": 591, "w": 18, "h": 12 } @@ -5631,35 +5862,14 @@ "h": 17 }, "frame": { - "x": 195, - "y": 489, + "x": 110, + "y": 603, "w": 18, "h": 17 } }, { - "filename": "928", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 13, - "y": 10, - "w": 13, - "h": 18 - }, - "frame": { - "x": 213, - "y": 489, - "w": 13, - "h": 18 - } - }, - { - "filename": "926", + "filename": "940s", "rotated": false, "trimmed": true, "sourceSize": { @@ -5668,57 +5878,15 @@ }, "spriteSourceSize": { "x": 11, - "y": 13, + "y": 14, "w": 17, - "h": 15 + "h": 14 }, "frame": { - "x": 226, - "y": 495, + "x": 132, + "y": 594, "w": 17, - "h": 15 - } - }, - { - "filename": "926s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 11, - "y": 13, - "w": 17, - "h": 15 - }, - "frame": { - "x": 195, - "y": 506, - "w": 17, - "h": 15 - } - }, - { - "filename": "999s-roaming", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 13, - "y": 10, - "w": 14, - "h": 18 - }, - "frame": { - "x": 212, - "y": 507, - "w": 14, - "h": 18 + "h": 14 } }, { @@ -5736,14 +5904,14 @@ "h": 16 }, "frame": { - "x": 226, - "y": 510, + "x": 149, + "y": 594, "w": 17, "h": 16 } }, { - "filename": "940", + "filename": "955s", "rotated": false, "trimmed": true, "sourceSize": { @@ -5752,15 +5920,15 @@ }, "spriteSourceSize": { "x": 11, - "y": 14, + "y": 12, "w": 17, - "h": 14 + "h": 16 }, "frame": { - "x": 175, - "y": 511, + "x": 166, + "y": 595, "w": 17, - "h": 14 + "h": 16 } }, { @@ -5778,12 +5946,54 @@ "h": 18 }, "frame": { - "x": 174, - "y": 525, + "x": 183, + "y": 595, "w": 16, "h": 18 } }, + { + "filename": "919", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 12, + "y": 13, + "w": 16, + "h": 15 + }, + "frame": { + "x": 199, + "y": 598, + "w": 16, + "h": 15 + } + }, + { + "filename": "919s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 12, + "y": 13, + "w": 16, + "h": 15 + }, + "frame": { + "x": 128, + "y": 608, + "w": 16, + "h": 15 + } + }, { "filename": "921s", "rotated": false, @@ -5799,12 +6009,54 @@ "h": 18 }, "frame": { - "x": 174, - "y": 543, + "x": 144, + "y": 610, "w": 16, "h": 18 } }, + { + "filename": "960s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 12, + "y": 10, + "w": 15, + "h": 18 + }, + "frame": { + "x": 109, + "y": 628, + "w": 15, + "h": 18 + } + }, + { + "filename": "999s-roaming", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 13, + "y": 10, + "w": 14, + "h": 18 + }, + "frame": { + "x": 124, + "y": 628, + "w": 14, + "h": 18 + } + }, { "filename": "928s", "rotated": false, @@ -5820,8 +6072,8 @@ "h": 18 }, "frame": { - "x": 172, - "y": 562, + "x": 138, + "y": 628, "w": 13, "h": 18 } @@ -5841,8 +6093,8 @@ "h": 17 }, "frame": { - "x": 185, - "y": 561, + "x": 160, + "y": 611, "w": 16, "h": 17 } @@ -5862,138 +6114,12 @@ "h": 17 }, "frame": { - "x": 190, - "y": 525, + "x": 151, + "y": 628, "w": 16, "h": 17 } }, - { - "filename": "955s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 11, - "y": 12, - "w": 17, - "h": 16 - }, - "frame": { - "x": 190, - "y": 542, - "w": 17, - "h": 16 - } - }, - { - "filename": "919s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 12, - "y": 13, - "w": 16, - "h": 15 - }, - "frame": { - "x": 206, - "y": 525, - "w": 16, - "h": 15 - } - }, - { - "filename": "944", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 12, - "y": 13, - "w": 16, - "h": 15 - }, - "frame": { - "x": 207, - "y": 540, - "w": 16, - "h": 15 - } - }, - { - "filename": "940s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 11, - "y": 14, - "w": 17, - "h": 14 - }, - "frame": { - "x": 222, - "y": 526, - "w": 17, - "h": 14 - } - }, - { - "filename": "944s", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 12, - "y": 13, - "w": 16, - "h": 15 - }, - "frame": { - "x": 223, - "y": 540, - "w": 16, - "h": 15 - } - }, - { - "filename": "938", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 40, - "h": 30 - }, - "spriteSourceSize": { - "x": 14, - "y": 12, - "w": 11, - "h": 16 - }, - "frame": { - "x": 239, - "y": 526, - "w": 11, - "h": 16 - } - }, { "filename": "938s", "rotated": false, @@ -6009,12 +6135,96 @@ "h": 16 }, "frame": { - "x": 239, - "y": 542, + "x": 167, + "y": 628, "w": 11, "h": 16 } }, + { + "filename": "944", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 12, + "y": 13, + "w": 16, + "h": 15 + }, + "frame": { + "x": 176, + "y": 613, + "w": 16, + "h": 15 + } + }, + { + "filename": "944s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 12, + "y": 13, + "w": 16, + "h": 15 + }, + "frame": { + "x": 192, + "y": 613, + "w": 16, + "h": 15 + } + }, + { + "filename": "996", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 12, + "y": 12, + "w": 15, + "h": 16 + }, + "frame": { + "x": 178, + "y": 628, + "w": 15, + "h": 16 + } + }, + { + "filename": "996s", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 12, + "y": 12, + "w": 15, + "h": 16 + }, + "frame": { + "x": 193, + "y": 628, + "w": 15, + "h": 16 + } + }, { "filename": "978-curly", "rotated": false, @@ -6030,8 +6240,8 @@ "h": 14 }, "frame": { - "x": 207, - "y": 555, + "x": 208, + "y": 613, "w": 15, "h": 14 } @@ -6051,8 +6261,8 @@ "h": 14 }, "frame": { - "x": 222, - "y": 555, + "x": 208, + "y": 627, "w": 15, "h": 14 } @@ -6072,8 +6282,8 @@ "h": 14 }, "frame": { - "x": 237, - "y": 558, + "x": 223, + "y": 606, "w": 15, "h": 14 } @@ -6093,8 +6303,8 @@ "h": 14 }, "frame": { - "x": 201, - "y": 569, + "x": 223, + "y": 620, "w": 15, "h": 14 } @@ -6114,8 +6324,8 @@ "h": 14 }, "frame": { - "x": 216, - "y": 569, + "x": 238, + "y": 606, "w": 15, "h": 14 } @@ -6135,8 +6345,8 @@ "h": 14 }, "frame": { - "x": 231, - "y": 572, + "x": 238, + "y": 620, "w": 15, "h": 14 } @@ -6147,6 +6357,6 @@ "meta": { "app": "https://www.codeandweb.com/texturepacker", "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:d412b44b05c0ac7988fc321b8a4eb571:51dd93a83920102d7a1b879808f62790:6fb417eff82c0971c86b4818772ba292$" + "smartupdate": "$TexturePacker:SmartUpdate:b180859bc4c006d56ee5322ca73fa54e:212d282258f5086ad99b3b2b95f7ec1a:6fb417eff82c0971c86b4818772ba292$" } } diff --git a/public/images/pokemon_icons_9.png b/public/images/pokemon_icons_9.png index 6123a15cbe9..2985fb800d6 100644 Binary files a/public/images/pokemon_icons_9.png and b/public/images/pokemon_icons_9.png differ diff --git a/public/images/pokemon_icons_9v.json b/public/images/pokemon_icons_9v.json index 83a47f101fa..6c8b93208e3 100644 --- a/public/images/pokemon_icons_9v.json +++ b/public/images/pokemon_icons_9v.json @@ -1,1047 +1,3296 @@ -{ "frames": { - "1000_1": { - "frame": { "x": 93, "y": 139, "w": 22, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 1, "w": 22, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "1000_2": { - "frame": { "x": 170, "y": 135, "w": 22, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 1, "w": 22, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "1000_3": { - "frame": { "x": 192, "y": 135, "w": 22, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 1, "w": 22, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "1001_2": { - "frame": { "x": 249, "y": 0, "w": 30, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 0, "w": 30, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "1001_3": { - "frame": { "x": 279, "y": 0, "w": 30, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 0, "w": 30, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "1003_2": { - "frame": { "x": 27, "y": 58, "w": 28, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 0, "w": 28, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "1003_3": { - "frame": { "x": 55, "y": 58, "w": 28, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 0, "w": 28, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "1004_2": { - "frame": { "x": 249, "y": 207, "w": 21, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 8, "w": 21, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "1004_3": { - "frame": { "x": 204, "y": 206, "w": 21, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 8, "w": 21, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "1006_2": { - "frame": { "x": 44, "y": 140, "w": 22, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 1, "w": 22, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "1006_3": { - "frame": { "x": 22, "y": 139, "w": 22, "h": 27 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 1, "w": 22, "h": 27 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "1007-apex-build_2": { - "frame": { "x": 155, "y": 0, "w": 32, "h": 29 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 0, "w": 32, "h": 29 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "1007-apex-build_3": { - "frame": { "x": 187, "y": 0, "w": 32, "h": 29 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 0, "w": 32, "h": 29 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "1008-ultimate-mode_1": { - "frame": { "x": 185, "y": 29, "w": 30, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 0, "w": 30, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "1008-ultimate-mode_2": { - "frame": { "x": 155, "y": 29, "w": 30, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 0, "w": 30, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "1008-ultimate-mode_3": { - "frame": { "x": 219, "y": 0, "w": 30, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 0, "w": 30, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "1010_2": { - "frame": { "x": 271, "y": 179, "w": 21, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 2, "w": 21, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "1010_3": { - "frame": { "x": 162, "y": 182, "w": 21, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 2, "w": 21, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "1018_2": { - "frame": { "x": 0, "y": 0, "w": 31, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 0, "w": 31, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "1018_3": { - "frame": { "x": 31, "y": 0, "w": 31, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 0, "w": 31, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "1022_2": { - "frame": { "x": 27, "y": 86, "w": 29, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 3, "w": 29, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "1022_3": { - "frame": { "x": 163, "y": 84, "w": 29, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 3, "w": 29, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "1023_2": { - "frame": { "x": 300, "y": 30, "w": 20, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 1, "w": 20, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "1023_3": { - "frame": { "x": 46, "y": 167, "w": 20, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 1, "w": 20, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "8901_1": { - "frame": { "x": 30, "y": 30, "w": 30, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 1, "w": 30, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "8901_2": { - "frame": { "x": 60, "y": 30, "w": 30, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 1, "w": 30, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "8901_3": { - "frame": { "x": 0, "y": 30, "w": 30, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 1, "w": 30, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "909_2": { - "frame": { "x": 42, "y": 195, "w": 21, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 21, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "909_3": { - "frame": { "x": 63, "y": 196, "w": 21, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 5, "w": 21, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "910_2": { - "frame": { "x": 271, "y": 205, "w": 21, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 4, "w": 21, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "910_3": { - "frame": { "x": 292, "y": 204, "w": 21, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 4, "w": 21, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "911_2": { - "frame": { "x": 131, "y": 112, "w": 28, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 3, "w": 28, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "911_3": { - "frame": { "x": 188, "y": 112, "w": 28, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 3, "w": 28, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "912_2": { - "frame": { "x": 36, "y": 244, "w": 15, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 9, "w": 15, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "912_3": { - "frame": { "x": 178, "y": 244, "w": 15, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 9, "w": 15, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "913_2": { - "frame": { "x": 84, "y": 217, "w": 17, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 5, "w": 17, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "913_3": { - "frame": { "x": 197, "y": 59, "w": 17, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 5, "w": 17, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "914_2": { - "frame": { "x": 122, "y": 135, "w": 24, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 3, "w": 24, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "914_3": { - "frame": { "x": 146, "y": 135, "w": 24, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 3, "w": 24, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "919_1": { - "frame": { "x": 0, "y": 253, "w": 16, "h": 15 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 13, "w": 16, "h": 15 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "919_2": { - "frame": { "x": 51, "y": 250, "w": 16, "h": 15 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 13, "w": 16, "h": 15 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "919_3": { - "frame": { "x": 95, "y": 247, "w": 16, "h": 15 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 13, "w": 16, "h": 15 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "920_1": { - "frame": { "x": 0, "y": 190, "w": 22, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 22, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "920_2": { - "frame": { "x": 208, "y": 183, "w": 22, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 22, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "920_3": { - "frame": { "x": 0, "y": 143, "w": 22, "h": 23 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 5, "w": 22, "h": 23 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "924_1": { - "frame": { "x": 237, "y": 152, "w": 29, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 8, "w": 29, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "924_2": { - "frame": { "x": 144, "y": 162, "w": 29, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 8, "w": 29, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "924_3": { - "frame": { "x": 266, "y": 159, "w": 29, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 8, "w": 29, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "925-four_1": { - "frame": { "x": 93, "y": 117, "w": 29, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 6, "w": 29, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "925-four_2": { - "frame": { "x": 245, "y": 130, "w": 29, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 6, "w": 29, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "925-four_3": { - "frame": { "x": 216, "y": 112, "w": 29, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 6, "w": 29, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "925-three_1": { - "frame": { "x": 115, "y": 160, "w": 29, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 8, "w": 29, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "925-three_2": { - "frame": { "x": 202, "y": 163, "w": 29, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 8, "w": 29, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "925-three_3": { - "frame": { "x": 173, "y": 162, "w": 29, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 8, "w": 29, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "932_2": { - "frame": { "x": 202, "y": 226, "w": 18, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 9, "w": 18, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "932_3": { - "frame": { "x": 292, "y": 225, "w": 18, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 9, "w": 18, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "933_2": { - "frame": { "x": 183, "y": 183, "w": 25, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 7, "w": 25, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "933_3": { - "frame": { "x": 292, "y": 183, "w": 25, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 7, "w": 25, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "934_2": { - "frame": { "x": 273, "y": 30, "w": 27, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 0, "w": 27, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "934_3": { - "frame": { "x": 0, "y": 58, "w": 27, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 0, "w": 27, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "935_1": { - "frame": { "x": 300, "y": 244, "w": 13, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 7, "w": 13, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "935_2": { - "frame": { "x": 287, "y": 244, "w": 13, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 7, "w": 13, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "935_3": { - "frame": { "x": 236, "y": 241, "w": 13, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 13, "y": 7, "w": 13, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "936_1": { - "frame": { "x": 251, "y": 179, "w": 20, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 0, "w": 20, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "936_2": { - "frame": { "x": 66, "y": 168, "w": 20, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 0, "w": 20, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "936_3": { - "frame": { "x": 231, "y": 172, "w": 20, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 0, "w": 20, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "937_1": { - "frame": { "x": 215, "y": 30, "w": 29, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 0, "w": 29, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "937_2": { - "frame": { "x": 244, "y": 30, "w": 29, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 0, "w": 29, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "937_3": { - "frame": { "x": 90, "y": 30, "w": 29, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 0, "w": 29, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "937_9": { - "frame": { "x": 119, "y": 30, "w": 29, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 5, "y": 0, "w": 29, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "940_2": { - "frame": { "x": 245, "y": 116, "w": 17, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 14, "w": 17, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "940_3": { - "frame": { "x": 153, "y": 254, "w": 17, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 14, "w": 17, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "941_2": { - "frame": { "x": 183, "y": 204, "w": 21, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 7, "w": 21, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "941_3": { - "frame": { "x": 125, "y": 204, "w": 21, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 7, "w": 21, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "948_2": { - "frame": { "x": 249, "y": 227, "w": 16, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 7, "w": 16, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "948_3": { - "frame": { "x": 0, "y": 232, "w": 16, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 7, "w": 16, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "949_2": { - "frame": { "x": 22, "y": 193, "w": 20, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 3, "w": 20, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "949_3": { - "frame": { "x": 86, "y": 192, "w": 20, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 3, "w": 20, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "951_2": { - "frame": { "x": 220, "y": 241, "w": 16, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 8, "w": 16, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "951_3": { - "frame": { "x": 162, "y": 234, "w": 16, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 8, "w": 16, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "952_2": { - "frame": { "x": 112, "y": 180, "w": 25, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 6, "w": 25, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "952_3": { - "frame": { "x": 137, "y": 182, "w": 25, "h": 22 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 6, "w": 25, "h": 22 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "953_2": { - "frame": { "x": 51, "y": 219, "w": 24, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 12, "w": 24, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "953_3": { - "frame": { "x": 225, "y": 225, "w": 24, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 12, "w": 24, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "954_2": { - "frame": { "x": 296, "y": 130, "w": 21, "h": 29 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 0, "w": 21, "h": 29 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "954_3": { - "frame": { "x": 216, "y": 134, "w": 21, "h": 29 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 0, "w": 21, "h": 29 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "957_1": { - "frame": { "x": 193, "y": 245, "w": 16, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 11, "w": 16, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "957_2": { - "frame": { "x": 301, "y": 113, "w": 16, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 11, "w": 16, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "957_3": { - "frame": { "x": 265, "y": 246, "w": 16, "h": 17 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 11, "w": 16, "h": 17 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "958_1": { - "frame": { "x": 270, "y": 226, "w": 17, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 8, "w": 17, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "958_2": { - "frame": { "x": 145, "y": 227, "w": 17, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 8, "w": 17, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "958_3": { - "frame": { "x": 101, "y": 227, "w": 17, "h": 20 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 8, "w": 17, "h": 20 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "959_1": { - "frame": { "x": 62, "y": 0, "w": 31, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 0, "w": 31, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "959_2": { - "frame": { "x": 93, "y": 0, "w": 31, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 0, "w": 31, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "959_3": { - "frame": { "x": 124, "y": 0, "w": 31, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 0, "w": 31, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "962_1": { - "frame": { "x": 301, "y": 88, "w": 19, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 3, "w": 19, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "962_2": { - "frame": { "x": 230, "y": 200, "w": 19, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 3, "w": 19, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "962_3": { - "frame": { "x": 106, "y": 202, "w": 19, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 3, "w": 19, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "967_2": { - "frame": { "x": 182, "y": 225, "w": 20, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 9, "w": 20, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "967_3": { - "frame": { "x": 125, "y": 225, "w": 20, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 9, "w": 20, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "968_2": { - "frame": { "x": 48, "y": 112, "w": 23, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 0, "w": 23, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "968_3": { - "frame": { "x": 25, "y": 111, "w": 23, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 0, "w": 23, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "969_2": { - "frame": { "x": 16, "y": 260, "w": 18, "h": 12 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 16, "w": 18, "h": 12 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "969_3": { - "frame": { "x": 67, "y": 255, "w": 18, "h": 12 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 11, "y": 16, "w": 18, "h": 12 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "970_2": { - "frame": { "x": 118, "y": 244, "w": 20, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 12, "w": 20, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "970_3": { - "frame": { "x": 16, "y": 244, "w": 20, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 12, "w": 20, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "973_1": { - "frame": { "x": 167, "y": 208, "w": 15, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 2, "w": 15, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "973_2": { - "frame": { "x": 21, "y": 218, "w": 15, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 2, "w": 15, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "973_3": { - "frame": { "x": 36, "y": 218, "w": 15, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 2, "w": 15, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "974_2": { - "frame": { "x": 73, "y": 240, "w": 22, "h": 15 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 13, "w": 22, "h": 15 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "974_3": { - "frame": { "x": 51, "y": 235, "w": 22, "h": 15 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 13, "w": 22, "h": 15 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "975_2": { - "frame": { "x": 269, "y": 109, "w": 32, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 7, "w": 32, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "975_3": { - "frame": { "x": 269, "y": 88, "w": 32, "h": 21 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 4, "y": 7, "w": 32, "h": 21 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "978-curly_2": { - "frame": { "x": 111, "y": 260, "w": 15, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 14, "w": 15, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "978-curly_3": { - "frame": { "x": 209, "y": 261, "w": 15, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 14, "w": 15, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "978-droopy_2": { - "frame": { "x": 85, "y": 262, "w": 15, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 14, "w": 15, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "978-droopy_3": { - "frame": { "x": 193, "y": 262, "w": 15, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 14, "w": 15, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "978-stretchy_2": { - "frame": { "x": 224, "y": 262, "w": 15, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 14, "w": 15, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "978-stretchy_3": { - "frame": { "x": 34, "y": 263, "w": 15, "h": 14 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 14, "w": 15, "h": 14 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "979_1": { - "frame": { "x": 56, "y": 86, "w": 27, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 2, "w": 27, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "979_2": { - "frame": { "x": 192, "y": 86, "w": 27, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 2, "w": 27, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "979_3": { - "frame": { "x": 219, "y": 86, "w": 27, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 2, "w": 27, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "981_2.png": { - "frame": { "x": 108, "y": 87, "w": 23, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 0, "w": 23, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "981_3.png": { - "frame": { "x": 246, "y": 86, "w": 23, "h": 30 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 0, "w": 23, "h": 30 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "982-three-segment_2": { - "frame": { "x": 83, "y": 87, "w": 25, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 1, "w": 25, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "982-three-segment_3": { - "frame": { "x": 295, "y": 60, "w": 25, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 1, "w": 25, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "982_2": { - "frame": { "x": 24, "y": 167, "w": 22, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 2, "w": 22, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "982_3": { - "frame": { "x": 90, "y": 166, "w": 22, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 2, "w": 22, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "987_1": { - "frame": { "x": 66, "y": 144, "w": 24, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 4, "w": 24, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "987_2": { - "frame": { "x": 295, "y": 159, "w": 24, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 4, "w": 24, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "987_3": { - "frame": { "x": 0, "y": 166, "w": 24, "h": 24 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 10, "y": 4, "w": 24, "h": 24 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "988_2": { - "frame": { "x": 137, "y": 84, "w": 26, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 1, "w": 26, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "988_3": { - "frame": { "x": 269, "y": 60, "w": 26, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 1, "w": 26, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "993_2": { - "frame": { "x": 167, "y": 59, "w": 30, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 2, "w": 30, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "993_3": { - "frame": { "x": 137, "y": 59, "w": 30, "h": 25 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 6, "y": 2, "w": 30, "h": 25 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "994_2": { - "frame": { "x": 242, "y": 58, "w": 27, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 1, "w": 27, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "994_3": { - "frame": { "x": 215, "y": 58, "w": 27, "h": 28 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 1, "w": 27, "h": 28 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "995_2": { - "frame": { "x": 110, "y": 58, "w": 27, "h": 29 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 0, "w": 27, "h": 29 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "995_3": { - "frame": { "x": 83, "y": 58, "w": 27, "h": 29 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 8, "y": 0, "w": 27, "h": 29 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "996_2": { - "frame": { "x": 138, "y": 247, "w": 15, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 12, "w": 15, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "996_3": { - "frame": { "x": 249, "y": 248, "w": 15, "h": 16 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 12, "y": 12, "w": 15, "h": 16 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "997_2": { - "frame": { "x": 146, "y": 208, "w": 21, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 9, "w": 21, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "997_3": { - "frame": { "x": 0, "y": 213, "w": 21, "h": 19 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 9, "w": 21, "h": 19 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "998_2": { - "frame": { "x": 163, "y": 109, "w": 25, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 2, "w": 25, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "998_3": { - "frame": { "x": 0, "y": 88, "w": 25, "h": 26 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 7, "y": 2, "w": 25, "h": 26 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "999_1": { - "frame": { "x": 274, "y": 130, "w": 22, "h": 29 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 0, "w": 22, "h": 29 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "999_2": { - "frame": { "x": 71, "y": 115, "w": 22, "h": 29 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 0, "w": 22, "h": 29 }, - "sourceSize": { "w": 40, "h": 30 } - }, - "999_3": { - "frame": { "x": 0, "y": 114, "w": 22, "h": 29 }, - "rotated": false, - "trimmed": true, - "spriteSourceSize": { "x": 9, "y": 0, "w": 22, "h": 29 }, - "sourceSize": { "w": 40, "h": 30 } - } - }, - "meta": { - "app": "https://www.aseprite.org/", - "version": "1.3.7-dev", - "image": "pokemon_icons_9v.png", - "format": "RGBA8888", - "size": { "w": 320, "h": 277 }, - "scale": "1" - } +{ + "textures": [ + { + "image": "pokemon_icons_9v.png", + "format": "RGBA8888", + "size": { + "w": 450, + "h": 450 + }, + "scale": 1, + "frames": [ + { + "filename": "909_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "909_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "910_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "910_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "911_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "911_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "912_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "912_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "913_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "913_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "914_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 0, + "w": 40, + "h": 30 + } + }, + { + "filename": "914_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "919_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "919_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "919_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "920_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "920_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "920_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "924_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "924_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "924_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "925-four_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 30, + "w": 40, + "h": 30 + } + }, + { + "filename": "925-four_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "925-four_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "925-three_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "925-three_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "925-three_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "932_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "932_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "933_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "933_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "934_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "934_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 60, + "w": 40, + "h": 30 + } + }, + { + "filename": "935_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "935_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "935_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "936_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "936_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "936_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "937_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "937_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "937_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "937_9", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "940_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 90, + "w": 40, + "h": 30 + } + }, + { + "filename": "940_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "941_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "941_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "944_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "944_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "945_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "945_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "948_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "948_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "949_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "949_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 120, + "w": 40, + "h": 30 + } + }, + { + "filename": "951_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "951_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "952_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "952_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "953_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "953_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "954_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "954_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "957_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "957_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "957_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 150, + "w": 40, + "h": 30 + } + }, + { + "filename": "958_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "958_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "958_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "959_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "959_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "959_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "962_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "962_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "962_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "967_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "967_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 180, + "w": 40, + "h": 30 + } + }, + { + "filename": "968_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "968_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "969_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "969_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "970_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "970_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "973_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "973_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "973_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "974_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "974_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 210, + "w": 40, + "h": 30 + } + }, + { + "filename": "975_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "975_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "978-curly_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "978-curly_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "978-droopy_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "978-droopy_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "978-stretchy_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "978-stretchy_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "979_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "979_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "979_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 240, + "w": 40, + "h": 30 + } + }, + { + "filename": "981_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "981_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "982-three-segment_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "982-three-segment_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "982_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "982_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "987_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "987_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "987_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "988_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "988_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 270, + "w": 40, + "h": 30 + } + }, + { + "filename": "993_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "993_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "994_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "994_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "995_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "995_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "996_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "996_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "997_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "997_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "998_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 300, + "w": 40, + "h": 30 + } + }, + { + "filename": "998_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "999_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "999_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "999_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "1000_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "1000_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "1000_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "1001_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "1001_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "1003_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "1003_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 330, + "w": 40, + "h": 30 + } + }, + { + "filename": "1004_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "1004_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "1006_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "1006_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "1007-apex-build_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "1007-apex-build_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "1008-ultimate-mode_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "1008-ultimate-mode_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "1008-ultimate-mode_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "1010_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "1010_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 360, + "w": 40, + "h": 30 + } + }, + { + "filename": "1012-counterfeit_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "1012-counterfeit_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "1013-unremarkable_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 80, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "1013-unremarkable_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 120, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "1018_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 160, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "1018_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 200, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "1022_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 240, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "1022_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 280, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "1023_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 320, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "1023_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 360, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "8901_1", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 400, + "y": 390, + "w": 40, + "h": 30 + } + }, + { + "filename": "8901_2", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 0, + "y": 420, + "w": 40, + "h": 30 + } + }, + { + "filename": "8901_3", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 40, + "h": 30 + }, + "spriteSourceSize": { + "x": 0, + "y": 0, + "w": 40, + "h": 30 + }, + "frame": { + "x": 40, + "y": 420, + "w": 40, + "h": 30 + } + } + ] + } + ], + "meta": { + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0", + "smartupdate": "$TexturePacker:SmartUpdate:c13ec323095f727665fa953e64e98300:e7531bea9b5e1bef44def5b357c81630:3ec5c0bc286c296cfb7fa30a8b06f3da$" + } } diff --git a/public/images/pokemon_icons_9v.png b/public/images/pokemon_icons_9v.png index 5d0908d0590..f71b6c5ada5 100644 Binary files a/public/images/pokemon_icons_9v.png and b/public/images/pokemon_icons_9v.png differ diff --git a/public/images/statuses_ca_ES.json b/public/images/statuses_ca-ES.json similarity index 100% rename from public/images/statuses_ca_ES.json rename to public/images/statuses_ca-ES.json diff --git a/public/images/statuses_ca_ES.png b/public/images/statuses_ca-ES.png similarity index 100% rename from public/images/statuses_ca_ES.png rename to public/images/statuses_ca-ES.png diff --git a/public/images/statuses_es.json b/public/images/statuses_es-ES.json similarity index 98% rename from public/images/statuses_es.json rename to public/images/statuses_es-ES.json index 4b44aa117e4..dbb3783842a 100644 --- a/public/images/statuses_es.json +++ b/public/images/statuses_es-ES.json @@ -1,7 +1,7 @@ { "textures": [ { - "image": "statuses_es.png", + "image": "statuses_es-ES.png", "format": "RGBA8888", "size": { "w": 22, diff --git a/public/images/statuses_es.png b/public/images/statuses_es-ES.png similarity index 100% rename from public/images/statuses_es.png rename to public/images/statuses_es-ES.png diff --git a/public/images/statuses_it.png b/public/images/statuses_it.png index d372b989be9..af3107018f8 100644 Binary files a/public/images/statuses_it.png and b/public/images/statuses_it.png differ diff --git a/public/images/statuses_pt_BR.json b/public/images/statuses_pt-BR.json similarity index 100% rename from public/images/statuses_pt_BR.json rename to public/images/statuses_pt-BR.json diff --git a/public/images/statuses_pt_BR.png b/public/images/statuses_pt-BR.png similarity index 100% rename from public/images/statuses_pt_BR.png rename to public/images/statuses_pt-BR.png diff --git a/public/images/statuses_zh_CN.json b/public/images/statuses_zh-CN.json similarity index 100% rename from public/images/statuses_zh_CN.json rename to public/images/statuses_zh-CN.json diff --git a/public/images/statuses_zh_CN.png b/public/images/statuses_zh-CN.png similarity index 100% rename from public/images/statuses_zh_CN.png rename to public/images/statuses_zh-CN.png diff --git a/public/images/statuses_zh_TW.json b/public/images/statuses_zh-TW.json similarity index 100% rename from public/images/statuses_zh_TW.json rename to public/images/statuses_zh-TW.json diff --git a/public/images/statuses_zh_TW.png b/public/images/statuses_zh-TW.png similarity index 100% rename from public/images/statuses_zh_TW.png rename to public/images/statuses_zh-TW.png diff --git a/public/images/trainer/atticus.json b/public/images/trainer/atticus.json new file mode 100644 index 00000000000..95621998bf2 --- /dev/null +++ b/public/images/trainer/atticus.json @@ -0,0 +1,41 @@ +{ + "textures": [ + { + "image": "atticus.png", + "format": "RGBA8888", + "size": { + "w": 46, + "h": 46 + }, + "scale": 1, + "frames": [ + { + "filename": "0001.png", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 21, + "y": 33, + "w": 43, + "h": 46 + }, + "frame": { + "x": 0, + "y": 0, + "w": 43, + "h": 46 + } + } + ] + } + ], + "meta": { + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0", + "smartupdate": "$TexturePacker:SmartUpdate:6dcd7c3d3982793cbca0d6fcd1f9260e:19c44634629fadd9d039d23dc71ec987:d26ede35f15aa571d5a7a2dd2fb868e1$" + } +} diff --git a/public/images/trainer/atticus.png b/public/images/trainer/atticus.png new file mode 100644 index 00000000000..e3e7e870f2b Binary files /dev/null and b/public/images/trainer/atticus.png differ diff --git a/public/images/trainer/bug_type_superfan.json b/public/images/trainer/bug_type_superfan.json index 74dca3583d5..6a77fe69912 100644 --- a/public/images/trainer/bug_type_superfan.json +++ b/public/images/trainer/bug_type_superfan.json @@ -4,1458 +4,30 @@ "image": "bug_type_superfan.png", "format": "RGBA8888", "size": { - "w": 224, - "h": 224 + "w": 71, + "h": 71 }, "scale": 1, "frames": [ - { - "filename": "0009.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 5, - "y": 1, - "w": 52, - "h": 85 - }, - "frame": { - "x": 1, - "y": 1, - "w": 52, - "h": 85 - } - }, - { - "filename": "0010.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 5, - "y": 1, - "w": 52, - "h": 85 - }, - "frame": { - "x": 1, - "y": 1, - "w": 52, - "h": 85 - } - }, - { - "filename": "0011.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 9, - "y": 11, - "w": 60, - "h": 75 - }, - "frame": { - "x": 55, - "y": 1, - "w": 60, - "h": 75 - } - }, { "filename": "0001.png", "rotated": false, "trimmed": true, "sourceSize": { "w": 80, - "h": 86 + "h": 80 }, "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 + "x": 4, + "y": 9, + "w": 71, + "h": 71 }, "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0026.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0027.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0028.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0029.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0030.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0031.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0032.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0033.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0034.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0035.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0036.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0037.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0038.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0039.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0040.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0041.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0042.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0043.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0044.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0045.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0046.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0047.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0048.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0049.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0050.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0051.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0052.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0053.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0054.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0055.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0056.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0057.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0058.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0059.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0060.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0061.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0062.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0063.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0064.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0065.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0066.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0067.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0068.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0069.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 6, - "y": 18, - "w": 65, - "h": 68 - }, - "frame": { - "x": 117, - "y": 1, - "w": 65, - "h": 68 - } - }, - { - "filename": "0002.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 10, + "x": 0, "y": 0, - "w": 46, - "h": 86 - }, - "frame": { - "x": 1, - "y": 88, - "w": 46, - "h": 86 - } - }, - { - "filename": "0003.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 10, - "y": 0, - "w": 46, - "h": 86 - }, - "frame": { - "x": 1, - "y": 88, - "w": 46, - "h": 86 - } - }, - { - "filename": "0004.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 10, - "y": 0, - "w": 46, - "h": 86 - }, - "frame": { - "x": 1, - "y": 88, - "w": 46, - "h": 86 - } - }, - { - "filename": "0005.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 10, - "y": 0, - "w": 46, - "h": 86 - }, - "frame": { - "x": 1, - "y": 88, - "w": 46, - "h": 86 - } - }, - { - "filename": "0006.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 10, - "y": 0, - "w": 46, - "h": 86 - }, - "frame": { - "x": 1, - "y": 88, - "w": 46, - "h": 86 - } - }, - { - "filename": "0007.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 10, - "y": 0, - "w": 46, - "h": 86 - }, - "frame": { - "x": 1, - "y": 88, - "w": 46, - "h": 86 - } - }, - { - "filename": "0008.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 10, - "y": 0, - "w": 46, - "h": 86 - }, - "frame": { - "x": 1, - "y": 88, - "w": 46, - "h": 86 - } - }, - { - "filename": "0012.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 8, - "y": 19, - "w": 66, - "h": 67 - }, - "frame": { - "x": 49, - "y": 88, - "w": 66, - "h": 67 - } - }, - { - "filename": "0013.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 8, - "y": 19, - "w": 66, - "h": 67 - }, - "frame": { - "x": 49, - "y": 88, - "w": 66, - "h": 67 - } - }, - { - "filename": "0014.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 8, - "y": 20, - "w": 65, - "h": 66 - }, - "frame": { - "x": 49, - "y": 157, - "w": 65, - "h": 66 - } - }, - { - "filename": "0015.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 8, - "y": 20, - "w": 65, - "h": 66 - }, - "frame": { - "x": 49, - "y": 157, - "w": 65, - "h": 66 - } - }, - { - "filename": "0016.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 8, - "y": 20, - "w": 65, - "h": 66 - }, - "frame": { - "x": 116, - "y": 157, - "w": 65, - "h": 66 - } - }, - { - "filename": "0017.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 8, - "y": 20, - "w": 65, - "h": 66 - }, - "frame": { - "x": 116, - "y": 157, - "w": 65, - "h": 66 - } - }, - { - "filename": "0018.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 8, - "y": 20, - "w": 65, - "h": 66 - }, - "frame": { - "x": 116, - "y": 157, - "w": 65, - "h": 66 - } - }, - { - "filename": "0019.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 8, - "y": 20, - "w": 65, - "h": 66 - }, - "frame": { - "x": 116, - "y": 157, - "w": 65, - "h": 66 - } - }, - { - "filename": "0020.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 8, - "y": 20, - "w": 65, - "h": 66 - }, - "frame": { - "x": 116, - "y": 157, - "w": 65, - "h": 66 - } - }, - { - "filename": "0021.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 8, - "y": 20, - "w": 65, - "h": 66 - }, - "frame": { - "x": 116, - "y": 157, - "w": 65, - "h": 66 - } - }, - { - "filename": "0022.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 8, - "y": 20, - "w": 65, - "h": 66 - }, - "frame": { - "x": 116, - "y": 157, - "w": 65, - "h": 66 - } - }, - { - "filename": "0023.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 8, - "y": 20, - "w": 65, - "h": 66 - }, - "frame": { - "x": 116, - "y": 157, - "w": 65, - "h": 66 - } - }, - { - "filename": "0024.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 7, - "y": 19, - "w": 65, - "h": 67 - }, - "frame": { - "x": 117, - "y": 71, - "w": 65, - "h": 67 - } - }, - { - "filename": "0025.png", - "rotated": false, - "trimmed": true, - "sourceSize": { - "w": 80, - "h": 86 - }, - "spriteSourceSize": { - "x": 7, - "y": 19, - "w": 65, - "h": 67 - }, - "frame": { - "x": 117, - "y": 71, - "w": 65, - "h": 67 + "w": 71, + "h": 71 } } ] @@ -1464,6 +36,6 @@ "meta": { "app": "https://www.codeandweb.com/texturepacker", "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:442c13442d70348845d7f5fcdfc121b3:3b8402aa64ee8990e64c7f03ffffbc55:568199339797fd79d11ae8d741953c1c$" + "smartupdate": "$TexturePacker:SmartUpdate:d051332055512f245ae68e912a28cd81:4926ba3fd9fe432bb535d13f4df1df4e:621aca0914900a3b9e235ebf0431ce2b$" } } diff --git a/public/images/trainer/bug_type_superfan.png b/public/images/trainer/bug_type_superfan.png index 59316fe6ed8..0d2fd7a68ae 100644 Binary files a/public/images/trainer/bug_type_superfan.png and b/public/images/trainer/bug_type_superfan.png differ diff --git a/public/images/trainer/eri.json b/public/images/trainer/eri.json new file mode 100644 index 00000000000..fd4daf60437 --- /dev/null +++ b/public/images/trainer/eri.json @@ -0,0 +1,41 @@ +{ + "textures": [ + { + "image": "eri.png", + "format": "RGBA8888", + "size": { + "w": 74, + "h": 74 + }, + "scale": 1, + "frames": [ + { + "filename": "0001.png", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 15, + "y": 5, + "w": 45, + "h": 74 + }, + "frame": { + "x": 0, + "y": 0, + "w": 45, + "h": 74 + } + } + ] + } + ], + "meta": { + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0", + "smartupdate": "$TexturePacker:SmartUpdate:59594ac27e74ec85e2949d12ff680dc2:d65b6b00858ac47b26ef8393a8fa6795:d7f4cd3ff755f8074c14d3006b0c8301$" + } +} diff --git a/public/images/trainer/eri.png b/public/images/trainer/eri.png new file mode 100644 index 00000000000..0c9bdf7b47b Binary files /dev/null and b/public/images/trainer/eri.png differ diff --git a/public/images/trainer/expert_pokemon_breeder.json b/public/images/trainer/expert_pokemon_breeder.json new file mode 100644 index 00000000000..cd6ecffb267 --- /dev/null +++ b/public/images/trainer/expert_pokemon_breeder.json @@ -0,0 +1,41 @@ +{ + "textures": [ + { + "image": "expert_pokemon_breeder.png", + "format": "RGBA8888", + "size": { + "w": 39, + "h": 75 + }, + "scale": 1, + "frames": [ + { + "filename": "0001.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 21, + "y": 3, + "w": 39, + "h": 75 + }, + "frame": { + "x": 0, + "y": 0, + "w": 39, + "h": 75 + } + } + ] + } + ], + "meta": { + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0", + "smartupdate": "$TexturePacker:SmartUpdate:cb681265d8dca038a518ab14076fd140:18ff41b1ef6967682643a11695926e58:c59ea3971195f5a395b75223a77d9068$" + } +} diff --git a/public/images/trainer/expert_pokemon_breeder.png b/public/images/trainer/expert_pokemon_breeder.png new file mode 100644 index 00000000000..0625f5255c3 Binary files /dev/null and b/public/images/trainer/expert_pokemon_breeder.png differ diff --git a/public/images/trainer/future_self_f.json b/public/images/trainer/future_self_f.json new file mode 100644 index 00000000000..0831828c2bc --- /dev/null +++ b/public/images/trainer/future_self_f.json @@ -0,0 +1,41 @@ +{ + "textures": [ + { + "image": "future_self_f.png", + "format": "RGBA8888", + "size": { + "w": 29, + "h": 69 + }, + "scale": 1, + "frames": [ + { + "filename": "0001.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 69, + "h": 69 + }, + "spriteSourceSize": { + "x": 21, + "y": 0, + "w": 29, + "h": 69 + }, + "frame": { + "x": 0, + "y": 0, + "w": 29, + "h": 69 + } + } + ] + } + ], + "meta": { + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0", + "smartupdate": "$TexturePacker:SmartUpdate:4eb16332c2e77886e4e621b62269f05e:26f1bc53c853efdbe228d67604b95b54:d25525a5db42bd57d2afe4b6e3081ee1$" + } +} diff --git a/public/images/trainer/future_self_f.png b/public/images/trainer/future_self_f.png new file mode 100644 index 00000000000..e75c5e5e65b Binary files /dev/null and b/public/images/trainer/future_self_f.png differ diff --git a/public/images/pokemon/shiny/493_fairy.json b/public/images/trainer/future_self_m.json similarity index 61% rename from public/images/pokemon/shiny/493_fairy.json rename to public/images/trainer/future_self_m.json index 3ccbf2a62f0..f5d60ff5add 100644 --- a/public/images/pokemon/shiny/493_fairy.json +++ b/public/images/trainer/future_self_m.json @@ -1,10 +1,10 @@ { "textures": [ { - "image": "493_fairy.png", + "image": "future_self_m.png", "format": "RGBA8888", "size": { - "w": 73, + "w": 36, "h": 73 }, "scale": 1, @@ -12,21 +12,21 @@ { "filename": "0001.png", "rotated": false, - "trimmed": false, + "trimmed": true, "sourceSize": { - "w": 68, + "w": 73, "h": 73 }, "spriteSourceSize": { - "x": 0, + "x": 18, "y": 0, - "w": 68, + "w": 36, "h": 73 }, "frame": { "x": 0, "y": 0, - "w": 68, + "w": 36, "h": 73 } } @@ -36,6 +36,6 @@ "meta": { "app": "https://www.codeandweb.com/texturepacker", "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:21d367e918dcc1c9da1a9d03fc93d5de:9159643cdc690b7cbd14818421c841ee:e24ac309b5e37680dba5092fa1b46d1d$" + "smartupdate": "$TexturePacker:SmartUpdate:0d8d68d06ae75bc93d72b54183a9df02:d3d509801da9ff5c0bd4793a05ece391:83c4b8c2ed25ea7d9795bec5c40c8602$" } } diff --git a/public/images/trainer/future_self_m.png b/public/images/trainer/future_self_m.png new file mode 100644 index 00000000000..edd15cb6ea3 Binary files /dev/null and b/public/images/trainer/future_self_m.png differ diff --git a/public/images/trainer/giacomo.json b/public/images/trainer/giacomo.json new file mode 100644 index 00000000000..5eeb2cd685b --- /dev/null +++ b/public/images/trainer/giacomo.json @@ -0,0 +1,41 @@ +{ + "textures": [ + { + "image": "giacomo.png", + "format": "RGBA8888", + "size": { + "w": 75, + "h": 75 + }, + "scale": 1, + "frames": [ + { + "filename": "0001.png", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 23, + "y": 4, + "w": 37, + "h": 75 + }, + "frame": { + "x": 0, + "y": 0, + "w": 37, + "h": 75 + } + } + ] + } + ], + "meta": { + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0", + "smartupdate": "$TexturePacker:SmartUpdate:8c4e7da48e5667abc6d364330268c092:0fa43e58d8a746d3b86cb2dd763719f4:8603cc19e888c8c8de62177f4011577c$" + } +} diff --git a/public/images/trainer/giacomo.png b/public/images/trainer/giacomo.png new file mode 100644 index 00000000000..275f47fad3c Binary files /dev/null and b/public/images/trainer/giacomo.png differ diff --git a/public/images/pokemon/variant/6706_3.json b/public/images/trainer/mela.json similarity index 55% rename from public/images/pokemon/variant/6706_3.json rename to public/images/trainer/mela.json index 615ca90e004..c9db18acc5a 100644 --- a/public/images/pokemon/variant/6706_3.json +++ b/public/images/trainer/mela.json @@ -1,11 +1,11 @@ { "textures": [ { - "image": "6706_3.png", + "image": "mela.png", "format": "RGBA8888", "size": { - "w": 82, - "h": 82 + "w": 78, + "h": 78 }, "scale": 1, "frames": [ @@ -14,20 +14,20 @@ "rotated": false, "trimmed": false, "sourceSize": { - "w": 82, - "h": 72 + "w": 80, + "h": 80 }, "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 82, - "h": 72 + "x": 18, + "y": 1, + "w": 46, + "h": 78 }, "frame": { "x": 0, "y": 0, - "w": 82, - "h": 72 + "w": 46, + "h": 78 } } ] @@ -36,6 +36,6 @@ "meta": { "app": "https://www.codeandweb.com/texturepacker", "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:02eb46aa66ac70df612e129b7801a85c:a77cca14b23f4f3aece64d1a82449a0f:d60cc2e5ae2bd18de8ee3ab0649593ee$" + "smartupdate": "$TexturePacker:SmartUpdate:e26d8c926c54c848cef673b3f59f35e7:ff040c2cebb1a92d2ef61dc91c018390:68668cf06383ff459cccaafb6bf56215$" } -} \ No newline at end of file +} diff --git a/public/images/trainer/mela.png b/public/images/trainer/mela.png new file mode 100644 index 00000000000..fbb08ed69cf Binary files /dev/null and b/public/images/trainer/mela.png differ diff --git a/public/images/trainer/ortega.json b/public/images/trainer/ortega.json new file mode 100644 index 00000000000..53bab5dba40 --- /dev/null +++ b/public/images/trainer/ortega.json @@ -0,0 +1,41 @@ +{ + "textures": [ + { + "image": "ortega.png", + "format": "RGBA8888", + "size": { + "w": 69, + "h": 69 + }, + "scale": 1, + "frames": [ + { + "filename": "0001.png", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 8, + "y": 10, + "w": 53, + "h": 69 + }, + "frame": { + "x": 0, + "y": 0, + "w": 53, + "h": 69 + } + } + ] + } + ], + "meta": { + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0", + "smartupdate": "$TexturePacker:SmartUpdate:c6ff92d90ed884222095de81d1db9166:a91cf3c83a063f549c52afb42f7ba3b0:c3f9fcec121c8bc93f2b230b20b79c57$" + } +} diff --git a/public/images/trainer/ortega.png b/public/images/trainer/ortega.png new file mode 100644 index 00000000000..7f694c6ded6 Binary files /dev/null and b/public/images/trainer/ortega.png differ diff --git a/public/images/pokemon/variant/6706_2.json b/public/images/trainer/penny.json similarity index 55% rename from public/images/pokemon/variant/6706_2.json rename to public/images/trainer/penny.json index f6bbf20116e..da64efffa3b 100644 --- a/public/images/pokemon/variant/6706_2.json +++ b/public/images/trainer/penny.json @@ -1,11 +1,11 @@ { "textures": [ { - "image": "6706_2.png", + "image": "penny.png", "format": "RGBA8888", "size": { - "w": 82, - "h": 82 + "w": 75, + "h": 75 }, "scale": 1, "frames": [ @@ -14,20 +14,20 @@ "rotated": false, "trimmed": false, "sourceSize": { - "w": 82, - "h": 72 + "w": 80, + "h": 80 }, "spriteSourceSize": { - "x": 0, - "y": 0, - "w": 82, - "h": 72 + "x": 24, + "y": 4, + "w": 34, + "h": 75 }, "frame": { "x": 0, "y": 0, - "w": 82, - "h": 72 + "w": 34, + "h": 75 } } ] @@ -36,6 +36,6 @@ "meta": { "app": "https://www.codeandweb.com/texturepacker", "version": "3.0", - "smartupdate": "$TexturePacker:SmartUpdate:02eb46aa66ac70df612e129b7801a85c:a77cca14b23f4f3aece64d1a82449a0f:d60cc2e5ae2bd18de8ee3ab0649593ee$" + "smartupdate": "$TexturePacker:SmartUpdate:54f184bf1995a94a78aff33c9a851e6b:a6c9b3fe428b0cd0344b5cf14b999f36:cf221da9747cb8cb356053d3042d8d22$" } -} \ No newline at end of file +} diff --git a/public/images/trainer/penny.png b/public/images/trainer/penny.png new file mode 100644 index 00000000000..0e36760e21b Binary files /dev/null and b/public/images/trainer/penny.png differ diff --git a/public/images/trainer/snow_worker.json b/public/images/trainer/snow_worker.json new file mode 100644 index 00000000000..0c1a21133b9 --- /dev/null +++ b/public/images/trainer/snow_worker.json @@ -0,0 +1,1637 @@ +{ + "textures": [ + { + "image": "snow_worker_m.png", + "format": "RGBA8888", + "size": { + "w": 183, + "h": 183 + }, + "scale": 1, + "frames": [ + { + "filename": "0001.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0002.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0003.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0032.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0033.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0034.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0035.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0036.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0037.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0038.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0039.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0040.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0041.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0042.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0043.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0044.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0045.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0046.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0047.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0048.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0049.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0050.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0051.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0052.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0053.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0054.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0055.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0056.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0057.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0058.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0059.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0060.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0061.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0062.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0063.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0064.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0065.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0066.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0067.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0068.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0069.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0070.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0071.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0072.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0073.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0074.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0075.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0076.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0077.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 47, + "h": 60 + }, + "frame": { + "x": 1, + "y": 1, + "w": 47, + "h": 60 + } + }, + { + "filename": "0004.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 46, + "h": 60 + }, + "frame": { + "x": 1, + "y": 63, + "w": 46, + "h": 60 + } + }, + { + "filename": "0030.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 46, + "h": 60 + }, + "frame": { + "x": 1, + "y": 63, + "w": 46, + "h": 60 + } + }, + { + "filename": "0031.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 16, + "y": 20, + "w": 46, + "h": 60 + }, + "frame": { + "x": 1, + "y": 63, + "w": 46, + "h": 60 + } + }, + { + "filename": "0005.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 17, + "y": 21, + "w": 46, + "h": 59 + }, + "frame": { + "x": 49, + "y": 63, + "w": 46, + "h": 59 + } + }, + { + "filename": "0029.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 17, + "y": 21, + "w": 46, + "h": 59 + }, + "frame": { + "x": 49, + "y": 63, + "w": 46, + "h": 59 + } + }, + { + "filename": "0006.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 17, + "y": 21, + "w": 46, + "h": 59 + }, + "frame": { + "x": 50, + "y": 1, + "w": 46, + "h": 59 + } + }, + { + "filename": "0007.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 17, + "y": 21, + "w": 46, + "h": 59 + }, + "frame": { + "x": 50, + "y": 1, + "w": 46, + "h": 59 + } + }, + { + "filename": "0028.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 17, + "y": 21, + "w": 46, + "h": 59 + }, + "frame": { + "x": 50, + "y": 1, + "w": 46, + "h": 59 + } + }, + { + "filename": "0008.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 17, + "y": 21, + "w": 46, + "h": 59 + }, + "frame": { + "x": 98, + "y": 1, + "w": 46, + "h": 59 + } + }, + { + "filename": "0013.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 17, + "y": 21, + "w": 46, + "h": 59 + }, + "frame": { + "x": 98, + "y": 1, + "w": 46, + "h": 59 + } + }, + { + "filename": "0014.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 17, + "y": 21, + "w": 46, + "h": 59 + }, + "frame": { + "x": 98, + "y": 1, + "w": 46, + "h": 59 + } + }, + { + "filename": "0015.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 17, + "y": 21, + "w": 46, + "h": 59 + }, + "frame": { + "x": 98, + "y": 1, + "w": 46, + "h": 59 + } + }, + { + "filename": "0020.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 17, + "y": 21, + "w": 46, + "h": 59 + }, + "frame": { + "x": 98, + "y": 1, + "w": 46, + "h": 59 + } + }, + { + "filename": "0021.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 17, + "y": 21, + "w": 46, + "h": 59 + }, + "frame": { + "x": 98, + "y": 1, + "w": 46, + "h": 59 + } + }, + { + "filename": "0022.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 17, + "y": 21, + "w": 46, + "h": 59 + }, + "frame": { + "x": 98, + "y": 1, + "w": 46, + "h": 59 + } + }, + { + "filename": "0023.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 17, + "y": 21, + "w": 46, + "h": 59 + }, + "frame": { + "x": 98, + "y": 1, + "w": 46, + "h": 59 + } + }, + { + "filename": "0024.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 17, + "y": 21, + "w": 46, + "h": 59 + }, + "frame": { + "x": 98, + "y": 1, + "w": 46, + "h": 59 + } + }, + { + "filename": "0025.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 17, + "y": 21, + "w": 46, + "h": 59 + }, + "frame": { + "x": 98, + "y": 1, + "w": 46, + "h": 59 + } + }, + { + "filename": "0026.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 17, + "y": 21, + "w": 46, + "h": 59 + }, + "frame": { + "x": 98, + "y": 1, + "w": 46, + "h": 59 + } + }, + { + "filename": "0027.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 17, + "y": 21, + "w": 46, + "h": 59 + }, + "frame": { + "x": 98, + "y": 1, + "w": 46, + "h": 59 + } + }, + { + "filename": "0009.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 17, + "y": 21, + "w": 46, + "h": 59 + }, + "frame": { + "x": 97, + "y": 62, + "w": 46, + "h": 59 + } + }, + { + "filename": "0012.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 17, + "y": 21, + "w": 46, + "h": 59 + }, + "frame": { + "x": 97, + "y": 62, + "w": 46, + "h": 59 + } + }, + { + "filename": "0016.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 17, + "y": 21, + "w": 46, + "h": 59 + }, + "frame": { + "x": 97, + "y": 62, + "w": 46, + "h": 59 + } + }, + { + "filename": "0018.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 17, + "y": 21, + "w": 46, + "h": 59 + }, + "frame": { + "x": 97, + "y": 62, + "w": 46, + "h": 59 + } + }, + { + "filename": "0019.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 17, + "y": 21, + "w": 46, + "h": 59 + }, + "frame": { + "x": 97, + "y": 62, + "w": 46, + "h": 59 + } + }, + { + "filename": "0010.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 17, + "y": 21, + "w": 46, + "h": 59 + }, + "frame": { + "x": 97, + "y": 123, + "w": 46, + "h": 59 + } + }, + { + "filename": "0011.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 17, + "y": 21, + "w": 46, + "h": 59 + }, + "frame": { + "x": 97, + "y": 123, + "w": 46, + "h": 59 + } + }, + { + "filename": "0017.png", + "rotated": false, + "trimmed": true, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 17, + "y": 21, + "w": 46, + "h": 59 + }, + "frame": { + "x": 97, + "y": 123, + "w": 46, + "h": 59 + } + } + ] + } + ], + "meta": { + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0", + "smartupdate": "$TexturePacker:SmartUpdate:c523abd1fb0f9a15c395d98cc94abb21:5b387f1394fa7c00ff021a434a2c70e2:dd52c0c753a2ab4cf10a366fabd9abcb$" + } +} diff --git a/public/images/trainer/snow_worker.png b/public/images/trainer/snow_worker.png new file mode 100644 index 00000000000..0e39505cc8d Binary files /dev/null and b/public/images/trainer/snow_worker.png differ diff --git a/public/images/trainer/star_grunt_f.json b/public/images/trainer/star_grunt_f.json new file mode 100644 index 00000000000..e26477e3512 --- /dev/null +++ b/public/images/trainer/star_grunt_f.json @@ -0,0 +1,41 @@ +{ + "textures": [ + { + "image": "star_grunt_f.png", + "format": "RGBA8888", + "size": { + "w": 68, + "h": 68 + }, + "scale": 1, + "frames": [ + { + "filename": "0001.png", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 24, + "y": 11, + "w": 30, + "h": 68 + }, + "frame": { + "x": 0, + "y": 0, + "w": 30, + "h": 68 + } + } + ] + } + ], + "meta": { + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0", + "smartupdate": "$TexturePacker:SmartUpdate:b542a1bdd6995584fc776f75d578b434:f03fddece4494ab59698002fe6671972:c6f0e54e24ec5ffaa711700431b1955e$" + } +} diff --git a/public/images/trainer/star_grunt_f.png b/public/images/trainer/star_grunt_f.png new file mode 100644 index 00000000000..6eb63ae1e03 Binary files /dev/null and b/public/images/trainer/star_grunt_f.png differ diff --git a/public/images/trainer/star_grunt_m.json b/public/images/trainer/star_grunt_m.json new file mode 100644 index 00000000000..bf49e3027e6 --- /dev/null +++ b/public/images/trainer/star_grunt_m.json @@ -0,0 +1,41 @@ +{ + "textures": [ + { + "image": "star_grunt_m.png", + "format": "RGBA8888", + "size": { + "w": 70, + "h": 70 + }, + "scale": 1, + "frames": [ + { + "filename": "0001.png", + "rotated": false, + "trimmed": false, + "sourceSize": { + "w": 80, + "h": 80 + }, + "spriteSourceSize": { + "x": 24, + "y": 9, + "w": 31, + "h": 70 + }, + "frame": { + "x": 0, + "y": 0, + "w": 31, + "h": 70 + } + } + ] + } + ], + "meta": { + "app": "https://www.codeandweb.com/texturepacker", + "version": "3.0", + "smartupdate": "$TexturePacker:SmartUpdate:abc4b0424c37fd55a2bf2e9f5142adce:41a140aa68a1eda61d9a00cab4e07721:a0796711f9e0333796b6629cd43ff8e8$" + } +} diff --git a/public/images/trainer/star_grunt_m.png b/public/images/trainer/star_grunt_m.png new file mode 100644 index 00000000000..a69359eda8e Binary files /dev/null and b/public/images/trainer/star_grunt_m.png differ diff --git a/public/images/types_es.json b/public/images/types_es-ES.json similarity index 99% rename from public/images/types_es.json rename to public/images/types_es-ES.json index 0fb922e8939..198899c0f12 100644 --- a/public/images/types_es.json +++ b/public/images/types_es-ES.json @@ -1,7 +1,7 @@ { "textures": [ { - "image": "types_es.png", + "image": "types_es-ES.png", "format": "RGBA8888", "size": { "w": 32, diff --git a/public/images/types_es.png b/public/images/types_es-ES.png similarity index 100% rename from public/images/types_es.png rename to public/images/types_es-ES.png diff --git a/public/images/types_it.png b/public/images/types_it.png index 8b644f1041c..3be03aeea68 100644 Binary files a/public/images/types_it.png and b/public/images/types_it.png differ diff --git a/public/images/ui/friendship.png b/public/images/ui/friendship.png new file mode 100644 index 00000000000..073adcadc76 Binary files /dev/null and b/public/images/ui/friendship.png differ diff --git a/public/images/ui/friendship_overlay.png b/public/images/ui/friendship_overlay.png new file mode 100644 index 00000000000..4a4724fbdc9 Binary files /dev/null and b/public/images/ui/friendship_overlay.png differ diff --git a/public/images/ui/legacy/friendship.png b/public/images/ui/legacy/friendship.png new file mode 100644 index 00000000000..073adcadc76 Binary files /dev/null and b/public/images/ui/legacy/friendship.png differ diff --git a/public/images/ui/legacy/friendship_overlay.png b/public/images/ui/legacy/friendship_overlay.png new file mode 100644 index 00000000000..4a4724fbdc9 Binary files /dev/null and b/public/images/ui/legacy/friendship_overlay.png differ diff --git a/public/images/ui/legacy/link_icon.png b/public/images/ui/legacy/link_icon.png new file mode 100644 index 00000000000..56081261b9c Binary files /dev/null and b/public/images/ui/legacy/link_icon.png differ diff --git a/public/images/ui/legacy/unlink_icon.png b/public/images/ui/legacy/unlink_icon.png new file mode 100644 index 00000000000..f0da5f8e3ed Binary files /dev/null and b/public/images/ui/legacy/unlink_icon.png differ diff --git a/public/images/ui/link_icon.png b/public/images/ui/link_icon.png new file mode 100644 index 00000000000..56081261b9c Binary files /dev/null and b/public/images/ui/link_icon.png differ diff --git a/public/images/ui/unlink_icon.png b/public/images/ui/unlink_icon.png new file mode 100644 index 00000000000..f0da5f8e3ed Binary files /dev/null and b/public/images/ui/unlink_icon.png differ diff --git a/public/locales b/public/locales new file mode 160000 index 00000000000..ed1b1df4776 --- /dev/null +++ b/public/locales @@ -0,0 +1 @@ +Subproject commit ed1b1df4776ccd4330e8ac1d2f44de611d04c2bc diff --git a/src/@types/PokerogueAccountApi.ts b/src/@types/PokerogueAccountApi.ts new file mode 100644 index 00000000000..68d0a5e7730 --- /dev/null +++ b/src/@types/PokerogueAccountApi.ts @@ -0,0 +1,17 @@ +import type { UserInfo } from "#app/@types/UserInfo"; + +export interface AccountInfoResponse extends UserInfo {} + +export interface AccountLoginRequest { + username: string; + password: string; +} + +export interface AccountLoginResponse { + token: string; +} + +export interface AccountRegisterRequest { + username: string; + password: string; +} diff --git a/src/@types/PokerogueAdminApi.ts b/src/@types/PokerogueAdminApi.ts new file mode 100644 index 00000000000..2ee25b560d9 --- /dev/null +++ b/src/@types/PokerogueAdminApi.ts @@ -0,0 +1,31 @@ +export interface LinkAccountToDiscordIdRequest { + username: string; + discordId: string; +} + +export interface UnlinkAccountFromDiscordIdRequest { + username: string; + discordId: string; +} + +export interface LinkAccountToGoogledIdRequest { + username: string; + googleId: string; +} + +export interface UnlinkAccountFromGoogledIdRequest { + username: string; + googleId: string; +} + +export interface SearchAccountRequest { + username: string; +} + +export interface SearchAccountResponse { + username: string; + discordId: string; + googleId: string; + lastLoggedIn: string; + registered: string; +} diff --git a/src/@types/PokerogueApi.ts b/src/@types/PokerogueApi.ts new file mode 100644 index 00000000000..79755b23a54 --- /dev/null +++ b/src/@types/PokerogueApi.ts @@ -0,0 +1,4 @@ +export interface TitleStatsResponse { + playerCount: number; + battleCount: number; +} diff --git a/src/@types/PokerogueDailyApi.ts b/src/@types/PokerogueDailyApi.ts new file mode 100644 index 00000000000..3f3d8eb61ca --- /dev/null +++ b/src/@types/PokerogueDailyApi.ts @@ -0,0 +1,10 @@ +import type { ScoreboardCategory } from "#app/ui/daily-run-scoreboard"; + +export interface GetDailyRankingsRequest { + category: ScoreboardCategory; + page?: number; +} + +export interface GetDailyRankingsPageCountRequest { + category: ScoreboardCategory; +} diff --git a/src/@types/PokerogueSavedataApi.ts b/src/@types/PokerogueSavedataApi.ts new file mode 100644 index 00000000000..a313cd708c7 --- /dev/null +++ b/src/@types/PokerogueSavedataApi.ts @@ -0,0 +1,8 @@ +import type { SessionSaveData, SystemSaveData } from "#app/system/game-data"; + +export interface UpdateAllSavedataRequest { + system: SystemSaveData; + session: SessionSaveData; + sessionSlotId: number; + clientSessionId: string; +} diff --git a/src/@types/PokerogueSessionSavedataApi.ts b/src/@types/PokerogueSessionSavedataApi.ts new file mode 100644 index 00000000000..c4650611c4f --- /dev/null +++ b/src/@types/PokerogueSessionSavedataApi.ts @@ -0,0 +1,40 @@ +export class UpdateSessionSavedataRequest { + slot: number; + trainerId: number; + secretId: number; + clientSessionId: string; +} + +/** This is **NOT** similar to {@linkcode ClearSessionSavedataRequest} */ +export interface NewClearSessionSavedataRequest { + slot: number; + isVictory: boolean; + clientSessionId: string; +} + +export interface GetSessionSavedataRequest { + slot: number; + clientSessionId: string; +} + +export interface DeleteSessionSavedataRequest { + slot: number; + clientSessionId: string; +} + +/** This is **NOT** similar to {@linkcode NewClearSessionSavedataRequest} */ +export interface ClearSessionSavedataRequest { + slot: number; + trainerId: number; + clientSessionId: string; +} + +/** + * Pokerogue API response for path: `/savedata/session/clear` + */ +export interface ClearSessionSavedataResponse { + /** Contains the error message if any occured */ + error?: string; + /** Is `true` if the request was successfully processed */ + success?: boolean; +} diff --git a/src/@types/PokerogueSystemSavedataApi.ts b/src/@types/PokerogueSystemSavedataApi.ts new file mode 100644 index 00000000000..8ce160a5ec2 --- /dev/null +++ b/src/@types/PokerogueSystemSavedataApi.ts @@ -0,0 +1,20 @@ +import type { SystemSaveData } from "#app/system/game-data"; + +export interface GetSystemSavedataRequest { + clientSessionId: string; +} + +export class UpdateSystemSavedataRequest { + clientSessionId: string; + trainerId?: number; + secretId?: number; +} + +export interface VerifySystemSavedataRequest { + clientSessionId: string; +} + +export interface VerifySystemSavedataResponse { + valid: boolean; + systemData: SystemSaveData; +} diff --git a/src/@types/UserInfo.ts b/src/@types/UserInfo.ts new file mode 100644 index 00000000000..c8a0c6ecb26 --- /dev/null +++ b/src/@types/UserInfo.ts @@ -0,0 +1,7 @@ +export interface UserInfo { + username: string; + lastSessionSlot: number; + discordId: string; + googleId: string; + hasAdminRole: boolean; +} diff --git a/src/@types/i18next.d.ts b/src/@types/i18next.d.ts index 9e8418a8977..3bd71bc6c61 100644 --- a/src/@types/i18next.d.ts +++ b/src/@types/i18next.d.ts @@ -1,18 +1,8 @@ -import { type enConfig } from "#app/locales/en/config"; import { TOptions } from "i18next"; -//TODO: this needs to be type properly in the future // Module declared to make referencing keys in the localization files type-safe. declare module "i18next" { - interface CustomTypeOptions { - defaultNS: "menu", // needed here as well for typedoc - resources: typeof enConfig - } - - interface TFunction { - ( - key: string | string[], - options?: TOptions & Record - ): string; - } + interface TFunction { + (key: string | string[], options?: TOptions & Record): string; } +} diff --git a/src/account.ts b/src/account.ts index c6d2f85489a..316645b38ff 100644 --- a/src/account.ts +++ b/src/account.ts @@ -1,14 +1,8 @@ +import { pokerogueApi } from "#app/plugins/api/pokerogue-api"; +import type { UserInfo } from "#app/@types/UserInfo"; import { bypassLogin } from "./battle-scene"; import * as Utils from "./utils"; -export interface UserInfo { - username: string; - lastSessionSlot: integer; - discordId: string; - googleId: string; - hasAdminRole: boolean; -} - export let loggedInUser: UserInfo | null = null; // This is a random string that is used to identify the client session - unique per session (tab or window) so that the game will only save on the one that the server is expecting export const clientSessionId = Utils.randomString(32); @@ -20,7 +14,7 @@ export function initLoggedInUser(): void { export function updateUserInfo(): Promise<[boolean, integer]> { return new Promise<[boolean, integer]>(resolve => { if (bypassLogin) { - loggedInUser = { username: "Guest", lastSessionSlot: -1, discordId: "", googleId: "", hasAdminRole: false}; + loggedInUser = { username: "Guest", lastSessionSlot: -1, discordId: "", googleId: "", hasAdminRole: false }; let lastSessionSlot = -1; for (let s = 0; s < 5; s++) { if (localStorage.getItem(`sessionData${s ? s : ""}_${loggedInUser.username}`)) { @@ -43,18 +37,14 @@ export function updateUserInfo(): Promise<[boolean, integer]> { }); return resolve([ true, 200 ]); } - Utils.apiFetch("account/info", true).then(response => { - if (!response.ok) { - resolve([ false, response.status ]); + pokerogueApi.account.getInfo().then(([ accountInfo, status ]) => { + if (!accountInfo) { + resolve([ false, status ]); return; + } else { + loggedInUser = accountInfo; + resolve([ true, 200 ]); } - return response.json(); - }).then(jsonResponse => { - loggedInUser = jsonResponse; - resolve([ true, 200 ]); - }).catch(err => { - console.error(err); - resolve([ false, 500 ]); }); }); } diff --git a/src/battle-scene.ts b/src/battle-scene.ts index 516662617f1..2f062667808 100644 --- a/src/battle-scene.ts +++ b/src/battle-scene.ts @@ -1,68 +1,59 @@ import Phaser from "phaser"; -import UI from "./ui/ui"; -import Pokemon, { PlayerPokemon, EnemyPokemon } from "./field/pokemon"; -import PokemonSpecies, { PokemonSpeciesFilter, allSpecies, getPokemonSpecies } from "./data/pokemon-species"; -import { Constructor, isNullOrUndefined } from "#app/utils"; -import * as Utils from "./utils"; -import { Modifier, ModifierBar, ConsumablePokemonModifier, ConsumableModifier, PokemonHpRestoreModifier, TurnHeldItemTransferModifier, HealingBoosterModifier, PersistentModifier, PokemonHeldItemModifier, ModifierPredicate, DoubleBattleChanceBoosterModifier, FusePokemonModifier, PokemonFormChangeItemModifier, TerastallizeModifier, overrideModifiers, overrideHeldItems, PokemonIncrementingStatModifier, ExpShareModifier, ExpBalanceModifier, MultipleParticipantExpBonusModifier, PokemonExpBoosterModifier } from "./modifier/modifier"; -import { PokeballType } from "./data/pokeball"; -import { initCommonAnims, initMoveAnim, loadCommonAnimAssets, loadMoveAnimAssets, populateAnims } from "./data/battle-anims"; -import { Phase } from "./phase"; -import { initGameSpeed } from "./system/game-speed"; -import { Arena, ArenaBase } from "./field/arena"; -import { GameData } from "./system/game-data"; -import { addTextObject, getTextColor, TextStyle } from "./ui/text"; -import { allMoves } from "./data/move"; -import { - ModifierPoolType, - getDefaultModifierTypeForTier, - getEnemyModifierTypesForWave, - getLuckString, - getLuckTextTint, - getModifierPoolForType, - getModifierType, - getPartyLuckValue, - modifierTypes, PokemonHeldItemModifierType -} from "./modifier/modifier-type"; -import AbilityBar from "./ui/ability-bar"; -import { BlockItemTheftAbAttr, DoubleBattleChanceAbAttr, ChangeMovePriorityAbAttr, PostBattleInitAbAttr, applyAbAttrs, applyPostBattleInitAbAttrs } from "./data/ability"; -import { allAbilities } from "./data/ability"; -import Battle, { BattleType, FixedBattleConfig } from "./battle"; -import { GameMode, GameModes, getGameMode } from "./game-mode"; -import FieldSpritePipeline from "./pipelines/field-sprite"; -import SpritePipeline from "./pipelines/sprite"; -import PartyExpBar from "./ui/party-exp-bar"; -import { trainerConfigs, TrainerSlot } from "./data/trainer-config"; -import Trainer, { TrainerVariant } from "./field/trainer"; -import TrainerData from "./system/trainer-data"; +import UI from "#app/ui/ui"; +import Pokemon, { EnemyPokemon, PlayerPokemon } from "#app/field/pokemon"; +import PokemonSpecies, { allSpecies, getPokemonSpecies, PokemonSpeciesFilter } from "#app/data/pokemon-species"; +import { Constructor, isNullOrUndefined, randSeedInt } from "#app/utils"; +import * as Utils from "#app/utils"; +import { ConsumableModifier, ConsumablePokemonModifier, DoubleBattleChanceBoosterModifier, ExpBalanceModifier, ExpShareModifier, FusePokemonModifier, HealingBoosterModifier, Modifier, ModifierBar, ModifierPredicate, MultipleParticipantExpBonusModifier, overrideHeldItems, overrideModifiers, PersistentModifier, PokemonExpBoosterModifier, PokemonFormChangeItemModifier, PokemonHeldItemModifier, PokemonHpRestoreModifier, PokemonIncrementingStatModifier, RememberMoveModifier, TerastallizeModifier, TurnHeldItemTransferModifier } from "./modifier/modifier"; +import { PokeballType } from "#enums/pokeball"; +import { initCommonAnims, initMoveAnim, loadCommonAnimAssets, loadMoveAnimAssets, populateAnims } from "#app/data/battle-anims"; +import { Phase } from "#app/phase"; +import { initGameSpeed } from "#app/system/game-speed"; +import { Arena, ArenaBase } from "#app/field/arena"; +import { GameData } from "#app/system/game-data"; +import { addTextObject, getTextColor, TextStyle } from "#app/ui/text"; +import { allMoves } from "#app/data/move"; +import { MusicPreference } from "#app/system/settings/settings"; +import { getDefaultModifierTypeForTier, getEnemyModifierTypesForWave, getLuckString, getLuckTextTint, getModifierPoolForType, getModifierType, getPartyLuckValue, ModifierPoolType, modifierTypes, PokemonHeldItemModifierType } from "#app/modifier/modifier-type"; +import AbilityBar from "#app/ui/ability-bar"; +import { allAbilities, applyAbAttrs, applyPostBattleInitAbAttrs, applyPostItemLostAbAttrs, BlockItemTheftAbAttr, DoubleBattleChanceAbAttr, PostBattleInitAbAttr, PostItemLostAbAttr } from "#app/data/ability"; +import Battle, { BattleType, FixedBattleConfig } from "#app/battle"; +import { GameMode, GameModes, getGameMode } from "#app/game-mode"; +import FieldSpritePipeline from "#app/pipelines/field-sprite"; +import SpritePipeline from "#app/pipelines/sprite"; +import PartyExpBar from "#app/ui/party-exp-bar"; +import { trainerConfigs, TrainerSlot } from "#app/data/trainer-config"; +import Trainer, { TrainerVariant } from "#app/field/trainer"; +import TrainerData from "#app/system/trainer-data"; import SoundFade from "phaser3-rex-plugins/plugins/soundfade"; -import { pokemonPrevolutions } from "./data/pokemon-evolutions"; -import PokeballTray from "./ui/pokeball-tray"; -import InvertPostFX from "./pipelines/invert"; -import { Achv, achvs, ModifierAchv, MoneyAchv } from "./system/achv"; -import { Voucher, vouchers } from "./system/voucher"; -import { Gender } from "./data/gender"; +import { pokemonPrevolutions } from "#app/data/balance/pokemon-evolutions"; +import PokeballTray from "#app/ui/pokeball-tray"; +import InvertPostFX from "#app/pipelines/invert"; +import { Achv, achvs, ModifierAchv, MoneyAchv } from "#app/system/achv"; +import { Voucher, vouchers } from "#app/system/voucher"; +import { Gender } from "#app/data/gender"; import UIPlugin from "phaser3-rex-plugins/templates/ui/ui-plugin"; -import { addUiThemeOverrides } from "./ui/ui-theme"; -import PokemonData from "./system/pokemon-data"; -import { Nature } from "./data/nature"; -import { SpeciesFormChangeManualTrigger, SpeciesFormChangeTimeOfDayTrigger, SpeciesFormChangeTrigger, pokemonFormChanges, FormChangeItem, SpeciesFormChange } from "./data/pokemon-forms"; -import { FormChangePhase } from "./phases/form-change-phase"; -import { getTypeRgb } from "./data/type"; -import PokemonSpriteSparkleHandler from "./field/pokemon-sprite-sparkle-handler"; -import CharSprite from "./ui/char-sprite"; -import DamageNumberHandler from "./field/damage-number-handler"; -import PokemonInfoContainer from "./ui/pokemon-info-container"; -import { biomeDepths, getBiomeName } from "./data/biomes"; -import { SceneBase } from "./scene-base"; -import CandyBar from "./ui/candy-bar"; -import { Variant, variantData } from "./data/variant"; +import { addUiThemeOverrides } from "#app/ui/ui-theme"; +import PokemonData from "#app/system/pokemon-data"; +import { Nature } from "#enums/nature"; +import { FormChangeItem, pokemonFormChanges, SpeciesFormChange, SpeciesFormChangeManualTrigger, SpeciesFormChangeTimeOfDayTrigger, SpeciesFormChangeTrigger } from "#app/data/pokemon-forms"; +import { FormChangePhase } from "#app/phases/form-change-phase"; +import { getTypeRgb } from "#app/data/type"; +import { Type } from "#enums/type"; +import PokemonSpriteSparkleHandler from "#app/field/pokemon-sprite-sparkle-handler"; +import CharSprite from "#app/ui/char-sprite"; +import DamageNumberHandler from "#app/field/damage-number-handler"; +import PokemonInfoContainer from "#app/ui/pokemon-info-container"; +import { biomeDepths, getBiomeName } from "#app/data/balance/biomes"; +import { SceneBase } from "#app/scene-base"; +import CandyBar from "#app/ui/candy-bar"; +import { Variant, variantData } from "#app/data/variant"; import { Localizable } from "#app/interfaces/locales"; import Overrides from "#app/overrides"; -import { InputsController } from "./inputs-controller"; -import { UiInputs } from "./ui-inputs"; -import { NewArenaEvent } from "./events/battle-scene"; -import { ArenaFlyout } from "./ui/arena-flyout"; +import { InputsController } from "#app/inputs-controller"; +import { UiInputs } from "#app/ui-inputs"; +import { NewArenaEvent } from "#app/events/battle-scene"; +import { ArenaFlyout } from "#app/ui/arena-flyout"; import { EaseType } from "#enums/ease-type"; import { BattleSpec } from "#enums/battle-spec"; import { BattleStyle } from "#enums/battle-style"; @@ -77,27 +68,27 @@ import { TimedEventManager } from "#app/timed-event-manager"; import { PokemonAnimType } from "#enums/pokemon-anim-type"; import i18next from "i18next"; import { TrainerType } from "#enums/trainer-type"; -import { battleSpecDialogue } from "./data/dialogue"; -import { LoadingScene } from "./loading-scene"; -import { LevelCapPhase } from "./phases/level-cap-phase"; -import { LoginPhase } from "./phases/login-phase"; -import { MessagePhase } from "./phases/message-phase"; -import { MovePhase } from "./phases/move-phase"; -import { NewBiomeEncounterPhase } from "./phases/new-biome-encounter-phase"; -import { NextEncounterPhase } from "./phases/next-encounter-phase"; -import { PokemonAnimPhase } from "./phases/pokemon-anim-phase"; -import { QuietFormChangePhase } from "./phases/quiet-form-change-phase"; -import { ReturnPhase } from "./phases/return-phase"; -import { SelectBiomePhase } from "./phases/select-biome-phase"; -import { ShowTrainerPhase } from "./phases/show-trainer-phase"; -import { SummonPhase } from "./phases/summon-phase"; -import { SwitchPhase } from "./phases/switch-phase"; -import { TitlePhase } from "./phases/title-phase"; -import { ToggleDoublePositionPhase } from "./phases/toggle-double-position-phase"; -import { TurnInitPhase } from "./phases/turn-init-phase"; -import { ShopCursorTarget } from "./enums/shop-cursor-target"; -import MysteryEncounter from "./data/mystery-encounters/mystery-encounter"; -import { allMysteryEncounters, ANTI_VARIANCE_WEIGHT_MODIFIER, AVERAGE_ENCOUNTERS_PER_RUN_TARGET, BASE_MYSTERY_ENCOUNTER_SPAWN_WEIGHT, MYSTERY_ENCOUNTER_SPAWN_MAX_WEIGHT, mysteryEncountersByBiome, WEIGHT_INCREMENT_ON_SPAWN_MISS } from "./data/mystery-encounters/mystery-encounters"; +import { battleSpecDialogue } from "#app/data/dialogue"; +import { LoadingScene } from "#app/loading-scene"; +import { LevelCapPhase } from "#app/phases/level-cap-phase"; +import { LoginPhase } from "#app/phases/login-phase"; +import { MessagePhase } from "#app/phases/message-phase"; +import { MovePhase } from "#app/phases/move-phase"; +import { NewBiomeEncounterPhase } from "#app/phases/new-biome-encounter-phase"; +import { NextEncounterPhase } from "#app/phases/next-encounter-phase"; +import { PokemonAnimPhase } from "#app/phases/pokemon-anim-phase"; +import { QuietFormChangePhase } from "#app/phases/quiet-form-change-phase"; +import { ReturnPhase } from "#app/phases/return-phase"; +import { SelectBiomePhase } from "#app/phases/select-biome-phase"; +import { ShowTrainerPhase } from "#app/phases/show-trainer-phase"; +import { SummonPhase } from "#app/phases/summon-phase"; +import { SwitchPhase } from "#app/phases/switch-phase"; +import { TitlePhase } from "#app/phases/title-phase"; +import { ToggleDoublePositionPhase } from "#app/phases/toggle-double-position-phase"; +import { TurnInitPhase } from "#app/phases/turn-init-phase"; +import { ShopCursorTarget } from "#app/enums/shop-cursor-target"; +import MysteryEncounter from "#app/data/mystery-encounters/mystery-encounter"; +import { allMysteryEncounters, ANTI_VARIANCE_WEIGHT_MODIFIER, AVERAGE_ENCOUNTERS_PER_RUN_TARGET, BASE_MYSTERY_ENCOUNTER_SPAWN_WEIGHT, MYSTERY_ENCOUNTER_SPAWN_MAX_WEIGHT, mysteryEncountersByBiome } from "#app/data/mystery-encounters/mystery-encounters"; import { MysteryEncounterSaveData } from "#app/data/mystery-encounters/mystery-encounter-save-data"; import { MysteryEncounterType } from "#enums/mystery-encounter-type"; import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; @@ -105,7 +96,10 @@ import HeldModifierConfig from "#app/interfaces/held-modifier-config"; import { ExpPhase } from "#app/phases/exp-phase"; import { ShowPartyExpBarPhase } from "#app/phases/show-party-exp-bar-phase"; import { MysteryEncounterMode } from "#enums/mystery-encounter-mode"; -import { ExpGainsSpeed } from "./enums/exp-gains-speed"; +import { ExpGainsSpeed } from "#enums/exp-gains-speed"; +import { BattlerTagType } from "#enums/battler-tag-type"; +import { FRIENDSHIP_GAIN_FROM_BATTLE } from "#app/data/balance/starters"; +import { StatusEffect } from "#enums/status-effect"; export const bypassLogin = import.meta.env.VITE_BYPASS_LOGIN === "1"; @@ -179,7 +173,7 @@ export default class BattleScene extends SceneBase { public uiTheme: UiTheme = UiTheme.DEFAULT; public windowType: integer = 0; public experimentalSprites: boolean = false; - public musicPreference: integer = 0; + public musicPreference: number = MusicPreference.MIXED; public moveAnimations: boolean = true; public expGainsSpeed: ExpGainsSpeed = ExpGainsSpeed.DEFAULT; public skipSeenDialogues: boolean = false; @@ -333,6 +327,7 @@ export default class BattleScene extends SceneBase { this.conditionalQueue = []; this.phaseQueuePrependSpliceIndex = -1; this.nextCommandPhaseQueue = []; + this.eventManager = new TimedEventManager(); this.updateGameInfo(); } @@ -388,7 +383,6 @@ export default class BattleScene extends SceneBase { this.fieldSpritePipeline = new FieldSpritePipeline(this.game); (this.renderer as Phaser.Renderer.WebGL.WebGLRenderer).pipelines.add("FieldSprite", this.fieldSpritePipeline); - this.eventManager = new TimedEventManager(); this.launchBattle(); } @@ -774,41 +768,65 @@ export default class BattleScene extends SceneBase { return true; } - getParty(): PlayerPokemon[] { + public getPlayerParty(): PlayerPokemon[] { return this.party; } - getPlayerPokemon(): PlayerPokemon | undefined { - return this.getPlayerField().find(p => p.isActive()); + /** + * @returns An array of {@linkcode PlayerPokemon} filtered from the player's party + * that are {@linkcode Pokemon.isAllowedInBattle | allowed in battle}. + */ + public getPokemonAllowedInBattle(): PlayerPokemon[] { + return this.getPlayerParty().filter(p => p.isAllowedInBattle()); } /** - * Returns an array of PlayerPokemon of length 1 or 2 depending on if double battles or not + * @returns The first {@linkcode PlayerPokemon} that is {@linkcode getPlayerField on the field} + * and {@linkcode PlayerPokemon.isActive is active} + * (aka {@linkcode PlayerPokemon.isAllowedInBattle is allowed in battle}), + * or `undefined` if there are no valid pokemon + * @param includeSwitching Whether a pokemon that is currently switching out is valid, default `true` + */ + public getPlayerPokemon(includeSwitching: boolean = true): PlayerPokemon | undefined { + return this.getPlayerField().find(p => p.isActive() && (includeSwitching || p.switchOutStatus === false)); + } + + /** + * Returns an array of PlayerPokemon of length 1 or 2 depending on if in a double battle or not. + * Does not actually check if the pokemon are on the field or not. * @returns array of {@linkcode PlayerPokemon} */ - getPlayerField(): PlayerPokemon[] { - const party = this.getParty(); + public getPlayerField(): PlayerPokemon[] { + const party = this.getPlayerParty(); return party.slice(0, Math.min(party.length, this.currentBattle?.double ? 2 : 1)); } - getEnemyParty(): EnemyPokemon[] { - return this.currentBattle?.enemyParty || []; - } - - getEnemyPokemon(): EnemyPokemon | undefined { - return this.getEnemyField().find(p => p.isActive()); + public getEnemyParty(): EnemyPokemon[] { + return this.currentBattle?.enemyParty ?? []; } /** - * Returns an array of EnemyPokemon of length 1 or 2 depending on if double battles or not + * @returns The first {@linkcode EnemyPokemon} that is {@linkcode getEnemyField on the field} + * and {@linkcode EnemyPokemon.isActive is active} + * (aka {@linkcode EnemyPokemon.isAllowedInBattle is allowed in battle}), + * or `undefined` if there are no valid pokemon + * @param includeSwitching Whether a pokemon that is currently switching out is valid, default `true` + */ + public getEnemyPokemon(includeSwitching: boolean = true): EnemyPokemon | undefined { + return this.getEnemyField().find(p => p.isActive() && (includeSwitching || p.switchOutStatus === false)); + } + + /** + * Returns an array of EnemyPokemon of length 1 or 2 depending on if in a double battle or not. + * Does not actually check if the pokemon are on the field or not. * @returns array of {@linkcode EnemyPokemon} */ - getEnemyField(): EnemyPokemon[] { + public getEnemyField(): EnemyPokemon[] { const party = this.getEnemyParty(); return party.slice(0, Math.min(party.length, this.currentBattle?.double ? 2 : 1)); } - getField(activeOnly: boolean = false): Pokemon[] { + public getField(activeOnly: boolean = false): Pokemon[] { const ret = new Array(4).fill(null); const playerField = this.getPlayerField(); const enemyField = this.getEnemyField(); @@ -861,7 +879,7 @@ export default class BattleScene extends SceneBase { getPokemonById(pokemonId: integer): Pokemon | null { const findInParty = (party: Pokemon[]) => party.find(p => p.id === pokemonId); - return (findInParty(this.getParty()) || findInParty(this.getEnemyParty())) ?? null; + return (findInParty(this.getPlayerParty()) || findInParty(this.getEnemyParty())) ?? null; } addPlayerPokemon(species: PokemonSpecies, level: integer, abilityIndex?: integer, formIndex?: integer, gender?: Gender, shiny?: boolean, variant?: Variant, ivs?: integer[], nature?: Nature, dataSource?: Pokemon | PokemonData, postProcess?: (playerPokemon: PlayerPokemon) => void): PlayerPokemon { @@ -884,6 +902,9 @@ export default class BattleScene extends SceneBase { } const pokemon = new EnemyPokemon(this, species, level, trainerSlot, boss, dataSource); + if (Overrides.OPP_FUSION_OVERRIDE) { + pokemon.generateFusionSpecies(); + } overrideModifiers(this, false); overrideHeldItems(this, pokemon, false); @@ -1035,10 +1056,6 @@ export default class BattleScene extends SceneBase { this.gameMode = getGameMode(GameModes.CLASSIC); - this.setSeed(Overrides.SEED_OVERRIDE || Utils.randomString(24)); - console.log("Seed:", this.seed); - this.resetSeed(); // Properly resets RNG after saving and quitting a session - this.disableMenu = false; this.score = 0; @@ -1057,7 +1074,7 @@ export default class BattleScene extends SceneBase { this.modifierBar.removeAll(true); this.enemyModifierBar.removeAll(true); - for (const p of this.getParty()) { + for (const p of this.getPlayerParty()) { p.destroy(); } this.party = []; @@ -1065,9 +1082,20 @@ export default class BattleScene extends SceneBase { p.destroy(); } + // If this is a ME, clear any residual visual sprites before reloading + if (this.currentBattle?.mysteryEncounter?.introVisuals) { + this.field.remove(this.currentBattle.mysteryEncounter?.introVisuals, true); + } + //@ts-ignore - allowing `null` for currentBattle causes a lot of trouble this.currentBattle = null; // TODO: resolve ts-ignore + // Reset RNG after end of game or save & quit. + // This needs to happen after clearing this.currentBattle or the seed will be affected by the last wave played + this.setSeed(Overrides.SEED_OVERRIDE || Utils.randomString(24)); + console.log("Seed:", this.seed); + this.resetSeed(); + this.biomeWaveText.setText(startingWave.toString()); this.biomeWaveText.setVisible(false); @@ -1095,6 +1123,8 @@ export default class BattleScene extends SceneBase { this.trainer.setPosition(406, 186); this.trainer.setVisible(true); + this.mysteryEncounterSaveData = new MysteryEncounterSaveData(); + this.updateGameInfo(); if (reloadI18n) { @@ -1130,6 +1160,13 @@ export default class BattleScene extends SceneBase { } } + getDoubleBattleChance(newWaveIndex: number, playerField: PlayerPokemon[]) { + const doubleChance = new Utils.IntegerHolder(newWaveIndex % 10 === 0 ? 32 : 8); + this.applyModifiers(DoubleBattleChanceBoosterModifier, true, doubleChance); + playerField.forEach(p => applyAbAttrs(DoubleBattleChanceAbAttr, p, null, false, doubleChance)); + return Math.max(doubleChance.value, 1); + } + newBattle(waveIndex?: integer, battleType?: BattleType, trainerData?: TrainerData, double?: boolean, mysteryEncounterType?: MysteryEncounterType): Battle | null { const _startingWave = Overrides.STARTING_WAVE_OVERRIDE || startingWave; const newWaveIndex = waveIndex || ((this.currentBattle?.waveIndex || (_startingWave - 1)) + 1); @@ -1166,10 +1203,7 @@ export default class BattleScene extends SceneBase { if (trainerConfigs[trainerType].doubleOnly) { doubleTrainer = true; } else if (trainerConfigs[trainerType].hasDouble) { - const doubleChance = new Utils.IntegerHolder(newWaveIndex % 10 === 0 ? 32 : 8); - this.applyModifiers(DoubleBattleChanceBoosterModifier, true, doubleChance); - playerField.forEach(p => applyAbAttrs(DoubleBattleChanceAbAttr, p, null, false, doubleChance)); - doubleTrainer = !Utils.randSeedInt(doubleChance.value); + doubleTrainer = !Utils.randSeedInt(this.getDoubleBattleChance(newWaveIndex, playerField)); // Add a check that special trainers can't be double except for tate and liza - they should use the normal double chance if (trainerConfigs[trainerType].trainerTypeDouble && ![ TrainerType.TATE, TrainerType.LIZA ].includes(trainerType)) { doubleTrainer = false; @@ -1182,41 +1216,16 @@ export default class BattleScene extends SceneBase { // Check for mystery encounter // Can only occur in place of a standard (non-boss) wild battle, waves 10-180 - const [lowestMysteryEncounterWave, highestMysteryEncounterWave] = this.gameMode.getMysteryEncounterLegalWaves(); - if (this.gameMode.hasMysteryEncounters && newBattleType === BattleType.WILD && !this.gameMode.isBoss(newWaveIndex) && newWaveIndex < highestMysteryEncounterWave && newWaveIndex > lowestMysteryEncounterWave) { - const roll = Utils.randSeedInt(MYSTERY_ENCOUNTER_SPAWN_MAX_WEIGHT); - - // Base spawn weight is BASE_MYSTERY_ENCOUNTER_SPAWN_WEIGHT/256, and increases by WEIGHT_INCREMENT_ON_SPAWN_MISS/256 for each missed attempt at spawning an encounter on a valid floor - const sessionEncounterRate = this.mysteryEncounterSaveData.encounterSpawnChance; - const encounteredEvents = this.mysteryEncounterSaveData.encounteredEvents; - - // If total number of encounters is lower than expected for the run, slightly favor a new encounter spawn (reverse as well) - // Reduces occurrence of runs with total encounters significantly different from AVERAGE_ENCOUNTERS_PER_RUN_TARGET - const expectedEncountersByFloor = AVERAGE_ENCOUNTERS_PER_RUN_TARGET / (highestMysteryEncounterWave - lowestMysteryEncounterWave) * (newWaveIndex - lowestMysteryEncounterWave); - const currentRunDiffFromAvg = expectedEncountersByFloor - encounteredEvents.length; - const favoredEncounterRate = sessionEncounterRate + currentRunDiffFromAvg * ANTI_VARIANCE_WEIGHT_MODIFIER; - - const successRate = isNullOrUndefined(Overrides.MYSTERY_ENCOUNTER_RATE_OVERRIDE) ? favoredEncounterRate : Overrides.MYSTERY_ENCOUNTER_RATE_OVERRIDE!; - - // If the most recent ME was 3 or fewer waves ago, can never spawn a ME - const canSpawn = encounteredEvents.length === 0 || (newWaveIndex - encounteredEvents[encounteredEvents.length - 1].waveIndex) > 3 || !isNullOrUndefined(Overrides.MYSTERY_ENCOUNTER_RATE_OVERRIDE); - - if (canSpawn && roll < successRate) { - newBattleType = BattleType.MYSTERY_ENCOUNTER; - // Reset base spawn weight - this.mysteryEncounterSaveData.encounterSpawnChance = BASE_MYSTERY_ENCOUNTER_SPAWN_WEIGHT; - } else { - this.mysteryEncounterSaveData.encounterSpawnChance = sessionEncounterRate + WEIGHT_INCREMENT_ON_SPAWN_MISS; - } + if (this.isWaveMysteryEncounter(newBattleType, newWaveIndex) || newBattleType === BattleType.MYSTERY_ENCOUNTER) { + newBattleType = BattleType.MYSTERY_ENCOUNTER; + // Reset to base spawn weight + this.mysteryEncounterSaveData.encounterSpawnChance = BASE_MYSTERY_ENCOUNTER_SPAWN_WEIGHT; } } if (double === undefined && newWaveIndex > 1) { if (newBattleType === BattleType.WILD && !this.gameMode.isWaveFinal(newWaveIndex)) { - const doubleChance = new Utils.IntegerHolder(newWaveIndex % 10 === 0 ? 32 : 8); - this.applyModifiers(DoubleBattleChanceBoosterModifier, true, doubleChance); - playerField.forEach(p => applyAbAttrs(DoubleBattleChanceAbAttr, p, null, false, doubleChance)); - newDouble = !Utils.randSeedInt(doubleChance.value); + newDouble = !Utils.randSeedInt(this.getDoubleBattleChance(newWaveIndex, playerField)); } else if (newBattleType === BattleType.TRAINER) { newDouble = newTrainer?.variant === TrainerVariant.DOUBLE; } @@ -1224,36 +1233,66 @@ export default class BattleScene extends SceneBase { newDouble = !!double; } - if (Overrides.BATTLE_TYPE_OVERRIDE === "double") { - newDouble = true; - } - /* Override battles into single only if not fighting with trainers */ - if (newBattleType !== BattleType.TRAINER && Overrides.BATTLE_TYPE_OVERRIDE === "single") { + // Disable double battles on Endless/Endless Spliced Wave 50x boss battles (Introduced 1.2.0) + if (this.gameMode.isEndlessBoss(newWaveIndex)) { newDouble = false; } - const lastBattle = this.currentBattle; + if (!isNullOrUndefined(Overrides.BATTLE_TYPE_OVERRIDE)) { + let doubleOverrideForWave: "single" | "double" | null = null; - if (lastBattle?.double && !newDouble) { - this.tryRemovePhase(p => p instanceof SwitchPhase); + switch (Overrides.BATTLE_TYPE_OVERRIDE) { + case "double": + doubleOverrideForWave = "double"; + break; + case "single": + doubleOverrideForWave = "single"; + break; + case "even-doubles": + doubleOverrideForWave = (newWaveIndex % 2) ? "single" : "double"; + break; + case "odd-doubles": + doubleOverrideForWave = (newWaveIndex % 2) ? "double" : "single"; + break; + } + + if (doubleOverrideForWave === "double") { + newDouble = true; + } + /** + * Override battles into single only if not fighting with trainers. + * @see {@link https://github.com/pagefaultgames/pokerogue/issues/1948 | GitHub Issue #1948} + */ + if (newBattleType !== BattleType.TRAINER && doubleOverrideForWave === "single") { + newDouble = false; + } } + const lastBattle = this.currentBattle; + const maxExpLevel = this.getMaxExpLevel(); this.lastEnemyTrainer = lastBattle?.trainer ?? null; this.lastMysteryEncounter = lastBattle?.mysteryEncounter; + if (newBattleType === BattleType.MYSTERY_ENCOUNTER) { + // Disable double battle on mystery encounters (it may be re-enabled as part of encounter) + newDouble = false; + } + + if (lastBattle?.double && !newDouble) { + this.tryRemovePhase(p => p instanceof SwitchPhase); + this.getPlayerField().forEach(p => p.lapseTag(BattlerTagType.COMMANDED)); + } + this.executeWithSeedOffset(() => { this.currentBattle = new Battle(this.gameMode, newWaveIndex, newBattleType, newTrainer, newDouble); }, newWaveIndex << 3, this.waveSeed); this.currentBattle.incrementTurn(this); if (newBattleType === BattleType.MYSTERY_ENCOUNTER) { - // Disable double battle on mystery encounters (it may be re-enabled as part of encounter) - this.currentBattle.double = false; - this.executeWithSeedOffset(() => { - this.currentBattle.mysteryEncounter = this.getMysteryEncounter(mysteryEncounterType); - }, this.currentBattle.waveIndex << 4); + // Will generate the actual Mystery Encounter during NextEncounterPhase, to ensure it uses proper biome + this.currentBattle.mysteryEncounterType = mysteryEncounterType; } //this.pushPhase(new TrainerMessageTestPhase(this, TrainerType.RIVAL, TrainerType.RIVAL_2, TrainerType.RIVAL_3, TrainerType.RIVAL_4, TrainerType.RIVAL_5, TrainerType.RIVAL_6)); @@ -1264,7 +1303,7 @@ export default class BattleScene extends SceneBase { const isEndlessFifthWave = this.gameMode.hasShortBiomes && (lastBattle.waveIndex % 5) === 0; const isWaveIndexMultipleOfFiftyMinusOne = (lastBattle.waveIndex % 50) === 49; const isNewBiome = isWaveIndexMultipleOfTen || isEndlessFifthWave || (isEndlessOrDaily && isWaveIndexMultipleOfFiftyMinusOne); - const resetArenaState = isNewBiome || [BattleType.TRAINER, BattleType.MYSTERY_ENCOUNTER].includes(this.currentBattle.battleType) || this.currentBattle.battleSpec === BattleSpec.FINAL_BOSS; + const resetArenaState = isNewBiome || [ BattleType.TRAINER, BattleType.MYSTERY_ENCOUNTER ].includes(this.currentBattle.battleType) || this.currentBattle.battleSpec === BattleSpec.FINAL_BOSS; this.getEnemyParty().forEach(enemyPokemon => enemyPokemon.destroy()); this.trySpreadPokerus(); if (!isNewBiome && (newWaveIndex % 10) === 5) { @@ -1273,13 +1312,15 @@ export default class BattleScene extends SceneBase { if (resetArenaState) { this.arena.resetArenaEffects(); + playerField.forEach((pokemon) => pokemon.lapseTag(BattlerTagType.COMMANDED)); + playerField.forEach((pokemon, p) => { if (pokemon.isOnField()) { this.pushPhase(new ReturnPhase(this, p)); } }); - for (const pokemon of this.getParty()) { + for (const pokemon of this.getPlayerParty()) { pokemon.resetBattleData(); applyPostBattleInitAbAttrs(PostBattleInitAbAttr, pokemon); } @@ -1289,7 +1330,7 @@ export default class BattleScene extends SceneBase { } } - for (const pokemon of this.getParty()) { + for (const pokemon of this.getPlayerParty()) { this.triggerPokemonFormChange(pokemon, SpeciesFormChangeTimeOfDayTrigger); } @@ -1358,69 +1399,78 @@ export default class BattleScene extends SceneBase { } switch (species.speciesId) { - case Species.UNOWN: - case Species.SHELLOS: - case Species.GASTRODON: - case Species.BASCULIN: - case Species.DEERLING: - case Species.SAWSBUCK: - case Species.FROAKIE: - case Species.FROGADIER: - case Species.SCATTERBUG: - case Species.SPEWPA: - case Species.VIVILLON: - case Species.FLABEBE: - case Species.FLOETTE: - case Species.FLORGES: - case Species.FURFROU: - case Species.PUMPKABOO: - case Species.GOURGEIST: - case Species.ORICORIO: - case Species.MAGEARNA: - case Species.ZARUDE: - case Species.SQUAWKABILLY: - case Species.TATSUGIRI: - case Species.PALDEA_TAUROS: - return Utils.randSeedInt(species.forms.length); - case Species.PIKACHU: - return Utils.randSeedInt(8); - case Species.EEVEE: - return Utils.randSeedInt(2); - case Species.GRENINJA: - return Utils.randSeedInt(2); - case Species.ZYGARDE: - return Utils.randSeedInt(3); - case Species.MINIOR: - return Utils.randSeedInt(6); - case Species.ALCREMIE: - return Utils.randSeedInt(9); - case Species.MEOWSTIC: - case Species.INDEEDEE: - case Species.BASCULEGION: - case Species.OINKOLOGNE: - return gender === Gender.FEMALE ? 1 : 0; - case Species.TOXTRICITY: - const lowkeyNatures = [ Nature.LONELY, Nature.BOLD, Nature.RELAXED, Nature.TIMID, Nature.SERIOUS, Nature.MODEST, Nature.MILD, Nature.QUIET, Nature.BASHFUL, Nature.CALM, Nature.GENTLE, Nature.CAREFUL ]; - if (nature !== undefined && lowkeyNatures.indexOf(nature) > -1) { - return 1; - } - return 0; - case Species.GIMMIGHOUL: - // Chest form can only be found in Mysterious Chest Encounter, if this is a game mode with MEs - if (this.gameMode.hasMysteryEncounters) { - return 1; // Wandering form - } else { + case Species.UNOWN: + case Species.SHELLOS: + case Species.GASTRODON: + case Species.BASCULIN: + case Species.DEERLING: + case Species.SAWSBUCK: + case Species.FROAKIE: + case Species.FROGADIER: + case Species.SCATTERBUG: + case Species.SPEWPA: + case Species.VIVILLON: + case Species.FLABEBE: + case Species.FLOETTE: + case Species.FLORGES: + case Species.FURFROU: + case Species.PUMPKABOO: + case Species.GOURGEIST: + case Species.ORICORIO: + case Species.MAGEARNA: + case Species.ZARUDE: + case Species.SQUAWKABILLY: + case Species.TATSUGIRI: + case Species.PALDEA_TAUROS: return Utils.randSeedInt(species.forms.length); - } + case Species.PIKACHU: + if (this.currentBattle?.battleType === BattleType.TRAINER && this.currentBattle?.waveIndex < 30) { + return 0; // Ban Cosplay and Partner Pika from Trainers before wave 30 + } + return Utils.randSeedInt(8); + case Species.EEVEE: + if (this.currentBattle?.battleType === BattleType.TRAINER && this.currentBattle?.waveIndex < 30) { + return 0; // No Partner Eevee for Wave 12 Preschoolers + } + return Utils.randSeedInt(2); + case Species.GRENINJA: + if (this.currentBattle?.battleType === BattleType.TRAINER) { + return 0; // Don't give trainers Battle Bond Greninja + } + return Utils.randSeedInt(2); + case Species.ZYGARDE: + return Utils.randSeedInt(4); + case Species.MINIOR: + return Utils.randSeedInt(7); + case Species.ALCREMIE: + return Utils.randSeedInt(9); + case Species.MEOWSTIC: + case Species.INDEEDEE: + case Species.BASCULEGION: + case Species.OINKOLOGNE: + return gender === Gender.FEMALE ? 1 : 0; + case Species.TOXTRICITY: + const lowkeyNatures = [ Nature.LONELY, Nature.BOLD, Nature.RELAXED, Nature.TIMID, Nature.SERIOUS, Nature.MODEST, Nature.MILD, Nature.QUIET, Nature.BASHFUL, Nature.CALM, Nature.GENTLE, Nature.CAREFUL ]; + if (nature !== undefined && lowkeyNatures.indexOf(nature) > -1) { + return 1; + } + return 0; + case Species.GIMMIGHOUL: + // Chest form can only be found in Mysterious Chest Encounter, if this is a game mode with MEs + if (this.gameMode.hasMysteryEncounters) { + return 1; // Wandering form + } else { + return Utils.randSeedInt(species.forms.length); + } } if (ignoreArena) { switch (species.speciesId) { - case Species.BURMY: - case Species.WORMADAM: - case Species.ROTOM: - case Species.LYCANROC: - return Utils.randSeedInt(species.forms.length); + case Species.BURMY: + case Species.WORMADAM: + case Species.ROTOM: + case Species.LYCANROC: + return Utils.randSeedInt(species.forms.length); } return 0; } @@ -1484,7 +1534,7 @@ export default class BattleScene extends SceneBase { } trySpreadPokerus(): void { - const party = this.getParty(); + const party = this.getPlayerParty(); const infectedIndexes: integer[] = []; const spread = (index: number, spreadTo: number) => { const partyMember = party[index + spreadTo]; @@ -1674,10 +1724,14 @@ export default class BattleScene extends SceneBase { this.scoreText.setVisible(this.gameMode.isDaily); } - updateAndShowText(duration: integer): void { + /** + * Displays the current luck value. + * @param duration The time for this label to fade in, if it is not already visible. + */ + updateAndShowText(duration: number): void { const labels = [ this.luckLabelText, this.luckText ]; labels.forEach(t => t.setAlpha(0)); - const luckValue = getPartyLuckValue(this.getParty()); + const luckValue = getPartyLuckValue(this.getPlayerParty()); this.luckText.setText(getLuckString(luckValue)); if (luckValue < 14) { this.luckText.setTint(getLuckTextTint(luckValue)); @@ -1757,14 +1811,14 @@ export default class BattleScene extends SceneBase { if (fromArenaPool) { return this.arena.randomSpecies(waveIndex, level, undefined, getPartyLuckValue(this.party)); } - const filteredSpecies = speciesFilter ? [...new Set(allSpecies.filter(s => s.isCatchable()).filter(speciesFilter).map(s => { + const filteredSpecies = speciesFilter ? [ ...new Set(allSpecies.filter(s => s.isCatchable()).filter(speciesFilter).map(s => { if (!filterAllEvolutions) { while (pokemonPrevolutions.hasOwnProperty(s.speciesId)) { s = getPokemonSpecies(pokemonPrevolutions[s.speciesId]); } } return s; - }))] : allSpecies.filter(s => s.isCatchable()); + })) ] : allSpecies.filter(s => s.isCatchable()); return filteredSpecies[Utils.randSeedInt(filteredSpecies.length)]; } @@ -1881,17 +1935,17 @@ export default class BattleScene extends SceneBase { const soundDetails = sound.key.split("/"); switch (soundDetails[0]) { - case "battle_anims": - case "cry": - if (soundDetails[1].startsWith("PRSFX- ")) { - sound.setVolume(this.masterVolume*this.fieldVolume*0.5); - } else { - sound.setVolume(this.masterVolume*this.fieldVolume); - } - break; - case "se": - case "ui": - sound.setVolume(this.masterVolume*this.seVolume); + case "battle_anims": + case "cry": + if (soundDetails[1].startsWith("PRSFX- ")) { + sound.setVolume(this.masterVolume * this.fieldVolume * 0.5); + } else { + sound.setVolume(this.masterVolume * this.fieldVolume); + } + break; + case "se": + case "ui": + sound.setVolume(this.masterVolume * this.seVolume); } } } @@ -1911,6 +1965,19 @@ export default class BattleScene extends SceneBase { return false; } + /** + * Fades out current track for `delay` ms, then fades in new track. + * @param newBgmKey + * @param destroy + * @param delay + */ + fadeAndSwitchBgm(newBgmKey: string, destroy: boolean = false, delay: number = 2000) { + this.fadeOutBgm(delay, destroy); + this.time.delayedCall(delay, () => { + this.playBgm(newBgmKey); + }); + } + playSound(sound: string | AnySound, config?: object): AnySound { const key = typeof sound === "string" ? sound : sound.key; config = config ?? {}; @@ -1918,31 +1985,31 @@ export default class BattleScene extends SceneBase { const keyDetails = key.split("/"); config["volume"] = config["volume"] ?? 1; switch (keyDetails[0]) { - case "level_up_fanfare": - case "item_fanfare": - case "minor_fanfare": - case "heal": - case "evolution": - case "evolution_fanfare": + case "level_up_fanfare": + case "item_fanfare": + case "minor_fanfare": + case "heal": + case "evolution": + case "evolution_fanfare": // These sounds are loaded in as BGM, but played as sound effects // When these sounds are updated in updateVolume(), they are treated as BGM however because they are placed in the BGM Cache through being called by playSoundWithoutBGM() - config["volume"] *= (this.masterVolume * this.bgmVolume); - break; - case "battle_anims": - case "cry": - config["volume"] *= (this.masterVolume * this.fieldVolume); - //PRSFX sound files are unusually loud - if (keyDetails[1].startsWith("PRSFX- ")) { - config["volume"] *= 0.5; - } - break; - case "ui": + config["volume"] *= (this.masterVolume * this.bgmVolume); + break; + case "battle_anims": + case "cry": + config["volume"] *= (this.masterVolume * this.fieldVolume); + //PRSFX sound files are unusually loud + if (keyDetails[1].startsWith("PRSFX- ")) { + config["volume"] *= 0.5; + } + break; + case "ui": //As of, right now this applies to the "select", "menu_open", "error" sound effects - config["volume"] *= (this.masterVolume * this.uiVolume); - break; - case "se": - config["volume"] *= (this.masterVolume * this.seVolume); - break; + config["volume"] *= (this.masterVolume * this.uiVolume); + break; + case "se": + config["volume"] *= (this.masterVolume * this.seVolume); + break; } this.sound.play(key, config); return this.sound.get(key) as AnySound; @@ -1971,192 +2038,208 @@ export default class BattleScene extends SceneBase { getBgmLoopPoint(bgmName: string): number { switch (bgmName) { - case "battle_kanto_champion": //B2W2 Kanto Champion Battle - return 13.950; - case "battle_johto_champion": //B2W2 Johto Champion Battle - return 23.498; - case "battle_hoenn_champion_g5": //B2W2 Hoenn Champion Battle - return 11.328; - case "battle_hoenn_champion_g6": //ORAS Hoenn Champion Battle - return 11.762; - case "battle_sinnoh_champion": //B2W2 Sinnoh Champion Battle - return 12.235; - case "battle_champion_alder": //BW Unova Champion Battle - return 27.653; - case "battle_champion_iris": //B2W2 Unova Champion Battle - return 10.145; - case "battle_kalos_champion": //XY Kalos Champion Battle - return 10.380; - case "battle_alola_champion": //USUM Alola Champion Battle - return 13.025; - case "battle_galar_champion": //SWSH Galar Champion Battle - return 61.635; - case "battle_champion_geeta": //SV Champion Geeta Battle - return 37.447; - case "battle_champion_nemona": //SV Champion Nemona Battle - return 14.914; - case "battle_champion_kieran": //SV Champion Kieran Battle - return 7.206; - case "battle_hoenn_elite": //ORAS Elite Four Battle - return 11.350; - case "battle_unova_elite": //BW Elite Four Battle - return 17.730; - case "battle_kalos_elite": //XY Elite Four Battle - return 12.340; - case "battle_alola_elite": //SM Elite Four Battle - return 19.212; - case "battle_galar_elite": //SWSH League Tournament Battle - return 164.069; - case "battle_paldea_elite": //SV Elite Four Battle - return 12.770; - case "battle_bb_elite": //SV BB League Elite Four Battle - return 19.434; - case "battle_final_encounter": //PMD RTDX Rayquaza's Domain - return 19.159; - case "battle_final": //BW Ghetsis Battle - return 16.453; - case "battle_kanto_gym": //B2W2 Kanto Gym Battle - return 13.857; - case "battle_johto_gym": //B2W2 Johto Gym Battle - return 12.911; - case "battle_hoenn_gym": //B2W2 Hoenn Gym Battle - return 12.379; - case "battle_sinnoh_gym": //B2W2 Sinnoh Gym Battle - return 13.122; - case "battle_unova_gym": //BW Unova Gym Battle - return 19.145; - case "battle_kalos_gym": //XY Kalos Gym Battle - return 44.810; - case "battle_galar_gym": //SWSH Galar Gym Battle - return 171.262; - case "battle_paldea_gym": //SV Paldea Gym Battle - return 127.489; - case "battle_legendary_kanto": //XY Kanto Legendary Battle - return 32.966; - case "battle_legendary_raikou": //HGSS Raikou Battle - return 12.632; - case "battle_legendary_entei": //HGSS Entei Battle - return 2.905; - case "battle_legendary_suicune": //HGSS Suicune Battle - return 12.636; - case "battle_legendary_lugia": //HGSS Lugia Battle - return 19.770; - case "battle_legendary_ho_oh": //HGSS Ho-oh Battle - return 17.668; - case "battle_legendary_regis_g5": //B2W2 Legendary Titan Battle - return 49.500; - case "battle_legendary_regis_g6": //ORAS Legendary Titan Battle - return 21.130; - case "battle_legendary_gro_kyo": //ORAS Groudon & Kyogre Battle - return 10.547; - case "battle_legendary_rayquaza": //ORAS Rayquaza Battle - return 10.495; - case "battle_legendary_deoxys": //ORAS Deoxys Battle - return 13.333; - case "battle_legendary_lake_trio": //ORAS Lake Guardians Battle - return 16.887; - case "battle_legendary_sinnoh": //ORAS Sinnoh Legendary Battle - return 22.770; - case "battle_legendary_dia_pal": //ORAS Dialga & Palkia Battle - return 16.009; - case "battle_legendary_origin_forme": //LA Origin Dialga & Palkia Battle - return 18.961; - case "battle_legendary_giratina": //ORAS Giratina Battle - return 10.451; - case "battle_legendary_arceus": //HGSS Arceus Battle - return 9.595; - case "battle_legendary_unova": //BW Unova Legendary Battle - return 13.855; - case "battle_legendary_kyurem": //BW Kyurem Battle - return 18.314; - case "battle_legendary_res_zek": //BW Reshiram & Zekrom Battle - return 18.329; - case "battle_legendary_xern_yvel": //XY Xerneas & Yveltal Battle - return 26.468; - case "battle_legendary_tapu": //SM Tapu Battle - return 0.000; - case "battle_legendary_sol_lun": //SM Solgaleo & Lunala Battle - return 6.525; - case "battle_legendary_ub": //SM Ultra Beast Battle - return 9.818; - case "battle_legendary_dusk_dawn": //USUM Dusk Mane & Dawn Wings Necrozma Battle - return 5.211; - case "battle_legendary_ultra_nec": //USUM Ultra Necrozma Battle - return 10.344; - case "battle_legendary_zac_zam": //SWSH Zacian & Zamazenta Battle - return 11.424; - case "battle_legendary_glas_spec": //SWSH Glastrier & Spectrier Battle - return 12.503; - case "battle_legendary_calyrex": //SWSH Calyrex Battle - return 50.641; - case "battle_legendary_riders": //SWSH Ice & Shadow Rider Calyrex Battle - return 18.155; - case "battle_legendary_birds_galar": //SWSH Galarian Legendary Birds Battle - return 0.175; - case "battle_legendary_ruinous": //SV Treasures of Ruin Battle - return 6.333; - case "battle_legendary_kor_mir": //SV Depths of Area Zero Battle - return 6.442; - case "battle_legendary_loyal_three": //SV Loyal Three Battle - return 6.500; - case "battle_legendary_ogerpon": //SV Ogerpon Battle - return 14.335; - case "battle_legendary_terapagos": //SV Terapagos Battle - return 24.377; - case "battle_legendary_pecharunt": //SV Pecharunt Battle - return 6.508; - case "battle_rival": //BW Rival Battle - return 14.110; - case "battle_rival_2": //BW N Battle - return 17.714; - case "battle_rival_3": //BW Final N Battle - return 17.586; - case "battle_trainer": //BW Trainer Battle - return 13.686; - case "battle_wild": //BW Wild Battle - return 12.703; - case "battle_wild_strong": //BW Strong Wild Battle - return 13.940; - case "end_summit": //PMD RTDX Sky Tower Summit - return 30.025; - case "battle_rocket_grunt": //HGSS Team Rocket Battle - return 12.707; - case "battle_aqua_magma_grunt": //ORAS Team Aqua & Magma Battle - return 12.062; - case "battle_galactic_grunt": //BDSP Team Galactic Battle - return 13.043; - case "battle_plasma_grunt": //BW Team Plasma Battle - return 12.974; - case "battle_flare_grunt": //XY Team Flare Battle - return 4.228; - case "battle_aether_grunt": // SM Aether Foundation Battle - return 16.00; - case "battle_skull_grunt": // SM Team Skull Battle - return 20.87; - case "battle_macro_grunt": // SWSH Trainer Battle - return 11.56; - case "battle_galactic_admin": //BDSP Team Galactic Admin Battle - return 11.997; - case "battle_skull_admin": //SM Team Skull Admin Battle - return 15.463; - case "battle_oleana": //SWSH Oleana Battle - return 14.110; - case "battle_rocket_boss": //USUM Giovanni Battle - return 9.115; - case "battle_aqua_magma_boss": //ORAS Archie & Maxie Battle - return 14.847; - case "battle_galactic_boss": //BDSP Cyrus Battle - return 106.962; - case "battle_plasma_boss": //B2W2 Ghetsis Battle - return 25.624; - case "battle_flare_boss": //XY Lysandre Battle - return 8.085; - case "battle_aether_boss": //SM Lusamine Battle - return 11.33; - case "battle_skull_boss": //SM Guzma Battle - return 13.13; - case "battle_macro_boss": //SWSH Rose Battle - return 11.42; + case "battle_kanto_champion": //B2W2 Kanto Champion Battle + return 13.950; + case "battle_johto_champion": //B2W2 Johto Champion Battle + return 23.498; + case "battle_hoenn_champion_g5": //B2W2 Hoenn Champion Battle + return 11.328; + case "battle_hoenn_champion_g6": //ORAS Hoenn Champion Battle + return 11.762; + case "battle_sinnoh_champion": //B2W2 Sinnoh Champion Battle + return 12.235; + case "battle_champion_alder": //BW Unova Champion Battle + return 27.653; + case "battle_champion_iris": //B2W2 Unova Champion Battle + return 10.145; + case "battle_kalos_champion": //XY Kalos Champion Battle + return 10.380; + case "battle_alola_champion": //USUM Alola Champion Battle + return 13.025; + case "battle_galar_champion": //SWSH Galar Champion Battle + return 61.635; + case "battle_champion_geeta": //SV Champion Geeta Battle + return 37.447; + case "battle_champion_nemona": //SV Champion Nemona Battle + return 14.914; + case "battle_champion_kieran": //SV Champion Kieran Battle + return 7.206; + case "battle_hoenn_elite": //ORAS Elite Four Battle + return 11.350; + case "battle_unova_elite": //BW Elite Four Battle + return 17.730; + case "battle_kalos_elite": //XY Elite Four Battle + return 12.340; + case "battle_alola_elite": //SM Elite Four Battle + return 19.212; + case "battle_galar_elite": //SWSH League Tournament Battle + return 164.069; + case "battle_paldea_elite": //SV Elite Four Battle + return 12.770; + case "battle_bb_elite": //SV BB League Elite Four Battle + return 19.434; + case "battle_final_encounter": //PMD RTDX Rayquaza's Domain + return 19.159; + case "battle_final": //BW Ghetsis Battle + return 16.453; + case "battle_kanto_gym": //B2W2 Kanto Gym Battle + return 13.857; + case "battle_johto_gym": //B2W2 Johto Gym Battle + return 12.911; + case "battle_hoenn_gym": //B2W2 Hoenn Gym Battle + return 12.379; + case "battle_sinnoh_gym": //B2W2 Sinnoh Gym Battle + return 13.122; + case "battle_unova_gym": //BW Unova Gym Battle + return 19.145; + case "battle_kalos_gym": //XY Kalos Gym Battle + return 44.810; + case "battle_galar_gym": //SWSH Galar Gym Battle + return 171.262; + case "battle_paldea_gym": //SV Paldea Gym Battle + return 127.489; + case "battle_legendary_kanto": //XY Kanto Legendary Battle + return 32.966; + case "battle_legendary_raikou": //HGSS Raikou Battle + return 12.632; + case "battle_legendary_entei": //HGSS Entei Battle + return 2.905; + case "battle_legendary_suicune": //HGSS Suicune Battle + return 12.636; + case "battle_legendary_lugia": //HGSS Lugia Battle + return 19.770; + case "battle_legendary_ho_oh": //HGSS Ho-oh Battle + return 17.668; + case "battle_legendary_regis_g5": //B2W2 Legendary Titan Battle + return 49.500; + case "battle_legendary_regis_g6": //ORAS Legendary Titan Battle + return 21.130; + case "battle_legendary_gro_kyo": //ORAS Groudon & Kyogre Battle + return 10.547; + case "battle_legendary_rayquaza": //ORAS Rayquaza Battle + return 10.495; + case "battle_legendary_deoxys": //ORAS Deoxys Battle + return 13.333; + case "battle_legendary_lake_trio": //ORAS Lake Guardians Battle + return 16.887; + case "battle_legendary_sinnoh": //ORAS Sinnoh Legendary Battle + return 22.770; + case "battle_legendary_dia_pal": //ORAS Dialga & Palkia Battle + return 16.009; + case "battle_legendary_origin_forme": //LA Origin Dialga & Palkia Battle + return 18.961; + case "battle_legendary_giratina": //ORAS Giratina Battle + return 10.451; + case "battle_legendary_arceus": //HGSS Arceus Battle + return 9.595; + case "battle_legendary_unova": //BW Unova Legendary Battle + return 13.855; + case "battle_legendary_kyurem": //BW Kyurem Battle + return 18.314; + case "battle_legendary_res_zek": //BW Reshiram & Zekrom Battle + return 18.329; + case "battle_legendary_xern_yvel": //XY Xerneas & Yveltal Battle + return 26.468; + case "battle_legendary_tapu": //SM Tapu Battle + return 0.000; + case "battle_legendary_sol_lun": //SM Solgaleo & Lunala Battle + return 6.525; + case "battle_legendary_ub": //SM Ultra Beast Battle + return 9.818; + case "battle_legendary_dusk_dawn": //USUM Dusk Mane & Dawn Wings Necrozma Battle + return 5.211; + case "battle_legendary_ultra_nec": //USUM Ultra Necrozma Battle + return 10.344; + case "battle_legendary_zac_zam": //SWSH Zacian & Zamazenta Battle + return 11.424; + case "battle_legendary_glas_spec": //SWSH Glastrier & Spectrier Battle + return 12.503; + case "battle_legendary_calyrex": //SWSH Calyrex Battle + return 50.641; + case "battle_legendary_riders": //SWSH Ice & Shadow Rider Calyrex Battle + return 18.155; + case "battle_legendary_birds_galar": //SWSH Galarian Legendary Birds Battle + return 0.175; + case "battle_legendary_ruinous": //SV Treasures of Ruin Battle + return 6.333; + case "battle_legendary_kor_mir": //SV Depths of Area Zero Battle + return 6.442; + case "battle_legendary_loyal_three": //SV Loyal Three Battle + return 6.500; + case "battle_legendary_ogerpon": //SV Ogerpon Battle + return 14.335; + case "battle_legendary_terapagos": //SV Terapagos Battle + return 24.377; + case "battle_legendary_pecharunt": //SV Pecharunt Battle + return 6.508; + case "battle_rival": //BW Rival Battle + return 14.110; + case "battle_rival_2": //BW N Battle + return 17.714; + case "battle_rival_3": //BW Final N Battle + return 17.586; + case "battle_trainer": //BW Trainer Battle + return 13.686; + case "battle_wild": //BW Wild Battle + return 12.703; + case "battle_wild_strong": //BW Strong Wild Battle + return 13.940; + case "end_summit": //PMD RTDX Sky Tower Summit + return 30.025; + case "battle_rocket_grunt": //HGSS Team Rocket Battle + return 12.707; + case "battle_aqua_magma_grunt": //ORAS Team Aqua & Magma Battle + return 12.062; + case "battle_galactic_grunt": //BDSP Team Galactic Battle + return 13.043; + case "battle_plasma_grunt": //BW Team Plasma Battle + return 12.974; + case "battle_flare_grunt": //XY Team Flare Battle + return 4.228; + case "battle_aether_grunt": // SM Aether Foundation Battle + return 16.00; + case "battle_skull_grunt": // SM Team Skull Battle + return 20.87; + case "battle_macro_grunt": // SWSH Trainer Battle + return 11.56; + case "battle_star_grunt": //SV Team Star Battle + return 133.362; + case "battle_galactic_admin": //BDSP Team Galactic Admin Battle + return 11.997; + case "battle_skull_admin": //SM Team Skull Admin Battle + return 15.463; + case "battle_oleana": //SWSH Oleana Battle + return 14.110; + case "battle_star_admin": //SV Team Star Boss Battle + return 9.493; + case "battle_rocket_boss": //USUM Giovanni Battle + return 9.115; + case "battle_aqua_magma_boss": //ORAS Archie & Maxie Battle + return 14.847; + case "battle_galactic_boss": //BDSP Cyrus Battle + return 106.962; + case "battle_plasma_boss": //B2W2 Ghetsis Battle + return 25.624; + case "battle_flare_boss": //XY Lysandre Battle + return 8.085; + case "battle_aether_boss": //SM Lusamine Battle + return 11.33; + case "battle_skull_boss": //SM Guzma Battle + return 13.13; + case "battle_macro_boss": //SWSH Rose Battle + return 11.42; + case "battle_star_boss": //SV Cassiopeia Battle + return 25.764; + case "mystery_encounter_gen_5_gts": // BW GTS + return 8.52; + case "mystery_encounter_gen_6_gts": // XY GTS + return 9.24; + case "mystery_encounter_fun_and_games": // EoS Guildmaster Wigglytuff + return 4.78; + case "mystery_encounter_weird_dream": // EoS Temporal Spire + return 41.42; + case "mystery_encounter_delibirdy": // Firel Delibirdy + return 82.28; } return 0; @@ -2191,7 +2274,7 @@ export default class BattleScene extends SceneBase { * */ pushConditionalPhase(phase: Phase, condition: () => boolean): void { - this.conditionalQueue.push([condition, phase]); + this.conditionalQueue.push([ condition, phase ]); } /** @@ -2283,7 +2366,10 @@ export default class BattleScene extends SceneBase { } } - this.currentPhase?.start(); + if (this.currentPhase) { + console.log(`%cStart Phase ${this.currentPhase.constructor.name}`, "color:green;"); + this.currentPhase.start(); + } } overridePhase(phase: Phase): boolean { @@ -2293,6 +2379,7 @@ export default class BattleScene extends SceneBase { this.standbyPhase = this.currentPhase; this.currentPhase = phase; + console.log(`%cStart Phase ${phase.constructor.name}`, "color:green;"); phase.start(); return true; @@ -2326,15 +2413,17 @@ export default class BattleScene extends SceneBase { return false; } - pushMovePhase(movePhase: MovePhase, priorityOverride?: integer): void { - const movePriority = new Utils.IntegerHolder(priorityOverride !== undefined ? priorityOverride : movePhase.move.getMove().priority); - applyAbAttrs(ChangeMovePriorityAbAttr, movePhase.pokemon, null, false, movePhase.move.getMove(), movePriority); - const lowerPriorityPhase = this.phaseQueue.find(p => p instanceof MovePhase && p.move.getMove().priority < movePriority.value); - if (lowerPriorityPhase) { - this.phaseQueue.splice(this.phaseQueue.indexOf(lowerPriorityPhase), 0, movePhase); - } else { - this.pushPhase(movePhase); + /** + * Will search for a specific phase in {@linkcode phaseQueuePrepend} via filter, and remove the first result if a match is found. + * @param phaseFilter filter function + */ + tryRemoveUnshiftedPhase(phaseFilter: (phase: Phase) => boolean): boolean { + const phaseIndex = this.phaseQueuePrepend.findIndex(phaseFilter); + if (phaseIndex > -1) { + this.phaseQueuePrepend.splice(phaseIndex, 1); + return true; } + return false; } /** @@ -2399,7 +2488,7 @@ export default class BattleScene extends SceneBase { return Math.floor(moneyValue / 10) * 10; } - addModifier(modifier: Modifier | null, ignoreUpdate?: boolean, playSound?: boolean, virtual?: boolean, instant?: boolean): Promise { + addModifier(modifier: Modifier | null, ignoreUpdate?: boolean, playSound?: boolean, virtual?: boolean, instant?: boolean, cost?: number): Promise { if (!modifier) { return Promise.resolve(false); } @@ -2415,7 +2504,10 @@ export default class BattleScene extends SceneBase { } if ((modifier as PersistentModifier).add(this.modifiers, !!virtual, this)) { if (modifier instanceof PokemonFormChangeItemModifier || modifier instanceof TerastallizeModifier) { - success = modifier.apply([ this.getPokemonById(modifier.pokemonId), true ]); + const pokemon = this.getPokemonById(modifier.pokemonId); + if (pokemon) { + success = modifier.apply(pokemon, true); + } } if (playSound && !this.sound.get(soundName)) { this.playSound(soundName); @@ -2442,7 +2534,7 @@ export default class BattleScene extends SceneBase { for (const p in this.party) { const pokemon = this.party[p]; - const args: any[] = [ pokemon ]; + const args: unknown[] = []; if (modifier instanceof PokemonHpRestoreModifier) { if (!(modifier as PokemonHpRestoreModifier).fainted) { const hpRestoreMultiplier = new Utils.IntegerHolder(1); @@ -2453,10 +2545,12 @@ export default class BattleScene extends SceneBase { } } else if (modifier instanceof FusePokemonModifier) { args.push(this.getPokemonById(modifier.fusePokemonId) as PlayerPokemon); + } else if (modifier instanceof RememberMoveModifier && !Utils.isNullOrUndefined(cost)) { + args.push(cost); } - if (modifier.shouldApply(args)) { - const result = modifier.apply(args); + if (modifier.shouldApply(pokemon, ...args)) { + const result = modifier.apply(pokemon, ...args); if (result instanceof Promise) { modifierPromises.push(result.then(s => success ||= s)); } else { @@ -2465,11 +2559,11 @@ export default class BattleScene extends SceneBase { } } - return Promise.allSettled([this.party.map(p => p.updateInfo(instant)), ...modifierPromises]).then(() => resolve(success)); + return Promise.allSettled([ this.party.map(p => p.updateInfo(instant)), ...modifierPromises ]).then(() => resolve(success)); } else { const args = [ this ]; - if (modifier.shouldApply(args)) { - const result = modifier.apply(args); + if (modifier.shouldApply(...args)) { + const result = modifier.apply(...args); if (result instanceof Promise) { return result.then(success => resolve(success)); } else { @@ -2491,7 +2585,10 @@ export default class BattleScene extends SceneBase { } if ((modifier as PersistentModifier).add(this.enemyModifiers, false, this)) { if (modifier instanceof PokemonFormChangeItemModifier || modifier instanceof TerastallizeModifier) { - modifier.apply([ this.getPokemonById(modifier.pokemonId), true ]); + const pokemon = this.getPokemonById(modifier.pokemonId); + if (pokemon) { + modifier.apply(pokemon, true); + } } for (const rm of modifiersToRemove) { this.removeModifier(rm, true); @@ -2511,14 +2608,15 @@ export default class BattleScene extends SceneBase { * The quantity to transfer is automatically capped at how much the recepient can take before reaching the maximum stack size for the item. * A transfer that moves a quantity smaller than what is specified in the transferQuantity parameter is still considered successful. * @param itemModifier {@linkcode PokemonHeldItemModifier} item to transfer (represents the whole stack) - * @param target {@linkcode Pokemon} pokemon recepient in this transfer - * @param playSound {boolean} - * @param transferQuantity {@linkcode integer} how many items of the stack to transfer. Optional, defaults to 1 - * @param instant {boolean} - * @param ignoreUpdate {boolean} - * @returns true if the transfer was successful + * @param target {@linkcode Pokemon} recepient in this transfer + * @param playSound `true` to play a sound when transferring the item + * @param transferQuantity How many items of the stack to transfer. Optional, defaults to `1` + * @param instant ??? (Optional) + * @param ignoreUpdate ??? (Optional) + * @param itemLost If `true`, treat the item's current holder as losing the item (for now, this simply enables Unburden). Default is `true`. + * @returns `true` if the transfer was successful */ - tryTransferHeldItemModifier(itemModifier: PokemonHeldItemModifier, target: Pokemon, playSound: boolean, transferQuantity: integer = 1, instant?: boolean, ignoreUpdate?: boolean): Promise { + tryTransferHeldItemModifier(itemModifier: PokemonHeldItemModifier, target: Pokemon, playSound: boolean, transferQuantity: number = 1, instant?: boolean, ignoreUpdate?: boolean, itemLost: boolean = true): Promise { return new Promise(resolve => { const source = itemModifier.pokemonId ? itemModifier.getPokemon(target.scene) : null; const cancelled = new Utils.BooleanHolder(false); @@ -2550,9 +2648,19 @@ export default class BattleScene extends SceneBase { const addModifier = () => { if (!matchingModifier || this.removeModifier(matchingModifier, !target.isPlayer())) { if (target.isPlayer()) { - this.addModifier(newItemModifier, ignoreUpdate, playSound, false, instant).then(() => resolve(true)); + this.addModifier(newItemModifier, ignoreUpdate, playSound, false, instant).then(() => { + if (source && itemLost) { + applyPostItemLostAbAttrs(PostItemLostAbAttr, source, false); + } + resolve(true); + }); } else { - this.addEnemyModifier(newItemModifier, ignoreUpdate, instant).then(() => resolve(true)); + this.addEnemyModifier(newItemModifier, ignoreUpdate, instant).then(() => { + if (source && itemLost) { + applyPostItemLostAbAttrs(PostItemLostAbAttr, source, false); + } + resolve(true); + }); } } else { resolve(false); @@ -2572,7 +2680,7 @@ export default class BattleScene extends SceneBase { removePartyMemberModifiers(partyMemberIndex: integer): Promise { return new Promise(resolve => { - const pokemonId = this.getParty()[partyMemberIndex].id; + const pokemonId = this.getPlayerParty()[partyMemberIndex].id; const modifiersToRemove = this.modifiers.filter(m => m instanceof PokemonHeldItemModifier && (m as PokemonHeldItemModifier).pokemonId === pokemonId); for (const m of modifiersToRemove) { this.modifiers.splice(this.modifiers.indexOf(m), 1); @@ -2603,7 +2711,7 @@ export default class BattleScene extends SceneBase { } party.forEach((enemyPokemon: EnemyPokemon, i: integer) => { - if (heldModifiersConfigs && i < heldModifiersConfigs.length && heldModifiersConfigs[i] && heldModifiersConfigs[i].length > 0) { + if (heldModifiersConfigs && i < heldModifiersConfigs.length && heldModifiersConfigs[i]) { heldModifiersConfigs[i].forEach(mt => { let modifier: PokemonHeldItemModifier; if (mt.modifier instanceof PokemonHeldItemModifierType) { @@ -2612,10 +2720,8 @@ export default class BattleScene extends SceneBase { modifier = mt.modifier as PokemonHeldItemModifier; modifier.pokemonId = enemyPokemon.id; } - const stackCount = mt.stackCount ?? 1; - modifier.stackCount = stackCount; - // TODO: set isTransferable - // modifier.isTransferrable = mt.isTransferable ?? true; + modifier.stackCount = mt.stackCount ?? 1; + modifier.isTransferable = mt.isTransferable ?? modifier.isTransferable; this.addEnemyModifier(modifier, true); }); } else { @@ -2650,7 +2756,7 @@ export default class BattleScene extends SceneBase { } /** - * Removes all modifiers from enemy of PersistentModifier type + * Removes all modifiers from enemy pokemon of {@linkcode PersistentModifier} type */ clearEnemyModifiers(): void { const modifiersToRemove = this.enemyModifiers.filter(m => m instanceof PersistentModifier); @@ -2661,10 +2767,11 @@ export default class BattleScene extends SceneBase { } /** - * Removes all modifiers from enemy of PokemonHeldItemModifier type + * Removes all modifiers from enemy pokemon of {@linkcode PokemonHeldItemModifier} type + * @param pokemon - If specified, only removes held items from that {@linkcode Pokemon} */ - clearEnemyHeldItemModifiers(): void { - const modifiersToRemove = this.enemyModifiers.filter(m => m instanceof PokemonHeldItemModifier); + clearEnemyHeldItemModifiers(pokemon?: Pokemon): void { + const modifiersToRemove = this.enemyModifiers.filter(m => m instanceof PokemonHeldItemModifier && (!pokemon || m.getPokemon(this) === pokemon)); for (const m of modifiersToRemove) { this.enemyModifiers.splice(this.enemyModifiers.indexOf(m), 1); } @@ -2700,7 +2807,7 @@ export default class BattleScene extends SceneBase { } } - this.updatePartyForModifiers(player ? this.getParty() : this.getEnemyParty(), instant).then(() => { + this.updatePartyForModifiers(player ? this.getPlayerParty() : this.getEnemyParty(), instant).then(() => { (player ? this.modifierBar : this.enemyModifierBar).updateModifiers(modifiers); if (!player) { this.updateUIPositions(); @@ -2721,13 +2828,24 @@ export default class BattleScene extends SceneBase { }); } - removeModifier(modifier: PersistentModifier, enemy?: boolean): boolean { + /** + * Removes a currently owned item. If the item is stacked, the entire item stack + * gets removed. This function does NOT apply in-battle effects, such as Unburden. + * If in-battle effects are needed, use {@linkcode Pokemon.loseHeldItem} instead. + * @param modifier The item to be removed. + * @param enemy If `true`, remove an item owned by the enemy. If `false`, remove an item owned by the player. Default is `false`. + * @returns `true` if the item exists and was successfully removed, `false` otherwise. + */ + removeModifier(modifier: PersistentModifier, enemy: boolean = false): boolean { const modifiers = !enemy ? this.modifiers : this.enemyModifiers; const modifierIndex = modifiers.indexOf(modifier); if (modifierIndex > -1) { modifiers.splice(modifierIndex, 1); if (modifier instanceof PokemonFormChangeItemModifier || modifier instanceof TerastallizeModifier) { - modifier.apply([ this.getPokemonById(modifier.pokemonId), false ]); + const pokemon = this.getPokemonById(modifier.pokemonId); + if (pokemon) { + modifier.apply(pokemon, false); + } } return true; } @@ -2745,38 +2863,66 @@ export default class BattleScene extends SceneBase { return (player ? this.modifiers : this.enemyModifiers).filter((m): m is T => m instanceof modifierType); } - findModifiers(modifierFilter: ModifierPredicate, player: boolean = true): PersistentModifier[] { - return (player ? this.modifiers : this.enemyModifiers).filter(m => (modifierFilter as ModifierPredicate)(m)); + /** + * Get all of the modifiers that pass the `modifierFilter` function + * @param modifierFilter The function used to filter a target's modifiers + * @param isPlayer Whether to search the player (`true`) or the enemy (`false`); Defaults to `true` + * @returns the list of all modifiers that passed the `modifierFilter` function + */ + findModifiers(modifierFilter: ModifierPredicate, isPlayer: boolean = true): PersistentModifier[] { + return (isPlayer ? this.modifiers : this.enemyModifiers).filter(modifierFilter); } + /** + * Find the first modifier that pass the `modifierFilter` function + * @param modifierFilter The function used to filter a target's modifiers + * @param player Whether to search the player (`true`) or the enemy (`false`); Defaults to `true` + * @returns the first modifier that passed the `modifierFilter` function; `undefined` if none passed + */ findModifier(modifierFilter: ModifierPredicate, player: boolean = true): PersistentModifier | undefined { - return (player ? this.modifiers : this.enemyModifiers).find(m => (modifierFilter as ModifierPredicate)(m)); + return (player ? this.modifiers : this.enemyModifiers).find(modifierFilter); } - applyShuffledModifiers(scene: BattleScene, modifierType: Constructor, player: boolean = true, ...args: any[]): PersistentModifier[] { - let modifiers = (player ? this.modifiers : this.enemyModifiers).filter(m => m instanceof modifierType && m.shouldApply(args)); + /** + * Apply all modifiers that match `modifierType` in a random order + * @param scene {@linkcode BattleScene} used to randomize the order of modifiers + * @param modifierType The type of modifier to apply; must extend {@linkcode PersistentModifier} + * @param player Whether to search the player (`true`) or the enemy (`false`); Defaults to `true` + * @param ...args The list of arguments needed to invoke `modifierType.apply` + * @returns the list of all modifiers that matched `modifierType` and were applied. + */ + applyShuffledModifiers(scene: BattleScene, modifierType: Constructor, player: boolean = true, ...args: Parameters): T[] { + let modifiers = (player ? this.modifiers : this.enemyModifiers).filter((m): m is T => m instanceof modifierType && m.shouldApply(...args)); scene.executeWithSeedOffset(() => { const shuffleModifiers = mods => { if (mods.length < 1) { return mods; } const rand = Utils.randSeedInt(mods.length); - return [mods[rand], ...shuffleModifiers(mods.filter((_, i) => i !== rand))]; + return [ mods[rand], ...shuffleModifiers(mods.filter((_, i) => i !== rand)) ]; }; modifiers = shuffleModifiers(modifiers); }, scene.currentBattle.turn << 4, scene.waveSeed); return this.applyModifiersInternal(modifiers, player, args); } - applyModifiers(modifierType: Constructor, player: boolean = true, ...args: any[]): PersistentModifier[] { - const modifiers = (player ? this.modifiers : this.enemyModifiers).filter(m => m instanceof modifierType && m.shouldApply(args)); + /** + * Apply all modifiers that match `modifierType` + * @param modifierType The type of modifier to apply; must extend {@linkcode PersistentModifier} + * @param player Whether to search the player (`true`) or the enemy (`false`); Defaults to `true` + * @param ...args The list of arguments needed to invoke `modifierType.apply` + * @returns the list of all modifiers that matched `modifierType` and were applied. + */ + applyModifiers(modifierType: Constructor, player: boolean = true, ...args: Parameters): T[] { + const modifiers = (player ? this.modifiers : this.enemyModifiers).filter((m): m is T => m instanceof modifierType && m.shouldApply(...args)); return this.applyModifiersInternal(modifiers, player, args); } - applyModifiersInternal(modifiers: PersistentModifier[], player: boolean, args: any[]): PersistentModifier[] { - const appliedModifiers: PersistentModifier[] = []; + /** Helper function to apply all passed modifiers */ + applyModifiersInternal(modifiers: T[], player: boolean, args: Parameters): T[] { + const appliedModifiers: T[] = []; for (const modifier of modifiers) { - if (modifier.apply(args)) { + if (modifier.apply(...args)) { console.log("Applied", modifier.type.name, !player ? "(enemy)" : ""); appliedModifiers.push(modifier); } @@ -2785,10 +2931,17 @@ export default class BattleScene extends SceneBase { return appliedModifiers; } - applyModifier(modifierType: Constructor, player: boolean = true, ...args: any[]): PersistentModifier | null { - const modifiers = (player ? this.modifiers : this.enemyModifiers).filter(m => m instanceof modifierType && m.shouldApply(args)); + /** + * Apply the first modifier that matches `modifierType` + * @param modifierType The type of modifier to apply; must extend {@linkcode PersistentModifier} + * @param player Whether to search the player (`true`) or the enemy (`false`); Defaults to `true` + * @param ...args The list of arguments needed to invoke `modifierType.apply` + * @returns the first modifier that matches `modifierType` and was applied; return `null` if none matched + */ + applyModifier(modifierType: Constructor, player: boolean = true, ...args: Parameters): T | null { + const modifiers = (player ? this.modifiers : this.enemyModifiers).filter((m): m is T => m instanceof modifierType && m.shouldApply(...args)); for (const modifier of modifiers) { - if (modifier.apply(args)) { + if (modifier.apply(...args)) { console.log("Applied", modifier.type.name, !player ? "(enemy)" : ""); return modifier; } @@ -2854,7 +3007,7 @@ export default class BattleScene extends SceneBase { } } - validateAchv(achv: Achv, args?: any[]): boolean { + validateAchv(achv: Achv, args?: unknown[]): boolean { if (!this.gameData.achvUnlocks.hasOwnProperty(achv.id) && achv.validate(this, args)) { this.gameData.achvUnlocks[achv.id] = new Date().getTime(); this.ui.achvBar.showAchv(achv); @@ -2867,7 +3020,7 @@ export default class BattleScene extends SceneBase { return false; } - validateVoucher(voucher: Voucher, args?: any[]): boolean { + validateVoucher(voucher: Voucher, args?: unknown[]): boolean { if (!this.gameData.voucherUnlocks.hasOwnProperty(voucher.id) && voucher.validate(this, args)) { this.gameData.voucherUnlocks[voucher.id] = new Date().getTime(); this.ui.achvBar.showAchv(voucher); @@ -2880,12 +3033,21 @@ export default class BattleScene extends SceneBase { updateGameInfo(): void { const gameInfo = { - playTime: this.sessionPlayTime ? this.sessionPlayTime : 0, + playTime: this.sessionPlayTime ?? 0, gameMode: this.currentBattle ? this.gameMode.getName() : "Title", biome: this.currentBattle ? getBiomeName(this.arena.biomeType) : "", - wave: this.currentBattle?.waveIndex || 0, - party: this.party ? this.party.map(p => { - return { name: p.name, level: p.level }; + wave: this.currentBattle?.waveIndex ?? 0, + party: this.party ? this.party.map((p) => { + return { + name: p.name, + form: p.getFormKey(), + types: p.getTypes().map((type) => Type[type]), + teraType: p.getTeraType() !== Type.UNKNOWN ? Type[p.getTeraType()] : "", + level: p.level, + currentHP: p.hp, + maxHP: p.getMaxHp(), + status: p.status?.effect ? StatusEffect[p.status.effect] : "" + }; }) : [], modeChain: this.ui?.getModeChain() ?? [], }; @@ -2900,22 +3062,16 @@ export default class BattleScene extends SceneBase { */ getActiveKeys(): string[] { const keys: string[] = []; - const playerParty = this.getParty(); - playerParty.forEach(p => { + let activePokemon: (PlayerPokemon | EnemyPokemon)[] = this.getPlayerParty(); + activePokemon = activePokemon.concat(this.getEnemyParty()); + activePokemon.forEach((p) => { keys.push(p.getSpriteKey(true)); - keys.push(p.getBattleSpriteKey(true, true)); - keys.push("cry/" + p.species.getCryKey(p.formIndex)); - if (p.fusionSpecies) { - keys.push("cry/"+p.fusionSpecies.getCryKey(p.fusionFormIndex)); + if (p instanceof PlayerPokemon) { + keys.push(p.getBattleSpriteKey(true, true)); } - }); - // enemyParty has to be operated on separately from playerParty because playerPokemon =/= enemyPokemon - const enemyParty = this.getEnemyParty(); - enemyParty.forEach(p => { - keys.push(p.getSpriteKey(true)); - keys.push("cry/" + p.species.getCryKey(p.formIndex)); + keys.push(p.species.getCryKey(p.formIndex)); if (p.fusionSpecies) { - keys.push("cry/"+p.fusionSpecies.getCryKey(p.fusionFormIndex)); + keys.push(p.fusionSpecies.getCryKey(p.fusionFormIndex)); } }); return keys; @@ -2936,7 +3092,7 @@ export default class BattleScene extends SceneBase { this.setFieldScale(0.75); this.triggerPokemonFormChange(pokemon, SpeciesFormChangeManualTrigger, false); this.currentBattle.double = true; - const availablePartyMembers = this.getParty().filter((p) => p.isAllowedInBattle()); + const availablePartyMembers = this.getPlayerParty().filter((p) => p.isAllowedInBattle()); if (availablePartyMembers.length > 1) { this.pushPhase(new ToggleDoublePositionPhase(this, true)); if (!availablePartyMembers[1].isOnField()) { @@ -2961,7 +3117,7 @@ export default class BattleScene extends SceneBase { */ applyPartyExp(expValue: number, pokemonDefeated: boolean, useWaveIndexMultiplier?: boolean, pokemonParticipantIds?: Set): void { const participantIds = pokemonParticipantIds ?? this.currentBattle.playerParticipantIds; - const party = this.getParty(); + const party = this.getPlayerParty(); const expShareModifier = this.findModifier(m => m instanceof ExpShareModifier) as ExpShareModifier; const expBalanceModifier = this.findModifier(m => m instanceof ExpBalanceModifier) as ExpBalanceModifier; const multipleParticipantExpBonusModifier = this.findModifier(m => m instanceof MultipleParticipantExpBonusModifier) as MultipleParticipantExpBonusModifier; @@ -2976,14 +3132,14 @@ export default class BattleScene extends SceneBase { if (participantIds.size > 0) { if (this.currentBattle.battleType === BattleType.TRAINER || this.currentBattle.mysteryEncounter?.encounterMode === MysteryEncounterMode.TRAINER_BATTLE) { expValue = Math.floor(expValue * 1.5); - } else if (this.currentBattle.battleType === BattleType.MYSTERY_ENCOUNTER && this.currentBattle.mysteryEncounter) { + } else if (this.currentBattle.isBattleMysteryEncounter() && this.currentBattle.mysteryEncounter) { expValue = Math.floor(expValue * this.currentBattle.mysteryEncounter.expMultiplier); } for (const partyMember of nonFaintedPartyMembers) { const pId = partyMember.id; const participated = participantIds.has(pId); if (participated && pokemonDefeated) { - partyMember.addFriendship(2); + partyMember.addFriendship(FRIENDSHIP_GAIN_FROM_BATTLE); const machoBraceModifier = partyMember.getHeldItems().find(m => m instanceof PokemonIncrementingStatModifier); if (machoBraceModifier && machoBraceModifier.stackCount < machoBraceModifier.getMaxStackCount(this)) { machoBraceModifier.stackCount++; @@ -3053,18 +3209,74 @@ export default class BattleScene extends SceneBase { } } + /** + * Returns if a wave COULD spawn a {@linkcode MysteryEncounter}. + * Even if returns `true`, does not guarantee that a wave will actually be a ME. + * That check is made in {@linkcode BattleScene.isWaveMysteryEncounter} instead. + */ + isMysteryEncounterValidForWave(battleType: BattleType, waveIndex: number): boolean { + const [ lowestMysteryEncounterWave, highestMysteryEncounterWave ] = this.gameMode.getMysteryEncounterLegalWaves(); + return this.gameMode.hasMysteryEncounters && battleType === BattleType.WILD && !this.gameMode.isBoss(waveIndex) && waveIndex < highestMysteryEncounterWave && waveIndex > lowestMysteryEncounterWave; + } + + /** + * Determines whether a wave should randomly generate a {@linkcode MysteryEncounter}. + * Currently, the only modes that MEs are allowed in are Classic and Challenge. + * Additionally, MEs cannot spawn outside of waves 10-180 in those modes + * @param newBattleType + * @param waveIndex + */ + private isWaveMysteryEncounter(newBattleType: BattleType, waveIndex: number): boolean { + const [ lowestMysteryEncounterWave, highestMysteryEncounterWave ] = this.gameMode.getMysteryEncounterLegalWaves(); + if (this.isMysteryEncounterValidForWave(newBattleType, waveIndex)) { + // Base spawn weight is BASE_MYSTERY_ENCOUNTER_SPAWN_WEIGHT/256, and increases by WEIGHT_INCREMENT_ON_SPAWN_MISS/256 for each missed attempt at spawning an encounter on a valid floor + const sessionEncounterRate = this.mysteryEncounterSaveData.encounterSpawnChance; + const encounteredEvents = this.mysteryEncounterSaveData.encounteredEvents; + + // If total number of encounters is lower than expected for the run, slightly favor a new encounter spawn (reverse as well) + // Reduces occurrence of runs with total encounters significantly different from AVERAGE_ENCOUNTERS_PER_RUN_TARGET + // Favored rate changes can never exceed 50%. So if base rate is 15/256 and favored rate would add 200/256, result will be (15 + 128)/256 + const expectedEncountersByFloor = AVERAGE_ENCOUNTERS_PER_RUN_TARGET / (highestMysteryEncounterWave - lowestMysteryEncounterWave) * (waveIndex - lowestMysteryEncounterWave); + const currentRunDiffFromAvg = expectedEncountersByFloor - encounteredEvents.length; + const favoredEncounterRate = sessionEncounterRate + Math.min(currentRunDiffFromAvg * ANTI_VARIANCE_WEIGHT_MODIFIER, MYSTERY_ENCOUNTER_SPAWN_MAX_WEIGHT / 2); + + const successRate = isNullOrUndefined(Overrides.MYSTERY_ENCOUNTER_RATE_OVERRIDE) ? favoredEncounterRate : Overrides.MYSTERY_ENCOUNTER_RATE_OVERRIDE!; + + // If the most recent ME was 3 or fewer waves ago, can never spawn a ME + const canSpawn = encounteredEvents.length === 0 || (waveIndex - encounteredEvents[encounteredEvents.length - 1].waveIndex) > 3 || !isNullOrUndefined(Overrides.MYSTERY_ENCOUNTER_RATE_OVERRIDE); + + if (canSpawn) { + let roll = MYSTERY_ENCOUNTER_SPAWN_MAX_WEIGHT; + // Always rolls the check on the same offset to ensure no RNG changes from reloading session + this.executeWithSeedOffset(() => { + roll = randSeedInt(MYSTERY_ENCOUNTER_SPAWN_MAX_WEIGHT); + }, waveIndex * 3 * 1000); + return roll < successRate; + } + } + + return false; + } + /** * Loads or generates a mystery encounter * @param encounterType used to load session encounter when restarting game, etc. + * @param canBypass optional boolean to indicate that the request is coming from a function that needs to access a Mystery Encounter outside of gameplay requirements * @returns */ - getMysteryEncounter(encounterType?: MysteryEncounterType): MysteryEncounter { + getMysteryEncounter(encounterType?: MysteryEncounterType, canBypass?: boolean): MysteryEncounter { // Loading override or session encounter let encounter: MysteryEncounter | null; - if (!isNullOrUndefined(Overrides.MYSTERY_ENCOUNTER_OVERRIDE) && allMysteryEncounters.hasOwnProperty(Overrides.MYSTERY_ENCOUNTER_OVERRIDE!)) { - encounter = allMysteryEncounters[Overrides.MYSTERY_ENCOUNTER_OVERRIDE!]; + if (!isNullOrUndefined(Overrides.MYSTERY_ENCOUNTER_OVERRIDE) && allMysteryEncounters.hasOwnProperty(Overrides.MYSTERY_ENCOUNTER_OVERRIDE)) { + encounter = allMysteryEncounters[Overrides.MYSTERY_ENCOUNTER_OVERRIDE]; + if (canBypass) { + return encounter; + } + } else if (canBypass) { + encounter = allMysteryEncounters[encounterType ?? -1]; + return encounter; } else { - encounter = !isNullOrUndefined(encounterType) ? allMysteryEncounters[encounterType!] : null; + encounter = !isNullOrUndefined(encounterType) ? allMysteryEncounters[encounterType] : null; } // Check for queued encounters first @@ -3088,7 +3300,7 @@ export default class BattleScene extends SceneBase { } // See Enum values for base tier weights - const tierWeights = [MysteryEncounterTier.COMMON, MysteryEncounterTier.GREAT, MysteryEncounterTier.ULTRA, MysteryEncounterTier.ROGUE]; + const tierWeights = [ MysteryEncounterTier.COMMON, MysteryEncounterTier.GREAT, MysteryEncounterTier.ULTRA, MysteryEncounterTier.ROGUE ]; // Adjust tier weights by previously encountered events to lower odds of only Common/Great in run this.mysteryEncounterSaveData.encounteredEvents.forEach(seenEncounterData => { @@ -3107,7 +3319,7 @@ export default class BattleScene extends SceneBase { let tier: MysteryEncounterTier | null = tierValue > commonThreshold ? MysteryEncounterTier.COMMON : tierValue > greatThreshold ? MysteryEncounterTier.GREAT : tierValue > ultraThreshold ? MysteryEncounterTier.ULTRA : MysteryEncounterTier.ROGUE; if (!isNullOrUndefined(Overrides.MYSTERY_ENCOUNTER_TIER_OVERRIDE)) { - tier = Overrides.MYSTERY_ENCOUNTER_TIER_OVERRIDE!; + tier = Overrides.MYSTERY_ENCOUNTER_TIER_OVERRIDE; } let availableEncounters: MysteryEncounter[] = []; @@ -3125,11 +3337,17 @@ export default class BattleScene extends SceneBase { if (encounterCandidate.encounterTier !== tier) { // Encounter is in tier return false; } - const disabledModes = encounterCandidate.disabledGameModes; - if (disabledModes && disabledModes.length > 0 - && disabledModes.includes(this.gameMode.modeId)) { // Encounter is enabled for game mode + const disallowedGameModes = encounterCandidate.disallowedGameModes; + if (disallowedGameModes && disallowedGameModes.length > 0 + && disallowedGameModes.includes(this.gameMode.modeId)) { // Encounter is enabled for game mode return false; } + if (this.gameMode.modeId === GameModes.CHALLENGE) { // Encounter is enabled for challenges + const disallowedChallenges = encounterCandidate.disallowedChallenges; + if (disallowedChallenges && disallowedChallenges.length > 0 && this.gameMode.challenges.some(challenge => disallowedChallenges.includes(challenge.id))) { + return false; + } + } if (!encounterCandidate.meetsRequirements(this)) { // Meets encounter requirements return false; } diff --git a/src/battle.ts b/src/battle.ts index a886a0eb771..75f0dff2534 100644 --- a/src/battle.ts +++ b/src/battle.ts @@ -4,18 +4,29 @@ import * as Utils from "./utils"; import Trainer, { TrainerVariant } from "./field/trainer"; import { GameMode } from "./game-mode"; import { MoneyMultiplierModifier, PokemonHeldItemModifier } from "./modifier/modifier"; -import { PokeballType } from "./data/pokeball"; +import { PokeballType } from "#enums/pokeball"; import { trainerConfigs } from "#app/data/trainer-config"; +import { SpeciesFormKey } from "#enums/species-form-key"; import Pokemon, { EnemyPokemon, PlayerPokemon, QueuedMove } from "#app/field/pokemon"; import { ArenaTagType } from "#enums/arena-tag-type"; import { BattleSpec } from "#enums/battle-spec"; import { Moves } from "#enums/moves"; import { PlayerGender } from "#enums/player-gender"; +import { MusicPreference } from "#app/system/settings/settings"; import { Species } from "#enums/species"; import { TrainerType } from "#enums/trainer-type"; import i18next from "#app/plugins/i18n"; -import MysteryEncounter from "./data/mystery-encounters/mystery-encounter"; +import MysteryEncounter from "#app/data/mystery-encounters/mystery-encounter"; import { MysteryEncounterMode } from "#enums/mystery-encounter-mode"; +import { CustomModifierSettings } from "#app/modifier/modifier-type"; +import { ModifierTier } from "#app/modifier/modifier-tier"; +import { MysteryEncounterType } from "#enums/mystery-encounter-type"; + +export enum ClassicFixedBossWaves { + // TODO: other fixed wave battles should be added here + EVIL_BOSS_1 = 115, + EVIL_BOSS_2 = 165, +} export enum BattleType { WILD, @@ -80,6 +91,7 @@ export default class Battle { public playerFaintsHistory: FaintLogEntry[] = []; public enemyFaintsHistory: FaintLogEntry[] = []; + public mysteryEncounterType?: MysteryEncounterType; /** If the current battle is a Mystery Encounter, this will always be defined */ public mysteryEncounter?: MysteryEncounter; @@ -157,7 +169,7 @@ export default class Battle { } addPostBattleLoot(enemyPokemon: EnemyPokemon): void { - this.postBattleLoot.push(...enemyPokemon.scene.findModifiers(m => m instanceof PokemonHeldItemModifier && m.pokemonId === enemyPokemon.id && m.isTransferrable, false).map(i => { + this.postBattleLoot.push(...enemyPokemon.scene.findModifiers(m => m instanceof PokemonHeldItemModifier && m.pokemonId === enemyPokemon.id && m.isTransferable, false).map(i => { const ret = i as PokemonHeldItemModifier; //@ts-ignore - this is awful to fix/change ret.pokemonId = null; @@ -202,8 +214,7 @@ export default class Battle { } getBgmOverride(scene: BattleScene): string | null { - const battlers = this.enemyParty.slice(0, this.getBattlerCount()); - if (this.battleType === BattleType.MYSTERY_ENCOUNTER && this.mysteryEncounter?.encounterMode === MysteryEncounterMode.DEFAULT) { + if (this.isBattleMysteryEncounter() && this.mysteryEncounter?.encounterMode === MysteryEncounterMode.DEFAULT) { // Music is overridden for MEs during ME onInit() // Should not use any BGM overrides before swapping from DEFAULT mode return null; @@ -211,7 +222,7 @@ export default class Battle { if (!this.started && this.trainer?.config.encounterBgm && this.trainer?.getEncounterMessages()?.length) { return `encounter_${this.trainer?.getEncounterBgm()}`; } - if (scene.musicPreference === 0) { + if (scene.musicPreference === MusicPreference.CONSISTENT) { return this.trainer?.getBattleBgm() ?? null; } else { return this.trainer?.getMixedBattleBgm() ?? null; @@ -219,147 +230,168 @@ export default class Battle { } else if (this.gameMode.isClassic && this.waveIndex > 195 && this.battleSpec !== BattleSpec.FINAL_BOSS) { return "end_summit"; } - for (const pokemon of battlers) { + const wildOpponents = scene.getEnemyParty(); + for (const pokemon of wildOpponents) { if (this.battleSpec === BattleSpec.FINAL_BOSS) { - if (pokemon.formIndex) { + if (pokemon.species.getFormSpriteKey(pokemon.formIndex) === SpeciesFormKey.ETERNAMAX) { return "battle_final"; } return "battle_final_encounter"; } if (pokemon.species.legendary || pokemon.species.subLegendary || pokemon.species.mythical) { - if (scene.musicPreference === 0) { - if (pokemon.species.speciesId === Species.REGIROCK || pokemon.species.speciesId === Species.REGICE || pokemon.species.speciesId === Species.REGISTEEL || pokemon.species.speciesId === Species.REGIGIGAS || pokemon.species.speciesId === Species.REGIELEKI || pokemon.species.speciesId === Species.REGIDRAGO) { - return "battle_legendary_regis_g5"; + if (scene.musicPreference === MusicPreference.CONSISTENT) { + switch (pokemon.species.speciesId) { + case Species.REGIROCK: + case Species.REGICE: + case Species.REGISTEEL: + case Species.REGIGIGAS: + case Species.REGIDRAGO: + case Species.REGIELEKI: + return "battle_legendary_regis_g5"; + case Species.KYUREM: + return "battle_legendary_kyurem"; + default: + if (pokemon.species.legendary) { + return "battle_legendary_res_zek"; + } + return "battle_legendary_unova"; } - if (pokemon.species.speciesId === Species.COBALION || pokemon.species.speciesId === Species.TERRAKION || pokemon.species.speciesId === Species.VIRIZION || pokemon.species.speciesId === Species.TORNADUS || pokemon.species.speciesId === Species.THUNDURUS || pokemon.species.speciesId === Species.LANDORUS || pokemon.species.speciesId === Species.KELDEO || pokemon.species.speciesId === Species.MELOETTA || pokemon.species.speciesId === Species.GENESECT) { - return "battle_legendary_unova"; - } - if (pokemon.species.speciesId === Species.KYUREM) { - return "battle_legendary_kyurem"; - } - if (pokemon.species.legendary) { - return "battle_legendary_res_zek"; - } - return "battle_legendary_unova"; - } else { - if (pokemon.species.speciesId === Species.ARTICUNO || pokemon.species.speciesId === Species.ZAPDOS || pokemon.species.speciesId === Species.MOLTRES || pokemon.species.speciesId === Species.MEWTWO || pokemon.species.speciesId === Species.MEW) { - return "battle_legendary_kanto"; - } - if (pokemon.species.speciesId === Species.RAIKOU) { - return "battle_legendary_raikou"; - } - if (pokemon.species.speciesId === Species.ENTEI) { - return "battle_legendary_entei"; - } - if (pokemon.species.speciesId === Species.SUICUNE) { - return "battle_legendary_suicune"; - } - if (pokemon.species.speciesId === Species.LUGIA) { - return "battle_legendary_lugia"; - } - if (pokemon.species.speciesId === Species.HO_OH) { - return "battle_legendary_ho_oh"; - } - if (pokemon.species.speciesId === Species.REGIROCK || pokemon.species.speciesId === Species.REGICE || pokemon.species.speciesId === Species.REGISTEEL || pokemon.species.speciesId === Species.REGIGIGAS || pokemon.species.speciesId === Species.REGIELEKI || pokemon.species.speciesId === Species.REGIDRAGO) { - return "battle_legendary_regis_g6"; - } - if (pokemon.species.speciesId === Species.GROUDON || pokemon.species.speciesId === Species.KYOGRE) { - return "battle_legendary_gro_kyo"; - } - if (pokemon.species.speciesId === Species.RAYQUAZA) { - return "battle_legendary_rayquaza"; - } - if (pokemon.species.speciesId === Species.DEOXYS) { - return "battle_legendary_deoxys"; - } - if (pokemon.species.speciesId === Species.UXIE || pokemon.species.speciesId === Species.MESPRIT || pokemon.species.speciesId === Species.AZELF) { - return "battle_legendary_lake_trio"; - } - if (pokemon.species.speciesId === Species.HEATRAN || pokemon.species.speciesId === Species.CRESSELIA || pokemon.species.speciesId === Species.DARKRAI || pokemon.species.speciesId === Species.SHAYMIN) { - return "battle_legendary_sinnoh"; - } - if (pokemon.species.speciesId === Species.DIALGA || pokemon.species.speciesId === Species.PALKIA) { - if (pokemon.getFormKey() === "") { + } else if (scene.musicPreference === MusicPreference.MIXED) { + switch (pokemon.species.speciesId) { + case Species.ARTICUNO: + case Species.ZAPDOS: + case Species.MOLTRES: + case Species.MEWTWO: + case Species.MEW: + return "battle_legendary_kanto"; + case Species.RAIKOU: + return "battle_legendary_raikou"; + case Species.ENTEI: + return "battle_legendary_entei"; + case Species.SUICUNE: + return "battle_legendary_suicune"; + case Species.LUGIA: + return "battle_legendary_lugia"; + case Species.HO_OH: + return "battle_legendary_ho_oh"; + case Species.REGIROCK: + case Species.REGICE: + case Species.REGISTEEL: + case Species.REGIGIGAS: + case Species.REGIDRAGO: + case Species.REGIELEKI: + return "battle_legendary_regis_g6"; + case Species.GROUDON: + case Species.KYOGRE: + return "battle_legendary_gro_kyo"; + case Species.RAYQUAZA: + return "battle_legendary_rayquaza"; + case Species.DEOXYS: + return "battle_legendary_deoxys"; + case Species.UXIE: + case Species.MESPRIT: + case Species.AZELF: + return "battle_legendary_lake_trio"; + case Species.HEATRAN: + case Species.CRESSELIA: + case Species.DARKRAI: + case Species.SHAYMIN: + return "battle_legendary_sinnoh"; + case Species.DIALGA: + case Species.PALKIA: + if (pokemon.species.getFormSpriteKey(pokemon.formIndex) === SpeciesFormKey.ORIGIN) { + return "battle_legendary_origin_forme"; + } return "battle_legendary_dia_pal"; - } - if (pokemon.getFormKey() === "origin") { - return "battle_legendary_origin_forme"; - } - } - if (pokemon.species.speciesId === Species.GIRATINA) { - return "battle_legendary_giratina"; - } - if (pokemon.species.speciesId === Species.ARCEUS) { - return "battle_legendary_arceus"; - } - if (pokemon.species.speciesId === Species.COBALION || pokemon.species.speciesId === Species.TERRAKION || pokemon.species.speciesId === Species.VIRIZION || pokemon.species.speciesId === Species.TORNADUS || pokemon.species.speciesId === Species.THUNDURUS || pokemon.species.speciesId === Species.LANDORUS || pokemon.species.speciesId === Species.KELDEO || pokemon.species.speciesId === Species.MELOETTA || pokemon.species.speciesId === Species.GENESECT) { - return "battle_legendary_unova"; - } - if (pokemon.species.speciesId === Species.KYUREM) { - return "battle_legendary_kyurem"; - } - if (pokemon.species.speciesId === Species.XERNEAS || pokemon.species.speciesId === Species.YVELTAL || pokemon.species.speciesId === Species.ZYGARDE) { - return "battle_legendary_xern_yvel"; - } - if (pokemon.species.speciesId === Species.TAPU_KOKO || pokemon.species.speciesId === Species.TAPU_LELE || pokemon.species.speciesId === Species.TAPU_BULU || pokemon.species.speciesId === Species.TAPU_FINI) { - return "battle_legendary_tapu"; - } - if ([ Species.COSMOG, Species.COSMOEM, Species.SOLGALEO, Species.LUNALA ].includes(pokemon.species.speciesId)) { - return "battle_legendary_sol_lun"; - } - if (pokemon.species.speciesId === Species.NECROZMA) { - if (pokemon.getFormKey() === "") { + case Species.GIRATINA: + return "battle_legendary_giratina"; + case Species.ARCEUS: + return "battle_legendary_arceus"; + case Species.COBALION: + case Species.TERRAKION: + case Species.VIRIZION: + case Species.KELDEO: + case Species.TORNADUS: + case Species.LANDORUS: + case Species.THUNDURUS: + case Species.MELOETTA: + case Species.GENESECT: + return "battle_legendary_unova"; + case Species.KYUREM: + return "battle_legendary_kyurem"; + case Species.XERNEAS: + case Species.YVELTAL: + case Species.ZYGARDE: + return "battle_legendary_xern_yvel"; + case Species.TAPU_KOKO: + case Species.TAPU_LELE: + case Species.TAPU_BULU: + case Species.TAPU_FINI: + return "battle_legendary_tapu"; + case Species.SOLGALEO: + case Species.LUNALA: return "battle_legendary_sol_lun"; - } - if (pokemon.getFormKey() === "dusk-mane" || pokemon.getFormKey() === "dawn-wings") { - return "battle_legendary_dusk_dawn"; - } - if (pokemon.getFormKey() === "ultra") { - return "battle_legendary_ultra_nec"; - } - } - if ([ Species.NIHILEGO, Species.BUZZWOLE, Species.PHEROMOSA, Species.XURKITREE, Species.CELESTEELA, Species.KARTANA, Species.GUZZLORD, Species.POIPOLE, Species.NAGANADEL, Species.STAKATAKA, Species.BLACEPHALON ].includes(pokemon.species.speciesId)) { - return "battle_legendary_ub"; - } - if (pokemon.species.speciesId === Species.ZACIAN || pokemon.species.speciesId === Species.ZAMAZENTA) { - return "battle_legendary_zac_zam"; - } - if (pokemon.species.speciesId === Species.GLASTRIER || pokemon.species.speciesId === Species.SPECTRIER) { - return "battle_legendary_glas_spec"; - } - if (pokemon.species.speciesId === Species.CALYREX) { - if (pokemon.getFormKey() === "") { + case Species.NECROZMA: + switch (pokemon.getFormKey()) { + case "dusk-mane": + case "dawn-wings": + return "battle_legendary_dusk_dawn"; + case "ultra": + return "battle_legendary_ultra_nec"; + default: + return "battle_legendary_sol_lun"; + } + case Species.NIHILEGO: + case Species.PHEROMOSA: + case Species.BUZZWOLE: + case Species.XURKITREE: + case Species.CELESTEELA: + case Species.KARTANA: + case Species.GUZZLORD: + case Species.POIPOLE: + case Species.NAGANADEL: + case Species.STAKATAKA: + case Species.BLACEPHALON: + return "battle_legendary_ub"; + case Species.ZACIAN: + case Species.ZAMAZENTA: + return "battle_legendary_zac_zam"; + case Species.GLASTRIER: + case Species.SPECTRIER: + return "battle_legendary_glas_spec"; + case Species.CALYREX: + if (pokemon.getFormKey() === "ice" || pokemon.getFormKey() === "shadow") { + return "battle_legendary_riders"; + } return "battle_legendary_calyrex"; - } - if (pokemon.getFormKey() === "ice" || pokemon.getFormKey() === "shadow") { - return "battle_legendary_riders"; - } + case Species.GALAR_ARTICUNO: + case Species.GALAR_ZAPDOS: + case Species.GALAR_MOLTRES: + return "battle_legendary_birds_galar"; + case Species.WO_CHIEN: + case Species.CHIEN_PAO: + case Species.TING_LU: + case Species.CHI_YU: + return "battle_legendary_ruinous"; + case Species.KORAIDON: + case Species.MIRAIDON: + return "battle_legendary_kor_mir"; + case Species.OKIDOGI: + case Species.MUNKIDORI: + case Species.FEZANDIPITI: + return "battle_legendary_loyal_three"; + case Species.OGERPON: + return "battle_legendary_ogerpon"; + case Species.TERAPAGOS: + return "battle_legendary_terapagos"; + case Species.PECHARUNT: + return "battle_legendary_pecharunt"; + default: + if (pokemon.species.legendary) { + return "battle_legendary_res_zek"; + } + return "battle_legendary_unova"; } - if (pokemon.species.speciesId === Species.GALAR_ARTICUNO || pokemon.species.speciesId === Species.GALAR_ZAPDOS || pokemon.species.speciesId === Species.GALAR_MOLTRES) { - return "battle_legendary_birds_galar"; - } - if (pokemon.species.speciesId === Species.WO_CHIEN || pokemon.species.speciesId === Species.CHIEN_PAO || pokemon.species.speciesId === Species.TING_LU || pokemon.species.speciesId === Species.CHI_YU) { - return "battle_legendary_ruinous"; - } - if (pokemon.species.speciesId === Species.KORAIDON || pokemon.species.speciesId === Species.MIRAIDON) { - return "battle_legendary_kor_mir"; - } - if (pokemon.species.speciesId === Species.OKIDOGI || pokemon.species.speciesId === Species.MUNKIDORI || pokemon.species.speciesId === Species.FEZANDIPITI) { - return "battle_legendary_loyal_three"; - } - if (pokemon.species.speciesId === Species.OGERPON) { - return "battle_legendary_ogerpon"; - } - if (pokemon.species.speciesId === Species.TERAPAGOS) { - return "battle_legendary_terapagos"; - } - if (pokemon.species.speciesId === Species.PECHARUNT) { - return "battle_legendary_pecharunt"; - } - if (pokemon.species.legendary) { - return "battle_legendary_res_zek"; - } - return "battle_legendary_unova"; } } } @@ -399,6 +431,13 @@ export default class Battle { scene.rngSeedOverride = tempSeedOverride; return ret; } + + /** + * Returns if the battle is of type {@linkcode BattleType.MYSTERY_ENCOUNTER} + */ + isBattleMysteryEncounter(): boolean { + return this.battleType === BattleType.MYSTERY_ENCOUNTER; + } } export class FixedBattle extends Battle { @@ -419,6 +458,7 @@ export class FixedBattleConfig { public getTrainer: GetTrainerFunc; public getEnemyParty: GetEnemyPartyFunc; public seedOffsetWaveIndex: number; + public customModifierRewardSettings?: CustomModifierSettings; setBattleType(battleType: BattleType): FixedBattleConfig { this.battleType = battleType; @@ -444,6 +484,11 @@ export class FixedBattleConfig { this.seedOffsetWaveIndex = seedOffsetWaveIndex; return this; } + + setCustomModifierRewards(customModifierRewardSettings: CustomModifierSettings) { + this.customModifierRewardSettings = customModifierRewardSettings; + return this; + } } @@ -474,7 +519,7 @@ function getRandomTrainerFunc(trainerPool: (TrainerType | TrainerType[])[], rand } /* 1/3 chance for evil team grunts to be double battles */ - const evilTeamGrunts = [TrainerType.ROCKET_GRUNT, TrainerType.MAGMA_GRUNT, TrainerType.AQUA_GRUNT, TrainerType.GALACTIC_GRUNT, TrainerType.PLASMA_GRUNT, TrainerType.FLARE_GRUNT]; + const evilTeamGrunts = [ TrainerType.ROCKET_GRUNT, TrainerType.MAGMA_GRUNT, TrainerType.AQUA_GRUNT, TrainerType.GALACTIC_GRUNT, TrainerType.PLASMA_GRUNT, TrainerType.FLARE_GRUNT, TrainerType.AETHER_GRUNT, TrainerType.SKULL_GRUNT, TrainerType.MACRO_GRUNT, TrainerType.STAR_GRUNT ]; const isEvilTeamGrunt = evilTeamGrunts.includes(trainerTypes[rand]); if (trainerConfigs[trainerTypes[rand]].hasDouble && isEvilTeamGrunt) { @@ -503,29 +548,35 @@ export const classicFixedBattles: FixedBattleConfigs = { [8]: new FixedBattleConfig().setBattleType(BattleType.TRAINER) .setGetTrainerFunc(scene => new Trainer(scene, TrainerType.RIVAL, scene.gameData.gender === PlayerGender.MALE ? TrainerVariant.FEMALE : TrainerVariant.DEFAULT)), [25]: new FixedBattleConfig().setBattleType(BattleType.TRAINER) - .setGetTrainerFunc(scene => new Trainer(scene, TrainerType.RIVAL_2, scene.gameData.gender === PlayerGender.MALE ? TrainerVariant.FEMALE : TrainerVariant.DEFAULT)), + .setGetTrainerFunc(scene => new Trainer(scene, TrainerType.RIVAL_2, scene.gameData.gender === PlayerGender.MALE ? TrainerVariant.FEMALE : TrainerVariant.DEFAULT)) + .setCustomModifierRewards({ guaranteedModifierTiers: [ ModifierTier.ULTRA, ModifierTier.GREAT, ModifierTier.GREAT ], allowLuckUpgrades: false }), [35]: new FixedBattleConfig().setBattleType(BattleType.TRAINER) - .setGetTrainerFunc(getRandomTrainerFunc([ TrainerType.ROCKET_GRUNT, TrainerType.MAGMA_GRUNT, TrainerType.AQUA_GRUNT, TrainerType.GALACTIC_GRUNT, TrainerType.PLASMA_GRUNT, TrainerType.FLARE_GRUNT, TrainerType.AETHER_GRUNT, TrainerType.SKULL_GRUNT, TrainerType.MACRO_GRUNT ], true)), + .setGetTrainerFunc(getRandomTrainerFunc([ TrainerType.ROCKET_GRUNT, TrainerType.MAGMA_GRUNT, TrainerType.AQUA_GRUNT, TrainerType.GALACTIC_GRUNT, TrainerType.PLASMA_GRUNT, TrainerType.FLARE_GRUNT, TrainerType.AETHER_GRUNT, TrainerType.SKULL_GRUNT, TrainerType.MACRO_GRUNT, TrainerType.STAR_GRUNT ], true)), [55]: new FixedBattleConfig().setBattleType(BattleType.TRAINER) - .setGetTrainerFunc(scene => new Trainer(scene, TrainerType.RIVAL_3, scene.gameData.gender === PlayerGender.MALE ? TrainerVariant.FEMALE : TrainerVariant.DEFAULT)), + .setGetTrainerFunc(scene => new Trainer(scene, TrainerType.RIVAL_3, scene.gameData.gender === PlayerGender.MALE ? TrainerVariant.FEMALE : TrainerVariant.DEFAULT)) + .setCustomModifierRewards({ guaranteedModifierTiers: [ ModifierTier.ULTRA, ModifierTier.ULTRA, ModifierTier.GREAT, ModifierTier.GREAT ], allowLuckUpgrades: false }), [62]: new FixedBattleConfig().setBattleType(BattleType.TRAINER).setSeedOffsetWave(35) - .setGetTrainerFunc(getRandomTrainerFunc([ TrainerType.ROCKET_GRUNT, TrainerType.MAGMA_GRUNT, TrainerType.AQUA_GRUNT, TrainerType.GALACTIC_GRUNT, TrainerType.PLASMA_GRUNT, TrainerType.FLARE_GRUNT, TrainerType.AETHER_GRUNT, TrainerType.SKULL_GRUNT, TrainerType.MACRO_GRUNT ], true)), + .setGetTrainerFunc(getRandomTrainerFunc([ TrainerType.ROCKET_GRUNT, TrainerType.MAGMA_GRUNT, TrainerType.AQUA_GRUNT, TrainerType.GALACTIC_GRUNT, TrainerType.PLASMA_GRUNT, TrainerType.FLARE_GRUNT, TrainerType.AETHER_GRUNT, TrainerType.SKULL_GRUNT, TrainerType.MACRO_GRUNT, TrainerType.STAR_GRUNT ], true)), [64]: new FixedBattleConfig().setBattleType(BattleType.TRAINER).setSeedOffsetWave(35) - .setGetTrainerFunc(getRandomTrainerFunc([ TrainerType.ROCKET_GRUNT, TrainerType.MAGMA_GRUNT, TrainerType.AQUA_GRUNT, TrainerType.GALACTIC_GRUNT, TrainerType.PLASMA_GRUNT, TrainerType.FLARE_GRUNT, TrainerType.AETHER_GRUNT, TrainerType.SKULL_GRUNT, TrainerType.MACRO_GRUNT ], true)), + .setGetTrainerFunc(getRandomTrainerFunc([ TrainerType.ROCKET_GRUNT, TrainerType.MAGMA_GRUNT, TrainerType.AQUA_GRUNT, TrainerType.GALACTIC_GRUNT, TrainerType.PLASMA_GRUNT, TrainerType.FLARE_GRUNT, TrainerType.AETHER_GRUNT, TrainerType.SKULL_GRUNT, TrainerType.MACRO_GRUNT, TrainerType.STAR_GRUNT ], true)), [66]: new FixedBattleConfig().setBattleType(BattleType.TRAINER).setSeedOffsetWave(35) - .setGetTrainerFunc(getRandomTrainerFunc([[ TrainerType.ARCHER, TrainerType.ARIANA, TrainerType.PROTON, TrainerType.PETREL ], [ TrainerType.TABITHA, TrainerType.COURTNEY ], [ TrainerType.MATT, TrainerType.SHELLY ], [ TrainerType.JUPITER, TrainerType.MARS, TrainerType.SATURN ], [ TrainerType.ZINZOLIN, TrainerType.ROOD ], [ TrainerType.XEROSIC, TrainerType.BRYONY ], TrainerType.FABA, TrainerType.PLUMERIA, TrainerType.OLEANA ], true)), + .setGetTrainerFunc(getRandomTrainerFunc([[ TrainerType.ARCHER, TrainerType.ARIANA, TrainerType.PROTON, TrainerType.PETREL ], [ TrainerType.TABITHA, TrainerType.COURTNEY ], [ TrainerType.MATT, TrainerType.SHELLY ], [ TrainerType.JUPITER, TrainerType.MARS, TrainerType.SATURN ], [ TrainerType.ZINZOLIN, TrainerType.ROOD ], [ TrainerType.XEROSIC, TrainerType.BRYONY ], TrainerType.FABA, TrainerType.PLUMERIA, TrainerType.OLEANA, [ TrainerType.GIACOMO, TrainerType.MELA, TrainerType.ATTICUS, TrainerType.ORTEGA, TrainerType.ERI ]], true)), [95]: new FixedBattleConfig().setBattleType(BattleType.TRAINER) - .setGetTrainerFunc(scene => new Trainer(scene, TrainerType.RIVAL_4, scene.gameData.gender === PlayerGender.MALE ? TrainerVariant.FEMALE : TrainerVariant.DEFAULT)), + .setGetTrainerFunc(scene => new Trainer(scene, TrainerType.RIVAL_4, scene.gameData.gender === PlayerGender.MALE ? TrainerVariant.FEMALE : TrainerVariant.DEFAULT)) + .setCustomModifierRewards({ guaranteedModifierTiers: [ ModifierTier.ULTRA, ModifierTier.ULTRA, ModifierTier.ULTRA, ModifierTier.ULTRA ], allowLuckUpgrades: false }), [112]: new FixedBattleConfig().setBattleType(BattleType.TRAINER).setSeedOffsetWave(35) - .setGetTrainerFunc(getRandomTrainerFunc([ TrainerType.ROCKET_GRUNT, TrainerType.MAGMA_GRUNT, TrainerType.AQUA_GRUNT, TrainerType.GALACTIC_GRUNT, TrainerType.PLASMA_GRUNT, TrainerType.FLARE_GRUNT, TrainerType.AETHER_GRUNT, TrainerType.SKULL_GRUNT, TrainerType.MACRO_GRUNT ], true)), + .setGetTrainerFunc(getRandomTrainerFunc([ TrainerType.ROCKET_GRUNT, TrainerType.MAGMA_GRUNT, TrainerType.AQUA_GRUNT, TrainerType.GALACTIC_GRUNT, TrainerType.PLASMA_GRUNT, TrainerType.FLARE_GRUNT, TrainerType.AETHER_GRUNT, TrainerType.SKULL_GRUNT, TrainerType.MACRO_GRUNT, TrainerType.STAR_GRUNT ], true)), [114]: new FixedBattleConfig().setBattleType(BattleType.TRAINER).setSeedOffsetWave(35) - .setGetTrainerFunc(getRandomTrainerFunc([[ TrainerType.ARCHER, TrainerType.ARIANA, TrainerType.PROTON, TrainerType.PETREL ], [ TrainerType.TABITHA, TrainerType.COURTNEY ], [ TrainerType.MATT, TrainerType.SHELLY ], [ TrainerType.JUPITER, TrainerType.MARS, TrainerType.SATURN ], [ TrainerType.ZINZOLIN, TrainerType.ROOD ], [ TrainerType.XEROSIC, TrainerType.BRYONY ], TrainerType.FABA, TrainerType.PLUMERIA, TrainerType.OLEANA ], true, 1)), - [115]: new FixedBattleConfig().setBattleType(BattleType.TRAINER).setSeedOffsetWave(35) - .setGetTrainerFunc(getRandomTrainerFunc([ TrainerType.ROCKET_BOSS_GIOVANNI_1, TrainerType.MAXIE, TrainerType.ARCHIE, TrainerType.CYRUS, TrainerType.GHETSIS, TrainerType.LYSANDRE, TrainerType.LUSAMINE, TrainerType.GUZMA, TrainerType.ROSE ])), + .setGetTrainerFunc(getRandomTrainerFunc([[ TrainerType.ARCHER, TrainerType.ARIANA, TrainerType.PROTON, TrainerType.PETREL ], [ TrainerType.TABITHA, TrainerType.COURTNEY ], [ TrainerType.MATT, TrainerType.SHELLY ], [ TrainerType.JUPITER, TrainerType.MARS, TrainerType.SATURN ], [ TrainerType.ZINZOLIN, TrainerType.ROOD ], [ TrainerType.XEROSIC, TrainerType.BRYONY ], TrainerType.FABA, TrainerType.PLUMERIA, TrainerType.OLEANA, [ TrainerType.GIACOMO, TrainerType.MELA, TrainerType.ATTICUS, TrainerType.ORTEGA, TrainerType.ERI ]], true, 1)), + [ClassicFixedBossWaves.EVIL_BOSS_1]: new FixedBattleConfig().setBattleType(BattleType.TRAINER).setSeedOffsetWave(35) + .setGetTrainerFunc(getRandomTrainerFunc([ TrainerType.ROCKET_BOSS_GIOVANNI_1, TrainerType.MAXIE, TrainerType.ARCHIE, TrainerType.CYRUS, TrainerType.GHETSIS, TrainerType.LYSANDRE, TrainerType.LUSAMINE, TrainerType.GUZMA, TrainerType.ROSE, TrainerType.PENNY ])) + .setCustomModifierRewards({ guaranteedModifierTiers: [ ModifierTier.ROGUE, ModifierTier.ROGUE, ModifierTier.ULTRA, ModifierTier.ULTRA, ModifierTier.ULTRA ], allowLuckUpgrades: false }), [145]: new FixedBattleConfig().setBattleType(BattleType.TRAINER) - .setGetTrainerFunc(scene => new Trainer(scene, TrainerType.RIVAL_5, scene.gameData.gender === PlayerGender.MALE ? TrainerVariant.FEMALE : TrainerVariant.DEFAULT)), - [165]: new FixedBattleConfig().setBattleType(BattleType.TRAINER).setSeedOffsetWave(35) - .setGetTrainerFunc(getRandomTrainerFunc([ TrainerType.ROCKET_BOSS_GIOVANNI_2, TrainerType.MAXIE_2, TrainerType.ARCHIE_2, TrainerType.CYRUS_2, TrainerType.GHETSIS_2, TrainerType.LYSANDRE_2, TrainerType.LUSAMINE_2, TrainerType.GUZMA_2, TrainerType.ROSE_2 ])), + .setGetTrainerFunc(scene => new Trainer(scene, TrainerType.RIVAL_5, scene.gameData.gender === PlayerGender.MALE ? TrainerVariant.FEMALE : TrainerVariant.DEFAULT)) + .setCustomModifierRewards({ guaranteedModifierTiers: [ ModifierTier.ROGUE, ModifierTier.ROGUE, ModifierTier.ROGUE, ModifierTier.ULTRA, ModifierTier.ULTRA ], allowLuckUpgrades: false }), + [ClassicFixedBossWaves.EVIL_BOSS_2]: new FixedBattleConfig().setBattleType(BattleType.TRAINER).setSeedOffsetWave(35) + .setGetTrainerFunc(getRandomTrainerFunc([ TrainerType.ROCKET_BOSS_GIOVANNI_2, TrainerType.MAXIE_2, TrainerType.ARCHIE_2, TrainerType.CYRUS_2, TrainerType.GHETSIS_2, TrainerType.LYSANDRE_2, TrainerType.LUSAMINE_2, TrainerType.GUZMA_2, TrainerType.ROSE_2, TrainerType.PENNY_2 ])) + .setCustomModifierRewards({ guaranteedModifierTiers: [ ModifierTier.ROGUE, ModifierTier.ROGUE, ModifierTier.ULTRA, ModifierTier.ULTRA, ModifierTier.ULTRA, ModifierTier.ULTRA ], allowLuckUpgrades: false }), [182]: new FixedBattleConfig().setBattleType(BattleType.TRAINER) .setGetTrainerFunc(getRandomTrainerFunc([ TrainerType.LORELEI, TrainerType.WILL, TrainerType.SIDNEY, TrainerType.AARON, TrainerType.SHAUNTAL, TrainerType.MALVA, [ TrainerType.HALA, TrainerType.MOLAYNE ], TrainerType.MARNIE_ELITE, TrainerType.RIKA, TrainerType.CRISPIN ])), [184]: new FixedBattleConfig().setBattleType(BattleType.TRAINER).setSeedOffsetWave(182) @@ -538,4 +589,5 @@ export const classicFixedBattles: FixedBattleConfigs = { .setGetTrainerFunc(getRandomTrainerFunc([ TrainerType.BLUE, [ TrainerType.RED, TrainerType.LANCE_CHAMPION ], [ TrainerType.STEVEN, TrainerType.WALLACE ], TrainerType.CYNTHIA, [ TrainerType.ALDER, TrainerType.IRIS ], TrainerType.DIANTHA, TrainerType.HAU, TrainerType.LEON, [ TrainerType.GEETA, TrainerType.NEMONA ], TrainerType.KIERAN ])), [195]: new FixedBattleConfig().setBattleType(BattleType.TRAINER) .setGetTrainerFunc(scene => new Trainer(scene, TrainerType.RIVAL_6, scene.gameData.gender === PlayerGender.MALE ? TrainerVariant.FEMALE : TrainerVariant.DEFAULT)) + .setCustomModifierRewards({ guaranteedModifierTiers: [ ModifierTier.ROGUE, ModifierTier.ROGUE, ModifierTier.ULTRA, ModifierTier.ULTRA, ModifierTier.GREAT, ModifierTier.GREAT ], allowLuckUpgrades: false }) }; diff --git a/src/configs/inputs/cfg_keyboard_qwerty.ts b/src/configs/inputs/cfg_keyboard_qwerty.ts index 09a02f02836..5ddc12e8784 100644 --- a/src/configs/inputs/cfg_keyboard_qwerty.ts +++ b/src/configs/inputs/cfg_keyboard_qwerty.ts @@ -1,5 +1,5 @@ -import {Button} from "#enums/buttons"; -import {SettingKeyboard} from "#app/system/settings/settings-keyboard"; +import { Button } from "#enums/buttons"; +import { SettingKeyboard } from "#app/system/settings/settings-keyboard"; const cfg_keyboard_qwerty = { padID: "default", diff --git a/src/configs/inputs/configHandler.ts b/src/configs/inputs/configHandler.ts index 45fb033e9fa..50be692cbc3 100644 --- a/src/configs/inputs/configHandler.ts +++ b/src/configs/inputs/configHandler.ts @@ -1,4 +1,4 @@ -import {Device} from "#enums/devices"; +import { Device } from "#enums/devices"; /** * Retrieves the key associated with the specified keycode from the mapping. diff --git a/src/configs/inputs/pad_dualshock.ts b/src/configs/inputs/pad_dualshock.ts index 742040958b4..2fbdd0ddfaa 100644 --- a/src/configs/inputs/pad_dualshock.ts +++ b/src/configs/inputs/pad_dualshock.ts @@ -1,5 +1,5 @@ -import {SettingGamepad} from "../../system/settings/settings-gamepad"; -import {Button} from "#enums/buttons"; +import { SettingGamepad } from "../../system/settings/settings-gamepad"; +import { Button } from "#enums/buttons"; /** * Dualshock mapping diff --git a/src/configs/inputs/pad_generic.ts b/src/configs/inputs/pad_generic.ts index 88ff66e231c..256af8f0fe3 100644 --- a/src/configs/inputs/pad_generic.ts +++ b/src/configs/inputs/pad_generic.ts @@ -1,5 +1,5 @@ -import {SettingGamepad} from "../../system/settings/settings-gamepad"; -import {Button} from "#enums/buttons"; +import { SettingGamepad } from "../../system/settings/settings-gamepad"; +import { Button } from "#enums/buttons"; /** * Generic pad mapping diff --git a/src/configs/inputs/pad_procon.ts b/src/configs/inputs/pad_procon.ts index be751cc3acc..98d17c4ef57 100644 --- a/src/configs/inputs/pad_procon.ts +++ b/src/configs/inputs/pad_procon.ts @@ -1,5 +1,5 @@ -import {SettingGamepad} from "#app/system/settings/settings-gamepad"; -import {Button} from "#enums/buttons"; +import { SettingGamepad } from "#app/system/settings/settings-gamepad"; +import { Button } from "#enums/buttons"; /** * Nintendo Pro Controller mapping diff --git a/src/configs/inputs/pad_unlicensedSNES.ts b/src/configs/inputs/pad_unlicensedSNES.ts index 8a7f3e78f98..77e68e6a644 100644 --- a/src/configs/inputs/pad_unlicensedSNES.ts +++ b/src/configs/inputs/pad_unlicensedSNES.ts @@ -1,5 +1,5 @@ -import {SettingGamepad} from "../../system/settings/settings-gamepad"; -import {Button} from "#enums/buttons"; +import { SettingGamepad } from "../../system/settings/settings-gamepad"; +import { Button } from "#enums/buttons"; /** * 081f-e401 - UnlicensedSNES diff --git a/src/configs/inputs/pad_xbox360.ts b/src/configs/inputs/pad_xbox360.ts index e003ccc8e87..6afc452f50b 100644 --- a/src/configs/inputs/pad_xbox360.ts +++ b/src/configs/inputs/pad_xbox360.ts @@ -1,5 +1,5 @@ -import {SettingGamepad} from "../../system/settings/settings-gamepad"; -import {Button} from "#enums/buttons"; +import { SettingGamepad } from "../../system/settings/settings-gamepad"; +import { Button } from "#enums/buttons"; /** * Generic pad mapping diff --git a/src/constants.ts b/src/constants.ts index a2f7e47b996..63f00b9f33f 100644 --- a/src/constants.ts +++ b/src/constants.ts @@ -1 +1,11 @@ -export const PLAYER_PARTY_MAX_SIZE = 6; +/** The maximum size of the player's party */ +export const PLAYER_PARTY_MAX_SIZE: number = 6; + +/** Whether to use seasonal splash messages in general */ +export const USE_SEASONAL_SPLASH_MESSAGES: boolean = false; + +/** Name of the session ID cookie */ +export const SESSION_ID_COOKIE_NAME: string = "pokerogue_sessionId"; + +/** Max value for an integer attribute in {@linkcode SystemSaveData} */ +export const MAX_INT_ATTR_VALUE = 0x80000000; diff --git a/src/data/ability.ts b/src/data/ability.ts old mode 100755 new mode 100644 index 0edbc172ad5..1697c816902 --- a/src/data/ability.ts +++ b/src/data/ability.ts @@ -1,15 +1,15 @@ -import Pokemon, { HitResult, PlayerPokemon, PokemonMove } from "../field/pokemon"; -import { Type } from "./type"; +import Pokemon, { EnemyPokemon, HitResult, MoveResult, PlayerPokemon, PokemonMove } from "../field/pokemon"; +import { Type } from "#enums/type"; import { Constructor } from "#app/utils"; import * as Utils from "../utils"; import { getPokemonNameWithAffix } from "../messages"; -import { Weather, WeatherType } from "./weather"; -import { BattlerTag, GroundedTag, GulpMissileTag, SemiInvulnerableTag } from "./battler-tags"; -import { StatusEffect, getNonVolatileStatusEffects, getStatusEffectDescriptor, getStatusEffectHealText } from "./status-effect"; +import { Weather } from "#app/data/weather"; +import { BattlerTag, BattlerTagLapseType, GroundedTag } from "./battler-tags"; +import { getNonVolatileStatusEffects, getStatusEffectDescriptor, getStatusEffectHealText } from "#app/data/status-effect"; import { Gender } from "./gender"; -import Move, { AttackMove, MoveCategory, MoveFlags, MoveTarget, FlinchAttr, OneHitKOAttr, HitHealAttr, allMoves, StatusMove, SelfStatusMove, VariablePowerAttr, applyMoveAttrs, IncrementMovePriorityAttr, VariableMoveTypeAttr, RandomMovesetMoveAttr, RandomMoveAttr, NaturePowerAttr, CopyMoveAttr, MoveAttr, MultiHitAttr, ChargeAttr, SacrificialAttr, SacrificialAttrOnHit, NeutralDamageAgainstFlyingTypeMultiplierAttr, FixedDamageAttr } from "./move"; +import Move, { AttackMove, MoveCategory, MoveFlags, MoveTarget, FlinchAttr, OneHitKOAttr, HitHealAttr, allMoves, StatusMove, SelfStatusMove, VariablePowerAttr, applyMoveAttrs, VariableMoveTypeAttr, RandomMovesetMoveAttr, RandomMoveAttr, NaturePowerAttr, CopyMoveAttr, NeutralDamageAgainstFlyingTypeMultiplierAttr, FixedDamageAttr } from "./move"; import { ArenaTagSide, ArenaTrapTag } from "./arena-tag"; -import { BerryModifier, PokemonHeldItemModifier } from "../modifier/modifier"; +import { BerryModifier, HitHealModifier, PokemonHeldItemModifier } from "../modifier/modifier"; import { TerrainType } from "./terrain"; import { SpeciesFormChangeManualTrigger, SpeciesFormChangeRevertWeatherFormTrigger, SpeciesFormChangeWeatherTrigger } from "./pokemon-forms"; import i18next from "i18next"; @@ -17,7 +17,7 @@ import { Localizable } from "#app/interfaces/locales"; import { Command } from "../ui/command-ui-handler"; import { BerryModifierType } from "#app/modifier/modifier-type"; import { getPokeballName } from "./pokeball"; -import { BattlerIndex } from "#app/battle"; +import { BattlerIndex, BattleType } from "#app/battle"; import { Abilities } from "#enums/abilities"; import { ArenaTagType } from "#enums/arena-tag-type"; import { BattlerTagType } from "#enums/battler-tag-type"; @@ -29,6 +29,15 @@ import { PokemonHealPhase } from "#app/phases/pokemon-heal-phase"; import { ShowAbilityPhase } from "#app/phases/show-ability-phase"; import { StatStageChangePhase } from "#app/phases/stat-stage-change-phase"; import BattleScene from "#app/battle-scene"; +import { SwitchType } from "#app/enums/switch-type"; +import { SwitchPhase } from "#app/phases/switch-phase"; +import { SwitchSummonPhase } from "#app/phases/switch-summon-phase"; +import { BattleEndPhase } from "#app/phases/battle-end-phase"; +import { NewBattlePhase } from "#app/phases/new-battle-phase"; +import { MoveEndPhase } from "#app/phases/move-end-phase"; +import { PokemonAnimType } from "#enums/pokemon-anim-type"; +import { StatusEffect } from "#enums/status-effect"; +import { WeatherType } from "#enums/weather-type"; export class Ability implements Localizable { public id: Abilities; @@ -118,11 +127,20 @@ export class Ability implements Localizable { this.nameAppend += " (N)"; return this; } + + /** + * Internal flag used for developers to document edge cases. When using this, please be sure to document the edge case. + * @returns the ability + */ + edgeCase(): this { + return this; + } } type AbAttrApplyFunc = (attr: TAttr, passive: boolean) => boolean | Promise; type AbAttrCondition = (pokemon: Pokemon) => boolean; +// TODO: Can this be improved? type PokemonAttackCondition = (user: Pokemon | null, target: Pokemon | null, move: Move) => boolean; type PokemonDefendCondition = (target: Pokemon, user: Pokemon, move: Move) => boolean; type PokemonStatStageChangeCondition = (target: Pokemon, statsChanged: BattleStat[], stages: number) => boolean; @@ -161,18 +179,31 @@ export class BlockRecoilDamageAttr extends AbAttr { } getTriggerMessage(pokemon: Pokemon, abilityName: string, ...args: any[]) { - return i18next.t("abilityTriggers:blockRecoilDamage", {pokemonName: getPokemonNameWithAffix(pokemon), abilityName: abilityName}); + return i18next.t("abilityTriggers:blockRecoilDamage", { pokemonName: getPokemonNameWithAffix(pokemon), abilityName: abilityName }); } } +/** + * Attribute for abilities that increase the chance of a double battle + * occurring. + * @see apply + */ export class DoubleBattleChanceAbAttr extends AbAttr { constructor() { super(false); } - apply(pokemon: Pokemon, passive: boolean, simulated: boolean, cancelled: Utils.BooleanHolder, args: any[]): boolean { - const doubleChance = (args[0] as Utils.IntegerHolder); - doubleChance.value = Math.max(doubleChance.value / 2, 1); + /** + * Increases the chance of a double battle occurring + * @param args [0] {@linkcode Utils.NumberHolder} for double battle chance + * @returns true if the ability was applied + */ + apply(_pokemon: Pokemon, _passive: boolean, _simulated: boolean, _cancelled: Utils.BooleanHolder, args: any[]): boolean { + const doubleBattleChance = args[0] as Utils.NumberHolder; + // This is divided because the chance is generated as a number from 0 to doubleBattleChance.value using Utils.randSeedInt + // A double battle will initiate if the generated number is 0 + doubleBattleChance.value = doubleBattleChance.value / 4; + return true; } } @@ -308,6 +339,30 @@ export class ReceivedMoveDamageMultiplierAbAttr extends PreDefendAbAttr { } } +/** + * Reduces the damage dealt to an allied Pokemon. Used by Friend Guard. + * @see {@linkcode applyPreDefend} + */ +export class AlliedFieldDamageReductionAbAttr extends PreDefendAbAttr { + private damageMultiplier: number; + + constructor(damageMultiplier: number) { + super(); + this.damageMultiplier = damageMultiplier; + } + + /** + * Handles the damage reduction + * @param args + * - `[0]` {@linkcode Utils.NumberHolder} - The damage being dealt + */ + override applyPreDefend(_pokemon: Pokemon, _passive: boolean, _simulated: boolean, _attacker: Pokemon, _move: Move, _cancelled: Utils.BooleanHolder, args: any[]): boolean { + const damage = args[0] as Utils.NumberHolder; + damage.value = Utils.toDmgValue(damage.value * this.damageMultiplier); + return true; + } +} + export class ReceivedTypeDamageMultiplierAbAttr extends ReceivedMoveDamageMultiplierAbAttr { constructor(moveType: Type, damageMultiplier: number) { super((target, user, move) => user.getMoveType(move) === moveType, damageMultiplier); @@ -353,6 +408,10 @@ export class TypeImmunityAbAttr extends PreDefendAbAttr { return false; } + getImmuneType(): Type | null { + return this.immuneType; + } + override getCondition(): AbAttrCondition | null { return this.condition; } @@ -455,7 +514,11 @@ export class NonSuperEffectiveImmunityAbAttr extends TypeImmunityAbAttr { } applyPreDefend(pokemon: Pokemon, passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, cancelled: Utils.BooleanHolder, args: any[]): boolean { - if (move instanceof AttackMove && pokemon.getAttackTypeEffectiveness(attacker.getMoveType(move), attacker) < 2) { + const modifierValue = args.length > 0 + ? (args[0] as Utils.NumberHolder).value + : pokemon.getAttackTypeEffectiveness(attacker.getMoveType(move), attacker, undefined, undefined, move); + + if (move instanceof AttackMove && modifierValue < 2) { cancelled.value = true; // Suppresses "No Effect" message (args[0] as Utils.NumberHolder).value = 0; return true; @@ -501,6 +564,7 @@ export class FullHpResistTypeAbAttr extends PreDefendAbAttr { if (pokemon.isFullHp() && typeMultiplier.value > 0.5) { typeMultiplier.value = 0.5; + pokemon.turnData.moveEffectiveness = 0.5; return true; } return false; @@ -519,64 +583,13 @@ export class PostDefendAbAttr extends AbAttr { } } -/** - * Applies the effects of Gulp Missile when the user is hit by an attack. - * @extends PostDefendAbAttr - */ -export class PostDefendGulpMissileAbAttr extends PostDefendAbAttr { - constructor() { - super(true); - } - - /** - * Damages the attacker and triggers the secondary effect based on the form or the BattlerTagType. - * @param {Pokemon} pokemon - The defending Pokemon. - * @param passive - n/a - * @param {Pokemon} attacker - The attacking Pokemon. - * @param {Move} move - The move being used. - * @param {HitResult} hitResult - n/a - * @param {any[]} args - n/a - * @returns Whether the effects of the ability are applied. - */ - applyPostDefend(pokemon: Pokemon, passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, hitResult: HitResult, args: any[]): boolean | Promise { - const battlerTag = pokemon.getTag(GulpMissileTag); - if (!battlerTag || move.category === MoveCategory.STATUS || pokemon.getTag(SemiInvulnerableTag)) { - return false; - } - - if (simulated) { - return true; - } - - const cancelled = new Utils.BooleanHolder(false); - applyAbAttrs(BlockNonDirectDamageAbAttr, attacker, cancelled); - - if (!cancelled.value) { - attacker.damageAndUpdate(Math.max(1, Math.floor(attacker.getMaxHp() / 4)), HitResult.OTHER); - } - - if (battlerTag.tagType === BattlerTagType.GULP_MISSILE_ARROKUDA) { - pokemon.scene.unshiftPhase(new StatStageChangePhase(pokemon.scene, attacker.getBattlerIndex(), false, [ Stat.DEF ], -1)); - } else { - attacker.trySetStatus(StatusEffect.PARALYSIS, true, pokemon); - } - - pokemon.removeTag(battlerTag.tagType); - return true; - } -} - export class FieldPriorityMoveImmunityAbAttr extends PreDefendAbAttr { applyPreDefend(pokemon: Pokemon, passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, cancelled: Utils.BooleanHolder, args: any[]): boolean { - const attackPriority = new Utils.IntegerHolder(move.priority); - applyMoveAttrs(IncrementMovePriorityAttr, attacker, null, move, attackPriority); - applyAbAttrs(ChangeMovePriorityAbAttr, attacker, null, simulated, move, attackPriority); - if (move.moveTarget === MoveTarget.USER || move.moveTarget === MoveTarget.NEAR_ALLY) { return false; } - if (attackPriority.value > 0 && !move.isMultiTarget()) { + if (move.getPriority(attacker) > 0 && !move.isMultiTarget()) { cancelled.value = true; return true; } @@ -662,15 +675,15 @@ export class ReverseDrainAbAttr extends PostDefendAbAttr { * Examples include: Absorb, Draining Kiss, Bitter Blade, etc. * Also displays a message to show this ability was activated. * @param pokemon {@linkcode Pokemon} with this ability - * @param passive N/A + * @param _passive N/A * @param attacker {@linkcode Pokemon} that is attacking this Pokemon * @param move {@linkcode PokemonMove} that is being used - * @param hitResult N/A - * @args N/A + * @param _hitResult N/A + * @param _args N/A * @returns true if healing should be reversed on a healing move, false otherwise. */ - applyPostDefend(pokemon: Pokemon, passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, hitResult: HitResult, args: any[]): boolean { - if (move.hasAttr(HitHealAttr)) { + override applyPostDefend(pokemon: Pokemon, _passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, _hitResult: HitResult, _args: any[]): boolean { + if (move.hasAttr(HitHealAttr) && !move.hitsSubstitute(attacker, pokemon)) { if (!simulated) { pokemon.scene.queueMessage(i18next.t("abilityTriggers:reverseDrain", { pokemonNameWithAffix: getPokemonNameWithAffix(attacker) })); } @@ -697,8 +710,8 @@ export class PostDefendStatStageChangeAbAttr extends PostDefendAbAttr { this.allOthers = allOthers; } - applyPostDefend(pokemon: Pokemon, passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, hitResult: HitResult, args: any[]): boolean { - if (this.condition(pokemon, attacker, move)) { + override applyPostDefend(pokemon: Pokemon, _passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, _hitResult: HitResult, _args: any[]): boolean { + if (this.condition(pokemon, attacker, move) && !move.hitsSubstitute(attacker, pokemon)) { if (simulated) { return true; } @@ -735,13 +748,13 @@ export class PostDefendHpGatedStatStageChangeAbAttr extends PostDefendAbAttr { this.selfTarget = selfTarget; } - applyPostDefend(pokemon: Pokemon, passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, hitResult: HitResult, args: any[]): boolean { - const hpGateFlat: integer = Math.ceil(pokemon.getMaxHp() * this.hpGate); + override applyPostDefend(pokemon: Pokemon, _passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, _hitResult: HitResult, _args: any[]): boolean { + const hpGateFlat: number = Math.ceil(pokemon.getMaxHp() * this.hpGate); const lastAttackReceived = pokemon.turnData.attacksReceived[pokemon.turnData.attacksReceived.length - 1]; const damageReceived = lastAttackReceived?.damage || 0; - if (this.condition(pokemon, attacker, move) && (pokemon.hp <= hpGateFlat && (pokemon.hp + damageReceived) > hpGateFlat)) { - if (!simulated ) { + if (this.condition(pokemon, attacker, move) && (pokemon.hp <= hpGateFlat && (pokemon.hp + damageReceived) > hpGateFlat) && !move.hitsSubstitute(attacker, pokemon)) { + if (!simulated) { pokemon.scene.unshiftPhase(new StatStageChangePhase(pokemon.scene, (this.selfTarget ? pokemon : attacker).getBattlerIndex(), true, this.stats, this.stages)); } return true; @@ -762,8 +775,8 @@ export class PostDefendApplyArenaTrapTagAbAttr extends PostDefendAbAttr { this.tagType = tagType; } - applyPostDefend(pokemon: Pokemon, passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, hitResult: HitResult, args: any[]): boolean { - if (this.condition(pokemon, attacker, move)) { + override applyPostDefend(pokemon: Pokemon, _passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, _hitResult: HitResult, _args: any[]): boolean { + if (this.condition(pokemon, attacker, move) && !move.hitsSubstitute(attacker, pokemon)) { const tag = pokemon.scene.arena.getTag(this.tagType) as ArenaTrapTag; if (!pokemon.scene.arena.getTag(this.tagType) || tag.layers < tag.maxLayers) { if (!simulated) { @@ -786,8 +799,8 @@ export class PostDefendApplyBattlerTagAbAttr extends PostDefendAbAttr { this.tagType = tagType; } - applyPostDefend(pokemon: Pokemon, passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, hitResult: HitResult, args: any[]): boolean { - if (this.condition(pokemon, attacker, move)) { + override applyPostDefend(pokemon: Pokemon, _passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, _hitResult: HitResult, _args: any[]): boolean { + if (this.condition(pokemon, attacker, move) && !move.hitsSubstitute(attacker, pokemon)) { if (!pokemon.getTag(this.tagType) && !simulated) { pokemon.addTag(this.tagType, undefined, undefined, pokemon.id); pokemon.scene.queueMessage(i18next.t("abilityTriggers:windPowerCharged", { pokemonName: getPokemonNameWithAffix(pokemon), moveName: move.name })); @@ -799,8 +812,8 @@ export class PostDefendApplyBattlerTagAbAttr extends PostDefendAbAttr { } export class PostDefendTypeChangeAbAttr extends PostDefendAbAttr { - applyPostDefend(pokemon: Pokemon, passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, hitResult: HitResult, args: any[]): boolean { - if (hitResult < HitResult.NO_EFFECT) { + override applyPostDefend(pokemon: Pokemon, _passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, hitResult: HitResult, _args: any[]): boolean { + if (hitResult < HitResult.NO_EFFECT && !move.hitsSubstitute(attacker, pokemon)) { if (simulated) { return true; } @@ -815,7 +828,7 @@ export class PostDefendTypeChangeAbAttr extends PostDefendAbAttr { return false; } - getTriggerMessage(pokemon: Pokemon, abilityName: string, ...args: any[]): string { + override getTriggerMessage(pokemon: Pokemon, abilityName: string, ..._args: any[]): string { return i18next.t("abilityTriggers:postDefendTypeChange", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon), abilityName, @@ -833,8 +846,8 @@ export class PostDefendTerrainChangeAbAttr extends PostDefendAbAttr { this.terrainType = terrainType; } - applyPostDefend(pokemon: Pokemon, passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, hitResult: HitResult, args: any[]): boolean { - if (hitResult < HitResult.NO_EFFECT) { + override applyPostDefend(pokemon: Pokemon, _passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, hitResult: HitResult, _args: any[]): boolean { + if (hitResult < HitResult.NO_EFFECT && !move.hitsSubstitute(attacker, pokemon)) { if (simulated) { return pokemon.scene.arena.terrain?.terrainType !== (this.terrainType || undefined); } else { @@ -857,8 +870,9 @@ export class PostDefendContactApplyStatusEffectAbAttr extends PostDefendAbAttr { this.effects = effects; } - applyPostDefend(pokemon: Pokemon, passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, hitResult: HitResult, args: any[]): boolean { - if (move.checkFlag(MoveFlags.MAKES_CONTACT, attacker, pokemon) && !attacker.status && (this.chance === -1 || pokemon.randSeedInt(100) < this.chance)) { + override applyPostDefend(pokemon: Pokemon, _passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, _hitResult: HitResult, _args: any[]): boolean { + if (move.checkFlag(MoveFlags.MAKES_CONTACT, attacker, pokemon) && !attacker.status + && (this.chance === -1 || pokemon.randSeedInt(100) < this.chance) && !move.hitsSubstitute(attacker, pokemon)) { const effect = this.effects.length === 1 ? this.effects[0] : this.effects[pokemon.randSeedInt(this.effects.length)]; if (simulated) { return attacker.canSetStatus(effect, true, false, pokemon); @@ -897,8 +911,8 @@ export class PostDefendContactApplyTagChanceAbAttr extends PostDefendAbAttr { this.turnCount = turnCount; } - applyPostDefend(pokemon: Pokemon, passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, hitResult: HitResult, args: any[]): boolean { - if (move.checkFlag(MoveFlags.MAKES_CONTACT, attacker, pokemon) && pokemon.randSeedInt(100) < this.chance) { + override applyPostDefend(pokemon: Pokemon, _passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, _hitResult: HitResult, _args: any[]): boolean { + if (move.checkFlag(MoveFlags.MAKES_CONTACT, attacker, pokemon) && pokemon.randSeedInt(100) < this.chance && !move.hitsSubstitute(attacker, pokemon)) { if (simulated) { return attacker.canAddTag(this.tagType); } else { @@ -921,7 +935,11 @@ export class PostDefendCritStatStageChangeAbAttr extends PostDefendAbAttr { this.stages = stages; } - applyPostDefend(pokemon: Pokemon, passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, hitResult: HitResult, args: any[]): boolean { + override applyPostDefend(pokemon: Pokemon, _passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, _hitResult: HitResult, _args: any[]): boolean { + if (move.hitsSubstitute(attacker, pokemon)) { + return false; + } + if (!simulated) { pokemon.scene.unshiftPhase(new StatStageChangePhase(pokemon.scene, pokemon.getBattlerIndex(), true, [ this.stat ], this.stages)); } @@ -929,7 +947,7 @@ export class PostDefendCritStatStageChangeAbAttr extends PostDefendAbAttr { return true; } - getCondition(): AbAttrCondition { + override getCondition(): AbAttrCondition { return (pokemon: Pokemon) => pokemon.turnData.attacksReceived.length !== 0 && pokemon.turnData.attacksReceived[pokemon.turnData.attacksReceived.length - 1].critical; } } @@ -943,8 +961,9 @@ export class PostDefendContactDamageAbAttr extends PostDefendAbAttr { this.damageRatio = damageRatio; } - applyPostDefend(pokemon: Pokemon, passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, hitResult: HitResult, args: any[]): boolean { - if (!simulated && move.checkFlag(MoveFlags.MAKES_CONTACT, attacker, pokemon) && !attacker.hasAbilityWithAttr(BlockNonDirectDamageAbAttr)) { + override applyPostDefend(pokemon: Pokemon, _passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, _hitResult: HitResult, _args: any[]): boolean { + if (!simulated && move.checkFlag(MoveFlags.MAKES_CONTACT, attacker, pokemon) + && !attacker.hasAbilityWithAttr(BlockNonDirectDamageAbAttr) && !move.hitsSubstitute(attacker, pokemon)) { attacker.damageAndUpdate(Utils.toDmgValue(attacker.getMaxHp() * (1 / this.damageRatio)), HitResult.OTHER); attacker.turnData.damageTaken += Utils.toDmgValue(attacker.getMaxHp() * (1 / this.damageRatio)); return true; @@ -953,7 +972,7 @@ export class PostDefendContactDamageAbAttr extends PostDefendAbAttr { return false; } - getTriggerMessage(pokemon: Pokemon, abilityName: string, ...args: any[]): string { + override getTriggerMessage(pokemon: Pokemon, abilityName: string, ..._args: any[]): string { return i18next.t("abilityTriggers:postDefendContactDamage", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon), abilityName @@ -976,8 +995,8 @@ export class PostDefendPerishSongAbAttr extends PostDefendAbAttr { this.turns = turns; } - applyPostDefend(pokemon: Pokemon, passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, hitResult: HitResult, args: any[]): boolean { - if (move.checkFlag(MoveFlags.MAKES_CONTACT, attacker, pokemon)) { + override applyPostDefend(pokemon: Pokemon, _passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, _hitResult: HitResult, _args: any[]): boolean { + if (move.checkFlag(MoveFlags.MAKES_CONTACT, attacker, pokemon) && !move.hitsSubstitute(attacker, pokemon)) { if (pokemon.getTag(BattlerTagType.PERISH_SONG) || attacker.getTag(BattlerTagType.PERISH_SONG)) { return false; } else { @@ -991,24 +1010,24 @@ export class PostDefendPerishSongAbAttr extends PostDefendAbAttr { return false; } - getTriggerMessage(pokemon: Pokemon, abilityName: string, ...args: any[]): string { - return i18next.t("abilityTriggers:perishBody", {pokemonName: getPokemonNameWithAffix(pokemon), abilityName: abilityName}); + override getTriggerMessage(pokemon: Pokemon, abilityName: string, ..._args: any[]): string { + return i18next.t("abilityTriggers:perishBody", { pokemonName: getPokemonNameWithAffix(pokemon), abilityName: abilityName }); } } export class PostDefendWeatherChangeAbAttr extends PostDefendAbAttr { private weatherType: WeatherType; - protected condition: PokemonDefendCondition | null; + protected condition?: PokemonDefendCondition; constructor(weatherType: WeatherType, condition?: PokemonDefendCondition) { super(); this.weatherType = weatherType; - this.condition = condition ?? null; + this.condition = condition; } - applyPostDefend(pokemon: Pokemon, passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, hitResult: HitResult, args: any[]): boolean { - if (this.condition !== null && !this.condition(pokemon, attacker, move)) { + override applyPostDefend(pokemon: Pokemon, _passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, _hitResult: HitResult, _args: any[]): boolean { + if (this.condition && !this.condition(pokemon, attacker, move) || move.hitsSubstitute(attacker, pokemon)) { return false; } if (!pokemon.scene.arena.weather?.isImmutable()) { @@ -1027,8 +1046,9 @@ export class PostDefendAbilitySwapAbAttr extends PostDefendAbAttr { super(); } - applyPostDefend(pokemon: Pokemon, passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, hitResult: HitResult, args: any[]): boolean { - if (move.checkFlag(MoveFlags.MAKES_CONTACT, attacker, pokemon) && !attacker.getAbility().hasAttr(UnswappableAbilityAbAttr)) { + override applyPostDefend(pokemon: Pokemon, _passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, _hitResult: HitResult, args: any[]): boolean { + if (move.checkFlag(MoveFlags.MAKES_CONTACT, attacker, pokemon) + && !attacker.getAbility().hasAttr(UnswappableAbilityAbAttr) && !move.hitsSubstitute(attacker, pokemon)) { if (!simulated) { const tempAbilityId = attacker.getAbility().id; attacker.summonData.ability = pokemon.getAbility().id; @@ -1040,7 +1060,7 @@ export class PostDefendAbilitySwapAbAttr extends PostDefendAbAttr { return false; } - getTriggerMessage(pokemon: Pokemon, abilityName: string, ...args: any[]): string { + override getTriggerMessage(pokemon: Pokemon, _abilityName: string, ..._args: any[]): string { return i18next.t("abilityTriggers:postDefendAbilitySwap", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) }); } } @@ -1053,8 +1073,9 @@ export class PostDefendAbilityGiveAbAttr extends PostDefendAbAttr { this.ability = ability; } - applyPostDefend(pokemon: Pokemon, passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, hitResult: HitResult, args: any[]): boolean { - if (move.checkFlag(MoveFlags.MAKES_CONTACT, attacker, pokemon) && !attacker.getAbility().hasAttr(UnsuppressableAbilityAbAttr) && !attacker.getAbility().hasAttr(PostDefendAbilityGiveAbAttr)) { + override applyPostDefend(pokemon: Pokemon, _passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, _hitResult: HitResult, _args: any[]): boolean { + if (move.checkFlag(MoveFlags.MAKES_CONTACT, attacker, pokemon) && !attacker.getAbility().hasAttr(UnsuppressableAbilityAbAttr) + && !attacker.getAbility().hasAttr(PostDefendAbilityGiveAbAttr) && !move.hitsSubstitute(attacker, pokemon)) { if (!simulated) { attacker.summonData.ability = this.ability; } @@ -1065,7 +1086,7 @@ export class PostDefendAbilityGiveAbAttr extends PostDefendAbAttr { return false; } - getTriggerMessage(pokemon: Pokemon, abilityName: string, ...args: any[]): string { + override getTriggerMessage(pokemon: Pokemon, abilityName: string, ..._args: any[]): string { return i18next.t("abilityTriggers:postDefendAbilityGive", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon), abilityName @@ -1084,8 +1105,8 @@ export class PostDefendMoveDisableAbAttr extends PostDefendAbAttr { this.chance = chance; } - applyPostDefend(pokemon: Pokemon, passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, hitResult: HitResult, args: any[]): boolean { - if (attacker.getTag(BattlerTagType.DISABLED) === null) { + override applyPostDefend(pokemon: Pokemon, _passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, _hitResult: HitResult, _args: any[]): boolean { + if (attacker.getTag(BattlerTagType.DISABLED) === null && !move.hitsSubstitute(attacker, pokemon)) { if (move.checkFlag(MoveFlags.MAKES_CONTACT, attacker, pokemon) && (this.chance === -1 || pokemon.randSeedInt(100) < this.chance)) { if (simulated) { return true; @@ -1151,7 +1172,9 @@ export class MoveEffectChanceMultiplierAbAttr extends AbAttr { apply(pokemon: Pokemon, passive: boolean, simulated: boolean, cancelled: Utils.BooleanHolder, args: any[]): boolean { // Disable showAbility during getTargetBenefitScore this.showAbility = args[4]; - if ((args[0] as Utils.NumberHolder).value <= 0 || (args[1] as Move).id === Moves.ORDER_UP) { + + const exceptMoves = [ Moves.ORDER_UP, Moves.ELECTRO_SHOT ]; + if ((args[0] as Utils.NumberHolder).value <= 0 || exceptMoves.includes((args[1] as Move).id)) { return false; } @@ -1296,7 +1319,7 @@ export class PokemonTypeChangeAbAttr extends PreAttackAbAttr { if (pokemon.getTypes().some((t) => t !== moveType)) { if (!simulated) { this.moveType = moveType; - pokemon.summonData.types = [moveType]; + pokemon.summonData.types = [ moveType ]; pokemon.updateInfo(); } @@ -1328,65 +1351,30 @@ export class AddSecondStrikeAbAttr extends PreAttackAbAttr { this.damageMultiplier = damageMultiplier; } - /** - * Determines whether this attribute can apply to a given move. - * @param {Move} move the move to which this attribute may apply - * @param numTargets the number of {@linkcode Pokemon} targeted by this move - * @returns true if the attribute can apply to the move, false otherwise - */ - canApplyPreAttack(move: Move, numTargets: integer): boolean { - /** - * Parental Bond cannot apply to multi-hit moves, charging moves, or - * moves that cause the user to faint. - */ - const exceptAttrs: Constructor[] = [ - MultiHitAttr, - ChargeAttr, - SacrificialAttr, - SacrificialAttrOnHit - ]; - - /** Parental Bond cannot apply to these specific moves */ - const exceptMoves: Moves[] = [ - Moves.FLING, - Moves.UPROAR, - Moves.ROLLOUT, - Moves.ICE_BALL, - Moves.ENDEAVOR - ]; - - /** Also check if this move is an Attack move and if it's only targeting one Pokemon */ - return numTargets === 1 - && !exceptAttrs.some(attr => move.hasAttr(attr)) - && !exceptMoves.some(id => move.id === id) - && move.category !== MoveCategory.STATUS; - } - /** * If conditions are met, this doubles the move's hit count (via args[1]) * or multiplies the damage of secondary strikes (via args[2]) - * @param {Pokemon} pokemon the Pokemon using the move + * @param pokemon the {@linkcode Pokemon} using the move * @param passive n/a * @param defender n/a - * @param {Move} move the move used by the ability source - * @param args\[0\] the number of Pokemon this move is targeting - * @param {Utils.IntegerHolder} args\[1\] the number of strikes with this move - * @param {Utils.NumberHolder} args\[2\] the damage multiplier for the current strike + * @param move the {@linkcode Move} used by the ability source + * @param args Additional arguments: + * - `[0]` the number of strikes this move currently has ({@linkcode Utils.NumberHolder}) + * - `[1]` the damage multiplier for the current strike ({@linkcode Utils.NumberHolder}) * @returns */ applyPreAttack(pokemon: Pokemon, passive: boolean, simulated: boolean, defender: Pokemon, move: Move, args: any[]): boolean { - const numTargets = args[0] as integer; - const hitCount = args[1] as Utils.IntegerHolder; - const multiplier = args[2] as Utils.NumberHolder; + const hitCount = args[0] as Utils.NumberHolder; + const multiplier = args[1] as Utils.NumberHolder; - if (this.canApplyPreAttack(move, numTargets)) { + if (move.canBeMultiStrikeEnhanced(pokemon, true)) { this.showAbility = !!hitCount?.value; - if (!!hitCount?.value) { - hitCount.value *= 2; + if (hitCount?.value) { + hitCount.value += 1; } - if (!!multiplier?.value && pokemon.turnData.hitsLeft % 2 === 1 && pokemon.turnData.hitsLeft !== pokemon.turnData.hitCount) { - multiplier.value *= this.damageMultiplier; + if (multiplier?.value && pokemon.turnData.hitsLeft === 1) { + multiplier.value = this.damageMultiplier; } return true; } @@ -1670,7 +1658,7 @@ export class PostAttackStealHeldItemAbAttr extends PostAttackAbAttr { applyPostAttackAfterMoveTypeCheck(pokemon: Pokemon, passive: boolean, simulated: boolean, defender: Pokemon, move: Move, hitResult: HitResult, args: any[]): Promise { return new Promise(resolve => { if (!simulated && hitResult < HitResult.NO_EFFECT && (!this.stealCondition || this.stealCondition(pokemon, defender, move))) { - const heldItems = this.getTargetHeldItems(defender).filter(i => i.isTransferrable); + const heldItems = this.getTargetHeldItems(defender).filter(i => i.isTransferable); if (heldItems.length) { const stolenItem = heldItems[pokemon.randSeedInt(heldItems.length)]; pokemon.scene.tryTransferHeldItemModifier(stolenItem, pokemon, false).then(success => { @@ -1752,18 +1740,18 @@ export class PostAttackApplyBattlerTagAbAttr extends PostAttackAbAttr { } export class PostDefendStealHeldItemAbAttr extends PostDefendAbAttr { - private condition: PokemonDefendCondition | null; + private condition?: PokemonDefendCondition; constructor(condition?: PokemonDefendCondition) { super(); - this.condition = condition ?? null; + this.condition = condition; } - applyPostDefend(pokemon: Pokemon, passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, hitResult: HitResult, args: any[]): Promise { + override applyPostDefend(pokemon: Pokemon, _passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, hitResult: HitResult, _args: any[]): Promise { return new Promise(resolve => { - if (!simulated && hitResult < HitResult.NO_EFFECT && (!this.condition || this.condition(pokemon, attacker, move))) { - const heldItems = this.getTargetHeldItems(attacker).filter(i => i.isTransferrable); + if (!simulated && hitResult < HitResult.NO_EFFECT && (!this.condition || this.condition(pokemon, attacker, move)) && !move.hitsSubstitute(attacker, pokemon)) { + const heldItems = this.getTargetHeldItems(attacker).filter(i => i.isTransferable); if (heldItems.length) { const stolenItem = heldItems[pokemon.randSeedInt(heldItems.length)]; pokemon.scene.tryTransferHeldItemModifier(stolenItem, pokemon, false).then(success => { @@ -1785,6 +1773,61 @@ export class PostDefendStealHeldItemAbAttr extends PostDefendAbAttr { } } +/** + * Base class for defining all {@linkcode Ability} Attributes after a status effect has been set. + * @see {@linkcode applyPostSetStatus()}. + */ +export class PostSetStatusAbAttr extends AbAttr { + /** + * Does nothing after a status condition is set. + * @param pokemon {@linkcode Pokemon} that status condition was set on. + * @param sourcePokemon {@linkcode Pokemon} that that set the status condition. Is `null` if status was not set by a Pokemon. + * @param passive Whether this ability is a passive. + * @param effect {@linkcode StatusEffect} that was set. + * @param args Set of unique arguments needed by this attribute. + * @returns `true` if application of the ability succeeds. + */ + applyPostSetStatus(pokemon: Pokemon, sourcePokemon: Pokemon | null = null, passive: boolean, effect: StatusEffect, simulated: boolean, args: any[]) : boolean | Promise { + return false; + } +} + +/** + * If another Pokemon burns, paralyzes, poisons, or badly poisons this Pokemon, + * that Pokemon receives the same non-volatile status condition as part of this + * ability attribute. For Synchronize ability. + */ +export class SynchronizeStatusAbAttr extends PostSetStatusAbAttr { + /** + * If the `StatusEffect` that was set is Burn, Paralysis, Poison, or Toxic, and the status + * was set by a source Pokemon, set the source Pokemon's status to the same `StatusEffect`. + * @param pokemon {@linkcode Pokemon} that status condition was set on. + * @param sourcePokemon {@linkcode Pokemon} that that set the status condition. Is null if status was not set by a Pokemon. + * @param passive Whether this ability is a passive. + * @param effect {@linkcode StatusEffect} that was set. + * @param args Set of unique arguments needed by this attribute. + * @returns `true` if application of the ability succeeds. + */ + override applyPostSetStatus(pokemon: Pokemon, sourcePokemon: Pokemon | null = null, passive: boolean, effect: StatusEffect, simulated: boolean, args: any[]): boolean { + /** Synchronizable statuses */ + const syncStatuses = new Set([ + StatusEffect.BURN, + StatusEffect.PARALYSIS, + StatusEffect.POISON, + StatusEffect.TOXIC + ]); + + if (sourcePokemon && syncStatuses.has(effect)) { + if (!simulated) { + sourcePokemon.trySetStatus(effect, true, pokemon); + } + return true; + } + + return false; + } +} + export class PostVictoryAbAttr extends AbAttr { applyPostVictory(pokemon: Pokemon, passive: boolean, simulated: boolean, args: any[]): boolean | Promise { return false; @@ -1881,6 +1924,10 @@ export class CopyFaintedAllyAbilityAbAttr extends PostKnockOutAbAttr { } } +/** + * Ability attribute for ignoring the opponent's stat changes + * @param stats the stats that should be ignored + */ export class IgnoreOpponentStatStagesAbAttr extends AbAttr { private stats: readonly BattleStat[]; @@ -1890,6 +1937,15 @@ export class IgnoreOpponentStatStagesAbAttr extends AbAttr { this.stats = stats ?? BATTLE_STATS; } + /** + * Modifies a BooleanHolder and returns the result to see if a stat is ignored or not + * @param _pokemon n/a + * @param _passive n/a + * @param simulated n/a + * @param _cancelled n/a + * @param args A BooleanHolder that represents whether or not to ignore a stat's stat changes + * @returns true if the stat is ignored, false otherwise + */ apply(_pokemon: Pokemon, _passive: boolean, simulated: boolean, _cancelled: Utils.BooleanHolder, args: any[]) { if (this.stats.includes(args[0])) { (args[1] as Utils.BooleanHolder).value = true; @@ -1954,6 +2010,7 @@ export class PostSummonAbAttr extends AbAttr { return false; } } + /** * Removes specified arena tags when a Pokemon is summoned. */ @@ -2371,30 +2428,48 @@ export class PostSummonCopyAllyStatsAbAttr extends PostSummonAbAttr { } } +/** + * Used by Imposter + */ export class PostSummonTransformAbAttr extends PostSummonAbAttr { constructor() { super(true); } - applyPostSummon(pokemon: Pokemon, passive: boolean, simulated: boolean, args: any[]): boolean { + async applyPostSummon(pokemon: Pokemon, _passive: boolean, simulated: boolean, _args: any[]): Promise { const targets = pokemon.getOpponents(); if (simulated || !targets.length) { return simulated; } + const promises: Promise[] = []; let target: Pokemon; if (targets.length > 1) { - pokemon.scene.executeWithSeedOffset(() => target = Utils.randSeedItem(targets), pokemon.scene.currentBattle.waveIndex); + pokemon.scene.executeWithSeedOffset(() => { + // in a double battle, if one of the opposing pokemon is fused the other one will be chosen + // if both are fused, then Imposter will fail below + if (targets[0].fusionSpecies) { + target = targets[1]; + return; + } else if (targets[1].fusionSpecies) { + target = targets[0]; + return; + } + target = Utils.randSeedItem(targets); + }, pokemon.scene.currentBattle.waveIndex); } else { target = targets[0]; } + target = target!; + + // transforming from or into fusion pokemon causes various problems (including crashes and save corruption) + if (target.fusionSpecies || pokemon.fusionSpecies) { + return false; + } - target = target!; // compiler doesn't know its guranteed to be defined pokemon.summonData.speciesForm = target.getSpeciesForm(); - pokemon.summonData.fusionSpeciesForm = target.getFusionSpeciesForm(); pokemon.summonData.ability = target.getAbility().id; pokemon.summonData.gender = target.getGender(); - pokemon.summonData.fusionGender = target.getFusionGender(); // Copy all stats (except HP) for (const s of EFFECTIVE_STATS) { @@ -2406,18 +2481,26 @@ export class PostSummonTransformAbAttr extends PostSummonAbAttr { pokemon.setStatStage(s, target.getStatStage(s)); } - pokemon.summonData.moveset = target.getMoveset().map(m => new PokemonMove(m!.moveId, m!.ppUsed, m!.ppUp)); // TODO: are those bangs correct? - pokemon.summonData.types = target.getTypes(); - - - pokemon.scene.playSound("battle_anims/PRSFX- Transform"); - - pokemon.loadAssets(false).then(() => { - pokemon.playAnim(); - pokemon.updateInfo(); + pokemon.summonData.moveset = target.getMoveset().map((m) => { + if (m) { + // If PP value is less than 5, do nothing. If greater, we need to reduce the value to 5. + return new PokemonMove(m.moveId, 0, 0, false, Math.min(m.getMove().pp, 5)); + } else { + console.warn(`Imposter: somehow iterating over a ${m} value when copying moveset!`); + return new PokemonMove(Moves.NONE); + } }); + pokemon.summonData.types = target.getTypes(); + promises.push(pokemon.updateInfo()); pokemon.scene.queueMessage(i18next.t("abilityTriggers:postSummonTransform", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon), targetName: target.name, })); + pokemon.scene.playSound("battle_anims/PRSFX- Transform"); + promises.push(pokemon.loadAssets(false).then(() => { + pokemon.playAnim(); + pokemon.updateInfo(); + })); + + await Promise.all(promises); return true; } @@ -2493,6 +2576,42 @@ export class PostSummonFormChangeByWeatherAbAttr extends PostSummonAbAttr { } } +/** + * Attribute implementing the effects of {@link https://bulbapedia.bulbagarden.net/wiki/Commander_(Ability) | Commander}. + * When the source of an ability with this attribute detects a Dondozo as their active ally, the source "jumps + * into the Dondozo's mouth," sharply boosting the Dondozo's stats, cancelling the source's moves, and + * causing attacks that target the source to always miss. + */ +export class CommanderAbAttr extends AbAttr { + constructor() { + super(true); + } + + override apply(pokemon: Pokemon, passive: boolean, simulated: boolean, cancelled: null, args: any[]): boolean { + // TODO: Should this work with X + Dondozo fusions? + if (pokemon.scene.currentBattle?.double && pokemon.getAlly()?.species.speciesId === Species.DONDOZO) { + // If the ally Dondozo is fainted or was previously "commanded" by + // another Pokemon, this effect cannot apply. + if (pokemon.getAlly().isFainted() || pokemon.getAlly().getTag(BattlerTagType.COMMANDED)) { + return false; + } + + if (!simulated) { + // Lapse the source's semi-invulnerable tags (to avoid visual inconsistencies) + pokemon.lapseTags(BattlerTagLapseType.MOVE_EFFECT); + // Play an animation of the source jumping into the ally Dondozo's mouth + pokemon.scene.triggerPokemonBattleAnim(pokemon, PokemonAnimType.COMMANDER_APPLY); + // Apply boosts from this effect to the ally Dondozo + pokemon.getAlly().addTag(BattlerTagType.COMMANDED, 0, Moves.NONE, pokemon.id); + // Cancel the source Pokemon's next move (if a move is queued) + pokemon.scene.tryRemovePhase((phase) => phase instanceof MovePhase && phase.pokemon === pokemon); + } + return true; + } + return false; + } +} + export class PreSwitchOutAbAttr extends AbAttr { constructor() { super(true); @@ -2535,24 +2654,24 @@ export class PreSwitchOutClearWeatherAbAttr extends PreSwitchOutAbAttr { // Clear weather only if user's ability matches the weather and no other pokemon has the ability. switch (weatherType) { - case (WeatherType.HARSH_SUN): - if (pokemon.hasAbility(Abilities.DESOLATE_LAND) + case (WeatherType.HARSH_SUN): + if (pokemon.hasAbility(Abilities.DESOLATE_LAND) && pokemon.scene.getField(true).filter(p => p !== pokemon).filter(p => p.hasAbility(Abilities.DESOLATE_LAND)).length === 0) { - turnOffWeather = true; - } - break; - case (WeatherType.HEAVY_RAIN): - if (pokemon.hasAbility(Abilities.PRIMORDIAL_SEA) + turnOffWeather = true; + } + break; + case (WeatherType.HEAVY_RAIN): + if (pokemon.hasAbility(Abilities.PRIMORDIAL_SEA) && pokemon.scene.getField(true).filter(p => p !== pokemon).filter(p => p.hasAbility(Abilities.PRIMORDIAL_SEA)).length === 0) { - turnOffWeather = true; - } - break; - case (WeatherType.STRONG_WINDS): - if (pokemon.hasAbility(Abilities.DELTA_STREAM) + turnOffWeather = true; + } + break; + case (WeatherType.STRONG_WINDS): + if (pokemon.hasAbility(Abilities.DELTA_STREAM) && pokemon.scene.getField(true).filter(p => p !== pokemon).filter(p => p.hasAbility(Abilities.DELTA_STREAM)).length === 0) { - turnOffWeather = true; - } - break; + turnOffWeather = true; + } + break; } if (simulated) { @@ -2780,17 +2899,17 @@ export class PreApplyBattlerTagAbAttr extends AbAttr { * Provides immunity to BattlerTags {@linkcode BattlerTag} to specified targets. */ export class PreApplyBattlerTagImmunityAbAttr extends PreApplyBattlerTagAbAttr { - private immuneTagType: BattlerTagType; + private immuneTagTypes: BattlerTagType[]; private battlerTag: BattlerTag; - constructor(immuneTagType: BattlerTagType) { + constructor(immuneTagTypes: BattlerTagType | BattlerTagType[]) { super(); - this.immuneTagType = immuneTagType; + this.immuneTagTypes = Array.isArray(immuneTagTypes) ? immuneTagTypes : [ immuneTagTypes ]; } applyPreApplyBattlerTag(pokemon: Pokemon, passive: boolean, simulated: boolean, tag: BattlerTag, cancelled: Utils.BooleanHolder, args: any[]): boolean { - if (tag.tagType === this.immuneTagType) { + if (this.immuneTagTypes.includes(tag.tagType)) { cancelled.value = true; if (!simulated) { this.battlerTag = tag; @@ -3013,7 +3132,7 @@ export class SuppressWeatherEffectAbAttr extends PreWeatherEffectAbAttr { /** * Condition function to applied to abilities related to Sheer Force. * Checks if last move used against target was affected by a Sheer Force user and: - * Disables: Color Change, Pickpocket, Wimp Out, Emergency Exit, Berserk, Anger Shell + * Disables: Color Change, Pickpocket, Berserk, Anger Shell * @returns {AbAttrCondition} If false disables the ability which the condition is applied to. */ function getSheerForceHitDisableAbCondition(): AbAttrCondition { @@ -3061,7 +3180,7 @@ function getAnticipationCondition(): AbAttrCondition { continue; } // the move's base type (not accounting for variable type changes) is super effective - if (move.getMove() instanceof AttackMove && pokemon.getAttackTypeEffectiveness(move.getMove().type, opponent, true) >= 2) { + if (move.getMove() instanceof AttackMove && pokemon.getAttackTypeEffectiveness(move.getMove().type, opponent, true, undefined, move.getMove()) >= 2) { return true; } // move is a OHKO @@ -3071,17 +3190,17 @@ function getAnticipationCondition(): AbAttrCondition { // edge case for hidden power, type is computed if (move.getMove().id === Moves.HIDDEN_POWER) { const iv_val = Math.floor(((opponent.ivs[Stat.HP] & 1) - +(opponent.ivs[Stat.ATK] & 1) * 2 - +(opponent.ivs[Stat.DEF] & 1) * 4 - +(opponent.ivs[Stat.SPD] & 1) * 8 - +(opponent.ivs[Stat.SPATK] & 1) * 16 - +(opponent.ivs[Stat.SPDEF] & 1) * 32) * 15/63); + + (opponent.ivs[Stat.ATK] & 1) * 2 + + (opponent.ivs[Stat.DEF] & 1) * 4 + + (opponent.ivs[Stat.SPD] & 1) * 8 + + (opponent.ivs[Stat.SPATK] & 1) * 16 + + (opponent.ivs[Stat.SPDEF] & 1) * 32) * 15 / 63); const type = [ Type.FIGHTING, Type.FLYING, Type.POISON, Type.GROUND, Type.ROCK, Type.BUG, Type.GHOST, Type.STEEL, Type.FIRE, Type.WATER, Type.GRASS, Type.ELECTRIC, - Type.PSYCHIC, Type.ICE, Type.DRAGON, Type.DARK][iv_val]; + Type.PSYCHIC, Type.ICE, Type.DRAGON, Type.DARK ][iv_val]; if (pokemon.getAttackTypeEffectiveness(type, opponent) >= 2) { return true; @@ -3126,12 +3245,12 @@ export class ForewarnAbAttr extends PostSummonAbAttr { } else if (move?.getMove().power === -1) { movePower = 80; } else { - movePower = move!.getMove().power; // TODO: is this bang correct? + movePower = move?.getMove().power ?? 0; } if (movePower > maxPowerSeen) { maxPowerSeen = movePower; - maxMove = move!.getName(); // TODO: is this bang correct? + maxMove = move?.getName() ?? ""; } } } @@ -3535,22 +3654,19 @@ export class MoodyAbAttr extends PostTurnAbAttr { } } -export class PostTurnStatStageChangeAbAttr extends PostTurnAbAttr { - private stats: BattleStat[]; - private stages: number; +export class SpeedBoostAbAttr extends PostTurnAbAttr { - constructor(stats: BattleStat[], stages: number) { + constructor() { super(true); - - this.stats = Array.isArray(stats) - ? stats - : [ stats ]; - this.stages = stages; } applyPostTurn(pokemon: Pokemon, passive: boolean, simulated: boolean, args: any[]): boolean { if (!simulated) { - pokemon.scene.unshiftPhase(new StatStageChangePhase(pokemon.scene, pokemon.getBattlerIndex(), true, this.stats, this.stages)); + if (!pokemon.turnData.switchedInThisTurn && !pokemon.turnData.failedRunAway) { + pokemon.scene.unshiftPhase(new StatStageChangePhase(pokemon.scene, pokemon.getBattlerIndex(), true, [ Stat.SPD ], 1)); + } else { + return false; + } } return true; } @@ -3616,7 +3732,7 @@ export class PostTurnHurtIfSleepingAbAttr extends PostTurnAbAttr { if ((opp.status?.effect === StatusEffect.SLEEP || opp.hasAbility(Abilities.COMATOSE)) && !opp.hasAbilityWithAttr(BlockNonDirectDamageAbAttr)) { if (!simulated) { opp.damageAndUpdate(Utils.toDmgValue(opp.getMaxHp() / 8), HitResult.OTHER); - pokemon.scene.queueMessage(i18next.t("abilityTriggers:badDreams", {pokemonName: getPokemonNameWithAffix(opp)})); + pokemon.scene.queueMessage(i18next.t("abilityTriggers:badDreams", { pokemonName: getPokemonNameWithAffix(opp) })); } hadEffect = true; } @@ -3727,8 +3843,8 @@ export class PostDancingMoveAbAttr extends PostMoveUsedAbAttr { */ applyPostMoveUsed(dancer: Pokemon, move: PokemonMove, source: Pokemon, targets: BattlerIndex[], simulated: boolean, args: any[]): boolean | Promise { // List of tags that prevent the Dancer from replicating the move - const forbiddenTags = [BattlerTagType.FLYING, BattlerTagType.UNDERWATER, - BattlerTagType.UNDERGROUND, BattlerTagType.HIDDEN]; + const forbiddenTags = [ BattlerTagType.FLYING, BattlerTagType.UNDERWATER, + BattlerTagType.UNDERGROUND, BattlerTagType.HIDDEN ]; // The move to replicate cannot come from the Dancer if (source.getBattlerIndex() !== dancer.getBattlerIndex() && !dancer.summonData.tags.some(tag => forbiddenTags.includes(tag.tagType))) { @@ -3739,7 +3855,7 @@ export class PostDancingMoveAbAttr extends PostMoveUsedAbAttr { dancer.scene.unshiftPhase(new MovePhase(dancer.scene, dancer, target, move, true, true)); } else if (move.getMove() instanceof SelfStatusMove) { // If the move is a SelfStatusMove (ie. Swords Dance) the Dancer should replicate it on itself - dancer.scene.unshiftPhase(new MovePhase(dancer.scene, dancer, [dancer.getBattlerIndex()], move, true, true)); + dancer.scene.unshiftPhase(new MovePhase(dancer.scene, dancer, [ dancer.getBattlerIndex() ], move, true, true)); } } return true; @@ -3756,9 +3872,44 @@ export class PostDancingMoveAbAttr extends PostMoveUsedAbAttr { */ getTarget(dancer: Pokemon, source: Pokemon, targets: BattlerIndex[]) : BattlerIndex[] { if (dancer.isPlayer()) { - return source.isPlayer() ? targets : [source.getBattlerIndex()]; + return source.isPlayer() ? targets : [ source.getBattlerIndex() ]; } - return source.isPlayer() ? [source.getBattlerIndex()] : targets; + return source.isPlayer() ? [ source.getBattlerIndex() ] : targets; + } +} + +/** + * Triggers after the Pokemon loses or consumes an item + * @extends AbAttr + */ +export class PostItemLostAbAttr extends AbAttr { + applyPostItemLost(pokemon: Pokemon, simulated: boolean, args: any[]): boolean | Promise { + return false; + } +} + +/** + * Applies a Battler Tag to the Pokemon after it loses or consumes item + * @extends PostItemLostAbAttr + */ +export class PostItemLostApplyBattlerTagAbAttr extends PostItemLostAbAttr { + private tagType: BattlerTagType; + constructor(tagType: BattlerTagType) { + super(true); + this.tagType = tagType; + } + /** + * Adds the last used Pokeball back into the player's inventory + * @param pokemon {@linkcode Pokemon} with this ability + * @param args N/A + * @returns true if BattlerTag was applied + */ + applyPostItemLost(pokemon: Pokemon, simulated: boolean, args: any[]): boolean | Promise { + if (!pokemon.getTag(this.tagType) && !simulated) { + pokemon.addTag(this.tagType); + return true; + } + return false; } } @@ -3966,7 +4117,7 @@ export class PostBattleLootAbAttr extends PostBattleAbAttr { if (!simulated && postBattleLoot.length) { const randItem = Utils.randSeedItem(postBattleLoot); //@ts-ignore - TODO see below - if (pokemon.scene.tryTransferHeldItemModifier(randItem, pokemon, true, 1, true)) { // TODO: fix. This is a promise!? + if (pokemon.scene.tryTransferHeldItemModifier(randItem, pokemon, true, 1, true, undefined, false)) { // TODO: fix. This is a promise!? postBattleLoot.splice(postBattleLoot.indexOf(randItem), 1); pokemon.scene.queueMessage(i18next.t("abilityTriggers:postBattleLoot", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon), itemName: randItem.type.name })); return true; @@ -4035,24 +4186,24 @@ export class PostFaintClearWeatherAbAttr extends PostFaintAbAttr { // Clear weather only if user's ability matches the weather and no other pokemon has the ability. switch (weatherType) { - case (WeatherType.HARSH_SUN): - if (pokemon.hasAbility(Abilities.DESOLATE_LAND) + case (WeatherType.HARSH_SUN): + if (pokemon.hasAbility(Abilities.DESOLATE_LAND) && pokemon.scene.getField(true).filter(p => p.hasAbility(Abilities.DESOLATE_LAND)).length === 0) { - turnOffWeather = true; - } - break; - case (WeatherType.HEAVY_RAIN): - if (pokemon.hasAbility(Abilities.PRIMORDIAL_SEA) + turnOffWeather = true; + } + break; + case (WeatherType.HEAVY_RAIN): + if (pokemon.hasAbility(Abilities.PRIMORDIAL_SEA) && pokemon.scene.getField(true).filter(p => p.hasAbility(Abilities.PRIMORDIAL_SEA)).length === 0) { - turnOffWeather = true; - } - break; - case (WeatherType.STRONG_WINDS): - if (pokemon.hasAbility(Abilities.DELTA_STREAM) + turnOffWeather = true; + } + break; + case (WeatherType.STRONG_WINDS): + if (pokemon.hasAbility(Abilities.DELTA_STREAM) && pokemon.scene.getField(true).filter(p => p.hasAbility(Abilities.DELTA_STREAM)).length === 0) { - turnOffWeather = true; - } - break; + turnOffWeather = true; + } + break; } if (simulated) { @@ -4156,6 +4307,11 @@ export class RedirectTypeMoveAbAttr extends RedirectMoveAbAttr { export class BlockRedirectAbAttr extends AbAttr { } +/** + * Used by Early Bird, makes the pokemon wake up faster + * @param statusEffect - The {@linkcode StatusEffect} to check for + * @see {@linkcode apply} + */ export class ReduceStatusEffectDurationAbAttr extends AbAttr { private statusEffect: StatusEffect; @@ -4165,9 +4321,19 @@ export class ReduceStatusEffectDurationAbAttr extends AbAttr { this.statusEffect = statusEffect; } - apply(pokemon: Pokemon, passive: boolean, simulated: boolean, cancelled: Utils.BooleanHolder, args: any[]): boolean { + /** + * Reduces the number of sleep turns remaining by an extra 1 when applied + * @param args - The args passed to the `AbAttr`: + * - `[0]` - The {@linkcode StatusEffect} of the Pokemon + * - `[1]` - The number of turns remaining until the status is healed + * @returns `true` if the ability was applied + */ + apply(_pokemon: Pokemon, _passive: boolean, _simulated: boolean, _cancelled: Utils.BooleanHolder, args: any[]): boolean { + if (!(args[1] instanceof Utils.NumberHolder)) { + return false; + } if (args[0] === this.statusEffect) { - (args[1] as Utils.IntegerHolder).value = Utils.toDmgValue((args[1] as Utils.IntegerHolder).value / 2); + args[1].value -= 1; return true; } @@ -4228,6 +4394,10 @@ export class ReduceBerryUseThresholdAbAttr extends AbAttr { } } +/** + * Ability attribute used for abilites that change the ability owner's weight + * Used for Heavy Metal (doubling weight) and Light Metal (halving weight) + */ export class WeightMultiplierAbAttr extends AbAttr { private multiplier: integer; @@ -4294,6 +4464,30 @@ export class AlwaysHitAbAttr extends AbAttr { } /** Attribute for abilities that allow moves that make contact to ignore protection (i.e. Unseen Fist) */ export class IgnoreProtectOnContactAbAttr extends AbAttr { } +/** + * Attribute implementing the effects of {@link https://bulbapedia.bulbagarden.net/wiki/Infiltrator_(Ability) | Infiltrator}. + * Allows the source's moves to bypass the effects of opposing Light Screen, Reflect, Aurora Veil, Safeguard, Mist, and Substitute. + */ +export class InfiltratorAbAttr extends AbAttr { + /** + * Sets a flag to bypass screens, Substitute, Safeguard, and Mist + * @param pokemon n/a + * @param passive n/a + * @param simulated n/a + * @param cancelled n/a + * @param args `[0]` a {@linkcode Utils.BooleanHolder | BooleanHolder} containing the flag + * @returns `true` if the bypass flag was successfully set; `false` otherwise. + */ + override apply(pokemon: Pokemon, passive: boolean, simulated: boolean, cancelled: null, args: any[]): boolean { + const bypassed = args[0]; + if (args[0] instanceof Utils.BooleanHolder) { + bypassed.value = true; + return true; + } + return false; + } +} + export class UncopiableAbilityAbAttr extends AbAttr { constructor() { super(false); @@ -4444,7 +4638,7 @@ export class PostSummonStatStageChangeOnArenaAbAttr extends PostSummonStatStageC export class FormBlockDamageAbAttr extends ReceivedMoveDamageMultiplierAbAttr { private multiplier: number; private tagType: BattlerTagType; - private recoilDamageFunc: ((pokemon: Pokemon) => number) | undefined; + private recoilDamageFunc?: ((pokemon: Pokemon) => number); private triggerMessageFunc: (pokemon: Pokemon, abilityName: string) => string; constructor(condition: PokemonDefendCondition, multiplier: number, tagType: BattlerTagType, triggerMessageFunc: (pokemon: Pokemon, abilityName: string) => string, recoilDamageFunc?: (pokemon: Pokemon) => number) { @@ -4460,16 +4654,16 @@ export class FormBlockDamageAbAttr extends ReceivedMoveDamageMultiplierAbAttr { * Applies the pre-defense ability to the Pokémon. * Removes the appropriate `BattlerTagType` when hit by an attack and is in its defense form. * - * @param {Pokemon} pokemon The Pokémon with the ability. - * @param {boolean} passive n/a - * @param {Pokemon} attacker The attacking Pokémon. - * @param {PokemonMove} move The move being used. - * @param {Utils.BooleanHolder} cancelled n/a - * @param {any[]} args Additional arguments. - * @returns {boolean} Whether the immunity was applied. + * @param pokemon The Pokémon with the ability. + * @param _passive n/a + * @param attacker The attacking Pokémon. + * @param move The move being used. + * @param _cancelled n/a + * @param args Additional arguments. + * @returns `true` if the immunity was applied. */ - applyPreDefend(pokemon: Pokemon, passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, cancelled: Utils.BooleanHolder, args: any[]): boolean { - if (this.condition(pokemon, attacker, move)) { + override applyPreDefend(pokemon: Pokemon, _passive: boolean, simulated: boolean, attacker: Pokemon, move: Move, _cancelled: Utils.BooleanHolder, args: any[]): boolean { + if (this.condition(pokemon, attacker, move) && !move.hitsSubstitute(attacker, pokemon)) { if (!simulated) { (args[0] as Utils.NumberHolder).value = this.multiplier; pokemon.removeTag(this.tagType); @@ -4485,12 +4679,12 @@ export class FormBlockDamageAbAttr extends ReceivedMoveDamageMultiplierAbAttr { /** * Gets the message triggered when the Pokémon avoids damage using the form-changing ability. - * @param {Pokemon} pokemon The Pokémon with the ability. - * @param {string} abilityName The name of the ability. - * @param {...any} args n/a - * @returns {string} The trigger message. + * @param pokemon The Pokémon with the ability. + * @param abilityName The name of the ability. + * @param _args n/a + * @returns The trigger message. */ - getTriggerMessage(pokemon: Pokemon, abilityName: string, ...args: any[]): string { + getTriggerMessage(pokemon: Pokemon, abilityName: string, ..._args: any[]): string { return this.triggerMessageFunc(pokemon, abilityName); } } @@ -4529,7 +4723,7 @@ export class BypassSpeedChanceAbAttr extends AbAttr { const turnCommand = pokemon.scene.currentBattle.turnCommands[pokemon.getBattlerIndex()]; const isCommandFight = turnCommand?.command === Command.FIGHT; - const move = turnCommand?.move?.move ?allMoves[turnCommand.move.move] : null; + const move = turnCommand?.move?.move ? allMoves[turnCommand.move.move] : null; const isDamageMove = move?.category === MoveCategory.PHYSICAL || move?.category === MoveCategory.SPECIAL; if (isCommandFight && isDamageMove) { @@ -4542,7 +4736,7 @@ export class BypassSpeedChanceAbAttr extends AbAttr { } getTriggerMessage(pokemon: Pokemon, abilityName: string, ...args: any[]): string { - return i18next.t("abilityTriggers:quickDraw", {pokemonName: getPokemonNameWithAffix(pokemon)}); + return i18next.t("abilityTriggers:quickDraw", { pokemonName: getPokemonNameWithAffix(pokemon) }); } } @@ -4581,6 +4775,84 @@ export class PreventBypassSpeedChanceAbAttr extends AbAttr { } } +/** + * This applies a terrain-based type change to the Pokemon. + * Used by Mimicry. + */ +export class TerrainEventTypeChangeAbAttr extends PostSummonAbAttr { + constructor() { + super(true); + } + + override apply(pokemon: Pokemon, _passive: boolean, _simulated: boolean, _cancelled: Utils.BooleanHolder, _args: any[]): boolean { + if (pokemon.isTerastallized()) { + return false; + } + const currentTerrain = pokemon.scene.arena.getTerrainType(); + const typeChange: Type[] = this.determineTypeChange(pokemon, currentTerrain); + if (typeChange.length !== 0) { + if (pokemon.summonData.addedType && typeChange.includes(pokemon.summonData.addedType)) { + pokemon.summonData.addedType = null; + } + pokemon.summonData.types = typeChange; + pokemon.updateInfo(); + } + return true; + } + + /** + * Retrieves the type(s) the Pokemon should change to in response to a terrain + * @param pokemon + * @param currentTerrain {@linkcode TerrainType} + * @returns a list of type(s) + */ + private determineTypeChange(pokemon: Pokemon, currentTerrain: TerrainType): Type[] { + const typeChange: Type[] = []; + switch (currentTerrain) { + case TerrainType.ELECTRIC: + typeChange.push(Type.ELECTRIC); + break; + case TerrainType.MISTY: + typeChange.push(Type.FAIRY); + break; + case TerrainType.GRASSY: + typeChange.push(Type.GRASS); + break; + case TerrainType.PSYCHIC: + typeChange.push(Type.PSYCHIC); + break; + default: + pokemon.getTypes(false, false, true).forEach(t => { + typeChange.push(t); + }); + break; + } + return typeChange; + } + + /** + * Checks if the Pokemon should change types if summoned into an active terrain + * @returns `true` if there is an active terrain requiring a type change | `false` if not + */ + override applyPostSummon(pokemon: Pokemon, passive: boolean, simulated: boolean, args: any[]): boolean | Promise { + if (pokemon.scene.arena.getTerrainType() !== TerrainType.NONE) { + return this.apply(pokemon, passive, simulated, new Utils.BooleanHolder(false), []); + } + return false; + } + + override getTriggerMessage(pokemon: Pokemon, abilityName: string, ...args: any[]) { + const currentTerrain = pokemon.scene.arena.getTerrainType(); + const pokemonNameWithAffix = getPokemonNameWithAffix(pokemon); + if (currentTerrain === TerrainType.NONE) { + return i18next.t("abilityTriggers:pokemonTypeChangeRevert", { pokemonNameWithAffix }); + } else { + const moveType = i18next.t(`pokemonInfo:Type.${Type[this.determineTypeChange(pokemon, currentTerrain)[0]]}`); + return i18next.t("abilityTriggers:pokemonTypeChange", { pokemonNameWithAffix, moveType }); + } + } +} + async function applyAbAttrsInternal( attrType: Constructor, pokemon: Pokemon | null, @@ -4590,8 +4862,8 @@ async function applyAbAttrsInternal( simulated: boolean = false, messages: string[] = [], ) { - for (const passive of [false, true]) { - if (!pokemon?.canApplyAbility(passive)) { + for (const passive of [ false, true ]) { + if (!pokemon?.canApplyAbility(passive) || (passive && pokemon.getPassiveAbility().id === pokemon.getAbility().id)) { continue; } @@ -4636,6 +4908,240 @@ async function applyAbAttrsInternal( } } +class ForceSwitchOutHelper { + constructor(private switchType: SwitchType) {} + + /** + * Handles the logic for switching out a Pokémon based on battle conditions, HP, and the switch type. + * + * @param pokemon The {@linkcode Pokemon} attempting to switch out. + * @returns `true` if the switch is successful + */ + public switchOutLogic(pokemon: Pokemon): boolean { + const switchOutTarget = pokemon; + /** + * If the switch-out target is a player-controlled Pokémon, the function checks: + * - Whether there are available party members to switch in. + * - If the Pokémon is still alive (hp > 0), and if so, it leaves the field and a new SwitchPhase is initiated. + */ + if (switchOutTarget instanceof PlayerPokemon) { + if (switchOutTarget.scene.getPlayerParty().filter((p) => p.isAllowedInBattle() && !p.isOnField()).length < 1) { + return false; + } + + if (switchOutTarget.hp > 0) { + switchOutTarget.leaveField(this.switchType === SwitchType.SWITCH); + pokemon.scene.prependToPhase(new SwitchPhase(pokemon.scene, this.switchType, switchOutTarget.getFieldIndex(), true, true), MoveEndPhase); + return true; + } + /** + * For non-wild battles, it checks if the opposing party has any available Pokémon to switch in. + * If yes, the Pokémon leaves the field and a new SwitchSummonPhase is initiated. + */ + } else if (pokemon.scene.currentBattle.battleType !== BattleType.WILD) { + if (switchOutTarget.scene.getEnemyParty().filter((p) => p.isAllowedInBattle() && !p.isOnField()).length < 1) { + return false; + } + if (switchOutTarget.hp > 0) { + switchOutTarget.leaveField(this.switchType === SwitchType.SWITCH); + pokemon.scene.prependToPhase(new SwitchSummonPhase(pokemon.scene, this.switchType, switchOutTarget.getFieldIndex(), + (pokemon.scene.currentBattle.trainer ? pokemon.scene.currentBattle.trainer.getNextSummonIndex((switchOutTarget as EnemyPokemon).trainerSlot) : 0), + false, false), MoveEndPhase); + return true; + } + /** + * For wild Pokémon battles, the Pokémon will flee if the conditions are met (waveIndex and double battles). + * It will not flee if it is a Mystery Encounter with fleeing disabled (checked in `getSwitchOutCondition()`) or if it is a wave 10x wild boss + */ + } else { + if (!pokemon.scene.currentBattle.waveIndex || pokemon.scene.currentBattle.waveIndex % 10 === 0) { + return false; + } + + if (switchOutTarget.hp > 0) { + switchOutTarget.leaveField(false); + pokemon.scene.queueMessage(i18next.t("moveTriggers:fled", { pokemonName: getPokemonNameWithAffix(switchOutTarget) }), null, true, 500); + + if (switchOutTarget.scene.currentBattle.double) { + const allyPokemon = switchOutTarget.getAlly(); + switchOutTarget.scene.redirectPokemonMoves(switchOutTarget, allyPokemon); + } + } + + if (!switchOutTarget.getAlly()?.isActive(true)) { + pokemon.scene.clearEnemyHeldItemModifiers(); + + if (switchOutTarget.hp) { + pokemon.scene.pushPhase(new BattleEndPhase(pokemon.scene)); + pokemon.scene.pushPhase(new NewBattlePhase(pokemon.scene)); + } + } + } + return false; + } + + /** + * Determines if a Pokémon can switch out based on its status, the opponent's status, and battle conditions. + * + * @param pokemon The Pokémon attempting to switch out. + * @param opponent The opponent Pokémon. + * @returns `true` if the switch-out condition is met + */ + public getSwitchOutCondition(pokemon: Pokemon, opponent: Pokemon): boolean { + const switchOutTarget = pokemon; + const player = switchOutTarget instanceof PlayerPokemon; + + if (player) { + const blockedByAbility = new Utils.BooleanHolder(false); + applyAbAttrs(ForceSwitchOutImmunityAbAttr, opponent, blockedByAbility); + return !blockedByAbility.value; + } + + if (!player && pokemon.scene.currentBattle.battleType === BattleType.WILD) { + if (!pokemon.scene.currentBattle.waveIndex && pokemon.scene.currentBattle.waveIndex % 10 === 0) { + return false; + } + } + + if (!player && pokemon.scene.currentBattle.isBattleMysteryEncounter() && !pokemon.scene.currentBattle.mysteryEncounter?.fleeAllowed) { + return false; + } + + const party = player ? pokemon.scene.getPlayerParty() : pokemon.scene.getEnemyParty(); + return (!player && pokemon.scene.currentBattle.battleType === BattleType.WILD) + || party.filter(p => p.isAllowedInBattle() + && (player || (p as EnemyPokemon).trainerSlot === (switchOutTarget as EnemyPokemon).trainerSlot)).length > pokemon.scene.currentBattle.getBattlerCount(); + } + + /** + * Returns a message if the switch-out attempt fails due to ability effects. + * + * @param target The target Pokémon. + * @returns The failure message, or `null` if no failure. + */ + public getFailedText(target: Pokemon): string | null { + const blockedByAbility = new Utils.BooleanHolder(false); + applyAbAttrs(ForceSwitchOutImmunityAbAttr, target, blockedByAbility); + return blockedByAbility.value ? i18next.t("moveTriggers:cannotBeSwitchedOut", { pokemonName: getPokemonNameWithAffix(target) }) : null; + } +} + +/** + * Calculates the amount of recovery from the Shell Bell item. + * + * If the Pokémon is holding a Shell Bell, this function computes the amount of health + * recovered based on the damage dealt in the current turn. The recovery is multiplied by the + * Shell Bell's modifier (if any). + * + * @param pokemon - The Pokémon whose Shell Bell recovery is being calculated. + * @returns The amount of health recovered by Shell Bell. + */ +function calculateShellBellRecovery(pokemon: Pokemon): number { + const shellBellModifier = pokemon.getHeldItems().find(m => m instanceof HitHealModifier); + if (shellBellModifier) { + return Utils.toDmgValue(pokemon.turnData.totalDamageDealt / 8) * shellBellModifier.stackCount; + } + return 0; +} + +/** + * Triggers after the Pokemon takes any damage + * @extends AbAttr + */ +export class PostDamageAbAttr extends AbAttr { + public applyPostDamage(pokemon: Pokemon, damage: number, passive: boolean, simulated: boolean, args: any[], source?: Pokemon): boolean | Promise { + return false; + } +} + +/** + * Ability attribute for forcing a Pokémon to switch out after its health drops below half. + * This attribute checks various conditions related to the damage received, the moves used by the Pokémon + * and its opponents, and determines whether a forced switch-out should occur. + * + * Used by Wimp Out and Emergency Exit + * + * @extends PostDamageAbAttr + * @see {@linkcode applyPostDamage} + */ +export class PostDamageForceSwitchAbAttr extends PostDamageAbAttr { + private helper: ForceSwitchOutHelper = new ForceSwitchOutHelper(SwitchType.SWITCH); + private hpRatio: number; + + constructor(hpRatio: number = 0.5) { + super(); + this.hpRatio = hpRatio; + } + + /** + * Applies the switch-out logic after the Pokémon takes damage. + * Checks various conditions based on the moves used by the Pokémon, the opponents' moves, and + * the Pokémon's health after damage to determine whether the switch-out should occur. + * + * @param pokemon The Pokémon that took damage. + * @param damage The amount of damage taken by the Pokémon. + * @param passive N/A + * @param simulated Whether the ability is being simulated. + * @param args N/A + * @param source The Pokemon that dealt damage + * @returns `true` if the switch-out logic was successfully applied + */ + public override applyPostDamage(pokemon: Pokemon, damage: number, passive: boolean, simulated: boolean, args: any[], source?: Pokemon): boolean | Promise { + const moveHistory = pokemon.getMoveHistory(); + // Will not activate when the Pokémon's HP is lowered by cutting its own HP + const fordbiddenAttackingMoves = [ Moves.BELLY_DRUM, Moves.SUBSTITUTE, Moves.CURSE, Moves.PAIN_SPLIT ]; + if (moveHistory.length > 0) { + const lastMoveUsed = moveHistory[moveHistory.length - 1]; + if (fordbiddenAttackingMoves.includes(lastMoveUsed.move)) { + return false; + } + } + + // Dragon Tail and Circle Throw switch out Pokémon before the Ability activates. + const fordbiddenDefendingMoves = [ Moves.DRAGON_TAIL, Moves.CIRCLE_THROW ]; + if (source) { + const enemyMoveHistory = source.getMoveHistory(); + if (enemyMoveHistory.length > 0) { + const enemyLastMoveUsed = enemyMoveHistory[enemyMoveHistory.length - 1]; + // Will not activate if the Pokémon's HP falls below half while it is in the air during Sky Drop. + if (fordbiddenDefendingMoves.includes(enemyLastMoveUsed.move) || enemyLastMoveUsed.move === Moves.SKY_DROP && enemyLastMoveUsed.result === MoveResult.OTHER) { + return false; + // Will not activate if the Pokémon's HP falls below half by a move affected by Sheer Force. + } else if (allMoves[enemyLastMoveUsed.move].chance >= 0 && source.hasAbility(Abilities.SHEER_FORCE)) { + return false; + // Activate only after the last hit of multistrike moves + } else if (source.turnData.hitsLeft > 1) { + return false; + } + if (source.turnData.hitCount > 1) { + damage = pokemon.turnData.damageTaken; + } + } + } + + if (pokemon.hp + damage >= pokemon.getMaxHp() * this.hpRatio) { + // Activates if it falls below half and recovers back above half from a Shell Bell + const shellBellHeal = calculateShellBellRecovery(pokemon); + if (pokemon.hp - shellBellHeal < pokemon.getMaxHp() * this.hpRatio) { + for (const opponent of pokemon.getOpponents()) { + if (!this.helper.getSwitchOutCondition(pokemon, opponent)) { + return false; + } + } + return this.helper.switchOutLogic(pokemon); + } else { + return false; + } + } else { + return false; + } + } + public getFailedText(user: Pokemon, target: Pokemon, move: Move, cancelled: Utils.BooleanHolder): string | null { + return this.helper.getFailedText(target); + } +} + + export function applyAbAttrs(attrType: Constructor, pokemon: Pokemon, cancelled: Utils.BooleanHolder | null, simulated: boolean = false, ...args: any[]): Promise { return applyAbAttrsInternal(attrType, pokemon, (attr, passive) => attr.apply(pokemon, passive, simulated, cancelled, args), args, false, simulated); } @@ -4664,6 +5170,15 @@ export function applyStatMultiplierAbAttrs(attrType: Constructor { return applyAbAttrsInternal(attrType, pokemon, (attr, passive) => attr.applyStatStage(pokemon, passive, simulated, stat, statValue, args), args); } +export function applyPostSetStatusAbAttrs(attrType: Constructor, + pokemon: Pokemon, effect: StatusEffect, sourcePokemon?: Pokemon | null, simulated: boolean = false, ...args: any[]): Promise { + return applyAbAttrsInternal(attrType, pokemon, (attr, passive) => attr.applyPostSetStatus(pokemon, sourcePokemon, passive, effect, simulated, args), args, false, simulated); +} + +export function applyPostDamageAbAttrs(attrType: Constructor, + pokemon: Pokemon, damage: number, passive: boolean, simulated: boolean = false, args: any[], source?: Pokemon): Promise { + return applyAbAttrsInternal(attrType, pokemon, (attr, passive) => attr.applyPostDamage(pokemon, damage, passive, simulated, args, source), args); +} /** * Applies a field Stat multiplier attribute @@ -4770,6 +5285,11 @@ export function applyPostFaintAbAttrs(attrType: Constructor, return applyAbAttrsInternal(attrType, pokemon, (attr, passive) => attr.applyPostFaint(pokemon, passive, simulated, attacker, move, hitResult, args), args, false, simulated); } +export function applyPostItemLostAbAttrs(attrType: Constructor, + pokemon: Pokemon, simulated: boolean = false, ...args: any[]): Promise { + return applyAbAttrsInternal(attrType, pokemon, (attr, passive) => attr.applyPostItemLost(pokemon, simulated, args), args); +} + function queueShowAbility(pokemon: Pokemon, passive: boolean): void { pokemon.scene.unshiftPhase(new ShowAbilityPhase(pokemon.scene, pokemon.id, passive)); pokemon.scene.clearPhaseQueueSplice(); @@ -4807,7 +5327,7 @@ export function initAbilities() { .attr(PostSummonWeatherChangeAbAttr, WeatherType.RAIN) .attr(PostBiomeChangeWeatherChangeAbAttr, WeatherType.RAIN), new Ability(Abilities.SPEED_BOOST, 3) - .attr(PostTurnStatStageChangeAbAttr, [ Stat.SPD ], 1), + .attr(SpeedBoostAbAttr), new Ability(Abilities.BATTLE_ARMOR, 3) .attr(BlockCritAbAttr) .ignorable(), @@ -4831,14 +5351,12 @@ export function initAbilities() { .bypassFaint(), new Ability(Abilities.VOLT_ABSORB, 3) .attr(TypeImmunityHealAbAttr, Type.ELECTRIC) - .partial() // Healing not blocked by Heal Block .ignorable(), new Ability(Abilities.WATER_ABSORB, 3) .attr(TypeImmunityHealAbAttr, Type.WATER) - .partial() // Healing not blocked by Heal Block .ignorable(), new Ability(Abilities.OBLIVIOUS, 3) - .attr(BattlerTagImmunityAbAttr, BattlerTagType.INFATUATED) + .attr(BattlerTagImmunityAbAttr, [ BattlerTagType.INFATUATED, BattlerTagType.TAUNT ]) .attr(IntimidateImmunityAbAttr) .ignorable(), new Ability(Abilities.CLOUD_NINE, 3) @@ -4864,7 +5382,7 @@ export function initAbilities() { .ignorable(), new Ability(Abilities.SHIELD_DUST, 3) .attr(IgnoreMoveEffectsAbAttr) - .partial(), + .ignorable(), new Ability(Abilities.OWN_TEMPO, 3) .attr(BattlerTagImmunityAbAttr, BattlerTagType.CONFUSED) .attr(IntimidateImmunityAbAttr) @@ -4896,7 +5414,7 @@ export function initAbilities() { .attr(EffectSporeAbAttr), new Ability(Abilities.SYNCHRONIZE, 3) .attr(SyncEncounterNatureAbAttr) - .unimplemented(), + .attr(SynchronizeStatusAbAttr), new Ability(Abilities.CLEAR_BODY, 3) .attr(ProtectStatAbAttr) .ignorable(), @@ -4907,8 +5425,7 @@ export function initAbilities() { .attr(TypeImmunityStatStageChangeAbAttr, Type.ELECTRIC, Stat.SPATK, 1) .ignorable(), new Ability(Abilities.SERENE_GRACE, 3) - .attr(MoveEffectChanceMultiplierAbAttr, 2) - .partial(), + .attr(MoveEffectChanceMultiplierAbAttr, 2), new Ability(Abilities.SWIFT_SWIM, 3) .attr(StatMultiplierAbAttr, Stat.SPD, 2) .condition(getWeatherCondition(WeatherType.RAIN, WeatherType.HEAVY_RAIN)), @@ -4918,6 +5435,7 @@ export function initAbilities() { new Ability(Abilities.ILLUMINATE, 3) .attr(ProtectStatAbAttr, Stat.ACC) .attr(DoubleBattleChanceAbAttr) + .attr(IgnoreOpponentStatStagesAbAttr, [ Stat.EVA ]) .ignorable(), new Ability(Abilities.TRACE, 3) .attr(PostSummonCopyAbilityAbAttr) @@ -4948,8 +5466,7 @@ export function initAbilities() { .attr(MoveImmunityAbAttr, (pokemon, attacker, move) => pokemon !== attacker && move.hasFlag(MoveFlags.SOUND_BASED)) .ignorable(), new Ability(Abilities.RAIN_DISH, 3) - .attr(PostWeatherLapseHealAbAttr, 1, WeatherType.RAIN, WeatherType.HEAVY_RAIN) - .partial(), // Healing not blocked by Heal Block + .attr(PostWeatherLapseHealAbAttr, 1, WeatherType.RAIN, WeatherType.HEAVY_RAIN), new Ability(Abilities.SAND_STREAM, 3) .attr(PostSummonWeatherChangeAbAttr, WeatherType.SANDSTORM) .attr(PostBiomeChangeWeatherChangeAbAttr, WeatherType.SANDSTORM), @@ -4983,11 +5500,9 @@ export function initAbilities() { new Ability(Abilities.CUTE_CHARM, 3) .attr(PostDefendContactApplyTagChanceAbAttr, 30, BattlerTagType.INFATUATED), new Ability(Abilities.PLUS, 3) - .conditionalAttr(p => p.scene.currentBattle.double && [Abilities.PLUS, Abilities.MINUS].some(a => p.getAlly().hasAbility(a)), StatMultiplierAbAttr, Stat.SPATK, 1.5) - .ignorable(), + .conditionalAttr(p => p.scene.currentBattle.double && [ Abilities.PLUS, Abilities.MINUS ].some(a => p.getAlly().hasAbility(a)), StatMultiplierAbAttr, Stat.SPATK, 1.5), new Ability(Abilities.MINUS, 3) - .conditionalAttr(p => p.scene.currentBattle.double && [Abilities.PLUS, Abilities.MINUS].some(a => p.getAlly().hasAbility(a)), StatMultiplierAbAttr, Stat.SPATK, 1.5) - .ignorable(), + .conditionalAttr(p => p.scene.currentBattle.double && [ Abilities.PLUS, Abilities.MINUS ].some(a => p.getAlly().hasAbility(a)), StatMultiplierAbAttr, Stat.SPATK, 1.5), new Ability(Abilities.FORECAST, 3) .attr(UncopiableAbilityAbAttr) .attr(NoFusionAbilityAbAttr) @@ -5067,7 +5582,9 @@ export function initAbilities() { new Ability(Abilities.ANGER_POINT, 4) .attr(PostDefendCritStatStageChangeAbAttr, Stat.ATK, 6), new Ability(Abilities.UNBURDEN, 4) - .unimplemented(), + .attr(PostItemLostApplyBattlerTagAbAttr, BattlerTagType.UNBURDEN) + .bypassFaint() // Allows reviver seed to activate Unburden + .edgeCase(), // Should not restore Unburden boost if Pokemon loses then regains Unburden ability new Ability(Abilities.HEATPROOF, 4) .attr(ReceivedTypeDamageMultiplierAbAttr, Type.FIRE, 0.5) .attr(ReduceBurnDamageAbAttr, 0.5) @@ -5080,7 +5597,6 @@ export function initAbilities() { .attr(PostWeatherLapseHealAbAttr, 2, WeatherType.RAIN, WeatherType.HEAVY_RAIN) .attr(ReceivedTypeDamageMultiplierAbAttr, Type.FIRE, 1.25) .attr(TypeImmunityHealAbAttr, Type.WATER) - .partial() // Healing not blocked by Heal Block .ignorable(), new Ability(Abilities.DOWNLOAD, 4) .attr(DownloadAbAttr), @@ -5105,7 +5621,7 @@ export function initAbilities() { .conditionalAttr(pokemon => !!pokemon.status || pokemon.hasAbility(Abilities.COMATOSE), StatMultiplierAbAttr, Stat.SPD, 1.5), new Ability(Abilities.NORMALIZE, 4) .attr(MoveTypeChangeAbAttr, Type.NORMAL, 1.2, (user, target, move) => { - return ![Moves.HIDDEN_POWER, Moves.WEATHER_BALL, Moves.NATURAL_GIFT, Moves.JUDGMENT, Moves.TECHNO_BLAST].includes(move.id); + return ![ Moves.HIDDEN_POWER, Moves.WEATHER_BALL, Moves.NATURAL_GIFT, Moves.JUDGMENT, Moves.TECHNO_BLAST ].includes(move.id); }), new Ability(Abilities.SNIPER, 4) .attr(MultCritAbAttr, 1.5), @@ -5132,8 +5648,7 @@ export function initAbilities() { .attr(PostSummonMessageAbAttr, (pokemon: Pokemon) => i18next.t("abilityTriggers:postSummonMoldBreaker", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) })) .attr(MoveAbilityBypassAbAttr), new Ability(Abilities.SUPER_LUCK, 4) - .attr(BonusCritAbAttr) - .partial(), + .attr(BonusCritAbAttr), new Ability(Abilities.AFTERMATH, 4) .attr(PostFaintContactDamageAbAttr, 4) .bypassFaint(), @@ -5142,18 +5657,17 @@ export function initAbilities() { new Ability(Abilities.FOREWARN, 4) .attr(ForewarnAbAttr), new Ability(Abilities.UNAWARE, 4) - .attr(IgnoreOpponentStatStagesAbAttr) + .attr(IgnoreOpponentStatStagesAbAttr, [ Stat.ATK, Stat.DEF, Stat.SPATK, Stat.SPDEF, Stat.ACC, Stat.EVA ]) .ignorable(), new Ability(Abilities.TINTED_LENS, 4) - //@ts-ignore - .attr(DamageBoostAbAttr, 2, (user, target, move) => target?.getMoveEffectiveness(user, move) <= 0.5), // TODO: fix TS issues + .attr(DamageBoostAbAttr, 2, (user, target, move) => (target?.getMoveEffectiveness(user!, move) ?? 1) <= 0.5), new Ability(Abilities.FILTER, 4) .attr(ReceivedMoveDamageMultiplierAbAttr, (target, user, move) => target.getMoveEffectiveness(user, move) >= 2, 0.75) .ignorable(), new Ability(Abilities.SLOW_START, 4) .attr(PostSummonAddBattlerTagAbAttr, BattlerTagType.SLOW_START, 5), new Ability(Abilities.SCRAPPY, 4) - .attr(IgnoreTypeImmunityAbAttr, Type.GHOST, [Type.NORMAL, Type.FIGHTING]) + .attr(IgnoreTypeImmunityAbAttr, Type.GHOST, [ Type.NORMAL, Type.FIGHTING ]) .attr(IntimidateImmunityAbAttr), new Ability(Abilities.STORM_DRAIN, 4) .attr(RedirectTypeMoveAbAttr, Type.WATER) @@ -5161,8 +5675,7 @@ export function initAbilities() { .ignorable(), new Ability(Abilities.ICE_BODY, 4) .attr(BlockWeatherDamageAttr, WeatherType.HAIL) - .attr(PostWeatherLapseHealAbAttr, 1, WeatherType.HAIL, WeatherType.SNOW) - .partial(), // Healing not blocked by Heal Block + .attr(PostWeatherLapseHealAbAttr, 1, WeatherType.HAIL, WeatherType.SNOW), new Ability(Abilities.SOLID_ROCK, 4) .attr(ReceivedMoveDamageMultiplierAbAttr, (target, user, move) => target.getMoveEffectiveness(user, move) >= 2, 0.75) .ignorable(), @@ -5195,16 +5708,17 @@ export function initAbilities() { .attr(PostDefendStealHeldItemAbAttr, (target, user, move) => move.hasFlag(MoveFlags.MAKES_CONTACT)) .condition(getSheerForceHitDisableAbCondition()), new Ability(Abilities.SHEER_FORCE, 5) - .attr(MovePowerBoostAbAttr, (user, target, move) => move.chance >= 1, 5461/4096) + .attr(MovePowerBoostAbAttr, (user, target, move) => move.chance >= 1, 5461 / 4096) .attr(MoveEffectChanceMultiplierAbAttr, 0) - .partial(), + .edgeCase() // Should disable shell bell and Meloetta's relic song transformation + .edgeCase(), // Should disable life orb, eject button, red card, kee/maranga berry if they get implemented new Ability(Abilities.CONTRARY, 5) .attr(StatStageChangeMultiplierAbAttr, -1) .ignorable(), new Ability(Abilities.UNNERVE, 5) .attr(PreventBerryUseAbAttr), new Ability(Abilities.DEFIANT, 5) - .attr(PostStatStageChangeStatStageChangeAbAttr, (target, statsChanged, stages) => stages < 0, [Stat.ATK], 2), + .attr(PostStatStageChangeStatStageChangeAbAttr, (target, statsChanged, stages) => stages < 0, [ Stat.ATK ], 2), new Ability(Abilities.DEFEATIST, 5) .attr(StatMultiplierAbAttr, Stat.ATK, 0.5) .attr(StatMultiplierAbAttr, Stat.SPATK, 0.5) @@ -5215,8 +5729,8 @@ export function initAbilities() { new Ability(Abilities.HEALER, 5) .conditionalAttr(pokemon => pokemon.getAlly() && Utils.randSeedInt(10) < 3, PostTurnResetStatusAbAttr, true), new Ability(Abilities.FRIEND_GUARD, 5) - .ignorable() - .unimplemented(), + .attr(AlliedFieldDamageReductionAbAttr, 0.75) + .ignorable(), new Ability(Abilities.WEAK_ARMOR, 5) .attr(PostDefendStatStageChangeAbAttr, (target, user, move) => move.category === MoveCategory.PHYSICAL, Stat.DEF, -1) .attr(PostDefendStatStageChangeAbAttr, (target, user, move) => move.category === MoveCategory.PHYSICAL, Stat.SPD, 2), @@ -5240,7 +5754,7 @@ export function initAbilities() { /** Rate is doubled when under sun {@link https://dex.pokemonshowdown.com/abilities/harvest} */ (pokemon) => 0.5 * (getWeatherCondition(WeatherType.SUNNY, WeatherType.HARSH_SUN)(pokemon) ? 2 : 1) ) - .partial(), + .edgeCase(), // Cannot recover berries used up by fling or natural gift (unimplemented) new Ability(Abilities.TELEPATHY, 5) .attr(MoveImmunityAbAttr, (pokemon, attacker, move) => pokemon.getAlly() === attacker && move instanceof AttackMove) .ignorable(), @@ -5265,8 +5779,9 @@ export function initAbilities() { .attr(WonderSkinAbAttr) .ignorable(), new Ability(Abilities.ANALYTIC, 5) - //@ts-ignore - .attr(MovePowerBoostAbAttr, (user, target, move) => !!target?.getLastXMoves(1).find(m => m.turn === target?.scene.currentBattle.turn) || user.scene.currentBattle.turnCommands[target.getBattlerIndex()].command !== Command.FIGHT, 1.3), // TODO fix TS issues + .attr(MovePowerBoostAbAttr, (user, target, move) => + !!target?.getLastXMoves(1).find(m => m.turn === target?.scene.currentBattle.turn) + || user?.scene.currentBattle.turnCommands[target?.getBattlerIndex() ?? BattlerIndex.ATTACKER]?.command !== Command.FIGHT, 1.3), new Ability(Abilities.ILLUSION, 5) .attr(UncopiableAbilityAbAttr) .attr(UnswappableAbilityAbAttr) @@ -5275,7 +5790,8 @@ export function initAbilities() { .attr(PostSummonTransformAbAttr) .attr(UncopiableAbilityAbAttr), new Ability(Abilities.INFILTRATOR, 5) - .unimplemented(), + .attr(InfiltratorAbAttr) + .partial(), // does not bypass Mist new Ability(Abilities.MUMMY, 5) .attr(PostDefendAbilityGiveAbAttr, Abilities.MUMMY) .bypassFaint(), @@ -5289,7 +5805,7 @@ export function initAbilities() { return move.category !== MoveCategory.STATUS && (moveType === Type.DARK || moveType === Type.BUG || moveType === Type.GHOST); }, Stat.SPD, 1) - .attr(PostIntimidateStatStageChangeAbAttr, [Stat.SPD], 1), + .attr(PostIntimidateStatStageChangeAbAttr, [ Stat.SPD ], 1), new Ability(Abilities.MAGIC_BOUNCE, 5) .ignorable() .unimplemented(), @@ -5318,7 +5834,7 @@ export function initAbilities() { .bypassFaint(), new Ability(Abilities.VICTORY_STAR, 5) .attr(StatMultiplierAbAttr, Stat.ACC, 1.1) - .partial(), + .partial(), // Does not boost ally's accuracy new Ability(Abilities.TURBOBLAZE, 5) .attr(PostSummonMessageAbAttr, (pokemon: Pokemon) => i18next.t("abilityTriggers:postSummonTurboblaze", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) })) .attr(MoveAbilityBypassAbAttr), @@ -5326,14 +5842,13 @@ export function initAbilities() { .attr(PostSummonMessageAbAttr, (pokemon: Pokemon) => i18next.t("abilityTriggers:postSummonTeravolt", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) })) .attr(MoveAbilityBypassAbAttr), new Ability(Abilities.AROMA_VEIL, 6) - .ignorable() - .unimplemented(), + .attr(UserFieldBattlerTagImmunityAbAttr, [ BattlerTagType.INFATUATED, BattlerTagType.TAUNT, BattlerTagType.DISABLED, BattlerTagType.TORMENT, BattlerTagType.HEAL_BLOCK ]) + .ignorable(), new Ability(Abilities.FLOWER_VEIL, 6) .ignorable() .unimplemented(), new Ability(Abilities.CHEEK_POUCH, 6) - .attr(HealFromBerryUseAbAttr, 1/3) - .partial(), // Healing not blocked by Heal Block + .attr(HealFromBerryUseAbAttr, 1 / 3), new Ability(Abilities.PROTEAN, 6) .attr(PokemonTypeChangeAbAttr), //.condition((p) => !p.summonData?.abilitiesApplied.includes(Abilities.PROTEAN)), //Gen 9 Implementation @@ -5346,7 +5861,7 @@ export function initAbilities() { .attr(MoveImmunityAbAttr, (pokemon, attacker, move) => pokemon !== attacker && move.hasFlag(MoveFlags.BALLBOMB_MOVE)) .ignorable(), new Ability(Abilities.COMPETITIVE, 6) - .attr(PostStatStageChangeStatStageChangeAbAttr, (target, statsChanged, stages) => stages < 0, [Stat.SPATK], 2), + .attr(PostStatStageChangeStatStageChangeAbAttr, (target, statsChanged, stages) => stages < 0, [ Stat.SPATK ], 2), new Ability(Abilities.STRONG_JAW, 6) .attr(MovePowerBoostAbAttr, (user, target, move) => move.hasFlag(MoveFlags.BITING_MOVE), 1.5), new Ability(Abilities.REFRIGERATE, 6) @@ -5413,11 +5928,11 @@ export function initAbilities() { new Ability(Abilities.STAMINA, 7) .attr(PostDefendStatStageChangeAbAttr, (target, user, move) => move.category !== MoveCategory.STATUS, Stat.DEF, 1), new Ability(Abilities.WIMP_OUT, 7) - .condition(getSheerForceHitDisableAbCondition()) - .unimplemented(), + .attr(PostDamageForceSwitchAbAttr) + .edgeCase(), // Should not trigger when hurting itself in confusion new Ability(Abilities.EMERGENCY_EXIT, 7) - .condition(getSheerForceHitDisableAbCondition()) - .unimplemented(), + .attr(PostDamageForceSwitchAbAttr) + .edgeCase(), // Should not trigger when hurting itself in confusion new Ability(Abilities.WATER_COMPACTION, 7) .attr(PostDefendStatStageChangeAbAttr, (target, user, move) => user.getMoveType(move) === Type.WATER && move.category !== MoveCategory.STATUS, Stat.DEF, 2), new Ability(Abilities.MERCILESS, 7) @@ -5431,10 +5946,9 @@ export function initAbilities() { .attr(UnsuppressableAbilityAbAttr) .attr(NoFusionAbilityAbAttr) .bypassFaint() - .partial(), + .partial(), // Meteor form should protect against status effects and yawn new Ability(Abilities.STAKEOUT, 7) - //@ts-ignore - .attr(MovePowerBoostAbAttr, (user, target, move) => user.scene.currentBattle.turnCommands[target.getBattlerIndex()].command === Command.POKEMON, 2), // TODO: fix TS issues + .attr(MovePowerBoostAbAttr, (user, target, move) => user?.scene.currentBattle.turnCommands[target?.getBattlerIndex() ?? BattlerIndex.ATTACKER]?.command === Command.POKEMON, 2), new Ability(Abilities.WATER_BUBBLE, 7) .attr(ReceivedTypeDamageMultiplierAbAttr, Type.FIRE, 0.5) .attr(MoveTypePowerBoostAbAttr, Type.WATER, 2) @@ -5443,7 +5957,7 @@ export function initAbilities() { new Ability(Abilities.STEELWORKER, 7) .attr(MoveTypePowerBoostAbAttr, Type.STEEL), new Ability(Abilities.BERSERK, 7) - .attr(PostDefendHpGatedStatStageChangeAbAttr, (target, user, move) => move.category !== MoveCategory.STATUS, 0.5, [Stat.SPATK], 1) + .attr(PostDefendHpGatedStatStageChangeAbAttr, (target, user, move) => move.category !== MoveCategory.STATUS, 0.5, [ Stat.SPATK ], 1) .condition(getSheerForceHitDisableAbCondition()), new Ability(Abilities.SLUSH_RUSH, 7) .attr(StatMultiplierAbAttr, Stat.SPD, 2) @@ -5475,7 +5989,8 @@ export function initAbilities() { .attr(NoFusionAbilityAbAttr) // Add BattlerTagType.DISGUISE if the pokemon is in its disguised form .conditionalAttr(pokemon => pokemon.formIndex === 0, PostSummonAddBattlerTagAbAttr, BattlerTagType.DISGUISE, 0, false) - .attr(FormBlockDamageAbAttr, (target, user, move) => !!target.getTag(BattlerTagType.DISGUISE) && target.getMoveEffectiveness(user, move) > 0, 0, BattlerTagType.DISGUISE, + .attr(FormBlockDamageAbAttr, + (target, user, move) => !!target.getTag(BattlerTagType.DISGUISE) && target.getMoveEffectiveness(user, move) > 0, 0, BattlerTagType.DISGUISE, (pokemon, abilityName) => i18next.t("abilityTriggers:disguiseAvoidedDamage", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon), abilityName: abilityName }), (pokemon) => Utils.toDmgValue(pokemon.getMaxHp() / 8)) .attr(PostBattleInitFormChangeAbAttr, () => 0) @@ -5489,19 +6004,21 @@ export function initAbilities() { .attr(UnsuppressableAbilityAbAttr) .attr(NoFusionAbilityAbAttr) .bypassFaint(), - new Ability(Abilities.POWER_CONSTRUCT, 7) // TODO: 10% Power Construct Zygarde isn't accounted for yet. If changed, update Zygarde's getSpeciesFormIndex entry accordingly - .attr(PostBattleInitFormChangeAbAttr, () => 2) - .attr(PostSummonFormChangeAbAttr, p => p.getHpRatio() <= 0.5 || p.getFormKey() === "complete" ? 4 : 2) - .attr(PostTurnFormChangeAbAttr, p => p.getHpRatio() <= 0.5 || p.getFormKey() === "complete" ? 4 : 2) + new Ability(Abilities.POWER_CONSTRUCT, 7) + .conditionalAttr(pokemon => pokemon.formIndex === 2 || pokemon.formIndex === 4, PostBattleInitFormChangeAbAttr, () => 2) + .conditionalAttr(pokemon => pokemon.formIndex === 3 || pokemon.formIndex === 5, PostBattleInitFormChangeAbAttr, () => 3) + .conditionalAttr(pokemon => pokemon.formIndex === 2 || pokemon.formIndex === 4, PostSummonFormChangeAbAttr, p => p.getHpRatio() <= 0.5 || p.getFormKey() === "complete" ? 4 : 2) + .conditionalAttr(pokemon => pokemon.formIndex === 2 || pokemon.formIndex === 4, PostTurnFormChangeAbAttr, p => p.getHpRatio() <= 0.5 || p.getFormKey() === "complete" ? 4 : 2) + .conditionalAttr(pokemon => pokemon.formIndex === 3 || pokemon.formIndex === 5, PostSummonFormChangeAbAttr, p => p.getHpRatio() <= 0.5 || p.getFormKey() === "10-complete" ? 5 : 3) + .conditionalAttr(pokemon => pokemon.formIndex === 3 || pokemon.formIndex === 5, PostTurnFormChangeAbAttr, p => p.getHpRatio() <= 0.5 || p.getFormKey() === "10-complete" ? 5 : 3) .attr(UncopiableAbilityAbAttr) .attr(UnswappableAbilityAbAttr) .attr(UnsuppressableAbilityAbAttr) .attr(NoFusionAbilityAbAttr) - .bypassFaint() - .partial(), - new Ability(Abilities.CORROSION, 7) // TODO: Test Corrosion against Magic Bounce once it is implemented - .attr(IgnoreTypeStatusEffectImmunityAbAttr, [StatusEffect.POISON, StatusEffect.TOXIC], [Type.STEEL, Type.POISON]) - .partial(), + .bypassFaint(), + new Ability(Abilities.CORROSION, 7) + .attr(IgnoreTypeStatusEffectImmunityAbAttr, [ StatusEffect.POISON, StatusEffect.TOXIC ], [ Type.STEEL, Type.POISON ]) + .edgeCase(), // Should interact correctly with magic coat/bounce (not yet implemented) + fling with toxic orb (not implemented yet) new Ability(Abilities.COMATOSE, 7) .attr(UncopiableAbilityAbAttr) .attr(UnswappableAbilityAbAttr) @@ -5517,7 +6034,7 @@ export function initAbilities() { new Ability(Abilities.DANCER, 7) .attr(PostDancingMoveAbAttr), new Ability(Abilities.BATTERY, 7) - .attr(AllyMoveCategoryPowerBoostAbAttr, [MoveCategory.SPECIAL], 1.3), + .attr(AllyMoveCategoryPowerBoostAbAttr, [ MoveCategory.SPECIAL ], 1.3), new Ability(Abilities.FLUFFY, 7) .attr(ReceivedMoveDamageMultiplierAbAttr, (target, user, move) => move.hasFlag(MoveFlags.MAKES_CONTACT), 0.5) .attr(ReceivedMoveDamageMultiplierAbAttr, (target, user, move) => user.getMoveType(move) === Type.FIRE, 2) @@ -5572,8 +6089,7 @@ export function initAbilities() { new Ability(Abilities.PRISM_ARMOR, 7) .attr(ReceivedMoveDamageMultiplierAbAttr, (target, user, move) => target.getMoveEffectiveness(user, move) >= 2, 0.75), new Ability(Abilities.NEUROFORCE, 7) - //@ts-ignore - .attr(MovePowerBoostAbAttr, (user, target, move) => target?.getMoveEffectiveness(user, move) >= 2, 1.25), // TODO: fix TS issues + .attr(MovePowerBoostAbAttr, (user, target, move) => (target?.getMoveEffectiveness(user!, move) ?? 1) >= 2, 1.25), new Ability(Abilities.INTREPID_SWORD, 8) .attr(PostSummonStatStageChangeAbAttr, [ Stat.ATK ], 1, true) .condition(getOncePerBattleCondition(Abilities.INTREPID_SWORD)), @@ -5594,13 +6110,20 @@ export function initAbilities() { new Ability(Abilities.MIRROR_ARMOR, 8) .ignorable() .unimplemented(), + /** + * Right now, the logic is attached to Surf and Dive moves. Ideally, the post-defend/hit should be an + * ability attribute but the current implementation of move effects for BattlerTag does not support this- in the case + * where Cramorant is fainted. + * @see {@linkcode GulpMissileTagAttr} and {@linkcode GulpMissileTag} for Gulp Missile implementation + */ new Ability(Abilities.GULP_MISSILE, 8) .attr(UnsuppressableAbilityAbAttr) .attr(NoTransformAbilityAbAttr) .attr(NoFusionAbilityAbAttr) .attr(UncopiableAbilityAbAttr) .attr(UnswappableAbilityAbAttr) - .attr(PostDefendGulpMissileAbAttr), + .bypassFaint() + .edgeCase(), // Soft-locks the game if a form-changed Cramorant and its attacker both faint at the same time (ex. using Self-Destruct) new Ability(Abilities.STALWART, 8) .attr(BlockRedirectAbAttr), new Ability(Abilities.STEAM_ENGINE, 8) @@ -5632,17 +6155,18 @@ export function initAbilities() { .conditionalAttr(getWeatherCondition(WeatherType.HAIL, WeatherType.SNOW), PostSummonAddBattlerTagAbAttr, BattlerTagType.ICE_FACE, 0) // When weather changes to HAIL or SNOW while pokemon is fielded, add BattlerTagType.ICE_FACE .attr(PostWeatherChangeAddBattlerTagAttr, BattlerTagType.ICE_FACE, 0, WeatherType.HAIL, WeatherType.SNOW) - .attr(FormBlockDamageAbAttr, (target, user, move) => move.category === MoveCategory.PHYSICAL && !!target.getTag(BattlerTagType.ICE_FACE), 0, BattlerTagType.ICE_FACE, + .attr(FormBlockDamageAbAttr, + (target, user, move) => move.category === MoveCategory.PHYSICAL && !!target.getTag(BattlerTagType.ICE_FACE), 0, BattlerTagType.ICE_FACE, (pokemon, abilityName) => i18next.t("abilityTriggers:iceFaceAvoidedDamage", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon), abilityName: abilityName })) .attr(PostBattleInitFormChangeAbAttr, () => 0) .bypassFaint() .ignorable(), new Ability(Abilities.POWER_SPOT, 8) - .attr(AllyMoveCategoryPowerBoostAbAttr, [MoveCategory.SPECIAL, MoveCategory.PHYSICAL], 1.3), + .attr(AllyMoveCategoryPowerBoostAbAttr, [ MoveCategory.SPECIAL, MoveCategory.PHYSICAL ], 1.3), new Ability(Abilities.MIMICRY, 8) - .unimplemented(), + .attr(TerrainEventTypeChangeAbAttr), new Ability(Abilities.SCREEN_CLEANER, 8) - .attr(PostSummonRemoveArenaTagAbAttr, [ArenaTagType.AURORA_VEIL, ArenaTagType.LIGHT_SCREEN, ArenaTagType.REFLECT]), + .attr(PostSummonRemoveArenaTagAbAttr, [ ArenaTagType.AURORA_VEIL, ArenaTagType.LIGHT_SCREEN, ArenaTagType.REFLECT ]), new Ability(Abilities.STEELY_SPIRIT, 8) .attr(UserFieldMoveTypePowerBoostAbAttr, Type.STEEL), new Ability(Abilities.PERISH_BODY, 8) @@ -5650,7 +6174,7 @@ export function initAbilities() { new Ability(Abilities.WANDERING_SPIRIT, 8) .attr(PostDefendAbilitySwapAbAttr) .bypassFaint() - .partial(), + .edgeCase(), // interacts incorrectly with rock head. It's meant to switch abilities before recoil would apply so that a pokemon with rock head would lose rock head first and still take the recoil new Ability(Abilities.GORILLA_TACTICS, 8) .attr(GorillaTacticsAbAttr), new Ability(Abilities.NEUTRALIZING_GAS, 8) @@ -5659,16 +6183,14 @@ export function initAbilities() { .attr(UnswappableAbilityAbAttr) .attr(NoTransformAbilityAbAttr) .attr(PostSummonMessageAbAttr, (pokemon: Pokemon) => i18next.t("abilityTriggers:postSummonNeutralizingGas", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) })) - .partial(), + .partial(), // A bunch of weird interactions with other abilities being suppressed then unsuppressed new Ability(Abilities.PASTEL_VEIL, 8) .attr(PostSummonUserFieldRemoveStatusEffectAbAttr, StatusEffect.POISON, StatusEffect.TOXIC) .attr(UserFieldStatusEffectImmunityAbAttr, StatusEffect.POISON, StatusEffect.TOXIC) .ignorable(), new Ability(Abilities.HUNGER_SWITCH, 8) - //@ts-ignore - .attr(PostTurnFormChangeAbAttr, p => p.getFormKey ? 0 : 1) // TODO: fix ts-ignore - //@ts-ignore - .attr(PostTurnFormChangeAbAttr, p => p.getFormKey ? 1 : 0) // TODO: fix ts-ignore + .attr(PostTurnFormChangeAbAttr, p => p.getFormKey() ? 0 : 1) + .attr(PostTurnFormChangeAbAttr, p => p.getFormKey() ? 1 : 0) .attr(UncopiableAbilityAbAttr) .attr(UnswappableAbilityAbAttr) .attr(NoTransformAbilityAbAttr) @@ -5727,7 +6249,7 @@ export function initAbilities() { .attr(PostSummonStatStageChangeOnArenaAbAttr, ArenaTagType.TAILWIND) .ignorable(), new Ability(Abilities.GUARD_DOG, 9) - .attr(PostIntimidateStatStageChangeAbAttr, [Stat.ATK], 1, true) + .attr(PostIntimidateStatStageChangeAbAttr, [ Stat.ATK ], 1, true) .attr(ForceSwitchOutImmunityAbAttr) .ignorable(), new Ability(Abilities.ROCKY_PAYLOAD, 9) @@ -5744,9 +6266,11 @@ export function initAbilities() { .attr(PreSwitchOutFormChangeAbAttr, (pokemon) => !pokemon.isFainted() ? 1 : pokemon.formIndex) .bypassFaint(), new Ability(Abilities.COMMANDER, 9) + .attr(CommanderAbAttr) + .attr(DoubleBattleChanceAbAttr) .attr(UncopiableAbilityAbAttr) .attr(UnswappableAbilityAbAttr) - .unimplemented(), + .edgeCase(), // Encore, Frenzy, and other non-`TURN_END` tags don't lapse correctly on the commanding Pokemon. new Ability(Abilities.ELECTROMORPHOSIS, 9) .attr(PostDefendApplyBattlerTagAbAttr, (target, user, move) => move.category !== MoveCategory.STATUS, BattlerTagType.CHARGED), new Ability(Abilities.PROTOSYNTHESIS, 9) @@ -5766,23 +6290,21 @@ export function initAbilities() { new Ability(Abilities.GOOD_AS_GOLD, 9) .attr(MoveImmunityAbAttr, (pokemon, attacker, move) => pokemon !== attacker && move.category === MoveCategory.STATUS) .ignorable() - .partial(), + .partial(), // Lots of weird interactions with moves and abilities such as negating status moves that target the field new Ability(Abilities.VESSEL_OF_RUIN, 9) .attr(FieldMultiplyStatAbAttr, Stat.SPATK, 0.75) .attr(PostSummonMessageAbAttr, (user) => i18next.t("abilityTriggers:postSummonVesselOfRuin", { pokemonNameWithAffix: getPokemonNameWithAffix(user), statName: i18next.t(getStatKey(Stat.SPATK)) })) .ignorable(), new Ability(Abilities.SWORD_OF_RUIN, 9) .attr(FieldMultiplyStatAbAttr, Stat.DEF, 0.75) - .attr(PostSummonMessageAbAttr, (user) => i18next.t("abilityTriggers:postSummonSwordOfRuin", { pokemonNameWithAffix: getPokemonNameWithAffix(user), statName: i18next.t(getStatKey(Stat.DEF)) })) - .ignorable(), + .attr(PostSummonMessageAbAttr, (user) => i18next.t("abilityTriggers:postSummonSwordOfRuin", { pokemonNameWithAffix: getPokemonNameWithAffix(user), statName: i18next.t(getStatKey(Stat.DEF)) })), new Ability(Abilities.TABLETS_OF_RUIN, 9) .attr(FieldMultiplyStatAbAttr, Stat.ATK, 0.75) .attr(PostSummonMessageAbAttr, (user) => i18next.t("abilityTriggers:postSummonTabletsOfRuin", { pokemonNameWithAffix: getPokemonNameWithAffix(user), statName: i18next.t(getStatKey(Stat.ATK)) })) .ignorable(), new Ability(Abilities.BEADS_OF_RUIN, 9) .attr(FieldMultiplyStatAbAttr, Stat.SPDEF, 0.75) - .attr(PostSummonMessageAbAttr, (user) => i18next.t("abilityTriggers:postSummonBeadsOfRuin", { pokemonNameWithAffix: getPokemonNameWithAffix(user), statName: i18next.t(getStatKey(Stat.SPDEF)) })) - .ignorable(), + .attr(PostSummonMessageAbAttr, (user) => i18next.t("abilityTriggers:postSummonBeadsOfRuin", { pokemonNameWithAffix: getPokemonNameWithAffix(user), statName: i18next.t(getStatKey(Stat.SPDEF)) })), new Ability(Abilities.ORICHALCUM_PULSE, 9) .attr(PostSummonWeatherChangeAbAttr, WeatherType.SUNNY) .attr(PostBiomeChangeWeatherChangeAbAttr, WeatherType.SUNNY) @@ -5799,7 +6321,7 @@ export function initAbilities() { .attr(MovePowerBoostAbAttr, (user, target, move) => move.hasFlag(MoveFlags.SLICING_MOVE), 1.5), new Ability(Abilities.SUPREME_OVERLORD, 9) .attr(VariableMovePowerBoostAbAttr, (user, target, move) => 1 + 0.1 * Math.min(user.isPlayer() ? user.scene.currentBattle.playerFaints : user.scene.currentBattle.enemyFaints, 5)) - .partial(), + .partial(), // Counter resets every wave instead of on arena reset new Ability(Abilities.COSTAR, 9) .attr(PostSummonCopyAllyStatsAbAttr), new Ability(Abilities.TOXIC_DEBRIS, 9) @@ -5810,14 +6332,13 @@ export function initAbilities() { .ignorable(), new Ability(Abilities.EARTH_EATER, 9) .attr(TypeImmunityHealAbAttr, Type.GROUND) - .partial() // Healing not blocked by Heal Block .ignorable(), new Ability(Abilities.MYCELIUM_MIGHT, 9) .attr(ChangeMovePriorityAbAttr, (pokemon, move) => move.category === MoveCategory.STATUS, -0.2) .attr(PreventBypassSpeedChanceAbAttr, (pokemon, move) => move.category === MoveCategory.STATUS) .attr(MoveAbilityBypassAbAttr, (pokemon, move: Move) => move.category === MoveCategory.STATUS), new Ability(Abilities.MINDS_EYE, 9) - .attr(IgnoreTypeImmunityAbAttr, Type.GHOST, [Type.NORMAL, Type.FIGHTING]) + .attr(IgnoreTypeImmunityAbAttr, Type.GHOST, [ Type.NORMAL, Type.FIGHTING ]) .attr(ProtectStatAbAttr, Stat.ACC) .attr(IgnoreOpponentStatStagesAbAttr, [ Stat.EVA ]) .ignorable(), @@ -5825,8 +6346,7 @@ export function initAbilities() { .attr(PostSummonStatStageChangeAbAttr, [ Stat.EVA ], -1) .condition(getOncePerBattleCondition(Abilities.SUPERSWEET_SYRUP)), new Ability(Abilities.HOSPITALITY, 9) - .attr(PostSummonAllyHealAbAttr, 4, true) - .partial(), // Healing not blocked by Heal Block + .attr(PostSummonAllyHealAbAttr, 4, true), new Ability(Abilities.TOXIC_CHAIN, 9) .attr(PostAttackApplyStatusEffectAbAttr, false, 30, StatusEffect.TOXIC), new Ability(Abilities.EMBODY_ASPECT_TEAL, 9) @@ -5834,25 +6354,25 @@ export function initAbilities() { .attr(UncopiableAbilityAbAttr) .attr(UnswappableAbilityAbAttr) .attr(NoTransformAbilityAbAttr) - .partial(), + .partial(), // Ogerpon tera interactions new Ability(Abilities.EMBODY_ASPECT_WELLSPRING, 9) .attr(PostBattleInitStatStageChangeAbAttr, [ Stat.SPDEF ], 1, true) .attr(UncopiableAbilityAbAttr) .attr(UnswappableAbilityAbAttr) .attr(NoTransformAbilityAbAttr) - .partial(), + .partial(), // Ogerpon tera interactions new Ability(Abilities.EMBODY_ASPECT_HEARTHFLAME, 9) .attr(PostBattleInitStatStageChangeAbAttr, [ Stat.ATK ], 1, true) .attr(UncopiableAbilityAbAttr) .attr(UnswappableAbilityAbAttr) .attr(NoTransformAbilityAbAttr) - .partial(), + .partial(), // Ogerpon tera interactions new Ability(Abilities.EMBODY_ASPECT_CORNERSTONE, 9) .attr(PostBattleInitStatStageChangeAbAttr, [ Stat.DEF ], 1, true) .attr(UncopiableAbilityAbAttr) .attr(UnswappableAbilityAbAttr) .attr(NoTransformAbilityAbAttr) - .partial(), + .partial(), // Ogerpon tera interactions new Ability(Abilities.TERA_SHIFT, 9) .attr(PostSummonFormChangeAbAttr, p => p.getFormKey() ? 0 : 1) .attr(UncopiableAbilityAbAttr) @@ -5872,6 +6392,6 @@ export function initAbilities() { new Ability(Abilities.POISON_PUPPETEER, 9) .attr(UncopiableAbilityAbAttr) .attr(UnswappableAbilityAbAttr) - .conditionalAttr(pokemon => pokemon.species.speciesId===Species.PECHARUNT, ConfusionOnStatusEffectAbAttr, StatusEffect.POISON, StatusEffect.TOXIC) + .attr(ConfusionOnStatusEffectAbAttr, StatusEffect.POISON, StatusEffect.TOXIC) ); } diff --git a/src/data/arena-tag.ts b/src/data/arena-tag.ts index fdc32b75c19..2f57650c65d 100644 --- a/src/data/arena-tag.ts +++ b/src/data/arena-tag.ts @@ -1,14 +1,15 @@ -import { Arena } from "../field/arena"; -import { Type } from "./type"; -import * as Utils from "../utils"; -import { MoveCategory, allMoves, MoveTarget, IncrementMovePriorityAttr, applyMoveAttrs } from "./move"; -import { getPokemonNameWithAffix } from "../messages"; -import Pokemon, { HitResult, PokemonMove } from "../field/pokemon"; -import { StatusEffect } from "./status-effect"; -import { BattlerIndex } from "../battle"; -import { BlockNonDirectDamageAbAttr, ChangeMovePriorityAbAttr, ProtectStatAbAttr, applyAbAttrs } from "./ability"; +import { Arena } from "#app/field/arena"; +import BattleScene from "#app/battle-scene"; +import { Type } from "#enums/type"; +import { BooleanHolder, NumberHolder, toDmgValue } from "#app/utils"; +import { MoveCategory, allMoves, MoveTarget } from "#app/data/move"; +import { getPokemonNameWithAffix } from "#app/messages"; +import Pokemon, { HitResult, PokemonMove } from "#app/field/pokemon"; +import { StatusEffect } from "#enums/status-effect"; +import { BattlerIndex } from "#app/battle"; +import { BlockNonDirectDamageAbAttr, InfiltratorAbAttr, ProtectStatAbAttr, applyAbAttrs } from "#app/data/ability"; import { Stat } from "#enums/stat"; -import { CommonAnim, CommonBattleAnim } from "./battle-anims"; +import { CommonAnim, CommonBattleAnim } from "#app/data/battle-anims"; import i18next from "i18next"; import { Abilities } from "#enums/abilities"; import { ArenaTagType } from "#enums/arena-tag-type"; @@ -18,6 +19,7 @@ import { MoveEffectPhase } from "#app/phases/move-effect-phase"; import { PokemonHealPhase } from "#app/phases/pokemon-heal-phase"; import { ShowAbilityPhase } from "#app/phases/show-ability-phase"; import { StatStageChangePhase } from "#app/phases/stat-stage-change-phase"; +import { CommonAnimPhase } from "#app/phases/common-anim-phase"; export enum ArenaTagSide { BOTH, @@ -26,22 +28,15 @@ export enum ArenaTagSide { } export abstract class ArenaTag { - public tagType: ArenaTagType; - public turnCount: integer; - public sourceMove?: Moves; - public sourceId?: integer; - public side: ArenaTagSide; + constructor( + public tagType: ArenaTagType, + public turnCount: number, + public sourceMove?: Moves, + public sourceId?: number, + public side: ArenaTagSide = ArenaTagSide.BOTH + ) {} - - constructor(tagType: ArenaTagType, turnCount: integer, sourceMove: Moves | undefined, sourceId?: integer, side: ArenaTagSide = ArenaTagSide.BOTH) { - this.tagType = tagType; - this.turnCount = turnCount; - this.sourceMove = sourceMove; - this.sourceId = sourceId; - this.side = side; - } - - apply(arena: Arena, args: any[]): boolean { + apply(arena: Arena, simulated: boolean, ...args: unknown[]): boolean { return true; } @@ -64,6 +59,44 @@ export abstract class ArenaTag { ? allMoves[this.sourceMove].name : null; } + + /** + * When given a arena tag or json representing one, load the data for it. + * This is meant to be inherited from by any arena tag with custom attributes + * @param {ArenaTag | any} source An arena tag + */ + loadTag(source : ArenaTag | any) : void { + this.turnCount = source.turnCount; + this.sourceMove = source.sourceMove; + this.sourceId = source.sourceId; + this.side = source.side; + } + + /** + * Helper function that retrieves the source Pokemon + * @param scene medium to retrieve the source Pokemon + * @returns The source {@linkcode Pokemon} or `null` if none is found + */ + public getSourcePokemon(scene: BattleScene): Pokemon | null { + return this.sourceId ? scene.getPokemonById(this.sourceId) : null; + } + + /** + * Helper function that retrieves the Pokemon affected + * @param scene - medium to retrieve the involved Pokemon + * @returns list of PlayerPokemon or EnemyPokemon on the field + */ + public getAffectedPokemon(scene: BattleScene): Pokemon[] { + switch (this.side) { + case ArenaTagSide.PLAYER: + return scene.getPlayerField() ?? []; + case ArenaTagSide.ENEMY: + return scene.getEnemyField() ?? []; + case ArenaTagSide.BOTH: + default: + return scene.getField(true) ?? []; + } + } } /** @@ -71,7 +104,7 @@ export abstract class ArenaTag { * Prevents Pokémon on the opposing side from lowering the stats of the Pokémon in the Mist. */ export class MistTag extends ArenaTag { - constructor(turnCount: integer, sourceId: integer, side: ArenaTagSide) { + constructor(turnCount: number, sourceId: number, side: ArenaTagSide) { super(ArenaTagType.MIST, turnCount, Moves.MIST, sourceId, side); } @@ -89,10 +122,32 @@ export class MistTag extends ArenaTag { } } - apply(arena: Arena, args: any[]): boolean { - (args[0] as Utils.BooleanHolder).value = true; + /** + * Cancels the lowering of stats + * @param arena the {@linkcode Arena} containing this effect + * @param simulated `true` if the effect should be applied quietly + * @param attacker the {@linkcode Pokemon} using a move into this effect. + * @param cancelled a {@linkcode BooleanHolder} whose value is set to `true` + * to flag the stat reduction as cancelled + * @returns `true` if a stat reduction was cancelled; `false` otherwise + */ + override apply(arena: Arena, simulated: boolean, attacker: Pokemon, cancelled: BooleanHolder): boolean { + // `StatStageChangePhase` currently doesn't have a reference to the source of stat drops, + // so this code currently has no effect on gameplay. + if (attacker) { + const bypassed = new BooleanHolder(false); + // TODO: Allow this to be simulated + applyAbAttrs(InfiltratorAbAttr, attacker, null, false, bypassed); + if (bypassed.value) { + return false; + } + } - arena.scene.queueMessage(i18next.t("arenaTag:mistApply")); + cancelled.value = true; + + if (!simulated) { + arena.scene.queueMessage(i18next.t("arenaTag:mistApply")); + } return true; } @@ -115,7 +170,7 @@ export class WeakenMoveScreenTag extends ArenaTag { * @param side - The side (player or enemy) the tag affects. * @param weakenedCategories - The categories of moves that are weakened by this tag. */ - constructor(tagType: ArenaTagType, turnCount: integer, sourceMove: Moves, sourceId: integer, side: ArenaTagSide, weakenedCategories: MoveCategory[]) { + constructor(tagType: ArenaTagType, turnCount: number, sourceMove: Moves, sourceId: number, side: ArenaTagSide, weakenedCategories: MoveCategory[]) { super(tagType, turnCount, sourceMove, sourceId, side); this.weakenedCategories = weakenedCategories; @@ -124,17 +179,21 @@ export class WeakenMoveScreenTag extends ArenaTag { /** * Applies the weakening effect to the move. * - * @param arena - The arena where the move is applied. - * @param args - The arguments for the move application. - * @param args[0] - The category of the move. - * @param args[1] - A boolean indicating whether it is a double battle. - * @param args[2] - An object of type `Utils.NumberHolder` that holds the damage multiplier - * - * @returns True if the move was weakened, otherwise false. + * @param arena the {@linkcode Arena} where the move is applied. + * @param simulated n/a + * @param attacker the attacking {@linkcode Pokemon} + * @param moveCategory the attacking move's {@linkcode MoveCategory}. + * @param damageMultiplier A {@linkcode NumberHolder} containing the damage multiplier + * @returns `true` if the attacking move was weakened; `false` otherwise. */ - apply(arena: Arena, args: any[]): boolean { - if (this.weakenedCategories.includes((args[0] as MoveCategory))) { - (args[2] as Utils.NumberHolder).value = (args[1] as boolean) ? 2732/4096 : 0.5; + override apply(arena: Arena, simulated: boolean, attacker: Pokemon, moveCategory: MoveCategory, damageMultiplier: NumberHolder): boolean { + if (this.weakenedCategories.includes(moveCategory)) { + const bypassed = new BooleanHolder(false); + applyAbAttrs(InfiltratorAbAttr, attacker, null, false, bypassed); + if (bypassed.value) { + return false; + } + damageMultiplier.value = arena.scene.currentBattle.double ? 2732 / 4096 : 0.5; return true; } return false; @@ -146,8 +205,8 @@ export class WeakenMoveScreenTag extends ArenaTag { * Used by {@linkcode Moves.REFLECT} */ class ReflectTag extends WeakenMoveScreenTag { - constructor(turnCount: integer, sourceId: integer, side: ArenaTagSide) { - super(ArenaTagType.REFLECT, turnCount, Moves.REFLECT, sourceId, side, [MoveCategory.PHYSICAL]); + constructor(turnCount: number, sourceId: number, side: ArenaTagSide) { + super(ArenaTagType.REFLECT, turnCount, Moves.REFLECT, sourceId, side, [ MoveCategory.PHYSICAL ]); } onAdd(arena: Arena, quiet: boolean = false): void { @@ -162,8 +221,8 @@ class ReflectTag extends WeakenMoveScreenTag { * Used by {@linkcode Moves.LIGHT_SCREEN} */ class LightScreenTag extends WeakenMoveScreenTag { - constructor(turnCount: integer, sourceId: integer, side: ArenaTagSide) { - super(ArenaTagType.LIGHT_SCREEN, turnCount, Moves.LIGHT_SCREEN, sourceId, side, [MoveCategory.SPECIAL]); + constructor(turnCount: number, sourceId: number, side: ArenaTagSide) { + super(ArenaTagType.LIGHT_SCREEN, turnCount, Moves.LIGHT_SCREEN, sourceId, side, [ MoveCategory.SPECIAL ]); } onAdd(arena: Arena, quiet: boolean = false): void { @@ -178,8 +237,8 @@ class LightScreenTag extends WeakenMoveScreenTag { * Used by {@linkcode Moves.AURORA_VEIL} */ class AuroraVeilTag extends WeakenMoveScreenTag { - constructor(turnCount: integer, sourceId: integer, side: ArenaTagSide) { - super(ArenaTagType.AURORA_VEIL, turnCount, Moves.AURORA_VEIL, sourceId, side, [MoveCategory.SPECIAL, MoveCategory.PHYSICAL]); + constructor(turnCount: number, sourceId: number, side: ArenaTagSide) { + super(ArenaTagType.AURORA_VEIL, turnCount, Moves.AURORA_VEIL, sourceId, side, [ MoveCategory.SPECIAL, MoveCategory.PHYSICAL ]); } onAdd(arena: Arena, quiet: boolean = false): void { @@ -201,7 +260,7 @@ export class ConditionalProtectTag extends ArenaTag { /** Does this apply to all moves, including those that ignore other forms of protection? */ protected ignoresBypass: boolean; - constructor(tagType: ArenaTagType, sourceMove: Moves, sourceId: integer, side: ArenaTagSide, condition: ProtectConditionFunc, ignoresBypass: boolean = false) { + constructor(tagType: ArenaTagType, sourceMove: Moves, sourceId: number, side: ArenaTagSide, condition: ProtectConditionFunc, ignoresBypass: boolean = false) { super(tagType, 1, sourceMove, sourceId, side); this.protectConditionFunc = condition; @@ -216,38 +275,34 @@ export class ConditionalProtectTag extends ArenaTag { onRemove(arena: Arena): void { } /** - * apply(): Checks incoming moves against the condition function + * Checks incoming moves against the condition function * and protects the target if conditions are met - * @param arena The arena containing this tag - * @param args\[0\] (Utils.BooleanHolder) Signals if the move is cancelled - * @param args\[1\] (Pokemon) The Pokemon using the move - * @param args\[2\] (Pokemon) The intended target of the move - * @param args\[3\] (Moves) The parameters to the condition function - * @param args\[4\] (Utils.BooleanHolder) Signals if the applied protection supercedes protection-ignoring effects - * @returns + * @param arena the {@linkcode Arena} containing this tag + * @param simulated `true` if the tag is applied quietly; `false` otherwise. + * @param isProtected a {@linkcode BooleanHolder} used to flag if the move is protected against + * @param attacker the attacking {@linkcode Pokemon} + * @param defender the defending {@linkcode Pokemon} + * @param moveId the {@linkcode Moves | identifier} for the move being used + * @param ignoresProtectBypass a {@linkcode BooleanHolder} used to flag if a protection effect supercedes effects that ignore protection + * @returns `true` if this tag protected against the attack; `false` otherwise */ - apply(arena: Arena, args: any[]): boolean { - const [ cancelled, user, target, moveId, ignoresBypass ] = args; + override apply(arena: Arena, simulated: boolean, isProtected: BooleanHolder, attacker: Pokemon, defender: Pokemon, + moveId: Moves, ignoresProtectBypass: BooleanHolder): boolean { - if (cancelled instanceof Utils.BooleanHolder - && user instanceof Pokemon - && target instanceof Pokemon - && typeof moveId === "number" - && ignoresBypass instanceof Utils.BooleanHolder) { + if ((this.side === ArenaTagSide.PLAYER) === defender.isPlayer() + && this.protectConditionFunc(arena, moveId)) { + if (!isProtected.value) { + isProtected.value = true; + if (!simulated) { + attacker.stopMultiHit(defender); - if ((this.side === ArenaTagSide.PLAYER) === target.isPlayer() - && this.protectConditionFunc(arena, moveId)) { - if (!cancelled.value) { - cancelled.value = true; - user.stopMultiHit(target); - - new CommonBattleAnim(CommonAnim.PROTECT, target).play(arena.scene); - arena.scene.queueMessage(i18next.t("arenaTag:conditionalProtectApply", { moveName: super.getMoveName(), pokemonNameWithAffix: getPokemonNameWithAffix(target) })); + new CommonBattleAnim(CommonAnim.PROTECT, defender).play(arena.scene); + arena.scene.queueMessage(i18next.t("arenaTag:conditionalProtectApply", { moveName: super.getMoveName(), pokemonNameWithAffix: getPokemonNameWithAffix(defender) })); } - - ignoresBypass.value = ignoresBypass.value || this.ignoresBypass; - return true; } + + ignoresProtectBypass.value = ignoresProtectBypass.value || this.ignoresBypass; + return true; } return false; } @@ -258,20 +313,20 @@ export class ConditionalProtectTag extends ArenaTag { * protection effect. * @param arena {@linkcode Arena} The arena containing the protection effect * @param moveId {@linkcode Moves} The move to check against this condition - * @returns `true` if the incoming move's priority is greater than 0. This includes - * moves with modified priorities from abilities (e.g. Prankster) + * @returns `true` if the incoming move's priority is greater than 0. + * This includes moves with modified priorities from abilities (e.g. Prankster) */ const QuickGuardConditionFunc: ProtectConditionFunc = (arena, moveId) => { const move = allMoves[moveId]; - const priority = new Utils.IntegerHolder(move.priority); const effectPhase = arena.scene.getCurrentPhase(); if (effectPhase instanceof MoveEffectPhase) { - const attacker = effectPhase.getUserPokemon()!; - applyMoveAttrs(IncrementMovePriorityAttr, attacker, null, move, priority); - applyAbAttrs(ChangeMovePriorityAbAttr, attacker, null, false, move, priority); + const attacker = effectPhase.getUserPokemon(); + if (attacker) { + return move.getPriority(attacker) > 0; + } } - return priority.value > 0; + return move.priority > 0; }; /** @@ -279,7 +334,7 @@ const QuickGuardConditionFunc: ProtectConditionFunc = (arena, moveId) => { * Condition: The incoming move has increased priority. */ class QuickGuardTag extends ConditionalProtectTag { - constructor(sourceId: integer, side: ArenaTagSide) { + constructor(sourceId: number, side: ArenaTagSide) { super(ArenaTagType.QUICK_GUARD, Moves.QUICK_GUARD, sourceId, side, QuickGuardConditionFunc); } } @@ -295,11 +350,11 @@ const WideGuardConditionFunc: ProtectConditionFunc = (arena, moveId) : boolean = const move = allMoves[moveId]; switch (move.moveTarget) { - case MoveTarget.ALL_ENEMIES: - case MoveTarget.ALL_NEAR_ENEMIES: - case MoveTarget.ALL_OTHERS: - case MoveTarget.ALL_NEAR_OTHERS: - return true; + case MoveTarget.ALL_ENEMIES: + case MoveTarget.ALL_NEAR_ENEMIES: + case MoveTarget.ALL_OTHERS: + case MoveTarget.ALL_NEAR_OTHERS: + return true; } return false; }; @@ -310,7 +365,7 @@ const WideGuardConditionFunc: ProtectConditionFunc = (arena, moveId) : boolean = * can be an ally or enemy. */ class WideGuardTag extends ConditionalProtectTag { - constructor(sourceId: integer, side: ArenaTagSide) { + constructor(sourceId: number, side: ArenaTagSide) { super(ArenaTagType.WIDE_GUARD, Moves.WIDE_GUARD, sourceId, side, WideGuardConditionFunc); } } @@ -332,7 +387,7 @@ const MatBlockConditionFunc: ProtectConditionFunc = (arena, moveId) : boolean => * Condition: The incoming move is a Physical or Special attack move. */ class MatBlockTag extends ConditionalProtectTag { - constructor(sourceId: integer, side: ArenaTagSide) { + constructor(sourceId: number, side: ArenaTagSide) { super(ArenaTagType.MAT_BLOCK, Moves.MAT_BLOCK, sourceId, side, MatBlockConditionFunc); } @@ -370,7 +425,7 @@ const CraftyShieldConditionFunc: ProtectConditionFunc = (arena, moveId) => { * not target all Pokemon or sides of the field. */ class CraftyShieldTag extends ConditionalProtectTag { - constructor(sourceId: integer, side: ArenaTagSide) { + constructor(sourceId: number, side: ArenaTagSide) { super(ArenaTagType.CRAFTY_SHIELD, Moves.CRAFTY_SHIELD, sourceId, side, CraftyShieldConditionFunc, true); } } @@ -382,12 +437,12 @@ class CraftyShieldTag extends ConditionalProtectTag { export class NoCritTag extends ArenaTag { /** * Constructor method for the NoCritTag class - * @param turnCount `integer` the number of turns this effect lasts + * @param turnCount `number` the number of turns this effect lasts * @param sourceMove {@linkcode Moves} the move that created this effect - * @param sourceId `integer` the ID of the {@linkcode Pokemon} that created this effect + * @param sourceId `number` the ID of the {@linkcode Pokemon} that created this effect * @param side {@linkcode ArenaTagSide} the side to which this effect belongs */ - constructor(turnCount: integer, sourceMove: Moves, sourceId: integer, side: ArenaTagSide) { + constructor(turnCount: number, sourceMove: Moves, sourceId: number, side: ArenaTagSide) { super(ArenaTagType.NO_CRIT, turnCount, sourceMove, sourceId, side); } @@ -417,7 +472,7 @@ class WishTag extends ArenaTag { private triggerMessage: string; private healHp: number; - constructor(turnCount: integer, sourceId: integer, side: ArenaTagSide) { + constructor(turnCount: number, sourceId: number, side: ArenaTagSide) { super(ArenaTagType.WISH, turnCount, Moves.WISH, sourceId, side); } @@ -427,7 +482,7 @@ class WishTag extends ArenaTag { if (user) { this.battlerIndex = user.getBattlerIndex(); this.triggerMessage = i18next.t("arenaTag:wishTagOnAdd", { pokemonNameWithAffix: getPokemonNameWithAffix(user) }); - this.healHp = Utils.toDmgValue(user.getMaxHp() / 2); + this.healHp = toDmgValue(user.getMaxHp() / 2); } else { console.warn("Failed to get source for WishTag onAdd"); } @@ -458,18 +513,25 @@ export class WeakenMoveTypeTag extends ArenaTag { * @param sourceMove - The move that created the tag. * @param sourceId - The ID of the source of the tag. */ - constructor(tagType: ArenaTagType, turnCount: integer, type: Type, sourceMove: Moves, sourceId: integer) { + constructor(tagType: ArenaTagType, turnCount: number, type: Type, sourceMove: Moves, sourceId: number) { super(tagType, turnCount, sourceMove, sourceId); this.weakenedType = type; } - apply(arena: Arena, args: any[]): boolean { - if ((args[0] as Type) === this.weakenedType) { - (args[1] as Utils.NumberHolder).value *= 0.33; + /** + * Reduces an attack's power by 0.33x if it matches this tag's weakened type. + * @param arena n/a + * @param simulated n/a + * @param type the attack's {@linkcode Type} + * @param power a {@linkcode NumberHolder} containing the attack's power + * @returns `true` if the attack's power was reduced; `false` otherwise. + */ + override apply(arena: Arena, simulated: boolean, type: Type, power: NumberHolder): boolean { + if (type === this.weakenedType) { + power.value *= 0.33; return true; } - return false; } } @@ -479,7 +541,7 @@ export class WeakenMoveTypeTag extends ArenaTag { * Weakens Electric type moves for a set amount of turns, usually 5. */ class MudSportTag extends WeakenMoveTypeTag { - constructor(turnCount: integer, sourceId: integer) { + constructor(turnCount: number, sourceId: number) { super(ArenaTagType.MUD_SPORT, turnCount, Type.ELECTRIC, Moves.MUD_SPORT, sourceId); } @@ -497,7 +559,7 @@ class MudSportTag extends WeakenMoveTypeTag { * Weakens Fire type moves for a set amount of turns, usually 5. */ class WaterSportTag extends WeakenMoveTypeTag { - constructor(turnCount: integer, sourceId: integer) { + constructor(turnCount: number, sourceId: number) { super(ArenaTagType.WATER_SPORT, turnCount, Type.FIRE, Moves.WATER_SPORT, sourceId); } @@ -510,12 +572,45 @@ class WaterSportTag extends WeakenMoveTypeTag { } } +/** + * Arena Tag class for {@link https://bulbapedia.bulbagarden.net/wiki/Ion_Deluge_(move) | Ion Deluge} + * and the secondary effect of {@link https://bulbapedia.bulbagarden.net/wiki/Plasma_Fists_(move) | Plasma Fists}. + * Converts Normal-type moves to Electric type for the rest of the turn. + */ +export class IonDelugeTag extends ArenaTag { + constructor(sourceMove?: Moves) { + super(ArenaTagType.ION_DELUGE, 1, sourceMove); + } + + /** Queues an on-add message */ + onAdd(arena: Arena): void { + arena.scene.queueMessage(i18next.t("arenaTag:plasmaFistsOnAdd")); + } + + onRemove(arena: Arena): void { } // Removes default on-remove message + + /** + * Converts Normal-type moves to Electric type + * @param arena n/a + * @param simulated n/a + * @param moveType a {@linkcode NumberHolder} containing a move's {@linkcode Type} + * @returns `true` if the given move type changed; `false` otherwise. + */ + override apply(arena: Arena, simulated: boolean, moveType: NumberHolder): boolean { + if (moveType.value === Type.NORMAL) { + moveType.value = Type.ELECTRIC; + return true; + } + return false; + } +} + /** * Abstract class to implement arena traps. */ export class ArenaTrapTag extends ArenaTag { - public layers: integer; - public maxLayers: integer; + public layers: number; + public maxLayers: number; /** * Creates a new instance of the ArenaTrapTag class. @@ -526,7 +621,7 @@ export class ArenaTrapTag extends ArenaTag { * @param side - The side (player or enemy) the tag affects. * @param maxLayers - The maximum amount of layers this tag can have. */ - constructor(tagType: ArenaTagType, sourceMove: Moves, sourceId: integer, side: ArenaTagSide, maxLayers: integer) { + constructor(tagType: ArenaTagType, sourceMove: Moves, sourceId: number, side: ArenaTagSide, maxLayers: number) { super(tagType, 0, sourceMove, sourceId, side); this.layers = 1; @@ -541,22 +636,34 @@ export class ArenaTrapTag extends ArenaTag { } } - apply(arena: Arena, args: any[]): boolean { - const pokemon = args[0] as Pokemon; - if (this.sourceId === pokemon.id || (this.side === ArenaTagSide.PLAYER) !== pokemon.isPlayer()) { + /** + * Activates the hazard effect onto a Pokemon when it enters the field + * @param arena the {@linkcode Arena} containing this tag + * @param simulated if `true`, only checks if the hazard would activate. + * @param pokemon the {@linkcode Pokemon} triggering this hazard + * @returns `true` if this hazard affects the given Pokemon; `false` otherwise. + */ + override apply(arena: Arena, simulated: boolean, pokemon: Pokemon): boolean { + if ((this.side === ArenaTagSide.PLAYER) !== pokemon.isPlayer()) { return false; } - return this.activateTrap(pokemon); + return this.activateTrap(pokemon, simulated); } - activateTrap(pokemon: Pokemon): boolean { + activateTrap(pokemon: Pokemon, simulated: boolean): boolean { return false; } getMatchupScoreMultiplier(pokemon: Pokemon): number { return pokemon.isGrounded() ? 1 : Phaser.Math.Linear(0, 1 / Math.pow(2, this.layers), Math.min(pokemon.getHpRatio(), 0.5) * 2); } + + loadTag(source: any): void { + super.loadTag(source); + this.layers = source.layers; + this.maxLayers = source.maxLayers; + } } /** @@ -565,7 +672,7 @@ export class ArenaTrapTag extends ArenaTag { * in damage for 1, 2, or 3 layers of Spikes respectively if they are summoned into this trap. */ class SpikesTag extends ArenaTrapTag { - constructor(sourceId: integer, side: ArenaTagSide) { + constructor(sourceId: number, side: ArenaTagSide) { super(ArenaTagType.SPIKES, Moves.SPIKES, sourceId, side, 3); } @@ -578,14 +685,18 @@ class SpikesTag extends ArenaTrapTag { } } - activateTrap(pokemon: Pokemon): boolean { + override activateTrap(pokemon: Pokemon, simulated: boolean): boolean { if (pokemon.isGrounded()) { - const cancelled = new Utils.BooleanHolder(false); + const cancelled = new BooleanHolder(false); applyAbAttrs(BlockNonDirectDamageAbAttr, pokemon, cancelled); + if (simulated) { + return !cancelled.value; + } + if (!cancelled.value) { const damageHpRatio = 1 / (10 - 2 * this.layers); - const damage = Utils.toDmgValue(pokemon.getMaxHp() * damageHpRatio); + const damage = toDmgValue(pokemon.getMaxHp() * damageHpRatio); pokemon.scene.queueMessage(i18next.t("arenaTag:spikesActivateTrap", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) })); pokemon.damageAndUpdate(damage, HitResult.OTHER); @@ -609,7 +720,7 @@ class SpikesTag extends ArenaTrapTag { class ToxicSpikesTag extends ArenaTrapTag { private neutralized: boolean; - constructor(sourceId: integer, side: ArenaTagSide) { + constructor(sourceId: number, side: ArenaTagSide) { super(ArenaTagType.TOXIC_SPIKES, Moves.TOXIC_SPIKES, sourceId, side, 2); this.neutralized = false; } @@ -629,8 +740,11 @@ class ToxicSpikesTag extends ArenaTrapTag { } } - activateTrap(pokemon: Pokemon): boolean { + override activateTrap(pokemon: Pokemon, simulated: boolean): boolean { if (pokemon.isGrounded()) { + if (simulated) { + return true; + } if (pokemon.isOfType(Type.POISON)) { this.neutralized = true; if (pokemon.scene.arena.removeTag(this.tagType)) { @@ -664,13 +778,14 @@ class ToxicSpikesTag extends ArenaTrapTag { * Delays the attack's effect by a set amount of turns, usually 3 (including the turn the move is used), * and deals damage after the turn count is reached. */ -class DelayedAttackTag extends ArenaTag { +export class DelayedAttackTag extends ArenaTag { public targetIndex: BattlerIndex; - constructor(tagType: ArenaTagType, sourceMove: Moves | undefined, sourceId: integer, targetIndex: BattlerIndex) { - super(tagType, 3, sourceMove, sourceId); + constructor(tagType: ArenaTagType, sourceMove: Moves | undefined, sourceId: number, targetIndex: BattlerIndex, side: ArenaTagSide = ArenaTagSide.BOTH) { + super(tagType, 3, sourceMove, sourceId, side); this.targetIndex = targetIndex; + this.side = side; } lapse(arena: Arena): boolean { @@ -692,7 +807,7 @@ class DelayedAttackTag extends ArenaTag { * who is summoned into the trap, based on the Rock type's type effectiveness. */ class StealthRockTag extends ArenaTrapTag { - constructor(sourceId: integer, side: ArenaTagSide) { + constructor(sourceId: number, side: ArenaTagSide) { super(ArenaTagType.STEALTH_ROCK, Moves.STEALTH_ROCK, sourceId, side, 1); } @@ -711,31 +826,31 @@ class StealthRockTag extends ArenaTrapTag { let damageHpRatio: number = 0; switch (effectiveness) { - case 0: - damageHpRatio = 0; - break; - case 0.25: - damageHpRatio = 0.03125; - break; - case 0.5: - damageHpRatio = 0.0625; - break; - case 1: - damageHpRatio = 0.125; - break; - case 2: - damageHpRatio = 0.25; - break; - case 4: - damageHpRatio = 0.5; - break; + case 0: + damageHpRatio = 0; + break; + case 0.25: + damageHpRatio = 0.03125; + break; + case 0.5: + damageHpRatio = 0.0625; + break; + case 1: + damageHpRatio = 0.125; + break; + case 2: + damageHpRatio = 0.25; + break; + case 4: + damageHpRatio = 0.5; + break; } return damageHpRatio; } - activateTrap(pokemon: Pokemon): boolean { - const cancelled = new Utils.BooleanHolder(false); + override activateTrap(pokemon: Pokemon, simulated: boolean): boolean { + const cancelled = new BooleanHolder(false); applyAbAttrs(BlockNonDirectDamageAbAttr, pokemon, cancelled); if (cancelled.value) { @@ -745,12 +860,16 @@ class StealthRockTag extends ArenaTrapTag { const damageHpRatio = this.getDamageHpRatio(pokemon); if (damageHpRatio) { - const damage = Utils.toDmgValue(pokemon.getMaxHp() * damageHpRatio); + if (simulated) { + return true; + } + const damage = toDmgValue(pokemon.getMaxHp() * damageHpRatio); pokemon.scene.queueMessage(i18next.t("arenaTag:stealthRockActivateTrap", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) })); pokemon.damageAndUpdate(damage, HitResult.OTHER); if (pokemon.turnData) { pokemon.turnData.damageTaken += damage; } + return true; } return false; @@ -768,7 +887,7 @@ class StealthRockTag extends ArenaTrapTag { * to any Pokémon who is summoned into this trap. */ class StickyWebTag extends ArenaTrapTag { - constructor(sourceId: integer, side: ArenaTagSide) { + constructor(sourceId: number, side: ArenaTagSide) { super(ArenaTagType.STICKY_WEB, Moves.STICKY_WEB, sourceId, side, 1); } @@ -780,14 +899,20 @@ class StickyWebTag extends ArenaTrapTag { } } - activateTrap(pokemon: Pokemon): boolean { + override activateTrap(pokemon: Pokemon, simulated: boolean): boolean { if (pokemon.isGrounded()) { - const cancelled = new Utils.BooleanHolder(false); + const cancelled = new BooleanHolder(false); applyAbAttrs(ProtectStatAbAttr, pokemon, cancelled); + + if (simulated) { + return !cancelled.value; + } + if (!cancelled.value) { pokemon.scene.queueMessage(i18next.t("arenaTag:stickyWebActivateTrap", { pokemonName: pokemon.getNameToRender() })); - const stages = new Utils.NumberHolder(-1); + const stages = new NumberHolder(-1); pokemon.scene.unshiftPhase(new StatStageChangePhase(pokemon.scene, pokemon.getBattlerIndex(), false, [ Stat.SPD ], stages.value)); + return true; } } @@ -802,12 +927,19 @@ class StickyWebTag extends ArenaTrapTag { * also reversing the turn order for all Pokémon on the field as well. */ export class TrickRoomTag extends ArenaTag { - constructor(turnCount: integer, sourceId: integer) { + constructor(turnCount: number, sourceId: number) { super(ArenaTagType.TRICK_ROOM, turnCount, Moves.TRICK_ROOM, sourceId); } - apply(arena: Arena, args: any[]): boolean { - const speedReversed = args[0] as Utils.BooleanHolder; + /** + * Reverses Speed-based turn order for all Pokemon on the field + * @param arena n/a + * @param simulated n/a + * @param speedReversed a {@linkcode BooleanHolder} used to flag if Speed-based + * turn order should be reversed. + * @returns `true` if turn order is successfully reversed; `false` otherwise + */ + override apply(arena: Arena, simulated: boolean, speedReversed: BooleanHolder): boolean { speedReversed.value = !speedReversed.value; return true; } @@ -830,7 +962,7 @@ export class TrickRoomTag extends ArenaTag { * {@linkcode Abilities.LEVITATE} for the duration of the arena tag, usually 5 turns. */ export class GravityTag extends ArenaTag { - constructor(turnCount: integer) { + constructor(turnCount: number) { super(ArenaTagType.GRAVITY, turnCount, Moves.GRAVITY); } @@ -838,7 +970,11 @@ export class GravityTag extends ArenaTag { arena.scene.queueMessage(i18next.t("arenaTag:gravityOnAdd")); arena.scene.getField(true).forEach((pokemon) => { if (pokemon !== null) { - pokemon.removeTag(BattlerTagType.MAGNET_RISEN); + pokemon.removeTag(BattlerTagType.FLOATING); + pokemon.removeTag(BattlerTagType.TELEKINESIS); + if (pokemon.getTag(BattlerTagType.FLYING)) { + pokemon.addTag(BattlerTagType.INTERRUPTED); + } } }); } @@ -854,7 +990,7 @@ export class GravityTag extends ArenaTag { * Applies this arena tag for 4 turns (including the turn the move was used). */ class TailwindTag extends ArenaTag { - constructor(turnCount: integer, sourceId: integer, side: ArenaTagSide) { + constructor(turnCount: number, sourceId: number, side: ArenaTagSide) { super(ArenaTagType.TAILWIND, turnCount, Moves.TAILWIND, sourceId, side); } @@ -892,7 +1028,7 @@ class TailwindTag extends ArenaTag { * Doubles the prize money from trainers and money moves like {@linkcode Moves.PAY_DAY} and {@linkcode Moves.MAKE_IT_RAIN}. */ class HappyHourTag extends ArenaTag { - constructor(turnCount: integer, sourceId: integer, side: ArenaTagSide) { + constructor(turnCount: number, sourceId: number, side: ArenaTagSide) { super(ArenaTagType.HAPPY_HOUR, turnCount, Moves.HAPPY_HOUR, sourceId, side); } @@ -906,7 +1042,7 @@ class HappyHourTag extends ArenaTag { } class SafeguardTag extends ArenaTag { - constructor(turnCount: integer, sourceId: integer, side: ArenaTagSide) { + constructor(turnCount: number, sourceId: number, side: ArenaTagSide) { super(ArenaTagType.SAFEGUARD, turnCount, Moves.SAFEGUARD, sourceId, side); } @@ -919,55 +1055,247 @@ class SafeguardTag extends ArenaTag { } } - -export function getArenaTag(tagType: ArenaTagType, turnCount: integer, sourceMove: Moves | undefined, sourceId: integer, targetIndex?: BattlerIndex, side: ArenaTagSide = ArenaTagSide.BOTH): ArenaTag | null { - switch (tagType) { - case ArenaTagType.MIST: - return new MistTag(turnCount, sourceId, side); - case ArenaTagType.QUICK_GUARD: - return new QuickGuardTag(sourceId, side); - case ArenaTagType.WIDE_GUARD: - return new WideGuardTag(sourceId, side); - case ArenaTagType.MAT_BLOCK: - return new MatBlockTag(sourceId, side); - case ArenaTagType.CRAFTY_SHIELD: - return new CraftyShieldTag(sourceId, side); - case ArenaTagType.NO_CRIT: - return new NoCritTag(turnCount, sourceMove!, sourceId, side); // TODO: is this bang correct? - case ArenaTagType.MUD_SPORT: - return new MudSportTag(turnCount, sourceId); - case ArenaTagType.WATER_SPORT: - return new WaterSportTag(turnCount, sourceId); - case ArenaTagType.SPIKES: - return new SpikesTag(sourceId, side); - case ArenaTagType.TOXIC_SPIKES: - return new ToxicSpikesTag(sourceId, side); - case ArenaTagType.FUTURE_SIGHT: - case ArenaTagType.DOOM_DESIRE: - return new DelayedAttackTag(tagType, sourceMove, sourceId, targetIndex!); // TODO:questionable bang - case ArenaTagType.WISH: - return new WishTag(turnCount, sourceId, side); - case ArenaTagType.STEALTH_ROCK: - return new StealthRockTag(sourceId, side); - case ArenaTagType.STICKY_WEB: - return new StickyWebTag(sourceId, side); - case ArenaTagType.TRICK_ROOM: - return new TrickRoomTag(turnCount, sourceId); - case ArenaTagType.GRAVITY: - return new GravityTag(turnCount); - case ArenaTagType.REFLECT: - return new ReflectTag(turnCount, sourceId, side); - case ArenaTagType.LIGHT_SCREEN: - return new LightScreenTag(turnCount, sourceId, side); - case ArenaTagType.AURORA_VEIL: - return new AuroraVeilTag(turnCount, sourceId, side); - case ArenaTagType.TAILWIND: - return new TailwindTag(turnCount, sourceId, side); - case ArenaTagType.HAPPY_HOUR: - return new HappyHourTag(turnCount, sourceId, side); - case ArenaTagType.SAFEGUARD: - return new SafeguardTag(turnCount, sourceId, side); - default: - return null; +class NoneTag extends ArenaTag { + constructor() { + super(ArenaTagType.NONE, 0); } } +/** + * This arena tag facilitates the application of the move Imprison + * Imprison remains in effect as long as the source Pokemon is active and present on the field. + * Imprison will apply to any opposing Pokemon that switch onto the field as well. + */ +class ImprisonTag extends ArenaTrapTag { + constructor(sourceId: number, side: ArenaTagSide) { + super(ArenaTagType.IMPRISON, Moves.IMPRISON, sourceId, side, 1); + } + + /** + * This function applies the effects of Imprison to the opposing Pokemon already present on the field. + * @param arena + */ + override onAdd({ scene }: Arena) { + const source = this.getSourcePokemon(scene); + if (source) { + const party = this.getAffectedPokemon(scene); + party?.forEach((p: Pokemon ) => { + if (p.isAllowedInBattle()) { + p.addTag(BattlerTagType.IMPRISON, 1, Moves.IMPRISON, this.sourceId); + } + }); + scene.queueMessage(i18next.t("battlerTags:imprisonOnAdd", { pokemonNameWithAffix: getPokemonNameWithAffix(source) })); + } + } + + /** + * Checks if the source Pokemon is still active on the field + * @param _arena + * @returns `true` if the source of the tag is still active on the field | `false` if not + */ + override lapse({ scene }: Arena): boolean { + const source = this.getSourcePokemon(scene); + return source ? source.isActive(true) : false; + } + + /** + * This applies the effects of Imprison to any opposing Pokemon that switch into the field while the source Pokemon is still active + * @param {Pokemon} pokemon the Pokemon Imprison is applied to + * @returns `true` + */ + override activateTrap(pokemon: Pokemon): boolean { + const source = this.getSourcePokemon(pokemon.scene); + if (source && source.isActive(true) && pokemon.isAllowedInBattle()) { + pokemon.addTag(BattlerTagType.IMPRISON, 1, Moves.IMPRISON, this.sourceId); + } + return true; + } + + /** + * When the arena tag is removed, it also attempts to remove any related Battler Tags if they haven't already been removed from the affected Pokemon + * @param arena + */ + override onRemove({ scene }: Arena): void { + const party = this.getAffectedPokemon(scene); + party?.forEach((p: Pokemon) => { + p.removeTag(BattlerTagType.IMPRISON); + }); + } +} + +/** + * Arena Tag implementing the "sea of fire" effect from the combination + * of {@link https://bulbapedia.bulbagarden.net/wiki/Fire_Pledge_(move) | Fire Pledge} + * and {@link https://bulbapedia.bulbagarden.net/wiki/Grass_Pledge_(move) | Grass Pledge}. + * Damages all non-Fire-type Pokemon on the given side of the field at the end + * of each turn for 4 turns. + */ +class FireGrassPledgeTag extends ArenaTag { + constructor(sourceId: number, side: ArenaTagSide) { + super(ArenaTagType.FIRE_GRASS_PLEDGE, 4, Moves.FIRE_PLEDGE, sourceId, side); + } + + override onAdd(arena: Arena): void { + // "A sea of fire enveloped your/the opposing team!" + arena.scene.queueMessage(i18next.t(`arenaTag:fireGrassPledgeOnAdd${this.side === ArenaTagSide.PLAYER ? "Player" : this.side === ArenaTagSide.ENEMY ? "Enemy" : ""}`)); + } + + override lapse(arena: Arena): boolean { + const field: Pokemon[] = (this.side === ArenaTagSide.PLAYER) + ? arena.scene.getPlayerField() + : arena.scene.getEnemyField(); + + field.filter(pokemon => !pokemon.isOfType(Type.FIRE)).forEach(pokemon => { + // "{pokemonNameWithAffix} was hurt by the sea of fire!" + pokemon.scene.queueMessage(i18next.t("arenaTag:fireGrassPledgeLapse", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) })); + // TODO: Replace this with a proper animation + pokemon.scene.unshiftPhase(new CommonAnimPhase(pokemon.scene, pokemon.getBattlerIndex(), pokemon.getBattlerIndex(), CommonAnim.MAGMA_STORM)); + pokemon.damageAndUpdate(toDmgValue(pokemon.getMaxHp() / 8)); + }); + + return super.lapse(arena); + } +} + +/** + * Arena Tag implementing the "rainbow" effect from the combination + * of {@link https://bulbapedia.bulbagarden.net/wiki/Water_Pledge_(move) | Water Pledge} + * and {@link https://bulbapedia.bulbagarden.net/wiki/Fire_Pledge_(move) | Fire Pledge}. + * Doubles the secondary effect chance of moves from Pokemon on the + * given side of the field for 4 turns. + */ +class WaterFirePledgeTag extends ArenaTag { + constructor(sourceId: number, side: ArenaTagSide) { + super(ArenaTagType.WATER_FIRE_PLEDGE, 4, Moves.WATER_PLEDGE, sourceId, side); + } + + override onAdd(arena: Arena): void { + // "A rainbow appeared in the sky on your/the opposing team's side!" + arena.scene.queueMessage(i18next.t(`arenaTag:waterFirePledgeOnAdd${this.side === ArenaTagSide.PLAYER ? "Player" : this.side === ArenaTagSide.ENEMY ? "Enemy" : ""}`)); + } + + /** + * Doubles the chance for the given move's secondary effect(s) to trigger + * @param arena the {@linkcode Arena} containing this tag + * @param simulated n/a + * @param moveChance a {@linkcode NumberHolder} containing + * the move's current effect chance + * @returns `true` if the move's effect chance was doubled (currently always `true`) + */ + override apply(arena: Arena, simulated: boolean, moveChance: NumberHolder): boolean { + moveChance.value *= 2; + return true; + } +} + +/** + * Arena Tag implementing the "swamp" effect from the combination + * of {@link https://bulbapedia.bulbagarden.net/wiki/Grass_Pledge_(move) | Grass Pledge} + * and {@link https://bulbapedia.bulbagarden.net/wiki/Water_Pledge_(move) | Water Pledge}. + * Quarters the Speed of Pokemon on the given side of the field for 4 turns. + */ +class GrassWaterPledgeTag extends ArenaTag { + constructor(sourceId: number, side: ArenaTagSide) { + super(ArenaTagType.GRASS_WATER_PLEDGE, 4, Moves.GRASS_PLEDGE, sourceId, side); + } + + override onAdd(arena: Arena): void { + // "A swamp enveloped your/the opposing team!" + arena.scene.queueMessage(i18next.t(`arenaTag:grassWaterPledgeOnAdd${this.side === ArenaTagSide.PLAYER ? "Player" : this.side === ArenaTagSide.ENEMY ? "Enemy" : ""}`)); + } +} + +/** + * Arena Tag class for {@link https://bulbapedia.bulbagarden.net/wiki/Fairy_Lock_(move) Fairy Lock}. + * Fairy Lock prevents all Pokémon (except Ghost types) on the field from switching out or + * fleeing during their next turn. + * If a Pokémon that's on the field when Fairy Lock is used goes on to faint later in the same turn, + * the Pokémon that replaces it will still be unable to switch out in the following turn. + */ +export class FairyLockTag extends ArenaTag { + constructor(turnCount: number, sourceId: number) { + super(ArenaTagType.FAIRY_LOCK, turnCount, Moves.FAIRY_LOCK, sourceId); + } + + onAdd(arena: Arena): void { + arena.scene.queueMessage(i18next.t("arenaTag:fairyLockOnAdd")); + } + +} + +// TODO: swap `sourceMove` and `sourceId` and make `sourceMove` an optional parameter +export function getArenaTag(tagType: ArenaTagType, turnCount: number, sourceMove: Moves | undefined, sourceId: number, targetIndex?: BattlerIndex, side: ArenaTagSide = ArenaTagSide.BOTH): ArenaTag | null { + switch (tagType) { + case ArenaTagType.MIST: + return new MistTag(turnCount, sourceId, side); + case ArenaTagType.QUICK_GUARD: + return new QuickGuardTag(sourceId, side); + case ArenaTagType.WIDE_GUARD: + return new WideGuardTag(sourceId, side); + case ArenaTagType.MAT_BLOCK: + return new MatBlockTag(sourceId, side); + case ArenaTagType.CRAFTY_SHIELD: + return new CraftyShieldTag(sourceId, side); + case ArenaTagType.NO_CRIT: + return new NoCritTag(turnCount, sourceMove!, sourceId, side); // TODO: is this bang correct? + case ArenaTagType.MUD_SPORT: + return new MudSportTag(turnCount, sourceId); + case ArenaTagType.WATER_SPORT: + return new WaterSportTag(turnCount, sourceId); + case ArenaTagType.ION_DELUGE: + return new IonDelugeTag(sourceMove); + case ArenaTagType.SPIKES: + return new SpikesTag(sourceId, side); + case ArenaTagType.TOXIC_SPIKES: + return new ToxicSpikesTag(sourceId, side); + case ArenaTagType.FUTURE_SIGHT: + case ArenaTagType.DOOM_DESIRE: + return new DelayedAttackTag(tagType, sourceMove, sourceId, targetIndex!, side); // TODO:questionable bang + case ArenaTagType.WISH: + return new WishTag(turnCount, sourceId, side); + case ArenaTagType.STEALTH_ROCK: + return new StealthRockTag(sourceId, side); + case ArenaTagType.STICKY_WEB: + return new StickyWebTag(sourceId, side); + case ArenaTagType.TRICK_ROOM: + return new TrickRoomTag(turnCount, sourceId); + case ArenaTagType.GRAVITY: + return new GravityTag(turnCount); + case ArenaTagType.REFLECT: + return new ReflectTag(turnCount, sourceId, side); + case ArenaTagType.LIGHT_SCREEN: + return new LightScreenTag(turnCount, sourceId, side); + case ArenaTagType.AURORA_VEIL: + return new AuroraVeilTag(turnCount, sourceId, side); + case ArenaTagType.TAILWIND: + return new TailwindTag(turnCount, sourceId, side); + case ArenaTagType.HAPPY_HOUR: + return new HappyHourTag(turnCount, sourceId, side); + case ArenaTagType.SAFEGUARD: + return new SafeguardTag(turnCount, sourceId, side); + case ArenaTagType.IMPRISON: + return new ImprisonTag(sourceId, side); + case ArenaTagType.FIRE_GRASS_PLEDGE: + return new FireGrassPledgeTag(sourceId, side); + case ArenaTagType.WATER_FIRE_PLEDGE: + return new WaterFirePledgeTag(sourceId, side); + case ArenaTagType.GRASS_WATER_PLEDGE: + return new GrassWaterPledgeTag(sourceId, side); + case ArenaTagType.FAIRY_LOCK: + return new FairyLockTag(turnCount, sourceId); + default: + return null; + } +} + +/** + * When given a battler tag or json representing one, creates an actual ArenaTag object with the same data. + * @param {ArenaTag | any} source An arena tag + * @return {ArenaTag} The valid arena tag + */ +export function loadArenaTag(source: ArenaTag | any): ArenaTag { + const tag = getArenaTag(source.tagType, source.turnCount, source.sourceMove, source.sourceId, source.targetIndex, source.side) + ?? new NoneTag(); + tag.loadTag(source); + return tag; +} + diff --git a/src/data/biomes.ts b/src/data/balance/biomes.ts similarity index 84% rename from src/data/biomes.ts rename to src/data/balance/biomes.ts index 0e37cc94ff5..0f4926cf7c7 100644 --- a/src/data/biomes.ts +++ b/src/data/balance/biomes.ts @@ -1,6 +1,6 @@ -import { Type } from "./type"; -import * as Utils from "../utils"; -import { pokemonEvolutions, SpeciesFormEvolution } from "./pokemon-evolutions"; +import { Type } from "#enums/type"; +import * as Utils from "#app/utils"; +import { pokemonEvolutions, SpeciesFormEvolution } from "#app/data/balance/pokemon-evolutions"; import i18next from "i18next"; import { Biome } from "#enums/biome"; import { Species } from "#enums/species"; @@ -13,14 +13,14 @@ export function getBiomeName(biome: Biome | -1) { return i18next.t("biome:unknownLocation"); } switch (biome) { - case Biome.GRASS: - return i18next.t("biome:GRASS"); - case Biome.RUINS: - return i18next.t("biome:RUINS"); - case Biome.END: - return i18next.t("biome:END"); - default: - return i18next.t(`biome:${Biome[biome].toUpperCase()}`); + case Biome.GRASS: + return i18next.t("biome:GRASS"); + case Biome.RUINS: + return i18next.t("biome:RUINS"); + case Biome.END: + return i18next.t("biome:END"); + default: + return i18next.t(`biome:${Biome[biome].toUpperCase()}`); } } @@ -37,34 +37,34 @@ export const biomeLinks: BiomeLinks = { [Biome.PLAINS]: [ Biome.GRASS, Biome.METROPOLIS, Biome.LAKE ], [Biome.GRASS]: Biome.TALL_GRASS, [Biome.TALL_GRASS]: [ Biome.FOREST, Biome.CAVE ], - [Biome.SLUM]: [ Biome.CONSTRUCTION_SITE, [ Biome.SWAMP, 2 ] ], + [Biome.SLUM]: [ Biome.CONSTRUCTION_SITE, [ Biome.SWAMP, 2 ]], [Biome.FOREST]: [ Biome.JUNGLE, Biome.MEADOW ], [Biome.SEA]: [ Biome.SEABED, Biome.ICE_CAVE ], [Biome.SWAMP]: [ Biome.GRAVEYARD, Biome.TALL_GRASS ], - [Biome.BEACH]: [ Biome.SEA, [ Biome.ISLAND, 2 ] ], + [Biome.BEACH]: [ Biome.SEA, [ Biome.ISLAND, 2 ]], [Biome.LAKE]: [ Biome.BEACH, Biome.SWAMP, Biome.CONSTRUCTION_SITE ], - [Biome.SEABED]: [ Biome.CAVE, [ Biome.VOLCANO, 3 ] ], - [Biome.MOUNTAIN]: [ Biome.VOLCANO, [ Biome.WASTELAND, 2 ], [ Biome.SPACE, 3 ] ], + [Biome.SEABED]: [ Biome.CAVE, [ Biome.VOLCANO, 3 ]], + [Biome.MOUNTAIN]: [ Biome.VOLCANO, [ Biome.WASTELAND, 2 ], [ Biome.SPACE, 3 ]], [Biome.BADLANDS]: [ Biome.DESERT, Biome.MOUNTAIN ], - [Biome.CAVE]: [ Biome.BADLANDS, Biome.LAKE, [ Biome.LABORATORY, 2 ] ], - [Biome.DESERT]: [ Biome.RUINS, [ Biome.CONSTRUCTION_SITE, 2 ] ], + [Biome.CAVE]: [ Biome.BADLANDS, Biome.LAKE, [ Biome.LABORATORY, 2 ]], + [Biome.DESERT]: [ Biome.RUINS, [ Biome.CONSTRUCTION_SITE, 2 ]], [Biome.ICE_CAVE]: Biome.SNOWY_FOREST, [Biome.MEADOW]: [ Biome.PLAINS, Biome.FAIRY_CAVE ], [Biome.POWER_PLANT]: Biome.FACTORY, - [Biome.VOLCANO]: [ Biome.BEACH, [ Biome.ICE_CAVE, 3 ] ], + [Biome.VOLCANO]: [ Biome.BEACH, [ Biome.ICE_CAVE, 3 ]], [Biome.GRAVEYARD]: Biome.ABYSS, - [Biome.DOJO]: [ Biome.PLAINS, [ Biome.JUNGLE, 2], [ Biome.TEMPLE, 2 ] ], - [Biome.FACTORY]: [ Biome.PLAINS, [ Biome.LABORATORY, 2 ] ], - [Biome.RUINS]: [ Biome.MOUNTAIN, [ Biome.FOREST, 2 ] ], + [Biome.DOJO]: [ Biome.PLAINS, [ Biome.JUNGLE, 2 ], [ Biome.TEMPLE, 2 ]], + [Biome.FACTORY]: [ Biome.PLAINS, [ Biome.LABORATORY, 2 ]], + [Biome.RUINS]: [ Biome.MOUNTAIN, [ Biome.FOREST, 2 ]], [Biome.WASTELAND]: Biome.BADLANDS, - [Biome.ABYSS]: [ Biome.CAVE, [ Biome.SPACE, 2 ], [ Biome.WASTELAND, 2 ] ], + [Biome.ABYSS]: [ Biome.CAVE, [ Biome.SPACE, 2 ], [ Biome.WASTELAND, 2 ]], [Biome.SPACE]: Biome.RUINS, - [Biome.CONSTRUCTION_SITE]: [ Biome.POWER_PLANT, [ Biome.DOJO, 2 ] ], + [Biome.CONSTRUCTION_SITE]: [ Biome.POWER_PLANT, [ Biome.DOJO, 2 ]], [Biome.JUNGLE]: [ Biome.TEMPLE ], - [Biome.FAIRY_CAVE]: [ Biome.ICE_CAVE, [ Biome.SPACE, 2 ] ], - [Biome.TEMPLE]: [ Biome.DESERT, [ Biome.SWAMP, 2 ], [ Biome.RUINS, 2 ] ], + [Biome.FAIRY_CAVE]: [ Biome.ICE_CAVE, [ Biome.SPACE, 2 ]], + [Biome.TEMPLE]: [ Biome.DESERT, [ Biome.SWAMP, 2 ], [ Biome.RUINS, 2 ]], [Biome.METROPOLIS]: Biome.SLUM, - [Biome.SNOWY_FOREST]: [ Biome.FOREST, [ Biome.MOUNTAIN, 2 ], [ Biome.LAKE, 2 ] ], + [Biome.SNOWY_FOREST]: [ Biome.FOREST, [ Biome.MOUNTAIN, 2 ], [ Biome.LAKE, 2 ]], [Biome.ISLAND]: Biome.SEA, [Biome.LABORATORY]: Biome.CONSTRUCTION_SITE }; @@ -113,7 +113,7 @@ export const biomePokemonPools: BiomePokemonPools = { [Biome.TOWN]: { [BiomePoolTier.COMMON]: { [TimeOfDay.DAWN]: [ - { 1: [ Species.CATERPIE ], 7: [ Species.METAPOD ] }, + { 1: [ Species.CATERPIE ], 7: [ Species.METAPOD ]}, Species.SENTRET, Species.LEDYBA, Species.HOPPIP, @@ -121,12 +121,12 @@ export const biomePokemonPools: BiomePokemonPools = { Species.STARLY, Species.PIDOVE, Species.COTTONEE, - { 1: [ Species.SCATTERBUG ], 9: [ Species.SPEWPA ] }, + { 1: [ Species.SCATTERBUG ], 9: [ Species.SPEWPA ]}, Species.YUNGOOS, Species.SKWOVET ], [TimeOfDay.DAY]: [ - { 1: [ Species.CATERPIE ], 7: [ Species.METAPOD ] }, + { 1: [ Species.CATERPIE ], 7: [ Species.METAPOD ]}, Species.SENTRET, Species.HOPPIP, Species.SUNKERN, @@ -134,12 +134,12 @@ export const biomePokemonPools: BiomePokemonPools = { Species.STARLY, Species.PIDOVE, Species.COTTONEE, - { 1: [ Species.SCATTERBUG ], 9: [ Species.SPEWPA ] }, + { 1: [ Species.SCATTERBUG ], 9: [ Species.SPEWPA ]}, Species.YUNGOOS, Species.SKWOVET ], - [TimeOfDay.DUSK]: [ { 1: [ Species.WEEDLE ], 7: [ Species.KAKUNA ] }, Species.POOCHYENA, Species.PATRAT, Species.PURRLOIN, Species.BLIPBUG ], - [TimeOfDay.NIGHT]: [ { 1: [ Species.WEEDLE ], 7: [ Species.KAKUNA ] }, Species.HOOTHOOT, Species.SPINARAK, Species.POOCHYENA, Species.CASCOON, Species.PATRAT, Species.PURRLOIN, Species.BLIPBUG ], + [TimeOfDay.DUSK]: [{ 1: [ Species.WEEDLE ], 7: [ Species.KAKUNA ]}, Species.POOCHYENA, Species.PATRAT, Species.PURRLOIN, Species.BLIPBUG ], + [TimeOfDay.NIGHT]: [{ 1: [ Species.WEEDLE ], 7: [ Species.KAKUNA ]}, Species.HOOTHOOT, Species.SPINARAK, Species.POOCHYENA, Species.CASCOON, Species.PATRAT, Species.PURRLOIN, Species.BLIPBUG ], [TimeOfDay.ALL]: [ Species.PIDGEY, Species.RATTATA, Species.SPEAROW, Species.ZIGZAGOON, Species.WURMPLE, Species.TAILLOW, Species.BIDOOF, Species.LILLIPUP, Species.FLETCHLING, Species.WOOLOO, Species.LECHONK ] }, [BiomePoolTier.UNCOMMON]: { @@ -149,56 +149,56 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.NIGHT]: [ Species.EKANS, Species.ODDISH, Species.PARAS, Species.VENONAT, Species.MEOWTH, Species.SEEDOT, Species.SHROOMISH, Species.KRICKETOT, Species.VENIPEDE ], [TimeOfDay.ALL]: [ Species.NINCADA, Species.WHISMUR, Species.FIDOUGH ] }, - [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [ Species.TANDEMAUS ], [TimeOfDay.DAY]: [ Species.TANDEMAUS ], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ABRA, Species.SURSKIT, Species.ROOKIDEE ] }, - [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.EEVEE, Species.RALTS ] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.DITTO ] }, - [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] }, - [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] } + [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [ Species.TANDEMAUS ], [TimeOfDay.DAY]: [ Species.TANDEMAUS ], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ABRA, Species.SURSKIT, Species.ROOKIDEE ]}, + [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.EEVEE, Species.RALTS ]}, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.DITTO ]}, + [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []}, + [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []}, + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []} }, [Biome.PLAINS]: { [BiomePoolTier.COMMON]: { - [TimeOfDay.DAWN]: [ { 1: [ Species.SENTRET ], 15: [ Species.FURRET ] }, { 1: [ Species.YUNGOOS ], 30: [ Species.GUMSHOOS ] }, { 1: [ Species.SKWOVET ], 24: [ Species.GREEDENT ] } ], - [TimeOfDay.DAY]: [ { 1: [ Species.SENTRET ], 15: [ Species.FURRET ] }, { 1: [ Species.YUNGOOS ], 30: [ Species.GUMSHOOS ] }, { 1: [ Species.SKWOVET ], 24: [ Species.GREEDENT ] } ], - [TimeOfDay.DUSK]: [ { 1: [ Species.MEOWTH ], 28: [ Species.PERSIAN ] }, { 1: [ Species.POOCHYENA ], 18: [ Species.MIGHTYENA ] } ], - [TimeOfDay.NIGHT]: [ { 1: [ Species.ZUBAT ], 22: [ Species.GOLBAT ] }, { 1: [ Species.MEOWTH ], 28: [ Species.PERSIAN ] }, { 1: [ Species.POOCHYENA ], 18: [ Species.MIGHTYENA ] } ], - [TimeOfDay.ALL]: [ { 1: [ Species.ZIGZAGOON ], 20: [ Species.LINOONE ] }, { 1: [ Species.BIDOOF ], 15: [ Species.BIBAREL ] }, { 1: [ Species.LECHONK ], 18: [ Species.OINKOLOGNE ] } ] + [TimeOfDay.DAWN]: [{ 1: [ Species.SENTRET ], 15: [ Species.FURRET ]}, { 1: [ Species.YUNGOOS ], 30: [ Species.GUMSHOOS ]}, { 1: [ Species.SKWOVET ], 24: [ Species.GREEDENT ]}], + [TimeOfDay.DAY]: [{ 1: [ Species.SENTRET ], 15: [ Species.FURRET ]}, { 1: [ Species.YUNGOOS ], 30: [ Species.GUMSHOOS ]}, { 1: [ Species.SKWOVET ], 24: [ Species.GREEDENT ]}], + [TimeOfDay.DUSK]: [{ 1: [ Species.MEOWTH ], 28: [ Species.PERSIAN ]}, { 1: [ Species.POOCHYENA ], 18: [ Species.MIGHTYENA ]}], + [TimeOfDay.NIGHT]: [{ 1: [ Species.ZUBAT ], 22: [ Species.GOLBAT ]}, { 1: [ Species.MEOWTH ], 28: [ Species.PERSIAN ]}, { 1: [ Species.POOCHYENA ], 18: [ Species.MIGHTYENA ]}], + [TimeOfDay.ALL]: [{ 1: [ Species.ZIGZAGOON ], 20: [ Species.LINOONE ]}, { 1: [ Species.BIDOOF ], 15: [ Species.BIBAREL ]}, { 1: [ Species.LECHONK ], 18: [ Species.OINKOLOGNE ]}] }, [BiomePoolTier.UNCOMMON]: { [TimeOfDay.DAWN]: [ - { 1: [ Species.DODUO ], 31: [ Species.DODRIO ] }, - { 1: [ Species.POOCHYENA ], 18: [ Species.MIGHTYENA ] }, - { 1: [ Species.STARLY ], 14: [ Species.STARAVIA ], 34: [ Species.STARAPTOR ] }, - { 1: [ Species.PIDOVE ], 21: [ Species.TRANQUILL ], 32: [ Species.UNFEZANT ] }, - { 1: [ Species.PAWMI ], 18: [ Species.PAWMO ], 32: [ Species.PAWMOT ] } + { 1: [ Species.DODUO ], 31: [ Species.DODRIO ]}, + { 1: [ Species.POOCHYENA ], 18: [ Species.MIGHTYENA ]}, + { 1: [ Species.STARLY ], 14: [ Species.STARAVIA ], 34: [ Species.STARAPTOR ]}, + { 1: [ Species.PIDOVE ], 21: [ Species.TRANQUILL ], 32: [ Species.UNFEZANT ]}, + { 1: [ Species.PAWMI ], 18: [ Species.PAWMO ], 32: [ Species.PAWMOT ]} ], [TimeOfDay.DAY]: [ - { 1: [ Species.DODUO ], 31: [ Species.DODRIO ] }, - { 1: [ Species.POOCHYENA ], 18: [ Species.MIGHTYENA ] }, - { 1: [ Species.STARLY ], 14: [ Species.STARAVIA ], 34: [ Species.STARAPTOR ] }, - { 1: [ Species.PIDOVE ], 21: [ Species.TRANQUILL ], 32: [ Species.UNFEZANT ] }, - { 1: [ Species.ROCKRUFF ], 25: [ Species.LYCANROC ] }, - { 1: [ Species.PAWMI ], 18: [ Species.PAWMO ], 32: [ Species.PAWMOT ] } + { 1: [ Species.DODUO ], 31: [ Species.DODRIO ]}, + { 1: [ Species.POOCHYENA ], 18: [ Species.MIGHTYENA ]}, + { 1: [ Species.STARLY ], 14: [ Species.STARAVIA ], 34: [ Species.STARAPTOR ]}, + { 1: [ Species.PIDOVE ], 21: [ Species.TRANQUILL ], 32: [ Species.UNFEZANT ]}, + { 1: [ Species.ROCKRUFF ], 25: [ Species.LYCANROC ]}, + { 1: [ Species.PAWMI ], 18: [ Species.PAWMO ], 32: [ Species.PAWMOT ]} ], - [TimeOfDay.DUSK]: [ { 1: [ Species.MANKEY ], 28: [ Species.PRIMEAPE ], 75: [ Species.ANNIHILAPE ] } ], - [TimeOfDay.NIGHT]: [ { 1: [ Species.MANKEY ], 28: [ Species.PRIMEAPE ], 75: [ Species.ANNIHILAPE ] } ], + [TimeOfDay.DUSK]: [{ 1: [ Species.MANKEY ], 28: [ Species.PRIMEAPE ], 75: [ Species.ANNIHILAPE ]}], + [TimeOfDay.NIGHT]: [{ 1: [ Species.MANKEY ], 28: [ Species.PRIMEAPE ], 75: [ Species.ANNIHILAPE ]}], [TimeOfDay.ALL]: [ - { 1: [ Species.PIDGEY ], 18: [ Species.PIDGEOTTO ], 36: [ Species.PIDGEOT ] }, - { 1: [ Species.SPEAROW ], 20: [ Species.FEAROW ] }, + { 1: [ Species.PIDGEY ], 18: [ Species.PIDGEOTTO ], 36: [ Species.PIDGEOT ]}, + { 1: [ Species.SPEAROW ], 20: [ Species.FEAROW ]}, Species.PIKACHU, - { 1: [ Species.FLETCHLING ], 17: [ Species.FLETCHINDER ], 35: [ Species.TALONFLAME ] } + { 1: [ Species.FLETCHLING ], 17: [ Species.FLETCHINDER ], 35: [ Species.TALONFLAME ]} ] }, [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [ Species.PALDEA_TAUROS ], [TimeOfDay.DAY]: [ Species.PALDEA_TAUROS ], - [TimeOfDay.DUSK]: [ { 1: [ Species.SHINX ], 15: [ Species.LUXIO ], 30: [ Species.LUXRAY ] } ], - [TimeOfDay.NIGHT]: [ { 1: [ Species.SHINX ], 15: [ Species.LUXIO ], 30: [ Species.LUXRAY ] } ], - [TimeOfDay.ALL]: [ { 1: [ Species.ABRA ], 16: [ Species.KADABRA ] }, { 1: [ Species.BUNEARY ], 20: [ Species.LOPUNNY ] }, { 1: [ Species.ROOKIDEE ], 18: [ Species.CORVISQUIRE ], 38: [ Species.CORVIKNIGHT ] } ] + [TimeOfDay.DUSK]: [{ 1: [ Species.SHINX ], 15: [ Species.LUXIO ], 30: [ Species.LUXRAY ]}], + [TimeOfDay.NIGHT]: [{ 1: [ Species.SHINX ], 15: [ Species.LUXIO ], 30: [ Species.LUXRAY ]}], + [TimeOfDay.ALL]: [{ 1: [ Species.ABRA ], 16: [ Species.KADABRA ]}, { 1: [ Species.BUNEARY ], 20: [ Species.LOPUNNY ]}, { 1: [ Species.ROOKIDEE ], 18: [ Species.CORVISQUIRE ], 38: [ Species.CORVIKNIGHT ]}] }, - [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.FARFETCHD, Species.LICKITUNG, Species.CHANSEY, Species.EEVEE, Species.SNORLAX, { 1: [ Species.DUNSPARCE ], 62: [ Species.DUDUNSPARCE ] } ] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.DITTO, Species.LATIAS, Species.LATIOS ] }, + [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.FARFETCHD, Species.LICKITUNG, Species.CHANSEY, Species.EEVEE, Species.SNORLAX, { 1: [ Species.DUNSPARCE ], 62: [ Species.DUDUNSPARCE ]}]}, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.DITTO, Species.LATIAS, Species.LATIOS ]}, [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [ Species.DODRIO, Species.FURRET, Species.GUMSHOOS, Species.GREEDENT ], [TimeOfDay.DAY]: [ Species.DODRIO, Species.FURRET, Species.GUMSHOOS, Species.GREEDENT ], @@ -213,22 +213,22 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.FARFETCHD, Species.SNORLAX, Species.LICKILICKY, Species.DUDUNSPARCE ] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.LATIAS, Species.LATIOS ] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] } + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.LATIAS, Species.LATIOS ]}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []} }, [Biome.GRASS]: { [BiomePoolTier.COMMON]: { - [TimeOfDay.DAWN]: [ { 1: [ Species.HOPPIP ], 18: [ Species.SKIPLOOM ] }, Species.SUNKERN, Species.COTTONEE, Species.PETILIL ], - [TimeOfDay.DAY]: [ { 1: [ Species.HOPPIP ], 18: [ Species.SKIPLOOM ] }, Species.SUNKERN, Species.COTTONEE, Species.PETILIL ], - [TimeOfDay.DUSK]: [ { 1: [ Species.SEEDOT ], 14: [ Species.NUZLEAF ] }, { 1: [ Species.SHROOMISH ], 23: [ Species.BRELOOM ] } ], - [TimeOfDay.NIGHT]: [ { 1: [ Species.SEEDOT ], 14: [ Species.NUZLEAF ] }, { 1: [ Species.SHROOMISH ], 23: [ Species.BRELOOM ] } ], + [TimeOfDay.DAWN]: [{ 1: [ Species.HOPPIP ], 18: [ Species.SKIPLOOM ]}, Species.SUNKERN, Species.COTTONEE, Species.PETILIL ], + [TimeOfDay.DAY]: [{ 1: [ Species.HOPPIP ], 18: [ Species.SKIPLOOM ]}, Species.SUNKERN, Species.COTTONEE, Species.PETILIL ], + [TimeOfDay.DUSK]: [{ 1: [ Species.SEEDOT ], 14: [ Species.NUZLEAF ]}, { 1: [ Species.SHROOMISH ], 23: [ Species.BRELOOM ]}], + [TimeOfDay.NIGHT]: [{ 1: [ Species.SEEDOT ], 14: [ Species.NUZLEAF ]}, { 1: [ Species.SHROOMISH ], 23: [ Species.BRELOOM ]}], [TimeOfDay.ALL]: [] }, [BiomePoolTier.UNCOMMON]: { - [TimeOfDay.DAWN]: [ { 1: [ Species.COMBEE ], 21: [ Species.VESPIQUEN ] }, { 1: [ Species.CHERUBI ], 25: [ Species.CHERRIM ] } ], - [TimeOfDay.DAY]: [ { 1: [ Species.COMBEE ], 21: [ Species.VESPIQUEN ] }, { 1: [ Species.CHERUBI ], 25: [ Species.CHERRIM ] } ], - [TimeOfDay.DUSK]: [ { 1: [ Species.FOONGUS ], 39: [ Species.AMOONGUSS ] } ], - [TimeOfDay.NIGHT]: [ { 1: [ Species.FOONGUS ], 39: [ Species.AMOONGUSS ] } ], + [TimeOfDay.DAWN]: [{ 1: [ Species.COMBEE ], 21: [ Species.VESPIQUEN ]}, { 1: [ Species.CHERUBI ], 25: [ Species.CHERRIM ]}], + [TimeOfDay.DAY]: [{ 1: [ Species.COMBEE ], 21: [ Species.VESPIQUEN ]}, { 1: [ Species.CHERUBI ], 25: [ Species.CHERRIM ]}], + [TimeOfDay.DUSK]: [{ 1: [ Species.FOONGUS ], 39: [ Species.AMOONGUSS ]}], + [TimeOfDay.NIGHT]: [{ 1: [ Species.FOONGUS ], 39: [ Species.AMOONGUSS ]}], [TimeOfDay.ALL]: [] }, [BiomePoolTier.RARE]: { @@ -236,28 +236,28 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], - [TimeOfDay.ALL]: [ { 1: [ Species.BULBASAUR ], 16: [ Species.IVYSAUR ], 32: [ Species.VENUSAUR ] }, Species.GROWLITHE, { 1: [ Species.TURTWIG ], 18: [ Species.GROTLE ], 32: [ Species.TORTERRA ] } ] + [TimeOfDay.ALL]: [{ 1: [ Species.BULBASAUR ], 16: [ Species.IVYSAUR ], 32: [ Species.VENUSAUR ]}, Species.GROWLITHE, { 1: [ Species.TURTWIG ], 18: [ Species.GROTLE ], 32: [ Species.TORTERRA ]}] }, - [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.SUDOWOODO ] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.VIRIZION ] }, - [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [ Species.JUMPLUFF, Species.SUNFLORA, Species.WHIMSICOTT ], [TimeOfDay.DAY]: [ Species.JUMPLUFF, Species.SUNFLORA, Species.WHIMSICOTT ], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] }, - [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.VENUSAUR, Species.SUDOWOODO, Species.TORTERRA ] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.VIRIZION ] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] } + [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.SUDOWOODO ]}, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.VIRIZION ]}, + [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [ Species.JUMPLUFF, Species.SUNFLORA, Species.WHIMSICOTT ], [TimeOfDay.DAY]: [ Species.JUMPLUFF, Species.SUNFLORA, Species.WHIMSICOTT ], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []}, + [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.VENUSAUR, Species.SUDOWOODO, Species.TORTERRA ]}, + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.VIRIZION ]}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []} }, [Biome.TALL_GRASS]: { [BiomePoolTier.COMMON]: { - [TimeOfDay.DAWN]: [ { 1: [ Species.BOUNSWEET ], 18: [ Species.STEENEE ], 58: [ Species.TSAREENA ] } ], - [TimeOfDay.DAY]: [ { 1: [ Species.NIDORAN_F ], 16: [ Species.NIDORINA ] }, { 1: [ Species.NIDORAN_M ], 16: [ Species.NIDORINO ] }, { 1: [ Species.BOUNSWEET ], 18: [ Species.STEENEE ], 58: [ Species.TSAREENA ] } ], - [TimeOfDay.DUSK]: [ { 1: [ Species.ODDISH ], 21: [ Species.GLOOM ] }, { 1: [ Species.KRICKETOT ], 10: [ Species.KRICKETUNE ] } ], - [TimeOfDay.NIGHT]: [ { 1: [ Species.ODDISH ], 21: [ Species.GLOOM ] }, { 1: [ Species.KRICKETOT ], 10: [ Species.KRICKETUNE ] } ], - [TimeOfDay.ALL]: [ { 1: [ Species.NINCADA ], 20: [ Species.NINJASK ] }, { 1: [ Species.FOMANTIS ], 44: [ Species.LURANTIS ] }, { 1: [ Species.NYMBLE ], 24: [ Species.LOKIX ] } ] + [TimeOfDay.DAWN]: [{ 1: [ Species.BOUNSWEET ], 18: [ Species.STEENEE ], 58: [ Species.TSAREENA ]}], + [TimeOfDay.DAY]: [{ 1: [ Species.NIDORAN_F ], 16: [ Species.NIDORINA ]}, { 1: [ Species.NIDORAN_M ], 16: [ Species.NIDORINO ]}, { 1: [ Species.BOUNSWEET ], 18: [ Species.STEENEE ], 58: [ Species.TSAREENA ]}], + [TimeOfDay.DUSK]: [{ 1: [ Species.ODDISH ], 21: [ Species.GLOOM ]}, { 1: [ Species.KRICKETOT ], 10: [ Species.KRICKETUNE ]}], + [TimeOfDay.NIGHT]: [{ 1: [ Species.ODDISH ], 21: [ Species.GLOOM ]}, { 1: [ Species.KRICKETOT ], 10: [ Species.KRICKETUNE ]}], + [TimeOfDay.ALL]: [{ 1: [ Species.NINCADA ], 20: [ Species.NINJASK ]}, { 1: [ Species.FOMANTIS ], 44: [ Species.LURANTIS ]}, { 1: [ Species.NYMBLE ], 24: [ Species.LOKIX ]}] }, [BiomePoolTier.UNCOMMON]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], - [TimeOfDay.NIGHT]: [ { 1: [ Species.PARAS ], 24: [ Species.PARASECT ] }, { 1: [ Species.VENONAT ], 31: [ Species.VENOMOTH ] }, { 1: [ Species.SPINARAK ], 22: [ Species.ARIADOS ] } ], + [TimeOfDay.NIGHT]: [{ 1: [ Species.PARAS ], 24: [ Species.PARASECT ]}, { 1: [ Species.VENONAT ], 31: [ Species.VENOMOTH ]}, { 1: [ Species.SPINARAK ], 22: [ Species.ARIADOS ]}], [TimeOfDay.ALL]: [ Species.VULPIX ] }, [BiomePoolTier.RARE]: { @@ -265,10 +265,10 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], - [TimeOfDay.ALL]: [ Species.PINSIR, { 1: [ Species.CHIKORITA ], 16: [ Species.BAYLEEF ], 32: [ Species.MEGANIUM ] }, { 1: [ Species.GIRAFARIG ], 62: [ Species.FARIGIRAF ] }, Species.ZANGOOSE, Species.KECLEON, Species.TROPIUS ] + [TimeOfDay.ALL]: [ Species.PINSIR, { 1: [ Species.CHIKORITA ], 16: [ Species.BAYLEEF ], 32: [ Species.MEGANIUM ]}, { 1: [ Species.GIRAFARIG ], 62: [ Species.FARIGIRAF ]}, Species.ZANGOOSE, Species.KECLEON, Species.TROPIUS ] }, - [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.SCYTHER, Species.SHEDINJA, Species.ROTOM ] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] }, + [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.SCYTHER, Species.SHEDINJA, Species.ROTOM ]}, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []}, [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [ Species.TSAREENA ], [TimeOfDay.DAY]: [ Species.NIDOQUEEN, Species.NIDOKING, Species.TSAREENA ], @@ -276,87 +276,87 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.NIGHT]: [ Species.VILEPLUME, Species.KRICKETUNE ], [TimeOfDay.ALL]: [ Species.NINJASK, Species.ZANGOOSE, Species.KECLEON, Species.LURANTIS, Species.LOKIX ] }, - [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [ Species.BELLOSSOM ], [TimeOfDay.DAY]: [ Species.BELLOSSOM ], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.PINSIR, Species.MEGANIUM, Species.FARIGIRAF ] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ROTOM ] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] } + [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [ Species.BELLOSSOM ], [TimeOfDay.DAY]: [ Species.BELLOSSOM ], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.PINSIR, Species.MEGANIUM, Species.FARIGIRAF ]}, + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ROTOM ]}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []} }, [Biome.METROPOLIS]: { [BiomePoolTier.COMMON]: { - [TimeOfDay.DAWN]: [ { 1: [ Species.YAMPER ], 25: [ Species.BOLTUND ] } ], - [TimeOfDay.DAY]: [ { 1: [ Species.YAMPER ], 25: [ Species.BOLTUND ] } ], - [TimeOfDay.DUSK]: [ { 1: [ Species.PATRAT ], 20: [ Species.WATCHOG ] } ], - [TimeOfDay.NIGHT]: [ { 1: [ Species.HOUNDOUR ], 24: [ Species.HOUNDOOM ] }, { 1: [ Species.PATRAT ], 20: [ Species.WATCHOG ] } ], - [TimeOfDay.ALL]: [ { 1: [ Species.RATTATA ], 20: [ Species.RATICATE ] }, { 1: [ Species.ZIGZAGOON ], 20: [ Species.LINOONE ] }, { 1: [ Species.LILLIPUP ], 16: [ Species.HERDIER ], 32: [ Species.STOUTLAND ] } ] + [TimeOfDay.DAWN]: [{ 1: [ Species.YAMPER ], 25: [ Species.BOLTUND ]}], + [TimeOfDay.DAY]: [{ 1: [ Species.YAMPER ], 25: [ Species.BOLTUND ]}], + [TimeOfDay.DUSK]: [{ 1: [ Species.PATRAT ], 20: [ Species.WATCHOG ]}], + [TimeOfDay.NIGHT]: [{ 1: [ Species.HOUNDOUR ], 24: [ Species.HOUNDOOM ]}, { 1: [ Species.PATRAT ], 20: [ Species.WATCHOG ]}], + [TimeOfDay.ALL]: [{ 1: [ Species.RATTATA ], 20: [ Species.RATICATE ]}, { 1: [ Species.ZIGZAGOON ], 20: [ Species.LINOONE ]}, { 1: [ Species.LILLIPUP ], 16: [ Species.HERDIER ], 32: [ Species.STOUTLAND ]}] }, [BiomePoolTier.UNCOMMON]: { - [TimeOfDay.DAWN]: [ { 1: [ Species.PATRAT ], 20: [ Species.WATCHOG ] }, Species.INDEEDEE ], - [TimeOfDay.DAY]: [ { 1: [ Species.PATRAT ], 20: [ Species.WATCHOG ] }, Species.INDEEDEE ], - [TimeOfDay.DUSK]: [ { 1: [ Species.ESPURR ], 25: [ Species.MEOWSTIC ] } ], - [TimeOfDay.NIGHT]: [ { 1: [ Species.ESPURR ], 25: [ Species.MEOWSTIC ] } ], - [TimeOfDay.ALL]: [ Species.PIKACHU, { 1: [ Species.GLAMEOW ], 38: [ Species.PURUGLY ] }, Species.FURFROU, { 1: [ Species.FIDOUGH ], 26: [ Species.DACHSBUN ] }, Species.SQUAWKABILLY ] + [TimeOfDay.DAWN]: [{ 1: [ Species.PATRAT ], 20: [ Species.WATCHOG ]}, Species.INDEEDEE ], + [TimeOfDay.DAY]: [{ 1: [ Species.PATRAT ], 20: [ Species.WATCHOG ]}, Species.INDEEDEE ], + [TimeOfDay.DUSK]: [{ 1: [ Species.ESPURR ], 25: [ Species.MEOWSTIC ]}], + [TimeOfDay.NIGHT]: [{ 1: [ Species.ESPURR ], 25: [ Species.MEOWSTIC ]}], + [TimeOfDay.ALL]: [ Species.PIKACHU, { 1: [ Species.GLAMEOW ], 38: [ Species.PURUGLY ]}, Species.FURFROU, { 1: [ Species.FIDOUGH ], 26: [ Species.DACHSBUN ]}, Species.SQUAWKABILLY ] }, [BiomePoolTier.RARE]: { - [TimeOfDay.DAWN]: [ { 1: [ Species.TANDEMAUS ], 25: [ Species.MAUSHOLD ] } ], - [TimeOfDay.DAY]: [ { 1: [ Species.TANDEMAUS ], 25: [ Species.MAUSHOLD ] } ], + [TimeOfDay.DAWN]: [{ 1: [ Species.TANDEMAUS ], 25: [ Species.MAUSHOLD ]}], + [TimeOfDay.DAY]: [{ 1: [ Species.TANDEMAUS ], 25: [ Species.MAUSHOLD ]}], [TimeOfDay.DUSK]: [ Species.MORPEKO ], [TimeOfDay.NIGHT]: [ Species.MORPEKO ], - [TimeOfDay.ALL]: [ { 1: [ Species.VAROOM ], 40: [ Species.REVAVROOM ] } ] + [TimeOfDay.ALL]: [{ 1: [ Species.VAROOM ], 40: [ Species.REVAVROOM ]}] }, - [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.DITTO, Species.EEVEE, Species.SMEARGLE ] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.CASTFORM ] }, - [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [ Species.BOLTUND ], [TimeOfDay.DAY]: [ Species.BOLTUND ], [TimeOfDay.DUSK]: [ Species.MEOWSTIC ], [TimeOfDay.NIGHT]: [ Species.MEOWSTIC ], [TimeOfDay.ALL]: [ Species.STOUTLAND, Species.FURFROU, Species.DACHSBUN ] }, - [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [ Species.MAUSHOLD ], [TimeOfDay.DAY]: [ Species.MAUSHOLD ], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.CASTFORM, Species.REVAVROOM ] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] } + [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.DITTO, Species.EEVEE, Species.SMEARGLE ]}, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.CASTFORM ]}, + [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [ Species.BOLTUND ], [TimeOfDay.DAY]: [ Species.BOLTUND ], [TimeOfDay.DUSK]: [ Species.MEOWSTIC ], [TimeOfDay.NIGHT]: [ Species.MEOWSTIC ], [TimeOfDay.ALL]: [ Species.STOUTLAND, Species.FURFROU, Species.DACHSBUN ]}, + [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [ Species.MAUSHOLD ], [TimeOfDay.DAY]: [ Species.MAUSHOLD ], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.CASTFORM, Species.REVAVROOM ]}, + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []} }, [Biome.FOREST]: { [BiomePoolTier.COMMON]: { [TimeOfDay.DAWN]: [ Species.BUTTERFREE, - { 1: [ Species.BELLSPROUT ], 21: [ Species.WEEPINBELL ] }, - { 1: [ Species.COMBEE ], 21: [ Species.VESPIQUEN ] }, + { 1: [ Species.BELLSPROUT ], 21: [ Species.WEEPINBELL ]}, + { 1: [ Species.COMBEE ], 21: [ Species.VESPIQUEN ]}, Species.PETILIL, - { 1: [ Species.DEERLING ], 34: [ Species.SAWSBUCK ] }, + { 1: [ Species.DEERLING ], 34: [ Species.SAWSBUCK ]}, Species.VIVILLON ], [TimeOfDay.DAY]: [ Species.BUTTERFREE, - { 1: [ Species.BELLSPROUT ], 21: [ Species.WEEPINBELL ] }, + { 1: [ Species.BELLSPROUT ], 21: [ Species.WEEPINBELL ]}, Species.BEAUTIFLY, - { 1: [ Species.COMBEE ], 21: [ Species.VESPIQUEN ] }, + { 1: [ Species.COMBEE ], 21: [ Species.VESPIQUEN ]}, Species.PETILIL, - { 1: [ Species.DEERLING ], 34: [ Species.SAWSBUCK ] }, + { 1: [ Species.DEERLING ], 34: [ Species.SAWSBUCK ]}, Species.VIVILLON ], [TimeOfDay.DUSK]: [ Species.BEEDRILL, - { 1: [ Species.PINECO ], 31: [ Species.FORRETRESS ] }, - { 1: [ Species.SEEDOT ], 14: [ Species.NUZLEAF ] }, - { 1: [ Species.SHROOMISH ], 23: [ Species.BRELOOM ] }, - { 1: [ Species.VENIPEDE ], 22: [ Species.WHIRLIPEDE ], 30: [ Species.SCOLIPEDE ] } + { 1: [ Species.PINECO ], 31: [ Species.FORRETRESS ]}, + { 1: [ Species.SEEDOT ], 14: [ Species.NUZLEAF ]}, + { 1: [ Species.SHROOMISH ], 23: [ Species.BRELOOM ]}, + { 1: [ Species.VENIPEDE ], 22: [ Species.WHIRLIPEDE ], 30: [ Species.SCOLIPEDE ]} ], [TimeOfDay.NIGHT]: [ Species.BEEDRILL, - { 1: [ Species.VENONAT ], 31: [ Species.VENOMOTH ] }, - { 1: [ Species.SPINARAK ], 22: [ Species.ARIADOS ] }, - { 1: [ Species.PINECO ], 31: [ Species.FORRETRESS ] }, + { 1: [ Species.VENONAT ], 31: [ Species.VENOMOTH ]}, + { 1: [ Species.SPINARAK ], 22: [ Species.ARIADOS ]}, + { 1: [ Species.PINECO ], 31: [ Species.FORRETRESS ]}, Species.DUSTOX, - { 1: [ Species.SEEDOT ], 14: [ Species.NUZLEAF ] }, - { 1: [ Species.SHROOMISH ], 23: [ Species.BRELOOM ] }, - { 1: [ Species.VENIPEDE ], 22: [ Species.WHIRLIPEDE ], 30: [ Species.SCOLIPEDE ] } + { 1: [ Species.SEEDOT ], 14: [ Species.NUZLEAF ]}, + { 1: [ Species.SHROOMISH ], 23: [ Species.BRELOOM ]}, + { 1: [ Species.VENIPEDE ], 22: [ Species.WHIRLIPEDE ], 30: [ Species.SCOLIPEDE ]} ], - [TimeOfDay.ALL]: [ { 1: [ Species.TAROUNTULA ], 15: [ Species.SPIDOPS ] }, { 1: [ Species.NYMBLE ], 24: [ Species.LOKIX ] }, { 1: [ Species.SHROODLE ], 28: [ Species.GRAFAIAI ] } ] + [TimeOfDay.ALL]: [{ 1: [ Species.TAROUNTULA ], 15: [ Species.SPIDOPS ]}, { 1: [ Species.NYMBLE ], 24: [ Species.LOKIX ]}, { 1: [ Species.SHROODLE ], 28: [ Species.GRAFAIAI ]}] }, [BiomePoolTier.UNCOMMON]: { - [TimeOfDay.DAWN]: [ Species.ROSELIA, Species.MOTHIM, { 1: [ Species.SEWADDLE ], 20: [ Species.SWADLOON ], 30: [ Species.LEAVANNY ] } ], - [TimeOfDay.DAY]: [ Species.ROSELIA, Species.MOTHIM, { 1: [ Species.SEWADDLE ], 20: [ Species.SWADLOON ], 30: [ Species.LEAVANNY ] } ], - [TimeOfDay.DUSK]: [ { 1: [ Species.SPINARAK ], 22: [ Species.ARIADOS ] }, { 1: [ Species.DOTTLER ], 30: [ Species.ORBEETLE ] } ], - [TimeOfDay.NIGHT]: [ { 1: [ Species.HOOTHOOT ], 20: [ Species.NOCTOWL ] }, { 1: [ Species.ROCKRUFF ], 25: [ Species.LYCANROC ] }, { 1: [ Species.DOTTLER ], 30: [ Species.ORBEETLE ] } ], + [TimeOfDay.DAWN]: [ Species.ROSELIA, Species.MOTHIM, { 1: [ Species.SEWADDLE ], 20: [ Species.SWADLOON ], 30: [ Species.LEAVANNY ]}], + [TimeOfDay.DAY]: [ Species.ROSELIA, Species.MOTHIM, { 1: [ Species.SEWADDLE ], 20: [ Species.SWADLOON ], 30: [ Species.LEAVANNY ]}], + [TimeOfDay.DUSK]: [{ 1: [ Species.SPINARAK ], 22: [ Species.ARIADOS ]}, { 1: [ Species.DOTTLER ], 30: [ Species.ORBEETLE ]}], + [TimeOfDay.NIGHT]: [{ 1: [ Species.HOOTHOOT ], 20: [ Species.NOCTOWL ]}, { 1: [ Species.ROCKRUFF ], 25: [ Species.LYCANROC ]}, { 1: [ Species.DOTTLER ], 30: [ Species.ORBEETLE ]}], [TimeOfDay.ALL]: [ - { 1: [ Species.EKANS ], 22: [ Species.ARBOK ] }, - { 1: [ Species.TEDDIURSA ], 30: [ Species.URSARING ] }, - { 1: [ Species.BURMY ], 20: [ Species.WORMADAM ] }, - { 1: [ Species.PANSAGE ], 30: [ Species.SIMISAGE ] } + { 1: [ Species.EKANS ], 22: [ Species.ARBOK ]}, + { 1: [ Species.TEDDIURSA ], 30: [ Species.URSARING ]}, + { 1: [ Species.BURMY ], 20: [ Species.WORMADAM ]}, + { 1: [ Species.PANSAGE ], 30: [ Species.SIMISAGE ]} ] }, [BiomePoolTier.RARE]: { @@ -366,18 +366,18 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.NIGHT]: [ Species.SCYTHER ], [TimeOfDay.ALL]: [ Species.HERACROSS, - { 1: [ Species.TREECKO ], 16: [ Species.GROVYLE ], 36: [ Species.SCEPTILE ] }, + { 1: [ Species.TREECKO ], 16: [ Species.GROVYLE ], 36: [ Species.SCEPTILE ]}, Species.TROPIUS, Species.KARRABLAST, Species.SHELMET, - { 1: [ Species.CHESPIN ], 16: [ Species.QUILLADIN ], 36: [ Species.CHESNAUGHT ] }, - { 1: [ Species.ROWLET ], 17: [ Species.DARTRIX ], 34: [ Species.DECIDUEYE ] }, + { 1: [ Species.CHESPIN ], 16: [ Species.QUILLADIN ], 36: [ Species.CHESNAUGHT ]}, + { 1: [ Species.ROWLET ], 17: [ Species.DARTRIX ], 34: [ Species.DECIDUEYE ]}, Species.SQUAWKABILLY, - { 1: [ Species.TOEDSCOOL ], 30: [ Species.TOEDSCRUEL ] } + { 1: [ Species.TOEDSCOOL ], 30: [ Species.TOEDSCRUEL ]} ] }, - [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [ Species.BLOODMOON_URSALUNA ], [TimeOfDay.ALL]: [ Species.DURANT ] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.KARTANA, Species.WO_CHIEN ] }, + [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [ Species.BLOODMOON_URSALUNA ], [TimeOfDay.ALL]: [ Species.DURANT ]}, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.KARTANA, Species.WO_CHIEN ]}, [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [ Species.VICTREEBEL, Species.MOTHIM, Species.VESPIQUEN, Species.LILLIGANT, Species.SAWSBUCK ], [TimeOfDay.DAY]: [ Species.VICTREEBEL, Species.BEAUTIFLY, Species.MOTHIM, Species.VESPIQUEN, Species.LILLIGANT, Species.SAWSBUCK ], @@ -392,29 +392,29 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.NIGHT]: [ Species.LYCANROC, Species.BLOODMOON_URSALUNA ], [TimeOfDay.ALL]: [ Species.HERACROSS, Species.SCEPTILE, Species.ESCAVALIER, Species.ACCELGOR, Species.DURANT, Species.CHESNAUGHT, Species.DECIDUEYE, Species.TOEDSCRUEL ] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.KARTANA, Species.WO_CHIEN ] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.CALYREX ] } + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.KARTANA, Species.WO_CHIEN ]}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.CALYREX ]} }, [Biome.SEA]: { [BiomePoolTier.COMMON]: { - [TimeOfDay.DAWN]: [ { 1: [ Species.SLOWPOKE ], 37: [ Species.SLOWBRO ] }, { 1: [ Species.WINGULL ], 25: [ Species.PELIPPER ] }, Species.CRAMORANT, { 1: [ Species.FINIZEN ], 38: [ Species.PALAFIN ] } ], - [TimeOfDay.DAY]: [ { 1: [ Species.SLOWPOKE ], 37: [ Species.SLOWBRO ] }, { 1: [ Species.WINGULL ], 25: [ Species.PELIPPER ] }, Species.CRAMORANT, { 1: [ Species.FINIZEN ], 38: [ Species.PALAFIN ] } ], - [TimeOfDay.DUSK]: [ { 1: [ Species.INKAY ], 30: [ Species.MALAMAR ] } ], - [TimeOfDay.NIGHT]: [ { 1: [ Species.FINNEON ], 31: [ Species.LUMINEON ] }, { 1: [ Species.INKAY ], 30: [ Species.MALAMAR ] } ], - [TimeOfDay.ALL]: [ { 1: [ Species.TENTACOOL ], 30: [ Species.TENTACRUEL ] }, { 1: [ Species.MAGIKARP ], 20: [ Species.GYARADOS ] }, { 1: [ Species.BUIZEL ], 26: [ Species.FLOATZEL ] } ] + [TimeOfDay.DAWN]: [{ 1: [ Species.SLOWPOKE ], 37: [ Species.SLOWBRO ]}, { 1: [ Species.WINGULL ], 25: [ Species.PELIPPER ]}, Species.CRAMORANT, { 1: [ Species.FINIZEN ], 38: [ Species.PALAFIN ]}], + [TimeOfDay.DAY]: [{ 1: [ Species.SLOWPOKE ], 37: [ Species.SLOWBRO ]}, { 1: [ Species.WINGULL ], 25: [ Species.PELIPPER ]}, Species.CRAMORANT, { 1: [ Species.FINIZEN ], 38: [ Species.PALAFIN ]}], + [TimeOfDay.DUSK]: [{ 1: [ Species.INKAY ], 30: [ Species.MALAMAR ]}], + [TimeOfDay.NIGHT]: [{ 1: [ Species.FINNEON ], 31: [ Species.LUMINEON ]}, { 1: [ Species.INKAY ], 30: [ Species.MALAMAR ]}], + [TimeOfDay.ALL]: [{ 1: [ Species.TENTACOOL ], 30: [ Species.TENTACRUEL ]}, { 1: [ Species.MAGIKARP ], 20: [ Species.GYARADOS ]}, { 1: [ Species.BUIZEL ], 26: [ Species.FLOATZEL ]}] }, [BiomePoolTier.UNCOMMON]: { - [TimeOfDay.DAWN]: [ { 1: [ Species.STARYU ], 30: [ Species.STARMIE ] } ], - [TimeOfDay.DAY]: [ { 1: [ Species.STARYU ], 30: [ Species.STARMIE ] } ], - [TimeOfDay.DUSK]: [ { 1: [ Species.SLOWPOKE ], 37: [ Species.SLOWBRO ] }, Species.SHELLDER, { 1: [ Species.CARVANHA ], 30: [ Species.SHARPEDO ] } ], - [TimeOfDay.NIGHT]: [ { 1: [ Species.SLOWPOKE ], 37: [ Species.SLOWBRO ] }, Species.SHELLDER, { 1: [ Species.CHINCHOU ], 27: [ Species.LANTURN ] }, { 1: [ Species.CARVANHA ], 30: [ Species.SHARPEDO ] } ], + [TimeOfDay.DAWN]: [{ 1: [ Species.STARYU ], 30: [ Species.STARMIE ]}], + [TimeOfDay.DAY]: [{ 1: [ Species.STARYU ], 30: [ Species.STARMIE ]}], + [TimeOfDay.DUSK]: [{ 1: [ Species.SLOWPOKE ], 37: [ Species.SLOWBRO ]}, Species.SHELLDER, { 1: [ Species.CARVANHA ], 30: [ Species.SHARPEDO ]}], + [TimeOfDay.NIGHT]: [{ 1: [ Species.SLOWPOKE ], 37: [ Species.SLOWBRO ]}, Species.SHELLDER, { 1: [ Species.CHINCHOU ], 27: [ Species.LANTURN ]}, { 1: [ Species.CARVANHA ], 30: [ Species.SHARPEDO ]}], [TimeOfDay.ALL]: [ - { 1: [ Species.POLIWAG ], 25: [ Species.POLIWHIRL ] }, - { 1: [ Species.HORSEA ], 32: [ Species.SEADRA ] }, - { 1: [ Species.GOLDEEN ], 33: [ Species.SEAKING ] }, - { 1: [ Species.WAILMER ], 40: [ Species.WAILORD ] }, - { 1: [ Species.PANPOUR ], 30: [ Species.SIMIPOUR ] }, - { 1: [ Species.WATTREL ], 25: [ Species.KILOWATTREL ] } + { 1: [ Species.POLIWAG ], 25: [ Species.POLIWHIRL ]}, + { 1: [ Species.HORSEA ], 32: [ Species.SEADRA ]}, + { 1: [ Species.GOLDEEN ], 33: [ Species.SEAKING ]}, + { 1: [ Species.WAILMER ], 40: [ Species.WAILORD ]}, + { 1: [ Species.PANPOUR ], 30: [ Species.SIMIPOUR ]}, + { 1: [ Species.WATTREL ], 25: [ Species.KILOWATTREL ]} ] }, [BiomePoolTier.RARE]: { @@ -422,10 +422,10 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], - [TimeOfDay.ALL]: [ Species.LAPRAS, { 1: [ Species.PIPLUP ], 16: [ Species.PRINPLUP ], 36: [ Species.EMPOLEON ] }, { 1: [ Species.POPPLIO ], 17: [ Species.BRIONNE ], 34: [ Species.PRIMARINA ] } ] + [TimeOfDay.ALL]: [ Species.LAPRAS, { 1: [ Species.PIPLUP ], 16: [ Species.PRINPLUP ], 36: [ Species.EMPOLEON ]}, { 1: [ Species.POPPLIO ], 17: [ Species.BRIONNE ], 34: [ Species.PRIMARINA ]}] }, - [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.KINGDRA, Species.ROTOM, { 1: [ Species.TIRTOUGA ], 37: [ Species.CARRACOSTA ] } ] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] }, + [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.KINGDRA, Species.ROTOM, { 1: [ Species.TIRTOUGA ], 37: [ Species.CARRACOSTA ]}]}, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []}, [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [ Species.PELIPPER, Species.CRAMORANT, Species.PALAFIN ], [TimeOfDay.DAY]: [ Species.PELIPPER, Species.CRAMORANT, Species.PALAFIN ], @@ -433,34 +433,34 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.NIGHT]: [ Species.SHARPEDO, Species.LUMINEON, Species.MALAMAR ], [TimeOfDay.ALL]: [ Species.TENTACRUEL, Species.FLOATZEL, Species.SIMIPOUR, Species.KILOWATTREL ] }, - [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.KINGDRA, Species.EMPOLEON, Species.PRIMARINA ] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ROTOM ] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.LUGIA ] } + [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.KINGDRA, Species.EMPOLEON, Species.PRIMARINA ]}, + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ROTOM ]}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.LUGIA ]} }, [Biome.SWAMP]: { [BiomePoolTier.COMMON]: { - [TimeOfDay.DAWN]: [ { 1: [ Species.WOOPER ], 20: [ Species.QUAGSIRE ] }, { 1: [ Species.LOTAD ], 14: [ Species.LOMBRE ] } ], - [TimeOfDay.DAY]: [ { 1: [ Species.WOOPER ], 20: [ Species.QUAGSIRE ] }, { 1: [ Species.LOTAD ], 14: [ Species.LOMBRE ] } ], - [TimeOfDay.DUSK]: [ { 1: [ Species.EKANS ], 22: [ Species.ARBOK ] }, { 1: [ Species.PALDEA_WOOPER ], 20: [ Species.CLODSIRE ] } ], - [TimeOfDay.NIGHT]: [ { 1: [ Species.EKANS ], 22: [ Species.ARBOK ] }, { 1: [ Species.PALDEA_WOOPER ], 20: [ Species.CLODSIRE ] } ], + [TimeOfDay.DAWN]: [{ 1: [ Species.WOOPER ], 20: [ Species.QUAGSIRE ]}, { 1: [ Species.LOTAD ], 14: [ Species.LOMBRE ]}], + [TimeOfDay.DAY]: [{ 1: [ Species.WOOPER ], 20: [ Species.QUAGSIRE ]}, { 1: [ Species.LOTAD ], 14: [ Species.LOMBRE ]}], + [TimeOfDay.DUSK]: [{ 1: [ Species.EKANS ], 22: [ Species.ARBOK ]}, { 1: [ Species.PALDEA_WOOPER ], 20: [ Species.CLODSIRE ]}], + [TimeOfDay.NIGHT]: [{ 1: [ Species.EKANS ], 22: [ Species.ARBOK ]}, { 1: [ Species.PALDEA_WOOPER ], 20: [ Species.CLODSIRE ]}], [TimeOfDay.ALL]: [ - { 1: [ Species.POLIWAG ], 25: [ Species.POLIWHIRL ] }, - { 1: [ Species.GULPIN ], 26: [ Species.SWALOT ] }, - { 1: [ Species.SHELLOS ], 30: [ Species.GASTRODON ] }, - { 1: [ Species.TYMPOLE ], 25: [ Species.PALPITOAD ], 36: [ Species.SEISMITOAD ] } + { 1: [ Species.POLIWAG ], 25: [ Species.POLIWHIRL ]}, + { 1: [ Species.GULPIN ], 26: [ Species.SWALOT ]}, + { 1: [ Species.SHELLOS ], 30: [ Species.GASTRODON ]}, + { 1: [ Species.TYMPOLE ], 25: [ Species.PALPITOAD ], 36: [ Species.SEISMITOAD ]} ] }, [BiomePoolTier.UNCOMMON]: { - [TimeOfDay.DAWN]: [ { 1: [ Species.EKANS ], 22: [ Species.ARBOK ] } ], - [TimeOfDay.DAY]: [ { 1: [ Species.EKANS ], 22: [ Species.ARBOK ] } ], - [TimeOfDay.DUSK]: [ { 1: [ Species.CROAGUNK ], 37: [ Species.TOXICROAK ] } ], - [TimeOfDay.NIGHT]: [ { 1: [ Species.CROAGUNK ], 37: [ Species.TOXICROAK ] } ], + [TimeOfDay.DAWN]: [{ 1: [ Species.EKANS ], 22: [ Species.ARBOK ]}], + [TimeOfDay.DAY]: [{ 1: [ Species.EKANS ], 22: [ Species.ARBOK ]}], + [TimeOfDay.DUSK]: [{ 1: [ Species.CROAGUNK ], 37: [ Species.TOXICROAK ]}], + [TimeOfDay.NIGHT]: [{ 1: [ Species.CROAGUNK ], 37: [ Species.TOXICROAK ]}], [TimeOfDay.ALL]: [ - { 1: [ Species.PSYDUCK ], 33: [ Species.GOLDUCK ] }, - { 1: [ Species.BARBOACH ], 30: [ Species.WHISCASH ] }, - { 1: [ Species.SKORUPI ], 40: [ Species.DRAPION ] }, + { 1: [ Species.PSYDUCK ], 33: [ Species.GOLDUCK ]}, + { 1: [ Species.BARBOACH ], 30: [ Species.WHISCASH ]}, + { 1: [ Species.SKORUPI ], 40: [ Species.DRAPION ]}, Species.STUNFISK, - { 1: [ Species.MAREANIE ], 38: [ Species.TOXAPEX ] } + { 1: [ Species.MAREANIE ], 38: [ Species.TOXAPEX ]} ] }, [BiomePoolTier.RARE]: { @@ -468,16 +468,16 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], - [TimeOfDay.ALL]: [ { 1: [ Species.TOTODILE ], 18: [ Species.CROCONAW ], 30: [ Species.FERALIGATR ] }, { 1: [ Species.MUDKIP ], 16: [ Species.MARSHTOMP ], 36: [ Species.SWAMPERT ] } ] + [TimeOfDay.ALL]: [{ 1: [ Species.TOTODILE ], 18: [ Species.CROCONAW ], 30: [ Species.FERALIGATR ]}, { 1: [ Species.MUDKIP ], 16: [ Species.MARSHTOMP ], 36: [ Species.SWAMPERT ]}] }, [BiomePoolTier.SUPER_RARE]: { - [TimeOfDay.DAWN]: [ { 1: [ Species.GALAR_SLOWPOKE ], 40: [ Species.GALAR_SLOWBRO ] }, { 1: [ Species.HISUI_SLIGGOO ], 80: [ Species.HISUI_GOODRA ] } ], - [TimeOfDay.DAY]: [ { 1: [ Species.GALAR_SLOWPOKE ], 40: [ Species.GALAR_SLOWBRO ] }, { 1: [ Species.HISUI_SLIGGOO ], 80: [ Species.HISUI_GOODRA ] } ], + [TimeOfDay.DAWN]: [{ 1: [ Species.GALAR_SLOWPOKE ], 40: [ Species.GALAR_SLOWBRO ]}, { 1: [ Species.HISUI_SLIGGOO ], 80: [ Species.HISUI_GOODRA ]}], + [TimeOfDay.DAY]: [{ 1: [ Species.GALAR_SLOWPOKE ], 40: [ Species.GALAR_SLOWBRO ]}, { 1: [ Species.HISUI_SLIGGOO ], 80: [ Species.HISUI_GOODRA ]}], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.POLITOED, Species.GALAR_STUNFISK ] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.AZELF, Species.POIPOLE ] }, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.AZELF, Species.POIPOLE ]}, [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [ Species.QUAGSIRE, Species.LUDICOLO ], [TimeOfDay.DAY]: [ Species.QUAGSIRE, Species.LUDICOLO ], @@ -492,22 +492,22 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.FERALIGATR, Species.POLITOED, Species.SWAMPERT, Species.GALAR_STUNFISK ] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.AZELF, Species.NAGANADEL ] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] } + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.AZELF, Species.NAGANADEL ]}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []} }, [Biome.BEACH]: { [BiomePoolTier.COMMON]: { - [TimeOfDay.DAWN]: [ { 1: [ Species.STARYU ], 30: [ Species.STARMIE ] } ], - [TimeOfDay.DAY]: [ { 1: [ Species.STARYU ], 30: [ Species.STARMIE ] } ], + [TimeOfDay.DAWN]: [{ 1: [ Species.STARYU ], 30: [ Species.STARMIE ]}], + [TimeOfDay.DAY]: [{ 1: [ Species.STARYU ], 30: [ Species.STARMIE ]}], [TimeOfDay.DUSK]: [ Species.SHELLDER ], [TimeOfDay.NIGHT]: [ Species.SHELLDER ], [TimeOfDay.ALL]: [ - { 1: [ Species.KRABBY ], 28: [ Species.KINGLER ] }, - { 1: [ Species.CORPHISH ], 30: [ Species.CRAWDAUNT ] }, - { 1: [ Species.DWEBBLE ], 34: [ Species.CRUSTLE ] }, - { 1: [ Species.BINACLE ], 39: [ Species.BARBARACLE ] }, - { 1: [ Species.MAREANIE ], 38: [ Species.TOXAPEX ] }, - { 1: [ Species.WIGLETT ], 26: [ Species.WUGTRIO ] } + { 1: [ Species.KRABBY ], 28: [ Species.KINGLER ]}, + { 1: [ Species.CORPHISH ], 30: [ Species.CRAWDAUNT ]}, + { 1: [ Species.DWEBBLE ], 34: [ Species.CRUSTLE ]}, + { 1: [ Species.BINACLE ], 39: [ Species.BARBARACLE ]}, + { 1: [ Species.MAREANIE ], 38: [ Species.TOXAPEX ]}, + { 1: [ Species.WIGLETT ], 26: [ Species.WUGTRIO ]} ] }, [BiomePoolTier.UNCOMMON]: { @@ -515,11 +515,11 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], - [TimeOfDay.ALL]: [ { 1: [ Species.BURMY ], 20: [ Species.WORMADAM ] }, { 1: [ Species.CLAUNCHER ], 37: [ Species.CLAWITZER ] }, { 1: [ Species.SANDYGAST ], 42: [ Species.PALOSSAND ] } ] + [TimeOfDay.ALL]: [{ 1: [ Species.BURMY ], 20: [ Species.WORMADAM ]}, { 1: [ Species.CLAUNCHER ], 37: [ Species.CLAWITZER ]}, { 1: [ Species.SANDYGAST ], 42: [ Species.PALOSSAND ]}] }, - [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ { 1: [ Species.QUAXLY ], 16: [ Species.QUAXWELL ], 36: [ Species.QUAQUAVAL ] }, Species.TATSUGIRI ] }, - [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ { 1: [ Species.TIRTOUGA ], 37: [ Species.CARRACOSTA ] } ] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.CRESSELIA, Species.KELDEO, Species.TAPU_FINI ] }, + [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [{ 1: [ Species.QUAXLY ], 16: [ Species.QUAXWELL ], 36: [ Species.QUAQUAVAL ]}, Species.TATSUGIRI ]}, + [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [{ 1: [ Species.TIRTOUGA ], 37: [ Species.CARRACOSTA ]}]}, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.CRESSELIA, Species.KELDEO, Species.TAPU_FINI ]}, [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [ Species.STARMIE ], [TimeOfDay.DAY]: [ Species.STARMIE ], @@ -527,29 +527,29 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.NIGHT]: [ Species.CLOYSTER ], [TimeOfDay.ALL]: [ Species.KINGLER, Species.CRAWDAUNT, Species.WORMADAM, Species.CRUSTLE, Species.BARBARACLE, Species.CLAWITZER, Species.TOXAPEX, Species.PALOSSAND ] }, - [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.CARRACOSTA, Species.QUAQUAVAL ] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.CRESSELIA, Species.KELDEO, Species.TAPU_FINI ] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] } + [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.CARRACOSTA, Species.QUAQUAVAL ]}, + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.CRESSELIA, Species.KELDEO, Species.TAPU_FINI ]}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []} }, [Biome.LAKE]: { [BiomePoolTier.COMMON]: { - [TimeOfDay.DAWN]: [ { 1: [ Species.LOTAD ], 14: [ Species.LOMBRE ] }, { 1: [ Species.DUCKLETT ], 35: [ Species.SWANNA ] } ], - [TimeOfDay.DAY]: [ { 1: [ Species.LOTAD ], 14: [ Species.LOMBRE ] }, { 1: [ Species.DUCKLETT ], 35: [ Species.SWANNA ] } ], - [TimeOfDay.DUSK]: [ { 1: [ Species.MARILL ], 18: [ Species.AZUMARILL ] } ], - [TimeOfDay.NIGHT]: [ { 1: [ Species.MARILL ], 18: [ Species.AZUMARILL ] } ], + [TimeOfDay.DAWN]: [{ 1: [ Species.LOTAD ], 14: [ Species.LOMBRE ]}, { 1: [ Species.DUCKLETT ], 35: [ Species.SWANNA ]}], + [TimeOfDay.DAY]: [{ 1: [ Species.LOTAD ], 14: [ Species.LOMBRE ]}, { 1: [ Species.DUCKLETT ], 35: [ Species.SWANNA ]}], + [TimeOfDay.DUSK]: [{ 1: [ Species.MARILL ], 18: [ Species.AZUMARILL ]}], + [TimeOfDay.NIGHT]: [{ 1: [ Species.MARILL ], 18: [ Species.AZUMARILL ]}], [TimeOfDay.ALL]: [ - { 1: [ Species.PSYDUCK ], 33: [ Species.GOLDUCK ] }, - { 1: [ Species.GOLDEEN ], 33: [ Species.SEAKING ] }, - { 1: [ Species.MAGIKARP ], 20: [ Species.GYARADOS ] }, - { 1: [ Species.CHEWTLE ], 22: [ Species.DREDNAW ] } + { 1: [ Species.PSYDUCK ], 33: [ Species.GOLDUCK ]}, + { 1: [ Species.GOLDEEN ], 33: [ Species.SEAKING ]}, + { 1: [ Species.MAGIKARP ], 20: [ Species.GYARADOS ]}, + { 1: [ Species.CHEWTLE ], 22: [ Species.DREDNAW ]} ] }, [BiomePoolTier.UNCOMMON]: { - [TimeOfDay.DAWN]: [ { 1: [ Species.DEWPIDER ], 22: [ Species.ARAQUANID ] } ], - [TimeOfDay.DAY]: [ { 1: [ Species.DEWPIDER ], 22: [ Species.ARAQUANID ] } ], + [TimeOfDay.DAWN]: [{ 1: [ Species.DEWPIDER ], 22: [ Species.ARAQUANID ]}], + [TimeOfDay.DAY]: [{ 1: [ Species.DEWPIDER ], 22: [ Species.ARAQUANID ]}], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], - [TimeOfDay.ALL]: [ { 1: [ Species.SLOWPOKE ], 37: [ Species.SLOWBRO ] }, { 1: [ Species.WOOPER ], 20: [ Species.QUAGSIRE ] }, { 1: [ Species.SURSKIT ], 22: [ Species.MASQUERAIN ] }, Species.WISHIWASHI, Species.FLAMIGO ] + [TimeOfDay.ALL]: [{ 1: [ Species.SLOWPOKE ], 37: [ Species.SLOWBRO ]}, { 1: [ Species.WOOPER ], 20: [ Species.QUAGSIRE ]}, { 1: [ Species.SURSKIT ], 22: [ Species.MASQUERAIN ]}, Species.WISHIWASHI, Species.FLAMIGO ] }, [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], @@ -557,14 +557,14 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ - { 1: [ Species.SQUIRTLE ], 16: [ Species.WARTORTLE ], 36: [ Species.BLASTOISE ] }, - { 1: [ Species.OSHAWOTT ], 17: [ Species.DEWOTT ], 36: [ Species.SAMUROTT ] }, - { 1: [ Species.FROAKIE ], 16: [ Species.FROGADIER ], 36: [ Species.GRENINJA ] }, - { 1: [ Species.SOBBLE ], 16: [ Species.DRIZZILE ], 35: [ Species.INTELEON ] } + { 1: [ Species.SQUIRTLE ], 16: [ Species.WARTORTLE ], 36: [ Species.BLASTOISE ]}, + { 1: [ Species.OSHAWOTT ], 17: [ Species.DEWOTT ], 36: [ Species.SAMUROTT ]}, + { 1: [ Species.FROAKIE ], 16: [ Species.FROGADIER ], 36: [ Species.GRENINJA ]}, + { 1: [ Species.SOBBLE ], 16: [ Species.DRIZZILE ], 35: [ Species.INTELEON ]} ] }, - [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.VAPOREON, Species.SLOWKING ] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.SUICUNE, Species.MESPRIT ] }, + [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.VAPOREON, Species.SLOWKING ]}, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.SUICUNE, Species.MESPRIT ]}, [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [ Species.SWANNA, Species.ARAQUANID ], [TimeOfDay.DAY]: [ Species.SWANNA, Species.ARAQUANID ], @@ -572,9 +572,9 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.NIGHT]: [ Species.AZUMARILL ], [TimeOfDay.ALL]: [ Species.GOLDUCK, Species.SLOWBRO, Species.SEAKING, Species.GYARADOS, Species.MASQUERAIN, Species.WISHIWASHI, Species.DREDNAW ] }, - [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.BLASTOISE, Species.VAPOREON, Species.SLOWKING, Species.SAMUROTT, Species.GRENINJA, Species.INTELEON ] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.SUICUNE, Species.MESPRIT ] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] } + [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.BLASTOISE, Species.VAPOREON, Species.SLOWKING, Species.SAMUROTT, Species.GRENINJA, Species.INTELEON ]}, + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.SUICUNE, Species.MESPRIT ]}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []} }, [Biome.SEABED]: { [BiomePoolTier.COMMON]: { @@ -583,12 +583,12 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ - { 1: [ Species.CHINCHOU ], 27: [ Species.LANTURN ] }, + { 1: [ Species.CHINCHOU ], 27: [ Species.LANTURN ]}, Species.REMORAID, Species.CLAMPERL, Species.BASCULIN, - { 1: [ Species.FRILLISH ], 40: [ Species.JELLICENT ] }, - { 1: [ Species.ARROKUDA ], 26: [ Species.BARRASKEWDA ] }, + { 1: [ Species.FRILLISH ], 40: [ Species.JELLICENT ]}, + { 1: [ Species.ARROKUDA ], 26: [ Species.BARRASKEWDA ]}, Species.VELUZA ] }, @@ -598,12 +598,12 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ - { 1: [ Species.TENTACOOL ], 30: [ Species.TENTACRUEL ] }, + { 1: [ Species.TENTACOOL ], 30: [ Species.TENTACRUEL ]}, Species.SHELLDER, - { 1: [ Species.WAILMER ], 40: [ Species.WAILORD ] }, + { 1: [ Species.WAILMER ], 40: [ Species.WAILORD ]}, Species.LUVDISC, - { 1: [ Species.SHELLOS ], 30: [ Species.GASTRODON ] }, - { 1: [ Species.SKRELP ], 48: [ Species.DRAGALGE ] }, + { 1: [ Species.SHELLOS ], 30: [ Species.GASTRODON ]}, + { 1: [ Species.SKRELP ], 48: [ Species.DRAGALGE ]}, Species.PINCURCHIN, Species.DONDOZO ] @@ -613,7 +613,7 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], - [TimeOfDay.ALL]: [ Species.QWILFISH, Species.CORSOLA, Species.OCTILLERY, { 1: [ Species.MANTYKE ], 52: [ Species.MANTINE ] }, Species.ALOMOMOLA, { 1: [ Species.TYNAMO ], 39: [ Species.EELEKTRIK ] }, Species.DHELMISE ] + [TimeOfDay.ALL]: [ Species.QWILFISH, Species.CORSOLA, Species.OCTILLERY, { 1: [ Species.MANTYKE ], 52: [ Species.MANTINE ]}, Species.ALOMOMOLA, { 1: [ Species.TYNAMO ], 39: [ Species.EELEKTRIK ]}, Species.DHELMISE ] }, [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], @@ -621,16 +621,16 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ - { 1: [ Species.OMANYTE ], 40: [ Species.OMASTAR ] }, - { 1: [ Species.KABUTO ], 40: [ Species.KABUTOPS ] }, + { 1: [ Species.OMANYTE ], 40: [ Species.OMASTAR ]}, + { 1: [ Species.KABUTO ], 40: [ Species.KABUTOPS ]}, Species.RELICANTH, Species.PYUKUMUKU, - { 1: [ Species.GALAR_CORSOLA ], 38: [ Species.CURSOLA ] }, + { 1: [ Species.GALAR_CORSOLA ], 38: [ Species.CURSOLA ]}, Species.ARCTOVISH, Species.HISUI_QWILFISH ] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.FEEBAS, Species.NIHILEGO ] }, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.FEEBAS, Species.NIHILEGO ]}, [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], @@ -645,56 +645,56 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.OMASTAR, Species.KABUTOPS, Species.RELICANTH, Species.EELEKTROSS, Species.PYUKUMUKU, Species.DHELMISE, Species.CURSOLA, Species.ARCTOVISH, Species.BASCULEGION, Species.OVERQWIL ] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.MILOTIC, Species.NIHILEGO ] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.KYOGRE ] } + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.MILOTIC, Species.NIHILEGO ]}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.KYOGRE ]} }, [Biome.MOUNTAIN]: { [BiomePoolTier.COMMON]: { [TimeOfDay.DAWN]: [ - { 1: [ Species.TAILLOW ], 22: [ Species.SWELLOW ] }, - { 1: [ Species.SWABLU ], 35: [ Species.ALTARIA ] }, - { 1: [ Species.STARLY ], 14: [ Species.STARAVIA ], 34: [ Species.STARAPTOR ] }, - { 1: [ Species.PIDOVE ], 21: [ Species.TRANQUILL ], 32: [ Species.UNFEZANT ] }, - { 1: [ Species.FLETCHLING ], 17: [ Species.FLETCHINDER ], 35: [ Species.TALONFLAME ] } + { 1: [ Species.TAILLOW ], 22: [ Species.SWELLOW ]}, + { 1: [ Species.SWABLU ], 35: [ Species.ALTARIA ]}, + { 1: [ Species.STARLY ], 14: [ Species.STARAVIA ], 34: [ Species.STARAPTOR ]}, + { 1: [ Species.PIDOVE ], 21: [ Species.TRANQUILL ], 32: [ Species.UNFEZANT ]}, + { 1: [ Species.FLETCHLING ], 17: [ Species.FLETCHINDER ], 35: [ Species.TALONFLAME ]} ], [TimeOfDay.DAY]: [ - { 1: [ Species.TAILLOW ], 22: [ Species.SWELLOW ] }, - { 1: [ Species.SWABLU ], 35: [ Species.ALTARIA ] }, - { 1: [ Species.STARLY ], 14: [ Species.STARAVIA ], 34: [ Species.STARAPTOR ] }, - { 1: [ Species.PIDOVE ], 21: [ Species.TRANQUILL ], 32: [ Species.UNFEZANT ] }, - { 1: [ Species.FLETCHLING ], 17: [ Species.FLETCHINDER ], 35: [ Species.TALONFLAME ] } + { 1: [ Species.TAILLOW ], 22: [ Species.SWELLOW ]}, + { 1: [ Species.SWABLU ], 35: [ Species.ALTARIA ]}, + { 1: [ Species.STARLY ], 14: [ Species.STARAVIA ], 34: [ Species.STARAPTOR ]}, + { 1: [ Species.PIDOVE ], 21: [ Species.TRANQUILL ], 32: [ Species.UNFEZANT ]}, + { 1: [ Species.FLETCHLING ], 17: [ Species.FLETCHINDER ], 35: [ Species.TALONFLAME ]} ], - [TimeOfDay.DUSK]: [ { 1: [ Species.RHYHORN ], 42: [ Species.RHYDON ] }, { 1: [ Species.ARON ], 32: [ Species.LAIRON ], 42: [ Species.AGGRON ] }, { 1: [ Species.ROGGENROLA ], 25: [ Species.BOLDORE ] } ], - [TimeOfDay.NIGHT]: [ { 1: [ Species.RHYHORN ], 42: [ Species.RHYDON ] }, { 1: [ Species.ARON ], 32: [ Species.LAIRON ], 42: [ Species.AGGRON ] }, { 1: [ Species.ROGGENROLA ], 25: [ Species.BOLDORE ] } ], - [TimeOfDay.ALL]: [ { 1: [ Species.PIDGEY ], 18: [ Species.PIDGEOTTO ], 36: [ Species.PIDGEOT ] }, { 1: [ Species.SPEAROW ], 20: [ Species.FEAROW ] }, { 1: [ Species.SKIDDO ], 32: [ Species.GOGOAT ] } ] + [TimeOfDay.DUSK]: [{ 1: [ Species.RHYHORN ], 42: [ Species.RHYDON ]}, { 1: [ Species.ARON ], 32: [ Species.LAIRON ], 42: [ Species.AGGRON ]}, { 1: [ Species.ROGGENROLA ], 25: [ Species.BOLDORE ]}], + [TimeOfDay.NIGHT]: [{ 1: [ Species.RHYHORN ], 42: [ Species.RHYDON ]}, { 1: [ Species.ARON ], 32: [ Species.LAIRON ], 42: [ Species.AGGRON ]}, { 1: [ Species.ROGGENROLA ], 25: [ Species.BOLDORE ]}], + [TimeOfDay.ALL]: [{ 1: [ Species.PIDGEY ], 18: [ Species.PIDGEOTTO ], 36: [ Species.PIDGEOT ]}, { 1: [ Species.SPEAROW ], 20: [ Species.FEAROW ]}, { 1: [ Species.SKIDDO ], 32: [ Species.GOGOAT ]}] }, [BiomePoolTier.UNCOMMON]: { [TimeOfDay.DAWN]: [ - { 1: [ Species.RHYHORN ], 42: [ Species.RHYDON ] }, - { 1: [ Species.ARON ], 32: [ Species.LAIRON ], 42: [ Species.AGGRON ] }, - { 1: [ Species.ROGGENROLA ], 25: [ Species.BOLDORE ] }, - { 1: [ Species.RUFFLET ], 54: [ Species.BRAVIARY ] }, - { 1: [ Species.ROOKIDEE ], 18: [ Species.CORVISQUIRE ], 38: [ Species.CORVIKNIGHT ] }, - { 1: [ Species.FLITTLE ], 35: [ Species.ESPATHRA ] }, + { 1: [ Species.RHYHORN ], 42: [ Species.RHYDON ]}, + { 1: [ Species.ARON ], 32: [ Species.LAIRON ], 42: [ Species.AGGRON ]}, + { 1: [ Species.ROGGENROLA ], 25: [ Species.BOLDORE ]}, + { 1: [ Species.RUFFLET ], 54: [ Species.BRAVIARY ]}, + { 1: [ Species.ROOKIDEE ], 18: [ Species.CORVISQUIRE ], 38: [ Species.CORVIKNIGHT ]}, + { 1: [ Species.FLITTLE ], 35: [ Species.ESPATHRA ]}, Species.BOMBIRDIER ], [TimeOfDay.DAY]: [ - { 1: [ Species.RHYHORN ], 42: [ Species.RHYDON ] }, - { 1: [ Species.ARON ], 32: [ Species.LAIRON ], 42: [ Species.AGGRON ] }, - { 1: [ Species.ROGGENROLA ], 25: [ Species.BOLDORE ] }, - { 1: [ Species.RUFFLET ], 54: [ Species.BRAVIARY ] }, - { 1: [ Species.ROOKIDEE ], 18: [ Species.CORVISQUIRE ], 38: [ Species.CORVIKNIGHT ] }, - { 1: [ Species.FLITTLE ], 35: [ Species.ESPATHRA ] }, + { 1: [ Species.RHYHORN ], 42: [ Species.RHYDON ]}, + { 1: [ Species.ARON ], 32: [ Species.LAIRON ], 42: [ Species.AGGRON ]}, + { 1: [ Species.ROGGENROLA ], 25: [ Species.BOLDORE ]}, + { 1: [ Species.RUFFLET ], 54: [ Species.BRAVIARY ]}, + { 1: [ Species.ROOKIDEE ], 18: [ Species.CORVISQUIRE ], 38: [ Species.CORVIKNIGHT ]}, + { 1: [ Species.FLITTLE ], 35: [ Species.ESPATHRA ]}, Species.BOMBIRDIER ], - [TimeOfDay.DUSK]: [ { 1: [ Species.VULLABY ], 54: [ Species.MANDIBUZZ ] } ], - [TimeOfDay.NIGHT]: [ { 1: [ Species.VULLABY ], 54: [ Species.MANDIBUZZ ] } ], + [TimeOfDay.DUSK]: [{ 1: [ Species.VULLABY ], 54: [ Species.MANDIBUZZ ]}], + [TimeOfDay.NIGHT]: [{ 1: [ Species.VULLABY ], 54: [ Species.MANDIBUZZ ]}], [TimeOfDay.ALL]: [ - { 1: [ Species.MACHOP ], 28: [ Species.MACHOKE ] }, - { 1: [ Species.GEODUDE ], 25: [ Species.GRAVELER ] }, - { 1: [ Species.NATU ], 25: [ Species.XATU ] }, - { 1: [ Species.SLUGMA ], 38: [ Species.MAGCARGO ] }, - { 1: [ Species.NACLI ], 24: [ Species.NACLSTACK ], 38: [ Species.GARGANACL ] } + { 1: [ Species.MACHOP ], 28: [ Species.MACHOKE ]}, + { 1: [ Species.GEODUDE ], 25: [ Species.GRAVELER ]}, + { 1: [ Species.NATU ], 25: [ Species.XATU ]}, + { 1: [ Species.SLUGMA ], 38: [ Species.MAGCARGO ]}, + { 1: [ Species.NACLI ], 24: [ Species.NACLSTACK ], 38: [ Species.GARGANACL ]} ] }, [BiomePoolTier.RARE]: { @@ -702,7 +702,7 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [ Species.MURKROW ], - [TimeOfDay.ALL]: [ Species.SKARMORY, { 1: [ Species.TORCHIC ], 16: [ Species.COMBUSKEN ], 36: [ Species.BLAZIKEN ] }, { 1: [ Species.SPOINK ], 32: [ Species.GRUMPIG ] }, Species.HAWLUCHA, Species.KLAWF ] + [TimeOfDay.ALL]: [ Species.SKARMORY, { 1: [ Species.TORCHIC ], 16: [ Species.COMBUSKEN ], 36: [ Species.BLAZIKEN ]}, { 1: [ Species.SPOINK ], 32: [ Species.GRUMPIG ]}, Species.HAWLUCHA, Species.KLAWF ] }, [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], @@ -710,16 +710,16 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ - { 1: [ Species.LARVITAR ], 30: [ Species.PUPITAR ] }, - { 1: [ Species.CRANIDOS ], 30: [ Species.RAMPARDOS ] }, - { 1: [ Species.SHIELDON ], 30: [ Species.BASTIODON ] }, - { 1: [ Species.GIBLE ], 24: [ Species.GABITE ], 48: [ Species.GARCHOMP ] }, + { 1: [ Species.LARVITAR ], 30: [ Species.PUPITAR ]}, + { 1: [ Species.CRANIDOS ], 30: [ Species.RAMPARDOS ]}, + { 1: [ Species.SHIELDON ], 30: [ Species.BASTIODON ]}, + { 1: [ Species.GIBLE ], 24: [ Species.GABITE ], 48: [ Species.GARCHOMP ]}, Species.ROTOM, Species.ARCHEOPS, - { 1: [ Species.AXEW ], 38: [ Species.FRAXURE ] } + { 1: [ Species.AXEW ], 38: [ Species.FRAXURE ]} ] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.TORNADUS, Species.TING_LU, Species.OGERPON ] }, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.TORNADUS, Species.TING_LU, Species.OGERPON ]}, [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [ Species.SWELLOW, Species.ALTARIA, Species.STARAPTOR, Species.UNFEZANT, Species.BRAVIARY, Species.TALONFLAME, Species.CORVIKNIGHT, Species.ESPATHRA ], [TimeOfDay.DAY]: [ Species.SWELLOW, Species.ALTARIA, Species.STARAPTOR, Species.UNFEZANT, Species.BRAVIARY, Species.TALONFLAME, Species.CORVIKNIGHT, Species.ESPATHRA ], @@ -727,39 +727,39 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.NIGHT]: [ Species.MANDIBUZZ ], [TimeOfDay.ALL]: [ Species.PIDGEOT, Species.FEAROW, Species.SKARMORY, Species.AGGRON, Species.GOGOAT, Species.GARGANACL ] }, - [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [ Species.HISUI_BRAVIARY ], [TimeOfDay.DAY]: [ Species.HISUI_BRAVIARY ], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.BLAZIKEN, Species.RAMPARDOS, Species.BASTIODON, Species.HAWLUCHA ] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ROTOM, Species.TORNADUS, Species.TING_LU, Species.OGERPON ] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.HO_OH ] } + [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [ Species.HISUI_BRAVIARY ], [TimeOfDay.DAY]: [ Species.HISUI_BRAVIARY ], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.BLAZIKEN, Species.RAMPARDOS, Species.BASTIODON, Species.HAWLUCHA ]}, + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ROTOM, Species.TORNADUS, Species.TING_LU, Species.OGERPON ]}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.HO_OH ]} }, [Biome.BADLANDS]: { [BiomePoolTier.COMMON]: { - [TimeOfDay.DAWN]: [ { 1: [ Species.PHANPY ], 25: [ Species.DONPHAN ] } ], - [TimeOfDay.DAY]: [ { 1: [ Species.PHANPY ], 25: [ Species.DONPHAN ] } ], + [TimeOfDay.DAWN]: [{ 1: [ Species.PHANPY ], 25: [ Species.DONPHAN ]}], + [TimeOfDay.DAY]: [{ 1: [ Species.PHANPY ], 25: [ Species.DONPHAN ]}], [TimeOfDay.DUSK]: [], - [TimeOfDay.NIGHT]: [ { 1: [ Species.CUBONE ], 28: [ Species.MAROWAK ] } ], + [TimeOfDay.NIGHT]: [{ 1: [ Species.CUBONE ], 28: [ Species.MAROWAK ]}], [TimeOfDay.ALL]: [ - { 1: [ Species.DIGLETT ], 26: [ Species.DUGTRIO ] }, - { 1: [ Species.GEODUDE ], 25: [ Species.GRAVELER ] }, - { 1: [ Species.RHYHORN ], 42: [ Species.RHYDON ] }, - { 1: [ Species.DRILBUR ], 31: [ Species.EXCADRILL ] }, - { 1: [ Species.MUDBRAY ], 30: [ Species.MUDSDALE ] } + { 1: [ Species.DIGLETT ], 26: [ Species.DUGTRIO ]}, + { 1: [ Species.GEODUDE ], 25: [ Species.GRAVELER ]}, + { 1: [ Species.RHYHORN ], 42: [ Species.RHYDON ]}, + { 1: [ Species.DRILBUR ], 31: [ Species.EXCADRILL ]}, + { 1: [ Species.MUDBRAY ], 30: [ Species.MUDSDALE ]} ] }, [BiomePoolTier.UNCOMMON]: { - [TimeOfDay.DAWN]: [ { 1: [ Species.SIZZLIPEDE ], 28: [ Species.CENTISKORCH ] }, { 1: [ Species.CAPSAKID ], 30: [ Species.SCOVILLAIN ] } ], - [TimeOfDay.DAY]: [ { 1: [ Species.SIZZLIPEDE ], 28: [ Species.CENTISKORCH ] }, { 1: [ Species.CAPSAKID ], 30: [ Species.SCOVILLAIN ] } ], + [TimeOfDay.DAWN]: [{ 1: [ Species.SIZZLIPEDE ], 28: [ Species.CENTISKORCH ]}, { 1: [ Species.CAPSAKID ], 30: [ Species.SCOVILLAIN ]}], + [TimeOfDay.DAY]: [{ 1: [ Species.SIZZLIPEDE ], 28: [ Species.CENTISKORCH ]}, { 1: [ Species.CAPSAKID ], 30: [ Species.SCOVILLAIN ]}], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ - { 1: [ Species.SANDSHREW ], 22: [ Species.SANDSLASH ] }, - { 1: [ Species.NUMEL ], 33: [ Species.CAMERUPT ] }, - { 1: [ Species.ROGGENROLA ], 25: [ Species.BOLDORE ] }, - { 1: [ Species.CUFANT ], 34: [ Species.COPPERAJAH ] } + { 1: [ Species.SANDSHREW ], 22: [ Species.SANDSLASH ]}, + { 1: [ Species.NUMEL ], 33: [ Species.CAMERUPT ]}, + { 1: [ Species.ROGGENROLA ], 25: [ Species.BOLDORE ]}, + { 1: [ Species.CUFANT ], 34: [ Species.COPPERAJAH ]} ] }, - [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ONIX, Species.GLIGAR, { 1: [ Species.POLTCHAGEIST ], 30: [ Species.SINISTCHA ] } ] }, - [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.LANDORUS, Species.OKIDOGI ] }, + [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ONIX, Species.GLIGAR, { 1: [ Species.POLTCHAGEIST ], 30: [ Species.SINISTCHA ]}]}, + [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []}, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.LANDORUS, Species.OKIDOGI ]}, [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [ Species.DONPHAN, Species.CENTISKORCH, Species.SCOVILLAIN ], [TimeOfDay.DAY]: [ Species.DONPHAN, Species.CENTISKORCH, Species.SCOVILLAIN ], @@ -767,9 +767,9 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.NIGHT]: [ Species.MAROWAK ], [TimeOfDay.ALL]: [ Species.DUGTRIO, Species.GOLEM, Species.RHYPERIOR, Species.GLISCOR, Species.EXCADRILL, Species.MUDSDALE, Species.COPPERAJAH ] }, - [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.STEELIX, Species.SINISTCHA ] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.LANDORUS, Species.OKIDOGI ] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.GROUDON ] } + [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.STEELIX, Species.SINISTCHA ]}, + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.LANDORUS, Species.OKIDOGI ]}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.GROUDON ]} }, [Biome.CAVE]: { [BiomePoolTier.COMMON]: { @@ -778,27 +778,27 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ - { 1: [ Species.ZUBAT ], 22: [ Species.GOLBAT ] }, - { 1: [ Species.PARAS ], 24: [ Species.PARASECT ] }, - { 1: [ Species.TEDDIURSA ], 30: [ Species.URSARING ] }, - { 1: [ Species.WHISMUR ], 20: [ Species.LOUDRED ], 40: [ Species.EXPLOUD ] }, - { 1: [ Species.ROGGENROLA ], 25: [ Species.BOLDORE ] }, - { 1: [ Species.WOOBAT ], 20: [ Species.SWOOBAT ] }, - { 1: [ Species.BUNNELBY ], 20: [ Species.DIGGERSBY ] }, - { 1: [ Species.NACLI ], 24: [ Species.NACLSTACK ], 38: [ Species.GARGANACL ] } + { 1: [ Species.ZUBAT ], 22: [ Species.GOLBAT ]}, + { 1: [ Species.PARAS ], 24: [ Species.PARASECT ]}, + { 1: [ Species.TEDDIURSA ], 30: [ Species.URSARING ]}, + { 1: [ Species.WHISMUR ], 20: [ Species.LOUDRED ], 40: [ Species.EXPLOUD ]}, + { 1: [ Species.ROGGENROLA ], 25: [ Species.BOLDORE ]}, + { 1: [ Species.WOOBAT ], 20: [ Species.SWOOBAT ]}, + { 1: [ Species.BUNNELBY ], 20: [ Species.DIGGERSBY ]}, + { 1: [ Species.NACLI ], 24: [ Species.NACLSTACK ], 38: [ Species.GARGANACL ]} ] }, [BiomePoolTier.UNCOMMON]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], - [TimeOfDay.DUSK]: [ { 1: [ Species.ROCKRUFF ], 25: [ Species.LYCANROC ] } ], + [TimeOfDay.DUSK]: [{ 1: [ Species.ROCKRUFF ], 25: [ Species.LYCANROC ]}], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ - { 1: [ Species.GEODUDE ], 25: [ Species.GRAVELER ] }, - { 1: [ Species.MAKUHITA ], 24: [ Species.HARIYAMA ] }, + { 1: [ Species.GEODUDE ], 25: [ Species.GRAVELER ]}, + { 1: [ Species.MAKUHITA ], 24: [ Species.HARIYAMA ]}, Species.NOSEPASS, - { 1: [ Species.NOIBAT ], 48: [ Species.NOIVERN ] }, - { 1: [ Species.WIMPOD ], 30: [ Species.GOLISOPOD ] } + { 1: [ Species.NOIBAT ], 48: [ Species.NOIVERN ]}, + { 1: [ Species.WIMPOD ], 30: [ Species.GOLISOPOD ]} ] }, [BiomePoolTier.RARE]: { @@ -806,10 +806,10 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], - [TimeOfDay.ALL]: [ Species.ONIX, { 1: [ Species.FERROSEED ], 40: [ Species.FERROTHORN ] }, Species.CARBINK, { 1: [ Species.GLIMMET ], 35: [ Species.GLIMMORA ] } ] + [TimeOfDay.ALL]: [ Species.ONIX, { 1: [ Species.FERROSEED ], 40: [ Species.FERROTHORN ]}, Species.CARBINK, { 1: [ Species.GLIMMET ], 35: [ Species.GLIMMORA ]}] }, - [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.SHUCKLE ] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.UXIE ] }, + [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.SHUCKLE ]}, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.UXIE ]}, [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], @@ -817,34 +817,34 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.PARASECT, Species.ONIX, Species.CROBAT, Species.URSARING, Species.EXPLOUD, Species.PROBOPASS, Species.GIGALITH, Species.SWOOBAT, Species.DIGGERSBY, Species.NOIVERN, Species.GOLISOPOD, Species.GARGANACL ] }, - [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [ Species.LYCANROC ], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.SHUCKLE, Species.FERROTHORN, Species.GLIMMORA ] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.UXIE ] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.TERAPAGOS ] } + [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [ Species.LYCANROC ], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.SHUCKLE, Species.FERROTHORN, Species.GLIMMORA ]}, + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.UXIE ]}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.TERAPAGOS ]} }, [Biome.DESERT]: { [BiomePoolTier.COMMON]: { - [TimeOfDay.DAWN]: [ Species.TRAPINCH, { 1: [ Species.HIPPOPOTAS ], 34: [ Species.HIPPOWDON ] }, { 1: [ Species.RELLOR ], 29: [ Species.RABSCA ] } ], - [TimeOfDay.DAY]: [ Species.TRAPINCH, { 1: [ Species.HIPPOPOTAS ], 34: [ Species.HIPPOWDON ] }, { 1: [ Species.RELLOR ], 29: [ Species.RABSCA ] } ], - [TimeOfDay.DUSK]: [ { 1: [ Species.CACNEA ], 32: [ Species.CACTURNE ] }, { 1: [ Species.SANDILE ], 29: [ Species.KROKOROK ], 40: [ Species.KROOKODILE ] } ], - [TimeOfDay.NIGHT]: [ { 1: [ Species.CACNEA ], 32: [ Species.CACTURNE ] }, { 1: [ Species.SANDILE ], 29: [ Species.KROKOROK ], 40: [ Species.KROOKODILE ] } ], - [TimeOfDay.ALL]: [ { 1: [ Species.SANDSHREW ], 22: [ Species.SANDSLASH ] }, { 1: [ Species.SKORUPI ], 40: [ Species.DRAPION ] }, { 1: [ Species.SILICOBRA ], 36: [ Species.SANDACONDA ] } ] + [TimeOfDay.DAWN]: [ Species.TRAPINCH, { 1: [ Species.HIPPOPOTAS ], 34: [ Species.HIPPOWDON ]}, { 1: [ Species.RELLOR ], 29: [ Species.RABSCA ]}], + [TimeOfDay.DAY]: [ Species.TRAPINCH, { 1: [ Species.HIPPOPOTAS ], 34: [ Species.HIPPOWDON ]}, { 1: [ Species.RELLOR ], 29: [ Species.RABSCA ]}], + [TimeOfDay.DUSK]: [{ 1: [ Species.CACNEA ], 32: [ Species.CACTURNE ]}, { 1: [ Species.SANDILE ], 29: [ Species.KROKOROK ], 40: [ Species.KROOKODILE ]}], + [TimeOfDay.NIGHT]: [{ 1: [ Species.CACNEA ], 32: [ Species.CACTURNE ]}, { 1: [ Species.SANDILE ], 29: [ Species.KROKOROK ], 40: [ Species.KROOKODILE ]}], + [TimeOfDay.ALL]: [{ 1: [ Species.SANDSHREW ], 22: [ Species.SANDSLASH ]}, { 1: [ Species.SKORUPI ], 40: [ Species.DRAPION ]}, { 1: [ Species.SILICOBRA ], 36: [ Species.SANDACONDA ]}] }, [BiomePoolTier.UNCOMMON]: { - [TimeOfDay.DAWN]: [ { 1: [ Species.SANDILE ], 29: [ Species.KROKOROK ], 40: [ Species.KROOKODILE ] }, Species.HELIOPTILE ], - [TimeOfDay.DAY]: [ { 1: [ Species.SANDILE ], 29: [ Species.KROKOROK ], 40: [ Species.KROOKODILE ] }, Species.HELIOPTILE ], + [TimeOfDay.DAWN]: [{ 1: [ Species.SANDILE ], 29: [ Species.KROKOROK ], 40: [ Species.KROOKODILE ]}, Species.HELIOPTILE ], + [TimeOfDay.DAY]: [{ 1: [ Species.SANDILE ], 29: [ Species.KROKOROK ], 40: [ Species.KROOKODILE ]}, Species.HELIOPTILE ], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], - [TimeOfDay.ALL]: [ Species.MARACTUS, { 1: [ Species.BRAMBLIN ], 30: [ Species.BRAMBLEGHAST ] }, Species.ORTHWORM ] + [TimeOfDay.ALL]: [ Species.MARACTUS, { 1: [ Species.BRAMBLIN ], 30: [ Species.BRAMBLEGHAST ]}, Species.ORTHWORM ] }, [BiomePoolTier.RARE]: { - [TimeOfDay.DAWN]: [ { 1: [ Species.VIBRAVA ], 45: [ Species.FLYGON ] } ], - [TimeOfDay.DAY]: [ { 1: [ Species.VIBRAVA ], 45: [ Species.FLYGON ] } ], + [TimeOfDay.DAWN]: [{ 1: [ Species.VIBRAVA ], 45: [ Species.FLYGON ]}], + [TimeOfDay.DAY]: [{ 1: [ Species.VIBRAVA ], 45: [ Species.FLYGON ]}], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], - [TimeOfDay.ALL]: [ { 1: [ Species.DARUMAKA ], 35: [ Species.DARMANITAN ] } ] + [TimeOfDay.ALL]: [{ 1: [ Species.DARUMAKA ], 35: [ Species.DARMANITAN ]}] }, - [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ { 1: [ Species.LILEEP ], 40: [ Species.CRADILY ] }, { 1: [ Species.ANORITH ], 40: [ Species.ARMALDO ] } ] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.REGIROCK, Species.TAPU_BULU, Species.PHEROMOSA ] }, + [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [{ 1: [ Species.LILEEP ], 40: [ Species.CRADILY ]}, { 1: [ Species.ANORITH ], 40: [ Species.ARMALDO ]}]}, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.REGIROCK, Species.TAPU_BULU, Species.PHEROMOSA ]}, [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [ Species.HIPPOWDON, Species.HELIOLISK, Species.RABSCA ], [TimeOfDay.DAY]: [ Species.HIPPOWDON, Species.HELIOLISK, Species.RABSCA ], @@ -852,9 +852,9 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.NIGHT]: [ Species.CACTURNE, Species.KROOKODILE ], [TimeOfDay.ALL]: [ Species.SANDSLASH, Species.DRAPION, Species.DARMANITAN, Species.MARACTUS, Species.SANDACONDA, Species.BRAMBLEGHAST ] }, - [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.CRADILY, Species.ARMALDO ] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.REGIROCK, Species.TAPU_BULU, Species.PHEROMOSA ] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] } + [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.CRADILY, Species.ARMALDO ]}, + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.REGIROCK, Species.TAPU_BULU, Species.PHEROMOSA ]}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []} }, [Biome.ICE_CAVE]: { [BiomePoolTier.COMMON]: { @@ -863,14 +863,14 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ - { 1: [ Species.SEEL ], 34: [ Species.DEWGONG ] }, - { 1: [ Species.SWINUB ], 33: [ Species.PILOSWINE ] }, - { 1: [ Species.SNOVER ], 40: [ Species.ABOMASNOW ] }, - { 1: [ Species.VANILLITE ], 35: [ Species.VANILLISH ], 47: [ Species.VANILLUXE ] }, - { 1: [ Species.CUBCHOO ], 37: [ Species.BEARTIC ] }, - { 1: [ Species.BERGMITE ], 37: [ Species.AVALUGG ] }, + { 1: [ Species.SEEL ], 34: [ Species.DEWGONG ]}, + { 1: [ Species.SWINUB ], 33: [ Species.PILOSWINE ]}, + { 1: [ Species.SNOVER ], 40: [ Species.ABOMASNOW ]}, + { 1: [ Species.VANILLITE ], 35: [ Species.VANILLISH ], 47: [ Species.VANILLUXE ]}, + { 1: [ Species.CUBCHOO ], 37: [ Species.BEARTIC ]}, + { 1: [ Species.BERGMITE ], 37: [ Species.AVALUGG ]}, Species.CRABRAWLER, - { 1: [ Species.SNOM ], 20: [ Species.FROSMOTH ] } + { 1: [ Species.SNOM ], 20: [ Species.FROSMOTH ]} ] }, [BiomePoolTier.UNCOMMON]: { @@ -880,15 +880,15 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.SNEASEL, - { 1: [ Species.SNORUNT ], 42: [ Species.GLALIE ] }, - { 1: [ Species.SPHEAL ], 32: [ Species.SEALEO ], 44: [ Species.WALREIN ] }, + { 1: [ Species.SNORUNT ], 42: [ Species.GLALIE ]}, + { 1: [ Species.SPHEAL ], 32: [ Species.SEALEO ], 44: [ Species.WALREIN ]}, Species.EISCUE, - { 1: [ Species.CETODDLE ], 30: [ Species.CETITAN ] } + { 1: [ Species.CETODDLE ], 30: [ Species.CETITAN ]} ] }, - [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.JYNX, Species.LAPRAS, Species.FROSLASS, Species.CRYOGONAL ] }, - [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.DELIBIRD, Species.ROTOM, { 1: [ Species.AMAURA ], 59: [ Species.AURORUS ] } ] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ARTICUNO, Species.REGICE ] }, + [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.JYNX, Species.LAPRAS, Species.FROSLASS, Species.CRYOGONAL ]}, + [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.DELIBIRD, Species.ROTOM, { 1: [ Species.AMAURA ], 59: [ Species.AURORUS ]}]}, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ARTICUNO, Species.REGICE ]}, [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], @@ -896,46 +896,46 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.DEWGONG, Species.GLALIE, Species.WALREIN, Species.WEAVILE, Species.MAMOSWINE, Species.FROSLASS, Species.VANILLUXE, Species.BEARTIC, Species.CRYOGONAL, Species.AVALUGG, Species.CRABOMINABLE, Species.CETITAN ] }, - [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.JYNX, Species.LAPRAS, Species.GLACEON, Species.AURORUS ] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ARTICUNO, Species.REGICE, Species.ROTOM ] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.KYUREM ] } + [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.JYNX, Species.LAPRAS, Species.GLACEON, Species.AURORUS ]}, + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ARTICUNO, Species.REGICE, Species.ROTOM ]}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.KYUREM ]} }, [Biome.MEADOW]: { [BiomePoolTier.COMMON]: { - [TimeOfDay.DAWN]: [ { 1: [ Species.LEDYBA ], 18: [ Species.LEDIAN ] }, Species.ROSELIA, Species.COTTONEE, Species.MINCCINO ], + [TimeOfDay.DAWN]: [{ 1: [ Species.LEDYBA ], 18: [ Species.LEDIAN ]}, Species.ROSELIA, Species.COTTONEE, Species.MINCCINO ], [TimeOfDay.DAY]: [ Species.ROSELIA, Species.COTTONEE, Species.MINCCINO ], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ - { 1: [ Species.BLITZLE ], 27: [ Species.ZEBSTRIKA ] }, - { 1: [ Species.FLABEBE ], 19: [ Species.FLOETTE ] }, - { 1: [ Species.CUTIEFLY ], 25: [ Species.RIBOMBEE ] }, - { 1: [ Species.GOSSIFLEUR ], 20: [ Species.ELDEGOSS ] }, - { 1: [ Species.WOOLOO ], 24: [ Species.DUBWOOL ] } + { 1: [ Species.BLITZLE ], 27: [ Species.ZEBSTRIKA ]}, + { 1: [ Species.FLABEBE ], 19: [ Species.FLOETTE ]}, + { 1: [ Species.CUTIEFLY ], 25: [ Species.RIBOMBEE ]}, + { 1: [ Species.GOSSIFLEUR ], 20: [ Species.ELDEGOSS ]}, + { 1: [ Species.WOOLOO ], 24: [ Species.DUBWOOL ]} ] }, [BiomePoolTier.UNCOMMON]: { [TimeOfDay.DAWN]: [ - { 1: [ Species.PONYTA ], 40: [ Species.RAPIDASH ] }, - { 1: [ Species.SNUBBULL ], 23: [ Species.GRANBULL ] }, - { 1: [ Species.SKITTY ], 30: [ Species.DELCATTY ] }, + { 1: [ Species.PONYTA ], 40: [ Species.RAPIDASH ]}, + { 1: [ Species.SNUBBULL ], 23: [ Species.GRANBULL ]}, + { 1: [ Species.SKITTY ], 30: [ Species.DELCATTY ]}, Species.BOUFFALANT, - { 1: [ Species.SMOLIV ], 25: [ Species.DOLLIV ], 35: [ Species.ARBOLIVA ] } + { 1: [ Species.SMOLIV ], 25: [ Species.DOLLIV ], 35: [ Species.ARBOLIVA ]} ], [TimeOfDay.DAY]: [ - { 1: [ Species.PONYTA ], 40: [ Species.RAPIDASH ] }, - { 1: [ Species.SNUBBULL ], 23: [ Species.GRANBULL ] }, - { 1: [ Species.SKITTY ], 30: [ Species.DELCATTY ] }, + { 1: [ Species.PONYTA ], 40: [ Species.RAPIDASH ]}, + { 1: [ Species.SNUBBULL ], 23: [ Species.GRANBULL ]}, + { 1: [ Species.SKITTY ], 30: [ Species.DELCATTY ]}, Species.BOUFFALANT, - { 1: [ Species.SMOLIV ], 25: [ Species.DOLLIV ], 35: [ Species.ARBOLIVA ] } + { 1: [ Species.SMOLIV ], 25: [ Species.DOLLIV ], 35: [ Species.ARBOLIVA ]} ], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ - { 1: [ Species.JIGGLYPUFF ], 30: [ Species.WIGGLYTUFF ] }, - { 1: [ Species.MAREEP ], 15: [ Species.FLAAFFY ], 30: [ Species.AMPHAROS ] }, - { 1: [ Species.RALTS ], 20: [ Species.KIRLIA ], 30: [ Species.GARDEVOIR ] }, - { 1: [ Species.GLAMEOW ], 38: [ Species.PURUGLY ] }, + { 1: [ Species.JIGGLYPUFF ], 30: [ Species.WIGGLYTUFF ]}, + { 1: [ Species.MAREEP ], 15: [ Species.FLAAFFY ], 30: [ Species.AMPHAROS ]}, + { 1: [ Species.RALTS ], 20: [ Species.KIRLIA ], 30: [ Species.GARDEVOIR ]}, + { 1: [ Species.GLAMEOW ], 38: [ Species.PURUGLY ]}, Species.ORICORIO ] }, @@ -944,10 +944,10 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [ Species.VOLBEAT, Species.ILLUMISE ], - [TimeOfDay.ALL]: [ Species.TAUROS, Species.EEVEE, Species.MILTANK, Species.SPINDA, { 1: [ Species.APPLIN ], 30: [ Species.DIPPLIN ] }, { 1: [ Species.SPRIGATITO ], 16: [ Species.FLORAGATO ], 36: [ Species.MEOWSCARADA ] } ] + [TimeOfDay.ALL]: [ Species.TAUROS, Species.EEVEE, Species.MILTANK, Species.SPINDA, { 1: [ Species.APPLIN ], 30: [ Species.DIPPLIN ]}, { 1: [ Species.SPRIGATITO ], 16: [ Species.FLORAGATO ], 36: [ Species.MEOWSCARADA ]}] }, - [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.CHANSEY, Species.SYLVEON ] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.MELOETTA ] }, + [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.CHANSEY, Species.SYLVEON ]}, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.MELOETTA ]}, [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [ Species.LEDIAN, Species.GRANBULL, Species.DELCATTY, Species.ROSERADE, Species.CINCCINO, Species.BOUFFALANT, Species.ARBOLIVA ], [TimeOfDay.DAY]: [ Species.GRANBULL, Species.DELCATTY, Species.ROSERADE, Species.CINCCINO, Species.BOUFFALANT, Species.ARBOLIVA ], @@ -955,9 +955,9 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.TAUROS, Species.MILTANK, Species.GARDEVOIR, Species.PURUGLY, Species.ZEBSTRIKA, Species.FLORGES, Species.RIBOMBEE, Species.DUBWOOL ] }, - [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [ Species.HISUI_LILLIGANT ], [TimeOfDay.DAY]: [ Species.HISUI_LILLIGANT ], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.BLISSEY, Species.SYLVEON, Species.FLAPPLE, Species.APPLETUN, Species.MEOWSCARADA, Species.HYDRAPPLE ] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.MELOETTA ] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.SHAYMIN ] } + [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [ Species.HISUI_LILLIGANT ], [TimeOfDay.DAY]: [ Species.HISUI_LILLIGANT ], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.BLISSEY, Species.SYLVEON, Species.FLAPPLE, Species.APPLETUN, Species.MEOWSCARADA, Species.HYDRAPPLE ]}, + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.MELOETTA ]}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.SHAYMIN ]} }, [Biome.POWER_PLANT]: { [BiomePoolTier.COMMON]: { @@ -967,20 +967,20 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.PIKACHU, - { 1: [ Species.MAGNEMITE ], 30: [ Species.MAGNETON ] }, - { 1: [ Species.VOLTORB ], 30: [ Species.ELECTRODE ] }, - { 1: [ Species.ELECTRIKE ], 26: [ Species.MANECTRIC ] }, - { 1: [ Species.SHINX ], 15: [ Species.LUXIO ], 30: [ Species.LUXRAY ] }, + { 1: [ Species.MAGNEMITE ], 30: [ Species.MAGNETON ]}, + { 1: [ Species.VOLTORB ], 30: [ Species.ELECTRODE ]}, + { 1: [ Species.ELECTRIKE ], 26: [ Species.MANECTRIC ]}, + { 1: [ Species.SHINX ], 15: [ Species.LUXIO ], 30: [ Species.LUXRAY ]}, Species.DEDENNE, - { 1: [ Species.GRUBBIN ], 20: [ Species.CHARJABUG ] }, - { 1: [ Species.PAWMI ], 18: [ Species.PAWMO ], 32: [ Species.PAWMOT ] }, - { 1: [ Species.TADBULB ], 30: [ Species.BELLIBOLT ] } + { 1: [ Species.GRUBBIN ], 20: [ Species.CHARJABUG ]}, + { 1: [ Species.PAWMI ], 18: [ Species.PAWMO ], 32: [ Species.PAWMOT ]}, + { 1: [ Species.TADBULB ], 30: [ Species.BELLIBOLT ]} ] }, - [BiomePoolTier.UNCOMMON]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ELECTABUZZ, Species.PLUSLE, Species.MINUN, Species.PACHIRISU, Species.EMOLGA, Species.TOGEDEMARU ] }, - [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ { 1: [ Species.MAREEP ], 15: [ Species.FLAAFFY ] } ] }, - [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.JOLTEON, Species.HISUI_VOLTORB ] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.RAIKOU, Species.THUNDURUS, Species.XURKITREE, Species.ZERAORA, Species.REGIELEKI ] }, + [BiomePoolTier.UNCOMMON]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ELECTABUZZ, Species.PLUSLE, Species.MINUN, Species.PACHIRISU, Species.EMOLGA, Species.TOGEDEMARU ]}, + [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [{ 1: [ Species.MAREEP ], 15: [ Species.FLAAFFY ]}]}, + [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.JOLTEON, Species.HISUI_VOLTORB ]}, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.RAIKOU, Species.THUNDURUS, Species.XURKITREE, Species.ZERAORA, Species.REGIELEKI ]}, [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], @@ -988,9 +988,9 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.RAICHU, Species.MANECTRIC, Species.LUXRAY, Species.MAGNEZONE, Species.ELECTIVIRE, Species.DEDENNE, Species.VIKAVOLT, Species.TOGEDEMARU, Species.PAWMOT, Species.BELLIBOLT ] }, - [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.JOLTEON, Species.AMPHAROS, Species.HISUI_ELECTRODE ] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ZAPDOS, Species.RAIKOU, Species.THUNDURUS, Species.XURKITREE, Species.ZERAORA, Species.REGIELEKI ] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ZEKROM ] } + [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.JOLTEON, Species.AMPHAROS, Species.HISUI_ELECTRODE ]}, + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ZAPDOS, Species.RAIKOU, Species.THUNDURUS, Species.XURKITREE, Species.ZERAORA, Species.REGIELEKI ]}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ZEKROM ]} }, [Biome.VOLCANO]: { [BiomePoolTier.COMMON]: { @@ -1001,32 +1001,32 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.ALL]: [ Species.VULPIX, Species.GROWLITHE, - { 1: [ Species.PONYTA ], 40: [ Species.RAPIDASH ] }, - { 1: [ Species.SLUGMA ], 38: [ Species.MAGCARGO ] }, - { 1: [ Species.NUMEL ], 33: [ Species.CAMERUPT ] }, - { 1: [ Species.SALANDIT ], 33: [ Species.SALAZZLE ] }, - { 1: [ Species.ROLYCOLY ], 18: [ Species.CARKOL ], 34: [ Species.COALOSSAL ] } + { 1: [ Species.PONYTA ], 40: [ Species.RAPIDASH ]}, + { 1: [ Species.SLUGMA ], 38: [ Species.MAGCARGO ]}, + { 1: [ Species.NUMEL ], 33: [ Species.CAMERUPT ]}, + { 1: [ Species.SALANDIT ], 33: [ Species.SALAZZLE ]}, + { 1: [ Species.ROLYCOLY ], 18: [ Species.CARKOL ], 34: [ Species.COALOSSAL ]} ] }, - [BiomePoolTier.UNCOMMON]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.MAGMAR, Species.TORKOAL, { 1: [ Species.PANSEAR ], 30: [ Species.SIMISEAR ] }, Species.HEATMOR, Species.TURTONATOR ] }, + [BiomePoolTier.UNCOMMON]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.MAGMAR, Species.TORKOAL, { 1: [ Species.PANSEAR ], 30: [ Species.SIMISEAR ]}, Species.HEATMOR, Species.TURTONATOR ]}, [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ - { 1: [ Species.CHARMANDER ], 16: [ Species.CHARMELEON ], 36: [ Species.CHARIZARD ] }, - { 1: [ Species.CYNDAQUIL ], 14: [ Species.QUILAVA ], 36: [ Species.TYPHLOSION ] }, - { 1: [ Species.CHIMCHAR ], 14: [ Species.MONFERNO ], 36: [ Species.INFERNAPE ] }, - { 1: [ Species.TEPIG ], 17: [ Species.PIGNITE ], 36: [ Species.EMBOAR ] }, - { 1: [ Species.FENNEKIN ], 16: [ Species.BRAIXEN ], 36: [ Species.DELPHOX ] }, - { 1: [ Species.LITTEN ], 17: [ Species.TORRACAT ], 34: [ Species.INCINEROAR ] }, - { 1: [ Species.SCORBUNNY ], 16: [ Species.RABOOT ], 35: [ Species.CINDERACE ] }, - { 1: [ Species.CHARCADET ], 30: [ Species.ARMAROUGE ] } + { 1: [ Species.CHARMANDER ], 16: [ Species.CHARMELEON ], 36: [ Species.CHARIZARD ]}, + { 1: [ Species.CYNDAQUIL ], 14: [ Species.QUILAVA ], 36: [ Species.TYPHLOSION ]}, + { 1: [ Species.CHIMCHAR ], 14: [ Species.MONFERNO ], 36: [ Species.INFERNAPE ]}, + { 1: [ Species.TEPIG ], 17: [ Species.PIGNITE ], 36: [ Species.EMBOAR ]}, + { 1: [ Species.FENNEKIN ], 16: [ Species.BRAIXEN ], 36: [ Species.DELPHOX ]}, + { 1: [ Species.LITTEN ], 17: [ Species.TORRACAT ], 34: [ Species.INCINEROAR ]}, + { 1: [ Species.SCORBUNNY ], 16: [ Species.RABOOT ], 35: [ Species.CINDERACE ]}, + { 1: [ Species.CHARCADET ], 30: [ Species.ARMAROUGE ]} ] }, - [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.FLAREON, Species.ROTOM, { 1: [ Species.LARVESTA ], 59: [ Species.VOLCARONA ] }, Species.HISUI_GROWLITHE ] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ENTEI, Species.HEATRAN, Species.VOLCANION, Species.CHI_YU ] }, + [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.FLAREON, Species.ROTOM, { 1: [ Species.LARVESTA ], 59: [ Species.VOLCARONA ]}, Species.HISUI_GROWLITHE ]}, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ENTEI, Species.HEATRAN, Species.VOLCANION, Species.CHI_YU ]}, [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], @@ -1041,8 +1041,8 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.CHARIZARD, Species.FLAREON, Species.TYPHLOSION, Species.INFERNAPE, Species.EMBOAR, Species.VOLCARONA, Species.DELPHOX, Species.INCINEROAR, Species.CINDERACE, Species.ARMAROUGE, Species.HISUI_ARCANINE ] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.MOLTRES, Species.ENTEI, Species.ROTOM, Species.HEATRAN, Species.VOLCANION, Species.CHI_YU ] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.RESHIRAM ] } + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.MOLTRES, Species.ENTEI, Species.ROTOM, Species.HEATRAN, Species.VOLCANION, Species.CHI_YU ]}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.RESHIRAM ]} }, [Biome.GRAVEYARD]: { [BiomePoolTier.COMMON]: { @@ -1051,14 +1051,14 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ - { 1: [ Species.GASTLY ], 25: [ Species.HAUNTER ] }, - { 1: [ Species.SHUPPET ], 37: [ Species.BANETTE ] }, - { 1: [ Species.DUSKULL ], 37: [ Species.DUSCLOPS ] }, - { 1: [ Species.DRIFLOON ], 28: [ Species.DRIFBLIM ] }, - { 1: [ Species.LITWICK ], 41: [ Species.LAMPENT ] }, + { 1: [ Species.GASTLY ], 25: [ Species.HAUNTER ]}, + { 1: [ Species.SHUPPET ], 37: [ Species.BANETTE ]}, + { 1: [ Species.DUSKULL ], 37: [ Species.DUSCLOPS ]}, + { 1: [ Species.DRIFLOON ], 28: [ Species.DRIFBLIM ]}, + { 1: [ Species.LITWICK ], 41: [ Species.LAMPENT ]}, Species.PHANTUMP, Species.PUMPKABOO, - { 1: [ Species.GREAVARD ], 60: [ Species.HOUNDSTONE ] } + { 1: [ Species.GREAVARD ], 60: [ Species.HOUNDSTONE ]} ] }, [BiomePoolTier.UNCOMMON]: { @@ -1066,11 +1066,11 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], - [TimeOfDay.ALL]: [ { 1: [ Species.CUBONE ], 28: [ Species.MAROWAK ] }, { 1: [ Species.YAMASK ], 34: [ Species.COFAGRIGUS ] }, { 1: [ Species.SINISTEA ], 30: [ Species.POLTEAGEIST ] } ] + [TimeOfDay.ALL]: [{ 1: [ Species.CUBONE ], 28: [ Species.MAROWAK ]}, { 1: [ Species.YAMASK ], 34: [ Species.COFAGRIGUS ]}, { 1: [ Species.SINISTEA ], 30: [ Species.POLTEAGEIST ]}] }, - [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.MISDREAVUS, Species.MIMIKYU, { 1: [ Species.FUECOCO ], 16: [ Species.CROCALOR ], 36: [ Species.SKELEDIRGE ] }, Species.CERULEDGE ] }, - [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.SPIRITOMB ] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.MARSHADOW, Species.SPECTRIER ] }, + [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.MISDREAVUS, Species.MIMIKYU, { 1: [ Species.FUECOCO ], 16: [ Species.CROCALOR ], 36: [ Species.SKELEDIRGE ]}, Species.CERULEDGE ]}, + [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.SPIRITOMB ]}, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.MARSHADOW, Species.SPECTRIER ]}, [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [ Species.MAROWAK ], [TimeOfDay.DAY]: [ Species.MAROWAK ], @@ -1078,9 +1078,9 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.GENGAR, Species.BANETTE, Species.DRIFBLIM, Species.MISMAGIUS, Species.DUSKNOIR, Species.CHANDELURE, Species.TREVENANT, Species.GOURGEIST, Species.MIMIKYU, Species.POLTEAGEIST, Species.HOUNDSTONE ] }, - [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.SKELEDIRGE, Species.CERULEDGE, Species.HISUI_TYPHLOSION ] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.MARSHADOW, Species.SPECTRIER ] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.GIRATINA ] } + [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.SKELEDIRGE, Species.CERULEDGE, Species.HISUI_TYPHLOSION ]}, + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.MARSHADOW, Species.SPECTRIER ]}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.GIRATINA ]} }, [Biome.DOJO]: { [BiomePoolTier.COMMON]: { @@ -1089,11 +1089,11 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ - { 1: [ Species.MANKEY ], 28: [ Species.PRIMEAPE ], 75: [ Species.ANNIHILAPE ] }, - { 1: [ Species.MAKUHITA ], 24: [ Species.HARIYAMA ] }, - { 1: [ Species.MEDITITE ], 37: [ Species.MEDICHAM ] }, - { 1: [ Species.STUFFUL ], 27: [ Species.BEWEAR ] }, - { 1: [ Species.CLOBBOPUS ], 55: [ Species.GRAPPLOCT ] } + { 1: [ Species.MANKEY ], 28: [ Species.PRIMEAPE ], 75: [ Species.ANNIHILAPE ]}, + { 1: [ Species.MAKUHITA ], 24: [ Species.HARIYAMA ]}, + { 1: [ Species.MEDITITE ], 37: [ Species.MEDICHAM ]}, + { 1: [ Species.STUFFUL ], 27: [ Species.BEWEAR ]}, + { 1: [ Species.CLOBBOPUS ], 55: [ Species.GRAPPLOCT ]} ] }, [BiomePoolTier.UNCOMMON]: { @@ -1101,11 +1101,11 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], - [TimeOfDay.ALL]: [ { 1: [ Species.CROAGUNK ], 37: [ Species.TOXICROAK ] }, { 1: [ Species.SCRAGGY ], 39: [ Species.SCRAFTY ] }, { 1: [ Species.MIENFOO ], 50: [ Species.MIENSHAO ] } ] + [TimeOfDay.ALL]: [{ 1: [ Species.CROAGUNK ], 37: [ Species.TOXICROAK ]}, { 1: [ Species.SCRAGGY ], 39: [ Species.SCRAFTY ]}, { 1: [ Species.MIENFOO ], 50: [ Species.MIENSHAO ]}] }, - [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.HITMONLEE, Species.HITMONCHAN, Species.LUCARIO, Species.THROH, Species.SAWK, { 1: [ Species.PANCHAM ], 52: [ Species.PANGORO ] } ] }, - [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.HITMONTOP, Species.GALLADE, Species.GALAR_FARFETCHD ] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.TERRAKION, Species.KUBFU, Species.GALAR_ZAPDOS ] }, + [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.HITMONLEE, Species.HITMONCHAN, Species.LUCARIO, Species.THROH, Species.SAWK, { 1: [ Species.PANCHAM ], 52: [ Species.PANGORO ]}]}, + [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.HITMONTOP, Species.GALLADE, Species.GALAR_FARFETCHD ]}, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.TERRAKION, Species.KUBFU, Species.GALAR_ZAPDOS ]}, [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], @@ -1113,9 +1113,9 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.HITMONLEE, Species.HITMONCHAN, Species.HARIYAMA, Species.MEDICHAM, Species.LUCARIO, Species.TOXICROAK, Species.THROH, Species.SAWK, Species.SCRAFTY, Species.MIENSHAO, Species.BEWEAR, Species.GRAPPLOCT, Species.ANNIHILAPE ] }, - [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.HITMONTOP, Species.GALLADE, Species.PANGORO, Species.SIRFETCHD, Species.HISUI_DECIDUEYE ] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.TERRAKION, Species.URSHIFU ] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ZAMAZENTA, Species.GALAR_ZAPDOS ] } + [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.HITMONTOP, Species.GALLADE, Species.PANGORO, Species.SIRFETCHD, Species.HISUI_DECIDUEYE ]}, + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.TERRAKION, Species.URSHIFU ]}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ZAMAZENTA, Species.GALAR_ZAPDOS ]} }, [Biome.FACTORY]: { [BiomePoolTier.COMMON]: { @@ -1124,21 +1124,21 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ - { 1: [ Species.MACHOP ], 28: [ Species.MACHOKE ] }, - { 1: [ Species.MAGNEMITE ], 30: [ Species.MAGNETON ] }, - { 1: [ Species.VOLTORB ], 30: [ Species.ELECTRODE ] }, - { 1: [ Species.TIMBURR ], 25: [ Species.GURDURR ] }, - { 1: [ Species.KLINK ], 38: [ Species.KLANG ], 49: [ Species.KLINKLANG ] } + { 1: [ Species.MACHOP ], 28: [ Species.MACHOKE ]}, + { 1: [ Species.MAGNEMITE ], 30: [ Species.MAGNETON ]}, + { 1: [ Species.VOLTORB ], 30: [ Species.ELECTRODE ]}, + { 1: [ Species.TIMBURR ], 25: [ Species.GURDURR ]}, + { 1: [ Species.KLINK ], 38: [ Species.KLANG ], 49: [ Species.KLINKLANG ]} ] }, - [BiomePoolTier.UNCOMMON]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ { 1: [ Species.BRONZOR ], 33: [ Species.BRONZONG ] }, Species.KLEFKI ] }, - [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ { 1: [ Species.PORYGON ], 30: [ Species.PORYGON2 ] } ] }, - [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ { 1: [ Species.BELDUM ], 20: [ Species.METANG ], 45: [ Species.METAGROSS ] } ] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.GENESECT, Species.MAGEARNA ] }, - [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.KLINKLANG, Species.KLEFKI ] }, - [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.GENESECT, Species.MAGEARNA ] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] } + [BiomePoolTier.UNCOMMON]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [{ 1: [ Species.BRONZOR ], 33: [ Species.BRONZONG ]}, Species.KLEFKI ]}, + [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [{ 1: [ Species.PORYGON ], 30: [ Species.PORYGON2 ]}]}, + [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [{ 1: [ Species.BELDUM ], 20: [ Species.METANG ], 45: [ Species.METAGROSS ]}]}, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.GENESECT, Species.MAGEARNA ]}, + [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.KLINKLANG, Species.KLEFKI ]}, + [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []}, + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.GENESECT, Species.MAGEARNA ]}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []} }, [Biome.RUINS]: { [BiomePoolTier.COMMON]: { @@ -1147,12 +1147,12 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ - { 1: [ Species.DROWZEE ], 26: [ Species.HYPNO ] }, - { 1: [ Species.NATU ], 25: [ Species.XATU ] }, + { 1: [ Species.DROWZEE ], 26: [ Species.HYPNO ]}, + { 1: [ Species.NATU ], 25: [ Species.XATU ]}, Species.UNOWN, - { 1: [ Species.SPOINK ], 32: [ Species.GRUMPIG ] }, - { 1: [ Species.BALTOY ], 36: [ Species.CLAYDOL ] }, - { 1: [ Species.ELGYEM ], 42: [ Species.BEHEEYEM ] } + { 1: [ Species.SPOINK ], 32: [ Species.GRUMPIG ]}, + { 1: [ Species.BALTOY ], 36: [ Species.CLAYDOL ]}, + { 1: [ Species.ELGYEM ], 42: [ Species.BEHEEYEM ]} ] }, [BiomePoolTier.UNCOMMON]: { @@ -1160,58 +1160,58 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], - [TimeOfDay.ALL]: [ { 1: [ Species.ABRA ], 16: [ Species.KADABRA ] }, Species.SIGILYPH, { 1: [ Species.TINKATINK ], 24: [ Species.TINKATUFF ], 38: [ Species.TINKATON ] } ] + [TimeOfDay.ALL]: [{ 1: [ Species.ABRA ], 16: [ Species.KADABRA ]}, Species.SIGILYPH, { 1: [ Species.TINKATINK ], 24: [ Species.TINKATUFF ], 38: [ Species.TINKATON ]}] }, - [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.MR_MIME, Species.WOBBUFFET, { 1: [ Species.GOTHITA ], 32: [ Species.GOTHORITA ], 41: [ Species.GOTHITELLE ] }, Species.STONJOURNER ] }, + [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.MR_MIME, Species.WOBBUFFET, { 1: [ Species.GOTHITA ], 32: [ Species.GOTHORITA ], 41: [ Species.GOTHITELLE ]}, Species.STONJOURNER ]}, [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [ Species.ESPEON ], - [TimeOfDay.DUSK]: [ { 1: [ Species.GALAR_YAMASK ], 34: [ Species.RUNERIGUS ] } ], - [TimeOfDay.NIGHT]: [ { 1: [ Species.GALAR_YAMASK ], 34: [ Species.RUNERIGUS ] } ], - [TimeOfDay.ALL]: [ { 1: [ Species.ARCHEN ], 37: [ Species.ARCHEOPS ] } ] + [TimeOfDay.DUSK]: [{ 1: [ Species.GALAR_YAMASK ], 34: [ Species.RUNERIGUS ]}], + [TimeOfDay.NIGHT]: [{ 1: [ Species.GALAR_YAMASK ], 34: [ Species.RUNERIGUS ]}], + [TimeOfDay.ALL]: [{ 1: [ Species.ARCHEN ], 37: [ Species.ARCHEOPS ]}] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.REGISTEEL, Species.FEZANDIPITI ] }, - [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ALAKAZAM, Species.HYPNO, Species.XATU, Species.GRUMPIG, Species.CLAYDOL, Species.SIGILYPH, Species.GOTHITELLE, Species.BEHEEYEM, Species.TINKATON ] }, - [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [ Species.ESPEON ], [TimeOfDay.DUSK]: [ Species.RUNERIGUS ], [TimeOfDay.NIGHT]: [ Species.RUNERIGUS ], [TimeOfDay.ALL]: [ Species.MR_MIME, Species.WOBBUFFET, Species.ARCHEOPS ] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.REGISTEEL, Species.FEZANDIPITI ] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.KORAIDON ] } + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.REGISTEEL, Species.FEZANDIPITI ]}, + [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ALAKAZAM, Species.HYPNO, Species.XATU, Species.GRUMPIG, Species.CLAYDOL, Species.SIGILYPH, Species.GOTHITELLE, Species.BEHEEYEM, Species.TINKATON ]}, + [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [ Species.ESPEON ], [TimeOfDay.DUSK]: [ Species.RUNERIGUS ], [TimeOfDay.NIGHT]: [ Species.RUNERIGUS ], [TimeOfDay.ALL]: [ Species.MR_MIME, Species.WOBBUFFET, Species.ARCHEOPS ]}, + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.REGISTEEL, Species.FEZANDIPITI ]}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.KORAIDON ]} }, [Biome.WASTELAND]: { [BiomePoolTier.COMMON]: { [TimeOfDay.DAWN]: [ - { 1: [ Species.BAGON ], 30: [ Species.SHELGON ], 50: [ Species.SALAMENCE ] }, - { 1: [ Species.GOOMY ], 40: [ Species.SLIGGOO ], 80: [ Species.GOODRA ] }, - { 1: [ Species.JANGMO_O ], 35: [ Species.HAKAMO_O ], 45: [ Species.KOMMO_O ] } + { 1: [ Species.BAGON ], 30: [ Species.SHELGON ], 50: [ Species.SALAMENCE ]}, + { 1: [ Species.GOOMY ], 40: [ Species.SLIGGOO ], 80: [ Species.GOODRA ]}, + { 1: [ Species.JANGMO_O ], 35: [ Species.HAKAMO_O ], 45: [ Species.KOMMO_O ]} ], [TimeOfDay.DAY]: [ - { 1: [ Species.BAGON ], 30: [ Species.SHELGON ], 50: [ Species.SALAMENCE ] }, - { 1: [ Species.GOOMY ], 40: [ Species.SLIGGOO ], 80: [ Species.GOODRA ] }, - { 1: [ Species.JANGMO_O ], 35: [ Species.HAKAMO_O ], 45: [ Species.KOMMO_O ] } + { 1: [ Species.BAGON ], 30: [ Species.SHELGON ], 50: [ Species.SALAMENCE ]}, + { 1: [ Species.GOOMY ], 40: [ Species.SLIGGOO ], 80: [ Species.GOODRA ]}, + { 1: [ Species.JANGMO_O ], 35: [ Species.HAKAMO_O ], 45: [ Species.KOMMO_O ]} ], - [TimeOfDay.DUSK]: [ { 1: [ Species.LARVITAR ], 30: [ Species.PUPITAR ], 55: [ Species.TYRANITAR ] } ], - [TimeOfDay.NIGHT]: [ { 1: [ Species.LARVITAR ], 30: [ Species.PUPITAR ], 55: [ Species.TYRANITAR ] } ], + [TimeOfDay.DUSK]: [{ 1: [ Species.LARVITAR ], 30: [ Species.PUPITAR ], 55: [ Species.TYRANITAR ]}], + [TimeOfDay.NIGHT]: [{ 1: [ Species.LARVITAR ], 30: [ Species.PUPITAR ], 55: [ Species.TYRANITAR ]}], [TimeOfDay.ALL]: [ - { 1: [ Species.VIBRAVA ], 45: [ Species.FLYGON ] }, - { 1: [ Species.GIBLE ], 24: [ Species.GABITE ], 48: [ Species.GARCHOMP ] }, - { 1: [ Species.AXEW ], 38: [ Species.FRAXURE ], 48: [ Species.HAXORUS ] } + { 1: [ Species.VIBRAVA ], 45: [ Species.FLYGON ]}, + { 1: [ Species.GIBLE ], 24: [ Species.GABITE ], 48: [ Species.GARCHOMP ]}, + { 1: [ Species.AXEW ], 38: [ Species.FRAXURE ], 48: [ Species.HAXORUS ]} ] }, [BiomePoolTier.UNCOMMON]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], - [TimeOfDay.DUSK]: [ { 1: [ Species.DEINO ], 50: [ Species.ZWEILOUS ], 64: [ Species.HYDREIGON ] } ], - [TimeOfDay.NIGHT]: [ { 1: [ Species.DEINO ], 50: [ Species.ZWEILOUS ], 64: [ Species.HYDREIGON ] } ], - [TimeOfDay.ALL]: [ { 1: [ Species.SWABLU ], 35: [ Species.ALTARIA ] }, Species.DRAMPA, Species.CYCLIZAR ] + [TimeOfDay.DUSK]: [{ 1: [ Species.DEINO ], 50: [ Species.ZWEILOUS ], 64: [ Species.HYDREIGON ]}], + [TimeOfDay.NIGHT]: [{ 1: [ Species.DEINO ], 50: [ Species.ZWEILOUS ], 64: [ Species.HYDREIGON ]}], + [TimeOfDay.ALL]: [{ 1: [ Species.SWABLU ], 35: [ Species.ALTARIA ]}, Species.DRAMPA, Species.CYCLIZAR ] }, [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], - [TimeOfDay.DUSK]: [ { 1: [ Species.DREEPY ], 50: [ Species.DRAKLOAK ], 60: [ Species.DRAGAPULT ] } ], - [TimeOfDay.NIGHT]: [ { 1: [ Species.DREEPY ], 50: [ Species.DRAKLOAK ], 60: [ Species.DRAGAPULT ] } ], - [TimeOfDay.ALL]: [ { 1: [ Species.DRATINI ], 30: [ Species.DRAGONAIR ], 55: [ Species.DRAGONITE ] }, { 1: [ Species.FRIGIBAX ], 35: [ Species.ARCTIBAX ], 54: [ Species.BAXCALIBUR ] } ] + [TimeOfDay.DUSK]: [{ 1: [ Species.DREEPY ], 50: [ Species.DRAKLOAK ], 60: [ Species.DRAGAPULT ]}], + [TimeOfDay.NIGHT]: [{ 1: [ Species.DREEPY ], 50: [ Species.DRAKLOAK ], 60: [ Species.DRAGAPULT ]}], + [TimeOfDay.ALL]: [{ 1: [ Species.DRATINI ], 30: [ Species.DRAGONAIR ], 55: [ Species.DRAGONITE ]}, { 1: [ Species.FRIGIBAX ], 35: [ Species.ARCTIBAX ], 54: [ Species.BAXCALIBUR ]}] }, - [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.AERODACTYL, Species.DRUDDIGON, { 1: [ Species.TYRUNT ], 59: [ Species.TYRANTRUM ] }, Species.DRACOZOLT, Species.DRACOVISH ] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.REGIDRAGO ] }, + [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.AERODACTYL, Species.DRUDDIGON, { 1: [ Species.TYRUNT ], 59: [ Species.TYRANTRUM ]}, Species.DRACOZOLT, Species.DRACOVISH ]}, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.REGIDRAGO ]}, [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [ Species.SALAMENCE, Species.GOODRA, Species.KOMMO_O ], [TimeOfDay.DAY]: [ Species.SALAMENCE, Species.GOODRA, Species.KOMMO_O ], @@ -1219,9 +1219,9 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.NIGHT]: [ Species.TYRANITAR, Species.DRAGAPULT ], [TimeOfDay.ALL]: [ Species.DRAGONITE, Species.FLYGON, Species.GARCHOMP, Species.HAXORUS, Species.DRAMPA, Species.BAXCALIBUR ] }, - [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.AERODACTYL, Species.DRUDDIGON, Species.TYRANTRUM, Species.DRACOZOLT, Species.DRACOVISH ] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.REGIDRAGO ] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.DIALGA ] } + [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.AERODACTYL, Species.DRUDDIGON, Species.TYRANTRUM, Species.DRACOZOLT, Species.DRACOVISH ]}, + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.REGIDRAGO ]}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.DIALGA ]} }, [Biome.ABYSS]: { [BiomePoolTier.COMMON]: { @@ -1231,25 +1231,25 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.MURKROW, - { 1: [ Species.HOUNDOUR ], 24: [ Species.HOUNDOOM ] }, + { 1: [ Species.HOUNDOUR ], 24: [ Species.HOUNDOOM ]}, Species.SABLEYE, - { 1: [ Species.PURRLOIN ], 20: [ Species.LIEPARD ] }, - { 1: [ Species.PAWNIARD ], 52: [ Species.BISHARP ], 64: [ Species.KINGAMBIT ] }, - { 1: [ Species.NICKIT ], 18: [ Species.THIEVUL ] }, - { 1: [ Species.IMPIDIMP ], 32: [ Species.MORGREM ], 42: [ Species.GRIMMSNARL ] }, - { 1: [ Species.MASCHIFF ], 30: [ Species.MABOSSTIFF ] } + { 1: [ Species.PURRLOIN ], 20: [ Species.LIEPARD ]}, + { 1: [ Species.PAWNIARD ], 52: [ Species.BISHARP ], 64: [ Species.KINGAMBIT ]}, + { 1: [ Species.NICKIT ], 18: [ Species.THIEVUL ]}, + { 1: [ Species.IMPIDIMP ], 32: [ Species.MORGREM ], 42: [ Species.GRIMMSNARL ]}, + { 1: [ Species.MASCHIFF ], 30: [ Species.MABOSSTIFF ]} ] }, - [BiomePoolTier.UNCOMMON]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] }, + [BiomePoolTier.UNCOMMON]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []}, [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], - [TimeOfDay.ALL]: [ Species.ABSOL, Species.SPIRITOMB, { 1: [ Species.ZORUA ], 30: [ Species.ZOROARK ] }, { 1: [ Species.DEINO ], 50: [ Species.ZWEILOUS ], 64: [ Species.HYDREIGON ] } ] + [TimeOfDay.ALL]: [ Species.ABSOL, Species.SPIRITOMB, { 1: [ Species.ZORUA ], 30: [ Species.ZOROARK ]}, { 1: [ Species.DEINO ], 50: [ Species.ZWEILOUS ], 64: [ Species.HYDREIGON ]}] }, - [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.UMBREON ] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.DARKRAI, Species.GALAR_MOLTRES ] }, + [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.UMBREON ]}, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.DARKRAI, Species.GALAR_MOLTRES ]}, [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], @@ -1257,9 +1257,9 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.HOUNDOOM, Species.SABLEYE, Species.ABSOL, Species.HONCHKROW, Species.SPIRITOMB, Species.LIEPARD, Species.ZOROARK, Species.HYDREIGON, Species.THIEVUL, Species.GRIMMSNARL, Species.MABOSSTIFF, Species.KINGAMBIT ] }, - [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.UMBREON, Species.HISUI_SAMUROTT ] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.DARKRAI ] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.PALKIA, Species.YVELTAL, Species.GALAR_MOLTRES ] } + [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.UMBREON, Species.HISUI_SAMUROTT ]}, + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.DARKRAI ]}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.PALKIA, Species.YVELTAL, Species.GALAR_MOLTRES ]} }, [Biome.SPACE]: { [BiomePoolTier.COMMON]: { @@ -1267,22 +1267,22 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.DAY]: [ Species.SOLROCK ], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [ Species.LUNATONE ], - [TimeOfDay.ALL]: [ Species.CLEFAIRY, { 1: [ Species.BRONZOR ], 33: [ Species.BRONZONG ] }, { 1: [ Species.MUNNA ], 30: [ Species.MUSHARNA ] }, Species.MINIOR ] + [TimeOfDay.ALL]: [ Species.CLEFAIRY, { 1: [ Species.BRONZOR ], 33: [ Species.BRONZONG ]}, { 1: [ Species.MUNNA ], 30: [ Species.MUSHARNA ]}, Species.MINIOR ] }, - [BiomePoolTier.UNCOMMON]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ { 1: [ Species.BALTOY ], 36: [ Species.CLAYDOL ] }, { 1: [ Species.ELGYEM ], 42: [ Species.BEHEEYEM ] } ] }, + [BiomePoolTier.UNCOMMON]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [{ 1: [ Species.BALTOY ], 36: [ Species.CLAYDOL ]}, { 1: [ Species.ELGYEM ], 42: [ Species.BEHEEYEM ]}]}, [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], - [TimeOfDay.ALL]: [ { 1: [ Species.BELDUM ], 20: [ Species.METANG ], 45: [ Species.METAGROSS ] }, Species.SIGILYPH, { 1: [ Species.SOLOSIS ], 32: [ Species.DUOSION ], 41: [ Species.REUNICLUS ] } ] + [TimeOfDay.ALL]: [{ 1: [ Species.BELDUM ], 20: [ Species.METANG ], 45: [ Species.METAGROSS ]}, Species.SIGILYPH, { 1: [ Species.SOLOSIS ], 32: [ Species.DUOSION ], 41: [ Species.REUNICLUS ]}] }, - [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ { 1: [ Species.PORYGON ], 30: [ Species.PORYGON2 ] } ] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ { 1: [ Species.COSMOG ], 43: [ Species.COSMOEM ] }, Species.CELESTEELA ] }, - [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [ Species.SOLROCK ], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [ Species.LUNATONE ], [TimeOfDay.ALL]: [ Species.CLEFABLE, Species.BRONZONG, Species.MUSHARNA, Species.REUNICLUS, Species.MINIOR ] }, - [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.METAGROSS, Species.PORYGON_Z ] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.CELESTEELA ] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [ Species.SOLGALEO ], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [ Species.LUNALA ], [TimeOfDay.ALL]: [ Species.RAYQUAZA, Species.NECROZMA ] } + [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [{ 1: [ Species.PORYGON ], 30: [ Species.PORYGON2 ]}]}, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [{ 1: [ Species.COSMOG ], 43: [ Species.COSMOEM ]}, Species.CELESTEELA ]}, + [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [ Species.SOLROCK ], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [ Species.LUNATONE ], [TimeOfDay.ALL]: [ Species.CLEFABLE, Species.BRONZONG, Species.MUSHARNA, Species.REUNICLUS, Species.MINIOR ]}, + [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.METAGROSS, Species.PORYGON_Z ]}, + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.CELESTEELA ]}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [ Species.SOLGALEO ], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [ Species.LUNALA ], [TimeOfDay.ALL]: [ Species.RAYQUAZA, Species.NECROZMA ]} }, [Biome.CONSTRUCTION_SITE]: { [BiomePoolTier.COMMON]: { @@ -1291,10 +1291,10 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ - { 1: [ Species.MACHOP ], 28: [ Species.MACHOKE ] }, - { 1: [ Species.MAGNEMITE ], 30: [ Species.MAGNETON ] }, - { 1: [ Species.DRILBUR ], 31: [ Species.EXCADRILL ] }, - { 1: [ Species.TIMBURR ], 25: [ Species.GURDURR ] } + { 1: [ Species.MACHOP ], 28: [ Species.MACHOKE ]}, + { 1: [ Species.MAGNEMITE ], 30: [ Species.MAGNETON ]}, + { 1: [ Species.DRILBUR ], 31: [ Species.EXCADRILL ]}, + { 1: [ Species.TIMBURR ], 25: [ Species.GURDURR ]} ] }, [BiomePoolTier.UNCOMMON]: { @@ -1303,60 +1303,60 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ - { 1: [ Species.GRIMER ], 38: [ Species.MUK ] }, - { 1: [ Species.KOFFING ], 35: [ Species.WEEZING ] }, - { 1: [ Species.RHYHORN ], 42: [ Species.RHYDON ] }, - { 1: [ Species.SCRAGGY ], 39: [ Species.SCRAFTY ] } + { 1: [ Species.GRIMER ], 38: [ Species.MUK ]}, + { 1: [ Species.KOFFING ], 35: [ Species.WEEZING ]}, + { 1: [ Species.RHYHORN ], 42: [ Species.RHYDON ]}, + { 1: [ Species.SCRAGGY ], 39: [ Species.SCRAFTY ]} ] }, - [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [ { 1: [ Species.GALAR_MEOWTH ], 28: [ Species.PERRSERKER ] } ], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ONIX, Species.HITMONLEE, Species.HITMONCHAN, Species.DURALUDON ] }, - [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.DITTO, Species.HITMONTOP ] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.COBALION, Species.STAKATAKA ] }, - [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.MACHAMP, Species.CONKELDURR ] }, - [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [ Species.PERRSERKER ], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ARCHALUDON ] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.COBALION, Species.STAKATAKA ] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] } + [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [{ 1: [ Species.GALAR_MEOWTH ], 28: [ Species.PERRSERKER ]}], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ONIX, Species.HITMONLEE, Species.HITMONCHAN, Species.DURALUDON ]}, + [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.DITTO, Species.HITMONTOP ]}, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.COBALION, Species.STAKATAKA ]}, + [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.MACHAMP, Species.CONKELDURR ]}, + [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [ Species.PERRSERKER ], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ARCHALUDON ]}, + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.COBALION, Species.STAKATAKA ]}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []} }, [Biome.JUNGLE]: { [BiomePoolTier.COMMON]: { - [TimeOfDay.DAWN]: [ Species.VESPIQUEN, { 1: [ Species.CHERUBI ], 25: [ Species.CHERRIM ] }, { 1: [ Species.SEWADDLE ], 20: [ Species.SWADLOON ], 30: [ Species.LEAVANNY ] } ], - [TimeOfDay.DAY]: [ Species.VESPIQUEN, { 1: [ Species.CHERUBI ], 25: [ Species.CHERRIM ] }, { 1: [ Species.SEWADDLE ], 20: [ Species.SWADLOON ], 30: [ Species.LEAVANNY ] } ], - [TimeOfDay.DUSK]: [ Species.SHROOMISH, { 1: [ Species.PURRLOIN ], 20: [ Species.LIEPARD ] }, { 1: [ Species.FOONGUS ], 39: [ Species.AMOONGUSS ] } ], - [TimeOfDay.NIGHT]: [ { 1: [ Species.SPINARAK ], 22: [ Species.ARIADOS ] }, Species.SHROOMISH, { 1: [ Species.PURRLOIN ], 20: [ Species.LIEPARD ] }, { 1: [ Species.FOONGUS ], 39: [ Species.AMOONGUSS ] } ], - [TimeOfDay.ALL]: [ Species.AIPOM, { 1: [ Species.BLITZLE ], 27: [ Species.ZEBSTRIKA ] }, { 1: [ Species.PIKIPEK ], 14: [ Species.TRUMBEAK ], 28: [ Species.TOUCANNON ] } ] + [TimeOfDay.DAWN]: [ Species.VESPIQUEN, { 1: [ Species.CHERUBI ], 25: [ Species.CHERRIM ]}, { 1: [ Species.SEWADDLE ], 20: [ Species.SWADLOON ], 30: [ Species.LEAVANNY ]}], + [TimeOfDay.DAY]: [ Species.VESPIQUEN, { 1: [ Species.CHERUBI ], 25: [ Species.CHERRIM ]}, { 1: [ Species.SEWADDLE ], 20: [ Species.SWADLOON ], 30: [ Species.LEAVANNY ]}], + [TimeOfDay.DUSK]: [ Species.SHROOMISH, { 1: [ Species.PURRLOIN ], 20: [ Species.LIEPARD ]}, { 1: [ Species.FOONGUS ], 39: [ Species.AMOONGUSS ]}], + [TimeOfDay.NIGHT]: [{ 1: [ Species.SPINARAK ], 22: [ Species.ARIADOS ]}, Species.SHROOMISH, { 1: [ Species.PURRLOIN ], 20: [ Species.LIEPARD ]}, { 1: [ Species.FOONGUS ], 39: [ Species.AMOONGUSS ]}], + [TimeOfDay.ALL]: [ Species.AIPOM, { 1: [ Species.BLITZLE ], 27: [ Species.ZEBSTRIKA ]}, { 1: [ Species.PIKIPEK ], 14: [ Species.TRUMBEAK ], 28: [ Species.TOUCANNON ]}] }, [BiomePoolTier.UNCOMMON]: { [TimeOfDay.DAWN]: [ Species.EXEGGCUTE, Species.TROPIUS, Species.COMBEE, Species.KOMALA ], [TimeOfDay.DAY]: [ Species.EXEGGCUTE, Species.TROPIUS, Species.COMBEE, Species.KOMALA ], - [TimeOfDay.DUSK]: [ Species.TANGELA, { 1: [ Species.SPINARAK ], 22: [ Species.ARIADOS ] }, { 1: [ Species.PANCHAM ], 52: [ Species.PANGORO ] } ], - [TimeOfDay.NIGHT]: [ Species.TANGELA, { 1: [ Species.PANCHAM ], 52: [ Species.PANGORO ] } ], + [TimeOfDay.DUSK]: [ Species.TANGELA, { 1: [ Species.SPINARAK ], 22: [ Species.ARIADOS ]}, { 1: [ Species.PANCHAM ], 52: [ Species.PANGORO ]}], + [TimeOfDay.NIGHT]: [ Species.TANGELA, { 1: [ Species.PANCHAM ], 52: [ Species.PANGORO ]}], [TimeOfDay.ALL]: [ - { 1: [ Species.PANSAGE ], 30: [ Species.SIMISAGE ] }, - { 1: [ Species.PANSEAR ], 30: [ Species.SIMISEAR ] }, - { 1: [ Species.PANPOUR ], 30: [ Species.SIMIPOUR ] }, - { 1: [ Species.JOLTIK ], 36: [ Species.GALVANTULA ] }, - { 1: [ Species.LITLEO ], 35: [ Species.PYROAR ] }, - { 1: [ Species.FOMANTIS ], 44: [ Species.LURANTIS ] }, + { 1: [ Species.PANSAGE ], 30: [ Species.SIMISAGE ]}, + { 1: [ Species.PANSEAR ], 30: [ Species.SIMISEAR ]}, + { 1: [ Species.PANPOUR ], 30: [ Species.SIMIPOUR ]}, + { 1: [ Species.JOLTIK ], 36: [ Species.GALVANTULA ]}, + { 1: [ Species.LITLEO ], 35: [ Species.PYROAR ]}, + { 1: [ Species.FOMANTIS ], 44: [ Species.LURANTIS ]}, Species.FALINKS ] }, [BiomePoolTier.RARE]: { - [TimeOfDay.DAWN]: [ { 1: [ Species.FOONGUS ], 39: [ Species.AMOONGUSS ] }, Species.PASSIMIAN, { 1: [ Species.GALAR_PONYTA ], 40: [ Species.GALAR_RAPIDASH ] } ], - [TimeOfDay.DAY]: [ { 1: [ Species.FOONGUS ], 39: [ Species.AMOONGUSS ] }, Species.PASSIMIAN ], + [TimeOfDay.DAWN]: [{ 1: [ Species.FOONGUS ], 39: [ Species.AMOONGUSS ]}, Species.PASSIMIAN, { 1: [ Species.GALAR_PONYTA ], 40: [ Species.GALAR_RAPIDASH ]}], + [TimeOfDay.DAY]: [{ 1: [ Species.FOONGUS ], 39: [ Species.AMOONGUSS ]}, Species.PASSIMIAN ], [TimeOfDay.DUSK]: [ Species.ORANGURU ], [TimeOfDay.NIGHT]: [ Species.ORANGURU ], [TimeOfDay.ALL]: [ Species.SCYTHER, Species.YANMA, - { 1: [ Species.SLAKOTH ], 18: [ Species.VIGOROTH ], 36: [ Species.SLAKING ] }, + { 1: [ Species.SLAKOTH ], 18: [ Species.VIGOROTH ], 36: [ Species.SLAKING ]}, Species.SEVIPER, Species.CARNIVINE, - { 1: [ Species.SNIVY ], 17: [ Species.SERVINE ], 36: [ Species.SERPERIOR ] }, - { 1: [ Species.GROOKEY ], 16: [ Species.THWACKEY ], 35: [ Species.RILLABOOM ] } + { 1: [ Species.SNIVY ], 17: [ Species.SERVINE ], 36: [ Species.SERPERIOR ]}, + { 1: [ Species.GROOKEY ], 16: [ Species.THWACKEY ], 35: [ Species.RILLABOOM ]} ] }, - [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.KANGASKHAN, Species.CHATOT, Species.KLEAVOR ] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.TAPU_LELE, Species.BUZZWOLE, Species.ZARUDE, Species.MUNKIDORI ] }, + [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.KANGASKHAN, Species.CHATOT, Species.KLEAVOR ]}, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.TAPU_LELE, Species.BUZZWOLE, Species.ZARUDE, Species.MUNKIDORI ]}, [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [ Species.EXEGGUTOR, Species.TROPIUS, Species.CHERRIM, Species.LEAVANNY, Species.KOMALA ], [TimeOfDay.DAY]: [ Species.EXEGGUTOR, Species.TROPIUS, Species.CHERRIM, Species.LEAVANNY, Species.KOMALA ], @@ -1371,8 +1371,8 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.KANGASKHAN, Species.SCIZOR, Species.SLAKING, Species.LEAFEON, Species.SERPERIOR, Species.RILLABOOM ] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.TAPU_LELE, Species.BUZZWOLE, Species.ZARUDE, Species.MUNKIDORI ] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.KLEAVOR ] } + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.TAPU_LELE, Species.BUZZWOLE, Species.ZARUDE, Species.MUNKIDORI ]}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.KLEAVOR ]} }, [Biome.FAIRY_CAVE]: { [BiomePoolTier.COMMON]: { @@ -1381,14 +1381,14 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ - { 1: [ Species.JIGGLYPUFF ], 30: [ Species.WIGGLYTUFF ] }, - { 1: [ Species.MARILL ], 18: [ Species.AZUMARILL ] }, + { 1: [ Species.JIGGLYPUFF ], 30: [ Species.WIGGLYTUFF ]}, + { 1: [ Species.MARILL ], 18: [ Species.AZUMARILL ]}, Species.MAWILE, - { 1: [ Species.SPRITZEE ], 40: [ Species.AROMATISSE ] }, - { 1: [ Species.SWIRLIX ], 40: [ Species.SLURPUFF ] }, - { 1: [ Species.CUTIEFLY ], 25: [ Species.RIBOMBEE ] }, - { 1: [ Species.MORELULL ], 24: [ Species.SHIINOTIC ] }, - { 1: [ Species.MILCERY ], 30: [ Species.ALCREMIE ] } + { 1: [ Species.SPRITZEE ], 40: [ Species.AROMATISSE ]}, + { 1: [ Species.SWIRLIX ], 40: [ Species.SLURPUFF ]}, + { 1: [ Species.CUTIEFLY ], 25: [ Species.RIBOMBEE ]}, + { 1: [ Species.MORELULL ], 24: [ Species.SHIINOTIC ]}, + { 1: [ Species.MILCERY ], 30: [ Species.ALCREMIE ]} ] }, [BiomePoolTier.UNCOMMON]: { @@ -1399,15 +1399,15 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.ALL]: [ Species.CLEFAIRY, Species.TOGETIC, - { 1: [ Species.RALTS ], 20: [ Species.KIRLIA ], 30: [ Species.GARDEVOIR ] }, + { 1: [ Species.RALTS ], 20: [ Species.KIRLIA ], 30: [ Species.GARDEVOIR ]}, Species.CARBINK, Species.COMFEY, - { 1: [ Species.HATENNA ], 32: [ Species.HATTREM ], 42: [ Species.HATTERENE ] } + { 1: [ Species.HATENNA ], 32: [ Species.HATTREM ], 42: [ Species.HATTERENE ]} ] }, - [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.AUDINO, Species.ETERNAL_FLOETTE ] }, - [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.DIANCIE, Species.ENAMORUS ] }, + [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.AUDINO, Species.ETERNAL_FLOETTE ]}, + [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []}, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.DIANCIE, Species.ENAMORUS ]}, [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], @@ -1415,9 +1415,9 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.WIGGLYTUFF, Species.MAWILE, Species.TOGEKISS, Species.AUDINO, Species.AROMATISSE, Species.SLURPUFF, Species.CARBINK, Species.RIBOMBEE, Species.SHIINOTIC, Species.COMFEY, Species.HATTERENE, Species.ALCREMIE ] }, - [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ETERNAL_FLOETTE ] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.DIANCIE, Species.ENAMORUS ] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.XERNEAS ] } + [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ETERNAL_FLOETTE ]}, + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.DIANCIE, Species.ENAMORUS ]}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.XERNEAS ]} }, [Biome.TEMPLE]: { [BiomePoolTier.COMMON]: { @@ -1426,12 +1426,12 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ - { 1: [ Species.GASTLY ], 25: [ Species.HAUNTER ] }, - { 1: [ Species.NATU ], 25: [ Species.XATU ] }, - { 1: [ Species.DUSKULL ], 37: [ Species.DUSCLOPS ] }, - { 1: [ Species.YAMASK ], 34: [ Species.COFAGRIGUS ] }, - { 1: [ Species.GOLETT ], 43: [ Species.GOLURK ] }, - { 1: [ Species.HONEDGE ], 35: [ Species.DOUBLADE ] } + { 1: [ Species.GASTLY ], 25: [ Species.HAUNTER ]}, + { 1: [ Species.NATU ], 25: [ Species.XATU ]}, + { 1: [ Species.DUSKULL ], 37: [ Species.DUSCLOPS ]}, + { 1: [ Species.YAMASK ], 34: [ Species.COFAGRIGUS ]}, + { 1: [ Species.GOLETT ], 43: [ Species.GOLURK ]}, + { 1: [ Species.HONEDGE ], 35: [ Species.DOUBLADE ]} ] }, [BiomePoolTier.UNCOMMON]: { @@ -1440,86 +1440,86 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ - { 1: [ Species.CUBONE ], 28: [ Species.MAROWAK ] }, - { 1: [ Species.BALTOY ], 36: [ Species.CLAYDOL ] }, - { 1: [ Species.CHINGLING ], 20: [ Species.CHIMECHO ] }, - { 1: [ Species.SKORUPI ], 40: [ Species.DRAPION ] }, - { 1: [ Species.LITWICK ], 41: [ Species.LAMPENT ] } + { 1: [ Species.CUBONE ], 28: [ Species.MAROWAK ]}, + { 1: [ Species.BALTOY ], 36: [ Species.CLAYDOL ]}, + { 1: [ Species.CHINGLING ], 20: [ Species.CHIMECHO ]}, + { 1: [ Species.SKORUPI ], 40: [ Species.DRAPION ]}, + { 1: [ Species.LITWICK ], 41: [ Species.LAMPENT ]} ] }, - [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ { 1: [ Species.GIMMIGHOUL ], 40: [ Species.GHOLDENGO ] } ] }, - [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.HOOPA, Species.TAPU_KOKO ] }, - [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.CHIMECHO, Species.COFAGRIGUS, Species.GOLURK, Species.AEGISLASH ] }, - [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.GHOLDENGO ] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.HOOPA, Species.TAPU_KOKO ] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.REGIGIGAS ] } + [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [{ 1: [ Species.GIMMIGHOUL ], 40: [ Species.GHOLDENGO ]}]}, + [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []}, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.HOOPA, Species.TAPU_KOKO ]}, + [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.CHIMECHO, Species.COFAGRIGUS, Species.GOLURK, Species.AEGISLASH ]}, + [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.GHOLDENGO ]}, + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.HOOPA, Species.TAPU_KOKO ]}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.REGIGIGAS ]} }, [Biome.SLUM]: { [BiomePoolTier.COMMON]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], - [TimeOfDay.DUSK]: [ { 1: [ Species.PATRAT ], 20: [ Species.WATCHOG ] } ], - [TimeOfDay.NIGHT]: [ { 1: [ Species.PATRAT ], 20: [ Species.WATCHOG ] } ], + [TimeOfDay.DUSK]: [{ 1: [ Species.PATRAT ], 20: [ Species.WATCHOG ]}], + [TimeOfDay.NIGHT]: [{ 1: [ Species.PATRAT ], 20: [ Species.WATCHOG ]}], [TimeOfDay.ALL]: [ - { 1: [ Species.RATTATA ], 20: [ Species.RATICATE ] }, - { 1: [ Species.GRIMER ], 38: [ Species.MUK ] }, - { 1: [ Species.KOFFING ], 35: [ Species.WEEZING ] }, - { 1: [ Species.TRUBBISH ], 36: [ Species.GARBODOR ] } + { 1: [ Species.RATTATA ], 20: [ Species.RATICATE ]}, + { 1: [ Species.GRIMER ], 38: [ Species.MUK ]}, + { 1: [ Species.KOFFING ], 35: [ Species.WEEZING ]}, + { 1: [ Species.TRUBBISH ], 36: [ Species.GARBODOR ]} ] }, [BiomePoolTier.UNCOMMON]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], - [TimeOfDay.DUSK]: [ { 1: [ Species.STUNKY ], 34: [ Species.SKUNTANK ] } ], - [TimeOfDay.NIGHT]: [ { 1: [ Species.STUNKY ], 34: [ Species.SKUNTANK ] } ], - [TimeOfDay.ALL]: [ { 1: [ Species.BURMY ], 20: [ Species.WORMADAM ] } ] + [TimeOfDay.DUSK]: [{ 1: [ Species.STUNKY ], 34: [ Species.SKUNTANK ]}], + [TimeOfDay.NIGHT]: [{ 1: [ Species.STUNKY ], 34: [ Species.SKUNTANK ]}], + [TimeOfDay.ALL]: [{ 1: [ Species.BURMY ], 20: [ Species.WORMADAM ]}] }, [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], - [TimeOfDay.DUSK]: [ Species.TOXTRICITY, { 1: [ Species.GALAR_LINOONE ], 65: [ Species.OBSTAGOON ] }, Species.GALAR_ZIGZAGOON ], - [TimeOfDay.NIGHT]: [ Species.TOXTRICITY, { 1: [ Species.GALAR_LINOONE ], 65: [ Species.OBSTAGOON ] }, Species.GALAR_ZIGZAGOON ], - [TimeOfDay.ALL]: [ { 1: [ Species.VAROOM ], 40: [ Species.REVAVROOM ] } ] + [TimeOfDay.DUSK]: [ Species.TOXTRICITY, { 1: [ Species.GALAR_LINOONE ], 65: [ Species.OBSTAGOON ]}, Species.GALAR_ZIGZAGOON ], + [TimeOfDay.NIGHT]: [ Species.TOXTRICITY, { 1: [ Species.GALAR_LINOONE ], 65: [ Species.OBSTAGOON ]}, Species.GALAR_ZIGZAGOON ], + [TimeOfDay.ALL]: [{ 1: [ Species.VAROOM ], 40: [ Species.REVAVROOM ]}] }, - [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.GUZZLORD ] }, - [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [ Species.SKUNTANK, Species.WATCHOG ], [TimeOfDay.NIGHT]: [ Species.SKUNTANK, Species.WATCHOG ], [TimeOfDay.ALL]: [ Species.MUK, Species.WEEZING, Species.WORMADAM, Species.GARBODOR ] }, - [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [ Species.TOXTRICITY, Species.OBSTAGOON ], [TimeOfDay.NIGHT]: [ Species.TOXTRICITY, Species.OBSTAGOON ], [TimeOfDay.ALL]: [ Species.REVAVROOM, Species.GALAR_WEEZING ] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.GUZZLORD ] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] } + [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []}, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.GUZZLORD ]}, + [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [ Species.SKUNTANK, Species.WATCHOG ], [TimeOfDay.NIGHT]: [ Species.SKUNTANK, Species.WATCHOG ], [TimeOfDay.ALL]: [ Species.MUK, Species.WEEZING, Species.WORMADAM, Species.GARBODOR ]}, + [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [ Species.TOXTRICITY, Species.OBSTAGOON ], [TimeOfDay.NIGHT]: [ Species.TOXTRICITY, Species.OBSTAGOON ], [TimeOfDay.ALL]: [ Species.REVAVROOM, Species.GALAR_WEEZING ]}, + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.GUZZLORD ]}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []} }, [Biome.SNOWY_FOREST]: { [BiomePoolTier.COMMON]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], - [TimeOfDay.DUSK]: [ Species.SNEASEL, { 1: [ Species.TEDDIURSA ], 30: [ Species.URSARING ] }, { 1: [ Species.SNOM ], 20: [ Species.FROSMOTH ] } ], - [TimeOfDay.NIGHT]: [ Species.SNEASEL, { 1: [ Species.TEDDIURSA ], 30: [ Species.URSARING ] }, { 1: [ Species.SNOM ], 20: [ Species.FROSMOTH ] } ], - [TimeOfDay.ALL]: [ { 1: [ Species.SWINUB ], 33: [ Species.PILOSWINE ] }, { 1: [ Species.SNOVER ], 40: [ Species.ABOMASNOW ] }, Species.EISCUE ] + [TimeOfDay.DUSK]: [ Species.SNEASEL, { 1: [ Species.TEDDIURSA ], 30: [ Species.URSARING ]}, { 1: [ Species.SNOM ], 20: [ Species.FROSMOTH ]}], + [TimeOfDay.NIGHT]: [ Species.SNEASEL, { 1: [ Species.TEDDIURSA ], 30: [ Species.URSARING ]}, { 1: [ Species.SNOM ], 20: [ Species.FROSMOTH ]}], + [TimeOfDay.ALL]: [{ 1: [ Species.SWINUB ], 33: [ Species.PILOSWINE ]}, { 1: [ Species.SNOVER ], 40: [ Species.ABOMASNOW ]}, Species.EISCUE ] }, [BiomePoolTier.UNCOMMON]: { - [TimeOfDay.DAWN]: [ Species.SNEASEL, { 1: [ Species.TEDDIURSA ], 30: [ Species.URSARING ] }, Species.STANTLER ], - [TimeOfDay.DAY]: [ Species.SNEASEL, { 1: [ Species.TEDDIURSA ], 30: [ Species.URSARING ] }, Species.STANTLER ], + [TimeOfDay.DAWN]: [ Species.SNEASEL, { 1: [ Species.TEDDIURSA ], 30: [ Species.URSARING ]}, Species.STANTLER ], + [TimeOfDay.DAY]: [ Species.SNEASEL, { 1: [ Species.TEDDIURSA ], 30: [ Species.URSARING ]}, Species.STANTLER ], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] }, [BiomePoolTier.RARE]: { - [TimeOfDay.DAWN]: [ { 1: [ Species.GALAR_DARUMAKA ], 30: [ Species.GALAR_DARMANITAN ] } ], - [TimeOfDay.DAY]: [ { 1: [ Species.GALAR_DARUMAKA ], 30: [ Species.GALAR_DARMANITAN ] } ], + [TimeOfDay.DAWN]: [{ 1: [ Species.GALAR_DARUMAKA ], 30: [ Species.GALAR_DARMANITAN ]}], + [TimeOfDay.DAY]: [{ 1: [ Species.GALAR_DARUMAKA ], 30: [ Species.GALAR_DARMANITAN ]}], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], - [TimeOfDay.ALL]: [ Species.DELIBIRD, { 1: [ Species.ALOLA_SANDSHREW ], 30: [ Species.ALOLA_SANDSLASH ] }, { 1: [ Species.ALOLA_VULPIX ], 30: [ Species.ALOLA_NINETALES ] } ] + [TimeOfDay.ALL]: [ Species.DELIBIRD, { 1: [ Species.ALOLA_SANDSHREW ], 30: [ Species.ALOLA_SANDSLASH ]}, { 1: [ Species.ALOLA_VULPIX ], 30: [ Species.ALOLA_NINETALES ]}] }, [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [ Species.HISUI_SNEASEL ], [TimeOfDay.DAY]: [ Species.HISUI_SNEASEL ], - [TimeOfDay.DUSK]: [ { 1: [ Species.HISUI_ZORUA ], 30: [ Species.HISUI_ZOROARK ] } ], - [TimeOfDay.NIGHT]: [ { 1: [ Species.HISUI_ZORUA ], 30: [ Species.HISUI_ZOROARK ] } ], - [TimeOfDay.ALL]: [ { 1: [ Species.GALAR_MR_MIME ], 42: [ Species.MR_RIME ] }, Species.ARCTOZOLT, Species.HISUI_AVALUGG ] + [TimeOfDay.DUSK]: [{ 1: [ Species.HISUI_ZORUA ], 30: [ Species.HISUI_ZOROARK ]}], + [TimeOfDay.NIGHT]: [{ 1: [ Species.HISUI_ZORUA ], 30: [ Species.HISUI_ZOROARK ]}], + [TimeOfDay.ALL]: [{ 1: [ Species.GALAR_MR_MIME ], 42: [ Species.MR_RIME ]}, Species.ARCTOZOLT, Species.HISUI_AVALUGG ] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.GLASTRIER, Species.CHIEN_PAO, Species.GALAR_ARTICUNO ] }, - [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [ Species.WYRDEER ], [TimeOfDay.DAY]: [ Species.WYRDEER ], [TimeOfDay.DUSK]: [ Species.FROSMOTH ], [TimeOfDay.NIGHT]: [ Species.FROSMOTH ], [TimeOfDay.ALL]: [ Species.ABOMASNOW, Species.URSALUNA ] }, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.GLASTRIER, Species.CHIEN_PAO, Species.GALAR_ARTICUNO ]}, + [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [ Species.WYRDEER ], [TimeOfDay.DAY]: [ Species.WYRDEER ], [TimeOfDay.DUSK]: [ Species.FROSMOTH ], [TimeOfDay.NIGHT]: [ Species.FROSMOTH ], [TimeOfDay.ALL]: [ Species.ABOMASNOW, Species.URSALUNA ]}, [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [ Species.SNEASLER, Species.GALAR_DARMANITAN ], [TimeOfDay.DAY]: [ Species.SNEASLER, Species.GALAR_DARMANITAN ], @@ -1527,22 +1527,22 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.NIGHT]: [ Species.HISUI_ZOROARK ], [TimeOfDay.ALL]: [ Species.MR_RIME, Species.ARCTOZOLT, Species.ALOLA_SANDSLASH, Species.ALOLA_NINETALES ] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.GLASTRIER, Species.CHIEN_PAO ] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ZACIAN, Species.GALAR_ARTICUNO ] } + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.GLASTRIER, Species.CHIEN_PAO ]}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ZACIAN, Species.GALAR_ARTICUNO ]} }, [Biome.ISLAND]: { [BiomePoolTier.COMMON]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], - [TimeOfDay.DUSK]: [ { 1: [ Species.ALOLA_RATTATA ], 30: [ Species.ALOLA_RATICATE ] }, { 1: [ Species.ALOLA_MEOWTH ], 30: [ Species.ALOLA_PERSIAN ] } ], - [TimeOfDay.NIGHT]: [ { 1: [ Species.ALOLA_RATTATA ], 30: [ Species.ALOLA_RATICATE ] }, { 1: [ Species.ALOLA_MEOWTH ], 30: [ Species.ALOLA_PERSIAN ] } ], + [TimeOfDay.DUSK]: [{ 1: [ Species.ALOLA_RATTATA ], 30: [ Species.ALOLA_RATICATE ]}, { 1: [ Species.ALOLA_MEOWTH ], 30: [ Species.ALOLA_PERSIAN ]}], + [TimeOfDay.NIGHT]: [{ 1: [ Species.ALOLA_RATTATA ], 30: [ Species.ALOLA_RATICATE ]}, { 1: [ Species.ALOLA_MEOWTH ], 30: [ Species.ALOLA_PERSIAN ]}], [TimeOfDay.ALL]: [ Species.ORICORIO, - { 1: [ Species.ALOLA_SANDSHREW ], 30: [ Species.ALOLA_SANDSLASH ] }, - { 1: [ Species.ALOLA_VULPIX ], 30: [ Species.ALOLA_NINETALES ] }, - { 1: [ Species.ALOLA_DIGLETT ], 26: [ Species.ALOLA_DUGTRIO ] }, - { 1: [ Species.ALOLA_GEODUDE ], 25: [ Species.ALOLA_GRAVELER ], 40: [ Species.ALOLA_GOLEM ] }, - { 1: [ Species.ALOLA_GRIMER ], 38: [ Species.ALOLA_MUK ] } + { 1: [ Species.ALOLA_SANDSHREW ], 30: [ Species.ALOLA_SANDSLASH ]}, + { 1: [ Species.ALOLA_VULPIX ], 30: [ Species.ALOLA_NINETALES ]}, + { 1: [ Species.ALOLA_DIGLETT ], 26: [ Species.ALOLA_DUGTRIO ]}, + { 1: [ Species.ALOLA_GEODUDE ], 25: [ Species.ALOLA_GRAVELER ], 40: [ Species.ALOLA_GOLEM ]}, + { 1: [ Species.ALOLA_GRIMER ], 38: [ Species.ALOLA_MUK ]} ] }, [BiomePoolTier.UNCOMMON]: { @@ -1552,9 +1552,9 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.NIGHT]: [ Species.ALOLA_MAROWAK ], [TimeOfDay.ALL]: [ Species.BRUXISH ] }, - [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] }, - [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.BLACEPHALON ] }, + [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []}, + [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []}, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.BLACEPHALON ]}, [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [ Species.ALOLA_RAICHU, Species.ALOLA_EXEGGUTOR ], [TimeOfDay.DAY]: [ Species.ALOLA_RAICHU, Species.ALOLA_EXEGGUTOR ], @@ -1562,9 +1562,9 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.NIGHT]: [ Species.ALOLA_RATICATE, Species.ALOLA_PERSIAN, Species.ALOLA_MAROWAK ], [TimeOfDay.ALL]: [ Species.ORICORIO, Species.BRUXISH, Species.ALOLA_SANDSLASH, Species.ALOLA_NINETALES, Species.ALOLA_DUGTRIO, Species.ALOLA_GOLEM, Species.ALOLA_MUK ] }, - [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.BLACEPHALON ] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] } + [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []}, + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.BLACEPHALON ]}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []} }, [Biome.LABORATORY]: { [BiomePoolTier.COMMON]: { @@ -1573,21 +1573,21 @@ export const biomePokemonPools: BiomePokemonPools = { [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ - { 1: [ Species.MAGNEMITE ], 30: [ Species.MAGNETON ] }, - { 1: [ Species.GRIMER ], 38: [ Species.MUK ] }, - { 1: [ Species.VOLTORB ], 30: [ Species.ELECTRODE ] }, - { 1: [ Species.BRONZOR ], 33: [ Species.BRONZONG ] }, - { 1: [ Species.KLINK ], 38: [ Species.KLANG ], 49: [ Species.KLINKLANG ] } + { 1: [ Species.MAGNEMITE ], 30: [ Species.MAGNETON ]}, + { 1: [ Species.GRIMER ], 38: [ Species.MUK ]}, + { 1: [ Species.VOLTORB ], 30: [ Species.ELECTRODE ]}, + { 1: [ Species.BRONZOR ], 33: [ Species.BRONZONG ]}, + { 1: [ Species.KLINK ], 38: [ Species.KLANG ], 49: [ Species.KLINKLANG ]} ] }, - [BiomePoolTier.UNCOMMON]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ { 1: [ Species.SOLOSIS ], 32: [ Species.DUOSION ], 41: [ Species.REUNICLUS ] } ] }, - [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.DITTO, { 1: [ Species.PORYGON ], 30: [ Species.PORYGON2 ] } ] }, - [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ROTOM ] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.TYPE_NULL ] }, - [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.MUK, Species.ELECTRODE, Species.BRONZONG, Species.MAGNEZONE, Species.PORYGON_Z, Species.REUNICLUS, Species.KLINKLANG ] }, - [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ROTOM, Species.ZYGARDE, Species.SILVALLY ] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.MEWTWO, Species.MIRAIDON ] } + [BiomePoolTier.UNCOMMON]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [{ 1: [ Species.SOLOSIS ], 32: [ Species.DUOSION ], 41: [ Species.REUNICLUS ]}]}, + [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.DITTO, { 1: [ Species.PORYGON ], 30: [ Species.PORYGON2 ]}]}, + [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ROTOM ]}, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.TYPE_NULL ]}, + [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.MUK, Species.ELECTRODE, Species.BRONZONG, Species.MAGNEZONE, Species.PORYGON_Z, Species.REUNICLUS, Species.KLINKLANG ]}, + [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []}, + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ROTOM, Species.ZYGARDE, Species.SILVALLY ]}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.MEWTWO, Species.MIRAIDON ]} }, [Biome.END]: { [BiomePoolTier.COMMON]: { @@ -1610,14 +1610,14 @@ export const biomePokemonPools: BiomePokemonPools = { Species.IRON_THORNS ] }, - [BiomePoolTier.UNCOMMON]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ROARING_MOON, Species.IRON_VALIANT ] }, - [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.WALKING_WAKE, Species.IRON_LEAVES, Species.GOUGING_FIRE, Species.RAGING_BOLT, Species.IRON_BOULDER, Species.IRON_CROWN ] }, - [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] }, - [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] }, - [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ETERNATUS ] }, - [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] }, - [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] }, - [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [] } + [BiomePoolTier.UNCOMMON]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ROARING_MOON, Species.IRON_VALIANT ]}, + [BiomePoolTier.RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.WALKING_WAKE, Species.IRON_LEAVES, Species.GOUGING_FIRE, Species.RAGING_BOLT, Species.IRON_BOULDER, Species.IRON_CROWN ]}, + [BiomePoolTier.SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []}, + [BiomePoolTier.ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []}, + [BiomePoolTier.BOSS]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: [ Species.ETERNATUS ]}, + [BiomePoolTier.BOSS_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []}, + [BiomePoolTier.BOSS_SUPER_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []}, + [BiomePoolTier.BOSS_ULTRA_RARE]: { [TimeOfDay.DAWN]: [], [TimeOfDay.DAY]: [], [TimeOfDay.DUSK]: [], [TimeOfDay.NIGHT]: [], [TimeOfDay.ALL]: []} } }; @@ -2051,27 +2051,27 @@ export function initBiomes() { ] ], [ Species.CATERPIE, Type.BUG, -1, [ - [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.METAPOD, Type.BUG, -1, [ - [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.BUTTERFREE, Type.BUG, Type.FLYING, [ - [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.WEEDLE, Type.BUG, Type.POISON, [ - [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.KAKUNA, Type.BUG, Type.POISON, [ - [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.BEEDRILL, Type.BUG, Type.POISON, [ - [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.PIDGEY, Type.NORMAL, Type.FLYING, [ @@ -2115,17 +2115,17 @@ export function initBiomes() { ] ], [ Species.EKANS, Type.POISON, -1, [ - [ Biome.TOWN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], + [ Biome.TOWN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], [ Biome.FOREST, BiomePoolTier.UNCOMMON ], - [ Biome.SWAMP, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.SWAMP, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.SWAMP, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.SWAMP, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.ARBOK, Type.POISON, -1, [ [ Biome.FOREST, BiomePoolTier.UNCOMMON ], - [ Biome.SWAMP, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.SWAMP, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.SWAMP, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.SWAMP, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.SWAMP, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.SWAMP, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.PIKACHU, Type.ELECTRIC, -1, [ @@ -2215,16 +2215,16 @@ export function initBiomes() { ] ], [ Species.ODDISH, Type.GRASS, Type.POISON, [ - [ Biome.TOWN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.TALL_GRASS, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.TOWN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.TALL_GRASS, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.GLOOM, Type.GRASS, Type.POISON, [ - [ Biome.TALL_GRASS, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.TALL_GRASS, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.VILEPLUME, Type.GRASS, Type.POISON, [ - [ Biome.TALL_GRASS, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.TALL_GRASS, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.PARAS, Type.BUG, Type.GRASS, [ @@ -2261,13 +2261,13 @@ export function initBiomes() { ] ], [ Species.MEOWTH, Type.NORMAL, -1, [ - [ Biome.TOWN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.PLAINS, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.TOWN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.PLAINS, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.PERSIAN, Type.NORMAL, -1, [ - [ Biome.PLAINS, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.PLAINS, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.PLAINS, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.PLAINS, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.PSYDUCK, Type.WATER, -1, [ @@ -2282,12 +2282,12 @@ export function initBiomes() { ] ], [ Species.MANKEY, Type.FIGHTING, -1, [ - [ Biome.PLAINS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], + [ Biome.PLAINS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], [ Biome.DOJO, BiomePoolTier.COMMON ] ] ], [ Species.PRIMEAPE, Type.FIGHTING, -1, [ - [ Biome.PLAINS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], + [ Biome.PLAINS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], [ Biome.DOJO, BiomePoolTier.COMMON ] ] ], @@ -2346,16 +2346,16 @@ export function initBiomes() { ] ], [ Species.BELLSPROUT, Type.GRASS, Type.POISON, [ - [ Biome.TOWN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.TOWN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.WEEPINBELL, Type.GRASS, Type.POISON, [ - [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.VICTREEBEL, Type.GRASS, Type.POISON, [ - [ Biome.FOREST, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.FOREST, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.TENTACOOL, Type.WATER, Type.POISON, [ @@ -2386,25 +2386,25 @@ export function initBiomes() { ] ], [ Species.PONYTA, Type.FIRE, -1, [ - [ Biome.MEADOW, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], + [ Biome.MEADOW, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], [ Biome.VOLCANO, BiomePoolTier.COMMON ] ] ], [ Species.RAPIDASH, Type.FIRE, -1, [ - [ Biome.MEADOW, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], + [ Biome.MEADOW, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], [ Biome.VOLCANO, BiomePoolTier.COMMON ], [ Biome.VOLCANO, BiomePoolTier.BOSS ] ] ], [ Species.SLOWPOKE, Type.WATER, Type.PSYCHIC, [ - [ Biome.SEA, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.SEA, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], + [ Biome.SEA, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.SEA, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], [ Biome.LAKE, BiomePoolTier.UNCOMMON ] ] ], [ Species.SLOWBRO, Type.WATER, Type.PSYCHIC, [ - [ Biome.SEA, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.SEA, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], + [ Biome.SEA, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.SEA, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], [ Biome.LAKE, BiomePoolTier.UNCOMMON ], [ Biome.LAKE, BiomePoolTier.BOSS ] ] @@ -2429,12 +2429,12 @@ export function initBiomes() { ] ], [ Species.DODUO, Type.NORMAL, Type.FLYING, [ - [ Biome.PLAINS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.PLAINS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.DODRIO, Type.NORMAL, Type.FLYING, [ - [ Biome.PLAINS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.PLAINS, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.PLAINS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.PLAINS, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.SEEL, Type.WATER, -1, [ @@ -2461,13 +2461,13 @@ export function initBiomes() { ] ], [ Species.SHELLDER, Type.WATER, -1, [ - [ Biome.SEA, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.BEACH, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], + [ Biome.SEA, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.BEACH, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], [ Biome.SEABED, BiomePoolTier.UNCOMMON ] ] ], [ Species.CLOYSTER, Type.WATER, Type.ICE, [ - [ Biome.BEACH, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.BEACH, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.GASTLY, Type.GHOST, Type.POISON, [ @@ -2523,12 +2523,12 @@ export function initBiomes() { ] ], [ Species.EXEGGCUTE, Type.GRASS, Type.PSYCHIC, [ - [ Biome.FOREST, BiomePoolTier.RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.JUNGLE, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.FOREST, BiomePoolTier.RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.JUNGLE, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.EXEGGUTOR, Type.GRASS, Type.PSYCHIC, [ - [ Biome.JUNGLE, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.JUNGLE, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.CUBONE, Type.GROUND, -1, [ @@ -2542,7 +2542,7 @@ export function initBiomes() { [ Biome.GRAVEYARD, BiomePoolTier.UNCOMMON ], [ Biome.TEMPLE, BiomePoolTier.UNCOMMON ], [ Biome.BADLANDS, BiomePoolTier.BOSS, TimeOfDay.NIGHT ], - [ Biome.GRAVEYARD, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY, TimeOfDay.DUSK ] ] + [ Biome.GRAVEYARD, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY, TimeOfDay.DUSK ]] ] ], [ Species.HITMONLEE, Type.FIGHTING, -1, [ @@ -2573,15 +2573,15 @@ export function initBiomes() { ] ], [ Species.RHYHORN, Type.GROUND, Type.ROCK, [ - [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], + [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], [ Biome.BADLANDS, BiomePoolTier.COMMON ], [ Biome.CONSTRUCTION_SITE, BiomePoolTier.UNCOMMON ] ] ], [ Species.RHYDON, Type.GROUND, Type.ROCK, [ - [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], + [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], [ Biome.BADLANDS, BiomePoolTier.COMMON ], [ Biome.CONSTRUCTION_SITE, BiomePoolTier.UNCOMMON ] ] @@ -2592,7 +2592,7 @@ export function initBiomes() { ] ], [ Species.TANGELA, Type.GRASS, -1, [ - [ Biome.JUNGLE, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.JUNGLE, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.KANGASKHAN, Type.NORMAL, -1, [ @@ -2620,14 +2620,14 @@ export function initBiomes() { ] ], [ Species.STARYU, Type.WATER, -1, [ - [ Biome.BEACH, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.SEA, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.BEACH, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.SEA, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.STARMIE, Type.WATER, Type.PSYCHIC, [ - [ Biome.BEACH, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.BEACH, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.SEA, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.BEACH, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.BEACH, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.SEA, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.MR_MIME, Type.PSYCHIC, Type.FAIRY, [ @@ -2637,7 +2637,7 @@ export function initBiomes() { ], [ Species.SCYTHER, Type.BUG, Type.FLYING, [ [ Biome.TALL_GRASS, BiomePoolTier.SUPER_RARE ], - [ Biome.FOREST, BiomePoolTier.RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], + [ Biome.FOREST, BiomePoolTier.RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], [ Biome.JUNGLE, BiomePoolTier.RARE ] ] ], @@ -2817,13 +2817,13 @@ export function initBiomes() { ] ], [ Species.SENTRET, Type.NORMAL, -1, [ - [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.PLAINS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.PLAINS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.FURRET, Type.NORMAL, -1, [ - [ Biome.PLAINS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.PLAINS, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.PLAINS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.PLAINS, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.HOOTHOOT, Type.NORMAL, Type.FLYING, [ @@ -2860,7 +2860,7 @@ export function initBiomes() { [ Biome.TALL_GRASS, BiomePoolTier.UNCOMMON, TimeOfDay.NIGHT ], [ Biome.FOREST, BiomePoolTier.UNCOMMON, TimeOfDay.DUSK ], [ Biome.FOREST, BiomePoolTier.COMMON, TimeOfDay.NIGHT ], - [ Biome.FOREST, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], + [ Biome.FOREST, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], [ Biome.JUNGLE, BiomePoolTier.UNCOMMON, TimeOfDay.DUSK ], [ Biome.JUNGLE, BiomePoolTier.COMMON, TimeOfDay.NIGHT ] ] @@ -2921,17 +2921,17 @@ export function initBiomes() { ] ], [ Species.BELLOSSOM, Type.GRASS, -1, [ - [ Biome.TALL_GRASS, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.TALL_GRASS, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.MARILL, Type.WATER, Type.FAIRY, [ - [ Biome.LAKE, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], + [ Biome.LAKE, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], [ Biome.FAIRY_CAVE, BiomePoolTier.COMMON ] ] ], [ Species.AZUMARILL, Type.WATER, Type.FAIRY, [ - [ Biome.LAKE, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.LAKE, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], + [ Biome.LAKE, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.LAKE, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], [ Biome.FAIRY_CAVE, BiomePoolTier.COMMON ] ] ], @@ -2946,16 +2946,16 @@ export function initBiomes() { ] ], [ Species.HOPPIP, Type.GRASS, Type.FLYING, [ - [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.GRASS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.GRASS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.SKIPLOOM, Type.GRASS, Type.FLYING, [ - [ Biome.GRASS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.GRASS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.JUMPLUFF, Type.GRASS, Type.FLYING, [ - [ Biome.GRASS, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.GRASS, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.AIPOM, Type.NORMAL, -1, [ @@ -2963,12 +2963,12 @@ export function initBiomes() { ] ], [ Species.SUNKERN, Type.GRASS, -1, [ - [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.GRASS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.GRASS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.SUNFLORA, Type.GRASS, -1, [ - [ Biome.GRASS, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.GRASS, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.YANMA, Type.BUG, Type.FLYING, [ @@ -2977,13 +2977,13 @@ export function initBiomes() { ], [ Species.WOOPER, Type.WATER, Type.GROUND, [ [ Biome.LAKE, BiomePoolTier.UNCOMMON ], - [ Biome.SWAMP, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.SWAMP, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.QUAGSIRE, Type.WATER, Type.GROUND, [ [ Biome.LAKE, BiomePoolTier.UNCOMMON ], - [ Biome.SWAMP, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.SWAMP, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.SWAMP, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.SWAMP, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.ESPEON, Type.PSYCHIC, -1, [ @@ -3024,12 +3024,12 @@ export function initBiomes() { ] ], [ Species.PINECO, Type.BUG, -1, [ - [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.FORRETRESS, Type.BUG, Type.STEEL, [ - [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.FOREST, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.FOREST, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.DUNSPARCE, Type.NORMAL, -1, [ @@ -3045,12 +3045,12 @@ export function initBiomes() { ] ], [ Species.SNUBBULL, Type.FAIRY, -1, [ - [ Biome.MEADOW, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.MEADOW, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.GRANBULL, Type.FAIRY, -1, [ - [ Biome.MEADOW, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.MEADOW, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.MEADOW, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.MEADOW, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.QWILFISH, Type.WATER, Type.POISON, [ @@ -3074,23 +3074,23 @@ export function initBiomes() { ], [ Species.SNEASEL, Type.DARK, Type.ICE, [ [ Biome.ICE_CAVE, BiomePoolTier.UNCOMMON ], - [ Biome.SNOWY_FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.SNOWY_FOREST, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.SNOWY_FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.SNOWY_FOREST, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.TEDDIURSA, Type.NORMAL, -1, [ [ Biome.FOREST, BiomePoolTier.UNCOMMON ], [ Biome.CAVE, BiomePoolTier.COMMON ], - [ Biome.SNOWY_FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.SNOWY_FOREST, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.SNOWY_FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.SNOWY_FOREST, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.URSARING, Type.NORMAL, -1, [ [ Biome.FOREST, BiomePoolTier.UNCOMMON ], [ Biome.CAVE, BiomePoolTier.COMMON ], [ Biome.CAVE, BiomePoolTier.BOSS ], - [ Biome.SNOWY_FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.SNOWY_FOREST, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.SNOWY_FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.SNOWY_FOREST, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.SLUGMA, Type.FIRE, -1, [ @@ -3160,12 +3160,12 @@ export function initBiomes() { ] ], [ Species.PHANPY, Type.GROUND, -1, [ - [ Biome.BADLANDS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.BADLANDS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.DONPHAN, Type.GROUND, -1, [ - [ Biome.BADLANDS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.BADLANDS, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.BADLANDS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.BADLANDS, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.PORYGON2, Type.NORMAL, -1, [ @@ -3175,9 +3175,9 @@ export function initBiomes() { ] ], [ Species.STANTLER, Type.NORMAL, -1, [ - [ Biome.FOREST, BiomePoolTier.RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.FOREST, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.SNOWY_FOREST, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.FOREST, BiomePoolTier.RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.FOREST, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.SNOWY_FOREST, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.SMEARGLE, Type.NORMAL, -1, [ @@ -3224,17 +3224,17 @@ export function initBiomes() { ], [ Species.LARVITAR, Type.ROCK, Type.GROUND, [ [ Biome.MOUNTAIN, BiomePoolTier.SUPER_RARE ], - [ Biome.WASTELAND, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.WASTELAND, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.PUPITAR, Type.ROCK, Type.GROUND, [ [ Biome.MOUNTAIN, BiomePoolTier.SUPER_RARE ], - [ Biome.WASTELAND, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.WASTELAND, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.TYRANITAR, Type.ROCK, Type.DARK, [ - [ Biome.WASTELAND, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.WASTELAND, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.WASTELAND, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.WASTELAND, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.LUGIA, Type.PSYCHIC, Type.FLYING, [ @@ -3287,16 +3287,16 @@ export function initBiomes() { ] ], [ Species.POOCHYENA, Type.DARK, -1, [ - [ Biome.TOWN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.PLAINS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.PLAINS, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.TOWN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.PLAINS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.PLAINS, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.MIGHTYENA, Type.DARK, -1, [ - [ Biome.PLAINS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.PLAINS, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.PLAINS, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.PLAINS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.PLAINS, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.PLAINS, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.ZIGZAGOON, Type.NORMAL, -1, [ @@ -3334,52 +3334,52 @@ export function initBiomes() { ] ], [ Species.LOTAD, Type.WATER, Type.GRASS, [ - [ Biome.TOWN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.LAKE, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.SWAMP, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.TOWN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.LAKE, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.SWAMP, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.LOMBRE, Type.WATER, Type.GRASS, [ - [ Biome.LAKE, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.SWAMP, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.LAKE, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.SWAMP, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.LUDICOLO, Type.WATER, Type.GRASS, [ - [ Biome.SWAMP, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.SWAMP, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.SEEDOT, Type.GRASS, -1, [ - [ Biome.TOWN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.GRASS, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.TOWN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.GRASS, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.NUZLEAF, Type.GRASS, Type.DARK, [ - [ Biome.GRASS, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.GRASS, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.SHIFTRY, Type.GRASS, Type.DARK, [ - [ Biome.FOREST, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.FOREST, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.TAILLOW, Type.NORMAL, Type.FLYING, [ [ Biome.TOWN, BiomePoolTier.COMMON ], - [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.SWELLOW, Type.NORMAL, Type.FLYING, [ - [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.MOUNTAIN, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.MOUNTAIN, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.WINGULL, Type.WATER, Type.FLYING, [ - [ Biome.SEA, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.SEA, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.PELIPPER, Type.WATER, Type.FLYING, [ - [ Biome.SEA, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.SEA, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.SEA, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.SEA, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.RALTS, Type.PSYCHIC, Type.FAIRY, [ @@ -3410,17 +3410,17 @@ export function initBiomes() { ] ], [ Species.SHROOMISH, Type.GRASS, -1, [ - [ Biome.TOWN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.GRASS, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.JUNGLE, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.TOWN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.GRASS, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.JUNGLE, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.BRELOOM, Type.GRASS, Type.FIGHTING, [ - [ Biome.GRASS, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.FOREST, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.JUNGLE, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.GRASS, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.FOREST, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.JUNGLE, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.SLAKOTH, Type.NORMAL, -1, [ @@ -3482,13 +3482,13 @@ export function initBiomes() { ] ], [ Species.SKITTY, Type.NORMAL, -1, [ - [ Biome.TOWN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.MEADOW, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.TOWN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.MEADOW, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.DELCATTY, Type.NORMAL, -1, [ - [ Biome.MEADOW, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.MEADOW, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.MEADOW, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.MEADOW, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.SABLEYE, Type.DARK, Type.GHOST, [ @@ -3502,18 +3502,18 @@ export function initBiomes() { ] ], [ Species.ARON, Type.STEEL, Type.ROCK, [ - [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.LAIRON, Type.STEEL, Type.ROCK, [ - [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.AGGRON, Type.STEEL, Type.ROCK, [ - [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], + [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], [ Biome.MOUNTAIN, BiomePoolTier.BOSS ] ] ], @@ -3552,8 +3552,8 @@ export function initBiomes() { ] ], [ Species.ROSELIA, Type.GRASS, Type.POISON, [ - [ Biome.FOREST, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.MEADOW, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.FOREST, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.MEADOW, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.GULPIN, Type.POISON, -1, [ @@ -3566,12 +3566,12 @@ export function initBiomes() { ] ], [ Species.CARVANHA, Type.WATER, Type.DARK, [ - [ Biome.SEA, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.SEA, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.SHARPEDO, Type.WATER, Type.DARK, [ - [ Biome.SEA, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.SEA, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.SEA, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.SEA, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.WAILMER, Type.WATER, -1, [ @@ -3617,37 +3617,37 @@ export function initBiomes() { ] ], [ Species.TRAPINCH, Type.GROUND, -1, [ - [ Biome.DESERT, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.DESERT, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.VIBRAVA, Type.GROUND, Type.DRAGON, [ - [ Biome.DESERT, BiomePoolTier.RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], + [ Biome.DESERT, BiomePoolTier.RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], [ Biome.WASTELAND, BiomePoolTier.COMMON ] ] ], [ Species.FLYGON, Type.GROUND, Type.DRAGON, [ - [ Biome.DESERT, BiomePoolTier.RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], + [ Biome.DESERT, BiomePoolTier.RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], [ Biome.WASTELAND, BiomePoolTier.COMMON ], [ Biome.WASTELAND, BiomePoolTier.BOSS ] ] ], [ Species.CACNEA, Type.GRASS, -1, [ - [ Biome.DESERT, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.DESERT, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.CACTURNE, Type.GRASS, Type.DARK, [ - [ Biome.DESERT, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.DESERT, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.DESERT, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.DESERT, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.SWABLU, Type.NORMAL, Type.FLYING, [ - [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], + [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], [ Biome.WASTELAND, BiomePoolTier.UNCOMMON ] ] ], [ Species.ALTARIA, Type.DRAGON, Type.FLYING, [ - [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.MOUNTAIN, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], + [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.MOUNTAIN, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], [ Biome.WASTELAND, BiomePoolTier.UNCOMMON ] ] ], @@ -3760,8 +3760,8 @@ export function initBiomes() { [ Species.TROPIUS, Type.GRASS, Type.FLYING, [ [ Biome.TALL_GRASS, BiomePoolTier.RARE ], [ Biome.FOREST, BiomePoolTier.RARE ], - [ Biome.JUNGLE, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.JUNGLE, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.JUNGLE, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.JUNGLE, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.CHIMECHO, Type.PSYCHIC, -1, [ @@ -3821,16 +3821,16 @@ export function initBiomes() { ] ], [ Species.BAGON, Type.DRAGON, -1, [ - [ Biome.WASTELAND, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.WASTELAND, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.SHELGON, Type.DRAGON, -1, [ - [ Biome.WASTELAND, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.WASTELAND, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.SALAMENCE, Type.DRAGON, Type.FLYING, [ - [ Biome.WASTELAND, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.WASTELAND, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.WASTELAND, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.WASTELAND, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.BELDUM, Type.STEEL, Type.PSYCHIC, [ @@ -3930,20 +3930,20 @@ export function initBiomes() { ] ], [ Species.STARLY, Type.NORMAL, Type.FLYING, [ - [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.PLAINS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.PLAINS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.STARAVIA, Type.NORMAL, Type.FLYING, [ - [ Biome.PLAINS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.PLAINS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.STARAPTOR, Type.NORMAL, Type.FLYING, [ - [ Biome.PLAINS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.MOUNTAIN, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.PLAINS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.MOUNTAIN, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.BIDOOF, Type.NORMAL, -1, [ @@ -3957,27 +3957,27 @@ export function initBiomes() { ] ], [ Species.KRICKETOT, Type.BUG, -1, [ - [ Biome.TOWN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.TALL_GRASS, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.TOWN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.TALL_GRASS, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.KRICKETUNE, Type.BUG, -1, [ - [ Biome.TALL_GRASS, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.TALL_GRASS, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.TALL_GRASS, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.TALL_GRASS, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.SHINX, Type.ELECTRIC, -1, [ - [ Biome.PLAINS, BiomePoolTier.RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], + [ Biome.PLAINS, BiomePoolTier.RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], [ Biome.POWER_PLANT, BiomePoolTier.COMMON ] ] ], [ Species.LUXIO, Type.ELECTRIC, -1, [ - [ Biome.PLAINS, BiomePoolTier.RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], + [ Biome.PLAINS, BiomePoolTier.RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], [ Biome.POWER_PLANT, BiomePoolTier.COMMON ] ] ], [ Species.LUXRAY, Type.ELECTRIC, -1, [ - [ Biome.PLAINS, BiomePoolTier.RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], + [ Biome.PLAINS, BiomePoolTier.RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], [ Biome.POWER_PLANT, BiomePoolTier.COMMON ], [ Biome.POWER_PLANT, BiomePoolTier.BOSS ] ] @@ -3985,7 +3985,7 @@ export function initBiomes() { [ Species.BUDEW, Type.GRASS, Type.POISON, [ ] ], [ Species.ROSERADE, Type.GRASS, Type.POISON, [ - [ Biome.MEADOW, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.MEADOW, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.CRANIDOS, Type.ROCK, -1, [ @@ -4022,22 +4022,22 @@ export function initBiomes() { ] ], [ Species.MOTHIM, Type.BUG, Type.FLYING, [ - [ Biome.FOREST, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.FOREST, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.FOREST, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.FOREST, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.COMBEE, Type.BUG, Type.FLYING, [ - [ Biome.TOWN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.GRASS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.JUNGLE, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.TOWN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.GRASS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.JUNGLE, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.VESPIQUEN, Type.BUG, Type.FLYING, [ - [ Biome.GRASS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.FOREST, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.JUNGLE, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.GRASS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.FOREST, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.JUNGLE, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.PACHIRISU, Type.ELECTRIC, -1, [ @@ -4054,15 +4054,15 @@ export function initBiomes() { ] ], [ Species.CHERUBI, Type.GRASS, -1, [ - [ Biome.TOWN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.GRASS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.JUNGLE, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.TOWN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.GRASS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.JUNGLE, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.CHERRIM, Type.GRASS, -1, [ - [ Biome.GRASS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.JUNGLE, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.JUNGLE, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.GRASS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.JUNGLE, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.JUNGLE, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.SHELLOS, Type.WATER, -1, [ @@ -4122,12 +4122,12 @@ export function initBiomes() { ] ], [ Species.STUNKY, Type.POISON, Type.DARK, [ - [ Biome.SLUM, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.SLUM, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.SKUNTANK, Type.POISON, Type.DARK, [ - [ Biome.SLUM, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.SLUM, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.SLUM, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.SLUM, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.BRONZOR, Type.STEEL, Type.PSYCHIC, [ @@ -4186,12 +4186,12 @@ export function initBiomes() { ] ], [ Species.HIPPOPOTAS, Type.GROUND, -1, [ - [ Biome.DESERT, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.DESERT, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.HIPPOWDON, Type.GROUND, -1, [ - [ Biome.DESERT, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.DESERT, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.DESERT, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.DESERT, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.SKORUPI, Type.POISON, Type.BUG, [ @@ -4208,12 +4208,12 @@ export function initBiomes() { ] ], [ Species.CROAGUNK, Type.POISON, Type.FIGHTING, [ - [ Biome.SWAMP, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], + [ Biome.SWAMP, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], [ Biome.DOJO, BiomePoolTier.UNCOMMON ] ] ], [ Species.TOXICROAK, Type.POISON, Type.FIGHTING, [ - [ Biome.SWAMP, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], + [ Biome.SWAMP, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], [ Biome.DOJO, BiomePoolTier.UNCOMMON ], [ Biome.DOJO, BiomePoolTier.BOSS ] ] @@ -4265,7 +4265,7 @@ export function initBiomes() { ] ], [ Species.TANGROWTH, Type.GRASS, -1, [ - [ Biome.JUNGLE, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.JUNGLE, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.ELECTIVIRE, Type.ELECTRIC, -1, [ @@ -4436,18 +4436,18 @@ export function initBiomes() { ] ], [ Species.PATRAT, Type.NORMAL, -1, [ - [ Biome.TOWN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.METROPOLIS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.METROPOLIS, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.SLUM, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.TOWN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.METROPOLIS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.METROPOLIS, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.SLUM, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.WATCHOG, Type.NORMAL, -1, [ - [ Biome.METROPOLIS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.METROPOLIS, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.SLUM, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.SLUM, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.METROPOLIS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.METROPOLIS, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.SLUM, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.SLUM, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.LILLIPUP, Type.NORMAL, -1, [ @@ -4465,15 +4465,15 @@ export function initBiomes() { ] ], [ Species.PURRLOIN, Type.DARK, -1, [ - [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], + [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], [ Biome.ABYSS, BiomePoolTier.COMMON ], - [ Biome.JUNGLE, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.JUNGLE, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.LIEPARD, Type.DARK, -1, [ [ Biome.ABYSS, BiomePoolTier.COMMON ], [ Biome.ABYSS, BiomePoolTier.BOSS ], - [ Biome.JUNGLE, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.JUNGLE, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.PANSAGE, Type.GRASS, -1, [ @@ -4519,20 +4519,20 @@ export function initBiomes() { ] ], [ Species.PIDOVE, Type.NORMAL, Type.FLYING, [ - [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.PLAINS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.PLAINS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.TRANQUILL, Type.NORMAL, Type.FLYING, [ - [ Biome.PLAINS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.PLAINS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.UNFEZANT, Type.NORMAL, Type.FLYING, [ - [ Biome.PLAINS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.MOUNTAIN, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.PLAINS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.MOUNTAIN, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.BLITZLE, Type.ELECTRIC, -1, [ @@ -4547,15 +4547,15 @@ export function initBiomes() { ] ], [ Species.ROGGENROLA, Type.ROCK, -1, [ - [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], + [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], [ Biome.BADLANDS, BiomePoolTier.UNCOMMON ], [ Biome.CAVE, BiomePoolTier.COMMON ] ] ], [ Species.BOLDORE, Type.ROCK, -1, [ - [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], + [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], [ Biome.BADLANDS, BiomePoolTier.UNCOMMON ], [ Biome.CAVE, BiomePoolTier.COMMON ] ] @@ -4627,52 +4627,52 @@ export function initBiomes() { ] ], [ Species.SEWADDLE, Type.BUG, Type.GRASS, [ - [ Biome.FOREST, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.JUNGLE, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.FOREST, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.JUNGLE, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.SWADLOON, Type.BUG, Type.GRASS, [ - [ Biome.FOREST, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.JUNGLE, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.FOREST, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.JUNGLE, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.LEAVANNY, Type.BUG, Type.GRASS, [ - [ Biome.FOREST, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.JUNGLE, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.JUNGLE, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.FOREST, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.JUNGLE, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.JUNGLE, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.VENIPEDE, Type.BUG, Type.POISON, [ - [ Biome.TOWN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.TOWN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.WHIRLIPEDE, Type.BUG, Type.POISON, [ - [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.SCOLIPEDE, Type.BUG, Type.POISON, [ - [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.FOREST, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.FOREST, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.COTTONEE, Type.GRASS, Type.FAIRY, [ - [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.GRASS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.MEADOW, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.GRASS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.MEADOW, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.WHIMSICOTT, Type.GRASS, Type.FAIRY, [ - [ Biome.GRASS, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.GRASS, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.PETILIL, Type.GRASS, -1, [ - [ Biome.GRASS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.GRASS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.LILLIGANT, Type.GRASS, -1, [ - [ Biome.FOREST, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.FOREST, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.BASCULIN, Type.WATER, -1, [ @@ -4680,19 +4680,19 @@ export function initBiomes() { ] ], [ Species.SANDILE, Type.GROUND, Type.DARK, [ - [ Biome.DESERT, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.DESERT, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.DESERT, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.DESERT, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.KROKOROK, Type.GROUND, Type.DARK, [ - [ Biome.DESERT, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.DESERT, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.DESERT, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.DESERT, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.KROOKODILE, Type.GROUND, Type.DARK, [ - [ Biome.DESERT, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.DESERT, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.DESERT, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.DESERT, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.DESERT, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.DESERT, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.DARUMAKA, Type.FIRE, -1, [ @@ -4786,12 +4786,12 @@ export function initBiomes() { ] ], [ Species.MINCCINO, Type.NORMAL, -1, [ - [ Biome.TOWN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.MEADOW, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.TOWN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.MEADOW, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.CINCCINO, Type.NORMAL, -1, [ - [ Biome.MEADOW, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.MEADOW, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.GOTHITA, Type.PSYCHIC, -1, [ @@ -4825,12 +4825,12 @@ export function initBiomes() { ] ], [ Species.DUCKLETT, Type.WATER, Type.FLYING, [ - [ Biome.LAKE, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.LAKE, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.SWANNA, Type.WATER, Type.FLYING, [ - [ Biome.LAKE, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.LAKE, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.LAKE, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.LAKE, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.VANILLITE, Type.ICE, -1, [ @@ -4847,12 +4847,12 @@ export function initBiomes() { ] ], [ Species.DEERLING, Type.NORMAL, Type.GRASS, [ - [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.SAWSBUCK, Type.NORMAL, Type.GRASS, [ - [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.FOREST, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.FOREST, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.EMOLGA, Type.ELECTRIC, Type.FLYING, [ @@ -4868,17 +4868,17 @@ export function initBiomes() { ] ], [ Species.FOONGUS, Type.GRASS, Type.POISON, [ - [ Biome.GRASS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.JUNGLE, BiomePoolTier.RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.JUNGLE, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.GRASS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.JUNGLE, BiomePoolTier.RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.JUNGLE, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.AMOONGUSS, Type.GRASS, Type.POISON, [ - [ Biome.GRASS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.JUNGLE, BiomePoolTier.RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.JUNGLE, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.JUNGLE, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.JUNGLE, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.GRASS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.JUNGLE, BiomePoolTier.RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.JUNGLE, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.JUNGLE, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.JUNGLE, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.FRILLISH, Type.WATER, Type.GHOST, [ @@ -5041,26 +5041,26 @@ export function initBiomes() { ] ], [ Species.BOUFFALANT, Type.NORMAL, -1, [ - [ Biome.MEADOW, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.MEADOW, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.MEADOW, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.MEADOW, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.RUFFLET, Type.NORMAL, Type.FLYING, [ - [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.BRAVIARY, Type.NORMAL, Type.FLYING, [ - [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.MOUNTAIN, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.MOUNTAIN, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.VULLABY, Type.DARK, Type.FLYING, [ - [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.MANDIBUZZ, Type.DARK, Type.FLYING, [ - [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.MOUNTAIN, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.MOUNTAIN, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.HEATMOR, Type.FIRE, -1, [ @@ -5074,17 +5074,17 @@ export function initBiomes() { ] ], [ Species.DEINO, Type.DARK, Type.DRAGON, [ - [ Biome.WASTELAND, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], + [ Biome.WASTELAND, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], [ Biome.ABYSS, BiomePoolTier.RARE ] ] ], [ Species.ZWEILOUS, Type.DARK, Type.DRAGON, [ - [ Biome.WASTELAND, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], + [ Biome.WASTELAND, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], [ Biome.ABYSS, BiomePoolTier.RARE ] ] ], [ Species.HYDREIGON, Type.DARK, Type.DRAGON, [ - [ Biome.WASTELAND, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], + [ Biome.WASTELAND, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], [ Biome.ABYSS, BiomePoolTier.RARE ], [ Biome.ABYSS, BiomePoolTier.BOSS ] ] @@ -5206,30 +5206,30 @@ export function initBiomes() { [ Species.FLETCHLING, Type.NORMAL, Type.FLYING, [ [ Biome.TOWN, BiomePoolTier.COMMON ], [ Biome.PLAINS, BiomePoolTier.UNCOMMON ], - [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.FLETCHINDER, Type.FIRE, Type.FLYING, [ [ Biome.PLAINS, BiomePoolTier.UNCOMMON ], - [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.TALONFLAME, Type.FIRE, Type.FLYING, [ [ Biome.PLAINS, BiomePoolTier.UNCOMMON ], - [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.MOUNTAIN, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.MOUNTAIN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.MOUNTAIN, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.SCATTERBUG, Type.BUG, -1, [ - [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.SPEWPA, Type.BUG, -1, [ - [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.VIVILLON, Type.BUG, Type.FLYING, [ - [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.LITLEO, Type.FIRE, Type.NORMAL, [ @@ -5264,14 +5264,14 @@ export function initBiomes() { ], [ Species.PANCHAM, Type.FIGHTING, -1, [ [ Biome.DOJO, BiomePoolTier.RARE ], - [ Biome.JUNGLE, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.JUNGLE, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.PANGORO, Type.FIGHTING, Type.DARK, [ [ Biome.DOJO, BiomePoolTier.RARE ], [ Biome.DOJO, BiomePoolTier.BOSS_RARE ], - [ Biome.JUNGLE, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.JUNGLE, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.JUNGLE, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.JUNGLE, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.FURFROU, Type.NORMAL, -1, [ @@ -5280,12 +5280,12 @@ export function initBiomes() { ] ], [ Species.ESPURR, Type.PSYCHIC, -1, [ - [ Biome.METROPOLIS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.METROPOLIS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.MEOWSTIC, Type.PSYCHIC, -1, [ - [ Biome.METROPOLIS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.METROPOLIS, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.METROPOLIS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.METROPOLIS, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.HONEDGE, Type.STEEL, Type.GHOST, [ @@ -5319,12 +5319,12 @@ export function initBiomes() { ] ], [ Species.INKAY, Type.DARK, Type.PSYCHIC, [ - [ Biome.SEA, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.SEA, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.MALAMAR, Type.DARK, Type.PSYCHIC, [ - [ Biome.SEA, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.SEA, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.SEA, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.SEA, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.BINACLE, Type.ROCK, Type.WATER, [ @@ -5355,11 +5355,11 @@ export function initBiomes() { ] ], [ Species.HELIOPTILE, Type.ELECTRIC, Type.NORMAL, [ - [ Biome.DESERT, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.DESERT, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.HELIOLISK, Type.ELECTRIC, Type.NORMAL, [ - [ Biome.DESERT, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.DESERT, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.TYRUNT, Type.ROCK, Type.DRAGON, [ @@ -5402,16 +5402,16 @@ export function initBiomes() { ] ], [ Species.GOOMY, Type.DRAGON, -1, [ - [ Biome.WASTELAND, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.WASTELAND, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.SLIGGOO, Type.DRAGON, -1, [ - [ Biome.WASTELAND, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.WASTELAND, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.GOODRA, Type.DRAGON, -1, [ - [ Biome.WASTELAND, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.WASTELAND, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.WASTELAND, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.WASTELAND, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.KLEFKI, Type.STEEL, Type.FAIRY, [ @@ -5533,13 +5533,13 @@ export function initBiomes() { ] ], [ Species.YUNGOOS, Type.NORMAL, -1, [ - [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.PLAINS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.PLAINS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.GUMSHOOS, Type.NORMAL, -1, [ - [ Biome.PLAINS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.PLAINS, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.PLAINS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.PLAINS, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.GRUBBIN, Type.BUG, -1, [ @@ -5622,12 +5622,12 @@ export function initBiomes() { ] ], [ Species.DEWPIDER, Type.WATER, Type.BUG, [ - [ Biome.LAKE, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.LAKE, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.ARAQUANID, Type.WATER, Type.BUG, [ - [ Biome.LAKE, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.LAKE, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.LAKE, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.LAKE, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.FOMANTIS, Type.GRASS, -1, [ @@ -5670,16 +5670,16 @@ export function initBiomes() { ] ], [ Species.BOUNSWEET, Type.GRASS, -1, [ - [ Biome.TALL_GRASS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.TALL_GRASS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.STEENEE, Type.GRASS, -1, [ - [ Biome.TALL_GRASS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.TALL_GRASS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.TSAREENA, Type.GRASS, -1, [ - [ Biome.TALL_GRASS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.TALL_GRASS, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.TALL_GRASS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.TALL_GRASS, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.COMFEY, Type.FAIRY, -1, [ @@ -5688,11 +5688,11 @@ export function initBiomes() { ] ], [ Species.ORANGURU, Type.NORMAL, Type.PSYCHIC, [ - [ Biome.JUNGLE, BiomePoolTier.RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.JUNGLE, BiomePoolTier.RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.PASSIMIAN, Type.FIGHTING, -1, [ - [ Biome.JUNGLE, BiomePoolTier.RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.JUNGLE, BiomePoolTier.RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.WIMPOD, Type.BUG, Type.WATER, [ @@ -5732,8 +5732,8 @@ export function initBiomes() { ] ], [ Species.KOMALA, Type.NORMAL, -1, [ - [ Biome.JUNGLE, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.JUNGLE, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.JUNGLE, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.JUNGLE, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.TURTONATOR, Type.FIRE, Type.DRAGON, [ @@ -5767,16 +5767,16 @@ export function initBiomes() { ] ], [ Species.JANGMO_O, Type.DRAGON, -1, [ - [ Biome.WASTELAND, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.WASTELAND, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.HAKAMO_O, Type.DRAGON, Type.FIGHTING, [ - [ Biome.WASTELAND, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.WASTELAND, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.KOMMO_O, Type.DRAGON, Type.FIGHTING, [ - [ Biome.WASTELAND, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.WASTELAND, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.WASTELAND, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.WASTELAND, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.TAPU_KOKO, Type.ELECTRIC, Type.FAIRY, [ @@ -5931,43 +5931,43 @@ export function initBiomes() { ] ], [ Species.SKWOVET, Type.NORMAL, -1, [ - [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.PLAINS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.PLAINS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.GREEDENT, Type.NORMAL, -1, [ - [ Biome.PLAINS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.PLAINS, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.PLAINS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.PLAINS, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.ROOKIDEE, Type.FLYING, -1, [ [ Biome.TOWN, BiomePoolTier.RARE ], [ Biome.PLAINS, BiomePoolTier.RARE ], - [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.CORVISQUIRE, Type.FLYING, -1, [ [ Biome.PLAINS, BiomePoolTier.RARE ], - [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.CORVIKNIGHT, Type.FLYING, Type.STEEL, [ [ Biome.PLAINS, BiomePoolTier.RARE ], - [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.MOUNTAIN, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.MOUNTAIN, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.BLIPBUG, Type.BUG, -1, [ - [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.TOWN, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.DOTTLER, Type.BUG, Type.PSYCHIC, [ - [ Biome.FOREST, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.FOREST, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.ORBEETLE, Type.BUG, Type.PSYCHIC, [ - [ Biome.FOREST, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.FOREST, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.FOREST, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.FOREST, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.NICKIT, Type.DARK, -1, [ @@ -6007,12 +6007,12 @@ export function initBiomes() { ] ], [ Species.YAMPER, Type.ELECTRIC, -1, [ - [ Biome.METROPOLIS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.METROPOLIS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.BOLTUND, Type.ELECTRIC, -1, [ - [ Biome.METROPOLIS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.METROPOLIS, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.METROPOLIS, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.METROPOLIS, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.ROLYCOLY, Type.ROCK, -1, [ @@ -6050,8 +6050,8 @@ export function initBiomes() { ] ], [ Species.CRAMORANT, Type.FLYING, Type.WATER, [ - [ Biome.SEA, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.SEA, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.SEA, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.SEA, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.ARROKUDA, Type.WATER, -1, [ @@ -6066,17 +6066,17 @@ export function initBiomes() { [ Species.TOXEL, Type.ELECTRIC, Type.POISON, [ ] ], [ Species.TOXTRICITY, Type.ELECTRIC, Type.POISON, [ - [ Biome.SLUM, BiomePoolTier.RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.SLUM, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.SLUM, BiomePoolTier.RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.SLUM, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.SIZZLIPEDE, Type.FIRE, Type.BUG, [ - [ Biome.BADLANDS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.BADLANDS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.CENTISKORCH, Type.FIRE, Type.BUG, [ - [ Biome.BADLANDS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.BADLANDS, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.BADLANDS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.BADLANDS, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.CLOBBOPUS, Type.FIGHTING, -1, [ @@ -6124,8 +6124,8 @@ export function initBiomes() { ] ], [ Species.OBSTAGOON, Type.DARK, Type.NORMAL, [ - [ Biome.SLUM, BiomePoolTier.RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.SLUM, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.SLUM, BiomePoolTier.RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.SLUM, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.PERRSERKER, Type.STEEL, -1, [ @@ -6148,8 +6148,8 @@ export function initBiomes() { ] ], [ Species.RUNERIGUS, Type.GROUND, Type.GHOST, [ - [ Biome.RUINS, BiomePoolTier.SUPER_RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.RUINS, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.RUINS, BiomePoolTier.SUPER_RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.RUINS, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.MILCERY, Type.FAIRY, -1, [ @@ -6172,13 +6172,13 @@ export function initBiomes() { ], [ Species.SNOM, Type.ICE, Type.BUG, [ [ Biome.ICE_CAVE, BiomePoolTier.COMMON ], - [ Biome.SNOWY_FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.SNOWY_FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.FROSMOTH, Type.ICE, Type.BUG, [ [ Biome.ICE_CAVE, BiomePoolTier.COMMON ], - [ Biome.SNOWY_FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.SNOWY_FOREST, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.SNOWY_FOREST, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.SNOWY_FOREST, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.STONJOURNER, Type.ROCK, -1, [ @@ -6191,11 +6191,11 @@ export function initBiomes() { ] ], [ Species.INDEEDEE, Type.PSYCHIC, Type.NORMAL, [ - [ Biome.METROPOLIS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.METROPOLIS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.MORPEKO, Type.ELECTRIC, Type.DARK, [ - [ Biome.METROPOLIS, BiomePoolTier.RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.METROPOLIS, BiomePoolTier.RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.CUFANT, Type.STEEL, -1, [ @@ -6232,16 +6232,16 @@ export function initBiomes() { ] ], [ Species.DREEPY, Type.DRAGON, Type.GHOST, [ - [ Biome.WASTELAND, BiomePoolTier.RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.WASTELAND, BiomePoolTier.RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.DRAKLOAK, Type.DRAGON, Type.GHOST, [ - [ Biome.WASTELAND, BiomePoolTier.RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.WASTELAND, BiomePoolTier.RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.DRAGAPULT, Type.DRAGON, Type.GHOST, [ - [ Biome.WASTELAND, BiomePoolTier.RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.WASTELAND, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.WASTELAND, BiomePoolTier.RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.WASTELAND, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.ZACIAN, Type.FAIRY, -1, [ @@ -6294,7 +6294,7 @@ export function initBiomes() { ] ], [ Species.WYRDEER, Type.NORMAL, Type.PSYCHIC, [ - [ Biome.SNOWY_FOREST, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.SNOWY_FOREST, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.KLEAVOR, Type.BUG, Type.ROCK, [ @@ -6311,7 +6311,7 @@ export function initBiomes() { ] ], [ Species.SNEASLER, Type.FIGHTING, Type.POISON, [ - [ Biome.SNOWY_FOREST, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.SNOWY_FOREST, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.OVERQWIL, Type.DARK, Type.POISON, [ @@ -6394,31 +6394,31 @@ export function initBiomes() { ] ], [ Species.PAWMI, Type.ELECTRIC, -1, [ - [ Biome.TOWN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.PLAINS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], + [ Biome.TOWN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.PLAINS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], [ Biome.POWER_PLANT, BiomePoolTier.COMMON ] ] ], [ Species.PAWMO, Type.ELECTRIC, Type.FIGHTING, [ - [ Biome.PLAINS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], + [ Biome.PLAINS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], [ Biome.POWER_PLANT, BiomePoolTier.COMMON ] ] ], [ Species.PAWMOT, Type.ELECTRIC, Type.FIGHTING, [ - [ Biome.PLAINS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.PLAINS, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], + [ Biome.PLAINS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.PLAINS, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], [ Biome.POWER_PLANT, BiomePoolTier.COMMON ], [ Biome.POWER_PLANT, BiomePoolTier.BOSS ] ] ], [ Species.TANDEMAUS, Type.NORMAL, -1, [ - [ Biome.TOWN, BiomePoolTier.RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.METROPOLIS, BiomePoolTier.RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.TOWN, BiomePoolTier.RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.METROPOLIS, BiomePoolTier.RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.MAUSHOLD, Type.NORMAL, -1, [ - [ Biome.METROPOLIS, BiomePoolTier.RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.METROPOLIS, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.METROPOLIS, BiomePoolTier.RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.METROPOLIS, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.FIDOUGH, Type.FAIRY, -1, [ @@ -6432,16 +6432,16 @@ export function initBiomes() { ] ], [ Species.SMOLIV, Type.GRASS, Type.NORMAL, [ - [ Biome.MEADOW, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.MEADOW, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.DOLLIV, Type.GRASS, Type.NORMAL, [ - [ Biome.MEADOW, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.MEADOW, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.ARBOLIVA, Type.GRASS, Type.NORMAL, [ - [ Biome.MEADOW, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.MEADOW, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.MEADOW, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.MEADOW, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.SQUAWKABILLY, Type.NORMAL, Type.FLYING, [ @@ -6539,30 +6539,30 @@ export function initBiomes() { ] ], [ Species.CAPSAKID, Type.GRASS, -1, [ - [ Biome.BADLANDS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.BADLANDS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.SCOVILLAIN, Type.GRASS, Type.FIRE, [ - [ Biome.BADLANDS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.BADLANDS, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.BADLANDS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.BADLANDS, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.RELLOR, Type.BUG, -1, [ - [ Biome.DESERT, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.DESERT, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.RABSCA, Type.BUG, Type.PSYCHIC, [ - [ Biome.DESERT, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.DESERT, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.DESERT, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.DESERT, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.FLITTLE, Type.PSYCHIC, -1, [ - [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.ESPATHRA, Type.PSYCHIC, -1, [ - [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.MOUNTAIN, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.MOUNTAIN, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.TINKATINK, Type.FAIRY, Type.STEEL, [ @@ -6587,16 +6587,16 @@ export function initBiomes() { ] ], [ Species.BOMBIRDIER, Type.FLYING, Type.DARK, [ - [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.MOUNTAIN, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.FINIZEN, Type.WATER, -1, [ - [ Biome.SEA, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.SEA, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.PALAFIN, Type.WATER, -1, [ - [ Biome.SEA, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.SEA, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.SEA, BiomePoolTier.COMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.SEA, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.VAROOM, Type.STEEL, Type.POISON, [ @@ -6664,14 +6664,14 @@ export function initBiomes() { ] ], [ Species.ANNIHILAPE, Type.FIGHTING, Type.GHOST, [ - [ Biome.PLAINS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], + [ Biome.PLAINS, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], [ Biome.DOJO, BiomePoolTier.COMMON ], [ Biome.DOJO, BiomePoolTier.BOSS ] ] ], [ Species.CLODSIRE, Type.POISON, Type.GROUND, [ - [ Biome.SWAMP, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.SWAMP, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.SWAMP, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.SWAMP, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.FARIGIRAF, Type.NORMAL, Type.PSYCHIC, [ @@ -6867,17 +6867,17 @@ export function initBiomes() { [ Species.PECHARUNT, Type.POISON, Type.GHOST, [ ] ], [ Species.ALOLA_RATTATA, Type.DARK, Type.NORMAL, [ - [ Biome.ISLAND, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.ISLAND, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.ALOLA_RATICATE, Type.DARK, Type.NORMAL, [ - [ Biome.ISLAND, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.ISLAND, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.ISLAND, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.ISLAND, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.ALOLA_RAICHU, Type.ELECTRIC, Type.PSYCHIC, [ - [ Biome.ISLAND, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.ISLAND, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.ISLAND, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.ISLAND, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.ALOLA_SANDSHREW, Type.ICE, Type.STEEL, [ @@ -6914,12 +6914,12 @@ export function initBiomes() { ] ], [ Species.ALOLA_MEOWTH, Type.DARK, -1, [ - [ Biome.ISLAND, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.ISLAND, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.ALOLA_PERSIAN, Type.DARK, -1, [ - [ Biome.ISLAND, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.ISLAND, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.ISLAND, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.ISLAND, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.ALOLA_GEODUDE, Type.ROCK, Type.ELECTRIC, [ @@ -6945,13 +6945,13 @@ export function initBiomes() { ] ], [ Species.ALOLA_EXEGGUTOR, Type.GRASS, Type.DRAGON, [ - [ Biome.ISLAND, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.ISLAND, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.ISLAND, BiomePoolTier.UNCOMMON, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.ISLAND, BiomePoolTier.BOSS, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.ALOLA_MAROWAK, Type.FIRE, Type.GHOST, [ - [ Biome.ISLAND, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.ISLAND, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.ISLAND, BiomePoolTier.UNCOMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.ISLAND, BiomePoolTier.BOSS, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.ETERNAL_FLOETTE, Type.FAIRY, -1, [ @@ -6973,12 +6973,12 @@ export function initBiomes() { ] ], [ Species.GALAR_SLOWPOKE, Type.PSYCHIC, -1, [ - [ Biome.SWAMP, BiomePoolTier.SUPER_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.SWAMP, BiomePoolTier.SUPER_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.GALAR_SLOWBRO, Type.POISON, Type.PSYCHIC, [ - [ Biome.SWAMP, BiomePoolTier.SUPER_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.SWAMP, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.SWAMP, BiomePoolTier.SUPER_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.SWAMP, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.GALAR_FARFETCHD, Type.FIGHTING, -1, [ @@ -7009,7 +7009,7 @@ export function initBiomes() { ] ], [ Species.GALAR_SLOWKING, Type.POISON, Type.PSYCHIC, [ - [ Biome.SWAMP, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.SWAMP, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.GALAR_CORSOLA, Type.GHOST, -1, [ @@ -7017,24 +7017,24 @@ export function initBiomes() { ] ], [ Species.GALAR_ZIGZAGOON, Type.DARK, Type.NORMAL, [ - [ Biome.SLUM, BiomePoolTier.RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.SLUM, BiomePoolTier.RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.GALAR_LINOONE, Type.DARK, Type.NORMAL, [ - [ Biome.SLUM, BiomePoolTier.RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.SLUM, BiomePoolTier.RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.GALAR_DARUMAKA, Type.ICE, -1, [ - [ Biome.SNOWY_FOREST, BiomePoolTier.RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.SNOWY_FOREST, BiomePoolTier.RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.GALAR_DARMANITAN, Type.ICE, -1, [ - [ Biome.SNOWY_FOREST, BiomePoolTier.RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.SNOWY_FOREST, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.SNOWY_FOREST, BiomePoolTier.RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.SNOWY_FOREST, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.GALAR_YAMASK, Type.GROUND, Type.GHOST, [ - [ Biome.RUINS, BiomePoolTier.SUPER_RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.RUINS, BiomePoolTier.SUPER_RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.GALAR_STUNFISK, Type.GROUND, Type.STEEL, [ @@ -7067,7 +7067,7 @@ export function initBiomes() { ] ], [ Species.HISUI_SNEASEL, Type.FIGHTING, Type.POISON, [ - [ Biome.SNOWY_FOREST, BiomePoolTier.SUPER_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.SNOWY_FOREST, BiomePoolTier.SUPER_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.HISUI_SAMUROTT, Type.WATER, Type.DARK, [ @@ -7075,29 +7075,29 @@ export function initBiomes() { ] ], [ Species.HISUI_LILLIGANT, Type.GRASS, Type.FIGHTING, [ - [ Biome.MEADOW, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.MEADOW, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.HISUI_ZORUA, Type.NORMAL, Type.GHOST, [ - [ Biome.SNOWY_FOREST, BiomePoolTier.SUPER_RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.SNOWY_FOREST, BiomePoolTier.SUPER_RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.HISUI_ZOROARK, Type.NORMAL, Type.GHOST, [ - [ Biome.SNOWY_FOREST, BiomePoolTier.SUPER_RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ], - [ Biome.SNOWY_FOREST, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.SNOWY_FOREST, BiomePoolTier.SUPER_RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]], + [ Biome.SNOWY_FOREST, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.HISUI_BRAVIARY, Type.PSYCHIC, Type.FLYING, [ - [ Biome.MOUNTAIN, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.MOUNTAIN, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.HISUI_SLIGGOO, Type.STEEL, Type.DRAGON, [ - [ Biome.SWAMP, BiomePoolTier.SUPER_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.SWAMP, BiomePoolTier.SUPER_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.HISUI_GOODRA, Type.STEEL, Type.DRAGON, [ - [ Biome.SWAMP, BiomePoolTier.SUPER_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.SWAMP, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.SWAMP, BiomePoolTier.SUPER_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.SWAMP, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.HISUI_AVALUGG, Type.ICE, Type.ROCK, [ @@ -7109,12 +7109,12 @@ export function initBiomes() { ] ], [ Species.PALDEA_TAUROS, Type.FIGHTING, -1, [ - [ Biome.PLAINS, BiomePoolTier.RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ], - [ Biome.PLAINS, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ] ] + [ Biome.PLAINS, BiomePoolTier.RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ]], + [ Biome.PLAINS, BiomePoolTier.BOSS_RARE, [ TimeOfDay.DAWN, TimeOfDay.DAY ]] ] ], [ Species.PALDEA_WOOPER, Type.POISON, Type.GROUND, [ - [ Biome.SWAMP, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ] ] + [ Biome.SWAMP, BiomePoolTier.COMMON, [ TimeOfDay.DUSK, TimeOfDay.NIGHT ]] ] ], [ Species.BLOODMOON_URSALUNA, Type.GROUND, Type.NORMAL, [ @@ -7146,7 +7146,7 @@ export function initBiomes() { [ Biome.METROPOLIS, BiomePoolTier.RARE ] ] ], - [ TrainerType.BACKERS, [] ], + [ TrainerType.BACKERS, []], [ TrainerType.BACKPACKER, [ [ Biome.MOUNTAIN, BiomePoolTier.COMMON ], [ Biome.CAVE, BiomePoolTier.COMMON ], @@ -7160,7 +7160,7 @@ export function initBiomes() { ], [ TrainerType.BEAUTY, [ [ Biome.FAIRY_CAVE, BiomePoolTier.COMMON ] - ] ], + ]], [ TrainerType.BIKER, [ [ Biome.SLUM, BiomePoolTier.COMMON ] ] @@ -7190,42 +7190,42 @@ export function initBiomes() { ], [ TrainerType.CLERK, [ [ Biome.METROPOLIS, BiomePoolTier.COMMON ] - ] ], + ]], [ TrainerType.CYCLIST, [ [ Biome.PLAINS, BiomePoolTier.UNCOMMON ], [ Biome.METROPOLIS, BiomePoolTier.COMMON ] ] ], - [ TrainerType.DANCER, [] ], + [ TrainerType.DANCER, []], [ TrainerType.DEPOT_AGENT, [ [ Biome.METROPOLIS, BiomePoolTier.UNCOMMON ] - ] ], - [ TrainerType.DOCTOR, [] ], + ]], + [ TrainerType.DOCTOR, []], [ TrainerType.FISHERMAN, [ [ Biome.LAKE, BiomePoolTier.COMMON ], [ Biome.BEACH, BiomePoolTier.COMMON ] ] ], - [ TrainerType.RICH, [] ], + [ TrainerType.RICH, []], [ TrainerType.GUITARIST, [ [ Biome.METROPOLIS, BiomePoolTier.UNCOMMON ], [ Biome.POWER_PLANT, BiomePoolTier.COMMON ] - ] ], - [ TrainerType.HARLEQUIN, [] ], + ]], + [ TrainerType.HARLEQUIN, []], [ TrainerType.HIKER, [ [ Biome.MOUNTAIN, BiomePoolTier.COMMON ], [ Biome.CAVE, BiomePoolTier.COMMON ], [ Biome.BADLANDS, BiomePoolTier.COMMON ] ] ], - [ TrainerType.HOOLIGANS, [] ], - [ TrainerType.HOOPSTER, [] ], - [ TrainerType.INFIELDER, [] ], - [ TrainerType.JANITOR, [] ], - [ TrainerType.LINEBACKER, [] ], - [ TrainerType.MAID, [] ], - [ TrainerType.MUSICIAN, [] ], - [ TrainerType.NURSERY_AIDE, [] ], + [ TrainerType.HOOLIGANS, []], + [ TrainerType.HOOPSTER, []], + [ TrainerType.INFIELDER, []], + [ TrainerType.JANITOR, []], + [ TrainerType.LINEBACKER, []], + [ TrainerType.MAID, []], + [ TrainerType.MUSICIAN, []], + [ TrainerType.NURSERY_AIDE, []], [ TrainerType.OFFICER, [ [ Biome.METROPOLIS, BiomePoolTier.COMMON ], [ Biome.CONSTRUCTION_SITE, BiomePoolTier.COMMON ], @@ -7237,9 +7237,9 @@ export function initBiomes() { [ Biome.MEADOW, BiomePoolTier.COMMON ] ] ], - [ TrainerType.PILOT, [] ], - [ TrainerType.POKEFAN, [] ], - [ TrainerType.PRESCHOOLER, [] ], + [ TrainerType.PILOT, []], + [ TrainerType.POKEFAN, []], + [ TrainerType.PRESCHOOLER, []], [ TrainerType.PSYCHIC, [ [ Biome.GRAVEYARD, BiomePoolTier.COMMON ], [ Biome.RUINS, BiomePoolTier.COMMON ] @@ -7251,7 +7251,7 @@ export function initBiomes() { [ Biome.JUNGLE, BiomePoolTier.COMMON ] ] ], - [ TrainerType.RICH_KID, [] ], + [ TrainerType.RICH_KID, []], [ TrainerType.ROUGHNECK, [ [ Biome.SLUM, BiomePoolTier.COMMON ] ] @@ -7261,13 +7261,13 @@ export function initBiomes() { [ Biome.RUINS, BiomePoolTier.COMMON ] ] ], - [ TrainerType.SMASHER, [] ], + [ TrainerType.SMASHER, []], [ TrainerType.SNOW_WORKER, [ [ Biome.ICE_CAVE, BiomePoolTier.COMMON ], [ Biome.SNOWY_FOREST, BiomePoolTier.COMMON ] ] ], - [ TrainerType.STRIKER, [] ], + [ TrainerType.STRIKER, []], [ TrainerType.SCHOOL_KID, [ [ Biome.GRASS, BiomePoolTier.COMMON ] ] @@ -7607,57 +7607,57 @@ export function initBiomes() { [ Biome.ICE_CAVE, BiomePoolTier.BOSS ] ] ], - [ TrainerType.LORELEI, [] ], - [ TrainerType.BRUNO, [] ], - [ TrainerType.AGATHA, [] ], - [ TrainerType.LANCE, [] ], - [ TrainerType.WILL, [] ], - [ TrainerType.KOGA, [] ], - [ TrainerType.KAREN, [] ], - [ TrainerType.SIDNEY, [] ], - [ TrainerType.PHOEBE, [] ], - [ TrainerType.GLACIA, [] ], - [ TrainerType.DRAKE, [] ], - [ TrainerType.AARON, [] ], - [ TrainerType.BERTHA, [] ], - [ TrainerType.FLINT, [] ], - [ TrainerType.LUCIAN, [] ], - [ TrainerType.SHAUNTAL, [] ], - [ TrainerType.MARSHAL, [] ], - [ TrainerType.GRIMSLEY, [] ], - [ TrainerType.CAITLIN, [] ], - [ TrainerType.MALVA, [] ], - [ TrainerType.SIEBOLD, [] ], - [ TrainerType.WIKSTROM, [] ], - [ TrainerType.DRASNA, [] ], - [ TrainerType.HALA, [] ], - [ TrainerType.MOLAYNE, [] ], - [ TrainerType.OLIVIA, [] ], - [ TrainerType.ACEROLA, [] ], - [ TrainerType.KAHILI, [] ], - [ TrainerType.RIKA, [] ], - [ TrainerType.POPPY, [] ], - [ TrainerType.LARRY_ELITE, [] ], - [ TrainerType.HASSEL, [] ], - [ TrainerType.CRISPIN, [] ], - [ TrainerType.AMARYS, [] ], - [ TrainerType.LACEY, [] ], - [ TrainerType.DRAYTON, [] ], - [ TrainerType.BLUE, [] ], - [ TrainerType.RED, [] ], - [ TrainerType.LANCE_CHAMPION, [] ], - [ TrainerType.STEVEN, [] ], - [ TrainerType.WALLACE, [] ], - [ TrainerType.CYNTHIA, [] ], - [ TrainerType.ALDER, [] ], - [ TrainerType.IRIS, [] ], - [ TrainerType.DIANTHA, [] ], - [ TrainerType.HAU, [] ], - [ TrainerType.GEETA, [] ], - [ TrainerType.NEMONA, [] ], - [ TrainerType.KIERAN, [] ], - [ TrainerType.LEON, [] ], - [ TrainerType.RIVAL, [] ] + [ TrainerType.LORELEI, []], + [ TrainerType.BRUNO, []], + [ TrainerType.AGATHA, []], + [ TrainerType.LANCE, []], + [ TrainerType.WILL, []], + [ TrainerType.KOGA, []], + [ TrainerType.KAREN, []], + [ TrainerType.SIDNEY, []], + [ TrainerType.PHOEBE, []], + [ TrainerType.GLACIA, []], + [ TrainerType.DRAKE, []], + [ TrainerType.AARON, []], + [ TrainerType.BERTHA, []], + [ TrainerType.FLINT, []], + [ TrainerType.LUCIAN, []], + [ TrainerType.SHAUNTAL, []], + [ TrainerType.MARSHAL, []], + [ TrainerType.GRIMSLEY, []], + [ TrainerType.CAITLIN, []], + [ TrainerType.MALVA, []], + [ TrainerType.SIEBOLD, []], + [ TrainerType.WIKSTROM, []], + [ TrainerType.DRASNA, []], + [ TrainerType.HALA, []], + [ TrainerType.MOLAYNE, []], + [ TrainerType.OLIVIA, []], + [ TrainerType.ACEROLA, []], + [ TrainerType.KAHILI, []], + [ TrainerType.RIKA, []], + [ TrainerType.POPPY, []], + [ TrainerType.LARRY_ELITE, []], + [ TrainerType.HASSEL, []], + [ TrainerType.CRISPIN, []], + [ TrainerType.AMARYS, []], + [ TrainerType.LACEY, []], + [ TrainerType.DRAYTON, []], + [ TrainerType.BLUE, []], + [ TrainerType.RED, []], + [ TrainerType.LANCE_CHAMPION, []], + [ TrainerType.STEVEN, []], + [ TrainerType.WALLACE, []], + [ TrainerType.CYNTHIA, []], + [ TrainerType.ALDER, []], + [ TrainerType.IRIS, []], + [ TrainerType.DIANTHA, []], + [ TrainerType.HAU, []], + [ TrainerType.GEETA, []], + [ TrainerType.NEMONA, []], + [ TrainerType.KIERAN, []], + [ TrainerType.LEON, []], + [ TrainerType.RIVAL, []] ]; biomeDepths[Biome.TOWN] = [ 0, 1 ]; @@ -7666,7 +7666,7 @@ export function initBiomes() { if (biome === Biome.END) { const biomeList = Object.keys(Biome).filter(key => !isNaN(Number(key))); biomeList.pop(); // Removes Biome.END from the list - const randIndex = Utils.randInt(biomeList.length, 1); // Will never be Biome.TOWN + const randIndex = Utils.randSeedInt(biomeList.length, 1); // Will never be Biome.TOWN biome = Biome[biomeList[randIndex]]; } const linkedBiomes: (Biome | [ Biome, integer ])[] = Array.isArray(biomeLinks[biome]) diff --git a/src/data/egg-moves.ts b/src/data/balance/egg-moves.ts similarity index 85% rename from src/data/egg-moves.ts rename to src/data/balance/egg-moves.ts index b516238c46e..8df92e179d9 100644 --- a/src/data/egg-moves.ts +++ b/src/data/balance/egg-moves.ts @@ -1,16 +1,16 @@ -import { allMoves } from "./move"; -import * as Utils from "../utils"; +import { allMoves } from "#app/data/move"; +import * as Utils from "#app/utils"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; export const speciesEggMoves = { - [Species.BULBASAUR]: [ Moves.SAPPY_SEED, Moves.SLUDGE_WAVE, Moves.EARTH_POWER, Moves.MATCHA_GOTCHA ], + [Species.BULBASAUR]: [ Moves.SAPPY_SEED, Moves.MALIGNANT_CHAIN, Moves.EARTH_POWER, Moves.MATCHA_GOTCHA ], [Species.CHARMANDER]: [ Moves.DRAGON_DANCE, Moves.BITTER_BLADE, Moves.EARTH_POWER, Moves.OBLIVION_WING ], [Species.SQUIRTLE]: [ Moves.FREEZE_DRY, Moves.SHORE_UP, Moves.BOUNCY_BUBBLE, Moves.ORIGIN_PULSE ], [Species.CATERPIE]: [ Moves.SANDSEAR_STORM, Moves.SILK_TRAP, Moves.TWIN_BEAM, Moves.BLEAKWIND_STORM ], - [Species.WEEDLE]: [ Moves.THOUSAND_ARROWS, Moves.SWORDS_DANCE, Moves.ATTACK_ORDER, Moves.NOXIOUS_TORQUE ], - [Species.PIDGEY]: [ Moves.WILDBOLT_STORM, Moves.SANDSEAR_STORM, Moves.CALM_MIND, Moves.BOOMBURST ], + [Species.WEEDLE]: [ Moves.THOUSAND_ARROWS, Moves.NOXIOUS_TORQUE, Moves.ATTACK_ORDER, Moves.VICTORY_DANCE ], + [Species.PIDGEY]: [ Moves.WILDBOLT_STORM, Moves.SANDSEAR_STORM, Moves.NASTY_PLOT, Moves.BOOMBURST ], [Species.RATTATA]: [ Moves.HYPER_FANG, Moves.PSYCHIC_FANGS, Moves.FIRE_FANG, Moves.EXTREME_SPEED ], [Species.SPEAROW]: [ Moves.FLOATY_FALL, Moves.EXTREME_SPEED, Moves.TIDY_UP, Moves.TRIPLE_ARROWS ], [Species.EKANS]: [ Moves.NOXIOUS_TORQUE, Moves.DRAGON_DANCE, Moves.SLACK_OFF, Moves.SHED_TAIL ], @@ -21,46 +21,46 @@ export const speciesEggMoves = { [Species.ZUBAT]: [ Moves.FLOATY_FALL, Moves.DIRE_CLAW, Moves.SWORDS_DANCE, Moves.COLLISION_COURSE ], [Species.ODDISH]: [ Moves.SLUDGE_BOMB, Moves.FIERY_DANCE, Moves.STRENGTH_SAP, Moves.SPORE ], [Species.PARAS]: [ Moves.LEECH_LIFE, Moves.HORN_LEECH, Moves.CRABHAMMER, Moves.SAPPY_SEED ], - [Species.VENONAT]: [ Moves.SLUDGE_BOMB, Moves.MOONLIGHT, Moves.EARTH_POWER, Moves.MYSTICAL_POWER ], + [Species.VENONAT]: [ Moves.SLUDGE_BOMB, Moves.TOXIC_THREAD, Moves.EARTH_POWER, Moves.STORED_POWER ], [Species.DIGLETT]: [ Moves.TRIPLE_DIVE, Moves.SWORDS_DANCE, Moves.TRIPLE_AXEL, Moves.HEADLONG_RUSH ], - [Species.MEOWTH]: [ Moves.COVET, Moves.SWORDS_DANCE, Moves.DOUBLE_KICK, Moves.TAIL_SLAP ], - [Species.PSYDUCK]: [ Moves.SPLISHY_SPLASH, Moves.AQUA_STEP, Moves.AURA_SPHERE, Moves.MYSTICAL_POWER ], - [Species.MANKEY]: [ Moves.DRAIN_PUNCH, Moves.PLAY_ROUGH, Moves.METEOR_MASH, Moves.NO_RETREAT ], + [Species.MEOWTH]: [ Moves.HEART_STAMP, Moves.SWORDS_DANCE, Moves.SIZZLY_SLIDE, Moves.TAIL_SLAP ], + [Species.PSYDUCK]: [ Moves.FROST_BREATH, Moves.AQUA_STEP, Moves.MYSTICAL_POWER, Moves.BOUNCY_BUBBLE ], + [Species.MANKEY]: [ Moves.DRAIN_PUNCH, Moves.SLACK_OFF, Moves.METEOR_MASH, Moves.NO_RETREAT ], [Species.GROWLITHE]: [ Moves.ZING_ZAP, Moves.PARTING_SHOT, Moves.MORNING_SUN, Moves.SACRED_FIRE ], [Species.POLIWAG]: [ Moves.SLACK_OFF, Moves.WILDBOLT_STORM, Moves.DRAIN_PUNCH, Moves.SURGING_STRIKES ], - [Species.ABRA]: [ Moves.AURA_SPHERE, Moves.BADDY_BAD, Moves.THUNDERBOLT, Moves.PSYSTRIKE ], + [Species.ABRA]: [ Moves.AURA_SPHERE, Moves.BADDY_BAD, Moves.ICE_BEAM, Moves.PSYSTRIKE ], [Species.MACHOP]: [ Moves.COMBAT_TORQUE, Moves.METEOR_MASH, Moves.MOUNTAIN_GALE, Moves.FISSURE ], [Species.BELLSPROUT]: [ Moves.SOLAR_BLADE, Moves.STRENGTH_SAP, Moves.FIRE_LASH, Moves.VICTORY_DANCE ], [Species.TENTACOOL]: [ Moves.BANEFUL_BUNKER, Moves.STRENGTH_SAP, Moves.BOUNCY_BUBBLE, Moves.MALIGNANT_CHAIN ], - [Species.GEODUDE]: [ Moves.BODY_PRESS, Moves.BULK_UP, Moves.SHORE_UP, Moves.HEAD_SMASH ], + [Species.GEODUDE]: [ Moves.FLARE_BLITZ, Moves.HEAD_SMASH, Moves.SHORE_UP, Moves.SHELL_SMASH ], [Species.PONYTA]: [ Moves.HIGH_HORSEPOWER, Moves.FIRE_LASH, Moves.SWORDS_DANCE, Moves.VOLT_TACKLE ], [Species.SLOWPOKE]: [ Moves.BOUNCY_BUBBLE, Moves.FLAMETHROWER, Moves.MYSTICAL_POWER, Moves.SHED_TAIL ], - [Species.MAGNEMITE]: [ Moves.PARABOLIC_CHARGE, Moves.BODY_PRESS, Moves.ICE_BEAM, Moves.THUNDERCLAP ], - [Species.FARFETCHD]: [ Moves.IVY_CUDGEL, Moves.TRIPLE_ARROWS, Moves.ROOST, Moves.VICTORY_DANCE ], + [Species.MAGNEMITE]: [ Moves.PARABOLIC_CHARGE, Moves.FLAMETHROWER, Moves.ICE_BEAM, Moves.THUNDERCLAP ], + [Species.FARFETCHD]: [ Moves.IVY_CUDGEL, Moves.TRIPLE_ARROWS, Moves.DRILL_RUN, Moves.VICTORY_DANCE ], [Species.DODUO]: [ Moves.TRIPLE_AXEL, Moves.MULTI_ATTACK, Moves.FLOATY_FALL, Moves.TRIPLE_ARROWS ], [Species.SEEL]: [ Moves.FREEZE_DRY, Moves.BOUNCY_BUBBLE, Moves.SLACK_OFF, Moves.STEAM_ERUPTION ], [Species.GRIMER]: [ Moves.SUCKER_PUNCH, Moves.CURSE, Moves.STRENGTH_SAP, Moves.NOXIOUS_TORQUE ], [Species.SHELLDER]: [ Moves.ROCK_BLAST, Moves.WATER_SHURIKEN, Moves.BANEFUL_BUNKER, Moves.BONE_RUSH ], [Species.GASTLY]: [ Moves.SLUDGE_BOMB, Moves.AURA_SPHERE, Moves.NASTY_PLOT, Moves.ASTRAL_BARRAGE ], - [Species.ONIX]: [ Moves.SHORE_UP, Moves.BODY_PRESS, Moves.HEAVY_SLAM, Moves.DIAMOND_STORM ], + [Species.ONIX]: [ Moves.SHORE_UP, Moves.THOUSAND_WAVES, Moves.COIL, Moves.DIAMOND_STORM ], [Species.DROWZEE]: [ Moves.BADDY_BAD, Moves.STRENGTH_SAP, Moves.LUMINA_CRASH, Moves.DARK_VOID ], - [Species.KRABBY]: [ Moves.FIRE_LASH, Moves.PLAY_ROUGH, Moves.IVY_CUDGEL, Moves.SHELL_SMASH ], - [Species.VOLTORB]: [ Moves.NASTY_PLOT, Moves.OVERHEAT, Moves.FROST_BREATH, Moves.ELECTRO_DRIFT ], + [Species.KRABBY]: [ Moves.DIRE_CLAW, Moves.JET_PUNCH, Moves.IVY_CUDGEL, Moves.SHELL_SMASH ], + [Species.VOLTORB]: [ Moves.NASTY_PLOT, Moves.FUSION_FLARE, Moves.FROST_BREATH, Moves.ELECTRO_DRIFT ], [Species.EXEGGCUTE]: [ Moves.FICKLE_BEAM, Moves.APPLE_ACID, Moves.TRICK_ROOM, Moves.LUMINA_CRASH ], [Species.CUBONE]: [ Moves.HEAD_SMASH, Moves.WOOD_HAMMER, Moves.SHADOW_SNEAK, Moves.BITTER_BLADE ], - [Species.LICKITUNG]: [ Moves.BODY_SLAM, Moves.FIRE_LASH, Moves.GRAV_APPLE, Moves.MILK_DRINK ], + [Species.LICKITUNG]: [ Moves.CRUSH_GRIP, Moves.FIRE_LASH, Moves.SLACK_OFF, Moves.MAGICAL_TORQUE ], [Species.KOFFING]: [ Moves.SCALD, Moves.RECOVER, Moves.BODY_PRESS, Moves.MALIGNANT_CHAIN ], [Species.RHYHORN]: [ Moves.SHORE_UP, Moves.ICE_HAMMER, Moves.ACCELEROCK, Moves.HEAD_SMASH ], [Species.TANGELA]: [ Moves.STRENGTH_SAP, Moves.SNAP_TRAP, Moves.PARTING_SHOT, Moves.SAPPY_SEED ], [Species.KANGASKHAN]: [ Moves.POWER_UP_PUNCH, Moves.TRAILBLAZE, Moves.FACADE, Moves.SEISMIC_TOSS ], [Species.HORSEA]: [ Moves.SNIPE_SHOT, Moves.FROST_BREATH, Moves.HURRICANE, Moves.SPACIAL_REND ], - [Species.GOLDEEN]: [ Moves.DRILL_RUN, Moves.FLIP_TURN, Moves.DRAGON_DANCE, Moves.FISHIOUS_REND ], + [Species.GOLDEEN]: [ Moves.GLACIAL_LANCE, Moves.SUPERCELL_SLAM, Moves.DRAGON_DANCE, Moves.FISHIOUS_REND ], [Species.STARYU]: [ Moves.CALM_MIND, Moves.BOUNCY_BUBBLE, Moves.MOONBLAST, Moves.MYSTICAL_POWER ], [Species.SCYTHER]: [ Moves.MIGHTY_CLEAVE, Moves.BUG_BITE, Moves.STORM_THROW, Moves.DOUBLE_IRON_BASH ], - [Species.PINSIR]: [ Moves.EARTHQUAKE, Moves.LEECH_LIFE, Moves.CLOSE_COMBAT, Moves.EXTREME_SPEED ], - [Species.TAUROS]: [ Moves.HIGH_HORSEPOWER, Moves.BLAZING_TORQUE, Moves.LIQUIDATION, Moves.COMBAT_TORQUE ], + [Species.PINSIR]: [ Moves.HEADLONG_RUSH, Moves.LEECH_LIFE, Moves.CRUSH_GRIP, Moves.EXTREME_SPEED ], + [Species.TAUROS]: [ Moves.HIGH_HORSEPOWER, Moves.FIRE_LASH, Moves.LIQUIDATION, Moves.COMBAT_TORQUE ], [Species.MAGIKARP]: [ Moves.FLIP_TURN, Moves.ICE_SPINNER, Moves.DRAGON_ASCENT, Moves.SURGING_STRIKES ], - [Species.LAPRAS]: [ Moves.RECOVER, Moves.FREEZE_DRY, Moves.SHELL_SMASH, Moves.STEAM_ERUPTION ], + [Species.LAPRAS]: [ Moves.RECOVER, Moves.FREEZE_DRY, Moves.SCALD, Moves.SHELL_SMASH ], [Species.DITTO]: [ Moves.MIMIC, Moves.SKETCH, Moves.METRONOME, Moves.IMPRISON ], [Species.EEVEE]: [ Moves.WISH, Moves.NO_RETREAT, Moves.ZIPPY_ZAP, Moves.BOOMBURST ], [Species.PORYGON]: [ Moves.THUNDERCLAP, Moves.AURA_SPHERE, Moves.FLAMETHROWER, Moves.TECHNO_BLAST ], @@ -68,56 +68,56 @@ export const speciesEggMoves = { [Species.KABUTO]: [ Moves.CEASELESS_EDGE, Moves.HIGH_HORSEPOWER, Moves.TRIPLE_DIVE, Moves.MIGHTY_CLEAVE ], [Species.AERODACTYL]: [ Moves.FLOATY_FALL, Moves.FLARE_BLITZ, Moves.SWORDS_DANCE, Moves.MIGHTY_CLEAVE ], [Species.ARTICUNO]: [ Moves.EARTH_POWER, Moves.CALM_MIND, Moves.AURORA_VEIL, Moves.AEROBLAST ], - [Species.ZAPDOS]: [ Moves.WEATHER_BALL, Moves.CALM_MIND, Moves.SANDSEAR_STORM, Moves.ELECTRO_SHOT ], + [Species.ZAPDOS]: [ Moves.BLEAKWIND_STORM, Moves.CALM_MIND, Moves.SANDSEAR_STORM, Moves.ELECTRO_SHOT ], [Species.MOLTRES]: [ Moves.SCORCHING_SANDS, Moves.CALM_MIND, Moves.AEROBLAST, Moves.TORCH_SONG ], [Species.DRATINI]: [ Moves.DRAGON_HAMMER, Moves.CRUSH_GRIP, Moves.FIRE_LASH, Moves.GIGATON_HAMMER ], [Species.MEWTWO]: [ Moves.METEOR_MASH, Moves.MOONBLAST, Moves.THUNDEROUS_KICK, Moves.PHOTON_GEYSER ], [Species.MEW]: [ Moves.PHOTON_GEYSER, Moves.MOONBLAST, Moves.ASTRAL_BARRAGE, Moves.SHELL_SMASH ], [Species.CHIKORITA]: [ Moves.SAPPY_SEED, Moves.STONE_AXE, Moves.DRAGON_DANCE, Moves.SPORE ], - [Species.CYNDAQUIL]: [ Moves.NASTY_PLOT, Moves.SCORCHING_SANDS, Moves.FIERY_DANCE, Moves.ELECTRO_DRIFT ], + [Species.CYNDAQUIL]: [ Moves.NASTY_PLOT, Moves.EARTH_POWER, Moves.FIERY_DANCE, Moves.ELECTRO_DRIFT ], [Species.TOTODILE]: [ Moves.THUNDER_PUNCH, Moves.DRAGON_DANCE, Moves.TRIPLE_AXEL, Moves.FISHIOUS_REND ], - [Species.SENTRET]: [ Moves.TIDY_UP, Moves.THIEF, Moves.NUZZLE, Moves.EXTREME_SPEED ], + [Species.SENTRET]: [ Moves.TIDY_UP, Moves.FAKE_OUT, Moves.NUZZLE, Moves.EXTREME_SPEED ], [Species.HOOTHOOT]: [ Moves.CALM_MIND, Moves.ESPER_WING, Moves.AEROBLAST, Moves.BOOMBURST ], [Species.LEDYBA]: [ Moves.POLLEN_PUFF, Moves.THIEF, Moves.PARTING_SHOT, Moves.SPORE ], [Species.SPINARAK]: [ Moves.PARTING_SHOT, Moves.ATTACK_ORDER, Moves.GASTRO_ACID, Moves.STRENGTH_SAP ], [Species.CHINCHOU]: [ Moves.THUNDERCLAP, Moves.BOUNCY_BUBBLE, Moves.THUNDER_CAGE, Moves.TAIL_GLOW ], - [Species.PICHU]: [ Moves.RISING_VOLTAGE, Moves.SPLISHY_SPLASH, Moves.FLOATY_FALL, Moves.THUNDERCLAP ], + [Species.PICHU]: [ Moves.MOONBLAST, Moves.TRIPLE_AXEL, Moves.FIERY_DANCE, Moves.AURA_WHEEL ], [Species.CLEFFA]: [ Moves.CALM_MIND, Moves.EARTH_POWER, Moves.WISH, Moves.LIGHT_OF_RUIN ], [Species.IGGLYBUFF]: [ Moves.DRAIN_PUNCH, Moves.GRAV_APPLE, Moves.SOFT_BOILED, Moves.EXTREME_SPEED ], [Species.TOGEPI]: [ Moves.SCORCHING_SANDS, Moves.ROOST, Moves.RELIC_SONG, Moves.FIERY_DANCE ], - [Species.NATU]: [ Moves.AEROBLAST, Moves.ROOST, Moves.CALM_MIND, Moves.LUMINA_CRASH ], + [Species.NATU]: [ Moves.AEROBLAST, Moves.ROOST, Moves.MOONBLAST, Moves.LUMINA_CRASH ], [Species.MAREEP]: [ Moves.ICE_BEAM, Moves.PARABOLIC_CHARGE, Moves.CORE_ENFORCER, Moves.TAIL_GLOW ], [Species.HOPPIP]: [ Moves.FLOATY_FALL, Moves.STRENGTH_SAP, Moves.SAPPY_SEED, Moves.SPORE ], [Species.AIPOM]: [ Moves.TIDY_UP, Moves.STORM_THROW, Moves.FAKE_OUT, Moves.POPULATION_BOMB ], - [Species.SUNKERN]: [ Moves.SPORE, Moves.SAPPY_SEED, Moves.FIERY_DANCE, Moves.HYDRO_STEAM ], + [Species.SUNKERN]: [ Moves.SPORE, Moves.QUIVER_DANCE, Moves.FIERY_DANCE, Moves.HYDRO_STEAM ], [Species.YANMA]: [ Moves.NASTY_PLOT, Moves.EARTH_POWER, Moves.HEAT_WAVE, Moves.BLEAKWIND_STORM ], [Species.WOOPER]: [ Moves.SIZZLY_SLIDE, Moves.RECOVER, Moves.CURSE, Moves.SURGING_STRIKES ], [Species.MURKROW]: [ Moves.TRIPLE_ARROWS, Moves.FLOATY_FALL, Moves.TIDY_UP, Moves.WICKED_BLOW ], [Species.MISDREAVUS]: [ Moves.TAKE_HEART, Moves.MOONBLAST, Moves.AURA_SPHERE, Moves.ASTRAL_BARRAGE ], [Species.UNOWN]: [ Moves.NATURE_POWER, Moves.COSMIC_POWER, Moves.ANCIENT_POWER, Moves.MYSTICAL_POWER ], [Species.GIRAFARIG]: [ Moves.MYSTICAL_POWER, Moves.NIGHT_DAZE, Moves.RECOVER, Moves.BOOMBURST ], - [Species.PINECO]: [ Moves.METAL_BURST, Moves.LUNGE, Moves.BODY_PRESS, Moves.SHORE_UP ], - [Species.DUNSPARCE]: [ Moves.BODY_SLAM, Moves.MAGICAL_TORQUE, Moves.BLAZING_TORQUE, Moves.EXTREME_SPEED ], + [Species.PINECO]: [ Moves.METAL_BURST, Moves.SHORE_UP, Moves.BODY_PRESS, Moves.DIAMOND_STORM ], + [Species.DUNSPARCE]: [ Moves.WICKED_TORQUE, Moves.MAGICAL_TORQUE, Moves.BLAZING_TORQUE, Moves.EXTREME_SPEED ], [Species.GLIGAR]: [ Moves.FLOATY_FALL, Moves.THOUSAND_WAVES, Moves.ROOST, Moves.MIGHTY_CLEAVE ], [Species.SNUBBULL]: [ Moves.FACADE, Moves.EARTHQUAKE, Moves.SWORDS_DANCE, Moves.EXTREME_SPEED ], [Species.QWILFISH]: [ Moves.BARB_BARRAGE, Moves.BANEFUL_BUNKER, Moves.KNOCK_OFF, Moves.FISHIOUS_REND ], [Species.SHUCKLE]: [ Moves.STUFF_CHEEKS, Moves.HEAL_ORDER, Moves.BODY_PRESS, Moves.SALT_CURE ], [Species.HERACROSS]: [ Moves.ROCK_BLAST, Moves.FIRST_IMPRESSION, Moves.ICICLE_SPEAR, Moves.DRAGON_DANCE ], [Species.SNEASEL]: [ Moves.DIRE_CLAW, Moves.STORM_THROW, Moves.TRIPLE_AXEL, Moves.WICKED_BLOW ], - [Species.TEDDIURSA]: [ Moves.MOUNTAIN_GALE, Moves.RAGING_BULL, Moves.SLACK_OFF, Moves.PRECIPICE_BLADES ], + [Species.TEDDIURSA]: [ Moves.MOUNTAIN_GALE, Moves.FAKE_OUT, Moves.SLACK_OFF, Moves.PRECIPICE_BLADES ], [Species.SLUGMA]: [ Moves.BURNING_BULWARK, Moves.POWER_GEM, Moves.SOLAR_BEAM, Moves.MAGMA_STORM ], [Species.SWINUB]: [ Moves.SLACK_OFF, Moves.LANDS_WRATH, Moves.MIGHTY_CLEAVE, Moves.GLACIAL_LANCE ], [Species.CORSOLA]: [ Moves.SCALD, Moves.FREEZE_DRY, Moves.STRENGTH_SAP, Moves.SALT_CURE ], [Species.REMORAID]: [ Moves.WATER_SHURIKEN, Moves.TAKE_HEART, Moves.SHELL_SIDE_ARM, Moves.BOUNCY_BUBBLE ], - [Species.DELIBIRD]: [ Moves.DRILL_RUN, Moves.FLOATY_FALL, Moves.VICTORY_DANCE, Moves.GLACIAL_LANCE ], + [Species.DELIBIRD]: [ Moves.BONEMERANG, Moves.FLOATY_FALL, Moves.VICTORY_DANCE, Moves.GLACIAL_LANCE ], [Species.SKARMORY]: [ Moves.ROOST, Moves.BODY_PRESS, Moves.SPIKY_SHIELD, Moves.BEAK_BLAST ], - [Species.HOUNDOUR]: [ Moves.HEAT_WAVE, Moves.FIERY_WRATH, Moves.SOLAR_BEAM, Moves.HYDRO_STEAM ], + [Species.HOUNDOUR]: [ Moves.MOONLIGHT, Moves.FIERY_WRATH, Moves.SECRET_SWORD, Moves.HYDRO_STEAM ], [Species.PHANPY]: [ Moves.SHORE_UP, Moves.SWORDS_DANCE, Moves.ICICLE_CRASH, Moves.COLLISION_COURSE ], - [Species.STANTLER]: [ Moves.THUNDEROUS_KICK, Moves.HYPER_VOICE, Moves.BULK_UP, Moves.PHOTON_GEYSER ], + [Species.STANTLER]: [ Moves.THUNDEROUS_KICK, Moves.PHOTON_GEYSER, Moves.SWORDS_DANCE, Moves.BOOMBURST ], [Species.SMEARGLE]: [ Moves.CONVERSION, Moves.BURNING_BULWARK, Moves.SALT_CURE, Moves.DARK_VOID ], [Species.TYROGUE]: [ Moves.VICTORY_DANCE, Moves.THUNDEROUS_KICK, Moves.METEOR_MASH, Moves.WICKED_BLOW ], [Species.SMOOCHUM]: [ Moves.EXPANDING_FORCE, Moves.AURA_SPHERE, Moves.FREEZE_DRY, Moves.QUIVER_DANCE ], - [Species.ELEKID]: [ Moves.BLAZING_TORQUE, Moves.TIDY_UP, Moves.MOUNTAIN_GALE, Moves.ZIPPY_ZAP ], + [Species.ELEKID]: [ Moves.FIRE_LASH, Moves.ZING_ZAP, Moves.MOUNTAIN_GALE, Moves.SHIFT_GEAR ], [Species.MAGBY]: [ Moves.THUNDERCLAP, Moves.EARTH_POWER, Moves.ARMOR_CANNON, Moves.FLEUR_CANNON ], [Species.MILTANK]: [ Moves.BODY_PRESS, Moves.BULK_UP, Moves.YAWN, Moves.SIZZLY_SLIDE ], [Species.RAIKOU]: [ Moves.PARABOLIC_CHARGE, Moves.NASTY_PLOT, Moves.FROST_BREATH, Moves.ELECTRO_DRIFT ], @@ -125,10 +125,10 @@ export const speciesEggMoves = { [Species.SUICUNE]: [ Moves.RECOVER, Moves.NASTY_PLOT, Moves.FREEZE_DRY, Moves.STEAM_ERUPTION ], [Species.LARVITAR]: [ Moves.DRAGON_DANCE, Moves.MOUNTAIN_GALE, Moves.SHORE_UP, Moves.DIAMOND_STORM ], [Species.LUGIA]: [ Moves.NASTY_PLOT, Moves.LUMINA_CRASH, Moves.AURA_SPHERE, Moves.OBLIVION_WING ], - [Species.HO_OH]: [ Moves.FLOATY_FALL, Moves.PRECIPICE_BLADES, Moves.REVIVAL_BLESSING, Moves.BOLT_BEAK ], + [Species.HO_OH]: [ Moves.BRAVE_BIRD, Moves.DRAGON_DANCE, Moves.REVIVAL_BLESSING, Moves.BOLT_BEAK ], [Species.CELEBI]: [ Moves.PHOTON_GEYSER, Moves.MATCHA_GOTCHA, Moves.REVIVAL_BLESSING, Moves.QUIVER_DANCE ], [Species.TREECKO]: [ Moves.NASTY_PLOT, Moves.APPLE_ACID, Moves.SECRET_SWORD, Moves.DRAGON_ENERGY ], - [Species.TORCHIC]: [ Moves.HIGH_JUMP_KICK, Moves.SUPERCELL_SLAM, Moves.KNOCK_OFF, Moves.V_CREATE ], + [Species.TORCHIC]: [ Moves.HIGH_JUMP_KICK, Moves.SUPERCELL_SLAM, Moves.BURNING_BULWARK, Moves.V_CREATE ], [Species.MUDKIP]: [ Moves.SHORE_UP, Moves.MOUNTAIN_GALE, Moves.BULK_UP, Moves.SURGING_STRIKES ], [Species.POOCHYENA]: [ Moves.JAW_LOCK, Moves.CLOSE_COMBAT, Moves.DIRE_CLAW, Moves.NO_RETREAT ], [Species.ZIGZAGOON]: [ Moves.EXTREME_SPEED, Moves.NUZZLE, Moves.HIGH_HORSEPOWER, Moves.TIDY_UP ], @@ -154,7 +154,7 @@ export const speciesEggMoves = { [Species.ELECTRIKE]: [ Moves.RISING_VOLTAGE, Moves.FLAMETHROWER, Moves.NASTY_PLOT, Moves.ICE_BEAM ], [Species.PLUSLE]: [ Moves.FLAMETHROWER, Moves.GLITZY_GLOW, Moves.SPLISHY_SPLASH, Moves.TAIL_GLOW ], [Species.MINUN]: [ Moves.ICE_BEAM, Moves.BADDY_BAD, Moves.SPARKLY_SWIRL, Moves.TAIL_GLOW ], - [Species.VOLBEAT]: [ Moves.BATON_PASS, Moves.LUNGE, Moves.DECORATE, Moves.VICTORY_DANCE ], + [Species.VOLBEAT]: [ Moves.BATON_PASS, Moves.STICKY_WEB, Moves.DECORATE, Moves.VICTORY_DANCE ], [Species.ILLUMISE]: [ Moves.PARTING_SHOT, Moves.GLITZY_GLOW, Moves.POWDER, Moves.QUIVER_DANCE ], [Species.GULPIN]: [ Moves.STRENGTH_SAP, Moves.EARTH_POWER, Moves.CALM_MIND, Moves.MALIGNANT_CHAIN ], [Species.CARVANHA]: [ Moves.THUNDER_FANG, Moves.SWORDS_DANCE, Moves.OBSTRUCT, Moves.SURGING_STRIKES ], @@ -168,7 +168,7 @@ export const speciesEggMoves = { [Species.SWABLU]: [ Moves.ROOST, Moves.NASTY_PLOT, Moves.FLOATY_FALL, Moves.BOOMBURST ], [Species.ZANGOOSE]: [ Moves.FACADE, Moves.HIGH_HORSEPOWER, Moves.EXTREME_SPEED, Moves.TIDY_UP ], [Species.SEVIPER]: [ Moves.ICE_BEAM, Moves.BITTER_BLADE, Moves.SUCKER_PUNCH, Moves.NO_RETREAT ], - [Species.LUNATONE]: [ Moves.POWER_GEM, Moves.NIGHT_DAZE, Moves.SHELL_SMASH, Moves.LUMINA_CRASH ], + [Species.LUNATONE]: [ Moves.POWER_GEM, Moves.MOONGEIST_BEAM, Moves.SHELL_SMASH, Moves.LUMINA_CRASH ], [Species.SOLROCK]: [ Moves.PSYSHIELD_BASH, Moves.MIGHTY_CLEAVE, Moves.SHELL_SMASH, Moves.SACRED_FIRE ], [Species.BARBOACH]: [ Moves.DRAGON_DANCE, Moves.ZING_ZAP, Moves.ICE_SPINNER, Moves.SURGING_STRIKES ], [Species.CORPHISH]: [ Moves.CEASELESS_EDGE, Moves.JET_PUNCH, Moves.SUCKER_PUNCH, Moves.SHELL_SMASH ], @@ -177,7 +177,7 @@ export const speciesEggMoves = { [Species.ANORITH]: [ Moves.FIRST_IMPRESSION, Moves.LEECH_LIFE, Moves.DRAGON_DANCE, Moves.MIGHTY_CLEAVE ], [Species.FEEBAS]: [ Moves.CALM_MIND, Moves.FREEZE_DRY, Moves.MOONBLAST, Moves.STEAM_ERUPTION ], [Species.CASTFORM]: [ Moves.BOOMBURST, Moves.HYDRO_STEAM, Moves.ERUPTION, Moves.QUIVER_DANCE ], - [Species.KECLEON]: [ Moves.DRAIN_PUNCH, Moves.DRAGON_DANCE, Moves.EXTREME_SPEED, Moves.MULTI_ATTACK ], + [Species.KECLEON]: [ Moves.ZIPPY_ZAP, Moves.COIL, Moves.EXTREME_SPEED, Moves.MULTI_ATTACK ], [Species.SHUPPET]: [ Moves.STORM_THROW, Moves.TIDY_UP, Moves.PARTING_SHOT, Moves.SPECTRAL_THIEF ], [Species.DUSKULL]: [ Moves.BULK_UP, Moves.DRAIN_PUNCH, Moves.STRENGTH_SAP, Moves.RAGE_FIST ], [Species.TROPIUS]: [ Moves.STUFF_CHEEKS, Moves.EARTH_POWER, Moves.APPLE_ACID, Moves.SAPPY_SEED ], @@ -189,13 +189,13 @@ export const speciesEggMoves = { [Species.RELICANTH]: [ Moves.DRAGON_DANCE, Moves.SHORE_UP, Moves.WAVE_CRASH, Moves.DIAMOND_STORM ], [Species.LUVDISC]: [ Moves.BATON_PASS, Moves.HEART_SWAP, Moves.GLITZY_GLOW, Moves.REVIVAL_BLESSING ], [Species.BAGON]: [ Moves.FLOATY_FALL, Moves.FIRE_LASH, Moves.DRAGON_DANCE, Moves.GLAIVE_RUSH ], - [Species.BELDUM]: [ Moves.HIGH_HORSEPOWER, Moves.RECOVER, Moves.TRIPLE_AXEL, Moves.SHIFT_GEAR ], + [Species.BELDUM]: [ Moves.HEADLONG_RUSH, Moves.DRAIN_PUNCH, Moves.TRIPLE_AXEL, Moves.SHIFT_GEAR ], [Species.REGIROCK]: [ Moves.STONE_AXE, Moves.BODY_PRESS, Moves.SHORE_UP, Moves.SALT_CURE ], [Species.REGICE]: [ Moves.EARTH_POWER, Moves.TAKE_HEART, Moves.RECOVER, Moves.FREEZE_DRY ], [Species.REGISTEEL]: [ Moves.BODY_PRESS, Moves.SIZZLY_SLIDE, Moves.RECOVER, Moves.GIGATON_HAMMER ], [Species.LATIAS]: [ Moves.CORE_ENFORCER, Moves.FUSION_FLARE, Moves.SPARKLY_SWIRL, Moves.MYSTICAL_POWER ], [Species.LATIOS]: [ Moves.CORE_ENFORCER, Moves.BLUE_FLARE, Moves.NASTY_PLOT, Moves.TACHYON_CUTTER ], - [Species.KYOGRE]: [ Moves.BOUNCY_BUBBLE, Moves.HURRICANE, Moves.FREEZE_DRY, Moves.ELECTRO_SHOT ], + [Species.KYOGRE]: [ Moves.RECOVER, Moves.HURRICANE, Moves.FREEZY_FROST, Moves.WILDBOLT_STORM ], [Species.GROUDON]: [ Moves.STONE_AXE, Moves.SOLAR_BLADE, Moves.MORNING_SUN, Moves.SACRED_FIRE ], [Species.RAYQUAZA]: [ Moves.V_CREATE, Moves.DRAGON_DARTS, Moves.CORE_ENFORCER, Moves.OBLIVION_WING ], [Species.JIRACHI]: [ Moves.TACHYON_CUTTER, Moves.TRIPLE_ARROWS, Moves.ROCK_SLIDE, Moves.SHELL_SMASH ], @@ -206,7 +206,7 @@ export const speciesEggMoves = { [Species.STARLY]: [ Moves.SWORDS_DANCE, Moves.HEAD_CHARGE, Moves.FLARE_BLITZ, Moves.EXTREME_SPEED ], [Species.BIDOOF]: [ Moves.EXTREME_SPEED, Moves.COSMIC_POWER, Moves.POWER_TRIP, Moves.AQUA_STEP ], [Species.KRICKETOT]: [ Moves.BONEMERANG, Moves.VICTORY_DANCE, Moves.STONE_AXE, Moves.POPULATION_BOMB ], - [Species.SHINX]: [ Moves.FIRE_LASH, Moves.TRIPLE_AXEL, Moves.FACADE, Moves.BOLT_STRIKE ], + [Species.SHINX]: [ Moves.FIRE_LASH, Moves.TRIPLE_AXEL, Moves.ZIPPY_ZAP, Moves.BOLT_STRIKE ], [Species.BUDEW]: [ Moves.FIERY_DANCE, Moves.ACID_SPRAY, Moves.BOUNCY_BUBBLE, Moves.QUIVER_DANCE ], [Species.CRANIDOS]: [ Moves.VOLT_TACKLE, Moves.ACCELEROCK, Moves.FLARE_BLITZ, Moves.SHIFT_GEAR ], [Species.SHIELDON]: [ Moves.SHORE_UP, Moves.BODY_PRESS, Moves.KINGS_SHIELD, Moves.DIAMOND_STORM ], @@ -223,7 +223,7 @@ export const speciesEggMoves = { [Species.STUNKY]: [ Moves.CEASELESS_EDGE, Moves.KNOCK_OFF, Moves.RECOVER, Moves.DIRE_CLAW ], [Species.BRONZOR]: [ Moves.RECOVER, Moves.TACHYON_CUTTER, Moves.GLARE, Moves.LUMINA_CRASH ], [Species.BONSLY]: [ Moves.ACCELEROCK, Moves.SWORDS_DANCE, Moves.STRENGTH_SAP, Moves.SAPPY_SEED ], - [Species.MIME_JR]: [ Moves.CALM_MIND, Moves.MOONBLAST, Moves.SIZZLY_SLIDE, Moves.LUMINA_CRASH ], + [Species.MIME_JR]: [ Moves.CHILLY_RECEPTION, Moves.MOONBLAST, Moves.FROST_BREATH, Moves.LUMINA_CRASH ], [Species.HAPPINY]: [ Moves.COTTON_GUARD, Moves.SEISMIC_TOSS, Moves.SIZZLY_SLIDE, Moves.REVIVAL_BLESSING ], [Species.CHATOT]: [ Moves.SPARKLING_ARIA, Moves.TORCH_SONG, Moves.BATON_PASS, Moves.BOOMBURST ], [Species.SPIRITOMB]: [ Moves.PARTING_SHOT, Moves.BADDY_BAD, Moves.STRENGTH_SAP, Moves.SPECTRAL_THIEF ], @@ -232,7 +232,7 @@ export const speciesEggMoves = { [Species.RIOLU]: [ Moves.THUNDEROUS_KICK, Moves.TACHYON_CUTTER, Moves.TRIPLE_AXEL, Moves.DOUBLE_IRON_BASH ], [Species.HIPPOPOTAS]: [ Moves.SHORE_UP, Moves.STONE_AXE, Moves.BULK_UP, Moves.SALT_CURE ], [Species.SKORUPI]: [ Moves.COIL, Moves.DIRE_CLAW, Moves.CRABHAMMER, Moves.WICKED_BLOW ], - [Species.CROAGUNK]: [ Moves.DIRE_CLAW, Moves.ICE_PUNCH, Moves.THUNDEROUS_KICK, Moves.VICTORY_DANCE ], + [Species.CROAGUNK]: [ Moves.DIRE_CLAW, Moves.ICE_SPINNER, Moves.THUNDEROUS_KICK, Moves.VICTORY_DANCE ], [Species.CARNIVINE]: [ Moves.STRENGTH_SAP, Moves.FIRE_LASH, Moves.COIL, Moves.SAPPY_SEED ], [Species.FINNEON]: [ Moves.QUIVER_DANCE, Moves.BOUNCY_BUBBLE, Moves.FREEZE_DRY, Moves.ORIGIN_PULSE ], [Species.MANTYKE]: [ Moves.SPLISHY_SPLASH, Moves.FREEZY_FROST, Moves.NASTY_PLOT, Moves.OBLIVION_WING ], @@ -243,7 +243,7 @@ export const speciesEggMoves = { [Species.AZELF]: [ Moves.PSYSTRIKE, Moves.ICE_BEAM, Moves.MOONBLAST, Moves.TAIL_GLOW ], [Species.DIALGA]: [ Moves.CORE_ENFORCER, Moves.TAKE_HEART, Moves.RECOVER, Moves.MAKE_IT_RAIN ], [Species.PALKIA]: [ Moves.RECOVER, Moves.TAKE_HEART, Moves.FREEZE_DRY, Moves.ORIGIN_PULSE ], - [Species.HEATRAN]: [ Moves.TORCH_SONG, Moves.RECOVER, Moves.TACHYON_CUTTER, Moves.MATCHA_GOTCHA ], + [Species.HEATRAN]: [ Moves.MATCHA_GOTCHA, Moves.RECOVER, Moves.TACHYON_CUTTER, Moves.TORCH_SONG ], [Species.REGIGIGAS]: [ Moves.SKILL_SWAP, Moves.RECOVER, Moves.EXTREME_SPEED, Moves.GIGATON_HAMMER ], [Species.GIRATINA]: [ Moves.DRAGON_DANCE, Moves.GLAIVE_RUSH, Moves.RECOVER, Moves.SPECTRAL_THIEF ], [Species.CRESSELIA]: [ Moves.COSMIC_POWER, Moves.SECRET_SWORD, Moves.SIZZLY_SLIDE, Moves.LUMINA_CRASH ], @@ -264,7 +264,7 @@ export const speciesEggMoves = { [Species.PANPOUR]: [ Moves.NASTY_PLOT, Moves.ENERGY_BALL, Moves.EARTH_POWER, Moves.STEAM_ERUPTION ], [Species.MUNNA]: [ Moves.COSMIC_POWER, Moves.AURA_SPHERE, Moves.EARTH_POWER, Moves.MYSTICAL_POWER ], [Species.PIDOVE]: [ Moves.GUNK_SHOT, Moves.TIDY_UP, Moves.FLOATY_FALL, Moves.TRIPLE_ARROWS ], - [Species.BLITZLE]: [ Moves.HIGH_HORSEPOWER, Moves.THUNDEROUS_KICK, Moves.FLARE_BLITZ, Moves.VOLT_TACKLE ], + [Species.BLITZLE]: [ Moves.HORN_LEECH, Moves.SWORDS_DANCE, Moves.FLARE_BLITZ, Moves.BOLT_STRIKE ], [Species.ROGGENROLA]: [ Moves.BODY_PRESS, Moves.CURSE, Moves.SHORE_UP, Moves.DIAMOND_STORM ], [Species.WOOBAT]: [ Moves.ESPER_WING, Moves.STORED_POWER, Moves.MYSTICAL_FIRE, Moves.OBLIVION_WING ], [Species.DRILBUR]: [ Moves.IRON_HEAD, Moves.MOUNTAIN_GALE, Moves.SHIFT_GEAR, Moves.THOUSAND_ARROWS ], @@ -274,18 +274,18 @@ export const speciesEggMoves = { [Species.THROH]: [ Moves.MACH_PUNCH, Moves.SLACK_OFF, Moves.METEOR_MASH, Moves.RAGE_FIST ], [Species.SAWK]: [ Moves.DRAIN_PUNCH, Moves.SUCKER_PUNCH, Moves.METEOR_MASH, Moves.VICTORY_DANCE ], [Species.SEWADDLE]: [ Moves.STONE_AXE, Moves.PSYCHO_CUT, Moves.BITTER_BLADE, Moves.VICTORY_DANCE ], - [Species.VENIPEDE]: [ Moves.SWORDS_DANCE, Moves.LEECH_LIFE, Moves.NOXIOUS_TORQUE, Moves.POWER_TRIP ], + [Species.VENIPEDE]: [ Moves.BANEFUL_BUNKER, Moves.LEECH_LIFE, Moves.NOXIOUS_TORQUE, Moves.POWER_TRIP ], [Species.COTTONEE]: [ Moves.POLLEN_PUFF, Moves.PARTING_SHOT, Moves.SLEEP_POWDER, Moves.SEED_FLARE ], [Species.PETILIL]: [ Moves.THUNDEROUS_KICK, Moves.SPARKLING_ARIA, Moves.FIERY_DANCE, Moves.FLOWER_TRICK ], [Species.BASCULIN]: [ Moves.LAST_RESPECTS, Moves.CLOSE_COMBAT, Moves.SPLISHY_SPLASH, Moves.NO_RETREAT ], [Species.SANDILE]: [ Moves.DIRE_CLAW, Moves.HIGH_HORSEPOWER, Moves.FIRE_LASH, Moves.WICKED_BLOW ], [Species.DARUMAKA]: [ Moves.DRAIN_PUNCH, Moves.ZIPPY_ZAP, Moves.EARTHQUAKE, Moves.PYRO_BALL ], - [Species.MARACTUS]: [ Moves.SCORCHING_SANDS, Moves.QUIVER_DANCE, Moves.FIERY_DANCE, Moves.SEED_FLARE ], + [Species.MARACTUS]: [ Moves.EARTH_POWER, Moves.QUIVER_DANCE, Moves.FIERY_DANCE, Moves.SEED_FLARE ], [Species.DWEBBLE]: [ Moves.CRABHAMMER, Moves.STONE_AXE, Moves.LEECH_LIFE, Moves.MIGHTY_CLEAVE ], - [Species.SCRAGGY]: [ Moves.SUCKER_PUNCH, Moves.BULLET_PUNCH, Moves.DRAGON_DANCE, Moves.COLLISION_COURSE ], + [Species.SCRAGGY]: [ Moves.SUCKER_PUNCH, Moves.BULLET_PUNCH, Moves.NOXIOUS_TORQUE, Moves.VICTORY_DANCE ], [Species.SIGILYPH]: [ Moves.MOONBLAST, Moves.CALM_MIND, Moves.FREEZING_GLARE, Moves.OBLIVION_WING ], - [Species.YAMASK]: [ Moves.STRENGTH_SAP, Moves.INFERNAL_PARADE, Moves.AURA_SPHERE, Moves.ASTRAL_BARRAGE ], - [Species.TIRTOUGA]: [ Moves.ICE_SPINNER, Moves.LIQUIDATION, Moves.SHORE_UP, Moves.MIGHTY_CLEAVE ], + [Species.YAMASK]: [ Moves.STRENGTH_SAP, Moves.GLARE, Moves.AURA_SPHERE, Moves.ASTRAL_BARRAGE ], + [Species.TIRTOUGA]: [ Moves.ICE_SPINNER, Moves.AQUA_STEP, Moves.SHORE_UP, Moves.MIGHTY_CLEAVE ], [Species.ARCHEN]: [ Moves.ROOST, Moves.EARTHQUAKE, Moves.FLOATY_FALL, Moves.MIGHTY_CLEAVE ], [Species.TRUBBISH]: [ Moves.COIL, Moves.RECOVER, Moves.DIRE_CLAW, Moves.GIGATON_HAMMER ], [Species.ZORUA]: [ Moves.FLAMETHROWER, Moves.MOONBLAST, Moves.AURA_SPHERE, Moves.FIERY_WRATH ], @@ -295,19 +295,19 @@ export const speciesEggMoves = { [Species.DUCKLETT]: [ Moves.SPLISHY_SPLASH, Moves.EARTH_POWER, Moves.WILDBOLT_STORM, Moves.QUIVER_DANCE ], [Species.VANILLITE]: [ Moves.EARTH_POWER, Moves.AURORA_VEIL, Moves.CALM_MIND, Moves.SPARKLY_SWIRL ], [Species.DEERLING]: [ Moves.TIDY_UP, Moves.FLOWER_TRICK, Moves.BODY_SLAM, Moves.COMBAT_TORQUE ], - [Species.EMOLGA]: [ Moves.TRIPLE_AXEL, Moves.SPLISHY_SPLASH, Moves.TAILWIND, Moves.ZIPPY_ZAP ], - [Species.KARRABLAST]: [ Moves.LEECH_LIFE, Moves.HEAL_ORDER, Moves.HIGH_HORSEPOWER, Moves.DOUBLE_IRON_BASH ], + [Species.EMOLGA]: [ Moves.TRIPLE_AXEL, Moves.SPLISHY_SPLASH, Moves.FLOATY_FALL, Moves.AURA_WHEEL ], + [Species.KARRABLAST]: [ Moves.LEECH_LIFE, Moves.BITTER_BLADE, Moves.HIGH_HORSEPOWER, Moves.DOUBLE_IRON_BASH ], [Species.FOONGUS]: [ Moves.POLLEN_PUFF, Moves.PARTING_SHOT, Moves.FOUL_PLAY, Moves.SAPPY_SEED ], - [Species.FRILLISH]: [ Moves.STRENGTH_SAP, Moves.INFERNAL_PARADE, Moves.FREEZE_DRY, Moves.STEAM_ERUPTION ], - [Species.ALOMOMOLA]: [ Moves.FLIP_TURN, Moves.HEART_SWAP, Moves.TOXIC, Moves.GLITZY_GLOW ], - [Species.JOLTIK]: [ Moves.THUNDER, Moves.PARABOLIC_CHARGE, Moves.EARTH_POWER, Moves.QUIVER_DANCE ], + [Species.FRILLISH]: [ Moves.STRENGTH_SAP, Moves.BUZZY_BUZZ, Moves.FREEZE_DRY, Moves.STEAM_ERUPTION ], + [Species.ALOMOMOLA]: [ Moves.FLIP_TURN, Moves.HEART_SWAP, Moves.GLITZY_GLOW, Moves.REVIVAL_BLESSING ], + [Species.JOLTIK]: [ Moves.WILDBOLT_STORM, Moves.PARABOLIC_CHARGE, Moves.EARTH_POWER, Moves.QUIVER_DANCE ], [Species.FERROSEED]: [ Moves.STRENGTH_SAP, Moves.BODY_PRESS, Moves.SPIKY_SHIELD, Moves.SAPPY_SEED ], [Species.KLINK]: [ Moves.TRIPLE_AXEL, Moves.HIGH_HORSEPOWER, Moves.FUSION_BOLT, Moves.DOUBLE_IRON_BASH ], - [Species.TYNAMO]: [ Moves.SCALD, Moves.STRENGTH_SAP, Moves.FIRE_LASH, Moves.PLASMA_FISTS ], - [Species.ELGYEM]: [ Moves.LUSTER_PURGE, Moves.TRICK_ROOM, Moves.AURA_SPHERE, Moves.TAIL_GLOW ], + [Species.TYNAMO]: [ Moves.SCALD, Moves.STRENGTH_SAP, Moves.FIRE_LASH, Moves.AURA_WHEEL ], + [Species.ELGYEM]: [ Moves.LUSTER_PURGE, Moves.BADDY_BAD, Moves.AURA_SPHERE, Moves.TAIL_GLOW ], [Species.LITWICK]: [ Moves.FIERY_DANCE, Moves.EARTH_POWER, Moves.MOONBLAST, Moves.ASTRAL_BARRAGE ], [Species.AXEW]: [ Moves.STONE_AXE, Moves.DIRE_CLAW, Moves.BITTER_BLADE, Moves.GLAIVE_RUSH ], - [Species.CUBCHOO]: [ Moves.TRIPLE_AXEL, Moves.LIQUIDATION, Moves.SWORDS_DANCE, Moves.COLLISION_COURSE ], + [Species.CUBCHOO]: [ Moves.MOUNTAIN_GALE, Moves.AQUA_STEP, Moves.ICE_SHARD, Moves.COLLISION_COURSE ], [Species.CRYOGONAL]: [ Moves.FREEZING_GLARE, Moves.AURORA_VEIL, Moves.NASTY_PLOT, Moves.ORIGIN_PULSE ], [Species.SHELMET]: [ Moves.POWER_GEM, Moves.NASTY_PLOT, Moves.EARTH_POWER, Moves.STEAM_ERUPTION ], [Species.STUNFISK]: [ Moves.BANEFUL_BUNKER, Moves.SANDSEAR_STORM, Moves.STRENGTH_SAP, Moves.THUNDERCLAP ], @@ -315,24 +315,24 @@ export const speciesEggMoves = { [Species.DRUDDIGON]: [ Moves.FIRE_LASH, Moves.ROOST, Moves.DRAGON_DARTS, Moves.CLANGOROUS_SOUL ], [Species.GOLETT]: [ Moves.SHIFT_GEAR, Moves.DRAIN_PUNCH, Moves.HEADLONG_RUSH, Moves.RAGE_FIST ], [Species.PAWNIARD]: [ Moves.SUCKER_PUNCH, Moves.CEASELESS_EDGE, Moves.BITTER_BLADE, Moves.LAST_RESPECTS ], - [Species.BOUFFALANT]: [ Moves.SLACK_OFF, Moves.JUMP_KICK, Moves.HEAD_SMASH, Moves.FLARE_BLITZ ], + [Species.BOUFFALANT]: [ Moves.SLACK_OFF, Moves.HIGH_JUMP_KICK, Moves.HEAD_SMASH, Moves.FLARE_BLITZ ], [Species.RUFFLET]: [ Moves.FLOATY_FALL, Moves.AURA_SPHERE, Moves.NO_RETREAT, Moves.BOLT_BEAK ], [Species.VULLABY]: [ Moves.FOUL_PLAY, Moves.BODY_PRESS, Moves.ROOST, Moves.RUINATION ], [Species.HEATMOR]: [ Moves.EARTH_POWER, Moves.OVERHEAT, Moves.THUNDERBOLT, Moves.V_CREATE ], [Species.DURANT]: [ Moves.HIGH_HORSEPOWER, Moves.FIRST_IMPRESSION, Moves.SWORDS_DANCE, Moves.BEHEMOTH_BASH ], [Species.DEINO]: [ Moves.FIERY_WRATH, Moves.ESPER_WING, Moves.SLUDGE_BOMB, Moves.FICKLE_BEAM ], [Species.LARVESTA]: [ Moves.THUNDERBOLT, Moves.MATCHA_GOTCHA, Moves.EARTH_POWER, Moves.TORCH_SONG ], - [Species.COBALION]: [ Moves.BEHEMOTH_BLADE, Moves.BODY_PRESS, Moves.CEASELESS_EDGE, Moves.VICTORY_DANCE ], + [Species.COBALION]: [ Moves.BEHEMOTH_BLADE, Moves.MIGHTY_CLEAVE, Moves.CEASELESS_EDGE, Moves.VICTORY_DANCE ], [Species.TERRAKION]: [ Moves.MIGHTY_CLEAVE, Moves.HEADLONG_RUSH, Moves.CEASELESS_EDGE, Moves.VICTORY_DANCE ], [Species.VIRIZION]: [ Moves.PSYBLADE, Moves.SAPPY_SEED, Moves.CEASELESS_EDGE, Moves.VICTORY_DANCE ], [Species.TORNADUS]: [ Moves.EARTH_POWER, Moves.PARTING_SHOT, Moves.ICE_BEAM, Moves.OBLIVION_WING ], [Species.THUNDURUS]: [ Moves.EARTH_POWER, Moves.HURRICANE, Moves.FROST_BREATH, Moves.ELECTRO_SHOT ], - [Species.RESHIRAM]: [ Moves.MORNING_SUN, Moves.TAKE_HEART, Moves.FICKLE_BEAM, Moves.ERUPTION ], - [Species.ZEKROM]: [ Moves.DRAGON_DANCE, Moves.THUNDEROUS_KICK, Moves.DRAGON_HAMMER, Moves.BOLT_BEAK ], + [Species.RESHIRAM]: [ Moves.ENERGY_BALL, Moves.TAKE_HEART, Moves.FICKLE_BEAM, Moves.ERUPTION ], + [Species.ZEKROM]: [ Moves.TRIPLE_AXEL, Moves.THUNDEROUS_KICK, Moves.DRAGON_HAMMER, Moves.BOLT_BEAK ], [Species.LANDORUS]: [ Moves.STONE_AXE, Moves.FLOATY_FALL, Moves.ROOST, Moves.BLEAKWIND_STORM ], - [Species.KYUREM]: [ Moves.DRAGON_DARTS, Moves.CORE_ENFORCER, Moves.NO_RETREAT, Moves.GLACIAL_LANCE ], + [Species.KYUREM]: [ Moves.DRAGON_DARTS, Moves.GLACIAL_LANCE, Moves.NO_RETREAT, Moves.DRAGON_ENERGY ], [Species.KELDEO]: [ Moves.BOUNCY_BUBBLE, Moves.THUNDERBOLT, Moves.FREEZE_DRY, Moves.STEAM_ERUPTION ], - [Species.MELOETTA]: [ Moves.VICTORY_DANCE, Moves.QUIVER_DANCE, Moves.TRIPLE_ARROWS, Moves.TORCH_SONG ], + [Species.MELOETTA]: [ Moves.BODY_SLAM, Moves.TORCH_SONG, Moves.TRIPLE_ARROWS, Moves.BOOMBURST ], [Species.GENESECT]: [ Moves.EXTREME_SPEED, Moves.U_TURN, Moves.TACHYON_CUTTER, Moves.TAIL_GLOW ], [Species.CHESPIN]: [ Moves.BODY_PRESS, Moves.SYNTHESIS, Moves.CEASELESS_EDGE, Moves.SAPPY_SEED ], [Species.FENNEKIN]: [ Moves.EXPANDING_FORCE, Moves.MOONBLAST, Moves.THUNDERBOLT, Moves.TORCH_SONG ], @@ -344,13 +344,13 @@ export const speciesEggMoves = { [Species.FLABEBE]: [ Moves.GLITZY_GLOW, Moves.MYSTICAL_FIRE, Moves.TAKE_HEART, Moves.SEED_FLARE ], [Species.SKIDDO]: [ Moves.HIGH_HORSEPOWER, Moves.GRASSY_GLIDE, Moves.STONE_AXE, Moves.SAPPY_SEED ], [Species.PANCHAM]: [ Moves.DRAIN_PUNCH, Moves.SUCKER_PUNCH, Moves.METEOR_MASH, Moves.WICKED_BLOW ], - [Species.FURFROU]: [ Moves.TIDY_UP, Moves.SLACK_OFF, Moves.COVET, Moves.MULTI_ATTACK ], - [Species.ESPURR]: [ Moves.GLARE, Moves.MOONBLAST, Moves.AURA_SPHERE, Moves.PSYSTRIKE ], + [Species.FURFROU]: [ Moves.TIDY_UP, Moves.SLACK_OFF, Moves.COMBAT_TORQUE, Moves.MULTI_ATTACK ], + [Species.ESPURR]: [ Moves.LUSTER_PURGE, Moves.MOONBLAST, Moves.AURA_SPHERE, Moves.DARK_VOID ], [Species.HONEDGE]: [ Moves.TACHYON_CUTTER, Moves.SHADOW_BONE, Moves.BITTER_BLADE, Moves.BEHEMOTH_BLADE ], - [Species.SPRITZEE]: [ Moves.TRICK_ROOM, Moves.FOUL_PLAY, Moves.WISH, Moves.REVIVAL_BLESSING ], + [Species.SPRITZEE]: [ Moves.SPEED_SWAP, Moves.TORCH_SONG, Moves.ROOST, Moves.REVIVAL_BLESSING ], [Species.SWIRLIX]: [ Moves.BELLY_DRUM, Moves.HEADLONG_RUSH, Moves.MAGICAL_TORQUE, Moves.REVIVAL_BLESSING ], [Species.INKAY]: [ Moves.POWER_TRIP, Moves.SPIN_OUT, Moves.RECOVER, Moves.PSYCHO_BOOST ], - [Species.BINACLE]: [ Moves.TRIPLE_AXEL, Moves.ACCELEROCK, Moves.DIRE_CLAW, Moves.MIGHTY_CLEAVE ], + [Species.BINACLE]: [ Moves.TRIPLE_AXEL, Moves.CRABHAMMER, Moves.DIRE_CLAW, Moves.MIGHTY_CLEAVE ], [Species.SKRELP]: [ Moves.STRENGTH_SAP, Moves.TRICK_ROOM, Moves.CALM_MIND, Moves.CORE_ENFORCER ], [Species.CLAUNCHER]: [ Moves.SHELL_SMASH, Moves.ARMOR_CANNON, Moves.WATER_SHURIKEN, Moves.ORIGIN_PULSE ], [Species.HELIOPTILE]: [ Moves.WEATHER_BALL, Moves.HYDRO_STEAM, Moves.EARTH_POWER, Moves.BOOMBURST ], @@ -360,15 +360,15 @@ export const speciesEggMoves = { [Species.DEDENNE]: [ Moves.BOOMBURST, Moves.FAKE_OUT, Moves.NASTY_PLOT, Moves.REVIVAL_BLESSING ], [Species.CARBINK]: [ Moves.BODY_PRESS, Moves.SHORE_UP, Moves.SPARKLY_SWIRL, Moves.DIAMOND_STORM ], [Species.GOOMY]: [ Moves.SCALD, Moves.RECOVER, Moves.CALM_MIND, Moves.MAKE_IT_RAIN ], - [Species.KLEFKI]: [ Moves.HEAL_BELL, Moves.ENCORE, Moves.TOPSY_TURVY, Moves.INSTRUCT ], + [Species.KLEFKI]: [ Moves.HEAL_BELL, Moves.ENCORE, Moves.INSTRUCT, Moves.TOPSY_TURVY ], [Species.PHANTUMP]: [ Moves.RAGE_FIST, Moves.TRICK_ROOM, Moves.SYNTHESIS, Moves.SAPPY_SEED ], [Species.PUMPKABOO]: [ Moves.SPIRIT_SHACKLE, Moves.FIRE_LASH, Moves.DIRE_CLAW, Moves.SAPPY_SEED ], [Species.BERGMITE]: [ Moves.STONE_AXE, Moves.METAL_BURST, Moves.BODY_PRESS, Moves.GLACIAL_LANCE ], [Species.NOIBAT]: [ Moves.AEROBLAST, Moves.OVERDRIVE, Moves.NASTY_PLOT, Moves.CLANGING_SCALES ], - [Species.XERNEAS]: [ Moves.SEARING_SHOT, Moves.LUMINA_CRASH, Moves.STRENGTH_SAP, Moves.TAIL_GLOW ], + [Species.XERNEAS]: [ Moves.EARTH_POWER, Moves.SPRINGTIDE_STORM, Moves.STRENGTH_SAP, Moves.TAIL_GLOW ], [Species.YVELTAL]: [ Moves.SHELL_SIDE_ARM, Moves.POWER_TRIP, Moves.FIERY_WRATH, Moves.CLANGOROUS_SOUL ], [Species.ZYGARDE]: [ Moves.DRAGON_DARTS, Moves.HEAL_ORDER, Moves.CLANGOROUS_SOUL, Moves.DOUBLE_IRON_BASH ], - [Species.DIANCIE]: [ Moves.MAGICAL_TORQUE, Moves.BODY_PRESS, Moves.SHORE_UP, Moves.GEOMANCY ], + [Species.DIANCIE]: [ Moves.MAGICAL_TORQUE, Moves.AURA_SPHERE, Moves.SHORE_UP, Moves.GEOMANCY ], [Species.HOOPA]: [ Moves.PHOTON_GEYSER, Moves.SECRET_SWORD, Moves.FIERY_WRATH, Moves.SHELL_SMASH ], [Species.VOLCANION]: [ Moves.HYDRO_STEAM, Moves.CALM_MIND, Moves.ENERGY_BALL, Moves.MAGMA_STORM ], [Species.ROWLET]: [ Moves.THOUSAND_ARROWS, Moves.SHADOW_BONE, Moves.FIRST_IMPRESSION, Moves.VICTORY_DANCE ], @@ -379,7 +379,7 @@ export const speciesEggMoves = { [Species.GRUBBIN]: [ Moves.ICE_BEAM, Moves.EARTH_POWER, Moves.THUNDERCLAP, Moves.QUIVER_DANCE ], [Species.CRABRAWLER]: [ Moves.JET_PUNCH, Moves.SHORE_UP, Moves.SUCKER_PUNCH, Moves.SURGING_STRIKES ], [Species.ORICORIO]: [ Moves.QUIVER_DANCE, Moves.FIERY_DANCE, Moves.THUNDERCLAP, Moves.OBLIVION_WING ], - [Species.CUTIEFLY]: [ Moves.STICKY_WEB, Moves.MOONBLAST, Moves.HEAT_WAVE, Moves.SPORE ], + [Species.CUTIEFLY]: [ Moves.STICKY_WEB, Moves.SLEEP_POWDER, Moves.HEAT_WAVE, Moves.SPARKLY_SWIRL ], [Species.ROCKRUFF]: [ Moves.HIGH_HORSEPOWER, Moves.TIDY_UP, Moves.ICE_SPINNER, Moves.MIGHTY_CLEAVE ], [Species.WISHIWASHI]: [ Moves.HEAL_ORDER, Moves.ICE_SPINNER, Moves.DRAGON_DANCE, Moves.JET_PUNCH ], [Species.MAREANIE]: [ Moves.CEASELESS_EDGE, Moves.SIZZLY_SLIDE, Moves.BODY_PRESS, Moves.LEECH_SEED ], @@ -394,31 +394,31 @@ export const speciesEggMoves = { [Species.ORANGURU]: [ Moves.JUNGLE_HEALING, Moves.YAWN, Moves.FOLLOW_ME, Moves.LUMINA_CRASH ], [Species.PASSIMIAN]: [ Moves.FAKE_OUT, Moves.SUCKER_PUNCH, Moves.ZING_ZAP, Moves.PYRO_BALL ], [Species.WIMPOD]: [ Moves.TRIPLE_AXEL, Moves.OBSTRUCT, Moves.JET_PUNCH, Moves.SURGING_STRIKES ], - [Species.SANDYGAST]: [ Moves.SCORCHING_SANDS, Moves.SPLISHY_SPLASH, Moves.TAKE_HEART, Moves.SALT_CURE ], + [Species.SANDYGAST]: [ Moves.SANDSEAR_STORM, Moves.SPLISHY_SPLASH, Moves.TAKE_HEART, Moves.SALT_CURE ], [Species.PYUKUMUKU]: [ Moves.COMEUPPANCE, Moves.BANEFUL_BUNKER, Moves.TOXIC_SPIKES, Moves.SALT_CURE ], [Species.TYPE_NULL]: [ Moves.DIRE_CLAW, Moves.RECOVER, Moves.EXTREME_SPEED, Moves.SHELL_SMASH ], [Species.MINIOR]: [ Moves.EARTH_POWER, Moves.FLOATY_FALL, Moves.ZING_ZAP, Moves.DIAMOND_STORM ], [Species.KOMALA]: [ Moves.SLACK_OFF, Moves.EXTREME_SPEED, Moves.KNOCK_OFF, Moves.COLLISION_COURSE ], [Species.TURTONATOR]: [ Moves.BURNING_BULWARK, Moves.MORNING_SUN, Moves.BODY_PRESS, Moves.CORE_ENFORCER ], - [Species.TOGEDEMARU]: [ Moves.FAKE_OUT, Moves.METAL_BURST, Moves.METEOR_MASH, Moves.BOLT_STRIKE ], + [Species.TOGEDEMARU]: [ Moves.FAKE_OUT, Moves.METAL_BURST, Moves.METEOR_MASH, Moves.AURA_WHEEL ], [Species.MIMIKYU]: [ Moves.SPIRIT_BREAK, Moves.TIDY_UP, Moves.BITTER_BLADE, Moves.SPECTRAL_THIEF ], [Species.BRUXISH]: [ Moves.PLAY_ROUGH, Moves.FIRE_FANG, Moves.DRAGON_DANCE, Moves.SURGING_STRIKES ], [Species.DRAMPA]: [ Moves.SLACK_OFF, Moves.TRICK_ROOM, Moves.CORE_ENFORCER, Moves.BOOMBURST ], [Species.DHELMISE]: [ Moves.SHADOW_BONE, Moves.STRENGTH_SAP, Moves.LIQUIDATION, Moves.SAPPY_SEED ], [Species.JANGMO_O]: [ Moves.BODY_PRESS, Moves.SHELL_SIDE_ARM, Moves.SECRET_SWORD, Moves.GLAIVE_RUSH ], - [Species.TAPU_KOKO]: [ Moves.MAGICAL_TORQUE, Moves.TRIPLE_AXEL, Moves.RISING_VOLTAGE, Moves.PLASMA_FISTS ], + [Species.TAPU_KOKO]: [ Moves.MAGICAL_TORQUE, Moves.TRIPLE_AXEL, Moves.RISING_VOLTAGE, Moves.BOLT_STRIKE ], [Species.TAPU_LELE]: [ Moves.MOONLIGHT, Moves.NASTY_PLOT, Moves.HEAT_WAVE, Moves.EXPANDING_FORCE ], [Species.TAPU_BULU]: [ Moves.SAPPY_SEED, Moves.DRAIN_PUNCH, Moves.MAGICAL_TORQUE, Moves.VICTORY_DANCE ], [Species.TAPU_FINI]: [ Moves.AURA_SPHERE, Moves.EARTH_POWER, Moves.RECOVER, Moves.QUIVER_DANCE ], [Species.COSMOG]: [ Moves.PHOTON_GEYSER, Moves.PRECIPICE_BLADES, Moves.SACRED_FIRE, Moves.ASTRAL_BARRAGE ], [Species.NIHILEGO]: [ Moves.STRENGTH_SAP, Moves.MALIGNANT_CHAIN, Moves.EARTH_POWER, Moves.QUIVER_DANCE ], [Species.BUZZWOLE]: [ Moves.FIRST_IMPRESSION, Moves.COMBAT_TORQUE, Moves.ROCK_WRECKER, Moves.DOUBLE_IRON_BASH ], - [Species.PHEROMOSA]: [ Moves.AURA_SPHERE, Moves.MAKE_IT_RAIN, Moves.ATTACK_ORDER, Moves.DIAMOND_STORM ], + [Species.PHEROMOSA]: [ Moves.SECRET_SWORD, Moves.MAKE_IT_RAIN, Moves.ATTACK_ORDER, Moves.DIAMOND_STORM ], [Species.XURKITREE]: [ Moves.FLAMETHROWER, Moves.GIGA_DRAIN, Moves.TAIL_GLOW, Moves.THUNDERCLAP ], [Species.CELESTEELA]: [ Moves.RECOVER, Moves.BUZZY_BUZZ, Moves.SANDSEAR_STORM, Moves.OBLIVION_WING ], [Species.KARTANA]: [ Moves.MIGHTY_CLEAVE, Moves.PSYBLADE, Moves.BITTER_BLADE, Moves.BEHEMOTH_BLADE ], [Species.GUZZLORD]: [ Moves.SUCKER_PUNCH, Moves.COMEUPPANCE, Moves.SLACK_OFF, Moves.SHED_TAIL ], - [Species.NECROZMA]: [ Moves.CLANGOROUS_SOUL, Moves.SACRED_FIRE, Moves.ASTRAL_BARRAGE, Moves.DYNAMAX_CANNON ], + [Species.NECROZMA]: [ Moves.DYNAMAX_CANNON, Moves.SACRED_FIRE, Moves.ASTRAL_BARRAGE, Moves.CLANGOROUS_SOUL ], [Species.MAGEARNA]: [ Moves.STRENGTH_SAP, Moves.EARTH_POWER, Moves.MOONBLAST, Moves.MAKE_IT_RAIN ], [Species.MARSHADOW]: [ Moves.POWER_UP_PUNCH, Moves.TRIPLE_AXEL, Moves.METEOR_MASH, Moves.STORM_THROW ], [Species.POIPOLE]: [ Moves.CORE_ENFORCER, Moves.ICE_BEAM, Moves.SEARING_SHOT, Moves.MALIGNANT_CHAIN ], @@ -428,11 +428,11 @@ export const speciesEggMoves = { [Species.MELTAN]: [ Moves.BULLET_PUNCH, Moves.DRAIN_PUNCH, Moves.BULK_UP, Moves.PLASMA_FISTS ], [Species.GROOKEY]: [ Moves.HIGH_HORSEPOWER, Moves.CLANGOROUS_SOUL, Moves.GRASSY_GLIDE, Moves.SAPPY_SEED ], [Species.SCORBUNNY]: [ Moves.EXTREME_SPEED, Moves.HIGH_JUMP_KICK, Moves.TRIPLE_AXEL, Moves.BOLT_STRIKE ], - [Species.SOBBLE]: [ Moves.AEROBLAST, Moves.FROST_BREATH, Moves.SCORCHING_SANDS, Moves.NASTY_PLOT ], - [Species.SKWOVET]: [ Moves.KNOCK_OFF, Moves.SLACK_OFF, Moves.BODY_PRESS, Moves.POPULATION_BOMB ], + [Species.SOBBLE]: [ Moves.AEROBLAST, Moves.FROST_BREATH, Moves.ENERGY_BALL, Moves.NASTY_PLOT ], + [Species.SKWOVET]: [ Moves.SUCKER_PUNCH, Moves.SLACK_OFF, Moves.COIL, Moves.POPULATION_BOMB ], [Species.ROOKIDEE]: [ Moves.ROOST, Moves.BODY_PRESS, Moves.KINGS_SHIELD, Moves.BEHEMOTH_BASH ], - [Species.BLIPBUG]: [ Moves.HEAL_ORDER, Moves.EXPANDING_FORCE, Moves.SPORE, Moves.TAIL_GLOW ], - [Species.NICKIT]: [ Moves.BADDY_BAD, Moves.BURNING_JEALOUSY, Moves.SPARKLY_SWIRL, Moves.FIERY_WRATH ], + [Species.BLIPBUG]: [ Moves.HEAL_ORDER, Moves.LUSTER_PURGE, Moves.SLEEP_POWDER, Moves.TAIL_GLOW ], + [Species.NICKIT]: [ Moves.BADDY_BAD, Moves.FLAMETHROWER, Moves.SPARKLY_SWIRL, Moves.MAKE_IT_RAIN ], [Species.GOSSIFLEUR]: [ Moves.TAILWIND, Moves.STRENGTH_SAP, Moves.SAPPY_SEED, Moves.SEED_FLARE ], [Species.WOOLOO]: [ Moves.PSYSHIELD_BASH, Moves.MILK_DRINK, Moves.BODY_PRESS, Moves.MULTI_ATTACK ], [Species.CHEWTLE]: [ Moves.ICE_FANG, Moves.ACCELEROCK, Moves.SHELL_SMASH, Moves.FISHIOUS_REND ], @@ -446,25 +446,25 @@ export const speciesEggMoves = { [Species.SIZZLIPEDE]: [ Moves.BURNING_BULWARK, Moves.ZING_ZAP, Moves.FIRST_IMPRESSION, Moves.BITTER_BLADE ], [Species.CLOBBOPUS]: [ Moves.STORM_THROW, Moves.JET_PUNCH, Moves.MACH_PUNCH, Moves.SURGING_STRIKES ], [Species.SINISTEA]: [ Moves.SCALD, Moves.TAKE_HEART, Moves.SPARKLY_SWIRL, Moves.MATCHA_GOTCHA ], - [Species.HATENNA]: [ Moves.RECOVER, Moves.MOONBLAST, Moves.BUZZY_BUZZ, Moves.SEARING_SHOT ], + [Species.HATENNA]: [ Moves.RECOVER, Moves.MOONBLAST, Moves.BUZZY_BUZZ, Moves.TORCH_SONG ], [Species.IMPIDIMP]: [ Moves.ENCORE, Moves.PARTING_SHOT, Moves.TOPSY_TURVY, Moves.WICKED_BLOW ], [Species.MILCERY]: [ Moves.MOONBLAST, Moves.CHILLY_RECEPTION, Moves.EARTH_POWER, Moves.GEOMANCY ], [Species.FALINKS]: [ Moves.COMBAT_TORQUE, Moves.PSYSHIELD_BASH, Moves.HEAL_ORDER, Moves.POPULATION_BOMB ], [Species.PINCURCHIN]: [ Moves.TRICK_ROOM, Moves.RISING_VOLTAGE, Moves.STRENGTH_SAP, Moves.THUNDERCLAP ], - [Species.SNOM]: [ Moves.MOONBLAST, Moves.SURF, Moves.EARTH_POWER, Moves.FIERY_DANCE ], + [Species.SNOM]: [ Moves.FROST_BREATH, Moves.HEAL_ORDER, Moves.EARTH_POWER, Moves.SPORE ], [Species.STONJOURNER]: [ Moves.BODY_PRESS, Moves.HELPING_HAND, Moves.ACCELEROCK, Moves.DIAMOND_STORM ], [Species.EISCUE]: [ Moves.TRIPLE_AXEL, Moves.AQUA_STEP, Moves.SHELL_SMASH, Moves.GLACIAL_LANCE ], [Species.INDEEDEE]: [ Moves.MATCHA_GOTCHA, Moves.EXPANDING_FORCE, Moves.MOONBLAST, Moves.REVIVAL_BLESSING ], [Species.MORPEKO]: [ Moves.TRIPLE_AXEL, Moves.OBSTRUCT, Moves.SWORDS_DANCE, Moves.COLLISION_COURSE ], [Species.CUFANT]: [ Moves.LIQUIDATION, Moves.CURSE, Moves.COMBAT_TORQUE, Moves.GIGATON_HAMMER ], - [Species.DRACOZOLT]: [ Moves.TRIPLE_AXEL, Moves.DRAGON_HAMMER, Moves.FIRE_LASH, Moves.DRAGON_DANCE ], + [Species.DRACOZOLT]: [ Moves.TRIPLE_AXEL, Moves.SCALE_SHOT, Moves.FIRE_LASH, Moves.DRAGON_DANCE ], [Species.ARCTOZOLT]: [ Moves.MOUNTAIN_GALE, Moves.AQUA_STEP, Moves.HIGH_HORSEPOWER, Moves.SHIFT_GEAR ], [Species.DRACOVISH]: [ Moves.TRIPLE_AXEL, Moves.DRAGON_HAMMER, Moves.THUNDER_FANG, Moves.DRAGON_DANCE ], [Species.ARCTOVISH]: [ Moves.ICE_FANG, Moves.THUNDER_FANG, Moves.HIGH_HORSEPOWER, Moves.SHIFT_GEAR ], [Species.DURALUDON]: [ Moves.CORE_ENFORCER, Moves.BODY_PRESS, Moves.RECOVER, Moves.TACHYON_CUTTER ], - [Species.DREEPY]: [ Moves.SHADOW_BONE, Moves.POWER_UP_PUNCH, Moves.BLAZING_TORQUE, Moves.GLAIVE_RUSH ], + [Species.DREEPY]: [ Moves.SHADOW_BONE, Moves.NASTY_PLOT, Moves.FIRE_LASH, Moves.COLLISION_COURSE ], [Species.ZACIAN]: [ Moves.MAGICAL_TORQUE, Moves.MIGHTY_CLEAVE, Moves.BITTER_BLADE, Moves.PRECIPICE_BLADES ], - [Species.ZAMAZENTA]: [ Moves.PSYSHIELD_BASH, Moves.BODY_PRESS, Moves.SLACK_OFF, Moves.VICTORY_DANCE ], + [Species.ZAMAZENTA]: [ Moves.BULK_UP, Moves.BODY_PRESS, Moves.SLACK_OFF, Moves.DIAMOND_STORM ], [Species.ETERNATUS]: [ Moves.BODY_PRESS, Moves.NASTY_PLOT, Moves.MALIGNANT_CHAIN, Moves.DRAGON_ENERGY ], [Species.KUBFU]: [ Moves.METEOR_MASH, Moves.DRAIN_PUNCH, Moves.JET_PUNCH, Moves.DRAGON_DANCE ], [Species.ZARUDE]: [ Moves.SAPPY_SEED, Moves.MIGHTY_CLEAVE, Moves.WICKED_BLOW, Moves.VICTORY_DANCE ], @@ -482,7 +482,7 @@ export const speciesEggMoves = { [Species.NYMBLE]: [ Moves.KNOCK_OFF, Moves.FELL_STINGER, Moves.ATTACK_ORDER, Moves.WICKED_BLOW ], [Species.PAWMI]: [ Moves.DRAIN_PUNCH, Moves.ICE_PUNCH, Moves.MACH_PUNCH, Moves.PLASMA_FISTS ], [Species.TANDEMAUS]: [ Moves.BATON_PASS, Moves.THIEF, Moves.SIZZLY_SLIDE, Moves.REVIVAL_BLESSING ], - [Species.FIDOUGH]: [ Moves.WISH, Moves.BODY_PRESS, Moves.SIZZLY_SLIDE, Moves.TIDY_UP ], + [Species.FIDOUGH]: [ Moves.SOFT_BOILED, Moves.HIGH_HORSEPOWER, Moves.SIZZLY_SLIDE, Moves.TIDY_UP ], [Species.SMOLIV]: [ Moves.STRENGTH_SAP, Moves.EARTH_POWER, Moves.CALM_MIND, Moves.BOOMBURST ], [Species.SQUAWKABILLY]: [ Moves.PARTING_SHOT, Moves.EARTHQUAKE, Moves.FLARE_BLITZ, Moves.EXTREME_SPEED ], [Species.NACLI]: [ Moves.BODY_PRESS, Moves.TOXIC, Moves.CURSE, Moves.DIAMOND_STORM ], @@ -492,7 +492,7 @@ export const speciesEggMoves = { [Species.MASCHIFF]: [ Moves.PARTING_SHOT, Moves.CLOSE_COMBAT, Moves.PSYCHIC_FANGS, Moves.NO_RETREAT ], [Species.SHROODLE]: [ Moves.GASTRO_ACID, Moves.PARTING_SHOT, Moves.TOXIC, Moves.SKETCH ], [Species.BRAMBLIN]: [ Moves.TAILWIND, Moves.STRENGTH_SAP, Moves.FLOWER_TRICK, Moves.LAST_RESPECTS ], - [Species.TOEDSCOOL]: [ Moves.STRENGTH_SAP, Moves.TOPSY_TURVY, Moves.PARTING_SHOT, Moves.SAPPY_SEED ], + [Species.TOEDSCOOL]: [ Moves.STRENGTH_SAP, Moves.TOPSY_TURVY, Moves.SAPPY_SEED, Moves.TAIL_GLOW ], [Species.KLAWF]: [ Moves.CRABHAMMER, Moves.SHORE_UP, Moves.MIGHTY_CLEAVE, Moves.SHELL_SMASH ], [Species.CAPSAKID]: [ Moves.STRENGTH_SAP, Moves.APPLE_ACID, Moves.FROST_BREATH, Moves.TORCH_SONG ], [Species.RELLOR]: [ Moves.HEAL_BLOCK, Moves.RECOVER, Moves.HEAT_WAVE, Moves.LUMINA_CRASH ], @@ -509,7 +509,7 @@ export const speciesEggMoves = { [Species.FLAMIGO]: [ Moves.THUNDEROUS_KICK, Moves.TRIPLE_AXEL, Moves.FLOATY_FALL, Moves.VICTORY_DANCE ], [Species.CETODDLE]: [ Moves.MOUNTAIN_GALE, Moves.HIGH_HORSEPOWER, Moves.RECOVER, Moves.DRAGON_DANCE ], [Species.VELUZA]: [ Moves.PSYBLADE, Moves.FLIP_TURN, Moves.ICE_SPINNER, Moves.BITTER_BLADE ], - [Species.DONDOZO]: [ Moves.SOFT_BOILED, Moves.ICE_SPINNER, Moves.TOXIC, Moves.SALT_CURE ], + [Species.DONDOZO]: [ Moves.SOFT_BOILED, Moves.SIZZLY_SLIDE, Moves.TOXIC, Moves.SALT_CURE ], [Species.TATSUGIRI]: [ Moves.ICE_BEAM, Moves.FILLET_AWAY, Moves.CORE_ENFORCER, Moves.STEAM_ERUPTION ], [Species.GREAT_TUSK]: [ Moves.STONE_AXE, Moves.MORNING_SUN, Moves.COLLISION_COURSE, Moves.SHIFT_GEAR ], [Species.SCREAM_TAIL]: [ Moves.TORCH_SONG, Moves.GLITZY_GLOW, Moves.MOONLIGHT, Moves.SPARKLY_SWIRL ], @@ -521,7 +521,7 @@ export const speciesEggMoves = { [Species.IRON_BUNDLE]: [ Moves.EARTH_POWER, Moves.BOUNCY_BUBBLE, Moves.NASTY_PLOT, Moves.STEAM_ERUPTION ], [Species.IRON_HANDS]: [ Moves.DRAIN_PUNCH, Moves.BULK_UP, Moves.PLASMA_FISTS, Moves.ICE_HAMMER ], [Species.IRON_JUGULIS]: [ Moves.FIERY_WRATH, Moves.ROOST, Moves.NASTY_PLOT, Moves.OBLIVION_WING ], - [Species.IRON_MOTH]: [ Moves.EARTH_POWER, Moves.SEARING_SHOT, Moves.QUIVER_DANCE, Moves.MALIGNANT_CHAIN ], + [Species.IRON_MOTH]: [ Moves.EARTH_POWER, Moves.SEARING_SHOT, Moves.MALIGNANT_CHAIN, Moves.QUIVER_DANCE ], [Species.IRON_THORNS]: [ Moves.DIAMOND_STORM, Moves.SHORE_UP, Moves.SHIFT_GEAR, Moves.PLASMA_FISTS ], [Species.FRIGIBAX]: [ Moves.DRAGON_DARTS, Moves.DRAGON_DANCE, Moves.EARTHQUAKE, Moves.GLACIAL_LANCE ], [Species.GIMMIGHOUL]: [ Moves.HAPPY_HOUR, Moves.AURA_SPHERE, Moves.SURF, Moves.ASTRAL_BARRAGE ], @@ -540,7 +540,7 @@ export const speciesEggMoves = { [Species.MUNKIDORI]: [ Moves.PSYSTRIKE, Moves.HEAT_WAVE, Moves.EARTH_POWER, Moves.MALIGNANT_CHAIN ], [Species.FEZANDIPITI]: [ Moves.BARB_BARRAGE, Moves.VICTORY_DANCE, Moves.TRIPLE_AXEL, Moves.MAGICAL_TORQUE ], [Species.OGERPON]: [ Moves.FLOWER_TRICK, Moves.BONEMERANG, Moves.TRIPLE_AXEL, Moves.GIGATON_HAMMER ], - [Species.GOUGING_FIRE]: [ Moves.SUPERCELL_SLAM, Moves.BULK_UP, Moves.SACRED_FIRE, Moves.GLAIVE_RUSH ], + [Species.GOUGING_FIRE]: [ Moves.EXTREME_SPEED, Moves.BULK_UP, Moves.SACRED_FIRE, Moves.GLAIVE_RUSH ], [Species.RAGING_BOLT]: [ Moves.NASTY_PLOT, Moves.FLAMETHROWER, Moves.MORNING_SUN, Moves.ELECTRO_DRIFT ], [Species.IRON_BOULDER]: [ Moves.PSYBLADE, Moves.KOWTOW_CLEAVE, Moves.STONE_AXE, Moves.BITTER_BLADE ], [Species.IRON_CROWN]: [ Moves.NASTY_PLOT, Moves.SECRET_SWORD, Moves.PSYSTRIKE, Moves.ELECTRO_DRIFT ], @@ -566,7 +566,7 @@ export const speciesEggMoves = { [Species.GALAR_DARUMAKA]: [ Moves.ICE_SPINNER, Moves.ENDURE, Moves.DRAIN_PUNCH, Moves.V_CREATE ], [Species.GALAR_YAMASK]: [ Moves.STRENGTH_SAP, Moves.DIRE_CLAW, Moves.THOUSAND_WAVES, Moves.SPECTRAL_THIEF ], [Species.GALAR_STUNFISK]: [ Moves.SPIKY_SHIELD, Moves.THOUSAND_ARROWS, Moves.STRENGTH_SAP, Moves.DOUBLE_IRON_BASH ], - [Species.HISUI_GROWLITHE]: [ Moves.WOOD_HAMMER, Moves.HEAD_SMASH, Moves.MORNING_SUN, Moves.DRAGON_DANCE ], + [Species.HISUI_GROWLITHE]: [ Moves.WAVE_CRASH, Moves.HEAD_SMASH, Moves.VOLT_TACKLE, Moves.DRAGON_DANCE ], [Species.HISUI_VOLTORB]: [ Moves.FROST_BREATH, Moves.NASTY_PLOT, Moves.APPLE_ACID, Moves.ELECTRO_DRIFT ], [Species.HISUI_QWILFISH]: [ Moves.CEASELESS_EDGE, Moves.KNOCK_OFF, Moves.STRENGTH_SAP, Moves.FISHIOUS_REND ], [Species.HISUI_SNEASEL]: [ Moves.THUNDEROUS_KICK, Moves.KNOCK_OFF, Moves.TRIPLE_AXEL, Moves.VICTORY_DANCE ], diff --git a/src/data/balance/passives.ts b/src/data/balance/passives.ts new file mode 100644 index 00000000000..6fb0e80e085 --- /dev/null +++ b/src/data/balance/passives.ts @@ -0,0 +1,574 @@ +import { Abilities } from "#app/enums/abilities"; +import { Species } from "#app/enums/species"; + +export const starterPassiveAbilities = { + [Species.BULBASAUR]: Abilities.GRASSY_SURGE, + [Species.CHARMANDER]: Abilities.BEAST_BOOST, + [Species.SQUIRTLE]: Abilities.STURDY, + [Species.CATERPIE]: Abilities.MAGICIAN, + [Species.WEEDLE]: Abilities.TINTED_LENS, + [Species.PIDGEY]: Abilities.SHEER_FORCE, + [Species.RATTATA]: Abilities.STRONG_JAW, + [Species.SPEAROW]: Abilities.MOXIE, + [Species.EKANS]: Abilities.REGENERATOR, + [Species.SANDSHREW]: Abilities.TOUGH_CLAWS, + [Species.NIDORAN_F]: Abilities.FLARE_BOOST, + [Species.NIDORAN_M]: Abilities.GUTS, + [Species.VULPIX]: Abilities.FUR_COAT, + [Species.ZUBAT]: Abilities.INTIMIDATE, + [Species.ODDISH]: Abilities.TRIAGE, + [Species.PARAS]: Abilities.TRIAGE, + [Species.VENONAT]: Abilities.SIMPLE, + [Species.DIGLETT]: Abilities.STURDY, + [Species.MEOWTH]: Abilities.TOUGH_CLAWS, + [Species.PSYDUCK]: Abilities.SIMPLE, + [Species.MANKEY]: Abilities.IRON_FIST, + [Species.GROWLITHE]: Abilities.SPEED_BOOST, + [Species.POLIWAG]: Abilities.NO_GUARD, + [Species.ABRA]: Abilities.PSYCHIC_SURGE, + [Species.MACHOP]: Abilities.QUICK_FEET, + [Species.BELLSPROUT]: Abilities.FLOWER_GIFT, + [Species.TENTACOOL]: Abilities.TOXIC_CHAIN, + [Species.GEODUDE]: Abilities.DRY_SKIN, + [Species.PONYTA]: Abilities.MAGIC_GUARD, + [Species.SLOWPOKE]: Abilities.UNAWARE, + [Species.MAGNEMITE]: Abilities.LEVITATE, + [Species.FARFETCHD]: Abilities.SNIPER, + [Species.DODUO]: Abilities.PARENTAL_BOND, + [Species.SEEL]: Abilities.WATER_BUBBLE, + [Species.GRIMER]: Abilities.WATER_ABSORB, + [Species.SHELLDER]: Abilities.ICE_SCALES, + [Species.GASTLY]: Abilities.SHADOW_SHIELD, + [Species.ONIX]: Abilities.ROCKY_PAYLOAD, + [Species.DROWZEE]: Abilities.MAGICIAN, + [Species.KRABBY]: Abilities.THERMAL_EXCHANGE, + [Species.VOLTORB]: Abilities.TRANSISTOR, + [Species.EXEGGCUTE]: Abilities.RIPEN, + [Species.CUBONE]: Abilities.PARENTAL_BOND, + [Species.LICKITUNG]: Abilities.CHEEK_POUCH, + [Species.KOFFING]: Abilities.PARENTAL_BOND, + [Species.RHYHORN]: Abilities.FILTER, + [Species.TANGELA]: Abilities.SEED_SOWER, + [Species.KANGASKHAN]: Abilities.GUTS, + [Species.HORSEA]: Abilities.DRAGONS_MAW, + [Species.GOLDEEN]: Abilities.MULTISCALE, + [Species.STARYU]: Abilities.REGENERATOR, + [Species.SCYTHER]: Abilities.TINTED_LENS, + [Species.PINSIR]: Abilities.TINTED_LENS, + [Species.TAUROS]: Abilities.STAMINA, + [Species.MAGIKARP]: Abilities.MULTISCALE, + [Species.LAPRAS]: Abilities.LIGHTNING_ROD, + [Species.DITTO]: Abilities.ADAPTABILITY, + [Species.EEVEE]: Abilities.PICKUP, + [Species.PORYGON]: Abilities.PROTEAN, + [Species.OMANYTE]: Abilities.STURDY, + [Species.KABUTO]: Abilities.TOUGH_CLAWS, + [Species.AERODACTYL]: Abilities.ORICHALCUM_PULSE, + [Species.ARTICUNO]: Abilities.SNOW_WARNING, + [Species.ZAPDOS]: Abilities.DRIZZLE, + [Species.MOLTRES]: Abilities.DROUGHT, + [Species.DRATINI]: Abilities.AERILATE, + [Species.MEWTWO]: Abilities.NEUROFORCE, + [Species.MEW]: Abilities.PROTEAN, + [Species.CHIKORITA]: Abilities.THICK_FAT, + [Species.CYNDAQUIL]: Abilities.DROUGHT, + [Species.TOTODILE]: Abilities.TOUGH_CLAWS, + [Species.SENTRET]: Abilities.PICKUP, + [Species.HOOTHOOT]: Abilities.AERILATE, + [Species.LEDYBA]: Abilities.PRANKSTER, + [Species.SPINARAK]: Abilities.PRANKSTER, + [Species.CHINCHOU]: Abilities.WATER_BUBBLE, + [Species.PICHU]: Abilities.ELECTRIC_SURGE, + [Species.CLEFFA]: Abilities.ANALYTIC, + [Species.IGGLYBUFF]: Abilities.HUGE_POWER, + [Species.TOGEPI]: Abilities.PIXILATE, + [Species.NATU]: Abilities.TINTED_LENS, + [Species.MAREEP]: Abilities.ELECTROMORPHOSIS, + [Species.HOPPIP]: Abilities.FLUFFY, + [Species.AIPOM]: Abilities.SCRAPPY, + [Species.SUNKERN]: Abilities.DROUGHT, + [Species.YANMA]: Abilities.SHEER_FORCE, + [Species.WOOPER]: Abilities.COMATOSE, + [Species.MURKROW]: Abilities.DARK_AURA, + [Species.MISDREAVUS]: Abilities.BEADS_OF_RUIN, + [Species.UNOWN]: Abilities.PICKUP, + [Species.GIRAFARIG]: Abilities.PARENTAL_BOND, + [Species.PINECO]: Abilities.IRON_BARBS, + [Species.DUNSPARCE]: Abilities.UNAWARE, + [Species.GLIGAR]: Abilities.TOXIC_BOOST, + [Species.SNUBBULL]: Abilities.PIXILATE, + [Species.QWILFISH]: Abilities.TOXIC_DEBRIS, + [Species.SHUCKLE]: Abilities.HARVEST, + [Species.HERACROSS]: Abilities.TECHNICIAN, + [Species.SNEASEL]: Abilities.TOUGH_CLAWS, + [Species.TEDDIURSA]: Abilities.THICK_FAT, + [Species.SLUGMA]: Abilities.DESOLATE_LAND, + [Species.SWINUB]: Abilities.SLUSH_RUSH, + [Species.CORSOLA]: Abilities.STORM_DRAIN, + [Species.REMORAID]: Abilities.SIMPLE, + [Species.DELIBIRD]: Abilities.HUGE_POWER, + [Species.SKARMORY]: Abilities.LIGHTNING_ROD, + [Species.HOUNDOUR]: Abilities.DROUGHT, + [Species.PHANPY]: Abilities.SPEED_BOOST, + [Species.STANTLER]: Abilities.SPEED_BOOST, + [Species.SMEARGLE]: Abilities.PRANKSTER, + [Species.TYROGUE]: Abilities.MOXIE, + [Species.SMOOCHUM]: Abilities.PSYCHIC_SURGE, + [Species.ELEKID]: Abilities.SHEER_FORCE, + [Species.MAGBY]: Abilities.CONTRARY, + [Species.MILTANK]: Abilities.STAMINA, + [Species.RAIKOU]: Abilities.TRANSISTOR, + [Species.ENTEI]: Abilities.MOXIE, + [Species.SUICUNE]: Abilities.UNAWARE, + [Species.LARVITAR]: Abilities.SAND_RUSH, + [Species.LUGIA]: Abilities.DELTA_STREAM, + [Species.HO_OH]: Abilities.MAGIC_GUARD, + [Species.CELEBI]: Abilities.PSYCHIC_SURGE, + [Species.TREECKO]: Abilities.TINTED_LENS, + [Species.TORCHIC]: Abilities.RECKLESS, + [Species.MUDKIP]: Abilities.DRIZZLE, + [Species.POOCHYENA]: Abilities.TOUGH_CLAWS, + [Species.ZIGZAGOON]: Abilities.RUN_AWAY, + [Species.WURMPLE]: Abilities.SIMPLE, + [Species.LOTAD]: Abilities.DRIZZLE, + [Species.SEEDOT]: Abilities.SHARPNESS, + [Species.TAILLOW]: Abilities.AERILATE, + [Species.WINGULL]: Abilities.SWIFT_SWIM, + [Species.RALTS]: Abilities.PSYCHIC_SURGE, + [Species.SURSKIT]: Abilities.WATER_BUBBLE, + [Species.SHROOMISH]: Abilities.GUTS, + [Species.SLAKOTH]: Abilities.GUTS, + [Species.NINCADA]: Abilities.MAGIC_GUARD, + [Species.WHISMUR]: Abilities.PUNK_ROCK, + [Species.MAKUHITA]: Abilities.STAMINA, + [Species.AZURILL]: Abilities.MISTY_SURGE, + [Species.NOSEPASS]: Abilities.LEVITATE, + [Species.SKITTY]: Abilities.SCRAPPY, + [Species.SABLEYE]: Abilities.UNNERVE, + [Species.MAWILE]: Abilities.UNNERVE, + [Species.ARON]: Abilities.EARTH_EATER, + [Species.MEDITITE]: Abilities.MINDS_EYE, + [Species.ELECTRIKE]: Abilities.ELECTRIC_SURGE, + [Species.PLUSLE]: Abilities.POWER_SPOT, + [Species.MINUN]: Abilities.POWER_SPOT, + [Species.VOLBEAT]: Abilities.HONEY_GATHER, + [Species.ILLUMISE]: Abilities.HONEY_GATHER, + [Species.GULPIN]: Abilities.EARTH_EATER, + [Species.CARVANHA]: Abilities.SHEER_FORCE, + [Species.WAILMER]: Abilities.LEVITATE, + [Species.NUMEL]: Abilities.FUR_COAT, + [Species.TORKOAL]: Abilities.ANALYTIC, + [Species.SPOINK]: Abilities.PSYCHIC_SURGE, + [Species.SPINDA]: Abilities.SIMPLE, + [Species.TRAPINCH]: Abilities.ADAPTABILITY, + [Species.CACNEA]: Abilities.SAND_RUSH, + [Species.SWABLU]: Abilities.ADAPTABILITY, + [Species.ZANGOOSE]: Abilities.POISON_HEAL, + [Species.SEVIPER]: Abilities.MULTISCALE, + [Species.LUNATONE]: Abilities.SHADOW_SHIELD, + [Species.SOLROCK]: Abilities.DROUGHT, + [Species.BARBOACH]: Abilities.SIMPLE, + [Species.CORPHISH]: Abilities.TOUGH_CLAWS, + [Species.BALTOY]: Abilities.WELL_BAKED_BODY, + [Species.LILEEP]: Abilities.SEED_SOWER, + [Species.ANORITH]: Abilities.WATER_ABSORB, + [Species.FEEBAS]: Abilities.MAGIC_GUARD, + [Species.CASTFORM]: Abilities.ADAPTABILITY, + [Species.KECLEON]: Abilities.ADAPTABILITY, + [Species.SHUPPET]: Abilities.SHADOW_SHIELD, + [Species.DUSKULL]: Abilities.UNNERVE, + [Species.TROPIUS]: Abilities.RIPEN, + [Species.ABSOL]: Abilities.SHARPNESS, + [Species.WYNAUT]: Abilities.STURDY, + [Species.SNORUNT]: Abilities.SNOW_WARNING, + [Species.SPHEAL]: Abilities.UNAWARE, + [Species.CLAMPERL]: Abilities.DRIZZLE, + [Species.RELICANTH]: Abilities.PRIMORDIAL_SEA, + [Species.LUVDISC]: Abilities.MULTISCALE, + [Species.BAGON]: Abilities.DRAGONS_MAW, + [Species.BELDUM]: Abilities.LEVITATE, + [Species.REGIROCK]: Abilities.SAND_STREAM, + [Species.REGICE]: Abilities.SNOW_WARNING, + [Species.REGISTEEL]: Abilities.FILTER, + [Species.LATIAS]: Abilities.PRISM_ARMOR, + [Species.LATIOS]: Abilities.TINTED_LENS, + [Species.KYOGRE]: Abilities.MOLD_BREAKER, + [Species.GROUDON]: Abilities.TURBOBLAZE, + [Species.RAYQUAZA]: Abilities.UNNERVE, + [Species.JIRACHI]: Abilities.COMATOSE, + [Species.DEOXYS]: Abilities.PROTEAN, + [Species.TURTWIG]: Abilities.THICK_FAT, + [Species.CHIMCHAR]: Abilities.BEAST_BOOST, + [Species.PIPLUP]: Abilities.DRIZZLE, + [Species.STARLY]: Abilities.ROCK_HEAD, + [Species.BIDOOF]: Abilities.SAP_SIPPER, + [Species.KRICKETOT]: Abilities.SHARPNESS, + [Species.SHINX]: Abilities.SPEED_BOOST, + [Species.BUDEW]: Abilities.GRASSY_SURGE, + [Species.CRANIDOS]: Abilities.ROCK_HEAD, + [Species.SHIELDON]: Abilities.EARTH_EATER, + [Species.BURMY]: Abilities.STURDY, + [Species.COMBEE]: Abilities.INTIMIDATE, + [Species.PACHIRISU]: Abilities.HONEY_GATHER, + [Species.BUIZEL]: Abilities.MOXIE, + [Species.CHERUBI]: Abilities.ORICHALCUM_PULSE, + [Species.SHELLOS]: Abilities.REGENERATOR, + [Species.DRIFLOON]: Abilities.MAGIC_GUARD, + [Species.BUNEARY]: Abilities.ADAPTABILITY, + [Species.GLAMEOW]: Abilities.INTIMIDATE, + [Species.CHINGLING]: Abilities.PUNK_ROCK, + [Species.STUNKY]: Abilities.NEUTRALIZING_GAS, + [Species.BRONZOR]: Abilities.BULLETPROOF, + [Species.BONSLY]: Abilities.SAP_SIPPER, + [Species.MIME_JR]: Abilities.OPPORTUNIST, + [Species.HAPPINY]: Abilities.FUR_COAT, + [Species.CHATOT]: Abilities.PUNK_ROCK, + [Species.SPIRITOMB]: Abilities.VESSEL_OF_RUIN, + [Species.GIBLE]: Abilities.SAND_STREAM, + [Species.MUNCHLAX]: Abilities.RIPEN, + [Species.RIOLU]: Abilities.MINDS_EYE, + [Species.HIPPOPOTAS]: Abilities.UNAWARE, + [Species.SKORUPI]: Abilities.SUPER_LUCK, + [Species.CROAGUNK]: Abilities.MOXIE, + [Species.CARNIVINE]: Abilities.ARENA_TRAP, + [Species.FINNEON]: Abilities.WATER_BUBBLE, + [Species.MANTYKE]: Abilities.UNAWARE, + [Species.SNOVER]: Abilities.THICK_FAT, + [Species.ROTOM]: Abilities.HADRON_ENGINE, + [Species.UXIE]: Abilities.UNAWARE, + [Species.MESPRIT]: Abilities.MOODY, + [Species.AZELF]: Abilities.NEUROFORCE, + [Species.DIALGA]: Abilities.LEVITATE, + [Species.PALKIA]: Abilities.SPEED_BOOST, + [Species.HEATRAN]: Abilities.EARTH_EATER, + [Species.REGIGIGAS]: Abilities.SCRAPPY, + [Species.GIRATINA]: Abilities.SHADOW_SHIELD, + [Species.CRESSELIA]: Abilities.SHADOW_SHIELD, + [Species.PHIONE]: Abilities.SIMPLE, + [Species.MANAPHY]: Abilities.PRIMORDIAL_SEA, + [Species.DARKRAI]: Abilities.UNNERVE, + [Species.SHAYMIN]: Abilities.WIND_RIDER, + [Species.ARCEUS]: Abilities.ADAPTABILITY, + [Species.VICTINI]: Abilities.SHEER_FORCE, + [Species.SNIVY]: Abilities.MULTISCALE, + [Species.TEPIG]: Abilities.ROCK_HEAD, + [Species.OSHAWOTT]: Abilities.INTREPID_SWORD, + [Species.PATRAT]: Abilities.NO_GUARD, + [Species.LILLIPUP]: Abilities.FUR_COAT, + [Species.PURRLOIN]: Abilities.PICKUP, + [Species.PANSAGE]: Abilities.WELL_BAKED_BODY, + [Species.PANSEAR]: Abilities.WATER_ABSORB, + [Species.PANPOUR]: Abilities.SAP_SIPPER, + [Species.MUNNA]: Abilities.NEUTRALIZING_GAS, + [Species.PIDOVE]: Abilities.SNIPER, + [Species.BLITZLE]: Abilities.ELECTRIC_SURGE, + [Species.ROGGENROLA]: Abilities.SOLID_ROCK, + [Species.WOOBAT]: Abilities.OPPORTUNIST, + [Species.DRILBUR]: Abilities.SAND_STREAM, + [Species.AUDINO]: Abilities.FRIEND_GUARD, + [Species.TIMBURR]: Abilities.ROCKY_PAYLOAD, + [Species.TYMPOLE]: Abilities.POISON_HEAL, + [Species.THROH]: Abilities.STAMINA, + [Species.SAWK]: Abilities.SCRAPPY, + [Species.SEWADDLE]: Abilities.SHARPNESS, + [Species.VENIPEDE]: Abilities.STAMINA, + [Species.COTTONEE]: Abilities.FLUFFY, + [Species.PETILIL]: Abilities.SIMPLE, + [Species.BASCULIN]: Abilities.SUPREME_OVERLORD, + [Species.SANDILE]: Abilities.TOUGH_CLAWS, + [Species.DARUMAKA]: Abilities.GORILLA_TACTICS, + [Species.MARACTUS]: Abilities.WELL_BAKED_BODY, + [Species.DWEBBLE]: Abilities.ROCKY_PAYLOAD, + [Species.SCRAGGY]: Abilities.PROTEAN, + [Species.SIGILYPH]: Abilities.FLARE_BOOST, + [Species.YAMASK]: Abilities.PURIFYING_SALT, + [Species.TIRTOUGA]: Abilities.WATER_ABSORB, + [Species.ARCHEN]: Abilities.MULTISCALE, + [Species.TRUBBISH]: Abilities.NEUTRALIZING_GAS, + [Species.ZORUA]: Abilities.DARK_AURA, + [Species.MINCCINO]: Abilities.FUR_COAT, + [Species.GOTHITA]: Abilities.UNNERVE, + [Species.SOLOSIS]: Abilities.PSYCHIC_SURGE, + [Species.DUCKLETT]: Abilities.DRIZZLE, + [Species.VANILLITE]: Abilities.SLUSH_RUSH, + [Species.DEERLING]: Abilities.FUR_COAT, + [Species.EMOLGA]: Abilities.TRANSISTOR, + [Species.KARRABLAST]: Abilities.QUICK_DRAW, + [Species.FOONGUS]: Abilities.THICK_FAT, + [Species.FRILLISH]: Abilities.POISON_HEAL, + [Species.ALOMOMOLA]: Abilities.MULTISCALE, + [Species.JOLTIK]: Abilities.TRANSISTOR, + [Species.FERROSEED]: Abilities.ROUGH_SKIN, + [Species.KLINK]: Abilities.STEELY_SPIRIT, + [Species.TYNAMO]: Abilities.POISON_HEAL, + [Species.ELGYEM]: Abilities.PRISM_ARMOR, + [Species.LITWICK]: Abilities.SOUL_HEART, + [Species.AXEW]: Abilities.DRAGONS_MAW, + [Species.CUBCHOO]: Abilities.TOUGH_CLAWS, + [Species.CRYOGONAL]: Abilities.SNOW_WARNING, + [Species.SHELMET]: Abilities.PROTEAN, + [Species.STUNFISK]: Abilities.STORM_DRAIN, + [Species.MIENFOO]: Abilities.NO_GUARD, + [Species.DRUDDIGON]: Abilities.INTIMIDATE, + [Species.GOLETT]: Abilities.SHADOW_SHIELD, + [Species.PAWNIARD]: Abilities.SWORD_OF_RUIN, + [Species.BOUFFALANT]: Abilities.ROCK_HEAD, + [Species.RUFFLET]: Abilities.SPEED_BOOST, + [Species.VULLABY]: Abilities.THICK_FAT, + [Species.HEATMOR]: Abilities.CONTRARY, + [Species.DURANT]: Abilities.COMPOUND_EYES, + [Species.DEINO]: Abilities.PARENTAL_BOND, + [Species.LARVESTA]: Abilities.DROUGHT, + [Species.COBALION]: Abilities.INTREPID_SWORD, + [Species.TERRAKION]: Abilities.ROCKY_PAYLOAD, + [Species.VIRIZION]: Abilities.SHARPNESS, + [Species.TORNADUS]: Abilities.DRIZZLE, + [Species.THUNDURUS]: Abilities.DRIZZLE, + [Species.RESHIRAM]: Abilities.ORICHALCUM_PULSE, + [Species.ZEKROM]: Abilities.HADRON_ENGINE, + [Species.LANDORUS]: Abilities.STORM_DRAIN, + [Species.KYUREM]: Abilities.SNOW_WARNING, + [Species.KELDEO]: Abilities.GRIM_NEIGH, + [Species.MELOETTA]: Abilities.MINDS_EYE, + [Species.GENESECT]: Abilities.PROTEAN, + [Species.CHESPIN]: Abilities.DAUNTLESS_SHIELD, + [Species.FENNEKIN]: Abilities.PSYCHIC_SURGE, + [Species.FROAKIE]: Abilities.STAKEOUT, + [Species.BUNNELBY]: Abilities.GUTS, + [Species.FLETCHLING]: Abilities.MAGIC_GUARD, + [Species.SCATTERBUG]: Abilities.PRANKSTER, + [Species.LITLEO]: Abilities.BEAST_BOOST, + [Species.FLABEBE]: Abilities.GRASSY_SURGE, + [Species.SKIDDO]: Abilities.SEED_SOWER, + [Species.PANCHAM]: Abilities.FUR_COAT, + [Species.FURFROU]: Abilities.FLUFFY, + [Species.ESPURR]: Abilities.FUR_COAT, + [Species.HONEDGE]: Abilities.SHARPNESS, + [Species.SPRITZEE]: Abilities.FUR_COAT, + [Species.SWIRLIX]: Abilities.WELL_BAKED_BODY, + [Species.INKAY]: Abilities.UNNERVE, + [Species.BINACLE]: Abilities.SAP_SIPPER, + [Species.SKRELP]: Abilities.DRAGONS_MAW, + [Species.CLAUNCHER]: Abilities.SWIFT_SWIM, + [Species.HELIOPTILE]: Abilities.PROTEAN, + [Species.TYRUNT]: Abilities.RECKLESS, + [Species.AMAURA]: Abilities.ICE_SCALES, + [Species.HAWLUCHA]: Abilities.MOXIE, + [Species.DEDENNE]: Abilities.PIXILATE, + [Species.CARBINK]: Abilities.SOLID_ROCK, + [Species.GOOMY]: Abilities.REGENERATOR, + [Species.KLEFKI]: Abilities.LEVITATE, + [Species.PHANTUMP]: Abilities.SHADOW_TAG, + [Species.PUMPKABOO]: Abilities.WELL_BAKED_BODY, + [Species.BERGMITE]: Abilities.ICE_SCALES, + [Species.NOIBAT]: Abilities.PUNK_ROCK, + [Species.XERNEAS]: Abilities.HARVEST, + [Species.YVELTAL]: Abilities.SOUL_HEART, + [Species.ZYGARDE]: Abilities.HUGE_POWER, + [Species.DIANCIE]: Abilities.LEVITATE, + [Species.HOOPA]: Abilities.OPPORTUNIST, + [Species.VOLCANION]: Abilities.FILTER, + [Species.ROWLET]: Abilities.SNIPER, + [Species.LITTEN]: Abilities.OPPORTUNIST, + [Species.POPPLIO]: Abilities.PUNK_ROCK, + [Species.PIKIPEK]: Abilities.TECHNICIAN, + [Species.YUNGOOS]: Abilities.TOUGH_CLAWS, + [Species.GRUBBIN]: Abilities.SPEED_BOOST, + [Species.CRABRAWLER]: Abilities.WATER_BUBBLE, + [Species.ORICORIO]: Abilities.ADAPTABILITY, + [Species.CUTIEFLY]: Abilities.TINTED_LENS, + [Species.ROCKRUFF]: Abilities.ROCKY_PAYLOAD, + [Species.WISHIWASHI]: Abilities.REGENERATOR, + [Species.MAREANIE]: Abilities.TOXIC_DEBRIS, + [Species.MUDBRAY]: Abilities.CUD_CHEW, + [Species.DEWPIDER]: Abilities.TINTED_LENS, + [Species.FOMANTIS]: Abilities.SHARPNESS, + [Species.MORELULL]: Abilities.TRIAGE, + [Species.SALANDIT]: Abilities.DRAGONS_MAW, + [Species.STUFFUL]: Abilities.SCRAPPY, + [Species.BOUNSWEET]: Abilities.MOXIE, + [Species.COMFEY]: Abilities.FRIEND_GUARD, + [Species.ORANGURU]: Abilities.POWER_SPOT, + [Species.PASSIMIAN]: Abilities.LIBERO, + [Species.WIMPOD]: Abilities.REGENERATOR, + [Species.SANDYGAST]: Abilities.SAND_SPIT, + [Species.PYUKUMUKU]: Abilities.PURIFYING_SALT, + [Species.TYPE_NULL]: Abilities.ADAPTABILITY, + [Species.MINIOR]: Abilities.STURDY, + [Species.KOMALA]: Abilities.GUTS, + [Species.TURTONATOR]: Abilities.DAUNTLESS_SHIELD, + [Species.TOGEDEMARU]: Abilities.ROUGH_SKIN, + [Species.MIMIKYU]: Abilities.TOUGH_CLAWS, + [Species.BRUXISH]: Abilities.MULTISCALE, + [Species.DRAMPA]: Abilities.THICK_FAT, + [Species.DHELMISE]: Abilities.WATER_BUBBLE, + [Species.JANGMO_O]: Abilities.DAUNTLESS_SHIELD, + [Species.TAPU_KOKO]: Abilities.TRANSISTOR, + [Species.TAPU_LELE]: Abilities.SHEER_FORCE, + [Species.TAPU_BULU]: Abilities.TRIAGE, + [Species.TAPU_FINI]: Abilities.FAIRY_AURA, + [Species.COSMOG]: Abilities.BEAST_BOOST, + [Species.NIHILEGO]: Abilities.LEVITATE, + [Species.BUZZWOLE]: Abilities.MOXIE, + [Species.PHEROMOSA]: Abilities.TINTED_LENS, + [Species.XURKITREE]: Abilities.TRANSISTOR, + [Species.CELESTEELA]: Abilities.HEATPROOF, + [Species.KARTANA]: Abilities.SHARPNESS, + [Species.GUZZLORD]: Abilities.POISON_HEAL, + [Species.NECROZMA]: Abilities.BEAST_BOOST, + [Species.MAGEARNA]: Abilities.STEELY_SPIRIT, + [Species.MARSHADOW]: Abilities.IRON_FIST, + [Species.POIPOLE]: Abilities.SHEER_FORCE, + [Species.STAKATAKA]: Abilities.SOLID_ROCK, + [Species.BLACEPHALON]: Abilities.MAGIC_GUARD, + [Species.ZERAORA]: Abilities.TOUGH_CLAWS, + [Species.MELTAN]: Abilities.STEELY_SPIRIT, + [Species.GROOKEY]: Abilities.GRASS_PELT, + [Species.SCORBUNNY]: Abilities.NO_GUARD, + [Species.SOBBLE]: Abilities.SUPER_LUCK, + [Species.SKWOVET]: Abilities.HARVEST, + [Species.ROOKIDEE]: Abilities.IRON_BARBS, + [Species.BLIPBUG]: Abilities.PSYCHIC_SURGE, + [Species.NICKIT]: Abilities.MAGICIAN, + [Species.GOSSIFLEUR]: Abilities.GRASSY_SURGE, + [Species.WOOLOO]: Abilities.SIMPLE, + [Species.CHEWTLE]: Abilities.ROCKY_PAYLOAD, + [Species.YAMPER]: Abilities.SHEER_FORCE, + [Species.ROLYCOLY]: Abilities.SOLID_ROCK, + [Species.APPLIN]: Abilities.DRAGONS_MAW, + [Species.SILICOBRA]: Abilities.SAND_RUSH, + [Species.CRAMORANT]: Abilities.LIGHTNING_ROD, + [Species.ARROKUDA]: Abilities.INTIMIDATE, + [Species.TOXEL]: Abilities.ELECTRIC_SURGE, + [Species.SIZZLIPEDE]: Abilities.SPEED_BOOST, + [Species.CLOBBOPUS]: Abilities.WATER_BUBBLE, + [Species.SINISTEA]: Abilities.SHADOW_SHIELD, + [Species.HATENNA]: Abilities.FAIRY_AURA, + [Species.IMPIDIMP]: Abilities.FUR_COAT, + [Species.MILCERY]: Abilities.REGENERATOR, + [Species.FALINKS]: Abilities.PARENTAL_BOND, + [Species.PINCURCHIN]: Abilities.ELECTROMORPHOSIS, + [Species.SNOM]: Abilities.SNOW_WARNING, + [Species.STONJOURNER]: Abilities.STURDY, + [Species.EISCUE]: Abilities.ICE_SCALES, + [Species.INDEEDEE]: Abilities.FRIEND_GUARD, + [Species.MORPEKO]: Abilities.MOODY, + [Species.CUFANT]: Abilities.EARTH_EATER, + [Species.DRACOZOLT]: Abilities.NO_GUARD, + [Species.ARCTOZOLT]: Abilities.TRANSISTOR, + [Species.DRACOVISH]: Abilities.SWIFT_SWIM, + [Species.ARCTOVISH]: Abilities.STRONG_JAW, + [Species.DURALUDON]: Abilities.STEELWORKER, + [Species.DREEPY]: Abilities.PARENTAL_BOND, + [Species.ZACIAN]: Abilities.UNNERVE, + [Species.ZAMAZENTA]: Abilities.UNNERVE, + [Species.ETERNATUS]: Abilities.NEUTRALIZING_GAS, + [Species.KUBFU]: Abilities.IRON_FIST, + [Species.ZARUDE]: Abilities.TOUGH_CLAWS, + [Species.REGIELEKI]: Abilities.ELECTRIC_SURGE, + [Species.REGIDRAGO]: Abilities.MULTISCALE, + [Species.GLASTRIER]: Abilities.FILTER, + [Species.SPECTRIER]: Abilities.SHADOW_SHIELD, + [Species.CALYREX]: Abilities.HARVEST, + [Species.ENAMORUS]: Abilities.FAIRY_AURA, + [Species.SPRIGATITO]: Abilities.MAGICIAN, + [Species.FUECOCO]: Abilities.PUNK_ROCK, + [Species.QUAXLY]: Abilities.OPPORTUNIST, + [Species.LECHONK]: Abilities.SIMPLE, + [Species.TAROUNTULA]: Abilities.HONEY_GATHER, + [Species.NYMBLE]: Abilities.GUTS, + [Species.PAWMI]: Abilities.TRANSISTOR, + [Species.TANDEMAUS]: Abilities.SCRAPPY, + [Species.FIDOUGH]: Abilities.WATER_ABSORB, + [Species.SMOLIV]: Abilities.RIPEN, + [Species.SQUAWKABILLY]: Abilities.MOXIE, + [Species.NACLI]: Abilities.SOLID_ROCK, + [Species.CHARCADET]: Abilities.PRISM_ARMOR, + [Species.TADBULB]: Abilities.STAMINA, + [Species.WATTREL]: Abilities.SHEER_FORCE, + [Species.MASCHIFF]: Abilities.STRONG_JAW, + [Species.SHROODLE]: Abilities.CORROSION, + [Species.BRAMBLIN]: Abilities.SHADOW_SHIELD, + [Species.TOEDSCOOL]: Abilities.PRANKSTER, + [Species.KLAWF]: Abilities.WATER_ABSORB, + [Species.CAPSAKID]: Abilities.PARENTAL_BOND, + [Species.RELLOR]: Abilities.PRANKSTER, + [Species.FLITTLE]: Abilities.DAZZLING, + [Species.TINKATINK]: Abilities.STEELWORKER, + [Species.WIGLETT]: Abilities.STURDY, + [Species.BOMBIRDIER]: Abilities.UNBURDEN, + [Species.FINIZEN]: Abilities.IRON_FIST, + [Species.VAROOM]: Abilities.LEVITATE, + [Species.CYCLIZAR]: Abilities.PROTEAN, + [Species.ORTHWORM]: Abilities.REGENERATOR, + [Species.GLIMMET]: Abilities.LEVITATE, + [Species.GREAVARD]: Abilities.FUR_COAT, + [Species.FLAMIGO]: Abilities.MOXIE, + [Species.CETODDLE]: Abilities.ICE_SCALES, + [Species.VELUZA]: Abilities.SUPER_LUCK, + [Species.DONDOZO]: Abilities.PARENTAL_BOND, + [Species.TATSUGIRI]: Abilities.ADAPTABILITY, + [Species.GREAT_TUSK]: Abilities.INTIMIDATE, + [Species.SCREAM_TAIL]: Abilities.UNAWARE, + [Species.BRUTE_BONNET]: Abilities.CHLOROPHYLL, + [Species.FLUTTER_MANE]: Abilities.DAZZLING, + [Species.SLITHER_WING]: Abilities.SCRAPPY, + [Species.SANDY_SHOCKS]: Abilities.EARTH_EATER, + [Species.IRON_TREADS]: Abilities.STEELY_SPIRIT, + [Species.IRON_BUNDLE]: Abilities.SNOW_WARNING, + [Species.IRON_HANDS]: Abilities.IRON_FIST, + [Species.IRON_JUGULIS]: Abilities.LIGHTNING_ROD, + [Species.IRON_MOTH]: Abilities.LEVITATE, + [Species.IRON_THORNS]: Abilities.SAND_STREAM, + [Species.FRIGIBAX]: Abilities.SNOW_WARNING, + [Species.GIMMIGHOUL]: Abilities.HONEY_GATHER, + [Species.WO_CHIEN]: Abilities.VESSEL_OF_RUIN, + [Species.CHIEN_PAO]: Abilities.INTIMIDATE, + [Species.TING_LU]: Abilities.STAMINA, + [Species.CHI_YU]: Abilities.BERSERK, + [Species.ROARING_MOON]: Abilities.TOUGH_CLAWS, + [Species.IRON_VALIANT]: Abilities.ADAPTABILITY, + [Species.KORAIDON]: Abilities.OPPORTUNIST, + [Species.MIRAIDON]: Abilities.OPPORTUNIST, + [Species.WALKING_WAKE]: Abilities.BEAST_BOOST, + [Species.IRON_LEAVES]: Abilities.SHARPNESS, + [Species.POLTCHAGEIST]: Abilities.TRIAGE, + [Species.OKIDOGI]: Abilities.FUR_COAT, + [Species.MUNKIDORI]: Abilities.NEUROFORCE, + [Species.FEZANDIPITI]: Abilities.LEVITATE, + [Species.OGERPON]: Abilities.OPPORTUNIST, + [Species.GOUGING_FIRE]: Abilities.BEAST_BOOST, + [Species.RAGING_BOLT]: Abilities.BEAST_BOOST, + [Species.IRON_BOULDER]: Abilities.SHARPNESS, + [Species.IRON_CROWN]: Abilities.SHARPNESS, + [Species.TERAPAGOS]: Abilities.SOUL_HEART, + [Species.PECHARUNT]: Abilities.TOXIC_CHAIN, + [Species.ALOLA_RATTATA]: Abilities.ADAPTABILITY, + [Species.ALOLA_SANDSHREW]: Abilities.ICE_SCALES, + [Species.ALOLA_VULPIX]: Abilities.SHEER_FORCE, + [Species.ALOLA_DIGLETT]: Abilities.STURDY, + [Species.ALOLA_MEOWTH]: Abilities.DARK_AURA, + [Species.ALOLA_GEODUDE]: Abilities.DRY_SKIN, + [Species.ALOLA_GRIMER]: Abilities.TOXIC_DEBRIS, + [Species.ETERNAL_FLOETTE]: Abilities.MAGIC_GUARD, + [Species.GALAR_MEOWTH]: Abilities.STEELWORKER, + [Species.GALAR_PONYTA]: Abilities.MOXIE, + [Species.GALAR_SLOWPOKE]: Abilities.UNAWARE, + [Species.GALAR_FARFETCHD]: Abilities.INTREPID_SWORD, + [Species.GALAR_ARTICUNO]: Abilities.SERENE_GRACE, + [Species.GALAR_ZAPDOS]: Abilities.TOUGH_CLAWS, + [Species.GALAR_MOLTRES]: Abilities.DARK_AURA, + [Species.GALAR_CORSOLA]: Abilities.SHADOW_SHIELD, + [Species.GALAR_ZIGZAGOON]: Abilities.POISON_HEAL, + [Species.GALAR_DARUMAKA]: Abilities.FLASH_FIRE, + [Species.GALAR_YAMASK]: Abilities.TABLETS_OF_RUIN, + [Species.GALAR_STUNFISK]: Abilities.ARENA_TRAP, + [Species.HISUI_GROWLITHE]: Abilities.RECKLESS, + [Species.HISUI_VOLTORB]: Abilities.TRANSISTOR, + [Species.HISUI_QWILFISH]: Abilities.MERCILESS, + [Species.HISUI_SNEASEL]: Abilities.SCRAPPY, + [Species.HISUI_ZORUA]: Abilities.ADAPTABILITY, + [Species.PALDEA_TAUROS]: Abilities.ADAPTABILITY, + [Species.PALDEA_WOOPER]: Abilities.THICK_FAT, + [Species.BLOODMOON_URSALUNA]: Abilities.BERSERK +}; diff --git a/src/data/pokemon-evolutions.ts b/src/data/balance/pokemon-evolutions.ts similarity index 96% rename from src/data/pokemon-evolutions.ts rename to src/data/balance/pokemon-evolutions.ts index f9602d1386a..9e86ea7397b 100644 --- a/src/data/pokemon-evolutions.ts +++ b/src/data/balance/pokemon-evolutions.ts @@ -1,16 +1,17 @@ -import { Gender } from "./gender"; -import { PokeballType } from "./pokeball"; -import Pokemon from "../field/pokemon"; -import { Stat } from "#enums/stat"; -import { Type } from "./type"; -import * as Utils from "../utils"; -import { SpeciesFormKey } from "./pokemon-species"; -import { WeatherType } from "./weather"; -import { Nature } from "./nature"; +import { Gender } from "#app/data/gender"; +import { PokeballType } from "#enums/pokeball"; +import Pokemon from "#app/field/pokemon"; +import { Type } from "#enums/type"; +import * as Utils from "#app/utils"; +import { WeatherType } from "#enums/weather-type"; +import { Nature } from "#enums/nature"; import { Biome } from "#enums/biome"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; import { TimeOfDay } from "#enums/time-of-day"; +import { DamageMoneyRewardModifier, ExtraModifierModifier, MoneyMultiplierModifier, TempExtraModifierModifier } from "#app/modifier/modifier"; +import { SpeciesFormKey } from "#enums/species-form-key"; + export enum SpeciesWildEvolutionDelay { NONE, @@ -269,9 +270,21 @@ export const pokemonEvolutions: PokemonEvolutions = { new SpeciesEvolution(Species.MAROWAK, 28, null, new SpeciesEvolutionCondition(p => p.scene.arena.getTimeOfDay() === TimeOfDay.DAWN || p.scene.arena.getTimeOfDay() === TimeOfDay.DAY)) ], [Species.TYROGUE]: [ - new SpeciesEvolution(Species.HITMONLEE, 20, null, new SpeciesEvolutionCondition(p => p.stats[Stat.ATK] > p.stats[Stat.DEF])), - new SpeciesEvolution(Species.HITMONCHAN, 20, null, new SpeciesEvolutionCondition(p => p.stats[Stat.ATK] < p.stats[Stat.DEF])), - new SpeciesEvolution(Species.HITMONTOP, 20, null, new SpeciesEvolutionCondition(p => p.stats[Stat.ATK] === p.stats[Stat.DEF])) + /** + * Custom: Evolves into Hitmonlee, Hitmonchan or Hitmontop at level 20 + * if it knows Low Sweep, Mach Punch, or Rapid Spin, respectively. + * If Tyrogue knows multiple of these moves, its evolution is based on + * the first qualifying move in its moveset. + */ + new SpeciesEvolution(Species.HITMONLEE, 20, null, new SpeciesEvolutionCondition(p => + p.getMoveset(true).find(move => move && [ Moves.LOW_SWEEP, Moves.MACH_PUNCH, Moves.RAPID_SPIN ].includes(move?.moveId))?.moveId === Moves.LOW_SWEEP + )), + new SpeciesEvolution(Species.HITMONCHAN, 20, null, new SpeciesEvolutionCondition(p => + p.getMoveset(true).find(move => move && [ Moves.LOW_SWEEP, Moves.MACH_PUNCH, Moves.RAPID_SPIN ].includes(move?.moveId))?.moveId === Moves.MACH_PUNCH + )), + new SpeciesEvolution(Species.HITMONTOP, 20, null, new SpeciesEvolutionCondition(p => + p.getMoveset(true).find(move => move && [ Moves.LOW_SWEEP, Moves.MACH_PUNCH, Moves.RAPID_SPIN ].includes(move?.moveId))?.moveId === Moves.RAPID_SPIN + )), ], [Species.KOFFING]: [ new SpeciesEvolution(Species.GALAR_WEEZING, 35, null, new SpeciesEvolutionCondition(p => p.scene.arena.getTimeOfDay() === TimeOfDay.DUSK || p.scene.arena.getTimeOfDay() === TimeOfDay.NIGHT)), @@ -465,7 +478,7 @@ export const pokemonEvolutions: PokemonEvolutions = { ], [Species.NINCADA]: [ new SpeciesEvolution(Species.NINJASK, 20, null, null), - new SpeciesEvolution(Species.SHEDINJA, 20, null, new SpeciesEvolutionCondition(p => p.scene.getParty().length < 6 && p.scene.pokeballCounts[PokeballType.POKEBALL] > 0)) + new SpeciesEvolution(Species.SHEDINJA, 20, null, new SpeciesEvolutionCondition(p => p.scene.getPlayerParty().length < 6 && p.scene.pokeballCounts[PokeballType.POKEBALL] > 0)) ], [Species.WHISMUR]: [ new SpeciesEvolution(Species.LOUDRED, 20, null, null) @@ -877,7 +890,7 @@ export const pokemonEvolutions: PokemonEvolutions = { new SpeciesEvolution(Species.GOGOAT, 32, null, null) ], [Species.PANCHAM]: [ - new SpeciesEvolution(Species.PANGORO, 32, null, new SpeciesEvolutionCondition(p => !!p.scene.getParty().find(p => p.getTypes(false, false, true).indexOf(Type.DARK) > -1)), SpeciesWildEvolutionDelay.MEDIUM) + new SpeciesEvolution(Species.PANGORO, 32, null, new SpeciesEvolutionCondition(p => !!p.scene.getPlayerParty().find(p => p.getTypes(false, false, true).indexOf(Type.DARK) > -1)), SpeciesWildEvolutionDelay.MEDIUM) ], [Species.ESPURR]: [ new SpeciesFormEvolution(Species.MEOWSTIC, "", "female", 25, null, new SpeciesEvolutionCondition(p => p.gender === Gender.FEMALE, p => p.gender = Gender.FEMALE)), @@ -992,8 +1005,8 @@ export const pokemonEvolutions: PokemonEvolutions = { new SpeciesEvolution(Species.COSMOEM, 23, null, null) ], [Species.COSMOEM]: [ - new SpeciesEvolution(Species.SOLGALEO, 53, EvolutionItem.SUN_FLUTE, null, SpeciesWildEvolutionDelay.VERY_LONG), - new SpeciesEvolution(Species.LUNALA, 53, EvolutionItem.MOON_FLUTE, null, SpeciesWildEvolutionDelay.VERY_LONG) + new SpeciesEvolution(Species.SOLGALEO, 1, EvolutionItem.SUN_FLUTE, null, SpeciesWildEvolutionDelay.VERY_LONG), + new SpeciesEvolution(Species.LUNALA, 1, EvolutionItem.MOON_FLUTE, null, SpeciesWildEvolutionDelay.VERY_LONG) ], [Species.MELTAN]: [ new SpeciesEvolution(Species.MELMETAL, 48, null, null) @@ -1430,7 +1443,7 @@ export const pokemonEvolutions: PokemonEvolutions = { ], [Species.ROCKRUFF]: [ new SpeciesFormEvolution(Species.LYCANROC, "", "midday", 25, null, new SpeciesEvolutionCondition(p => (p.scene.arena.getTimeOfDay() === TimeOfDay.DAWN || p.scene.arena.getTimeOfDay() === TimeOfDay.DAY) && (p.formIndex === 0))), - new SpeciesFormEvolution(Species.LYCANROC, "", "dusk", 25, null, new SpeciesEvolutionCondition(p => p.formIndex === 1)), + new SpeciesFormEvolution(Species.LYCANROC, "own-tempo", "dusk", 25, null, new SpeciesEvolutionCondition(p => p.formIndex === 1)), new SpeciesFormEvolution(Species.LYCANROC, "", "midnight", 25, null, new SpeciesEvolutionCondition(p => (p.scene.arena.getTimeOfDay() === TimeOfDay.DUSK || p.scene.arena.getTimeOfDay() === TimeOfDay.NIGHT) && (p.formIndex === 0))) ], [Species.STEENEE]: [ @@ -1647,8 +1660,14 @@ export const pokemonEvolutions: PokemonEvolutions = { new SpeciesEvolution(Species.FROSMOTH, 1, null, new SpeciesFriendshipEvolutionCondition(90, p => p.scene.arena.getTimeOfDay() === TimeOfDay.DUSK || p.scene.arena.getTimeOfDay() === TimeOfDay.NIGHT), SpeciesWildEvolutionDelay.MEDIUM) ], [Species.GIMMIGHOUL]: [ - new SpeciesFormEvolution(Species.GHOLDENGO, "chest", "", 1, null, new SpeciesEvolutionCondition( p => p.evoCounter > 9 ), SpeciesWildEvolutionDelay.VERY_LONG), - new SpeciesFormEvolution(Species.GHOLDENGO, "roaming", "", 1, null, new SpeciesEvolutionCondition( p => p.evoCounter > 9 ), SpeciesWildEvolutionDelay.VERY_LONG) + new SpeciesFormEvolution(Species.GHOLDENGO, "chest", "", 1, null, new SpeciesEvolutionCondition(p => p.evoCounter + + p.getHeldItems().filter(m => m instanceof DamageMoneyRewardModifier).length + + p.scene.findModifiers(m => m instanceof MoneyMultiplierModifier + || m instanceof ExtraModifierModifier || m instanceof TempExtraModifierModifier).length > 9), SpeciesWildEvolutionDelay.VERY_LONG), + new SpeciesFormEvolution(Species.GHOLDENGO, "roaming", "", 1, null, new SpeciesEvolutionCondition(p => p.evoCounter + + p.getHeldItems().filter(m => m instanceof DamageMoneyRewardModifier).length + + p.scene.findModifiers(m => m instanceof MoneyMultiplierModifier + || m instanceof ExtraModifierModifier || m instanceof TempExtraModifierModifier).length > 9), SpeciesWildEvolutionDelay.VERY_LONG) ] }; diff --git a/src/data/pokemon-level-moves.ts b/src/data/balance/pokemon-level-moves.ts similarity index 95% rename from src/data/pokemon-level-moves.ts rename to src/data/balance/pokemon-level-moves.ts index b56bab724be..71d98fb4fc2 100644 --- a/src/data/pokemon-level-moves.ts +++ b/src/data/balance/pokemon-level-moves.ts @@ -93,6 +93,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.GROWL ], [ 1, Moves.EMBER ], [ 1, Moves.SMOKESCREEN ], + [ 1, Moves.FIRE_SPIN ], // Previous Stage Move [ 12, Moves.DRAGON_BREATH ], [ 19, Moves.FIRE_FANG ], [ 24, Moves.SLASH ], @@ -174,6 +175,9 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.METAPOD]: [ [ EVOLVE_MOVE, Moves.HARDEN ], + [ RELEARN_MOVE, Moves.TACKLE ], // Previous Stage Move + [ RELEARN_MOVE, Moves.STRING_SHOT ], // Previous Stage Move + [ RELEARN_MOVE, Moves.BUG_BITE ], // Previous Stage Move [ 1, Moves.HARDEN ], ], [Species.BUTTERFREE]: [ @@ -203,10 +207,17 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.KAKUNA]: [ [ EVOLVE_MOVE, Moves.HARDEN ], + [ RELEARN_MOVE, Moves.POISON_STING ], // Previous Stage Move + [ RELEARN_MOVE, Moves.STRING_SHOT ], // Previous Stage Move + [ RELEARN_MOVE, Moves.BUG_BITE ], // Previous Stage Move [ 1, Moves.HARDEN ], ], [Species.BEEDRILL]: [ [ EVOLVE_MOVE, Moves.TWINEEDLE ], + [ 1, Moves.POISON_STING ], // Previous Stage Move + [ 1, Moves.STRING_SHOT ], // Previous Stage Move + [ 1, Moves.HARDEN ], // Previous Stage Move + [ 1, Moves.BUG_BITE ], // Previous Stage Move [ 1, Moves.FURY_ATTACK ], [ 11, Moves.FURY_CUTTER ], [ 14, Moves.RAGE ], @@ -454,6 +465,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.POISON_STING ], [ 1, Moves.DEFENSE_CURL ], [ 1, Moves.CRUSH_CLAW ], + [ 1, Moves.AGILITY ], // Previous Stage Move [ 9, Moves.ROLLOUT ], [ 12, Moves.FURY_CUTTER ], [ 15, Moves.RAPID_SPIN ], @@ -961,6 +973,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.SCRATCH ], [ 1, Moves.LEER ], [ 1, Moves.FOCUS_ENERGY ], + [ 1, Moves.COVET ], // Previous Stage Move [ 1, Moves.FLING ], [ 5, Moves.FURY_SWIPES ], [ 8, Moves.LOW_KICK ], @@ -1044,10 +1057,6 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.POLIWRATH]: [ [ EVOLVE_MOVE, Moves.DYNAMIC_PUNCH ], - [ 1, Moves.BUBBLE_BEAM ], - [ 1, Moves.BODY_SLAM ], - [ 1, Moves.HYPNOSIS ], - [ 1, Moves.WATER_SPORT ], [ RELEARN_MOVE, Moves.POUND ], [ RELEARN_MOVE, Moves.DOUBLE_EDGE ], [ RELEARN_MOVE, Moves.WATER_GUN ], @@ -1057,13 +1066,18 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ RELEARN_MOVE, Moves.MUD_SHOT ], [ RELEARN_MOVE, Moves.EARTH_POWER ], [ RELEARN_MOVE, Moves.CIRCLE_THROW ], + [ 1, Moves.BUBBLE_BEAM ], + [ 1, Moves.BODY_SLAM ], + [ 1, Moves.HYPNOSIS ], + [ 1, Moves.WATER_SPORT ], ], [Species.ABRA]: [ [ 1, Moves.TELEPORT ], - [ 1, Moves.CONFUSION ], //Custom + [ 1, Moves.CONFUSION ], // Custom ], [Species.KADABRA]: [ - [ EVOLVE_MOVE, Moves.PSYBEAM ], //LGPE + [ EVOLVE_MOVE, Moves.PSYBEAM ], // LGPE + [ 1, Moves.CONFUSION ], // Previous Stage Move, Custom [ 1, Moves.DISABLE ], [ 1, Moves.TELEPORT ], [ 1, Moves.KINESIS ], @@ -1184,10 +1198,18 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ RELEARN_MOVE, Moves.STOCKPILE ], [ RELEARN_MOVE, Moves.SWALLOW ], [ RELEARN_MOVE, Moves.SPIT_UP ], + [ RELEARN_MOVE, Moves.WRAP ], // Previous Stage Move + [ RELEARN_MOVE, Moves.GROWTH ], // Previous Stage Move + [ RELEARN_MOVE, Moves.ACID ], // Previous Stage Move + [ RELEARN_MOVE, Moves.KNOCK_OFF ], // Previous Stage Move [ RELEARN_MOVE, Moves.GASTRO_ACID ], + [ RELEARN_MOVE, Moves.POISON_JAB ], // Previous Stage Move + [ RELEARN_MOVE, Moves.SLAM ], // Previous Stage Move [ RELEARN_MOVE, Moves.POWER_WHIP ], [ 1, Moves.VINE_WHIP ], [ 1, Moves.SLEEP_POWDER ], + [ 1, Moves.POISON_POWDER ], // Previous Stage Move + [ 1, Moves.STUN_SPORE ], // Previous Stage Move [ 1, Moves.SWEET_SCENT ], [ 1, Moves.RAZOR_LEAF ], [ 44, Moves.LEAF_BLADE ], @@ -1262,6 +1284,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.TACKLE ], [ 1, Moves.DEFENSE_CURL ], [ 1, Moves.ROCK_POLISH ], + [ 1, Moves.ROLLOUT ], // Previous Stage Move [ 1, Moves.HEAVY_SLAM ], [ 16, Moves.ROCK_THROW ], [ 18, Moves.SMACK_DOWN ], @@ -1548,7 +1571,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.GASTLY]: [ [ 1, Moves.CONFUSE_RAY ], [ 1, Moves.LICK ], - [ 1, Moves.ACID ], //Custom + [ 1, Moves.ACID ], // Custom [ 4, Moves.HYPNOSIS ], [ 8, Moves.MEAN_LOOK ], [ 12, Moves.PAYBACK ], @@ -1567,6 +1590,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.HYPNOSIS ], [ 1, Moves.CONFUSE_RAY ], [ 1, Moves.LICK ], + [ 1, Moves.ACID ], // Previous Stage Move, Custom [ 1, Moves.MEAN_LOOK ], [ 12, Moves.PAYBACK ], [ 16, Moves.SPITE ], @@ -1583,6 +1607,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.HYPNOSIS ], [ 1, Moves.CONFUSE_RAY ], [ 1, Moves.LICK ], + [ 1, Moves.ACID ], // Previous Stage Move, Custom [ 1, Moves.PERISH_SONG ], [ 1, Moves.MEAN_LOOK ], [ 1, Moves.SHADOW_PUNCH ], @@ -1609,7 +1634,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 12, Moves.DRAGON_BREATH ], [ 16, Moves.CURSE ], [ 20, Moves.ROCK_SLIDE ], - [ 22, Moves.GYRO_BALL ], //Custom, from USUM + [ 22, Moves.GYRO_BALL ], // Custom, from USUM [ 24, Moves.SCREECH ], [ 28, Moves.SAND_TOMB ], [ 32, Moves.STEALTH_ROCK ], @@ -1810,6 +1835,8 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.LOW_SWEEP ], [ 1, Moves.JUMP_KICK ], [ 1, Moves.ROLLING_KICK ], + [ 1, Moves.MACH_PUNCH ], // Previous Stage Move, Custom + [ 1, Moves.RAPID_SPIN ], // Previous Stage Move, Custom [ 4, Moves.DOUBLE_KICK ], [ 8, Moves.LOW_KICK ], [ 12, Moves.ENDURE ], @@ -1832,6 +1859,8 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.FEINT ], [ 1, Moves.PURSUIT ], [ 1, Moves.COMET_PUNCH ], + [ 1, Moves.LOW_SWEEP ], // Previous Stage Move, Custom + [ 1, Moves.RAPID_SPIN ], // Previous Stage Move, Custom [ 4, Moves.MACH_PUNCH ], [ 8, Moves.VACUUM_WAVE ], [ 12, Moves.DETECT ], @@ -1849,7 +1878,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.LICKITUNG]: [ [ 1, Moves.DEFENSE_CURL ], [ 1, Moves.LICK ], - [ 1, Moves.TACKLE ], //Custom + [ 1, Moves.TACKLE ], // Custom [ 6, Moves.REST ], [ 12, Moves.SUPERSONIC ], [ 18, Moves.WRAP ], @@ -2090,6 +2119,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.MR_MIME]: [ [ 1, Moves.POUND ], + [ 1, Moves.TICKLE ], // Previous Stage Move [ 1, Moves.BATON_PASS ], [ 1, Moves.ENCORE ], [ 1, Moves.COPYCAT ], @@ -2122,7 +2152,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 20, Moves.DOUBLE_HIT ], [ 24, Moves.SLASH ], [ 28, Moves.FOCUS_ENERGY ], - [ 30, Moves.STEEL_WING ], //Custom + [ 30, Moves.STEEL_WING ], // Custom [ 32, Moves.AGILITY ], [ 36, Moves.AIR_SLASH ], [ 40, Moves.X_SCISSOR ], @@ -2279,6 +2309,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.VAPOREON]: [ [ EVOLVE_MOVE, Moves.BOUNCY_BUBBLE ], + [ RELEARN_MOVE, Moves.VEEVEE_VOLLEY ], // Previous Stage Move [ 1, Moves.TACKLE ], [ 1, Moves.TAKE_DOWN ], [ 1, Moves.DOUBLE_EDGE ], @@ -2306,6 +2337,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.JOLTEON]: [ [ EVOLVE_MOVE, Moves.BUZZY_BUZZ ], + [ RELEARN_MOVE, Moves.VEEVEE_VOLLEY ], // Previous Stage Move [ 1, Moves.TACKLE ], [ 1, Moves.TAKE_DOWN ], [ 1, Moves.DOUBLE_EDGE ], @@ -2333,6 +2365,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.FLAREON]: [ [ EVOLVE_MOVE, Moves.SIZZLY_SLIDE ], + [ RELEARN_MOVE, Moves.VEEVEE_VOLLEY ], // Previous Stage Move [ 1, Moves.TACKLE ], [ 1, Moves.TAKE_DOWN ], [ 1, Moves.DOUBLE_EDGE ], @@ -2463,6 +2496,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.SNORLAX]: [ [ 1, Moves.TACKLE ], [ 1, Moves.SCREECH ], + [ 1, Moves.ODOR_SLEUTH ], // Previous Stage Move [ 1, Moves.DEFENSE_CURL ], [ 1, Moves.METRONOME ], [ 1, Moves.LICK ], @@ -2632,7 +2666,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.CHIKORITA]: [ [ 1, Moves.TACKLE ], [ 1, Moves.GROWL ], - [ 5, Moves.RAZOR_LEAF ], //Custom, moved from 6 to 5 + [ 5, Moves.RAZOR_LEAF ], // Custom, moved from 6 to 5 [ 9, Moves.POISON_POWDER ], [ 12, Moves.SYNTHESIS ], [ 17, Moves.REFLECT ], @@ -2682,8 +2716,8 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.CYNDAQUIL]: [ [ 1, Moves.TACKLE ], [ 1, Moves.LEER ], - [ 5, Moves.EMBER ], //Custom, moved from 10 to 5 - [ 10, Moves.SMOKESCREEN ], //Custom, moved from 6 to 10 + [ 5, Moves.EMBER ], // Custom, moved from 10 to 5 + [ 10, Moves.SMOKESCREEN ], // Custom, moved from 6 to 10 [ 13, Moves.QUICK_ATTACK ], [ 19, Moves.FLAME_WHEEL ], [ 22, Moves.DEFENSE_CURL ], @@ -2737,7 +2771,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.TOTODILE]: [ [ 1, Moves.SCRATCH ], [ 1, Moves.LEER ], - [ 5, Moves.WATER_GUN ], //Custom, moved from 6 to 5 + [ 5, Moves.WATER_GUN ], // Custom, moved from 6 to 5 [ 9, Moves.BITE ], [ 13, Moves.SCARY_FACE ], [ 19, Moves.ICE_FANG ], @@ -3149,6 +3183,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.MOONBLAST ], ], [Species.MARILL]: [ + [ 1, Moves.SPLASH ], // Previous Stage Move [ 1, Moves.TACKLE ], [ 1, Moves.TAIL_WHIP ], [ 1, Moves.WATER_GUN ], @@ -3168,6 +3203,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 36, Moves.SUPERPOWER ], ], [Species.AZUMARILL]: [ + [ 1, Moves.SPLASH ], // Previous Stage Move [ 1, Moves.TACKLE ], [ 1, Moves.TAIL_WHIP ], [ 1, Moves.WATER_GUN ], @@ -3189,6 +3225,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.SUDOWOODO]: [ [ EVOLVE_MOVE, Moves.SLAM ], [ 1, Moves.ROCK_THROW ], + [ 1, Moves.TACKLE ], // Previous Stage Move, Custom [ 1, Moves.FLAIL ], [ 1, Moves.FAKE_TEARS ], [ 1, Moves.HAMMER_ARM ], @@ -3222,6 +3259,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.HYDRO_PUMP ], [ 1, Moves.BELLY_DRUM ], [ 1, Moves.POUND ], + [ 1, Moves.WATER_SPORT ], // Previous Stage Move ], [Species.HOPPIP]: [ [ 1, Moves.TACKLE ], @@ -3315,9 +3353,12 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 39, Moves.SEED_BOMB ], ], [Species.SUNFLORA]: [ + [ RELEARN_MOVE, Moves.SEED_BOMB ], // Previous Stage Move [ 1, Moves.POUND ], [ 1, Moves.TACKLE ], [ 1, Moves.GROWTH ], + [ 1, Moves.ENDEAVOR ], // Previous Stage Move + [ 1, Moves.SYNTHESIS ], // Previous Stage Move [ 4, Moves.INGRAIN ], [ 7, Moves.ABSORB ], [ 10, Moves.MEGA_DRAIN ], @@ -3382,6 +3423,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.ESPEON]: [ [ EVOLVE_MOVE, Moves.GLITZY_GLOW ], + [ RELEARN_MOVE, Moves.VEEVEE_VOLLEY ], // Previous Stage Move [ 1, Moves.TACKLE ], [ 1, Moves.TAKE_DOWN ], [ 1, Moves.DOUBLE_EDGE ], @@ -3408,6 +3450,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.UMBREON]: [ [ EVOLVE_MOVE, Moves.BADDY_BAD ], + [ RELEARN_MOVE, Moves.VEEVEE_VOLLEY ], // Previous Stage Move [ 1, Moves.TACKLE ], [ 1, Moves.TAKE_DOWN ], [ 1, Moves.DOUBLE_EDGE ], @@ -3464,6 +3507,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 15, Moves.DISABLE ], [ 18, Moves.WATER_PULSE ], [ 21, Moves.HEADBUTT ], + [ 24, Moves.ZEN_HEADBUTT ], // Previous Stage Move, Galar Slowking Level [ 27, Moves.AMNESIA ], [ 30, Moves.SURF ], [ 33, Moves.SLACK_OFF ], @@ -3562,7 +3606,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.DUNSPARCE]: [ [ 1, Moves.DEFENSE_CURL ], [ 1, Moves.FLAIL ], - [ 1, Moves.TACKLE ], //Custom + [ 1, Moves.TACKLE ], // Custom [ 4, Moves.MUD_SLAP ], [ 8, Moves.ROLLOUT ], [ 12, Moves.GLARE ], @@ -3609,6 +3653,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 12, Moves.DRAGON_BREATH ], [ 16, Moves.CURSE ], [ 20, Moves.ROCK_SLIDE ], + [ 22, Moves.GYRO_BALL ], // Custom from USUM [ 24, Moves.SCREECH ], [ 28, Moves.SAND_TOMB ], [ 32, Moves.STEALTH_ROCK ], @@ -3688,6 +3733,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 20, Moves.DOUBLE_HIT ], [ 24, Moves.SLASH ], [ 28, Moves.FOCUS_ENERGY ], + [ 30, Moves.STEEL_WING ], // Custom [ 32, Moves.IRON_DEFENSE ], [ 36, Moves.IRON_HEAD ], [ 40, Moves.X_SCISSOR ], @@ -3765,8 +3811,11 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.SCRATCH ], [ 1, Moves.LEER ], [ 1, Moves.LICK ], - [ 1, Moves.FAKE_TEARS ], [ 1, Moves.COVET ], + [ 1, Moves.FLING ], // Previous Stage Move + [ 1, Moves.BABY_DOLL_EYES ], // Previous Stage Move + [ 1, Moves.FAKE_TEARS ], + [ 1, Moves.CHARM ], // Previous Stage Move [ 8, Moves.FURY_SWIPES ], [ 13, Moves.PAYBACK ], [ 17, Moves.SWEET_SCENT ], @@ -3783,7 +3832,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.SLUGMA]: [ [ 1, Moves.SMOG ], [ 1, Moves.YAWN ], - [ 5, Moves.EMBER ], //Custom, Moved from Level 6 to 5 + [ 5, Moves.EMBER ], // Custom, Moved from Level 6 to 5 [ 8, Moves.ROCK_THROW ], [ 13, Moves.HARDEN ], [ 20, Moves.CLEAR_SMOG ], @@ -3898,7 +3947,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 48, Moves.SOAK ], [ 54, Moves.HYPER_BEAM ], ], - [Species.DELIBIRD]: [ //Given a custom level up learnset + [Species.DELIBIRD]: [ // Given a custom level up learnset [ 1, Moves.PRESENT ], [ 1, Moves.METRONOME ], [ 5, Moves.FAKE_OUT ], @@ -3991,6 +4040,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 62, Moves.INFERNO ], ], [Species.KINGDRA]: [ + [ RELEARN_MOVE, Moves.LASER_FOCUS ], // Previous Stage Move [ 1, Moves.LEER ], [ 1, Moves.WATER_GUN ], [ 1, Moves.SMOKESCREEN ], @@ -4025,9 +4075,17 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.DONPHAN]: [ [ EVOLVE_MOVE, Moves.FURY_ATTACK ], - [ 1, Moves.HORN_ATTACK ], + [ 1, Moves.TACKLE ], // Previous Stage Move [ 1, Moves.GROWL ], + [ 1, Moves.HORN_ATTACK ], [ 1, Moves.DEFENSE_CURL ], + [ 1, Moves.ODOR_SLEUTH ], // Previous Stage Move + [ 1, Moves.FLAIL ], // Previous Stage Move + [ 1, Moves.ENDURE ], // Previous Stage Move + [ 1, Moves.TAKE_DOWN ], // Previous Stage Move + [ 1, Moves.CHARM ], // Previous Stage Move + [ 1, Moves.LAST_RESORT ], // Previous Stage Move + [ 1, Moves.DOUBLE_EDGE ], // Previous Stage Move [ 1, Moves.THUNDER_FANG ], [ 1, Moves.FIRE_FANG ], [ 1, Moves.BULLDOZE ], @@ -4047,6 +4105,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.CONVERSION ], [ 1, Moves.RECYCLE ], [ 1, Moves.MAGNET_RISE ], + [ 1, Moves.MAGIC_COAT ], // Previous Stage Move [ 15, Moves.THUNDER_SHOCK ], [ 20, Moves.PSYBEAM ], [ 25, Moves.CONVERSION_2 ], @@ -4093,6 +4152,9 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.FOCUS_ENERGY ], [ 1, Moves.FAKE_OUT ], [ 1, Moves.HELPING_HAND ], + [ 10, Moves.LOW_SWEEP ], // Custom + [ 10, Moves.MACH_PUNCH ], // Custom + [ 10, Moves.RAPID_SPIN ], // Custom ], [Species.HITMONTOP]: [ [ EVOLVE_MOVE, Moves.TRIPLE_KICK ], @@ -4104,6 +4166,8 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.FEINT ], [ 1, Moves.PURSUIT ], [ 1, Moves.ROLLING_KICK ], + [ 1, Moves.LOW_SWEEP ], // Previous Stage Move, Custom + [ 1, Moves.MACH_PUNCH ], // Previous Stage Move, Custom [ 4, Moves.QUICK_ATTACK ], [ 8, Moves.GYRO_BALL ], [ 12, Moves.DETECT ], @@ -4513,6 +4577,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.MARSHTOMP]: [ [ EVOLVE_MOVE, Moves.MUD_SHOT ], + [ RELEARN_MOVE, Moves.SURF ], // Previous Stage Move [ RELEARN_MOVE, Moves.ROCK_SMASH ], [ 1, Moves.TACKLE ], [ 1, Moves.GROWL ], @@ -4634,10 +4699,15 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.SILCOON]: [ [ EVOLVE_MOVE, Moves.HARDEN ], + [ RELEARN_MOVE, Moves.TACKLE ], // Previous Stage Move + [ RELEARN_MOVE, Moves.STRING_SHOT ], // Previous Stage Move + [ RELEARN_MOVE, Moves.POISON_STING ], // Previous Stage Move + [ RELEARN_MOVE, Moves.BUG_BITE ], // Previous Stage Move [ 1, Moves.HARDEN ], ], [Species.BEAUTIFLY]: [ [ EVOLVE_MOVE, Moves.GUST ], + [ 1, Moves.TACKLE ], // Previous Stage Move [ 1, Moves.BUG_BITE ], [ 1, Moves.GUST ], [ 1, Moves.HARDEN ], @@ -4658,10 +4728,15 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.CASCOON]: [ [ EVOLVE_MOVE, Moves.HARDEN ], + [ RELEARN_MOVE, Moves.TACKLE ], // Previous Stage Move + [ RELEARN_MOVE, Moves.STRING_SHOT ], // Previous Stage Move + [ RELEARN_MOVE, Moves.POISON_STING ], // Previous Stage Move + [ RELEARN_MOVE, Moves.BUG_BITE ], // Previous Stage Move [ 1, Moves.HARDEN ], ], [Species.DUSTOX]: [ [ EVOLVE_MOVE, Moves.GUST ], + [ 1, Moves.TACKLE ], // Previous Stage Move [ 1, Moves.BUG_BITE ], [ 1, Moves.GUST ], [ 1, Moves.HARDEN ], @@ -4701,6 +4776,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.ABSORB ], [ 1, Moves.FLAIL ], [ 1, Moves.FAKE_OUT ], + [ 1, Moves.RAIN_DANCE ], // Previous Stage Move [ 1, Moves.KNOCK_OFF ], [ 1, Moves.TEETER_DANCE ], [ 1, Moves.ASTONISH ], @@ -4728,6 +4804,8 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ RELEARN_MOVE, Moves.ASTONISH ], [ RELEARN_MOVE, Moves.ENERGY_BALL ], [ RELEARN_MOVE, Moves.ZEN_HEADBUTT ], + [ RELEARN_MOVE, Moves.LEECH_SEED ], // Previous Stage Move + [ RELEARN_MOVE, Moves.GIGA_DRAIN ], // Previous Stage Move [ 1, Moves.FAKE_OUT ], [ 1, Moves.BUBBLE_BEAM ], [ 1, Moves.RAIN_DANCE ], @@ -4757,8 +4835,10 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.EXPLOSION ], [ 1, Moves.TACKLE ], [ 1, Moves.HARDEN ], + [ 1, Moves.BIDE ], // Previous Stage Move [ 1, Moves.ABSORB ], [ 1, Moves.ASTONISH ], + [ 1, Moves.HEADBUTT ], // Previous Stage Move [ 9, Moves.GROWTH ], [ 12, Moves.ROLLOUT ], [ 18, Moves.MEGA_DRAIN ], @@ -4773,11 +4853,13 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ EVOLVE_MOVE, Moves.LEAF_BLADE ], [ RELEARN_MOVE, Moves.WHIRLWIND ], [ RELEARN_MOVE, Moves.TACKLE ], + [ RELEARN_MOVE, Moves.BIDE ], // Previous Stage Move [ RELEARN_MOVE, Moves.ABSORB ], [ RELEARN_MOVE, Moves.MEGA_DRAIN ], [ RELEARN_MOVE, Moves.GROWTH ], [ RELEARN_MOVE, Moves.RAZOR_LEAF ], [ RELEARN_MOVE, Moves.HARDEN ], + [ RELEARN_MOVE, Moves.HEADBUTT ], // Previous Stage Move [ RELEARN_MOVE, Moves.EXPLOSION ], [ RELEARN_MOVE, Moves.ROLLOUT ], [ RELEARN_MOVE, Moves.SWAGGER ], @@ -4930,11 +5012,17 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 38, Moves.STICKY_WEB ], ], [Species.MASQUERAIN]: [ + [ RELEARN_MOVE, Moves.BATON_PASS ], // Previous Stage Move + [ RELEARN_MOVE, Moves.STICKY_WEB ], // Previous Stage Move [ 1, Moves.WHIRLWIND ], [ 1, Moves.WATER_GUN ], [ 1, Moves.QUICK_ATTACK ], [ 1, Moves.SWEET_SCENT ], [ 1, Moves.SOAK ], + [ 1, Moves.BUBBLE_BEAM ], // Previous Stage Move + [ 1, Moves.AGILITY ], // Previous Stage Move + [ 1, Moves.MIST ], // Previous Stage Move + [ 1, Moves.HAZE ], // Previous Stage Move [ 1, Moves.OMINOUS_WIND ], [ 17, Moves.GUST ], [ 22, Moves.SCARY_FACE ], @@ -4963,6 +5051,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ EVOLVE_MOVE, Moves.MACH_PUNCH ], [ RELEARN_MOVE, Moves.SPORE ], [ 1, Moves.POISON_POWDER ], + [ 1, Moves.GIGA_DRAIN ], // Previous Stage Move [ 1, Moves.GROWTH ], [ 1, Moves.TOXIC ], [ 1, Moves.ABSORB ], @@ -4994,9 +5083,16 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 38, Moves.PLAY_ROUGH ], ], [Species.VIGOROTH]: [ + [ RELEARN_MOVE, Moves.PLAY_ROUGH ], // Previous Stage Move [ 1, Moves.SCRATCH ], + [ 1, Moves.YAWN ], // Previous Stage Move [ 1, Moves.FOCUS_ENERGY ], + [ 1, Moves.SLACK_OFF ], // Previous Stage Move [ 1, Moves.ENCORE ], + [ 1, Moves.HEADBUTT ], // Previous Stage Move + [ 1, Moves.AMNESIA ], // Previous Stage Move + [ 1, Moves.COVET ], // Previous Stage Move + [ 1, Moves.FLAIL ], // Previous Stage Move [ 1, Moves.UPROAR ], [ 14, Moves.FURY_SWIPES ], [ 17, Moves.ENDURE ], @@ -5008,11 +5104,20 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.SLAKING]: [ [ EVOLVE_MOVE, Moves.SWAGGER ], + [ RELEARN_MOVE, Moves.PLAY_ROUGH ], // Previous Stage Move + [ RELEARN_MOVE, Moves.FOCUS_PUNCH ], // Previous Stage Move [ 1, Moves.SUCKER_PUNCH ], [ 1, Moves.SCRATCH ], [ 1, Moves.YAWN ], + [ 1, Moves.FOCUS_ENERGY ], // Previous Stage Move [ 1, Moves.ENCORE ], [ 1, Moves.SLACK_OFF ], + [ 1, Moves.UPROAR ], // Previous Stage Move + [ 1, Moves.FURY_SWIPES ], // Previous Stage Move + [ 1, Moves.ENDURE ], // Previous Stage Move + [ 1, Moves.HEADBUTT ], // Previous Stage Move + [ 1, Moves.SLASH ], // Previous Stage Move + [ 1, Moves.REVERSAL ], // Previous Stage Move [ 17, Moves.AMNESIA ], [ 23, Moves.COVET ], [ 27, Moves.THROAT_CHOP ], @@ -5148,6 +5253,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.BRINE ], [ 1, Moves.TACKLE ], [ 1, Moves.FOCUS_ENERGY ], + [ 1, Moves.SAND_ATTACK ], // Previous Stage Move [ 1, Moves.ARM_THRUST ], [ 10, Moves.FAKE_OUT ], [ 13, Moves.FORCE_PALM ], @@ -5351,6 +5457,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.DETECT ], [ 1, Moves.WORK_UP ], [ 1, Moves.BIDE ], + [ 1, Moves.REVERSAL ], // Previous Stage Move [ 12, Moves.ENDURE ], [ 15, Moves.FEINT ], [ 17, Moves.FORCE_PALM ], @@ -5520,6 +5627,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.POISON_GAS ], [ 1, Moves.WRING_OUT ], [ 1, Moves.SLUDGE ], + [ 1, Moves.PAIN_SPLIT ], // Previous Stage Move [ 12, Moves.AMNESIA ], [ 17, Moves.ACID_SPRAY ], [ 20, Moves.ENCORE ], @@ -5565,7 +5673,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.WAILMER]: [ [ 1, Moves.SPLASH ], - [ 1, Moves.TACKLE ], //Custom + [ 1, Moves.TACKLE ], // Custom [ 3, Moves.GROWL ], [ 6, Moves.ASTONISH ], [ 12, Moves.WATER_GUN ], @@ -5586,6 +5694,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.SOAK ], [ 1, Moves.NOBLE_ROAR ], [ 1, Moves.SPLASH ], + [ 1, Moves.TACKLE ], // Previous Stage Move, Custom [ 1, Moves.GROWL ], [ 1, Moves.ASTONISH ], [ 1, Moves.WATER_GUN ], @@ -5620,6 +5729,8 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.CAMERUPT]: [ [ EVOLVE_MOVE, Moves.ROCK_SLIDE ], + [ RELEARN_MOVE, Moves.FLAMETHROWER ], // Previous Stage Move + [ RELEARN_MOVE, Moves.DOUBLE_EDGE ], // Previous Stage Move [ 1, Moves.FISSURE ], [ 1, Moves.ERUPTION ], [ 1, Moves.GROWL ], @@ -5658,7 +5769,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.SPOINK]: [ [ 1, Moves.SPLASH ], - [ 5, Moves.CONFUSION ], //Custom, Moved from Level 7 to 5 + [ 5, Moves.CONFUSION ], // Custom, Moved from Level 7 to 5 [ 10, Moves.GROWL ], [ 14, Moves.PSYBEAM ], [ 18, Moves.PSYCH_UP ], @@ -5676,6 +5787,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.BELCH ], [ 1, Moves.SPLASH ], [ 1, Moves.CONFUSION ], + [ 1, Moves.GROWL ], // Previous Stage Move [ 1, Moves.PSYBEAM ], [ 18, Moves.PSYCH_UP ], [ 22, Moves.CONFUSE_RAY ], @@ -6167,7 +6279,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.SHUPPET]: [ [ 1, Moves.ASTONISH ], - [ 1, Moves.PURSUIT ], //Custom + [ 1, Moves.PURSUIT ], // Custom [ 4, Moves.SCREECH ], [ 7, Moves.NIGHT_SHADE ], [ 10, Moves.SPITE ], @@ -6183,6 +6295,8 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.BANETTE]: [ [ EVOLVE_MOVE, Moves.KNOCK_OFF ], + [ 1, Moves.ASTONISH ], // Previous Stage Move + [ 1, Moves.PURSUIT ], // Previous Stage Move, Custom [ 1, Moves.SCREECH ], [ 1, Moves.NIGHT_SHADE ], [ 1, Moves.SPITE ], @@ -6199,7 +6313,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.DUSKULL]: [ [ 1, Moves.ASTONISH ], [ 1, Moves.LEER ], - [ 1, Moves.PURSUIT ], //Custom + [ 1, Moves.PURSUIT ], // Custom [ 4, Moves.DISABLE ], [ 8, Moves.SHADOW_SNEAK ], [ 12, Moves.CONFUSE_RAY ], @@ -6221,6 +6335,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.BIND ], [ 1, Moves.ASTONISH ], [ 1, Moves.LEER ], + [ 1, Moves.PURSUIT ], // Previous Stage Move, Custom [ 1, Moves.DISABLE ], [ 1, Moves.SHADOW_SNEAK ], [ 12, Moves.CONFUSE_RAY ], @@ -6252,7 +6367,10 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.CHIMECHO]: [ [ 1, Moves.HEALING_WISH ], + [ 1, Moves.LAST_RESORT ], // Previous Stage Move + [ 1, Moves.ENTRAINMENT ], // Previous Stage Move [ 1, Moves.WRAP ], + [ 1, Moves.PSYWAVE ], // Previous Stage Move, Custom [ 1, Moves.GROWL ], [ 1, Moves.ASTONISH ], [ 1, Moves.CONFUSION ], @@ -6392,6 +6510,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 50, Moves.SHELL_SMASH ], ], [Species.HUNTAIL]: [ + [ 1, Moves.CLAMP ], // Previous Stage Move [ 1, Moves.WATER_GUN ], [ 1, Moves.IRON_DEFENSE ], [ 1, Moves.SHELL_SMASH ], @@ -6412,6 +6531,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 50, Moves.HYDRO_PUMP ], ], [Species.GOREBYSS]: [ + [ 1, Moves.CLAMP ], // Previous Stage Move [ 1, Moves.WATER_GUN ], [ 1, Moves.IRON_DEFENSE ], [ 1, Moves.SHELL_SMASH ], @@ -6497,6 +6617,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.SALAMENCE]: [ [ EVOLVE_MOVE, Moves.FLY ], + [ RELEARN_MOVE, Moves.OUTRAGE ], // Previous Stage Move [ 1, Moves.PROTECT ], [ 1, Moves.DRAGON_TAIL ], [ 1, Moves.DUAL_WINGBEAT ], @@ -6712,7 +6833,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 98, Moves.DOOM_DESIRE ], ], [Species.DEOXYS]: [ - [ 1, Moves.CONFUSION ], //Custom + [ 1, Moves.CONFUSION ], // Custom [ 1, Moves.LEER ], [ 1, Moves.WRAP ], [ 7, Moves.NIGHT_SHADE ], @@ -6731,8 +6852,8 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.TURTWIG]: [ [ 1, Moves.TACKLE ], [ 5, Moves.WITHDRAW ], - [ 5, Moves.LEAFAGE ], //Custom, moved from 10 to 5, BDSP - [ 9, Moves.GROWTH ], //Fill empty moveslot, from BDSP level 6 + [ 5, Moves.LEAFAGE ], // Custom, moved from 10 to 5, BDSP + [ 9, Moves.GROWTH ], // Fill empty moveslot, from BDSP level 6 [ 13, Moves.RAZOR_LEAF ], [ 17, Moves.CURSE ], [ 21, Moves.BITE ], @@ -6748,6 +6869,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.ABSORB ], [ 1, Moves.WITHDRAW ], [ 1, Moves.LEAFAGE ], + [ 1, Moves.GROWTH ], // Previous Stage Move [ 13, Moves.RAZOR_LEAF ], [ 17, Moves.CURSE ], [ 22, Moves.BITE ], @@ -6763,6 +6885,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.TACKLE ], [ 1, Moves.ABSORB ], [ 1, Moves.LEAFAGE ], + [ 1, Moves.GROWTH ], // Previous Stage Move [ 1, Moves.RAZOR_LEAF ], [ 1, Moves.WITHDRAW ], [ 1, Moves.WOOD_HAMMER ], @@ -6779,7 +6902,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.CHIMCHAR]: [ [ 1, Moves.SCRATCH ], [ 1, Moves.LEER ], - [ 5, Moves.EMBER ], //Custom, moved from 7 to 5 + [ 5, Moves.EMBER ], // Custom, moved from 7 to 5 [ 9, Moves.TAUNT ], [ 15, Moves.FURY_SWIPES ], [ 17, Moves.FLAME_WHEEL ], @@ -6793,6 +6916,9 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.MONFERNO]: [ [ EVOLVE_MOVE, Moves.MACH_PUNCH ], + [ RELEARN_MOVE, Moves.NASTY_PLOT ], // Previous Stage Move + [ RELEARN_MOVE, Moves.FACADE ], // Previous Stage Move + [ RELEARN_MOVE, Moves.FLAMETHROWER ], // Previous Stage Move [ 1, Moves.SCRATCH ], [ 1, Moves.LEER ], [ 1, Moves.EMBER ], @@ -6810,7 +6936,10 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.INFERNAPE]: [ [ EVOLVE_MOVE, Moves.CLOSE_COMBAT ], [ RELEARN_MOVE, Moves.TAUNT ], + [ RELEARN_MOVE, Moves.NASTY_PLOT ], // Previous Stage Move + [ RELEARN_MOVE, Moves.FACADE ], // Previous Stage Move [ RELEARN_MOVE, Moves.SLACK_OFF ], + [ RELEARN_MOVE, Moves.FLAMETHROWER ], // Previous Stage Move [ 1, Moves.SCRATCH ], [ 1, Moves.LEER ], [ 1, Moves.EMBER ], @@ -6828,7 +6957,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.PIPLUP]: [ [ 1, Moves.POUND ], [ 4, Moves.GROWL ], - [ 5, Moves.WATER_GUN ], //Custom, moved from 8 to 5 + [ 5, Moves.WATER_GUN ], // Custom, moved from 8 to 5 [ 11, Moves.CHARM ], [ 15, Moves.PECK ], [ 18, Moves.BUBBLE_BEAM ], @@ -6845,6 +6974,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.TACKLE ], [ 1, Moves.GROWL ], [ 1, Moves.WATER_GUN ], + [ 1, Moves.CHARM ], // Previous Stage Move [ 15, Moves.PECK ], [ 19, Moves.BUBBLE_BEAM ], [ 24, Moves.SWAGGER ], @@ -6860,6 +6990,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.TACKLE ], [ 1, Moves.GROWL ], [ 1, Moves.WATER_GUN ], + [ 1, Moves.CHARM ], // Previous Stage Move [ 1, Moves.METAL_CLAW ], [ 11, Moves.SWORDS_DANCE ], [ 15, Moves.PECK ], @@ -6963,6 +7094,8 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.TACKLE ], [ 1, Moves.GROWL ], [ 1, Moves.BIDE ], + [ 1, Moves.STRUGGLE_BUG ], // Previous Stage Move + [ 1, Moves.BUG_BITE ], // Previous Stage Move [ 14, Moves.ABSORB ], [ 18, Moves.SING ], [ 22, Moves.FOCUS_ENERGY ], @@ -7113,13 +7246,14 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.BURMY]: [ [ 1, Moves.PROTECT ], - [ 1, Moves.STRUGGLE_BUG ], //Custom + [ 1, Moves.STRUGGLE_BUG ], // Custom [ 10, Moves.TACKLE ], [ 15, Moves.BUG_BITE ], [ 20, Moves.STRING_SHOT ], ], [Species.WORMADAM]: [ [ EVOLVE_MOVE, Moves.QUIVER_DANCE ], + [ 1, Moves.STRUGGLE_BUG ], // Previous Stage Move, Custom [ 1, Moves.TACKLE ], [ 1, Moves.PROTECT ], [ 1, Moves.SUCKER_PUNCH ], @@ -7140,6 +7274,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.MOTHIM]: [ [ EVOLVE_MOVE, Moves.QUIVER_DANCE ], + [ 1, Moves.STRUGGLE_BUG ], // Previous Stage Move [ 1, Moves.TACKLE ], [ 1, Moves.PROTECT ], [ 1, Moves.BUG_BITE ], @@ -7221,6 +7356,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 49, Moves.WAVE_CRASH ], ], [Species.FLOATZEL]: [ + [ 1, Moves.TACKLE ], // Previous Stage Move [ 1, Moves.GROWL ], [ 1, Moves.QUICK_ATTACK ], [ 1, Moves.CRUNCH ], @@ -7368,6 +7504,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.LOPUNNY]: [ [ EVOLVE_MOVE, Moves.RETURN ], + [ 1, Moves.FRUSTRATION ], // Previous Stage Move [ 1, Moves.POUND ], [ 1, Moves.DEFENSE_CURL ], [ 1, Moves.SPLASH ], @@ -7389,6 +7526,16 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 56, Moves.HIGH_JUMP_KICK ], ], [Species.MISMAGIUS]: [ + // Previous Stage Relearn Learnset + [ RELEARN_MOVE, Moves.CONFUSION ], + [ RELEARN_MOVE, Moves.CONFUSE_RAY ], + [ RELEARN_MOVE, Moves.MEAN_LOOK ], + [ RELEARN_MOVE, Moves.HEX ], + [ RELEARN_MOVE, Moves.PSYBEAM ], + [ RELEARN_MOVE, Moves.PAIN_SPLIT ], + [ RELEARN_MOVE, Moves.PAYBACK ], + [ RELEARN_MOVE, Moves.SHADOW_BALL ], + [ RELEARN_MOVE, Moves.PERISH_SONG ], [ 1, Moves.GROWL ], [ 1, Moves.SPITE ], [ 1, Moves.PSYWAVE ], @@ -7400,11 +7547,18 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.MYSTICAL_FIRE ], ], [Species.HONCHKROW]: [ - [ 1, Moves.WING_ATTACK ], - [ 1, Moves.HAZE ], + [ 1, Moves.PECK ], // Previous Stage Move [ 1, Moves.ASTONISH ], + [ 1, Moves.GUST ], // Previous Stage Move + [ 1, Moves.HAZE ], + [ 1, Moves.WING_ATTACK ], + [ 1, Moves.NIGHT_SHADE ], // Previous Stage Move + [ 1, Moves.ASSURANCE ], // Previous Stage Move + [ 1, Moves.TAUNT ], // Previous Stage Move + [ 1, Moves.MEAN_LOOK ], // Previous Stage Move [ 1, Moves.SUCKER_PUNCH ], [ 1, Moves.NIGHT_SLASH ], + [ 1, Moves.TORMENT ], // Previous Stage Move [ 1, Moves.QUASH ], [ 1, Moves.PURSUIT ], [ 25, Moves.SWAGGER ], @@ -7449,7 +7603,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.CHINGLING]: [ [ 1, Moves.WRAP ], - [ 1, Moves.PSYWAVE ], //Custom + [ 1, Moves.PSYWAVE ], // Custom [ 4, Moves.GROWL ], [ 7, Moves.ASTONISH ], [ 10, Moves.CONFUSION ], @@ -7482,6 +7636,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.SMOKESCREEN ], [ 1, Moves.POISON_GAS ], [ 1, Moves.FEINT ], + [ 1, Moves.ACID_SPRAY ], // Previous Stage Move [ 12, Moves.FURY_SWIPES ], [ 15, Moves.FOCUS_ENERGY ], [ 18, Moves.BITE ], @@ -7533,7 +7688,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.BONSLY]: [ [ 1, Moves.FAKE_TEARS ], [ 1, Moves.COPYCAT ], - [ 1, Moves.TACKLE ], //Custom + [ 1, Moves.TACKLE ], // Custom [ 4, Moves.FLAIL ], [ 8, Moves.ROCK_THROW ], [ 12, Moves.BLOCK ], @@ -7554,11 +7709,11 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 4, Moves.BATON_PASS ], [ 8, Moves.ENCORE ], [ 12, Moves.CONFUSION ], - [ 16, Moves.MIMIC ], //Custom, swapped with Role Play to be closer to USUM + [ 16, Moves.MIMIC ], // Custom, swapped with Role Play to be closer to USUM [ 20, Moves.PROTECT ], [ 24, Moves.RECYCLE ], [ 28, Moves.PSYBEAM ], - [ 32, Moves.ROLE_PLAY ], //Custom, swapped with Mimic + [ 32, Moves.ROLE_PLAY ], // Custom, swapped with Mimic [ 36, Moves.LIGHT_SCREEN ], [ 36, Moves.REFLECT ], [ 36, Moves.SAFEGUARD ], @@ -7696,6 +7851,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.LUCARIO]: [ [ EVOLVE_MOVE, Moves.AURA_SPHERE ], [ 1, Moves.QUICK_ATTACK ], + [ 1, Moves.ENDURE ], // Previous Stage Move [ 1, Moves.SCREECH ], [ 1, Moves.REVERSAL ], [ 1, Moves.DETECT ], @@ -7836,7 +7992,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.CARNIVINE]: [ [ 1, Moves.BIND ], [ 1, Moves.GROWTH ], - [ 1, Moves.LEAFAGE ], //Custom + [ 1, Moves.LEAFAGE ], // Custom [ 7, Moves.BITE ], [ 11, Moves.VINE_WHIP ], [ 17, Moves.SWEET_SCENT ], @@ -7973,6 +8129,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.SUPERSONIC ], [ 1, Moves.DEFENSE_CURL ], [ 1, Moves.LICK ], + [ 1, Moves.TACKLE ], // Previous Stage Move, Custom [ 1, Moves.ROLLOUT ], [ 1, Moves.WRING_OUT ], [ 6, Moves.REST ], @@ -8086,7 +8243,9 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ RELEARN_MOVE, Moves.HYPNOSIS ], [ 1, Moves.TACKLE ], [ 1, Moves.DOUBLE_TEAM ], + [ 1, Moves.AIR_CUTTER ], // Previous Stage Move [ 1, Moves.NIGHT_SLASH ], + [ 1, Moves.WING_ATTACK ], // Previous Stage Move [ 1, Moves.AIR_SLASH ], [ 1, Moves.BUG_BUZZ ], [ 14, Moves.QUICK_ATTACK ], @@ -8102,6 +8261,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.LEAFEON]: [ [ EVOLVE_MOVE, Moves.SAPPY_SEED ], + [ RELEARN_MOVE, Moves.VEEVEE_VOLLEY ], // Previous Stage Move [ 1, Moves.TACKLE ], [ 1, Moves.TAKE_DOWN ], [ 1, Moves.DOUBLE_EDGE ], @@ -8129,6 +8289,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.GLACEON]: [ [ EVOLVE_MOVE, Moves.FREEZY_FROST ], + [ RELEARN_MOVE, Moves.VEEVEE_VOLLEY ], // Previous Stage Move [ 1, Moves.TACKLE ], [ 1, Moves.TAKE_DOWN ], [ 1, Moves.DOUBLE_EDGE ], @@ -8154,8 +8315,11 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 60, Moves.LAST_RESORT ], ], [Species.GLISCOR]: [ + [ 1, Moves.POISON_STING ], // Previous Stage Move [ 1, Moves.SAND_ATTACK ], [ 1, Moves.HARDEN ], + [ 1, Moves.POISON_TAIL ], // Previous Stage Move + [ 1, Moves.SLASH ], // Previous Stage Move [ 1, Moves.POISON_JAB ], [ 1, Moves.THUNDER_FANG ], [ 1, Moves.ICE_FANG ], @@ -8248,8 +8412,10 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.PROBOPASS]: [ [ EVOLVE_MOVE, Moves.TRI_ATTACK ], [ 1, Moves.TACKLE ], + [ 1, Moves.HARDEN ], // Previous Stage Move [ 1, Moves.IRON_DEFENSE ], [ 1, Moves.BLOCK ], + [ 1, Moves.ROCK_THROW ], // Previous Stage Move [ 1, Moves.GRAVITY ], [ 1, Moves.MAGNET_RISE ], [ 1, Moves.WIDE_GUARD ], @@ -8275,6 +8441,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.LEER ], [ 1, Moves.DISABLE ], [ 1, Moves.ASTONISH ], + [ 1, Moves.PURSUIT ], // Previous Stage Move, Custom [ 1, Moves.SHADOW_PUNCH ], [ 1, Moves.GRAVITY ], [ 1, Moves.SHADOW_SNEAK ], @@ -8298,6 +8465,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.POWDER_SNOW ], [ 1, Moves.PROTECT ], [ 1, Moves.DESTINY_BOND ], + [ 1, Moves.WEATHER_BALL ], // Previous Stage Move [ 1, Moves.CRUNCH ], [ 1, Moves.ASTONISH ], [ 1, Moves.ICE_FANG ], @@ -8538,7 +8706,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.DARKRAI]: [ [ 1, Moves.DISABLE ], [ 1, Moves.OMINOUS_WIND ], - [ 1, Moves.PURSUIT ], //Custom + [ 1, Moves.PURSUIT ], // Custom [ 11, Moves.QUICK_ATTACK ], [ 20, Moves.HYPNOSIS ], [ 29, Moves.SUCKER_PUNCH ], @@ -8551,7 +8719,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 93, Moves.DARK_PULSE ], ], [Species.SHAYMIN]: [ - [ 1, Moves.LEAFAGE ], //Custom + [ 1, Moves.LEAFAGE ], // Custom [ 1, Moves.GROWTH ], [ 10, Moves.MAGICAL_LEAF ], [ 19, Moves.LEECH_SEED ], @@ -8603,7 +8771,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.SNIVY]: [ [ 1, Moves.TACKLE ], [ 4, Moves.LEER ], - [ 5, Moves.VINE_WHIP ], //Custom, moved from 7 to 5 + [ 5, Moves.VINE_WHIP ], // Custom, moved from 7 to 5 [ 10, Moves.WRAP ], [ 13, Moves.GROWTH ], [ 16, Moves.MAGICAL_LEAF ], @@ -8651,7 +8819,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.TEPIG]: [ [ 1, Moves.TACKLE ], [ 3, Moves.TAIL_WHIP ], - [ 5, Moves.EMBER ], //Custom, moved from 7 to 5 + [ 5, Moves.EMBER ], // Custom, moved from 7 to 5 [ 9, Moves.ENDURE ], [ 13, Moves.DEFENSE_CURL ], [ 15, Moves.FLAME_CHARGE ], @@ -8705,7 +8873,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.OSHAWOTT]: [ [ 1, Moves.TACKLE ], [ 5, Moves.TAIL_WHIP ], - [ 5, Moves.WATER_GUN ], //Custom, moved from 7 to 5 + [ 5, Moves.WATER_GUN ], // Custom, moved from 7 to 5 [ 11, Moves.SOAK ], [ 13, Moves.FOCUS_ENERGY ], [ 17, Moves.RAZOR_SHELL ], @@ -8776,6 +8944,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.WATCHOG]: [ [ EVOLVE_MOVE, Moves.CONFUSE_RAY ], + [ RELEARN_MOVE, Moves.WORK_UP ], // Previous Stage Move [ 1, Moves.TACKLE ], [ 1, Moves.LEER ], [ 1, Moves.BITE ], @@ -8895,6 +9064,19 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 43, Moves.CRUNCH ], ], [Species.SIMISAGE]: [ + // Previous Stage Relearn Learnset + [ RELEARN_MOVE, Moves.SCRATCH ], + [ RELEARN_MOVE, Moves.PLAY_NICE ], + [ RELEARN_MOVE, Moves.VINE_WHIP ], + [ RELEARN_MOVE, Moves.LEECH_SEED ], + [ RELEARN_MOVE, Moves.BITE ], + [ RELEARN_MOVE, Moves.TORMENT ], + [ RELEARN_MOVE, Moves.FLING ], + [ RELEARN_MOVE, Moves.ACROBATICS ], + [ RELEARN_MOVE, Moves.GRASS_KNOT ], + [ RELEARN_MOVE, Moves.RECYCLE ], + [ RELEARN_MOVE, Moves.NATURAL_GIFT ], + [ RELEARN_MOVE, Moves.CRUNCH ], [ 1, Moves.LEER ], [ 1, Moves.LICK ], [ 1, Moves.FURY_SWIPES ], @@ -8919,6 +9101,19 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 43, Moves.CRUNCH ], ], [Species.SIMISEAR]: [ + // Previous Stage Relearn Learnset + [ RELEARN_MOVE, Moves.SCRATCH ], + [ RELEARN_MOVE, Moves.PLAY_NICE ], + [ RELEARN_MOVE, Moves.INCINERATE ], + [ RELEARN_MOVE, Moves.YAWN ], + [ RELEARN_MOVE, Moves.BITE ], + [ RELEARN_MOVE, Moves.AMNESIA ], + [ RELEARN_MOVE, Moves.FLING ], + [ RELEARN_MOVE, Moves.ACROBATICS ], + [ RELEARN_MOVE, Moves.FIRE_BLAST ], + [ RELEARN_MOVE, Moves.RECYCLE ], + [ RELEARN_MOVE, Moves.NATURAL_GIFT ], + [ RELEARN_MOVE, Moves.CRUNCH ], [ 1, Moves.LEER ], [ 1, Moves.LICK ], [ 1, Moves.FURY_SWIPES ], @@ -8943,6 +9138,19 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 43, Moves.CRUNCH ], ], [Species.SIMIPOUR]: [ + // Previous Stage Relearn Learnset + [ RELEARN_MOVE, Moves.SCRATCH ], + [ RELEARN_MOVE, Moves.PLAY_NICE ], + [ RELEARN_MOVE, Moves.WATER_GUN ], + [ RELEARN_MOVE, Moves.WATER_SPORT ], + [ RELEARN_MOVE, Moves.BITE ], + [ RELEARN_MOVE, Moves.TAUNT ], + [ RELEARN_MOVE, Moves.FLING ], + [ RELEARN_MOVE, Moves.ACROBATICS ], + [ RELEARN_MOVE, Moves.BRINE ], + [ RELEARN_MOVE, Moves.RECYCLE ], + [ RELEARN_MOVE, Moves.NATURAL_GIFT ], + [ RELEARN_MOVE, Moves.CRUNCH ], [ 1, Moves.LEER ], [ 1, Moves.LICK ], [ 1, Moves.FURY_SWIPES ], @@ -8967,6 +9175,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 52, Moves.WONDER_ROOM ], ], [Species.MUSHARNA]: [ + [ 1, Moves.PSYWAVE ], // Previous Stage Move [ 1, Moves.PSYBEAM ], [ 1, Moves.PSYCHIC ], [ 1, Moves.HYPNOSIS ], @@ -9295,7 +9504,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 70, Moves.HYDRO_PUMP ], ], [Species.THROH]: [ - [ 1, Moves.ROCK_SMASH ], //Custom + [ 1, Moves.ROCK_SMASH ], // Custom [ 1, Moves.LEER ], [ 1, Moves.BIDE ], [ 1, Moves.MAT_BLOCK ], @@ -9355,9 +9564,15 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.LEAVANNY]: [ [ EVOLVE_MOVE, Moves.SLASH ], [ RELEARN_MOVE, Moves.BUG_BITE ], + [ RELEARN_MOVE, Moves.STICKY_WEB ], // Previous Stage Move + [ RELEARN_MOVE, Moves.BUG_BUZZ ], // Previous Stage Move + [ 1, Moves.PROTECT ], // Previous Stage Move [ 1, Moves.TACKLE ], [ 1, Moves.RAZOR_LEAF ], [ 1, Moves.STRING_SHOT ], + [ 1, Moves.GRASS_WHISTLE ], // Previous Stage Move + [ 1, Moves.ENDURE ], // Previous Stage Move + [ 1, Moves.FLAIL ], // Previous Stage Move [ 1, Moves.FALSE_SWIPE ], [ 22, Moves.STRUGGLE_BUG ], [ 29, Moves.FELL_STINGER ], @@ -9890,6 +10105,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.TORMENT ], [ 1, Moves.U_TURN ], [ 1, Moves.HONE_CLAWS ], + [ 1, Moves.SCARY_FACE ], // Previous Stage Move [ 1, Moves.PURSUIT ], [ 12, Moves.FURY_SWIPES ], [ 20, Moves.TAUNT ], @@ -9964,6 +10180,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 28, Moves.FAKE_TEARS ], [ 34, Moves.HEAL_BLOCK ], [ 35, Moves.PSYCH_UP ], + [ 40, Moves.PSYCHIC ], // Previous Stage Move, Gothitelle Level [ 46, Moves.FLATTER ], [ 52, Moves.FUTURE_SIGHT ], [ 58, Moves.MAGIC_ROOM ], @@ -10081,7 +10298,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.VANILLITE]: [ [ 1, Moves.HARDEN ], [ 1, Moves.ASTONISH ], - [ 1, Moves.POWDER_SNOW ], //Custom + [ 1, Moves.POWDER_SNOW ], // Custom [ 4, Moves.TAUNT ], [ 8, Moves.MIST ], [ 12, Moves.ICY_WIND ], @@ -10100,6 +10317,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.HARDEN ], [ 1, Moves.TAUNT ], [ 1, Moves.ASTONISH ], + [ 1, Moves.POWDER_SNOW ], // Previous Stage Move, Custom [ 12, Moves.ICY_WIND ], [ 16, Moves.AVALANCHE ], [ 20, Moves.HAIL ], @@ -10116,6 +10334,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.HARDEN ], [ 1, Moves.TAUNT ], [ 1, Moves.ASTONISH ], + [ 1, Moves.POWDER_SNOW ], // Previous Stage Move, Custom [ 1, Moves.WEATHER_BALL ], [ 1, Moves.ICICLE_CRASH ], [ 1, Moves.FREEZE_DRY ], @@ -10428,6 +10647,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.EELEKTRIK]: [ [ EVOLVE_MOVE, Moves.CRUNCH ], + [ 1, Moves.TACKLE ], // Previous Stage Move [ 1, Moves.HEADBUTT ], [ 1, Moves.THUNDER_WAVE ], [ 1, Moves.SPARK ], @@ -10445,7 +10665,15 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 74, Moves.THRASH ], ], [Species.EELEKTROSS]: [ + [ RELEARN_MOVE, Moves.THUNDERBOLT ], // Previous Stage Move + [ RELEARN_MOVE, Moves.ACID_SPRAY ], // Previous Stage Move + [ 1, Moves.TACKLE ], // Previous Stage Move [ 1, Moves.HEADBUTT ], + [ 1, Moves.THUNDER_WAVE ], // Previous Stage Move + [ 1, Moves.SPARK ], // Previous Stage Move + [ 1, Moves.CHARGE_BEAM ], // Previous Stage Move + [ 1, Moves.ION_DELUGE ], // Previous Stage Move + [ 1, Moves.BIND ], // Previous Stage Move [ 1, Moves.THRASH ], [ 1, Moves.ACID ], [ 1, Moves.ZAP_CANNON ], @@ -10688,6 +10916,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.BODY_SLAM ], [ 1, Moves.ACID ], [ 1, Moves.ABSORB ], + [ 1, Moves.PROTECT ], // Previous Stage Move [ 1, Moves.QUICK_ATTACK ], [ 1, Moves.DOUBLE_TEAM ], [ 1, Moves.ACID_ARMOR ], @@ -10881,6 +11110,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.BRAVIARY]: [ [ EVOLVE_MOVE, Moves.SUPERPOWER ], + [ RELEARN_MOVE, Moves.BRAVE_BIRD ], // Previous Stage Move [ 1, Moves.WING_ATTACK ], [ 1, Moves.LEER ], [ 1, Moves.PECK ], @@ -11422,6 +11652,10 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.GROWL ], [ 1, Moves.WATER_GUN ], [ 1, Moves.QUICK_ATTACK ], + [ 1, Moves.ROUND ], // Previous Stage Move + [ 1, Moves.FLING ], // Previous Stage Move + [ 1, Moves.SMACK_DOWN ], // Previous Stage Move + [ 1, Moves.BOUNCE ], // Previous Stage Move [ 1, Moves.HAZE ], [ 1, Moves.MAT_BLOCK ], [ 1, Moves.ROLE_PLAY ], @@ -11529,10 +11763,19 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.SPEWPA]: [ [ EVOLVE_MOVE, Moves.PROTECT ], + [ RELEARN_MOVE, Moves.TACKLE ], // Previous Stage Move + [ RELEARN_MOVE, Moves.STRING_SHOT ], // Previous Stage Move + [ RELEARN_MOVE, Moves.STUN_SPORE ], // Previous Stage Move + [ RELEARN_MOVE, Moves.BUG_BITE ], // Previous Stage Move [ 1, Moves.HARDEN ], ], [Species.VIVILLON]: [ [ EVOLVE_MOVE, Moves.GUST ], + [ 1, Moves.PROTECT ], // Previous Stage Move + [ 1, Moves.TACKLE ], // Previous Stage Move + [ 1, Moves.STRING_SHOT ], // Previous Stage Move + [ 1, Moves.HARDEN ], // Previous Stage Move + [ 1, Moves.BUG_BITE ], // Previous Stage Move [ 1, Moves.POISON_POWDER ], [ 1, Moves.STUN_SPORE ], [ 1, Moves.SLEEP_POWDER ], @@ -11615,6 +11858,10 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 58, Moves.SOLAR_BEAM ], ], [Species.FLORGES]: [ + [ 1, Moves.VINE_WHIP ], // Previous Stage Move + [ 1, Moves.TACKLE ], // Previous Stage Move + [ 1, Moves.FAIRY_WIND ], // Previous Stage Move + [ 1, Moves.RAZOR_LEAF ], // Previous Stage Move [ 1, Moves.SOLAR_BEAM ], [ 1, Moves.PETAL_DANCE ], [ 1, Moves.SAFEGUARD ], @@ -12106,6 +12353,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.SYLVEON]: [ [ EVOLVE_MOVE, Moves.SPARKLY_SWIRL ], + [ RELEARN_MOVE, Moves.VEEVEE_VOLLEY ], // Previous Stage Move [ 1, Moves.TACKLE ], [ 1, Moves.TAKE_DOWN ], [ 1, Moves.DOUBLE_EDGE ], @@ -12216,6 +12464,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.TACKLE ], [ 1, Moves.WATER_GUN ], [ 1, Moves.ABSORB ], + [ 1, Moves.ACID_ARMOR ], // Previous Stage Move [ 1, Moves.DRAGON_BREATH ], [ 1, Moves.POISON_TAIL ], [ 1, Moves.FEINT ], @@ -12225,6 +12474,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 20, Moves.FLAIL ], [ 25, Moves.WATER_PULSE ], [ 30, Moves.RAIN_DANCE ], + [ 35, Moves.DRAGON_PULSE ], // Previous Stage Move, NatDex / Hisui Goodra Level [ 43, Moves.CURSE ], [ 49, Moves.BODY_SLAM ], [ 58, Moves.MUDDY_WATER ], @@ -12285,7 +12535,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.PUMPKABOO]: [ [ 1, Moves.ASTONISH ], [ 1, Moves.TRICK_OR_TREAT ], - [ 1, Moves.LEAFAGE ], //Custom + [ 1, Moves.LEAFAGE ], // Custom [ 4, Moves.SHADOW_SNEAK ], [ 8, Moves.CONFUSE_RAY ], [ 12, Moves.RAZOR_LEAF ], @@ -12302,6 +12552,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.CONFUSE_RAY ], [ 1, Moves.EXPLOSION ], [ 1, Moves.ASTONISH ], + [ 1, Moves.LEAFAGE ], // Previous Stage Move, Custom [ 1, Moves.SHADOW_SNEAK ], [ 1, Moves.TRICK_OR_TREAT ], [ 1, Moves.MOONBLAST ], @@ -12813,11 +13064,14 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.CRABOMINABLE]: [ [ EVOLVE_MOVE, Moves.ICE_PUNCH ], + [ RELEARN_MOVE, Moves.CRABHAMMER ], // Previous Stage Move + [ 1, Moves.VISE_GRIP ], // Previous Stage Move [ 1, Moves.LEER ], [ 1, Moves.PROTECT ], [ 1, Moves.ROCK_SMASH ], [ 1, Moves.BUBBLE ], [ 1, Moves.PURSUIT ], + [ 1, Moves.PAYBACK ], // Previous Stage Move [ 17, Moves.BUBBLE_BEAM ], [ 22, Moves.BRICK_BREAK ], [ 25, Moves.SLAM ], @@ -13006,6 +13260,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.BUG_BITE ], [ 1, Moves.WIDE_GUARD ], [ 1, Moves.INFESTATION ], + [ 1, Moves.WATER_SPORT ], // Previous Stage Move [ 1, Moves.SPIDER_WEB ], [ 12, Moves.BUBBLE_BEAM ], [ 16, Moves.AQUA_RING ], @@ -13154,7 +13409,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.BOUNSWEET]: [ [ 1, Moves.SPLASH ], - [ 1, Moves.LEAFAGE ], //Custom + [ 1, Moves.LEAFAGE ], // Custom [ 4, Moves.PLAY_NICE ], [ 8, Moves.RAPID_SPIN ], [ 12, Moves.RAZOR_LEAF ], @@ -13165,6 +13420,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 32, Moves.AROMATIC_MIST ], ], [Species.STEENEE]: [ + [ 1, Moves.LEAFAGE ], // Previous Stage Move, Custom [ 1, Moves.RAZOR_LEAF ], [ 1, Moves.SPLASH ], [ 1, Moves.FLAIL ], @@ -13179,6 +13435,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.TSAREENA]: [ [ EVOLVE_MOVE, Moves.TROP_KICK ], + [ 1, Moves.LEAFAGE ], // Previous Stage Move, Custom [ 1, Moves.RAZOR_LEAF ], [ 1, Moves.SPLASH ], [ 1, Moves.FLAIL ], @@ -13303,7 +13560,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 68, Moves.SANDSTORM ], ], [Species.PYUKUMUKU]: [ - [ 1, Moves.COUNTER ], //Custom, Moved from Level 20 to 1 + [ 1, Moves.COUNTER ], // Custom, Moved from Level 20 to 1 [ 1, Moves.HARDEN ], [ 1, Moves.BATON_PASS ], [ 1, Moves.BIDE ], @@ -13312,7 +13569,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 5, Moves.HELPING_HAND ], [ 10, Moves.TAUNT ], [ 15, Moves.SAFEGUARD ], - [ 20, Moves.MIRROR_COAT ], //Custom + [ 20, Moves.MIRROR_COAT ], // Custom [ 25, Moves.PURIFY ], [ 30, Moves.CURSE ], [ 35, Moves.GASTRO_ACID ], @@ -13629,15 +13886,19 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.COSMOG]: [ [ 1, Moves.TELEPORT ], [ 1, Moves.SPLASH ], - [ 1, Moves.STORED_POWER ], //Custom + [ 1, Moves.STORED_POWER ], // Custom ], [Species.COSMOEM]: [ [ EVOLVE_MOVE, Moves.COSMIC_POWER ], [ 1, Moves.TELEPORT ], + [ 1, Moves.SPLASH ], // Previous Stage Move + [ 1, Moves.STORED_POWER ], // Previous Stage Move, Custom ], [Species.SOLGALEO]: [ [ EVOLVE_MOVE, Moves.SUNSTEEL_STRIKE ], [ 1, Moves.TELEPORT ], + [ 1, Moves.SPLASH ], // Previous Stage Move + [ 1, Moves.STORED_POWER ], // Previous Stage Move, Custom [ 1, Moves.METAL_CLAW ], [ 1, Moves.COSMIC_POWER ], [ 1, Moves.NOBLE_ROAR ], @@ -13660,6 +13921,8 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.CONFUSION ], [ 1, Moves.HYPNOSIS ], [ 1, Moves.TELEPORT ], + [ 1, Moves.SPLASH ], // Previous Stage Move + [ 1, Moves.STORED_POWER ], // Previous Stage Move, Custom [ 1, Moves.COSMIC_POWER ], [ 7, Moves.NIGHT_SHADE ], [ 14, Moves.CONFUSE_RAY ], @@ -13826,7 +14089,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.MAGEARNA]: [ [ 1, Moves.HELPING_HAND ], [ 1, Moves.GYRO_BALL ], - [ 1, Moves.DISARMING_VOICE ], //Custom + [ 1, Moves.DISARMING_VOICE ], // Custom [ 1, Moves.CRAFTY_SHIELD ], [ 1, Moves.GEAR_UP ], [ 6, Moves.DEFENSE_CURL ], @@ -13867,7 +14130,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 99, Moves.CLOSE_COMBAT ], ], [Species.POIPOLE]: [ - [ RELEARN_MOVE, Moves.DRAGON_PULSE ], //Custom, made relearn + [ RELEARN_MOVE, Moves.DRAGON_PULSE ], // Custom, made relearn [ 1, Moves.GROWL ], [ 1, Moves.ACID ], [ 1, Moves.PECK ], @@ -13986,7 +14249,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.GROOKEY]: [ [ 1, Moves.SCRATCH ], [ 1, Moves.GROWL ], - [ 5, Moves.BRANCH_POKE ], //Custom, moved from 6 to 5 + [ 5, Moves.BRANCH_POKE ], // Custom, moved from 6 to 5 [ 8, Moves.TAUNT ], [ 12, Moves.RAZOR_LEAF ], [ 17, Moves.SCREECH ], @@ -14031,7 +14294,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.SCORBUNNY]: [ [ 1, Moves.TACKLE ], [ 1, Moves.GROWL ], - [ 5, Moves.EMBER ], //Custom, moved from 6 to 5 + [ 5, Moves.EMBER ], // Custom, moved from 6 to 5 [ 8, Moves.QUICK_ATTACK ], [ 12, Moves.DOUBLE_KICK ], [ 17, Moves.FLAME_CHARGE ], @@ -14073,7 +14336,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.SOBBLE]: [ [ 1, Moves.POUND ], [ 1, Moves.GROWL ], - [ 5, Moves.WATER_GUN ], //Custom, moved from 6 to 5 + [ 5, Moves.WATER_GUN ], // Custom, moved from 6 to 5 [ 8, Moves.BIND ], [ 12, Moves.WATER_PULSE ], [ 17, Moves.TEARFUL_LOOK ], @@ -14400,10 +14663,11 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.APPLIN]: [ [ 1, Moves.WITHDRAW ], [ 1, Moves.ASTONISH ], - [ 1, Moves.LEAFAGE ], //Custom + [ 1, Moves.LEAFAGE ], // Custom ], [Species.FLAPPLE]: [ [ EVOLVE_MOVE, Moves.WING_ATTACK ], + [ 1, Moves.LEAFAGE ], // Previous Stage Move, Custom [ 1, Moves.GROWTH ], [ 1, Moves.WITHDRAW ], [ 1, Moves.TWISTER ], @@ -14423,6 +14687,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.APPLETUN]: [ [ EVOLVE_MOVE, Moves.HEADBUTT ], + [ 1, Moves.LEAFAGE ], // Previous Stage Move, Custom [ 1, Moves.GROWTH ], [ 1, Moves.WITHDRAW ], [ 1, Moves.SWEET_SCENT ], @@ -14443,7 +14708,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.SILICOBRA]: [ [ 1, Moves.SAND_ATTACK ], [ 1, Moves.WRAP ], - [ 1, Moves.MUD_SLAP ], //Custom + [ 1, Moves.MUD_SLAP ], // Custom [ 5, Moves.MINIMIZE ], [ 10, Moves.BRUTAL_SWING ], [ 15, Moves.BULLDOZE ], @@ -14458,6 +14723,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.SANDACONDA]: [ [ 1, Moves.SAND_ATTACK ], [ 1, Moves.WRAP ], + [ 1, Moves.MUD_SLAP ], // Previous Stage Move, Custom [ 1, Moves.MINIMIZE ], [ 1, Moves.BRUTAL_SWING ], [ 15, Moves.BULLDOZE ], @@ -14605,7 +14871,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.SINISTEA]: [ [ 1, Moves.WITHDRAW ], [ 1, Moves.ASTONISH ], - [ 1, Moves.ABSORB ], //Custom + [ 1, Moves.ABSORB ], // Custom [ 6, Moves.AROMATIC_MIST ], [ 12, Moves.MEGA_DRAIN ], [ 24, Moves.SUCKER_PUNCH ], @@ -14618,6 +14884,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.POLTEAGEIST]: [ [ EVOLVE_MOVE, Moves.TEATIME ], + [ 1, Moves.ABSORB ], // Previous Stage Move, Custom [ 1, Moves.MEGA_DRAIN ], [ 1, Moves.WITHDRAW ], [ 1, Moves.ASTONISH ], @@ -14805,6 +15072,8 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.MR_RIME]: [ [ 1, Moves.POUND ], + [ 1, Moves.BARRIER ], // Previous Stage Move + [ 1, Moves.TICKLE ], // Previous Stage Move [ 1, Moves.MIMIC ], [ 1, Moves.LIGHT_SCREEN ], [ 1, Moves.REFLECT ], @@ -15133,6 +15402,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.DRAGAPULT]: [ [ EVOLVE_MOVE, Moves.DRAGON_DARTS ], + [ RELEARN_MOVE, Moves.DRAGON_PULSE ], // Previous Stage Move [ 1, Moves.BITE ], [ 1, Moves.QUICK_ATTACK ], [ 1, Moves.DRAGON_BREATH ], @@ -15339,6 +15609,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.WYRDEER]: [ [ EVOLVE_MOVE, Moves.PSYSHIELD_BASH ], [ 1, Moves.TACKLE ], + [ 1, Moves.ME_FIRST ], // Previous Stage Move [ 3, Moves.LEER ], [ 7, Moves.ASTONISH ], [ 10, Moves.HYPNOSIS ], @@ -15355,6 +15626,8 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.KLEAVOR]: [ [ EVOLVE_MOVE, Moves.STONE_AXE ], + [ 1, Moves.WING_ATTACK ], // Previous Stage Move + [ 1, Moves.AIR_SLASH ], // Previous Stage Move [ 1, Moves.LEER ], [ 1, Moves.QUICK_ATTACK ], [ 4, Moves.FURY_CUTTER ], @@ -15364,6 +15637,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 20, Moves.DOUBLE_HIT ], [ 24, Moves.SLASH ], [ 28, Moves.FOCUS_ENERGY ], + [ 30, Moves.STEEL_WING ], // Custom [ 32, Moves.AGILITY ], [ 36, Moves.ROCK_SLIDE ], [ 40, Moves.X_SCISSOR ], @@ -15374,8 +15648,11 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.SCRATCH ], [ 1, Moves.LEER ], [ 1, Moves.LICK ], - [ 1, Moves.FAKE_TEARS ], [ 1, Moves.COVET ], + [ 1, Moves.FLING ], // Previous Stage Move + [ 1, Moves.BABY_DOLL_EYES ], // Previous Stage Move + [ 1, Moves.FAKE_TEARS ], + [ 1, Moves.CHARM ], // Previous Stage Moves [ 8, Moves.FURY_SWIPES ], [ 13, Moves.PAYBACK ], [ 17, Moves.SWEET_SCENT ], @@ -15390,6 +15667,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 64, Moves.HAMMER_ARM ], ], [Species.BASCULEGION]: [ + [ RELEARN_MOVE, Moves.FINAL_GAMBIT ], // Previous Stage Move, White Stripe currently shares moveset with other forms [ 1, Moves.TAIL_WHIP ], [ 1, Moves.WATER_GUN ], [ 1, Moves.SHADOW_BALL ], @@ -15949,10 +16227,12 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.GARGANACL]: [ [ EVOLVE_MOVE, Moves.HAMMER_ARM ], + [ RELEARN_MOVE, Moves.IRON_DEFENSE ], // Previous Stage Move [ 1, Moves.TACKLE ], [ 1, Moves.HARDEN ], [ 1, Moves.BLOCK ], [ 1, Moves.ROCK_BLAST ], + [ 1, Moves.SMACK_DOWN ], // Previous Stage Move [ 1, Moves.WIDE_GUARD ], [ 5, Moves.ROCK_THROW ], [ 7, Moves.MUD_SHOT ], @@ -16140,6 +16420,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ EVOLVE_MOVE, Moves.DOODLE ], [ 1, Moves.SCRATCH ], [ 1, Moves.LEER ], + [ 1, Moves.BITE ], // Previous Stage Move [ 5, Moves.ACID_SPRAY ], [ 8, Moves.FURY_SWIPES ], [ 11, Moves.SWITCHEROO ], @@ -16294,6 +16575,8 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.TACKLE ], [ 1, Moves.CONFUSION ], [ 1, Moves.DEFENSE_CURL ], + [ 1, Moves.MUD_SHOT ], // Previous Stage Move + [ 1, Moves.DIG ], // Previous Stage Move [ 4, Moves.SAND_ATTACK ], [ 7, Moves.STRUGGLE_BUG ], [ 11, Moves.ROLLOUT ], @@ -16717,6 +17000,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.LEER ], [ 1, Moves.COUNTER ], [ 1, Moves.FOCUS_ENERGY ], + [ 1, Moves.COVET ], // Previous Stage Move [ 1, Moves.FLING ], [ 5, Moves.FURY_SWIPES ], [ 8, Moves.LOW_KICK ], @@ -16734,6 +17018,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.CLODSIRE]: [ [ EVOLVE_MOVE, Moves.AMNESIA ], + [ 1, Moves.TACKLE ], // Previous Stage Move [ 1, Moves.TAIL_WHIP ], [ 1, Moves.POISON_STING ], [ 4, Moves.TOXIC_SPIKES ], @@ -16768,6 +17053,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.DUDUNSPARCE]: [ [ 1, Moves.DEFENSE_CURL ], [ 1, Moves.FLAIL ], + [ 1, Moves.TACKLE ], // Previous Stage Move, Custom [ 4, Moves.MUD_SLAP ], [ 8, Moves.ROLLOUT ], [ 12, Moves.GLARE ], @@ -16864,7 +17150,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.CONFUSE_RAY ], [ 1, Moves.SPITE ], [ 1, Moves.ASTONISH ], - [ 1, Moves.PSYBEAM ], //Custom, moved from 7 to 1 + [ 1, Moves.PSYBEAM ], // Custom, moved from 7 to 1 [ 14, Moves.MEAN_LOOK ], [ 21, Moves.MEMENTO ], [ 28, Moves.WISH ], @@ -16939,7 +17225,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.IRON_BUNDLE]: [ [ RELEARN_MOVE, Moves.ELECTRIC_TERRAIN ], [ 1, Moves.PRESENT ], - [ 1, Moves.WATER_GUN ], //Custom + [ 1, Moves.WATER_GUN ], // Custom [ 7, Moves.POWDER_SNOW ], [ 14, Moves.WHIRLPOOL ], [ 21, Moves.TAKE_DOWN ], @@ -17058,6 +17344,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 18, Moves.FOCUS_ENERGY ], [ 24, Moves.BITE ], [ 29, Moves.ICE_FANG ], + [ 32, Moves.DRAGON_CLAW ], // Previous Stage Move, Frigibax Level [ 40, Moves.TAKE_DOWN ], [ 45, Moves.ICE_BEAM ], [ 50, Moves.CRUNCH ], @@ -17305,6 +17592,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [Species.DIPPLIN]: [ [ EVOLVE_MOVE, Moves.DOUBLE_HIT ], [ RELEARN_MOVE, Moves.DRAGON_CHEER ], // Custom + [ 1, Moves.LEAFAGE ], [ 1, Moves.WITHDRAW ], [ 1, Moves.SWEET_SCENT ], [ 1, Moves.RECYCLE ], @@ -17324,7 +17612,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.STUN_SPORE ], [ 1, Moves.WITHDRAW ], [ 1, Moves.ASTONISH ], - [ 5, Moves.ABSORB ], //Custom, Moved from Level 6 to 5 + [ 5, Moves.ABSORB ], // Custom, Moved from Level 6 to 5 [ 12, Moves.LIFE_DEW ], [ 18, Moves.FOUL_PLAY ], [ 24, Moves.MEGA_DRAIN ], @@ -17337,6 +17625,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.SINISTCHA]: [ [ EVOLVE_MOVE, Moves.MATCHA_GOTCHA ], + [ RELEARN_MOVE, Moves.GIGA_DRAIN ], // Previous Stage Move [ 1, Moves.STUN_SPORE ], [ 1, Moves.WITHDRAW ], [ 1, Moves.ASTONISH ], @@ -17419,6 +17708,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.ARCHALUDON]: [ [ EVOLVE_MOVE, Moves.ELECTRO_SHOT ], + [ RELEARN_MOVE, Moves.LASER_FOCUS ], // Previous Stage Move [ 1, Moves.LEER ], [ 1, Moves.METAL_CLAW ], [ 6, Moves.ROCK_SMASH ], @@ -17438,6 +17728,8 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ RELEARN_MOVE, Moves.YAWN ], [ RELEARN_MOVE, Moves.DOUBLE_HIT ], [ RELEARN_MOVE, Moves.INFESTATION ], + [ RELEARN_MOVE, Moves.DRAGON_CHEER ], // Previous Stage Move, Custom + [ 1, Moves.LEAFAGE ], // Previous Stage Move, Custom [ 1, Moves.WITHDRAW ], [ 1, Moves.SWEET_SCENT ], [ 1, Moves.RECYCLE ], @@ -17809,6 +18101,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.DEFENSE_CURL ], [ 1, Moves.CHARGE ], [ 1, Moves.ROCK_POLISH ], + [ 1, Moves.ROLLOUT ], // Previous Stage Move [ 1, Moves.HEAVY_SLAM ], [ 12, Moves.SPARK ], [ 16, Moves.ROCK_THROW ], @@ -18051,6 +18344,8 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.GALAR_MR_MIME]: [ [ 1, Moves.POUND ], + [ 1, Moves.BARRIER ], // Previous Stage Move + [ 1, Moves.TICKLE ], // Previous Stage Move [ 1, Moves.MIMIC ], [ 1, Moves.LIGHT_SCREEN ], [ 1, Moves.REFLECT ], @@ -18411,6 +18706,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.TACKLE ], [ 1, Moves.TAIL_WHIP ], [ 1, Moves.WATER_GUN ], + [ 1, Moves.SOAK ], // Previous Stage Move [ 1, Moves.SLASH ], [ 1, Moves.MEGAHORN ], [ 1, Moves.SUCKER_PUNCH ], @@ -18436,6 +18732,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.STUN_SPORE ], [ 1, Moves.SLEEP_POWDER ], [ 1, Moves.GIGA_DRAIN ], + [ 1, Moves.CHARM ], // Previous Stage Move [ 1, Moves.SYNTHESIS ], [ 1, Moves.SUNNY_DAY ], [ 1, Moves.HELPING_HAND ], @@ -18487,6 +18784,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.HISUI_BRAVIARY]: [ [ EVOLVE_MOVE, Moves.ESPER_WING ], + [ RELEARN_MOVE, Moves.BRAVE_BIRD ], // Previous Stage Move [ 1, Moves.WING_ATTACK ], [ 1, Moves.LEER ], [ 1, Moves.PECK ], @@ -18511,6 +18809,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.ABSORB ], [ 1, Moves.ACID_ARMOR ], [ 1, Moves.DRAGON_BREATH ], + [ 1, Moves.BODY_SLAM ], // Previous Stage Move [ 15, Moves.PROTECT ], [ 20, Moves.FLAIL ], [ 25, Moves.WATER_PULSE ], @@ -18525,6 +18824,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { [ 1, Moves.TACKLE ], [ 1, Moves.WATER_GUN ], [ 1, Moves.ABSORB ], + [ 1, Moves.ACID_ARMOR ], // Previous Stage Move [ 1, Moves.DRAGON_BREATH ], [ 1, Moves.FEINT ], [ 1, Moves.ACID_SPRAY ], @@ -18565,9 +18865,11 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { ], [Species.HISUI_DECIDUEYE]: [ [ EVOLVE_MOVE, Moves.TRIPLE_ARROWS ], + [ RELEARN_MOVE, Moves.NASTY_PLOT ], // Previous Stage Move [ 1, Moves.TACKLE ], [ 1, Moves.GROWL ], [ 1, Moves.U_TURN ], + [ 1, Moves.ASTONISH ], // Previous Stage Move [ 1, Moves.LEAF_STORM ], [ 1, Moves.LEAFAGE ], [ 9, Moves.PECK ], @@ -18633,7 +18935,7 @@ export const pokemonSpeciesLevelMoves: PokemonSpeciesLevelMoves = { }; export const pokemonFormLevelMoves: PokemonSpeciesFormLevelMoves = { - [Species.PIKACHU]: { //Custom + [Species.PIKACHU]: { // Custom 1: [ [ 1, Moves.TAIL_WHIP ], [ 1, Moves.GROWL ], @@ -18648,14 +18950,14 @@ export const pokemonFormLevelMoves: PokemonSpeciesFormLevelMoves = { [ 8, Moves.DOUBLE_TEAM ], [ 12, Moves.ELECTRO_BALL ], [ 16, Moves.FEINT ], - [ 20, Moves.ZIPPY_ZAP ], //Custom + [ 20, Moves.ZIPPY_ZAP ], // Custom [ 24, Moves.AGILITY ], [ 28, Moves.IRON_TAIL ], [ 32, Moves.DISCHARGE ], - [ 34, Moves.FLOATY_FALL ], //Custom + [ 34, Moves.FLOATY_FALL ], // Custom [ 36, Moves.THUNDERBOLT ], [ 40, Moves.LIGHT_SCREEN ], - [ 42, Moves.SPLISHY_SPLASH ], //Custom + [ 42, Moves.SPLISHY_SPLASH ], // Custom [ 44, Moves.THUNDER ], [ 48, Moves.PIKA_PAPOW ], ], @@ -18816,19 +19118,19 @@ export const pokemonFormLevelMoves: PokemonSpeciesFormLevelMoves = { [ 8, Moves.DOUBLE_TEAM ], [ 12, Moves.ELECTRO_BALL ], [ 16, Moves.FEINT ], - [ 20, Moves.ZIPPY_ZAP ], //Custom + [ 20, Moves.ZIPPY_ZAP ], // Custom [ 24, Moves.AGILITY ], [ 28, Moves.IRON_TAIL ], [ 32, Moves.DISCHARGE ], - [ 34, Moves.FLOATY_FALL ], //Custom + [ 34, Moves.FLOATY_FALL ], // Custom [ 36, Moves.THUNDERBOLT ], [ 40, Moves.LIGHT_SCREEN ], - [ 42, Moves.SPLISHY_SPLASH ], //Custom + [ 42, Moves.SPLISHY_SPLASH ], // Custom [ 44, Moves.THUNDER ], [ 48, Moves.PIKA_PAPOW ], ], }, - [Species.EEVEE]: { //Custom + [Species.EEVEE]: { // Custom 1: [ [ 1, Moves.TACKLE ], [ 1, Moves.TAIL_WHIP ], @@ -18838,21 +19140,21 @@ export const pokemonFormLevelMoves: PokemonSpeciesFormLevelMoves = { [ 5, Moves.SAND_ATTACK ], [ 10, Moves.QUICK_ATTACK ], [ 15, Moves.BABY_DOLL_EYES ], - [ 18, Moves.BOUNCY_BUBBLE ], //Custom - [ 18, Moves.SIZZLY_SLIDE ], //Custom - [ 18, Moves.BUZZY_BUZZ ], //Custom + [ 18, Moves.BOUNCY_BUBBLE ], // Custom + [ 18, Moves.SIZZLY_SLIDE ], // Custom + [ 18, Moves.BUZZY_BUZZ ], // Custom [ 20, Moves.SWIFT ], [ 25, Moves.BITE ], [ 30, Moves.COPYCAT ], - [ 33, Moves.BADDY_BAD ], //Custom - [ 33, Moves.GLITZY_GLOW ], //Custom + [ 33, Moves.BADDY_BAD ], // Custom + [ 33, Moves.GLITZY_GLOW ], // Custom [ 35, Moves.BATON_PASS ], - [ 40, Moves.VEEVEE_VOLLEY ], //Custom, replaces Take Down - [ 43, Moves.FREEZY_FROST ], //Custom - [ 43, Moves.SAPPY_SEED ], //Custom + [ 40, Moves.VEEVEE_VOLLEY ], // Custom, replaces Take Down + [ 43, Moves.FREEZY_FROST ], // Custom + [ 43, Moves.SAPPY_SEED ], // Custom [ 45, Moves.CHARM ], [ 50, Moves.DOUBLE_EDGE ], - [ 53, Moves.SPARKLY_SWIRL ], //Custom + [ 53, Moves.SPARKLY_SWIRL ], // Custom [ 55, Moves.LAST_RESORT ], ], 2: [ @@ -18864,27 +19166,27 @@ export const pokemonFormLevelMoves: PokemonSpeciesFormLevelMoves = { [ 5, Moves.SAND_ATTACK ], [ 10, Moves.QUICK_ATTACK ], [ 15, Moves.BABY_DOLL_EYES ], - [ 18, Moves.BOUNCY_BUBBLE ], //Custom - [ 18, Moves.SIZZLY_SLIDE ], //Custom - [ 18, Moves.BUZZY_BUZZ ], //Custom + [ 18, Moves.BOUNCY_BUBBLE ], // Custom + [ 18, Moves.SIZZLY_SLIDE ], // Custom + [ 18, Moves.BUZZY_BUZZ ], // Custom [ 20, Moves.SWIFT ], [ 25, Moves.BITE ], [ 30, Moves.COPYCAT ], - [ 33, Moves.BADDY_BAD ], //Custom - [ 33, Moves.GLITZY_GLOW ], //Custom + [ 33, Moves.BADDY_BAD ], // Custom + [ 33, Moves.GLITZY_GLOW ], // Custom [ 35, Moves.BATON_PASS ], - [ 40, Moves.VEEVEE_VOLLEY ], //Custom, replaces Take Down - [ 43, Moves.FREEZY_FROST ], //Custom - [ 43, Moves.SAPPY_SEED ], //Custom + [ 40, Moves.VEEVEE_VOLLEY ], // Custom, replaces Take Down + [ 43, Moves.FREEZY_FROST ], // Custom + [ 43, Moves.SAPPY_SEED ], // Custom [ 45, Moves.CHARM ], [ 50, Moves.DOUBLE_EDGE ], - [ 53, Moves.SPARKLY_SWIRL ], //Custom + [ 53, Moves.SPARKLY_SWIRL ], // Custom [ 55, Moves.LAST_RESORT ], ], }, [Species.DEOXYS]: { 1: [ - [ 1, Moves.CONFUSION ], //Custom + [ 1, Moves.CONFUSION ], // Custom [ 1, Moves.WRAP ], [ 1, Moves.LEER ], [ 7, Moves.NIGHT_SHADE ], @@ -18901,7 +19203,7 @@ export const pokemonFormLevelMoves: PokemonSpeciesFormLevelMoves = { [ 73, Moves.HYPER_BEAM ], ], 2: [ - [ 1, Moves.CONFUSION ], //Custom + [ 1, Moves.CONFUSION ], // Custom [ 1, Moves.WRAP ], [ 1, Moves.LEER ], [ 7, Moves.NIGHT_SHADE ], @@ -18920,7 +19222,7 @@ export const pokemonFormLevelMoves: PokemonSpeciesFormLevelMoves = { [ 73, Moves.MIRROR_COAT ], ], 3: [ - [ 1, Moves.CONFUSION ], //Custom + [ 1, Moves.CONFUSION ], // Custom [ 1, Moves.WRAP ], [ 1, Moves.LEER ], [ 7, Moves.NIGHT_SHADE ], @@ -18940,6 +19242,7 @@ export const pokemonFormLevelMoves: PokemonSpeciesFormLevelMoves = { [Species.WORMADAM]: { 1: [ [ EVOLVE_MOVE, Moves.QUIVER_DANCE ], + [ 1, Moves.STRUGGLE_BUG ], // Previous Stage Move, Custom [ 1, Moves.TACKLE ], [ 1, Moves.PROTECT ], [ 1, Moves.SUCKER_PUNCH ], @@ -18960,6 +19263,7 @@ export const pokemonFormLevelMoves: PokemonSpeciesFormLevelMoves = { ], 2: [ [ EVOLVE_MOVE, Moves.QUIVER_DANCE ], + [ 1, Moves.STRUGGLE_BUG ], // Previous Stage Move, Custom [ 1, Moves.METAL_BURST ], [ 1, Moves.TACKLE ], [ 1, Moves.PROTECT ], @@ -19064,7 +19368,7 @@ export const pokemonFormLevelMoves: PokemonSpeciesFormLevelMoves = { }, [Species.SHAYMIN]: { 1: [ - [ 1, Moves.LEAFAGE ], //Custom + [ 1, Moves.LEAFAGE ], // Custom [ 1, Moves.GROWTH ], [ 10, Moves.MAGICAL_LEAF ], [ 19, Moves.LEECH_SEED ], @@ -19166,6 +19470,10 @@ export const pokemonFormLevelMoves: PokemonSpeciesFormLevelMoves = { [ 1, Moves.GROWL ], [ 1, Moves.WATER_GUN ], [ 1, Moves.QUICK_ATTACK ], + [ 1, Moves.ROUND ], // Previous Stage Move + [ 1, Moves.FLING ], // Previous Stage Move + [ 1, Moves.SMACK_DOWN ], // Previous Stage Move + [ 1, Moves.BOUNCE ], // Previous Stage Move [ 1, Moves.HAZE ], [ 1, Moves.ROLE_PLAY ], [ 1, Moves.NIGHT_SLASH ], @@ -19498,6 +19806,108 @@ export const pokemonFormLevelMoves: PokemonSpeciesFormLevelMoves = { [ 51, Moves.BELCH ], ], }, + [Species.REVAVROOM]: { + 1: [ + [ EVOLVE_MOVE, Moves.WICKED_TORQUE ], + [ EVOLVE_MOVE, Moves.SHIFT_GEAR ], + [ 1, Moves.LICK ], + [ 1, Moves.POISON_GAS ], + [ 1, Moves.MAGNET_RISE ], + [ 4, Moves.SMOG ], + [ 7, Moves.TAUNT ], + [ 10, Moves.ASSURANCE ], + [ 13, Moves.SLUDGE ], + [ 17, Moves.GYRO_BALL ], + [ 21, Moves.HEADBUTT ], + [ 25, Moves.SCREECH ], + [ 28, Moves.IRON_HEAD ], + [ 32, Moves.SWAGGER ], + [ 36, Moves.POISON_JAB ], + [ 46, Moves.UPROAR ], + [ 52, Moves.SPIN_OUT ], + [ 58, Moves.GUNK_SHOT ], + ], + 2: [ + [ EVOLVE_MOVE, Moves.BLAZING_TORQUE ], + [ EVOLVE_MOVE, Moves.SHIFT_GEAR ], + [ 1, Moves.LICK ], + [ 1, Moves.POISON_GAS ], + [ 1, Moves.MAGNET_RISE ], + [ 4, Moves.SMOG ], + [ 7, Moves.TAUNT ], + [ 10, Moves.ASSURANCE ], + [ 13, Moves.SLUDGE ], + [ 17, Moves.GYRO_BALL ], + [ 21, Moves.HEADBUTT ], + [ 25, Moves.SCREECH ], + [ 28, Moves.IRON_HEAD ], + [ 32, Moves.SWAGGER ], + [ 36, Moves.POISON_JAB ], + [ 46, Moves.UPROAR ], + [ 52, Moves.SPIN_OUT ], + [ 58, Moves.GUNK_SHOT ], + ], + 3: [ + [ EVOLVE_MOVE, Moves.NOXIOUS_TORQUE ], + [ EVOLVE_MOVE, Moves.SHIFT_GEAR ], + [ 1, Moves.LICK ], + [ 1, Moves.POISON_GAS ], + [ 1, Moves.MAGNET_RISE ], + [ 4, Moves.SMOG ], + [ 7, Moves.TAUNT ], + [ 10, Moves.ASSURANCE ], + [ 13, Moves.SLUDGE ], + [ 17, Moves.GYRO_BALL ], + [ 21, Moves.HEADBUTT ], + [ 25, Moves.SCREECH ], + [ 28, Moves.IRON_HEAD ], + [ 32, Moves.SWAGGER ], + [ 36, Moves.POISON_JAB ], + [ 46, Moves.UPROAR ], + [ 52, Moves.SPIN_OUT ], + [ 58, Moves.GUNK_SHOT ], + ], + 4: [ + [ EVOLVE_MOVE, Moves.MAGICAL_TORQUE ], + [ EVOLVE_MOVE, Moves.SHIFT_GEAR ], + [ 1, Moves.LICK ], + [ 1, Moves.POISON_GAS ], + [ 1, Moves.MAGNET_RISE ], + [ 4, Moves.SMOG ], + [ 7, Moves.TAUNT ], + [ 10, Moves.ASSURANCE ], + [ 13, Moves.SLUDGE ], + [ 17, Moves.GYRO_BALL ], + [ 21, Moves.HEADBUTT ], + [ 25, Moves.SCREECH ], + [ 28, Moves.IRON_HEAD ], + [ 32, Moves.SWAGGER ], + [ 36, Moves.POISON_JAB ], + [ 46, Moves.UPROAR ], + [ 52, Moves.SPIN_OUT ], + [ 58, Moves.GUNK_SHOT ], + ], + 5: [ + [ EVOLVE_MOVE, Moves.COMBAT_TORQUE ], + [ EVOLVE_MOVE, Moves.SHIFT_GEAR ], + [ 1, Moves.LICK ], + [ 1, Moves.POISON_GAS ], + [ 1, Moves.MAGNET_RISE ], + [ 4, Moves.SMOG ], + [ 7, Moves.TAUNT ], + [ 10, Moves.ASSURANCE ], + [ 13, Moves.SLUDGE ], + [ 17, Moves.GYRO_BALL ], + [ 21, Moves.HEADBUTT ], + [ 25, Moves.SCREECH ], + [ 28, Moves.IRON_HEAD ], + [ 32, Moves.SWAGGER ], + [ 36, Moves.POISON_JAB ], + [ 46, Moves.UPROAR ], + [ 52, Moves.SPIN_OUT ], + [ 58, Moves.GUNK_SHOT ], + ], + }, [Species.PALDEA_TAUROS]: { 1: [ [ 1, Moves.TACKLE ], diff --git a/src/data/balance/rates.ts b/src/data/balance/rates.ts new file mode 100644 index 00000000000..c5eaf40e608 --- /dev/null +++ b/src/data/balance/rates.ts @@ -0,0 +1,53 @@ +/** + * Rates for shinies and other random properties are defined in this file. + * CHANCE is defined as x/65536 + * RATE is defined as 1/x + */ + +// #region Encounterable properties +/** `64/65536 -> 1/1024` */ +export const BASE_SHINY_CHANCE = 64; + +/** `256/65536 -> 1/256` */ +export const BASE_HIDDEN_ABILITY_CHANCE = 256; + +// #region Egg properties + +// Threshold x at which a gacha egg is determined to be a certain tier +// Specifically, the tier is determined by the highest threshold a random value between 0-255 meets or exceeds +// Legendary Up Gacha raises these thresholds by 1, thereby giving Legendary eggs 2/256 chance +export const GACHA_DEFAULT_COMMON_EGG_THRESHOLD = 52; // Default 204/256 chance, 203/256 chance in Legendary Up Gacha +export const GACHA_DEFAULT_RARE_EGG_THRESHOLD = 8; // Default 44/256 chance +export const GACHA_DEFAULT_EPIC_EGG_THRESHOLD = 1; // Default 7/256 chance, leaving Legendary as 1/256 chance +export const GACHA_LEGENDARY_UP_THRESHOLD_OFFSET = 1; // The offset to threshold for Legendary Up gacha eggs. +x/256 Legendary Egg chance, -x/256 Common Egg chance + +// The number of eggs without finding a certain tier egg it takes for egg pity to kick in and that tier to be forced +// These numbers are roughly the 80% mark. That is, 80% of the time you'll get an egg before this gets triggered. +export const EGG_PITY_LEGENDARY_THRESHOLD = 412; +export const EGG_PITY_EPIC_THRESHOLD = 59; +export const EGG_PITY_RARE_THRESHOLD = 9; + +// Waves to hatch an egg of a given tier +export const HATCH_WAVES_COMMON_EGG = 10; +export const HATCH_WAVES_RARE_EGG = 25; +export const HATCH_WAVES_EPIC_EGG = 50; +export const HATCH_WAVES_LEGENDARY_EGG = 100; +export const HATCH_WAVES_MANAPHY_EGG = 50; + +// Rates for specific random properties in 1/x +export const GACHA_DEFAULT_SHINY_RATE = 128; +export const GACHA_SHINY_UP_SHINY_RATE = 64; +export const SAME_SPECIES_EGG_SHINY_RATE = 12; +export const SAME_SPECIES_EGG_HA_RATE = 8; +export const MANAPHY_EGG_MANAPHY_RATE = 8; +export const GACHA_EGG_HA_RATE = 192; + +// 1/x for legendary eggs, 1/x*2 for epic eggs, 1/x*4 for rare eggs, and 1/x*8 for common eggs +export const GACHA_DEFAULT_RARE_EGGMOVE_RATE = 6; +export const SAME_SPECIES_EGG_RARE_EGGMOVE_RATE = 3; +export const GACHA_MOVE_UP_RARE_EGGMOVE_RATE = 3; + +// #region Variant properties +// The chance x/10 of a shiny being a variant, then of being specifically an epic variant +export const SHINY_VARIANT_CHANCE = 4; +export const SHINY_EPIC_CHANCE = 1; diff --git a/src/data/balance/species-egg-tiers.ts b/src/data/balance/species-egg-tiers.ts new file mode 100644 index 00000000000..27baa18151a --- /dev/null +++ b/src/data/balance/species-egg-tiers.ts @@ -0,0 +1,603 @@ +import { Species } from "#enums/species"; +import { EggTier } from "#enums/egg-type"; + +/** + * Map of all starters and their respective {@linkcode EggTier}, which determines the type of egg the starter hatches from. + */ +export const speciesEggTiers = { + [Species.BULBASAUR]: EggTier.COMMON, + [Species.CHARMANDER]: EggTier.COMMON, + [Species.SQUIRTLE]: EggTier.COMMON, + [Species.CATERPIE]: EggTier.COMMON, + [Species.WEEDLE]: EggTier.COMMON, + [Species.PIDGEY]: EggTier.COMMON, + [Species.RATTATA]: EggTier.COMMON, + [Species.SPEAROW]: EggTier.COMMON, + [Species.EKANS]: EggTier.COMMON, + [Species.PIKACHU]: EggTier.COMMON, + [Species.SANDSHREW]: EggTier.COMMON, + [Species.NIDORAN_F]: EggTier.COMMON, + [Species.NIDORAN_M]: EggTier.COMMON, + [Species.CLEFAIRY]: EggTier.COMMON, + [Species.VULPIX]: EggTier.COMMON, + [Species.JIGGLYPUFF]: EggTier.COMMON, + [Species.ZUBAT]: EggTier.COMMON, + [Species.ODDISH]: EggTier.COMMON, + [Species.PARAS]: EggTier.COMMON, + [Species.VENONAT]: EggTier.COMMON, + [Species.DIGLETT]: EggTier.COMMON, + [Species.MEOWTH]: EggTier.COMMON, + [Species.PSYDUCK]: EggTier.COMMON, + [Species.MANKEY]: EggTier.RARE, + [Species.GROWLITHE]: EggTier.RARE, + [Species.POLIWAG]: EggTier.COMMON, + [Species.ABRA]: EggTier.RARE, + [Species.MACHOP]: EggTier.COMMON, + [Species.BELLSPROUT]: EggTier.COMMON, + [Species.TENTACOOL]: EggTier.COMMON, + [Species.GEODUDE]: EggTier.COMMON, + [Species.PONYTA]: EggTier.COMMON, + [Species.SLOWPOKE]: EggTier.COMMON, + [Species.MAGNEMITE]: EggTier.RARE, + [Species.FARFETCHD]: EggTier.COMMON, + [Species.DODUO]: EggTier.COMMON, + [Species.SEEL]: EggTier.COMMON, + [Species.GRIMER]: EggTier.COMMON, + [Species.SHELLDER]: EggTier.RARE, + [Species.GASTLY]: EggTier.RARE, + [Species.ONIX]: EggTier.COMMON, + [Species.DROWZEE]: EggTier.COMMON, + [Species.KRABBY]: EggTier.COMMON, + [Species.VOLTORB]: EggTier.COMMON, + [Species.EXEGGCUTE]: EggTier.COMMON, + [Species.CUBONE]: EggTier.COMMON, + [Species.HITMONLEE]: EggTier.RARE, + [Species.HITMONCHAN]: EggTier.RARE, + [Species.LICKITUNG]: EggTier.COMMON, + [Species.KOFFING]: EggTier.COMMON, + [Species.RHYHORN]: EggTier.COMMON, + [Species.CHANSEY]: EggTier.COMMON, + [Species.TANGELA]: EggTier.COMMON, + [Species.KANGASKHAN]: EggTier.RARE, + [Species.HORSEA]: EggTier.COMMON, + [Species.GOLDEEN]: EggTier.COMMON, + [Species.STARYU]: EggTier.COMMON, + [Species.MR_MIME]: EggTier.COMMON, + [Species.SCYTHER]: EggTier.RARE, + [Species.JYNX]: EggTier.RARE, + [Species.ELECTABUZZ]: EggTier.RARE, + [Species.MAGMAR]: EggTier.RARE, + [Species.PINSIR]: EggTier.RARE, + [Species.TAUROS]: EggTier.RARE, + [Species.MAGIKARP]: EggTier.RARE, + [Species.LAPRAS]: EggTier.RARE, + [Species.DITTO]: EggTier.COMMON, + [Species.EEVEE]: EggTier.COMMON, + [Species.PORYGON]: EggTier.RARE, + [Species.OMANYTE]: EggTier.COMMON, + [Species.KABUTO]: EggTier.COMMON, + [Species.AERODACTYL]: EggTier.RARE, + [Species.SNORLAX]: EggTier.RARE, + [Species.ARTICUNO]: EggTier.EPIC, + [Species.ZAPDOS]: EggTier.EPIC, + [Species.MOLTRES]: EggTier.EPIC, + [Species.DRATINI]: EggTier.RARE, + [Species.MEWTWO]: EggTier.LEGENDARY, + [Species.MEW]: EggTier.EPIC, + + [Species.CHIKORITA]: EggTier.COMMON, + [Species.CYNDAQUIL]: EggTier.COMMON, + [Species.TOTODILE]: EggTier.COMMON, + [Species.SENTRET]: EggTier.COMMON, + [Species.HOOTHOOT]: EggTier.COMMON, + [Species.LEDYBA]: EggTier.COMMON, + [Species.SPINARAK]: EggTier.COMMON, + [Species.CHINCHOU]: EggTier.COMMON, + [Species.PICHU]: EggTier.COMMON, + [Species.CLEFFA]: EggTier.COMMON, + [Species.IGGLYBUFF]: EggTier.COMMON, + [Species.TOGEPI]: EggTier.COMMON, + [Species.NATU]: EggTier.COMMON, + [Species.MAREEP]: EggTier.COMMON, + [Species.MARILL]: EggTier.RARE, + [Species.SUDOWOODO]: EggTier.COMMON, + [Species.HOPPIP]: EggTier.COMMON, + [Species.AIPOM]: EggTier.COMMON, + [Species.SUNKERN]: EggTier.COMMON, + [Species.YANMA]: EggTier.COMMON, + [Species.WOOPER]: EggTier.COMMON, + [Species.MURKROW]: EggTier.COMMON, + [Species.MISDREAVUS]: EggTier.COMMON, + [Species.UNOWN]: EggTier.COMMON, + [Species.WOBBUFFET]: EggTier.COMMON, + [Species.GIRAFARIG]: EggTier.COMMON, + [Species.PINECO]: EggTier.COMMON, + [Species.DUNSPARCE]: EggTier.COMMON, + [Species.GLIGAR]: EggTier.COMMON, + [Species.SNUBBULL]: EggTier.COMMON, + [Species.QWILFISH]: EggTier.COMMON, + [Species.SHUCKLE]: EggTier.COMMON, + [Species.HERACROSS]: EggTier.RARE, + [Species.SNEASEL]: EggTier.RARE, + [Species.TEDDIURSA]: EggTier.RARE, + [Species.SLUGMA]: EggTier.COMMON, + [Species.SWINUB]: EggTier.COMMON, + [Species.CORSOLA]: EggTier.COMMON, + [Species.REMORAID]: EggTier.COMMON, + [Species.DELIBIRD]: EggTier.COMMON, + [Species.MANTINE]: EggTier.COMMON, + [Species.SKARMORY]: EggTier.RARE, + [Species.HOUNDOUR]: EggTier.COMMON, + [Species.PHANPY]: EggTier.COMMON, + [Species.STANTLER]: EggTier.COMMON, + [Species.SMEARGLE]: EggTier.COMMON, + [Species.TYROGUE]: EggTier.COMMON, + [Species.SMOOCHUM]: EggTier.COMMON, + [Species.ELEKID]: EggTier.COMMON, + [Species.MAGBY]: EggTier.COMMON, + [Species.MILTANK]: EggTier.RARE, + [Species.RAIKOU]: EggTier.EPIC, + [Species.ENTEI]: EggTier.EPIC, + [Species.SUICUNE]: EggTier.EPIC, + [Species.LARVITAR]: EggTier.RARE, + [Species.LUGIA]: EggTier.LEGENDARY, + [Species.HO_OH]: EggTier.LEGENDARY, + [Species.CELEBI]: EggTier.EPIC, + + [Species.TREECKO]: EggTier.COMMON, + [Species.TORCHIC]: EggTier.RARE, + [Species.MUDKIP]: EggTier.COMMON, + [Species.POOCHYENA]: EggTier.COMMON, + [Species.ZIGZAGOON]: EggTier.COMMON, + [Species.WURMPLE]: EggTier.COMMON, + [Species.LOTAD]: EggTier.COMMON, + [Species.SEEDOT]: EggTier.COMMON, + [Species.TAILLOW]: EggTier.COMMON, + [Species.WINGULL]: EggTier.COMMON, + [Species.RALTS]: EggTier.COMMON, + [Species.SURSKIT]: EggTier.COMMON, + [Species.SHROOMISH]: EggTier.COMMON, + [Species.SLAKOTH]: EggTier.RARE, + [Species.NINCADA]: EggTier.RARE, + [Species.WHISMUR]: EggTier.COMMON, + [Species.MAKUHITA]: EggTier.COMMON, + [Species.AZURILL]: EggTier.RARE, + [Species.NOSEPASS]: EggTier.COMMON, + [Species.SKITTY]: EggTier.COMMON, + [Species.SABLEYE]: EggTier.COMMON, + [Species.MAWILE]: EggTier.COMMON, + [Species.ARON]: EggTier.COMMON, + [Species.MEDITITE]: EggTier.COMMON, + [Species.ELECTRIKE]: EggTier.COMMON, + [Species.PLUSLE]: EggTier.COMMON, + [Species.MINUN]: EggTier.COMMON, + [Species.VOLBEAT]: EggTier.COMMON, + [Species.ILLUMISE]: EggTier.COMMON, + [Species.ROSELIA]: EggTier.COMMON, + [Species.GULPIN]: EggTier.COMMON, + [Species.CARVANHA]: EggTier.COMMON, + [Species.WAILMER]: EggTier.COMMON, + [Species.NUMEL]: EggTier.COMMON, + [Species.TORKOAL]: EggTier.COMMON, + [Species.SPOINK]: EggTier.COMMON, + [Species.SPINDA]: EggTier.COMMON, + [Species.TRAPINCH]: EggTier.COMMON, + [Species.CACNEA]: EggTier.COMMON, + [Species.SWABLU]: EggTier.COMMON, + [Species.ZANGOOSE]: EggTier.RARE, + [Species.SEVIPER]: EggTier.COMMON, + [Species.LUNATONE]: EggTier.COMMON, + [Species.SOLROCK]: EggTier.COMMON, + [Species.BARBOACH]: EggTier.COMMON, + [Species.CORPHISH]: EggTier.COMMON, + [Species.BALTOY]: EggTier.COMMON, + [Species.LILEEP]: EggTier.COMMON, + [Species.ANORITH]: EggTier.COMMON, + [Species.FEEBAS]: EggTier.RARE, + [Species.CASTFORM]: EggTier.COMMON, + [Species.KECLEON]: EggTier.COMMON, + [Species.SHUPPET]: EggTier.COMMON, + [Species.DUSKULL]: EggTier.COMMON, + [Species.TROPIUS]: EggTier.COMMON, + [Species.CHIMECHO]: EggTier.COMMON, + [Species.ABSOL]: EggTier.RARE, + [Species.WYNAUT]: EggTier.COMMON, + [Species.SNORUNT]: EggTier.COMMON, + [Species.SPHEAL]: EggTier.COMMON, + [Species.CLAMPERL]: EggTier.COMMON, + [Species.RELICANTH]: EggTier.COMMON, + [Species.LUVDISC]: EggTier.COMMON, + [Species.BAGON]: EggTier.RARE, + [Species.BELDUM]: EggTier.RARE, + [Species.REGIROCK]: EggTier.EPIC, + [Species.REGICE]: EggTier.EPIC, + [Species.REGISTEEL]: EggTier.EPIC, + [Species.LATIAS]: EggTier.EPIC, + [Species.LATIOS]: EggTier.EPIC, + [Species.KYOGRE]: EggTier.LEGENDARY, + [Species.GROUDON]: EggTier.LEGENDARY, + [Species.RAYQUAZA]: EggTier.LEGENDARY, + [Species.JIRACHI]: EggTier.EPIC, + [Species.DEOXYS]: EggTier.EPIC, + + [Species.TURTWIG]: EggTier.COMMON, + [Species.CHIMCHAR]: EggTier.COMMON, + [Species.PIPLUP]: EggTier.COMMON, + [Species.STARLY]: EggTier.COMMON, + [Species.BIDOOF]: EggTier.COMMON, + [Species.KRICKETOT]: EggTier.COMMON, + [Species.SHINX]: EggTier.COMMON, + [Species.BUDEW]: EggTier.COMMON, + [Species.CRANIDOS]: EggTier.COMMON, + [Species.SHIELDON]: EggTier.COMMON, + [Species.BURMY]: EggTier.COMMON, + [Species.COMBEE]: EggTier.COMMON, + [Species.PACHIRISU]: EggTier.COMMON, + [Species.BUIZEL]: EggTier.COMMON, + [Species.CHERUBI]: EggTier.COMMON, + [Species.SHELLOS]: EggTier.COMMON, + [Species.DRIFLOON]: EggTier.COMMON, + [Species.BUNEARY]: EggTier.COMMON, + [Species.GLAMEOW]: EggTier.COMMON, + [Species.CHINGLING]: EggTier.COMMON, + [Species.STUNKY]: EggTier.COMMON, + [Species.BRONZOR]: EggTier.COMMON, + [Species.BONSLY]: EggTier.COMMON, + [Species.MIME_JR]: EggTier.COMMON, + [Species.HAPPINY]: EggTier.COMMON, + [Species.CHATOT]: EggTier.COMMON, + [Species.SPIRITOMB]: EggTier.RARE, + [Species.GIBLE]: EggTier.RARE, + [Species.MUNCHLAX]: EggTier.RARE, + [Species.RIOLU]: EggTier.COMMON, + [Species.HIPPOPOTAS]: EggTier.COMMON, + [Species.SKORUPI]: EggTier.COMMON, + [Species.CROAGUNK]: EggTier.COMMON, + [Species.CARNIVINE]: EggTier.COMMON, + [Species.FINNEON]: EggTier.COMMON, + [Species.MANTYKE]: EggTier.COMMON, + [Species.SNOVER]: EggTier.COMMON, + [Species.ROTOM]: EggTier.RARE, + [Species.UXIE]: EggTier.EPIC, + [Species.MESPRIT]: EggTier.EPIC, + [Species.AZELF]: EggTier.EPIC, + [Species.DIALGA]: EggTier.LEGENDARY, + [Species.PALKIA]: EggTier.LEGENDARY, + [Species.HEATRAN]: EggTier.EPIC, + [Species.REGIGIGAS]: EggTier.EPIC, + [Species.GIRATINA]: EggTier.LEGENDARY, + [Species.CRESSELIA]: EggTier.EPIC, + [Species.PHIONE]: EggTier.RARE, + [Species.MANAPHY]: EggTier.EPIC, + [Species.DARKRAI]: EggTier.EPIC, + [Species.SHAYMIN]: EggTier.EPIC, + [Species.ARCEUS]: EggTier.LEGENDARY, + + [Species.VICTINI]: EggTier.EPIC, + [Species.SNIVY]: EggTier.COMMON, + [Species.TEPIG]: EggTier.COMMON, + [Species.OSHAWOTT]: EggTier.COMMON, + [Species.PATRAT]: EggTier.COMMON, + [Species.LILLIPUP]: EggTier.COMMON, + [Species.PURRLOIN]: EggTier.COMMON, + [Species.PANSAGE]: EggTier.COMMON, + [Species.PANSEAR]: EggTier.COMMON, + [Species.PANPOUR]: EggTier.COMMON, + [Species.MUNNA]: EggTier.COMMON, + [Species.PIDOVE]: EggTier.COMMON, + [Species.BLITZLE]: EggTier.COMMON, + [Species.ROGGENROLA]: EggTier.COMMON, + [Species.WOOBAT]: EggTier.COMMON, + [Species.DRILBUR]: EggTier.RARE, + [Species.AUDINO]: EggTier.COMMON, + [Species.TIMBURR]: EggTier.RARE, + [Species.TYMPOLE]: EggTier.COMMON, + [Species.THROH]: EggTier.RARE, + [Species.SAWK]: EggTier.RARE, + [Species.SEWADDLE]: EggTier.COMMON, + [Species.VENIPEDE]: EggTier.COMMON, + [Species.COTTONEE]: EggTier.COMMON, + [Species.PETILIL]: EggTier.COMMON, + [Species.BASCULIN]: EggTier.RARE, + [Species.SANDILE]: EggTier.RARE, + [Species.DARUMAKA]: EggTier.RARE, + [Species.MARACTUS]: EggTier.COMMON, + [Species.DWEBBLE]: EggTier.COMMON, + [Species.SCRAGGY]: EggTier.COMMON, + [Species.SIGILYPH]: EggTier.RARE, + [Species.YAMASK]: EggTier.COMMON, + [Species.TIRTOUGA]: EggTier.COMMON, + [Species.ARCHEN]: EggTier.COMMON, + [Species.TRUBBISH]: EggTier.COMMON, + [Species.ZORUA]: EggTier.COMMON, + [Species.MINCCINO]: EggTier.COMMON, + [Species.GOTHITA]: EggTier.COMMON, + [Species.SOLOSIS]: EggTier.COMMON, + [Species.DUCKLETT]: EggTier.COMMON, + [Species.VANILLITE]: EggTier.COMMON, + [Species.DEERLING]: EggTier.COMMON, + [Species.EMOLGA]: EggTier.COMMON, + [Species.KARRABLAST]: EggTier.COMMON, + [Species.FOONGUS]: EggTier.COMMON, + [Species.FRILLISH]: EggTier.COMMON, + [Species.ALOMOMOLA]: EggTier.RARE, + [Species.JOLTIK]: EggTier.COMMON, + [Species.FERROSEED]: EggTier.COMMON, + [Species.KLINK]: EggTier.COMMON, + [Species.TYNAMO]: EggTier.COMMON, + [Species.ELGYEM]: EggTier.COMMON, + [Species.LITWICK]: EggTier.COMMON, + [Species.AXEW]: EggTier.RARE, + [Species.CUBCHOO]: EggTier.COMMON, + [Species.CRYOGONAL]: EggTier.RARE, + [Species.SHELMET]: EggTier.COMMON, + [Species.STUNFISK]: EggTier.COMMON, + [Species.MIENFOO]: EggTier.COMMON, + [Species.DRUDDIGON]: EggTier.RARE, + [Species.GOLETT]: EggTier.COMMON, + [Species.PAWNIARD]: EggTier.RARE, + [Species.BOUFFALANT]: EggTier.RARE, + [Species.RUFFLET]: EggTier.COMMON, + [Species.VULLABY]: EggTier.COMMON, + [Species.HEATMOR]: EggTier.COMMON, + [Species.DURANT]: EggTier.RARE, + [Species.DEINO]: EggTier.RARE, + [Species.LARVESTA]: EggTier.RARE, + [Species.COBALION]: EggTier.EPIC, + [Species.TERRAKION]: EggTier.EPIC, + [Species.VIRIZION]: EggTier.EPIC, + [Species.TORNADUS]: EggTier.EPIC, + [Species.THUNDURUS]: EggTier.EPIC, + [Species.RESHIRAM]: EggTier.LEGENDARY, + [Species.ZEKROM]: EggTier.LEGENDARY, + [Species.LANDORUS]: EggTier.EPIC, + [Species.KYUREM]: EggTier.LEGENDARY, + [Species.KELDEO]: EggTier.EPIC, + [Species.MELOETTA]: EggTier.EPIC, + [Species.GENESECT]: EggTier.EPIC, + + [Species.CHESPIN]: EggTier.COMMON, + [Species.FENNEKIN]: EggTier.COMMON, + [Species.FROAKIE]: EggTier.RARE, + [Species.BUNNELBY]: EggTier.COMMON, + [Species.FLETCHLING]: EggTier.COMMON, + [Species.SCATTERBUG]: EggTier.COMMON, + [Species.LITLEO]: EggTier.COMMON, + [Species.FLABEBE]: EggTier.COMMON, + [Species.SKIDDO]: EggTier.COMMON, + [Species.PANCHAM]: EggTier.COMMON, + [Species.FURFROU]: EggTier.COMMON, + [Species.ESPURR]: EggTier.COMMON, + [Species.HONEDGE]: EggTier.RARE, + [Species.SPRITZEE]: EggTier.COMMON, + [Species.SWIRLIX]: EggTier.COMMON, + [Species.INKAY]: EggTier.COMMON, + [Species.BINACLE]: EggTier.COMMON, + [Species.SKRELP]: EggTier.COMMON, + [Species.CLAUNCHER]: EggTier.COMMON, + [Species.HELIOPTILE]: EggTier.COMMON, + [Species.TYRUNT]: EggTier.COMMON, + [Species.AMAURA]: EggTier.COMMON, + [Species.HAWLUCHA]: EggTier.RARE, + [Species.DEDENNE]: EggTier.COMMON, + [Species.CARBINK]: EggTier.COMMON, + [Species.GOOMY]: EggTier.RARE, + [Species.KLEFKI]: EggTier.COMMON, + [Species.PHANTUMP]: EggTier.COMMON, + [Species.PUMPKABOO]: EggTier.COMMON, + [Species.BERGMITE]: EggTier.COMMON, + [Species.NOIBAT]: EggTier.COMMON, + [Species.XERNEAS]: EggTier.LEGENDARY, + [Species.YVELTAL]: EggTier.LEGENDARY, + [Species.ZYGARDE]: EggTier.LEGENDARY, + [Species.DIANCIE]: EggTier.EPIC, + [Species.HOOPA]: EggTier.EPIC, + [Species.VOLCANION]: EggTier.EPIC, + [Species.ETERNAL_FLOETTE]: EggTier.RARE, + + [Species.ROWLET]: EggTier.COMMON, + [Species.LITTEN]: EggTier.COMMON, + [Species.POPPLIO]: EggTier.RARE, + [Species.PIKIPEK]: EggTier.COMMON, + [Species.YUNGOOS]: EggTier.COMMON, + [Species.GRUBBIN]: EggTier.COMMON, + [Species.CRABRAWLER]: EggTier.COMMON, + [Species.ORICORIO]: EggTier.COMMON, + [Species.CUTIEFLY]: EggTier.COMMON, + [Species.ROCKRUFF]: EggTier.COMMON, + [Species.WISHIWASHI]: EggTier.COMMON, + [Species.MAREANIE]: EggTier.COMMON, + [Species.MUDBRAY]: EggTier.COMMON, + [Species.DEWPIDER]: EggTier.COMMON, + [Species.FOMANTIS]: EggTier.COMMON, + [Species.MORELULL]: EggTier.COMMON, + [Species.SALANDIT]: EggTier.COMMON, + [Species.STUFFUL]: EggTier.COMMON, + [Species.BOUNSWEET]: EggTier.COMMON, + [Species.COMFEY]: EggTier.RARE, + [Species.ORANGURU]: EggTier.RARE, + [Species.PASSIMIAN]: EggTier.RARE, + [Species.WIMPOD]: EggTier.COMMON, + [Species.SANDYGAST]: EggTier.COMMON, + [Species.PYUKUMUKU]: EggTier.COMMON, + [Species.TYPE_NULL]: EggTier.RARE, + [Species.MINIOR]: EggTier.RARE, + [Species.KOMALA]: EggTier.COMMON, + [Species.TURTONATOR]: EggTier.RARE, + [Species.TOGEDEMARU]: EggTier.COMMON, + [Species.MIMIKYU]: EggTier.RARE, + [Species.BRUXISH]: EggTier.RARE, + [Species.DRAMPA]: EggTier.RARE, + [Species.DHELMISE]: EggTier.RARE, + [Species.JANGMO_O]: EggTier.RARE, + [Species.TAPU_KOKO]: EggTier.EPIC, + [Species.TAPU_LELE]: EggTier.EPIC, + [Species.TAPU_BULU]: EggTier.EPIC, + [Species.TAPU_FINI]: EggTier.EPIC, + [Species.COSMOG]: EggTier.EPIC, + [Species.NIHILEGO]: EggTier.EPIC, + [Species.BUZZWOLE]: EggTier.EPIC, + [Species.PHEROMOSA]: EggTier.EPIC, + [Species.XURKITREE]: EggTier.EPIC, + [Species.CELESTEELA]: EggTier.EPIC, + [Species.KARTANA]: EggTier.EPIC, + [Species.GUZZLORD]: EggTier.EPIC, + [Species.NECROZMA]: EggTier.LEGENDARY, + [Species.MAGEARNA]: EggTier.EPIC, + [Species.MARSHADOW]: EggTier.EPIC, + [Species.POIPOLE]: EggTier.EPIC, + [Species.STAKATAKA]: EggTier.EPIC, + [Species.BLACEPHALON]: EggTier.EPIC, + [Species.ZERAORA]: EggTier.EPIC, + [Species.MELTAN]: EggTier.EPIC, + [Species.ALOLA_RATTATA]: EggTier.COMMON, + [Species.ALOLA_SANDSHREW]: EggTier.COMMON, + [Species.ALOLA_VULPIX]: EggTier.COMMON, + [Species.ALOLA_DIGLETT]: EggTier.COMMON, + [Species.ALOLA_MEOWTH]: EggTier.COMMON, + [Species.ALOLA_GEODUDE]: EggTier.COMMON, + [Species.ALOLA_GRIMER]: EggTier.COMMON, + + [Species.GROOKEY]: EggTier.COMMON, + [Species.SCORBUNNY]: EggTier.RARE, + [Species.SOBBLE]: EggTier.COMMON, + [Species.SKWOVET]: EggTier.COMMON, + [Species.ROOKIDEE]: EggTier.COMMON, + [Species.BLIPBUG]: EggTier.COMMON, + [Species.NICKIT]: EggTier.COMMON, + [Species.GOSSIFLEUR]: EggTier.COMMON, + [Species.WOOLOO]: EggTier.COMMON, + [Species.CHEWTLE]: EggTier.COMMON, + [Species.YAMPER]: EggTier.COMMON, + [Species.ROLYCOLY]: EggTier.COMMON, + [Species.APPLIN]: EggTier.COMMON, + [Species.SILICOBRA]: EggTier.COMMON, + [Species.CRAMORANT]: EggTier.COMMON, + [Species.ARROKUDA]: EggTier.COMMON, + [Species.TOXEL]: EggTier.COMMON, + [Species.SIZZLIPEDE]: EggTier.COMMON, + [Species.CLOBBOPUS]: EggTier.COMMON, + [Species.SINISTEA]: EggTier.COMMON, + [Species.HATENNA]: EggTier.COMMON, + [Species.IMPIDIMP]: EggTier.COMMON, + [Species.MILCERY]: EggTier.COMMON, + [Species.FALINKS]: EggTier.RARE, + [Species.PINCURCHIN]: EggTier.COMMON, + [Species.SNOM]: EggTier.COMMON, + [Species.STONJOURNER]: EggTier.COMMON, + [Species.EISCUE]: EggTier.COMMON, + [Species.INDEEDEE]: EggTier.RARE, + [Species.MORPEKO]: EggTier.COMMON, + [Species.CUFANT]: EggTier.COMMON, + [Species.DRACOZOLT]: EggTier.RARE, + [Species.ARCTOZOLT]: EggTier.RARE, + [Species.DRACOVISH]: EggTier.RARE, + [Species.ARCTOVISH]: EggTier.RARE, + [Species.DURALUDON]: EggTier.RARE, + [Species.DREEPY]: EggTier.RARE, + [Species.ZACIAN]: EggTier.LEGENDARY, + [Species.ZAMAZENTA]: EggTier.LEGENDARY, + [Species.ETERNATUS]: EggTier.LEGENDARY, + [Species.KUBFU]: EggTier.EPIC, + [Species.ZARUDE]: EggTier.EPIC, + [Species.REGIELEKI]: EggTier.EPIC, + [Species.REGIDRAGO]: EggTier.EPIC, + [Species.GLASTRIER]: EggTier.EPIC, + [Species.SPECTRIER]: EggTier.EPIC, + [Species.CALYREX]: EggTier.LEGENDARY, + [Species.GALAR_MEOWTH]: EggTier.COMMON, + [Species.GALAR_PONYTA]: EggTier.COMMON, + [Species.GALAR_SLOWPOKE]: EggTier.COMMON, + [Species.GALAR_FARFETCHD]: EggTier.COMMON, + [Species.GALAR_CORSOLA]: EggTier.COMMON, + [Species.GALAR_ZIGZAGOON]: EggTier.COMMON, + [Species.GALAR_DARUMAKA]: EggTier.RARE, + [Species.GALAR_YAMASK]: EggTier.COMMON, + [Species.GALAR_STUNFISK]: EggTier.COMMON, + [Species.GALAR_MR_MIME]: EggTier.COMMON, + [Species.GALAR_ARTICUNO]: EggTier.EPIC, + [Species.GALAR_ZAPDOS]: EggTier.EPIC, + [Species.GALAR_MOLTRES]: EggTier.EPIC, + [Species.HISUI_GROWLITHE]: EggTier.RARE, + [Species.HISUI_VOLTORB]: EggTier.COMMON, + [Species.HISUI_QWILFISH]: EggTier.RARE, + [Species.HISUI_SNEASEL]: EggTier.RARE, + [Species.HISUI_ZORUA]: EggTier.COMMON, + [Species.ENAMORUS]: EggTier.EPIC, + + [Species.SPRIGATITO]: EggTier.RARE, + [Species.FUECOCO]: EggTier.RARE, + [Species.QUAXLY]: EggTier.RARE, + [Species.LECHONK]: EggTier.COMMON, + [Species.TAROUNTULA]: EggTier.COMMON, + [Species.NYMBLE]: EggTier.COMMON, + [Species.PAWMI]: EggTier.COMMON, + [Species.TANDEMAUS]: EggTier.RARE, + [Species.FIDOUGH]: EggTier.COMMON, + [Species.SMOLIV]: EggTier.COMMON, + [Species.SQUAWKABILLY]: EggTier.COMMON, + [Species.NACLI]: EggTier.RARE, + [Species.CHARCADET]: EggTier.RARE, + [Species.TADBULB]: EggTier.COMMON, + [Species.WATTREL]: EggTier.COMMON, + [Species.MASCHIFF]: EggTier.COMMON, + [Species.SHROODLE]: EggTier.COMMON, + [Species.BRAMBLIN]: EggTier.COMMON, + [Species.TOEDSCOOL]: EggTier.COMMON, + [Species.KLAWF]: EggTier.COMMON, + [Species.CAPSAKID]: EggTier.COMMON, + [Species.RELLOR]: EggTier.COMMON, + [Species.FLITTLE]: EggTier.COMMON, + [Species.TINKATINK]: EggTier.RARE, + [Species.WIGLETT]: EggTier.COMMON, + [Species.BOMBIRDIER]: EggTier.COMMON, + [Species.FINIZEN]: EggTier.COMMON, + [Species.VAROOM]: EggTier.RARE, + [Species.CYCLIZAR]: EggTier.RARE, + [Species.ORTHWORM]: EggTier.RARE, + [Species.GLIMMET]: EggTier.RARE, + [Species.GREAVARD]: EggTier.COMMON, + [Species.FLAMIGO]: EggTier.RARE, + [Species.CETODDLE]: EggTier.COMMON, + [Species.VELUZA]: EggTier.RARE, + [Species.DONDOZO]: EggTier.RARE, + [Species.TATSUGIRI]: EggTier.RARE, + [Species.GREAT_TUSK]: EggTier.EPIC, + [Species.SCREAM_TAIL]: EggTier.EPIC, + [Species.BRUTE_BONNET]: EggTier.EPIC, + [Species.FLUTTER_MANE]: EggTier.EPIC, + [Species.SLITHER_WING]: EggTier.EPIC, + [Species.SANDY_SHOCKS]: EggTier.EPIC, + [Species.IRON_TREADS]: EggTier.EPIC, + [Species.IRON_BUNDLE]: EggTier.EPIC, + [Species.IRON_HANDS]: EggTier.EPIC, + [Species.IRON_JUGULIS]: EggTier.EPIC, + [Species.IRON_MOTH]: EggTier.EPIC, + [Species.IRON_THORNS]: EggTier.EPIC, + [Species.FRIGIBAX]: EggTier.RARE, + [Species.GIMMIGHOUL]: EggTier.RARE, + [Species.WO_CHIEN]: EggTier.EPIC, + [Species.CHIEN_PAO]: EggTier.EPIC, + [Species.TING_LU]: EggTier.EPIC, + [Species.CHI_YU]: EggTier.EPIC, + [Species.ROARING_MOON]: EggTier.EPIC, + [Species.IRON_VALIANT]: EggTier.EPIC, + [Species.KORAIDON]: EggTier.LEGENDARY, + [Species.MIRAIDON]: EggTier.LEGENDARY, + [Species.WALKING_WAKE]: EggTier.EPIC, + [Species.IRON_LEAVES]: EggTier.EPIC, + [Species.POLTCHAGEIST]: EggTier.RARE, + [Species.OKIDOGI]: EggTier.EPIC, + [Species.MUNKIDORI]: EggTier.EPIC, + [Species.FEZANDIPITI]: EggTier.EPIC, + [Species.OGERPON]: EggTier.EPIC, + [Species.GOUGING_FIRE]: EggTier.EPIC, + [Species.RAGING_BOLT]: EggTier.EPIC, + [Species.IRON_BOULDER]: EggTier.EPIC, + [Species.IRON_CROWN]: EggTier.EPIC, + [Species.TERAPAGOS]: EggTier.LEGENDARY, + [Species.PECHARUNT]: EggTier.EPIC, + [Species.PALDEA_TAUROS]: EggTier.RARE, + [Species.PALDEA_WOOPER]: EggTier.COMMON, + [Species.BLOODMOON_URSALUNA]: EggTier.EPIC, +}; diff --git a/src/data/balance/starters.ts b/src/data/balance/starters.ts new file mode 100644 index 00000000000..d6a1f0c3eaf --- /dev/null +++ b/src/data/balance/starters.ts @@ -0,0 +1,677 @@ +import { Species } from "#enums/species"; + +export const POKERUS_STARTER_COUNT = 5; + +// #region Friendship constants +export const CLASSIC_CANDY_FRIENDSHIP_MULTIPLIER = 2; +export const FRIENDSHIP_GAIN_FROM_BATTLE = 2; +export const FRIENDSHIP_GAIN_FROM_RARE_CANDY = 5; +export const FRIENDSHIP_LOSS_FROM_FAINT = 10; + +/** + * Function to get the cumulative friendship threshold at which a candy is earned + * @param starterCost The cost of the starter, found in {@linkcode speciesStarterCosts} + * @returns aforementioned threshold + */ +export function getStarterValueFriendshipCap(starterCost: number): number { + switch (starterCost) { + case 1: + return 20; + case 2: + return 40; + case 3: + return 60; + case 4: + return 100; + case 5: + return 140; + case 6: + return 200; + case 7: + return 280; + case 8: + case 9: + return 450; + default: + return 600; + } +} + +export const speciesStarterCosts = { + [Species.BULBASAUR]: 3, + [Species.CHARMANDER]: 3, + [Species.SQUIRTLE]: 3, + [Species.CATERPIE]: 2, + [Species.WEEDLE]: 1, + [Species.PIDGEY]: 1, + [Species.RATTATA]: 1, + [Species.SPEAROW]: 1, + [Species.EKANS]: 2, + [Species.PIKACHU]: 3, + [Species.SANDSHREW]: 2, + [Species.NIDORAN_F]: 3, + [Species.NIDORAN_M]: 3, + [Species.CLEFAIRY]: 3, + [Species.VULPIX]: 3, + [Species.JIGGLYPUFF]: 2, + [Species.ZUBAT]: 3, + [Species.ODDISH]: 3, + [Species.PARAS]: 2, + [Species.VENONAT]: 2, + [Species.DIGLETT]: 2, + [Species.MEOWTH]: 3, + [Species.PSYDUCK]: 2, + [Species.MANKEY]: 4, + [Species.GROWLITHE]: 4, + [Species.POLIWAG]: 2, + [Species.ABRA]: 4, + [Species.MACHOP]: 3, + [Species.BELLSPROUT]: 2, + [Species.TENTACOOL]: 3, + [Species.GEODUDE]: 3, + [Species.PONYTA]: 2, + [Species.SLOWPOKE]: 3, + [Species.MAGNEMITE]: 4, + [Species.FARFETCHD]: 2, + [Species.DODUO]: 3, + [Species.SEEL]: 1, + [Species.GRIMER]: 2, + [Species.SHELLDER]: 5, + [Species.GASTLY]: 4, + [Species.ONIX]: 3, + [Species.DROWZEE]: 2, + [Species.KRABBY]: 3, + [Species.VOLTORB]: 2, + [Species.EXEGGCUTE]: 3, + [Species.CUBONE]: 3, + [Species.HITMONLEE]: 4, + [Species.HITMONCHAN]: 4, + [Species.LICKITUNG]: 3, + [Species.KOFFING]: 2, + [Species.RHYHORN]: 3, + [Species.CHANSEY]: 3, + [Species.TANGELA]: 3, + [Species.KANGASKHAN]: 4, + [Species.HORSEA]: 3, + [Species.GOLDEEN]: 2, + [Species.STARYU]: 3, + [Species.MR_MIME]: 3, + [Species.SCYTHER]: 5, + [Species.JYNX]: 4, + [Species.ELECTABUZZ]: 4, + [Species.MAGMAR]: 4, + [Species.PINSIR]: 4, + [Species.TAUROS]: 4, + [Species.MAGIKARP]: 4, + [Species.LAPRAS]: 4, + [Species.DITTO]: 2, + [Species.EEVEE]: 3, + [Species.PORYGON]: 4, + [Species.OMANYTE]: 3, + [Species.KABUTO]: 3, + [Species.AERODACTYL]: 5, + [Species.SNORLAX]: 5, + [Species.ARTICUNO]: 6, + [Species.ZAPDOS]: 6, + [Species.MOLTRES]: 6, + [Species.DRATINI]: 4, + [Species.MEWTWO]: 8, + [Species.MEW]: 6, + + [Species.CHIKORITA]: 2, + [Species.CYNDAQUIL]: 3, + [Species.TOTODILE]: 3, + [Species.SENTRET]: 1, + [Species.HOOTHOOT]: 2, + [Species.LEDYBA]: 1, + [Species.SPINARAK]: 1, + [Species.CHINCHOU]: 2, + [Species.PICHU]: 2, + [Species.CLEFFA]: 2, + [Species.IGGLYBUFF]: 1, + [Species.TOGEPI]: 3, + [Species.NATU]: 2, + [Species.MAREEP]: 2, + [Species.MARILL]: 4, + [Species.SUDOWOODO]: 3, + [Species.HOPPIP]: 2, + [Species.AIPOM]: 2, + [Species.SUNKERN]: 1, + [Species.YANMA]: 3, + [Species.WOOPER]: 2, + [Species.MURKROW]: 3, + [Species.MISDREAVUS]: 2, + [Species.UNOWN]: 1, + [Species.WOBBUFFET]: 2, + [Species.GIRAFARIG]: 3, + [Species.PINECO]: 2, + [Species.DUNSPARCE]: 3, + [Species.GLIGAR]: 3, + [Species.SNUBBULL]: 2, + [Species.QWILFISH]: 3, + [Species.SHUCKLE]: 3, + [Species.HERACROSS]: 5, + [Species.SNEASEL]: 4, + [Species.TEDDIURSA]: 4, + [Species.SLUGMA]: 2, + [Species.SWINUB]: 3, + [Species.CORSOLA]: 2, + [Species.REMORAID]: 2, + [Species.DELIBIRD]: 2, + [Species.MANTINE]: 3, + [Species.SKARMORY]: 4, + [Species.HOUNDOUR]: 3, + [Species.PHANPY]: 3, + [Species.STANTLER]: 3, + [Species.SMEARGLE]: 1, + [Species.TYROGUE]: 3, + [Species.SMOOCHUM]: 3, + [Species.ELEKID]: 3, + [Species.MAGBY]: 3, + [Species.MILTANK]: 4, + [Species.RAIKOU]: 6, + [Species.ENTEI]: 6, + [Species.SUICUNE]: 6, + [Species.LARVITAR]: 4, + [Species.LUGIA]: 8, + [Species.HO_OH]: 8, + [Species.CELEBI]: 6, + + [Species.TREECKO]: 3, + [Species.TORCHIC]: 4, + [Species.MUDKIP]: 3, + [Species.POOCHYENA]: 2, + [Species.ZIGZAGOON]: 2, + [Species.WURMPLE]: 1, + [Species.LOTAD]: 3, + [Species.SEEDOT]: 2, + [Species.TAILLOW]: 3, + [Species.WINGULL]: 2, + [Species.RALTS]: 3, + [Species.SURSKIT]: 2, + [Species.SHROOMISH]: 3, + [Species.SLAKOTH]: 4, + [Species.NINCADA]: 4, + [Species.WHISMUR]: 2, + [Species.MAKUHITA]: 3, + [Species.AZURILL]: 4, + [Species.NOSEPASS]: 2, + [Species.SKITTY]: 1, + [Species.SABLEYE]: 2, + [Species.MAWILE]: 3, + [Species.ARON]: 3, + [Species.MEDITITE]: 3, + [Species.ELECTRIKE]: 2, + [Species.PLUSLE]: 2, + [Species.MINUN]: 2, + [Species.VOLBEAT]: 2, + [Species.ILLUMISE]: 2, + [Species.ROSELIA]: 3, + [Species.GULPIN]: 1, + [Species.CARVANHA]: 3, + [Species.WAILMER]: 2, + [Species.NUMEL]: 2, + [Species.TORKOAL]: 3, + [Species.SPOINK]: 2, + [Species.SPINDA]: 1, + [Species.TRAPINCH]: 3, + [Species.CACNEA]: 2, + [Species.SWABLU]: 2, + [Species.ZANGOOSE]: 4, + [Species.SEVIPER]: 3, + [Species.LUNATONE]: 3, + [Species.SOLROCK]: 3, + [Species.BARBOACH]: 2, + [Species.CORPHISH]: 3, + [Species.BALTOY]: 2, + [Species.LILEEP]: 3, + [Species.ANORITH]: 3, + [Species.FEEBAS]: 4, + [Species.CASTFORM]: 1, + [Species.KECLEON]: 2, + [Species.SHUPPET]: 2, + [Species.DUSKULL]: 3, + [Species.TROPIUS]: 3, + [Species.CHIMECHO]: 3, + [Species.ABSOL]: 4, + [Species.WYNAUT]: 2, + [Species.SNORUNT]: 2, + [Species.SPHEAL]: 2, + [Species.CLAMPERL]: 3, + [Species.RELICANTH]: 3, + [Species.LUVDISC]: 1, + [Species.BAGON]: 4, + [Species.BELDUM]: 4, + [Species.REGIROCK]: 6, + [Species.REGICE]: 6, + [Species.REGISTEEL]: 6, + [Species.LATIAS]: 7, + [Species.LATIOS]: 7, + [Species.KYOGRE]: 9, + [Species.GROUDON]: 9, + [Species.RAYQUAZA]: 9, + [Species.JIRACHI]: 7, + [Species.DEOXYS]: 7, + + [Species.TURTWIG]: 3, + [Species.CHIMCHAR]: 3, + [Species.PIPLUP]: 3, + [Species.STARLY]: 3, + [Species.BIDOOF]: 2, + [Species.KRICKETOT]: 1, + [Species.SHINX]: 2, + [Species.BUDEW]: 3, + [Species.CRANIDOS]: 3, + [Species.SHIELDON]: 3, + [Species.BURMY]: 2, + [Species.COMBEE]: 2, + [Species.PACHIRISU]: 2, + [Species.BUIZEL]: 2, + [Species.CHERUBI]: 1, + [Species.SHELLOS]: 3, + [Species.DRIFLOON]: 2, + [Species.BUNEARY]: 2, + [Species.GLAMEOW]: 2, + [Species.CHINGLING]: 2, + [Species.STUNKY]: 2, + [Species.BRONZOR]: 3, + [Species.BONSLY]: 2, + [Species.MIME_JR]: 2, + [Species.HAPPINY]: 2, + [Species.CHATOT]: 2, + [Species.SPIRITOMB]: 4, + [Species.GIBLE]: 4, + [Species.MUNCHLAX]: 4, + [Species.RIOLU]: 3, + [Species.HIPPOPOTAS]: 3, + [Species.SKORUPI]: 3, + [Species.CROAGUNK]: 2, + [Species.CARNIVINE]: 2, + [Species.FINNEON]: 1, + [Species.MANTYKE]: 2, + [Species.SNOVER]: 2, + [Species.ROTOM]: 5, + [Species.UXIE]: 6, + [Species.MESPRIT]: 6, + [Species.AZELF]: 6, + [Species.DIALGA]: 8, + [Species.PALKIA]: 8, + [Species.HEATRAN]: 6, + [Species.REGIGIGAS]: 7, + [Species.GIRATINA]: 8, + [Species.CRESSELIA]: 6, + [Species.PHIONE]: 4, + [Species.MANAPHY]: 7, + [Species.DARKRAI]: 7, + [Species.SHAYMIN]: 6, + [Species.ARCEUS]: 9, + + [Species.VICTINI]: 7, + [Species.SNIVY]: 3, + [Species.TEPIG]: 3, + [Species.OSHAWOTT]: 3, + [Species.PATRAT]: 1, + [Species.LILLIPUP]: 3, + [Species.PURRLOIN]: 2, + [Species.PANSAGE]: 2, + [Species.PANSEAR]: 2, + [Species.PANPOUR]: 2, + [Species.MUNNA]: 2, + [Species.PIDOVE]: 1, + [Species.BLITZLE]: 2, + [Species.ROGGENROLA]: 3, + [Species.WOOBAT]: 3, + [Species.DRILBUR]: 4, + [Species.AUDINO]: 3, + [Species.TIMBURR]: 4, + [Species.TYMPOLE]: 3, + [Species.THROH]: 4, + [Species.SAWK]: 4, + [Species.SEWADDLE]: 2, + [Species.VENIPEDE]: 3, + [Species.COTTONEE]: 3, + [Species.PETILIL]: 3, + [Species.BASCULIN]: 4, + [Species.SANDILE]: 4, + [Species.DARUMAKA]: 4, + [Species.MARACTUS]: 2, + [Species.DWEBBLE]: 2, + [Species.SCRAGGY]: 3, + [Species.SIGILYPH]: 4, + [Species.YAMASK]: 3, + [Species.TIRTOUGA]: 3, + [Species.ARCHEN]: 3, + [Species.TRUBBISH]: 2, + [Species.ZORUA]: 3, + [Species.MINCCINO]: 3, + [Species.GOTHITA]: 3, + [Species.SOLOSIS]: 3, + [Species.DUCKLETT]: 2, + [Species.VANILLITE]: 3, + [Species.DEERLING]: 2, + [Species.EMOLGA]: 2, + [Species.KARRABLAST]: 3, + [Species.FOONGUS]: 2, + [Species.FRILLISH]: 3, + [Species.ALOMOMOLA]: 4, + [Species.JOLTIK]: 3, + [Species.FERROSEED]: 3, + [Species.KLINK]: 3, + [Species.TYNAMO]: 2, + [Species.ELGYEM]: 2, + [Species.LITWICK]: 3, + [Species.AXEW]: 4, + [Species.CUBCHOO]: 2, + [Species.CRYOGONAL]: 4, + [Species.SHELMET]: 2, + [Species.STUNFISK]: 3, + [Species.MIENFOO]: 3, + [Species.DRUDDIGON]: 4, + [Species.GOLETT]: 3, + [Species.PAWNIARD]: 4, + [Species.BOUFFALANT]: 4, + [Species.RUFFLET]: 3, + [Species.VULLABY]: 3, + [Species.HEATMOR]: 3, + [Species.DURANT]: 4, + [Species.DEINO]: 4, + [Species.LARVESTA]: 4, + [Species.COBALION]: 6, + [Species.TERRAKION]: 6, + [Species.VIRIZION]: 6, + [Species.TORNADUS]: 7, + [Species.THUNDURUS]: 7, + [Species.RESHIRAM]: 8, + [Species.ZEKROM]: 8, + [Species.LANDORUS]: 7, + [Species.KYUREM]: 8, + [Species.KELDEO]: 6, + [Species.MELOETTA]: 7, + [Species.GENESECT]: 6, + + [Species.CHESPIN]: 3, + [Species.FENNEKIN]: 3, + [Species.FROAKIE]: 4, + [Species.BUNNELBY]: 3, + [Species.FLETCHLING]: 3, + [Species.SCATTERBUG]: 2, + [Species.LITLEO]: 2, + [Species.FLABEBE]: 3, + [Species.SKIDDO]: 2, + [Species.PANCHAM]: 3, + [Species.FURFROU]: 3, + [Species.ESPURR]: 2, + [Species.HONEDGE]: 4, + [Species.SPRITZEE]: 2, + [Species.SWIRLIX]: 3, + [Species.INKAY]: 3, + [Species.BINACLE]: 3, + [Species.SKRELP]: 2, + [Species.CLAUNCHER]: 3, + [Species.HELIOPTILE]: 3, + [Species.TYRUNT]: 3, + [Species.AMAURA]: 3, + [Species.HAWLUCHA]: 4, + [Species.DEDENNE]: 2, + [Species.CARBINK]: 2, + [Species.GOOMY]: 4, + [Species.KLEFKI]: 3, + [Species.PHANTUMP]: 2, + [Species.PUMPKABOO]: 2, + [Species.BERGMITE]: 3, + [Species.NOIBAT]: 3, + [Species.XERNEAS]: 8, + [Species.YVELTAL]: 8, + [Species.ZYGARDE]: 8, + [Species.DIANCIE]: 7, + [Species.HOOPA]: 7, + [Species.VOLCANION]: 6, + [Species.ETERNAL_FLOETTE]: 4, + + [Species.ROWLET]: 3, + [Species.LITTEN]: 3, + [Species.POPPLIO]: 4, + [Species.PIKIPEK]: 2, + [Species.YUNGOOS]: 2, + [Species.GRUBBIN]: 3, + [Species.CRABRAWLER]: 3, + [Species.ORICORIO]: 3, + [Species.CUTIEFLY]: 3, + [Species.ROCKRUFF]: 3, + [Species.WISHIWASHI]: 2, + [Species.MAREANIE]: 2, + [Species.MUDBRAY]: 3, + [Species.DEWPIDER]: 3, + [Species.FOMANTIS]: 2, + [Species.MORELULL]: 2, + [Species.SALANDIT]: 3, + [Species.STUFFUL]: 3, + [Species.BOUNSWEET]: 3, + [Species.COMFEY]: 4, + [Species.ORANGURU]: 4, + [Species.PASSIMIAN]: 4, + [Species.WIMPOD]: 3, + [Species.SANDYGAST]: 3, + [Species.PYUKUMUKU]: 2, + [Species.TYPE_NULL]: 5, + [Species.MINIOR]: 4, + [Species.KOMALA]: 3, + [Species.TURTONATOR]: 4, + [Species.TOGEDEMARU]: 3, + [Species.MIMIKYU]: 4, + [Species.BRUXISH]: 4, + [Species.DRAMPA]: 4, + [Species.DHELMISE]: 4, + [Species.JANGMO_O]: 4, + [Species.TAPU_KOKO]: 6, + [Species.TAPU_LELE]: 6, + [Species.TAPU_BULU]: 6, + [Species.TAPU_FINI]: 6, + [Species.COSMOG]: 7, + [Species.NIHILEGO]: 6, + [Species.BUZZWOLE]: 6, + [Species.PHEROMOSA]: 7, + [Species.XURKITREE]: 6, + [Species.CELESTEELA]: 6, + [Species.KARTANA]: 7, + [Species.GUZZLORD]: 6, + [Species.NECROZMA]: 8, + [Species.MAGEARNA]: 7, + [Species.MARSHADOW]: 7, + [Species.POIPOLE]: 7, + [Species.STAKATAKA]: 6, + [Species.BLACEPHALON]: 7, + [Species.ZERAORA]: 6, + [Species.MELTAN]: 6, + [Species.ALOLA_RATTATA]: 1, + [Species.ALOLA_SANDSHREW]: 2, + [Species.ALOLA_VULPIX]: 3, + [Species.ALOLA_DIGLETT]: 2, + [Species.ALOLA_MEOWTH]: 3, + [Species.ALOLA_GEODUDE]: 3, + [Species.ALOLA_GRIMER]: 3, + + [Species.GROOKEY]: 3, + [Species.SCORBUNNY]: 4, + [Species.SOBBLE]: 3, + [Species.SKWOVET]: 2, + [Species.ROOKIDEE]: 3, + [Species.BLIPBUG]: 2, + [Species.NICKIT]: 1, + [Species.GOSSIFLEUR]: 2, + [Species.WOOLOO]: 2, + [Species.CHEWTLE]: 3, + [Species.YAMPER]: 2, + [Species.ROLYCOLY]: 3, + [Species.APPLIN]: 3, + [Species.SILICOBRA]: 3, + [Species.CRAMORANT]: 3, + [Species.ARROKUDA]: 3, + [Species.TOXEL]: 3, + [Species.SIZZLIPEDE]: 3, + [Species.CLOBBOPUS]: 2, + [Species.SINISTEA]: 3, + [Species.HATENNA]: 3, + [Species.IMPIDIMP]: 3, + [Species.MILCERY]: 3, + [Species.FALINKS]: 4, + [Species.PINCURCHIN]: 3, + [Species.SNOM]: 3, + [Species.STONJOURNER]: 3, + [Species.EISCUE]: 3, + [Species.INDEEDEE]: 4, + [Species.MORPEKO]: 3, + [Species.CUFANT]: 3, + [Species.DRACOZOLT]: 5, + [Species.ARCTOZOLT]: 4, + [Species.DRACOVISH]: 5, + [Species.ARCTOVISH]: 4, + [Species.DURALUDON]: 5, + [Species.DREEPY]: 4, + [Species.ZACIAN]: 9, + [Species.ZAMAZENTA]: 8, + [Species.ETERNATUS]: 10, + [Species.KUBFU]: 6, + [Species.ZARUDE]: 6, + [Species.REGIELEKI]: 6, + [Species.REGIDRAGO]: 6, + [Species.GLASTRIER]: 6, + [Species.SPECTRIER]: 7, + [Species.CALYREX]: 8, + [Species.GALAR_MEOWTH]: 3, + [Species.GALAR_PONYTA]: 2, + [Species.GALAR_SLOWPOKE]: 3, + [Species.GALAR_FARFETCHD]: 3, + [Species.GALAR_CORSOLA]: 3, + [Species.GALAR_ZIGZAGOON]: 3, + [Species.GALAR_DARUMAKA]: 4, + [Species.GALAR_YAMASK]: 3, + [Species.GALAR_STUNFISK]: 2, + [Species.GALAR_MR_MIME]: 3, + [Species.GALAR_ARTICUNO]: 6, + [Species.GALAR_ZAPDOS]: 6, + [Species.GALAR_MOLTRES]: 6, + [Species.HISUI_GROWLITHE]: 4, + [Species.HISUI_VOLTORB]: 3, + [Species.HISUI_QWILFISH]: 4, + [Species.HISUI_SNEASEL]: 5, + [Species.HISUI_ZORUA]: 3, + [Species.ENAMORUS]: 7, + + [Species.SPRIGATITO]: 4, + [Species.FUECOCO]: 4, + [Species.QUAXLY]: 4, + [Species.LECHONK]: 2, + [Species.TAROUNTULA]: 1, + [Species.NYMBLE]: 3, + [Species.PAWMI]: 3, + [Species.TANDEMAUS]: 4, + [Species.FIDOUGH]: 2, + [Species.SMOLIV]: 3, + [Species.SQUAWKABILLY]: 2, + [Species.NACLI]: 4, + [Species.CHARCADET]: 4, + [Species.TADBULB]: 3, + [Species.WATTREL]: 3, + [Species.MASCHIFF]: 3, + [Species.SHROODLE]: 2, + [Species.BRAMBLIN]: 3, + [Species.TOEDSCOOL]: 3, + [Species.KLAWF]: 3, + [Species.CAPSAKID]: 3, + [Species.RELLOR]: 2, + [Species.FLITTLE]: 3, + [Species.TINKATINK]: 4, + [Species.WIGLETT]: 2, + [Species.BOMBIRDIER]: 3, + [Species.FINIZEN]: 3, + [Species.VAROOM]: 4, + [Species.CYCLIZAR]: 4, + [Species.ORTHWORM]: 4, + [Species.GLIMMET]: 4, + [Species.GREAVARD]: 3, + [Species.FLAMIGO]: 4, + [Species.CETODDLE]: 3, + [Species.VELUZA]: 4, + [Species.DONDOZO]: 4, + [Species.TATSUGIRI]: 4, + [Species.GREAT_TUSK]: 6, + [Species.SCREAM_TAIL]: 6, + [Species.BRUTE_BONNET]: 6, + [Species.FLUTTER_MANE]: 7, + [Species.SLITHER_WING]: 6, + [Species.SANDY_SHOCKS]: 6, + [Species.IRON_TREADS]: 6, + [Species.IRON_BUNDLE]: 6, + [Species.IRON_HANDS]: 6, + [Species.IRON_JUGULIS]: 6, + [Species.IRON_MOTH]: 6, + [Species.IRON_THORNS]: 6, + [Species.FRIGIBAX]: 4, + [Species.GIMMIGHOUL]: 4, + [Species.WO_CHIEN]: 6, + [Species.CHIEN_PAO]: 7, + [Species.TING_LU]: 6, + [Species.CHI_YU]: 7, + [Species.ROARING_MOON]: 6, + [Species.IRON_VALIANT]: 6, + [Species.KORAIDON]: 9, + [Species.MIRAIDON]: 9, + [Species.WALKING_WAKE]: 6, + [Species.IRON_LEAVES]: 6, + [Species.POLTCHAGEIST]: 4, + [Species.OKIDOGI]: 6, + [Species.MUNKIDORI]: 6, + [Species.FEZANDIPITI]: 6, + [Species.OGERPON]: 7, + [Species.GOUGING_FIRE]: 7, + [Species.RAGING_BOLT]: 6, + [Species.IRON_BOULDER]: 7, + [Species.IRON_CROWN]: 6, + [Species.TERAPAGOS]: 8, + [Species.PECHARUNT]: 6, + [Species.PALDEA_TAUROS]: 5, + [Species.PALDEA_WOOPER]: 3, + [Species.BLOODMOON_URSALUNA]: 6, +}; + +const starterCandyCosts: { passive: number; costReduction: [number, number]; egg: number; }[] = [ + { passive: 40, costReduction: [ 25, 60 ], egg: 30 }, // 1 Cost + { passive: 40, costReduction: [ 25, 60 ], egg: 30 }, // 2 Cost + { passive: 35, costReduction: [ 20, 50 ], egg: 25 }, // 3 Cost + { passive: 30, costReduction: [ 15, 40 ], egg: 20 }, // 4 Cost + { passive: 25, costReduction: [ 12, 35 ], egg: 18 }, // 5 Cost + { passive: 20, costReduction: [ 10, 30 ], egg: 15 }, // 6 Cost + { passive: 15, costReduction: [ 8, 20 ], egg: 12 }, // 7 Cost + { passive: 10, costReduction: [ 5, 15 ], egg: 10 }, // 8 Cost + { passive: 10, costReduction: [ 5, 15 ], egg: 10 }, // 9 Cost + { passive: 10, costReduction: [ 5, 15 ], egg: 10 }, // 10 Cost +]; + +/** + * Getter for {@linkcode starterCandyCosts} for passive unlock candy cost based on initial point cost + * @param starterCost the default point cost of the starter found in {@linkcode speciesStarterCosts} + * @returns the candy cost for passive unlock + */ +export function getPassiveCandyCount(starterCost: number): number { + return starterCandyCosts[starterCost - 1].passive; +} + +/** + * Getter for {@linkcode starterCandyCosts} for value reduction unlock candy cost based on initial point cost + * @param starterCost the default point cost of the starter found in {@linkcode speciesStarterCosts} + * @returns respective candy cost for the two cost reductions as an array 2 numbers + */ +export function getValueReductionCandyCounts(starterCost: number): [number, number] { + return starterCandyCosts[starterCost - 1].costReduction; +} + +/** + * Getter for {@linkcode starterCandyCosts} for egg purchase candy cost based on initial point cost + * @param starterCost the default point cost of the starter found in {@linkcode speciesStarterCosts} + * @returns the candy cost for the purchasable egg + */ +export function getSameSpeciesEggCandyCounts(starterCost: number): number { + return starterCandyCosts[starterCost - 1].egg; +} + diff --git a/src/data/tms.ts b/src/data/balance/tms.ts similarity index 98% rename from src/data/tms.ts rename to src/data/balance/tms.ts index 9dea6d74a86..4882cf4f652 100644 --- a/src/data/tms.ts +++ b/src/data/balance/tms.ts @@ -1,4 +1,4 @@ -import { ModifierTier } from "../modifier/modifier-tier"; +import { ModifierTier } from "#app/modifier/modifier-tier"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; @@ -1107,12 +1107,7 @@ export const tmSpecies: TmSpecies = { Species.QUILLADIN, Species.CHESNAUGHT, Species.FROGADIER, - [ - Species.GRENINJA, - "", - "battle-bond", - "ash", - ], + Species.GRENINJA, Species.BUNNELBY, Species.DIGGERSBY, Species.FLETCHLING, @@ -2878,12 +2873,7 @@ export const tmSpecies: TmSpecies = { Species.DELPHOX, Species.FROAKIE, Species.FROGADIER, - [ - Species.GRENINJA, - "", - "battle-bond", - "ash", - ], + Species.GRENINJA, Species.BUNNELBY, Species.DIGGERSBY, Species.FLETCHLING, @@ -3312,11 +3302,23 @@ export const tmSpecies: TmSpecies = { Species.FERALIGATR, Species.SENTRET, Species.FURRET, + Species.HOOTHOOT, Species.NOCTOWL, + Species.LEDYBA, + Species.LEDIAN, + Species.SPINARAK, + Species.ARIADOS, Species.CROBAT, Species.CHINCHOU, Species.LANTURN, + Species.PICHU, + Species.CLEFFA, Species.IGGLYBUFF, + Species.TYROGUE, + Species.TOGEPI, + Species.TOGETIC, + Species.NATU, + Species.XATU, Species.MAREEP, Species.FLAAFFY, Species.AMPHAROS, @@ -3338,6 +3340,7 @@ export const tmSpecies: TmSpecies = { Species.UMBREON, Species.MURKROW, Species.SLOWKING, + Species.MISDREAVUS, Species.GIRAFARIG, Species.PINECO, Species.FORRETRESS, @@ -3348,11 +3351,21 @@ export const tmSpecies: TmSpecies = { Species.GRANBULL, Species.QWILFISH, Species.SCIZOR, + Species.SHUCKLE, Species.HERACROSS, + Species.SNEASEL, Species.TEDDIURSA, Species.URSARING, + Species.SLUGMA, + Species.MAGCARGO, Species.SWINUB, Species.PILOSWINE, + Species.CORSOLA, + Species.REMORAID, + Species.OCTILLERY, + Species.DELIBIRD, + Species.MANTINE, + Species.SKARMORY, Species.HOUNDOUR, Species.HOUNDOOM, Species.KINGDRA, @@ -3360,9 +3373,12 @@ export const tmSpecies: TmSpecies = { Species.DONPHAN, Species.PORYGON2, Species.STANTLER, + Species.TYROGUE, Species.HITMONTOP, + Species.SMOOCHUM, Species.ELEKID, Species.MAGBY, + Species.MILTANK, Species.BLISSEY, Species.RAIKOU, Species.ENTEI, @@ -3372,6 +3388,9 @@ export const tmSpecies: TmSpecies = { Species.TYRANITAR, Species.LUGIA, Species.HO_OH, + Species.CELEBI, + Species.TREECKO, + Species.GROVYLE, Species.SCEPTILE, Species.TORCHIC, Species.COMBUSKEN, @@ -3381,41 +3400,116 @@ export const tmSpecies: TmSpecies = { Species.SWAMPERT, Species.POOCHYENA, Species.MIGHTYENA, + Species.ZIGZAGOON, + Species.LINOONE, + Species.BEAUTIFLY, + Species.DUSTOX, Species.LOTAD, Species.LOMBRE, Species.LUDICOLO, Species.SEEDOT, Species.NUZLEAF, Species.SHIFTRY, + Species.TAILLOW, + Species.SWELLOW, + Species.WINGULL, + Species.PELIPPER, + Species.RALTS, + Species.KIRLIA, + Species.GARDEVOIR, + Species.SURSKIT, + Species.MASQUERAIN, + Species.SHROOMISH, + Species.BRELOOM, Species.VIGOROTH, Species.SLAKING, + Species.NINCADA, + Species.NINJASK, + Species.SHEDINJA, + Species.WHISMUR, + Species.LOUDRED, + Species.EXPLOUD, Species.MAKUHITA, Species.HARIYAMA, + Species.AZURILL, Species.NOSEPASS, + Species.SKITTY, + Species.DELCATTY, + Species.SABLEYE, + Species.MAWILE, + Species.ARON, + Species.LAIRON, + Species.AGGRON, + Species.MEDITITE, + Species.MEDICHAM, + Species.ELECTRIKE, + Species.MANECTRIC, + Species.PLUSLE, + Species.MINUN, Species.VOLBEAT, Species.ILLUMISE, + Species.ROSELIA, + Species.GULPIN, Species.SWALOT, + Species.CARVANHA, + Species.SHARPEDO, + Species.WAILMER, + Species.WAILORD, Species.NUMEL, Species.CAMERUPT, Species.TORKOAL, + Species.SPOINK, + Species.GRUMPIG, + Species.SPINDA, + Species.TRAPINCH, + Species.VIBRAVA, Species.FLYGON, + Species.CACNEA, + Species.CACTURNE, + Species.SWABLU, Species.ALTARIA, Species.ZANGOOSE, Species.SEVIPER, + Species.LUNATONE, + Species.SOLROCK, Species.BARBOACH, Species.WHISCASH, Species.CORPHISH, Species.CRAWDAUNT, + Species.BALTOY, + Species.CLAYDOL, + Species.LILEEP, + Species.CRADILY, + Species.ANORITH, + Species.ARMALDO, Species.FEEBAS, Species.MILOTIC, + Species.CASTFORM, + Species.KECLEON, + Species.SHUPPET, + Species.BANETTE, + Species.DUSKULL, + Species.DUSCLOPS, Species.TROPIUS, Species.CHIMECHO, + Species.ABSOL, + Species.SNORUNT, + Species.GLALIE, + Species.SPHEAL, + Species.SEALEO, + Species.WALREIN, + Species.CLAMPERL, + Species.HUNTAIL, + Species.GOREBYSS, + Species.RELICANTH, + Species.LUVDISC, Species.BAGON, Species.SHELGON, Species.SALAMENCE, Species.METANG, Species.METAGROSS, Species.REGIROCK, + Species.REGICE, Species.REGISTEEL, Species.LATIAS, Species.LATIOS, @@ -3423,6 +3517,7 @@ export const tmSpecies: TmSpecies = { Species.GROUDON, Species.RAYQUAZA, Species.JIRACHI, + Species.DEOXYS, Species.TURTWIG, Species.GROTLE, Species.TORTERRA, @@ -3910,7 +4005,6 @@ export const tmSpecies: TmSpecies = { Species.YAMPER, Species.BOLTUND, Species.ZAMAZENTA, - Species.URSHIFU, Species.ZARUDE, Species.GLASTRIER, Species.WYRDEER, @@ -3940,6 +4034,10 @@ export const tmSpecies: TmSpecies = { Species.ALOLA_NINETALES, Species.ALOLA_PERSIAN, Species.ALOLA_GOLEM, + [ + Species.URSHIFU, + "single-strike", + ], Species.HISUI_GROWLITHE, Species.HISUI_ARCANINE, Species.HISUI_TYPHLOSION, @@ -6987,14 +7085,7 @@ export const tmSpecies: TmSpecies = { Species.LITLEO, Species.PYROAR, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.SKIDDO, Species.GOGOAT, @@ -8301,7 +8392,6 @@ export const tmSpecies: TmSpecies = { [ Species.WORMADAM, "sandy", - "trash", ], Species.ALOLA_SANDSHREW, Species.ALOLA_SANDSLASH, @@ -8612,12 +8702,7 @@ export const tmSpecies: TmSpecies = { Species.CHESNAUGHT, Species.FROAKIE, Species.FROGADIER, - [ - Species.GRENINJA, - "", - "battle-bond", - "ash", - ], + Species.GRENINJA, Species.BUNNELBY, Species.DIGGERSBY, Species.LITLEO, @@ -9406,14 +9491,7 @@ export const tmSpecies: TmSpecies = { Species.LITLEO, Species.PYROAR, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.SKIDDO, Species.GOGOAT, @@ -9766,14 +9844,7 @@ export const tmSpecies: TmSpecies = { Species.DELPHOX, Species.VIVILLON, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.ESPURR, Species.MEOWSTIC, @@ -11147,14 +11218,7 @@ export const tmSpecies: TmSpecies = { Species.LITLEO, Species.PYROAR, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.SKIDDO, Species.GOGOAT, @@ -12359,6 +12423,7 @@ export const tmSpecies: TmSpecies = { Species.TURTWIG, Species.GROTLE, Species.TORTERRA, + Species.BASTIODON, Species.CHINGLING, Species.BRONZOR, Species.BRONZONG, @@ -12366,6 +12431,7 @@ export const tmSpecies: TmSpecies = { Species.WEAVILE, Species.MAGNEZONE, Species.TANGROWTH, + Species.ELECTIVIRE, Species.TOGEKISS, Species.MAMOSWINE, Species.GALLADE, @@ -12398,6 +12464,8 @@ export const tmSpecies: TmSpecies = { Species.CRYOGONAL, Species.MIENFOO, Species.MIENSHAO, + Species.GOLETT, + Species.GOLURK, Species.HYDREIGON, Species.COBALION, Species.TERRAKION, @@ -13657,12 +13725,7 @@ export const tmSpecies: TmSpecies = { Species.DELPHOX, Species.FROAKIE, Species.FROGADIER, - [ - Species.GRENINJA, - "", - "battle-bond", - "ash", - ], + Species.GRENINJA, Species.FLETCHLING, Species.FLETCHINDER, Species.TALONFLAME, @@ -15326,14 +15389,7 @@ export const tmSpecies: TmSpecies = { Species.LITLEO, Species.PYROAR, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.SKIDDO, Species.GOGOAT, @@ -16934,14 +16990,7 @@ export const tmSpecies: TmSpecies = { Species.LITLEO, Species.PYROAR, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.SKIDDO, Species.GOGOAT, @@ -18483,14 +18532,7 @@ export const tmSpecies: TmSpecies = { Species.LITLEO, Species.PYROAR, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.SKIDDO, Species.GOGOAT, @@ -20250,14 +20292,7 @@ export const tmSpecies: TmSpecies = { Species.LITLEO, Species.PYROAR, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.SKIDDO, Species.GOGOAT, @@ -21583,12 +21618,7 @@ export const tmSpecies: TmSpecies = { Species.DELPHOX, Species.FROAKIE, Species.FROGADIER, - [ - Species.GRENINJA, - "", - "battle-bond", - "ash", - ], + Species.GRENINJA, Species.BUNNELBY, Species.DIGGERSBY, Species.LITLEO, @@ -22516,7 +22546,6 @@ export const tmSpecies: TmSpecies = { [ Species.WORMADAM, "sandy", - "trash", ], Species.ALOLA_DIGLETT, Species.ALOLA_DUGTRIO, @@ -22691,14 +22720,7 @@ export const tmSpecies: TmSpecies = { Species.CHESNAUGHT, Species.VIVILLON, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.SKIDDO, Species.GOGOAT, @@ -23402,12 +23424,7 @@ export const tmSpecies: TmSpecies = { Species.DELPHOX, Species.FROAKIE, Species.FROGADIER, - [ - Species.GRENINJA, - "", - "battle-bond", - "ash", - ], + Species.GRENINJA, Species.BUNNELBY, Species.DIGGERSBY, Species.FLETCHLING, @@ -24134,12 +24151,7 @@ export const tmSpecies: TmSpecies = { Species.KELDEO, Species.FROAKIE, Species.FROGADIER, - [ - Species.GRENINJA, - "", - "battle-bond", - "ash", - ], + Species.GRENINJA, Species.PANCHAM, Species.PANGORO, Species.HONEDGE, @@ -24842,14 +24854,7 @@ export const tmSpecies: TmSpecies = { Species.LITLEO, Species.PYROAR, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.SKIDDO, Species.GOGOAT, @@ -25712,14 +25717,7 @@ export const tmSpecies: TmSpecies = { Species.LITLEO, Species.PYROAR, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.SKIDDO, Species.GOGOAT, @@ -26695,14 +26693,7 @@ export const tmSpecies: TmSpecies = { Species.LITLEO, Species.PYROAR, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.SKIDDO, Species.GOGOAT, @@ -27845,14 +27836,7 @@ export const tmSpecies: TmSpecies = { Species.LITLEO, Species.PYROAR, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.SKIDDO, Species.GOGOAT, @@ -28911,14 +28895,7 @@ export const tmSpecies: TmSpecies = { Species.LITLEO, Species.PYROAR, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.SKIDDO, Species.GOGOAT, @@ -29514,14 +29491,7 @@ export const tmSpecies: TmSpecies = { Species.DELPHOX, Species.VIVILLON, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.ESPURR, Species.MEOWSTIC, @@ -31408,14 +31378,7 @@ export const tmSpecies: TmSpecies = { Species.LITLEO, Species.PYROAR, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.SKIDDO, Species.GOGOAT, @@ -32327,14 +32290,7 @@ export const tmSpecies: TmSpecies = { Species.LITLEO, Species.PYROAR, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.SKIDDO, Species.GOGOAT, @@ -33037,14 +32993,7 @@ export const tmSpecies: TmSpecies = { Species.LITLEO, Species.PYROAR, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.SKIDDO, Species.GOGOAT, @@ -33471,7 +33420,6 @@ export const tmSpecies: TmSpecies = { Species.ARCTOVISH, Species.ZACIAN, Species.ZAMAZENTA, - Species.URSHIFU, Species.ZARUDE, Species.REGIDRAGO, Species.GLASTRIER, @@ -33522,6 +33470,10 @@ export const tmSpecies: TmSpecies = { Species.ALOLA_MUK, Species.GALAR_MEOWTH, Species.GALAR_STUNFISK, + [ + Species.URSHIFU, + "single-strike", + ], [ Species.CALYREX, "ice", @@ -36644,14 +36596,7 @@ export const tmSpecies: TmSpecies = { Species.LITLEO, Species.PYROAR, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.SKIDDO, Species.GOGOAT, @@ -37389,14 +37334,7 @@ export const tmSpecies: TmSpecies = { Species.BUNNELBY, Species.DIGGERSBY, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.SKIDDO, Species.GOGOAT, @@ -38266,23 +38204,11 @@ export const tmSpecies: TmSpecies = { Species.DELPHOX, Species.FROAKIE, Species.FROGADIER, - [ - Species.GRENINJA, - "", - "battle-bond", - "ash", - ], + Species.GRENINJA, Species.LITLEO, Species.PYROAR, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.SKIDDO, Species.GOGOAT, @@ -39323,12 +39249,7 @@ export const tmSpecies: TmSpecies = { Species.CHESPIN, Species.QUILLADIN, Species.CHESNAUGHT, - [ - Species.GRENINJA, - "", - "battle-bond", - "ash", - ], + Species.GRENINJA, Species.BUNNELBY, Species.DIGGERSBY, Species.SKIDDO, @@ -40356,7 +40277,10 @@ export const tmSpecies: TmSpecies = { Species.FENNEKIN, Species.BRAIXEN, Species.DELPHOX, - Species.MEOWSTIC, + [ + Species.MEOWSTIC, + "male", + ], Species.KLEFKI, Species.PHANTUMP, Species.TREVENANT, @@ -40418,6 +40342,1065 @@ export const tmSpecies: TmSpecies = { Species.HISUI_ZORUA, Species.HISUI_ZOROARK, ], + [Moves.SECRET_POWER]: [ + Species.BULBASAUR, + Species.IVYSAUR, + Species.VENUSAUR, + Species.CHARMANDER, + Species.CHARMELEON, + Species.CHARIZARD, + Species.SQUIRTLE, + Species.WARTORTLE, + Species.BLASTOISE, + Species.BUTTERFREE, + Species.BEEDRILL, + Species.PIDGEY, + Species.PIDGEOTTO, + Species.PIDGEOT, + Species.RATTATA, + Species.RATICATE, + Species.SPEAROW, + Species.FEAROW, + Species.EKANS, + Species.ARBOK, + Species.PIKACHU, + Species.RAICHU, + Species.SANDSHREW, + Species.SANDSLASH, + Species.NIDORAN_F, + Species.NIDORINA, + Species.NIDOQUEEN, + Species.NIDORAN_M, + Species.NIDORINO, + Species.NIDOKING, + Species.CLEFAIRY, + Species.CLEFABLE, + Species.VULPIX, + Species.NINETALES, + Species.JIGGLYPUFF, + Species.WIGGLYTUFF, + Species.ZUBAT, + Species.GOLBAT, + Species.ODDISH, + Species.GLOOM, + Species.VILEPLUME, + Species.PARAS, + Species.PARASECT, + Species.VENONAT, + Species.VENOMOTH, + Species.DIGLETT, + Species.DUGTRIO, + Species.MEOWTH, + Species.PERSIAN, + Species.PSYDUCK, + Species.GOLDUCK, + Species.MANKEY, + Species.PRIMEAPE, + Species.GROWLITHE, + Species.ARCANINE, + Species.POLIWAG, + Species.POLIWHIRL, + Species.POLIWRATH, + Species.ABRA, + Species.KADABRA, + Species.ALAKAZAM, + Species.MACHOP, + Species.MACHOKE, + Species.MACHAMP, + Species.BELLSPROUT, + Species.WEEPINBELL, + Species.VICTREEBEL, + Species.TENTACOOL, + Species.TENTACRUEL, + Species.GEODUDE, + Species.GRAVELER, + Species.GOLEM, + Species.PONYTA, + Species.RAPIDASH, + Species.SLOWPOKE, + Species.SLOWBRO, + Species.MAGNEMITE, + Species.MAGNETON, + Species.FARFETCHD, + Species.DODUO, + Species.DODRIO, + Species.SEEL, + Species.DEWGONG, + Species.GRIMER, + Species.MUK, + Species.SHELLDER, + Species.CLOYSTER, + Species.GASTLY, + Species.HAUNTER, + Species.GENGAR, + Species.ONIX, + Species.DROWZEE, + Species.HYPNO, + Species.KRABBY, + Species.KINGLER, + Species.VOLTORB, + Species.ELECTRODE, + Species.EXEGGCUTE, + Species.EXEGGUTOR, + Species.CUBONE, + Species.MAROWAK, + Species.HITMONLEE, + Species.HITMONCHAN, + Species.LICKITUNG, + Species.KOFFING, + Species.WEEZING, + Species.RHYHORN, + Species.RHYDON, + Species.CHANSEY, + Species.TANGELA, + Species.KANGASKHAN, + Species.HORSEA, + Species.SEADRA, + Species.GOLDEEN, + Species.SEAKING, + Species.STARYU, + Species.STARMIE, + Species.MR_MIME, + Species.SCYTHER, + Species.JYNX, + Species.ELECTABUZZ, + Species.MAGMAR, + Species.PINSIR, + Species.TAUROS, + Species.GYARADOS, + Species.LAPRAS, + Species.EEVEE, + Species.VAPOREON, + Species.JOLTEON, + Species.FLAREON, + Species.PORYGON, + Species.OMANYTE, + Species.OMASTAR, + Species.KABUTO, + Species.KABUTOPS, + Species.AERODACTYL, + Species.SNORLAX, + Species.ARTICUNO, + Species.ZAPDOS, + Species.MOLTRES, + Species.DRATINI, + Species.DRAGONAIR, + Species.DRAGONITE, + Species.MEWTWO, + Species.MEW, + Species.CHIKORITA, + Species.BAYLEEF, + Species.MEGANIUM, + Species.CYNDAQUIL, + Species.QUILAVA, + Species.TYPHLOSION, + Species.TOTODILE, + Species.CROCONAW, + Species.FERALIGATR, + Species.SENTRET, + Species.FURRET, + Species.HOOTHOOT, + Species.NOCTOWL, + Species.LEDYBA, + Species.LEDIAN, + Species.SPINARAK, + Species.ARIADOS, + Species.CROBAT, + Species.CHINCHOU, + Species.LANTURN, + Species.PICHU, + Species.CLEFFA, + Species.IGGLYBUFF, + Species.TOGEPI, + Species.TOGETIC, + Species.NATU, + Species.XATU, + Species.MAREEP, + Species.FLAAFFY, + Species.AMPHAROS, + Species.BELLOSSOM, + Species.MARILL, + Species.AZUMARILL, + Species.SUDOWOODO, + Species.POLITOED, + Species.HOPPIP, + Species.SKIPLOOM, + Species.JUMPLUFF, + Species.AIPOM, + Species.SUNKERN, + Species.SUNFLORA, + Species.YANMA, + Species.WOOPER, + Species.QUAGSIRE, + Species.ESPEON, + Species.UMBREON, + Species.MURKROW, + Species.SLOWKING, + Species.MISDREAVUS, + Species.GIRAFARIG, + Species.PINECO, + Species.FORRETRESS, + Species.DUNSPARCE, + Species.GLIGAR, + Species.STEELIX, + Species.SNUBBULL, + Species.GRANBULL, + Species.QWILFISH, + Species.SCIZOR, + Species.SHUCKLE, + Species.HERACROSS, + Species.SNEASEL, + Species.TEDDIURSA, + Species.URSARING, + Species.SLUGMA, + Species.MAGCARGO, + Species.SWINUB, + Species.PILOSWINE, + Species.CORSOLA, + Species.REMORAID, + Species.OCTILLERY, + Species.DELIBIRD, + Species.MANTINE, + Species.SKARMORY, + Species.HOUNDOUR, + Species.HOUNDOOM, + Species.KINGDRA, + Species.PHANPY, + Species.DONPHAN, + Species.PORYGON2, + Species.STANTLER, + Species.TYROGUE, + Species.HITMONTOP, + Species.SMOOCHUM, + Species.ELEKID, + Species.MAGBY, + Species.MILTANK, + Species.BLISSEY, + Species.RAIKOU, + Species.ENTEI, + Species.SUICUNE, + Species.LARVITAR, + Species.PUPITAR, + Species.TYRANITAR, + Species.LUGIA, + Species.HO_OH, + Species.CELEBI, + Species.TREECKO, + Species.GROVYLE, + Species.SCEPTILE, + Species.TORCHIC, + Species.COMBUSKEN, + Species.BLAZIKEN, + Species.MUDKIP, + Species.MARSHTOMP, + Species.SWAMPERT, + Species.POOCHYENA, + Species.MIGHTYENA, + Species.ZIGZAGOON, + Species.LINOONE, + Species.BEAUTIFLY, + Species.DUSTOX, + Species.LOTAD, + Species.LOMBRE, + Species.LUDICOLO, + Species.SEEDOT, + Species.NUZLEAF, + Species.SHIFTRY, + Species.TAILLOW, + Species.SWELLOW, + Species.WINGULL, + Species.PELIPPER, + Species.RALTS, + Species.KIRLIA, + Species.GARDEVOIR, + Species.SURSKIT, + Species.MASQUERAIN, + Species.SHROOMISH, + Species.BRELOOM, + Species.SLAKOTH, + Species.VIGOROTH, + Species.SLAKING, + Species.NINCADA, + Species.NINJASK, + Species.SHEDINJA, + Species.WHISMUR, + Species.LOUDRED, + Species.EXPLOUD, + Species.MAKUHITA, + Species.HARIYAMA, + Species.AZURILL, + Species.NOSEPASS, + Species.SKITTY, + Species.DELCATTY, + Species.SABLEYE, + Species.MAWILE, + Species.ARON, + Species.LAIRON, + Species.AGGRON, + Species.MEDITITE, + Species.MEDICHAM, + Species.ELECTRIKE, + Species.MANECTRIC, + Species.PLUSLE, + Species.MINUN, + Species.VOLBEAT, + Species.ILLUMISE, + Species.ROSELIA, + Species.GULPIN, + Species.SWALOT, + Species.CARVANHA, + Species.SHARPEDO, + Species.WAILMER, + Species.WAILORD, + Species.NUMEL, + Species.CAMERUPT, + Species.TORKOAL, + Species.SPOINK, + Species.GRUMPIG, + Species.SPINDA, + Species.TRAPINCH, + Species.VIBRAVA, + Species.FLYGON, + Species.CACNEA, + Species.CACTURNE, + Species.SWABLU, + Species.ALTARIA, + Species.ZANGOOSE, + Species.SEVIPER, + Species.LUNATONE, + Species.SOLROCK, + Species.BARBOACH, + Species.WHISCASH, + Species.CORPHISH, + Species.CRAWDAUNT, + Species.BALTOY, + Species.CLAYDOL, + Species.LILEEP, + Species.CRADILY, + Species.ANORITH, + Species.ARMALDO, + Species.FEEBAS, + Species.MILOTIC, + Species.CASTFORM, + Species.KECLEON, + Species.SHUPPET, + Species.BANETTE, + Species.DUSKULL, + Species.DUSCLOPS, + Species.TROPIUS, + Species.CHIMECHO, + Species.ABSOL, + Species.SNORUNT, + Species.GLALIE, + Species.SPHEAL, + Species.SEALEO, + Species.WALREIN, + Species.CLAMPERL, + Species.HUNTAIL, + Species.GOREBYSS, + Species.RELICANTH, + Species.LUVDISC, + Species.BAGON, + Species.SHELGON, + Species.SALAMENCE, + Species.METANG, + Species.METAGROSS, + Species.REGIROCK, + Species.REGICE, + Species.REGISTEEL, + Species.LATIAS, + Species.LATIOS, + Species.KYOGRE, + Species.GROUDON, + Species.RAYQUAZA, + Species.JIRACHI, + Species.DEOXYS, + Species.TURTWIG, + Species.GROTLE, + Species.TORTERRA, + Species.CHIMCHAR, + Species.MONFERNO, + Species.INFERNAPE, + Species.PIPLUP, + Species.PRINPLUP, + Species.EMPOLEON, + Species.STARLY, + Species.STARAVIA, + Species.STARAPTOR, + Species.BIDOOF, + Species.BIBAREL, + Species.KRICKETUNE, + Species.SHINX, + Species.LUXIO, + Species.LUXRAY, + Species.BUDEW, + Species.ROSERADE, + Species.CRANIDOS, + Species.RAMPARDOS, + Species.SHIELDON, + Species.BASTIODON, + Species.WORMADAM, + Species.MOTHIM, + Species.VESPIQUEN, + Species.PACHIRISU, + Species.BUIZEL, + Species.FLOATZEL, + Species.CHERUBI, + Species.CHERRIM, + Species.SHELLOS, + Species.GASTRODON, + Species.AMBIPOM, + Species.DRIFLOON, + Species.DRIFBLIM, + Species.BUNEARY, + Species.LOPUNNY, + Species.MISMAGIUS, + Species.HONCHKROW, + Species.GLAMEOW, + Species.PURUGLY, + Species.CHINGLING, + Species.STUNKY, + Species.SKUNTANK, + Species.BRONZOR, + Species.BRONZONG, + Species.BONSLY, + Species.MIME_JR, + Species.HAPPINY, + Species.CHATOT, + Species.SPIRITOMB, + Species.GIBLE, + Species.GABITE, + Species.GARCHOMP, + Species.MUNCHLAX, + Species.RIOLU, + Species.LUCARIO, + Species.HIPPOPOTAS, + Species.HIPPOWDON, + Species.SKORUPI, + Species.DRAPION, + Species.CROAGUNK, + Species.TOXICROAK, + Species.CARNIVINE, + Species.FINNEON, + Species.LUMINEON, + Species.MANTYKE, + Species.SNOVER, + Species.ABOMASNOW, + Species.WEAVILE, + Species.MAGNEZONE, + Species.LICKILICKY, + Species.RHYPERIOR, + Species.TANGROWTH, + Species.ELECTIVIRE, + Species.MAGMORTAR, + Species.TOGEKISS, + Species.YANMEGA, + Species.LEAFEON, + Species.GLACEON, + Species.GLISCOR, + Species.MAMOSWINE, + Species.PORYGON_Z, + Species.GALLADE, + Species.PROBOPASS, + Species.DUSKNOIR, + Species.FROSLASS, + Species.ROTOM, + Species.UXIE, + Species.MESPRIT, + Species.AZELF, + Species.DIALGA, + Species.PALKIA, + Species.HEATRAN, + Species.REGIGIGAS, + Species.GIRATINA, + Species.CRESSELIA, + Species.PHIONE, + Species.MANAPHY, + Species.DARKRAI, + Species.SHAYMIN, + Species.ARCEUS, + Species.VICTINI, + Species.SNIVY, + Species.SERVINE, + Species.SERPERIOR, + Species.TEPIG, + Species.PIGNITE, + Species.EMBOAR, + Species.OSHAWOTT, + Species.DEWOTT, + Species.SAMUROTT, + Species.PATRAT, + Species.WATCHOG, + Species.LILLIPUP, + Species.HERDIER, + Species.STOUTLAND, + Species.PURRLOIN, + Species.LIEPARD, + Species.PANSAGE, + Species.SIMISAGE, + Species.PANSEAR, + Species.SIMISEAR, + Species.PANPOUR, + Species.SIMIPOUR, + Species.MUNNA, + Species.MUSHARNA, + Species.PIDOVE, + Species.TRANQUILL, + Species.UNFEZANT, + Species.BLITZLE, + Species.ZEBSTRIKA, + Species.ROGGENROLA, + Species.BOLDORE, + Species.GIGALITH, + Species.WOOBAT, + Species.SWOOBAT, + Species.DRILBUR, + Species.EXCADRILL, + Species.AUDINO, + Species.TIMBURR, + Species.GURDURR, + Species.CONKELDURR, + Species.TYMPOLE, + Species.PALPITOAD, + Species.SEISMITOAD, + Species.THROH, + Species.SAWK, + Species.SEWADDLE, + Species.SWADLOON, + Species.LEAVANNY, + Species.VENIPEDE, + Species.WHIRLIPEDE, + Species.SCOLIPEDE, + Species.COTTONEE, + Species.WHIMSICOTT, + Species.PETILIL, + Species.LILLIGANT, + Species.BASCULIN, + Species.SANDILE, + Species.KROKOROK, + Species.KROOKODILE, + Species.DARUMAKA, + Species.DARMANITAN, + Species.MARACTUS, + Species.DWEBBLE, + Species.CRUSTLE, + Species.SCRAGGY, + Species.SCRAFTY, + Species.SIGILYPH, + Species.YAMASK, + Species.COFAGRIGUS, + Species.TIRTOUGA, + Species.CARRACOSTA, + Species.ARCHEN, + Species.ARCHEOPS, + Species.TRUBBISH, + Species.GARBODOR, + Species.ZORUA, + Species.ZOROARK, + Species.MINCCINO, + Species.CINCCINO, + Species.GOTHITA, + Species.GOTHORITA, + Species.GOTHITELLE, + Species.SOLOSIS, + Species.DUOSION, + Species.REUNICLUS, + Species.DUCKLETT, + Species.SWANNA, + Species.VANILLITE, + Species.VANILLISH, + Species.VANILLUXE, + Species.DEERLING, + Species.SAWSBUCK, + Species.EMOLGA, + Species.KARRABLAST, + Species.ESCAVALIER, + Species.FOONGUS, + Species.AMOONGUSS, + Species.FRILLISH, + Species.JELLICENT, + Species.ALOMOMOLA, + Species.JOLTIK, + Species.GALVANTULA, + Species.FERROSEED, + Species.FERROTHORN, + Species.KLINK, + Species.KLANG, + Species.KLINKLANG, + Species.EELEKTRIK, + Species.EELEKTROSS, + Species.ELGYEM, + Species.BEHEEYEM, + Species.LITWICK, + Species.LAMPENT, + Species.CHANDELURE, + Species.AXEW, + Species.FRAXURE, + Species.HAXORUS, + Species.CUBCHOO, + Species.BEARTIC, + Species.CRYOGONAL, + Species.SHELMET, + Species.ACCELGOR, + Species.STUNFISK, + Species.MIENFOO, + Species.MIENSHAO, + Species.DRUDDIGON, + Species.GOLETT, + Species.GOLURK, + Species.PAWNIARD, + Species.BISHARP, + Species.BOUFFALANT, + Species.RUFFLET, + Species.BRAVIARY, + Species.VULLABY, + Species.MANDIBUZZ, + Species.HEATMOR, + Species.DURANT, + Species.DEINO, + Species.ZWEILOUS, + Species.HYDREIGON, + Species.LARVESTA, + Species.VOLCARONA, + Species.COBALION, + Species.TERRAKION, + Species.VIRIZION, + Species.TORNADUS, + Species.THUNDURUS, + Species.RESHIRAM, + Species.ZEKROM, + Species.LANDORUS, + Species.KYUREM, + Species.KELDEO, + Species.MELOETTA, + Species.GENESECT, + Species.CHESPIN, + Species.QUILLADIN, + Species.CHESNAUGHT, + Species.FENNEKIN, + Species.BRAIXEN, + Species.DELPHOX, + Species.FROAKIE, + Species.FROGADIER, + Species.GRENINJA, + Species.BUNNELBY, + Species.DIGGERSBY, + Species.FLETCHLING, + Species.FLETCHINDER, + Species.TALONFLAME, + Species.VIVILLON, + Species.LITLEO, + Species.PYROAR, + Species.FLABEBE, + Species.FLOETTE, + Species.FLORGES, + Species.SKIDDO, + Species.GOGOAT, + Species.PANCHAM, + Species.PANGORO, + Species.FURFROU, + Species.ESPURR, + Species.MEOWSTIC, + Species.HONEDGE, + Species.DOUBLADE, + Species.AEGISLASH, + Species.SPRITZEE, + Species.AROMATISSE, + Species.SWIRLIX, + Species.SLURPUFF, + Species.INKAY, + Species.MALAMAR, + Species.BINACLE, + Species.BARBARACLE, + Species.SKRELP, + Species.DRAGALGE, + Species.CLAUNCHER, + Species.CLAWITZER, + Species.HELIOPTILE, + Species.HELIOLISK, + Species.TYRUNT, + Species.TYRANTRUM, + Species.AMAURA, + Species.AURORUS, + Species.SYLVEON, + Species.HAWLUCHA, + Species.DEDENNE, + Species.CARBINK, + Species.GOOMY, + Species.SLIGGOO, + Species.GOODRA, + Species.KLEFKI, + Species.PHANTUMP, + Species.TREVENANT, + Species.PUMPKABOO, + Species.GOURGEIST, + Species.BERGMITE, + Species.AVALUGG, + Species.NOIBAT, + Species.NOIVERN, + Species.XERNEAS, + Species.YVELTAL, + Species.ZYGARDE, + Species.DIANCIE, + Species.HOOPA, + Species.VOLCANION, + Species.ROWLET, + Species.DARTRIX, + Species.DECIDUEYE, + Species.LITTEN, + Species.TORRACAT, + Species.INCINEROAR, + Species.POPPLIO, + Species.BRIONNE, + Species.PRIMARINA, + Species.PIKIPEK, + Species.TRUMBEAK, + Species.TOUCANNON, + Species.YUNGOOS, + Species.GUMSHOOS, + Species.GRUBBIN, + Species.CHARJABUG, + Species.VIKAVOLT, + Species.CRABRAWLER, + Species.CRABOMINABLE, + Species.ORICORIO, + Species.CUTIEFLY, + Species.RIBOMBEE, + Species.ROCKRUFF, + Species.LYCANROC, + Species.WISHIWASHI, + Species.MAREANIE, + Species.TOXAPEX, + Species.MUDBRAY, + Species.MUDSDALE, + Species.DEWPIDER, + Species.ARAQUANID, + Species.FOMANTIS, + Species.LURANTIS, + Species.MORELULL, + Species.SHIINOTIC, + Species.SALANDIT, + Species.SALAZZLE, + Species.STUFFUL, + Species.BEWEAR, + Species.BOUNSWEET, + Species.STEENEE, + Species.TSAREENA, + Species.COMFEY, + Species.ORANGURU, + Species.PASSIMIAN, + Species.WIMPOD, + Species.GOLISOPOD, + Species.SANDYGAST, + Species.PALOSSAND, + Species.TYPE_NULL, + Species.SILVALLY, + Species.MINIOR, + Species.KOMALA, + Species.TURTONATOR, + Species.TOGEDEMARU, + Species.MIMIKYU, + Species.BRUXISH, + Species.DRAMPA, + Species.DHELMISE, + Species.JANGMO_O, + Species.HAKAMO_O, + Species.KOMMO_O, + Species.TAPU_KOKO, + Species.TAPU_LELE, + Species.TAPU_BULU, + Species.TAPU_FINI, + Species.SOLGALEO, + Species.LUNALA, + Species.NIHILEGO, + Species.BUZZWOLE, + Species.PHEROMOSA, + Species.XURKITREE, + Species.CELESTEELA, + Species.KARTANA, + Species.GUZZLORD, + Species.NECROZMA, + Species.MAGEARNA, + Species.MARSHADOW, + Species.POIPOLE, + Species.NAGANADEL, + Species.STAKATAKA, + Species.BLACEPHALON, + Species.ZERAORA, + Species.MELTAN, + Species.MELMETAL, + Species.GROOKEY, + Species.THWACKEY, + Species.RILLABOOM, + Species.SCORBUNNY, + Species.RABOOT, + Species.CINDERACE, + Species.SOBBLE, + Species.DRIZZILE, + Species.INTELEON, + Species.SKWOVET, + Species.GREEDENT, + Species.ROOKIDEE, + Species.CORVISQUIRE, + Species.CORVIKNIGHT, + Species.DOTTLER, + Species.ORBEETLE, + Species.NICKIT, + Species.THIEVUL, + Species.GOSSIFLEUR, + Species.ELDEGOSS, + Species.WOOLOO, + Species.DUBWOOL, + Species.CHEWTLE, + Species.DREDNAW, + Species.YAMPER, + Species.BOLTUND, + Species.ROLYCOLY, + Species.CARKOL, + Species.COALOSSAL, + Species.FLAPPLE, + Species.APPLETUN, + Species.SILICOBRA, + Species.SANDACONDA, + Species.CRAMORANT, + Species.ARROKUDA, + Species.BARRASKEWDA, + Species.TOXEL, + Species.TOXTRICITY, + Species.SIZZLIPEDE, + Species.CENTISKORCH, + Species.CLOBBOPUS, + Species.GRAPPLOCT, + Species.SINISTEA, + Species.POLTEAGEIST, + Species.HATENNA, + Species.HATTREM, + Species.HATTERENE, + Species.IMPIDIMP, + Species.MORGREM, + Species.GRIMMSNARL, + Species.OBSTAGOON, + Species.PERRSERKER, + Species.CURSOLA, + Species.SIRFETCHD, + Species.MR_RIME, + Species.RUNERIGUS, + Species.MILCERY, + Species.ALCREMIE, + Species.FALINKS, + Species.PINCURCHIN, + Species.SNOM, + Species.FROSMOTH, + Species.STONJOURNER, + Species.EISCUE, + Species.INDEEDEE, + Species.MORPEKO, + Species.CUFANT, + Species.COPPERAJAH, + Species.DRACOZOLT, + Species.ARCTOZOLT, + Species.DRACOVISH, + Species.ARCTOVISH, + Species.DURALUDON, + Species.DREEPY, + Species.DRAKLOAK, + Species.DRAGAPULT, + Species.ZACIAN, + Species.ZAMAZENTA, + Species.ETERNATUS, + Species.KUBFU, + Species.URSHIFU, + Species.ZARUDE, + Species.REGIELEKI, + Species.REGIDRAGO, + Species.GLASTRIER, + Species.SPECTRIER, + Species.CALYREX, + Species.WYRDEER, + Species.KLEAVOR, + Species.URSALUNA, + Species.BASCULEGION, + Species.SNEASLER, + Species.OVERQWIL, + Species.ENAMORUS, + Species.SPRIGATITO, + Species.FLORAGATO, + Species.MEOWSCARADA, + Species.FUECOCO, + Species.CROCALOR, + Species.SKELEDIRGE, + Species.QUAXLY, + Species.QUAXWELL, + Species.QUAQUAVAL, + Species.LECHONK, + Species.OINKOLOGNE, + Species.TAROUNTULA, + Species.SPIDOPS, + Species.NYMBLE, + Species.LOKIX, + Species.PAWMI, + Species.PAWMO, + Species.PAWMOT, + Species.TANDEMAUS, + Species.MAUSHOLD, + Species.FIDOUGH, + Species.DACHSBUN, + Species.SMOLIV, + Species.DOLLIV, + Species.ARBOLIVA, + Species.SQUAWKABILLY, + Species.NACLI, + Species.NACLSTACK, + Species.GARGANACL, + Species.CHARCADET, + Species.ARMAROUGE, + Species.CERULEDGE, + Species.TADBULB, + Species.BELLIBOLT, + Species.WATTREL, + Species.KILOWATTREL, + Species.MASCHIFF, + Species.MABOSSTIFF, + Species.SHROODLE, + Species.GRAFAIAI, + Species.BRAMBLIN, + Species.BRAMBLEGHAST, + Species.TOEDSCOOL, + Species.TOEDSCRUEL, + Species.KLAWF, + Species.CAPSAKID, + Species.SCOVILLAIN, + Species.RELLOR, + Species.RABSCA, + Species.FLITTLE, + Species.ESPATHRA, + Species.TINKATINK, + Species.TINKATUFF, + Species.TINKATON, + Species.WIGLETT, + Species.WUGTRIO, + Species.BOMBIRDIER, + Species.FINIZEN, + Species.PALAFIN, + Species.VAROOM, + Species.REVAVROOM, + Species.CYCLIZAR, + Species.ORTHWORM, + Species.GLIMMET, + Species.GLIMMORA, + Species.GREAVARD, + Species.HOUNDSTONE, + Species.FLAMIGO, + Species.CETODDLE, + Species.CETITAN, + Species.VELUZA, + Species.DONDOZO, + Species.TATSUGIRI, + Species.ANNIHILAPE, + Species.CLODSIRE, + Species.FARIGIRAF, + Species.DUDUNSPARCE, + Species.KINGAMBIT, + Species.GREAT_TUSK, + Species.SCREAM_TAIL, + Species.BRUTE_BONNET, + Species.FLUTTER_MANE, + Species.SLITHER_WING, + Species.SANDY_SHOCKS, + Species.IRON_TREADS, + Species.IRON_BUNDLE, + Species.IRON_HANDS, + Species.IRON_JUGULIS, + Species.IRON_MOTH, + Species.IRON_THORNS, + Species.FRIGIBAX, + Species.ARCTIBAX, + Species.BAXCALIBUR, + Species.GIMMIGHOUL, + Species.GHOLDENGO, + Species.WO_CHIEN, + Species.CHIEN_PAO, + Species.TING_LU, + Species.CHI_YU, + Species.ROARING_MOON, + Species.IRON_VALIANT, + Species.KORAIDON, + Species.MIRAIDON, + Species.WALKING_WAKE, + Species.IRON_LEAVES, + Species.DIPPLIN, + Species.POLTCHAGEIST, + Species.SINISTCHA, + Species.OKIDOGI, + Species.MUNKIDORI, + Species.FEZANDIPITI, + Species.OGERPON, + Species.ARCHALUDON, + Species.HYDRAPPLE, + Species.GOUGING_FIRE, + Species.RAGING_BOLT, + Species.IRON_BOULDER, + Species.IRON_CROWN, + Species.TERAPAGOS, + Species.PECHARUNT, + Species.ALOLA_RATTATA, + Species.ALOLA_RATICATE, + Species.ALOLA_RAICHU, + Species.ALOLA_SANDSHREW, + Species.ALOLA_SANDSLASH, + Species.ALOLA_VULPIX, + Species.ALOLA_NINETALES, + Species.ALOLA_DIGLETT, + Species.ALOLA_DUGTRIO, + Species.ALOLA_MEOWTH, + Species.ALOLA_PERSIAN, + Species.ALOLA_GEODUDE, + Species.ALOLA_GRAVELER, + Species.ALOLA_GOLEM, + Species.ALOLA_GRIMER, + Species.ALOLA_MUK, + Species.ALOLA_EXEGGUTOR, + Species.ALOLA_MAROWAK, + Species.ETERNAL_FLOETTE, + Species.GALAR_MEOWTH, + Species.GALAR_PONYTA, + Species.GALAR_RAPIDASH, + Species.GALAR_SLOWPOKE, + Species.GALAR_SLOWBRO, + Species.GALAR_FARFETCHD, + Species.GALAR_WEEZING, + Species.GALAR_MR_MIME, + Species.GALAR_ARTICUNO, + Species.GALAR_ZAPDOS, + Species.GALAR_MOLTRES, + Species.GALAR_SLOWKING, + Species.GALAR_CORSOLA, + Species.GALAR_ZIGZAGOON, + Species.GALAR_LINOONE, + Species.GALAR_DARUMAKA, + Species.GALAR_DARMANITAN, + Species.GALAR_YAMASK, + Species.GALAR_STUNFISK, + Species.HISUI_GROWLITHE, + Species.HISUI_ARCANINE, + Species.HISUI_VOLTORB, + Species.HISUI_ELECTRODE, + Species.HISUI_TYPHLOSION, + Species.HISUI_QWILFISH, + Species.HISUI_SNEASEL, + Species.HISUI_SAMUROTT, + Species.HISUI_LILLIGANT, + Species.HISUI_ZORUA, + Species.HISUI_ZOROARK, + Species.HISUI_BRAVIARY, + Species.HISUI_SLIGGOO, + Species.HISUI_GOODRA, + Species.HISUI_AVALUGG, + Species.HISUI_DECIDUEYE, + Species.PALDEA_TAUROS, + Species.PALDEA_WOOPER, + Species.BLOODMOON_URSALUNA, + ], [Moves.DIVE]: [ Species.SQUIRTLE, Species.WARTORTLE, @@ -41805,7 +42788,6 @@ export const tmSpecies: TmSpecies = { [ Species.WORMADAM, "sandy", - "trash", ], Species.ALOLA_SANDSHREW, Species.ALOLA_SANDSLASH, @@ -43701,12 +44683,7 @@ export const tmSpecies: TmSpecies = { Species.DELPHOX, Species.FROAKIE, Species.FROGADIER, - [ - Species.GRENINJA, - "", - "battle-bond", - "ash", - ], + Species.GRENINJA, Species.BUNNELBY, Species.DIGGERSBY, Species.SKIDDO, @@ -44160,14 +45137,7 @@ export const tmSpecies: TmSpecies = { Species.QUILLADIN, Species.CHESNAUGHT, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.SKIDDO, Species.GOGOAT, @@ -44377,14 +45347,7 @@ export const tmSpecies: TmSpecies = { Species.DELPHOX, Species.VIVILLON, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.ESPURR, Species.MEOWSTIC, @@ -45256,6 +46219,10 @@ export const tmSpecies: TmSpecies = { Species.IRON_CROWN, Species.TERAPAGOS, Species.ALOLA_EXEGGUTOR, + [ + Species.INDEEDEE, + "male", + ], ], [Moves.GYRO_BALL]: [ Species.SQUIRTLE, @@ -47501,12 +48468,7 @@ export const tmSpecies: TmSpecies = { Species.ACCELGOR, Species.FROAKIE, Species.FROGADIER, - [ - Species.GRENINJA, - "", - "battle-bond", - "ash", - ], + Species.GRENINJA, Species.SKRELP, Species.DRAGALGE, Species.MAREANIE, @@ -48143,7 +49105,6 @@ export const tmSpecies: TmSpecies = { Species.RUNERIGUS, Species.MORPEKO, Species.DURALUDON, - Species.URSHIFU, Species.ZARUDE, Species.SPECTRIER, Species.OVERQWIL, @@ -48179,6 +49140,10 @@ export const tmSpecies: TmSpecies = { Species.GALAR_WEEZING, Species.GALAR_MOLTRES, Species.GALAR_YAMASK, + [ + Species.URSHIFU, + "single-strike", + ], [ Species.CALYREX, "shadow", @@ -48456,14 +49421,7 @@ export const tmSpecies: TmSpecies = { Species.QUILLADIN, Species.CHESNAUGHT, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.SKIDDO, Species.GOGOAT, @@ -49622,7 +50580,10 @@ export const tmSpecies: TmSpecies = { Species.TORTERRA, Species.BUDEW, Species.ROSERADE, - Species.WORMADAM, + [ + Species.WORMADAM, + "plant", + ], Species.MOTHIM, Species.CHERUBI, Species.CHERRIM, @@ -49698,14 +50659,7 @@ export const tmSpecies: TmSpecies = { Species.CHESNAUGHT, Species.VIVILLON, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.SKIDDO, Species.GOGOAT, @@ -52635,7 +53589,10 @@ export const tmSpecies: TmSpecies = { Species.TORTERRA, Species.BUDEW, Species.ROSERADE, - Species.WORMADAM, + [ + Species.WORMADAM, + "plant", + ], Species.SNOVER, Species.ABOMASNOW, Species.TANGROWTH, @@ -53751,7 +54708,10 @@ export const tmSpecies: TmSpecies = { Species.BIBAREL, Species.BUDEW, Species.ROSERADE, - Species.WORMADAM, + [ + Species.WORMADAM, + "plant", + ], Species.PACHIRISU, Species.CHERUBI, Species.CHERRIM, @@ -53863,14 +54823,7 @@ export const tmSpecies: TmSpecies = { Species.BUNNELBY, Species.DIGGERSBY, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.SKIDDO, Species.GOGOAT, @@ -55590,12 +56543,7 @@ export const tmSpecies: TmSpecies = { Species.CHESPIN, Species.QUILLADIN, Species.CHESNAUGHT, - [ - Species.GRENINJA, - "", - "battle-bond", - "ash", - ], + Species.GRENINJA, Species.PANCHAM, Species.PANGORO, Species.HELIOPTILE, @@ -55877,7 +56825,6 @@ export const tmSpecies: TmSpecies = { Species.MR_RIME, Species.MORPEKO, Species.DURALUDON, - Species.URSHIFU, Species.SPECTRIER, Species.MEOWSCARADA, Species.SQUAWKABILLY, @@ -55918,6 +56865,10 @@ export const tmSpecies: TmSpecies = { Species.GALAR_MOLTRES, Species.GALAR_SLOWKING, Species.GALAR_STUNFISK, + [ + Species.URSHIFU, + "single-strike", + ], [ Species.CALYREX, "shadow", @@ -56577,14 +57528,7 @@ export const tmSpecies: TmSpecies = { Species.LITLEO, Species.PYROAR, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.SKIDDO, Species.GOGOAT, @@ -57019,14 +57963,7 @@ export const tmSpecies: TmSpecies = { Species.LITLEO, Species.PYROAR, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.PANCHAM, Species.PANGORO, @@ -57354,14 +58291,7 @@ export const tmSpecies: TmSpecies = { Species.BRAIXEN, Species.DELPHOX, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.ESPURR, Species.MEOWSTIC, @@ -58997,7 +59927,6 @@ export const tmSpecies: TmSpecies = { [ Species.WORMADAM, "sandy", - "trash", ], Species.ALOLA_SANDSHREW, Species.ALOLA_SANDSLASH, @@ -59768,26 +60697,6 @@ export const tmSpecies: TmSpecies = { Species.HISUI_SAMUROTT, Species.PALDEA_TAUROS, ], - [Moves.SACRED_SWORD]: [ - Species.GALLADE, - Species.OSHAWOTT, - Species.DEWOTT, - Species.SAMUROTT, - Species.COBALION, - Species.TERRAKION, - Species.VIRIZION, - Species.KELDEO, - Species.HONEDGE, - Species.DOUBLADE, - Species.AEGISLASH, - Species.KARTANA, - Species.ZACIAN, - Species.CHIEN_PAO, - Species.IRON_LEAVES, - Species.IRON_BOULDER, - Species.IRON_CROWN, - Species.HISUI_SAMUROTT, - ], [Moves.RAZOR_SHELL]: [ Species.SLOWBRO, Species.SHELLDER, @@ -60070,7 +60979,6 @@ export const tmSpecies: TmSpecies = { Species.DURALUDON, Species.ZACIAN, Species.ZAMAZENTA, - Species.URSHIFU, Species.ZARUDE, Species.GLASTRIER, Species.SPECTRIER, @@ -60116,6 +61024,10 @@ export const tmSpecies: TmSpecies = { Species.HISUI_ZOROARK, Species.HISUI_BRAVIARY, Species.BLOODMOON_URSALUNA, + [ + Species.URSHIFU, + "single-strike", + ], ], [Moves.PHANTOM_FORCE]: [ Species.HAUNTER, @@ -60446,14 +61358,7 @@ export const tmSpecies: TmSpecies = { Species.QUILLADIN, Species.CHESNAUGHT, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.SKIDDO, Species.GOGOAT, @@ -60529,16 +61434,12 @@ export const tmSpecies: TmSpecies = { Species.WHIMSICOTT, Species.ALOMOMOLA, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, - Species.MEOWSTIC, + [ + Species.MEOWSTIC, + "male", + ], Species.SPRITZEE, Species.AROMATISSE, Species.SYLVEON, @@ -61402,14 +62303,7 @@ export const tmSpecies: TmSpecies = { Species.LITLEO, Species.PYROAR, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.SKIDDO, Species.GOGOAT, @@ -61899,14 +62793,7 @@ export const tmSpecies: TmSpecies = { Species.MELOETTA, Species.DELPHOX, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.SPRITZEE, Species.AROMATISSE, @@ -62617,7 +63504,6 @@ export const tmSpecies: TmSpecies = { Species.SIRFETCHD, Species.FALINKS, Species.PINCURCHIN, - Species.URSHIFU, Species.ZARUDE, Species.GLASTRIER, Species.TAROUNTULA, @@ -62647,6 +63533,10 @@ export const tmSpecies: TmSpecies = { Species.GALAR_ZAPDOS, Species.GALAR_CORSOLA, Species.GALAR_LINOONE, + [ + Species.URSHIFU, + "single-strike", + ], [ Species.CALYREX, "ice", @@ -63461,12 +64351,16 @@ export const tmSpecies: TmSpecies = { Species.BLOODMOON_URSALUNA, ], [Moves.LIQUIDATION]: [ + Species.SQUIRTLE, + Species.WARTORTLE, Species.BLASTOISE, Species.PSYDUCK, Species.GOLDUCK, Species.POLIWAG, Species.POLIWHIRL, Species.POLIWRATH, + Species.TENTACOOL, + Species.TENTACRUEL, Species.SLOWPOKE, Species.SLOWBRO, Species.DEWGONG, @@ -63482,7 +64376,11 @@ export const tmSpecies: TmSpecies = { Species.KABUTO, Species.KABUTOPS, Species.MEW, + Species.TOTODILE, + Species.CROCONAW, Species.FERALIGATR, + Species.CHINCHOU, + Species.LANTURN, Species.MARILL, Species.AZUMARILL, Species.POLITOED, @@ -63495,6 +64393,9 @@ export const tmSpecies: TmSpecies = { Species.MANTINE, Species.KINGDRA, Species.SUICUNE, + Species.LUGIA, + Species.MUDKIP, + Species.MARSHTOMP, Species.SWAMPERT, Species.WINGULL, Species.PELIPPER, @@ -63511,6 +64412,8 @@ export const tmSpecies: TmSpecies = { Species.WALREIN, Species.RELICANTH, Species.LUVDISC, + Species.LATIAS, + Species.LATIOS, Species.KYOGRE, Species.PIPLUP, Species.PRINPLUP, @@ -63541,12 +64444,7 @@ export const tmSpecies: TmSpecies = { Species.KELDEO, Species.FROAKIE, Species.FROGADIER, - [ - Species.GRENINJA, - "", - "battle-bond", - "ash", - ], + Species.GRENINJA, Species.INKAY, Species.MALAMAR, Species.BINACLE, @@ -63627,11 +64525,13 @@ export const tmSpecies: TmSpecies = { Species.ONIX, Species.HYPNO, Species.LICKITUNG, + Species.RHYHORN, Species.RHYDON, Species.LAPRAS, Species.SNORLAX, Species.DRAGONITE, Species.MEW, + Species.MEGANIUM, Species.SUDOWOODO, Species.QUAGSIRE, Species.FORRETRESS, @@ -63665,6 +64565,8 @@ export const tmSpecies: TmSpecies = { Species.REGISTEEL, Species.GROUDON, Species.TORTERRA, + Species.RAMPARDOS, + Species.BASTIODON, Species.BRONZONG, Species.HIPPOPOTAS, Species.HIPPOWDON, @@ -63679,6 +64581,7 @@ export const tmSpecies: TmSpecies = { Species.HEATRAN, Species.REGIGIGAS, Species.ARCEUS, + Species.EMBOAR, Species.ROGGENROLA, Species.BOLDORE, Species.GIGALITH, @@ -63691,6 +64594,7 @@ export const tmSpecies: TmSpecies = { Species.CUBCHOO, Species.BEARTIC, Species.GOLURK, + Species.COBALION, Species.RESHIRAM, Species.ZEKROM, Species.KYUREM, @@ -64755,7 +65659,6 @@ export const tmSpecies: TmSpecies = { Species.OBSTAGOON, Species.PERRSERKER, Species.MORPEKO, - Species.URSHIFU, Species.ZARUDE, Species.GLASTRIER, Species.SPECTRIER, @@ -64803,6 +65706,10 @@ export const tmSpecies: TmSpecies = { Species.GALAR_LINOONE, Species.GALAR_DARMANITAN, Species.GALAR_STUNFISK, + [ + Species.URSHIFU, + "single-strike", + ], [ Species.CALYREX, "ice", @@ -65933,12 +66840,7 @@ export const tmSpecies: TmSpecies = { Species.DELPHOX, Species.FROAKIE, Species.FROGADIER, - [ - Species.GRENINJA, - "", - "battle-bond", - "ash", - ], + Species.GRENINJA, Species.BUNNELBY, Species.DIGGERSBY, Species.FLETCHLING, @@ -65950,14 +66852,7 @@ export const tmSpecies: TmSpecies = { Species.LITLEO, Species.PYROAR, Species.FLABEBE, - [ - Species.FLOETTE, - "red", - "yellow", - "orange", - "blue", - "white", - ], + Species.FLOETTE, Species.FLORGES, Species.SKIDDO, Species.GOGOAT, @@ -66291,6 +67186,13 @@ export const tmSpecies: TmSpecies = { Species.MUNKIDORI, Species.FEZANDIPITI, Species.OGERPON, + Species.ARCHALUDON, + Species.HYDRAPPLE, + Species.GOUGING_FIRE, + Species.RAGING_BOLT, + Species.IRON_BOULDER, + Species.IRON_CROWN, + Species.PECHARUNT, Species.GALAR_MEOWTH, Species.GALAR_SLOWPOKE, Species.GALAR_SLOWBRO, @@ -66429,16 +67331,8 @@ export const tmSpecies: TmSpecies = { Species.PIPLUP, Species.PRINPLUP, Species.EMPOLEON, - [ - Species.SHELLOS, - "east", - "west", - ], - [ - Species.GASTRODON, - "east", - "west", - ], + Species.SHELLOS, + Species.GASTRODON, Species.MISMAGIUS, Species.HAPPINY, Species.SNOVER, @@ -66456,25 +67350,11 @@ export const tmSpecies: TmSpecies = { Species.CUBCHOO, Species.BEARTIC, Species.CRYOGONAL, - [ - Species.TORNADUS, - "incarnate", - "therian", - ], - [ - Species.KYUREM, - "", - "black", - "white", - ], + Species.TORNADUS, + Species.KYUREM, Species.FROAKIE, Species.FROGADIER, - [ - Species.GRENINJA, - "", - "battle-bond", - "ash", - ], + Species.GRENINJA, Species.SKRELP, Species.DRAGALGE, Species.BERGMITE, @@ -66482,11 +67362,7 @@ export const tmSpecies: TmSpecies = { Species.DIANCIE, Species.PRIMARINA, Species.CRABOMINABLE, - [ - Species.MAGEARNA, - "", - "original", - ], + Species.MAGEARNA, Species.INTELEON, Species.FROSMOTH, Species.EISCUE, @@ -66779,12 +67655,7 @@ export const tmSpecies: TmSpecies = { Species.CHESNAUGHT, Species.FROAKIE, Species.FROGADIER, - [ - Species.GRENINJA, - "", - "battle-bond", - "ash", - ], + Species.GRENINJA, Species.LITLEO, Species.PYROAR, Species.FLABEBE, @@ -67007,23 +67878,14 @@ export const tmSpecies: TmSpecies = { Species.WEAVILE, Species.GLACEON, Species.FROSLASS, - [ - Species.PALKIA, - "", - "origin", - ], + Species.PALKIA, Species.PHIONE, Species.MANAPHY, Species.ARCEUS, Species.OSHAWOTT, Species.DEWOTT, Species.SAMUROTT, - [ - Species.BASCULIN, - "red-striped", - "blue-striped", - "white-striped", - ], + Species.BASCULIN, Species.MINCCINO, Species.CINCCINO, Species.DUCKLETT, @@ -67036,12 +67898,7 @@ export const tmSpecies: TmSpecies = { Species.KELDEO, Species.FROAKIE, Species.FROGADIER, - [ - Species.GRENINJA, - "", - "battle-bond", - "ash", - ], + Species.GRENINJA, Species.FLABEBE, Species.FLOETTE, Species.FLORGES, @@ -67304,6 +68161,10 @@ export const tmSpecies: TmSpecies = { Species.FEZANDIPITI, Species.ALOLA_RAICHU, Species.ETERNAL_FLOETTE, + [ + Species.INDEEDEE, + "female", + ], ], [Moves.TEMPER_FLARE]: [ Species.CHARMANDER, @@ -67695,6 +68556,7 @@ export const tmPoolTiers: TmPoolTiers = { [Moves.ENDEAVOR]: ModifierTier.COMMON, [Moves.SKILL_SWAP]: ModifierTier.COMMON, [Moves.IMPRISON]: ModifierTier.COMMON, + [Moves.SECRET_POWER]: ModifierTier.COMMON, [Moves.DIVE]: ModifierTier.GREAT, [Moves.FEATHER_DANCE]: ModifierTier.COMMON, [Moves.BLAZE_KICK]: ModifierTier.GREAT, @@ -67823,7 +68685,6 @@ export const tmPoolTiers: TmPoolTiers = { [Moves.ELECTROWEB]: ModifierTier.GREAT, [Moves.WILD_CHARGE]: ModifierTier.GREAT, [Moves.DRILL_RUN]: ModifierTier.GREAT, - [Moves.SACRED_SWORD]: ModifierTier.ULTRA, [Moves.RAZOR_SHELL]: ModifierTier.GREAT, [Moves.HEAT_CRASH]: ModifierTier.GREAT, [Moves.TAIL_SLAP]: ModifierTier.GREAT, diff --git a/src/data/battle-anims.ts b/src/data/battle-anims.ts index d972e48df7c..5928a65b4e3 100644 --- a/src/data/battle-anims.ts +++ b/src/data/battle-anims.ts @@ -1,6 +1,6 @@ //import { battleAnimRawData } from "./battle-anim-raw-data"; import BattleScene from "../battle-scene"; -import { AttackMove, BeakBlastHeaderAttr, ChargeAttr, DelayedAttackAttr, MoveFlags, SelfStatusMove, allMoves } from "./move"; +import { AttackMove, BeakBlastHeaderAttr, DelayedAttackAttr, MoveFlags, SelfStatusMove, allMoves } from "./move"; import Pokemon from "../field/pokemon"; import * as Utils from "../utils"; import { BattlerIndex } from "../battle"; @@ -134,15 +134,15 @@ export class AnimConfig { for (const te of frameTimedEvents[fte]) { let timedEvent: AnimTimedEvent | undefined; switch (te.eventType) { - case "AnimTimedSoundEvent": - timedEvent = new AnimTimedSoundEvent(te.frameIndex, te.resourceName, te); - break; - case "AnimTimedAddBgEvent": - timedEvent = new AnimTimedAddBgEvent(te.frameIndex, te.resourceName, te); - break; - case "AnimTimedUpdateBgEvent": - timedEvent = new AnimTimedUpdateBgEvent(te.frameIndex, te.resourceName, te); - break; + case "AnimTimedSoundEvent": + timedEvent = new AnimTimedSoundEvent(te.frameIndex, te.resourceName, te); + break; + case "AnimTimedAddBgEvent": + timedEvent = new AnimTimedAddBgEvent(te.frameIndex, te.resourceName, te); + break; + case "AnimTimedUpdateBgEvent": + timedEvent = new AnimTimedUpdateBgEvent(te.frameIndex, te.resourceName, te); + break; } timedEvent && timedEvents.push(timedEvent); @@ -243,12 +243,12 @@ class AnimFrame { if (!init) { let target = AnimFrameTarget.GRAPHIC; switch (pattern) { - case -2: - target = AnimFrameTarget.TARGET; - break; - case -1: - target = AnimFrameTarget.USER; - break; + case -2: + target = AnimFrameTarget.TARGET; + break; + case -1: + target = AnimFrameTarget.USER; + break; } this.target = target; this.graphicFrame = pattern >= 0 ? pattern : 0; @@ -428,9 +428,9 @@ class AnimTimedAddBgEvent extends AnimTimedBgEvent { moveAnim.bgSprite.setScale(1.25); moveAnim.bgSprite.setAlpha(this.opacity / 255); scene.field.add(moveAnim.bgSprite); - const fieldPokemon = scene.getEnemyPokemon() || scene.getPlayerPokemon(); + const fieldPokemon = scene.getEnemyPokemon(false) ?? scene.getPlayerPokemon(false); if (!isNullOrUndefined(priority)) { - scene.field.moveTo(moveAnim.bgSprite as Phaser.GameObjects.GameObject, priority!); + scene.field.moveTo(moveAnim.bgSprite as Phaser.GameObjects.GameObject, priority); } else if (fieldPokemon?.isOnField()) { scene.field.moveBelow(moveAnim.bgSprite as Phaser.GameObjects.GameObject, fieldPokemon); } @@ -476,8 +476,11 @@ export function initMoveAnim(scene: BattleScene, move: Moves): Promise { } else { const loadedCheckTimer = setInterval(() => { if (moveAnims.get(move) !== null) { - const chargeAttr = allMoves[move].getAttrs(ChargeAttr)[0] || allMoves[move].getAttrs(DelayedAttackAttr)[0]; - if (chargeAttr && chargeAnims.get(chargeAttr.chargeAnim) === null) { + const chargeAnimSource = (allMoves[move].isChargingMove()) + ? allMoves[move] + : (allMoves[move].getAttrs(DelayedAttackAttr)[0] + ?? allMoves[move].getAttrs(BeakBlastHeaderAttr)[0]); + if (chargeAnimSource && chargeAnims.get(chargeAnimSource.chargeAnim) === null) { return; } clearInterval(loadedCheckTimer); @@ -507,11 +510,12 @@ export function initMoveAnim(scene: BattleScene, move: Moves): Promise { } else { populateMoveAnim(move, ba); } - const chargeAttr = allMoves[move].getAttrs(ChargeAttr)[0] - || allMoves[move].getAttrs(DelayedAttackAttr)[0] - || allMoves[move].getAttrs(BeakBlastHeaderAttr)[0]; - if (chargeAttr) { - initMoveChargeAnim(scene, chargeAttr.chargeAnim).then(() => resolve()); + const chargeAnimSource = (allMoves[move].isChargingMove()) + ? allMoves[move] + : (allMoves[move].getAttrs(DelayedAttackAttr)[0] + ?? allMoves[move].getAttrs(BeakBlastHeaderAttr)[0]); + if (chargeAnimSource) { + initMoveChargeAnim(scene, chargeAnimSource.chargeAnim).then(() => resolve()); } else { resolve(); } @@ -556,7 +560,7 @@ function logMissingMoveAnim(move: Moves, ...optionalParams: any[]) { * @param encounterAnim one or more animations to fetch */ export async function initEncounterAnims(scene: BattleScene, encounterAnim: EncounterAnim | EncounterAnim[]): Promise { - const anims = Array.isArray(encounterAnim) ? encounterAnim : [encounterAnim]; + const anims = Array.isArray(encounterAnim) ? encounterAnim : [ encounterAnim ]; const encounterAnimNames = Utils.getEnumKeys(EncounterAnim); const encounterAnimFetches: Promise>[] = []; for (const anim of anims) { @@ -638,11 +642,12 @@ export function loadMoveAnimAssets(scene: BattleScene, moveIds: Moves[], startLo return new Promise(resolve => { const moveAnimations = moveIds.map(m => moveAnims.get(m) as AnimConfig).flat(); for (const moveId of moveIds) { - const chargeAttr = allMoves[moveId].getAttrs(ChargeAttr)[0] - || allMoves[moveId].getAttrs(DelayedAttackAttr)[0] - || allMoves[moveId].getAttrs(BeakBlastHeaderAttr)[0]; - if (chargeAttr) { - const moveChargeAnims = chargeAnims.get(chargeAttr.chargeAnim); + const chargeAnimSource = (allMoves[moveId].isChargingMove()) + ? allMoves[moveId] + : (allMoves[moveId].getAttrs(DelayedAttackAttr)[0] + ?? allMoves[moveId].getAttrs(BeakBlastHeaderAttr)[0]); + if (chargeAnimSource) { + const moveChargeAnims = chargeAnims.get(chargeAnimSource.chargeAnim); moveAnimations.push(moveChargeAnims instanceof AnimConfig ? moveChargeAnims : moveChargeAnims![0]); // TODO: is the bang correct? if (Array.isArray(moveChargeAnims)) { moveAnimations.push(moveChargeAnims[1]); @@ -743,16 +748,21 @@ export abstract class BattleAnim { public target: Pokemon | null; public sprites: Phaser.GameObjects.Sprite[]; public bgSprite: Phaser.GameObjects.TileSprite | Phaser.GameObjects.Rectangle; - public playOnEmptyField: boolean; + /** + * Will attempt to play as much of an animation as possible, even if not all targets are on the field. + * Will also play the animation, even if the user has selected "Move Animations" OFF in Settings. + * Exclusively used by MEs atm, for visual animations at the start of an encounter. + */ + public playRegardlessOfIssues: boolean; private srcLine: number[]; private dstLine: number[]; - constructor(user?: Pokemon, target?: Pokemon, playOnEmptyField: boolean = false) { + constructor(user?: Pokemon, target?: Pokemon, playRegardlessOfIssues: boolean = false) { this.user = user ?? null; this.target = target ?? null; this.sprites = []; - this.playOnEmptyField = playOnEmptyField; + this.playRegardlessOfIssues = playRegardlessOfIssues; } abstract getAnim(): AnimConfig | null; @@ -769,9 +779,9 @@ export abstract class BattleAnim { private getGraphicFrameData(scene: BattleScene, frames: AnimFrame[], onSubstitute?: boolean): Map> { const ret: Map> = new Map([ - [AnimFrameTarget.GRAPHIC, new Map() ], - [AnimFrameTarget.USER, new Map() ], - [AnimFrameTarget.TARGET, new Map() ] + [ AnimFrameTarget.GRAPHIC, new Map() ], + [ AnimFrameTarget.USER, new Map() ], + [ AnimFrameTarget.TARGET, new Map() ] ]); const isOppAnim = this.isOppAnim(); @@ -798,23 +808,23 @@ export abstract class BattleAnim { let scaleX = (frame.zoomX / 100) * (!frame.mirror ? 1 : -1); const scaleY = (frame.zoomY / 100); switch (frame.focus) { - case AnimFocus.TARGET: - x += targetInitialX - targetFocusX; - y += (targetInitialY - targetHalfHeight) - targetFocusY; - break; - case AnimFocus.USER: - x += userInitialX - userFocusX; - y += (userInitialY - userHalfHeight) - userFocusY; - break; - case AnimFocus.USER_TARGET: - const point = transformPoint(this.srcLine[0], this.srcLine[1], this.srcLine[2], this.srcLine[3], - this.dstLine[0], this.dstLine[1] - userHalfHeight, this.dstLine[2], this.dstLine[3] - targetHalfHeight, x, y); - x = point[0]; - y = point[1]; - if (frame.target === AnimFrameTarget.GRAPHIC && isReversed(this.srcLine[0], this.srcLine[2], this.dstLine[0], this.dstLine[2])) { - scaleX = scaleX * -1; - } - break; + case AnimFocus.TARGET: + x += targetInitialX - targetFocusX; + y += (targetInitialY - targetHalfHeight) - targetFocusY; + break; + case AnimFocus.USER: + x += userInitialX - userFocusX; + y += (userInitialY - userHalfHeight) - userFocusY; + break; + case AnimFocus.USER_TARGET: + const point = transformPoint(this.srcLine[0], this.srcLine[1], this.srcLine[2], this.srcLine[3], + this.dstLine[0], this.dstLine[1] - userHalfHeight, this.dstLine[2], this.dstLine[3] - targetHalfHeight, x, y); + x = point[0]; + y = point[1]; + if (frame.target === AnimFrameTarget.GRAPHIC && isReversed(this.srcLine[0], this.srcLine[2], this.dstLine[0], this.dstLine[2])) { + scaleX = scaleX * -1; + } + break; } const angle = -frame.angle; const key = frame.target === AnimFrameTarget.GRAPHIC ? g++ : frame.target === AnimFrameTarget.USER ? u++ : t++; @@ -829,7 +839,7 @@ export abstract class BattleAnim { const user = !isOppAnim ? this.user! : this.target!; // TODO: are those bangs correct? const target = !isOppAnim ? this.target! : this.user!; - if (!target?.isOnField() && !this.playOnEmptyField) { + if (!target?.isOnField() && !this.playRegardlessOfIssues) { if (callback) { callback(); } @@ -896,7 +906,7 @@ export abstract class BattleAnim { } }; - if (!scene.moveAnimations) { + if (!scene.moveAnimations && !this.playRegardlessOfIssues) { return cleanUpAndComplete(); } @@ -910,12 +920,12 @@ export abstract class BattleAnim { this.srcLine = [ userFocusX, userFocusY, targetFocusX, targetFocusY ]; this.dstLine = [ userInitialX, userInitialY, targetInitialX, targetInitialY ]; - let r = anim!.frames.length; // TODO: is this bang correct? + let r = anim?.frames.length ?? 0; let f = 0; scene.tweens.addCounter({ duration: Utils.getFrameMs(3), - repeat: anim!.frames.length, // TODO: is this bang correct? + repeat: anim?.frames.length ?? 0, onRepeat: () => { if (!f) { userSprite.setVisible(false); @@ -932,7 +942,7 @@ export abstract class BattleAnim { const isUser = frame.target === AnimFrameTarget.USER; if (isUser && target === user) { continue; - } else if (this.playOnEmptyField && frame.target === AnimFrameTarget.TARGET && !target.isOnField()) { + } else if (this.playRegardlessOfIssues && frame.target === AnimFrameTarget.TARGET && !target.isOnField()) { continue; } const sprites = spriteCache[isUser ? AnimFrameTarget.USER : AnimFrameTarget.TARGET]; @@ -988,44 +998,44 @@ export abstract class BattleAnim { spritePriorities[graphicIndex] = frame.priority; const setSpritePriority = (priority: integer) => { switch (priority) { - case 0: - scene.field.moveBelow(moveSprite as Phaser.GameObjects.GameObject, scene.getEnemyPokemon() || scene.getPlayerPokemon()!); // TODO: is this bang correct? - break; - case 1: - scene.field.moveTo(moveSprite, scene.field.getAll().length - 1); - break; - case 2: - switch (frame.focus) { - case AnimFocus.USER: - if (this.bgSprite) { - scene.field.moveAbove(moveSprite as Phaser.GameObjects.GameObject, this.bgSprite); - } else { - scene.field.moveBelow(moveSprite as Phaser.GameObjects.GameObject, this.user!); // TODO: is this bang correct? + case 0: + scene.field.moveBelow(moveSprite as Phaser.GameObjects.GameObject, scene.getEnemyPokemon(false) ?? scene.getPlayerPokemon(false)!); // TODO: is this bang correct? + break; + case 1: + scene.field.moveTo(moveSprite, scene.field.getAll().length - 1); + break; + case 2: + switch (frame.focus) { + case AnimFocus.USER: + if (this.bgSprite) { + scene.field.moveAbove(moveSprite as Phaser.GameObjects.GameObject, this.bgSprite); + } else { + scene.field.moveBelow(moveSprite as Phaser.GameObjects.GameObject, this.user!); // TODO: is this bang correct? + } + break; + case AnimFocus.TARGET: + scene.field.moveBelow(moveSprite as Phaser.GameObjects.GameObject, this.target!); // TODO: is this bang correct? + break; + default: + setSpritePriority(1); + break; } break; - case AnimFocus.TARGET: - scene.field.moveBelow(moveSprite as Phaser.GameObjects.GameObject, this.target!); // TODO: is this bang correct? + case 3: + switch (frame.focus) { + case AnimFocus.USER: + scene.field.moveAbove(moveSprite as Phaser.GameObjects.GameObject, this.user!); // TODO: is this bang correct? + break; + case AnimFocus.TARGET: + scene.field.moveAbove(moveSprite as Phaser.GameObjects.GameObject, this.target!); // TODO: is this bang correct? + break; + default: + setSpritePriority(1); + break; + } break; default: setSpritePriority(1); - break; - } - break; - case 3: - switch (frame.focus) { - case AnimFocus.USER: - scene.field.moveAbove(moveSprite as Phaser.GameObjects.GameObject, this.user!); // TODO: is this bang correct? - break; - case AnimFocus.TARGET: - scene.field.moveAbove(moveSprite as Phaser.GameObjects.GameObject, this.target!); // TODO: is this bang correct? - break; - default: - setSpritePriority(1); - break; - } - break; - default: - setSpritePriority(1); } }; setSpritePriority(frame.priority); @@ -1088,9 +1098,9 @@ export abstract class BattleAnim { private getGraphicFrameDataWithoutTarget(frames: AnimFrame[], targetInitialX: number, targetInitialY: number): Map> { const ret: Map> = new Map([ - [AnimFrameTarget.GRAPHIC, new Map() ], - [AnimFrameTarget.USER, new Map() ], - [AnimFrameTarget.TARGET, new Map() ] + [ AnimFrameTarget.GRAPHIC, new Map() ], + [ AnimFrameTarget.USER, new Map() ], + [ AnimFrameTarget.TARGET, new Map() ] ]); let g = 0; @@ -1145,7 +1155,7 @@ export abstract class BattleAnim { } }; - if (!scene.moveAnimations) { + if (!scene.moveAnimations && !this.playRegardlessOfIssues) { return cleanUpAndComplete(); } @@ -1259,7 +1269,7 @@ export class CommonBattleAnim extends BattleAnim { } getAnim(): AnimConfig | null { - return this.commonAnim ? commonAnims.get(this.commonAnim)! : null; // TODO: is this bang correct? + return this.commonAnim ? commonAnims.get(this.commonAnim) ?? null : null; } isOppAnim(): boolean { @@ -1279,7 +1289,7 @@ export class MoveAnim extends BattleAnim { getAnim(): AnimConfig { return moveAnims.get(this.move) instanceof AnimConfig ? moveAnims.get(this.move) as AnimConfig - : moveAnims.get(this.move)![this.user?.isPlayer() ? 0 : 1] as AnimConfig; // TODO: is this bang correct? + : moveAnims.get(this.move)?.[this.user?.isPlayer() ? 0 : 1] as AnimConfig; } isOppAnim(): boolean { @@ -1311,7 +1321,7 @@ export class MoveChargeAnim extends MoveAnim { getAnim(): AnimConfig { return chargeAnims.get(this.chargeAnim) instanceof AnimConfig ? chargeAnims.get(this.chargeAnim) as AnimConfig - : chargeAnims.get(this.chargeAnim)![this.user?.isPlayer() ? 0 : 1] as AnimConfig; // TODO: is this bang correct? + : chargeAnims.get(this.chargeAnim)?.[this.user?.isPlayer() ? 0 : 1] as AnimConfig; } } @@ -1391,108 +1401,108 @@ export async function populateAnims() { const fieldName = field.slice(0, field.indexOf(":")); const fieldData = field.slice(fieldName.length + 1, field.lastIndexOf("\n")).trim(); switch (fieldName) { - case "array": - const framesData = fieldData.split(" - - - ").slice(1); - for (let fd = 0; fd < framesData.length; fd++) { - anim.frames.push([]); - const frameData = framesData[fd]; - const focusFramesData = frameData.split(" - - "); - for (let tf = 0; tf < focusFramesData.length; tf++) { - const values = focusFramesData[tf].replace(/ \- /g, "").split("\n"); - const targetFrame = new AnimFrame(parseFloat(values[0]), parseFloat(values[1]), parseFloat(values[2]), parseFloat(values[11]), parseFloat(values[3]), - parseInt(values[4]) === 1, parseInt(values[6]) === 1, parseInt(values[5]), parseInt(values[7]), parseInt(values[8]), parseInt(values[12]), parseInt(values[13]), - parseInt(values[14]), parseInt(values[15]), parseInt(values[16]), parseInt(values[17]), parseInt(values[18]), parseInt(values[19]), - parseInt(values[21]), parseInt(values[22]), parseInt(values[23]), parseInt(values[24]), parseInt(values[20]) === 1, parseInt(values[25]), parseInt(values[26]) as AnimFocus); - anim.frames[fd].push(targetFrame); + case "array": + const framesData = fieldData.split(" - - - ").slice(1); + for (let fd = 0; fd < framesData.length; fd++) { + anim.frames.push([]); + const frameData = framesData[fd]; + const focusFramesData = frameData.split(" - - "); + for (let tf = 0; tf < focusFramesData.length; tf++) { + const values = focusFramesData[tf].replace(/ \- /g, "").split("\n"); + const targetFrame = new AnimFrame(parseFloat(values[0]), parseFloat(values[1]), parseFloat(values[2]), parseFloat(values[11]), parseFloat(values[3]), + parseInt(values[4]) === 1, parseInt(values[6]) === 1, parseInt(values[5]), parseInt(values[7]), parseInt(values[8]), parseInt(values[12]), parseInt(values[13]), + parseInt(values[14]), parseInt(values[15]), parseInt(values[16]), parseInt(values[17]), parseInt(values[18]), parseInt(values[19]), + parseInt(values[21]), parseInt(values[22]), parseInt(values[23]), parseInt(values[24]), parseInt(values[20]) === 1, parseInt(values[25]), parseInt(values[26]) as AnimFocus); + anim.frames[fd].push(targetFrame); + } } - } - break; - case "graphic": - const graphic = fieldData !== "''" ? fieldData : ""; - anim.graphic = graphic.indexOf(".") > -1 - ? graphic.slice(0, fieldData.indexOf(".")) - : graphic; - break; - case "timing": - const timingEntries = fieldData.split("- !ruby/object:PBAnimTiming ").slice(1); - for (let t = 0; t < timingEntries.length; t++) { - const timingData = timingEntries[t].replace(/\n/g, " ").replace(/[ ]{2,}/g, " ").replace(/[a-z]+: ! '', /ig, "").replace(/name: (.*?),/, "name: \"$1\",") - .replace(/flashColor: !ruby\/object:Color { alpha: ([\d\.]+), blue: ([\d\.]+), green: ([\d\.]+), red: ([\d\.]+)}/, "flashRed: $4, flashGreen: $3, flashBlue: $2, flashAlpha: $1"); - const frameIndex = parseInt(/frame: (\d+)/.exec(timingData)![1]); // TODO: is the bang correct? - let resourceName = /name: "(.*?)"/.exec(timingData)![1].replace("''", ""); // TODO: is the bang correct? - const timingType = parseInt(/timingType: (\d)/.exec(timingData)![1]); // TODO: is the bang correct? - let timedEvent: AnimTimedEvent | undefined; - switch (timingType) { - case 0: - if (resourceName && resourceName.indexOf(".") === -1) { - let ext: string | undefined; - [ "wav", "mp3", "m4a" ].every(e => { - if (seNames.indexOf(`${resourceName}.${e}`) > -1) { - ext = e; - return false; + break; + case "graphic": + const graphic = fieldData !== "''" ? fieldData : ""; + anim.graphic = graphic.indexOf(".") > -1 + ? graphic.slice(0, fieldData.indexOf(".")) + : graphic; + break; + case "timing": + const timingEntries = fieldData.split("- !ruby/object:PBAnimTiming ").slice(1); + for (let t = 0; t < timingEntries.length; t++) { + const timingData = timingEntries[t].replace(/\n/g, " ").replace(/[ ]{2,}/g, " ").replace(/[a-z]+: ! '', /ig, "").replace(/name: (.*?),/, "name: \"$1\",") + .replace(/flashColor: !ruby\/object:Color { alpha: ([\d\.]+), blue: ([\d\.]+), green: ([\d\.]+), red: ([\d\.]+)}/, "flashRed: $4, flashGreen: $3, flashBlue: $2, flashAlpha: $1"); + const frameIndex = parseInt(/frame: (\d+)/.exec(timingData)![1]); // TODO: is the bang correct? + let resourceName = /name: "(.*?)"/.exec(timingData)![1].replace("''", ""); // TODO: is the bang correct? + const timingType = parseInt(/timingType: (\d)/.exec(timingData)![1]); // TODO: is the bang correct? + let timedEvent: AnimTimedEvent | undefined; + switch (timingType) { + case 0: + if (resourceName && resourceName.indexOf(".") === -1) { + let ext: string | undefined; + [ "wav", "mp3", "m4a" ].every(e => { + if (seNames.indexOf(`${resourceName}.${e}`) > -1) { + ext = e; + return false; + } + return true; + }); + if (!ext) { + ext = ".wav"; + } + resourceName += `.${ext}`; } - return true; - }); - if (!ext) { - ext = ".wav"; + timedEvent = new AnimTimedSoundEvent(frameIndex, resourceName); + break; + case 1: + timedEvent = new AnimTimedAddBgEvent(frameIndex, resourceName.slice(0, resourceName.indexOf("."))); + break; + case 2: + timedEvent = new AnimTimedUpdateBgEvent(frameIndex, resourceName.slice(0, resourceName.indexOf("."))); + break; + } + if (!timedEvent) { + continue; + } + const propPattern = /([a-z]+): (.*?)(?:,|\})/ig; + let propMatch: RegExpExecArray; + while ((propMatch = propPattern.exec(timingData)!)) { // TODO: is this bang correct? + const prop = propMatch[1]; + let value: any = propMatch[2]; + switch (prop) { + case "bgX": + case "bgY": + value = parseFloat(value); + break; + case "volume": + case "pitch": + case "opacity": + case "colorRed": + case "colorGreen": + case "colorBlue": + case "colorAlpha": + case "duration": + case "flashScope": + case "flashRed": + case "flashGreen": + case "flashBlue": + case "flashAlpha": + case "flashDuration": + value = parseInt(value); + break; + } + if (timedEvent.hasOwnProperty(prop)) { + timedEvent[prop] = value; } - resourceName += `.${ext}`; } - timedEvent = new AnimTimedSoundEvent(frameIndex, resourceName); - break; - case 1: - timedEvent = new AnimTimedAddBgEvent(frameIndex, resourceName.slice(0, resourceName.indexOf("."))); - break; - case 2: - timedEvent = new AnimTimedUpdateBgEvent(frameIndex, resourceName.slice(0, resourceName.indexOf("."))); - break; - } - if (!timedEvent) { - continue; - } - const propPattern = /([a-z]+): (.*?)(?:,|\})/ig; - let propMatch: RegExpExecArray; - while ((propMatch = propPattern.exec(timingData)!)) { // TODO: is this bang correct? - const prop = propMatch[1]; - let value: any = propMatch[2]; - switch (prop) { - case "bgX": - case "bgY": - value = parseFloat(value); - break; - case "volume": - case "pitch": - case "opacity": - case "colorRed": - case "colorGreen": - case "colorBlue": - case "colorAlpha": - case "duration": - case "flashScope": - case "flashRed": - case "flashGreen": - case "flashBlue": - case "flashAlpha": - case "flashDuration": - value = parseInt(value); - break; + if (!anim.frameTimedEvents.has(frameIndex)) { + anim.frameTimedEvents.set(frameIndex, []); } - if (timedEvent.hasOwnProperty(prop)) { - timedEvent[prop] = value; - } - } - if (!anim.frameTimedEvents.has(frameIndex)) { - anim.frameTimedEvents.set(frameIndex, []); - } anim.frameTimedEvents.get(frameIndex)!.push(timedEvent); // TODO: is this bang correct? - } - break; - case "position": - anim.position = parseInt(fieldData); - break; - case "hue": - anim.hue = parseInt(fieldData); - break; + } + break; + case "position": + anim.position = parseInt(fieldData); + break; + case "hue": + anim.hue = parseInt(fieldData); + break; } } } diff --git a/src/data/battler-tags.ts b/src/data/battler-tags.ts index 32b3d54f302..ce25b56157c 100644 --- a/src/data/battler-tags.ts +++ b/src/data/battler-tags.ts @@ -1,28 +1,44 @@ -import { ChargeAnim, CommonAnim, CommonBattleAnim, MoveChargeAnim } from "./battle-anims"; -import { getPokemonNameWithAffix } from "../messages"; -import Pokemon, { MoveResult, HitResult } from "../field/pokemon"; -import { StatusEffect } from "./status-effect"; -import * as Utils from "../utils"; -import { ChargeAttr, MoveFlags, allMoves } from "./move"; -import { Type } from "./type"; -import { BlockNonDirectDamageAbAttr, FlinchEffectAbAttr, ReverseDrainAbAttr, applyAbAttrs, ProtectStatAbAttr } from "./ability"; -import { TerrainType } from "./terrain"; -import { WeatherType } from "./weather"; -import { allAbilities } from "./ability"; -import { SpeciesFormChangeManualTrigger } from "./pokemon-forms"; -import { Abilities } from "#enums/abilities"; -import { BattlerTagType } from "#enums/battler-tag-type"; -import { Moves } from "#enums/moves"; -import { Species } from "#enums/species"; -import i18next from "#app/plugins/i18n"; -import { Stat, type BattleStat, type EffectiveStat, EFFECTIVE_STATS, getStatKey } from "#app/enums/stat"; +import BattleScene from "#app/battle-scene"; +import { + allAbilities, + applyAbAttrs, + BlockNonDirectDamageAbAttr, + FlinchEffectAbAttr, + ProtectStatAbAttr, + ReverseDrainAbAttr +} from "#app/data/ability"; +import { ChargeAnim, CommonAnim, CommonBattleAnim, MoveChargeAnim } from "#app/data/battle-anims"; +import Move, { + allMoves, + applyMoveAttrs, + ConsecutiveUseDoublePowerAttr, + HealOnAllyAttr, + MoveCategory, + MoveFlags, + StatusCategoryOnAllyAttr +} from "#app/data/move"; +import { SpeciesFormChangeManualTrigger } from "#app/data/pokemon-forms"; +import { getStatusEffectHealText } from "#app/data/status-effect"; +import { TerrainType } from "#app/data/terrain"; +import { Type } from "#enums/type"; +import Pokemon, { HitResult, MoveResult } from "#app/field/pokemon"; +import { getPokemonNameWithAffix } from "#app/messages"; import { CommonAnimPhase } from "#app/phases/common-anim-phase"; import { MoveEffectPhase } from "#app/phases/move-effect-phase"; import { MovePhase } from "#app/phases/move-phase"; import { PokemonHealPhase } from "#app/phases/pokemon-heal-phase"; import { ShowAbilityPhase } from "#app/phases/show-ability-phase"; -import { StatStageChangePhase, StatStageChangeCallback } from "#app/phases/stat-stage-change-phase"; -import { PokemonAnimType } from "#app/enums/pokemon-anim-type"; +import { StatStageChangeCallback, StatStageChangePhase } from "#app/phases/stat-stage-change-phase"; +import i18next from "#app/plugins/i18n"; +import { BooleanHolder, getFrameMs, NumberHolder, toDmgValue } from "#app/utils"; +import { Abilities } from "#enums/abilities"; +import { BattlerTagType } from "#enums/battler-tag-type"; +import { Moves } from "#enums/moves"; +import { PokemonAnimType } from "#enums/pokemon-anim-type"; +import { Species } from "#enums/species"; +import { EFFECTIVE_STATS, getStatKey, Stat, type BattleStat, type EffectiveStat } from "#enums/stat"; +import { StatusEffect } from "#enums/status-effect"; +import { WeatherType } from "#enums/weather-type"; export enum BattlerTagLapseType { FAINT, @@ -32,6 +48,7 @@ export enum BattlerTagLapseType { MOVE_EFFECT, TURN_END, HIT, + AFTER_HIT, CUSTOM } @@ -90,6 +107,15 @@ export class BattlerTag { this.sourceMove = source.sourceMove; this.sourceId = source.sourceId; } + + /** + * Helper function that retrieves the source Pokemon object + * @param scene medium to retrieve the source Pokemon + * @returns The source {@linkcode Pokemon} or `null` if none is found + */ + public getSourcePokemon(scene: BattleScene): Pokemon | null { + return this.sourceId ? scene.getPokemonById(this.sourceId) : null; + } } export interface WeatherBattlerTag { @@ -120,7 +146,7 @@ export abstract class MoveRestrictionBattlerTag extends BattlerTag { const phase = pokemon.scene.getCurrentPhase() as MovePhase; const move = phase.move; - if (this.isMoveRestricted(move.moveId)) { + if (this.isMoveRestricted(move.moveId, pokemon)) { if (this.interruptedText(pokemon, move.moveId)) { pokemon.scene.queueMessage(this.interruptedText(pokemon, move.moveId)); } @@ -136,10 +162,23 @@ export abstract class MoveRestrictionBattlerTag extends BattlerTag { /** * Gets whether this tag is restricting a move. * - * @param {Moves} move {@linkcode Moves} ID to check restriction for. - * @returns {boolean} `true` if the move is restricted by this tag, otherwise `false`. + * @param move - {@linkcode Moves} ID to check restriction for. + * @param user - The {@linkcode Pokemon} involved + * @returns `true` if the move is restricted by this tag, otherwise `false`. */ - abstract isMoveRestricted(move: Moves): boolean; + public abstract isMoveRestricted(move: Moves, user?: Pokemon): boolean; + + /** + * Checks if this tag is restricting a move based on a user's decisions during the target selection phase + * + * @param {Moves} move {@linkcode Moves} move ID to check restriction for + * @param {Pokemon} user {@linkcode Pokemon} the user of the above move + * @param {Pokemon} target {@linkcode Pokemon} the target of the above move + * @returns {boolean} `false` unless overridden by the child tag + */ + isMoveTargetRestricted(move: Moves, user: Pokemon, target: Pokemon): boolean { + return false; + } /** * Gets the text to display when the player attempts to select a move that is restricted by this tag. @@ -315,6 +354,16 @@ export class GorillaTacticsTag extends MoveRestrictionBattlerTag { pokemon.setStat(Stat.ATK, pokemon.getStat(Stat.ATK, false) * 1.5, false); } + /** + * Loads the Gorilla Tactics Battler Tag along with its unique class variable moveId + * @override + * @param source Gorilla Tactics' {@linkcode BattlerTag} information + */ + public override loadTag(source: BattlerTag | any): void { + super.loadTag(source); + this.moveId = source.moveId; + } + /** * * @override @@ -351,7 +400,7 @@ export class RechargingTag extends BattlerTag { super.onAdd(pokemon); // Queue a placeholder move for the Pokemon to "use" next turn - pokemon.getMoveQueue().push({ move: Moves.NONE, targets: [] }); + pokemon.getMoveQueue().push({ move: Moves.NONE, targets: []}); } /** Cancels the source's move this turn and queues a "__ must recharge!" message */ @@ -372,7 +421,7 @@ export class RechargingTag extends BattlerTag { */ export class BeakBlastChargingTag extends BattlerTag { constructor() { - super(BattlerTagType.BEAK_BLAST_CHARGING, [ BattlerTagLapseType.PRE_MOVE, BattlerTagLapseType.TURN_END ], 1, Moves.BEAK_BLAST); + super(BattlerTagType.BEAK_BLAST_CHARGING, [ BattlerTagLapseType.PRE_MOVE, BattlerTagLapseType.TURN_END, BattlerTagLapseType.AFTER_HIT ], 1, Moves.BEAK_BLAST); } onAdd(pokemon: Pokemon): void { @@ -388,16 +437,13 @@ export class BeakBlastChargingTag extends BattlerTag { * to be removed after the source makes a move (or the turn ends, whichever comes first) * @param pokemon {@linkcode Pokemon} the owner of this tag * @param lapseType {@linkcode BattlerTagLapseType} the type of functionality invoked in battle - * @returns `true` if invoked with the CUSTOM lapse type; `false` otherwise + * @returns `true` if invoked with the `AFTER_HIT` lapse type */ lapse(pokemon: Pokemon, lapseType: BattlerTagLapseType): boolean { - if (lapseType === BattlerTagLapseType.CUSTOM) { - const effectPhase = pokemon.scene.getCurrentPhase(); - if (effectPhase instanceof MoveEffectPhase) { - const attacker = effectPhase.getPokemon(); - if (effectPhase.move.getMove().checkFlag(MoveFlags.MAKES_CONTACT, attacker, pokemon)) { - attacker.trySetStatus(StatusEffect.BURN, true, pokemon); - } + if (lapseType === BattlerTagLapseType.AFTER_HIT) { + const phaseData = getMoveEffectPhaseData(pokemon); + if (phaseData?.move.hasFlag(MoveFlags.MAKES_CONTACT)) { + phaseData.attacker.trySetStatus(StatusEffect.BURN, true, pokemon); } return true; } @@ -411,11 +457,10 @@ export class BeakBlastChargingTag extends BattlerTag { * @see {@link https://bulbapedia.bulbagarden.net/wiki/Shell_Trap_(move) | Shell Trap} */ export class ShellTrapTag extends BattlerTag { - public activated: boolean; + public activated: boolean = false; constructor() { - super(BattlerTagType.SHELL_TRAP, BattlerTagLapseType.TURN_END, 1); - this.activated = false; + super(BattlerTagType.SHELL_TRAP, [ BattlerTagLapseType.TURN_END, BattlerTagLapseType.AFTER_HIT ], 1); } onAdd(pokemon: Pokemon): void { @@ -426,25 +471,33 @@ export class ShellTrapTag extends BattlerTag { * "Activates" the shell trap, causing the tag owner to move next. * @param pokemon {@linkcode Pokemon} the owner of this tag * @param lapseType {@linkcode BattlerTagLapseType} the type of functionality invoked in battle - * @returns `true` if invoked with the `CUSTOM` lapse type; `false` otherwise + * @returns `true` if invoked with the `AFTER_HIT` lapse type */ lapse(pokemon: Pokemon, lapseType: BattlerTagLapseType): boolean { - if (lapseType === BattlerTagLapseType.CUSTOM) { - const shellTrapPhaseIndex = pokemon.scene.phaseQueue.findIndex( - phase => phase instanceof MovePhase && phase.pokemon === pokemon - ); - const firstMovePhaseIndex = pokemon.scene.phaseQueue.findIndex( - phase => phase instanceof MovePhase - ); + if (lapseType === BattlerTagLapseType.AFTER_HIT) { + const phaseData = getMoveEffectPhaseData(pokemon); - if (shellTrapPhaseIndex !== -1 && shellTrapPhaseIndex !== firstMovePhaseIndex) { - const shellTrapMovePhase = pokemon.scene.phaseQueue.splice(shellTrapPhaseIndex, 1)[0]; - pokemon.scene.prependToPhase(shellTrapMovePhase, MovePhase); + // Trap should only be triggered by opponent's Physical moves + if (phaseData?.move.category === MoveCategory.PHYSICAL && pokemon.isOpponent(phaseData.attacker)) { + const shellTrapPhaseIndex = pokemon.scene.phaseQueue.findIndex( + phase => phase instanceof MovePhase && phase.pokemon === pokemon + ); + const firstMovePhaseIndex = pokemon.scene.phaseQueue.findIndex( + phase => phase instanceof MovePhase + ); + + // Only shift MovePhase timing if it's not already next up + if (shellTrapPhaseIndex !== -1 && shellTrapPhaseIndex !== firstMovePhaseIndex) { + const shellTrapMovePhase = pokemon.scene.phaseQueue.splice(shellTrapPhaseIndex, 1)[0]; + pokemon.scene.prependToPhase(shellTrapMovePhase, MovePhase); + } + + this.activated = true; } - this.activated = true; return true; } + return super.lapse(pokemon, lapseType); } } @@ -557,7 +610,7 @@ export class InterruptedTag extends BattlerTag { super.onAdd(pokemon); pokemon.getMoveQueue().shift(); - pokemon.pushMoveHistory({move: Moves.NONE, result: MoveResult.OTHER}); + pokemon.pushMoveHistory({ move: Moves.NONE, result: MoveResult.OTHER }); } lapse(pokemon: Pokemon, lapseType: BattlerTagLapseType): boolean { @@ -608,7 +661,7 @@ export class ConfusedTag extends BattlerTag { if (pokemon.randSeedInt(3) === 0) { const atk = pokemon.getEffectiveStat(Stat.ATK); const def = pokemon.getEffectiveStat(Stat.DEF); - const damage = Utils.toDmgValue(((((2 * pokemon.level / 5 + 2) * 40 * atk / def) / 50) + 2) * (pokemon.randSeedIntRange(85, 100) / 100)); + const damage = toDmgValue(((((2 * pokemon.level / 5 + 2) * 40 * atk / def) / 50) + 2) * (pokemon.randSeedIntRange(85, 100) / 100)); pokemon.scene.queueMessage(i18next.t("battlerTags:confusedLapseHurtItself")); pokemon.damageAndUpdate(damage); pokemon.battleData.hitCount++; @@ -779,13 +832,13 @@ export class SeedTag extends BattlerTag { if (ret) { const source = pokemon.getOpponents().find(o => o.getBattlerIndex() === this.sourceIndex); if (source) { - const cancelled = new Utils.BooleanHolder(false); + const cancelled = new BooleanHolder(false); applyAbAttrs(BlockNonDirectDamageAbAttr, pokemon, cancelled); if (!cancelled.value) { pokemon.scene.unshiftPhase(new CommonAnimPhase(pokemon.scene, source.getBattlerIndex(), pokemon.getBattlerIndex(), CommonAnim.LEECH_SEED)); - const damage = pokemon.damageAndUpdate(Utils.toDmgValue(pokemon.getMaxHp() / 8)); + const damage = pokemon.damageAndUpdate(toDmgValue(pokemon.getMaxHp() / 8)); const reverseDrain = pokemon.hasAbilityWithAttr(ReverseDrainAbAttr, false); pokemon.scene.unshiftPhase(new PokemonHealPhase(pokemon.scene, source.getBattlerIndex(), !reverseDrain ? damage : damage * -1, @@ -805,7 +858,7 @@ export class SeedTag extends BattlerTag { export class NightmareTag extends BattlerTag { constructor() { - super(BattlerTagType.NIGHTMARE, BattlerTagLapseType.AFTER_MOVE, 1, Moves.NIGHTMARE); + super(BattlerTagType.NIGHTMARE, BattlerTagLapseType.TURN_END, 1, Moves.NIGHTMARE); } onAdd(pokemon: Pokemon): void { @@ -827,11 +880,11 @@ export class NightmareTag extends BattlerTag { pokemon.scene.queueMessage(i18next.t("battlerTags:nightmareLapse", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) })); pokemon.scene.unshiftPhase(new CommonAnimPhase(pokemon.scene, pokemon.getBattlerIndex(), undefined, CommonAnim.CURSE)); // TODO: Update animation type - const cancelled = new Utils.BooleanHolder(false); + const cancelled = new BooleanHolder(false); applyAbAttrs(BlockNonDirectDamageAbAttr, pokemon, cancelled); if (!cancelled.value) { - pokemon.damageAndUpdate(Utils.toDmgValue(pokemon.getMaxHp() / 4)); + pokemon.damageAndUpdate(toDmgValue(pokemon.getMaxHp() / 4)); } } @@ -857,11 +910,15 @@ export class FrenzyTag extends BattlerTag { } } -export class EncoreTag extends BattlerTag { +/** + * Applies the effects of the move Encore onto the target Pokemon + * Encore forces the target Pokemon to use its most-recent move for 3 turns + */ +export class EncoreTag extends MoveRestrictionBattlerTag { public moveId: Moves; constructor(sourceId: number) { - super(BattlerTagType.ENCORE, BattlerTagLapseType.AFTER_MOVE, 3, Moves.ENCORE, sourceId); + super(BattlerTagType.ENCORE, [ BattlerTagLapseType.CUSTOM, BattlerTagLapseType.AFTER_MOVE ], 3, Moves.ENCORE, sourceId); } /** @@ -886,18 +943,14 @@ export class EncoreTag extends BattlerTag { } switch (repeatableMove.move) { - case Moves.MIMIC: - case Moves.MIRROR_MOVE: - case Moves.TRANSFORM: - case Moves.STRUGGLE: - case Moves.SKETCH: - case Moves.SLEEP_TALK: - case Moves.ENCORE: - return false; - } - - if (allMoves[repeatableMove.move].hasAttr(ChargeAttr) && repeatableMove.result === MoveResult.OTHER) { - return false; + case Moves.MIMIC: + case Moves.MIRROR_MOVE: + case Moves.TRANSFORM: + case Moves.STRUGGLE: + case Moves.SKETCH: + case Moves.SLEEP_TALK: + case Moves.ENCORE: + return false; } this.moveId = repeatableMove.move; @@ -921,6 +974,39 @@ export class EncoreTag extends BattlerTag { } } + /** + * If the encored move has run out of PP, Encore ends early. Otherwise, Encore lapses based on the AFTER_MOVE battler tag lapse type. + * @returns `true` to persist | `false` to end and be removed + */ + override lapse(pokemon: Pokemon, lapseType: BattlerTagLapseType): boolean { + if (lapseType === BattlerTagLapseType.CUSTOM) { + const encoredMove = pokemon.getMoveset().find(m => m?.moveId === this.moveId); + if (encoredMove && encoredMove?.getPpRatio() > 0) { + return true; + } + return false; + } else { + return super.lapse(pokemon, lapseType); + } + } + + /** + * Checks if the move matches the moveId stored within the tag and returns a boolean value + * @param move {@linkcode Moves} the move selected + * @param user N/A + * @returns `true` if the move does not match with the moveId stored and as a result, restricted + */ + override isMoveRestricted(move: Moves, _user?: Pokemon): boolean { + if (move !== this.moveId) { + return true; + } + return false; + } + + override selectionDeniedText(_pokemon: Pokemon, move: Moves): string { + return i18next.t("battle:moveDisabled", { moveName: allMoves[move].name }); + } + onRemove(pokemon: Pokemon): void { super.onRemove(pokemon); @@ -971,7 +1057,7 @@ export class IngrainTag extends TrappedTag { new PokemonHealPhase( pokemon.scene, pokemon.getBattlerIndex(), - Utils.toDmgValue(pokemon.getMaxHp() / 16), + toDmgValue(pokemon.getMaxHp() / 16), i18next.t("battlerTags:ingrainLapse", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) }), true ) @@ -1034,7 +1120,7 @@ export class AquaRingTag extends BattlerTag { new PokemonHealPhase( pokemon.scene, pokemon.getBattlerIndex(), - Utils.toDmgValue(pokemon.getMaxHp() / 16), + toDmgValue(pokemon.getMaxHp() / 16), i18next.t("battlerTags:aquaRingLapse", { moveName: this.getMoveName(), pokemonName: getPokemonNameWithAffix(pokemon) @@ -1128,11 +1214,11 @@ export abstract class DamagingTrapTag extends TrappedTag { ); pokemon.scene.unshiftPhase(new CommonAnimPhase(pokemon.scene, pokemon.getBattlerIndex(), undefined, this.commonAnim)); - const cancelled = new Utils.BooleanHolder(false); + const cancelled = new BooleanHolder(false); applyAbAttrs(BlockNonDirectDamageAbAttr, pokemon, cancelled); if (!cancelled.value) { - pokemon.damageAndUpdate(Utils.toDmgValue(pokemon.getMaxHp() / 8)); + pokemon.damageAndUpdate(toDmgValue(pokemon.getMaxHp() / 8)); } } @@ -1323,7 +1409,7 @@ export class ContactDamageProtectedTag extends ProtectedTag { if (effectPhase instanceof MoveEffectPhase && effectPhase.move.getMove().hasFlag(MoveFlags.MAKES_CONTACT)) { const attacker = effectPhase.getPokemon(); if (!attacker.hasAbilityWithAttr(BlockNonDirectDamageAbAttr)) { - attacker.damageAndUpdate(Utils.toDmgValue(attacker.getMaxHp() * (1 / this.damageRatio)), HitResult.OTHER); + attacker.damageAndUpdate(toDmgValue(attacker.getMaxHp() * (1 / this.damageRatio)), HitResult.OTHER); } } } @@ -1364,7 +1450,7 @@ export class ContactStatStageChangeProtectedTag extends DamageProtectedTag { const effectPhase = pokemon.scene.getCurrentPhase(); if (effectPhase instanceof MoveEffectPhase && effectPhase.move.getMove().hasFlag(MoveFlags.MAKES_CONTACT)) { const attacker = effectPhase.getPokemon(); - pokemon.scene.unshiftPhase(new StatStageChangePhase(pokemon.scene, attacker.getBattlerIndex(), true, [ this.stat ], this.levels)); + pokemon.scene.unshiftPhase(new StatStageChangePhase(pokemon.scene, attacker.getBattlerIndex(), false, [ this.stat ], this.levels)); } } @@ -1416,9 +1502,14 @@ export class ContactBurnProtectedTag extends DamageProtectedTag { } } +/** + * `BattlerTag` class for effects that cause the affected Pokemon to survive lethal attacks at 1 HP. + * Used for {@link https://bulbapedia.bulbagarden.net/wiki/Endure_(move) | Endure} and + * Endure Tokens. + */ export class EnduringTag extends BattlerTag { - constructor(sourceMove: Moves) { - super(BattlerTagType.ENDURING, BattlerTagLapseType.TURN_END, 0, sourceMove); + constructor(tagType: BattlerTagType, lapseType: BattlerTagLapseType, sourceMove: Moves) { + super(tagType, lapseType, 0, sourceMove); } onAdd(pokemon: Pokemon): void { @@ -1525,6 +1616,22 @@ export class AbilityBattlerTag extends BattlerTag { } } +/** + * Tag used by Unburden to double speed + * @extends AbilityBattlerTag + */ +export class UnburdenTag extends AbilityBattlerTag { + constructor() { + super(BattlerTagType.UNBURDEN, Abilities.UNBURDEN, BattlerTagLapseType.CUSTOM, 1); + } + onAdd(pokemon: Pokemon): void { + super.onAdd(pokemon); + } + onRemove(pokemon: Pokemon): void { + super.onRemove(pokemon); + } +} + export class TruantTag extends AbilityBattlerTag { constructor() { super(BattlerTagType.TRUANT, Abilities.TRUANT, BattlerTagLapseType.MOVE, 1); @@ -1608,12 +1715,12 @@ export class HighestStatBoostTag extends AbilityBattlerTag { this.stat = highestStat; switch (this.stat) { - case Stat.SPD: - this.multiplier = 1.5; - break; - default: - this.multiplier = 1.3; - break; + case Stat.SPD: + this.multiplier = 1.5; + break; + default: + this.multiplier = 1.3; + break; } pokemon.scene.queueMessage(i18next.t("battlerTags:highestStatBoostOnAdd", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon), statName: i18next.t(getStatKey(highestStat)) }), null, false, null, true); @@ -1676,7 +1783,7 @@ export class SemiInvulnerableTag extends BattlerTag { onRemove(pokemon: Pokemon): void { // Wait 2 frames before setting visible for battle animations that don't immediately show the sprite invisible pokemon.scene.tweens.addCounter({ - duration: Utils.getFrameMs(2), + duration: getFrameMs(2), onComplete: () => pokemon.setVisible(true) }); } @@ -1701,21 +1808,30 @@ export class TypeImmuneTag extends BattlerTag { } } -export class MagnetRisenTag extends TypeImmuneTag { - constructor(tagType: BattlerTagType, sourceMove: Moves) { - super(tagType, sourceMove, Type.GROUND, 5); +/** + * Battler Tag that lifts the affected Pokemon into the air and provides immunity to Ground type moves. + * @see {@link https://bulbapedia.bulbagarden.net/wiki/Magnet_Rise_(move) | Moves.MAGNET_RISE} + * @see {@link https://bulbapedia.bulbagarden.net/wiki/Telekinesis_(move) | Moves.TELEKINESIS} + */ +export class FloatingTag extends TypeImmuneTag { + constructor(tagType: BattlerTagType, sourceMove: Moves, turnCount: number) { + super(tagType, sourceMove, Type.GROUND, turnCount); } onAdd(pokemon: Pokemon): void { super.onAdd(pokemon); - pokemon.scene.queueMessage(i18next.t("battlerTags:magnetRisenOnAdd", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) })); + if (this.sourceMove === Moves.MAGNET_RISE) { + pokemon.scene.queueMessage(i18next.t("battlerTags:magnetRisenOnAdd", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) })); + } + } onRemove(pokemon: Pokemon): void { super.onRemove(pokemon); - - pokemon.scene.queueMessage(i18next.t("battlerTags:magnetRisenOnRemove", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) })); + if (this.sourceMove === Moves.MAGNET_RISE) { + pokemon.scene.queueMessage(i18next.t("battlerTags:magnetRisenOnRemove", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) })); + } } } @@ -1818,12 +1934,12 @@ export class SaltCuredTag extends BattlerTag { if (ret) { pokemon.scene.unshiftPhase(new CommonAnimPhase(pokemon.scene, pokemon.getBattlerIndex(), pokemon.getBattlerIndex(), CommonAnim.SALT_CURE)); - const cancelled = new Utils.BooleanHolder(false); + const cancelled = new BooleanHolder(false); applyAbAttrs(BlockNonDirectDamageAbAttr, pokemon, cancelled); if (!cancelled.value) { const pokemonSteelOrWater = pokemon.isOfType(Type.STEEL) || pokemon.isOfType(Type.WATER); - pokemon.damageAndUpdate(Utils.toDmgValue(pokemonSteelOrWater ? pokemon.getMaxHp() / 4 : pokemon.getMaxHp() / 8)); + pokemon.damageAndUpdate(toDmgValue(pokemonSteelOrWater ? pokemon.getMaxHp() / 4 : pokemon.getMaxHp() / 8)); pokemon.scene.queueMessage( i18next.t("battlerTags:saltCuredLapse", { @@ -1865,11 +1981,11 @@ export class CursedTag extends BattlerTag { if (ret) { pokemon.scene.unshiftPhase(new CommonAnimPhase(pokemon.scene, pokemon.getBattlerIndex(), pokemon.getBattlerIndex(), CommonAnim.SALT_CURE)); - const cancelled = new Utils.BooleanHolder(false); + const cancelled = new BooleanHolder(false); applyAbAttrs(BlockNonDirectDamageAbAttr, pokemon, cancelled); if (!cancelled.value) { - pokemon.damageAndUpdate(Utils.toDmgValue(pokemon.getMaxHp() / 4)); + pokemon.damageAndUpdate(toDmgValue(pokemon.getMaxHp() / 4)); pokemon.scene.queueMessage(i18next.t("battlerTags:cursedLapse", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) })); } } @@ -1923,10 +2039,10 @@ export class RoostedTag extends BattlerTag { modifiedTypes = currentTypes.filter(type => type !== Type.NORMAL); modifiedTypes.push(Type.FLYING); } else { - modifiedTypes = [Type.FLYING]; + modifiedTypes = [ Type.FLYING ]; } } else { - modifiedTypes = [...currentTypes]; + modifiedTypes = [ ...currentTypes ]; modifiedTypes.push(Type.FLYING); } pokemon.summonData.types = modifiedTypes; @@ -1946,10 +2062,10 @@ export class RoostedTag extends BattlerTag { if (this.isBaseFlying) { let modifiedTypes: Type[]; if (this.isBasePureFlying && !isCurrentlyDualType) { - modifiedTypes = [Type.NORMAL]; + modifiedTypes = [ Type.NORMAL ]; } else { if (!!pokemon.getTag(RemovedTypeTag) && isOriginallyDualType && !isCurrentlyDualType) { - modifiedTypes = [Type.UNKNOWN]; + modifiedTypes = [ Type.UNKNOWN ]; } else { modifiedTypes = currentTypes.filter(type => type !== Type.FLYING); } @@ -2018,6 +2134,42 @@ export class IceFaceBlockDamageTag extends FormBlockDamageTag { } } +/** + * Battler tag indicating a Tatsugiri with {@link https://bulbapedia.bulbagarden.net/wiki/Commander_(Ability) | Commander} + * has entered the tagged Pokemon's mouth. + */ +export class CommandedTag extends BattlerTag { + private _tatsugiriFormKey: string; + + constructor(sourceId: number) { + super(BattlerTagType.COMMANDED, BattlerTagLapseType.CUSTOM, 0, Moves.NONE, sourceId); + } + + public get tatsugiriFormKey(): string { + return this._tatsugiriFormKey; + } + + /** Caches the Tatsugiri's form key and sharply boosts the tagged Pokemon's stats */ + override onAdd(pokemon: Pokemon): void { + this._tatsugiriFormKey = this.getSourcePokemon(pokemon.scene)?.getFormKey() ?? "curly"; + pokemon.scene.unshiftPhase(new StatStageChangePhase( + pokemon.scene, pokemon.getBattlerIndex(), true, [ Stat.ATK, Stat.DEF, Stat.SPATK, Stat.SPDEF, Stat.SPD ], 2 + )); + } + + /** Triggers an {@linkcode PokemonAnimType | animation} of the tagged Pokemon "spitting out" Tatsugiri */ + override onRemove(pokemon: Pokemon): void { + if (this.getSourcePokemon(pokemon.scene)?.isActive(true)) { + pokemon.scene.triggerPokemonBattleAnim(pokemon, PokemonAnimType.COMMANDER_REMOVE); + } + } + + override loadTag(source: BattlerTag | any): void { + super.loadTag(source); + this._tatsugiriFormKey = source._tatsugiriFormKey; + } +} + /** * Battler tag enabling the Stockpile mechanic. This tag handles: * - Stack tracking, including max limit enforcement (which is replicated in Stockpile for redundancy). @@ -2055,8 +2207,8 @@ export class StockpilingTag extends BattlerTag { super.loadTag(source); this.stockpiledCount = source.stockpiledCount || 0; this.statChangeCounts = { - [ Stat.DEF ]: source.statChangeCounts?.[ Stat.DEF ] ?? 0, - [ Stat.SPDEF ]: source.statChangeCounts?.[ Stat.SPDEF ] ?? 0, + [Stat.DEF]: source.statChangeCounts?.[Stat.DEF] ?? 0, + [Stat.SPDEF]: source.statChangeCounts?.[Stat.SPDEF] ?? 0, }; } @@ -2078,7 +2230,7 @@ export class StockpilingTag extends BattlerTag { // Attempt to increase DEF and SPDEF by one stage, keeping track of successful changes. pokemon.scene.unshiftPhase(new StatStageChangePhase( pokemon.scene, pokemon.getBattlerIndex(), true, - [Stat.SPDEF, Stat.DEF], 1, true, false, true, this.onStatStagesChanged + [ Stat.SPDEF, Stat.DEF ], 1, true, false, true, this.onStatStagesChanged )); } } @@ -2111,7 +2263,40 @@ export class StockpilingTag extends BattlerTag { */ export class GulpMissileTag extends BattlerTag { constructor(tagType: BattlerTagType, sourceMove: Moves) { - super(tagType, BattlerTagLapseType.CUSTOM, 0, sourceMove); + super(tagType, BattlerTagLapseType.HIT, 0, sourceMove); + } + + override lapse(pokemon: Pokemon, lapseType: BattlerTagLapseType): boolean { + if (pokemon.getTag(BattlerTagType.UNDERWATER)) { + return true; + } + + const moveEffectPhase = pokemon.scene.getCurrentPhase(); + if (moveEffectPhase instanceof MoveEffectPhase) { + const attacker = moveEffectPhase.getUserPokemon(); + + if (!attacker) { + return false; + } + + if (moveEffectPhase.move.getMove().hitsSubstitute(attacker, pokemon)) { + return true; + } + + const cancelled = new BooleanHolder(false); + applyAbAttrs(BlockNonDirectDamageAbAttr, attacker, cancelled); + + if (!cancelled.value) { + attacker.damageAndUpdate(Math.max(1, Math.floor(attacker.getMaxHp() / 4)), HitResult.OTHER); + } + + if (this.tagType === BattlerTagType.GULP_MISSILE_ARROKUDA) { + pokemon.scene.unshiftPhase(new StatStageChangePhase(pokemon.scene, attacker.getBattlerIndex(), false, [ Stat.DEF ], -1)); + } else { + attacker.trySetStatus(StatusEffect.PARALYSIS, true, pokemon); + } + } + return false; } /** @@ -2178,6 +2363,74 @@ export class ExposedTag extends BattlerTag { } } +/** + * Tag that prevents HP recovery from held items and move effects. It also blocks the usage of recovery moves. + * Applied by moves: {@linkcode Moves.HEAL_BLOCK | Heal Block (5 turns)}, {@linkcode Moves.PSYCHIC_NOISE | Psychic Noise (2 turns)} + * + * @extends MoveRestrictionBattlerTag + */ +export class HealBlockTag extends MoveRestrictionBattlerTag { + constructor(turnCount: number, sourceMove: Moves) { + super(BattlerTagType.HEAL_BLOCK, [ BattlerTagLapseType.PRE_MOVE, BattlerTagLapseType.TURN_END ], turnCount, sourceMove); + } + + onActivation(pokemon: Pokemon): string { + return i18next.t("battle:battlerTagsHealBlock", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) }); + } + + /** + * Checks if a move is disabled under Heal Block + * @param {Moves} move {@linkcode Moves} the move ID + * @returns `true` if the move has a TRIAGE_MOVE flag and is a status move + */ + override isMoveRestricted(move: Moves): boolean { + if (allMoves[move].hasFlag(MoveFlags.TRIAGE_MOVE) && allMoves[move].category === MoveCategory.STATUS) { + return true; + } + return false; + } + + /** + * Checks if a move is disabled under Heal Block because of its choice of target + * Implemented b/c of Pollen Puff + * @param {Moves} move {@linkcode Moves} the move ID + * @param {Pokemon} user {@linkcode Pokemon} the move user + * @param {Pokemon} target {@linkcode Pokemon} the target of the move + * @returns `true` if the move cannot be used because the target is an ally + */ + override isMoveTargetRestricted(move: Moves, user: Pokemon, target: Pokemon) { + const moveCategory = new NumberHolder(allMoves[move].category); + applyMoveAttrs(StatusCategoryOnAllyAttr, user, target, allMoves[move], moveCategory); + if (allMoves[move].hasAttr(HealOnAllyAttr) && moveCategory.value === MoveCategory.STATUS ) { + return true; + } + return false; + } + + /** + * Uses its own unique selectionDeniedText() message + */ + override selectionDeniedText(pokemon: Pokemon, move: Moves): string { + return i18next.t("battle:moveDisabledHealBlock", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon), moveName: allMoves[move].name, healBlockName: allMoves[Moves.HEAL_BLOCK].name }); + } + + /** + * @override + * @param {Pokemon} pokemon {@linkcode Pokemon} attempting to use the restricted move + * @param {Moves} move {@linkcode Moves} ID of the move being interrupted + * @returns {string} text to display when the move is interrupted + */ + override interruptedText(pokemon: Pokemon, move: Moves): string { + return i18next.t("battle:moveDisabledHealBlock", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon), moveName: allMoves[move].name, healBlockName: allMoves[Moves.HEAL_BLOCK].name }); + } + + override onRemove(pokemon: Pokemon): void { + super.onRemove(pokemon); + + pokemon.scene.queueMessage(i18next.t("battle:battlerTagsHealBlockOnRemove", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) }), null, false, null); + } +} + /** * Tag that doubles the type effectiveness of Fire-type moves. * @extends BattlerTag @@ -2201,6 +2454,56 @@ export class TarShotTag extends BattlerTag { } } +/** + * Battler Tag implementing the type-changing effect of {@link https://bulbapedia.bulbagarden.net/wiki/Electrify_(move) | Electrify}. + * While this tag is in effect, the afflicted Pokemon's moves are changed to Electric type. + */ +export class ElectrifiedTag extends BattlerTag { + constructor() { + super(BattlerTagType.ELECTRIFIED, BattlerTagLapseType.TURN_END, 1, Moves.ELECTRIFY); + } + + override onAdd(pokemon: Pokemon): void { + // "{pokemonNameWithAffix}'s moves have been electrified!" + pokemon.scene.queueMessage(i18next.t("battlerTags:electrifiedOnAdd", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) })); + } +} + +/** + * Battler Tag that keeps track of how many times the user has Autotomized + * Each count of Autotomization reduces the weight by 100kg + */ +export class AutotomizedTag extends BattlerTag { + public autotomizeCount: number = 0; + constructor(sourceMove: Moves = Moves.AUTOTOMIZE) { + super(BattlerTagType.AUTOTOMIZED, BattlerTagLapseType.CUSTOM, 1, sourceMove); + } + + /** + * Adds an autotomize count to the Pokemon. Each stack reduces weight by 100kg + * If the Pokemon is over 0.1kg it also displays a message. + * @param pokemon The Pokemon that is being autotomized + */ + onAdd(pokemon: Pokemon): void { + const minWeight = 0.1; + if (pokemon.getWeight() > minWeight) { + pokemon.scene.queueMessage(i18next.t("battlerTags:autotomizeOnAdd", { + pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) + })); + } + this.autotomizeCount += 1; + } + + onOverlap(pokemon: Pokemon): void { + this.onAdd(pokemon); + } +} + +/** + * Tag implementing the {@link https://bulbapedia.bulbagarden.net/wiki/Substitute_(doll)#Effect | Substitute Doll} effect, + * for use with the moves Substitute and Shed Tail. Pokemon with this tag deflect most forms of received attack damage + * onto the tag. This tag also grants immunity to most Status moves and several move effects. + */ export class SubstituteTag extends BattlerTag { /** The substitute's remaining HP. If HP is depleted, the Substitute fades. */ public hp: number; @@ -2210,7 +2513,7 @@ export class SubstituteTag extends BattlerTag { public sourceInFocus: boolean; constructor(sourceMove: Moves, sourceId: integer) { - super(BattlerTagType.SUBSTITUTE, [BattlerTagLapseType.PRE_MOVE, BattlerTagLapseType.AFTER_MOVE, BattlerTagLapseType.HIT], 0, sourceMove, sourceId, true); + super(BattlerTagType.SUBSTITUTE, [ BattlerTagLapseType.PRE_MOVE, BattlerTagLapseType.AFTER_MOVE, BattlerTagLapseType.HIT ], 0, sourceMove, sourceId, true); } /** Sets the Substitute's HP and queues an on-add battle animation that initializes the Substitute's sprite. */ @@ -2220,7 +2523,11 @@ export class SubstituteTag extends BattlerTag { // Queue battle animation and message pokemon.scene.triggerPokemonBattleAnim(pokemon, PokemonAnimType.SUBSTITUTE_ADD); - pokemon.scene.queueMessage(i18next.t("battlerTags:substituteOnAdd", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) }), 1500); + if (this.sourceMove === Moves.SHED_TAIL) { + pokemon.scene.queueMessage(i18next.t("battlerTags:shedTailOnAdd", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) }), 1500); + } else { + pokemon.scene.queueMessage(i18next.t("battlerTags:substituteOnAdd", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) }), 1500); + } // Remove any binding effects from the user pokemon.findAndRemoveTags(tag => tag instanceof DamagingTrapTag); @@ -2230,7 +2537,7 @@ export class SubstituteTag extends BattlerTag { onRemove(pokemon: Pokemon): void { // Only play the animation if the cause of removal isn't from the source's own move if (!this.sourceInFocus) { - pokemon.scene.triggerPokemonBattleAnim(pokemon, PokemonAnimType.SUBSTITUTE_REMOVE, [this.sprite]); + pokemon.scene.triggerPokemonBattleAnim(pokemon, PokemonAnimType.SUBSTITUTE_REMOVE, [ this.sprite ]); } else { this.sprite.destroy(); } @@ -2239,28 +2546,28 @@ export class SubstituteTag extends BattlerTag { lapse(pokemon: Pokemon, lapseType: BattlerTagLapseType): boolean { switch (lapseType) { - case BattlerTagLapseType.PRE_MOVE: - this.onPreMove(pokemon); - break; - case BattlerTagLapseType.AFTER_MOVE: - this.onAfterMove(pokemon); - break; - case BattlerTagLapseType.HIT: - this.onHit(pokemon); - break; + case BattlerTagLapseType.PRE_MOVE: + this.onPreMove(pokemon); + break; + case BattlerTagLapseType.AFTER_MOVE: + this.onAfterMove(pokemon); + break; + case BattlerTagLapseType.HIT: + this.onHit(pokemon); + break; } return lapseType !== BattlerTagLapseType.CUSTOM; // only remove this tag on custom lapse } /** Triggers an animation that brings the Pokemon into focus before it uses a move */ onPreMove(pokemon: Pokemon): void { - pokemon.scene.triggerPokemonBattleAnim(pokemon, PokemonAnimType.SUBSTITUTE_PRE_MOVE, [this.sprite]); + pokemon.scene.triggerPokemonBattleAnim(pokemon, PokemonAnimType.SUBSTITUTE_PRE_MOVE, [ this.sprite ]); this.sourceInFocus = true; } /** Triggers an animation that brings the Pokemon out of focus after it uses a move */ onAfterMove(pokemon: Pokemon): void { - pokemon.scene.triggerPokemonBattleAnim(pokemon, PokemonAnimType.SUBSTITUTE_POST_MOVE, [this.sprite]); + pokemon.scene.triggerPokemonBattleAnim(pokemon, PokemonAnimType.SUBSTITUTE_POST_MOVE, [ this.sprite ]); this.sourceInFocus = false; } @@ -2268,7 +2575,10 @@ export class SubstituteTag extends BattlerTag { onHit(pokemon: Pokemon): void { const moveEffectPhase = pokemon.scene.getCurrentPhase(); if (moveEffectPhase instanceof MoveEffectPhase) { - const attacker = moveEffectPhase.getUserPokemon()!; + const attacker = moveEffectPhase.getUserPokemon(); + if (!attacker) { + return; + } const move = moveEffectPhase.move.getMove(); const firstHit = (attacker.turnData.hitCount === attacker.turnData.hitsLeft); @@ -2309,7 +2619,7 @@ export class MysteryEncounterPostSummonTag extends BattlerTag { const ret = super.lapse(pokemon, lapseType); if (lapseType === BattlerTagLapseType.CUSTOM) { - const cancelled = new Utils.BooleanHolder(false); + const cancelled = new BooleanHolder(false); applyAbAttrs(ProtectStatAbAttr, pokemon, cancelled); if (!cancelled.value) { if (pokemon.mysteryEncounterBattleEffects) { @@ -2327,172 +2637,495 @@ export class MysteryEncounterPostSummonTag extends BattlerTag { } } +/** + * Battle Tag that applies the move Torment to the target Pokemon + * Torment restricts the use of moves twice in a row. + * The tag is only removed if the target leaves the battle. + * Torment does not interrupt the move if the move is performed consecutively in the same turn and right after Torment is applied + */ +export class TormentTag extends MoveRestrictionBattlerTag { + constructor(sourceId: number) { + super(BattlerTagType.TORMENT, BattlerTagLapseType.AFTER_MOVE, 1, Moves.TORMENT, sourceId); + } + + /** + * Adds the battler tag to the target Pokemon and defines the private class variable 'target' + * 'Target' is used to track the Pokemon's current status + * @param {Pokemon} pokemon the Pokemon tormented + */ + override onAdd(pokemon: Pokemon) { + super.onAdd(pokemon); + pokemon.scene.queueMessage(i18next.t("battlerTags:tormentOnAdd", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) }), 1500); + } + + /** + * Torment only ends when the affected Pokemon leaves the battle field + * @param {Pokemon} pokemon the Pokemon under the effects of Torment + * @param _tagType + * @returns `true` if still present | `false` if not + */ + override lapse(pokemon: Pokemon, _tagType: BattlerTagLapseType): boolean { + return pokemon.isActive(true); + } + + /** + * This checks if the current move used is identical to the last used move with a {@linkcode MoveResult} of `SUCCESS`/`MISS` + * @param {Moves} move the move under investigation + * @returns `true` if there is valid consecutive usage | `false` if the moves are different from each other + */ + public override isMoveRestricted(move: Moves, user: Pokemon): boolean { + if (!user) { + return false; + } + const lastMove = user.getLastXMoves(1)[0]; + if ( !lastMove ) { + return false; + } + // This checks for locking / momentum moves like Rollout and Hydro Cannon + if the user is under the influence of BattlerTagType.FRENZY + // Because Uproar's unique behavior is not implemented, it does not check for Uproar. Torment has been marked as partial in moves.ts + const moveObj = allMoves[lastMove.move]; + const isUnaffected = moveObj.hasAttr(ConsecutiveUseDoublePowerAttr) || user.getTag(BattlerTagType.FRENZY); + const validLastMoveResult = (lastMove.result === MoveResult.SUCCESS) || (lastMove.result === MoveResult.MISS); + if (lastMove.move === move && validLastMoveResult && lastMove.move !== Moves.STRUGGLE && !isUnaffected) { + return true; + } + return false; + } + + override selectionDeniedText(pokemon: Pokemon, _move: Moves): string { + return i18next.t("battle:moveDisabledTorment", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) }); + } +} + +/** + * BattlerTag that applies the effects of Taunt to the target Pokemon + * Taunt restricts the use of status moves. + * The tag is removed after 4 turns. + */ +export class TauntTag extends MoveRestrictionBattlerTag { + constructor() { + super(BattlerTagType.TAUNT, [ BattlerTagLapseType.PRE_MOVE, BattlerTagLapseType.AFTER_MOVE ], 4, Moves.TAUNT); + } + + override onAdd(pokemon: Pokemon) { + super.onAdd(pokemon); + pokemon.scene.queueMessage(i18next.t("battlerTags:tauntOnAdd", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) }), 1500); + } + + /** + * Checks if a move is a status move and determines its restriction status on that basis + * @param {Moves} move the move under investigation + * @returns `true` if the move is a status move + */ + override isMoveRestricted(move: Moves): boolean { + return allMoves[move].category === MoveCategory.STATUS; + } + + override selectionDeniedText(pokemon: Pokemon, move: Moves): string { + return i18next.t("battle:moveDisabledTaunt", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon), moveName: allMoves[move].name }); + } + + override interruptedText(pokemon: Pokemon, move: Moves): string { + return i18next.t("battle:moveDisabledTaunt", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon), moveName: allMoves[move].name }); + } +} + +/** + * BattlerTag that applies the effects of Imprison to the target Pokemon + * Imprison restricts the opposing side's usage of moves shared by the source-user of Imprison. + * The tag is only removed when the source-user is removed from the field. + */ +export class ImprisonTag extends MoveRestrictionBattlerTag { + constructor(sourceId: number) { + super(BattlerTagType.IMPRISON, [ BattlerTagLapseType.PRE_MOVE, BattlerTagLapseType.AFTER_MOVE ], 1, Moves.IMPRISON, sourceId); + } + + /** + * Checks if the source of Imprison is still active + * @override + * @param pokemon The pokemon this tag is attached to + * @returns `true` if the source is still active + */ + public override lapse(pokemon: Pokemon, lapseType: BattlerTagLapseType): boolean { + const source = this.getSourcePokemon(pokemon.scene); + if (source) { + if (lapseType === BattlerTagLapseType.PRE_MOVE) { + return super.lapse(pokemon, lapseType) && source.isActive(true); + } else { + return source.isActive(true); + } + } + return false; + } + + /** + * Checks if the source of the tag has the parameter move in its moveset and that the source is still active + * @override + * @param {Moves} move the move under investigation + * @returns `false` if either condition is not met + */ + public override isMoveRestricted(move: Moves, user: Pokemon): boolean { + const source = this.getSourcePokemon(user.scene); + if (source) { + const sourceMoveset = source.getMoveset().map(m => m!.moveId); + return sourceMoveset?.includes(move) && source.isActive(true); + } + return false; + } + + override selectionDeniedText(pokemon: Pokemon, move: Moves): string { + return i18next.t("battle:moveDisabledImprison", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon), moveName: allMoves[move].name }); + } + + override interruptedText(pokemon: Pokemon, move: Moves): string { + return i18next.t("battle:moveDisabledImprison", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon), moveName: allMoves[move].name }); + } +} + +/** + * Battler Tag that applies the effects of Syrup Bomb to the target Pokemon. + * For three turns, starting from the turn of hit, at the end of each turn, the target Pokemon's speed will decrease by 1. + * The tag can also expire by taking the target Pokemon off the field, or the Pokemon that originally used the move. + */ +export class SyrupBombTag extends BattlerTag { + constructor(sourceId: number) { + super(BattlerTagType.SYRUP_BOMB, BattlerTagLapseType.TURN_END, 3, Moves.SYRUP_BOMB, sourceId); + } + + /** + * Adds the Syrup Bomb battler tag to the target Pokemon. + * @param pokemon - The target {@linkcode Pokemon} + */ + override onAdd(pokemon: Pokemon) { + super.onAdd(pokemon); + pokemon.scene.queueMessage(i18next.t("battlerTags:syrupBombOnAdd", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) })); + } + + /** + * Applies the single-stage speed down to the target Pokemon and decrements the tag's turn count + * @param pokemon - The target {@linkcode Pokemon} + * @param _lapseType - N/A + * @returns `true` if the `turnCount` is still greater than `0`; `false` if the `turnCount` is `0` or the target or source Pokemon has been removed from the field + */ + override lapse(pokemon: Pokemon, _lapseType: BattlerTagLapseType): boolean { + if (this.sourceId && !pokemon.scene.getPokemonById(this.sourceId)?.isActive(true)) { + return false; + } + // Custom message in lieu of an animation in mainline + pokemon.scene.queueMessage(i18next.t("battlerTags:syrupBombLapse", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) })); + pokemon.scene.unshiftPhase(new StatStageChangePhase( + pokemon.scene, pokemon.getBattlerIndex(), true, + [ Stat.SPD ], -1, true, false, true + )); + return --this.turnCount > 0; + } +} + +/** + * Telekinesis raises the target into the air for three turns and causes all moves used against the target (aside from OHKO moves) to hit the target unless the target is in a semi-invulnerable state from Fly/Dig. + * The first effect is provided by {@linkcode FloatingTag}, the accuracy-bypass effect is provided by TelekinesisTag + * The effects of Telekinesis can be baton passed to a teammate. Unlike the mainline games, Telekinesis can be baton-passed to Mega Gengar. + * @see {@link https://bulbapedia.bulbagarden.net/wiki/Telekinesis_(move) | Moves.TELEKINESIS} + */ +export class TelekinesisTag extends BattlerTag { + constructor(sourceMove: Moves) { + super(BattlerTagType.TELEKINESIS, [ BattlerTagLapseType.PRE_MOVE, BattlerTagLapseType.AFTER_MOVE ], 3, sourceMove, undefined, true); + } + + override onAdd(pokemon: Pokemon) { + pokemon.scene.queueMessage(i18next.t("battlerTags:telekinesisOnAdd", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) })); + } +} + +/** + * Tag that swaps the user's base ATK stat with its base DEF stat. + * @extends BattlerTag + */ +export class PowerTrickTag extends BattlerTag { + constructor(sourceMove: Moves, sourceId: number) { + super(BattlerTagType.POWER_TRICK, BattlerTagLapseType.CUSTOM, 0, sourceMove, sourceId, true); + } + + onAdd(pokemon: Pokemon): void { + this.swapStat(pokemon); + pokemon.scene.queueMessage(i18next.t("battlerTags:powerTrickActive", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) })); + } + + onRemove(pokemon: Pokemon): void { + this.swapStat(pokemon); + pokemon.scene.queueMessage(i18next.t("battlerTags:powerTrickActive", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) })); + } + + /** + * Removes the Power Trick tag and reverts any stat changes if the tag is already applied. + * @param {Pokemon} pokemon The {@linkcode Pokemon} that already has the Power Trick tag. + */ + onOverlap(pokemon: Pokemon): void { + pokemon.removeTag(this.tagType); + } + + /** + * Swaps the user's base ATK stat with its base DEF stat. + * @param {Pokemon} pokemon The {@linkcode Pokemon} whose stats will be swapped. + */ + swapStat(pokemon: Pokemon): void { + const temp = pokemon.getStat(Stat.ATK, false); + pokemon.setStat(Stat.ATK, pokemon.getStat(Stat.DEF, false), false); + pokemon.setStat(Stat.DEF, temp, false); + } +} + +/** + * Tag associated with the move Grudge. + * If this tag is active when the bearer faints from an opponent's move, the tag reduces that move's PP to 0. + * Otherwise, it lapses when the bearer makes another move. + */ +export class GrudgeTag extends BattlerTag { + constructor() { + super(BattlerTagType.GRUDGE, [ BattlerTagLapseType.CUSTOM, BattlerTagLapseType.PRE_MOVE ], 1, Moves.GRUDGE); + } + + onAdd(pokemon: Pokemon) { + super.onAdd(pokemon); + pokemon.scene.queueMessage(i18next.t("battlerTags:grudgeOnAdd", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) })); + } + + /** + * Activates Grudge's special effect on the attacking Pokemon and lapses the tag. + * @param pokemon + * @param lapseType + * @param sourcePokemon {@linkcode Pokemon} the source of the move that fainted the tag's bearer + * @returns `false` if Grudge activates its effect or lapses + */ + override lapse(pokemon: Pokemon, lapseType: BattlerTagLapseType, sourcePokemon?: Pokemon): boolean { + if (lapseType === BattlerTagLapseType.CUSTOM && sourcePokemon) { + if (sourcePokemon.isActive() && pokemon.isOpponent(sourcePokemon)) { + const lastMove = pokemon.turnData.attacksReceived[0]; + const lastMoveData = sourcePokemon.getMoveset().find(m => m?.moveId === lastMove.move); + if (lastMoveData && lastMove.move !== Moves.STRUGGLE) { + lastMoveData.ppUsed = lastMoveData.getMovePp(); + pokemon.scene.queueMessage(i18next.t("battlerTags:grudgeLapse", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon), moveName: lastMoveData.getName() })); + } + } + return false; + } else { + return super.lapse(pokemon, lapseType); + } + } +} + +/** + * Tag used to heal the user of Psycho Shift of its status effect if Psycho Shift succeeds in transferring its status effect to the target Pokemon + */ +export class PsychoShiftTag extends BattlerTag { + constructor() { + super(BattlerTagType.PSYCHO_SHIFT, BattlerTagLapseType.AFTER_MOVE, 1, Moves.PSYCHO_SHIFT); + } + + /** + * Heals Psycho Shift's user of its status effect after it uses a move + * @returns `false` to expire the tag immediately + */ + override lapse(pokemon: Pokemon, _lapseType: BattlerTagLapseType): boolean { + if (pokemon.status && pokemon.isActive(true)) { + pokemon.scene.queueMessage(getStatusEffectHealText(pokemon.status.effect, getPokemonNameWithAffix(pokemon))); + pokemon.resetStatus(); + pokemon.updateInfo(); + } + return false; + } +} + /** * Retrieves a {@linkcode BattlerTag} based on the provided tag type, turn count, source move, and source ID. - * - * @param {BattlerTagType} tagType the type of the {@linkcode BattlerTagType}. - * @param turnCount the turn count. - * @param {Moves} sourceMove the source {@linkcode Moves}. - * @param sourceId the source ID. - * @returns {BattlerTag} the corresponding {@linkcode BattlerTag} object. + * @param sourceId - The ID of the pokemon adding the tag + * @returns The corresponding {@linkcode BattlerTag} object. */ export function getBattlerTag(tagType: BattlerTagType, turnCount: number, sourceMove: Moves, sourceId: number): BattlerTag { switch (tagType) { - case BattlerTagType.RECHARGING: - return new RechargingTag(sourceMove); - case BattlerTagType.BEAK_BLAST_CHARGING: - return new BeakBlastChargingTag(); - case BattlerTagType.SHELL_TRAP: - return new ShellTrapTag(); - case BattlerTagType.FLINCHED: - return new FlinchedTag(sourceMove); - case BattlerTagType.INTERRUPTED: - return new InterruptedTag(sourceMove); - case BattlerTagType.CONFUSED: - return new ConfusedTag(turnCount, sourceMove); - case BattlerTagType.INFATUATED: - return new InfatuatedTag(sourceMove, sourceId); - case BattlerTagType.SEEDED: - return new SeedTag(sourceId); - case BattlerTagType.NIGHTMARE: - return new NightmareTag(); - case BattlerTagType.FRENZY: - return new FrenzyTag(turnCount, sourceMove, sourceId); - case BattlerTagType.CHARGING: - return new BattlerTag(tagType, BattlerTagLapseType.CUSTOM, 1, sourceMove, sourceId); - case BattlerTagType.ENCORE: - return new EncoreTag(sourceId); - case BattlerTagType.HELPING_HAND: - return new HelpingHandTag(sourceId); - case BattlerTagType.INGRAIN: - return new IngrainTag(sourceId); - case BattlerTagType.AQUA_RING: - return new AquaRingTag(); - case BattlerTagType.DROWSY: - return new DrowsyTag(); - case BattlerTagType.TRAPPED: - return new TrappedTag(tagType, BattlerTagLapseType.CUSTOM, turnCount, sourceMove, sourceId); - case BattlerTagType.NO_RETREAT: - return new NoRetreatTag(sourceId); - case BattlerTagType.BIND: - return new BindTag(turnCount, sourceId); - case BattlerTagType.WRAP: - return new WrapTag(turnCount, sourceId); - case BattlerTagType.FIRE_SPIN: - return new FireSpinTag(turnCount, sourceId); - case BattlerTagType.WHIRLPOOL: - return new WhirlpoolTag(turnCount, sourceId); - case BattlerTagType.CLAMP: - return new ClampTag(turnCount, sourceId); - case BattlerTagType.SAND_TOMB: - return new SandTombTag(turnCount, sourceId); - case BattlerTagType.MAGMA_STORM: - return new MagmaStormTag(turnCount, sourceId); - case BattlerTagType.SNAP_TRAP: - return new SnapTrapTag(turnCount, sourceId); - case BattlerTagType.THUNDER_CAGE: - return new ThunderCageTag(turnCount, sourceId); - case BattlerTagType.INFESTATION: - return new InfestationTag(turnCount, sourceId); - case BattlerTagType.PROTECTED: - return new ProtectedTag(sourceMove); - case BattlerTagType.SPIKY_SHIELD: - return new ContactDamageProtectedTag(sourceMove, 8); - case BattlerTagType.KINGS_SHIELD: - return new ContactStatStageChangeProtectedTag(sourceMove, tagType, Stat.ATK, -1); - case BattlerTagType.OBSTRUCT: - return new ContactStatStageChangeProtectedTag(sourceMove, tagType, Stat.DEF, -2); - case BattlerTagType.SILK_TRAP: - return new ContactStatStageChangeProtectedTag(sourceMove, tagType, Stat.SPD, -1); - case BattlerTagType.BANEFUL_BUNKER: - return new ContactPoisonProtectedTag(sourceMove); - case BattlerTagType.BURNING_BULWARK: - return new ContactBurnProtectedTag(sourceMove); - case BattlerTagType.ENDURING: - return new EnduringTag(sourceMove); - case BattlerTagType.STURDY: - return new SturdyTag(sourceMove); - case BattlerTagType.PERISH_SONG: - return new PerishSongTag(turnCount); - case BattlerTagType.CENTER_OF_ATTENTION: - return new CenterOfAttentionTag(sourceMove); - case BattlerTagType.TRUANT: - return new TruantTag(); - case BattlerTagType.SLOW_START: - return new SlowStartTag(); - case BattlerTagType.PROTOSYNTHESIS: - return new WeatherHighestStatBoostTag(tagType, Abilities.PROTOSYNTHESIS, WeatherType.SUNNY, WeatherType.HARSH_SUN); - case BattlerTagType.QUARK_DRIVE: - return new TerrainHighestStatBoostTag(tagType, Abilities.QUARK_DRIVE, TerrainType.ELECTRIC); - case BattlerTagType.FLYING: - case BattlerTagType.UNDERGROUND: - case BattlerTagType.UNDERWATER: - case BattlerTagType.HIDDEN: - return new SemiInvulnerableTag(tagType, turnCount, sourceMove); - case BattlerTagType.FIRE_BOOST: - return new TypeBoostTag(tagType, sourceMove, Type.FIRE, 1.5, false); - case BattlerTagType.CRIT_BOOST: - return new CritBoostTag(tagType, sourceMove); - case BattlerTagType.DRAGON_CHEER: - return new DragonCheerTag(); - case BattlerTagType.ALWAYS_CRIT: - case BattlerTagType.IGNORE_ACCURACY: - return new BattlerTag(tagType, BattlerTagLapseType.TURN_END, 2, sourceMove); - case BattlerTagType.ALWAYS_GET_HIT: - case BattlerTagType.RECEIVE_DOUBLE_DAMAGE: - return new BattlerTag(tagType, BattlerTagLapseType.PRE_MOVE, 1, sourceMove); - case BattlerTagType.BYPASS_SLEEP: - return new BattlerTag(tagType, BattlerTagLapseType.TURN_END, turnCount, sourceMove); - case BattlerTagType.IGNORE_FLYING: - return new GroundedTag(tagType, BattlerTagLapseType.CUSTOM, sourceMove); - case BattlerTagType.ROOSTED: - return new RoostedTag(); - case BattlerTagType.BURNED_UP: - return new RemovedTypeTag(tagType, BattlerTagLapseType.CUSTOM, sourceMove); - case BattlerTagType.DOUBLE_SHOCKED: - return new RemovedTypeTag(tagType, BattlerTagLapseType.CUSTOM, sourceMove); - case BattlerTagType.SALT_CURED: - return new SaltCuredTag(sourceId); - case BattlerTagType.CURSED: - return new CursedTag(sourceId); - case BattlerTagType.CHARGED: - return new TypeBoostTag(tagType, sourceMove, Type.ELECTRIC, 2, true); - case BattlerTagType.MAGNET_RISEN: - return new MagnetRisenTag(tagType, sourceMove); - case BattlerTagType.MINIMIZED: - return new MinimizeTag(); - case BattlerTagType.DESTINY_BOND: - return new DestinyBondTag(sourceMove, sourceId); - case BattlerTagType.ICE_FACE: - return new IceFaceBlockDamageTag(tagType); - case BattlerTagType.DISGUISE: - return new FormBlockDamageTag(tagType); - case BattlerTagType.STOCKPILING: - return new StockpilingTag(sourceMove); - case BattlerTagType.OCTOLOCK: - return new OctolockTag(sourceId); - case BattlerTagType.DISABLED: - return new DisabledTag(sourceId); - case BattlerTagType.IGNORE_GHOST: - return new ExposedTag(tagType, sourceMove, Type.GHOST, [Type.NORMAL, Type.FIGHTING]); - case BattlerTagType.IGNORE_DARK: - return new ExposedTag(tagType, sourceMove, Type.DARK, [Type.PSYCHIC]); - case BattlerTagType.GULP_MISSILE_ARROKUDA: - case BattlerTagType.GULP_MISSILE_PIKACHU: - return new GulpMissileTag(tagType, sourceMove); - case BattlerTagType.TAR_SHOT: - return new TarShotTag(); - case BattlerTagType.THROAT_CHOPPED: - return new ThroatChoppedTag(); - case BattlerTagType.GORILLA_TACTICS: - return new GorillaTacticsTag(); - case BattlerTagType.SUBSTITUTE: - return new SubstituteTag(sourceMove, sourceId); - case BattlerTagType.MYSTERY_ENCOUNTER_POST_SUMMON: - return new MysteryEncounterPostSummonTag(); - case BattlerTagType.NONE: - default: - return new BattlerTag(tagType, BattlerTagLapseType.CUSTOM, turnCount, sourceMove, sourceId); + case BattlerTagType.RECHARGING: + return new RechargingTag(sourceMove); + case BattlerTagType.BEAK_BLAST_CHARGING: + return new BeakBlastChargingTag(); + case BattlerTagType.SHELL_TRAP: + return new ShellTrapTag(); + case BattlerTagType.FLINCHED: + return new FlinchedTag(sourceMove); + case BattlerTagType.INTERRUPTED: + return new InterruptedTag(sourceMove); + case BattlerTagType.CONFUSED: + return new ConfusedTag(turnCount, sourceMove); + case BattlerTagType.INFATUATED: + return new InfatuatedTag(sourceMove, sourceId); + case BattlerTagType.SEEDED: + return new SeedTag(sourceId); + case BattlerTagType.NIGHTMARE: + return new NightmareTag(); + case BattlerTagType.FRENZY: + return new FrenzyTag(turnCount, sourceMove, sourceId); + case BattlerTagType.CHARGING: + return new BattlerTag(tagType, BattlerTagLapseType.CUSTOM, 1, sourceMove, sourceId); + case BattlerTagType.ENCORE: + return new EncoreTag(sourceId); + case BattlerTagType.HELPING_HAND: + return new HelpingHandTag(sourceId); + case BattlerTagType.INGRAIN: + return new IngrainTag(sourceId); + case BattlerTagType.AQUA_RING: + return new AquaRingTag(); + case BattlerTagType.DROWSY: + return new DrowsyTag(); + case BattlerTagType.TRAPPED: + return new TrappedTag(tagType, BattlerTagLapseType.CUSTOM, turnCount, sourceMove, sourceId); + case BattlerTagType.NO_RETREAT: + return new NoRetreatTag(sourceId); + case BattlerTagType.BIND: + return new BindTag(turnCount, sourceId); + case BattlerTagType.WRAP: + return new WrapTag(turnCount, sourceId); + case BattlerTagType.FIRE_SPIN: + return new FireSpinTag(turnCount, sourceId); + case BattlerTagType.WHIRLPOOL: + return new WhirlpoolTag(turnCount, sourceId); + case BattlerTagType.CLAMP: + return new ClampTag(turnCount, sourceId); + case BattlerTagType.SAND_TOMB: + return new SandTombTag(turnCount, sourceId); + case BattlerTagType.MAGMA_STORM: + return new MagmaStormTag(turnCount, sourceId); + case BattlerTagType.SNAP_TRAP: + return new SnapTrapTag(turnCount, sourceId); + case BattlerTagType.THUNDER_CAGE: + return new ThunderCageTag(turnCount, sourceId); + case BattlerTagType.INFESTATION: + return new InfestationTag(turnCount, sourceId); + case BattlerTagType.PROTECTED: + return new ProtectedTag(sourceMove); + case BattlerTagType.SPIKY_SHIELD: + return new ContactDamageProtectedTag(sourceMove, 8); + case BattlerTagType.KINGS_SHIELD: + return new ContactStatStageChangeProtectedTag(sourceMove, tagType, Stat.ATK, -1); + case BattlerTagType.OBSTRUCT: + return new ContactStatStageChangeProtectedTag(sourceMove, tagType, Stat.DEF, -2); + case BattlerTagType.SILK_TRAP: + return new ContactStatStageChangeProtectedTag(sourceMove, tagType, Stat.SPD, -1); + case BattlerTagType.BANEFUL_BUNKER: + return new ContactPoisonProtectedTag(sourceMove); + case BattlerTagType.BURNING_BULWARK: + return new ContactBurnProtectedTag(sourceMove); + case BattlerTagType.ENDURING: + return new EnduringTag(tagType, BattlerTagLapseType.TURN_END, sourceMove); + case BattlerTagType.ENDURE_TOKEN: + return new EnduringTag(tagType, BattlerTagLapseType.AFTER_HIT, sourceMove); + case BattlerTagType.STURDY: + return new SturdyTag(sourceMove); + case BattlerTagType.PERISH_SONG: + return new PerishSongTag(turnCount); + case BattlerTagType.CENTER_OF_ATTENTION: + return new CenterOfAttentionTag(sourceMove); + case BattlerTagType.TRUANT: + return new TruantTag(); + case BattlerTagType.SLOW_START: + return new SlowStartTag(); + case BattlerTagType.PROTOSYNTHESIS: + return new WeatherHighestStatBoostTag(tagType, Abilities.PROTOSYNTHESIS, WeatherType.SUNNY, WeatherType.HARSH_SUN); + case BattlerTagType.QUARK_DRIVE: + return new TerrainHighestStatBoostTag(tagType, Abilities.QUARK_DRIVE, TerrainType.ELECTRIC); + case BattlerTagType.FLYING: + case BattlerTagType.UNDERGROUND: + case BattlerTagType.UNDERWATER: + case BattlerTagType.HIDDEN: + return new SemiInvulnerableTag(tagType, turnCount, sourceMove); + case BattlerTagType.FIRE_BOOST: + return new TypeBoostTag(tagType, sourceMove, Type.FIRE, 1.5, false); + case BattlerTagType.CRIT_BOOST: + return new CritBoostTag(tagType, sourceMove); + case BattlerTagType.DRAGON_CHEER: + return new DragonCheerTag(); + case BattlerTagType.ALWAYS_CRIT: + case BattlerTagType.IGNORE_ACCURACY: + return new BattlerTag(tagType, BattlerTagLapseType.TURN_END, 2, sourceMove); + case BattlerTagType.ALWAYS_GET_HIT: + case BattlerTagType.RECEIVE_DOUBLE_DAMAGE: + return new BattlerTag(tagType, BattlerTagLapseType.PRE_MOVE, 1, sourceMove); + case BattlerTagType.BYPASS_SLEEP: + return new BattlerTag(tagType, BattlerTagLapseType.TURN_END, turnCount, sourceMove); + case BattlerTagType.IGNORE_FLYING: + return new GroundedTag(tagType, BattlerTagLapseType.CUSTOM, sourceMove); + case BattlerTagType.ROOSTED: + return new RoostedTag(); + case BattlerTagType.BURNED_UP: + return new RemovedTypeTag(tagType, BattlerTagLapseType.CUSTOM, sourceMove); + case BattlerTagType.DOUBLE_SHOCKED: + return new RemovedTypeTag(tagType, BattlerTagLapseType.CUSTOM, sourceMove); + case BattlerTagType.SALT_CURED: + return new SaltCuredTag(sourceId); + case BattlerTagType.CURSED: + return new CursedTag(sourceId); + case BattlerTagType.CHARGED: + return new TypeBoostTag(tagType, sourceMove, Type.ELECTRIC, 2, true); + case BattlerTagType.FLOATING: + return new FloatingTag(tagType, sourceMove, turnCount); + case BattlerTagType.MINIMIZED: + return new MinimizeTag(); + case BattlerTagType.DESTINY_BOND: + return new DestinyBondTag(sourceMove, sourceId); + case BattlerTagType.ICE_FACE: + return new IceFaceBlockDamageTag(tagType); + case BattlerTagType.DISGUISE: + return new FormBlockDamageTag(tagType); + case BattlerTagType.COMMANDED: + return new CommandedTag(sourceId); + case BattlerTagType.STOCKPILING: + return new StockpilingTag(sourceMove); + case BattlerTagType.OCTOLOCK: + return new OctolockTag(sourceId); + case BattlerTagType.DISABLED: + return new DisabledTag(sourceId); + case BattlerTagType.IGNORE_GHOST: + return new ExposedTag(tagType, sourceMove, Type.GHOST, [ Type.NORMAL, Type.FIGHTING ]); + case BattlerTagType.IGNORE_DARK: + return new ExposedTag(tagType, sourceMove, Type.DARK, [ Type.PSYCHIC ]); + case BattlerTagType.GULP_MISSILE_ARROKUDA: + case BattlerTagType.GULP_MISSILE_PIKACHU: + return new GulpMissileTag(tagType, sourceMove); + case BattlerTagType.TAR_SHOT: + return new TarShotTag(); + case BattlerTagType.ELECTRIFIED: + return new ElectrifiedTag(); + case BattlerTagType.THROAT_CHOPPED: + return new ThroatChoppedTag(); + case BattlerTagType.GORILLA_TACTICS: + return new GorillaTacticsTag(); + case BattlerTagType.UNBURDEN: + return new UnburdenTag(); + case BattlerTagType.SUBSTITUTE: + return new SubstituteTag(sourceMove, sourceId); + case BattlerTagType.AUTOTOMIZED: + return new AutotomizedTag(); + case BattlerTagType.MYSTERY_ENCOUNTER_POST_SUMMON: + return new MysteryEncounterPostSummonTag(); + case BattlerTagType.HEAL_BLOCK: + return new HealBlockTag(turnCount, sourceMove); + case BattlerTagType.TORMENT: + return new TormentTag(sourceId); + case BattlerTagType.TAUNT: + return new TauntTag(); + case BattlerTagType.IMPRISON: + return new ImprisonTag(sourceId); + case BattlerTagType.SYRUP_BOMB: + return new SyrupBombTag(sourceId); + case BattlerTagType.TELEKINESIS: + return new TelekinesisTag(sourceMove); + case BattlerTagType.POWER_TRICK: + return new PowerTrickTag(sourceMove, sourceId); + case BattlerTagType.GRUDGE: + return new GrudgeTag(); + case BattlerTagType.PSYCHO_SHIFT: + return new PsychoShiftTag(); + case BattlerTagType.NONE: + default: + return new BattlerTag(tagType, BattlerTagLapseType.CUSTOM, turnCount, sourceMove, sourceId); } } @@ -2506,3 +3139,22 @@ export function loadBattlerTag(source: BattlerTag | any): BattlerTag { tag.loadTag(source); return tag; } + +/** + * Helper function to verify that the current phase is a MoveEffectPhase and provide quick access to commonly used fields + * + * @param pokemon {@linkcode Pokemon} The Pokémon used to access the current phase + * @returns null if current phase is not MoveEffectPhase, otherwise Object containing the {@linkcode MoveEffectPhase}, and its + * corresponding {@linkcode Move} and user {@linkcode Pokemon} + */ +function getMoveEffectPhaseData(pokemon: Pokemon): {phase: MoveEffectPhase, attacker: Pokemon, move: Move} | null { + const phase = pokemon.scene.getCurrentPhase(); + if (phase instanceof MoveEffectPhase) { + return { + phase : phase, + attacker : phase.getPokemon(), + move : phase.move.getMove() + }; + } + return null; +} diff --git a/src/data/berry.ts b/src/data/berry.ts index 01325ee39dd..dfd6a7ddcf0 100644 --- a/src/data/berry.ts +++ b/src/data/berry.ts @@ -2,7 +2,7 @@ import { getPokemonNameWithAffix } from "../messages"; import Pokemon, { HitResult } from "../field/pokemon"; import { getStatusEffectHealText } from "./status-effect"; import * as Utils from "../utils"; -import { DoubleBerryEffectAbAttr, ReduceBerryUseThresholdAbAttr, applyAbAttrs } from "./ability"; +import { DoubleBerryEffectAbAttr, PostItemLostAbAttr, ReduceBerryUseThresholdAbAttr, applyAbAttrs, applyPostItemLostAbAttrs } from "./ability"; import i18next from "i18next"; import { BattlerTagType } from "#enums/battler-tag-type"; import { BerryType } from "#enums/berry-type"; @@ -22,113 +22,119 @@ export type BerryPredicate = (pokemon: Pokemon) => boolean; export function getBerryPredicate(berryType: BerryType): BerryPredicate { switch (berryType) { - case BerryType.SITRUS: - return (pokemon: Pokemon) => pokemon.getHpRatio() < 0.5; - case BerryType.LUM: - return (pokemon: Pokemon) => !!pokemon.status || !!pokemon.getTag(BattlerTagType.CONFUSED); - case BerryType.ENIGMA: - return (pokemon: Pokemon) => !!pokemon.turnData.attacksReceived.filter(a => a.result === HitResult.SUPER_EFFECTIVE).length; - case BerryType.LIECHI: - case BerryType.GANLON: - case BerryType.PETAYA: - case BerryType.APICOT: - case BerryType.SALAC: - return (pokemon: Pokemon) => { - const threshold = new Utils.NumberHolder(0.25); - // Offset BerryType such that LIECHI -> Stat.ATK = 1, GANLON -> Stat.DEF = 2, so on and so forth - const stat: BattleStat = berryType - BerryType.ENIGMA; - applyAbAttrs(ReduceBerryUseThresholdAbAttr, pokemon, null, false, threshold); - return pokemon.getHpRatio() < threshold.value && pokemon.getStatStage(stat) < 6; - }; - case BerryType.LANSAT: - return (pokemon: Pokemon) => { - const threshold = new Utils.NumberHolder(0.25); - applyAbAttrs(ReduceBerryUseThresholdAbAttr, pokemon, null, false, threshold); - return pokemon.getHpRatio() < 0.25 && !pokemon.getTag(BattlerTagType.CRIT_BOOST); - }; - case BerryType.STARF: - return (pokemon: Pokemon) => { - const threshold = new Utils.NumberHolder(0.25); - applyAbAttrs(ReduceBerryUseThresholdAbAttr, pokemon, null, false, threshold); - return pokemon.getHpRatio() < 0.25; - }; - case BerryType.LEPPA: - return (pokemon: Pokemon) => { - const threshold = new Utils.NumberHolder(0.25); - applyAbAttrs(ReduceBerryUseThresholdAbAttr, pokemon, null, false, threshold); - return !!pokemon.getMoveset().find(m => !m?.getPpRatio()); - }; + case BerryType.SITRUS: + return (pokemon: Pokemon) => pokemon.getHpRatio() < 0.5; + case BerryType.LUM: + return (pokemon: Pokemon) => !!pokemon.status || !!pokemon.getTag(BattlerTagType.CONFUSED); + case BerryType.ENIGMA: + return (pokemon: Pokemon) => !!pokemon.turnData.attacksReceived.filter(a => a.result === HitResult.SUPER_EFFECTIVE).length; + case BerryType.LIECHI: + case BerryType.GANLON: + case BerryType.PETAYA: + case BerryType.APICOT: + case BerryType.SALAC: + return (pokemon: Pokemon) => { + const threshold = new Utils.NumberHolder(0.25); + // Offset BerryType such that LIECHI -> Stat.ATK = 1, GANLON -> Stat.DEF = 2, so on and so forth + const stat: BattleStat = berryType - BerryType.ENIGMA; + applyAbAttrs(ReduceBerryUseThresholdAbAttr, pokemon, null, false, threshold); + return pokemon.getHpRatio() < threshold.value && pokemon.getStatStage(stat) < 6; + }; + case BerryType.LANSAT: + return (pokemon: Pokemon) => { + const threshold = new Utils.NumberHolder(0.25); + applyAbAttrs(ReduceBerryUseThresholdAbAttr, pokemon, null, false, threshold); + return pokemon.getHpRatio() < 0.25 && !pokemon.getTag(BattlerTagType.CRIT_BOOST); + }; + case BerryType.STARF: + return (pokemon: Pokemon) => { + const threshold = new Utils.NumberHolder(0.25); + applyAbAttrs(ReduceBerryUseThresholdAbAttr, pokemon, null, false, threshold); + return pokemon.getHpRatio() < 0.25; + }; + case BerryType.LEPPA: + return (pokemon: Pokemon) => { + const threshold = new Utils.NumberHolder(0.25); + applyAbAttrs(ReduceBerryUseThresholdAbAttr, pokemon, null, false, threshold); + return !!pokemon.getMoveset().find(m => !m?.getPpRatio()); + }; } } -export type BerryEffectFunc = (pokemon: Pokemon) => void; +export type BerryEffectFunc = (pokemon: Pokemon, berryOwner?: Pokemon) => void; export function getBerryEffectFunc(berryType: BerryType): BerryEffectFunc { switch (berryType) { - case BerryType.SITRUS: - case BerryType.ENIGMA: - return (pokemon: Pokemon) => { - if (pokemon.battleData) { - pokemon.battleData.berriesEaten.push(berryType); - } - const hpHealed = new Utils.NumberHolder(Utils.toDmgValue(pokemon.getMaxHp() / 4)); - applyAbAttrs(DoubleBerryEffectAbAttr, pokemon, null, false, hpHealed); - pokemon.scene.unshiftPhase(new PokemonHealPhase(pokemon.scene, pokemon.getBattlerIndex(), - hpHealed.value, i18next.t("battle:hpHealBerry", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon), berryName: getBerryName(berryType) }), true)); - }; - case BerryType.LUM: - return (pokemon: Pokemon) => { - if (pokemon.battleData) { - pokemon.battleData.berriesEaten.push(berryType); - } - if (pokemon.status) { - pokemon.scene.queueMessage(getStatusEffectHealText(pokemon.status.effect, getPokemonNameWithAffix(pokemon))); - } - pokemon.resetStatus(true, true); - pokemon.updateInfo(); - }; - case BerryType.LIECHI: - case BerryType.GANLON: - case BerryType.PETAYA: - case BerryType.APICOT: - case BerryType.SALAC: - return (pokemon: Pokemon) => { - if (pokemon.battleData) { - pokemon.battleData.berriesEaten.push(berryType); - } - // Offset BerryType such that LIECHI -> Stat.ATK = 1, GANLON -> Stat.DEF = 2, so on and so forth - const stat: BattleStat = berryType - BerryType.ENIGMA; - const statStages = new Utils.NumberHolder(1); - applyAbAttrs(DoubleBerryEffectAbAttr, pokemon, null, false, statStages); - pokemon.scene.unshiftPhase(new StatStageChangePhase(pokemon.scene, pokemon.getBattlerIndex(), true, [ stat ], statStages.value)); - }; - case BerryType.LANSAT: - return (pokemon: Pokemon) => { - if (pokemon.battleData) { - pokemon.battleData.berriesEaten.push(berryType); - } - pokemon.addTag(BattlerTagType.CRIT_BOOST); - }; - case BerryType.STARF: - return (pokemon: Pokemon) => { - if (pokemon.battleData) { - pokemon.battleData.berriesEaten.push(berryType); - } - const randStat = Utils.randSeedInt(Stat.SPD, Stat.ATK); - const stages = new Utils.NumberHolder(2); - applyAbAttrs(DoubleBerryEffectAbAttr, pokemon, null, false, stages); - pokemon.scene.unshiftPhase(new StatStageChangePhase(pokemon.scene, pokemon.getBattlerIndex(), true, [ randStat ], stages.value)); - }; - case BerryType.LEPPA: - return (pokemon: Pokemon) => { - if (pokemon.battleData) { - pokemon.battleData.berriesEaten.push(berryType); - } - const ppRestoreMove = pokemon.getMoveset().find(m => !m?.getPpRatio()) ? pokemon.getMoveset().find(m => !m?.getPpRatio()) : pokemon.getMoveset().find(m => m!.getPpRatio() < 1); // TODO: is this bang correct? - if (ppRestoreMove !== undefined) { + case BerryType.SITRUS: + case BerryType.ENIGMA: + return (pokemon: Pokemon, berryOwner?: Pokemon) => { + if (pokemon.battleData) { + pokemon.battleData.berriesEaten.push(berryType); + } + const hpHealed = new Utils.NumberHolder(Utils.toDmgValue(pokemon.getMaxHp() / 4)); + applyAbAttrs(DoubleBerryEffectAbAttr, pokemon, null, false, hpHealed); + pokemon.scene.unshiftPhase(new PokemonHealPhase(pokemon.scene, pokemon.getBattlerIndex(), + hpHealed.value, i18next.t("battle:hpHealBerry", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon), berryName: getBerryName(berryType) }), true)); + applyPostItemLostAbAttrs(PostItemLostAbAttr, berryOwner ?? pokemon, false); + }; + case BerryType.LUM: + return (pokemon: Pokemon, berryOwner?: Pokemon) => { + if (pokemon.battleData) { + pokemon.battleData.berriesEaten.push(berryType); + } + if (pokemon.status) { + pokemon.scene.queueMessage(getStatusEffectHealText(pokemon.status.effect, getPokemonNameWithAffix(pokemon))); + } + pokemon.resetStatus(true, true); + pokemon.updateInfo(); + applyPostItemLostAbAttrs(PostItemLostAbAttr, berryOwner ?? pokemon, false); + }; + case BerryType.LIECHI: + case BerryType.GANLON: + case BerryType.PETAYA: + case BerryType.APICOT: + case BerryType.SALAC: + return (pokemon: Pokemon, berryOwner?: Pokemon) => { + if (pokemon.battleData) { + pokemon.battleData.berriesEaten.push(berryType); + } + // Offset BerryType such that LIECHI -> Stat.ATK = 1, GANLON -> Stat.DEF = 2, so on and so forth + const stat: BattleStat = berryType - BerryType.ENIGMA; + const statStages = new Utils.NumberHolder(1); + applyAbAttrs(DoubleBerryEffectAbAttr, pokemon, null, false, statStages); + pokemon.scene.unshiftPhase(new StatStageChangePhase(pokemon.scene, pokemon.getBattlerIndex(), true, [ stat ], statStages.value)); + applyPostItemLostAbAttrs(PostItemLostAbAttr, berryOwner ?? pokemon, false); + }; + case BerryType.LANSAT: + return (pokemon: Pokemon, berryOwner?: Pokemon) => { + if (pokemon.battleData) { + pokemon.battleData.berriesEaten.push(berryType); + } + pokemon.addTag(BattlerTagType.CRIT_BOOST); + applyPostItemLostAbAttrs(PostItemLostAbAttr, berryOwner ?? pokemon, false); + }; + case BerryType.STARF: + return (pokemon: Pokemon, berryOwner?: Pokemon) => { + if (pokemon.battleData) { + pokemon.battleData.berriesEaten.push(berryType); + } + const randStat = Utils.randSeedInt(Stat.SPD, Stat.ATK); + const stages = new Utils.NumberHolder(2); + applyAbAttrs(DoubleBerryEffectAbAttr, pokemon, null, false, stages); + pokemon.scene.unshiftPhase(new StatStageChangePhase(pokemon.scene, pokemon.getBattlerIndex(), true, [ randStat ], stages.value)); + applyPostItemLostAbAttrs(PostItemLostAbAttr, berryOwner ?? pokemon, false); + }; + case BerryType.LEPPA: + return (pokemon: Pokemon, berryOwner?: Pokemon) => { + if (pokemon.battleData) { + pokemon.battleData.berriesEaten.push(berryType); + } + const ppRestoreMove = pokemon.getMoveset().find(m => !m?.getPpRatio()) ? pokemon.getMoveset().find(m => !m?.getPpRatio()) : pokemon.getMoveset().find(m => m!.getPpRatio() < 1); // TODO: is this bang correct? + if (ppRestoreMove !== undefined) { ppRestoreMove!.ppUsed = Math.max(ppRestoreMove!.ppUsed - 10, 0); pokemon.scene.queueMessage(i18next.t("battle:ppHealBerry", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon), moveName: ppRestoreMove!.getName(), berryName: getBerryName(berryType) })); - } - }; + applyPostItemLostAbAttrs(PostItemLostAbAttr, berryOwner ?? pokemon, false); + } + }; } } diff --git a/src/data/challenge.ts b/src/data/challenge.ts index 2205519c532..4301ea7b375 100644 --- a/src/data/challenge.ts +++ b/src/data/challenge.ts @@ -1,20 +1,21 @@ -import * as Utils from "../utils"; +import * as Utils from "#app/utils"; import i18next from "i18next"; import { defaultStarterSpecies, DexAttrProps, GameData } from "#app/system/game-data"; -import PokemonSpecies, { getPokemonSpecies, getPokemonSpeciesForm, speciesStarters } from "./pokemon-species"; +import PokemonSpecies, { getPokemonSpecies, getPokemonSpeciesForm } from "#app/data/pokemon-species"; +import { speciesStarterCosts } from "#app/data/balance/starters"; import Pokemon, { PokemonMove } from "#app/field/pokemon"; import { BattleType, FixedBattleConfig } from "#app/battle"; import Trainer, { TrainerVariant } from "#app/field/trainer"; import { GameMode } from "#app/game-mode"; -import { Type } from "./type"; +import { Type } from "#enums/type"; import { Challenges } from "#enums/challenges"; import { Species } from "#enums/species"; import { TrainerType } from "#enums/trainer-type"; -import { Nature } from "./nature"; -import { Moves } from "#app/enums/moves"; -import { TypeColor, TypeShadow } from "#app/enums/color"; -import { pokemonEvolutions } from "./pokemon-evolutions"; -import { pokemonFormChanges } from "./pokemon-forms"; +import { Nature } from "#enums/nature"; +import { Moves } from "#enums/moves"; +import { TypeColor, TypeShadow } from "#enums/color"; +import { pokemonEvolutions } from "#app/data/balance/pokemon-evolutions"; +import { pokemonFormChanges } from "#app/data/pokemon-forms"; /** A constant for the default max cost of the starting party before a run */ const DEFAULT_PARTY_MAX_COST = 10; @@ -172,11 +173,9 @@ export abstract class Challenge { * @param overrideValue {@link integer} The value to check for. If undefined, gets the current value. * @returns {@link string} The localised name for the current value. */ - getValue(overrideValue?: integer): string { - if (overrideValue === undefined) { - overrideValue = this.value; - } - return i18next.t(`challenges:${this.geti18nKey()}.value.${this.value}`); + getValue(overrideValue?: number): string { + const value = overrideValue ?? this.value; + return i18next.t(`challenges:${this.geti18nKey()}.value.${value}`); } /** @@ -184,11 +183,9 @@ export abstract class Challenge { * @param overrideValue {@link integer} The value to check for. If undefined, gets the current value. * @returns {@link string} The localised description for the current value. */ - getDescription(overrideValue?: integer): string { - if (overrideValue === undefined) { - overrideValue = this.value; - } - return `${i18next.t([`challenges:${this.geti18nKey()}.desc.${this.value}`, `challenges:${this.geti18nKey()}.desc`])}`; + getDescription(overrideValue?: number): string { + const value = overrideValue ?? this.value; + return `${i18next.t([ `challenges:${this.geti18nKey()}.desc.${value}`, `challenges:${this.geti18nKey()}.desc` ])}`; } /** @@ -417,9 +414,9 @@ export class SingleGenerationChallenge extends Challenge { } applyStarterChoice(pokemon: PokemonSpecies, valid: Utils.BooleanHolder, dexAttr: DexAttrProps, soft: boolean = false): boolean { - const generations = [pokemon.generation]; + const generations = [ pokemon.generation ]; if (soft) { - const speciesToCheck = [pokemon.speciesId]; + const speciesToCheck = [ pokemon.speciesId ]; while (speciesToCheck.length) { const checking = speciesToCheck.pop(); if (checking && pokemonEvolutions.hasOwnProperty(checking)) { @@ -451,21 +448,21 @@ export class SingleGenerationChallenge extends Challenge { applyFixedBattle(waveIndex: Number, battleConfig: FixedBattleConfig): boolean { let trainerTypes: TrainerType[] = []; switch (waveIndex) { - case 182: - trainerTypes = [ TrainerType.LORELEI, TrainerType.WILL, TrainerType.SIDNEY, TrainerType.AARON, TrainerType.SHAUNTAL, TrainerType.MALVA, Utils.randSeedItem([ TrainerType.HALA, TrainerType.MOLAYNE ]), TrainerType.MARNIE_ELITE, TrainerType.RIKA ]; - break; - case 184: - trainerTypes = [ TrainerType.BRUNO, TrainerType.KOGA, TrainerType.PHOEBE, TrainerType.BERTHA, TrainerType.MARSHAL, TrainerType.SIEBOLD, TrainerType.OLIVIA, TrainerType.NESSA_ELITE, TrainerType.POPPY ]; - break; - case 186: - trainerTypes = [ TrainerType.AGATHA, TrainerType.BRUNO, TrainerType.GLACIA, TrainerType.FLINT, TrainerType.GRIMSLEY, TrainerType.WIKSTROM, TrainerType.ACEROLA, Utils.randSeedItem([TrainerType.BEA_ELITE, TrainerType.ALLISTER_ELITE]), TrainerType.LARRY_ELITE ]; - break; - case 188: - trainerTypes = [ TrainerType.LANCE, TrainerType.KAREN, TrainerType.DRAKE, TrainerType.LUCIAN, TrainerType.CAITLIN, TrainerType.DRASNA, TrainerType.KAHILI, TrainerType.RAIHAN_ELITE, TrainerType.HASSEL ]; - break; - case 190: - trainerTypes = [ TrainerType.BLUE, Utils.randSeedItem([ TrainerType.RED, TrainerType.LANCE_CHAMPION ]), Utils.randSeedItem([ TrainerType.STEVEN, TrainerType.WALLACE ]), TrainerType.CYNTHIA, Utils.randSeedItem([ TrainerType.ALDER, TrainerType.IRIS ]), TrainerType.DIANTHA, TrainerType.HAU, TrainerType.LEON, Utils.randSeedItem([ TrainerType.GEETA, TrainerType.NEMONA ]) ]; - break; + case 182: + trainerTypes = [ TrainerType.LORELEI, TrainerType.WILL, TrainerType.SIDNEY, TrainerType.AARON, TrainerType.SHAUNTAL, TrainerType.MALVA, Utils.randSeedItem([ TrainerType.HALA, TrainerType.MOLAYNE ]), TrainerType.MARNIE_ELITE, TrainerType.RIKA ]; + break; + case 184: + trainerTypes = [ TrainerType.BRUNO, TrainerType.KOGA, TrainerType.PHOEBE, TrainerType.BERTHA, TrainerType.MARSHAL, TrainerType.SIEBOLD, TrainerType.OLIVIA, TrainerType.NESSA_ELITE, TrainerType.POPPY ]; + break; + case 186: + trainerTypes = [ TrainerType.AGATHA, TrainerType.BRUNO, TrainerType.GLACIA, TrainerType.FLINT, TrainerType.GRIMSLEY, TrainerType.WIKSTROM, TrainerType.ACEROLA, Utils.randSeedItem([ TrainerType.BEA_ELITE, TrainerType.ALLISTER_ELITE ]), TrainerType.LARRY_ELITE ]; + break; + case 188: + trainerTypes = [ TrainerType.LANCE, TrainerType.KAREN, TrainerType.DRAKE, TrainerType.LUCIAN, TrainerType.CAITLIN, TrainerType.DRASNA, TrainerType.KAHILI, TrainerType.RAIHAN_ELITE, TrainerType.HASSEL ]; + break; + case 190: + trainerTypes = [ TrainerType.BLUE, Utils.randSeedItem([ TrainerType.RED, TrainerType.LANCE_CHAMPION ]), Utils.randSeedItem([ TrainerType.STEVEN, TrainerType.WALLACE ]), TrainerType.CYNTHIA, Utils.randSeedItem([ TrainerType.ALDER, TrainerType.IRIS ]), TrainerType.DIANTHA, TrainerType.HAU, TrainerType.LEON, Utils.randSeedItem([ TrainerType.GEETA, TrainerType.NEMONA ]) ]; + break; } if (trainerTypes.length === 0) { return false; @@ -487,14 +484,12 @@ export class SingleGenerationChallenge extends Challenge { * @param {value} overrideValue The value to check for. If undefined, gets the current value. * @returns {string} The localised name for the current value. */ - getValue(overrideValue?: integer): string { - if (overrideValue === undefined) { - overrideValue = this.value; - } - if (this.value === 0) { + getValue(overrideValue?: number): string { + const value = overrideValue ?? this.value; + if (value === 0) { return i18next.t("settings:off"); } - return i18next.t(`starterSelectUiHandler:gen${this.value}`); + return i18next.t(`starterSelectUiHandler:gen${value}`); } /** @@ -502,14 +497,12 @@ export class SingleGenerationChallenge extends Challenge { * @param {value} overrideValue The value to check for. If undefined, gets the current value. * @returns {string} The localised description for the current value. */ - getDescription(overrideValue?: integer): string { - if (overrideValue === undefined) { - overrideValue = this.value; - } - if (this.value === 0) { + getDescription(overrideValue?: number): string { + const value = overrideValue ?? this.value; + if (value === 0) { return i18next.t("challenges:singleGeneration.desc_default"); } - return i18next.t("challenges:singleGeneration.desc", { gen: i18next.t(`challenges:singleGeneration.gen_${this.value}`) }); + return i18next.t("challenges:singleGeneration.desc", { gen: i18next.t(`challenges:singleGeneration.gen_${value}`) }); } @@ -535,19 +528,20 @@ interface monotypeOverride { */ export class SingleTypeChallenge extends Challenge { private static TYPE_OVERRIDES: monotypeOverride[] = [ - {species: Species.MELOETTA, type: Type.PSYCHIC, fusion: true}, - {species: Species.CASTFORM, type: Type.NORMAL, fusion: false}, + { species: Species.CASTFORM, type: Type.NORMAL, fusion: false }, ]; + // TODO: Find a solution for all Pokemon with this ssui issue, including Basculin and Burmy + private static SPECIES_OVERRIDES: Species[] = [ Species.MELOETTA ]; constructor() { super(Challenges.SINGLE_TYPE, 18); } - applyStarterChoice(pokemon: PokemonSpecies, valid: Utils.BooleanHolder, dexAttr: DexAttrProps, soft: boolean = false): boolean { + override applyStarterChoice(pokemon: PokemonSpecies, valid: Utils.BooleanHolder, dexAttr: DexAttrProps, soft: boolean = false): boolean { const speciesForm = getPokemonSpeciesForm(pokemon.speciesId, dexAttr.formIndex); - const types = [speciesForm.type1, speciesForm.type2]; - if (soft) { - const speciesToCheck = [pokemon.speciesId]; + const types = [ speciesForm.type1, speciesForm.type2 ]; + if (soft && !SingleTypeChallenge.SPECIES_OVERRIDES.includes(pokemon.speciesId)) { + const speciesToCheck = [ pokemon.speciesId ]; while (speciesToCheck.length) { const checking = speciesToCheck.pop(); if (checking && pokemonEvolutions.hasOwnProperty(checking)) { @@ -612,9 +606,9 @@ export class SingleTypeChallenge extends Challenge { overrideValue = this.value; } const type = i18next.t(`pokemonInfo:Type.${Type[this.value - 1]}`); - const typeColor = `[color=${TypeColor[Type[this.value-1]]}][shadow=${TypeShadow[Type[this.value-1]]}]${type}[/shadow][/color]`; + const typeColor = `[color=${TypeColor[Type[this.value - 1]]}][shadow=${TypeShadow[Type[this.value - 1]]}]${type}[/shadow][/color]`; const defaultDesc = i18next.t("challenges:singleType.desc_default"); - const typeDesc = i18next.t("challenges:singleType.desc", {type: typeColor}); + const typeDesc = i18next.t("challenges:singleType.desc", { type: typeColor }); return this.value === 0 ? defaultDesc : typeDesc; } @@ -644,7 +638,7 @@ export class FreshStartChallenge extends Challenge { applyStarterCost(species: Species, cost: Utils.NumberHolder): boolean { if (defaultStarterSpecies.includes(species)) { - cost.value = speciesStarters[species]; + cost.value = speciesStarterCosts[species]; return true; } return false; @@ -659,7 +653,7 @@ export class FreshStartChallenge extends Challenge { pokemon.shiny = false; // Not shiny pokemon.variant = 0; // Not shiny pokemon.formIndex = 0; // Froakie should be base form - pokemon.ivs = [10, 10, 10, 10, 10, 10]; // Default IVs of 10 for all stats + pokemon.ivs = [ 15, 15, 15, 15, 15, 15 ]; // Default IVs of 15 for all stats (Updated to 15 from 10 in 1.2.0) return true; } @@ -726,7 +720,7 @@ export class LowerStarterMaxCostChallenge extends Challenge { } applyStarterChoice(pokemon: PokemonSpecies, valid: Utils.BooleanHolder): boolean { - if (speciesStarters[pokemon.speciesId] > DEFAULT_PARTY_MAX_COST - this.value) { + if (speciesStarterCosts[pokemon.speciesId] > DEFAULT_PARTY_MAX_COST - this.value) { valid.value = false; return true; } @@ -897,45 +891,45 @@ export function applyChallenges(gameMode: GameMode, challengeType: ChallengeType gameMode.challenges.forEach(c => { if (c.value !== 0) { switch (challengeType) { - case ChallengeType.STARTER_CHOICE: - ret ||= c.applyStarterChoice(args[0], args[1], args[2], args[3]); - break; - case ChallengeType.STARTER_POINTS: - ret ||= c.applyStarterPoints(args[0]); - break; - case ChallengeType.STARTER_COST: - ret ||= c.applyStarterCost(args[0], args[1]); - break; - case ChallengeType.STARTER_MODIFY: - ret ||= c.applyStarterModify(args[0]); - break; - case ChallengeType.POKEMON_IN_BATTLE: - ret ||= c.applyPokemonInBattle(args[0], args[1]); - break; - case ChallengeType.FIXED_BATTLES: - ret ||= c.applyFixedBattle(args[0], args[1]); - break; - case ChallengeType.TYPE_EFFECTIVENESS: - ret ||= c.applyTypeEffectiveness(args[0]); - break; - case ChallengeType.AI_LEVEL: - ret ||= c.applyLevelChange(args[0], args[1], args[2], args[3]); - break; - case ChallengeType.AI_MOVE_SLOTS: - ret ||= c.applyMoveSlot(args[0], args[1]); - break; - case ChallengeType.PASSIVE_ACCESS: - ret ||= c.applyPassiveAccess(args[0], args[1]); - break; - case ChallengeType.GAME_MODE_MODIFY: - ret ||= c.applyGameModeModify(gameMode); - break; - case ChallengeType.MOVE_ACCESS: - ret ||= c.applyMoveAccessLevel(args[0], args[1], args[2], args[3]); - break; - case ChallengeType.MOVE_WEIGHT: - ret ||= c.applyMoveWeight(args[0], args[1], args[2], args[3]); - break; + case ChallengeType.STARTER_CHOICE: + ret ||= c.applyStarterChoice(args[0], args[1], args[2], args[3]); + break; + case ChallengeType.STARTER_POINTS: + ret ||= c.applyStarterPoints(args[0]); + break; + case ChallengeType.STARTER_COST: + ret ||= c.applyStarterCost(args[0], args[1]); + break; + case ChallengeType.STARTER_MODIFY: + ret ||= c.applyStarterModify(args[0]); + break; + case ChallengeType.POKEMON_IN_BATTLE: + ret ||= c.applyPokemonInBattle(args[0], args[1]); + break; + case ChallengeType.FIXED_BATTLES: + ret ||= c.applyFixedBattle(args[0], args[1]); + break; + case ChallengeType.TYPE_EFFECTIVENESS: + ret ||= c.applyTypeEffectiveness(args[0]); + break; + case ChallengeType.AI_LEVEL: + ret ||= c.applyLevelChange(args[0], args[1], args[2], args[3]); + break; + case ChallengeType.AI_MOVE_SLOTS: + ret ||= c.applyMoveSlot(args[0], args[1]); + break; + case ChallengeType.PASSIVE_ACCESS: + ret ||= c.applyPassiveAccess(args[0], args[1]); + break; + case ChallengeType.GAME_MODE_MODIFY: + ret ||= c.applyGameModeModify(gameMode); + break; + case ChallengeType.MOVE_ACCESS: + ret ||= c.applyMoveAccessLevel(args[0], args[1], args[2], args[3]); + break; + case ChallengeType.MOVE_WEIGHT: + ret ||= c.applyMoveWeight(args[0], args[1], args[2], args[3]); + break; } } }); @@ -949,18 +943,18 @@ export function applyChallenges(gameMode: GameMode, challengeType: ChallengeType */ export function copyChallenge(source: Challenge | any): Challenge { switch (source.id) { - case Challenges.SINGLE_GENERATION: - return SingleGenerationChallenge.loadChallenge(source); - case Challenges.SINGLE_TYPE: - return SingleTypeChallenge.loadChallenge(source); - case Challenges.LOWER_MAX_STARTER_COST: - return LowerStarterMaxCostChallenge.loadChallenge(source); - case Challenges.LOWER_STARTER_POINTS: - return LowerStarterPointsChallenge.loadChallenge(source); - case Challenges.FRESH_START: - return FreshStartChallenge.loadChallenge(source); - case Challenges.INVERSE_BATTLE: - return InverseBattleChallenge.loadChallenge(source); + case Challenges.SINGLE_GENERATION: + return SingleGenerationChallenge.loadChallenge(source); + case Challenges.SINGLE_TYPE: + return SingleTypeChallenge.loadChallenge(source); + case Challenges.LOWER_MAX_STARTER_COST: + return LowerStarterMaxCostChallenge.loadChallenge(source); + case Challenges.LOWER_STARTER_POINTS: + return LowerStarterPointsChallenge.loadChallenge(source); + case Challenges.FRESH_START: + return FreshStartChallenge.loadChallenge(source); + case Challenges.INVERSE_BATTLE: + return InverseBattleChallenge.loadChallenge(source); } throw new Error("Unknown challenge copied"); } diff --git a/src/data/mystery-encounters/mystery-encounter-pokemon-data.ts b/src/data/custom-pokemon-data.ts similarity index 64% rename from src/data/mystery-encounters/mystery-encounter-pokemon-data.ts rename to src/data/custom-pokemon-data.ts index fc6ce313d41..7bc884cff50 100644 --- a/src/data/mystery-encounters/mystery-encounter-pokemon-data.ts +++ b/src/data/custom-pokemon-data.ts @@ -1,18 +1,20 @@ import { Abilities } from "#enums/abilities"; -import { Type } from "#app/data/type"; +import { Type } from "#enums/type"; import { isNullOrUndefined } from "#app/utils"; +import { Nature } from "#enums/nature"; /** * Data that can customize a Pokemon in non-standard ways from its Species - * Currently only used by Mystery Encounters, may need to be renamed if it becomes more widely used + * Currently only used by Mystery Encounters and Mints. */ -export class MysteryEncounterPokemonData { +export class CustomPokemonData { public spriteScale: number; public ability: Abilities | -1; public passive: Abilities | -1; + public nature: Nature | -1; public types: Type[]; - constructor(data?: MysteryEncounterPokemonData | Partial) { + constructor(data?: CustomPokemonData | Partial) { if (!isNullOrUndefined(data)) { Object.assign(this, data); } @@ -20,6 +22,7 @@ export class MysteryEncounterPokemonData { this.spriteScale = this.spriteScale ?? -1; this.ability = this.ability ?? -1; this.passive = this.passive ?? -1; + this.nature = this.nature ?? -1; this.types = this.types ?? []; } } diff --git a/src/data/daily-run.ts b/src/data/daily-run.ts index 370b13ea3a3..506ea0471c6 100644 --- a/src/data/daily-run.ts +++ b/src/data/daily-run.ts @@ -1,10 +1,12 @@ import { PartyMemberStrength } from "#enums/party-member-strength"; import { Species } from "#enums/species"; -import BattleScene from "../battle-scene"; -import { PlayerPokemon } from "../field/pokemon"; -import { Starter } from "../ui/starter-select-ui-handler"; -import * as Utils from "../utils"; -import PokemonSpecies, { PokemonSpeciesForm, getPokemonSpecies, getPokemonSpeciesForm, speciesStarters } from "./pokemon-species"; +import BattleScene from "#app/battle-scene"; +import { PlayerPokemon } from "#app/field/pokemon"; +import { Starter } from "#app/ui/starter-select-ui-handler"; +import * as Utils from "#app/utils"; +import PokemonSpecies, { PokemonSpeciesForm, getPokemonSpecies, getPokemonSpeciesForm } from "#app/data/pokemon-species"; +import { speciesStarterCosts } from "#app/data/balance/starters"; +import { pokerogueApi } from "#app/plugins/api/pokerogue-api"; export interface DailyRunConfig { seed: integer; @@ -13,14 +15,9 @@ export interface DailyRunConfig { export function fetchDailyRunSeed(): Promise { return new Promise((resolve, reject) => { - Utils.apiFetch("daily/seed").then(response => { - if (!response.ok) { - resolve(null); - return; - } - return response.text(); - }).then(seed => resolve(seed ?? null)) - .catch(err => reject(err)); + pokerogueApi.daily.getSeed().then(dailySeed => { + resolve(dailySeed); + }); }); } @@ -46,9 +43,9 @@ export function getDailyRunStarters(scene: BattleScene, seed: string): Starter[] for (let c = 0; c < starterCosts.length; c++) { const cost = starterCosts[c]; - const costSpecies = Object.keys(speciesStarters) + const costSpecies = Object.keys(speciesStarterCosts) .map(s => parseInt(s) as Species) - .filter(s => speciesStarters[s] === cost); + .filter(s => speciesStarterCosts[s] === cost); const randPkmSpecies = getPokemonSpecies(Utils.randSeedItem(costSpecies)); const starterSpecies = getPokemonSpecies(randPkmSpecies.getTrainerSpeciesForLevel(startingLevel, true, PartyMemberStrength.STRONGER)); starters.push(getDailyRunStarter(scene, starterSpecies, startingLevel)); diff --git a/src/data/dialogue.ts b/src/data/dialogue.ts index b01242d083a..3219ce4d058 100644 --- a/src/data/dialogue.ts +++ b/src/data/dialogue.ts @@ -353,6 +353,25 @@ export const trainerTypeDialogue: TrainerTypeDialogue = { ] }, ], + // Defeat dialogue in the language .JSONS exist as translated or placeholders; (en, fr, it, es, de, ja, ko, zh_cn, zh_tw, pt_br) + [TrainerType.SNOW_WORKER]: [ + { + encounter: [ + "dialogue:snow_worker.encounter.1", + ], + victory: [ + "dialogue:snow_worker.victory.1", + ] + }, + { + encounter: [ + "dialogue:snow_worker_double.encounter.1", + ], + victory: [ + "dialogue:snow_worker_double.victory.1", + ] + }, + ], [TrainerType.HEX_MANIAC]: [ { encounter: [ @@ -837,11 +856,15 @@ export const trainerTypeDialogue: TrainerTypeDialogue = { "dialogue:macro_grunt.encounter.1", "dialogue:macro_grunt.encounter.2", "dialogue:macro_grunt.encounter.3", + "dialogue:macro_grunt.encounter.4", + "dialogue:macro_grunt.encounter.5", ], victory: [ "dialogue:macro_grunt.victory.1", "dialogue:macro_grunt.victory.2", "dialogue:macro_grunt.victory.3", + "dialogue:macro_grunt.victory.4", + "dialogue:macro_grunt.victory.5", ] } ], @@ -859,6 +882,84 @@ export const trainerTypeDialogue: TrainerTypeDialogue = { ] } ], + [TrainerType.STAR_GRUNT]: [ + { + encounter: [ + "dialogue:star_grunt.encounter.1", + "dialogue:star_grunt.encounter.2", + "dialogue:star_grunt.encounter.3", + "dialogue:star_grunt.encounter.4", + "dialogue:star_grunt.encounter.5", + ], + victory: [ + "dialogue:star_grunt.victory.1", + "dialogue:star_grunt.victory.2", + "dialogue:star_grunt.victory.3", + "dialogue:star_grunt.victory.4", + "dialogue:star_grunt.victory.5", + ] + } + ], + [TrainerType.GIACOMO]: [ + { + encounter: [ + "dialogue:giacomo.encounter.1", + "dialogue:giacomo.encounter.2", + ], + victory: [ + "dialogue:giacomo.victory.1", + "dialogue:giacomo.victory.2", + ] + } + ], + [TrainerType.MELA]: [ + { + encounter: [ + "dialogue:mela.encounter.1", + "dialogue:mela.encounter.2", + ], + victory: [ + "dialogue:mela.victory.1", + "dialogue:mela.victory.2", + ] + } + ], + [TrainerType.ATTICUS]: [ + { + encounter: [ + "dialogue:atticus.encounter.1", + "dialogue:atticus.encounter.2", + ], + victory: [ + "dialogue:atticus.victory.1", + "dialogue:atticus.victory.2", + ] + } + ], + [TrainerType.ORTEGA]: [ + { + encounter: [ + "dialogue:ortega.encounter.1", + "dialogue:ortega.encounter.2", + ], + victory: [ + "dialogue:ortega.victory.1", + "dialogue:ortega.victory.2", + ] + } + ], + [TrainerType.ERI]: [ + { + encounter: [ + "dialogue:eri.encounter.1", + "dialogue:eri.encounter.2", + ], + victory: [ + "dialogue:eri.victory.1", + "dialogue:eri.victory.2", + ] + } + ], [TrainerType.ROCKET_BOSS_GIOVANNI_1]: [ { encounter: [ @@ -1093,6 +1194,32 @@ export const trainerTypeDialogue: TrainerTypeDialogue = { ] } ], + [TrainerType.PENNY]: [ + { + encounter: [ + "dialogue:star_boss_penny_1.encounter.1" + ], + victory: [ + "dialogue:star_boss_penny_1.victory.1" + ], + defeat: [ + "dialogue:star_boss_penny_1.defeat.1" + ] + } + ], + [TrainerType.PENNY_2]: [ + { + encounter: [ + "dialogue:star_boss_penny_2.encounter.1" + ], + victory: [ + "dialogue:star_boss_penny_2.victory.1" + ], + defeat: [ + "dialogue:star_boss_penny_2.defeat.1" + ] + } + ], [TrainerType.BUCK]: [ { encounter: [ @@ -2996,44 +3123,44 @@ export const trainerTypeDialogue: TrainerTypeDialogue = { export const doubleBattleDialogue = { "blue_red_double": { - encounter: ["doubleBattleDialogue:blue_red_double.encounter.1"], - victory: ["doubleBattleDialogue:blue_red_double.victory.1"] + encounter: [ "doubleBattleDialogue:blue_red_double.encounter.1" ], + victory: [ "doubleBattleDialogue:blue_red_double.victory.1" ] }, "red_blue_double": { - encounter: ["doubleBattleDialogue:red_blue_double.encounter.1"], - victory: ["doubleBattleDialogue:red_blue_double.victory.1"] + encounter: [ "doubleBattleDialogue:red_blue_double.encounter.1" ], + victory: [ "doubleBattleDialogue:red_blue_double.victory.1" ] }, "tate_liza_double": { - encounter: ["doubleBattleDialogue:tate_liza_double.encounter.1"], - victory: ["doubleBattleDialogue:tate_liza_double.victory.1"] + encounter: [ "doubleBattleDialogue:tate_liza_double.encounter.1" ], + victory: [ "doubleBattleDialogue:tate_liza_double.victory.1" ] }, "liza_tate_double": { - encounter: ["doubleBattleDialogue:liza_tate_double.encounter.1"], - victory: [ "doubleBattleDialogue:liza_tate_double.victory.1"] + encounter: [ "doubleBattleDialogue:liza_tate_double.encounter.1" ], + victory: [ "doubleBattleDialogue:liza_tate_double.victory.1" ] }, "wallace_steven_double": { - encounter: [ "doubleBattleDialogue:wallace_steven_double.encounter.1"], - victory: [ "doubleBattleDialogue:wallace_steven_double.victory.1"] + encounter: [ "doubleBattleDialogue:wallace_steven_double.encounter.1" ], + victory: [ "doubleBattleDialogue:wallace_steven_double.victory.1" ] }, "steven_wallace_double": { - encounter: [ "doubleBattleDialogue:steven_wallace_double.encounter.1"], - victory: [ "doubleBattleDialogue:steven_wallace_double.victory.1"] + encounter: [ "doubleBattleDialogue:steven_wallace_double.encounter.1" ], + victory: [ "doubleBattleDialogue:steven_wallace_double.victory.1" ] }, "alder_iris_double": { - encounter: [ "doubleBattleDialogue:alder_iris_double.encounter.1"], - victory: [ "doubleBattleDialogue:alder_iris_double.victory.1"] + encounter: [ "doubleBattleDialogue:alder_iris_double.encounter.1" ], + victory: [ "doubleBattleDialogue:alder_iris_double.victory.1" ] }, "iris_alder_double": { - encounter: [ "doubleBattleDialogue:iris_alder_double.encounter.1"], - victory: [ "doubleBattleDialogue:iris_alder_double.victory.1"] + encounter: [ "doubleBattleDialogue:iris_alder_double.encounter.1" ], + victory: [ "doubleBattleDialogue:iris_alder_double.victory.1" ] }, "marnie_piers_double": { - encounter: [ "doubleBattleDialogue:marnie_piers_double.encounter.1"], - victory: [ "doubleBattleDialogue:marnie_piers_double.victory.1"] + encounter: [ "doubleBattleDialogue:marnie_piers_double.encounter.1" ], + victory: [ "doubleBattleDialogue:marnie_piers_double.victory.1" ] }, "piers_marnie_double": { - encounter: [ "doubleBattleDialogue:piers_marnie_double.encounter.1"], - victory: [ "doubleBattleDialogue:piers_marnie_double.victory.1"] + encounter: [ "doubleBattleDialogue:piers_marnie_double.encounter.1" ], + victory: [ "doubleBattleDialogue:piers_marnie_double.victory.1" ] }, @@ -3066,7 +3193,7 @@ export function initTrainerTypeDialogue(): void { const trainerTypes = Object.keys(trainerTypeDialogue).map(t => parseInt(t) as TrainerType); for (const trainerType of trainerTypes) { const messages = trainerTypeDialogue[trainerType]; - const messageTypes = ["encounter", "victory", "defeat"]; + const messageTypes = [ "encounter", "victory", "defeat" ]; for (const messageType of messageTypes) { if (Array.isArray(messages)) { if (messages[0][messageType]) { diff --git a/src/data/egg-hatch-data.ts b/src/data/egg-hatch-data.ts index e754a9205c4..ba553b55c4f 100644 --- a/src/data/egg-hatch-data.ts +++ b/src/data/egg-hatch-data.ts @@ -48,7 +48,7 @@ export class EggHatchData { seenCount: currDexEntry.seenCount, caughtCount: currDexEntry.caughtCount, hatchedCount: currDexEntry.hatchedCount, - ivs: [...currDexEntry.ivs] + ivs: [ ...currDexEntry.ivs ] }; this.starterDataEntryBeforeUpdate = { moveset: currStarterDataEntry.moveset, diff --git a/src/data/egg.ts b/src/data/egg.ts index 0219f4f5b47..f7d109dfa62 100644 --- a/src/data/egg.ts +++ b/src/data/egg.ts @@ -1,30 +1,20 @@ -import BattleScene from "../battle-scene"; -import PokemonSpecies, { getPokemonSpecies, speciesStarters } from "./pokemon-species"; -import { VariantTier } from "../enums/variant-tiers"; -import * as Utils from "../utils"; +import BattleScene from "#app/battle-scene"; +import PokemonSpecies, { getPokemonSpecies } from "#app/data/pokemon-species"; +import { speciesStarterCosts } from "#app/data/balance/starters"; +import { VariantTier } from "#enums/variant-tier"; +import * as Utils from "#app/utils"; import Overrides from "#app/overrides"; -import { pokemonPrevolutions } from "./pokemon-evolutions"; +import { pokemonPrevolutions } from "#app/data/balance/pokemon-evolutions"; import { PlayerPokemon } from "#app/field/pokemon"; import i18next from "i18next"; import { EggTier } from "#enums/egg-type"; import { Species } from "#enums/species"; -import { EggSourceType } from "#app/enums/egg-source-types"; +import { EggSourceType } from "#enums/egg-source-types"; +import { MANAPHY_EGG_MANAPHY_RATE, SAME_SPECIES_EGG_HA_RATE, GACHA_EGG_HA_RATE, GACHA_DEFAULT_RARE_EGGMOVE_RATE, SAME_SPECIES_EGG_RARE_EGGMOVE_RATE, GACHA_MOVE_UP_RARE_EGGMOVE_RATE, GACHA_DEFAULT_SHINY_RATE, GACHA_SHINY_UP_SHINY_RATE, SAME_SPECIES_EGG_SHINY_RATE, EGG_PITY_LEGENDARY_THRESHOLD, EGG_PITY_EPIC_THRESHOLD, EGG_PITY_RARE_THRESHOLD, SHINY_VARIANT_CHANCE, SHINY_EPIC_CHANCE, GACHA_DEFAULT_COMMON_EGG_THRESHOLD, GACHA_DEFAULT_RARE_EGG_THRESHOLD, GACHA_DEFAULT_EPIC_EGG_THRESHOLD, GACHA_LEGENDARY_UP_THRESHOLD_OFFSET, HATCH_WAVES_MANAPHY_EGG, HATCH_WAVES_COMMON_EGG, HATCH_WAVES_RARE_EGG, HATCH_WAVES_EPIC_EGG, HATCH_WAVES_LEGENDARY_EGG } from "#app/data/balance/rates"; +import { speciesEggTiers } from "#app/data/balance/species-egg-tiers"; export const EGG_SEED = 1073741824; -// Rates for specific random properties in 1/x -const DEFAULT_SHINY_RATE = 128; -const GACHA_SHINY_UP_SHINY_RATE = 64; -const SAME_SPECIES_EGG_SHINY_RATE = 12; -const SAME_SPECIES_EGG_HA_RATE = 8; -const MANAPHY_EGG_MANAPHY_RATE = 8; -const GACHA_EGG_HA_RATE = 192; - -// 1/x for legendary eggs, 1/x*2 for epic eggs, 1/x*4 for rare eggs, and 1/x*8 for common eggs -const DEFAULT_RARE_EGGMOVE_RATE = 6; -const SAME_SPECIES_EGG_RARE_EGGMOVE_RATE = 3; -const GACHA_MOVE_UP_RARE_EGGMOVE_RATE = 3; - /** Egg options to override egg properties */ export interface IEggOptions { /** Id. Used to check if egg type will be manaphy (id % 204 === 0) */ @@ -171,14 +161,14 @@ export class Egg { // Override egg tier and hatchwaves if species was given if (eggOptions?.species) { - this._tier = this.getEggTierFromSpeciesStarterValue(); + this._tier = this.getEggTier(); this._hatchWaves = eggOptions.hatchWaves ?? this.getEggTierDefaultHatchWaves(); } // If species has no variant, set variantTier to common. This needs to // be done because species with no variants get filtered at rollSpecies but if the // species is set via options or the legendary gacha pokemon gets choosen the check never happens if (this._species && !getPokemonSpecies(this._species).hasVariants()) { - this._variantTier = VariantTier.COMMON; + this._variantTier = VariantTier.STANDARD; } // Needs this._tier so it needs to be generated afer the tier override if bought from same species this._eggMoveIndex = eggOptions?.eggMoveIndex ?? this.rollEggMoveIndex(); @@ -272,14 +262,14 @@ export class Egg { return "Manaphy"; } switch (this.tier) { - case EggTier.GREAT: - return i18next.t("egg:greatTier"); - case EggTier.ULTRA: - return i18next.t("egg:ultraTier"); - case EggTier.MASTER: - return i18next.t("egg:masterTier"); - default: - return i18next.t("egg:defaultTier"); + case EggTier.RARE: + return i18next.t("egg:greatTier"); + case EggTier.EPIC: + return i18next.t("egg:ultraTier"); + case EggTier.LEGENDARY: + return i18next.t("egg:masterTier"); + default: + return i18next.t("egg:defaultTier"); } } @@ -298,19 +288,19 @@ export class Egg { public getEggTypeDescriptor(scene: BattleScene): string { switch (this.sourceType) { - case EggSourceType.SAME_SPECIES_EGG: - return this._eggDescriptor ?? i18next.t("egg:sameSpeciesEgg", { species: getPokemonSpecies(this._species).getName()}); - case EggSourceType.GACHA_LEGENDARY: - return this._eggDescriptor ?? `${i18next.t("egg:gachaTypeLegendary")} (${getPokemonSpecies(getLegendaryGachaSpeciesForTimestamp(scene, this.timestamp)).getName()})`; - case EggSourceType.GACHA_SHINY: - return this._eggDescriptor ?? i18next.t("egg:gachaTypeShiny"); - case EggSourceType.GACHA_MOVE: - return this._eggDescriptor ?? i18next.t("egg:gachaTypeMove"); - case EggSourceType.EVENT: - return this._eggDescriptor ?? i18next.t("egg:eventType"); - default: - console.warn("getEggTypeDescriptor case not defined. Returning default empty string"); - return ""; + case EggSourceType.SAME_SPECIES_EGG: + return this._eggDescriptor ?? i18next.t("egg:sameSpeciesEgg", { species: getPokemonSpecies(this._species).getName() }); + case EggSourceType.GACHA_LEGENDARY: + return this._eggDescriptor ?? `${i18next.t("egg:gachaTypeLegendary")} (${getPokemonSpecies(getLegendaryGachaSpeciesForTimestamp(scene, this.timestamp)).getName()})`; + case EggSourceType.GACHA_SHINY: + return this._eggDescriptor ?? i18next.t("egg:gachaTypeShiny"); + case EggSourceType.GACHA_MOVE: + return this._eggDescriptor ?? i18next.t("egg:gachaTypeMove"); + case EggSourceType.EVENT: + return this._eggDescriptor ?? i18next.t("egg:eventType"); + default: + console.warn("getEggTypeDescriptor case not defined. Returning default empty string"); + return ""; } } @@ -323,16 +313,16 @@ export class Egg { //// private rollEggMoveIndex() { - let baseChance = DEFAULT_RARE_EGGMOVE_RATE; + let baseChance = GACHA_DEFAULT_RARE_EGGMOVE_RATE; switch (this._sourceType) { - case EggSourceType.SAME_SPECIES_EGG: - baseChance = SAME_SPECIES_EGG_RARE_EGGMOVE_RATE; - break; - case EggSourceType.GACHA_MOVE: - baseChance = GACHA_MOVE_UP_RARE_EGGMOVE_RATE; - break; - default: - break; + case EggSourceType.SAME_SPECIES_EGG: + baseChance = SAME_SPECIES_EGG_RARE_EGGMOVE_RATE; + break; + case EggSourceType.GACHA_MOVE: + baseChance = GACHA_MOVE_UP_RARE_EGGMOVE_RATE; + break; + default: + break; } const tierMultiplier = this.isManaphyEgg() ? 2 : Math.pow(2, 3 - this.tier); @@ -341,24 +331,24 @@ export class Egg { private getEggTierDefaultHatchWaves(eggTier?: EggTier): number { if (this._species === Species.PHIONE || this._species === Species.MANAPHY) { - return 50; + return HATCH_WAVES_MANAPHY_EGG; } switch (eggTier ?? this._tier) { - case EggTier.COMMON: - return 10; - case EggTier.GREAT: - return 25; - case EggTier.ULTRA: - return 50; + case EggTier.COMMON: + return HATCH_WAVES_COMMON_EGG; + case EggTier.RARE: + return HATCH_WAVES_RARE_EGG; + case EggTier.EPIC: + return HATCH_WAVES_EPIC_EGG; } - return 100; + return HATCH_WAVES_LEGENDARY_EGG; } private rollEggTier(): EggTier { - const tierValueOffset = this._sourceType === EggSourceType.GACHA_LEGENDARY ? 1 : 0; + const tierValueOffset = this._sourceType === EggSourceType.GACHA_LEGENDARY ? GACHA_LEGENDARY_UP_THRESHOLD_OFFSET : 0; const tierValue = Utils.randInt(256); - return tierValue >= 52 + tierValueOffset ? EggTier.COMMON : tierValue >= 8 + tierValueOffset ? EggTier.GREAT : tierValue >= 1 + tierValueOffset ? EggTier.ULTRA : EggTier.MASTER; + return tierValue >= GACHA_DEFAULT_COMMON_EGG_THRESHOLD + tierValueOffset ? EggTier.COMMON : tierValue >= GACHA_DEFAULT_RARE_EGG_THRESHOLD + tierValueOffset ? EggTier.RARE : tierValue >= GACHA_DEFAULT_EPIC_EGG_THRESHOLD + tierValueOffset ? EggTier.EPIC : EggTier.LEGENDARY; } private rollSpecies(scene: BattleScene): Species | null { @@ -378,7 +368,7 @@ export class Egg { */ const rand = (Utils.randSeedInt(MANAPHY_EGG_MANAPHY_RATE) !== 1); return rand ? Species.PHIONE : Species.MANAPHY; - } else if (this.tier === EggTier.MASTER + } else if (this.tier === EggTier.LEGENDARY && this._sourceType === EggSourceType.GACHA_LEGENDARY) { if (!Utils.randSeedInt(2)) { return getLegendaryGachaSpeciesForTimestamp(scene, this.timestamp); @@ -389,28 +379,28 @@ export class Egg { let maxStarterValue: integer; switch (this.tier) { - case EggTier.GREAT: - minStarterValue = 4; - maxStarterValue = 5; - break; - case EggTier.ULTRA: - minStarterValue = 6; - maxStarterValue = 7; - break; - case EggTier.MASTER: - minStarterValue = 8; - maxStarterValue = 9; - break; - default: - minStarterValue = 1; - maxStarterValue = 3; - break; + case EggTier.RARE: + minStarterValue = 4; + maxStarterValue = 5; + break; + case EggTier.EPIC: + minStarterValue = 6; + maxStarterValue = 7; + break; + case EggTier.LEGENDARY: + minStarterValue = 8; + maxStarterValue = 9; + break; + default: + minStarterValue = 1; + maxStarterValue = 3; + break; } - const ignoredSpecies = [Species.PHIONE, Species.MANAPHY, Species.ETERNATUS]; + const ignoredSpecies = [ Species.PHIONE, Species.MANAPHY, Species.ETERNATUS ]; - let speciesPool = Object.keys(speciesStarters) - .filter(s => speciesStarters[s] >= minStarterValue && speciesStarters[s] <= maxStarterValue) + let speciesPool = Object.keys(speciesEggTiers) + .filter(s => speciesEggTiers[s] === this.tier) .map(s => parseInt(s) as Species) .filter(s => !pokemonPrevolutions.hasOwnProperty(s) && getPokemonSpecies(s).isObtainable() && ignoredSpecies.indexOf(s) === -1); @@ -441,7 +431,9 @@ export class Egg { let totalWeight = 0; const speciesWeights : number[] = []; for (const speciesId of speciesPool) { - let weight = Math.floor((((maxStarterValue - speciesStarters[speciesId]) / ((maxStarterValue - minStarterValue) + 1)) * 1.5 + 1) * 100); + // Accounts for species that have starter costs outside of the normal range for their EggTier + const speciesCostClamped = Phaser.Math.Clamp(speciesStarterCosts[speciesId], minStarterValue, maxStarterValue); + let weight = Math.floor((((maxStarterValue - speciesCostClamped) / ((maxStarterValue - minStarterValue) + 1)) * 1.5 + 1) * 100); const species = getPokemonSpecies(speciesId); if (species.isRegional()) { weight = Math.floor(weight / 2); @@ -475,16 +467,16 @@ export class Egg { * @returns True if the egg is shiny **/ private rollShiny(): boolean { - let shinyChance = DEFAULT_SHINY_RATE; + let shinyChance = GACHA_DEFAULT_SHINY_RATE; switch (this._sourceType) { - case EggSourceType.GACHA_SHINY: - shinyChance = GACHA_SHINY_UP_SHINY_RATE; - break; - case EggSourceType.SAME_SPECIES_EGG: - shinyChance = SAME_SPECIES_EGG_SHINY_RATE; - break; - default: - break; + case EggSourceType.GACHA_SHINY: + shinyChance = GACHA_SHINY_UP_SHINY_RATE; + break; + case EggSourceType.SAME_SPECIES_EGG: + shinyChance = SAME_SPECIES_EGG_SHINY_RATE; + break; + default: + break; } return !Utils.randSeedInt(shinyChance); @@ -494,13 +486,13 @@ export class Egg { // place but I don't want to touch the pokemon class. private rollVariant(): VariantTier { if (!this.isShiny) { - return VariantTier.COMMON; + return VariantTier.STANDARD; } const rand = Utils.randSeedInt(10); - if (rand >= 4) { - return VariantTier.COMMON; // 6/10 - } else if (rand >= 1) { + if (rand >= SHINY_VARIANT_CHANCE) { + return VariantTier.STANDARD; // 6/10 + } else if (rand >= SHINY_EPIC_CHANCE) { return VariantTier.RARE; // 3/10 } else { return VariantTier.EPIC; // 1/10 @@ -508,17 +500,17 @@ export class Egg { } private checkForPityTierOverrides(scene: BattleScene): void { - const tierValueOffset = this._sourceType === EggSourceType.GACHA_LEGENDARY ? 1 : 0; - scene.gameData.eggPity[EggTier.GREAT] += 1; - scene.gameData.eggPity[EggTier.ULTRA] += 1; - scene.gameData.eggPity[EggTier.MASTER] += 1 + tierValueOffset; + const tierValueOffset = this._sourceType === EggSourceType.GACHA_LEGENDARY ? GACHA_LEGENDARY_UP_THRESHOLD_OFFSET : 0; + scene.gameData.eggPity[EggTier.RARE] += 1; + scene.gameData.eggPity[EggTier.EPIC] += 1; + scene.gameData.eggPity[EggTier.LEGENDARY] += 1 + tierValueOffset; // These numbers are roughly the 80% mark. That is, 80% of the time you'll get an egg before this gets triggered. - if (scene.gameData.eggPity[EggTier.MASTER] >= 412 && this._tier === EggTier.COMMON) { - this._tier = EggTier.MASTER; - } else if (scene.gameData.eggPity[EggTier.ULTRA] >= 59 && this._tier === EggTier.COMMON) { - this._tier = EggTier.ULTRA; - } else if (scene.gameData.eggPity[EggTier.GREAT] >= 9 && this._tier === EggTier.COMMON) { - this._tier = EggTier.GREAT; + if (scene.gameData.eggPity[EggTier.LEGENDARY] >= EGG_PITY_LEGENDARY_THRESHOLD && this._tier === EggTier.COMMON) { + this._tier = EggTier.LEGENDARY; + } else if (scene.gameData.eggPity[EggTier.EPIC] >= EGG_PITY_EPIC_THRESHOLD && this._tier === EggTier.COMMON) { + this._tier = EggTier.EPIC; + } else if (scene.gameData.eggPity[EggTier.RARE] >= EGG_PITY_RARE_THRESHOLD && this._tier === EggTier.COMMON) { + this._tier = EggTier.RARE; } scene.gameData.eggPity[this._tier] = 0; } @@ -527,38 +519,24 @@ export class Egg { scene.gameData.gameStats.eggsPulled++; if (this.isManaphyEgg()) { scene.gameData.gameStats.manaphyEggsPulled++; - this._hatchWaves = this.getEggTierDefaultHatchWaves(EggTier.ULTRA); + this._hatchWaves = this.getEggTierDefaultHatchWaves(EggTier.EPIC); return; } switch (this.tier) { - case EggTier.GREAT: - scene.gameData.gameStats.rareEggsPulled++; - break; - case EggTier.ULTRA: - scene.gameData.gameStats.epicEggsPulled++; - break; - case EggTier.MASTER: - scene.gameData.gameStats.legendaryEggsPulled++; - break; + case EggTier.RARE: + scene.gameData.gameStats.rareEggsPulled++; + break; + case EggTier.EPIC: + scene.gameData.gameStats.epicEggsPulled++; + break; + case EggTier.LEGENDARY: + scene.gameData.gameStats.legendaryEggsPulled++; + break; } } - private getEggTierFromSpeciesStarterValue(): EggTier { - const speciesStartValue = speciesStarters[this.species]; - if (speciesStartValue >= 1 && speciesStartValue <= 3) { - return EggTier.COMMON; - } - if (speciesStartValue >= 4 && speciesStartValue <= 5) { - return EggTier.GREAT; - } - if (speciesStartValue >= 6 && speciesStartValue <= 7) { - return EggTier.ULTRA; - } - if (speciesStartValue >= 8) { - return EggTier.MASTER; - } - - return EggTier.COMMON; + private getEggTier(): EggTier { + return speciesEggTiers[this.species]; } //// @@ -566,11 +544,15 @@ export class Egg { //// } -export function getLegendaryGachaSpeciesForTimestamp(scene: BattleScene, timestamp: number): Species { - const legendarySpecies = Object.entries(speciesStarters) - .filter(s => s[1] >= 8 && s[1] <= 9) +export function getValidLegendaryGachaSpecies() : Species[] { + return Object.entries(speciesEggTiers) + .filter(s => s[1] === EggTier.LEGENDARY) .map(s => parseInt(s[0])) - .filter(s => getPokemonSpecies(s).isObtainable()); + .filter(s => getPokemonSpecies(s).isObtainable() && s !== Species.ETERNATUS); +} + +export function getLegendaryGachaSpeciesForTimestamp(scene: BattleScene, timestamp: number): Species { + const legendarySpecies = getValidLegendaryGachaSpecies(); let ret: Species; @@ -590,17 +572,9 @@ export function getLegendaryGachaSpeciesForTimestamp(scene: BattleScene, timesta /** * Check for a given species EggTier Value - * @param species - Species for wich we will check the egg tier it belongs to + * @param pokemonSpecies - Species for wich we will check the egg tier it belongs to * @returns The egg tier of a given pokemon species */ export function getEggTierForSpecies(pokemonSpecies :PokemonSpecies): EggTier { - const speciesBaseValue = speciesStarters[pokemonSpecies.getRootSpeciesId()]; - if (speciesBaseValue <= 3) { - return EggTier.COMMON; - } else if (speciesBaseValue <= 5) { - return EggTier.GREAT; - } else if (speciesBaseValue <= 7) { - return EggTier.ULTRA; - } - return EggTier.MASTER; + return speciesEggTiers[pokemonSpecies.getRootSpeciesId()]; } diff --git a/src/data/exp.ts b/src/data/exp.ts index 3b332eb7cf2..c03abddadfc 100644 --- a/src/data/exp.ts +++ b/src/data/exp.ts @@ -28,24 +28,24 @@ export function getLevelTotalExp(level: integer, growthRate: GrowthRate): intege let ret: integer; switch (growthRate) { - case GrowthRate.ERRATIC: - ret = (Math.pow(level, 4) + (Math.pow(level, 3) * 2000)) / 3500; - break; - case GrowthRate.FAST: - ret = Math.pow(level, 3) * 4 / 5; - break; - case GrowthRate.MEDIUM_FAST: - ret = Math.pow(level, 3); - break; - case GrowthRate.MEDIUM_SLOW: - ret = (Math.pow(level, 3) * 6 / 5) - (15 * Math.pow(level, 2)) + (100 * level) - 140; - break; - case GrowthRate.SLOW: - ret = Math.pow(level, 3) * 5 / 4; - break; - case GrowthRate.FLUCTUATING: - ret = (Math.pow(level, 3) * ((level / 2) + 8)) * 4 / (100 + level); - break; + case GrowthRate.ERRATIC: + ret = (Math.pow(level, 4) + (Math.pow(level, 3) * 2000)) / 3500; + break; + case GrowthRate.FAST: + ret = Math.pow(level, 3) * 4 / 5; + break; + case GrowthRate.MEDIUM_FAST: + ret = Math.pow(level, 3); + break; + case GrowthRate.MEDIUM_SLOW: + ret = (Math.pow(level, 3) * 6 / 5) - (15 * Math.pow(level, 2)) + (100 * level) - 140; + break; + case GrowthRate.SLOW: + ret = Math.pow(level, 3) * 5 / 4; + break; + case GrowthRate.FLUCTUATING: + ret = (Math.pow(level, 3) * ((level / 2) + 8)) * 4 / (100 + level); + break; } if (growthRate !== GrowthRate.MEDIUM_FAST) { @@ -61,17 +61,17 @@ export function getLevelRelExp(level: integer, growthRate: GrowthRate): number { export function getGrowthRateColor(growthRate: GrowthRate, shadow?: boolean) { switch (growthRate) { - case GrowthRate.ERRATIC: - return !shadow ? "#f85888" : "#906060"; - case GrowthRate.FAST: - return !shadow ? "#f8d030" : "#b8a038"; - case GrowthRate.MEDIUM_FAST: - return !shadow ? "#78c850" : "#588040"; - case GrowthRate.MEDIUM_SLOW: - return !shadow ? "#6890f0" : "#807870"; - case GrowthRate.SLOW: - return !shadow ? "#f08030" : "#c03028"; - case GrowthRate.FLUCTUATING: - return !shadow ? "#a040a0" : "#483850"; + case GrowthRate.ERRATIC: + return !shadow ? "#f85888" : "#906060"; + case GrowthRate.FAST: + return !shadow ? "#f8d030" : "#b8a038"; + case GrowthRate.MEDIUM_FAST: + return !shadow ? "#78c850" : "#588040"; + case GrowthRate.MEDIUM_SLOW: + return !shadow ? "#6890f0" : "#807870"; + case GrowthRate.SLOW: + return !shadow ? "#f08030" : "#c03028"; + case GrowthRate.FLUCTUATING: + return !shadow ? "#a040a0" : "#483850"; } } diff --git a/src/data/gender.ts b/src/data/gender.ts index 0d4b76d8bd1..dae7723dd85 100644 --- a/src/data/gender.ts +++ b/src/data/gender.ts @@ -6,20 +6,20 @@ export enum Gender { export function getGenderSymbol(gender: Gender) { switch (gender) { - case Gender.MALE: - return "♂"; - case Gender.FEMALE: - return "♀"; + case Gender.MALE: + return "♂"; + case Gender.FEMALE: + return "♀"; } return ""; } export function getGenderColor(gender: Gender, shadow?: boolean) { switch (gender) { - case Gender.MALE: - return shadow ? "#006090" : "#40c8f8"; - case Gender.FEMALE: - return shadow ? "#984038" : "#f89890"; + case Gender.MALE: + return shadow ? "#006090" : "#40c8f8"; + case Gender.FEMALE: + return shadow ? "#984038" : "#f89890"; } return "#ffffff"; } diff --git a/src/data/move.ts b/src/data/move.ts index 1bfe20abc48..2ac4d74b712 100644 --- a/src/data/move.ts +++ b/src/data/move.ts @@ -1,16 +1,16 @@ -import { ChargeAnim, MoveChargeAnim, initMoveAnim, loadMoveAnimAssets } from "./battle-anims"; -import { EncoreTag, GulpMissileTag, HelpingHandTag, SemiInvulnerableTag, ShellTrapTag, StockpilingTag, TrappedTag, SubstituteTag, TypeBoostTag } from "./battler-tags"; +import { ChargeAnim, initMoveAnim, loadMoveAnimAssets, MoveChargeAnim } from "./battle-anims"; +import { CommandedTag, EncoreTag, GulpMissileTag, HelpingHandTag, SemiInvulnerableTag, ShellTrapTag, StockpilingTag, SubstituteTag, TrappedTag, TypeBoostTag } from "./battler-tags"; import { getPokemonNameWithAffix } from "../messages"; import Pokemon, { AttackMoveResult, EnemyPokemon, HitResult, MoveResult, PlayerPokemon, PokemonMove, TurnMove } from "../field/pokemon"; -import { StatusEffect, getStatusEffectHealText, isNonVolatileStatusEffect, getNonVolatileStatusEffects } from "./status-effect"; -import { getTypeDamageMultiplier, Type } from "./type"; -import { Constructor } from "#app/utils"; +import { getNonVolatileStatusEffects, getStatusEffectHealText, isNonVolatileStatusEffect } from "./status-effect"; +import { getTypeDamageMultiplier } from "./type"; +import { Type } from "#enums/type"; +import { Constructor, NumberHolder } from "#app/utils"; import * as Utils from "../utils"; -import { WeatherType } from "./weather"; +import { WeatherType } from "#enums/weather-type"; import { ArenaTagSide, ArenaTrapTag, WeakenMoveTypeTag } from "./arena-tag"; -import { UnswappableAbilityAbAttr, UncopiableAbilityAbAttr, UnsuppressableAbilityAbAttr, BlockRecoilDamageAttr, BlockOneHitKOAbAttr, IgnoreContactAbAttr, MaxMultiHitAbAttr, applyAbAttrs, BlockNonDirectDamageAbAttr, MoveAbilityBypassAbAttr, ReverseDrainAbAttr, FieldPreventExplosiveMovesAbAttr, ForceSwitchOutImmunityAbAttr, BlockItemTheftAbAttr, applyPostAttackAbAttrs, ConfusionOnStatusEffectAbAttr, HealFromBerryUseAbAttr, IgnoreProtectOnContactAbAttr, IgnoreMoveEffectsAbAttr, applyPreDefendAbAttrs, MoveEffectChanceMultiplierAbAttr, WonderSkinAbAttr, applyPreAttackAbAttrs, MoveTypeChangeAbAttr, UserFieldMoveTypePowerBoostAbAttr, FieldMoveTypePowerBoostAbAttr, AllyMoveCategoryPowerBoostAbAttr, VariableMovePowerAbAttr } from "./ability"; -import { allAbilities } from "./ability"; -import { PokemonHeldItemModifier, BerryModifier, PreserveBerryModifier, PokemonMoveAccuracyBoosterModifier, AttackTypeBoosterModifier, PokemonMultiHitModifier } from "../modifier/modifier"; +import { allAbilities, AllyMoveCategoryPowerBoostAbAttr, applyAbAttrs, applyPostAttackAbAttrs, applyPostItemLostAbAttrs, applyPreAttackAbAttrs, applyPreDefendAbAttrs, BlockItemTheftAbAttr, BlockNonDirectDamageAbAttr, BlockOneHitKOAbAttr, BlockRecoilDamageAttr, ChangeMovePriorityAbAttr, ConfusionOnStatusEffectAbAttr, FieldMoveTypePowerBoostAbAttr, FieldPreventExplosiveMovesAbAttr, ForceSwitchOutImmunityAbAttr, HealFromBerryUseAbAttr, IgnoreContactAbAttr, IgnoreMoveEffectsAbAttr, IgnoreProtectOnContactAbAttr, InfiltratorAbAttr, MaxMultiHitAbAttr, MoveAbilityBypassAbAttr, MoveEffectChanceMultiplierAbAttr, MoveTypeChangeAbAttr, PostDamageForceSwitchAbAttr, PostItemLostAbAttr, ReverseDrainAbAttr, UncopiableAbilityAbAttr, UnsuppressableAbilityAbAttr, UnswappableAbilityAbAttr, UserFieldMoveTypePowerBoostAbAttr, VariableMovePowerAbAttr, WonderSkinAbAttr } from "./ability"; +import { AttackTypeBoosterModifier, BerryModifier, PokemonHeldItemModifier, PokemonMoveAccuracyBoosterModifier, PokemonMultiHitModifier, PreserveBerryModifier } from "../modifier/modifier"; import { BattlerIndex, BattleType } from "../battle"; import { TerrainType } from "./terrain"; import { ModifierPoolType } from "#app/modifier/modifier-type"; @@ -25,8 +25,7 @@ import { Biome } from "#enums/biome"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; import { MoveUsedEvent } from "#app/events/battle-scene"; -import { Stat, type BattleStat, type EffectiveStat, BATTLE_STATS, EFFECTIVE_STATS, getStatKey } from "#app/enums/stat"; -import { PartyStatusCurePhase } from "#app/phases/party-status-cure-phase"; +import { BATTLE_STATS, type BattleStat, EFFECTIVE_STATS, type EffectiveStat, getStatKey, Stat } from "#app/enums/stat"; import { BattleEndPhase } from "#app/phases/battle-end-phase"; import { MoveEndPhase } from "#app/phases/move-end-phase"; import { MovePhase } from "#app/phases/move-phase"; @@ -35,10 +34,12 @@ import { PokemonHealPhase } from "#app/phases/pokemon-heal-phase"; import { StatStageChangePhase } from "#app/phases/stat-stage-change-phase"; import { SwitchPhase } from "#app/phases/switch-phase"; import { SwitchSummonPhase } from "#app/phases/switch-summon-phase"; +import { ShowAbilityPhase } from "#app/phases/show-ability-phase"; import { SpeciesFormChangeRevertWeatherFormTrigger } from "./pokemon-forms"; -import { NumberHolder } from "#app/utils"; import { GameMode } from "#app/game-mode"; import { applyChallenges, ChallengeType } from "./challenge"; +import { SwitchType } from "#enums/switch-type"; +import { StatusEffect } from "enums/status-effect"; export enum MoveCategory { PHYSICAL, @@ -275,38 +276,41 @@ export default class Move implements Localizable { */ isMultiTarget(): boolean { switch (this.moveTarget) { - case MoveTarget.ALL_OTHERS: - case MoveTarget.ALL_NEAR_OTHERS: - case MoveTarget.ALL_NEAR_ENEMIES: - case MoveTarget.ALL_ENEMIES: - case MoveTarget.USER_AND_ALLIES: - case MoveTarget.ALL: - case MoveTarget.USER_SIDE: - case MoveTarget.ENEMY_SIDE: - case MoveTarget.BOTH_SIDES: - return true; + case MoveTarget.ALL_OTHERS: + case MoveTarget.ALL_NEAR_OTHERS: + case MoveTarget.ALL_NEAR_ENEMIES: + case MoveTarget.ALL_ENEMIES: + case MoveTarget.USER_AND_ALLIES: + case MoveTarget.ALL: + case MoveTarget.USER_SIDE: + case MoveTarget.ENEMY_SIDE: + case MoveTarget.BOTH_SIDES: + return true; } return false; } /** - * Getter function that returns if the move targets itself or an ally + * Getter function that returns if the move targets the user or its ally * @returns boolean */ - isAllyTarget(): boolean { switch (this.moveTarget) { - case MoveTarget.USER: - case MoveTarget.NEAR_ALLY: - case MoveTarget.ALLY: - case MoveTarget.USER_OR_NEAR_ALLY: - case MoveTarget.USER_AND_ALLIES: - case MoveTarget.USER_SIDE: - return true; + case MoveTarget.USER: + case MoveTarget.NEAR_ALLY: + case MoveTarget.ALLY: + case MoveTarget.USER_OR_NEAR_ALLY: + case MoveTarget.USER_AND_ALLIES: + case MoveTarget.USER_SIDE: + return true; } return false; } + isChargingMove(): this is ChargingMove { + return false; + } + /** * Checks if the move is immune to certain types. * Currently looks at cases of Grass types with powder moves and Dark types with moves affected by Prankster. @@ -321,16 +325,16 @@ export default class Move implements Localizable { } switch (type) { - case Type.GRASS: - if (this.hasFlag(MoveFlags.POWDER_MOVE)) { - return true; - } - break; - case Type.DARK: - if (user.hasAbility(Abilities.PRANKSTER) && this.category === MoveCategory.STATUS && (user.isPlayer() !== target.isPlayer())) { - return true; - } - break; + case Type.GRASS: + if (this.hasFlag(MoveFlags.POWDER_MOVE)) { + return true; + } + break; + case Type.DARK: + if (user.hasAbility(Abilities.PRANKSTER) && this.category === MoveCategory.STATUS && (user.isPlayer() !== target.isPlayer())) { + return true; + } + break; } return false; } @@ -342,11 +346,16 @@ export default class Move implements Localizable { * @returns `true` if the move can bypass the target's Substitute; `false` otherwise. */ hitsSubstitute(user: Pokemon, target: Pokemon | null): boolean { - if (this.moveTarget === MoveTarget.USER || !target?.getTag(BattlerTagType.SUBSTITUTE)) { + if ([ MoveTarget.USER, MoveTarget.USER_SIDE, MoveTarget.ENEMY_SIDE, MoveTarget.BOTH_SIDES ].includes(this.moveTarget) + || !target?.getTag(BattlerTagType.SUBSTITUTE)) { return false; } - return !user.hasAbility(Abilities.INFILTRATOR) + const bypassed = new Utils.BooleanHolder(false); + // TODO: Allow this to be simulated + applyAbAttrs(InfiltratorAbAttr, user, null, false, bypassed); + + return !bypassed.value && !this.hasFlag(MoveFlags.SOUND_BASED) && !this.hasFlag(MoveFlags.IGNORE_SUBSTITUTE); } @@ -365,6 +374,14 @@ export default class Move implements Localizable { return this; } + /** + * Internal dev flag for documenting edge cases. When using this, please document the known edge case. + * @returns the called object {@linkcode Move} + */ + edgeCase(): this { + return this; + } + /** * Marks the move as "partial": appends texts to the move name * @returns the called object {@linkcode Move} @@ -399,220 +416,202 @@ export default class Move implements Localizable { /** * Sets the {@linkcode MoveFlags.MAKES_CONTACT} flag for the calling Move - * @param makesContact The value (boolean) to set the flag to + * @param setFlag Default `true`, set to `false` if the move doesn't make contact + * @see {@linkcode Abilities.STATIC} * @returns The {@linkcode Move} that called this function */ - makesContact(makesContact: boolean = true): this { - this.setFlag(MoveFlags.MAKES_CONTACT, makesContact); + makesContact(setFlag: boolean = true): this { + this.setFlag(MoveFlags.MAKES_CONTACT, setFlag); return this; } /** * Sets the {@linkcode MoveFlags.IGNORE_PROTECT} flag for the calling Move - * @param ignoresProtect The value (boolean) to set the flag to - * example: @see {@linkcode Moves.CURSE} + * @see {@linkcode Moves.CURSE} * @returns The {@linkcode Move} that called this function */ - ignoresProtect(ignoresProtect: boolean = true): this { - this.setFlag(MoveFlags.IGNORE_PROTECT, ignoresProtect); + ignoresProtect(): this { + this.setFlag(MoveFlags.IGNORE_PROTECT, true); return this; } /** * Sets the {@linkcode MoveFlags.IGNORE_VIRTUAL} flag for the calling Move - * @param ignoresVirtual The value (boolean) to set the flag to - * example: @see {@linkcode Moves.NATURE_POWER} + * @see {@linkcode Moves.NATURE_POWER} * @returns The {@linkcode Move} that called this function */ - ignoresVirtual(ignoresVirtual: boolean = true): this { - this.setFlag(MoveFlags.IGNORE_VIRTUAL, ignoresVirtual); + ignoresVirtual(): this { + this.setFlag(MoveFlags.IGNORE_VIRTUAL, true); return this; } /** * Sets the {@linkcode MoveFlags.SOUND_BASED} flag for the calling Move - * @param soundBased The value (boolean) to set the flag to - * example: @see {@linkcode Moves.UPROAR} + * @see {@linkcode Moves.UPROAR} * @returns The {@linkcode Move} that called this function */ - soundBased(soundBased: boolean = true): this { - this.setFlag(MoveFlags.SOUND_BASED, soundBased); + soundBased(): this { + this.setFlag(MoveFlags.SOUND_BASED, true); return this; } /** * Sets the {@linkcode MoveFlags.HIDE_USER} flag for the calling Move - * @param hidesUser The value (boolean) to set the flag to - * example: @see {@linkcode Moves.TELEPORT} + * @see {@linkcode Moves.TELEPORT} * @returns The {@linkcode Move} that called this function */ - hidesUser(hidesUser: boolean = true): this { - this.setFlag(MoveFlags.HIDE_USER, hidesUser); + hidesUser(): this { + this.setFlag(MoveFlags.HIDE_USER, true); return this; } /** * Sets the {@linkcode MoveFlags.HIDE_TARGET} flag for the calling Move - * @param hidesTarget The value (boolean) to set the flag to - * example: @see {@linkcode Moves.WHIRLWIND} + * @see {@linkcode Moves.WHIRLWIND} * @returns The {@linkcode Move} that called this function */ - hidesTarget(hidesTarget: boolean = true): this { - this.setFlag(MoveFlags.HIDE_TARGET, hidesTarget); + hidesTarget(): this { + this.setFlag(MoveFlags.HIDE_TARGET, true); return this; } /** * Sets the {@linkcode MoveFlags.BITING_MOVE} flag for the calling Move - * @param bitingMove The value (boolean) to set the flag to - * example: @see {@linkcode Moves.BITE} + * @see {@linkcode Moves.BITE} * @returns The {@linkcode Move} that called this function */ - bitingMove(bitingMove: boolean = true): this { - this.setFlag(MoveFlags.BITING_MOVE, bitingMove); + bitingMove(): this { + this.setFlag(MoveFlags.BITING_MOVE, true); return this; } /** * Sets the {@linkcode MoveFlags.PULSE_MOVE} flag for the calling Move - * @param pulseMove The value (boolean) to set the flag to - * example: @see {@linkcode Moves.WATER_PULSE} + * @see {@linkcode Moves.WATER_PULSE} * @returns The {@linkcode Move} that called this function */ - pulseMove(pulseMove: boolean = true): this { - this.setFlag(MoveFlags.PULSE_MOVE, pulseMove); + pulseMove(): this { + this.setFlag(MoveFlags.PULSE_MOVE, true); return this; } /** * Sets the {@linkcode MoveFlags.PUNCHING_MOVE} flag for the calling Move - * @param punchingMove The value (boolean) to set the flag to - * example: @see {@linkcode Moves.DRAIN_PUNCH} + * @see {@linkcode Moves.DRAIN_PUNCH} * @returns The {@linkcode Move} that called this function */ - punchingMove(punchingMove: boolean = true): this { - this.setFlag(MoveFlags.PUNCHING_MOVE, punchingMove); + punchingMove(): this { + this.setFlag(MoveFlags.PUNCHING_MOVE, true); return this; } /** * Sets the {@linkcode MoveFlags.SLICING_MOVE} flag for the calling Move - * @param slicingMove The value (boolean) to set the flag to - * example: @see {@linkcode Moves.X_SCISSOR} + * @see {@linkcode Moves.X_SCISSOR} * @returns The {@linkcode Move} that called this function */ - slicingMove(slicingMove: boolean = true): this { - this.setFlag(MoveFlags.SLICING_MOVE, slicingMove); + slicingMove(): this { + this.setFlag(MoveFlags.SLICING_MOVE, true); return this; } /** * Sets the {@linkcode MoveFlags.RECKLESS_MOVE} flag for the calling Move * @see {@linkcode Abilities.RECKLESS} - * @param recklessMove The value to set the flag to * @returns The {@linkcode Move} that called this function */ - recklessMove(recklessMove: boolean = true): this { - this.setFlag(MoveFlags.RECKLESS_MOVE, recklessMove); + recklessMove(): this { + this.setFlag(MoveFlags.RECKLESS_MOVE, true); return this; } /** * Sets the {@linkcode MoveFlags.BALLBOMB_MOVE} flag for the calling Move - * @param ballBombMove The value (boolean) to set the flag to - * example: @see {@linkcode Moves.ELECTRO_BALL} + * @see {@linkcode Moves.ELECTRO_BALL} * @returns The {@linkcode Move} that called this function */ - ballBombMove(ballBombMove: boolean = true): this { - this.setFlag(MoveFlags.BALLBOMB_MOVE, ballBombMove); + ballBombMove(): this { + this.setFlag(MoveFlags.BALLBOMB_MOVE, true); return this; } /** * Sets the {@linkcode MoveFlags.POWDER_MOVE} flag for the calling Move - * @param powderMove The value (boolean) to set the flag to - * example: @see {@linkcode Moves.STUN_SPORE} + * @see {@linkcode Moves.STUN_SPORE} * @returns The {@linkcode Move} that called this function */ - powderMove(powderMove: boolean = true): this { - this.setFlag(MoveFlags.POWDER_MOVE, powderMove); + powderMove(): this { + this.setFlag(MoveFlags.POWDER_MOVE, true); return this; } /** * Sets the {@linkcode MoveFlags.DANCE_MOVE} flag for the calling Move - * @param danceMove The value (boolean) to set the flag to - * example: @see {@linkcode Moves.PETAL_DANCE} + * @see {@linkcode Moves.PETAL_DANCE} * @returns The {@linkcode Move} that called this function */ - danceMove(danceMove: boolean = true): this { - this.setFlag(MoveFlags.DANCE_MOVE, danceMove); + danceMove(): this { + this.setFlag(MoveFlags.DANCE_MOVE, true); return this; } /** * Sets the {@linkcode MoveFlags.WIND_MOVE} flag for the calling Move - * @param windMove The value (boolean) to set the flag to - * example: @see {@linkcode Moves.HURRICANE} + * @see {@linkcode Moves.HURRICANE} * @returns The {@linkcode Move} that called this function */ - windMove(windMove: boolean = true): this { - this.setFlag(MoveFlags.WIND_MOVE, windMove); + windMove(): this { + this.setFlag(MoveFlags.WIND_MOVE, true); return this; } /** * Sets the {@linkcode MoveFlags.TRIAGE_MOVE} flag for the calling Move - * @param triageMove The value (boolean) to set the flag to - * example: @see {@linkcode Moves.ABSORB} + * @see {@linkcode Moves.ABSORB} * @returns The {@linkcode Move} that called this function */ - triageMove(triageMove: boolean = true): this { - this.setFlag(MoveFlags.TRIAGE_MOVE, triageMove); + triageMove(): this { + this.setFlag(MoveFlags.TRIAGE_MOVE, true); return this; } /** * Sets the {@linkcode MoveFlags.IGNORE_ABILITIES} flag for the calling Move - * @param ignoresAbilities sThe value (boolean) to set the flag to - * example: @see {@linkcode Moves.SUNSTEEL_STRIKE} + * @see {@linkcode Moves.SUNSTEEL_STRIKE} * @returns The {@linkcode Move} that called this function */ - ignoresAbilities(ignoresAbilities: boolean = true): this { - this.setFlag(MoveFlags.IGNORE_ABILITIES, ignoresAbilities); + ignoresAbilities(): this { + this.setFlag(MoveFlags.IGNORE_ABILITIES, true); return this; } /** * Sets the {@linkcode MoveFlags.CHECK_ALL_HITS} flag for the calling Move - * @param checkAllHits The value (boolean) to set the flag to - * example: @see {@linkcode Moves.TRIPLE_AXEL} + * @see {@linkcode Moves.TRIPLE_AXEL} * @returns The {@linkcode Move} that called this function */ - checkAllHits(checkAllHits: boolean = true): this { - this.setFlag(MoveFlags.CHECK_ALL_HITS, checkAllHits); + checkAllHits(): this { + this.setFlag(MoveFlags.CHECK_ALL_HITS, true); return this; } /** * Sets the {@linkcode MoveFlags.IGNORE_SUBSTITUTE} flag for the calling Move - * @param ignoresSubstitute The value (boolean) to set the flag to - * example: @see {@linkcode Moves.WHIRLWIND} + * @see {@linkcode Moves.WHIRLWIND} * @returns The {@linkcode Move} that called this function */ - ignoresSubstitute(ignoresSubstitute: boolean = true): this { - this.setFlag(MoveFlags.IGNORE_SUBSTITUTE, ignoresSubstitute); + ignoresSubstitute(): this { + this.setFlag(MoveFlags.IGNORE_SUBSTITUTE, true); return this; } /** * Sets the {@linkcode MoveFlags.REDIRECT_COUNTER} flag for the calling Move - * @param redirectCounter The value (boolean) to set the flag to - * example: @see {@linkcode Moves.METAL_BURST} + * @see {@linkcode Moves.METAL_BURST} * @returns The {@linkcode Move} that called this function */ - redirectCounter(redirectCounter: boolean = true): this { - this.setFlag(MoveFlags.REDIRECT_COUNTER, redirectCounter); + redirectCounter(): this { + this.setFlag(MoveFlags.REDIRECT_COUNTER, true); return this; } @@ -626,33 +625,33 @@ export default class Move implements Localizable { checkFlag(flag: MoveFlags, user: Pokemon, target: Pokemon | null): boolean { // special cases below, eg: if the move flag is MAKES_CONTACT, and the user pokemon has an ability that ignores contact (like "Long Reach"), then overrides and move does not make contact switch (flag) { - case MoveFlags.MAKES_CONTACT: - if (user.hasAbilityWithAttr(IgnoreContactAbAttr) || this.hitsSubstitute(user, target)) { - return false; - } - break; - case MoveFlags.IGNORE_ABILITIES: - if (user.hasAbilityWithAttr(MoveAbilityBypassAbAttr)) { - const abilityEffectsIgnored = new Utils.BooleanHolder(false); - applyAbAttrs(MoveAbilityBypassAbAttr, user, abilityEffectsIgnored, false, this); - if (abilityEffectsIgnored.value) { + case MoveFlags.MAKES_CONTACT: + if (user.hasAbilityWithAttr(IgnoreContactAbAttr) || this.hitsSubstitute(user, target)) { + return false; + } + break; + case MoveFlags.IGNORE_ABILITIES: + if (user.hasAbilityWithAttr(MoveAbilityBypassAbAttr)) { + const abilityEffectsIgnored = new Utils.BooleanHolder(false); + applyAbAttrs(MoveAbilityBypassAbAttr, user, abilityEffectsIgnored, false, this); + if (abilityEffectsIgnored.value) { + return true; + } + } + break; + case MoveFlags.IGNORE_PROTECT: + if (user.hasAbilityWithAttr(IgnoreProtectOnContactAbAttr) + && this.checkFlag(MoveFlags.MAKES_CONTACT, user, null)) { return true; } - } - break; - case MoveFlags.IGNORE_PROTECT: - if (user.hasAbilityWithAttr(IgnoreProtectOnContactAbAttr) - && this.checkFlag(MoveFlags.MAKES_CONTACT, user, null)) { - return true; - } - break; + break; } return !!(this.flags & flag); } /** - * Applies each {@linkcode MoveCondition} of this move to the params + * Applies each {@linkcode MoveCondition} function of this move to the params, determines if the move can be used prior to calling each attribute's apply() * @param user {@linkcode Pokemon} to apply conditions to * @param target {@linkcode Pokemon} to apply conditions to * @param move {@linkcode Move} to apply conditions to @@ -669,12 +668,12 @@ export default class Move implements Localizable { } /** - * Sees if, given the target pokemon, a move fails on it (by looking at each {@linkcode MoveAttr} of this move + * Sees if a move has a custom failure text (by looking at each {@linkcode MoveAttr} of this move) * @param user {@linkcode Pokemon} using the move * @param target {@linkcode Pokemon} receiving the move * @param move {@linkcode Move} using the move * @param cancelled {@linkcode Utils.BooleanHolder} to hold boolean value - * @returns string of the failed text, or null + * @returns string of the custom failure text, or `null` if it uses the default text ("But it failed!") */ getFailedText(user: Pokemon, target: Pokemon, move: Move, cancelled: Utils.BooleanHolder): string | null { for (const attr of this.attrs) { @@ -717,6 +716,10 @@ export default class Move implements Localizable { getTargetBenefitScore(user: Pokemon, target: Pokemon, move: Move): integer { let score = 0; + if (target.getAlly()?.getTag(BattlerTagType.COMMANDED)?.getSourcePokemon(target.scene) === target) { + return 20 * (target.isPlayer() === user.isPlayer() ? -1 : 1); // always -20 with how the AI handles this score + } + for (const attr of this.attrs) { // conditionals to check if the move is self targeting (if so then you are applying the move to yourself, not the target) score += attr.getTargetBenefitScore(user, !attr.selfTarget ? target : user, move) * (target !== user && attr.selfTarget ? -1 : 1); @@ -800,7 +803,7 @@ export default class Move implements Localizable { .flat(), ); for (const aura of fieldAuras) { - aura.applyPreAttack(source, null, simulated, target, this, [power]); + aura.applyPreAttack(source, null, simulated, target, this, [ power ]); } const alliedField: Pokemon[] = source instanceof PlayerPokemon ? source.scene.getPlayerField() : source.scene.getEnemyField(); @@ -815,10 +818,8 @@ export default class Move implements Localizable { applyMoveAttrs(VariablePowerAttr, source, target, this, power); - source.scene.applyModifiers(PokemonMultiHitModifier, source.isPlayer(), source, new Utils.IntegerHolder(0), power); - if (!this.hasAttr(TypelessAttr)) { - source.scene.arena.applyTags(WeakenMoveTypeTag, this.type, power); + source.scene.arena.applyTags(WeakenMoveTypeTag, simulated, this.type, power); source.scene.applyModifiers(AttackTypeBoosterModifier, source.isPlayer(), source, this.type, power); } @@ -828,6 +829,54 @@ export default class Move implements Localizable { return power.value; } + + getPriority(user: Pokemon, simulated: boolean = true) { + const priority = new Utils.NumberHolder(this.priority); + + applyMoveAttrs(IncrementMovePriorityAttr, user, null, this, priority); + applyAbAttrs(ChangeMovePriorityAbAttr, user, null, simulated, this, priority); + + return priority.value; + } + + /** + * Returns `true` if this move can be given additional strikes + * by enhancing effects. + * Currently used for {@link https://bulbapedia.bulbagarden.net/wiki/Parental_Bond_(Ability) | Parental Bond} + * and {@linkcode PokemonMultiHitModifier | Multi-Lens}. + * @param user The {@linkcode Pokemon} using the move + * @param restrictSpread `true` if the enhancing effect + * should not affect multi-target moves (default `false`) + */ + canBeMultiStrikeEnhanced(user: Pokemon, restrictSpread: boolean = false): boolean { + // Multi-strike enhancers... + + // ...cannot enhance moves that hit multiple targets + const { targets, multiple } = getMoveTargets(user, this.id); + const isMultiTarget = multiple && targets.length > 1; + + // ...cannot enhance multi-hit or sacrificial moves + const exceptAttrs: Constructor[] = [ + MultiHitAttr, + SacrificialAttr, + SacrificialAttrOnHit + ]; + + // ...and cannot enhance these specific moves. + const exceptMoves: Moves[] = [ + Moves.FLING, + Moves.UPROAR, + Moves.ROLLOUT, + Moves.ICE_BALL, + Moves.ENDEAVOR + ]; + + return (!restrictSpread || !isMultiTarget) + && !this.isChargingMove() + && !exceptAttrs.some(attr => this.hasAttr(attr)) + && !exceptMoves.some(id => this.id === id) + && this.category !== MoveCategory.STATUS; + } } export class AttackMove extends Move { @@ -848,7 +897,7 @@ export class AttackMove extends Move { let attackScore = 0; - const effectiveness = target.getAttackTypeEffectiveness(this.type, user); + const effectiveness = target.getAttackTypeEffectiveness(this.type, user, undefined, undefined, this); attackScore = Math.pow(effectiveness - 1, 2) * effectiveness < 1 ? -2 : 2; if (attackScore) { if (this.category === MoveCategory.PHYSICAL) { @@ -899,6 +948,85 @@ export class SelfStatusMove extends Move { } } +type SubMove = new (...args: any[]) => Move; + +function ChargeMove(Base: TBase) { + return class extends Base { + /** The animation to play during the move's charging phase */ + public readonly chargeAnim: ChargeAnim = ChargeAnim[`${Moves[this.id]}_CHARGING`]; + /** The message to show during the move's charging phase */ + private _chargeText: string; + + /** Move attributes that apply during the move's charging phase */ + public chargeAttrs: MoveAttr[] = []; + + override isChargingMove(): this is ChargingMove { + return true; + } + + /** + * Sets the text to be displayed during this move's charging phase. + * References to the user Pokemon should be written as "{USER}", and + * references to the target Pokemon should be written as "{TARGET}". + * @param chargeText the text to set + * @returns this {@linkcode Move} (for chaining API purposes) + */ + chargeText(chargeText: string): this { + this._chargeText = chargeText; + return this; + } + + /** + * Queues the charge text to display to the player + * @param user the {@linkcode Pokemon} using this move + * @param target the {@linkcode Pokemon} targeted by this move (optional) + */ + showChargeText(user: Pokemon, target?: Pokemon): void { + user.scene.queueMessage(this._chargeText + .replace("{USER}", getPokemonNameWithAffix(user)) + .replace("{TARGET}", getPokemonNameWithAffix(target)) + ); + } + + /** + * Gets all charge attributes of the given attribute type. + * @param attrType any attribute that extends {@linkcode MoveAttr} + * @returns Array of attributes that match `attrType`, or an empty array if + * no matches are found. + */ + getChargeAttrs(attrType: Constructor): T[] { + return this.chargeAttrs.filter((attr): attr is T => attr instanceof attrType); + } + + /** + * Checks if this move has an attribute of the given type. + * @param attrType any attribute that extends {@linkcode MoveAttr} + * @returns `true` if a matching attribute is found; `false` otherwise + */ + hasChargeAttr(attrType: Constructor): boolean { + return this.chargeAttrs.some((attr) => attr instanceof attrType); + } + + /** + * Adds an attribute to this move to be applied during the move's charging phase + * @param ChargeAttrType the type of {@linkcode MoveAttr} being added + * @param args the parameters to construct the given {@linkcode MoveAttr} with + * @returns this {@linkcode Move} (for chaining API purposes) + */ + chargeAttr>(ChargeAttrType: T, ...args: ConstructorParameters): this { + const chargeAttr = new ChargeAttrType(...args); + this.chargeAttrs.push(chargeAttr); + + return this; + } + }; +} + +export class ChargingAttackMove extends ChargeMove(AttackMove) {} +export class ChargingSelfStatusMove extends ChargeMove(SelfStatusMove) {} + +export type ChargingMove = ChargingAttackMove | ChargingSelfStatusMove; + /** * Base class defining all {@linkcode Move} Attributes * @abstract @@ -973,28 +1101,80 @@ export enum MoveEffectTrigger { POST_TARGET, } +interface MoveEffectAttrOptions { + /** + * Defines when this effect should trigger in the move's effect order + * @see {@linkcode MoveEffectPhase} + */ + trigger?: MoveEffectTrigger; + /** Should this effect only apply on the first hit? */ + firstHitOnly?: boolean; + /** Should this effect only apply on the last hit? */ + lastHitOnly?: boolean; + /** Should this effect only apply on the first target hit? */ + firstTargetOnly?: boolean; + /** Overrides the secondary effect chance for this attr if set. */ + effectChanceOverride?: number; +} + /** Base class defining all Move Effect Attributes * @extends MoveAttr * @see {@linkcode apply} */ export class MoveEffectAttr extends MoveAttr { - /** Defines when this effect should trigger in the move's effect order - * @see {@linkcode phases.MoveEffectPhase.start} + /** + * A container for this attribute's optional parameters + * @see {@linkcode MoveEffectAttrOptions} for supported params. */ - public trigger: MoveEffectTrigger; - /** Should this effect only apply on the first hit? */ - public firstHitOnly: boolean; - /** Should this effect only apply on the last hit? */ - public lastHitOnly: boolean; - /** Should this effect only apply on the first target hit? */ - public firstTargetOnly: boolean; + protected options?: MoveEffectAttrOptions; - constructor(selfTarget?: boolean, trigger?: MoveEffectTrigger, firstHitOnly: boolean = false, lastHitOnly: boolean = false, firstTargetOnly: boolean = false) { + constructor(selfTarget?: boolean, options?: MoveEffectAttrOptions) { super(selfTarget); - this.trigger = trigger !== undefined ? trigger : MoveEffectTrigger.POST_APPLY; - this.firstHitOnly = firstHitOnly; - this.lastHitOnly = lastHitOnly; - this.firstTargetOnly = firstTargetOnly; + this.options = options; + } + + /** + * Defines when this effect should trigger in the move's effect order. + * @default MoveEffectTrigger.POST_APPLY + * @see {@linkcode MoveEffectTrigger} + */ + public get trigger () { + return this.options?.trigger ?? MoveEffectTrigger.POST_APPLY; + } + + /** + * `true` if this effect should only trigger on the first hit of + * multi-hit moves. + * @default false + */ + public get firstHitOnly () { + return this.options?.firstHitOnly ?? false; + } + + /** + * `true` if this effect should only trigger on the last hit of + * multi-hit moves. + * @default false + */ + public get lastHitOnly () { + return this.options?.lastHitOnly ?? false; + } + + /** + * `true` if this effect should apply only upon hitting a target + * for the first time when targeting multiple {@linkcode Pokemon}. + * @default false + */ + public get firstTargetOnly () { + return this.options?.firstTargetOnly ?? false; + } + + /** + * If defined, overrides the move's base chance for this + * secondary effect to trigger. + */ + public get effectChanceOverride () { + return this.options?.effectChanceOverride; } /** @@ -1019,16 +1199,23 @@ export class MoveEffectAttr extends MoveAttr { /** * Gets the used move's additional effect chance. - * If user's ability has MoveEffectChanceMultiplierAbAttr or IgnoreMoveEffectsAbAttr modifies the base chance. + * Chance is modified by {@linkcode MoveEffectChanceMultiplierAbAttr} and {@linkcode IgnoreMoveEffectsAbAttr}. * @param user {@linkcode Pokemon} using this move - * @param target {@linkcode Pokemon} target of this move + * @param target {@linkcode Pokemon | Target} of this move * @param move {@linkcode Move} being used - * @param selfEffect {@linkcode Boolean} if move targets user. - * @returns Move chance value. + * @param selfEffect `true` if move targets user. + * @returns Move effect chance value. */ getMoveChance(user: Pokemon, target: Pokemon, move: Move, selfEffect?: Boolean, showAbility?: Boolean): integer { - const moveChance = new Utils.NumberHolder(move.chance); + const moveChance = new Utils.NumberHolder(this.effectChanceOverride ?? move.chance); + applyAbAttrs(MoveEffectChanceMultiplierAbAttr, user, null, false, moveChance, move, target, selfEffect, showAbility); + + if ((!move.hasAttr(FlinchAttr) || moveChance.value <= move.chance) && !move.hasAttr(SecretPowerAttr)) { + const userSide = user.isPlayer() ? ArenaTagSide.PLAYER : ArenaTagSide.ENEMY; + user.scene.arena.applyTagsForSide(ArenaTagType.WATER_FIRE_PLEDGE, userSide, false, moveChance); + } + if (!selfEffect) { applyPreDefendAbAttrs(IgnoreMoveEffectsAbAttr, target, user, null, null, false, moveChance); } @@ -1312,7 +1499,7 @@ export class RecoilAttr extends MoveEffectAttr { private unblockable: boolean; constructor(useHp: boolean = false, damageRatio: number = 0.25, unblockable: boolean = false) { - super(true, MoveEffectTrigger.POST_APPLY, false, true); + super(true, { lastHitOnly: true }); this.useHp = useHp; this.damageRatio = damageRatio; @@ -1334,8 +1521,13 @@ export class RecoilAttr extends MoveEffectAttr { return false; } - const damageValue = (!this.useHp ? user.turnData.damageDealt : user.getMaxHp()) * this.damageRatio; - const minValue = user.turnData.damageDealt ? 1 : 0; + // Chloroblast and Struggle should not deal recoil damage if the move was not successful + if (this.useHp && [ MoveResult.FAIL, MoveResult.MISS ].includes(user.getLastXMoves(1)[0]?.result)) { + return false; + } + + const damageValue = (!this.useHp ? user.turnData.totalDamageDealt : user.getMaxHp()) * this.damageRatio; + const minValue = user.turnData.totalDamageDealt ? 1 : 0; const recoilDamage = Utils.toDmgValue(damageValue, minValue); if (!recoilDamage) { return false; @@ -1346,7 +1538,7 @@ export class RecoilAttr extends MoveEffectAttr { } user.damageAndUpdate(recoilDamage, HitResult.OTHER, false, true, true); - user.scene.queueMessage(i18next.t("moveTriggers:hitWithRecoil", {pokemonName: getPokemonNameWithAffix(user)})); + user.scene.queueMessage(i18next.t("moveTriggers:hitWithRecoil", { pokemonName: getPokemonNameWithAffix(user) })); user.turnData.damageTaken += recoilDamage; return true; @@ -1365,7 +1557,7 @@ export class RecoilAttr extends MoveEffectAttr { **/ export class SacrificialAttr extends MoveEffectAttr { constructor() { - super(true, MoveEffectTrigger.POST_TARGET); + super(true, { trigger: MoveEffectTrigger.POST_TARGET }); } /** @@ -1398,7 +1590,7 @@ export class SacrificialAttr extends MoveEffectAttr { **/ export class SacrificialAttrOnHit extends MoveEffectAttr { constructor() { - super(true, MoveEffectTrigger.HIT); + super(true, { trigger: MoveEffectTrigger.HIT }); } /** @@ -1437,7 +1629,7 @@ export class SacrificialAttrOnHit extends MoveEffectAttr { */ export class HalfSacrificialAttr extends MoveEffectAttr { constructor() { - super(true, MoveEffectTrigger.POST_TARGET); + super(true, { trigger: MoveEffectTrigger.POST_TARGET }); } /** @@ -1457,8 +1649,8 @@ export class HalfSacrificialAttr extends MoveEffectAttr { // Check to see if the Pokemon has an ability that blocks non-direct damage applyAbAttrs(BlockNonDirectDamageAbAttr, user, cancelled); if (!cancelled.value) { - user.damageAndUpdate(Utils.toDmgValue(user.getMaxHp()/2), HitResult.OTHER, false, true, true); - user.scene.queueMessage(i18next.t("moveTriggers:cutHpPowerUpMove", {pokemonName: getPokemonNameWithAffix(user)})); // Queue recoil message + user.damageAndUpdate(Utils.toDmgValue(user.getMaxHp() / 2), HitResult.OTHER, false, true, true); + user.scene.queueMessage(i18next.t("moveTriggers:cutHpPowerUpMove", { pokemonName: getPokemonNameWithAffix(user) })); // Queue recoil message } return true; } @@ -1467,7 +1659,7 @@ export class HalfSacrificialAttr extends MoveEffectAttr { if (user.isBoss()) { return -10; } - return Math.ceil(((1 - user.getHpRatio()/2) * 10 - 10) * (target.getAttackTypeEffectiveness(move.type, user) - 0.5)); + return Math.ceil(((1 - user.getHpRatio() / 2) * 10 - 10) * (target.getAttackTypeEffectiveness(move.type, user) - 0.5)); } } @@ -1478,8 +1670,13 @@ export class HalfSacrificialAttr extends MoveEffectAttr { * @see {@linkcode apply} */ export class AddSubstituteAttr extends MoveEffectAttr { - constructor() { + /** The ratio of the user's max HP that is required to apply this effect */ + private hpCost: number; + + constructor(hpCost: number = 0.25) { super(true); + + this.hpCost = hpCost; } /** @@ -1495,8 +1692,7 @@ export class AddSubstituteAttr extends MoveEffectAttr { return false; } - const hpCost = Math.floor(user.getMaxHp() / 4); - user.damageAndUpdate(hpCost, HitResult.OTHER, false, true, true); + user.damageAndUpdate(Math.floor(user.getMaxHp() * this.hpCost), HitResult.OTHER, false, true, true); user.addTag(BattlerTagType.SUBSTITUTE, 0, move.id, user.id); return true; } @@ -1509,7 +1705,7 @@ export class AddSubstituteAttr extends MoveEffectAttr { } getCondition(): MoveConditionFunc { - return (user, target, move) => !user.getTag(SubstituteTag) && user.hp > Math.floor(user.getMaxHp() / 4) && user.getMaxHp() > 1; + return (user, target, move) => !user.getTag(SubstituteTag) && user.hp > Math.floor(user.getMaxHp() * this.hpCost) && user.getMaxHp() > 1; } getFailedText(user: Pokemon, target: Pokemon, move: Move, cancelled: Utils.BooleanHolder): string | null { @@ -1560,7 +1756,7 @@ export class HealAttr extends MoveEffectAttr { */ addHealPhase(target: Pokemon, healRatio: number) { target.scene.unshiftPhase(new PokemonHealPhase(target.scene, target.getBattlerIndex(), - Utils.toDmgValue(target.getMaxHp() * healRatio), i18next.t("moveTriggers:healHp", {pokemonName: getPokemonNameWithAffix(target)}), true, !this.showAnim)); + Utils.toDmgValue(target.getMaxHp() * healRatio), i18next.t("moveTriggers:healHp", { pokemonName: getPokemonNameWithAffix(target) }), true, !this.showAnim)); } getTargetBenefitScore(user: Pokemon, target: Pokemon, move: Move): integer { @@ -1599,12 +1795,31 @@ export class PartyStatusCureAttr extends MoveEffectAttr { if (!this.canApply(user, target, move, args)) { return false; } - this.addPartyCurePhase(user); + const partyPokemon = user.isPlayer() ? user.scene.getPlayerParty() : user.scene.getEnemyParty(); + partyPokemon.forEach(p => this.cureStatus(p, user.id)); + + if (this.message) { + user.scene.queueMessage(this.message); + } + return true; } - addPartyCurePhase(user: Pokemon) { - user.scene.unshiftPhase(new PartyStatusCurePhase(user.scene, user, this.message, this.abilityCondition)); + /** + * Tries to cure the status of the given {@linkcode Pokemon} + * @param pokemon The {@linkcode Pokemon} to cure. + * @param userId The ID of the (move) {@linkcode Pokemon | user}. + */ + public cureStatus(pokemon: Pokemon, userId: number) { + if (!pokemon.isOnField() || pokemon.id === userId) { // user always cures its own status, regardless of ability + pokemon.resetStatus(false); + pokemon.updateInfo(); + } else if (!pokemon.hasAbility(this.abilityCondition)) { + pokemon.resetStatus(); + pokemon.updateInfo(); + } else { + pokemon.scene.unshiftPhase(new ShowAbilityPhase(pokemon.scene, pokemon.id, pokemon.getPassiveAbility()?.id === this.abilityCondition)); + } } } @@ -1632,7 +1847,7 @@ export class FlameBurstAttr extends MoveEffectAttr { return false; } - targetAlly.damageAndUpdate(Math.max(1, Math.floor(1/16 * targetAlly.getMaxHp())), HitResult.OTHER); + targetAlly.damageAndUpdate(Math.max(1, Math.floor(1 / 16 * targetAlly.getMaxHp())), HitResult.OTHER); return true; } @@ -1652,10 +1867,10 @@ export class SacrificialFullRestoreAttr extends SacrificialAttr { } // We don't know which party member will be chosen, so pick the highest max HP in the party - const maxPartyMemberHp = user.scene.getParty().map(p => p.getMaxHp()).reduce((maxHp: integer, hp: integer) => Math.max(hp, maxHp), 0); + const maxPartyMemberHp = user.scene.getPlayerParty().map(p => p.getMaxHp()).reduce((maxHp: integer, hp: integer) => Math.max(hp, maxHp), 0); user.scene.pushPhase(new PokemonHealPhase(user.scene, user.getBattlerIndex(), - maxPartyMemberHp, i18next.t("moveTriggers:sacrificialFullRestore", {pokemonName: getPokemonNameWithAffix(user)}), true, false, false, true), true); + maxPartyMemberHp, i18next.t("moveTriggers:sacrificialFullRestore", { pokemonName: getPokemonNameWithAffix(user) }), true, false, false, true), true); return true; } @@ -1665,7 +1880,7 @@ export class SacrificialFullRestoreAttr extends SacrificialAttr { } getCondition(): MoveConditionFunc { - return (user, target, move) => user.scene.getParty().filter(p => p.isActive()).length > user.scene.currentBattle.getBattlerCount(); + return (user, _target, _move) => user.scene.getPlayerParty().filter(p => p.isActive()).length > user.scene.currentBattle.getBattlerCount(); } } @@ -1692,7 +1907,7 @@ export class IgnoreWeatherTypeDebuffAttr extends MoveAttr { * @returns true if the function succeeds */ apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { - const weatherModifier=args[0] as Utils.NumberHolder; + const weatherModifier = args[0] as Utils.NumberHolder; //If the type-based attack power modifier due to weather (e.g. Water moves in Sun) is below 1, set it to 1 if (user.scene.arena.weather?.weatherType === this.weather) { weatherModifier.value = Math.max(weatherModifier.value, 1); @@ -1722,17 +1937,17 @@ export abstract class WeatherHealAttr extends HealAttr { export class PlantHealAttr extends WeatherHealAttr { getWeatherHealRatio(weatherType: WeatherType): number { switch (weatherType) { - case WeatherType.SUNNY: - case WeatherType.HARSH_SUN: - return 2 / 3; - case WeatherType.RAIN: - case WeatherType.SANDSTORM: - case WeatherType.HAIL: - case WeatherType.SNOW: - case WeatherType.HEAVY_RAIN: - return 0.25; - default: - return 0.5; + case WeatherType.SUNNY: + case WeatherType.HARSH_SUN: + return 2 / 3; + case WeatherType.RAIN: + case WeatherType.SANDSTORM: + case WeatherType.HAIL: + case WeatherType.SNOW: + case WeatherType.HEAVY_RAIN: + return 0.25; + default: + return 0.5; } } } @@ -1740,10 +1955,10 @@ export class PlantHealAttr extends WeatherHealAttr { export class SandHealAttr extends WeatherHealAttr { getWeatherHealRatio(weatherType: WeatherType): number { switch (weatherType) { - case WeatherType.SANDSTORM: - return 2 / 3; - default: - return 0.5; + case WeatherType.SANDSTORM: + return 2 / 3; + default: + return 0.5; } } } @@ -1818,7 +2033,7 @@ export class HitHealAttr extends MoveEffectAttr { private healStat: EffectiveStat | null; constructor(healRatio?: number | null, healStat?: EffectiveStat) { - super(true, MoveEffectTrigger.HIT); + super(true, { trigger: MoveEffectTrigger.HIT }); this.healRatio = healRatio ?? 0.5; this.healStat = healStat ?? null; @@ -1840,11 +2055,11 @@ export class HitHealAttr extends MoveEffectAttr { if (this.healStat !== null) { // Strength Sap formula healAmount = target.getEffectiveStat(this.healStat); - message = i18next.t("battle:drainMessage", {pokemonName: getPokemonNameWithAffix(target)}); + message = i18next.t("battle:drainMessage", { pokemonName: getPokemonNameWithAffix(target) }); } else { // Default healing formula used by draining moves like Absorb, Draining Kiss, Bitter Blade, etc. - healAmount = Utils.toDmgValue(user.turnData.currDamageDealt * this.healRatio); - message = i18next.t("battle:regainHealth", {pokemonName: getPokemonNameWithAffix(user)}); + healAmount = Utils.toDmgValue(user.turnData.singleHitDamageDealt * this.healRatio); + message = i18next.t("battle:regainHealth", { pokemonName: getPokemonNameWithAffix(user) }); } if (reverseDrain) { if (user.hasAbilityWithAttr(BlockNonDirectDamageAbAttr)) { @@ -1870,7 +2085,7 @@ export class HitHealAttr extends MoveEffectAttr { getUserBenefitScore(user: Pokemon, target: Pokemon, move: Move): integer { if (this.healStat) { const healAmount = target.getEffectiveStat(this.healStat); - return Math.floor(Math.max(0, (Math.min(1, (healAmount+user.hp)/user.getMaxHp() - 0.33))) / user.getHpRatio()); + return Math.floor(Math.max(0, (Math.min(1, (healAmount + user.hp) / user.getMaxHp() - 0.33))) / user.getHpRatio()); } return Math.floor(Math.max((1 - user.getHpRatio()) - 0.33, 0) * (move.power / 4)); } @@ -1923,12 +2138,21 @@ export class IncrementMovePriorityAttr extends MoveAttr { * @see {@linkcode apply} */ export class MultiHitAttr extends MoveAttr { + /** This move's intrinsic multi-hit type. It should never be modified. */ + private readonly intrinsicMultiHitType: MultiHitType; + /** This move's current multi-hit type. It may be temporarily modified by abilities (e.g., Battle Bond). */ private multiHitType: MultiHitType; constructor(multiHitType?: MultiHitType) { super(); - this.multiHitType = multiHitType !== undefined ? multiHitType : MultiHitType._2_TO_5; + this.intrinsicMultiHitType = multiHitType !== undefined ? multiHitType : MultiHitType._2_TO_5; + this.multiHitType = this.intrinsicMultiHitType; + } + + // Currently used by `battle_bond.test.ts` + getMultiHitType(): MultiHitType { + return this.multiHitType; } /** @@ -1942,7 +2166,7 @@ export class MultiHitAttr extends MoveAttr { * @returns True */ apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { - const hitType = new Utils.NumberHolder(this.multiHitType); + const hitType = new Utils.NumberHolder(this.intrinsicMultiHitType); applyMoveAttrs(ChangeMultiHitTypeAttr, user, target, move, hitType); this.multiHitType = hitType.value; @@ -1964,33 +2188,33 @@ export class MultiHitAttr extends MoveAttr { */ getHitCount(user: Pokemon, target: Pokemon): integer { switch (this.multiHitType) { - case MultiHitType._2_TO_5: - { - const rand = user.randSeedInt(16); - const hitValue = new Utils.IntegerHolder(rand); - applyAbAttrs(MaxMultiHitAbAttr, user, null, false, hitValue); - if (hitValue.value >= 10) { - return 2; - } else if (hitValue.value >= 4) { - return 3; - } else if (hitValue.value >= 2) { - return 4; - } else { - return 5; + case MultiHitType._2_TO_5: + { + const rand = user.randSeedInt(16); + const hitValue = new Utils.IntegerHolder(rand); + applyAbAttrs(MaxMultiHitAbAttr, user, null, false, hitValue); + if (hitValue.value >= 10) { + return 2; + } else if (hitValue.value >= 4) { + return 3; + } else if (hitValue.value >= 2) { + return 4; + } else { + return 5; + } } - } - case MultiHitType._2: - return 2; - case MultiHitType._3: - return 3; - case MultiHitType._10: - return 10; - case MultiHitType.BEAT_UP: - const party = user.isPlayer() ? user.scene.getParty() : user.scene.getEnemyParty(); - // No status means the ally pokemon can contribute to Beat Up - return party.reduce((total, pokemon) => { - return total + (pokemon.id === user.id ? 1 : pokemon?.status && pokemon.status.effect !== StatusEffect.NONE ? 0 : 1); - }, 0); + case MultiHitType._2: + return 2; + case MultiHitType._3: + return 3; + case MultiHitType._10: + return 10; + case MultiHitType.BEAT_UP: + const party = user.isPlayer() ? user.scene.getPlayerParty() : user.scene.getEnemyParty(); + // No status means the ally pokemon can contribute to Beat Up + return party.reduce((total, pokemon) => { + return total + (pokemon.id === user.id ? 1 : pokemon?.status && pokemon.status.effect !== StatusEffect.NONE ? 0 : 1); + }, 0); } } } @@ -2014,15 +2238,15 @@ export class WaterShurikenMultiHitTypeAttr extends ChangeMultiHitTypeAttr { export class StatusEffectAttr extends MoveEffectAttr { public effect: StatusEffect; - public cureTurn: integer | null; - public overrideStatus: boolean; + public turnsRemaining?: number; + public overrideStatus: boolean = false; - constructor(effect: StatusEffect, selfTarget?: boolean, cureTurn?: integer, overrideStatus?: boolean) { - super(selfTarget, MoveEffectTrigger.HIT); + constructor(effect: StatusEffect, selfTarget?: boolean, turnsRemaining?: number, overrideStatus: boolean = false) { + super(selfTarget, { trigger: MoveEffectTrigger.HIT }); this.effect = effect; - this.cureTurn = cureTurn!; // TODO: is this bang correct? - this.overrideStatus = !!overrideStatus; + this.turnsRemaining = turnsRemaining; + this.overrideStatus = overrideStatus; } apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { @@ -2042,14 +2266,14 @@ export class StatusEffectAttr extends MoveEffectAttr { } } - if (user !== target && target.scene.arena.getTagOnSide(ArenaTagType.SAFEGUARD, target.isPlayer() ? ArenaTagSide.PLAYER : ArenaTagSide.ENEMY)) { + if (user !== target && target.isSafeguarded(user)) { if (move.category === MoveCategory.STATUS) { - user.scene.queueMessage(i18next.t("moveTriggers:safeguard", { targetName: getPokemonNameWithAffix(target)})); + user.scene.queueMessage(i18next.t("moveTriggers:safeguard", { targetName: getPokemonNameWithAffix(target) })); } return false; } if ((!pokemon.status || (pokemon.status.effect === this.effect && moveChance < 0)) - && pokemon.trySetStatus(this.effect, true, user, this.cureTurn)) { + && pokemon.trySetStatus(this.effect, true, user, this.turnsRemaining)) { applyPostAttackAbAttrs(ConfusionOnStatusEffectAbAttr, user, target, move, null, false, this.effect); return true; } @@ -2059,15 +2283,18 @@ export class StatusEffectAttr extends MoveEffectAttr { getTargetBenefitScore(user: Pokemon, target: Pokemon, move: Move): number { const moveChance = this.getMoveChance(user, target, move, this.selfTarget, false); - return !(this.selfTarget ? user : target).status && (this.selfTarget ? user : target).canSetStatus(this.effect, true, false, user) ? Math.floor(moveChance * -0.1) : 0; + const score = (moveChance < 0) ? -10 : Math.floor(moveChance * -0.1); + const pokemon = this.selfTarget ? user : target; + + return !pokemon.status && pokemon.canSetStatus(this.effect, true, false, user) ? score : 0; } } export class MultiStatusEffectAttr extends StatusEffectAttr { public effects: StatusEffect[]; - constructor(effects: StatusEffect[], selfTarget?: boolean, cureTurn?: integer, overrideStatus?: boolean) { - super(effects[0], selfTarget, cureTurn, overrideStatus); + constructor(effects: StatusEffect[], selfTarget?: boolean, turnsRemaining?: number, overrideStatus?: boolean) { + super(effects[0], selfTarget, turnsRemaining, overrideStatus); this.effects = effects; } @@ -2079,39 +2306,43 @@ export class MultiStatusEffectAttr extends StatusEffectAttr { getTargetBenefitScore(user: Pokemon, target: Pokemon, move: Move): number { const moveChance = this.getMoveChance(user, target, move, this.selfTarget, false); - return !(this.selfTarget ? user : target).status && (this.selfTarget ? user : target).canSetStatus(this.effect, true, false, user) ? Math.floor(moveChance * -0.1) : 0; + const score = (moveChance < 0) ? -10 : Math.floor(moveChance * -0.1); + const pokemon = this.selfTarget ? user : target; + + return !pokemon.status && pokemon.canSetStatus(this.effect, true, false, user) ? score : 0; } } export class PsychoShiftEffectAttr extends MoveEffectAttr { constructor() { - super(false, MoveEffectTrigger.HIT); + super(false, { trigger: MoveEffectTrigger.HIT }); } - apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { + /** + * Applies the effect of Psycho Shift to its target + * Psycho Shift takes the user's status effect and passes it onto the target. The user is then healed after the move has been successfully executed. + * @returns `true` if Psycho Shift's effect is able to be applied to the target + */ + apply(user: Pokemon, target: Pokemon, _move: Move, _args: any[]): boolean { const statusToApply: StatusEffect | undefined = user.status?.effect ?? (user.hasAbility(Abilities.COMATOSE) ? StatusEffect.SLEEP : undefined); if (target.status) { return false; - } - //@ts-ignore - how can target.status.effect be checked when we return `false` before when it's defined? - if (!target.status || (target.status.effect === statusToApply && move.chance < 0)) { // TODO: resolve ts-ignore - const statusAfflictResult = target.trySetStatus(statusToApply, true, user); - if (statusAfflictResult) { - if (user.status) { - user.scene.queueMessage(getStatusEffectHealText(user.status.effect, getPokemonNameWithAffix(user))); - } - user.resetStatus(); - user.updateInfo(); - } - return statusAfflictResult; - } + } else { + const canSetStatus = target.canSetStatus(statusToApply, true, false, user); + const trySetStatus = canSetStatus ? target.trySetStatus(statusToApply, true, user) : false; - return false; + if (trySetStatus && user.status) { + // PsychoShiftTag is added to the user if move succeeds so that the user is healed of its status effect after its move + user.addTag(BattlerTagType.PSYCHO_SHIFT); + } + + return trySetStatus; + } } getTargetBenefitScore(user: Pokemon, target: Pokemon, move: Move): number { - return !(this.selfTarget ? user : target).status && (this.selfTarget ? user : target).canSetStatus(user.status?.effect, true, false, user) ? Math.floor(move.chance * -0.1) : 0; + return !target.status && target.canSetStatus(user.status?.effect, true, false, user) ? -10 : 0; } } /** @@ -2123,7 +2354,7 @@ export class StealHeldItemChanceAttr extends MoveEffectAttr { private chance: number; constructor(chance: number) { - super(false, MoveEffectTrigger.HIT); + super(false, { trigger: MoveEffectTrigger.HIT }); this.chance = chance; } @@ -2136,7 +2367,7 @@ export class StealHeldItemChanceAttr extends MoveEffectAttr { if (rand >= this.chance) { return resolve(false); } - const heldItems = this.getTargetHeldItems(target).filter(i => i.isTransferrable); + const heldItems = this.getTargetHeldItems(target).filter(i => i.isTransferable); if (heldItems.length) { const poolType = target.isPlayer() ? ModifierPoolType.PLAYER : target.hasTrainer() ? ModifierPoolType.TRAINER : ModifierPoolType.WILD; const highestItemTier = heldItems.map(m => m.type.getOrInferTier(poolType)).reduce((highestTier, tier) => Math.max(tier!, highestTier), 0); // TODO: is the bang after tier correct? @@ -2144,7 +2375,7 @@ export class StealHeldItemChanceAttr extends MoveEffectAttr { const stolenItem = tierHeldItems[user.randSeedInt(tierHeldItems.length)]; user.scene.tryTransferHeldItemModifier(stolenItem, user, false).then(success => { if (success) { - user.scene.queueMessage(i18next.t("moveTriggers:stoleItem", {pokemonName: getPokemonNameWithAffix(user), targetName: getPokemonNameWithAffix(target), itemName: stolenItem.type.name})); + user.scene.queueMessage(i18next.t("moveTriggers:stoleItem", { pokemonName: getPokemonNameWithAffix(user), targetName: getPokemonNameWithAffix(target), itemName: stolenItem.type.name })); } resolve(success); }); @@ -2184,7 +2415,7 @@ export class RemoveHeldItemAttr extends MoveEffectAttr { private berriesOnly: boolean; constructor(berriesOnly: boolean) { - super(false, MoveEffectTrigger.HIT); + super(false, { trigger: MoveEffectTrigger.HIT }); this.berriesOnly = berriesOnly; } @@ -2213,7 +2444,7 @@ export class RemoveHeldItemAttr extends MoveEffectAttr { } // Considers entire transferrable item pool by default (Knock Off). Otherwise berries only if specified (Incinerate). - let heldItems = this.getTargetHeldItems(target).filter(i => i.isTransferrable); + let heldItems = this.getTargetHeldItems(target).filter(i => i.isTransferable); if (this.berriesOnly) { heldItems = heldItems.filter(m => m instanceof BerryModifier && m.pokemonId === target.id, target.isPlayer()); @@ -2223,13 +2454,14 @@ export class RemoveHeldItemAttr extends MoveEffectAttr { const removedItem = heldItems[user.randSeedInt(heldItems.length)]; // Decrease item amount and update icon - !--removedItem.stackCount; + target.loseHeldItem(removedItem); target.scene.updateModifiers(target.isPlayer()); + if (this.berriesOnly) { - user.scene.queueMessage(i18next.t("moveTriggers:incineratedItem", {pokemonName: getPokemonNameWithAffix(user), targetName: getPokemonNameWithAffix(target), itemName: removedItem.type.name})); + user.scene.queueMessage(i18next.t("moveTriggers:incineratedItem", { pokemonName: getPokemonNameWithAffix(user), targetName: getPokemonNameWithAffix(target), itemName: removedItem.type.name })); } else { - user.scene.queueMessage(i18next.t("moveTriggers:knockedOffItem", {pokemonName: getPokemonNameWithAffix(user), targetName: getPokemonNameWithAffix(target), itemName: removedItem.type.name})); + user.scene.queueMessage(i18next.t("moveTriggers:knockedOffItem", { pokemonName: getPokemonNameWithAffix(user), targetName: getPokemonNameWithAffix(target), itemName: removedItem.type.name })); } } @@ -2258,7 +2490,7 @@ export class RemoveHeldItemAttr extends MoveEffectAttr { export class EatBerryAttr extends MoveEffectAttr { protected chosenBerry: BerryModifier | undefined; constructor() { - super(true, MoveEffectTrigger.HIT); + super(true, { trigger: MoveEffectTrigger.HIT }); } /** * Causes the target to eat a berry. @@ -2293,16 +2525,14 @@ export class EatBerryAttr extends MoveEffectAttr { } reduceBerryModifier(target: Pokemon) { - if (this.chosenBerry?.stackCount === 1) { - target.scene.removeModifier(this.chosenBerry, !target.isPlayer()); - } else if (this.chosenBerry !== undefined && this.chosenBerry.stackCount > 1) { - this.chosenBerry.stackCount--; + if (this.chosenBerry) { + target.loseHeldItem(this.chosenBerry); } target.scene.updateModifiers(target.isPlayer()); } - eatBerry(consumer: Pokemon) { - getBerryEffectFunc(this.chosenBerry!.berryType)(consumer); // consumer eats the berry + eatBerry(consumer: Pokemon, berryOwner?: Pokemon) { + getBerryEffectFunc(this.chosenBerry!.berryType)(consumer, berryOwner); // consumer eats the berry applyAbAttrs(HealFromBerryUseAbAttr, consumer, new Utils.BooleanHolder(false)); } } @@ -2339,10 +2569,11 @@ export class StealEatBerryAttr extends EatBerryAttr { } // if the target has berries, pick a random berry and steal it this.chosenBerry = heldBerries[user.randSeedInt(heldBerries.length)]; - const message = i18next.t("battle:stealEatBerry", {pokemonName: user.name, targetName: target.name, berryName: this.chosenBerry.type.name}); + applyPostItemLostAbAttrs(PostItemLostAbAttr, target, false); + const message = i18next.t("battle:stealEatBerry", { pokemonName: user.name, targetName: target.name, berryName: this.chosenBerry.type.name }); user.scene.queueMessage(message); this.reduceBerryModifier(target); - this.eatBerry(user); + this.eatBerry(user, target); return true; } } @@ -2358,12 +2589,11 @@ export class HealStatusEffectAttr extends MoveEffectAttr { /** * @param selfTarget - Whether this move targets the user - * @param ...effects - List of status effects to cure + * @param effects - status effect or list of status effects to cure */ - constructor(selfTarget: boolean, ...effects: StatusEffect[]) { - super(selfTarget, MoveEffectTrigger.POST_APPLY, false, true); - - this.effects = effects; + constructor(selfTarget: boolean, effects: StatusEffect | StatusEffect[]) { + super(selfTarget, { lastHitOnly: true }); + this.effects = [ effects ].flat(1); } /** @@ -2417,6 +2647,16 @@ export class BypassSleepAttr extends MoveAttr { return false; } + + /** + * Returns arbitrarily high score when Pokemon is asleep, otherwise shouldn't be used + * @param user + * @param target + * @param move + */ + getUserBenefitScore(user: Pokemon, target: Pokemon, move: Move): integer { + return user.status && user.status.effect === StatusEffect.SLEEP ? 200 : -10; + } } /** @@ -2529,6 +2769,63 @@ export class OneHitKOAttr extends MoveAttr { } } +/** + * Attribute that allows charge moves to resolve in 1 turn under a given condition. + * Should only be used for {@linkcode ChargingMove | ChargingMoves} as a `chargeAttr`. + * @extends MoveAttr + */ +export class InstantChargeAttr extends MoveAttr { + /** The condition in which the move with this attribute instantly charges */ + protected readonly condition: UserMoveConditionFunc; + + constructor(condition: UserMoveConditionFunc) { + super(true); + this.condition = condition; + } + + /** + * Flags the move with this attribute as instantly charged if this attribute's condition is met. + * @param user the {@linkcode Pokemon} using the move + * @param target n/a + * @param move the {@linkcode Move} associated with this attribute + * @param args + * - `[0]` a {@linkcode Utils.BooleanHolder | BooleanHolder} for the "instant charge" flag + * @returns `true` if the instant charge condition is met; `false` otherwise. + */ + override apply(user: Pokemon, target: Pokemon | null, move: Move, args: any[]): boolean { + const instantCharge = args[0]; + if (!(instantCharge instanceof Utils.BooleanHolder)) { + return false; + } + + if (this.condition(user, move)) { + instantCharge.value = true; + return true; + } + return false; + } +} + +/** + * Attribute that allows charge moves to resolve in 1 turn while specific {@linkcode WeatherType | Weather} + * is active. Should only be used for {@linkcode ChargingMove | ChargingMoves} as a `chargeAttr`. + * @extends InstantChargeAttr + */ +export class WeatherInstantChargeAttr extends InstantChargeAttr { + constructor(weatherTypes: WeatherType[]) { + super((user, move) => { + const currentWeather = user.scene.arena.weather; + + if (Utils.isNullOrUndefined(currentWeather?.weatherType)) { + return false; + } else { + return !currentWeather?.isEffectSuppressed(user.scene) + && weatherTypes.includes(currentWeather?.weatherType); + } + }); + } +} + export class OverrideMoveEffectAttr extends MoveAttr { apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean | Promise { //const overridden = args[0] as Utils.BooleanHolder; @@ -2537,111 +2834,14 @@ export class OverrideMoveEffectAttr extends MoveAttr { } } -export class ChargeAttr extends OverrideMoveEffectAttr { - public chargeAnim: ChargeAnim; - private chargeText: string; - private tagType: BattlerTagType | null; - private chargeEffect: boolean; - public followUpPriority: integer | null; - - constructor(chargeAnim: ChargeAnim, chargeText: string, tagType?: BattlerTagType | null, chargeEffect: boolean = false) { - super(); - - this.chargeAnim = chargeAnim; - this.chargeText = chargeText; - this.tagType = tagType!; // TODO: is this bang correct? - this.chargeEffect = chargeEffect; - } - - apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): Promise { - return new Promise(resolve => { - const lastMove = user.getLastXMoves().find(() => true); - if (!lastMove || lastMove.move !== move.id || (lastMove.result !== MoveResult.OTHER && lastMove.turn !== user.scene.currentBattle.turn)) { - (args[0] as Utils.BooleanHolder).value = true; - new MoveChargeAnim(this.chargeAnim, move.id, user).play(user.scene, false, () => { - user.scene.queueMessage(this.chargeText.replace("{TARGET}", getPokemonNameWithAffix(target)).replace("{USER}", getPokemonNameWithAffix(user))); - if (this.tagType) { - user.addTag(this.tagType, 1, move.id, user.id); - } - if (this.chargeEffect) { - applyMoveAttrs(MoveEffectAttr, user, target, move); - } - user.pushMoveHistory({ move: move.id, targets: [ target.getBattlerIndex() ], result: MoveResult.OTHER }); - user.getMoveQueue().push({ move: move.id, targets: [ target.getBattlerIndex() ], ignorePP: true }); - user.addTag(BattlerTagType.CHARGING, 1, move.id, user.id); - resolve(true); - }); - } else { - user.lapseTag(BattlerTagType.CHARGING); - resolve(false); - } - }); - } - - usedChargeEffect(user: Pokemon, target: Pokemon | null, move: Move): boolean { - if (!this.chargeEffect) { - return false; - } - // Account for move history being populated when this function is called - const lastMoves = user.getLastXMoves(2); - return lastMoves.length === 2 && lastMoves[1].move === move.id && lastMoves[1].result === MoveResult.OTHER; - } -} - -export class SunlightChargeAttr extends ChargeAttr { - constructor(chargeAnim: ChargeAnim, chargeText: string) { - super(chargeAnim, chargeText); - } - - apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): Promise { - return new Promise(resolve => { - const weatherType = user.scene.arena.weather?.weatherType; - if (!user.scene.arena.weather?.isEffectSuppressed(user.scene) && (weatherType === WeatherType.SUNNY || weatherType === WeatherType.HARSH_SUN)) { - resolve(false); - } else { - super.apply(user, target, move, args).then(result => resolve(result)); - } - }); - } -} - -export class ElectroShotChargeAttr extends ChargeAttr { - private statIncreaseApplied: boolean; - constructor() { - super(ChargeAnim.ELECTRO_SHOT_CHARGING, i18next.t("moveTriggers:absorbedElectricity", {pokemonName: "{USER}"}), null, true); - // Add a flag because ChargeAttr skills use themselves twice instead of once over one-to-two turns - this.statIncreaseApplied = false; - } - - apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): Promise { - return new Promise(resolve => { - const weatherType = user.scene.arena.weather?.weatherType; - if (!user.scene.arena.weather?.isEffectSuppressed(user.scene) && (weatherType === WeatherType.RAIN || weatherType === WeatherType.HEAVY_RAIN)) { - // Apply the SPATK increase every call when used in the rain - const statChangeAttr = new StatStageChangeAttr([ Stat.SPATK ], 1, true); - statChangeAttr.apply(user, target, move, args); - // After the SPATK is raised, execute the move resolution e.g. deal damage - resolve(false); - } else { - if (!this.statIncreaseApplied) { - // Apply the SPATK increase only if it hasn't been applied before e.g. on the first turn charge up animation - const statChangeAttr = new StatStageChangeAttr([ Stat.SPATK ], 1, true); - statChangeAttr.apply(user, target, move, args); - // Set the flag to true so that on the following turn it doesn't raise SPATK a second time - this.statIncreaseApplied = true; - } - super.apply(user, target, move, args).then(result => { - if (!result) { - // On the second turn, reset the statIncreaseApplied flag without applying the SPATK increase - this.statIncreaseApplied = false; - } - resolve(result); - }); - } - }); - } -} - +/** + * Attack Move that doesn't hit the turn it is played and doesn't allow for multiple + * uses on the same target. Examples are Future Sight or Doom Desire. + * @extends OverrideMoveEffectAttr + * @param tagType The {@linkcode ArenaTagType} that will be placed on the field when the move is used + * @param chargeAnim The {@linkcode ChargeAnim | Charging Animation} used for the move + * @param chargeText The text to display when the move is used + */ export class DelayedAttackAttr extends OverrideMoveEffectAttr { public tagType: ArenaTagType; public chargeAnim: ChargeAnim; @@ -2656,37 +2856,155 @@ export class DelayedAttackAttr extends OverrideMoveEffectAttr { } apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): Promise { + // Edge case for the move applied on a pokemon that has fainted + if (!target) { + return Promise.resolve(true); + } + const side = target.isPlayer() ? ArenaTagSide.PLAYER : ArenaTagSide.ENEMY; return new Promise(resolve => { if (args.length < 2 || !args[1]) { new MoveChargeAnim(this.chargeAnim, move.id, user).play(user.scene, false, () => { (args[0] as Utils.BooleanHolder).value = true; user.scene.queueMessage(this.chargeText.replace("{TARGET}", getPokemonNameWithAffix(target)).replace("{USER}", getPokemonNameWithAffix(user))); user.pushMoveHistory({ move: move.id, targets: [ target.getBattlerIndex() ], result: MoveResult.OTHER }); - user.scene.arena.addTag(this.tagType, 3, move.id, user.id, ArenaTagSide.BOTH, false, target.getBattlerIndex()); + user.scene.arena.addTag(this.tagType, 3, move.id, user.id, side, false, target.getBattlerIndex()); resolve(true); }); } else { - user.scene.ui.showText(i18next.t("moveTriggers:tookMoveAttack", {pokemonName: getPokemonNameWithAffix(user.scene.getPokemonById(target.id) ?? undefined), moveName: move.name}), null, () => resolve(true)); + user.scene.ui.showText(i18next.t("moveTriggers:tookMoveAttack", { pokemonName: getPokemonNameWithAffix(user.scene.getPokemonById(target.id) ?? undefined), moveName: move.name }), null, () => resolve(true)); } }); } } +/** + * Attribute that cancels the associated move's effects when set to be combined with the user's ally's + * subsequent move this turn. Used for Grass Pledge, Water Pledge, and Fire Pledge. + * @extends OverrideMoveEffectAttr + */ +export class AwaitCombinedPledgeAttr extends OverrideMoveEffectAttr { + constructor() { + super(true); + } + /** + * If the user's ally is set to use a different move with this attribute, + * defer this move's effects for a combined move on the ally's turn. + * @param user the {@linkcode Pokemon} using this move + * @param target n/a + * @param move the {@linkcode Move} being used + * @param args + * - [0] a {@linkcode Utils.BooleanHolder} indicating whether the move's base + * effects should be overridden this turn. + * @returns `true` if base move effects were overridden; `false` otherwise + */ + override apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { + if (user.turnData.combiningPledge) { + // "The two moves have become one!\nIt's a combined move!" + user.scene.queueMessage(i18next.t("moveTriggers:combiningPledge")); + return false; + } + + const overridden = args[0] as Utils.BooleanHolder; + + const allyMovePhase = user.scene.findPhase((phase) => phase instanceof MovePhase && phase.pokemon.isPlayer() === user.isPlayer()); + if (allyMovePhase) { + const allyMove = allyMovePhase.move.getMove(); + if (allyMove !== move && allyMove.hasAttr(AwaitCombinedPledgeAttr)) { + [ user, allyMovePhase.pokemon ].forEach((p) => p.turnData.combiningPledge = move.id); + + // "{userPokemonName} is waiting for {allyPokemonName}'s move..." + user.scene.queueMessage(i18next.t("moveTriggers:awaitingPledge", { + userPokemonName: getPokemonNameWithAffix(user), + allyPokemonName: getPokemonNameWithAffix(allyMovePhase.pokemon) + })); + + // Move the ally's MovePhase (if needed) so that the ally moves next + const allyMovePhaseIndex = user.scene.phaseQueue.indexOf(allyMovePhase); + const firstMovePhaseIndex = user.scene.phaseQueue.findIndex((phase) => phase instanceof MovePhase); + if (allyMovePhaseIndex !== firstMovePhaseIndex) { + user.scene.prependToPhase(user.scene.phaseQueue.splice(allyMovePhaseIndex, 1)[0], MovePhase); + } + + overridden.value = true; + return true; + } + } + return false; + } +} + +/** + * Set of optional parameters that may be applied to stat stage changing effects + * @extends MoveEffectAttrOptions + * @see {@linkcode StatStageChangeAttr} + */ +interface StatStageChangeAttrOptions extends MoveEffectAttrOptions { + /** If defined, needs to be met in order for the stat change to apply */ + condition?: MoveConditionFunc, + /** `true` to display a message */ + showMessage?: boolean +} + +/** + * Attribute used for moves that change stat stages + * + * @param stats {@linkcode BattleStat} Array of stat(s) to change + * @param stages How many stages to change the stat(s) by, [-6, 6] + * @param selfTarget `true` if the move is self-targetting + * @param options {@linkcode StatStageChangeAttrOptions} Container for any optional parameters for this attribute. + * + * @extends MoveEffectAttr + * @see {@linkcode apply} + */ export class StatStageChangeAttr extends MoveEffectAttr { public stats: BattleStat[]; - public stages: integer; - private condition: MoveConditionFunc | null; - private showMessage: boolean; + public stages: number; + /** + * Container for optional parameters to this attribute. + * @see {@linkcode StatStageChangeAttrOptions} for available optional params + */ + protected override options?: StatStageChangeAttrOptions; - constructor(stats: BattleStat[], stages: integer, selfTarget?: boolean, condition?: MoveConditionFunc | null, showMessage: boolean = true, firstHitOnly: boolean = false, moveEffectTrigger: MoveEffectTrigger = MoveEffectTrigger.HIT, firstTargetOnly: boolean = false) { - super(selfTarget, moveEffectTrigger, firstHitOnly, false, firstTargetOnly); + constructor(stats: BattleStat[], stages: number, selfTarget?: boolean, options?: StatStageChangeAttrOptions) { + super(selfTarget, options); this.stats = stats; this.stages = stages; - this.condition = condition!; // TODO: is this bang correct? - this.showMessage = showMessage; + this.options = options; } + /** + * The condition required for the stat stage change to apply. + * Defaults to `null` (i.e. no condition required). + */ + private get condition () { + return this.options?.condition ?? null; + } + + /** + * `true` to display a message for the stat change. + * @default true + */ + private get showMessage () { + return this.options?.showMessage ?? true; + } + + /** + * Indicates when the stat change should trigger + * @default MoveEffectTrigger.HIT + */ + public override get trigger () { + return this.options?.trigger ?? MoveEffectTrigger.HIT; + } + + /** + * Attempts to change stats of the user or target (depending on value of selfTarget) if conditions are met + * @param user {@linkcode Pokemon} the user of the move + * @param target {@linkcode Pokemon} the target of the move + * @param move {@linkcode Move} the move + * @param args unused + * @returns whether stat stages were changed + */ apply(user: Pokemon, target: Pokemon, move: Move, args?: any[]): boolean | Promise { if (!super.apply(user, target, move, args) || (this.condition && !this.condition(user, target, move))) { return false; @@ -2723,26 +3041,26 @@ export class StatStageChangeAttr extends MoveEffectAttr { } let noEffect = false; switch (stat) { - case Stat.ATK: - if (this.selfTarget) { - noEffect = !user.getMoveset().find(m => m instanceof AttackMove && m.category === MoveCategory.PHYSICAL); - } - break; - case Stat.DEF: - if (!this.selfTarget) { - noEffect = !user.getMoveset().find(m => m instanceof AttackMove && m.category === MoveCategory.PHYSICAL); - } - break; - case Stat.SPATK: - if (this.selfTarget) { - noEffect = !user.getMoveset().find(m => m instanceof AttackMove && m.category === MoveCategory.SPECIAL); - } - break; - case Stat.SPDEF: - if (!this.selfTarget) { - noEffect = !user.getMoveset().find(m => m instanceof AttackMove && m.category === MoveCategory.SPECIAL); - } - break; + case Stat.ATK: + if (this.selfTarget) { + noEffect = !user.getMoveset().find(m => m instanceof AttackMove && m.category === MoveCategory.PHYSICAL); + } + break; + case Stat.DEF: + if (!this.selfTarget) { + noEffect = !user.getMoveset().find(m => m instanceof AttackMove && m.category === MoveCategory.PHYSICAL); + } + break; + case Stat.SPATK: + if (this.selfTarget) { + noEffect = !user.getMoveset().find(m => m instanceof AttackMove && m.category === MoveCategory.SPECIAL); + } + break; + case Stat.SPDEF: + if (!this.selfTarget) { + noEffect = !user.getMoveset().find(m => m instanceof AttackMove && m.category === MoveCategory.SPECIAL); + } + break; } if (noEffect) { continue; @@ -2753,6 +3071,146 @@ export class StatStageChangeAttr extends MoveEffectAttr { } } +/** + * Attribute used to determine the Biome/Terrain-based secondary effect of Secret Power + */ +export class SecretPowerAttr extends MoveEffectAttr { + constructor() { + super(false); + } + + /** + * Used to apply the secondary effect to the target Pokemon + * @returns `true` if a secondary effect is successfully applied + */ + override apply(user: Pokemon, target: Pokemon, move: Move, args?: any[]): boolean | Promise { + if (!super.apply(user, target, move, args)) { + return false; + } + let secondaryEffect: MoveEffectAttr; + const terrain = user.scene.arena.getTerrainType(); + if (terrain !== TerrainType.NONE) { + secondaryEffect = this.determineTerrainEffect(terrain); + } else { + const biome = user.scene.arena.biomeType; + secondaryEffect = this.determineBiomeEffect(biome); + } + return secondaryEffect.apply(user, target, move, []); + } + + /** + * Determines the secondary effect based on terrain. + * Takes precedence over biome-based effects. + * ``` + * Electric Terrain | Paralysis + * Misty Terrain | SpAtk -1 + * Grassy Terrain | Sleep + * Psychic Terrain | Speed -1 + * ``` + * @param terrain - {@linkcode TerrainType} The current terrain + * @returns the chosen secondary effect {@linkcode MoveEffectAttr} + */ + private determineTerrainEffect(terrain: TerrainType): MoveEffectAttr { + let secondaryEffect: MoveEffectAttr; + switch (terrain) { + case TerrainType.ELECTRIC: + default: + secondaryEffect = new StatusEffectAttr(StatusEffect.PARALYSIS, false); + break; + case TerrainType.MISTY: + secondaryEffect = new StatStageChangeAttr([ Stat.SPATK ], -1, false); + break; + case TerrainType.GRASSY: + secondaryEffect = new StatusEffectAttr(StatusEffect.SLEEP, false); + break; + case TerrainType.PSYCHIC: + secondaryEffect = new StatStageChangeAttr([ Stat.SPD ], -1, false); + break; + } + return secondaryEffect; + } + + /** + * Determines the secondary effect based on biome + * ``` + * Town, Metropolis, Slum, Dojo, Laboratory, Power Plant + Default | Paralysis + * Plains, Grass, Tall Grass, Forest, Jungle, Meadow | Sleep + * Swamp, Mountain, Temple, Ruins | Speed -1 + * Ice Cave, Snowy Forest | Freeze + * Volcano | Burn + * Fairy Cave | SpAtk -1 + * Desert, Construction Site, Beach, Island, Badlands | Accuracy -1 + * Sea, Lake, Seabed | Atk -1 + * Cave, Wasteland, Graveyard, Abyss, Space | Flinch + * End | Def -1 + * ``` + * @param biome - The current {@linkcode Biome} the battle is set in + * @returns the chosen secondary effect {@linkcode MoveEffectAttr} + */ + private determineBiomeEffect(biome: Biome): MoveEffectAttr { + let secondaryEffect: MoveEffectAttr; + switch (biome) { + case Biome.PLAINS: + case Biome.GRASS: + case Biome.TALL_GRASS: + case Biome.FOREST: + case Biome.JUNGLE: + case Biome.MEADOW: + secondaryEffect = new StatusEffectAttr(StatusEffect.SLEEP, false); + break; + case Biome.SWAMP: + case Biome.MOUNTAIN: + case Biome.TEMPLE: + case Biome.RUINS: + secondaryEffect = new StatStageChangeAttr([ Stat.SPD ], -1, false); + break; + case Biome.ICE_CAVE: + case Biome.SNOWY_FOREST: + secondaryEffect = new StatusEffectAttr(StatusEffect.FREEZE, false); + break; + case Biome.VOLCANO: + secondaryEffect = new StatusEffectAttr(StatusEffect.BURN, false); + break; + case Biome.FAIRY_CAVE: + secondaryEffect = new StatStageChangeAttr([ Stat.SPATK ], -1, false); + break; + case Biome.DESERT: + case Biome.CONSTRUCTION_SITE: + case Biome.BEACH: + case Biome.ISLAND: + case Biome.BADLANDS: + secondaryEffect = new StatStageChangeAttr([ Stat.ACC ], -1, false); + break; + case Biome.SEA: + case Biome.LAKE: + case Biome.SEABED: + secondaryEffect = new StatStageChangeAttr([ Stat.ATK ], -1, false); + break; + case Biome.CAVE: + case Biome.WASTELAND: + case Biome.GRAVEYARD: + case Biome.ABYSS: + case Biome.SPACE: + secondaryEffect = new AddBattlerTagAttr(BattlerTagType.FLINCHED, false, true); + break; + case Biome.END: + secondaryEffect = new StatStageChangeAttr([ Stat.DEF ], -1, false); + break; + case Biome.TOWN: + case Biome.METROPOLIS: + case Biome.SLUM: + case Biome.DOJO: + case Biome.FACTORY: + case Biome.LABORATORY: + case Biome.POWER_PLANT: + default: + secondaryEffect = new StatusEffectAttr(StatusEffect.PARALYSIS, false); + break; + } + return secondaryEffect; + } +} + export class PostVictoryStatStageChangeAttr extends MoveAttr { private stats: BattleStat[]; private stages: number; @@ -2783,7 +3241,7 @@ export class AcupressureStatStageChangeAttr extends MoveEffectAttr { apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean | Promise { const randStats = BATTLE_STATS.filter(s => target.getStatStage(s) < 6); if (randStats.length > 0) { - const boostStat = [randStats[user.randSeedInt(randStats.length)]]; + const boostStat = [ randStats[user.randSeedInt(randStats.length)] ]; user.scene.unshiftPhase(new StatStageChangePhase(user.scene, target.getBattlerIndex(), this.selfTarget, boostStat, 2)); return true; } @@ -2812,7 +3270,7 @@ export class CutHpStatStageBoostAttr extends StatStageChangeAttr { private messageCallback: ((user: Pokemon) => void) | undefined; constructor(stat: BattleStat[], levels: integer, cutRatio: integer, messageCallback?: ((user: Pokemon) => void) | undefined) { - super(stat, levels, true, null, true); + super(stat, levels, true); this.cutRatio = cutRatio; this.messageCallback = messageCallback; @@ -2836,6 +3294,41 @@ export class CutHpStatStageBoostAttr extends StatStageChangeAttr { } } +/** + * Attribute implementing the stat boosting effect of {@link https://bulbapedia.bulbagarden.net/wiki/Order_Up_(move) | Order Up}. + * If the user has a Pokemon with {@link https://bulbapedia.bulbagarden.net/wiki/Commander_(Ability) | Commander} in their mouth, + * one of the user's stats are increased by 1 stage, depending on the "commanding" Pokemon's form. This effect does not respect + * effect chance, but Order Up itself may be boosted by Sheer Force. + */ +export class OrderUpStatBoostAttr extends MoveEffectAttr { + constructor() { + super(true, { trigger: MoveEffectTrigger.HIT }); + } + + override apply(user: Pokemon, target: Pokemon, move: Move, args?: any[]): boolean { + const commandedTag = user.getTag(CommandedTag); + if (!commandedTag) { + return false; + } + + let increasedStat: EffectiveStat = Stat.ATK; + switch (commandedTag.tatsugiriFormKey) { + case "curly": + increasedStat = Stat.ATK; + break; + case "droopy": + increasedStat = Stat.DEF; + break; + case "stretchy": + increasedStat = Stat.SPD; + break; + } + + user.scene.unshiftPhase(new StatStageChangePhase(user.scene, user.getBattlerIndex(), this.selfTarget, [ increasedStat ], 1)); + return true; + } +} + export class CopyStatsAttr extends MoveEffectAttr { apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { if (!super.apply(user, target, move, args)) { @@ -2854,7 +3347,7 @@ export class CopyStatsAttr extends MoveEffectAttr { } target.updateInfo(); user.updateInfo(); - target.scene.queueMessage(i18next.t("moveTriggers:copiedStatChanges", {pokemonName: getPokemonNameWithAffix(user), targetName: getPokemonNameWithAffix(target)})); + target.scene.queueMessage(i18next.t("moveTriggers:copiedStatChanges", { pokemonName: getPokemonNameWithAffix(user), targetName: getPokemonNameWithAffix(target) })); return true; } @@ -2873,7 +3366,7 @@ export class InvertStatsAttr extends MoveEffectAttr { target.updateInfo(); user.updateInfo(); - target.scene.queueMessage(i18next.t("moveTriggers:invertStats", {pokemonName: getPokemonNameWithAffix(target)})); + target.scene.queueMessage(i18next.t("moveTriggers:invertStats", { pokemonName: getPokemonNameWithAffix(target) })); return true; } @@ -2894,7 +3387,7 @@ export class ResetStatsAttr extends MoveEffectAttr { } else { // Affects only the single target when Clear Smog is used if (!move.hitsSubstitute(user, target)) { promises.push(this.resetStats(target)); - target.scene.queueMessage(i18next.t("moveTriggers:resetStats", {pokemonName: getPokemonNameWithAffix(target)})); + target.scene.queueMessage(i18next.t("moveTriggers:resetStats", { pokemonName: getPokemonNameWithAffix(target) })); } } @@ -3031,21 +3524,21 @@ export class LessPPMorePowerAttr extends VariablePowerAttr { const power = args[0] as Utils.NumberHolder; switch (ppRemains) { - case 0: - power.value = 200; - break; - case 1: - power.value = 80; - break; - case 2: - power.value = 60; - break; - case 3: - power.value = 50; - break; - default: - power.value = 40; - break; + case 0: + power.value = 200; + break; + case 1: + power.value = 80; + break; + case 2: + power.value = 60; + break; + case 3: + power.value = 50; + break; + default: + power.value = 40; + break; } return true; } @@ -3075,7 +3568,7 @@ export class MovePowerMultiplierAttr extends VariablePowerAttr { * @returns The base power of the Beat Up hit. */ const beatUpFunc = (user: Pokemon, allyIndex: number): number => { - const party = user.isPlayer() ? user.scene.getParty() : user.scene.getEnemyParty(); + const party = user.isPlayer() ? user.scene.getPlayerParty() : user.scene.getEnemyParty(); for (let i = allyIndex; i < party.length; i++) { const pokemon = party[i]; @@ -3103,7 +3596,7 @@ export class BeatUpAttr extends VariablePowerAttr { apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { const power = args[0] as Utils.NumberHolder; - const party = user.isPlayer() ? user.scene.getParty() : user.scene.getEnemyParty(); + const party = user.isPlayer() ? user.scene.getPlayerParty() : user.scene.getEnemyParty(); const allyCount = party.filter(pokemon => { return pokemon.id === user.id || !pokemon.status?.effect; }).length; @@ -3118,7 +3611,7 @@ const doublePowerChanceMessageFunc = (user: Pokemon, target: Pokemon, move: Move user.scene.executeWithSeedOffset(() => { const rand = Utils.randSeedInt(100); if (rand < move.chance) { - message = i18next.t("moveTriggers:goingAllOutForAttack", {pokemonName: getPokemonNameWithAffix(user)}); + message = i18next.t("moveTriggers:goingAllOutForAttack", { pokemonName: getPokemonNameWithAffix(user) }); } }, user.scene.currentBattle.turn << 6, user.scene.waveSeed); return message; @@ -3265,24 +3758,24 @@ export class LowHpPowerAttr extends VariablePowerAttr { const hpRatio = user.getHpRatio(); switch (true) { - case (hpRatio < 0.0417): - power.value = 200; - break; - case (hpRatio < 0.1042): - power.value = 150; - break; - case (hpRatio < 0.2083): - power.value = 100; - break; - case (hpRatio < 0.3542): - power.value = 80; - break; - case (hpRatio < 0.6875): - power.value = 40; - break; - default: - power.value = 20; - break; + case (hpRatio < 0.0417): + power.value = 200; + break; + case (hpRatio < 0.1042): + power.value = 150; + break; + case (hpRatio < 0.2083): + power.value = 100; + break; + case (hpRatio < 0.3542): + power.value = 80; + break; + case (hpRatio < 0.6875): + power.value = 40; + break; + default: + power.value = 20; + break; } return true; @@ -3302,21 +3795,21 @@ export class CompareWeightPowerAttr extends VariablePowerAttr { const relativeWeight = (targetWeight / userWeight) * 100; switch (true) { - case (relativeWeight < 20.01): - power.value = 120; - break; - case (relativeWeight < 25.01): - power.value = 100; - break; - case (relativeWeight < 33.35): - power.value = 80; - break; - case (relativeWeight < 50.01): - power.value = 60; - break; - default: - power.value = 40; - break; + case (relativeWeight < 20.01): + power.value = 120; + break; + case (relativeWeight < 25.01): + power.value = 100; + break; + case (relativeWeight < 33.35): + power.value = 80; + break; + case (relativeWeight < 50.01): + power.value = 60; + break; + default: + power.value = 40; + break; } return true; @@ -3397,7 +3890,7 @@ const magnitudeMessageFunc = (user: Pokemon, target: Pokemon, move: Move) => { } } - message = i18next.t("moveTriggers:magnitudeMessage", {magnitude: m + 4}); + message = i18next.t("moveTriggers:magnitudeMessage", { magnitude: m + 4 }); }, user.scene.currentBattle.turn << 6, user.scene.waveSeed); return message!; }; @@ -3432,13 +3925,13 @@ export class AntiSunlightPowerDecreaseAttr extends VariablePowerAttr { const power = args[0] as Utils.NumberHolder; const weatherType = user.scene.arena.weather?.weatherType || WeatherType.NONE; switch (weatherType) { - case WeatherType.RAIN: - case WeatherType.SANDSTORM: - case WeatherType.HAIL: - case WeatherType.SNOW: - case WeatherType.HEAVY_RAIN: - power.value *= 0.5; - return true; + case WeatherType.RAIN: + case WeatherType.SANDSTORM: + case WeatherType.HAIL: + case WeatherType.SNOW: + case WeatherType.HEAVY_RAIN: + power.value *= 0.5; + return true; } } @@ -3547,7 +4040,7 @@ export class PresentPowerAttr extends VariablePowerAttr { // If this move is multi-hit, disable all other hits user.stopMultiHit(); target.scene.unshiftPhase(new PokemonHealPhase(target.scene, target.getBattlerIndex(), - Utils.toDmgValue(target.getMaxHp() / 4), i18next.t("moveTriggers:regainedHealth", {pokemonName: getPokemonNameWithAffix(target)}), true)); + Utils.toDmgValue(target.getMaxHp() / 4), i18next.t("moveTriggers:regainedHealth", { pokemonName: getPokemonNameWithAffix(target) }), true)); } return true; @@ -3712,8 +4205,8 @@ export class LastMoveDoublePowerAttr extends VariablePowerAttr { for (const p of pokemonActed) { const [ lastMove ] = p.getLastXMoves(1); - if (lastMove.result !== MoveResult.FAIL) { - if ((lastMove.result === MoveResult.SUCCESS) && (lastMove.move === this.move)) { + if (lastMove?.result !== MoveResult.FAIL) { + if ((lastMove?.result === MoveResult.SUCCESS) && (lastMove?.move === this.move)) { power.value *= 2; return true; } else { @@ -3726,6 +4219,99 @@ export class LastMoveDoublePowerAttr extends VariablePowerAttr { } } +/** + * Changes a Pledge move's power to 150 when combined with another unique Pledge + * move from an ally. + */ +export class CombinedPledgePowerAttr extends VariablePowerAttr { + override apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { + const power = args[0]; + if (!(power instanceof Utils.NumberHolder)) { + return false; + } + const combinedPledgeMove = user.turnData.combiningPledge; + + if (combinedPledgeMove && combinedPledgeMove !== move.id) { + power.value *= 150 / 80; + return true; + } + return false; + } +} + +/** + * Applies STAB to the given Pledge move if the move is part of a combined attack. + */ +export class CombinedPledgeStabBoostAttr extends MoveAttr { + override apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { + const stabMultiplier = args[0]; + if (!(stabMultiplier instanceof Utils.NumberHolder)) { + return false; + } + const combinedPledgeMove = user.turnData.combiningPledge; + + if (combinedPledgeMove && combinedPledgeMove !== move.id) { + stabMultiplier.value = 1.5; + return true; + } + return false; + } +} + +/** + * Variable Power attribute for {@link https://bulbapedia.bulbagarden.net/wiki/Round_(move) | Round}. + * Doubles power if another Pokemon has previously selected Round this turn. + * @extends VariablePowerAttr + */ +export class RoundPowerAttr extends VariablePowerAttr { + override apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { + const power = args[0]; + if (!(power instanceof Utils.NumberHolder)) { + return false; + } + + if (user.turnData?.joinedRound) { + power.value *= 2; + return true; + } + return false; + } +} + +/** + * Attribute for the "combo" effect of {@link https://bulbapedia.bulbagarden.net/wiki/Round_(move) | Round}. + * Preempts the next move in the turn order with the first instance of any Pokemon + * using Round. Also marks the Pokemon using the cued Round to double the move's power. + * @extends MoveEffectAttr + * @see {@linkcode RoundPowerAttr} + */ +export class CueNextRoundAttr extends MoveEffectAttr { + constructor() { + super(true, { lastHitOnly: true }); + } + + override apply(user: Pokemon, target: Pokemon, move: Move, args?: any[]): boolean { + const nextRoundPhase = user.scene.findPhase(phase => + phase instanceof MovePhase && phase.move.moveId === Moves.ROUND + ); + + if (!nextRoundPhase) { + return false; + } + + // Update the phase queue so that the next Pokemon using Round moves next + const nextRoundIndex = user.scene.phaseQueue.indexOf(nextRoundPhase); + const nextMoveIndex = user.scene.phaseQueue.findIndex(phase => phase instanceof MovePhase); + if (nextRoundIndex !== nextMoveIndex) { + user.scene.prependToPhase(user.scene.phaseQueue.splice(nextRoundIndex, 1)[0], MovePhase); + } + + // Mark the corresponding Pokemon as having "joined the Round" (for doubling power later) + nextRoundPhase.pokemon.turnData.joinedRound = true; + return true; + } +} + export class VariableAtkAttr extends MoveAttr { constructor() { super(); @@ -3796,14 +4382,14 @@ export class ThunderAccuracyAttr extends VariableAccuracyAttr { const accuracy = args[0] as Utils.NumberHolder; const weatherType = user.scene.arena.weather?.weatherType || WeatherType.NONE; switch (weatherType) { - case WeatherType.SUNNY: - case WeatherType.HARSH_SUN: - accuracy.value = 50; - return true; - case WeatherType.RAIN: - case WeatherType.HEAVY_RAIN: - accuracy.value = -1; - return true; + case WeatherType.SUNNY: + case WeatherType.HARSH_SUN: + accuracy.value = 50; + return true; + case WeatherType.RAIN: + case WeatherType.HEAVY_RAIN: + accuracy.value = -1; + return true; } } @@ -3822,10 +4408,10 @@ export class StormAccuracyAttr extends VariableAccuracyAttr { const accuracy = args[0] as Utils.NumberHolder; const weatherType = user.scene.arena.weather?.weatherType || WeatherType.NONE; switch (weatherType) { - case WeatherType.RAIN: - case WeatherType.HEAVY_RAIN: - accuracy.value = -1; - return true; + case WeatherType.RAIN: + case WeatherType.HEAVY_RAIN: + accuracy.value = -1; + return true; } } @@ -3906,7 +4492,14 @@ export class PhotonGeyserCategoryAttr extends VariableMoveCategoryAttr { } } -export class TeraBlastCategoryAttr extends VariableMoveCategoryAttr { +/** + * Attribute used for tera moves that change category based on the user's Atk and SpAtk stats + * Note: Currently, `getEffectiveStat` does not ignore all abilities that affect stats except those + * with the attribute of `StatMultiplierAbAttr` + * TODO: Remove the `.partial()` tag from Tera Blast and Tera Starstorm when the above issue is resolved + * @extends VariableMoveCategoryAttr + */ +export class TeraMoveCategoryAttr extends VariableMoveCategoryAttr { apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { const category = (args[0] as Utils.NumberHolder); @@ -3956,11 +4549,11 @@ export class StatusCategoryOnAllyAttr extends VariableMoveCategoryAttr { * @param user {@linkcode Pokemon} using the move * @param target {@linkcode Pokemon} target of the move * @param move {@linkcode Move} with this attribute - * @param args [0] {@linkcode Utils.IntegerHolder} The category of the move + * @param args [0] {@linkcode Utils.NumberHolder} The category of the move * @returns true if the function succeeds */ apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { - const category = (args[0] as Utils.IntegerHolder); + const category = (args[0] as Utils.NumberHolder); if (user.getAlly() === target) { category.value = MoveCategory.STATUS; @@ -3974,18 +4567,17 @@ export class StatusCategoryOnAllyAttr extends VariableMoveCategoryAttr { export class ShellSideArmCategoryAttr extends VariableMoveCategoryAttr { apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { const category = (args[0] as Utils.NumberHolder); - const atkRatio = user.getEffectiveStat(Stat.ATK, target, move) / target.getEffectiveStat(Stat.DEF, user, move); - const specialRatio = user.getEffectiveStat(Stat.SPATK, target, move) / target.getEffectiveStat(Stat.SPDEF, user, move); - // Shell Side Arm is much more complicated than it looks, this is a partial implementation to try to achieve something similar to the games - if (atkRatio > specialRatio) { + const predictedPhysDmg = target.getBaseDamage(user, move, MoveCategory.PHYSICAL, true, true); + const predictedSpecDmg = target.getBaseDamage(user, move, MoveCategory.SPECIAL, true, true); + + if (predictedPhysDmg > predictedSpecDmg) { category.value = MoveCategory.PHYSICAL; return true; - } else if (atkRatio === specialRatio && user.randSeedInt(2) === 0) { + } else if (predictedPhysDmg === predictedSpecDmg && user.randSeedInt(2) === 0) { category.value = MoveCategory.PHYSICAL; return true; } - return false; } } @@ -3996,6 +4588,30 @@ export class VariableMoveTypeAttr extends MoveAttr { } } +/** + * Attribute used for Tera Starstorm that changes the move type to Stellar + * @extends VariableMoveTypeAttr + */ +export class TeraStarstormTypeAttr extends VariableMoveTypeAttr { + /** + * + * @param user the {@linkcode Pokemon} using the move + * @param target n/a + * @param move n/a + * @param args[0] {@linkcode Utils.NumberHolder} the move type + * @returns `true` if the move type is changed to {@linkcode Type.STELLAR}, `false` otherwise + */ + override apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { + if (user.isTerastallized() && (user.hasFusionSpecies(Species.TERAPAGOS) || user.species.speciesId === Species.TERAPAGOS)) { + const moveType = args[0] as Utils.NumberHolder; + + moveType.value = Type.STELLAR; + return true; + } + return false; + } +} + export class FormChangeItemTypeAttr extends VariableMoveTypeAttr { apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { const moveType = args[0]; @@ -4003,8 +4619,8 @@ export class FormChangeItemTypeAttr extends VariableMoveTypeAttr { return false; } - if ([user.species.speciesId, user.fusionSpecies?.speciesId].includes(Species.ARCEUS) || [user.species.speciesId, user.fusionSpecies?.speciesId].includes(Species.SILVALLY)) { - const form = user.species.speciesId === Species.ARCEUS || user.species.speciesId === Species.SILVALLY ? user.formIndex : user.fusionSpecies?.formIndex!; // TODO: is this bang correct? + if ([ user.species.speciesId, user.fusionSpecies?.speciesId ].includes(Species.ARCEUS) || [ user.species.speciesId, user.fusionSpecies?.speciesId ].includes(Species.SILVALLY)) { + const form = user.species.speciesId === Species.ARCEUS || user.species.speciesId === Species.SILVALLY ? user.formIndex : user.fusionSpecies?.formIndex!; moveType.value = Type[Type[form]]; return true; @@ -4021,25 +4637,25 @@ export class TechnoBlastTypeAttr extends VariableMoveTypeAttr { return false; } - if ([user.species.speciesId, user.fusionSpecies?.speciesId].includes(Species.GENESECT)) { + if ([ user.species.speciesId, user.fusionSpecies?.speciesId ].includes(Species.GENESECT)) { const form = user.species.speciesId === Species.GENESECT ? user.formIndex : user.fusionSpecies?.formIndex; switch (form) { - case 1: // Shock Drive - moveType.value = Type.ELECTRIC; - break; - case 2: // Burn Drive - moveType.value = Type.FIRE; - break; - case 3: // Chill Drive - moveType.value = Type.ICE; - break; - case 4: // Douse Drive - moveType.value = Type.WATER; - break; - default: - moveType.value = Type.NORMAL; - break; + case 1: // Shock Drive + moveType.value = Type.ELECTRIC; + break; + case 2: // Burn Drive + moveType.value = Type.FIRE; + break; + case 3: // Chill Drive + moveType.value = Type.ICE; + break; + case 4: // Douse Drive + moveType.value = Type.WATER; + break; + default: + moveType.value = Type.NORMAL; + break; } return true; } @@ -4055,16 +4671,16 @@ export class AuraWheelTypeAttr extends VariableMoveTypeAttr { return false; } - if ([user.species.speciesId, user.fusionSpecies?.speciesId].includes(Species.MORPEKO)) { + if ([ user.species.speciesId, user.fusionSpecies?.speciesId ].includes(Species.MORPEKO)) { const form = user.species.speciesId === Species.MORPEKO ? user.formIndex : user.fusionSpecies?.formIndex; switch (form) { - case 1: // Hangry Mode - moveType.value = Type.DARK; - break; - default: // Full Belly Mode - moveType.value = Type.ELECTRIC; - break; + case 1: // Hangry Mode + moveType.value = Type.DARK; + break; + default: // Full Belly Mode + moveType.value = Type.ELECTRIC; + break; } return true; } @@ -4080,19 +4696,19 @@ export class RagingBullTypeAttr extends VariableMoveTypeAttr { return false; } - if ([user.species.speciesId, user.fusionSpecies?.speciesId].includes(Species.PALDEA_TAUROS)) { + if ([ user.species.speciesId, user.fusionSpecies?.speciesId ].includes(Species.PALDEA_TAUROS)) { const form = user.species.speciesId === Species.PALDEA_TAUROS ? user.formIndex : user.fusionSpecies?.formIndex; switch (form) { - case 1: // Blaze breed - moveType.value = Type.FIRE; - break; - case 2: // Aqua breed - moveType.value = Type.WATER; - break; - default: - moveType.value = Type.FIGHTING; - break; + case 1: // Blaze breed + moveType.value = Type.FIRE; + break; + case 2: // Aqua breed + moveType.value = Type.WATER; + break; + default: + moveType.value = Type.FIGHTING; + break; } return true; } @@ -4108,26 +4724,26 @@ export class IvyCudgelTypeAttr extends VariableMoveTypeAttr { return false; } - if ([user.species.speciesId, user.fusionSpecies?.speciesId].includes(Species.OGERPON)) { + if ([ user.species.speciesId, user.fusionSpecies?.speciesId ].includes(Species.OGERPON)) { const form = user.species.speciesId === Species.OGERPON ? user.formIndex : user.fusionSpecies?.formIndex; switch (form) { - case 1: // Wellspring Mask - case 5: // Wellspring Mask Tera - moveType.value = Type.WATER; - break; - case 2: // Hearthflame Mask - case 6: // Hearthflame Mask Tera - moveType.value = Type.FIRE; - break; - case 3: // Cornerstone Mask - case 7: // Cornerstone Mask Tera - moveType.value = Type.ROCK; - break; - case 4: // Teal Mask Tera - default: - moveType.value = Type.GRASS; - break; + case 1: // Wellspring Mask + case 5: // Wellspring Mask Tera + moveType.value = Type.WATER; + break; + case 2: // Hearthflame Mask + case 6: // Hearthflame Mask Tera + moveType.value = Type.FIRE; + break; + case 3: // Cornerstone Mask + case 7: // Cornerstone Mask Tera + moveType.value = Type.ROCK; + break; + case 4: // Teal Mask Tera + default: + moveType.value = Type.GRASS; + break; } return true; } @@ -4145,23 +4761,23 @@ export class WeatherBallTypeAttr extends VariableMoveTypeAttr { if (!user.scene.arena.weather?.isEffectSuppressed(user.scene)) { switch (user.scene.arena.weather?.weatherType) { - case WeatherType.SUNNY: - case WeatherType.HARSH_SUN: - moveType.value = Type.FIRE; - break; - case WeatherType.RAIN: - case WeatherType.HEAVY_RAIN: - moveType.value = Type.WATER; - break; - case WeatherType.SANDSTORM: - moveType.value = Type.ROCK; - break; - case WeatherType.HAIL: - case WeatherType.SNOW: - moveType.value = Type.ICE; - break; - default: - return false; + case WeatherType.SUNNY: + case WeatherType.HARSH_SUN: + moveType.value = Type.FIRE; + break; + case WeatherType.RAIN: + case WeatherType.HEAVY_RAIN: + moveType.value = Type.WATER; + break; + case WeatherType.SANDSTORM: + moveType.value = Type.ROCK; + break; + case WeatherType.HAIL: + case WeatherType.SNOW: + moveType.value = Type.ICE; + break; + default: + return false; } return true; } @@ -4196,20 +4812,20 @@ export class TerrainPulseTypeAttr extends VariableMoveTypeAttr { const currentTerrain = user.scene.arena.getTerrainType(); switch (currentTerrain) { - case TerrainType.MISTY: - moveType.value = Type.FAIRY; - break; - case TerrainType.ELECTRIC: - moveType.value = Type.ELECTRIC; - break; - case TerrainType.GRASSY: - moveType.value = Type.GRASS; - break; - case TerrainType.PSYCHIC: - moveType.value = Type.PSYCHIC; - break; - default: - return false; + case TerrainType.MISTY: + moveType.value = Type.FAIRY; + break; + case TerrainType.ELECTRIC: + moveType.value = Type.ELECTRIC; + break; + case TerrainType.GRASSY: + moveType.value = Type.GRASS; + break; + case TerrainType.PSYCHIC: + moveType.value = Type.PSYCHIC; + break; + default: + return false; } return true; } @@ -4227,17 +4843,17 @@ export class HiddenPowerTypeAttr extends VariableMoveTypeAttr { } const iv_val = Math.floor(((user.ivs[Stat.HP] & 1) - +(user.ivs[Stat.ATK] & 1) * 2 - +(user.ivs[Stat.DEF] & 1) * 4 - +(user.ivs[Stat.SPD] & 1) * 8 - +(user.ivs[Stat.SPATK] & 1) * 16 - +(user.ivs[Stat.SPDEF] & 1) * 32) * 15/63); + + (user.ivs[Stat.ATK] & 1) * 2 + + (user.ivs[Stat.DEF] & 1) * 4 + + (user.ivs[Stat.SPD] & 1) * 8 + + (user.ivs[Stat.SPATK] & 1) * 16 + + (user.ivs[Stat.SPDEF] & 1) * 32) * 15 / 63); moveType.value = [ Type.FIGHTING, Type.FLYING, Type.POISON, Type.GROUND, Type.ROCK, Type.BUG, Type.GHOST, Type.STEEL, Type.FIRE, Type.WATER, Type.GRASS, Type.ELECTRIC, - Type.PSYCHIC, Type.ICE, Type.DRAGON, Type.DARK][iv_val]; + Type.PSYCHIC, Type.ICE, Type.DRAGON, Type.DARK ][iv_val]; return true; } @@ -4292,6 +4908,47 @@ export class MatchUserTypeAttr extends VariableMoveTypeAttr { } } +/** + * Changes the type of a Pledge move based on the Pledge move combined with it. + * @extends VariableMoveTypeAttr + */ +export class CombinedPledgeTypeAttr extends VariableMoveTypeAttr { + override apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { + const moveType = args[0]; + if (!(moveType instanceof Utils.NumberHolder)) { + return false; + } + + const combinedPledgeMove = user.turnData.combiningPledge; + if (!combinedPledgeMove) { + return false; + } + + switch (move.id) { + case Moves.FIRE_PLEDGE: + if (combinedPledgeMove === Moves.WATER_PLEDGE) { + moveType.value = Type.WATER; + return true; + } + return false; + case Moves.WATER_PLEDGE: + if (combinedPledgeMove === Moves.GRASS_PLEDGE) { + moveType.value = Type.GRASS; + return true; + } + return false; + case Moves.GRASS_PLEDGE: + if (combinedPledgeMove === Moves.FIRE_PLEDGE) { + moveType.value = Type.FIRE; + return true; + } + return false; + default: + return false; + } + } +} + export class VariableMoveTypeMultiplierAttr extends MoveAttr { apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { return false; @@ -4313,37 +4970,22 @@ export class NeutralDamageAgainstFlyingTypeMultiplierAttr extends VariableMoveTy } } -export class WaterSuperEffectTypeMultiplierAttr extends VariableMoveTypeMultiplierAttr { - apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { - const multiplier = args[0] as Utils.NumberHolder; - if (target.isOfType(Type.WATER)) { - const effectivenessAgainstWater = new Utils.NumberHolder(getTypeDamageMultiplier(move.type, Type.WATER)); - applyChallenges(user.scene.gameMode, ChallengeType.TYPE_EFFECTIVENESS, effectivenessAgainstWater); - if (effectivenessAgainstWater.value !== 0) { - multiplier.value *= 2 / effectivenessAgainstWater.value; - return true; - } - } - - return false; - } -} - export class IceNoEffectTypeAttr extends VariableMoveTypeMultiplierAttr { /** * Checks to see if the Target is Ice-Type or not. If so, the move will have no effect. - * @param {Pokemon} user N/A - * @param {Pokemon} target Pokemon that is being checked whether Ice-Type or not. - * @param {Move} move N/A - * @param {any[]} args Sets to false if the target is Ice-Type, so it should do no damage/no effect. - * @returns {boolean} Returns true if move is successful, false if Ice-Type. + * @param user n/a + * @param target The {@linkcode Pokemon} targeted by the move + * @param move n/a + * @param args `[0]` a {@linkcode Utils.NumberHolder | NumberHolder} containing a type effectiveness multiplier + * @returns `true` if this Ice-type immunity applies; `false` otherwise */ apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { + const multiplier = args[0] as Utils.NumberHolder; if (target.isOfType(Type.ICE)) { - (args[0] as Utils.BooleanHolder).value = false; - return false; + multiplier.value = 0; + return true; } - return true; + return false; } } @@ -4355,6 +4997,41 @@ export class FlyingTypeMultiplierAttr extends VariableMoveTypeMultiplierAttr { } } +/** + * Attribute for moves which have a custom type chart interaction. + */ +export class VariableMoveTypeChartAttr extends MoveAttr { + /** + * @param user {@linkcode Pokemon} using the move + * @param target {@linkcode Pokemon} target of the move + * @param move {@linkcode Move} with this attribute + * @param args [0] {@linkcode NumberHolder} holding the type effectiveness + * @param args [1] A single defensive type of the target + * + * @returns true if application of the attribute succeeds + */ + apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { + return false; + } +} + +/** + * This class forces Freeze-Dry to be super effective against Water Type. + */ +export class FreezeDryAttr extends VariableMoveTypeChartAttr { + apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { + const multiplier = args[0] as Utils.NumberHolder; + const defType = args[1] as Type; + + if (defType === Type.WATER) { + multiplier.value = 2; + return true; + } else { + return false; + } + } +} + export class OneHitKOAccuracyAttr extends VariableAccuracyAttr { apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { const accuracy = args[0] as Utils.NumberHolder; @@ -4428,7 +5105,7 @@ const crashDamageFunc = (user: Pokemon, move: Move) => { } user.damageAndUpdate(Utils.toDmgValue(user.getMaxHp() / 2), HitResult.OTHER, false, true); - user.scene.queueMessage(i18next.t("moveTriggers:keptGoingAndCrashed", {pokemonName: getPokemonNameWithAffix(user)})); + user.scene.queueMessage(i18next.t("moveTriggers:keptGoingAndCrashed", { pokemonName: getPokemonNameWithAffix(user) })); user.turnData.damageTaken += Utils.toDmgValue(user.getMaxHp() / 2); return true; @@ -4439,11 +5116,19 @@ export class TypelessAttr extends MoveAttr { } * Attribute used for moves which ignore redirection effects, and always target their original target, i.e. Snipe Shot * Bypasses Storm Drain, Follow Me, Ally Switch, and the like. */ -export class BypassRedirectAttr extends MoveAttr { } +export class BypassRedirectAttr extends MoveAttr { + /** `true` if this move only bypasses redirection from Abilities */ + public readonly abilitiesOnly: boolean; + + constructor(abilitiesOnly: boolean = false) { + super(); + this.abilitiesOnly = abilitiesOnly; + } +} export class FrenzyAttr extends MoveEffectAttr { constructor() { - super(true, MoveEffectTrigger.HIT, false, true); + super(true, { trigger: MoveEffectTrigger.HIT, lastHitOnly: true }); } canApply(user: Pokemon, target: Pokemon, move: Move, args: any[]) { @@ -4477,6 +5162,37 @@ export const frenzyMissFunc: UserMoveConditionFunc = (user: Pokemon, move: Move) return true; }; +/** + * Attribute that grants {@link https://bulbapedia.bulbagarden.net/wiki/Semi-invulnerable_turn | semi-invulnerability} to the user during + * the associated move's charging phase. Should only be used for {@linkcode ChargingMove | ChargingMoves} as a `chargeAttr`. + * @extends MoveEffectAttr + */ +export class SemiInvulnerableAttr extends MoveEffectAttr { + /** The type of {@linkcode SemiInvulnerableTag} to grant to the user */ + public tagType: BattlerTagType; + + constructor(tagType: BattlerTagType) { + super(true); + this.tagType = tagType; + } + + /** + * Grants a {@linkcode SemiInvulnerableTag} to the associated move's user. + * @param user the {@linkcode Pokemon} using the move + * @param target n/a + * @param move the {@linkcode Move} being used + * @param args n/a + * @returns `true` if semi-invulnerability was successfully granted; `false` otherwise. + */ + override apply(user: Pokemon, target: Pokemon, move: Move, args?: any[]): boolean { + if (!super.apply(user, target, move, args)) { + return false; + } + + return user.addTag(this.tagType, 1, move.id, user.id); + } +} + export class AddBattlerTagAttr extends MoveEffectAttr { public tagType: BattlerTagType; public turnCountMin: integer; @@ -4485,7 +5201,7 @@ export class AddBattlerTagAttr extends MoveEffectAttr { private failOnOverlap: boolean; constructor(tagType: BattlerTagType, selfTarget: boolean = false, failOnOverlap: boolean = false, turnCountMin: integer = 0, turnCountMax?: integer, lastHitOnly: boolean = false, cancelOnFail: boolean = false) { - super(selfTarget, MoveEffectTrigger.POST_APPLY, false, lastHitOnly); + super(selfTarget, { lastHitOnly: lastHitOnly }); this.tagType = tagType; this.turnCountMin = turnCountMin; @@ -4495,7 +5211,7 @@ export class AddBattlerTagAttr extends MoveEffectAttr { } canApply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { - if (!super.canApply(user, target, move, args) || (this.cancelOnFail === true && user.getLastXMoves(1)[0].result === MoveResult.FAIL)) { + if (!super.canApply(user, target, move, args) || (this.cancelOnFail === true && user.getLastXMoves(1)[0]?.result === MoveResult.FAIL)) { return false; } else { return true; @@ -4523,45 +5239,48 @@ export class AddBattlerTagAttr extends MoveEffectAttr { getTagTargetBenefitScore(user: Pokemon, target: Pokemon, move: Move): integer | void { switch (this.tagType) { - case BattlerTagType.RECHARGING: - case BattlerTagType.PERISH_SONG: - return -16; - case BattlerTagType.FLINCHED: - case BattlerTagType.CONFUSED: - case BattlerTagType.INFATUATED: - case BattlerTagType.NIGHTMARE: - case BattlerTagType.DROWSY: - case BattlerTagType.DISABLED: - return -5; - case BattlerTagType.SEEDED: - case BattlerTagType.SALT_CURED: - case BattlerTagType.CURSED: - case BattlerTagType.FRENZY: - case BattlerTagType.TRAPPED: - case BattlerTagType.BIND: - case BattlerTagType.WRAP: - case BattlerTagType.FIRE_SPIN: - case BattlerTagType.WHIRLPOOL: - case BattlerTagType.CLAMP: - case BattlerTagType.SAND_TOMB: - case BattlerTagType.MAGMA_STORM: - case BattlerTagType.SNAP_TRAP: - case BattlerTagType.THUNDER_CAGE: - case BattlerTagType.INFESTATION: - return -3; - case BattlerTagType.ENCORE: - return -2; - case BattlerTagType.MINIMIZED: - return 0; - case BattlerTagType.INGRAIN: - case BattlerTagType.IGNORE_ACCURACY: - case BattlerTagType.AQUA_RING: - return 3; - case BattlerTagType.PROTECTED: - case BattlerTagType.FLYING: - case BattlerTagType.CRIT_BOOST: - case BattlerTagType.ALWAYS_CRIT: - return 5; + case BattlerTagType.RECHARGING: + case BattlerTagType.PERISH_SONG: + return -16; + case BattlerTagType.FLINCHED: + case BattlerTagType.CONFUSED: + case BattlerTagType.INFATUATED: + case BattlerTagType.NIGHTMARE: + case BattlerTagType.DROWSY: + case BattlerTagType.DISABLED: + case BattlerTagType.HEAL_BLOCK: + case BattlerTagType.RECEIVE_DOUBLE_DAMAGE: + return -5; + case BattlerTagType.SEEDED: + case BattlerTagType.SALT_CURED: + case BattlerTagType.CURSED: + case BattlerTagType.FRENZY: + case BattlerTagType.TRAPPED: + case BattlerTagType.BIND: + case BattlerTagType.WRAP: + case BattlerTagType.FIRE_SPIN: + case BattlerTagType.WHIRLPOOL: + case BattlerTagType.CLAMP: + case BattlerTagType.SAND_TOMB: + case BattlerTagType.MAGMA_STORM: + case BattlerTagType.SNAP_TRAP: + case BattlerTagType.THUNDER_CAGE: + case BattlerTagType.INFESTATION: + return -3; + case BattlerTagType.ENCORE: + return -2; + case BattlerTagType.MINIMIZED: + case BattlerTagType.ALWAYS_GET_HIT: + return 0; + case BattlerTagType.INGRAIN: + case BattlerTagType.IGNORE_ACCURACY: + case BattlerTagType.AQUA_RING: + return 3; + case BattlerTagType.PROTECTED: + case BattlerTagType.FLYING: + case BattlerTagType.CRIT_BOOST: + case BattlerTagType.ALWAYS_CRIT: + return 5; } } @@ -4574,6 +5293,30 @@ export class AddBattlerTagAttr extends MoveEffectAttr { } } +/** + * Adds a {@link https://bulbapedia.bulbagarden.net/wiki/Seeding | Seeding} effect to the target + * as seen with Leech Seed and Sappy Seed. + * @extends AddBattlerTagAttr + */ +export class LeechSeedAttr extends AddBattlerTagAttr { + constructor() { + super(BattlerTagType.SEEDED); + } + + /** + * Adds a Seeding effect to the target if the target does not have an active Substitute. + * @param user the {@linkcode Pokemon} using the move + * @param target the {@linkcode Pokemon} targeted by the move + * @param move the {@linkcode Move} invoking this effect + * @param args n/a + * @returns `true` if the effect successfully applies; `false` otherwise + */ + apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { + return !move.hitsSubstitute(user, target) + && super.apply(user, target, move, args); + } +} + /** * Adds the appropriate battler tag for Gulp Missile when Surf or Dive is used. * @extends MoveEffectAttr @@ -4585,14 +5328,14 @@ export class GulpMissileTagAttr extends MoveEffectAttr { /** * Adds BattlerTagType from GulpMissileTag based on the Pokemon's HP ratio. - * @param {Pokemon} user The Pokemon using the move. - * @param {Pokemon} target The Pokemon being targeted by the move. - * @param {Move} move The move being used. - * @param {any[]} args Additional arguments, if any. + * @param user The Pokemon using the move. + * @param _target N/A + * @param move The move being used. + * @param _args N/A * @returns Whether the BattlerTag is applied. */ - apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean | Promise { - if (!super.apply(user, target, move, args)) { + apply(user: Pokemon, _target: Pokemon, move: Move, _args: any[]): boolean { + if (!super.apply(user, _target, move, _args)) { return false; } @@ -4667,7 +5410,7 @@ export class CurseAttr extends MoveEffectAttr { target.addTag(BattlerTagType.CURSED, 0, move.id, user.id); return true; } else { - user.scene.unshiftPhase(new StatStageChangePhase(user.scene, user.getBattlerIndex(), true, [ Stat.ATK, Stat.DEF], 1)); + user.scene.unshiftPhase(new StatStageChangePhase(user.scene, user.getBattlerIndex(), true, [ Stat.ATK, Stat.DEF ], 1)); user.scene.unshiftPhase(new StatStageChangePhase(user.scene, user.getBattlerIndex(), true, [ Stat.SPD ], -1)); return true; } @@ -4737,9 +5480,9 @@ export class ConfuseAttr extends AddBattlerTagAttr { } apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { - if (!this.selfTarget && target.scene.arena.getTagOnSide(ArenaTagType.SAFEGUARD, target.isPlayer() ? ArenaTagSide.PLAYER : ArenaTagSide.ENEMY)) { + if (!this.selfTarget && target.isSafeguarded(user)) { if (move.category === MoveCategory.STATUS) { - user.scene.queueMessage(i18next.t("moveTriggers:safeguard", { targetName: getPokemonNameWithAffix(target)})); + user.scene.queueMessage(i18next.t("moveTriggers:safeguard", { targetName: getPokemonNameWithAffix(target) })); } return false; } @@ -4799,7 +5542,7 @@ export class IgnoreAccuracyAttr extends AddBattlerTagAttr { return false; } - user.scene.queueMessage(i18next.t("moveTriggers:tookAimAtTarget", {pokemonName: getPokemonNameWithAffix(user), targetName: getPokemonNameWithAffix(target)})); + user.scene.queueMessage(i18next.t("moveTriggers:tookAimAtTarget", { pokemonName: getPokemonNameWithAffix(user), targetName: getPokemonNameWithAffix(target) })); return true; } @@ -4815,7 +5558,7 @@ export class FaintCountdownAttr extends AddBattlerTagAttr { return false; } - user.scene.queueMessage(i18next.t("moveTriggers:faintCountdown", {pokemonName: getPokemonNameWithAffix(target), turnCount: this.turnCountMin - 1})); + user.scene.queueMessage(i18next.t("moveTriggers:faintCountdown", { pokemonName: getPokemonNameWithAffix(target), turnCount: this.turnCountMin - 1 })); return true; } @@ -4852,16 +5595,18 @@ export class RemoveAllSubstitutesAttr extends MoveEffectAttr { } /** - * Attribute used when a move hits a {@linkcode BattlerTagType} for double damage + * Attribute used when a move can deal damage to {@linkcode BattlerTagType} + * Moves that always hit but do not deal double damage: Thunder, Fissure, Sky Uppercut, + * Smack Down, Hurricane, Thousand Arrows * @extends MoveAttr */ -export class DealsDoubleDamageToTagAttr extends MoveAttr { +export class HitsTagAttr extends MoveAttr { /** The {@linkcode BattlerTagType} this move hits */ public tagType: BattlerTagType; - /** Should this move deal double damage against {@linkcode DealsDoubleDamageToTagAttr.tagType}? */ + /** Should this move deal double damage against {@linkcode HitsTagAttr.tagType}? */ public doubleDamage: boolean; - constructor(tagType: BattlerTagType, doubleDamage?: boolean) { + constructor(tagType: BattlerTagType, doubleDamage: boolean = false) { super(); this.tagType = tagType; @@ -4873,6 +5618,17 @@ export class DealsDoubleDamageToTagAttr extends MoveAttr { } } +/** + * Used for moves that will always hit for a given tag but also doubles damage. + * Moves include: Gust, Stomp, Body Slam, Surf, Earthquake, Magnitude, Twister, + * Whirlpool, Dragon Rush, Heat Crash, Steam Roller, Flying Press + */ +export class HitsTagForDoubleDamageAttr extends HitsTagAttr { + constructor(tagType: BattlerTagType) { + super(tagType, true); + } +} + export class AddArenaTagAttr extends MoveEffectAttr { public tagType: ArenaTagType; public turnCount: integer; @@ -4880,7 +5636,7 @@ export class AddArenaTagAttr extends MoveEffectAttr { public selfSideTarget: boolean; constructor(tagType: ArenaTagType, turnCount?: integer | null, failOnOverlap: boolean = false, selfSideTarget: boolean = false) { - super(true, MoveEffectTrigger.POST_APPLY); + super(true); this.tagType = tagType; this.turnCount = turnCount!; // TODO: is the bang correct? @@ -4893,8 +5649,9 @@ export class AddArenaTagAttr extends MoveEffectAttr { return false; } - if ((move.chance < 0 || move.chance === 100 || user.randSeedInt(100) < move.chance) && user.getLastXMoves(1)[0].result === MoveResult.SUCCESS) { - user.scene.arena.addTag(this.tagType, this.turnCount, move.id, user.id, (this.selfSideTarget ? user : target).isPlayer() ? ArenaTagSide.PLAYER : ArenaTagSide.ENEMY); + if ((move.chance < 0 || move.chance === 100 || user.randSeedInt(100) < move.chance) && user.getLastXMoves(1)[0]?.result === MoveResult.SUCCESS) { + const side = (this.selfSideTarget ? user : target).isPlayer() ? ArenaTagSide.PLAYER : ArenaTagSide.ENEMY; + user.scene.arena.addTag(this.tagType, this.turnCount, move.id, user.id, side); return true; } @@ -4918,7 +5675,7 @@ export class RemoveArenaTagsAttr extends MoveEffectAttr { public selfSideTarget: boolean; constructor(tagTypes: ArenaTagType[], selfSideTarget: boolean) { - super(true, MoveEffectTrigger.POST_APPLY); + super(true); this.tagTypes = tagTypes; this.selfSideTarget = selfSideTarget; @@ -4968,7 +5725,7 @@ export class AddArenaTrapTagHitAttr extends AddArenaTagAttr { const moveChance = this.getMoveChance(user, target, move, this.selfTarget, true); const side = (this.selfSideTarget ? user : target).isPlayer() ? ArenaTagSide.PLAYER : ArenaTagSide.ENEMY; const tag = user.scene.arena.getTagOnSide(this.tagType, side) as ArenaTrapTag; - if ((moveChance < 0 || moveChance === 100 || user.randSeedInt(100) < moveChance) && user.getLastXMoves(1)[0].result === MoveResult.SUCCESS) { + if ((moveChance < 0 || moveChance === 100 || user.randSeedInt(100) < moveChance) && user.getLastXMoves(1)[0]?.result === MoveResult.SUCCESS) { user.scene.arena.addTag(this.tagType, 0, move.id, user.id, side); if (!tag) { return true; @@ -4984,7 +5741,7 @@ export class RemoveArenaTrapAttr extends MoveEffectAttr { private targetBothSides: boolean; constructor(targetBothSides: boolean = false) { - super(true, MoveEffectTrigger.PRE_APPLY); + super(true, { trigger: MoveEffectTrigger.PRE_APPLY }); this.targetBothSides = targetBothSides; } @@ -5020,7 +5777,7 @@ export class RemoveScreensAttr extends MoveEffectAttr { private targetBothSides: boolean; constructor(targetBothSides: boolean = false) { - super(true, MoveEffectTrigger.PRE_APPLY); + super(true, { trigger: MoveEffectTrigger.PRE_APPLY }); this.targetBothSides = targetBothSides; } @@ -5058,7 +5815,7 @@ export class SwapArenaTagsAttr extends MoveEffectAttr { constructor(SwapTags: ArenaTagType[]) { - super(true, MoveEffectTrigger.POST_APPLY); + super(true); this.SwapTags = SwapTags; } @@ -5085,11 +5842,37 @@ export class SwapArenaTagsAttr extends MoveEffectAttr { } - user.scene.queueMessage(i18next.t("moveTriggers:swapArenaTags", {pokemonName: getPokemonNameWithAffix(user)})); + user.scene.queueMessage(i18next.t("moveTriggers:swapArenaTags", { pokemonName: getPokemonNameWithAffix(user) })); return true; } } +/** + * Attribute that adds a secondary effect to the field when two unique Pledge moves + * are combined. The effect added varies based on the two Pledge moves combined. + */ +export class AddPledgeEffectAttr extends AddArenaTagAttr { + private readonly requiredPledge: Moves; + + constructor(tagType: ArenaTagType, requiredPledge: Moves, selfSideTarget: boolean = false) { + super(tagType, 4, false, selfSideTarget); + + this.requiredPledge = requiredPledge; + } + + override apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { + // TODO: add support for `HIT` effect triggering in AddArenaTagAttr to remove the need for this check + if (user.getLastXMoves(1)[0]?.result !== MoveResult.SUCCESS) { + return false; + } + + if (user.turnData.combiningPledge === this.requiredPledge) { + return super.apply(user, target, move, args); + } + return false; + } +} + /** * Attribute used for Revival Blessing. * @extends MoveEffectAttr @@ -5112,7 +5895,7 @@ export class RevivalBlessingAttr extends MoveEffectAttr { return new Promise(resolve => { // If user is player, checks if the user has fainted pokemon if (user instanceof PlayerPokemon - && user.scene.getParty().findIndex(p => p.isFainted())>-1) { + && user.scene.getPlayerParty().findIndex(p => p.isFainted()) > -1) { (user as PlayerPokemon).revivalBlessing().then(() => { resolve(true); }); @@ -5126,14 +5909,14 @@ export class RevivalBlessingAttr extends MoveEffectAttr { const slotIndex = user.scene.getEnemyParty().findIndex(p => pokemon.id === p.id); pokemon.resetStatus(); pokemon.heal(Math.min(Utils.toDmgValue(0.5 * pokemon.getMaxHp()), pokemon.getMaxHp())); - user.scene.queueMessage(i18next.t("moveTriggers:revivalBlessing", {pokemonName: getPokemonNameWithAffix(pokemon)}), 0, true); + user.scene.queueMessage(i18next.t("moveTriggers:revivalBlessing", { pokemonName: getPokemonNameWithAffix(pokemon) }), 0, true); if (user.scene.currentBattle.double && user.scene.getEnemyParty().length > 1) { const allyPokemon = user.getAlly(); - if (slotIndex<=1) { - user.scene.unshiftPhase(new SwitchSummonPhase(user.scene, pokemon.getFieldIndex(), slotIndex, false, false, false)); + if (slotIndex <= 1) { + user.scene.unshiftPhase(new SwitchSummonPhase(user.scene, SwitchType.SWITCH, pokemon.getFieldIndex(), slotIndex, false, false)); } else if (allyPokemon.isFainted()) { - user.scene.unshiftPhase(new SwitchSummonPhase(user.scene, allyPokemon.getFieldIndex(), slotIndex, false, false, false)); + user.scene.unshiftPhase(new SwitchSummonPhase(user.scene, SwitchType.SWITCH, allyPokemon.getFieldIndex(), slotIndex, false, false)); } } resolve(true); @@ -5153,76 +5936,112 @@ export class RevivalBlessingAttr extends MoveEffectAttr { } } -export class ForceSwitchOutAttr extends MoveEffectAttr { - private user: boolean; - private batonPass: boolean; - constructor(user?: boolean, batonPass?: boolean) { - super(false, MoveEffectTrigger.POST_APPLY, false, true); - this.user = !!user; - this.batonPass = !!batonPass; +export class ForceSwitchOutAttr extends MoveEffectAttr { + constructor( + private selfSwitch: boolean = false, + private switchType: SwitchType = SwitchType.SWITCH + ) { + super(false, { lastHitOnly: true }); } isBatonPass() { - return this.batonPass; + return this.switchType === SwitchType.BATON_PASS; } - apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): Promise { - return new Promise(resolve => { + apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { + // Check if the move category is not STATUS or if the switch out condition is not met + if (!this.getSwitchOutCondition()(user, target, move)) { + return false; + } - // Check if the move category is not STATUS or if the switch out condition is not met - if (!this.getSwitchOutCondition()(user, target, move)) { - return resolve(false); + /** The {@linkcode Pokemon} to be switched out with this effect */ + const switchOutTarget = this.selfSwitch ? user : target; + + // If the switch-out target is a Dondozo with a Tatsugiri in its mouth + // (e.g. when it uses Flip Turn), make it spit out the Tatsugiri before switching out. + switchOutTarget.lapseTag(BattlerTagType.COMMANDED); + + if (switchOutTarget instanceof PlayerPokemon) { + /** + * Check if Wimp Out/Emergency Exit activates due to being hit by U-turn or Volt Switch + * If it did, the user of U-turn or Volt Switch will not be switched out. + */ + if (target.getAbility().hasAttr(PostDamageForceSwitchAbAttr) && + (move.id === Moves.U_TURN || move.id === Moves.VOLT_SWITCH || move.id === Moves.FLIP_TURN) + ) { + if (this.hpDroppedBelowHalf(target)) { + return false; + } + } + // Switch out logic for the player's Pokemon + if (switchOutTarget.scene.getPlayerParty().filter((p) => p.isAllowedInBattle() && !p.isOnField()).length < 1) { + return false; } - // Move the switch out logic inside the conditional block - // This ensures that the switch out only happens when the conditions are met - const switchOutTarget = this.user ? user : target; - if (switchOutTarget instanceof PlayerPokemon) { - switchOutTarget.leaveField(!this.batonPass); + if (switchOutTarget.hp > 0) { + switchOutTarget.leaveField(this.switchType === SwitchType.SWITCH); + user.scene.prependToPhase(new SwitchPhase(user.scene, this.switchType, switchOutTarget.getFieldIndex(), true, true), MoveEndPhase); + return true; + } + return false; + } else if (user.scene.currentBattle.battleType !== BattleType.WILD) { + // Switch out logic for trainer battles + if (switchOutTarget.scene.getEnemyParty().filter((p) => p.isAllowedInBattle() && !p.isOnField()).length < 1) { + return false; + } - if (switchOutTarget.hp > 0) { - user.scene.prependToPhase(new SwitchPhase(user.scene, switchOutTarget.getFieldIndex(), true, true), MoveEndPhase); - resolve(true); - } else { - resolve(false); - } - return; - } else if (user.scene.currentBattle.battleType !== BattleType.WILD) { - // Switch out logic for trainer battles - switchOutTarget.leaveField(!this.batonPass); - - if (switchOutTarget.hp > 0) { + if (switchOutTarget.hp > 0) { // for opponent switching out - user.scene.prependToPhase(new SwitchSummonPhase(user.scene, switchOutTarget.getFieldIndex(), (user.scene.currentBattle.trainer ? user.scene.currentBattle.trainer.getNextSummonIndex((switchOutTarget as EnemyPokemon).trainerSlot) : 0), false, this.batonPass, false), MoveEndPhase); + switchOutTarget.leaveField(this.switchType === SwitchType.SWITCH); + user.scene.prependToPhase(new SwitchSummonPhase(user.scene, this.switchType, switchOutTarget.getFieldIndex(), + (user.scene.currentBattle.trainer ? user.scene.currentBattle.trainer.getNextSummonIndex((switchOutTarget as EnemyPokemon).trainerSlot) : 0), + false, false), MoveEndPhase); + } + } else { + /** + * Check if Wimp Out/Emergency Exit activates due to being hit by U-turn or Volt Switch + * If it did, the user of U-turn or Volt Switch will not be switched out. + */ + if (target.getAbility().hasAttr(PostDamageForceSwitchAbAttr) && + (move.id === Moves.U_TURN || move.id === Moves.VOLT_SWITCH) || move.id === Moves.FLIP_TURN) { + if (this.hpDroppedBelowHalf(target)) { + return false; } - } else { - // Switch out logic for everything else (eg: WILD battles) - switchOutTarget.leaveField(false); + } - if (switchOutTarget.hp) { - switchOutTarget.setWildFlee(true); - user.scene.queueMessage(i18next.t("moveTriggers:fled", {pokemonName: getPokemonNameWithAffix(switchOutTarget)}), null, true, 500); + // Switch out logic for everything else (eg: WILD battles) + if (user.scene.currentBattle.waveIndex % 10 === 0) { + return false; + } - // in double battles redirect potential moves off fled pokemon - if (switchOutTarget.scene.currentBattle.double) { - const allyPokemon = switchOutTarget.getAlly(); - switchOutTarget.scene.redirectPokemonMoves(switchOutTarget, allyPokemon); - } - } + // Don't allow wild mons to flee with U-turn et al + if (this.selfSwitch && !user.isPlayer() && move.category !== MoveCategory.STATUS) { + return false; + } - if (!switchOutTarget.getAlly()?.isActive(true)) { - user.scene.clearEnemyHeldItemModifiers(); + if (switchOutTarget.hp > 0) { + switchOutTarget.leaveField(false); + user.scene.queueMessage(i18next.t("moveTriggers:fled", { pokemonName: getPokemonNameWithAffix(switchOutTarget) }), null, true, 500); - if (switchOutTarget.hp) { - user.scene.pushPhase(new BattleEndPhase(user.scene)); - user.scene.pushPhase(new NewBattlePhase(user.scene)); - } - } - } + // in double battles redirect potential moves off fled pokemon + if (switchOutTarget.scene.currentBattle.double) { + const allyPokemon = switchOutTarget.getAlly(); + switchOutTarget.scene.redirectPokemonMoves(switchOutTarget, allyPokemon); + } + } - resolve(true); - }); + if (!switchOutTarget.getAlly()?.isActive(true)) { + user.scene.clearEnemyHeldItemModifiers(); + + if (switchOutTarget.hp) { + user.scene.pushPhase(new BattleEndPhase(user.scene)); + user.scene.pushPhase(new NewBattlePhase(user.scene)); + } + } + } + + return true; } getCondition(): MoveConditionFunc { @@ -5232,34 +6051,49 @@ export class ForceSwitchOutAttr extends MoveEffectAttr { getFailedText(user: Pokemon, target: Pokemon, move: Move, cancelled: Utils.BooleanHolder): string | null { const blockedByAbility = new Utils.BooleanHolder(false); applyAbAttrs(ForceSwitchOutImmunityAbAttr, target, blockedByAbility); - return blockedByAbility.value ? i18next.t("moveTriggers:cannotBeSwitchedOut", {pokemonName: getPokemonNameWithAffix(target)}) : null; + return blockedByAbility.value ? i18next.t("moveTriggers:cannotBeSwitchedOut", { pokemonName: getPokemonNameWithAffix(target) }) : null; } getSwitchOutCondition(): MoveConditionFunc { return (user, target, move) => { - const switchOutTarget = (this.user ? user : target); + const switchOutTarget = (this.selfSwitch ? user : target); const player = switchOutTarget instanceof PlayerPokemon; - if (!this.user && move.hitsSubstitute(user, target)) { - return false; + if (!this.selfSwitch) { + if (move.hitsSubstitute(user, target)) { + return false; + } + + // Dondozo with an allied Tatsugiri in its mouth cannot be forced out + const commandedTag = switchOutTarget.getTag(BattlerTagType.COMMANDED); + if (commandedTag?.getSourcePokemon(switchOutTarget.scene)?.isActive(true)) { + return false; + } + + if (!player && user.scene.currentBattle.isBattleMysteryEncounter() && !user.scene.currentBattle.mysteryEncounter?.fleeAllowed) { + // Don't allow wild opponents to be force switched during MEs with flee disabled + return false; + } + + const blockedByAbility = new Utils.BooleanHolder(false); + applyAbAttrs(ForceSwitchOutImmunityAbAttr, target, blockedByAbility); + return !blockedByAbility.value; } - if (!this.user && move.category === MoveCategory.STATUS && (target.hasAbilityWithAttr(ForceSwitchOutImmunityAbAttr))) { - return false; - } - - if (!player && !user.scene.currentBattle.battleType) { - if (this.batonPass) { + if (!player && user.scene.currentBattle.battleType === BattleType.WILD) { + if (this.isBatonPass()) { return false; } // Don't allow wild opponents to flee on the boss stage since it can ruin a run early on - if (!(user.scene.currentBattle.waveIndex % 10)) { + if (user.scene.currentBattle.waveIndex % 10 === 0) { return false; } } - const party = player ? user.scene.getParty() : user.scene.getEnemyParty(); - return (!player && !user.scene.currentBattle.battleType) || party.filter(p => p.isAllowedInBattle() && (player || (p as EnemyPokemon).trainerSlot === (switchOutTarget as EnemyPokemon).trainerSlot)).length > user.scene.currentBattle.getBattlerCount(); + const party = player ? user.scene.getPlayerParty() : user.scene.getEnemyParty(); + return (!player && !user.scene.currentBattle.battleType) + || party.filter(p => p.isAllowedInBattle() + && (player || (p as EnemyPokemon).trainerSlot === (switchOutTarget as EnemyPokemon).trainerSlot)).length > user.scene.currentBattle.getBattlerCount(); }; } @@ -5267,22 +6101,48 @@ export class ForceSwitchOutAttr extends MoveEffectAttr { if (!user.scene.getEnemyParty().find(p => p.isActive() && !p.isOnField())) { return -20; } - let ret = this.user ? Math.floor((1 - user.getHpRatio()) * 20) : super.getUserBenefitScore(user, target, move); - if (this.user && this.batonPass) { + let ret = this.selfSwitch ? Math.floor((1 - user.getHpRatio()) * 20) : super.getUserBenefitScore(user, target, move); + if (this.selfSwitch && this.isBatonPass()) { const statStageTotal = user.getStatStages().reduce((s: integer, total: integer) => total += s, 0); ret = ret / 2 + (Phaser.Tweens.Builders.GetEaseFunction("Sine.easeOut")(Math.min(Math.abs(statStageTotal), 10) / 10) * (statStageTotal >= 0 ? 10 : -10)); } return ret; } + + /** + * Helper function to check if the Pokémon's health is below half after taking damage. + * Used for an edge case interaction with Wimp Out/Emergency Exit. + * If the Ability activates due to being hit by U-turn or Volt Switch, the user of that move will not be switched out. + */ + hpDroppedBelowHalf(target: Pokemon): boolean { + const pokemonHealth = target.hp; + const maxPokemonHealth = target.getMaxHp(); + const damageTaken = target.turnData.damageTaken; + const initialHealth = pokemonHealth + damageTaken; + + // Check if the Pokémon's health has dropped below half after the damage + return initialHealth >= maxPokemonHealth / 2 && pokemonHealth < maxPokemonHealth / 2; + } } +export class ChillyReceptionAttr extends ForceSwitchOutAttr { + apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { + user.scene.arena.trySetWeather(WeatherType.SNOW, true); + return super.apply(user, target, move, args); + } + + getCondition(): MoveConditionFunc { + // chilly reception move will go through if the weather is change-able to snow, or the user can switch out, else move will fail + return (user, target, move) => user.scene.arena.weather?.weatherType !== WeatherType.SNOW || super.getSwitchOutCondition()(user, target, move); + } +} export class RemoveTypeAttr extends MoveEffectAttr { private removedType: Type; private messageCallback: ((user: Pokemon) => void) | undefined; constructor(removedType: Type, messageCallback?: (user: Pokemon) => void) { - super(true, MoveEffectTrigger.POST_TARGET); + super(true, { trigger: MoveEffectTrigger.POST_TARGET }); this.removedType = removedType; this.messageCallback = messageCallback; @@ -5299,6 +6159,9 @@ export class RemoveTypeAttr extends MoveEffectAttr { const userTypes = user.getTypes(true); const modifiedTypes = userTypes.filter(type => type !== this.removedType); + if (modifiedTypes.length === 0) { + modifiedTypes.push(Type.UNKNOWN); + } user.summonData.types = modifiedTypes; user.updateInfo(); @@ -5321,16 +6184,20 @@ export class CopyTypeAttr extends MoveEffectAttr { return false; } - user.summonData.types = target.getTypes(true); + const targetTypes = target.getTypes(true); + if (targetTypes.includes(Type.UNKNOWN) && targetTypes.indexOf(Type.UNKNOWN) > -1) { + targetTypes[targetTypes.indexOf(Type.UNKNOWN)] = Type.NORMAL; + } + user.summonData.types = targetTypes; user.updateInfo(); - user.scene.queueMessage(i18next.t("moveTriggers:copyType", {pokemonName: getPokemonNameWithAffix(user), targetPokemonName: getPokemonNameWithAffix(target)})); + user.scene.queueMessage(i18next.t("moveTriggers:copyType", { pokemonName: getPokemonNameWithAffix(user), targetPokemonName: getPokemonNameWithAffix(target) })); return true; } getCondition(): MoveConditionFunc { - return (user, target, move) => target.getTypes()[0] !== Type.UNKNOWN; + return (user, target, move) => target.getTypes()[0] !== Type.UNKNOWN || target.summonData.addedType !== null; } } @@ -5344,31 +6211,123 @@ export class CopyBiomeTypeAttr extends MoveEffectAttr { return false; } - const biomeType = user.scene.arena.getTypeForBiome(); + const terrainType = user.scene.arena.getTerrainType(); + let typeChange: Type; + if (terrainType !== TerrainType.NONE) { + typeChange = this.getTypeForTerrain(user.scene.arena.getTerrainType()); + } else { + typeChange = this.getTypeForBiome(user.scene.arena.biomeType); + } - user.summonData.types = [ biomeType ]; + user.summonData.types = [ typeChange ]; user.updateInfo(); - user.scene.queueMessage(i18next.t("moveTriggers:transformedIntoType", {pokemonName: getPokemonNameWithAffix(user), typeName: i18next.t(`pokemonInfo:Type.${Type[biomeType]}`)})); + user.scene.queueMessage(i18next.t("moveTriggers:transformedIntoType", { pokemonName: getPokemonNameWithAffix(user), typeName: i18next.t(`pokemonInfo:Type.${Type[typeChange]}`) })); return true; } + + /** + * Retrieves a type from the current terrain + * @param terrainType {@linkcode TerrainType} + * @returns {@linkcode Type} + */ + private getTypeForTerrain(terrainType: TerrainType): Type { + switch (terrainType) { + case TerrainType.ELECTRIC: + return Type.ELECTRIC; + case TerrainType.MISTY: + return Type.FAIRY; + case TerrainType.GRASSY: + return Type.GRASS; + case TerrainType.PSYCHIC: + return Type.PSYCHIC; + case TerrainType.NONE: + default: + return Type.UNKNOWN; + } + } + + /** + * Retrieves a type from the current biome + * @param biomeType {@linkcode Biome} + * @returns {@linkcode Type} + */ + private getTypeForBiome(biomeType: Biome): Type { + switch (biomeType) { + case Biome.TOWN: + case Biome.PLAINS: + case Biome.METROPOLIS: + return Type.NORMAL; + case Biome.GRASS: + case Biome.TALL_GRASS: + return Type.GRASS; + case Biome.FOREST: + case Biome.JUNGLE: + return Type.BUG; + case Biome.SLUM: + case Biome.SWAMP: + return Type.POISON; + case Biome.SEA: + case Biome.BEACH: + case Biome.LAKE: + case Biome.SEABED: + return Type.WATER; + case Biome.MOUNTAIN: + return Type.FLYING; + case Biome.BADLANDS: + return Type.GROUND; + case Biome.CAVE: + case Biome.DESERT: + return Type.ROCK; + case Biome.ICE_CAVE: + case Biome.SNOWY_FOREST: + return Type.ICE; + case Biome.MEADOW: + case Biome.FAIRY_CAVE: + case Biome.ISLAND: + return Type.FAIRY; + case Biome.POWER_PLANT: + return Type.ELECTRIC; + case Biome.VOLCANO: + return Type.FIRE; + case Biome.GRAVEYARD: + case Biome.TEMPLE: + return Type.GHOST; + case Biome.DOJO: + case Biome.CONSTRUCTION_SITE: + return Type.FIGHTING; + case Biome.FACTORY: + case Biome.LABORATORY: + return Type.STEEL; + case Biome.RUINS: + case Biome.SPACE: + return Type.PSYCHIC; + case Biome.WASTELAND: + case Biome.END: + return Type.DRAGON; + case Biome.ABYSS: + return Type.DARK; + default: + return Type.UNKNOWN; + } + } } export class ChangeTypeAttr extends MoveEffectAttr { private type: Type; constructor(type: Type) { - super(false, MoveEffectTrigger.HIT); + super(false, { trigger: MoveEffectTrigger.HIT }); this.type = type; } apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { - target.summonData.types = [this.type]; + target.summonData.types = [ this.type ]; target.updateInfo(); - user.scene.queueMessage(i18next.t("moveTriggers:transformedIntoType", {pokemonName: getPokemonNameWithAffix(target), typeName: i18next.t(`pokemonInfo:Type.${Type[this.type]}`)})); + user.scene.queueMessage(i18next.t("moveTriggers:transformedIntoType", { pokemonName: getPokemonNameWithAffix(target), typeName: i18next.t(`pokemonInfo:Type.${Type[this.type]}`) })); return true; } @@ -5382,26 +6341,22 @@ export class AddTypeAttr extends MoveEffectAttr { private type: Type; constructor(type: Type) { - super(false, MoveEffectTrigger.HIT); + super(false, { trigger: MoveEffectTrigger.HIT }); this.type = type; } apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { - const types = target.getTypes().slice(0, 2).filter(t => t !== Type.UNKNOWN); // TODO: Figure out some way to actually check if another version of this effect is already applied - if (this.type !== Type.UNKNOWN) { - types.push(this.type); - } - target.summonData.types = types; + target.summonData.addedType = this.type; target.updateInfo(); - user.scene.queueMessage(i18next.t("moveTriggers:addType", {typeName: i18next.t(`pokemonInfo:Type.${Type[this.type]}`), pokemonName: getPokemonNameWithAffix(target)})); + user.scene.queueMessage(i18next.t("moveTriggers:addType", { typeName: i18next.t(`pokemonInfo:Type.${Type[this.type]}`), pokemonName: getPokemonNameWithAffix(target) })); return true; } getCondition(): MoveConditionFunc { - return (user, target, move) => !target.isTerastallized()&& !target.getTypes().includes(this.type); + return (user, target, move) => !target.isTerastallized() && !target.getTypes().includes(this.type); } } @@ -5417,7 +6372,7 @@ export class FirstMoveTypeAttr extends MoveEffectAttr { const firstMoveType = target.getMoveset()[0]?.getMove().type!; // TODO: is this bang correct? user.summonData.types = [ firstMoveType ]; - user.scene.queueMessage(i18next.t("battle:transformedIntoType", {pokemonName: getPokemonNameWithAffix(user), type: i18next.t(`pokemonInfo:Type.${Type[firstMoveType]}`)})); + user.scene.queueMessage(i18next.t("battle:transformedIntoType", { pokemonName: getPokemonNameWithAffix(user), type: i18next.t(`pokemonInfo:Type.${Type[firstMoveType]}`) })); return true; } @@ -5444,19 +6399,19 @@ export class RandomMovesetMoveAttr extends OverrideMoveEffectAttr { } let selectTargets: BattlerIndex[]; switch (true) { - case (moveTargets.multiple || moveTargets.targets.length === 1): { - selectTargets = moveTargets.targets; - break; - } - case (moveTargets.targets.indexOf(target.getBattlerIndex()) > -1): { - selectTargets = [ target.getBattlerIndex() ]; - break; - } - default: { - moveTargets.targets.splice(moveTargets.targets.indexOf(user.getAlly().getBattlerIndex())); - selectTargets = [ moveTargets.targets[user.randSeedInt(moveTargets.targets.length)] ]; - break; - } + case (moveTargets.multiple || moveTargets.targets.length === 1): { + selectTargets = moveTargets.targets; + break; + } + case (moveTargets.targets.indexOf(target.getBattlerIndex()) > -1): { + selectTargets = [ target.getBattlerIndex() ]; + break; + } + default: { + moveTargets.targets.splice(moveTargets.targets.indexOf(user.getAlly().getBattlerIndex())); + selectTargets = [ moveTargets.targets[user.randSeedInt(moveTargets.targets.length)] ]; + break; + } } const targets = selectTargets; user.getMoveQueue().push({ move: move?.moveId!, targets: targets, ignorePP: true }); // TODO: is this bang correct? @@ -5469,10 +6424,17 @@ export class RandomMovesetMoveAttr extends OverrideMoveEffectAttr { } export class RandomMoveAttr extends OverrideMoveEffectAttr { + /** + * This function exists solely to allow tests to override the randomly selected move by mocking this function. + */ + public getMoveOverride(): Moves | null { + return null; + } + apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): Promise { return new Promise(resolve => { const moveIds = Utils.getEnumValues(Moves).filter(m => !allMoves[m].hasFlag(MoveFlags.IGNORE_VIRTUAL) && !allMoves[m].name.endsWith(" (N)")); - const moveId = moveIds[user.randSeedInt(moveIds.length)]; + const moveId = this.getMoveOverride() ?? moveIds[user.randSeedInt(moveIds.length)]; const moveTargets = getMoveTargets(user, moveId); if (!moveTargets.targets.length) { @@ -5500,135 +6462,135 @@ export class NaturePowerAttr extends OverrideMoveEffectAttr { let moveId; switch (user.scene.arena.getTerrainType()) { // this allows terrains to 'override' the biome move - case TerrainType.NONE: - switch (user.scene.arena.biomeType) { - case Biome.TOWN: - moveId = Moves.ROUND; + case TerrainType.NONE: + switch (user.scene.arena.biomeType) { + case Biome.TOWN: + moveId = Moves.ROUND; + break; + case Biome.METROPOLIS: + moveId = Moves.TRI_ATTACK; + break; + case Biome.SLUM: + moveId = Moves.SLUDGE_BOMB; + break; + case Biome.PLAINS: + moveId = Moves.SILVER_WIND; + break; + case Biome.GRASS: + moveId = Moves.GRASS_KNOT; + break; + case Biome.TALL_GRASS: + moveId = Moves.POLLEN_PUFF; + break; + case Biome.MEADOW: + moveId = Moves.GIGA_DRAIN; + break; + case Biome.FOREST: + moveId = Moves.BUG_BUZZ; + break; + case Biome.JUNGLE: + moveId = Moves.LEAF_STORM; + break; + case Biome.SEA: + moveId = Moves.HYDRO_PUMP; + break; + case Biome.SWAMP: + moveId = Moves.MUD_BOMB; + break; + case Biome.BEACH: + moveId = Moves.SCALD; + break; + case Biome.LAKE: + moveId = Moves.BUBBLE_BEAM; + break; + case Biome.SEABED: + moveId = Moves.BRINE; + break; + case Biome.ISLAND: + moveId = Moves.LEAF_TORNADO; + break; + case Biome.MOUNTAIN: + moveId = Moves.AIR_SLASH; + break; + case Biome.BADLANDS: + moveId = Moves.EARTH_POWER; + break; + case Biome.DESERT: + moveId = Moves.SCORCHING_SANDS; + break; + case Biome.WASTELAND: + moveId = Moves.DRAGON_PULSE; + break; + case Biome.CONSTRUCTION_SITE: + moveId = Moves.STEEL_BEAM; + break; + case Biome.CAVE: + moveId = Moves.POWER_GEM; + break; + case Biome.ICE_CAVE: + moveId = Moves.ICE_BEAM; + break; + case Biome.SNOWY_FOREST: + moveId = Moves.FROST_BREATH; + break; + case Biome.VOLCANO: + moveId = Moves.LAVA_PLUME; + break; + case Biome.GRAVEYARD: + moveId = Moves.SHADOW_BALL; + break; + case Biome.RUINS: + moveId = Moves.ANCIENT_POWER; + break; + case Biome.TEMPLE: + moveId = Moves.EXTRASENSORY; + break; + case Biome.DOJO: + moveId = Moves.FOCUS_BLAST; + break; + case Biome.FAIRY_CAVE: + moveId = Moves.ALLURING_VOICE; + break; + case Biome.ABYSS: + moveId = Moves.OMINOUS_WIND; + break; + case Biome.SPACE: + moveId = Moves.DRACO_METEOR; + break; + case Biome.FACTORY: + moveId = Moves.FLASH_CANNON; + break; + case Biome.LABORATORY: + moveId = Moves.ZAP_CANNON; + break; + case Biome.POWER_PLANT: + moveId = Moves.CHARGE_BEAM; + break; + case Biome.END: + moveId = Moves.ETERNABEAM; + break; + } break; - case Biome.METROPOLIS: + case TerrainType.MISTY: + moveId = Moves.MOONBLAST; + break; + case TerrainType.ELECTRIC: + moveId = Moves.THUNDERBOLT; + break; + case TerrainType.GRASSY: + moveId = Moves.ENERGY_BALL; + break; + case TerrainType.PSYCHIC: + moveId = Moves.PSYCHIC; + break; + default: + // Just in case there's no match moveId = Moves.TRI_ATTACK; break; - case Biome.SLUM: - moveId = Moves.SLUDGE_BOMB; - break; - case Biome.PLAINS: - moveId = Moves.SILVER_WIND; - break; - case Biome.GRASS: - moveId = Moves.GRASS_KNOT; - break; - case Biome.TALL_GRASS: - moveId = Moves.POLLEN_PUFF; - break; - case Biome.MEADOW: - moveId = Moves.GIGA_DRAIN; - break; - case Biome.FOREST: - moveId = Moves.BUG_BUZZ; - break; - case Biome.JUNGLE: - moveId = Moves.LEAF_STORM; - break; - case Biome.SEA: - moveId = Moves.HYDRO_PUMP; - break; - case Biome.SWAMP: - moveId = Moves.MUD_BOMB; - break; - case Biome.BEACH: - moveId = Moves.SCALD; - break; - case Biome.LAKE: - moveId = Moves.BUBBLE_BEAM; - break; - case Biome.SEABED: - moveId = Moves.BRINE; - break; - case Biome.ISLAND: - moveId = Moves.LEAF_TORNADO; - break; - case Biome.MOUNTAIN: - moveId = Moves.AIR_SLASH; - break; - case Biome.BADLANDS: - moveId = Moves.EARTH_POWER; - break; - case Biome.DESERT: - moveId = Moves.SCORCHING_SANDS; - break; - case Biome.WASTELAND: - moveId = Moves.DRAGON_PULSE; - break; - case Biome.CONSTRUCTION_SITE: - moveId = Moves.STEEL_BEAM; - break; - case Biome.CAVE: - moveId = Moves.POWER_GEM; - break; - case Biome.ICE_CAVE: - moveId = Moves.ICE_BEAM; - break; - case Biome.SNOWY_FOREST: - moveId = Moves.FROST_BREATH; - break; - case Biome.VOLCANO: - moveId = Moves.LAVA_PLUME; - break; - case Biome.GRAVEYARD: - moveId = Moves.SHADOW_BALL; - break; - case Biome.RUINS: - moveId = Moves.ANCIENT_POWER; - break; - case Biome.TEMPLE: - moveId = Moves.EXTRASENSORY; - break; - case Biome.DOJO: - moveId = Moves.FOCUS_BLAST; - break; - case Biome.FAIRY_CAVE: - moveId = Moves.ALLURING_VOICE; - break; - case Biome.ABYSS: - moveId = Moves.OMINOUS_WIND; - break; - case Biome.SPACE: - moveId = Moves.DRACO_METEOR; - break; - case Biome.FACTORY: - moveId = Moves.FLASH_CANNON; - break; - case Biome.LABORATORY: - moveId = Moves.ZAP_CANNON; - break; - case Biome.POWER_PLANT: - moveId = Moves.CHARGE_BEAM; - break; - case Biome.END: - moveId = Moves.ETERNABEAM; - break; - } - break; - case TerrainType.MISTY: - moveId = Moves.MOONBLAST; - break; - case TerrainType.ELECTRIC: - moveId = Moves.THUNDERBOLT; - break; - case TerrainType.GRASSY: - moveId = Moves.ENERGY_BALL; - break; - case TerrainType.PSYCHIC: - moveId = Moves.PSYCHIC; - break; - default: - // Just in case there's no match - moveId = Moves.TRI_ATTACK; - break; } - user.getMoveQueue().push({ move: moveId, targets: [target.getBattlerIndex()], ignorePP: true }); - user.scene.unshiftPhase(new MovePhase(user.scene, user, [target.getBattlerIndex()], new PokemonMove(moveId, 0, 0, true), true)); + user.getMoveQueue().push({ move: moveId, targets: [ target.getBattlerIndex() ], ignorePP: true }); + user.scene.unshiftPhase(new MovePhase(user.scene, user, [ target.getBattlerIndex() ], new PokemonMove(moveId, 0, 0, true), true)); initMoveAnim(user.scene, moveId).then(() => { loadMoveAnimAssets(user.scene, [ moveId ], true) .then(() => resolve(true)); @@ -5644,7 +6606,7 @@ const lastMoveCopiableCondition: MoveConditionFunc = (user, target, move) => { return false; } - if (allMoves[copiableMove].hasAttr(ChargeAttr)) { + if (allMoves[copiableMove].isChargingMove()) { return false; } @@ -5706,7 +6668,7 @@ export class ReducePpMoveAttr extends MoveEffectAttr { const lastPpUsed = movesetMove?.ppUsed!; // TODO: is the bang correct? movesetMove!.ppUsed = Math.min((movesetMove?.ppUsed!) + this.reduction, movesetMove?.getMovePp()!); // TODO: is the bang correct? - const message = i18next.t("battle:ppReduced", {targetName: getPokemonNameWithAffix(target), moveName: movesetMove?.getName(), reduction: (movesetMove?.ppUsed!) - lastPpUsed}); // TODO: is the bang correct? + const message = i18next.t("battle:ppReduced", { targetName: getPokemonNameWithAffix(target), moveName: movesetMove?.getName(), reduction: (movesetMove?.ppUsed!) - lastPpUsed }); // TODO: is the bang correct? user.scene.eventTarget.dispatchEvent(new MoveUsedEvent(target?.id, movesetMove?.getMove()!, movesetMove?.ppUsed!)); // TODO: are these bangs correct? user.scene.queueMessage(message); @@ -5792,7 +6754,7 @@ const targetMoveCopiableCondition: MoveConditionFunc = (user, target, move) => { return false; } - if (allMoves[copiableMove.move].hasAttr(ChargeAttr) && copiableMove.result === MoveResult.OTHER) { + if (allMoves[copiableMove.move].isChargingMove() && copiableMove.result === MoveResult.OTHER) { return false; } @@ -5819,7 +6781,7 @@ export class MovesetCopyMoveAttr extends OverrideMoveEffectAttr { user.summonData.moveset = user.getMoveset().slice(0); user.summonData.moveset[thisMoveIndex] = new PokemonMove(copiedMove.id, 0, 0); - user.scene.queueMessage(i18next.t("moveTriggers:copiedMove", {pokemonName: getPokemonNameWithAffix(user), moveName: copiedMove.name})); + user.scene.queueMessage(i18next.t("moveTriggers:copiedMove", { pokemonName: getPokemonNameWithAffix(user), moveName: copiedMove.name })); return true; } @@ -5855,7 +6817,8 @@ export class SketchAttr extends MoveEffectAttr { return false; } - const targetMove = target.getMoveHistory().filter(m => !m.virtual).at(-1); + const targetMove = target.getLastXMoves(-1) + .find(m => m.move !== Moves.NONE && m.move !== Moves.STRUGGLE && !m.virtual); if (!targetMove) { return false; } @@ -5868,7 +6831,7 @@ export class SketchAttr extends MoveEffectAttr { user.setMove(sketchIndex, sketchedMove.id); - user.scene.queueMessage(i18next.t("moveTriggers:sketchedMove", {pokemonName: getPokemonNameWithAffix(user), moveName: sketchedMove.name})); + user.scene.queueMessage(i18next.t("moveTriggers:sketchedMove", { pokemonName: getPokemonNameWithAffix(user), moveName: sketchedMove.name })); return true; } @@ -5913,7 +6876,7 @@ export class AbilityChangeAttr extends MoveEffectAttr { public ability: Abilities; constructor(ability: Abilities, selfTarget?: boolean) { - super(selfTarget, MoveEffectTrigger.HIT); + super(selfTarget, { trigger: MoveEffectTrigger.HIT }); this.ability = ability; } @@ -5928,7 +6891,7 @@ export class AbilityChangeAttr extends MoveEffectAttr { moveTarget.summonData.ability = this.ability; user.scene.triggerPokemonFormChange(moveTarget, SpeciesFormChangeRevertWeatherFormTrigger); - user.scene.queueMessage(i18next.t("moveTriggers:acquiredAbility", {pokemonName: getPokemonNameWithAffix((this.selfTarget ? user : target)), abilityName: allAbilities[this.ability].name})); + user.scene.queueMessage(i18next.t("moveTriggers:acquiredAbility", { pokemonName: getPokemonNameWithAffix((this.selfTarget ? user : target)), abilityName: allAbilities[this.ability].name })); return true; } @@ -5942,7 +6905,7 @@ export class AbilityCopyAttr extends MoveEffectAttr { public copyToPartner: boolean; constructor(copyToPartner: boolean = false) { - super(false, MoveEffectTrigger.HIT); + super(false, { trigger: MoveEffectTrigger.HIT }); this.copyToPartner = copyToPartner; } @@ -5954,11 +6917,11 @@ export class AbilityCopyAttr extends MoveEffectAttr { user.summonData.ability = target.getAbility().id; - user.scene.queueMessage(i18next.t("moveTriggers:copiedTargetAbility", {pokemonName: getPokemonNameWithAffix(user), targetName: getPokemonNameWithAffix(target), abilityName: allAbilities[target.getAbility().id].name})); + user.scene.queueMessage(i18next.t("moveTriggers:copiedTargetAbility", { pokemonName: getPokemonNameWithAffix(user), targetName: getPokemonNameWithAffix(target), abilityName: allAbilities[target.getAbility().id].name })); if (this.copyToPartner && user.scene.currentBattle?.double && user.getAlly().hp) { user.getAlly().summonData.ability = target.getAbility().id; - user.getAlly().scene.queueMessage(i18next.t("moveTriggers:copiedTargetAbility", {pokemonName: getPokemonNameWithAffix(user.getAlly()), targetName: getPokemonNameWithAffix(target), abilityName: allAbilities[target.getAbility().id].name})); + user.getAlly().scene.queueMessage(i18next.t("moveTriggers:copiedTargetAbility", { pokemonName: getPokemonNameWithAffix(user.getAlly()), targetName: getPokemonNameWithAffix(target), abilityName: allAbilities[target.getAbility().id].name })); } return true; @@ -5981,7 +6944,7 @@ export class AbilityGiveAttr extends MoveEffectAttr { public copyToPartner: boolean; constructor() { - super(false, MoveEffectTrigger.HIT); + super(false, { trigger: MoveEffectTrigger.HIT }); } apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { @@ -5991,7 +6954,7 @@ export class AbilityGiveAttr extends MoveEffectAttr { target.summonData.ability = user.getAbility().id; - user.scene.queueMessage(i18next.t("moveTriggers:acquiredAbility", {pokemonName: getPokemonNameWithAffix(target), abilityName: allAbilities[user.getAbility().id].name})); + user.scene.queueMessage(i18next.t("moveTriggers:acquiredAbility", { pokemonName: getPokemonNameWithAffix(target), abilityName: allAbilities[user.getAbility().id].name })); return true; } @@ -6011,7 +6974,7 @@ export class SwitchAbilitiesAttr extends MoveEffectAttr { user.summonData.ability = target.getAbility().id; target.summonData.ability = tempAbilityId; - user.scene.queueMessage(i18next.t("moveTriggers:swappedAbilitiesWithTarget", {pokemonName: getPokemonNameWithAffix(user)})); + user.scene.queueMessage(i18next.t("moveTriggers:swappedAbilitiesWithTarget", { pokemonName: getPokemonNameWithAffix(user) })); // Swaps Forecast/Flower Gift from Castform/Cherrim user.scene.arena.triggerWeatherBasedFormChangesToNormal(); // Swaps Forecast/Flower Gift to Castform/Cherrim (edge case) @@ -6043,7 +7006,7 @@ export class SuppressAbilitiesAttr extends MoveEffectAttr { target.summonData.abilitySuppressed = true; target.scene.arena.triggerWeatherBasedFormChangesToNormal(); - target.scene.queueMessage(i18next.t("moveTriggers:suppressAbilities", {pokemonName: getPokemonNameWithAffix(target)})); + target.scene.queueMessage(i18next.t("moveTriggers:suppressAbilities", { pokemonName: getPokemonNameWithAffix(target) })); return true; } @@ -6083,40 +7046,54 @@ export class SuppressAbilitiesIfActedAttr extends MoveEffectAttr { } } +/** + * Used by Transform + */ export class TransformAttr extends MoveEffectAttr { - apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): Promise { - return new Promise(resolve => { - if (!super.apply(user, target, move, args)) { - return resolve(false); + async apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): Promise { + if (!super.apply(user, target, move, args)) { + return false; + } + + const promises: Promise[] = []; + user.summonData.speciesForm = target.getSpeciesForm(); + user.summonData.ability = target.getAbility().id; + user.summonData.gender = target.getGender(); + + // Power Trick's effect will not preserved after using Transform + user.removeTag(BattlerTagType.POWER_TRICK); + + // Copy all stats (except HP) + for (const s of EFFECTIVE_STATS) { + user.setStat(s, target.getStat(s, false), false); + } + + // Copy all stat stages + for (const s of BATTLE_STATS) { + user.setStatStage(s, target.getStatStage(s)); + } + + user.summonData.moveset = target.getMoveset().map((m) => { + if (m) { + // If PP value is less than 5, do nothing. If greater, we need to reduce the value to 5. + return new PokemonMove(m.moveId, 0, 0, false, Math.min(m.getMove().pp, 5)); + } else { + console.warn(`Transform: somehow iterating over a ${m} value when copying moveset!`); + return new PokemonMove(Moves.NONE); } - - user.summonData.speciesForm = target.getSpeciesForm(); - user.summonData.fusionSpeciesForm = target.getFusionSpeciesForm(); - user.summonData.ability = target.getAbility().id; - user.summonData.gender = target.getGender(); - user.summonData.fusionGender = target.getFusionGender(); - - // Copy all stats (except HP) - for (const s of EFFECTIVE_STATS) { - user.setStat(s, target.getStat(s, false), false); - } - - // Copy all stat stages - for (const s of BATTLE_STATS) { - user.setStatStage(s, target.getStatStage(s)); - } - - user.summonData.moveset = target.getMoveset().map(m => new PokemonMove(m?.moveId!, m?.ppUsed, m?.ppUp)); // TODO: is this bang correct? - user.summonData.types = target.getTypes(); - - user.scene.queueMessage(i18next.t("moveTriggers:transformedIntoTarget", {pokemonName: getPokemonNameWithAffix(user), targetName: getPokemonNameWithAffix(target)})); - - user.loadAssets(false).then(() => { - user.playAnim(); - user.updateInfo(); - resolve(true); - }); }); + user.summonData.types = target.getTypes(); + promises.push(user.updateInfo()); + + user.scene.queueMessage(i18next.t("moveTriggers:transformedIntoTarget", { pokemonName: getPokemonNameWithAffix(user), targetName: getPokemonNameWithAffix(target) })); + + promises.push(user.loadAssets(false).then(() => { + user.playAnim(); + user.updateInfo(); + })); + + await Promise.all(promises); + return true; } } @@ -6280,7 +7257,7 @@ export class DiscourageFrequentUseAttr extends MoveAttr { export class MoneyAttr extends MoveEffectAttr { constructor() { - super(true, MoveEffectTrigger.HIT, true); + super(true, { trigger: MoveEffectTrigger.HIT, firstHitOnly: true }); } apply(user: Pokemon, target: Pokemon, move: Move): boolean { @@ -6297,7 +7274,7 @@ export class MoneyAttr extends MoveEffectAttr { */ export class DestinyBondAttr extends MoveEffectAttr { constructor() { - super(true, MoveEffectTrigger.PRE_APPLY); + super(true, { trigger: MoveEffectTrigger.PRE_APPLY }); } /** @@ -6309,7 +7286,7 @@ export class DestinyBondAttr extends MoveEffectAttr { * @returns true */ apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { - user.scene.queueMessage(`${i18next.t("moveTriggers:tryingToTakeFoeDown", {pokemonName: getPokemonNameWithAffix(user)})}`); + user.scene.queueMessage(`${i18next.t("moveTriggers:tryingToTakeFoeDown", { pokemonName: getPokemonNameWithAffix(user) })}`); user.addTag(BattlerTagType.DESTINY_BOND, undefined, move.id, user.id); return true; } @@ -6347,7 +7324,7 @@ export class StatusIfBoostedAttr extends MoveEffectAttr { public effect: StatusEffect; constructor(effect: StatusEffect) { - super(true, MoveEffectTrigger.HIT); + super(true, { trigger: MoveEffectTrigger.HIT }); this.effect = effect; } @@ -6393,13 +7370,13 @@ export class AttackedByItemAttr extends MoveAttr { */ getCondition(): MoveConditionFunc { return (user: Pokemon, target: Pokemon, move: Move) => { - const heldItems = target.getHeldItems().filter(i => i.isTransferrable); + const heldItems = target.getHeldItems().filter(i => i.isTransferable); if (heldItems.length === 0) { return false; } const itemName = heldItems[0]?.type?.name ?? "item"; - target.scene.queueMessage(i18next.t("moveTriggers:attackedByItem", {pokemonName: getPokemonNameWithAffix(target), itemName: itemName})); + target.scene.queueMessage(i18next.t("moveTriggers:attackedByItem", { pokemonName: getPokemonNameWithAffix(target), itemName: itemName })); return true; }; @@ -6438,12 +7415,12 @@ export class AfterYouAttr extends MoveEffectAttr { * @returns true */ override apply(user: Pokemon, target: Pokemon, _move: Move, _args: any[]): boolean { - user.scene.queueMessage(i18next.t("moveTriggers:afterYou", {targetName: getPokemonNameWithAffix(target)})); + user.scene.queueMessage(i18next.t("moveTriggers:afterYou", { targetName: getPokemonNameWithAffix(target) })); //Will find next acting phase of the targeted pokémon, delete it and queue it next on successful delete. const nextAttackPhase = target.scene.findPhase((phase) => phase.pokemon === target); if (nextAttackPhase && target.scene.tryRemovePhase((phase: MovePhase) => phase.pokemon === target)) { - target.scene.prependToPhase(new MovePhase(target.scene, target, [...nextAttackPhase.targets], nextAttackPhase.move), MovePhase); + target.scene.prependToPhase(new MovePhase(target.scene, target, [ ...nextAttackPhase.targets ], nextAttackPhase.move), MovePhase); } return true; @@ -6461,7 +7438,7 @@ const failIfDampCondition: MoveConditionFunc = (user, target, move) => { user.scene.getField(true).map(p=>applyAbAttrs(FieldPreventExplosiveMovesAbAttr, p, cancelled)); // Queue a message if an ability prevented usage of the move if (cancelled.value) { - user.scene.queueMessage(i18next.t("moveTriggers:cannotUseMove", {pokemonName: getPokemonNameWithAffix(user), moveName: move.name})); + user.scene.queueMessage(i18next.t("moveTriggers:cannotUseMove", { pokemonName: getPokemonNameWithAffix(user), moveName: move.name })); } return !cancelled.value; }; @@ -6472,6 +7449,11 @@ const targetSleptOrComatoseCondition: MoveConditionFunc = (user: Pokemon, target const failIfLastCondition: MoveConditionFunc = (user: Pokemon, target: Pokemon, move: Move) => user.scene.phaseQueue.find(phase => phase instanceof MovePhase) !== undefined; +const failIfLastInPartyCondition: MoveConditionFunc = (user: Pokemon, target: Pokemon, move: Move) => { + const party: Pokemon[] = user.isPlayer() ? user.scene.getPlayerParty() : user.scene.getEnemyParty(); + return party.some(pokemon => pokemon.isActive() && !pokemon.isOnField()); +}; + export type MoveAttrFilter = (attr: MoveAttr) => boolean; function applyMoveAttrsInternal(attrFilter: MoveAttrFilter, user: Pokemon | null, target: Pokemon | null, move: Move, args: any[]): Promise { @@ -6488,6 +7470,20 @@ function applyMoveAttrsInternal(attrFilter: MoveAttrFilter, user: Pokemon | null }); } +function applyMoveChargeAttrsInternal(attrFilter: MoveAttrFilter, user: Pokemon | null, target: Pokemon | null, move: ChargingMove, args: any[]): Promise { + return new Promise(resolve => { + const chargeAttrPromises: Promise[] = []; + const chargeMoveAttrs = move.chargeAttrs.filter(a => attrFilter(a)); + for (const attr of chargeMoveAttrs) { + const result = attr.apply(user, target, move, args); + if (result instanceof Promise) { + chargeAttrPromises.push(result); + } + } + Promise.allSettled(chargeAttrPromises).then(() => resolve()); + }); +} + export function applyMoveAttrs(attrType: Constructor, user: Pokemon | null, target: Pokemon | null, move: Move, ...args: any[]): Promise { return applyMoveAttrsInternal((attr: MoveAttr) => attr instanceof attrType, user, target, move, args); } @@ -6496,6 +7492,10 @@ export function applyFilteredMoveAttrs(attrFilter: MoveAttrFilter, user: Pokemon return applyMoveAttrsInternal(attrFilter, user, target, move, args); } +export function applyMoveChargeAttrs(attrType: Constructor, user: Pokemon | null, target: Pokemon | null, move: ChargingMove, ...args: any[]): Promise { + return applyMoveChargeAttrsInternal((attr: MoveAttr) => attr instanceof attrType, user, target, move, args); +} + export class MoveCondition { protected func: MoveConditionFunc; @@ -6514,7 +7514,7 @@ export class MoveCondition { export class FirstMoveCondition extends MoveCondition { constructor() { - super((user, target, move) => user.battleSummonData?.turnCount === 1); + super((user, target, move) => user.battleSummonData?.waveTurnCount === 1); } getUserBenefitScore(user: Pokemon, target: Pokemon, move: Move): integer { @@ -6522,6 +7522,27 @@ export class FirstMoveCondition extends MoveCondition { } } +/** + * Condition used by the move {@link https://bulbapedia.bulbagarden.net/wiki/Upper_Hand_(move) | Upper Hand}. + * Moves with this condition are only successful when the target has selected + * a high-priority attack (after factoring in priority-boosting effects) and + * hasn't moved yet this turn. + */ +export class UpperHandCondition extends MoveCondition { + constructor() { + super((user, target, move) => { + const targetCommand = user.scene.currentBattle.turnCommands[target.getBattlerIndex()]; + + return !!targetCommand + && targetCommand.command === Command.FIGHT + && !target.turnData.acted + && !!targetCommand.move?.move + && allMoves[targetCommand.move.move].category !== MoveCategory.STATUS + && allMoves[targetCommand.move.move].getPriority(target) > 0; + }); + } +} + export class hitsSameTypeAttr extends VariableMoveTypeMultiplierAttr { apply(user: Pokemon, target: Pokemon, move: Move, args: any[]): boolean { const multiplier = args[0] as Utils.NumberHolder; @@ -6559,7 +7580,7 @@ export class ResistLastMoveTypeAttr extends MoveEffectAttr { return false; } - const [targetMove] = target.getLastXMoves(1); // target's most recent move + const [ targetMove ] = target.getLastXMoves(1); // target's most recent move if (!targetMove) { return false; } @@ -6575,7 +7596,7 @@ export class ResistLastMoveTypeAttr extends MoveEffectAttr { } const type = validTypes[user.randSeedInt(validTypes.length)]; user.summonData.types = [ type ]; - user.scene.queueMessage(i18next.t("battle:transformedIntoType", {pokemonName: getPokemonNameWithAffix(user), type: Utils.toReadableString(Type[type])})); + user.scene.queueMessage(i18next.t("battle:transformedIntoType", { pokemonName: getPokemonNameWithAffix(user), type: Utils.toReadableString(Type[type]) })); user.updateInfo(); return true; @@ -6634,7 +7655,7 @@ export class ExposedMoveAttr extends AddBattlerTagAttr { return false; } - user.scene.queueMessage(i18next.t("moveTriggers:exposedMove", { pokemonName: getPokemonNameWithAffix(user), targetPokemonName: getPokemonNameWithAffix(target)})); + user.scene.queueMessage(i18next.t("moveTriggers:exposedMove", { pokemonName: getPokemonNameWithAffix(user), targetPokemonName: getPokemonNameWithAffix(target) })); return true; } @@ -6659,47 +7680,47 @@ export function getMoveTargets(user: Pokemon, move: Moves): MoveTargetSet { let multiple = false; switch (moveTarget) { - case MoveTarget.USER: - case MoveTarget.PARTY: - set = [ user ]; - break; - case MoveTarget.NEAR_OTHER: - case MoveTarget.OTHER: - case MoveTarget.ALL_NEAR_OTHERS: - case MoveTarget.ALL_OTHERS: - set = (opponents.concat([ user.getAlly() ])); - multiple = moveTarget === MoveTarget.ALL_NEAR_OTHERS || moveTarget === MoveTarget.ALL_OTHERS; - break; - case MoveTarget.NEAR_ENEMY: - case MoveTarget.ALL_NEAR_ENEMIES: - case MoveTarget.ALL_ENEMIES: - case MoveTarget.ENEMY_SIDE: - set = opponents; - multiple = moveTarget !== MoveTarget.NEAR_ENEMY; - break; - case MoveTarget.RANDOM_NEAR_ENEMY: - set = [ opponents[user.randSeedInt(opponents.length)] ]; - break; - case MoveTarget.ATTACKER: - return { targets: [ -1 as BattlerIndex ], multiple: false }; - case MoveTarget.NEAR_ALLY: - case MoveTarget.ALLY: - set = [ user.getAlly() ]; - break; - case MoveTarget.USER_OR_NEAR_ALLY: - case MoveTarget.USER_AND_ALLIES: - case MoveTarget.USER_SIDE: - set = [ user, user.getAlly() ]; - multiple = moveTarget !== MoveTarget.USER_OR_NEAR_ALLY; - break; - case MoveTarget.ALL: - case MoveTarget.BOTH_SIDES: - set = [ user, user.getAlly() ].concat(opponents); - multiple = true; - break; - case MoveTarget.CURSE: - set = user.getTypes(true).includes(Type.GHOST) ? (opponents.concat([ user.getAlly() ])) : [ user ]; - break; + case MoveTarget.USER: + case MoveTarget.PARTY: + set = [ user ]; + break; + case MoveTarget.NEAR_OTHER: + case MoveTarget.OTHER: + case MoveTarget.ALL_NEAR_OTHERS: + case MoveTarget.ALL_OTHERS: + set = (opponents.concat([ user.getAlly() ])); + multiple = moveTarget === MoveTarget.ALL_NEAR_OTHERS || moveTarget === MoveTarget.ALL_OTHERS; + break; + case MoveTarget.NEAR_ENEMY: + case MoveTarget.ALL_NEAR_ENEMIES: + case MoveTarget.ALL_ENEMIES: + case MoveTarget.ENEMY_SIDE: + set = opponents; + multiple = moveTarget !== MoveTarget.NEAR_ENEMY; + break; + case MoveTarget.RANDOM_NEAR_ENEMY: + set = [ opponents[user.randSeedInt(opponents.length)] ]; + break; + case MoveTarget.ATTACKER: + return { targets: [ -1 as BattlerIndex ], multiple: false }; + case MoveTarget.NEAR_ALLY: + case MoveTarget.ALLY: + set = [ user.getAlly() ]; + break; + case MoveTarget.USER_OR_NEAR_ALLY: + case MoveTarget.USER_AND_ALLIES: + case MoveTarget.USER_SIDE: + set = [ user, user.getAlly() ]; + multiple = moveTarget !== MoveTarget.USER_OR_NEAR_ALLY; + break; + case MoveTarget.ALL: + case MoveTarget.BOTH_SIDES: + set = [ user, user.getAlly() ].concat(opponents); + multiple = true; + break; + case MoveTarget.CURSE: + set = user.getTypes(true).includes(Type.GHOST) ? (opponents.concat([ user.getAlly() ])) : [ user ]; + break; } return { targets: set.filter(p => p?.isActive(true)).map(p => p.getBattlerIndex()).filter(t => t !== undefined), multiple }; @@ -6740,8 +7761,8 @@ export function initMoves() { new AttackMove(Moves.GUILLOTINE, Type.NORMAL, MoveCategory.PHYSICAL, 200, 30, 5, -1, 0, 1) .attr(OneHitKOAttr) .attr(OneHitKOAccuracyAttr), - new AttackMove(Moves.RAZOR_WIND, Type.NORMAL, MoveCategory.SPECIAL, 80, 100, 10, -1, 0, 1) - .attr(ChargeAttr, ChargeAnim.RAZOR_WIND_CHARGING, i18next.t("moveTriggers:whippedUpAWhirlwind", {pokemonName: "{USER}"})) + new ChargingAttackMove(Moves.RAZOR_WIND, Type.NORMAL, MoveCategory.SPECIAL, 80, 100, 10, -1, 0, 1) + .chargeText(i18next.t("moveTriggers:whippedUpAWhirlwind", { pokemonName: "{USER}" })) .attr(HighCritAttr) .windMove() .ignoresVirtual() @@ -6752,16 +7773,18 @@ export function initMoves() { new AttackMove(Moves.CUT, Type.NORMAL, MoveCategory.PHYSICAL, 50, 95, 30, -1, 0, 1) .slicingMove(), new AttackMove(Moves.GUST, Type.FLYING, MoveCategory.SPECIAL, 40, 100, 35, -1, 0, 1) - .attr(DealsDoubleDamageToTagAttr, BattlerTagType.FLYING, true) + .attr(HitsTagForDoubleDamageAttr, BattlerTagType.FLYING) .windMove(), new AttackMove(Moves.WING_ATTACK, Type.FLYING, MoveCategory.PHYSICAL, 60, 100, 35, -1, 0, 1), new StatusMove(Moves.WHIRLWIND, Type.NORMAL, -1, 20, -1, -6, 1) .attr(ForceSwitchOutAttr) .ignoresSubstitute() .hidesTarget() - .windMove(), - new AttackMove(Moves.FLY, Type.FLYING, MoveCategory.PHYSICAL, 90, 95, 15, -1, 0, 1) - .attr(ChargeAttr, ChargeAnim.FLY_CHARGING, i18next.t("moveTriggers:flewUpHigh", {pokemonName: "{USER}"}), BattlerTagType.FLYING) + .windMove() + .partial(), // Should force random switches + new ChargingAttackMove(Moves.FLY, Type.FLYING, MoveCategory.PHYSICAL, 90, 95, 15, -1, 0, 1) + .chargeText(i18next.t("moveTriggers:flewUpHigh", { pokemonName: "{USER}" })) + .chargeAttr(SemiInvulnerableAttr, BattlerTagType.FLYING) .condition(failOnGravityCondition) .ignoresVirtual(), new AttackMove(Moves.BIND, Type.NORMAL, MoveCategory.PHYSICAL, 15, 85, 20, -1, 0, 1) @@ -6770,7 +7793,7 @@ export function initMoves() { new AttackMove(Moves.VINE_WHIP, Type.GRASS, MoveCategory.PHYSICAL, 45, 100, 25, -1, 0, 1), new AttackMove(Moves.STOMP, Type.NORMAL, MoveCategory.PHYSICAL, 65, 100, 20, 30, 0, 1) .attr(AlwaysHitMinimizeAttr) - .attr(DealsDoubleDamageToTagAttr, BattlerTagType.MINIMIZED, true) + .attr(HitsTagForDoubleDamageAttr, BattlerTagType.MINIMIZED) .attr(FlinchAttr), new AttackMove(Moves.DOUBLE_KICK, Type.FIGHTING, MoveCategory.PHYSICAL, 30, 100, 30, -1, 0, 1) .attr(MultiHitAttr, MultiHitType._2), @@ -6795,7 +7818,7 @@ export function initMoves() { new AttackMove(Moves.TACKLE, Type.NORMAL, MoveCategory.PHYSICAL, 40, 100, 35, -1, 0, 1), new AttackMove(Moves.BODY_SLAM, Type.NORMAL, MoveCategory.PHYSICAL, 85, 100, 15, 30, 0, 1) .attr(AlwaysHitMinimizeAttr) - .attr(DealsDoubleDamageToTagAttr, BattlerTagType.MINIMIZED, true) + .attr(HitsTagForDoubleDamageAttr, BattlerTagType.MINIMIZED) .attr(StatusEffectAttr, StatusEffect.PARALYSIS), new AttackMove(Moves.WRAP, Type.NORMAL, MoveCategory.PHYSICAL, 15, 90, 20, -1, 0, 1) .attr(TrapAttr, BattlerTagType.WRAP), @@ -6836,7 +7859,8 @@ export function initMoves() { new StatusMove(Moves.ROAR, Type.NORMAL, -1, 20, -1, -6, 1) .attr(ForceSwitchOutAttr) .soundBased() - .hidesTarget(), + .hidesTarget() + .partial(), // Should force random switching new StatusMove(Moves.SING, Type.NORMAL, 55, 15, -1, 0, 1) .attr(StatusEffectAttr, StatusEffect.SLEEP) .soundBased(), @@ -6863,7 +7887,7 @@ export function initMoves() { new AttackMove(Moves.HYDRO_PUMP, Type.WATER, MoveCategory.SPECIAL, 110, 80, 5, -1, 0, 1), new AttackMove(Moves.SURF, Type.WATER, MoveCategory.SPECIAL, 90, 100, 15, -1, 0, 1) .target(MoveTarget.ALL_NEAR_OTHERS) - .attr(DealsDoubleDamageToTagAttr, BattlerTagType.UNDERWATER, true) + .attr(HitsTagForDoubleDamageAttr, BattlerTagType.UNDERWATER) .attr(GulpMissileTagAttr), new AttackMove(Moves.ICE_BEAM, Type.ICE, MoveCategory.SPECIAL, 90, 100, 10, 10, 0, 1) .attr(StatusEffectAttr, StatusEffect.FREEZE), @@ -6900,7 +7924,7 @@ export function initMoves() { .attr(HitHealAttr) .triageMove(), new StatusMove(Moves.LEECH_SEED, Type.GRASS, 90, 10, -1, 0, 1) - .attr(AddBattlerTagAttr, BattlerTagType.SEEDED) + .attr(LeechSeedAttr) .condition((user, target, move) => !target.getTag(BattlerTagType.SEEDED) && !target.isOfType(Type.GRASS)), new SelfStatusMove(Moves.GROWTH, Type.NORMAL, -1, 20, -1, 0, 1) .attr(GrowthStatStageChangeAttr), @@ -6909,8 +7933,9 @@ export function initMoves() { .makesContact(false) .slicingMove() .target(MoveTarget.ALL_NEAR_ENEMIES), - new AttackMove(Moves.SOLAR_BEAM, Type.GRASS, MoveCategory.SPECIAL, 120, 100, 10, -1, 0, 1) - .attr(SunlightChargeAttr, ChargeAnim.SOLAR_BEAM_CHARGING, i18next.t("moveTriggers:tookInSunlight", {pokemonName: "{USER}"})) + new ChargingAttackMove(Moves.SOLAR_BEAM, Type.GRASS, MoveCategory.SPECIAL, 120, 100, 10, -1, 0, 1) + .chargeText(i18next.t("moveTriggers:tookInSunlight", { pokemonName: "{USER}" })) + .chargeAttr(WeatherInstantChargeAttr, [ WeatherType.SUNNY, WeatherType.HARSH_SUN ]) .attr(AntiSunlightPowerDecreaseAttr) .ignoresVirtual(), new StatusMove(Moves.POISON_POWDER, Type.POISON, 75, 35, -1, 0, 1) @@ -6946,21 +7971,22 @@ export function initMoves() { new AttackMove(Moves.THUNDER, Type.ELECTRIC, MoveCategory.SPECIAL, 110, 70, 10, 30, 0, 1) .attr(StatusEffectAttr, StatusEffect.PARALYSIS) .attr(ThunderAccuracyAttr) - .attr(DealsDoubleDamageToTagAttr, BattlerTagType.FLYING, false), + .attr(HitsTagAttr, BattlerTagType.FLYING), new AttackMove(Moves.ROCK_THROW, Type.ROCK, MoveCategory.PHYSICAL, 50, 90, 15, -1, 0, 1) .makesContact(false), new AttackMove(Moves.EARTHQUAKE, Type.GROUND, MoveCategory.PHYSICAL, 100, 100, 10, -1, 0, 1) - .attr(DealsDoubleDamageToTagAttr, BattlerTagType.UNDERGROUND, true) + .attr(HitsTagForDoubleDamageAttr, BattlerTagType.UNDERGROUND) .attr(MovePowerMultiplierAttr, (user, target, move) => user.scene.arena.getTerrainType() === TerrainType.GRASSY && target.isGrounded() ? 0.5 : 1) .makesContact(false) .target(MoveTarget.ALL_NEAR_OTHERS), new AttackMove(Moves.FISSURE, Type.GROUND, MoveCategory.PHYSICAL, 200, 30, 5, -1, 0, 1) .attr(OneHitKOAttr) .attr(OneHitKOAccuracyAttr) - .attr(DealsDoubleDamageToTagAttr, BattlerTagType.UNDERGROUND, false) + .attr(HitsTagAttr, BattlerTagType.UNDERGROUND) .makesContact(false), - new AttackMove(Moves.DIG, Type.GROUND, MoveCategory.PHYSICAL, 80, 100, 10, -1, 0, 1) - .attr(ChargeAttr, ChargeAnim.DIG_CHARGING, i18next.t("moveTriggers:dugAHole", {pokemonName: "{USER}"}), BattlerTagType.UNDERGROUND) + new ChargingAttackMove(Moves.DIG, Type.GROUND, MoveCategory.PHYSICAL, 80, 100, 10, -1, 0, 1) + .chargeText(i18next.t("moveTriggers:dugAHole", { pokemonName: "{USER}" })) + .chargeAttr(SemiInvulnerableAttr, BattlerTagType.UNDERGROUND) .ignoresVirtual(), new StatusMove(Moves.TOXIC, Type.POISON, 90, 10, -1, 0, 1) .attr(StatusEffectAttr, StatusEffect.TOXIC) @@ -6977,7 +8003,7 @@ export function initMoves() { .attr(StatStageChangeAttr, [ Stat.SPD ], 2, true), new AttackMove(Moves.QUICK_ATTACK, Type.NORMAL, MoveCategory.PHYSICAL, 40, 100, 30, -1, 1, 1), new AttackMove(Moves.RAGE, Type.NORMAL, MoveCategory.PHYSICAL, 20, 100, 20, -1, 0, 1) - .partial(), + .partial(), // No effect implemented new SelfStatusMove(Moves.TELEPORT, Type.PSYCHIC, -1, 20, -1, -6, 1) .attr(ForceSwitchOutAttr, true) .hidesUser(), @@ -7056,9 +8082,9 @@ export function initMoves() { .attr(TrapAttr, BattlerTagType.CLAMP), new AttackMove(Moves.SWIFT, Type.NORMAL, MoveCategory.SPECIAL, 60, -1, 20, -1, 0, 1) .target(MoveTarget.ALL_NEAR_ENEMIES), - new AttackMove(Moves.SKULL_BASH, Type.NORMAL, MoveCategory.PHYSICAL, 130, 100, 10, -1, 0, 1) - .attr(ChargeAttr, ChargeAnim.SKULL_BASH_CHARGING, i18next.t("moveTriggers:loweredItsHead", {pokemonName: "{USER}"}), null, true) - .attr(StatStageChangeAttr, [ Stat.DEF ], 1, true) + new ChargingAttackMove(Moves.SKULL_BASH, Type.NORMAL, MoveCategory.PHYSICAL, 130, 100, 10, -1, 0, 1) + .chargeText(i18next.t("moveTriggers:loweredItsHead", { pokemonName: "{USER}" })) + .chargeAttr(StatStageChangeAttr, [ Stat.DEF ], 1, true) .ignoresVirtual(), new AttackMove(Moves.SPIKE_CANNON, Type.NORMAL, MoveCategory.PHYSICAL, 20, 100, 15, -1, 0, 1) .attr(MultiHitAttr) @@ -7095,14 +8121,16 @@ export function initMoves() { .triageMove(), new StatusMove(Moves.LOVELY_KISS, Type.NORMAL, 75, 10, -1, 0, 1) .attr(StatusEffectAttr, StatusEffect.SLEEP), - new AttackMove(Moves.SKY_ATTACK, Type.FLYING, MoveCategory.PHYSICAL, 140, 90, 5, 30, 0, 1) - .attr(ChargeAttr, ChargeAnim.SKY_ATTACK_CHARGING, i18next.t("moveTriggers:isGlowing", {pokemonName: "{USER}"})) + new ChargingAttackMove(Moves.SKY_ATTACK, Type.FLYING, MoveCategory.PHYSICAL, 140, 90, 5, 30, 0, 1) + .chargeText(i18next.t("moveTriggers:isGlowing", { pokemonName: "{USER}" })) .attr(HighCritAttr) .attr(FlinchAttr) .makesContact(false) .ignoresVirtual(), new StatusMove(Moves.TRANSFORM, Type.NORMAL, -1, 10, -1, 0, 1) .attr(TransformAttr) + // transforming from or into fusion pokemon causes various problems (such as crashes) + .condition((user, target, move) => !target.getTag(BattlerTagType.SUBSTITUTE) && !user.fusionSpecies && !target.fusionSpecies) .ignoresProtect(), new AttackMove(Moves.BUBBLE, Type.WATER, MoveCategory.SPECIAL, 40, 100, 30, 10, 0, 1) .attr(StatStageChangeAttr, [ Stat.SPD ], -1) @@ -7150,7 +8178,7 @@ export function initMoves() { new SelfStatusMove(Moves.CONVERSION, Type.NORMAL, -1, 30, -1, 0, 1) .attr(FirstMoveTypeAttr), new AttackMove(Moves.TRI_ATTACK, Type.NORMAL, MoveCategory.SPECIAL, 80, 100, 10, 20, 0, 1) - .attr(MultiStatusEffectAttr, [StatusEffect.BURN, StatusEffect.FREEZE, StatusEffect.PARALYSIS]), + .attr(MultiStatusEffectAttr, [ StatusEffect.BURN, StatusEffect.FREEZE, StatusEffect.PARALYSIS ]), new AttackMove(Moves.SUPER_FANG, Type.NORMAL, MoveCategory.PHYSICAL, -1, 90, 10, -1, 0, 1) .attr(TargetHalfHpDamageAttr), new AttackMove(Moves.SLASH, Type.NORMAL, MoveCategory.PHYSICAL, 70, 100, 20, -1, 0, 1) @@ -7191,7 +8219,7 @@ export function initMoves() { new StatusMove(Moves.CURSE, Type.GHOST, -1, 10, -1, 0, 2) .attr(CurseAttr) .ignoresSubstitute() - .ignoresProtect(true) + .ignoresProtect() .target(MoveTarget.CURSE), new AttackMove(Moves.FLAIL, Type.NORMAL, MoveCategory.PHYSICAL, -1, 100, 15, -1, 0, 2) .attr(LowHpPowerAttr), @@ -7292,7 +8320,7 @@ export function initMoves() { new StatusMove(Moves.CHARM, Type.FAIRY, 100, 20, -1, 0, 2) .attr(StatStageChangeAttr, [ Stat.ATK ], -2), new AttackMove(Moves.ROLLOUT, Type.ROCK, MoveCategory.PHYSICAL, 30, 90, 20, -1, 0, 2) - .partial() + .partial() // Does not lock the user, also does not increase damage properly .attr(ConsecutiveUseDoublePowerAttr, 5, true, true, Moves.DEFENSE_CURL), new AttackMove(Moves.FALSE_SWIPE, Type.NORMAL, MoveCategory.PHYSICAL, 40, 100, 40, -1, 0, 2) .attr(SurviveDamageAttr), @@ -7346,7 +8374,7 @@ export function initMoves() { .attr(PreMoveMessageAttr, magnitudeMessageFunc) .attr(MagnitudePowerAttr) .attr(MovePowerMultiplierAttr, (user, target, move) => user.scene.arena.getTerrainType() === TerrainType.GRASSY && target.isGrounded() ? 0.5 : 1) - .attr(DealsDoubleDamageToTagAttr, BattlerTagType.UNDERGROUND, true) + .attr(HitsTagForDoubleDamageAttr, BattlerTagType.UNDERGROUND) .makesContact(false) .target(MoveTarget.ALL_NEAR_OTHERS), new AttackMove(Moves.DYNAMIC_PUNCH, Type.FIGHTING, MoveCategory.PHYSICAL, 100, 50, 5, 100, 0, 2) @@ -7356,14 +8384,15 @@ export function initMoves() { new AttackMove(Moves.DRAGON_BREATH, Type.DRAGON, MoveCategory.SPECIAL, 60, 100, 20, 30, 0, 2) .attr(StatusEffectAttr, StatusEffect.PARALYSIS), new SelfStatusMove(Moves.BATON_PASS, Type.NORMAL, -1, 40, -1, 0, 2) - .attr(ForceSwitchOutAttr, true, true) + .attr(ForceSwitchOutAttr, true, SwitchType.BATON_PASS) + .condition(failIfLastInPartyCondition) .hidesUser(), new StatusMove(Moves.ENCORE, Type.NORMAL, 100, 5, -1, 0, 2) .attr(AddBattlerTagAttr, BattlerTagType.ENCORE, false, true) .ignoresSubstitute() .condition((user, target, move) => new EncoreTag(user.id).canAdd(target)), new AttackMove(Moves.PURSUIT, Type.DARK, MoveCategory.PHYSICAL, 40, 100, 20, -1, 0, 2) - .partial(), + .partial(), // No effect implemented new AttackMove(Moves.RAPID_SPIN, Type.NORMAL, MoveCategory.PHYSICAL, 50, 100, 40, 100, 0, 2) .attr(StatStageChangeAttr, [ Stat.SPD ], 1, true) .attr(RemoveBattlerTagAttr, [ @@ -7402,7 +8431,7 @@ export function initMoves() { new AttackMove(Moves.CROSS_CHOP, Type.FIGHTING, MoveCategory.PHYSICAL, 100, 80, 5, -1, 0, 2) .attr(HighCritAttr), new AttackMove(Moves.TWISTER, Type.DRAGON, MoveCategory.SPECIAL, 40, 100, 20, 20, 0, 2) - .attr(DealsDoubleDamageToTagAttr, BattlerTagType.FLYING, true) + .attr(HitsTagForDoubleDamageAttr, BattlerTagType.FLYING) .attr(FlinchAttr) .windMove() .target(MoveTarget.ALL_NEAR_ENEMIES), @@ -7428,13 +8457,14 @@ export function initMoves() { .attr(StatStageChangeAttr, [ Stat.SPDEF ], -1) .ballBombMove(), new AttackMove(Moves.FUTURE_SIGHT, Type.PSYCHIC, MoveCategory.SPECIAL, 120, 100, 10, -1, 0, 2) - .partial() - .attr(DelayedAttackAttr, ArenaTagType.FUTURE_SIGHT, ChargeAnim.FUTURE_SIGHT_CHARGING, i18next.t("moveTriggers:foresawAnAttack", {pokemonName: "{USER}"})), + .partial() // cannot be used on multiple Pokemon on the same side in a double battle, hits immediately when called by Metronome/etc + .ignoresProtect() + .attr(DelayedAttackAttr, ArenaTagType.FUTURE_SIGHT, ChargeAnim.FUTURE_SIGHT_CHARGING, i18next.t("moveTriggers:foresawAnAttack", { pokemonName: "{USER}" })), new AttackMove(Moves.ROCK_SMASH, Type.FIGHTING, MoveCategory.PHYSICAL, 40, 100, 15, 50, 0, 2) .attr(StatStageChangeAttr, [ Stat.DEF ], -1), new AttackMove(Moves.WHIRLPOOL, Type.WATER, MoveCategory.SPECIAL, 35, 85, 15, -1, 0, 2) .attr(TrapAttr, BattlerTagType.WHIRLPOOL) - .attr(DealsDoubleDamageToTagAttr, BattlerTagType.UNDERWATER, true), + .attr(HitsTagForDoubleDamageAttr, BattlerTagType.UNDERWATER), new AttackMove(Moves.BEAT_UP, Type.DARK, MoveCategory.PHYSICAL, -1, 100, 10, -1, 0, 2) .attr(MultiHitAttr, MultiHitType.BEAT_UP) .attr(BeatUpAttr) @@ -7446,18 +8476,18 @@ export function initMoves() { .ignoresVirtual() .soundBased() .target(MoveTarget.RANDOM_NEAR_ENEMY) - .partial(), + .partial(), // Does not lock the user, does not stop Pokemon from sleeping new SelfStatusMove(Moves.STOCKPILE, Type.NORMAL, -1, 20, -1, 0, 3) .condition(user => (user.getTag(StockpilingTag)?.stockpiledCount ?? 0) < 3) .attr(AddBattlerTagAttr, BattlerTagType.STOCKPILING, true), new AttackMove(Moves.SPIT_UP, Type.NORMAL, MoveCategory.SPECIAL, -1, -1, 10, -1, 0, 3) .condition(hasStockpileStacksCondition) .attr(SpitUpPowerAttr, 100) - .attr(RemoveBattlerTagAttr, [BattlerTagType.STOCKPILING], true), + .attr(RemoveBattlerTagAttr, [ BattlerTagType.STOCKPILING ], true), new SelfStatusMove(Moves.SWALLOW, Type.NORMAL, -1, 10, -1, 0, 3) .condition(hasStockpileStacksCondition) .attr(SwallowHealAttr) - .attr(RemoveBattlerTagAttr, [BattlerTagType.STOCKPILING], true) + .attr(RemoveBattlerTagAttr, [ BattlerTagType.STOCKPILING ], true) .triageMove(), new AttackMove(Moves.HEAT_WAVE, Type.FIRE, MoveCategory.SPECIAL, 95, 90, 10, 10, 0, 3) .attr(HealStatusEffectAttr, true, StatusEffect.FREEZE) @@ -7469,7 +8499,8 @@ export function initMoves() { .target(MoveTarget.BOTH_SIDES), new StatusMove(Moves.TORMENT, Type.DARK, 100, 15, -1, 0, 3) .ignoresSubstitute() - .unimplemented(), + .edgeCase() // Incomplete implementation because of Uproar's partial implementation + .attr(AddBattlerTagAttr, BattlerTagType.TORMENT, false, true, 1), new StatusMove(Moves.FLATTER, Type.DARK, 100, 15, -1, 0, 3) .attr(StatStageChangeAttr, [ Stat.SPATK ], 1) .attr(ConfuseAttr), @@ -7483,7 +8514,7 @@ export function initMoves() { && (user.status.effect === StatusEffect.BURN || user.status.effect === StatusEffect.POISON || user.status.effect === StatusEffect.TOXIC || user.status.effect === StatusEffect.PARALYSIS) ? 2 : 1) .attr(BypassBurnDamageReductionAttr), new AttackMove(Moves.FOCUS_PUNCH, Type.FIGHTING, MoveCategory.PHYSICAL, 150, 100, 20, -1, -3, 3) - .attr(MessageHeaderAttr, (user, move) => i18next.t("moveTriggers:isTighteningFocus", {pokemonName: getPokemonNameWithAffix(user)})) + .attr(MessageHeaderAttr, (user, move) => i18next.t("moveTriggers:isTighteningFocus", { pokemonName: getPokemonNameWithAffix(user) })) .punchingMove() .ignoresVirtual() .condition((user, target, move) => !user.turnData.attacksReceived.find(r => r.damage)), @@ -7500,11 +8531,12 @@ export function initMoves() { .attr(AddBattlerTagAttr, BattlerTagType.CHARGED, true, false), new StatusMove(Moves.TAUNT, Type.DARK, 100, 20, -1, 0, 3) .ignoresSubstitute() - .unimplemented(), + .attr(AddBattlerTagAttr, BattlerTagType.TAUNT, false, true, 4), new StatusMove(Moves.HELPING_HAND, Type.NORMAL, -1, 20, -1, 5, 3) .attr(AddBattlerTagAttr, BattlerTagType.HELPING_HAND) .ignoresSubstitute() - .target(MoveTarget.NEAR_ALLY), + .target(MoveTarget.NEAR_ALLY) + .condition(failIfSingleBattle), new StatusMove(Moves.TRICK, Type.PSYCHIC, 100, 10, -1, 0, 3) .unimplemented(), new StatusMove(Moves.ROLE_PLAY, Type.PSYCHIC, -1, 10, -1, 0, 3) @@ -7517,7 +8549,9 @@ export function initMoves() { .attr(RandomMovesetMoveAttr, true) .ignoresVirtual(), new SelfStatusMove(Moves.INGRAIN, Type.GRASS, -1, 20, -1, 0, 3) - .attr(AddBattlerTagAttr, BattlerTagType.INGRAIN, true, true), + .attr(AddBattlerTagAttr, BattlerTagType.INGRAIN, true, true) + .attr(AddBattlerTagAttr, BattlerTagType.IGNORE_FLYING, true, true) + .attr(RemoveBattlerTagAttr, [ BattlerTagType.FLOATING ], true), new AttackMove(Moves.SUPERPOWER, Type.FIGHTING, MoveCategory.PHYSICAL, 120, 100, 5, -1, 0, 3) .attr(StatStageChangeAttr, [ Stat.ATK, Stat.DEF ], -1, true), new SelfStatusMove(Moves.MAGIC_COAT, Type.PSYCHIC, -1, 15, -1, 4, 3) @@ -7530,9 +8564,9 @@ export function initMoves() { .attr(RemoveScreensAttr), new StatusMove(Moves.YAWN, Type.NORMAL, -1, 10, -1, 0, 3) .attr(AddBattlerTagAttr, BattlerTagType.DROWSY, false, true) - .condition((user, target, move) => !target.status && !target.scene.arena.getTagOnSide(ArenaTagType.SAFEGUARD, target.isPlayer() ? ArenaTagSide.PLAYER : ArenaTagSide.ENEMY)), + .condition((user, target, move) => !target.status && !target.isSafeguarded(user)), new AttackMove(Moves.KNOCK_OFF, Type.DARK, MoveCategory.PHYSICAL, 65, 100, 20, -1, 0, 3) - .attr(MovePowerMultiplierAttr, (user, target, move) => target.getHeldItems().filter(i => i.isTransferrable).length > 0 ? 1.5 : 1) + .attr(MovePowerMultiplierAttr, (user, target, move) => target.getHeldItems().filter(i => i.isTransferable).length > 0 ? 1.5 : 1) .attr(RemoveHeldItemAttr, false), new AttackMove(Moves.ENDEAVOR, Type.NORMAL, MoveCategory.PHYSICAL, -1, 100, 5, -1, 0, 3) .attr(MatchHpAttr) @@ -7543,22 +8577,24 @@ export function initMoves() { new StatusMove(Moves.SKILL_SWAP, Type.PSYCHIC, -1, 10, -1, 0, 3) .ignoresSubstitute() .attr(SwitchAbilitiesAttr), - new SelfStatusMove(Moves.IMPRISON, Type.PSYCHIC, -1, 10, -1, 0, 3) + new StatusMove(Moves.IMPRISON, Type.PSYCHIC, 100, 10, -1, 0, 3) .ignoresSubstitute() - .unimplemented(), + .attr(AddArenaTagAttr, ArenaTagType.IMPRISON, 1, true, false) + .target(MoveTarget.ENEMY_SIDE), new SelfStatusMove(Moves.REFRESH, Type.NORMAL, -1, 20, -1, 0, 3) - .attr(HealStatusEffectAttr, true, StatusEffect.PARALYSIS, StatusEffect.POISON, StatusEffect.TOXIC, StatusEffect.BURN) + .attr(HealStatusEffectAttr, true, [ StatusEffect.PARALYSIS, StatusEffect.POISON, StatusEffect.TOXIC, StatusEffect.BURN ]) .condition((user, target, move) => !!user.status && (user.status.effect === StatusEffect.PARALYSIS || user.status.effect === StatusEffect.POISON || user.status.effect === StatusEffect.TOXIC || user.status.effect === StatusEffect.BURN)), new SelfStatusMove(Moves.GRUDGE, Type.GHOST, -1, 5, -1, 0, 3) - .unimplemented(), + .attr(AddBattlerTagAttr, BattlerTagType.GRUDGE, true, undefined, 1), new SelfStatusMove(Moves.SNATCH, Type.DARK, -1, 10, -1, 4, 3) .unimplemented(), new AttackMove(Moves.SECRET_POWER, Type.NORMAL, MoveCategory.PHYSICAL, 70, 100, 20, 30, 0, 3) .makesContact(false) - .partial(), - new AttackMove(Moves.DIVE, Type.WATER, MoveCategory.PHYSICAL, 80, 100, 10, -1, 0, 3) - .attr(ChargeAttr, ChargeAnim.DIVE_CHARGING, i18next.t("moveTriggers:hidUnderwater", {pokemonName: "{USER}"}), BattlerTagType.UNDERWATER, true) - .attr(GulpMissileTagAttr) + .attr(SecretPowerAttr), + new ChargingAttackMove(Moves.DIVE, Type.WATER, MoveCategory.PHYSICAL, 80, 100, 10, -1, 0, 3) + .chargeText(i18next.t("moveTriggers:hidUnderwater", { pokemonName: "{USER}" })) + .chargeAttr(SemiInvulnerableAttr, BattlerTagType.UNDERWATER) + .chargeAttr(GulpMissileTagAttr) .ignoresVirtual(), new AttackMove(Moves.ARM_THRUST, Type.FIGHTING, MoveCategory.PHYSICAL, 15, 100, 20, -1, 0, 3) .attr(MultiHitAttr), @@ -7586,7 +8622,7 @@ export function initMoves() { .attr(AddArenaTagAttr, ArenaTagType.MUD_SPORT, 5) .target(MoveTarget.BOTH_SIDES), new AttackMove(Moves.ICE_BALL, Type.ICE, MoveCategory.PHYSICAL, 30, 90, 20, -1, 0, 3) - .partial() + .partial() // Does not lock the user properly, does not increase damage correctly .attr(ConsecutiveUseDoublePowerAttr, 5, true, true, Moves.DEFENSE_CURL) .ballBombMove(), new AttackMove(Moves.NEEDLE_ARM, Type.GRASS, MoveCategory.PHYSICAL, 60, 100, 15, 30, 0, 3) @@ -7613,7 +8649,7 @@ export function initMoves() { .attr(FlinchAttr), new AttackMove(Moves.WEATHER_BALL, Type.NORMAL, MoveCategory.SPECIAL, 50, 100, 10, -1, 0, 3) .attr(WeatherBallTypeAttr) - .attr(MovePowerMultiplierAttr, (user, target, move) => [WeatherType.SUNNY, WeatherType.RAIN, WeatherType.SANDSTORM, WeatherType.HAIL, WeatherType.SNOW, WeatherType.FOG, WeatherType.HEAVY_RAIN, WeatherType.HARSH_SUN].includes(user.scene.arena.weather?.weatherType!) && !user.scene.arena.weather?.isEffectSuppressed(user.scene) ? 2 : 1) // TODO: is this bang correct? + .attr(MovePowerMultiplierAttr, (user, target, move) => [ WeatherType.SUNNY, WeatherType.RAIN, WeatherType.SANDSTORM, WeatherType.HAIL, WeatherType.SNOW, WeatherType.FOG, WeatherType.HEAVY_RAIN, WeatherType.HARSH_SUN ].includes(user.scene.arena.weather?.weatherType!) && !user.scene.arena.weather?.isEffectSuppressed(user.scene) ? 2 : 1) // TODO: is this bang correct? .ballBombMove(), new StatusMove(Moves.AROMATHERAPY, Type.GRASS, -1, 5, -1, 0, 3) .attr(PartyStatusCureAttr, i18next.t("moveTriggers:soothingAromaWaftedThroughArea"), Abilities.SAP_SIPPER) @@ -7657,7 +8693,7 @@ export function initMoves() { new AttackMove(Moves.EXTRASENSORY, Type.PSYCHIC, MoveCategory.SPECIAL, 80, 100, 20, 10, 0, 3) .attr(FlinchAttr), new AttackMove(Moves.SKY_UPPERCUT, Type.FIGHTING, MoveCategory.PHYSICAL, 85, 90, 15, -1, 0, 3) - .attr(DealsDoubleDamageToTagAttr, BattlerTagType.FLYING) + .attr(HitsTagAttr, BattlerTagType.FLYING) .punchingMove(), new AttackMove(Moves.SAND_TOMB, Type.GROUND, MoveCategory.PHYSICAL, 35, 85, 15, -1, 0, 3) .attr(TrapAttr, BattlerTagType.SAND_TOMB) @@ -7691,8 +8727,9 @@ export function initMoves() { .attr(RechargeAttr), new SelfStatusMove(Moves.BULK_UP, Type.FIGHTING, -1, 20, -1, 0, 3) .attr(StatStageChangeAttr, [ Stat.ATK, Stat.DEF ], 1, true), - new AttackMove(Moves.BOUNCE, Type.FLYING, MoveCategory.PHYSICAL, 85, 85, 5, 30, 0, 3) - .attr(ChargeAttr, ChargeAnim.BOUNCE_CHARGING, i18next.t("moveTriggers:sprangUp", {pokemonName: "{USER}"}), BattlerTagType.FLYING) + new ChargingAttackMove(Moves.BOUNCE, Type.FLYING, MoveCategory.PHYSICAL, 85, 85, 5, 30, 0, 3) + .chargeText(i18next.t("moveTriggers:sprangUp", { pokemonName: "{USER}" })) + .chargeAttr(SemiInvulnerableAttr, BattlerTagType.FLYING) .attr(StatusEffectAttr, StatusEffect.PARALYSIS) .condition(failOnGravityCondition) .ignoresVirtual(), @@ -7729,8 +8766,9 @@ export function initMoves() { .attr(ConfuseAttr) .pulseMove(), new AttackMove(Moves.DOOM_DESIRE, Type.STEEL, MoveCategory.SPECIAL, 140, 100, 5, -1, 0, 3) - .partial() - .attr(DelayedAttackAttr, ArenaTagType.DOOM_DESIRE, ChargeAnim.DOOM_DESIRE_CHARGING, i18next.t("moveTriggers:choseDoomDesireAsDestiny", {pokemonName: "{USER}"})), + .partial() // cannot be used on multiple Pokemon on the same side in a double battle, hits immediately when called by Metronome/etc + .ignoresProtect() + .attr(DelayedAttackAttr, ArenaTagType.DOOM_DESIRE, ChargeAnim.DOOM_DESIRE_CHARGING, i18next.t("moveTriggers:choseDoomDesireAsDestiny", { pokemonName: "{USER}" })), new AttackMove(Moves.PSYCHO_BOOST, Type.PSYCHIC, MoveCategory.SPECIAL, 140, 90, 5, -1, 0, 3) .attr(StatStageChangeAttr, [ Stat.SPATK ], -2, true), new SelfStatusMove(Moves.ROOST, Type.FLYING, -1, 5, -1, 0, 4) @@ -7781,7 +8819,7 @@ export function initMoves() { .makesContact(false) .target(MoveTarget.ATTACKER), new AttackMove(Moves.U_TURN, Type.BUG, MoveCategory.PHYSICAL, 70, 100, 20, -1, 0, 4) - .attr(ForceSwitchOutAttr, true, false), + .attr(ForceSwitchOutAttr, true), new AttackMove(Moves.CLOSE_COMBAT, Type.FIGHTING, MoveCategory.PHYSICAL, 120, 100, 5, -1, 0, 4) .attr(StatStageChangeAttr, [ Stat.DEF, Stat.SPDEF ], -1, true), new AttackMove(Moves.PAYBACK, Type.DARK, MoveCategory.PHYSICAL, 50, 100, 10, -1, 0, 4) @@ -7807,13 +8845,13 @@ export function initMoves() { .makesContact() .attr(LessPPMorePowerAttr), new StatusMove(Moves.HEAL_BLOCK, Type.PSYCHIC, 100, 15, -1, 0, 4) - .target(MoveTarget.ALL_NEAR_ENEMIES) - .unimplemented(), + .attr(AddBattlerTagAttr, BattlerTagType.HEAL_BLOCK, false, true, 5) + .target(MoveTarget.ALL_NEAR_ENEMIES), new AttackMove(Moves.WRING_OUT, Type.NORMAL, MoveCategory.SPECIAL, -1, 100, 5, -1, 0, 4) .attr(OpponentHighHpPowerAttr, 120) .makesContact(), new SelfStatusMove(Moves.POWER_TRICK, Type.PSYCHIC, -1, 10, -1, 0, 4) - .unimplemented(), + .attr(AddBattlerTagAttr, BattlerTagType.POWER_TRICK, true), new StatusMove(Moves.GASTRO_ACID, Type.POISON, 100, 10, -1, 0, 4) .attr(SuppressAbilitiesAttr), new StatusMove(Moves.LUCKY_CHANT, Type.NORMAL, -1, 30, -1, 0, 4) @@ -7851,8 +8889,8 @@ export function initMoves() { new SelfStatusMove(Moves.AQUA_RING, Type.WATER, -1, 20, -1, 0, 4) .attr(AddBattlerTagAttr, BattlerTagType.AQUA_RING, true, true), new SelfStatusMove(Moves.MAGNET_RISE, Type.ELECTRIC, -1, 10, -1, 0, 4) - .attr(AddBattlerTagAttr, BattlerTagType.MAGNET_RISEN, true, true) - .condition((user, target, move) => !user.scene.arena.getTag(ArenaTagType.GRAVITY) && [BattlerTagType.MAGNET_RISEN, BattlerTagType.IGNORE_FLYING, BattlerTagType.INGRAIN].every((tag) => !user.getTag(tag))), + .attr(AddBattlerTagAttr, BattlerTagType.FLOATING, true, true, 5) + .condition((user, target, move) => !user.scene.arena.getTag(ArenaTagType.GRAVITY) && [ BattlerTagType.FLOATING, BattlerTagType.IGNORE_FLYING, BattlerTagType.INGRAIN ].every((tag) => !user.getTag(tag))), new AttackMove(Moves.FLARE_BLITZ, Type.FIRE, MoveCategory.PHYSICAL, 120, 100, 15, 10, 0, 4) .attr(RecoilAttr, false, 0.33) .attr(HealStatusEffectAttr, true, StatusEffect.FREEZE) @@ -7889,7 +8927,7 @@ export function initMoves() { .pulseMove(), new AttackMove(Moves.DRAGON_RUSH, Type.DRAGON, MoveCategory.PHYSICAL, 100, 75, 10, 20, 0, 4) .attr(AlwaysHitMinimizeAttr) - .attr(DealsDoubleDamageToTagAttr, BattlerTagType.MINIMIZED, true) + .attr(HitsTagForDoubleDamageAttr, BattlerTagType.MINIMIZED) .attr(FlinchAttr), new AttackMove(Moves.POWER_GEM, Type.ROCK, MoveCategory.SPECIAL, 80, 100, 20, -1, 0, 4), new AttackMove(Moves.DRAIN_PUNCH, Type.FIGHTING, MoveCategory.PHYSICAL, 75, 100, 10, -1, 0, 4) @@ -8018,7 +9056,7 @@ export function initMoves() { .makesContact(false), new SelfStatusMove(Moves.DEFEND_ORDER, Type.BUG, -1, 10, -1, 0, 4) .attr(StatStageChangeAttr, [ Stat.DEF, Stat.SPDEF ], 1, true), - new SelfStatusMove(Moves.HEAL_ORDER, Type.BUG, -1, 10, -1, 0, 4) + new SelfStatusMove(Moves.HEAL_ORDER, Type.BUG, -1, 5, -1, 0, 4) .attr(HealAttr, 0.5) .triageMove(), new AttackMove(Moves.HEAD_SMASH, Type.ROCK, MoveCategory.PHYSICAL, 150, 80, 5, -1, 0, 4) @@ -8047,8 +9085,9 @@ export function initMoves() { new AttackMove(Moves.OMINOUS_WIND, Type.GHOST, MoveCategory.SPECIAL, 60, 100, 5, 10, 0, 4) .attr(StatStageChangeAttr, [ Stat.ATK, Stat.DEF, Stat.SPATK, Stat.SPDEF, Stat.SPD ], 1, true) .windMove(), - new AttackMove(Moves.SHADOW_FORCE, Type.GHOST, MoveCategory.PHYSICAL, 120, 100, 5, -1, 0, 4) - .attr(ChargeAttr, ChargeAnim.SHADOW_FORCE_CHARGING, i18next.t("moveTriggers:vanishedInstantly", {pokemonName: "{USER}"}), BattlerTagType.HIDDEN) + new ChargingAttackMove(Moves.SHADOW_FORCE, Type.GHOST, MoveCategory.PHYSICAL, 120, 100, 5, -1, 0, 4) + .chargeText(i18next.t("moveTriggers:vanishedInstantly", { pokemonName: "{USER}" })) + .chargeAttr(SemiInvulnerableAttr, BattlerTagType.HIDDEN) .ignoresProtect() .ignoresVirtual(), new SelfStatusMove(Moves.HONE_CLAWS, Type.DARK, -1, 15, -1, 0, 5) @@ -8071,13 +9110,17 @@ export function initMoves() { .attr(MovePowerMultiplierAttr, (user, target, move) => target.status && (target.status.effect === StatusEffect.POISON || target.status.effect === StatusEffect.TOXIC) ? 2 : 1), new SelfStatusMove(Moves.AUTOTOMIZE, Type.STEEL, -1, 15, -1, 0, 5) .attr(StatStageChangeAttr, [ Stat.SPD ], 2, true) - .partial(), + .attr(AddBattlerTagAttr, BattlerTagType.AUTOTOMIZED, true), new SelfStatusMove(Moves.RAGE_POWDER, Type.BUG, -1, 20, -1, 2, 5) .powderMove() .attr(AddBattlerTagAttr, BattlerTagType.CENTER_OF_ATTENTION, true), new StatusMove(Moves.TELEKINESIS, Type.PSYCHIC, -1, 15, -1, 0, 5) .condition(failOnGravityCondition) - .unimplemented(), + .condition((_user, target, _move) => ![ Species.DIGLETT, Species.DUGTRIO, Species.ALOLA_DIGLETT, Species.ALOLA_DUGTRIO, Species.SANDYGAST, Species.PALOSSAND, Species.WIGLETT, Species.WUGTRIO ].includes(target.species.speciesId)) + .condition((_user, target, _move) => !(target.species.speciesId === Species.GENGAR && target.getFormKey() === "mega")) + .condition((_user, target, _move) => Utils.isNullOrUndefined(target.getTag(BattlerTagType.INGRAIN)) && Utils.isNullOrUndefined(target.getTag(BattlerTagType.IGNORE_FLYING))) + .attr(AddBattlerTagAttr, BattlerTagType.TELEKINESIS, false, true, 3) + .attr(AddBattlerTagAttr, BattlerTagType.FLOATING, false, true, 3), new StatusMove(Moves.MAGIC_ROOM, Type.PSYCHIC, -1, 10, -1, 0, 5) .ignoresProtect() .target(MoveTarget.BOTH_SIDES) @@ -8085,8 +9128,8 @@ export function initMoves() { new AttackMove(Moves.SMACK_DOWN, Type.ROCK, MoveCategory.PHYSICAL, 50, 100, 15, 100, 0, 5) .attr(AddBattlerTagAttr, BattlerTagType.IGNORE_FLYING, false, false, 1, 1, true) .attr(AddBattlerTagAttr, BattlerTagType.INTERRUPTED) - .attr(RemoveBattlerTagAttr, [BattlerTagType.FLYING, BattlerTagType.MAGNET_RISEN]) - .attr(DealsDoubleDamageToTagAttr, BattlerTagType.FLYING, false) + .attr(RemoveBattlerTagAttr, [ BattlerTagType.FLYING, BattlerTagType.FLOATING, BattlerTagType.TELEKINESIS ]) + .attr(HitsTagAttr, BattlerTagType.FLYING) .makesContact(false), new AttackMove(Moves.STORM_THROW, Type.FIGHTING, MoveCategory.PHYSICAL, 60, 100, 10, -1, 0, 5) .attr(CritOnlyAttr), @@ -8101,7 +9144,7 @@ export function initMoves() { new AttackMove(Moves.HEAVY_SLAM, Type.STEEL, MoveCategory.PHYSICAL, -1, 100, 10, -1, 0, 5) .attr(AlwaysHitMinimizeAttr) .attr(CompareWeightPowerAttr) - .attr(DealsDoubleDamageToTagAttr, BattlerTagType.MINIMIZED, true), + .attr(HitsTagForDoubleDamageAttr, BattlerTagType.MINIMIZED), new AttackMove(Moves.SYNCHRONOISE, Type.PSYCHIC, MoveCategory.SPECIAL, 120, 100, 10, -1, 0, 5) .target(MoveTarget.ALL_NEAR_OTHERS) .condition(unknownTypeCondition) @@ -8134,8 +9177,9 @@ export function initMoves() { .condition((user, target, move) => !target.turnData.acted) .attr(AfterYouAttr), new AttackMove(Moves.ROUND, Type.NORMAL, MoveCategory.SPECIAL, 60, 100, 15, -1, 0, 5) - .soundBased() - .partial(), + .attr(CueNextRoundAttr) + .attr(RoundPowerAttr) + .soundBased(), new AttackMove(Moves.ECHOED_VOICE, Type.NORMAL, MoveCategory.SPECIAL, 40, 100, 15, -1, 0, 5) .attr(ConsecutiveUseMultiBasePowerAttr, 5, false) .soundBased(), @@ -8166,25 +9210,28 @@ export function initMoves() { new AttackMove(Moves.HEX, Type.GHOST, MoveCategory.SPECIAL, 65, 100, 10, -1, 0, 5) .attr( MovePowerMultiplierAttr, - (user, target, move) => target.status || target.hasAbility(Abilities.COMATOSE)? 2 : 1), - new AttackMove(Moves.SKY_DROP, Type.FLYING, MoveCategory.PHYSICAL, 60, 100, 10, -1, 0, 5) - .partial() // Should immobilize the target, Flying types should take no damage. cf https://bulbapedia.bulbagarden.net/wiki/Sky_Drop_(move) and https://www.smogon.com/dex/sv/moves/sky-drop/ - .attr(ChargeAttr, ChargeAnim.SKY_DROP_CHARGING, i18next.t("moveTriggers:tookTargetIntoSky", {pokemonName: "{USER}", targetName: "{TARGET}"}), BattlerTagType.FLYING) // TODO: Add 2nd turn message + (user, target, move) => target.status || target.hasAbility(Abilities.COMATOSE) ? 2 : 1), + new ChargingAttackMove(Moves.SKY_DROP, Type.FLYING, MoveCategory.PHYSICAL, 60, 100, 10, -1, 0, 5) + .chargeText(i18next.t("moveTriggers:tookTargetIntoSky", { pokemonName: "{USER}", targetName: "{TARGET}" })) + .chargeAttr(SemiInvulnerableAttr, BattlerTagType.FLYING) .condition(failOnGravityCondition) .condition((user, target, move) => !target.getTag(BattlerTagType.SUBSTITUTE)) - .ignoresVirtual(), + .ignoresVirtual() + .partial(), // Should immobilize the target, Flying types should take no damage. cf https://bulbapedia.bulbagarden.net/wiki/Sky_Drop_(move) and https://www.smogon.com/dex/sv/moves/sky-drop/ new SelfStatusMove(Moves.SHIFT_GEAR, Type.STEEL, -1, 10, -1, 0, 5) .attr(StatStageChangeAttr, [ Stat.ATK ], 1, true) .attr(StatStageChangeAttr, [ Stat.SPD ], 2, true), new AttackMove(Moves.CIRCLE_THROW, Type.FIGHTING, MoveCategory.PHYSICAL, 60, 90, 10, -1, -6, 5) - .attr(ForceSwitchOutAttr), + .attr(ForceSwitchOutAttr) + .partial(), // Should force random switches new AttackMove(Moves.INCINERATE, Type.FIRE, MoveCategory.SPECIAL, 60, 100, 15, -1, 0, 5) .target(MoveTarget.ALL_NEAR_ENEMIES) .attr(RemoveHeldItemAttr, true), new StatusMove(Moves.QUASH, Type.DARK, 100, 15, -1, 0, 5) + .condition(failIfSingleBattle) .unimplemented(), new AttackMove(Moves.ACROBATICS, Type.FLYING, MoveCategory.PHYSICAL, 55, 100, 15, -1, 0, 5) - .attr(MovePowerMultiplierAttr, (user, target, move) => Math.max(1, 2 - 0.2 * user.getHeldItems().filter(i => i.isTransferrable).reduce((v, m) => v + m.stackCount, 0))), + .attr(MovePowerMultiplierAttr, (user, target, move) => Math.max(1, 2 - 0.2 * user.getHeldItems().filter(i => i.isTransferable).reduce((v, m) => v + m.stackCount, 0))), new StatusMove(Moves.REFLECT_TYPE, Type.NORMAL, -1, 15, -1, 0, 5) .ignoresSubstitute() .attr(CopyTypeAttr), @@ -8208,13 +9255,31 @@ export function initMoves() { new AttackMove(Moves.INFERNO, Type.FIRE, MoveCategory.SPECIAL, 100, 50, 5, 100, 0, 5) .attr(StatusEffectAttr, StatusEffect.BURN), new AttackMove(Moves.WATER_PLEDGE, Type.WATER, MoveCategory.SPECIAL, 80, 100, 10, -1, 0, 5) - .partial(), + .attr(AwaitCombinedPledgeAttr) + .attr(CombinedPledgeTypeAttr) + .attr(CombinedPledgePowerAttr) + .attr(CombinedPledgeStabBoostAttr) + .attr(AddPledgeEffectAttr, ArenaTagType.WATER_FIRE_PLEDGE, Moves.FIRE_PLEDGE, true) + .attr(AddPledgeEffectAttr, ArenaTagType.GRASS_WATER_PLEDGE, Moves.GRASS_PLEDGE) + .attr(BypassRedirectAttr, true), new AttackMove(Moves.FIRE_PLEDGE, Type.FIRE, MoveCategory.SPECIAL, 80, 100, 10, -1, 0, 5) - .partial(), + .attr(AwaitCombinedPledgeAttr) + .attr(CombinedPledgeTypeAttr) + .attr(CombinedPledgePowerAttr) + .attr(CombinedPledgeStabBoostAttr) + .attr(AddPledgeEffectAttr, ArenaTagType.FIRE_GRASS_PLEDGE, Moves.GRASS_PLEDGE) + .attr(AddPledgeEffectAttr, ArenaTagType.WATER_FIRE_PLEDGE, Moves.WATER_PLEDGE, true) + .attr(BypassRedirectAttr, true), new AttackMove(Moves.GRASS_PLEDGE, Type.GRASS, MoveCategory.SPECIAL, 80, 100, 10, -1, 0, 5) - .partial(), + .attr(AwaitCombinedPledgeAttr) + .attr(CombinedPledgeTypeAttr) + .attr(CombinedPledgePowerAttr) + .attr(CombinedPledgeStabBoostAttr) + .attr(AddPledgeEffectAttr, ArenaTagType.GRASS_WATER_PLEDGE, Moves.WATER_PLEDGE) + .attr(AddPledgeEffectAttr, ArenaTagType.FIRE_GRASS_PLEDGE, Moves.FIRE_PLEDGE) + .attr(BypassRedirectAttr, true), new AttackMove(Moves.VOLT_SWITCH, Type.ELECTRIC, MoveCategory.SPECIAL, 70, 100, 20, -1, 0, 5) - .attr(ForceSwitchOutAttr, true, false), + .attr(ForceSwitchOutAttr, true), new AttackMove(Moves.STRUGGLE_BUG, Type.BUG, MoveCategory.SPECIAL, 50, 100, 20, 100, 0, 5) .attr(StatStageChangeAttr, [ Stat.SPATK ], -1) .target(MoveTarget.ALL_NEAR_ENEMIES), @@ -8227,7 +9292,8 @@ export function initMoves() { .attr(CritOnlyAttr), new AttackMove(Moves.DRAGON_TAIL, Type.DRAGON, MoveCategory.PHYSICAL, 60, 90, 10, -1, -6, 5) .attr(ForceSwitchOutAttr) - .hidesTarget(), + .hidesTarget() + .partial(), // Should force random switches new SelfStatusMove(Moves.WORK_UP, Type.NORMAL, -1, 30, -1, 0, 5) .attr(StatStageChangeAttr, [ Stat.ATK, Stat.SPATK ], 1, true), new AttackMove(Moves.ELECTROWEB, Type.ELECTRIC, MoveCategory.SPECIAL, 55, 95, 15, 100, 0, 5) @@ -8254,12 +9320,12 @@ export function initMoves() { new AttackMove(Moves.HEAT_CRASH, Type.FIRE, MoveCategory.PHYSICAL, -1, 100, 10, -1, 0, 5) .attr(AlwaysHitMinimizeAttr) .attr(CompareWeightPowerAttr) - .attr(DealsDoubleDamageToTagAttr, BattlerTagType.MINIMIZED, true), + .attr(HitsTagForDoubleDamageAttr, BattlerTagType.MINIMIZED), new AttackMove(Moves.LEAF_TORNADO, Type.GRASS, MoveCategory.SPECIAL, 65, 90, 10, 50, 0, 5) .attr(StatStageChangeAttr, [ Stat.ACC ], -1), new AttackMove(Moves.STEAMROLLER, Type.BUG, MoveCategory.PHYSICAL, 65, 100, 20, 30, 0, 5) .attr(AlwaysHitMinimizeAttr) - .attr(DealsDoubleDamageToTagAttr, BattlerTagType.MINIMIZED, true) + .attr(HitsTagForDoubleDamageAttr, BattlerTagType.MINIMIZED) .attr(FlinchAttr), new SelfStatusMove(Moves.COTTON_GUARD, Type.GRASS, -1, 10, -1, 0, 5) .attr(StatStageChangeAttr, [ Stat.DEF ], 3, true), @@ -8272,7 +9338,7 @@ export function initMoves() { new AttackMove(Moves.HURRICANE, Type.FLYING, MoveCategory.SPECIAL, 110, 70, 10, 30, 0, 5) .attr(ThunderAccuracyAttr) .attr(ConfuseAttr) - .attr(DealsDoubleDamageToTagAttr, BattlerTagType.FLYING, false) + .attr(HitsTagAttr, BattlerTagType.FLYING) .windMove(), new AttackMove(Moves.HEAD_CHARGE, Type.NORMAL, MoveCategory.PHYSICAL, 120, 100, 15, -1, 0, 5) .attr(RecoilAttr) @@ -8302,12 +9368,12 @@ export function initMoves() { new AttackMove(Moves.FIERY_DANCE, Type.FIRE, MoveCategory.SPECIAL, 80, 100, 10, 50, 0, 5) .attr(StatStageChangeAttr, [ Stat.SPATK ], 1, true) .danceMove(), - new AttackMove(Moves.FREEZE_SHOCK, Type.ICE, MoveCategory.PHYSICAL, 140, 90, 5, 30, 0, 5) - .attr(ChargeAttr, ChargeAnim.FREEZE_SHOCK_CHARGING, i18next.t("moveTriggers:becameCloakedInFreezingLight", {pokemonName: "{USER}"})) + new ChargingAttackMove(Moves.FREEZE_SHOCK, Type.ICE, MoveCategory.PHYSICAL, 140, 90, 5, 30, 0, 5) + .chargeText(i18next.t("moveTriggers:becameCloakedInFreezingLight", { pokemonName: "{USER}" })) .attr(StatusEffectAttr, StatusEffect.PARALYSIS) .makesContact(false), - new AttackMove(Moves.ICE_BURN, Type.ICE, MoveCategory.SPECIAL, 140, 90, 5, 30, 0, 5) - .attr(ChargeAttr, ChargeAnim.ICE_BURN_CHARGING, i18next.t("moveTriggers:becameCloakedInFreezingAir", {pokemonName: "{USER}"})) + new ChargingAttackMove(Moves.ICE_BURN, Type.ICE, MoveCategory.SPECIAL, 140, 90, 5, 30, 0, 5) + .chargeText(i18next.t("moveTriggers:becameCloakedInFreezingAir", { pokemonName: "{USER}" })) .attr(StatusEffectAttr, StatusEffect.BURN) .ignoresVirtual(), new AttackMove(Moves.SNARL, Type.DARK, MoveCategory.SPECIAL, 55, 95, 15, 100, 0, 5) @@ -8328,7 +9394,7 @@ export function initMoves() { new AttackMove(Moves.FLYING_PRESS, Type.FIGHTING, MoveCategory.PHYSICAL, 100, 95, 10, -1, 0, 6) .attr(AlwaysHitMinimizeAttr) .attr(FlyingTypeMultiplierAttr) - .attr(DealsDoubleDamageToTagAttr, BattlerTagType.MINIMIZED, true) + .attr(HitsTagForDoubleDamageAttr, BattlerTagType.MINIMIZED) .condition(failOnGravityCondition), new StatusMove(Moves.MAT_BLOCK, Type.FIGHTING, -1, 10, -1, 0, 6) .target(MoveTarget.USER_SIDE) @@ -8341,48 +9407,46 @@ export function initMoves() { .target(MoveTarget.ALL) .condition((user, target, move) => { // If any fielded pokémon is grass-type and grounded. - return [...user.scene.getEnemyParty(), ...user.scene.getParty()].some((poke) => poke.isOfType(Type.GRASS) && poke.isGrounded()); + return [ ...user.scene.getEnemyParty(), ...user.scene.getPlayerParty() ].some((poke) => poke.isOfType(Type.GRASS) && poke.isGrounded()); }) - .attr(StatStageChangeAttr, [ Stat.ATK, Stat.SPATK ], 1, false, (user, target, move) => target.isOfType(Type.GRASS) && target.isGrounded()), + .attr(StatStageChangeAttr, [ Stat.ATK, Stat.SPATK ], 1, false, { condition: (user, target, move) => target.isOfType(Type.GRASS) && target.isGrounded() }), new StatusMove(Moves.STICKY_WEB, Type.BUG, -1, 20, -1, 0, 6) .attr(AddArenaTrapTagAttr, ArenaTagType.STICKY_WEB) .target(MoveTarget.ENEMY_SIDE), new AttackMove(Moves.FELL_STINGER, Type.BUG, MoveCategory.PHYSICAL, 50, 100, 25, -1, 0, 6) .attr(PostVictoryStatStageChangeAttr, [ Stat.ATK ], 3, true ), - new AttackMove(Moves.PHANTOM_FORCE, Type.GHOST, MoveCategory.PHYSICAL, 90, 100, 10, -1, 0, 6) - .attr(ChargeAttr, ChargeAnim.PHANTOM_FORCE_CHARGING, i18next.t("moveTriggers:vanishedInstantly", {pokemonName: "{USER}"}), BattlerTagType.HIDDEN) + new ChargingAttackMove(Moves.PHANTOM_FORCE, Type.GHOST, MoveCategory.PHYSICAL, 90, 100, 10, -1, 0, 6) + .chargeText(i18next.t("moveTriggers:vanishedInstantly", { pokemonName: "{USER}" })) + .chargeAttr(SemiInvulnerableAttr, BattlerTagType.HIDDEN) .ignoresProtect() .ignoresVirtual(), new StatusMove(Moves.TRICK_OR_TREAT, Type.GHOST, 100, 20, -1, 0, 6) - .attr(AddTypeAttr, Type.GHOST) - .partial(), + .attr(AddTypeAttr, Type.GHOST), new StatusMove(Moves.NOBLE_ROAR, Type.NORMAL, 100, 30, -1, 0, 6) .attr(StatStageChangeAttr, [ Stat.ATK, Stat.SPATK ], -1) .soundBased(), new StatusMove(Moves.ION_DELUGE, Type.ELECTRIC, -1, 25, -1, 1, 6) - .target(MoveTarget.BOTH_SIDES) - .unimplemented(), + .attr(AddArenaTagAttr, ArenaTagType.ION_DELUGE) + .target(MoveTarget.BOTH_SIDES), new AttackMove(Moves.PARABOLIC_CHARGE, Type.ELECTRIC, MoveCategory.SPECIAL, 65, 100, 20, -1, 0, 6) .attr(HitHealAttr) .target(MoveTarget.ALL_NEAR_OTHERS) .triageMove(), new StatusMove(Moves.FORESTS_CURSE, Type.GRASS, 100, 20, -1, 0, 6) - .attr(AddTypeAttr, Type.GRASS) - .partial(), + .attr(AddTypeAttr, Type.GRASS), new AttackMove(Moves.PETAL_BLIZZARD, Type.GRASS, MoveCategory.PHYSICAL, 90, 100, 15, -1, 0, 6) .windMove() .makesContact(false) .target(MoveTarget.ALL_NEAR_OTHERS), new AttackMove(Moves.FREEZE_DRY, Type.ICE, MoveCategory.SPECIAL, 70, 100, 20, 10, 0, 6) .attr(StatusEffectAttr, StatusEffect.FREEZE) - .attr(WaterSuperEffectTypeMultiplierAttr) - .partial(), // This currently just multiplies the move's power instead of changing its effectiveness. It also doesn't account for abilities that modify type effectiveness such as tera shell. + .attr(FreezeDryAttr), new AttackMove(Moves.DISARMING_VOICE, Type.FAIRY, MoveCategory.SPECIAL, 40, -1, 15, -1, 0, 6) .soundBased() .target(MoveTarget.ALL_NEAR_ENEMIES), new StatusMove(Moves.PARTING_SHOT, Type.DARK, 100, 20, -1, 0, 6) - .attr(StatStageChangeAttr, [ Stat.ATK, Stat.SPATK ], -1, false, null, true, true, MoveEffectTrigger.PRE_APPLY) - .attr(ForceSwitchOutAttr, true, false) + .attr(StatStageChangeAttr, [ Stat.ATK, Stat.SPATK ], -1, false, { trigger: MoveEffectTrigger.PRE_APPLY }) + .attr(ForceSwitchOutAttr, true) .soundBased(), new StatusMove(Moves.TOPSY_TURVY, Type.DARK, -1, 20, -1, 0, 6) .attr(InvertStatsAttr), @@ -8396,7 +9460,7 @@ export function initMoves() { .condition(failIfLastCondition), new StatusMove(Moves.FLOWER_SHIELD, Type.FAIRY, -1, 10, -1, 0, 6) .target(MoveTarget.ALL) - .attr(StatStageChangeAttr, [ Stat.DEF ], 1, false, (user, target, move) => target.getTypes().includes(Type.GRASS) && !target.getTag(SemiInvulnerableTag)), + .attr(StatStageChangeAttr, [ Stat.DEF ], 1, false, { condition: (user, target, move) => target.getTypes().includes(Type.GRASS) && !target.getTag(SemiInvulnerableTag) }), new StatusMove(Moves.GRASSY_TERRAIN, Type.GRASS, -1, 10, -1, 0, 6) .attr(TerrainChangeAttr, TerrainType.GRASSY) .target(MoveTarget.BOTH_SIDES), @@ -8404,7 +9468,7 @@ export function initMoves() { .attr(TerrainChangeAttr, TerrainType.MISTY) .target(MoveTarget.BOTH_SIDES), new StatusMove(Moves.ELECTRIFY, Type.ELECTRIC, -1, 20, -1, 0, 6) - .unimplemented(), + .attr(AddBattlerTagAttr, BattlerTagType.ELECTRIFIED, false, true), new AttackMove(Moves.PLAY_ROUGH, Type.FAIRY, MoveCategory.PHYSICAL, 90, 90, 10, 10, 0, 6) .attr(StatStageChangeAttr, [ Stat.ATK ], -1), new AttackMove(Moves.FAIRY_WIND, Type.FAIRY, MoveCategory.SPECIAL, 40, 100, 30, -1, 0, 6) @@ -8416,8 +9480,9 @@ export function initMoves() { .target(MoveTarget.ALL_NEAR_OTHERS), new StatusMove(Moves.FAIRY_LOCK, Type.FAIRY, -1, 10, -1, 0, 6) .ignoresSubstitute() + .ignoresProtect() .target(MoveTarget.BOTH_SIDES) - .unimplemented(), + .attr(AddArenaTagAttr, ArenaTagType.FAIRY_LOCK, 2, true), new SelfStatusMove(Moves.KINGS_SHIELD, Type.STEEL, -1, 10, -1, 4, 6) .attr(ProtectAttr, BattlerTagType.KINGS_SHIELD) .condition(failIfLastCondition), @@ -8428,7 +9493,7 @@ export function initMoves() { .attr(StatStageChangeAttr, [ Stat.SPATK ], -1) .soundBased(), new AttackMove(Moves.DIAMOND_STORM, Type.ROCK, MoveCategory.PHYSICAL, 100, 95, 5, 50, 0, 6) - .attr(StatStageChangeAttr, [ Stat.DEF ], 2, true) + .attr(StatStageChangeAttr, [ Stat.DEF ], 2, true, { firstTargetOnly: true }) .makesContact(false) .target(MoveTarget.ALL_NEAR_ENEMIES), new AttackMove(Moves.STEAM_ERUPTION, Type.WATER, MoveCategory.SPECIAL, 110, 95, 5, 30, 0, 6) @@ -8450,25 +9515,26 @@ export function initMoves() { new StatusMove(Moves.AROMATIC_MIST, Type.FAIRY, -1, 20, -1, 0, 6) .attr(StatStageChangeAttr, [ Stat.SPDEF ], 1) .ignoresSubstitute() + .condition(failIfSingleBattle) .target(MoveTarget.NEAR_ALLY), new StatusMove(Moves.EERIE_IMPULSE, Type.ELECTRIC, 100, 15, -1, 0, 6) .attr(StatStageChangeAttr, [ Stat.SPATK ], -2), new StatusMove(Moves.VENOM_DRENCH, Type.POISON, 100, 20, -1, 0, 6) - .attr(StatStageChangeAttr, [ Stat.ATK, Stat.SPATK, Stat.SPD ], -1, false, (user, target, move) => target.status?.effect === StatusEffect.POISON || target.status?.effect === StatusEffect.TOXIC) + .attr(StatStageChangeAttr, [ Stat.ATK, Stat.SPATK, Stat.SPD ], -1, false, { condition: (user, target, move) => target.status?.effect === StatusEffect.POISON || target.status?.effect === StatusEffect.TOXIC }) .target(MoveTarget.ALL_NEAR_ENEMIES), new StatusMove(Moves.POWDER, Type.BUG, 100, 20, -1, 1, 6) .ignoresSubstitute() .powderMove() .unimplemented(), - new SelfStatusMove(Moves.GEOMANCY, Type.FAIRY, -1, 10, -1, 0, 6) - .attr(ChargeAttr, ChargeAnim.GEOMANCY_CHARGING, i18next.t("moveTriggers:isChargingPower", {pokemonName: "{USER}"})) + new ChargingSelfStatusMove(Moves.GEOMANCY, Type.FAIRY, -1, 10, -1, 0, 6) + .chargeText(i18next.t("moveTriggers:isChargingPower", { pokemonName: "{USER}" })) .attr(StatStageChangeAttr, [ Stat.SPATK, Stat.SPDEF, Stat.SPD ], 2, true) .ignoresVirtual(), new StatusMove(Moves.MAGNETIC_FLUX, Type.ELECTRIC, -1, 20, -1, 0, 6) - .attr(StatStageChangeAttr, [ Stat.DEF, Stat.SPDEF ], 1, false, (user, target, move) => !![ Abilities.PLUS, Abilities.MINUS].find(a => target.hasAbility(a, false))) + .attr(StatStageChangeAttr, [ Stat.DEF, Stat.SPDEF ], 1, false, { condition: (user, target, move) => !![ Abilities.PLUS, Abilities.MINUS ].find(a => target.hasAbility(a, false)) }) .ignoresSubstitute() .target(MoveTarget.USER_AND_ALLIES) - .condition((user, target, move) => !![ user, user.getAlly() ].filter(p => p?.isActive()).find(p => !![ Abilities.PLUS, Abilities.MINUS].find(a => p.hasAbility(a, false)))), + .condition((user, target, move) => !![ user, user.getAlly() ].filter(p => p?.isActive()).find(p => !![ Abilities.PLUS, Abilities.MINUS ].find(a => p.hasAbility(a, false)))), new StatusMove(Moves.HAPPY_HOUR, Type.NORMAL, -1, 30, -1, 0, 6) // No animation .attr(AddArenaTagAttr, ArenaTagType.HAPPY_HOUR, null, true) .target(MoveTarget.USER_SIDE), @@ -8499,10 +9565,10 @@ export function initMoves() { new AttackMove(Moves.THOUSAND_ARROWS, Type.GROUND, MoveCategory.PHYSICAL, 90, 100, 10, -1, 0, 6) .attr(NeutralDamageAgainstFlyingTypeMultiplierAttr) .attr(AddBattlerTagAttr, BattlerTagType.IGNORE_FLYING, false, false, 1, 1, true) - .attr(DealsDoubleDamageToTagAttr, BattlerTagType.FLYING, false) - .attr(DealsDoubleDamageToTagAttr, BattlerTagType.MAGNET_RISEN, false) + .attr(HitsTagAttr, BattlerTagType.FLYING) + .attr(HitsTagAttr, BattlerTagType.FLOATING) .attr(AddBattlerTagAttr, BattlerTagType.INTERRUPTED) - .attr(RemoveBattlerTagAttr, [BattlerTagType.FLYING, BattlerTagType.MAGNET_RISEN]) + .attr(RemoveBattlerTagAttr, [ BattlerTagType.FLYING, BattlerTagType.FLOATING, BattlerTagType.TELEKINESIS ]) .makesContact(false) .target(MoveTarget.ALL_NEAR_ENEMIES), new AttackMove(Moves.THOUSAND_WAVES, Type.GROUND, MoveCategory.PHYSICAL, 90, 100, 10, -1, 0, 6) @@ -8662,7 +9728,7 @@ export function initMoves() { .attr(StatStageChangeAttr, [ Stat.SPD ], -1, true) .punchingMove(), new StatusMove(Moves.FLORAL_HEALING, Type.FAIRY, -1, 10, -1, 0, 7) - .attr(BoostHealAttr, 0.5, 2/3, true, false, (user, target, move) => user.scene.arena.terrain?.terrainType === TerrainType.GRASSY) + .attr(BoostHealAttr, 0.5, 2 / 3, true, false, (user, target, move) => user.scene.arena.terrain?.terrainType === TerrainType.GRASSY) .triageMove(), new AttackMove(Moves.HIGH_HORSEPOWER, Type.GROUND, MoveCategory.PHYSICAL, 95, 95, 10, -1, 0, 7), new StatusMove(Moves.STRENGTH_SAP, Type.GRASS, 100, 10, -1, 0, 7) @@ -8670,24 +9736,26 @@ export function initMoves() { .attr(StatStageChangeAttr, [ Stat.ATK ], -1) .condition((user, target, move) => target.getStatStage(Stat.ATK) > -6) .triageMove(), - new AttackMove(Moves.SOLAR_BLADE, Type.GRASS, MoveCategory.PHYSICAL, 125, 100, 10, -1, 0, 7) - .attr(SunlightChargeAttr, ChargeAnim.SOLAR_BLADE_CHARGING, i18next.t("moveTriggers:isGlowing", {pokemonName: "{USER}"})) + new ChargingAttackMove(Moves.SOLAR_BLADE, Type.GRASS, MoveCategory.PHYSICAL, 125, 100, 10, -1, 0, 7) + .chargeText(i18next.t("moveTriggers:isGlowing", { pokemonName: "{USER}" })) + .chargeAttr(WeatherInstantChargeAttr, [ WeatherType.SUNNY, WeatherType.HARSH_SUN ]) .attr(AntiSunlightPowerDecreaseAttr) .slicingMove(), new AttackMove(Moves.LEAFAGE, Type.GRASS, MoveCategory.PHYSICAL, 40, 100, 40, -1, 0, 7) .makesContact(false), new StatusMove(Moves.SPOTLIGHT, Type.NORMAL, -1, 15, -1, 3, 7) - .attr(AddBattlerTagAttr, BattlerTagType.CENTER_OF_ATTENTION, false), + .attr(AddBattlerTagAttr, BattlerTagType.CENTER_OF_ATTENTION, false) + .condition(failIfSingleBattle), new StatusMove(Moves.TOXIC_THREAD, Type.POISON, 100, 20, -1, 0, 7) .attr(StatusEffectAttr, StatusEffect.POISON) .attr(StatStageChangeAttr, [ Stat.SPD ], -1), new SelfStatusMove(Moves.LASER_FOCUS, Type.NORMAL, -1, 30, -1, 0, 7) .attr(AddBattlerTagAttr, BattlerTagType.ALWAYS_CRIT, true, false), new StatusMove(Moves.GEAR_UP, Type.STEEL, -1, 20, -1, 0, 7) - .attr(StatStageChangeAttr, [ Stat.ATK, Stat.SPATK ], 1, false, (user, target, move) => !![ Abilities.PLUS, Abilities.MINUS].find(a => target.hasAbility(a, false))) + .attr(StatStageChangeAttr, [ Stat.ATK, Stat.SPATK ], 1, false, { condition: (user, target, move) => !![ Abilities.PLUS, Abilities.MINUS ].find(a => target.hasAbility(a, false)) }) .ignoresSubstitute() .target(MoveTarget.USER_AND_ALLIES) - .condition((user, target, move) => !![ user, user.getAlly() ].filter(p => p?.isActive()).find(p => !![ Abilities.PLUS, Abilities.MINUS].find(a => p.hasAbility(a, false)))), + .condition((user, target, move) => !![ user, user.getAlly() ].filter(p => p?.isActive()).find(p => !![ Abilities.PLUS, Abilities.MINUS ].find(a => p.hasAbility(a, false)))), new AttackMove(Moves.THROAT_CHOP, Type.DARK, MoveCategory.PHYSICAL, 80, 100, 15, 100, 0, 7) .attr(AddBattlerTagAttr, BattlerTagType.THROAT_CHOPPED), new AttackMove(Moves.POLLEN_PUFF, Type.BUG, MoveCategory.SPECIAL, 90, 100, 15, -1, 0, 7) @@ -8713,7 +9781,7 @@ export function initMoves() { .attr(HealStatusEffectAttr, true, StatusEffect.FREEZE) .attr(AddBattlerTagAttr, BattlerTagType.BURNED_UP, true, false) .attr(RemoveTypeAttr, Type.FIRE, (user) => { - user.scene.queueMessage(i18next.t("moveTriggers:burnedItselfOut", {pokemonName: getPokemonNameWithAffix(user)})); + user.scene.queueMessage(i18next.t("moveTriggers:burnedItselfOut", { pokemonName: getPokemonNameWithAffix(user) })); }), new StatusMove(Moves.SPEED_SWAP, Type.PSYCHIC, -1, 10, -1, 0, 7) .attr(SwapStatAttr, Stat.SPD) @@ -8723,7 +9791,7 @@ export function initMoves() { .condition( (user: Pokemon, target: Pokemon, move: Move) => isNonVolatileStatusEffect(target.status?.effect!)) // TODO: is this bang correct? .attr(HealAttr, 0.5) - .attr(HealStatusEffectAttr, false, ...getNonVolatileStatusEffects()) + .attr(HealStatusEffectAttr, false, getNonVolatileStatusEffects()) .triageMove(), new AttackMove(Moves.REVELATION_DANCE, Type.NORMAL, MoveCategory.SPECIAL, 90, 100, 15, -1, 0, 7) .danceMove() @@ -8741,7 +9809,7 @@ export function initMoves() { .ballBombMove() .makesContact(false), new AttackMove(Moves.CLANGING_SCALES, Type.DRAGON, MoveCategory.SPECIAL, 110, 100, 5, -1, 0, 7) - .attr(StatStageChangeAttr, [ Stat.DEF ], -1, true, null, true, false, MoveEffectTrigger.HIT, true) + .attr(StatStageChangeAttr, [ Stat.DEF ], -1, true, { firstTargetOnly: true }) .soundBased() .target(MoveTarget.ALL_NEAR_ENEMIES), new AttackMove(Moves.DRAGON_HAMMER, Type.DRAGON, MoveCategory.PHYSICAL, 90, 100, 15, -1, 0, 7), @@ -8754,15 +9822,15 @@ export function initMoves() { /* Unused */ new AttackMove(Moves.SINISTER_ARROW_RAID, Type.GHOST, MoveCategory.PHYSICAL, 180, -1, 1, -1, 0, 7) .makesContact(false) - .partial() + .edgeCase() // I assume it's because the user needs spirit shackle and decidueye .ignoresVirtual(), new AttackMove(Moves.MALICIOUS_MOONSAULT, Type.DARK, MoveCategory.PHYSICAL, 180, -1, 1, -1, 0, 7) .attr(AlwaysHitMinimizeAttr) - .attr(DealsDoubleDamageToTagAttr, BattlerTagType.MINIMIZED, true) - .partial() + .attr(HitsTagAttr, BattlerTagType.MINIMIZED, true) + .edgeCase() // I assume it's because it needs darkest lariat and incineroar .ignoresVirtual(), new AttackMove(Moves.OCEANIC_OPERETTA, Type.WATER, MoveCategory.SPECIAL, 195, -1, 1, -1, 0, 7) - .partial() + .edgeCase() // I assume it's because it needs sparkling aria and primarina .ignoresVirtual(), new AttackMove(Moves.GUARDIAN_OF_ALOLA, Type.FAIRY, MoveCategory.SPECIAL, -1, -1, 1, -1, 0, 7) .unimplemented() @@ -8771,10 +9839,10 @@ export function initMoves() { .unimplemented() .ignoresVirtual(), new AttackMove(Moves.STOKED_SPARKSURFER, Type.ELECTRIC, MoveCategory.SPECIAL, 175, -1, 1, 100, 0, 7) - .partial() + .edgeCase() // I assume it's because it needs thunderbolt and Alola Raichu .ignoresVirtual(), new AttackMove(Moves.PULVERIZING_PANCAKE, Type.NORMAL, MoveCategory.PHYSICAL, 210, -1, 1, -1, 0, 7) - .partial() + .edgeCase() // I assume it's because it needs giga impact and snorlax .ignoresVirtual(), new SelfStatusMove(Moves.EXTREME_EVOBOOST, Type.NORMAL, -1, 1, -1, 0, 7) .attr(StatStageChangeAttr, [ Stat.ATK, Stat.DEF, Stat.SPATK, Stat.SPDEF, Stat.SPD ], 2, true) @@ -8805,13 +9873,11 @@ export function initMoves() { .attr(RechargeAttr), new AttackMove(Moves.SPECTRAL_THIEF, Type.GHOST, MoveCategory.PHYSICAL, 90, 100, 10, -1, 0, 7) .ignoresSubstitute() - .partial(), + .partial(), // Does not steal stats new AttackMove(Moves.SUNSTEEL_STRIKE, Type.STEEL, MoveCategory.PHYSICAL, 100, 100, 5, -1, 0, 7) - .ignoresAbilities() - .partial(), + .ignoresAbilities(), new AttackMove(Moves.MOONGEIST_BEAM, Type.GHOST, MoveCategory.SPECIAL, 100, 100, 5, -1, 0, 7) - .ignoresAbilities() - .partial(), + .ignoresAbilities(), new StatusMove(Moves.TEARFUL_LOOK, Type.NORMAL, -1, 20, -1, 0, 7) .attr(StatStageChangeAttr, [ Stat.ATK, Stat.SPATK ], -1), new AttackMove(Moves.ZING_ZAP, Type.ELECTRIC, MoveCategory.PHYSICAL, 80, 100, 10, 30, 0, 7) @@ -8822,7 +9888,7 @@ export function initMoves() { .attr(FormChangeItemTypeAttr), /* Unused */ new AttackMove(Moves.TEN_MILLION_VOLT_THUNDERBOLT, Type.ELECTRIC, MoveCategory.SPECIAL, 195, -1, 1, -1, 0, 7) - .partial() + .edgeCase() // I assume it's because it needs thunderbolt and pikachu in a cap .ignoresVirtual(), /* End Unused */ new AttackMove(Moves.MIND_BLOWN, Type.FIRE, MoveCategory.SPECIAL, 150, 100, 5, -1, 0, 7) @@ -8830,12 +9896,11 @@ export function initMoves() { .attr(HalfSacrificialAttr) .target(MoveTarget.ALL_NEAR_OTHERS), new AttackMove(Moves.PLASMA_FISTS, Type.ELECTRIC, MoveCategory.PHYSICAL, 100, 100, 15, -1, 0, 7) - .punchingMove() - .partial(), + .attr(AddArenaTagAttr, ArenaTagType.ION_DELUGE, 1) + .punchingMove(), new AttackMove(Moves.PHOTON_GEYSER, Type.PSYCHIC, MoveCategory.SPECIAL, 100, 100, 5, -1, 0, 7) .attr(PhotonGeyserCategoryAttr) - .ignoresAbilities() - .partial(), + .ignoresAbilities(), /* Unused */ new AttackMove(Moves.LIGHT_THAT_BURNS_THE_SKY, Type.PSYCHIC, MoveCategory.SPECIAL, 200, -1, 1, -1, 0, 7) .attr(PhotonGeyserCategoryAttr) @@ -8848,20 +9913,20 @@ export function initMoves() { .ignoresAbilities() .ignoresVirtual(), new AttackMove(Moves.LETS_SNUGGLE_FOREVER, Type.FAIRY, MoveCategory.PHYSICAL, 190, -1, 1, -1, 0, 7) - .partial() + .edgeCase() // I assume it needs play rough and mimikyu .ignoresVirtual(), new AttackMove(Moves.SPLINTERED_STORMSHARDS, Type.ROCK, MoveCategory.PHYSICAL, 190, -1, 1, -1, 0, 7) .attr(ClearTerrainAttr) .makesContact(false) .ignoresVirtual(), new AttackMove(Moves.CLANGOROUS_SOULBLAZE, Type.DRAGON, MoveCategory.SPECIAL, 185, -1, 1, 100, 0, 7) - .attr(StatStageChangeAttr, [ Stat.ATK, Stat.DEF, Stat.SPATK, Stat.SPDEF, Stat.SPD ], 1, true) + .attr(StatStageChangeAttr, [ Stat.ATK, Stat.DEF, Stat.SPATK, Stat.SPDEF, Stat.SPD ], 1, true, { firstTargetOnly: true }) .soundBased() .target(MoveTarget.ALL_NEAR_ENEMIES) - .partial() + .edgeCase() // I assume it needs clanging scales and Kommo-O .ignoresVirtual(), /* End Unused */ - new AttackMove(Moves.ZIPPY_ZAP, Type.ELECTRIC, MoveCategory.PHYSICAL, 50, 100, 15, 100, 2, 7) //LGPE Implementation + new AttackMove(Moves.ZIPPY_ZAP, Type.ELECTRIC, MoveCategory.PHYSICAL, 50, 100, 15, -1, 2, 7) // LGPE Implementation .attr(CritOnlyAttr), new AttackMove(Moves.SPLISHY_SPLASH, Type.WATER, MoveCategory.SPECIAL, 90, 100, 15, 30, 0, 7) .attr(StatusEffectAttr, StatusEffect.PARALYSIS) @@ -8871,7 +9936,7 @@ export function initMoves() { new AttackMove(Moves.PIKA_PAPOW, Type.ELECTRIC, MoveCategory.SPECIAL, -1, -1, 20, -1, 0, 7) .attr(FriendshipPowerAttr), new AttackMove(Moves.BOUNCY_BUBBLE, Type.WATER, MoveCategory.SPECIAL, 60, 100, 20, -1, 0, 7) - .attr(HitHealAttr, 1.0) + .attr(HitHealAttr) // Custom .triageMove() .target(MoveTarget.ALL_NEAR_ENEMIES), new AttackMove(Moves.BUZZY_BUZZ, Type.ELECTRIC, MoveCategory.SPECIAL, 60, 100, 20, 100, 0, 7) @@ -8883,8 +9948,8 @@ export function initMoves() { new AttackMove(Moves.BADDY_BAD, Type.DARK, MoveCategory.SPECIAL, 80, 95, 15, -1, 0, 7) .attr(AddArenaTagAttr, ArenaTagType.REFLECT, 5, false, true), new AttackMove(Moves.SAPPY_SEED, Type.GRASS, MoveCategory.PHYSICAL, 100, 90, 10, 100, 0, 7) - .makesContact(false) - .attr(AddBattlerTagAttr, BattlerTagType.SEEDED), + .attr(LeechSeedAttr) + .makesContact(false), new AttackMove(Moves.FREEZY_FROST, Type.ICE, MoveCategory.SPECIAL, 100, 90, 10, -1, 0, 7) .attr(ResetStatsAttr, true), new AttackMove(Moves.SPARKLY_SWIRL, Type.FAIRY, MoveCategory.SPECIAL, 120, 85, 5, -1, 0, 7) @@ -8921,14 +9986,14 @@ export function initMoves() { new AttackMove(Moves.JAW_LOCK, Type.DARK, MoveCategory.PHYSICAL, 80, 100, 10, -1, 0, 8) .attr(JawLockAttr) .bitingMove(), - new SelfStatusMove(Moves.STUFF_CHEEKS, Type.NORMAL, -1, 10, -1, 0, 8) // TODO: Stuff Cheeks should not be selectable when the user does not have a berry, see wiki + new SelfStatusMove(Moves.STUFF_CHEEKS, Type.NORMAL, -1, 10, -1, 0, 8) .attr(EatBerryAttr) .attr(StatStageChangeAttr, [ Stat.DEF ], 2, true) .condition((user) => { const userBerries = user.scene.findModifiers(m => m instanceof BerryModifier, user.isPlayer()); return userBerries.length > 0; }) - .partial(), + .edgeCase(), // Stuff Cheeks should not be selectable when the user does not have a berry, see wiki new SelfStatusMove(Moves.NO_RETREAT, Type.FIGHTING, -1, 5, -1, 0, 8) .attr(StatStageChangeAttr, [ Stat.ATK, Stat.DEF, Stat.SPATK, Stat.SPDEF, Stat.SPD ], 1, true) .attr(AddBattlerTagAttr, BattlerTagType.NO_RETREAT, true, false) @@ -8942,7 +10007,7 @@ export function initMoves() { new AttackMove(Moves.DRAGON_DARTS, Type.DRAGON, MoveCategory.PHYSICAL, 50, 100, 10, -1, 0, 8) .attr(MultiHitAttr, MultiHitType._2) .makesContact(false) - .partial(), + .partial(), // smart targetting is unimplemented new StatusMove(Moves.TEATIME, Type.NORMAL, -1, 10, -1, 0, 8) .attr(EatBerryAttr) .target(MoveTarget.ALL), @@ -8954,7 +10019,7 @@ export function initMoves() { .attr(FirstAttackDoublePowerAttr) .bitingMove(), new StatusMove(Moves.COURT_CHANGE, Type.NORMAL, 100, 10, -1, 0, 8) - .attr(SwapArenaTagsAttr, [ArenaTagType.AURORA_VEIL, ArenaTagType.LIGHT_SCREEN, ArenaTagType.MIST, ArenaTagType.REFLECT, ArenaTagType.SPIKES, ArenaTagType.STEALTH_ROCK, ArenaTagType.STICKY_WEB, ArenaTagType.TAILWIND, ArenaTagType.TOXIC_SPIKES]), + .attr(SwapArenaTagsAttr, [ ArenaTagType.AURORA_VEIL, ArenaTagType.LIGHT_SCREEN, ArenaTagType.MIST, ArenaTagType.REFLECT, ArenaTagType.SPIKES, ArenaTagType.STEALTH_ROCK, ArenaTagType.STICKY_WEB, ArenaTagType.TAILWIND, ArenaTagType.TOXIC_SPIKES ]), new AttackMove(Moves.MAX_FLARE, Type.FIRE, MoveCategory.PHYSICAL, 10, -1, 10, -1, 0, 8) .target(MoveTarget.NEAR_ENEMY) .unimplemented() @@ -9053,8 +10118,7 @@ export function initMoves() { new AttackMove(Moves.AURA_WHEEL, Type.ELECTRIC, MoveCategory.PHYSICAL, 110, 100, 10, 100, 0, 8) .attr(StatStageChangeAttr, [ Stat.SPD ], 1, true) .makesContact(false) - .attr(AuraWheelTypeAttr) - .condition((user, target, move) => [user.species.speciesId, user.fusionSpecies?.speciesId].includes(Species.MORPEKO)), // Missing custom fail message + .attr(AuraWheelTypeAttr), new AttackMove(Moves.BREAKING_SWIPE, Type.DRAGON, MoveCategory.PHYSICAL, 60, 100, 15, 100, 0, 8) .target(MoveTarget.ALL_NEAR_ENEMIES) .attr(StatStageChangeAttr, [ Stat.ATK ], -1), @@ -9089,24 +10153,23 @@ export function initMoves() { .attr(HalfSacrificialAttr), new AttackMove(Moves.EXPANDING_FORCE, Type.PSYCHIC, MoveCategory.SPECIAL, 80, 100, 10, -1, 0, 8) .attr(MovePowerMultiplierAttr, (user, target, move) => user.scene.arena.getTerrainType() === TerrainType.PSYCHIC && user.isGrounded() ? 1.5 : 1) - .attr(VariableTargetAttr, (user, target, move) => user.scene.arena.getTerrainType() === TerrainType.PSYCHIC && user.isGrounded() ? 6 : 3), + .attr(VariableTargetAttr, (user, target, move) => user.scene.arena.getTerrainType() === TerrainType.PSYCHIC && user.isGrounded() ? MoveTarget.ALL_NEAR_ENEMIES : MoveTarget.NEAR_OTHER), new AttackMove(Moves.STEEL_ROLLER, Type.STEEL, MoveCategory.PHYSICAL, 130, 100, 5, -1, 0, 8) .attr(ClearTerrainAttr) .condition((user, target, move) => !!user.scene.arena.terrain), new AttackMove(Moves.SCALE_SHOT, Type.DRAGON, MoveCategory.PHYSICAL, 25, 90, 20, -1, 0, 8) - //.attr(StatStageChangeAttr, Stat.SPD, 1, true) // TODO: Have boosts only apply at end of move, not after every hit - //.attr(StatStageChangeAttr, Stat.DEF, -1, true) + .attr(StatStageChangeAttr, [ Stat.SPD ], 1, true, { lastHitOnly: true }) + .attr(StatStageChangeAttr, [ Stat.DEF ], -1, true, { lastHitOnly: true }) .attr(MultiHitAttr) - .makesContact(false) - .partial(), - new AttackMove(Moves.METEOR_BEAM, Type.ROCK, MoveCategory.SPECIAL, 120, 90, 10, 100, 0, 8) - .attr(ChargeAttr, ChargeAnim.METEOR_BEAM_CHARGING, i18next.t("moveTriggers:isOverflowingWithSpacePower", {pokemonName: "{USER}"}), null, true) - .attr(StatStageChangeAttr, [ Stat.SPATK ], 1, true) + .makesContact(false), + new ChargingAttackMove(Moves.METEOR_BEAM, Type.ROCK, MoveCategory.SPECIAL, 120, 90, 10, -1, 0, 8) + .chargeText(i18next.t("moveTriggers:isOverflowingWithSpacePower", { pokemonName: "{USER}" })) + .chargeAttr(StatStageChangeAttr, [ Stat.SPATK ], 1, true) .ignoresVirtual(), new AttackMove(Moves.SHELL_SIDE_ARM, Type.POISON, MoveCategory.SPECIAL, 90, 100, 10, 20, 0, 8) .attr(ShellSideArmCategoryAttr) .attr(StatusEffectAttr, StatusEffect.POISON) - .partial(), + .partial(), // Physical version of the move does not make contact new AttackMove(Moves.MISTY_EXPLOSION, Type.FAIRY, MoveCategory.SPECIAL, 100, 100, 5, -1, 0, 8) .attr(SacrificialAttr) .target(MoveTarget.ALL_NEAR_OTHERS) @@ -9136,9 +10199,10 @@ export function initMoves() { .unimplemented(), new StatusMove(Moves.COACHING, Type.FIGHTING, -1, 10, -1, 0, 8) .attr(StatStageChangeAttr, [ Stat.ATK, Stat.DEF ], 1) - .target(MoveTarget.NEAR_ALLY), + .target(MoveTarget.NEAR_ALLY) + .condition(failIfSingleBattle), new AttackMove(Moves.FLIP_TURN, Type.WATER, MoveCategory.PHYSICAL, 60, 100, 20, -1, 0, 8) - .attr(ForceSwitchOutAttr, true, false), + .attr(ForceSwitchOutAttr, true), new AttackMove(Moves.TRIPLE_AXEL, Type.ICE, MoveCategory.PHYSICAL, 20, 90, 10, -1, 0, 8) .attr(MultiHitAttr, MultiHitType._3) .attr(MultiHitPowerIncrementAttr, 3) @@ -9151,7 +10215,7 @@ export function initMoves() { .attr(StatusEffectAttr, StatusEffect.BURN), new StatusMove(Moves.JUNGLE_HEALING, Type.GRASS, -1, 10, -1, 0, 8) .attr(HealAttr, 0.25, true, false) - .attr(HealStatusEffectAttr, false, StatusEffect.PARALYSIS, StatusEffect.POISON, StatusEffect.TOXIC, StatusEffect.BURN, StatusEffect.SLEEP) + .attr(HealStatusEffectAttr, false, getNonVolatileStatusEffects()) .target(MoveTarget.USER_AND_ALLIES), new AttackMove(Moves.WICKED_BLOW, Type.DARK, MoveCategory.PHYSICAL, 75, 100, 5, -1, 0, 8) .attr(CritOnlyAttr) @@ -9181,7 +10245,7 @@ export function initMoves() { .attr(AttackReducePpMoveAttr, 3) .soundBased(), new AttackMove(Moves.DIRE_CLAW, Type.POISON, MoveCategory.PHYSICAL, 80, 100, 15, 50, 0, 8) - .attr(MultiStatusEffectAttr, [StatusEffect.POISON, StatusEffect.PARALYSIS, StatusEffect.SLEEP]), + .attr(MultiStatusEffectAttr, [ StatusEffect.POISON, StatusEffect.PARALYSIS, StatusEffect.SLEEP ]), new AttackMove(Moves.PSYSHIELD_BASH, Type.PSYCHIC, MoveCategory.PHYSICAL, 70, 90, 10, 100, 0, 8) .attr(StatStageChangeAttr, [ Stat.DEF ], 1, true), new SelfStatusMove(Moves.POWER_SHIFT, Type.NORMAL, -1, 10, -1, 0, 8) @@ -9230,9 +10294,8 @@ export function initMoves() { new AttackMove(Moves.TRIPLE_ARROWS, Type.FIGHTING, MoveCategory.PHYSICAL, 90, 100, 10, 30, 0, 8) .makesContact(false) .attr(HighCritAttr) - .attr(StatStageChangeAttr, [ Stat.DEF ], -1) - .attr(FlinchAttr) - .partial(), + .attr(StatStageChangeAttr, [ Stat.DEF ], -1, false, { effectChanceOverride: 50 }) + .attr(FlinchAttr), new AttackMove(Moves.INFERNAL_PARADE, Type.GHOST, MoveCategory.SPECIAL, 60, 100, 15, 30, 0, 8) .attr(StatusEffectAttr, StatusEffect.BURN) .attr(MovePowerMultiplierAttr, (user, target, move) => target.status ? 2 : 1), @@ -9256,12 +10319,12 @@ export function initMoves() { .target(MoveTarget.ALL_NEAR_ENEMIES), new StatusMove(Moves.LUNAR_BLESSING, Type.PSYCHIC, -1, 5, -1, 0, 8) .attr(HealAttr, 0.25, true, false) - .attr(HealStatusEffectAttr, false, StatusEffect.PARALYSIS, StatusEffect.POISON, StatusEffect.TOXIC, StatusEffect.BURN, StatusEffect.SLEEP) + .attr(HealStatusEffectAttr, false, getNonVolatileStatusEffects()) .target(MoveTarget.USER_AND_ALLIES) .triageMove(), new SelfStatusMove(Moves.TAKE_HEART, Type.PSYCHIC, -1, 10, -1, 0, 8) .attr(StatStageChangeAttr, [ Stat.SPATK, Stat.SPDEF ], 1, true) - .attr(HealStatusEffectAttr, true, StatusEffect.PARALYSIS, StatusEffect.POISON, StatusEffect.TOXIC, StatusEffect.BURN, StatusEffect.SLEEP), + .attr(HealStatusEffectAttr, true, [ StatusEffect.PARALYSIS, StatusEffect.POISON, StatusEffect.TOXIC, StatusEffect.BURN, StatusEffect.SLEEP ]), /* Unused new AttackMove(Moves.G_MAX_WILDFIRE, Type.FIRE, MoveCategory.PHYSICAL, 10, -1, 10, -1, 0, 8) .target(MoveTarget.ALL_NEAR_ENEMIES) @@ -9364,10 +10427,11 @@ export function initMoves() { .unimplemented(), End Unused */ new AttackMove(Moves.TERA_BLAST, Type.NORMAL, MoveCategory.SPECIAL, 80, 100, 10, -1, 0, 9) - .attr(TeraBlastCategoryAttr) + .attr(TeraMoveCategoryAttr) .attr(TeraBlastTypeAttr) .attr(TeraBlastPowerAttr) - .attr(StatStageChangeAttr, [ Stat.ATK, Stat.SPATK ], -1, true, (user, target, move) => user.isTerastallized() && user.isOfType(Type.STELLAR)), + .attr(StatStageChangeAttr, [ Stat.ATK, Stat.SPATK ], -1, true, { condition: (user, target, move) => user.isTerastallized() && user.isOfType(Type.STELLAR) }) + .partial(), /** Does not ignore abilities that affect stats, relevant in determining the move's category {@see TeraMoveCategoryAttr} */ new SelfStatusMove(Moves.SILK_TRAP, Type.BUG, -1, 10, -1, 4, 9) .attr(ProtectAttr, BattlerTagType.SILK_TRAP) .condition(failIfLastCondition), @@ -9377,13 +10441,14 @@ export function initMoves() { .attr(ConfuseAttr) .recklessMove(), new AttackMove(Moves.LAST_RESPECTS, Type.GHOST, MoveCategory.PHYSICAL, 50, 100, 10, -1, 0, 9) + .partial() // Counter resets every wave instead of on arena reset .attr(MovePowerMultiplierAttr, (user, target, move) => 1 + Math.min(user.isPlayer() ? user.scene.currentBattle.playerFaints : user.scene.currentBattle.enemyFaints, 100)) .makesContact(false), new AttackMove(Moves.LUMINA_CRASH, Type.PSYCHIC, MoveCategory.SPECIAL, 80, 100, 10, 100, 0, 9) .attr(StatStageChangeAttr, [ Stat.SPDEF ], -2), new AttackMove(Moves.ORDER_UP, Type.DRAGON, MoveCategory.PHYSICAL, 80, 100, 10, 100, 0, 9) - .makesContact(false) - .partial(), + .attr(OrderUpStatBoostAttr) + .makesContact(false), new AttackMove(Moves.JET_PUNCH, Type.WATER, MoveCategory.PHYSICAL, 60, 100, 15, -1, 1, 9) .punchingMove(), new StatusMove(Moves.SPICY_EXTRACT, Type.GRASS, -1, 15, -1, 0, 9) @@ -9449,29 +10514,30 @@ export function initMoves() { .attr(RemoveScreensAttr), new AttackMove(Moves.MAKE_IT_RAIN, Type.STEEL, MoveCategory.SPECIAL, 120, 100, 5, -1, 0, 9) .attr(MoneyAttr) - .attr(StatStageChangeAttr, [ Stat.SPATK ], -1, true, null, true, false, MoveEffectTrigger.HIT, true) + .attr(StatStageChangeAttr, [ Stat.SPATK ], -1, true, { firstTargetOnly: true }) .target(MoveTarget.ALL_NEAR_ENEMIES), new AttackMove(Moves.PSYBLADE, Type.PSYCHIC, MoveCategory.PHYSICAL, 80, 100, 15, -1, 0, 9) .attr(MovePowerMultiplierAttr, (user, target, move) => user.scene.arena.getTerrainType() === TerrainType.ELECTRIC && user.isGrounded() ? 1.5 : 1) .slicingMove(), new AttackMove(Moves.HYDRO_STEAM, Type.WATER, MoveCategory.SPECIAL, 80, 100, 15, -1, 0, 9) .attr(IgnoreWeatherTypeDebuffAttr, WeatherType.SUNNY) - .attr(MovePowerMultiplierAttr, (user, target, move) => [WeatherType.SUNNY, WeatherType.HARSH_SUN].includes(user.scene.arena.weather?.weatherType!) && !user.scene.arena.weather?.isEffectSuppressed(user.scene) ? 1.5 : 1), // TODO: is this bang correct? + .attr(MovePowerMultiplierAttr, (user, target, move) => [ WeatherType.SUNNY, WeatherType.HARSH_SUN ].includes(user.scene.arena.weather?.weatherType!) && !user.scene.arena.weather?.isEffectSuppressed(user.scene) ? 1.5 : 1), // TODO: is this bang correct? new AttackMove(Moves.RUINATION, Type.DARK, MoveCategory.SPECIAL, -1, 90, 10, -1, 0, 9) .attr(TargetHalfHpDamageAttr), new AttackMove(Moves.COLLISION_COURSE, Type.FIGHTING, MoveCategory.PHYSICAL, 100, 100, 5, -1, 0, 9) - .attr(MovePowerMultiplierAttr, (user, target, move) => target.getAttackTypeEffectiveness(move.type, user) >= 2 ? 5461/4096 : 1), + .attr(MovePowerMultiplierAttr, (user, target, move) => target.getAttackTypeEffectiveness(move.type, user) >= 2 ? 5461 / 4096 : 1), new AttackMove(Moves.ELECTRO_DRIFT, Type.ELECTRIC, MoveCategory.SPECIAL, 100, 100, 5, -1, 0, 9) - .attr(MovePowerMultiplierAttr, (user, target, move) => target.getAttackTypeEffectiveness(move.type, user) >= 2 ? 5461/4096 : 1) + .attr(MovePowerMultiplierAttr, (user, target, move) => target.getAttackTypeEffectiveness(move.type, user) >= 2 ? 5461 / 4096 : 1) .makesContact(), new SelfStatusMove(Moves.SHED_TAIL, Type.NORMAL, -1, 10, -1, 0, 9) - .unimplemented(), - new StatusMove(Moves.CHILLY_RECEPTION, Type.ICE, -1, 10, -1, 0, 9) - .attr(WeatherChangeAttr, WeatherType.SNOW) - .attr(ForceSwitchOutAttr, true, false) - .target(MoveTarget.BOTH_SIDES), + .attr(AddSubstituteAttr, 0.5) + .attr(ForceSwitchOutAttr, true, SwitchType.SHED_TAIL) + .condition(failIfLastInPartyCondition), + new SelfStatusMove(Moves.CHILLY_RECEPTION, Type.ICE, -1, 10, -1, 0, 9) + .attr(PreMoveMessageAttr, (user, move) => i18next.t("moveTriggers:chillyReception", { pokemonName: getPokemonNameWithAffix(user) })) + .attr(ChillyReceptionAttr, true), new SelfStatusMove(Moves.TIDY_UP, Type.NORMAL, -1, 10, -1, 0, 9) - .attr(StatStageChangeAttr, [ Stat.ATK, Stat.SPD ], 1, true, null, true, true) + .attr(StatStageChangeAttr, [ Stat.ATK, Stat.SPD ], 1, true) .attr(RemoveArenaTrapAttr, true) .attr(RemoveAllSubstitutesAttr), new StatusMove(Moves.SNOWSCAPE, Type.ICE, -1, 10, -1, 0, 9) @@ -9503,7 +10569,7 @@ export function initMoves() { }) .attr(AddBattlerTagAttr, BattlerTagType.DOUBLE_SHOCKED, true, false) .attr(RemoveTypeAttr, Type.ELECTRIC, (user) => { - user.scene.queueMessage(i18next.t("moveTriggers:usedUpAllElectricity", {pokemonName: getPokemonNameWithAffix(user)})); + user.scene.queueMessage(i18next.t("moveTriggers:usedUpAllElectricity", { pokemonName: getPokemonNameWithAffix(user) })); }), new AttackMove(Moves.GIGATON_HAMMER, Type.STEEL, MoveCategory.PHYSICAL, 160, 100, 5, -1, 0, 9) .makesContact(false) @@ -9547,19 +10613,22 @@ export function initMoves() { .target(MoveTarget.ALL_NEAR_ENEMIES) .triageMove(), new AttackMove(Moves.SYRUP_BOMB, Type.GRASS, MoveCategory.SPECIAL, 60, 85, 10, -1, 0, 9) - .attr(StatStageChangeAttr, [ Stat.SPD ], -1) //Temporary - .ballBombMove() - .partial(), + .attr(AddBattlerTagAttr, BattlerTagType.SYRUP_BOMB, false, false, 3) + .ballBombMove(), new AttackMove(Moves.IVY_CUDGEL, Type.GRASS, MoveCategory.PHYSICAL, 100, 100, 10, -1, 0, 9) .attr(IvyCudgelTypeAttr) .attr(HighCritAttr) .makesContact(false), - new AttackMove(Moves.ELECTRO_SHOT, Type.ELECTRIC, MoveCategory.SPECIAL, 130, 100, 10, 100, 0, 9) - .attr(ElectroShotChargeAttr) + new ChargingAttackMove(Moves.ELECTRO_SHOT, Type.ELECTRIC, MoveCategory.SPECIAL, 130, 100, 10, 100, 0, 9) + .chargeText(i18next.t("moveTriggers:absorbedElectricity", { pokemonName: "{USER}" })) + .chargeAttr(StatStageChangeAttr, [ Stat.SPATK ], 1, true) + .chargeAttr(WeatherInstantChargeAttr, [ WeatherType.RAIN, WeatherType.HEAVY_RAIN ]) .ignoresVirtual(), new AttackMove(Moves.TERA_STARSTORM, Type.NORMAL, MoveCategory.SPECIAL, 120, 100, 5, -1, 0, 9) - .attr(TeraBlastCategoryAttr) - .partial(), + .attr(TeraMoveCategoryAttr) + .attr(TeraStarstormTypeAttr) + .attr(VariableTargetAttr, (user, target, move) => (user.hasFusionSpecies(Species.TERAPAGOS) || user.species.speciesId === Species.TERAPAGOS) && user.isTerastallized() ? MoveTarget.ALL_NEAR_ENEMIES : MoveTarget.NEAR_OTHER) + .partial(), /** Does not ignore abilities that affect stats, relevant in determining the move's category {@see TeraMoveCategoryAttr} */ new AttackMove(Moves.FICKLE_BEAM, Type.DRAGON, MoveCategory.SPECIAL, 80, 100, 5, 30, 0, 9) .attr(PreMoveMessageAttr, doublePowerChanceMessageFunc) .attr(DoublePowerChanceAttr), @@ -9590,12 +10659,10 @@ export function initMoves() { .recklessMove(), new AttackMove(Moves.PSYCHIC_NOISE, Type.PSYCHIC, MoveCategory.SPECIAL, 75, 100, 10, -1, 0, 9) .soundBased() - .partial(), + .attr(AddBattlerTagAttr, BattlerTagType.HEAL_BLOCK, false, false, 2), new AttackMove(Moves.UPPER_HAND, Type.FIGHTING, MoveCategory.PHYSICAL, 65, 100, 15, 100, 3, 9) .attr(FlinchAttr) - .condition((user, target, move) => user.scene.currentBattle.turnCommands[target.getBattlerIndex()]?.command === Command.FIGHT && !target.turnData.acted && allMoves[user.scene.currentBattle.turnCommands[target.getBattlerIndex()]?.move?.move!].category !== MoveCategory.STATUS && allMoves[user.scene.currentBattle.turnCommands[target.getBattlerIndex()]?.move?.move!].priority > 0 ) // TODO: is this bang correct? - //TODO: Should also apply when target move priority increased by ability ex. gale wings - .partial(), + .condition(new UpperHandCondition()), new AttackMove(Moves.MALIGNANT_CHAIN, Type.POISON, MoveCategory.SPECIAL, 100, 100, 5, 50, 0, 9) .attr(StatusEffectAttr, StatusEffect.TOXIC) ); diff --git a/src/data/mystery-encounters/encounters/a-trainers-test-encounter.ts b/src/data/mystery-encounters/encounters/a-trainers-test-encounter.ts index b66ca10c9f5..f0155b4f2a4 100644 --- a/src/data/mystery-encounters/encounters/a-trainers-test-encounter.ts +++ b/src/data/mystery-encounters/encounters/a-trainers-test-encounter.ts @@ -2,7 +2,7 @@ import { EnemyPartyConfig, initBattleWithEnemyConfig, leaveEncounterWithoutBattl import { trainerConfigs, } from "#app/data/trainer-config"; import { MysteryEncounterType } from "#enums/mystery-encounter-type"; import BattleScene from "#app/battle-scene"; -import MysteryEncounter, { MysteryEncounterBuilder } from "../mystery-encounter"; +import MysteryEncounter, { MysteryEncounterBuilder } from "#app/data/mystery-encounters/mystery-encounter"; import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; import { TrainerType } from "#enums/trainer-type"; import { Species } from "#enums/species"; @@ -15,9 +15,10 @@ import { EggTier } from "#enums/egg-type"; import { PartyHealPhase } from "#app/phases/party-heal-phase"; import { ModifierTier } from "#app/modifier/modifier-tier"; import { modifierTypes } from "#app/modifier/modifier-type"; +import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES } from "#app/game-mode"; /** the i18n namespace for the encounter */ -const namespace = "mysteryEncounter:aTrainersTest"; +const namespace = "mysteryEncounters/aTrainersTest"; /** * A Trainer's Test encounter. @@ -27,11 +28,11 @@ const namespace = "mysteryEncounter:aTrainersTest"; export const ATrainersTestEncounter: MysteryEncounter = MysteryEncounterBuilder.withEncounterType(MysteryEncounterType.A_TRAINERS_TEST) .withEncounterTier(MysteryEncounterTier.ROGUE) - .withSceneWaveRangeRequirement(100, 180) + .withSceneWaveRangeRequirement(100, CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES[1]) .withIntroSpriteConfigs([]) // These are set in onInit() .withIntroDialogue([ { - text: `${namespace}.intro`, + text: `${namespace}:intro`, }, ]) .withAutoHideIntroVisuals(false) @@ -43,63 +44,63 @@ export const ATrainersTestEncounter: MysteryEncounter = let spriteKeys; let trainerNameKey: string; switch (randSeedInt(5)) { - default: - case 0: - trainerType = TrainerType.BUCK; - spriteKeys = getSpriteKeysFromSpecies(Species.CLAYDOL); - trainerNameKey = "buck"; - break; - case 1: - trainerType = TrainerType.CHERYL; - spriteKeys = getSpriteKeysFromSpecies(Species.BLISSEY); - trainerNameKey = "cheryl"; - break; - case 2: - trainerType = TrainerType.MARLEY; - spriteKeys = getSpriteKeysFromSpecies(Species.ARCANINE); - trainerNameKey = "marley"; - break; - case 3: - trainerType = TrainerType.MIRA; - spriteKeys = getSpriteKeysFromSpecies(Species.ALAKAZAM, false, 1); - trainerNameKey = "mira"; - break; - case 4: - trainerType = TrainerType.RILEY; - spriteKeys = getSpriteKeysFromSpecies(Species.LUCARIO, false, 1); - trainerNameKey = "riley"; - break; + default: + case 0: + trainerType = TrainerType.BUCK; + spriteKeys = getSpriteKeysFromSpecies(Species.CLAYDOL); + trainerNameKey = "buck"; + break; + case 1: + trainerType = TrainerType.CHERYL; + spriteKeys = getSpriteKeysFromSpecies(Species.BLISSEY); + trainerNameKey = "cheryl"; + break; + case 2: + trainerType = TrainerType.MARLEY; + spriteKeys = getSpriteKeysFromSpecies(Species.ARCANINE); + trainerNameKey = "marley"; + break; + case 3: + trainerType = TrainerType.MIRA; + spriteKeys = getSpriteKeysFromSpecies(Species.ALAKAZAM, false, 1); + trainerNameKey = "mira"; + break; + case 4: + trainerType = TrainerType.RILEY; + spriteKeys = getSpriteKeysFromSpecies(Species.LUCARIO, false, 1); + trainerNameKey = "riley"; + break; } // Dialogue and tokens for trainer encounter.dialogue.intro = [ { speaker: `trainerNames:${trainerNameKey}`, - text: `${namespace}.${trainerNameKey}.intro_dialogue` + text: `${namespace}:${trainerNameKey}.intro_dialogue` } ]; encounter.options[0].dialogue!.selected = [ { speaker: `trainerNames:${trainerNameKey}`, - text: `${namespace}.${trainerNameKey}.accept` + text: `${namespace}:${trainerNameKey}.accept` } ]; encounter.options[1].dialogue!.selected = [ { speaker: `trainerNames:${trainerNameKey}`, - text: `${namespace}.${trainerNameKey}.decline` + text: `${namespace}:${trainerNameKey}.decline` } ]; encounter.setDialogueToken("statTrainerName", i18next.t(`trainerNames:${trainerNameKey}`)); - const eggDescription = i18next.t(`${namespace}.title`) + ":\n" + i18next.t(`trainerNames:${trainerNameKey}`); + const eggDescription = i18next.t(`${namespace}:title`) + ":\n" + i18next.t(`trainerNames:${trainerNameKey}`); encounter.misc = { trainerType, trainerNameKey, trainerEggDescription: eggDescription }; // Trainer config const trainerConfig = trainerConfigs[trainerType].clone(); const trainerSpriteKey = trainerConfig.getSpriteKey(); encounter.enemyPartyConfigs.push({ - levelAdditiveMultiplier: 1, + levelAdditiveModifier: 1, trainerConfig: trainerConfig }); @@ -127,14 +128,15 @@ export const ATrainersTestEncounter: MysteryEncounter = return true; }) - .withTitle(`${namespace}.title`) - .withDescription(`${namespace}.description`) - .withQuery(`${namespace}.query`) + .setLocalizationKey(`${namespace}`) + .withTitle(`${namespace}:title`) + .withDescription(`${namespace}:description`) + .withQuery(`${namespace}:query`) .withIntroDialogue() .withSimpleOption( { - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip` + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip` }, async (scene: BattleScene) => { const encounter = scene.currentBattle.mysteryEncounter!; @@ -148,18 +150,17 @@ export const ATrainersTestEncounter: MysteryEncounter = pulled: false, sourceType: EggSourceType.EVENT, eggDescriptor: encounter.misc.trainerEggDescription, - tier: EggTier.ULTRA + tier: EggTier.EPIC }; - encounter.setDialogueToken("eggType", i18next.t(`${namespace}.eggTypes.epic`)); - setEncounterRewards(scene, { guaranteedModifierTypeFuncs: [modifierTypes.SACRED_ASH], guaranteedModifierTiers: [ModifierTier.ROGUE, ModifierTier.ULTRA], fillRemaining: true }, [eggOptions]); - - return initBattleWithEnemyConfig(scene, config); + encounter.setDialogueToken("eggType", i18next.t(`${namespace}:eggTypes.epic`)); + setEncounterRewards(scene, { guaranteedModifierTypeFuncs: [ modifierTypes.SACRED_ASH ], guaranteedModifierTiers: [ ModifierTier.ROGUE, ModifierTier.ULTRA ], fillRemaining: true }, [ eggOptions ]); + await initBattleWithEnemyConfig(scene, config); } ) .withSimpleOption( { - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip` + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip` }, async (scene: BattleScene) => { const encounter = scene.currentBattle.mysteryEncounter!; @@ -171,16 +172,16 @@ export const ATrainersTestEncounter: MysteryEncounter = pulled: false, sourceType: EggSourceType.EVENT, eggDescriptor: encounter.misc.trainerEggDescription, - tier: EggTier.GREAT + tier: EggTier.RARE }; - encounter.setDialogueToken("eggType", i18next.t(`${namespace}.eggTypes.rare`)); - setEncounterRewards(scene, { fillRemaining: false, rerollMultiplier: -1 }, [eggOptions]); + encounter.setDialogueToken("eggType", i18next.t(`${namespace}:eggTypes.rare`)); + setEncounterRewards(scene, { fillRemaining: false, rerollMultiplier: -1 }, [ eggOptions ]); leaveEncounterWithoutBattle(scene); } ) .withOutroDialogue([ { - text: `${namespace}.outro`, - }, + text: `${namespace}:outro` + } ]) .build(); diff --git a/src/data/mystery-encounters/encounters/absolute-avarice-encounter.ts b/src/data/mystery-encounters/encounters/absolute-avarice-encounter.ts index a9a273c6ec4..9c00148fbac 100644 --- a/src/data/mystery-encounters/encounters/absolute-avarice-encounter.ts +++ b/src/data/mystery-encounters/encounters/absolute-avarice-encounter.ts @@ -4,13 +4,13 @@ import { BerryModifierType, modifierTypes, PokemonHeldItemModifierType } from "# import { MysteryEncounterType } from "#enums/mystery-encounter-type"; import { Species } from "#enums/species"; import BattleScene from "#app/battle-scene"; -import MysteryEncounter, { MysteryEncounterBuilder } from "../mystery-encounter"; -import { MysteryEncounterOptionBuilder } from "../mystery-encounter-option"; -import { PersistentModifierRequirement } from "../mystery-encounter-requirements"; +import MysteryEncounter, { MysteryEncounterBuilder } from "#app/data/mystery-encounters/mystery-encounter"; +import { MysteryEncounterOptionBuilder } from "#app/data/mystery-encounters/mystery-encounter-option"; +import { PersistentModifierRequirement } from "#app/data/mystery-encounters/mystery-encounter-requirements"; import { queueEncounterMessage } from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode"; -import { BerryModifier } from "#app/modifier/modifier"; +import { BerryModifier, PokemonInstantReviveModifier } from "#app/modifier/modifier"; import { getPokemonSpecies } from "#app/data/pokemon-species"; import { Moves } from "#enums/moves"; import { BattlerTagType } from "#enums/battler-tag-type"; @@ -18,15 +18,16 @@ import { randInt } from "#app/utils"; import { BattlerIndex } from "#app/battle"; import { applyModifierTypeToPlayerPokemon, catchPokemon, getHighestLevelPlayerPokemon } from "#app/data/mystery-encounters/utils/encounter-pokemon-utils"; import { TrainerSlot } from "#app/data/trainer-config"; -import { PokeballType } from "#app/data/pokeball"; +import { PokeballType } from "#enums/pokeball"; import HeldModifierConfig from "#app/interfaces/held-modifier-config"; import { BerryType } from "#enums/berry-type"; import { StatStageChangePhase } from "#app/phases/stat-stage-change-phase"; import { Stat } from "#enums/stat"; import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES } from "#app/game-mode"; +import i18next from "i18next"; /** the i18n namespace for this encounter */ -const namespace = "mysteryEncounter:absoluteAvarice"; +const namespace = "mysteryEncounters/absoluteAvarice"; /** * Absolute Avarice encounter. @@ -38,6 +39,7 @@ export const AbsoluteAvariceEncounter: MysteryEncounter = .withEncounterTier(MysteryEncounterTier.GREAT) .withSceneWaveRangeRequirement(...CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES) .withSceneRequirement(new PersistentModifierRequirement("BerryModifier", 4)) // Must have at least 4 berries to spawn + .withFleeAllowed(false) .withIntroSpriteConfigs([ { // This sprite has the shadow @@ -159,20 +161,15 @@ export const AbsoluteAvariceEncounter: MysteryEncounter = ]) .withHideWildIntroMessage(true) .withAutoHideIntroVisuals(false) - .withOnVisualsStart((scene: BattleScene) => { - doGreedentSpriteSteal(scene); - doBerrySpritePile(scene); - - return true; - }) .withIntroDialogue([ { - text: `${namespace}.intro`, + text: `${namespace}:intro`, } ]) - .withTitle(`${namespace}.title`) - .withDescription(`${namespace}.description`) - .withQuery(`${namespace}.query`) + .setLocalizationKey(`${namespace}`) + .withTitle(`${namespace}:title`) + .withDescription(`${namespace}:description`) + .withQuery(`${namespace}:query`) .withOnInit((scene: BattleScene) => { const encounter = scene.currentBattle.mysteryEncounter!; @@ -184,7 +181,7 @@ export const AbsoluteAvariceEncounter: MysteryEncounter = // Sort berries by party member ID to more easily re-add later if necessary const berryItemsMap = new Map(); - scene.getParty().forEach(pokemon => { + scene.getPlayerParty().forEach(pokemon => { const pokemonBerries = berryItems.filter(b => b.pokemonId === pokemon.id); if (pokemonBerries?.length > 0) { berryItemsMap.set(pokemon.id, pokemonBerries); @@ -199,46 +196,66 @@ export const AbsoluteAvariceEncounter: MysteryEncounter = // Can't define stack count on a ModifierType, have to just create separate instances for each stack // Overflow berries will be "lost" on the boss, but it's un-catchable anyway for (let i = 0; i < berryMod.stackCount; i++) { - const modifierType = generateModifierType(scene, modifierTypes.BERRY, [berryMod.berryType]) as PokemonHeldItemModifierType; + const modifierType = generateModifierType(scene, modifierTypes.BERRY, [ berryMod.berryType ]) as PokemonHeldItemModifierType; bossModifierConfigs.push({ modifier: modifierType }); } - - scene.removeModifier(berryMod); }); + // Do NOT remove the real berries yet or else it will be persisted in the session data + + // SpDef buff below wave 50, +1 to all stats otherwise + const statChangesForBattle: (Stat.ATK | Stat.DEF | Stat.SPATK | Stat.SPDEF | Stat.SPD | Stat.ACC | Stat.EVA)[] = scene.currentBattle.waveIndex < 50 ? + [ Stat.SPDEF ] : + [ Stat.ATK, Stat.DEF, Stat.SPATK, Stat.SPDEF, Stat.SPD ]; + // Calculate boss mon const config: EnemyPartyConfig = { - levelAdditiveMultiplier: 1, + levelAdditiveModifier: 1, pokemonConfigs: [ { species: getPokemonSpecies(Species.GREEDENT), isBoss: true, bossSegments: 3, - moveSet: [Moves.THRASH, Moves.BODY_PRESS, Moves.STUFF_CHEEKS, Moves.SLACK_OFF], + moveSet: [ Moves.THRASH, Moves.BODY_PRESS, Moves.STUFF_CHEEKS, Moves.CRUNCH ], modifierConfigs: bossModifierConfigs, - tags: [BattlerTagType.MYSTERY_ENCOUNTER_POST_SUMMON], + tags: [ BattlerTagType.MYSTERY_ENCOUNTER_POST_SUMMON ], mysteryEncounterBattleEffects: (pokemon: Pokemon) => { - queueEncounterMessage(pokemon.scene, `${namespace}.option.1.boss_enraged`); - pokemon.scene.unshiftPhase(new StatStageChangePhase(pokemon.scene, pokemon.getBattlerIndex(), true, [Stat.ATK, Stat.DEF, Stat.SPATK, Stat.SPDEF, Stat.SPD], 1)); + queueEncounterMessage(pokemon.scene, `${namespace}:option.1.boss_enraged`); + pokemon.scene.unshiftPhase(new StatStageChangePhase(pokemon.scene, pokemon.getBattlerIndex(), true, statChangesForBattle, 1)); } } ], }; - encounter.enemyPartyConfigs = [config]; + encounter.enemyPartyConfigs = [ config ]; encounter.setDialogueToken("greedentName", getPokemonSpecies(Species.GREEDENT).getName()); return true; }) + .withOnVisualsStart((scene: BattleScene) => { + doGreedentSpriteSteal(scene); + doBerrySpritePile(scene); + + // Remove the berries from the party + // Session has been safely saved at this point, so data won't be lost + const berryItems = scene.findModifiers(m => m instanceof BerryModifier) as BerryModifier[]; + berryItems.forEach(berryMod => { + scene.removeModifier(berryMod); + }); + + scene.updateModifiers(true); + + return true; + }) .withOption( MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) .withDialogue({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.1.selected`, + text: `${namespace}:option.1.selected`, }, ], }) @@ -248,29 +265,28 @@ export const AbsoluteAvariceEncounter: MysteryEncounter = // Provides 1x Reviver Seed to each party member at end of battle const revSeed = generateModifierType(scene, modifierTypes.REVIVER_SEED); + encounter.setDialogueToken("foodReward", revSeed?.name ?? i18next.t("modifierType:ModifierType.REVIVER_SEED.name")); const givePartyPokemonReviverSeeds = () => { - const party = scene.getParty(); + const party = scene.getPlayerParty(); party.forEach(p => { - if (revSeed) { + const heldItems = p.getHeldItems(); + if (revSeed && !heldItems.some(item => item instanceof PokemonInstantReviveModifier)) { const seedModifier = revSeed.newModifier(p); - if (seedModifier) { - encounter.setDialogueToken("foodReward", seedModifier.type.name); - } scene.addModifier(seedModifier, false, false, false, true); } }); - queueEncounterMessage(scene, `${namespace}.option.1.food_stash`); + queueEncounterMessage(scene, `${namespace}:option.1.food_stash`); }; setEncounterRewards(scene, { fillRemaining: true }, undefined, givePartyPokemonReviverSeeds); encounter.startOfBattleEffects.push({ sourceBattlerIndex: BattlerIndex.ENEMY, - targets: [BattlerIndex.ENEMY], + targets: [ BattlerIndex.ENEMY ], move: new PokemonMove(Moves.STUFF_CHEEKS), ignorePp: true }); - transitionMysteryEncounterIntroVisuals(scene, true, true, 500); + await transitionMysteryEncounterIntroVisuals(scene, true, true, 500); await initBattleWithEnemyConfig(scene, encounter.enemyPartyConfigs[0]); }) .build() @@ -279,11 +295,11 @@ export const AbsoluteAvariceEncounter: MysteryEncounter = MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) .withDialogue({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, selected: [ { - text: `${namespace}.option.2.selected`, + text: `${namespace}:option.2.selected`, }, ], }) @@ -291,8 +307,8 @@ export const AbsoluteAvariceEncounter: MysteryEncounter = const encounter = scene.currentBattle.mysteryEncounter!; const berryMap = encounter.misc.berryItemsMap; - // Returns 2/5 of the berries stolen from each Pokemon - const party = scene.getParty(); + // Returns 2/5 of the berries stolen to each Pokemon + const party = scene.getPlayerParty(); party.forEach(pokemon => { const stolenBerries: BerryModifier[] = berryMap.get(pokemon.id); const berryTypesAsArray: BerryType[] = []; @@ -305,13 +321,14 @@ export const AbsoluteAvariceEncounter: MysteryEncounter = Phaser.Math.RND.shuffle(berryTypesAsArray); const randBerryType = berryTypesAsArray.pop(); - const berryModType = generateModifierType(scene, modifierTypes.BERRY, [randBerryType]) as BerryModifierType; + const berryModType = generateModifierType(scene, modifierTypes.BERRY, [ randBerryType ]) as BerryModifierType; applyModifierTypeToPlayerPokemon(scene, pokemon, berryModType); } } }); + await scene.updateModifiers(true); - transitionMysteryEncounterIntroVisuals(scene, true, true, 500); + await transitionMysteryEncounterIntroVisuals(scene, true, true, 500); leaveEncounterWithoutBattle(scene, true); }) .build() @@ -320,11 +337,11 @@ export const AbsoluteAvariceEncounter: MysteryEncounter = MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) .withDialogue({ - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, selected: [ { - text: `${namespace}.option.3.selected`, + text: `${namespace}:option.3.selected`, }, ], }) @@ -337,12 +354,12 @@ export const AbsoluteAvariceEncounter: MysteryEncounter = .withOptionPhase(async (scene: BattleScene) => { // Let it have the food // Greedent joins the team, level equal to 2 below highest party member - const level = getHighestLevelPlayerPokemon(scene).level - 2; + const level = getHighestLevelPlayerPokemon(scene, false, true).level - 2; const greedent = new EnemyPokemon(scene, getPokemonSpecies(Species.GREEDENT), level, TrainerSlot.NONE, false); - greedent.moveset = [new PokemonMove(Moves.THRASH), new PokemonMove(Moves.BODY_PRESS), new PokemonMove(Moves.STUFF_CHEEKS), new PokemonMove(Moves.SLACK_OFF)]; + greedent.moveset = [ new PokemonMove(Moves.THRASH), new PokemonMove(Moves.BODY_PRESS), new PokemonMove(Moves.STUFF_CHEEKS), new PokemonMove(Moves.SLACK_OFF) ]; greedent.passive = true; - transitionMysteryEncounterIntroVisuals(scene, true, true, 500); + await transitionMysteryEncounterIntroVisuals(scene, true, true, 500); await catchPokemon(scene, greedent, null, PokeballType.POKEBALL, false); leaveEncounterWithoutBattle(scene, true); }) @@ -456,7 +473,7 @@ function doGreedentEatBerries(scene: BattleScene) { */ function doBerrySpritePile(scene: BattleScene, isEat: boolean = false) { const berryAddDelay = 150; - let animationOrder = ["starf", "sitrus", "lansat", "salac", "apicot", "enigma", "liechi", "ganlon", "lum", "petaya", "leppa"]; + let animationOrder = [ "starf", "sitrus", "lansat", "salac", "apicot", "enigma", "liechi", "ganlon", "lum", "petaya", "leppa" ]; if (isEat) { animationOrder = animationOrder.reverse(); } @@ -480,7 +497,7 @@ function doBerrySpritePile(scene: BattleScene, isEat: boolean = false) { // Animate Petaya berry falling off the pile if (berry === "petaya" && sprite && tintSprite && !isEat) { scene.time.delayedCall(200, () => { - doBerryBounce(scene, [sprite, tintSprite], 30, 500); + doBerryBounce(scene, [ sprite, tintSprite ], 30, 500); }); } }); diff --git a/src/data/mystery-encounters/encounters/an-offer-you-cant-refuse-encounter.ts b/src/data/mystery-encounters/encounters/an-offer-you-cant-refuse-encounter.ts index 9f38b5a4dea..1e20b73e351 100644 --- a/src/data/mystery-encounters/encounters/an-offer-you-cant-refuse-encounter.ts +++ b/src/data/mystery-encounters/encounters/an-offer-you-cant-refuse-encounter.ts @@ -1,21 +1,31 @@ -import { leaveEncounterWithoutBattle, setEncounterExp, updatePlayerMoney, } from "#app/data/mystery-encounters/utils/encounter-phase-utils"; +import { generateModifierType, leaveEncounterWithoutBattle, setEncounterExp, updatePlayerMoney, } from "#app/data/mystery-encounters/utils/encounter-phase-utils"; import { modifierTypes } from "#app/modifier/modifier-type"; import { MysteryEncounterType } from "#enums/mystery-encounter-type"; import { Species } from "#enums/species"; import BattleScene from "#app/battle-scene"; -import MysteryEncounter, { MysteryEncounterBuilder } from "../mystery-encounter"; -import { MysteryEncounterOptionBuilder } from "../mystery-encounter-option"; -import { AbilityRequirement, CombinationPokemonRequirement, MoveRequirement } from "../mystery-encounter-requirements"; +import MysteryEncounter, { MysteryEncounterBuilder } from "#app/data/mystery-encounters/mystery-encounter"; +import { MysteryEncounterOptionBuilder } from "#app/data/mystery-encounters/mystery-encounter-option"; +import { AbilityRequirement, CombinationPokemonRequirement, MoveRequirement } from "#app/data/mystery-encounters/mystery-encounter-requirements"; import { getHighestStatTotalPlayerPokemon } from "#app/data/mystery-encounters/utils/encounter-pokemon-utils"; import { EXTORTION_ABILITIES, EXTORTION_MOVES } from "#app/data/mystery-encounters/requirements/requirement-groups"; import { getPokemonSpecies } from "#app/data/pokemon-species"; +import { speciesStarterCosts } from "#app/data/balance/starters"; import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode"; import { ModifierRewardPhase } from "#app/phases/modifier-reward-phase"; import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES } from "#app/game-mode"; +import i18next from "i18next"; /** the i18n namespace for this encounter */ -const namespace = "mysteryEncounter:offerYouCantRefuse"; +const namespace = "mysteryEncounters/anOfferYouCantRefuse"; + +/** + * Money offered starts at base value of Relic Gold, increasing linearly up to 3x Relic Gold based on the starter tier of the Pokemon being purchased + * Starter value 1-3 -> Relic Gold + * Starter value 10 -> 3 * Relic Gold + */ +const MONEY_MINIMUM_MULTIPLIER = 10; +const MONEY_MAXIMUM_MULTIPLIER = 30; /** * An Offer You Can't Refuse encounter. @@ -26,7 +36,7 @@ export const AnOfferYouCantRefuseEncounter: MysteryEncounter = MysteryEncounterBuilder.withEncounterType(MysteryEncounterType.AN_OFFER_YOU_CANT_REFUSE) .withEncounterTier(MysteryEncounterTier.GREAT) .withSceneWaveRangeRequirement(...CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES) - .withScenePartySizeRequirement(2, 6) // Must have at least 2 pokemon in party + .withScenePartySizeRequirement(2, 6, true) // Must have at least 2 pokemon in party .withIntroSpriteConfigs([ { spriteKey: Species.LIEPARD.toString(), @@ -48,20 +58,25 @@ export const AnOfferYouCantRefuseEncounter: MysteryEncounter = ]) .withIntroDialogue([ { - text: `${namespace}.intro`, + text: `${namespace}:intro`, }, { - text: `${namespace}.intro_dialogue`, - speaker: `${namespace}.speaker`, + text: `${namespace}:intro_dialogue`, + speaker: `${namespace}:speaker`, }, ]) - .withTitle(`${namespace}.title`) - .withDescription(`${namespace}.description`) - .withQuery(`${namespace}.query`) + .setLocalizationKey(`${namespace}`) + .withTitle(`${namespace}:title`) + .withDescription(`${namespace}:description`) + .withQuery(`${namespace}:query`) .withOnInit((scene: BattleScene) => { const encounter = scene.currentBattle.mysteryEncounter!; - const pokemon = getHighestStatTotalPlayerPokemon(scene, false); - const price = scene.getWaveMoneyAmount(10); + const pokemon = getHighestStatTotalPlayerPokemon(scene, true, true); + + const baseSpecies = pokemon.getSpeciesForm().getRootSpeciesId(); + const starterValue: number = speciesStarterCosts[baseSpecies] ?? 1; + const multiplier = Math.max(MONEY_MAXIMUM_MULTIPLIER / 10 * starterValue, MONEY_MINIMUM_MULTIPLIER); + const price = scene.getWaveMoneyAmount(multiplier); encounter.setDialogueToken("strongestPokemon", pokemon.getNameToRender()); encounter.setDialogueToken("price", price.toString()); @@ -84,6 +99,8 @@ export const AnOfferYouCantRefuseEncounter: MysteryEncounter = } } + const shinyCharm = generateModifierType(scene, modifierTypes.SHINY_CHARM); + encounter.setDialogueToken("itemName", shinyCharm?.name ?? i18next.t("modifierType:ModifierType.SHINY_CHARM.name")); encounter.setDialogueToken("liepardName", getPokemonSpecies(Species.LIEPARD).getName()); return true; @@ -92,12 +109,12 @@ export const AnOfferYouCantRefuseEncounter: MysteryEncounter = MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) .withDialogue({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.1.selected`, - speaker: `${namespace}.speaker`, + text: `${namespace}:option.1.selected`, + speaker: `${namespace}:speaker`, }, ], }) @@ -109,7 +126,7 @@ export const AnOfferYouCantRefuseEncounter: MysteryEncounter = return true; }) .withOptionPhase(async (scene: BattleScene) => { - // Give the player a Shiny charm + // Give the player a Shiny Charm scene.unshiftPhase(new ModifierRewardPhase(scene, modifierTypes.SHINY_CHARM)); leaveEncounterWithoutBattle(scene, true); }) @@ -118,18 +135,20 @@ export const AnOfferYouCantRefuseEncounter: MysteryEncounter = .withOption( MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DISABLED_OR_SPECIAL) - .withPrimaryPokemonRequirement(new CombinationPokemonRequirement( - new MoveRequirement(EXTORTION_MOVES), - new AbilityRequirement(EXTORTION_ABILITIES)) + .withPrimaryPokemonRequirement( + CombinationPokemonRequirement.Some( + new MoveRequirement(EXTORTION_MOVES, true), + new AbilityRequirement(EXTORTION_ABILITIES, true) + ) ) .withDialogue({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, - disabledButtonTooltip: `${namespace}.option.2.tooltip_disabled`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, + disabledButtonTooltip: `${namespace}:option.2.tooltip_disabled`, selected: [ { - speaker: `${namespace}.speaker`, - text: `${namespace}.option.2.selected`, + speaker: `${namespace}:speaker`, + text: `${namespace}:option.2.selected`, }, ], }) @@ -147,12 +166,12 @@ export const AnOfferYouCantRefuseEncounter: MysteryEncounter = ) .withSimpleOption( { - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, selected: [ { - speaker: `${namespace}.speaker`, - text: `${namespace}.option.3.selected`, + speaker: `${namespace}:speaker`, + text: `${namespace}:option.3.selected`, }, ], }, diff --git a/src/data/mystery-encounters/encounters/berries-abound-encounter.ts b/src/data/mystery-encounters/encounters/berries-abound-encounter.ts index 7e6914cabdd..5524511c67b 100644 --- a/src/data/mystery-encounters/encounters/berries-abound-encounter.ts +++ b/src/data/mystery-encounters/encounters/berries-abound-encounter.ts @@ -17,13 +17,13 @@ import { randSeedInt } from "#app/utils"; import { BattlerTagType } from "#enums/battler-tag-type"; import { MysteryEncounterType } from "#enums/mystery-encounter-type"; import BattleScene from "#app/battle-scene"; -import MysteryEncounter, { MysteryEncounterBuilder } from "../mystery-encounter"; +import MysteryEncounter, { MysteryEncounterBuilder } from "#app/data/mystery-encounters/mystery-encounter"; import { queueEncounterMessage, showEncounterText } from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; import { getPokemonNameWithAffix } from "#app/messages"; import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode"; import { TrainerSlot } from "#app/data/trainer-config"; -import { applyModifierTypeToPlayerPokemon, getHighestStatPlayerPokemon, getSpriteKeysFromPokemon } from "#app/data/mystery-encounters/utils/encounter-pokemon-utils"; +import { applyModifierTypeToPlayerPokemon, getEncounterPokemonLevelForWave, getHighestStatPlayerPokemon, getSpriteKeysFromPokemon, STANDARD_ENCOUNTER_BOOSTED_LEVEL_MODIFIER } from "#app/data/mystery-encounters/utils/encounter-pokemon-utils"; import PokemonData from "#app/system/pokemon-data"; import { BerryModifier } from "#app/modifier/modifier"; import i18next from "#app/plugins/i18n"; @@ -33,7 +33,7 @@ import { StatStageChangePhase } from "#app/phases/stat-stage-change-phase"; import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES } from "#app/game-mode"; /** the i18n namespace for the encounter */ -const namespace = "mysteryEncounter:berriesAbound"; +const namespace = "mysteryEncounters/berriesAbound"; /** * Berries Abound encounter. @@ -46,22 +46,22 @@ export const BerriesAboundEncounter: MysteryEncounter = .withSceneWaveRangeRequirement(...CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES) .withCatchAllowed(true) .withHideWildIntroMessage(true) + .withFleeAllowed(false) .withIntroSpriteConfigs([]) // Set in onInit() .withIntroDialogue([ { - text: `${namespace}.intro`, + text: `${namespace}:intro`, }, ]) .withOnInit((scene: BattleScene) => { const encounter = scene.currentBattle.mysteryEncounter!; // Calculate boss mon - const level = (scene.currentBattle.enemyLevels?.[0] ?? scene.currentBattle.waveIndex) + Math.max(Math.round((scene.currentBattle.waveIndex / 10)), 0); - const bossSpecies = scene.arena.randomSpecies(scene.currentBattle.waveIndex, level, 0, getPartyLuckValue(scene.getParty()), true); + const level = getEncounterPokemonLevelForWave(scene, STANDARD_ENCOUNTER_BOOSTED_LEVEL_MODIFIER); + const bossSpecies = scene.arena.randomSpecies(scene.currentBattle.waveIndex, level, 0, getPartyLuckValue(scene.getPlayerParty()), true); const bossPokemon = new EnemyPokemon(scene, bossSpecies, level, TrainerSlot.NONE, true); encounter.setDialogueToken("enemyPokemon", getPokemonNameWithAffix(bossPokemon)); const config: EnemyPartyConfig = { - levelAdditiveMultiplier: 1, pokemonConfigs: [{ level: level, species: bossSpecies, @@ -69,7 +69,7 @@ export const BerriesAboundEncounter: MysteryEncounter = isBoss: true }], }; - encounter.enemyPartyConfigs = [config]; + encounter.enemyPartyConfigs = [ config ]; // Calculate the number of extra berries that player receives // 10-40: 2, 40-120: 4, 120-160: 5, 160-180: 7 @@ -77,13 +77,13 @@ export const BerriesAboundEncounter: MysteryEncounter = scene.currentBattle.waveIndex > 160 ? 7 : scene.currentBattle.waveIndex > 120 ? 5 : scene.currentBattle.waveIndex > 40 ? 4 : 2; - regenerateModifierPoolThresholds(scene.getParty(), ModifierPoolType.PLAYER, 0); + regenerateModifierPoolThresholds(scene.getPlayerParty(), ModifierPoolType.PLAYER, 0); encounter.misc = { numBerries }; const { spriteKey, fileRoot } = getSpriteKeysFromPokemon(bossPokemon); encounter.spriteConfigs = [ { - spriteKey: "berry_bush", + spriteKey: "berries_abound_bush", fileRoot: "mystery-encounters", x: 25, y: -6, @@ -103,23 +103,24 @@ export const BerriesAboundEncounter: MysteryEncounter = ]; // Get fastest party pokemon for option 2 - const fastestPokemon = getHighestStatPlayerPokemon(scene, PERMANENT_STATS[Stat.SPD], true); + const fastestPokemon = getHighestStatPlayerPokemon(scene, PERMANENT_STATS[Stat.SPD], true, false); encounter.misc.fastestPokemon = fastestPokemon; encounter.misc.enemySpeed = bossPokemon.getStat(Stat.SPD); encounter.setDialogueToken("fastestPokemon", fastestPokemon.getNameToRender()); return true; }) - .withTitle(`${namespace}.title`) - .withDescription(`${namespace}.description`) - .withQuery(`${namespace}.query`) + .setLocalizationKey(`${namespace}`) + .withTitle(`${namespace}:title`) + .withDescription(`${namespace}:description`) + .withQuery(`${namespace}:query`) .withSimpleOption( { - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.1.selected`, + text: `${namespace}:option.1.selected`, }, ], }, @@ -128,15 +129,15 @@ export const BerriesAboundEncounter: MysteryEncounter = const encounter = scene.currentBattle.mysteryEncounter!; const numBerries = encounter.misc.numBerries; - const doBerryRewards = async () => { - const berryText = numBerries + " " + i18next.t(`${namespace}.berries`); + const doBerryRewards = () => { + const berryText = i18next.t(`${namespace}:berries`); scene.playSound("item_fanfare"); - queueEncounterMessage(scene, i18next.t("battle:rewardGain", { modifierName: berryText })); + queueEncounterMessage(scene, i18next.t("battle:rewardGainCount", { modifierName: berryText, count: numBerries })); // Generate a random berry and give it to the first Pokemon with room for it for (let i = 0; i < numBerries; i++) { - await tryGiveBerry(scene); + tryGiveBerry(scene); } }; @@ -157,16 +158,16 @@ export const BerriesAboundEncounter: MysteryEncounter = MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) .withDialogue({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip` + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip` }) .withOptionPhase(async (scene: BattleScene) => { // Pick race for berries const encounter = scene.currentBattle.mysteryEncounter!; - const fastestPokemon = encounter.misc.fastestPokemon; - const enemySpeed = encounter.misc.enemySpeed; + const fastestPokemon: PlayerPokemon = encounter.misc.fastestPokemon; + const enemySpeed: number = encounter.misc.enemySpeed; const speedDiff = fastestPokemon.getStat(Stat.SPD) / (enemySpeed * 1.1); - const numBerries = encounter.misc.numBerries; + const numBerries: number = encounter.misc.numBerries; const shopOptions: ModifierTypeOption[] = []; for (let i = 0; i < 5; i++) { @@ -179,47 +180,52 @@ export const BerriesAboundEncounter: MysteryEncounter = if (speedDiff < 1) { // Caught and attacked by boss, gets +1 to all stats at start of fight - const doBerryRewards = async () => { - const berryText = numBerries + " " + i18next.t(`${namespace}.berries`); + const doBerryRewards = () => { + const berryText = i18next.t(`${namespace}:berries`); scene.playSound("item_fanfare"); - queueEncounterMessage(scene, i18next.t("battle:rewardGain", { modifierName: berryText })); + queueEncounterMessage(scene, i18next.t("battle:rewardGainCount", { modifierName: berryText, count: numBerries })); // Generate a random berry and give it to the first Pokemon with room for it for (let i = 0; i < numBerries; i++) { - await tryGiveBerry(scene); + tryGiveBerry(scene); } }; + // Defense/Spd buffs below wave 50, +1 to all stats otherwise + const statChangesForBattle: (Stat.ATK | Stat.DEF | Stat.SPATK | Stat.SPDEF | Stat.SPD | Stat.ACC | Stat.EVA)[] = scene.currentBattle.waveIndex < 50 ? + [ Stat.DEF, Stat.SPDEF, Stat.SPD ] : + [ Stat.ATK, Stat.DEF, Stat.SPATK, Stat.SPDEF, Stat.SPD ]; + const config = scene.currentBattle.mysteryEncounter!.enemyPartyConfigs[0]; - config.pokemonConfigs![0].tags = [BattlerTagType.MYSTERY_ENCOUNTER_POST_SUMMON]; + config.pokemonConfigs![0].tags = [ BattlerTagType.MYSTERY_ENCOUNTER_POST_SUMMON ]; config.pokemonConfigs![0].mysteryEncounterBattleEffects = (pokemon: Pokemon) => { - queueEncounterMessage(pokemon.scene, `${namespace}.option.2.boss_enraged`); - pokemon.scene.unshiftPhase(new StatStageChangePhase(pokemon.scene, pokemon.getBattlerIndex(), true, [Stat.ATK, Stat.DEF, Stat.SPATK, Stat.SPDEF, Stat.SPD], 1)); + queueEncounterMessage(pokemon.scene, `${namespace}:option.2.boss_enraged`); + pokemon.scene.unshiftPhase(new StatStageChangePhase(pokemon.scene, pokemon.getBattlerIndex(), true, statChangesForBattle, 1)); }; setEncounterRewards(scene, { guaranteedModifierTypeOptions: shopOptions, fillRemaining: false }, undefined, doBerryRewards); - await showEncounterText(scene, `${namespace}.option.2.selected_bad`); + await showEncounterText(scene, `${namespace}:option.2.selected_bad`); await initBattleWithEnemyConfig(scene, config); return; } else { // Gains 1 berry for every 10% faster the player's pokemon is than the enemy, up to a max of numBerries, minimum of 2 - const numBerriesGrabbed = Math.max(Math.min(Math.round((speedDiff - 1)/0.08), numBerries), 2); + const numBerriesGrabbed = Math.max(Math.min(Math.round((speedDiff - 1) / 0.08), numBerries), 2); encounter.setDialogueToken("numBerries", String(numBerriesGrabbed)); - const doFasterBerryRewards = async () => { - const berryText = numBerriesGrabbed + " " + i18next.t(`${namespace}.berries`); + const doFasterBerryRewards = () => { + const berryText = i18next.t(`${namespace}:berries`); scene.playSound("item_fanfare"); - queueEncounterMessage(scene, i18next.t("battle:rewardGain", { modifierName: berryText })); + queueEncounterMessage(scene, i18next.t("battle:rewardGainCount", { modifierName: berryText, count: numBerriesGrabbed })); // Generate a random berry and give it to the first Pokemon with room for it (trying to give to fastest first) for (let i = 0; i < numBerriesGrabbed; i++) { - await tryGiveBerry(scene, fastestPokemon); + tryGiveBerry(scene, fastestPokemon); } }; setEncounterExp(scene, fastestPokemon.id, encounter.enemyPartyConfigs[0].pokemonConfigs![0].species.baseExp); setEncounterRewards(scene, { guaranteedModifierTypeOptions: shopOptions, fillRemaining: false }, undefined, doFasterBerryRewards); - await showEncounterText(scene, `${namespace}.option.2.selected`); + await showEncounterText(scene, `${namespace}:option.2.selected`); leaveEncounterWithoutBattle(scene); } }) @@ -227,11 +233,11 @@ export const BerriesAboundEncounter: MysteryEncounter = ) .withSimpleOption( { - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, selected: [ { - text: `${namespace}.option.3.selected`, + text: `${namespace}:option.3.selected`, }, ], }, @@ -243,11 +249,11 @@ export const BerriesAboundEncounter: MysteryEncounter = ) .build(); -async function tryGiveBerry(scene: BattleScene, prioritizedPokemon?: PlayerPokemon) { +function tryGiveBerry(scene: BattleScene, prioritizedPokemon?: PlayerPokemon) { const berryType = randSeedInt(Object.keys(BerryType).filter(s => !isNaN(Number(s))).length) as BerryType; - const berry = generateModifierType(scene, modifierTypes.BERRY, [berryType]) as BerryModifierType; + const berry = generateModifierType(scene, modifierTypes.BERRY, [ berryType ]) as BerryModifierType; - const party = scene.getParty(); + const party = scene.getPlayerParty(); // Will try to apply to prioritized pokemon first, then do normal application method if it fails if (prioritizedPokemon) { @@ -255,7 +261,7 @@ async function tryGiveBerry(scene: BattleScene, prioritizedPokemon?: PlayerPokem && m.pokemonId === prioritizedPokemon.id && (m as BerryModifier).berryType === berryType, true) as BerryModifier; if (!heldBerriesOfType || heldBerriesOfType.getStackCount() < heldBerriesOfType.getMaxStackCount(scene)) { - await applyModifierTypeToPlayerPokemon(scene, prioritizedPokemon, berry); + applyModifierTypeToPlayerPokemon(scene, prioritizedPokemon, berry); return; } } @@ -266,7 +272,7 @@ async function tryGiveBerry(scene: BattleScene, prioritizedPokemon?: PlayerPokem && m.pokemonId === pokemon.id && (m as BerryModifier).berryType === berryType, true) as BerryModifier; if (!heldBerriesOfType || heldBerriesOfType.getStackCount() < heldBerriesOfType.getMaxStackCount(scene)) { - await applyModifierTypeToPlayerPokemon(scene, pokemon, berry); + applyModifierTypeToPlayerPokemon(scene, pokemon, berry); return; } } diff --git a/src/data/mystery-encounters/encounters/bug-type-superfan-encounter.ts b/src/data/mystery-encounters/encounters/bug-type-superfan-encounter.ts index 7fdaec35dc3..ecd6972902b 100644 --- a/src/data/mystery-encounters/encounters/bug-type-superfan-encounter.ts +++ b/src/data/mystery-encounters/encounters/bug-type-superfan-encounter.ts @@ -9,6 +9,7 @@ import { transitionMysteryEncounterIntroVisuals, } from "#app/data/mystery-encounters/utils/encounter-phase-utils"; import { + getRandomPartyMemberFunc, trainerConfigs, TrainerPartyCompoundTemplate, TrainerPartyTemplate, @@ -17,14 +18,12 @@ import { import { MysteryEncounterType } from "#enums/mystery-encounter-type"; import { PartyMemberStrength } from "#enums/party-member-strength"; import BattleScene from "#app/battle-scene"; -import * as Utils from "#app/utils"; import { isNullOrUndefined, randSeedInt, randSeedShuffle } from "#app/utils"; -import MysteryEncounter, { MysteryEncounterBuilder } from "../mystery-encounter"; +import MysteryEncounter, { MysteryEncounterBuilder } from "#app/data/mystery-encounters/mystery-encounter"; import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; import { TrainerType } from "#enums/trainer-type"; import { Species } from "#enums/species"; -import Pokemon, { EnemyPokemon, PlayerPokemon, PokemonMove } from "#app/field/pokemon"; -import { getPokemonSpecies } from "#app/data/pokemon-species"; +import Pokemon, { PlayerPokemon, PokemonMove } from "#app/field/pokemon"; import { getEncounterText, showEncounterDialogue } from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; import { LearnMovePhase } from "#app/phases/learn-move-phase"; import { Moves } from "#enums/moves"; @@ -37,12 +36,14 @@ import { HeldItemRequirement, TypeRequirement } from "#app/data/mystery-encounters/mystery-encounter-requirements"; -import { Type } from "#app/data/type"; +import { Type } from "#enums/type"; import { AttackTypeBoosterModifierType, ModifierTypeOption, modifierTypes } from "#app/modifier/modifier-type"; import { AttackTypeBoosterModifier, BypassSpeedChanceModifier, ContactHeldItemTransferChanceModifier, + GigantamaxAccessModifier, + MegaEvolutionAccessModifier, PokemonHeldItemModifier } from "#app/modifier/modifier"; import i18next from "i18next"; @@ -50,9 +51,10 @@ import MoveInfoOverlay from "#app/ui/move-info-overlay"; import { allMoves } from "#app/data/move"; import { ModifierTier } from "#app/modifier/modifier-tier"; import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES } from "#app/game-mode"; +import { getSpriteKeysFromSpecies } from "#app/data/mystery-encounters/utils/encounter-pokemon-utils"; /** the i18n namespace for the encounter */ -const namespace = "mysteryEncounter:bugTypeSuperfan"; +const namespace = "mysteryEncounters/bugTypeSuperfan"; const POOL_1_POKEMON = [ Species.PARASECT, @@ -178,30 +180,38 @@ const MISC_TUTOR_MOVES = [ Moves.U_TURN ]; +/** + * Wave breakpoints that determine how strong to make the Bug-Type Superfan's team + */ +const WAVE_LEVEL_BREAKPOINTS = [ 30, 50, 70, 100, 120, 140, 160 ]; + /** * Bug Type Superfan encounter. - * @see {@link https://github.com/pagefaultgames/pokerogue/issues/3810 | GitHub Issue #3810} + * @see {@link https://github.com/pagefaultgames/pokerogue/issues/3820 | GitHub Issue #3820} * @see For biome requirements check {@linkcode mysteryEncountersByBiome} */ export const BugTypeSuperfanEncounter: MysteryEncounter = MysteryEncounterBuilder.withEncounterType(MysteryEncounterType.BUG_TYPE_SUPERFAN) .withEncounterTier(MysteryEncounterTier.GREAT) - .withPrimaryPokemonRequirement(new CombinationPokemonRequirement( - // Must have at least 1 Bug type on team, OR have a bug item somewhere on the team - new HeldItemRequirement(["BypassSpeedChanceModifier", "ContactHeldItemTransferChanceModifier"], 1), - new AttackTypeBoosterHeldItemTypeRequirement(Type.BUG, 1), - new TypeRequirement(Type.BUG, false, 1) - )) + .withPrimaryPokemonRequirement( + CombinationPokemonRequirement.Some( + // Must have at least 1 Bug type on team, OR have a bug item somewhere on the team + new HeldItemRequirement([ "BypassSpeedChanceModifier", "ContactHeldItemTransferChanceModifier" ], 1), + new AttackTypeBoosterHeldItemTypeRequirement(Type.BUG, 1), + new TypeRequirement(Type.BUG, false, 1) + ) + ) + .withMaxAllowedEncounters(1) .withSceneWaveRangeRequirement(...CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES) .withIntroSpriteConfigs([]) // These are set in onInit() .withAutoHideIntroVisuals(false) .withIntroDialogue([ { - text: `${namespace}.intro`, + text: `${namespace}:intro`, }, { - speaker: `${namespace}.speaker`, - text: `${namespace}.intro_dialogue`, + speaker: `${namespace}:speaker`, + text: `${namespace}:intro_dialogue`, }, ]) .withOnInit((scene: BattleScene) => { @@ -216,18 +226,53 @@ export const BugTypeSuperfanEncounter: MysteryEncounter = female: true, }); + let beedrillKeys: { spriteKey: string, fileRoot: string }, butterfreeKeys: { spriteKey: string, fileRoot: string }; + if (scene.currentBattle.waveIndex < WAVE_LEVEL_BREAKPOINTS[3]) { + beedrillKeys = getSpriteKeysFromSpecies(Species.BEEDRILL, false); + butterfreeKeys = getSpriteKeysFromSpecies(Species.BUTTERFREE, false); + } else { + // Mega Beedrill/Gmax Butterfree + beedrillKeys = getSpriteKeysFromSpecies(Species.BEEDRILL, false, 1); + butterfreeKeys = getSpriteKeysFromSpecies(Species.BUTTERFREE, false, 1); + } + encounter.spriteConfigs = [ + { + spriteKey: beedrillKeys.spriteKey, + fileRoot: beedrillKeys.fileRoot, + hasShadow: true, + repeat: true, + isPokemon: true, + x: -30, + tint: 0.15, + y: -4, + yShadow: -4 + }, + { + spriteKey: butterfreeKeys.spriteKey, + fileRoot: butterfreeKeys.fileRoot, + hasShadow: true, + repeat: true, + isPokemon: true, + x: 30, + tint: 0.15, + y: -4, + yShadow: -4 + }, { spriteKey: spriteKey, fileRoot: "trainer", hasShadow: true, + x: 4, + y: 7, + yShadow: 7 }, ]; const requiredItems = [ generateModifierType(scene, modifierTypes.QUICK_CLAW), generateModifierType(scene, modifierTypes.GRIP_CLAW), - generateModifierType(scene, modifierTypes.ATTACK_TYPE_BOOSTER, [Type.BUG]), + generateModifierType(scene, modifierTypes.ATTACK_TYPE_BOOSTER, [ Type.BUG ]), ]; const requiredItemString = requiredItems.map(m => m?.name ?? "unknown").join("/"); @@ -235,17 +280,18 @@ export const BugTypeSuperfanEncounter: MysteryEncounter = return true; }) - .withTitle(`${namespace}.title`) - .withDescription(`${namespace}.description`) - .withQuery(`${namespace}.query`) + .setLocalizationKey(`${namespace}`) + .withTitle(`${namespace}:title`) + .withDescription(`${namespace}:description`) + .withQuery(`${namespace}:query`) .withSimpleOption( { - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - speaker: `${namespace}.speaker`, - text: `${namespace}.option.1.selected`, + speaker: `${namespace}:speaker`, + text: `${namespace}:option.1.selected`, }, ], }, @@ -276,47 +322,55 @@ export const BugTypeSuperfanEncounter: MysteryEncounter = .newOptionWithMode(MysteryEncounterOptionMode.DISABLED_OR_DEFAULT) .withPrimaryPokemonRequirement(new TypeRequirement(Type.BUG, false, 1)) // Must have 1 Bug type on team .withDialogue({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, - disabledButtonTooltip: `${namespace}.option.2.disabled_tooltip` + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, + disabledButtonTooltip: `${namespace}:option.2.disabled_tooltip` }) .withPreOptionPhase(async (scene: BattleScene) => { // Player shows off their bug types const encounter = scene.currentBattle.mysteryEncounter!; // Player gets different rewards depending on the number of bug types they have - const numBugTypes = scene.getParty().filter(p => p.isOfType(Type.BUG, true)).length; - encounter.setDialogueToken("numBugTypes", numBugTypes.toString()); + const numBugTypes = scene.getPlayerParty().filter(p => p.isOfType(Type.BUG, true)).length; + const numBugTypesText = i18next.t(`${namespace}:numBugTypes`, { count: numBugTypes }); + encounter.setDialogueToken("numBugTypes", numBugTypesText); if (numBugTypes < 2) { - setEncounterRewards(scene, { guaranteedModifierTypeFuncs: [modifierTypes.SUPER_LURE, modifierTypes.GREAT_BALL], fillRemaining: false }); + setEncounterRewards(scene, { guaranteedModifierTypeFuncs: [ modifierTypes.SUPER_LURE, modifierTypes.GREAT_BALL ], fillRemaining: false }); encounter.selectedOption!.dialogue!.selected = [ { - speaker: `${namespace}.speaker`, - text: `${namespace}.option.2.selected_0_to_1`, + speaker: `${namespace}:speaker`, + text: `${namespace}:option.2.selected_0_to_1`, }, ]; } else if (numBugTypes < 4) { - setEncounterRewards(scene, { guaranteedModifierTypeFuncs: [modifierTypes.QUICK_CLAW, modifierTypes.MAX_LURE, modifierTypes.ULTRA_BALL], fillRemaining: false }); + setEncounterRewards(scene, { guaranteedModifierTypeFuncs: [ modifierTypes.QUICK_CLAW, modifierTypes.MAX_LURE, modifierTypes.ULTRA_BALL ], fillRemaining: false }); encounter.selectedOption!.dialogue!.selected = [ { - speaker: `${namespace}.speaker`, - text: `${namespace}.option.2.selected_2_to_3`, + speaker: `${namespace}:speaker`, + text: `${namespace}:option.2.selected_2_to_3`, }, ]; } else if (numBugTypes < 6) { - setEncounterRewards(scene, { guaranteedModifierTypeFuncs: [modifierTypes.GRIP_CLAW, modifierTypes.MAX_LURE, modifierTypes.ROGUE_BALL], fillRemaining: false }); + setEncounterRewards(scene, { guaranteedModifierTypeFuncs: [ modifierTypes.GRIP_CLAW, modifierTypes.MAX_LURE, modifierTypes.ROGUE_BALL ], fillRemaining: false }); encounter.selectedOption!.dialogue!.selected = [ { - speaker: `${namespace}.speaker`, - text: `${namespace}.option.2.selected_4_to_5`, + speaker: `${namespace}:speaker`, + text: `${namespace}:option.2.selected_4_to_5`, }, ]; } else { - // If player has any evolution/form change items that are valid for their party, will spawn one of those items in addition to a Master Ball - const modifierOptions: ModifierTypeOption[] = [generateModifierTypeOption(scene, modifierTypes.MASTER_BALL)!, generateModifierTypeOption(scene, modifierTypes.MAX_LURE)!]; + // If the player has any evolution/form change items that are valid for their party, + // spawn one of those items in addition to Dynamax Band, Mega Band, and Master Ball + const modifierOptions: ModifierTypeOption[] = [ generateModifierTypeOption(scene, modifierTypes.MASTER_BALL)! ]; const specialOptions: ModifierTypeOption[] = []; + if (!scene.findModifier(m => m instanceof MegaEvolutionAccessModifier)) { + modifierOptions.push(generateModifierTypeOption(scene, modifierTypes.MEGA_BRACELET)!); + } + if (!scene.findModifier(m => m instanceof GigantamaxAccessModifier)) { + modifierOptions.push(generateModifierTypeOption(scene, modifierTypes.DYNAMAX_BAND)!); + } const nonRareEvolutionModifier = generateModifierTypeOption(scene, modifierTypes.EVOLUTION_ITEM); if (nonRareEvolutionModifier) { specialOptions.push(nonRareEvolutionModifier); @@ -329,6 +383,10 @@ export const BugTypeSuperfanEncounter: MysteryEncounter = if (formChangeModifier) { specialOptions.push(formChangeModifier); } + const rareFormChangeModifier = generateModifierTypeOption(scene, modifierTypes.RARE_FORM_CHANGE_ITEM); + if (rareFormChangeModifier) { + specialOptions.push(rareFormChangeModifier); + } if (specialOptions.length > 0) { modifierOptions.push(specialOptions[randSeedInt(specialOptions.length)]); } @@ -336,8 +394,8 @@ export const BugTypeSuperfanEncounter: MysteryEncounter = setEncounterRewards(scene, { guaranteedModifierTypeOptions: modifierOptions, fillRemaining: false }); encounter.selectedOption!.dialogue!.selected = [ { - speaker: `${namespace}.speaker`, - text: `${namespace}.option.2.selected_6`, + speaker: `${namespace}:speaker`, + text: `${namespace}:option.2.selected_6`, }, ]; } @@ -349,25 +407,27 @@ export const BugTypeSuperfanEncounter: MysteryEncounter = .build()) .withOption(MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DISABLED_OR_DEFAULT) - .withPrimaryPokemonRequirement(new CombinationPokemonRequirement( - // Meets one or both of the below reqs - new HeldItemRequirement(["BypassSpeedChanceModifier", "ContactHeldItemTransferChanceModifier"], 1), - new AttackTypeBoosterHeldItemTypeRequirement(Type.BUG, 1) - )) + .withPrimaryPokemonRequirement( + CombinationPokemonRequirement.Some( + // Meets one or both of the below reqs + new HeldItemRequirement([ "BypassSpeedChanceModifier", "ContactHeldItemTransferChanceModifier" ], 1), + new AttackTypeBoosterHeldItemTypeRequirement(Type.BUG, 1) + ) + ) .withDialogue({ - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, - disabledButtonTooltip: `${namespace}.option.3.disabled_tooltip`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, + disabledButtonTooltip: `${namespace}:option.3.disabled_tooltip`, selected: [ { - text: `${namespace}.option.3.selected`, + text: `${namespace}:option.3.selected`, }, { - speaker: `${namespace}.speaker`, - text: `${namespace}.option.3.selected_dialogue`, + speaker: `${namespace}:speaker`, + text: `${namespace}:option.3.selected_dialogue`, }, ], - secondOptionPrompt: `${namespace}.option.3.select_prompt`, + secondOptionPrompt: `${namespace}:option.3.select_prompt`, }) .withPreOptionPhase(async (scene: BattleScene): Promise => { const encounter = scene.currentBattle.mysteryEncounter!; @@ -375,9 +435,10 @@ export const BugTypeSuperfanEncounter: MysteryEncounter = const onPokemonSelected = (pokemon: PlayerPokemon) => { // Get Pokemon held items and filter for valid ones const validItems = pokemon.getHeldItems().filter(item => { - return item instanceof BypassSpeedChanceModifier || + return (item instanceof BypassSpeedChanceModifier || item instanceof ContactHeldItemTransferChanceModifier || - (item instanceof AttackTypeBoosterModifier && (item.type as AttackTypeBoosterModifierType).moveType === Type.BUG); + (item instanceof AttackTypeBoosterModifier && (item.type as AttackTypeBoosterModifierType).moveType === Type.BUG)) && + item.isTransferable; }); return validItems.map((modifier: PokemonHeldItemModifier) => { @@ -405,7 +466,7 @@ export const BugTypeSuperfanEncounter: MysteryEncounter = (item instanceof AttackTypeBoosterModifier && (item.type as AttackTypeBoosterModifierType).moveType === Type.BUG); }); if (!hasValidItem) { - return getEncounterText(scene, `${namespace}.option.3.invalid_selection`) ?? null; + return getEncounterText(scene, `${namespace}:option.3.invalid_selection`) ?? null; } return null; @@ -416,24 +477,21 @@ export const BugTypeSuperfanEncounter: MysteryEncounter = .withOptionPhase(async (scene: BattleScene) => { const encounter = scene.currentBattle.mysteryEncounter!; const modifier = encounter.misc.chosenModifier; + const chosenPokemon: PlayerPokemon = encounter.misc.chosenPokemon; - // Remove the modifier if its stacks go to 0 - modifier.stackCount -= 1; - if (modifier.stackCount === 0) { - scene.removeModifier(modifier); - } + chosenPokemon.loseHeldItem(modifier, false); scene.updateModifiers(true, true); const bugNet = generateModifierTypeOption(scene, modifierTypes.MYSTERY_ENCOUNTER_GOLDEN_BUG_NET)!; bugNet.type.tier = ModifierTier.ROGUE; - setEncounterRewards(scene, { guaranteedModifierTypeOptions: [bugNet], guaranteedModifierTypeFuncs: [modifierTypes.REVIVER_SEED], fillRemaining: false }); + setEncounterRewards(scene, { guaranteedModifierTypeOptions: [ bugNet ], guaranteedModifierTypeFuncs: [ modifierTypes.REVIVER_SEED ], fillRemaining: false }); leaveEncounterWithoutBattle(scene, true); }) .build()) .withOutroDialogue([ { - text: `${namespace}.outro`, + text: `${namespace}:outro`, }, ]) .build(); @@ -443,29 +501,29 @@ function getTrainerConfigForWave(waveIndex: number) { const config = trainerConfigs[TrainerType.BUG_TYPE_SUPERFAN].clone(); config.name = i18next.t("trainerNames:bug_type_superfan"); - const pool3Copy = POOL_3_POKEMON.slice(0); - randSeedShuffle(pool3Copy); + let pool3Copy = POOL_3_POKEMON.slice(0); + pool3Copy = randSeedShuffle(pool3Copy); const pool3Mon = pool3Copy.pop()!; - if (waveIndex < 30) { + if (waveIndex < WAVE_LEVEL_BREAKPOINTS[0]) { // Use default template (2 AVG) config .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.BEEDRILL ], TrainerSlot.TRAINER, true)) .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.BUTTERFREE ], TrainerSlot.TRAINER, true)); - } else if (waveIndex < 50) { + } else if (waveIndex < WAVE_LEVEL_BREAKPOINTS[1]) { config .setPartyTemplates(new TrainerPartyTemplate(3, PartyMemberStrength.AVERAGE)) .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.BEEDRILL ], TrainerSlot.TRAINER, true)) .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.BUTTERFREE ], TrainerSlot.TRAINER, true)) .setPartyMemberFunc(2, getRandomPartyMemberFunc(POOL_1_POKEMON, TrainerSlot.TRAINER, true)); - } else if (waveIndex < 70) { + } else if (waveIndex < WAVE_LEVEL_BREAKPOINTS[2]) { config .setPartyTemplates(new TrainerPartyTemplate(4, PartyMemberStrength.AVERAGE)) .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.BEEDRILL ], TrainerSlot.TRAINER, true)) .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.BUTTERFREE ], TrainerSlot.TRAINER, true)) .setPartyMemberFunc(2, getRandomPartyMemberFunc(POOL_1_POKEMON, TrainerSlot.TRAINER, true)) .setPartyMemberFunc(3, getRandomPartyMemberFunc(POOL_2_POKEMON, TrainerSlot.TRAINER, true)); - } else if (waveIndex < 100) { + } else if (waveIndex < WAVE_LEVEL_BREAKPOINTS[3]) { config .setPartyTemplates(new TrainerPartyTemplate(5, PartyMemberStrength.AVERAGE)) .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.BEEDRILL ], TrainerSlot.TRAINER, true)) @@ -473,7 +531,7 @@ function getTrainerConfigForWave(waveIndex: number) { .setPartyMemberFunc(2, getRandomPartyMemberFunc(POOL_1_POKEMON, TrainerSlot.TRAINER, true)) .setPartyMemberFunc(3, getRandomPartyMemberFunc(POOL_2_POKEMON, TrainerSlot.TRAINER, true)) .setPartyMemberFunc(4, getRandomPartyMemberFunc(POOL_2_POKEMON, TrainerSlot.TRAINER, true)); - } else if (waveIndex < 120) { + } else if (waveIndex < WAVE_LEVEL_BREAKPOINTS[4]) { config .setPartyTemplates(new TrainerPartyTemplate(5, PartyMemberStrength.AVERAGE)) .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.BEEDRILL ], TrainerSlot.TRAINER, true, p => { @@ -488,15 +546,15 @@ function getTrainerConfigForWave(waveIndex: number) { })) .setPartyMemberFunc(2, getRandomPartyMemberFunc(POOL_2_POKEMON, TrainerSlot.TRAINER, true)) .setPartyMemberFunc(3, getRandomPartyMemberFunc(POOL_2_POKEMON, TrainerSlot.TRAINER, true)) - .setPartyMemberFunc(4, getRandomPartyMemberFunc([pool3Mon.species], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(4, getRandomPartyMemberFunc([ pool3Mon.species ], TrainerSlot.TRAINER, true, p => { if (!isNullOrUndefined(pool3Mon.formIndex)) { - p.formIndex = pool3Mon.formIndex!; + p.formIndex = pool3Mon.formIndex; p.generateAndPopulateMoveset(); p.generateName(); } })); - } else if (waveIndex < 140) { - randSeedShuffle(pool3Copy); + } else if (waveIndex < WAVE_LEVEL_BREAKPOINTS[5]) { + pool3Copy = randSeedShuffle(pool3Copy); const pool3Mon2 = pool3Copy.pop()!; config .setPartyTemplates(new TrainerPartyTemplate(5, PartyMemberStrength.AVERAGE)) @@ -511,21 +569,21 @@ function getTrainerConfigForWave(waveIndex: number) { p.generateName(); })) .setPartyMemberFunc(2, getRandomPartyMemberFunc(POOL_2_POKEMON, TrainerSlot.TRAINER, true)) - .setPartyMemberFunc(3, getRandomPartyMemberFunc([pool3Mon.species], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(3, getRandomPartyMemberFunc([ pool3Mon.species ], TrainerSlot.TRAINER, true, p => { if (!isNullOrUndefined(pool3Mon.formIndex)) { - p.formIndex = pool3Mon.formIndex!; + p.formIndex = pool3Mon.formIndex; p.generateAndPopulateMoveset(); p.generateName(); } })) - .setPartyMemberFunc(4, getRandomPartyMemberFunc([pool3Mon2.species], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(4, getRandomPartyMemberFunc([ pool3Mon2.species ], TrainerSlot.TRAINER, true, p => { if (!isNullOrUndefined(pool3Mon2.formIndex)) { - p.formIndex = pool3Mon2.formIndex!; + p.formIndex = pool3Mon2.formIndex; p.generateAndPopulateMoveset(); p.generateName(); } })); - } else if (waveIndex < 160) { + } else if (waveIndex < WAVE_LEVEL_BREAKPOINTS[6]) { config .setPartyTemplates(new TrainerPartyCompoundTemplate(new TrainerPartyTemplate(4, PartyMemberStrength.AVERAGE), new TrainerPartyTemplate(1, PartyMemberStrength.STRONG))) .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.BEEDRILL ], TrainerSlot.TRAINER, true, p => { @@ -539,15 +597,17 @@ function getTrainerConfigForWave(waveIndex: number) { p.generateName(); })) .setPartyMemberFunc(2, getRandomPartyMemberFunc(POOL_2_POKEMON, TrainerSlot.TRAINER, true)) - .setPartyMemberFunc(3, getRandomPartyMemberFunc([pool3Mon.species], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(3, getRandomPartyMemberFunc([ pool3Mon.species ], TrainerSlot.TRAINER, true, p => { if (!isNullOrUndefined(pool3Mon.formIndex)) { - p.formIndex = pool3Mon.formIndex!; + p.formIndex = pool3Mon.formIndex; p.generateAndPopulateMoveset(); p.generateName(); } })) .setPartyMemberFunc(4, getRandomPartyMemberFunc(POOL_4_POKEMON, TrainerSlot.TRAINER, true)); } else { + pool3Copy = randSeedShuffle(pool3Copy); + const pool3Mon2 = pool3Copy.pop()!; config .setPartyTemplates(new TrainerPartyCompoundTemplate(new TrainerPartyTemplate(4, PartyMemberStrength.AVERAGE), new TrainerPartyTemplate(1, PartyMemberStrength.STRONG))) .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.BEEDRILL ], TrainerSlot.TRAINER, true, p => { @@ -562,16 +622,16 @@ function getTrainerConfigForWave(waveIndex: number) { p.generateAndPopulateMoveset(); p.generateName(); })) - .setPartyMemberFunc(2, getRandomPartyMemberFunc([pool3Mon.species], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(2, getRandomPartyMemberFunc([ pool3Mon.species ], TrainerSlot.TRAINER, true, p => { if (!isNullOrUndefined(pool3Mon.formIndex)) { - p.formIndex = pool3Mon.formIndex!; + p.formIndex = pool3Mon.formIndex; p.generateAndPopulateMoveset(); p.generateName(); } })) - .setPartyMemberFunc(3, getRandomPartyMemberFunc([pool3Mon.species], TrainerSlot.TRAINER, true, p => { - if (!isNullOrUndefined(pool3Mon.formIndex)) { - p.formIndex = pool3Mon.formIndex!; + .setPartyMemberFunc(3, getRandomPartyMemberFunc([ pool3Mon2.species ], TrainerSlot.TRAINER, true, p => { + if (!isNullOrUndefined(pool3Mon2.formIndex)) { + p.formIndex = pool3Mon2.formIndex; p.generateAndPopulateMoveset(); p.generateName(); } @@ -582,20 +642,10 @@ function getTrainerConfigForWave(waveIndex: number) { return config; } -function getRandomPartyMemberFunc(speciesPool: Species[], trainerSlot: TrainerSlot = TrainerSlot.TRAINER, ignoreEvolution: boolean = false, postProcess?: (enemyPokemon: EnemyPokemon) => void) { - return (scene: BattleScene, level: number, strength: PartyMemberStrength) => { - let species = Utils.randSeedItem(speciesPool); - if (!ignoreEvolution) { - species = getPokemonSpecies(species).getTrainerSpeciesForLevel(level, true, strength); - } - return scene.addEnemyPokemon(getPokemonSpecies(species), level, trainerSlot, undefined, undefined, postProcess); - }; -} - function doBugTypeMoveTutor(scene: BattleScene): Promise { return new Promise(async resolve => { const moveOptions = scene.currentBattle.mysteryEncounter!.misc.moveTutorOptions; - await showEncounterDialogue(scene, `${namespace}.battle_won`, `${namespace}.speaker`); + await showEncounterDialogue(scene, `${namespace}:battle_won`, `${namespace}:speaker`); const overlayScale = 1; const moveInfoOverlay = new MoveInfoOverlay(scene, { @@ -630,34 +680,14 @@ function doBugTypeMoveTutor(scene: BattleScene): Promise { moveInfoOverlay.setVisible(false); }; - const result = await selectOptionThenPokemon(scene, optionSelectItems, `${namespace}.teach_move_prompt`, undefined, onHoverOverCancel); + const result = await selectOptionThenPokemon(scene, optionSelectItems, `${namespace}:teach_move_prompt`, undefined, onHoverOverCancel); // let forceExit = !!result; if (!result) { moveInfoOverlay.active = false; moveInfoOverlay.setVisible(false); } - // TODO: add menu to confirm player doesn't want to teach a move - // while (!result && !forceExit) { - // // Didn't teach a move, ask the player to confirm they don't want to teach a move - // await showEncounterDialogue(scene, `${namespace}.confirm_no_teach`, `${namespace}.speaker`); - // const confirm = await new Promise(confirmResolve => { - // scene.ui.setMode(Mode.CONFIRM, () => confirmResolve(true), () => confirmResolve(false)); - // }); - // scene.ui.clearText(); - // await scene.ui.setMode(Mode.MESSAGE); - // if (confirm) { - // // No teach, break out of loop - // forceExit = true; - // } else { - // // Re-show learn menu - // result = await selectOptionThenPokemon(scene, optionSelectItems, `${namespace}.teach_move_prompt`, undefined, onHoverOverCancel); - // if (!result) { - // moveInfoOverlay.active = false; - // moveInfoOverlay.setVisible(false); - // } - // } - // } + // TODO: add menu to confirm player doesn't want to teach a move? // Option select complete, handle if they are learning a move if (result && result.selectedOptionIndex < moveOptions.length) { diff --git a/src/data/mystery-encounters/encounters/clowning-around-encounter.ts b/src/data/mystery-encounters/encounters/clowning-around-encounter.ts index 061d2a33e8a..ae6cabd4dae 100644 --- a/src/data/mystery-encounters/encounters/clowning-around-encounter.ts +++ b/src/data/mystery-encounters/encounters/clowning-around-encounter.ts @@ -1,18 +1,18 @@ import { EnemyPartyConfig, generateModifierType, initBattleWithEnemyConfig, leaveEncounterWithoutBattle, loadCustomMovesForEncounter, selectPokemonForOption, setEncounterRewards, transitionMysteryEncounterIntroVisuals } from "#app/data/mystery-encounters/utils/encounter-phase-utils"; import { trainerConfigs, TrainerPartyCompoundTemplate, TrainerPartyTemplate, } from "#app/data/trainer-config"; import { ModifierTier } from "#app/modifier/modifier-tier"; -import { modifierTypes, PokemonHeldItemModifierType } from "#app/modifier/modifier-type"; +import { ModifierPoolType, modifierTypes, PokemonHeldItemModifierType } from "#app/modifier/modifier-type"; import { MysteryEncounterType } from "#enums/mystery-encounter-type"; import { PartyMemberStrength } from "#enums/party-member-strength"; import BattleScene from "#app/battle-scene"; -import MysteryEncounter, { MysteryEncounterBuilder } from "../mystery-encounter"; +import MysteryEncounter, { MysteryEncounterBuilder } from "#app/data/mystery-encounters/mystery-encounter"; import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; import { Species } from "#enums/species"; import { TrainerType } from "#enums/trainer-type"; import { getPokemonSpecies } from "#app/data/pokemon-species"; import { Abilities } from "#enums/abilities"; -import { applyModifierTypeToPlayerPokemon } from "#app/data/mystery-encounters/utils/encounter-pokemon-utils"; -import { Type } from "#app/data/type"; +import { applyAbilityOverrideToPokemon, applyModifierTypeToPlayerPokemon } from "#app/data/mystery-encounters/utils/encounter-pokemon-utils"; +import { Type } from "#enums/type"; import { MysteryEncounterOptionBuilder } from "#app/data/mystery-encounters/mystery-encounter-option"; import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode"; import { randSeedInt, randSeedShuffle } from "#app/utils"; @@ -28,12 +28,13 @@ import { BattlerIndex } from "#app/battle"; import { Moves } from "#enums/moves"; import { EncounterBattleAnim } from "#app/data/battle-anims"; import { MoveCategory } from "#app/data/move"; -import { MysteryEncounterPokemonData } from "#app/data/mystery-encounters/mystery-encounter-pokemon-data"; -import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES, GameModes } from "#app/game-mode"; +import { CustomPokemonData } from "#app/data/custom-pokemon-data"; +import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES } from "#app/game-mode"; import { EncounterAnim } from "#enums/encounter-anims"; +import { Challenges } from "#enums/challenges"; /** the i18n namespace for the encounter */ -const namespace = "mysteryEncounter:clowningAround"; +const namespace = "mysteryEncounters/clowningAround"; const RANDOM_ABILITY_POOL = [ Abilities.STURDY, @@ -61,7 +62,7 @@ const RANDOM_ABILITY_POOL = [ export const ClowningAroundEncounter: MysteryEncounter = MysteryEncounterBuilder.withEncounterType(MysteryEncounterType.CLOWNING_AROUND) .withEncounterTier(MysteryEncounterTier.ULTRA) - .withDisabledGameModes(GameModes.CHALLENGE) + .withDisallowedChallenges(Challenges.SINGLE_TYPE) .withSceneWaveRangeRequirement(80, CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES[1]) .withAnimations(EncounterAnim.SMOKESCREEN) .withAutoHideIntroVisuals(false) @@ -97,11 +98,11 @@ export const ClowningAroundEncounter: MysteryEncounter = ]) .withIntroDialogue([ { - text: `${namespace}.intro`, + text: `${namespace}:intro`, }, { - text: `${namespace}.intro_dialogue`, - speaker: `${namespace}.speaker` + text: `${namespace}:intro_dialogue`, + speaker: `${namespace}:speaker` }, ]) .withOnInit((scene: BattleScene) => { @@ -128,38 +129,39 @@ export const ClowningAroundEncounter: MysteryEncounter = { species: getPokemonSpecies(Species.MR_MIME), isBoss: true, - moveSet: [Moves.TEETER_DANCE, Moves.ALLY_SWITCH, Moves.DAZZLING_GLEAM, Moves.PSYCHIC] + moveSet: [ Moves.TEETER_DANCE, Moves.ALLY_SWITCH, Moves.DAZZLING_GLEAM, Moves.PSYCHIC ] }, { // Blacephalon has the random ability from pool, and 2 entirely random types to fit with the theme of the encounter species: getPokemonSpecies(Species.BLACEPHALON), - mysteryEncounterPokemonData: new MysteryEncounterPokemonData({ ability: ability, types: [randSeedInt(18), randSeedInt(18)] }), + customPokemonData: new CustomPokemonData({ ability: ability, types: [ randSeedInt(18), randSeedInt(18) ]}), isBoss: true, - moveSet: [Moves.TRICK, Moves.HYPNOSIS, Moves.SHADOW_BALL, Moves.MIND_BLOWN] + moveSet: [ Moves.TRICK, Moves.HYPNOSIS, Moves.SHADOW_BALL, Moves.MIND_BLOWN ] }, ], doubleBattle: true }); // Load animations/sfx for start of fight moves - loadCustomMovesForEncounter(scene, [Moves.ROLE_PLAY, Moves.TAUNT]); + loadCustomMovesForEncounter(scene, [ Moves.ROLE_PLAY, Moves.TAUNT ]); encounter.setDialogueToken("blacephalonName", getPokemonSpecies(Species.BLACEPHALON).getName()); return true; }) - .withTitle(`${namespace}.title`) - .withDescription(`${namespace}.description`) - .withQuery(`${namespace}.query`) + .setLocalizationKey(`${namespace}`) + .withTitle(`${namespace}:title`) + .withDescription(`${namespace}:description`) + .withQuery(`${namespace}:query`) .withOption( MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) .withDialogue({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.1.selected`, - speaker: `${namespace}.speaker` + text: `${namespace}:option.1.selected`, + speaker: `${namespace}:speaker` }, ], }) @@ -174,19 +176,19 @@ export const ClowningAroundEncounter: MysteryEncounter = encounter.startOfBattleEffects.push( { // Mr. Mime copies the Blacephalon's random ability sourceBattlerIndex: BattlerIndex.ENEMY, - targets: [BattlerIndex.ENEMY_2], + targets: [ BattlerIndex.ENEMY_2 ], move: new PokemonMove(Moves.ROLE_PLAY), ignorePp: true }, { sourceBattlerIndex: BattlerIndex.ENEMY_2, - targets: [BattlerIndex.PLAYER], + targets: [ BattlerIndex.PLAYER ], move: new PokemonMove(Moves.TAUNT), ignorePp: true }, { sourceBattlerIndex: BattlerIndex.ENEMY_2, - targets: [BattlerIndex.PLAYER_2], + targets: [ BattlerIndex.PLAYER_2 ], move: new PokemonMove(Moves.TAUNT), ignorePp: true }); @@ -198,7 +200,7 @@ export const ClowningAroundEncounter: MysteryEncounter = // After the battle, offer the player the opportunity to permanently swap ability const abilityWasSwapped = await handleSwapAbility(scene); if (abilityWasSwapped) { - await showEncounterText(scene, `${namespace}.option.1.ability_gained`); + await showEncounterText(scene, `${namespace}:option.1.ability_gained`); } // Play animations once ability swap is complete @@ -221,19 +223,19 @@ export const ClowningAroundEncounter: MysteryEncounter = MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) .withDialogue({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, selected: [ { - text: `${namespace}.option.2.selected`, - speaker: `${namespace}.speaker` + text: `${namespace}:option.2.selected`, + speaker: `${namespace}:speaker` }, { - text: `${namespace}.option.2.selected_2`, + text: `${namespace}:option.2.selected_2`, }, { - text: `${namespace}.option.2.selected_3`, - speaker: `${namespace}.speaker` + text: `${namespace}:option.2.selected_3`, + speaker: `${namespace}:speaker` }, ], }) @@ -243,15 +245,15 @@ export const ClowningAroundEncounter: MysteryEncounter = // So Vitamins, form change items, etc. are not included const encounter = scene.currentBattle.mysteryEncounter!; - const party = scene.getParty(); + const party = scene.getPlayerParty(); let mostHeldItemsPokemon = party[0]; let count = mostHeldItemsPokemon.getHeldItems() - .filter(m => m.isTransferrable && !(m instanceof BerryModifier)) + .filter(m => m.isTransferable && !(m instanceof BerryModifier)) .reduce((v, m) => v + m.stackCount, 0); party.forEach(pokemon => { const nextCount = pokemon.getHeldItems() - .filter(m => m.isTransferrable && !(m instanceof BerryModifier)) + .filter(m => m.isTransferable && !(m instanceof BerryModifier)) .reduce((v, m) => v + m.stackCount, 0); if (nextCount > count) { mostHeldItemsPokemon = pokemon; @@ -276,9 +278,9 @@ export const ClowningAroundEncounter: MysteryEncounter = // Shuffle Transferable held items in the same tier (only shuffles Ultra and Rogue atm) let numUltra = 0; let numRogue = 0; - items.filter(m => m.isTransferrable && !(m instanceof BerryModifier)) + items.filter(m => m.isTransferable && !(m instanceof BerryModifier)) .forEach(m => { - const type = m.type.withTierFromPool(); + const type = m.type.withTierFromPool(ModifierPoolType.PLAYER, party); const tier = type.tier ?? ModifierTier.ULTRA; if (type.id === "GOLDEN_EGG" || tier === ModifierTier.ROGUE) { numRogue += m.stackCount; @@ -307,26 +309,26 @@ export const ClowningAroundEncounter: MysteryEncounter = MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) .withDialogue({ - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, selected: [ { - text: `${namespace}.option.3.selected`, - speaker: `${namespace}.speaker` + text: `${namespace}:option.3.selected`, + speaker: `${namespace}:speaker` }, { - text: `${namespace}.option.3.selected_2`, + text: `${namespace}:option.3.selected_2`, }, { - text: `${namespace}.option.3.selected_3`, - speaker: `${namespace}.speaker` + text: `${namespace}:option.3.selected_3`, + speaker: `${namespace}:speaker` }, ], }) .withPreOptionPhase(async (scene: BattleScene) => { // Randomize the second type of all player's pokemon // If the pokemon does not normally have a second type, it will gain 1 - for (const pokemon of scene.getParty()) { + for (const pokemon of scene.getPlayerParty()) { const originalTypes = pokemon.getTypes(false, false, true); // If the Pokemon has non-status moves that don't match the Pokemon's type, prioritizes those as the new type @@ -335,11 +337,11 @@ export const ClowningAroundEncounter: MysteryEncounter = .filter(move => move && !originalTypes.includes(move.getMove().type) && move.getMove().category !== MoveCategory.STATUS) .map(move => move!.getMove().type); if (priorityTypes?.length > 0) { - priorityTypes = [...new Set(priorityTypes)]; - randSeedShuffle(priorityTypes); + priorityTypes = [ ...new Set(priorityTypes) ].sort(); + priorityTypes = randSeedShuffle(priorityTypes); } - const newTypes = [originalTypes[0]]; + const newTypes = [ originalTypes[0] ]; let secondType: Type | null = null; while (secondType === null || secondType === newTypes[0] || originalTypes.includes(secondType)) { if (priorityTypes.length > 0) { @@ -349,10 +351,18 @@ export const ClowningAroundEncounter: MysteryEncounter = } } newTypes.push(secondType); - if (!pokemon.mysteryEncounterPokemonData) { - pokemon.mysteryEncounterPokemonData = new MysteryEncounterPokemonData(); + + // Apply the type changes (to both base and fusion, if pokemon is fused) + if (!pokemon.customPokemonData) { + pokemon.customPokemonData = new CustomPokemonData(); + } + pokemon.customPokemonData.types = newTypes; + if (pokemon.isFusion()) { + if (!pokemon.fusionCustomPokemonData) { + pokemon.fusionCustomPokemonData = new CustomPokemonData(); + } + pokemon.fusionCustomPokemonData.types = newTypes; } - pokemon.mysteryEncounterPokemonData.types = newTypes; } }) .withOptionPhase(async (scene: BattleScene) => { @@ -368,15 +378,15 @@ export const ClowningAroundEncounter: MysteryEncounter = ) .withOutroDialogue([ { - text: `${namespace}.outro`, + text: `${namespace}:outro`, }, ]) .build(); async function handleSwapAbility(scene: BattleScene) { return new Promise(async resolve => { - await showEncounterDialogue(scene, `${namespace}.option.1.apply_ability_dialogue`, `${namespace}.speaker`); - await showEncounterText(scene, `${namespace}.option.1.apply_ability_message`); + await showEncounterDialogue(scene, `${namespace}:option.1.apply_ability_dialogue`, `${namespace}:speaker`); + await showEncounterText(scene, `${namespace}:option.1.apply_ability_message`); scene.ui.setMode(Mode.MESSAGE).then(() => { displayYesNoOptions(scene, resolve); @@ -385,7 +395,7 @@ async function handleSwapAbility(scene: BattleScene) { } function displayYesNoOptions(scene: BattleScene, resolve) { - showEncounterText(scene, `${namespace}.option.1.ability_prompt`, null, 500, false); + showEncounterText(scene, `${namespace}:option.1.ability_prompt`, null, 500, false); const fullOptions = [ { label: i18next.t("menu:yes"), @@ -415,10 +425,8 @@ function onYesAbilitySwap(scene: BattleScene, resolve) { const onPokemonSelected = (pokemon: PlayerPokemon) => { // Do ability swap const encounter = scene.currentBattle.mysteryEncounter!; - if (!pokemon.mysteryEncounterPokemonData) { - pokemon.mysteryEncounterPokemonData = new MysteryEncounterPokemonData(); - } - pokemon.mysteryEncounterPokemonData.ability = encounter.misc.ability; + + applyAbilityOverrideToPokemon(pokemon, encounter.misc.ability); encounter.setDialogueToken("chosenPokemon", pokemon.getNameToRender()); scene.ui.setMode(Mode.MESSAGE).then(() => resolve(true)); }; @@ -437,37 +445,37 @@ function generateItemsOfTier(scene: BattleScene, pokemon: PlayerPokemon, numItem // Pools have instances of the modifier type equal to the max stacks that modifier can be applied to any one pokemon // This is to prevent "over-generating" a random item of a certain type during item swaps const ultraPool = [ - [modifierTypes.REVIVER_SEED, 1], - [modifierTypes.GOLDEN_PUNCH, 5], - [modifierTypes.ATTACK_TYPE_BOOSTER, 99], - [modifierTypes.QUICK_CLAW, 3], - [modifierTypes.WIDE_LENS, 3] + [ modifierTypes.REVIVER_SEED, 1 ], + [ modifierTypes.GOLDEN_PUNCH, 5 ], + [ modifierTypes.ATTACK_TYPE_BOOSTER, 99 ], + [ modifierTypes.QUICK_CLAW, 3 ], + [ modifierTypes.WIDE_LENS, 3 ] ]; const roguePool = [ - [modifierTypes.LEFTOVERS, 4], - [modifierTypes.SHELL_BELL, 4], - [modifierTypes.SOUL_DEW, 10], - [modifierTypes.SOOTHE_BELL, 3], - [modifierTypes.SCOPE_LENS, 1], - [modifierTypes.BATON, 1], - [modifierTypes.FOCUS_BAND, 5], - [modifierTypes.KINGS_ROCK, 3], - [modifierTypes.GRIP_CLAW, 5] + [ modifierTypes.LEFTOVERS, 4 ], + [ modifierTypes.SHELL_BELL, 4 ], + [ modifierTypes.SOUL_DEW, 10 ], + [ modifierTypes.SOOTHE_BELL, 3 ], + [ modifierTypes.SCOPE_LENS, 1 ], + [ modifierTypes.BATON, 1 ], + [ modifierTypes.FOCUS_BAND, 5 ], + [ modifierTypes.KINGS_ROCK, 3 ], + [ modifierTypes.GRIP_CLAW, 5 ] ]; const berryPool = [ - [BerryType.APICOT, 3], - [BerryType.ENIGMA, 2], - [BerryType.GANLON, 3], - [BerryType.LANSAT, 3], - [BerryType.LEPPA, 2], - [BerryType.LIECHI, 3], - [BerryType.LUM, 2], - [BerryType.PETAYA, 3], - [BerryType.SALAC, 2], - [BerryType.SITRUS, 2], - [BerryType.STARF, 3] + [ BerryType.APICOT, 3 ], + [ BerryType.ENIGMA, 2 ], + [ BerryType.GANLON, 3 ], + [ BerryType.LANSAT, 3 ], + [ BerryType.LEPPA, 2 ], + [ BerryType.LIECHI, 3 ], + [ BerryType.LUM, 2 ], + [ BerryType.PETAYA, 3 ], + [ BerryType.SALAC, 2 ], + [ BerryType.SITRUS, 2 ], + [ BerryType.STARF, 3 ] ]; let pool: any[]; @@ -478,11 +486,15 @@ function generateItemsOfTier(scene: BattleScene, pokemon: PlayerPokemon, numItem } for (let i = 0; i < numItems; i++) { + if (pool.length === 0) { + // Stop generating new items if somehow runs out of items to spawn + return; + } const randIndex = randSeedInt(pool.length); const newItemType = pool[randIndex]; - let newMod; + let newMod: PokemonHeldItemModifierType; if (tier === "Berries") { - newMod = generateModifierType(scene, modifierTypes.BERRY, [newItemType[0]]) as PokemonHeldItemModifierType; + newMod = generateModifierType(scene, modifierTypes.BERRY, [ newItemType[0] ]) as PokemonHeldItemModifierType; } else { newMod = generateModifierType(scene, newItemType[0]) as PokemonHeldItemModifierType; } diff --git a/src/data/mystery-encounters/encounters/dancing-lessons-encounter.ts b/src/data/mystery-encounters/encounters/dancing-lessons-encounter.ts index 046e2b2f876..bae5a8790e9 100644 --- a/src/data/mystery-encounters/encounters/dancing-lessons-encounter.ts +++ b/src/data/mystery-encounters/encounters/dancing-lessons-encounter.ts @@ -1,35 +1,36 @@ -import { EnemyPartyConfig, initBattleWithEnemyConfig, leaveEncounterWithoutBattle, selectPokemonForOption, setEncounterRewards } from "#app/data/mystery-encounters/utils/encounter-phase-utils"; -import Pokemon, { EnemyPokemon, PlayerPokemon, PokemonMove } from "#app/field/pokemon"; -import { MysteryEncounterType } from "#enums/mystery-encounter-type"; -import { Species } from "#enums/species"; +import { BattlerIndex } from "#app/battle"; import BattleScene from "#app/battle-scene"; -import MysteryEncounter, { MysteryEncounterBuilder } from "../mystery-encounter"; -import { MysteryEncounterOptionBuilder } from "../mystery-encounter-option"; -import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; -import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode"; -import { getPokemonSpecies } from "#app/data/pokemon-species"; -import { Moves } from "#enums/moves"; -import { TrainerSlot } from "#app/data/trainer-config"; -import PokemonData from "#app/system/pokemon-data"; -import { Biome } from "#enums/biome"; import { EncounterBattleAnim } from "#app/data/battle-anims"; -import { BattlerTagType } from "#enums/battler-tag-type"; -import { getEncounterText, queueEncounterMessage } from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; +import MysteryEncounter, { MysteryEncounterBuilder } from "#app/data/mystery-encounters/mystery-encounter"; +import { MysteryEncounterOptionBuilder } from "#app/data/mystery-encounters/mystery-encounter-option"; import { MoveRequirement } from "#app/data/mystery-encounters/mystery-encounter-requirements"; import { DANCING_MOVES } from "#app/data/mystery-encounters/requirements/requirement-groups"; -import { OptionSelectItem } from "#app/ui/abstact-option-select-ui-handler"; -import { BattlerIndex } from "#app/battle"; -import { catchPokemon } from "#app/data/mystery-encounters/utils/encounter-pokemon-utils"; -import { PokeballType } from "#enums/pokeball"; +import { getEncounterText, queueEncounterMessage } from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; +import { EnemyPartyConfig, initBattleWithEnemyConfig, leaveEncounterWithoutBattle, selectPokemonForOption, setEncounterRewards } from "#app/data/mystery-encounters/utils/encounter-phase-utils"; +import { catchPokemon, getEncounterPokemonLevelForWave, STANDARD_ENCOUNTER_BOOSTED_LEVEL_MODIFIER } from "#app/data/mystery-encounters/utils/encounter-pokemon-utils"; +import { getPokemonSpecies } from "#app/data/pokemon-species"; +import { TrainerSlot } from "#app/data/trainer-config"; +import Pokemon, { EnemyPokemon, PlayerPokemon, PokemonMove } from "#app/field/pokemon"; +import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES } from "#app/game-mode"; import { modifierTypes } from "#app/modifier/modifier-type"; import { LearnMovePhase } from "#app/phases/learn-move-phase"; import { StatStageChangePhase } from "#app/phases/stat-stage-change-phase"; -import { Stat } from "#enums/stat"; +import PokemonData from "#app/system/pokemon-data"; +import { OptionSelectItem } from "#app/ui/abstact-option-select-ui-handler"; +import { BattlerTagType } from "#enums/battler-tag-type"; +import { Biome } from "#enums/biome"; import { EncounterAnim } from "#enums/encounter-anims"; -import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES } from "#app/game-mode"; +import { Moves } from "#enums/moves"; +import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode"; +import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; +import { MysteryEncounterType } from "#enums/mystery-encounter-type"; +import { PokeballType } from "#enums/pokeball"; +import { Species } from "#enums/species"; +import { Stat } from "#enums/stat"; +import i18next from "i18next"; /** the i18n namespace for this encounter */ -const namespace = "mysteryEncounter:dancingLessons"; +const namespace = "mysteryEncounters/dancingLessons"; // Fire form const BAILE_STYLE_BIOMES = [ @@ -89,25 +90,27 @@ export const DancingLessonsEncounter: MysteryEncounter = .withHideWildIntroMessage(true) .withAutoHideIntroVisuals(false) .withCatchAllowed(true) + .withFleeAllowed(false) .withOnVisualsStart((scene: BattleScene) => { - const danceAnim = new EncounterBattleAnim(EncounterAnim.DANCE, scene.getEnemyPokemon()!, scene.getParty()[0]); + const danceAnim = new EncounterBattleAnim(EncounterAnim.DANCE, scene.getEnemyPokemon()!, scene.getPlayerPokemon()!); danceAnim.play(scene); return true; }) .withIntroDialogue([ { - text: `${namespace}.intro`, + text: `${namespace}:intro`, } ]) - .withTitle(`${namespace}.title`) - .withDescription(`${namespace}.description`) - .withQuery(`${namespace}.query`) + .setLocalizationKey(`${namespace}`) + .withTitle(`${namespace}:title`) + .withDescription(`${namespace}:description`) + .withQuery(`${namespace}:query`) .withOnInit((scene: BattleScene) => { const encounter = scene.currentBattle.mysteryEncounter!; const species = getPokemonSpecies(Species.ORICORIO); - const level = (scene.currentBattle.enemyLevels?.[0] ?? scene.currentBattle.waveIndex) + Math.max(Math.round((scene.currentBattle.waveIndex / 10)), 0); + const level = getEncounterPokemonLevelForWave(scene, STANDARD_ENCOUNTER_BOOSTED_LEVEL_MODIFIER); const enemyPokemon = new EnemyPokemon(scene, species, level, TrainerSlot.NONE, false); if (!enemyPokemon.moveset.some(m => m && m.getMove().id === Moves.REVELATION_DANCE)) { if (enemyPokemon.moveset.length < 4) { @@ -133,33 +136,32 @@ export const DancingLessonsEncounter: MysteryEncounter = } const oricorioData = new PokemonData(enemyPokemon); - const oricorio = scene.addEnemyPokemon(species, scene.currentBattle.enemyLevels![0], TrainerSlot.NONE, false, oricorioData); + const oricorio = scene.addEnemyPokemon(species, level, TrainerSlot.NONE, false, oricorioData); // Adds a real Pokemon sprite to the field (required for the animation) scene.getEnemyParty().forEach(enemyPokemon => { scene.field.remove(enemyPokemon, true); }); - scene.currentBattle.enemyParty = [oricorio]; + scene.currentBattle.enemyParty = [ oricorio ]; scene.field.add(oricorio); // Spawns on offscreen field oricorio.x -= 300; encounter.loadAssets.push(oricorio.loadAssets()); const config: EnemyPartyConfig = { - levelAdditiveMultiplier: 1, pokemonConfigs: [{ species: species, dataSource: oricorioData, isBoss: true, // Gets +1 to all stats except SPD on battle start - tags: [BattlerTagType.MYSTERY_ENCOUNTER_POST_SUMMON], + tags: [ BattlerTagType.MYSTERY_ENCOUNTER_POST_SUMMON ], mysteryEncounterBattleEffects: (pokemon: Pokemon) => { - queueEncounterMessage(pokemon.scene, `${namespace}.option.1.boss_enraged`); - pokemon.scene.unshiftPhase(new StatStageChangePhase(pokemon.scene, pokemon.getBattlerIndex(), true, [Stat.ATK, Stat.DEF, Stat.SPATK, Stat.SPDEF], 1)); + queueEncounterMessage(pokemon.scene, `${namespace}:option.1.boss_enraged`); + pokemon.scene.unshiftPhase(new StatStageChangePhase(pokemon.scene, pokemon.getBattlerIndex(), true, [ Stat.ATK, Stat.DEF, Stat.SPATK, Stat.SPDEF ], 1)); } }], }; - encounter.enemyPartyConfigs = [config]; + encounter.enemyPartyConfigs = [ config ]; encounter.misc = { oricorioData }; @@ -172,11 +174,11 @@ export const DancingLessonsEncounter: MysteryEncounter = MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) .withDialogue({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.1.selected`, + text: `${namespace}:option.1.selected`, }, ], }) @@ -186,13 +188,13 @@ export const DancingLessonsEncounter: MysteryEncounter = encounter.startOfBattleEffects.push({ sourceBattlerIndex: BattlerIndex.ENEMY, - targets: [BattlerIndex.PLAYER], + targets: [ BattlerIndex.PLAYER ], move: new PokemonMove(Moves.REVELATION_DANCE), ignorePp: true }); await hideOricorioPokemon(scene); - setEncounterRewards(scene, { guaranteedModifierTypeFuncs: [modifierTypes.BATON], fillRemaining: true }); + setEncounterRewards(scene, { guaranteedModifierTypeFuncs: [ modifierTypes.BATON ], fillRemaining: true }); await initBattleWithEnemyConfig(scene, encounter.enemyPartyConfigs[0]); }) .build() @@ -201,11 +203,11 @@ export const DancingLessonsEncounter: MysteryEncounter = MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) .withDialogue({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, selected: [ { - text: `${namespace}.option.2.selected`, + text: `${namespace}:option.2.selected`, }, ], }) @@ -215,7 +217,7 @@ export const DancingLessonsEncounter: MysteryEncounter = const onPokemonSelected = (pokemon: PlayerPokemon) => { encounter.setDialogueToken("selectedPokemon", pokemon.getNameToRender()); - scene.unshiftPhase(new LearnMovePhase(scene, scene.getParty().indexOf(pokemon), Moves.REVELATION_DANCE)); + scene.unshiftPhase(new LearnMovePhase(scene, scene.getPlayerParty().indexOf(pokemon), Moves.REVELATION_DANCE)); // Play animation again to "learn" the dance const danceAnim = new EncounterBattleAnim(EncounterAnim.DANCE, scene.getEnemyPokemon()!, scene.getPlayerPokemon()); @@ -226,7 +228,7 @@ export const DancingLessonsEncounter: MysteryEncounter = }) .withOptionPhase(async (scene: BattleScene) => { // Learn its Dance - hideOricorioPokemon(scene); + await hideOricorioPokemon(scene); leaveEncounterWithoutBattle(scene, true); }) .build() @@ -234,15 +236,15 @@ export const DancingLessonsEncounter: MysteryEncounter = .withOption( MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DISABLED_OR_SPECIAL) - .withPrimaryPokemonRequirement(new MoveRequirement(DANCING_MOVES)) // Will set option3PrimaryName and option3PrimaryMove dialogue tokens automatically + .withPrimaryPokemonRequirement(new MoveRequirement(DANCING_MOVES, true)) // Will set option3PrimaryName and option3PrimaryMove dialogue tokens automatically .withDialogue({ - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, - disabledButtonTooltip: `${namespace}.option.3.disabled_tooltip`, - secondOptionPrompt: `${namespace}.option.3.select_prompt`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, + disabledButtonTooltip: `${namespace}:option.3.disabled_tooltip`, + secondOptionPrompt: `${namespace}:option.3.select_prompt`, selected: [ { - text: `${namespace}.option.3.selected`, + text: `${namespace}:option.3.selected`, }, ], }) @@ -269,12 +271,15 @@ export const DancingLessonsEncounter: MysteryEncounter = }); }; - // Only Pokemon that have a Dancing move can be selected + // Only challenge legal/unfainted Pokemon that have a Dancing move can be selected const selectableFilter = (pokemon: Pokemon) => { // If pokemon meets primary pokemon reqs, it can be selected + if (!pokemon.isAllowedInBattle()) { + return i18next.t("partyUiHandler:cantBeUsed", { pokemonName: pokemon.getNameToRender() }) ?? null; + } const meetsReqs = encounter.options[2].pokemonMeetsPrimaryRequirements(scene, pokemon); if (!meetsReqs) { - return getEncounterText(scene, `${namespace}.invalid_selection`) ?? null; + return getEncounterText(scene, `${namespace}:invalid_selection`) ?? null; } return null; @@ -298,7 +303,7 @@ export const DancingLessonsEncounter: MysteryEncounter = } } - hideOricorioPokemon(scene); + await hideOricorioPokemon(scene); await catchPokemon(scene, oricorio, null, PokeballType.POKEBALL, false); leaveEncounterWithoutBattle(scene, true); }) diff --git a/src/data/mystery-encounters/encounters/dark-deal-encounter.ts b/src/data/mystery-encounters/encounters/dark-deal-encounter.ts index 212ff6ed1bb..2b801d70f61 100644 --- a/src/data/mystery-encounters/encounters/dark-deal-encounter.ts +++ b/src/data/mystery-encounters/encounters/dark-deal-encounter.ts @@ -1,12 +1,12 @@ -import { Type } from "#app/data/type"; +import { Type } from "#enums/type"; import { isNullOrUndefined, randSeedInt } from "#app/utils"; import { MysteryEncounterType } from "#enums/mystery-encounter-type"; import { Species } from "#enums/species"; import BattleScene from "#app/battle-scene"; import { modifierTypes } from "#app/modifier/modifier-type"; import { getPokemonSpecies } from "#app/data/pokemon-species"; -import MysteryEncounter, { MysteryEncounterBuilder } from "../mystery-encounter"; -import { MysteryEncounterOptionBuilder } from "../mystery-encounter-option"; +import MysteryEncounter, { MysteryEncounterBuilder } from "#app/data/mystery-encounters/mystery-encounter"; +import { MysteryEncounterOptionBuilder } from "#app/data/mystery-encounters/mystery-encounter-option"; import { EnemyPartyConfig, EnemyPokemonConfig, initBattleWithEnemyConfig, leaveEncounterWithoutBattle, } from "../utils/encounter-phase-utils"; import { getRandomPlayerPokemon, getRandomSpeciesByStarterTier } from "#app/data/mystery-encounters/utils/encounter-pokemon-utils"; import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; @@ -14,11 +14,12 @@ import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode import { ModifierRewardPhase } from "#app/phases/modifier-reward-phase"; import { PokemonFormChangeItemModifier, PokemonHeldItemModifier } from "#app/modifier/modifier"; import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES } from "#app/game-mode"; +import { Challenges } from "#enums/challenges"; /** i18n namespace for encounter */ -const namespace = "mysteryEncounter:darkDeal"; +const namespace = "mysteryEncounters/darkDeal"; -/** Exclude Ultra Beasts (inludes Cosmog/Solgaleo/Lunala/Necrozma), Paradox (includes Miraidon/Koraidon), Eternatus, and egg-locked mythicals */ +/** Exclude Ultra Beasts (inludes Cosmog/Solgaleo/Lunala/Necrozma), Paradox (includes Miraidon/Koraidon), Eternatus, and Mythicals */ const excludedBosses = [ Species.NECROZMA, Species.COSMOG, @@ -63,11 +64,24 @@ const excludedBosses = [ Species.CELEBI, Species.DEOXYS, Species.JIRACHI, + Species.DARKRAI, Species.PHIONE, Species.MANAPHY, Species.ARCEUS, + Species.SHAYMIN, Species.VICTINI, + Species.MELOETTA, + Species.KELDEO, + Species.GENESECT, + Species.DIANCIE, + Species.HOOPA, + Species.VOLCANION, + Species.MAGEARNA, + Species.MARSHADOW, + Species.ZERAORA, + Species.ZARUDE, Species.MELTAN, + Species.MELMETAL, Species.PECHARUNT, ]; @@ -81,7 +95,7 @@ export const DarkDealEncounter: MysteryEncounter = .withEncounterTier(MysteryEncounterTier.ROGUE) .withIntroSpriteConfigs([ { - spriteKey: "mad_scientist_m", + spriteKey: "dark_deal_scientist", fileRoot: "mystery-encounters", hasShadow: true, }, @@ -94,39 +108,41 @@ export const DarkDealEncounter: MysteryEncounter = ]) .withIntroDialogue([ { - text: `${namespace}.intro`, + text: `${namespace}:intro`, }, { - speaker: `${namespace}.speaker`, - text: `${namespace}.intro_dialogue`, + speaker: `${namespace}:speaker`, + text: `${namespace}:intro_dialogue`, }, ]) .withSceneWaveRangeRequirement(30, CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES[1]) - .withScenePartySizeRequirement(2, 6) // Must have at least 2 pokemon in party + .withScenePartySizeRequirement(2, 6, true) // Must have at least 2 pokemon in party .withCatchAllowed(true) - .withTitle(`${namespace}.title`) - .withDescription(`${namespace}.description`) - .withQuery(`${namespace}.query`) + .setLocalizationKey(`${namespace}`) + .withTitle(`${namespace}:title`) + .withDescription(`${namespace}:description`) + .withQuery(`${namespace}:query`) .withOption( MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) .withDialogue({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - speaker: `${namespace}.speaker`, - text: `${namespace}.option.1.selected_dialogue`, + speaker: `${namespace}:speaker`, + text: `${namespace}:option.1.selected_dialogue`, }, { - text: `${namespace}.option.1.selected_message`, + text: `${namespace}:option.1.selected_message`, }, ], }) .withPreOptionPhase(async (scene: BattleScene) => { // Removes random pokemon (including fainted) from party and adds name to dialogue data tokens // Will never return last battle able mon and instead pick fainted/unable to battle - const removedPokemon = getRandomPlayerPokemon(scene, false, true); + const removedPokemon = getRandomPlayerPokemon(scene, true, false, true); + // Get all the pokemon's held items const modifiers = removedPokemon.getHeldItems().filter(m => !(m instanceof PokemonFormChangeItemModifier)); scene.removePokemonFromPlayerParty(removedPokemon); @@ -146,19 +162,26 @@ export const DarkDealEncounter: MysteryEncounter = scene.unshiftPhase(new ModifierRewardPhase(scene, modifierTypes.ROGUE_BALL)); // Start encounter with random legendary (7-10 starter strength) that has level additive - const bossTypes: Type[] = encounter.misc.removedTypes; + // If this is a mono-type challenge, always ensure the required type is filtered for + let bossTypes: Type[] = encounter.misc.removedTypes; + const singleTypeChallenges = scene.gameMode.challenges.filter(c => c.value && c.id === Challenges.SINGLE_TYPE); + if (scene.gameMode.isChallenge && singleTypeChallenges.length > 0) { + bossTypes = singleTypeChallenges.map(c => (c.value - 1) as Type); + } + const bossModifiers: PokemonHeldItemModifier[] = encounter.misc.modifiers; // Starter egg tier, 35/50/10/5 %odds for tiers 6/7/8/9+ const roll = randSeedInt(100); const starterTier: number | [number, number] = - roll > 65 ? 6 : roll > 15 ? 7 : roll > 5 ? 8 : [9, 10]; + roll >= 65 ? 6 : roll >= 15 ? 7 : roll >= 5 ? 8 : [ 9, 10 ]; const bossSpecies = getPokemonSpecies(getRandomSpeciesByStarterTier(starterTier, excludedBosses, bossTypes)); const pokemonConfig: EnemyPokemonConfig = { species: bossSpecies, isBoss: true, modifierConfigs: bossModifiers.map(m => { return { - modifier: m + modifier: m, + stackCount: m.getStackCount(), }; }) }; @@ -166,20 +189,20 @@ export const DarkDealEncounter: MysteryEncounter = pokemonConfig.formIndex = 0; } const config: EnemyPartyConfig = { - pokemonConfigs: [pokemonConfig], + pokemonConfigs: [ pokemonConfig ], }; - return initBattleWithEnemyConfig(scene, config); + await initBattleWithEnemyConfig(scene, config); }) .build() ) .withSimpleOption( { - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, selected: [ { - speaker: `${namespace}.speaker`, - text: `${namespace}.option.2.selected`, + speaker: `${namespace}:speaker`, + text: `${namespace}:option.2.selected`, }, ], }, @@ -191,7 +214,7 @@ export const DarkDealEncounter: MysteryEncounter = ) .withOutroDialogue([ { - text: `${namespace}.outro` + text: `${namespace}:outro` } ]) .build(); diff --git a/src/data/mystery-encounters/encounters/delibirdy-encounter.ts b/src/data/mystery-encounters/encounters/delibirdy-encounter.ts index ed9344d3c95..a3a97a01238 100644 --- a/src/data/mystery-encounters/encounters/delibirdy-encounter.ts +++ b/src/data/mystery-encounters/encounters/delibirdy-encounter.ts @@ -1,28 +1,28 @@ +import BattleScene from "#app/battle-scene"; +import MysteryEncounter, { MysteryEncounterBuilder } from "#app/data/mystery-encounters/mystery-encounter"; +import { MysteryEncounterOptionBuilder } from "#app/data/mystery-encounters/mystery-encounter-option"; +import { CombinationPokemonRequirement, HeldItemRequirement, MoneyRequirement } from "#app/data/mystery-encounters/mystery-encounter-requirements"; +import { getEncounterText, showEncounterText } from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; import { generateModifierType, leaveEncounterWithoutBattle, selectPokemonForOption, updatePlayerMoney, } from "#app/data/mystery-encounters/utils/encounter-phase-utils"; +import { applyModifierTypeToPlayerPokemon } from "#app/data/mystery-encounters/utils/encounter-pokemon-utils"; +import { getPokemonSpecies } from "#app/data/pokemon-species"; import Pokemon, { PlayerPokemon } from "#app/field/pokemon"; +import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES } from "#app/game-mode"; +import { BerryModifier, HealingBoosterModifier, LevelIncrementBoosterModifier, MoneyMultiplierModifier, PokemonHeldItemModifier, PokemonInstantReviveModifier, PreserveBerryModifier } from "#app/modifier/modifier"; import { modifierTypes, PokemonHeldItemModifierType } from "#app/modifier/modifier-type"; +import { ModifierRewardPhase } from "#app/phases/modifier-reward-phase"; +import i18next from "#app/plugins/i18n"; +import { OptionSelectItem } from "#app/ui/abstact-option-select-ui-handler"; +import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode"; +import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; import { MysteryEncounterType } from "#enums/mystery-encounter-type"; import { Species } from "#enums/species"; -import BattleScene from "#app/battle-scene"; -import MysteryEncounter, { MysteryEncounterBuilder } from "../mystery-encounter"; -import { MysteryEncounterOptionBuilder } from "../mystery-encounter-option"; -import { CombinationPokemonRequirement, HeldItemRequirement, MoneyRequirement } from "../mystery-encounter-requirements"; -import { getEncounterText, showEncounterText } from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; -import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; -import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode"; -import { HealingBoosterModifier, HiddenAbilityRateBoosterModifier, LevelIncrementBoosterModifier, PokemonHeldItemModifier, PreserveBerryModifier } from "#app/modifier/modifier"; -import { OptionSelectItem } from "#app/ui/abstact-option-select-ui-handler"; -import { applyModifierTypeToPlayerPokemon } from "#app/data/mystery-encounters/utils/encounter-pokemon-utils"; -import i18next from "#app/plugins/i18n"; -import { ModifierRewardPhase } from "#app/phases/modifier-reward-phase"; -import { getPokemonSpecies } from "#app/data/pokemon-species"; -import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES } from "#app/game-mode"; /** the i18n namespace for this encounter */ -const namespace = "mysteryEncounter:delibirdy"; +const namespace = "mysteryEncounters/delibirdy"; /** Berries only */ -const OPTION_2_ALLOWED_MODIFIERS = ["BerryModifier", "PokemonInstantReviveModifier"]; +const OPTION_2_ALLOWED_MODIFIERS = [ "BerryModifier", "PokemonInstantReviveModifier" ]; /** Disallowed items are berries, Reviver Seeds, and Vitamins (form change items and fusion items are not PokemonHeldItemModifiers) */ const OPTION_3_DISALLOWED_MODIFIERS = [ @@ -33,6 +33,8 @@ const OPTION_3_DISALLOWED_MODIFIERS = [ "PokemonBaseStatTotalModifier" ]; +const DELIBIRDY_MONEY_PRICE_MULTIPLIER = 2; + /** * Delibird-y encounter. * @see {@link https://github.com/pagefaultgames/pokerogue/issues/3804 | GitHub Issue #3804} @@ -42,11 +44,14 @@ export const DelibirdyEncounter: MysteryEncounter = MysteryEncounterBuilder.withEncounterType(MysteryEncounterType.DELIBIRDY) .withEncounterTier(MysteryEncounterTier.GREAT) .withSceneWaveRangeRequirement(...CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES) - .withSceneRequirement(new MoneyRequirement(0, 2)) // Must have enough money for it to spawn at the very least - .withPrimaryPokemonRequirement(new CombinationPokemonRequirement( // Must also have either option 2 or 3 available to spawn - new HeldItemRequirement(OPTION_2_ALLOWED_MODIFIERS), - new HeldItemRequirement(OPTION_3_DISALLOWED_MODIFIERS, 1, true) - )) + .withSceneRequirement(new MoneyRequirement(0, DELIBIRDY_MONEY_PRICE_MULTIPLIER)) // Must have enough money for it to spawn at the very least + .withPrimaryPokemonRequirement( + CombinationPokemonRequirement.Some( + // Must also have either option 2 or 3 available to spawn + new HeldItemRequirement(OPTION_2_ALLOWED_MODIFIERS), + new HeldItemRequirement(OPTION_3_DISALLOWED_MODIFIERS, 1, true) + ) + ) .withIntroSpriteConfigs([ { spriteKey: "", @@ -79,32 +84,39 @@ export const DelibirdyEncounter: MysteryEncounter = ]) .withIntroDialogue([ { - text: `${namespace}.intro`, + text: `${namespace}:intro`, } ]) - .withTitle(`${namespace}.title`) - .withDescription(`${namespace}.description`) - .withQuery(`${namespace}.query`) + .setLocalizationKey(`${namespace}`) + .withTitle(`${namespace}:title`) + .withDescription(`${namespace}:description`) + .withQuery(`${namespace}:query`) .withOutroDialogue([ { - text: `${namespace}.outro`, + text: `${namespace}:outro`, } ]) .withOnInit((scene: BattleScene) => { const encounter = scene.currentBattle.mysteryEncounter!; encounter.setDialogueToken("delibirdName", getPokemonSpecies(Species.DELIBIRD).getName()); + + scene.loadBgm("mystery_encounter_delibirdy", "mystery_encounter_delibirdy.mp3"); + return true; + }) + .withOnVisualsStart((scene: BattleScene) => { + scene.fadeAndSwitchBgm("mystery_encounter_delibirdy"); return true; }) .withOption( MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DISABLED_OR_DEFAULT) - .withSceneMoneyRequirement(0, 2) // Must have money to spawn + .withSceneMoneyRequirement(0, DELIBIRDY_MONEY_PRICE_MULTIPLIER) // Must have money to spawn .withDialogue({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.1.selected`, + text: `${namespace}:option.1.selected`, }, ], }) @@ -114,18 +126,18 @@ export const DelibirdyEncounter: MysteryEncounter = return true; }) .withOptionPhase(async (scene: BattleScene) => { - // Give the player an Ability Charm + // Give the player an Amulet Coin // Check if the player has max stacks of that item already - const existing = scene.findModifier(m => m instanceof HiddenAbilityRateBoosterModifier) as HiddenAbilityRateBoosterModifier; + const existing = scene.findModifier(m => m instanceof MoneyMultiplierModifier) as MoneyMultiplierModifier; if (existing && existing.getStackCount() >= existing.getMaxStackCount(scene)) { // At max stacks, give the first party pokemon a Shell Bell instead const shellBell = generateModifierType(scene, modifierTypes.SHELL_BELL) as PokemonHeldItemModifierType; - await applyModifierTypeToPlayerPokemon(scene, scene.getParty()[0], shellBell); + await applyModifierTypeToPlayerPokemon(scene, scene.getPlayerPokemon()!, shellBell); scene.playSound("item_fanfare"); await showEncounterText(scene, i18next.t("battle:rewardGain", { modifierName: shellBell.name }), null, undefined, true); } else { - scene.unshiftPhase(new ModifierRewardPhase(scene, modifierTypes.ABILITY_CHARM)); + scene.unshiftPhase(new ModifierRewardPhase(scene, modifierTypes.AMULET_COIN)); } leaveEncounterWithoutBattle(scene, true); @@ -137,12 +149,12 @@ export const DelibirdyEncounter: MysteryEncounter = .newOptionWithMode(MysteryEncounterOptionMode.DISABLED_OR_DEFAULT) .withPrimaryPokemonRequirement(new HeldItemRequirement(OPTION_2_ALLOWED_MODIFIERS)) .withDialogue({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, - secondOptionPrompt: `${namespace}.option.2.select_prompt`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, + secondOptionPrompt: `${namespace}:option.2.select_prompt`, selected: [ { - text: `${namespace}.option.2.selected`, + text: `${namespace}:option.2.selected`, }, ], }) @@ -151,7 +163,7 @@ export const DelibirdyEncounter: MysteryEncounter = const onPokemonSelected = (pokemon: PlayerPokemon) => { // Get Pokemon held items and filter for valid ones const validItems = pokemon.getHeldItems().filter((it) => { - return OPTION_2_ALLOWED_MODIFIERS.some(heldItem => it.constructor.name === heldItem); + return OPTION_2_ALLOWED_MODIFIERS.some(heldItem => it.constructor.name === heldItem) && it.isTransferable; }); return validItems.map((modifier: PokemonHeldItemModifier) => { @@ -171,12 +183,11 @@ export const DelibirdyEncounter: MysteryEncounter = }); }; - // Only Pokemon that can gain benefits are above 1/3rd HP with no status const selectableFilter = (pokemon: Pokemon) => { - // If pokemon meets primary pokemon reqs, it can be selected + // If pokemon has valid item, it can be selected const meetsReqs = encounter.options[1].pokemonMeetsPrimaryRequirements(scene, pokemon); if (!meetsReqs) { - return getEncounterText(scene, `${namespace}.invalid_selection`) ?? null; + return getEncounterText(scene, `${namespace}:invalid_selection`) ?? null; } return null; @@ -186,42 +197,39 @@ export const DelibirdyEncounter: MysteryEncounter = }) .withOptionPhase(async (scene: BattleScene) => { const encounter = scene.currentBattle.mysteryEncounter!; - const modifier = encounter.misc.chosenModifier; + const modifier: BerryModifier | PokemonInstantReviveModifier = encounter.misc.chosenModifier; + const chosenPokemon: PlayerPokemon = encounter.misc.chosenPokemon; - // Give the player a Candy Jar if they gave a Berry, and a Healing Charm for Reviver Seed - if (modifier.type.name.includes("Berry")) { + // Give the player a Candy Jar if they gave a Berry, and a Berry Pouch for Reviver Seed + if (modifier instanceof BerryModifier) { // Check if the player has max stacks of that Candy Jar already const existing = scene.findModifier(m => m instanceof LevelIncrementBoosterModifier) as LevelIncrementBoosterModifier; if (existing && existing.getStackCount() >= existing.getMaxStackCount(scene)) { // At max stacks, give the first party pokemon a Shell Bell instead const shellBell = generateModifierType(scene, modifierTypes.SHELL_BELL) as PokemonHeldItemModifierType; - await applyModifierTypeToPlayerPokemon(scene, scene.getParty()[0], shellBell); + await applyModifierTypeToPlayerPokemon(scene, scene.getPlayerPokemon()!, shellBell); scene.playSound("item_fanfare"); await showEncounterText(scene, i18next.t("battle:rewardGain", { modifierName: shellBell.name }), null, undefined, true); } else { scene.unshiftPhase(new ModifierRewardPhase(scene, modifierTypes.CANDY_JAR)); } } else { - // Check if the player has max stacks of that Healing Charm already - const existing = scene.findModifier(m => m instanceof HealingBoosterModifier) as HealingBoosterModifier; + // Check if the player has max stacks of that Berry Pouch already + const existing = scene.findModifier(m => m instanceof PreserveBerryModifier) as PreserveBerryModifier; if (existing && existing.getStackCount() >= existing.getMaxStackCount(scene)) { // At max stacks, give the first party pokemon a Shell Bell instead const shellBell = generateModifierType(scene, modifierTypes.SHELL_BELL) as PokemonHeldItemModifierType; - await applyModifierTypeToPlayerPokemon(scene, scene.getParty()[0], shellBell); + await applyModifierTypeToPlayerPokemon(scene, scene.getPlayerPokemon()!, shellBell); scene.playSound("item_fanfare"); await showEncounterText(scene, i18next.t("battle:rewardGain", { modifierName: shellBell.name }), null, undefined, true); } else { - scene.unshiftPhase(new ModifierRewardPhase(scene, modifierTypes.HEALING_CHARM)); + scene.unshiftPhase(new ModifierRewardPhase(scene, modifierTypes.BERRY_POUCH)); } } - // Remove the modifier if its stacks go to 0 - modifier.stackCount -= 1; - if (modifier.stackCount === 0) { - scene.removeModifier(modifier); - } + chosenPokemon.loseHeldItem(modifier, false); leaveEncounterWithoutBattle(scene, true); }) @@ -232,12 +240,12 @@ export const DelibirdyEncounter: MysteryEncounter = .newOptionWithMode(MysteryEncounterOptionMode.DISABLED_OR_DEFAULT) .withPrimaryPokemonRequirement(new HeldItemRequirement(OPTION_3_DISALLOWED_MODIFIERS, 1, true)) .withDialogue({ - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, - secondOptionPrompt: `${namespace}.option.3.select_prompt`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, + secondOptionPrompt: `${namespace}:option.3.select_prompt`, selected: [ { - text: `${namespace}.option.3.selected`, + text: `${namespace}:option.3.selected`, }, ], }) @@ -246,7 +254,7 @@ export const DelibirdyEncounter: MysteryEncounter = const onPokemonSelected = (pokemon: PlayerPokemon) => { // Get Pokemon held items and filter for valid ones const validItems = pokemon.getHeldItems().filter((it) => { - return !OPTION_3_DISALLOWED_MODIFIERS.some(heldItem => it.constructor.name === heldItem); + return !OPTION_3_DISALLOWED_MODIFIERS.some(heldItem => it.constructor.name === heldItem) && it.isTransferable; }); return validItems.map((modifier: PokemonHeldItemModifier) => { @@ -266,12 +274,11 @@ export const DelibirdyEncounter: MysteryEncounter = }); }; - // Only Pokemon that can gain benefits are above 1/3rd HP with no status const selectableFilter = (pokemon: Pokemon) => { - // If pokemon meets primary pokemon reqs, it can be selected + // If pokemon has valid item, it can be selected const meetsReqs = encounter.options[2].pokemonMeetsPrimaryRequirements(scene, pokemon); if (!meetsReqs) { - return getEncounterText(scene, `${namespace}.invalid_selection`) ?? null; + return getEncounterText(scene, `${namespace}:invalid_selection`) ?? null; } return null; @@ -282,25 +289,22 @@ export const DelibirdyEncounter: MysteryEncounter = .withOptionPhase(async (scene: BattleScene) => { const encounter = scene.currentBattle.mysteryEncounter!; const modifier = encounter.misc.chosenModifier; + const chosenPokemon: PlayerPokemon = encounter.misc.chosenPokemon; - // Check if the player has max stacks of Berry Pouch already - const existing = scene.findModifier(m => m instanceof PreserveBerryModifier) as PreserveBerryModifier; + // Check if the player has max stacks of Healing Charm already + const existing = scene.findModifier(m => m instanceof HealingBoosterModifier) as HealingBoosterModifier; if (existing && existing.getStackCount() >= existing.getMaxStackCount(scene)) { // At max stacks, give the first party pokemon a Shell Bell instead const shellBell = generateModifierType(scene, modifierTypes.SHELL_BELL) as PokemonHeldItemModifierType; - await applyModifierTypeToPlayerPokemon(scene, scene.getParty()[0], shellBell); + await applyModifierTypeToPlayerPokemon(scene, scene.getPlayerParty()[0], shellBell); scene.playSound("item_fanfare"); await showEncounterText(scene, i18next.t("battle:rewardGain", { modifierName: shellBell.name }), null, undefined, true); } else { - scene.unshiftPhase(new ModifierRewardPhase(scene, modifierTypes.BERRY_POUCH)); + scene.unshiftPhase(new ModifierRewardPhase(scene, modifierTypes.HEALING_CHARM)); } - // Remove the modifier if its stacks go to 0 - modifier.stackCount -= 1; - if (modifier.stackCount === 0) { - scene.removeModifier(modifier); - } + chosenPokemon.loseHeldItem(modifier, false); leaveEncounterWithoutBattle(scene, true); }) diff --git a/src/data/mystery-encounters/encounters/department-store-sale-encounter.ts b/src/data/mystery-encounters/encounters/department-store-sale-encounter.ts index e35ca08b6a0..10034d19263 100644 --- a/src/data/mystery-encounters/encounters/department-store-sale-encounter.ts +++ b/src/data/mystery-encounters/encounters/department-store-sale-encounter.ts @@ -9,12 +9,12 @@ import { Species } from "#enums/species"; import BattleScene from "#app/battle-scene"; import MysteryEncounter, { MysteryEncounterBuilder, -} from "../mystery-encounter"; +} from "#app/data/mystery-encounters/mystery-encounter"; import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES } from "#app/game-mode"; /** i18n namespace for encounter */ -const namespace = "mysteryEncounter:departmentStoreSale"; +const namespace = "mysteryEncounters/departmentStoreSale"; /** * Department Store Sale encounter. @@ -27,7 +27,7 @@ export const DepartmentStoreSaleEncounter: MysteryEncounter = .withSceneWaveRangeRequirement(CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES[0], 100) .withIntroSpriteConfigs([ { - spriteKey: "b2w2_lady", + spriteKey: "department_store_sale_lady", fileRoot: "mystery-encounters", hasShadow: true, x: -20, @@ -43,27 +43,28 @@ export const DepartmentStoreSaleEncounter: MysteryEncounter = ]) .withIntroDialogue([ { - text: `${namespace}.intro`, + text: `${namespace}:intro`, }, { - text: `${namespace}.intro_dialogue`, - speaker: `${namespace}.speaker`, + text: `${namespace}:intro_dialogue`, + speaker: `${namespace}:speaker`, }, ]) .withAutoHideIntroVisuals(false) - .withTitle(`${namespace}.title`) - .withDescription(`${namespace}.description`) - .withQuery(`${namespace}.query`) + .setLocalizationKey(`${namespace}`) + .withTitle(`${namespace}:title`) + .withDescription(`${namespace}:description`) + .withQuery(`${namespace}:query`) .withSimpleOption( { - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, }, async (scene: BattleScene) => { // Choose TMs const modifiers: ModifierTypeFunc[] = []; let i = 0; - while (i < 4) { + while (i < 5) { // 2/2/1 weight on TM rarity const roll = randSeedInt(5); if (roll < 2) { @@ -82,8 +83,8 @@ export const DepartmentStoreSaleEncounter: MysteryEncounter = ) .withSimpleOption( { - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, }, async (scene: BattleScene) => { // Choose Vitamins @@ -106,8 +107,8 @@ export const DepartmentStoreSaleEncounter: MysteryEncounter = ) .withSimpleOption( { - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, }, async (scene: BattleScene) => { // Choose X Items @@ -130,8 +131,8 @@ export const DepartmentStoreSaleEncounter: MysteryEncounter = ) .withSimpleOption( { - buttonLabel: `${namespace}.option.4.label`, - buttonTooltip: `${namespace}.option.4.tooltip`, + buttonLabel: `${namespace}:option.4.label`, + buttonTooltip: `${namespace}:option.4.tooltip`, }, async (scene: BattleScene) => { // Choose Pokeballs @@ -158,7 +159,7 @@ export const DepartmentStoreSaleEncounter: MysteryEncounter = ) .withOutroDialogue([ { - text: `${namespace}.outro`, + text: `${namespace}:outro`, } ]) .build(); diff --git a/src/data/mystery-encounters/encounters/field-trip-encounter.ts b/src/data/mystery-encounters/encounters/field-trip-encounter.ts index e0101d60a2a..1c26df0cf71 100644 --- a/src/data/mystery-encounters/encounters/field-trip-encounter.ts +++ b/src/data/mystery-encounters/encounters/field-trip-encounter.ts @@ -6,7 +6,7 @@ import { modifierTypes } from "#app/modifier/modifier-type"; import { OptionSelectItem } from "#app/ui/abstact-option-select-ui-handler"; import { MysteryEncounterType } from "#enums/mystery-encounter-type"; import BattleScene from "#app/battle-scene"; -import MysteryEncounter, { MysteryEncounterBuilder } from "../mystery-encounter"; +import MysteryEncounter, { MysteryEncounterBuilder } from "#app/data/mystery-encounters/mystery-encounter"; import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode"; import { Stat } from "#enums/stat"; @@ -14,7 +14,7 @@ import i18next from "i18next"; import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES } from "#app/game-mode"; /** i18n namespace for the encounter */ -const namespace = "mysteryEncounter:fieldTrip"; +const namespace = "mysteryEncounters/fieldTrip"; /** * Field Trip encounter. @@ -24,7 +24,7 @@ const namespace = "mysteryEncounter:fieldTrip"; export const FieldTripEncounter: MysteryEncounter = MysteryEncounterBuilder.withEncounterType(MysteryEncounterType.FIELD_TRIP) .withEncounterTier(MysteryEncounterTier.COMMON) - .withSceneWaveRangeRequirement(...CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES) + .withSceneWaveRangeRequirement(CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES[0], 100) .withIntroSpriteConfigs([ { spriteKey: "preschooler_m", @@ -32,7 +32,7 @@ export const FieldTripEncounter: MysteryEncounter = hasShadow: true, }, { - spriteKey: "teacher", + spriteKey: "field_trip_teacher", fileRoot: "mystery-encounters", hasShadow: true, }, @@ -44,24 +44,25 @@ export const FieldTripEncounter: MysteryEncounter = ]) .withIntroDialogue([ { - text: `${namespace}.intro`, + text: `${namespace}:intro`, }, { - text: `${namespace}.intro_dialogue`, - speaker: `${namespace}.speaker`, + text: `${namespace}:intro_dialogue`, + speaker: `${namespace}:speaker`, }, ]) .withAutoHideIntroVisuals(false) - .withTitle(`${namespace}.title`) - .withDescription(`${namespace}.description`) - .withQuery(`${namespace}.query`) + .setLocalizationKey(`${namespace}`) + .withTitle(`${namespace}:title`) + .withDescription(`${namespace}:description`) + .withQuery(`${namespace}:query`) .withOption( MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) .withDialogue({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, - secondOptionPrompt: `${namespace}.second_option_prompt`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, + secondOptionPrompt: `${namespace}:second_option_prompt`, }) .withPreOptionPhase(async (scene: BattleScene): Promise => { const encounter = scene.currentBattle.mysteryEncounter!; @@ -72,7 +73,7 @@ export const FieldTripEncounter: MysteryEncounter = label: move.getName(), handler: () => { // Pokemon and move selected - encounter.setDialogueToken("moveCategory", i18next.t(`${namespace}.physical`)); + encounter.setDialogueToken("moveCategory", i18next.t(`${namespace}:physical`)); pokemonAndMoveChosen(scene, pokemon, move, MoveCategory.PHYSICAL); return true; }, @@ -87,9 +88,9 @@ export const FieldTripEncounter: MysteryEncounter = const encounter = scene.currentBattle.mysteryEncounter!; if (encounter.misc.correctMove) { const modifiers = [ - generateModifierTypeOption(scene, modifierTypes.TEMP_STAT_STAGE_BOOSTER, [Stat.ATK])!, - generateModifierTypeOption(scene, modifierTypes.TEMP_STAT_STAGE_BOOSTER, [Stat.DEF])!, - generateModifierTypeOption(scene, modifierTypes.TEMP_STAT_STAGE_BOOSTER, [Stat.SPD])!, + generateModifierTypeOption(scene, modifierTypes.TEMP_STAT_STAGE_BOOSTER, [ Stat.ATK ])!, + generateModifierTypeOption(scene, modifierTypes.TEMP_STAT_STAGE_BOOSTER, [ Stat.DEF ])!, + generateModifierTypeOption(scene, modifierTypes.TEMP_STAT_STAGE_BOOSTER, [ Stat.SPD ])!, generateModifierTypeOption(scene, modifierTypes.DIRE_HIT)!, generateModifierTypeOption(scene, modifierTypes.RARER_CANDY)!, ]; @@ -105,9 +106,9 @@ export const FieldTripEncounter: MysteryEncounter = MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) .withDialogue({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, - secondOptionPrompt: `${namespace}.second_option_prompt`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, + secondOptionPrompt: `${namespace}:second_option_prompt`, }) .withPreOptionPhase(async (scene: BattleScene): Promise => { const encounter = scene.currentBattle.mysteryEncounter!; @@ -118,7 +119,7 @@ export const FieldTripEncounter: MysteryEncounter = label: move.getName(), handler: () => { // Pokemon and move selected - encounter.setDialogueToken("moveCategory", i18next.t(`${namespace}.special`)); + encounter.setDialogueToken("moveCategory", i18next.t(`${namespace}:special`)); pokemonAndMoveChosen(scene, pokemon, move, MoveCategory.SPECIAL); return true; }, @@ -133,9 +134,9 @@ export const FieldTripEncounter: MysteryEncounter = const encounter = scene.currentBattle.mysteryEncounter!; if (encounter.misc.correctMove) { const modifiers = [ - generateModifierTypeOption(scene, modifierTypes.TEMP_STAT_STAGE_BOOSTER, [Stat.SPATK])!, - generateModifierTypeOption(scene, modifierTypes.TEMP_STAT_STAGE_BOOSTER, [Stat.SPDEF])!, - generateModifierTypeOption(scene, modifierTypes.TEMP_STAT_STAGE_BOOSTER, [Stat.SPD])!, + generateModifierTypeOption(scene, modifierTypes.TEMP_STAT_STAGE_BOOSTER, [ Stat.SPATK ])!, + generateModifierTypeOption(scene, modifierTypes.TEMP_STAT_STAGE_BOOSTER, [ Stat.SPDEF ])!, + generateModifierTypeOption(scene, modifierTypes.TEMP_STAT_STAGE_BOOSTER, [ Stat.SPD ])!, generateModifierTypeOption(scene, modifierTypes.DIRE_HIT)!, generateModifierTypeOption(scene, modifierTypes.RARER_CANDY)!, ]; @@ -151,9 +152,9 @@ export const FieldTripEncounter: MysteryEncounter = MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) .withDialogue({ - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, - secondOptionPrompt: `${namespace}.second_option_prompt`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, + secondOptionPrompt: `${namespace}:second_option_prompt`, }) .withPreOptionPhase(async (scene: BattleScene): Promise => { const encounter = scene.currentBattle.mysteryEncounter!; @@ -164,7 +165,7 @@ export const FieldTripEncounter: MysteryEncounter = label: move.getName(), handler: () => { // Pokemon and move selected - encounter.setDialogueToken("moveCategory", i18next.t(`${namespace}.status`)); + encounter.setDialogueToken("moveCategory", i18next.t(`${namespace}:status`)); pokemonAndMoveChosen(scene, pokemon, move, MoveCategory.STATUS); return true; }, @@ -179,8 +180,8 @@ export const FieldTripEncounter: MysteryEncounter = const encounter = scene.currentBattle.mysteryEncounter!; if (encounter.misc.correctMove) { const modifiers = [ - generateModifierTypeOption(scene, modifierTypes.TEMP_STAT_STAGE_BOOSTER, [Stat.ACC])!, - generateModifierTypeOption(scene, modifierTypes.TEMP_STAT_STAGE_BOOSTER, [Stat.SPD])!, + generateModifierTypeOption(scene, modifierTypes.TEMP_STAT_STAGE_BOOSTER, [ Stat.ACC ])!, + generateModifierTypeOption(scene, modifierTypes.TEMP_STAT_STAGE_BOOSTER, [ Stat.SPD ])!, generateModifierTypeOption(scene, modifierTypes.GREAT_BALL)!, generateModifierTypeOption(scene, modifierTypes.IV_SCANNER)!, generateModifierTypeOption(scene, modifierTypes.RARER_CANDY)!, @@ -203,31 +204,31 @@ function pokemonAndMoveChosen(scene: BattleScene, pokemon: PlayerPokemon, move: if (!correctMove) { encounter.selectedOption!.dialogue!.selected = [ { - text: `${namespace}.option.selected`, + text: `${namespace}:option.selected`, }, { - text: `${namespace}.incorrect`, - speaker: `${namespace}.speaker`, + text: `${namespace}:incorrect`, + speaker: `${namespace}:speaker`, }, { - text: `${namespace}.incorrect_exp`, + text: `${namespace}:incorrect_exp`, }, ]; - setEncounterExp(scene, scene.getParty().map((p) => p.id), 50); + setEncounterExp(scene, scene.getPlayerParty().map((p) => p.id), 50); } else { encounter.selectedOption!.dialogue!.selected = [ { - text: `${namespace}.option.selected`, + text: `${namespace}:option.selected`, }, { - text: `${namespace}.correct`, - speaker: `${namespace}.speaker`, + text: `${namespace}:correct`, + speaker: `${namespace}:speaker`, }, { - text: `${namespace}.correct_exp`, + text: `${namespace}:correct_exp`, }, ]; - setEncounterExp(scene, [pokemon.id], 100); + setEncounterExp(scene, [ pokemon.id ], 100); } encounter.misc = { correctMove: correctMove, diff --git a/src/data/mystery-encounters/encounters/fiery-fallout-encounter.ts b/src/data/mystery-encounters/encounters/fiery-fallout-encounter.ts index 1861abcc7a4..bbc979e844e 100644 --- a/src/data/mystery-encounters/encounters/fiery-fallout-encounter.ts +++ b/src/data/mystery-encounters/encounters/fiery-fallout-encounter.ts @@ -3,28 +3,34 @@ import { EnemyPartyConfig, initBattleWithEnemyConfig, loadCustomMovesForEncounte import { AttackTypeBoosterModifierType, modifierTypes, } from "#app/modifier/modifier-type"; import { MysteryEncounterType } from "#enums/mystery-encounter-type"; import BattleScene from "#app/battle-scene"; -import MysteryEncounter, { MysteryEncounterBuilder } from "../mystery-encounter"; -import { TypeRequirement } from "../mystery-encounter-requirements"; +import MysteryEncounter, { MysteryEncounterBuilder } from "#app/data/mystery-encounters/mystery-encounter"; +import { AbilityRequirement, CombinationPokemonRequirement, TypeRequirement } from "#app/data/mystery-encounters/mystery-encounter-requirements"; import { Species } from "#enums/species"; import { getPokemonSpecies } from "#app/data/pokemon-species"; import { Gender } from "#app/data/gender"; -import { Type } from "#app/data/type"; +import { Type } from "#enums/type"; import { BattlerIndex } from "#app/battle"; -import { PokemonMove } from "#app/field/pokemon"; +import Pokemon, { PokemonMove } from "#app/field/pokemon"; import { Moves } from "#enums/moves"; import { EncounterBattleAnim } from "#app/data/battle-anims"; -import { WeatherType } from "#app/data/weather"; +import { WeatherType } from "#enums/weather-type"; import { isNullOrUndefined, randSeedInt } from "#app/utils"; -import { StatusEffect } from "#app/data/status-effect"; +import { StatusEffect } from "#enums/status-effect"; import { queueEncounterMessage } from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; -import { applyDamageToPokemon, applyModifierTypeToPlayerPokemon } from "#app/data/mystery-encounters/utils/encounter-pokemon-utils"; +import { applyAbilityOverrideToPokemon, applyDamageToPokemon, applyModifierTypeToPlayerPokemon } from "#app/data/mystery-encounters/utils/encounter-pokemon-utils"; import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode"; import { EncounterAnim } from "#enums/encounter-anims"; import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES } from "#app/game-mode"; +import { Abilities } from "#enums/abilities"; +import { BattlerTagType } from "#enums/battler-tag-type"; +import { StatStageChangePhase } from "#app/phases/stat-stage-change-phase"; +import { Stat } from "#enums/stat"; +import { Ability } from "#app/data/ability"; +import { FIRE_RESISTANT_ABILITIES } from "#app/data/mystery-encounters/requirements/requirement-groups"; /** the i18n namespace for the encounter */ -const namespace = "mysteryEncounter:fieryFallout"; +const namespace = "mysteryEncounters/fieryFallout"; /** * Damage percentage taken when suffering the heat. @@ -46,9 +52,10 @@ export const FieryFalloutEncounter: MysteryEncounter = .withIntroSpriteConfigs([]) // Set in onInit() .withAnimations(EncounterAnim.MAGMA_BG, EncounterAnim.MAGMA_SPOUT) .withAutoHideIntroVisuals(false) + .withFleeAllowed(false) .withIntroDialogue([ { - text: `${namespace}.intro`, + text: `${namespace}:intro`, }, ]) .withOnInit((scene: BattleScene) => { @@ -61,18 +68,26 @@ export const FieryFalloutEncounter: MysteryEncounter = { species: volcaronaSpecies, isBoss: false, - gender: Gender.MALE + gender: Gender.MALE, + tags: [ BattlerTagType.MYSTERY_ENCOUNTER_POST_SUMMON ], + mysteryEncounterBattleEffects: (pokemon: Pokemon) => { + pokemon.scene.unshiftPhase(new StatStageChangePhase(pokemon.scene, pokemon.getBattlerIndex(), true, [ Stat.SPDEF, Stat.SPD ], 1)); + } }, { species: volcaronaSpecies, isBoss: false, - gender: Gender.FEMALE + gender: Gender.FEMALE, + tags: [ BattlerTagType.MYSTERY_ENCOUNTER_POST_SUMMON ], + mysteryEncounterBattleEffects: (pokemon: Pokemon) => { + pokemon.scene.unshiftPhase(new StatStageChangePhase(pokemon.scene, pokemon.getBattlerIndex(), true, [ Stat.SPDEF, Stat.SPD ], 1)); + } } ], doubleBattle: true, - disableSwitch: true + disableSwitch: true, }; - encounter.enemyPartyConfigs = [config]; + encounter.enemyPartyConfigs = [ config ]; // Load hidden Volcarona sprites encounter.spriteConfigs = [ @@ -98,7 +113,7 @@ export const FieryFalloutEncounter: MysteryEncounter = ]; // Load animations/sfx for Volcarona moves - loadCustomMovesForEncounter(scene, [Moves.FIRE_SPIN, Moves.QUIVER_DANCE]); + loadCustomMovesForEncounter(scene, [ Moves.FIRE_SPIN, Moves.QUIVER_DANCE ]); scene.arena.trySetWeather(WeatherType.SUNNY, true); @@ -121,66 +136,55 @@ export const FieryFalloutEncounter: MysteryEncounter = return true; }) - .withTitle(`${namespace}.title`) - .withDescription(`${namespace}.description`) - .withQuery(`${namespace}.query`) + .setLocalizationKey(`${namespace}`) + .withTitle(`${namespace}:title`) + .withDescription(`${namespace}:description`) + .withQuery(`${namespace}:query`) .withSimpleOption( { - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.1.selected`, + text: `${namespace}:option.1.selected`, }, ], }, async (scene: BattleScene) => { // Pick battle const encounter = scene.currentBattle.mysteryEncounter!; - setEncounterRewards(scene, { fillRemaining: true }, undefined, () => giveLeadPokemonCharcoal(scene)); + setEncounterRewards(scene, { fillRemaining: true }, undefined, () => giveLeadPokemonAttackTypeBoostItem(scene)); encounter.startOfBattleEffects.push( { sourceBattlerIndex: BattlerIndex.ENEMY, - targets: [BattlerIndex.PLAYER], + targets: [ BattlerIndex.PLAYER ], move: new PokemonMove(Moves.FIRE_SPIN), ignorePp: true }, { sourceBattlerIndex: BattlerIndex.ENEMY_2, - targets: [BattlerIndex.PLAYER_2], + targets: [ BattlerIndex.PLAYER_2 ], move: new PokemonMove(Moves.FIRE_SPIN), ignorePp: true - }, - { - sourceBattlerIndex: BattlerIndex.ENEMY, - targets: [BattlerIndex.ENEMY], - move: new PokemonMove(Moves.QUIVER_DANCE), - ignorePp: true - }, - { - sourceBattlerIndex: BattlerIndex.ENEMY_2, - targets: [BattlerIndex.ENEMY_2], - move: new PokemonMove(Moves.QUIVER_DANCE), - ignorePp: true }); await initBattleWithEnemyConfig(scene, scene.currentBattle.mysteryEncounter!.enemyPartyConfigs[0]); } ) .withSimpleOption( { - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, selected: [ { - text: `${namespace}.option.2.selected`, + text: `${namespace}:option.2.selected`, }, ], }, async (scene: BattleScene) => { - // Damage non-fire types and burn 1 random non-fire type member + // Damage non-fire types and burn 1 random non-fire type member + give it Heatproof const encounter = scene.currentBattle.mysteryEncounter!; - const nonFireTypes = scene.getParty().filter((p) => p.isAllowedInBattle() && !p.getTypes().includes(Type.FIRE)); + const nonFireTypes = scene.getPlayerParty().filter((p) => p.isAllowedInBattle() && !p.getTypes().includes(Type.FIRE)); for (const pkm of nonFireTypes) { const percentage = DAMAGE_PERCENTAGE / 100; @@ -189,14 +193,18 @@ export const FieryFalloutEncounter: MysteryEncounter = } // Burn random member - const burnable = nonFireTypes.filter(p => isNullOrUndefined(p.status) || isNullOrUndefined(p.status!.effect) || p.status?.effect === StatusEffect.BURN); + const burnable = nonFireTypes.filter(p => isNullOrUndefined(p.status) || isNullOrUndefined(p.status.effect) || p.status.effect === StatusEffect.NONE); if (burnable?.length > 0) { const roll = randSeedInt(burnable.length); const chosenPokemon = burnable[roll]; if (chosenPokemon.trySetStatus(StatusEffect.BURN)) { // Burn applied encounter.setDialogueToken("burnedPokemon", chosenPokemon.getNameToRender()); - queueEncounterMessage(scene, `${namespace}.option.2.target_burned`); + encounter.setDialogueToken("abilityName", new Ability(Abilities.HEATPROOF, 3).name); + queueEncounterMessage(scene, `${namespace}:option.2.target_burned`); + + // Also permanently change the burned Pokemon's ability to Heatproof + applyAbilityOverrideToPokemon(chosenPokemon, Abilities.HEATPROOF); } } @@ -207,49 +215,60 @@ export const FieryFalloutEncounter: MysteryEncounter = .withOption( MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DISABLED_OR_SPECIAL) - .withPrimaryPokemonRequirement(new TypeRequirement(Type.FIRE, true, 1)) // Will set option3PrimaryName dialogue token automatically - .withSecondaryPokemonRequirement(new TypeRequirement(Type.FIRE, true, 1)) // Will set option3SecondaryName dialogue token automatically + .withPrimaryPokemonRequirement( + CombinationPokemonRequirement.Some( + new TypeRequirement(Type.FIRE, true, 1), + new AbilityRequirement(FIRE_RESISTANT_ABILITIES, true) + ) + ) // Will set option3PrimaryName dialogue token automatically .withDialogue({ - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, - disabledButtonTooltip: `${namespace}.option.3.disabled_tooltip`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, + disabledButtonTooltip: `${namespace}:option.3.disabled_tooltip`, selected: [ { - text: `${namespace}.option.3.selected`, + text: `${namespace}:option.3.selected`, }, ], }) .withPreOptionPhase(async (scene: BattleScene) => { + // Do NOT await this, to prevent player from repeatedly pressing options transitionMysteryEncounterIntroVisuals(scene, false, false, 2000); }) .withOptionPhase(async (scene: BattleScene) => { // Fire types help calm the Volcarona const encounter = scene.currentBattle.mysteryEncounter!; - transitionMysteryEncounterIntroVisuals(scene); + await transitionMysteryEncounterIntroVisuals(scene); setEncounterRewards(scene, { fillRemaining: true }, undefined, () => { - giveLeadPokemonCharcoal(scene); + giveLeadPokemonAttackTypeBoostItem(scene); }); const primary = encounter.options[2].primaryPokemon!; - const secondary = encounter.options[2].secondaryPokemon![0]; - setEncounterExp(scene, [primary.id, secondary.id], getPokemonSpecies(Species.VOLCARONA).baseExp * 2); + setEncounterExp(scene, [ primary.id ], getPokemonSpecies(Species.VOLCARONA).baseExp * 2); leaveEncounterWithoutBattle(scene); }) .build() ) .build(); -function giveLeadPokemonCharcoal(scene: BattleScene) { - // Give first party pokemon Charcoal for free at end of battle - const leadPokemon = scene.getParty()?.[0]; +function giveLeadPokemonAttackTypeBoostItem(scene: BattleScene) { + // Give first party pokemon attack type boost item for free at end of battle + const leadPokemon = scene.getPlayerParty()?.[0]; if (leadPokemon) { - const charcoal = generateModifierType(scene, modifierTypes.ATTACK_TYPE_BOOSTER, [Type.FIRE]) as AttackTypeBoosterModifierType; - applyModifierTypeToPlayerPokemon(scene, leadPokemon, charcoal); - scene.currentBattle.mysteryEncounter!.setDialogueToken("leadPokemon", leadPokemon.getNameToRender()); - queueEncounterMessage(scene, `${namespace}.found_charcoal`); + // Generate type booster held item, default to Charcoal if item fails to generate + let boosterModifierType = generateModifierType(scene, modifierTypes.ATTACK_TYPE_BOOSTER) as AttackTypeBoosterModifierType; + if (!boosterModifierType) { + boosterModifierType = generateModifierType(scene, modifierTypes.ATTACK_TYPE_BOOSTER, [ Type.FIRE ]) as AttackTypeBoosterModifierType; + } + applyModifierTypeToPlayerPokemon(scene, leadPokemon, boosterModifierType); + + const encounter = scene.currentBattle.mysteryEncounter!; + encounter.setDialogueToken("itemName", boosterModifierType.name); + encounter.setDialogueToken("leadPokemon", leadPokemon.getNameToRender()); + queueEncounterMessage(scene, `${namespace}:found_item`); } } diff --git a/src/data/mystery-encounters/encounters/fight-or-flight-encounter.ts b/src/data/mystery-encounters/encounters/fight-or-flight-encounter.ts index c163a2fc194..3f9030dc3b2 100644 --- a/src/data/mystery-encounters/encounters/fight-or-flight-encounter.ts +++ b/src/data/mystery-encounters/encounters/fight-or-flight-encounter.ts @@ -17,12 +17,12 @@ import { } from "#app/modifier/modifier-type"; import { MysteryEncounterType } from "#enums/mystery-encounter-type"; import BattleScene from "#app/battle-scene"; -import MysteryEncounter, { MysteryEncounterBuilder } from "../mystery-encounter"; -import { MoveRequirement } from "../mystery-encounter-requirements"; +import MysteryEncounter, { MysteryEncounterBuilder } from "#app/data/mystery-encounters/mystery-encounter"; +import { MoveRequirement } from "#app/data/mystery-encounters/mystery-encounter-requirements"; import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode"; import { TrainerSlot } from "#app/data/trainer-config"; -import { getSpriteKeysFromPokemon } from "#app/data/mystery-encounters/utils/encounter-pokemon-utils"; +import { getEncounterPokemonLevelForWave, getSpriteKeysFromPokemon, STANDARD_ENCOUNTER_BOOSTED_LEVEL_MODIFIER } from "#app/data/mystery-encounters/utils/encounter-pokemon-utils"; import PokemonData from "#app/system/pokemon-data"; import { BattlerTagType } from "#enums/battler-tag-type"; import { queueEncounterMessage } from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; @@ -31,7 +31,7 @@ import { StatStageChangePhase } from "#app/phases/stat-stage-change-phase"; import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES } from "#app/game-mode"; /** the i18n namespace for the encounter */ -const namespace = "mysteryEncounter:fightOrFlight"; +const namespace = "mysteryEncounters/fightOrFlight"; /** * Fight or Flight encounter. @@ -44,36 +44,37 @@ export const FightOrFlightEncounter: MysteryEncounter = .withSceneWaveRangeRequirement(...CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES) .withCatchAllowed(true) .withHideWildIntroMessage(true) + .withFleeAllowed(false) .withIntroSpriteConfigs([]) // Set in onInit() .withIntroDialogue([ { - text: `${namespace}.intro`, + text: `${namespace}:intro`, }, ]) .withOnInit((scene: BattleScene) => { const encounter = scene.currentBattle.mysteryEncounter!; // Calculate boss mon - const level = (scene.currentBattle.enemyLevels?.[0] ?? scene.currentBattle.waveIndex) + Math.max(Math.round((scene.currentBattle.waveIndex / 10)), 0); - const bossSpecies = scene.arena.randomSpecies(scene.currentBattle.waveIndex, level, 0, getPartyLuckValue(scene.getParty()), true); + const level = getEncounterPokemonLevelForWave(scene, STANDARD_ENCOUNTER_BOOSTED_LEVEL_MODIFIER); + const bossSpecies = scene.arena.randomSpecies(scene.currentBattle.waveIndex, level, 0, getPartyLuckValue(scene.getPlayerParty()), true); const bossPokemon = new EnemyPokemon(scene, bossSpecies, level, TrainerSlot.NONE, true); encounter.setDialogueToken("enemyPokemon", bossPokemon.getNameToRender()); const config: EnemyPartyConfig = { - levelAdditiveMultiplier: 1, pokemonConfigs: [{ level: level, species: bossSpecies, dataSource: new PokemonData(bossPokemon), isBoss: true, - tags: [BattlerTagType.MYSTERY_ENCOUNTER_POST_SUMMON], + tags: [ BattlerTagType.MYSTERY_ENCOUNTER_POST_SUMMON ], mysteryEncounterBattleEffects: (pokemon: Pokemon) => { - queueEncounterMessage(pokemon.scene, `${namespace}.option.1.stat_boost`); + queueEncounterMessage(pokemon.scene, `${namespace}:option.1.stat_boost`); // Randomly boost 1 stat 2 stages - pokemon.scene.unshiftPhase(new StatStageChangePhase(pokemon.scene, pokemon.getBattlerIndex(), true, [randSeedInt(5)], 2)); + // Cannot boost Spd, Acc, or Evasion + pokemon.scene.unshiftPhase(new StatStageChangePhase(pokemon.scene, pokemon.getBattlerIndex(), true, [ randSeedInt(4, 1) ], 2)); } }], }; - encounter.enemyPartyConfigs = [config]; + encounter.enemyPartyConfigs = [ config ]; // Calculate item // Waves 10-40 GREAT, 60-120 ULTRA, 120-160 ROGUE, 160-180 MASTER @@ -85,11 +86,11 @@ export const FightOrFlightEncounter: MysteryEncounter = : scene.currentBattle.waveIndex > 40 ? ModifierTier.ULTRA : ModifierTier.GREAT; - regenerateModifierPoolThresholds(scene.getParty(), ModifierPoolType.PLAYER, 0); + regenerateModifierPoolThresholds(scene.getPlayerParty(), ModifierPoolType.PLAYER, 0); let item: ModifierTypeOption | null = null; // TMs and Candy Jar excluded from possible rewards as they're too swingy in value for a singular item reward while (!item || item.type.id.includes("TM_") || item.type.id === "CANDY_JAR") { - item = getPlayerModifierTypeOptions(1, scene.getParty(), [], { guaranteedModifierTiers: [tier], allowLuckUpgrades: false })[0]; + item = getPlayerModifierTypeOptions(1, scene.getPlayerParty(), [], { guaranteedModifierTiers: [ tier ], allowLuckUpgrades: false })[0]; } encounter.setDialogueToken("itemName", item.type.name); encounter.misc = item; @@ -119,16 +120,17 @@ export const FightOrFlightEncounter: MysteryEncounter = return true; }) - .withTitle(`${namespace}.title`) - .withDescription(`${namespace}.description`) - .withQuery(`${namespace}.query`) + .setLocalizationKey(`${namespace}`) + .withTitle(`${namespace}:title`) + .withDescription(`${namespace}:description`) + .withQuery(`${namespace}:query`) .withSimpleOption( { - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.1.selected`, + text: `${namespace}:option.1.selected`, }, ], }, @@ -136,21 +138,21 @@ export const FightOrFlightEncounter: MysteryEncounter = // Pick battle // Pokemon will randomly boost 1 stat by 2 stages const item = scene.currentBattle.mysteryEncounter!.misc as ModifierTypeOption; - setEncounterRewards(scene, { guaranteedModifierTypeOptions: [item], fillRemaining: false }); + setEncounterRewards(scene, { guaranteedModifierTypeOptions: [ item ], fillRemaining: false }); await initBattleWithEnemyConfig(scene, scene.currentBattle.mysteryEncounter!.enemyPartyConfigs[0]); } ) .withOption( MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DISABLED_OR_SPECIAL) - .withPrimaryPokemonRequirement(new MoveRequirement(STEALING_MOVES)) // Will set option2PrimaryName and option2PrimaryMove dialogue tokens automatically + .withPrimaryPokemonRequirement(new MoveRequirement(STEALING_MOVES, true)) // Will set option2PrimaryName and option2PrimaryMove dialogue tokens automatically .withDialogue({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, - disabledButtonTooltip: `${namespace}.option.2.disabled_tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, + disabledButtonTooltip: `${namespace}:option.2.disabled_tooltip`, selected: [ { - text: `${namespace}.option.2.selected` + text: `${namespace}:option.2.selected` } ] }) @@ -158,7 +160,7 @@ export const FightOrFlightEncounter: MysteryEncounter = // Pick steal const encounter = scene.currentBattle.mysteryEncounter!; const item = scene.currentBattle.mysteryEncounter!.misc as ModifierTypeOption; - setEncounterRewards(scene, { guaranteedModifierTypeOptions: [item], fillRemaining: false }); + setEncounterRewards(scene, { guaranteedModifierTypeOptions: [ item ], fillRemaining: false }); // Use primaryPokemon to execute the thievery const primaryPokemon = encounter.options[1].primaryPokemon!; @@ -169,11 +171,11 @@ export const FightOrFlightEncounter: MysteryEncounter = ) .withSimpleOption( { - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, selected: [ { - text: `${namespace}.option.3.selected`, + text: `${namespace}:option.3.selected`, }, ], }, diff --git a/src/data/mystery-encounters/encounters/fun-and-games-encounter.ts b/src/data/mystery-encounters/encounters/fun-and-games-encounter.ts index a544657e47c..c286fffe0de 100644 --- a/src/data/mystery-encounters/encounters/fun-and-games-encounter.ts +++ b/src/data/mystery-encounters/encounters/fun-and-games-encounter.ts @@ -1,13 +1,13 @@ import { leaveEncounterWithoutBattle, selectPokemonForOption, setEncounterRewards, transitionMysteryEncounterIntroVisuals, updatePlayerMoney, } from "#app/data/mystery-encounters/utils/encounter-phase-utils"; import { MysteryEncounterType } from "#enums/mystery-encounter-type"; import BattleScene from "#app/battle-scene"; -import MysteryEncounter, { MysteryEncounterBuilder } from "../mystery-encounter"; +import MysteryEncounter, { MysteryEncounterBuilder } from "#app/data/mystery-encounters/mystery-encounter"; import { MysteryEncounterOptionBuilder } from "#app/data/mystery-encounters/mystery-encounter-option"; import { TrainerSlot } from "#app/data/trainer-config"; import Pokemon, { FieldPosition, PlayerPokemon } from "#app/field/pokemon"; import { getPokemonSpecies } from "#app/data/pokemon-species"; import { MoneyRequirement } from "#app/data/mystery-encounters/mystery-encounter-requirements"; -import { getEncounterText, queueEncounterMessage, showEncounterText } from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; +import { queueEncounterMessage, showEncounterText } from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode"; import { Species } from "#enums/species"; @@ -22,9 +22,10 @@ import { PostSummonPhase } from "#app/phases/post-summon-phase"; import { modifierTypes } from "#app/modifier/modifier-type"; import { Nature } from "#enums/nature"; import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES } from "#app/game-mode"; +import { isPokemonValidForEncounterOptionSelection } from "#app/data/mystery-encounters/utils/encounter-pokemon-utils"; /** the i18n namespace for the encounter */ -const namespace = "mysteryEncounter:funAndGames"; +const namespace = "mysteryEncounters/funAndGames"; /** * Fun and Games! encounter. @@ -43,16 +44,17 @@ export const FunAndGamesEncounter: MysteryEncounter = .withSkipEnemyBattleTurns(true) // Will skip COMMAND selection menu and go straight to FIGHT (move select) menu .withSkipToFightInput(true) + .withFleeAllowed(false) .withIntroSpriteConfigs([ { - spriteKey: "carnival_game", + spriteKey: "fun_and_games_game", fileRoot: "mystery-encounters", hasShadow: false, x: 0, y: 6, }, { - spriteKey: "carnival_wobbuffet", + spriteKey: "fun_and_games_wobbuffet", fileRoot: "mystery-encounters", hasShadow: true, x: -28, @@ -60,7 +62,7 @@ export const FunAndGamesEncounter: MysteryEncounter = yShadow: 6 }, { - spriteKey: "carnival_man", + spriteKey: "fun_and_games_man", fileRoot: "mystery-encounters", hasShadow: true, x: 40, @@ -70,13 +72,14 @@ export const FunAndGamesEncounter: MysteryEncounter = ]) .withIntroDialogue([ { - speaker: `${namespace}.speaker`, - text: `${namespace}.intro_dialogue`, + speaker: `${namespace}:speaker`, + text: `${namespace}:intro_dialogue`, }, ]) - .withTitle(`${namespace}.title`) - .withDescription(`${namespace}.description`) - .withQuery(`${namespace}.query`) + .setLocalizationKey(`${namespace}`) + .withTitle(`${namespace}:title`) + .withDescription(`${namespace}:description`) + .withQuery(`${namespace}:query`) .withOnInit((scene: BattleScene) => { const encounter = scene.currentBattle.mysteryEncounter!; scene.loadBgm("mystery_encounter_fun_and_games", "mystery_encounter_fun_and_games.mp3"); @@ -84,23 +87,18 @@ export const FunAndGamesEncounter: MysteryEncounter = return true; }) .withOnVisualsStart((scene: BattleScene) => { - // Change the bgm - scene.fadeOutBgm(2000, false); - scene.time.delayedCall(2000, () => { - scene.playBgm("mystery_encounter_fun_and_games"); - }); - + scene.fadeAndSwitchBgm("mystery_encounter_fun_and_games"); return true; }) .withOption(MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DISABLED_OR_DEFAULT) .withSceneRequirement(new MoneyRequirement(0, 1.5)) // Cost equal to 1 Max Potion .withDialogue({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.1.selected`, + text: `${namespace}:option.1.selected`, }, ], }) @@ -115,12 +113,7 @@ export const FunAndGamesEncounter: MysteryEncounter = // Only Pokemon that are not KOed/legal can be selected const selectableFilter = (pokemon: Pokemon) => { - const meetsReqs = pokemon.isAllowedInBattle(); - if (!meetsReqs) { - return getEncounterText(scene, `${namespace}.invalid_selection`) ?? null; - } - - return null; + return isPokemonValidForEncounterOptionSelection(pokemon, scene, `${namespace}:invalid_selection`); }; return selectPokemonForOption(scene, onPokemonSelected, undefined, selectableFilter); @@ -149,17 +142,17 @@ export const FunAndGamesEncounter: MysteryEncounter = ) .withSimpleOption( { - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, selected: [ { - text: `${namespace}.option.2.selected`, + text: `${namespace}:option.2.selected`, }, ], }, async (scene: BattleScene) => { // Leave encounter with no rewards or exp - transitionMysteryEncounterIntroVisuals(scene, true, true); + await transitionMysteryEncounterIntroVisuals(scene, true, true); leaveEncounterWithoutBattle(scene, true); return true; } @@ -172,10 +165,12 @@ async function summonPlayerPokemon(scene: BattleScene) { const playerPokemon = encounter.misc.playerPokemon; // Swaps the chosen Pokemon and the first player's lead Pokemon in the party - const party = scene.getParty(); + const party = scene.getPlayerParty(); const chosenIndex = party.indexOf(playerPokemon); if (chosenIndex !== 0) { - [party[chosenIndex], party[0]] = [party[chosenIndex], party[chosenIndex]]; + const leadPokemon = party[0]; + party[0] = playerPokemon; + party[chosenIndex] = leadPokemon; } // Do trainer summon animation @@ -203,7 +198,7 @@ async function summonPlayerPokemon(scene: BattleScene) { const enemySpecies = getPokemonSpecies(Species.WOBBUFFET); scene.currentBattle.enemyParty = []; const wobbuffet = scene.addEnemyPokemon(enemySpecies, encounter.misc.playerPokemon.level, TrainerSlot.NONE, false); - wobbuffet.ivs = [0, 0, 0, 0, 0, 0]; + wobbuffet.ivs = [ 0, 0, 0, 0, 0, 0 ]; wobbuffet.setNature(Nature.MILD); wobbuffet.setAlpha(0); wobbuffet.setVisible(false); @@ -237,7 +232,7 @@ function handleLoseMinigame(scene: BattleScene) { scene.currentBattle.enemyParty = []; scene.currentBattle.mysteryEncounter!.doContinueEncounter = undefined; leaveEncounterWithoutBattle(scene, true); - await showEncounterText(scene, `${namespace}.ko`); + await showEncounterText(scene, `${namespace}:ko`); const reviveCost = scene.getWaveMoneyAmount(1.5); updatePlayerMoney(scene, -reviveCost, true, false); } @@ -262,20 +257,20 @@ function handleNextTurn(scene: BattleScene) { let isHealPhase = false; if (healthRatio < 0.03) { // Grand prize - setEncounterRewards(scene, { guaranteedModifierTypeFuncs: [modifierTypes.MULTI_LENS], fillRemaining: false }); - resultMessageKey = `${namespace}.best_result`; + setEncounterRewards(scene, { guaranteedModifierTypeFuncs: [ modifierTypes.MULTI_LENS ], fillRemaining: false }); + resultMessageKey = `${namespace}:best_result`; } else if (healthRatio < 0.15) { // 2nd prize - setEncounterRewards(scene, { guaranteedModifierTypeFuncs: [modifierTypes.SCOPE_LENS], fillRemaining: false }); - resultMessageKey = `${namespace}.great_result`; + setEncounterRewards(scene, { guaranteedModifierTypeFuncs: [ modifierTypes.SCOPE_LENS ], fillRemaining: false }); + resultMessageKey = `${namespace}:great_result`; } else if (healthRatio < 0.33) { // 3rd prize - setEncounterRewards(scene, { guaranteedModifierTypeFuncs: [modifierTypes.WIDE_LENS], fillRemaining: false }); - resultMessageKey = `${namespace}.good_result`; + setEncounterRewards(scene, { guaranteedModifierTypeFuncs: [ modifierTypes.WIDE_LENS ], fillRemaining: false }); + resultMessageKey = `${namespace}:good_result`; } else { // No prize isHealPhase = true; - resultMessageKey = `${namespace}.bad_result`; + resultMessageKey = `${namespace}:bad_result`; } // End the battle @@ -285,7 +280,7 @@ function handleNextTurn(scene: BattleScene) { scene.currentBattle.mysteryEncounter!.doContinueEncounter = undefined; leaveEncounterWithoutBattle(scene, isHealPhase); // Must end the TurnInit phase prematurely so battle phases aren't added to queue - queueEncounterMessage(scene, `${namespace}.end_game`); + queueEncounterMessage(scene, `${namespace}:end_game`); queueEncounterMessage(scene, resultMessageKey); // Skip remainder of TurnInitPhase @@ -293,9 +288,9 @@ function handleNextTurn(scene: BattleScene) { } else { if (encounter.misc.turnsRemaining < 3) { // Display charging messages on turns that aren't the initial turn - queueEncounterMessage(scene, `${namespace}.charging_continue`); + queueEncounterMessage(scene, `${namespace}:charging_continue`); } - queueEncounterMessage(scene, `${namespace}.turn_remaining_${encounter.misc.turnsRemaining}`); + queueEncounterMessage(scene, `${namespace}:turn_remaining_${encounter.misc.turnsRemaining}`); encounter.misc.turnsRemaining--; } @@ -310,7 +305,7 @@ async function showWobbuffetHealthBar(scene: BattleScene) { scene.field.add(wobbuffet); const playerPokemon = scene.getPlayerPokemon() as Pokemon; - if (playerPokemon?.visible) { + if (playerPokemon?.isOnField()) { scene.field.moveBelow(wobbuffet, playerPokemon); } // Show health bar and trigger cry @@ -417,7 +412,7 @@ function hideShowmanIntroSprite(scene: BattleScene) { // Slide the Wobbuffet and Game over slightly scene.tweens.add({ - targets: [wobbuffet, carnivalGame], + targets: [ wobbuffet, carnivalGame ], x: "+=16", ease: "Sine.easeInOut", duration: 750 diff --git a/src/data/mystery-encounters/encounters/global-trade-system-encounter.ts b/src/data/mystery-encounters/encounters/global-trade-system-encounter.ts index 1c5a1f009d9..2d569621449 100644 --- a/src/data/mystery-encounters/encounters/global-trade-system-encounter.ts +++ b/src/data/mystery-encounters/encounters/global-trade-system-encounter.ts @@ -1,42 +1,51 @@ import { leaveEncounterWithoutBattle, selectPokemonForOption, setEncounterRewards } from "#app/data/mystery-encounters/utils/encounter-phase-utils"; import { TrainerSlot, } from "#app/data/trainer-config"; import { ModifierTier } from "#app/modifier/modifier-tier"; +import { MusicPreference } from "#app/system/settings/settings"; import { getPlayerModifierTypeOptions, ModifierPoolType, ModifierTypeOption, regenerateModifierPoolThresholds } from "#app/modifier/modifier-type"; import { MysteryEncounterType } from "#enums/mystery-encounter-type"; import BattleScene from "#app/battle-scene"; -import MysteryEncounter, { MysteryEncounterBuilder } from "../mystery-encounter"; +import MysteryEncounter, { MysteryEncounterBuilder } from "#app/data/mystery-encounters/mystery-encounter"; import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; import { Species } from "#enums/species"; import PokemonSpecies, { allSpecies, getPokemonSpecies } from "#app/data/pokemon-species"; import { getTypeRgb } from "#app/data/type"; import { MysteryEncounterOptionBuilder } from "#app/data/mystery-encounters/mystery-encounter-option"; import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode"; +import * as Utils from "#app/utils"; import { IntegerHolder, isNullOrUndefined, randInt, randSeedInt, randSeedShuffle } from "#app/utils"; -import Pokemon, { EnemyPokemon, PlayerPokemon } from "#app/field/pokemon"; -import { HiddenAbilityRateBoosterModifier, PokemonFormChangeItemModifier, PokemonHeldItemModifier, SpeciesStatBoosterModifier } from "#app/modifier/modifier"; +import Pokemon, { EnemyPokemon, PlayerPokemon, PokemonMove } from "#app/field/pokemon"; +import { HiddenAbilityRateBoosterModifier, PokemonFormChangeItemModifier, PokemonHeldItemModifier, ShinyRateBoosterModifier, SpeciesStatBoosterModifier } from "#app/modifier/modifier"; import { OptionSelectItem } from "#app/ui/abstact-option-select-ui-handler"; import PokemonData from "#app/system/pokemon-data"; import i18next from "i18next"; import { Gender, getGenderSymbol } from "#app/data/gender"; import { getNatureName } from "#app/data/nature"; -import { getPokeballAtlasKey, getPokeballTintColor, PokeballType } from "#app/data/pokeball"; +import { getPokeballAtlasKey, getPokeballTintColor } from "#app/data/pokeball"; import { getEncounterText, showEncounterText } from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; import { trainerNamePools } from "#app/data/trainer-names"; import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES } from "#app/game-mode"; +import { addPokemonDataToDexAndValidateAchievements } from "#app/data/mystery-encounters/utils/encounter-pokemon-utils"; +import type { PokeballType } from "#enums/pokeball"; /** the i18n namespace for the encounter */ -const namespace = "mysteryEncounter:globalTradeSystem"; +const namespace = "mysteryEncounters/globalTradeSystem"; + +/** Base shiny chance of 512/65536 -> 1/128 odds, affected by events and Shiny Charms. Cannot exceed 1/16 odds. */ +const WONDER_TRADE_SHINY_CHANCE = 512; +/** Max shiny chance of 4096/65536 -> 1/16 odds. */ +const MAX_WONDER_TRADE_SHINY_CHANCE = 4096; const LEGENDARY_TRADE_POOLS = { - 1: [Species.RATTATA, Species.PIDGEY, Species.WEEDLE], - 2: [Species.SENTRET, Species.HOOTHOOT, Species.LEDYBA], - 3: [Species.POOCHYENA, Species.ZIGZAGOON, Species.TAILLOW], - 4: [Species.BIDOOF, Species.STARLY, Species.KRICKETOT], - 5: [Species.PATRAT, Species.PURRLOIN, Species.PIDOVE], - 6: [Species.BUNNELBY, Species.LITLEO, Species.SCATTERBUG], - 7: [Species.PIKIPEK, Species.YUNGOOS, Species.ROCKRUFF], - 8: [Species.SKWOVET, Species.WOOLOO, Species.ROOKIDEE], - 9: [Species.LECHONK, Species.FIDOUGH, Species.TAROUNTULA] + 1: [ Species.RATTATA, Species.PIDGEY, Species.WEEDLE ], + 2: [ Species.SENTRET, Species.HOOTHOOT, Species.LEDYBA ], + 3: [ Species.POOCHYENA, Species.ZIGZAGOON, Species.TAILLOW ], + 4: [ Species.BIDOOF, Species.STARLY, Species.KRICKETOT ], + 5: [ Species.PATRAT, Species.PURRLOIN, Species.PIDOVE ], + 6: [ Species.BUNNELBY, Species.LITLEO, Species.SCATTERBUG ], + 7: [ Species.PIKIPEK, Species.YUNGOOS, Species.ROCKRUFF ], + 8: [ Species.SKWOVET, Species.WOOLOO, Species.ROOKIDEE ], + 9: [ Species.LECHONK, Species.FIDOUGH, Species.TAROUNTULA ] }; /** Exclude Paradox mons as they aren't considered legendary/mythical */ @@ -86,18 +95,19 @@ export const GlobalTradeSystemEncounter: MysteryEncounter = ]) .withIntroDialogue([ { - text: `${namespace}.intro`, + text: `${namespace}:intro`, } ]) - .withTitle(`${namespace}.title`) - .withDescription(`${namespace}.description`) - .withQuery(`${namespace}.query`) + .setLocalizationKey(`${namespace}`) + .withTitle(`${namespace}:title`) + .withDescription(`${namespace}:description`) + .withQuery(`${namespace}:query`) .withOnInit((scene: BattleScene) => { const encounter = scene.currentBattle.mysteryEncounter!; // Load bgm let bgmKey: string; - if (scene.musicPreference === 0) { + if (scene.musicPreference === MusicPreference.CONSISTENT) { bgmKey = "mystery_encounter_gen_5_gts"; scene.loadBgm(bgmKey, `${bgmKey}.mp3`); } else { @@ -118,21 +128,17 @@ export const GlobalTradeSystemEncounter: MysteryEncounter = return true; }) .withOnVisualsStart((scene: BattleScene) => { - // Change the bgm - scene.fadeOutBgm(1500, false); - scene.time.delayedCall(1500, () => { - scene.playBgm(scene.currentBattle.mysteryEncounter!.misc.bgmKey); - }); - + scene.fadeAndSwitchBgm(scene.currentBattle.mysteryEncounter!.misc.bgmKey); return true; }) .withOption( MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) + .withHasDexProgress(true) .withDialogue({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, - secondOptionPrompt: `${namespace}.option.1.trade_options_prompt`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, + secondOptionPrompt: `${namespace}:option.1.trade_options_prompt`, }) .withPreOptionPhase(async (scene: BattleScene): Promise => { const encounter = scene.currentBattle.mysteryEncounter!; @@ -156,7 +162,7 @@ export const GlobalTradeSystemEncounter: MysteryEncounter = return true; }, onHover: () => { - const formName = tradePokemon.species.forms?.[pokemon.formIndex]?.formName; + const formName = tradePokemon.species.forms && tradePokemon.species.forms.length > tradePokemon.formIndex ? tradePokemon.species.forms[tradePokemon.formIndex].formName : null; const line1 = i18next.t("pokemonInfoContainer:ability") + " " + tradePokemon.getAbility().name + (tradePokemon.getGender() !== Gender.GENDERLESS ? " | " + i18next.t("pokemonInfoContainer:gender") + " " + getGenderSymbol(tradePokemon.getGender()) : ""); const line2 = i18next.t("pokemonInfoContainer:nature") + " " + getNatureName(tradePokemon.getNature()) + (formName ? " | " + i18next.t("pokemonInfoContainer:form") + " " + formName : ""); showEncounterText(scene, `${line1}\n${line2}`, 0, 0, false); @@ -187,7 +193,7 @@ export const GlobalTradeSystemEncounter: MysteryEncounter = receivedPokemonData.pokeball = randInt(4) as PokeballType; const dataSource = new PokemonData(receivedPokemonData); const newPlayerPokemon = scene.addPlayerPokemon(receivedPokemonData.species, receivedPokemonData.level, dataSource.abilityIndex, dataSource.formIndex, dataSource.gender, dataSource.shiny, dataSource.variant, dataSource.ivs, dataSource.nature, dataSource); - scene.getParty().push(newPlayerPokemon); + scene.getPlayerParty().push(newPlayerPokemon); await newPlayerPokemon.loadAssets(); for (const mod of modifiers) { @@ -198,8 +204,9 @@ export const GlobalTradeSystemEncounter: MysteryEncounter = // Show the trade animation await showTradeBackground(scene); await doPokemonTradeSequence(scene, tradedPokemon, newPlayerPokemon); - await showEncounterText(scene, `${namespace}.trade_received`, null, 0, true, 4000); + await showEncounterText(scene, `${namespace}:trade_received`, null, 0, true, 4000); scene.playBgm(encounter.misc.bgmKey); + await addPokemonDataToDexAndValidateAchievements(scene, newPlayerPokemon); await hideTradeBackground(scene); tradedPokemon.destroy(); @@ -210,34 +217,60 @@ export const GlobalTradeSystemEncounter: MysteryEncounter = .withOption( MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) + .withHasDexProgress(true) .withDialogue({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, }) .withPreOptionPhase(async (scene: BattleScene): Promise => { const encounter = scene.currentBattle.mysteryEncounter!; const onPokemonSelected = (pokemon: PlayerPokemon) => { // Randomly generate a Wonder Trade pokemon - // const randomTradeOption = generateTradeOption(scene.getParty().map(p => p.species)); - const randomTradeOption = getPokemonSpecies(Species.BURMY); + const randomTradeOption = generateTradeOption(scene.getPlayerParty().map(p => p.species)); const tradePokemon = new EnemyPokemon(scene, randomTradeOption, pokemon.level, TrainerSlot.NONE, false); // Extra shiny roll at 1/128 odds (boosted by events and charms) if (!tradePokemon.shiny) { - // 512/65536 -> 1/128 - tradePokemon.trySetShinySeed(512, true); + const shinyThreshold = new Utils.IntegerHolder(WONDER_TRADE_SHINY_CHANCE); + if (scene.eventManager.isEventActive()) { + shinyThreshold.value *= scene.eventManager.getShinyMultiplier(); + } + scene.applyModifiers(ShinyRateBoosterModifier, true, shinyThreshold); + + // Base shiny chance of 512/65536 -> 1/128, affected by events and Shiny Charms + // Maximum shiny chance of 4096/65536 -> 1/16, cannot improve further after that + const shinyChance = Math.min(shinyThreshold.value, MAX_WONDER_TRADE_SHINY_CHANCE); + + tradePokemon.trySetShinySeed(shinyChance, false); } // Extra HA roll at base 1/64 odds (boosted by events and charms) - if (pokemon.species.abilityHidden) { - const hiddenIndex = pokemon.species.ability2 ? 2 : 1; - if (pokemon.abilityIndex < hiddenIndex) { + const hiddenIndex = tradePokemon.species.ability2 ? 2 : 1; + if (tradePokemon.species.abilityHidden) { + if (tradePokemon.abilityIndex < hiddenIndex) { const hiddenAbilityChance = new IntegerHolder(64); scene.applyModifiers(HiddenAbilityRateBoosterModifier, true, hiddenAbilityChance); const hasHiddenAbility = !randSeedInt(hiddenAbilityChance.value); if (hasHiddenAbility) { - pokemon.abilityIndex = hiddenIndex; + tradePokemon.abilityIndex = hiddenIndex; + } + } + } + + // If Pokemon is still not shiny or with HA, give the Pokemon a random Common egg move in its moveset + if (!tradePokemon.shiny && (!tradePokemon.species.abilityHidden || tradePokemon.abilityIndex < hiddenIndex)) { + const eggMoves = tradePokemon.getEggMoves(); + if (eggMoves) { + // Cannot gen the rare egg move, only 1 of the first 3 common moves + const eggMove = eggMoves[randSeedInt(3)]; + if (!tradePokemon.moveset.some(m => m?.moveId === eggMove)) { + if (tradePokemon.moveset.length < 4) { + tradePokemon.moveset.push(new PokemonMove(eggMove)); + } else { + const eggMoveIndex = randSeedInt(4); + tradePokemon.moveset[eggMoveIndex] = new PokemonMove(eggMove); + } } } } @@ -268,7 +301,7 @@ export const GlobalTradeSystemEncounter: MysteryEncounter = receivedPokemonData.pokeball = randInt(4) as PokeballType; const dataSource = new PokemonData(receivedPokemonData); const newPlayerPokemon = scene.addPlayerPokemon(receivedPokemonData.species, receivedPokemonData.level, dataSource.abilityIndex, dataSource.formIndex, dataSource.gender, dataSource.shiny, dataSource.variant, dataSource.ivs, dataSource.nature, dataSource); - scene.getParty().push(newPlayerPokemon); + scene.getPlayerParty().push(newPlayerPokemon); await newPlayerPokemon.loadAssets(); for (const mod of modifiers) { @@ -279,8 +312,9 @@ export const GlobalTradeSystemEncounter: MysteryEncounter = // Show the trade animation await showTradeBackground(scene); await doPokemonTradeSequence(scene, tradedPokemon, newPlayerPokemon); - await showEncounterText(scene, `${namespace}.trade_received`, null, 0, true, 4000); - scene.playBgm(scene.currentBattle.mysteryEncounter!.misc.bgmKey); + await showEncounterText(scene, `${namespace}:trade_received`, null, 0, true, 4000); + scene.playBgm(encounter.misc.bgmKey); + await addPokemonDataToDexAndValidateAchievements(scene, newPlayerPokemon); await hideTradeBackground(scene); tradedPokemon.destroy(); @@ -292,16 +326,16 @@ export const GlobalTradeSystemEncounter: MysteryEncounter = MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) .withDialogue({ - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, - secondOptionPrompt: `${namespace}.option.3.trade_options_prompt`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, + secondOptionPrompt: `${namespace}:option.3.trade_options_prompt`, }) .withPreOptionPhase(async (scene: BattleScene): Promise => { const encounter = scene.currentBattle.mysteryEncounter!; const onPokemonSelected = (pokemon: PlayerPokemon) => { // Get Pokemon held items and filter for valid ones const validItems = pokemon.getHeldItems().filter((it) => { - return it.isTransferrable; + return it.isTransferable; }); return validItems.map((modifier: PokemonHeldItemModifier) => { @@ -311,6 +345,7 @@ export const GlobalTradeSystemEncounter: MysteryEncounter = // Pokemon and item selected encounter.setDialogueToken("chosenItem", modifier.type.name); encounter.misc.chosenModifier = modifier; + encounter.misc.chosenPokemon = pokemon; return true; }, }; @@ -318,14 +353,13 @@ export const GlobalTradeSystemEncounter: MysteryEncounter = }); }; - // Only Pokemon that can gain benefits are above 1/3rd HP with no status const selectableFilter = (pokemon: Pokemon) => { // If pokemon has items to trade const meetsReqs = pokemon.getHeldItems().filter((it) => { - return it.isTransferrable; + return it.isTransferable; }).length > 0; if (!meetsReqs) { - return getEncounterText(scene, `${namespace}.option.3.invalid_selection`) ?? null; + return getEncounterText(scene, `${namespace}:option.3.invalid_selection`) ?? null; } return null; @@ -335,10 +369,12 @@ export const GlobalTradeSystemEncounter: MysteryEncounter = }) .withOptionPhase(async (scene: BattleScene) => { const encounter = scene.currentBattle.mysteryEncounter!; - const modifier = encounter.misc.chosenModifier; + const modifier = encounter.misc.chosenModifier as PokemonHeldItemModifier; + const party = scene.getPlayerParty(); + const chosenPokemon: PlayerPokemon = encounter.misc.chosenPokemon; // Check tier of the traded item, the received item will be one tier up - const type = modifier.type.withTierFromPool(); + const type = modifier.type.withTierFromPool(ModifierPoolType.PLAYER, party); let tier = type.tier ?? ModifierTier.GREAT; // Eggs and White Herb are not in the pool if (type.id === "WHITE_HERB") { @@ -353,38 +389,34 @@ export const GlobalTradeSystemEncounter: MysteryEncounter = tier++; } - regenerateModifierPoolThresholds(scene.getParty(), ModifierPoolType.PLAYER, 0); + regenerateModifierPoolThresholds(party, ModifierPoolType.PLAYER, 0); let item: ModifierTypeOption | null = null; // TMs excluded from possible rewards while (!item || item.type.id.includes("TM_")) { - item = getPlayerModifierTypeOptions(1, scene.getParty(), [], { guaranteedModifierTiers: [tier], allowLuckUpgrades: false })[0]; + item = getPlayerModifierTypeOptions(1, party, [], { guaranteedModifierTiers: [ tier ], allowLuckUpgrades: false })[0]; } encounter.setDialogueToken("itemName", item.type.name); - setEncounterRewards(scene, { guaranteedModifierTypeOptions: [item], fillRemaining: false }); + setEncounterRewards(scene, { guaranteedModifierTypeOptions: [ item ], fillRemaining: false }); - // Remove the chosen modifier if its stacks go to 0 - modifier.stackCount -= 1; - if (modifier.stackCount === 0) { - scene.removeModifier(modifier); - } - scene.updateModifiers(true, true); + chosenPokemon.loseHeldItem(modifier, false); + await scene.updateModifiers(true, true); // Generate a trainer name const traderName = generateRandomTraderName(); encounter.setDialogueToken("tradeTrainerName", traderName.trim()); - await showEncounterText(scene, `${namespace}.item_trade_selected`); + await showEncounterText(scene, `${namespace}:item_trade_selected`); leaveEncounterWithoutBattle(scene); }) .build() ) .withSimpleOption( { - buttonLabel: `${namespace}.option.4.label`, - buttonTooltip: `${namespace}.option.4.tooltip`, + buttonLabel: `${namespace}:option.4.label`, + buttonTooltip: `${namespace}:option.4.tooltip`, selected: [ { - text: `${namespace}.option.4.selected`, + text: `${namespace}:option.4.selected`, }, ], }, @@ -399,9 +431,9 @@ export const GlobalTradeSystemEncounter: MysteryEncounter = function getPokemonTradeOptions(scene: BattleScene): Map { const tradeOptionsMap: Map = new Map(); // Starts by filtering out any current party members as valid resulting species - const alreadyUsedSpecies: PokemonSpecies[] = scene.getParty().map(p => p.species); + const alreadyUsedSpecies: PokemonSpecies[] = scene.getPlayerParty().map(p => p.species); - scene.getParty().forEach(pokemon => { + scene.getPlayerParty().forEach(pokemon => { // If the party member is legendary/mythical, the only trade options available are always pulled from generation-specific legendary trade pools if (pokemon.species.legendary || pokemon.species.subLegendary || pokemon.species.mythical) { const generation = pokemon.species.generation; @@ -432,14 +464,13 @@ function getPokemonTradeOptions(scene: BattleScene): Map function generateTradeOption(alreadyUsedSpecies: PokemonSpecies[], originalBst?: number): PokemonSpecies { let newSpecies: PokemonSpecies | undefined; + let bstCap = 9999; + let bstMin = 0; + if (originalBst) { + bstCap = originalBst + 100; + bstMin = originalBst - 100; + } while (isNullOrUndefined(newSpecies)) { - let bstCap = 9999; - let bstMin = 0; - if (originalBst) { - bstCap = originalBst + 100; - bstMin = originalBst - 100; - } - // Get all non-legendary species that fall within the Bst range requirements let validSpecies = allSpecies .filter(s => { @@ -453,7 +484,7 @@ function generateTradeOption(alreadyUsedSpecies: PokemonSpecies[], originalBst?: if (validSpecies?.length > 20) { validSpecies = randSeedShuffle(validSpecies); newSpecies = validSpecies.pop(); - while (isNullOrUndefined(newSpecies) || alreadyUsedSpecies.includes(newSpecies!)) { + while (isNullOrUndefined(newSpecies) || alreadyUsedSpecies.includes(newSpecies)) { newSpecies = validSpecies.pop(); } } else { @@ -599,10 +630,10 @@ function doPokemonTradeSequence(scene: BattleScene, tradedPokemon: PlayerPokemon duration: 500, onComplete: async () => { scene.fadeOutBgm(1000, false); - await showEncounterText(scene, `${namespace}.pokemon_trade_selected`); + await showEncounterText(scene, `${namespace}:pokemon_trade_selected`); tradedPokemon.cry(); scene.playBgm("evolution"); - await showEncounterText(scene, `${namespace}.pokemon_trade_goodbye`); + await showEncounterText(scene, `${namespace}:pokemon_trade_goodbye`); tradedPokeball.setAlpha(0); tradedPokeball.setVisible(true); @@ -621,7 +652,7 @@ function doPokemonTradeSequence(scene: BattleScene, tradedPokemon: PlayerPokemon // addPokeballOpenParticles(scene, tradedPokemon.x, tradedPokemon.y, tradedPokemon.pokeball); scene.tweens.add({ - targets: [tradedPokemonTintSprite, tradedPokemonSprite], + targets: [ tradedPokemonTintSprite, tradedPokemonSprite ], duration: 500, ease: "Sine.easeIn", scale: 0.25, @@ -697,7 +728,7 @@ function doPokemonTradeFlyBySequence(scene: BattleScene, tradedPokemonSprite: Ph duration: FADE_DELAY, onComplete: () => { scene.tweens.add({ - targets: [receivedPokemonSprite, tradedPokemonSprite], + targets: [ receivedPokemonSprite, tradedPokemonSprite ], y: tradeBaseBg.displayWidth / 2 - 100, ease: "Cubic.easeInOut", duration: BASE_ANIM_DURATION * 3, diff --git a/src/data/mystery-encounters/encounters/lost-at-sea-encounter.ts b/src/data/mystery-encounters/encounters/lost-at-sea-encounter.ts index 16568d8cb7d..a8cb076bbe9 100644 --- a/src/data/mystery-encounters/encounters/lost-at-sea-encounter.ts +++ b/src/data/mystery-encounters/encounters/lost-at-sea-encounter.ts @@ -3,14 +3,14 @@ import { Moves } from "#app/enums/moves"; import { Species } from "#app/enums/species"; import { MysteryEncounterType } from "#enums/mystery-encounter-type"; import BattleScene from "#app/battle-scene"; -import MysteryEncounter, { MysteryEncounterBuilder } from "../mystery-encounter"; -import { MysteryEncounterOptionBuilder } from "../mystery-encounter-option"; +import MysteryEncounter, { MysteryEncounterBuilder } from "#app/data/mystery-encounters/mystery-encounter"; +import { MysteryEncounterOptionBuilder } from "#app/data/mystery-encounters/mystery-encounter-option"; import { leaveEncounterWithoutBattle, setEncounterExp } from "../utils/encounter-phase-utils"; import { applyDamageToPokemon } from "#app/data/mystery-encounters/utils/encounter-pokemon-utils"; import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode"; import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES } from "#app/game-mode"; -import {PokemonMove} from "#app/field/pokemon"; +import { PokemonMove } from "#app/field/pokemon"; const OPTION_1_REQUIRED_MOVE = Moves.SURF; const OPTION_2_REQUIRED_MOVE = Moves.FLY; @@ -21,7 +21,7 @@ const OPTION_2_REQUIRED_MOVE = Moves.FLY; */ const DAMAGE_PERCENTAGE: number = 25; /** The i18n namespace for the encounter */ -const namespace = "mysteryEncounter:lostAtSea"; +const namespace = "mysteryEncounters/lostAtSea"; /** * Lost at sea encounter. @@ -33,14 +33,14 @@ export const LostAtSeaEncounter: MysteryEncounter = MysteryEncounterBuilder.with .withSceneWaveRangeRequirement(...CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES) .withIntroSpriteConfigs([ { - spriteKey: "buoy", + spriteKey: "lost_at_sea_buoy", fileRoot: "mystery-encounters", hasShadow: false, x: 20, y: 3, }, ]) - .withIntroDialogue([{ text: `${namespace}.intro` }]) + .withIntroDialogue([{ text: `${namespace}:intro` }]) .withOnInit((scene: BattleScene) => { const encounter = scene.currentBattle.mysteryEncounter!; @@ -50,22 +50,23 @@ export const LostAtSeaEncounter: MysteryEncounter = MysteryEncounterBuilder.with return true; }) - .withTitle(`${namespace}.title`) - .withDescription(`${namespace}.description`) - .withQuery(`${namespace}.query`) + .setLocalizationKey(`${namespace}`) + .withTitle(`${namespace}:title`) + .withDescription(`${namespace}:description`) + .withQuery(`${namespace}:query`) .withOption( // Option 1: Use a (non fainted) pokemon that can learn Surf to guide you back/ MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DISABLED_OR_DEFAULT) .withPokemonCanLearnMoveRequirement(OPTION_1_REQUIRED_MOVE) .withDialogue({ - buttonLabel: `${namespace}.option.1.label`, - disabledButtonLabel: `${namespace}.option.1.label_disabled`, - buttonTooltip: `${namespace}.option.1.tooltip`, - disabledButtonTooltip: `${namespace}.option.1.tooltip_disabled`, + buttonLabel: `${namespace}:option.1.label`, + disabledButtonLabel: `${namespace}:option.1.label_disabled`, + buttonTooltip: `${namespace}:option.1.tooltip`, + disabledButtonTooltip: `${namespace}:option.1.tooltip_disabled`, selected: [ { - text: `${namespace}.option.1.selected`, + text: `${namespace}:option.1.selected`, }, ], }) @@ -78,13 +79,13 @@ export const LostAtSeaEncounter: MysteryEncounter = MysteryEncounterBuilder.with .newOptionWithMode(MysteryEncounterOptionMode.DISABLED_OR_DEFAULT) .withPokemonCanLearnMoveRequirement(OPTION_2_REQUIRED_MOVE) .withDialogue({ - buttonLabel: `${namespace}.option.2.label`, - disabledButtonLabel: `${namespace}.option.2.label_disabled`, - buttonTooltip: `${namespace}.option.2.tooltip`, - disabledButtonTooltip: `${namespace}.option.2.tooltip_disabled`, + buttonLabel: `${namespace}:option.2.label`, + disabledButtonLabel: `${namespace}:option.2.label_disabled`, + buttonTooltip: `${namespace}:option.2.tooltip`, + disabledButtonTooltip: `${namespace}:option.2.tooltip_disabled`, selected: [ { - text: `${namespace}.option.2.selected`, + text: `${namespace}:option.2.selected`, }, ], }) @@ -94,16 +95,16 @@ export const LostAtSeaEncounter: MysteryEncounter = MysteryEncounterBuilder.with .withSimpleOption( // Option 3: Wander aimlessly { - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, selected: [ { - text: `${namespace}.option.3.selected`, + text: `${namespace}:option.3.selected`, }, ], }, async (scene: BattleScene) => { - const allowedPokemon = scene.getParty().filter((p) => p.isAllowedInBattle()); + const allowedPokemon = scene.getPlayerParty().filter((p) => p.isAllowedInBattle()); for (const pkm of allowedPokemon) { const percentage = DAMAGE_PERCENTAGE / 100; @@ -118,7 +119,7 @@ export const LostAtSeaEncounter: MysteryEncounter = MysteryEncounterBuilder.with ) .withOutroDialogue([ { - text: `${namespace}.outro`, + text: `${namespace}:outro`, }, ]) .build(); @@ -128,7 +129,7 @@ export const LostAtSeaEncounter: MysteryEncounter = MysteryEncounterBuilder.with * * @param scene Battle scene */ -async function handlePokemonGuidingYouPhase(scene: BattleScene) { +function handlePokemonGuidingYouPhase(scene: BattleScene) { const laprasSpecies = getPokemonSpecies(Species.LAPRAS); const { mysteryEncounter } = scene.currentBattle; diff --git a/src/data/mystery-encounters/encounters/mysterious-challengers-encounter.ts b/src/data/mystery-encounters/encounters/mysterious-challengers-encounter.ts index 71a44bd6852..7fdd29d36a2 100644 --- a/src/data/mystery-encounters/encounters/mysterious-challengers-encounter.ts +++ b/src/data/mystery-encounters/encounters/mysterious-challengers-encounter.ts @@ -15,12 +15,12 @@ import { MysteryEncounterType } from "#enums/mystery-encounter-type"; import { PartyMemberStrength } from "#enums/party-member-strength"; import BattleScene from "#app/battle-scene"; import * as Utils from "#app/utils"; -import MysteryEncounter, { MysteryEncounterBuilder } from "../mystery-encounter"; +import MysteryEncounter, { MysteryEncounterBuilder } from "#app/data/mystery-encounters/mystery-encounter"; import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES } from "#app/game-mode"; /** the i18n namespace for the encounter */ -const namespace = "mysteryEncounter:mysteriousChallengers"; +const namespace = "mysteryEncounters/mysteriousChallengers"; /** * Mysterious Challengers encounter. @@ -34,7 +34,7 @@ export const MysteriousChallengersEncounter: MysteryEncounter = .withIntroSpriteConfigs([]) // These are set in onInit() .withIntroDialogue([ { - text: `${namespace}.intro`, + text: `${namespace}:intro`, }, ]) .withOnInit((scene: BattleScene) => { @@ -56,7 +56,13 @@ export const MysteriousChallengersEncounter: MysteryEncounter = // Hard difficulty trainer is another random trainer, but with AVERAGE_BALANCED config // Number of mons is based off wave: 1-20 is 2, 20-40 is 3, etc. capping at 6 after wave 100 - const hardTrainerType = scene.arena.randomTrainerType(scene.currentBattle.waveIndex); + let retries = 0; + let hardTrainerType = scene.arena.randomTrainerType(scene.currentBattle.waveIndex); + while (retries < 5 && hardTrainerType === normalTrainerType) { + // Will try to use a different trainer from the normal trainer type + hardTrainerType = scene.arena.randomTrainerType(scene.currentBattle.waveIndex); + retries++; + } const hardTemplate = new TrainerPartyCompoundTemplate( new TrainerPartyTemplate(1, PartyMemberStrength.STRONGER, false, true), new TrainerPartyTemplate( @@ -75,7 +81,7 @@ export const MysteriousChallengersEncounter: MysteryEncounter = const hardSpriteKey = hardConfig.getSpriteKey(female, hardConfig.doubleOnly); encounter.enemyPartyConfigs.push({ trainerConfig: hardConfig, - levelAdditiveMultiplier: 1, + levelAdditiveModifier: 1, female: female, }); @@ -98,7 +104,7 @@ export const MysteriousChallengersEncounter: MysteryEncounter = const brutalSpriteKey = brutalConfig.getSpriteKey(female, brutalConfig.doubleOnly); encounter.enemyPartyConfigs.push({ trainerConfig: brutalConfig, - levelAdditiveMultiplier: 1.5, + levelAdditiveModifier: 1.5, female: female, }); @@ -125,16 +131,17 @@ export const MysteriousChallengersEncounter: MysteryEncounter = return true; }) - .withTitle(`${namespace}.title`) - .withDescription(`${namespace}.description`) - .withQuery(`${namespace}.query`) + .setLocalizationKey(`${namespace}`) + .withTitle(`${namespace}:title`) + .withDescription(`${namespace}:description`) + .withQuery(`${namespace}:query`) .withSimpleOption( { - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.selected`, + text: `${namespace}:option.selected`, }, ], }, @@ -143,23 +150,23 @@ export const MysteriousChallengersEncounter: MysteryEncounter = // Spawn standard trainer battle with memory mushroom reward const config: EnemyPartyConfig = encounter.enemyPartyConfigs[0]; - setEncounterRewards(scene, { guaranteedModifierTypeFuncs: [modifierTypes.TM_COMMON, modifierTypes.TM_GREAT, modifierTypes.MEMORY_MUSHROOM], fillRemaining: true }); + setEncounterRewards(scene, { guaranteedModifierTypeFuncs: [ modifierTypes.TM_COMMON, modifierTypes.TM_GREAT, modifierTypes.MEMORY_MUSHROOM ], fillRemaining: true }); // Seed offsets to remove possibility of different trainers having exact same teams - let ret; + let initBattlePromise: Promise; scene.executeWithSeedOffset(() => { - ret = initBattleWithEnemyConfig(scene, config); + initBattlePromise = initBattleWithEnemyConfig(scene, config); }, scene.currentBattle.waveIndex * 10); - return ret; + await initBattlePromise!; } ) .withSimpleOption( { - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, selected: [ { - text: `${namespace}.option.selected`, + text: `${namespace}:option.selected`, }, ], }, @@ -168,23 +175,23 @@ export const MysteriousChallengersEncounter: MysteryEncounter = // Spawn hard fight const config: EnemyPartyConfig = encounter.enemyPartyConfigs[1]; - setEncounterRewards(scene, { guaranteedModifierTiers: [ModifierTier.ULTRA, ModifierTier.ULTRA, ModifierTier.GREAT, ModifierTier.GREAT], fillRemaining: true }); + setEncounterRewards(scene, { guaranteedModifierTiers: [ ModifierTier.ULTRA, ModifierTier.ULTRA, ModifierTier.GREAT, ModifierTier.GREAT ], fillRemaining: true }); // Seed offsets to remove possibility of different trainers having exact same teams - let ret; + let initBattlePromise: Promise; scene.executeWithSeedOffset(() => { - ret = initBattleWithEnemyConfig(scene, config); + initBattlePromise = initBattleWithEnemyConfig(scene, config); }, scene.currentBattle.waveIndex * 100); - return ret; + await initBattlePromise!; } ) .withSimpleOption( { - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, selected: [ { - text: `${namespace}.option.selected`, + text: `${namespace}:option.selected`, }, ], }, @@ -196,19 +203,19 @@ export const MysteriousChallengersEncounter: MysteryEncounter = // To avoid player level snowballing from picking this option encounter.expMultiplier = 0.9; - setEncounterRewards(scene, { guaranteedModifierTiers: [ModifierTier.ROGUE, ModifierTier.ROGUE, ModifierTier.ULTRA, ModifierTier.GREAT], fillRemaining: true }); + setEncounterRewards(scene, { guaranteedModifierTiers: [ ModifierTier.ROGUE, ModifierTier.ROGUE, ModifierTier.ULTRA, ModifierTier.GREAT ], fillRemaining: true }); // Seed offsets to remove possibility of different trainers having exact same teams - let ret; + let initBattlePromise: Promise; scene.executeWithSeedOffset(() => { - ret = initBattleWithEnemyConfig(scene, config); + initBattlePromise = initBattleWithEnemyConfig(scene, config); }, scene.currentBattle.waveIndex * 1000); - return ret; + await initBattlePromise!; } ) .withOutroDialogue([ { - text: `${namespace}.outro`, + text: `${namespace}:outro`, }, ]) .build(); diff --git a/src/data/mystery-encounters/encounters/mysterious-chest-encounter.ts b/src/data/mystery-encounters/encounters/mysterious-chest-encounter.ts index 26e846ed874..ab6517e97af 100644 --- a/src/data/mystery-encounters/encounters/mysterious-chest-encounter.ts +++ b/src/data/mystery-encounters/encounters/mysterious-chest-encounter.ts @@ -1,28 +1,29 @@ +import BattleScene from "#app/battle-scene"; +import MysteryEncounter, { MysteryEncounterBuilder } from "#app/data/mystery-encounters/mystery-encounter"; +import { MysteryEncounterOptionBuilder } from "#app/data/mystery-encounters/mystery-encounter-option"; import { queueEncounterMessage, showEncounterText } from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; import { EnemyPartyConfig, initBattleWithEnemyConfig, leaveEncounterWithoutBattle, setEncounterRewards, transitionMysteryEncounterIntroVisuals } from "#app/data/mystery-encounters/utils/encounter-phase-utils"; import { getHighestLevelPlayerPokemon, koPlayerPokemon } from "#app/data/mystery-encounters/utils/encounter-pokemon-utils"; -import { ModifierTier } from "#app/modifier/modifier-tier"; -import { randSeedInt } from "#app/utils"; -import { MysteryEncounterType } from "#enums/mystery-encounter-type"; -import BattleScene from "#app/battle-scene"; -import MysteryEncounter, { MysteryEncounterBuilder } from "../mystery-encounter"; -import { MysteryEncounterOptionBuilder } from "../mystery-encounter-option"; -import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; -import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode"; import { getPokemonSpecies } from "#app/data/pokemon-species"; -import { Species } from "#enums/species"; -import { Moves } from "#enums/moves"; -import { GameOverPhase } from "#app/phases/game-over-phase"; import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES } from "#app/game-mode"; +import { ModifierTier } from "#app/modifier/modifier-tier"; +import { GameOverPhase } from "#app/phases/game-over-phase"; +import { randSeedInt } from "#app/utils"; +import { Moves } from "#enums/moves"; +import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode"; +import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; +import { MysteryEncounterType } from "#enums/mystery-encounter-type"; +import { Species } from "#enums/species"; /** i18n namespace for encounter */ -const namespace = "mysteryEncounter:mysteriousChest"; +const namespace = "mysteryEncounters/mysteriousChest"; const RAND_LENGTH = 100; -const COMMON_REWARDS_WEIGHT = 20; // 20% -const ULTRA_REWARDS_WEIGHT = 50; // 30% -const ROGUE_REWARDS_WEIGHT = 60; // 10% -const MASTER_REWARDS_WEIGHT = 65; // 5% +const TRAP_PERCENT = 35; +const COMMON_REWARDS_PERCENT = 20; +const ULTRA_REWARDS_PERCENT = 30; +const ROGUE_REWARDS_PERCENT = 10; +const MASTER_REWARDS_PERCENT = 5; /** * Mysterious Chest encounter. @@ -37,7 +38,7 @@ export const MysteriousChestEncounter: MysteryEncounter = .withCatchAllowed(true) .withIntroSpriteConfigs([ { - spriteKey: "chest_blue", + spriteKey: "mysterious_chest_blue", fileRoot: "mystery-encounters", hasShadow: true, y: 8, @@ -46,7 +47,7 @@ export const MysteriousChestEncounter: MysteryEncounter = disableAnimation: true, // Re-enabled after option select }, { - spriteKey: "chest_red", + spriteKey: "mysterious_chest_red", fileRoot: "mystery-encounters", hasShadow: false, y: 8, @@ -57,32 +58,38 @@ export const MysteriousChestEncounter: MysteryEncounter = ]) .withIntroDialogue([ { - text: `${namespace}.intro`, + text: `${namespace}:intro`, } ]) - .withTitle(`${namespace}.title`) - .withDescription(`${namespace}.description`) - .withQuery(`${namespace}.query`) + .setLocalizationKey(`${namespace}`) + .withTitle(`${namespace}:title`) + .withDescription(`${namespace}:description`) + .withQuery(`${namespace}:query`) .withOnInit((scene: BattleScene) => { const encounter = scene.currentBattle.mysteryEncounter!; // Calculate boss mon const config: EnemyPartyConfig = { - levelAdditiveMultiplier: 0.5, + levelAdditiveModifier: 0.5, disableSwitch: true, pokemonConfigs: [ { species: getPokemonSpecies(Species.GIMMIGHOUL), formIndex: 0, isBoss: true, - moveSet: [Moves.NASTY_PLOT, Moves.SHADOW_BALL, Moves.POWER_GEM, Moves.THIEF] + moveSet: [ Moves.NASTY_PLOT, Moves.SHADOW_BALL, Moves.POWER_GEM, Moves.THIEF ] } ], }; - encounter.enemyPartyConfigs = [config]; + encounter.enemyPartyConfigs = [ config ]; encounter.setDialogueToken("gimmighoulName", getPokemonSpecies(Species.GIMMIGHOUL).getName()); + encounter.setDialogueToken("trapPercent", TRAP_PERCENT.toString()); + encounter.setDialogueToken("commonPercent", COMMON_REWARDS_PERCENT.toString()); + encounter.setDialogueToken("ultraPercent", ULTRA_REWARDS_PERCENT.toString()); + encounter.setDialogueToken("roguePercent", ROGUE_REWARDS_PERCENT.toString()); + encounter.setDialogueToken("masterPercent", MASTER_REWARDS_PERCENT.toString()); return true; }) @@ -90,11 +97,11 @@ export const MysteriousChestEncounter: MysteryEncounter = MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) .withDialogue({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.1.selected`, + text: `${namespace}:option.1.selected`, }, ], }) @@ -109,7 +116,7 @@ export const MysteriousChestEncounter: MysteryEncounter = roll }; - if (roll >= MASTER_REWARDS_WEIGHT) { + if (roll < TRAP_PERCENT) { // Chest is springing trap, change to red chest sprite const blueChestSprites = introVisuals.getSpriteAtIndex(0); const redChestSprites = introVisuals.getSpriteAtIndex(1); @@ -124,7 +131,7 @@ export const MysteriousChestEncounter: MysteryEncounter = // Open the chest const encounter = scene.currentBattle.mysteryEncounter!; const roll = encounter.misc.roll; - if (roll < COMMON_REWARDS_WEIGHT) { + if (roll >= RAND_LENGTH - COMMON_REWARDS_PERCENT) { // Choose between 2 COMMON / 2 GREAT tier items (20%) setEncounterRewards(scene, { guaranteedModifierTiers: [ @@ -135,9 +142,9 @@ export const MysteriousChestEncounter: MysteryEncounter = ], }); // Display result message then proceed to rewards - queueEncounterMessage(scene, `${namespace}.option.1.normal`); + queueEncounterMessage(scene, `${namespace}:option.1.normal`); leaveEncounterWithoutBattle(scene); - } else if (roll < ULTRA_REWARDS_WEIGHT) { + } else if (roll >= RAND_LENGTH - COMMON_REWARDS_PERCENT - ULTRA_REWARDS_PERCENT) { // Choose between 3 ULTRA tier items (30%) setEncounterRewards(scene, { guaranteedModifierTiers: [ @@ -147,38 +154,38 @@ export const MysteriousChestEncounter: MysteryEncounter = ], }); // Display result message then proceed to rewards - queueEncounterMessage(scene, `${namespace}.option.1.good`); + queueEncounterMessage(scene, `${namespace}:option.1.good`); leaveEncounterWithoutBattle(scene); - } else if (roll < ROGUE_REWARDS_WEIGHT) { + } else if (roll >= RAND_LENGTH - COMMON_REWARDS_PERCENT - ULTRA_REWARDS_PERCENT - ROGUE_REWARDS_PERCENT) { // Choose between 2 ROGUE tier items (10%) - setEncounterRewards(scene, { guaranteedModifierTiers: [ModifierTier.ROGUE, ModifierTier.ROGUE] }); + setEncounterRewards(scene, { guaranteedModifierTiers: [ ModifierTier.ROGUE, ModifierTier.ROGUE ]}); // Display result message then proceed to rewards - queueEncounterMessage(scene, `${namespace}.option.1.great`); + queueEncounterMessage(scene, `${namespace}:option.1.great`); leaveEncounterWithoutBattle(scene); - } else if (roll < MASTER_REWARDS_WEIGHT) { + } else if (roll >= RAND_LENGTH - COMMON_REWARDS_PERCENT - ULTRA_REWARDS_PERCENT - ROGUE_REWARDS_PERCENT - MASTER_REWARDS_PERCENT) { // Choose 1 MASTER tier item (5%) - setEncounterRewards(scene, { guaranteedModifierTiers: [ModifierTier.MASTER] }); + setEncounterRewards(scene, { guaranteedModifierTiers: [ ModifierTier.MASTER ]}); // Display result message then proceed to rewards - queueEncounterMessage(scene, `${namespace}.option.1.amazing`); + queueEncounterMessage(scene, `${namespace}:option.1.amazing`); leaveEncounterWithoutBattle(scene); } else { // Your highest level unfainted Pokemon gets OHKO. Start battle against a Gimmighoul (35%) - const highestLevelPokemon = getHighestLevelPlayerPokemon( - scene, - true - ); + const highestLevelPokemon = getHighestLevelPlayerPokemon(scene, true, false); koPlayerPokemon(scene, highestLevelPokemon); + + encounter.setDialogueToken("pokeName", highestLevelPokemon.getNameToRender()); + await showEncounterText(scene, `${namespace}:option.1.bad`); + // Handle game over edge case - const allowedPokemon = scene.getParty().filter(p => p.isAllowedInBattle()); + const allowedPokemon = scene.getPokemonAllowedInBattle(); if (allowedPokemon.length === 0) { // If there are no longer any legal pokemon in the party, game over. scene.clearPhaseQueue(); scene.unshiftPhase(new GameOverPhase(scene)); } else { // Show which Pokemon was KOed, then start battle against Gimmighoul - encounter.setDialogueToken("pokeName", highestLevelPokemon.getNameToRender()); - await showEncounterText(scene, `${namespace}.option.1.bad`); - transitionMysteryEncounterIntroVisuals(scene, true, true, 500); + await transitionMysteryEncounterIntroVisuals(scene, true, true, 500); + setEncounterRewards(scene, { fillRemaining: true }); await initBattleWithEnemyConfig(scene, encounter.enemyPartyConfigs[0]); } } @@ -187,11 +194,11 @@ export const MysteriousChestEncounter: MysteryEncounter = ) .withSimpleOption( { - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, selected: [ { - text: `${namespace}.option.2.selected`, + text: `${namespace}:option.2.selected`, }, ], }, diff --git a/src/data/mystery-encounters/encounters/part-timer-encounter.ts b/src/data/mystery-encounters/encounters/part-timer-encounter.ts index 2abbb53c333..092d2ab2673 100644 --- a/src/data/mystery-encounters/encounters/part-timer-encounter.ts +++ b/src/data/mystery-encounters/encounters/part-timer-encounter.ts @@ -2,19 +2,20 @@ import { MysteryEncounterOptionBuilder } from "#app/data/mystery-encounters/myst import { leaveEncounterWithoutBattle, selectPokemonForOption, setEncounterExp, setEncounterRewards, transitionMysteryEncounterIntroVisuals, updatePlayerMoney } from "#app/data/mystery-encounters/utils/encounter-phase-utils"; import { MysteryEncounterType } from "#enums/mystery-encounter-type"; import BattleScene from "#app/battle-scene"; -import MysteryEncounter, { MysteryEncounterBuilder } from "../mystery-encounter"; -import { MoveRequirement } from "../mystery-encounter-requirements"; +import MysteryEncounter, { MysteryEncounterBuilder } from "#app/data/mystery-encounters/mystery-encounter"; +import { MoveRequirement } from "#app/data/mystery-encounters/mystery-encounter-requirements"; import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode"; import { Stat } from "#enums/stat"; import { CHARMING_MOVES } from "#app/data/mystery-encounters/requirements/requirement-groups"; -import { getEncounterText, showEncounterDialogue, showEncounterText } from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; +import { showEncounterDialogue, showEncounterText } from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; import i18next from "i18next"; import Pokemon, { PlayerPokemon } from "#app/field/pokemon"; import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES } from "#app/game-mode"; +import { isPokemonValidForEncounterOptionSelection } from "#app/data/mystery-encounters/utils/encounter-pokemon-utils"; /** the i18n namespace for the encounter */ -const namespace = "mysteryEncounter:partTimer"; +const namespace = "mysteryEncounters/partTimer"; /** * Part Timer encounter. @@ -27,7 +28,7 @@ export const PartTimerEncounter: MysteryEncounter = .withSceneWaveRangeRequirement(...CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES) .withIntroSpriteConfigs([ { - spriteKey: "warehouse_crate", + spriteKey: "part_timer_crate", fileRoot: "mystery-encounters", hasShadow: false, y: 6, @@ -44,11 +45,11 @@ export const PartTimerEncounter: MysteryEncounter = .withAutoHideIntroVisuals(false) .withIntroDialogue([ { - text: `${namespace}.intro`, + text: `${namespace}:intro`, }, { - speaker: `${namespace}.speaker`, - text: `${namespace}.intro_dialogue`, + speaker: `${namespace}:speaker`, + text: `${namespace}:intro_dialogue`, }, ]) .withOnInit((scene: BattleScene) => { @@ -68,17 +69,18 @@ export const PartTimerEncounter: MysteryEncounter = return true; }) - .withTitle(`${namespace}.title`) - .withDescription(`${namespace}.description`) - .withQuery(`${namespace}.query`) + .setLocalizationKey(`${namespace}`) + .withTitle(`${namespace}:title`) + .withDescription(`${namespace}:description`) + .withQuery(`${namespace}:query`) .withOption(MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) .withDialogue({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.1.selected` + text: `${namespace}:option.1.selected` } ] }) @@ -93,7 +95,7 @@ export const PartTimerEncounter: MysteryEncounter = // Calculation from Pokemon.calculateStats const baselineValue = Math.floor(((2 * 90 + 16) * pokemon.level) * 0.01) + 5; const percentDiff = (pokemon.getStat(Stat.SPD) - baselineValue) / baselineValue; - const moneyMultiplier = Math.min(Math.max(2.5 * (1+ percentDiff), 1), 4); + const moneyMultiplier = Math.min(Math.max(2.5 * (1 + percentDiff), 1), 4); encounter.misc = { moneyMultiplier @@ -117,11 +119,7 @@ export const PartTimerEncounter: MysteryEncounter = // Only Pokemon non-KOd pokemon can be selected const selectableFilter = (pokemon: Pokemon) => { - if (!pokemon.isAllowedInBattle()) { - return getEncounterText(scene, `${namespace}.invalid_selection`) ?? null; - } - - return null; + return isPokemonValidForEncounterOptionSelection(pokemon, scene, `${namespace}:invalid_selection`); }; return selectPokemonForOption(scene, onPokemonSelected, undefined, selectableFilter); @@ -135,14 +133,14 @@ export const PartTimerEncounter: MysteryEncounter = // Give money and do dialogue if (moneyMultiplier > 2.5) { - await showEncounterDialogue(scene, `${namespace}.job_complete_good`, `${namespace}.speaker`); + await showEncounterDialogue(scene, `${namespace}:job_complete_good`, `${namespace}:speaker`); } else { - await showEncounterDialogue(scene, `${namespace}.job_complete_bad`, `${namespace}.speaker`); + await showEncounterDialogue(scene, `${namespace}:job_complete_bad`, `${namespace}:speaker`); } const moneyChange = scene.getWaveMoneyAmount(moneyMultiplier); updatePlayerMoney(scene, moneyChange, true, false); await showEncounterText(scene, i18next.t("mysteryEncounterMessages:receive_money", { amount: moneyChange })); - await showEncounterText(scene, `${namespace}.pokemon_tired`); + await showEncounterText(scene, `${namespace}:pokemon_tired`); setEncounterRewards(scene, { fillRemaining: true }); leaveEncounterWithoutBattle(scene); @@ -152,11 +150,11 @@ export const PartTimerEncounter: MysteryEncounter = .withOption(MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) .withDialogue({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, selected: [ { - text: `${namespace}.option.2.selected` + text: `${namespace}:option.2.selected` } ] }) @@ -198,11 +196,7 @@ export const PartTimerEncounter: MysteryEncounter = // Only Pokemon non-KOd pokemon can be selected const selectableFilter = (pokemon: Pokemon) => { - if (!pokemon.isAllowedInBattle()) { - return getEncounterText(scene, `${namespace}.invalid_selection`) ?? null; - } - - return null; + return isPokemonValidForEncounterOptionSelection(pokemon, scene, `${namespace}:invalid_selection`); }; return selectPokemonForOption(scene, onPokemonSelected, undefined, selectableFilter); @@ -216,14 +210,14 @@ export const PartTimerEncounter: MysteryEncounter = // Give money and do dialogue if (moneyMultiplier > 2.5) { - await showEncounterDialogue(scene, `${namespace}.job_complete_good`, `${namespace}.speaker`); + await showEncounterDialogue(scene, `${namespace}:job_complete_good`, `${namespace}:speaker`); } else { - await showEncounterDialogue(scene, `${namespace}.job_complete_bad`, `${namespace}.speaker`); + await showEncounterDialogue(scene, `${namespace}:job_complete_bad`, `${namespace}:speaker`); } const moneyChange = scene.getWaveMoneyAmount(moneyMultiplier); updatePlayerMoney(scene, moneyChange, true, false); await showEncounterText(scene, i18next.t("mysteryEncounterMessages:receive_money", { amount: moneyChange })); - await showEncounterText(scene, `${namespace}.pokemon_tired`); + await showEncounterText(scene, `${namespace}:pokemon_tired`); setEncounterRewards(scene, { fillRemaining: true }); leaveEncounterWithoutBattle(scene); @@ -233,14 +227,14 @@ export const PartTimerEncounter: MysteryEncounter = .withOption( MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DISABLED_OR_SPECIAL) - .withPrimaryPokemonRequirement(new MoveRequirement(CHARMING_MOVES)) // Will set option3PrimaryName and option3PrimaryMove dialogue tokens automatically + .withPrimaryPokemonRequirement(new MoveRequirement(CHARMING_MOVES, true)) // Will set option3PrimaryName and option3PrimaryMove dialogue tokens automatically .withDialogue({ - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, - disabledButtonTooltip: `${namespace}.option.3.disabled_tooltip`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, + disabledButtonTooltip: `${namespace}:option.3.disabled_tooltip`, selected: [ { - text: `${namespace}.option.3.selected`, + text: `${namespace}:option.3.selected`, }, ], }) @@ -271,11 +265,11 @@ export const PartTimerEncounter: MysteryEncounter = await transitionMysteryEncounterIntroVisuals(scene, false, false); // Give money and do dialogue - await showEncounterDialogue(scene, `${namespace}.job_complete_good`, `${namespace}.speaker`); + await showEncounterDialogue(scene, `${namespace}:job_complete_good`, `${namespace}:speaker`); const moneyChange = scene.getWaveMoneyAmount(2.5); updatePlayerMoney(scene, moneyChange, true, false); await showEncounterText(scene, i18next.t("mysteryEncounterMessages:receive_money", { amount: moneyChange })); - await showEncounterText(scene, `${namespace}.pokemon_tired`); + await showEncounterText(scene, `${namespace}:pokemon_tired`); setEncounterRewards(scene, { fillRemaining: true }); leaveEncounterWithoutBattle(scene); @@ -284,8 +278,8 @@ export const PartTimerEncounter: MysteryEncounter = ) .withOutroDialogue([ { - speaker: `${namespace}.speaker`, - text: `${namespace}.outro`, + speaker: `${namespace}:speaker`, + text: `${namespace}:outro`, } ]) .build(); diff --git a/src/data/mystery-encounters/encounters/safari-zone-encounter.ts b/src/data/mystery-encounters/encounters/safari-zone-encounter.ts index 49abf98cf49..0353d52a592 100644 --- a/src/data/mystery-encounters/encounters/safari-zone-encounter.ts +++ b/src/data/mystery-encounters/encounters/safari-zone-encounter.ts @@ -1,12 +1,12 @@ import { initSubsequentOptionSelect, leaveEncounterWithoutBattle, transitionMysteryEncounterIntroVisuals, updatePlayerMoney, } from "#app/data/mystery-encounters/utils/encounter-phase-utils"; import { MysteryEncounterType } from "#enums/mystery-encounter-type"; import BattleScene from "#app/battle-scene"; -import MysteryEncounter, { MysteryEncounterBuilder } from "../mystery-encounter"; +import MysteryEncounter, { MysteryEncounterBuilder } from "#app/data/mystery-encounters/mystery-encounter"; import MysteryEncounterOption, { MysteryEncounterOptionBuilder } from "#app/data/mystery-encounters/mystery-encounter-option"; import { TrainerSlot } from "#app/data/trainer-config"; import { HiddenAbilityRateBoosterModifier, IvScannerModifier } from "#app/modifier/modifier"; import { EnemyPokemon } from "#app/field/pokemon"; -import { PokeballType } from "#app/data/pokeball"; +import { PokeballType } from "#enums/pokeball"; import { PlayerGender } from "#enums/player-gender"; import { IntegerHolder, randSeedInt } from "#app/utils"; import { getPokemonSpecies } from "#app/data/pokemon-species"; @@ -21,11 +21,13 @@ import { SummonPhase } from "#app/phases/summon-phase"; import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES } from "#app/game-mode"; /** the i18n namespace for the encounter */ -const namespace = "mysteryEncounter:safariZone"; +const namespace = "mysteryEncounters/safariZone"; -const TRAINER_THROW_ANIMATION_TIMES = [512, 184, 768]; +const TRAINER_THROW_ANIMATION_TIMES = [ 512, 184, 768 ]; -const SAFARI_MONEY_MULTIPLIER = 2.75; +const SAFARI_MONEY_MULTIPLIER = 2; + +const NUM_SAFARI_ENCOUNTERS = 3; /** * Safari Zone encounter. @@ -49,21 +51,26 @@ export const SafariZoneEncounter: MysteryEncounter = ]) .withIntroDialogue([ { - text: `${namespace}.intro`, + text: `${namespace}:intro`, }, ]) - .withTitle(`${namespace}.title`) - .withDescription(`${namespace}.description`) - .withQuery(`${namespace}.query`) + .setLocalizationKey(`${namespace}`) + .withTitle(`${namespace}:title`) + .withDescription(`${namespace}:description`) + .withQuery(`${namespace}:query`) + .withOnInit((scene: BattleScene) => { + scene.currentBattle.mysteryEncounter?.setDialogueToken("numEncounters", NUM_SAFARI_ENCOUNTERS.toString()); + return true; + }) .withOption(MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DISABLED_OR_DEFAULT) .withSceneRequirement(new MoneyRequirement(0, SAFARI_MONEY_MULTIPLIER)) // Cost equal to 1 Max Revive .withDialogue({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.1.selected`, + text: `${namespace}:option.1.selected`, }, ], }) @@ -72,15 +79,15 @@ export const SafariZoneEncounter: MysteryEncounter = const encounter = scene.currentBattle.mysteryEncounter!; encounter.continuousEncounter = true; encounter.misc = { - safariPokemonRemaining: 3 + safariPokemonRemaining: NUM_SAFARI_ENCOUNTERS }; updatePlayerMoney(scene, -(encounter.options[0].requirements[0] as MoneyRequirement).requiredMoney); // Load bait/mud assets scene.loadSe("PRSFX- Bug Bite", "battle_anims", "PRSFX- Bug Bite.wav"); scene.loadSe("PRSFX- Sludge Bomb2", "battle_anims", "PRSFX- Sludge Bomb2.wav"); scene.loadSe("PRSFX- Taunt2", "battle_anims", "PRSFX- Taunt2.wav"); - scene.loadAtlas("bait", "mystery-encounters"); - scene.loadAtlas("mud", "mystery-encounters"); + scene.loadAtlas("safari_zone_bait", "mystery-encounters"); + scene.loadAtlas("safari_zone_mud", "mystery-encounters"); // Clear enemy party scene.currentBattle.enemyParty = []; await transitionMysteryEncounterIntroVisuals(scene); @@ -92,11 +99,11 @@ export const SafariZoneEncounter: MysteryEncounter = ) .withSimpleOption( { - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, selected: [ { - text: `${namespace}.option.2.selected`, + text: `${namespace}:option.2.selected`, }, ], }, @@ -127,11 +134,11 @@ const safariZoneGameOptions: MysteryEncounterOption[] = [ MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) .withDialogue({ - buttonLabel: `${namespace}.safari.1.label`, - buttonTooltip: `${namespace}.safari.1.tooltip`, + buttonLabel: `${namespace}:safari.1.label`, + buttonTooltip: `${namespace}:safari.1.tooltip`, selected: [ { - text: `${namespace}.safari.1.selected`, + text: `${namespace}:safari.1.selected`, } ], }) @@ -162,11 +169,11 @@ const safariZoneGameOptions: MysteryEncounterOption[] = [ MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) .withDialogue({ - buttonLabel: `${namespace}.safari.2.label`, - buttonTooltip: `${namespace}.safari.2.tooltip`, + buttonLabel: `${namespace}:safari.2.label`, + buttonTooltip: `${namespace}:safari.2.tooltip`, selected: [ { - text: `${namespace}.safari.2.selected`, + text: `${namespace}:safari.2.selected`, }, ], }) @@ -180,9 +187,9 @@ const safariZoneGameOptions: MysteryEncounterOption[] = [ // 80% chance to increase flee stage +1 const fleeChangeResult = tryChangeFleeStage(scene, 1, 8); if (!fleeChangeResult) { - await showEncounterText(scene, getEncounterText(scene, `${namespace}.safari.busy_eating`) ?? "", null, 1000, false ); + await showEncounterText(scene, getEncounterText(scene, `${namespace}:safari.busy_eating`) ?? "", null, 1000, false ); } else { - await showEncounterText(scene, getEncounterText(scene, `${namespace}.safari.eating`) ?? "", null, 1000, false); + await showEncounterText(scene, getEncounterText(scene, `${namespace}:safari.eating`) ?? "", null, 1000, false); } await doEndTurn(scene, 1); @@ -192,11 +199,11 @@ const safariZoneGameOptions: MysteryEncounterOption[] = [ MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) .withDialogue({ - buttonLabel: `${namespace}.safari.3.label`, - buttonTooltip: `${namespace}.safari.3.tooltip`, + buttonLabel: `${namespace}:safari.3.label`, + buttonTooltip: `${namespace}:safari.3.tooltip`, selected: [ { - text: `${namespace}.safari.3.selected`, + text: `${namespace}:safari.3.selected`, }, ], }) @@ -209,9 +216,9 @@ const safariZoneGameOptions: MysteryEncounterOption[] = [ // 80% chance to decrease catch stage -1 const catchChangeResult = tryChangeCatchStage(scene, -1, 8); if (!catchChangeResult) { - await showEncounterText(scene, getEncounterText(scene, `${namespace}.safari.beside_itself_angry`) ?? "", null, 1000, false ); + await showEncounterText(scene, getEncounterText(scene, `${namespace}:safari.beside_itself_angry`) ?? "", null, 1000, false ); } else { - await showEncounterText(scene, getEncounterText(scene, `${namespace}.safari.angry`) ?? "", null, 1000, false ); + await showEncounterText(scene, getEncounterText(scene, `${namespace}:safari.angry`) ?? "", null, 1000, false ); } await doEndTurn(scene, 2); @@ -221,8 +228,8 @@ const safariZoneGameOptions: MysteryEncounterOption[] = [ MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) .withDialogue({ - buttonLabel: `${namespace}.safari.4.label`, - buttonTooltip: `${namespace}.safari.4.tooltip`, + buttonLabel: `${namespace}:safari.4.label`, + buttonTooltip: `${namespace}:safari.4.tooltip`, }) .withOptionPhase(async (scene: BattleScene) => { // Flee option @@ -247,14 +254,14 @@ async function summonSafariPokemon(scene: BattleScene) { const encounter = scene.currentBattle.mysteryEncounter!; // Message pokemon remaining encounter.setDialogueToken("remainingCount", encounter.misc.safariPokemonRemaining); - scene.queueMessage(getEncounterText(scene, `${namespace}.safari.remaining_count`) ?? "", null, true); + scene.queueMessage(getEncounterText(scene, `${namespace}:safari.remaining_count`) ?? "", null, true); // Generate pokemon using safariPokemonRemaining so they are always the same pokemon no matter how many turns are taken // Safari pokemon roll twice on shiny and HA chances, but are otherwise normal let enemySpecies; let pokemon; scene.executeWithSeedOffset(() => { - enemySpecies = getPokemonSpecies(getRandomSpeciesByStarterTier([0, 5])); + enemySpecies = getPokemonSpecies(getRandomSpeciesByStarterTier([ 0, 5 ], undefined, undefined, false, false, false)); const level = scene.currentBattle.getLevelForWave(); enemySpecies = getPokemonSpecies(enemySpecies.getWildSpeciesForLevel(level, true, false, scene.gameMode)); pokemon = scene.addEnemyPokemon(enemySpecies, level, TrainerSlot.NONE, false); @@ -282,7 +289,7 @@ async function summonSafariPokemon(scene: BattleScene) { pokemon.calculateStats(); scene.currentBattle.enemyParty.unshift(pokemon); - }, scene.currentBattle.waveIndex * 1000 + encounter.misc.safariPokemonRemaining); + }, scene.currentBattle.waveIndex * 1000 * encounter.misc.safariPokemonRemaining); scene.gameData.setPokemonSeen(pokemon, true); await pokemon.loadAssets(); @@ -296,13 +303,16 @@ async function summonSafariPokemon(scene: BattleScene) { scene.unshiftPhase(new SummonPhase(scene, 0, false)); encounter.setDialogueToken("pokemonName", getPokemonNameWithAffix(pokemon)); - showEncounterText(scene, getEncounterText(scene, "battle:singleWildAppeared") ?? "", null, 1500, false) - .then(() => { - const ivScannerModifier = scene.findModifier(m => m instanceof IvScannerModifier); - if (ivScannerModifier) { - scene.pushPhase(new ScanIvsPhase(scene, pokemon.getBattlerIndex(), Math.min(ivScannerModifier.getStackCount() * 2, 6))); - } - }); + + // TODO: If we await showEncounterText here, then the text will display without + // the wild Pokemon on screen, but if we don't await it, then the text never + // shows up and the IV scanner breaks. For now, we place the IV scanner code + // separately so that at least the IV scanner works. + + const ivScannerModifier = scene.findModifier(m => m instanceof IvScannerModifier); + if (ivScannerModifier) { + scene.pushPhase(new ScanIvsPhase(scene, pokemon.getBattlerIndex(), Math.min(ivScannerModifier.getStackCount() * 2, 6))); + } } function throwPokeball(scene: BattleScene, pokemon: EnemyPokemon): Promise { @@ -322,7 +332,7 @@ async function throwBait(scene: BattleScene, pokemon: EnemyPokemon): Promise { // If pokemon meets primary pokemon reqs, it can be selected - const meetsReqs = encounter.pokemonMeetsPrimaryRequirements(scene, pokemon); - if (!meetsReqs) { - return getEncounterText(scene, `${namespace}.invalid_selection`) ?? null; + if (!pokemon.isAllowedInChallenge()) { + return i18next.t("partyUiHandler:cantBeUsed", { pokemonName: pokemon.getNameToRender() }) ?? null; + } + if (!encounter.pokemonMeetsPrimaryRequirements(scene, pokemon)) { + return getEncounterText(scene, `${namespace}:invalid_selection`) ?? null; } return null; @@ -115,7 +122,7 @@ export const ShadyVitaminDealerEncounter: MysteryEncounter = await applyModifierTypeToPlayerPokemon(scene, chosenPokemon, modType); } - leaveEncounterWithoutBattle(scene); + leaveEncounterWithoutBattle(scene, true); }) .withPostOptionPhase(async (scene: BattleScene) => { // Damage and status applied after dealer leaves (to make thematic sense) @@ -131,24 +138,24 @@ export const ShadyVitaminDealerEncounter: MysteryEncounter = newNature = randSeedInt(25) as Nature; } - chosenPokemon.nature = newNature; + chosenPokemon.setCustomNature(newNature); encounter.setDialogueToken("newNature", getNatureName(newNature)); - queueEncounterMessage(scene, `${namespace}.cheap_side_effects`); - setEncounterExp(scene, [chosenPokemon.id], 100); - chosenPokemon.updateInfo(); + queueEncounterMessage(scene, `${namespace}:cheap_side_effects`); + setEncounterExp(scene, [ chosenPokemon.id ], 100); + await chosenPokemon.updateInfo(); }) .build() ) .withOption( MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DISABLED_OR_DEFAULT) - .withSceneMoneyRequirement(0, 3.5) + .withSceneMoneyRequirement(0, VITAMIN_DEALER_EXPENSIVE_PRICE_MULTIPLIER) .withDialogue({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, selected: [ { - text: `${namespace}.option.selected`, + text: `${namespace}:option.selected`, }, ], }) @@ -172,13 +179,7 @@ export const ShadyVitaminDealerEncounter: MysteryEncounter = // Only Pokemon that can gain benefits are unfainted const selectableFilter = (pokemon: Pokemon) => { - // If pokemon is unfainted it can be selected - const meetsReqs = !pokemon.isFainted(true); - if (!meetsReqs) { - return getEncounterText(scene, `${namespace}.invalid_selection`) ?? null; - } - - return null; + return isPokemonValidForEncounterOptionSelection(pokemon, scene, `${namespace}:invalid_selection`); }; return selectPokemonForOption(scene, onPokemonSelected, undefined, selectableFilter); @@ -193,28 +194,28 @@ export const ShadyVitaminDealerEncounter: MysteryEncounter = await applyModifierTypeToPlayerPokemon(scene, chosenPokemon, modType); } - leaveEncounterWithoutBattle(scene); + leaveEncounterWithoutBattle(scene, true); }) .withPostOptionPhase(async (scene: BattleScene) => { // Status applied after dealer leaves (to make thematic sense) const encounter = scene.currentBattle.mysteryEncounter!; const chosenPokemon = encounter.misc.chosenPokemon; - queueEncounterMessage(scene, `${namespace}.no_bad_effects`); - setEncounterExp(scene, [chosenPokemon.id], 100); + queueEncounterMessage(scene, `${namespace}:no_bad_effects`); + setEncounterExp(scene, [ chosenPokemon.id ], 100); - chosenPokemon.updateInfo(); + await chosenPokemon.updateInfo(); }) .build() ) .withSimpleOption( { - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, selected: [ { - text: `${namespace}.option.3.selected`, - speaker: `${namespace}.speaker` + text: `${namespace}:option.3.selected`, + speaker: `${namespace}:speaker` } ] }, diff --git a/src/data/mystery-encounters/encounters/slumbering-snorlax-encounter.ts b/src/data/mystery-encounters/encounters/slumbering-snorlax-encounter.ts index b9f08b12ffd..3fb502be545 100644 --- a/src/data/mystery-encounters/encounters/slumbering-snorlax-encounter.ts +++ b/src/data/mystery-encounters/encounters/slumbering-snorlax-encounter.ts @@ -1,25 +1,27 @@ import { STEALING_MOVES } from "#app/data/mystery-encounters/requirements/requirement-groups"; -import { modifierTypes } from "#app/modifier/modifier-type"; +import { modifierTypes, PokemonHeldItemModifierType } from "#app/modifier/modifier-type"; import { MysteryEncounterType } from "#enums/mystery-encounter-type"; import { Species } from "#enums/species"; import BattleScene from "#app/battle-scene"; -import { StatusEffect } from "#app/data/status-effect"; -import MysteryEncounter, { MysteryEncounterBuilder } from "../mystery-encounter"; -import { MysteryEncounterOptionBuilder } from "../mystery-encounter-option"; -import { MoveRequirement } from "../mystery-encounter-requirements"; -import { EnemyPartyConfig, EnemyPokemonConfig, initBattleWithEnemyConfig, loadCustomMovesForEncounter, leaveEncounterWithoutBattle, setEncounterExp, setEncounterRewards, } from "../utils/encounter-phase-utils"; +import { StatusEffect } from "#enums/status-effect"; +import MysteryEncounter, { MysteryEncounterBuilder } from "#app/data/mystery-encounters/mystery-encounter"; +import { MysteryEncounterOptionBuilder } from "#app/data/mystery-encounters/mystery-encounter-option"; +import { MoveRequirement } from "#app/data/mystery-encounters/mystery-encounter-requirements"; +import { EnemyPartyConfig, EnemyPokemonConfig, generateModifierType, initBattleWithEnemyConfig, leaveEncounterWithoutBattle, loadCustomMovesForEncounter, setEncounterExp, setEncounterRewards, } from "../utils/encounter-phase-utils"; import { queueEncounterMessage } from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; import { Moves } from "#enums/moves"; import { BattlerIndex } from "#app/battle"; -import { PokemonMove } from "#app/field/pokemon"; +import { AiType, PokemonMove } from "#app/field/pokemon"; import { getPokemonSpecies } from "#app/data/pokemon-species"; import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode"; import { PartyHealPhase } from "#app/phases/party-heal-phase"; import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES } from "#app/game-mode"; +import { BerryType } from "#enums/berry-type"; +import { CustomPokemonData } from "#app/data/custom-pokemon-data"; /** i18n namespace for the encounter */ -const namespace = "mysteryEncounter:slumberingSnorlax"; +const namespace = "mysteryEncounters/slumberingSnorlax"; /** * Sleeping Snorlax encounter. @@ -32,20 +34,21 @@ export const SlumberingSnorlaxEncounter: MysteryEncounter = .withSceneWaveRangeRequirement(...CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES) .withCatchAllowed(true) .withHideWildIntroMessage(true) + .withFleeAllowed(false) .withIntroSpriteConfigs([ { spriteKey: Species.SNORLAX.toString(), fileRoot: "pokemon", hasShadow: true, tint: 0.25, - scale: 1.5, + scale: 1.25, repeat: true, y: 5, }, ]) .withIntroDialogue([ { - text: `${namespace}.intro`, + text: `${namespace}:intro`, }, ]) .withOnInit((scene: BattleScene) => { @@ -57,49 +60,62 @@ export const SlumberingSnorlaxEncounter: MysteryEncounter = const pokemonConfig: EnemyPokemonConfig = { species: bossSpecies, isBoss: true, - status: [StatusEffect.SLEEP, 5], // Extra turns on timer for Snorlax's start of fight moves - moveSet: [Moves.REST, Moves.SLEEP_TALK, Moves.CRUNCH, Moves.GIGA_IMPACT] + status: [ StatusEffect.SLEEP, 5 ], // Extra turns on timer for Snorlax's start of fight moves + moveSet: [ Moves.REST, Moves.SLEEP_TALK, Moves.CRUNCH, Moves.GIGA_IMPACT ], + modifierConfigs: [ + { + modifier: generateModifierType(scene, modifierTypes.BERRY, [ BerryType.SITRUS ]) as PokemonHeldItemModifierType, + stackCount: 2 + }, + { + modifier: generateModifierType(scene, modifierTypes.BERRY, [ BerryType.ENIGMA ]) as PokemonHeldItemModifierType, + stackCount: 2 + }, + ], + customPokemonData: new CustomPokemonData({ spriteScale: 1.25 }), + aiType: AiType.SMART // Required to ensure Snorlax uses Sleep Talk while it is asleep }; const config: EnemyPartyConfig = { - levelAdditiveMultiplier: 0.5, - pokemonConfigs: [pokemonConfig], + levelAdditiveModifier: 0.5, + pokemonConfigs: [ pokemonConfig ], }; - encounter.enemyPartyConfigs = [config]; + encounter.enemyPartyConfigs = [ config ]; // Load animations/sfx for Snorlax fight start moves - loadCustomMovesForEncounter(scene, [Moves.SNORE]); + loadCustomMovesForEncounter(scene, [ Moves.SNORE ]); encounter.setDialogueToken("snorlaxName", getPokemonSpecies(Species.SNORLAX).getName()); return true; }) - .withTitle(`${namespace}.title`) - .withDescription(`${namespace}.description`) - .withQuery(`${namespace}.query`) + .setLocalizationKey(`${namespace}`) + .withTitle(`${namespace}:title`) + .withDescription(`${namespace}:description`) + .withQuery(`${namespace}:query`) .withSimpleOption( { - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.1.selected`, + text: `${namespace}:option.1.selected`, }, ], }, async (scene: BattleScene) => { // Pick battle const encounter = scene.currentBattle.mysteryEncounter!; - setEncounterRewards(scene, { guaranteedModifierTypeFuncs: [modifierTypes.LEFTOVERS], fillRemaining: true}); + setEncounterRewards(scene, { guaranteedModifierTypeFuncs: [ modifierTypes.LEFTOVERS ], fillRemaining: true }); encounter.startOfBattleEffects.push( { sourceBattlerIndex: BattlerIndex.ENEMY, - targets: [BattlerIndex.PLAYER], + targets: [ BattlerIndex.PLAYER ], move: new PokemonMove(Moves.SNORE), ignorePp: true }, { sourceBattlerIndex: BattlerIndex.ENEMY, - targets: [BattlerIndex.PLAYER], + targets: [ BattlerIndex.PLAYER ], move: new PokemonMove(Moves.SNORE), ignorePp: true }); @@ -108,11 +124,11 @@ export const SlumberingSnorlaxEncounter: MysteryEncounter = ) .withSimpleOption( { - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, selected: [ { - text: `${namespace}.option.2.selected`, + text: `${namespace}:option.2.selected`, }, ], }, @@ -120,28 +136,28 @@ export const SlumberingSnorlaxEncounter: MysteryEncounter = // Fall asleep waiting for Snorlax // Full heal party scene.unshiftPhase(new PartyHealPhase(scene, true)); - queueEncounterMessage(scene, `${namespace}.option.2.rest_result`); + queueEncounterMessage(scene, `${namespace}:option.2.rest_result`); leaveEncounterWithoutBattle(scene); } ) .withOption( MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DISABLED_OR_SPECIAL) - .withPrimaryPokemonRequirement(new MoveRequirement(STEALING_MOVES)) + .withPrimaryPokemonRequirement(new MoveRequirement(STEALING_MOVES, true)) .withDialogue({ - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, - disabledButtonTooltip: `${namespace}.option.3.disabled_tooltip`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, + disabledButtonTooltip: `${namespace}:option.3.disabled_tooltip`, selected: [ { - text: `${namespace}.option.3.selected` + text: `${namespace}:option.3.selected` } ] }) .withOptionPhase(async (scene: BattleScene) => { // Steal the Snorlax's Leftovers const instance = scene.currentBattle.mysteryEncounter!; - setEncounterRewards(scene, { guaranteedModifierTypeFuncs: [modifierTypes.LEFTOVERS], fillRemaining: false }); + setEncounterRewards(scene, { guaranteedModifierTypeFuncs: [ modifierTypes.LEFTOVERS ], fillRemaining: false }); // Snorlax exp to Pokemon that did the stealing setEncounterExp(scene, instance.primaryPokemon!.id, getPokemonSpecies(Species.SNORLAX).baseExp); leaveEncounterWithoutBattle(scene); diff --git a/src/data/mystery-encounters/encounters/teleporting-hijinks-encounter.ts b/src/data/mystery-encounters/encounters/teleporting-hijinks-encounter.ts index bf976458fdd..042e9278673 100644 --- a/src/data/mystery-encounters/encounters/teleporting-hijinks-encounter.ts +++ b/src/data/mystery-encounters/encounters/teleporting-hijinks-encounter.ts @@ -2,8 +2,8 @@ import { EnemyPartyConfig, generateModifierTypeOption, initBattleWithEnemyConfig import { randSeedInt } from "#app/utils"; import { MysteryEncounterType } from "#enums/mystery-encounter-type"; import BattleScene from "#app/battle-scene"; -import MysteryEncounter, { MysteryEncounterBuilder } from "../mystery-encounter"; -import { MoneyRequirement, WaveModulusRequirement } from "../mystery-encounter-requirements"; +import MysteryEncounter, { MysteryEncounterBuilder } from "#app/data/mystery-encounters/mystery-encounter"; +import { MoneyRequirement, WaveModulusRequirement } from "#app/data/mystery-encounters/mystery-encounter-requirements"; import Pokemon, { EnemyPokemon } from "#app/field/pokemon"; import { MysteryEncounterOptionBuilder } from "#app/data/mystery-encounters/mystery-encounter-option"; import { queueEncounterMessage, showEncounterText } from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; @@ -12,7 +12,7 @@ import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode"; import { Biome } from "#enums/biome"; import { getBiomeKey } from "#app/field/arena"; -import { Type } from "#app/data/type"; +import { Type } from "#enums/type"; import { getPartyLuckValue, modifierTypes } from "#app/modifier/modifier-type"; import { TrainerSlot } from "#app/data/trainer-config"; import { BattlerTagType } from "#enums/battler-tag-type"; @@ -20,13 +20,14 @@ import { getPokemonNameWithAffix } from "#app/messages"; import { StatStageChangePhase } from "#app/phases/stat-stage-change-phase"; import { Stat } from "#enums/stat"; import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES } from "#app/game-mode"; +import { getEncounterPokemonLevelForWave, STANDARD_ENCOUNTER_BOOSTED_LEVEL_MODIFIER } from "#app/data/mystery-encounters/utils/encounter-pokemon-utils"; /** the i18n namespace for this encounter */ -const namespace = "mysteryEncounter:teleportingHijinks"; +const namespace = "mysteryEncounters/teleportingHijinks"; -const MONEY_COST_MULTIPLIER = 2.5; -const BIOME_CANDIDATES = [Biome.SPACE, Biome.FAIRY_CAVE, Biome.LABORATORY, Biome.ISLAND]; -const MACHINE_INTERFACING_TYPES = [Type.ELECTRIC, Type.STEEL]; +const MONEY_COST_MULTIPLIER = 1.75; +const BIOME_CANDIDATES = [ Biome.SPACE, Biome.FAIRY_CAVE, Biome.LABORATORY, Biome.ISLAND, Biome.WASTELAND, Biome.DOJO ]; +const MACHINE_INTERFACING_TYPES = [ Type.ELECTRIC, Type.STEEL ]; /** * Teleporting Hijinks encounter. @@ -37,13 +38,14 @@ export const TeleportingHijinksEncounter: MysteryEncounter = MysteryEncounterBuilder.withEncounterType(MysteryEncounterType.TELEPORTING_HIJINKS) .withEncounterTier(MysteryEncounterTier.COMMON) .withSceneWaveRangeRequirement(...CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES) - .withSceneRequirement(new WaveModulusRequirement([1, 2, 3], 10)) // Must be in first 3 waves after boss wave - .withSceneRequirement(new MoneyRequirement(undefined, MONEY_COST_MULTIPLIER)) // Must be able to pay teleport cost + .withSceneRequirement(new WaveModulusRequirement([ 1, 2, 3 ], 10)) // Must be in first 3 waves after boss wave + .withSceneRequirement(new MoneyRequirement(0, MONEY_COST_MULTIPLIER)) // Must be able to pay teleport cost .withAutoHideIntroVisuals(false) .withCatchAllowed(true) + .withFleeAllowed(false) .withIntroSpriteConfigs([ { - spriteKey: "teleporter", + spriteKey: "teleporting_hijinks_teleporter", fileRoot: "mystery-encounters", hasShadow: true, x: 4, @@ -53,12 +55,13 @@ export const TeleportingHijinksEncounter: MysteryEncounter = ]) .withIntroDialogue([ { - text: `${namespace}.intro`, + text: `${namespace}:intro`, } ]) - .withTitle(`${namespace}.title`) - .withDescription(`${namespace}.description`) - .withQuery(`${namespace}.query`) + .setLocalizationKey(`${namespace}`) + .withTitle(`${namespace}:title`) + .withDescription(`${namespace}:description`) + .withQuery(`${namespace}:query`) .withOnInit((scene: BattleScene) => { const encounter = scene.currentBattle.mysteryEncounter!; const price = scene.getWaveMoneyAmount(MONEY_COST_MULTIPLIER); @@ -72,13 +75,13 @@ export const TeleportingHijinksEncounter: MysteryEncounter = .withOption( MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DISABLED_OR_DEFAULT) - .withSceneMoneyRequirement(undefined, MONEY_COST_MULTIPLIER) // Must be able to pay teleport cost + .withSceneMoneyRequirement(0, MONEY_COST_MULTIPLIER) // Must be able to pay teleport cost .withDialogue({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.1.selected`, + text: `${namespace}:option.1.selected`, } ], }) @@ -98,12 +101,12 @@ export const TeleportingHijinksEncounter: MysteryEncounter = .newOptionWithMode(MysteryEncounterOptionMode.DISABLED_OR_SPECIAL) .withPokemonTypeRequirement(MACHINE_INTERFACING_TYPES, true, 1) // Must have Steel or Electric type .withDialogue({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, - disabledButtonTooltip: `${namespace}.option.2.disabled_tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, + disabledButtonTooltip: `${namespace}:option.2.disabled_tooltip`, selected: [ { - text: `${namespace}.option.2.selected`, + text: `${namespace}:option.2.selected`, } ], }) @@ -117,11 +120,11 @@ export const TeleportingHijinksEncounter: MysteryEncounter = ) .withSimpleOption( { - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, selected: [ { - text: `${namespace}.option.3.selected`, + text: `${namespace}:option.3.selected`, }, ], }, @@ -130,8 +133,8 @@ export const TeleportingHijinksEncounter: MysteryEncounter = const encounter = scene.currentBattle.mysteryEncounter!; // Init enemy - const level = (scene.currentBattle.enemyLevels?.[0] ?? scene.currentBattle.waveIndex) + Math.max(Math.round((scene.currentBattle.waveIndex / 10)), 0); - const bossSpecies = scene.arena.randomSpecies(scene.currentBattle.waveIndex, level, 0, getPartyLuckValue(scene.getParty()), true); + const level = getEncounterPokemonLevelForWave(scene, STANDARD_ENCOUNTER_BOOSTED_LEVEL_MODIFIER); + const bossSpecies = scene.arena.randomSpecies(scene.currentBattle.waveIndex, level, 0, getPartyLuckValue(scene.getPlayerParty()), true); const bossPokemon = new EnemyPokemon(scene, bossSpecies, level, TrainerSlot.NONE, true); encounter.setDialogueToken("enemyPokemon", getPokemonNameWithAffix(bossPokemon)); const config: EnemyPartyConfig = { @@ -143,10 +146,10 @@ export const TeleportingHijinksEncounter: MysteryEncounter = }], }; - const magnet = generateModifierTypeOption(scene, modifierTypes.ATTACK_TYPE_BOOSTER, [Type.STEEL])!; - const metalCoat = generateModifierTypeOption(scene, modifierTypes.ATTACK_TYPE_BOOSTER, [Type.ELECTRIC])!; - setEncounterRewards(scene, { guaranteedModifierTypeOptions: [magnet, metalCoat], fillRemaining: true }); - transitionMysteryEncounterIntroVisuals(scene, true, true); + const magnet = generateModifierTypeOption(scene, modifierTypes.ATTACK_TYPE_BOOSTER, [ Type.STEEL ])!; + const metalCoat = generateModifierTypeOption(scene, modifierTypes.ATTACK_TYPE_BOOSTER, [ Type.ELECTRIC ])!; + setEncounterRewards(scene, { guaranteedModifierTypeOptions: [ magnet, metalCoat ], fillRemaining: true }); + await transitionMysteryEncounterIntroVisuals(scene, true, true); await initBattleWithEnemyConfig(scene, config); } ) @@ -160,26 +163,32 @@ async function doBiomeTransitionDialogueAndBattleInit(scene: BattleScene) { const newBiome = filteredBiomes[randSeedInt(filteredBiomes.length)]; // Show dialogue and transition biome - await showEncounterText(scene, `${namespace}.transport`); - await Promise.all([animateBiomeChange(scene, newBiome), transitionMysteryEncounterIntroVisuals(scene)]); + await showEncounterText(scene, `${namespace}:transport`); + await Promise.all([ animateBiomeChange(scene, newBiome), transitionMysteryEncounterIntroVisuals(scene) ]); scene.playBgm(); - await showEncounterText(scene, `${namespace}.attacked`); + await showEncounterText(scene, `${namespace}:attacked`); // Init enemy - const level = (scene.currentBattle.enemyLevels?.[0] ?? scene.currentBattle.waveIndex) + Math.max(Math.round((scene.currentBattle.waveIndex / 10)), 0); - const bossSpecies = scene.arena.randomSpecies(scene.currentBattle.waveIndex, level, 0, getPartyLuckValue(scene.getParty()), true); + const level = getEncounterPokemonLevelForWave(scene, STANDARD_ENCOUNTER_BOOSTED_LEVEL_MODIFIER); + const bossSpecies = scene.arena.randomSpecies(scene.currentBattle.waveIndex, level, 0, getPartyLuckValue(scene.getPlayerParty()), true); const bossPokemon = new EnemyPokemon(scene, bossSpecies, level, TrainerSlot.NONE, true); encounter.setDialogueToken("enemyPokemon", getPokemonNameWithAffix(bossPokemon)); + + // Defense/Spd buffs below wave 50, +1 to all stats otherwise + const statChangesForBattle: (Stat.ATK | Stat.DEF | Stat.SPATK | Stat.SPDEF | Stat.SPD | Stat.ACC | Stat.EVA)[] = scene.currentBattle.waveIndex < 50 ? + [ Stat.DEF, Stat.SPDEF, Stat.SPD ] : + [ Stat.ATK, Stat.DEF, Stat.SPATK, Stat.SPDEF, Stat.SPD ]; + const config: EnemyPartyConfig = { pokemonConfigs: [{ level: level, species: bossSpecies, dataSource: new PokemonData(bossPokemon), isBoss: true, - tags: [BattlerTagType.MYSTERY_ENCOUNTER_POST_SUMMON], + tags: [ BattlerTagType.MYSTERY_ENCOUNTER_POST_SUMMON ], mysteryEncounterBattleEffects: (pokemon: Pokemon) => { - queueEncounterMessage(pokemon.scene, `${namespace}.boss_enraged`); - pokemon.scene.unshiftPhase(new StatStageChangePhase(pokemon.scene, pokemon.getBattlerIndex(), true, [Stat.ATK, Stat.DEF, Stat.SPATK, Stat.SPDEF, Stat.SPD], 1)); + queueEncounterMessage(pokemon.scene, `${namespace}:boss_enraged`); + pokemon.scene.unshiftPhase(new StatStageChangePhase(pokemon.scene, pokemon.getBattlerIndex(), true, statChangesForBattle, 1)); } }], }; @@ -190,7 +199,7 @@ async function doBiomeTransitionDialogueAndBattleInit(scene: BattleScene) { async function animateBiomeChange(scene: BattleScene, nextBiome: Biome) { return new Promise(resolve => { scene.tweens.add({ - targets: [scene.arenaEnemy, scene.lastEnemyTrainer], + targets: [ scene.arenaEnemy, scene.lastEnemyTrainer ], x: "+=300", duration: 2000, onComplete: () => { @@ -206,7 +215,7 @@ async function animateBiomeChange(scene: BattleScene, nextBiome: Biome) { scene.arenaPlayerTransition.setVisible(true); scene.tweens.add({ - targets: [scene.arenaPlayer, scene.arenaBgTransition, scene.arenaPlayerTransition], + targets: [ scene.arenaPlayer, scene.arenaBgTransition, scene.arenaPlayerTransition ], duration: 1000, ease: "Sine.easeInOut", alpha: (target: any) => target === scene.arenaPlayer ? 0 : 1, diff --git a/src/data/mystery-encounters/encounters/the-expert-pokemon-breeder-encounter.ts b/src/data/mystery-encounters/encounters/the-expert-pokemon-breeder-encounter.ts new file mode 100644 index 00000000000..6a4c6592fda --- /dev/null +++ b/src/data/mystery-encounters/encounters/the-expert-pokemon-breeder-encounter.ts @@ -0,0 +1,626 @@ +import { EnemyPartyConfig, generateModifierType, handleMysteryEncounterBattleFailed, initBattleWithEnemyConfig, setEncounterRewards, } from "#app/data/mystery-encounters/utils/encounter-phase-utils"; +import { trainerConfigs } from "#app/data/trainer-config"; +import { MysteryEncounterType } from "#enums/mystery-encounter-type"; +import BattleScene from "#app/battle-scene"; +import { randSeedShuffle } from "#app/utils"; +import MysteryEncounter, { MysteryEncounterBuilder } from "../mystery-encounter"; +import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; +import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES } from "#app/game-mode"; +import { Biome } from "#enums/biome"; +import { TrainerType } from "#enums/trainer-type"; +import i18next from "i18next"; +import { Species } from "#enums/species"; +import { getPokemonSpecies } from "#app/data/pokemon-species"; +import { speciesStarterCosts } from "#app/data/balance/starters"; +import { Nature } from "#enums/nature"; +import { Moves } from "#enums/moves"; +import { PlayerPokemon } from "#app/field/pokemon"; +import { getEncounterText } from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; +import { IEggOptions } from "#app/data/egg"; +import { EggSourceType } from "#enums/egg-source-types"; +import { EggTier } from "#enums/egg-type"; +import { MysteryEncounterOptionBuilder } from "#app/data/mystery-encounters/mystery-encounter-option"; +import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode"; +import { achvs } from "#app/system/achv"; +import { modifierTypes, PokemonHeldItemModifierType } from "#app/modifier/modifier-type"; +import { Type } from "#enums/type"; +import { getPokeballTintColor } from "#app/data/pokeball"; +import { PokemonHeldItemModifier } from "#app/modifier/modifier"; + +/** the i18n namespace for the encounter */ +const namespace = "mysteryEncounters/theExpertPokemonBreeder"; + +const trainerNameKey = "trainerNames:expert_pokemon_breeder"; + +const FIRST_STAGE_EVOLUTION_WAVE = 45; +const SECOND_STAGE_EVOLUTION_WAVE = 60; +const FINAL_STAGE_EVOLUTION_WAVE = 75; + +const FRIENDSHIP_ADDED = 20; + +class BreederSpeciesEvolution { + species: Species; + evolution: number; + + constructor(species: Species, evolution: number) { + this.species = species; + this.evolution = evolution; + } +} + +const POOL_1_POKEMON: (Species | BreederSpeciesEvolution)[][] = [ + [ Species.MUNCHLAX, new BreederSpeciesEvolution(Species.SNORLAX, SECOND_STAGE_EVOLUTION_WAVE) ], + [ Species.HAPPINY, new BreederSpeciesEvolution(Species.CHANSEY, FIRST_STAGE_EVOLUTION_WAVE), new BreederSpeciesEvolution(Species.BLISSEY, FINAL_STAGE_EVOLUTION_WAVE) ], + [ Species.MAGBY, new BreederSpeciesEvolution(Species.MAGMAR, FIRST_STAGE_EVOLUTION_WAVE), new BreederSpeciesEvolution(Species.MAGMORTAR, FINAL_STAGE_EVOLUTION_WAVE) ], + [ Species.ELEKID, new BreederSpeciesEvolution(Species.ELECTABUZZ, FIRST_STAGE_EVOLUTION_WAVE), new BreederSpeciesEvolution(Species.ELECTIVIRE, FINAL_STAGE_EVOLUTION_WAVE) ], + [ Species.RIOLU, new BreederSpeciesEvolution(Species.LUCARIO, SECOND_STAGE_EVOLUTION_WAVE) ], + [ Species.BUDEW, new BreederSpeciesEvolution(Species.ROSELIA, FIRST_STAGE_EVOLUTION_WAVE), new BreederSpeciesEvolution(Species.ROSERADE, FINAL_STAGE_EVOLUTION_WAVE) ], + [ Species.TOXEL, new BreederSpeciesEvolution(Species.TOXTRICITY, SECOND_STAGE_EVOLUTION_WAVE) ], + [ Species.MIME_JR, new BreederSpeciesEvolution(Species.GALAR_MR_MIME, FIRST_STAGE_EVOLUTION_WAVE), new BreederSpeciesEvolution(Species.MR_RIME, FINAL_STAGE_EVOLUTION_WAVE) ] +]; + +const POOL_2_POKEMON: (Species | BreederSpeciesEvolution)[][] = [ + [ Species.PICHU, new BreederSpeciesEvolution(Species.PIKACHU, FIRST_STAGE_EVOLUTION_WAVE), new BreederSpeciesEvolution(Species.RAICHU, FINAL_STAGE_EVOLUTION_WAVE) ], + [ Species.PICHU, new BreederSpeciesEvolution(Species.PIKACHU, FIRST_STAGE_EVOLUTION_WAVE), new BreederSpeciesEvolution(Species.ALOLA_RAICHU, FINAL_STAGE_EVOLUTION_WAVE) ], + [ Species.SMOOCHUM, new BreederSpeciesEvolution(Species.JYNX, SECOND_STAGE_EVOLUTION_WAVE) ], + [ Species.TYROGUE, new BreederSpeciesEvolution(Species.HITMONLEE, SECOND_STAGE_EVOLUTION_WAVE) ], + [ Species.TYROGUE, new BreederSpeciesEvolution(Species.HITMONCHAN, SECOND_STAGE_EVOLUTION_WAVE) ], + [ Species.TYROGUE, new BreederSpeciesEvolution(Species.HITMONTOP, SECOND_STAGE_EVOLUTION_WAVE) ], + [ Species.IGGLYBUFF, new BreederSpeciesEvolution(Species.JIGGLYPUFF, FIRST_STAGE_EVOLUTION_WAVE), new BreederSpeciesEvolution(Species.WIGGLYTUFF, FINAL_STAGE_EVOLUTION_WAVE) ], + [ Species.AZURILL, new BreederSpeciesEvolution(Species.MARILL, FIRST_STAGE_EVOLUTION_WAVE), new BreederSpeciesEvolution(Species.AZUMARILL, FINAL_STAGE_EVOLUTION_WAVE) ], + [ Species.WYNAUT, new BreederSpeciesEvolution(Species.WOBBUFFET, SECOND_STAGE_EVOLUTION_WAVE) ], + [ Species.CHINGLING, new BreederSpeciesEvolution(Species.CHIMECHO, SECOND_STAGE_EVOLUTION_WAVE) ], + [ Species.BONSLY, new BreederSpeciesEvolution(Species.SUDOWOODO, SECOND_STAGE_EVOLUTION_WAVE) ], + [ Species.MANTYKE, new BreederSpeciesEvolution(Species.MANTINE, SECOND_STAGE_EVOLUTION_WAVE) ] +]; + +/** + * The Expert Pokémon Breeder encounter. + * @see {@link https://github.com/pagefaultgames/pokerogue/issues/3818 | GitHub Issue #3818} + * @see For biome requirements check {@linkcode mysteryEncountersByBiome} + */ +export const TheExpertPokemonBreederEncounter: MysteryEncounter = + MysteryEncounterBuilder.withEncounterType(MysteryEncounterType.THE_EXPERT_POKEMON_BREEDER) + .withEncounterTier(MysteryEncounterTier.ULTRA) + .withSceneWaveRangeRequirement(...CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES) + .withScenePartySizeRequirement(4, 6, true) // Must have at least 4 legal pokemon in party + .withIntroSpriteConfigs([]) // These are set in onInit() + .withIntroDialogue([ + { + text: `${namespace}:intro`, + }, + { + speaker: trainerNameKey, + text: `${namespace}:intro_dialogue`, + }, + ]) + .withOnInit((scene: BattleScene) => { + const encounter = scene.currentBattle.mysteryEncounter!; + const waveIndex = scene.currentBattle.waveIndex; + // Calculates what trainers are available for battle in the encounter + + // If player is in space biome, uses special "Space" version of the trainer + encounter.enemyPartyConfigs = [ + getPartyConfig(scene) + ]; + + const cleffaSpecies = waveIndex < FIRST_STAGE_EVOLUTION_WAVE ? Species.CLEFFA : waveIndex < FINAL_STAGE_EVOLUTION_WAVE ? Species.CLEFAIRY : Species.CLEFABLE; + encounter.spriteConfigs = [ + { + spriteKey: cleffaSpecies.toString(), + fileRoot: "pokemon", + hasShadow: true, + repeat: true, + x: 14, + y: -2, + yShadow: -2 + }, + { + spriteKey: "expert_pokemon_breeder", + fileRoot: "trainer", + hasShadow: true, + x: -14, + y: 4, + yShadow: 2 + }, + ]; + + // Determine the 3 pokemon the player can battle with + let partyCopy = scene.getPlayerParty().slice(0); + partyCopy = partyCopy + .filter(p => p.isAllowedInBattle()) + .sort((a, b) => a.friendship - b.friendship); + + const pokemon1 = partyCopy[0]; + const pokemon2 = partyCopy[1]; + const pokemon3 = partyCopy[2]; + encounter.setDialogueToken("pokemon1Name", pokemon1.getNameToRender()); + encounter.setDialogueToken("pokemon2Name", pokemon2.getNameToRender()); + encounter.setDialogueToken("pokemon3Name", pokemon3.getNameToRender()); + + // Dialogue and egg calcs for Pokemon 1 + const [ pokemon1CommonEggs, pokemon1RareEggs ] = calculateEggRewardsForPokemon(pokemon1); + let pokemon1Tooltip = getEncounterText(scene, `${namespace}:option.1.tooltip_base`)!; + if (pokemon1RareEggs > 0) { + const eggsText = i18next.t(`${namespace}:numEggs`, { count: pokemon1RareEggs, rarity: i18next.t("egg:greatTier") }); + pokemon1Tooltip += i18next.t(`${namespace}:eggs_tooltip`, { eggs: eggsText }); + encounter.setDialogueToken("pokemon1RareEggs", eggsText); + } + if (pokemon1CommonEggs > 0) { + const eggsText = i18next.t(`${namespace}:numEggs`, { count: pokemon1CommonEggs, rarity: i18next.t("egg:defaultTier") }); + pokemon1Tooltip += i18next.t(`${namespace}:eggs_tooltip`, { eggs: eggsText }); + encounter.setDialogueToken("pokemon1CommonEggs", eggsText); + } + encounter.options[0].dialogue!.buttonTooltip = pokemon1Tooltip; + + // Dialogue and egg calcs for Pokemon 2 + const [ pokemon2CommonEggs, pokemon2RareEggs ] = calculateEggRewardsForPokemon(pokemon2); + let pokemon2Tooltip = getEncounterText(scene, `${namespace}:option.2.tooltip_base`)!; + if (pokemon2RareEggs > 0) { + const eggsText = i18next.t(`${namespace}:numEggs`, { count: pokemon2RareEggs, rarity: i18next.t("egg:greatTier") }); + pokemon2Tooltip += i18next.t(`${namespace}:eggs_tooltip`, { eggs: eggsText }); + encounter.setDialogueToken("pokemon2RareEggs", eggsText); + } + if (pokemon2CommonEggs > 0) { + const eggsText = i18next.t(`${namespace}:numEggs`, { count: pokemon2CommonEggs, rarity: i18next.t("egg:defaultTier") }); + pokemon2Tooltip += i18next.t(`${namespace}:eggs_tooltip`, { eggs: eggsText }); + encounter.setDialogueToken("pokemon2CommonEggs", eggsText); + } + encounter.options[1].dialogue!.buttonTooltip = pokemon2Tooltip; + + // Dialogue and egg calcs for Pokemon 3 + const [ pokemon3CommonEggs, pokemon3RareEggs ] = calculateEggRewardsForPokemon(pokemon3); + let pokemon3Tooltip = getEncounterText(scene, `${namespace}:option.3.tooltip_base`)!; + if (pokemon3RareEggs > 0) { + const eggsText = i18next.t(`${namespace}:numEggs`, { count: pokemon3RareEggs, rarity: i18next.t("egg:greatTier") }); + pokemon3Tooltip += i18next.t(`${namespace}:eggs_tooltip`, { eggs: eggsText }); + encounter.setDialogueToken("pokemon3RareEggs", eggsText); + } + if (pokemon3CommonEggs > 0) { + const eggsText = i18next.t(`${namespace}:numEggs`, { count: pokemon3CommonEggs, rarity: i18next.t("egg:defaultTier") }); + pokemon3Tooltip += i18next.t(`${namespace}:eggs_tooltip`, { eggs: eggsText }); + encounter.setDialogueToken("pokemon3CommonEggs", eggsText); + } + encounter.options[2].dialogue!.buttonTooltip = pokemon3Tooltip; + + encounter.misc = { + pokemon1, + pokemon1CommonEggs, + pokemon1RareEggs, + pokemon2, + pokemon2CommonEggs, + pokemon2RareEggs, + pokemon3, + pokemon3CommonEggs, + pokemon3RareEggs + }; + + return true; + }) + .setLocalizationKey(`${namespace}`) + .withTitle(`${namespace}:title`) + .withDescription(`${namespace}:description`) + .withQuery(`${namespace}:query`) + .withOption( + MysteryEncounterOptionBuilder + .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) + .withDialogue({ + buttonLabel: `${namespace}:option.1.label`, + selected: [ + { + speaker: trainerNameKey, + text: `${namespace}:option.selected`, + }, + ], + }) + .withOptionPhase(async (scene: BattleScene) => { + const encounter = scene.currentBattle.mysteryEncounter!; + // Spawn battle with first pokemon + const config: EnemyPartyConfig = encounter.enemyPartyConfigs[0]; + + const { pokemon1, pokemon1CommonEggs, pokemon1RareEggs } = encounter.misc; + encounter.misc.chosenPokemon = pokemon1; + encounter.setDialogueToken("chosenPokemon", pokemon1.getNameToRender()); + const eggOptions = getEggOptions(scene, pokemon1CommonEggs, pokemon1RareEggs); + setEncounterRewards(scene, + { guaranteedModifierTypeFuncs: [ modifierTypes.SOOTHE_BELL ], fillRemaining: true }, + eggOptions, + () => doPostEncounterCleanup(scene)); + + // Remove all Pokemon from the party except the chosen Pokemon + removePokemonFromPartyAndStoreHeldItems(scene, encounter, pokemon1); + + // Configure outro dialogue for egg rewards + encounter.dialogue.outro = [ + { + speaker: trainerNameKey, + text: `${namespace}:outro`, + }, + ]; + if (encounter.dialogueTokens.hasOwnProperty("pokemon1CommonEggs")) { + encounter.dialogue.outro.push({ + text: i18next.t(`${namespace}:gained_eggs`, { numEggs: encounter.dialogueTokens["pokemon1CommonEggs"] }), + }); + } + if (encounter.dialogueTokens.hasOwnProperty("pokemon1RareEggs")) { + encounter.dialogue.outro.push({ + text: i18next.t(`${namespace}:gained_eggs`, { numEggs: encounter.dialogueTokens["pokemon1RareEggs"] }), + }); + } + + encounter.onGameOver = onGameOver; + await initBattleWithEnemyConfig(scene, config); + }) + .build() + ) + .withOption( + MysteryEncounterOptionBuilder + .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) + .withDialogue({ + buttonLabel: `${namespace}:option.2.label`, + selected: [ + { + speaker: trainerNameKey, + text: `${namespace}:option.selected`, + }, + ], + }) + .withOptionPhase(async (scene: BattleScene) => { + const encounter = scene.currentBattle.mysteryEncounter!; + // Spawn battle with second pokemon + const config: EnemyPartyConfig = encounter.enemyPartyConfigs[0]; + + const { pokemon2, pokemon2CommonEggs, pokemon2RareEggs } = encounter.misc; + encounter.misc.chosenPokemon = pokemon2; + encounter.setDialogueToken("chosenPokemon", pokemon2.getNameToRender()); + const eggOptions = getEggOptions(scene, pokemon2CommonEggs, pokemon2RareEggs); + setEncounterRewards(scene, + { guaranteedModifierTypeFuncs: [ modifierTypes.SOOTHE_BELL ], fillRemaining: true }, + eggOptions, + () => doPostEncounterCleanup(scene)); + + // Remove all Pokemon from the party except the chosen Pokemon + removePokemonFromPartyAndStoreHeldItems(scene, encounter, pokemon2); + + // Configure outro dialogue for egg rewards + encounter.dialogue.outro = [ + { + speaker: trainerNameKey, + text: `${namespace}:outro`, + }, + ]; + if (encounter.dialogueTokens.hasOwnProperty("pokemon2CommonEggs")) { + encounter.dialogue.outro.push({ + text: i18next.t(`${namespace}:gained_eggs`, { numEggs: encounter.dialogueTokens["pokemon2CommonEggs"] }), + }); + } + if (encounter.dialogueTokens.hasOwnProperty("pokemon2RareEggs")) { + encounter.dialogue.outro.push({ + text: i18next.t(`${namespace}:gained_eggs`, { numEggs: encounter.dialogueTokens["pokemon2RareEggs"] }), + }); + } + + encounter.onGameOver = onGameOver; + await initBattleWithEnemyConfig(scene, config); + }) + .build() + ) + .withOption( + MysteryEncounterOptionBuilder + .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) + .withDialogue({ + buttonLabel: `${namespace}:option.3.label`, + selected: [ + { + speaker: trainerNameKey, + text: `${namespace}:option.selected`, + }, + ], + }) + .withOptionPhase(async (scene: BattleScene) => { + const encounter = scene.currentBattle.mysteryEncounter!; + // Spawn battle with third pokemon + const config: EnemyPartyConfig = encounter.enemyPartyConfigs[0]; + + const { pokemon3, pokemon3CommonEggs, pokemon3RareEggs } = encounter.misc; + encounter.misc.chosenPokemon = pokemon3; + encounter.setDialogueToken("chosenPokemon", pokemon3.getNameToRender()); + const eggOptions = getEggOptions(scene, pokemon3CommonEggs, pokemon3RareEggs); + setEncounterRewards(scene, + { guaranteedModifierTypeFuncs: [ modifierTypes.SOOTHE_BELL ], fillRemaining: true }, + eggOptions, + () => doPostEncounterCleanup(scene)); + + // Remove all Pokemon from the party except the chosen Pokemon + removePokemonFromPartyAndStoreHeldItems(scene, encounter, pokemon3); + + // Configure outro dialogue for egg rewards + encounter.dialogue.outro = [ + { + speaker: trainerNameKey, + text: `${namespace}:outro`, + }, + ]; + if (encounter.dialogueTokens.hasOwnProperty("pokemon3CommonEggs")) { + encounter.dialogue.outro.push({ + text: i18next.t(`${namespace}:gained_eggs`, { numEggs: encounter.dialogueTokens["pokemon3CommonEggs"] }), + }); + } + if (encounter.dialogueTokens.hasOwnProperty("pokemon3RareEggs")) { + encounter.dialogue.outro.push({ + text: i18next.t(`${namespace}:gained_eggs`, { numEggs: encounter.dialogueTokens["pokemon3RareEggs"] }), + }); + } + + encounter.onGameOver = onGameOver; + await initBattleWithEnemyConfig(scene, config); + }) + .build() + ) + .withOutroDialogue([ + { + speaker: trainerNameKey, + text: `${namespace}:outro`, + }, + ]) + .build(); + +function getPartyConfig(scene: BattleScene): EnemyPartyConfig { + // Bug type superfan trainer config + const waveIndex = scene.currentBattle.waveIndex; + const breederConfig = trainerConfigs[TrainerType.EXPERT_POKEMON_BREEDER].clone(); + breederConfig.name = i18next.t(trainerNameKey); + + // First mon is *always* this special cleffa + const cleffaSpecies = waveIndex < FIRST_STAGE_EVOLUTION_WAVE ? Species.CLEFFA : waveIndex < FINAL_STAGE_EVOLUTION_WAVE ? Species.CLEFAIRY : Species.CLEFABLE; + const baseConfig: EnemyPartyConfig = { + trainerType: TrainerType.EXPERT_POKEMON_BREEDER, + pokemonConfigs: [ + { + nickname: i18next.t(`${namespace}:cleffa_1_nickname`, { speciesName: getPokemonSpecies(cleffaSpecies).getName() }), + species: getPokemonSpecies(cleffaSpecies), + isBoss: false, + abilityIndex: 1, // Magic Guard + shiny: false, + nature: Nature.ADAMANT, + moveSet: [ Moves.METEOR_MASH, Moves.FIRE_PUNCH, Moves.ICE_PUNCH, Moves.THUNDER_PUNCH ], + ivs: [ 31, 31, 31, 31, 31, 31 ], + modifierConfigs: [ + { + modifier: generateModifierType(scene, modifierTypes.TERA_SHARD, [ Type.STEEL ]) as PokemonHeldItemModifierType, + } + ] + } + ] + }; + + if (scene.arena.biomeType === Biome.SPACE) { + // All 3 members always Cleffa line, but different configs + baseConfig.pokemonConfigs!.push({ + nickname: i18next.t(`${namespace}:cleffa_2_nickname`, { speciesName: getPokemonSpecies(cleffaSpecies).getName() }), + species: getPokemonSpecies(cleffaSpecies), + isBoss: false, + abilityIndex: 1, // Magic Guard + shiny: true, + variant: 1, + nature: Nature.MODEST, + moveSet: [ Moves.MOONBLAST, Moves.MYSTICAL_FIRE, Moves.ICE_BEAM, Moves.THUNDERBOLT ], + ivs: [ 31, 31, 31, 31, 31, 31 ] + }, + { + nickname: i18next.t(`${namespace}:cleffa_3_nickname`, { speciesName: getPokemonSpecies(cleffaSpecies).getName() }), + species: getPokemonSpecies(cleffaSpecies), + isBoss: false, + abilityIndex: 2, // Friend Guard / Unaware + shiny: true, + variant: 2, + nature: Nature.BOLD, + moveSet: [ Moves.TRI_ATTACK, Moves.STORED_POWER, Moves.TAKE_HEART, Moves.MOONLIGHT ], + ivs: [ 31, 31, 31, 31, 31, 31 ] + }); + } else { + // Second member from pool 1 + const pool1Species = getSpeciesFromPool(POOL_1_POKEMON, waveIndex); + // Third member from pool 2 + const pool2Species = getSpeciesFromPool(POOL_2_POKEMON, waveIndex); + + baseConfig.pokemonConfigs!.push({ + species: getPokemonSpecies(pool1Species), + isBoss: false, + ivs: [ 31, 31, 31, 31, 31, 31 ] + }, + { + species: getPokemonSpecies(pool2Species), + isBoss: false, + ivs: [ 31, 31, 31, 31, 31, 31 ] + }); + } + + return baseConfig; +} + +function getSpeciesFromPool(speciesPool: (Species | BreederSpeciesEvolution)[][], waveIndex: number): Species { + const poolCopy = randSeedShuffle(speciesPool.slice(0)); + const speciesEvolutions = poolCopy.pop()!.slice(0); + let speciesObject = speciesEvolutions.pop()!; + while (speciesObject instanceof BreederSpeciesEvolution && speciesObject.evolution > waveIndex) { + speciesObject = speciesEvolutions.pop()!; + } + return speciesObject instanceof BreederSpeciesEvolution ? speciesObject.species : speciesObject; +} + +function calculateEggRewardsForPokemon(pokemon: PlayerPokemon): [number, number] { + const bst = pokemon.calculateBaseStats().reduce((a, b) => a + b, 0); + // 1 point for every 20 points below 680 BST the pokemon is, (max 18, min 1) + const pointsFromBst = Math.min(Math.max(Math.floor((680 - bst) / 20), 1), 18); + + const rootSpecies = pokemon.species.getRootSpeciesId(); + let pointsFromStarterTier = 0; + // 2 points for every 1 below 7 that the pokemon's starter tier is (max 12, min 0) + if (speciesStarterCosts.hasOwnProperty(rootSpecies)) { + const starterTier = speciesStarterCosts[rootSpecies]; + pointsFromStarterTier = Math.min(Math.max(Math.floor(7 - starterTier) * 2, 0), 12); + } + + // Maximum of 30 points + let totalPoints = Math.min(pointsFromStarterTier + pointsFromBst, 30); + + // First 5 points go to Common eggs + let numCommons = Math.min(totalPoints, 5); + totalPoints -= numCommons; + + // Then, 1 Rare egg for every 4 points + const numRares = Math.floor(totalPoints / 4); + // 1 Common egg for every point leftover + numCommons += totalPoints % 4; + + return [ numCommons, numRares ]; +} + +function getEggOptions(scene: BattleScene, commonEggs: number, rareEggs: number) { + const eggDescription = i18next.t(`${namespace}:title`) + ":\n" + i18next.t(trainerNameKey); + const eggOptions: IEggOptions[] = []; + + if (commonEggs > 0) { + for (let i = 0; i < commonEggs; i++) { + eggOptions.push({ + scene, + pulled: false, + sourceType: EggSourceType.EVENT, + eggDescriptor: eggDescription, + tier: EggTier.COMMON + }); + } + } + if (rareEggs > 0) { + for (let i = 0; i < rareEggs; i++) { + eggOptions.push({ + scene, + pulled: false, + sourceType: EggSourceType.EVENT, + eggDescriptor: eggDescription, + tier: EggTier.RARE + }); + } + } + + return eggOptions; +} + +function removePokemonFromPartyAndStoreHeldItems(scene: BattleScene, encounter: MysteryEncounter, chosenPokemon: PlayerPokemon) { + const party = scene.getPlayerParty(); + const chosenIndex = party.indexOf(chosenPokemon); + party[chosenIndex] = party[0]; + party[0] = chosenPokemon; + encounter.misc.originalParty = scene.getPlayerParty().slice(1); + encounter.misc.originalPartyHeldItems = encounter.misc.originalParty + .map(p => p.getHeldItems()); + scene["party"] = [ + chosenPokemon + ]; +} + +function checkAchievement(scene: BattleScene) { + if (scene.arena.biomeType === Biome.SPACE) { + scene.validateAchv(achvs.BREEDERS_IN_SPACE); + } +} + +function restorePartyAndHeldItems(scene: BattleScene) { + const encounter = scene.currentBattle.mysteryEncounter!; + // Restore original party + scene.getPlayerParty().push(...encounter.misc.originalParty); + + // Restore held items + const originalHeldItems = encounter.misc.originalPartyHeldItems; + originalHeldItems.forEach((pokemonHeldItemsList: PokemonHeldItemModifier[]) => { + pokemonHeldItemsList.forEach(heldItem => { + scene.addModifier(heldItem, true, false, false, true); + }); + }); + scene.updateModifiers(true); +} + +function onGameOver(scene: BattleScene) { + const encounter = scene.currentBattle.mysteryEncounter!; + + encounter.dialogue.outro = [ + { + speaker: trainerNameKey, + text: `${namespace}:outro_failed`, + }, + ]; + + // Restore original party, player loses all friendship with chosen mon (it remains fainted) + restorePartyAndHeldItems(scene); + const chosenPokemon = encounter.misc.chosenPokemon; + chosenPokemon.friendship = 0; + + // Clear all rewards that would have been earned + encounter.doEncounterRewards = undefined; + + // Set flag that encounter was failed + encounter.misc.encounterFailed = true; + + // Revert BGM + scene.playBgm(scene.arena.bgm); + + // Clear any leftover battle phases + scene.clearPhaseQueue(); + scene.clearPhaseQueueSplice(); + + // Return enemy Pokemon + const pokemon = scene.getEnemyPokemon(); + if (pokemon) { + scene.playSound("se/pb_rel"); + pokemon.hideInfo(); + pokemon.tint(getPokeballTintColor(pokemon.pokeball), 1, 250, "Sine.easeIn"); + scene.tweens.add({ + targets: pokemon, + duration: 250, + ease: "Sine.easeIn", + scale: 0.5, + onComplete: () => { + scene.field.remove(pokemon, true); + } + }); + } + + // Show the enemy trainer + scene.time.delayedCall(250, () => { + const sprites = scene.currentBattle.trainer?.getSprites(); + const tintSprites = scene.currentBattle.trainer?.getTintSprites(); + if (sprites && tintSprites) { + for (let i = 0; i < sprites.length; i++) { + sprites[i].setVisible(true); + tintSprites[i].setVisible(true); + sprites[i].clearTint(); + tintSprites[i].clearTint(); + } + } + scene.tweens.add({ + targets: scene.currentBattle.trainer, + x: "-=16", + y: "+=16", + alpha: 1, + ease: "Sine.easeInOut", + duration: 750 + }); + }); + + + handleMysteryEncounterBattleFailed(scene, true); + + return false; +} + +function doPostEncounterCleanup(scene: BattleScene) { + const encounter = scene.currentBattle.mysteryEncounter!; + if (!encounter.misc.encounterFailed) { + // Give achievement if in Space biome + checkAchievement(scene); + // Give 20 friendship to the chosen pokemon + encounter.misc.chosenPokemon.addFriendship(FRIENDSHIP_ADDED); + restorePartyAndHeldItems(scene); + } +} diff --git a/src/data/mystery-encounters/encounters/the-pokemon-salesman-encounter.ts b/src/data/mystery-encounters/encounters/the-pokemon-salesman-encounter.ts index 16b0c421bd4..77d92e3749e 100644 --- a/src/data/mystery-encounters/encounters/the-pokemon-salesman-encounter.ts +++ b/src/data/mystery-encounters/encounters/the-pokemon-salesman-encounter.ts @@ -2,12 +2,13 @@ import { leaveEncounterWithoutBattle, transitionMysteryEncounterIntroVisuals, up import { isNullOrUndefined, randSeedInt } from "#app/utils"; import { MysteryEncounterType } from "#enums/mystery-encounter-type"; import BattleScene from "#app/battle-scene"; -import MysteryEncounter, { MysteryEncounterBuilder } from "../mystery-encounter"; -import { MoneyRequirement } from "../mystery-encounter-requirements"; +import MysteryEncounter, { MysteryEncounterBuilder } from "#app/data/mystery-encounters/mystery-encounter"; +import { MoneyRequirement } from "#app/data/mystery-encounters/mystery-encounter-requirements"; import { catchPokemon, getRandomSpeciesByStarterTier, getSpriteKeysFromPokemon } from "#app/data/mystery-encounters/utils/encounter-pokemon-utils"; -import { getPokemonSpecies, speciesStarters } from "#app/data/pokemon-species"; +import { getPokemonSpecies } from "#app/data/pokemon-species"; +import { speciesStarterCosts } from "#app/data/balance/starters"; import { Species } from "#enums/species"; -import { PokeballType } from "#app/data/pokeball"; +import { PokeballType } from "#enums/pokeball"; import { EnemyPokemon, PlayerPokemon } from "#app/field/pokemon"; import { MysteryEncounterOptionBuilder } from "#app/data/mystery-encounters/mystery-encounter-option"; import { showEncounterDialogue } from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; @@ -15,11 +16,15 @@ import PokemonData from "#app/system/pokemon-data"; import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode"; import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES } from "#app/game-mode"; +import { Abilities } from "#enums/abilities"; /** the i18n namespace for this encounter */ -const namespace = "mysteryEncounter:pokemonSalesman"; +const namespace = "mysteryEncounters/thePokemonSalesman"; -const MAX_POKEMON_PRICE_MULTIPLIER = 6; +const MAX_POKEMON_PRICE_MULTIPLIER = 4; + +/** Odds of shiny magikarp will be 1/value */ +const SHINY_MAGIKARP_WEIGHT = 100; /** * Pokemon Salesman encounter. @@ -30,7 +35,7 @@ export const ThePokemonSalesmanEncounter: MysteryEncounter = MysteryEncounterBuilder.withEncounterType(MysteryEncounterType.THE_POKEMON_SALESMAN) .withEncounterTier(MysteryEncounterTier.ULTRA) .withSceneWaveRangeRequirement(...CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES) - .withSceneRequirement(new MoneyRequirement(undefined, MAX_POKEMON_PRICE_MULTIPLIER)) // Some costs may not be as significant, this is the max you'd pay + .withSceneRequirement(new MoneyRequirement(0, MAX_POKEMON_PRICE_MULTIPLIER)) // Some costs may not be as significant, this is the max you'd pay .withAutoHideIntroVisuals(false) .withIntroSpriteConfigs([ { @@ -41,33 +46,35 @@ export const ThePokemonSalesmanEncounter: MysteryEncounter = ]) .withIntroDialogue([ { - text: `${namespace}.intro`, + text: `${namespace}:intro`, }, { - text: `${namespace}.intro_dialogue`, - speaker: `${namespace}.speaker`, + text: `${namespace}:intro_dialogue`, + speaker: `${namespace}:speaker`, }, ]) - .withTitle(`${namespace}.title`) - .withDescription(`${namespace}.description`) - .withQuery(`${namespace}.query`) + .setLocalizationKey(`${namespace}`) + .withTitle(`${namespace}:title`) + .withDescription(`${namespace}:description`) + .withQuery(`${namespace}:query`) .withOnInit((scene: BattleScene) => { const encounter = scene.currentBattle.mysteryEncounter!; - let species = getPokemonSpecies(getRandomSpeciesByStarterTier([0, 5])); - const tries = 0; + let species = getPokemonSpecies(getRandomSpeciesByStarterTier([ 0, 5 ], undefined, undefined, false, false, false)); + let tries = 0; // Reroll any species that don't have HAs - while (isNullOrUndefined(species.abilityHidden) && tries < 5) { - species = getPokemonSpecies(getRandomSpeciesByStarterTier([0, 5])); + while ((isNullOrUndefined(species.abilityHidden) || species.abilityHidden === Abilities.NONE) && tries < 5) { + species = getPokemonSpecies(getRandomSpeciesByStarterTier([ 0, 5 ], undefined, undefined, false, false, false)); + tries++; } let pokemon: PlayerPokemon; - if (isNullOrUndefined(species.abilityHidden) || randSeedInt(100) === 0) { + if (randSeedInt(SHINY_MAGIKARP_WEIGHT) === 0 || isNullOrUndefined(species.abilityHidden) || species.abilityHidden === Abilities.NONE) { // If no HA mon found or you roll 1%, give shiny Magikarp species = getPokemonSpecies(Species.MAGIKARP); const hiddenIndex = species.ability2 ? 2 : 1; - pokemon = new PlayerPokemon(scene, species, 5, hiddenIndex, species.formIndex, undefined, true); + pokemon = new PlayerPokemon(scene, species, 5, hiddenIndex, species.formIndex, undefined, true, 0); } else { const hiddenIndex = species.ability2 ? 2 : 1; pokemon = new PlayerPokemon(scene, species, 5, hiddenIndex, species.formIndex); @@ -83,15 +90,15 @@ export const ThePokemonSalesmanEncounter: MysteryEncounter = isPokemon: true }); - const starterTier = speciesStarters[species.speciesId]; + const starterTier = speciesStarterCosts[species.speciesId]; // Prices decrease by starter tier less than 5, but only reduces cost by half at max let priceMultiplier = MAX_POKEMON_PRICE_MULTIPLIER * (Math.max(starterTier, 2.5) / 5); if (pokemon.shiny) { // Always max price for shiny (flip HA back to normal), and add special messaging priceMultiplier = MAX_POKEMON_PRICE_MULTIPLIER; pokemon.abilityIndex = 0; - encounter.dialogue.encounterOptionsDialogue!.description = `${namespace}.description_shiny`; - encounter.options[0].dialogue!.buttonTooltip = `${namespace}.option.1.tooltip_shiny`; + encounter.dialogue.encounterOptionsDialogue!.description = `${namespace}:description_shiny`; + encounter.options[0].dialogue!.buttonTooltip = `${namespace}:option.1.tooltip_shiny`; } const price = scene.getWaveMoneyAmount(priceMultiplier); encounter.setDialogueToken("purchasePokemon", pokemon.getNameToRender()); @@ -109,13 +116,13 @@ export const ThePokemonSalesmanEncounter: MysteryEncounter = MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DISABLED_OR_DEFAULT) .withHasDexProgress(true) - .withSceneMoneyRequirement(undefined, MAX_POKEMON_PRICE_MULTIPLIER) // Wave scaling money multiplier of 2 + .withSceneMoneyRequirement(0, MAX_POKEMON_PRICE_MULTIPLIER) // Wave scaling money multiplier of 2 .withDialogue({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.1.selected_message`, + text: `${namespace}:option.1.selected_message`, } ], }) @@ -128,7 +135,7 @@ export const ThePokemonSalesmanEncounter: MysteryEncounter = updatePlayerMoney(scene, -price, true, false); // Show dialogue - await showEncounterDialogue(scene, `${namespace}.option.1.selected_dialogue`, `${namespace}.speaker`); + await showEncounterDialogue(scene, `${namespace}:option.1.selected_dialogue`, `${namespace}:speaker`); await transitionMysteryEncounterIntroVisuals(scene); // "Catch" purchased pokemon @@ -142,11 +149,11 @@ export const ThePokemonSalesmanEncounter: MysteryEncounter = ) .withSimpleOption( { - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, selected: [ { - text: `${namespace}.option.2.selected`, + text: `${namespace}:option.2.selected`, }, ], }, diff --git a/src/data/mystery-encounters/encounters/the-strong-stuff-encounter.ts b/src/data/mystery-encounters/encounters/the-strong-stuff-encounter.ts index 047aa0d83f6..754632aedea 100644 --- a/src/data/mystery-encounters/encounters/the-strong-stuff-encounter.ts +++ b/src/data/mystery-encounters/encounters/the-strong-stuff-encounter.ts @@ -2,10 +2,10 @@ import { EnemyPartyConfig, initBattleWithEnemyConfig, loadCustomMovesForEncounte import { modifierTypes, PokemonHeldItemModifierType, } from "#app/modifier/modifier-type"; import { MysteryEncounterType } from "#enums/mystery-encounter-type"; import BattleScene from "#app/battle-scene"; -import MysteryEncounter, { MysteryEncounterBuilder } from "../mystery-encounter"; +import MysteryEncounter, { MysteryEncounterBuilder } from "#app/data/mystery-encounters/mystery-encounter"; import { getPokemonSpecies } from "#app/data/pokemon-species"; import { Species } from "#enums/species"; -import { Nature } from "#app/data/nature"; +import { Nature } from "#enums/nature"; import Pokemon, { PokemonMove } from "#app/field/pokemon"; import { queueEncounterMessage, showEncounterText } from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; import { modifyPlayerPokemonBST } from "#app/data/mystery-encounters/utils/encounter-pokemon-utils"; @@ -14,13 +14,13 @@ import { BattlerIndex } from "#app/battle"; import { BattlerTagType } from "#enums/battler-tag-type"; import { BerryType } from "#enums/berry-type"; import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; -import { MysteryEncounterPokemonData } from "#app/data/mystery-encounters/mystery-encounter-pokemon-data"; +import { CustomPokemonData } from "#app/data/custom-pokemon-data"; import { Stat } from "#enums/stat"; import { StatStageChangePhase } from "#app/phases/stat-stage-change-phase"; import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES } from "#app/game-mode"; /** the i18n namespace for the encounter */ -const namespace = "mysteryEncounter:theStrongStuff"; +const namespace = "mysteryEncounters/theStrongStuff"; // Halved for HP stat const HIGH_BST_REDUCTION_VALUE = 15; @@ -33,11 +33,13 @@ const BST_INCREASE_VALUE = 10; */ export const TheStrongStuffEncounter: MysteryEncounter = MysteryEncounterBuilder.withEncounterType(MysteryEncounterType.THE_STRONG_STUFF) - .withEncounterTier(MysteryEncounterTier.GREAT) + .withEncounterTier(MysteryEncounterTier.COMMON) .withSceneWaveRangeRequirement(...CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES) .withScenePartySizeRequirement(3, 6) // Must have at least 3 pokemon in party + .withMaxAllowedEncounters(1) .withHideWildIntroMessage(true) .withAutoHideIntroVisuals(false) + .withFleeAllowed(false) .withIntroSpriteConfigs([ { spriteKey: "berry_juice", @@ -62,7 +64,7 @@ export const TheStrongStuffEncounter: MysteryEncounter = ]) // Set in onInit() .withIntroDialogue([ { - text: `${namespace}.intro`, + text: `${namespace}:intro`, }, ]) .withOnInit((scene: BattleScene) => { @@ -70,61 +72,62 @@ export const TheStrongStuffEncounter: MysteryEncounter = // Calculate boss mon const config: EnemyPartyConfig = { - levelAdditiveMultiplier: 1, + levelAdditiveModifier: 1, disableSwitch: true, pokemonConfigs: [ { species: getPokemonSpecies(Species.SHUCKLE), isBoss: true, bossSegments: 5, - mysteryEncounterPokemonData: new MysteryEncounterPokemonData({ spriteScale: 1.25 }), + customPokemonData: new CustomPokemonData({ spriteScale: 1.25 }), nature: Nature.BOLD, - moveSet: [Moves.INFESTATION, Moves.SALT_CURE, Moves.GASTRO_ACID, Moves.HEAL_ORDER], + moveSet: [ Moves.INFESTATION, Moves.SALT_CURE, Moves.GASTRO_ACID, Moves.HEAL_ORDER ], modifierConfigs: [ { - modifier: generateModifierType(scene, modifierTypes.BERRY, [BerryType.SITRUS]) as PokemonHeldItemModifierType + modifier: generateModifierType(scene, modifierTypes.BERRY, [ BerryType.SITRUS ]) as PokemonHeldItemModifierType }, { - modifier: generateModifierType(scene, modifierTypes.BERRY, [BerryType.ENIGMA]) as PokemonHeldItemModifierType + modifier: generateModifierType(scene, modifierTypes.BERRY, [ BerryType.ENIGMA ]) as PokemonHeldItemModifierType }, { - modifier: generateModifierType(scene, modifierTypes.BERRY, [BerryType.APICOT]) as PokemonHeldItemModifierType + modifier: generateModifierType(scene, modifierTypes.BERRY, [ BerryType.APICOT ]) as PokemonHeldItemModifierType }, { - modifier: generateModifierType(scene, modifierTypes.BERRY, [BerryType.GANLON]) as PokemonHeldItemModifierType + modifier: generateModifierType(scene, modifierTypes.BERRY, [ BerryType.GANLON ]) as PokemonHeldItemModifierType }, { - modifier: generateModifierType(scene, modifierTypes.BERRY, [BerryType.LUM]) as PokemonHeldItemModifierType, + modifier: generateModifierType(scene, modifierTypes.BERRY, [ BerryType.LUM ]) as PokemonHeldItemModifierType, stackCount: 2 } ], - tags: [BattlerTagType.MYSTERY_ENCOUNTER_POST_SUMMON], + tags: [ BattlerTagType.MYSTERY_ENCOUNTER_POST_SUMMON ], mysteryEncounterBattleEffects: (pokemon: Pokemon) => { - queueEncounterMessage(pokemon.scene, `${namespace}.option.2.stat_boost`); - pokemon.scene.unshiftPhase(new StatStageChangePhase(pokemon.scene, pokemon.getBattlerIndex(), true, [Stat.DEF, Stat.SPDEF], 2)); + queueEncounterMessage(pokemon.scene, `${namespace}:option.2.stat_boost`); + pokemon.scene.unshiftPhase(new StatStageChangePhase(pokemon.scene, pokemon.getBattlerIndex(), true, [ Stat.DEF, Stat.SPDEF ], 2)); } } ], }; - encounter.enemyPartyConfigs = [config]; + encounter.enemyPartyConfigs = [ config ]; - loadCustomMovesForEncounter(scene, [Moves.GASTRO_ACID, Moves.STEALTH_ROCK]); + loadCustomMovesForEncounter(scene, [ Moves.GASTRO_ACID, Moves.STEALTH_ROCK ]); encounter.setDialogueToken("shuckleName", getPokemonSpecies(Species.SHUCKLE).getName()); return true; }) - .withTitle(`${namespace}.title`) - .withDescription(`${namespace}.description`) - .withQuery(`${namespace}.query`) + .setLocalizationKey(`${namespace}`) + .withTitle(`${namespace}:title`) + .withDescription(`${namespace}:description`) + .withQuery(`${namespace}:query`) .withSimpleOption( { - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.1.selected` + text: `${namespace}:option.1.selected` } ] }, @@ -137,7 +140,7 @@ export const TheStrongStuffEncounter: MysteryEncounter = // -15 to all base stats of highest BST (halved for HP), +10 to all base stats of rest of party (halved for HP) // Sort party by bst - const sortedParty = scene.getParty().slice(0) + const sortedParty = scene.getPlayerParty().slice(0) .sort((pokemon1, pokemon2) => { const pokemon1Bst = pokemon1.calculateBaseStats().reduce((a, b) => a + b, 0); const pokemon2Bst = pokemon2.calculateBaseStats().reduce((a, b) => a + b, 0); @@ -157,8 +160,13 @@ export const TheStrongStuffEncounter: MysteryEncounter = encounter.setDialogueToken("reductionValue", HIGH_BST_REDUCTION_VALUE.toString()); encounter.setDialogueToken("increaseValue", BST_INCREASE_VALUE.toString()); - await showEncounterText(scene, `${namespace}.option.1.selected_2`, null, undefined, true); + await showEncounterText(scene, `${namespace}:option.1.selected_2`, null, undefined, true); + encounter.dialogue.outro = [ + { + text: `${namespace}:outro`, + } + ]; setEncounterRewards(scene, { fillRemaining: true }); leaveEncounterWithoutBattle(scene, true); return true; @@ -166,33 +174,34 @@ export const TheStrongStuffEncounter: MysteryEncounter = ) .withSimpleOption( { - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, selected: [ { - text: `${namespace}.option.2.selected`, + text: `${namespace}:option.2.selected`, }, ], }, async (scene: BattleScene) => { // Pick battle const encounter = scene.currentBattle.mysteryEncounter!; - setEncounterRewards(scene, { guaranteedModifierTypeFuncs: [modifierTypes.SOUL_DEW], fillRemaining: true }); + setEncounterRewards(scene, { guaranteedModifierTypeFuncs: [ modifierTypes.SOUL_DEW ], fillRemaining: true }); encounter.startOfBattleEffects.push( { sourceBattlerIndex: BattlerIndex.ENEMY, - targets: [BattlerIndex.PLAYER], + targets: [ BattlerIndex.PLAYER ], move: new PokemonMove(Moves.GASTRO_ACID), ignorePp: true }, { sourceBattlerIndex: BattlerIndex.ENEMY, - targets: [BattlerIndex.PLAYER], + targets: [ BattlerIndex.PLAYER ], move: new PokemonMove(Moves.STEALTH_ROCK), ignorePp: true }); - transitionMysteryEncounterIntroVisuals(scene, true, true, 500); + encounter.dialogue.outro = []; + await transitionMysteryEncounterIntroVisuals(scene, true, true, 500); await initBattleWithEnemyConfig(scene, encounter.enemyPartyConfigs[0]); } ) diff --git a/src/data/mystery-encounters/encounters/the-winstrate-challenge-encounter.ts b/src/data/mystery-encounters/encounters/the-winstrate-challenge-encounter.ts index 902aefcb490..f4446241873 100644 --- a/src/data/mystery-encounters/encounters/the-winstrate-challenge-encounter.ts +++ b/src/data/mystery-encounters/encounters/the-winstrate-challenge-encounter.ts @@ -2,7 +2,7 @@ import { EnemyPartyConfig, generateModifierType, generateModifierTypeOption, ini import { modifierTypes, PokemonHeldItemModifierType } from "#app/modifier/modifier-type"; import { MysteryEncounterType } from "#enums/mystery-encounter-type"; import BattleScene from "#app/battle-scene"; -import MysteryEncounter, { MysteryEncounterBuilder } from "../mystery-encounter"; +import MysteryEncounter, { MysteryEncounterBuilder } from "#app/data/mystery-encounters/mystery-encounter"; import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; import { TrainerType } from "#enums/trainer-type"; import { Species } from "#enums/species"; @@ -10,7 +10,7 @@ import { Abilities } from "#enums/abilities"; import { getPokemonSpecies } from "#app/data/pokemon-species"; import { Moves } from "#enums/moves"; import { Nature } from "#enums/nature"; -import { Type } from "#app/data/type"; +import { Type } from "#enums/type"; import { BerryType } from "#enums/berry-type"; import { Stat } from "#enums/stat"; import { SpeciesFormChangeManualTrigger } from "#app/data/pokemon-forms"; @@ -23,9 +23,10 @@ import { ReturnPhase } from "#app/phases/return-phase"; import i18next from "i18next"; import { ModifierTier } from "#app/modifier/modifier-tier"; import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES } from "#app/game-mode"; +import { BattlerTagType } from "#enums/battler-tag-type"; /** the i18n namespace for the encounter */ -const namespace = "mysteryEncounter:theWinstrateChallenge"; +const namespace = "mysteryEncounters/theWinstrateChallenge"; /** * The Winstrate Challenge encounter. @@ -74,11 +75,11 @@ export const TheWinstrateChallengeEncounter: MysteryEncounter = ]) .withIntroDialogue([ { - text: `${namespace}.intro`, + text: `${namespace}:intro`, }, { - speaker: `${namespace}.speaker`, - text: `${namespace}.intro_dialogue`, + speaker: `${namespace}:speaker`, + text: `${namespace}:intro_dialogue`, }, ]) .withAutoHideIntroVisuals(false) @@ -94,24 +95,25 @@ export const TheWinstrateChallengeEncounter: MysteryEncounter = return true; }) - .withTitle(`${namespace}.title`) - .withDescription(`${namespace}.description`) - .withQuery(`${namespace}.query`) + .setLocalizationKey(`${namespace}`) + .withTitle(`${namespace}:title`) + .withDescription(`${namespace}:description`) + .withQuery(`${namespace}:query`) .withSimpleOption( { - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - speaker: `${namespace}.speaker`, - text: `${namespace}.option.1.selected`, + speaker: `${namespace}:speaker`, + text: `${namespace}:option.1.selected`, }, ], }, async (scene: BattleScene) => { // Spawn 5 trainer battles back to back with Macho Brace in rewards - scene.currentBattle.mysteryEncounter!.doContinueEncounter = (scene: BattleScene) => { - return endTrainerBattleAndShowDialogue(scene); + scene.currentBattle.mysteryEncounter!.doContinueEncounter = async (scene: BattleScene) => { + await endTrainerBattleAndShowDialogue(scene); }; await transitionMysteryEncounterIntroVisuals(scene, true, false); await spawnNextTrainerOrEndEncounter(scene); @@ -119,19 +121,19 @@ export const TheWinstrateChallengeEncounter: MysteryEncounter = ) .withSimpleOption( { - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, selected: [ { - speaker: `${namespace}.speaker`, - text: `${namespace}.option.2.selected`, + speaker: `${namespace}:speaker`, + text: `${namespace}:option.2.selected`, }, ], }, async (scene: BattleScene) => { // Refuse the challenge, they full heal the party and give the player a Rarer Candy scene.unshiftPhase(new PartyHealPhase(scene, true)); - setEncounterRewards(scene, { guaranteedModifierTypeFuncs: [modifierTypes.RARER_CANDY], fillRemaining: false }); + setEncounterRewards(scene, { guaranteedModifierTypeFuncs: [ modifierTypes.RARER_CANDY ], fillRemaining: false }); leaveEncounterWithoutBattle(scene); } ) @@ -142,19 +144,19 @@ async function spawnNextTrainerOrEndEncounter(scene: BattleScene) { const nextConfig = encounter.enemyPartyConfigs.pop(); if (!nextConfig) { await transitionMysteryEncounterIntroVisuals(scene, false, false); - await showEncounterDialogue(scene, `${namespace}.victory`, `${namespace}.speaker`); + await showEncounterDialogue(scene, `${namespace}:victory`, `${namespace}:speaker`); // Give 10x Voucher const newModifier = modifierTypes.VOUCHER_PREMIUM().newModifier(); - scene.addModifier(newModifier); + await scene.addModifier(newModifier); scene.playSound("item_fanfare"); await showEncounterText(scene, i18next.t("battle:rewardGain", { modifierName: newModifier?.type.name })); - await showEncounterDialogue(scene, `${namespace}.victory_2`, `${namespace}.speaker`); + await showEncounterDialogue(scene, `${namespace}:victory_2`, `${namespace}:speaker`); scene.ui.clearText(); // Clears "Winstrate" title from screen as rewards get animated in const machoBrace = generateModifierTypeOption(scene, modifierTypes.MYSTERY_ENCOUNTER_MACHO_BRACE)!; machoBrace.type.tier = ModifierTier.MASTER; - setEncounterRewards(scene, { guaranteedModifierTypeOptions: [machoBrace], fillRemaining: false }); + setEncounterRewards(scene, { guaranteedModifierTypeOptions: [ machoBrace ], fillRemaining: false }); encounter.doContinueEncounter = undefined; leaveEncounterWithoutBattle(scene, false, MysteryEncounterMode.NO_BATTLE); } else { @@ -186,9 +188,10 @@ function endTrainerBattleAndShowDialogue(scene: BattleScene): Promise { } else { scene.arena.resetArenaEffects(); const playerField = scene.getPlayerField(); + playerField.forEach((pokemon) => pokemon.lapseTag(BattlerTagType.COMMANDED)); playerField.forEach((_, p) => scene.unshiftPhase(new ReturnPhase(scene, p))); - for (const pokemon of scene.getParty()) { + for (const pokemon of scene.getPlayerParty()) { // Only trigger form change when Eiscue is in Noice form // Hardcoded Eiscue for now in case it is fused with another pokemon if (pokemon.species.speciesId === Species.EISCUE && pokemon.hasAbility(Abilities.ICE_FACE) && pokemon.formIndex === 1) { @@ -232,7 +235,7 @@ function getVictorTrainerConfig(scene: BattleScene): EnemyPartyConfig { isBoss: false, abilityIndex: 0, // Guts nature: Nature.ADAMANT, - moveSet: [Moves.FACADE, Moves.BRAVE_BIRD, Moves.PROTECT, Moves.QUICK_ATTACK], + moveSet: [ Moves.FACADE, Moves.BRAVE_BIRD, Moves.PROTECT, Moves.QUICK_ATTACK ], modifierConfigs: [ { modifier: generateModifierType(scene, modifierTypes.FLAME_ORB) as PokemonHeldItemModifierType, @@ -250,7 +253,7 @@ function getVictorTrainerConfig(scene: BattleScene): EnemyPartyConfig { isBoss: false, abilityIndex: 1, // Guts nature: Nature.ADAMANT, - moveSet: [Moves.FACADE, Moves.OBSTRUCT, Moves.NIGHT_SLASH, Moves.FIRE_PUNCH], + moveSet: [ Moves.FACADE, Moves.OBSTRUCT, Moves.NIGHT_SLASH, Moves.FIRE_PUNCH ], modifierConfigs: [ { modifier: generateModifierType(scene, modifierTypes.FLAME_ORB) as PokemonHeldItemModifierType, @@ -276,7 +279,7 @@ function getVictoriaTrainerConfig(scene: BattleScene): EnemyPartyConfig { isBoss: false, abilityIndex: 0, // Natural Cure nature: Nature.CALM, - moveSet: [Moves.SYNTHESIS, Moves.SLUDGE_BOMB, Moves.GIGA_DRAIN, Moves.SLEEP_POWDER], + moveSet: [ Moves.SYNTHESIS, Moves.SLUDGE_BOMB, Moves.GIGA_DRAIN, Moves.SLEEP_POWDER ], modifierConfigs: [ { modifier: generateModifierType(scene, modifierTypes.SOUL_DEW) as PokemonHeldItemModifierType, @@ -294,15 +297,15 @@ function getVictoriaTrainerConfig(scene: BattleScene): EnemyPartyConfig { isBoss: false, formIndex: 1, nature: Nature.TIMID, - moveSet: [Moves.PSYSHOCK, Moves.MOONBLAST, Moves.SHADOW_BALL, Moves.WILL_O_WISP], + moveSet: [ Moves.PSYSHOCK, Moves.MOONBLAST, Moves.SHADOW_BALL, Moves.WILL_O_WISP ], modifierConfigs: [ { - modifier: generateModifierType(scene, modifierTypes.ATTACK_TYPE_BOOSTER, [Type.PSYCHIC]) as PokemonHeldItemModifierType, + modifier: generateModifierType(scene, modifierTypes.ATTACK_TYPE_BOOSTER, [ Type.PSYCHIC ]) as PokemonHeldItemModifierType, stackCount: 1, isTransferable: false }, { - modifier: generateModifierType(scene, modifierTypes.ATTACK_TYPE_BOOSTER, [Type.FAIRY]) as PokemonHeldItemModifierType, + modifier: generateModifierType(scene, modifierTypes.ATTACK_TYPE_BOOSTER, [ Type.FAIRY ]) as PokemonHeldItemModifierType, stackCount: 1, isTransferable: false } @@ -321,15 +324,15 @@ function getViviTrainerConfig(scene: BattleScene): EnemyPartyConfig { isBoss: false, abilityIndex: 3, // Lightning Rod nature: Nature.ADAMANT, - moveSet: [Moves.WATERFALL, Moves.MEGAHORN, Moves.KNOCK_OFF, Moves.REST], + moveSet: [ Moves.WATERFALL, Moves.MEGAHORN, Moves.KNOCK_OFF, Moves.REST ], modifierConfigs: [ { - modifier: generateModifierType(scene, modifierTypes.BERRY, [BerryType.LUM]) as PokemonHeldItemModifierType, + modifier: generateModifierType(scene, modifierTypes.BERRY, [ BerryType.LUM ]) as PokemonHeldItemModifierType, stackCount: 2, isTransferable: false }, { - modifier: generateModifierType(scene, modifierTypes.BASE_STAT_BOOSTER, [Stat.HP]) as PokemonHeldItemModifierType, + modifier: generateModifierType(scene, modifierTypes.BASE_STAT_BOOSTER, [ Stat.HP ]) as PokemonHeldItemModifierType, stackCount: 4, isTransferable: false } @@ -340,10 +343,10 @@ function getViviTrainerConfig(scene: BattleScene): EnemyPartyConfig { isBoss: false, abilityIndex: 1, // Poison Heal nature: Nature.JOLLY, - moveSet: [Moves.SPORE, Moves.SWORDS_DANCE, Moves.SEED_BOMB, Moves.DRAIN_PUNCH], + moveSet: [ Moves.SPORE, Moves.SWORDS_DANCE, Moves.SEED_BOMB, Moves.DRAIN_PUNCH ], modifierConfigs: [ { - modifier: generateModifierType(scene, modifierTypes.BASE_STAT_BOOSTER, [Stat.HP]) as PokemonHeldItemModifierType, + modifier: generateModifierType(scene, modifierTypes.BASE_STAT_BOOSTER, [ Stat.HP ]) as PokemonHeldItemModifierType, stackCount: 4, isTransferable: false }, @@ -358,7 +361,7 @@ function getViviTrainerConfig(scene: BattleScene): EnemyPartyConfig { isBoss: false, formIndex: 1, nature: Nature.CALM, - moveSet: [Moves.EARTH_POWER, Moves.FIRE_BLAST, Moves.YAWN, Moves.PROTECT], + moveSet: [ Moves.EARTH_POWER, Moves.FIRE_BLAST, Moves.YAWN, Moves.PROTECT ], modifierConfigs: [ { modifier: generateModifierType(scene, modifierTypes.QUICK_CLAW) as PokemonHeldItemModifierType, @@ -380,7 +383,7 @@ function getVickyTrainerConfig(scene: BattleScene): EnemyPartyConfig { isBoss: false, formIndex: 1, nature: Nature.IMPISH, - moveSet: [Moves.AXE_KICK, Moves.ICE_PUNCH, Moves.ZEN_HEADBUTT, Moves.BULLET_PUNCH], + moveSet: [ Moves.AXE_KICK, Moves.ICE_PUNCH, Moves.ZEN_HEADBUTT, Moves.BULLET_PUNCH ], modifierConfigs: [ { modifier: generateModifierType(scene, modifierTypes.SHELL_BELL) as PokemonHeldItemModifierType, @@ -401,10 +404,10 @@ function getVitoTrainerConfig(scene: BattleScene): EnemyPartyConfig { isBoss: false, abilityIndex: 0, // Soundproof nature: Nature.MODEST, - moveSet: [Moves.THUNDERBOLT, Moves.GIGA_DRAIN, Moves.FOUL_PLAY, Moves.THUNDER_WAVE], + moveSet: [ Moves.THUNDERBOLT, Moves.GIGA_DRAIN, Moves.FOUL_PLAY, Moves.THUNDER_WAVE ], modifierConfigs: [ { - modifier: generateModifierType(scene, modifierTypes.BASE_STAT_BOOSTER, [Stat.SPD]) as PokemonHeldItemModifierType, + modifier: generateModifierType(scene, modifierTypes.BASE_STAT_BOOSTER, [ Stat.SPD ]) as PokemonHeldItemModifierType, stackCount: 2, isTransferable: false } @@ -415,50 +418,50 @@ function getVitoTrainerConfig(scene: BattleScene): EnemyPartyConfig { isBoss: false, abilityIndex: 2, // Gluttony nature: Nature.QUIET, - moveSet: [Moves.SLUDGE_BOMB, Moves.GIGA_DRAIN, Moves.ICE_BEAM, Moves.EARTHQUAKE], + moveSet: [ Moves.SLUDGE_BOMB, Moves.GIGA_DRAIN, Moves.ICE_BEAM, Moves.EARTHQUAKE ], modifierConfigs: [ { - modifier: generateModifierType(scene, modifierTypes.BERRY, [BerryType.SITRUS]) as PokemonHeldItemModifierType, + modifier: generateModifierType(scene, modifierTypes.BERRY, [ BerryType.SITRUS ]) as PokemonHeldItemModifierType, stackCount: 2, }, { - modifier: generateModifierType(scene, modifierTypes.BERRY, [BerryType.APICOT]) as PokemonHeldItemModifierType, + modifier: generateModifierType(scene, modifierTypes.BERRY, [ BerryType.APICOT ]) as PokemonHeldItemModifierType, stackCount: 2, }, { - modifier: generateModifierType(scene, modifierTypes.BERRY, [BerryType.GANLON]) as PokemonHeldItemModifierType, + modifier: generateModifierType(scene, modifierTypes.BERRY, [ BerryType.GANLON ]) as PokemonHeldItemModifierType, stackCount: 2, }, { - modifier: generateModifierType(scene, modifierTypes.BERRY, [BerryType.STARF]) as PokemonHeldItemModifierType, + modifier: generateModifierType(scene, modifierTypes.BERRY, [ BerryType.STARF ]) as PokemonHeldItemModifierType, stackCount: 2, }, { - modifier: generateModifierType(scene, modifierTypes.BERRY, [BerryType.SALAC]) as PokemonHeldItemModifierType, + modifier: generateModifierType(scene, modifierTypes.BERRY, [ BerryType.SALAC ]) as PokemonHeldItemModifierType, stackCount: 2, }, { - modifier: generateModifierType(scene, modifierTypes.BERRY, [BerryType.LUM]) as PokemonHeldItemModifierType, + modifier: generateModifierType(scene, modifierTypes.BERRY, [ BerryType.LUM ]) as PokemonHeldItemModifierType, stackCount: 2, }, { - modifier: generateModifierType(scene, modifierTypes.BERRY, [BerryType.LANSAT]) as PokemonHeldItemModifierType, + modifier: generateModifierType(scene, modifierTypes.BERRY, [ BerryType.LANSAT ]) as PokemonHeldItemModifierType, stackCount: 2, }, { - modifier: generateModifierType(scene, modifierTypes.BERRY, [BerryType.LIECHI]) as PokemonHeldItemModifierType, + modifier: generateModifierType(scene, modifierTypes.BERRY, [ BerryType.LIECHI ]) as PokemonHeldItemModifierType, stackCount: 2, }, { - modifier: generateModifierType(scene, modifierTypes.BERRY, [BerryType.PETAYA]) as PokemonHeldItemModifierType, + modifier: generateModifierType(scene, modifierTypes.BERRY, [ BerryType.PETAYA ]) as PokemonHeldItemModifierType, stackCount: 2, }, { - modifier: generateModifierType(scene, modifierTypes.BERRY, [BerryType.ENIGMA]) as PokemonHeldItemModifierType, + modifier: generateModifierType(scene, modifierTypes.BERRY, [ BerryType.ENIGMA ]) as PokemonHeldItemModifierType, stackCount: 2, }, { - modifier: generateModifierType(scene, modifierTypes.BERRY, [BerryType.LEPPA]) as PokemonHeldItemModifierType, + modifier: generateModifierType(scene, modifierTypes.BERRY, [ BerryType.LEPPA ]) as PokemonHeldItemModifierType, stackCount: 2, } ] @@ -468,7 +471,7 @@ function getVitoTrainerConfig(scene: BattleScene): EnemyPartyConfig { isBoss: false, abilityIndex: 2, // Tangled Feet nature: Nature.JOLLY, - moveSet: [Moves.DRILL_PECK, Moves.QUICK_ATTACK, Moves.THRASH, Moves.KNOCK_OFF], + moveSet: [ Moves.DRILL_PECK, Moves.QUICK_ATTACK, Moves.THRASH, Moves.KNOCK_OFF ], modifierConfigs: [ { modifier: generateModifierType(scene, modifierTypes.KINGS_ROCK) as PokemonHeldItemModifierType, @@ -482,7 +485,7 @@ function getVitoTrainerConfig(scene: BattleScene): EnemyPartyConfig { isBoss: false, formIndex: 1, nature: Nature.BOLD, - moveSet: [Moves.PSYCHIC, Moves.SHADOW_BALL, Moves.FOCUS_BLAST, Moves.THUNDERBOLT], + moveSet: [ Moves.PSYCHIC, Moves.SHADOW_BALL, Moves.FOCUS_BLAST, Moves.THUNDERBOLT ], modifierConfigs: [ { modifier: generateModifierType(scene, modifierTypes.WIDE_LENS) as PokemonHeldItemModifierType, @@ -496,7 +499,7 @@ function getVitoTrainerConfig(scene: BattleScene): EnemyPartyConfig { isBoss: false, abilityIndex: 0, // Sheer Force nature: Nature.IMPISH, - moveSet: [Moves.EARTHQUAKE, Moves.U_TURN, Moves.FLARE_BLITZ, Moves.ROCK_SLIDE], + moveSet: [ Moves.EARTHQUAKE, Moves.U_TURN, Moves.FLARE_BLITZ, Moves.ROCK_SLIDE ], modifierConfigs: [ { modifier: generateModifierType(scene, modifierTypes.QUICK_CLAW) as PokemonHeldItemModifierType, diff --git a/src/data/mystery-encounters/encounters/training-session-encounter.ts b/src/data/mystery-encounters/encounters/training-session-encounter.ts index 6c0f1706fa5..725c4ba79eb 100644 --- a/src/data/mystery-encounters/encounters/training-session-encounter.ts +++ b/src/data/mystery-encounters/encounters/training-session-encounter.ts @@ -1,9 +1,9 @@ import { Ability, allAbilities } from "#app/data/ability"; import { EnemyPartyConfig, initBattleWithEnemyConfig, leaveEncounterWithoutBattle, selectPokemonForOption, setEncounterRewards, } from "#app/data/mystery-encounters/utils/encounter-phase-utils"; -import { getNatureName, Nature } from "#app/data/nature"; -import { speciesStarters } from "#app/data/pokemon-species"; +import { getNatureName } from "#app/data/nature"; +import { speciesStarterCosts } from "#app/data/balance/starters"; import Pokemon, { PlayerPokemon } from "#app/field/pokemon"; -import { PokemonFormChangeItemModifier, PokemonHeldItemModifier } from "#app/modifier/modifier"; +import { PokemonHeldItemModifier } from "#app/modifier/modifier"; import { AbilityAttr } from "#app/system/game-data"; import PokemonData from "#app/system/pokemon-data"; import { OptionSelectItem } from "#app/ui/abstact-option-select-ui-handler"; @@ -11,18 +11,20 @@ import { isNullOrUndefined, randSeedShuffle } from "#app/utils"; import { BattlerTagType } from "#enums/battler-tag-type"; import { MysteryEncounterType } from "#enums/mystery-encounter-type"; import BattleScene from "#app/battle-scene"; -import MysteryEncounter, { MysteryEncounterBuilder } from "../mystery-encounter"; -import { MysteryEncounterOptionBuilder } from "../mystery-encounter-option"; -import { getEncounterText, queueEncounterMessage, showEncounterText } from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; +import MysteryEncounter, { MysteryEncounterBuilder } from "#app/data/mystery-encounters/mystery-encounter"; +import { MysteryEncounterOptionBuilder } from "#app/data/mystery-encounters/mystery-encounter-option"; +import { queueEncounterMessage, showEncounterText } from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode"; import HeldModifierConfig from "#app/interfaces/held-modifier-config"; import i18next from "i18next"; import { getStatKey } from "#enums/stat"; import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES } from "#app/game-mode"; +import { isPokemonValidForEncounterOptionSelection } from "#app/data/mystery-encounters/utils/encounter-pokemon-utils"; +import type { Nature } from "#enums/nature"; /** The i18n namespace for the encounter */ -const namespace = "mysteryEncounter:trainingSession"; +const namespace = "mysteryEncounters/trainingSession"; /** * Training Session encounter. @@ -34,10 +36,12 @@ export const TrainingSessionEncounter: MysteryEncounter = .withEncounterTier(MysteryEncounterTier.ULTRA) .withSceneWaveRangeRequirement(...CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES) .withScenePartySizeRequirement(2, 6, true) // Must have at least 2 unfainted pokemon in party + .withFleeAllowed(false) .withHideWildIntroMessage(true) + .withPreventGameStatsUpdates(true) // Do not count the Pokemon as seen or defeated since it is ours .withIntroSpriteConfigs([ { - spriteKey: "training_gear", + spriteKey: "training_session_gear", fileRoot: "mystery-encounters", hasShadow: true, y: 6, @@ -47,22 +51,23 @@ export const TrainingSessionEncounter: MysteryEncounter = ]) .withIntroDialogue([ { - text: `${namespace}.intro`, + text: `${namespace}:intro`, } ]) - .withTitle(`${namespace}.title`) - .withDescription(`${namespace}.description`) - .withQuery(`${namespace}.query`) + .setLocalizationKey(`${namespace}`) + .withTitle(`${namespace}:title`) + .withDescription(`${namespace}:description`) + .withQuery(`${namespace}:query`) .withOption( MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) .withHasDexProgress(true) .withDialogue({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.selected`, + text: `${namespace}:option.selected`, }, ], }) @@ -76,12 +81,7 @@ export const TrainingSessionEncounter: MysteryEncounter = // Only Pokemon that are not KOed/legal can be trained const selectableFilter = (pokemon: Pokemon) => { - const meetsReqs = pokemon.isAllowedInBattle(); - if (!meetsReqs) { - return getEncounterText(scene, `${namespace}.invalid_selection`) ?? null; - } - - return null; + return isPokemonValidForEncounterOptionSelection(pokemon, scene, `${namespace}:invalid_selection`); }; return selectPokemonForOption(scene, onPokemonSelected, undefined, selectableFilter); @@ -97,19 +97,14 @@ export const TrainingSessionEncounter: MysteryEncounter = 5 ); const modifiers = new ModifiersHolder(); - const config = getEnemyConfig( - scene, - playerPokemon, - segments, - modifiers - ); + const config = getEnemyConfig(scene, playerPokemon, segments, modifiers); scene.removePokemonFromPlayerParty(playerPokemon, false); const onBeforeRewardsPhase = () => { encounter.setDialogueToken("stat1", "-"); encounter.setDialogueToken("stat2", "-"); // Add the pokemon back to party with IV boost - const ivIndexes: any[] = []; + let ivIndexes: any[] = []; playerPokemon.ivs.forEach((iv, index) => { if (iv < 31) { ivIndexes.push({ iv: iv, index: index }); @@ -125,7 +120,7 @@ export const TrainingSessionEncounter: MysteryEncounter = // 25-27 starting IV caps in 2 encounters let improvedCount = 0; while (ivIndexes.length > 0 && improvedCount < 2) { - randSeedShuffle(ivIndexes); + ivIndexes = randSeedShuffle(ivIndexes); const ivToChange = ivIndexes.pop(); let newVal = ivToChange.iv; if (improvedCount === 0) { @@ -153,25 +148,23 @@ export const TrainingSessionEncounter: MysteryEncounter = if (improvedCount > 0) { playerPokemon.calculateStats(); - scene.gameData.updateSpeciesDexIvs( - playerPokemon.species.getRootSpeciesId(true), - playerPokemon.ivs - ); + scene.gameData.updateSpeciesDexIvs(playerPokemon.species.getRootSpeciesId(true), playerPokemon.ivs); scene.gameData.setPokemonCaught(playerPokemon, false); } // Add pokemon and mods back - scene.getParty().push(playerPokemon); + scene.getPlayerParty().push(playerPokemon); for (const mod of modifiers.value) { + mod.pokemonId = playerPokemon.id; scene.addModifier(mod, true, false, false, true); } scene.updateModifiers(true); - queueEncounterMessage(scene, `${namespace}.option.1.finished`); + queueEncounterMessage(scene, `${namespace}:option.1.finished`); }; setEncounterRewards(scene, { fillRemaining: true }, undefined, onBeforeRewardsPhase); - return initBattleWithEnemyConfig(scene, config); + await initBattleWithEnemyConfig(scene, config); }) .build() ) @@ -180,12 +173,12 @@ export const TrainingSessionEncounter: MysteryEncounter = .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) .withHasDexProgress(true) .withDialogue({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, - secondOptionPrompt: `${namespace}.option.2.select_prompt`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, + secondOptionPrompt: `${namespace}:option.2.select_prompt`, selected: [ { - text: `${namespace}.option.selected`, + text: `${namespace}:option.selected`, }, ], }) @@ -214,12 +207,7 @@ export const TrainingSessionEncounter: MysteryEncounter = // Only Pokemon that are not KOed/legal can be trained const selectableFilter = (pokemon: Pokemon) => { - const meetsReqs = pokemon.isAllowedInBattle(); - if (!meetsReqs) { - return getEncounterText(scene, `${namespace}.invalid_selection`) ?? null; - } - - return null; + return isPokemonValidForEncounterOptionSelection(pokemon, scene, `${namespace}:invalid_selection`); }; return selectPokemonForOption(scene, onPokemonSelected, undefined, selectableFilter); @@ -230,27 +218,19 @@ export const TrainingSessionEncounter: MysteryEncounter = // Spawn medium training session with chosen pokemon // Every 40 waves, add +1 boss segment, capping at 6 - const segments = Math.min( - 2 + Math.floor(scene.currentBattle.waveIndex / 40), - 6 - ); + const segments = Math.min(2 + Math.floor(scene.currentBattle.waveIndex / 40), 6); const modifiers = new ModifiersHolder(); - const config = getEnemyConfig( - scene, - playerPokemon, - segments, - modifiers - ); + const config = getEnemyConfig(scene, playerPokemon, segments, modifiers); scene.removePokemonFromPlayerParty(playerPokemon, false); const onBeforeRewardsPhase = () => { - queueEncounterMessage(scene, `${namespace}.option.2.finished`); + queueEncounterMessage(scene, `${namespace}:option.2.finished`); // Add the pokemon back to party with Nature change - playerPokemon.setNature(encounter.misc.chosenNature); - scene.gameData.setPokemonCaught(playerPokemon, false); + playerPokemon.setCustomNature(encounter.misc.chosenNature); + scene.gameData.unlockSpeciesNature(playerPokemon.species, encounter.misc.chosenNature); // Add pokemon and modifiers back - scene.getParty().push(playerPokemon); + scene.getPlayerParty().push(playerPokemon); for (const mod of modifiers.value) { mod.pokemonId = playerPokemon.id; scene.addModifier(mod, true, false, false, true); @@ -260,7 +240,7 @@ export const TrainingSessionEncounter: MysteryEncounter = setEncounterRewards(scene, { fillRemaining: true }, undefined, onBeforeRewardsPhase); - return initBattleWithEnemyConfig(scene, config); + await initBattleWithEnemyConfig(scene, config); }) .build() ) @@ -269,12 +249,12 @@ export const TrainingSessionEncounter: MysteryEncounter = .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) .withHasDexProgress(true) .withDialogue({ - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, - secondOptionPrompt: `${namespace}.option.3.select_prompt`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, + secondOptionPrompt: `${namespace}:option.3.select_prompt`, selected: [ { - text: `${namespace}.option.selected`, + text: `${namespace}:option.selected`, }, ], }) @@ -318,12 +298,7 @@ export const TrainingSessionEncounter: MysteryEncounter = // Only Pokemon that are not KOed/legal can be trained const selectableFilter = (pokemon: Pokemon) => { - const meetsReqs = pokemon.isAllowedInBattle(); - if (!meetsReqs) { - return getEncounterText(scene, `${namespace}.invalid_selection`) ?? null; - } - - return null; + return isPokemonValidForEncounterOptionSelection(pokemon, scene, `${namespace}:invalid_selection`); }; return selectPokemonForOption(scene, onPokemonSelected, undefined, selectableFilter); @@ -344,39 +319,33 @@ export const TrainingSessionEncounter: MysteryEncounter = scene.removePokemonFromPlayerParty(playerPokemon, false); const onBeforeRewardsPhase = () => { - queueEncounterMessage(scene, `${namespace}.option.3.finished`); + queueEncounterMessage(scene, `${namespace}:option.3.finished`); // Add the pokemon back to party with ability change const abilityIndex = encounter.misc.abilityIndex; + if (!!playerPokemon.getFusionSpeciesForm()) { playerPokemon.fusionAbilityIndex = abilityIndex; - if (!isNullOrUndefined(playerPokemon.fusionSpecies?.speciesId) && speciesStarters.hasOwnProperty(playerPokemon.fusionSpecies!.speciesId)) { - scene.gameData.starterData[playerPokemon.fusionSpecies!.speciesId] - .abilityAttr |= - abilityIndex !== 1 || playerPokemon.fusionSpecies!.ability2 - ? Math.pow(2, playerPokemon.fusionAbilityIndex) - : AbilityAttr.ABILITY_HIDDEN; + + // Only update the fusion's dex data if the Pokemon is already caught in dex (ignore rentals) + const rootFusionSpecies = playerPokemon.fusionSpecies?.getRootSpeciesId(); + if (!isNullOrUndefined(rootFusionSpecies) + && speciesStarterCosts.hasOwnProperty(rootFusionSpecies) + && !!scene.gameData.dexData[rootFusionSpecies].caughtAttr) { + scene.gameData.starterData[rootFusionSpecies].abilityAttr |= playerPokemon.fusionAbilityIndex !== 1 || playerPokemon.fusionSpecies?.ability2 + ? 1 << playerPokemon.fusionAbilityIndex + : AbilityAttr.ABILITY_HIDDEN; } } else { playerPokemon.abilityIndex = abilityIndex; - if ( - speciesStarters.hasOwnProperty(playerPokemon.species.speciesId) - ) { - scene.gameData.starterData[ - playerPokemon.species.speciesId - ].abilityAttr |= - abilityIndex !== 1 || playerPokemon.species.ability2 - ? Math.pow(2, playerPokemon.abilityIndex) - : AbilityAttr.ABILITY_HIDDEN; - } } - playerPokemon.getAbility(); playerPokemon.calculateStats(); scene.gameData.setPokemonCaught(playerPokemon, false); // Add pokemon and mods back - scene.getParty().push(playerPokemon); + scene.getPlayerParty().push(playerPokemon); for (const mod of modifiers.value) { + mod.pokemonId = playerPokemon.id; scene.addModifier(mod, true, false, false, true); } scene.updateModifiers(true); @@ -384,17 +353,17 @@ export const TrainingSessionEncounter: MysteryEncounter = setEncounterRewards(scene, { fillRemaining: true }, undefined, onBeforeRewardsPhase); - return initBattleWithEnemyConfig(scene, config); + await initBattleWithEnemyConfig(scene, config); }) .build() ) .withSimpleOption( { - buttonLabel: `${namespace}.option.4.label`, - buttonTooltip: `${namespace}.option.4.tooltip`, + buttonLabel: `${namespace}:option.4.label`, + buttonTooltip: `${namespace}:option.4.tooltip`, selected: [ { - text: `${namespace}.option.4.selected`, + text: `${namespace}:option.4.selected`, }, ], }, @@ -410,10 +379,12 @@ function getEnemyConfig(scene: BattleScene, playerPokemon: PlayerPokemon, segmen playerPokemon.resetSummonData(); // Passes modifiers by reference - modifiers.value = playerPokemon.getHeldItems().filter(m => !(m instanceof PokemonFormChangeItemModifier)); + modifiers.value = playerPokemon.getHeldItems(); const modifierConfigs = modifiers.value.map((mod) => { return { - modifier: mod + modifier: mod.clone(), + isTransferable: false, + stackCount: mod.stackCount }; }) as HeldModifierConfig[]; diff --git a/src/data/mystery-encounters/encounters/trash-to-treasure-encounter.ts b/src/data/mystery-encounters/encounters/trash-to-treasure-encounter.ts index ec6291f2a8c..fba3a6ca95e 100644 --- a/src/data/mystery-encounters/encounters/trash-to-treasure-encounter.ts +++ b/src/data/mystery-encounters/encounters/trash-to-treasure-encounter.ts @@ -2,8 +2,8 @@ import { EnemyPartyConfig, EnemyPokemonConfig, generateModifierType, initBattleW import { modifierTypes, PokemonHeldItemModifierType } from "#app/modifier/modifier-type"; import { MysteryEncounterType } from "#enums/mystery-encounter-type"; import BattleScene from "#app/battle-scene"; -import MysteryEncounter, { MysteryEncounterBuilder } from "../mystery-encounter"; -import { MysteryEncounterOptionBuilder } from "../mystery-encounter-option"; +import MysteryEncounter, { MysteryEncounterBuilder } from "#app/data/mystery-encounters/mystery-encounter"; +import { MysteryEncounterOptionBuilder } from "#app/data/mystery-encounters/mystery-encounter-option"; import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode"; import { Species } from "#enums/species"; @@ -16,14 +16,16 @@ import { getPokemonSpecies } from "#app/data/pokemon-species"; import { Moves } from "#enums/moves"; import { BattlerIndex } from "#app/battle"; import { PokemonMove } from "#app/field/pokemon"; -import { ModifierRewardPhase } from "#app/phases/modifier-reward-phase"; import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES } from "#app/game-mode"; /** the i18n namespace for this encounter */ -const namespace = "mysteryEncounter:trashToTreasure"; +const namespace = "mysteryEncounters/trashToTreasure"; const SOUND_EFFECT_WAIT_TIME = 700; +// Items will cost 2.5x as much for remainder of the run +const SHOP_ITEM_COST_MULTIPLIER = 2.5; + /** * Trash to Treasure encounter. * @see {@link https://github.com/pagefaultgames/pokerogue/issues/3809 | GitHub Issue #3809} @@ -34,6 +36,7 @@ export const TrashToTreasureEncounter: MysteryEncounter = .withEncounterTier(MysteryEncounterTier.ULTRA) .withSceneWaveRangeRequirement(60, CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES[1]) .withMaxAllowedEncounters(1) + .withFleeAllowed(false) .withIntroSpriteConfigs([ { spriteKey: Species.GARBODOR.toString() + "-gigantamax", @@ -48,12 +51,13 @@ export const TrashToTreasureEncounter: MysteryEncounter = .withAutoHideIntroVisuals(false) .withIntroDialogue([ { - text: `${namespace}.intro`, + text: `${namespace}:intro`, }, ]) - .withTitle(`${namespace}.title`) - .withDescription(`${namespace}.description`) - .withQuery(`${namespace}.query`) + .setLocalizationKey(`${namespace}`) + .withTitle(`${namespace}:title`) + .withDescription(`${namespace}:description`) + .withQuery(`${namespace}:query`) .withOnInit((scene: BattleScene) => { const encounter = scene.currentBattle.mysteryEncounter!; @@ -64,32 +68,34 @@ export const TrashToTreasureEncounter: MysteryEncounter = isBoss: true, formIndex: 1, // Gmax bossSegmentModifier: 1, // +1 Segment from normal - moveSet: [Moves.PAYBACK, Moves.GUNK_SHOT, Moves.STOMPING_TANTRUM, Moves.DRAIN_PUNCH] + moveSet: [ Moves.PAYBACK, Moves.GUNK_SHOT, Moves.STOMPING_TANTRUM, Moves.DRAIN_PUNCH ] }; const config: EnemyPartyConfig = { - levelAdditiveMultiplier: 1, - pokemonConfigs: [pokemonConfig], + levelAdditiveModifier: 0.5, + pokemonConfigs: [ pokemonConfig ], disableSwitch: true }; - encounter.enemyPartyConfigs = [config]; + encounter.enemyPartyConfigs = [ config ]; // Load animations/sfx for Garbodor fight start moves - loadCustomMovesForEncounter(scene, [Moves.TOXIC, Moves.AMNESIA]); + loadCustomMovesForEncounter(scene, [ Moves.TOXIC, Moves.AMNESIA ]); scene.loadSe("PRSFX- Dig2", "battle_anims", "PRSFX- Dig2.wav"); scene.loadSe("PRSFX- Venom Drench", "battle_anims", "PRSFX- Venom Drench.wav"); + encounter.setDialogueToken("costMultiplier", SHOP_ITEM_COST_MULTIPLIER.toString()); + return true; }) .withOption( MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) .withDialogue({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.1.selected`, + text: `${namespace}:option.1.selected`, }, ], }) @@ -99,11 +105,17 @@ export const TrashToTreasureEncounter: MysteryEncounter = }) .withOptionPhase(async (scene: BattleScene) => { // Gain 2 Leftovers and 2 Shell Bell - transitionMysteryEncounterIntroVisuals(scene); + await transitionMysteryEncounterIntroVisuals(scene); await tryApplyDigRewardItems(scene); - // Give the player the Black Sludge curse - scene.unshiftPhase(new ModifierRewardPhase(scene, modifierTypes.MYSTERY_ENCOUNTER_BLACK_SLUDGE)); + const blackSludge = generateModifierType(scene, modifierTypes.MYSTERY_ENCOUNTER_BLACK_SLUDGE, [ SHOP_ITEM_COST_MULTIPLIER ]); + const modifier = blackSludge?.newModifier(); + if (modifier) { + await scene.addModifier(modifier, false, false, false, true); + scene.playSound("battle_anims/PRSFX- Venom Drench", { volume: 2 }); + await showEncounterText(scene, i18next.t("battle:rewardGain", { modifierName: modifier.type.name }), null, undefined, true); + } + leaveEncounterWithoutBattle(scene, true); }) .build() @@ -112,33 +124,33 @@ export const TrashToTreasureEncounter: MysteryEncounter = MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) .withDialogue({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, selected: [ { - text: `${namespace}.option.2.selected`, + text: `${namespace}:option.2.selected`, }, ], }) .withOptionPhase(async (scene: BattleScene) => { // Investigate garbage, battle Gmax Garbodor scene.setFieldScale(0.75); - await showEncounterText(scene, `${namespace}.option.2.selected_2`); - transitionMysteryEncounterIntroVisuals(scene); + await showEncounterText(scene, `${namespace}:option.2.selected_2`); + await transitionMysteryEncounterIntroVisuals(scene); const encounter = scene.currentBattle.mysteryEncounter!; - setEncounterRewards(scene, { guaranteedModifierTiers: [ModifierTier.ROGUE, ModifierTier.ROGUE, ModifierTier.ULTRA, ModifierTier.GREAT], fillRemaining: true }); + setEncounterRewards(scene, { guaranteedModifierTiers: [ ModifierTier.ROGUE, ModifierTier.ROGUE, ModifierTier.ULTRA, ModifierTier.GREAT ], fillRemaining: true }); encounter.startOfBattleEffects.push( { sourceBattlerIndex: BattlerIndex.ENEMY, - targets: [BattlerIndex.PLAYER], + targets: [ BattlerIndex.PLAYER ], move: new PokemonMove(Moves.TOXIC), ignorePp: true }, { sourceBattlerIndex: BattlerIndex.ENEMY, - targets: [BattlerIndex.ENEMY], + targets: [ BattlerIndex.ENEMY ], move: new PokemonMove(Moves.AMNESIA), ignorePp: true }); @@ -152,7 +164,7 @@ async function tryApplyDigRewardItems(scene: BattleScene) { const shellBell = generateModifierType(scene, modifierTypes.SHELL_BELL) as PokemonHeldItemModifierType; const leftovers = generateModifierType(scene, modifierTypes.LEFTOVERS) as PokemonHeldItemModifierType; - const party = scene.getParty(); + const party = scene.getPlayerParty(); // Iterate over the party until an item was successfully given // First leftovers @@ -180,7 +192,7 @@ async function tryApplyDigRewardItems(scene: BattleScene) { } scene.playSound("item_fanfare"); - await showEncounterText(scene, i18next.t("battle:rewardGain", { modifierName: "2 " + leftovers.name }), null, undefined, true); + await showEncounterText(scene, i18next.t("battle:rewardGainCount", { modifierName: leftovers.name, count: 2 }), null, undefined, true); // First Shell bell for (const pokemon of party) { @@ -207,10 +219,10 @@ async function tryApplyDigRewardItems(scene: BattleScene) { } scene.playSound("item_fanfare"); - await showEncounterText(scene, i18next.t("battle:rewardGain", { modifierName: "2 " + shellBell.name }), null, undefined, true); + await showEncounterText(scene, i18next.t("battle:rewardGainCount", { modifierName: shellBell.name, count: 2 }), null, undefined, true); } -async function doGarbageDig(scene: BattleScene) { +function doGarbageDig(scene: BattleScene) { scene.playSound("battle_anims/PRSFX- Dig2"); scene.time.delayedCall(SOUND_EFFECT_WAIT_TIME, () => { scene.playSound("battle_anims/PRSFX- Dig2"); diff --git a/src/data/mystery-encounters/encounters/uncommon-breed-encounter.ts b/src/data/mystery-encounters/encounters/uncommon-breed-encounter.ts index f9148b87f9b..a2c32c6af40 100644 --- a/src/data/mystery-encounters/encounters/uncommon-breed-encounter.ts +++ b/src/data/mystery-encounters/encounters/uncommon-breed-encounter.ts @@ -5,14 +5,13 @@ import Pokemon, { EnemyPokemon, PokemonMove } from "#app/field/pokemon"; import { getPartyLuckValue } from "#app/modifier/modifier-type"; import { MysteryEncounterType } from "#enums/mystery-encounter-type"; import BattleScene from "#app/battle-scene"; -import MysteryEncounter, { MysteryEncounterBuilder } from "../mystery-encounter"; -import { MoveRequirement, PersistentModifierRequirement } from "../mystery-encounter-requirements"; +import MysteryEncounter, { MysteryEncounterBuilder } from "#app/data/mystery-encounters/mystery-encounter"; +import { MoveRequirement, PersistentModifierRequirement } from "#app/data/mystery-encounters/mystery-encounter-requirements"; import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode"; import { TrainerSlot } from "#app/data/trainer-config"; import { catchPokemon, getHighestLevelPlayerPokemon, getSpriteKeysFromPokemon } from "#app/data/mystery-encounters/utils/encounter-pokemon-utils"; import PokemonData from "#app/system/pokemon-data"; -import { speciesEggMoves } from "#app/data/egg-moves"; import { isNullOrUndefined, randSeedInt } from "#app/utils"; import { Moves } from "#enums/moves"; import { BattlerIndex } from "#app/battle"; @@ -26,7 +25,7 @@ import { Stat } from "#enums/stat"; import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES } from "#app/game-mode"; /** the i18n namespace for the encounter */ -const namespace = "mysteryEncounter:uncommonBreed"; +const namespace = "mysteryEncounters/uncommonBreed"; /** * Uncommon Breed encounter. @@ -39,10 +38,11 @@ export const UncommonBreedEncounter: MysteryEncounter = .withSceneWaveRangeRequirement(...CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES) .withCatchAllowed(true) .withHideWildIntroMessage(true) + .withFleeAllowed(false) .withIntroSpriteConfigs([]) // Set in onInit() .withIntroDialogue([ { - text: `${namespace}.intro`, + text: `${namespace}:intro`, }, ]) .withOnInit((scene: BattleScene) => { @@ -50,27 +50,32 @@ export const UncommonBreedEncounter: MysteryEncounter = // Calculate boss mon // Level equal to 2 below highest party member - const level = getHighestLevelPlayerPokemon(scene).level - 2; - const species = scene.arena.randomSpecies(scene.currentBattle.waveIndex, level, 0, getPartyLuckValue(scene.getParty()), true); + const level = getHighestLevelPlayerPokemon(scene, false, true).level - 2; + const species = scene.arena.randomSpecies(scene.currentBattle.waveIndex, level, 0, getPartyLuckValue(scene.getPlayerParty()), true); const pokemon = new EnemyPokemon(scene, species, level, TrainerSlot.NONE, true); - const speciesRootForm = pokemon.species.getRootSpeciesId(); // Pokemon will always have one of its egg moves in its moveset - if (speciesEggMoves.hasOwnProperty(speciesRootForm)) { - const eggMoves: Moves[] = speciesEggMoves[speciesRootForm]; + const eggMoves = pokemon.getEggMoves(); + if (eggMoves) { const eggMoveIndex = randSeedInt(4); const randomEggMove: Moves = eggMoves[eggMoveIndex]; encounter.misc = { - eggMove: randomEggMove + eggMove: randomEggMove, + pokemon: pokemon }; if (pokemon.moveset.length < 4) { pokemon.moveset.push(new PokemonMove(randomEggMove)); } else { pokemon.moveset[0] = new PokemonMove(randomEggMove); } + } else { + encounter.misc.pokemon = pokemon; } - encounter.misc.pokemon = pokemon; + // Defense/Spd buffs below wave 50, +1 to all stats otherwise + const statChangesForBattle: (Stat.ATK | Stat.DEF | Stat.SPATK | Stat.SPDEF | Stat.SPD | Stat.ACC | Stat.EVA)[] = scene.currentBattle.waveIndex < 50 ? + [ Stat.DEF, Stat.SPDEF, Stat.SPD ] : + [ Stat.ATK, Stat.DEF, Stat.SPATK, Stat.SPDEF, Stat.SPD ]; const config: EnemyPartyConfig = { pokemonConfigs: [{ @@ -78,14 +83,14 @@ export const UncommonBreedEncounter: MysteryEncounter = species: species, dataSource: new PokemonData(pokemon), isBoss: false, - tags: [BattlerTagType.MYSTERY_ENCOUNTER_POST_SUMMON], + tags: [ BattlerTagType.MYSTERY_ENCOUNTER_POST_SUMMON ], mysteryEncounterBattleEffects: (pokemon: Pokemon) => { - queueEncounterMessage(pokemon.scene, `${namespace}.option.1.stat_boost`); - pokemon.scene.unshiftPhase(new StatStageChangePhase(pokemon.scene, pokemon.getBattlerIndex(), true, [Stat.ATK, Stat.DEF, Stat.SPATK, Stat.SPDEF, Stat.SPD], 1)); + queueEncounterMessage(pokemon.scene, `${namespace}:option.1.stat_boost`); + pokemon.scene.unshiftPhase(new StatStageChangePhase(pokemon.scene, pokemon.getBattlerIndex(), true, statChangesForBattle, 1)); } }], }; - encounter.enemyPartyConfigs = [config]; + encounter.enemyPartyConfigs = [ config ]; const { spriteKey, fileRoot } = getSpriteKeysFromPokemon(pokemon); encounter.spriteConfigs = [ @@ -120,16 +125,17 @@ export const UncommonBreedEncounter: MysteryEncounter = scene.time.delayedCall(500, () => scene.playSound("battle_anims/PRSFX- Spotlight2")); return true; }) - .withTitle(`${namespace}.title`) - .withDescription(`${namespace}.description`) - .withQuery(`${namespace}.query`) + .setLocalizationKey(`${namespace}`) + .withTitle(`${namespace}:title`) + .withDescription(`${namespace}:description`) + .withQuery(`${namespace}:query`) .withSimpleOption( { - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.1.selected`, + text: `${namespace}:option.1.selected`, }, ], }, @@ -147,7 +153,7 @@ export const UncommonBreedEncounter: MysteryEncounter = encounter.startOfBattleEffects.push( { sourceBattlerIndex: BattlerIndex.ENEMY, - targets: [target], + targets: [ target ], move: pokemonMove, ignorePp: true }); @@ -162,12 +168,12 @@ export const UncommonBreedEncounter: MysteryEncounter = .newOptionWithMode(MysteryEncounterOptionMode.DISABLED_OR_SPECIAL) .withSceneRequirement(new PersistentModifierRequirement("BerryModifier", 4)) // Will set option2PrimaryName and option2PrimaryMove dialogue tokens automatically .withDialogue({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, - disabledButtonTooltip: `${namespace}.option.2.disabled_tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, + disabledButtonTooltip: `${namespace}:option.2.disabled_tooltip`, selected: [ { - text: `${namespace}.option.2.selected` + text: `${namespace}:option.2.selected` } ] }) @@ -176,7 +182,7 @@ export const UncommonBreedEncounter: MysteryEncounter = // Remove 4 random berries from player's party // Get all player berry items, remove from party, and store reference - const berryItems: BerryModifier[]= scene.findModifiers(m => m instanceof BerryModifier) as BerryModifier[]; + const berryItems: BerryModifier[] = scene.findModifiers(m => m instanceof BerryModifier) as BerryModifier[]; for (let i = 0; i < 4; i++) { const index = randSeedInt(berryItems.length); const randBerry = berryItems[index]; @@ -193,20 +199,7 @@ export const UncommonBreedEncounter: MysteryEncounter = const pokemon = encounter.misc.pokemon; // Give 1 additional egg move - const previousEggMove = encounter.misc.eggMove; - const speciesRootForm = pokemon.species.getRootSpeciesId(); - if (speciesEggMoves.hasOwnProperty(speciesRootForm)) { - const eggMoves: Moves[] = speciesEggMoves[speciesRootForm]; - let randomEggMove: Moves = eggMoves[randSeedInt(4)]; - while (randomEggMove === previousEggMove) { - randomEggMove = eggMoves[randSeedInt(4)]; - } - if (pokemon.moveset.length < 4) { - pokemon.moveset.push(new PokemonMove(randomEggMove)); - } else { - pokemon.moveset[1] = new PokemonMove(randomEggMove); - } - } + givePokemonExtraEggMove(pokemon, encounter.misc.eggMove); await catchPokemon(scene, pokemon, null, PokeballType.POKEBALL, false); setEncounterRewards(scene, { fillRemaining: true }); @@ -217,14 +210,14 @@ export const UncommonBreedEncounter: MysteryEncounter = .withOption( MysteryEncounterOptionBuilder .newOptionWithMode(MysteryEncounterOptionMode.DISABLED_OR_SPECIAL) - .withPrimaryPokemonRequirement(new MoveRequirement(CHARMING_MOVES)) // Will set option2PrimaryName and option2PrimaryMove dialogue tokens automatically + .withPrimaryPokemonRequirement(new MoveRequirement(CHARMING_MOVES, true)) // Will set option2PrimaryName and option2PrimaryMove dialogue tokens automatically .withDialogue({ - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, - disabledButtonTooltip: `${namespace}.option.3.disabled_tooltip`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, + disabledButtonTooltip: `${namespace}:option.3.disabled_tooltip`, selected: [ { - text: `${namespace}.option.3.selected` + text: `${namespace}:option.3.selected` } ] }) @@ -235,20 +228,7 @@ export const UncommonBreedEncounter: MysteryEncounter = const pokemon = encounter.misc.pokemon; // Give 1 additional egg move - const previousEggMove = encounter.misc.eggMove; - const speciesRootForm = pokemon.species.getRootSpeciesId(); - if (speciesEggMoves.hasOwnProperty(speciesRootForm)) { - const eggMoves: Moves[] = speciesEggMoves[speciesRootForm]; - let randomEggMove: Moves = eggMoves[randSeedInt(4)]; - while (randomEggMove === previousEggMove) { - randomEggMove = eggMoves[randSeedInt(4)]; - } - if (pokemon.moveset.length < 4) { - pokemon.moveset.push(new PokemonMove(randomEggMove)); - } else { - pokemon.moveset[1] = new PokemonMove(randomEggMove); - } - } + givePokemonExtraEggMove(pokemon, encounter.misc.eggMove); // Roll IVs a second time pokemon.ivs = pokemon.ivs.map(iv => { @@ -266,3 +246,18 @@ export const UncommonBreedEncounter: MysteryEncounter = .build() ) .build(); + +function givePokemonExtraEggMove(pokemon: EnemyPokemon, previousEggMove: Moves) { + const eggMoves = pokemon.getEggMoves(); + if (eggMoves) { + let randomEggMove: Moves = eggMoves[randSeedInt(4)]; + while (randomEggMove === previousEggMove) { + randomEggMove = eggMoves[randSeedInt(4)]; + } + if (pokemon.moveset.length < 4) { + pokemon.moveset.push(new PokemonMove(randomEggMove)); + } else { + pokemon.moveset[1] = new PokemonMove(randomEggMove); + } + } +} diff --git a/src/data/mystery-encounters/encounters/weird-dream-encounter.ts b/src/data/mystery-encounters/encounters/weird-dream-encounter.ts index 476cc98f503..3d2e8493d44 100644 --- a/src/data/mystery-encounters/encounters/weird-dream-encounter.ts +++ b/src/data/mystery-encounters/encounters/weird-dream-encounter.ts @@ -1,29 +1,36 @@ -import { Type } from "#app/data/type"; +import { Type } from "#enums/type"; import { MysteryEncounterType } from "#enums/mystery-encounter-type"; import { Species } from "#enums/species"; import BattleScene from "#app/battle-scene"; -import MysteryEncounter, { MysteryEncounterBuilder } from "../mystery-encounter"; -import { MysteryEncounterOptionBuilder } from "../mystery-encounter-option"; -import { leaveEncounterWithoutBattle, setEncounterRewards, } from "../utils/encounter-phase-utils"; +import MysteryEncounter, { MysteryEncounterBuilder } from "#app/data/mystery-encounters/mystery-encounter"; +import { MysteryEncounterOptionBuilder } from "#app/data/mystery-encounters/mystery-encounter-option"; +import { EnemyPartyConfig, EnemyPokemonConfig, generateModifierType, initBattleWithEnemyConfig, leaveEncounterWithoutBattle, setEncounterRewards, } from "../utils/encounter-phase-utils"; import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode"; -import { PlayerPokemon, PokemonMove } from "#app/field/pokemon"; +import Pokemon, { PlayerPokemon, PokemonMove } from "#app/field/pokemon"; import { IntegerHolder, isNullOrUndefined, randSeedInt, randSeedShuffle } from "#app/utils"; import PokemonSpecies, { allSpecies, getPokemonSpecies } from "#app/data/pokemon-species"; import { HiddenAbilityRateBoosterModifier, PokemonFormChangeItemModifier, PokemonHeldItemModifier } from "#app/modifier/modifier"; import { achvs } from "#app/system/achv"; -import { speciesEggMoves } from "#app/data/egg-moves"; -import { MysteryEncounterPokemonData } from "#app/data/mystery-encounters/mystery-encounter-pokemon-data"; -import { queueEncounterMessage, showEncounterText } from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; -import { modifierTypes } from "#app/modifier/modifier-type"; +import { CustomPokemonData } from "#app/data/custom-pokemon-data"; +import { showEncounterText } from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; +import { modifierTypes, PokemonHeldItemModifierType } from "#app/modifier/modifier-type"; import i18next from "#app/plugins/i18n"; import { doPokemonTransformationSequence, TransformationScreenPosition } from "#app/data/mystery-encounters/utils/encounter-transformation-sequence"; import { getLevelTotalExp } from "#app/data/exp"; import { Stat } from "#enums/stat"; -import { CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES, GameModes } from "#app/game-mode"; +import { Challenges } from "#enums/challenges"; +import { ModifierTier } from "#app/modifier/modifier-tier"; +import { PlayerGender } from "#enums/player-gender"; +import { TrainerType } from "#enums/trainer-type"; +import PokemonData from "#app/system/pokemon-data"; +import { Nature } from "#enums/nature"; +import HeldModifierConfig from "#app/interfaces/held-modifier-config"; +import { trainerConfigs, TrainerPartyTemplate } from "#app/data/trainer-config"; +import { PartyMemberStrength } from "#enums/party-member-strength"; /** i18n namespace for encounter */ -const namespace = "mysteryEncounter:weirdDream"; +const namespace = "mysteryEncounters/weirdDream"; /** Exclude Ultra Beasts, Paradox, Eternatus, and all legendary/mythical/trio pokemon that are below 570 BST */ const EXCLUDED_TRANSFORMATION_SPECIES = [ @@ -80,18 +87,22 @@ const EXCLUDED_TRANSFORMATION_SPECIES = [ const SUPER_LEGENDARY_BST_THRESHOLD = 600; const NON_LEGENDARY_BST_THRESHOLD = 570; -const GAIN_OLD_GATEAU_ITEM_BST_THRESHOLD = 450; + +const OLD_GATEAU_STATS_UP = 20; + +/** 0-100 */ +const PERCENT_LEVEL_LOSS_ON_REFUSE = 10; /** * Value ranges of the resulting species BST transformations after adding values to original species * 2 Pokemon in the party use this range */ -const HIGH_BST_TRANSFORM_BASE_VALUES: [number, number] = [90, 110]; +const HIGH_BST_TRANSFORM_BASE_VALUES: [number, number] = [ 90, 110 ]; /** * Value ranges of the resulting species BST transformations after adding values to original species * All remaining Pokemon in the party use this range */ -const STANDARD_BST_TRANSFORM_BASE_VALUES: [number, number] = [40, 50]; +const STANDARD_BST_TRANSFORM_BASE_VALUES: [number, number] = [ 40, 50 ]; /** * Weird Dream encounter. @@ -101,8 +112,9 @@ const STANDARD_BST_TRANSFORM_BASE_VALUES: [number, number] = [40, 50]; export const WeirdDreamEncounter: MysteryEncounter = MysteryEncounterBuilder.withEncounterType(MysteryEncounterType.WEIRD_DREAM) .withEncounterTier(MysteryEncounterTier.ROGUE) - .withDisabledGameModes(GameModes.CHALLENGE) - .withSceneWaveRangeRequirement(...CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES) + .withDisallowedChallenges(Challenges.SINGLE_TYPE, Challenges.SINGLE_GENERATION) + // TODO: should reset minimum wave to 10 when there are more Rogue tiers in pool. Matching Dark Deal minimum for now. + .withSceneWaveRangeRequirement(30, 140) .withIntroSpriteConfigs([ { spriteKey: "weird_dream_woman", @@ -115,27 +127,32 @@ export const WeirdDreamEncounter: MysteryEncounter = ]) .withIntroDialogue([ { - text: `${namespace}.intro`, + text: `${namespace}:intro`, }, { - speaker: `${namespace}.speaker`, - text: `${namespace}.intro_dialogue`, + speaker: `${namespace}:speaker`, + text: `${namespace}:intro_dialogue`, }, ]) - .withTitle(`${namespace}.title`) - .withDescription(`${namespace}.description`) - .withQuery(`${namespace}.query`) + .setLocalizationKey(`${namespace}`) + .withTitle(`${namespace}:title`) + .withDescription(`${namespace}:description`) + .withQuery(`${namespace}:query`) .withOnInit((scene: BattleScene) => { scene.loadBgm("mystery_encounter_weird_dream", "mystery_encounter_weird_dream.mp3"); + + // Calculate all the newly transformed Pokemon and begin asset load + const teamTransformations = getTeamTransformations(scene); + const loadAssets = teamTransformations.map(t => (t.newPokemon as PlayerPokemon).loadAssets()); + scene.currentBattle.mysteryEncounter!.misc = { + teamTransformations, + loadAssets + }; + return true; }) .withOnVisualsStart((scene: BattleScene) => { - // Change the bgm - scene.fadeOutBgm(3000, false); - scene.time.delayedCall(3000, () => { - scene.playBgm("mystery_encounter_weird_dream"); - }); - + scene.fadeAndSwitchBgm("mystery_encounter_weird_dream"); return true; }) .withOption( @@ -143,11 +160,11 @@ export const WeirdDreamEncounter: MysteryEncounter = .newOptionWithMode(MysteryEncounterOptionMode.DEFAULT) .withHasDexProgress(true) .withDialogue({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.1.selected`, + text: `${namespace}:option.1.selected`, } ], }) @@ -157,17 +174,14 @@ export const WeirdDreamEncounter: MysteryEncounter = doShowDreamBackground(scene); }); - // Calculate all the newly transformed Pokemon and begin asset load - const teamTransformations = getTeamTransformations(scene); - const loadAssets = teamTransformations.map(t => (t.newPokemon as PlayerPokemon).loadAssets()); - scene.currentBattle.mysteryEncounter!.misc = { - teamTransformations, - loadAssets - }; + for (const transformation of scene.currentBattle.mysteryEncounter!.misc.teamTransformations) { + scene.removePokemonFromPlayerParty(transformation.previousPokemon, false); + scene.getPlayerParty().push(transformation.newPokemon); + } }) .withOptionPhase(async (scene: BattleScene) => { // Starts cutscene dialogue, but does not await so that cutscene plays as player goes through dialogue - const cutsceneDialoguePromise = showEncounterText(scene, `${namespace}.option.1.cutscene`); + const cutsceneDialoguePromise = showEncounterText(scene, `${namespace}:option.1.cutscene`); // Change the entire player's party // Wait for all new Pokemon assets to be loaded before showing transformation animations @@ -191,33 +205,115 @@ export const WeirdDreamEncounter: MysteryEncounter = await cutsceneDialoguePromise; doHideDreamBackground(scene); - await showEncounterText(scene, `${namespace}.option.1.dream_complete`); + await showEncounterText(scene, `${namespace}:option.1.dream_complete`); await doNewTeamPostProcess(scene, transformations); - setEncounterRewards(scene, { guaranteedModifierTypeFuncs: [modifierTypes.MEMORY_MUSHROOM, modifierTypes.ROGUE_BALL, modifierTypes.MINT, modifierTypes.MINT]}); + setEncounterRewards(scene, { guaranteedModifierTypeFuncs: [ modifierTypes.MEMORY_MUSHROOM, modifierTypes.ROGUE_BALL, modifierTypes.MINT, modifierTypes.MINT, modifierTypes.MINT ], fillRemaining: false }); leaveEncounterWithoutBattle(scene, true); }) .build() ) .withSimpleOption( { - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, selected: [ { - text: `${namespace}.option.2.selected`, + text: `${namespace}:option.2.selected`, }, ], }, async (scene: BattleScene) => { - // Reduce party levels by 20% - for (const pokemon of scene.getParty()) { - pokemon.level = Math.max(Math.ceil(0.8 * pokemon.level), 1); + // Battle your "future" team for some item rewards + const transformations: PokemonTransformation[] = scene.currentBattle.mysteryEncounter!.misc.teamTransformations; + + // Uses the pokemon that player's party would have transformed into + const enemyPokemonConfigs: EnemyPokemonConfig[] = []; + for (const transformation of transformations) { + const newPokemon = transformation.newPokemon; + const previousPokemon = transformation.previousPokemon; + + await postProcessTransformedPokemon(scene, previousPokemon, newPokemon, newPokemon.species.getRootSpeciesId(), true); + + const dataSource = new PokemonData(newPokemon); + dataSource.player = false; + + // Copy held items to new pokemon + const newPokemonHeldItemConfigs: HeldModifierConfig[] = []; + for (const item of transformation.heldItems) { + newPokemonHeldItemConfigs.push({ + modifier: item.clone() as PokemonHeldItemModifier, + stackCount: item.getStackCount(), + isTransferable: false + }); + } + // Any pokemon that is below 570 BST gets +20 permanent BST to 3 stats + if (shouldGetOldGateau(newPokemon)) { + const stats = getOldGateauBoostedStats(newPokemon); + newPokemonHeldItemConfigs.push({ + modifier: generateModifierType(scene, modifierTypes.MYSTERY_ENCOUNTER_OLD_GATEAU, [ OLD_GATEAU_STATS_UP, stats ]) as PokemonHeldItemModifierType, + stackCount: 1, + isTransferable: false + }); + } + + const enemyConfig: EnemyPokemonConfig = { + species: transformation.newSpecies, + isBoss: newPokemon.getSpeciesForm().getBaseStatTotal() > NON_LEGENDARY_BST_THRESHOLD, + level: previousPokemon.level, + dataSource: dataSource, + modifierConfigs: newPokemonHeldItemConfigs + }; + + enemyPokemonConfigs.push(enemyConfig); + } + + const genderIndex = scene.gameData.gender ?? PlayerGender.UNSET; + const trainerConfig = trainerConfigs[genderIndex === PlayerGender.FEMALE ? TrainerType.FUTURE_SELF_F : TrainerType.FUTURE_SELF_M].clone(); + trainerConfig.setPartyTemplates(new TrainerPartyTemplate(transformations.length, PartyMemberStrength.STRONG)); + const enemyPartyConfig: EnemyPartyConfig = { + trainerConfig: trainerConfig, + pokemonConfigs: enemyPokemonConfigs, + female: genderIndex === PlayerGender.FEMALE + }; + + const onBeforeRewards = () => { + // Before battle rewards, unlock the passive on a pokemon in the player's team for the rest of the run (not permanently) + // One random pokemon will get its passive unlocked + const passiveDisabledPokemon = scene.getPlayerParty().filter(p => !p.passive); + if (passiveDisabledPokemon?.length > 0) { + const enablePassiveMon = passiveDisabledPokemon[randSeedInt(passiveDisabledPokemon.length)]; + enablePassiveMon.passive = true; + enablePassiveMon.updateInfo(true); + } + }; + + setEncounterRewards(scene, { guaranteedModifierTiers: [ ModifierTier.ROGUE, ModifierTier.ROGUE, ModifierTier.ULTRA, ModifierTier.ULTRA, ModifierTier.GREAT, ModifierTier.GREAT ], fillRemaining: false }, undefined, onBeforeRewards); + + await showEncounterText(scene, `${namespace}:option.2.selected_2`, null, undefined, true); + await initBattleWithEnemyConfig(scene, enemyPartyConfig); + } + ) + .withSimpleOption( + { + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, + selected: [ + { + text: `${namespace}:option.3.selected`, + }, + ], + }, + async (scene: BattleScene) => { + // Leave, reduce party levels by 10% + for (const pokemon of scene.getPlayerParty()) { + pokemon.level = Math.max(Math.ceil((100 - PERCENT_LEVEL_LOSS_ON_REFUSE) / 100 * pokemon.level), 1); pokemon.exp = getLevelTotalExp(pokemon.level, pokemon.species.growthRate); pokemon.levelExp = 0; pokemon.calculateStats(); - pokemon.updateInfo(); + pokemon.getBattleInfo().setLevel(pokemon.level); + await pokemon.updateInfo(); } leaveEncounterWithoutBattle(scene, true); @@ -234,9 +330,9 @@ interface PokemonTransformation { } function getTeamTransformations(scene: BattleScene): PokemonTransformation[] { - const party = scene.getParty(); + const party = scene.getPlayerParty(); // Removes all pokemon from the party - const alreadyUsedSpecies: PokemonSpecies[] = []; + const alreadyUsedSpecies: PokemonSpecies[] = party.map(p => p.species); const pokemonTransformations: PokemonTransformation[] = party.map(p => { return { previousPokemon: p @@ -251,11 +347,11 @@ function getTeamTransformations(scene: BattleScene): PokemonTransformation[] { // First, roll 2 of the party members to new Pokemon at a +90 to +110 BST difference // Then, roll the remainder of the party members at a +40 to +50 BST difference const numPokemon = party.length; + const removedPokemon = randSeedShuffle(party.slice(0)); for (let i = 0; i < numPokemon; i++) { - const removed = party[randSeedInt(party.length)]; + const removed = removedPokemon[i]; const index = pokemonTransformations.findIndex(p => p.previousPokemon.id === removed.id); pokemonTransformations[index].heldItems = removed.getHeldItems().filter(m => !(m instanceof PokemonFormChangeItemModifier)); - scene.removePokemonFromPlayerParty(removed, false); const bst = removed.calculateBaseStats().reduce((a, b) => a + b, 0); let newBstRange: [number, number]; @@ -277,14 +373,13 @@ function getTeamTransformations(scene: BattleScene): PokemonTransformation[] { pokemonTransformations[index].newSpecies = newSpecies; + console.log("New species: " + JSON.stringify(newSpecies)); alreadyUsedSpecies.push(newSpecies); } for (const transformation of pokemonTransformations) { const newAbilityIndex = randSeedInt(transformation.newSpecies.getAbilityCount()); - const newPlayerPokemon = scene.addPlayerPokemon(transformation.newSpecies, transformation.previousPokemon.level, newAbilityIndex, undefined); - transformation.newPokemon = newPlayerPokemon; - scene.getParty().push(newPlayerPokemon); + transformation.newPokemon = scene.addPlayerPokemon(transformation.newSpecies, transformation.previousPokemon.level, newAbilityIndex, undefined); } return pokemonTransformations; @@ -297,125 +392,37 @@ async function doNewTeamPostProcess(scene: BattleScene, transformations: Pokemon const newPokemon = transformation.newPokemon; const speciesRootForm = newPokemon.species.getRootSpeciesId(); - // Roll HA a second time - if (newPokemon.species.abilityHidden) { - const hiddenIndex = newPokemon.species.ability2 ? 2 : 1; - if (newPokemon.abilityIndex < hiddenIndex) { - const hiddenAbilityChance = new IntegerHolder(256); - scene.applyModifiers(HiddenAbilityRateBoosterModifier, true, hiddenAbilityChance); - - const hasHiddenAbility = !randSeedInt(hiddenAbilityChance.value); - - if (hasHiddenAbility) { - newPokemon.abilityIndex = hiddenIndex; - } - } + if (await postProcessTransformedPokemon(scene, previousPokemon, newPokemon, speciesRootForm)) { + atLeastOneNewStarter = true; } - // Roll IVs a second time - newPokemon.ivs = newPokemon.ivs.map(iv => { - const newValue = randSeedInt(31); - return newValue > iv ? newValue : iv; - }); - - // For pokemon at/below 570 BST or any shiny pokemon, unlock it permanently as if you had caught it - if (newPokemon.getSpeciesForm().getBaseStatTotal() <= NON_LEGENDARY_BST_THRESHOLD || newPokemon.isShiny()) { - if (newPokemon.getSpeciesForm().abilityHidden && newPokemon.abilityIndex === newPokemon.getSpeciesForm().getAbilityCount() - 1) { - scene.validateAchv(achvs.HIDDEN_ABILITY); - } - - if (newPokemon.species.subLegendary) { - scene.validateAchv(achvs.CATCH_SUB_LEGENDARY); - } - - if (newPokemon.species.legendary) { - scene.validateAchv(achvs.CATCH_LEGENDARY); - } - - if (newPokemon.species.mythical) { - scene.validateAchv(achvs.CATCH_MYTHICAL); - } - - scene.gameData.updateSpeciesDexIvs(newPokemon.species.getRootSpeciesId(true), newPokemon.ivs); - const newStarterUnlocked = await scene.gameData.setPokemonCaught(newPokemon, true, false, false); - if (newStarterUnlocked) { - atLeastOneNewStarter = true; - queueEncounterMessage(scene, i18next.t("battle:addedAsAStarter", { pokemonName: getPokemonSpecies(speciesRootForm).getName() })); - } - } - - // If the previous pokemon had higher IVs, override to those (after updating dex IVs > prevents perfect 31s on a new unlock) - newPokemon.ivs = newPokemon.ivs.map((iv, index) => { - return previousPokemon.ivs[index] > iv ? previousPokemon.ivs[index] : iv; - }); - - // For pokemon that the player owns (including ones just caught), gain a candy - if (!!scene.gameData.dexData[speciesRootForm].caughtAttr) { - scene.gameData.addStarterCandy(getPokemonSpecies(speciesRootForm), 1); - } - - // Set the moveset of the new pokemon to be the same as previous, but with 1 egg move of the new species - newPokemon.moveset = previousPokemon.moveset; - if (speciesEggMoves.hasOwnProperty(speciesRootForm)) { - const eggMoves = speciesEggMoves[speciesRootForm]; - const eggMoveIndex = randSeedInt(4); - const randomEggMove = eggMoves[eggMoveIndex]; - if (newPokemon.moveset.length < 4) { - newPokemon.moveset.push(new PokemonMove(randomEggMove)); - } else { - newPokemon.moveset[randSeedInt(4)] = new PokemonMove(randomEggMove); - } - // For pokemon that the player owns (including ones just caught), unlock the egg move - if (!!scene.gameData.dexData[speciesRootForm].caughtAttr) { - await scene.gameData.setEggMoveUnlocked(getPokemonSpecies(speciesRootForm), eggMoveIndex, true); - } - } - - // Randomize the second type of the pokemon - // If the pokemon does not normally have a second type, it will gain 1 - const newTypes = [newPokemon.getTypes()[0]]; - let newType = randSeedInt(18) as Type; - while (newType === newTypes[0]) { - newType = randSeedInt(18) as Type; - } - newTypes.push(newType); - if (!newPokemon.mysteryEncounterPokemonData) { - newPokemon.mysteryEncounterPokemonData = new MysteryEncounterPokemonData(); - } - newPokemon.mysteryEncounterPokemonData.types = newTypes; - + // Copy old items to new pokemon for (const item of transformation.heldItems) { item.pokemonId = newPokemon.id; - scene.addModifier(item, false, false, false, true); + await scene.addModifier(item, false, false, false, true); } - - // Any pokemon that is at or below 450 BST gets +20 permanent BST to 3 stats: HP (halved, +10), lowest of Atk/SpAtk, and lowest of Def/SpDef - if (newPokemon.getSpeciesForm().getBaseStatTotal() <= GAIN_OLD_GATEAU_ITEM_BST_THRESHOLD) { - const stats: Stat[] = [Stat.HP]; - const baseStats = newPokemon.getSpeciesForm().baseStats.slice(0); - // Attack or SpAtk - stats.push(baseStats[Stat.ATK] < baseStats[Stat.SPATK] ? Stat.ATK : Stat.SPATK); - // Def or SpDef - stats.push(baseStats[Stat.DEF] < baseStats[Stat.SPDEF] ? Stat.DEF : Stat.SPDEF); - // const mod = modifierTypes.MYSTERY_ENCOUNTER_OLD_GATEAU().newModifier(newPokemon, 20, stats); - const modType = modifierTypes.MYSTERY_ENCOUNTER_OLD_GATEAU().generateType(scene.getParty(), [20, stats]); + // Any pokemon that is below 570 BST gets +20 permanent BST to 3 stats + if (shouldGetOldGateau(newPokemon)) { + const stats = getOldGateauBoostedStats(newPokemon); + const modType = modifierTypes.MYSTERY_ENCOUNTER_OLD_GATEAU() + .generateType(scene.getPlayerParty(), [ OLD_GATEAU_STATS_UP, stats ]) + ?.withIdFromFunc(modifierTypes.MYSTERY_ENCOUNTER_OLD_GATEAU); const modifier = modType?.newModifier(newPokemon); if (modifier) { - scene.addModifier(modifier); + await scene.addModifier(modifier, false, false, false, true); } } - // Enable passive if previous had it - newPokemon.passive = previousPokemon.passive; - newPokemon.calculateStats(); - newPokemon.initBattleInfo(); + await newPokemon.updateInfo(); } // One random pokemon will get its passive unlocked - const passiveDisabledPokemon = scene.getParty().filter(p => !p.passive); + const passiveDisabledPokemon = scene.getPlayerParty().filter(p => !p.passive); if (passiveDisabledPokemon?.length > 0) { - passiveDisabledPokemon[randSeedInt(passiveDisabledPokemon.length)].passive = true; + const enablePassiveMon = passiveDisabledPokemon[randSeedInt(passiveDisabledPokemon.length)]; + enablePassiveMon.passive = true; + await enablePassiveMon.updateInfo(true); } // If at least one new starter was unlocked, play 1 fanfare @@ -424,6 +431,138 @@ async function doNewTeamPostProcess(scene: BattleScene, transformations: Pokemon } } +/** + * Applies special changes to the newly transformed pokemon, such as passing previous moves, gaining egg moves, etc. + * Returns whether the transformed pokemon unlocks a new starter for the player. + * @param scene + * @param previousPokemon + * @param newPokemon + * @param speciesRootForm + * @param forBattle Default `false`. If false, will perform achievements and dex unlocks for the player. + */ +async function postProcessTransformedPokemon(scene: BattleScene, previousPokemon: PlayerPokemon, newPokemon: PlayerPokemon, speciesRootForm: Species, forBattle: boolean = false): Promise { + let isNewStarter = false; + // Roll HA a second time + if (newPokemon.species.abilityHidden) { + const hiddenIndex = newPokemon.species.ability2 ? 2 : 1; + if (newPokemon.abilityIndex < hiddenIndex) { + const hiddenAbilityChance = new IntegerHolder(256); + scene.applyModifiers(HiddenAbilityRateBoosterModifier, true, hiddenAbilityChance); + + const hasHiddenAbility = !randSeedInt(hiddenAbilityChance.value); + + if (hasHiddenAbility) { + newPokemon.abilityIndex = hiddenIndex; + } + } + } + + // Roll IVs a second time + newPokemon.ivs = newPokemon.ivs.map(iv => { + const newValue = randSeedInt(31); + return newValue > iv ? newValue : iv; + }); + + // Roll a neutral nature + newPokemon.nature = [ Nature.HARDY, Nature.DOCILE, Nature.BASHFUL, Nature.QUIRKY, Nature.SERIOUS ][randSeedInt(5)]; + + // For pokemon at/below 570 BST or any shiny pokemon, unlock it permanently as if you had caught it + if (!forBattle && (newPokemon.getSpeciesForm().getBaseStatTotal() <= NON_LEGENDARY_BST_THRESHOLD || newPokemon.isShiny())) { + if (newPokemon.getSpeciesForm().abilityHidden && newPokemon.abilityIndex === newPokemon.getSpeciesForm().getAbilityCount() - 1) { + scene.validateAchv(achvs.HIDDEN_ABILITY); + } + + if (newPokemon.species.subLegendary) { + scene.validateAchv(achvs.CATCH_SUB_LEGENDARY); + } + + if (newPokemon.species.legendary) { + scene.validateAchv(achvs.CATCH_LEGENDARY); + } + + if (newPokemon.species.mythical) { + scene.validateAchv(achvs.CATCH_MYTHICAL); + } + + scene.gameData.updateSpeciesDexIvs(newPokemon.species.getRootSpeciesId(true), newPokemon.ivs); + const newStarterUnlocked = await scene.gameData.setPokemonCaught(newPokemon, true, false, false); + if (newStarterUnlocked) { + isNewStarter = true; + await showEncounterText(scene, i18next.t("battle:addedAsAStarter", { pokemonName: getPokemonSpecies(speciesRootForm).getName() })); + } + } + + // If the previous pokemon had pokerus, transfer to new pokemon + newPokemon.pokerus = previousPokemon.pokerus; + + // Transfer previous Pokemon's luck value + newPokemon.luck = previousPokemon.getLuck(); + + // If the previous pokemon had higher IVs, override to those (after updating dex IVs > prevents perfect 31s on a new unlock) + newPokemon.ivs = newPokemon.ivs.map((iv, index) => { + return previousPokemon.ivs[index] > iv ? previousPokemon.ivs[index] : iv; + }); + + // For pokemon that the player owns (including ones just caught), gain a candy + if (!forBattle && !!scene.gameData.dexData[speciesRootForm].caughtAttr) { + scene.gameData.addStarterCandy(getPokemonSpecies(speciesRootForm), 1); + } + + // Set the moveset of the new pokemon to be the same as previous, but with 1 egg move and 1 (attempted) STAB move of the new species + newPokemon.generateAndPopulateMoveset(); + // Store a copy of a "standard" generated moveset for the new pokemon, will be used later for finding a favored move + const newPokemonGeneratedMoveset = newPokemon.moveset; + + newPokemon.moveset = previousPokemon.moveset.slice(0); + + const newEggMoveIndex = await addEggMoveToNewPokemonMoveset(scene, newPokemon, speciesRootForm, forBattle); + + // Try to add a favored STAB move (might fail if Pokemon already knows a bunch of moves from newPokemonGeneratedMoveset) + addFavoredMoveToNewPokemonMoveset(newPokemon, newPokemonGeneratedMoveset, newEggMoveIndex); + + // Randomize the second type of the pokemon + // If the pokemon does not normally have a second type, it will gain 1 + const newTypes = [ newPokemon.getTypes()[0] ]; + let newType = randSeedInt(18) as Type; + while (newType === newTypes[0]) { + newType = randSeedInt(18) as Type; + } + newTypes.push(newType); + if (!newPokemon.customPokemonData) { + newPokemon.customPokemonData = new CustomPokemonData(); + } + newPokemon.customPokemonData.types = newTypes; + + // Enable passive if previous had it + newPokemon.passive = previousPokemon.passive; + + return isNewStarter; +} + +/** + * @returns `true` if a given Pokemon has valid BST to be given an Old Gateau + */ +function shouldGetOldGateau(pokemon: Pokemon): boolean { + return pokemon.getSpeciesForm().getBaseStatTotal() < NON_LEGENDARY_BST_THRESHOLD; +} + +/** + * Get the lowest of HP/Spd, lowest of Atk/SpAtk, and lowest of Def/SpDef + * @returns Array of 3 {@linkcode Stat}s to boost + */ +function getOldGateauBoostedStats(pokemon: Pokemon): Stat[] { + const stats: Stat[] = []; + const baseStats = pokemon.getSpeciesForm().baseStats.slice(0); + // HP or Speed + stats.push(baseStats[Stat.HP] < baseStats[Stat.SPD] ? Stat.HP : Stat.SPD); + // Attack or SpAtk + stats.push(baseStats[Stat.ATK] < baseStats[Stat.SPATK] ? Stat.ATK : Stat.SPATK); + // Def or SpDef + stats.push(baseStats[Stat.DEF] < baseStats[Stat.SPDEF] ? Stat.DEF : Stat.SPDEF); + return stats; +} + + function getTransformedSpecies(originalBst: number, bstSearchRange: [number, number], hasPokemonBstHigherThan600: boolean, hasPokemonBstBetween570And600: boolean, alreadyUsedSpecies: PokemonSpecies[]): PokemonSpecies { let newSpecies: PokemonSpecies | undefined; while (isNullOrUndefined(newSpecies)) { @@ -445,7 +584,7 @@ function getTransformedSpecies(originalBst: number, bstSearchRange: [number, num if (validSpecies?.length > 20) { validSpecies = randSeedShuffle(validSpecies); newSpecies = validSpecies.pop(); - while (isNullOrUndefined(newSpecies) || alreadyUsedSpecies.includes(newSpecies!)) { + while (isNullOrUndefined(newSpecies) || alreadyUsedSpecies.includes(newSpecies)) { newSpecies = validSpecies.pop(); } } else { @@ -455,7 +594,7 @@ function getTransformedSpecies(originalBst: number, bstSearchRange: [number, num } } - return newSpecies!; + return newSpecies; } function doShowDreamBackground(scene: BattleScene) { @@ -540,3 +679,85 @@ function doSideBySideTransformations(scene: BattleScene, transformations: Pokemo } }); } + +/** + * Returns index of the new egg move within the Pokemon's moveset (not the index of the move in `speciesEggMoves`) + * @param scene + * @param newPokemon + * @param speciesRootForm + */ +async function addEggMoveToNewPokemonMoveset(scene: BattleScene, newPokemon: PlayerPokemon, speciesRootForm: Species, forBattle: boolean = false): Promise { + let eggMoveIndex: null | number = null; + const eggMoves = newPokemon.getEggMoves()?.slice(0); + if (eggMoves) { + const eggMoveIndices = randSeedShuffle([ 0, 1, 2, 3 ]); + let randomEggMoveIndex = eggMoveIndices.pop(); + let randomEggMove = !isNullOrUndefined(randomEggMoveIndex) ? eggMoves[randomEggMoveIndex] : null; + let retries = 0; + while (retries < 3 && (!randomEggMove || newPokemon.moveset.some(m => m?.moveId === randomEggMove))) { + // If Pokemon already knows this move, roll for another egg move + randomEggMoveIndex = eggMoveIndices.pop(); + randomEggMove = !isNullOrUndefined(randomEggMoveIndex) ? eggMoves[randomEggMoveIndex] : null; + retries++; + } + + if (randomEggMove) { + if (!newPokemon.moveset.some(m => m?.moveId === randomEggMove)) { + if (newPokemon.moveset.length < 4) { + newPokemon.moveset.push(new PokemonMove(randomEggMove)); + } else { + eggMoveIndex = randSeedInt(4); + newPokemon.moveset[eggMoveIndex] = new PokemonMove(randomEggMove); + } + } + + // For pokemon that the player owns (including ones just caught), unlock the egg move + if (!forBattle && !isNullOrUndefined(randomEggMoveIndex) && !!scene.gameData.dexData[speciesRootForm].caughtAttr) { + await scene.gameData.setEggMoveUnlocked(getPokemonSpecies(speciesRootForm), randomEggMoveIndex, true); + } + } + } + + return eggMoveIndex; +} + +/** + * Returns index of the new egg move within the Pokemon's moveset (not the index of the move in `speciesEggMoves`) + * @param newPokemon + * @param newPokemonGeneratedMoveset + * @param newEggMoveIndex + */ +function addFavoredMoveToNewPokemonMoveset(newPokemon: PlayerPokemon, newPokemonGeneratedMoveset: (PokemonMove | null)[], newEggMoveIndex: number | null) { + let favoredMove: PokemonMove | null = null; + for (const move of newPokemonGeneratedMoveset) { + // Needs to match first type, second type will be replaced + if (move?.getMove().type === newPokemon.getTypes()[0] && !newPokemon.moveset.some(m => m?.moveId === move?.moveId)) { + favoredMove = move; + break; + } + } + // If was unable to find a favored move, uses first move in moveset that isn't already known (typically a high power STAB move) + // Otherwise, it gains no favored move + if (!favoredMove) { + for (const move of newPokemonGeneratedMoveset) { + // Needs to match first type, second type will be replaced + if (!newPokemon.moveset.some(m => m?.moveId === move?.moveId)) { + favoredMove = move; + break; + } + } + } + // Finally, assign favored move to random index that isn't the new egg move index + if (favoredMove) { + if (newPokemon.moveset.length < 4) { + newPokemon.moveset.push(favoredMove); + } else { + let favoredMoveIndex = randSeedInt(4); + while (newEggMoveIndex !== null && favoredMoveIndex === newEggMoveIndex) { + favoredMoveIndex = randSeedInt(4); + } + + newPokemon.moveset[favoredMoveIndex] = favoredMove; + } + } +} diff --git a/src/data/mystery-encounters/mystery-encounter-option.ts b/src/data/mystery-encounters/mystery-encounter-option.ts index fb3daf53a8b..4ff8fd95f85 100644 --- a/src/data/mystery-encounters/mystery-encounter-option.ts +++ b/src/data/mystery-encounters/mystery-encounter-option.ts @@ -2,8 +2,8 @@ import { OptionTextDisplay } from "#app/data/mystery-encounters/mystery-encounte import { Moves } from "#app/enums/moves"; import Pokemon, { PlayerPokemon } from "#app/field/pokemon"; import BattleScene from "#app/battle-scene"; -import { Type } from "../type"; -import { EncounterPokemonRequirement, EncounterSceneRequirement, MoneyRequirement, TypeRequirement } from "./mystery-encounter-requirements"; +import { Type } from "#enums/type"; +import { EncounterPokemonRequirement, EncounterSceneRequirement, MoneyRequirement, TypeRequirement } from "#app/data/mystery-encounters/mystery-encounter-requirements"; import { CanLearnMoveRequirement, CanLearnMoveRequirementOptions } from "./requirements/can-learn-move-requirement"; import { isNullOrUndefined, randSeedInt } from "#app/utils"; import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode"; @@ -88,7 +88,7 @@ export default class MysteryEncounterOption implements IMysteryEncounterOption { * @param pokemon */ pokemonMeetsPrimaryRequirements(scene: BattleScene, pokemon: Pokemon): boolean { - return !this.primaryPokemonRequirements.some(req => !req.queryParty(scene.getParty()).map(p => p.id).includes(pokemon.id)); + return !this.primaryPokemonRequirements.some(req => !req.queryParty(scene.getPlayerParty()).map(p => p.id).includes(pokemon.id)); } /** @@ -102,10 +102,10 @@ export default class MysteryEncounterOption implements IMysteryEncounterOption { if (!this.primaryPokemonRequirements || this.primaryPokemonRequirements.length === 0) { return true; } - let qualified: PlayerPokemon[] = scene.getParty(); + let qualified: PlayerPokemon[] = scene.getPlayerParty(); for (const req of this.primaryPokemonRequirements) { if (req.meetsRequirement(scene)) { - const queryParty = req.queryParty(scene.getParty()); + const queryParty = req.queryParty(scene.getPlayerParty()); qualified = qualified.filter(pkmn => queryParty.includes(pkmn)); } else { this.primaryPokemon = undefined; @@ -162,10 +162,10 @@ export default class MysteryEncounterOption implements IMysteryEncounterOption { return true; } - let qualified: PlayerPokemon[] = scene.getParty(); + let qualified: PlayerPokemon[] = scene.getPlayerParty(); for (const req of this.secondaryPokemonRequirements) { if (req.meetsRequirement(scene)) { - const queryParty = req.queryParty(scene.getParty()); + const queryParty = req.queryParty(scene.getPlayerParty()); qualified = qualified.filter(pkmn => queryParty.includes(pkmn)); } else { this.secondaryPokemon = []; @@ -208,7 +208,7 @@ export class MysteryEncounterOptionBuilder implements Partial req.meetsRequirement(scene)) + : this.requirements.some(req => req.meetsRequirement(scene)); } + /** + * Retrieves a dialogue token key/value pair for the given {@linkcode EncounterSceneRequirement | requirements}. + * @param scene The {@linkcode BattleScene} to check against + * @param pokemon The {@linkcode PlayerPokemon} to check against + * @returns A dialogue token key/value pair + * @throws An {@linkcode Error} if {@linkcode isAnd} is `true` (not supported) + */ override getDialogueToken(scene: BattleScene, pokemon?: PlayerPokemon): [string, string] { - for (const req of this.orRequirements) { - if (req.meetsRequirement(scene)) { - return req.getDialogueToken(scene, pokemon); + if (this.isAnd) { + throw new Error("Not implemented (Sorry)"); + } else { + for (const req of this.requirements) { + if (req.meetsRequirement(scene)) { + return req.getDialogueToken(scene, pokemon); + } } - } - return this.orRequirements[0].getDialogueToken(scene, pokemon); + return this.requirements[0].getDialogueToken(scene, pokemon); + } } } @@ -89,44 +117,74 @@ export abstract class EncounterPokemonRequirement implements EncounterRequiremen abstract getDialogueToken(scene: BattleScene, pokemon?: PlayerPokemon): [string, string]; } +/** + * Combination of multiple {@linkcode EncounterPokemonRequirement | EncounterPokemonRequirements} (OR/AND possible. See {@linkcode isAnd}) + */ export class CombinationPokemonRequirement extends EncounterPokemonRequirement { - orRequirements: EncounterPokemonRequirement[]; + /** If `true`, all requirements must be met (AND). If `false`, any requirement must be met (OR) */ + private isAnd: boolean; + private requirements: EncounterPokemonRequirement[]; - constructor(...orRequirements: EncounterPokemonRequirement[]) { + public static Some(...requirements: EncounterPokemonRequirement[]): CombinationPokemonRequirement { + return new CombinationPokemonRequirement(false, ...requirements); + } + + public static Every(...requirements: EncounterPokemonRequirement[]): CombinationPokemonRequirement { + return new CombinationPokemonRequirement(true, ...requirements); + } + + private constructor(isAnd: boolean, ...requirements: EncounterPokemonRequirement[]) { super(); + this.isAnd = isAnd; this.invertQuery = false; this.minNumberOfPokemon = 1; - this.orRequirements = orRequirements; + this.requirements = requirements; } + /** + * Checks if all/any requirements are met (depends on {@linkcode isAnd}) + * @param scene The {@linkcode BattleScene} to check against + * @returns true if all/any requirements are met (depends on {@linkcode isAnd}) + */ override meetsRequirement(scene: BattleScene): boolean { - for (const req of this.orRequirements) { - if (req.meetsRequirement(scene)) { - return true; - } - } - return false; + return this.isAnd + ? this.requirements.every(req => req.meetsRequirement(scene)) + : this.requirements.some(req => req.meetsRequirement(scene)); } + /** + * Queries the players party for all party members that are compatible with all/any requirements (depends on {@linkcode isAnd}) + * @param partyPokemon The party of {@linkcode PlayerPokemon} + * @returns All party members that are compatible with all/any requirements (depends on {@linkcode isAnd}) + */ override queryParty(partyPokemon: PlayerPokemon[]): PlayerPokemon[] { - for (const req of this.orRequirements) { - const result = req.queryParty(partyPokemon); - if (result?.length > 0) { - return result; - } + if (this.isAnd) { + return this.requirements.reduce((relevantPokemon, req) => req.queryParty(relevantPokemon), partyPokemon); + } else { + const matchingRequirement = this.requirements.find(req => req.queryParty(partyPokemon).length > 0); + return matchingRequirement ? matchingRequirement.queryParty(partyPokemon) : []; } - - return []; } + /** + * Retrieves a dialogue token key/value pair for the given {@linkcode EncounterPokemonRequirement | requirements}. + * @param scene The {@linkcode BattleScene} to check against + * @param pokemon The {@linkcode PlayerPokemon} to check against + * @returns A dialogue token key/value pair + * @throws An {@linkcode Error} if {@linkcode isAnd} is `true` (not supported) + */ override getDialogueToken(scene: BattleScene, pokemon?: PlayerPokemon): [string, string] { - for (const req of this.orRequirements) { - if (req.meetsRequirement(scene)) { - return req.getDialogueToken(scene, pokemon); + if (this.isAnd) { + throw new Error("Not implemented (Sorry)"); + } else { + for (const req of this.requirements) { + if (req.meetsRequirement(scene)) { + return req.getDialogueToken(scene, pokemon); + } } - } - return this.orRequirements[0].getDialogueToken(scene, pokemon); + return this.requirements[0].getDialogueToken(scene, pokemon); + } } } @@ -147,7 +205,7 @@ export class PreviousEncounterRequirement extends EncounterSceneRequirement { } override getDialogueToken(scene: BattleScene, pokemon?: PlayerPokemon): [string, string] { - return ["previousEncounter", scene.mysteryEncounterSaveData.encounteredEvents.find(e => e.type === this.previousEncounterRequirement)?.[0].toString() ?? ""]; + return [ "previousEncounter", scene.mysteryEncounterSaveData.encounteredEvents.find(e => e.type === this.previousEncounterRequirement)?.[0].toString() ?? "" ]; } } @@ -165,9 +223,9 @@ export class WaveRangeRequirement extends EncounterSceneRequirement { } override meetsRequirement(scene: BattleScene): boolean { - if (!isNullOrUndefined(this.waveRange) && this.waveRange?.[0] <= this.waveRange?.[1]) { + if (!isNullOrUndefined(this.waveRange) && this.waveRange[0] <= this.waveRange[1]) { const waveIndex = scene.currentBattle.waveIndex; - if (waveIndex >= 0 && (this.waveRange?.[0] >= 0 && this.waveRange?.[0] > waveIndex) || (this.waveRange?.[1] >= 0 && this.waveRange?.[1] < waveIndex)) { + if (waveIndex >= 0 && (this.waveRange[0] >= 0 && this.waveRange[0] > waveIndex) || (this.waveRange[1] >= 0 && this.waveRange[1] < waveIndex)) { return false; } } @@ -175,7 +233,7 @@ export class WaveRangeRequirement extends EncounterSceneRequirement { } override getDialogueToken(scene: BattleScene, pokemon?: PlayerPokemon): [string, string] { - return ["waveIndex", scene.currentBattle.waveIndex.toString()]; + return [ "waveIndex", scene.currentBattle.waveIndex.toString() ]; } } @@ -204,7 +262,7 @@ export class WaveModulusRequirement extends EncounterSceneRequirement { } override getDialogueToken(scene: BattleScene, pokemon?: PlayerPokemon): [string, string] { - return ["waveIndex", scene.currentBattle.waveIndex.toString()]; + return [ "waveIndex", scene.currentBattle.waveIndex.toString() ]; } } @@ -213,7 +271,7 @@ export class TimeOfDayRequirement extends EncounterSceneRequirement { constructor(timeOfDay: TimeOfDay | TimeOfDay[]) { super(); - this.requiredTimeOfDay = Array.isArray(timeOfDay) ? timeOfDay : [timeOfDay]; + this.requiredTimeOfDay = Array.isArray(timeOfDay) ? timeOfDay : [ timeOfDay ]; } override meetsRequirement(scene: BattleScene): boolean { @@ -226,7 +284,7 @@ export class TimeOfDayRequirement extends EncounterSceneRequirement { } override getDialogueToken(scene: BattleScene, pokemon?: PlayerPokemon): [string, string] { - return ["timeOfDay", TimeOfDay[scene.arena.getTimeOfDay()].toLocaleLowerCase()]; + return [ "timeOfDay", TimeOfDay[scene.arena.getTimeOfDay()].toLocaleLowerCase() ]; } } @@ -235,7 +293,7 @@ export class WeatherRequirement extends EncounterSceneRequirement { constructor(weather: WeatherType | WeatherType[]) { super(); - this.requiredWeather = Array.isArray(weather) ? weather : [weather]; + this.requiredWeather = Array.isArray(weather) ? weather : [ weather ]; } override meetsRequirement(scene: BattleScene): boolean { @@ -251,32 +309,32 @@ export class WeatherRequirement extends EncounterSceneRequirement { const currentWeather = scene.arena.weather?.weatherType; let token = ""; if (!isNullOrUndefined(currentWeather)) { - token = WeatherType[currentWeather!].replace("_", " ").toLocaleLowerCase(); + token = WeatherType[currentWeather].replace("_", " ").toLocaleLowerCase(); } - return ["weather", token]; + return [ "weather", token ]; } } export class PartySizeRequirement extends EncounterSceneRequirement { partySizeRange: [number, number]; - excludeFainted: boolean; + excludeDisallowedPokemon: boolean; /** * Used for specifying a party size requirement * If min and max are equivalent, will check for exact size * @param partySizeRange - * @param excludeFainted + * @param excludeDisallowedPokemon */ - constructor(partySizeRange: [number, number], excludeFainted: boolean) { + constructor(partySizeRange: [number, number], excludeDisallowedPokemon: boolean) { super(); this.partySizeRange = partySizeRange; - this.excludeFainted = excludeFainted; + this.excludeDisallowedPokemon = excludeDisallowedPokemon; } override meetsRequirement(scene: BattleScene): boolean { - if (!isNullOrUndefined(this.partySizeRange) && this.partySizeRange?.[0] <= this.partySizeRange?.[1]) { - const partySize = this.excludeFainted ? scene.getParty().filter(p => p.isAllowedInBattle()).length : scene.getParty().length; - if (partySize >= 0 && (this.partySizeRange?.[0] >= 0 && this.partySizeRange?.[0] > partySize) || (this.partySizeRange?.[1] >= 0 && this.partySizeRange?.[1] < partySize)) { + if (!isNullOrUndefined(this.partySizeRange) && this.partySizeRange[0] <= this.partySizeRange[1]) { + const partySize = this.excludeDisallowedPokemon ? scene.getPokemonAllowedInBattle().length : scene.getPlayerParty().length; + if (partySize >= 0 && (this.partySizeRange[0] >= 0 && this.partySizeRange[0] > partySize) || (this.partySizeRange[1] >= 0 && this.partySizeRange[1] < partySize)) { return false; } } @@ -285,7 +343,7 @@ export class PartySizeRequirement extends EncounterSceneRequirement { } override getDialogueToken(scene: BattleScene, pokemon?: PlayerPokemon): [string, string] { - return ["partySize", scene.getParty().length.toString()]; + return [ "partySize", scene.getPlayerParty().length.toString() ]; } } @@ -296,11 +354,11 @@ export class PersistentModifierRequirement extends EncounterSceneRequirement { constructor(heldItem: string | string[], minNumberOfItems: number = 1) { super(); this.minNumberOfItems = minNumberOfItems; - this.requiredHeldItemModifiers = Array.isArray(heldItem) ? heldItem : [heldItem]; + this.requiredHeldItemModifiers = Array.isArray(heldItem) ? heldItem : [ heldItem ]; } override meetsRequirement(scene: BattleScene): boolean { - const partyPokemon = scene.getParty(); + const partyPokemon = scene.getPlayerParty(); if (isNullOrUndefined(partyPokemon) || this.requiredHeldItemModifiers?.length < 0) { return false; } @@ -318,7 +376,7 @@ export class PersistentModifierRequirement extends EncounterSceneRequirement { } override getDialogueToken(scene: BattleScene, pokemon?: PlayerPokemon): [string, string] { - return ["requiredItem", this.requiredHeldItemModifiers[0]]; + return [ "requiredItem", this.requiredHeldItemModifiers[0] ]; } } @@ -326,7 +384,7 @@ export class MoneyRequirement extends EncounterSceneRequirement { requiredMoney: number; // Static value scalingMultiplier: number; // Calculates required money based off wave index - constructor(requiredMoney?: number, scalingMultiplier?: number) { + constructor(requiredMoney: number, scalingMultiplier?: number) { super(); this.requiredMoney = requiredMoney ?? 0; this.scalingMultiplier = scalingMultiplier ?? 0; @@ -346,7 +404,7 @@ export class MoneyRequirement extends EncounterSceneRequirement { override getDialogueToken(scene: BattleScene, pokemon?: PlayerPokemon): [string, string] { const value = this.scalingMultiplier > 0 ? scene.getWaveMoneyAmount(this.scalingMultiplier).toString() : this.requiredMoney.toString(); - return ["money", value]; + return [ "money", value ]; } } @@ -359,11 +417,11 @@ export class SpeciesRequirement extends EncounterPokemonRequirement { super(); this.minNumberOfPokemon = minNumberOfPokemon; this.invertQuery = invertQuery; - this.requiredSpecies = Array.isArray(species) ? species : [species]; + this.requiredSpecies = Array.isArray(species) ? species : [ species ]; } override meetsRequirement(scene: BattleScene): boolean { - const partyPokemon = scene.getParty(); + const partyPokemon = scene.getPlayerParty(); if (isNullOrUndefined(partyPokemon) || this.requiredSpecies?.length < 0) { return false; } @@ -381,9 +439,9 @@ export class SpeciesRequirement extends EncounterPokemonRequirement { override getDialogueToken(scene: BattleScene, pokemon?: PlayerPokemon): [string, string] { if (pokemon?.species.speciesId && this.requiredSpecies.includes(pokemon.species.speciesId)) { - return ["species", Species[pokemon.species.speciesId]]; + return [ "species", Species[pokemon.species.speciesId] ]; } - return ["species", ""]; + return [ "species", "" ]; } } @@ -397,11 +455,11 @@ export class NatureRequirement extends EncounterPokemonRequirement { super(); this.minNumberOfPokemon = minNumberOfPokemon; this.invertQuery = invertQuery; - this.requiredNature = Array.isArray(nature) ? nature : [nature]; + this.requiredNature = Array.isArray(nature) ? nature : [ nature ]; } override meetsRequirement(scene: BattleScene): boolean { - const partyPokemon = scene.getParty(); + const partyPokemon = scene.getPlayerParty(); if (isNullOrUndefined(partyPokemon) || this.requiredNature?.length < 0) { return false; } @@ -418,10 +476,10 @@ export class NatureRequirement extends EncounterPokemonRequirement { } override getDialogueToken(scene: BattleScene, pokemon?: PlayerPokemon): [string, string] { - if (!isNullOrUndefined(pokemon?.nature) && this.requiredNature.includes(pokemon!.nature)) { - return ["nature", Nature[pokemon!.nature]]; + if (!isNullOrUndefined(pokemon?.nature) && this.requiredNature.includes(pokemon.nature)) { + return [ "nature", Nature[pokemon.nature] ]; } - return ["nature", ""]; + return [ "nature", "" ]; } } @@ -436,11 +494,11 @@ export class TypeRequirement extends EncounterPokemonRequirement { this.excludeFainted = excludeFainted; this.minNumberOfPokemon = minNumberOfPokemon; this.invertQuery = invertQuery; - this.requiredType = Array.isArray(type) ? type : [type]; + this.requiredType = Array.isArray(type) ? type : [ type ]; } override meetsRequirement(scene: BattleScene): boolean { - let partyPokemon = scene.getParty(); + let partyPokemon = scene.getPlayerParty(); if (isNullOrUndefined(partyPokemon)) { return false; @@ -465,9 +523,9 @@ export class TypeRequirement extends EncounterPokemonRequirement { override getDialogueToken(scene: BattleScene, pokemon?: PlayerPokemon): [string, string] { const includedTypes = this.requiredType.filter((ty) => pokemon?.getTypes().includes(ty)); if (includedTypes.length > 0) { - return ["type", Type[includedTypes[0]]]; + return [ "type", Type[includedTypes[0]] ]; } - return ["type", ""]; + return [ "type", "" ]; } } @@ -476,16 +534,18 @@ export class MoveRequirement extends EncounterPokemonRequirement { requiredMoves: Moves[] = []; minNumberOfPokemon: number; invertQuery: boolean; + excludeDisallowedPokemon: boolean; - constructor(moves: Moves | Moves[], minNumberOfPokemon: number = 1, invertQuery: boolean = false) { + constructor(moves: Moves | Moves[], excludeDisallowedPokemon: boolean, minNumberOfPokemon: number = 1, invertQuery: boolean = false) { super(); + this.excludeDisallowedPokemon = excludeDisallowedPokemon; this.minNumberOfPokemon = minNumberOfPokemon; this.invertQuery = invertQuery; - this.requiredMoves = Array.isArray(moves) ? moves : [moves]; + this.requiredMoves = Array.isArray(moves) ? moves : [ moves ]; } override meetsRequirement(scene: BattleScene): boolean { - const partyPokemon = scene.getParty(); + const partyPokemon = scene.getPlayerParty(); if (isNullOrUndefined(partyPokemon) || this.requiredMoves?.length < 0) { return false; } @@ -494,19 +554,24 @@ export class MoveRequirement extends EncounterPokemonRequirement { override queryParty(partyPokemon: PlayerPokemon[]): PlayerPokemon[] { if (!this.invertQuery) { - return partyPokemon.filter((pokemon) => this.requiredMoves.filter((reqMove) => pokemon.moveset.filter((move) => move?.moveId === reqMove).length > 0).length > 0); + // get the Pokemon with at least one move in the required moves list + return partyPokemon.filter((pokemon) => + (!this.excludeDisallowedPokemon || pokemon.isAllowedInBattle()) + && pokemon.moveset.some((move) => move?.moveId && this.requiredMoves.includes(move.moveId))); } else { // for an inverted query, we only want to get the pokemon that don't have ANY of the listed moves - return partyPokemon.filter((pokemon) => this.requiredMoves.filter((reqMove) => pokemon.moveset.filter((move) => move?.moveId === reqMove).length === 0).length === 0); + return partyPokemon.filter((pokemon) => + (!this.excludeDisallowedPokemon || pokemon.isAllowedInBattle()) + && !pokemon.moveset.some((move) => move?.moveId && this.requiredMoves.includes(move.moveId))); } } override getDialogueToken(scene: BattleScene, pokemon?: PlayerPokemon): [string, string] { const includedMoves = pokemon?.moveset.filter((move) => move?.moveId && this.requiredMoves.includes(move.moveId)); if (includedMoves && includedMoves.length > 0 && includedMoves[0]) { - return ["move", includedMoves[0].getName()]; + return [ "move", includedMoves[0].getName() ]; } - return ["move", ""]; + return [ "move", "" ]; } } @@ -525,11 +590,11 @@ export class CompatibleMoveRequirement extends EncounterPokemonRequirement { super(); this.minNumberOfPokemon = minNumberOfPokemon; this.invertQuery = invertQuery; - this.requiredMoves = Array.isArray(learnableMove) ? learnableMove : [learnableMove]; + this.requiredMoves = Array.isArray(learnableMove) ? learnableMove : [ learnableMove ]; } override meetsRequirement(scene: BattleScene): boolean { - const partyPokemon = scene.getParty(); + const partyPokemon = scene.getPlayerParty(); if (isNullOrUndefined(partyPokemon) || this.requiredMoves?.length < 0) { return false; } @@ -548,9 +613,9 @@ export class CompatibleMoveRequirement extends EncounterPokemonRequirement { override getDialogueToken(scene: BattleScene, pokemon?: PlayerPokemon): [string, string] { const includedCompatMoves = this.requiredMoves.filter((reqMove) => pokemon?.compatibleTms.filter((tm) => !pokemon.moveset.find(m => m?.moveId === tm)).includes(reqMove)); if (includedCompatMoves.length > 0) { - return ["compatibleMove", Moves[includedCompatMoves[0]]]; + return [ "compatibleMove", Moves[includedCompatMoves[0]] ]; } - return ["compatibleMove", ""]; + return [ "compatibleMove", "" ]; } } @@ -559,16 +624,18 @@ export class AbilityRequirement extends EncounterPokemonRequirement { requiredAbilities: Abilities[]; minNumberOfPokemon: number; invertQuery: boolean; + excludeDisallowedPokemon: boolean; - constructor(abilities: Abilities | Abilities[], minNumberOfPokemon: number = 1, invertQuery: boolean = false) { + constructor(abilities: Abilities | Abilities[], excludeDisallowedPokemon: boolean, minNumberOfPokemon: number = 1, invertQuery: boolean = false) { super(); + this.excludeDisallowedPokemon = excludeDisallowedPokemon; this.minNumberOfPokemon = minNumberOfPokemon; this.invertQuery = invertQuery; - this.requiredAbilities = Array.isArray(abilities) ? abilities : [abilities]; + this.requiredAbilities = Array.isArray(abilities) ? abilities : [ abilities ]; } override meetsRequirement(scene: BattleScene): boolean { - const partyPokemon = scene.getParty(); + const partyPokemon = scene.getPlayerParty(); if (isNullOrUndefined(partyPokemon) || this.requiredAbilities?.length < 0) { return false; } @@ -577,18 +644,23 @@ export class AbilityRequirement extends EncounterPokemonRequirement { override queryParty(partyPokemon: PlayerPokemon[]): PlayerPokemon[] { if (!this.invertQuery) { - return partyPokemon.filter((pokemon) => this.requiredAbilities.some((ability) => pokemon.getAbility().id === ability)); + return partyPokemon.filter((pokemon) => + (!this.excludeDisallowedPokemon || pokemon.isAllowedInBattle()) + && this.requiredAbilities.some((ability) => pokemon.hasAbility(ability, false))); } else { - // for an inverted query, we only want to get the pokemon that don't have ANY of the listed abilitiess - return partyPokemon.filter((pokemon) => this.requiredAbilities.filter((ability) => pokemon.getAbility().id === ability).length === 0); + // for an inverted query, we only want to get the pokemon that don't have ANY of the listed abilities + return partyPokemon.filter((pokemon) => + (!this.excludeDisallowedPokemon || pokemon.isAllowedInBattle()) + && this.requiredAbilities.filter((ability) => pokemon.hasAbility(ability, false)).length === 0); } } - override getDialogueToken(scene: BattleScene, pokemon?: PlayerPokemon): [string, string] { - if (pokemon?.getAbility().id && this.requiredAbilities.some(a => pokemon.getAbility().id === a)) { - return ["ability", pokemon.getAbility().name]; + override getDialogueToken(_scene: BattleScene, pokemon?: PlayerPokemon): [string, string] { + const matchingAbility = this.requiredAbilities.find(a => pokemon?.hasAbility(a, false)); + if (!isNullOrUndefined(matchingAbility)) { + return [ "ability", allAbilities[matchingAbility].name ]; } - return ["ability", ""]; + return [ "ability", "" ]; } } @@ -601,11 +673,11 @@ export class StatusEffectRequirement extends EncounterPokemonRequirement { super(); this.minNumberOfPokemon = minNumberOfPokemon; this.invertQuery = invertQuery; - this.requiredStatusEffect = Array.isArray(statusEffect) ? statusEffect : [statusEffect]; + this.requiredStatusEffect = Array.isArray(statusEffect) ? statusEffect : [ statusEffect ]; } override meetsRequirement(scene: BattleScene): boolean { - const partyPokemon = scene.getParty(); + const partyPokemon = scene.getPlayerParty(); if (isNullOrUndefined(partyPokemon) || this.requiredStatusEffect?.length < 0) { return false; } @@ -620,7 +692,7 @@ export class StatusEffectRequirement extends EncounterPokemonRequirement { return this.requiredStatusEffect.some((statusEffect) => { if (statusEffect === StatusEffect.NONE) { // StatusEffect.NONE also checks for null or undefined status - return isNullOrUndefined(pokemon.status) || isNullOrUndefined(pokemon.status!.effect) || pokemon.status?.effect === statusEffect; + return isNullOrUndefined(pokemon.status) || isNullOrUndefined(pokemon.status.effect) || pokemon.status.effect === statusEffect; } else { return pokemon.status?.effect === statusEffect; } @@ -628,12 +700,11 @@ export class StatusEffectRequirement extends EncounterPokemonRequirement { }); } else { // for an inverted query, we only want to get the pokemon that don't have ANY of the listed StatusEffects - // return partyPokemon.filter((pokemon) => this.requiredStatusEffect.filter((statusEffect) => pokemon.status?.effect === statusEffect).length === 0); return partyPokemon.filter((pokemon) => { return !this.requiredStatusEffect.some((statusEffect) => { if (statusEffect === StatusEffect.NONE) { // StatusEffect.NONE also checks for null or undefined status - return isNullOrUndefined(pokemon.status) || isNullOrUndefined(pokemon.status!.effect) || pokemon.status?.effect === statusEffect; + return isNullOrUndefined(pokemon.status) || isNullOrUndefined(pokemon.status.effect) || pokemon.status.effect === statusEffect; } else { return pokemon.status?.effect === statusEffect; } @@ -645,14 +716,14 @@ export class StatusEffectRequirement extends EncounterPokemonRequirement { override getDialogueToken(scene: BattleScene, pokemon?: PlayerPokemon): [string, string] { const reqStatus = this.requiredStatusEffect.filter((a) => { if (a === StatusEffect.NONE) { - return isNullOrUndefined(pokemon?.status) || isNullOrUndefined(pokemon!.status!.effect) || pokemon!.status!.effect === a; + return isNullOrUndefined(pokemon?.status) || isNullOrUndefined(pokemon.status.effect) || pokemon.status.effect === a; } return pokemon!.status?.effect === a; }); if (reqStatus.length > 0) { - return ["status", StatusEffect[reqStatus[0]]]; + return [ "status", StatusEffect[reqStatus[0]] ]; } - return ["status", ""]; + return [ "status", "" ]; } } @@ -671,11 +742,11 @@ export class CanFormChangeWithItemRequirement extends EncounterPokemonRequiremen super(); this.minNumberOfPokemon = minNumberOfPokemon; this.invertQuery = invertQuery; - this.requiredFormChangeItem = Array.isArray(formChangeItem) ? formChangeItem : [formChangeItem]; + this.requiredFormChangeItem = Array.isArray(formChangeItem) ? formChangeItem : [ formChangeItem ]; } override meetsRequirement(scene: BattleScene): boolean { - const partyPokemon = scene.getParty(); + const partyPokemon = scene.getPlayerParty(); if (isNullOrUndefined(partyPokemon) || this.requiredFormChangeItem?.length < 0) { return false; } @@ -707,9 +778,9 @@ export class CanFormChangeWithItemRequirement extends EncounterPokemonRequiremen override getDialogueToken(scene: BattleScene, pokemon?: PlayerPokemon): [string, string] { const requiredItems = this.requiredFormChangeItem.filter((formChangeItem) => this.filterByForm(pokemon, formChangeItem)); if (requiredItems.length > 0) { - return ["formChangeItem", FormChangeItem[requiredItems[0]]]; + return [ "formChangeItem", FormChangeItem[requiredItems[0]] ]; } - return ["formChangeItem", ""]; + return [ "formChangeItem", "" ]; } } @@ -723,11 +794,11 @@ export class CanEvolveWithItemRequirement extends EncounterPokemonRequirement { super(); this.minNumberOfPokemon = minNumberOfPokemon; this.invertQuery = invertQuery; - this.requiredEvolutionItem = Array.isArray(evolutionItems) ? evolutionItems : [evolutionItems]; + this.requiredEvolutionItem = Array.isArray(evolutionItems) ? evolutionItems : [ evolutionItems ]; } override meetsRequirement(scene: BattleScene): boolean { - const partyPokemon = scene.getParty(); + const partyPokemon = scene.getPlayerParty(); if (isNullOrUndefined(partyPokemon) || this.requiredEvolutionItem?.length < 0) { return false; } @@ -757,9 +828,9 @@ export class CanEvolveWithItemRequirement extends EncounterPokemonRequirement { override getDialogueToken(scene: BattleScene, pokemon?: PlayerPokemon): [string, string] { const requiredItems = this.requiredEvolutionItem.filter((evoItem) => this.filterByEvo(pokemon, evoItem)); if (requiredItems.length > 0) { - return ["evolutionItem", EvolutionItem[requiredItems[0]]]; + return [ "evolutionItem", EvolutionItem[requiredItems[0]] ]; } - return ["evolutionItem", ""]; + return [ "evolutionItem", "" ]; } } @@ -767,16 +838,18 @@ export class HeldItemRequirement extends EncounterPokemonRequirement { requiredHeldItemModifiers: string[]; minNumberOfPokemon: number; invertQuery: boolean; + requireTransferable: boolean; - constructor(heldItem: string | string[], minNumberOfPokemon: number = 1, invertQuery: boolean = false) { + constructor(heldItem: string | string[], minNumberOfPokemon: number = 1, invertQuery: boolean = false, requireTransferable: boolean = true) { super(); this.minNumberOfPokemon = minNumberOfPokemon; this.invertQuery = invertQuery; - this.requiredHeldItemModifiers = Array.isArray(heldItem) ? heldItem : [heldItem]; + this.requiredHeldItemModifiers = Array.isArray(heldItem) ? heldItem : [ heldItem ]; + this.requireTransferable = requireTransferable; } override meetsRequirement(scene: BattleScene): boolean { - const partyPokemon = scene.getParty(); + const partyPokemon = scene.getPlayerParty(); if (isNullOrUndefined(partyPokemon)) { return false; } @@ -787,26 +860,28 @@ export class HeldItemRequirement extends EncounterPokemonRequirement { if (!this.invertQuery) { return partyPokemon.filter((pokemon) => this.requiredHeldItemModifiers.some((heldItem) => { return pokemon.getHeldItems().some((it) => { - return it.constructor.name === heldItem; + return it.constructor.name === heldItem && (!this.requireTransferable || it.isTransferable); }); })); } else { // for an inverted query, we only want to get the pokemon that have any held items that are NOT in requiredHeldItemModifiers // E.g. functions as a blacklist return partyPokemon.filter((pokemon) => pokemon.getHeldItems().filter((it) => { - return !this.requiredHeldItemModifiers.some(heldItem => it.constructor.name === heldItem); + return !this.requiredHeldItemModifiers.some(heldItem => it.constructor.name === heldItem) + && (!this.requireTransferable || it.isTransferable); }).length > 0); } } override getDialogueToken(scene: BattleScene, pokemon?: PlayerPokemon): [string, string] { const requiredItems = pokemon?.getHeldItems().filter((it) => { - return this.requiredHeldItemModifiers.some(heldItem => it.constructor.name === heldItem); + return this.requiredHeldItemModifiers.some(heldItem => it.constructor.name === heldItem) + && (!this.requireTransferable || it.isTransferable); }); if (requiredItems && requiredItems.length > 0) { - return ["heldItem", requiredItems[0].type.name]; + return [ "heldItem", requiredItems[0].type.name ]; } - return ["heldItem", ""]; + return [ "heldItem", "" ]; } } @@ -814,16 +889,18 @@ export class AttackTypeBoosterHeldItemTypeRequirement extends EncounterPokemonRe requiredHeldItemTypes: Type[]; minNumberOfPokemon: number; invertQuery: boolean; + requireTransferable: boolean; - constructor(heldItemTypes: Type | Type[], minNumberOfPokemon: number = 1, invertQuery: boolean = false) { + constructor(heldItemTypes: Type | Type[], minNumberOfPokemon: number = 1, invertQuery: boolean = false, requireTransferable: boolean = true) { super(); this.minNumberOfPokemon = minNumberOfPokemon; this.invertQuery = invertQuery; - this.requiredHeldItemTypes = Array.isArray(heldItemTypes) ? heldItemTypes : [heldItemTypes]; + this.requiredHeldItemTypes = Array.isArray(heldItemTypes) ? heldItemTypes : [ heldItemTypes ]; + this.requireTransferable = requireTransferable; } override meetsRequirement(scene: BattleScene): boolean { - const partyPokemon = scene.getParty(); + const partyPokemon = scene.getPlayerParty(); if (isNullOrUndefined(partyPokemon)) { return false; } @@ -834,26 +911,34 @@ export class AttackTypeBoosterHeldItemTypeRequirement extends EncounterPokemonRe if (!this.invertQuery) { return partyPokemon.filter((pokemon) => this.requiredHeldItemTypes.some((heldItemType) => { return pokemon.getHeldItems().some((it) => { - return it instanceof AttackTypeBoosterModifier && (it.type as AttackTypeBoosterModifierType).moveType === heldItemType; + return it instanceof AttackTypeBoosterModifier + && (it.type as AttackTypeBoosterModifierType).moveType === heldItemType + && (!this.requireTransferable || it.isTransferable); }); })); } else { // for an inverted query, we only want to get the pokemon that have any held items that are NOT in requiredHeldItemModifiers // E.g. functions as a blacklist return partyPokemon.filter((pokemon) => pokemon.getHeldItems().filter((it) => { - return !this.requiredHeldItemTypes.some(heldItemType => it instanceof AttackTypeBoosterModifier && (it.type as AttackTypeBoosterModifierType).moveType === heldItemType); + return !this.requiredHeldItemTypes.some(heldItemType => + it instanceof AttackTypeBoosterModifier + && (it.type as AttackTypeBoosterModifierType).moveType === heldItemType + && (!this.requireTransferable || it.isTransferable)); }).length > 0); } } override getDialogueToken(scene: BattleScene, pokemon?: PlayerPokemon): [string, string] { const requiredItems = pokemon?.getHeldItems().filter((it) => { - return this.requiredHeldItemTypes.some(heldItemType => it instanceof AttackTypeBoosterModifier && (it.type as AttackTypeBoosterModifierType).moveType === heldItemType); + return this.requiredHeldItemTypes.some(heldItemType => + it instanceof AttackTypeBoosterModifier + && (it.type as AttackTypeBoosterModifierType).moveType === heldItemType) + && (!this.requireTransferable || it.isTransferable); }); if (requiredItems && requiredItems.length > 0) { - return ["heldItem", requiredItems[0].type.name]; + return [ "heldItem", requiredItems[0].type.name ]; } - return ["heldItem", ""]; + return [ "heldItem", "" ]; } } @@ -872,7 +957,7 @@ export class LevelRequirement extends EncounterPokemonRequirement { override meetsRequirement(scene: BattleScene): boolean { // Party Pokemon inside required level range if (!isNullOrUndefined(this.requiredLevelRange) && this.requiredLevelRange[0] <= this.requiredLevelRange[1]) { - const partyPokemon = scene.getParty(); + const partyPokemon = scene.getPlayerParty(); const pokemonInRange = this.queryParty(partyPokemon); if (pokemonInRange.length < this.minNumberOfPokemon) { return false; @@ -891,7 +976,7 @@ export class LevelRequirement extends EncounterPokemonRequirement { } override getDialogueToken(scene: BattleScene, pokemon?: PlayerPokemon): [string, string] { - return ["level", pokemon?.level.toString() ?? ""]; + return [ "level", pokemon?.level.toString() ?? "" ]; } } @@ -910,7 +995,7 @@ export class FriendshipRequirement extends EncounterPokemonRequirement { override meetsRequirement(scene: BattleScene): boolean { // Party Pokemon inside required friendship range if (!isNullOrUndefined(this.requiredFriendshipRange) && this.requiredFriendshipRange[0] <= this.requiredFriendshipRange[1]) { - const partyPokemon = scene.getParty(); + const partyPokemon = scene.getPlayerParty(); const pokemonInRange = this.queryParty(partyPokemon); if (pokemonInRange.length < this.minNumberOfPokemon) { return false; @@ -929,7 +1014,7 @@ export class FriendshipRequirement extends EncounterPokemonRequirement { } override getDialogueToken(scene: BattleScene, pokemon?: PlayerPokemon): [string, string] { - return ["friendship", pokemon?.friendship.toString() ?? ""]; + return [ "friendship", pokemon?.friendship.toString() ?? "" ]; } } @@ -953,7 +1038,7 @@ export class HealthRatioRequirement extends EncounterPokemonRequirement { override meetsRequirement(scene: BattleScene): boolean { // Party Pokemon's health inside required health range if (!isNullOrUndefined(this.requiredHealthRange) && this.requiredHealthRange[0] <= this.requiredHealthRange[1]) { - const partyPokemon = scene.getParty(); + const partyPokemon = scene.getPlayerParty(); const pokemonInRange = this.queryParty(partyPokemon); if (pokemonInRange.length < this.minNumberOfPokemon) { return false; @@ -974,10 +1059,11 @@ export class HealthRatioRequirement extends EncounterPokemonRequirement { } override getDialogueToken(scene: BattleScene, pokemon?: PlayerPokemon): [string, string] { - if (!isNullOrUndefined(pokemon?.getHpRatio())) { - return ["healthRatio", Math.floor(pokemon!.getHpRatio() * 100).toString() + "%"]; + const hpRatio = pokemon?.getHpRatio(); + if (!isNullOrUndefined(hpRatio)) { + return [ "healthRatio", Math.floor(hpRatio * 100).toString() + "%" ]; } - return ["healthRatio", ""]; + return [ "healthRatio", "" ]; } } @@ -996,7 +1082,7 @@ export class WeightRequirement extends EncounterPokemonRequirement { override meetsRequirement(scene: BattleScene): boolean { // Party Pokemon's weight inside required weight range if (!isNullOrUndefined(this.requiredWeightRange) && this.requiredWeightRange[0] <= this.requiredWeightRange[1]) { - const partyPokemon = scene.getParty(); + const partyPokemon = scene.getPlayerParty(); const pokemonInRange = this.queryParty(partyPokemon); if (pokemonInRange.length < this.minNumberOfPokemon) { return false; @@ -1015,8 +1101,7 @@ export class WeightRequirement extends EncounterPokemonRequirement { } override getDialogueToken(scene: BattleScene, pokemon?: PlayerPokemon): [string, string] { - return ["weight", pokemon?.getWeight().toString() ?? ""]; + return [ "weight", pokemon?.getWeight().toString() ?? "" ]; } } - diff --git a/src/data/mystery-encounters/mystery-encounter.ts b/src/data/mystery-encounters/mystery-encounter.ts index a204ea848da..e341da4e435 100644 --- a/src/data/mystery-encounters/mystery-encounter.ts +++ b/src/data/mystery-encounters/mystery-encounter.ts @@ -5,7 +5,7 @@ import { MysteryEncounterType } from "#enums/mystery-encounter-type"; import BattleScene from "#app/battle-scene"; import MysteryEncounterIntroVisuals, { MysteryEncounterSpriteConfig } from "#app/field/mystery-encounter-intro"; import * as Utils from "#app/utils"; -import { StatusEffect } from "../status-effect"; +import { StatusEffect } from "#enums/status-effect"; import MysteryEncounterDialogue, { OptionTextDisplay } from "./mystery-encounter-dialogue"; import MysteryEncounterOption, { MysteryEncounterOptionBuilder, OptionPhaseCallback } from "./mystery-encounter-option"; import { EncounterPokemonRequirement, EncounterSceneRequirement, HealthRatioRequirement, PartySizeRequirement, StatusEffectRequirement, WaveRangeRequirement } from "./mystery-encounter-requirements"; @@ -15,6 +15,7 @@ import { MysteryEncounterMode } from "#enums/mystery-encounter-mode"; import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode"; import { GameModes } from "#app/game-mode"; import { EncounterAnim } from "#enums/encounter-anims"; +import { Challenges } from "#enums/challenges"; export interface EncounterStartOfBattleEffect { sourcePokemon?: Pokemon; @@ -25,6 +26,9 @@ export interface EncounterStartOfBattleEffect { followUp?: boolean; } +const DEFAULT_MAX_ALLOWED_ENCOUNTERS = 2; +const DEFAULT_MAX_ALLOWED_ROGUE_ENCOUNTERS = 1; + /** * Used by {@linkcode MysteryEncounterBuilder} class to define required/optional properties on the {@linkcode MysteryEncounter} class when building. * @@ -37,16 +41,19 @@ export interface IMysteryEncounter { spriteConfigs: MysteryEncounterSpriteConfig[]; encounterTier: MysteryEncounterTier; encounterAnimations?: EncounterAnim[]; - disabledGameModes?: GameModes[]; + disallowedGameModes?: GameModes[]; + disallowedChallenges?: Challenges[]; hideBattleIntroMessage: boolean; autoHideIntroVisuals: boolean; enterIntroVisualsFromRight: boolean; catchAllowed: boolean; + fleeAllowed: boolean; continuousEncounter: boolean; maxAllowedEncounters: number; hasBattleAnimationsWithoutTargets: boolean; skipEnemyBattleTurns: boolean; skipToFightInput: boolean; + preventGameStatsUpdates: boolean; onInit?: (scene: BattleScene) => boolean; onVisualsStart?: (scene: BattleScene) => boolean; @@ -89,7 +96,11 @@ export default class MysteryEncounter implements IMysteryEncounter { /** * If specified, defines any game modes where the {@linkcode MysteryEncounter} should *NOT* spawn */ - disabledGameModes?: GameModes[]; + disallowedGameModes?: GameModes[]; + /** + * If specified, defines any challenges (from Challenge game mode) where the {@linkcode MysteryEncounter} should *NOT* spawn + */ + disallowedChallenges?: Challenges[]; /** * If true, hides "A Wild X Appeared" etc. messages * Default true @@ -110,6 +121,11 @@ export default class MysteryEncounter implements IMysteryEncounter { * Default false */ catchAllowed: boolean; + /** + * If true, allows fleeing from a wild encounter (trainer battle MEs auto-disable fleeing) + * Default true + */ + fleeAllowed: boolean; /** * If true, encounter will continuously run through multiple battles/puzzles/etc. instead of going to next wave * MUST EVENTUALLY BE DISABLED TO CONTINUE TO NEXT WAVE @@ -135,6 +151,10 @@ export default class MysteryEncounter implements IMysteryEncounter { * If true, will skip COMMAND input and go straight to FIGHT (move select) input menu */ skipToFightInput: boolean; + /** + * If true, will prevent updating {@linkcode GameStats} for encountering and/or defeating Pokemon + */ + preventGameStatsUpdates: boolean; // #region Event callback functions @@ -152,6 +172,11 @@ export default class MysteryEncounter implements IMysteryEncounter { doEncounterRewards?: (scene: BattleScene) => boolean; /** Will execute callback during VictoryPhase of a continuousEncounter */ doContinueEncounter?: (scene: BattleScene) => Promise; + /** + * Can perform special logic when a ME battle is lost, before GameOver/battle retry prompt. + * Should return `true` if it is treated as "real" Game Over, `false` if not. + */ + onGameOver?: (scene: BattleScene) => boolean; /** * Requirements @@ -170,7 +195,7 @@ export default class MysteryEncounter implements IMysteryEncounter { secondaryPokemon?: PlayerPokemon[]; // #region Post-construct / Auto-populated params - + localizationKey: string; /** * Dialogue object containing all the dialogue, messages, tooltips, etc. for an encounter */ @@ -244,10 +269,11 @@ export default class MysteryEncounter implements IMysteryEncounter { Object.assign(this, encounter); } this.encounterTier = this.encounterTier ?? MysteryEncounterTier.COMMON; + this.localizationKey = this.localizationKey ?? ""; this.dialogue = this.dialogue ?? {}; - this.spriteConfigs = this.spriteConfigs ? [...this.spriteConfigs] : []; - // Default max is 1 for ROGUE encounters, 3 for others - this.maxAllowedEncounters = this.maxAllowedEncounters ?? this.encounterTier === MysteryEncounterTier.ROGUE ? 1 : 3; + this.spriteConfigs = this.spriteConfigs ? [ ...this.spriteConfigs ] : []; + // Default max is 1 for ROGUE encounters, 2 for others + this.maxAllowedEncounters = this.maxAllowedEncounters ?? this.encounterTier === MysteryEncounterTier.ROGUE ? DEFAULT_MAX_ALLOWED_ROGUE_ENCOUNTERS : DEFAULT_MAX_ALLOWED_ENCOUNTERS; this.encounterMode = MysteryEncounterMode.DEFAULT; this.requirements = this.requirements ? this.requirements : []; this.hideBattleIntroMessage = this.hideBattleIntroMessage ?? false; @@ -288,7 +314,7 @@ export default class MysteryEncounter implements IMysteryEncounter { * @param pokemon */ pokemonMeetsPrimaryRequirements(scene: BattleScene, pokemon: Pokemon): boolean { - return !this.primaryPokemonRequirements.some(req => !req.queryParty(scene.getParty()).map(p => p.id).includes(pokemon.id)); + return !this.primaryPokemonRequirements.some(req => !req.queryParty(scene.getPlayerParty()).map(p => p.id).includes(pokemon.id)); } /** @@ -300,18 +326,18 @@ export default class MysteryEncounter implements IMysteryEncounter { */ private meetsPrimaryRequirementAndPrimaryPokemonSelected(scene: BattleScene): boolean { if (!this.primaryPokemonRequirements || this.primaryPokemonRequirements.length === 0) { - const activeMon = scene.getParty().filter(p => p.isActive(true)); + const activeMon = scene.getPlayerParty().filter(p => p.isActive(true)); if (activeMon.length > 0) { this.primaryPokemon = activeMon[0]; } else { - this.primaryPokemon = scene.getParty().filter(p => !p.isFainted())[0]; + this.primaryPokemon = scene.getPlayerParty().filter(p => p.isAllowedInBattle())[0]; } return true; } - let qualified: PlayerPokemon[] = scene.getParty(); + let qualified: PlayerPokemon[] = scene.getPlayerParty(); for (const req of this.primaryPokemonRequirements) { if (req.meetsRequirement(scene)) { - qualified = qualified.filter(pkmn => req.queryParty(scene.getParty()).includes(pkmn)); + qualified = qualified.filter(pkmn => req.queryParty(scene.getPlayerParty()).includes(pkmn)); } else { this.primaryPokemon = undefined; return false; @@ -368,10 +394,10 @@ export default class MysteryEncounter implements IMysteryEncounter { return true; } - let qualified: PlayerPokemon[] = scene.getParty(); + let qualified: PlayerPokemon[] = scene.getPlayerParty(); for (const req of this.secondaryPokemonRequirements) { if (req.meetsRequirement(scene)) { - qualified = qualified.filter(pkmn => req.queryParty(scene.getParty()).includes(pkmn)); + qualified = qualified.filter(pkmn => req.queryParty(scene.getPlayerParty()).includes(pkmn)); } else { this.secondaryPokemon = []; return false; @@ -508,6 +534,7 @@ export class MysteryEncounterBuilder implements Partial { options: [MysteryEncounterOption, MysteryEncounterOption, ...MysteryEncounterOption[]]; enemyPartyConfigs: EnemyPartyConfig[] = []; + localizationKey: string = ""; dialogue: MysteryEncounterDialogue = {}; requirements: EncounterSceneRequirement[] = []; primaryPokemonRequirements: EncounterPokemonRequirement[] = []; @@ -520,11 +547,13 @@ export class MysteryEncounterBuilder implements Partial { enterIntroVisualsFromRight: boolean = false; continuousEncounter: boolean = false; catchAllowed: boolean = false; + fleeAllowed: boolean = true; lockEncounterRewardTiers: boolean = false; startOfBattleEffectsComplete: boolean = false; hasBattleAnimationsWithoutTargets: boolean = false; skipEnemyBattleTurns: boolean = false; skipToFightInput: boolean = false; + preventGameStatsUpdates: boolean = false; maxAllowedEncounters: number = 3; expMultiplier: number = 1; @@ -552,7 +581,7 @@ export class MysteryEncounterBuilder implements Partial { */ withOption(option: MysteryEncounterOption): this & Pick { if (!this.options) { - const options = [option]; + const options = [ option ]; return Object.assign(this, { options }); } else { this.options.push(option); @@ -580,8 +609,8 @@ export class MysteryEncounterBuilder implements Partial { * There should be at least 2 options defined and no more than 4. * If complex use {@linkcode MysteryEncounterBuilder.withOption} * - * @param dialogue - {@linkcode OptionTextDisplay} - * @param callback - {@linkcode OptionPhaseCallback} + * @param dialogue {@linkcode OptionTextDisplay} + * @param callback {@linkcode OptionPhaseCallback} * @returns */ withSimpleDexProgressOption(dialogue: OptionTextDisplay, callback: OptionPhaseCallback): this & Pick { @@ -603,14 +632,24 @@ export class MysteryEncounterBuilder implements Partial { } withIntroDialogue(dialogue: MysteryEncounterDialogue["intro"] = []): this { - this.dialogue = {...this.dialogue, intro: dialogue }; + this.dialogue = { ...this.dialogue, intro: dialogue }; return this; } - withIntro({spriteConfigs, dialogue} : {spriteConfigs: MysteryEncounterSpriteConfig[], dialogue?: MysteryEncounterDialogue["intro"]}) { + withIntro({ spriteConfigs, dialogue } : {spriteConfigs: MysteryEncounterSpriteConfig[], dialogue?: MysteryEncounterDialogue["intro"]}) { return this.withIntroSpriteConfigs(spriteConfigs).withIntroDialogue(dialogue); } + /** + * Sets the localization key used by the encounter + * @param localizationKey the string used as the key + * @returns `this` + */ + setLocalizationKey(localizationKey: string): this { + this.localizationKey = localizationKey; + return this; + } + /** * OPTIONAL */ @@ -639,18 +678,28 @@ export class MysteryEncounterBuilder implements Partial { * @returns */ withAnimations(...encounterAnimations: EncounterAnim[]): this & Required> { - const animations = Array.isArray(encounterAnimations) ? encounterAnimations : [encounterAnimations]; + const animations = Array.isArray(encounterAnimations) ? encounterAnimations : [ encounterAnimations ]; return Object.assign(this, { encounterAnimations: animations }); } /** * Defines any game modes where the Mystery Encounter should *NOT* spawn * @returns - * @param disabledGameModes + * @param disallowedGameModes */ - withDisabledGameModes(...disabledGameModes: GameModes[]): this & Required> { - const gameModes = Array.isArray(disabledGameModes) ? disabledGameModes : [disabledGameModes]; - return Object.assign(this, { disabledGameModes: gameModes }); + withDisallowedGameModes(...disallowedGameModes: GameModes[]): this & Required> { + const gameModes = Array.isArray(disallowedGameModes) ? disallowedGameModes : [ disallowedGameModes ]; + return Object.assign(this, { disallowedGameModes: gameModes }); + } + + /** + * Defines any challenges (from Challenge game mode) where the Mystery Encounter should *NOT* spawn + * @returns + * @param disallowedChallenges + */ + withDisallowedChallenges(...disallowedChallenges: Challenges[]): this & Required> { + const challenges = Array.isArray(disallowedChallenges) ? disallowedChallenges : [ disallowedChallenges ]; + return Object.assign(this, { disallowedChallenges: challenges }); } /** @@ -692,6 +741,14 @@ export class MysteryEncounterBuilder implements Partial { return Object.assign(this, { skipToFightInput }); } + /** + * If true, will prevent updating {@linkcode GameStats} for encountering and/or defeating Pokemon + * Default `false` + */ + withPreventGameStatsUpdates(preventGameStatsUpdates: boolean): this & Required> { + return Object.assign(this, { preventGameStatsUpdates }); + } + /** * Sets the maximum number of times that an encounter can spawn in a given Classic run * @param maxAllowedEncounters @@ -724,7 +781,7 @@ export class MysteryEncounterBuilder implements Partial { * @returns */ withSceneWaveRangeRequirement(min: number, max?: number): this & Required> { - return this.withSceneRequirement(new WaveRangeRequirement([min, max ?? min])); + return this.withSceneRequirement(new WaveRangeRequirement([ min, max ?? min ])); } /** @@ -732,11 +789,11 @@ export class MysteryEncounterBuilder implements Partial { * * @param min min wave (or exact size if only min is given) * @param max optional max size. If not given, defaults to min => exact wave - * @param excludeFainted - if true, only counts unfainted mons + * @param excludeDisallowedPokemon if true, only counts allowed (legal in Challenge/unfainted) mons * @returns */ - withScenePartySizeRequirement(min: number, max?: number, excludeFainted: boolean = false): this & Required> { - return this.withSceneRequirement(new PartySizeRequirement([min, max ?? min], excludeFainted)); + withScenePartySizeRequirement(min: number, max?: number, excludeDisallowedPokemon: boolean = false): this & Required> { + return this.withSceneRequirement(new PartySizeRequirement([ min, max ?? min ], excludeDisallowedPokemon)); } /** @@ -798,7 +855,7 @@ export class MysteryEncounterBuilder implements Partial { * NOTE: If rewards are dependent on options selected, runtime data, etc., * It may be better to programmatically set doEncounterRewards elsewhere. * There is a helper function in mystery-encounter utils, setEncounterRewards(), which can be called programmatically to set rewards - * @param doEncounterRewards - synchronous callback function to perform during rewards phase of the encounter + * @param doEncounterRewards Synchronous callback function to perform during rewards phase of the encounter * @returns */ withRewards(doEncounterRewards: (scene: BattleScene) => boolean): this & Required> { @@ -812,7 +869,7 @@ export class MysteryEncounterBuilder implements Partial { * NOTE: If rewards are dependent on options selected, runtime data, etc., * It may be better to programmatically set doEncounterExp elsewhere. * There is a helper function in mystery-encounter utils, setEncounterExp(), which can be called programmatically to set rewards - * @param doEncounterExp - synchronous callback function to perform during rewards phase of the encounter + * @param doEncounterExp Synchronous callback function to perform during rewards phase of the encounter * @returns */ withExp(doEncounterExp: (scene: BattleScene) => boolean): this & Required> { @@ -823,7 +880,7 @@ export class MysteryEncounterBuilder implements Partial { * Can be used to perform init logic before intro visuals are shown and before the MysteryEncounterPhase begins * Useful for performing things like procedural generation of intro sprites, etc. * - * @param onInit - synchronous callback function to perform as soon as the encounter is selected for the next phase + * @param onInit Synchronous callback function to perform as soon as the encounter is selected for the next phase * @returns */ withOnInit(onInit: (scene: BattleScene) => boolean): this & Required> { @@ -833,7 +890,7 @@ export class MysteryEncounterBuilder implements Partial { /** * Can be used to perform some extra logic (usually animations) when the enemy field is finished sliding in * - * @param onVisualsStart - synchronous callback function to perform as soon as the enemy field finishes sliding in + * @param onVisualsStart Synchronous callback function to perform as soon as the enemy field finishes sliding in * @returns */ withOnVisualsStart(onVisualsStart: (scene: BattleScene) => boolean): this & Required> { @@ -843,7 +900,7 @@ export class MysteryEncounterBuilder implements Partial { /** * Can set whether catching is allowed or not on the encounter * This flag can also be programmatically set inside option event functions or elsewhere - * @param catchAllowed - if true, allows enemy pokemon to be caught during the encounter + * @param catchAllowed If `true`, allows enemy pokemon to be caught during the encounter * @returns */ withCatchAllowed(catchAllowed: boolean): this & Required> { @@ -851,7 +908,16 @@ export class MysteryEncounterBuilder implements Partial { } /** - * @param hideBattleIntroMessage - if true, will not show the trainerAppeared/wildAppeared/bossAppeared message for an encounter + * Can set whether fleeing is allowed or not on the encounter + * @param fleeAllowed If `false`, prevents fleeing from a wild battle (trainer battle MEs already have flee disabled) + * @returns + */ + withFleeAllowed(fleeAllowed: boolean): this & Required> { + return Object.assign(this, { fleeAllowed }); + } + + /** + * @param hideBattleIntroMessage If `true`, will not show the trainerAppeared/wildAppeared/bossAppeared message for an encounter * @returns */ withHideWildIntroMessage(hideBattleIntroMessage: boolean): this & Required> { @@ -859,7 +925,7 @@ export class MysteryEncounterBuilder implements Partial { } /** - * @param autoHideIntroVisuals - if false, will not hide the intro visuals that are displayed at the beginning of encounter + * @param autoHideIntroVisuals If `false`, will not hide the intro visuals that are displayed at the beginning of encounter * @returns */ withAutoHideIntroVisuals(autoHideIntroVisuals: boolean): this & Required> { @@ -867,7 +933,7 @@ export class MysteryEncounterBuilder implements Partial { } /** - * @param enterIntroVisualsFromRight - If true, will slide in intro visuals from the right side of the screen. If false, slides in from left, as normal + * @param enterIntroVisualsFromRight If `true`, will slide in intro visuals from the right side of the screen. If false, slides in from left, as normal * Default false * @returns */ @@ -878,7 +944,7 @@ export class MysteryEncounterBuilder implements Partial { /** * Add a title for the encounter * - * @param title - title of the encounter + * @param title Title of the encounter * @returns */ withTitle(title: string): this { @@ -898,7 +964,7 @@ export class MysteryEncounterBuilder implements Partial { /** * Add a description of the encounter * - * @param description - description of the encounter + * @param description Description of the encounter * @returns */ withDescription(description: string): this { @@ -918,7 +984,7 @@ export class MysteryEncounterBuilder implements Partial { /** * Add a query for the encounter * - * @param query - query to use for the encounter + * @param query Query to use for the encounter * @returns */ withQuery(query: string): this { @@ -938,11 +1004,11 @@ export class MysteryEncounterBuilder implements Partial { /** * Add outro dialogue/s for the encounter * - * @param dialogue - outro dialogue/s + * @param dialogue Outro dialogue(s) * @returns */ withOutroDialogue(dialogue: MysteryEncounterDialogue["outro"] = []): this { - this.dialogue = {...this.dialogue, outro: dialogue }; + this.dialogue = { ...this.dialogue, outro: dialogue }; return this; } diff --git a/src/data/mystery-encounters/mystery-encounters.ts b/src/data/mystery-encounters/mystery-encounters.ts index d235ff86861..8c1c3bf6de4 100644 --- a/src/data/mystery-encounters/mystery-encounters.ts +++ b/src/data/mystery-encounters/mystery-encounters.ts @@ -31,6 +31,8 @@ import { BugTypeSuperfanEncounter } from "#app/data/mystery-encounters/encounter import { FunAndGamesEncounter } from "#app/data/mystery-encounters/encounters/fun-and-games-encounter"; import { UncommonBreedEncounter } from "#app/data/mystery-encounters/encounters/uncommon-breed-encounter"; import { GlobalTradeSystemEncounter } from "#app/data/mystery-encounters/encounters/global-trade-system-encounter"; +import { TheExpertPokemonBreederEncounter } from "#app/data/mystery-encounters/encounters/the-expert-pokemon-breeder-encounter"; +import { getBiomeName } from "#app/data/balance/biomes"; /** * Spawn chance: (BASE_MYSTERY_ENCOUNTER_SPAWN_WEIGHT + WIGHT_INCREMENT_ON_SPAWN_MISS * ) / MYSTERY_ENCOUNTER_SPAWN_MAX_WEIGHT @@ -184,7 +186,8 @@ const humanTransitableBiomeEncounters: MysteryEncounterType[] = [ MysteryEncounterType.SHADY_VITAMIN_DEALER, MysteryEncounterType.THE_POKEMON_SALESMAN, MysteryEncounterType.AN_OFFER_YOU_CANT_REFUSE, - MysteryEncounterType.THE_WINSTRATE_CHALLENGE + MysteryEncounterType.THE_WINSTRATE_CHALLENGE, + MysteryEncounterType.THE_EXPERT_POKEMON_BREEDER ]; const civilizationBiomeEncounters: MysteryEncounterType[] = [ @@ -221,71 +224,72 @@ const anyBiomeEncounters: MysteryEncounterType[] = [ * that biome groups do not cover */ export const mysteryEncountersByBiome = new Map([ - [Biome.TOWN, []], - [Biome.PLAINS, [ + [ Biome.TOWN, []], + [ Biome.PLAINS, [ MysteryEncounterType.SLUMBERING_SNORLAX, MysteryEncounterType.ABSOLUTE_AVARICE ]], - [Biome.GRASS, [ + [ Biome.GRASS, [ MysteryEncounterType.SLUMBERING_SNORLAX, MysteryEncounterType.ABSOLUTE_AVARICE ]], - [Biome.TALL_GRASS, [ + [ Biome.TALL_GRASS, [ MysteryEncounterType.ABSOLUTE_AVARICE ]], - [Biome.METROPOLIS, []], - [Biome.FOREST, [ + [ Biome.METROPOLIS, []], + [ Biome.FOREST, [ MysteryEncounterType.SAFARI_ZONE, MysteryEncounterType.ABSOLUTE_AVARICE ]], - - [Biome.SEA, [ + [ Biome.SEA, [ MysteryEncounterType.LOST_AT_SEA ]], - [Biome.SWAMP, [ + [ Biome.SWAMP, [ MysteryEncounterType.SAFARI_ZONE ]], - [Biome.BEACH, []], - [Biome.LAKE, []], - [Biome.SEABED, []], - [Biome.MOUNTAIN, []], - [Biome.BADLANDS, [ + [ Biome.BEACH, []], + [ Biome.LAKE, []], + [ Biome.SEABED, []], + [ Biome.MOUNTAIN, []], + [ Biome.BADLANDS, [ MysteryEncounterType.DANCING_LESSONS ]], - [Biome.CAVE, [ + [ Biome.CAVE, [ MysteryEncounterType.THE_STRONG_STUFF ]], - [Biome.DESERT, [ + [ Biome.DESERT, [ MysteryEncounterType.DANCING_LESSONS ]], - [Biome.ICE_CAVE, []], - [Biome.MEADOW, []], - [Biome.POWER_PLANT, []], - [Biome.VOLCANO, [ + [ Biome.ICE_CAVE, []], + [ Biome.MEADOW, []], + [ Biome.POWER_PLANT, []], + [ Biome.VOLCANO, [ MysteryEncounterType.FIERY_FALLOUT, MysteryEncounterType.DANCING_LESSONS ]], - [Biome.GRAVEYARD, []], - [Biome.DOJO, []], - [Biome.FACTORY, []], - [Biome.RUINS, []], - [Biome.WASTELAND, [ + [ Biome.GRAVEYARD, []], + [ Biome.DOJO, []], + [ Biome.FACTORY, []], + [ Biome.RUINS, []], + [ Biome.WASTELAND, [ MysteryEncounterType.DANCING_LESSONS ]], - [Biome.ABYSS, [ + [ Biome.ABYSS, [ MysteryEncounterType.DANCING_LESSONS ]], - [Biome.SPACE, []], - [Biome.CONSTRUCTION_SITE, []], - [Biome.JUNGLE, [ + [ Biome.SPACE, [ + MysteryEncounterType.THE_EXPERT_POKEMON_BREEDER + ]], + [ Biome.CONSTRUCTION_SITE, []], + [ Biome.JUNGLE, [ MysteryEncounterType.SAFARI_ZONE ]], - [Biome.FAIRY_CAVE, []], - [Biome.TEMPLE, []], - [Biome.SLUM, []], - [Biome.SNOWY_FOREST, []], - [Biome.ISLAND, []], - [Biome.LABORATORY, []] + [ Biome.FAIRY_CAVE, []], + [ Biome.TEMPLE, []], + [ Biome.SLUM, []], + [ Biome.SNOWY_FOREST, []], + [ Biome.ISLAND, []], + [ Biome.LABORATORY, []] ]); export function initMysteryEncounters() { @@ -319,6 +323,7 @@ export function initMysteryEncounters() { allMysteryEncounters[MysteryEncounterType.FUN_AND_GAMES] = FunAndGamesEncounter; allMysteryEncounters[MysteryEncounterType.UNCOMMON_BREED] = UncommonBreedEncounter; allMysteryEncounters[MysteryEncounterType.GLOBAL_TRADE_SYSTEM] = GlobalTradeSystemEncounter; + allMysteryEncounters[MysteryEncounterType.THE_EXPERT_POKEMON_BREEDER] = TheExpertPokemonBreederEncounter; // Add extreme encounters to biome map extremeBiomeEncounters.forEach(encounter => { @@ -358,11 +363,17 @@ export function initMysteryEncounters() { }); // Add ANY biome encounters to biome map - mysteryEncountersByBiome.forEach(biomeEncounters => { + // eslint-disable-next-line + let encounterBiomeTableLog = ""; + mysteryEncountersByBiome.forEach((biomeEncounters, biome) => { anyBiomeEncounters.forEach(encounter => { if (!biomeEncounters.includes(encounter)) { biomeEncounters.push(encounter); } }); + + encounterBiomeTableLog += `${getBiomeName(biome).toUpperCase()}: [${biomeEncounters.map(type => MysteryEncounterType[type].toString().toLowerCase()).sort().join(", ")}]\n`; }); + + //console.debug("All Mystery Encounters by Biome:\n" + encounterBiomeTableLog); } diff --git a/src/data/mystery-encounters/requirements/can-learn-move-requirement.ts b/src/data/mystery-encounters/requirements/can-learn-move-requirement.ts index bbdf2ee5a4d..a2c08938fbe 100644 --- a/src/data/mystery-encounters/requirements/can-learn-move-requirement.ts +++ b/src/data/mystery-encounters/requirements/can-learn-move-requirement.ts @@ -2,7 +2,7 @@ import BattleScene from "#app/battle-scene"; import { Moves } from "#app/enums/moves"; import { PlayerPokemon, PokemonMove } from "#app/field/pokemon"; import { isNullOrUndefined } from "#app/utils"; -import { EncounterPokemonRequirement } from "../mystery-encounter-requirements"; +import { EncounterPokemonRequirement } from "#app/data/mystery-encounters/mystery-encounter-requirements"; /** * {@linkcode CanLearnMoveRequirement} options @@ -28,7 +28,7 @@ export class CanLearnMoveRequirement extends EncounterPokemonRequirement { constructor(requiredMoves: Moves | Moves[], options: CanLearnMoveRequirementOptions = {}) { super(); - this.requiredMoves = Array.isArray(requiredMoves) ? requiredMoves : [requiredMoves]; + this.requiredMoves = Array.isArray(requiredMoves) ? requiredMoves : [ requiredMoves ]; this.excludeLevelMoves = options.excludeLevelMoves ?? false; this.excludeTmMoves = options.excludeTmMoves ?? false; @@ -39,7 +39,7 @@ export class CanLearnMoveRequirement extends EncounterPokemonRequirement { } override meetsRequirement(scene: BattleScene): boolean { - const partyPokemon = scene.getParty().filter((pkm) => (this.includeFainted ? pkm.isAllowed() : pkm.isAllowedInBattle())); + const partyPokemon = scene.getPlayerParty().filter((pkm) => (this.includeFainted ? pkm.isAllowedInChallenge() : pkm.isAllowedInBattle())); if (isNullOrUndefined(partyPokemon) || this.requiredMoves?.length < 0) { return false; @@ -64,11 +64,11 @@ export class CanLearnMoveRequirement extends EncounterPokemonRequirement { } override getDialogueToken(_scene: BattleScene, _pokemon?: PlayerPokemon): [string, string] { - return ["requiredMoves", this.requiredMoves.map(m => new PokemonMove(m).getName()).join(", ")]; + return [ "requiredMoves", this.requiredMoves.map(m => new PokemonMove(m).getName()).join(", ") ]; } private getPokemonLevelMoves(pkm: PlayerPokemon): Moves[] { - return pkm.getLevelMoves().map(([_level, move]) => move); + return pkm.getLevelMoves().map(([ _level, move ]) => move); } private getAllPokemonMoves(pkm: PlayerPokemon): Moves[] { diff --git a/src/data/mystery-encounters/requirements/requirement-groups.ts b/src/data/mystery-encounters/requirements/requirement-groups.ts index 63c899fc5e9..76bbb8f03a7 100644 --- a/src/data/mystery-encounters/requirements/requirement-groups.ts +++ b/src/data/mystery-encounters/requirements/requirement-groups.ts @@ -118,3 +118,20 @@ export const EXTORTION_ABILITIES = [ Abilities.SUCTION_CUPS, Abilities.STICKY_HOLD ]; + +/** + * Abilities that signify resistance to fire + */ +export const FIRE_RESISTANT_ABILITIES = [ + Abilities.FLAME_BODY, + Abilities.FLASH_FIRE, + Abilities.WELL_BAKED_BODY, + Abilities.HEATPROOF, + Abilities.THERMAL_EXCHANGE, + Abilities.THICK_FAT, + Abilities.WATER_BUBBLE, + Abilities.MAGMA_ARMOR, + Abilities.WATER_VEIL, + Abilities.STEAM_ENGINE, + Abilities.PRIMORDIAL_SEA +]; diff --git a/src/data/mystery-encounters/utils/encounter-dialogue-utils.ts b/src/data/mystery-encounters/utils/encounter-dialogue-utils.ts index 494a45f69f5..acaa7c6244f 100644 --- a/src/data/mystery-encounters/utils/encounter-dialogue-utils.ts +++ b/src/data/mystery-encounters/utils/encounter-dialogue-utils.ts @@ -7,22 +7,22 @@ import i18next from "i18next"; /** * Will inject all relevant dialogue tokens that exist in the {@linkcode BattleScene.currentBattle.mysteryEncounter.dialogueTokens}, into i18n text. * Also adds BBCodeText fragments for colored text, if applicable - * @param scene * @param keyOrString * @param primaryStyle Can define a text style to be applied to the entire string. Must be defined for BBCodeText styles to be applied correctly - * @param uiTheme */ -export function getEncounterText(scene: BattleScene, keyOrString?: string, primaryStyle?: TextStyle, uiTheme: UiTheme = UiTheme.DEFAULT): string | null { +export function getEncounterText(scene: BattleScene, keyOrString?: string, primaryStyle?: TextStyle): string | null { if (isNullOrUndefined(keyOrString)) { return null; } - let textString: string | null = getTextWithDialogueTokens(scene, keyOrString!); + const uiTheme = scene.uiTheme ?? UiTheme.DEFAULT; + + let textString: string | null = getTextWithDialogueTokens(scene, keyOrString); // Can only color the text if a Primary Style is defined // primaryStyle is applied to all text that does not have its own specified style if (primaryStyle && textString) { - textString = getTextWithColors(textString, primaryStyle, uiTheme); + textString = getTextWithColors(textString, primaryStyle, uiTheme, true); } return textString; diff --git a/src/data/mystery-encounters/utils/encounter-phase-utils.ts b/src/data/mystery-encounters/utils/encounter-phase-utils.ts index 2cd369fbaad..c6dda134346 100644 --- a/src/data/mystery-encounters/utils/encounter-phase-utils.ts +++ b/src/data/mystery-encounters/utils/encounter-phase-utils.ts @@ -1,9 +1,9 @@ import Battle, { BattlerIndex, BattleType } from "#app/battle"; -import { biomeLinks, BiomePoolTier } from "#app/data/biomes"; +import { biomeLinks, BiomePoolTier } from "#app/data/balance/biomes"; import MysteryEncounterOption from "#app/data/mystery-encounters/mystery-encounter-option"; import { AVERAGE_ENCOUNTERS_PER_RUN_TARGET, WEIGHT_INCREMENT_ON_SPAWN_MISS } from "#app/data/mystery-encounters/mystery-encounters"; import { showEncounterText } from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; -import Pokemon, { FieldPosition, PlayerPokemon, PokemonMove, PokemonSummonData } from "#app/field/pokemon"; +import Pokemon, { AiType, FieldPosition, PlayerPokemon, PokemonMove, PokemonSummonData } from "#app/field/pokemon"; import { CustomModifierSettings, ModifierPoolType, ModifierType, ModifierTypeGenerator, ModifierTypeOption, modifierTypes, regenerateModifierPoolThresholds } from "#app/modifier/modifier-type"; import { MysteryEncounterBattlePhase, MysteryEncounterBattleStartCleanupPhase, MysteryEncounterPhase, MysteryEncounterRewardsPhase } from "#app/phases/mystery-encounter-phases"; import PokemonData from "#app/system/pokemon-data"; @@ -19,15 +19,15 @@ import i18next from "i18next"; import BattleScene from "#app/battle-scene"; import Trainer, { TrainerVariant } from "#app/field/trainer"; import { Gender } from "#app/data/gender"; -import { Nature } from "#app/data/nature"; +import { Nature } from "#enums/nature"; import { Moves } from "#enums/moves"; import { initMoveAnim, loadMoveAnimAssets } from "#app/data/battle-anims"; import { MysteryEncounterMode } from "#enums/mystery-encounter-mode"; -import { Status, StatusEffect } from "#app/data/status-effect"; +import { Status } from "#app/data/status-effect"; import { TrainerConfig, trainerConfigs, TrainerSlot } from "#app/data/trainer-config"; import PokemonSpecies from "#app/data/pokemon-species"; import { Egg, IEggOptions } from "#app/data/egg"; -import { MysteryEncounterPokemonData } from "#app/data/mystery-encounters/mystery-encounter-pokemon-data"; +import { CustomPokemonData } from "#app/data/custom-pokemon-data"; import HeldModifierConfig from "#app/interfaces/held-modifier-config"; import { MovePhase } from "#app/phases/move-phase"; import { EggLapsePhase } from "#app/phases/egg-lapse-phase"; @@ -36,13 +36,15 @@ import { BattleEndPhase } from "#app/phases/battle-end-phase"; import { GameOverPhase } from "#app/phases/game-over-phase"; import { SelectModifierPhase } from "#app/phases/select-modifier-phase"; import { PartyExpPhase } from "#app/phases/party-exp-phase"; +import { Variant } from "#app/data/variant"; +import { StatusEffect } from "#enums/status-effect"; /** * Animates exclamation sprite over trainer's head at start of encounter * @param scene */ export function doTrainerExclamation(scene: BattleScene) { - const exclamationSprite = scene.add.sprite(0, 0, "exclaim"); + const exclamationSprite = scene.add.sprite(0, 0, "encounter_exclaim"); exclamationSprite.setName("exclamation"); scene.field.add(exclamationSprite); scene.field.moveTo(exclamationSprite, scene.field.getAll().length - 1); @@ -67,9 +69,10 @@ export function doTrainerExclamation(scene: BattleScene) { export interface EnemyPokemonConfig { species: PokemonSpecies; isBoss: boolean; + nickname?: string; bossSegments?: number; bossSegmentModifier?: number; // Additive to the determined segment number - mysteryEncounterPokemonData?: MysteryEncounterPokemonData; + customPokemonData?: CustomPokemonData; formIndex?: number; abilityIndex?: number; level?: number; @@ -79,27 +82,32 @@ export interface EnemyPokemonConfig { nature?: Nature; ivs?: [number, number, number, number, number, number]; shiny?: boolean; + /** Is only checked if Pokemon is shiny */ + variant?: Variant; /** Can set just the status, or pass a timer on the status turns */ status?: StatusEffect | [StatusEffect, number]; mysteryEncounterBattleEffects?: (pokemon: Pokemon) => void; modifierConfigs?: HeldModifierConfig[]; tags?: BattlerTagType[]; dataSource?: PokemonData; + aiType?: AiType; } export interface EnemyPartyConfig { - /** Formula for enemy: level += waveIndex / 10 * levelAdditive */ - levelAdditiveMultiplier?: number; + /** Formula for enemy level: level += waveIndex / 10 * levelAdditiveModifier */ + levelAdditiveModifier?: number; doubleBattle?: boolean; /** Generates trainer battle solely off trainer type */ trainerType?: TrainerType; /** More customizable option for configuring trainer battle */ trainerConfig?: TrainerConfig; pokemonConfigs?: EnemyPokemonConfig[]; - /** True for female trainer, false for male */ + /** `true` for female trainer, false for male */ female?: boolean; - /** True will prevent player from switching */ + /** `true` will prevent player from switching */ disableSwitch?: boolean; + /** `true` or leaving undefined will increment dex seen count for the encounter battle, `false` will not */ + countAsSeen?: boolean; } /** @@ -128,7 +136,7 @@ export async function initBattleWithEnemyConfig(scene: BattleScene, partyConfig: scene.currentBattle.trainer.destroy(); } - trainerConfig = partyConfig?.trainerConfig ? partyConfig?.trainerConfig : trainerConfigs[trainerType!]; + trainerConfig = partyTrainerConfig ? partyTrainerConfig : trainerConfigs[trainerType!]; const doubleTrainer = trainerConfig.doubleOnly || (trainerConfig.hasDouble && !!partyConfig.doubleBattle); doubleBattle = doubleTrainer; @@ -138,7 +146,7 @@ export async function initBattleWithEnemyConfig(scene: BattleScene, partyConfig: newTrainer.setVisible(false); scene.field.add(newTrainer); scene.currentBattle.trainer = newTrainer; - loadEnemyAssets.push(newTrainer.loadAssets()); + loadEnemyAssets.push(newTrainer.loadAssets().then(() => newTrainer.initSprite())); battle.enemyLevels = scene.currentBattle.trainer.getPartyLevels(scene.currentBattle.waveIndex); } else { @@ -156,10 +164,10 @@ export async function initBattleWithEnemyConfig(scene: BattleScene, partyConfig: // ME levels are modified by an additive value that scales with wave index // Base scaling: Every 10 waves, modifier gets +1 level - // This can be amplified or counteracted by setting levelAdditiveMultiplier in config - // levelAdditiveMultiplier value of 0.5 will halve the modifier scaling, 2 will double it, etc. + // This can be amplified or counteracted by setting levelAdditiveModifier in config + // levelAdditiveModifier value of 0.5 will halve the modifier scaling, 2 will double it, etc. // Leaving null/undefined will disable level scaling - const mult: number = !isNullOrUndefined(partyConfig.levelAdditiveMultiplier) ? partyConfig.levelAdditiveMultiplier! : 0; + const mult: number = !isNullOrUndefined(partyConfig.levelAdditiveModifier) ? partyConfig.levelAdditiveModifier : 0; const additive = Math.max(Math.round((scene.currentBattle.waveIndex / 10) * mult), 0); battle.enemyLevels = battle.enemyLevels.map(level => level + additive); @@ -210,13 +218,18 @@ export async function initBattleWithEnemyConfig(scene: BattleScene, partyConfig: enemyPokemon.resetSummonData(); } - if (!loaded) { + if (!loaded && isNullOrUndefined(partyConfig.countAsSeen) || partyConfig.countAsSeen) { scene.gameData.setPokemonSeen(enemyPokemon, true, !!(trainerType || trainerConfig)); } if (partyConfig?.pokemonConfigs && e < partyConfig.pokemonConfigs.length) { const config = partyConfig.pokemonConfigs[e]; + // Set form + if (!isNullOrUndefined(config.nickname)) { + enemyPokemon.nickname = btoa(unescape(encodeURIComponent(config.nickname))); + } + // Generate new id, reset status and HP in case using data source if (config.dataSource) { enemyPokemon.id = Utils.randSeedInt(4294967296); @@ -224,24 +237,29 @@ export async function initBattleWithEnemyConfig(scene: BattleScene, partyConfig: // Set form if (!isNullOrUndefined(config.formIndex)) { - enemyPokemon.formIndex = config.formIndex!; + enemyPokemon.formIndex = config.formIndex; } // Set shiny if (!isNullOrUndefined(config.shiny)) { - enemyPokemon.shiny = config.shiny!; + enemyPokemon.shiny = config.shiny; + } + + // Set Variant + if (enemyPokemon.shiny && !isNullOrUndefined(config.variant)) { + enemyPokemon.variant = config.variant; } // Set custom mystery encounter data fields (such as sprite scale, custom abilities, types, etc.) - if (!isNullOrUndefined(config.mysteryEncounterPokemonData)) { - enemyPokemon.mysteryEncounterPokemonData = config.mysteryEncounterPokemonData!; + if (!isNullOrUndefined(config.customPokemonData)) { + enemyPokemon.customPokemonData = config.customPokemonData; } // Set Boss if (config.isBoss) { let segments = !isNullOrUndefined(config.bossSegments) ? config.bossSegments! : scene.getEncounterBossSegments(scene.currentBattle.waveIndex, level, enemySpecies, true); if (!isNullOrUndefined(config.bossSegmentModifier)) { - segments += config.bossSegmentModifier!; + segments += config.bossSegmentModifier; } enemyPokemon.setBoss(true, segments); } @@ -277,13 +295,18 @@ export async function initBattleWithEnemyConfig(scene: BattleScene, partyConfig: // Set ability if (!isNullOrUndefined(config.abilityIndex)) { - enemyPokemon.abilityIndex = config.abilityIndex!; + enemyPokemon.abilityIndex = config.abilityIndex; } // Set gender if (!isNullOrUndefined(config.gender)) { enemyPokemon.gender = config.gender!; - enemyPokemon.summonData.gender = config.gender!; + enemyPokemon.summonData.gender = config.gender; + } + + // Set AI type + if (!isNullOrUndefined(config.aiType)) { + enemyPokemon.aiType = config.aiType; } // Set moves @@ -307,6 +330,9 @@ export async function initBattleWithEnemyConfig(scene: BattleScene, partyConfig: // Requires re-priming summon data to update everything properly enemyPokemon.primeSummonData(enemyPokemon.summonData); + if (enemyPokemon.isShiny() && !enemyPokemon["shinySparkle"]) { + enemyPokemon.initShinySparkle(); + } enemyPokemon.initBattleInfo(); enemyPokemon.getBattleInfo().initInfo(enemyPokemon); enemyPokemon.generateName(); @@ -314,7 +340,7 @@ export async function initBattleWithEnemyConfig(scene: BattleScene, partyConfig: loadEnemyAssets.push(enemyPokemon.loadAssets()); - console.log(enemyPokemon.name, enemyPokemon.species.speciesId, enemyPokemon.stats); + console.log(`Pokemon: ${enemyPokemon.name}`, `Species ID: ${enemyPokemon.species.speciesId}`, `Stats: ${enemyPokemon.stats}`, `Ability: ${enemyPokemon.getAbility().name}`, `Passive Ability: ${enemyPokemon.getPassiveAbility().name}`); }); scene.pushPhase(new MysteryEncounterBattlePhase(scene, partyConfig.disableSwitch)); @@ -348,7 +374,7 @@ export async function initBattleWithEnemyConfig(scene: BattleScene, partyConfig: * @param moves */ export function loadCustomMovesForEncounter(scene: BattleScene, moves: Moves | Moves[]) { - moves = Array.isArray(moves) ? moves : [moves]; + moves = Array.isArray(moves) ? moves : [ moves ]; return Promise.all(moves.map(move => initMoveAnim(scene, move))) .then(() => loadMoveAnimAssets(scene, moves)); } @@ -393,9 +419,9 @@ export function generateModifierType(scene: BattleScene, modifier: () => Modifie // Populates item id and tier (order matters) result = result .withIdFromFunc(modifierTypes[modifierId]) - .withTierFromPool(); + .withTierFromPool(ModifierPoolType.PLAYER, scene.getPlayerParty()); - return result instanceof ModifierTypeGenerator ? result.generateType(scene.getParty(), pregenArgs) : result; + return result instanceof ModifierTypeGenerator ? result.generateType(scene.getPlayerParty(), pregenArgs) : result; } /** @@ -426,9 +452,9 @@ export function selectPokemonForOption(scene: BattleScene, onPokemonSelected: (p // Open party screen to choose pokemon scene.ui.setMode(Mode.PARTY, PartyUiMode.SELECT, -1, (slotIndex: number, option: PartyOption) => { - if (slotIndex < scene.getParty().length) { + if (slotIndex < scene.getPlayerParty().length) { scene.ui.setMode(modeToSetOnExit).then(() => { - const pokemon = scene.getParty()[slotIndex]; + const pokemon = scene.getPlayerParty()[slotIndex]; const secondaryOptions = onPokemonSelected(pokemon); if (!secondaryOptions) { scene.currentBattle.mysteryEncounter!.setDialogueToken("selectedPokemon", pokemon.getNameToRender()); @@ -538,7 +564,7 @@ export function selectOptionThenPokemon(scene: BattleScene, options: OptionSelec const selectPokemonAfterOption = (selectedOptionIndex: number) => { // Open party screen to choose a Pokemon scene.ui.setMode(Mode.PARTY, PartyUiMode.SELECT, -1, (slotIndex: number, option: PartyOption) => { - if (slotIndex < scene.getParty().length) { + if (slotIndex < scene.getPlayerParty().length) { // Pokemon and option selected scene.ui.setMode(modeToSetOnExit).then(() => { const result: PokemonAndOptionSelected = { selectedPokemonIndex: slotIndex, selectedOptionIndex: selectedOptionIndex }; @@ -638,7 +664,7 @@ export function setEncounterRewards(scene: BattleScene, customShopRewards?: Cust * @param useWaveIndex - set to false when directly passing the the full exp value instead of baseExpValue */ export function setEncounterExp(scene: BattleScene, participantId: number | number[], baseExpValue: number, useWaveIndex: boolean = true) { - const participantIds = Array.isArray(participantId) ? participantId : [participantId]; + const participantIds = Array.isArray(participantId) ? participantId : [ participantId ]; scene.currentBattle.mysteryEncounter!.doEncounterExp = (scene: BattleScene) => { scene.unshiftPhase(new PartyExpPhase(scene, baseExpValue, useWaveIndex, new Set(participantIds))); @@ -688,7 +714,7 @@ export function leaveEncounterWithoutBattle(scene: BattleScene, addHealPhase: bo * @param doNotContinue - default `false`. If set to true, will not end the battle and continue to next wave */ export function handleMysteryEncounterVictory(scene: BattleScene, addHealPhase: boolean = false, doNotContinue: boolean = false) { - const allowedPkm = scene.getParty().filter((pkm) => pkm.isAllowedInBattle()); + const allowedPkm = scene.getPlayerParty().filter((pkm) => pkm.isAllowedInBattle()); if (allowedPkm.length === 0) { scene.clearPhaseQueue(); @@ -702,23 +728,54 @@ export function handleMysteryEncounterVictory(scene: BattleScene, addHealPhase: if (encounter.continuousEncounter || doNotContinue) { return; } else if (encounter.encounterMode === MysteryEncounterMode.NO_BATTLE) { - scene.pushPhase(new EggLapsePhase(scene)); scene.pushPhase(new MysteryEncounterRewardsPhase(scene, addHealPhase)); + scene.pushPhase(new EggLapsePhase(scene)); } else if (!scene.getEnemyParty().find(p => encounter.encounterMode !== MysteryEncounterMode.TRAINER_BATTLE ? p.isOnField() : !p?.isFainted(true))) { scene.pushPhase(new BattleEndPhase(scene)); if (encounter.encounterMode === MysteryEncounterMode.TRAINER_BATTLE) { scene.pushPhase(new TrainerVictoryPhase(scene)); } if (scene.gameMode.isEndless || !scene.gameMode.isWaveFinal(scene.currentBattle.waveIndex)) { + scene.pushPhase(new MysteryEncounterRewardsPhase(scene, addHealPhase)); if (!encounter.doContinueEncounter) { // Only lapse eggs once for multi-battle encounters scene.pushPhase(new EggLapsePhase(scene)); } - scene.pushPhase(new MysteryEncounterRewardsPhase(scene, addHealPhase)); } } } +/** + * Similar to {@linkcode handleMysteryEncounterVictory}, but for cases where the player lost a battle or failed a challenge + * @param scene + * @param addHealPhase + */ +export function handleMysteryEncounterBattleFailed(scene: BattleScene, addHealPhase: boolean = false, doNotContinue: boolean = false) { + const allowedPkm = scene.getPlayerParty().filter((pkm) => pkm.isAllowedInBattle()); + + if (allowedPkm.length === 0) { + scene.clearPhaseQueue(); + scene.unshiftPhase(new GameOverPhase(scene)); + return; + } + + // If in repeated encounter variant, do nothing + // Variant must eventually be swapped in order to handle "true" end of the encounter + const encounter = scene.currentBattle.mysteryEncounter!; + if (encounter.continuousEncounter || doNotContinue) { + return; + } else if (encounter.encounterMode !== MysteryEncounterMode.NO_BATTLE) { + scene.pushPhase(new BattleEndPhase(scene, false)); + } + + scene.pushPhase(new MysteryEncounterRewardsPhase(scene, addHealPhase)); + + if (!encounter.doContinueEncounter) { + // Only lapse eggs once for multi-battle encounters + scene.pushPhase(new EggLapsePhase(scene)); + } +} + /** * * @param scene @@ -744,8 +801,8 @@ export function transitionMysteryEncounterIntroVisuals(scene: BattleScene, hide: // Transition scene.tweens.add({ - targets: [introVisuals, enemyPokemon], - x: `${hide? "+" : "-"}=16`, + targets: [ introVisuals, enemyPokemon ], + x: `${hide ? "+" : "-"}=16`, y: `${hide ? "-" : "+"}=16`, alpha: hide ? 0 : 1, ease: "Sine.easeInOut", @@ -776,7 +833,7 @@ export function transitionMysteryEncounterIntroVisuals(scene: BattleScene, hide: */ export function handleMysteryEncounterBattleStartEffects(scene: BattleScene) { const encounter = scene.currentBattle.mysteryEncounter; - if (scene.currentBattle.battleType === BattleType.MYSTERY_ENCOUNTER && encounter && encounter.encounterMode !== MysteryEncounterMode.NO_BATTLE && !encounter.startOfBattleEffectsComplete) { + if (scene.currentBattle.isBattleMysteryEncounter() && encounter && encounter.encounterMode !== MysteryEncounterMode.NO_BATTLE && !encounter.startOfBattleEffectsComplete) { const effects = encounter.startOfBattleEffects; effects.forEach(effect => { let source; @@ -815,7 +872,7 @@ export function handleMysteryEncounterBattleStartEffects(scene: BattleScene) { */ export function handleMysteryEncounterTurnStartEffects(scene: BattleScene): boolean { const encounter = scene.currentBattle.mysteryEncounter; - if (scene.currentBattle.battleType === BattleType.MYSTERY_ENCOUNTER && encounter && encounter.onTurnStart) { + if (scene.currentBattle.isBattleMysteryEncounter() && encounter && encounter.onTurnStart) { return encounter.onTurnStart(scene); } @@ -832,14 +889,14 @@ export function calculateMEAggregateStats(scene: BattleScene, baseSpawnWeight: n const numRuns = 1000; let run = 0; const biomes = Object.keys(Biome).filter(key => isNaN(Number(key))); - const alwaysPickTheseBiomes = [Biome.ISLAND, Biome.ABYSS, Biome.WASTELAND, Biome.FAIRY_CAVE, Biome.TEMPLE, Biome.LABORATORY, Biome.SPACE, Biome.WASTELAND]; + const alwaysPickTheseBiomes = [ Biome.ISLAND, Biome.ABYSS, Biome.WASTELAND, Biome.FAIRY_CAVE, Biome.TEMPLE, Biome.LABORATORY, Biome.SPACE, Biome.WASTELAND ]; const calculateNumEncounters = (): any[] => { let encounterRate = baseSpawnWeight; // BASE_MYSTERY_ENCOUNTER_SPAWN_WEIGHT - const numEncounters = [0, 0, 0, 0]; + const numEncounters = [ 0, 0, 0, 0 ]; let mostRecentEncounterWave = 0; - const encountersByBiome = new Map(biomes.map(b => [b, 0])); - const validMEfloorsByBiome = new Map(biomes.map(b => [b, 0])); + const encountersByBiome = new Map(biomes.map(b => [ b, 0 ])); + const validMEfloorsByBiome = new Map(biomes.map(b => [ b, 0 ])); let currentBiome = Biome.TOWN; let currentArena = scene.newArena(currentBiome); scene.setSeed(Utils.randomString(24)); @@ -912,7 +969,7 @@ export function calculateMEAggregateStats(scene: BattleScene, baseSpawnWeight: n // Calculate encounter rarity // Common / Uncommon / Rare / Super Rare (base is out of 128) - const tierWeights = [66, 40, 19, 3]; + const tierWeights = [ 66, 40, 19, 3 ]; // Adjust tier weights by currently encountered events (pity system that lowers odds of multiple Common/Great) tierWeights[0] = tierWeights[0] - 6 * numEncounters[0]; @@ -931,7 +988,7 @@ export function calculateMEAggregateStats(scene: BattleScene, baseSpawnWeight: n } } - return [numEncounters, encountersByBiome, validMEfloorsByBiome]; + return [ numEncounters, encountersByBiome, validMEfloorsByBiome ]; }; const encounterRuns: number[][] = []; @@ -939,7 +996,7 @@ export function calculateMEAggregateStats(scene: BattleScene, baseSpawnWeight: n const validFloorsByBiome: Map[] = []; while (run < numRuns) { scene.executeWithSeedOffset(() => { - const [numEncounters, encountersByBiome, validMEfloorsByBiome] = calculateNumEncounters(); + const [ numEncounters, encountersByBiome, validMEfloorsByBiome ] = calculateNumEncounters(); encounterRuns.push(numEncounters); encountersByBiomeRuns.push(encountersByBiome); validFloorsByBiome.push(validMEfloorsByBiome); @@ -980,7 +1037,7 @@ export function calculateMEAggregateStats(scene: BattleScene, baseSpawnWeight: n let stats = `Starting weight: ${baseSpawnWeight}\nAverage MEs per run: ${totalMean}\nStandard Deviation: ${totalStd}\nAvg Commons: ${commonMean}\nAvg Greats: ${uncommonMean}\nAvg Ultras: ${rareMean}\nAvg Rogues: ${superRareMean}\n`; - const meanEncountersPerRunPerBiomeSorted = [...meanEncountersPerRunPerBiome.entries()].sort((e1, e2) => e2[1] - e1[1]); + const meanEncountersPerRunPerBiomeSorted = [ ...meanEncountersPerRunPerBiome.entries() ].sort((e1, e2) => e2[1] - e1[1]); meanEncountersPerRunPerBiomeSorted.forEach(value => stats = stats + `${value[0]}: avg valid floors ${meanMEFloorsPerRunPerBiome.get(value[0])}, avg MEs ${value[1]},\n`); console.log(stats); @@ -998,7 +1055,7 @@ export function calculateRareSpawnAggregateStats(scene: BattleScene, luckValue: let run = 0; const calculateNumRareEncounters = (): any[] => { - const bossEncountersByRarity = [0, 0, 0, 0]; + const bossEncountersByRarity = [ 0, 0, 0, 0 ]; scene.setSeed(Utils.randomString(24)); scene.resetSeed(); // There are 12 wild boss floors @@ -1013,19 +1070,19 @@ export function calculateRareSpawnAggregateStats(scene: BattleScene, luckValue: const tier = tierValue >= 20 ? BiomePoolTier.BOSS : tierValue >= 6 ? BiomePoolTier.BOSS_RARE : tierValue >= 1 ? BiomePoolTier.BOSS_SUPER_RARE : BiomePoolTier.BOSS_ULTRA_RARE; switch (tier) { - default: - case BiomePoolTier.BOSS: - ++bossEncountersByRarity[0]; - break; - case BiomePoolTier.BOSS_RARE: - ++bossEncountersByRarity[1]; - break; - case BiomePoolTier.BOSS_SUPER_RARE: - ++bossEncountersByRarity[2]; - break; - case BiomePoolTier.BOSS_ULTRA_RARE: - ++bossEncountersByRarity[3]; - break; + default: + case BiomePoolTier.BOSS: + ++bossEncountersByRarity[0]; + break; + case BiomePoolTier.BOSS_RARE: + ++bossEncountersByRarity[1]; + break; + case BiomePoolTier.BOSS_SUPER_RARE: + ++bossEncountersByRarity[2]; + break; + case BiomePoolTier.BOSS_ULTRA_RARE: + ++bossEncountersByRarity[3]; + break; } } diff --git a/src/data/mystery-encounters/utils/encounter-pokemon-utils.ts b/src/data/mystery-encounters/utils/encounter-pokemon-utils.ts index bac8bded9ba..fc85754bdde 100644 --- a/src/data/mystery-encounters/utils/encounter-pokemon-utils.ts +++ b/src/data/mystery-encounters/utils/encounter-pokemon-utils.ts @@ -3,22 +3,31 @@ import i18next from "i18next"; import { isNullOrUndefined, randSeedInt } from "#app/utils"; import { PokemonHeldItemModifier } from "#app/modifier/modifier"; import Pokemon, { EnemyPokemon, PlayerPokemon } from "#app/field/pokemon"; -import { doPokeballBounceAnim, getPokeballAtlasKey, getPokeballCatchMultiplier, getPokeballTintColor, PokeballType } from "#app/data/pokeball"; +import { doPokeballBounceAnim, getPokeballAtlasKey, getPokeballCatchMultiplier, getPokeballTintColor } from "#app/data/pokeball"; import { PlayerGender } from "#enums/player-gender"; import { addPokeballCaptureStars, addPokeballOpenParticles } from "#app/field/anims"; -import { getStatusEffectCatchRateMultiplier, StatusEffect } from "#app/data/status-effect"; +import { getStatusEffectCatchRateMultiplier } from "#app/data/status-effect"; import { achvs } from "#app/system/achv"; import { Mode } from "#app/ui/ui"; import { PartyOption, PartyUiMode } from "#app/ui/party-ui-handler"; import { Species } from "#enums/species"; -import { Type } from "#app/data/type"; -import PokemonSpecies, { getPokemonSpecies, speciesStarters } from "#app/data/pokemon-species"; -import { queueEncounterMessage, showEncounterText } from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; +import { Type } from "#enums/type"; +import PokemonSpecies, { getPokemonSpecies } from "#app/data/pokemon-species"; +import { speciesStarterCosts } from "#app/data/balance/starters"; +import { getEncounterText, queueEncounterMessage, showEncounterText } from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; import { getPokemonNameWithAffix } from "#app/messages"; import { modifierTypes, PokemonHeldItemModifierType } from "#app/modifier/modifier-type"; import { Gender } from "#app/data/gender"; import { PermanentStat } from "#enums/stat"; import { VictoryPhase } from "#app/phases/victory-phase"; +import { SummaryUiMode } from "#app/ui/summary-ui-handler"; +import { CustomPokemonData } from "#app/data/custom-pokemon-data"; +import { Abilities } from "#enums/abilities"; +import type { PokeballType } from "#enums/pokeball"; +import { StatusEffect } from "#enums/status-effect"; + +/** Will give +1 level every 10 waves */ +export const STANDARD_ENCOUNTER_BOOSTED_LEVEL_MODIFIER = 1; /** * Gets the sprite key and file root for a given PokemonSpecies (accounts for gender, shiny, variants, forms, and experimental) @@ -46,28 +55,39 @@ export function getSpriteKeysFromPokemon(pokemon: Pokemon): { spriteKey: string, } /** - * - * Will never remove the player's last non-fainted Pokemon (if they only have 1) + * Will never remove the player's last non-fainted Pokemon (if they only have 1). * Otherwise, picks a Pokemon completely at random and removes from the party * @param scene - * @param isAllowedInBattle Default false. If true, only picks from unfainted mons. If there is only 1 unfainted mon left and doNotReturnLastAbleMon is also true, will return fainted mon - * @param doNotReturnLastAbleMon Default false. If true, will never return the last unfainted pokemon in the party. Useful when this function is being used to determine what Pokemon to remove from the party (Don't want to remove last unfainted) + * @param isAllowed Default `false`. If `true`, only picks from legal mons. If no legal mons are found (or there is 1, with `doNotReturnLastAllowedMon = true`), will return a mon that is not allowed. + * @param isFainted Default `false`. If `true`, includes fainted mons. + * @param doNotReturnLastAllowedMon Default `false`. If `true`, will never return the last unfainted pokemon in the party. Useful when this function is being used to determine what Pokemon to remove from the party (Don't want to remove last unfainted) * @returns */ -export function getRandomPlayerPokemon(scene: BattleScene, isAllowedInBattle: boolean = false, doNotReturnLastAbleMon: boolean = false): PlayerPokemon { - const party = scene.getParty(); +export function getRandomPlayerPokemon(scene: BattleScene, isAllowed: boolean = false, isFainted: boolean = false, doNotReturnLastAllowedMon: boolean = false): PlayerPokemon { + const party = scene.getPlayerParty(); let chosenIndex: number; - let chosenPokemon: PlayerPokemon; - const unfaintedMons = party.filter(p => p.isAllowedInBattle()); - const faintedMons = party.filter(p => !p.isAllowedInBattle()); + let chosenPokemon: PlayerPokemon | null = null; + const fullyLegalMons = party.filter(p => (!isAllowed || p.isAllowedInChallenge()) && (isFainted || !p.isFainted())); + const allowedOnlyMons = party.filter(p => p.isAllowedInChallenge()); - if (doNotReturnLastAbleMon && unfaintedMons.length === 1) { - chosenIndex = randSeedInt(faintedMons.length); - chosenPokemon = faintedMons[chosenIndex]; - } else if (isAllowedInBattle) { - chosenIndex = randSeedInt(unfaintedMons.length); - chosenPokemon = unfaintedMons[chosenIndex]; - } else { + if (doNotReturnLastAllowedMon && fullyLegalMons.length === 1) { + // If there is only 1 legal/unfainted mon left, select from fainted legal mons + const faintedLegalMons = party.filter(p => (!isAllowed || p.isAllowedInChallenge()) && p.isFainted()); + if (faintedLegalMons.length > 0) { + chosenIndex = randSeedInt(faintedLegalMons.length); + chosenPokemon = faintedLegalMons[chosenIndex]; + } + } + if (!chosenPokemon && fullyLegalMons.length > 0) { + chosenIndex = randSeedInt(fullyLegalMons.length); + chosenPokemon = fullyLegalMons[chosenIndex]; + } + if (!chosenPokemon && isAllowed && allowedOnlyMons.length > 0) { + chosenIndex = randSeedInt(allowedOnlyMons.length); + chosenPokemon = allowedOnlyMons[chosenIndex]; + } + if (!chosenPokemon) { + // If no other options worked, returns fully random chosenIndex = randSeedInt(party.length); chosenPokemon = party[chosenIndex]; } @@ -78,15 +98,19 @@ export function getRandomPlayerPokemon(scene: BattleScene, isAllowedInBattle: bo /** * Ties are broken by whatever mon is closer to the front of the party * @param scene - * @param unfainted Default false. If true, only picks from unfainted mons. + * @param isAllowed Default false. If true, only picks from legal mons. + * @param isFainted Default false. If true, includes fainted mons. * @returns */ -export function getHighestLevelPlayerPokemon(scene: BattleScene, unfainted: boolean = false): PlayerPokemon { - const party = scene.getParty(); +export function getHighestLevelPlayerPokemon(scene: BattleScene, isAllowed: boolean = false, isFainted: boolean = false): PlayerPokemon { + const party = scene.getPlayerParty(); let pokemon: PlayerPokemon | null = null; for (const p of party) { - if (unfainted && p.isFainted()) { + if (isAllowed && !p.isAllowedInChallenge()) { + continue; + } + if (!isFainted && p.isFainted()) { continue; } @@ -100,15 +124,19 @@ export function getHighestLevelPlayerPokemon(scene: BattleScene, unfainted: bool * Ties are broken by whatever mon is closer to the front of the party * @param scene * @param stat Stat to search for - * @param unfainted Default false. If true, only picks from unfainted mons. + * @param isAllowed Default false. If true, only picks from legal mons. + * @param isFainted Default false. If true, includes fainted mons. * @returns */ -export function getHighestStatPlayerPokemon(scene: BattleScene, stat: PermanentStat, unfainted: boolean = false): PlayerPokemon { - const party = scene.getParty(); +export function getHighestStatPlayerPokemon(scene: BattleScene, stat: PermanentStat, isAllowed: boolean = false, isFainted: boolean = false): PlayerPokemon { + const party = scene.getPlayerParty(); let pokemon: PlayerPokemon | null = null; for (const p of party) { - if (unfainted && p.isFainted()) { + if (isAllowed && !p.isAllowedInChallenge()) { + continue; + } + if (!isFainted && p.isFainted()) { continue; } @@ -121,15 +149,19 @@ export function getHighestStatPlayerPokemon(scene: BattleScene, stat: PermanentS /** * Ties are broken by whatever mon is closer to the front of the party * @param scene - * @param unfainted - default false. If true, only picks from unfainted mons. + * @param isAllowed Default false. If true, only picks from legal mons. + * @param isFainted Default false. If true, includes fainted mons. * @returns */ -export function getLowestLevelPlayerPokemon(scene: BattleScene, unfainted: boolean = false): PlayerPokemon { - const party = scene.getParty(); +export function getLowestLevelPlayerPokemon(scene: BattleScene, isAllowed: boolean = false, isFainted: boolean = false): PlayerPokemon { + const party = scene.getPlayerParty(); let pokemon: PlayerPokemon | null = null; for (const p of party) { - if (unfainted && p.isFainted()) { + if (isAllowed && !p.isAllowedInChallenge()) { + continue; + } + if (!isFainted && p.isFainted()) { continue; } @@ -142,15 +174,19 @@ export function getLowestLevelPlayerPokemon(scene: BattleScene, unfainted: boole /** * Ties are broken by whatever mon is closer to the front of the party * @param scene - * @param unfainted - default false. If true, only picks from unfainted mons. + * @param isAllowed Default false. If true, only picks from legal mons. + * @param isFainted Default false. If true, includes fainted mons. * @returns */ -export function getHighestStatTotalPlayerPokemon(scene: BattleScene, unfainted: boolean = false): PlayerPokemon { - const party = scene.getParty(); +export function getHighestStatTotalPlayerPokemon(scene: BattleScene, isAllowed: boolean = false, isFainted: boolean = false): PlayerPokemon { + const party = scene.getPlayerParty(); let pokemon: PlayerPokemon | null = null; for (const p of party) { - if (unfainted && p.isFainted()) { + if (isAllowed && !p.isAllowedInChallenge()) { + continue; + } + if (!isFainted && p.isFainted()) { continue; } @@ -166,25 +202,34 @@ export function getHighestStatTotalPlayerPokemon(scene: BattleScene, unfainted: * @param starterTiers * @param excludedSpecies * @param types + * @param allowSubLegendary + * @param allowLegendary + * @param allowMythical * @returns */ -export function getRandomSpeciesByStarterTier(starterTiers: number | [number, number], excludedSpecies?: Species[], types?: Type[]): Species { +export function getRandomSpeciesByStarterTier(starterTiers: number | [number, number], excludedSpecies?: Species[], types?: Type[], allowSubLegendary: boolean = true, allowLegendary: boolean = true, allowMythical: boolean = true): Species { let min = Array.isArray(starterTiers) ? starterTiers[0] : starterTiers; let max = Array.isArray(starterTiers) ? starterTiers[1] : starterTiers; - let filteredSpecies: [PokemonSpecies, number][] = Object.keys(speciesStarters) - .map(s => [parseInt(s) as Species, speciesStarters[s] as number]) - .filter(s => getPokemonSpecies(s[0]) && (!excludedSpecies || !excludedSpecies.includes(s[0]))) - .map(s => [getPokemonSpecies(s[0]), s[1]]); + let filteredSpecies: [PokemonSpecies, number][] = Object.keys(speciesStarterCosts) + .map(s => [ parseInt(s) as Species, speciesStarterCosts[s] as number ]) + .filter(s => { + const pokemonSpecies = getPokemonSpecies(s[0]); + return pokemonSpecies && (!excludedSpecies || !excludedSpecies.includes(s[0])) + && (allowSubLegendary || !pokemonSpecies.subLegendary) + && (allowLegendary || !pokemonSpecies.legendary) + && (allowMythical || !pokemonSpecies.mythical); + }) + .map(s => [ getPokemonSpecies(s[0]), s[1] ]); if (types && types.length > 0) { - filteredSpecies = filteredSpecies.filter(s => types.includes(s[0].type1) || (!isNullOrUndefined(s[0].type2) && types.includes(s[0].type2!))); + filteredSpecies = filteredSpecies.filter(s => types.includes(s[0].type1) || (!isNullOrUndefined(s[0].type2) && types.includes(s[0].type2))); } // If no filtered mons exist at specified starter tiers, will expand starter search range until there are // Starts by decrementing starter tier min until it is 0, then increments tier max up to 10 let tryFilterStarterTiers: [PokemonSpecies, number][] = filteredSpecies.filter(s => (s[1] >= min && s[1] <= max)); - while (tryFilterStarterTiers.length === 0 && (min !== 0 && max !== 10)) { + while (tryFilterStarterTiers.length === 0 && !(min === 0 && max === 10)) { if (min > 0) { min--; } else { @@ -271,7 +316,9 @@ export function applyHealToPokemon(scene: BattleScene, pokemon: PlayerPokemon, h * @param value */ export async function modifyPlayerPokemonBST(pokemon: PlayerPokemon, value: number) { - const modType = modifierTypes.MYSTERY_ENCOUNTER_SHUCKLE_JUICE().generateType(pokemon.scene.getParty(), [value]); + const modType = modifierTypes.MYSTERY_ENCOUNTER_SHUCKLE_JUICE() + .generateType(pokemon.scene.getPlayerParty(), [ value ]) + ?.withIdFromFunc(modifierTypes.MYSTERY_ENCOUNTER_SHUCKLE_JUICE); const modifier = modType?.newModifier(pokemon); if (modifier) { await pokemon.scene.addModifier(modifier, false, false, false, true); @@ -289,10 +336,12 @@ export async function modifyPlayerPokemonBST(pokemon: PlayerPokemon, value: numb */ export async function applyModifierTypeToPlayerPokemon(scene: BattleScene, pokemon: PlayerPokemon, modType: PokemonHeldItemModifierType, fallbackModifierType?: PokemonHeldItemModifierType) { // Check if the Pokemon has max stacks of that item already + const modifier = modType.newModifier(pokemon); const existing = scene.findModifier(m => ( m instanceof PokemonHeldItemModifier && m.type.id === modType.id && - m.pokemonId === pokemon.id + m.pokemonId === pokemon.id && + m.matchType(modifier) )) as PokemonHeldItemModifier; // At max stacks @@ -305,7 +354,6 @@ export async function applyModifierTypeToPlayerPokemon(scene: BattleScene, pokem return applyModifierTypeToPlayerPokemon(scene, pokemon, fallbackModifierType); } - const modifier = modType.newModifier(pokemon); await scene.addModifier(modifier, false, false, false, true); } @@ -327,7 +375,7 @@ export function trainerThrowPokeball(scene: BattleScene, pokemon: EnemyPokemon, const _3m = 3 * pokemon.getMaxHp(); const _2h = 2 * pokemon.hp; const catchRate = pokemon.species.catchRate; - const pokeballMultiplier = getPokeballCatchMultiplier(this.pokeballType); + const pokeballMultiplier = getPokeballCatchMultiplier(pokeballType); const statusMultiplier = pokemon.status ? getStatusEffectCatchRateMultiplier(pokemon.status.effect) : 1; const x = Math.round((((_3m - _2h) * catchRate * pokeballMultiplier) / _3m) * statusMultiplier); ballTwitchRate = Math.round(65536 / Math.sqrt(Math.sqrt(255 / x))); @@ -501,8 +549,6 @@ function failCatch(scene: BattleScene, pokemon: EnemyPokemon, originalY: number, * @param isObtain */ export async function catchPokemon(scene: BattleScene, pokemon: EnemyPokemon, pokeball: Phaser.GameObjects.Sprite | null, pokeballType: PokeballType, showCatchObtainMessage: boolean = true, isObtain: boolean = false): Promise { - scene.unshiftPhase(new VictoryPhase(scene, pokemon.id, true)); - const speciesForm = !pokemon.fusionSpecies ? pokemon.getSpeciesForm() : pokemon.getFusionSpeciesForm(); if (speciesForm.abilityHidden && (pokemon.fusionSpecies ? pokemon.fusionAbilityIndex : pokemon.abilityIndex) === speciesForm.getAbilityCount() - 1) { @@ -528,6 +574,11 @@ export async function catchPokemon(scene: BattleScene, pokemon: EnemyPokemon, po return new Promise(resolve => { const doPokemonCatchMenu = () => { const end = () => { + // Ensure the pokemon is in the enemy party in all situations + if (!scene.getEnemyParty().some(p => p.id === pokemon.id)) { + scene.getEnemyParty().push(pokemon); + } + scene.unshiftPhase(new VictoryPhase(scene, pokemon.id, true)); scene.pokemonInfoContainer.hide(); if (pokeball) { removePb(scene, pokeball); @@ -539,10 +590,10 @@ export async function catchPokemon(scene: BattleScene, pokemon: EnemyPokemon, po scene.field.remove(pokemon, true); } }; - const addToParty = () => { - const newPokemon = pokemon.addToParty(pokeballType); + const addToParty = (slotIndex?: number) => { + const newPokemon = pokemon.addToParty(pokeballType, slotIndex); const modifiers = scene.findModifiers(m => m instanceof PokemonHeldItemModifier, false); - if (scene.getParty().filter(p => p.isShiny()).length === 6) { + if (scene.getPlayerParty().filter(p => p.isShiny()).length === 6) { scene.validateAchv(achvs.SHINY_PARTY); } Promise.all(modifiers.map(m => scene.addModifier(m, true))).then(() => { @@ -555,16 +606,23 @@ export async function catchPokemon(scene: BattleScene, pokemon: EnemyPokemon, po } }); }; - Promise.all([pokemon.hideInfo(), scene.gameData.setPokemonCaught(pokemon)]).then(() => { - if (scene.getParty().length === 6) { + Promise.all([ pokemon.hideInfo(), scene.gameData.setPokemonCaught(pokemon) ]).then(() => { + if (scene.getPlayerParty().length === 6) { const promptRelease = () => { scene.ui.showText(i18next.t("battle:partyFull", { pokemonName: pokemon.getNameToRender() }), null, () => { - scene.pokemonInfoContainer.makeRoomForConfirmUi(); + scene.pokemonInfoContainer.makeRoomForConfirmUi(1, true); scene.ui.setMode(Mode.CONFIRM, () => { - scene.ui.setMode(Mode.PARTY, PartyUiMode.RELEASE, 0, (slotIndex: number, _option: PartyOption) => { + const newPokemon = scene.addPlayerPokemon(pokemon.species, pokemon.level, pokemon.abilityIndex, pokemon.formIndex, pokemon.gender, pokemon.shiny, pokemon.variant, pokemon.ivs, pokemon.nature, pokemon); + scene.ui.setMode(Mode.SUMMARY, newPokemon, 0, SummaryUiMode.DEFAULT, () => { + scene.ui.setMode(Mode.MESSAGE).then(() => { + promptRelease(); + }); + }, false); + }, () => { + scene.ui.setMode(Mode.PARTY, PartyUiMode.RELEASE, 0, (slotIndex: integer, _option: PartyOption) => { scene.ui.setMode(Mode.MESSAGE).then(() => { if (slotIndex < 6) { - addToParty(); + addToParty(slotIndex); } else { promptRelease(); } @@ -575,7 +633,7 @@ export async function catchPokemon(scene: BattleScene, pokemon: EnemyPokemon, po removePokemon(); end(); }); - }); + }, "fullParty"); }); }; promptRelease(); @@ -674,50 +732,126 @@ export function doPlayerFlee(scene: BattleScene, pokemon: EnemyPokemon): Promise * Bug Species and their corresponding weights */ const GOLDEN_BUG_NET_SPECIES_POOL: [Species, number][] = [ - [Species.SCYTHER, 40], - [Species.SCIZOR, 40], - [Species.KLEAVOR, 40], - [Species.PINSIR, 40], - [Species.HERACROSS, 40], - [Species.YANMA, 40], - [Species.YANMEGA, 40], - [Species.SHUCKLE, 40], - [Species.ANORITH, 40], - [Species.ARMALDO, 40], - [Species.ESCAVALIER, 40], - [Species.ACCELGOR, 40], - [Species.JOLTIK, 40], - [Species.GALVANTULA, 40], - [Species.DURANT, 40], - [Species.LARVESTA, 40], - [Species.VOLCARONA, 40], - [Species.DEWPIDER, 40], - [Species.ARAQUANID, 40], - [Species.WIMPOD, 40], - [Species.GOLISOPOD, 40], - [Species.SIZZLIPEDE, 40], - [Species.CENTISKORCH, 40], - [Species.NYMBLE, 40], - [Species.LOKIX, 40], - [Species.BUZZWOLE, 1], - [Species.PHEROMOSA, 1], + [ Species.SCYTHER, 40 ], + [ Species.SCIZOR, 40 ], + [ Species.KLEAVOR, 40 ], + [ Species.PINSIR, 40 ], + [ Species.HERACROSS, 40 ], + [ Species.YANMA, 40 ], + [ Species.YANMEGA, 40 ], + [ Species.SHUCKLE, 40 ], + [ Species.ANORITH, 40 ], + [ Species.ARMALDO, 40 ], + [ Species.ESCAVALIER, 40 ], + [ Species.ACCELGOR, 40 ], + [ Species.JOLTIK, 40 ], + [ Species.GALVANTULA, 40 ], + [ Species.DURANT, 40 ], + [ Species.LARVESTA, 40 ], + [ Species.VOLCARONA, 40 ], + [ Species.DEWPIDER, 40 ], + [ Species.ARAQUANID, 40 ], + [ Species.WIMPOD, 40 ], + [ Species.GOLISOPOD, 40 ], + [ Species.SIZZLIPEDE, 40 ], + [ Species.CENTISKORCH, 40 ], + [ Species.NYMBLE, 40 ], + [ Species.LOKIX, 40 ], + [ Species.BUZZWOLE, 1 ], + [ Species.PHEROMOSA, 1 ], ]; /** - * Will randomly return one of the species from GOLDEN_BUG_NET_SPECIES_POOL, based on their weights + * Will randomly return one of the species from GOLDEN_BUG_NET_SPECIES_POOL, based on their weights. + * Will also check for and evolve pokemon based on level. */ -export function getGoldenBugNetSpecies(): PokemonSpecies { +export function getGoldenBugNetSpecies(level: number): PokemonSpecies { const totalWeight = GOLDEN_BUG_NET_SPECIES_POOL.reduce((a, b) => a + b[1], 0); const roll = randSeedInt(totalWeight); let w = 0; - for (const species of GOLDEN_BUG_NET_SPECIES_POOL) { - w += species[1]; + for (const speciesWeightPair of GOLDEN_BUG_NET_SPECIES_POOL) { + w += speciesWeightPair[1]; if (roll < w) { - return getPokemonSpecies(species); + const initialSpecies = getPokemonSpecies(speciesWeightPair[0]); + return getPokemonSpecies(initialSpecies.getSpeciesForLevel(level, true)); } } // Defaults to Scyther return getPokemonSpecies(Species.SCYTHER); } + +/** + * Generates a Pokemon level for a given wave, with an option to increase/decrease by a scaling modifier + * @param scene + * @param levelAdditiveModifier Default 0. will add +(1 level / 10 waves * levelAdditiveModifier) to the level calculation + */ +export function getEncounterPokemonLevelForWave(scene: BattleScene, levelAdditiveModifier: number = 0) { + const currentBattle = scene.currentBattle; + const baseLevel = currentBattle.getLevelForWave(); + + // Add a level scaling modifier that is (+1 level per 10 waves) * levelAdditiveModifier + return baseLevel + Math.max(Math.round((currentBattle.waveIndex / 10) * levelAdditiveModifier), 0); +} + +export async function addPokemonDataToDexAndValidateAchievements(scene: BattleScene, pokemon: PlayerPokemon) { + const speciesForm = !pokemon.fusionSpecies ? pokemon.getSpeciesForm() : pokemon.getFusionSpeciesForm(); + + if (speciesForm.abilityHidden && (pokemon.fusionSpecies ? pokemon.fusionAbilityIndex : pokemon.abilityIndex) === speciesForm.getAbilityCount() - 1) { + scene.validateAchv(achvs.HIDDEN_ABILITY); + } + + if (pokemon.species.subLegendary) { + scene.validateAchv(achvs.CATCH_SUB_LEGENDARY); + } + + if (pokemon.species.legendary) { + scene.validateAchv(achvs.CATCH_LEGENDARY); + } + + if (pokemon.species.mythical) { + scene.validateAchv(achvs.CATCH_MYTHICAL); + } + + scene.gameData.updateSpeciesDexIvs(pokemon.species.getRootSpeciesId(true), pokemon.ivs); + return scene.gameData.setPokemonCaught(pokemon, true, false, false); +} + +/** + * Checks if a Pokemon is allowed under a challenge, and allowed in battle. + * If both are true, returns `null`. + * If one of them is not true, returns message content that the Pokemon is invalid. + * Typically used for cheecking whether a Pokemon can be selected for a {@linkcode MysteryEncounterOption} + * @param pokemon + * @param scene + * @param invalidSelectionKey + */ +export function isPokemonValidForEncounterOptionSelection(pokemon: Pokemon, scene: BattleScene, invalidSelectionKey: string): string | null { + if (!pokemon.isAllowedInChallenge()) { + return i18next.t("partyUiHandler:cantBeUsed", { pokemonName: pokemon.getNameToRender() }) ?? null; + } + if (!pokemon.isAllowedInBattle()) { + return getEncounterText(scene, invalidSelectionKey) ?? null; + } + + return null; +} + +/** + * Permanently overrides the ability (not passive) of a pokemon. + * If the pokemon is a fusion, instead overrides the fused pokemon's ability. + */ +export function applyAbilityOverrideToPokemon(pokemon: Pokemon, ability: Abilities) { + if (pokemon.isFusion()) { + if (!pokemon.fusionCustomPokemonData) { + pokemon.fusionCustomPokemonData = new CustomPokemonData(); + } + pokemon.fusionCustomPokemonData.ability = ability; + } else { + if (!pokemon.customPokemonData) { + pokemon.customPokemonData = new CustomPokemonData(); + } + pokemon.customPokemonData.ability = ability; + } +} diff --git a/src/data/mystery-encounters/utils/encounter-transformation-sequence.ts b/src/data/mystery-encounters/utils/encounter-transformation-sequence.ts index fd9d43829e5..fcadb101817 100644 --- a/src/data/mystery-encounters/utils/encounter-transformation-sequence.ts +++ b/src/data/mystery-encounters/utils/encounter-transformation-sequence.ts @@ -103,7 +103,7 @@ export function doPokemonTransformationSequence(scene: BattleScene, previousPoke scene.time.delayedCall(1000, () => { pokemonEvoTintSprite.setScale(0.25); pokemonEvoTintSprite.setVisible(true); - doCycle(scene, 2, 6, pokemonTintSprite, pokemonEvoTintSprite).then(() => { + doCycle(scene, 1.5, 6, pokemonTintSprite, pokemonEvoTintSprite).then(() => { pokemonEvoSprite.setVisible(true); doCircleInward(scene, transformationBaseBg, transformationContainer, xOffset, yOffset); @@ -115,7 +115,7 @@ export function doPokemonTransformationSequence(scene: BattleScene, previousPoke delay: 150, easing: "Sine.easeIn", onComplete: () => { - scene.time.delayedCall(2500, () => { + scene.time.delayedCall(3000, () => { resolve(); scene.tweens.add({ targets: pokemonEvoSprite, diff --git a/src/data/nature.ts b/src/data/nature.ts index c614be465c3..b90047ce6f0 100644 --- a/src/data/nature.ts +++ b/src/data/nature.ts @@ -3,9 +3,7 @@ import { TextStyle, getBBCodeFrag } from "../ui/text"; import { Nature } from "#enums/nature"; import { UiTheme } from "#enums/ui-theme"; import i18next from "i18next"; -import { Stat, EFFECTIVE_STATS, getShortenedStatKey } from "#app/enums/stat"; - -export { Nature }; +import { Stat, EFFECTIVE_STATS, getShortenedStatKey } from "#enums/stat"; export function getNatureName(nature: Nature, includeStatEffects: boolean = false, forStarterSelect: boolean = false, ignoreBBCode: boolean = false, uiTheme: UiTheme = UiTheme.DEFAULT): string { let ret = Utils.toReadableString(Nature[nature]); @@ -37,76 +35,76 @@ export function getNatureName(nature: Nature, includeStatEffects: boolean = fals export function getNatureStatMultiplier(nature: Nature, stat: Stat): number { switch (stat) { - case Stat.ATK: - switch (nature) { - case Nature.LONELY: - case Nature.BRAVE: - case Nature.ADAMANT: - case Nature.NAUGHTY: - return 1.1; - case Nature.BOLD: - case Nature.TIMID: - case Nature.MODEST: - case Nature.CALM: - return 0.9; - } - break; - case Stat.DEF: - switch (nature) { - case Nature.BOLD: - case Nature.RELAXED: - case Nature.IMPISH: - case Nature.LAX: - return 1.1; - case Nature.LONELY: - case Nature.HASTY: - case Nature.MILD: - case Nature.GENTLE: - return 0.9; - } - break; - case Stat.SPATK: - switch (nature) { - case Nature.MODEST: - case Nature.MILD: - case Nature.QUIET: - case Nature.RASH: - return 1.1; - case Nature.ADAMANT: - case Nature.IMPISH: - case Nature.JOLLY: - case Nature.CAREFUL: - return 0.9; - } - break; - case Stat.SPDEF: - switch (nature) { - case Nature.CALM: - case Nature.GENTLE: - case Nature.SASSY: - case Nature.CAREFUL: - return 1.1; - case Nature.NAUGHTY: - case Nature.LAX: - case Nature.NAIVE: - case Nature.RASH: - return 0.9; - } - break; - case Stat.SPD: - switch (nature) { - case Nature.TIMID: - case Nature.HASTY: - case Nature.JOLLY: - case Nature.NAIVE: - return 1.1; - case Nature.BRAVE: - case Nature.RELAXED: - case Nature.QUIET: - case Nature.SASSY: - return 0.9; - } - break; + case Stat.ATK: + switch (nature) { + case Nature.LONELY: + case Nature.BRAVE: + case Nature.ADAMANT: + case Nature.NAUGHTY: + return 1.1; + case Nature.BOLD: + case Nature.TIMID: + case Nature.MODEST: + case Nature.CALM: + return 0.9; + } + break; + case Stat.DEF: + switch (nature) { + case Nature.BOLD: + case Nature.RELAXED: + case Nature.IMPISH: + case Nature.LAX: + return 1.1; + case Nature.LONELY: + case Nature.HASTY: + case Nature.MILD: + case Nature.GENTLE: + return 0.9; + } + break; + case Stat.SPATK: + switch (nature) { + case Nature.MODEST: + case Nature.MILD: + case Nature.QUIET: + case Nature.RASH: + return 1.1; + case Nature.ADAMANT: + case Nature.IMPISH: + case Nature.JOLLY: + case Nature.CAREFUL: + return 0.9; + } + break; + case Stat.SPDEF: + switch (nature) { + case Nature.CALM: + case Nature.GENTLE: + case Nature.SASSY: + case Nature.CAREFUL: + return 1.1; + case Nature.NAUGHTY: + case Nature.LAX: + case Nature.NAIVE: + case Nature.RASH: + return 0.9; + } + break; + case Stat.SPD: + switch (nature) { + case Nature.TIMID: + case Nature.HASTY: + case Nature.JOLLY: + case Nature.NAIVE: + return 1.1; + case Nature.BRAVE: + case Nature.RELAXED: + case Nature.QUIET: + case Nature.SASSY: + return 0.9; + } + break; } return 1; diff --git a/src/data/pokeball.ts b/src/data/pokeball.ts index 59ff4ed86ce..4c9fc719a4d 100644 --- a/src/data/pokeball.ts +++ b/src/data/pokeball.ts @@ -1,92 +1,119 @@ +import { CriticalCatchChanceBoosterModifier } from "#app/modifier/modifier"; +import { NumberHolder } from "#app/utils"; import { PokeballType } from "#enums/pokeball"; import BattleScene from "../battle-scene"; import i18next from "i18next"; -export { PokeballType }; - export const MAX_PER_TYPE_POKEBALLS: integer = 99; export function getPokeballAtlasKey(type: PokeballType): string { switch (type) { - case PokeballType.POKEBALL: - return "pb"; - case PokeballType.GREAT_BALL: - return "gb"; - case PokeballType.ULTRA_BALL: - return "ub"; - case PokeballType.ROGUE_BALL: - return "rb"; - case PokeballType.MASTER_BALL: - return "mb"; - case PokeballType.LUXURY_BALL: - return "lb"; + case PokeballType.POKEBALL: + return "pb"; + case PokeballType.GREAT_BALL: + return "gb"; + case PokeballType.ULTRA_BALL: + return "ub"; + case PokeballType.ROGUE_BALL: + return "rb"; + case PokeballType.MASTER_BALL: + return "mb"; + case PokeballType.LUXURY_BALL: + return "lb"; } } export function getPokeballName(type: PokeballType): string { let ret: string; switch (type) { - case PokeballType.POKEBALL: - ret = i18next.t("pokeball:pokeBall"); - break; - case PokeballType.GREAT_BALL: - ret = i18next.t("pokeball:greatBall"); - break; - case PokeballType.ULTRA_BALL: - ret = i18next.t("pokeball:ultraBall"); - break; - case PokeballType.ROGUE_BALL: - ret = i18next.t("pokeball:rogueBall"); - break; - case PokeballType.MASTER_BALL: - ret = i18next.t("pokeball:masterBall"); - break; - case PokeballType.LUXURY_BALL: - ret = i18next.t("pokeball:luxuryBall"); - break; + case PokeballType.POKEBALL: + ret = i18next.t("pokeball:pokeBall"); + break; + case PokeballType.GREAT_BALL: + ret = i18next.t("pokeball:greatBall"); + break; + case PokeballType.ULTRA_BALL: + ret = i18next.t("pokeball:ultraBall"); + break; + case PokeballType.ROGUE_BALL: + ret = i18next.t("pokeball:rogueBall"); + break; + case PokeballType.MASTER_BALL: + ret = i18next.t("pokeball:masterBall"); + break; + case PokeballType.LUXURY_BALL: + ret = i18next.t("pokeball:luxuryBall"); + break; } return ret; } export function getPokeballCatchMultiplier(type: PokeballType): number { switch (type) { - case PokeballType.POKEBALL: - return 1; - case PokeballType.GREAT_BALL: - return 1.5; - case PokeballType.ULTRA_BALL: - return 2; - case PokeballType.ROGUE_BALL: - return 3; - case PokeballType.MASTER_BALL: - return -1; - case PokeballType.LUXURY_BALL: - return 1; + case PokeballType.POKEBALL: + return 1; + case PokeballType.GREAT_BALL: + return 1.5; + case PokeballType.ULTRA_BALL: + return 2; + case PokeballType.ROGUE_BALL: + return 3; + case PokeballType.MASTER_BALL: + return -1; + case PokeballType.LUXURY_BALL: + return 1; } } export function getPokeballTintColor(type: PokeballType): number { switch (type) { - case PokeballType.POKEBALL: - return 0xd52929; - case PokeballType.GREAT_BALL: - return 0x94b4de; - case PokeballType.ULTRA_BALL: - return 0xe6cd31; - case PokeballType.ROGUE_BALL: - return 0xd52929; - case PokeballType.MASTER_BALL: - return 0xa441bd; - case PokeballType.LUXURY_BALL: - return 0xffde6a; + case PokeballType.POKEBALL: + return 0xd52929; + case PokeballType.GREAT_BALL: + return 0x94b4de; + case PokeballType.ULTRA_BALL: + return 0xe6cd31; + case PokeballType.ROGUE_BALL: + return 0xd52929; + case PokeballType.MASTER_BALL: + return 0xa441bd; + case PokeballType.LUXURY_BALL: + return 0xffde6a; } } -export function doPokeballBounceAnim(scene: BattleScene, pokeball: Phaser.GameObjects.Sprite, y1: number, y2: number, baseBounceDuration: integer, callback: Function) { +/** + * Gets the critical capture chance based on number of mons registered in Dex and modified {@link https://bulbapedia.bulbagarden.net/wiki/Catch_rate Catch rate} + * Formula from {@link https://www.dragonflycave.com/mechanics/gen-vi-vii-capturing Dragonfly Cave Gen 6 Capture Mechanics page} + * @param scene {@linkcode BattleScene} current BattleScene + * @param modifiedCatchRate the modified catch rate as calculated in {@linkcode AttemptCapturePhase} + * @returns the chance of getting a critical capture, out of 256 + */ +export function getCriticalCaptureChance(scene: BattleScene, modifiedCatchRate: number): number { + if (scene.gameMode.isFreshStartChallenge()) { + return 0; + } + const dexCount = scene.gameData.getSpeciesCount(d => !!d.caughtAttr); + const catchingCharmMultiplier = new NumberHolder(1); + scene.findModifier(m => m instanceof CriticalCatchChanceBoosterModifier)?.apply(catchingCharmMultiplier); + const dexMultiplier = scene.gameMode.isDaily || dexCount > 800 ? 2.5 + : dexCount > 600 ? 2 + : dexCount > 400 ? 1.5 + : dexCount > 200 ? 1 + : dexCount > 100 ? 0.5 + : 0; + return Math.floor(catchingCharmMultiplier.value * dexMultiplier * Math.min(255, modifiedCatchRate) / 6); +} + +export function doPokeballBounceAnim(scene: BattleScene, pokeball: Phaser.GameObjects.Sprite, y1: number, y2: number, baseBounceDuration: number, callback: Function, isCritical: boolean = false) { let bouncePower = 1; let bounceYOffset = y1; let bounceY = y2; const yd = y2 - y1; + const x0 = pokeball.x; + const x1 = x0 + 3; + const x2 = x0 - 3; + let critShakes = 4; const doBounce = () => { scene.tweens.add({ @@ -117,5 +144,40 @@ export function doPokeballBounceAnim(scene: BattleScene, pokeball: Phaser.GameOb }); }; - doBounce(); + const doCritShake = () => { + scene.tweens.add({ + targets: pokeball, + x: x2, + duration: 125, + ease: "Linear", + onComplete: () => { + scene.tweens.add({ + targets: pokeball, + x: x1, + duration: 125, + ease: "Linear", + onComplete: () => { + critShakes--; + if (critShakes > 0) { + doCritShake(); + } else { + scene.tweens.add({ + targets: pokeball, + x: x0, + duration: 60, + ease: "Linear", + onComplete: () => scene.time.delayedCall(500, doBounce) + }); + } + } + }); + } + }); + }; + + if (isCritical) { + scene.time.delayedCall(500, doCritShake); + } else { + doBounce(); + } } diff --git a/src/data/pokemon-forms.ts b/src/data/pokemon-forms.ts index a904f497b0f..2db0ed54294 100644 --- a/src/data/pokemon-forms.ts +++ b/src/data/pokemon-forms.ts @@ -1,18 +1,18 @@ import { PokemonFormChangeItemModifier, TerastallizeModifier } from "../modifier/modifier"; import Pokemon from "../field/pokemon"; -import { SpeciesFormKey } from "./pokemon-species"; -import { StatusEffect } from "./status-effect"; +import { StatusEffect } from "#enums/status-effect"; import { MoveCategory, allMoves } from "./move"; -import { Type } from "./type"; -import { Constructor } from "#app/utils"; +import { Type } from "#enums/type"; +import { Constructor, nil } from "#app/utils"; import { Abilities } from "#enums/abilities"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; import { TimeOfDay } from "#enums/time-of-day"; import { getPokemonNameWithAffix } from "#app/messages"; import i18next from "i18next"; -import { WeatherType } from "./weather"; +import { WeatherType } from "#enums/weather-type"; import { Challenges } from "#app/enums/challenges"; +import { SpeciesFormKey } from "#enums/species-form-key"; export enum FormChangeItem { NONE, @@ -185,7 +185,7 @@ export class SpeciesFormChange { return true; } - findTrigger(triggerType: Constructor): SpeciesFormChangeTrigger | null { + findTrigger(triggerType: Constructor): SpeciesFormChangeTrigger | nil { if (!this.trigger.hasTriggerType(triggerType)) { return null; } @@ -193,7 +193,7 @@ export class SpeciesFormChange { const trigger = this.trigger; if (trigger instanceof SpeciesFormChangeCompoundTrigger) { - return trigger.triggers.find(t => t.hasTriggerType(triggerType))!; // TODO: is this bang correct? + return trigger.triggers.find(t => t.hasTriggerType(triggerType)); } return trigger; @@ -202,11 +202,11 @@ export class SpeciesFormChange { export class SpeciesFormChangeCondition { public predicate: SpeciesFormChangeConditionPredicate; - public enforceFunc: SpeciesFormChangeConditionEnforceFunc | null; + public enforceFunc: SpeciesFormChangeConditionEnforceFunc | nil; constructor(predicate: SpeciesFormChangeConditionPredicate, enforceFunc?: SpeciesFormChangeConditionEnforceFunc) { this.predicate = predicate; - this.enforceFunc = enforceFunc!; // TODO: is this bang correct? + this.enforceFunc = enforceFunc; } } @@ -640,18 +640,18 @@ export const pokemonFormChanges: PokemonFormChanges = { new SpeciesFormChange(Species.ALTARIA, "", SpeciesFormKey.MEGA, new SpeciesFormChangeItemTrigger(FormChangeItem.ALTARIANITE)) ], [Species.CASTFORM]: [ - new SpeciesFormChange(Species.CASTFORM, "", "sunny", new SpeciesFormChangeWeatherTrigger(Abilities.FORECAST, [WeatherType.SUNNY, WeatherType.HARSH_SUN]), true), - new SpeciesFormChange(Species.CASTFORM, "rainy", "sunny", new SpeciesFormChangeWeatherTrigger(Abilities.FORECAST, [WeatherType.SUNNY, WeatherType.HARSH_SUN]), true), - new SpeciesFormChange(Species.CASTFORM, "snowy", "sunny", new SpeciesFormChangeWeatherTrigger(Abilities.FORECAST, [WeatherType.SUNNY, WeatherType.HARSH_SUN]), true), - new SpeciesFormChange(Species.CASTFORM, "", "rainy", new SpeciesFormChangeWeatherTrigger(Abilities.FORECAST, [WeatherType.RAIN, WeatherType.HEAVY_RAIN]), true), - new SpeciesFormChange(Species.CASTFORM, "sunny", "rainy", new SpeciesFormChangeWeatherTrigger(Abilities.FORECAST, [WeatherType.RAIN, WeatherType.HEAVY_RAIN]), true), - new SpeciesFormChange(Species.CASTFORM, "snowy", "rainy", new SpeciesFormChangeWeatherTrigger(Abilities.FORECAST, [WeatherType.RAIN, WeatherType.HEAVY_RAIN]), true), - new SpeciesFormChange(Species.CASTFORM, "", "snowy", new SpeciesFormChangeWeatherTrigger(Abilities.FORECAST, [WeatherType.HAIL, WeatherType.SNOW]), true), - new SpeciesFormChange(Species.CASTFORM, "sunny", "snowy", new SpeciesFormChangeWeatherTrigger(Abilities.FORECAST, [WeatherType.HAIL, WeatherType.SNOW]), true), - new SpeciesFormChange(Species.CASTFORM, "rainy", "snowy", new SpeciesFormChangeWeatherTrigger(Abilities.FORECAST, [WeatherType.HAIL, WeatherType.SNOW]), true), - new SpeciesFormChange(Species.CASTFORM, "sunny", "", new SpeciesFormChangeRevertWeatherFormTrigger(Abilities.FORECAST, [WeatherType.NONE, WeatherType.SANDSTORM, WeatherType.STRONG_WINDS, WeatherType.FOG]), true), - new SpeciesFormChange(Species.CASTFORM, "rainy", "", new SpeciesFormChangeRevertWeatherFormTrigger(Abilities.FORECAST, [WeatherType.NONE, WeatherType.SANDSTORM, WeatherType.STRONG_WINDS, WeatherType.FOG]), true), - new SpeciesFormChange(Species.CASTFORM, "snowy", "", new SpeciesFormChangeRevertWeatherFormTrigger(Abilities.FORECAST, [WeatherType.NONE, WeatherType.SANDSTORM, WeatherType.STRONG_WINDS, WeatherType.FOG]), true), + new SpeciesFormChange(Species.CASTFORM, "", "sunny", new SpeciesFormChangeWeatherTrigger(Abilities.FORECAST, [ WeatherType.SUNNY, WeatherType.HARSH_SUN ]), true), + new SpeciesFormChange(Species.CASTFORM, "rainy", "sunny", new SpeciesFormChangeWeatherTrigger(Abilities.FORECAST, [ WeatherType.SUNNY, WeatherType.HARSH_SUN ]), true), + new SpeciesFormChange(Species.CASTFORM, "snowy", "sunny", new SpeciesFormChangeWeatherTrigger(Abilities.FORECAST, [ WeatherType.SUNNY, WeatherType.HARSH_SUN ]), true), + new SpeciesFormChange(Species.CASTFORM, "", "rainy", new SpeciesFormChangeWeatherTrigger(Abilities.FORECAST, [ WeatherType.RAIN, WeatherType.HEAVY_RAIN ]), true), + new SpeciesFormChange(Species.CASTFORM, "sunny", "rainy", new SpeciesFormChangeWeatherTrigger(Abilities.FORECAST, [ WeatherType.RAIN, WeatherType.HEAVY_RAIN ]), true), + new SpeciesFormChange(Species.CASTFORM, "snowy", "rainy", new SpeciesFormChangeWeatherTrigger(Abilities.FORECAST, [ WeatherType.RAIN, WeatherType.HEAVY_RAIN ]), true), + new SpeciesFormChange(Species.CASTFORM, "", "snowy", new SpeciesFormChangeWeatherTrigger(Abilities.FORECAST, [ WeatherType.HAIL, WeatherType.SNOW ]), true), + new SpeciesFormChange(Species.CASTFORM, "sunny", "snowy", new SpeciesFormChangeWeatherTrigger(Abilities.FORECAST, [ WeatherType.HAIL, WeatherType.SNOW ]), true), + new SpeciesFormChange(Species.CASTFORM, "rainy", "snowy", new SpeciesFormChangeWeatherTrigger(Abilities.FORECAST, [ WeatherType.HAIL, WeatherType.SNOW ]), true), + new SpeciesFormChange(Species.CASTFORM, "sunny", "", new SpeciesFormChangeRevertWeatherFormTrigger(Abilities.FORECAST, [ WeatherType.NONE, WeatherType.SANDSTORM, WeatherType.STRONG_WINDS, WeatherType.FOG ]), true), + new SpeciesFormChange(Species.CASTFORM, "rainy", "", new SpeciesFormChangeRevertWeatherFormTrigger(Abilities.FORECAST, [ WeatherType.NONE, WeatherType.SANDSTORM, WeatherType.STRONG_WINDS, WeatherType.FOG ]), true), + new SpeciesFormChange(Species.CASTFORM, "snowy", "", new SpeciesFormChangeRevertWeatherFormTrigger(Abilities.FORECAST, [ WeatherType.NONE, WeatherType.SANDSTORM, WeatherType.STRONG_WINDS, WeatherType.FOG ]), true), new SpeciesFormChange(Species.CASTFORM, "sunny", "", new SpeciesFormChangeActiveTrigger(), true), new SpeciesFormChange(Species.CASTFORM, "rainy", "", new SpeciesFormChangeActiveTrigger(), true), new SpeciesFormChange(Species.CASTFORM, "snowy", "", new SpeciesFormChangeActiveTrigger(), true) @@ -799,8 +799,8 @@ export const pokemonFormChanges: PokemonFormChanges = { [Species.ZYGARDE]: [ new SpeciesFormChange(Species.ZYGARDE, "50-pc", "complete", new SpeciesFormChangeManualTrigger(), true), new SpeciesFormChange(Species.ZYGARDE, "complete", "50-pc", new SpeciesFormChangeManualTrigger(), true), - new SpeciesFormChange(Species.ZYGARDE, "10-pc", "complete", new SpeciesFormChangeManualTrigger(), true), - new SpeciesFormChange(Species.ZYGARDE, "complete", "10-pc", new SpeciesFormChangeManualTrigger(), true) + new SpeciesFormChange(Species.ZYGARDE, "10-pc", "10-complete", new SpeciesFormChangeManualTrigger(), true), + new SpeciesFormChange(Species.ZYGARDE, "10-complete", "10-pc", new SpeciesFormChangeManualTrigger(), true) ], [Species.DIANCIE]: [ new SpeciesFormChange(Species.DIANCIE, "", SpeciesFormKey.MEGA, new SpeciesFormChangeItemTrigger(FormChangeItem.DIANCITE)) diff --git a/src/data/pokemon-species.ts b/src/data/pokemon-species.ts index 4eb526eeb2b..ec104d4d4aa 100644 --- a/src/data/pokemon-species.ts +++ b/src/data/pokemon-species.ts @@ -4,18 +4,20 @@ import { PartyMemberStrength } from "#enums/party-member-strength"; import { Species } from "#enums/species"; import { QuantizerCelebi, argbFromRgba, rgbaFromArgb } from "@material/material-color-utilities"; import i18next from "i18next"; -import BattleScene, { AnySound } from "../battle-scene"; -import { GameMode } from "../game-mode"; -import { StarterMoveset } from "../system/game-data"; -import * as Utils from "../utils"; -import { uncatchableSpecies } from "./biomes"; -import { speciesEggMoves } from "./egg-moves"; -import { GrowthRate } from "./exp"; -import { EvolutionLevel, SpeciesWildEvolutionDelay, pokemonEvolutions, pokemonPrevolutions } from "./pokemon-evolutions"; -import { Type } from "./type"; -import { LevelMoves, pokemonFormLevelMoves, pokemonFormLevelMoves as pokemonSpeciesFormLevelMoves, pokemonSpeciesLevelMoves } from "./pokemon-level-moves"; +import BattleScene, { AnySound } from "#app/battle-scene"; +import { GameMode } from "#app/game-mode"; +import { StarterMoveset } from "#app/system/game-data"; +import * as Utils from "#app/utils"; +import { uncatchableSpecies } from "#app/data/balance/biomes"; +import { speciesEggMoves } from "#app/data/balance/egg-moves"; +import { GrowthRate } from "#app/data/exp"; +import { EvolutionLevel, SpeciesWildEvolutionDelay, pokemonEvolutions, pokemonPrevolutions } from "#app/data/balance/pokemon-evolutions"; +import { Type } from "#enums/type"; +import { LevelMoves, pokemonFormLevelMoves, pokemonFormLevelMoves as pokemonSpeciesFormLevelMoves, pokemonSpeciesLevelMoves } from "#app/data/balance/pokemon-level-moves"; import { Stat } from "#enums/stat"; -import { Variant, VariantSet, variantColorCache, variantData } from "./variant"; +import { Variant, VariantSet, variantColorCache, variantData } from "#app/data/variant"; +import { speciesStarterCosts, POKERUS_STARTER_COUNT } from "#app/data/balance/starters"; +import { SpeciesFormKey } from "#enums/species-form-key"; export enum Region { NORMAL, @@ -45,7 +47,7 @@ export function getPokemonSpecies(species: Species | Species[] | undefined): Pok return allSpecies[species - 1]; } -export function getPokemonSpeciesForm(species: Species, formIndex: integer): PokemonSpeciesForm { +export function getPokemonSpeciesForm(species: Species, formIndex: number): PokemonSpeciesForm { const retSpecies: PokemonSpecies = species >= 2000 ? allSpecies.find(s => s.speciesId === species)! // TODO: is the bang correct? : allSpecies[species - 1]; @@ -127,26 +129,27 @@ export type PokemonSpeciesFilter = (species: PokemonSpecies) => boolean; export abstract class PokemonSpeciesForm { public speciesId: Species; - public formIndex: integer; - public generation: integer; - public type1: Type; - public type2: Type | null; - public height: number; - public weight: number; - public ability1: Abilities; - public ability2: Abilities; - public abilityHidden: Abilities; - public baseTotal: integer; - public baseStats: integer[]; - public catchRate: integer; - public baseFriendship: integer; - public baseExp: integer; - public genderDiffs: boolean; - public isStarterSelectable: boolean; + protected _formIndex: number; + protected _generation: number; + readonly type1: Type; + readonly type2: Type | null; + readonly height: number; + readonly weight: number; + readonly ability1: Abilities; + readonly ability2: Abilities; + readonly abilityHidden: Abilities; + readonly baseTotal: number; + readonly baseStats: number[]; + readonly catchRate: number; + readonly baseFriendship: number; + readonly baseExp: number; + readonly genderDiffs: boolean; + readonly isStarterSelectable: boolean; constructor(type1: Type, type2: Type | null, height: number, weight: number, ability1: Abilities, ability2: Abilities, abilityHidden: Abilities, - baseTotal: integer, baseHp: integer, baseAtk: integer, baseDef: integer, baseSpatk: integer, baseSpdef: integer, baseSpd: integer, - catchRate: integer, baseFriendship: integer, baseExp: integer, genderDiffs: boolean, isStarterSelectable: boolean) { + baseTotal: number, baseHp: number, baseAtk: number, baseDef: number, baseSpatk: number, baseSpdef: number, baseSpd: number, + catchRate: number, baseFriendship: number, baseExp: number, genderDiffs: boolean, isStarterSelectable: boolean + ) { this.type1 = type1; this.type2 = type2; this.height = height; @@ -172,13 +175,29 @@ export abstract class PokemonSpeciesForm { */ getRootSpeciesId(forStarter: boolean = false): Species { let ret = this.speciesId; - while (pokemonPrevolutions.hasOwnProperty(ret) && (!forStarter || !speciesStarters.hasOwnProperty(ret))) { + while (pokemonPrevolutions.hasOwnProperty(ret) && (!forStarter || !speciesStarterCosts.hasOwnProperty(ret))) { ret = pokemonPrevolutions[ret]; } return ret; } - isOfType(type: integer): boolean { + get generation(): number { + return this._generation; + } + + set generation(generation: number) { + this._generation = generation; + } + + get formIndex(): number { + return this._formIndex; + } + + set formIndex(formIndex: number) { + this._formIndex = formIndex; + } + + isOfType(type: number): boolean { return this.type1 === type || (this.type2 !== null && this.type2 === type); } @@ -186,7 +205,7 @@ export abstract class PokemonSpeciesForm { * Method to get the total number of abilities a Pokemon species has. * @returns Number of abilities */ - getAbilityCount(): integer { + getAbilityCount(): number { return this.abilityHidden !== Abilities.NONE ? 3 : 2; } @@ -195,7 +214,7 @@ export abstract class PokemonSpeciesForm { * @param abilityIndex Which ability to get (should only be 0-2) * @returns The id of the Ability */ - getAbility(abilityIndex: integer): Abilities { + getAbility(abilityIndex: number): Abilities { let ret: Abilities; if (abilityIndex === 0) { ret = this.ability1; @@ -236,8 +255,8 @@ export abstract class PokemonSpeciesForm { isRareRegional(): boolean { switch (this.getRegion()) { - case Region.HISUI: - return true; + case Region.HISUI: + return true; } return false; @@ -263,24 +282,24 @@ export abstract class PokemonSpeciesForm { getBaseExp(): number { let ret = this.baseExp; switch (this.getFormSpriteKey()) { - case SpeciesFormKey.MEGA: - case SpeciesFormKey.MEGA_X: - case SpeciesFormKey.MEGA_Y: - case SpeciesFormKey.PRIMAL: - case SpeciesFormKey.GIGANTAMAX: - case SpeciesFormKey.ETERNAMAX: - ret *= 1.5; - break; + case SpeciesFormKey.MEGA: + case SpeciesFormKey.MEGA_X: + case SpeciesFormKey.MEGA_Y: + case SpeciesFormKey.PRIMAL: + case SpeciesFormKey.GIGANTAMAX: + case SpeciesFormKey.ETERNAMAX: + ret *= 1.5; + break; } return ret; } - getSpriteAtlasPath(female: boolean, formIndex?: integer, shiny?: boolean, variant?: integer): string { + getSpriteAtlasPath(female: boolean, formIndex?: number, shiny?: boolean, variant?: number): string { const spriteId = this.getSpriteId(female, formIndex, shiny, variant).replace(/\_{2}/g, "/"); return `${/_[1-3]$/.test(spriteId) ? "variant/" : ""}${spriteId}`; } - getSpriteId(female: boolean, formIndex?: integer, shiny?: boolean, variant: integer = 0, back?: boolean): string { + getSpriteId(female: boolean, formIndex?: number, shiny?: boolean, variant: number = 0, back?: boolean): string { if (formIndex === undefined || this instanceof PokemonForm) { formIndex = this.formIndex; } @@ -297,11 +316,11 @@ export abstract class PokemonSpeciesForm { return `${back ? "back__" : ""}${shiny && (!variantSet || (!variant && !variantSet[variant || 0])) ? "shiny__" : ""}${baseSpriteKey}${shiny && variantSet && variantSet[variant] === 2 ? `_${variant + 1}` : ""}`; } - getSpriteKey(female: boolean, formIndex?: integer, shiny?: boolean, variant?: integer): string { + getSpriteKey(female: boolean, formIndex?: number, shiny?: boolean, variant?: number): string { return `pkmn__${this.getSpriteId(female, formIndex, shiny, variant)}`; } - abstract getFormSpriteKey(formIndex?: integer): string; + abstract getFormSpriteKey(formIndex?: number): string; /** @@ -309,9 +328,9 @@ export abstract class PokemonSpeciesForm { * @param formIndex optional form index for pokemon with different forms * @returns species id if no additional forms, index with formkey if a pokemon with a form */ - getVariantDataIndex(formIndex?: integer) { + getVariantDataIndex(formIndex?: number) { let formkey: string | null = null; - let variantDataIndex: integer | string = this.speciesId; + let variantDataIndex: number | string = this.speciesId; const species = getPokemonSpecies(this.speciesId); if (species.forms.length > 0 && formIndex !== undefined) { formkey = species.forms[formIndex]?.getFormSpriteKey(formIndex); @@ -322,13 +341,13 @@ export abstract class PokemonSpeciesForm { return variantDataIndex; } - getIconAtlasKey(formIndex?: integer, shiny?: boolean, variant?: integer): string { + getIconAtlasKey(formIndex?: number, shiny?: boolean, variant?: number): string { const variantDataIndex = this.getVariantDataIndex(formIndex); const isVariant = shiny && variantData[variantDataIndex] && (variant !== undefined && variantData[variantDataIndex][variant]); return `pokemon_icons_${this.generation}${isVariant ? "v" : ""}`; } - getIconId(female: boolean, formIndex?: integer, shiny?: boolean, variant?: integer): string { + getIconId(female: boolean, formIndex?: number, shiny?: boolean, variant?: number): string { if (formIndex === undefined) { formIndex = this.formIndex; } @@ -344,29 +363,35 @@ export abstract class PokemonSpeciesForm { } switch (this.speciesId) { - case Species.HIPPOPOTAS: - case Species.HIPPOWDON: - case Species.UNFEZANT: - case Species.FRILLISH: - case Species.JELLICENT: - case Species.PYROAR: - ret += female ? "-f" : ""; - break; + case Species.DODUO: + case Species.DODRIO: + case Species.MEGANIUM: + case Species.TORCHIC: + case Species.COMBUSKEN: + case Species.BLAZIKEN: + case Species.HIPPOPOTAS: + case Species.HIPPOWDON: + case Species.UNFEZANT: + case Species.FRILLISH: + case Species.JELLICENT: + case Species.PYROAR: + ret += female ? "-f" : ""; + break; } let formSpriteKey = this.getFormSpriteKey(formIndex); if (formSpriteKey) { switch (this.speciesId) { - case Species.DUDUNSPARCE: - break; - case Species.ZACIAN: - case Species.ZAMAZENTA: - if (formSpriteKey.startsWith("behemoth")) { - formSpriteKey = "crowned"; - } - default: - ret += `-${formSpriteKey}`; - break; + case Species.DUDUNSPARCE: + break; + case Species.ZACIAN: + case Species.ZAMAZENTA: + if (formSpriteKey.startsWith("behemoth")) { + formSpriteKey = "crowned"; + } + default: + ret += `-${formSpriteKey}`; + break; } } @@ -377,19 +402,19 @@ export abstract class PokemonSpeciesForm { return ret; } - getCryKey(formIndex?: integer): string { + getCryKey(formIndex?: number): string { let speciesId = this.speciesId; if (this.speciesId > 2000) { switch (this.speciesId) { - case Species.GALAR_SLOWPOKE: - break; - case Species.ETERNAL_FLOETTE: - break; - case Species.BLOODMOON_URSALUNA: - break; - default: - speciesId = speciesId % 2000; - break; + case Species.GALAR_SLOWPOKE: + break; + case Species.ETERNAL_FLOETTE: + break; + case Species.BLOODMOON_URSALUNA: + break; + default: + speciesId = speciesId % 2000; + break; } } let ret = speciesId.toString(); @@ -401,49 +426,50 @@ export abstract class PokemonSpeciesForm { } const formKey = forms[formIndex || 0].formKey; switch (formKey) { - case SpeciesFormKey.MEGA: - case SpeciesFormKey.MEGA_X: - case SpeciesFormKey.MEGA_Y: - case SpeciesFormKey.GIGANTAMAX: - case SpeciesFormKey.GIGANTAMAX_SINGLE: - case SpeciesFormKey.GIGANTAMAX_RAPID: - case "white": - case "black": - case "therian": - case "sky": - case "gorging": - case "gulping": - case "no-ice": - case "hangry": - case "crowned": - case "eternamax": - case "four": - case "droopy": - case "stretchy": - case "hero": - case "roaming": - case "complete": - case "10": - case "10-pc": - case "super": - case "unbound": - case "pau": - case "pompom": - case "sensu": - case "dusk": - case "midnight": - case "school": - case "dawn-wings": - case "dusk-mane": - case "ultra": - ret += `-${formKey}`; - break; + case SpeciesFormKey.MEGA: + case SpeciesFormKey.MEGA_X: + case SpeciesFormKey.MEGA_Y: + case SpeciesFormKey.GIGANTAMAX: + case SpeciesFormKey.GIGANTAMAX_SINGLE: + case SpeciesFormKey.GIGANTAMAX_RAPID: + case "white": + case "black": + case "therian": + case "sky": + case "gorging": + case "gulping": + case "no-ice": + case "hangry": + case "crowned": + case "eternamax": + case "four": + case "droopy": + case "stretchy": + case "hero": + case "roaming": + case "complete": + case "10-complete": + case "10": + case "10-pc": + case "super": + case "unbound": + case "pau": + case "pompom": + case "sensu": + case "dusk": + case "midnight": + case "school": + case "dawn-wings": + case "dusk-mane": + case "ultra": + ret += `-${formKey}`; + break; } } - return ret; + return `cry/${ret}`; } - validateStarterMoveset(moveset: StarterMoveset, eggMoves: integer): boolean { + validateStarterMoveset(moveset: StarterMoveset, eggMoves: number): boolean { const rootSpeciesId = this.getRootSpeciesId(); for (const moveId of moveset) { if (speciesEggMoves.hasOwnProperty(rootSpeciesId)) { @@ -464,11 +490,11 @@ export abstract class PokemonSpeciesForm { return true; } - loadAssets(scene: BattleScene, female: boolean, formIndex?: integer, shiny?: boolean, variant?: Variant, startLoad?: boolean): Promise { + loadAssets(scene: BattleScene, female: boolean, formIndex?: number, shiny?: boolean, variant?: Variant, startLoad?: boolean): Promise { return new Promise(resolve => { const spriteKey = this.getSpriteKey(female, formIndex, shiny, variant); scene.loadPokemonAtlas(spriteKey, this.getSpriteAtlasPath(female, formIndex, shiny, variant)); - scene.load.audio(`cry/${this.getCryKey(formIndex)}`, `audio/cry/${this.getCryKey(formIndex)}.m4a`); + scene.load.audio(`${this.getCryKey(formIndex)}`, `audio/${this.getCryKey(formIndex)}.m4a`); scene.load.once(Phaser.Loader.Events.COMPLETE, () => { const originalWarn = console.warn; // Ignore warnings for missing frames, because there will be a lot @@ -479,9 +505,11 @@ export abstract class PokemonSpeciesForm { scene.anims.create({ key: this.getSpriteKey(female, formIndex, shiny, variant), frames: frameNames, - frameRate: 12, + frameRate: 10, repeat: -1 }); + } else { + scene.anims.get(spriteKey).frameRate = 10; } let spritePath = this.getSpriteAtlasPath(female, formIndex, shiny, variant).replace("variant/", "").replace(/_[1-3]$/, ""); const useExpSprite = scene.experimentalSprites && scene.hasExpSprite(spriteKey); @@ -524,14 +552,14 @@ export abstract class PokemonSpeciesForm { if (cry?.pendingRemove) { cry = null; } - cry = scene.playSound(`cry/${(cry ?? cryKey)}`, soundConfig); + cry = scene.playSound(cry ?? cryKey, soundConfig); if (ignorePlay) { cry.stop(); } return cry; } - generateCandyColors(scene: BattleScene): integer[][] { + generateCandyColors(scene: BattleScene): number[][] { const sourceTexture = scene.textures.get(this.getSpriteKey(false)); const sourceFrame = sourceTexture.frames[sourceTexture.firstFrame]; @@ -539,7 +567,7 @@ export abstract class PokemonSpeciesForm { const canvas = document.createElement("canvas"); - const spriteColors: integer[][] = []; + const spriteColors: number[][] = []; const context = canvas.getContext("2d"); const frame = sourceFrame; @@ -562,7 +590,7 @@ export abstract class PokemonSpeciesForm { } for (let i = 0; i < pixelData.length; i += 4) { - const total = pixelData.slice(i, i + 3).reduce((total: integer, value: integer) => total + value, 0); + const total = pixelData.slice(i, i + 3).reduce((total: number, value: number) => total + value, 0); if (!total) { continue; } @@ -581,27 +609,28 @@ export abstract class PokemonSpeciesForm { Math.random = originalRandom; - return Array.from(paletteColors.keys()).map(c => Object.values(rgbaFromArgb(c)) as integer[]); + return Array.from(paletteColors.keys()).map(c => Object.values(rgbaFromArgb(c)) as number[]); } } export default class PokemonSpecies extends PokemonSpeciesForm implements Localizable { public name: string; - public subLegendary: boolean; - public legendary: boolean; - public mythical: boolean; - public species: string; - public growthRate: GrowthRate; - public malePercent: number | null; - public genderDiffs: boolean; - public canChangeForm: boolean; - public forms: PokemonForm[]; + readonly subLegendary: boolean; + readonly legendary: boolean; + readonly mythical: boolean; + readonly species: string; + readonly growthRate: GrowthRate; + readonly malePercent: number | null; + readonly genderDiffs: boolean; + readonly canChangeForm: boolean; + readonly forms: PokemonForm[]; - constructor(id: Species, generation: integer, subLegendary: boolean, legendary: boolean, mythical: boolean, species: string, + constructor(id: Species, generation: number, subLegendary: boolean, legendary: boolean, mythical: boolean, species: string, type1: Type, type2: Type | null, height: number, weight: number, ability1: Abilities, ability2: Abilities, abilityHidden: Abilities, - baseTotal: integer, baseHp: integer, baseAtk: integer, baseDef: integer, baseSpatk: integer, baseSpdef: integer, baseSpd: integer, - catchRate: integer, baseFriendship: integer, baseExp: integer, growthRate: GrowthRate, malePercent: number | null, - genderDiffs: boolean, canChangeForm?: boolean, ...forms: PokemonForm[]) { + baseTotal: number, baseHp: number, baseAtk: number, baseDef: number, baseSpatk: number, baseSpdef: number, baseSpd: number, + catchRate: number, baseFriendship: number, baseExp: number, growthRate: GrowthRate, malePercent: number | null, + genderDiffs: boolean, canChangeForm?: boolean, ...forms: PokemonForm[] + ) { super(type1, type2, height, weight, ability1, ability2, abilityHidden, baseTotal, baseHp, baseAtk, baseDef, baseSpatk, baseSpdef, baseSpd, catchRate, baseFriendship, baseExp, genderDiffs, false); this.speciesId = id; @@ -626,28 +655,28 @@ export default class PokemonSpecies extends PokemonSpeciesForm implements Locali }); } - getName(formIndex?: integer): string { + getName(formIndex?: number): string { if (formIndex !== undefined && this.forms.length) { const form = this.forms[formIndex]; let key: string | null; switch (form.formKey) { - case SpeciesFormKey.MEGA: - case SpeciesFormKey.PRIMAL: - case SpeciesFormKey.ETERNAMAX: - case SpeciesFormKey.MEGA_X: - case SpeciesFormKey.MEGA_Y: - key = form.formKey; - break; - default: - if (form.formKey.indexOf(SpeciesFormKey.GIGANTAMAX) > -1) { - key = "gigantamax"; - } else { - key = null; - } + case SpeciesFormKey.MEGA: + case SpeciesFormKey.PRIMAL: + case SpeciesFormKey.ETERNAMAX: + case SpeciesFormKey.MEGA_X: + case SpeciesFormKey.MEGA_Y: + key = form.formKey; + break; + default: + if (form.formKey.indexOf(SpeciesFormKey.GIGANTAMAX) > -1) { + key = "gigantamax"; + } else { + key = null; + } } if (key) { - return i18next.t(`battlePokemonForm:${key}`, {pokemonName: this.name}); + return i18next.t(`battlePokemonForm:${key}`, { pokemonName: this.name }); } } return this.name; @@ -657,11 +686,11 @@ export default class PokemonSpecies extends PokemonSpeciesForm implements Locali this.name = i18next.t(`pokemon:${Species[this.speciesId].toLowerCase()}`); } - getWildSpeciesForLevel(level: integer, allowEvolving: boolean, isBoss: boolean, gameMode: GameMode): Species { + getWildSpeciesForLevel(level: number, allowEvolving: boolean, isBoss: boolean, gameMode: GameMode): Species { return this.getSpeciesForLevel(level, allowEvolving, false, (isBoss ? PartyMemberStrength.WEAKER : PartyMemberStrength.AVERAGE) + (gameMode?.isEndless ? 1 : 0)); } - getTrainerSpeciesForLevel(level: integer, allowEvolving: boolean = false, strength: PartyMemberStrength, currentWave: number = 0): Species { + getTrainerSpeciesForLevel(level: number, allowEvolving: boolean = false, strength: PartyMemberStrength, currentWave: number = 0): Species { return this.getSpeciesForLevel(level, allowEvolving, true, strength, currentWave); } @@ -683,24 +712,24 @@ export default class PokemonSpecies extends PokemonSpeciesForm implements Locali * @param strength {@linkcode PartyMemberStrength} The strength of the party member in question * @returns {@linkcode integer} The level difference from expected evolution level tolerated for a mon to be unevolved. Lower value = higher evolution chance. */ - private getStrengthLevelDiff(strength: PartyMemberStrength): integer { + private getStrengthLevelDiff(strength: PartyMemberStrength): number { switch (Math.min(strength, PartyMemberStrength.STRONGER)) { - case PartyMemberStrength.WEAKEST: - return 60; - case PartyMemberStrength.WEAKER: - return 40; - case PartyMemberStrength.WEAK: - return 20; - case PartyMemberStrength.AVERAGE: - return 8; - case PartyMemberStrength.STRONG: - return 4; - default: - return 0; + case PartyMemberStrength.WEAKEST: + return 60; + case PartyMemberStrength.WEAKER: + return 40; + case PartyMemberStrength.WEAK: + return 20; + case PartyMemberStrength.AVERAGE: + return 8; + case PartyMemberStrength.STRONG: + return 4; + default: + return 0; } } - getSpeciesForLevel(level: integer, allowEvolving: boolean = false, forTrainer: boolean = false, strength: PartyMemberStrength = PartyMemberStrength.WEAKER, currentWave: number = 0): Species { + getSpeciesForLevel(level: number, allowEvolving: boolean = false, forTrainer: boolean = false, strength: PartyMemberStrength = PartyMemberStrength.WEAKER, currentWave: number = 0): Species { const prevolutionLevels = this.getPrevolutionLevels(); if (prevolutionLevels.length) { @@ -762,6 +791,13 @@ export default class PokemonSpecies extends PokemonSpeciesForm implements Locali } } + //TODO: Adjust templates and delays so we don't have to hardcode it + /* TEMPORARY! (Most) Trainers shouldn't be using unevolved Pokemon by the third gym leader / wave 80. Exceptions to this include Breeders, whose large teams are balanced by the use of weaker pokemon */ + if (currentWave >= 80 && forTrainer && strength > PartyMemberStrength.WEAKER) { + evolutionChance = 1; + noEvolutionChance = 0; + } + if (evolutionChance > 0) { if (isRegionalEvolution) { evolutionChance /= (evolutionSpecies.isRareRegional() ? 16 : 4); @@ -835,7 +871,7 @@ export default class PokemonSpecies extends PokemonSpeciesForm implements Locali } // This could definitely be written better and more accurate to the getSpeciesForLevel logic, but it is only for generating movesets for evolved Pokemon - getSimulatedEvolutionChain(currentLevel: integer, forTrainer: boolean = false, isBoss: boolean = false, player: boolean = false): EvolutionLevel[] { + getSimulatedEvolutionChain(currentLevel: number, forTrainer: boolean = false, isBoss: boolean = false, player: boolean = false): EvolutionLevel[] { const ret: EvolutionLevel[] = []; if (pokemonPrevolutions.hasOwnProperty(this.speciesId)) { const prevolutionLevels = this.getPrevolutionLevels().reverse(); @@ -858,17 +894,24 @@ export default class PokemonSpecies extends PokemonSpeciesForm implements Locali getCompatibleFusionSpeciesFilter(): PokemonSpeciesFilter { const hasEvolution = pokemonEvolutions.hasOwnProperty(this.speciesId); const hasPrevolution = pokemonPrevolutions.hasOwnProperty(this.speciesId); - const pseudoLegendary = this.subLegendary; + const subLegendary = this.subLegendary; const legendary = this.legendary; const mythical = this.mythical; return species => { - return (pseudoLegendary || legendary || mythical || - (pokemonEvolutions.hasOwnProperty(species.speciesId) === hasEvolution - && pokemonPrevolutions.hasOwnProperty(species.speciesId) === hasPrevolution)) - && species.subLegendary === pseudoLegendary + return ( + subLegendary + || legendary + || mythical + || ( + pokemonEvolutions.hasOwnProperty(species.speciesId) === hasEvolution + && pokemonPrevolutions.hasOwnProperty(species.speciesId) === hasPrevolution + ) + ) + && species.subLegendary === subLegendary && species.legendary === legendary && species.mythical === mythical - && (this.isTrainerForbidden() || !species.isTrainerForbidden()); + && (this.isTrainerForbidden() || !species.isTrainerForbidden()) + && species.speciesId !== Species.DITTO; }; } @@ -887,7 +930,7 @@ export default class PokemonSpecies extends PokemonSpeciesForm implements Locali return variantData.hasOwnProperty(variantDataIndex) || variantData.hasOwnProperty(this.speciesId); } - getFormSpriteKey(formIndex?: integer) { + getFormSpriteKey(formIndex?: number) { if (this.forms.length && (formIndex !== undefined && formIndex >= this.forms.length)) { console.warn(`Attempted accessing form with index ${formIndex} of species ${this.getName()} with only ${this.forms.length || 0} forms`); formIndex = Math.min(formIndex, this.forms.length - 1); @@ -904,35 +947,56 @@ export class PokemonForm extends PokemonSpeciesForm { public formSpriteKey: string | null; // This is a collection of form keys that have in-run form changes, but should still be separately selectable from the start screen - private starterSelectableKeys: string[] = ["10", "50", "10-pc", "50-pc", "red", "orange", "yellow", "green", "blue", "indigo", "violet"]; + private starterSelectableKeys: string[] = [ "10", "50", "10-pc", "50-pc", "red", "orange", "yellow", "green", "blue", "indigo", "violet" ]; constructor(formName: string, formKey: string, type1: Type, type2: Type | null, height: number, weight: number, ability1: Abilities, ability2: Abilities, abilityHidden: Abilities, - baseTotal: integer, baseHp: integer, baseAtk: integer, baseDef: integer, baseSpatk: integer, baseSpdef: integer, baseSpd: integer, - catchRate: integer, baseFriendship: integer, baseExp: integer, genderDiffs?: boolean, formSpriteKey?: string | null, isStarterSelectable?: boolean, ) { + baseTotal: number, baseHp: number, baseAtk: number, baseDef: number, baseSpatk: number, baseSpdef: number, baseSpd: number, + catchRate: number, baseFriendship: number, baseExp: number, genderDiffs: boolean = false, formSpriteKey: string | null = null, isStarterSelectable: boolean = false + ) { super(type1, type2, height, weight, ability1, ability2, abilityHidden, baseTotal, baseHp, baseAtk, baseDef, baseSpatk, baseSpdef, baseSpd, - catchRate, baseFriendship, baseExp, !!genderDiffs, (!!isStarterSelectable || !formKey)); + catchRate, baseFriendship, baseExp, genderDiffs, (isStarterSelectable || !formKey)); this.formName = formName; this.formKey = formKey; - this.formSpriteKey = formSpriteKey !== undefined ? formSpriteKey : null; + this.formSpriteKey = formSpriteKey; } - getFormSpriteKey(_formIndex?: integer) { + getFormSpriteKey(_formIndex?: number) { return this.formSpriteKey !== null ? this.formSpriteKey : this.formKey; } } -export enum SpeciesFormKey { - MEGA = "mega", - MEGA_X = "mega-x", - MEGA_Y = "mega-y", - PRIMAL = "primal", - ORIGIN = "origin", - INCARNATE = "incarnate", - THERIAN = "therian", - GIGANTAMAX = "gigantamax", - GIGANTAMAX_SINGLE = "gigantamax-single", - GIGANTAMAX_RAPID = "gigantamax-rapid", - ETERNAMAX = "eternamax" +export const noStarterFormKeys: string[] = [ + SpeciesFormKey.MEGA, + SpeciesFormKey.MEGA_X, + SpeciesFormKey.MEGA_Y, + SpeciesFormKey.PRIMAL, + SpeciesFormKey.ORIGIN, + SpeciesFormKey.THERIAN, + SpeciesFormKey.GIGANTAMAX, + SpeciesFormKey.GIGANTAMAX_RAPID, + SpeciesFormKey.GIGANTAMAX_SINGLE, + SpeciesFormKey.ETERNAMAX +].map(k => k.toString()); + +/** +* Method to get the daily list of starters with Pokerus. +* @param scene {@linkcode BattleScene} used as part of RNG +* @returns A list of starters with Pokerus +*/ +export function getPokerusStarters(scene: BattleScene): PokemonSpecies[] { + const pokerusStarters: PokemonSpecies[] = []; + const date = new Date(); + date.setUTCHours(0, 0, 0, 0); + scene.executeWithSeedOffset(() => { + while (pokerusStarters.length < POKERUS_STARTER_COUNT) { + const randomSpeciesId = parseInt(Utils.randSeedItem(Object.keys(speciesStarterCosts)), 10); + const species = getPokemonSpecies(randomSpeciesId); + if (!pokerusStarters.includes(species)) { + pokerusStarters.push(species); + } + } + }, 0, date.getTime().toString()); + return pokerusStarters; } export const allSpecies: PokemonSpecies[] = []; @@ -944,7 +1008,7 @@ export function initSpecies() { new PokemonSpecies(Species.VENUSAUR, 1, false, false, false, "Seed Pokémon", Type.GRASS, Type.POISON, 2, 100, Abilities.OVERGROW, Abilities.NONE, Abilities.CHLOROPHYLL, 525, 80, 82, 83, 100, 100, 80, 45, 50, 263, GrowthRate.MEDIUM_SLOW, 87.5, true, true, new PokemonForm("Normal", "", Type.GRASS, Type.POISON, 2, 100, Abilities.OVERGROW, Abilities.NONE, Abilities.CHLOROPHYLL, 525, 80, 82, 83, 100, 100, 80, 45, 50, 263, true, null, true), new PokemonForm("Mega", SpeciesFormKey.MEGA, Type.GRASS, Type.POISON, 2.4, 155.5, Abilities.THICK_FAT, Abilities.THICK_FAT, Abilities.THICK_FAT, 625, 80, 100, 123, 122, 120, 80, 45, 50, 263, true), - new PokemonForm("G-Max", SpeciesFormKey.GIGANTAMAX, Type.GRASS, Type.POISON, 24, 999.9, Abilities.CHLOROPHYLL, Abilities.CHLOROPHYLL, Abilities.CHLOROPHYLL, 625, 120, 82, 98, 130, 115, 80, 45, 50, 263, true), + new PokemonForm("G-Max", SpeciesFormKey.GIGANTAMAX, Type.GRASS, Type.POISON, 24, 999.9, Abilities.EFFECT_SPORE, Abilities.NONE, Abilities.EFFECT_SPORE, 625, 120, 82, 98, 130, 115, 80, 45, 50, 263, true), ), new PokemonSpecies(Species.CHARMANDER, 1, false, false, false, "Lizard Pokémon", Type.FIRE, null, 0.6, 8.5, Abilities.BLAZE, Abilities.NONE, Abilities.SOLAR_POWER, 309, 39, 52, 43, 60, 50, 65, 45, 50, 62, GrowthRate.MEDIUM_SLOW, 87.5, false), new PokemonSpecies(Species.CHARMELEON, 1, false, false, false, "Flame Pokémon", Type.FIRE, null, 1.1, 19, Abilities.BLAZE, Abilities.NONE, Abilities.SOLAR_POWER, 405, 58, 64, 58, 80, 65, 80, 45, 50, 142, GrowthRate.MEDIUM_SLOW, 87.5, false), @@ -952,20 +1016,20 @@ export function initSpecies() { new PokemonForm("Normal", "", Type.FIRE, Type.FLYING, 1.7, 90.5, Abilities.BLAZE, Abilities.NONE, Abilities.SOLAR_POWER, 534, 78, 84, 78, 109, 85, 100, 45, 50, 267, false, null, true), new PokemonForm("Mega X", SpeciesFormKey.MEGA_X, Type.FIRE, Type.DRAGON, 1.7, 110.5, Abilities.TOUGH_CLAWS, Abilities.NONE, Abilities.TOUGH_CLAWS, 634, 78, 130, 111, 130, 85, 100, 45, 50, 267), new PokemonForm("Mega Y", SpeciesFormKey.MEGA_Y, Type.FIRE, Type.FLYING, 1.7, 100.5, Abilities.DROUGHT, Abilities.NONE, Abilities.DROUGHT, 634, 78, 104, 78, 159, 115, 100, 45, 50, 267), - new PokemonForm("G-Max", SpeciesFormKey.GIGANTAMAX, Type.FIRE, Type.FLYING, 28, 999.9, Abilities.BERSERK, Abilities.BERSERK, Abilities.BERSERK, 634, 118, 84, 93, 139, 110, 100, 45, 50, 267), + new PokemonForm("G-Max", SpeciesFormKey.GIGANTAMAX, Type.FIRE, Type.FLYING, 28, 999.9, Abilities.BERSERK, Abilities.NONE, Abilities.BERSERK, 634, 118, 84, 93, 139, 100, 100, 45, 50, 267), ), new PokemonSpecies(Species.SQUIRTLE, 1, false, false, false, "Tiny Turtle Pokémon", Type.WATER, null, 0.5, 9, Abilities.TORRENT, Abilities.NONE, Abilities.RAIN_DISH, 314, 44, 48, 65, 50, 64, 43, 45, 50, 63, GrowthRate.MEDIUM_SLOW, 87.5, false), new PokemonSpecies(Species.WARTORTLE, 1, false, false, false, "Turtle Pokémon", Type.WATER, null, 1, 22.5, Abilities.TORRENT, Abilities.NONE, Abilities.RAIN_DISH, 405, 59, 63, 80, 65, 80, 58, 45, 50, 142, GrowthRate.MEDIUM_SLOW, 87.5, false), new PokemonSpecies(Species.BLASTOISE, 1, false, false, false, "Shellfish Pokémon", Type.WATER, null, 1.6, 85.5, Abilities.TORRENT, Abilities.NONE, Abilities.RAIN_DISH, 530, 79, 83, 100, 85, 105, 78, 45, 50, 265, GrowthRate.MEDIUM_SLOW, 87.5, false, true, new PokemonForm("Normal", "", Type.WATER, null, 1.6, 85.5, Abilities.TORRENT, Abilities.NONE, Abilities.RAIN_DISH, 530, 79, 83, 100, 85, 105, 78, 45, 50, 265, false, null, true), new PokemonForm("Mega", SpeciesFormKey.MEGA, Type.WATER, null, 1.6, 101.1, Abilities.MEGA_LAUNCHER, Abilities.NONE, Abilities.MEGA_LAUNCHER, 630, 79, 103, 120, 135, 115, 78, 45, 50, 265), - new PokemonForm("G-Max", SpeciesFormKey.GIGANTAMAX, Type.WATER, Type.STEEL, 25, 999.9, Abilities.SHELL_ARMOR, Abilities.SHELL_ARMOR, Abilities.SHELL_ARMOR, 630, 119, 83, 130, 115, 115, 68, 45, 50, 265), + new PokemonForm("G-Max", SpeciesFormKey.GIGANTAMAX, Type.WATER, Type.STEEL, 25, 999.9, Abilities.SHELL_ARMOR, Abilities.NONE, Abilities.SHELL_ARMOR, 630, 119, 83, 135, 115, 110, 68, 45, 50, 265), ), new PokemonSpecies(Species.CATERPIE, 1, false, false, false, "Worm Pokémon", Type.BUG, null, 0.3, 2.9, Abilities.SHIELD_DUST, Abilities.NONE, Abilities.RUN_AWAY, 195, 45, 30, 35, 20, 20, 45, 255, 50, 39, GrowthRate.MEDIUM_FAST, 50, false), new PokemonSpecies(Species.METAPOD, 1, false, false, false, "Cocoon Pokémon", Type.BUG, null, 0.7, 9.9, Abilities.SHED_SKIN, Abilities.NONE, Abilities.SHED_SKIN, 205, 50, 20, 55, 25, 25, 30, 120, 50, 72, GrowthRate.MEDIUM_FAST, 50, false), new PokemonSpecies(Species.BUTTERFREE, 1, false, false, false, "Butterfly Pokémon", Type.BUG, Type.FLYING, 1.1, 32, Abilities.COMPOUND_EYES, Abilities.NONE, Abilities.TINTED_LENS, 395, 60, 45, 50, 90, 80, 70, 45, 50, 198, GrowthRate.MEDIUM_FAST, 50, true, true, new PokemonForm("Normal", "", Type.BUG, Type.FLYING, 1.1, 32, Abilities.COMPOUND_EYES, Abilities.NONE, Abilities.TINTED_LENS, 395, 60, 45, 50, 90, 80, 70, 45, 50, 198, true, null, true), - new PokemonForm("G-Max", SpeciesFormKey.GIGANTAMAX, Type.BUG, Type.FLYING, 17, 999.9, Abilities.COMPOUND_EYES, Abilities.COMPOUND_EYES, Abilities.COMPOUND_EYES, 495, 85, 35, 80, 120, 90, 85, 45, 50, 198, true), + new PokemonForm("G-Max", SpeciesFormKey.GIGANTAMAX, Type.BUG, Type.FLYING, 17, 999.9, Abilities.COMPOUND_EYES, Abilities.NONE, Abilities.COMPOUND_EYES, 495, 85, 35, 80, 120, 90, 85, 45, 50, 198, true), ), new PokemonSpecies(Species.WEEDLE, 1, false, false, false, "Hairy Bug Pokémon", Type.BUG, Type.POISON, 0.3, 3.2, Abilities.SHIELD_DUST, Abilities.NONE, Abilities.RUN_AWAY, 195, 40, 35, 30, 20, 20, 50, 255, 70, 39, GrowthRate.MEDIUM_FAST, 50, false), new PokemonSpecies(Species.KAKUNA, 1, false, false, false, "Cocoon Pokémon", Type.BUG, Type.POISON, 0.6, 10, Abilities.SHED_SKIN, Abilities.NONE, Abilities.SHED_SKIN, 205, 45, 25, 50, 25, 25, 35, 120, 70, 72, GrowthRate.MEDIUM_FAST, 50, false), @@ -994,7 +1058,7 @@ export function initSpecies() { new PokemonForm("Cute Cosplay", "cute-cosplay", Type.ELECTRIC, null, 0.4, 6, Abilities.STATIC, Abilities.NONE, Abilities.LIGHTNING_ROD, 430, 45, 80, 50, 75, 60, 120, 190, 50, 112, true, null, true), //Custom new PokemonForm("Smart Cosplay", "smart-cosplay", Type.ELECTRIC, null, 0.4, 6, Abilities.STATIC, Abilities.NONE, Abilities.LIGHTNING_ROD, 430, 45, 80, 50, 75, 60, 120, 190, 50, 112, true, null, true), //Custom new PokemonForm("Tough Cosplay", "tough-cosplay", Type.ELECTRIC, null, 0.4, 6, Abilities.STATIC, Abilities.NONE, Abilities.LIGHTNING_ROD, 430, 45, 80, 50, 75, 60, 120, 190, 50, 112, true, null, true), //Custom - new PokemonForm("G-Max", SpeciesFormKey.GIGANTAMAX, Type.ELECTRIC, null, 21, 999.9, Abilities.LIGHTNING_ROD, Abilities.LIGHTNING_ROD, Abilities.LIGHTNING_ROD, 530, 125, 95, 60, 90, 70, 90, 190, 50, 112), //+100 BST from Partner Form + new PokemonForm("G-Max", SpeciesFormKey.GIGANTAMAX, Type.ELECTRIC, null, 21, 999.9, Abilities.LIGHTNING_ROD, Abilities.NONE, Abilities.LIGHTNING_ROD, 530, 125, 95, 60, 90, 70, 90, 190, 50, 112), //+100 BST from Partner Form ), new PokemonSpecies(Species.RAICHU, 1, false, false, false, "Mouse Pokémon", Type.ELECTRIC, null, 0.8, 30, Abilities.STATIC, Abilities.NONE, Abilities.LIGHTNING_ROD, 485, 60, 90, 55, 90, 80, 110, 75, 50, 243, GrowthRate.MEDIUM_FAST, 50, true), new PokemonSpecies(Species.SANDSHREW, 1, false, false, false, "Mouse Pokémon", Type.GROUND, null, 0.6, 12, Abilities.SAND_VEIL, Abilities.NONE, Abilities.SAND_RUSH, 300, 50, 75, 85, 20, 30, 40, 255, 50, 60, GrowthRate.MEDIUM_FAST, 50, false), @@ -1079,7 +1143,7 @@ export function initSpecies() { new PokemonSpecies(Species.GENGAR, 1, false, false, false, "Shadow Pokémon", Type.GHOST, Type.POISON, 1.5, 40.5, Abilities.CURSED_BODY, Abilities.NONE, Abilities.NONE, 500, 60, 65, 60, 130, 75, 110, 45, 50, 250, GrowthRate.MEDIUM_SLOW, 50, false, true, new PokemonForm("Normal", "", Type.GHOST, Type.POISON, 1.5, 40.5, Abilities.CURSED_BODY, Abilities.NONE, Abilities.NONE, 500, 60, 65, 60, 130, 75, 110, 45, 50, 250, false, null, true), new PokemonForm("Mega", SpeciesFormKey.MEGA, Type.GHOST, Type.POISON, 1.4, 40.5, Abilities.SHADOW_TAG, Abilities.NONE, Abilities.NONE, 600, 60, 65, 80, 170, 95, 130, 45, 50, 250), - new PokemonForm("G-Max", SpeciesFormKey.GIGANTAMAX, Type.GHOST, Type.POISON, 20, 999.9, Abilities.CURSED_BODY, Abilities.CURSED_BODY, Abilities.CURSED_BODY, 600, 140, 65, 70, 140, 85, 100, 45, 50, 250), + new PokemonForm("G-Max", SpeciesFormKey.GIGANTAMAX, Type.GHOST, Type.POISON, 20, 999.9, Abilities.CURSED_BODY, Abilities.NONE, Abilities.NONE, 600, 140, 65, 70, 140, 85, 100, 45, 50, 250), ), new PokemonSpecies(Species.ONIX, 1, false, false, false, "Rock Snake Pokémon", Type.ROCK, Type.GROUND, 8.8, 210, Abilities.ROCK_HEAD, Abilities.STURDY, Abilities.WEAK_ARMOR, 385, 35, 45, 160, 30, 45, 70, 45, 50, 77, GrowthRate.MEDIUM_FAST, 50, false), new PokemonSpecies(Species.DROWZEE, 1, false, false, false, "Hypnosis Pokémon", Type.PSYCHIC, null, 1, 32.4, Abilities.INSOMNIA, Abilities.FOREWARN, Abilities.INNER_FOCUS, 328, 60, 48, 45, 43, 90, 42, 190, 70, 66, GrowthRate.MEDIUM_FAST, 50, false), @@ -1087,7 +1151,7 @@ export function initSpecies() { new PokemonSpecies(Species.KRABBY, 1, false, false, false, "River Crab Pokémon", Type.WATER, null, 0.4, 6.5, Abilities.HYPER_CUTTER, Abilities.SHELL_ARMOR, Abilities.SHEER_FORCE, 325, 30, 105, 90, 25, 25, 50, 225, 50, 65, GrowthRate.MEDIUM_FAST, 50, false), new PokemonSpecies(Species.KINGLER, 1, false, false, false, "Pincer Pokémon", Type.WATER, null, 1.3, 60, Abilities.HYPER_CUTTER, Abilities.SHELL_ARMOR, Abilities.SHEER_FORCE, 475, 55, 130, 115, 50, 50, 75, 60, 50, 166, GrowthRate.MEDIUM_FAST, 50, false, true, new PokemonForm("Normal", "", Type.WATER, null, 1.3, 60, Abilities.HYPER_CUTTER, Abilities.SHELL_ARMOR, Abilities.SHEER_FORCE, 475, 55, 130, 115, 50, 50, 75, 60, 50, 166, false, null, true), - new PokemonForm("G-Max", SpeciesFormKey.GIGANTAMAX, Type.WATER, null, 19, 999.9, Abilities.TOUGH_CLAWS, Abilities.TOUGH_CLAWS, Abilities.TOUGH_CLAWS, 575, 90, 155, 140, 50, 80, 70, 60, 50, 166), + new PokemonForm("G-Max", SpeciesFormKey.GIGANTAMAX, Type.WATER, null, 19, 999.9, Abilities.TOUGH_CLAWS, Abilities.TOUGH_CLAWS, Abilities.TOUGH_CLAWS, 575, 90, 155, 140, 50, 70, 70, 60, 50, 166), ), new PokemonSpecies(Species.VOLTORB, 1, false, false, false, "Ball Pokémon", Type.ELECTRIC, null, 0.5, 10.4, Abilities.SOUNDPROOF, Abilities.STATIC, Abilities.AFTERMATH, 330, 40, 30, 50, 55, 55, 100, 190, 70, 66, GrowthRate.MEDIUM_FAST, null, false), new PokemonSpecies(Species.ELECTRODE, 1, false, false, false, "Ball Pokémon", Type.ELECTRIC, null, 1.2, 66.6, Abilities.SOUNDPROOF, Abilities.STATIC, Abilities.AFTERMATH, 490, 60, 50, 70, 80, 80, 150, 60, 70, 172, GrowthRate.MEDIUM_FAST, null, false), @@ -1131,7 +1195,7 @@ export function initSpecies() { ), new PokemonSpecies(Species.LAPRAS, 1, false, false, false, "Transport Pokémon", Type.WATER, Type.ICE, 2.5, 220, Abilities.WATER_ABSORB, Abilities.SHELL_ARMOR, Abilities.HYDRATION, 535, 130, 85, 80, 85, 95, 60, 45, 50, 187, GrowthRate.SLOW, 50, false, true, new PokemonForm("Normal", "", Type.WATER, Type.ICE, 2.5, 220, Abilities.WATER_ABSORB, Abilities.SHELL_ARMOR, Abilities.HYDRATION, 535, 130, 85, 80, 85, 95, 60, 45, 50, 187, false, null, true), - new PokemonForm("G-Max", SpeciesFormKey.GIGANTAMAX, Type.WATER, Type.ICE, 24, 999.9, Abilities.SHELL_ARMOR, Abilities.SHELL_ARMOR, Abilities.SHELL_ARMOR, 635, 170, 85, 95, 115, 110, 60, 45, 50, 187), + new PokemonForm("G-Max", SpeciesFormKey.GIGANTAMAX, Type.WATER, Type.ICE, 24, 999.9, Abilities.SHIELD_DUST, Abilities.SHIELD_DUST, Abilities.SHIELD_DUST, 635, 170, 85, 85, 105, 130, 60, 45, 50, 187), ), new PokemonSpecies(Species.DITTO, 1, false, false, false, "Transform Pokémon", Type.NORMAL, null, 0.3, 4, Abilities.LIMBER, Abilities.NONE, Abilities.IMPOSTER, 288, 48, 48, 48, 48, 48, 48, 35, 50, 101, GrowthRate.MEDIUM_FAST, null, false), new PokemonSpecies(Species.EEVEE, 1, false, false, false, "Evolution Pokémon", Type.NORMAL, null, 0.3, 6.5, Abilities.RUN_AWAY, Abilities.ADAPTABILITY, Abilities.ANTICIPATION, 325, 55, 55, 50, 45, 65, 55, 45, 50, 65, GrowthRate.MEDIUM_FAST, 87.5, false, true, @@ -1492,9 +1556,9 @@ export function initSpecies() { new PokemonForm("Normal", "", Type.DRAGON, Type.FLYING, 1.5, 102.6, Abilities.INTIMIDATE, Abilities.NONE, Abilities.MOXIE, 600, 95, 135, 80, 110, 80, 100, 45, 35, 300, false, null, true), new PokemonForm("Mega", SpeciesFormKey.MEGA, Type.DRAGON, Type.FLYING, 1.8, 112.6, Abilities.AERILATE, Abilities.NONE, Abilities.AERILATE, 700, 95, 145, 130, 120, 90, 120, 45, 35, 300), ), - new PokemonSpecies(Species.BELDUM, 3, false, false, false, "Iron Ball Pokémon", Type.STEEL, Type.PSYCHIC, 0.6, 95.2, Abilities.CLEAR_BODY, Abilities.NONE, Abilities.LIGHT_METAL, 300, 40, 55, 80, 35, 60, 30, 3, 35, 60, GrowthRate.SLOW, null, false), - new PokemonSpecies(Species.METANG, 3, false, false, false, "Iron Claw Pokémon", Type.STEEL, Type.PSYCHIC, 1.2, 202.5, Abilities.CLEAR_BODY, Abilities.NONE, Abilities.LIGHT_METAL, 420, 60, 75, 100, 55, 80, 50, 3, 35, 147, GrowthRate.SLOW, null, false), - new PokemonSpecies(Species.METAGROSS, 3, false, false, false, "Iron Leg Pokémon", Type.STEEL, Type.PSYCHIC, 1.6, 550, Abilities.CLEAR_BODY, Abilities.NONE, Abilities.LIGHT_METAL, 600, 80, 135, 130, 95, 90, 70, 3, 35, 300, GrowthRate.SLOW, null, false, true, + new PokemonSpecies(Species.BELDUM, 3, false, false, false, "Iron Ball Pokémon", Type.STEEL, Type.PSYCHIC, 0.6, 95.2, Abilities.CLEAR_BODY, Abilities.NONE, Abilities.LIGHT_METAL, 300, 40, 55, 80, 35, 60, 30, 45, 35, 60, GrowthRate.SLOW, null, false), //Custom Catchrate, matching Frigibax + new PokemonSpecies(Species.METANG, 3, false, false, false, "Iron Claw Pokémon", Type.STEEL, Type.PSYCHIC, 1.2, 202.5, Abilities.CLEAR_BODY, Abilities.NONE, Abilities.LIGHT_METAL, 420, 60, 75, 100, 55, 80, 50, 25, 35, 147, GrowthRate.SLOW, null, false), //Custom Catchrate, matching Arctibax + new PokemonSpecies(Species.METAGROSS, 3, false, false, false, "Iron Leg Pokémon", Type.STEEL, Type.PSYCHIC, 1.6, 550, Abilities.CLEAR_BODY, Abilities.NONE, Abilities.LIGHT_METAL, 600, 80, 135, 130, 95, 90, 70, 10, 35, 300, GrowthRate.SLOW, null, false, true, //Custom Catchrate, matching Baxcalibur new PokemonForm("Normal", "", Type.STEEL, Type.PSYCHIC, 1.6, 550, Abilities.CLEAR_BODY, Abilities.NONE, Abilities.LIGHT_METAL, 600, 80, 135, 130, 95, 90, 70, 3, 35, 300, false, null, true), new PokemonForm("Mega", SpeciesFormKey.MEGA, Type.STEEL, Type.PSYCHIC, 2.5, 942.9, Abilities.TOUGH_CLAWS, Abilities.NONE, Abilities.TOUGH_CLAWS, 700, 80, 145, 150, 105, 110, 110, 3, 35, 300), ), @@ -1745,7 +1809,7 @@ export function initSpecies() { new PokemonSpecies(Species.EXCADRILL, 5, false, false, false, "Subterrene Pokémon", Type.GROUND, Type.STEEL, 0.7, 40.4, Abilities.SAND_RUSH, Abilities.SAND_FORCE, Abilities.MOLD_BREAKER, 508, 110, 135, 60, 50, 65, 88, 60, 50, 178, GrowthRate.MEDIUM_FAST, 50, false), new PokemonSpecies(Species.AUDINO, 5, false, false, false, "Hearing Pokémon", Type.NORMAL, null, 1.1, 31, Abilities.HEALER, Abilities.REGENERATOR, Abilities.KLUTZ, 445, 103, 60, 86, 60, 86, 50, 255, 50, 390, GrowthRate.FAST, 50, false, true, new PokemonForm("Normal", "", Type.NORMAL, null, 1.1, 31, Abilities.HEALER, Abilities.REGENERATOR, Abilities.KLUTZ, 445, 103, 60, 86, 60, 86, 50, 255, 50, 390, false, null, true), - new PokemonForm("Mega", SpeciesFormKey.MEGA, Type.NORMAL, Type.FAIRY, 1.5, 32, Abilities.HEALER, Abilities.HEALER, Abilities.HEALER, 545, 103, 60, 126, 80, 126, 50, 255, 50, 390), + new PokemonForm("Mega", SpeciesFormKey.MEGA, Type.NORMAL, Type.FAIRY, 1.5, 32, Abilities.REGENERATOR, Abilities.REGENERATOR, Abilities.REGENERATOR, 545, 103, 60, 126, 80, 126, 50, 255, 50, 390), //Custom Ability, base form Hidden Ability ), new PokemonSpecies(Species.TIMBURR, 5, false, false, false, "Muscular Pokémon", Type.FIGHTING, null, 0.6, 12.5, Abilities.GUTS, Abilities.SHEER_FORCE, Abilities.IRON_FIST, 305, 75, 80, 55, 25, 35, 35, 180, 70, 61, GrowthRate.MEDIUM_SLOW, 75, false), new PokemonSpecies(Species.GURDURR, 5, false, false, false, "Muscular Pokémon", Type.FIGHTING, null, 1.2, 40, Abilities.GUTS, Abilities.SHEER_FORCE, Abilities.IRON_FIST, 405, 85, 105, 85, 40, 50, 40, 90, 50, 142, GrowthRate.MEDIUM_SLOW, 75, false), @@ -1832,7 +1896,7 @@ export function initSpecies() { new PokemonSpecies(Species.ALOMOMOLA, 5, false, false, false, "Caring Pokémon", Type.WATER, null, 1.2, 31.6, Abilities.HEALER, Abilities.HYDRATION, Abilities.REGENERATOR, 470, 165, 75, 80, 40, 45, 65, 75, 70, 165, GrowthRate.FAST, 50, false), new PokemonSpecies(Species.JOLTIK, 5, false, false, false, "Attaching Pokémon", Type.BUG, Type.ELECTRIC, 0.1, 0.6, Abilities.COMPOUND_EYES, Abilities.UNNERVE, Abilities.SWARM, 319, 50, 47, 50, 57, 50, 65, 190, 50, 64, GrowthRate.MEDIUM_FAST, 50, false), new PokemonSpecies(Species.GALVANTULA, 5, false, false, false, "EleSpider Pokémon", Type.BUG, Type.ELECTRIC, 0.8, 14.3, Abilities.COMPOUND_EYES, Abilities.UNNERVE, Abilities.SWARM, 472, 70, 77, 60, 97, 60, 108, 75, 50, 165, GrowthRate.MEDIUM_FAST, 50, false), - new PokemonSpecies(Species.FERROSEED, 5, false, false, false, "Thorn Seed Pokémon", Type.GRASS, Type.STEEL, 0.6, 18.8, Abilities.IRON_BARBS, Abilities.NONE, Abilities.IRON_BARBS, 305, 44, 50, 91, 24, 86, 10, 255, 50, 61, GrowthRate.MEDIUM_FAST, 50, false), + new PokemonSpecies(Species.FERROSEED, 5, false, false, false, "Thorn Seed Pokémon", Type.GRASS, Type.STEEL, 0.6, 18.8, Abilities.IRON_BARBS, Abilities.NONE, Abilities.ANTICIPATION, 305, 44, 50, 91, 24, 86, 10, 255, 50, 61, GrowthRate.MEDIUM_FAST, 50, false), new PokemonSpecies(Species.FERROTHORN, 5, false, false, false, "Thorn Pod Pokémon", Type.GRASS, Type.STEEL, 1, 110, Abilities.IRON_BARBS, Abilities.NONE, Abilities.ANTICIPATION, 489, 74, 94, 131, 54, 116, 20, 90, 50, 171, GrowthRate.MEDIUM_FAST, 50, false), new PokemonSpecies(Species.KLINK, 5, false, false, false, "Gear Pokémon", Type.STEEL, null, 0.3, 21, Abilities.PLUS, Abilities.MINUS, Abilities.CLEAR_BODY, 300, 40, 55, 70, 45, 60, 30, 130, 50, 60, GrowthRate.MEDIUM_SLOW, null, false), new PokemonSpecies(Species.KLANG, 5, false, false, false, "Gear Pokémon", Type.STEEL, null, 0.6, 51, Abilities.PLUS, Abilities.MINUS, Abilities.CLEAR_BODY, 440, 60, 80, 95, 70, 85, 50, 60, 50, 154, GrowthRate.MEDIUM_SLOW, null, false), @@ -2104,7 +2168,8 @@ export function initSpecies() { new PokemonForm("10% Forme", "10", Type.DRAGON, Type.GROUND, 1.2, 33.5, Abilities.AURA_BREAK, Abilities.NONE, Abilities.NONE, 486, 54, 100, 71, 61, 85, 115, 3, 0, 300, false, null, true), new PokemonForm("50% Forme Power Construct", "50-pc", Type.DRAGON, Type.GROUND, 5, 305, Abilities.POWER_CONSTRUCT, Abilities.NONE, Abilities.NONE, 600, 108, 100, 121, 81, 95, 95, 3, 0, 300, false, "", true), new PokemonForm("10% Forme Power Construct", "10-pc", Type.DRAGON, Type.GROUND, 1.2, 33.5, Abilities.POWER_CONSTRUCT, Abilities.NONE, Abilities.NONE, 486, 54, 100, 71, 61, 85, 115, 3, 0, 300, false, "10", true), - new PokemonForm("Complete Forme", "complete", Type.DRAGON, Type.GROUND, 4.5, 610, Abilities.POWER_CONSTRUCT, Abilities.NONE, Abilities.NONE, 708, 216, 100, 121, 91, 95, 85, 3, 0, 300), + new PokemonForm("Complete Forme (50% PC)", "complete", Type.DRAGON, Type.GROUND, 4.5, 610, Abilities.POWER_CONSTRUCT, Abilities.NONE, Abilities.NONE, 708, 216, 100, 121, 91, 95, 85, 3, 0, 300), + new PokemonForm("Complete Forme (10% PC)", "10-complete", Type.DRAGON, Type.GROUND, 4.5, 610, Abilities.POWER_CONSTRUCT, Abilities.NONE, Abilities.NONE, 708, 216, 100, 121, 91, 95, 85, 3, 0, 300, false, "complete"), ), new PokemonSpecies(Species.DIANCIE, 6, false, false, true, "Jewel Pokémon", Type.ROCK, Type.FAIRY, 0.7, 8.8, Abilities.CLEAR_BODY, Abilities.NONE, Abilities.NONE, 600, 50, 100, 150, 100, 150, 50, 3, 50, 300, GrowthRate.SLOW, null, false, true, new PokemonForm("Normal", "", Type.ROCK, Type.FAIRY, 0.7, 8.8, Abilities.CLEAR_BODY, Abilities.NONE, Abilities.NONE, 600, 50, 100, 150, 100, 150, 50, 3, 50, 300, false, null, true), @@ -2267,25 +2332,25 @@ export function initSpecies() { new PokemonSpecies(Species.MELTAN, 7, false, false, true, "Hex Nut Pokémon", Type.STEEL, null, 0.2, 8, Abilities.MAGNET_PULL, Abilities.NONE, Abilities.NONE, 300, 46, 65, 65, 55, 35, 34, 3, 0, 150, GrowthRate.SLOW, null, false), new PokemonSpecies(Species.MELMETAL, 7, false, false, true, "Hex Nut Pokémon", Type.STEEL, null, 2.5, 800, Abilities.IRON_FIST, Abilities.NONE, Abilities.NONE, 600, 135, 143, 143, 80, 65, 34, 3, 0, 300, GrowthRate.SLOW, null, false, true, new PokemonForm("Normal", "", Type.STEEL, null, 2.5, 800, Abilities.IRON_FIST, Abilities.NONE, Abilities.NONE, 600, 135, 143, 143, 80, 65, 34, 3, 0, 300, false, null, true), - new PokemonForm("G-Max", SpeciesFormKey.GIGANTAMAX, Type.STEEL, null, 25, 999.9, Abilities.IRON_FIST, Abilities.IRON_FIST, Abilities.IRON_FIST, 700, 175, 165, 155, 85, 75, 45, 3, 0, 300), + new PokemonForm("G-Max", SpeciesFormKey.GIGANTAMAX, Type.STEEL, null, 25, 999.9, Abilities.IRON_FIST, Abilities.NONE, Abilities.NONE, 700, 175, 165, 155, 85, 75, 45, 3, 0, 300), ), new PokemonSpecies(Species.GROOKEY, 8, false, false, false, "Chimp Pokémon", Type.GRASS, null, 0.3, 5, Abilities.OVERGROW, Abilities.NONE, Abilities.GRASSY_SURGE, 310, 50, 65, 50, 40, 40, 65, 45, 50, 62, GrowthRate.MEDIUM_SLOW, 87.5, false), new PokemonSpecies(Species.THWACKEY, 8, false, false, false, "Beat Pokémon", Type.GRASS, null, 0.7, 14, Abilities.OVERGROW, Abilities.NONE, Abilities.GRASSY_SURGE, 420, 70, 85, 70, 55, 60, 80, 45, 50, 147, GrowthRate.MEDIUM_SLOW, 87.5, false), new PokemonSpecies(Species.RILLABOOM, 8, false, false, false, "Drummer Pokémon", Type.GRASS, null, 2.1, 90, Abilities.OVERGROW, Abilities.NONE, Abilities.GRASSY_SURGE, 530, 100, 125, 90, 60, 70, 85, 45, 50, 265, GrowthRate.MEDIUM_SLOW, 87.5, false, true, new PokemonForm("Normal", "", Type.GRASS, null, 2.1, 90, Abilities.OVERGROW, Abilities.NONE, Abilities.GRASSY_SURGE, 530, 100, 125, 90, 60, 70, 85, 45, 50, 265, false, null, true), - new PokemonForm("G-Max", SpeciesFormKey.GIGANTAMAX, Type.GRASS, null, 28, 999.9, Abilities.GRASSY_SURGE, Abilities.GRASSY_SURGE, Abilities.GRASSY_SURGE, 630, 125, 150, 105, 85, 85, 80, 45, 50, 265), + new PokemonForm("G-Max", SpeciesFormKey.GIGANTAMAX, Type.GRASS, null, 28, 999.9, Abilities.GRASSY_SURGE, Abilities.NONE, Abilities.GRASSY_SURGE, 630, 125, 150, 105, 85, 85, 80, 45, 50, 265), ), new PokemonSpecies(Species.SCORBUNNY, 8, false, false, false, "Rabbit Pokémon", Type.FIRE, null, 0.3, 4.5, Abilities.BLAZE, Abilities.NONE, Abilities.LIBERO, 310, 50, 71, 40, 40, 40, 69, 45, 50, 62, GrowthRate.MEDIUM_SLOW, 87.5, false), new PokemonSpecies(Species.RABOOT, 8, false, false, false, "Rabbit Pokémon", Type.FIRE, null, 0.6, 9, Abilities.BLAZE, Abilities.NONE, Abilities.LIBERO, 420, 65, 86, 60, 55, 60, 94, 45, 50, 147, GrowthRate.MEDIUM_SLOW, 87.5, false), new PokemonSpecies(Species.CINDERACE, 8, false, false, false, "Striker Pokémon", Type.FIRE, null, 1.4, 33, Abilities.BLAZE, Abilities.NONE, Abilities.LIBERO, 530, 80, 116, 75, 65, 75, 119, 45, 50, 265, GrowthRate.MEDIUM_SLOW, 87.5, false, true, new PokemonForm("Normal", "", Type.FIRE, null, 1.4, 33, Abilities.BLAZE, Abilities.NONE, Abilities.LIBERO, 530, 80, 116, 75, 65, 75, 119, 45, 50, 265, false, null, true), - new PokemonForm("G-Max", SpeciesFormKey.GIGANTAMAX, Type.FIRE, null, 27, 999.9, Abilities.LIBERO, Abilities.LIBERO, Abilities.LIBERO, 630, 100, 146, 80, 90, 80, 134, 45, 50, 265), + new PokemonForm("G-Max", SpeciesFormKey.GIGANTAMAX, Type.FIRE, null, 27, 999.9, Abilities.LIBERO, Abilities.NONE, Abilities.LIBERO, 630, 100, 146, 80, 90, 80, 134, 45, 50, 265), ), new PokemonSpecies(Species.SOBBLE, 8, false, false, false, "Water Lizard Pokémon", Type.WATER, null, 0.3, 4, Abilities.TORRENT, Abilities.NONE, Abilities.SNIPER, 310, 50, 40, 40, 70, 40, 70, 45, 50, 62, GrowthRate.MEDIUM_SLOW, 87.5, false), new PokemonSpecies(Species.DRIZZILE, 8, false, false, false, "Water Lizard Pokémon", Type.WATER, null, 0.7, 11.5, Abilities.TORRENT, Abilities.NONE, Abilities.SNIPER, 420, 65, 60, 55, 95, 55, 90, 45, 50, 147, GrowthRate.MEDIUM_SLOW, 87.5, false), new PokemonSpecies(Species.INTELEON, 8, false, false, false, "Secret Agent Pokémon", Type.WATER, null, 1.9, 45.2, Abilities.TORRENT, Abilities.NONE, Abilities.SNIPER, 530, 70, 85, 65, 125, 65, 120, 45, 50, 265, GrowthRate.MEDIUM_SLOW, 87.5, false, true, new PokemonForm("Normal", "", Type.WATER, null, 1.9, 45.2, Abilities.TORRENT, Abilities.NONE, Abilities.SNIPER, 530, 70, 85, 65, 125, 65, 120, 45, 50, 265, false, null, true), - new PokemonForm("G-Max", SpeciesFormKey.GIGANTAMAX, Type.WATER, null, 40, 999.9, Abilities.SNIPER, Abilities.SNIPER, Abilities.SNIPER, 630, 95, 97, 77, 147, 77, 137, 45, 50, 265), + new PokemonForm("G-Max", SpeciesFormKey.GIGANTAMAX, Type.WATER, null, 40, 999.9, Abilities.SNIPER, Abilities.NONE, Abilities.SNIPER, 630, 95, 97, 77, 147, 77, 137, 45, 50, 265), ), new PokemonSpecies(Species.SKWOVET, 8, false, false, false, "Cheeky Pokémon", Type.NORMAL, null, 0.3, 2.5, Abilities.CHEEK_POUCH, Abilities.NONE, Abilities.GLUTTONY, 275, 70, 55, 55, 35, 35, 25, 255, 50, 55, GrowthRate.MEDIUM_FAST, 50, false), new PokemonSpecies(Species.GREEDENT, 8, false, false, false, "Greedy Pokémon", Type.NORMAL, null, 0.6, 6, Abilities.CHEEK_POUCH, Abilities.NONE, Abilities.GLUTTONY, 460, 120, 95, 95, 55, 75, 20, 90, 50, 161, GrowthRate.MEDIUM_FAST, 50, false), @@ -2391,7 +2456,7 @@ export function initSpecies() { new PokemonForm("Ruby Swirl", "ruby-swirl", Type.FAIRY, null, 0.3, 0.5, Abilities.SWEET_VEIL, Abilities.NONE, Abilities.AROMA_VEIL, 495, 65, 60, 75, 110, 121, 64, 100, 50, 173, false, null, true), new PokemonForm("Caramel Swirl", "caramel-swirl", Type.FAIRY, null, 0.3, 0.5, Abilities.SWEET_VEIL, Abilities.NONE, Abilities.AROMA_VEIL, 495, 65, 60, 75, 110, 121, 64, 100, 50, 173, false, null, true), new PokemonForm("Rainbow Swirl", "rainbow-swirl", Type.FAIRY, null, 0.3, 0.5, Abilities.SWEET_VEIL, Abilities.NONE, Abilities.AROMA_VEIL, 495, 65, 60, 75, 110, 121, 64, 100, 50, 173, false, null, true), - new PokemonForm("G-Max", SpeciesFormKey.GIGANTAMAX, Type.FAIRY, null, 30, 999.9, Abilities.MISTY_SURGE, Abilities.MISTY_SURGE, Abilities.MISTY_SURGE, 595, 135, 60, 75, 130, 131, 64, 100, 50, 173), + new PokemonForm("G-Max", SpeciesFormKey.GIGANTAMAX, Type.FAIRY, null, 30, 999.9, Abilities.MISTY_SURGE, Abilities.NONE, Abilities.MISTY_SURGE, 595, 135, 60, 75, 130, 131, 64, 100, 50, 173), ), new PokemonSpecies(Species.FALINKS, 8, false, false, false, "Formation Pokémon", Type.FIGHTING, null, 3, 62, Abilities.BATTLE_ARMOR, Abilities.NONE, Abilities.DEFIANT, 470, 65, 100, 100, 70, 60, 75, 45, 50, 165, GrowthRate.MEDIUM_FAST, null, false), new PokemonSpecies(Species.PINCURCHIN, 8, false, false, false, "Sea Urchin Pokémon", Type.ELECTRIC, null, 0.3, 1, Abilities.LIGHTNING_ROD, Abilities.NONE, Abilities.ELECTRIC_SURGE, 435, 48, 101, 95, 91, 85, 15, 75, 50, 152, GrowthRate.MEDIUM_FAST, 50, false), @@ -2413,7 +2478,7 @@ export function initSpecies() { new PokemonSpecies(Species.CUFANT, 8, false, false, false, "Copperderm Pokémon", Type.STEEL, null, 1.2, 100, Abilities.SHEER_FORCE, Abilities.NONE, Abilities.HEAVY_METAL, 330, 72, 80, 49, 40, 49, 40, 190, 50, 66, GrowthRate.MEDIUM_FAST, 50, false), new PokemonSpecies(Species.COPPERAJAH, 8, false, false, false, "Copperderm Pokémon", Type.STEEL, null, 3, 650, Abilities.SHEER_FORCE, Abilities.NONE, Abilities.HEAVY_METAL, 500, 122, 130, 69, 80, 69, 30, 90, 50, 175, GrowthRate.MEDIUM_FAST, 50, false, true, new PokemonForm("Normal", "", Type.STEEL, null, 3, 650, Abilities.SHEER_FORCE, Abilities.NONE, Abilities.HEAVY_METAL, 500, 122, 130, 69, 80, 69, 30, 90, 50, 175, false, null, true), - new PokemonForm("G-Max", SpeciesFormKey.GIGANTAMAX, Type.STEEL, Type.GROUND, 23, 999.9, Abilities.MOLD_BREAKER, Abilities.MOLD_BREAKER, Abilities.MOLD_BREAKER, 600, 167, 155, 89, 80, 89, 20, 90, 50, 175), + new PokemonForm("G-Max", SpeciesFormKey.GIGANTAMAX, Type.STEEL, Type.GROUND, 23, 999.9, Abilities.MOLD_BREAKER, Abilities.NONE, Abilities.MOLD_BREAKER, 600, 167, 155, 89, 80, 89, 20, 90, 50, 175), ), new PokemonSpecies(Species.DRACOZOLT, 8, false, false, false, "Fossil Pokémon", Type.ELECTRIC, Type.DRAGON, 1.8, 190, Abilities.VOLT_ABSORB, Abilities.HUSTLE, Abilities.SAND_RUSH, 505, 90, 100, 90, 80, 70, 75, 45, 50, 177, GrowthRate.SLOW, null, false), new PokemonSpecies(Species.ARCTOZOLT, 8, false, false, false, "Fossil Pokémon", Type.ELECTRIC, Type.ICE, 2.3, 150, Abilities.VOLT_ABSORB, Abilities.STATIC, Abilities.SLUSH_RUSH, 505, 90, 100, 90, 90, 80, 55, 45, 50, 177, GrowthRate.SLOW, null, false), @@ -2545,7 +2610,14 @@ export function initSpecies() { new PokemonForm("Hero Form", "hero", Type.WATER, null, 1.8, 97.4, Abilities.ZERO_TO_HERO, Abilities.NONE, Abilities.ZERO_TO_HERO, 650, 100, 160, 97, 106, 87, 100, 45, 50, 160), ), new PokemonSpecies(Species.VAROOM, 9, false, false, false, "Single-Cyl Pokémon", Type.STEEL, Type.POISON, 1, 35, Abilities.OVERCOAT, Abilities.NONE, Abilities.SLOW_START, 300, 45, 70, 63, 30, 45, 47, 190, 50, 60, GrowthRate.MEDIUM_FAST, 50, false), - new PokemonSpecies(Species.REVAVROOM, 9, false, false, false, "Multi-Cyl Pokémon", Type.STEEL, Type.POISON, 1.8, 120, Abilities.OVERCOAT, Abilities.NONE, Abilities.FILTER, 500, 80, 119, 90, 54, 67, 90, 75, 50, 175, GrowthRate.MEDIUM_FAST, 50, false), + new PokemonSpecies(Species.REVAVROOM, 9, false, false, false, "Multi-Cyl Pokémon", Type.STEEL, Type.POISON, 1.8, 120, Abilities.OVERCOAT, Abilities.NONE, Abilities.FILTER, 500, 80, 119, 90, 54, 67, 90, 75, 50, 175, GrowthRate.MEDIUM_FAST, 50, false, false, + new PokemonForm("Normal", "", Type.STEEL, Type.POISON, 1.8, 120, Abilities.OVERCOAT, Abilities.NONE, Abilities.FILTER, 500, 80, 119, 90, 54, 67, 90, 75, 50, 175, false, null, true), + new PokemonForm("Segin Starmobile", "segin-starmobile", Type.STEEL, Type.DARK, 1.8, 240, Abilities.INTIMIDATE, Abilities.NONE, Abilities.INTIMIDATE, 600, 110, 129, 100, 77, 79, 105, 75, 50, 175), + new PokemonForm("Schedar Starmobile", "schedar-starmobile", Type.STEEL, Type.FIRE, 1.8, 240, Abilities.SPEED_BOOST, Abilities.NONE, Abilities.SPEED_BOOST, 600, 110, 129, 100, 77, 79, 105, 75, 50, 175), + new PokemonForm("Navi Starmobile", "navi-starmobile", Type.STEEL, Type.POISON, 1.8, 240, Abilities.TOXIC_DEBRIS, Abilities.NONE, Abilities.TOXIC_DEBRIS, 600, 110, 129, 100, 77, 79, 105, 75, 50, 175), + new PokemonForm("Ruchbah Starmobile", "ruchbah-starmobile", Type.STEEL, Type.FAIRY, 1.8, 240, Abilities.MISTY_SURGE, Abilities.NONE, Abilities.MISTY_SURGE, 600, 110, 129, 100, 77, 79, 105, 75, 50, 175), + new PokemonForm("Caph Starmobile", "caph-starmobile", Type.STEEL, Type.FIGHTING, 1.8, 240, Abilities.STAMINA, Abilities.NONE, Abilities.STAMINA, 600, 110, 129, 100, 77, 79, 105, 75, 50, 175), + ), new PokemonSpecies(Species.CYCLIZAR, 9, false, false, false, "Mount Pokémon", Type.DRAGON, Type.NORMAL, 1.6, 63, Abilities.SHED_SKIN, Abilities.NONE, Abilities.REGENERATOR, 501, 70, 95, 65, 85, 65, 121, 190, 50, 175, GrowthRate.MEDIUM_SLOW, 50, false), new PokemonSpecies(Species.ORTHWORM, 9, false, false, false, "Earthworm Pokémon", Type.STEEL, null, 2.5, 310, Abilities.EARTH_EATER, Abilities.NONE, Abilities.SAND_VEIL, 480, 70, 85, 145, 60, 55, 65, 25, 50, 240, GrowthRate.SLOW, 50, false), new PokemonSpecies(Species.GLIMMET, 9, false, false, false, "Ore Pokémon", Type.ROCK, Type.POISON, 0.7, 8, Abilities.TOXIC_DEBRIS, Abilities.NONE, Abilities.CORROSION, 350, 48, 35, 42, 105, 60, 60, 70, 50, 70, GrowthRate.MEDIUM_SLOW, 50, false), @@ -2610,8 +2682,8 @@ export function initSpecies() { new PokemonForm("Aquatic Mode", "aquatic-mode", Type.ELECTRIC, Type.DRAGON, 2.8, 240, Abilities.HADRON_ENGINE, Abilities.NONE, Abilities.NONE, 670, 100, 85, 100, 135, 115, 135, 3, 0, 335, false, null, true), new PokemonForm("Glide Mode", "glide-mode", Type.ELECTRIC, Type.DRAGON, 2.8, 240, Abilities.HADRON_ENGINE, Abilities.NONE, Abilities.NONE, 670, 100, 85, 100, 135, 115, 135, 3, 0, 335, false, null, true), ), - new PokemonSpecies(Species.WALKING_WAKE, 9, false, false, false, "Paradox Pokémon", Type.WATER, Type.DRAGON, 3.5, 280, Abilities.PROTOSYNTHESIS, Abilities.NONE, Abilities.NONE, 590, 99, 83, 91, 125, 83, 109, 5, 0, 295, GrowthRate.SLOW, null, false), - new PokemonSpecies(Species.IRON_LEAVES, 9, false, false, false, "Paradox Pokémon", Type.GRASS, Type.PSYCHIC, 1.5, 125, Abilities.QUARK_DRIVE, Abilities.NONE, Abilities.NONE, 590, 90, 130, 88, 70, 108, 104, 5, 0, 295, GrowthRate.SLOW, null, false), + new PokemonSpecies(Species.WALKING_WAKE, 9, false, false, false, "Paradox Pokémon", Type.WATER, Type.DRAGON, 3.5, 280, Abilities.PROTOSYNTHESIS, Abilities.NONE, Abilities.NONE, 590, 99, 83, 91, 125, 83, 109, 10, 0, 295, GrowthRate.SLOW, null, false), //Custom Catchrate, matching Gouging Fire and Raging Bolt + new PokemonSpecies(Species.IRON_LEAVES, 9, false, false, false, "Paradox Pokémon", Type.GRASS, Type.PSYCHIC, 1.5, 125, Abilities.QUARK_DRIVE, Abilities.NONE, Abilities.NONE, 590, 90, 130, 88, 70, 108, 104, 10, 0, 295, GrowthRate.SLOW, null, false), //Custom Catchrate, matching Iron Boulder and Iron Crown new PokemonSpecies(Species.DIPPLIN, 9, false, false, false, "Candy Apple Pokémon", Type.GRASS, Type.DRAGON, 0.4, 9.7, Abilities.SUPERSWEET_SYRUP, Abilities.GLUTTONY, Abilities.STICKY_HOLD, 485, 80, 80, 110, 95, 80, 40, 45, 50, 170, GrowthRate.ERRATIC, 50, false), new PokemonSpecies(Species.POLTCHAGEIST, 9, false, false, false, "Matcha Pokémon", Type.GRASS, Type.GHOST, 0.1, 1.1, Abilities.HOSPITALITY, Abilities.NONE, Abilities.HEATPROOF, 308, 40, 45, 45, 74, 54, 50, 120, 50, 62, GrowthRate.SLOW, null, false, false, new PokemonForm("Counterfeit Form", "counterfeit", Type.GRASS, Type.GHOST, 0.1, 1.1, Abilities.HOSPITALITY, Abilities.NONE, Abilities.HEATPROOF, 308, 40, 45, 45, 74, 54, 50, 120, 50, 62, false, null, true), @@ -2664,7 +2736,7 @@ export function initSpecies() { new PokemonSpecies(Species.ALOLA_MUK, 7, false, false, false, "Sludge Pokémon", Type.POISON, Type.DARK, 1, 52, Abilities.POISON_TOUCH, Abilities.GLUTTONY, Abilities.POWER_OF_ALCHEMY, 500, 105, 105, 75, 65, 100, 50, 75, 70, 175, GrowthRate.MEDIUM_FAST, 50, false), new PokemonSpecies(Species.ALOLA_EXEGGUTOR, 7, false, false, false, "Coconut Pokémon", Type.GRASS, Type.DRAGON, 10.9, 415.6, Abilities.FRISK, Abilities.NONE, Abilities.HARVEST, 530, 95, 105, 85, 125, 75, 45, 45, 50, 186, GrowthRate.SLOW, 50, false), new PokemonSpecies(Species.ALOLA_MAROWAK, 7, false, false, false, "Bone Keeper Pokémon", Type.FIRE, Type.GHOST, 1, 34, Abilities.CURSED_BODY, Abilities.LIGHTNING_ROD, Abilities.ROCK_HEAD, 425, 60, 80, 110, 50, 80, 45, 75, 50, 149, GrowthRate.MEDIUM_FAST, 50, false), - new PokemonSpecies(Species.ETERNAL_FLOETTE, 6, false, false, false, "Single Bloom Pokémon", Type.FAIRY, null, 0.2, 0.9, Abilities.FLOWER_VEIL, Abilities.NONE, Abilities.SYMBIOSIS, 551, 74, 65, 67, 125, 128, 92, 120, 70, 130, GrowthRate.MEDIUM_FAST, 0, false), + new PokemonSpecies(Species.ETERNAL_FLOETTE, 6, true, false, false, "Single Bloom Pokémon", Type.FAIRY, null, 0.2, 0.9, Abilities.FLOWER_VEIL, Abilities.NONE, Abilities.SYMBIOSIS, 551, 74, 65, 67, 125, 128, 92, 120, 70, 130, GrowthRate.MEDIUM_FAST, 0, false), //Marked as Sub-Legend, for casing purposes new PokemonSpecies(Species.GALAR_MEOWTH, 8, false, false, false, "Scratch Cat Pokémon", Type.STEEL, null, 0.4, 7.5, Abilities.PICKUP, Abilities.TOUGH_CLAWS, Abilities.UNNERVE, 290, 50, 65, 55, 40, 40, 40, 255, 50, 58, GrowthRate.MEDIUM_FAST, 50, false), new PokemonSpecies(Species.GALAR_PONYTA, 8, false, false, false, "Fire Horse Pokémon", Type.PSYCHIC, null, 0.8, 24, Abilities.RUN_AWAY, Abilities.PASTEL_VEIL, Abilities.ANTICIPATION, 410, 50, 85, 55, 65, 65, 90, 190, 50, 82, GrowthRate.MEDIUM_FAST, 50, false), new PokemonSpecies(Species.GALAR_RAPIDASH, 8, false, false, false, "Fire Horse Pokémon", Type.PSYCHIC, Type.FAIRY, 1.7, 80, Abilities.RUN_AWAY, Abilities.PASTEL_VEIL, Abilities.ANTICIPATION, 500, 65, 100, 70, 80, 80, 105, 60, 50, 175, GrowthRate.MEDIUM_FAST, 50, false), @@ -2709,1239 +2781,10 @@ export function initSpecies() { new PokemonForm("Aqua Breed", "aqua", Type.FIGHTING, Type.WATER, 1.4, 110, Abilities.INTIMIDATE, Abilities.ANGER_POINT, Abilities.CUD_CHEW, 490, 75, 110, 105, 30, 70, 100, 45, 50, 172, false, null, true), ), new PokemonSpecies(Species.PALDEA_WOOPER, 9, false, false, false, "Water Fish Pokémon", Type.POISON, Type.GROUND, 0.4, 11, Abilities.POISON_POINT, Abilities.WATER_ABSORB, Abilities.UNAWARE, 210, 55, 45, 45, 25, 25, 15, 255, 50, 42, GrowthRate.MEDIUM_FAST, 50, false), - new PokemonSpecies(Species.BLOODMOON_URSALUNA, 9, false, false, false, "Peat Pokémon", Type.GROUND, Type.NORMAL, 2.7, 333, Abilities.MINDS_EYE, Abilities.NONE, Abilities.NONE, 555, 113, 70, 120, 135, 65, 52, 75, 50, 275, GrowthRate.MEDIUM_FAST, 50, false), + new PokemonSpecies(Species.BLOODMOON_URSALUNA, 9, true, false, false, "Peat Pokémon", Type.GROUND, Type.NORMAL, 2.7, 333, Abilities.MINDS_EYE, Abilities.NONE, Abilities.NONE, 555, 113, 70, 120, 135, 65, 52, 75, 50, 275, GrowthRate.MEDIUM_FAST, 50, false), //Marked as Sub-Legend, for casing purposes ); } -export const speciesStarters = { - [Species.BULBASAUR]: 3, - [Species.CHARMANDER]: 3, - [Species.SQUIRTLE]: 3, - [Species.CATERPIE]: 2, - [Species.WEEDLE]: 1, - [Species.PIDGEY]: 1, - [Species.RATTATA]: 1, - [Species.SPEAROW]: 1, - [Species.EKANS]: 2, - [Species.PIKACHU]: 3, - [Species.SANDSHREW]: 2, - [Species.NIDORAN_F]: 3, - [Species.NIDORAN_M]: 3, - [Species.CLEFAIRY]: 3, - [Species.VULPIX]: 3, - [Species.JIGGLYPUFF]: 2, - [Species.ZUBAT]: 3, - [Species.ODDISH]: 3, - [Species.PARAS]: 2, - [Species.VENONAT]: 2, - [Species.DIGLETT]: 2, - [Species.MEOWTH]: 3, - [Species.PSYDUCK]: 2, - [Species.MANKEY]: 4, - [Species.GROWLITHE]: 4, - [Species.POLIWAG]: 2, - [Species.ABRA]: 4, - [Species.MACHOP]: 3, - [Species.BELLSPROUT]: 2, - [Species.TENTACOOL]: 3, - [Species.GEODUDE]: 3, - [Species.PONYTA]: 2, - [Species.SLOWPOKE]: 3, - [Species.MAGNEMITE]: 4, - [Species.FARFETCHD]: 2, - [Species.DODUO]: 3, - [Species.SEEL]: 1, - [Species.GRIMER]: 2, - [Species.SHELLDER]: 5, - [Species.GASTLY]: 4, - [Species.ONIX]: 3, - [Species.DROWZEE]: 2, - [Species.KRABBY]: 3, - [Species.VOLTORB]: 2, - [Species.EXEGGCUTE]: 3, - [Species.CUBONE]: 3, - [Species.HITMONLEE]: 4, - [Species.HITMONCHAN]: 4, - [Species.LICKITUNG]: 3, - [Species.KOFFING]: 2, - [Species.RHYHORN]: 3, - [Species.CHANSEY]: 3, - [Species.TANGELA]: 3, - [Species.KANGASKHAN]: 4, - [Species.HORSEA]: 3, - [Species.GOLDEEN]: 2, - [Species.STARYU]: 3, - [Species.MR_MIME]: 3, - [Species.SCYTHER]: 5, - [Species.JYNX]: 4, - [Species.ELECTABUZZ]: 4, - [Species.MAGMAR]: 4, - [Species.PINSIR]: 4, - [Species.TAUROS]: 4, - [Species.MAGIKARP]: 4, - [Species.LAPRAS]: 4, - [Species.DITTO]: 2, - [Species.EEVEE]: 3, - [Species.PORYGON]: 4, - [Species.OMANYTE]: 3, - [Species.KABUTO]: 3, - [Species.AERODACTYL]: 5, - [Species.SNORLAX]: 5, - [Species.ARTICUNO]: 6, - [Species.ZAPDOS]: 6, - [Species.MOLTRES]: 6, - [Species.DRATINI]: 4, - [Species.MEWTWO]: 8, - [Species.MEW]: 6, - - [Species.CHIKORITA]: 2, - [Species.CYNDAQUIL]: 3, - [Species.TOTODILE]: 3, - [Species.SENTRET]: 1, - [Species.HOOTHOOT]: 2, - [Species.LEDYBA]: 1, - [Species.SPINARAK]: 1, - [Species.CHINCHOU]: 2, - [Species.PICHU]: 2, - [Species.CLEFFA]: 2, - [Species.IGGLYBUFF]: 1, - [Species.TOGEPI]: 3, - [Species.NATU]: 2, - [Species.MAREEP]: 2, - [Species.MARILL]: 4, - [Species.SUDOWOODO]: 3, - [Species.HOPPIP]: 2, - [Species.AIPOM]: 2, - [Species.SUNKERN]: 1, - [Species.YANMA]: 3, - [Species.WOOPER]: 2, - [Species.MURKROW]: 3, - [Species.MISDREAVUS]: 2, - [Species.UNOWN]: 1, - [Species.WOBBUFFET]: 2, - [Species.GIRAFARIG]: 3, - [Species.PINECO]: 2, - [Species.DUNSPARCE]: 3, - [Species.GLIGAR]: 3, - [Species.SNUBBULL]: 2, - [Species.QWILFISH]: 3, - [Species.SHUCKLE]: 3, - [Species.HERACROSS]: 5, - [Species.SNEASEL]: 4, - [Species.TEDDIURSA]: 4, - [Species.SLUGMA]: 2, - [Species.SWINUB]: 3, - [Species.CORSOLA]: 2, - [Species.REMORAID]: 2, - [Species.DELIBIRD]: 2, - [Species.MANTINE]: 3, - [Species.SKARMORY]: 4, - [Species.HOUNDOUR]: 3, - [Species.PHANPY]: 3, - [Species.STANTLER]: 3, - [Species.SMEARGLE]: 1, - [Species.TYROGUE]: 3, - [Species.SMOOCHUM]: 3, - [Species.ELEKID]: 3, - [Species.MAGBY]: 3, - [Species.MILTANK]: 4, - [Species.RAIKOU]: 6, - [Species.ENTEI]: 6, - [Species.SUICUNE]: 6, - [Species.LARVITAR]: 4, - [Species.LUGIA]: 8, - [Species.HO_OH]: 8, - [Species.CELEBI]: 6, - - [Species.TREECKO]: 3, - [Species.TORCHIC]: 4, - [Species.MUDKIP]: 3, - [Species.POOCHYENA]: 2, - [Species.ZIGZAGOON]: 2, - [Species.WURMPLE]: 1, - [Species.LOTAD]: 3, - [Species.SEEDOT]: 2, - [Species.TAILLOW]: 3, - [Species.WINGULL]: 2, - [Species.RALTS]: 3, - [Species.SURSKIT]: 2, - [Species.SHROOMISH]: 3, - [Species.SLAKOTH]: 4, - [Species.NINCADA]: 4, - [Species.WHISMUR]: 2, - [Species.MAKUHITA]: 3, - [Species.AZURILL]: 4, - [Species.NOSEPASS]: 2, - [Species.SKITTY]: 1, - [Species.SABLEYE]: 2, - [Species.MAWILE]: 3, - [Species.ARON]: 3, - [Species.MEDITITE]: 3, - [Species.ELECTRIKE]: 2, - [Species.PLUSLE]: 2, - [Species.MINUN]: 2, - [Species.VOLBEAT]: 2, - [Species.ILLUMISE]: 2, - [Species.ROSELIA]: 3, - [Species.GULPIN]: 1, - [Species.CARVANHA]: 3, - [Species.WAILMER]: 2, - [Species.NUMEL]: 2, - [Species.TORKOAL]: 3, - [Species.SPOINK]: 2, - [Species.SPINDA]: 1, - [Species.TRAPINCH]: 3, - [Species.CACNEA]: 2, - [Species.SWABLU]: 2, - [Species.ZANGOOSE]: 4, - [Species.SEVIPER]: 3, - [Species.LUNATONE]: 3, - [Species.SOLROCK]: 3, - [Species.BARBOACH]: 2, - [Species.CORPHISH]: 3, - [Species.BALTOY]: 2, - [Species.LILEEP]: 3, - [Species.ANORITH]: 3, - [Species.FEEBAS]: 4, - [Species.CASTFORM]: 1, - [Species.KECLEON]: 2, - [Species.SHUPPET]: 2, - [Species.DUSKULL]: 3, - [Species.TROPIUS]: 3, - [Species.CHIMECHO]: 3, - [Species.ABSOL]: 4, - [Species.WYNAUT]: 2, - [Species.SNORUNT]: 2, - [Species.SPHEAL]: 2, - [Species.CLAMPERL]: 3, - [Species.RELICANTH]: 3, - [Species.LUVDISC]: 1, - [Species.BAGON]: 4, - [Species.BELDUM]: 4, - [Species.REGIROCK]: 6, - [Species.REGICE]: 6, - [Species.REGISTEEL]: 6, - [Species.LATIAS]: 7, - [Species.LATIOS]: 7, - [Species.KYOGRE]: 9, - [Species.GROUDON]: 9, - [Species.RAYQUAZA]: 9, - [Species.JIRACHI]: 7, - [Species.DEOXYS]: 7, - - [Species.TURTWIG]: 3, - [Species.CHIMCHAR]: 3, - [Species.PIPLUP]: 3, - [Species.STARLY]: 3, - [Species.BIDOOF]: 2, - [Species.KRICKETOT]: 1, - [Species.SHINX]: 2, - [Species.BUDEW]: 3, - [Species.CRANIDOS]: 3, - [Species.SHIELDON]: 3, - [Species.BURMY]: 2, - [Species.COMBEE]: 2, - [Species.PACHIRISU]: 2, - [Species.BUIZEL]: 2, - [Species.CHERUBI]: 1, - [Species.SHELLOS]: 3, - [Species.DRIFLOON]: 2, - [Species.BUNEARY]: 2, - [Species.GLAMEOW]: 2, - [Species.CHINGLING]: 2, - [Species.STUNKY]: 2, - [Species.BRONZOR]: 3, - [Species.BONSLY]: 2, - [Species.MIME_JR]: 2, - [Species.HAPPINY]: 2, - [Species.CHATOT]: 2, - [Species.SPIRITOMB]: 4, - [Species.GIBLE]: 4, - [Species.MUNCHLAX]: 4, - [Species.RIOLU]: 3, - [Species.HIPPOPOTAS]: 3, - [Species.SKORUPI]: 3, - [Species.CROAGUNK]: 2, - [Species.CARNIVINE]: 2, - [Species.FINNEON]: 1, - [Species.MANTYKE]: 2, - [Species.SNOVER]: 2, - [Species.ROTOM]: 5, - [Species.UXIE]: 6, - [Species.MESPRIT]: 6, - [Species.AZELF]: 6, - [Species.DIALGA]: 8, - [Species.PALKIA]: 8, - [Species.HEATRAN]: 6, - [Species.REGIGIGAS]: 7, - [Species.GIRATINA]: 8, - [Species.CRESSELIA]: 6, - [Species.PHIONE]: 4, - [Species.MANAPHY]: 7, - [Species.DARKRAI]: 6, - [Species.SHAYMIN]: 6, - [Species.ARCEUS]: 9, - - [Species.VICTINI]: 7, - [Species.SNIVY]: 3, - [Species.TEPIG]: 3, - [Species.OSHAWOTT]: 3, - [Species.PATRAT]: 1, - [Species.LILLIPUP]: 3, - [Species.PURRLOIN]: 2, - [Species.PANSAGE]: 2, - [Species.PANSEAR]: 2, - [Species.PANPOUR]: 2, - [Species.MUNNA]: 2, - [Species.PIDOVE]: 1, - [Species.BLITZLE]: 2, - [Species.ROGGENROLA]: 3, - [Species.WOOBAT]: 3, - [Species.DRILBUR]: 4, - [Species.AUDINO]: 3, - [Species.TIMBURR]: 4, - [Species.TYMPOLE]: 3, - [Species.THROH]: 4, - [Species.SAWK]: 4, - [Species.SEWADDLE]: 2, - [Species.VENIPEDE]: 3, - [Species.COTTONEE]: 3, - [Species.PETILIL]: 3, - [Species.BASCULIN]: 4, - [Species.SANDILE]: 4, - [Species.DARUMAKA]: 4, - [Species.MARACTUS]: 2, - [Species.DWEBBLE]: 2, - [Species.SCRAGGY]: 3, - [Species.SIGILYPH]: 4, - [Species.YAMASK]: 3, - [Species.TIRTOUGA]: 3, - [Species.ARCHEN]: 3, - [Species.TRUBBISH]: 2, - [Species.ZORUA]: 3, - [Species.MINCCINO]: 3, - [Species.GOTHITA]: 3, - [Species.SOLOSIS]: 3, - [Species.DUCKLETT]: 2, - [Species.VANILLITE]: 3, - [Species.DEERLING]: 2, - [Species.EMOLGA]: 2, - [Species.KARRABLAST]: 3, - [Species.FOONGUS]: 2, - [Species.FRILLISH]: 3, - [Species.ALOMOMOLA]: 4, - [Species.JOLTIK]: 3, - [Species.FERROSEED]: 3, - [Species.KLINK]: 3, - [Species.TYNAMO]: 2, - [Species.ELGYEM]: 2, - [Species.LITWICK]: 3, - [Species.AXEW]: 4, - [Species.CUBCHOO]: 2, - [Species.CRYOGONAL]: 4, - [Species.SHELMET]: 2, - [Species.STUNFISK]: 3, - [Species.MIENFOO]: 3, - [Species.DRUDDIGON]: 4, - [Species.GOLETT]: 3, - [Species.PAWNIARD]: 4, - [Species.BOUFFALANT]: 4, - [Species.RUFFLET]: 3, - [Species.VULLABY]: 3, - [Species.HEATMOR]: 3, - [Species.DURANT]: 4, - [Species.DEINO]: 4, - [Species.LARVESTA]: 4, - [Species.COBALION]: 6, - [Species.TERRAKION]: 6, - [Species.VIRIZION]: 6, - [Species.TORNADUS]: 7, - [Species.THUNDURUS]: 7, - [Species.RESHIRAM]: 8, - [Species.ZEKROM]: 8, - [Species.LANDORUS]: 7, - [Species.KYUREM]: 8, - [Species.KELDEO]: 6, - [Species.MELOETTA]: 6, - [Species.GENESECT]: 6, - - [Species.CHESPIN]: 3, - [Species.FENNEKIN]: 3, - [Species.FROAKIE]: 4, - [Species.BUNNELBY]: 3, - [Species.FLETCHLING]: 3, - [Species.SCATTERBUG]: 2, - [Species.LITLEO]: 2, - [Species.FLABEBE]: 3, - [Species.SKIDDO]: 2, - [Species.PANCHAM]: 3, - [Species.FURFROU]: 3, - [Species.ESPURR]: 2, - [Species.HONEDGE]: 4, - [Species.SPRITZEE]: 2, - [Species.SWIRLIX]: 3, - [Species.INKAY]: 3, - [Species.BINACLE]: 3, - [Species.SKRELP]: 2, - [Species.CLAUNCHER]: 3, - [Species.HELIOPTILE]: 3, - [Species.TYRUNT]: 3, - [Species.AMAURA]: 3, - [Species.HAWLUCHA]: 4, - [Species.DEDENNE]: 2, - [Species.CARBINK]: 2, - [Species.GOOMY]: 4, - [Species.KLEFKI]: 3, - [Species.PHANTUMP]: 2, - [Species.PUMPKABOO]: 2, - [Species.BERGMITE]: 3, - [Species.NOIBAT]: 3, - [Species.XERNEAS]: 8, - [Species.YVELTAL]: 8, - [Species.ZYGARDE]: 8, - [Species.DIANCIE]: 7, - [Species.HOOPA]: 7, - [Species.VOLCANION]: 6, - [Species.ETERNAL_FLOETTE]: 4, - - [Species.ROWLET]: 3, - [Species.LITTEN]: 3, - [Species.POPPLIO]: 4, - [Species.PIKIPEK]: 2, - [Species.YUNGOOS]: 2, - [Species.GRUBBIN]: 3, - [Species.CRABRAWLER]: 3, - [Species.ORICORIO]: 3, - [Species.CUTIEFLY]: 3, - [Species.ROCKRUFF]: 3, - [Species.WISHIWASHI]: 2, - [Species.MAREANIE]: 2, - [Species.MUDBRAY]: 3, - [Species.DEWPIDER]: 3, - [Species.FOMANTIS]: 2, - [Species.MORELULL]: 2, - [Species.SALANDIT]: 3, - [Species.STUFFUL]: 3, - [Species.BOUNSWEET]: 3, - [Species.COMFEY]: 4, - [Species.ORANGURU]: 4, - [Species.PASSIMIAN]: 4, - [Species.WIMPOD]: 3, - [Species.SANDYGAST]: 3, - [Species.PYUKUMUKU]: 2, - [Species.TYPE_NULL]: 5, - [Species.MINIOR]: 4, - [Species.KOMALA]: 3, - [Species.TURTONATOR]: 4, - [Species.TOGEDEMARU]: 3, - [Species.MIMIKYU]: 4, - [Species.BRUXISH]: 4, - [Species.DRAMPA]: 4, - [Species.DHELMISE]: 4, - [Species.JANGMO_O]: 4, - [Species.TAPU_KOKO]: 6, - [Species.TAPU_LELE]: 6, - [Species.TAPU_BULU]: 6, - [Species.TAPU_FINI]: 6, - [Species.COSMOG]: 6, - [Species.NIHILEGO]: 6, - [Species.BUZZWOLE]: 6, - [Species.PHEROMOSA]: 7, - [Species.XURKITREE]: 6, - [Species.CELESTEELA]: 6, - [Species.KARTANA]: 7, - [Species.GUZZLORD]: 6, - [Species.NECROZMA]: 8, - [Species.MAGEARNA]: 7, - [Species.MARSHADOW]: 7, - [Species.POIPOLE]: 7, - [Species.STAKATAKA]: 6, - [Species.BLACEPHALON]: 7, - [Species.ZERAORA]: 6, - [Species.MELTAN]: 6, - [Species.ALOLA_RATTATA]: 1, - [Species.ALOLA_SANDSHREW]: 2, - [Species.ALOLA_VULPIX]: 3, - [Species.ALOLA_DIGLETT]: 2, - [Species.ALOLA_MEOWTH]: 3, - [Species.ALOLA_GEODUDE]: 3, - [Species.ALOLA_GRIMER]: 3, - - [Species.GROOKEY]: 3, - [Species.SCORBUNNY]: 4, - [Species.SOBBLE]: 3, - [Species.SKWOVET]: 2, - [Species.ROOKIDEE]: 3, - [Species.BLIPBUG]: 2, - [Species.NICKIT]: 1, - [Species.GOSSIFLEUR]: 2, - [Species.WOOLOO]: 2, - [Species.CHEWTLE]: 3, - [Species.YAMPER]: 2, - [Species.ROLYCOLY]: 3, - [Species.APPLIN]: 3, - [Species.SILICOBRA]: 3, - [Species.CRAMORANT]: 3, - [Species.ARROKUDA]: 3, - [Species.TOXEL]: 3, - [Species.SIZZLIPEDE]: 3, - [Species.CLOBBOPUS]: 2, - [Species.SINISTEA]: 3, - [Species.HATENNA]: 3, - [Species.IMPIDIMP]: 3, - [Species.MILCERY]: 3, - [Species.FALINKS]: 4, - [Species.PINCURCHIN]: 3, - [Species.SNOM]: 3, - [Species.STONJOURNER]: 3, - [Species.EISCUE]: 3, - [Species.INDEEDEE]: 4, - [Species.MORPEKO]: 3, - [Species.CUFANT]: 3, - [Species.DRACOZOLT]: 5, - [Species.ARCTOZOLT]: 4, - [Species.DRACOVISH]: 5, - [Species.ARCTOVISH]: 4, - [Species.DURALUDON]: 5, - [Species.DREEPY]: 4, - [Species.ZACIAN]: 9, - [Species.ZAMAZENTA]: 8, - [Species.ETERNATUS]: 10, - [Species.KUBFU]: 6, - [Species.ZARUDE]: 6, - [Species.REGIELEKI]: 6, - [Species.REGIDRAGO]: 6, - [Species.GLASTRIER]: 6, - [Species.SPECTRIER]: 7, - [Species.CALYREX]: 8, - [Species.GALAR_MEOWTH]: 3, - [Species.GALAR_PONYTA]: 2, - [Species.GALAR_SLOWPOKE]: 3, - [Species.GALAR_FARFETCHD]: 3, - [Species.GALAR_CORSOLA]: 3, - [Species.GALAR_ZIGZAGOON]: 3, - [Species.GALAR_DARUMAKA]: 4, - [Species.GALAR_YAMASK]: 3, - [Species.GALAR_STUNFISK]: 2, - [Species.GALAR_MR_MIME]: 3, - [Species.GALAR_ARTICUNO]: 6, - [Species.GALAR_ZAPDOS]: 6, - [Species.GALAR_MOLTRES]: 6, - [Species.HISUI_GROWLITHE]: 4, - [Species.HISUI_VOLTORB]: 3, - [Species.HISUI_QWILFISH]: 4, - [Species.HISUI_SNEASEL]: 5, - [Species.HISUI_ZORUA]: 3, - [Species.ENAMORUS]: 7, - - [Species.SPRIGATITO]: 4, - [Species.FUECOCO]: 4, - [Species.QUAXLY]: 4, - [Species.LECHONK]: 2, - [Species.TAROUNTULA]: 1, - [Species.NYMBLE]: 3, - [Species.PAWMI]: 3, - [Species.TANDEMAUS]: 4, - [Species.FIDOUGH]: 2, - [Species.SMOLIV]: 3, - [Species.SQUAWKABILLY]: 2, - [Species.NACLI]: 4, - [Species.CHARCADET]: 4, - [Species.TADBULB]: 3, - [Species.WATTREL]: 3, - [Species.MASCHIFF]: 3, - [Species.SHROODLE]: 2, - [Species.BRAMBLIN]: 3, - [Species.TOEDSCOOL]: 3, - [Species.KLAWF]: 3, - [Species.CAPSAKID]: 3, - [Species.RELLOR]: 2, - [Species.FLITTLE]: 3, - [Species.TINKATINK]: 4, - [Species.WIGLETT]: 2, - [Species.BOMBIRDIER]: 3, - [Species.FINIZEN]: 3, - [Species.VAROOM]: 4, - [Species.CYCLIZAR]: 4, - [Species.ORTHWORM]: 4, - [Species.GLIMMET]: 4, - [Species.GREAVARD]: 3, - [Species.FLAMIGO]: 4, - [Species.CETODDLE]: 3, - [Species.VELUZA]: 4, - [Species.DONDOZO]: 4, - [Species.TATSUGIRI]: 4, - [Species.GREAT_TUSK]: 6, - [Species.SCREAM_TAIL]: 6, - [Species.BRUTE_BONNET]: 6, - [Species.FLUTTER_MANE]: 7, - [Species.SLITHER_WING]: 6, - [Species.SANDY_SHOCKS]: 6, - [Species.IRON_TREADS]: 6, - [Species.IRON_BUNDLE]: 6, - [Species.IRON_HANDS]: 6, - [Species.IRON_JUGULIS]: 6, - [Species.IRON_MOTH]: 6, - [Species.IRON_THORNS]: 6, - [Species.FRIGIBAX]: 4, - [Species.GIMMIGHOUL]: 4, - [Species.WO_CHIEN]: 6, - [Species.CHIEN_PAO]: 7, - [Species.TING_LU]: 6, - [Species.CHI_YU]: 7, - [Species.ROARING_MOON]: 6, - [Species.IRON_VALIANT]: 6, - [Species.KORAIDON]: 9, - [Species.MIRAIDON]: 9, - [Species.WALKING_WAKE]: 6, - [Species.IRON_LEAVES]: 6, - [Species.POLTCHAGEIST]: 4, - [Species.OKIDOGI]: 6, - [Species.MUNKIDORI]: 6, - [Species.FEZANDIPITI]: 6, - [Species.OGERPON]: 7, - [Species.GOUGING_FIRE]: 7, - [Species.RAGING_BOLT]: 6, - [Species.IRON_BOULDER]: 7, - [Species.IRON_CROWN]: 6, - [Species.TERAPAGOS]: 8, - [Species.PECHARUNT]: 6, - [Species.PALDEA_TAUROS]: 5, - [Species.PALDEA_WOOPER]: 3, - [Species.BLOODMOON_URSALUNA]: 6, -}; - -export const noStarterFormKeys: string[] = [ - SpeciesFormKey.MEGA, - SpeciesFormKey.MEGA_X, - SpeciesFormKey.MEGA_Y, - SpeciesFormKey.PRIMAL, - SpeciesFormKey.ORIGIN, - SpeciesFormKey.THERIAN, - SpeciesFormKey.GIGANTAMAX, - SpeciesFormKey.GIGANTAMAX_RAPID, - SpeciesFormKey.GIGANTAMAX_SINGLE, - SpeciesFormKey.ETERNAMAX -].map(k => k.toString()); - -export function getStarterValueFriendshipCap(value: integer): integer { - switch (value) { - case 1: - return 20; - case 2: - return 40; - case 3: - return 60; - case 4: - return 100; - case 5: - return 140; - case 6: - return 200; - case 7: - return 280; - case 8: - case 9: - return 450; - default: - return 600; - } -} - -export const POKERUS_STARTER_COUNT = 5; //adjust here! -/** -* Method to get the daily list of starters with Pokerus. -* @param scene {@linkcode BattleScene} used as part of RNG -* @returns A list of starters with Pokerus -*/ -export function getPokerusStarters(scene: BattleScene): PokemonSpecies[] { - const pokerusStarters: PokemonSpecies[] = []; - const date = new Date(); - date.setUTCHours(0, 0, 0, 0); - scene.executeWithSeedOffset(() => { - while (pokerusStarters.length < POKERUS_STARTER_COUNT) { - const randomSpeciesId = parseInt(Utils.randSeedItem(Object.keys(speciesStarters)), 10); - const species = getPokemonSpecies(randomSpeciesId); - if (!pokerusStarters.includes(species)) { - pokerusStarters.push(species); - } - } - }, 0, date.getTime().toString()); - return pokerusStarters; -} - -export const starterPassiveAbilities = { - [Species.BULBASAUR]: Abilities.GRASSY_SURGE, - [Species.CHARMANDER]: Abilities.BEAST_BOOST, - [Species.SQUIRTLE]: Abilities.STURDY, - [Species.CATERPIE]: Abilities.MAGICIAN, - [Species.WEEDLE]: Abilities.TINTED_LENS, - [Species.PIDGEY]: Abilities.FLARE_BOOST, - [Species.RATTATA]: Abilities.STRONG_JAW, - [Species.SPEAROW]: Abilities.MOXIE, - [Species.EKANS]: Abilities.REGENERATOR, - [Species.SANDSHREW]: Abilities.TOUGH_CLAWS, - [Species.NIDORAN_F]: Abilities.FLARE_BOOST, - [Species.NIDORAN_M]: Abilities.GUTS, - [Species.VULPIX]: Abilities.FUR_COAT, - [Species.ZUBAT]: Abilities.INTIMIDATE, - [Species.ODDISH]: Abilities.TRIAGE, - [Species.PARAS]: Abilities.TRIAGE, - [Species.VENONAT]: Abilities.SIMPLE, - [Species.DIGLETT]: Abilities.STURDY, - [Species.MEOWTH]: Abilities.TOUGH_CLAWS, - [Species.PSYDUCK]: Abilities.SIMPLE, - [Species.MANKEY]: Abilities.IRON_FIST, - [Species.GROWLITHE]: Abilities.SPEED_BOOST, - [Species.POLIWAG]: Abilities.NO_GUARD, - [Species.ABRA]: Abilities.PSYCHIC_SURGE, - [Species.MACHOP]: Abilities.QUICK_FEET, - [Species.BELLSPROUT]: Abilities.PROTOSYNTHESIS, - [Species.TENTACOOL]: Abilities.TOXIC_CHAIN, - [Species.GEODUDE]: Abilities.DRY_SKIN, - [Species.PONYTA]: Abilities.MAGIC_GUARD, - [Species.SLOWPOKE]: Abilities.UNAWARE, - [Species.MAGNEMITE]: Abilities.LEVITATE, - [Species.FARFETCHD]: Abilities.SNIPER, - [Species.DODUO]: Abilities.PARENTAL_BOND, - [Species.SEEL]: Abilities.WATER_BUBBLE, - [Species.GRIMER]: Abilities.WATER_ABSORB, - [Species.SHELLDER]: Abilities.ICE_SCALES, - [Species.GASTLY]: Abilities.SHADOW_SHIELD, - [Species.ONIX]: Abilities.ROCKY_PAYLOAD, - [Species.DROWZEE]: Abilities.MAGICIAN, - [Species.KRABBY]: Abilities.UNBURDEN, - [Species.VOLTORB]: Abilities.TRANSISTOR, - [Species.EXEGGCUTE]: Abilities.RIPEN, - [Species.CUBONE]: Abilities.PARENTAL_BOND, - [Species.LICKITUNG]: Abilities.THICK_FAT, - [Species.KOFFING]: Abilities.PARENTAL_BOND, - [Species.RHYHORN]: Abilities.FILTER, - [Species.TANGELA]: Abilities.SEED_SOWER, - [Species.KANGASKHAN]: Abilities.GUTS, - [Species.HORSEA]: Abilities.DRAGONS_MAW, - [Species.GOLDEEN]: Abilities.MULTISCALE, - [Species.STARYU]: Abilities.REGENERATOR, - [Species.SCYTHER]: Abilities.TINTED_LENS, - [Species.PINSIR]: Abilities.TINTED_LENS, - [Species.TAUROS]: Abilities.SCRAPPY, - [Species.MAGIKARP]: Abilities.MULTISCALE, - [Species.LAPRAS]: Abilities.LIGHTNING_ROD, - [Species.DITTO]: Abilities.ADAPTABILITY, - [Species.EEVEE]: Abilities.PICKUP, - [Species.PORYGON]: Abilities.PROTEAN, - [Species.OMANYTE]: Abilities.STURDY, - [Species.KABUTO]: Abilities.TOUGH_CLAWS, - [Species.AERODACTYL]: Abilities.ORICHALCUM_PULSE, - [Species.ARTICUNO]: Abilities.SNOW_WARNING, - [Species.ZAPDOS]: Abilities.DRIZZLE, - [Species.MOLTRES]: Abilities.DROUGHT, - [Species.DRATINI]: Abilities.AERILATE, - [Species.MEWTWO]: Abilities.NEUROFORCE, - [Species.MEW]: Abilities.PROTEAN, - [Species.CHIKORITA]: Abilities.THICK_FAT, - [Species.CYNDAQUIL]: Abilities.DROUGHT, - [Species.TOTODILE]: Abilities.TOUGH_CLAWS, - [Species.SENTRET]: Abilities.PICKUP, - [Species.HOOTHOOT]: Abilities.AERILATE, - [Species.LEDYBA]: Abilities.PRANKSTER, - [Species.SPINARAK]: Abilities.PRANKSTER, - [Species.CHINCHOU]: Abilities.WATER_BUBBLE, - [Species.PICHU]: Abilities.ELECTRIC_SURGE, - [Species.CLEFFA]: Abilities.ANALYTIC, - [Species.IGGLYBUFF]: Abilities.HUGE_POWER, - [Species.TOGEPI]: Abilities.PIXILATE, - [Species.NATU]: Abilities.TINTED_LENS, - [Species.MAREEP]: Abilities.ELECTROMORPHOSIS, - [Species.HOPPIP]: Abilities.FLUFFY, - [Species.AIPOM]: Abilities.SCRAPPY, - [Species.SUNKERN]: Abilities.DROUGHT, - [Species.YANMA]: Abilities.SHEER_FORCE, - [Species.WOOPER]: Abilities.COMATOSE, - [Species.MURKROW]: Abilities.DARK_AURA, - [Species.MISDREAVUS]: Abilities.BEADS_OF_RUIN, - [Species.UNOWN]: Abilities.PICKUP, - [Species.GIRAFARIG]: Abilities.PARENTAL_BOND, - [Species.PINECO]: Abilities.IRON_BARBS, - [Species.DUNSPARCE]: Abilities.UNAWARE, - [Species.GLIGAR]: Abilities.TOXIC_BOOST, - [Species.SNUBBULL]: Abilities.PIXILATE, - [Species.QWILFISH]: Abilities.TOXIC_DEBRIS, - [Species.SHUCKLE]: Abilities.HARVEST, - [Species.HERACROSS]: Abilities.TECHNICIAN, - [Species.SNEASEL]: Abilities.TOUGH_CLAWS, - [Species.TEDDIURSA]: Abilities.THICK_FAT, - [Species.SLUGMA]: Abilities.DESOLATE_LAND, - [Species.SWINUB]: Abilities.SLUSH_RUSH, - [Species.CORSOLA]: Abilities.STORM_DRAIN, - [Species.REMORAID]: Abilities.SIMPLE, - [Species.DELIBIRD]: Abilities.HUGE_POWER, - [Species.SKARMORY]: Abilities.LIGHTNING_ROD, - [Species.HOUNDOUR]: Abilities.DROUGHT, - [Species.PHANPY]: Abilities.SPEED_BOOST, - [Species.STANTLER]: Abilities.ANALYTIC, - [Species.SMEARGLE]: Abilities.PRANKSTER, - [Species.TYROGUE]: Abilities.MOXIE, - [Species.SMOOCHUM]: Abilities.PSYCHIC_SURGE, - [Species.ELEKID]: Abilities.SHEER_FORCE, - [Species.MAGBY]: Abilities.CONTRARY, - [Species.MILTANK]: Abilities.STAMINA, - [Species.RAIKOU]: Abilities.TRANSISTOR, - [Species.ENTEI]: Abilities.MOXIE, - [Species.SUICUNE]: Abilities.UNAWARE, - [Species.LARVITAR]: Abilities.SAND_RUSH, - [Species.LUGIA]: Abilities.DELTA_STREAM, - [Species.HO_OH]: Abilities.MAGIC_GUARD, - [Species.CELEBI]: Abilities.GRASSY_SURGE, - [Species.TREECKO]: Abilities.TINTED_LENS, - [Species.TORCHIC]: Abilities.RECKLESS, - [Species.MUDKIP]: Abilities.DRIZZLE, - [Species.POOCHYENA]: Abilities.TOUGH_CLAWS, - [Species.ZIGZAGOON]: Abilities.RUN_AWAY, - [Species.WURMPLE]: Abilities.SIMPLE, - [Species.LOTAD]: Abilities.DRIZZLE, - [Species.SEEDOT]: Abilities.SHARPNESS, - [Species.TAILLOW]: Abilities.AERILATE, - [Species.WINGULL]: Abilities.SWIFT_SWIM, - [Species.RALTS]: Abilities.PSYCHIC_SURGE, - [Species.SURSKIT]: Abilities.WATER_BUBBLE, - [Species.SHROOMISH]: Abilities.GUTS, - [Species.SLAKOTH]: Abilities.GUTS, - [Species.NINCADA]: Abilities.MAGIC_GUARD, - [Species.WHISMUR]: Abilities.PUNK_ROCK, - [Species.MAKUHITA]: Abilities.STAMINA, - [Species.AZURILL]: Abilities.MISTY_SURGE, - [Species.NOSEPASS]: Abilities.LEVITATE, - [Species.SKITTY]: Abilities.SCRAPPY, - [Species.SABLEYE]: Abilities.UNNERVE, - [Species.MAWILE]: Abilities.UNNERVE, - [Species.ARON]: Abilities.EARTH_EATER, - [Species.MEDITITE]: Abilities.MINDS_EYE, - [Species.ELECTRIKE]: Abilities.ELECTRIC_SURGE, - [Species.PLUSLE]: Abilities.POWER_SPOT, - [Species.MINUN]: Abilities.POWER_SPOT, - [Species.VOLBEAT]: Abilities.HONEY_GATHER, - [Species.ILLUMISE]: Abilities.HONEY_GATHER, - [Species.GULPIN]: Abilities.EARTH_EATER, - [Species.CARVANHA]: Abilities.SHEER_FORCE, - [Species.WAILMER]: Abilities.LEVITATE, - [Species.NUMEL]: Abilities.FUR_COAT, - [Species.TORKOAL]: Abilities.ANALYTIC, - [Species.SPOINK]: Abilities.PSYCHIC_SURGE, - [Species.SPINDA]: Abilities.SIMPLE, - [Species.TRAPINCH]: Abilities.ADAPTABILITY, - [Species.CACNEA]: Abilities.SAND_RUSH, - [Species.SWABLU]: Abilities.ADAPTABILITY, - [Species.ZANGOOSE]: Abilities.POISON_HEAL, - [Species.SEVIPER]: Abilities.MULTISCALE, - [Species.LUNATONE]: Abilities.SHADOW_SHIELD, - [Species.SOLROCK]: Abilities.DROUGHT, - [Species.BARBOACH]: Abilities.SIMPLE, - [Species.CORPHISH]: Abilities.TOUGH_CLAWS, - [Species.BALTOY]: Abilities.WELL_BAKED_BODY, - [Species.LILEEP]: Abilities.SEED_SOWER, - [Species.ANORITH]: Abilities.WATER_ABSORB, - [Species.FEEBAS]: Abilities.MAGIC_GUARD, - [Species.CASTFORM]: Abilities.ADAPTABILITY, - [Species.KECLEON]: Abilities.ADAPTABILITY, - [Species.SHUPPET]: Abilities.SHADOW_SHIELD, - [Species.DUSKULL]: Abilities.UNNERVE, - [Species.TROPIUS]: Abilities.RIPEN, - [Species.ABSOL]: Abilities.SHARPNESS, - [Species.WYNAUT]: Abilities.STURDY, - [Species.SNORUNT]: Abilities.SNOW_WARNING, - [Species.SPHEAL]: Abilities.UNAWARE, - [Species.CLAMPERL]: Abilities.DRIZZLE, - [Species.RELICANTH]: Abilities.PRIMORDIAL_SEA, - [Species.LUVDISC]: Abilities.MULTISCALE, - [Species.BAGON]: Abilities.DRAGONS_MAW, - [Species.BELDUM]: Abilities.LEVITATE, - [Species.REGIROCK]: Abilities.SAND_STREAM, - [Species.REGICE]: Abilities.SNOW_WARNING, - [Species.REGISTEEL]: Abilities.FILTER, - [Species.LATIAS]: Abilities.PRISM_ARMOR, - [Species.LATIOS]: Abilities.TINTED_LENS, - [Species.KYOGRE]: Abilities.MOLD_BREAKER, - [Species.GROUDON]: Abilities.TURBOBLAZE, - [Species.RAYQUAZA]: Abilities.UNNERVE, - [Species.JIRACHI]: Abilities.COMATOSE, - [Species.DEOXYS]: Abilities.PROTEAN, - [Species.TURTWIG]: Abilities.THICK_FAT, - [Species.CHIMCHAR]: Abilities.BEAST_BOOST, - [Species.PIPLUP]: Abilities.DRIZZLE, - [Species.STARLY]: Abilities.ROCK_HEAD, - [Species.BIDOOF]: Abilities.SAP_SIPPER, - [Species.KRICKETOT]: Abilities.SHARPNESS, - [Species.SHINX]: Abilities.SPEED_BOOST, - [Species.BUDEW]: Abilities.GRASSY_SURGE, - [Species.CRANIDOS]: Abilities.ROCK_HEAD, - [Species.SHIELDON]: Abilities.EARTH_EATER, - [Species.BURMY]: Abilities.STURDY, - [Species.COMBEE]: Abilities.INTIMIDATE, - [Species.PACHIRISU]: Abilities.HONEY_GATHER, - [Species.BUIZEL]: Abilities.MOXIE, - [Species.CHERUBI]: Abilities.ORICHALCUM_PULSE, - [Species.SHELLOS]: Abilities.REGENERATOR, - [Species.DRIFLOON]: Abilities.MAGIC_GUARD, - [Species.BUNEARY]: Abilities.ADAPTABILITY, - [Species.GLAMEOW]: Abilities.INTIMIDATE, - [Species.CHINGLING]: Abilities.PUNK_ROCK, - [Species.STUNKY]: Abilities.NEUTRALIZING_GAS, - [Species.BRONZOR]: Abilities.BULLETPROOF, - [Species.BONSLY]: Abilities.SAP_SIPPER, - [Species.MIME_JR]: Abilities.OPPORTUNIST, - [Species.HAPPINY]: Abilities.FUR_COAT, - [Species.CHATOT]: Abilities.PUNK_ROCK, - [Species.SPIRITOMB]: Abilities.VESSEL_OF_RUIN, - [Species.GIBLE]: Abilities.SAND_STREAM, - [Species.MUNCHLAX]: Abilities.RIPEN, - [Species.RIOLU]: Abilities.MINDS_EYE, - [Species.HIPPOPOTAS]: Abilities.UNAWARE, - [Species.SKORUPI]: Abilities.SUPER_LUCK, - [Species.CROAGUNK]: Abilities.MOXIE, - [Species.CARNIVINE]: Abilities.ARENA_TRAP, - [Species.FINNEON]: Abilities.WATER_BUBBLE, - [Species.MANTYKE]: Abilities.UNAWARE, - [Species.SNOVER]: Abilities.THICK_FAT, - [Species.ROTOM]: Abilities.HADRON_ENGINE, - [Species.UXIE]: Abilities.UNAWARE, - [Species.MESPRIT]: Abilities.MOODY, - [Species.AZELF]: Abilities.NEUROFORCE, - [Species.DIALGA]: Abilities.LEVITATE, - [Species.PALKIA]: Abilities.SPEED_BOOST, - [Species.HEATRAN]: Abilities.EARTH_EATER, - [Species.REGIGIGAS]: Abilities.MINDS_EYE, - [Species.GIRATINA]: Abilities.SHADOW_SHIELD, - [Species.CRESSELIA]: Abilities.SHADOW_SHIELD, - [Species.PHIONE]: Abilities.SIMPLE, - [Species.MANAPHY]: Abilities.PRIMORDIAL_SEA, - [Species.DARKRAI]: Abilities.UNNERVE, - [Species.SHAYMIN]: Abilities.WIND_RIDER, - [Species.ARCEUS]: Abilities.ADAPTABILITY, - [Species.VICTINI]: Abilities.SHEER_FORCE, - [Species.SNIVY]: Abilities.MULTISCALE, - [Species.TEPIG]: Abilities.ROCK_HEAD, - [Species.OSHAWOTT]: Abilities.INTREPID_SWORD, - [Species.PATRAT]: Abilities.NO_GUARD, - [Species.LILLIPUP]: Abilities.FUR_COAT, - [Species.PURRLOIN]: Abilities.PICKUP, - [Species.PANSAGE]: Abilities.WELL_BAKED_BODY, - [Species.PANSEAR]: Abilities.WATER_ABSORB, - [Species.PANPOUR]: Abilities.SAP_SIPPER, - [Species.MUNNA]: Abilities.NEUTRALIZING_GAS, - [Species.PIDOVE]: Abilities.SNIPER, - [Species.BLITZLE]: Abilities.RECKLESS, - [Species.ROGGENROLA]: Abilities.SOLID_ROCK, - [Species.WOOBAT]: Abilities.OPPORTUNIST, - [Species.DRILBUR]: Abilities.SAND_STREAM, - [Species.AUDINO]: Abilities.FRIEND_GUARD, - [Species.TIMBURR]: Abilities.ROCKY_PAYLOAD, - [Species.TYMPOLE]: Abilities.POISON_HEAL, - [Species.THROH]: Abilities.STAMINA, - [Species.SAWK]: Abilities.SCRAPPY, - [Species.SEWADDLE]: Abilities.SHARPNESS, - [Species.VENIPEDE]: Abilities.STAMINA, - [Species.COTTONEE]: Abilities.FLUFFY, - [Species.PETILIL]: Abilities.SIMPLE, - [Species.BASCULIN]: Abilities.SUPREME_OVERLORD, - [Species.SANDILE]: Abilities.TOUGH_CLAWS, - [Species.DARUMAKA]: Abilities.GORILLA_TACTICS, - [Species.MARACTUS]: Abilities.WELL_BAKED_BODY, - [Species.DWEBBLE]: Abilities.ROCKY_PAYLOAD, - [Species.SCRAGGY]: Abilities.PROTEAN, - [Species.SIGILYPH]: Abilities.FLARE_BOOST, - [Species.YAMASK]: Abilities.PURIFYING_SALT, - [Species.TIRTOUGA]: Abilities.WATER_ABSORB, - [Species.ARCHEN]: Abilities.MULTISCALE, - [Species.TRUBBISH]: Abilities.NEUTRALIZING_GAS, - [Species.ZORUA]: Abilities.DARK_AURA, - [Species.MINCCINO]: Abilities.FUR_COAT, - [Species.GOTHITA]: Abilities.UNNERVE, - [Species.SOLOSIS]: Abilities.PSYCHIC_SURGE, - [Species.DUCKLETT]: Abilities.DRIZZLE, - [Species.VANILLITE]: Abilities.SLUSH_RUSH, - [Species.DEERLING]: Abilities.FUR_COAT, - [Species.EMOLGA]: Abilities.TRANSISTOR, - [Species.KARRABLAST]: Abilities.QUICK_DRAW, - [Species.FOONGUS]: Abilities.THICK_FAT, - [Species.FRILLISH]: Abilities.UNAWARE, - [Species.ALOMOMOLA]: Abilities.MULTISCALE, - [Species.JOLTIK]: Abilities.TRANSISTOR, - [Species.FERROSEED]: Abilities.ROUGH_SKIN, - [Species.KLINK]: Abilities.STEELY_SPIRIT, - [Species.TYNAMO]: Abilities.POISON_HEAL, - [Species.ELGYEM]: Abilities.PRISM_ARMOR, - [Species.LITWICK]: Abilities.SOUL_HEART, - [Species.AXEW]: Abilities.DRAGONS_MAW, - [Species.CUBCHOO]: Abilities.TOUGH_CLAWS, - [Species.CRYOGONAL]: Abilities.SNOW_WARNING, - [Species.SHELMET]: Abilities.PROTEAN, - [Species.STUNFISK]: Abilities.STORM_DRAIN, - [Species.MIENFOO]: Abilities.NO_GUARD, - [Species.DRUDDIGON]: Abilities.INTIMIDATE, - [Species.GOLETT]: Abilities.SHADOW_SHIELD, - [Species.PAWNIARD]: Abilities.SWORD_OF_RUIN, - [Species.BOUFFALANT]: Abilities.ROCK_HEAD, - [Species.RUFFLET]: Abilities.SPEED_BOOST, - [Species.VULLABY]: Abilities.THICK_FAT, - [Species.HEATMOR]: Abilities.CONTRARY, - [Species.DURANT]: Abilities.COMPOUND_EYES, - [Species.DEINO]: Abilities.PARENTAL_BOND, - [Species.LARVESTA]: Abilities.DROUGHT, - [Species.COBALION]: Abilities.INTREPID_SWORD, - [Species.TERRAKION]: Abilities.ROCKY_PAYLOAD, - [Species.VIRIZION]: Abilities.SHARPNESS, - [Species.TORNADUS]: Abilities.DRIZZLE, - [Species.THUNDURUS]: Abilities.DRIZZLE, - [Species.RESHIRAM]: Abilities.ORICHALCUM_PULSE, - [Species.ZEKROM]: Abilities.HADRON_ENGINE, - [Species.LANDORUS]: Abilities.STORM_DRAIN, - [Species.KYUREM]: Abilities.SNOW_WARNING, - [Species.KELDEO]: Abilities.GRIM_NEIGH, - [Species.MELOETTA]: Abilities.MINDS_EYE, - [Species.GENESECT]: Abilities.PROTEAN, - [Species.CHESPIN]: Abilities.DAUNTLESS_SHIELD, - [Species.FENNEKIN]: Abilities.PSYCHIC_SURGE, - [Species.FROAKIE]: Abilities.STAKEOUT, - [Species.BUNNELBY]: Abilities.GUTS, - [Species.FLETCHLING]: Abilities.MAGIC_GUARD, - [Species.SCATTERBUG]: Abilities.PRANKSTER, - [Species.LITLEO]: Abilities.BEAST_BOOST, - [Species.FLABEBE]: Abilities.GRASSY_SURGE, - [Species.SKIDDO]: Abilities.SEED_SOWER, - [Species.PANCHAM]: Abilities.FUR_COAT, - [Species.FURFROU]: Abilities.FLUFFY, - [Species.ESPURR]: Abilities.FUR_COAT, - [Species.HONEDGE]: Abilities.SHARPNESS, - [Species.SPRITZEE]: Abilities.FUR_COAT, - [Species.SWIRLIX]: Abilities.WELL_BAKED_BODY, - [Species.INKAY]: Abilities.UNNERVE, - [Species.BINACLE]: Abilities.SAP_SIPPER, - [Species.SKRELP]: Abilities.DRAGONS_MAW, - [Species.CLAUNCHER]: Abilities.SWIFT_SWIM, - [Species.HELIOPTILE]: Abilities.PROTEAN, - [Species.TYRUNT]: Abilities.RECKLESS, - [Species.AMAURA]: Abilities.ICE_SCALES, - [Species.HAWLUCHA]: Abilities.MOXIE, - [Species.DEDENNE]: Abilities.PIXILATE, - [Species.CARBINK]: Abilities.SOLID_ROCK, - [Species.GOOMY]: Abilities.REGENERATOR, - [Species.KLEFKI]: Abilities.LEVITATE, - [Species.PHANTUMP]: Abilities.SHADOW_TAG, - [Species.PUMPKABOO]: Abilities.WELL_BAKED_BODY, - [Species.BERGMITE]: Abilities.ICE_SCALES, - [Species.NOIBAT]: Abilities.PUNK_ROCK, - [Species.XERNEAS]: Abilities.HARVEST, - [Species.YVELTAL]: Abilities.SOUL_HEART, - [Species.ZYGARDE]: Abilities.HUGE_POWER, - [Species.DIANCIE]: Abilities.LEVITATE, - [Species.HOOPA]: Abilities.OPPORTUNIST, - [Species.VOLCANION]: Abilities.FILTER, - [Species.ROWLET]: Abilities.SNIPER, - [Species.LITTEN]: Abilities.FUR_COAT, - [Species.POPPLIO]: Abilities.PUNK_ROCK, - [Species.PIKIPEK]: Abilities.TECHNICIAN, - [Species.YUNGOOS]: Abilities.TOUGH_CLAWS, - [Species.GRUBBIN]: Abilities.SPEED_BOOST, - [Species.CRABRAWLER]: Abilities.WATER_BUBBLE, - [Species.ORICORIO]: Abilities.ADAPTABILITY, - [Species.CUTIEFLY]: Abilities.TINTED_LENS, - [Species.ROCKRUFF]: Abilities.ROCKY_PAYLOAD, - [Species.WISHIWASHI]: Abilities.REGENERATOR, - [Species.MAREANIE]: Abilities.TOXIC_DEBRIS, - [Species.MUDBRAY]: Abilities.CUD_CHEW, - [Species.DEWPIDER]: Abilities.TINTED_LENS, - [Species.FOMANTIS]: Abilities.SHARPNESS, - [Species.MORELULL]: Abilities.TRIAGE, - [Species.SALANDIT]: Abilities.DRAGONS_MAW, - [Species.STUFFUL]: Abilities.SCRAPPY, - [Species.BOUNSWEET]: Abilities.MOXIE, - [Species.COMFEY]: Abilities.FRIEND_GUARD, - [Species.ORANGURU]: Abilities.POWER_SPOT, - [Species.PASSIMIAN]: Abilities.LIBERO, - [Species.WIMPOD]: Abilities.REGENERATOR, - [Species.SANDYGAST]: Abilities.SAND_SPIT, - [Species.PYUKUMUKU]: Abilities.PURIFYING_SALT, - [Species.TYPE_NULL]: Abilities.ADAPTABILITY, - [Species.MINIOR]: Abilities.STURDY, - [Species.KOMALA]: Abilities.GUTS, - [Species.TURTONATOR]: Abilities.DAUNTLESS_SHIELD, - [Species.TOGEDEMARU]: Abilities.ROUGH_SKIN, - [Species.MIMIKYU]: Abilities.TOUGH_CLAWS, - [Species.BRUXISH]: Abilities.MULTISCALE, - [Species.DRAMPA]: Abilities.THICK_FAT, - [Species.DHELMISE]: Abilities.WATER_BUBBLE, - [Species.JANGMO_O]: Abilities.DAUNTLESS_SHIELD, - [Species.TAPU_KOKO]: Abilities.TRANSISTOR, - [Species.TAPU_LELE]: Abilities.SHEER_FORCE, - [Species.TAPU_BULU]: Abilities.TRIAGE, - [Species.TAPU_FINI]: Abilities.FAIRY_AURA, - [Species.COSMOG]: Abilities.BEAST_BOOST, - [Species.NIHILEGO]: Abilities.LEVITATE, - [Species.BUZZWOLE]: Abilities.MOXIE, - [Species.PHEROMOSA]: Abilities.TINTED_LENS, - [Species.XURKITREE]: Abilities.TRANSISTOR, - [Species.CELESTEELA]: Abilities.HEATPROOF, - [Species.KARTANA]: Abilities.SHARPNESS, - [Species.GUZZLORD]: Abilities.POISON_HEAL, - [Species.NECROZMA]: Abilities.BEAST_BOOST, - [Species.MAGEARNA]: Abilities.STEELY_SPIRIT, - [Species.MARSHADOW]: Abilities.IRON_FIST, - [Species.POIPOLE]: Abilities.SHEER_FORCE, - [Species.STAKATAKA]: Abilities.SOLID_ROCK, - [Species.BLACEPHALON]: Abilities.MAGIC_GUARD, - [Species.ZERAORA]: Abilities.TOUGH_CLAWS, - [Species.MELTAN]: Abilities.STEELY_SPIRIT, - [Species.GROOKEY]: Abilities.GRASS_PELT, - [Species.SCORBUNNY]: Abilities.NO_GUARD, - [Species.SOBBLE]: Abilities.SUPER_LUCK, - [Species.SKWOVET]: Abilities.HARVEST, - [Species.ROOKIDEE]: Abilities.IRON_BARBS, - [Species.BLIPBUG]: Abilities.PSYCHIC_SURGE, - [Species.NICKIT]: Abilities.MAGICIAN, - [Species.GOSSIFLEUR]: Abilities.GRASSY_SURGE, - [Species.WOOLOO]: Abilities.SIMPLE, - [Species.CHEWTLE]: Abilities.ROCKY_PAYLOAD, - [Species.YAMPER]: Abilities.SHEER_FORCE, - [Species.ROLYCOLY]: Abilities.SOLID_ROCK, - [Species.APPLIN]: Abilities.DRAGONS_MAW, - [Species.SILICOBRA]: Abilities.SAND_RUSH, - [Species.CRAMORANT]: Abilities.LIGHTNING_ROD, - [Species.ARROKUDA]: Abilities.INTIMIDATE, - [Species.TOXEL]: Abilities.ELECTRIC_SURGE, - [Species.SIZZLIPEDE]: Abilities.SPEED_BOOST, - [Species.CLOBBOPUS]: Abilities.WATER_BUBBLE, - [Species.SINISTEA]: Abilities.SHADOW_SHIELD, - [Species.HATENNA]: Abilities.FAIRY_AURA, - [Species.IMPIDIMP]: Abilities.FUR_COAT, - [Species.MILCERY]: Abilities.REGENERATOR, - [Species.FALINKS]: Abilities.PARENTAL_BOND, - [Species.PINCURCHIN]: Abilities.ELECTROMORPHOSIS, - [Species.SNOM]: Abilities.SNOW_WARNING, - [Species.STONJOURNER]: Abilities.STURDY, - [Species.EISCUE]: Abilities.ICE_SCALES, - [Species.INDEEDEE]: Abilities.FRIEND_GUARD, - [Species.MORPEKO]: Abilities.MOODY, - [Species.CUFANT]: Abilities.EARTH_EATER, - [Species.DRACOZOLT]: Abilities.NO_GUARD, - [Species.ARCTOZOLT]: Abilities.TRANSISTOR, - [Species.DRACOVISH]: Abilities.SWIFT_SWIM, - [Species.ARCTOVISH]: Abilities.STRONG_JAW, - [Species.DURALUDON]: Abilities.STEELWORKER, - [Species.DREEPY]: Abilities.PARENTAL_BOND, - [Species.ZACIAN]: Abilities.UNNERVE, - [Species.ZAMAZENTA]: Abilities.STAMINA, - [Species.ETERNATUS]: Abilities.NEUTRALIZING_GAS, - [Species.KUBFU]: Abilities.IRON_FIST, - [Species.ZARUDE]: Abilities.TOUGH_CLAWS, - [Species.REGIELEKI]: Abilities.ELECTRIC_SURGE, - [Species.REGIDRAGO]: Abilities.MULTISCALE, - [Species.GLASTRIER]: Abilities.FILTER, - [Species.SPECTRIER]: Abilities.SHADOW_SHIELD, - [Species.CALYREX]: Abilities.HARVEST, - [Species.ENAMORUS]: Abilities.FAIRY_AURA, - [Species.SPRIGATITO]: Abilities.MAGICIAN, - [Species.FUECOCO]: Abilities.PUNK_ROCK, - [Species.QUAXLY]: Abilities.OPPORTUNIST, - [Species.LECHONK]: Abilities.SIMPLE, - [Species.TAROUNTULA]: Abilities.HONEY_GATHER, - [Species.NYMBLE]: Abilities.GUTS, - [Species.PAWMI]: Abilities.TRANSISTOR, - [Species.TANDEMAUS]: Abilities.SCRAPPY, - [Species.FIDOUGH]: Abilities.WATER_ABSORB, - [Species.SMOLIV]: Abilities.RIPEN, - [Species.SQUAWKABILLY]: Abilities.MOXIE, - [Species.NACLI]: Abilities.SOLID_ROCK, - [Species.CHARCADET]: Abilities.PRISM_ARMOR, - [Species.TADBULB]: Abilities.STAMINA, - [Species.WATTREL]: Abilities.SHEER_FORCE, - [Species.MASCHIFF]: Abilities.STRONG_JAW, - [Species.SHROODLE]: Abilities.CORROSION, - [Species.BRAMBLIN]: Abilities.SHADOW_SHIELD, - [Species.TOEDSCOOL]: Abilities.PRANKSTER, - [Species.KLAWF]: Abilities.WATER_ABSORB, - [Species.CAPSAKID]: Abilities.PARENTAL_BOND, - [Species.RELLOR]: Abilities.PRANKSTER, - [Species.FLITTLE]: Abilities.MAGIC_BOUNCE, - [Species.TINKATINK]: Abilities.STEELWORKER, - [Species.WIGLETT]: Abilities.STURDY, - [Species.BOMBIRDIER]: Abilities.UNBURDEN, - [Species.FINIZEN]: Abilities.IRON_FIST, - [Species.VAROOM]: Abilities.LEVITATE, - [Species.CYCLIZAR]: Abilities.PROTEAN, - [Species.ORTHWORM]: Abilities.REGENERATOR, - [Species.GLIMMET]: Abilities.LEVITATE, - [Species.GREAVARD]: Abilities.FUR_COAT, - [Species.FLAMIGO]: Abilities.MOXIE, - [Species.CETODDLE]: Abilities.ICE_SCALES, - [Species.VELUZA]: Abilities.SUPER_LUCK, - [Species.DONDOZO]: Abilities.PARENTAL_BOND, - [Species.TATSUGIRI]: Abilities.ADAPTABILITY, - [Species.GREAT_TUSK]: Abilities.INTIMIDATE, - [Species.SCREAM_TAIL]: Abilities.UNAWARE, - [Species.BRUTE_BONNET]: Abilities.CHLOROPHYLL, - [Species.FLUTTER_MANE]: Abilities.DAZZLING, - [Species.SLITHER_WING]: Abilities.SCRAPPY, - [Species.SANDY_SHOCKS]: Abilities.EARTH_EATER, - [Species.IRON_TREADS]: Abilities.STEELY_SPIRIT, - [Species.IRON_BUNDLE]: Abilities.SNOW_WARNING, - [Species.IRON_HANDS]: Abilities.IRON_FIST, - [Species.IRON_JUGULIS]: Abilities.LIGHTNING_ROD, - [Species.IRON_MOTH]: Abilities.LEVITATE, - [Species.IRON_THORNS]: Abilities.SAND_STREAM, - [Species.FRIGIBAX]: Abilities.SNOW_WARNING, - [Species.GIMMIGHOUL]: Abilities.HONEY_GATHER, - [Species.WO_CHIEN]: Abilities.VESSEL_OF_RUIN, - [Species.CHIEN_PAO]: Abilities.SNOW_WARNING, - [Species.TING_LU]: Abilities.STAMINA, - [Species.CHI_YU]: Abilities.BERSERK, - [Species.ROARING_MOON]: Abilities.TOUGH_CLAWS, - [Species.IRON_VALIANT]: Abilities.ADAPTABILITY, - [Species.KORAIDON]: Abilities.OPPORTUNIST, - [Species.MIRAIDON]: Abilities.OPPORTUNIST, - [Species.WALKING_WAKE]: Abilities.BEAST_BOOST, - [Species.IRON_LEAVES]: Abilities.SHARPNESS, - [Species.POLTCHAGEIST]: Abilities.TRIAGE, - [Species.OKIDOGI]: Abilities.FUR_COAT, - [Species.MUNKIDORI]: Abilities.NEUROFORCE, - [Species.FEZANDIPITI]: Abilities.LEVITATE, - [Species.OGERPON]: Abilities.OPPORTUNIST, - [Species.GOUGING_FIRE]: Abilities.BEAST_BOOST, - [Species.RAGING_BOLT]: Abilities.BEAST_BOOST, - [Species.IRON_BOULDER]: Abilities.SHARPNESS, - [Species.IRON_CROWN]: Abilities.SHARPNESS, - [Species.TERAPAGOS]: Abilities.SOUL_HEART, - [Species.PECHARUNT]: Abilities.TOXIC_CHAIN, - [Species.ALOLA_RATTATA]: Abilities.ADAPTABILITY, - [Species.ALOLA_SANDSHREW]: Abilities.TOUGH_CLAWS, - [Species.ALOLA_VULPIX]: Abilities.SHEER_FORCE, - [Species.ALOLA_DIGLETT]: Abilities.STURDY, - [Species.ALOLA_MEOWTH]: Abilities.DARK_AURA, - [Species.ALOLA_GEODUDE]: Abilities.DRY_SKIN, - [Species.ALOLA_GRIMER]: Abilities.TOXIC_DEBRIS, - [Species.ETERNAL_FLOETTE]: Abilities.MAGIC_GUARD, - [Species.GALAR_MEOWTH]: Abilities.STEELWORKER, - [Species.GALAR_PONYTA]: Abilities.MOXIE, - [Species.GALAR_SLOWPOKE]: Abilities.UNAWARE, - [Species.GALAR_FARFETCHD]: Abilities.INTREPID_SWORD, - [Species.GALAR_ARTICUNO]: Abilities.SERENE_GRACE, - [Species.GALAR_ZAPDOS]: Abilities.TOUGH_CLAWS, - [Species.GALAR_MOLTRES]: Abilities.DARK_AURA, - [Species.GALAR_CORSOLA]: Abilities.SHADOW_SHIELD, - [Species.GALAR_ZIGZAGOON]: Abilities.POISON_HEAL, - [Species.GALAR_DARUMAKA]: Abilities.FLASH_FIRE, - [Species.GALAR_YAMASK]: Abilities.TABLETS_OF_RUIN, - [Species.GALAR_STUNFISK]: Abilities.ARENA_TRAP, - [Species.HISUI_GROWLITHE]: Abilities.RECKLESS, - [Species.HISUI_VOLTORB]: Abilities.TRANSISTOR, - [Species.HISUI_QWILFISH]: Abilities.MERCILESS, - [Species.HISUI_SNEASEL]: Abilities.SCRAPPY, - [Species.HISUI_ZORUA]: Abilities.ADAPTABILITY, - [Species.PALDEA_TAUROS]: Abilities.ADAPTABILITY, - [Species.PALDEA_WOOPER]: Abilities.THICK_FAT, - [Species.BLOODMOON_URSALUNA]: Abilities.BERSERK -}; - // TODO: Remove { //setTimeout(() => { diff --git a/src/data/splash-messages.ts b/src/data/splash-messages.ts index 8e95bba0591..1f00ce0d555 100644 --- a/src/data/splash-messages.ts +++ b/src/data/splash-messages.ts @@ -1,46 +1,227 @@ -import i18next from "i18next"; +import { USE_SEASONAL_SPLASH_MESSAGES } from "#app/constants"; -export function getBattleCountSplashMessage(): string { - return `{COUNT} ${i18next.t("splashMessages:battlesWon")}`; +//#region Interfaces/Types + +type Month = "01" | "02" | "03" | "04" | "05" | "06" | "07" | "08" | "09" | "10" | "11" | "12"; +type Day = + | Month + | "13" + | "14" + | "15" + | "16" + | "17" + | "18" + | "19" + | "20" + | "21" + | "22" + | "23" + | "24" + | "25" + | "26" + | "27" + | "28" + | "29" + | "30" + | "31"; + +/** + * Represents a season with its {@linkcode name}, + * {@linkcode start} day+month, {@linkcode end} day+month + * and {@linkcode messages}. + */ +interface Season { + /** The name of the season (internal use only) */ + name: string; + /** The start day and month of the season. Format `MM-DD` */ + start: `${Month}-${Day}`; + /** The end day and month of the season. Format `MM-DD` */ + end: `${Month}-${Day}`; + /** Collection of the messages to display (without the `i18next.t()` call!) */ + messages: string[]; } +//#region Constants + +/** The weight multiplier for the battles-won splash message */ +const BATTLES_WON_WEIGHT_MULTIPLIER = 10; +/** The weight multiplier for the seasonal splash messages */ +const SEASONAL_WEIGHT_MULTIPLIER = 10; + +//#region Common Messages + +const commonSplashMessages = [ + ...Array(BATTLES_WON_WEIGHT_MULTIPLIER).fill("battlesWon"), + "joinTheDiscord", + "infiniteLevels", + "everythingIsStackable", + "optionalSaveScumming", + "biomes", + "openSource", + "playWithSpeed", + "liveBugTesting", + "heavyInfluence", + "pokemonRiskAndPokemonRain", + "nowWithMoreSalt", + "infiniteFusionAtHome", + "brokenEggMoves", + "magnificent", + "doPeopleReadThis", + "thatsCrazy", + "gottaCatchEmAll", + "questionableBalancing", + "coolShaders", + "aiFree", + "suddenDifficultySpikes", + "basedOnAnUnfinishedFlashGame", + "moreAddictiveThanIntended", + "mostlyConsistentSeeds", + "achievementPointsDontDoAnything", + "nothingBeatsAJellyFilledDonut", + "dontTalkAboutTheTinkatonIncident", + "alsoTryPokengine", + "alsoTryEmeraldRogue", + "alsoTryRadicalRed", + "eeveeExpo", + "checkOutYnoproject", + "breedersInSpace", + "alsoTryPokemonUnbound", + "tryTheJohtoDragonChallenge", + "basicReadingAbilityRecommended", + "shoutoutsToTheArtists", + "gamblingNotEncouraged", + "dontForgetToTakeABreak", + "wEvent", + "ifItsNotAccurateItsAccurate", + "everyLossIsProgressMade", + "liveWoChienReaction", + "itsAFeatureNotABug", + "theEggsAreNotForEating", + "7.8outOf10TooManyWaterBiomes", + "butNothingHappened", + "thePowerOfScienceIsAmazing", + "freeToPlay", + "theresATimeAndPlaceForEverything", + "nowWithShinierShinies", + "smilesGoForMiles", + "certainlyNotDragonFree", + "haveANiceDay", + "redacted", + "hi", + "transRights", + "shinyOddsHigherThanYouThink", + "noFalseTrades", + "notForProfit", + "timeForYourDailyRun", + "moreEggsThanADaycare", + "disclaimerHarshSunDoesNotGiveVitaminD", + "whoNeedsAMap", + "luxrayIsNotADarkType", + "selfDestructiveEncounters", + "mostOptionsAreViable", + "pokerogueMorse", + "smiley", + "beAwareOfPassives", + "asSeenOnTheWorldWideWeb", + "vaultinVeluzas", + "tooManyStarters", + "checkTheWiki", + "winWithYourFavorites", + "alsoTryPokerogueWait", + "theWayISeeItKyogreIsSurrounded", + "tryOutHoneyGather", + "notForTheFaintOfHeart", + "p", + "flipYourDeviceToEvolveInkay", + "inArceusWeTrust", + "whyDidTheTorchicCrossTheRoad", + "goodLuck", + "fuseWisely", + "compensation", + "prepareForTroubleAndMakeItDouble", + "anEggForYourTroubles", + "regirock", + "hereForAGoodTime", + "getGoodOrDont", + "checkTheSubreddit", + "betterNerfGreninja", + "inCaseOfUpdateClearYourCache", + "insertTextHere", + "endingEndlessNotFound", + "iLikeMyEggsVouchered", + "YOU", + "noAddedSugar", + "notSponsored", + "notRated", + "justOneMoreWaveMom", + "saltCured", + "onlyOnPokerogueNet", + "pixelPerfection", + "openSource", + "probablyGood", + "itsAMonsterHouse", + "dontForgetYourPassword", + "tripleTripleTripleAxel", + "questionExclamation", + "clownEncounters", + "fullOfBerries", + "limitsAreMeantToBeBrokenSometimes", + "keepItCasual", + "serversProbablyWorking", + "mew", + "makeItRainAndYourProblemsGoAway", + "customMusicTracks", + "youAreValid", + "number591IsLookingOff", + "timeForYourDeliDelivery", + "goodFirstImpression", + "iPreferRarerCandies", +]; + +//#region Seasonal Messages + +const seasonalSplashMessages: Season[] = [ + { + name: "Halloween", + start: "09-15", + end: "10-31", + messages: [ "halloween.pumpkabooAbout", "halloween.mayContainSpiders", "halloween.spookyScarySkeledirge", "halloween.gourgeistUsedTrickOrTreat", "halloween.letsSnuggleForever" ], + }, + { + name: "XMAS", + start: "12-01", + end: "12-26", + messages: [ "xmas.happyHolidays", "xmas.unaffilicatedWithDelibirdServices", "xmas.delibirdSeason", "xmas.diamondsFromTheSky", "xmas.holidayStylePikachuNotIncluded" ], + }, + { + name: "New Year's", + start: "01-01", + end: "01-31", + messages: [ "newYears.happyNewYear" ], + }, +]; + +//#endregion + export function getSplashMessages(): string[] { - const splashMessages = Array(10).fill(getBattleCountSplashMessage()); - splashMessages.push( - i18next.t("splashMessages:joinTheDiscord"), - i18next.t("splashMessages:infiniteLevels"), - i18next.t("splashMessages:everythingStacks"), - i18next.t("splashMessages:optionalSaveScumming"), - i18next.t("splashMessages:biomes"), - i18next.t("splashMessages:openSource"), - i18next.t("splashMessages:playWithSpeed"), - i18next.t("splashMessages:liveBugTesting"), - i18next.t("splashMessages:heavyInfluence"), - i18next.t("splashMessages:pokemonRiskAndPokemonRain"), - i18next.t("splashMessages:nowWithMoreSalt"), - i18next.t("splashMessages:infiniteFusionAtHome"), - i18next.t("splashMessages:brokenEggMoves"), - i18next.t("splashMessages:magnificent"), - i18next.t("splashMessages:mubstitute"), - i18next.t("splashMessages:thatsCrazy"), - i18next.t("splashMessages:oranceJuice"), - i18next.t("splashMessages:questionableBalancing"), - i18next.t("splashMessages:coolShaders"), - i18next.t("splashMessages:aiFree"), - i18next.t("splashMessages:suddenDifficultySpikes"), - i18next.t("splashMessages:basedOnAnUnfinishedFlashGame"), - i18next.t("splashMessages:moreAddictiveThanIntended"), - i18next.t("splashMessages:mostlyConsistentSeeds"), - i18next.t("splashMessages:achievementPointsDontDoAnything"), - i18next.t("splashMessages:youDoNotStartAtLevel"), - i18next.t("splashMessages:dontTalkAboutTheManaphyEggIncident"), - i18next.t("splashMessages:alsoTryPokengine"), - i18next.t("splashMessages:alsoTryEmeraldRogue"), - i18next.t("splashMessages:alsoTryRadicalRed"), - i18next.t("splashMessages:eeveeExpo"), - i18next.t("splashMessages:ynoproject"), - i18next.t("splashMessages:breedersInSpace"), - ); + const splashMessages: string[] = [ ...commonSplashMessages ]; + console.log("use seasonal splash messages", USE_SEASONAL_SPLASH_MESSAGES); + if (USE_SEASONAL_SPLASH_MESSAGES) { + // add seasonal splash messages if the season is active + for (const { name, start, end, messages } of seasonalSplashMessages) { + const now = new Date(); + const startDate = new Date(`${start}-${now.getFullYear()}`); + const endDate = new Date(`${end}-${now.getFullYear()}`); - return splashMessages; + if (now >= startDate && now <= endDate) { + console.log(`Adding ${messages.length} ${name} splash messages (weight: x${SEASONAL_WEIGHT_MULTIPLIER})`); + messages.forEach((message) => { + const weightedMessage = Array(SEASONAL_WEIGHT_MULTIPLIER).fill(message); + splashMessages.push(...weightedMessage); + }); + } + } + } + + return splashMessages.map((message) => `splashMessages:${message}`); } diff --git a/src/data/status-effect.ts b/src/data/status-effect.ts index 4381db5c2c6..6b4e1d546df 100644 --- a/src/data/status-effect.ts +++ b/src/data/status-effect.ts @@ -1,22 +1,24 @@ -import * as Utils from "../utils"; +import { randIntRange } from "#app/utils"; import { StatusEffect } from "#enums/status-effect"; import i18next, { ParseKeys } from "i18next"; -export { StatusEffect }; - export class Status { public effect: StatusEffect; - public turnCount: integer; - public cureTurn: integer | null; + /** Toxic damage is `1/16 max HP * toxicTurnCount` */ + public toxicTurnCount: number = 0; + public sleepTurnsRemaining?: number; - constructor(effect: StatusEffect, turnCount: integer = 0, cureTurn?: integer) { + constructor(effect: StatusEffect, toxicTurnCount: number = 0, sleepTurnsRemaining?: number) { this.effect = effect; - this.turnCount = turnCount === undefined ? 0 : turnCount; - this.cureTurn = cureTurn!; // TODO: is this bang correct? + this.toxicTurnCount = toxicTurnCount; + this.sleepTurnsRemaining = sleepTurnsRemaining; } incrementTurn(): void { - this.turnCount++; + this.toxicTurnCount++; + if (this.sleepTurnsRemaining) { + this.sleepTurnsRemaining--; + } } isPostTurn(): boolean { @@ -26,24 +28,28 @@ export class Status { function getStatusEffectMessageKey(statusEffect: StatusEffect | undefined): string { switch (statusEffect) { - case StatusEffect.POISON: - return "statusEffect:poison"; - case StatusEffect.TOXIC: - return "statusEffect:toxic"; - case StatusEffect.PARALYSIS: - return "statusEffect:paralysis"; - case StatusEffect.SLEEP: - return "statusEffect:sleep"; - case StatusEffect.FREEZE: - return "statusEffect:freeze"; - case StatusEffect.BURN: - return "statusEffect:burn"; - default: - return "statusEffect:none"; + case StatusEffect.POISON: + return "statusEffect:poison"; + case StatusEffect.TOXIC: + return "statusEffect:toxic"; + case StatusEffect.PARALYSIS: + return "statusEffect:paralysis"; + case StatusEffect.SLEEP: + return "statusEffect:sleep"; + case StatusEffect.FREEZE: + return "statusEffect:freeze"; + case StatusEffect.BURN: + return "statusEffect:burn"; + default: + return "statusEffect:none"; } } export function getStatusEffectObtainText(statusEffect: StatusEffect | undefined, pokemonNameWithAffix: string, sourceText?: string): string { + if (statusEffect === StatusEffect.NONE) { + return ""; + } + if (!sourceText) { const i18nKey = `${getStatusEffectMessageKey(statusEffect)}.obtain`as ParseKeys; return i18next.t(i18nKey, { pokemonNameWithAffix: pokemonNameWithAffix }); @@ -53,35 +59,47 @@ export function getStatusEffectObtainText(statusEffect: StatusEffect | undefined } export function getStatusEffectActivationText(statusEffect: StatusEffect, pokemonNameWithAffix: string): string { + if (statusEffect === StatusEffect.NONE) { + return ""; + } const i18nKey = `${getStatusEffectMessageKey(statusEffect)}.activation` as ParseKeys; return i18next.t(i18nKey, { pokemonNameWithAffix: pokemonNameWithAffix }); } export function getStatusEffectOverlapText(statusEffect: StatusEffect, pokemonNameWithAffix: string): string { + if (statusEffect === StatusEffect.NONE) { + return ""; + } const i18nKey = `${getStatusEffectMessageKey(statusEffect)}.overlap` as ParseKeys; return i18next.t(i18nKey, { pokemonNameWithAffix: pokemonNameWithAffix }); } export function getStatusEffectHealText(statusEffect: StatusEffect, pokemonNameWithAffix: string): string { + if (statusEffect === StatusEffect.NONE) { + return ""; + } const i18nKey = `${getStatusEffectMessageKey(statusEffect)}.heal` as ParseKeys; return i18next.t(i18nKey, { pokemonNameWithAffix: pokemonNameWithAffix }); } export function getStatusEffectDescriptor(statusEffect: StatusEffect): string { + if (statusEffect === StatusEffect.NONE) { + return ""; + } const i18nKey = `${getStatusEffectMessageKey(statusEffect)}.description` as ParseKeys; return i18next.t(i18nKey); } export function getStatusEffectCatchRateMultiplier(statusEffect: StatusEffect): number { switch (statusEffect) { - case StatusEffect.POISON: - case StatusEffect.TOXIC: - case StatusEffect.PARALYSIS: - case StatusEffect.BURN: - return 1.5; - case StatusEffect.SLEEP: - case StatusEffect.FREEZE: - return 2.5; + case StatusEffect.POISON: + case StatusEffect.TOXIC: + case StatusEffect.PARALYSIS: + case StatusEffect.BURN: + return 1.5; + case StatusEffect.SLEEP: + case StatusEffect.FREEZE: + return 2.5; } return 1; @@ -91,7 +109,7 @@ export function getStatusEffectCatchRateMultiplier(statusEffect: StatusEffect): * Returns a random non-volatile StatusEffect */ export function generateRandomStatusEffect(): StatusEffect { - return Utils.randIntRange(1, 6); + return randIntRange(1, 6); } /** @@ -107,7 +125,7 @@ export function getRandomStatusEffect(statusEffectA: StatusEffect, statusEffectB return statusEffectA; } - return Utils.randIntRange(0, 2) ? statusEffectA : statusEffectB; + return randIntRange(0, 2) ? statusEffectA : statusEffectB; } /** @@ -124,7 +142,7 @@ export function getRandomStatus(statusA: Status | null, statusB: Status | null): } - return Utils.randIntRange(0, 2) ? statusA : statusB; + return randIntRange(0, 2) ? statusA : statusB; } /** diff --git a/src/data/terrain.ts b/src/data/terrain.ts index 6db68b92239..6ba9acfd166 100644 --- a/src/data/terrain.ts +++ b/src/data/terrain.ts @@ -1,8 +1,6 @@ import Pokemon from "../field/pokemon"; import Move from "./move"; -import { Type } from "./type"; -import * as Utils from "../utils"; -import { ChangeMovePriorityAbAttr, applyAbAttrs } from "./ability"; +import { Type } from "#enums/type"; import { ProtectAttr } from "./move"; import { BattlerIndex } from "#app/battle"; import i18next from "i18next"; @@ -34,21 +32,21 @@ export class Terrain { getAttackTypeMultiplier(attackType: Type): number { switch (this.terrainType) { - case TerrainType.ELECTRIC: - if (attackType === Type.ELECTRIC) { - return 1.3; - } - break; - case TerrainType.GRASSY: - if (attackType === Type.GRASS) { - return 1.3; - } - break; - case TerrainType.PSYCHIC: - if (attackType === Type.PSYCHIC) { - return 1.3; - } - break; + case TerrainType.ELECTRIC: + if (attackType === Type.ELECTRIC) { + return 1.3; + } + break; + case TerrainType.GRASSY: + if (attackType === Type.GRASS) { + return 1.3; + } + break; + case TerrainType.PSYCHIC: + if (attackType === Type.PSYCHIC) { + return 1.3; + } + break; } return 1; @@ -56,13 +54,11 @@ export class Terrain { isMoveTerrainCancelled(user: Pokemon, targets: BattlerIndex[], move: Move): boolean { switch (this.terrainType) { - case TerrainType.PSYCHIC: - if (!move.hasAttr(ProtectAttr)) { - const priority = new Utils.IntegerHolder(move.priority); - applyAbAttrs(ChangeMovePriorityAbAttr, user, null, false, move, priority); - // Cancels move if the move has positive priority and targets a Pokemon grounded on the Psychic Terrain - return priority.value > 0 && user.getOpponents().some(o => targets.includes(o.getBattlerIndex()) && o.isGrounded()); - } + case TerrainType.PSYCHIC: + if (!move.hasAttr(ProtectAttr)) { + // Cancels move if the move has positive priority and targets a Pokemon grounded on the Psychic Terrain + return move.getPriority(user) > 0 && user.getOpponents().some(o => targets.includes(o.getBattlerIndex()) && o.isGrounded()); + } } return false; @@ -71,14 +67,14 @@ export class Terrain { export function getTerrainName(terrainType: TerrainType): string { switch (terrainType) { - case TerrainType.MISTY: - return i18next.t("terrain:misty"); - case TerrainType.ELECTRIC: - return i18next.t("terrain:electric"); - case TerrainType.GRASSY: - return i18next.t("terrain:grassy"); - case TerrainType.PSYCHIC: - return i18next.t("terrain:psychic"); + case TerrainType.MISTY: + return i18next.t("terrain:misty"); + case TerrainType.ELECTRIC: + return i18next.t("terrain:electric"); + case TerrainType.GRASSY: + return i18next.t("terrain:grassy"); + case TerrainType.PSYCHIC: + return i18next.t("terrain:psychic"); } return ""; @@ -87,14 +83,14 @@ export function getTerrainName(terrainType: TerrainType): string { export function getTerrainColor(terrainType: TerrainType): [ integer, integer, integer ] { switch (terrainType) { - case TerrainType.MISTY: - return [ 232, 136, 200 ]; - case TerrainType.ELECTRIC: - return [ 248, 248, 120 ]; - case TerrainType.GRASSY: - return [ 120, 200, 80 ]; - case TerrainType.PSYCHIC: - return [ 160, 64, 160 ]; + case TerrainType.MISTY: + return [ 232, 136, 200 ]; + case TerrainType.ELECTRIC: + return [ 248, 248, 120 ]; + case TerrainType.GRASSY: + return [ 120, 200, 80 ]; + case TerrainType.PSYCHIC: + return [ 160, 64, 160 ]; } return [ 0, 0, 0 ]; diff --git a/src/data/trainer-config.ts b/src/data/trainer-config.ts index 8b96e3cefb8..5e5f38bd00d 100644 --- a/src/data/trainer-config.ts +++ b/src/data/trainer-config.ts @@ -1,22 +1,27 @@ -import BattleScene, { startingWave } from "../battle-scene"; -import { ModifierTypeFunc, modifierTypes } from "../modifier/modifier-type"; -import { EnemyPokemon } from "../field/pokemon"; -import * as Utils from "../utils"; -import { PokeballType } from "./pokeball"; -import { pokemonEvolutions, pokemonPrevolutions } from "./pokemon-evolutions"; -import PokemonSpecies, { getPokemonSpecies, PokemonSpeciesFilter } from "./pokemon-species"; -import { tmSpecies } from "./tms"; -import { Type } from "./type"; -import { doubleBattleDialogue } from "./dialogue"; -import { PersistentModifier } from "../modifier/modifier"; -import { TrainerVariant } from "../field/trainer"; +import BattleScene, { startingWave } from "#app/battle-scene"; +import { ModifierTypeFunc, modifierTypes } from "#app/modifier/modifier-type"; +import { EnemyPokemon, PokemonMove } from "#app/field/pokemon"; +import * as Utils from "#app/utils"; +import { PokeballType } from "#enums/pokeball"; +import { pokemonEvolutions, pokemonPrevolutions } from "#app/data/balance/pokemon-evolutions"; +import PokemonSpecies, { getPokemonSpecies, PokemonSpeciesFilter } from "#app/data/pokemon-species"; +import { tmSpecies } from "#app/data/balance/tms"; +import { Type } from "#enums/type"; +import { doubleBattleDialogue } from "#app/data/dialogue"; +import { PersistentModifier } from "#app/modifier/modifier"; +import { TrainerVariant } from "#app/field/trainer"; import { getIsInitialized, initI18n } from "#app/plugins/i18n"; import i18next from "i18next"; -import {Moves} from "#enums/moves"; -import {PartyMemberStrength} from "#enums/party-member-strength"; -import {Species} from "#enums/species"; -import {TrainerType} from "#enums/trainer-type"; -import {Gender} from "./gender"; +import { Moves } from "#enums/moves"; +import { PartyMemberStrength } from "#enums/party-member-strength"; +import { Species } from "#enums/species"; +import { TrainerType } from "#enums/trainer-type"; +import { Gender } from "#app/data/gender"; + +/** Minimum BST for Pokemon generated onto the Elite Four's teams */ +const ELITE_FOUR_MINIMUM_BST = 460; +/** Minimum BST for Pokemon generated onto the E4 Champion's team */ +const CHAMPION_MINIMUM_BST = 508; export enum TrainerPoolTier { COMMON, @@ -198,6 +203,7 @@ export class TrainerConfig { public modifierRewardFuncs: ModifierTypeFunc[] = []; public partyTemplates: TrainerPartyTemplate[]; public partyTemplateFunc: PartyTemplateFunc; + public eventRewardFuncs: ModifierTypeFunc[] = []; public partyMemberFuncs: PartyMemberFuncs = {}; public speciesPools: TrainerTierPools; public speciesFilter: PokemonSpeciesFilter; @@ -222,7 +228,7 @@ export class TrainerConfig { this.battleBgm = "battle_trainer"; this.mixedBattleBgm = "battle_trainer"; this.victoryBgm = "victory_trainer"; - this.partyTemplates = [trainerPartyTemplates.TWO_AVG]; + this.partyTemplates = [ trainerPartyTemplates.TWO_AVG ]; this.speciesFilter = species => (allowLegendaries || (!species.legendary && !species.subLegendary && !species.mythical)) && !species.isTrainerForbidden(); } @@ -294,62 +300,65 @@ export class TrainerConfig { getDerivedType(trainerTypeToDeriveFrom: TrainerType | null = null): TrainerType { let trainerType = trainerTypeToDeriveFrom ? trainerTypeToDeriveFrom : this.trainerType; switch (trainerType) { - case TrainerType.RIVAL_2: - case TrainerType.RIVAL_3: - case TrainerType.RIVAL_4: - case TrainerType.RIVAL_5: - case TrainerType.RIVAL_6: - trainerType = TrainerType.RIVAL; - break; - case TrainerType.LANCE_CHAMPION: - trainerType = TrainerType.LANCE; - break; - case TrainerType.LARRY_ELITE: - trainerType = TrainerType.LARRY; - break; - case TrainerType.ROCKET_BOSS_GIOVANNI_1: - case TrainerType.ROCKET_BOSS_GIOVANNI_2: - trainerType = TrainerType.GIOVANNI; - break; - case TrainerType.MAXIE_2: - trainerType = TrainerType.MAXIE; - break; - case TrainerType.ARCHIE_2: - trainerType = TrainerType.ARCHIE; - break; - case TrainerType.CYRUS_2: - trainerType = TrainerType.CYRUS; - break; - case TrainerType.GHETSIS_2: - trainerType = TrainerType.GHETSIS; - break; - case TrainerType.LYSANDRE_2: - trainerType = TrainerType.LYSANDRE; - break; - case TrainerType.LUSAMINE_2: - trainerType = TrainerType.LUSAMINE; - break; - case TrainerType.GUZMA_2: - trainerType = TrainerType.GUZMA; - break; - case TrainerType.ROSE_2: - trainerType = TrainerType.ROSE; - break; - case TrainerType.MARNIE_ELITE: - trainerType = TrainerType.MARNIE; - break; - case TrainerType.NESSA_ELITE: - trainerType = TrainerType.NESSA; - break; - case TrainerType.BEA_ELITE: - trainerType = TrainerType.BEA; - break; - case TrainerType.ALLISTER_ELITE: - trainerType = TrainerType.ALLISTER; - break; - case TrainerType.RAIHAN_ELITE: - trainerType = TrainerType.RAIHAN; - break; + case TrainerType.RIVAL_2: + case TrainerType.RIVAL_3: + case TrainerType.RIVAL_4: + case TrainerType.RIVAL_5: + case TrainerType.RIVAL_6: + trainerType = TrainerType.RIVAL; + break; + case TrainerType.LANCE_CHAMPION: + trainerType = TrainerType.LANCE; + break; + case TrainerType.LARRY_ELITE: + trainerType = TrainerType.LARRY; + break; + case TrainerType.ROCKET_BOSS_GIOVANNI_1: + case TrainerType.ROCKET_BOSS_GIOVANNI_2: + trainerType = TrainerType.GIOVANNI; + break; + case TrainerType.MAXIE_2: + trainerType = TrainerType.MAXIE; + break; + case TrainerType.ARCHIE_2: + trainerType = TrainerType.ARCHIE; + break; + case TrainerType.CYRUS_2: + trainerType = TrainerType.CYRUS; + break; + case TrainerType.GHETSIS_2: + trainerType = TrainerType.GHETSIS; + break; + case TrainerType.LYSANDRE_2: + trainerType = TrainerType.LYSANDRE; + break; + case TrainerType.LUSAMINE_2: + trainerType = TrainerType.LUSAMINE; + break; + case TrainerType.GUZMA_2: + trainerType = TrainerType.GUZMA; + break; + case TrainerType.ROSE_2: + trainerType = TrainerType.ROSE; + break; + case TrainerType.PENNY_2: + trainerType = TrainerType.PENNY; + break; + case TrainerType.MARNIE_ELITE: + trainerType = TrainerType.MARNIE; + break; + case TrainerType.NESSA_ELITE: + trainerType = TrainerType.NESSA; + break; + case TrainerType.BEA_ELITE: + trainerType = TrainerType.BEA; + break; + case TrainerType.ALLISTER_ELITE: + trainerType = TrainerType.ALLISTER; + break; + case TrainerType.RAIHAN_ELITE: + trainerType = TrainerType.RAIHAN; + break; } return trainerType; @@ -518,7 +527,7 @@ export class TrainerConfig { } setSpeciesPools(speciesPools: TrainerTierPools | Species[]): TrainerConfig { - this.speciesPools = (Array.isArray(speciesPools) ? {[TrainerPoolTier.COMMON]: speciesPools} : speciesPools) as unknown as TrainerTierPools; + this.speciesPools = (Array.isArray(speciesPools) ? { [TrainerPoolTier.COMMON]: speciesPools } : speciesPools) as unknown as TrainerTierPools; return this; } @@ -538,6 +547,17 @@ export class TrainerConfig { return this; } + setEventModifierRewardFuncs(...modifierTypeFuncs: (() => ModifierTypeFunc)[]): TrainerConfig { + this.eventRewardFuncs = modifierTypeFuncs.map(func => () => { + const modifierTypeFunc = func(); + const modifierType = modifierTypeFunc(); + modifierType.withIdFromFunc(modifierTypeFunc); + return modifierType; + }); + return this; + } + + setModifierRewardFuncs(...modifierTypeFuncs: (() => ModifierTypeFunc)[]): TrainerConfig { this.modifierRewardFuncs = modifierTypeFuncs.map(func => () => { const modifierTypeFunc = func(); @@ -556,69 +576,104 @@ export class TrainerConfig { speciesPoolPerEvilTeamAdmin(team): TrainerTierPools { team = team.toLowerCase(); switch (team) { - case "rocket": { - return { - [TrainerPoolTier.COMMON]: [Species.RATTATA, Species.KOFFING, Species.EKANS, Species.ZUBAT, Species.MAGIKARP, Species.HOUNDOUR, Species.ONIX, Species.CUBONE, Species.GROWLITHE, Species.MURKROW, Species.GASTLY, Species.EXEGGCUTE, Species.VOLTORB, Species.DROWZEE, Species.VILEPLUME], - [TrainerPoolTier.UNCOMMON]: [Species.PORYGON, Species.MANKEY, Species.MAGNEMITE, Species.ALOLA_SANDSHREW, Species.ALOLA_MEOWTH, Species.ALOLA_GRIMER, Species.ALOLA_GEODUDE, Species.PALDEA_TAUROS, Species.OMANYTE, Species.KABUTO, Species.MAGBY, Species.ELEKID], - [TrainerPoolTier.RARE]: [Species.DRATINI, Species.LARVITAR] - }; - } - case "magma": { - return { - [TrainerPoolTier.COMMON]: [Species.GROWLITHE, Species.SLUGMA, Species.SOLROCK, Species.HIPPOPOTAS, Species.BALTOY, Species.ROLYCOLY, Species.GLIGAR, Species.TORKOAL, Species.HOUNDOUR, Species.MAGBY], - [TrainerPoolTier.UNCOMMON]: [Species.TRAPINCH, Species.SILICOBRA, Species.RHYHORN, Species.ANORITH, Species.LILEEP, Species.HISUI_GROWLITHE, Species.TURTONATOR, Species.ARON, Species.BARBOACH], - [TrainerPoolTier.RARE]: [Species.CAPSAKID, Species.CHARCADET] - }; - } - case "aqua": { - return { - [TrainerPoolTier.COMMON]: [Species.CORPHISH, Species.SPHEAL, Species.CLAMPERL, Species.CHINCHOU, Species.WOOPER, Species.WINGULL, Species.TENTACOOL, Species.AZURILL, Species.LOTAD, Species.WAILMER, Species.REMORAID], - [TrainerPoolTier.UNCOMMON]: [Species.MANTYKE, Species.HISUI_QWILFISH, Species.ARROKUDA, Species.DHELMISE, Species.CLOBBOPUS, Species.FEEBAS, Species.PALDEA_WOOPER, Species.HORSEA, Species.SKRELP], - [TrainerPoolTier.RARE]: [Species.DONDOZO, Species.BASCULEGION] - }; - } - case "galactic": { - return { - [TrainerPoolTier.COMMON]: [Species.BRONZOR, Species.SWINUB, Species.YANMA, Species.LICKITUNG, Species.TANGELA, Species.MAGBY, Species.ELEKID, Species.SKORUPI, Species.ZUBAT, Species.MURKROW, Species.MAGIKARP, Species.VOLTORB], - [TrainerPoolTier.UNCOMMON]: [Species.HISUI_GROWLITHE, Species.HISUI_QWILFISH, Species.SNEASEL, Species.DUSKULL, Species.ROTOM, Species.HISUI_VOLTORB, Species.GLIGAR, Species.ABRA], - [TrainerPoolTier.RARE]: [Species.URSALUNA, Species.HISUI_LILLIGANT, Species.SPIRITOMB, Species.HISUI_SNEASEL] - }; - } - case "plasma": { - return { - [TrainerPoolTier.COMMON]: [Species.YAMASK, Species.ROGGENROLA, Species.JOLTIK, Species.TYMPOLE, Species.FRILLISH, Species.FERROSEED, Species.SANDILE, Species.TIMBURR, Species.DARUMAKA, Species.FOONGUS, Species.CUBCHOO, Species.VANILLITE], - [TrainerPoolTier.UNCOMMON]: [Species.PAWNIARD, Species.VULLABY, Species.ZORUA, Species.DRILBUR, Species.KLINK, Species.TYNAMO, Species.GALAR_DARUMAKA, Species.GOLETT, Species.MIENFOO, Species.DURANT, Species.SIGILYPH], - [TrainerPoolTier.RARE]: [Species.HISUI_ZORUA, Species.AXEW, Species.DEINO, Species.HISUI_BRAVIARY] - }; - } - case "flare": { - return { - [TrainerPoolTier.COMMON]: [Species.FLETCHLING, Species.LITLEO, Species.INKAY, Species.HELIOPTILE, Species.ELECTRIKE, Species.SKORUPI, Species.PURRLOIN, Species.CLAWITZER, Species.PANCHAM, Species.ESPURR, Species.BUNNELBY], - [TrainerPoolTier.UNCOMMON]: [Species.LITWICK, Species.SNEASEL, Species.PUMPKABOO, Species.PHANTUMP, Species.HONEDGE, Species.BINACLE, Species.BERGMITE, Species.HOUNDOUR, Species.SKRELP, Species.SLIGGOO], - [TrainerPoolTier.RARE]: [Species.NOIVERN, Species.HISUI_AVALUGG, Species.HISUI_SLIGGOO] - }; - } - case "aether": { - return { - [TrainerPoolTier.COMMON]: [ Species.BRUXISH, Species.SLOWPOKE, Species.BALTOY, Species.EXEGGCUTE, Species.ABRA, Species.ALOLA_RAICHU, Species.ELGYEM, Species.NATU, Species.BLIPBUG, Species.GIRAFARIG, Species.ORANGURU], - [TrainerPoolTier.UNCOMMON]: [Species.GALAR_SLOWPOKE, Species.MEDITITE, Species.BELDUM, Species.HATENNA, Species.INKAY, Species.RALTS, Species.GALAR_MR_MIME], - [TrainerPoolTier.RARE]: [Species.ARMAROUGE, Species.HISUI_BRAVIARY, Species.PORYGON] - }; - } - case "skull": { - return { - [TrainerPoolTier.COMMON]: [ Species.MAREANIE, Species.ALOLA_GRIMER, Species.GASTLY, Species.ZUBAT, Species.FOMANTIS, Species.VENIPEDE, Species.BUDEW, Species.KOFFING, Species.STUNKY, Species.CROAGUNK, Species.NIDORAN_F], - [TrainerPoolTier.UNCOMMON]: [Species.GALAR_SLOWPOKE, Species.SKORUPI, Species.PALDEA_WOOPER, Species.VULLABY, Species.HISUI_QWILFISH, Species.GLIMMET], - [TrainerPoolTier.RARE]: [Species.SKRELP, Species.HISUI_SNEASEL] - }; - } - case "macro": { - return { - [TrainerPoolTier.COMMON]: [ Species.HATENNA, Species.FEEBAS, Species.BOUNSWEET, Species.SALANDIT, Species.GALAR_PONYTA, Species.GOTHITA, Species.FROSLASS, Species.VULPIX, Species.FRILLISH, Species.ODDISH, Species.SINISTEA], - [TrainerPoolTier.UNCOMMON]: [Species.VULLABY, Species.MAREANIE, Species.ALOLA_VULPIX, Species.TOGEPI, Species.GALAR_CORSOLA, Species.APPLIN], - [TrainerPoolTier.RARE]: [Species.TINKATINK, Species.HISUI_LILLIGANT] - }; - } + case "rocket": { + return { + [TrainerPoolTier.COMMON]: [ Species.RATTATA, Species.KOFFING, Species.EKANS, Species.ZUBAT, Species.MAGIKARP, Species.HOUNDOUR, Species.ONIX, Species.CUBONE, Species.GROWLITHE, Species.MURKROW, Species.GASTLY, Species.EXEGGCUTE, Species.VOLTORB, Species.DROWZEE, Species.VILEPLUME ], + [TrainerPoolTier.UNCOMMON]: [ Species.PORYGON, Species.MANKEY, Species.MAGNEMITE, Species.ALOLA_SANDSHREW, Species.ALOLA_MEOWTH, Species.ALOLA_GRIMER, Species.ALOLA_GEODUDE, Species.PALDEA_TAUROS, Species.OMANYTE, Species.KABUTO, Species.MAGBY, Species.ELEKID ], + [TrainerPoolTier.RARE]: [ Species.DRATINI, Species.LARVITAR ] + }; + } + case "magma": { + return { + [TrainerPoolTier.COMMON]: [ Species.GROWLITHE, Species.SLUGMA, Species.SOLROCK, Species.HIPPOPOTAS, Species.BALTOY, Species.ROLYCOLY, Species.GLIGAR, Species.TORKOAL, Species.HOUNDOUR, Species.MAGBY ], + [TrainerPoolTier.UNCOMMON]: [ Species.TRAPINCH, Species.SILICOBRA, Species.RHYHORN, Species.ANORITH, Species.LILEEP, Species.HISUI_GROWLITHE, Species.TURTONATOR, Species.ARON, Species.TOEDSCOOL ], + [TrainerPoolTier.RARE]: [ Species.CAPSAKID, Species.CHARCADET ] + }; + } + case "aqua": { + return { + [TrainerPoolTier.COMMON]: [ Species.CORPHISH, Species.SPHEAL, Species.CLAMPERL, Species.CHINCHOU, Species.WOOPER, Species.WINGULL, Species.TENTACOOL, Species.AZURILL, Species.LOTAD, Species.WAILMER, Species.REMORAID, Species.BARBOACH ], + [TrainerPoolTier.UNCOMMON]: [ Species.MANTYKE, Species.HISUI_QWILFISH, Species.ARROKUDA, Species.DHELMISE, Species.CLOBBOPUS, Species.FEEBAS, Species.PALDEA_WOOPER, Species.HORSEA, Species.SKRELP ], + [TrainerPoolTier.RARE]: [ Species.DONDOZO, Species.BASCULEGION ] + }; + } + case "galactic": { + return { + [TrainerPoolTier.COMMON]: [ Species.BRONZOR, Species.SWINUB, Species.YANMA, Species.LICKITUNG, Species.TANGELA, Species.MAGBY, Species.ELEKID, Species.SKORUPI, Species.ZUBAT, Species.MURKROW, Species.MAGIKARP, Species.VOLTORB ], + [TrainerPoolTier.UNCOMMON]: [ Species.HISUI_GROWLITHE, Species.HISUI_QWILFISH, Species.SNEASEL, Species.DUSKULL, Species.ROTOM, Species.HISUI_VOLTORB, Species.GLIGAR, Species.ABRA ], + [TrainerPoolTier.RARE]: [ Species.URSALUNA, Species.HISUI_LILLIGANT, Species.SPIRITOMB, Species.HISUI_SNEASEL ] + }; + } + case "plasma": { + return { + [TrainerPoolTier.COMMON]: [ Species.YAMASK, Species.ROGGENROLA, Species.JOLTIK, Species.TYMPOLE, Species.FRILLISH, Species.FERROSEED, Species.SANDILE, Species.TIMBURR, Species.DARUMAKA, Species.FOONGUS, Species.CUBCHOO, Species.VANILLITE ], + [TrainerPoolTier.UNCOMMON]: [ Species.PAWNIARD, Species.VULLABY, Species.ZORUA, Species.DRILBUR, Species.KLINK, Species.TYNAMO, Species.GALAR_DARUMAKA, Species.GOLETT, Species.MIENFOO, Species.DURANT, Species.SIGILYPH ], + [TrainerPoolTier.RARE]: [ Species.HISUI_ZORUA, Species.AXEW, Species.DEINO, Species.HISUI_BRAVIARY ] + }; + } + case "flare": { + return { + [TrainerPoolTier.COMMON]: [ Species.FLETCHLING, Species.LITLEO, Species.INKAY, Species.FOONGUS, Species.HELIOPTILE, Species.ELECTRIKE, Species.SKORUPI, Species.PURRLOIN, Species.CLAWITZER, Species.PANCHAM, Species.ESPURR, Species.BUNNELBY ], + [TrainerPoolTier.UNCOMMON]: [ Species.LITWICK, Species.SNEASEL, Species.PUMPKABOO, Species.PHANTUMP, Species.HONEDGE, Species.BINACLE, Species.HOUNDOUR, Species.SKRELP, Species.SLIGGOO ], + [TrainerPoolTier.RARE]: [ Species.NOIBAT, Species.HISUI_AVALUGG, Species.HISUI_SLIGGOO ] + }; + } + case "aether": { + return { + [TrainerPoolTier.COMMON]: [ Species.BRUXISH, Species.SLOWPOKE, Species.BALTOY, Species.EXEGGCUTE, Species.ABRA, Species.ALOLA_RAICHU, Species.ELGYEM, Species.NATU, Species.BLIPBUG, Species.GIRAFARIG, Species.ORANGURU ], + [TrainerPoolTier.UNCOMMON]: [ Species.GALAR_SLOWPOKE, Species.MEDITITE, Species.BELDUM, Species.HATENNA, Species.INKAY, Species.RALTS, Species.GALAR_MR_MIME ], + [TrainerPoolTier.RARE]: [ Species.ARMAROUGE, Species.HISUI_BRAVIARY, Species.PORYGON ] + }; + } + case "skull": { + return { + [TrainerPoolTier.COMMON]: [ Species.MAREANIE, Species.ALOLA_GRIMER, Species.GASTLY, Species.ZUBAT, Species.FOMANTIS, Species.VENIPEDE, Species.BUDEW, Species.KOFFING, Species.STUNKY, Species.CROAGUNK, Species.NIDORAN_F ], + [TrainerPoolTier.UNCOMMON]: [ Species.GALAR_SLOWPOKE, Species.SKORUPI, Species.PALDEA_WOOPER, Species.VULLABY, Species.HISUI_QWILFISH, Species.GLIMMET ], + [TrainerPoolTier.RARE]: [ Species.SKRELP, Species.HISUI_SNEASEL ] + }; + } + case "macro": { + return { + [TrainerPoolTier.COMMON]: [ Species.HATENNA, Species.FEEBAS, Species.BOUNSWEET, Species.SALANDIT, Species.GALAR_PONYTA, Species.GOTHITA, Species.FROSLASS, Species.VULPIX, Species.FRILLISH, Species.ODDISH, Species.SINISTEA ], + [TrainerPoolTier.UNCOMMON]: [ Species.VULLABY, Species.MAREANIE, Species.ALOLA_VULPIX, Species.TOGEPI, Species.GALAR_CORSOLA, Species.APPLIN ], + [TrainerPoolTier.RARE]: [ Species.TINKATINK, Species.HISUI_LILLIGANT ] + }; + } + case "star_1": { + return { + [TrainerPoolTier.COMMON]: [ Species.MURKROW, Species.SEEDOT, Species.CACNEA, Species.STUNKY, Species.SANDILE, Species.NYMBLE, Species.MASCHIFF, Species.GALAR_ZIGZAGOON ], + [TrainerPoolTier.UNCOMMON]: [ Species.UMBREON, Species.SNEASEL, Species.CORPHISH, Species.ZORUA, Species.INKAY, Species.BOMBIRDIER ], + [TrainerPoolTier.RARE]: [ Species.DEINO, Species.SPRIGATITO ] + }; + } + case "star_2": { + return { + [TrainerPoolTier.COMMON]: [ Species.GROWLITHE, Species.HOUNDOUR, Species.NUMEL, Species.LITWICK, Species.FLETCHLING, Species.LITLEO, Species.ROLYCOLY, Species.CAPSAKID ], + [TrainerPoolTier.UNCOMMON]: [ Species.PONYTA, Species.FLAREON, Species.MAGBY, Species.TORKOAL, Species.SALANDIT, Species.TURTONATOR ], + [TrainerPoolTier.RARE]: [ Species.LARVESTA, Species.FUECOCO ] + }; + } + case "star_3": { + return { + [TrainerPoolTier.COMMON]: [ Species.ZUBAT, Species.GRIMER, Species.STUNKY, Species.FOONGUS, Species.MAREANIE, Species.TOXEL, Species.SHROODLE, Species.PALDEA_WOOPER ], + [TrainerPoolTier.UNCOMMON]: [ Species.GASTLY, Species.SEVIPER, Species.SKRELP, Species.ALOLA_GRIMER, Species.GALAR_SLOWPOKE, Species.HISUI_QWILFISH ], + [TrainerPoolTier.RARE]: [ Species.GLIMMET, Species.BULBASAUR ] + }; + } + case "star_4": { + return { + [TrainerPoolTier.COMMON]: [ Species.CLEFFA, Species.IGGLYBUFF, Species.AZURILL, Species.COTTONEE, Species.FLABEBE, Species.HATENNA, Species.IMPIDIMP, Species.TINKATINK ], + [TrainerPoolTier.UNCOMMON]: [ Species.TOGEPI, Species.GARDEVOIR, Species.SYLVEON, Species.KLEFKI, Species.MIMIKYU, Species.ALOLA_VULPIX ], + [TrainerPoolTier.RARE]: [ Species.GALAR_PONYTA, Species.POPPLIO ] + }; + } + case "star_5": { + return { + [TrainerPoolTier.COMMON]: [ Species.SHROOMISH, Species.MAKUHITA, Species.MEDITITE, Species.CROAGUNK, Species.SCRAGGY, Species.MIENFOO, Species.PAWMI, Species.PALDEA_TAUROS ], + [TrainerPoolTier.UNCOMMON]: [ Species.RIOLU, Species.TIMBURR, Species.HAWLUCHA, Species.PASSIMIAN, Species.FALINKS, Species.FLAMIGO ], + [TrainerPoolTier.RARE]: [ Species.JANGMO_O, Species.QUAXLY ] + }; + } } console.warn(`Evil team admin for ${team} not found. Returning empty species pools.`); @@ -643,7 +698,7 @@ export class TrainerConfig { signatureSpecies.forEach((speciesPool, s) => { if (!Array.isArray(speciesPool)) { - speciesPool = [speciesPool]; + speciesPool = [ speciesPool ]; } this.setPartyMemberFunc(-(s + 1), getRandomPartyMemberFunc(speciesPool)); }); @@ -677,7 +732,7 @@ export class TrainerConfig { signatureSpecies.forEach((speciesPool, s) => { if (!Array.isArray(speciesPool)) { - speciesPool = [speciesPool]; + speciesPool = [ speciesPool ]; } this.setPartyMemberFunc(-(s + 1), getRandomPartyMemberFunc(speciesPool)); }); @@ -716,7 +771,7 @@ export class TrainerConfig { } signatureSpecies.forEach((speciesPool, s) => { if (!Array.isArray(speciesPool)) { - speciesPool = [speciesPool]; + speciesPool = [ speciesPool ]; } this.setPartyMemberFunc(-(s + 1), getRandomPartyMemberFunc(speciesPool)); }); @@ -757,7 +812,7 @@ export class TrainerConfig { signatureSpecies.forEach((speciesPool, s) => { // Ensure speciesPool is an array. if (!Array.isArray(speciesPool)) { - speciesPool = [speciesPool]; + speciesPool = [ speciesPool ]; } // Set a function to get a random party member from the species pool. this.setPartyMemberFunc(-(s + 1), getRandomPartyMemberFunc(speciesPool)); @@ -814,7 +869,7 @@ export class TrainerConfig { signatureSpecies.forEach((speciesPool, s) => { // Ensure speciesPool is an array. if (!Array.isArray(speciesPool)) { - speciesPool = [speciesPool]; + speciesPool = [ speciesPool ]; } // Set a function to get a random party member from the species pool. this.setPartyMemberFunc(-(s + 1), getRandomPartyMemberFunc(speciesPool)); @@ -822,10 +877,10 @@ export class TrainerConfig { // Set species filter and specialty types if provided, otherwise filter by base total. if (specialtyTypes.length) { - this.setSpeciesFilter(p => specialtyTypes.some(t => p.isOfType(t)) && p.baseTotal >= 450); + this.setSpeciesFilter(p => specialtyTypes.some(t => p.isOfType(t)) && p.baseTotal >= ELITE_FOUR_MINIMUM_BST); this.setSpecialtyTypes(...specialtyTypes); } else { - this.setSpeciesFilter(p => p.baseTotal >= 450); + this.setSpeciesFilter(p => p.baseTotal >= ELITE_FOUR_MINIMUM_BST); } // Localize the trainer's name by converting it to lowercase and replacing spaces with underscores. @@ -869,14 +924,13 @@ export class TrainerConfig { signatureSpecies.forEach((speciesPool, s) => { // Ensure speciesPool is an array. if (!Array.isArray(speciesPool)) { - speciesPool = [speciesPool]; + speciesPool = [ speciesPool ]; } // Set a function to get a random party member from the species pool. this.setPartyMemberFunc(-(s + 1), getRandomPartyMemberFunc(speciesPool)); }); - // Set species filter to only include species with a base total of 470 or higher. - this.setSpeciesFilter(p => p.baseTotal >= 470); + this.setSpeciesFilter(p => p.baseTotal >= CHAMPION_MINIMUM_BST); // Localize the trainer's name by converting it to lowercase and replacing spaces with underscores. const nameForCall = this.name.toLowerCase().replace(/\s/g, "_"); @@ -911,7 +965,7 @@ export class TrainerConfig { if (!getIsInitialized()) { initI18n(); } - this.name = i18next.t(`trainerNames:${name.toLowerCase()}`); + this.name = i18next.t(`trainerNames:${name.toLowerCase().replace(/\s/g, "_")}`); return this; } @@ -1105,8 +1159,16 @@ function getGymLeaderPartyTemplate(scene: BattleScene) { return getWavePartyTemplate(scene, trainerPartyTemplates.GYM_LEADER_1, trainerPartyTemplates.GYM_LEADER_2, trainerPartyTemplates.GYM_LEADER_3, trainerPartyTemplates.GYM_LEADER_4, trainerPartyTemplates.GYM_LEADER_5); } -function getRandomPartyMemberFunc(speciesPool: Species[], trainerSlot: TrainerSlot = TrainerSlot.TRAINER, ignoreEvolution: boolean = false, postProcess?: (enemyPokemon: EnemyPokemon) => void): PartyMemberFunc { - return (scene: BattleScene, level: integer, strength: PartyMemberStrength) => { +/** + * Randomly selects one of the `Species` from `speciesPool`, determines its evolution, level, and strength. + * Then adds Pokemon to scene. + * @param speciesPool + * @param trainerSlot + * @param ignoreEvolution + * @param postProcess + */ +export function getRandomPartyMemberFunc(speciesPool: Species[], trainerSlot: TrainerSlot = TrainerSlot.TRAINER, ignoreEvolution: boolean = false, postProcess?: (enemyPokemon: EnemyPokemon) => void) { + return (scene: BattleScene, level: number, strength: PartyMemberStrength) => { let species = Utils.randSeedItem(speciesPool); if (!ignoreEvolution) { species = getPokemonSpecies(species).getTrainerSpeciesForLevel(level, true, strength, scene.currentBattle.waveIndex); @@ -1130,7 +1192,7 @@ function getRandomTeraModifiers(party: EnemyPokemon[], count: integer, types?: T for (let t = 0; t < Math.min(count, party.length); t++) { const randomIndex = Utils.randSeedItem(partyMemberIndexes); partyMemberIndexes.splice(partyMemberIndexes.indexOf(randomIndex), 1); - ret.push(modifierTypes.TERA_SHARD().generateType([], [Utils.randSeedItem(types ? types : party[randomIndex].getTypes())])!.withIdFromFunc(modifierTypes.TERA_SHARD).newModifier(party[randomIndex]) as PersistentModifier); // TODO: is the bang correct? + ret.push(modifierTypes.TERA_SHARD().generateType([], [ Utils.randSeedItem(types ? types : party[randomIndex].getTypes()) ])!.withIdFromFunc(modifierTypes.TERA_SHARD).newModifier(party[randomIndex]) as PersistentModifier); // TODO: is the bang correct? } return ret; } @@ -1145,135 +1207,135 @@ type SignatureSpecies = { * This is in a separate const so it can be accessed from other places and not just the trainerConfigs */ export const signatureSpecies: SignatureSpecies = { - BROCK: [Species.GEODUDE, Species.ONIX], - MISTY: [Species.STARYU, Species.PSYDUCK], - LT_SURGE: [Species.VOLTORB, Species.PIKACHU, Species.ELECTABUZZ], - ERIKA: [Species.ODDISH, Species.BELLSPROUT, Species.TANGELA, Species.HOPPIP], - JANINE: [Species.VENONAT, Species.SPINARAK, Species.ZUBAT], - SABRINA: [Species.ABRA, Species.MR_MIME, Species.ESPEON], - BLAINE: [Species.GROWLITHE, Species.PONYTA, Species.MAGMAR], - GIOVANNI: [Species.SANDILE, Species.MURKROW, Species.NIDORAN_M, Species.NIDORAN_F], - FALKNER: [Species.PIDGEY, Species.HOOTHOOT, Species.DODUO], - BUGSY: [Species.SCYTHER, Species.HERACROSS, Species.SHUCKLE, Species.PINSIR], - WHITNEY: [Species.GIRAFARIG, Species.MILTANK], - MORTY: [Species.GASTLY, Species.MISDREAVUS, Species.SABLEYE], - CHUCK: [Species.POLIWRATH, Species.MANKEY], - JASMINE: [Species.MAGNEMITE, Species.STEELIX], - PRYCE: [Species.SEEL, Species.SWINUB], - CLAIR: [Species.DRATINI, Species.HORSEA, Species.GYARADOS], - ROXANNE: [Species.GEODUDE, Species.NOSEPASS], - BRAWLY: [Species.MACHOP, Species.MAKUHITA], - WATTSON: [Species.MAGNEMITE, Species.VOLTORB, Species.ELECTRIKE], - FLANNERY: [Species.SLUGMA, Species.TORKOAL, Species.NUMEL], - NORMAN: [Species.SLAKOTH, Species.SPINDA, Species.CHANSEY, Species.KANGASKHAN], - WINONA: [Species.SWABLU, Species.WINGULL, Species.TROPIUS, Species.SKARMORY], - TATE: [Species.SOLROCK, Species.NATU, Species.CHIMECHO, Species.GALLADE], - LIZA: [Species.LUNATONE, Species.SPOINK, Species.BALTOY, Species.GARDEVOIR], - JUAN: [Species.HORSEA, Species.BARBOACH, Species.SPHEAL, Species.RELICANTH], - ROARK: [Species.CRANIDOS, Species.LARVITAR, Species.GEODUDE], - GARDENIA: [Species.ROSELIA, Species.TANGELA, Species.TURTWIG], - MAYLENE: [Species.LUCARIO, Species.MEDITITE, Species.CHIMCHAR], - CRASHER_WAKE: [Species.BUIZEL, Species.MAGIKARP, Species.PIPLUP], - FANTINA: [Species.MISDREAVUS, Species.DRIFLOON, Species.SPIRITOMB], - BYRON: [Species.SHIELDON, Species.BRONZOR, Species.AGGRON], - CANDICE: [Species.SNEASEL, Species.SNOVER, Species.SNORUNT], - VOLKNER: [Species.SHINX, Species.CHINCHOU, Species.ROTOM], - CILAN: [Species.PANSAGE, Species.COTTONEE, Species.PETILIL], - CHILI: [Species.PANSEAR, Species.DARUMAKA, Species.HEATMOR], - CRESS: [Species.PANPOUR, Species.BASCULIN, Species.TYMPOLE], - CHEREN: [Species.LILLIPUP, Species.MINCCINO, Species.PATRAT], - LENORA: [Species.KANGASKHAN, Species.DEERLING, Species.AUDINO], - ROXIE: [Species.VENIPEDE, Species.TRUBBISH, Species.SKORUPI], - BURGH: [Species.SEWADDLE, Species.SHELMET, Species.KARRABLAST], - ELESA: [Species.EMOLGA, Species.BLITZLE, Species.JOLTIK], - CLAY: [Species.DRILBUR, Species.SANDILE, Species.GOLETT], - SKYLA: [Species.DUCKLETT, Species.WOOBAT, Species.RUFFLET], - BRYCEN: [Species.CRYOGONAL, Species.VANILLITE, Species.CUBCHOO], - DRAYDEN: [Species.DRUDDIGON, Species.AXEW, Species.DEINO], - MARLON: [Species.WAILMER, Species.FRILLISH, Species.TIRTOUGA], - VIOLA: [Species.SURSKIT, Species.SCATTERBUG], - GRANT: [Species.AMAURA, Species.TYRUNT], - KORRINA: [Species.HAWLUCHA, Species.LUCARIO, Species.MIENFOO], - RAMOS: [Species.SKIDDO, Species.HOPPIP, Species.BELLSPROUT], - CLEMONT: [Species.HELIOPTILE, Species.MAGNEMITE, Species.EMOLGA], - VALERIE: [Species.SYLVEON, Species.MAWILE, Species.MR_MIME], - OLYMPIA: [Species.ESPURR, Species.SIGILYPH, Species.SLOWKING], - WULFRIC: [Species.BERGMITE, Species.SNOVER, Species.CRYOGONAL], - MILO: [Species.GOSSIFLEUR, Species.APPLIN, Species.BOUNSWEET], - NESSA: [Species.CHEWTLE, Species.ARROKUDA, Species.WIMPOD], - KABU: [Species.SIZZLIPEDE, Species.VULPIX, Species.TORKOAL], - BEA: [Species.GALAR_FARFETCHD, Species.MACHOP, Species.CLOBBOPUS], - ALLISTER: [Species.GALAR_YAMASK, Species.GALAR_CORSOLA, Species.GASTLY], - OPAL: [Species.MILCERY, Species.TOGETIC, Species.GALAR_WEEZING], - BEDE: [Species.HATENNA, Species.GALAR_PONYTA, Species.GARDEVOIR], - GORDIE: [Species.ROLYCOLY, Species.STONJOURNER, Species.BINACLE], - MELONY: [Species.SNOM, Species.GALAR_DARUMAKA, Species.GALAR_MR_MIME], - PIERS: [Species.GALAR_ZIGZAGOON, Species.SCRAGGY, Species.INKAY], - MARNIE: [Species.IMPIDIMP, Species.PURRLOIN, Species.MORPEKO], - RAIHAN: [Species.DURALUDON, Species.TURTONATOR, Species.GOOMY], - KATY: [Species.NYMBLE, Species.TAROUNTULA, Species.HERACROSS], - BRASSIUS: [Species.SMOLIV, Species.SHROOMISH, Species.ODDISH], - IONO: [Species.TADBULB, Species.WATTREL, Species.VOLTORB], - KOFU: [Species.VELUZA, Species.WIGLETT, Species.WINGULL], - LARRY: [Species.STARLY, Species.DUNSPARCE, Species.KOMALA], - RYME: [Species.GREAVARD, Species.SHUPPET, Species.MIMIKYU], - TULIP: [Species.GIRAFARIG, Species.FLITTLE, Species.RALTS], - GRUSHA: [Species.CETODDLE, Species.ALOLA_VULPIX, Species.CUBCHOO], - LORELEI: [Species.JYNX, [Species.SLOWBRO, Species.GALAR_SLOWBRO], Species.LAPRAS, [Species.ALOLA_SANDSLASH, Species.CLOYSTER]], - BRUNO: [Species.MACHAMP, Species.HITMONCHAN, Species.HITMONLEE, [Species.ALOLA_GOLEM, Species.GOLEM]], - AGATHA: [Species.GENGAR, [Species.ARBOK, Species.WEEZING], Species.CROBAT, Species.ALOLA_MAROWAK], - LANCE: [Species.DRAGONITE, Species.GYARADOS, Species.AERODACTYL, Species.ALOLA_EXEGGUTOR], - WILL: [Species.XATU, Species.JYNX, [Species.SLOWBRO, Species.SLOWKING], Species.EXEGGUTOR], - KOGA: [[Species.WEEZING, Species.MUK], [Species.VENOMOTH, Species.ARIADOS], Species.CROBAT, Species.TENTACRUEL], - KAREN: [Species.UMBREON, Species.HONCHKROW, Species.HOUNDOOM, Species.WEAVILE], - SIDNEY: [[Species.SHIFTRY, Species.CACTURNE], [Species.SHARPEDO, Species.CRAWDAUNT], Species.ABSOL, Species.MIGHTYENA], - PHOEBE: [Species.SABLEYE, Species.DUSKNOIR, Species.BANETTE, [Species.MISMAGIUS, Species.DRIFBLIM]], - GLACIA: [Species.GLALIE, Species.WALREIN, Species.FROSLASS, Species.ABOMASNOW], - DRAKE: [Species.ALTARIA, Species.SALAMENCE, Species.FLYGON, Species.KINGDRA], - AARON: [[Species.SCIZOR, Species.KLEAVOR], Species.HERACROSS, [Species.VESPIQUEN, Species.YANMEGA], Species.DRAPION], - BERTHA: [Species.WHISCASH, Species.HIPPOWDON, Species.GLISCOR, Species.RHYPERIOR], - FLINT: [[Species.FLAREON, Species.RAPIDASH], Species.MAGMORTAR, [Species.STEELIX, Species.LOPUNNY], Species.INFERNAPE], - LUCIAN: [Species.MR_MIME, Species.GALLADE, Species.BRONZONG, [Species.ALAKAZAM, Species.ESPEON]], - SHAUNTAL: [Species.COFAGRIGUS, Species.CHANDELURE, Species.GOLURK, Species.JELLICENT], - MARSHAL: [Species.CONKELDURR, Species.MIENSHAO, Species.THROH, Species.SAWK], - GRIMSLEY: [Species.LIEPARD, Species.KINGAMBIT, Species.SCRAFTY, Species.KROOKODILE], - CAITLIN: [Species.MUSHARNA, Species.GOTHITELLE, Species.SIGILYPH, Species.REUNICLUS], - MALVA: [Species.PYROAR, Species.TORKOAL, Species.CHANDELURE, Species.TALONFLAME], - SIEBOLD: [Species.CLAWITZER, Species.GYARADOS, Species.BARBARACLE, Species.STARMIE], - WIKSTROM: [Species.KLEFKI, Species.PROBOPASS, Species.SCIZOR, Species.AEGISLASH], - DRASNA: [Species.DRAGALGE, Species.DRUDDIGON, Species.ALTARIA, Species.NOIVERN], - HALA: [Species.HARIYAMA, Species.BEWEAR, Species.CRABOMINABLE, [Species.POLIWRATH, Species.ANNIHILAPE]], - MOLAYNE: [Species.KLEFKI, Species.MAGNEZONE, Species.METAGROSS, Species.ALOLA_DUGTRIO], - OLIVIA: [Species.RELICANTH, Species.CARBINK, Species.ALOLA_GOLEM, Species.LYCANROC], - ACEROLA: [[Species.BANETTE, Species.DRIFBLIM], Species.MIMIKYU, Species.DHELMISE, Species.PALOSSAND], - KAHILI: [[Species.BRAVIARY, Species.MANDIBUZZ], Species.HAWLUCHA, Species.ORICORIO, Species.TOUCANNON], - MARNIE_ELITE: [Species.MORPEKO, Species.LIEPARD, [Species.TOXICROAK, Species.SCRAFTY], Species.GRIMMSNARL], - NESSA_ELITE: [Species.GOLISOPOD, [Species.PELIPPER, Species.QUAGSIRE], Species.TOXAPEX, Species.DREDNAW], - BEA_ELITE: [Species.HAWLUCHA, [Species.GRAPPLOCT, Species.SIRFETCHD], Species.FALINKS, Species.MACHAMP], - ALLISTER_ELITE: [Species.DUSKNOIR, [Species.POLTEAGEIST, Species.RUNERIGUS], Species.CURSOLA, Species.GENGAR], - RAIHAN_ELITE: [Species.GOODRA, [Species.TORKOAL, Species.TURTONATOR], Species.FLYGON, Species.ARCHALUDON], - RIKA: [Species.WHISCASH, [Species.DONPHAN, Species.DUGTRIO], Species.CAMERUPT, Species.CLODSIRE], - POPPY: [Species.COPPERAJAH, Species.BRONZONG, Species.CORVIKNIGHT, Species.TINKATON], - LARRY_ELITE: [Species.STARAPTOR, Species.FLAMIGO, Species.ALTARIA, Species.TROPIUS], - HASSEL: [Species.NOIVERN, [Species.FLAPPLE, Species.APPLETUN], Species.DRAGALGE, Species.BAXCALIBUR], - CRISPIN: [Species.TALONFLAME, Species.CAMERUPT, Species.MAGMORTAR, Species.BLAZIKEN], - AMARYS: [Species.SKARMORY, Species.EMPOLEON, Species.SCIZOR, Species.METAGROSS], - LACEY: [Species.EXCADRILL, Species.PRIMARINA, [Species.ALCREMIE, Species.GRANBULL], Species.WHIMSICOTT], - DRAYTON: [Species.DRAGONITE, Species.ARCHALUDON, Species.HAXORUS, Species.SCEPTILE], - BLUE: [[Species.GYARADOS, Species.EXEGGUTOR, Species.ARCANINE], Species.HO_OH, [Species.RHYPERIOR, Species.MAGNEZONE]], // Alakazam lead, Mega Pidgeot - RED: [Species.LUGIA, Species.SNORLAX, [Species.ESPEON, Species.UMBREON, Species.SYLVEON]], // GMax Pikachu lead, Mega gen 1 starter - LANCE_CHAMPION: [Species.DRAGONITE, Species.KINGDRA, Species.ALOLA_EXEGGUTOR], // Aerodactyl lead, Mega Latias/Latios - STEVEN: [Species.AGGRON, [Species.ARMALDO, Species.CRADILY], Species.DIALGA], // Skarmory lead, Mega Metagross - WALLACE: [Species.MILOTIC, Species.PALKIA, Species.LUDICOLO], // Pelipper lead, Mega Swampert - CYNTHIA: [Species.GIRATINA, Species.LUCARIO, Species.TOGEKISS], // Spiritomb lead, Mega Garchomp - ALDER: [Species.VOLCARONA, Species.ZEKROM, [Species.ACCELGOR, Species.ESCAVALIER], Species.KELDEO], // Bouffalant/Braviary lead - IRIS: [Species.HAXORUS, Species.RESHIRAM, Species.ARCHEOPS], // Druddigon lead, Gmax Lapras - DIANTHA: [Species.HAWLUCHA, Species.XERNEAS, Species.GOODRA], // Gourgeist lead, Mega Gardevoir - HAU: [[Species.SOLGALEO, Species.LUNALA], Species.NOIVERN, [Species.DECIDUEYE, Species.INCINEROAR, Species.PRIMARINA], [Species.TAPU_BULU, Species.TAPU_FINI, Species.TAPU_KOKO, Species.TAPU_LELE]], // Alola Raichu lead - LEON: [Species.DRAGAPULT, [Species.ZACIAN, Species.ZAMAZENTA], Species.AEGISLASH], // Rillaboom/Cinderace/Inteleon lead, GMax Charizard - GEETA: [Species.MIRAIDON, [Species.ESPATHRA, Species.VELUZA], [Species.AVALUGG, Species.HISUI_AVALUGG], Species.KINGAMBIT], // Glimmora lead - NEMONA: [Species.KORAIDON, Species.PAWMOT, [Species.DUDUNSPARCE, Species.ORTHWORM], [Species.MEOWSCARADA, Species.SKELEDIRGE, Species.QUAQUAVAL]], // Lycanroc lead - KIERAN: [[Species.GRIMMSNARL, Species.INCINEROAR, Species.PORYGON_Z], Species.OGERPON, Species.TERAPAGOS, Species.HYDRAPPLE], // Poliwrath/Politoed lead + BROCK: [ Species.GEODUDE, Species.ONIX ], + MISTY: [ Species.STARYU, Species.PSYDUCK ], + LT_SURGE: [ Species.VOLTORB, Species.PIKACHU, Species.ELECTABUZZ ], + ERIKA: [ Species.ODDISH, Species.BELLSPROUT, Species.TANGELA, Species.HOPPIP ], + JANINE: [ Species.VENONAT, Species.SPINARAK, Species.ZUBAT ], + SABRINA: [ Species.ABRA, Species.MR_MIME, Species.ESPEON ], + BLAINE: [ Species.GROWLITHE, Species.PONYTA, Species.MAGMAR ], + GIOVANNI: [ Species.SANDILE, Species.MURKROW, Species.NIDORAN_M, Species.NIDORAN_F ], + FALKNER: [ Species.PIDGEY, Species.HOOTHOOT, Species.DODUO ], + BUGSY: [ Species.SCYTHER, Species.HERACROSS, Species.SHUCKLE, Species.PINSIR ], + WHITNEY: [ Species.GIRAFARIG, Species.MILTANK ], + MORTY: [ Species.GASTLY, Species.MISDREAVUS, Species.SABLEYE ], + CHUCK: [ Species.POLIWRATH, Species.MANKEY ], + JASMINE: [ Species.MAGNEMITE, Species.STEELIX ], + PRYCE: [ Species.SEEL, Species.SWINUB ], + CLAIR: [ Species.DRATINI, Species.HORSEA, Species.GYARADOS ], + ROXANNE: [ Species.GEODUDE, Species.NOSEPASS ], + BRAWLY: [ Species.MACHOP, Species.MAKUHITA ], + WATTSON: [ Species.MAGNEMITE, Species.VOLTORB, Species.ELECTRIKE ], + FLANNERY: [ Species.SLUGMA, Species.TORKOAL, Species.NUMEL ], + NORMAN: [ Species.SLAKOTH, Species.SPINDA, Species.CHANSEY, Species.KANGASKHAN ], + WINONA: [ Species.SWABLU, Species.WINGULL, Species.TROPIUS, Species.SKARMORY ], + TATE: [ Species.SOLROCK, Species.NATU, Species.CHIMECHO, Species.GALLADE ], + LIZA: [ Species.LUNATONE, Species.SPOINK, Species.BALTOY, Species.GARDEVOIR ], + JUAN: [ Species.HORSEA, Species.BARBOACH, Species.SPHEAL, Species.RELICANTH ], + ROARK: [ Species.CRANIDOS, Species.LARVITAR, Species.GEODUDE ], + GARDENIA: [ Species.ROSELIA, Species.TANGELA, Species.TURTWIG ], + MAYLENE: [ Species.LUCARIO, Species.MEDITITE, Species.CHIMCHAR ], + CRASHER_WAKE: [ Species.BUIZEL, Species.MAGIKARP, Species.PIPLUP ], + FANTINA: [ Species.MISDREAVUS, Species.DRIFLOON, Species.SPIRITOMB ], + BYRON: [ Species.SHIELDON, Species.BRONZOR, Species.AGGRON ], + CANDICE: [ Species.SNEASEL, Species.SNOVER, Species.SNORUNT ], + VOLKNER: [ Species.SHINX, Species.CHINCHOU, Species.ROTOM ], + CILAN: [ Species.PANSAGE, Species.COTTONEE, Species.PETILIL ], + CHILI: [ Species.PANSEAR, Species.DARUMAKA, Species.HEATMOR ], + CRESS: [ Species.PANPOUR, Species.BASCULIN, Species.TYMPOLE ], + CHEREN: [ Species.LILLIPUP, Species.MINCCINO, Species.PATRAT ], + LENORA: [ Species.KANGASKHAN, Species.DEERLING, Species.AUDINO ], + ROXIE: [ Species.VENIPEDE, Species.TRUBBISH, Species.SKORUPI ], + BURGH: [ Species.SEWADDLE, Species.SHELMET, Species.KARRABLAST ], + ELESA: [ Species.EMOLGA, Species.BLITZLE, Species.JOLTIK ], + CLAY: [ Species.DRILBUR, Species.SANDILE, Species.GOLETT ], + SKYLA: [ Species.DUCKLETT, Species.WOOBAT, Species.RUFFLET ], + BRYCEN: [ Species.CRYOGONAL, Species.VANILLITE, Species.CUBCHOO ], + DRAYDEN: [ Species.DRUDDIGON, Species.AXEW, Species.DEINO ], + MARLON: [ Species.WAILMER, Species.FRILLISH, Species.TIRTOUGA ], + VIOLA: [ Species.SURSKIT, Species.SCATTERBUG ], + GRANT: [ Species.AMAURA, Species.TYRUNT ], + KORRINA: [ Species.HAWLUCHA, Species.LUCARIO, Species.MIENFOO ], + RAMOS: [ Species.SKIDDO, Species.HOPPIP, Species.BELLSPROUT ], + CLEMONT: [ Species.HELIOPTILE, Species.MAGNEMITE, Species.EMOLGA ], + VALERIE: [ Species.SYLVEON, Species.MAWILE, Species.MR_MIME ], + OLYMPIA: [ Species.ESPURR, Species.SIGILYPH, Species.SLOWKING ], + WULFRIC: [ Species.BERGMITE, Species.SNOVER, Species.CRYOGONAL ], + MILO: [ Species.GOSSIFLEUR, Species.APPLIN, Species.BOUNSWEET ], + NESSA: [ Species.CHEWTLE, Species.ARROKUDA, Species.WIMPOD ], + KABU: [ Species.SIZZLIPEDE, Species.VULPIX, Species.TORKOAL ], + BEA: [ Species.GALAR_FARFETCHD, Species.MACHOP, Species.CLOBBOPUS ], + ALLISTER: [ Species.GALAR_YAMASK, Species.GALAR_CORSOLA, Species.GASTLY ], + OPAL: [ Species.MILCERY, Species.TOGETIC, Species.GALAR_WEEZING ], + BEDE: [ Species.HATENNA, Species.GALAR_PONYTA, Species.GARDEVOIR ], + GORDIE: [ Species.ROLYCOLY, Species.STONJOURNER, Species.BINACLE ], + MELONY: [ Species.SNOM, Species.GALAR_DARUMAKA, Species.GALAR_MR_MIME ], + PIERS: [ Species.GALAR_ZIGZAGOON, Species.SCRAGGY, Species.INKAY ], + MARNIE: [ Species.IMPIDIMP, Species.PURRLOIN, Species.MORPEKO ], + RAIHAN: [ Species.DURALUDON, Species.TURTONATOR, Species.GOOMY ], + KATY: [ Species.NYMBLE, Species.TAROUNTULA, Species.HERACROSS ], + BRASSIUS: [ Species.SMOLIV, Species.SHROOMISH, Species.ODDISH ], + IONO: [ Species.TADBULB, Species.WATTREL, Species.VOLTORB ], + KOFU: [ Species.VELUZA, Species.WIGLETT, Species.WINGULL ], + LARRY: [ Species.STARLY, Species.DUNSPARCE, Species.KOMALA ], + RYME: [ Species.GREAVARD, Species.SHUPPET, Species.MIMIKYU ], + TULIP: [ Species.GIRAFARIG, Species.FLITTLE, Species.RALTS ], + GRUSHA: [ Species.CETODDLE, Species.ALOLA_VULPIX, Species.CUBCHOO ], + LORELEI: [ Species.JYNX, [ Species.SLOWBRO, Species.GALAR_SLOWBRO ], Species.LAPRAS, [ Species.ALOLA_SANDSLASH, Species.CLOYSTER ]], + BRUNO: [ Species.MACHAMP, Species.HITMONCHAN, Species.HITMONLEE, [ Species.ALOLA_GOLEM, Species.GOLEM ]], + AGATHA: [ Species.GENGAR, [ Species.ARBOK, Species.WEEZING ], Species.CROBAT, Species.ALOLA_MAROWAK ], + LANCE: [ Species.DRAGONITE, Species.GYARADOS, Species.AERODACTYL, Species.ALOLA_EXEGGUTOR ], + WILL: [ Species.XATU, Species.JYNX, [ Species.SLOWBRO, Species.SLOWKING ], Species.EXEGGUTOR ], + KOGA: [[ Species.WEEZING, Species.MUK ], [ Species.VENOMOTH, Species.ARIADOS ], Species.CROBAT, Species.TENTACRUEL ], + KAREN: [ Species.UMBREON, Species.HONCHKROW, Species.HOUNDOOM, Species.WEAVILE ], + SIDNEY: [[ Species.SHIFTRY, Species.CACTURNE ], [ Species.SHARPEDO, Species.CRAWDAUNT ], Species.ABSOL, Species.MIGHTYENA ], + PHOEBE: [ Species.SABLEYE, Species.DUSKNOIR, Species.BANETTE, [ Species.MISMAGIUS, Species.DRIFBLIM ]], + GLACIA: [ Species.GLALIE, Species.WALREIN, Species.FROSLASS, Species.ABOMASNOW ], + DRAKE: [ Species.ALTARIA, Species.SALAMENCE, Species.FLYGON, Species.KINGDRA ], + AARON: [[ Species.SCIZOR, Species.KLEAVOR ], Species.HERACROSS, [ Species.VESPIQUEN, Species.YANMEGA ], Species.DRAPION ], + BERTHA: [ Species.WHISCASH, Species.HIPPOWDON, Species.GLISCOR, Species.RHYPERIOR ], + FLINT: [[ Species.FLAREON, Species.RAPIDASH ], Species.MAGMORTAR, [ Species.STEELIX, Species.LOPUNNY ], Species.INFERNAPE ], + LUCIAN: [ Species.MR_MIME, Species.GALLADE, Species.BRONZONG, [ Species.ALAKAZAM, Species.ESPEON ]], + SHAUNTAL: [ Species.COFAGRIGUS, Species.CHANDELURE, Species.GOLURK, Species.JELLICENT ], + MARSHAL: [ Species.CONKELDURR, Species.MIENSHAO, Species.THROH, Species.SAWK ], + GRIMSLEY: [ Species.LIEPARD, Species.KINGAMBIT, Species.SCRAFTY, Species.KROOKODILE ], + CAITLIN: [ Species.MUSHARNA, Species.GOTHITELLE, Species.SIGILYPH, Species.REUNICLUS ], + MALVA: [ Species.PYROAR, Species.TORKOAL, Species.CHANDELURE, Species.TALONFLAME ], + SIEBOLD: [ Species.CLAWITZER, Species.GYARADOS, Species.BARBARACLE, Species.STARMIE ], + WIKSTROM: [ Species.KLEFKI, Species.PROBOPASS, Species.SCIZOR, Species.AEGISLASH ], + DRASNA: [ Species.DRAGALGE, Species.DRUDDIGON, Species.ALTARIA, Species.NOIVERN ], + HALA: [ Species.HARIYAMA, Species.BEWEAR, Species.CRABOMINABLE, [ Species.POLIWRATH, Species.ANNIHILAPE ]], + MOLAYNE: [ Species.KLEFKI, Species.MAGNEZONE, Species.METAGROSS, Species.ALOLA_DUGTRIO ], + OLIVIA: [ Species.RELICANTH, Species.CARBINK, Species.ALOLA_GOLEM, Species.LYCANROC ], + ACEROLA: [[ Species.BANETTE, Species.DRIFBLIM ], Species.MIMIKYU, Species.DHELMISE, Species.PALOSSAND ], + KAHILI: [[ Species.BRAVIARY, Species.MANDIBUZZ ], Species.HAWLUCHA, Species.ORICORIO, Species.TOUCANNON ], + MARNIE_ELITE: [ Species.MORPEKO, Species.LIEPARD, [ Species.TOXICROAK, Species.SCRAFTY ], Species.GRIMMSNARL ], + NESSA_ELITE: [ Species.GOLISOPOD, [ Species.PELIPPER, Species.QUAGSIRE ], Species.TOXAPEX, Species.DREDNAW ], + BEA_ELITE: [ Species.HAWLUCHA, [ Species.GRAPPLOCT, Species.SIRFETCHD ], Species.FALINKS, Species.MACHAMP ], + ALLISTER_ELITE: [ Species.DUSKNOIR, [ Species.POLTEAGEIST, Species.RUNERIGUS ], Species.CURSOLA, Species.GENGAR ], + RAIHAN_ELITE: [ Species.GOODRA, [ Species.TORKOAL, Species.TURTONATOR ], Species.FLYGON, Species.ARCHALUDON ], + RIKA: [ Species.WHISCASH, [ Species.DONPHAN, Species.DUGTRIO ], Species.CAMERUPT, Species.CLODSIRE ], + POPPY: [ Species.COPPERAJAH, Species.BRONZONG, Species.CORVIKNIGHT, Species.TINKATON ], + LARRY_ELITE: [ Species.STARAPTOR, Species.FLAMIGO, Species.ALTARIA, Species.TROPIUS ], + HASSEL: [ Species.NOIVERN, [ Species.FLAPPLE, Species.APPLETUN ], Species.DRAGALGE, Species.BAXCALIBUR ], + CRISPIN: [ Species.TALONFLAME, Species.CAMERUPT, Species.MAGMORTAR, Species.BLAZIKEN ], + AMARYS: [ Species.SKARMORY, Species.EMPOLEON, Species.SCIZOR, Species.METAGROSS ], + LACEY: [ Species.EXCADRILL, Species.PRIMARINA, [ Species.ALCREMIE, Species.GRANBULL ], Species.WHIMSICOTT ], + DRAYTON: [ Species.DRAGONITE, Species.ARCHALUDON, Species.HAXORUS, Species.SCEPTILE ], + BLUE: [[ Species.GYARADOS, Species.EXEGGUTOR, Species.ARCANINE ], Species.HO_OH, [ Species.RHYPERIOR, Species.MAGNEZONE ]], // Alakazam lead, Mega Pidgeot + RED: [ Species.LUGIA, Species.SNORLAX, [ Species.ESPEON, Species.UMBREON, Species.SYLVEON ]], // GMax Pikachu lead, Mega gen 1 starter + LANCE_CHAMPION: [ Species.DRAGONITE, Species.KINGDRA, Species.ALOLA_EXEGGUTOR ], // Aerodactyl lead, Mega Latias/Latios + STEVEN: [ Species.AGGRON, [ Species.ARMALDO, Species.CRADILY ], Species.DIALGA ], // Skarmory lead, Mega Metagross + WALLACE: [ Species.MILOTIC, Species.PALKIA, Species.LUDICOLO ], // Pelipper lead, Mega Swampert + CYNTHIA: [ Species.GIRATINA, Species.LUCARIO, Species.TOGEKISS ], // Spiritomb lead, Mega Garchomp + ALDER: [ Species.VOLCARONA, Species.ZEKROM, [ Species.ACCELGOR, Species.ESCAVALIER ], Species.KELDEO ], // Bouffalant/Braviary lead + IRIS: [ Species.HAXORUS, Species.RESHIRAM, Species.ARCHEOPS ], // Druddigon lead, Gmax Lapras + DIANTHA: [ Species.HAWLUCHA, Species.XERNEAS, Species.GOODRA ], // Gourgeist lead, Mega Gardevoir + HAU: [[ Species.SOLGALEO, Species.LUNALA ], Species.NOIVERN, [ Species.DECIDUEYE, Species.INCINEROAR, Species.PRIMARINA ], [ Species.TAPU_BULU, Species.TAPU_FINI, Species.TAPU_KOKO, Species.TAPU_LELE ]], // Alola Raichu lead + LEON: [ Species.DRAGAPULT, Species.ZACIAN, Species.AEGISLASH ], // Rillaboom/Cinderace/Inteleon lead, GMax Charizard + GEETA: [ Species.MIRAIDON, [ Species.ESPATHRA, Species.VELUZA ], [ Species.AVALUGG, Species.HISUI_AVALUGG ], Species.KINGAMBIT ], // Glimmora lead + NEMONA: [ Species.KORAIDON, Species.PAWMOT, [ Species.DUDUNSPARCE, Species.ORTHWORM ], [ Species.MEOWSCARADA, Species.SKELEDIRGE, Species.QUAQUAVAL ]], // Lycanroc lead + KIERAN: [[ Species.GRIMMSNARL, Species.INCINEROAR, Species.PORYGON_Z ], Species.OGERPON, Species.TERAPAGOS, Species.HYDRAPPLE ], // Poliwrath/Politoed lead }; export const trainerConfigs: TrainerConfigs = { @@ -1281,15 +1343,15 @@ export const trainerConfigs: TrainerConfigs = { [TrainerType.ACE_TRAINER]: new TrainerConfig(++t).setHasGenders("Ace Trainer Female").setHasDouble("Ace Duo").setMoneyMultiplier(2.25).setEncounterBgm(TrainerType.ACE_TRAINER) .setPartyTemplateFunc(scene => getWavePartyTemplate(scene, trainerPartyTemplates.THREE_WEAK_BALANCED, trainerPartyTemplates.FOUR_WEAK_BALANCED, trainerPartyTemplates.FIVE_WEAK_BALANCED, trainerPartyTemplates.SIX_WEAK_BALANCED)), [TrainerType.ARTIST]: new TrainerConfig(++t).setEncounterBgm(TrainerType.RICH).setPartyTemplates(trainerPartyTemplates.ONE_STRONG, trainerPartyTemplates.TWO_AVG, trainerPartyTemplates.THREE_AVG) - .setSpeciesPools([Species.SMEARGLE]), + .setSpeciesPools([ Species.SMEARGLE ]), [TrainerType.BACKERS]: new TrainerConfig(++t).setHasGenders("Backers").setDoubleOnly().setEncounterBgm(TrainerType.CYCLIST), [TrainerType.BACKPACKER]: new TrainerConfig(++t).setHasGenders("Backpacker Female").setHasDouble("Backpackers").setSpeciesFilter(s => s.isOfType(Type.FLYING) || s.isOfType(Type.ROCK)).setEncounterBgm(TrainerType.BACKPACKER) .setPartyTemplates(trainerPartyTemplates.ONE_STRONG, trainerPartyTemplates.ONE_WEAK_ONE_STRONG, trainerPartyTemplates.ONE_AVG_ONE_STRONG) .setSpeciesPools({ - [TrainerPoolTier.COMMON]: [Species.RHYHORN, Species.AIPOM, Species.MAKUHITA, Species.MAWILE, Species.NUMEL, Species.LILLIPUP, Species.SANDILE, Species.WOOLOO], - [TrainerPoolTier.UNCOMMON]: [Species.GIRAFARIG, Species.ZANGOOSE, Species.SEVIPER, Species.CUBCHOO, Species.PANCHAM, Species.SKIDDO, Species.MUDBRAY], - [TrainerPoolTier.RARE]: [Species.TAUROS, Species.STANTLER, Species.DARUMAKA, Species.BOUFFALANT, Species.DEERLING, Species.IMPIDIMP], - [TrainerPoolTier.SUPER_RARE]: [Species.GALAR_DARUMAKA, Species.TEDDIURSA] + [TrainerPoolTier.COMMON]: [ Species.RHYHORN, Species.AIPOM, Species.MAKUHITA, Species.MAWILE, Species.NUMEL, Species.LILLIPUP, Species.SANDILE, Species.WOOLOO ], + [TrainerPoolTier.UNCOMMON]: [ Species.GIRAFARIG, Species.ZANGOOSE, Species.SEVIPER, Species.CUBCHOO, Species.PANCHAM, Species.SKIDDO, Species.MUDBRAY ], + [TrainerPoolTier.RARE]: [ Species.TAUROS, Species.STANTLER, Species.DARUMAKA, Species.BOUFFALANT, Species.DEERLING, Species.IMPIDIMP ], + [TrainerPoolTier.SUPER_RARE]: [ Species.GALAR_DARUMAKA, Species.TEDDIURSA ] }), [TrainerType.BAKER]: new TrainerConfig(++t).setEncounterBgm(TrainerType.CLERK).setMoneyMultiplier(1.35).setSpeciesFilter(s => s.isOfType(Type.GRASS) || s.isOfType(Type.FIRE)), [TrainerType.BEAUTY]: new TrainerConfig(++t).setMoneyMultiplier(1.55).setEncounterBgm(TrainerType.PARASOL_LADY), @@ -1297,11 +1359,11 @@ export const trainerConfigs: TrainerConfigs = { [TrainerType.BLACK_BELT]: new TrainerConfig(++t).setHasGenders("Battle Girl", TrainerType.PSYCHIC).setHasDouble("Crush Kin").setEncounterBgm(TrainerType.ROUGHNECK).setSpecialtyTypes(Type.FIGHTING) .setPartyTemplates(trainerPartyTemplates.TWO_WEAK_ONE_AVG, trainerPartyTemplates.TWO_WEAK_ONE_AVG, trainerPartyTemplates.TWO_AVG, trainerPartyTemplates.TWO_AVG, trainerPartyTemplates.TWO_WEAK_ONE_STRONG, trainerPartyTemplates.THREE_AVG, trainerPartyTemplates.TWO_AVG_ONE_STRONG) .setSpeciesPools({ - [TrainerPoolTier.COMMON]: [Species.NIDORAN_F, Species.NIDORAN_M, Species.MACHOP, Species.MAKUHITA, Species.MEDITITE, Species.CROAGUNK, Species.TIMBURR], - [TrainerPoolTier.UNCOMMON]: [Species.MANKEY, Species.POLIWRATH, Species.TYROGUE, Species.BRELOOM, Species.SCRAGGY, Species.MIENFOO, Species.PANCHAM, Species.STUFFUL, Species.CRABRAWLER], - [TrainerPoolTier.RARE]: [Species.HERACROSS, Species.RIOLU, Species.THROH, Species.SAWK, Species.PASSIMIAN, Species.CLOBBOPUS], - [TrainerPoolTier.SUPER_RARE]: [Species.HITMONTOP, Species.INFERNAPE, Species.GALLADE, Species.HAWLUCHA, Species.HAKAMO_O], - [TrainerPoolTier.ULTRA_RARE]: [Species.KUBFU] + [TrainerPoolTier.COMMON]: [ Species.NIDORAN_F, Species.NIDORAN_M, Species.MACHOP, Species.MAKUHITA, Species.MEDITITE, Species.CROAGUNK, Species.TIMBURR ], + [TrainerPoolTier.UNCOMMON]: [ Species.MANKEY, Species.POLIWRATH, Species.TYROGUE, Species.BRELOOM, Species.SCRAGGY, Species.MIENFOO, Species.PANCHAM, Species.STUFFUL, Species.CRABRAWLER ], + [TrainerPoolTier.RARE]: [ Species.HERACROSS, Species.RIOLU, Species.THROH, Species.SAWK, Species.PASSIMIAN, Species.CLOBBOPUS ], + [TrainerPoolTier.SUPER_RARE]: [ Species.HITMONTOP, Species.INFERNAPE, Species.GALLADE, Species.HAWLUCHA, Species.HAKAMO_O ], + [TrainerPoolTier.ULTRA_RARE]: [ Species.KUBFU ] }), [TrainerType.BREEDER]: new TrainerConfig(++t).setMoneyMultiplier(1.325).setEncounterBgm(TrainerType.POKEFAN).setHasGenders("Breeder Female").setHasDouble("Breeders") .setPartyTemplateFunc(scene => getWavePartyTemplate(scene, trainerPartyTemplates.FOUR_WEAKER, trainerPartyTemplates.FIVE_WEAKER, trainerPartyTemplates.SIX_WEAKER)) @@ -1309,25 +1371,25 @@ export const trainerConfigs: TrainerConfigs = { [TrainerType.CLERK]: new TrainerConfig(++t).setHasGenders("Clerk Female").setHasDouble("Colleagues").setEncounterBgm(TrainerType.CLERK) .setPartyTemplates(trainerPartyTemplates.TWO_WEAK, trainerPartyTemplates.THREE_WEAK, trainerPartyTemplates.ONE_AVG, trainerPartyTemplates.TWO_AVG, trainerPartyTemplates.TWO_WEAK_ONE_AVG) .setSpeciesPools({ - [TrainerPoolTier.COMMON]: [Species.MEOWTH, Species.PSYDUCK, Species.BUDEW, Species.PIDOVE, Species.CINCCINO, Species.LITLEO], - [TrainerPoolTier.UNCOMMON]: [Species.JIGGLYPUFF, Species.MAGNEMITE, Species.MARILL, Species.COTTONEE, Species.SKIDDO], - [TrainerPoolTier.RARE]: [Species.BUIZEL, Species.SNEASEL, Species.KLEFKI, Species.INDEEDEE] + [TrainerPoolTier.COMMON]: [ Species.MEOWTH, Species.PSYDUCK, Species.BUDEW, Species.PIDOVE, Species.CINCCINO, Species.LITLEO ], + [TrainerPoolTier.UNCOMMON]: [ Species.JIGGLYPUFF, Species.MAGNEMITE, Species.MARILL, Species.COTTONEE, Species.SKIDDO ], + [TrainerPoolTier.RARE]: [ Species.BUIZEL, Species.SNEASEL, Species.KLEFKI, Species.INDEEDEE ] }), [TrainerType.CYCLIST]: new TrainerConfig(++t).setMoneyMultiplier(1.3).setHasGenders("Cyclist Female").setHasDouble("Cyclists").setEncounterBgm(TrainerType.CYCLIST) .setPartyTemplates(trainerPartyTemplates.TWO_WEAK, trainerPartyTemplates.ONE_AVG) .setSpeciesPools({ - [TrainerPoolTier.COMMON]: [Species.PICHU, Species.STARLY, Species.TAILLOW, Species.BOLTUND], - [TrainerPoolTier.UNCOMMON]: [Species.DODUO, Species.ELECTRIKE, Species.BLITZLE, Species.WATTREL], - [TrainerPoolTier.RARE]: [Species.YANMA, Species.NINJASK, Species.WHIRLIPEDE, Species.EMOLGA], - [TrainerPoolTier.SUPER_RARE]: [Species.ACCELGOR, Species.DREEPY] + [TrainerPoolTier.COMMON]: [ Species.PICHU, Species.STARLY, Species.TAILLOW, Species.BOLTUND ], + [TrainerPoolTier.UNCOMMON]: [ Species.DODUO, Species.ELECTRIKE, Species.BLITZLE, Species.WATTREL ], + [TrainerPoolTier.RARE]: [ Species.YANMA, Species.NINJASK, Species.WHIRLIPEDE, Species.EMOLGA ], + [TrainerPoolTier.SUPER_RARE]: [ Species.ACCELGOR, Species.DREEPY ] }), [TrainerType.DANCER]: new TrainerConfig(++t).setMoneyMultiplier(1.55).setEncounterBgm(TrainerType.CYCLIST) .setPartyTemplates(trainerPartyTemplates.TWO_WEAK, trainerPartyTemplates.ONE_AVG, trainerPartyTemplates.TWO_AVG, trainerPartyTemplates.TWO_WEAK_SAME_TWO_WEAK_SAME) .setSpeciesPools({ - [TrainerPoolTier.COMMON]: [Species.RALTS, Species.SPOINK, Species.LOTAD, Species.BUDEW], - [TrainerPoolTier.UNCOMMON]: [Species.SPINDA, Species.SWABLU, Species.MARACTUS,], - [TrainerPoolTier.RARE]: [Species.BELLOSSOM, Species.HITMONTOP, Species.MIME_JR, Species.ORICORIO], - [TrainerPoolTier.SUPER_RARE]: [Species.POPPLIO] + [TrainerPoolTier.COMMON]: [ Species.RALTS, Species.SPOINK, Species.LOTAD, Species.BUDEW ], + [TrainerPoolTier.UNCOMMON]: [ Species.SPINDA, Species.SWABLU, Species.MARACTUS, ], + [TrainerPoolTier.RARE]: [ Species.BELLOSSOM, Species.HITMONTOP, Species.MIME_JR, Species.ORICORIO ], + [TrainerPoolTier.SUPER_RARE]: [ Species.POPPLIO ] }), [TrainerType.DEPOT_AGENT]: new TrainerConfig(++t).setMoneyMultiplier(1.45).setEncounterBgm(TrainerType.CLERK), [TrainerType.DOCTOR]: new TrainerConfig(++t).setHasGenders("Nurse", "lass").setHasDouble("Medical Team").setMoneyMultiplier(3).setEncounterBgm(TrainerType.CLERK) @@ -1337,20 +1399,20 @@ export const trainerConfigs: TrainerConfigs = { [TrainerType.FISHERMAN]: new TrainerConfig(++t).setMoneyMultiplier(1.25).setEncounterBgm(TrainerType.BACKPACKER).setSpecialtyTypes(Type.WATER) .setPartyTemplates(trainerPartyTemplates.TWO_WEAK_SAME_ONE_AVG, trainerPartyTemplates.ONE_AVG, trainerPartyTemplates.THREE_WEAK_SAME, trainerPartyTemplates.ONE_STRONG, trainerPartyTemplates.SIX_WEAKER) .setSpeciesPools({ - [TrainerPoolTier.COMMON]: [Species.TENTACOOL, Species.MAGIKARP, Species.GOLDEEN, Species.STARYU, Species.REMORAID, Species.SKRELP, Species.CLAUNCHER, Species.ARROKUDA], - [TrainerPoolTier.UNCOMMON]: [Species.POLIWAG, Species.SHELLDER, Species.KRABBY, Species.HORSEA, Species.CARVANHA, Species.BARBOACH, Species.CORPHISH, Species.FINNEON, Species.TYMPOLE, Species.BASCULIN, Species.FRILLISH, Species.INKAY], - [TrainerPoolTier.RARE]: [Species.CHINCHOU, Species.CORSOLA, Species.WAILMER, Species.BARBOACH, Species.CLAMPERL, Species.LUVDISC, Species.MANTYKE, Species.ALOMOMOLA, Species.TATSUGIRI, Species.VELUZA], - [TrainerPoolTier.SUPER_RARE]: [Species.LAPRAS, Species.FEEBAS, Species.RELICANTH, Species.DONDOZO] + [TrainerPoolTier.COMMON]: [ Species.TENTACOOL, Species.MAGIKARP, Species.GOLDEEN, Species.STARYU, Species.REMORAID, Species.SKRELP, Species.CLAUNCHER, Species.ARROKUDA ], + [TrainerPoolTier.UNCOMMON]: [ Species.POLIWAG, Species.SHELLDER, Species.KRABBY, Species.HORSEA, Species.CARVANHA, Species.BARBOACH, Species.CORPHISH, Species.FINNEON, Species.TYMPOLE, Species.BASCULIN, Species.FRILLISH, Species.INKAY ], + [TrainerPoolTier.RARE]: [ Species.CHINCHOU, Species.CORSOLA, Species.WAILMER, Species.BARBOACH, Species.CLAMPERL, Species.LUVDISC, Species.MANTYKE, Species.ALOMOMOLA, Species.TATSUGIRI, Species.VELUZA ], + [TrainerPoolTier.SUPER_RARE]: [ Species.LAPRAS, Species.FEEBAS, Species.RELICANTH, Species.DONDOZO ] }), [TrainerType.GUITARIST]: new TrainerConfig(++t).setMoneyMultiplier(1.2).setEncounterBgm(TrainerType.ROUGHNECK).setSpecialtyTypes(Type.ELECTRIC).setSpeciesFilter(s => s.isOfType(Type.ELECTRIC)), [TrainerType.HARLEQUIN]: new TrainerConfig(++t).setEncounterBgm(TrainerType.PSYCHIC).setSpeciesFilter(s => tmSpecies[Moves.TRICK_ROOM].indexOf(s.speciesId) > -1), [TrainerType.HIKER]: new TrainerConfig(++t).setEncounterBgm(TrainerType.BACKPACKER) .setPartyTemplates(trainerPartyTemplates.TWO_AVG_SAME_ONE_AVG, trainerPartyTemplates.TWO_AVG_SAME_ONE_STRONG, trainerPartyTemplates.TWO_AVG, trainerPartyTemplates.FOUR_WEAK, trainerPartyTemplates.ONE_STRONG) .setSpeciesPools({ - [TrainerPoolTier.COMMON]: [Species.SANDSHREW, Species.DIGLETT, Species.GEODUDE, Species.MACHOP, Species.ARON, Species.ROGGENROLA, Species.DRILBUR, Species.NACLI], - [TrainerPoolTier.UNCOMMON]: [Species.ZUBAT, Species.RHYHORN, Species.ONIX, Species.CUBONE, Species.WOOBAT, Species.SWINUB, Species.NOSEPASS, Species.HIPPOPOTAS, Species.DWEBBLE, Species.KLAWF, Species.TOEDSCOOL], - [TrainerPoolTier.RARE]: [Species.TORKOAL, Species.TRAPINCH, Species.BARBOACH, Species.GOLETT, Species.ALOLA_DIGLETT, Species.ALOLA_GEODUDE, Species.GALAR_STUNFISK, Species.PALDEA_WOOPER], - [TrainerPoolTier.SUPER_RARE]: [Species.MAGBY, Species.LARVITAR] + [TrainerPoolTier.COMMON]: [ Species.SANDSHREW, Species.DIGLETT, Species.GEODUDE, Species.MACHOP, Species.ARON, Species.ROGGENROLA, Species.DRILBUR, Species.NACLI ], + [TrainerPoolTier.UNCOMMON]: [ Species.ZUBAT, Species.RHYHORN, Species.ONIX, Species.CUBONE, Species.WOOBAT, Species.SWINUB, Species.NOSEPASS, Species.HIPPOPOTAS, Species.DWEBBLE, Species.KLAWF, Species.TOEDSCOOL ], + [TrainerPoolTier.RARE]: [ Species.TORKOAL, Species.TRAPINCH, Species.BARBOACH, Species.GOLETT, Species.ALOLA_DIGLETT, Species.ALOLA_GEODUDE, Species.GALAR_STUNFISK, Species.PALDEA_WOOPER ], + [TrainerPoolTier.SUPER_RARE]: [ Species.MAGBY, Species.LARVITAR ] }), [TrainerType.HOOLIGANS]: new TrainerConfig(++t).setDoubleOnly().setEncounterBgm(TrainerType.ROUGHNECK).setSpeciesFilter(s => s.isOfType(Type.POISON) || s.isOfType(Type.DARK)), [TrainerType.HOOPSTER]: new TrainerConfig(++t).setMoneyMultiplier(1.2).setEncounterBgm(TrainerType.CYCLIST), @@ -1366,11 +1428,11 @@ export const trainerConfigs: TrainerConfigs = { [TrainerType.OFFICER]: new TrainerConfig(++t).setMoneyMultiplier(1.55).setEncounterBgm(TrainerType.CLERK) .setPartyTemplates(trainerPartyTemplates.ONE_AVG, trainerPartyTemplates.ONE_STRONG, trainerPartyTemplates.TWO_AVG, trainerPartyTemplates.TWO_WEAK_SAME_ONE_AVG) .setSpeciesPools({ - [TrainerPoolTier.COMMON]: [Species.VULPIX, Species.GROWLITHE, Species.SNUBBULL, Species.POOCHYENA, Species.ELECTRIKE, Species.LILLIPUP, Species.YAMPER, Species.FIDOUGH], - [TrainerPoolTier.UNCOMMON]: [Species.HOUNDOUR, Species.ROCKRUFF, Species.MASCHIFF], - [TrainerPoolTier.RARE]: [Species.JOLTEON, Species.RIOLU], + [TrainerPoolTier.COMMON]: [ Species.VULPIX, Species.GROWLITHE, Species.SNUBBULL, Species.POOCHYENA, Species.ELECTRIKE, Species.LILLIPUP, Species.YAMPER, Species.FIDOUGH ], + [TrainerPoolTier.UNCOMMON]: [ Species.HOUNDOUR, Species.ROCKRUFF, Species.MASCHIFF ], + [TrainerPoolTier.RARE]: [ Species.JOLTEON, Species.RIOLU ], [TrainerPoolTier.SUPER_RARE]: [], - [TrainerPoolTier.ULTRA_RARE]: [Species.ENTEI, Species.SUICUNE, Species.RAIKOU] + [TrainerPoolTier.ULTRA_RARE]: [ Species.ENTEI, Species.SUICUNE, Species.RAIKOU ] }), [TrainerType.PARASOL_LADY]: new TrainerConfig(++t).setMoneyMultiplier(1.55).setEncounterBgm(TrainerType.PARASOL_LADY).setSpeciesFilter(s => s.isOfType(Type.WATER)), [TrainerType.PILOT]: new TrainerConfig(++t).setEncounterBgm(TrainerType.CLERK).setSpeciesFilter(s => tmSpecies[Moves.FLY].indexOf(s.speciesId) > -1), @@ -1379,25 +1441,25 @@ export const trainerConfigs: TrainerConfigs = { [TrainerType.PRESCHOOLER]: new TrainerConfig(++t).setMoneyMultiplier(0.2).setEncounterBgm(TrainerType.YOUNGSTER).setHasGenders("Preschooler Female", "lass").setHasDouble("Preschoolers") .setPartyTemplates(trainerPartyTemplates.THREE_WEAK, trainerPartyTemplates.FOUR_WEAKER, trainerPartyTemplates.TWO_WEAK_SAME_ONE_AVG, trainerPartyTemplates.FIVE_WEAKER) .setSpeciesPools({ - [TrainerPoolTier.COMMON]: [Species.CATERPIE, Species.PICHU, Species.SANDSHREW, Species.LEDYBA, Species.BUDEW, Species.BURMY, Species.WOOLOO, Species.PAWMI, Species.SMOLIV], - [TrainerPoolTier.UNCOMMON]: [Species.EEVEE, Species.CLEFFA, Species.IGGLYBUFF, Species.SWINUB, Species.WOOPER, Species.DRIFLOON, Species.DEDENNE, Species.STUFFUL], - [TrainerPoolTier.RARE]: [Species.RALTS, Species.RIOLU, Species.JOLTIK, Species.TANDEMAUS], - [TrainerPoolTier.SUPER_RARE]: [Species.DARUMAKA, Species.TINKATINK], + [TrainerPoolTier.COMMON]: [ Species.CATERPIE, Species.PICHU, Species.SANDSHREW, Species.LEDYBA, Species.BUDEW, Species.BURMY, Species.WOOLOO, Species.PAWMI, Species.SMOLIV ], + [TrainerPoolTier.UNCOMMON]: [ Species.EEVEE, Species.CLEFFA, Species.IGGLYBUFF, Species.SWINUB, Species.WOOPER, Species.DRIFLOON, Species.DEDENNE, Species.STUFFUL ], + [TrainerPoolTier.RARE]: [ Species.RALTS, Species.RIOLU, Species.JOLTIK, Species.TANDEMAUS ], + [TrainerPoolTier.SUPER_RARE]: [ Species.DARUMAKA, Species.TINKATINK ], }), [TrainerType.PSYCHIC]: new TrainerConfig(++t).setHasGenders("Psychic Female").setHasDouble("Psychics").setMoneyMultiplier(1.4).setEncounterBgm(TrainerType.PSYCHIC) .setPartyTemplates(trainerPartyTemplates.TWO_WEAK, trainerPartyTemplates.TWO_AVG, trainerPartyTemplates.TWO_WEAK_SAME_ONE_AVG, trainerPartyTemplates.TWO_WEAK_SAME_TWO_WEAK_SAME, trainerPartyTemplates.ONE_STRONGER) .setSpeciesPools({ - [TrainerPoolTier.COMMON]: [Species.ABRA, Species.DROWZEE, Species.RALTS, Species.SPOINK, Species.GOTHITA, Species.SOLOSIS, Species.BLIPBUG, Species.ESPURR, Species.HATENNA], - [TrainerPoolTier.UNCOMMON]: [Species.MIME_JR, Species.EXEGGCUTE, Species.MEDITITE, Species.NATU, Species.EXEGGCUTE, Species.WOOBAT, Species.INKAY, Species.ORANGURU], - [TrainerPoolTier.RARE]: [Species.ELGYEM, Species.SIGILYPH, Species.BALTOY, Species.GIRAFARIG, Species.MEOWSTIC], - [TrainerPoolTier.SUPER_RARE]: [Species.BELDUM, Species.ESPEON, Species.STANTLER], + [TrainerPoolTier.COMMON]: [ Species.ABRA, Species.DROWZEE, Species.RALTS, Species.SPOINK, Species.GOTHITA, Species.SOLOSIS, Species.BLIPBUG, Species.ESPURR, Species.HATENNA ], + [TrainerPoolTier.UNCOMMON]: [ Species.MIME_JR, Species.EXEGGCUTE, Species.MEDITITE, Species.NATU, Species.EXEGGCUTE, Species.WOOBAT, Species.INKAY, Species.ORANGURU ], + [TrainerPoolTier.RARE]: [ Species.ELGYEM, Species.SIGILYPH, Species.BALTOY, Species.GIRAFARIG, Species.MEOWSTIC ], + [TrainerPoolTier.SUPER_RARE]: [ Species.BELDUM, Species.ESPEON, Species.STANTLER ], }), [TrainerType.RANGER]: new TrainerConfig(++t).setMoneyMultiplier(1.4).setName("Pokémon Ranger").setEncounterBgm(TrainerType.BACKPACKER).setHasGenders("Pokémon Ranger Female").setHasDouble("Pokémon Rangers") .setSpeciesPools({ - [TrainerPoolTier.COMMON]: [Species.PICHU, Species.GROWLITHE, Species.PONYTA, Species.ZIGZAGOON, Species.SEEDOT, Species.BIDOOF, Species.RIOLU, Species.SEWADDLE, Species.SKIDDO, Species.SALANDIT, Species.YAMPER], - [TrainerPoolTier.UNCOMMON]: [Species.AZURILL, Species.TAUROS, Species.MAREEP, Species.FARFETCHD, Species.TEDDIURSA, Species.SHROOMISH, Species.ELECTRIKE, Species.BUDEW, Species.BUIZEL, Species.MUDBRAY, Species.STUFFUL], - [TrainerPoolTier.RARE]: [Species.EEVEE, Species.SCYTHER, Species.KANGASKHAN, Species.RALTS, Species.MUNCHLAX, Species.ZORUA, Species.PALDEA_TAUROS, Species.TINKATINK, Species.CYCLIZAR, Species.FLAMIGO], - [TrainerPoolTier.SUPER_RARE]: [Species.LARVESTA], + [TrainerPoolTier.COMMON]: [ Species.PICHU, Species.GROWLITHE, Species.PONYTA, Species.ZIGZAGOON, Species.SEEDOT, Species.BIDOOF, Species.RIOLU, Species.SEWADDLE, Species.SKIDDO, Species.SALANDIT, Species.YAMPER ], + [TrainerPoolTier.UNCOMMON]: [ Species.AZURILL, Species.TAUROS, Species.MAREEP, Species.FARFETCHD, Species.TEDDIURSA, Species.SHROOMISH, Species.ELECTRIKE, Species.BUDEW, Species.BUIZEL, Species.MUDBRAY, Species.STUFFUL ], + [TrainerPoolTier.RARE]: [ Species.EEVEE, Species.SCYTHER, Species.KANGASKHAN, Species.RALTS, Species.MUNCHLAX, Species.ZORUA, Species.PALDEA_TAUROS, Species.TINKATINK, Species.CYCLIZAR, Species.FLAMIGO ], + [TrainerPoolTier.SUPER_RARE]: [ Species.LARVESTA ], }), [TrainerType.RICH]: new TrainerConfig(++t).setMoneyMultiplier(5).setName("Gentleman").setHasGenders("Madame").setHasDouble("Rich Couple"), [TrainerType.RICH_KID]: new TrainerConfig(++t).setMoneyMultiplier(3.75).setName("Rich Boy").setHasGenders("Lady").setHasDouble("Rich Kids").setEncounterBgm(TrainerType.RICH), @@ -1405,121 +1467,153 @@ export const trainerConfigs: TrainerConfigs = { [TrainerType.SAILOR]: new TrainerConfig(++t).setMoneyMultiplier(1.4).setEncounterBgm(TrainerType.BACKPACKER).setSpeciesFilter(s => s.isOfType(Type.WATER) || s.isOfType(Type.FIGHTING)), [TrainerType.SCIENTIST]: new TrainerConfig(++t).setHasGenders("Scientist Female").setHasDouble("Scientists").setMoneyMultiplier(1.7).setEncounterBgm(TrainerType.SCIENTIST) .setSpeciesPools({ - [TrainerPoolTier.COMMON]: [Species.MAGNEMITE, Species.GRIMER, Species.DROWZEE, Species.VOLTORB, Species.KOFFING], - [TrainerPoolTier.UNCOMMON]: [Species.BALTOY, Species.BRONZOR, Species.FERROSEED, Species.KLINK, Species.CHARJABUG, Species.BLIPBUG, Species.HELIOPTILE], - [TrainerPoolTier.RARE]: [Species.ABRA, Species.DITTO, Species.PORYGON, Species.ELEKID, Species.SOLOSIS, Species.GALAR_WEEZING], - [TrainerPoolTier.SUPER_RARE]: [Species.OMANYTE, Species.KABUTO, Species.AERODACTYL, Species.LILEEP, Species.ANORITH, Species.CRANIDOS, Species.SHIELDON, Species.TIRTOUGA, Species.ARCHEN, Species.ARCTOVISH, Species.ARCTOZOLT, Species.DRACOVISH, Species.DRACOZOLT], - [TrainerPoolTier.ULTRA_RARE]: [Species.ROTOM, Species.MELTAN] + [TrainerPoolTier.COMMON]: [ Species.MAGNEMITE, Species.GRIMER, Species.DROWZEE, Species.VOLTORB, Species.KOFFING ], + [TrainerPoolTier.UNCOMMON]: [ Species.BALTOY, Species.BRONZOR, Species.FERROSEED, Species.KLINK, Species.CHARJABUG, Species.BLIPBUG, Species.HELIOPTILE ], + [TrainerPoolTier.RARE]: [ Species.ABRA, Species.DITTO, Species.PORYGON, Species.ELEKID, Species.SOLOSIS, Species.GALAR_WEEZING ], + [TrainerPoolTier.SUPER_RARE]: [ Species.OMANYTE, Species.KABUTO, Species.AERODACTYL, Species.LILEEP, Species.ANORITH, Species.CRANIDOS, Species.SHIELDON, Species.TIRTOUGA, Species.ARCHEN, Species.ARCTOVISH, Species.ARCTOZOLT, Species.DRACOVISH, Species.DRACOZOLT ], + [TrainerPoolTier.ULTRA_RARE]: [ Species.ROTOM, Species.MELTAN ] }), [TrainerType.SMASHER]: new TrainerConfig(++t).setMoneyMultiplier(1.2).setEncounterBgm(TrainerType.CYCLIST), - [TrainerType.SNOW_WORKER]: new TrainerConfig(++t).setName("Worker").setHasGenders("Worker Female").setHasDouble("Workers").setMoneyMultiplier(1.7).setEncounterBgm(TrainerType.CLERK).setSpeciesFilter(s => s.isOfType(Type.ICE) || s.isOfType(Type.STEEL)), + [TrainerType.SNOW_WORKER]: new TrainerConfig(++t).setName("Worker").setHasDouble("Workers").setMoneyMultiplier(1.7).setEncounterBgm(TrainerType.CLERK).setSpeciesFilter(s => s.isOfType(Type.ICE) || s.isOfType(Type.STEEL)), [TrainerType.STRIKER]: new TrainerConfig(++t).setMoneyMultiplier(1.2).setEncounterBgm(TrainerType.CYCLIST), [TrainerType.SCHOOL_KID]: new TrainerConfig(++t).setMoneyMultiplier(0.75).setEncounterBgm(TrainerType.YOUNGSTER).setHasGenders("School Kid Female", "lass").setHasDouble("School Kids") .setSpeciesPools({ - [TrainerPoolTier.COMMON]: [Species.ODDISH, Species.EXEGGCUTE, Species.TEDDIURSA, Species.WURMPLE, Species.RALTS, Species.SHROOMISH, Species.FLETCHLING], - [TrainerPoolTier.UNCOMMON]: [Species.VOLTORB, Species.WHISMUR, Species.MEDITITE, Species.MIME_JR, Species.NYMBLE], - [TrainerPoolTier.RARE]: [Species.TANGELA, Species.EEVEE, Species.YANMA], - [TrainerPoolTier.SUPER_RARE]: [Species.TADBULB] + [TrainerPoolTier.COMMON]: [ Species.ODDISH, Species.EXEGGCUTE, Species.TEDDIURSA, Species.WURMPLE, Species.RALTS, Species.SHROOMISH, Species.FLETCHLING ], + [TrainerPoolTier.UNCOMMON]: [ Species.VOLTORB, Species.WHISMUR, Species.MEDITITE, Species.MIME_JR, Species.NYMBLE ], + [TrainerPoolTier.RARE]: [ Species.TANGELA, Species.EEVEE, Species.YANMA ], + [TrainerPoolTier.SUPER_RARE]: [ Species.TADBULB ] }), [TrainerType.SWIMMER]: new TrainerConfig(++t).setMoneyMultiplier(1.3).setEncounterBgm(TrainerType.PARASOL_LADY).setHasGenders("Swimmer Female").setHasDouble("Swimmers").setSpecialtyTypes(Type.WATER).setSpeciesFilter(s => s.isOfType(Type.WATER)), [TrainerType.TWINS]: new TrainerConfig(++t).setDoubleOnly().setMoneyMultiplier(0.65).setUseSameSeedForAllMembers() .setPartyTemplateFunc(scene => getWavePartyTemplate(scene, trainerPartyTemplates.TWO_WEAK, trainerPartyTemplates.TWO_AVG, trainerPartyTemplates.TWO_STRONG)) - .setPartyMemberFunc(0, getRandomPartyMemberFunc([Species.PLUSLE, Species.VOLBEAT, Species.PACHIRISU, Species.SILCOON, Species.METAPOD, Species.IGGLYBUFF, Species.PETILIL, Species.EEVEE])) - .setPartyMemberFunc(1, getRandomPartyMemberFunc([Species.MINUN, Species.ILLUMISE, Species.EMOLGA, Species.CASCOON, Species.KAKUNA, Species.CLEFFA, Species.COTTONEE, Species.EEVEE], TrainerSlot.TRAINER_PARTNER)) + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.PLUSLE, Species.VOLBEAT, Species.PACHIRISU, Species.SILCOON, Species.METAPOD, Species.IGGLYBUFF, Species.PETILIL, Species.EEVEE ])) + .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.MINUN, Species.ILLUMISE, Species.EMOLGA, Species.CASCOON, Species.KAKUNA, Species.CLEFFA, Species.COTTONEE, Species.EEVEE ], TrainerSlot.TRAINER_PARTNER)) .setEncounterBgm(TrainerType.TWINS), [TrainerType.VETERAN]: new TrainerConfig(++t).setHasGenders("Veteran Female").setHasDouble("Veteran Duo").setMoneyMultiplier(2.5).setEncounterBgm(TrainerType.ACE_TRAINER).setSpeciesFilter(s => s.isOfType(Type.DRAGON)), [TrainerType.WAITER]: new TrainerConfig(++t).setHasGenders("Waitress").setHasDouble("Restaurant Staff").setMoneyMultiplier(1.5).setEncounterBgm(TrainerType.CLERK) .setSpeciesPools({ - [TrainerPoolTier.COMMON]: [Species.CLEFFA, Species.CHATOT, Species.PANSAGE, Species.PANSEAR, Species.PANPOUR, Species.MINCCINO], - [TrainerPoolTier.UNCOMMON]: [Species.TROPIUS, Species.PETILIL, Species.BOUNSWEET, Species.INDEEDEE], - [TrainerPoolTier.RARE]: [Species.APPLIN, Species.SINISTEA, Species.POLTCHAGEIST] + [TrainerPoolTier.COMMON]: [ Species.CLEFFA, Species.CHATOT, Species.PANSAGE, Species.PANSEAR, Species.PANPOUR, Species.MINCCINO ], + [TrainerPoolTier.UNCOMMON]: [ Species.TROPIUS, Species.PETILIL, Species.BOUNSWEET, Species.INDEEDEE ], + [TrainerPoolTier.RARE]: [ Species.APPLIN, Species.SINISTEA, Species.POLTCHAGEIST ] }), [TrainerType.WORKER]: new TrainerConfig(++t).setHasGenders("Worker Female").setHasDouble("Workers").setEncounterBgm(TrainerType.CLERK).setMoneyMultiplier(1.7).setSpeciesFilter(s => s.isOfType(Type.ROCK) || s.isOfType(Type.STEEL)), [TrainerType.YOUNGSTER]: new TrainerConfig(++t).setMoneyMultiplier(0.5).setEncounterBgm(TrainerType.YOUNGSTER).setHasGenders("Lass", "lass").setHasDouble("Beginners").setPartyTemplates(trainerPartyTemplates.TWO_WEAKER) .setSpeciesPools( - [Species.CATERPIE, Species.WEEDLE, Species.RATTATA, Species.SENTRET, Species.POOCHYENA, Species.ZIGZAGOON, Species.WURMPLE, Species.BIDOOF, Species.PATRAT, Species.LILLIPUP] + [ Species.CATERPIE, Species.WEEDLE, Species.RATTATA, Species.SENTRET, Species.POOCHYENA, Species.ZIGZAGOON, Species.WURMPLE, Species.BIDOOF, Species.PATRAT, Species.LILLIPUP ] ), [TrainerType.ROCKET_GRUNT]: new TrainerConfig(++t).setHasGenders("Rocket Grunt Female").setHasDouble("Rocket Grunts").setMoneyMultiplier(1.0).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_rocket_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)) .setSpeciesPools({ - [TrainerPoolTier.COMMON]: [Species.WEEDLE, Species.RATTATA, Species.EKANS, Species.SANDSHREW, Species.ZUBAT, Species.GEODUDE, Species.KOFFING, Species.GRIMER, Species.ODDISH, Species.SLOWPOKE], - [TrainerPoolTier.UNCOMMON]: [Species.GYARADOS, Species.LICKITUNG, Species.TAUROS, Species.MANKEY, Species.SCYTHER, Species.ELEKID, Species.MAGBY, Species.CUBONE, Species.GROWLITHE, Species.MURKROW, Species.GASTLY, Species.EXEGGCUTE, Species.VOLTORB, Species.MAGNEMITE], - [TrainerPoolTier.RARE]: [Species.PORYGON, Species.ALOLA_RATTATA, Species.ALOLA_SANDSHREW, Species.ALOLA_MEOWTH, Species.ALOLA_GRIMER, Species.ALOLA_GEODUDE, Species.PALDEA_TAUROS, Species.OMANYTE, Species.KABUTO], - [TrainerPoolTier.SUPER_RARE]: [Species.DRATINI, Species.LARVITAR] + [TrainerPoolTier.COMMON]: [ Species.WEEDLE, Species.RATTATA, Species.EKANS, Species.SANDSHREW, Species.ZUBAT, Species.GEODUDE, Species.KOFFING, Species.GRIMER, Species.ODDISH, Species.SLOWPOKE ], + [TrainerPoolTier.UNCOMMON]: [ Species.GYARADOS, Species.LICKITUNG, Species.TAUROS, Species.MANKEY, Species.SCYTHER, Species.ELEKID, Species.MAGBY, Species.CUBONE, Species.GROWLITHE, Species.MURKROW, Species.GASTLY, Species.EXEGGCUTE, Species.VOLTORB, Species.MAGNEMITE ], + [TrainerPoolTier.RARE]: [ Species.PORYGON, Species.ALOLA_RATTATA, Species.ALOLA_SANDSHREW, Species.ALOLA_MEOWTH, Species.ALOLA_GRIMER, Species.ALOLA_GEODUDE, Species.PALDEA_TAUROS, Species.OMANYTE, Species.KABUTO ], + [TrainerPoolTier.SUPER_RARE]: [ Species.DRATINI, Species.LARVITAR ] }), - [TrainerType.ARCHER]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("rocket_admin", "rocket", [Species.HOUNDOOM]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_rocket_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), - [TrainerType.ARIANA]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("rocket_admin_female", "rocket", [Species.ARBOK]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_rocket_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), - [TrainerType.PROTON]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("rocket_admin", "rocket", [Species.CROBAT]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_rocket_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), - [TrainerType.PETREL]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("rocket_admin", "rocket", [Species.WEEZING]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_rocket_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), + [TrainerType.ARCHER]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("rocket_admin", "rocket", [ Species.HOUNDOOM ]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_rocket_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), + [TrainerType.ARIANA]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("rocket_admin_female", "rocket", [ Species.ARBOK ]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_rocket_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), + [TrainerType.PROTON]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("rocket_admin", "rocket", [ Species.CROBAT ]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_rocket_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), + [TrainerType.PETREL]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("rocket_admin", "rocket", [ Species.WEEZING ]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_rocket_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), [TrainerType.MAGMA_GRUNT]: new TrainerConfig(++t).setHasGenders("Magma Grunt Female").setHasDouble("Magma Grunts").setMoneyMultiplier(1.0).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_aqua_magma_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)) .setSpeciesPools({ - [TrainerPoolTier.COMMON]: [Species.SLUGMA, Species.POOCHYENA, Species.NUMEL, Species.ZIGZAGOON, Species.DIGLETT, Species.MAGBY, Species.TORKOAL, Species.GROWLITHE, Species.BALTOY], - [TrainerPoolTier.UNCOMMON]: [Species.SOLROCK, Species.HIPPOPOTAS, Species.SANDACONDA, Species.PHANPY, Species.ROLYCOLY, Species.GLIGAR, Species.RHYHORN, Species.HEATMOR], - [TrainerPoolTier.RARE]: [Species.TRAPINCH, Species.LILEEP, Species.ANORITH, Species.HISUI_GROWLITHE, Species.TURTONATOR, Species.ARON], - [TrainerPoolTier.SUPER_RARE]: [Species.CAPSAKID, Species.CHARCADET] + [TrainerPoolTier.COMMON]: [ Species.SLUGMA, Species.POOCHYENA, Species.NUMEL, Species.ZIGZAGOON, Species.DIGLETT, Species.MAGBY, Species.TORKOAL, Species.GROWLITHE, Species.BALTOY ], + [TrainerPoolTier.UNCOMMON]: [ Species.SOLROCK, Species.HIPPOPOTAS, Species.SANDACONDA, Species.PHANPY, Species.ROLYCOLY, Species.GLIGAR, Species.RHYHORN, Species.HEATMOR ], + [TrainerPoolTier.RARE]: [ Species.TRAPINCH, Species.LILEEP, Species.ANORITH, Species.HISUI_GROWLITHE, Species.TURTONATOR, Species.ARON, Species.TOEDSCOOL ], + [TrainerPoolTier.SUPER_RARE]: [ Species.CAPSAKID, Species.CHARCADET ] }), - [TrainerType.TABITHA]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("magma_admin", "magma", [Species.CAMERUPT]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_aqua_magma_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), - [TrainerType.COURTNEY]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("magma_admin_female", "magma", [Species.CAMERUPT]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_aqua_magma_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), + [TrainerType.TABITHA]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("magma_admin", "magma", [ Species.CAMERUPT ]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_aqua_magma_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), + [TrainerType.COURTNEY]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("magma_admin_female", "magma", [ Species.CAMERUPT ]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_aqua_magma_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), [TrainerType.AQUA_GRUNT]: new TrainerConfig(++t).setHasGenders("Aqua Grunt Female").setHasDouble("Aqua Grunts").setMoneyMultiplier(1.0).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_aqua_magma_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)) .setSpeciesPools({ - [TrainerPoolTier.COMMON]: [Species.CARVANHA, Species.WAILMER, Species.ZIGZAGOON, Species.LOTAD, Species.CORPHISH, Species.SPHEAL, Species.REMORAID, Species.QWILFISH, Species.BARBOACH], - [TrainerPoolTier.UNCOMMON]: [Species.CLAMPERL, Species.CHINCHOU, Species.WOOPER, Species.WINGULL, Species.TENTACOOL, Species.AZURILL, Species.CLOBBOPUS, Species.HORSEA], - [TrainerPoolTier.RARE]: [Species.MANTINE, Species.DHELMISE, Species.HISUI_QWILFISH, Species.ARROKUDA, Species.PALDEA_WOOPER, Species.SKRELP], - [TrainerPoolTier.SUPER_RARE]: [Species.DONDOZO, Species.BASCULEGION] + [TrainerPoolTier.COMMON]: [ Species.CARVANHA, Species.WAILMER, Species.ZIGZAGOON, Species.LOTAD, Species.CORPHISH, Species.SPHEAL, Species.REMORAID, Species.QWILFISH, Species.BARBOACH ], + [TrainerPoolTier.UNCOMMON]: [ Species.CLAMPERL, Species.CHINCHOU, Species.WOOPER, Species.WINGULL, Species.TENTACOOL, Species.AZURILL, Species.CLOBBOPUS, Species.HORSEA ], + [TrainerPoolTier.RARE]: [ Species.MANTYKE, Species.DHELMISE, Species.HISUI_QWILFISH, Species.ARROKUDA, Species.PALDEA_WOOPER, Species.SKRELP ], + [TrainerPoolTier.SUPER_RARE]: [ Species.DONDOZO, Species.BASCULEGION ] }), - [TrainerType.MATT]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("aqua_admin", "aqua", [Species.SHARPEDO]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_aqua_magma_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), - [TrainerType.SHELLY]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("aqua_admin_female", "aqua", [Species.SHARPEDO]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_aqua_magma_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), + [TrainerType.MATT]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("aqua_admin", "aqua", [ Species.SHARPEDO ]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_aqua_magma_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), + [TrainerType.SHELLY]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("aqua_admin_female", "aqua", [ Species.SHARPEDO ]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_aqua_magma_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), [TrainerType.GALACTIC_GRUNT]: new TrainerConfig(++t).setHasGenders("Galactic Grunt Female").setHasDouble("Galactic Grunts").setMoneyMultiplier(1.0).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_galactic_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)) .setSpeciesPools({ - [TrainerPoolTier.COMMON]: [Species.GLAMEOW, Species.STUNKY, Species.CROAGUNK, Species.SHINX, Species.WURMPLE, Species.BRONZOR, Species.DRIFLOON, Species.BURMY, Species.CARNIVINE], - [TrainerPoolTier.UNCOMMON]: [Species.LICKITUNG, Species.RHYHORN, Species.TANGELA, Species.ZUBAT, Species.YANMA, Species.SKORUPI, Species.GLIGAR, Species.SWINUB], - [TrainerPoolTier.RARE]: [Species.HISUI_GROWLITHE, Species.HISUI_QWILFISH, Species.SNEASEL, Species.ELEKID, Species.MAGBY, Species.DUSKULL], - [TrainerPoolTier.SUPER_RARE]: [Species.ROTOM, Species.SPIRITOMB, Species.HISUI_SNEASEL] + [TrainerPoolTier.COMMON]: [ Species.GLAMEOW, Species.STUNKY, Species.CROAGUNK, Species.SHINX, Species.WURMPLE, Species.BRONZOR, Species.DRIFLOON, Species.BURMY, Species.CARNIVINE ], + [TrainerPoolTier.UNCOMMON]: [ Species.LICKITUNG, Species.RHYHORN, Species.TANGELA, Species.ZUBAT, Species.YANMA, Species.SKORUPI, Species.GLIGAR, Species.SWINUB ], + [TrainerPoolTier.RARE]: [ Species.HISUI_GROWLITHE, Species.HISUI_QWILFISH, Species.SNEASEL, Species.ELEKID, Species.MAGBY, Species.DUSKULL ], + [TrainerPoolTier.SUPER_RARE]: [ Species.ROTOM, Species.SPIRITOMB, Species.HISUI_SNEASEL ] }), - [TrainerType.JUPITER]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("galactic_commander_female", "galactic", [Species.SKUNTANK]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_galactic_admin").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), - [TrainerType.MARS]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("galactic_commander_female", "galactic", [Species.PURUGLY]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_galactic_admin").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), - [TrainerType.SATURN]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("galactic_commander", "galactic", [Species.TOXICROAK]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_galactic_admin").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), + [TrainerType.JUPITER]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("galactic_commander_female", "galactic", [ Species.SKUNTANK ]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_galactic_admin").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), + [TrainerType.MARS]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("galactic_commander_female", "galactic", [ Species.PURUGLY ]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_galactic_admin").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), + [TrainerType.SATURN]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("galactic_commander", "galactic", [ Species.TOXICROAK ]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_galactic_admin").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), [TrainerType.PLASMA_GRUNT]: new TrainerConfig(++t).setHasGenders("Plasma Grunt Female").setHasDouble("Plasma Grunts").setMoneyMultiplier(1.0).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_plasma_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)) .setSpeciesPools({ - [TrainerPoolTier.COMMON]: [Species.PATRAT, Species.LILLIPUP, Species.PURRLOIN, Species.SCRAFTY, Species.WOOBAT, Species.VANILLITE, Species.SANDILE, Species.TRUBBISH, Species.TYMPOLE], - [TrainerPoolTier.UNCOMMON]: [Species.FRILLISH, Species.VENIPEDE, Species.GOLETT, Species.TIMBURR, Species.DARUMAKA, Species.FOONGUS, Species.JOLTIK], - [TrainerPoolTier.RARE]: [Species.PAWNIARD, Species.RUFFLET, Species.VULLABY, Species.ZORUA, Species.DRILBUR, Species.KLINK, Species.CUBCHOO, Species.MIENFOO, Species.DURANT, Species.BOUFFALANT], - [TrainerPoolTier.SUPER_RARE]: [Species.DRUDDIGON, Species.HISUI_ZORUA, Species.AXEW, Species.DEINO] + [TrainerPoolTier.COMMON]: [ Species.PATRAT, Species.LILLIPUP, Species.PURRLOIN, Species.SCRAFTY, Species.WOOBAT, Species.VANILLITE, Species.SANDILE, Species.TRUBBISH, Species.TYMPOLE ], + [TrainerPoolTier.UNCOMMON]: [ Species.FRILLISH, Species.VENIPEDE, Species.GOLETT, Species.TIMBURR, Species.DARUMAKA, Species.FOONGUS, Species.JOLTIK, Species.CUBCHOO, Species.KLINK ], + [TrainerPoolTier.RARE]: [ Species.PAWNIARD, Species.RUFFLET, Species.VULLABY, Species.ZORUA, Species.DRILBUR, Species.MIENFOO, Species.DURANT, Species.BOUFFALANT ], + [TrainerPoolTier.SUPER_RARE]: [ Species.DRUDDIGON, Species.HISUI_ZORUA, Species.AXEW, Species.DEINO ] }), - [TrainerType.ZINZOLIN]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("plasma_sage", "plasma", [Species.CRYOGONAL]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_plasma_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), - [TrainerType.ROOD]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("plasma_sage", "plasma", [Species.SWOOBAT]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_plasma_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), + [TrainerType.ZINZOLIN]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("plasma_sage", "plasma", [ Species.CRYOGONAL ]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_plasma_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), + [TrainerType.ROOD]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("plasma_sage", "plasma", [ Species.SWOOBAT ]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_plasma_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), [TrainerType.FLARE_GRUNT]: new TrainerConfig(++t).setHasGenders("Flare Grunt Female").setHasDouble("Flare Grunts").setMoneyMultiplier(1.0).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_flare_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)) .setSpeciesPools({ - [TrainerPoolTier.COMMON]: [Species.FLETCHLING, Species.LITLEO, Species.PONYTA, Species.INKAY, Species.HOUNDOUR, Species.SKORUPI, Species.SCRAFTY, Species.CROAGUNK, Species.SCATTERBUG, Species.ESPURR], - [TrainerPoolTier.UNCOMMON]: [Species.HELIOPTILE, Species.ELECTRIKE, Species.SKRELP, Species.PANCHAM, Species.PURRLOIN, Species.POOCHYENA, Species.BINACLE, Species.CLAUNCHER, Species.PUMPKABOO, Species.PHANTUMP], - [TrainerPoolTier.RARE]: [Species.LITWICK, Species.SNEASEL, Species.PAWNIARD, Species.BERGMITE, Species.SLIGGOO], - [TrainerPoolTier.SUPER_RARE]: [Species.NOIVERN, Species.HISUI_SLIGGOO, Species.HISUI_AVALUGG] + [TrainerPoolTier.COMMON]: [ Species.FLETCHLING, Species.LITLEO, Species.PONYTA, Species.INKAY, Species.HOUNDOUR, Species.SKORUPI, Species.SCRAFTY, Species.CROAGUNK, Species.SCATTERBUG, Species.ESPURR ], + [TrainerPoolTier.UNCOMMON]: [ Species.HELIOPTILE, Species.ELECTRIKE, Species.SKRELP, Species.PANCHAM, Species.PURRLOIN, Species.POOCHYENA, Species.BINACLE, Species.CLAUNCHER, Species.PUMPKABOO, Species.PHANTUMP, Species.FOONGUS ], + [TrainerPoolTier.RARE]: [ Species.LITWICK, Species.SNEASEL, Species.PAWNIARD, Species.SLIGGOO ], + [TrainerPoolTier.SUPER_RARE]: [ Species.NOIBAT, Species.HISUI_SLIGGOO, Species.HISUI_AVALUGG ] }), - [TrainerType.BRYONY]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("flare_admin_female", "flare", [Species.LIEPARD]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_flare_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), - [TrainerType.XEROSIC]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("flare_admin", "flare", [Species.MALAMAR]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_flare_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), + [TrainerType.BRYONY]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("flare_admin_female", "flare", [ Species.LIEPARD ]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_flare_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), + [TrainerType.XEROSIC]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("flare_admin", "flare", [ Species.MALAMAR ]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_flare_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), [TrainerType.AETHER_GRUNT]: new TrainerConfig(++t).setHasGenders("Aether Grunt Female").setHasDouble("Aether Grunts").setMoneyMultiplier(1.0).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_aether_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)) .setSpeciesPools({ - [TrainerPoolTier.COMMON]: [ Species.PIKIPEK, Species.ROCKRUFF, Species.ALOLA_DIGLETT, Species.ALOLA_EXEGGUTOR, Species.YUNGOOS, Species.CORSOLA, Species.ALOLA_GEODUDE, Species.ALOLA_RAICHU, Species.BOUNSWEET, Species.LILLIPUP, Species.KOMALA, Species.MORELULL, Species.COMFEY, Species.TOGEDEMARU], - [TrainerPoolTier.UNCOMMON]: [ Species.POLIWAG, Species.STUFFUL, Species.ORANGURU, Species.PASSIMIAN, Species.BRUXISH, Species.MINIOR, Species.WISHIWASHI, Species.CRABRAWLER, Species.CUTIEFLY, Species.ORICORIO, Species.MUDBRAY, Species.PYUKUMUKU, Species.ALOLA_MAROWAK], - [TrainerPoolTier.RARE]: [ Species.GALAR_CORSOLA, Species.ALOLA_SANDSHREW, Species.ALOLA_VULPIX, Species.TURTONATOR, Species.DRAMPA], - [TrainerPoolTier.SUPER_RARE]: [Species.JANGMO_O, Species.PORYGON] + [TrainerPoolTier.COMMON]: [ Species.PIKIPEK, Species.ROCKRUFF, Species.ALOLA_DIGLETT, Species.ALOLA_EXEGGUTOR, Species.YUNGOOS, Species.CORSOLA, Species.ALOLA_GEODUDE, Species.ALOLA_RAICHU, Species.BOUNSWEET, Species.LILLIPUP, Species.KOMALA, Species.MORELULL, Species.COMFEY, Species.TOGEDEMARU ], + [TrainerPoolTier.UNCOMMON]: [ Species.POLIWAG, Species.STUFFUL, Species.ORANGURU, Species.PASSIMIAN, Species.BRUXISH, Species.MINIOR, Species.WISHIWASHI, Species.ALOLA_SANDSHREW, Species.ALOLA_VULPIX, Species.CRABRAWLER, Species.CUTIEFLY, Species.ORICORIO, Species.MUDBRAY, Species.PYUKUMUKU, Species.ALOLA_MAROWAK ], + [TrainerPoolTier.RARE]: [ Species.GALAR_CORSOLA, Species.TURTONATOR, Species.MIMIKYU, Species.MAGNEMITE, Species.DRAMPA ], + [TrainerPoolTier.SUPER_RARE]: [ Species.JANGMO_O, Species.PORYGON ] }), - [TrainerType.FABA]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("aether_admin", "aether", [Species.HYPNO]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_aether_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), + [TrainerType.FABA]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("aether_admin", "aether", [ Species.HYPNO ]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_aether_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), [TrainerType.SKULL_GRUNT]: new TrainerConfig(++t).setHasGenders("Skull Grunt Female").setHasDouble("Skull Grunts").setMoneyMultiplier(1.0).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_skull_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)) .setSpeciesPools({ - [TrainerPoolTier.COMMON]: [ Species.SALANDIT, Species.ALOLA_RATTATA, Species.EKANS, Species.ALOLA_MEOWTH, Species.SCRAGGY, Species.KOFFING, Species.ALOLA_GRIMER, Species.MAREANIE, Species.SPINARAK, Species.TRUBBISH], - [TrainerPoolTier.UNCOMMON]: [ Species.FOMANTIS, Species.SABLEYE, Species.SANDILE, Species.HOUNDOUR, Species.ALOLA_MAROWAK, Species.GASTLY, Species.PANCHAM, Species.DROWZEE, Species.ZUBAT, Species.VENIPEDE, Species.VULLABY], - [TrainerPoolTier.RARE]: [Species.SANDYGAST, Species.PAWNIARD, Species.MIMIKYU, Species.DHELMISE, Species.WISHIWASHI, Species.NYMBLE], - [TrainerPoolTier.SUPER_RARE]: [Species.GRUBBIN, Species.DEWPIDER] + [TrainerPoolTier.COMMON]: [ Species.SALANDIT, Species.ALOLA_RATTATA, Species.EKANS, Species.ALOLA_MEOWTH, Species.SCRAGGY, Species.KOFFING, Species.ALOLA_GRIMER, Species.MAREANIE, Species.SPINARAK, Species.TRUBBISH, Species.DROWZEE ], + [TrainerPoolTier.UNCOMMON]: [ Species.FOMANTIS, Species.SABLEYE, Species.SANDILE, Species.HOUNDOUR, Species.ALOLA_MAROWAK, Species.GASTLY, Species.PANCHAM, Species.ZUBAT, Species.VENIPEDE, Species.VULLABY ], + [TrainerPoolTier.RARE]: [ Species.SANDYGAST, Species.PAWNIARD, Species.MIMIKYU, Species.DHELMISE, Species.WISHIWASHI, Species.NYMBLE ], + [TrainerPoolTier.SUPER_RARE]: [ Species.GRUBBIN, Species.DEWPIDER ] }), - [TrainerType.PLUMERIA]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("skull_admin", "skull", [Species.SALAZZLE]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_skull_admin").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), + [TrainerType.PLUMERIA]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("skull_admin", "skull", [ Species.SALAZZLE ]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_skull_admin").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), [TrainerType.MACRO_GRUNT]: new TrainerConfig(++t).setHasGenders("Macro Grunt Female").setHasDouble("Macro Grunts").setMoneyMultiplier(1.0).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_macro_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)) .setSpeciesPools({ - [TrainerPoolTier.COMMON]: [ Species.CUFANT, Species.GALAR_MEOWTH, Species.KLINK, Species.ROOKIDEE, Species.CRAMORANT, Species.GALAR_ZIGZAGOON, Species.SKWOVET, Species.STEELIX, Species.MAWILE, Species.FERROSEED], - [TrainerPoolTier.UNCOMMON]: [ Species.DRILBUR, Species.MAGNEMITE, Species.HATENNA, Species.ARROKUDA, Species.APPLIN, Species.GALAR_PONYTA, Species.GALAR_YAMASK, Species.SINISTEA, Species.RIOLU], - [TrainerPoolTier.RARE]: [Species.FALINKS, Species.BELDUM, Species.GALAR_FARFETCHD, Species.GALAR_MR_MIME, Species.HONEDGE, Species.SCIZOR, Species.GALAR_DARUMAKA], - [TrainerPoolTier.SUPER_RARE]: [Species.DURALUDON, Species.DREEPY] + [TrainerPoolTier.COMMON]: [ Species.CUFANT, Species.GALAR_MEOWTH, Species.KLINK, Species.ROOKIDEE, Species.CRAMORANT, Species.GALAR_ZIGZAGOON, Species.SKWOVET, Species.STEELIX, Species.MAWILE, Species.FERROSEED ], + [TrainerPoolTier.UNCOMMON]: [ Species.DRILBUR, Species.MAGNEMITE, Species.HATENNA, Species.ARROKUDA, Species.APPLIN, Species.GALAR_PONYTA, Species.GALAR_YAMASK, Species.SINISTEA, Species.RIOLU ], + [TrainerPoolTier.RARE]: [ Species.FALINKS, Species.BELDUM, Species.GALAR_FARFETCHD, Species.GALAR_MR_MIME, Species.HONEDGE, Species.SCIZOR, Species.GALAR_DARUMAKA ], + [TrainerPoolTier.SUPER_RARE]: [ Species.DURALUDON, Species.DREEPY ] }), - [TrainerType.OLEANA]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("macro_admin", "macro", [Species.GARBODOR]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_oleana").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), + [TrainerType.OLEANA]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("macro_admin", "macro", [ Species.GARBODOR ]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_oleana").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)), + [TrainerType.STAR_GRUNT]: new TrainerConfig(++t).setHasGenders("Star Grunt Female").setHasDouble("Star Grunts").setMoneyMultiplier(1.0).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_star_grunt").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)) + .setSpeciesPools({ + [TrainerPoolTier.COMMON]: [ Species.DUNSPARCE, Species.HOUNDOUR, Species.AZURILL, Species.GULPIN, Species.FOONGUS, Species.FLETCHLING, Species.LITLEO, Species.FLABEBE, Species.CRABRAWLER, Species.NYMBLE, Species.PAWMI, Species.FIDOUGH, Species.SQUAWKABILLY, Species.MASCHIFF, Species.SHROODLE, Species.KLAWF, Species.WIGLETT, Species.PALDEA_WOOPER ], + [TrainerPoolTier.UNCOMMON]: [ Species.KOFFING, Species.EEVEE, Species.GIRAFARIG, Species.RALTS, Species.TORKOAL, Species.SEVIPER, Species.SCRAGGY, Species.ZORUA, Species.MIMIKYU, Species.IMPIDIMP, Species.FALINKS, Species.CAPSAKID, Species.TINKATINK, Species.BOMBIRDIER, Species.CYCLIZAR, Species.FLAMIGO, Species.PALDEA_TAUROS ], + [TrainerPoolTier.RARE]: [ Species.MANKEY, Species.PAWNIARD, Species.CHARCADET, Species.FLITTLE, Species.VAROOM, Species.ORTHWORM ], + [TrainerPoolTier.SUPER_RARE]: [ Species.DONDOZO, Species.GIMMIGHOUL ] + }), + [TrainerType.GIACOMO]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("star_admin", "star_1", [ Species.KINGAMBIT ]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_star_admin").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)) + .setPartyMemberFunc(3, getRandomPartyMemberFunc([ Species.REVAVROOM ], TrainerSlot.TRAINER, true, p => { + p.formIndex = 1; // Segin Starmobile + p.moveset = [ new PokemonMove(Moves.WICKED_TORQUE), new PokemonMove(Moves.SPIN_OUT), new PokemonMove(Moves.SHIFT_GEAR), new PokemonMove(Moves.HIGH_HORSEPOWER) ]; + })), + [TrainerType.MELA]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("star_admin", "star_2", [ Species.ARMAROUGE ]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_star_admin").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)) + .setPartyMemberFunc(3, getRandomPartyMemberFunc([ Species.REVAVROOM ], TrainerSlot.TRAINER, true, p => { + p.formIndex = 2; // Schedar Starmobile + p.moveset = [ new PokemonMove(Moves.BLAZING_TORQUE), new PokemonMove(Moves.SPIN_OUT), new PokemonMove(Moves.SHIFT_GEAR), new PokemonMove(Moves.HIGH_HORSEPOWER) ]; + })), + [TrainerType.ATTICUS]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("star_admin", "star_3", [ Species.REVAVROOM ]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_star_admin").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)) + .setPartyMemberFunc(3, getRandomPartyMemberFunc([ Species.REVAVROOM ], TrainerSlot.TRAINER, true, p => { + p.formIndex = 3; // Navi Starmobile + p.moveset = [ new PokemonMove(Moves.NOXIOUS_TORQUE), new PokemonMove(Moves.SPIN_OUT), new PokemonMove(Moves.SHIFT_GEAR), new PokemonMove(Moves.HIGH_HORSEPOWER) ]; + })), + [TrainerType.ORTEGA]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("star_admin", "star_4", [ Species.DACHSBUN ]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_star_admin").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)) + .setPartyMemberFunc(3, getRandomPartyMemberFunc([ Species.REVAVROOM ], TrainerSlot.TRAINER, true, p => { + p.formIndex = 4; // Ruchbah Starmobile + p.moveset = [ new PokemonMove(Moves.MAGICAL_TORQUE), new PokemonMove(Moves.SPIN_OUT), new PokemonMove(Moves.SHIFT_GEAR), new PokemonMove(Moves.HIGH_HORSEPOWER) ]; + })), + [TrainerType.ERI]: new TrainerConfig(++t).setMoneyMultiplier(1.5).initForEvilTeamAdmin("star_admin", "star_5", [ Species.ANNIHILAPE ]).setEncounterBgm(TrainerType.PLASMA_GRUNT).setBattleBgm("battle_plasma_grunt").setMixedBattleBgm("battle_star_admin").setVictoryBgm("victory_team_plasma").setPartyTemplateFunc(scene => getEvilGruntPartyTemplate(scene)) + .setPartyMemberFunc(3, getRandomPartyMemberFunc([ Species.REVAVROOM ], TrainerSlot.TRAINER, true, p => { + p.formIndex = 5; // Caph Starmobile + p.moveset = [ new PokemonMove(Moves.COMBAT_TORQUE), new PokemonMove(Moves.SPIN_OUT), new PokemonMove(Moves.SHIFT_GEAR), new PokemonMove(Moves.HIGH_HORSEPOWER) ]; + })), [TrainerType.BROCK]: new TrainerConfig((t = TrainerType.BROCK)).initForGymLeader(signatureSpecies["BROCK"], true, Type.ROCK).setBattleBgm("battle_kanto_gym").setMixedBattleBgm("battle_kanto_gym"), [TrainerType.MISTY]: new TrainerConfig(++t).initForGymLeader(signatureSpecies["MISTY"], false, Type.WATER).setBattleBgm("battle_kanto_gym").setMixedBattleBgm("battle_kanto_gym"), @@ -1639,141 +1733,150 @@ export const trainerConfigs: TrainerConfigs = { [TrainerType.DRAYTON]: new TrainerConfig(++t).initForEliteFour(signatureSpecies["DRAYTON"], true, Type.DRAGON).setMixedBattleBgm("battle_bb_elite"), [TrainerType.BLUE]: new TrainerConfig((t = TrainerType.BLUE)).initForChampion(signatureSpecies["BLUE"], true).setBattleBgm("battle_kanto_champion").setMixedBattleBgm("battle_kanto_champion").setHasDouble("blue_red_double").setDoubleTrainerType(TrainerType.RED).setDoubleTitle("champion_double") - .setPartyMemberFunc(0, getRandomPartyMemberFunc([Species.ALAKAZAM], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.ALAKAZAM ], TrainerSlot.TRAINER, true, p => { p.generateAndPopulateMoveset(); })) - .setPartyMemberFunc(1, getRandomPartyMemberFunc([Species.PIDGEOT], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.PIDGEOT ], TrainerSlot.TRAINER, true, p => { p.formIndex = 1; // Mega Pidgeot p.generateAndPopulateMoveset(); p.generateName(); })), [TrainerType.RED]: new TrainerConfig(++t).initForChampion(signatureSpecies["RED"], true).setBattleBgm("battle_johto_champion").setMixedBattleBgm("battle_johto_champion").setHasDouble("red_blue_double").setDoubleTrainerType(TrainerType.BLUE).setDoubleTitle("champion_double") - .setPartyMemberFunc(0, getRandomPartyMemberFunc([Species.PIKACHU], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.PIKACHU ], TrainerSlot.TRAINER, true, p => { p.formIndex = 8; // G-Max Pikachu p.generateAndPopulateMoveset(); p.generateName(); })) - .setPartyMemberFunc(1, getRandomPartyMemberFunc([Species.VENUSAUR, Species.CHARIZARD, Species.BLASTOISE], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.VENUSAUR, Species.CHARIZARD, Species.BLASTOISE ], TrainerSlot.TRAINER, true, p => { p.formIndex = 1; // Mega Venusaur, Mega Charizard X, or Mega Blastoise p.generateAndPopulateMoveset(); p.generateName(); })), [TrainerType.LANCE_CHAMPION]: new TrainerConfig(++t).setName("Lance").initForChampion(signatureSpecies["LANCE_CHAMPION"], true).setBattleBgm("battle_johto_champion").setMixedBattleBgm("battle_johto_champion") - .setPartyMemberFunc(0, getRandomPartyMemberFunc([Species.AERODACTYL], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.AERODACTYL ], TrainerSlot.TRAINER, true, p => { p.generateAndPopulateMoveset(); })) - .setPartyMemberFunc(1, getRandomPartyMemberFunc([Species.LATIAS, Species.LATIOS], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.LATIAS, Species.LATIOS ], TrainerSlot.TRAINER, true, p => { p.formIndex = 1; // Mega Latias or Mega Latios p.generateAndPopulateMoveset(); p.generateName(); })), [TrainerType.STEVEN]: new TrainerConfig(++t).initForChampion(signatureSpecies["STEVEN"], true).setBattleBgm("battle_hoenn_champion_g5").setMixedBattleBgm("battle_hoenn_champion_g6").setHasDouble("steven_wallace_double").setDoubleTrainerType(TrainerType.WALLACE).setDoubleTitle("champion_double") - .setPartyMemberFunc(0, getRandomPartyMemberFunc([Species.SKARMORY], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.SKARMORY ], TrainerSlot.TRAINER, true, p => { p.generateAndPopulateMoveset(); })) - .setPartyMemberFunc(1, getRandomPartyMemberFunc([Species.METAGROSS], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.METAGROSS ], TrainerSlot.TRAINER, true, p => { p.formIndex = 1; // Mega Metagross p.generateAndPopulateMoveset(); p.generateName(); })), [TrainerType.WALLACE]: new TrainerConfig(++t).initForChampion(signatureSpecies["WALLACE"], true).setBattleBgm("battle_hoenn_champion_g5").setMixedBattleBgm("battle_hoenn_champion_g6").setHasDouble("wallace_steven_double").setDoubleTrainerType(TrainerType.STEVEN).setDoubleTitle("champion_double") - .setPartyMemberFunc(0, getRandomPartyMemberFunc([Species.PELIPPER], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.PELIPPER ], TrainerSlot.TRAINER, true, p => { p.abilityIndex = 1; // Drizzle p.generateAndPopulateMoveset(); })) - .setPartyMemberFunc(1, getRandomPartyMemberFunc([Species.SWAMPERT], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.SWAMPERT ], TrainerSlot.TRAINER, true, p => { p.formIndex = 1; // Mega Swampert p.generateAndPopulateMoveset(); p.generateName(); })), [TrainerType.CYNTHIA]: new TrainerConfig(++t).initForChampion(signatureSpecies["CYNTHIA"], false).setBattleBgm("battle_sinnoh_champion").setMixedBattleBgm("battle_sinnoh_champion") - .setPartyMemberFunc(0, getRandomPartyMemberFunc([Species.SPIRITOMB], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.SPIRITOMB ], TrainerSlot.TRAINER, true, p => { p.generateAndPopulateMoveset(); })) - .setPartyMemberFunc(1, getRandomPartyMemberFunc([Species.GARCHOMP], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.GARCHOMP ], TrainerSlot.TRAINER, true, p => { p.formIndex = 1; // Mega Garchomp p.generateAndPopulateMoveset(); p.generateName(); })), [TrainerType.ALDER]: new TrainerConfig(++t).initForChampion(signatureSpecies["ALDER"], true).setHasDouble("alder_iris_double").setDoubleTrainerType(TrainerType.IRIS).setDoubleTitle("champion_double").setBattleBgm("battle_champion_alder").setMixedBattleBgm("battle_champion_alder") - .setPartyMemberFunc(0, getRandomPartyMemberFunc([Species.BOUFFALANT, Species.BRAVIARY], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.BOUFFALANT, Species.BRAVIARY ], TrainerSlot.TRAINER, true, p => { p.generateAndPopulateMoveset(); })), [TrainerType.IRIS]: new TrainerConfig(++t).initForChampion(signatureSpecies["IRIS"], false).setBattleBgm("battle_champion_iris").setMixedBattleBgm("battle_champion_iris").setHasDouble("iris_alder_double").setDoubleTrainerType(TrainerType.ALDER).setDoubleTitle("champion_double") - .setPartyMemberFunc(0, getRandomPartyMemberFunc([Species.DRUDDIGON], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.DRUDDIGON ], TrainerSlot.TRAINER, true, p => { p.generateAndPopulateMoveset(); })) - .setPartyMemberFunc(1, getRandomPartyMemberFunc([Species.LAPRAS], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.LAPRAS ], TrainerSlot.TRAINER, true, p => { p.formIndex = 1; // G-Max Lapras p.generateAndPopulateMoveset(); p.generateName(); })), [TrainerType.DIANTHA]: new TrainerConfig(++t).initForChampion(signatureSpecies["DIANTHA"], false).setMixedBattleBgm("battle_kalos_champion") - .setPartyMemberFunc(0, getRandomPartyMemberFunc([Species.GOURGEIST], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.GOURGEIST ], TrainerSlot.TRAINER, true, p => { p.generateAndPopulateMoveset(); })) - .setPartyMemberFunc(1, getRandomPartyMemberFunc([Species.GARDEVOIR], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.GARDEVOIR ], TrainerSlot.TRAINER, true, p => { p.formIndex = 1; // Mega Gardevoir p.generateAndPopulateMoveset(); p.generateName(); })), [TrainerType.HAU]: new TrainerConfig(++t).initForChampion(signatureSpecies["HAU"], true).setMixedBattleBgm("battle_alola_champion") - .setPartyMemberFunc(0, getRandomPartyMemberFunc([Species.ALOLA_RAICHU], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.ALOLA_RAICHU ], TrainerSlot.TRAINER, true, p => { p.generateAndPopulateMoveset(); })), [TrainerType.LEON]: new TrainerConfig(++t).initForChampion(signatureSpecies["LEON"], true).setMixedBattleBgm("battle_galar_champion") - .setPartyMemberFunc(0, getRandomPartyMemberFunc([Species.RILLABOOM, Species.CINDERACE, Species.INTELEON], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.RILLABOOM, Species.CINDERACE, Species.INTELEON ], TrainerSlot.TRAINER, true, p => { p.generateAndPopulateMoveset(); })) - .setPartyMemberFunc(1, getRandomPartyMemberFunc([Species.CHARIZARD], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.CHARIZARD ], TrainerSlot.TRAINER, true, p => { p.formIndex = 3; // G-Max Charizard p.generateAndPopulateMoveset(); p.generateName(); })), [TrainerType.GEETA]: new TrainerConfig(++t).initForChampion(signatureSpecies["GEETA"], false).setMixedBattleBgm("battle_champion_geeta") - .setPartyMemberFunc(0, getRandomPartyMemberFunc([Species.GLIMMORA], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.GLIMMORA ], TrainerSlot.TRAINER, true, p => { p.generateAndPopulateMoveset(); })), [TrainerType.NEMONA]: new TrainerConfig(++t).initForChampion(signatureSpecies["NEMONA"], false).setMixedBattleBgm("battle_champion_nemona") - .setPartyMemberFunc(0, getRandomPartyMemberFunc([Species.LYCANROC], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.LYCANROC ], TrainerSlot.TRAINER, true, p => { p.formIndex = 0; // Midday form p.generateAndPopulateMoveset(); })), [TrainerType.KIERAN]: new TrainerConfig(++t).initForChampion(signatureSpecies["KIERAN"], true).setMixedBattleBgm("battle_champion_kieran") - .setPartyMemberFunc(0, getRandomPartyMemberFunc([Species.POLIWRATH, Species.POLITOED], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.POLIWRATH, Species.POLITOED ], TrainerSlot.TRAINER, true, p => { p.generateAndPopulateMoveset(); })), [TrainerType.RIVAL]: new TrainerConfig((t = TrainerType.RIVAL)).setName("Finn").setHasGenders("Ivy").setHasCharSprite().setTitle("Rival").setStaticParty().setEncounterBgm(TrainerType.RIVAL).setBattleBgm("battle_rival").setMixedBattleBgm("battle_rival").setPartyTemplates(trainerPartyTemplates.RIVAL) .setModifierRewardFuncs(() => modifierTypes.SUPER_EXP_CHARM, () => modifierTypes.EXP_SHARE) - .setPartyMemberFunc(0, getRandomPartyMemberFunc([Species.BULBASAUR, Species.CHARMANDER, Species.SQUIRTLE, Species.CHIKORITA, Species.CYNDAQUIL, Species.TOTODILE, Species.TREECKO, Species.TORCHIC, Species.MUDKIP, Species.TURTWIG, Species.CHIMCHAR, Species.PIPLUP, Species.SNIVY, Species.TEPIG, Species.OSHAWOTT, Species.CHESPIN, Species.FENNEKIN, Species.FROAKIE, Species.ROWLET, Species.LITTEN, Species.POPPLIO, Species.GROOKEY, Species.SCORBUNNY, Species.SOBBLE, Species.SPRIGATITO, Species.FUECOCO, Species.QUAXLY], TrainerSlot.TRAINER, true)) - .setPartyMemberFunc(1, getRandomPartyMemberFunc([Species.PIDGEY, Species.HOOTHOOT, Species.TAILLOW, Species.STARLY, Species.PIDOVE, Species.FLETCHLING, Species.PIKIPEK, Species.ROOKIDEE, Species.WATTREL], TrainerSlot.TRAINER, true)), + .setEventModifierRewardFuncs(() => modifierTypes.SHINY_CHARM, () => modifierTypes.ABILITY_CHARM) + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.BULBASAUR, Species.CHARMANDER, Species.SQUIRTLE, Species.CHIKORITA, Species.CYNDAQUIL, Species.TOTODILE, Species.TREECKO, Species.TORCHIC, Species.MUDKIP, Species.TURTWIG, Species.CHIMCHAR, Species.PIPLUP, Species.SNIVY, Species.TEPIG, Species.OSHAWOTT, Species.CHESPIN, Species.FENNEKIN, Species.FROAKIE, Species.ROWLET, Species.LITTEN, Species.POPPLIO, Species.GROOKEY, Species.SCORBUNNY, Species.SOBBLE, Species.SPRIGATITO, Species.FUECOCO, Species.QUAXLY ], TrainerSlot.TRAINER, true, + (p => p.abilityIndex = 0))) + .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.PIDGEY, Species.HOOTHOOT, Species.TAILLOW, Species.STARLY, Species.PIDOVE, Species.FLETCHLING, Species.PIKIPEK, Species.ROOKIDEE, Species.WATTREL ], TrainerSlot.TRAINER, true)), [TrainerType.RIVAL_2]: new TrainerConfig(++t).setName("Finn").setHasGenders("Ivy").setHasCharSprite().setTitle("Rival").setStaticParty().setMoneyMultiplier(1.25).setEncounterBgm(TrainerType.RIVAL).setBattleBgm("battle_rival").setMixedBattleBgm("battle_rival").setPartyTemplates(trainerPartyTemplates.RIVAL_2) .setModifierRewardFuncs(() => modifierTypes.EXP_SHARE) - .setPartyMemberFunc(0, getRandomPartyMemberFunc([Species.IVYSAUR, Species.CHARMELEON, Species.WARTORTLE, Species.BAYLEEF, Species.QUILAVA, Species.CROCONAW, Species.GROVYLE, Species.COMBUSKEN, Species.MARSHTOMP, Species.GROTLE, Species.MONFERNO, Species.PRINPLUP, Species.SERVINE, Species.PIGNITE, Species.DEWOTT, Species.QUILLADIN, Species.BRAIXEN, Species.FROGADIER, Species.DARTRIX, Species.TORRACAT, Species.BRIONNE, Species.THWACKEY, Species.RABOOT, Species.DRIZZILE, Species.FLORAGATO, Species.CROCALOR, Species.QUAXWELL], TrainerSlot.TRAINER, true)) - .setPartyMemberFunc(1, getRandomPartyMemberFunc([Species.PIDGEOTTO, Species.HOOTHOOT, Species.TAILLOW, Species.STARAVIA, Species.TRANQUILL, Species.FLETCHINDER, Species.TRUMBEAK, Species.CORVISQUIRE, Species.WATTREL], TrainerSlot.TRAINER, true)) + .setEventModifierRewardFuncs(() => modifierTypes.SHINY_CHARM) + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.IVYSAUR, Species.CHARMELEON, Species.WARTORTLE, Species.BAYLEEF, Species.QUILAVA, Species.CROCONAW, Species.GROVYLE, Species.COMBUSKEN, Species.MARSHTOMP, Species.GROTLE, Species.MONFERNO, Species.PRINPLUP, Species.SERVINE, Species.PIGNITE, Species.DEWOTT, Species.QUILLADIN, Species.BRAIXEN, Species.FROGADIER, Species.DARTRIX, Species.TORRACAT, Species.BRIONNE, Species.THWACKEY, Species.RABOOT, Species.DRIZZILE, Species.FLORAGATO, Species.CROCALOR, Species.QUAXWELL ], TrainerSlot.TRAINER, true, + (p => p.abilityIndex = 0))) + .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.PIDGEOTTO, Species.HOOTHOOT, Species.TAILLOW, Species.STARAVIA, Species.TRANQUILL, Species.FLETCHINDER, Species.TRUMBEAK, Species.CORVISQUIRE, Species.WATTREL ], TrainerSlot.TRAINER, true)) .setPartyMemberFunc(2, getSpeciesFilterRandomPartyMemberFunc((species: PokemonSpecies) => !pokemonEvolutions.hasOwnProperty(species.speciesId) && !pokemonPrevolutions.hasOwnProperty(species.speciesId) && species.baseTotal >= 450)), [TrainerType.RIVAL_3]: new TrainerConfig(++t).setName("Finn").setHasGenders("Ivy").setHasCharSprite().setTitle("Rival").setStaticParty().setMoneyMultiplier(1.5).setEncounterBgm(TrainerType.RIVAL).setBattleBgm("battle_rival").setMixedBattleBgm("battle_rival").setPartyTemplates(trainerPartyTemplates.RIVAL_3) - .setPartyMemberFunc(0, getRandomPartyMemberFunc([Species.VENUSAUR, Species.CHARIZARD, Species.BLASTOISE, Species.MEGANIUM, Species.TYPHLOSION, Species.FERALIGATR, Species.SCEPTILE, Species.BLAZIKEN, Species.SWAMPERT, Species.TORTERRA, Species.INFERNAPE, Species.EMPOLEON, Species.SERPERIOR, Species.EMBOAR, Species.SAMUROTT, Species.CHESNAUGHT, Species.DELPHOX, Species.GRENINJA, Species.DECIDUEYE, Species.INCINEROAR, Species.PRIMARINA, Species.RILLABOOM, Species.CINDERACE, Species.INTELEON, Species.MEOWSCARADA, Species.SKELEDIRGE, Species.QUAQUAVAL], TrainerSlot.TRAINER, true)) - .setPartyMemberFunc(1, getRandomPartyMemberFunc([Species.PIDGEOT, Species.NOCTOWL, Species.SWELLOW, Species.STARAPTOR, Species.UNFEZANT, Species.TALONFLAME, Species.TOUCANNON, Species.CORVIKNIGHT, Species.KILOWATTREL], TrainerSlot.TRAINER, true)) + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.VENUSAUR, Species.CHARIZARD, Species.BLASTOISE, Species.MEGANIUM, Species.TYPHLOSION, Species.FERALIGATR, Species.SCEPTILE, Species.BLAZIKEN, Species.SWAMPERT, Species.TORTERRA, Species.INFERNAPE, Species.EMPOLEON, Species.SERPERIOR, Species.EMBOAR, Species.SAMUROTT, Species.CHESNAUGHT, Species.DELPHOX, Species.GRENINJA, Species.DECIDUEYE, Species.INCINEROAR, Species.PRIMARINA, Species.RILLABOOM, Species.CINDERACE, Species.INTELEON, Species.MEOWSCARADA, Species.SKELEDIRGE, Species.QUAQUAVAL ], TrainerSlot.TRAINER, true, + (p => p.abilityIndex = 0))) + .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.PIDGEOT, Species.NOCTOWL, Species.SWELLOW, Species.STARAPTOR, Species.UNFEZANT, Species.TALONFLAME, Species.TOUCANNON, Species.CORVIKNIGHT, Species.KILOWATTREL ], TrainerSlot.TRAINER, true)) .setPartyMemberFunc(2, getSpeciesFilterRandomPartyMemberFunc((species: PokemonSpecies) => !pokemonEvolutions.hasOwnProperty(species.speciesId) && !pokemonPrevolutions.hasOwnProperty(species.speciesId) && species.baseTotal >= 450)) .setSpeciesFilter(species => species.baseTotal >= 540), [TrainerType.RIVAL_4]: new TrainerConfig(++t).setName("Finn").setHasGenders("Ivy").setHasCharSprite().setTitle("Rival").setBoss().setStaticParty().setMoneyMultiplier(1.75).setEncounterBgm(TrainerType.RIVAL).setBattleBgm("battle_rival_2").setMixedBattleBgm("battle_rival_2").setPartyTemplates(trainerPartyTemplates.RIVAL_4) - .setPartyMemberFunc(0, getRandomPartyMemberFunc([Species.VENUSAUR, Species.CHARIZARD, Species.BLASTOISE, Species.MEGANIUM, Species.TYPHLOSION, Species.FERALIGATR, Species.SCEPTILE, Species.BLAZIKEN, Species.SWAMPERT, Species.TORTERRA, Species.INFERNAPE, Species.EMPOLEON, Species.SERPERIOR, Species.EMBOAR, Species.SAMUROTT, Species.CHESNAUGHT, Species.DELPHOX, Species.GRENINJA, Species.DECIDUEYE, Species.INCINEROAR, Species.PRIMARINA, Species.RILLABOOM, Species.CINDERACE, Species.INTELEON, Species.MEOWSCARADA, Species.SKELEDIRGE, Species.QUAQUAVAL], TrainerSlot.TRAINER, true)) - .setPartyMemberFunc(1, getRandomPartyMemberFunc([Species.PIDGEOT, Species.NOCTOWL, Species.SWELLOW, Species.STARAPTOR, Species.UNFEZANT, Species.TALONFLAME, Species.TOUCANNON, Species.CORVIKNIGHT, Species.KILOWATTREL], TrainerSlot.TRAINER, true)) + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.VENUSAUR, Species.CHARIZARD, Species.BLASTOISE, Species.MEGANIUM, Species.TYPHLOSION, Species.FERALIGATR, Species.SCEPTILE, Species.BLAZIKEN, Species.SWAMPERT, Species.TORTERRA, Species.INFERNAPE, Species.EMPOLEON, Species.SERPERIOR, Species.EMBOAR, Species.SAMUROTT, Species.CHESNAUGHT, Species.DELPHOX, Species.GRENINJA, Species.DECIDUEYE, Species.INCINEROAR, Species.PRIMARINA, Species.RILLABOOM, Species.CINDERACE, Species.INTELEON, Species.MEOWSCARADA, Species.SKELEDIRGE, Species.QUAQUAVAL ], TrainerSlot.TRAINER, true, + (p => p.abilityIndex = 0))) + .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.PIDGEOT, Species.NOCTOWL, Species.SWELLOW, Species.STARAPTOR, Species.UNFEZANT, Species.TALONFLAME, Species.TOUCANNON, Species.CORVIKNIGHT, Species.KILOWATTREL ], TrainerSlot.TRAINER, true)) .setPartyMemberFunc(2, getSpeciesFilterRandomPartyMemberFunc((species: PokemonSpecies) => !pokemonEvolutions.hasOwnProperty(species.speciesId) && !pokemonPrevolutions.hasOwnProperty(species.speciesId) && species.baseTotal >= 450)) .setSpeciesFilter(species => species.baseTotal >= 540) .setGenModifiersFunc(party => { const starter = party[0]; - return [modifierTypes.TERA_SHARD().generateType([], [starter.species.type1])!.withIdFromFunc(modifierTypes.TERA_SHARD).newModifier(starter) as PersistentModifier]; // TODO: is the bang correct? + return [ modifierTypes.TERA_SHARD().generateType([], [ starter.species.type1 ])!.withIdFromFunc(modifierTypes.TERA_SHARD).newModifier(starter) as PersistentModifier ]; // TODO: is the bang correct? }), [TrainerType.RIVAL_5]: new TrainerConfig(++t).setName("Finn").setHasGenders("Ivy").setHasCharSprite().setTitle("Rival").setBoss().setStaticParty().setMoneyMultiplier(2.25).setEncounterBgm(TrainerType.RIVAL).setBattleBgm("battle_rival_3").setMixedBattleBgm("battle_rival_3").setPartyTemplates(trainerPartyTemplates.RIVAL_5) - .setPartyMemberFunc(0, getRandomPartyMemberFunc([Species.VENUSAUR, Species.CHARIZARD, Species.BLASTOISE, Species.MEGANIUM, Species.TYPHLOSION, Species.FERALIGATR, Species.SCEPTILE, Species.BLAZIKEN, Species.SWAMPERT, Species.TORTERRA, Species.INFERNAPE, Species.EMPOLEON, Species.SERPERIOR, Species.EMBOAR, Species.SAMUROTT, Species.CHESNAUGHT, Species.DELPHOX, Species.GRENINJA, Species.DECIDUEYE, Species.INCINEROAR, Species.PRIMARINA, Species.RILLABOOM, Species.CINDERACE, Species.INTELEON, Species.MEOWSCARADA, Species.SKELEDIRGE, Species.QUAQUAVAL], TrainerSlot.TRAINER, true, - p => p.setBoss(true, 2))) - .setPartyMemberFunc(1, getRandomPartyMemberFunc([Species.PIDGEOT, Species.NOCTOWL, Species.SWELLOW, Species.STARAPTOR, Species.UNFEZANT, Species.TALONFLAME, Species.TOUCANNON, Species.CORVIKNIGHT, Species.KILOWATTREL], TrainerSlot.TRAINER, true)) + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.VENUSAUR, Species.CHARIZARD, Species.BLASTOISE, Species.MEGANIUM, Species.TYPHLOSION, Species.FERALIGATR, Species.SCEPTILE, Species.BLAZIKEN, Species.SWAMPERT, Species.TORTERRA, Species.INFERNAPE, Species.EMPOLEON, Species.SERPERIOR, Species.EMBOAR, Species.SAMUROTT, Species.CHESNAUGHT, Species.DELPHOX, Species.GRENINJA, Species.DECIDUEYE, Species.INCINEROAR, Species.PRIMARINA, Species.RILLABOOM, Species.CINDERACE, Species.INTELEON, Species.MEOWSCARADA, Species.SKELEDIRGE, Species.QUAQUAVAL ], TrainerSlot.TRAINER, true, + p => { + p.setBoss(true, 2); + p.abilityIndex = 0; + })) + .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.PIDGEOT, Species.NOCTOWL, Species.SWELLOW, Species.STARAPTOR, Species.UNFEZANT, Species.TALONFLAME, Species.TOUCANNON, Species.CORVIKNIGHT, Species.KILOWATTREL ], TrainerSlot.TRAINER, true)) .setPartyMemberFunc(2, getSpeciesFilterRandomPartyMemberFunc((species: PokemonSpecies) => !pokemonEvolutions.hasOwnProperty(species.speciesId) && !pokemonPrevolutions.hasOwnProperty(species.speciesId) && species.baseTotal >= 450)) .setSpeciesFilter(species => species.baseTotal >= 540) - .setPartyMemberFunc(5, getRandomPartyMemberFunc([Species.RAYQUAZA], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(5, getRandomPartyMemberFunc([ Species.RAYQUAZA ], TrainerSlot.TRAINER, true, p => { p.setBoss(true, 3); p.pokeball = PokeballType.MASTER_BALL; p.shiny = true; @@ -1781,22 +1884,23 @@ export const trainerConfigs: TrainerConfigs = { })) .setGenModifiersFunc(party => { const starter = party[0]; - return [modifierTypes.TERA_SHARD().generateType([], [starter.species.type1])!.withIdFromFunc(modifierTypes.TERA_SHARD).newModifier(starter) as PersistentModifier]; //TODO: is the bang correct? + return [ modifierTypes.TERA_SHARD().generateType([], [ starter.species.type1 ])!.withIdFromFunc(modifierTypes.TERA_SHARD).newModifier(starter) as PersistentModifier ]; //TODO: is the bang correct? }), [TrainerType.RIVAL_6]: new TrainerConfig(++t).setName("Finn").setHasGenders("Ivy").setHasCharSprite().setTitle("Rival").setBoss().setStaticParty().setMoneyMultiplier(3).setEncounterBgm("final").setBattleBgm("battle_rival_3").setMixedBattleBgm("battle_rival_3").setPartyTemplates(trainerPartyTemplates.RIVAL_6) - .setPartyMemberFunc(0, getRandomPartyMemberFunc([Species.VENUSAUR, Species.CHARIZARD, Species.BLASTOISE, Species.MEGANIUM, Species.TYPHLOSION, Species.FERALIGATR, Species.SCEPTILE, Species.BLAZIKEN, Species.SWAMPERT, Species.TORTERRA, Species.INFERNAPE, Species.EMPOLEON, Species.SERPERIOR, Species.EMBOAR, Species.SAMUROTT, Species.CHESNAUGHT, Species.DELPHOX, Species.GRENINJA, Species.DECIDUEYE, Species.INCINEROAR, Species.PRIMARINA, Species.RILLABOOM, Species.CINDERACE, Species.INTELEON, Species.MEOWSCARADA, Species.SKELEDIRGE, Species.QUAQUAVAL], TrainerSlot.TRAINER, true, + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.VENUSAUR, Species.CHARIZARD, Species.BLASTOISE, Species.MEGANIUM, Species.TYPHLOSION, Species.FERALIGATR, Species.SCEPTILE, Species.BLAZIKEN, Species.SWAMPERT, Species.TORTERRA, Species.INFERNAPE, Species.EMPOLEON, Species.SERPERIOR, Species.EMBOAR, Species.SAMUROTT, Species.CHESNAUGHT, Species.DELPHOX, Species.GRENINJA, Species.DECIDUEYE, Species.INCINEROAR, Species.PRIMARINA, Species.RILLABOOM, Species.CINDERACE, Species.INTELEON, Species.MEOWSCARADA, Species.SKELEDIRGE, Species.QUAQUAVAL ], TrainerSlot.TRAINER, true, p => { p.setBoss(true, 3); + p.abilityIndex = 0; p.generateAndPopulateMoveset(); })) - .setPartyMemberFunc(1, getRandomPartyMemberFunc([Species.PIDGEOT, Species.NOCTOWL, Species.SWELLOW, Species.STARAPTOR, Species.UNFEZANT, Species.TALONFLAME, Species.TOUCANNON, Species.CORVIKNIGHT, Species.KILOWATTREL], TrainerSlot.TRAINER, true, + .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.PIDGEOT, Species.NOCTOWL, Species.SWELLOW, Species.STARAPTOR, Species.UNFEZANT, Species.TALONFLAME, Species.TOUCANNON, Species.CORVIKNIGHT, Species.KILOWATTREL ], TrainerSlot.TRAINER, true, p => { p.setBoss(true, 2); p.generateAndPopulateMoveset(); })) .setPartyMemberFunc(2, getSpeciesFilterRandomPartyMemberFunc((species: PokemonSpecies) => !pokemonEvolutions.hasOwnProperty(species.speciesId) && !pokemonPrevolutions.hasOwnProperty(species.speciesId) && species.baseTotal >= 450)) .setSpeciesFilter(species => species.baseTotal >= 540) - .setPartyMemberFunc(5, getRandomPartyMemberFunc([Species.RAYQUAZA], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(5, getRandomPartyMemberFunc([ Species.RAYQUAZA ], TrainerSlot.TRAINER, true, p => { p.setBoss(); p.generateAndPopulateMoveset(); p.pokeball = PokeballType.MASTER_BALL; @@ -1807,16 +1911,19 @@ export const trainerConfigs: TrainerConfigs = { })) .setGenModifiersFunc(party => { const starter = party[0]; - return [modifierTypes.TERA_SHARD().generateType([], [starter.species.type1])!.withIdFromFunc(modifierTypes.TERA_SHARD).newModifier(starter) as PersistentModifier]; // TODO: is the bang correct? + return [ modifierTypes.TERA_SHARD().generateType([], [ starter.species.type1 ])!.withIdFromFunc(modifierTypes.TERA_SHARD).newModifier(starter) as PersistentModifier ]; // TODO: is the bang correct? }), [TrainerType.ROCKET_BOSS_GIOVANNI_1]: new TrainerConfig(t = TrainerType.ROCKET_BOSS_GIOVANNI_1).setName("Giovanni").initForEvilTeamLeader("Rocket Boss", []).setMixedBattleBgm("battle_rocket_boss").setVictoryBgm("victory_team_plasma") - .setPartyMemberFunc(0, getRandomPartyMemberFunc([Species.PERSIAN, Species.ALOLA_PERSIAN])) - .setPartyMemberFunc(1, getRandomPartyMemberFunc([Species.DUGTRIO, Species.ALOLA_DUGTRIO])) - .setPartyMemberFunc(2, getRandomPartyMemberFunc([Species.HONCHKROW])) - .setPartyMemberFunc(3, getRandomPartyMemberFunc([Species.NIDOKING, Species.NIDOQUEEN])) - .setPartyMemberFunc(4, getRandomPartyMemberFunc([Species.RHYPERIOR])) - .setPartyMemberFunc(5, getRandomPartyMemberFunc([Species.KANGASKHAN], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.PERSIAN, Species.ALOLA_PERSIAN ], TrainerSlot.TRAINER, true, p => { + p.generateAndPopulateMoveset(); + p.gender = Gender.MALE; + })) + .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.DUGTRIO, Species.ALOLA_DUGTRIO ])) + .setPartyMemberFunc(2, getRandomPartyMemberFunc([ Species.HONCHKROW ])) + .setPartyMemberFunc(3, getRandomPartyMemberFunc([ Species.NIDOKING, Species.NIDOQUEEN ])) + .setPartyMemberFunc(4, getRandomPartyMemberFunc([ Species.RHYPERIOR ])) + .setPartyMemberFunc(5, getRandomPartyMemberFunc([ Species.KANGASKHAN ], TrainerSlot.TRAINER, true, p => { p.setBoss(true, 2); p.generateAndPopulateMoveset(); p.pokeball = PokeballType.ULTRA_BALL; @@ -1824,90 +1931,100 @@ export const trainerConfigs: TrainerConfigs = { p.generateName(); })), [TrainerType.ROCKET_BOSS_GIOVANNI_2]: new TrainerConfig(++t).setName("Giovanni").initForEvilTeamLeader("Rocket Boss", [], true).setMixedBattleBgm("battle_rocket_boss").setVictoryBgm("victory_team_plasma") - .setPartyMemberFunc(0, getRandomPartyMemberFunc([Species.TYRANITAR, Species.IRON_THORNS], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.TYRANITAR, Species.IRON_THORNS ], TrainerSlot.TRAINER, true, p => { p.setBoss(true, 2); p.generateAndPopulateMoveset(); p.pokeball = PokeballType.ULTRA_BALL; })) - .setPartyMemberFunc(1, getRandomPartyMemberFunc([Species.HIPPOWDON])) - .setPartyMemberFunc(2, getRandomPartyMemberFunc([Species.EXCADRILL, Species.GARCHOMP])) - .setPartyMemberFunc(3, getRandomPartyMemberFunc([Species.KANGASKHAN], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.HIPPOWDON ])) + .setPartyMemberFunc(2, getRandomPartyMemberFunc([ Species.EXCADRILL, Species.GARCHOMP ])) + .setPartyMemberFunc(3, getRandomPartyMemberFunc([ Species.KANGASKHAN ], TrainerSlot.TRAINER, true, p => { p.setBoss(true, 2); p.generateAndPopulateMoveset(); p.pokeball = PokeballType.ULTRA_BALL; p.formIndex = 1; // Mega Kangaskhan p.generateName(); })) - .setPartyMemberFunc(4, getRandomPartyMemberFunc([Species.GASTRODON, Species.SEISMITOAD])) - .setPartyMemberFunc(5, getRandomPartyMemberFunc([Species.MEWTWO], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(4, getRandomPartyMemberFunc([ Species.GASTRODON, Species.SEISMITOAD ], TrainerSlot.TRAINER, true, p => { + //Storm Drain Gastrodon, Water Absorb Seismitoad + if (p.species.speciesId === Species.GASTRODON) { + p.abilityIndex = 0; + } else if (p.species.speciesId === Species.SEISMITOAD) { + p.abilityIndex = 2; + } + })) + .setPartyMemberFunc(5, getRandomPartyMemberFunc([ Species.MEWTWO ], TrainerSlot.TRAINER, true, p => { p.setBoss(true, 2); p.generateAndPopulateMoveset(); p.pokeball = PokeballType.MASTER_BALL; })), [TrainerType.MAXIE]: new TrainerConfig(++t).setName("Maxie").initForEvilTeamLeader("Magma Boss", []).setMixedBattleBgm("battle_aqua_magma_boss").setVictoryBgm("victory_team_plasma") - .setPartyMemberFunc(0, getRandomPartyMemberFunc([Species.MIGHTYENA])) - .setPartyMemberFunc(1, getRandomPartyMemberFunc([Species.CROBAT, Species.GLISCOR])) - .setPartyMemberFunc(2, getRandomPartyMemberFunc([Species.WEEZING, Species.GALAR_WEEZING])) - .setPartyMemberFunc(3, getRandomPartyMemberFunc([Species.MAGMORTAR, Species.TORKOAL])) - .setPartyMemberFunc(4, getRandomPartyMemberFunc([Species.FLYGON])) - .setPartyMemberFunc(5, getRandomPartyMemberFunc([Species.CAMERUPT], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.MIGHTYENA ])) + .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.CROBAT, Species.GLISCOR ])) + .setPartyMemberFunc(2, getRandomPartyMemberFunc([ Species.WEEZING, Species.GALAR_WEEZING ])) + .setPartyMemberFunc(3, getRandomPartyMemberFunc([ Species.MAGMORTAR, Species.TORKOAL ])) + .setPartyMemberFunc(4, getRandomPartyMemberFunc([ Species.FLYGON ])) + .setPartyMemberFunc(5, getRandomPartyMemberFunc([ Species.CAMERUPT ], TrainerSlot.TRAINER, true, p => { p.setBoss(true, 2); p.generateAndPopulateMoveset(); p.pokeball = PokeballType.ULTRA_BALL; p.formIndex = 1; // Mega Camerupt p.generateName(); + p.gender = Gender.MALE; })), [TrainerType.MAXIE_2]: new TrainerConfig(++t).setName("Maxie").initForEvilTeamLeader("Magma Boss", [], true).setMixedBattleBgm("battle_aqua_magma_boss").setVictoryBgm("victory_team_plasma") - .setPartyMemberFunc(0, getRandomPartyMemberFunc([Species.SOLROCK, Species.TYPHLOSION], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.SOLROCK, Species.TYPHLOSION ], TrainerSlot.TRAINER, true, p => { p.setBoss(true, 2); p.generateAndPopulateMoveset(); p.pokeball = PokeballType.ULTRA_BALL; })) - .setPartyMemberFunc(1, getRandomPartyMemberFunc([Species.TORKOAL, Species.NINETALES], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.TORKOAL, Species.NINETALES ], TrainerSlot.TRAINER, true, p => { p.generateAndPopulateMoveset(); p.abilityIndex = 2; // Drought })) - .setPartyMemberFunc(2, getRandomPartyMemberFunc([Species.SHIFTRY, Species.SCOVILLAIN], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(2, getRandomPartyMemberFunc([ Species.SHIFTRY, Species.SCOVILLAIN ], TrainerSlot.TRAINER, true, p => { p.generateAndPopulateMoveset(); p.abilityIndex = 0; // Chlorophyll })) - .setPartyMemberFunc(3, getRandomPartyMemberFunc([Species.GREAT_TUSK])) - .setPartyMemberFunc(4, getRandomPartyMemberFunc([Species.CAMERUPT], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(3, getRandomPartyMemberFunc([ Species.GREAT_TUSK ])) + .setPartyMemberFunc(4, getRandomPartyMemberFunc([ Species.CAMERUPT ], TrainerSlot.TRAINER, true, p => { p.setBoss(true, 2); p.generateAndPopulateMoveset(); p.pokeball = PokeballType.ULTRA_BALL; p.formIndex = 1; // Mega Camerupt p.generateName(); + p.gender = Gender.MALE; })) - .setPartyMemberFunc(5, getRandomPartyMemberFunc([Species.GROUDON], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(5, getRandomPartyMemberFunc([ Species.GROUDON ], TrainerSlot.TRAINER, true, p => { p.setBoss(true, 2); p.generateAndPopulateMoveset(); p.pokeball = PokeballType.MASTER_BALL; })), [TrainerType.ARCHIE]: new TrainerConfig(++t).setName("Archie").initForEvilTeamLeader("Aqua Boss", []).setMixedBattleBgm("battle_aqua_magma_boss").setVictoryBgm("victory_team_plasma") - .setPartyMemberFunc(0, getRandomPartyMemberFunc([Species.LINOONE])) - .setPartyMemberFunc(1, getRandomPartyMemberFunc([Species.CROBAT, Species.PELIPPER])) - .setPartyMemberFunc(2, getRandomPartyMemberFunc([Species.MUK, Species.ALOLA_MUK])) - .setPartyMemberFunc(3, getRandomPartyMemberFunc([Species.TENTACRUEL])) - .setPartyMemberFunc(4, getRandomPartyMemberFunc([Species.RELICANTH, Species.WAILORD])) - .setPartyMemberFunc(5, getRandomPartyMemberFunc([Species.SHARPEDO], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.LINOONE ])) + .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.CROBAT, Species.PELIPPER ])) + .setPartyMemberFunc(2, getRandomPartyMemberFunc([ Species.MUK, Species.ALOLA_MUK ])) + .setPartyMemberFunc(3, getRandomPartyMemberFunc([ Species.TENTACRUEL ])) + .setPartyMemberFunc(4, getRandomPartyMemberFunc([ Species.RELICANTH, Species.WAILORD ])) + .setPartyMemberFunc(5, getRandomPartyMemberFunc([ Species.SHARPEDO ], TrainerSlot.TRAINER, true, p => { p.setBoss(true, 2); p.generateAndPopulateMoveset(); p.pokeball = PokeballType.ULTRA_BALL; p.formIndex = 1; // Mega Sharpedo p.generateName(); + p.gender = Gender.MALE; })), [TrainerType.ARCHIE_2]: new TrainerConfig(++t).setName("Archie").initForEvilTeamLeader("Aqua Boss", [], true).setMixedBattleBgm("battle_aqua_magma_boss").setVictoryBgm("victory_team_plasma") - .setPartyMemberFunc(0, getRandomPartyMemberFunc([Species.EMPOLEON, Species.LUDICOLO], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.EMPOLEON, Species.LUDICOLO ], TrainerSlot.TRAINER, true, p => { p.setBoss(true, 2); p.generateAndPopulateMoveset(); p.pokeball = PokeballType.ULTRA_BALL; })) - .setPartyMemberFunc(1, getRandomPartyMemberFunc([Species.POLITOED, Species.PELIPPER], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.POLITOED, Species.PELIPPER ], TrainerSlot.TRAINER, true, p => { p.generateAndPopulateMoveset(); p.abilityIndex = 2; // Drizzle })) - .setPartyMemberFunc(2, getRandomPartyMemberFunc([Species.BEARTIC, Species.ARMALDO], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(2, getRandomPartyMemberFunc([ Species.BEARTIC, Species.ARMALDO ], TrainerSlot.TRAINER, true, p => { p.generateAndPopulateMoveset(); p.abilityIndex = 2; // Swift Swim })) @@ -1915,14 +2032,15 @@ export const trainerConfigs: TrainerConfigs = { p.generateAndPopulateMoveset(); p.abilityIndex = 1; // Swift Swim })) - .setPartyMemberFunc(4, getRandomPartyMemberFunc([Species.SHARPEDO], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(4, getRandomPartyMemberFunc([ Species.SHARPEDO ], TrainerSlot.TRAINER, true, p => { p.setBoss(true, 2); p.generateAndPopulateMoveset(); p.pokeball = PokeballType.ULTRA_BALL; p.formIndex = 1; // Mega Sharpedo p.generateName(); + p.gender = Gender.MALE; })) - .setPartyMemberFunc(5, getRandomPartyMemberFunc([Species.KYOGRE], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(5, getRandomPartyMemberFunc([ Species.KYOGRE ], TrainerSlot.TRAINER, true, p => { p.setBoss(true, 2); p.generateAndPopulateMoveset(); p.pokeball = PokeballType.MASTER_BALL; @@ -1938,51 +2056,54 @@ export const trainerConfigs: TrainerConfigs = { p.formIndex = 1; // Mega Houndoom p.generateName(); })) - .setPartyMemberFunc(5, getRandomPartyMemberFunc([Species.WEAVILE], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(5, getRandomPartyMemberFunc([ Species.WEAVILE ], TrainerSlot.TRAINER, true, p => { p.setBoss(true, 2); p.generateAndPopulateMoveset(); p.pokeball = PokeballType.ULTRA_BALL; + p.gender = Gender.MALE; })), [TrainerType.CYRUS_2]: new TrainerConfig(++t).setName("Cyrus").initForEvilTeamLeader("Galactic Boss", [], true).setMixedBattleBgm("battle_galactic_boss").setVictoryBgm("victory_team_plasma") - .setPartyMemberFunc(0, getRandomPartyMemberFunc([Species.AZELF, Species.UXIE, Species.MESPRIT], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.AZELF, Species.UXIE, Species.MESPRIT ], TrainerSlot.TRAINER, true, p => { p.setBoss(true, 2); p.generateAndPopulateMoveset(); })) - .setPartyMemberFunc(1, getRandomPartyMemberFunc([Species.ELECTRODE, Species.HISUI_ELECTRODE])) - .setPartyMemberFunc(2, getRandomPartyMemberFunc([Species.SALAMENCE, Species.ROARING_MOON])) - .setPartyMemberFunc(3, getRandomPartyMemberFunc([Species.HOUNDOOM], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.ELECTRODE, Species.HISUI_ELECTRODE ])) + .setPartyMemberFunc(2, getRandomPartyMemberFunc([ Species.SALAMENCE, Species.ROARING_MOON ])) + .setPartyMemberFunc(3, getRandomPartyMemberFunc([ Species.HOUNDOOM ], TrainerSlot.TRAINER, true, p => { p.generateAndPopulateMoveset(); p.pokeball = PokeballType.ULTRA_BALL; p.formIndex = 1; // Mega Houndoom p.generateName(); })) - .setPartyMemberFunc(4, getRandomPartyMemberFunc([Species.WEAVILE, Species.SNEASLER], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(4, getRandomPartyMemberFunc([ Species.WEAVILE, Species.SNEASLER ], TrainerSlot.TRAINER, true, p => { p.setBoss(true, 2); p.generateAndPopulateMoveset(); p.pokeball = PokeballType.ULTRA_BALL; + p.gender = Gender.MALE; })) - .setPartyMemberFunc(5, getRandomPartyMemberFunc([Species.DARKRAI], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(5, getRandomPartyMemberFunc([ Species.DARKRAI ], TrainerSlot.TRAINER, true, p => { p.setBoss(true, 2); p.generateAndPopulateMoveset(); p.pokeball = PokeballType.MASTER_BALL; })), [TrainerType.GHETSIS]: new TrainerConfig(++t).setName("Ghetsis").initForEvilTeamLeader("Plasma Boss", []).setMixedBattleBgm("battle_plasma_boss").setVictoryBgm("victory_team_plasma") - .setPartyMemberFunc(0, getRandomPartyMemberFunc([Species.COFAGRIGUS, Species.RUNERIGUS])) - .setPartyMemberFunc(1, getRandomPartyMemberFunc([Species.BOUFFALANT])) - .setPartyMemberFunc(2, getRandomPartyMemberFunc([Species.SEISMITOAD, Species.CARRACOSTA])) - .setPartyMemberFunc(3, getRandomPartyMemberFunc([Species.EELEKTROSS, Species.GALVANTULA])) - .setPartyMemberFunc(4, getRandomPartyMemberFunc([Species.VOLCARONA])) - .setPartyMemberFunc(5, getRandomPartyMemberFunc([Species.HYDREIGON], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.COFAGRIGUS, Species.RUNERIGUS ])) + .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.BOUFFALANT ])) + .setPartyMemberFunc(2, getRandomPartyMemberFunc([ Species.SEISMITOAD, Species.CARRACOSTA ])) + .setPartyMemberFunc(3, getRandomPartyMemberFunc([ Species.EELEKTROSS, Species.GALVANTULA ])) + .setPartyMemberFunc(4, getRandomPartyMemberFunc([ Species.VOLCARONA ])) + .setPartyMemberFunc(5, getRandomPartyMemberFunc([ Species.HYDREIGON ], TrainerSlot.TRAINER, true, p => { p.setBoss(true, 2); p.generateAndPopulateMoveset(); p.pokeball = PokeballType.ULTRA_BALL; + p.gender = Gender.MALE; })), [TrainerType.GHETSIS_2]: new TrainerConfig(++t).setName("Ghetsis").initForEvilTeamLeader("Plasma Boss", [], true).setMixedBattleBgm("battle_plasma_boss").setVictoryBgm("victory_team_plasma") .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.GENESECT ], TrainerSlot.TRAINER, true, p => { p.setBoss(true, 2); p.generateAndPopulateMoveset(); p.pokeball = PokeballType.ULTRA_BALL; - p.formIndex = Utils.randSeedInt(5, 1); // Shock, Burn, Chill, or Douse Drive + p.formIndex = Utils.randSeedInt(4, 1); // Shock, Burn, Chill, or Douse Drive })) .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.BASCULEGION, Species.JELLICENT ], TrainerSlot.TRAINER, true, p => { p.generateAndPopulateMoveset(); @@ -1995,8 +2116,13 @@ export const trainerConfigs: TrainerConfigs = { p.setBoss(true, 2); p.generateAndPopulateMoveset(); p.pokeball = PokeballType.ULTRA_BALL; + if (p.species.speciesId === Species.HYDREIGON) { + p.gender = Gender.MALE; + } else if (p.species.speciesId === Species.IRON_JUGULIS) { + p.gender = Gender.GENDERLESS; + } })) - .setPartyMemberFunc(5, getRandomPartyMemberFunc([Species.KYUREM], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(5, getRandomPartyMemberFunc([ Species.KYUREM ], TrainerSlot.TRAINER, true, p => { p.setBoss(true, 2); p.generateAndPopulateMoveset(); p.pokeball = PokeballType.MASTER_BALL; @@ -2016,9 +2142,10 @@ export const trainerConfigs: TrainerConfigs = { p.pokeball = PokeballType.ULTRA_BALL; p.formIndex = 1; // Mega Gyarados p.generateName(); + p.gender = Gender.MALE; })), [TrainerType.LYSANDRE_2]: new TrainerConfig(++t).setName("Lysandre").initForEvilTeamLeader("Flare Boss", [], true).setMixedBattleBgm("battle_flare_boss").setVictoryBgm("victory_team_plasma") - .setPartyMemberFunc(0, getRandomPartyMemberFunc([Species.SCREAM_TAIL, Species.FLUTTER_MANE], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.SCREAM_TAIL, Species.FLUTTER_MANE ], TrainerSlot.TRAINER, true, p => { p.setBoss(true, 2); p.generateAndPopulateMoveset(); p.pokeball = PokeballType.ULTRA_BALL; @@ -2035,14 +2162,18 @@ export const trainerConfigs: TrainerConfigs = { p.pokeball = PokeballType.ULTRA_BALL; p.formIndex = 1; // Mega Gyardos p.generateName(); + p.gender = Gender.MALE; })) - .setPartyMemberFunc(5, getRandomPartyMemberFunc([Species.YVELTAL], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(5, getRandomPartyMemberFunc([ Species.YVELTAL ], TrainerSlot.TRAINER, true, p => { p.setBoss(true, 2); p.generateAndPopulateMoveset(); p.pokeball = PokeballType.MASTER_BALL; })), [TrainerType.LUSAMINE]: new TrainerConfig(++t).setName("Lusamine").initForEvilTeamLeader("Aether Boss", []).setMixedBattleBgm("battle_aether_boss").setVictoryBgm("victory_team_plasma") - .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.CLEFABLE ])) + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.CLEFABLE ], TrainerSlot.TRAINER, true, p => { + p.generateAndPopulateMoveset(); + p.gender = Gender.FEMALE; + })) .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.LILLIGANT, Species.HISUI_LILLIGANT ])) .setPartyMemberFunc(2, getRandomPartyMemberFunc([ Species.MILOTIC, Species.PRIMARINA ])) .setPartyMemberFunc(3, getRandomPartyMemberFunc([ Species.GALAR_SLOWBRO, Species.GALAR_SLOWKING ])) @@ -2059,7 +2190,10 @@ export const trainerConfigs: TrainerConfigs = { p.pokeball = PokeballType.ROGUE_BALL; })) .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.MILOTIC, Species.PRIMARINA ])) - .setPartyMemberFunc(2, getRandomPartyMemberFunc([ Species.CLEFABLE ])) + .setPartyMemberFunc(2, getRandomPartyMemberFunc([ Species.CLEFABLE ], TrainerSlot.TRAINER, true, p => { + p.generateAndPopulateMoveset(); + p.gender = Gender.FEMALE; + })) .setPartyMemberFunc(3, getRandomPartyMemberFunc([ Species.STAKATAKA, Species.CELESTEELA, Species.GUZZLORD ], TrainerSlot.TRAINER, true, p => { p.generateAndPopulateMoveset(); p.pokeball = PokeballType.ROGUE_BALL; @@ -2075,10 +2209,24 @@ export const trainerConfigs: TrainerConfigs = { p.pokeball = PokeballType.MASTER_BALL; })), [TrainerType.GUZMA]: new TrainerConfig(++t).setName("Guzma").initForEvilTeamLeader("Skull Boss", []).setMixedBattleBgm("battle_skull_boss").setVictoryBgm("victory_team_plasma") - .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.LOKIX, Species.YANMEGA ])) + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.LOKIX, Species.YANMEGA ], TrainerSlot.TRAINER, true, p => { + //Tinted Lens Lokix, Tinted Lens Yanmega + if (p.species.speciesId === Species.LOKIX) { + p.abilityIndex = 2; + } else if (p.species.speciesId === Species.YANMEGA) { + p.abilityIndex = 1; + } + })) .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.HERACROSS ])) - .setPartyMemberFunc(2, getRandomPartyMemberFunc([ Species.SCIZOR, Species.KLEAVOR ])) - .setPartyMemberFunc(3, getRandomPartyMemberFunc([ Species.GALVANTULA, Species.VIKAVOLT])) + .setPartyMemberFunc(2, getRandomPartyMemberFunc([ Species.SCIZOR, Species.KLEAVOR ], TrainerSlot.TRAINER, true, p => { + //Technician Scizor, Sharpness Kleavor + if (p.species.speciesId === Species.SCIZOR) { + p.abilityIndex = 1; + } else if (p.species.speciesId === Species.KLEAVOR) { + p.abilityIndex = 2; + } + })) + .setPartyMemberFunc(3, getRandomPartyMemberFunc([ Species.GALVANTULA, Species.VIKAVOLT ])) .setPartyMemberFunc(4, getRandomPartyMemberFunc([ Species.PINSIR ], TrainerSlot.TRAINER, true, p => { p.generateAndPopulateMoveset(); p.formIndex = 1; // Mega Pinsir @@ -2088,6 +2236,7 @@ export const trainerConfigs: TrainerConfigs = { .setPartyMemberFunc(5, getRandomPartyMemberFunc([ Species.GOLISOPOD ], TrainerSlot.TRAINER, true, p => { p.setBoss(true, 2); p.generateAndPopulateMoveset(); + p.gender = Gender.MALE; p.pokeball = PokeballType.ULTRA_BALL; })), [TrainerType.GUZMA_2]: new TrainerConfig(++t).setName("Guzma").initForEvilTeamLeader("Skull Boss", [], true).setMixedBattleBgm("battle_skull_boss").setVictoryBgm("victory_team_plasma") @@ -2095,27 +2244,35 @@ export const trainerConfigs: TrainerConfigs = { p.setBoss(true, 2); p.generateAndPopulateMoveset(); p.abilityIndex = 2; //Anticipation + p.gender = Gender.MALE; p.pokeball = PokeballType.ULTRA_BALL; })) - .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.HISUI_SAMUROTT, Species.CRAWDAUNT ], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.SCIZOR, Species.KLEAVOR ], TrainerSlot.TRAINER, true, p => { + //Technician Scizor, Sharpness Kleavor + if (p.species.speciesId === Species.SCIZOR) { + p.abilityIndex = 1; + } else if (p.species.speciesId === Species.KLEAVOR) { + p.abilityIndex = 2; + } + })) + .setPartyMemberFunc(2, getRandomPartyMemberFunc([ Species.HISUI_SAMUROTT, Species.CRAWDAUNT ], TrainerSlot.TRAINER, true, p => { p.abilityIndex = 2; //Sharpness Hisui Samurott, Adaptability Crawdaunt })) - .setPartyMemberFunc(2, getRandomPartyMemberFunc([ Species.SCIZOR, Species.KLEAVOR ])) - .setPartyMemberFunc(3, getRandomPartyMemberFunc([ Species.PINSIR ], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(3, getRandomPartyMemberFunc([ Species.BUZZWOLE ], TrainerSlot.TRAINER, true, p => { p.generateAndPopulateMoveset(); + p.pokeball = PokeballType.ROGUE_BALL; + })) + .setPartyMemberFunc(4, getRandomPartyMemberFunc([ Species.XURKITREE ], TrainerSlot.TRAINER, true, p => { + p.setBoss(true, 2); + p.generateAndPopulateMoveset(); + p.pokeball = PokeballType.ROGUE_BALL; + })) + .setPartyMemberFunc(5, getRandomPartyMemberFunc([ Species.PINSIR ], TrainerSlot.TRAINER, true, p => { + p.setBoss(true, 2); p.formIndex = 1; + p.generateAndPopulateMoveset(); p.generateName(); p.pokeball = PokeballType.ULTRA_BALL; - })) - .setPartyMemberFunc(4, getRandomPartyMemberFunc([ Species.BUZZWOLE ], TrainerSlot.TRAINER, true, p => { - p.setBoss(true, 2); - p.generateAndPopulateMoveset(); - p.pokeball = PokeballType.ROGUE_BALL; - })) - .setPartyMemberFunc(5, getRandomPartyMemberFunc([ Species.XURKITREE ], TrainerSlot.TRAINER, true, p => { - p.setBoss(true, 2); - p.generateAndPopulateMoveset(); - p.pokeball = PokeballType.ROGUE_BALL; })), [TrainerType.ROSE]: new TrainerConfig(++t).setName("Rose").initForEvilTeamLeader("Macro Boss", []).setMixedBattleBgm("battle_macro_boss").setVictoryBgm("victory_team_plasma") .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.ARCHALUDON ])) @@ -2129,19 +2286,19 @@ export const trainerConfigs: TrainerConfigs = { p.formIndex = 1; // G-Max Copperajah p.generateName(); p.pokeball = PokeballType.ULTRA_BALL; + p.gender = Gender.FEMALE; })), [TrainerType.ROSE_2]: new TrainerConfig(++t).setName("Rose").initForEvilTeamLeader("Macro Boss", [], true).setMixedBattleBgm("battle_macro_boss").setVictoryBgm("victory_team_plasma") - .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.MELMETAL ], TrainerSlot.TRAINER, true, p => { + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.ARCHALUDON ], TrainerSlot.TRAINER, true, p => { p.setBoss(true, 2); p.generateAndPopulateMoveset(); - p.pokeball = PokeballType.ULTRA_BALL; })) .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.AEGISLASH, Species.GHOLDENGO ])) .setPartyMemberFunc(2, getRandomPartyMemberFunc([ Species.DRACOVISH, Species.DRACOZOLT ], TrainerSlot.TRAINER, true, p => { p.generateAndPopulateMoveset(); p.abilityIndex = 1; //Strong Jaw Dracovish, Hustle Dracozolt })) - .setPartyMemberFunc(3, getRandomPartyMemberFunc([ Species.ARCHALUDON ])) + .setPartyMemberFunc(3, getRandomPartyMemberFunc([ Species.MELMETAL ])) .setPartyMemberFunc(4, getRandomPartyMemberFunc([ Species.GALAR_ARTICUNO, Species.GALAR_ZAPDOS, Species.GALAR_MOLTRES ], TrainerSlot.TRAINER, true, p => { p.setBoss(true, 2); p.generateAndPopulateMoveset(); @@ -2153,7 +2310,68 @@ export const trainerConfigs: TrainerConfigs = { p.formIndex = 1; // G-Max Copperajah p.generateName(); p.pokeball = PokeballType.ULTRA_BALL; + p.gender = Gender.FEMALE; })), + [TrainerType.PENNY]: new TrainerConfig(++t).setName("Cassiopeia").initForEvilTeamLeader("Star Boss", []).setMixedBattleBgm("battle_star_boss").setVictoryBgm("victory_team_plasma") + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.VAPOREON, Species.JOLTEON, Species.FLAREON ])) + .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.ESPEON, Species.UMBREON ], TrainerSlot.TRAINER, true, p => { + p.abilityIndex = 2; // Magic Bounce Espeon, Inner Focus Umbreon + p.generateAndPopulateMoveset(); + })) + .setPartyMemberFunc(2, getRandomPartyMemberFunc([ Species.LEAFEON, Species.GLACEON ])) + .setPartyMemberFunc(3, getRandomPartyMemberFunc([ Species.ROTOM ], TrainerSlot.TRAINER, true, p => { + p.generateAndPopulateMoveset(); + p.formIndex = Utils.randSeedInt(5, 1); // Heat, Wash, Frost, Fan, or Mow + })) + .setPartyMemberFunc(4, getRandomPartyMemberFunc([ Species.SYLVEON ], TrainerSlot.TRAINER, true, p => { + p.abilityIndex = 2; // Pixilate + p.generateAndPopulateMoveset(); + p.gender = Gender.FEMALE; + })) + .setPartyMemberFunc(5, getRandomPartyMemberFunc([ Species.EEVEE ], TrainerSlot.TRAINER, true, p => { + p.setBoss(true, 2); + p.generateAndPopulateMoveset(); + p.formIndex = 2; // G-Max Eevee + p.pokeball = PokeballType.ULTRA_BALL; + p.generateName(); + })) + .setGenModifiersFunc(party => { + const teraPokemon = party[4]; + return [ modifierTypes.TERA_SHARD().generateType([], [ teraPokemon.species.type1 ])!.withIdFromFunc(modifierTypes.TERA_SHARD).newModifier(teraPokemon) as PersistentModifier ]; //TODO: is the bang correct? + }), + [TrainerType.PENNY_2]: new TrainerConfig(++t).setName("Cassiopeia").initForEvilTeamLeader("Star Boss", [], true).setMixedBattleBgm("battle_star_boss").setVictoryBgm("victory_team_plasma") + .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.SYLVEON ], TrainerSlot.TRAINER, true, p => { + p.setBoss(true, 2); + p.abilityIndex = 2; // Pixilate + p.generateAndPopulateMoveset(); + p.gender = Gender.FEMALE; + })) + .setPartyMemberFunc(1, getRandomPartyMemberFunc([ Species.ENTEI, Species.RAIKOU, Species.SUICUNE ], TrainerSlot.TRAINER, true, p => { + p.generateAndPopulateMoveset(); + p.pokeball = PokeballType.ULTRA_BALL; + })) + .setPartyMemberFunc(2, getRandomPartyMemberFunc([ Species.WALKING_WAKE, Species.GOUGING_FIRE, Species.RAGING_BOLT ])) + .setPartyMemberFunc(3, getRandomPartyMemberFunc([ Species.REVAVROOM ], TrainerSlot.TRAINER, true, p => { + p.formIndex = Utils.randSeedInt(5, 1); //Random Starmobile form + p.generateAndPopulateMoveset(); + p.pokeball = PokeballType.ROGUE_BALL; + })) + .setPartyMemberFunc(4, getRandomPartyMemberFunc([ Species.EEVEE ], TrainerSlot.TRAINER, true, p => { + p.setBoss(true, 2); + p.generateAndPopulateMoveset(); + p.formIndex = 2; + p.generateName(); + p.pokeball = PokeballType.ULTRA_BALL; + })) + .setPartyMemberFunc(5, getRandomPartyMemberFunc([ Species.ZAMAZENTA ], TrainerSlot.TRAINER, true, p => { + p.setBoss(true, 2); + p.generateAndPopulateMoveset(); + p.pokeball = PokeballType.MASTER_BALL; + })) + .setGenModifiersFunc(party => { + const teraPokemon = party[0]; + return [ modifierTypes.TERA_SHARD().generateType([], [ teraPokemon.species.type1 ])!.withIdFromFunc(modifierTypes.TERA_SHARD).newModifier(teraPokemon) as PersistentModifier ]; //TODO: is the bang correct? + }), [TrainerType.BUCK]: new TrainerConfig(++t).setName("Buck").initForStatTrainer([], true) .setPartyMemberFunc(0, getRandomPartyMemberFunc([ Species.CLAYDOL ], TrainerSlot.TRAINER, true, p => { p.setBoss(true, 3); @@ -2302,6 +2520,24 @@ export const trainerConfigs: TrainerConfigs = { .setMoneyMultiplier(2) .setPartyTemplates(new TrainerPartyCompoundTemplate(new TrainerPartyTemplate(3, PartyMemberStrength.AVERAGE), new TrainerPartyTemplate(2, PartyMemberStrength.STRONG))), [TrainerType.BUG_TYPE_SUPERFAN]: new TrainerConfig(++t).setMoneyMultiplier(2.25).setEncounterBgm(TrainerType.ACE_TRAINER) - .setPartyTemplates(new TrainerPartyTemplate(2, PartyMemberStrength.AVERAGE)) + .setPartyTemplates(new TrainerPartyTemplate(2, PartyMemberStrength.AVERAGE)), + [TrainerType.EXPERT_POKEMON_BREEDER]: new TrainerConfig(++t).setMoneyMultiplier(3).setEncounterBgm(TrainerType.ACE_TRAINER).setLocalizedName("Expert Pokemon Breeder") + .setPartyTemplates(new TrainerPartyTemplate(3, PartyMemberStrength.AVERAGE)), + [TrainerType.FUTURE_SELF_M]: new TrainerConfig(++t) + .setMoneyMultiplier(0) + .setEncounterBgm("mystery_encounter_weird_dream") + .setBattleBgm("mystery_encounter_weird_dream") + .setMixedBattleBgm("mystery_encounter_weird_dream") + .setVictoryBgm("mystery_encounter_weird_dream") + .setLocalizedName("Future Self M") + .setPartyTemplates(new TrainerPartyTemplate(6, PartyMemberStrength.STRONG)), + [TrainerType.FUTURE_SELF_F]: new TrainerConfig(++t) + .setMoneyMultiplier(0) + .setEncounterBgm("mystery_encounter_weird_dream") + .setBattleBgm("mystery_encounter_weird_dream") + .setMixedBattleBgm("mystery_encounter_weird_dream") + .setVictoryBgm("mystery_encounter_weird_dream") + .setLocalizedName("Future Self F") + .setPartyTemplates(new TrainerPartyTemplate(6, PartyMemberStrength.STRONG)) }; diff --git a/src/data/trainer-names.ts b/src/data/trainer-names.ts index 899702ff193..d075b7121f2 100644 --- a/src/data/trainer-names.ts +++ b/src/data/trainer-names.ts @@ -75,56 +75,56 @@ const trainerNameConfigs: TrainerNameConfigs = { }; export const trainerNamePools = { - [TrainerType.ACE_TRAINER]: [["Aaron", "Allen", "Blake", "Brian", "Gaven", "Jake", "Kevin", "Mike", "Nick", "Paul", "Ryan", "Sean", "Darin", "Albert", "Berke", "Clyde", "Edgar", "George", "Leroy", "Owen", "Parker", "Randall", "Ruben", "Samuel", "Vincent", "Warren", "Wilton", "Zane", "Alfred", "Braxton", "Felix", "Gerald", "Jonathan", "Leonel", "Marcel", "Mitchell", "Quincy", "Roderick", "Colby", "Rolando", "Yuji", "Abel", "Anton", "Arthur", "Cesar", "Dalton", "Dennis", "Ernest", "Garrett", "Graham", "Henry", "Isaiah", "Jonah", "Jose", "Keenan", "Micah", "Omar", "Quinn", "Rodolfo", "Saul", "Sergio", "Skylar", "Stefan", "Zachery", "Alton", "Arabella", "Bonita", "Cal", "Cody", "French", "Kobe", "Paulo", "Shaye", "Austin", "Beckett", "Charlie", "Corky", "David", "Dwayne", "Elmer", "Jesse", "Jared", "Johan", "Jordan", "Kipp", "Lou", "Terry", "Tom", "Webster", "Billy", "Doyle", "Enzio", "Geoff", "Grant", "Kelsey", "Miguel", "Pierce", "Ray", "Santino", "Shel", "Adelbert", "Bence", "Emil", "Evan", "Mathis", "Maxim", "Neil", "Rico", "Robbie", "Theo", "Viktor", "Benedict", "Cornelius", "Hisato", "Leopold", "Neville", "Vito", "Chase", "Cole", "Hiroshi", "Jackson", "Jim", "Kekoa", "Makana", "Yuki", "Elwood", "Seth", "Alvin", "Arjun", "Arnold", "Cameron", "Carl", "Carlton", "Christopher", "Dave", "Dax", "Dominic", "Edmund", "Finn", "Fred", "Garret", "Grayson", "Jace", "Jaxson", "Jay", "Jirard", "Johnson", "Kayden", "Kite", "Louis", "Mac", "Marty", "Percy", "Raymond", "Ronnie", "Satch", "Tim", "Zach", "Conner", "Vince", "Bedro", "Boda", "Botan", "Daras", "Dury", "Herton", "Rewn", "Stum", "Tock", "Trilo", "Berki", "Cruik", "Dazon", "Desid", "Dillot", "Farfin", "Forgon", "Hebel", "Morfon", "Moril", "Shadd", "Vanhub", "Bardo", "Carben", "Degin", "Gorps", "Klept", "Lask", "Malex", "Mopar", "Niled", "Noxon", "Teslor", "Tetil"], ["Beth", "Carol", "Cybil", "Emma", "Fran", "Gwen", "Irene", "Jenn", "Joyce", "Kate", "Kelly", "Lois", "Lola", "Megan", "Quinn", "Reena", "Cara", "Alexa", "Brooke", "Caroline", "Elaine", "Hope", "Jennifer", "Jody", "Julie", "Lori", "Mary", "Michelle", "Shannon", "Wendy", "Alexia", "Alicia", "Athena", "Carolina", "Cristin", "Darcy", "Dianne", "Halle", "Jazmyn", "Katelynn", "Keira", "Marley", "Allyson", "Kathleen", "Naomi", "Alyssa", "Ariana", "Brandi", "Breanna", "Brenda", "Brenna", "Catherine", "Clarice", "Dana", "Deanna", "Destiny", "Jamie", "Jasmin", "Kassandra", "Laura", "Maria", "Mariah", "Maya", "Meagan", "Mikayla", "Monique", "Natasha", "Olivia", "Sandra", "Savannah", "Sydney", "Moira", "Piper", "Salma", "Allison", "Beverly", "Cathy", "Cheyenne", "Clara", "Dara", "Eileen", "Glinda", "Junko", "Lena", "Lucille", "Mariana", "Olwen", "Shanta", "Stella", "Angi", "Belle", "Chandra", "Cora", "Eve", "Jacqueline", "Jeanne", "Juliet", "Kathrine", "Layla", "Lucca", "Melina", "Miki", "Nina", "Sable", "Shelly", "Summer", "Trish", "Vicki", "Alanza", "Cordelia", "Hilde", "Imelda", "Michele", "Mireille", "Claudia", "Constance", "Harriet", "Honor", "Melba", "Portia", "Alexis", "Angela", "Karla", "Lindsey", "Tori", "Sheri", "Jada", "Kailee", "Amanda", "Annie", "Kindra", "Kyla", "Sofia", "Yvette", "Becky", "Flora", "Gloria", "Buna", "Ferda", "Lehan", "Liqui", "Lomen", "Neira", "Atilo", "Detta", "Gilly", "Gosney", "Levens", "Moden", "Rask", "Rateis", "Rosno", "Tynan", "Veron", "Zoel", "Cida", "Dibsin", "Dodin", "Ebson", "Equin", "Flostin", "Gabsen", "Halsion", "Hileon", "Quelor", "Rapeel", "Roze", "Tensin"]], - [TrainerType.ARTIST]: [["Ismael", "William", "Horton", "Pierre", "Zach", "Gough", "Salvador", "Vincent", "Duncan"], ["Georgia"]], - [TrainerType.BACKERS]: [["Alf & Fred", "Hawk & Dar", "Joe & Ross", "Les & Web", "Masa & Yas", "Stu & Art"], ["Ai & Ciel", "Ami & Eira", "Cam & Abby", "Fey & Sue", "Kat & Phae", "Kay & Ali", "Ava & Aya", "Cleo & Rio", "May & Mal"]], - [TrainerType.BACKPACKER]: [["Alexander", "Carlos", "Herman", "Jerome", "Keane", "Kelsey", "Kiyo", "Michael", "Nate", "Peter", "Sam", "Stephen", "Talon", "Terrance", "Toru", "Waylon", "Boone", "Clifford", "Ivan", "Kendall", "Lowell", "Randall", "Reece", "Roland", "Shane", "Walt", "Farid", "Heike", "Joren", "Lane", "Roderick", "Darnell", "Deon", "Emory", "Graeme", "Grayson", "Aitor", "Alex", "Arturo", "Asier", "Jaime", "Jonathan", "Julio", "Kevin", "Kosuke", "Lander", "Markel", "Mateo", "Nil", "Pau", "Samuel"], ["Anna", "Corin", "Elaine", "Emi", "Jill", "Kumiko", "Liz", "Lois", "Lora", "Molly", "Patty", "Ruth", "Vicki", "Annie", "Blossom", "Clara", "Eileen", "Mae", "Myra", "Rachel", "Tami", "Ashley", "Mikiko", "Kiana", "Perdy", "Maria", "Yuho", "Peren", "Barbara", "Diane"]], - [TrainerType.BAKER]: ["Chris", "Jenn", "Lilly"], - [TrainerType.BEAUTY]: ["Cassie", "Julia", "Olivia", "Samantha", "Valerie", "Victoria", "Bridget", "Connie", "Jessica", "Johanna", "Melissa", "Sheila", "Shirley", "Tiffany", "Namiko", "Thalia", "Grace", "Lola", "Lori", "Maura", "Tamia", "Cyndy", "Devon", "Gabriella", "Harley", "Lindsay", "Nicola", "Callie", "Charlotte", "Kassandra", "December", "Fleming", "Nikola", "Aimee", "Anais", "Brigitte", "Cassandra", "Andrea", "Brittney", "Carolyn", "Krystal", "Alexis", "Alice", "Aina", "Anya", "Arianna", "Aubrey", "Beverly", "Camille", "Beauty", "Evette", "Hansol", "Haruka", "Jill", "Jo", "Lana", "Lois", "Lucy", "Mai", "Nickie", "Nicole", "Prita", "Rose", "Shelly", "Suzy", "Tessa", "Anita", "Alissa", "Rita", "Cudsy", "Eloff", "Miru", "Minot", "Nevah", "Niven", "Ogoin"], - [TrainerType.BIKER]: ["Charles", "Dwayne", "Glenn", "Harris", "Joel", "Riley", "Zeke", "Alex", "Billy", "Ernest", "Gerald", "Hideo", "Isaac", "Jared", "Jaren", "Jaxon", "Jordy", "Lao", "Lukas", "Malik", "Nikolas", "Ricardo", "Ruben", "Virgil", "William", "Aiden", "Dale", "Dan", "Jacob", "Markey", "Reese", "Teddy", "Theron", "Jeremy", "Morgann", "Phillip", "Philip", "Stanley", "Dillon"], - [TrainerType.BLACK_BELT]: [["Kenji", "Lao", "Lung", "Nob", "Wai", "Yoshi", "Atsushi", "Daisuke", "Hideki", "Hitoshi", "Kiyo", "Koichi", "Koji", "Yuji", "Cristian", "Rhett", "Takao", "Theodore", "Zander", "Aaron", "Hugh", "Mike", "Nicolas", "Shea", "Takashi", "Adam", "Carl", "Colby", "Darren", "David", "Davon", "Derek", "Eddie", "Gregory", "Griffin", "Jarrett", "Jeffery", "Kendal", "Kyle", "Luke", "Miles", "Nathaniel", "Philip", "Rafael", "Ray", "Ricky", "Sean", "Willie", "Ander", "Manford", "Benjamin", "Corey", "Edward", "Grant", "Jay", "Kendrew", "Kentaro", "Ryder", "Teppei", "Thomas", "Tyrone", "Andrey", "Donny", "Drago", "Gordon", "Grigor", "Jeriel", "Kenneth", "Martell", "Mathis", "Rich", "Rocky", "Rodrigo", "Wesley", "Zachery", "Alonzo", "Cadoc", "Gunnar", "Igor", "Killian", "Markus", "Ricardo", "Yanis", "Banting", "Clayton", "Duane", "Earl", "Greg", "Roy", "Terry", "Tracy", "Walter", "Alvaro", "Curtis", "Francis", "Ross", "Brice", "Cheng", "Dudley", "Eric", "Kano", "Masahiro", "Randy", "Ryuji", "Steve", "Tadashi", "Wong", "Yuen", "Brian", "Carter", "Reece", "Nick", "Yang"], ["Cora", "Cyndy", "Jill", "Laura", "Sadie", "Tessa", "Vivian", "Aisha", "Callie", "Danielle", "Helene", "Jocelyn", "Lilith", "Paula", "Reyna", "Helen", "Kelsey", "Tyler", "Amy", "Chandra", "Hillary", "Janie", "Lee", "Maggie", "Mikiko", "Miriam", "Sharon", "Susie", "Xiao", "Alize", "Azra", "Brenda", "Chalina", "Chan", "Glinda", "Maki", "Tia", "Tiffany", "Wendy", "Andrea", "Gabrielle", "Gerardine", "Hailey", "Hedvig", "Justine", "Kinsey", "Sigrid", "Veronique", "Tess"]], - [TrainerType.BREEDER]: [["Isaac", "Myles", "Salvadore", "Albert", "Kahlil", "Eustace", "Galen", "Owen", "Addison", "Marcus", "Foster", "Cory", "Glenn", "Jay", "Wesley", "William", "Adrian", "Bradley", "Jaime"], ["Allison", "Alize", "Bethany", "Lily", "Lydia", "Gabrielle", "Jayden", "Pat", "Veronica", "Amber", "Jennifer", "Kaylee", "Adelaide", "Brooke", "Ethel", "April", "Irene", "Magnolia", "Amala", "Mercy", "Amanda", "Ikue", "Savannah", "Yuka", "Chloe", "Debra", "Denise", "Elena"]], - [TrainerType.CLERK]: [["Chaz", "Clemens", "Doug", "Fredric", "Ivan", "Isaac", "Nelson", "Wade", "Warren", "Augustin", "Gilligan", "Cody", "Jeremy", "Shane", "Dugal", "Royce", "Ronald"], ["Alberta", "Ingrid", "Katie", "Piper", "Trisha", "Wren", "Britney", "Lana", "Jessica", "Kristen", "Michelle", "Gabrielle"]], - [TrainerType.CYCLIST]: [["Axel", "James", "John", "Ryan", "Hector", "Jeremiah"], ["Kayla", "Megan", "Nicole", "Rachel", "Krissa", "Adelaide"]], - [TrainerType.DANCER]: ["Brian", "Davey", "Dirk", "Edmond", "Mickey", "Raymond", "Cara", "Julia", "Maika", "Mireille", "Ronda", "Zoe"], - [TrainerType.DEPOT_AGENT]: ["Josh", "Hank", "Vincent"], - [TrainerType.DOCTOR]: [["Hank", "Jerry", "Jules", "Logan", "Wayne", "Braid", "Derek", "Heath", "Julius", "Kit", "Graham"], ["Kirsten", "Sachiko", "Shery", "Carol", "Dixie", "Mariah"]], - [TrainerType.FIREBREATHER]: ["Bill", "Burt", "Cliff", "Dick", "Lyle", "Ned", "Otis", "Ray", "Richard", "Walt"], - [TrainerType.FISHERMAN]: ["Andre", "Arnold", "Barney", "Chris", "Edgar", "Henry", "Jonah", "Justin", "Kyle", "Martin", "Marvin", "Ralph", "Raymond", "Scott", "Stephen", "Wilton", "Tully", "Andrew", "Barny", "Carter", "Claude", "Dale", "Elliot", "Eugene", "Ivan", "Ned", "Nolan", "Roger", "Ronald", "Wade", "Wayne", "Darian", "Kai", "Chip", "Hank", "Kaden", "Tommy", "Tylor", "Alec", "Brett", "Cameron", "Cody", "Cole", "Cory", "Erick", "George", "Joseph", "Juan", "Kenneth", "Luc", "Miguel", "Travis", "Walter", "Zachary", "Josh", "Gideon", "Kyler", "Liam", "Murphy", "Bruce", "Damon", "Devon", "Hubert", "Jones", "Lydon", "Mick", "Pete", "Sean", "Sid", "Vince", "Bucky", "Dean", "Eustace", "Kenzo", "Leroy", "Mack", "Ryder", "Ewan", "Finn", "Murray", "Seward", "Shad", "Wharton", "Finley", "Fisher", "Fisk", "River", "Sheaffer", "Timin", "Carl", "Ernest", "Hal", "Herbert", "Hisato", "Mike", "Vernon", "Harriet", "Marina", "Chase"], - [TrainerType.GUITARIST]: ["Anna", "Beverly", "January", "Tina", "Alicia", "Claudia", "Julia", "Lidia", "Mireia", "Noelia", "Sara", "Sheila", "Tatiana"], - [TrainerType.HARLEQUIN]: ["Charley", "Ian", "Jack", "Kerry", "Louis", "Pat", "Paul", "Rick", "Anders", "Clarence", "Gary"], - [TrainerType.HIKER]: ["Anthony", "Bailey", "Benjamin", "Daniel", "Erik", "Jim", "Kenny", "Leonard", "Michael", "Parry", "Phillip", "Russell", "Sidney", "Tim", "Timothy", "Alan", "Brice", "Clark", "Eric", "Lenny", "Lucas", "Mike", "Trent", "Devan", "Eli", "Marc", "Sawyer", "Allen", "Daryl", "Dudley", "Earl", "Franklin", "Jeremy", "Marcos", "Nob", "Oliver", "Wayne", "Alexander", "Damon", "Jonathan", "Justin", "Kevin", "Lorenzo", "Louis", "Maurice", "Nicholas", "Reginald", "Robert", "Theodore", "Bruce", "Clarke", "Devin", "Dwight", "Edwin", "Eoin", "Noland", "Russel", "Andy", "Bret", "Darrell", "Gene", "Hardy", "Hugh", "Jebediah", "Jeremiah", "Kit", "Neil", "Terrell", "Don", "Doug", "Hunter", "Jared", "Jerome", "Keith", "Manuel", "Markus", "Otto", "Shelby", "Stephen", "Teppei", "Tobias", "Wade", "Zaiem", "Aaron", "Alain", "Bergin", "Bernard", "Brent", "Corwin", "Craig", "Delmon", "Dunstan", "Orestes", "Ross", "Davian", "Calhoun", "David", "Gabriel", "Ryan", "Thomas", "Travis", "Zachary", "Anuhea", "Barnaby", "Claus", "Collin", "Colson", "Dexter", "Dillan", "Eugine", "Farkas", "Hisato", "Julius", "Kenji", "Irwin", "Lionel", "Paul", "Richter", "Valentino", "Donald", "Douglas", "Kevyn", "Chester"], //["Angela","Carla","Celia","Daniela","Estela","Fatima","Helena","Leire","Lucia","Luna","Manuela","Mar","Marina","Miyu","Nancy","Nerea","Paula","Rocio","Yanira"] - [TrainerType.HOOLIGANS]: ["Jim & Cas", "Rob & Sal"], - [TrainerType.HOOPSTER]: ["Bobby", "John", "Lamarcus", "Derrick", "Nicolas"], - [TrainerType.INFIELDER]: ["Alex", "Connor", "Todd"], - [TrainerType.JANITOR]: ["Caleb", "Geoff", "Brady", "Felix", "Orville", "Melvin", "Shawn"], - [TrainerType.LINEBACKER]: ["Bob", "Dan", "Jonah"], - [TrainerType.MAID]: ["Belinda", "Sophie", "Emily", "Elena", "Clare", "Alica", "Tanya", "Tammy"], - [TrainerType.MUSICIAN]: ["Boris", "Preston", "Charles", "Clyde", "Vincent", "Dalton", "Kirk", "Shawn", "Fabian", "Fernando", "Joseph", "Marcos", "Arturo", "Jerry", "Lonnie", "Tony"], - [TrainerType.NURSERY_AIDE]: ["Autumn", "Briana", "Leah", "Miho", "Ethel", "Hollie", "Ilse", "June", "Kimya", "Rosalyn"], - [TrainerType.OFFICER]: ["Dirk", "Keith", "Alex", "Bobby", "Caleb", "Danny", "Dylan", "Thomas", "Daniel", "Jeff", "Braven", "Dell", "Neagle", "Haruki", "Mitchell", "Raymond"], - [TrainerType.PARASOL_LADY]: ["Angelica", "Clarissa", "Madeline", "Akari", "Annabell", "Kayley", "Rachel", "Alexa", "Sabrina", "April", "Gwyneth", "Laura", "Lumi", "Mariah", "Melita", "Nicole", "Tihana", "Ingrid", "Tyra"], - [TrainerType.PILOT]: ["Chase", "Leonard", "Ted", "Elron", "Ewing", "Flynn", "Winslow"], - [TrainerType.POKEFAN]: [["Alex", "Allan", "Brandon", "Carter", "Colin", "Derek", "Jeremy", "Joshua", "Rex", "Robert", "Trevor", "William", "Colton", "Miguel", "Francisco", "Kaleb", "Leonard", "Boone", "Elliot", "Jude", "Norbert", "Corey", "Gabe", "Baxter"], ["Beverly", "Georgia", "Jaime", "Ruth", "Isabel", "Marissa", "Vanessa", "Annika", "Bethany", "Kimberly", "Meredith", "Rebekah", "Eleanor", "Darcy", "Lydia", "Sachiko", "Abigail", "Agnes", "Lydie", "Roisin", "Tara", "Carmen", "Janet"]], - [TrainerType.PRESCHOOLER]: [["Billy", "Doyle", "Evan", "Homer", "Tully", "Albert", "Buster", "Greg", "Ike", "Jojo", "Tyrone", "Adrian", "Oliver", "Hayden", "Hunter", "Kaleb", "Liam", "Dylan"], ["Juliet", "Mia", "Sarah", "Wendy", "Winter", "Chrissy", "Eva", "Lin", "Samantha", "Ella", "Lily", "Natalie", "Ailey", "Hannah", "Malia", "Kindra", "Nancy"]], - [TrainerType.PSYCHIC]: [["Fidel", "Franklin", "Gilbert", "Greg", "Herman", "Jared", "Mark", "Nathan", "Norman", "Phil", "Richard", "Rodney", "Cameron", "Edward", "Fritz", "Joshua", "Preston", "Virgil", "William", "Alvaro", "Blake", "Cedric", "Keenan", "Nicholas", "Dario", "Johan", "Lorenzo", "Tyron", "Bryce", "Corbin", "Deandre", "Elijah", "Kody", "Landon", "Maxwell", "Mitchell", "Sterling", "Eli", "Nelson", "Vernon", "Gaven", "Gerard", "Low", "Micki", "Perry", "Rudolf", "Tommy", "Al", "Nandor", "Tully", "Arthur", "Emanuel", "Franz", "Harry", "Paschal", "Robert", "Sayid", "Angelo", "Anton", "Arin", "Avery", "Danny", "Frasier", "Harrison", "Jaime", "Ross", "Rui", "Vlad", "Mason"], ["Alexis", "Hannah", "Jacki", "Jaclyn", "Kayla", "Maura", "Samantha", "Alix", "Brandi", "Edie", "Macey", "Mariella", "Marlene", "Laura", "Rodette", "Abigail", "Brittney", "Chelsey", "Daisy", "Desiree", "Kendra", "Lindsey", "Rachael", "Valencia", "Belle", "Cybil", "Doreen", "Dua", "Future", "Lin", "Madhu", "Alia", "Ena", "Joyce", "Lynette", "Olesia", "Sarah"]], - [TrainerType.RANGER]: [["Carlos", "Jackson", "Sebastian", "Gav", "Lorenzo", "Logan", "Nicolas", "Trenton", "Deshawn", "Dwayne", "Jeffery", "Kyler", "Taylor", "Alain", "Claude", "Crofton", "Forrest", "Harry", "Jaden", "Keith", "Lewis", "Miguel", "Pedro", "Ralph", "Richard", "Bret", "Daryl", "Eddie", "Johan", "Leaf", "Louis", "Maxwell", "Parker", "Rick", "Steve", "Bjorn", "Chaise", "Dean", "Lee", "Maurice", "Nash", "Ralf", "Reed", "Shinobu", "Silas"], ["Catherine", "Jenna", "Sophia", "Merdith", "Nora", "Beth", "Chelsea", "Katelyn", "Madeline", "Allison", "Ashlee", "Felicia", "Krista", "Annie", "Audra", "Brenda", "Chloris", "Eliza", "Heidi", "Irene", "Mary", "Mylene", "Shanti", "Shelly", "Thalia", "Anja", "Briana", "Dianna", "Elaine", "Elle", "Hillary", "Katie", "Lena", "Lois", "Malory", "Melita", "Mikiko", "Naoko", "Serenity", "Ambre", "Brooke", "Clementine", "Melina", "Petra", "Twiggy"]], - [TrainerType.RICH]: [["Alfred", "Edward", "Gregory", "Preston", "Thomas", "Tucker", "Walter", "Clifford", "Everett", "Micah", "Nate", "Pierre", "Terrance", "Arthur", "Brooks", "Emanuel", "Lamar", "Jeremy", "Leonardo", "Milton", "Frederic", "Renaud", "Robert", "Yan", "Daniel", "Sheldon", "Stonewall", "Gerald", "Ronald", "Smith", "Stanley", "Reginald", "Orson", "Wilco", "Caden", "Glenn"], ["Rebecca", "Reina", "Cassandra", "Emilia", "Grace", "Marian", "Elizabeth", "Kathleen", "Sayuri", "Caroline", "Judy"]], - [TrainerType.RICH_KID]: [["Garret", "Winston", "Dawson", "Enrique", "Jason", "Roman", "Trey", "Liam", "Anthony", "Brad", "Cody", "Manuel", "Martin", "Pierce", "Rolan", "Keenan", "Filbert", "Antoin", "Cyus", "Diek", "Dugo", "Flitz", "Jurek", "Lond", "Perd", "Quint", "Basto", "Benit", "Brot", "Denc", "Guyit", "Marcon", "Perc", "Puros", "Roex", "Sainz", "Symin", "Tark", "Venak"], ["Anette", "Brianna", "Cindy", "Colleen", "Daphne", "Elizabeth", "Naomi", "Sarah", "Charlotte", "Gillian", "Jacki", "Lady", "Melissa", "Celeste", "Colette", "Elizandra", "Isabel", "Lynette", "Magnolia", "Sophie", "Lina", "Dulcie", "Auro", "Brin", "Caril", "Eloos", "Gwin", "Illa", "Kowly", "Rima", "Ristin", "Vesey", "Brena", "Deasy", "Denslon", "Kylet", "Nemi", "Rene", "Sanol", "Stouner", "Sturk", "Talmen", "Zoila"]], - [TrainerType.ROUGHNECK]: ["Camron", "Corey", "Gabriel", "Isaiah", "Jamal", "Koji", "Luke", "Paxton", "Raul", "Zeek", "Kirby", "Chance", "Dave", "Fletcher", "Johnny", "Reese", "Joey", "Ricky", "Silvester", "Martin"], - [TrainerType.SAILOR]: ["Alberto", "Bost", "Brennan", "Brenden", "Claude", "Cory", "Damian", "Dirk", "Duncan", "Dwayne", "Dylan", "Eddie", "Edmond", "Elijah", "Ernest", "Eugene", "Garrett", "Golos", "Gratin", "Grestly", "Harry", "Hols", "Hudson", "Huey", "Jebol", "Jeff", "Leonald", "Luther", "Kelvin", "Kenneth", "Kent", "Knook", "Marc", "Mifis", "Monar", "Morkor", "Ordes", "Oxlin", "Parker", "Paul", "Philip", "Roberto", "Samson", "Skyler", "Stanly", "Tebu", "Terrell", "Trevor", "Yasu", "Zachariah"], - [TrainerType.SCIENTIST]: [["Jed", "Marc", "Mitch", "Rich", "Ross", "Beau", "Braydon", "Connor", "Ed", "Ivan", "Jerry", "Jose", "Joshua", "Parker", "Rodney", "Taylor", "Ted", "Travis", "Zackery", "Darrius", "Emilio", "Fredrick", "Shaun", "Stefano", "Travon", "Daniel", "Garett", "Gregg", "Linden", "Lowell", "Trenton", "Dudley", "Luke", "Markus", "Nathan", "Orville", "Randall", "Ron", "Ronald", "Simon", "Steve", "William", "Franklin", "Clarke", "Jacques", "Terrance", "Ernst", "Justus", "Ikaika", "Jayson", "Kyle", "Reid", "Tyrone", "Adam", "Albert", "Alphonse", "Cory", "Donnie", "Elton", "Francis", "Gordon", "Herbert", "Humphrey", "Jordan", "Julian", "Keaton", "Levi", "Melvin", "Murray", "West", "Craig", "Coren", "Dubik", "Kotan", "Lethco", "Mante", "Mort", "Myron", "Odlow", "Ribek", "Roeck", "Vogi", "Vonder", "Zogo", "Doimo", "Doton", "Durel", "Hildon", "Kukla", "Messa", "Nanot", "Platen", "Raburn", "Reman", "Acrod", "Coffy", "Elrok", "Foss", "Hardig", "Hombol", "Hospel", "Kaller", "Klots", "Krilok", "Limar", "Loket", "Mesak", "Morbit", "Newin", "Orill", "Tabor", "Tekot"], ["Blythe", "Chan", "Kathrine", "Marie", "Maria", "Naoko", "Samantha", "Satomi", "Shannon", "Athena", "Caroline", "Lumi", "Lumina", "Marissa", "Sonia"]], - [TrainerType.SMASHER]: ["Aspen", "Elena", "Mari", "Amy", "Lizzy"], - [TrainerType.SNOW_WORKER]: [["Braden", "Brendon", "Colin", "Conrad", "Dillan", "Gary", "Gerardo", "Holden", "Jackson", "Mason", "Quentin", "Willy", "Noel", "Arnold", "Brady", "Brand", "Cairn", "Cliff", "Don", "Eddie", "Felix", "Filipe", "Glenn", "Gus", "Heath", "Matthew", "Patton", "Rich", "Rob", "Ryan", "Scott", "Shelby", "Sterling", "Tyler", "Victor", "Zack", "Friedrich", "Herman", "Isaac", "Leo", "Maynard", "Mitchell", "Morgann", "Nathan", "Niel", "Pasqual", "Paul", "Tavarius", "Tibor", "Dimitri", "Narek", "Yusif", "Frank", "Jeff", "Vaclav", "Ovid", "Francis", "Keith", "Russel", "Sangon", "Toway", "Bomber", "Chean", "Demit", "Hubor", "Kebile", "Laber", "Ordo", "Retay", "Ronix", "Wagel", "Dobit", "Kaster", "Lobel", "Releo", "Saken", "Rustix"], ["Georgia", "Sandra", "Yvonne"]], - [TrainerType.STRIKER]: ["Marco", "Roberto", "Tony"], - [TrainerType.SCHOOL_KID]: [["Alan", "Billy", "Chad", "Danny", "Dudley", "Jack", "Joe", "Johnny", "Kipp", "Nate", "Ricky", "Tommy", "Jerry", "Paul", "Ted", "Chance", "Esteban", "Forrest", "Harrison", "Connor", "Sherman", "Torin", "Travis", "Al", "Carter", "Edgar", "Jem", "Sammy", "Shane", "Shayne", "Alvin", "Keston", "Neil", "Seymour", "William", "Carson", "Clark", "Nolan"], ["Georgia", "Karen", "Meiko", "Christine", "Mackenzie", "Tiera", "Ann", "Gina", "Lydia", "Marsha", "Millie", "Sally", "Serena", "Silvia", "Alberta", "Cassie", "Mara", "Rita", "Georgie", "Meena", "Nitzel"]], - [TrainerType.SWIMMER]: [["Berke", "Cameron", "Charlie", "George", "Harold", "Jerome", "Kirk", "Mathew", "Parker", "Randall", "Seth", "Simon", "Tucker", "Austin", "Barry", "Chad", "Cody", "Darrin", "David", "Dean", "Douglas", "Franklin", "Gilbert", "Herman", "Jack", "Luis", "Matthew", "Reed", "Richard", "Rodney", "Roland", "Spencer", "Stan", "Tony", "Clarence", "Declan", "Dominik", "Harrison", "Kevin", "Leonardo", "Nolen", "Pete", "Santiago", "Axle", "Braden", "Finn", "Garrett", "Mymo", "Reece", "Samir", "Toby", "Adrian", "Colton", "Dillon", "Erik", "Evan", "Francisco", "Glenn", "Kurt", "Oscar", "Ricardo", "Sam", "Sheltin", "Troy", "Vincent", "Wade", "Wesley", "Duane", "Elmo", "Esteban", "Frankie", "Ronald", "Tyson", "Bart", "Matt", "Tim", "Wright", "Jeffery", "Kyle", "Alessandro", "Estaban", "Kieran", "Ramses", "Casey", "Dakota", "Jared", "Kalani", "Keoni", "Lawrence", "Logan", "Robert", "Roddy", "Yasu", "Derek", "Jacob", "Bruce", "Clayton"], ["Briana", "Dawn", "Denise", "Diana", "Elaine", "Kara", "Kaylee", "Lori", "Nicole", "Nikki", "Paula", "Susie", "Wendy", "Alice", "Beth", "Beverly", "Brenda", "Dana", "Debra", "Grace", "Jenny", "Katie", "Laurel", "Linda", "Missy", "Sharon", "Tanya", "Tara", "Tisha", "Carlee", "Imani", "Isabelle", "Kyla", "Sienna", "Abigail", "Amara", "Anya", "Connie", "Maria", "Melissa", "Nora", "Shirley", "Shania", "Tiffany", "Aubree", "Cassandra", "Claire", "Crystal", "Erica", "Gabrielle", "Haley", "Jessica", "Joanna", "Lydia", "Mallory", "Mary", "Miranda", "Paige", "Sophia", "Vanessa", "Chelan", "Debbie", "Joy", "Kendra", "Leona", "Mina", "Caroline", "Joyce", "Larissa", "Rebecca", "Tyra", "Dara", "Desiree", "Kaoru", "Ruth", "Coral", "Genevieve", "Isla", "Marissa", "Romy", "Sheryl", "Alexandria", "Alicia", "Chelsea", "Jade", "Kelsie", "Laura", "Portia", "Shelby", "Sara", "Tiare", "Kyra", "Natasha", "Layla", "Scarlett", "Cora"]], - [TrainerType.TWINS]: ["Amy & May", "Jo & Zoe", "Meg & Peg", "Ann & Anne", "Lea & Pia", "Amy & Liv", "Gina & Mia", "Miu & Yuki", "Tori & Tia", "Eli & Anne", "Jen & Kira", "Joy & Meg", "Kiri & Jan", "Miu & Mia", "Emma & Lil", "Liv & Liz", "Teri & Tia", "Amy & Mimi", "Clea & Gil", "Day & Dani", "Kay & Tia", "Tori & Til", "Saya & Aya", "Emy & Lin", "Kumi & Amy", "Mayo & May", "Ally & Amy", "Lia & Lily", "Rae & Ula", "Sola & Ana", "Tara & Val", "Faith & Joy", "Nana & Nina"], - [TrainerType.VETERAN]: [["Armando", "Brenden", "Brian", "Clayton", "Edgar", "Emanuel", "Grant", "Harlan", "Terrell", "Arlen", "Chester", "Hugo", "Martell", "Ray", "Shaun", "Abraham", "Carter", "Claude", "Jerry", "Lucius", "Murphy", "Rayne", "Ron", "Sinan", "Sterling", "Vincent", "Zach", "Gerard", "Gilles", "Louis", "Timeo", "Akira", "Don", "Eric", "Harry", "Leon", "Roger", "Angus", "Aristo", "Brone", "Johnny"], ["Julia", "Karla", "Kim", "Sayuri", "Tiffany", "Cathy", "Cecile", "Chloris", "Denae", "Gina", "Maya", "Oriana", "Portia", "Rhona", "Rosaline", "Catrina", "Inga", "Trisha", "Heather", "Lynn", "Sheri", "Alonsa", "Ella", "Leticia", "Kiara"]], - [TrainerType.WAITER]: [["Bert", "Clint", "Maxwell", "Lou"], ["Kati", "Aurora", "Bonita", "Flo", "Tia", "Jan", "Olwen", "Paget", "Paula", "Talia"]], - [TrainerType.WORKER]: [["Braden", "Brendon", "Colin", "Conrad", "Dillan", "Gary", "Gerardo", "Holden", "Jackson", "Mason", "Quentin", "Willy", "Noel", "Arnold", "Brady", "Brand", "Cairn", "Cliff", "Don", "Eddie", "Felix", "Filipe", "Glenn", "Gus", "Heath", "Matthew", "Patton", "Rich", "Rob", "Ryan", "Scott", "Shelby", "Sterling", "Tyler", "Victor", "Zack", "Friedrich", "Herman", "Isaac", "Leo", "Maynard", "Mitchell", "Morgann", "Nathan", "Niel", "Pasqual", "Paul", "Tavarius", "Tibor", "Dimitri", "Narek", "Yusif", "Frank", "Jeff", "Vaclav", "Ovid", "Francis", "Keith", "Russel", "Sangon", "Toway", "Bomber", "Chean", "Demit", "Hubor", "Kebile", "Laber", "Ordo", "Retay", "Ronix", "Wagel", "Dobit", "Kaster", "Lobel", "Releo", "Saken", "Rustix"], ["Georgia", "Sandra", "Yvonne"]], - [TrainerType.YOUNGSTER]: [["Albert", "Gordon", "Ian", "Jason", "Jimmy", "Mikey", "Owen", "Samuel", "Warren", "Allen", "Ben", "Billy", "Calvin", "Dillion", "Eddie", "Joey", "Josh", "Neal", "Timmy", "Tommy", "Breyden", "Deandre", "Demetrius", "Dillon", "Jaylen", "Johnson", "Shigenobu", "Chad", "Cole", "Cordell", "Dan", "Dave", "Destin", "Nash", "Tyler", "Yasu", "Austin", "Dallas", "Darius", "Donny", "Jonathon", "Logan", "Michael", "Oliver", "Sebastian", "Tristan", "Wayne", "Norman", "Roland", "Regis", "Abe", "Astor", "Keita", "Kenneth", "Kevin", "Kyle", "Lester", "Masao", "Nicholas", "Parker", "Wes", "Zachary", "Cody", "Henley", "Jaye", "Karl", "Kenny", "Masahiro", "Pedro", "Petey", "Sinclair", "Terrell", "Waylon", "Aidan", "Anthony", "David", "Jacob", "Jayden", "Cutler", "Ham", "Caleb", "Kai", "Honus", "Kenway", "Bret", "Chris", "Cid", "Dennis", "Easton", "Ken", "Robby", "Ronny", "Shawn", "Benjamin", "Jake", "Travis", "Adan", "Aday", "Beltran", "Elian", "Hernan", "Julen", "Luka", "Roi", "Bernie", "Dustin", "Jonathan", "Wyatt"], ["Alice", "Bridget", "Carrie", "Connie", "Dana", "Ellen", "Krise", "Laura", "Linda", "Michelle", "Shannon", "Andrea", "Crissy", "Janice", "Robin", "Sally", "Tiana", "Haley", "Ali", "Ann", "Dalia", "Dawn", "Iris", "Joana", "Julia", "Kay", "Lisa", "Megan", "Mikaela", "Miriam", "Paige", "Reli", "Blythe", "Briana", "Caroline", "Cassidy", "Kaitlin", "Madeline", "Molly", "Natalie", "Samantha", "Sarah", "Cathy", "Dye", "Eri", "Eva", "Fey", "Kara", "Lurleen", "Maki", "Mali", "Maya", "Miki", "Sibyl", "Daya", "Diana", "Flo", "Helia", "Henrietta", "Isabel", "Mai", "Persephone", "Serena", "Anna", "Charlotte", "Elin", "Elsa", "Lise", "Sara", "Suzette", "Audrey", "Emmy", "Isabella", "Madison", "Rika", "Rylee", "Salla", "Ellie", "Alexandra", "Amy", "Lass", "Brittany", "Chel", "Cindy", "Dianne", "Emily", "Emma", "Evelyn", "Hana", "Harleen", "Hazel", "Jocelyn", "Katrina", "Kimberly", "Lina", "Marge", "Mila", "Mizuki", "Rena", "Sal", "Satoko", "Summer", "Tomoe", "Vicky", "Yue", "Yumi", "Lauren", "Rei", "Riley", "Lois", "Nancy", "Tammy", "Terry"]], - [TrainerType.HEX_MANIAC]: ["Kindra", "Patricia", "Tammy", "Tasha", "Valerie", "Alaina", "Kathleen", "Leah", "Makie", "Sylvia", "Anina", "Arachna", "Carrie", "Desdemona", "Josette", "Luna", "Melanie", "Osanna", "Raziah"], + [TrainerType.ACE_TRAINER]: [[ "Aaron", "Allen", "Blake", "Brian", "Gaven", "Jake", "Kevin", "Mike", "Nick", "Paul", "Ryan", "Sean", "Darin", "Albert", "Berke", "Clyde", "Edgar", "George", "Leroy", "Owen", "Parker", "Randall", "Ruben", "Samuel", "Vincent", "Warren", "Wilton", "Zane", "Alfred", "Braxton", "Felix", "Gerald", "Jonathan", "Leonel", "Marcel", "Mitchell", "Quincy", "Roderick", "Colby", "Rolando", "Yuji", "Abel", "Anton", "Arthur", "Cesar", "Dalton", "Dennis", "Ernest", "Garrett", "Graham", "Henry", "Isaiah", "Jonah", "Jose", "Keenan", "Micah", "Omar", "Quinn", "Rodolfo", "Saul", "Sergio", "Skylar", "Stefan", "Zachery", "Alton", "Arabella", "Bonita", "Cal", "Cody", "French", "Kobe", "Paulo", "Shaye", "Austin", "Beckett", "Charlie", "Corky", "David", "Dwayne", "Elmer", "Jesse", "Jared", "Johan", "Jordan", "Kipp", "Lou", "Terry", "Tom", "Webster", "Billy", "Doyle", "Enzio", "Geoff", "Grant", "Kelsey", "Miguel", "Pierce", "Ray", "Santino", "Shel", "Adelbert", "Bence", "Emil", "Evan", "Mathis", "Maxim", "Neil", "Rico", "Robbie", "Theo", "Viktor", "Benedict", "Cornelius", "Hisato", "Leopold", "Neville", "Vito", "Chase", "Cole", "Hiroshi", "Jackson", "Jim", "Kekoa", "Makana", "Yuki", "Elwood", "Seth", "Alvin", "Arjun", "Arnold", "Cameron", "Carl", "Carlton", "Christopher", "Dave", "Dax", "Dominic", "Edmund", "Finn", "Fred", "Garret", "Grayson", "Jace", "Jaxson", "Jay", "Jirard", "Johnson", "Kayden", "Kite", "Louis", "Mac", "Marty", "Percy", "Raymond", "Ronnie", "Satch", "Tim", "Zach", "Conner", "Vince", "Bedro", "Boda", "Botan", "Daras", "Dury", "Herton", "Rewn", "Stum", "Tock", "Trilo", "Berki", "Cruik", "Dazon", "Desid", "Dillot", "Farfin", "Forgon", "Hebel", "Morfon", "Moril", "Shadd", "Vanhub", "Bardo", "Carben", "Degin", "Gorps", "Klept", "Lask", "Malex", "Mopar", "Niled", "Noxon", "Teslor", "Tetil" ], [ "Beth", "Carol", "Cybil", "Emma", "Fran", "Gwen", "Irene", "Jenn", "Joyce", "Kate", "Kelly", "Lois", "Lola", "Megan", "Quinn", "Reena", "Cara", "Alexa", "Brooke", "Caroline", "Elaine", "Hope", "Jennifer", "Jody", "Julie", "Lori", "Mary", "Michelle", "Shannon", "Wendy", "Alexia", "Alicia", "Athena", "Carolina", "Cristin", "Darcy", "Dianne", "Halle", "Jazmyn", "Katelynn", "Keira", "Marley", "Allyson", "Kathleen", "Naomi", "Alyssa", "Ariana", "Brandi", "Breanna", "Brenda", "Brenna", "Catherine", "Clarice", "Dana", "Deanna", "Destiny", "Jamie", "Jasmin", "Kassandra", "Laura", "Maria", "Mariah", "Maya", "Meagan", "Mikayla", "Monique", "Natasha", "Olivia", "Sandra", "Savannah", "Sydney", "Moira", "Piper", "Salma", "Allison", "Beverly", "Cathy", "Cheyenne", "Clara", "Dara", "Eileen", "Glinda", "Junko", "Lena", "Lucille", "Mariana", "Olwen", "Shanta", "Stella", "Angi", "Belle", "Chandra", "Cora", "Eve", "Jacqueline", "Jeanne", "Juliet", "Kathrine", "Layla", "Lucca", "Melina", "Miki", "Nina", "Sable", "Shelly", "Summer", "Trish", "Vicki", "Alanza", "Cordelia", "Hilde", "Imelda", "Michele", "Mireille", "Claudia", "Constance", "Harriet", "Honor", "Melba", "Portia", "Alexis", "Angela", "Karla", "Lindsey", "Tori", "Sheri", "Jada", "Kailee", "Amanda", "Annie", "Kindra", "Kyla", "Sofia", "Yvette", "Becky", "Flora", "Gloria", "Buna", "Ferda", "Lehan", "Liqui", "Lomen", "Neira", "Atilo", "Detta", "Gilly", "Gosney", "Levens", "Moden", "Rask", "Rateis", "Rosno", "Tynan", "Veron", "Zoel", "Cida", "Dibsin", "Dodin", "Ebson", "Equin", "Flostin", "Gabsen", "Halsion", "Hileon", "Quelor", "Rapeel", "Roze", "Tensin" ]], + [TrainerType.ARTIST]: [[ "Ismael", "William", "Horton", "Pierre", "Zach", "Gough", "Salvador", "Vincent", "Duncan" ], [ "Georgia" ]], + [TrainerType.BACKERS]: [[ "Alf & Fred", "Hawk & Dar", "Joe & Ross", "Les & Web", "Masa & Yas", "Stu & Art" ], [ "Ai & Ciel", "Ami & Eira", "Cam & Abby", "Fey & Sue", "Kat & Phae", "Kay & Ali", "Ava & Aya", "Cleo & Rio", "May & Mal" ]], + [TrainerType.BACKPACKER]: [[ "Alexander", "Carlos", "Herman", "Jerome", "Keane", "Kelsey", "Kiyo", "Michael", "Nate", "Peter", "Sam", "Stephen", "Talon", "Terrance", "Toru", "Waylon", "Boone", "Clifford", "Ivan", "Kendall", "Lowell", "Randall", "Reece", "Roland", "Shane", "Walt", "Farid", "Heike", "Joren", "Lane", "Roderick", "Darnell", "Deon", "Emory", "Graeme", "Grayson", "Aitor", "Alex", "Arturo", "Asier", "Jaime", "Jonathan", "Julio", "Kevin", "Kosuke", "Lander", "Markel", "Mateo", "Nil", "Pau", "Samuel" ], [ "Anna", "Corin", "Elaine", "Emi", "Jill", "Kumiko", "Liz", "Lois", "Lora", "Molly", "Patty", "Ruth", "Vicki", "Annie", "Blossom", "Clara", "Eileen", "Mae", "Myra", "Rachel", "Tami", "Ashley", "Mikiko", "Kiana", "Perdy", "Maria", "Yuho", "Peren", "Barbara", "Diane" ]], + [TrainerType.BAKER]: [ "Chris", "Jenn", "Lilly" ], + [TrainerType.BEAUTY]: [ "Cassie", "Julia", "Olivia", "Samantha", "Valerie", "Victoria", "Bridget", "Connie", "Jessica", "Johanna", "Melissa", "Sheila", "Shirley", "Tiffany", "Namiko", "Thalia", "Grace", "Lola", "Lori", "Maura", "Tamia", "Cyndy", "Devon", "Gabriella", "Harley", "Lindsay", "Nicola", "Callie", "Charlotte", "Kassandra", "December", "Fleming", "Nikola", "Aimee", "Anais", "Brigitte", "Cassandra", "Andrea", "Brittney", "Carolyn", "Krystal", "Alexis", "Alice", "Aina", "Anya", "Arianna", "Aubrey", "Beverly", "Camille", "Beauty", "Evette", "Hansol", "Haruka", "Jill", "Jo", "Lana", "Lois", "Lucy", "Mai", "Nickie", "Nicole", "Prita", "Rose", "Shelly", "Suzy", "Tessa", "Anita", "Alissa", "Rita", "Cudsy", "Eloff", "Miru", "Minot", "Nevah", "Niven", "Ogoin" ], + [TrainerType.BIKER]: [ "Charles", "Dwayne", "Glenn", "Harris", "Joel", "Riley", "Zeke", "Alex", "Billy", "Ernest", "Gerald", "Hideo", "Isaac", "Jared", "Jaren", "Jaxon", "Jordy", "Lao", "Lukas", "Malik", "Nikolas", "Ricardo", "Ruben", "Virgil", "William", "Aiden", "Dale", "Dan", "Jacob", "Markey", "Reese", "Teddy", "Theron", "Jeremy", "Morgann", "Phillip", "Philip", "Stanley", "Dillon" ], + [TrainerType.BLACK_BELT]: [[ "Kenji", "Lao", "Lung", "Nob", "Wai", "Yoshi", "Atsushi", "Daisuke", "Hideki", "Hitoshi", "Kiyo", "Koichi", "Koji", "Yuji", "Cristian", "Rhett", "Takao", "Theodore", "Zander", "Aaron", "Hugh", "Mike", "Nicolas", "Shea", "Takashi", "Adam", "Carl", "Colby", "Darren", "David", "Davon", "Derek", "Eddie", "Gregory", "Griffin", "Jarrett", "Jeffery", "Kendal", "Kyle", "Luke", "Miles", "Nathaniel", "Philip", "Rafael", "Ray", "Ricky", "Sean", "Willie", "Ander", "Manford", "Benjamin", "Corey", "Edward", "Grant", "Jay", "Kendrew", "Kentaro", "Ryder", "Teppei", "Thomas", "Tyrone", "Andrey", "Donny", "Drago", "Gordon", "Grigor", "Jeriel", "Kenneth", "Martell", "Mathis", "Rich", "Rocky", "Rodrigo", "Wesley", "Zachery", "Alonzo", "Cadoc", "Gunnar", "Igor", "Killian", "Markus", "Ricardo", "Yanis", "Banting", "Clayton", "Duane", "Earl", "Greg", "Roy", "Terry", "Tracy", "Walter", "Alvaro", "Curtis", "Francis", "Ross", "Brice", "Cheng", "Dudley", "Eric", "Kano", "Masahiro", "Randy", "Ryuji", "Steve", "Tadashi", "Wong", "Yuen", "Brian", "Carter", "Reece", "Nick", "Yang" ], [ "Cora", "Cyndy", "Jill", "Laura", "Sadie", "Tessa", "Vivian", "Aisha", "Callie", "Danielle", "Helene", "Jocelyn", "Lilith", "Paula", "Reyna", "Helen", "Kelsey", "Tyler", "Amy", "Chandra", "Hillary", "Janie", "Lee", "Maggie", "Mikiko", "Miriam", "Sharon", "Susie", "Xiao", "Alize", "Azra", "Brenda", "Chalina", "Chan", "Glinda", "Maki", "Tia", "Tiffany", "Wendy", "Andrea", "Gabrielle", "Gerardine", "Hailey", "Hedvig", "Justine", "Kinsey", "Sigrid", "Veronique", "Tess" ]], + [TrainerType.BREEDER]: [[ "Isaac", "Myles", "Salvadore", "Albert", "Kahlil", "Eustace", "Galen", "Owen", "Addison", "Marcus", "Foster", "Cory", "Glenn", "Jay", "Wesley", "William", "Adrian", "Bradley", "Jaime" ], [ "Allison", "Alize", "Bethany", "Lily", "Lydia", "Gabrielle", "Jayden", "Pat", "Veronica", "Amber", "Jennifer", "Kaylee", "Adelaide", "Brooke", "Ethel", "April", "Irene", "Magnolia", "Amala", "Mercy", "Amanda", "Ikue", "Savannah", "Yuka", "Chloe", "Debra", "Denise", "Elena" ]], + [TrainerType.CLERK]: [[ "Chaz", "Clemens", "Doug", "Fredric", "Ivan", "Isaac", "Nelson", "Wade", "Warren", "Augustin", "Gilligan", "Cody", "Jeremy", "Shane", "Dugal", "Royce", "Ronald" ], [ "Alberta", "Ingrid", "Katie", "Piper", "Trisha", "Wren", "Britney", "Lana", "Jessica", "Kristen", "Michelle", "Gabrielle" ]], + [TrainerType.CYCLIST]: [[ "Axel", "James", "John", "Ryan", "Hector", "Jeremiah" ], [ "Kayla", "Megan", "Nicole", "Rachel", "Krissa", "Adelaide" ]], + [TrainerType.DANCER]: [ "Brian", "Davey", "Dirk", "Edmond", "Mickey", "Raymond", "Cara", "Julia", "Maika", "Mireille", "Ronda", "Zoe" ], + [TrainerType.DEPOT_AGENT]: [ "Josh", "Hank", "Vincent" ], + [TrainerType.DOCTOR]: [[ "Hank", "Jerry", "Jules", "Logan", "Wayne", "Braid", "Derek", "Heath", "Julius", "Kit", "Graham" ], [ "Kirsten", "Sachiko", "Shery", "Carol", "Dixie", "Mariah" ]], + [TrainerType.FIREBREATHER]: [ "Bill", "Burt", "Cliff", "Dick", "Lyle", "Ned", "Otis", "Ray", "Richard", "Walt" ], + [TrainerType.FISHERMAN]: [ "Andre", "Arnold", "Barney", "Chris", "Edgar", "Henry", "Jonah", "Justin", "Kyle", "Martin", "Marvin", "Ralph", "Raymond", "Scott", "Stephen", "Wilton", "Tully", "Andrew", "Barny", "Carter", "Claude", "Dale", "Elliot", "Eugene", "Ivan", "Ned", "Nolan", "Roger", "Ronald", "Wade", "Wayne", "Darian", "Kai", "Chip", "Hank", "Kaden", "Tommy", "Tylor", "Alec", "Brett", "Cameron", "Cody", "Cole", "Cory", "Erick", "George", "Joseph", "Juan", "Kenneth", "Luc", "Miguel", "Travis", "Walter", "Zachary", "Josh", "Gideon", "Kyler", "Liam", "Murphy", "Bruce", "Damon", "Devon", "Hubert", "Jones", "Lydon", "Mick", "Pete", "Sean", "Sid", "Vince", "Bucky", "Dean", "Eustace", "Kenzo", "Leroy", "Mack", "Ryder", "Ewan", "Finn", "Murray", "Seward", "Shad", "Wharton", "Finley", "Fisher", "Fisk", "River", "Sheaffer", "Timin", "Carl", "Ernest", "Hal", "Herbert", "Hisato", "Mike", "Vernon", "Harriet", "Marina", "Chase" ], + [TrainerType.GUITARIST]: [ "Anna", "Beverly", "January", "Tina", "Alicia", "Claudia", "Julia", "Lidia", "Mireia", "Noelia", "Sara", "Sheila", "Tatiana" ], + [TrainerType.HARLEQUIN]: [ "Charley", "Ian", "Jack", "Kerry", "Louis", "Pat", "Paul", "Rick", "Anders", "Clarence", "Gary" ], + [TrainerType.HIKER]: [ "Anthony", "Bailey", "Benjamin", "Daniel", "Erik", "Jim", "Kenny", "Leonard", "Michael", "Parry", "Phillip", "Russell", "Sidney", "Tim", "Timothy", "Alan", "Brice", "Clark", "Eric", "Lenny", "Lucas", "Mike", "Trent", "Devan", "Eli", "Marc", "Sawyer", "Allen", "Daryl", "Dudley", "Earl", "Franklin", "Jeremy", "Marcos", "Nob", "Oliver", "Wayne", "Alexander", "Damon", "Jonathan", "Justin", "Kevin", "Lorenzo", "Louis", "Maurice", "Nicholas", "Reginald", "Robert", "Theodore", "Bruce", "Clarke", "Devin", "Dwight", "Edwin", "Eoin", "Noland", "Russel", "Andy", "Bret", "Darrell", "Gene", "Hardy", "Hugh", "Jebediah", "Jeremiah", "Kit", "Neil", "Terrell", "Don", "Doug", "Hunter", "Jared", "Jerome", "Keith", "Manuel", "Markus", "Otto", "Shelby", "Stephen", "Teppei", "Tobias", "Wade", "Zaiem", "Aaron", "Alain", "Bergin", "Bernard", "Brent", "Corwin", "Craig", "Delmon", "Dunstan", "Orestes", "Ross", "Davian", "Calhoun", "David", "Gabriel", "Ryan", "Thomas", "Travis", "Zachary", "Anuhea", "Barnaby", "Claus", "Collin", "Colson", "Dexter", "Dillan", "Eugine", "Farkas", "Hisato", "Julius", "Kenji", "Irwin", "Lionel", "Paul", "Richter", "Valentino", "Donald", "Douglas", "Kevyn", "Chester" ], //["Angela","Carla","Celia","Daniela","Estela","Fatima","Helena","Leire","Lucia","Luna","Manuela","Mar","Marina","Miyu","Nancy","Nerea","Paula","Rocio","Yanira"] + [TrainerType.HOOLIGANS]: [ "Jim & Cas", "Rob & Sal" ], + [TrainerType.HOOPSTER]: [ "Bobby", "John", "Lamarcus", "Derrick", "Nicolas" ], + [TrainerType.INFIELDER]: [ "Alex", "Connor", "Todd" ], + [TrainerType.JANITOR]: [ "Caleb", "Geoff", "Brady", "Felix", "Orville", "Melvin", "Shawn" ], + [TrainerType.LINEBACKER]: [ "Bob", "Dan", "Jonah" ], + [TrainerType.MAID]: [ "Belinda", "Sophie", "Emily", "Elena", "Clare", "Alica", "Tanya", "Tammy" ], + [TrainerType.MUSICIAN]: [ "Boris", "Preston", "Charles", "Clyde", "Vincent", "Dalton", "Kirk", "Shawn", "Fabian", "Fernando", "Joseph", "Marcos", "Arturo", "Jerry", "Lonnie", "Tony" ], + [TrainerType.NURSERY_AIDE]: [ "Autumn", "Briana", "Leah", "Miho", "Ethel", "Hollie", "Ilse", "June", "Kimya", "Rosalyn" ], + [TrainerType.OFFICER]: [ "Dirk", "Keith", "Alex", "Bobby", "Caleb", "Danny", "Dylan", "Thomas", "Daniel", "Jeff", "Braven", "Dell", "Neagle", "Haruki", "Mitchell", "Raymond" ], + [TrainerType.PARASOL_LADY]: [ "Angelica", "Clarissa", "Madeline", "Akari", "Annabell", "Kayley", "Rachel", "Alexa", "Sabrina", "April", "Gwyneth", "Laura", "Lumi", "Mariah", "Melita", "Nicole", "Tihana", "Ingrid", "Tyra" ], + [TrainerType.PILOT]: [ "Chase", "Leonard", "Ted", "Elron", "Ewing", "Flynn", "Winslow" ], + [TrainerType.POKEFAN]: [[ "Alex", "Allan", "Brandon", "Carter", "Colin", "Derek", "Jeremy", "Joshua", "Rex", "Robert", "Trevor", "William", "Colton", "Miguel", "Francisco", "Kaleb", "Leonard", "Boone", "Elliot", "Jude", "Norbert", "Corey", "Gabe", "Baxter" ], [ "Beverly", "Georgia", "Jaime", "Ruth", "Isabel", "Marissa", "Vanessa", "Annika", "Bethany", "Kimberly", "Meredith", "Rebekah", "Eleanor", "Darcy", "Lydia", "Sachiko", "Abigail", "Agnes", "Lydie", "Roisin", "Tara", "Carmen", "Janet" ]], + [TrainerType.PRESCHOOLER]: [[ "Billy", "Doyle", "Evan", "Homer", "Tully", "Albert", "Buster", "Greg", "Ike", "Jojo", "Tyrone", "Adrian", "Oliver", "Hayden", "Hunter", "Kaleb", "Liam", "Dylan" ], [ "Juliet", "Mia", "Sarah", "Wendy", "Winter", "Chrissy", "Eva", "Lin", "Samantha", "Ella", "Lily", "Natalie", "Ailey", "Hannah", "Malia", "Kindra", "Nancy" ]], + [TrainerType.PSYCHIC]: [[ "Fidel", "Franklin", "Gilbert", "Greg", "Herman", "Jared", "Mark", "Nathan", "Norman", "Phil", "Richard", "Rodney", "Cameron", "Edward", "Fritz", "Joshua", "Preston", "Virgil", "William", "Alvaro", "Blake", "Cedric", "Keenan", "Nicholas", "Dario", "Johan", "Lorenzo", "Tyron", "Bryce", "Corbin", "Deandre", "Elijah", "Kody", "Landon", "Maxwell", "Mitchell", "Sterling", "Eli", "Nelson", "Vernon", "Gaven", "Gerard", "Low", "Micki", "Perry", "Rudolf", "Tommy", "Al", "Nandor", "Tully", "Arthur", "Emanuel", "Franz", "Harry", "Paschal", "Robert", "Sayid", "Angelo", "Anton", "Arin", "Avery", "Danny", "Frasier", "Harrison", "Jaime", "Ross", "Rui", "Vlad", "Mason" ], [ "Alexis", "Hannah", "Jacki", "Jaclyn", "Kayla", "Maura", "Samantha", "Alix", "Brandi", "Edie", "Macey", "Mariella", "Marlene", "Laura", "Rodette", "Abigail", "Brittney", "Chelsey", "Daisy", "Desiree", "Kendra", "Lindsey", "Rachael", "Valencia", "Belle", "Cybil", "Doreen", "Dua", "Future", "Lin", "Madhu", "Alia", "Ena", "Joyce", "Lynette", "Olesia", "Sarah" ]], + [TrainerType.RANGER]: [[ "Carlos", "Jackson", "Sebastian", "Gav", "Lorenzo", "Logan", "Nicolas", "Trenton", "Deshawn", "Dwayne", "Jeffery", "Kyler", "Taylor", "Alain", "Claude", "Crofton", "Forrest", "Harry", "Jaden", "Keith", "Lewis", "Miguel", "Pedro", "Ralph", "Richard", "Bret", "Daryl", "Eddie", "Johan", "Leaf", "Louis", "Maxwell", "Parker", "Rick", "Steve", "Bjorn", "Chaise", "Dean", "Lee", "Maurice", "Nash", "Ralf", "Reed", "Shinobu", "Silas" ], [ "Catherine", "Jenna", "Sophia", "Merdith", "Nora", "Beth", "Chelsea", "Katelyn", "Madeline", "Allison", "Ashlee", "Felicia", "Krista", "Annie", "Audra", "Brenda", "Chloris", "Eliza", "Heidi", "Irene", "Mary", "Mylene", "Shanti", "Shelly", "Thalia", "Anja", "Briana", "Dianna", "Elaine", "Elle", "Hillary", "Katie", "Lena", "Lois", "Malory", "Melita", "Mikiko", "Naoko", "Serenity", "Ambre", "Brooke", "Clementine", "Melina", "Petra", "Twiggy" ]], + [TrainerType.RICH]: [[ "Alfred", "Edward", "Gregory", "Preston", "Thomas", "Tucker", "Walter", "Clifford", "Everett", "Micah", "Nate", "Pierre", "Terrance", "Arthur", "Brooks", "Emanuel", "Lamar", "Jeremy", "Leonardo", "Milton", "Frederic", "Renaud", "Robert", "Yan", "Daniel", "Sheldon", "Stonewall", "Gerald", "Ronald", "Smith", "Stanley", "Reginald", "Orson", "Wilco", "Caden", "Glenn" ], [ "Rebecca", "Reina", "Cassandra", "Emilia", "Grace", "Marian", "Elizabeth", "Kathleen", "Sayuri", "Caroline", "Judy" ]], + [TrainerType.RICH_KID]: [[ "Garret", "Winston", "Dawson", "Enrique", "Jason", "Roman", "Trey", "Liam", "Anthony", "Brad", "Cody", "Manuel", "Martin", "Pierce", "Rolan", "Keenan", "Filbert", "Antoin", "Cyus", "Diek", "Dugo", "Flitz", "Jurek", "Lond", "Perd", "Quint", "Basto", "Benit", "Brot", "Denc", "Guyit", "Marcon", "Perc", "Puros", "Roex", "Sainz", "Symin", "Tark", "Venak" ], [ "Anette", "Brianna", "Cindy", "Colleen", "Daphne", "Elizabeth", "Naomi", "Sarah", "Charlotte", "Gillian", "Jacki", "Lady", "Melissa", "Celeste", "Colette", "Elizandra", "Isabel", "Lynette", "Magnolia", "Sophie", "Lina", "Dulcie", "Auro", "Brin", "Caril", "Eloos", "Gwin", "Illa", "Kowly", "Rima", "Ristin", "Vesey", "Brena", "Deasy", "Denslon", "Kylet", "Nemi", "Rene", "Sanol", "Stouner", "Sturk", "Talmen", "Zoila" ]], + [TrainerType.ROUGHNECK]: [ "Camron", "Corey", "Gabriel", "Isaiah", "Jamal", "Koji", "Luke", "Paxton", "Raul", "Zeek", "Kirby", "Chance", "Dave", "Fletcher", "Johnny", "Reese", "Joey", "Ricky", "Silvester", "Martin" ], + [TrainerType.SAILOR]: [ "Alberto", "Bost", "Brennan", "Brenden", "Claude", "Cory", "Damian", "Dirk", "Duncan", "Dwayne", "Dylan", "Eddie", "Edmond", "Elijah", "Ernest", "Eugene", "Garrett", "Golos", "Gratin", "Grestly", "Harry", "Hols", "Hudson", "Huey", "Jebol", "Jeff", "Leonald", "Luther", "Kelvin", "Kenneth", "Kent", "Knook", "Marc", "Mifis", "Monar", "Morkor", "Ordes", "Oxlin", "Parker", "Paul", "Philip", "Roberto", "Samson", "Skyler", "Stanly", "Tebu", "Terrell", "Trevor", "Yasu", "Zachariah" ], + [TrainerType.SCIENTIST]: [[ "Jed", "Marc", "Mitch", "Rich", "Ross", "Beau", "Braydon", "Connor", "Ed", "Ivan", "Jerry", "Jose", "Joshua", "Parker", "Rodney", "Taylor", "Ted", "Travis", "Zackery", "Darrius", "Emilio", "Fredrick", "Shaun", "Stefano", "Travon", "Daniel", "Garett", "Gregg", "Linden", "Lowell", "Trenton", "Dudley", "Luke", "Markus", "Nathan", "Orville", "Randall", "Ron", "Ronald", "Simon", "Steve", "William", "Franklin", "Clarke", "Jacques", "Terrance", "Ernst", "Justus", "Ikaika", "Jayson", "Kyle", "Reid", "Tyrone", "Adam", "Albert", "Alphonse", "Cory", "Donnie", "Elton", "Francis", "Gordon", "Herbert", "Humphrey", "Jordan", "Julian", "Keaton", "Levi", "Melvin", "Murray", "West", "Craig", "Coren", "Dubik", "Kotan", "Lethco", "Mante", "Mort", "Myron", "Odlow", "Ribek", "Roeck", "Vogi", "Vonder", "Zogo", "Doimo", "Doton", "Durel", "Hildon", "Kukla", "Messa", "Nanot", "Platen", "Raburn", "Reman", "Acrod", "Coffy", "Elrok", "Foss", "Hardig", "Hombol", "Hospel", "Kaller", "Klots", "Krilok", "Limar", "Loket", "Mesak", "Morbit", "Newin", "Orill", "Tabor", "Tekot" ], [ "Blythe", "Chan", "Kathrine", "Marie", "Maria", "Naoko", "Samantha", "Satomi", "Shannon", "Athena", "Caroline", "Lumi", "Lumina", "Marissa", "Sonia" ]], + [TrainerType.SMASHER]: [ "Aspen", "Elena", "Mari", "Amy", "Lizzy" ], + [TrainerType.SNOW_WORKER]: [[ "Braden", "Brendon", "Colin", "Conrad", "Dillan", "Gary", "Gerardo", "Holden", "Jackson", "Mason", "Quentin", "Willy", "Noel", "Arnold", "Brady", "Brand", "Cairn", "Cliff", "Don", "Eddie", "Felix", "Filipe", "Glenn", "Gus", "Heath", "Matthew", "Patton", "Rich", "Rob", "Ryan", "Scott", "Shelby", "Sterling", "Tyler", "Victor", "Zack", "Friedrich", "Herman", "Isaac", "Leo", "Maynard", "Mitchell", "Morgann", "Nathan", "Niel", "Pasqual", "Paul", "Tavarius", "Tibor", "Dimitri", "Narek", "Yusif", "Frank", "Jeff", "Vaclav", "Ovid", "Francis", "Keith", "Russel", "Sangon", "Toway", "Bomber", "Chean", "Demit", "Hubor", "Kebile", "Laber", "Ordo", "Retay", "Ronix", "Wagel", "Dobit", "Kaster", "Lobel", "Releo", "Saken", "Rustix" ], [ "Georgia", "Sandra", "Yvonne" ]], + [TrainerType.STRIKER]: [ "Marco", "Roberto", "Tony" ], + [TrainerType.SCHOOL_KID]: [[ "Alan", "Billy", "Chad", "Danny", "Dudley", "Jack", "Joe", "Johnny", "Kipp", "Nate", "Ricky", "Tommy", "Jerry", "Paul", "Ted", "Chance", "Esteban", "Forrest", "Harrison", "Connor", "Sherman", "Torin", "Travis", "Al", "Carter", "Edgar", "Jem", "Sammy", "Shane", "Shayne", "Alvin", "Keston", "Neil", "Seymour", "William", "Carson", "Clark", "Nolan" ], [ "Georgia", "Karen", "Meiko", "Christine", "Mackenzie", "Tiera", "Ann", "Gina", "Lydia", "Marsha", "Millie", "Sally", "Serena", "Silvia", "Alberta", "Cassie", "Mara", "Rita", "Georgie", "Meena", "Nitzel" ]], + [TrainerType.SWIMMER]: [[ "Berke", "Cameron", "Charlie", "George", "Harold", "Jerome", "Kirk", "Mathew", "Parker", "Randall", "Seth", "Simon", "Tucker", "Austin", "Barry", "Chad", "Cody", "Darrin", "David", "Dean", "Douglas", "Franklin", "Gilbert", "Herman", "Jack", "Luis", "Matthew", "Reed", "Richard", "Rodney", "Roland", "Spencer", "Stan", "Tony", "Clarence", "Declan", "Dominik", "Harrison", "Kevin", "Leonardo", "Nolen", "Pete", "Santiago", "Axle", "Braden", "Finn", "Garrett", "Mymo", "Reece", "Samir", "Toby", "Adrian", "Colton", "Dillon", "Erik", "Evan", "Francisco", "Glenn", "Kurt", "Oscar", "Ricardo", "Sam", "Sheltin", "Troy", "Vincent", "Wade", "Wesley", "Duane", "Elmo", "Esteban", "Frankie", "Ronald", "Tyson", "Bart", "Matt", "Tim", "Wright", "Jeffery", "Kyle", "Alessandro", "Estaban", "Kieran", "Ramses", "Casey", "Dakota", "Jared", "Kalani", "Keoni", "Lawrence", "Logan", "Robert", "Roddy", "Yasu", "Derek", "Jacob", "Bruce", "Clayton" ], [ "Briana", "Dawn", "Denise", "Diana", "Elaine", "Kara", "Kaylee", "Lori", "Nicole", "Nikki", "Paula", "Susie", "Wendy", "Alice", "Beth", "Beverly", "Brenda", "Dana", "Debra", "Grace", "Jenny", "Katie", "Laurel", "Linda", "Missy", "Sharon", "Tanya", "Tara", "Tisha", "Carlee", "Imani", "Isabelle", "Kyla", "Sienna", "Abigail", "Amara", "Anya", "Connie", "Maria", "Melissa", "Nora", "Shirley", "Shania", "Tiffany", "Aubree", "Cassandra", "Claire", "Crystal", "Erica", "Gabrielle", "Haley", "Jessica", "Joanna", "Lydia", "Mallory", "Mary", "Miranda", "Paige", "Sophia", "Vanessa", "Chelan", "Debbie", "Joy", "Kendra", "Leona", "Mina", "Caroline", "Joyce", "Larissa", "Rebecca", "Tyra", "Dara", "Desiree", "Kaoru", "Ruth", "Coral", "Genevieve", "Isla", "Marissa", "Romy", "Sheryl", "Alexandria", "Alicia", "Chelsea", "Jade", "Kelsie", "Laura", "Portia", "Shelby", "Sara", "Tiare", "Kyra", "Natasha", "Layla", "Scarlett", "Cora" ]], + [TrainerType.TWINS]: [ "Amy & May", "Jo & Zoe", "Meg & Peg", "Ann & Anne", "Lea & Pia", "Amy & Liv", "Gina & Mia", "Miu & Yuki", "Tori & Tia", "Eli & Anne", "Jen & Kira", "Joy & Meg", "Kiri & Jan", "Miu & Mia", "Emma & Lil", "Liv & Liz", "Teri & Tia", "Amy & Mimi", "Clea & Gil", "Day & Dani", "Kay & Tia", "Tori & Til", "Saya & Aya", "Emy & Lin", "Kumi & Amy", "Mayo & May", "Ally & Amy", "Lia & Lily", "Rae & Ula", "Sola & Ana", "Tara & Val", "Faith & Joy", "Nana & Nina" ], + [TrainerType.VETERAN]: [[ "Armando", "Brenden", "Brian", "Clayton", "Edgar", "Emanuel", "Grant", "Harlan", "Terrell", "Arlen", "Chester", "Hugo", "Martell", "Ray", "Shaun", "Abraham", "Carter", "Claude", "Jerry", "Lucius", "Murphy", "Rayne", "Ron", "Sinan", "Sterling", "Vincent", "Zach", "Gerard", "Gilles", "Louis", "Timeo", "Akira", "Don", "Eric", "Harry", "Leon", "Roger", "Angus", "Aristo", "Brone", "Johnny" ], [ "Julia", "Karla", "Kim", "Sayuri", "Tiffany", "Cathy", "Cecile", "Chloris", "Denae", "Gina", "Maya", "Oriana", "Portia", "Rhona", "Rosaline", "Catrina", "Inga", "Trisha", "Heather", "Lynn", "Sheri", "Alonsa", "Ella", "Leticia", "Kiara" ]], + [TrainerType.WAITER]: [[ "Bert", "Clint", "Maxwell", "Lou" ], [ "Kati", "Aurora", "Bonita", "Flo", "Tia", "Jan", "Olwen", "Paget", "Paula", "Talia" ]], + [TrainerType.WORKER]: [[ "Braden", "Brendon", "Colin", "Conrad", "Dillan", "Gary", "Gerardo", "Holden", "Jackson", "Mason", "Quentin", "Willy", "Noel", "Arnold", "Brady", "Brand", "Cairn", "Cliff", "Don", "Eddie", "Felix", "Filipe", "Glenn", "Gus", "Heath", "Matthew", "Patton", "Rich", "Rob", "Ryan", "Scott", "Shelby", "Sterling", "Tyler", "Victor", "Zack", "Friedrich", "Herman", "Isaac", "Leo", "Maynard", "Mitchell", "Morgann", "Nathan", "Niel", "Pasqual", "Paul", "Tavarius", "Tibor", "Dimitri", "Narek", "Yusif", "Frank", "Jeff", "Vaclav", "Ovid", "Francis", "Keith", "Russel", "Sangon", "Toway", "Bomber", "Chean", "Demit", "Hubor", "Kebile", "Laber", "Ordo", "Retay", "Ronix", "Wagel", "Dobit", "Kaster", "Lobel", "Releo", "Saken", "Rustix" ], [ "Georgia", "Sandra", "Yvonne" ]], + [TrainerType.YOUNGSTER]: [[ "Albert", "Gordon", "Ian", "Jason", "Jimmy", "Mikey", "Owen", "Samuel", "Warren", "Allen", "Ben", "Billy", "Calvin", "Dillion", "Eddie", "Joey", "Josh", "Neal", "Timmy", "Tommy", "Breyden", "Deandre", "Demetrius", "Dillon", "Jaylen", "Johnson", "Shigenobu", "Chad", "Cole", "Cordell", "Dan", "Dave", "Destin", "Nash", "Tyler", "Yasu", "Austin", "Dallas", "Darius", "Donny", "Jonathon", "Logan", "Michael", "Oliver", "Sebastian", "Tristan", "Wayne", "Norman", "Roland", "Regis", "Abe", "Astor", "Keita", "Kenneth", "Kevin", "Kyle", "Lester", "Masao", "Nicholas", "Parker", "Wes", "Zachary", "Cody", "Henley", "Jaye", "Karl", "Kenny", "Masahiro", "Pedro", "Petey", "Sinclair", "Terrell", "Waylon", "Aidan", "Anthony", "David", "Jacob", "Jayden", "Cutler", "Ham", "Caleb", "Kai", "Honus", "Kenway", "Bret", "Chris", "Cid", "Dennis", "Easton", "Ken", "Robby", "Ronny", "Shawn", "Benjamin", "Jake", "Travis", "Adan", "Aday", "Beltran", "Elian", "Hernan", "Julen", "Luka", "Roi", "Bernie", "Dustin", "Jonathan", "Wyatt" ], [ "Alice", "Bridget", "Carrie", "Connie", "Dana", "Ellen", "Krise", "Laura", "Linda", "Michelle", "Shannon", "Andrea", "Crissy", "Janice", "Robin", "Sally", "Tiana", "Haley", "Ali", "Ann", "Dalia", "Dawn", "Iris", "Joana", "Julia", "Kay", "Lisa", "Megan", "Mikaela", "Miriam", "Paige", "Reli", "Blythe", "Briana", "Caroline", "Cassidy", "Kaitlin", "Madeline", "Molly", "Natalie", "Samantha", "Sarah", "Cathy", "Dye", "Eri", "Eva", "Fey", "Kara", "Lurleen", "Maki", "Mali", "Maya", "Miki", "Sibyl", "Daya", "Diana", "Flo", "Helia", "Henrietta", "Isabel", "Mai", "Persephone", "Serena", "Anna", "Charlotte", "Elin", "Elsa", "Lise", "Sara", "Suzette", "Audrey", "Emmy", "Isabella", "Madison", "Rika", "Rylee", "Salla", "Ellie", "Alexandra", "Amy", "Lass", "Brittany", "Chel", "Cindy", "Dianne", "Emily", "Emma", "Evelyn", "Hana", "Harleen", "Hazel", "Jocelyn", "Katrina", "Kimberly", "Lina", "Marge", "Mila", "Mizuki", "Rena", "Sal", "Satoko", "Summer", "Tomoe", "Vicky", "Yue", "Yumi", "Lauren", "Rei", "Riley", "Lois", "Nancy", "Tammy", "Terry" ]], + [TrainerType.HEX_MANIAC]: [ "Kindra", "Patricia", "Tammy", "Tasha", "Valerie", "Alaina", "Kathleen", "Leah", "Makie", "Sylvia", "Anina", "Arachna", "Carrie", "Desdemona", "Josette", "Luna", "Melanie", "Osanna", "Raziah" ], }; // function used in a commented code @@ -140,7 +140,7 @@ function fetchAndPopulateTrainerNames(url: string, parser: DOMParser, trainerNam if (!trainerListHeader) { return []; } - const elements = [...(trainerListHeader?.parentElement?.childNodes ?? [])]; + const elements = [ ...(trainerListHeader?.parentElement?.childNodes ?? []) ]; const startChildIndex = elements.indexOf(trainerListHeader); const endChildIndex = elements.findIndex(h => h.nodeName === "H2" && elements.indexOf(h) > startChildIndex); const tables = elements.filter(t => { @@ -152,7 +152,7 @@ function fetchAndPopulateTrainerNames(url: string, parser: DOMParser, trainerNam }).map(t => t as Element); console.log(url, tables); for (const table of tables) { - const trainerRows = [...table.querySelectorAll("tr:not(:first-child)")].filter(r => r.children.length === 9); + const trainerRows = [ ...table.querySelectorAll("tr:not(:first-child)") ].filter(r => r.children.length === 9); for (const row of trainerRows) { const nameCell = row.firstElementChild; if (!nameCell) { diff --git a/src/data/type.ts b/src/data/type.ts index 47bea8dd72b..6170eadc91e 100644 --- a/src/data/type.ts +++ b/src/data/type.ts @@ -1,25 +1,4 @@ -export enum Type { - UNKNOWN = -1, - NORMAL = 0, - FIGHTING, - FLYING, - POISON, - GROUND, - ROCK, - BUG, - GHOST, - STEEL, - FIRE, - WATER, - GRASS, - ELECTRIC, - PSYCHIC, - ICE, - DRAGON, - DARK, - FAIRY, - STELLAR -} +import { Type } from "#enums/type"; export type TypeDamageMultiplier = 0 | 0.125 | 0.25 | 0.5 | 1 | 2 | 4 | 8; @@ -29,260 +8,260 @@ export function getTypeDamageMultiplier(attackType: Type, defType: Type): TypeDa } switch (defType) { - case Type.NORMAL: - switch (attackType) { - case Type.FIGHTING: - return 2; - case Type.GHOST: - return 0; - default: - return 1; - } - case Type.FIGHTING: - switch (attackType) { - case Type.FLYING: - case Type.PSYCHIC: - case Type.FAIRY: - return 2; - case Type.ROCK: - case Type.BUG: - case Type.DARK: - return 0.5; - default: - return 1; - } - case Type.FLYING: - switch (attackType) { - case Type.ROCK: - case Type.ELECTRIC: - case Type.ICE: - return 2; - case Type.FIGHTING: - case Type.BUG: - case Type.GRASS: - return 0.5; - case Type.GROUND: - return 0; - default: - return 1; - } - case Type.POISON: - switch (attackType) { - case Type.GROUND: - case Type.PSYCHIC: - return 2; - case Type.FIGHTING: - case Type.POISON: - case Type.BUG: - case Type.GRASS: - case Type.FAIRY: - return 0.5; - default: - return 1; - } - case Type.GROUND: - switch (attackType) { - case Type.WATER: - case Type.GRASS: - case Type.ICE: - return 2; - case Type.POISON: - case Type.ROCK: - return 0.5; - case Type.ELECTRIC: - return 0; - default: - return 1; - } - case Type.ROCK: - switch (attackType) { - case Type.FIGHTING: - case Type.GROUND: - case Type.STEEL: - case Type.WATER: - case Type.GRASS: - return 2; case Type.NORMAL: - case Type.FLYING: - case Type.POISON: - case Type.FIRE: - return 0.5; - default: - return 1; - } - case Type.BUG: - switch (attackType) { - case Type.FLYING: - case Type.ROCK: - case Type.FIRE: - return 2; + switch (attackType) { + case Type.FIGHTING: + return 2; + case Type.GHOST: + return 0; + default: + return 1; + } case Type.FIGHTING: + switch (attackType) { + case Type.FLYING: + case Type.PSYCHIC: + case Type.FAIRY: + return 2; + case Type.ROCK: + case Type.BUG: + case Type.DARK: + return 0.5; + default: + return 1; + } + case Type.FLYING: + switch (attackType) { + case Type.ROCK: + case Type.ELECTRIC: + case Type.ICE: + return 2; + case Type.FIGHTING: + case Type.BUG: + case Type.GRASS: + return 0.5; + case Type.GROUND: + return 0; + default: + return 1; + } + case Type.POISON: + switch (attackType) { + case Type.GROUND: + case Type.PSYCHIC: + return 2; + case Type.FIGHTING: + case Type.POISON: + case Type.BUG: + case Type.GRASS: + case Type.FAIRY: + return 0.5; + default: + return 1; + } case Type.GROUND: - case Type.GRASS: - return 0.5; - default: - return 1; - } - case Type.GHOST: - switch (attackType) { + switch (attackType) { + case Type.WATER: + case Type.GRASS: + case Type.ICE: + return 2; + case Type.POISON: + case Type.ROCK: + return 0.5; + case Type.ELECTRIC: + return 0; + default: + return 1; + } + case Type.ROCK: + switch (attackType) { + case Type.FIGHTING: + case Type.GROUND: + case Type.STEEL: + case Type.WATER: + case Type.GRASS: + return 2; + case Type.NORMAL: + case Type.FLYING: + case Type.POISON: + case Type.FIRE: + return 0.5; + default: + return 1; + } + case Type.BUG: + switch (attackType) { + case Type.FLYING: + case Type.ROCK: + case Type.FIRE: + return 2; + case Type.FIGHTING: + case Type.GROUND: + case Type.GRASS: + return 0.5; + default: + return 1; + } case Type.GHOST: - case Type.DARK: - return 2; - case Type.POISON: - case Type.BUG: - return 0.5; - case Type.NORMAL: - case Type.FIGHTING: - return 0; - default: - return 1; - } - case Type.STEEL: - switch (attackType) { - case Type.FIGHTING: - case Type.GROUND: - case Type.FIRE: - return 2; - case Type.NORMAL: - case Type.FLYING: - case Type.ROCK: - case Type.BUG: + switch (attackType) { + case Type.GHOST: + case Type.DARK: + return 2; + case Type.POISON: + case Type.BUG: + return 0.5; + case Type.NORMAL: + case Type.FIGHTING: + return 0; + default: + return 1; + } case Type.STEEL: + switch (attackType) { + case Type.FIGHTING: + case Type.GROUND: + case Type.FIRE: + return 2; + case Type.NORMAL: + case Type.FLYING: + case Type.ROCK: + case Type.BUG: + case Type.STEEL: + case Type.GRASS: + case Type.PSYCHIC: + case Type.ICE: + case Type.DRAGON: + case Type.FAIRY: + return 0.5; + case Type.POISON: + return 0; + default: + return 1; + } + case Type.FIRE: + switch (attackType) { + case Type.GROUND: + case Type.ROCK: + case Type.WATER: + return 2; + case Type.BUG: + case Type.STEEL: + case Type.FIRE: + case Type.GRASS: + case Type.ICE: + case Type.FAIRY: + return 0.5; + default: + return 1; + } + case Type.WATER: + switch (attackType) { + case Type.GRASS: + case Type.ELECTRIC: + return 2; + case Type.STEEL: + case Type.FIRE: + case Type.WATER: + case Type.ICE: + return 0.5; + default: + return 1; + } case Type.GRASS: + switch (attackType) { + case Type.FLYING: + case Type.POISON: + case Type.BUG: + case Type.FIRE: + case Type.ICE: + return 2; + case Type.GROUND: + case Type.WATER: + case Type.GRASS: + case Type.ELECTRIC: + return 0.5; + default: + return 1; + } + case Type.ELECTRIC: + switch (attackType) { + case Type.GROUND: + return 2; + case Type.FLYING: + case Type.STEEL: + case Type.ELECTRIC: + return 0.5; + default: + return 1; + } case Type.PSYCHIC: + switch (attackType) { + case Type.BUG: + case Type.GHOST: + case Type.DARK: + return 2; + case Type.FIGHTING: + case Type.PSYCHIC: + return 0.5; + default: + return 1; + } case Type.ICE: + switch (attackType) { + case Type.FIGHTING: + case Type.ROCK: + case Type.STEEL: + case Type.FIRE: + return 2; + case Type.ICE: + return 0.5; + default: + return 1; + } case Type.DRAGON: - case Type.FAIRY: - return 0.5; - case Type.POISON: - return 0; - default: - return 1; - } - case Type.FIRE: - switch (attackType) { - case Type.GROUND: - case Type.ROCK: - case Type.WATER: - return 2; - case Type.BUG: - case Type.STEEL: - case Type.FIRE: - case Type.GRASS: - case Type.ICE: - case Type.FAIRY: - return 0.5; - default: - return 1; - } - case Type.WATER: - switch (attackType) { - case Type.GRASS: - case Type.ELECTRIC: - return 2; - case Type.STEEL: - case Type.FIRE: - case Type.WATER: - case Type.ICE: - return 0.5; - default: - return 1; - } - case Type.GRASS: - switch (attackType) { - case Type.FLYING: - case Type.POISON: - case Type.BUG: - case Type.FIRE: - case Type.ICE: - return 2; - case Type.GROUND: - case Type.WATER: - case Type.GRASS: - case Type.ELECTRIC: - return 0.5; - default: - return 1; - } - case Type.ELECTRIC: - switch (attackType) { - case Type.GROUND: - return 2; - case Type.FLYING: - case Type.STEEL: - case Type.ELECTRIC: - return 0.5; - default: - return 1; - } - case Type.PSYCHIC: - switch (attackType) { - case Type.BUG: - case Type.GHOST: + switch (attackType) { + case Type.ICE: + case Type.DRAGON: + case Type.FAIRY: + return 2; + case Type.FIRE: + case Type.WATER: + case Type.GRASS: + case Type.ELECTRIC: + return 0.5; + default: + return 1; + } case Type.DARK: - return 2; - case Type.FIGHTING: - case Type.PSYCHIC: - return 0.5; - default: - return 1; - } - case Type.ICE: - switch (attackType) { - case Type.FIGHTING: - case Type.ROCK: - case Type.STEEL: - case Type.FIRE: - return 2; - case Type.ICE: - return 0.5; - default: - return 1; - } - case Type.DRAGON: - switch (attackType) { - case Type.ICE: - case Type.DRAGON: + switch (attackType) { + case Type.FIGHTING: + case Type.BUG: + case Type.FAIRY: + return 2; + case Type.GHOST: + case Type.DARK: + return 0.5; + case Type.PSYCHIC: + return 0; + default: + return 1; + } case Type.FAIRY: - return 2; - case Type.FIRE: - case Type.WATER: - case Type.GRASS: - case Type.ELECTRIC: - return 0.5; - default: + switch (attackType) { + case Type.POISON: + case Type.STEEL: + return 2; + case Type.FIGHTING: + case Type.BUG: + case Type.DARK: + return 0.5; + case Type.DRAGON: + return 0; + default: + return 1; + } + case Type.STELLAR: return 1; - } - case Type.DARK: - switch (attackType) { - case Type.FIGHTING: - case Type.BUG: - case Type.FAIRY: - return 2; - case Type.GHOST: - case Type.DARK: - return 0.5; - case Type.PSYCHIC: - return 0; - default: - return 1; - } - case Type.FAIRY: - switch (attackType) { - case Type.POISON: - case Type.STEEL: - return 2; - case Type.FIGHTING: - case Type.BUG: - case Type.DARK: - return 0.5; - case Type.DRAGON: - return 0; - default: - return 1; - } - case Type.STELLAR: - return 1; } return 1; @@ -295,86 +274,86 @@ export function getTypeDamageMultiplier(attackType: Type, defType: Type): TypeDa export function getTypeDamageMultiplierColor(multiplier: TypeDamageMultiplier, side: "defense" | "offense"): string | undefined { if (side === "offense") { switch (multiplier) { - case 0: - return "#929292"; - case 0.125: - return "#FF5500"; - case 0.25: - return "#FF7400"; - case 0.5: - return "#FE8E00"; - case 1: - return undefined; - case 2: - return "#4AA500"; - case 4: - return "#4BB400"; - case 8: - return "#52C200"; + case 0: + return "#929292"; + case 0.125: + return "#FF5500"; + case 0.25: + return "#FF7400"; + case 0.5: + return "#FE8E00"; + case 1: + return undefined; + case 2: + return "#4AA500"; + case 4: + return "#4BB400"; + case 8: + return "#52C200"; } } else if (side === "defense") { switch (multiplier) { - case 0: - return "#B1B100"; - case 0.125: - return "#2DB4FF"; - case 0.25: - return "#00A4FF"; - case 0.5: - return "#0093FF"; - case 1: - return undefined; - case 2: - return "#FE8E00"; - case 4: - return "#FF7400"; - case 8: - return "#FF5500"; + case 0: + return "#B1B100"; + case 0.125: + return "#2DB4FF"; + case 0.25: + return "#00A4FF"; + case 0.5: + return "#0093FF"; + case 1: + return undefined; + case 2: + return "#FE8E00"; + case 4: + return "#FF7400"; + case 8: + return "#FF5500"; } } } export function getTypeRgb(type: Type): [ integer, integer, integer ] { switch (type) { - case Type.NORMAL: - return [ 168, 168, 120 ]; - case Type.FIGHTING: - return [ 192, 48, 40 ]; - case Type.FLYING: - return [ 168, 144, 240 ]; - case Type.POISON: - return [ 160, 64, 160 ]; - case Type.GROUND: - return [ 224, 192, 104 ]; - case Type.ROCK: - return [ 184, 160, 56 ]; - case Type.BUG: - return [ 168, 184, 32 ]; - case Type.GHOST: - return [ 112, 88, 152 ]; - case Type.STEEL: - return [ 184, 184, 208 ]; - case Type.FIRE: - return [ 240, 128, 48 ]; - case Type.WATER: - return [ 104, 144, 240 ]; - case Type.GRASS: - return [ 120, 200, 80 ]; - case Type.ELECTRIC: - return [ 248, 208, 48 ]; - case Type.PSYCHIC: - return [ 248, 88, 136 ]; - case Type.ICE: - return [ 152, 216, 216 ]; - case Type.DRAGON: - return [ 112, 56, 248 ]; - case Type.DARK: - return [ 112, 88, 72 ]; - case Type.FAIRY: - return [ 232, 136, 200 ]; - case Type.STELLAR: - return [ 255, 255, 255 ]; - default: - return [ 0, 0, 0 ]; + case Type.NORMAL: + return [ 168, 168, 120 ]; + case Type.FIGHTING: + return [ 192, 48, 40 ]; + case Type.FLYING: + return [ 168, 144, 240 ]; + case Type.POISON: + return [ 160, 64, 160 ]; + case Type.GROUND: + return [ 224, 192, 104 ]; + case Type.ROCK: + return [ 184, 160, 56 ]; + case Type.BUG: + return [ 168, 184, 32 ]; + case Type.GHOST: + return [ 112, 88, 152 ]; + case Type.STEEL: + return [ 184, 184, 208 ]; + case Type.FIRE: + return [ 240, 128, 48 ]; + case Type.WATER: + return [ 104, 144, 240 ]; + case Type.GRASS: + return [ 120, 200, 80 ]; + case Type.ELECTRIC: + return [ 248, 208, 48 ]; + case Type.PSYCHIC: + return [ 248, 88, 136 ]; + case Type.ICE: + return [ 152, 216, 216 ]; + case Type.DRAGON: + return [ 112, 56, 248 ]; + case Type.DARK: + return [ 112, 88, 72 ]; + case Type.FAIRY: + return [ 232, 136, 200 ]; + case Type.STELLAR: + return [ 255, 255, 255 ]; + default: + return [ 0, 0, 0 ]; } } diff --git a/src/data/variant.ts b/src/data/variant.ts index b7a01a4be89..13869635f1e 100644 --- a/src/data/variant.ts +++ b/src/data/variant.ts @@ -10,22 +10,22 @@ export const variantColorCache = {}; export function getVariantTint(variant: Variant): integer { switch (variant) { - case 0: - return 0xf8c020; - case 1: - return 0x20f8f0; - case 2: - return 0xe81048; + case 0: + return 0xf8c020; + case 1: + return 0x20f8f0; + case 2: + return 0xe81048; } } export function getVariantIcon(variant: Variant): integer { switch (variant) { - case 0: - return VariantTier.STANDARD; - case 1: - return VariantTier.RARE; - case 2: - return VariantTier.EPIC; + case 0: + return VariantTier.STANDARD; + case 1: + return VariantTier.RARE; + case 2: + return VariantTier.EPIC; } } diff --git a/src/data/weather.ts b/src/data/weather.ts index afdd0a958cf..0a76a015402 100644 --- a/src/data/weather.ts +++ b/src/data/weather.ts @@ -2,7 +2,7 @@ import { Biome } from "#enums/biome"; import { WeatherType } from "#enums/weather-type"; import { getPokemonNameWithAffix } from "../messages"; import Pokemon from "../field/pokemon"; -import { Type } from "./type"; +import { Type } from "#enums/type"; import Move, { AttackMove } from "./move"; import * as Utils from "../utils"; import BattleScene from "../battle-scene"; @@ -10,7 +10,6 @@ import { SuppressWeatherEffectAbAttr } from "./ability"; import { TerrainType, getTerrainName } from "./terrain"; import i18next from "i18next"; -export { WeatherType }; export class Weather { public weatherType: WeatherType; public turnsLeft: integer; @@ -33,10 +32,10 @@ export class Weather { isImmutable(): boolean { switch (this.weatherType) { - case WeatherType.HEAVY_RAIN: - case WeatherType.HARSH_SUN: - case WeatherType.STRONG_WINDS: - return true; + case WeatherType.HEAVY_RAIN: + case WeatherType.HARSH_SUN: + case WeatherType.STRONG_WINDS: + return true; } return false; @@ -44,9 +43,9 @@ export class Weather { isDamaging(): boolean { switch (this.weatherType) { - case WeatherType.SANDSTORM: - case WeatherType.HAIL: - return true; + case WeatherType.SANDSTORM: + case WeatherType.HAIL: + return true; } return false; @@ -54,10 +53,10 @@ export class Weather { isTypeDamageImmune(type: Type): boolean { switch (this.weatherType) { - case WeatherType.SANDSTORM: - return type === Type.GROUND || type === Type.ROCK || type === Type.STEEL; - case WeatherType.HAIL: - return type === Type.ICE; + case WeatherType.SANDSTORM: + return type === Type.GROUND || type === Type.ROCK || type === Type.STEEL; + case WeatherType.HAIL: + return type === Type.ICE; } return false; @@ -65,24 +64,24 @@ export class Weather { getAttackTypeMultiplier(attackType: Type): number { switch (this.weatherType) { - case WeatherType.SUNNY: - case WeatherType.HARSH_SUN: - if (attackType === Type.FIRE) { - return 1.5; - } - if (attackType === Type.WATER) { - return 0.5; - } - break; - case WeatherType.RAIN: - case WeatherType.HEAVY_RAIN: - if (attackType === Type.FIRE) { - return 0.5; - } - if (attackType === Type.WATER) { - return 1.5; - } - break; + case WeatherType.SUNNY: + case WeatherType.HARSH_SUN: + if (attackType === Type.FIRE) { + return 1.5; + } + if (attackType === Type.WATER) { + return 0.5; + } + break; + case WeatherType.RAIN: + case WeatherType.HEAVY_RAIN: + if (attackType === Type.FIRE) { + return 0.5; + } + if (attackType === Type.WATER) { + return 1.5; + } + break; } return 1; @@ -92,10 +91,10 @@ export class Weather { const moveType = user.getMoveType(move); switch (this.weatherType) { - case WeatherType.HARSH_SUN: - return move instanceof AttackMove && moveType === Type.WATER; - case WeatherType.HEAVY_RAIN: - return move instanceof AttackMove && moveType === Type.FIRE; + case WeatherType.HARSH_SUN: + return move instanceof AttackMove && moveType === Type.WATER; + case WeatherType.HEAVY_RAIN: + return move instanceof AttackMove && moveType === Type.FIRE; } return false; @@ -120,24 +119,24 @@ export class Weather { export function getWeatherStartMessage(weatherType: WeatherType): string | null { switch (weatherType) { - case WeatherType.SUNNY: - return i18next.t("weather:sunnyStartMessage"); - case WeatherType.RAIN: - return i18next.t("weather:rainStartMessage"); - case WeatherType.SANDSTORM: - return i18next.t("weather:sandstormStartMessage"); - case WeatherType.HAIL: - return i18next.t("weather:hailStartMessage"); - case WeatherType.SNOW: - return i18next.t("weather:snowStartMessage"); - case WeatherType.FOG: - return i18next.t("weather:fogStartMessage"); - case WeatherType.HEAVY_RAIN: - return i18next.t("weather:heavyRainStartMessage"); - case WeatherType.HARSH_SUN: - return i18next.t("weather:harshSunStartMessage"); - case WeatherType.STRONG_WINDS: - return i18next.t("weather:strongWindsStartMessage"); + case WeatherType.SUNNY: + return i18next.t("weather:sunnyStartMessage"); + case WeatherType.RAIN: + return i18next.t("weather:rainStartMessage"); + case WeatherType.SANDSTORM: + return i18next.t("weather:sandstormStartMessage"); + case WeatherType.HAIL: + return i18next.t("weather:hailStartMessage"); + case WeatherType.SNOW: + return i18next.t("weather:snowStartMessage"); + case WeatherType.FOG: + return i18next.t("weather:fogStartMessage"); + case WeatherType.HEAVY_RAIN: + return i18next.t("weather:heavyRainStartMessage"); + case WeatherType.HARSH_SUN: + return i18next.t("weather:harshSunStartMessage"); + case WeatherType.STRONG_WINDS: + return i18next.t("weather:strongWindsStartMessage"); } return null; @@ -145,24 +144,24 @@ export function getWeatherStartMessage(weatherType: WeatherType): string | null export function getWeatherLapseMessage(weatherType: WeatherType): string | null { switch (weatherType) { - case WeatherType.SUNNY: - return i18next.t("weather:sunnyLapseMessage"); - case WeatherType.RAIN: - return i18next.t("weather:rainLapseMessage"); - case WeatherType.SANDSTORM: - return i18next.t("weather:sandstormLapseMessage"); - case WeatherType.HAIL: - return i18next.t("weather:hailLapseMessage"); - case WeatherType.SNOW: - return i18next.t("weather:snowLapseMessage"); - case WeatherType.FOG: - return i18next.t("weather:fogLapseMessage"); - case WeatherType.HEAVY_RAIN: - return i18next.t("weather:heavyRainLapseMessage"); - case WeatherType.HARSH_SUN: - return i18next.t("weather:harshSunLapseMessage"); - case WeatherType.STRONG_WINDS: - return i18next.t("weather:strongWindsLapseMessage"); + case WeatherType.SUNNY: + return i18next.t("weather:sunnyLapseMessage"); + case WeatherType.RAIN: + return i18next.t("weather:rainLapseMessage"); + case WeatherType.SANDSTORM: + return i18next.t("weather:sandstormLapseMessage"); + case WeatherType.HAIL: + return i18next.t("weather:hailLapseMessage"); + case WeatherType.SNOW: + return i18next.t("weather:snowLapseMessage"); + case WeatherType.FOG: + return i18next.t("weather:fogLapseMessage"); + case WeatherType.HEAVY_RAIN: + return i18next.t("weather:heavyRainLapseMessage"); + case WeatherType.HARSH_SUN: + return i18next.t("weather:harshSunLapseMessage"); + case WeatherType.STRONG_WINDS: + return i18next.t("weather:strongWindsLapseMessage"); } return null; @@ -170,10 +169,10 @@ export function getWeatherLapseMessage(weatherType: WeatherType): string | null export function getWeatherDamageMessage(weatherType: WeatherType, pokemon: Pokemon): string | null { switch (weatherType) { - case WeatherType.SANDSTORM: - return i18next.t("weather:sandstormDamageMessage", {pokemonNameWithAffix: getPokemonNameWithAffix(pokemon)}); - case WeatherType.HAIL: - return i18next.t("weather:hailDamageMessage", {pokemonNameWithAffix: getPokemonNameWithAffix(pokemon)}); + case WeatherType.SANDSTORM: + return i18next.t("weather:sandstormDamageMessage", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) }); + case WeatherType.HAIL: + return i18next.t("weather:hailDamageMessage", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) }); } return null; @@ -181,24 +180,24 @@ export function getWeatherDamageMessage(weatherType: WeatherType, pokemon: Pokem export function getWeatherClearMessage(weatherType: WeatherType): string | null { switch (weatherType) { - case WeatherType.SUNNY: - return i18next.t("weather:sunnyClearMessage"); - case WeatherType.RAIN: - return i18next.t("weather:rainClearMessage"); - case WeatherType.SANDSTORM: - return i18next.t("weather:sandstormClearMessage"); - case WeatherType.HAIL: - return i18next.t("weather:hailClearMessage"); - case WeatherType.SNOW: - return i18next.t("weather:snowClearMessage"); - case WeatherType.FOG: - return i18next.t("weather:fogClearMessage"); - case WeatherType.HEAVY_RAIN: - return i18next.t("weather:heavyRainClearMessage"); - case WeatherType.HARSH_SUN: - return i18next.t("weather:harshSunClearMessage"); - case WeatherType.STRONG_WINDS: - return i18next.t("weather:strongWindsClearMessage"); + case WeatherType.SUNNY: + return i18next.t("weather:sunnyClearMessage"); + case WeatherType.RAIN: + return i18next.t("weather:rainClearMessage"); + case WeatherType.SANDSTORM: + return i18next.t("weather:sandstormClearMessage"); + case WeatherType.HAIL: + return i18next.t("weather:hailClearMessage"); + case WeatherType.SNOW: + return i18next.t("weather:snowClearMessage"); + case WeatherType.FOG: + return i18next.t("weather:fogClearMessage"); + case WeatherType.HEAVY_RAIN: + return i18next.t("weather:heavyRainClearMessage"); + case WeatherType.HARSH_SUN: + return i18next.t("weather:harshSunClearMessage"); + case WeatherType.STRONG_WINDS: + return i18next.t("weather:strongWindsClearMessage"); } return null; @@ -206,41 +205,41 @@ export function getWeatherClearMessage(weatherType: WeatherType): string | null export function getTerrainStartMessage(terrainType: TerrainType): string | null { switch (terrainType) { - case TerrainType.MISTY: - return i18next.t("terrain:mistyStartMessage"); - case TerrainType.ELECTRIC: - return i18next.t("terrain:electricStartMessage"); - case TerrainType.GRASSY: - return i18next.t("terrain:grassyStartMessage"); - case TerrainType.PSYCHIC: - return i18next.t("terrain:psychicStartMessage"); - default: - console.warn("getTerrainStartMessage not defined. Using default null"); - return null; + case TerrainType.MISTY: + return i18next.t("terrain:mistyStartMessage"); + case TerrainType.ELECTRIC: + return i18next.t("terrain:electricStartMessage"); + case TerrainType.GRASSY: + return i18next.t("terrain:grassyStartMessage"); + case TerrainType.PSYCHIC: + return i18next.t("terrain:psychicStartMessage"); + default: + console.warn("getTerrainStartMessage not defined. Using default null"); + return null; } } export function getTerrainClearMessage(terrainType: TerrainType): string | null { switch (terrainType) { - case TerrainType.MISTY: - return i18next.t("terrain:mistyClearMessage"); - case TerrainType.ELECTRIC: - return i18next.t("terrain:electricClearMessage"); - case TerrainType.GRASSY: - return i18next.t("terrain:grassyClearMessage"); - case TerrainType.PSYCHIC: - return i18next.t("terrain:psychicClearMessage"); - default: - console.warn("getTerrainClearMessage not defined. Using default null"); - return null; + case TerrainType.MISTY: + return i18next.t("terrain:mistyClearMessage"); + case TerrainType.ELECTRIC: + return i18next.t("terrain:electricClearMessage"); + case TerrainType.GRASSY: + return i18next.t("terrain:grassyClearMessage"); + case TerrainType.PSYCHIC: + return i18next.t("terrain:psychicClearMessage"); + default: + console.warn("getTerrainClearMessage not defined. Using default null"); + return null; } } export function getTerrainBlockMessage(pokemon: Pokemon, terrainType: TerrainType): string { if (terrainType === TerrainType.MISTY) { - return i18next.t("terrain:mistyBlockMessage", {pokemonNameWithAffix: getPokemonNameWithAffix(pokemon)}); + return i18next.t("terrain:mistyBlockMessage", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) }); } - return i18next.t("terrain:defaultBlockMessage", {pokemonNameWithAffix: getPokemonNameWithAffix(pokemon), terrainName: getTerrainName(terrainType)}); + return i18next.t("terrain:defaultBlockMessage", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon), terrainName: getTerrainName(terrainType) }); } interface WeatherPoolEntry { @@ -252,126 +251,126 @@ export function getRandomWeatherType(arena: any /* Importing from arena causes a let weatherPool: WeatherPoolEntry[] = []; const hasSun = arena.getTimeOfDay() < 2; switch (arena.biomeType) { - case Biome.GRASS: - weatherPool = [ - { weatherType: WeatherType.NONE, weight: 7 } - ]; - if (hasSun) { - weatherPool.push({ weatherType: WeatherType.SUNNY, weight: 3 }); - } - break; - case Biome.TALL_GRASS: - weatherPool = [ - { weatherType: WeatherType.NONE, weight: 8 }, - { weatherType: WeatherType.RAIN, weight: 5 }, - ]; - if (hasSun) { - weatherPool.push({ weatherType: WeatherType.SUNNY, weight: 8 }); - } - break; - case Biome.FOREST: - weatherPool = [ - { weatherType: WeatherType.NONE, weight: 8 }, - { weatherType: WeatherType.RAIN, weight: 5 } - ]; - break; - case Biome.SEA: - weatherPool = [ - { weatherType: WeatherType.NONE, weight: 3 }, - { weatherType: WeatherType.RAIN, weight: 12 } - ]; - break; - case Biome.SWAMP: - weatherPool = [ - { weatherType: WeatherType.NONE, weight: 3 }, - { weatherType: WeatherType.RAIN, weight: 4 }, - { weatherType: WeatherType.FOG, weight: 1 } - ]; - break; - case Biome.BEACH: - weatherPool = [ - { weatherType: WeatherType.NONE, weight: 8 }, - { weatherType: WeatherType.RAIN, weight: 3 } - ]; - if (hasSun) { - weatherPool.push({ weatherType: WeatherType.SUNNY, weight: 5 }); - } - break; - case Biome.LAKE: - weatherPool = [ - { weatherType: WeatherType.NONE, weight: 10 }, - { weatherType: WeatherType.RAIN, weight: 5 }, - { weatherType: WeatherType.FOG, weight: 1 } - ]; - break; - case Biome.SEABED: - weatherPool = [ - { weatherType: WeatherType.RAIN, weight: 1 } - ]; - break; - case Biome.BADLANDS: - weatherPool = [ - { weatherType: WeatherType.NONE, weight: 8 }, - { weatherType: WeatherType.SANDSTORM, weight: 2 } - ]; - if (hasSun) { - weatherPool.push({ weatherType: WeatherType.SUNNY, weight: 5 }); - } - break; - case Biome.DESERT: - weatherPool = [ - { weatherType: WeatherType.SANDSTORM, weight: 2 } - ]; - if (hasSun) { - weatherPool.push({ weatherType: WeatherType.SUNNY, weight: 2 }); - } - break; - case Biome.ICE_CAVE: - weatherPool = [ - { weatherType: WeatherType.NONE, weight: 3 }, - { weatherType: WeatherType.SNOW, weight: 4 }, - { weatherType: WeatherType.HAIL, weight: 1 } - ]; - break; - case Biome.MEADOW: - weatherPool = [ - { weatherType: WeatherType.NONE, weight: 2 } - ]; - if (hasSun) { - weatherPool.push({ weatherType: WeatherType.SUNNY, weight: 2 }); - } - case Biome.VOLCANO: - weatherPool = [ - { weatherType: hasSun ? WeatherType.SUNNY : WeatherType.NONE, weight: 1 } - ]; - break; - case Biome.GRAVEYARD: - weatherPool = [ - { weatherType: WeatherType.NONE, weight: 3 }, - { weatherType: WeatherType.FOG, weight: 1 } - ]; - break; - case Biome.JUNGLE: - weatherPool = [ - { weatherType: WeatherType.NONE, weight: 8 }, - { weatherType: WeatherType.RAIN, weight: 2 } - ]; - break; - case Biome.SNOWY_FOREST: - weatherPool = [ - { weatherType: WeatherType.SNOW, weight: 7 }, - { weatherType: WeatherType.HAIL, weight: 1 } - ]; - break; - case Biome.ISLAND: - weatherPool = [ - { weatherType: WeatherType.NONE, weight: 5 }, - { weatherType: WeatherType.RAIN, weight: 1 }, - ]; - if (hasSun) { - weatherPool.push({ weatherType: WeatherType.SUNNY, weight: 2 }); - } - break; + case Biome.GRASS: + weatherPool = [ + { weatherType: WeatherType.NONE, weight: 7 } + ]; + if (hasSun) { + weatherPool.push({ weatherType: WeatherType.SUNNY, weight: 3 }); + } + break; + case Biome.TALL_GRASS: + weatherPool = [ + { weatherType: WeatherType.NONE, weight: 8 }, + { weatherType: WeatherType.RAIN, weight: 5 }, + ]; + if (hasSun) { + weatherPool.push({ weatherType: WeatherType.SUNNY, weight: 8 }); + } + break; + case Biome.FOREST: + weatherPool = [ + { weatherType: WeatherType.NONE, weight: 8 }, + { weatherType: WeatherType.RAIN, weight: 5 } + ]; + break; + case Biome.SEA: + weatherPool = [ + { weatherType: WeatherType.NONE, weight: 3 }, + { weatherType: WeatherType.RAIN, weight: 12 } + ]; + break; + case Biome.SWAMP: + weatherPool = [ + { weatherType: WeatherType.NONE, weight: 3 }, + { weatherType: WeatherType.RAIN, weight: 4 }, + { weatherType: WeatherType.FOG, weight: 1 } + ]; + break; + case Biome.BEACH: + weatherPool = [ + { weatherType: WeatherType.NONE, weight: 8 }, + { weatherType: WeatherType.RAIN, weight: 3 } + ]; + if (hasSun) { + weatherPool.push({ weatherType: WeatherType.SUNNY, weight: 5 }); + } + break; + case Biome.LAKE: + weatherPool = [ + { weatherType: WeatherType.NONE, weight: 10 }, + { weatherType: WeatherType.RAIN, weight: 5 }, + { weatherType: WeatherType.FOG, weight: 1 } + ]; + break; + case Biome.SEABED: + weatherPool = [ + { weatherType: WeatherType.RAIN, weight: 1 } + ]; + break; + case Biome.BADLANDS: + weatherPool = [ + { weatherType: WeatherType.NONE, weight: 8 }, + { weatherType: WeatherType.SANDSTORM, weight: 2 } + ]; + if (hasSun) { + weatherPool.push({ weatherType: WeatherType.SUNNY, weight: 5 }); + } + break; + case Biome.DESERT: + weatherPool = [ + { weatherType: WeatherType.SANDSTORM, weight: 2 } + ]; + if (hasSun) { + weatherPool.push({ weatherType: WeatherType.SUNNY, weight: 2 }); + } + break; + case Biome.ICE_CAVE: + weatherPool = [ + { weatherType: WeatherType.NONE, weight: 3 }, + { weatherType: WeatherType.SNOW, weight: 4 }, + { weatherType: WeatherType.HAIL, weight: 1 } + ]; + break; + case Biome.MEADOW: + weatherPool = [ + { weatherType: WeatherType.NONE, weight: 2 } + ]; + if (hasSun) { + weatherPool.push({ weatherType: WeatherType.SUNNY, weight: 2 }); + } + case Biome.VOLCANO: + weatherPool = [ + { weatherType: hasSun ? WeatherType.SUNNY : WeatherType.NONE, weight: 1 } + ]; + break; + case Biome.GRAVEYARD: + weatherPool = [ + { weatherType: WeatherType.NONE, weight: 3 }, + { weatherType: WeatherType.FOG, weight: 1 } + ]; + break; + case Biome.JUNGLE: + weatherPool = [ + { weatherType: WeatherType.NONE, weight: 8 }, + { weatherType: WeatherType.RAIN, weight: 2 } + ]; + break; + case Biome.SNOWY_FOREST: + weatherPool = [ + { weatherType: WeatherType.SNOW, weight: 7 }, + { weatherType: WeatherType.HAIL, weight: 1 } + ]; + break; + case Biome.ISLAND: + weatherPool = [ + { weatherType: WeatherType.NONE, weight: 5 }, + { weatherType: WeatherType.RAIN, weight: 1 }, + ]; + if (hasSun) { + weatherPool.push({ weatherType: WeatherType.SUNNY, weight: 2 }); + } + break; } if (weatherPool.length > 1) { diff --git a/src/enums/arena-tag-type.ts b/src/enums/arena-tag-type.ts index 1c79750c91a..1c62ccb14a6 100644 --- a/src/enums/arena-tag-type.ts +++ b/src/enums/arena-tag-type.ts @@ -1,4 +1,3 @@ - export enum ArenaTagType { NONE = "NONE", MUD_SPORT = "MUD_SPORT", @@ -23,5 +22,11 @@ export enum ArenaTagType { TAILWIND = "TAILWIND", HAPPY_HOUR = "HAPPY_HOUR", SAFEGUARD = "SAFEGUARD", - NO_CRIT = "NO_CRIT" + NO_CRIT = "NO_CRIT", + IMPRISON = "IMPRISON", + ION_DELUGE = "ION_DELUGE", + FIRE_GRASS_PLEDGE = "FIRE_GRASS_PLEDGE", + WATER_FIRE_PLEDGE = "WATER_FIRE_PLEDGE", + GRASS_WATER_PLEDGE = "GRASS_WATER_PLEDGE", + FAIRY_LOCK = "FAIRY_LOCK", } diff --git a/src/enums/battler-tag-type.ts b/src/enums/battler-tag-type.ts index f367b1b56c0..bb969386630 100644 --- a/src/enums/battler-tag-type.ts +++ b/src/enums/battler-tag-type.ts @@ -1,4 +1,3 @@ - export enum BattlerTagType { NONE = "NONE", RECHARGING = "RECHARGING", @@ -55,7 +54,7 @@ export enum BattlerTagType { CURSED = "CURSED", CHARGED = "CHARGED", ROOSTED = "ROOSTED", - MAGNET_RISEN = "MAGNET_RISEN", + FLOATING = "FLOATING", MINIMIZED = "MINIMIZED", DESTINY_BOND = "DESTINY_BOND", CENTER_OF_ATTENTION = "CENTER_OF_ATTENTION", @@ -75,9 +74,23 @@ export enum BattlerTagType { DRAGON_CHEER = "DRAGON_CHEER", NO_RETREAT = "NO_RETREAT", GORILLA_TACTICS = "GORILLA_TACTICS", + UNBURDEN = "UNBURDEN", THROAT_CHOPPED = "THROAT_CHOPPED", TAR_SHOT = "TAR_SHOT", BURNED_UP = "BURNED_UP", DOUBLE_SHOCKED = "DOUBLE_SHOCKED", + AUTOTOMIZED = "AUTOTOMIZED", MYSTERY_ENCOUNTER_POST_SUMMON = "MYSTERY_ENCOUNTER_POST_SUMMON", + POWER_TRICK = "POWER_TRICK", + HEAL_BLOCK = "HEAL_BLOCK", + TORMENT = "TORMENT", + TAUNT = "TAUNT", + IMPRISON = "IMPRISON", + SYRUP_BOMB = "SYRUP_BOMB", + ELECTRIFIED = "ELECTRIFIED", + TELEKINESIS = "TELEKINESIS", + COMMANDED = "COMMANDED", + GRUDGE = "GRUDGE", + PSYCHO_SHIFT = "PSYCHO_SHIFT", + ENDURE_TOKEN = "ENDURE_TOKEN", } diff --git a/src/enums/berry-type.ts b/src/enums/berry-type.ts index 8b7aab16010..97c69148146 100644 --- a/src/enums/berry-type.ts +++ b/src/enums/berry-type.ts @@ -1,4 +1,3 @@ - export enum BerryType { SITRUS, LUM, diff --git a/src/enums/biome.ts b/src/enums/biome.ts index 7088b2e99ac..bb9eaf454cc 100644 --- a/src/enums/biome.ts +++ b/src/enums/biome.ts @@ -1,4 +1,3 @@ - export enum Biome { TOWN, PLAINS, diff --git a/src/enums/egg-type.ts b/src/enums/egg-type.ts index d8d0facb020..901e60b3c76 100644 --- a/src/enums/egg-type.ts +++ b/src/enums/egg-type.ts @@ -1,6 +1,6 @@ export enum EggTier { COMMON, - GREAT, - ULTRA, - MASTER + RARE, + EPIC, + LEGENDARY } diff --git a/src/enums/mystery-encounter-type.ts b/src/enums/mystery-encounter-type.ts index 39a8087599c..b973652b113 100644 --- a/src/enums/mystery-encounter-type.ts +++ b/src/enums/mystery-encounter-type.ts @@ -28,5 +28,6 @@ export enum MysteryEncounterType { BUG_TYPE_SUPERFAN, FUN_AND_GAMES, UNCOMMON_BREED, - GLOBAL_TRADE_SYSTEM + GLOBAL_TRADE_SYSTEM, + THE_EXPERT_POKEMON_BREEDER } diff --git a/src/enums/pokemon-anim-type.ts b/src/enums/pokemon-anim-type.ts index 5a0a0c2f622..b153fb2e652 100644 --- a/src/enums/pokemon-anim-type.ts +++ b/src/enums/pokemon-anim-type.ts @@ -12,5 +12,15 @@ export enum PokemonAnimType { * Removes a Pokemon's Substitute doll from the field. * The Pokemon then moves back to its original position. */ - SUBSTITUTE_REMOVE + SUBSTITUTE_REMOVE, + /** + * Brings Tatsugiri and Dondozo to the center of the field, with + * Tatsugiri jumping into the Dondozo's mouth + */ + COMMANDER_APPLY, + /** + * Dondozo "spits out" Tatsugiri, moving Tatsugiri back to its original + * field position. + */ + COMMANDER_REMOVE } diff --git a/src/enums/species-form-key.ts b/src/enums/species-form-key.ts new file mode 100644 index 00000000000..b324c876b87 --- /dev/null +++ b/src/enums/species-form-key.ts @@ -0,0 +1,13 @@ +export enum SpeciesFormKey { + MEGA = "mega", + MEGA_X = "mega-x", + MEGA_Y = "mega-y", + PRIMAL = "primal", + ORIGIN = "origin", + INCARNATE = "incarnate", + THERIAN = "therian", + GIGANTAMAX = "gigantamax", + GIGANTAMAX_SINGLE = "gigantamax-single", + GIGANTAMAX_RAPID = "gigantamax-rapid", + ETERNAMAX = "eternamax", +} diff --git a/src/enums/stat.ts b/src/enums/stat.ts index a12d53e8559..6b3f7dc6d79 100644 --- a/src/enums/stat.ts +++ b/src/enums/stat.ts @@ -50,7 +50,7 @@ export function getStatStageChangeDescriptionKey(stages: number, isIncrease: boo return isIncrease ? "battle:statRose" : "battle:statFell"; } else if (stages === 2) { return isIncrease ? "battle:statSharplyRose" : "battle:statHarshlyFell"; - } else if (stages <= 6) { + } else if (stages > 2 && stages <= 6) { return isIncrease ? "battle:statRoseDrastically" : "battle:statSeverelyFell"; } return isIncrease ? "battle:statWontGoAnyHigher" : "battle:statWontGoAnyLower"; diff --git a/src/enums/switch-type.ts b/src/enums/switch-type.ts new file mode 100644 index 00000000000..752c0902636 --- /dev/null +++ b/src/enums/switch-type.ts @@ -0,0 +1,14 @@ +/** + * Indicates the type of switch functionality that a {@linkcode SwitchPhase} + * or {@linkcode SwitchSummonPhase} will carry out. + */ +export enum SwitchType { + /** Switchout specifically for when combat starts and the player is prompted if they will switch Pokemon */ + INITIAL_SWITCH, + /** Basic switchout where the Pokemon to switch in is selected */ + SWITCH, + /** Transfers stat stages and other effects from the returning Pokemon to the switched in Pokemon */ + BATON_PASS, + /** Transfers the returning Pokemon's Substitute to the switched in Pokemon */ + SHED_TAIL +} diff --git a/src/enums/time-of-day.ts b/src/enums/time-of-day.ts index 9363aa4c73a..3fd05308cc6 100644 --- a/src/enums/time-of-day.ts +++ b/src/enums/time-of-day.ts @@ -1,4 +1,3 @@ - export enum TimeOfDay { ALL = -1, DAWN, diff --git a/src/enums/trainer-type.ts b/src/enums/trainer-type.ts index cfc52b70eb0..708faf69196 100644 --- a/src/enums/trainer-type.ts +++ b/src/enums/trainer-type.ts @@ -78,6 +78,12 @@ export enum TrainerType { PLUMERIA, MACRO_GRUNT, OLEANA, + STAR_GRUNT, + GIACOMO, + MELA, + ATTICUS, + ORTEGA, + ERI, ROCKET_BOSS_GIOVANNI_1, ROCKET_BOSS_GIOVANNI_2, MAXIE, @@ -96,6 +102,8 @@ export enum TrainerType { GUZMA_2, ROSE, ROSE_2, + PENNY, + PENNY_2, BUCK, CHERYL, MARLEY, @@ -107,6 +115,9 @@ export enum TrainerType { VICKY, VITO, BUG_TYPE_SUPERFAN, + EXPERT_POKEMON_BREEDER, + FUTURE_SELF_M, + FUTURE_SELF_F, BROCK = 200, MISTY, diff --git a/src/enums/type.ts b/src/enums/type.ts new file mode 100644 index 00000000000..a04849c2ca3 --- /dev/null +++ b/src/enums/type.ts @@ -0,0 +1,22 @@ +export enum Type { + UNKNOWN = -1, + NORMAL = 0, + FIGHTING, + FLYING, + POISON, + GROUND, + ROCK, + BUG, + GHOST, + STEEL, + FIRE, + WATER, + GRASS, + ELECTRIC, + PSYCHIC, + ICE, + DRAGON, + DARK, + FAIRY, + STELLAR +} diff --git a/src/enums/variant-tiers.ts b/src/enums/variant-tiers.ts deleted file mode 100644 index 20a0e8ec4e4..00000000000 --- a/src/enums/variant-tiers.ts +++ /dev/null @@ -1,5 +0,0 @@ -export enum VariantTier { - COMMON, - RARE, - EPIC -} diff --git a/src/events/arena.ts b/src/events/arena.ts index c05e67d353c..b1126e5c03d 100644 --- a/src/events/arena.ts +++ b/src/events/arena.ts @@ -1,7 +1,7 @@ import { ArenaTagSide } from "#app/data/arena-tag"; import { ArenaTagType } from "#enums/arena-tag-type"; import { TerrainType } from "#app/data/terrain"; -import { WeatherType } from "#app/data/weather"; +import { WeatherType } from "#enums/weather-type"; /** Alias for all {@linkcode ArenaEvent} type strings */ export enum ArenaEventType { diff --git a/src/field/anims.ts b/src/field/anims.ts index 52a15aa4f20..dddf38e4a7e 100644 --- a/src/field/anims.ts +++ b/src/field/anims.ts @@ -1,24 +1,24 @@ import BattleScene from "../battle-scene"; -import { PokeballType } from "../data/pokeball"; +import { PokeballType } from "#enums/pokeball"; import * as Utils from "../utils"; export function addPokeballOpenParticles(scene: BattleScene, x: number, y: number, pokeballType: PokeballType): void { switch (pokeballType) { - case PokeballType.POKEBALL: - doDefaultPbOpenParticles(scene, x, y, 48); - break; - case PokeballType.GREAT_BALL: - doDefaultPbOpenParticles(scene, x, y, 96); - break; - case PokeballType.ULTRA_BALL: - doUbOpenParticles(scene, x, y, 8); - break; - case PokeballType.ROGUE_BALL: - doUbOpenParticles(scene, x, y, 10); - break; - case PokeballType.MASTER_BALL: - doMbOpenParticles(scene, x, y); - break; + case PokeballType.POKEBALL: + doDefaultPbOpenParticles(scene, x, y, 48); + break; + case PokeballType.GREAT_BALL: + doDefaultPbOpenParticles(scene, x, y, 96); + break; + case PokeballType.ULTRA_BALL: + doUbOpenParticles(scene, x, y, 8); + break; + case PokeballType.ROGUE_BALL: + doUbOpenParticles(scene, x, y, 10); + break; + case PokeballType.MASTER_BALL: + doMbOpenParticles(scene, x, y); + break; } } diff --git a/src/field/arena.ts b/src/field/arena.ts index bf4075e5c1c..da74063ac06 100644 --- a/src/field/arena.ts +++ b/src/field/arena.ts @@ -1,29 +1,37 @@ -import BattleScene from "../battle-scene"; -import { BiomePoolTier, PokemonPools, BiomeTierTrainerPools, biomePokemonPools, biomeTrainerPools } from "../data/biomes"; +import BattleScene from "#app/battle-scene"; +import { biomePokemonPools, BiomePoolTier, BiomeTierTrainerPools, biomeTrainerPools, PokemonPools } from "#app/data/balance/biomes"; import { Constructor } from "#app/utils"; -import * as Utils from "../utils"; -import PokemonSpecies, { getPokemonSpecies } from "../data/pokemon-species"; -import { Weather, WeatherType, getTerrainClearMessage, getTerrainStartMessage, getWeatherClearMessage, getWeatherStartMessage } from "../data/weather"; -import { CommonAnim } from "../data/battle-anims"; -import { Type } from "../data/type"; -import Move from "../data/move"; -import { ArenaTag, ArenaTagSide, ArenaTrapTag, getArenaTag } from "../data/arena-tag"; -import { BattlerIndex } from "../battle"; -import { Terrain, TerrainType } from "../data/terrain"; -import { PostTerrainChangeAbAttr, PostWeatherChangeAbAttr, applyPostTerrainChangeAbAttrs, applyPostWeatherChangeAbAttrs } from "../data/ability"; -import Pokemon from "./pokemon"; +import * as Utils from "#app/utils"; +import PokemonSpecies, { getPokemonSpecies } from "#app/data/pokemon-species"; +import { getTerrainClearMessage, getTerrainStartMessage, getWeatherClearMessage, getWeatherStartMessage, Weather } from "#app/data/weather"; +import { CommonAnim } from "#app/data/battle-anims"; +import { Type } from "#enums/type"; +import Move from "#app/data/move"; +import { ArenaTag, ArenaTagSide, ArenaTrapTag, getArenaTag } from "#app/data/arena-tag"; +import { BattlerIndex } from "#app/battle"; +import { Terrain, TerrainType } from "#app/data/terrain"; +import { + applyAbAttrs, + applyPostTerrainChangeAbAttrs, + applyPostWeatherChangeAbAttrs, + PostTerrainChangeAbAttr, + PostWeatherChangeAbAttr, + TerrainEventTypeChangeAbAttr +} from "#app/data/ability"; +import Pokemon from "#app/field/pokemon"; import Overrides from "#app/overrides"; -import { WeatherChangedEvent, TerrainChangedEvent, TagAddedEvent, TagRemovedEvent } from "../events/arena"; +import { TagAddedEvent, TagRemovedEvent, TerrainChangedEvent, WeatherChangedEvent } from "#app/events/arena"; import { ArenaTagType } from "#enums/arena-tag-type"; import { Biome } from "#enums/biome"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; import { TimeOfDay } from "#enums/time-of-day"; import { TrainerType } from "#enums/trainer-type"; -import { Abilities } from "#app/enums/abilities"; +import { Abilities } from "#enums/abilities"; import { SpeciesFormChangeRevertWeatherFormTrigger, SpeciesFormChangeWeatherTrigger } from "#app/data/pokemon-forms"; import { CommonAnimPhase } from "#app/phases/common-anim-phase"; import { ShowAbilityPhase } from "#app/phases/show-ability-phase"; +import { WeatherType } from "#enums/weather-type"; export class Arena { public scene: BattleScene; @@ -33,6 +41,7 @@ export class Arena { public tags: ArenaTag[]; public bgm: string; public ignoreAbilities: boolean; + public ignoringEffectSource: BattlerIndex | null; private lastTimeOfDay: TimeOfDay; @@ -128,18 +137,18 @@ export class Arena { if (ret.subLegendary || ret.legendary || ret.mythical) { switch (true) { - case (ret.baseTotal >= 720): - regen = level < 90; - break; - case (ret.baseTotal >= 670): - regen = level < 70; - break; - case (ret.baseTotal >= 580): - regen = level < 50; - break; - default: - regen = level < 30; - break; + case (ret.baseTotal >= 720): + regen = level < 90; + break; + case (ret.baseTotal >= 670): + regen = level < 70; + break; + case (ret.baseTotal >= 580): + regen = level < 50; + break; + default: + regen = level < 30; + break; } } } @@ -176,112 +185,52 @@ export class Arena { getSpeciesFormIndex(species: PokemonSpecies): integer { switch (species.speciesId) { - case Species.BURMY: - case Species.WORMADAM: - switch (this.biomeType) { - case Biome.BEACH: - return 1; - case Biome.SLUM: - return 2; - } - break; - case Species.ROTOM: - switch (this.biomeType) { - case Biome.VOLCANO: - return 1; - case Biome.SEA: - return 2; - case Biome.ICE_CAVE: - return 3; - case Biome.MOUNTAIN: - return 4; - case Biome.TALL_GRASS: - return 5; - } - break; - case Species.LYCANROC: - const timeOfDay = this.getTimeOfDay(); - switch (timeOfDay) { - case TimeOfDay.DAY: - case TimeOfDay.DAWN: - return 0; - case TimeOfDay.DUSK: - return 2; - case TimeOfDay.NIGHT: - return 1; - } - break; + case Species.BURMY: + case Species.WORMADAM: + switch (this.biomeType) { + case Biome.BEACH: + return 1; + case Biome.SLUM: + return 2; + } + break; + case Species.ROTOM: + switch (this.biomeType) { + case Biome.VOLCANO: + return 1; + case Biome.SEA: + return 2; + case Biome.ICE_CAVE: + return 3; + case Biome.MOUNTAIN: + return 4; + case Biome.TALL_GRASS: + return 5; + } + break; + case Species.LYCANROC: + const timeOfDay = this.getTimeOfDay(); + switch (timeOfDay) { + case TimeOfDay.DAY: + case TimeOfDay.DAWN: + return 0; + case TimeOfDay.DUSK: + return 2; + case TimeOfDay.NIGHT: + return 1; + } + break; } return 0; } - getTypeForBiome() { - switch (this.biomeType) { - case Biome.TOWN: - case Biome.PLAINS: - case Biome.METROPOLIS: - return Type.NORMAL; - case Biome.GRASS: - case Biome.TALL_GRASS: - return Type.GRASS; - case Biome.FOREST: - case Biome.JUNGLE: - return Type.BUG; - case Biome.SLUM: - case Biome.SWAMP: - return Type.POISON; - case Biome.SEA: - case Biome.BEACH: - case Biome.LAKE: - case Biome.SEABED: - return Type.WATER; - case Biome.MOUNTAIN: - return Type.FLYING; - case Biome.BADLANDS: - return Type.GROUND; - case Biome.CAVE: - case Biome.DESERT: - return Type.ROCK; - case Biome.ICE_CAVE: - case Biome.SNOWY_FOREST: - return Type.ICE; - case Biome.MEADOW: - case Biome.FAIRY_CAVE: - case Biome.ISLAND: - return Type.FAIRY; - case Biome.POWER_PLANT: - return Type.ELECTRIC; - case Biome.VOLCANO: - return Type.FIRE; - case Biome.GRAVEYARD: - case Biome.TEMPLE: - return Type.GHOST; - case Biome.DOJO: - case Biome.CONSTRUCTION_SITE: - return Type.FIGHTING; - case Biome.FACTORY: - case Biome.LABORATORY: - return Type.STEEL; - case Biome.RUINS: - case Biome.SPACE: - return Type.PSYCHIC; - case Biome.WASTELAND: - case Biome.END: - return Type.DRAGON; - case Biome.ABYSS: - return Type.DARK; - default: - return Type.UNKNOWN; - } - } - getBgTerrainColorRatioForBiome(): number { switch (this.biomeType) { - case Biome.SPACE: - return 1; - case Biome.END: - return 0; + case Biome.SPACE: + return 1; + case Biome.END: + return 0; } return 131 / 180; @@ -386,21 +335,22 @@ export class Arena { this.scene.getField(true).filter(p => p.isOnField()).map(pokemon => { pokemon.findAndRemoveTags(t => "terrainTypes" in t && !(t.terrainTypes as TerrainType[]).find(t => t === terrain)); applyPostTerrainChangeAbAttrs(PostTerrainChangeAbAttr, pokemon, terrain); + applyAbAttrs(TerrainEventTypeChangeAbAttr, pokemon, null, false); }); return true; } - isMoveWeatherCancelled(user: Pokemon, move: Move) { - return this.weather && !this.weather.isEffectSuppressed(this.scene) && this.weather.isMoveWeatherCancelled(user, move); + public isMoveWeatherCancelled(user: Pokemon, move: Move): boolean { + return !!this.weather && !this.weather.isEffectSuppressed(this.scene) && this.weather.isMoveWeatherCancelled(user, move); } - isMoveTerrainCancelled(user: Pokemon, targets: BattlerIndex[], move: Move) { - return this.terrain && this.terrain.isMoveTerrainCancelled(user, targets, move); + public isMoveTerrainCancelled(user: Pokemon, targets: BattlerIndex[], move: Move): boolean { + return !!this.terrain && this.terrain.isMoveTerrainCancelled(user, targets, move); } - getTerrainType() : TerrainType { - return this.terrain?.terrainType || TerrainType.NONE; + public getTerrainType(): TerrainType { + return this.terrain?.terrainType ?? TerrainType.NONE; } getAttackTypeMultiplier(attackType: Type, grounded: boolean): number { @@ -423,52 +373,52 @@ export class Arena { */ getTrainerChance(): integer { switch (this.biomeType) { - case Biome.METROPOLIS: - return 2; - case Biome.SLUM: - case Biome.BEACH: - case Biome.DOJO: - case Biome.CONSTRUCTION_SITE: - return 4; - case Biome.PLAINS: - case Biome.GRASS: - case Biome.LAKE: - case Biome.CAVE: - return 6; - case Biome.TALL_GRASS: - case Biome.FOREST: - case Biome.SEA: - case Biome.SWAMP: - case Biome.MOUNTAIN: - case Biome.BADLANDS: - case Biome.DESERT: - case Biome.MEADOW: - case Biome.POWER_PLANT: - case Biome.GRAVEYARD: - case Biome.FACTORY: - case Biome.SNOWY_FOREST: - return 8; - case Biome.ICE_CAVE: - case Biome.VOLCANO: - case Biome.RUINS: - case Biome.WASTELAND: - case Biome.JUNGLE: - case Biome.FAIRY_CAVE: - return 12; - case Biome.SEABED: - case Biome.ABYSS: - case Biome.SPACE: - case Biome.TEMPLE: - return 16; - default: - return 0; + case Biome.METROPOLIS: + return 2; + case Biome.SLUM: + case Biome.BEACH: + case Biome.DOJO: + case Biome.CONSTRUCTION_SITE: + return 4; + case Biome.PLAINS: + case Biome.GRASS: + case Biome.LAKE: + case Biome.CAVE: + return 6; + case Biome.TALL_GRASS: + case Biome.FOREST: + case Biome.SEA: + case Biome.SWAMP: + case Biome.MOUNTAIN: + case Biome.BADLANDS: + case Biome.DESERT: + case Biome.MEADOW: + case Biome.POWER_PLANT: + case Biome.GRAVEYARD: + case Biome.FACTORY: + case Biome.SNOWY_FOREST: + return 8; + case Biome.ICE_CAVE: + case Biome.VOLCANO: + case Biome.RUINS: + case Biome.WASTELAND: + case Biome.JUNGLE: + case Biome.FAIRY_CAVE: + return 12; + case Biome.SEABED: + case Biome.ABYSS: + case Biome.SPACE: + case Biome.TEMPLE: + return 16; + default: + return 0; } } getTimeOfDay(): TimeOfDay { switch (this.biomeType) { - case Biome.ABYSS: - return TimeOfDay.NIGHT; + case Biome.ABYSS: + return TimeOfDay.NIGHT; } const waveCycle = ((this.scene.currentBattle?.waveIndex || 0) + this.scene.waveCycleOffset) % 40; @@ -490,35 +440,35 @@ export class Arena { isOutside(): boolean { switch (this.biomeType) { - case Biome.SEABED: - case Biome.CAVE: - case Biome.ICE_CAVE: - case Biome.POWER_PLANT: - case Biome.DOJO: - case Biome.FACTORY: - case Biome.ABYSS: - case Biome.FAIRY_CAVE: - case Biome.TEMPLE: - case Biome.LABORATORY: - return false; - default: - return true; + case Biome.SEABED: + case Biome.CAVE: + case Biome.ICE_CAVE: + case Biome.POWER_PLANT: + case Biome.DOJO: + case Biome.FACTORY: + case Biome.ABYSS: + case Biome.FAIRY_CAVE: + case Biome.TEMPLE: + case Biome.LABORATORY: + return false; + default: + return true; } } overrideTint(): [integer, integer, integer] { switch (Overrides.ARENA_TINT_OVERRIDE) { - case TimeOfDay.DUSK: - return [ 98, 48, 73 ].map(c => Math.round((c + 128) / 2)) as [integer, integer, integer]; - break; - case (TimeOfDay.NIGHT): - return [ 64, 64, 64 ]; - break; - case TimeOfDay.DAWN: - case TimeOfDay.DAY: - default: - return [ 128, 128, 128 ]; - break; + case TimeOfDay.DUSK: + return [ 98, 48, 73 ].map(c => Math.round((c + 128) / 2)) as [integer, integer, integer]; + break; + case (TimeOfDay.NIGHT): + return [ 64, 64, 64 ]; + break; + case TimeOfDay.DAWN: + case TimeOfDay.DAY: + default: + return [ 128, 128, 128 ]; + break; } } @@ -527,10 +477,10 @@ export class Arena { return this.overrideTint(); } switch (this.biomeType) { - case Biome.ABYSS: - return [ 64, 64, 64 ]; - default: - return [ 128, 128, 128 ]; + case Biome.ABYSS: + return [ 64, 64, 64 ]; + default: + return [ 128, 128, 128 ]; } } @@ -543,8 +493,8 @@ export class Arena { } switch (this.biomeType) { - default: - return [ 98, 48, 73 ].map(c => Math.round((c + 128) / 2)) as [integer, integer, integer]; + default: + return [ 98, 48, 73 ].map(c => Math.round((c + 128) / 2)) as [integer, integer, integer]; } } @@ -553,10 +503,10 @@ export class Arena { return this.overrideTint(); } switch (this.biomeType) { - case Biome.ABYSS: - case Biome.SPACE: - case Biome.END: - return this.getDayTint(); + case Biome.ABYSS: + case Biome.SPACE: + case Biome.END: + return this.getDayTint(); } if (!this.isOutside()) { @@ -564,39 +514,42 @@ export class Arena { } switch (this.biomeType) { - default: - return [ 48, 48, 98 ]; + default: + return [ 48, 48, 98 ]; } } - setIgnoreAbilities(ignoreAbilities: boolean = true): void { + setIgnoreAbilities(ignoreAbilities: boolean, ignoringEffectSource: BattlerIndex | null = null): void { this.ignoreAbilities = ignoreAbilities; + this.ignoringEffectSource = ignoreAbilities ? ignoringEffectSource : null; } /** * Applies each `ArenaTag` in this Arena, based on which side (self, enemy, or both) is passed in as a parameter * @param tagType Either an {@linkcode ArenaTagType} string, or an actual {@linkcode ArenaTag} class to filter which ones to apply * @param side {@linkcode ArenaTagSide} which side's arena tags to apply + * @param simulated if `true`, this applies arena tags without changing game state * @param args array of parameters that the called upon tags may need */ - applyTagsForSide(tagType: ArenaTagType | Constructor, side: ArenaTagSide, ...args: unknown[]): void { + applyTagsForSide(tagType: ArenaTagType | Constructor, side: ArenaTagSide, simulated: boolean, ...args: unknown[]): void { let tags = typeof tagType === "string" ? this.tags.filter(t => t.tagType === tagType) : this.tags.filter(t => t instanceof tagType); if (side !== ArenaTagSide.BOTH) { tags = tags.filter(t => t.side === side); } - tags.forEach(t => t.apply(this, args)); + tags.forEach(t => t.apply(this, simulated, ...args)); } /** * Applies the specified tag to both sides (ie: both user and trainer's tag that match the Tag specified) * by calling {@linkcode applyTagsForSide()} * @param tagType Either an {@linkcode ArenaTagType} string, or an actual {@linkcode ArenaTag} class to filter which ones to apply + * @param simulated if `true`, this applies arena tags without changing game state * @param args array of parameters that the called upon tags may need */ - applyTags(tagType: ArenaTagType | Constructor, ...args: unknown[]): void { - this.applyTagsForSide(tagType, ArenaTagSide.BOTH, ...args); + applyTags(tagType: ArenaTagType | Constructor, simulated: boolean, ...args: unknown[]): void { + this.applyTagsForSide(tagType, ArenaTagSide.BOTH, simulated, ...args); } /** @@ -743,77 +696,77 @@ export class Arena { getBgmLoopPoint(): number { switch (this.biomeType) { - case Biome.TOWN: - return 7.288; - case Biome.PLAINS: - return 17.485; - case Biome.GRASS: - return 1.995; - case Biome.TALL_GRASS: - return 9.608; - case Biome.METROPOLIS: - return 141.470; - case Biome.FOREST: - return 4.294; - case Biome.SEA: - return 0.024; - case Biome.SWAMP: - return 4.461; - case Biome.BEACH: - return 3.462; - case Biome.LAKE: - return 5.350; - case Biome.SEABED: - return 2.600; - case Biome.MOUNTAIN: - return 4.018; - case Biome.BADLANDS: - return 17.790; - case Biome.CAVE: - return 14.240; - case Biome.DESERT: - return 1.143; - case Biome.ICE_CAVE: - return 0.000; - case Biome.MEADOW: - return 3.891; - case Biome.POWER_PLANT: - return 9.447; - case Biome.VOLCANO: - return 17.637; - case Biome.GRAVEYARD: - return 3.232; - case Biome.DOJO: - return 6.205; - case Biome.FACTORY: - return 4.985; - case Biome.RUINS: - return 2.270; - case Biome.WASTELAND: - return 6.336; - case Biome.ABYSS: - return 5.130; - case Biome.SPACE: - return 20.036; - case Biome.CONSTRUCTION_SITE: - return 1.222; - case Biome.JUNGLE: - return 0.000; - case Biome.FAIRY_CAVE: - return 4.542; - case Biome.TEMPLE: - return 2.547; - case Biome.ISLAND: - return 2.751; - case Biome.LABORATORY: - return 114.862; - case Biome.SLUM: - return 0.000; - case Biome.SNOWY_FOREST: - return 3.047; - default: - console.warn(`missing bgm loop-point for biome "${Biome[this.biomeType]}" (=${this.biomeType})`); - return 0; + case Biome.TOWN: + return 7.288; + case Biome.PLAINS: + return 17.485; + case Biome.GRASS: + return 1.995; + case Biome.TALL_GRASS: + return 9.608; + case Biome.METROPOLIS: + return 141.470; + case Biome.FOREST: + return 4.294; + case Biome.SEA: + return 0.024; + case Biome.SWAMP: + return 4.461; + case Biome.BEACH: + return 3.462; + case Biome.LAKE: + return 7.215; + case Biome.SEABED: + return 2.600; + case Biome.MOUNTAIN: + return 4.018; + case Biome.BADLANDS: + return 17.790; + case Biome.CAVE: + return 14.240; + case Biome.DESERT: + return 1.143; + case Biome.ICE_CAVE: + return 0.000; + case Biome.MEADOW: + return 3.891; + case Biome.POWER_PLANT: + return 9.447; + case Biome.VOLCANO: + return 17.637; + case Biome.GRAVEYARD: + return 13.711; + case Biome.DOJO: + return 6.205; + case Biome.FACTORY: + return 4.985; + case Biome.RUINS: + return 0.000; + case Biome.WASTELAND: + return 6.336; + case Biome.ABYSS: + return 5.130; + case Biome.SPACE: + return 20.036; + case Biome.CONSTRUCTION_SITE: + return 1.222; + case Biome.JUNGLE: + return 0.000; + case Biome.FAIRY_CAVE: + return 4.542; + case Biome.TEMPLE: + return 2.547; + case Biome.ISLAND: + return 2.751; + case Biome.LABORATORY: + return 114.862; + case Biome.SLUM: + return 0.000; + case Biome.SNOWY_FOREST: + return 3.047; + default: + console.warn(`missing bgm loop-point for biome "${Biome[this.biomeType]}" (=${this.biomeType})`); + return 0; } } } @@ -824,32 +777,32 @@ export function getBiomeKey(biome: Biome): string { export function getBiomeHasProps(biomeType: Biome): boolean { switch (biomeType) { - case Biome.METROPOLIS: - case Biome.BEACH: - case Biome.LAKE: - case Biome.SEABED: - case Biome.MOUNTAIN: - case Biome.BADLANDS: - case Biome.CAVE: - case Biome.DESERT: - case Biome.ICE_CAVE: - case Biome.MEADOW: - case Biome.POWER_PLANT: - case Biome.VOLCANO: - case Biome.GRAVEYARD: - case Biome.FACTORY: - case Biome.RUINS: - case Biome.WASTELAND: - case Biome.ABYSS: - case Biome.CONSTRUCTION_SITE: - case Biome.JUNGLE: - case Biome.FAIRY_CAVE: - case Biome.TEMPLE: - case Biome.SNOWY_FOREST: - case Biome.ISLAND: - case Biome.LABORATORY: - case Biome.END: - return true; + case Biome.METROPOLIS: + case Biome.BEACH: + case Biome.LAKE: + case Biome.SEABED: + case Biome.MOUNTAIN: + case Biome.BADLANDS: + case Biome.CAVE: + case Biome.DESERT: + case Biome.ICE_CAVE: + case Biome.MEADOW: + case Biome.POWER_PLANT: + case Biome.VOLCANO: + case Biome.GRAVEYARD: + case Biome.FACTORY: + case Biome.RUINS: + case Biome.WASTELAND: + case Biome.ABYSS: + case Biome.CONSTRUCTION_SITE: + case Biome.JUNGLE: + case Biome.FAIRY_CAVE: + case Biome.TEMPLE: + case Biome.SNOWY_FOREST: + case Biome.ISLAND: + case Biome.LABORATORY: + case Biome.END: + return true; } return false; diff --git a/src/field/damage-number-handler.ts b/src/field/damage-number-handler.ts index ae0692da342..4ddcd2d3ee7 100644 --- a/src/field/damage-number-handler.ts +++ b/src/field/damage-number-handler.ts @@ -29,21 +29,21 @@ export default class DamageNumberHandler { let [ textColor, shadowColor ] : TextAndShadowArr = [ null, null ]; switch (result) { - case HitResult.SUPER_EFFECTIVE: - [ textColor, shadowColor ] = [ "#f8d030", "#b8a038" ]; - break; - case HitResult.NOT_VERY_EFFECTIVE: - [ textColor, shadowColor ] = [ "#f08030", "#c03028" ]; - break; - case HitResult.ONE_HIT_KO: - [ textColor, shadowColor ] = [ "#a040a0", "#483850" ]; - break; - case HitResult.HEAL: - [ textColor, shadowColor ] = [ "#78c850", "#588040" ]; - break; - default: - [ textColor, shadowColor ] = [ "#ffffff", "#636363" ]; - break; + case HitResult.SUPER_EFFECTIVE: + [ textColor, shadowColor ] = [ "#f8d030", "#b8a038" ]; + break; + case HitResult.NOT_VERY_EFFECTIVE: + [ textColor, shadowColor ] = [ "#f08030", "#c03028" ]; + break; + case HitResult.ONE_HIT_KO: + [ textColor, shadowColor ] = [ "#a040a0", "#483850" ]; + break; + case HitResult.HEAL: + [ textColor, shadowColor ] = [ "#78c850", "#588040" ]; + break; + default: + [ textColor, shadowColor ] = [ "#ffffff", "#636363" ]; + break; } if (textColor) { diff --git a/src/field/mystery-encounter-intro.ts b/src/field/mystery-encounter-intro.ts index 7c58a494699..1577d1157d7 100644 --- a/src/field/mystery-encounter-intro.ts +++ b/src/field/mystery-encounter-intro.ts @@ -86,7 +86,7 @@ export default class MysteryEncounterIntroVisuals extends Phaser.GameObjects.Con }; if (!isNullOrUndefined(result.species)) { - const keys = getSpriteKeysFromSpecies(result.species!); + const keys = getSpriteKeysFromSpecies(result.species); result.spriteKey = keys.spriteKey; result.fileRoot = keys.fileRoot; result.isPokemon = true; @@ -101,14 +101,14 @@ export default class MysteryEncounterIntroVisuals extends Phaser.GameObjects.Con const getSprite = (spriteKey: string, hasShadow?: boolean, yShadow?: number) => { const ret = this.scene.addFieldSprite(0, 0, spriteKey); ret.setOrigin(0.5, 1); - ret.setPipeline(this.scene.spritePipeline, { tone: [0.0, 0.0, 0.0, 0.0], hasShadow: !!hasShadow, yShadowOffset: yShadow ?? 0 }); + ret.setPipeline(this.scene.spritePipeline, { tone: [ 0.0, 0.0, 0.0, 0.0 ], hasShadow: !!hasShadow, yShadowOffset: yShadow ?? 0 }); return ret; }; const getItemSprite = (spriteKey: string, hasShadow?: boolean, yShadow?: number) => { const icon = this.scene.add.sprite(-19, 2, "items", spriteKey); icon.setOrigin(0.5, 1); - icon.setPipeline(this.scene.spritePipeline, { tone: [0.0, 0.0, 0.0, 0.0], hasShadow: !!hasShadow, yShadowOffset: yShadow ?? 0 }); + icon.setPipeline(this.scene.spritePipeline, { tone: [ 0.0, 0.0, 0.0, 0.0 ], hasShadow: !!hasShadow, yShadowOffset: yShadow ?? 0 }); return icon; }; @@ -212,7 +212,7 @@ export default class MysteryEncounterIntroVisuals extends Phaser.GameObjects.Con this.scene.anims.create({ key: config.spriteKey, frames: frameNames, - frameRate: 12, + frameRate: 10, repeat: -1 }); } diff --git a/src/field/pokemon-sprite-sparkle-handler.ts b/src/field/pokemon-sprite-sparkle-handler.ts index ccf6a098667..2c4c295eaa4 100644 --- a/src/field/pokemon-sprite-sparkle-handler.ts +++ b/src/field/pokemon-sprite-sparkle-handler.ts @@ -36,7 +36,7 @@ export default class PokemonSpriteSparkleHandler { const ratioY = s.height / height; const pixel = texture.manager.getPixel(pixelX, pixelY, texture.key, "__BASE"); if (pixel?.alpha) { - const [ xOffset, yOffset ] = [ -s.originX * s.width, -s.originY * s.height]; + const [ xOffset, yOffset ] = [ -s.originX * s.width, -s.originY * s.height ]; const sparkle = (s.scene as BattleScene).addFieldSprite(((pokemon?.x || 0) + s.x + pixelX * ratioX + xOffset), ((pokemon?.y || 0) + s.y + pixelY * ratioY + yOffset), "tera_sparkle"); sparkle.pipelineData["ignoreTimeTint"] = s.pipelineData["ignoreTimeTint"]; sparkle.setName("sprite-tera-sparkle"); diff --git a/src/field/pokemon.ts b/src/field/pokemon.ts index cdafc960382..1dc4972af79 100644 --- a/src/field/pokemon.ts +++ b/src/field/pokemon.ts @@ -1,43 +1,46 @@ import Phaser from "phaser"; -import BattleScene, { AnySound } from "../battle-scene"; +import BattleScene, { AnySound } from "#app/battle-scene"; import { Variant, VariantSet, variantColorCache } from "#app/data/variant"; import { variantData } from "#app/data/variant"; -import BattleInfo, { PlayerBattleInfo, EnemyBattleInfo } from "../ui/battle-info"; -import Move, { HighCritAttr, DealsDoubleDamageToTagAttr, applyMoveAttrs, FixedDamageAttr, VariableAtkAttr, allMoves, MoveCategory, TypelessAttr, CritOnlyAttr, getMoveTargets, OneHitKOAttr, VariableMoveTypeAttr, VariableDefAttr, AttackMove, ModifiedDamageAttr, VariableMoveTypeMultiplierAttr, IgnoreOpponentStatStagesAttr, SacrificialAttr, VariableMoveCategoryAttr, CounterDamageAttr, StatStageChangeAttr, RechargeAttr, ChargeAttr, IgnoreWeatherTypeDebuffAttr, BypassBurnDamageReductionAttr, SacrificialAttrOnHit, OneHitKOAccuracyAttr, RespectAttackTypeImmunityAttr, MoveTarget } from "../data/move"; -import { default as PokemonSpecies, PokemonSpeciesForm, SpeciesFormKey, getFusedSpeciesName, getPokemonSpecies, getPokemonSpeciesForm, getStarterValueFriendshipCap, speciesStarters, starterPassiveAbilities } from "../data/pokemon-species"; -import { Constructor, isNullOrUndefined, randSeedInt } from "#app/utils"; -import * as Utils from "../utils"; -import { Type, TypeDamageMultiplier, getTypeDamageMultiplier, getTypeRgb } from "../data/type"; -import { getLevelTotalExp } from "../data/exp"; +import BattleInfo, { PlayerBattleInfo, EnemyBattleInfo } from "#app/ui/battle-info"; +import Move, { HighCritAttr, HitsTagAttr, applyMoveAttrs, FixedDamageAttr, VariableAtkAttr, allMoves, MoveCategory, TypelessAttr, CritOnlyAttr, getMoveTargets, OneHitKOAttr, VariableMoveTypeAttr, VariableDefAttr, AttackMove, ModifiedDamageAttr, VariableMoveTypeMultiplierAttr, IgnoreOpponentStatStagesAttr, SacrificialAttr, VariableMoveCategoryAttr, CounterDamageAttr, StatStageChangeAttr, RechargeAttr, IgnoreWeatherTypeDebuffAttr, BypassBurnDamageReductionAttr, SacrificialAttrOnHit, OneHitKOAccuracyAttr, RespectAttackTypeImmunityAttr, MoveTarget, CombinedPledgeStabBoostAttr, VariableMoveTypeChartAttr } from "#app/data/move"; +import { default as PokemonSpecies, PokemonSpeciesForm, getFusedSpeciesName, getPokemonSpecies, getPokemonSpeciesForm } from "#app/data/pokemon-species"; +import { CLASSIC_CANDY_FRIENDSHIP_MULTIPLIER, getStarterValueFriendshipCap, speciesStarterCosts } from "#app/data/balance/starters"; +import { starterPassiveAbilities } from "#app/data/balance/passives"; +import { Constructor, isNullOrUndefined, randSeedInt, type nil } from "#app/utils"; +import * as Utils from "#app/utils"; +import { TypeDamageMultiplier, getTypeDamageMultiplier, getTypeRgb } from "#app/data/type"; +import { Type } from "#enums/type"; +import { getLevelTotalExp } from "#app/data/exp"; import { Stat, type PermanentStat, type BattleStat, type EffectiveStat, PERMANENT_STATS, BATTLE_STATS, EFFECTIVE_STATS } from "#enums/stat"; -import { DamageMoneyRewardModifier, EnemyDamageBoosterModifier, EnemyDamageReducerModifier, EnemyEndureChanceModifier, EnemyFusionChanceModifier, HiddenAbilityRateBoosterModifier, BaseStatModifier, PokemonFriendshipBoosterModifier, PokemonHeldItemModifier, PokemonNatureWeightModifier, ShinyRateBoosterModifier, SurviveDamageModifier, TempStatStageBoosterModifier, TempCritBoosterModifier, StatBoosterModifier, CritBoosterModifier, TerastallizeModifier, PokemonBaseStatFlatModifier, PokemonBaseStatTotalModifier, PokemonIncrementingStatModifier, EvoTrackerModifier } from "../modifier/modifier"; -import { PokeballType } from "../data/pokeball"; -import { Gender } from "../data/gender"; -import { initMoveAnim, loadMoveAnimAssets } from "../data/battle-anims"; -import { Status, StatusEffect, getRandomStatus } from "../data/status-effect"; -import { pokemonEvolutions, pokemonPrevolutions, SpeciesFormEvolution, SpeciesEvolutionCondition, FusionSpeciesFormEvolution } from "../data/pokemon-evolutions"; -import { reverseCompatibleTms, tmSpecies, tmPoolTiers } from "../data/tms"; -import { BattlerTag, BattlerTagLapseType, EncoreTag, GroundedTag, HighestStatBoostTag, SubstituteTag, TypeImmuneTag, getBattlerTag, SemiInvulnerableTag, TypeBoostTag, MoveRestrictionBattlerTag, ExposedTag, DragonCheerTag, CritBoostTag, TrappedTag, TarShotTag } from "../data/battler-tags"; -import { WeatherType } from "../data/weather"; -import { ArenaTagSide, NoCritTag, WeakenMoveScreenTag } from "../data/arena-tag"; -import { Ability, AbAttr, StatMultiplierAbAttr, BlockCritAbAttr, BonusCritAbAttr, BypassBurnDamageReductionAbAttr, FieldPriorityMoveImmunityAbAttr, IgnoreOpponentStatStagesAbAttr, MoveImmunityAbAttr, PreDefendFullHpEndureAbAttr, ReceivedMoveDamageMultiplierAbAttr, ReduceStatusEffectDurationAbAttr, StabBoostAbAttr, StatusEffectImmunityAbAttr, TypeImmunityAbAttr, WeightMultiplierAbAttr, allAbilities, applyAbAttrs, applyStatMultiplierAbAttrs, applyPreApplyBattlerTagAbAttrs, applyPreAttackAbAttrs, applyPreDefendAbAttrs, applyPreSetStatusAbAttrs, UnsuppressableAbilityAbAttr, SuppressFieldAbilitiesAbAttr, NoFusionAbilityAbAttr, MultCritAbAttr, IgnoreTypeImmunityAbAttr, DamageBoostAbAttr, IgnoreTypeStatusEffectImmunityAbAttr, ConditionalCritAbAttr, applyFieldStatMultiplierAbAttrs, FieldMultiplyStatAbAttr, AddSecondStrikeAbAttr, UserFieldStatusEffectImmunityAbAttr, UserFieldBattlerTagImmunityAbAttr, BattlerTagImmunityAbAttr, MoveTypeChangeAbAttr, FullHpResistTypeAbAttr, applyCheckTrappedAbAttrs, CheckTrappedAbAttr } from "../data/ability"; -import PokemonData from "../system/pokemon-data"; -import { BattlerIndex } from "../battle"; -import { Mode } from "../ui/ui"; -import PartyUiHandler, { PartyOption, PartyUiMode } from "../ui/party-ui-handler"; +import { DamageMoneyRewardModifier, EnemyDamageBoosterModifier, EnemyDamageReducerModifier, EnemyEndureChanceModifier, EnemyFusionChanceModifier, HiddenAbilityRateBoosterModifier, BaseStatModifier, PokemonFriendshipBoosterModifier, PokemonHeldItemModifier, PokemonNatureWeightModifier, ShinyRateBoosterModifier, SurviveDamageModifier, TempStatStageBoosterModifier, TempCritBoosterModifier, StatBoosterModifier, CritBoosterModifier, TerastallizeModifier, PokemonBaseStatFlatModifier, PokemonBaseStatTotalModifier, PokemonIncrementingStatModifier, EvoTrackerModifier, PokemonMultiHitModifier } from "#app/modifier/modifier"; +import { PokeballType } from "#enums/pokeball"; +import { Gender } from "#app/data/gender"; +import { initMoveAnim, loadMoveAnimAssets } from "#app/data/battle-anims"; +import { Status, getRandomStatus } from "#app/data/status-effect"; +import { pokemonEvolutions, pokemonPrevolutions, SpeciesFormEvolution, SpeciesEvolutionCondition, FusionSpeciesFormEvolution } from "#app/data/balance/pokemon-evolutions"; +import { reverseCompatibleTms, tmSpecies, tmPoolTiers } from "#app/data/balance/tms"; +import { BattlerTag, BattlerTagLapseType, EncoreTag, GroundedTag, HighestStatBoostTag, SubstituteTag, TypeImmuneTag, getBattlerTag, SemiInvulnerableTag, TypeBoostTag, MoveRestrictionBattlerTag, ExposedTag, DragonCheerTag, CritBoostTag, TrappedTag, TarShotTag, AutotomizedTag, PowerTrickTag } from "../data/battler-tags"; +import { WeatherType } from "#enums/weather-type"; +import { ArenaTagSide, NoCritTag, WeakenMoveScreenTag } from "#app/data/arena-tag"; +import { Ability, AbAttr, StatMultiplierAbAttr, BlockCritAbAttr, BonusCritAbAttr, BypassBurnDamageReductionAbAttr, FieldPriorityMoveImmunityAbAttr, IgnoreOpponentStatStagesAbAttr, MoveImmunityAbAttr, PreDefendFullHpEndureAbAttr, ReceivedMoveDamageMultiplierAbAttr, StabBoostAbAttr, StatusEffectImmunityAbAttr, TypeImmunityAbAttr, WeightMultiplierAbAttr, allAbilities, applyAbAttrs, applyStatMultiplierAbAttrs, applyPreApplyBattlerTagAbAttrs, applyPreAttackAbAttrs, applyPreDefendAbAttrs, applyPreSetStatusAbAttrs, UnsuppressableAbilityAbAttr, SuppressFieldAbilitiesAbAttr, NoFusionAbilityAbAttr, MultCritAbAttr, IgnoreTypeImmunityAbAttr, DamageBoostAbAttr, IgnoreTypeStatusEffectImmunityAbAttr, ConditionalCritAbAttr, applyFieldStatMultiplierAbAttrs, FieldMultiplyStatAbAttr, AddSecondStrikeAbAttr, UserFieldStatusEffectImmunityAbAttr, UserFieldBattlerTagImmunityAbAttr, BattlerTagImmunityAbAttr, MoveTypeChangeAbAttr, FullHpResistTypeAbAttr, applyCheckTrappedAbAttrs, CheckTrappedAbAttr, PostSetStatusAbAttr, applyPostSetStatusAbAttrs, InfiltratorAbAttr, AlliedFieldDamageReductionAbAttr, PostDamageAbAttr, applyPostDamageAbAttrs, PostDamageForceSwitchAbAttr, CommanderAbAttr, applyPostItemLostAbAttrs, PostItemLostAbAttr } from "#app/data/ability"; +import PokemonData from "#app/system/pokemon-data"; +import { BattlerIndex } from "#app/battle"; +import { Mode } from "#app/ui/ui"; +import PartyUiHandler, { PartyOption, PartyUiMode } from "#app/ui/party-ui-handler"; import SoundFade from "phaser3-rex-plugins/plugins/soundfade"; -import { LevelMoves } from "../data/pokemon-level-moves"; -import { DamageAchv, achvs } from "../system/achv"; -import { DexAttr, StarterDataEntry, StarterMoveset } from "../system/game-data"; +import { LevelMoves } from "#app/data/balance/pokemon-level-moves"; +import { DamageAchv, achvs } from "#app/system/achv"; +import { DexAttr, StarterDataEntry, StarterMoveset } from "#app/system/game-data"; import { QuantizerCelebi, argbFromRgba, rgbaFromArgb } from "@material/material-color-utilities"; -import { Nature, getNatureStatMultiplier } from "../data/nature"; -import { SpeciesFormChange, SpeciesFormChangeActiveTrigger, SpeciesFormChangeMoveLearnedTrigger, SpeciesFormChangePostMoveTrigger, SpeciesFormChangeStatusEffectTrigger } from "../data/pokemon-forms"; -import { TerrainType } from "../data/terrain"; -import { TrainerSlot } from "../data/trainer-config"; +import { getNatureStatMultiplier } from "#app/data/nature"; +import { SpeciesFormChange, SpeciesFormChangeActiveTrigger, SpeciesFormChangeMoveLearnedTrigger, SpeciesFormChangePostMoveTrigger, SpeciesFormChangeStatusEffectTrigger } from "#app/data/pokemon-forms"; +import { TerrainType } from "#app/data/terrain"; +import { TrainerSlot } from "#app/data/trainer-config"; import Overrides from "#app/overrides"; import i18next from "i18next"; -import { speciesEggMoves } from "../data/egg-moves"; -import { ModifierTier } from "../modifier/modifier-tier"; +import { speciesEggMoves } from "#app/data/balance/egg-moves"; +import { ModifierTier } from "#app/modifier/modifier-tier"; import { applyChallenges, ChallengeType } from "#app/data/challenge"; import { Abilities } from "#enums/abilities"; import { ArenaTagType } from "#enums/arena-tag-type"; @@ -58,9 +61,14 @@ import { StatStageChangePhase } from "#app/phases/stat-stage-change-phase"; import { SwitchSummonPhase } from "#app/phases/switch-summon-phase"; import { ToggleDoublePositionPhase } from "#app/phases/toggle-double-position-phase"; import { Challenges } from "#enums/challenges"; -import { PokemonAnimType } from "#app/enums/pokemon-anim-type"; +import { PokemonAnimType } from "#enums/pokemon-anim-type"; import { PLAYER_PARTY_MAX_SIZE } from "#app/constants"; -import { MysteryEncounterPokemonData } from "#app/data/mystery-encounters/mystery-encounter-pokemon-data"; +import { CustomPokemonData } from "#app/data/custom-pokemon-data"; +import { SwitchType } from "#enums/switch-type"; +import { SpeciesFormKey } from "#enums/species-form-key"; +import { BASE_HIDDEN_ABILITY_CHANCE, BASE_SHINY_CHANCE, SHINY_EPIC_CHANCE, SHINY_VARIANT_CHANCE } from "#app/data/balance/rates"; +import { Nature } from "#enums/nature"; +import { StatusEffect } from "#enums/status-effect"; export enum FieldPosition { CENTER, @@ -88,7 +96,6 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { public stats: integer[]; public ivs: integer[]; public nature: Nature; - public natureOverride: Nature | -1; public moveset: (PokemonMove | null)[]; public status: Status | null; public friendship: integer; @@ -99,7 +106,7 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { public luck: integer; public pauseEvolutions: boolean; public pokerus: boolean; - public wildFlee: boolean; + public switchOutStatus: boolean; public evoCounter: integer; public fusionSpecies: PokemonSpecies | null; @@ -109,6 +116,7 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { public fusionVariant: Variant; public fusionGender: Gender; public fusionLuck: integer; + public fusionCustomPokemonData: CustomPokemonData | null; private summonDataPrimer: PokemonSummonData | null; @@ -116,7 +124,7 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { public battleData: PokemonBattleData; public battleSummonData: PokemonBattleSummonData; public turnData: PokemonTurnData; - public mysteryEncounterPokemonData: MysteryEncounterPokemonData; + public customPokemonData: CustomPokemonData; /** Used by Mystery Encounters to execute pokemon-specific logic (such as stat boosts) at start of battle */ public mysteryEncounterBattleEffects?: (pokemon: Pokemon) => void; @@ -137,7 +145,7 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { throw `Cannot create a player Pokemon for species '${species.getName(formIndex)}'`; } - const hiddenAbilityChance = new Utils.IntegerHolder(256); + const hiddenAbilityChance = new Utils.IntegerHolder(BASE_HIDDEN_ABILITY_CHANCE); if (!this.hasTrainer()) { this.scene.applyModifiers(HiddenAbilityRateBoosterModifier, true, hiddenAbilityChance); } @@ -145,7 +153,7 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { this.species = species; this.pokeball = dataSource?.pokeball || PokeballType.POKEBALL; this.level = level; - this.wildFlee = false; + this.switchOutStatus = false; // Determine the ability index if (abilityIndex !== undefined) { @@ -187,7 +195,6 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { } this.nature = dataSource.nature || 0 as Nature; this.nickname = dataSource.nickname; - this.natureOverride = dataSource.natureOverride !== undefined ? dataSource.natureOverride : -1; this.moveset = dataSource.moveset; this.status = dataSource.status!; // TODO: is this bang correct? this.friendship = dataSource.friendship !== undefined ? dataSource.friendship : this.species.baseFriendship; @@ -206,8 +213,9 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { this.fusionVariant = dataSource.fusionVariant || 0; this.fusionGender = dataSource.fusionGender; this.fusionLuck = dataSource.fusionLuck; + this.fusionCustomPokemonData = dataSource.fusionCustomPokemonData; this.usedTMs = dataSource.usedTMs ?? []; - this.mysteryEncounterPokemonData = new MysteryEncounterPokemonData(dataSource.mysteryEncounterPokemonData); + this.customPokemonData = new CustomPokemonData(dataSource.customPokemonData); } else { this.id = Utils.randSeedInt(4294967296); this.ivs = ivs || Utils.getIvsFromId(this.id); @@ -225,10 +233,10 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { } if (this.variant === undefined) { - this.variant = this.shiny ? this.generateVariant() : 0; + this.variant = this.shiny ? this.generateShinyVariant() : 0; } - this.mysteryEncounterPokemonData = new MysteryEncounterPokemonData(); + this.customPokemonData = new CustomPokemonData(); if (nature !== undefined) { this.setNature(nature); @@ -236,8 +244,6 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { this.generateNature(); } - this.natureOverride = -1; - this.friendship = species.baseFriendship; this.metLevel = level; this.metBiome = scene.currentBattle ? scene.arena.biomeType : -1; @@ -322,35 +328,45 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { return this.scene.field.getIndex(this) > -1; } - isFainted(checkStatus?: boolean): boolean { - return !this.hp && (!checkStatus || this.status?.effect === StatusEffect.FAINT); + /** + * Checks if a pokemon is fainted (ie: its `hp <= 0`). + * It's usually better to call {@linkcode isAllowedInBattle()} + * @param checkStatus `true` to also check that the pokemon's status is {@linkcode StatusEffect.FAINT} + * @returns `true` if the pokemon is fainted + */ + public isFainted(checkStatus: boolean = false): boolean { + return this.hp <= 0 && (!checkStatus || this.status?.effect === StatusEffect.FAINT); } /** - * Check if this pokemon is both not fainted (or a fled wild pokemon) and allowed to be in battle. - * This is frequently a better alternative to {@link isFainted} - * @returns {boolean} True if pokemon is allowed in battle + * Check if this pokemon is both not fainted and allowed to be in battle based on currently active challenges. + * @returns {boolean} `true` if pokemon is allowed in battle */ - isAllowedInBattle(): boolean { - return !this.isFainted() && this.isAllowed(); + public isAllowedInBattle(): boolean { + return !this.isFainted() && this.isAllowedInChallenge(); } /** - * Check if this pokemon is allowed (no challenge exclusion) - * This is frequently a better alternative to {@link isFainted} - * @returns {boolean} True if pokemon is allowed in battle + * Check if this pokemon is allowed based on any active challenges. + * It's usually better to call {@linkcode isAllowedInBattle()} + * @returns {boolean} `true` if pokemon is allowed in battle */ - isAllowed(): boolean { + public isAllowedInChallenge(): boolean { const challengeAllowed = new Utils.BooleanHolder(true); applyChallenges(this.scene.gameMode, ChallengeType.POKEMON_IN_BATTLE, this, challengeAllowed); - return !this.wildFlee && challengeAllowed.value; + return challengeAllowed.value; } - isActive(onField?: boolean): boolean { + /** + * Checks if the pokemon is allowed in battle (ie: not fainted, and allowed under any active challenges). + * @param onField `true` to also check if the pokemon is currently on the field, defaults to `false` + * @returns `true` if the pokemon is "active". Returns `false` if there is no active {@linkcode BattleScene} + */ + public isActive(onField: boolean = false): boolean { if (!this.scene) { return false; } - return this.isAllowedInBattle() && !!this.scene && (!onField || this.isOnField()); + return this.isAllowedInBattle() && (!onField || this.isOnField()); } getDexAttr(): bigint { @@ -411,7 +427,7 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { this.scene.anims.create({ key: this.getBattleSpriteKey(), frames: battleFrameNames, - frameRate: 12, + frameRate: 10, repeat: -1 }); } @@ -425,38 +441,26 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { resolve(); }; if (this.shiny) { - const populateVariantColors = (key: string, back: boolean = false): Promise => { - return new Promise(resolve => { - const battleSpritePath = this.getBattleSpriteAtlasPath(back, ignoreOverride).replace("variant/", "").replace(/_[1-3]$/, ""); + const populateVariantColors = (isBackSprite: boolean = false): Promise => { + return new Promise(async resolve => { + const battleSpritePath = this.getBattleSpriteAtlasPath(isBackSprite, ignoreOverride).replace("variant/", "").replace(/_[1-3]$/, ""); let config = variantData; - const useExpSprite = this.scene.experimentalSprites && this.scene.hasExpSprite(this.getBattleSpriteKey(back, ignoreOverride)); + const useExpSprite = this.scene.experimentalSprites && this.scene.hasExpSprite(this.getBattleSpriteKey(isBackSprite, ignoreOverride)); battleSpritePath.split("/").map(p => config ? config = config[p] : null); const variantSet: VariantSet = config as VariantSet; if (variantSet && variantSet[this.variant] === 1) { - if (variantColorCache.hasOwnProperty(key)) { - return resolve(); + const cacheKey = this.getBattleSpriteKey(isBackSprite); + if (!variantColorCache.hasOwnProperty(cacheKey)) { + await this.populateVariantColorCache(cacheKey, useExpSprite, battleSpritePath); } - this.scene.cachedFetch(`./images/pokemon/variant/${useExpSprite ? "exp/" : ""}${battleSpritePath}.json`). - then(res => { - // Prevent the JSON from processing if it failed to load - if (!res.ok) { - console.error(`Could not load ${res.url}!`); - return; - } - return res.json(); - }).then(c => { - variantColorCache[key] = c; - resolve(); - }); - } else { - resolve(); } + resolve(); }); }; if (this.isPlayer()) { - Promise.all([ populateVariantColors(this.getBattleSpriteKey(false)), populateVariantColors(this.getBattleSpriteKey(true), true) ]).then(() => updateFusionPaletteAndResolve()); + Promise.all([ populateVariantColors(false), populateVariantColors(true) ]).then(() => updateFusionPaletteAndResolve()); } else { - populateVariantColors(this.getBattleSpriteKey(false)).then(() => updateFusionPaletteAndResolve()); + populateVariantColors(false).then(() => updateFusionPaletteAndResolve()); } } else { updateFusionPaletteAndResolve(); @@ -469,6 +473,47 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { }); } + /** + * Gracefully handle errors loading a variant sprite. Log if it fails and attempt to fall back on + * non-experimental sprites before giving up. + * + * @param cacheKey the cache key for the variant color sprite + * @param attemptedSpritePath the sprite path that failed to load + * @param useExpSprite was the attempted sprite experimental + * @param battleSpritePath the filename of the sprite + * @param optionalParams any additional params to log + */ + async fallbackVariantColor(cacheKey: string, attemptedSpritePath: string, useExpSprite: boolean, battleSpritePath: string, ...optionalParams: any[]) { + console.warn(`Could not load ${attemptedSpritePath}!`, ...optionalParams); + if (useExpSprite) { + await this.populateVariantColorCache(cacheKey, false, battleSpritePath); + } + } + + /** + * Attempt to process variant sprite. + * + * @param cacheKey the cache key for the variant color sprite + * @param useExpSprite should the experimental sprite be used + * @param battleSpritePath the filename of the sprite + */ + async populateVariantColorCache(cacheKey: string, useExpSprite: boolean, battleSpritePath: string) { + const spritePath = `./images/pokemon/variant/${useExpSprite ? "exp/" : ""}${battleSpritePath}.json`; + return this.scene.cachedFetch(spritePath).then(res => { + // Prevent the JSON from processing if it failed to load + if (!res.ok) { + return this.fallbackVariantColor(cacheKey, res.url, useExpSprite, battleSpritePath, res.status, res.statusText); + } + return res.json(); + }).catch(error => { + return this.fallbackVariantColor(cacheKey, spritePath, useExpSprite, battleSpritePath, error); + }).then(c => { + if (!isNullOrUndefined(c)) { + variantColorCache[cacheKey] = c; + } + }); + } + getFormKey(): string { if (!this.species.forms.length || this.species.forms.length <= this.formIndex) { return ""; @@ -584,10 +629,10 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { getSpriteScale(): number { const formKey = this.getFormKey(); - if (formKey.indexOf(SpeciesFormKey.GIGANTAMAX) > -1 || formKey.indexOf(SpeciesFormKey.ETERNAMAX) > -1) { + if (this.isMax() === true || formKey === "segin-starmobile" || formKey === "schedar-starmobile" || formKey === "navi-starmobile" || formKey === "ruchbah-starmobile" || formKey === "caph-starmobile") { return 1.5; - } else if (this.mysteryEncounterPokemonData.spriteScale > 0) { - return this.mysteryEncounterPokemonData.spriteScale; + } else if (this.customPokemonData.spriteScale > 0) { + return this.customPokemonData.spriteScale; } return 1; } @@ -673,12 +718,12 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { getFieldPositionOffset(): [ number, number ] { switch (this.fieldPosition) { - case FieldPosition.CENTER: - return [ 0, 0 ]; - case FieldPosition.LEFT: - return [ -32, -8 ]; - case FieldPosition.RIGHT: - return [ 32, 0 ]; + case FieldPosition.CENTER: + return [ 0, 0 ]; + case FieldPosition.LEFT: + return [ -32, -8 ]; + case FieldPosition.RIGHT: + return [ 32, 0 ]; } } @@ -689,7 +734,7 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { * @see {@linkcode getFieldPositionOffset} */ getSubstituteOffset(): [ number, number ] { - return this.isPlayer() ? [-30, 10] : [30, -10]; + return this.isPlayer() ? [ -30, 10 ] : [ 30, -10 ]; } /** @@ -742,9 +787,16 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { const relX = newOffset[0] - initialOffset[0]; const relY = newOffset[1] - initialOffset[1]; + const subTag = this.getTag(SubstituteTag); + if (duration) { + // TODO: can this use stricter typing? + const targets: any[] = [ this ]; + if (subTag?.sprite) { + targets.push(subTag.sprite); + } this.scene.tweens.add({ - targets: this, + targets: targets, x: (_target, _key, value: number) => value + relX, y: (_target, _key, value: number) => value + relY, duration: duration, @@ -754,6 +806,10 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { } else { this.x += relX; this.y += relY; + if (subTag?.sprite) { + subTag.sprite.x += relX; + subTag.sprite.y += relY; + } } }); } @@ -899,37 +955,42 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { let ret = statValue.value * this.getStatStageMultiplier(stat, opponent, move, ignoreOppAbility, isCritical, simulated); switch (stat) { - case Stat.ATK: - if (this.getTag(BattlerTagType.SLOW_START)) { - ret >>= 1; - } - break; - case Stat.DEF: - if (this.isOfType(Type.ICE) && this.scene.arena.weather?.weatherType === WeatherType.SNOW) { - ret *= 1.5; - } - break; - case Stat.SPATK: - break; - case Stat.SPDEF: - if (this.isOfType(Type.ROCK) && this.scene.arena.weather?.weatherType === WeatherType.SANDSTORM) { - ret *= 1.5; - } - break; - case Stat.SPD: - // Check both the player and enemy to see if Tailwind should be multiplying the speed of the Pokemon - if ((this.isPlayer() && this.scene.arena.getTagOnSide(ArenaTagType.TAILWIND, ArenaTagSide.PLAYER)) - || (!this.isPlayer() && this.scene.arena.getTagOnSide(ArenaTagType.TAILWIND, ArenaTagSide.ENEMY))) { - ret *= 2; - } + case Stat.ATK: + if (this.getTag(BattlerTagType.SLOW_START)) { + ret >>= 1; + } + break; + case Stat.DEF: + if (this.isOfType(Type.ICE) && this.scene.arena.weather?.weatherType === WeatherType.SNOW) { + ret *= 1.5; + } + break; + case Stat.SPATK: + break; + case Stat.SPDEF: + if (this.isOfType(Type.ROCK) && this.scene.arena.weather?.weatherType === WeatherType.SANDSTORM) { + ret *= 1.5; + } + break; + case Stat.SPD: + const side = this.isPlayer() ? ArenaTagSide.PLAYER : ArenaTagSide.ENEMY; + if (this.scene.arena.getTagOnSide(ArenaTagType.TAILWIND, side)) { + ret *= 2; + } + if (this.scene.arena.getTagOnSide(ArenaTagType.GRASS_WATER_PLEDGE, side)) { + ret >>= 2; + } - if (this.getTag(BattlerTagType.SLOW_START)) { - ret >>= 1; - } - if (this.status && this.status.effect === StatusEffect.PARALYSIS) { - ret >>= 1; - } - break; + if (this.getTag(BattlerTagType.SLOW_START)) { + ret >>= 1; + } + if (this.status && this.status.effect === StatusEffect.PARALYSIS) { + ret >>= 1; + } + if (this.getTag(BattlerTagType.UNBURDEN) && this.hasAbility(Abilities.UNBURDEN)) { + ret *= 2; + } + break; } const highestStatBoost = this.findTag(t => t instanceof HighestStatBoostTag && (t as HighestStatBoostTag).stat === stat) as HighestStatBoostTag; @@ -949,32 +1010,35 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { const baseStats = this.calculateBaseStats(); // Using base stats, calculate and store stats one by one for (const s of PERMANENT_STATS) { - let value = Math.floor(((2 * baseStats[s] + this.ivs[s]) * this.level) * 0.01); + const statHolder = new Utils.IntegerHolder(Math.floor(((2 * baseStats[s] + this.ivs[s]) * this.level) * 0.01)); if (s === Stat.HP) { - value = value + this.level + 10; + statHolder.value = statHolder.value + this.level + 10; + this.scene.applyModifier(PokemonIncrementingStatModifier, this.isPlayer(), this, s, statHolder); if (this.hasAbility(Abilities.WONDER_GUARD, false, true)) { - value = 1; + statHolder.value = 1; } - if (this.hp > value || this.hp === undefined) { - this.hp = value; + if (this.hp > statHolder.value || this.hp === undefined) { + this.hp = statHolder.value; } else if (this.hp) { const lastMaxHp = this.getMaxHp(); - if (lastMaxHp && value > lastMaxHp) { - this.hp += value - lastMaxHp; + if (lastMaxHp && statHolder.value > lastMaxHp) { + this.hp += statHolder.value - lastMaxHp; } } } else { - value += 5; + statHolder.value += 5; const natureStatMultiplier = new Utils.NumberHolder(getNatureStatMultiplier(this.getNature(), s)); this.scene.applyModifier(PokemonNatureWeightModifier, this.isPlayer(), this, natureStatMultiplier); if (natureStatMultiplier.value !== 1) { - value = Math.max(Math[natureStatMultiplier.value > 1 ? "ceil" : "floor"](value * natureStatMultiplier.value), 1); + statHolder.value = Math.max(Math[natureStatMultiplier.value > 1 ? "ceil" : "floor"](statHolder.value * natureStatMultiplier.value), 1); } + this.scene.applyModifier(PokemonIncrementingStatModifier, this.isPlayer(), this, s, statHolder); } - this.setStat(s, value); + statHolder.value = Phaser.Math.Clamp(statHolder.value, 1, Number.MAX_SAFE_INTEGER); + + this.setStat(s, statHolder.value); } - this.scene.applyModifier(PokemonIncrementingStatModifier, this.isPlayer(), this, this.stats); } calculateBaseStats(): number[] { @@ -1000,7 +1064,7 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { } getNature(): Nature { - return this.natureOverride !== -1 ? this.natureOverride : this.nature; + return this.customPokemonData.nature !== -1 ? this.customPokemonData.nature : this.nature; } setNature(nature: Nature): void { @@ -1008,6 +1072,11 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { this.calculateStats(); } + setCustomNature(nature: Nature): void { + this.customPokemonData.nature = nature; + this.calculateStats(); + } + generateNature(naturePool?: Nature[]): void { if (naturePool === undefined) { naturePool = Utils.getEnumValues(Nature); @@ -1077,6 +1146,15 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { return !!this.fusionSpecies; } + /** + * Checks if the {@linkcode Pokemon} has a fusion with the specified {@linkcode Species}. + * @param species the pokemon {@linkcode Species} to check + * @returns `true` if the {@linkcode Pokemon} has a fusion with the specified {@linkcode Species}, `false` otherwise + */ + hasFusionSpecies(species: Species): boolean { + return this.fusionSpecies?.speciesId === species; + } + abstract isBoss(): boolean; getMoveset(ignoreOverride?: boolean): (PokemonMove | null)[] { @@ -1087,7 +1165,7 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { // Overrides moveset based on arrays specified in overrides.ts let overrideArray: Moves | Array = this.isPlayer() ? Overrides.MOVESET_OVERRIDE : Overrides.OPP_MOVESET_OVERRIDE; if (!Array.isArray(overrideArray)) { - overrideArray = [overrideArray]; + overrideArray = [ overrideArray ]; } if (overrideArray.length > 0) { if (!this.isPlayer()) { @@ -1131,7 +1209,7 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { * @returns an array of {@linkcode Moves}, the length of which is determined * by how many learnable moves there are for the {@linkcode Pokemon}. */ - getLearnableLevelMoves(): Moves[] { + public getLearnableLevelMoves(): Moves[] { let levelMoves = this.getLevelMoves(1, true, false, true).map(lm => lm[1]); if (this.metBiome === -1 && !this.scene.gameMode.isFreshStartChallenge() && !this.scene.gameMode.isDaily) { levelMoves = this.getUnlockedEggMoves().concat(levelMoves); @@ -1145,13 +1223,13 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { /** * Gets the types of a pokemon - * @param includeTeraType boolean to include tera-formed type, default false - * @param forDefend boolean if the pokemon is defending from an attack - * @param ignoreOverride boolean if true, ignore ability changing effects + * @param includeTeraType - `true` to include tera-formed type; Default: `false` + * @param forDefend - `true` if the pokemon is defending from an attack; Default: `false` + * @param ignoreOverride - If `true`, ignore ability changing effects; Default: `false` * @returns array of {@linkcode Type} */ - getTypes(includeTeraType = false, forDefend: boolean = false, ignoreOverride?: boolean): Type[] { - const types : Type[] = []; + public getTypes(includeTeraType = false, forDefend: boolean = false, ignoreOverride: boolean = false): Type[] { + const types: Type[] = []; if (includeTeraType) { const teraType = this.getTeraType(); @@ -1164,11 +1242,31 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { } if (!types.length || !includeTeraType) { - if (this.mysteryEncounterPokemonData.types && this.mysteryEncounterPokemonData.types.length > 0) { - // "Permanent" override for a Pokemon's normal types, currently only used by Mystery Encounters - this.mysteryEncounterPokemonData.types.forEach(t => types.push(t)); - } else if (!ignoreOverride && this.summonData?.types && this.summonData.types.length > 0) { + if (!ignoreOverride && this.summonData?.types && this.summonData.types.length > 0) { this.summonData.types.forEach(t => types.push(t)); + } else if (this.customPokemonData.types && this.customPokemonData.types.length > 0) { + // "Permanent" override for a Pokemon's normal types, currently only used by Mystery Encounters + types.push(this.customPokemonData.types[0]); + + // Fusing a Pokemon onto something with "permanently changed" types will still apply the fusion's types as normal + const fusionSpeciesForm = this.getFusionSpeciesForm(ignoreOverride); + if (fusionSpeciesForm) { + // Check if the fusion Pokemon also had "permanently changed" types + const fusionMETypes = this.fusionCustomPokemonData?.types; + if (fusionMETypes && fusionMETypes.length >= 2 && fusionMETypes[1] !== types[0]) { + types.push(fusionMETypes[1]); + } else if (fusionMETypes && fusionMETypes.length === 1 && fusionMETypes[0] !== types[0]) { + types.push(fusionMETypes[0]); + } else if (fusionSpeciesForm.type2 !== null && fusionSpeciesForm.type2 !== types[0]) { + types.push(fusionSpeciesForm.type2); + } else if (fusionSpeciesForm.type1 !== types[0]) { + types.push(fusionSpeciesForm.type1); + } + } + + if (types.length === 1 && this.customPokemonData.types.length >= 2) { + types.push(this.customPokemonData.types[1]); + } } else { const speciesForm = this.getSpeciesForm(ignoreOverride); @@ -1176,7 +1274,14 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { const fusionSpeciesForm = this.getFusionSpeciesForm(ignoreOverride); if (fusionSpeciesForm) { - if (fusionSpeciesForm.type2 !== null && fusionSpeciesForm.type2 !== speciesForm.type1) { + // Check if the fusion Pokemon also had "permanently changed" types + // Otherwise, use standard fusion type logic + const fusionMETypes = this.fusionCustomPokemonData?.types; + if (fusionMETypes && fusionMETypes.length >= 2 && fusionMETypes[1] !== types[0]) { + types.push(fusionMETypes[1]); + } else if (fusionMETypes && fusionMETypes.length === 1 && fusionMETypes[0] !== types[0]) { + types.push(fusionMETypes[0]); + } else if (fusionSpeciesForm.type2 !== null && fusionSpeciesForm.type2 !== speciesForm.type1) { types.push(fusionSpeciesForm.type2); } else if (fusionSpeciesForm.type1 !== speciesForm.type1) { types.push(fusionSpeciesForm.type1); @@ -1189,36 +1294,53 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { } } - // this.scene potentially can be undefined for a fainted pokemon in doubles - // use optional chaining to avoid runtime errors - - if (!types.length) { // become UNKNOWN if no types are present + // become UNKNOWN if no types are present + if (!types.length) { types.push(Type.UNKNOWN); } - if (types.length > 1 && types.includes(Type.UNKNOWN)) { // remove UNKNOWN if other types are present + // remove UNKNOWN if other types are present + if (types.length > 1 && types.includes(Type.UNKNOWN)) { const index = types.indexOf(Type.UNKNOWN); if (index !== -1) { types.splice(index, 1); } } + // the type added to Pokemon from moves like Forest's Curse or Trick Or Treat + if (!ignoreOverride && this.summonData && this.summonData.addedType && !types.includes(this.summonData.addedType)) { + types.push(this.summonData.addedType); + } + + // If both types are the same (can happen in weird custom typing scenarios), reduce to single type + if (types.length > 1 && types[0] === types[1]) { + types.splice(0, 1); + } + return types; } - isOfType(type: Type, includeTeraType: boolean = true, forDefend: boolean = false, ignoreOverride?: boolean): boolean { - return !!this.getTypes(includeTeraType, forDefend, ignoreOverride).some(t => t === type); + /** + * Checks if the pokemon's typing includes the specified type + * @param type - {@linkcode Type} to check + * @param includeTeraType - `true` to include tera-formed type; Default: `true` + * @param forDefend - `true` if the pokemon is defending from an attack; Default: `false` + * @param ignoreOverride - If `true`, ignore ability changing effects; Default: `false` + * @returns `true` if the Pokemon's type matches + */ + public isOfType(type: Type, includeTeraType: boolean = true, forDefend: boolean = false, ignoreOverride: boolean = false): boolean { + return this.getTypes(includeTeraType, forDefend, ignoreOverride).some((t) => t === type); } /** * Gets the non-passive ability of the pokemon. This accounts for fusions and ability changing effects. - * This should rarely be called, most of the time {@link hasAbility} or {@link hasAbilityWithAttr} are better used as + * This should rarely be called, most of the time {@linkcode hasAbility} or {@linkcode hasAbilityWithAttr} are better used as * those check both the passive and non-passive abilities and account for ability suppression. - * @see {@link hasAbility} {@link hasAbilityWithAttr} Intended ways to check abilities in most cases - * @param {boolean} ignoreOverride If true, ignore ability changing effects - * @returns {Ability} The non-passive ability of the pokemon + * @see {@linkcode hasAbility} {@linkcode hasAbilityWithAttr} Intended ways to check abilities in most cases + * @param ignoreOverride - If `true`, ignore ability changing effects; Default: `false` + * @returns The non-passive {@linkcode Ability} of the pokemon */ - getAbility(ignoreOverride?: boolean): Ability { + public getAbility(ignoreOverride: boolean = false): Ability { if (!ignoreOverride && this.summonData?.ability) { return allAbilities[this.summonData.ability]; } @@ -1228,11 +1350,15 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { if (Overrides.OPP_ABILITY_OVERRIDE && !this.isPlayer()) { return allAbilities[Overrides.OPP_ABILITY_OVERRIDE]; } - if (!isNullOrUndefined(this.mysteryEncounterPokemonData.ability) && this.mysteryEncounterPokemonData.ability !== -1) { - return allAbilities[this.mysteryEncounterPokemonData.ability]; - } if (this.isFusion()) { - return allAbilities[this.getFusionSpeciesForm(ignoreOverride).getAbility(this.fusionAbilityIndex)]; + if (!isNullOrUndefined(this.fusionCustomPokemonData?.ability) && this.fusionCustomPokemonData.ability !== -1) { + return allAbilities[this.fusionCustomPokemonData.ability]; + } else { + return allAbilities[this.getFusionSpeciesForm(ignoreOverride).getAbility(this.fusionAbilityIndex)]; + } + } + if (!isNullOrUndefined(this.customPokemonData.ability) && this.customPokemonData.ability !== -1) { + return allAbilities[this.customPokemonData.ability]; } let abilityId = this.getSpeciesForm(ignoreOverride).getAbility(this.abilityIndex); if (abilityId === Abilities.NONE) { @@ -1243,20 +1369,20 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { /** * Gets the passive ability of the pokemon. This should rarely be called, most of the time - * {@link hasAbility} or {@link hasAbilityWithAttr} are better used as those check both the passive and + * {@linkcode hasAbility} or {@linkcode hasAbilityWithAttr} are better used as those check both the passive and * non-passive abilities and account for ability suppression. - * @see {@link hasAbility} {@link hasAbilityWithAttr} Intended ways to check abilities in most cases - * @returns {Ability} The passive ability of the pokemon + * @see {@linkcode hasAbility} {@linkcode hasAbilityWithAttr} Intended ways to check abilities in most cases + * @returns The passive {@linkcode Ability} of the pokemon */ - getPassiveAbility(): Ability { + public getPassiveAbility(): Ability { if (Overrides.PASSIVE_ABILITY_OVERRIDE && this.isPlayer()) { return allAbilities[Overrides.PASSIVE_ABILITY_OVERRIDE]; } if (Overrides.OPP_PASSIVE_ABILITY_OVERRIDE && !this.isPlayer()) { return allAbilities[Overrides.OPP_PASSIVE_ABILITY_OVERRIDE]; } - if (!isNullOrUndefined(this.mysteryEncounterPokemonData.passive) && this.mysteryEncounterPokemonData.passive !== -1) { - return allAbilities[this.mysteryEncounterPokemonData.passive]; + if (!isNullOrUndefined(this.customPokemonData.passive) && this.customPokemonData.passive !== -1) { + return allAbilities[this.customPokemonData.passive]; } let starterSpeciesId = this.species.speciesId; @@ -1270,12 +1396,12 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { * Gets a list of all instances of a given ability attribute among abilities this pokemon has. * Accounts for all the various effects which can affect whether an ability will be present or * in effect, and both passive and non-passive. - * @param attrType {@linkcode AbAttr} The ability attribute to check for. - * @param canApply {@linkcode Boolean} If false, it doesn't check whether the ability is currently active - * @param ignoreOverride {@linkcode Boolean} If true, it ignores ability changing effects - * @returns A list of all the ability attributes on this ability. + * @param attrType - {@linkcode AbAttr} The ability attribute to check for. + * @param canApply - If `false`, it doesn't check whether the ability is currently active; Default `true` + * @param ignoreOverride - If `true`, it ignores ability changing effects; Default `false` + * @returns An array of all the ability attributes on this ability. */ - getAbilityAttrs(attrType: { new(...args: any[]): T }, canApply: boolean = true, ignoreOverride?: boolean): T[] { + public getAbilityAttrs(attrType: { new(...args: any[]): T }, canApply: boolean = true, ignoreOverride: boolean = false): T[] { const abilityAttrs: T[] = []; if (!canApply || this.canApplyAbility()) { @@ -1294,12 +1420,12 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { * - bought with starter candy * - set by override * - is a boss pokemon - * @returns whether or not a pokemon should have a passive + * @returns `true` if the Pokemon has a passive */ - hasPassive(): boolean { + public hasPassive(): boolean { // returns override if valid for current case - if ((Overrides.PASSIVE_ABILITY_OVERRIDE !== Abilities.NONE && this.isPlayer()) || - (Overrides.OPP_PASSIVE_ABILITY_OVERRIDE !== Abilities.NONE && !this.isPlayer())) { + if ((Overrides.PASSIVE_ABILITY_OVERRIDE !== Abilities.NONE && this.isPlayer()) + || (Overrides.OPP_PASSIVE_ABILITY_OVERRIDE !== Abilities.NONE && !this.isPlayer())) { return true; } @@ -1318,12 +1444,12 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { /** * Checks whether an ability of a pokemon can be currently applied. This should rarely be - * directly called, as {@link hasAbility} and {@link hasAbilityWithAttr} already call this. - * @see {@link hasAbility} {@link hasAbilityWithAttr} Intended ways to check abilities in most cases - * @param {boolean} passive If true, check if passive can be applied instead of non-passive - * @returns {Ability} The passive ability of the pokemon + * directly called, as {@linkcode hasAbility} and {@linkcode hasAbilityWithAttr} already call this. + * @see {@linkcode hasAbility} {@linkcode hasAbilityWithAttr} Intended ways to check abilities in most cases + * @param passive If true, check if passive can be applied instead of non-passive + * @returns `true` if the ability can be applied */ - canApplyAbility(passive: boolean = false): boolean { + public canApplyAbility(passive: boolean = false): boolean { if (passive && !this.hasPassive()) { return false; } @@ -1331,7 +1457,8 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { if (this.isFusion() && ability.hasAttr(NoFusionAbilityAbAttr)) { return false; } - if (this.scene?.arena.ignoreAbilities && ability.isIgnorable) { + const arena = this.scene?.arena; + if (arena.ignoreAbilities && arena.ignoringEffectSource !== this.getBattlerIndex() && ability.isIgnorable) { return false; } if (this.summonData?.abilitySuppressed && !ability.hasAttr(UnsuppressableAbilityAbAttr)) { @@ -1341,17 +1468,17 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { const suppressed = new Utils.BooleanHolder(false); this.scene.getField(true).filter(p => p !== this).map(p => { if (p.getAbility().hasAttr(SuppressFieldAbilitiesAbAttr) && p.canApplyAbility()) { - p.getAbility().getAttrs(SuppressFieldAbilitiesAbAttr).map(a => a.apply(this, false, false, suppressed, [ability])); + p.getAbility().getAttrs(SuppressFieldAbilitiesAbAttr).map(a => a.apply(this, false, false, suppressed, [ ability ])); } if (p.getPassiveAbility().hasAttr(SuppressFieldAbilitiesAbAttr) && p.canApplyAbility(true)) { - p.getPassiveAbility().getAttrs(SuppressFieldAbilitiesAbAttr).map(a => a.apply(this, true, false, suppressed, [ability])); + p.getPassiveAbility().getAttrs(SuppressFieldAbilitiesAbAttr).map(a => a.apply(this, true, false, suppressed, [ ability ])); } }); if (suppressed.value) { return false; } } - return (!!this.hp || ability.isBypassFaint) && !ability.conditions.find(condition => !condition(this)); + return (this.hp > 0 || ability.isBypassFaint) && !ability.conditions.find(condition => !condition(this)); } /** @@ -1363,11 +1490,11 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { * @param {boolean} ignoreOverride If true, it ignores ability changing effects * @returns {boolean} Whether the ability is present and active */ - hasAbility(ability: Abilities, canApply: boolean = true, ignoreOverride?: boolean): boolean { - if ((!canApply || this.canApplyAbility()) && this.getAbility(ignoreOverride).id === ability) { + public hasAbility(ability: Abilities, canApply: boolean = true, ignoreOverride?: boolean): boolean { + if (this.getAbility(ignoreOverride).id === ability && (!canApply || this.canApplyAbility())) { return true; } - if (this.hasPassive() && (!canApply || this.canApplyAbility(true)) && this.getPassiveAbility().id === ability) { + if (this.getPassiveAbility().id === ability && this.hasPassive() && (!canApply || this.canApplyAbility(true))) { return true; } return false; @@ -1383,7 +1510,7 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { * @param {boolean} ignoreOverride If true, it ignores ability changing effects * @returns {boolean} Whether an ability with that attribute is present and active */ - hasAbilityWithAttr(attrType: Constructor, canApply: boolean = true, ignoreOverride?: boolean): boolean { + public hasAbilityWithAttr(attrType: Constructor, canApply: boolean = true, ignoreOverride?: boolean): boolean { if ((!canApply || this.canApplyAbility()) && this.getAbility(ignoreOverride).hasAttr(attrType)) { return true; } @@ -1393,18 +1520,29 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { return false; } - getWeight(): number { - const weight = new Utils.NumberHolder(this.species.weight); + /** + * Gets the weight of the Pokemon with subtractive modifiers (Autotomize) happening first + * and then multiplicative modifiers happening after (Heavy Metal and Light Metal) + * @returns the kg of the Pokemon (minimum of 0.1) + */ + public getWeight(): number { + const autotomizedTag = this.getTag(AutotomizedTag); + let weightRemoved = 0; + if (!Utils.isNullOrUndefined(autotomizedTag)) { + weightRemoved = 100 * autotomizedTag!.autotomizeCount; + } + const minWeight = 0.1; + const weight = new Utils.NumberHolder(this.species.weight - weightRemoved); + // This will trigger the ability overlay so only call this function when necessary applyAbAttrs(WeightMultiplierAbAttr, this, null, false, weight); - return weight.value; + return Math.max(minWeight, weight.value); } /** - * Gets the tera-formed type of the pokemon, or UNKNOWN if not present - * @returns the {@linkcode Type} + * @returns The tera-formed type of the pokemon, or {@linkcode Type.UNKNOWN} if not present */ - getTeraType(): Type { + public getTeraType(): Type { // this.scene can be undefined for a fainted mon in doubles if (this.scene !== undefined) { const teraModifier = this.scene.findModifier(m => m instanceof TerastallizeModifier @@ -1418,23 +1556,28 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { return Type.UNKNOWN; } - isTerastallized(): boolean { + public isTerastallized(): boolean { return this.getTeraType() !== Type.UNKNOWN; } - isGrounded(): boolean { - return !!this.getTag(GroundedTag) || (!this.isOfType(Type.FLYING, true, true) && !this.hasAbility(Abilities.LEVITATE) && !this.getTag(BattlerTagType.MAGNET_RISEN) && !this.getTag(SemiInvulnerableTag)); + public isGrounded(): boolean { + return !!this.getTag(GroundedTag) || (!this.isOfType(Type.FLYING, true, true) && !this.hasAbility(Abilities.LEVITATE) && !this.getTag(BattlerTagType.FLOATING) && !this.getTag(SemiInvulnerableTag)); } /** * Determines whether this Pokemon is prevented from running or switching due * to effects from moves and/or abilities. - * @param trappedAbMessages `string[]` If defined, ability trigger messages + * @param trappedAbMessages - If defined, ability trigger messages * (e.g. from Shadow Tag) are forwarded through this array. - * @param simulated `boolean` if `true`, applies abilities via simulated calls. - * @returns + * @param simulated - If `true`, applies abilities via simulated calls. + * @returns `true` if the pokemon is trapped */ - isTrapped(trappedAbMessages: string[] = [], simulated: boolean = true): boolean { + public isTrapped(trappedAbMessages: string[] = [], simulated: boolean = true): boolean { + const commandedTag = this.getTag(BattlerTagType.COMMANDED); + if (commandedTag?.getSourcePokemon(this.scene)?.isActive(true)) { + return true; + } + if (this.isOfType(Type.GHOST)) { return false; } @@ -1442,31 +1585,36 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { const trappedByAbility = new Utils.BooleanHolder(false); const opposingField = this.isPlayer() ? this.scene.getEnemyField() : this.scene.getPlayerField(); - opposingField.forEach(opponent => + opposingField.forEach((opponent) => applyCheckTrappedAbAttrs(CheckTrappedAbAttr, opponent, trappedByAbility, this, trappedAbMessages, simulated) ); - return (trappedByAbility.value || !!this.getTag(TrappedTag)); + const side = this.isPlayer() ? ArenaTagSide.PLAYER : ArenaTagSide.ENEMY; + return (trappedByAbility.value || !!this.getTag(TrappedTag) || !!this.scene.arena.getTagOnSide(ArenaTagType.FAIRY_LOCK, side)); } /** * Calculates the type of a move when used by this Pokemon after * type-changing move and ability attributes have applied. - * @param move {@linkcode Move} The move being used. - * @param simulated If `true`, prevents showing abilities applied in this calculation. - * @returns the {@linkcode Type} of the move after attributes are applied + * @param move - {@linkcode Move} The move being used. + * @param simulated - If `true`, prevents showing abilities applied in this calculation. + * @returns The {@linkcode Type} of the move after attributes are applied */ - getMoveType(move: Move, simulated: boolean = true): Type { + public getMoveType(move: Move, simulated: boolean = true): Type { const moveTypeHolder = new Utils.NumberHolder(move.type); applyMoveAttrs(VariableMoveTypeAttr, this, null, move, moveTypeHolder); applyPreAttackAbAttrs(MoveTypeChangeAbAttr, this, null, move, simulated, moveTypeHolder); + this.scene.arena.applyTags(ArenaTagType.ION_DELUGE, simulated, moveTypeHolder); + if (this.getTag(BattlerTagType.ELECTRIFIED)) { + moveTypeHolder.value = Type.ELECTRIC; + } + return moveTypeHolder.value as Type; } - /** * Calculates the effectiveness of a move against the Pokémon. * This includes modifiers from move and ability attributes. @@ -1479,13 +1627,17 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { * @returns The type damage multiplier, indicating the effectiveness of the move */ getMoveEffectiveness(source: Pokemon, move: Move, ignoreAbility: boolean = false, simulated: boolean = true, cancelled?: Utils.BooleanHolder): TypeDamageMultiplier { + if (!Utils.isNullOrUndefined(this.turnData?.moveEffectiveness)) { + return this.turnData?.moveEffectiveness; + } + if (move.hasAttr(TypelessAttr)) { return 1; } const moveType = source.getMoveType(move); const typeMultiplier = new Utils.NumberHolder((move.category !== MoveCategory.STATUS || move.hasAttr(RespectAttackTypeImmunityAttr)) - ? this.getAttackTypeEffectiveness(moveType, source, false, simulated) + ? this.getAttackTypeEffectiveness(moveType, source, false, simulated, move) : 1); applyMoveAttrs(VariableMoveTypeMultiplierAttr, source, this, move, typeMultiplier); @@ -1513,7 +1665,7 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { const immuneTags = this.findTags(tag => tag instanceof TypeImmuneTag && tag.immuneType === moveType); for (const tag of immuneTags) { - if (move && !move.getAttrs(DealsDoubleDamageToTagAttr).some(attr => attr.tagType === tag.tagType)) { + if (move && !move.getAttrs(HitsTagAttr).some(attr => attr.tagType === tag.tagType)) { typeMultiplier.value = 0; break; } @@ -1537,9 +1689,10 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { * @param source {@linkcode Pokemon} the Pokemon using the move * @param ignoreStrongWinds whether or not this ignores strong winds (anticipation, forewarn, stealth rocks) * @param simulated tag to only apply the strong winds effect message when the move is used + * @param move (optional) the move whose type effectiveness is to be checked. Used for applying {@linkcode VariableMoveTypeChartAttr} * @returns a multiplier for the type effectiveness */ - getAttackTypeEffectiveness(moveType: Type, source?: Pokemon, ignoreStrongWinds: boolean = false, simulated: boolean = true): TypeDamageMultiplier { + getAttackTypeEffectiveness(moveType: Type, source?: Pokemon, ignoreStrongWinds: boolean = false, simulated: boolean = true, move?: Move): TypeDamageMultiplier { if (moveType === Type.STELLAR) { return this.isTerastallized() ? 2 : 1; } @@ -1558,6 +1711,9 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { let multiplier = types.map(defType => { const multiplier = new Utils.NumberHolder(getTypeDamageMultiplier(moveType, defType)); applyChallenges(this.scene.gameMode, ChallengeType.TYPE_EFFECTIVENESS, multiplier); + if (move) { + applyMoveAttrs(VariableMoveTypeChartAttr, null, this, move, multiplier, defType); + } if (source) { const ignoreImmunity = new Utils.BooleanHolder(false); if (source.isActive(true) && source.hasAbilityWithAttr(IgnoreTypeImmunityAbAttr)) { @@ -1634,7 +1790,7 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { if (pokemonEvolutions.hasOwnProperty(this.species.speciesId)) { const evolutions = pokemonEvolutions[this.species.speciesId]; for (const e of evolutions) { - if (!e.item && this.level >= e.level && (!e.preFormKey || this.getFormKey() === e.preFormKey)) { + if (!e.item && this.level >= e.level && (isNullOrUndefined(e.preFormKey) || this.getFormKey() === e.preFormKey)) { if (e.condition === null || (e.condition as SpeciesEvolutionCondition).predicate(this)) { return e; } @@ -1645,7 +1801,7 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { if (this.isFusion() && this.fusionSpecies && pokemonEvolutions.hasOwnProperty(this.fusionSpecies.speciesId)) { const fusionEvolutions = pokemonEvolutions[this.fusionSpecies.speciesId].map(e => new FusionSpeciesFormEvolution(this.species.speciesId, e)); for (const fe of fusionEvolutions) { - if (!fe.item && this.level >= fe.level && (!fe.preFormKey || this.getFusionFormKey() === fe.preFormKey)) { + if (!fe.item && this.level >= fe.level && (isNullOrUndefined(fe.preFormKey) || this.getFusionFormKey() === fe.preFormKey)) { if (fe.condition === null || (fe.condition as SpeciesEvolutionCondition).predicate(this)) { return fe; } @@ -1753,8 +1909,8 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { * * @returns list of egg moves */ - getEggMoves() : Moves[] { - return speciesEggMoves[this.species.speciesId]; + getEggMoves() : Moves[] | undefined { + return speciesEggMoves[this.getSpeciesForm().getRootSpeciesId()]; } setMove(moveIndex: integer, moveId: Moves): void { @@ -1772,7 +1928,7 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { * The exact mechanic is that it calculates E as the XOR of the player's trainer ID and secret ID. * F is calculated as the XOR of the first 16 bits of the Pokemon's ID with the last 16 bits. * The XOR of E and F are then compared to the {@linkcode shinyThreshold} (or {@linkcode thresholdOverride} if set) to see whether or not to generate a shiny. - * The base shiny odds are {@linkcode baseShinyChance} / 65536 + * The base shiny odds are {@linkcode BASE_SHINY_CHANCE} / 65536 * @param thresholdOverride number that is divided by 2^16 (65536) to get the shiny chance, overrides {@linkcode shinyThreshold} if set (bypassing shiny rate modifiers such as Shiny Charm) * @returns true if the Pokemon has been set as a shiny, false otherwise */ @@ -1788,9 +1944,7 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { const E = this.scene.gameData.trainerId ^ this.scene.gameData.secretId; const F = rand1 ^ rand2; - /** `64/65536 -> 1/1024` */ - const baseShinyChance = 64; - const shinyThreshold = new Utils.IntegerHolder(baseShinyChance); + const shinyThreshold = new Utils.IntegerHolder(BASE_SHINY_CHANCE); if (thresholdOverride === undefined) { if (this.scene.eventManager.isEventActive()) { shinyThreshold.value *= this.scene.eventManager.getShinyMultiplier(); @@ -1815,15 +1969,13 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { * Function that tries to set a Pokemon shiny based on seed. * For manual use only, usually to roll a Pokemon's shiny chance a second time. * - * The base shiny odds are {@linkcode baseShinyChance} / 65536 - * @param thresholdOverride number that is divided by 2^16 (65536) to get the shiny chance, overrides {@linkcode shinyThreshold} if set (bypassing shiny rate modifiers such as Shiny Charm) + * The base shiny odds are {@linkcode BASE_SHINY_CHANCE} / `65536` + * @param thresholdOverride number that is divided by `2^16` (`65536`) to get the shiny chance, overrides {@linkcode shinyThreshold} if set (bypassing shiny rate modifiers such as Shiny Charm) * @param applyModifiersToOverride If {@linkcode thresholdOverride} is set and this is true, will apply Shiny Charm and event modifiers to {@linkcode thresholdOverride} - * @returns true if the Pokemon has been set as a shiny, false otherwise + * @returns `true` if the Pokemon has been set as a shiny, `false` otherwise */ - trySetShinySeed(thresholdOverride?: integer, applyModifiersToOverride?: boolean): boolean { - /** `64/65536 -> 1/1024` */ - const baseShinyChance = 64; - const shinyThreshold = new Utils.IntegerHolder(baseShinyChance); + public trySetShinySeed(thresholdOverride?: number, applyModifiersToOverride?: boolean): boolean { + const shinyThreshold = new Utils.NumberHolder(BASE_SHINY_CHANCE); if (thresholdOverride === undefined || applyModifiersToOverride) { if (thresholdOverride !== undefined && applyModifiersToOverride) { shinyThreshold.value = thresholdOverride; @@ -1848,13 +2000,13 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { } /** - * Generates a variant - * Has a 10% of returning 2 (epic variant) - * And a 30% of returning 1 (rare variant) - * Returns 0 (basic shiny) if there is no variant or 60% of the time otherwise - * @returns the shiny variant + * Generates a shiny variant + * @returns `0-2`, with the following probabilities: + * - Has a 10% chance of returning `2` (epic variant) + * - Has a 30% chance of returning `1` (rare variant) + * - Has a 60% chance of returning `0` (basic shiny) */ - generateVariant(): Variant { + protected generateShinyVariant(): Variant { const formIndex: number = this.formIndex; let variantDataIndex: string | number = this.species.speciesId; if (this.species.forms.length > 0) { @@ -1867,18 +2019,21 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { if (!this.shiny || (!variantData.hasOwnProperty(variantDataIndex) && !variantData.hasOwnProperty(this.species.speciesId))) { return 0; } - const rand = Utils.randSeedInt(10); - if (rand >= 4) { + const rand = new Utils.NumberHolder(0); + this.scene.executeWithSeedOffset(() => { + rand.value = Utils.randSeedInt(10); + }, this.id, this.scene.waveSeed); + if (rand.value >= SHINY_VARIANT_CHANCE) { return 0; // 6/10 - } else if (rand >= 1) { + } else if (rand.value >= SHINY_EPIC_CHANCE) { return 1; // 3/10 } else { return 2; // 1/10 } } - generateFusionSpecies(forStarter?: boolean): void { - const hiddenAbilityChance = new Utils.IntegerHolder(256); + public generateFusionSpecies(forStarter?: boolean): void { + const hiddenAbilityChance = new Utils.NumberHolder(BASE_HIDDEN_ABILITY_CHANCE); if (!this.hasTrainer()) { this.scene.applyModifiers(HiddenAbilityRateBoosterModifier, true, hiddenAbilityChance); } @@ -1886,18 +2041,28 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { const hasHiddenAbility = !Utils.randSeedInt(hiddenAbilityChance.value); const randAbilityIndex = Utils.randSeedInt(2); - const filter = !forStarter ? this.species.getCompatibleFusionSpeciesFilter() - : species => { + const filter = !forStarter ? + this.species.getCompatibleFusionSpeciesFilter() + : (species: PokemonSpecies) => { return pokemonEvolutions.hasOwnProperty(species.speciesId) - && !pokemonPrevolutions.hasOwnProperty(species.speciesId) - && !species.pseudoLegendary - && !species.legendary - && !species.mythical - && !species.isTrainerForbidden() - && species.speciesId !== this.species.speciesId; + && !pokemonPrevolutions.hasOwnProperty(species.speciesId) + && !species.subLegendary + && !species.legendary + && !species.mythical + && !species.isTrainerForbidden() + && species.speciesId !== this.species.speciesId + && species.speciesId !== Species.DITTO; }; - this.fusionSpecies = this.scene.randomSpecies(this.scene.currentBattle?.waveIndex || 0, this.level, false, filter, true); + let fusionOverride: PokemonSpecies | undefined = undefined; + + if (forStarter && this instanceof PlayerPokemon && Overrides.STARTER_FUSION_SPECIES_OVERRIDE) { + fusionOverride = getPokemonSpecies(Overrides.STARTER_FUSION_SPECIES_OVERRIDE); + } else if (this instanceof EnemyPokemon && Overrides.OPP_FUSION_SPECIES_OVERRIDE) { + fusionOverride = getPokemonSpecies(Overrides.OPP_FUSION_SPECIES_OVERRIDE); + } + + this.fusionSpecies = fusionOverride ?? this.scene.randomSpecies(this.scene.currentBattle?.waveIndex || 0, this.level, false, filter, true); this.fusionAbilityIndex = (this.fusionSpecies.abilityHidden && hasHiddenAbility ? 2 : this.fusionSpecies.ability2 !== this.fusionSpecies.ability1 ? randAbilityIndex : 0); this.fusionShiny = this.shiny; this.fusionVariant = this.variant; @@ -1919,7 +2084,7 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { this.generateName(); } - clearFusionSpecies(): void { + public clearFusionSpecies(): void { this.fusionSpecies = null; this.fusionFormIndex = 0; this.fusionAbilityIndex = 0; @@ -1927,17 +2092,19 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { this.fusionVariant = 0; this.fusionGender = 0; this.fusionLuck = 0; + this.fusionCustomPokemonData = null; this.generateName(); this.calculateStats(); } - generateAndPopulateMoveset(): void { + /** Generates a semi-random moveset for a Pokemon */ + public generateAndPopulateMoveset(): void { this.moveset = []; let movePool: [Moves, number][] = []; const allLevelMoves = this.getLevelMoves(1, true, true); if (!allLevelMoves) { - console.log(this.species.speciesId, "ERROR"); + console.warn("Error encountered trying to generate moveset for:", this.species.name); return; } @@ -1947,17 +2114,16 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { break; } let weight = levelMove[0]; - if (weight === 0) { // Evo Moves + // Evolution Moves + if (weight === 0) { weight = 50; } - if (weight === 1 && allMoves[levelMove[1]].power >= 80) { // Assume level 1 moves with 80+ BP are "move reminder" moves and bump their weight + // Assume level 1 moves with 80+ BP are "move reminder" moves and bump their weight + if (weight === 1 && allMoves[levelMove[1]].power >= 80) { weight = 40; } - if (allMoves[levelMove[1]].name.endsWith(" (N)")) { - weight /= 100; - } // Unimplemented level up moves are possible to generate, but 1% of their normal chance. - if (!movePool.some(m => m[0] === levelMove[1])) { - movePool.push([levelMove[1], weight]); + if (!movePool.some(m => m[0] === levelMove[1]) && !allMoves[levelMove[1]].name.endsWith(" (N)")) { + movePool.push([ levelMove[1], weight ]); } } @@ -1979,42 +2145,46 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { } if (compatible && !movePool.some(m => m[0] === moveId) && !allMoves[moveId].name.endsWith(" (N)")) { if (tmPoolTiers[moveId] === ModifierTier.COMMON && this.level >= 15) { - movePool.push([moveId, 4]); + movePool.push([ moveId, 4 ]); } else if (tmPoolTiers[moveId] === ModifierTier.GREAT && this.level >= 30) { - movePool.push([moveId, 8]); + movePool.push([ moveId, 8 ]); } else if (tmPoolTiers[moveId] === ModifierTier.ULTRA && this.level >= 50) { - movePool.push([moveId, 14]); + movePool.push([ moveId, 14 ]); } } } - if (this.level >= 60) { // No egg moves below level 60 + // No egg moves below level 60 + if (this.level >= 60) { for (let i = 0; i < 3; i++) { const moveId = speciesEggMoves[this.species.getRootSpeciesId()][i]; if (!movePool.some(m => m[0] === moveId) && !allMoves[moveId].name.endsWith(" (N)")) { - movePool.push([moveId, 40]); + movePool.push([ moveId, 40 ]); } } const moveId = speciesEggMoves[this.species.getRootSpeciesId()][3]; - if (this.level >= 170 && !movePool.some(m => m[0] === moveId) && !allMoves[moveId].name.endsWith(" (N)") && !this.isBoss()) { // No rare egg moves before e4 - movePool.push([moveId, 30]); + // No rare egg moves before e4 + if (this.level >= 170 && !movePool.some(m => m[0] === moveId) && !allMoves[moveId].name.endsWith(" (N)") && !this.isBoss()) { + movePool.push([ moveId, 30 ]); } if (this.fusionSpecies) { for (let i = 0; i < 3; i++) { const moveId = speciesEggMoves[this.fusionSpecies.getRootSpeciesId()][i]; if (!movePool.some(m => m[0] === moveId) && !allMoves[moveId].name.endsWith(" (N)")) { - movePool.push([moveId, 40]); + movePool.push([ moveId, 40 ]); } } const moveId = speciesEggMoves[this.fusionSpecies.getRootSpeciesId()][3]; - if (this.level >= 170 && !movePool.some(m => m[0] === moveId) && !allMoves[moveId].name.endsWith(" (N)") && !this.isBoss()) {// No rare egg moves before e4 - movePool.push([moveId, 30]); + // No rare egg moves before e4 + if (this.level >= 170 && !movePool.some(m => m[0] === moveId) && !allMoves[moveId].name.endsWith(" (N)") && !this.isBoss()) { + movePool.push([ moveId, 30 ]); } } } } - if (this.isBoss()) { // Bosses never get self ko moves + // Bosses never get self ko moves + if (this.isBoss()) { movePool = movePool.filter(m => !allMoves[m[0]].hasAttr(SacrificialAttr)); } movePool = movePool.filter(m => !allMoves[m[0]].hasAttr(SacrificialAttrOnHit)); @@ -2022,37 +2192,39 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { // Trainers never get OHKO moves movePool = movePool.filter(m => !allMoves[m[0]].hasAttr(OneHitKOAttr)); // Half the weight of self KO moves - movePool = movePool.map(m => [m[0], m[1] * (!!allMoves[m[0]].hasAttr(SacrificialAttr) ? 0.5 : 1)]); - movePool = movePool.map(m => [m[0], m[1] * (!!allMoves[m[0]].hasAttr(SacrificialAttrOnHit) ? 0.5 : 1)]); + movePool = movePool.map(m => [ m[0], m[1] * (!!allMoves[m[0]].hasAttr(SacrificialAttr) ? 0.5 : 1) ]); + movePool = movePool.map(m => [ m[0], m[1] * (!!allMoves[m[0]].hasAttr(SacrificialAttrOnHit) ? 0.5 : 1) ]); // Trainers get a weight bump to stat buffing moves - movePool = movePool.map(m => [m[0], m[1] * (allMoves[m[0]].getAttrs(StatStageChangeAttr).some(a => a.stages > 1 && a.selfTarget) ? 1.25 : 1)]); + movePool = movePool.map(m => [ m[0], m[1] * (allMoves[m[0]].getAttrs(StatStageChangeAttr).some(a => a.stages > 1 && a.selfTarget) ? 1.25 : 1) ]); // Trainers get a weight decrease to multiturn moves - movePool = movePool.map(m => [m[0], m[1] * (!!allMoves[m[0]].hasAttr(ChargeAttr) || !!allMoves[m[0]].hasAttr(RechargeAttr) ? 0.7 : 1)]); + movePool = movePool.map(m => [ m[0], m[1] * (!!allMoves[m[0]].isChargingMove() || !!allMoves[m[0]].hasAttr(RechargeAttr) ? 0.7 : 1) ]); } // Weight towards higher power moves, by reducing the power of moves below the highest power. // Caps max power at 90 to avoid something like hyper beam ruining the stats. // This is a pretty soft weighting factor, although it is scaled with the weight multiplier. const maxPower = Math.min(movePool.reduce((v, m) => Math.max(allMoves[m[0]].power, v), 40), 90); - movePool = movePool.map(m => [m[0], m[1] * (allMoves[m[0]].category === MoveCategory.STATUS ? 1 : Math.max(Math.min(allMoves[m[0]].power/maxPower, 1), 0.5))]); + movePool = movePool.map(m => [ m[0], m[1] * (allMoves[m[0]].category === MoveCategory.STATUS ? 1 : Math.max(Math.min(allMoves[m[0]].power / maxPower, 1), 0.5)) ]); // Weight damaging moves against the lower stat const atk = this.getStat(Stat.ATK); const spAtk = this.getStat(Stat.SPATK); const worseCategory: MoveCategory = atk > spAtk ? MoveCategory.SPECIAL : MoveCategory.PHYSICAL; const statRatio = worseCategory === MoveCategory.PHYSICAL ? atk / spAtk : spAtk / atk; - movePool = movePool.map(m => [m[0], m[1] * (allMoves[m[0]].category === worseCategory ? statRatio : 1)]); + movePool = movePool.map(m => [ m[0], m[1] * (allMoves[m[0]].category === worseCategory ? statRatio : 1) ]); - let weightMultiplier = 0.9; // The higher this is the more the game weights towards higher level moves. At 0 all moves are equal weight. + /** The higher this is the more the game weights towards higher level moves. At `0` all moves are equal weight. */ + let weightMultiplier = 0.9; if (this.hasTrainer()) { weightMultiplier += 0.7; } if (this.isBoss()) { weightMultiplier += 0.4; } - const baseWeights: [Moves, number][] = movePool.map(m => [m[0], Math.ceil(Math.pow(m[1], weightMultiplier)*100)]); + const baseWeights: [Moves, number][] = movePool.map(m => [ m[0], Math.ceil(Math.pow(m[1], weightMultiplier) * 100) ]); - if (this.hasTrainer() || this.isBoss()) { // Trainers and bosses always force a stab move + // Trainers and bosses always force a stab move + if (this.hasTrainer() || this.isBoss()) { const stabMovePool = baseWeights.filter(m => allMoves[m[0]].category !== MoveCategory.STATUS && this.isOfType(allMoves[m[0]].type)); if (stabMovePool.length) { @@ -2082,8 +2254,19 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { // Sqrt the weight of any damaging moves with overlapping types. This is about a 0.05 - 0.1 multiplier. // Other damaging moves 2x weight if 0-1 damaging moves, 0.5x if 2, 0.125x if 3. These weights double if STAB. // Status moves remain unchanged on weight, this encourages 1-2 - movePool = baseWeights.filter(m => !this.moveset.some(mo => m[0] === mo?.moveId)).map(m => [m[0], this.moveset.some(mo => mo?.getMove().category !== MoveCategory.STATUS && mo?.getMove().type === allMoves[m[0]].type) ? Math.ceil(Math.sqrt(m[1])) : allMoves[m[0]].category !== MoveCategory.STATUS ? Math.ceil(m[1]/Math.max(Math.pow(4, this.moveset.filter(mo => (mo?.getMove().power!) > 1).length)/8, 0.5) * (this.isOfType(allMoves[m[0]].type) ? 2 : 1)) : m[1]]); // TODO: is this bang correct? - } else { // Non-trainer pokemon just use normal weights + movePool = baseWeights.filter(m => !this.moveset.some(mo => m[0] === mo?.moveId)).map((m) => { + let ret: number; + if (this.moveset.some(mo => mo?.getMove().category !== MoveCategory.STATUS && mo?.getMove().type === allMoves[m[0]].type)) { + ret = Math.ceil(Math.sqrt(m[1])); + } else if (allMoves[m[0]].category !== MoveCategory.STATUS) { + ret = Math.ceil(m[1] / Math.max(Math.pow(4, this.moveset.filter(mo => (mo?.getMove().power ?? 0) > 1).length) / 8, 0.5) * (this.isOfType(allMoves[m[0]].type) ? 2 : 1)); + } else { + ret = m[1]; + } + return [ m[0], ret ]; + }); + } else { + // Non-trainer pokemon just use normal weights movePool = baseWeights.filter(m => !this.moveset.some(mo => m[0] === mo?.moveId)); } const totalWeight = movePool.reduce((v, m) => v + m[1], 0); @@ -2095,14 +2278,17 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { this.moveset.push(new PokemonMove(movePool[index][0], 0, 0)); } - this.scene.triggerPokemonFormChange(this, SpeciesFormChangeMoveLearnedTrigger); + // Trigger FormChange, except for enemy Pokemon during Mystery Encounters, to avoid crashes + if (this.isPlayer() || !this.scene.currentBattle?.isBattleMysteryEncounter() || !this.scene.currentBattle?.mysteryEncounter) { + this.scene.triggerPokemonFormChange(this, SpeciesFormChangeMoveLearnedTrigger); + } } - trySelectMove(moveIndex: integer, ignorePp?: boolean): boolean { + public trySelectMove(moveIndex: integer, ignorePp?: boolean): boolean { const move = this.getMoveset().length > moveIndex ? this.getMoveset()[moveIndex] : null; - return move?.isUsable(this, ignorePp)!; // TODO: is this bang correct? + return move?.isUsable(this, ignorePp) ?? false; } showInfo(): void { @@ -2152,11 +2338,11 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { } /** - * sets if the pokemon has fled (implies it's a wild pokemon) + * sets if the pokemon is switching out (if it's a enemy wild implies it's going to flee) * @param status - boolean */ - setWildFlee(status: boolean): void { - this.wildFlee = status; + setSwitchOutStatus(status: boolean): void { + this.switchOutStatus = status; } updateInfo(instant?: boolean): Promise { @@ -2193,6 +2379,15 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { this.levelExp = this.exp - getLevelTotalExp(this.level, this.species.growthRate); } + /** + * Compares if `this` and {@linkcode target} are on the same team. + * @param target the {@linkcode Pokemon} to compare against. + * @returns `true` if the two pokemon are allies, `false` otherwise + */ + public isOpponent(target: Pokemon): boolean { + return this.isPlayer() !== target.isPlayer(); + } + getOpponent(targetIndex: integer): Pokemon | null { const ret = this.getOpponents()[targetIndex]; if (ret.summonData) { @@ -2246,14 +2441,14 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { if (opponent) { if (isCritical) { switch (stat) { - case Stat.ATK: - case Stat.SPATK: - statStage.value = Math.max(statStage.value, 0); - break; - case Stat.DEF: - case Stat.SPDEF: - statStage.value = Math.min(statStage.value, 0); - break; + case Stat.ATK: + case Stat.SPATK: + statStage.value = Math.max(statStage.value, 0); + break; + case Stat.DEF: + case Stat.SPDEF: + statStage.value = Math.min(statStage.value, 0); + break; } } if (!ignoreOppAbility) { @@ -2322,11 +2517,61 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { return accuracyMultiplier.value / evasionMultiplier.value; } + /** + * Calculates the base damage of the given move against this Pokemon when attacked by the given source. + * Used during damage calculation and for Shell Side Arm's forecasting effect. + * @param source the attacking {@linkcode Pokemon}. + * @param move the {@linkcode Move} used in the attack. + * @param moveCategory the move's {@linkcode MoveCategory} after variable-category effects are applied. + * @param ignoreAbility if `true`, ignores this Pokemon's defensive ability effects (defaults to `false`). + * @param ignoreSourceAbility if `true`, ignore's the attacking Pokemon's ability effects (defaults to `false`). + * @param isCritical if `true`, calculates effective stats as if the hit were critical (defaults to `false`). + * @param simulated if `true`, suppresses changes to game state during calculation (defaults to `true`). + * @returns The move's base damage against this Pokemon when used by the source Pokemon. + */ + getBaseDamage(source: Pokemon, move: Move, moveCategory: MoveCategory, ignoreAbility: boolean = false, ignoreSourceAbility: boolean = false, isCritical: boolean = false, simulated: boolean = true): number { + const isPhysical = moveCategory === MoveCategory.PHYSICAL; + + /** A base damage multiplier based on the source's level */ + const levelMultiplier = (2 * source.level / 5 + 2); + + /** The power of the move after power boosts from abilities, etc. have applied */ + const power = move.calculateBattlePower(source, this, simulated); + + /** + * The attacker's offensive stat for the given move's category. + * Critical hits cause negative stat stages to be ignored. + */ + const sourceAtk = new Utils.NumberHolder(source.getEffectiveStat(isPhysical ? Stat.ATK : Stat.SPATK, this, undefined, ignoreSourceAbility, ignoreAbility, isCritical, simulated)); + applyMoveAttrs(VariableAtkAttr, source, this, move, sourceAtk); + + /** + * This Pokemon's defensive stat for the given move's category. + * Critical hits cause positive stat stages to be ignored. + */ + const targetDef = new Utils.NumberHolder(this.getEffectiveStat(isPhysical ? Stat.DEF : Stat.SPDEF, source, move, ignoreAbility, ignoreSourceAbility, isCritical, simulated)); + applyMoveAttrs(VariableDefAttr, source, this, move, targetDef); + + /** + * The attack's base damage, as determined by the source's level, move power + * and Attack stat as well as this Pokemon's Defense stat + */ + const baseDamage = ((levelMultiplier * power * sourceAtk.value / targetDef.value) / 50) + 2; + + /** Debug message for non-simulated calls (i.e. when damage is actually dealt) */ + if (!simulated) { + console.log("base damage", baseDamage, move.name, power, sourceAtk.value, targetDef.value); + } + + return baseDamage; + } + /** * Calculates the damage of an attack made by another Pokemon against this Pokemon * @param source {@linkcode Pokemon} the attacking Pokemon * @param move {@linkcode Pokemon} the move used in the attack * @param ignoreAbility If `true`, ignores this Pokemon's defensive ability effects + * @param ignoreSourceAbility If `true`, ignores the attacking Pokemon's ability effects * @param isCritical If `true`, calculates damage for a critical hit. * @param simulated If `true`, suppresses changes to game state during the calculation. * @returns a {@linkcode DamageCalculationResult} object with three fields: @@ -2377,6 +2622,10 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { const fixedDamage = new Utils.IntegerHolder(0); applyMoveAttrs(FixedDamageAttr, source, this, move, fixedDamage); if (fixedDamage.value) { + const multiLensMultiplier = new Utils.NumberHolder(1); + source.scene.applyModifiers(PokemonMultiHitModifier, source.isPlayer(), source, move.id, null, multiLensMultiplier); + fixedDamage.value = Utils.toDmgValue(fixedDamage.value * multiLensMultiplier.value); + return { cancelled: false, result: HitResult.EFFECTIVE, @@ -2395,45 +2644,22 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { }; } - // ----- BEGIN BASE DAMAGE MULTIPLIERS ----- - - /** A base damage multiplier based on the source's level */ - const levelMultiplier = (2 * source.level / 5 + 2); - - /** The power of the move after power boosts from abilities, etc. have applied */ - const power = move.calculateBattlePower(source, this, simulated); - - /** - * The attacker's offensive stat for the given move's category. - * Critical hits ignore negative stat stages. - */ - const sourceAtk = new Utils.NumberHolder(source.getEffectiveStat(isPhysical ? Stat.ATK : Stat.SPATK, this, undefined, ignoreSourceAbility, ignoreAbility, isCritical, simulated)); - applyMoveAttrs(VariableAtkAttr, source, this, move, sourceAtk); - - /** - * This Pokemon's defensive stat for the given move's category. - * Critical hits ignore positive stat stages. - */ - const targetDef = new Utils.NumberHolder(this.getEffectiveStat(isPhysical ? Stat.DEF : Stat.SPDEF, source, move, ignoreAbility, ignoreSourceAbility, isCritical, simulated)); - applyMoveAttrs(VariableDefAttr, source, this, move, targetDef); - /** * The attack's base damage, as determined by the source's level, move power * and Attack stat as well as this Pokemon's Defense stat */ - const baseDamage = ((levelMultiplier * power * sourceAtk.value / targetDef.value) / 50) + 2; - - // ------ END BASE DAMAGE MULTIPLIERS ------ + const baseDamage = this.getBaseDamage(source, move, moveCategory, ignoreAbility, ignoreSourceAbility, isCritical, simulated); /** 25% damage debuff on moves hitting more than one non-fainted target (regardless of immunities) */ const { targets, multiple } = getMoveTargets(source, move.id); const numTargets = multiple ? targets.length : 1; const targetMultiplier = (numTargets > 1) ? 0.75 : 1; - /** 0.25x multiplier if this is an added strike from the attacker's Parental Bond */ - const parentalBondMultiplier = new Utils.NumberHolder(1); + /** Multiplier for moves enhanced by Multi-Lens and/or Parental Bond */ + const multiStrikeEnhancementMultiplier = new Utils.NumberHolder(1); + source.scene.applyModifiers(PokemonMultiHitModifier, source.isPlayer(), source, move.id, null, multiStrikeEnhancementMultiplier); if (!ignoreSourceAbility) { - applyPreAttackAbAttrs(AddSecondStrikeAbAttr, source, this, move, simulated, numTargets, new Utils.IntegerHolder(0), parentalBondMultiplier); + applyPreAttackAbAttrs(AddSecondStrikeAbAttr, source, this, move, simulated, null, multiStrikeEnhancementMultiplier); } /** Doubles damage if this Pokemon's last move was Glaive Rush */ @@ -2460,6 +2686,7 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { if (matchesSourceType) { stabMultiplier.value += 0.5; } + applyMoveAttrs(CombinedPledgeStabBoostAttr, source, this, move, stabMultiplier); if (sourceTeraType !== Type.UNKNOWN && sourceTeraType === moveType) { stabMultiplier.value += 0.5; } @@ -2486,16 +2713,16 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { /** Reduces damage if this Pokemon has a relevant screen (e.g. Light Screen for special attacks) */ const screenMultiplier = new Utils.NumberHolder(1); - this.scene.arena.applyTagsForSide(WeakenMoveScreenTag, defendingSide, move.category, this.scene.currentBattle.double, screenMultiplier); + this.scene.arena.applyTagsForSide(WeakenMoveScreenTag, defendingSide, simulated, source, moveCategory, screenMultiplier); /** - * For each {@linkcode DealsDoubleDamageToTagAttr} the move has, doubles the damage of the move if: + * For each {@linkcode HitsTagAttr} the move has, doubles the damage of the move if: * The target has a {@linkcode BattlerTagType} that this move interacts with * AND * The move doubles damage when used against that tag */ const hitsTagMultiplier = new Utils.NumberHolder(1); - move.getAttrs(DealsDoubleDamageToTagAttr).filter(hta => hta.doubleDamage).forEach(hta => { + move.getAttrs(HitsTagAttr).filter(hta => hta.doubleDamage).forEach(hta => { if (this.getTag(hta.tagType)) { hitsTagMultiplier.value *= 2; } @@ -2509,7 +2736,7 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { damage.value = Utils.toDmgValue( baseDamage * targetMultiplier - * parentalBondMultiplier.value + * multiStrikeEnhancementMultiplier.value * arenaAttackTypeMultiplier.value * glaiveRushMultiplier.value * criticalMultiplier.value @@ -2535,9 +2762,15 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { this.scene.applyModifiers(EnemyDamageReducerModifier, false, damage); } + /** Apply this Pokemon's post-calc defensive modifiers (e.g. Fur Coat) */ if (!ignoreAbility) { applyPreDefendAbAttrs(ReceivedMoveDamageMultiplierAbAttr, this, source, move, cancelled, simulated, damage); + + /** Additionally apply friend guard damage reduction if ally has it. */ + if (this.scene.currentBattle.double && this.getAlly()?.isActive(true)) { + applyPreDefendAbAttrs(AlliedFieldDamageReductionAbAttr, this.getAlly(), source, move, cancelled, simulated, damage); + } } // This attribute may modify damage arbitrarily, so be careful about changing its order of application. @@ -2549,7 +2782,7 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { // debug message for when damage is applied (i.e. not simulated) if (!simulated) { - console.log("damage", damage.value, move.name, power, sourceAtk, targetDef); + console.log("damage", damage.value, move.name); } let hitResult: HitResult; @@ -2576,7 +2809,9 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { */ apply(source: Pokemon, move: Move): HitResult { const defendingSide = this.isPlayer() ? ArenaTagSide.PLAYER : ArenaTagSide.ENEMY; - if (move.category === MoveCategory.STATUS) { + const moveCategory = new Utils.NumberHolder(move.category); + applyMoveAttrs(VariableMoveCategoryAttr, source, this, move, moveCategory); + if (moveCategory.value === MoveCategory.STATUS) { const cancelled = new Utils.BooleanHolder(false); const typeMultiplier = this.getMoveEffectiveness(source, move, false, false, cancelled); @@ -2594,7 +2829,7 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { if (critOnly.value || critAlways) { isCritical = true; } else { - const critChance = [24, 8, 2, 1][Math.max(0, Math.min(this.getCritStage(source, move), 3))]; + const critChance = [ 24, 8, 2, 1 ][Math.max(0, Math.min(this.getCritStage(source, move), 3))]; isCritical = critChance === 1 || !this.scene.randBattleSeedInt(critChance); } @@ -2627,6 +2862,7 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { // In case of fatal damage, this tag would have gotten cleared before we could lapse it. const destinyTag = this.getTag(BattlerTagType.DESTINY_BOND); + const grudgeTag = this.getTag(BattlerTagType.GRUDGE); const isOneHitKo = result === HitResult.ONE_HIT_KO; @@ -2646,19 +2882,28 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { * We explicitly require to ignore the faint phase here, as we want to show the messages * about the critical hit and the super effective/not very effective messages before the faint phase. */ - const damage = this.damageAndUpdate(isBlockedBySubstitute ? 0 : dmg, result as DamageResult, isCritical, isOneHitKo, isOneHitKo, true); + const damage = this.damageAndUpdate(isBlockedBySubstitute ? 0 : dmg, result as DamageResult, isCritical, isOneHitKo, isOneHitKo, true, source); if (damage > 0) { if (source.isPlayer()) { - this.scene.validateAchvs(DamageAchv, damage); + this.scene.validateAchvs(DamageAchv, new Utils.NumberHolder(damage)); if (damage > this.scene.gameData.gameStats.highestDamage) { this.scene.gameData.gameStats.highestDamage = damage; } } - source.turnData.damageDealt += damage; - source.turnData.currDamageDealt = damage; + source.turnData.totalDamageDealt += damage; + source.turnData.singleHitDamageDealt = damage; this.turnData.damageTaken += damage; this.battleData.hitCount++; + + // Multi-Lens and Parental Bond check for Wimp Out/Emergency Exit + if (this.hasAbilityWithAttr(PostDamageForceSwitchAbAttr)) { + const multiHitModifier = source.getHeldItems().find(m => m instanceof PokemonMultiHitModifier); + if (multiHitModifier || source.hasAbilityWithAttr(AddSecondStrikeAbAttr)) { + applyPostDamageAbAttrs(PostDamageAbAttr, this, damage, this.hasPassive(), false, [], source); + } + } + const attackResult = { move: move.id, result: result as DamageResult, damage: damage, critical: isCritical, sourceId: source.id, sourceBattlerIndex: source.getBattlerIndex() }; this.turnData.attacksReceived.unshift(attackResult); if (source.isPlayer() && !this.isPlayer()) { @@ -2674,28 +2919,26 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { // want to include is.Fainted() in case multi hit move ends early, still want to render message if (source.turnData.hitsLeft === 1 || this.isFainted()) { switch (result) { - case HitResult.SUPER_EFFECTIVE: - this.scene.queueMessage(i18next.t("battle:hitResultSuperEffective")); - break; - case HitResult.NOT_VERY_EFFECTIVE: - this.scene.queueMessage(i18next.t("battle:hitResultNotVeryEffective")); - break; - case HitResult.ONE_HIT_KO: - this.scene.queueMessage(i18next.t("battle:hitResultOneHitKO")); - break; + case HitResult.SUPER_EFFECTIVE: + this.scene.queueMessage(i18next.t("battle:hitResultSuperEffective")); + break; + case HitResult.NOT_VERY_EFFECTIVE: + this.scene.queueMessage(i18next.t("battle:hitResultNotVeryEffective")); + break; + case HitResult.ONE_HIT_KO: + this.scene.queueMessage(i18next.t("battle:hitResultOneHitKO")); + break; } } if (this.isFainted()) { // set splice index here, so future scene queues happen before FaintedPhase this.scene.setPhaseQueueSplice(); - this.scene.unshiftPhase(new FaintPhase(this.scene, this.getBattlerIndex(), isOneHitKo)); - this.destroySubstitute(); - this.resetSummonData(); - } + this.scene.unshiftPhase(new FaintPhase(this.scene, this.getBattlerIndex(), isOneHitKo, destinyTag, grudgeTag, source)); - if (dmg) { - destinyTag?.lapse(source, BattlerTagLapseType.CUSTOM); + this.destroySubstitute(); + this.lapseTag(BattlerTagType.COMMANDED); + this.resetSummonData(); } return result; @@ -2721,6 +2964,8 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { surviveDamage.value = this.lapseTag(BattlerTagType.ENDURING); } else if (this.hp > 1 && this.getTag(BattlerTagType.STURDY)) { surviveDamage.value = this.lapseTag(BattlerTagType.STURDY); + } else if (this.hp >= 1 && this.getTag(BattlerTagType.ENDURE_TOKEN)) { + surviveDamage.value = this.lapseTag(BattlerTagType.ENDURE_TOKEN); } if (!surviveDamage.value) { this.scene.applyModifiers(SurviveDamageModifier, this.isPlayer(), this, surviveDamage); @@ -2743,9 +2988,9 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { this.scene.setPhaseQueueSplice(); this.scene.unshiftPhase(new FaintPhase(this.scene, this.getBattlerIndex(), preventEndure)); this.destroySubstitute(); + this.lapseTag(BattlerTagType.COMMANDED); this.resetSummonData(); } - return damage; } @@ -2759,12 +3004,13 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { * @param ignoreFaintPhase boolean to ignore adding a FaintPhase, passsed to damage() * @returns integer of damage done */ - damageAndUpdate(damage: integer, result?: DamageResult, critical: boolean = false, ignoreSegments: boolean = false, preventEndure: boolean = false, ignoreFaintPhase: boolean = false): integer { + damageAndUpdate(damage: integer, result?: DamageResult, critical: boolean = false, ignoreSegments: boolean = false, preventEndure: boolean = false, ignoreFaintPhase: boolean = false, source?: Pokemon): integer { const damagePhase = new DamagePhase(this.scene, this.getBattlerIndex(), damage, result as DamageResult, critical); this.scene.unshiftPhase(damagePhase); damage = this.damage(damage, ignoreSegments, preventEndure, ignoreFaintPhase); // Damage amount may have changed, but needed to be queued before calling damage function damagePhase.updateAmount(damage); + applyPostDamageAbAttrs(PostDamageAbAttr, this, damage, this.hasPassive(), false, [], source); return damage; } @@ -2779,7 +3025,7 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { } isMax(): boolean { - const maxForms = [SpeciesFormKey.GIGANTAMAX, SpeciesFormKey.GIGANTAMAX_RAPID, SpeciesFormKey.GIGANTAMAX_SINGLE, SpeciesFormKey.ETERNAMAX] as string[]; + const maxForms = [ SpeciesFormKey.GIGANTAMAX, SpeciesFormKey.GIGANTAMAX_RAPID, SpeciesFormKey.GIGANTAMAX_SINGLE, SpeciesFormKey.ETERNAMAX ] as string[]; return maxForms.includes(this.getFormKey()) || (!!this.getFusionFormKey() && maxForms.includes(this.getFusionFormKey()!)); } @@ -2825,19 +3071,19 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { } /** @overload */ - getTag(tagType: BattlerTagType): BattlerTag | null; + getTag(tagType: BattlerTagType): BattlerTag | nil; /** @overload */ - getTag(tagType: Constructor): T | null; + getTag(tagType: Constructor): T | nil; - getTag(tagType: BattlerTagType | Constructor): BattlerTag | null { + getTag(tagType: BattlerTagType | Constructor): BattlerTag | nil { if (!this.summonData) { return null; } return (tagType instanceof Function ? this.summonData.tags.find(t => t instanceof tagType) : this.summonData.tags.find(t => t.tagType === tagType) - )!; // TODO: is this bang correct? + ); } findTag(tagFilter: ((tag: BattlerTag) => boolean)) { @@ -2855,6 +3101,9 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { } lapseTag(tagType: BattlerTagType): boolean { + if (!this.summonData) { + return false; + } const tags = this.summonData.tags; const tag = tags.find(t => t.tagType === tagType); if (tag && !(tag.lapse(this, BattlerTagLapseType.CUSTOM))) { @@ -2865,6 +3114,9 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { } lapseTags(lapseType: BattlerTagLapseType): void { + if (!this.summonData) { + return; + } const tags = this.summonData.tags; tags.filter(t => lapseType === BattlerTagLapseType.FAINT || ((t.lapseTypes.some(lType => lType === lapseType)) && !(t.lapse(this, lapseType)))).forEach(t => { t.onRemove(this); @@ -2873,6 +3125,9 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { } removeTag(tagType: BattlerTagType): boolean { + if (!this.summonData) { + return false; + } const tags = this.summonData.tags; const tag = tags.find(t => t.tagType === tagType); if (tag) { @@ -2927,6 +3182,10 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { continue; } + if (tag instanceof PowerTrickTag) { + tag.swapStat(this); + } + this.summonData.tags.push(tag); } @@ -2941,19 +3200,43 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { * * @see {@linkcode MoveRestrictionBattlerTag} */ - isMoveRestricted(moveId: Moves): boolean { - return this.getRestrictingTag(moveId) !== null; + public isMoveRestricted(moveId: Moves, pokemon?: Pokemon): boolean { + return this.getRestrictingTag(moveId, pokemon) !== null; + } + + /** + * Gets whether the given move is currently disabled for the user based on the player's target selection + * + * @param {Moves} moveId {@linkcode Moves} ID of the move to check + * @param {Pokemon} user {@linkcode Pokemon} the move user + * @param {Pokemon} target {@linkcode Pokemon} the target of the move + * + * @returns {boolean} `true` if the move is disabled for this Pokemon due to the player's target selection + * + * @see {@linkcode MoveRestrictionBattlerTag} + */ + isMoveTargetRestricted(moveId: Moves, user: Pokemon, target: Pokemon): boolean { + for (const tag of this.findTags(t => t instanceof MoveRestrictionBattlerTag)) { + if ((tag as MoveRestrictionBattlerTag).isMoveTargetRestricted(moveId, user, target)) { + return (tag as MoveRestrictionBattlerTag !== null); + } + } + return false; } /** * Gets the {@link MoveRestrictionBattlerTag} that is restricting a move, if it exists. * * @param {Moves} moveId {@linkcode Moves} ID of the move to check + * @param {Pokemon} user {@linkcode Pokemon} the move user, optional and used when the target is a factor in the move's restricted status + * @param {Pokemon} target {@linkcode Pokemon} the target of the move, optional and used when the target is a factor in the move's restricted status * @returns {MoveRestrictionBattlerTag | null} the first tag on this Pokemon that restricts the move, or `null` if the move is not restricted. */ - getRestrictingTag(moveId: Moves): MoveRestrictionBattlerTag | null { + getRestrictingTag(moveId: Moves, user?: Pokemon, target?: Pokemon): MoveRestrictionBattlerTag | null { for (const tag of this.findTags(t => t instanceof MoveRestrictionBattlerTag)) { - if ((tag as MoveRestrictionBattlerTag).isMoveRestricted(moveId)) { + if ((tag as MoveRestrictionBattlerTag).isMoveRestricted(moveId, user)) { + return tag as MoveRestrictionBattlerTag; + } else if (user && target && (tag as MoveRestrictionBattlerTag).isMoveTargetRestricted(moveId, user, target)) { return tag as MoveRestrictionBattlerTag; } } @@ -2969,9 +3252,21 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { this.getMoveHistory().push(turnMove); } - getLastXMoves(turnCount: integer = 0): TurnMove[] { + /** + * Returns a list of the most recent move entries in this Pokemon's move history. + * The retrieved move entries are sorted in order from NEWEST to OLDEST. + * @param moveCount The number of move entries to retrieve. + * If negative, retrieve the Pokemon's entire move history (equivalent to reversing the output of {@linkcode getMoveHistory()}). + * Default is `1`. + * @returns A list of {@linkcode TurnMove}, as specified above. + */ + getLastXMoves(moveCount: number = 1): TurnMove[] { const moveHistory = this.getMoveHistory(); - return moveHistory.slice(turnCount >= 0 ? Math.max(moveHistory.length - (turnCount || 1), 0) : 0, moveHistory.length).reverse(); + if (moveCount >= 0) { + return moveHistory.slice(Math.max(moveHistory.length - moveCount, 0)).reverse(); + } else { + return moveHistory.slice(0).reverse(); + } } getMoveQueue(): QueuedMove[] { @@ -3019,7 +3314,7 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { try { SoundFade.fadeOut(scene, cry, Utils.fixedInt(Math.ceil(duration * 0.2))); fusionCry = this.getFusionSpeciesForm().cry(scene, Object.assign({ seek: Math.max(fusionCry.totalDuration * 0.4, 0) }, soundConfig)); - SoundFade.fadeIn(scene, fusionCry, Utils.fixedInt(Math.ceil(duration * 0.2)), scene.masterVolume * scene.seVolume, 0); + SoundFade.fadeIn(scene, fusionCry, Utils.fixedInt(Math.ceil(duration * 0.2)), scene.masterVolume * scene.fieldVolume, 0); } catch (err) { console.error(err); } @@ -3034,11 +3329,12 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { return this.fusionFaintCry(callback); } - const key = `cry/${this.species.getCryKey(this.formIndex)}`; - //eslint-disable-next-line @typescript-eslint/no-unused-vars - let i = 0; + const key = this.species.getCryKey(this.formIndex); let rate = 0.85; const cry = this.scene.playSound(key, { rate: rate }) as AnySound; + if (!cry || this.scene.fieldVolume === 0) { + return callback(); + } const sprite = this.getSprite(); const tintSprite = this.getTintSprite(); const delay = Math.max(this.scene.sound.get(key).totalDuration * 50, 25); @@ -3053,7 +3349,6 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { delay: Utils.fixedInt(delay), repeat: -1, callback: () => { - ++i; frameThreshold = sprite.anims.msPerFrame / rate; frameProgress += delay; while (frameProgress > frameThreshold) { @@ -3092,7 +3387,7 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { } private fusionFaintCry(callback: Function): void { - const key = `cry/${this.species.getCryKey(this.formIndex)}`; + const key = this.species.getCryKey(this.formIndex); let i = 0; let rate = 0.85; const cry = this.scene.playSound(key, { rate: rate }) as AnySound; @@ -3100,12 +3395,14 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { const tintSprite = this.getTintSprite(); let duration = cry.totalDuration * 1000; - const fusionCryKey = `cry/${this.fusionSpecies?.getCryKey(this.fusionFormIndex)}`; + const fusionCryKey = this.fusionSpecies!.getCryKey(this.fusionFormIndex); let fusionCry = this.scene.playSound(fusionCryKey, { rate: rate }) as AnySound; + if (!cry || !fusionCry || this.scene.fieldVolume === 0) { + return callback(); + } fusionCry.stop(); duration = Math.min(duration, fusionCry.totalDuration * 1000); fusionCry.destroy(); - const delay = Math.max(duration * 0.05, 25); let transitionIndex = 0; @@ -3143,10 +3440,10 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { } frameProgress -= frameThreshold; } - if (i === transitionIndex) { + if (i === transitionIndex && fusionCryKey) { SoundFade.fadeOut(this.scene, cry, Utils.fixedInt(Math.ceil((duration / rate) * 0.2))); fusionCry = this.scene.playSound(fusionCryKey, Object.assign({ seek: Math.max(fusionCry.totalDuration * 0.4, 0), rate: rate })); - SoundFade.fadeIn(this.scene, fusionCry, Utils.fixedInt(Math.ceil((duration / rate) * 0.2)), this.scene.masterVolume * this.scene.seVolume, 0); + SoundFade.fadeIn(this.scene, fusionCry, Utils.fixedInt(Math.ceil((duration / rate) * 0.2)), this.scene.masterVolume * this.scene.fieldVolume, 0); } rate *= 0.99; if (cry && !cry.pendingRemove) { @@ -3197,61 +3494,60 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { } } - const types = this.getTypes(true, true); - - const defendingSide = this.isPlayer() ? ArenaTagSide.PLAYER : ArenaTagSide.ENEMY; - if (sourcePokemon && sourcePokemon !== this && this.scene.arena.getTagOnSide(ArenaTagType.SAFEGUARD, defendingSide)) { + if (sourcePokemon && sourcePokemon !== this && this.isSafeguarded(sourcePokemon)) { return false; } - switch (effect) { - case StatusEffect.POISON: - case StatusEffect.TOXIC: - // Check if the Pokemon is immune to Poison/Toxic or if the source pokemon is canceling the immunity - const poisonImmunity = types.map(defType => { - // Check if the Pokemon is not immune to Poison/Toxic - if (defType !== Type.POISON && defType !== Type.STEEL) { - return false; - } + const types = this.getTypes(true, true); - // Check if the source Pokemon has an ability that cancels the Poison/Toxic immunity - const cancelImmunity = new Utils.BooleanHolder(false); - if (sourcePokemon) { - applyAbAttrs(IgnoreTypeStatusEffectImmunityAbAttr, sourcePokemon, cancelImmunity, false, effect, defType); - if (cancelImmunity.value) { + switch (effect) { + case StatusEffect.POISON: + case StatusEffect.TOXIC: + // Check if the Pokemon is immune to Poison/Toxic or if the source pokemon is canceling the immunity + const poisonImmunity = types.map(defType => { + // Check if the Pokemon is not immune to Poison/Toxic + if (defType !== Type.POISON && defType !== Type.STEEL) { + return false; + } + + // Check if the source Pokemon has an ability that cancels the Poison/Toxic immunity + const cancelImmunity = new Utils.BooleanHolder(false); + if (sourcePokemon) { + applyAbAttrs(IgnoreTypeStatusEffectImmunityAbAttr, sourcePokemon, cancelImmunity, false, effect, defType); + if (cancelImmunity.value) { + return false; + } + } + + return true; + }); + + if (this.isOfType(Type.POISON) || this.isOfType(Type.STEEL)) { + if (poisonImmunity.includes(true)) { return false; } } - - return true; - }); - - if (this.isOfType(Type.POISON) || this.isOfType(Type.STEEL)) { - if (poisonImmunity.includes(true)) { + break; + case StatusEffect.PARALYSIS: + if (this.isOfType(Type.ELECTRIC)) { return false; } - } - break; - case StatusEffect.PARALYSIS: - if (this.isOfType(Type.ELECTRIC)) { - return false; - } - break; - case StatusEffect.SLEEP: - if (this.isGrounded() && this.scene.arena.terrain?.terrainType === TerrainType.ELECTRIC) { - return false; - } - break; - case StatusEffect.FREEZE: - if (this.isOfType(Type.ICE) || (this.scene?.arena?.weather?.weatherType &&[WeatherType.SUNNY, WeatherType.HARSH_SUN].includes(this.scene.arena.weather.weatherType))) { - return false; - } - break; - case StatusEffect.BURN: - if (this.isOfType(Type.FIRE)) { - return false; - } - break; + break; + case StatusEffect.SLEEP: + if (this.isGrounded() && this.scene.arena.terrain?.terrainType === TerrainType.ELECTRIC) { + return false; + } + break; + case StatusEffect.FREEZE: + if (this.isOfType(Type.ICE) || (this.scene?.arena?.weather?.weatherType && [ WeatherType.SUNNY, WeatherType.HARSH_SUN ].includes(this.scene.arena.weather.weatherType))) { + return false; + } + break; + case StatusEffect.BURN: + if (this.isOfType(Type.FIRE)) { + return false; + } + break; } const cancelled = new Utils.BooleanHolder(false); @@ -3267,7 +3563,7 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { return true; } - trySetStatus(effect: StatusEffect | undefined, asPhase: boolean = false, sourcePokemon: Pokemon | null = null, cureTurn: integer | null = 0, sourceText: string | null = null): boolean { + trySetStatus(effect?: StatusEffect, asPhase: boolean = false, sourcePokemon: Pokemon | null = null, turnsRemaining: number = 0, sourceText: string | null = null): boolean { if (!this.canSetStatus(effect, asPhase, false, sourcePokemon)) { return false; } @@ -3281,15 +3577,14 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { } if (asPhase) { - this.scene.unshiftPhase(new ObtainStatusEffectPhase(this.scene, this.getBattlerIndex(), effect, cureTurn, sourceText!, sourcePokemon!)); // TODO: are these bangs correct? + this.scene.unshiftPhase(new ObtainStatusEffectPhase(this.scene, this.getBattlerIndex(), effect, turnsRemaining, sourceText, sourcePokemon)); return true; } - let statusCureTurn: Utils.IntegerHolder; + let sleepTurnsRemaining: Utils.NumberHolder; if (effect === StatusEffect.SLEEP) { - statusCureTurn = new Utils.IntegerHolder(this.randSeedIntRange(2, 4)); - applyAbAttrs(ReduceStatusEffectDurationAbAttr, this, null, false, effect, statusCureTurn); + sleepTurnsRemaining = new Utils.NumberHolder(this.randSeedIntRange(2, 4)); this.setFrameRate(4); @@ -3309,12 +3604,13 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { } } - statusCureTurn = statusCureTurn!; // tell TS compiler it's defined + sleepTurnsRemaining = sleepTurnsRemaining!; // tell TS compiler it's defined effect = effect!; // If `effect` is undefined then `trySetStatus()` will have already returned early via the `canSetStatus()` call - this.status = new Status(effect, 0, statusCureTurn?.value); + this.status = new Status(effect, 0, sleepTurnsRemaining?.value); if (effect !== StatusEffect.FAINT) { this.scene.triggerPokemonFormChange(this, SpeciesFormChangeStatusEffectTrigger, true); + applyPostSetStatusAbAttrs(PostSetStatusAbAttr, this, effect, sourcePokemon); } return true; @@ -3333,7 +3629,7 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { } this.status = null; if (lastStatus === StatusEffect.SLEEP) { - this.setFrameRate(12); + this.setFrameRate(10); if (this.getTag(BattlerTagType.NIGHTMARE)) { this.lapseTag(BattlerTagType.NIGHTMARE); } @@ -3348,6 +3644,23 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { } } + /** + * Checks if this Pokemon is protected by Safeguard + * @param attacker the {@linkcode Pokemon} inflicting status on this Pokemon + * @returns `true` if this Pokemon is protected by Safeguard; `false` otherwise. + */ + isSafeguarded(attacker: Pokemon): boolean { + const defendingSide = this.isPlayer() ? ArenaTagSide.PLAYER : ArenaTagSide.ENEMY; + if (this.scene.arena.getTagOnSide(ArenaTagType.SAFEGUARD, defendingSide)) { + const bypassed = new Utils.BooleanHolder(false); + if (attacker) { + applyAbAttrs(InfiltratorAbAttr, attacker, null, false, bypassed); + } + return !bypassed.value; + } + return false; + } + primeSummonData(summonDataPrimer: PokemonSummonData): void { this.summonDataPrimer = summonDataPrimer; } @@ -3358,6 +3671,7 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { this.updateFusionPalette(); } this.summonData = new PokemonSummonData(); + this.setSwitchOutStatus(false); if (!this.battleData) { this.resetBattleData(); } @@ -3373,6 +3687,13 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { this.scene.triggerPokemonBattleAnim(this, PokemonAnimType.SUBSTITUTE_ADD); this.getTag(SubstituteTag)!.sourceInFocus = false; } + + // If this Pokemon has Commander and Dondozo as an active ally, hide this Pokemon's sprite. + if (this.hasAbilityWithAttr(CommanderAbAttr) + && this.scene.currentBattle.double + && this.getAlly()?.species.speciesId === Species.DONDOZO) { + this.setVisible(false); + } this.summonDataPrimer = null; } this.updateInfo(); @@ -3534,7 +3855,7 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { const pixel = pixelData[f].slice(i, i + 4); let [ r, g, b, a ] = pixel; if (variantColors) { - const color = Utils.rgbaToInt([r, g, b, a]); + const color = Utils.rgbaToInt([ r, g, b, a ]); if (variantColorSet.has(color)) { const mappedPixel = variantColorSet.get(color); if (mappedPixel) { @@ -3578,7 +3899,7 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { } let [ r, g, b, a ] = [ pixelData[2 + f][i], pixelData[2 + f][i + 1], pixelData[2 + f][i + 2], pixelData[2 + f][i + 3] ]; if (variantColors) { - const color = Utils.rgbaToInt([r, g, b, a]); + const color = Utils.rgbaToInt([ r, g, b, a ]); if (variantColorSet.has(color)) { const mappedPixel = variantColorSet.get(color); if (mappedPixel) { @@ -3756,13 +4077,13 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { this.resetTurnData(); if (clearEffects) { this.destroySubstitute(); - this.resetSummonData(); - this.resetBattleData(); + this.resetSummonData(); // this also calls `resetBattleSummonData` } if (hideInfo) { this.hideInfo(); } this.scene.field.remove(this); + this.setSwitchOutStatus(true); this.scene.triggerPokemonFormChange(this, SpeciesFormChangeActiveTrigger, true); } @@ -3786,6 +4107,47 @@ export default abstract class Pokemon extends Phaser.GameObjects.Container { const rootForm = getPokemonSpecies(this.species.getRootSpeciesId()); return rootForm.getAbility(abilityIndex) === rootForm.getAbility(currentAbilityIndex); } + + /** + * Helper function to check if the player already owns the starter data of the Pokemon's + * current ability + * @param ownedAbilityAttrs the owned abilityAttr of this Pokemon's root form + * @returns true if the player already has it, false otherwise + */ + checkIfPlayerHasAbilityOfStarter(ownedAbilityAttrs: number): boolean { + if ((ownedAbilityAttrs & 1) > 0 && this.hasSameAbilityInRootForm(0)) { + return true; + } + if ((ownedAbilityAttrs & 2) > 0 && this.hasSameAbilityInRootForm(1)) { + return true; + } + if ((ownedAbilityAttrs & 4) > 0 && this.hasSameAbilityInRootForm(2)) { + return true; + } + return false; + } + + /** + * Reduces one of this Pokemon's held item stacks by 1, and removes the item if applicable. + * Does nothing if this Pokemon is somehow not the owner of the held item. + * @param heldItem The item stack to be reduced by 1. + * @param forBattle If `false`, do not trigger in-battle effects (such as Unburden) from losing the item. For example, set this to `false` if the Pokemon is giving away the held item for a Mystery Encounter. Default is `true`. + * @returns `true` if the item was removed successfully, `false` otherwise. + */ + public loseHeldItem(heldItem: PokemonHeldItemModifier, forBattle: boolean = true): boolean { + if (heldItem.pokemonId === -1 || heldItem.pokemonId === this.id) { + heldItem.stackCount--; + if (heldItem.stackCount <= 0) { + this.scene.removeModifier(heldItem, !this.isPlayer()); + } + if (forBattle) { + applyPostItemLostAbAttrs(PostItemLostAbAttr, this, false); + } + return true; + } else { + return false; + } + } } export default interface Pokemon { @@ -3799,16 +4161,20 @@ export class PlayerPokemon extends Pokemon { super(scene, 106, 148, species, level, abilityIndex, formIndex, gender, shiny, variant, ivs, nature, dataSource); if (Overrides.STATUS_OVERRIDE) { - this.status = new Status(Overrides.STATUS_OVERRIDE); + this.status = new Status(Overrides.STATUS_OVERRIDE, 0, 4); } if (Overrides.SHINY_OVERRIDE) { this.shiny = true; this.initShinySparkle(); - if (Overrides.VARIANT_OVERRIDE) { - this.variant = Overrides.VARIANT_OVERRIDE; - } + } else if (Overrides.SHINY_OVERRIDE === false) { + this.shiny = false; } + + if (Overrides.VARIANT_OVERRIDE !== null && this.shiny) { + this.variant = Overrides.VARIANT_OVERRIDE; + } + if (!dataSource) { if (this.scene.gameMode.isDaily) { this.generateAndPopulateMoveset(); @@ -3853,7 +4219,8 @@ export class PlayerPokemon extends Pokemon { let compatible = false; for (const p of tmSpecies[tm]) { if (Array.isArray(p)) { - if (p[0] === this.species.speciesId || (this.fusionSpecies && p[0] === this.fusionSpecies.speciesId) && p.slice(1).indexOf(this.species.forms[this.formIndex]) > -1) { + const [ pkm, form ] = p; + if ((pkm === this.species.speciesId || this.fusionSpecies && pkm === this.fusionSpecies.speciesId) && form === this.getFormKey()) { compatible = true; break; } @@ -3884,16 +4251,17 @@ export class PlayerPokemon extends Pokemon { /** * Causes this mon to leave the field (via {@linkcode leaveField}) and then * opens the party switcher UI to switch a new mon in - * @param batonPass Indicates if this switch was caused by a baton pass (and - * thus should maintain active mon effects) + * @param switchType the {@linkcode SwitchType} for this switch-out. If this is + * `BATON_PASS` or `SHED_TAIL`, this Pokemon's effects are not cleared upon leaving + * the field. */ - switchOut(batonPass: boolean): Promise { + switchOut(switchType: SwitchType = SwitchType.SWITCH): Promise { return new Promise(resolve => { - this.leaveField(!batonPass); + this.leaveField(switchType === SwitchType.SWITCH); this.scene.ui.setMode(Mode.PARTY, PartyUiMode.FAINT_SWITCH, this.getFieldIndex(), (slotIndex: integer, option: PartyOption) => { if (slotIndex >= this.scene.currentBattle.getBattlerCount() && slotIndex < 6) { - this.scene.prependToPhase(new SwitchSummonPhase(this.scene, this.getFieldIndex(), slotIndex, false, batonPass), MoveEndPhase); + this.scene.prependToPhase(new SwitchSummonPhase(this.scene, switchType, this.getFieldIndex(), slotIndex, false), MoveEndPhase); } this.scene.ui.setMode(Mode.MESSAGE).then(resolve); }, PartyUiHandler.FilterNonFainted); @@ -3908,7 +4276,11 @@ export class PlayerPokemon extends Pokemon { fusionStarterSpeciesId ? this.scene.gameData.starterData[fusionStarterSpeciesId] : null ].filter(d => !!d); const amount = new Utils.IntegerHolder(friendship); - const starterAmount = new Utils.IntegerHolder(Math.floor(friendship * (this.scene.gameMode.isClassic && friendship > 0 ? 2 : 1) / (fusionStarterSpeciesId ? 2 : 1))); + let candyFriendshipMultiplier = CLASSIC_CANDY_FRIENDSHIP_MULTIPLIER; + if (this.scene.eventManager.isEventActive()) { + candyFriendshipMultiplier *= this.scene.eventManager.getFriendshipMultiplier(); + } + const starterAmount = new Utils.IntegerHolder(Math.floor(friendship * (this.scene.gameMode.isClassic && friendship > 0 ? candyFriendshipMultiplier : 1) / (fusionStarterSpeciesId ? 2 : 1))); if (amount.value > 0) { this.scene.applyModifier(PokemonFriendshipBoosterModifier, true, this, amount); this.scene.applyModifier(PokemonFriendshipBoosterModifier, true, this, starterAmount); @@ -3920,7 +4292,7 @@ export class PlayerPokemon extends Pokemon { starterData.forEach((sd: StarterDataEntry, i: integer) => { const speciesId = !i ? starterSpeciesId : fusionStarterSpeciesId as Species; sd.friendship = (sd.friendship || 0) + starterAmount.value; - if (sd.friendship >= getStarterValueFriendshipCap(speciesStarters[speciesId])) { + if (sd.friendship >= getStarterValueFriendshipCap(speciesStarterCosts[speciesId])) { this.scene.gameData.addStarterCandy(getPokemonSpecies(speciesId), 1); sd.friendship = 0; } @@ -3940,8 +4312,8 @@ export class PlayerPokemon extends Pokemon { revivalBlessing(): Promise { return new Promise(resolve => { this.scene.ui.setMode(Mode.PARTY, PartyUiMode.REVIVAL_BLESSING, this.getFieldIndex(), (slotIndex:integer, option: PartyOption) => { - if (slotIndex >= 0 && slotIndex<6) { - const pokemon = this.scene.getParty()[slotIndex]; + if (slotIndex >= 0 && slotIndex < 6) { + const pokemon = this.scene.getPlayerParty()[slotIndex]; if (!pokemon || !pokemon.isFainted()) { resolve(); } @@ -3949,17 +4321,17 @@ export class PlayerPokemon extends Pokemon { pokemon.resetTurnData(); pokemon.resetStatus(); pokemon.heal(Math.min(Utils.toDmgValue(0.5 * pokemon.getMaxHp()), pokemon.getMaxHp())); - this.scene.queueMessage(i18next.t("moveTriggers:revivalBlessing", {pokemonName: pokemon.name}), 0, true); + this.scene.queueMessage(i18next.t("moveTriggers:revivalBlessing", { pokemonName: pokemon.name }), 0, true); - if (this.scene.currentBattle.double && this.scene.getParty().length > 1) { + if (this.scene.currentBattle.double && this.scene.getPlayerParty().length > 1) { const allyPokemon = this.getAlly(); - if (slotIndex<=1) { + if (slotIndex <= 1) { // Revived ally pokemon - this.scene.unshiftPhase(new SwitchSummonPhase(this.scene, pokemon.getFieldIndex(), slotIndex, false, false, true)); + this.scene.unshiftPhase(new SwitchSummonPhase(this.scene, SwitchType.SWITCH, pokemon.getFieldIndex(), slotIndex, false, true)); this.scene.unshiftPhase(new ToggleDoublePositionPhase(this.scene, true)); } else if (allyPokemon.isFainted()) { // Revived party pokemon, and ally pokemon is fainted - this.scene.unshiftPhase(new SwitchSummonPhase(this.scene, allyPokemon.getFieldIndex(), slotIndex, false, false, true)); + this.scene.unshiftPhase(new SwitchSummonPhase(this.scene, SwitchType.SWITCH, allyPokemon.getFieldIndex(), slotIndex, false, true)); this.scene.unshiftPhase(new ToggleDoublePositionPhase(this.scene, true)); } } @@ -4020,7 +4392,7 @@ export class PlayerPokemon extends Pokemon { if (!isFusion) { const abilityCount = this.getSpeciesForm().getAbilityCount(); const preEvoAbilityCount = preEvolution.getAbilityCount(); - if ([0, 1, 2].includes(this.abilityIndex)) { + if ([ 0, 1, 2 ].includes(this.abilityIndex)) { // Handles cases where a Pokemon with 3 abilities evolves into a Pokemon with 2 abilities (ie: Eevee -> any Eeveelution) if (this.abilityIndex === 2 && preEvoAbilityCount === 3 && abilityCount === 2) { this.abilityIndex = 1; @@ -4033,7 +4405,7 @@ export class PlayerPokemon extends Pokemon { } else { // Do the same as above, but for fusions const abilityCount = this.getFusionSpeciesForm().getAbilityCount(); const preEvoAbilityCount = preEvolution.getAbilityCount(); - if ([0, 1, 2].includes(this.fusionAbilityIndex)) { + if ([ 0, 1, 2 ].includes(this.fusionAbilityIndex)) { if (this.fusionAbilityIndex === 2 && preEvoAbilityCount === 3 && abilityCount === 2) { this.fusionAbilityIndex = 1; } @@ -4076,7 +4448,6 @@ export class PlayerPokemon extends Pokemon { if (newEvolution.condition?.predicate(this)) { const newPokemon = this.scene.addPlayerPokemon(this.species, this.level, this.abilityIndex, this.formIndex, undefined, this.shiny, this.variant, this.ivs, this.nature); - newPokemon.natureOverride = this.natureOverride; newPokemon.passive = this.passive; newPokemon.moveset = this.moveset.slice(); newPokemon.moveset = this.copyMoveset(); @@ -4094,7 +4465,7 @@ export class PlayerPokemon extends Pokemon { newPokemon.fusionLuck = this.fusionLuck; newPokemon.usedTMs = this.usedTMs; - this.scene.getParty().push(newPokemon); + this.scene.getPlayerParty().push(newPokemon); newPokemon.evolve((!isFusion ? newEvolution : new FusionSpeciesFormEvolution(this.id, newEvolution)), evoSpecies); const modifiers = this.scene.findModifiers(m => m instanceof PokemonHeldItemModifier && m.pokemonId === this.id, true) as PokemonHeldItemModifier[]; @@ -4118,12 +4489,33 @@ export class PlayerPokemon extends Pokemon { changeForm(formChange: SpeciesFormChange): Promise { return new Promise(resolve => { + const previousFormIndex = this.formIndex; this.formIndex = Math.max(this.species.forms.findIndex(f => f.formKey === formChange.formKey), 0); this.generateName(); const abilityCount = this.getSpeciesForm().getAbilityCount(); if (this.abilityIndex >= abilityCount) { // Shouldn't happen this.abilityIndex = abilityCount - 1; } + + // In cases where a form change updates the type of a Pokemon from its previous form (Arceus, Silvally, Castform, etc.), + // persist that type change in customPokemonData if necessary + const baseForm = this.species.forms[previousFormIndex]; + const baseFormTypes = [ baseForm.type1, baseForm.type2 ]; + if (this.customPokemonData.types.length > 0) { + if (this.getSpeciesForm().type1 !== baseFormTypes[0]) { + this.customPokemonData.types[0] = this.getSpeciesForm().type1; + } + + const type2 = this.getSpeciesForm().type2; + if (!isNullOrUndefined(type2) && type2 !== baseFormTypes[1]) { + if (this.customPokemonData.types.length > 1) { + this.customPokemonData.types[1] = type2; + } else { + this.customPokemonData.types.push(type2); + } + } + } + this.compatibleTms.splice(0, this.compatibleTms.length); this.generateCompatibleTms(); const updateAndResolve = () => { @@ -4160,6 +4552,7 @@ export class PlayerPokemon extends Pokemon { this.fusionVariant = pokemon.variant; this.fusionGender = pokemon.gender; this.fusionLuck = pokemon.luck; + this.fusionCustomPokemonData = pokemon.customPokemonData; if ((pokemon.pauseEvolutions) || (this.pauseEvolutions)) { this.pauseEvolutions = true; } @@ -4188,8 +4581,8 @@ export class PlayerPokemon extends Pokemon { this.generateCompatibleTms(); this.updateInfo(true); - const fusedPartyMemberIndex = this.scene.getParty().indexOf(pokemon); - let partyMemberIndex = this.scene.getParty().indexOf(this); + const fusedPartyMemberIndex = this.scene.getPlayerParty().indexOf(pokemon); + let partyMemberIndex = this.scene.getPlayerParty().indexOf(this); if (partyMemberIndex > fusedPartyMemberIndex) { partyMemberIndex--; } @@ -4197,14 +4590,14 @@ export class PlayerPokemon extends Pokemon { && m.pokemonId === pokemon.id, true) as PokemonHeldItemModifier[]; const transferModifiers: Promise[] = []; for (const modifier of fusedPartyMemberHeldModifiers) { - transferModifiers.push(this.scene.tryTransferHeldItemModifier(modifier, this, false, modifier.getStackCount(), true, true)); + transferModifiers.push(this.scene.tryTransferHeldItemModifier(modifier, this, false, modifier.getStackCount(), true, true, false)); } Promise.allSettled(transferModifiers).then(() => { this.scene.updateModifiers(true, true).then(() => { this.scene.removePartyMemberModifiers(fusedPartyMemberIndex); - this.scene.getParty().splice(fusedPartyMemberIndex, 1)[0]; - const newPartyMemberIndex = this.scene.getParty().indexOf(this); - pokemon.getMoveset(true).map(m => this.scene.unshiftPhase(new LearnMovePhase(this.scene, newPartyMemberIndex, m!.getMove().id))); // TODO: is the bang correct? + this.scene.getPlayerParty().splice(fusedPartyMemberIndex, 1)[0]; + const newPartyMemberIndex = this.scene.getPlayerParty().indexOf(this); + pokemon.getMoveset(true).map((m: PokemonMove) => this.scene.unshiftPhase(new LearnMovePhase(this.scene, newPartyMemberIndex, m.getMove().id))); pokemon.destroy(); this.updateFusionPalette(); resolve(); @@ -4225,8 +4618,12 @@ export class PlayerPokemon extends Pokemon { /** Returns a deep copy of this Pokemon's moveset array */ copyMoveset(): PokemonMove[] { const newMoveset : PokemonMove[] = []; - this.moveset.forEach(move => - newMoveset.push(new PokemonMove(move!.moveId, 0, move!.ppUp, move!.virtual))); // TODO: are those bangs correct? + this.moveset.forEach((move) => { + // TODO: refactor `moveset` to not accept `null`s + if (move) { + newMoveset.push(new PokemonMove(move.moveId, 0, move.ppUp, move.virtual, move.maxPpOverride)); + } + }); return newMoveset; } @@ -4251,7 +4648,7 @@ export class EnemyPokemon extends Pokemon { } if (Overrides.OPP_STATUS_OVERRIDE) { - this.status = new Status(Overrides.OPP_STATUS_OVERRIDE); + this.status = new Status(Overrides.OPP_STATUS_OVERRIDE, 0, 4); } if (Overrides.OPP_GENDER_OVERRIDE) { @@ -4260,9 +4657,11 @@ export class EnemyPokemon extends Pokemon { const speciesId = this.species.speciesId; - if (speciesId in Overrides.OPP_FORM_OVERRIDES + if ( + speciesId in Overrides.OPP_FORM_OVERRIDES && Overrides.OPP_FORM_OVERRIDES[speciesId] - && this.species.forms[Overrides.OPP_FORM_OVERRIDES[speciesId]]) { + && this.species.forms[Overrides.OPP_FORM_OVERRIDES[speciesId]] + ) { this.formIndex = Overrides.OPP_FORM_OVERRIDES[speciesId] ?? 0; } @@ -4273,10 +4672,13 @@ export class EnemyPokemon extends Pokemon { if (Overrides.OPP_SHINY_OVERRIDE) { this.shiny = true; this.initShinySparkle(); + } else if (Overrides.OPP_SHINY_OVERRIDE === false) { + this.shiny = false; } + if (this.shiny) { - this.variant = this.generateVariant(); - if (Overrides.OPP_VARIANT_OVERRIDE) { + this.variant = this.generateShinyVariant(); + if (Overrides.OPP_VARIANT_OVERRIDE !== null) { this.variant = Overrides.OPP_VARIANT_OVERRIDE; } } @@ -4326,35 +4728,35 @@ export class EnemyPokemon extends Pokemon { generateAndPopulateMoveset(formIndex?: integer): void { switch (true) { - case (this.species.speciesId === Species.SMEARGLE): - this.moveset = [ - new PokemonMove(Moves.SKETCH), - new PokemonMove(Moves.SKETCH), - new PokemonMove(Moves.SKETCH), - new PokemonMove(Moves.SKETCH) - ]; - break; - case (this.species.speciesId === Species.ETERNATUS): - this.moveset = (formIndex !== undefined ? formIndex : this.formIndex) - ? [ - new PokemonMove(Moves.DYNAMAX_CANNON), - new PokemonMove(Moves.CROSS_POISON), - new PokemonMove(Moves.FLAMETHROWER), - new PokemonMove(Moves.RECOVER, 0, -4) - ] - : [ - new PokemonMove(Moves.ETERNABEAM), - new PokemonMove(Moves.SLUDGE_BOMB), - new PokemonMove(Moves.FLAMETHROWER), - new PokemonMove(Moves.COSMIC_POWER) + case (this.species.speciesId === Species.SMEARGLE): + this.moveset = [ + new PokemonMove(Moves.SKETCH), + new PokemonMove(Moves.SKETCH), + new PokemonMove(Moves.SKETCH), + new PokemonMove(Moves.SKETCH) ]; - if (this.scene.gameMode.hasChallenge(Challenges.INVERSE_BATTLE)) { - this.moveset[2] = new PokemonMove(Moves.THUNDERBOLT); - } - break; - default: - super.generateAndPopulateMoveset(); - break; + break; + case (this.species.speciesId === Species.ETERNATUS): + this.moveset = (formIndex !== undefined ? formIndex : this.formIndex) + ? [ + new PokemonMove(Moves.DYNAMAX_CANNON), + new PokemonMove(Moves.CROSS_POISON), + new PokemonMove(Moves.FLAMETHROWER), + new PokemonMove(Moves.RECOVER, 0, -4) + ] + : [ + new PokemonMove(Moves.ETERNABEAM), + new PokemonMove(Moves.SLUDGE_BOMB), + new PokemonMove(Moves.FLAMETHROWER), + new PokemonMove(Moves.COSMIC_POWER) + ]; + if (this.scene.gameMode.hasChallenge(Challenges.INVERSE_BATTLE)) { + this.moveset[2] = new PokemonMove(Moves.THUNDERBOLT); + } + break; + default: + super.generateAndPopulateMoveset(); + break; } } @@ -4394,135 +4796,135 @@ export class EnemyPokemon extends Pokemon { } } switch (this.aiType) { - case AiType.RANDOM: // No enemy should spawn with this AI type in-game - const moveId = movePool[this.scene.randBattleSeedInt(movePool.length)]!.moveId; // TODO: is the bang correct? - return { move: moveId, targets: this.getNextTargets(moveId) }; - case AiType.SMART_RANDOM: - case AiType.SMART: + case AiType.RANDOM: // No enemy should spawn with this AI type in-game + const moveId = movePool[this.scene.randBattleSeedInt(movePool.length)]!.moveId; // TODO: is the bang correct? + return { move: moveId, targets: this.getNextTargets(moveId) }; + case AiType.SMART_RANDOM: + case AiType.SMART: /** * Search this Pokemon's move pool for moves that will KO an opposing target. * If there are any moves that can KO an opponent (i.e. a player Pokemon), * those moves are the only ones considered for selection on this turn. */ - const koMoves = movePool.filter(pkmnMove => { - if (!pkmnMove) { - return false; - } + const koMoves = movePool.filter(pkmnMove => { + if (!pkmnMove) { + return false; + } - const move = pkmnMove.getMove()!; - if (move.moveTarget === MoveTarget.ATTACKER) { - return false; - } + const move = pkmnMove.getMove()!; + if (move.moveTarget === MoveTarget.ATTACKER) { + return false; + } - const fieldPokemon = this.scene.getField(); - const moveTargets = getMoveTargets(this, move.id).targets - .map(ind => fieldPokemon[ind]) - .filter(p => this.isPlayer() !== p.isPlayer()); - // Only considers critical hits for crit-only moves or when this Pokemon is under the effect of Laser Focus - const isCritical = move.hasAttr(CritOnlyAttr) || !!this.getTag(BattlerTagType.ALWAYS_CRIT); + const fieldPokemon = this.scene.getField(); + const moveTargets = getMoveTargets(this, move.id).targets + .map(ind => fieldPokemon[ind]) + .filter(p => this.isPlayer() !== p.isPlayer()); + // Only considers critical hits for crit-only moves or when this Pokemon is under the effect of Laser Focus + const isCritical = move.hasAttr(CritOnlyAttr) || !!this.getTag(BattlerTagType.ALWAYS_CRIT); - return move.category !== MoveCategory.STATUS + return move.category !== MoveCategory.STATUS && moveTargets.some(p => { - const doesNotFail = move.applyConditions(this, p, move) || [Moves.SUCKER_PUNCH, Moves.UPPER_HAND, Moves.THUNDERCLAP].includes(move.id); + const doesNotFail = move.applyConditions(this, p, move) || [ Moves.SUCKER_PUNCH, Moves.UPPER_HAND, Moves.THUNDERCLAP ].includes(move.id); return doesNotFail && p.getAttackDamage(this, move, !p.battleData.abilityRevealed, false, isCritical).damage >= p.hp; }); - }, this); + }, this); - if (koMoves.length > 0) { - movePool = koMoves; - } + if (koMoves.length > 0) { + movePool = koMoves; + } - /** + /** * Move selection is based on the move's calculated "benefit score" against the * best possible target(s) (as determined by {@linkcode getNextTargets}). * For more information on how benefit scores are calculated, see `docs/enemy-ai.md`. */ - const moveScores = movePool.map(() => 0); - const moveTargets = Object.fromEntries(movePool.map(m => [ m!.moveId, this.getNextTargets(m!.moveId) ])); // TODO: are those bangs correct? - for (const m in movePool) { - const pokemonMove = movePool[m]!; // TODO: is the bang correct? - const move = pokemonMove.getMove(); + const moveScores = movePool.map(() => 0); + const moveTargets = Object.fromEntries(movePool.map(m => [ m!.moveId, this.getNextTargets(m!.moveId) ])); // TODO: are those bangs correct? + for (const m in movePool) { + const pokemonMove = movePool[m]!; // TODO: is the bang correct? + const move = pokemonMove.getMove(); - let moveScore = moveScores[m]; - const targetScores: integer[] = []; + let moveScore = moveScores[m]; + const targetScores: integer[] = []; - for (const mt of moveTargets[move.id]) { + for (const mt of moveTargets[move.id]) { // Prevent a target score from being calculated when the target is whoever attacks the user - if (mt === BattlerIndex.ATTACKER) { - break; - } + if (mt === BattlerIndex.ATTACKER) { + break; + } - const target = this.scene.getField()[mt]; - /** + const target = this.scene.getField()[mt]; + /** * The "target score" of a move is given by the move's user benefit score + the move's target benefit score. * If the target is an ally, the target benefit score is multiplied by -1. */ - let targetScore = move.getUserBenefitScore(this, target, move) + move.getTargetBenefitScore(this, target, move) * (mt < BattlerIndex.ENEMY === this.isPlayer() ? 1 : -1); - if (Number.isNaN(targetScore)) { - console.error(`Move ${move.name} returned score of NaN`); - targetScore = 0; - } - /** + let targetScore = move.getUserBenefitScore(this, target, move) + move.getTargetBenefitScore(this, target, move) * (mt < BattlerIndex.ENEMY === this.isPlayer() ? 1 : -1); + if (Number.isNaN(targetScore)) { + console.error(`Move ${move.name} returned score of NaN`); + targetScore = 0; + } + /** * If this move is unimplemented, or the move is known to fail when used, set its * target score to -20 */ - if ((move.name.endsWith(" (N)") || !move.applyConditions(this, target, move)) && ![Moves.SUCKER_PUNCH, Moves.UPPER_HAND, Moves.THUNDERCLAP].includes(move.id)) { - targetScore = -20; - } else if (move instanceof AttackMove) { + if ((move.name.endsWith(" (N)") || !move.applyConditions(this, target, move)) && ![ Moves.SUCKER_PUNCH, Moves.UPPER_HAND, Moves.THUNDERCLAP ].includes(move.id)) { + targetScore = -20; + } else if (move instanceof AttackMove) { /** * Attack moves are given extra multipliers to their base benefit score based on * the move's type effectiveness against the target and whether the move is a STAB move. */ - const effectiveness = target.getMoveEffectiveness(this, move, !target.battleData?.abilityRevealed); - if (target.isPlayer() !== this.isPlayer()) { - targetScore *= effectiveness; - if (this.isOfType(move.type)) { - targetScore *= 1.5; + const effectiveness = target.getMoveEffectiveness(this, move, !target.battleData?.abilityRevealed); + if (target.isPlayer() !== this.isPlayer()) { + targetScore *= effectiveness; + if (this.isOfType(move.type)) { + targetScore *= 1.5; + } + } else if (effectiveness) { + targetScore /= effectiveness; + if (this.isOfType(move.type)) { + targetScore /= 1.5; + } } - } else if (effectiveness) { - targetScore /= effectiveness; - if (this.isOfType(move.type)) { - targetScore /= 1.5; + /** If a move has a base benefit score of 0, its benefit score is assumed to be unimplemented at this point */ + if (!targetScore) { + targetScore = -20; } } - /** If a move has a base benefit score of 0, its benefit score is assumed to be unimplemented at this point */ - if (!targetScore) { - targetScore = -20; - } + targetScores.push(targetScore); } - targetScores.push(targetScore); + // When a move has multiple targets, its score is equal to the maximum target score across all targets + moveScore += Math.max(...targetScores); + + // could make smarter by checking opponent def/spdef + moveScores[m] = moveScore; } - // When a move has multiple targets, its score is equal to the maximum target score across all targets - moveScore += Math.max(...targetScores); - // could make smarter by checking opponent def/spdef - moveScores[m] = moveScore; - } + console.log(moveScores); - console.log(moveScores); - - // Sort the move pool in decreasing order of move score - const sortedMovePool = movePool.slice(0); - sortedMovePool.sort((a, b) => { - const scoreA = moveScores[movePool.indexOf(a)]; - const scoreB = moveScores[movePool.indexOf(b)]; - return scoreA < scoreB ? 1 : scoreA > scoreB ? -1 : 0; - }); - let r = 0; - if (this.aiType === AiType.SMART_RANDOM) { + // Sort the move pool in decreasing order of move score + const sortedMovePool = movePool.slice(0); + sortedMovePool.sort((a, b) => { + const scoreA = moveScores[movePool.indexOf(a)]; + const scoreB = moveScores[movePool.indexOf(b)]; + return scoreA < scoreB ? 1 : scoreA > scoreB ? -1 : 0; + }); + let r = 0; + if (this.aiType === AiType.SMART_RANDOM) { // Has a 5/8 chance to select the best move, and a 3/8 chance to advance to the next best move (and repeat this roll) - while (r < sortedMovePool.length - 1 && this.scene.randBattleSeedInt(8) >= 5) { - r++; - } - } else if (this.aiType === AiType.SMART) { + while (r < sortedMovePool.length - 1 && this.scene.randBattleSeedInt(8) >= 5) { + r++; + } + } else if (this.aiType === AiType.SMART) { // The chance to advance to the next best move increases when the compared moves' scores are closer to each other. - while (r < sortedMovePool.length - 1 && (moveScores[movePool.indexOf(sortedMovePool[r + 1])] / moveScores[movePool.indexOf(sortedMovePool[r])]) >= 0 + while (r < sortedMovePool.length - 1 && (moveScores[movePool.indexOf(sortedMovePool[r + 1])] / moveScores[movePool.indexOf(sortedMovePool[r])]) >= 0 && this.scene.randBattleSeedInt(100) < Math.round((moveScores[movePool.indexOf(sortedMovePool[r + 1])] / moveScores[movePool.indexOf(sortedMovePool[r])]) * 50)) { - r++; + r++; + } } - } - console.log(movePool.map(m => m!.getName()), moveScores, r, sortedMovePool.map(m => m!.getName())); // TODO: are those bangs correct? - return { move: sortedMovePool[r]!.moveId, targets: moveTargets[sortedMovePool[r]!.moveId] }; + console.log(movePool.map(m => m!.getName()), moveScores, r, sortedMovePool.map(m => m!.getName())); // TODO: are those bangs correct? + return { move: sortedMovePool[r]!.moveId, targets: moveTargets[sortedMovePool[r]!.moveId] }; } } @@ -4562,7 +4964,7 @@ export class EnemyPokemon extends Pokemon { // Set target to BattlerIndex.ATTACKER when using a counter move // This is the same as when the player does so if (move.hasAttr(CounterDamageAttr)) { - return [BattlerIndex.ATTACKER]; + return [ BattlerIndex.ATTACKER ]; } return []; @@ -4670,10 +5072,10 @@ export class EnemyPokemon extends Pokemon { } switch (this.scene.currentBattle.battleSpec) { - case BattleSpec.FINAL_BOSS: - if (!this.formIndex && this.bossSegmentIndex < 1) { - damage = Math.min(damage, this.hp - 1); - } + case BattleSpec.FINAL_BOSS: + if (!this.formIndex && this.bossSegmentIndex < 1) { + damage = Math.min(damage, this.hp - 1); + } } const ret = super.damage(damage, ignoreSegments, preventEndure, ignoreFaintPhase); @@ -4702,8 +5104,15 @@ export class EnemyPokemon extends Pokemon { return true; } + /** + * Go through a boss' health segments and give stats boosts for each newly cleared segment + * The base boost is 1 to a random stat that's not already maxed out per broken shield + * For Pokemon with 3 health segments or more, breaking the last shield gives +2 instead + * For Pokemon with 5 health segments or more, breaking the last two shields give +2 each + * @param segmentIndex index of the segment to get down to (0 = no shield left, 1 = 1 shield left, etc.) + */ handleBossSegmentCleared(segmentIndex: integer): void { - while (segmentIndex - 1 < this.bossSegmentIndex) { + while (this.bossSegmentIndex > 0 && segmentIndex - 1 < this.bossSegmentIndex) { // Filter out already maxed out stat stages and weigh the rest based on existing stats const leftoverStats = EFFECTIVE_STATS.filter((s: EffectiveStat) => this.getStatStage(s) < 6); const statWeights = leftoverStats.map((s: EffectiveStat) => this.getStat(s, false)); @@ -4742,26 +5151,6 @@ export class EnemyPokemon extends Pokemon { } } - heal(amount: integer): integer { - if (this.isBoss()) { - const amountRatio = amount / this.getMaxHp(); - const segmentBypassCount = Math.floor(amountRatio / (1 / this.bossSegments)); - const segmentSize = this.getMaxHp() / this.bossSegments; - for (let s = 1; s < this.bossSegments; s++) { - const hpThreshold = segmentSize * s; - if (this.hp <= Math.round(hpThreshold)) { - const healAmount = Math.min(amount, this.getMaxHp() - this.hp, Math.round(hpThreshold + (segmentSize * segmentBypassCount) - this.hp)); - this.hp += healAmount; - return healAmount; - } else if (s >= this.bossSegmentIndex) { - return super.heal(amount); - } - } - } - - return super.heal(amount); - } - getFieldIndex(): integer { return this.scene.getEnemyField().indexOf(this); } @@ -4772,12 +5161,13 @@ export class EnemyPokemon extends Pokemon { /** * Add a new pokemon to the player's party (at `slotIndex` if set). + * The new pokemon's visibility will be set to `false`. * @param pokeballType the type of pokeball the pokemon was caught with * @param slotIndex an optional index to place the pokemon in the party * @returns the pokemon that was added or null if the pokemon could not be added */ addToParty(pokeballType: PokeballType, slotIndex: number = -1) { - const party = this.scene.getParty(); + const party = this.scene.getPlayerParty(); let ret: PlayerPokemon | null = null; if (party.length < PLAYER_PARTY_MAX_SIZE) { @@ -4794,6 +5184,9 @@ export class EnemyPokemon extends Pokemon { party.push(newPokemon); } + // Hide the Pokemon since it is not on the field + newPokemon.setVisible(false); + ret = newPokemon; this.scene.triggerPokemonFormChange(newPokemon, SpeciesFormChangeActiveTrigger, true); } @@ -4832,7 +5225,6 @@ export class PokemonSummonData { public tags: BattlerTag[] = []; public abilitySuppressed: boolean = false; public abilitiesApplied: Abilities[] = []; - public speciesForm: PokemonSpeciesForm | null; public fusionSpeciesForm: PokemonSpeciesForm; public ability: Abilities = Abilities.NONE; @@ -4843,6 +5235,7 @@ export class PokemonSummonData { public moveset: (PokemonMove | null)[]; // If not initialized this value will not be populated from save data. public types: Type[] = []; + public addedType: Type | null = null; } export class PokemonBattleData { @@ -4856,6 +5249,8 @@ export class PokemonBattleData { export class PokemonBattleSummonData { /** The number of turns the pokemon has passed since entering the battle */ public turnCount: number = 1; + /** The number of turns the pokemon has passed since the start of the wave */ + public waveTurnCount: number = 1; /** The list of moves the pokemon has used since entering the battle */ public moveHistory: TurnMove[] = []; } @@ -4863,15 +5258,24 @@ export class PokemonBattleSummonData { export class PokemonTurnData { public flinched: boolean = false; public acted: boolean = false; - public hitCount: number; - public hitsLeft: number; - public damageDealt: number = 0; - public currDamageDealt: number = 0; + public hitCount: number = 0; + /** + * - `-1` = Calculate how many hits are left + * - `0` = Move is finished + */ + public hitsLeft: number = -1; + public totalDamageDealt: number = 0; + public singleHitDamageDealt: number = 0; public damageTaken: number = 0; public attacksReceived: AttackMoveResult[] = []; public order: number; public statStagesIncreased: boolean = false; public statStagesDecreased: boolean = false; + public moveEffectiveness: TypeDamageMultiplier | null = null; + public combiningPledge?: Moves; + public switchedInThisTurn: boolean = false; + public failedRunAway: boolean = false; + public joinedRound: boolean = false; } export enum AiType { @@ -4929,15 +5333,22 @@ export interface DamageCalculationResult { **/ export class PokemonMove { public moveId: Moves; - public ppUsed: integer; - public ppUp: integer; + public ppUsed: number; + public ppUp: number; public virtual: boolean; - constructor(moveId: Moves, ppUsed?: integer, ppUp?: integer, virtual?: boolean) { + /** + * If defined and nonzero, overrides the maximum PP of the move (e.g., due to move being copied by Transform). + * This also nullifies all effects of `ppUp`. + */ + public maxPpOverride?: number; + + constructor(moveId: Moves, ppUsed: number = 0, ppUp: number = 0, virtual: boolean = false, maxPpOverride?: number) { this.moveId = moveId; - this.ppUsed = ppUsed || 0; - this.ppUp = ppUp || 0; - this.virtual = !!virtual; + this.ppUsed = ppUsed; + this.ppUp = ppUp; + this.virtual = virtual; + this.maxPpOverride = maxPpOverride; } /** @@ -4949,8 +5360,8 @@ export class PokemonMove { * @param {boolean} ignoreRestrictionTags If `true`, skips the check for move restriction tags (see {@link MoveRestrictionBattlerTag}) * @returns `true` if the move can be selected and used by the Pokemon, otherwise `false`. */ - isUsable(pokemon: Pokemon, ignorePp?: boolean, ignoreRestrictionTags?: boolean): boolean { - if (this.moveId && !ignoreRestrictionTags && pokemon.isMoveRestricted(this.moveId)) { + isUsable(pokemon: Pokemon, ignorePp: boolean = false, ignoreRestrictionTags: boolean = false): boolean { + if (this.moveId && !ignoreRestrictionTags && pokemon.isMoveRestricted(this.moveId, pokemon)) { return false; } @@ -4974,7 +5385,7 @@ export class PokemonMove { } getMovePp(): integer { - return this.getMove().pp + this.ppUp * Utils.toDmgValue(this.getMove().pp / 5); + return this.maxPpOverride || (this.getMove().pp + this.ppUp * Utils.toDmgValue(this.getMove().pp / 5)); } getPpRatio(): number { @@ -4991,6 +5402,6 @@ export class PokemonMove { * @return {PokemonMove} A valid pokemonmove object */ static loadMove(source: PokemonMove | any): PokemonMove { - return new PokemonMove(source.moveId, source.ppUsed, source.ppUp, source.virtual); + return new PokemonMove(source.moveId, source.ppUsed, source.ppUp, source.virtual, source.maxPpOverride); } } diff --git a/src/field/trainer.ts b/src/field/trainer.ts index 1973d7216a6..b77a156f401 100644 --- a/src/field/trainer.ts +++ b/src/field/trainer.ts @@ -1,6 +1,6 @@ -import BattleScene from "../battle-scene"; -import {pokemonPrevolutions} from "../data/pokemon-evolutions"; -import PokemonSpecies, {getPokemonSpecies} from "../data/pokemon-species"; +import BattleScene from "#app/battle-scene"; +import { pokemonPrevolutions } from "#app/data/balance/pokemon-evolutions"; +import PokemonSpecies, { getPokemonSpecies } from "#app/data/pokemon-species"; import { TrainerConfig, TrainerPartyCompoundTemplate, @@ -10,13 +10,13 @@ import { trainerConfigs, trainerPartyTemplates, signatureSpecies -} from "../data/trainer-config"; -import {EnemyPokemon} from "./pokemon"; -import * as Utils from "../utils"; -import {PersistentModifier} from "../modifier/modifier"; -import {trainerNamePools} from "../data/trainer-names"; -import {ArenaTagSide, ArenaTrapTag} from "#app/data/arena-tag"; -import {getIsInitialized, initI18n} from "#app/plugins/i18n"; +} from "#app/data/trainer-config"; +import { EnemyPokemon } from "#app/field/pokemon"; +import * as Utils from "#app/utils"; +import { PersistentModifier } from "#app/modifier/modifier"; +import { trainerNamePools } from "#app/data/trainer-names"; +import { ArenaTagSide, ArenaTrapTag } from "#app/data/arena-tag"; +import { getIsInitialized, initI18n } from "#app/plugins/i18n"; import i18next from "i18next"; import { PartyMemberStrength } from "#enums/party-member-strength"; import { Species } from "#enums/species"; @@ -56,7 +56,7 @@ export default class Trainer extends Phaser.GameObjects.Container { if (partnerName) { this.partnerName = partnerName; } else { - [this.name, this.partnerName] = this.name.split(" & "); + [ this.name, this.partnerName ] = this.name.split(" & "); } } else { this.partnerName = partnerName || Utils.randSeedItem(Array.isArray(namePool[0]) ? namePool[1] : namePool); @@ -65,16 +65,16 @@ export default class Trainer extends Phaser.GameObjects.Container { } switch (this.variant) { - case TrainerVariant.FEMALE: - if (!this.config.hasGenders) { - variant = TrainerVariant.DEFAULT; - } - break; - case TrainerVariant.DOUBLE: - if (!this.config.hasDouble) { - variant = TrainerVariant.DEFAULT; - } - break; + case TrainerVariant.FEMALE: + if (!this.config.hasGenders) { + variant = TrainerVariant.DEFAULT; + } + break; + case TrainerVariant.DOUBLE: + if (!this.config.hasDouble) { + variant = TrainerVariant.DEFAULT; + } + break; } console.log(Object.keys(trainerPartyTemplates)[Object.values(trainerPartyTemplates).indexOf(this.getPartyTemplate())]); @@ -82,7 +82,7 @@ export default class Trainer extends Phaser.GameObjects.Container { const getSprite = (hasShadow?: boolean, forceFemale?: boolean) => { const ret = this.scene.addFieldSprite(0, 0, this.config.getSpriteKey(variant === TrainerVariant.FEMALE || forceFemale, this.isDouble())); ret.setOrigin(0.5, 1); - ret.setPipeline(this.scene.spritePipeline, {tone: [0.0, 0.0, 0.0, 0.0], hasShadow: !!hasShadow}); + ret.setPipeline(this.scene.spritePipeline, { tone: [ 0.0, 0.0, 0.0, 0.0 ], hasShadow: !!hasShadow }); return ret; }; @@ -126,7 +126,7 @@ export default class Trainer extends Phaser.GameObjects.Container { // Determine the title to include based on the configuration and includeTitle flag. let title = includeTitle && this.config.title ? this.config.title : null; - const evilTeamTitles = ["grunt"]; + const evilTeamTitles = [ "grunt" ]; if (this.name === "" && evilTeamTitles.some(t => name.toLocaleLowerCase().includes(t))) { // This is a evil team grunt so we localize it by only using the "name" as the title title = i18next.t(`trainerClasses:${name.toLowerCase().replace(/\s/g, "_")}`); @@ -229,21 +229,21 @@ export default class Trainer extends Phaser.GameObjects.Container { const strength = partyTemplate.getStrength(i); switch (strength) { - case PartyMemberStrength.WEAKER: - multiplier = 0.95; - break; - case PartyMemberStrength.WEAK: - multiplier = 1.0; - break; - case PartyMemberStrength.AVERAGE: - multiplier = 1.1; - break; - case PartyMemberStrength.STRONG: - multiplier = 1.2; - break; - case PartyMemberStrength.STRONGER: - multiplier = 1.25; - break; + case PartyMemberStrength.WEAKER: + multiplier = 0.95; + break; + case PartyMemberStrength.WEAK: + multiplier = 1.0; + break; + case PartyMemberStrength.AVERAGE: + multiplier = 1.1; + break; + case PartyMemberStrength.STRONG: + multiplier = 1.2; + break; + case PartyMemberStrength.STRONGER: + multiplier = 1.25; + break; } let levelOffset = 0; @@ -336,9 +336,9 @@ export default class Trainer extends Phaser.GameObjects.Container { if (!(index % 2)) { // Since the only currently allowed double battle with named trainers is Tate & Liza, we need to make sure that Solrock is the first pokemon in the party for Tate and Lunatone for Liza if (index === 0 && (TrainerType[this.config.trainerType] === TrainerType[TrainerType.TATE])) { - newSpeciesPool = [Species.SOLROCK]; + newSpeciesPool = [ Species.SOLROCK ]; } else if (index === 0 && (TrainerType[this.config.trainerType] === TrainerType[TrainerType.LIZA])) { - newSpeciesPool = [Species.LUNATONE]; + newSpeciesPool = [ Species.LUNATONE ]; } else { newSpeciesPool = speciesPoolFiltered; } @@ -346,9 +346,9 @@ export default class Trainer extends Phaser.GameObjects.Container { // If the index is odd, use the species pool for the partner trainer (that way he only uses his own pokemon in battle) // Since the only currently allowed double battle with named trainers is Tate & Liza, we need to make sure that Solrock is the first pokemon in the party for Tate and Lunatone for Liza if (index === 1 && (TrainerType[this.config.trainerTypeDouble] === TrainerType[TrainerType.TATE])) { - newSpeciesPool = [Species.SOLROCK]; + newSpeciesPool = [ Species.SOLROCK ]; } else if (index === 1 && (TrainerType[this.config.trainerTypeDouble] === TrainerType[TrainerType.LIZA])) { - newSpeciesPool = [Species.LUNATONE]; + newSpeciesPool = [ Species.LUNATONE ]; } else { newSpeciesPool = speciesPoolPartnerFiltered; } @@ -383,7 +383,7 @@ export default class Trainer extends Phaser.GameObjects.Container { const battle = this.scene.currentBattle; const template = this.getPartyTemplate(); - let species: PokemonSpecies; + let baseSpecies: PokemonSpecies; if (this.config.speciesPools) { const tierValue = Utils.randSeedInt(512); let tier = tierValue >= 156 ? TrainerPoolTier.COMMON : tierValue >= 32 ? TrainerPoolTier.UNCOMMON : tierValue >= 6 ? TrainerPoolTier.RARE : tierValue >= 1 ? TrainerPoolTier.SUPER_RARE : TrainerPoolTier.ULTRA_RARE; @@ -393,17 +393,17 @@ export default class Trainer extends Phaser.GameObjects.Container { tier--; } const tierPool = this.config.speciesPools[tier]; - species = getPokemonSpecies(Utils.randSeedItem(tierPool)); + baseSpecies = getPokemonSpecies(Utils.randSeedItem(tierPool)); } else { - species = this.scene.randomSpecies(battle.waveIndex, level, false, this.config.speciesFilter); + baseSpecies = this.scene.randomSpecies(battle.waveIndex, level, false, this.config.speciesFilter); } - let ret = getPokemonSpecies(species.getTrainerSpeciesForLevel(level, true, strength, this.scene.currentBattle.waveIndex)); + let ret = getPokemonSpecies(baseSpecies.getTrainerSpeciesForLevel(level, true, strength, this.scene.currentBattle.waveIndex)); let retry = false; console.log(ret.getName()); - if (pokemonPrevolutions.hasOwnProperty(species.speciesId) && ret.speciesId !== species.speciesId) { + if (pokemonPrevolutions.hasOwnProperty(baseSpecies.speciesId) && ret.speciesId !== baseSpecies.speciesId) { retry = true; } else if (template.isBalanced(battle.enemyParty.length)) { const partyMemberTypes = battle.enemyParty.map(p => p.getTypes(true)).flat(); @@ -417,7 +417,7 @@ export default class Trainer extends Phaser.GameObjects.Container { console.log("Attempting reroll of species evolution to fit specialty type..."); let evoAttempt = 0; while (retry && evoAttempt++ < 10) { - ret = getPokemonSpecies(species.getTrainerSpeciesForLevel(level, true, strength, this.scene.currentBattle.waveIndex)); + ret = getPokemonSpecies(baseSpecies.getTrainerSpeciesForLevel(level, true, strength, this.scene.currentBattle.waveIndex)); console.log(ret.name); if (this.config.specialtyTypes.find(t => ret.isOfType(t))) { retry = false; @@ -425,14 +425,35 @@ export default class Trainer extends Phaser.GameObjects.Container { } } - if (retry && (attempt || 0) < 10) { + // Prompts reroll of party member species if species already present in the enemy party + if (this.checkDuplicateSpecies(ret, baseSpecies)) { + console.log("Duplicate species detected, prompting reroll..."); + retry = true; + } + + if (retry && (attempt ?? 0) < 10) { console.log("Rerolling party member..."); - ret = this.genNewPartyMemberSpecies(level, strength, (attempt || 0) + 1); + ret = this.genNewPartyMemberSpecies(level, strength, (attempt ?? 0) + 1); } return ret; } + /** + * Checks if the enemy trainer already has the Pokemon species in their party + * @param {PokemonSpecies} species {@linkcode PokemonSpecies} + * @param {PokemonSpecies} baseSpecies {@linkcode PokemonSpecies} - baseSpecies of the Pokemon if species is forced to evolve + * @returns `true` if the species is already present in the party + */ + checkDuplicateSpecies(species: PokemonSpecies, baseSpecies: PokemonSpecies): boolean { + const staticPartyPokemon = (signatureSpecies[TrainerType[this.config.trainerType]] ?? []).flat(1); + + const currentPartySpecies = this.scene.getEnemyParty().map(p => { + return p.species.speciesId; + }); + return currentPartySpecies.includes(species.speciesId) || staticPartyPokemon.includes(baseSpecies.speciesId); + } + getPartyMemberMatchupScores(trainerSlot: TrainerSlot = TrainerSlot.NONE, forSwitch: boolean = false): [integer, integer][] { if (trainerSlot && !this.isDouble()) { trainerSlot = TrainerSlot.NONE; @@ -457,7 +478,7 @@ export default class Trainer extends Phaser.GameObjects.Container { } } - return [party.indexOf(p), score]; + return [ party.indexOf(p), score ]; }) as [integer, integer][]; return partyMemberScores; @@ -494,19 +515,19 @@ export default class Trainer extends Phaser.GameObjects.Container { getPartyMemberModifierChanceMultiplier(index: integer): number { switch (this.getPartyTemplate().getStrength(index)) { - case PartyMemberStrength.WEAKER: - return 0.75; - case PartyMemberStrength.WEAK: - return 0.675; - case PartyMemberStrength.AVERAGE: - return 0.5625; - case PartyMemberStrength.STRONG: - return 0.45; - case PartyMemberStrength.STRONGER: - return 0.375; - default: - console.warn("getPartyMemberModifierChanceMultiplier not defined. Using default 0"); - return 0; + case PartyMemberStrength.WEAKER: + return 0.75; + case PartyMemberStrength.WEAK: + return 0.675; + case PartyMemberStrength.AVERAGE: + return 0.5625; + case PartyMemberStrength.STRONG: + return 0.45; + case PartyMemberStrength.STRONGER: + return 0.375; + default: + console.warn("getPartyMemberModifierChanceMultiplier not defined. Using default 0"); + return 0; } } diff --git a/src/game-mode.ts b/src/game-mode.ts index a2d61d7cfff..3f12c5b056e 100644 --- a/src/game-mode.ts +++ b/src/game-mode.ts @@ -33,8 +33,8 @@ interface GameModeConfig { } // Describes min and max waves for MEs in specific game modes -export const CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES: [number, number] = [10, 180]; -export const CHALLENGE_MODE_MYSTERY_ENCOUNTER_WAVES: [number, number] = [10, 180]; +export const CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES: [number, number] = [ 10, 180 ]; +export const CHALLENGE_MODE_MYSTERY_ENCOUNTER_WAVES: [number, number] = [ 10, 180 ]; export class GameMode implements GameModeConfig { public modeId: GameModes; @@ -92,10 +92,10 @@ export class GameMode implements GameModeConfig { return Overrides.STARTING_LEVEL_OVERRIDE; } switch (this.modeId) { - case GameModes.DAILY: - return 20; - default: - return 5; + case GameModes.DAILY: + return 20; + default: + return 5; } } @@ -117,19 +117,19 @@ export class GameMode implements GameModeConfig { */ getStartingBiome(scene: BattleScene): Biome { switch (this.modeId) { - case GameModes.DAILY: - return scene.generateRandomBiome(this.getWaveForDifficulty(1)); - default: - return Overrides.STARTING_BIOME_OVERRIDE || Biome.TOWN; + case GameModes.DAILY: + return scene.generateRandomBiome(this.getWaveForDifficulty(1)); + default: + return Overrides.STARTING_BIOME_OVERRIDE || Biome.TOWN; } } getWaveForDifficulty(waveIndex: integer, ignoreCurveChanges: boolean = false): integer { switch (this.modeId) { - case GameModes.DAILY: - return waveIndex + 30 + (!ignoreCurveChanges ? Math.floor(waveIndex / 5) : 0); - default: - return waveIndex; + case GameModes.DAILY: + return waveIndex + 30 + (!ignoreCurveChanges ? Math.floor(waveIndex / 5) : 0); + default: + return waveIndex; } } @@ -186,10 +186,10 @@ export class GameMode implements GameModeConfig { isTrainerBoss(waveIndex: integer, biomeType: Biome, offsetGym: boolean): boolean { switch (this.modeId) { - case GameModes.DAILY: - return waveIndex > 10 && waveIndex < 50 && !(waveIndex % 10); - default: - return (waveIndex % 30) === (offsetGym ? 0 : 20) && (biomeType !== Biome.END || this.isClassic || this.isWaveFinal(waveIndex)); + case GameModes.DAILY: + return waveIndex > 10 && waveIndex < 50 && !(waveIndex % 10); + default: + return (waveIndex % 30) === (offsetGym ? 0 : 20) && (biomeType !== Biome.END || this.isClassic || this.isWaveFinal(waveIndex)); } } @@ -211,14 +211,14 @@ export class GameMode implements GameModeConfig { */ isWaveFinal(waveIndex: integer, modeId: GameModes = this.modeId): boolean { switch (modeId) { - case GameModes.CLASSIC: - case GameModes.CHALLENGE: - return waveIndex === 200; - case GameModes.ENDLESS: - case GameModes.SPLICED_ENDLESS: - return !(waveIndex % 250); - case GameModes.DAILY: - return waveIndex === 50; + case GameModes.CLASSIC: + case GameModes.CHALLENGE: + return waveIndex === 200; + case GameModes.ENDLESS: + case GameModes.SPLICED_ENDLESS: + return !(waveIndex % 250); + case GameModes.DAILY: + return waveIndex === 50; } } @@ -230,13 +230,20 @@ export class GameMode implements GameModeConfig { return waveIndex % 10 === 0; } + /** + * @returns `true` if the current battle is against classic mode's final boss + */ + isBattleClassicFinalBoss(waveIndex: number): boolean { + return (this.modeId === GameModes.CLASSIC || this.modeId === GameModes.CHALLENGE) && this.isWaveFinal(waveIndex); + } + /** * Every 50 waves of an Endless mode is a boss * At this time it is paradox pokemon * @returns true if waveIndex is a multiple of 50 in Endless */ isEndlessBoss(waveIndex: integer): boolean { - return !!(waveIndex % 50) && + return waveIndex % 50 === 0 && (this.modeId === GameModes.ENDLESS || this.modeId === GameModes.SPLICED_ENDLESS); } @@ -268,7 +275,6 @@ export class GameMode implements GameModeConfig { isFixedBattle(waveIndex: integer): boolean { const dummyConfig = new FixedBattleConfig(); return this.battleConfig.hasOwnProperty(waveIndex) || applyChallenges(this, ChallengeType.FIXED_BATTLES, waveIndex, dummyConfig); - } /** @@ -288,40 +294,40 @@ export class GameMode implements GameModeConfig { getClearScoreBonus(): integer { switch (this.modeId) { - case GameModes.CLASSIC: - case GameModes.CHALLENGE: - return 5000; - case GameModes.DAILY: - return 2500; - default: - return 0; + case GameModes.CLASSIC: + case GameModes.CHALLENGE: + return 5000; + case GameModes.DAILY: + return 2500; + default: + return 0; } } getEnemyModifierChance(isBoss: boolean): integer { switch (this.modeId) { - case GameModes.CLASSIC: - case GameModes.CHALLENGE: - case GameModes.DAILY: - return !isBoss ? 18 : 6; - case GameModes.ENDLESS: - case GameModes.SPLICED_ENDLESS: - return !isBoss ? 12 : 4; + case GameModes.CLASSIC: + case GameModes.CHALLENGE: + case GameModes.DAILY: + return !isBoss ? 18 : 6; + case GameModes.ENDLESS: + case GameModes.SPLICED_ENDLESS: + return !isBoss ? 12 : 4; } } getName(): string { switch (this.modeId) { - case GameModes.CLASSIC: - return i18next.t("gameMode:classic"); - case GameModes.ENDLESS: - return i18next.t("gameMode:endless"); - case GameModes.SPLICED_ENDLESS: - return i18next.t("gameMode:endlessSpliced"); - case GameModes.DAILY: - return i18next.t("gameMode:dailyRun"); - case GameModes.CHALLENGE: - return i18next.t("gameMode:challenge"); + case GameModes.CLASSIC: + return i18next.t("gameMode:classic"); + case GameModes.ENDLESS: + return i18next.t("gameMode:endless"); + case GameModes.SPLICED_ENDLESS: + return i18next.t("gameMode:endlessSpliced"); + case GameModes.DAILY: + return i18next.t("gameMode:dailyRun"); + case GameModes.CHALLENGE: + return i18next.t("gameMode:challenge"); } } @@ -330,42 +336,42 @@ export class GameMode implements GameModeConfig { */ getMysteryEncounterLegalWaves(): [number, number] { switch (this.modeId) { - default: - return [0, 0]; - case GameModes.CLASSIC: - return CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES; - case GameModes.CHALLENGE: - return CHALLENGE_MODE_MYSTERY_ENCOUNTER_WAVES; + default: + return [ 0, 0 ]; + case GameModes.CLASSIC: + return CLASSIC_MODE_MYSTERY_ENCOUNTER_WAVES; + case GameModes.CHALLENGE: + return CHALLENGE_MODE_MYSTERY_ENCOUNTER_WAVES; } } static getModeName(modeId: GameModes): string { switch (modeId) { - case GameModes.CLASSIC: - return i18next.t("gameMode:classic"); - case GameModes.ENDLESS: - return i18next.t("gameMode:endless"); - case GameModes.SPLICED_ENDLESS: - return i18next.t("gameMode:endlessSpliced"); - case GameModes.DAILY: - return i18next.t("gameMode:dailyRun"); - case GameModes.CHALLENGE: - return i18next.t("gameMode:challenge"); + case GameModes.CLASSIC: + return i18next.t("gameMode:classic"); + case GameModes.ENDLESS: + return i18next.t("gameMode:endless"); + case GameModes.SPLICED_ENDLESS: + return i18next.t("gameMode:endlessSpliced"); + case GameModes.DAILY: + return i18next.t("gameMode:dailyRun"); + case GameModes.CHALLENGE: + return i18next.t("gameMode:challenge"); } } } export function getGameMode(gameMode: GameModes): GameMode { switch (gameMode) { - case GameModes.CLASSIC: - return new GameMode(GameModes.CLASSIC, { isClassic: true, hasTrainers: true, hasMysteryEncounters: true }, classicFixedBattles); - case GameModes.ENDLESS: - return new GameMode(GameModes.ENDLESS, { isEndless: true, hasShortBiomes: true, hasRandomBosses: true }); - case GameModes.SPLICED_ENDLESS: - return new GameMode(GameModes.SPLICED_ENDLESS, { isEndless: true, hasShortBiomes: true, hasRandomBosses: true, isSplicedOnly: true }); - case GameModes.DAILY: - return new GameMode(GameModes.DAILY, { isDaily: true, hasTrainers: true, hasNoShop: true }); - case GameModes.CHALLENGE: - return new GameMode(GameModes.CHALLENGE, { isClassic: true, hasTrainers: true, isChallenge: true, hasMysteryEncounters: true }, classicFixedBattles); + case GameModes.CLASSIC: + return new GameMode(GameModes.CLASSIC, { isClassic: true, hasTrainers: true, hasMysteryEncounters: true }, classicFixedBattles); + case GameModes.ENDLESS: + return new GameMode(GameModes.ENDLESS, { isEndless: true, hasShortBiomes: true, hasRandomBosses: true }); + case GameModes.SPLICED_ENDLESS: + return new GameMode(GameModes.SPLICED_ENDLESS, { isEndless: true, hasShortBiomes: true, hasRandomBosses: true, isSplicedOnly: true }); + case GameModes.DAILY: + return new GameMode(GameModes.DAILY, { isDaily: true, hasTrainers: true, hasNoShop: true }); + case GameModes.CHALLENGE: + return new GameMode(GameModes.CHALLENGE, { isClassic: true, hasTrainers: true, isChallenge: true, hasMysteryEncounters: true }, classicFixedBattles); } } diff --git a/src/inputs-controller.ts b/src/inputs-controller.ts index bb3cfcbeb3b..537d2870259 100644 --- a/src/inputs-controller.ts +++ b/src/inputs-controller.ts @@ -1,12 +1,12 @@ import Phaser from "phaser"; import * as Utils from "./utils"; -import {deepCopy} from "./utils"; +import { deepCopy } from "./utils"; import pad_generic from "./configs/inputs/pad_generic"; import pad_unlicensedSNES from "./configs/inputs/pad_unlicensedSNES"; import pad_xbox360 from "./configs/inputs/pad_xbox360"; import pad_dualshock from "./configs/inputs/pad_dualshock"; import pad_procon from "./configs/inputs/pad_procon"; -import {Mode} from "./ui/ui"; +import { Mode } from "./ui/ui"; import SettingsGamepadUiHandler from "./ui/settings/settings-gamepad-ui-handler"; import SettingsKeyboardUiHandler from "./ui/settings/settings-keyboard-ui-handler"; import cfg_keyboard_qwerty from "./configs/inputs/cfg_keyboard_qwerty"; @@ -16,8 +16,8 @@ import { getIconForLatestInput, swap, } from "#app/configs/inputs/configHandler"; import BattleScene from "./battle-scene"; -import {SettingGamepad} from "#app/system/settings/settings-gamepad"; -import {SettingKeyboard} from "#app/system/settings/settings-keyboard"; +import { SettingGamepad } from "#app/system/settings/settings-gamepad"; +import { SettingKeyboard } from "#app/system/settings/settings-keyboard"; import TouchControl from "#app/touch-controls"; import { Button } from "#enums/buttons"; import { Device } from "#enums/devices"; @@ -294,7 +294,7 @@ export class InputsController { this.setChosenGamepad(gamepadID); } const config = deepCopy(this.getConfig(gamepadID)) as InterfaceConfig; - config.custom = this.configs[gamepadID]?.custom || {...config.default}; + config.custom = this.configs[gamepadID]?.custom || { ...config.default }; this.configs[gamepadID] = config; this.scene.gameData?.saveMappingConfigs(gamepadID, this.configs[gamepadID]); } @@ -307,9 +307,9 @@ export class InputsController { * Initializes or updates configurations for connected keyboards. */ setupKeyboard(): void { - for (const layout of ["default"]) { + for (const layout of [ "default" ]) { const config = deepCopy(this.getConfigKeyboard(layout)) as InterfaceConfig; - config.custom = this.configs[layout]?.custom || {...config.default}; + config.custom = this.configs[layout]?.custom || { ...config.default }; this.configs[layout] = config; this.scene.gameData?.saveMappingConfigs(this.selectedDevice[Device.KEYBOARD], this.configs[layout]); } @@ -330,7 +330,7 @@ export class InputsController { return el !== null; }) ?? []; - for (const [index, thisGamepad] of this.gamepads.entries()) { + for (const [ index, thisGamepad ] of this.gamepads.entries()) { thisGamepad.index = index; // Overwrite the gamepad index, in case we had undefined gamepads earlier } } diff --git a/src/loading-scene.ts b/src/loading-scene.ts index c3cb494d497..c49b8d5aaa9 100644 --- a/src/loading-scene.ts +++ b/src/loading-scene.ts @@ -1,28 +1,25 @@ -import { GachaType } from "./enums/gacha-types"; -import { trainerConfigs } from "./data/trainer-config"; -import { getBiomeHasProps } from "./field/arena"; -import CacheBustedLoaderPlugin from "./plugins/cache-busted-loader-plugin"; -import { SceneBase } from "./scene-base"; -import { WindowVariant, getWindowVariantSuffix } from "./ui/ui-theme"; -import { isMobile } from "./touch-controls"; -import * as Utils from "./utils"; -import { initI18n } from "./plugins/i18n"; -import { initPokemonPrevolutions } from "#app/data/pokemon-evolutions"; -import { initBiomes } from "#app/data/biomes"; -import { initEggMoves } from "#app/data/egg-moves"; +import { GachaType } from "#enums/gacha-types"; +import { getBiomeHasProps } from "#app/field/arena"; +import CacheBustedLoaderPlugin from "#app/plugins/cache-busted-loader-plugin"; +import { SceneBase } from "#app/scene-base"; +import { WindowVariant, getWindowVariantSuffix } from "#app/ui/ui-theme"; +import { isMobile } from "#app/touch-controls"; +import * as Utils from "#app/utils"; +import { initPokemonPrevolutions } from "#app/data/balance/pokemon-evolutions"; +import { initBiomes } from "#app/data/balance/biomes"; +import { initEggMoves } from "#app/data/balance/egg-moves"; import { initPokemonForms } from "#app/data/pokemon-forms"; import { initSpecies } from "#app/data/pokemon-species"; import { initMoves } from "#app/data/move"; import { initAbilities } from "#app/data/ability"; import { initAchievements } from "#app/system/achv"; import { initTrainerTypeDialogue } from "#app/data/dialogue"; -import { initChallenges } from "./data/challenge"; +import { initChallenges } from "#app/data/challenge"; import i18next from "i18next"; -import { initStatsKeys } from "./ui/game-stats-ui-handler"; -import { initVouchers } from "./system/voucher"; +import { initStatsKeys } from "#app/ui/game-stats-ui-handler"; +import { initVouchers } from "#app/system/voucher"; import { Biome } from "#enums/biome"; -import { TrainerType } from "#enums/trainer-type"; -import {initMysteryEncounters} from "#app/data/mystery-encounters/mystery-encounters"; +import { initMysteryEncounters } from "#app/data/mystery-encounters/mystery-encounters"; export class LoadingScene extends SceneBase { public static readonly KEY = "loading"; @@ -33,7 +30,6 @@ export class LoadingScene extends SceneBase { super(LoadingScene.KEY); Phaser.Plugins.PluginCache.register("Loader", CacheBustedLoaderPlugin, "load"); - initI18n(); } preload() { @@ -48,6 +44,8 @@ export class LoadingScene extends SceneBase { this.loadAtlas("prompt", "ui"); this.loadImage("candy", "ui"); this.loadImage("candy_overlay", "ui"); + this.loadImage("friendship", "ui"); + this.loadImage("friendship_overlay", "ui"); this.loadImage("cursor", "ui"); this.loadImage("cursor_reverse", "ui"); for (const wv of Utils.getEnumValues(WindowVariant)) { @@ -167,6 +165,8 @@ export class LoadingScene extends SceneBase { this.loadImage("discord", "ui"); this.loadImage("google", "ui"); this.loadImage("settings_icon", "ui"); + this.loadImage("link_icon", "ui"); + this.loadImage("unlink_icon", "ui"); this.loadImage("default_bg", "arenas"); // Load arena images @@ -208,14 +208,6 @@ export class LoadingScene extends SceneBase { this.loadAtlas("trainer_f_back", "trainer"); this.loadAtlas("trainer_f_back_pb", "trainer"); - Utils.getEnumValues(TrainerType).map(tt => { - const config = trainerConfigs[tt]; - this.loadAtlas(config.getSpriteKey(), "trainer"); - if (config.doubleOnly || config.hasDouble) { - this.loadAtlas(config.getSpriteKey(true), "trainer"); - } - }); - // Load character sprites this.loadAtlas("c_rival_m", "character", "rival_m"); this.loadAtlas("c_rival_f", "character", "rival_f"); @@ -240,7 +232,7 @@ export class LoadingScene extends SceneBase { // Get current lang and load the types atlas for it. English will only load types while all other languages will load types and types_ const lang = i18next.resolvedLanguage; if (lang !== "en") { - if (Utils.verifyLang(lang)) { + if (Utils.hasAllLocalizedSprites(lang)) { this.loadAtlas(`statuses_${lang}`, ""); this.loadAtlas(`types_${lang}`, ""); } else { @@ -252,11 +244,11 @@ export class LoadingScene extends SceneBase { this.loadAtlas("statuses", ""); this.loadAtlas("types", ""); } - const availableLangs = ["en", "de", "it", "fr", "ja", "ko", "es", "pt-BR", "zh-CN"]; + const availableLangs = [ "en", "de", "it", "fr", "ja", "ko", "es-ES", "pt-BR", "zh-CN" ]; if (lang && availableLangs.includes(lang)) { - this.loadImage("egg-update_"+lang, "events"); + this.loadImage("halloween2024-event-" + lang, "events"); } else { - this.loadImage("egg-update_en", "events"); + this.loadImage("halloween2024-event-en", "events"); } this.loadAtlas("statuses", ""); @@ -487,18 +479,18 @@ export class LoadingScene extends SceneBase { this.load.on(this.LOAD_EVENTS.FILE_COMPLETE, (key: string) => { assetText.setText(i18next.t("menu:loadingAsset", { assetName: key })); switch (key) { - case "loading_bg": - bg.setTexture("loading_bg"); - if (mobile) { - bg.setVisible(true); - } - break; - case "logo": - logo.setTexture("logo"); - if (mobile) { - logo.setVisible(true); - } - break; + case "loading_bg": + bg.setTexture("loading_bg"); + if (mobile) { + bg.setVisible(true); + } + break; + case "logo": + logo.setTexture("logo"); + if (mobile) { + logo.setVisible(true); + } + break; } }); diff --git a/src/locales/ca_ES/ability-trigger.json b/src/locales/ca_ES/ability-trigger.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/ability-trigger.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/ability.json b/src/locales/ca_ES/ability.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/ability.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/achv.json b/src/locales/ca_ES/achv.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/achv.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/arena-flyout.json b/src/locales/ca_ES/arena-flyout.json deleted file mode 100644 index 21a02c789e8..00000000000 --- a/src/locales/ca_ES/arena-flyout.json +++ /dev/null @@ -1,40 +0,0 @@ -{ - "activeBattleEffects": "Efectes d'Arena Activa", - "player": "Jugador", - "neutral": "Neutre", - "enemy": "Enemic", - "sunny": "Assolellat", - "rain": "Plujós", - "sandstorm": "Tempesta Sorra", - "hail": "Calamarsa", - "snow": "Neu", - "fog": "Boira", - "heavyRain": "Diluvi", - "harshSun": "Sol Abrasador", - "strongWinds": "Vents Forts", - "misty": "Camp de Boira", - "electric": "Camp Elèctric", - "grassy": "Camp d'Herba", - "psychic": "Camp Psíquic", - "mudSport": "Xipollejo Fang", - "waterSport": "Hidrorraig", - "spikes": "Pues", - "toxicSpikes": "Pues Tòxiques", - "mist": "Boirina", - "futureSight": "Premonició", - "doomDesire": "Desig Ocult", - "wish": "Desig", - "stealthRock": "Trampa Roques", - "stickyWeb": "Xarxa Viscosa", - "trickRoom": "Espai Rar", - "gravity": "Gravetat", - "reflect": "Reflex", - "lightScreen": "Pantalla de Llum", - "auroraVeil": "Vel Aurora", - "quickGuard": "Anticipi", - "wideGuard": "Vasta Guàrdia", - "matBlock": "Escut Tatami", - "craftyShield": "Truc Defensa", - "tailwind": "Vent Afí", - "happyHour": "Paga Extra" -} diff --git a/src/locales/ca_ES/arena-tag.json b/src/locales/ca_ES/arena-tag.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/arena-tag.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/battle-info.json b/src/locales/ca_ES/battle-info.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/battle-info.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/battle-message-ui-handler.json b/src/locales/ca_ES/battle-message-ui-handler.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/battle-message-ui-handler.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/battle-scene.json b/src/locales/ca_ES/battle-scene.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/battle-scene.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/battle.json b/src/locales/ca_ES/battle.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/battle.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/battler-tags.json b/src/locales/ca_ES/battler-tags.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/battler-tags.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/berry.json b/src/locales/ca_ES/berry.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/berry.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/bgm-name.json b/src/locales/ca_ES/bgm-name.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/bgm-name.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/biome.json b/src/locales/ca_ES/biome.json deleted file mode 100644 index e570195e4c8..00000000000 --- a/src/locales/ca_ES/biome.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "unknownLocation": "En algun lloc que no recordes", - "TOWN": "Poble", - "PLAINS": "Vall", - "GRASS": "Camp", - "TALL_GRASS": "Herba Alta", - "METROPOLIS": "Metròpoli", - "FOREST": "Bosc", - "SEA": "Mar", - "SWAMP": "Pantà", - "BEACH": "Platja", - "LAKE": "Llac", - "SEABED": "Fons Marí", - "MOUNTAIN": "Muntanya", - "BADLANDS": "Badlands", - "CAVE": "Cova", - "DESERT": "Desert", - "ICE_CAVE": "Cova Gelada", - "MEADOW": "Prat", - "POWER_PLANT": "Planta d'Energia", - "VOLCANO": "Volcà", - "GRAVEYARD": "Cementiri", - "DOJO": "Dojo", - "FACTORY": "Fàbrica", - "RUINS": "Ruïnes Antigues", - "WASTELAND": "Terra Erma", - "ABYSS": "Avenc", - "SPACE": "Espai", - "CONSTRUCTION_SITE": "Obra", - "JUNGLE": "Jungla", - "FAIRY_CAVE": "Cova de Fades", - "TEMPLE": "Temple", - "SLUM": "Suburbi", - "SNOWY_FOREST": "Bosc Nevat", - "ISLAND": "Illa", - "LABORATORY": "Laboratori", - "END": "???" -} diff --git a/src/locales/ca_ES/challenges.json b/src/locales/ca_ES/challenges.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/challenges.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/command-ui-handler.json b/src/locales/ca_ES/command-ui-handler.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/command-ui-handler.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/common.json b/src/locales/ca_ES/common.json deleted file mode 100644 index 8fd27cf486f..00000000000 --- a/src/locales/ca_ES/common.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "start": "Començar", - "luckIndicator": "Sort:", - "shinyOnHover": "Variocolor", - "commonShiny": "Comú", - "rareShiny": "Rar", - "epicShiny": "Èpica" -} diff --git a/src/locales/ca_ES/config.ts b/src/locales/ca_ES/config.ts deleted file mode 100644 index 4d8f6c9dc59..00000000000 --- a/src/locales/ca_ES/config.ts +++ /dev/null @@ -1,113 +0,0 @@ -import common from "./common.json"; -import settings from "./settings.json"; -import ability from "./ability.json"; -import abilityTriggers from "./ability-trigger.json"; -import arenaFlyout from "./arena-flyout.json"; -import arenaTag from "./arena-tag.json"; -import achv from "./achv.json"; -import battle from "./battle.json"; -import battleScene from "./battle-scene.json"; -import battleInfo from "./battle-info.json"; -import battleMessageUiHandler from "./battle-message-ui-handler.json"; -import battlerTags from "./battler-tags.json"; -import berry from "./berry.json"; -import bgmName from "./bgm-name.json"; -import biome from "./biome.json"; -import challenges from "./challenges.json"; -import commandUiHandler from "./command-ui-handler.json"; -import dialogue from "./dialogue.json"; -import battleSpecDialogue from "./dialogue-final-boss.json"; -import miscDialogue from "./dialogue-misc.json"; -import doubleBattleDialogue from "./dialogue-double-battle.json"; -import egg from "./egg.json"; -import fightUiHandler from "./fight-ui-handler.json"; -import filterBar from "./filter-bar.json"; -import gameMode from "./game-mode.json"; -import gameStatsUiHandler from "./game-stats-ui-handler.json"; -import growth from "./growth.json"; -import menu from "./menu.json"; -import menuUiHandler from "./menu-ui-handler.json"; -import modifier from "./modifier.json"; -import modifierType from "./modifier-type.json"; -import move from "./move.json"; -import nature from "./nature.json"; -import partyUiHandler from "./party-ui-handler.json"; -import pokeball from "./pokeball.json"; -import pokemon from "./pokemon.json"; -import pokemonForm from "./pokemon-form.json"; -import battlePokemonForm from "./pokemon-form-battle.json"; -import pokemonInfo from "./pokemon-info.json"; -import pokemonInfoContainer from "./pokemon-info-container.json"; -import pokemonSummary from "./pokemon-summary.json"; -import saveSlotSelectUiHandler from "./save-slot-select-ui-handler.json"; -import splashMessages from "./splash-messages.json"; -import starterSelectUiHandler from "./starter-select-ui-handler.json"; -import statusEffect from "./status-effect.json"; -import trainerTitles from "./trainer-titles.json"; -import trainerClasses from "./trainer-classes.json"; -import trainerNames from "./trainer-names.json"; -import tutorial from "./tutorial.json"; -import voucher from "./voucher.json"; -import weather from "./weather.json"; -import terrain from "./terrain.json"; -import modifierSelectUiHandler from "./modifier-select-ui-handler.json"; -import moveTriggers from "./move-trigger.json"; -import runHistory from "./run-history.json"; - -export const caEsConfig = { - ability, - abilityTriggers, - arenaFlyout, - arenaTag, - battle, - battleScene, - battleInfo, - battleMessageUiHandler, - battlePokemonForm, - battlerTags, - berry, - bgmName, - biome, - challenges, - commandUiHandler, - common, - achv, - dialogue, - battleSpecDialogue, - miscDialogue, - doubleBattleDialogue, - egg, - fightUiHandler, - filterBar, - gameMode, - gameStatsUiHandler, - growth, - menu, - menuUiHandler, - modifier, - modifierType, - move, - nature, - pokeball, - pokemon, - pokemonForm, - pokemonInfo, - pokemonInfoContainer, - pokemonSummary, - saveSlotSelectUiHandler, - settings, - splashMessages, - starterSelectUiHandler, - statusEffect, - terrain, - titles: trainerTitles, - trainerClasses, - trainerNames, - tutorial, - voucher, - weather, - partyUiHandler, - modifierSelectUiHandler, - moveTriggers, - runHistory, -}; diff --git a/src/locales/ca_ES/dialogue-double-battle.json b/src/locales/ca_ES/dialogue-double-battle.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/dialogue-double-battle.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/dialogue-final-boss.json b/src/locales/ca_ES/dialogue-final-boss.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/dialogue-final-boss.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/dialogue-misc.json b/src/locales/ca_ES/dialogue-misc.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/dialogue-misc.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/dialogue.json b/src/locales/ca_ES/dialogue.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/dialogue.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/egg.json b/src/locales/ca_ES/egg.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/egg.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/fight-ui-handler.json b/src/locales/ca_ES/fight-ui-handler.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/fight-ui-handler.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/filter-bar.json b/src/locales/ca_ES/filter-bar.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/filter-bar.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/game-mode.json b/src/locales/ca_ES/game-mode.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/game-mode.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/game-stats-ui-handler.json b/src/locales/ca_ES/game-stats-ui-handler.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/game-stats-ui-handler.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/growth.json b/src/locales/ca_ES/growth.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/growth.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/menu-ui-handler.json b/src/locales/ca_ES/menu-ui-handler.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/menu-ui-handler.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/menu.json b/src/locales/ca_ES/menu.json deleted file mode 100644 index 42b0847b2f2..00000000000 --- a/src/locales/ca_ES/menu.json +++ /dev/null @@ -1,55 +0,0 @@ -{ - "cancel": "Cancel-la", - "continue": "Continuar", - "dailyRun": "Repte Diari (Beta)", - "loadGame": "Carregar Partida", - "newGame": "Nova Partida", - "settings": "Opcions", - "selectGameMode": "Trieu un mode de joc", - "logInOrCreateAccount": "Inicieu sessió o creeu un compte per començar. No cal correu electrònic!", - "username": "Usuari", - "password": "Contrasenya", - "login": "Iniciar Sessió", - "orUse": "O Usa", - "register": "Registrar-se", - "emptyUsername": "L'usuari no pot estar buit", - "invalidLoginUsername": "L'usuari no és vàlid", - "invalidRegisterUsername": "L'usuari només pot contenir lletres, números i guions baixos", - "invalidLoginPassword": "La contrasenya no és vàlida", - "invalidRegisterPassword": "La Contrasenya ha de tenir 6 o més caràcters", - "usernameAlreadyUsed": "L'usuari ja està en ús", - "accountNonExistent": "L'usuari no existeix", - "unmatchingPassword": "La contrasenya no coincideix", - "passwordNotMatchingConfirmPassword": "La contrasenya ha de coincidir amb la contrasenya de confirmació", - "confirmPassword": "Confirmeu la Contrasenya", - "registrationAgeWarning": "En registrar-te, confirmes que tens 13 anys o més.", - "backToLogin": "Torna a Iniciar Sessió", - "failedToLoadSaveData": "No s'han pogut carregar les dades desades. Torneu a carregar la pàgina.\nSi això continua, comproveu #announcements a Discord.", - "sessionSuccess": "Sessió carregada amb èxit.", - "failedToLoadSession": "No s'han pogut carregar les dades de la sessió.\nÉs possible que estiguin malmeses.", - "boyOrGirl": "Ets Nen o Nena?", - "evolving": "Que?\n{{pokemonName}} està evolucionant!", - "stoppedEvolving": "Prou?\nL'evolució de {{pokemonName}} s'ha aturat!", - "pauseEvolutionsQuestion": "Vols aturar les evolucions de {{pokémon Name}}?\nSempre poden ser activades des de la pantalla del teu equip.", - "evolutionsPaused": "L'evolució s'ha posat en pausa per a ", - "evolutionDone": "Enhorabona!\n{{pokemonName}} ha evolucionat a {{evolvedPokemonName}}!", - "dailyRankings": "Rànquings Diaris", - "weeklyRankings": "Rànquings Setmanals", - "noRankings": "Sense Rànquings", - "positionIcon": "#", - "usernameScoreboard": "Usuari", - "score": "Puntuació", - "wave": "Onada", - "loading": "Carregant…", - "loadingAsset": "Carregant actius: {{assetName}}", - "playersOnline": "Jugadors en Línia", - "yes":"sí", - "no":"No", - "disclaimer": "AVÍS", - "disclaimerDescription": "Aquest joc encara no s'ha completat; podríeu tenir problemes de joc (inclosa la possible pèrdua de dades desades),\n el joc pot canviar sense previ avís, i el joc es pot actualitzar o completar o no.", - "choosePokemon": "Elegir un Pokémon.", - "renamePokemon": "Rebatejar Pokémon", - "rename": "Rebatejar", - "nickname": "Sobrenom", - "errorServerDown": "Vaja! S'ha produït un problema en contactar amb el servidor.\n\nPots deixar aquesta pestanya oberta,\nel joc es tornarà a connectar automàticament." -} diff --git a/src/locales/ca_ES/modifier-select-ui-handler.json b/src/locales/ca_ES/modifier-select-ui-handler.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/modifier-select-ui-handler.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/modifier-type.json b/src/locales/ca_ES/modifier-type.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/modifier-type.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/modifier.json b/src/locales/ca_ES/modifier.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/modifier.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/move-trigger.json b/src/locales/ca_ES/move-trigger.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/move-trigger.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/move.json b/src/locales/ca_ES/move.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/move.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/nature.json b/src/locales/ca_ES/nature.json deleted file mode 100644 index b07413683db..00000000000 --- a/src/locales/ca_ES/nature.json +++ /dev/null @@ -1,27 +0,0 @@ -{ - "Hardy": "Forta", - "Lonely": "Esquerpa", - "Brave": "Audaç", - "Adamant": "Ferma", - "Naughty": "Múrria", - "Bold": "Agosarada", - "Docile": "Dòcil", - "Relaxed": "Relaxat", - "Impish": "Frenètic", - "Lax": "Despreocupat", - "Timid": "Poruc", - "Hasty": "Àvid", - "Serious": "Seriós", - "Jolly": "Jovial", - "Naive": "Ingenu", - "Modest": "Modesta", - "Mild": "Suau", - "Quiet": "Tranquil", - "Bashful": "Vergonyós", - "Rash": "Imprudent", - "Calm": "Serena", - "Gentle": "Amable", - "Sassy": "Descarat", - "Careful": "Cautelós", - "Quirky": "Estrany" -} diff --git a/src/locales/ca_ES/party-ui-handler.json b/src/locales/ca_ES/party-ui-handler.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/party-ui-handler.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/pokeball.json b/src/locales/ca_ES/pokeball.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/pokeball.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/pokemon-form-battle.json b/src/locales/ca_ES/pokemon-form-battle.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/pokemon-form-battle.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/pokemon-form.json b/src/locales/ca_ES/pokemon-form.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/pokemon-form.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/pokemon-info-container.json b/src/locales/ca_ES/pokemon-info-container.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/pokemon-info-container.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/pokemon-info.json b/src/locales/ca_ES/pokemon-info.json deleted file mode 100644 index 421ea6a88f7..00000000000 --- a/src/locales/ca_ES/pokemon-info.json +++ /dev/null @@ -1,40 +0,0 @@ -{ - "Stat": { - "HP": "PS", - "HPshortened": "PS", - "ATK": "Atac", - "ATKshortened": "Ata", - "DEF": "Defensa", - "DEFshortened": "Def", - "SPATK": "At. Esp.", - "SPATKshortened": "AtEsp", - "SPDEF": "Def. Esp.", - "SPDEFshortened": "DefEsp", - "SPD": "Velocitat", - "SPDshortened": "Veloc.", - "ACC": "Precisió", - "EVA": "Evació" - }, - "Type": { - "UNKNOWN": "???", - "NORMAL": "Normal", - "FIGHTING": "Lluita", - "FLYING": "Volador", - "POISON": "Verí", - "GROUND": "Terra", - "ROCK": "Roca", - "BUG": "Bestiola", - "GHOST": "Fantasma", - "STEEL": "Acer", - "FIRE": "Foc", - "WATER": "Aigua", - "GRASS": "Planta", - "ELECTRIC": "Elèctric", - "PSYCHIC": "Psíquic", - "ICE": "Gel", - "DRAGON": "Drac", - "DARK": "Sinistre", - "FAIRY": "Fada", - "STELLAR": "Astral" - } -} diff --git a/src/locales/ca_ES/pokemon-summary.json b/src/locales/ca_ES/pokemon-summary.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/pokemon-summary.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/pokemon.json b/src/locales/ca_ES/pokemon.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/pokemon.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/run-history.json b/src/locales/ca_ES/run-history.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/run-history.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/save-slot-select-ui-handler.json b/src/locales/ca_ES/save-slot-select-ui-handler.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/save-slot-select-ui-handler.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/settings.json b/src/locales/ca_ES/settings.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/settings.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/splash-messages.json b/src/locales/ca_ES/splash-messages.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/splash-messages.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/starter-select-ui-handler.json b/src/locales/ca_ES/starter-select-ui-handler.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/starter-select-ui-handler.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/status-effect.json b/src/locales/ca_ES/status-effect.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/status-effect.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/terrain.json b/src/locales/ca_ES/terrain.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/terrain.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/trainer-classes.json b/src/locales/ca_ES/trainer-classes.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/trainer-classes.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/trainer-names.json b/src/locales/ca_ES/trainer-names.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/trainer-names.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/trainer-titles.json b/src/locales/ca_ES/trainer-titles.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/trainer-titles.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/tutorial.json b/src/locales/ca_ES/tutorial.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/tutorial.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/voucher.json b/src/locales/ca_ES/voucher.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/voucher.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/ca_ES/weather.json b/src/locales/ca_ES/weather.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/ca_ES/weather.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/de/ability-trigger.json b/src/locales/de/ability-trigger.json deleted file mode 100644 index 379692c45ae..00000000000 --- a/src/locales/de/ability-trigger.json +++ /dev/null @@ -1,64 +0,0 @@ -{ - "blockRecoilDamage": "{{pokemonName}} wurde durch {{abilityName}} vor Rückstoß geschützt!", - "badDreams": "{{pokemonName}} ist in einem Alptraum gefangen!", - "costar": "{{pokemonName}} kopiert die Statusveränderungen von {{allyName}}!", - "iceFaceAvoidedDamage": "{{pokemonNameWithAffix}} wehrt Schaden mit {{abilityName}} ab!", - "perishBody": "Durch {{abilityName}} von {{pokemonName}} werden beide Pokémon nach drei Runden K.O. gehen!", - "poisonHeal": "{{abilityName}} von {{pokemonName}} füllte einige KP auf!", - "trace": "{{pokemonName}} kopiert {{abilityName}} von {{targetName}}!", - "windPowerCharged": "Der Treffer durch {{moveName}} läd die Stärke von {{pokemonName}} auf!", - "quickDraw": "Durch Schnellschuss kann {{pokemonName}} schneller handeln als sonst!", - "blockItemTheft": "{{abilityName}} von {{pokemonNameWithAffix}} verhindert Item-Diebstahl!", - "typeImmunityHeal": "{{abilityName}} von {{pokemonNameWithAffix}} füllte einige KP auf!", - "nonSuperEffectiveImmunity": "{{pokemonNameWithAffix}} vermeidet Schaden mit {{abilityName}}!", - "disguiseAvoidedDamage": "Die Tarnung von {{pokemonNameWithAffix}} ist aufgeflogen!!", - "fullHpResistType": "Der Panzer von {{pokemonNameWithAffix}} funkelt und verzerrt die Wechselwirkungen zwischen den Typen!", - "moveImmunity": "Es hat keine Wirkung auf {{pokemonNameWithAffix}}...", - "reverseDrain": "{{pokemonNameWithAffix}} saugt Kloakensoße auf!", - "postDefendTypeChange": "{{abilityName}} von {{pokemonNameWithAffix}} macht es zu einem {{typeName}}-Typ!", - "postDefendContactDamage": "{{abilityName}} von {{pokemonNameWithAffix}} schadet seinem Angreifer!", - "postDefendAbilitySwap": "{{pokemonNameWithAffix}} tauscht Fähigkeiten mit dem Ziel!", - "postDefendAbilityGive": "{{pokemonNameWithAffix}} gibt seinem Ziel {{abilityName}}!", - "postDefendMoveDisable": "{{moveName}} von {{pokemonNameWithAffix}} wurde blockiert!", - "pokemonTypeChange": "{{pokemonNameWithAffix}} nimmt den Typ {{moveType}} an!", - "postAttackStealHeldItem": "{{pokemonNameWithAffix}} stiehlt {{stolenItemType}} von {{defenderName}}!", - "postDefendStealHeldItem": "{{pokemonNameWithAffix}} stiehlt {{stolenItemType}} von {{attackerName}}!", - "copyFaintedAllyAbility": "Die Fähigkeit {{abilityName}} von {{pokemonNameWithAffix}} wurde übernommen!", - "intimidateImmunity": "{{abilityName}} von {{pokemonNameWithAffix}} verhindert den Effekt von Bedroher!", - "postSummonAllyHeal": "{{pokemonNameWithAffix}} trinkt den von {{pokemonName}} zubereiteten Tee!", - "postSummonClearAllyStats": "Die Statusveränderungen von {{pokemonNameWithAffix}} wurden aufgehoben!", - "postSummonTransform": "{{pokemonNameWithAffix}} verwandelt sich in {{targetName}}!", - "protectStat": "{{abilityName}} von {{pokemonNameWithAffix}} verhindert das der Statuswert {{statName}} gesenkt wird!", - "statusEffectImmunityWithName": "{{abilityName}} von {{pokemonNameWithAffix}} verhindert {{statusEffectName}}!", - "statusEffectImmunity": "{{abilityName}} von {{pokemonNameWithAffix}} verhindert Statusprobleme", - "battlerTagImmunity": "{{abilityName}} von {{pokemonNameWithAffix}} verhindert {{battlerTagName}}!", - "forewarn": "Vorwarnung von {{pokemonNameWithAffix}}: Konzentraion auf {{moveName}}!", - "frisk": "{{pokemonNameWithAffix}} hat die Fähigkeit {{opponentAbilityName}} von {{opponentName}} erschnüffelt!", - "postWeatherLapseHeal": "{{abilityName}} von {{pokemonNameWithAffix}} füllte einige KP auf!", - "postWeatherLapseDamage": "{{pokemonNameWithAffix}} wurde durch {{abilityName}} verletzt!", - "postTurnLootCreateEatenBerry": "{{pokemonNameWithAffix}} hat {{berryName}} geerntet!", - "postTurnHeal": "{{abilityName}} von {{pokemonNameWithAffix}} füllte einige KP auf!", - "fetchBall": "{{pokemonNameWithAffix}} hat einen {{pokeballName}} gefunden!", - "healFromBerryUse": "{{abilityName}} von {{pokemonNameWithAffix}} füllte einige KP auf!", - "arenaTrap": "{{abilityName}} von {{pokemonNameWithAffix}} verhindert den Tausch!", - "postBattleLoot": "{{pokemonNameWithAffix}} hebt {{itemName}} auf!", - "postFaintContactDamage": "{{abilityName}} von {{pokemonNameWithAffix}} schadet seinem Angreifer!", - "postFaintHpDamage": "{{abilityName}} von {{pokemonNameWithAffix}} schadet seinem Angreifer!", - "postSummonPressure": "{{pokemonNameWithAffix}} setzt Gegner mit Erzwinger unter Druck!", - "weatherEffectDisappeared": "Jegliche wetterbedingten Effekte wurden aufgehoben!", - "postSummonMoldBreaker": "{{pokemonNameWithAffix}} gelingt es, gegnerische Fähigkeiten zu überbrücken!", - "postSummonAnticipation": "{{pokemonNameWithAffix}} erschaudert!", - "postSummonTurboblaze": "{{pokemonNameWithAffix}} strahlt eine lodernde Aura aus!", - "postSummonTeravolt": "{{pokemonNameWithAffix}} strahlt eine knisternde Aura aus!", - "postSummonDarkAura": "{{pokemonNameWithAffix}} strahlt eine dunkle Aura aus!", - "postSummonFairyAura": "{{pokemonNameWithAffix}} strahlt eine Feenaura aus!", - "postSummonAuraBreak": "{{pokemonNameWithAffix}} kehrt die Wirkung aller Aura-Fähigkeiten um!", - "postSummonNeutralizingGas": "Reaktionsgas von {{pokemonNameWithAffix}} hat sich in der Umgebung ausgebreitet!", - "postSummonAsOneGlastrier": "{{pokemonNameWithAffix}} verfügt über zwei Fähigkeiten!", - "postSummonAsOneSpectrier": "{{pokemonNameWithAffix}} verfügt über zwei Fähigkeiten!", - "postSummonVesselOfRuin": "Unheilsgefäß von {{pokemonNameWithAffix}} schwächt {{statName}} aller Pokémon im Umkreis!", - "postSummonSwordOfRuin": "Unheilsschwert von {{pokemonNameWithAffix}} schwächt {{statName}} aller Pokémon im Umkreis!", - "postSummonTabletsOfRuin": "Unheilstafeln von {{pokemonNameWithAffix}} schwächt {{statName}} aller Pokémon im Umkreis!", - "postSummonBeadsOfRuin": "Unheilsjuwelen von {{pokemonNameWithAffix}} schwächt {{statName}} aller Pokémon im Umkreis!", - "preventBerryUse": "{{pokemonNameWithAffix}} kriegt vor Anspannung keine Beeren mehr runter!" -} diff --git a/src/locales/de/ability.json b/src/locales/de/ability.json deleted file mode 100644 index 84f30fac755..00000000000 --- a/src/locales/de/ability.json +++ /dev/null @@ -1,1242 +0,0 @@ -{ - "stench": { - "name": "Duftnote", - "description": "Lässt das Ziel beim Angriff eventuell durch Gestank zurückschrecken." - }, - "drizzle": { - "name": "Niesel", - "description": "Ruft bei Kampfantritt Regen herbei." - }, - "speedBoost": { - "name": "Temposchub", - "description": "Erhöht in jeder Runde die Initiative." - }, - "battleArmor": { - "name": "Kampfpanzer", - "description": "Wehrt gegnerische Volltreffer mit einem harten Panzer ab." - }, - "sturdy": { - "name": "Robustheit", - "description": "Bietet Schutz gegen K.O.-Attacken. Bei vollen KP übersteht das Pokémon auch K.O.-Treffer." - }, - "damp": { - "name": "Feuchtigkeit", - "description": "Befeuchtet die Umgebung und verhindert so den Einsatz von Attacken wie Finale, die Explosionen auslösen." - }, - "limber": { - "name": "Flexibilität", - "description": "Der flexible Körper des Pokémon schützt es vor Paralyse." - }, - "sandVeil": { - "name": "Sandschleier", - "description": "Erhöht in Sandstürmen den Ausweichwert." - }, - "static": { - "name": "Statik", - "description": "Kann bei Berührung durch statisch aufgeladenen Körper paralysieren." - }, - "voltAbsorb": { - "name": "Voltabsorber", - "description": "Treffer durch Elektro-Attacken verursachen keinen Schaden, sondern regenerieren stattdessen KP." - }, - "waterAbsorb": { - "name": "H2OAbsorber", - "description": "Treffer durch Wasser-Attacken verursachen keinen Schaden, sondern regenerieren stattdessen KP." - }, - "oblivious": { - "name": "Dösigkeit", - "description": "Das Pokémon ist so apathisch, dass es nicht betört oder provoziert werden kann." - }, - "cloudNine": { - "name": "Wolke Sieben", - "description": "Hebt alle Wetter-Effekte auf." - }, - "compoundEyes": { - "name": "Facettenauge", - "description": "Erhöht die Genauigkeit von Attacken." - }, - "insomnia": { - "name": "Insomnia", - "description": "Verhindert Einschlafen." - }, - "colorChange": { - "name": "Farbwechsel", - "description": "Ändert seinen Typ zu dem der Attacke des Angreifers." - }, - "immunity": { - "name": "Immunität", - "description": "Das starke Immunsystem des Pokémon verhindert Vergiftungen." - }, - "flashFire": { - "name": "Feuerfänger", - "description": "Verstärkt Feuer-Attacken, wenn es von Feuer-Attacken getroffen wird." - }, - "shieldDust": { - "name": "Puderabwehr", - "description": "Blockiert durch Puder die Zusatzeffekte gegnerischer Angriffe." - }, - "ownTempo": { - "name": "Tempomacher", - "description": "Das Pokémon lässt sich nicht aus der Ruhe bringen und verhindert so Verwirrung." - }, - "suctionCups": { - "name": "Saugnapf", - "description": "Blockt Attacken und Items, die Pokémon austauschen, indem es sich mit einem Saugnapf am Boden verankert." - }, - "intimidate": { - "name": "Bedroher", - "description": "Senkt den Angriff der Gegner, indem es sie gleich zu Kampfantritt bedroht und einschüchtert." - }, - "shadowTag": { - "name": "Wegsperre", - "description": "Hindert Gegner an der Flucht beziehungsweise am Auswechseln, indem es ihnen den Weg versperrt." - }, - "roughSkin": { - "name": "Rauhaut", - "description": "Angreifer werden durch die raue Haut des Pokémon bei direkten Attacken verletzt." - }, - "wonderGuard": { - "name": "Wunderwache", - "description": "Wundersame Kräfte bewirken, dass nur sehr effektive Treffer bei ihm Schaden anrichten." - }, - "levitate": { - "name": "Schwebe", - "description": "Verleiht volle Immunität gegen alle Boden-Attacken durch Schwebezustand." - }, - "effectSpore": { - "name": "Sporenwirt", - "description": "Wird dieses Pokémon durch eine direkte Attacke angegriffen, kann das beim Gegner Paralyse, Vergiftung oder Schlaf auslösen." - }, - "synchronize": { - "name": "Synchro", - "description": "Erleidet das Pokémon Verbrennungen, Vergiftungen oder Paralyse, ereilt das jeweilige Statusproblem auch den Verursacher." - }, - "clearBody": { - "name": "Neutraltorso", - "description": "Verhindert das Senken der Statuswerte durch Attacken und Fähigkeiten von Angreifern." - }, - "naturalCure": { - "name": "Innere Kraft", - "description": "Wird das Pokémon ausgewechselt, werden seine Statusprobleme geheilt." - }, - "lightningRod": { - "name": "Blitzfänger", - "description": "Zieht Elektro-Attacken an. Statt durch diese Schaden zu nehmen, erhöht es den eigenen Spezial-Angriff." - }, - "sereneGrace": { - "name": "Edelmut", - "description": "Erhöht die Wahrscheinlichkeit, dass Zusatzeffekte von Attacken auftreten." - }, - "swiftSwim": { - "name": "Wassertempo", - "description": "Erhöht bei Regen die Initiative." - }, - "chlorophyll": { - "name": "Chlorophyll", - "description": "Erhöht bei Sonnenschein die Initiative." - }, - "illuminate": { - "name": "Erleuchtung", - "description": "Erhellt die Umgebung und erhöht dadurch die Wahrscheinlichkeit, wilden Pokémon zu begegnen." - }, - "trace": { - "name": "Erfassen", - "description": "Kopiert bei Kampfantritt die Fähigkeit eines Gegners." - }, - "hugePower": { - "name": "Kraftkoloss", - "description": "Verdoppelt die Stärke von physischen Attacken." - }, - "poisonPoint": { - "name": "Giftdorn", - "description": "Vergiftet den Angreifer bei Berührung eventuell." - }, - "innerFocus": { - "name": "Konzentrator", - "description": "Verhindert durch erhöhte Konzentrationsfähigkeit Zurückschrecken." - }, - "magmaArmor": { - "name": "Magmapanzer", - "description": "Dank eines Panzers aus Magma kann dieses Pokémon nicht eingefroren werden." - }, - "waterVeil": { - "name": "Aquahülle", - "description": "Verhindert durch eine Hülle aus Wasser Verbrennungen." - }, - "magnetPull": { - "name": "Magnetfalle", - "description": "Hindert Stahl-Pokémon durch Magnetismus an der Flucht." - }, - "soundproof": { - "name": "Lärmschutz", - "description": "Bietet durch Schalldämmung volle Immunität gegen alle Lärm-Attacken." - }, - "rainDish": { - "name": "Regengenuss", - "description": "Regeneriert bei Regen nach und nach KP." - }, - "sandStream": { - "name": "Sandsturm", - "description": "Erzeugt bei Kampfantritt Sandstürme." - }, - "pressure": { - "name": "Erzwinger", - "description": "Zwingt Gegner dazu, beim Einsatz von Attacken mehr AP zu verbrauchen." - }, - "thickFat": { - "name": "Speckschicht", - "description": "Das Pokémon wird von einer dicken Fettschicht geschützt, was den durch Feuer- und Eis-Attacken erlittenen Schaden halbiert." - }, - "earlyBird": { - "name": "Frühwecker", - "description": "Wenn es eingeschlafen ist, kann es doppelt so schnell wieder aufwachen wie andere Pokémon." - }, - "flameBody": { - "name": "Flammkörper", - "description": "Fügt dem Angreifer bei Berührung eventuell Verbrennungen zu." - }, - "runAway": { - "name": "Angsthase", - "description": "Die Flucht vor wilden Pokémon gelingt immer." - }, - "keenEye": { - "name": "Adlerauge", - "description": "Sein scharfer Blick hindert Angreifer daran, seine Genauigkeit zu senken." - }, - "hyperCutter": { - "name": "Scherenmacht", - "description": "Hindert Angreifer durch mächtige Scheren daran, den Angriffs-Wert zu senken." - }, - "pickup": { - "name": "Mitnahme", - "description": "Hebt gelegentlich von Gegnern benutzte Items auf. Dies geschieht nicht nur während Kämpfen, sondern auch unterwegs." - }, - "truant": { - "name": "Schnarchnase", - "description": "Das Pokémon muss nach Einsatz einer Attacke eine Runde lang aussetzen." - }, - "hustle": { - "name": "Übereifer", - "description": "Erhöht den Angriffs-Wert, aber senkt die Genauigkeit." - }, - "cuteCharm": { - "name": "Charmebolzen", - "description": "Wird dieses Pokémon durch eine direkte Attacke angegriffen, verliebt sich der Gegner eventuell in es." - }, - "plus": { - "name": "Plus", - "description": "Erhöht den Spezial-Angriff, wenn das Pokémon einen Mitstreiter mit der Fähigkeit Plus oder Minus hat." - }, - "minus": { - "name": "Minus", - "description": "Erhöht den Spezial-Angriff, wenn das Pokémon einen Mitstreiter mit der Fähigkeit Plus oder Minus hat." - }, - "forecast": { - "name": "Prognose", - "description": "Nimmt je nach Wetter entweder den Typ Wasser, Feuer oder Eis an." - }, - "stickyHold": { - "name": "Klebekörper", - "description": "Trägt es ein Item, bleibt dieses an seinem klebrigen Körper haften, wodurch Item-Diebstahl verhindert wird." - }, - "shedSkin": { - "name": "Expidermis", - "description": "Das Pokémon befreit sich eventuell von Statusproblemen, indem es seine Haut abstreift." - }, - "guts": { - "name": "Adrenalin", - "description": "Bei Statusproblemen setzt es Adrenalin frei und erhöht so seinen Angriffs-Wert." - }, - "marvelScale": { - "name": "Notschutz", - "description": "Bei Statusproblemen schützt es sich mit mysteriösen Schuppen und erhöht so seine Verteidigung." - }, - "liquidOoze": { - "name": "Kloakensoße", - "description": "Angreifer, die durch Saug-Attacken Kloakensoße in sich aufgenommen haben, nehmen durch deren widerwärtigen Gestank Schaden." - }, - "overgrow": { - "name": "Notdünger", - "description": "Erhöht die Stärke von Pflanzen-Attacken, wenn die KP auf einen gewissen Wert fallen." - }, - "blaze": { - "name": "Großbrand", - "description": "Erhöht die Stärke von Feuer-Attacken, wenn die KP auf einen gewissen Wert fallen." - }, - "torrent": { - "name": "Sturzbach", - "description": "Erhöht die Stärke von Wasser-Attacken, wenn die KP auf einen gewissen Wert fallen." - }, - "swarm": { - "name": "Hexaplaga", - "description": "Erhöht die Stärke von Käfer-Attacken, wenn die KP auf einen gewissen Wert fallen." - }, - "rockHead": { - "name": "Steinhaupt", - "description": "Verhindert Schaden, der durch Rückstoß entstehen würde." - }, - "drought": { - "name": "Dürre", - "description": "Erzeugt bei Kampfantritt gleißendes Sonnenlicht." - }, - "arenaTrap": { - "name": "Ausweglos", - "description": "Hindert Gegner im Kampf an der Flucht." - }, - "vitalSpirit": { - "name": "Munterkeit", - "description": "Das Pokémon ist so munter, dass es nicht einschlafen kann." - }, - "whiteSmoke": { - "name": "Pulverrauch", - "description": "Indem es sich mit pulvrigem Rauch umhüllt, hindert es Angreifer daran, seine Statuswerte zu senken." - }, - "purePower": { - "name": "Mentalkraft", - "description": "Verdoppelt mit reiner Willenskraft die Stärke seiner physischen Attacken." - }, - "shellArmor": { - "name": "Panzerhaut", - "description": "Wehrt gegnerische Volltreffer mit einem harten Panzer ab." - }, - "airLock": { - "name": "Klimaschutz", - "description": "Hebt alle Wetter-Effekte auf." - }, - "tangledFeet": { - "name": "Fußangel", - "description": "Erhöht den Ausweichwert, wenn das Pokémon verwirrt ist." - }, - "motorDrive": { - "name": "Starthilfe", - "description": "Treffer durch Elektro-Attacken verursachen keinen Schaden, sondern geben dem Pokémon eine Starthilfe und erhöhen so seine Initiative." - }, - "rivalry": { - "name": "Rivalität", - "description": "Greift es einen Rivalen desselben Geschlechts an, wird es stärker. Greift es ein Ziel des anderen Geschlechts an, wird es schwächer." - }, - "steadfast": { - "name": "Felsenfest", - "description": "Sein eiserner Wille erhöht die Initiative, wann immer das Pokémon zurückschreckt." - }, - "snowCloak": { - "name": "Schneemantel", - "description": "Erhöht bei Hagel den Ausweichwert." - }, - "gluttony": { - "name": "Völlerei", - "description": "Setzt bestimmte Beeren nicht erst in einer Notlage ein, sondern bereits dann, wenn seine KP auf die Hälfte des Maximalwerts fallen." - }, - "angerPoint": { - "name": "Kurzschluss", - "description": "Wird nach Einstecken eines Volltreffers wütend und maximiert dabei seinen Angriffs-Wert." - }, - "unburden": { - "name": "Entlastung", - "description": "Wenn das von ihm getragene Item verwendet wird oder verloren geht, erhöht dies seine Initiative." - }, - "heatproof": { - "name": "Hitzeschutz", - "description": "Sein Hitze abweisender Körper halbiert den durch Feuer-Attacken erlittenen Schaden." - }, - "simple": { - "name": "Wankelmut", - "description": "Verdoppelt die Wirkung eigener Statusveränderungen." - }, - "drySkin": { - "name": "Trockenheit", - "description": "Bei Sonnenschein verliert das Pokémon KP und der Schaden durch Feuer-Attacken steigt. Bei Regen und Treffern durch Wasser-Attacken regeneriert es KP." - }, - "download": { - "name": "Download", - "description": "Ist die Spezial-Verteidigung des Gegners höher als seine Verteidigung, wird der eigene Spezial-Angriff erhöht. Ist die Verteidigung höher, steigt der Angriff." - }, - "ironFist": { - "name": "Eisenfaust", - "description": "Erhöht die Stärke von Hieb-, Punch-, Faust- und Schlag-Attacken." - }, - "poisonHeal": { - "name": "Aufheber", - "description": "Das Pokémon erleidet keinen Schaden durch Vergiftung, sondern regeneriert KP." - }, - "adaptability": { - "name": "Anpassung", - "description": "Erhöht die Stärke von Attacken, die dem Typ des Pokémon entsprechen." - }, - "skillLink": { - "name": "Wertelink", - "description": "Landet mit Serien-Attacken immer die maximale Anzahl an Treffern." - }, - "hydration": { - "name": "Hydration", - "description": "Heilt bei Regen Statusprobleme." - }, - "solarPower": { - "name": "Solarkraft", - "description": "Führt bei Sonnenschein in jeder Runde zu KP-Verlusten, erhöht aber den Spezial-Angriff." - }, - "quickFeet": { - "name": "Rasanz", - "description": "Erhöht bei Statusproblemen die Initiative." - }, - "normalize": { - "name": "Regulierung", - "description": "Alle Attacken des Pokémon nehmen den Typ Normal an und ihre Stärke erhöht sich ein wenig." - }, - "sniper": { - "name": "Superschütze", - "description": "Erhöht bei Volltreffern die Stärke der Attacke noch weiter." - }, - "magicGuard": { - "name": "Magieschild", - "description": "Das Pokémon nimmt nur durch Offensiv-Attacken Schaden." - }, - "noGuard": { - "name": "Schildlos", - "description": "Alle Attacken des oder auf das Pokémon gelingen aufgrund seiner deckungslosen Kampftaktik." - }, - "stall": { - "name": "Zeitspiel", - "description": "Handelt auch mit Initiative-Vorteil stets als Letztes." - }, - "technician": { - "name": "Techniker", - "description": "Erhöht die Stärke von schwächeren Attacken." - }, - "leafGuard": { - "name": "Floraschild", - "description": "Verhindert bei Sonnenschein Statusprobleme." - }, - "klutz": { - "name": "Tollpatsch", - "description": "Das Pokémon kann keine getragenen Items verwenden." - }, - "moldBreaker": { - "name": "Überbrückung", - "description": "Attacken können ungeachtet der Fähigkeiten des Zieles verwendet werden." - }, - "superLuck": { - "name": "Glückspilz", - "description": "Großes Glück erhöht die Wahrscheinlichkeit, einen Volltreffer zu landen." - }, - "aftermath": { - "name": "Finalschlag", - "description": "Wird das Pokémon durch eine direkte Attacke besiegt, fügt es dem Angreifer Schaden zu." - }, - "anticipation": { - "name": "Vorahnung", - "description": "Kann gefährliche gegnerische Attacken erahnen." - }, - "forewarn": { - "name": "Vorwarnung", - "description": "Gibt bei Kampfantritt Auskunft über eine Attacke aus dem gegnerischen Repertoire." - }, - "unaware": { - "name": "Unkenntnis", - "description": "Greift das Pokémon an, ignoriert es sämtliche Statusveränderungen des Zieles." - }, - "tintedLens": { - "name": "Aufwertung", - "description": "Bewirkt, dass nicht sehr effektive Attacken dem Ziel trotz des Typennachteils normalen Schaden zufügen." - }, - "filter": { - "name": "Filter", - "description": "Reduziert die Stärke von sehr effektiven Attacken und verringert damit den Schaden, den das Pokémon durch sie erleidet." - }, - "slowStart": { - "name": "Saumselig", - "description": "Halbiert fünf Runden lang den Angriffs-Wert und die Initiative des Pokémon." - }, - "scrappy": { - "name": "Rauflust", - "description": "Bewirkt, dass Normal- und Kampf-Attacken auch Pokémon vom Typ Geist treffen können." - }, - "stormDrain": { - "name": "Sturmsog", - "description": "Zieht Wasser-Attacken an. Statt durch diese Schaden zu nehmen, erhöht es den eigenen Spezial-Angriff." - }, - "iceBody": { - "name": "Eishaut", - "description": "Regeneriert bei Hagel nach und nach KP." - }, - "solidRock": { - "name": "Felskern", - "description": "Reduziert die Stärke von sehr effektiven Attacken und verringert damit den Schaden, den das Pokémon durch sie erleidet." - }, - "snowWarning": { - "name": "Hagelalarm", - "description": "Löst bei Kampfantritt Hagel aus." - }, - "honeyGather": { - "name": "Honigmaul", - "description": "Sammelt nach dem Kampf Honig. Dieser wird dann für Geld verkauft." - }, - "frisk": { - "name": "Schnüffler", - "description": "Kann bei Kampfantritt Auskunft über die Fähigkeit vom Gegner geben." - }, - "reckless": { - "name": "Achtlos", - "description": "Erhöht die Stärke von Attacken mit Rückstoßschaden." - }, - "multitype": { - "name": "Variabilität", - "description": "Das Pokémon passt seinen Typ dem der getragenen Tafel bzw. des getragenen Z-Kristalls an." - }, - "flowerGift": { - "name": "Pflanzengabe", - "description": "Erhöht bei Sonnenschein den Angriff und die Spezial-Verteidigung aller Team-Pokémon." - }, - "badDreams": { - "name": "Alptraum", - "description": "Fügt schlafenden Gegnern Schaden zu." - }, - "pickpocket": { - "name": "Langfinger", - "description": "Stiehlt das Item des Angreifers bei Berührung." - }, - "sheerForce": { - "name": "Rohe Gewalt", - "description": "Erhöht die Stärke von Attacken, aber hebt dafür ihre Zusatzeffekte auf." - }, - "contrary": { - "name": "Umkehrung", - "description": "Statusveränderungen werden umgekehrt: Statuswerte, die eigentlich erhöht werden sollten, sinken und umgekehrt." - }, - "unnerve": { - "name": "Anspannung", - "description": "Erzeugt bei Gegnern Stress und hindert sie so daran, Beeren zu konsumieren." - }, - "defiant": { - "name": "Siegeswille", - "description": "Erhöht den Angriff stark, wenn ein Statuswert gesenkt wurde." - }, - "defeatist": { - "name": "Schwächling", - "description": "Fallen seine KP auf die Hälfte des Maximalwerts oder weniger, bekommt es Angst. Dadurch wird die Stärke seines Angriffs und Spezial-Angriffs halbiert." - }, - "cursedBody": { - "name": "Tastfluch", - "description": "Blockiert eventuell die Attacke, mit welcher der Angreifer es getroffen hat." - }, - "healer": { - "name": "Heilherz", - "description": "Befreit Mitstreiter gelegentlich von Statusproblemen." - }, - "friendGuard": { - "name": "Freundeshut", - "description": "Kann den Schaden, den Mitstreiter erleiden, verringern." - }, - "weakArmor": { - "name": "Bruchrüstung", - "description": "Senkt bei erlittenem Treffer durch eine physische Attacke die Verteidigung des Pokémon, aber erhöht dafür seine Initiative stark." - }, - "heavyMetal": { - "name": "Schwermetall", - "description": "Verdoppelt das eigene Gewicht." - }, - "lightMetal": { - "name": "Leichtmetall", - "description": "Halbiert das eigene Gewicht." - }, - "multiscale": { - "name": "Multischuppe", - "description": "Verringert den erlittenen Schaden bei vollen KP." - }, - "toxicBoost": { - "name": "Giftwahn", - "description": "Erhöht bei Vergiftungen die Stärke von physischen Attacken." - }, - "flareBoost": { - "name": "Hitzewahn", - "description": "Erhöht bei Verbrennungen die Stärke von Spezial-Attacken." - }, - "harvest": { - "name": "Reiche Ernte", - "description": "Dieselbe Beere kann mehrmals verwendet werden." - }, - "telepathy": { - "name": "Telepathie", - "description": "Erkennt und pariert Attacken von Mitstreitern." - }, - "moody": { - "name": "Gefühlswippe", - "description": "Erhöht in jeder Runde aufs Neue einen Statuswert stark und senkt einen anderen." - }, - "overcoat": { - "name": "Partikelschutz", - "description": "Nimmt weder durch Wetterlagen wie Sandsturm oder Hagel noch durch Pulver oder Puder Schaden." - }, - "poisonTouch": { - "name": "Giftgriff", - "description": "Kann das Ziel durch bloßes Berühren vergiften." - }, - "regenerator": { - "name": "Belebekraft", - "description": "Wird das Pokémon ausgewechselt, regeneriert es eine kleine Menge an KP." - }, - "bigPecks": { - "name": "Brustbieter", - "description": "Hindert Angreifer daran, die Verteidigung des Pokémon zu senken." - }, - "sandRush": { - "name": "Sandscharrer", - "description": "Erhöht in Sandstürmen die Initiative." - }, - "wonderSkin": { - "name": "Wunderhaut", - "description": "Wehrt mit robustem Körper viele Status-Attacken ab." - }, - "analytic": { - "name": "Analyse", - "description": "Greift das Pokémon zuletzt an, erhöht sich die Stärke der Attacke, die es einsetzt." - }, - "illusion": { - "name": "Trugbild", - "description": "Führt den Gegner hinters Licht, indem es bei Kampfantritt die Gestalt des Pokémon an der letzten Stelle im Team annimmt." - }, - "imposter": { - "name": "Doppelgänger", - "description": "Kämpft als Kopie seines Gegenübers." - }, - "infiltrator": { - "name": "Schwebedurch", - "description": "Überwindet gegnerische Schilde sowie Delegatoren und greift an." - }, - "mummy": { - "name": "Mumie", - "description": "Überträgt bei Berührung die Fähigkeit Mumie auf den Angreifer." - }, - "moxie": { - "name": "Hochmut", - "description": "Besiegt es ein Pokémon, steigt sein Selbstvertrauen und somit auch sein Angriff." - }, - "justified": { - "name": "Redlichkeit", - "description": "Wird es von einer Unlicht-Attacke getroffen, meldet sich sein Sinn für Gerechtigkeit zu Wort und sein Angriff steigt." - }, - "rattled": { - "name": "Hasenfuß", - "description": "Wird es von einer Unlicht-, Geister- oder Käfer-Attacke getroffen, bekommt es Angst und seine Initiative steigt." - }, - "magicBounce": { - "name": "Magiespiegel", - "description": "Lenkt Status-Attacken auf den Angreifer um, ohne selbst von ihnen getroffen zu werden." - }, - "sapSipper": { - "name": "Vegetarier", - "description": "Wird es von einer Pflanzen-Attacke getroffen, erleidet es keinerlei Schaden und sein Angriff steigt." - }, - "prankster": { - "name": "Strolch", - "description": "Ermöglicht einen Erstschlag mit Status-Attacken." - }, - "sandForce": { - "name": "Sandgewalt", - "description": "Erhöht in Sandstürmen die Stärke von Gesteins-, Boden- und Stahl-Attacken." - }, - "ironBarbs": { - "name": "Eisenstachel", - "description": "Fügt dem Angreifer bei Berührung mit eisernen Stacheln Schaden zu." - }, - "zenMode": { - "name": "TranceModus", - "description": "Fallen seine KP auf die Hälfte des Maximalwerts oder weniger, wechselt es seine Gestalt." - }, - "victoryStar": { - "name": "Triumphstern", - "description": "Erhöht die Genauigkeit aller Team-Pokémon." - }, - "turboblaze": { - "name": "Turbobrand", - "description": "Attacken können ungeachtet der Fähigkeit des Zieles eingesetzt werden." - }, - "teravolt": { - "name": "Teravolt", - "description": "Attacken können ungeachtet der Fähigkeit des Zieles eingesetzt werden." - }, - "aromaVeil": { - "name": "Dufthülle", - "description": "Kann alle Team-Pokémon vor mentalen Angriffen schützen." - }, - "flowerVeil": { - "name": "Blütenhülle", - "description": "Schützt Mitstreiter vom Typ Pflanze vor dem Senken ihrer Statuswerte sowie vor Statusproblemen." - }, - "cheekPouch": { - "name": "Backentaschen", - "description": "Regeneriert beim Konsum von Beeren ungeachtet der Beerensorte KP." - }, - "protean": { - "name": "Wandlungskunst", - "description": "Das Pokémon nimmt bei Einsatz einer Attacke deren Typ an." - }, - "furCoat": { - "name": "Fellkleid", - "description": "Halbiert den Schaden, den das Pokémon durch physische Attacken erleidet." - }, - "magician": { - "name": "Zauberer", - "description": "Trifft das Pokémon ein Ziel mit einer Attacke, kann es ihm dabei sein Item stehlen." - }, - "bulletproof": { - "name": "Kugelsicher", - "description": "Kann das Pokémon vor geworfenen kugelförmigen Objekten, wie zum Beispiel Bomben, schützen." - }, - "competitive": { - "name": "Unbeugsamkeit", - "description": "Erhöht den Spezial-Angriff stark, wenn ein Statuswert gesenkt wurde." - }, - "strongJaw": { - "name": "Titankiefer", - "description": "Der kräftige Kiefer des Pokémon erhöht die Stärke von Biss-Attacken." - }, - "refrigerate": { - "name": "Frostschicht", - "description": "Attacken vom Typ Normal nehmen den Typ Eis an und ihre Stärke erhöht sich ein wenig." - }, - "sweetVeil": { - "name": "Zuckerhülle", - "description": "Alle Team-Pokémon können nicht einschlafen." - }, - "stanceChange": { - "name": "Taktikwechsel", - "description": "Setzt das Pokémon eine Offensiv-Attacke ein, nimmt es die Klingenform an. Setzt es danach die Attacke Königsschild ein, nimmt es die Schildform an." - }, - "galeWings": { - "name": "Orkanschwingen", - "description": "Kann bei vollen KP einen Erstschlag mit Flug-Attacken ermöglichen." - }, - "megaLauncher": { - "name": "Megawumme", - "description": "Erhöht die Stärke einiger Wellen-, Aura- und Puls-Attacken." - }, - "grassPelt": { - "name": "Pflanzenpelz", - "description": "Erhöht die Verteidigung, wenn Grasfeld aktiv ist." - }, - "symbiosis": { - "name": "Nutznießer", - "description": "Gibt Mitstreitern, die ihr Item aufgebraucht haben, sein eigenes Item." - }, - "toughClaws": { - "name": "Krallenwucht", - "description": "Erhöht die Stärke von direkten Attacken." - }, - "pixilate": { - "name": "Feenschicht", - "description": "Attacken vom Typ Normal nehmen den Typ Fee an und ihre Stärke erhöht sich ein wenig." - }, - "gooey": { - "name": "Viskosität", - "description": "Senkt bei Berührung im Zuge eines Angriffs die Initiative des Angreifers." - }, - "aerilate": { - "name": "Zenithaut", - "description": "Attacken vom Typ Normal nehmen den Typ Flug an und ihre Stärke erhöht sich ein wenig." - }, - "parentalBond": { - "name": "Familienbande", - "description": "Zwei Generationen setzen jeweils ein Mal zum Angriff an." - }, - "darkAura": { - "name": "Dunkelaura", - "description": "Erhöht die Stärke aller Attacken des Typs Unlicht." - }, - "fairyAura": { - "name": "Feenaura", - "description": "Erhöht die Stärke aller Attacken des Typs Fee." - }, - "auraBreak": { - "name": "AuraUmkehr", - "description": "Kehrt die Wirkung von Auren um und senkt so die Stärke bestimmter Attacken, anstatt sie zu erhöhen." - }, - "primordialSea": { - "name": "Urmeer", - "description": "Ändert das Wetter, um Feuer-Attacken wirkungslos zu machen." - }, - "desolateLand": { - "name": "Endland", - "description": "Ändert das Wetter, um Wasser-Attacken wirkungslos zu machen." - }, - "deltaStream": { - "name": "DeltaWind", - "description": "Ändert das Wetter, um die Schwächen des Typs Flug zu beseitigen." - }, - "stamina": { - "name": "Zähigkeit", - "description": "Wird es von einer Attacke getroffen, steigt seine Verteidigung." - }, - "wimpOut": { - "name": "Reißaus", - "description": "Fallen seine KP auf die Hälfte des Maximalwerts oder weniger, zieht es sich ängstlich zurück." - }, - "emergencyExit": { - "name": "Rückzug", - "description": "Fallen seine KP auf die Hälfte des Maximalwerts oder weniger, bringt es sich in Sicherheit." - }, - "waterCompaction": { - "name": "Verklumpen", - "description": "Wird es von einer Wasser-Attacke getroffen, steigt seine Verteidigung stark." - }, - "merciless": { - "name": "Quälerei", - "description": "Sorgt bei Angriffen auf vergiftete Ziele für Volltreffergarantie." - }, - "shieldsDown": { - "name": "Limitschild", - "description": "Fallen seine KP auf die Hälfte des Maximalwerts oder weniger, zerbricht die Panzerung des Pokémon und es wird aggressiver." - }, - "stakeout": { - "name": "Beschattung", - "description": "Bewirkt bei Angriffen auf neu eingewechselte Ziele doppelten Schaden." - }, - "waterBubble": { - "name": "Wasserblase", - "description": "Feuer-Attacken fügen dem Pokémon weniger Schaden zu. Verhindert Verbrennungen." - }, - "steelworker": { - "name": "Stahlprofi", - "description": "Erhöht die Stärke von Stahl-Attacken." - }, - "berserk": { - "name": "Wutausbruch", - "description": "Fallen seine KP nach einem Angriff auf die Hälfte des Maximalwerts oder weniger, steigt sein Spezial-Angriff." - }, - "slushRush": { - "name": "Schneescharrer", - "description": "Erhöht bei Hagel die Initiative." - }, - "longReach": { - "name": "Langstrecke", - "description": "Ermöglicht dem Pokémon den Einsatz aller seiner Attacken, ohne das Ziel dabei direkt zu berühren." - }, - "liquidVoice": { - "name": "Plätscherstimme", - "description": "Bewirkt, dass alle Lärm-Attacken des Pokémon den Typ Wasser annehmen." - }, - "triage": { - "name": "Heilwandel", - "description": "Ermöglicht einen Erstschlag mit Attacken, welche die KP des Anwenders direkt regenerieren." - }, - "galvanize": { - "name": "Elektrohaut", - "description": "Attacken vom Typ Normal nehmen den Typ Elektro an und ihre Stärke erhöht sich ein wenig." - }, - "surgeSurfer": { - "name": "SurfSchweif", - "description": "Verdoppelt die Initiative, wenn zuvor ein Elektrofeld erzeugt wurde." - }, - "schooling": { - "name": "Fischschwarm", - "description": "Verfügt es über einen hohen KP-Wert, wird es zu einem Schwarm und gewinnt an Stärke. Ist der KP-Wert niedrig, löst sich der Schwarm wieder auf." - }, - "disguise": { - "name": "Kostümspuk", - "description": "Kann ein Mal pro Kampf mit seinem gruseligen Kostüm einen Angriff abwehren." - }, - "battleBond": { - "name": "Freundschaftsakt", - "description": "Besiegt es ein Ziel, vertieft dies die Freundschaft zu seinem Trainer, wodurch es die Ash-Form annimmt und sein Wasser-Shuriken stärker wird." - }, - "powerConstruct": { - "name": "Scharwandel", - "description": "Fallen seine KP auf die Hälfte des Maximalwerts oder weniger, eilen ihm weitere Zellen zu Hilfe und es nimmt die Optimumform an." - }, - "corrosion": { - "name": "Korrosion", - "description": "Kann selbst Pokémon vom Typ Stahl oder Gift vergiften." - }, - "comatose": { - "name": "Dauerschlaf", - "description": "Das Pokémon befindet sich ununterbrochen im Halbschlaf und wacht nie vollständig auf. Es kann jedoch im Schlaf angreifen." - }, - "queenlyMajesty": { - "name": "Majestät", - "description": "Schüchtert Gegner ein und hindert sie so daran, Erstschlag-Attacken gegen es einzusetzen." - }, - "innardsOut": { - "name": "Magenkrempler", - "description": "Wird es durch eine Attacke besiegt, fügt es dem Angreifer Schaden in Höhe des KP-Werts zu, den es besaß, bevor es kampfunfähig wurde." - }, - "dancer": { - "name": "Tänzer", - "description": "Kann direkt im Anschluss an die Tanz-Attacke eines anderen Pokémon ebenfalls eine solche einsetzen." - }, - "battery": { - "name": "Batterie", - "description": "Erhöht die Stärke der Spezial-Attacken seiner Mitstreiter." - }, - "fluffy": { - "name": "Flauschigkeit", - "description": "Halbiert den Schaden, den es durch direkte Attacken nimmt, aber verdoppelt dafür den durch Feuer-Attacken erlittenen Schaden." - }, - "dazzling": { - "name": "Buntkörper", - "description": "Überrascht Gegner und hindert sie so daran, Erstschlag-Attacken gegen es einzusetzen." - }, - "soulHeart": { - "name": "Seelenherz", - "description": "Erhöht jedes Mal, wenn ein Pokémon besiegt wird, den eigenen Spezial-Angriff." - }, - "tanglingHair": { - "name": "Lockenkopf", - "description": "Senkt bei Berührung im Zuge eines Angriffs die Initiative des Angreifers." - }, - "receiver": { - "name": "Receiver", - "description": "Wird einer seiner Mitstreiter besiegt, erhält es dessen Fähigkeit." - }, - "powerOfAlchemy": { - "name": "Chemiekraft", - "description": "Wechselt seine Fähigkeit zu der eines kampfunfähig gewordenen Mitstreiters." - }, - "beastBoost": { - "name": "Bestien-Boost", - "description": "Erhöht in jeder Runde, in der es ein anderes Pokémon besiegt, seinen höchsten Statuswert." - }, - "rksSystem": { - "name": "Alpha-System", - "description": "Das Pokémon passt seinen Typ der getragenen Disc an." - }, - "electricSurge": { - "name": "Elektro-Erzeuger", - "description": "Erzeugt bei Kampfantritt ein Elektrofeld." - }, - "psychicSurge": { - "name": "Psycho-Erzeuger", - "description": "Erzeugt bei Kampfantritt ein Psychofeld." - }, - "mistySurge": { - "name": "Nebel-Erzeuger", - "description": "Erzeugt bei Kampfantritt ein Nebelfeld." - }, - "grassySurge": { - "name": "Gras-Erzeuger", - "description": "Erzeugt bei Kampfantritt ein Grasfeld." - }, - "fullMetalBody": { - "name": "Metallprotektor", - "description": "Verhindert das Senken der Statuswerte durch Attacken und Fähigkeiten von Angreifern." - }, - "shadowShield": { - "name": "Phantomschutz", - "description": "Verringert den erlittenen Schaden bei vollen KP." - }, - "prismArmor": { - "name": "Prismarüstung", - "description": "Reduziert die Stärke von sehr effektiven Attacken und verringert damit den Schaden, den das Pokémon durch sie erleidet." - }, - "neuroforce": { - "name": "Zerebralmacht", - "description": "Erhöht die Stärke von sehr effektiven Attacken." - }, - "intrepidSword": { - "name": "Kühnes Schwert", - "description": "Erhöht bei Kampfantritt den Angriff." - }, - "dauntlessShield": { - "name": "Wackerer Schild", - "description": "Erhöht bei Kampfantritt die Verteidigung." - }, - "libero": { - "name": "Libero", - "description": "Das Pokémon nimmt bei Einsatz einer Attacke deren Typ an." - }, - "ballFetch": { - "name": "Apport", - "description": "Trägt das Pokémon kein Item bei sich, hebt es den Ball aus dem ersten gescheiterten Fangversuch des Kampfes wieder auf." - }, - "cottonDown": { - "name": "Wollflaum", - "description": "Wird es von einem Angriff getroffen, verstreut es Teile seines Wollflaums, wodurch die Initiative aller anderen Pokémon sinkt." - }, - "propellerTail": { - "name": "Schraubflosse", - "description": "Ignoriert die Effekte von Fähigkeiten und Attacken anderer Pokémon, die Attacken auf sich lenken." - }, - "mirrorArmor": { - "name": "Spiegelrüstung", - "description": "Lenkt ausschließlich Effekte, welche die Statuswerte des Pokémon senken würden, auf den Angreifer um." - }, - "gulpMissile": { - "name": "Würggeschoss", - "description": "Wenn das Pokémon Surfer oder Taucher einsetzt, fängt es sich dabei Beute. Erleidet es anschließend Schaden, greift es an, indem es die Beute wieder ausspuckt." - }, - "stalwart": { - "name": "Stahlrückgrat", - "description": "Ignoriert die Effekte von Fähigkeiten und Attacken anderer Pokémon, die Attacken auf sich lenken." - }, - "steamEngine": { - "name": "Dampfantrieb", - "description": "Wird es von einer Wasser- oder Feuer-Attacke getroffen, steigt seine Initiative drastisch." - }, - "punkRock": { - "name": "Punk Rock", - "description": "Erhöht die Stärke von eigenen Lärm-Attacken und halbiert den Schaden, den das Pokémon selbst durch Lärm-Attacken erleidet." - }, - "sandSpit": { - "name": "Sandspeier", - "description": "Löst einen Sandsturm aus, wenn das Pokémon von einer Attacke erfasst wird." - }, - "iceScales": { - "name": "Eisflügelstaub", - "description": "Halbiert mithilfe von schützendem Eisflügelstaub den Schaden, den das Pokémon durch Spezial-Attacken erleidet." - }, - "ripen": { - "name": "Heranreifen", - "description": "Verdoppelt den Effekt von Beeren, indem es sie heranreifen lässt." - }, - "iceFace": { - "name": "Tiefkühlkopf", - "description": "Der Eisblock um seinen Kopf blockt eine physische Attacke ab. Dies bewirkt jedoch einen Formwechsel. Durch Hagel wird der Eisblock wiederhergestellt." - }, - "powerSpot": { - "name": "Kraftquelle", - "description": "Erhöht bei direkt benachbarten Pokémon die Stärke von Attacken." - }, - "mimicry": { - "name": "Mimese", - "description": "Der Typ des Pokémon ändert sich in Abhängigkeit vom Zustand des Feldes." - }, - "screenCleaner": { - "name": "Hemmungslos", - "description": "Hebt bei Kampfantritt die Wirkung von Lichtschild, Reflektor und Auroraschleier auf Mitstreiter- und Gegnerseite auf." - }, - "steelySpirit": { - "name": "Stählerner Wille", - "description": "Erhöht die Stärke von Stahl-Attacken auf Mitstreiterseite." - }, - "perishBody": { - "name": "Unheilskörper", - "description": "Erleidet es einen Treffer von einer direkten Attacke, wird es zusammen mit dem Angreifer nach drei Runden besiegt. Rettung ist durch Austausch möglich." - }, - "wanderingSpirit": { - "name": "Rastlose Seele", - "description": "Wird das Pokémon von einer direkten Attacke getroffen, tauscht es seine Fähigkeit mit der des Angreifers." - }, - "gorillaTactics": { - "name": "Affenfokus", - "description": "Erhöht den Angriff, aber nur die zuerst gewählte Attacke kann eingesetzt werden." - }, - "neutralizingGas": { - "name": "Reaktionsgas", - "description": "Solange ein Pokémon mit der Fähigkeit Reaktionsgas am Kampf beteiligt ist, werden die Fähigkeiten aller anderen Pokémon unterdrückt oder aufgehoben." - }, - "pastelVeil": { - "name": "Pastellhülle", - "description": "Schützt das Pokémon und seine Mitstreiter vor Vergiftung." - }, - "hungerSwitch": { - "name": "Heißhunger", - "description": "Das Pokémon ändert zum Ende jeder Runde seine Form und wechselt somit zwischen dem Pappsatt- und dem Kohldampfmuster." - }, - "quickDraw": { - "name": "Schnellschuss", - "description": "Ermöglicht dem Pokémon gelegentlich den Erstschlag." - }, - "unseenFist": { - "name": "Verborgene Faust", - "description": "Wenn das Pokémon eine direkte Attacke einsetzt, trifft diese auch dann, wenn sich das Ziel selbst schützt." - }, - "curiousMedicine": { - "name": "Kuriose Arznei", - "description": "Das Pokémon versprüht bei Kampfantritt Arznei aus seiner Muschel, die alle Statusveränderungen auf der Mitstreiterseite aufhebt." - }, - "transistor": { - "name": "Transistor", - "description": "Erhöht die Stärke von Elektro-Attacken." - }, - "dragonsMaw": { - "name": "Drachenkiefer", - "description": "Erhöht die Stärke von Drachen-Attacken." - }, - "chillingNeigh": { - "name": "Helles Wiehern", - "description": "Besiegt es ein Pokémon, stößt es ein frostiges Wiehern aus und erhöht damit seinen Angriff." - }, - "grimNeigh": { - "name": "Dunkles Wiehern", - "description": "Besiegt es ein Pokémon, stößt es ein furchteinflößendes Wiehern aus und erhöht damit seinen Spezial-Angriff." - }, - "asOneGlastrier": { - "name": "Reitgespann", - "description": "Das Pokémon verfügt sowohl über Coronospas Fähigkeit Anspannung als auch über Polaross’ Fähigkeit Helles Wiehern." - }, - "asOneSpectrier": { - "name": "Reitgespann", - "description": "Das Pokémon verfügt sowohl über Coronospas Fähigkeit Anspannung als auch über Phantoross’ Fähigkeit Dunkles Wiehern." - }, - "lingeringAroma": { - "name": "Duftschwade", - "description": "Das Pokémon überträgt bei Berührung die Fähigkeit Duftschwade auf den Angreifer." - }, - "seedSower": { - "name": "Streusaat", - "description": "Wird das Pokémon von einem Angriff getroffen, erzeugt es ein Grasfeld." - }, - "thermalExchange": { - "name": "Thermowandel", - "description": "Wird das Pokémon von einer Feuer-Attacke getroffen, steigt sein Angriff. Außerdem kann es keine Verbrennung erleiden." - }, - "angerShell": { - "name": "Wutpanzer", - "description": "Fallen die KP des Pokémon durch einen Angriff auf die Hälfte des Maximalwerts oder weniger, sinken Vert. und Sp.-Vert., aber Ang., Sp.-Ang. und Initiative steigen." - }, - "purifyingSalt": { - "name": "Läutersalz", - "description": "Das Pokémon kann dank seines läuternden Salzes keine Statusprobleme erleiden und der durch Geist-Attacken erlittene Schaden wird halbiert." - }, - "wellBakedBody": { - "name": "Knusperkruste", - "description": "Wird das Pokémon von einer Feuer-Attacke getroffen, erleidet es keinen Schaden. Stattdessen steigt seine Verteidigung stark." - }, - "windRider": { - "name": "Windreiter", - "description": "Wirkt Rückenwind oder wird das Pokémon von einer Wind-Attacke getroffen, steigt sein Angriff. Außerdem erleidet es keinen Schaden durch Wind-Attacken." - }, - "guardDog": { - "name": "Wachhund", - "description": "Wird das Pokémon bedroht, steigt sein Angriff. Attacken und Items, durch die Pokémon ausgetauscht werden, haben keine Wirkung auf es." - }, - "rockyPayload": { - "name": "Steinträger", - "description": "Die Stärke von Gesteins-Attacken des Pokémon steigt." - }, - "windPower": { - "name": "Windkraft", - "description": "Wird das Pokémon von einer Wind-Attacke getroffen, lädt es sich auf. Dadurch steigt die Stärke seiner nächsten Elektro-Attacke." - }, - "zeroToHero": { - "name": "Superwechsel", - "description": "Wird das Pokémon ausgewechselt, nimmt es die Heldenform an." - }, - "commander": { - "name": "Kommandant", - "description": "Befindet sich ein Heerashai auf der Mitstreiterseite, springt das Pokémon bei Kampfantritt in dessen Maul und gibt von dort aus Befehle." - }, - "electromorphosis": { - "name": "Dynamo", - "description": "Wenn das Pokémon Schaden erleidet, lädt es sich auf. Dadurch steigt die Stärke seiner nächsten Elektro-Attacke." - }, - "protosynthesis": { - "name": "Paläosynthese", - "description": "Bei Sonnenschein oder wenn das Pokémon eine Energiekapsel trägt, steigt sein höchster Statuswert." - }, - "quarkDrive": { - "name": "Quantenantrieb", - "description": "Im Elektrofeld oder wenn das Pokémon eine Energiekapsel trägt, steigt sein höchster Statuswert." - }, - "goodAsGold": { - "name": "Goldkörper", - "description": "Dank seines robusten Körpers aus reinem, rostfreiem Gold kann das Pokémon nicht von Status-Attacken getroffen werden." - }, - "vesselOfRuin": { - "name": "Unheilsgefäß", - "description": "Mit der Macht seines Unheil bringenden Gefäßes schwächt das Pokémon den Spezial-Angriff aller anderen Pokémon." - }, - "swordOfRuin": { - "name": "Unheilsschwert", - "description": "Mit der Macht seines Unheil bringenden Schwertes schwächt das Pokémon die Verteidigung aller anderen Pokémon." - }, - "tabletsOfRuin": { - "name": "Unheilstafeln", - "description": "Mit der Macht seiner Unheil bringenden Holztafeln schwächt das Pokémon den Angriff aller anderen Pokémon." - }, - "beadsOfRuin": { - "name": "Unheilsjuwelen", - "description": "Mit der Macht seiner Unheil bringenden Juwelen schwächt das Pokémon die Spezial-Verteidigung aller anderen Pokémon." - }, - "orichalcumPulse": { - "name": "Orichalkum-Puls", - "description": "Das Pokémon erzeugt bei Kampfantritt Sonnenschein. Bei Sonnenschein verstärkt ein urzeitlicher Puls seinen Angriff." - }, - "hadronEngine": { - "name": "Hadronen-Motor", - "description": "Das Pokémon erzeugt bei Kampfantritt ein Elektrofeld. Wenn ein Elektrofeld aktiv ist, verstärkt ein futuristischer Motor seinen Spezial-Angriff." - }, - "opportunist": { - "name": "Profiteur", - "description": "Wenn ein Statuswert eines Gegners steigt, profitiert das Pokémon ebenfalls davon und der gleiche Statuswert steigt auch bei ihm." - }, - "cudChew": { - "name": "Wiederkäuer", - "description": "Wenn ein Pokémon eine Beere isst, stößt es diese am Ende der nächsten Runde wieder aus seinem Magen auf und verspeist diese erneut." - }, - "sharpness": { - "name": "Scharfkantig", - "description": "Die Stärke von Schnitt-Attacken des Pokémon steigt." - }, - "supremeOverlord": { - "name": "Feldherr", - "description": "Bei Kampfantritt steigen der Angriff und Spezial-Angriff des Pokémon ein bisschen für jedes bis dahin besiegte Team-Mitglied." - }, - "costar": { - "name": "Synchronauftritt", - "description": "Das Pokémon kopiert bei Kampfantritt die Statusveränderungen eines Mitstreiters." - }, - "toxicDebris": { - "name": "Giftbelag", - "description": "Erleidet das Pokémon Schaden durch eine physische Attacke, verstreut es giftige Stacheln auf der gegnerischen Seite." - }, - "armorTail": { - "name": "Schweifrüstung", - "description": "Der rätselhafte Schweif, der den Kopf des Pokémon umhüllt, hindert Gegner daran, Erstschlag-Attacken gegen die Mitstreiterseite einzusetzen." - }, - "earthEater": { - "name": "Bodenschmaus", - "description": "Wird das Pokémon von einer Boden-Attacke getroffen, erleidet es keinen Schaden, sondern regeneriert stattdessen KP." - }, - "myceliumMight": { - "name": "Myzelienkraft", - "description": "Beim Einsatz von Status-Attacken handelt das Pokémon stets langsamer, aber dafür kann es sie ungeachtet der Fähigkeit des Zieles einsetzen." - }, - "mindsEye": { - "name": "Geistiges Auge", - "description": "Die Genauigkeit des Pokémon kann nicht gesenkt werden. Es ignoriert Änderungen am Ausweichwert des Zieles und trifft mit Normal- und Kampf-Attacken Geister-Pokémon." - }, - "supersweetSyrup": { - "name": "Süßer Nektar", - "description": "Beim ersten Kampfantritt verbreitet das Pokémon den Duft süßen Nektars und senkt so den Ausweichwert seiner Gegner." - }, - "hospitality": { - "name": "Gastlichkeit", - "description": "Bei Kampfantritt zeigt das Pokémon seine Gastlichkeit, indem es die KP seines Mitstreiters ein wenig auffüllt." - }, - "toxicChain": { - "name": "Giftkette", - "description": "Durch die toxischen Stoffe in seiner Kette werden Ziele, die das Pokémon mit einer Attacke trifft, gelegentlich schwer vergiftet." - }, - "embodyAspectTeal": { - "name": "Erinnerungskraft", - "description": "Die Erinnerungen, die das Pokémon in sich trägt, lassen die Türkisgrüne Maske aufleuchten und erhöhen seine Initiative." - }, - "embodyAspectWellspring": { - "name": "Erinnerungskraft", - "description": "Die Erinnerungen, die das Pokémon in sich trägt, lassen die Brunnenmaske aufleuchten und erhöhen seine Spezial-Verteidigung." - }, - "embodyAspectHearthflame": { - "name": "Erinnerungskraft", - "description": "Die Erinnerungen, die das Pokémon in sich trägt, lassen die Ofenmaske aufleuchten und erhöhen seinen Angriff." - }, - "embodyAspectCornerstone": { - "name": "Erinnerungskraft", - "description": "Die Erinnerungen, die das Pokémon in sich trägt, lassen die Fundamentmaske aufleuchten und erhöhen seine Verteidigung." - }, - "teraShift": { - "name": "Tera-Wandel", - "description": "Bei Kampfantritt absorbiert das Pokémon Energie in seiner Umgebung und nimmt die Terakristall-Form an." - }, - "teraShell": { - "name": "Tera-Panzer", - "description": "Der Panzer des Pokémon birgt die Kraft aller Typen in sich. Alle Schaden verursachenden Attacken, die es bei vollen KP treffen, sind nicht sehr effektiv." - }, - "teraformZero": { - "name": "Teraforming Null", - "description": "Wenn Terapagos die Stellarform annimmt, eliminiert es dank seiner verborgenen Kräfte sämtliche Wettereffekte und Felder." - }, - "poisonPuppeteer": { - "name": "Giftpuppenspiel", - "description": "Wenn Infamomo ein Ziel mit einer Attacke vergiftet, so wird dieses auch verwirrt." - } -} \ No newline at end of file diff --git a/src/locales/de/achv.json b/src/locales/de/achv.json deleted file mode 100644 index 21a1d89f9d6..00000000000 --- a/src/locales/de/achv.json +++ /dev/null @@ -1,277 +0,0 @@ -{ - "Achievements": { - "name": "Errungenschaften" - }, - "Locked": { - "name": "Gesperrt" - }, - "MoneyAchv": { - "description": "Häufe eine Gesamtsumme von {{moneyAmount}} ₽ an." - }, - "10K_MONEY": { - "name": "Besserverdiener", - "name_female": "Besserverdienerin" - }, - "100K_MONEY": { - "name": "Reich" - }, - "1M_MONEY": { - "name": "Millionär", - "name_female": "Millionärin" - }, - "10M_MONEY": { - "name": "Einprozenter" - }, - "DamageAchv": { - "description": "Füge mit einem Treffer {{damageAmount}} Schaden zu." - }, - "250_DMG": { - "name": "Harte Treffer" - }, - "1000_DMG": { - "name": "Härtere Treffer" - }, - "2500_DMG": { - "name": "Das ist ne Menge Schaden!" - }, - "10000_DMG": { - "name": "One Punch Man", - "name_female": "One Punch Woman" - }, - "HealAchv": { - "description": "Heile {{healAmount}} {{HP}} auf einmal. Mit einer Attacke, Fähigkeit oder einem gehaltenen Gegenstand." - }, - "250_HEAL": { - "name": "Anfänger-Heiler", - "name_female": "Anfänger-Heilerin" - }, - "1000_HEAL": { - "name": "Gesundheitsprofi" - }, - "2500_HEAL": { - "name": "Kleriker", - "name_female": "Klerikerin" - }, - "10000_HEAL": { - "name": "Wiederherstellungsmeister", - "name_female": "Wiederherstellungsmeisterin" - }, - "LevelAchv": { - "description": "Erhöhe das Level eines Pokémon auf {{level}}." - }, - "LV_100": { - "name": "Warte, es gibt mehr!" - }, - "LV_250": { - "name": "Elite" - }, - "LV_1000": { - "name": "Geh noch höher hinaus!" - }, - "RibbonAchv": { - "description": "Sammle insgesamt {{ribbonAmount}} Bänder." - }, - "10_RIBBONS": { - "name": "Champion der Pokémon Liga" - }, - "25_RIBBONS": { - "name": "Bänder-Sammler", - "name_female": "Bänder-Sammlerin" - }, - "50_RIBBONS": { - "name": "Bänder-Experte", - "name_female": "Bänder-Expertin" - }, - "75_RIBBONS": { - "name": "Bänder-Guru" - }, - "100_RIBBONS": { - "name": "Bänder-Meister", - "name_female": "Bänder-Meisterin" - }, - "TRANSFER_MAX_STAT_STAGE": { - "name": "Teamwork", - "description": "Nutze Staffette, während der Anwender mindestens eines Statuswertes maximiert hat." - }, - "MAX_FRIENDSHIP": { - "name": "Freundschaftsmaximierung", - "description": "Erreiche maximale Freundschaft bei einem Pokémon." - }, - "MEGA_EVOLVE": { - "name": "Megaverwandlung", - "description": "Megaentwickle ein Pokémon." - }, - "GIGANTAMAX": { - "name": "Absolute Einheit", - "description": "Gigadynamaximiere ein Pokémon." - }, - "TERASTALLIZE": { - "name": "Typen-Bonus Enthusiast", - "description": "Terrakristallisiere ein Pokémon." - }, - "STELLAR_TERASTALLIZE": { - "name": "Der geheime Typ", - "description": "Terrakristallisiere ein Pokémon zum Typen Stellar." - }, - "SPLICE": { - "name": "Unendliche Fusion", - "description": "Kombiniere zwei Pokémon mit einem DNS-Keil." - }, - "MINI_BLACK_HOLE": { - "name": "Ein Loch voller Items", - "description": "Erlange ein Mini-Schwarzes Loch." - }, - "CATCH_MYTHICAL": { - "name": "Mysteriöses!", - "description": "Fange ein mysteriöses Pokémon." - }, - "CATCH_SUB_LEGENDARY": { - "name": "Sub-Legendär", - "description": "Fange ein sub-legendäres Pokémon." - }, - "CATCH_LEGENDARY": { - "name": "Legendär", - "description": "Fange ein legendäres Pokémon." - }, - "SEE_SHINY": { - "name": "Schillerndes Licht", - "description": "Finde ein wildes schillerndes Pokémon." - }, - "SHINY_PARTY": { - "name": "Das ist Hingabe", - "description": "Habe ein Team aus schillernden Pokémon." - }, - "HATCH_MYTHICAL": { - "name": "Mysteriöses Ei", - "description": "Lass ein mysteriöses Pokémon aus einem Ei schlüpfen." - }, - "HATCH_SUB_LEGENDARY": { - "name": "Sub-Legendäres Ei", - "description": "Lass ein sub-legendäres Pokémon aus einem Ei schlüpfen." - }, - "HATCH_LEGENDARY": { - "name": "Legendäres Ei", - "description": "Lass ein legendäres Pokémon aus einem Ei schlüpfen." - }, - "HATCH_SHINY": { - "name": "Schillerndes Ei", - "description": "Lass ein schillerndes Pokémon aus einem Ei schlüpfen." - }, - "HIDDEN_ABILITY": { - "name": "Geheimes Talent", - "description": "Fang ein Pokémon mit versteckter Fähigkeit." - }, - "PERFECT_IVS": { - "name": "Zertifikat der Echtheit", - "description": "Erhalte ein Pokémon mit perfekten IS-Werten." - }, - "CLASSIC_VICTORY": { - "name": "Ungeschlagen", - "description": "Beende den klassischen Modus erfolgreich." - }, - "UNEVOLVED_CLASSIC_VICTORY": { - "name": "'Bringe dein Kind mit zur Arbeit'-Tag", - "description": "Beende den klassischen Modus erfolgreich mit mindestens einem nicht entwickeltem Pokémon in deinem Team" - }, - "MONO_GEN_ONE": { - "name": "Der originale Rivale", - "description": "Schließe die 'Nur 1. Generation' Herausforderung ab." - }, - "MONO_GEN_TWO": { - "name": "Generation 1.5", - "description": "Schließe die 'Nur 2. Generation' Herausforderung ab." - }, - "MONO_GEN_THREE": { - "name": "Zu viel Wasser?", - "description": "Schließe die 'Nur 3. Generation' Herausforderung ab." - }, - "MONO_GEN_FOUR": { - "name": "Ist SIE wirklich die Stärkste?", - "description": "Schließe die 'Nur 4. Generation' Herausforderung ab." - }, - "MONO_GEN_FIVE": { - "name": "Komplett Original", - "description": "Schließe die 'Nur 5. Generation' Herausforderung ab." - }, - "MONO_GEN_SIX": { - "name": "Fast Königlich", - "description": "Schließe die 'Nur 6. Generation' Herausforderung ab." - }, - "MONO_GEN_SEVEN": { - "name": "Technisch gesehen", - "description": "Schließe die 'Nur 7. Generation' Herausforderung ab." - }, - "MONO_GEN_EIGHT": { - "name": "Die Zeit des Champions", - "description": "Schließe die 'Nur 8. Generation' Herausforderung ab." - }, - "MONO_GEN_NINE": { - "name": "Sie hat es dir leicht gemacht...", - "description": "Schließe die 'Nur 9. Generation' Herausforderung ab." - }, - "MonoType": { - "description": "Beende die Monotyp-{{type}} Herausforderung." - }, - "MONO_NORMAL": { - "name": "Normaler Typ" - }, - "MONO_FIGHTING": { - "name": "Ich kenne Kung Fu." - }, - "MONO_FLYING": { - "name": "Ich glaube ich kann fliegen." - }, - "MONO_POISON": { - "name": "Kantos Liebling" - }, - "MONO_GROUND": { - "name": "Auf dem Boden bleiben." - }, - "MONO_ROCK": { - "name": "So hart wie Rocko." - }, - "MONO_BUG": { - "name": "Steche wie ein Bibor." - }, - "MONO_GHOST": { - "name": "Wer wird angerufen?" - }, - "MONO_STEEL": { - "name": "Stahlharte Entschlossenheit" - }, - "MONO_FIRE": { - "name": "Brennende Leidenschaft" - }, - "MONO_WATER": { - "name": "Wenn es regnet, schüttet es!" - }, - "MONO_GRASS": { - "name": "Grüner Daumen" - }, - "MONO_ELECTRIC": { - "name": "Elektrisierend" - }, - "MONO_PSYCHIC": { - "name": "Übernatürliches Talent" - }, - "MONO_ICE": { - "name": "Eis Eis Baby" - }, - "MONO_DRAGON": { - "name": "Siegfried bist du es?" - }, - "MONO_DARK": { - "name": "Es ist nur eine Phase!" - }, - "MONO_FAIRY": { - "name": "Ein ewiges Abenteuer!" - }, - "FRESH_START": { - "name": "Hussa, noch einmal von vorn!", - "description": "Schließe die 'Neuanfang' Herausforderung ab" - }, - "INVERSE_BATTLE": { - "name": "Spieglein, Spieglein an der Wand", - "description": "Schließe die 'Umkehrkampf' Herausforderung ab" - } -} diff --git a/src/locales/de/arena-flyout.json b/src/locales/de/arena-flyout.json deleted file mode 100644 index a1f2254c642..00000000000 --- a/src/locales/de/arena-flyout.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "activeBattleEffects": "Aktive Kampfeffekte", - "player": "Spieler", - "neutral": "Neutral", - "enemy": "Gegner", - "sunny": "Sonne", - "rain": "Regen", - "sandstorm": "Sandsturm", - "hail": "Hagelsturm", - "snow": "Schneesturm", - "fog": "Nebel", - "heavyRain": "Strömender Regen", - "harshSun": "Sehr starker Sonnenschein", - "strongWinds": "Luftströmungen", - "misty": "Nebelfeld", - "electric": "Elektrofeld", - "grassy": "Grasfeld", - "psychic": "Psychofeld", - "mudSport": "Lehmsuhler", - "waterSport": "Nassmacher", - "spikes": "Stachler", - "toxicSpikes": "Giftspitzen", - "mist": "Weißnebel", - "futureSight": "Seher", - "doomDesire": "Kismetwunsch", - "wish": "Wunschtraum", - "stealthRock": "Tarnsteine", - "stickyWeb": "Klebenetz", - "trickRoom": "Bizarroraum", - "gravity": "Erdanziehung", - "reflect": "Reflektor", - "lightScreen": "Lichtschild", - "auroraVeil": "Auroraschleier", - "quickGuard": "Rapidschutz", - "wideGuard": "Rundumschutz", - "matBlock": "Tatami-Schild", - "craftyShield": "Trickschutz", - "tailwind": "Rückenwind", - "happyHour": "Goldene Zeiten", - "safeguard": "Bodyguard" -} diff --git a/src/locales/de/arena-tag.json b/src/locales/de/arena-tag.json deleted file mode 100644 index 3bed4fefbd0..00000000000 --- a/src/locales/de/arena-tag.json +++ /dev/null @@ -1,57 +0,0 @@ -{ - "yourTeam": "Pokémon auf deiner Seite", - "opposingTeam": "Pokémon auf gegnerischer Seite", - "arenaOnRemove": "Der Effekt von {{moveName}} lässt nach!", - "arenaOnRemovePlayer": "Der Effekt von {{moveName}} lässt auf deiner Seite nach!", - "arenaOnRemoveEnemy": "Der Effekt von {{moveName}} lässt auf der Seite des Gegners nach!", - "mistOnAdd": "Pokémon, die auf der Seite von {{pokemonNameWithAffix}} kämpfen, werden in Weißnebel gehüllt!!", - "mistApply": "Der Weißnebel verhindert die Senkung von Statuswerten!", - "reflectOnAdd": "Reflektor stärkt Pokémon gegen physische Attacken!", - "reflectOnAddPlayer": "Reflektor stärkt Pokémon auf deiner Seite gegen physische Attacken!", - "reflectOnAddEnemy": "Reflektor stärkt gegnerische Pokémon gegen physische Attacken!", - "lightScreenOnAdd": "Lichtschild stärkt Pokémon gegen Spezial-Attacken!", - "lightScreenOnAddPlayer": "Lichtschild stärkt Pokémon, die auf deiner Seite kämpfen, gegen Spezial-Attacken!", - "lightScreenOnAddEnemy": "Lichtschild stärkt gegnerische Pokémon gegen Spezial-Attacken!", - "auroraVeilOnAdd": "Auroraschleier stärkt Pokémon gegen physische und Spezial-Attacken", - "auroraVeilOnAddPlayer": "Auroraschleier stärkt Pokémon auf deiner Seite gegen physische und Spezial-Attacken!", - "auroraVeilOnAddEnemy": "Auroraschleier stärkt gegnerische Pokémon gegen physische und Spezial-Attacken!", - "conditionalProtectOnAdd": "Die Pokémon werden von {{moveName}} behütet!", - "conditionalProtectOnAddPlayer": "Die Pokémon auf deiner Seite werden von {{moveName}} behütet!", - "conditionalProtectOnAddEnemy": "Die Pokémon auf der gegnerischen Seite werden von {{moveName}} behütet!", - "conditionalProtectApply": "{{pokemonNameWithAffix}} wird durch {{moveName}} geschützt!", - "matBlockOnAdd": "{{pokemonNameWithAffix}} bringt seinen Tatami-Schild in Position!", - "noCritOnAddPlayer": "{{moveName}} schützt dein Team vor Volltreffern!", - "noCritOnAddEnemy": "{{moveName}} schützt das gegnerische Team vor Volltreffern!", - "noCritOnRemove": "{{moveName}} von {{pokemonNameWithAffix}} hört auf zu wirken!", - "wishTagOnAdd": "Der Wunschtraum von {{pokemonNameWithAffix}} erfüllt sich!", - "mudSportOnAdd": "Die Stärke aller Elektro-Attacken wurde reduziert!", - "mudSportOnRemove": "Lehmsuhler hört auf zu wirken!", - "waterSportOnAdd": "Die Stärke aller Feuer-Attacken wurde reduziert!", - "waterSportOnRemove": "Nassmacher hört auf zu wirken!", - "spikesOnAdd": "Die {{opponentDesc}} sind von Stacheln umgeben!", - "spikesActivateTrap": "Die {{pokemonNameWithAffix}} wurde durch Stachler verletzt!!", - "toxicSpikesOnAdd": "Die {{opponentDesc}} sind überall von giftigen Stacheln umgeben", - "toxicSpikesActivateTrapPoison": "{{pokemonNameWithAffix}} absorbiert die {{moveName}}!", - "stealthRockOnAdd": "Um die {{opponentDesc}} schweben spitze Steine!", - "stealthRockActivateTrap": "{{pokemonNameWithAffix}} wird von spitzen Steinen getroffen!!", - "stickyWebOnAdd": "Am Boden um die {{opponentDesc}} entspinnt sich ein {{moveName}}!", - "stickyWebActivateTrap": "{{pokemonName}} ist im Klebenetz gefangen!", - "trickRoomOnAdd": "{{pokemonNameWithAffix}} hat die Dimensionen verdreht!", - "trickRoomOnRemove": "Die verdrehte Dimension ist wieder normal!", - "gravityOnAdd": "Die Erdanziehung wurde verstärkt!", - "gravityOnRemove": "Die Erdanziehung ist wieder normal!", - "tailwindOnAdd": "Die Pokémon erhalten Rückenwind!", - "tailwindOnAddPlayer": "Die Pokémon, die auf deiner Seite kämpfen, erhalten Rückenwind!", - "tailwindOnAddEnemy": "Die gegnerischen Pokémon erhalten Rückenwind!", - "tailwindOnRemove": "Der Rückenwind hat sich gelegt!", - "tailwindOnRemovePlayer": "Der Rückenwind auf deiner Seite hat sich gelegt!", - "tailwindOnRemoveEnemy": "Der Rückenwind auf gegnerischer Seite hat sich gelegt!", - "happyHourOnAdd": "Goldene Zeiten sind angebrochen!", - "happyHourOnRemove": "Die goldenen Zeiten sind vorbei!", - "safeguardOnAdd": "Das ganze Feld wird von einem Schleier umhüllt!", - "safeguardOnAddPlayer": "Das Team des Anwenders wird von einem Schleier umhüllt!", - "safeguardOnAddEnemy": "Das gegnerische Team wird von einem Schleier umhüllt!", - "safeguardOnRemove": "Der mystische Schleier, der das ganze Feld umgab, hat sich gelüftet!", - "safeguardOnRemovePlayer": "Der mystische Schleier, der dein Team umgab, hat sich gelüftet!", - "safeguardOnRemoveEnemy": "Der mystische Schleier, der das gegnerische Team umgab, hat sich gelüftet!" -} \ No newline at end of file diff --git a/src/locales/de/battle-info.json b/src/locales/de/battle-info.json deleted file mode 100644 index f7844273af8..00000000000 --- a/src/locales/de/battle-info.json +++ /dev/null @@ -1,3 +0,0 @@ -{ - "generation": "Generation {{generation}}" -} \ No newline at end of file diff --git a/src/locales/de/battle-message-ui-handler.json b/src/locales/de/battle-message-ui-handler.json deleted file mode 100644 index 0d8038b5a85..00000000000 --- a/src/locales/de/battle-message-ui-handler.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "ivBest": "Sensationell", - "ivFantastic": "Fantastisch", - "ivVeryGood": "Sehr Gut", - "ivPrettyGood": "Gut", - "ivDecent": "Nicht Übel", - "ivNoGood": "Schlecht" -} \ No newline at end of file diff --git a/src/locales/de/battle-scene.json b/src/locales/de/battle-scene.json deleted file mode 100644 index ef916edbf08..00000000000 --- a/src/locales/de/battle-scene.json +++ /dev/null @@ -1,3 +0,0 @@ -{ - "moneyOwned": "{{formattedMoney}} ₽" -} \ No newline at end of file diff --git a/src/locales/de/battle.json b/src/locales/de/battle.json deleted file mode 100644 index 38e36d4b2da..00000000000 --- a/src/locales/de/battle.json +++ /dev/null @@ -1,100 +0,0 @@ -{ - "bossAppeared": "{{bossName}} erscheint.", - "trainerAppeared": "{{trainerName}} möchte kämpfen!", - "trainerAppearedDouble": "{{trainerName}} möchten kämpfen!", - "trainerSendOut": "{{trainerName}} setzt {{pokemonName}} ein!", - "singleWildAppeared": "Ein wildes {{pokemonName}} erscheint!", - "multiWildAppeared": "Ein wildes {{pokemonName1}} und {{pokemonName2}} erscheinen!", - "playerComeBack": "Komm zurück, {{pokemonName}}!", - "trainerComeBack": "{{trainerName}} ruft {{pokemonName}} zurück!", - "playerGo": "Los! {{pokemonName}}!", - "trainerGo": "{{trainerName}} sendet {{pokemonName}} raus!", - "switchQuestion": "Möchtest du {{pokemonName}} auswechseln?", - "trainerDefeated": "{{trainerName}} wurde besiegt!", - "moneyWon": "Du gewinnst {{moneyAmount}} ₽!", - "moneyPickedUp": "Du hebst {{moneyAmount}} ₽ auf!", - "pokemonCaught": "{{pokemonName}} wurde gefangen!", - "addedAsAStarter": "{{pokemonName}} wurde als Starterpokémon hinzugefügt!", - "partyFull": "Dein Team ist voll. Möchtest du ein Pokémon durch {{pokemonName}} ersetzen?", - "pokemon": "Pokémon", - "sendOutPokemon": "Los, {{pokemonName}}!", - "hitResultCriticalHit": "Ein Volltreffer!", - "hitResultSuperEffective": "Das ist sehr effektiv!", - "hitResultNotVeryEffective": "Das ist nicht sehr effektiv…", - "hitResultNoEffect": "Es hat keine Wirkung auf {{pokemonName}}…", - "hitResultImmune": "{{pokemonName}} ist unversehrt!", - "hitResultOneHitKO": "Ein K.O.-Treffer!", - "attackFailed": "Es ist fehlgeschlagen!", - "attackMissed": "Die Attacke hat {{pokemonNameWithAffix}} verfehlt!", - "attackHitsCount": "{{count}}-mal getroffen!", - "rewardGain": "Du erhältst {{modifierName}}!", - "expGain": "{{pokemonName}} erhält {{exp}} Erfahrungspunkte!", - "levelUp": "{{pokemonName}} erreicht Lv. {{level}}!", - "learnMove": "{{pokemonName}} erlernt {{moveName}}!", - "learnMovePrompt": "{{pokemonName}} versucht, {{moveName}} zu erlernen.", - "learnMoveLimitReached": "Aber {{pokemonName}} kann nur maximal vier Attacken erlernen.", - "learnMoveReplaceQuestion": "Soll eine bekannte Attacke durch {{moveName}} ersetzt werden?", - "learnMoveStopTeaching": "{{moveName}} nicht erlernen?", - "learnMoveNotLearned": "{{pokemonName}} hat {{moveName}} nicht erlernt.", - "learnMoveForgetQuestion": "Welche Attacke soll vergessen werden?", - "learnMoveForgetSuccess": "{{pokemonName}} hat {{moveName}} vergessen.", - "countdownPoof": "@d{32}Eins, @d{15}zwei @d{15}und@d{15}… @d{15}… @d{15}… @d{15}@s{se/pb_bounce_1}schwupp!", - "learnMoveAnd": "Und…", - "levelCapUp": "Die Levelbeschränkung wurde auf {{levelCap}} erhöht!", - "moveNotImplemented": "{{moveName}} ist noch nicht implementiert und kann nicht ausgewählt werden.", - "moveNoPP": "Es sind keine AP für diese Attacke mehr übrig!", - "moveDisabled": "{{moveName}} ist deaktiviert!", - "disableInterruptedMove": "{{moveName}} von {{pokemonNameWithAffix}} ist blockiert!", - "noPokeballForce": "Eine unsichtbare Kraft verhindert die Nutzung von Pokébällen.", - "noPokeballTrainer": "Du kannst das Pokémon eines anderen Trainers nicht fangen!", - "noPokeballMulti": "Du kannst erst einen Pokéball werfen, wenn nur noch ein Pokémon übrig ist!", - "noPokeballStrong": "Das Ziel-Pokémon ist zu stark, um gefangen zu werden! Du musst es zuerst schwächen!", - "noEscapeForce": "Eine unsichtbare Kraft verhindert die Flucht.", - "noEscapeTrainer": "Du kannst nicht aus einem Trainerkampf fliehen!", - "noEscapePokemon": "{{moveName}} von {{pokemonName}} verhindert {{escapeVerb}}!", - "runAwaySuccess": "Du bist entkommen!", - "runAwayCannotEscape": "Flucht gescheitert!", - "escapeVerbSwitch": "auswechseln", - "escapeVerbFlee": "flucht", - "skipItemQuestion": "Bist du sicher, dass du kein Item nehmen willst?", - "itemStackFull": "Du hast bereits zu viele von {{fullItemName}}. Du erhältst stattdessen {{itemName}}.", - "notDisabled": "{{moveName}} von {{pokemonName}} ist nicht mehr deaktiviert!", - "turnEndHpRestore": "Die KP von {{pokemonName}} wurden wiederhergestellt.", - "hpIsFull": "Die KP von {{pokemonName}} sind voll!", - "eggHatching": "Oh?", - "ivScannerUseQuestion": "IV-Scanner auf {{pokemonName}} benutzen?", - "wildPokemonWithAffix": "{{pokemonName}} (wild)", - "foePokemonWithAffix": "{{pokemonName}} (Gegner)", - "useMove": "{{pokemonNameWithAffix}} setzt {{moveName}} ein!", - "drainMessage": "{{pokemonName}} wurde Energie abgesaugt", - "regainHealth": "KP von {{pokemonName}} wurden wieder aufgefrischt!", - "stealEatBerry": "{{pokemonName}} hat {{targetName}} seine {{berryName}} weggefuttert!", - "ppHealBerry": "{{berryName}} von {{pokemonNameWithAffix}} füllt AP von {{moveName}} auf!", - "hpHealBerry": "{{berryName}} füllt KP von {{pokemonNameWithAffix}} auf!", - "fainted": "{{pokemonNameWithAffix}} wurde besiegt!", - "statsAnd": "und", - "stats": "Alle Werte", - "statRose_one": "{{stats}} von {{pokemonNameWithAffix}} steigt!", - "statRose_other": "{{stats}} von {{pokemonNameWithAffix}} steigen!", - "statSharplyRose_one": "{{stats}} von {{pokemonNameWithAffix}} steigt stark!", - "statSharplyRose_other": "{{stats}} von {{pokemonNameWithAffix}} steigen stark!", - "statRoseDrastically_one": "{{stats}} von {{pokemonNameWithAffix}} steigt drastisch!", - "statRoseDrastically_other": "{{stats}} von {{pokemonNameWithAffix}} steigen drastisch!", - "statWontGoAnyHigher_one": "{{stats}} von {{pokemonNameWithAffix}} kann nicht weiter erhöht werden!", - "statWontGoAnyHigher_other": "{{stats}} von {{pokemonNameWithAffix}} können nicht weiter erhöht werden!", - "statFell_one": "{{stats}} von {{pokemonNameWithAffix}} sinkt!", - "statFell_other": "{{stats}} von {{pokemonNameWithAffix}} sinken!", - "statHarshlyFell_one": "{{stats}} von {{pokemonNameWithAffix}} sinkt stark!", - "statHarshlyFell_other": "{{stats}} von {{pokemonNameWithAffix}} sinken stark!", - "statSeverelyFell_one": "{{stats}} von {{pokemonNameWithAffix}} sinkt drastisch!", - "statSeverelyFell_other": "{{stats}} von {{pokemonNameWithAffix}} sinken drastisch!", - "statWontGoAnyLower_one": "{{stats}} von {{pokemonNameWithAffix}} kann nicht weiter sinken!", - "statWontGoAnyLower_other": "{{stats}} von {{pokemonNameWithAffix}} können nicht weiter sinken!", - "transformedIntoType": "{{pokemonName}} transformed\ninto the {{type}} type!", - "ppReduced": "{{moveName}} von {{targetName}} wird um {{reduction}} AP reduziert!", - "retryBattle": "Möchtest du vom Beginn des Kampfes neustarten?", - "unlockedSomething": "{{unlockedThing}} wurde freigeschaltet.", - "congratulations": "Glückwunsch!", - "beatModeFirstTime": "{{speciesName}} hat den {{gameMode}} Modus zum ersten Mal beendet! Du erhältst {{newModifier}}!", - "eggSkipPrompt": "Zur Ei-Zusammenfassung springen?" -} diff --git a/src/locales/de/battler-tags.json b/src/locales/de/battler-tags.json deleted file mode 100644 index 2f8a8d0c438..00000000000 --- a/src/locales/de/battler-tags.json +++ /dev/null @@ -1,77 +0,0 @@ -{ - "trappedDesc": "Wechselsperre", - "flinchedDesc": "Zurückschrecken", - "confusedDesc": "Verwirrung", - "infatuatedDesc": "Verliebt", - "seedDesc": "Bepflanzt", - "nightmareDesc": "Nachtmahr", - "ingrainDesc": "Verwurzlung", - "drowsyDesc": "Schläfrigkeit", - "rechargingLapse": "{{pokemonNameWithAffix}} kann sich wegen des Rückstoßes durch den Angriff nicht bewegen!", - "trappedOnAdd": "{{pokemonNameWithAffix}} kann nicht mehr fliehen!", - "trappedOnRemove": "{{pokemonNameWithAffix}} wurde von {{moveName}} befreit.", - "flinchedLapse": "{{pokemonNameWithAffix}} ist zurückgeschreckt und kann nicht handeln!", - "confusedOnAdd": "{{pokemonNameWithAffix}} wurde verwirrt!", - "confusedOnRemove": "{{pokemonNameWithAffix}} ist nicht mehr verwirrt!", - "confusedOnOverlap": "{{pokemonNameWithAffix}} ist bereits verwirrt!", - "confusedLapse": "{{pokemonNameWithAffix}} ist verwirrt!", - "confusedLapseHurtItself": "Es hat sich vor Verwirrung selbst verletzt!", - "destinyBondLapseIsBoss": "{{pokemonNameWithAffix}} ist immun gegen den Effekt von Abgangsbund!", - "destinyBondLapse": "{{pokemonNameWithAffix}} nimmt {{pokemonNameWithAffix2}} mit sich!", - "infatuatedOnAdd": "{{pokemonNameWithAffix}} hat sich in {{sourcePokemonName}} verliebt!", - "infatuatedOnOverlap": "{{pokemonNameWithAffix}} ist bereits verliebt.", - "infatuatedLapse": "{{pokemonNameWithAffix}} ist in {{sourcePokemonName}} verliebt!", - "infatuatedLapseImmobilize": "{{pokemonNameWithAffix}} ist starr vor Liebe!", - "infatuatedOnRemove": "{{pokemonNameWithAffix}} ist nicht mehr verliebt!", - "seededOnAdd": "{{pokemonNameWithAffix}} wurde bepflanzt!", - "seededLapse": "{{pokemonNameWithAffix}} wurden durch Egelsamen KP geraubt!", - "seededLapseShed": "Egelsamen von {{pokemonNameWithAffix}} saugt Kloakensoße auf!", - "nightmareOnAdd": "Nachtmahr sucht {{pokemonNameWithAffix}} heim!", - "nightmareOnOverlap": "{{pokemonNameWithAffix}} wird bereits von Nachtmahr heimgesucht!", - "nightmareLapse": "Nachtmahr schadet {{pokemonNameWithAffix}}!", - "encoreOnAdd": "{{pokemonNameWithAffix}} gibt eine Zugabe", - "encoreOnRemove": "Die Zugabe von {{pokemonNameWithAffix}} ist beendet!", - "helpingHandOnAdd": "{{pokemonNameWithAffix}} will {{pokemonName}} helfen!", - "ingrainLapse": "{{pokemonNameWithAffix}} nimmt über seine Wurzeln Nährstoffe auf!", - "ingrainOnTrap": "{{pokemonNameWithAffix}} pflanzt seine Wurzeln!", - "aquaRingOnAdd": "{{pokemonNameWithAffix}} umgibt sich mit einem Wasserring!", - "aquaRingLapse": "{{moveName}} füllt KP von {{pokemonName}} wieder auf!", - "drowsyOnAdd": "{{pokemonNameWithAffix}} wurde schläfrig gemacht!", - "damagingTrapLapse": "{{pokemonNameWithAffix}} wurde durch {{moveName}} verletzt!", - "bindOnTrap": "{{pokemonNameWithAffix}} wurde durch {{moveName}} von {{sourcePokemonName}} gequetscht!", - "wrapOnTrap": "{{pokemonNameWithAffix}} wurde von {{sourcePokemonName}} umwickelt!", - "vortexOnTrap": "{{pokemonNameWithAffix}} wird in dem Strudel gefangen!", - "clampOnTrap": "{{sourcePokemonNameWithAffix}} wurde von {{pokemonName}} geschnappt!", - "sandTombOnTrap": "{{pokemonNameWithAffix}} wurde von {{moveName}} gefangen!", - "magmaStormOnTrap": "{{pokemonNameWithAffix}} wurde in wirbelndem Magma eingeschlossen!", - "snapTrapOnTrap": "{{pokemonNameWithAffix}} wurde durch Sandgrab gefangen!", - "thunderCageOnTrap": "{{sourcePokemonNameWithAffix}} hat {{pokemonNameWithAffix}} gefangen!", - "infestationOnTrap": "{{sourcePokemonNameWithAffix}} plagt {{pokemonNameWithAffix}}!", - "protectedOnAdd": "{{pokemonNameWithAffix}} schützt sich selbst!", - "protectedLapse": "{{pokemonNameWithAffix}} schützt sich selbst!", - "enduringOnAdd": "{{pokemonNameWithAffix}} sammelt sich, um die nächste Attacke zu überstehen!", - "enduringLapse": "{{pokemonNameWithAffix}} übersteht die Attacke!", - "sturdyLapse": "{{pokemonNameWithAffix}} übersteht die Attacke!", - "perishSongLapse": "Abgesang von {{pokemonNameWithAffix}} steht bei {{turnCount}}.", - "centerOfAttentionOnAdd": "{{pokemonNameWithAffix}} zieht alle Aufmerksamkeit auf sich!", - "truantLapse": "{{pokemonNameWithAffix}} faulenzt!", - "slowStartOnAdd": "{{pokemonNameWithAffix}} kommt nicht in Fahrt!", - "slowStartOnRemove": "{{pokemonNameWithAffix}} kriegt schließlich doch noch die Kurve!", - "highestStatBoostOnAdd": "{{statName}} von {{pokemonNameWithAffix}} wird verstärkt!", - "highestStatBoostOnRemove": "Der Effekt von {{abilityName}} von {{pokemonNameWithAffix}} lässt nach!", - "magnetRisenOnAdd": "{{pokemonNameWithAffix}} schwebt aufgrund von Elektromagnetismus!", - "magnetRisenOnRemove": "Der Elektromagnetismus von {{pokemonNameWithAffix}} hört auf zu wirken!", - "critBoostOnAdd": "{{pokemonNameWithAffix}} läuft zu Hochtouren auf!", - "critBoostOnRemove": "{{pokemonNameWithAffix}} entspannt.", - "saltCuredOnAdd": "{{pokemonNameWithAffix}} wurde eingepökelt!", - "saltCuredLapse": "{{pokemonNameWithAffix}} wurde durch {{moveName}} verletzt!", - "cursedOnAdd": "{{pokemonNameWithAffix}} nimmt einen Teil seiner KP und legt einen Fluch auf {{pokemonName}}!", - "cursedLapse": "{{pokemonNameWithAffix}} wurde durch den Fluch verletzt!", - "stockpilingOnAdd": "{{pokemonNameWithAffix}} hortet {{stockpiledCount}}!", - "disabledOnAdd": " {{moveName}} von {{pokemonNameWithAffix}} wurde blockiert!", - "disabledLapse": "{{moveName}} von {{pokemonNameWithAffix}} ist nicht länger blockiert!", - "tarShotOnAdd": "{{pokemonNameWithAffix}} ist nun schwach gegenüber Feuer-Attacken!", - "substituteOnAdd": "Ein Delegator von {{pokemonNameWithAffix}} ist erschienen!", - "substituteOnHit": "Der Delegator steckt den Schlag für {{pokemonNameWithAffix}} ein!", - "substituteOnRemove": "Der Delegator von {{pokemonNameWithAffix}} hört auf zu wirken!" -} diff --git a/src/locales/de/berry.json b/src/locales/de/berry.json deleted file mode 100644 index 61f3c623e32..00000000000 --- a/src/locales/de/berry.json +++ /dev/null @@ -1,46 +0,0 @@ -{ - "SITRUS": { - "name": "Tsitrubeere", - "effect": "Stellt 25% der KP wieder her, wenn die KP unter 50% sind." - }, - "LUM": { - "name": "Prunusbeere", - "effect": "Heilt jede nichtflüchtige Statusveränderung und Verwirrung." - }, - "ENIGMA": { - "name": "Enigmabeere", - "effect": "Stellt 25% der KP wieder her, wenn der Träger von einer sehr effektiven Attacke getroffen wird." - }, - "LIECHI": { - "name": "Lydzibeere", - "effect": "Steigert den Angriff, wenn die KP unter 25% sind." - }, - "GANLON": { - "name": "Linganbeere", - "effect": "Steigert die Verteidigung, wenn die KP unter 25% sind." - }, - "PETAYA": { - "name": "Tahaybeere", - "effect": "Steigert den Spezial-Angriff, wenn die KP unter 25% sind." - }, - "APICOT": { - "name": "Apikobeere", - "effect": "Steigert die Spezial-Verteidigung, wenn die KP unter 25% sind." - }, - "SALAC": { - "name": "Salkabeere", - "effect": "Steigert die Initiative, wenn die KP unter 25% sind." - }, - "LANSAT": { - "name": "Lansatbeere", - "effect": "Erhöht die Volltrefferchance, wenn die KP unter 25% sind." - }, - "STARF": { - "name": "Krambobeere", - "effect": "Erhöht einen zufälligen Statuswert stark, wenn die KP unter 25% sind." - }, - "LEPPA": { - "name": "Jonagobeere", - "effect": "Stellt 10 AP für eine Attacke wieder her, wenn deren AP auf 0 fallen." - } -} \ No newline at end of file diff --git a/src/locales/de/bgm-name.json b/src/locales/de/bgm-name.json deleted file mode 100644 index 1eab276a70a..00000000000 --- a/src/locales/de/bgm-name.json +++ /dev/null @@ -1,150 +0,0 @@ -{ - "music": "Musik: ", - "missing_entries": "{{name}}", - "battle_kanto_champion": "S2W2 Vs. Kanto Champion", - "battle_johto_champion": "S2W2 Vs. Johto Champion", - "battle_hoenn_champion_g5": "S2W2 Vs. Hoenn Champion", - "battle_hoenn_champion_g6": "ORAS Vs. Hoenn Champion", - "battle_sinnoh_champion": "S2W2 Vs. Champion Cynthia", - "battle_champion_alder": "SW Vs. Champion Lauro", - "battle_champion_iris": "S2W2 Vs. Champion Lilia", - "battle_kalos_champion": "XY Vs. Champion Diantha", - "battle_alola_champion": "USUM Vs. Alola Champion", - "battle_galar_champion": "SWSH Vs. Champion Delion", - "battle_champion_geeta": "KAPU Vs. Champion Sagaria", - "battle_champion_nemona": "KAPU Vs. Champion Nemila", - "battle_champion_kieran": "KAPU Vs. Jo", - "battle_hoenn_elite": "ORAS Vs. Hoenn Top Vier", - "battle_unova_elite": "SW Vs. Einall Top Vier", - "battle_kalos_elite": "XY Vs. Kalos Top Vier", - "battle_alola_elite": "SM Vs. Alola Top Vier", - "battle_galar_elite": "SWSH Galar Champ-Cup", - "battle_paldea_elite": "KAPU Vs. Paldea Top Vier", - "battle_bb_elite": "KAPU Vs. Blaubeer-Top-Vier", - "battle_final_encounter": "PMDDX Rayquazas Domäne", - "battle_final": "SW Vs. G-Cis", - "battle_kanto_gym": "S2W2 Vs. Kanto Arenaleiter", - "battle_johto_gym": "S2W2 Vs. Johto Arenaleiter", - "battle_hoenn_gym": "S2W2 Vs. Hoenn Arenaleiter", - "battle_sinnoh_gym": "S2W2 Vs. Sinnoh Arenaleiter", - "battle_unova_gym": "SW Vs. Einall Arenaleiter", - "battle_kalos_gym": "XY Vs. Kalos Arenaleiter", - "battle_galar_gym": "SWSH Vs. Galar Arenaleiter", - "battle_paldea_gym": "KAPU Vs. Paldea Arenaleiter", - "battle_legendary_kanto": "XY Vs. Legendäres Kanto Pokémon", - "battle_legendary_raikou": "HGSS Vs. Raikou", - "battle_legendary_entei": "HGSS Vs. Entei", - "battle_legendary_suicune": "HGSS Vs. Suicune", - "battle_legendary_lugia": "HGSS Vs. Lugia", - "battle_legendary_ho_oh": "HGSS Vs. Ho-oh", - "battle_legendary_regis_g5": "S2W2 Vs. Legendäre Giganten", - "battle_legendary_regis_g6": "ORAS Vs. Legendäre Giganten", - "battle_legendary_gro_kyo": "ORAS Vs. Groudon & Kyogre", - "battle_legendary_rayquaza": "ORAS Vs. Rayquaza", - "battle_legendary_deoxys": "ORAS Vs. Deoxys", - "battle_legendary_lake_trio": "ORAS Vs. Seen-Trio", - "battle_legendary_sinnoh": "ORAS Vs. Legendäres Sinnoh Pokémon", - "battle_legendary_dia_pal": "ORAS Vs. Dialga & Palkia", - "battle_legendary_origin_forme": "PLA Vs. Urform Dialga & Palkia", - "battle_legendary_giratina": "ORAS Vs. Giratina", - "battle_legendary_arceus": "HGSS Vs. Arceus", - "battle_legendary_unova": "SW Vs. Legendäres Einall Pokémon", - "battle_legendary_kyurem": "SW Vs. Kyurem", - "battle_legendary_res_zek": "SW Vs. Reshiram & Zekrom", - "battle_legendary_xern_yvel": "XY Vs. Xerneas & Yveltal", - "battle_legendary_tapu": "SM Vs. Kapu", - "battle_legendary_sol_lun": "SM Vs. Solgaleo & Lunala", - "battle_legendary_ub": "SM Vs. Ultrabestie", - "battle_legendary_dusk_dawn": "USUM Vs. Abendmähne- & Morgenschwingen-Necrozma", - "battle_legendary_ultra_nec": "USUM Vs. Ultra-Necrozma", - "battle_legendary_zac_zam": "SWSH Vs. Zacian & Zamazenta", - "battle_legendary_glas_spec": "SWSH Vs. Polaross & Phantoross", - "battle_legendary_calyrex": "SWSH Vs. Coronospa", - "battle_legendary_riders": "SWSH Vs. Schimmelreiter & Rappenreiter Coronospa", - "battle_legendary_birds_galar": "SWSH Vs. Legendäre Galar-Vögel", - "battle_legendary_ruinous": "KAPU Vs. Schätze des Unheils", - "battle_legendary_kor_mir": "KAPU Die Tiefen von Zone Null", - "battle_legendary_loyal_three": "KAPU Drei Gefährten", - "battle_legendary_ogerpon": "KAPU Vs. Ogerpon", - "battle_legendary_terapagos": "KAPU Vs. Terapagos", - "battle_legendary_pecharunt": "KAPU Vs. Infamomo", - "battle_rival": "SW Vs. Rivale", - "battle_rival_2": "SW Vs. N", - "battle_rival_3": "SW Vs. N (Finale)", - "battle_trainer": "SW Vs. Trainer", - "battle_wild": "SW Vs. Wilde Pokémon", - "battle_wild_strong": "SW Vs. Starke Wilde Pokémon", - "end_summit": "PMDDX Gipfel des Himmelturms", - "battle_rocket_grunt": "HGSS Vs. Team Rocket Rüpel", - "battle_aqua_magma_grunt": "ORAS Vs. Team Aqua & Magma", - "battle_galactic_grunt": "BDSP Vs. Team Galaktik Rüpel", - "battle_plasma_grunt": "SW Vs. Team Plasma Rüpel", - "battle_flare_grunt": "XY Vs. Team Flare Rüpel", - "battle_aether_grunt": "SM Vs. Æther Foundation", - "battle_skull_grunt": "SM Vs. Team Skull Rüpel", - "battle_macro_grunt": "SWSH Vs. Trainer", - "battle_galactic_admin": "BDSP Vs. Team Galactic Commander", - "battle_skull_admin": "SM Vs. Team Skull Vorstand", - "battle_oleana": "SWSH Vs. Oleana", - "battle_rocket_boss": "USUM Vs. Giovanni", - "battle_aqua_magma_boss": "ORAS Vs. Team Aqua & Magma Boss", - "battle_galactic_boss": "BDSP Vs. Zyrus", - "battle_plasma_boss": "S2W2 Vs. G-Cis", - "battle_flare_boss": "XY Vs. Flordelis", - "battle_aether_boss": "SM Vs. Samantha", - "battle_skull_boss": "SM Vs. Bromley", - "battle_macro_boss": "SWSH Vs. Rose", - - "abyss": "PMD Erkundungsteam Himmel Dunkelkrater", - "badlands": "PMD Erkundungsteam Himmel Kargtal", - "beach": "PMD Erkundungsteam Himmel Feuchtklippe", - "cave": "PMD Erkundungsteam Himmel Himmelsgipfel-Höhle", - "construction_site": "PMD Erkundungsteam Himmel Geröllbruch", - "desert": "PMD Erkundungsteam Himmel Nordwüste", - "dojo": "PMD Erkundungsteam Himmel Knogga-Dojo", - "end": "PMD Retterteam DX Himmelsturm", - "factory": "PMD Erkundungsteam Himmel Verborgene Ruinen", - "fairy_cave": "PMD Erkundungsteam Himmel Sternenhöhle", - "forest": "PMD Erkundungsteam Himmel Düsterwald", - "grass": "PMD Erkundungsteam Himmel Apfelwald", - "graveyard": "PMD Erkundungsteam Himmel Verwirrwald", - "ice_cave": "PMD Erkundungsteam Himmel Rieseneisberg", - "island": "PMD Erkundungsteam Himmel Schroffküste", - "jungle": "Lmz - Jungle", - "laboratory": "Firel - Laboratory", - "lake": "PMD Erkundungsteam Himmel Kristallhöhle", - "meadow": "PMD Erkundungsteam Himmel Himmelsgipfel-Wald", - "metropolis": "Firel - Metropolis", - "mountain": "PMD Erkundungsteam Himmel Hornberg", - "plains": "PMD Erkundungsteam Himmel Himmelsgipfel-Prärie", - "power_plant": "PMD Erkundungsteam Himmel Weite Ampere-Ebene", - "ruins": "PMD Erkundungsteam Himmel Tiefes Ruinenverlies", - "sea": "Andr06 - Marine Mystique", - "seabed": "Firel - Seabed", - "slum": "Andr06 - Sneaky Snom", - "snowy_forest": "PMD Erkundungsteam Himmel Himmelsgipfel-Schneefeld", - "space": "Firel - Aether", - "swamp": "PMD Erkundungsteam Himmel Ringmeer", - "tall_grass": "PMD Erkundungsteam Himmel Nebelwald", - "temple": "PMD Erkundungsteam Himmel Ägishöhle", - "town": "PMD Erkundungsteam Himmel Zufälliges Dungeon-Theme 3", - "volcano": "PMD Erkundungsteam Himmel Dunsthöhle", - "wasteland": "PMD Erkundungsteam Himmel Verborgenes Hochland", - "encounter_ace_trainer": "SW Trainerblicke treffen sich (Ass-Trainer)", - "encounter_backpacker": "SW Trainerblicke treffen sich (Backpacker)", - "encounter_clerk": "SW Trainerblicke treffen sich (Angestellter)", - "encounter_cyclist": "SW Trainerblicke treffen sich (Biker)", - "encounter_lass": "SW Trainerblicke treffen sich (Göre)", - "encounter_parasol_lady": "SW Trainerblicke treffen sich (Schirmdame)", - "encounter_pokefan": "SW Trainerblicke treffen sich (Pokéfan)", - "encounter_psychic": "SW Trainerblicke treffen sich (Seher)", - "encounter_rich": "SW Trainerblicke treffen sich (Gentleman)", - "encounter_rival": "SW Vs. Cheren", - "encounter_roughneck": "SW Trainerblicke treffen sich (Raufbold)", - "encounter_scientist": "SW Trainerblicke treffen sich (Forscher)", - "encounter_twins": "SW Trainerblicke treffen sich (Zwillinge)", - "encounter_youngster": "SW Trainerblicke treffen sich (Knirps)", - "heal": "SW Pokémon-Heilung", - "menu": "PMD Erkundungsteam Himmel Willkommen in der Welt der Pokémon!", - "title": "PMD Erkundungsteam Himmel Top-Menü-Thema" -} diff --git a/src/locales/de/biome.json b/src/locales/de/biome.json deleted file mode 100644 index a4add24ad3b..00000000000 --- a/src/locales/de/biome.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "unknownLocation": "An einem unbekannten Ort", - "TOWN": "Stadt", - "PLAINS": "Ebene", - "GRASS": "Grasfeld", - "TALL_GRASS": "Hohes Gras", - "METROPOLIS": "Metropole", - "FOREST": "Wald", - "SEA": "Meer", - "SWAMP": "Sumpf", - "BEACH": "Strand", - "LAKE": "See", - "SEABED": "Meeresboden", - "MOUNTAIN": "Berg", - "BADLANDS": "Kargland", - "CAVE": "Höhle", - "DESERT": "Wüste", - "ICE_CAVE": "Eishöhle", - "MEADOW": "Weide", - "POWER_PLANT": "Kraftwerk", - "VOLCANO": "Vulkan", - "GRAVEYARD": "Friedhof", - "DOJO": "Dojo", - "FACTORY": "Fabrik", - "RUINS": "Alte Ruinen", - "WASTELAND": "Ödland", - "ABYSS": "Der Abgrund", - "SPACE": "Stratosphäre", - "CONSTRUCTION_SITE": "Baustelle", - "JUNGLE": "Dschungel", - "FAIRY_CAVE": "Feenhöhle", - "TEMPLE": "Tempel", - "SLUM": "Elendsviertel", - "SNOWY_FOREST": "Verschneiter Wald", - "ISLAND": "Insel", - "LABORATORY": "Labor", - "END": "???" -} \ No newline at end of file diff --git a/src/locales/de/challenges.json b/src/locales/de/challenges.json deleted file mode 100644 index c8836c50549..00000000000 --- a/src/locales/de/challenges.json +++ /dev/null @@ -1,37 +0,0 @@ -{ - "noneSelected": "Keine ausgewählt", - "title": "Herausforderungsmodifikatoren", - "illegalEvolution": "{{pokemon}} hat sich in ein Pokémon verwandelt, dass für diese Herausforderung nicht zulässig ist!", - "singleGeneration": { - "name": "Mono-Generation", - "desc": "Du kannst nur Pokémon aus der {{gen}} Generation verwenden.", - "desc_default": "Du kannst nur Pokémon aus der gewählten Generation verwenden.", - "gen_1": "ersten", - "gen_2": "zweiten", - "gen_3": "dritten", - "gen_4": "vierten", - "gen_5": "fünften", - "gen_6": "sechsten", - "gen_7": "siebten", - "gen_8": "achten", - "gen_9": "neunten" - }, - "singleType": { - "name": "Mono-Typ", - "desc": "Du kannst nur Pokémon des Typs {{type}} verwenden.", - "desc_default": "Du kannst nur Pokémon des gewählten Typs verwenden." - }, - "freshStart": { - "name": "Neuanfang", - "desc": "Du kannst nur die ursprünglichen Starter verwenden, genau so, als hättest du gerade erst mit Pokérogue begonnen.", - "value.0": "Aus", - "value.1": "An" - }, - "inverseBattle": { - "name": "Umkehrkampf", - "shortName": "Umkehrkampf", - "desc": "Die Typen-Effektivität wird umgekehrt, und kein Typ ist gegen einen anderen Typ immun.\nDeaktiviert die Erfolge anderer Herausforderungen.", - "value.0": "Aus", - "value.1": "An" - } -} \ No newline at end of file diff --git a/src/locales/de/command-ui-handler.json b/src/locales/de/command-ui-handler.json deleted file mode 100644 index 4949929770b..00000000000 --- a/src/locales/de/command-ui-handler.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "fight": "Kampf", - "ball": "Ball", - "pokemon": "Pokémon", - "run": "Fliehen", - "actionMessage": "Was soll\n{{pokemonName}} tun?" -} \ No newline at end of file diff --git a/src/locales/de/common.json b/src/locales/de/common.json deleted file mode 100644 index b0ca16e04f4..00000000000 --- a/src/locales/de/common.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "start": "Start", - "luckIndicator": "Glück:", - "shinyOnHover": "Schillernd", - "commonShiny": "Gewöhnlich", - "rareShiny": "Selten", - "epicShiny": "Episch" -} \ No newline at end of file diff --git a/src/locales/de/config.ts b/src/locales/de/config.ts deleted file mode 100644 index 772bfb6d1d5..00000000000 --- a/src/locales/de/config.ts +++ /dev/null @@ -1,113 +0,0 @@ -import common from "./common.json"; -import settings from "./settings.json"; -import ability from "./ability.json"; -import abilityTriggers from "./ability-trigger.json"; -import arenaFlyout from "./arena-flyout.json"; -import arenaTag from "./arena-tag.json"; -import achv from "./achv.json"; -import battle from "./battle.json"; -import battleScene from "./battle-scene.json"; -import battleInfo from "./battle-info.json"; -import battleMessageUiHandler from "./battle-message-ui-handler.json"; -import battlerTags from "./battler-tags.json"; -import berry from "./berry.json"; -import bgmName from "./bgm-name.json"; -import biome from "./biome.json"; -import challenges from "./challenges.json"; -import commandUiHandler from "./command-ui-handler.json"; -import dialogue from "./dialogue.json"; -import battleSpecDialogue from "./dialogue-final-boss.json"; -import miscDialogue from "./dialogue-misc.json"; -import doubleBattleDialogue from "./dialogue-double-battle.json"; -import egg from "./egg.json"; -import fightUiHandler from "./fight-ui-handler.json"; -import filterBar from "./filter-bar.json"; -import gameMode from "./game-mode.json"; -import gameStatsUiHandler from "./game-stats-ui-handler.json"; -import growth from "./growth.json"; -import menu from "./menu.json"; -import menuUiHandler from "./menu-ui-handler.json"; -import modifier from "./modifier.json"; -import modifierType from "./modifier-type.json"; -import move from "./move.json"; -import nature from "./nature.json"; -import partyUiHandler from "./party-ui-handler.json"; -import pokeball from "./pokeball.json"; -import pokemon from "./pokemon.json"; -import pokemonForm from "./pokemon-form.json"; -import battlePokemonForm from "./pokemon-form-battle.json"; -import pokemonInfo from "./pokemon-info.json"; -import pokemonInfoContainer from "./pokemon-info-container.json"; -import pokemonSummary from "./pokemon-summary.json"; -import saveSlotSelectUiHandler from "./save-slot-select-ui-handler.json"; -import splashMessages from "./splash-messages.json"; -import starterSelectUiHandler from "./starter-select-ui-handler.json"; -import statusEffect from "./status-effect.json"; -import trainerTitles from "./trainer-titles.json"; -import trainerClasses from "./trainer-classes.json"; -import trainerNames from "./trainer-names.json"; -import tutorial from "./tutorial.json"; -import voucher from "./voucher.json"; -import weather from "./weather.json"; -import terrain from "./terrain.json"; -import modifierSelectUiHandler from "./modifier-select-ui-handler.json"; -import moveTriggers from "./move-trigger.json"; -import runHistory from "./run-history.json"; - -export const deConfig = { - ability, - abilityTriggers, - arenaFlyout, - arenaTag, - battle, - battleScene, - battleInfo, - battleMessageUiHandler, - battlePokemonForm, - battlerTags, - berry, - bgmName, - biome, - challenges, - commandUiHandler, - common, - achv, - dialogue, - battleSpecDialogue, - miscDialogue, - doubleBattleDialogue, - egg, - fightUiHandler, - filterBar, - gameMode, - gameStatsUiHandler, - growth, - menu, - menuUiHandler, - modifier, - modifierType, - move, - nature, - pokeball, - pokemon, - pokemonForm, - pokemonInfo, - pokemonInfoContainer, - pokemonSummary, - saveSlotSelectUiHandler, - settings, - splashMessages, - starterSelectUiHandler, - statusEffect, - terrain, - titles: trainerTitles, - trainerClasses, - trainerNames, - tutorial, - voucher, - weather, - partyUiHandler, - modifierSelectUiHandler, - moveTriggers, - runHistory, -}; diff --git a/src/locales/de/dialogue-double-battle.json b/src/locales/de/dialogue-double-battle.json deleted file mode 100644 index ec7cf375c0c..00000000000 --- a/src/locales/de/dialogue-double-battle.json +++ /dev/null @@ -1,82 +0,0 @@ -{ - "blue_red_double": { - "encounter": { - "1": "Blau: Hey Rot, lass uns ihnen zeigen, was wir drauf haben!\n$Rot: ...\n$Blau: Das ist die Macht von Alabastia!" - }, - "victory": { - "1": "Blau: Das war ein großartiger Kampf!\n$Rot: ..." - } - }, - "red_blue_double": { - "encounter": { - "1": "Rot: ...!\n$Blau: Er redet nicht viel...\n$Blau: Aber lass dich davon nicht täuschen! Er ist schließlich ein Champ!" - }, - "victory": { - "1": "Rot: ...!\n$Blau: Das nächste Mal gewinnen wir!" - } - }, - "tate_liza_double": { - "encounter": { - "1": "Ben: Hehehe...Bist du überrascht?\n$Svenja: Wir sind zwei Arenaleiter auf einmal!\n$Ben: Wir sind Zwillinge!\n$Svenja: Wir müssen nicht reden um uns gegenseitig zu verstehen!\n$Ben: Die doppelte Kraft...\n$Svenja: Kannst du ihr standhalten?" - }, - "victory": { - "1": "Ben: Was? Unsere Kombination war perfekt!\n$Svenja: Sieht so aus als müssten wir wohl mehr tranieren..." - } - }, - "liza_tate_double": { - "encounter": { - "1": "Svenja: Hihihi... Bist du überrascht?\n$Ben: Ja, wir sind wirklich zwei Arenaleiter auf einmal!\n$Svenja: Das ist mein Zwillingsbruder Ben!\n$Ben: Und das meine Zwillingsschwester Svenja!\n$Svenja: Wir sind die perfekte Kombo!" - }, - "victory": { - "1": "Svenja: Sind wir...\n$Ben: ...nicht so stark wie wir dachten?" - } - }, - "wallace_steven_double": { - "encounter": { - "1": "Troy: Wassili, lass uns ihnen die Kraft von Champions zeigen!\n$Wassili: Wir zeigen dir die Kraft von Hoenn!\n$Troy: Los gehts!" - }, - "victory": { - "1": "Troy: Das war ein großartiger Kampf!\n$Wassili: Das nächste Mal gewinnen wir!" - } - }, - "steven_wallace_double": { - "encounter": { - "1": "Troy: Hast du irgendwelche seltenen Pokémon?\n$Wassili: Troy... Wir sind hier um zu kämpfen und nicht um mit unseren Pokémon zu prahlen...\n$Troy: Oh... Wenn das so ist... Lass uns anfangen!" - }, - "victory": { - "1": "Troy: Jetzt da wir mit Kämpfen fertig sind... Lass uns mit unsereren Pokémon prahlen!\n$Wassili: Troy..." - } - }, - "alder_iris_double": { - "encounter": { - "1": "Lauro: Wir sind die stärksten Trainer aus Einall!\n$Lilia: Kämpfe gegen starke Trainer machen am meisten Spaß!" - }, - "victory": { - "1": "Lauro: Wow! Du bist super stark!\n$Lilia: Beim nächsten Mal schlagen wir dich!" - } - }, - "iris_alder_double": { - "encounter": { - "1": "Lilia: Willkommen Herausforderer! Ich bin DER Champion von Einall!\n$Lauro: Lilia, bist du nicht etwas zu aufgeregt?" - }, - "victory": { - "1": "Lilia: Eine solche Niederlage ist nicht einfach zu verkraften...\n$Lauro: Aber wir wachsen an unseren Niederlagen und werden immer besser!" - } - }, - "marnie_piers_double": { - "encounter": { - "1": "Mary: Bruder, lass uns ihnen die Kraft von Spikeford zeigen!\n$Nezz: Wir bringen die Dunkelheit!" - }, - "victory": { - "1": "Mary: Du hast Licht in unsere Dunkelheit gebracht!\n$Piers: Es ist viel zu hell..." - } - }, - "piers_marnie_double": { - "encounter": { - "1": "Nezz: Bereit für ein Konzert?\n$Mary: Bruder...Sie sind hier um zu kämpfen, nicht um zu singen..." - }, - "victory": { - "1": "Nezz: Das war mal ein großartiges Konzert!\n$Marnie: Bruder..." - } - } -} \ No newline at end of file diff --git a/src/locales/de/dialogue-final-boss.json b/src/locales/de/dialogue-final-boss.json deleted file mode 100644 index bffbd779be0..00000000000 --- a/src/locales/de/dialogue-final-boss.json +++ /dev/null @@ -1,4 +0,0 @@ -{ - "encounter": "Es scheint, als wäre es wieder mal an der Zeit.\nDu weißt, warum du hierher kommen musst, oder?\n$Dich hat es hierher gezogen, du warst bereits hier.\nUnzählige Male.\n$Obwohl, vielleicht doch nicht unzählig.\nUm genau zu sein, dies ist der {{cycleCount}}te Zyklus.\n$Du verlierst jeden Zyklus dein Gedächtnis. Trotzdem \nbleibt etwas, ein Teil deines ehemaligen Ichs, erhalten.\n$Bis jetzt hast du es noch nicht vollbracht zu siegen, aber dieses Mal spüre ich eine andere Präsenz in dir.\n\n$Du bist der Einzige hier, aber es kommt mir so vor als wäre da...jemand anderes.\n$Wirst du endlich beweisen, dass du ein würdiger Herausforder bist?\nDie Herausforderung auf die ich seit Jahrtausenden warte?\n$Lass uns beginnen.","firstStageWin": "Ahh verstehe. Diese Präsenz, die ich gespürt habe, ist wirklich real.\nEs scheint als müsste ich micht nicht länger zurück halten.\n$Enttäusche mich nicht.", - "secondStageWin": "…Herrlich." -} \ No newline at end of file diff --git a/src/locales/de/dialogue-misc.json b/src/locales/de/dialogue-misc.json deleted file mode 100644 index 69c704c66c6..00000000000 --- a/src/locales/de/dialogue-misc.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "ending": "@c{shock}Du bist zurück?@d{32} Bedeutet das…@d{96} du hast gewonnen?!\n$@c{smile_ehalf}Ich hätte wissen sollen, dass du es in dir hast.\n$@c{smile_eclosed}Natürlich… ich hatte immer dieses Gefühl.\n$@c{smile}Es ist jetzt vorbei, richtig? Du hast die Schleife beendet.\n$@c{smile_ehalf}Du hast auch deinen Traum erfüllt, nicht wahr?\n$Du hast nicht einmal verloren.\n$Ich werde die Einzige sein, die sich daran erinnert, was du getan hast.\n$@c{angry_mopen}Ich werde versuchen, es nicht zu vergessen!\n$@c{smile_wave_wink}Nur ein Scherz!@d{64} @c{smile}Ich würde es nie vergessen.@d{32}\n$Deine Legende wird in unseren Herzen weiterleben.\n$@c{smile_wave}Wie auch immer,@d{64} es wird spät…@d{96} denke ich?\nEs ist schwer zu sagen an diesem Ort.\n$Lass uns nach Hause gehen. \n$@c{smile_wave_wink}Vielleicht können wir morgen noch einen Kampf haben, der alten Zeiten willen?", - "ending_female": "@c{smile}Oh? Du hast gewonnen?@d{96} @c{smile_eclosed}Ich schätze, das hätte ich wissen sollen.\n$Aber, du bist jetzt zurück.\n$@c{smile}Es ist vorbei.@d{64} Du hast die Schleife beendet.\n$@c{serious_smile_fists}Du hast auch deinen Traum erfüllt, nicht wahr?\nDu hast nicht einmal verloren.\n$@c{neutral}Ich bin der Einzige, der sich daran erinnern wird, was du getan hast.@d{96}\n$Ich schätze, das ist in Ordnung, oder?\n$@c{serious_smile_fists}Deine Legende wird immer in unseren Herzen weiterleben.\n$@c{smile_eclosed}Wie auch immer, ich habe genug von diesem Ort, oder nicht? Lass uns nach Hause gehen.\n$@c{serious_smile_fists}Vielleicht können wir, wenn wir zurück sind, noch einen Kampf haben?\n$Wenn du dazu bereit bist.", - "ending_endless": "Glückwunsch! Du hast das aktuelle Ende erreicht!\nWir arbeiten an mehr Spielinhalten.", - "ending_name": "Entwickler" -} diff --git a/src/locales/de/dialogue.json b/src/locales/de/dialogue.json deleted file mode 100644 index 8a3dbb8880e..00000000000 --- a/src/locales/de/dialogue.json +++ /dev/null @@ -1,2691 +0,0 @@ -{ - "youngster": { - "encounter": { - "1": "Hey, willst du kämpfen?", - "2": "Bist du auch ein neuer Trainer?", - "3": "Hey, ich habe dich noch nie gesehen. Lass uns kämpfen!", - "4": "Ich habe gerade verloren und suche nach neuen Pokémon.\nWarte! Du siehst schwach aus! Lass uns kämpfen!", - "5": "Haben wir uns schon mal getroffen oder nicht? Ich erinnere mich nicht wirklich\n$Nun, ich denke, es ist trotzdem schön, dich zu treffen!", - "6": "Okay, lass uns kämpfen!", - "7": "Okay, hier komme ich! Ich zeige dir meine Kraft!", - "8": "Fan fan fan... Ich zeige dir wie fantastisch meine Pokémon sind!", - "9": "Es ist nicht nötig, Zeit mit Begrüßungen zu verschwenden.\nSobald du bereit bist geht es los!", - "10": "Lass deine Deckung nicht fallen, sonst weinst du, wenn dich ein Kind besiegt.", - "11": "Ich habe meine Pokémon mit großer Sorgfalt aufgezogen. Du darfst ihnen nicht wehtun!", - "12": "Schön, dass du es geschafft hast! Von hier an wird es nicht einfacher.", - "13": "Die Kämpfe gehen immer weiter! Willkommen in der Welt ohne Ende!" - }, - "victory": { - "1": "Wow! Du bist stark!", - "2": "Ich hatte keine Chance, oder?", - "3": "Wenn ich älter bin, werde ich dich besiegen!", - "4": "Ugh. Ich habe keine Pokémon mehr.", - "5": "Das kann nicht sein… DAS KANN NICHT SEIN! Wie konnte ich schon wieder verlieren…", - "6": "Nein! Ich habe verloren!", - "7": "Wow! Du bist unglaublich! Ich bin erstaunt und überrascht!", - "8": "Kann es sein… Wie… Meine Pokémon und ich sind die stärksten, aber…", - "9": "Das nächste Mal werde ich dich besiegen! Lass uns wieder kämpfen!", - "10": "Man! Kannst du nicht sehen, dass ich nur ein Kind bin? Es war nicht fair von dir, so hart zu kämpfen!", - "11": "Deine Pokémon sind unglaublich! Tauschst du mit mir?", - "12": "Ich habe mich ein bisschen mitreißen lassen, worüber habe ich vorhin gesprochen?", - "13": "Ahaha! Da ist es! Genau! Du bist schon jetzt in dieser Welt zu Hause!" - } - }, - "lass": { - "encounter": { - "1": "Lass uns kämpfen, wollen wir?", - "2": "Du siehst wie ein neuer Trainer aus. Lass uns kämpfen!", - "3": "Ich erkenne dich nicht. Wie wäre es mit einem Kampf?", - "4": "Lass uns einen lustigen Pokémon-Kampf haben!", - "5": "Ich zeige dir, wie man Pokémon wirklich einsetzt!", - "6": "Ein ernsthafter Kampf beginnt mit einem ernsten Anfang! Bist du sicher, dass du bereit bist?", - "7": "Du bist nur einmal jung. Und du hast nur eine Chance bei einem bestimmten Kampf.\n$Bald wirst du nur noch eine Erinnerung sein.", - "8": "Du solltest es leicht mit mir angehen, OK? Aber ich kämpfe ernsthaft!", - "9": "Die Schule ist langweilig. Ich habe nichts zu tun. Gähn. Ich kämpfe nur, um die Zeit totzuschlagen." - }, - "victory": { - "1": "Das war beeindruckend! Ich habe noch viel zu lernen.", - "2": "Ich dachte nicht, dass du mich so schlagen würdest…", - "3": "Ich hoffe, wir haben eines Tages ein Rematch.", - "4": "Das war ziemlich erstaunlich! Du hast mich total erschöpft…", - "5": "Du hast mir tatsächlich eine Lektion erteilt! Du bist ziemlich erstaunlich!", - "6": "Ernsthaft, ich habe verloren. Das ist, wie, ernsthaft deprimierend, aber du warst ernsthaft cool.", - "7": "Ich brauche keine Erinnerungen wie diese. Löschen der Erinnerung…", - "8": "Hey! Ich habe dir gesagt, du sollst es leicht mit mir angehen!\n$Trotzdem bist du ziemlich cool, wenn du ernsthaft bist.", - "9": "Ich werde langsam müde vom Kämpfen… Es muss etwas Neues zu tun geben…" - } - }, - "breeder": { - "encounter": { - "1": "Gehorsame Pokémon, eigensinnige Pokémon… Pokémon haben einzigartige Eigenschaften.", - "2": "Auch wenn meine Erziehung und mein Verhalten schlecht sind, habe ich meine Pokémon gut aufgezogen.", - "3": "Hmm, disziplinierst du deine Pokémon? Zu viel Verwöhnen ist nicht gut." - }, - "victory": { - "1": "Es ist wichtig, die Eigenschaften jedes Pokémon zu pflegen und zu trainieren.", - "2": "Im Gegensatz zu meinem teuflischen Selbst sind dies einige gute Pokémon.", - "3": "Zu viel Lob kann sowohl Pokémon als auch Menschen verwöhnen." - }, - "defeat": { - "1": "Du solltest nicht wütend auf deine Pokémon werden, auch wenn du einen Kampf verlierst.", - "2": "Richtig? Ziemlich gute Pokémon, oder? Ich bin dafür geeignet, Dinge großzuziehen.", - "3": "Egal wie sehr du deine Pokémon liebst,\n$du musst sie trotzdem disziplinieren, wenn sie sich schlecht benehmen." - } - }, - "breeder_female": { - "encounter": { - "1": "Pokémon verraten dich nie. Sie erwidern die ganze Liebe, die du ihnen gibst.", - "2": "Soll ich dir einen Tipp geben, wie man gute Pokémon trainiert?", - "3": "Ich habe diese sehr speziellen Pokémon mit einer speziellen Methode aufgezogen." - }, - "victory": { - "1": "Ugh… So sollte das nicht laufen. Habe ich die falsche Mischung verabreicht?", - "2": "Wie konnte das meinen Pokémon passieren… Was fütterst du deine Pokémon?", - "3": "Wenn ich verliere, sagt dir das, dass ich nur die Zeit totgeschlagen habe.\n$Es verletzt mein Ego überhaupt nicht." - }, - "defeat": { - "1": "Das beweist, dass meine Pokémon meine Liebe angenommen haben.", - "2": "Der wahre Trick, um gute Pokémon zu trainieren, besteht darin, gute Pokémon zu fangen.", - "3": "Pokémon werden stark oder schwach, je nachdem, wie du sie großziehst." - } - }, - "fisherman": { - "encounter": { - "1": "Aack! Du hast mich einen Biss verlieren lassen!\nWas wirst du dagegen tun?", - "2": "Geh weg! Du erschreckst die Pokémon!", - "3": "Mal sehen, ob du einen Sieg an Land ziehen kannst!" - }, - "victory": { - "1": "Vergiss es einfach.", - "2": "Nächstes Mal werde ich den Triumph an Land ziehen!", - "3": "Ich glaube, ich habe die Strömungen diesmal unterschätzt." - } - }, - "fisherman_female": { - "encounter": { - "1": "Woah! Ich habe einen großen Fang gemacht!", - "2": "Die Leine ist drin, bereit, den Erfolg an Land zu ziehen!", - "3": "Bereit, Wellen zu schlagen!" - }, - "victory": { - "1": "Ich komme mit einem stärkeren Haken zurück.", - "2": "Ich werde das nächste Mal den Sieg an Land ziehen.", - "3": "Ich schärfe nur meine Haken für das Comeback!" - } - }, - "swimmer": { - "encounter": { - "1": "Zeit, einzutauchen!", - "2": "Lass uns die Wellen des Sieges reiten!", - "3": "Bereit, einen Sprung ins Wasser zu machen!" - }, - "victory": { - "1": "Getränkt in Niederlage!", - "2": "Eine Welle der Niederlage!", - "3": "Zurück ans Ufer, schätze ich." - } - }, - "backpacker": { - "encounter": { - "1": "Packe deine Sachen, es geht los!", - "2": "Mal sehen, ob du mithalten kannst!", - "3": "Bereit machen, Herausforderer!", - "4": "Ich habe 20 Jahre damit verbracht, mich selbst zu finden… Aber wo bin ich?" - }, - "victory": { - "1": "Diesmal bin ich gestolpert!", - "2": "Oh, ich glaube, ich bin verloren.", - "3": "Sackgasse!", - "4": "Warte eine Sekunde! Hey! Weißt du nicht, wer ich bin?" - } - }, - "ace_trainer": { - "encounter": { - "1": "Du scheinst ziemlich zuversichtlich zu sein.", - "2": "Deine Pokémon… Zeig sie mir…", - "3": "Weil ich ein Ass-Trainer bin, denken die Leute, ich sei stark.", - "4": "Weißt du, was es braucht, um ein Ass-Trainer zu sein?" - }, - "victory": { - "1": "Ja… Du hast gute Pokémon…", - "2": "Was?! Aber ich bin ein Kampfgott!", - "3": "Natürlich, du bist der Hauptcharakter!", - "4": "OK! OK! Du könntest ein Ass-Trainer sein!" - }, - "defeat": { - "1": "Ich widme meinen Körper und meine Seele den Pokémon-Kämpfen!", - "2": "Alles innerhalb meiner Erwartungen… Nichts Überraschendes…", - "3": "Ich dachte, ich würde zu einem zerbrechlichen Menschen heranwachsen, \n$der aussieht, als würde er zerbrechen, wenn du ihn zu fest drückst.", - "4": "Natürlich bin ich stark und verliere nicht. Es ist wichtig, dass ich anmutig gewinne." - } - }, - "parasol_lady": { - "encounter": { - "1": "Zeit, das Schlachtfeld mit Eleganz und Anmut zu betreten!" - }, - "victory": { - "1": "Meine Eleganz bleibt ungebrochen!" - } - }, - "twins": { - "encounter": { - "1": "Mach dich bereit, denn wenn wir zusammenarbeiten, gibt es doppelten Ärger!", - "2": "Zwei Herzen, eine Strategie – mal sehen, ob du mit unserer Zwillingskraft mithalten kannst!", - "3": "Hoffe, du bist bereit für doppelten Ärger, denn wir werden dir einheizen!" - }, - "victory": { - "1": "Wir haben vielleicht diese Runde verloren, aber unsere Bindung bleibt unzerbrechlich!", - "2": "Unser Zwillingsgeist wird nicht lange getrübt bleiben.", - "3": "Wir werden als dynamisches Duo stärker zurückkommen!" - }, - "defeat": { - "1": "Zwillingskraft herrscht vor!", - "2": "Zwei Herzen, ein Triumph!", - "3": "Doppelte Freude, doppelter Siegestanz!" - } - }, - "cyclist": { - "encounter": { - "1": "Mach dich bereit, meinen Staub zu schlucken!", - "2": "Mach dich bereit, Herausforderer! Ich werde dich im Staub zurücklassen!", - "3": "Volle Fahrt voraus, mal sehen, ob du mithalten kannst!" - }, - "victory": { - "1": "Die Speichen stehen still, aber die Entschlossenheit dreht weiter.", - "2": "Abgehängt!", - "3": "Der Weg zum Sieg hat viele Kurven und Wendungen, die es noch zu erkunden gilt." - } - }, - "black_belt": { - "encounter": { - "1": "Ich lobe deinen Mut, mich herauszufordern! Denn ich bin derjenige mit dem stärksten Tritt!", - "2": "Oh, ich verstehe. Möchtest du in Stücke geschnitten werden? Oder bevorzugst du die Rolle des Punchingballs?" - }, - "victory": { - "1": "Oh. Die Pokémon haben gekämpft. Mein starker Tritt hat überhaupt nicht geholfen.", - "2": "Hmmm… Wenn ich sowieso verlieren würde, wollte ich wenigstens total vermöbelt werden." - } - }, - "battle_girl": { - "encounter": { - "1": "Du musst mich nicht beeindrucken. Du kannst gegen mich verlieren." - }, - "victory": { - "1": "Es ist schwer, sich zu verabschieden, aber uns läuft die Zeit davon…" - } - }, - "hiker": { - "encounter": { - "1": "Mein mittelalterlicher Bauch gibt mir so viel Gravitas wie die Berge, die ich besteige!", - "2": "Ich habe diesen kräftigen Körper von meinen Eltern geerbt… Ich bin wie eine lebende Bergkette…" - }, - "victory": { - "1": "Zumindest kann ich nicht verlieren, wenn es um BMI geht!", - "2": "Es ist nicht genug… Es ist nie genug. Mein schlechtes Cholesterin ist nicht hoch genug…" - } - }, - "ranger": { - "encounter": { - "1": "Wenn ich von der Natur umgeben bin, hören die meisten anderen Dinge auf, wichtig zu sein.", - "2": "Wenn ich ohne die Natur in meinem Leben lebe, fühle ich mich wie ein Fisch ohne Wasser." - }, - "victory": { - "1": "Es spielt keine Rolle für die Weite der Natur, ob ich gewinne oder verliere…", - "2": "So etwas ist ziemlich trivial im Vergleich zu den erdrückenden Gefühlen des Stadtlebens." - }, - "defeat": { - "1": "Ich habe den Kampf gewonnen. Aber der Sieg ist nichts im Vergleich zur Weite der Natur…", - "2": "Ich bin sicher, das mein Sieg nur dank der Natur möglich war." - } - }, - "scientist": { - "encounter": { - "1": "Meine Forschung wird diese Welt zu Frieden und Freude führen." - }, - "victory": { - "1": "Ich bin ein Genie… Ich sollte nicht gegen jemanden wie dich verlieren…" - } - }, - "school_kid": { - "encounter": { - "1": "…Heehee. Ich bin zuversichtlich in meine Berechnungen und Analysen.", - "2": "Ich sammle so viel Erfahrung wie möglich, weil ich eines Tages ein Arenaleiter sein möchte." - }, - "victory": { - "1": "Ohhhh… Berechnungen und Analysen sind kein Gegner für den Zufall…", - "2": "Auch schwierige, anstrengende Erfahrungen haben ihren Zweck, denke ich." - } - }, - "artist": { - "encounter": { - "1": "Früher war ich beliebt, aber jetzt bin ich völlig veraltet." - }, - "victory": { - "1": "Mit der Zeit ändern sich auch die Werte. Das habe ich zu spät erkannt." - } - }, - "guitarist": { - "encounter": { - "1": "Mach dich bereit, den Rhythmus der Niederlage zu spüren, während ich meinen Weg zum Sieg spiele!" - }, - "victory": { - "1": "Für den Moment zum Schweigen gebracht, aber meine Melodie der Widerstandsfähigkeit wird weiterspielen." - } - }, - "worker": { - "encounter": { - "1": "Es stört mich, dass die Leute mich immer missverstehen. Ich bin garnicht so grob wie alle denken." - }, - "victory": { - "1": "Ich will wirklich nicht, dass meine Haut verbrennt, also möchte ich im Schatten arbeiten." - } - }, - "worker_female": { - "encounter": { - "1": "Es stört mich, dass die Leute mich immer missverstehen. Ich bin garnicht so grob wie alle denken." - }, - "victory": { - "1": "Ich will wirklich nicht, dass meine Haut verbrennt, also möchte ich im Schatten arbeiten." - }, - "defeat": { - "1": "Mein Körper und mein Geist sind nicht immer unbedingt synchron." - } - }, - "worker_double": { - "encounter": { - "1": "Ich zeige dir, dass wir dich brechen können. Wir haben auf dem Feld trainiert!" - }, - "victory": { - "1": "Wie seltsam… Wie konnte das passieren… Ich hätte nicht ausgemuskelt werden sollen." - } - }, - "hex_maniac": { - "encounter": { - "1": "Ich höre normalerweise nur klassische Musik, aber wenn ich verliere,\n$werde ich ein bisschen New Age ausprobieren!", - "2": "Ich werde mit jeder Träne stärker, die ich weine." - }, - "victory": { - "1": "Ist das der Beginn des Zeitalters des Wassermanns? Ich bin bereit für die Veränderung.", - "2": "Jetzt kann ich noch stärker werden. Ich wachse mit jedem Groll." - }, - "defeat": { - "1": "New Age bezieht sich einfach auf Komponisten der klassischen Musik des 20. Jahrhunderts, richtig?", - "2": "Lass dich nicht von Traurigkeit oder Frustration aufhalten.\n$Du kannst deine Groll nutzen, um dich zu motivieren." - } - }, - "psychic": { - "encounter": { - "1": "Hallo! Konzentrier dich!" - }, - "victory": { - "1": "Eeeeek!" - } - }, - "officer": { - "encounter": { - "1": "Bereite dich vor, denn die Gerechtigkeit wird gleich vollstreckt!", - "2": "Bereit, das Gesetz zu verteidigen und die Gerechtigkeit auf dem Schlachtfeld zu wahren!" - }, - "victory": { - "1": "Die Gerechtigkeit auf meinen Schultern fühlt sich schwerer an denn je…", - "2": "Die Schatten der Niederlage schweben über dem Revier." - } - }, - "beauty": { - "encounter": { - "1": "Mein letzter Kampf überhaupt… So möchte ich, dass wir diesen Kampf sehen…" - }, - "victory": { - "1": "Es war schön… Lass uns irgendwann wieder einen letzten Kampf haben…" - } - }, - "baker": { - "encounter": { - "1": "Hoffe, du bist bereit, die Niederlage zu schmecken!" - }, - "victory": { - "1": "Ich werde ein Comeback backen." - } - }, - "biker": { - "encounter": { - "1": "Zeit, aufzudrehen und dich im Staub zurückzulassen!" - }, - "victory": { - "1": "Ich werde für das nächste Rennen tunen." - } - }, - "firebreather": { - "encounter": { - "1": "Meine Flammen werden dich verschlingen!", - "2": "Meine Seele hat Feuer gefangen. Ich werde dir zeigen, wie heiß sie brennt!", - "3": "Komm näher und sieh dir meine Flammen an!" - }, - "victory": { - "1": "Verbrannt bis zur Asche...", - "2": "Yow! Das ist heiß!", - "3": "Auuu! Ich habe mir die Nasenspitze verbrannt!" - } - }, - "sailor": { - "encounter": { - "1": "Matrose, du gehst über Bord, wenn du verlierst!", - "2": "Komm schon! Mein Stolz als Seemann steht auf dem Spiel!", - "3": "Ahoj! Bist du seekrank?" - }, - "victory": { - "1": "Argh! Von einem Kind besiegt!", - "2": "Dein Geist hat mich versenkt!", - "3": "Ich glaube, ich bin der der seekrank ist..." - } - }, - "archer": { - "encounter": { - "1": "Bevor du weitergehst, lass uns sehen, wie du dich gegen uns, Team Rocket, schlägst!", - "2": "Ich habe Berichte erhalten, dass deine Fähigkeiten nicht unbedeutend sind.\n$Mal sehen, ob sie wahr sind.", - "3": "Ich bin Atlas, ein Vorstand von Team Rocket.\n$Und ich mache es den Feinden unserer Organisation nicht leicht." - }, - "victory": { - "1": "Was für ein Fehler!", - "2": "Mit meinen aktuellen Fähigkeiten war ich der Aufgabe doch nicht gewachsen.", - "3": "V-verzeih mir, Giovanni... Dass ich von einem einfachen Trainer besiegt wurde..." - } - }, - "ariana": { - "encounter": { - "1": "Halt! Wir können niemanden herumlaufen lassen. \n$Es ist schädlich für den Stolz von Team Rocket, verstehst du.", - "2": "Ich weiß nicht und es ist mir egal, ob das, was ich tue, richtig oder falsch ist...\n$Ich vertraue einfach auf Giovanni und tue, was mir gesagt wird.", - "3": "Dein Trip endet hier. Ich werde dich erledigen!" - }, - "victory": { - "1": "Tch, du bist wirklich stark. Es ist schade. \n$Wenn du Team Rocket beitreten würdest, könntest du ein Vorstand werden.", - "2": "Ich... ich bin zerstört...", - "3": "Aaaieeeee! Das kann nicht passieren! Ich habe hart gekämpft, aber trotzdem verloren..." - } - }, - "proton": { - "encounter": { - "1": "Was willst du? Wenn du unsere Arbeit unterbrichst, erwarte keine Gnade!", - "2": "Was haben wir hier? Ich werde oft als der gruseligste und grausamste Typ bei Team Rocket bezeichnet…\n$Ich rate dir dringend, dich nicht in unsere Geschäfte einzumischen!", - "3": "Ich bin Proton, ein Admin von Team Rocket. Ich bin hier, um deinem Einmischen ein Ende zu setzen!" - }, - "victory": { - "1": "Die Festung ist gefallen! Alle Mann zurückziehen!", - "2": "Du hast diesmal gewonnen… Aber alles, was du getan hast, war, den Zorn von Team Rocket zu vergrößern…", - "3": "Ich bin besiegt… Aber ich werde das nicht vergessen!" - } - }, - "petrel": { - "encounter": { - "1": "Muhahaha, wir haben auf dich gewartet. Ich? Du weißt nicht, wer ich bin? Ich bin Giovanni.\n$Der majestätische Giovanni höchstpersönlich! Wahahaha!\n$…Huh? Ich klinge überhaupt nicht wie Giovanni?\n$Ich sehe nicht einmal aus wie Giovanni?\n$Wie kommt das? Ich habe so hart daran gearbeitet, ihn nachzuahmen!", - "2": "Ich bin Lambda, ein Admin von Team Rocket. Ich werde nicht zulassen, dass du unsere Pläne störst!", - "3": "Rocket Vorstand Lambda wird sich um diesen Eindringling kümmern!" - }, - "victory": { - "1": "OK, OK. Ich sage dir, wo er ist.", - "2": "Ich… Ich konnte nichts tun… Giovanni, bitte vergib mir…", - "3": "Nein, ich kann das nicht auf mich sitzen lassen. Ich muss die anderen informieren…" - } - }, - "tabitha": { - "encounter": { - "1": "Hehehe! Du bist also bis hierher gekommen! Aber du bist zu spät!", - "2": "Hehehe... Schon hier, oder? Wir haben dich unterschätzt! Aber das war's! \n$Ich bin eine Klasse über den Rüpeln, die du bisher gesehen hast. Ich halte dich nicht hin.\n$Ich werde dich zermalmen!", - "3": "Ich werde dir eine kleine Kostprobe des Schmerzes geben! Ergebe dich!" - }, - "victory": { - "1": "Hehehe! Du hast mich vielleicht besiegt, aber du hast keine Chance gegen den Boss!\n$Wenn du jetzt aufgibst, musst du dich keiner ordentlichen Tracht Prügel stellen!", - "2": "Hehehe... Also habe ich auch verloren...", - "3": "Ahya! Wie konnte das passieren? Ein Vorstand wie ich von einem zufälligen Trainer besiegt..." - } - }, - "courtney": { - "encounter": { - "1": "Stellt euch...Mir NICHT...IN DEN WEEEG...!!", - "2": "... Nun dann... Auslöschen...", - "3": "...?! Du... Hm... ♪ Das trifft sich ausgezeichnet... ♪\n$Dann hole ich mir eben zuerst deine Pokémon... Her damit..." - }, - "victory": { - "1": "... ...Ändere... die Welt.", - "2": "Wie erwartet. Unerwartet. Du. Ziel erfasst... abgeschlossen.\n$Beginne... Experiment. Du. Für immer. Aha... ♪", - "3": "...Schon wieder? Das war unerwartet. ...Ich wusste es. Du... bist interessant! ...Haha. ♪" - } - }, - "shelly": { - "encounter": { - "1": "Ahahahaha! Du wirst dich in die Angelegenheiten von Team Aqua einmischen?\n$Du bist entweder absolut furchtlos, einfach unwissend oder beides!\n$Du bist so süß, dass es ekelhaft ist! Ich werde dich erledigen.", - "2": "Was ist das? Wer ist dieser verwöhnte Gör?", - "3": "Beruhige dich. Sei geduldig. Ich werde dich gleich zermalmen." - }, - "victory": { - "1": "Ahahahaha! Wir wurden unerwartet gestört! Uns bleiben keine Optionen.\n$Wir müssen uns zurückziehen. Aber das ist nicht das letzte Mal, dass du Team Aqua siehst!\n$Wir haben andere Pläne! Vergiss das nicht!", - "2": "Ahhh?! War ich zu nachsichtig mit dir?!", - "3": "Uh. Willst du mir sagen, dass du während des Kampfes noch besser geworden bist?\n$Du bist ein Gör mit einer glänzenden Zukunft…\n$Meine Pokémon und ich haben keine Kraft mehr zu kämpfen…\n$Geh weiter… Geh und werde von Adrian zerstört." - } - }, - "matt": { - "encounter": { - "1": "Hoohahaha! Was, hast du eine Schraube locker oder so?\n$Sieh dich an, kleiner Makuhita-ähnlicher Trainer!", - "2": "Oho! Du! Du bist das lustige Kind!", - "3": "Was machst du hier? Bist du uns gefolgt?" - }, - "victory": { - "1": "Bwaarharharharhar!! Ich hab zwar verloren, aber das hat Spaß gemacht!", - "2": "Ich kann es fühlen! Ich kann es spüren, das ist klar! Die Stärke, die von dir ausgeht!\n$Mehr! Ich will noch mehr! Aber es sieht so aus, als hätten wir keine Zeit mehr...", - "3": "Das war Spaß! Ich wusste, dass du mir eine gute Zeit bieten würdest!\n$Ich freue mich darauf, dich eines Tages wieder zu treffen!" - } - }, - "mars": { - "encounter": { - "1": "Ich bin Mars, eine der obersten Commander von Team Galaktik.", - "2": "Die Vision von Team Galaktik für die Zukunft ist unbeirrt. Opposition wird gnadenlos zerschlagen!", - "3": "Fühlst du dich nervös? Das solltest du!" - }, - "victory": { - "1": "Das kann nicht passieren! Wie habe ich verloren?!", - "2": "Du hast etwas Können, das muss ich zugeben.", - "3": "Besiegt... Das war ein teurer Fehler." - } - }, - "jupiter": { - "encounter": { - "1": "Jupiter, Commander von Team Galaktik, zu Diensten.", - "2": "Widerstand ist zwecklos. Team Galaktik wird siegen!", - "3": "Du zitterst... Schon Angst?" - }, - "victory": { - "1": "Unmöglich... Ich habe verloren?!", - "2": "Beeindruckend, du hast Mut!", - "3": "So zu verlieren... Wie peinlich." - } - }, - "saturn": { - "encounter": { - "1": "Ich bin Saturn, Commander von Team Galaktik.", - "2": "Unsere Mission ist absolut. Jeder Widerstand wird vernichtet!", - "3": "Ist das Angst, die ich in deinen Augen sehe?" - }, - "victory": { - "1": "Unmöglich... Von dir besiegt?!", - "2": "Du hast dich als würdiger Gegner erwiesen.", - "3": "Besiegt in der Niederlage... Das ist inakzeptabel." - } - }, - "zinzolin": { - "encounter": { - "1": "Du könntest eine Bedrohung für Team Plasma werden, also werden wir dich hier und jetzt eliminieren!", - "2": "Oh, zum Heulen... Ich hatte nicht erwartet, in dieser eisigen Kälte kämpfen zu müssen!", - "3": "Du bist ein beeindruckender Trainer, dass du es so weit geschafft hast. Aber hier endet es." - }, - "victory": { - "1": "G-Cis... Ich habe versagt...", - "2": "Es ist bitterkalt. Ich zittere. Ich leide. Doch ich stehe immer noch siegreich da.", - "3": "Hm. Du bist ein klügerer Trainer, als ich erwartet habe, aber nicht klug genug." - } - }, - "rood": { - "encounter": { - "1": "Du bist eine Bedrohung für Team Plasma. Wir können dich hier und jetzt nicht laufen lassen!", - "2": "Oh, dieser eisige Wind... Ich hätte nie gedacht, dass ich hier kämpfen müsste!", - "3": "Du bist ein bemerkenswerter Trainer, dass du es bis hierher geschafft hast. Aber hier wird es enden." - }, - "victory": { - "1": "G-Cis... Ich habe meine Mission nicht erfüllt...", - "2": "Die Kälte ist durchdringend. Ich zittere. Ich leide. Doch ich habe gesiegt.", - "3": "Hm. Du bist ein talentierter Trainer, aber leider nicht talentiert genug." - } - }, - "xerosic": { - "encounter": { - "1": "Ah ha ha! Es wäre mir ein Vergnügen. Komm schon, kleiner Trainer! Zeig mir, was du drauf hast!", - "2": "Hm... Du bist mächtiger, als du aussiehst. Ich frage mich, wie viel Energie in dir steckt.", - "3": "Ich habe auf dich gewartet! Ich muss ein wenig Forschung an dir betreiben! Komm, lass uns beginnen!" - }, - "victory": { - "1": "Ah, du bist ziemlich stark. Oh ja—sehr stark, in der Tat.", - "2": "Ding-ding-ding! Du hast es geschafft! Dem Sieger gebührt die Beute!", - "3": "Wunderbar! Erstaunlich! Du hast enorme Fähigkeiten und Mut!" - } - }, - "bryony": { - "encounter": { - "1": "Ich bin Begonia, und es wäre mir ein Vergnügen, gegen dich zu kämpfen. Zeig mir, was du drauf hast.", - "2": "Beeindruckend... Du bist mächtiger, als du aussiehst. Zeig mir das wahre Ausmaß deiner Energie.", - "3": "Ich habe deine Ankunft erwartet. Es ist Zeit für einen kleinen Test. Sollen wir beginnen?" - }, - "victory": { - "1": "Du bist ziemlich stark. Oh ja—sehr stark, in der Tat.", - "2": "Ding-ding-ding! Du hast dich gut geschlagen. Der Sieg gehört dir.", - "3": "Wunderbar! Bemerkenswert! Deine Fähigkeiten und dein Mut sind lobenswert." - } - }, - "rocket_grunt": { - "encounter": { - "1": "Jetzt gibt es Ärger!…\n$und es kommt noch härter!\n$Wir wollen über die Erde regieren…\n$und naja du kennst den Rest…!", - "2": "Wir führen gerade eine große Operation durch. Hast du vor uns zu stören?", - "3": "Gib uns deine Pokémon, oder stelle dich dem Zorn von Team Rocket!", - "4": "Team Rocket wird seinen Plan zur Vollendung bringen, Aus dem Weg!", - "5": "Los, gib uns deine Pokémon. Wir brauchen sie für unseren Plan!" - }, - "victory": { - "1": "Das war mal wieder ein Schuss in den Ofen!", - "2": "Dem Boss wird das aber nicht gefallen!", - "3": "Ich habe es vermasselt!", - "4": "Meine Kollegen werden das nicht tolerieren!", - "5": "Team Rocket wird wiederkehren! Das sage ich Jessie und James!" - } - }, - "magma_grunt": { - "encounter": { - "1": "Keiner, der sich Team Magma in den Weg stellt, bekommt Gnade, nicht einmal Kinder!", - "2": "Störe besser nicht unsere Pläne! Wir formen die Welt nach unseren Vorstellungen!", - "3": "Du stehst uns im Weg! Team Magma hat keine Zeit für Störenfriede wie dich!", - "4": "Bereite dich auf die Hölle vor, denn es wird bald sehr heiß!", - "5": "Wir werden die Macht des Vulkans entfesseln! Es wird gewaltig sein! Mach dich bereit!" - }, - "victory": { - "1": "Wie kann das sein? Ich bin Teil des mächtigen Team Magma! Wir streben nach der Verbesserung der Welt...", - "2": "Unglaublich, dass ich verloren habe! Mit meinen mächtigen Pokémon.", - "3": "Das kann nicht sein! Ich hab doch viel mehr Erfahrung als du!", - "4": "Verdammt... Ich hätte sofort in unser Versteck fliehen sollen...", - "5": "Du hast mich besiegt... Der Boss wird mich dafür zur Rechenschaft ziehen." - } - }, - "aqua_grunt": { - "encounter": { - "1": "Du willst dich also mit Team Aqua anlegen? Du traust dich ja was… Dich werfe ich über Bord!", - "2": "Du hast ganz schön Mut, dich mit Team Aqua anzulegen!", - "3": "Ich hoffe du hast einen Regenschirm dabei. Hier wird es jetzt nass!", - "4": "Wir, Team Aqua, existieren zum Wohle aller!", - "5": "Bereite dich darauf vor, von den Fluten meiner Pokémon weggespült zu werden!" - }, - "victory": { - "1": "Vielleicht sollte ich wohl lieber selber über die Planke gehen…", - "2": "Arrgh, ich habe nicht damit gerechnet, von einer Landratte gestört zu werden!", - "3": "Ich habe verloren?! Ich schätze, ich muss jetzt zurück zum Versteck schwimmen...", - "4": "Oh Mann, was für eine Katastrophe... Der Boss wird wütend sein...", - "5": "Du hast mich besiegt... Meinst du, der Boss wird mich dafür kielholen lassen?" - } - }, - "galactic_grunt": { - "encounter": { - "1": "Team Galaktik wird die Welt in eine bessere verwandeln! Und du wirst uns nicht aufhalten!", - "2": "Erlebe die Macht unserer Technologie und die Zukunft, die wir uns vorstellen!", - "3": "Im Namen von Team Galaktik werde ich jeden beseitigen, der uns im Weg steht!", - "4": "Mach dich bereit zu verlieren!", - "5": "Hoffentlich bist du bereit für eine kosmische Niederlage!" - }, - "victory": { - "1": "Zyrus wird uns für diese Niederlage bestrafen…", - "2": "Dieser Rückschlag bedeutet nichts in Hinsicht unseres großen Plans.", - "3": "Unsere Pläne sind größer als diese Niederlage.", - "4": "Wie ist das möglich?!", - "5": "Notiz an mich selbst: Pokémon-Kämpfe üben, so bald wie möglich." - } - }, - "plasma_grunt": { - "encounter": { - "1": "Pokémon sollten frei sein! Team Plasma wird sie befreien!", - "2": "Wenn ich gegen dich gewinne, lass deine Pokémon frei!", - "3": "Wenn du Team Plasma im Weg stehst, werde ich mich um dich kümmern!", - "4": "Team Plasma wird Pokémon von egoistischen Menschen wie dir befreien!", - "5": "Lass dich von unserem Aussehen nicht täuschen. Unsere Kampffähigkeiten sind überragend!" - }, - "victory": { - "1": "Wie konnte ich verlieren? Ich dachte, ich würde die Welt retten...", - "2": "Wie konnte ich nur verlieren...", - "3": "...Dieses Pokémon ist zu schwach, ich werde stärkere beschaffen müssen!", - "4": "Große Pläne stoßen immer auf Hindernisse.", - "5": "Das ist ein schwerer Rückschlag für Team Plasma..." - } - }, - "flare_grunt": { - "encounter": { - "1": "Deine Pokémon haben keine Chance gegen die Überlegenheit von Team Flare.", - "2": "Mach dich bereit, denn gleich wird es hier lichterloh brennen!", - "3": "Team Flare wird die Welt von allen Makeln befreien!", - "4": "Bereite dich auf die unvergleichliche Macht von Team Flare vor!", - "5": "Unsere Mission steht über allem, sogar über der Mode!" - }, - "victory": { - "1": "Diese Niederlage wirft einen Schatten auf meine Zukunft.", - "2": "Es scheint, dass ich meine Strategien überdenken muss. Zurück ans Reißbrett.", - "3": "Unglaublich?! Ich habe verloren?!", - "4": "Selbst in der Niederlage bleibt Team Flare unübertroffen in seiner Eleganz.", - "5": "Du hast mich besiegt, aber Team Flare wird immer in Glanz und Stil erstrahlen." - } - }, - "aether_grunt": { - "encounter": { - "1": "Ich werde dich mit allem, was ich habe, bekämpfen. Ich werde dich auslöschen!", - "2": "Mir ist egal, ob du ein simpler Trainer bist oder nicht.\n$Ich werde dich hochkant rauswerfen, wenn du uns bedrohst!", - "3": "Mir wurde gesagt, Trainer abzuweisen, egal wer sie sind!", - "4": "Ich zeige dir die Macht des Æther-Paradies", - "5": "Jetzt da du die Wahre Natur des Æther-Paradies kennst, müssen wir dich leider beseitigen!" - }, - "victory": { - "1": "Hmph! Du scheinst ziemlich geschickt zu sein.", - "2": "Was hat das zu bedeuten? Was hat das zu bedeuten!", - "3": "Hey, du bist so stark, dass ich dich nicht abweisen kann!", - "4": "Hmm... Es scheint, als hätte ich verloren.", - "5": "Ich hätte das Blitzdings benutzen sollen..." - } - }, - "faba": { - "encounter": { - "1": "Ich bin Regionalleiter Fabian und ich werde dir zeigen, wie hart die Welt sein kann!", - "2": "Die letzte Verteidigungslinie des Æther-Paradieses kämpft gegen einen simplen Trainer?", - "3": "Ich Fabian, bin der Regionalleiter der Æther Foundation.\n$Der einzige auf der Welt, ich bin unersetzlich." - }, - "victory": { - "1": "Aiyee!", - "2": "W-w-wie kann das sein?! Wie konnte dieser Trainer...", - "3": "Das ist der Grund... warum ich andere Menschen nicht ausstehen kann." - } - }, - "skull_grunt": { - "encounter": { - "1": "Wir sind nicht böse, wir sind einfach nur nicht nett!", - "2": "Willst du Stress, oder was? Das ist unsere Art, Hallo zu sagen! Tschüss, du Punk!", - "3": "Wir sind nur ein paar Typen und Mädels mit großem Interesse an den Pokémon anderer Leute!", - "4": "Wieso machst du einen auf hart, wenn wir schon hart wie Knochen sind, Homie?", - "5": "Yo, platz hier nich’ rein, ♪ wie’n wildes Kleinstein! ♪ Wenn du meinst, dass Team Skull ♪\n$an nix denkt als Krawall, ♪ hast du leider ’nen Knall, ♪ denn das is’ nich’ der Fall! ♪\n$Wir woll’n hier nur gammeln ♪ und gechillt Staub ansammeln! ♪" - }, - "victory": { - "1": "Wie jetzt? Schon vorbei?", - "2": "Woah, lass uns lieber die Kurve kratzen, yo! Kein Bock, hier meinen Schädel zu riskieren...", - "3": "Wir brauchen deine schwachen Pokémon eh nicht!", - "4": "Was? Deine Stärke spür ich bis in die Knochen...", - "5": "Mein Homie und ich sind also weniger wert als Pokémon? Willste uns dissen, oder was?" - } - }, - "plumeria": { - "encounter": { - "1": "..Hmph. Du siehst nicht so aus, als wärst du etwas Besonderes.", - "2": "Die blöden Rüpel brauchen viel zu lange, um mit euch gewöhnlichen Trainern fertig zu werden...", - "3": "Lege dich mit irgendjemandem in Team Skull an, und ich zeige dir, wie ernst ich werden kann." - }, - "victory": { - "1": "Du bist ziemlich stark. Das muss ich zugeben.", - "2": "Jetzt versteh ich, warum meine Rüpel so viel Zeit damit verschwenden...", - "3": "Ich denke, ich muss diese Niederlage einfach hinnehmen." - } - }, - "macro_grunt": { - "encounter": { - "1": "Achtung hier ist Endstation für dich!", - "2": "Du bist ein Trainer, oder? Wir von MC Wertpapiere wissen so etwas.\n$Ich fürchte, das gibt dir trotzdem nicht das Recht, sich in unsere Arbeit einzumischen.", - "3": "Ich bin von MC Versicherungen! Hast du eine Lebensversicherung?" - }, - "victory": { - "1": "Ich habe keine andere Wahl, als respektvoll zurückzutreten.", - "2": "Mein Erspartes aufzugeben bringt mich in die roten Zahlen...", - "3": "Okay zurück an die Arbeit. Versicherungen verkauft sich nicht von alleine." - } - }, - "oleana": { - "encounter": { - "1": "Ich werde keine Störung von Präsident Roses Plänen zulassen!", - "2": "Du hast es also durch die Mitarbeiter der Tochterunternehmen geschafft,\n$die ich beauftragt habe, um dich aufzuhalten. Ich hätte nichts anderes erwartet.", - "3": "Für den Präsidenten! Ich werde nicht verlieren! \n$Mach dich bereit mit Macro Cosmos Airlines nach Hause zu fliegen!" - }, - "victory": { - "1": "Ich habe es nicht geschafft... Olivia... du bist wirklich eine hoffnungslose Frau.", - "2": "Arghhh! Das ist unentschuldbar... Was habe ich mir dabei gedacht...\n$Jeder Trainer, der es so weit geschafft hat, muss ein harter Brocken sein...", - "3": "Ich bin eine müde Olivia... Ob es Macro Cosmos Betten gibt?" - } - }, - "rocket_boss_giovanni_1": { - "encounter": { - "1": "Ich bin beeindruckt, du hast es bis hierher geschafft!\n$Ich bin Giovanni, der Anführer von Team Rocket!\n$Wir regieren den Untergrund von Kanto!\n$Und wir lassen sicherlich nicht zu, dass ein Kind uns aufhält!" - }, - "victory": { - "1": "Ich ziehe mich zurück, aber ich werde zurückkehren! Team Rocket wird niemals besiegt werden!" - }, - "defeat": { - "1": "Merke dir meine Worte. Nicht in der Lage zu sein,\n$deine eigene Stärke zu messen, zeigt, dass du immer noch ein Kind bist." - } - }, - "rocket_boss_giovanni_2": { - "encounter": { - "1": "Du schon wieder… Wie hast du mich gefunden? Team Rocket wird dich endlich aus der Welt schaffen!" - }, - "victory": { - "1": "Wie ist das möglich...? Der kostbare Traum von Team Rocket ist nicht mehr als eine Illusion geworden..." - }, - "defeat": { - "1": "Team Rocket wird niemals besiegt werden! Ich werde zurückkehren!" - } - }, - "magma_boss_maxie_1": { - "encounter": { - "1": "Die Welt ist nicht perfekt. Ich werde sie verbessern, indem ich sie neu erschaffe!\n$Wir brauchen mehr Landmassen um zu leben! Team Magma wird dieses Ziel mit aller Macht erreichen!" - }, - "victory": { - "1": "Ugh! Das entspricht nicht meinen Berechnungen! Wie konnte ich verlieren? Wir sehen uns wieder!" - }, - "defeat": { - "1": "Team Magma wird weiterhin die Welt verbessern!" - } - }, - "magma_boss_maxie_2": { - "encounter": { - "1": "Du bist das letzte Hindernis, das zwischen mir und meinen Zielen steht.\n$Mach dich bereit durch die Macht von Team Magma besiegt zu werden!" - }, - "victory": { - "1": "Das... Das kann nicht sein..." - }, - "defeat": { - "1": "Und jetzt werde ich diesen Planeten terraformen, um ihn ideal für die Menschheit zu machen." - } - }, - "aqua_boss_archie_1": { - "encounter": { - "1": "Ich bin Adrian, der Anführer von Team Aqua! Wir werden die Welt mit Wasser überfluten!" - }, - "victory": { - "1": "Lass uns mal wieder treffen. Ich werde mir sicher sein, dass ich dieses Gesicht wiedererkenne." - }, - "defeat": { - "1": "Brilliant! Mein Team wird jetzt nicht zurückhalten!" - } - }, - "aqua_boss_archie_2": { - "encounter": { - "1": "Ich habe lange auf diesen Tag gewartet. Das ist die wahre Macht von Team Aqua!" - }, - "victory": { - "1": "So habe ich mir das nicht vorgestellt..." - }, - "defeat": { - "1": "Ich werde alles in dieser Welt in seinen ursprünglichen, reinen Zustand zurückversetzen!!" - } - }, - "galactic_boss_cyrus_1": { - "encounter": { - "1": "Du wurdest von leerer Gefühlsduselei hierher getrieben.\n$Ich werde dich bereuen lassen, auf dein Herz gehört zu haben!" - }, - "victory": { - "1": "Interessant. Und ziemlich eigenartig." - }, - "defeat": { - "1": "Ich werde meine neue Welt erschaffen..." - } - }, - "galactic_boss_cyrus_2": { - "encounter": { - "1": "So sehen wir uns wieder. Es scheint, als wären unsere Schicksale miteinander verflochten.\n$Aber hier und jetzt werde ich diese Verbindung brechen!" - }, - "victory": { - "1": "Wie? Wie? WIE?!" - }, - "defeat": { - "1": "Bis bald." - } - }, - "plasma_boss_ghetsis_1": { - "encounter": { - "1": "Ich werde nicht zulassen, dass mich jemand aufhält! Egal wer es auch sein mag!" - }, - "victory": { - "1": "Wie kann das sein? Ich bin der Schöpfer von Team Plasma! Ich bin perfekt!" - }, - "defeat": { - "1": "Ich bin der perfekte Herrscher einer perfekten neuen Welt! Mwa ha ha!" - } - }, - "plasma_boss_ghetsis_2": { - "encounter": { - "1": "Komm schon! Ich will dein Gesicht sehen, in dem Moment, in dem du alle Hoffnung verlierst!" - }, - "victory": { - "1": "Meine Berechnungen... Nein! Meine sorgfältigen Pläne! Die Welt sollte mir gehören!" - }, - "defeat": { - "1": "Kyurem! Verwende Absorptionsfusion!" - } - }, - "flare_boss_lysandre_1": { - "encounter": { - "1": "DU willst mich aufhalten? Dann zeig mir deine Stärke in einem Kampf!" - }, - "victory": { - "1": "Du bist hier, um mich aufzuhalten. Aber ich bitte dich zu warten.\n$Ich bin so kurz davor, meine Vision zu verwirklichen." - }, - "defeat": { - "1": "Pokémon... Sollten nicht mehr existieren." - } - }, - "flare_boss_lysandre_2": { - "encounter": { - "1": "Die Zukunft, die du willst, oder die Zukunft, die ich will...\n$Lass uns sehen, welche mehr zu existieren verdient, sollen wir?" - }, - "victory": { - "1": "Die Zukunft, die ich erschaffen wollte... Es ist vorbei..." - }, - "defeat": { - "1": "Narren ohne Vision werden weiterhin diese wunderschöne Welt verunreinigen." - } - }, - "aether_boss_lusamine_1": { - "encounter": { - "1": "Du wirst mein süßes Biest erschrecken! Wie kannst du nur? Ultra-Bestien sind so niedlich!\n$Es sieht so aus, als müsste ich dich zuerst zum Schweigen bringen." - }, - "victory": { - "1": "Wie kann eine Person nur so grausam sein?!" - }, - "defeat": { - "1": "Und jetzt, mein süßes Biest, komm zu Mama!" - } - }, - "aether_boss_lusamine_2": { - "encounter": { - "1": "Wieso musst du mich weiterhin belästigen?! Ich habe die Nase voll von dir.\n$Du machst mich krank! Genug mit diesem nutzlosen Gerede... \n$Mit der Kraft von Anego, von uns als UB-01 Schmarotzer klassifiziert,\n$werde ich dir zeigen, wie falsch du warst, hierher zu kommen!" - }, - "victory": { - "1": "Aaauuuggghhhhhhhhh!!!" - }, - "defeat": { - "1": "Alles, was ich will, ist mein kostbares Biest! Der Rest von euch ist mir egal!" - } - }, - "skull_boss_guzma_1": { - "encounter": { - "1": "Kein Erbarmen! Keine Gnade! Ich bin dein schlimmster Alptraum! \n$Oh yeah, ich bin der große, böse Bromley!" - }, - "victory": { - "1": "Irgendwann mach ich dich platt! Ich hab noch ein Ass im Ärmel. Du wirst schon sehen." - }, - "defeat": { - "1": "Du hast den langen Weg hierher DAFÜR aufgenommen? Pah!" - } - }, - "skull_boss_guzma_2": { - "encounter": { - "1": "Mir ist egal, wer du bist. Ich mach dich platt!! Das schreibt mir mein Ego vor. Ich bin Bromley!" - }, - "victory": { - "1": "Bromley!!! Was ist falsch mit dir?!" - }, - "defeat": { - "1": "Ihr seid wirklich selten dämlich." - } - }, - "macro_boss_rose_1": { - "encounter": { - "1": "Mein Name ist Rose. Ich bin der Präsident der Galar Pokémon-Liga und Geschäftsführer von Macro Cosmos\n$Ich habe eine Aufgabe, eine Berufung! Ich muss die Galar-Region mit unbegrenzter Energie versorgen,\n$damit sie sich bis in alle Ewigkeit in Frieden fortentwickeln kann!" - }, - "victory": { - "1": "Du versteht es einfach nicht...So können wir die Geschichte nicht verändern!" - }, - "defeat": { - "1": "Ohne deine Einmischung kann ich jetzt endlich weiterarbeiten!" - } - }, - "macro_boss_rose_2": { - "encounter": { - "1": "Ich bin fest entschlossen, das Energieproblem in der Galar-Region\n$und natürlich auf der ganzen Welt zu lösen.\n$Meine Erfahrungen und Erfolge, die Macro Cosmos zu einem Erfolg gemacht haben,\n$sind der Beweis, dass meine Methoden funktionieren.\n$Ich habe nicht vor, meine Meinung zu ändern, selbst wenn ich verliere." - }, - "victory": { - "1": "Ich hatte vergessen, wie großartig Pokémon-Kämpfe sind! Es ist so lange her, dass ich gekämpft habe...\n$Das war wirklich befriedigend, ich akzeptiere die Niederlage für diesen Kampf." - }, - "defeat": { - "1": "Ich nehme an, es muss den Anschein haben, dass ich etwas Schreckliches tue.\n$Ich erwarte nicht, dass du es verstehst. Aber ich muss der Galar-Region grenzenlose Energie\n$bereitstellen, um ewigen Wohlstand zu gewährleisten." - } - }, - "brock": { - "encounter": { - "1": "Meine Expertise in Bezug auf Gesteins-Pokémon wird dich besiegen! Komm schon!", - "2": "Meine felsenfeste Entschlossenheit wird dich überwältigen!", - "3": "Ich bin ein harter Fels, der nicht so leicht zu brechen ist!" - }, - "victory": { - "1": "Die Stärke deiner Pokémon hat meine steinharte Verteidigung überwunden!", - "2": "Die Welt ist riesig! Ich bin froh, dass ich die Chance hatte, gegen dich zu kämpfen.", - "3": "Perhaps I should go back to pursuing my dream as a Pokémon Breeder…" - }, - "defeat": { - "1": "Der beste Angriff ist eine gute Verteidigung!\nDas ist meine Art, Dinge zu tun!", - "2": "Komm und studiere Felsen mit mir, um besser zu lernen wie man gegen sie kämpft!", - "3": "Meine Reisen durch die Regionen zahlen sich aus!" - } - }, - "misty": { - "encounter": { - "1": "Meine Taktik ist ein Frontalangriff mit Wasser-Pokémon!", - "2": "Hiya! Ich zeige dir die Stärke meiner Wasser-Pokémon!", - "3": "Mein Traum war es, auf eine Reise zu gehen und gegen starke Trainer zu kämpfen… \n$Wirst du eine ausreichende Herausforderung sein?" - }, - "victory": { - "1": "Du bist wirklich stark… Ich gebe zu, du hast es drauf…", - "2": "Du weißt, dass du nur Glück hattest, oder?", - "3": "Wow, ich kann nicht glauben, dass du mich besiegt hast!" - }, - "defeat": { - "1": "War die mächtige Misty zu viel für dich?", - "2": "Ich hoffe, du hast die eleganten Schwimmtechniken meiner Pokémon gesehen!", - "3": "Deine Pokémon waren keine Herausforderung für meine geliebten Pokémon!" - } - }, - "lt_surge": { - "encounter": { - "1": "Meine Elektro-Pokémon haben mich im Krieg gerettet! Ich werde dir zeigen, wie!", - "2": "Du wirst um Gnade winseln, wenn ich dich geschockt habe!", - "3": "Ich werde dich genau so zappen, wie ich es mit all meinen Feinden im Kampf mache!" - }, - "victory": { - "1": "Whoa! Dein Team ist echt stark!", - "2": "Aaargh, du bist stark! Selbst meine elektrischen Tricks haben gegen dich verloren.", - "3": "Das war ein absolut schockierender Verlust!" - }, - "defeat": { - "1": "Oh ja! Wenn es um Elektro-Pokémon geht, bin ich weltweit die Nummer eins!", - "2": "Hahaha! Das war ein elektrisierender Kampf!", - "3": "Ein Pokémon-Kampf ist Krieg, und ich habe dir den Nahkampf gezeigt!" - } - }, - "erika": { - "encounter": { - "1": "Ah, das Wetter ist hier so schön…\nOh, ein Kampf? Nun gut.", - "2": "Meine Pokémon-Kampffähigkeiten stehen in Konkurrenz zu meinen Blumenarrangierfähigkeiten.", - "3": "Oh, ich hoffe, der angenehme Duft meiner Pokémon lässt mich nicht wieder einschlafen…", - "4": "Blumen in einem Garten zu sehen ist so beruhigend." - }, - "victory": { - "1": "Oh! Ich gestehe meine Niederlage ein.", - "2": "Dieser Kampf war so entspannend.", - "3": "Ah, es scheint, dass ich verloren habe…", - "4": "Na immerhin habe ich noch meine Blumen." - }, - "defeat": { - "1": "Ich hatte Angst, dass ich einschlafen würde…", - "2": "Es scheint, als hätten meine Pflanzen-Pokémon dich überwältigt.", - "3": "Dieser Kampf war eine so beruhigende Erfahrung.", - "4": "Das war alles?" - } - }, - "janine": { - "encounter": { - "1": "Ich meistere die Kunst der giftigen Angriffe. Ich werde heute mit dir trainieren!", - "2": "Vater vertraut darauf, dass ich mich behaupten kann. Ich werde ihm recht geben!", - "3": "Meine Ninja-Techniken sind nur zweitrangig zu denen meines Vaters! Kannst du mithalten?" - }, - "victory": { - "1": "Selbst jetzt brauche ich noch Training… Ich verstehe.", - "2": "Dein Kampfstil hat meinen überwältigt.", - "3": "Ich werde mich wirklich anstrengen und meine Fähigkeiten verbessern." - }, - "defeat": { - "1": "Fufufu… das Gift hat dir all deine Kraft zum Kämpfen geraubt.", - "2": "Ha! Du hattest keine Chance gegen meine überlegenen Ninja-Fähigkeiten!", - "3": "Vaters Vertrauen in mich war nicht unbegründet." - } - }, - "sabrina": { - "encounter": { - "1": "Ich habe deine Ankunft in einer Vision gesehen!", - "2": "Ich mag es nicht zu kämpfen, aber wenn du darauf bestehst, werde ich dir meine Kräfte zeigen!", - "3": "Ich spüre große Ambitionen in dir. Ich werde sehen, ob sie begründet sind." - }, - "victory": { - "1": "Deine Kraft… Sie übertrifft bei weitem das, was ich vorausgesehen habe…", - "2": "Ich habe es nicht geschafft, deine Stärke genau vorherzusagen.", - "3": "Selbst mit meinen immensen psychischen Kräften kann ich niemanden spüren, der stärker ist als du." - }, - "defeat": { - "1": "Dieser Sieg… Genau so habe ich ihn in meinen Visionen gesehen!", - "2": "Vielleicht war es jemand anderes, den ich spürte…", - "3": "Verfeinere deine Fähigkeiten, bevor du unüberlegt in den Kampf stürzt.\n$Du weißt nie, was die Zukunft bereithält, wenn du es tust…" - } - }, - "blaine": { - "encounter": { - "1": "Hah! Ich hoffe, du hast Feuerheiler mitgebracht!", - "2": "Meine feurigen Pokémon werden alle Herausforderer verbrennen!", - "3": "Mach dich bereit, mit dem Feuer zu spielen!" - }, - "victory": { - "1": "Ich habe mich bis auf die Knochen verbrannt! Nicht einmal Asche bleibt!", - "2": "Habe ich die Flammen nicht hoch genug geschürt?", - "3": "Ich bin komplett ausgebrannt… Aber das lässt meine Motivation, mich zu verbessern, noch heißer brennen!" - }, - "defeat": { - "1": "Mein wütendes Inferno kann nicht gelöscht werden!", - "2": "Meine Pokémon sind durch die Hitze dieses Sieges gestärkt worden!", - "3": "Hah! Meine Leidenschaft brennt heller als deine!" - } - }, - "giovanni": { - "encounter": { - "1": "Ich, der Anführer von Team Rocket, werde dir eine Welt voller Schmerz bereiten!", - "2": "Mein Training hier wird entscheidend sein, bevor ich mich wieder meinen alten Kollegen stelle.", - "3": "Ich denke dass du nicht auf die Ausmaße des Scheiterns vorbereitet bist, die du gleich erleben wirst!" - }, - "victory": { - "1": "WAS! Ich, verlieren?! Es gibt nichts, was ich dir sagen möchte!", - "2": "Hmm… Du wirst nie verstehen können, was ich zu erreichen versuche.", - "3": "Diese Niederlage ist nur ein kleiner Rückschlag.\nTeam Rocket wird aus der Asche auferstehen." - }, - "defeat": { - "1": "Das du nicht in der Lage bist, deine eigene Stärke einzuschätzen, zeigt, dass du noch ein Kind bist.", - "2": "Versuche nicht, dich wieder in meine Angelegenheiten einzumischen.", - "3": "Ich hoffe, du verstehst, wie dumm es war, mich herauszufordern." - } - }, - "roxanne": { - "encounter": { - "1": "Wärs du so freundlich und würdest mir zeigen, wie du kämpfst?", - "2": "Man lernt so viel, wenn man gegen viele Trainer kämpft.", - "3": "Oh, du hast mich beim Strategie entwickeln erwischt. Möchtest du kämpfen?" - }, - "victory": { - "1": "Oh, es scheint, als hätte ich verloren.", - "2": "Es scheint, als hätte ich noch so viel mehr zu lernen, wenn es um Kämpfe geht.", - "3": "Ich werde mir zu Herzen nehmen, was ich heute gelernt habe." - }, - "defeat": { - "1": "Ich habe so viele Dinge aus unserem Kampf gelernt. Ich hoffe, du auch.", - "2": "Ich freue mich darauf, wieder gegen dich zu kämpfen.\n$Ich hoffe, du wirst das, was du hier gelernt hast, anwenden.", - "3": "Ich habe gewonnen, weil ich alles gelernt habe." - } - }, - "brawly": { - "encounter": { - "1": "Oh man, ein Herausforderer!\nLass uns sehen, was du kannst!", - "2": "Du scheinst auf große Auftritte zu stehen.\nLass uns kämpfen", - "3": "Zeit, einen Sturm zu entfachen!\nLos geht's!" - }, - "victory": { - "1": "Oh wow, du hast mich überrumpelt!", - "2": "Du hast meinen Flow übernommen und mich besiegt!", - "3": "Ich fühle mich als hätte ich mich in der Granithöhle verirrt!" - }, - "defeat": { - "1": "Haha, ich surfe die große Welle! Fordere mich irgendwann wieder heraus.", - "2": "Surfe mal wieder mit mir!", - "3": "Genau wie die Gezeiten kommen und gehen, hoffe ich, dass du zurückkommst, um mich herauszufordern." - } - }, - "wattson": { - "encounter": { - "1": "Zeit, geschockt zu werden! Wahahahaha!", - "2": "Ich lass die Funken fliegen! Wahahahaha!", - "3": "Ich hoffe, du hast Para-Heiler dabei! Wahahahaha!" - }, - "victory": { - "1": "Scheint als wäre ich entladen! Wahahahaha!", - "2": "Du hast mich komplett geerdet! Wahahahaha!", - "3": "Danke für den Nervenkitzel! Wahahahaha!" - }, - "defeat": { - "1": "Lade deine Batterien wieder auf und fordere mich irgendwann wieder heraus! Wahahahaha!", - "2": "Ich hoffe du fandest unseren Kampf elektrisierend! Wahahahaha!", - "3": "Bist du nicht geschockt, dass ich gewonnen habe? Wahahahaha!" - } - }, - "flannery": { - "encounter": { - "1": "Nett dich zu kennenzulernen! Warte, nein… Ich werde dich zermalmen!", - "2": "Ich bin noch nicht lange Arenaleiterin, aber ich werde dich grillen!", - "3": "Es ist Zeit, dir die Kampftechniken zu zeigen, die mein Großvater mir beigebracht hat! Lass uns kämpfen!" - }, - "victory": { - "1": "Du erinnerst mich an meinen Großvater… Kein Wunder, dass ich verloren habe.", - "2": "Strenge ich mich zu sehr an? Ich sollte mich entspannen, ich darf mich nicht zu sehr aufregen.", - "3": "Zu verlieren wird meine Flamme nicht ersticken. Zeit, das Training wieder zu entfachen!" - }, - "defeat": { - "1": "Ich hoffe, ich habe meinen Großvater stolz gemacht… Lass uns irgendwann wieder kämpfen.", - "2": "Ich… Ich kann nicht glauben, dass ich gewonnen habe! Meine Art zu kämpfen hat funktioniert!", - "3": "Lass uns bald wieder heiße Moves austauschen!" - } - }, - "norman": { - "encounter": { - "1": "Ich bin überrascht, dass du es bis hierher geschafft hast. Lass uns kämpfen.", - "2": "Ich werde alles in meiner Macht stehende tun, um als Arenaleiter zu gewinnen. Los geht's!", - "3": "Du solltest alles geben! Lasst uns kämpfen!" - }, - "victory": { - "1": "Ich habe gegen dich verloren…? Das ist eine Überraschung.", - "2": "War der Umzug nach Hoenn die richtige Entscheidung? Ich bin mir nicht sicher.", - "3": "Ich kann es nicht fasen. Das war ein großartiger Kampf." - }, - "defeat": { - "1": "Wir haben beide unser Bestes gegeben. Ich hoffe, wir können bald wieder kämpfen.", - "2": "Du solltest versuchen, mein Kind herauszufordern. Du könntest etwas lernen!", - "3": "Danke für den tollen Kampf. Viel Glück beim nächsten Mal." - } - }, - "winona": { - "encounter": { - "1": "Ich bin durch die Lüfte geflogen und habe nach Beute gesucht… und du bist mein Ziel!", - "2": "Egal, wie unser Kampf ausgeht, meine Flug-Pokémon und ich werden mit Anmut triumphieren. Auf in den Kampf!", - "3": "Ich hoffe, du hast keine Höhenangst. Lasst uns aufsteigen!" - }, - "victory": { - "1": "Du bist der erste Trainer, den ich gesehen habe, der mehr Anmut hat als ich. Ausgezeichnet", - "2": "Meine Flug-Pokémon sind abgestürzt! Na gut.", - "3": "Auch wenn ich gefallen sein mag, meine Pokémon werden weiter fliegen!" - }, - "defeat": { - "1": "Meine Flug-Pokémon und ich werden für immer elegant tanzen!", - "2": "Ich hoffe du hast die Show genossen. Unser anmutiger Tanz ist beendet.", - "3": "Wirst du zurückkommen und unsere elegante Choreographie noch einmal sehen?" - } - }, - "tate": { - "encounter": { - "1": "Hehehe… Bist du überrascht, mich ohne meine Schwester zu sehen?", - "2": "Ich kann sehen, was du denkst… Du willst kämpfen!", - "3": "Wie kannst du jemanden besiegen der deine Gedanken lesen kann?" - }, - "victory": { - "1": "Ich kann es nicht ändern… Ich vermisse Svenja…", - "2": "Die Bande zwischen dir und deinen Pokémon ist stärker als meine.", - "3": "Zusammen mit Svenja wären wir unschlagbar gewesen. Wir können gegenseitig unsere Sätze beenden!" - }, - "defeat": { - "1": "Meine Pokémon und ich sind siegreich.", - "2": "Wenn du mich nicht besiegen kannst, wirst du auch niemals Svenja besiegen können.", - "3": "All das verdanke ich meinem strengen Training mit Svenja. Meine Pokémon und ich sind eins." - } - }, - "liza": { - "encounter": { - "1": "Hihihi… Bist du überrascht, mich ohne meinen Bruder zu sehen?", - "2": "Ich kann sehen, wonach du verlangst… Du willst kämpfen, oder?", - "3": "Wie kannst du jemanden besiegen, der eins mit seinen Pokémon ist?" - }, - "victory": { - "1": "Ich kann es nicht ändern… Ich vermisse Ben…", - "2": "Das Band zwischen dir und deinen Pokémon ist stärker als meins.", - "3": "Zusammen mit Ben wären wir unschlagbar gewesen. Wir können gegenseitig unsere Sätze beenden!" - }, - "defeat": { - "1": "Meine Pokémon und ich sind siegreich.", - "2": "Wenn du mich nicht besiegen kannst, wirst du auch niemals Ben besiegen können.", - "3": "All das verdanke ich meinem strengen Training mit Ben. Meine Pokémon und ich sind eins." - } - }, - "juan": { - "encounter": { - "1": "Jetzt ist nicht die Zeit, schüchtern zu sein. Lass uns kämpfen!", - "2": "Ahahaha, Du wirst Zeuge meiner Kunstfertigkeit mit Wasser-Pokémon!", - "3": "Ein Taifun nähert sich! Wirst du mich testen können?", - "4": "Bitte, du wirst Zeuge unserer Kunstfertigkeit.\n$Eine großartige Illusion aus Wasser, die von meinen Pokémon und mir geschaffen wurde!" - }, - "victory": { - "1": "Du bist ein Genie, das Wasilli herausfordern kann!", - "2": "Ich habe mich auf Eleganz konzentriert, während du trainiert hast.\n$Es kein Wunder, dass du gewonnen hast.", - "3": "Ahahaha! Nun gut, dieses Mal hast du gewonnen.", - "4": "Ich spüre den Glanz deines Könnens, der alles überwinden wird." - }, - "defeat": { - "1": "Meine Pokémon und ich haben eine Illusion aus Wasser geschaffen und sind siegreich hervorgegangen.", - "2": "Ahahaha, Ich habe gewonnen, und du hast verloren.", - "3": "Soll ich dir mein Outfit leihen? Es könnte dir beim Kampf helfen! Ahahaha, ich scherze!", - "4": "Ich bin der Gewinner! Das heißt, du hast verloren." - } - }, - "crasher_wake": { - "encounter": { - "1": "Aufgepasst! Wellenbrecher Marinus… ist… da!", - "2": "Brechende Wellen! Ich bin Wellenbrecher Marinus!", - "3": "Ich bin die Flutwelle der Macht, die dich wegspült!" - }, - "victory": { - "1": "Das bringt ein Grinsen in mein Gesicht! Guhahaha! Das war ein Spaß!", - "2": "Hunwah! Es ist vorbei! Wie soll ich das sagen… Ich will mehr! Ich wollte viel mehr kämpfen!", - "3": "WAAAS?!" - }, - "defeat": { - "1": "Yeeeeah! So muss das sein!", - "2": "Ich habe gewonnen, aber ich will mehr! Ich wollte viel mehr kämpfen!", - "3": "Bis bald! Ich freue mich auf den nächsten Kampf!" - } - }, - "falkner": { - "encounter": { - "1": "Ich werde dir die wahre Kraft der prächtigen Flug-Pokémon zeigen!", - "2": "Winde, bleibt bei mir!", - "3": "Vater! Ich hoffe, du siehst mir beim Kampf von oben zu!" - }, - "victory": { - "1": "Ich verstehe… Ich werde mich anmutig zurückziehen.", - "2": "Eine Niederlage ist eine Niederlage. Du bist wirklich stark.", - "3": "…Verdammt! Ich habe verloren!" - }, - "defeat": { - "1": "Vater! Ich habe mit deinen geliebten Flug-Pokémon gewonnen…", - "2": "Flug-Pokémon sind die Besten!", - "3": "Ich habe das Gefühl, dass ich meinem Vater näher komme!" - } - }, - "nessa": { - "encounter": { - "1": "Egal, welchen Plan dein raffinierter Verstand auch schmiedet,\n$mein Partner und ich werden ihn mit Sicherheit zu Fall bringen.", - "2": "Ich bin nicht hier, um zu plaudern. Ich bin hier, um zu gewinnen!", - "3": "Das ist ein kleines Geschenk von meinen Pokémon… Ich hoffe, du kannst es annehmen!" - }, - "victory": { - "1": "Du und deine Pokémon sind einfach zu stark…", - "2": "Wie…? Wie kann das sein?", - "3": "Ich wurde total weggespült!" - }, - "defeat": { - "1": "Die wütenede Welle schlägt wieder zu!", - "2": "Es ist Zeit, die Welle des Sieges zu reiten!", - "3": "Ehehe!" - } - }, - "melony": { - "encounter": { - "1": "Ich halte mich nicht zurück!", - "2": "Okay, ich denke, wir sollten anfangen.", - "3": "Ich werde dich einfrieren!" - }, - "victory": { - "1": "Du… Du bist ziemlich gut, oder?", - "2": "Wenn du Mac triffst, haue ihn für mich um, ja?", - "3": "Ich denke, du hast 'das Eis brechen' ein wenig zu wörtlich genommen…" - }, - "defeat": { - "1": "Siehst du jetzt, wie ernst Kämpfe sein können?", - "2": "Hee! Es sieht so aus, als hätte ich wieder gewonnen!", - "3": "Hältst du dich zurück?" - } - }, - "marlon": { - "encounter": { - "1": "Du siehst stark aus! Los geht's!", - "2": "Ich bin stark wie das weite Meer. Du wirst weggespült, das ist sicher.", - "3": "Oh ho, ich treffe auf dich! Das ist abgefahren." - }, - "victory": { - "1": "Du hast total gerockt! Du ziehst einige krasse Pokémon groß. Du hast das Trainer-Ding drauf!", - "2": "Du siehst nicht nur stark aus, du bist auch stark! Eh, ich wurde auch weggespült!", - "3": "Du bist stark wie eine spektakuläre Welle!" - }, - "defeat": { - "1": "Du bist stark, aber nicht stark genug, um das Meer zu beeinflussen, 'OK!", - "2": "Hee! Sieht so aus, als hätte ich wieder gewonnen!", - "3": "Süßer, süßer Sieg!" - } - }, - "shauntal": { - "encounter": { - "1": "Entschuldigung. Du bist ein Herausforderer, oder?\nIch bin Anissa, die Geist-Pokémon-Nutzerin\n$der Top Vier. Ich werde dich in die Welt der Bücher entführen.", - "2": "Ich liebe es, über Trainer und deren Pokémon zu schreiben.\n$Könnte ich dich als Inspiration verwenden?", - "3": "Jeder, der mit Pokémon arbeitet, hat eine Geschichte zu erzählen. Welche Geschichte wird erzählt?" - }, - "victory": { - "1": "Wow. Ich bin sprachlos!", - "2": "E-entschuldigung! Zuerst muss ich mich bei meinen Pokémon entschuldigen…\n$Es tut mir wirklich leid, dass ihr wegen mir eine schlechte Erfahrung gemacht habt.", - "3": "Selbst in Anbetracht dessen, bin ich immer noch eine der Top Vier!" - }, - "defeat": { - "1": "Eheh.", - "2": "Das war exzellentes Material für meinen nächsten Roman!", - "3": "Und wenn sie nicht gestorben sind, dann leben sie noch heute…" - } - }, - "marshal": { - "encounter": { - "1": "Mein Mentor, Lauro, sieht Potential in dir. Ich werde dich testen,\n$dich an die Grenzen deiner Stärke bringen. Kiai!", - "2": "Ein Sieg, ein entscheidender Sieg, das ist mein Ziel! Herausforderer, hier komme ich!", - "3": "Ich selber suche die Stärke eines Kämpfers zu entwickeln und jede Schwäche in mir zu brechen!" - }, - "victory": { - "1": "Puh! Gut gemacht!", - "2": "Während deine Kämpfe weitergehen, strebe nach noch größeren Höhen!", - "3": "Die Stärke, die du und deine Pokémon gezeigt haben, hat mich tief beeindruckt..." - }, - "defeat": { - "1": "Hmm.", - "2": "Das war ein guter Kampf.", - "3": "Haaah! Haaah! Haiyaaaah!" - } - }, - "cheren": { - "encounter": { - "1": "Du erinnerst mich an einen alten Freund. Das macht mich gespannt auf diesen Pokémon-Kampf!", - "2": "Pokémon-Kämpfe haben keinen Sinn, wenn man nicht darüber nachdenkt, warum man kämpft.\n$Oder besser gesagt, es macht das Kämpfen mit Pokémon sinnlos.", - "3": "Ich heiße Cheren! Ich bin ein Arenaleiter und Lehrer! Freut mich, dich kennenzulernen." - }, - "victory": { - "1": "Danke! Ich habe gesehen, was mir gefehlt hat.", - "2": "Danke! Ich habe das Gefühl, ein Stück meines Ideals entdeckt zu haben.", - "3": "Hmm… Das ist problematisch." - }, - "defeat": { - "1": "Als Arenaleiter will ich eine Hürde für dich sein, die du überwinden musst.", - "2": "In Ordnung!", - "3": "Ich bin so weit gekommen, weil Pokémon an meiner Seite waren.\n$Vielleicht sollten wir darüber nachdenken, warum Pokémon uns helfen,\n$nicht als Pokémon und Trainer, sondern als Beziehung zwischen Lebewesen." - } - }, - "chili": { - "encounter": { - "1": "Jaaaa! Zeit, mit dem Feuer zu spielen! Ich bin der Stärkste von uns Brüdern!", - "2": "Ta-da! Der Feuer-Typ-Kämpfer Maik --das bin ich-- wird dein Gegner sein!", - "3": "Ich werde dir zeigen, was ich und meine feurigen Pokémon draufhaben!" - }, - "victory": { - "1": "Du hast mich besiegt. Ich bin... ausgebrannt...", - "2": "Whoa ho! Du brennst vor Energie!", - "3": "Autsch! Du hast mich erwischt!" - }, - "defeat": { - "1": "Ich brenne! Spiel mit mir, und du wirst dich verbrennen!", - "2": "Wenn du mit Feuer spielst, wirst du verbrannt!", - "3": "Ich meine, komm schon, dein Gegner war ich! Du hattest keine Chance!" - } - }, - "cilan": { - "encounter": { - "1": "Nichts Persönliches... Keine harten Gefühle... Ich und meine Pflanzen-Pokémon werden...\n$Ähm... Wir werden kämpfen, egal was passiert.", - "2": "Also, ähm, wenn es für dich in Ordnung ist, werde ich, ähm, alles geben, um, äh, dein Gegner zu sein.", - "3": "OK… Also, ähm, ich bin Benny, ich mag Pflanzen-Pokémon." - }, - "victory": { - "1": "Ähm… Ist es jetzt vorbei?", - "2": "…Was für eine Überraschung. Du bist sehr stark, nicht wahr? \n$Ich glaube, meine Brüder hätten dich auch nicht besiegen können…", - "3": "…Hmm. Sieht aus, als wäre mein Timing, ähm, schlecht gewesen?" - }, - "defeat": { - "1": "Huh? Habe ich gewonnen?", - "2": "Ich denke... Ich habe wohl gewonnen, weil ich mit meinen Brüdern Maik und Colin traniert habe,\n$und wir so alle stärker geworden sind.", - "3": "Es... es war ein ziemlich aufregendes Erlebnis..." - } - }, - "roark": { - "encounter": { - "1": "Ich muss dein Potenzial als Trainer und die Stärke der Pokémon sehen, die mit dir kämpfen!", - "2": "Los geht's! Dies sind meine Gesteins-Pokémon, mein ganzer Stolz!", - "3": "Gesteins-Pokémon sind einfach die besten!", - "4": "Tag für Tag grabe ich hier nach Fossilien.\n$Die viele Arbeit hat meine Pokémon felsenfest gemacht\nund das wirst du jetzt im Kampf zu spüren bekommen!" - }, - "victory": { - "1": "W-was? Das kann nicht sein! Meine total tranierten Pokémon!", - "2": "…Wir haben die Kontrolle verloren. Beim nächsten Mal fordere ich dich\n$zu einem Fossilien-Ausgrabungswettbewerb heraus.", - "3": "Mit deinem Können ist es nur natürlich, dass du gewinnst.", - "4": "W-was?! Das kann nicht sein! Selbst das war nicht genug?" - }, - "defeat": { - "1": "Siehst du? Ich bin stolz auf meinen steinigen Kampfstil!", - "2": "Danke! Der Kampf hat mir Vertrauen gegeben, dass ich vielleicht meinen Vater besiegen kann!", - "3": "Na, was sagst du jetzt? Meine felsenfesten Pokémon waren hart genug für dich, was?", - "4": "Ich wusste, dass ich gewinnen würde!" - } - }, - "morty": { - "encounter": { - "1": "Mit ein bisschen mehr könnte ich eine Zukunft sehen, in der ich das legendäre Pokémon treffe.\n$Du wirst mir helfen, dieses Level zu erreichen!", - "2": "Es heißt, dass ein regenbogenfarbenes Pokémon vor einem wirklich starken Trainer erscheinen wird.\n$Ich habe an diese Geschichte geglaubt, deshalb habe ich mein ganzes Leben lang heimlich trainiert.\n$Als Ergebnis kann ich jetzt Dinge sehen, die andere nicht sehen.\n$Ich sehe einen Schatten der Person, die das Pokémon erscheinen lassen wird.\n$Ich glaube, diese Person bin ich! Du wirst mir helfen, dieses Level zu erreichen!", - "3": "Ob du es glaubst oder nicht, mystische Kräfte existieren.", - "4": "Du kannst die Früchte meines Trainings bezeugen.", - "5": "Du musst deine Seele mit der eines Pokémon vereinen. Kannst du das?", - "6": "Sag mal, willst du an meinem Training teilnehmen?" - }, - "victory": { - "1": "Ich bin noch nicht gut genug...", - "2": "Ich sehe... Deine Reise hat dich an weit entfernte Orte geführt und du hast viel mehr gesehen als ich.\n$Ich beneide dich darum...", - "3": "Wie ist das möglich...", - "4": "Ich glaube nicht, dass unser Potenzial so unterschiedlich ist.\n$Aber du scheinst etwas mehr zu haben... Sei es drum.", - "5": "Ich brauche wohl mehr Training.", - "6": "Das ist schade." - }, - "defeat": { - "1": "Ich habe... einen weiteren Schritt nach vorne gemacht.", - "2": "Fufufu...", - "3": "W-was?! Das kann nicht sein! Selbst das war nicht genug?", - "4": "Ich fühle mich, als hätte ich gerade einen wirklich hartnäckigen Felsen durchbrochen!", - "5": "Ahahahah!", - "6": "Ich wusste, dass ich gewinnen würde!" - } - }, - "crispin": { - "encounter": { - "1": "Ich will gewinnen, also werde ich genau das tun!", - "2": "Ich kämpfe, weil ich kämpfen will! Und weißt du was? So sollte es sein!" - }, - "victory": { - "1": "Ich wollte gewinnen... aber ich habe verloren!", - "2": "Ich habe verloren... weil ich nicht gewinnen konnte!" - }, - "defeat": { - "1": "Hey, warte mal. Habe ich gerade gewonnen? Ich glaube, ich habe gewonnen! Das ist befriedigend!", - "2": "Wooo! Das war unglaublich!" - } - }, - "amarys": { - "encounter": { - "1": "Ich möchte jemandem helfen. Daher kann ich es mir nicht leisten, zu verlieren.\n$… Unser Kampf beginnt jetzt." - }, - "victory": { - "1": "Ich bin... nicht genug, wie ich sehe." - }, - "defeat": { - "1": "Der Sieg gehört mir. Gut gekämpft." - } - }, - "lacey": { - "encounter": { - "1": "Ich werde dir mit meinem gewohnten Team, als Mitglied der Top Vier gegenüberstehen." - }, - "victory": { - "1": "Das war ein großartiger Kampf!" - }, - "defeat": { - "1": "Geben wir deinem Pokémon einen kräftigen Applaus für ihre Bemühungen!" - } - }, - "drayton": { - "encounter": { - "1": "Mann, ich liebe Stühle. Liebst du nicht auch Stühle? Was für Lebensretter.\n$Ich verstehe nicht, warum nicht jeder einfach die ganze Zeit sitzt. Stehen ist anstrengend!" - }, - "victory": { - "1": "Ich hätte damit rechnen sollen!" - }, - "defeat": { - "1": "Heh heh! Macht nichts, ich habe hier nur einen Sieg eingefahren.\n$Ich verstehe, wenn du sauer bist, aber geh nicht völlig auf mich los, okay?" - } - }, - "ramos": { - "encounter": { - "1": "Hast du den Garten-Spielplatz genossen, den ich mit all diesen kräftigen Pflanzen angelegt habe?\n$Ihre Stärke ist ein Zeichen meiner Stärke als Gärtner und Arenaleiter! \n$Bist du sicher, dass du bereit bist, dich dem zu stellen?" - }, - "victory": { - "1": "Du glaubst an deine Pokémon... Und sie glauben an dich... Es war ein feiner Kampf, Sprössling." - }, - "defeat": { - "1": "Hohoho... In der Tat. Schwache kleine Grashalme brechen selbst durch Beton." - } - }, - "viola": { - "encounter": { - "1": "Ob es die Tränen der Frustration nach einer Niederlage sind\n$oder das Aufblühen der Freude nach einem Sieg...\n$Beides sind großartige Motive für meine Kamera! Fantastisch! Das wird einfach fantastisch!\n$Jetzt komm auf mich zu!", - "2": "Mein Objektiv ist immer auf den Sieg fokussiert - ich lasse mir diesen Moment nicht entgehen!" - }, - "victory": { - "1": "Du und deine Pokémon haben mir eine ganz neue Tiefenschärfe gezeigt! Einfach fantastisch!", - "2": "Die Welt, die du durch ein Objektiv siehst, und die Welt,\n$die du mit einem Pokémon an deiner Seite siehst...\n$Die gleiche Welt kann völlig anders aussehen, je nach Blickwinkel." - }, - "defeat": { - "1": "Das Foto vom Moment meines Sieges wird ein echter Gewinner sein!", - "2": "Ja! Ich habe einige großartige Fotos gemacht!" - } - }, - "candice": { - "encounter": { - "1": "Du willst Frida herausfordern? Klar! Ich habe auf jemanden Starken gewartet!\n$Aber ich sollte dir sagen, ich bin stark, weil ich weiß, wie man sich konzentriert.", - "2": "Pokémon, Mode, Romantik... Es geht alles um Konzentration!\n$Ich werde dir zeigen, was ich meine. Mach dich bereit zu verlieren!" - }, - "victory": { - "1": "Ich muss sagen, ich bin von dir angetan! Vielleicht bewundere ich dich sogar ein bisschen.", - "2": "Wow! Du bist großartig! Du hast meinen Respekt verdient!\n$Ich denke, dein Fokus und Wille haben uns völlig umgehauen." - }, - "defeat": { - "1": "Ich habe deinen Siegeswillen gespürt, aber ich verliere nicht!", - "2": "Siehst du? Fridas Fokus! Der Fokus meiner Pokémon ist auch großartig!" - } - }, - "gardenia": { - "encounter": { - "1": "Du hast eine Sieger-Aura. Also, das wird Spaß machen. Lass uns kämpfen!" - }, - "victory": { - "1": "Unglaublich! Du bist sehr gut, nicht wahr?" - }, - "defeat": { - "1": "Ja! Meine Pokémon und ich sind perfekt abgestimmt!" - } - }, - "aaron": { - "encounter": { - "1": "Okay! Lass mich gegen dich antreten!" - }, - "victory": { - "1": "Kämpfen ist eine tiefe und komplexe Angelegenheit..." - }, - "defeat": { - "1": "Ein Sieg über ein Mitglied der Top Vier ist nicht leicht zu erringen." - } - }, - "cress": { - "encounter": { - "1": "Das ist korrekt! Ich und meine geschätzten Wasser-Pokémon werden deine Gegner im Kampf sein!" - }, - "victory": { - "1": "Verlieren? Ich? Das glaube ich nicht." - }, - "defeat": { - "1": "Das ist das passende Ergebnis, wenn ich dein Gegner bin." - } - }, - "allister": { - "encounter": { - "1": "'N-Nio.\nH-hier… g-geht's los…" - }, - "victory": { - "1": "Ich hätte beinahe meine Maske vor Schock verloren... Das war...\n$Wow. Ich sehe dein Können, wie es wirklich ist." - }, - "defeat": { - "1": "D-das war klasse!" - } - }, - "clay": { - "encounter": { - "1": "Harrumph! Du hast mich warten lassen, oder? Gut, jetzt will ich sehen, was du drauf hast!" - }, - "victory": { - "1": "Mann oh Mann... Es fühlt sich gut an, alles zu geben und trotzdem besiegt zu werden!" - }, - "defeat": { - "1": "Was wichtig ist, ist wie du auf eine Niederlage reagierst.\n$Deshalb sind Leute, die Niederlagen als Ansporn nutzen, um besser zu werden, stark." - } - }, - "kofu": { - "encounter": { - "1": "Ich werde dir ein ganzes Menü aus Wasser-Pokémon servieren! Aber versuch nicht, sie zu essen!" - }, - "victory": { - "1": "Vaultin' Veluza! Du bist ein lebhafter Mensch, nicht wahr!\n$Ein bisschen ZU lebhaft, wenn ich das so sagen darf!" - }, - "defeat": { - "1": "Komm bald wieder zu mir, hörst du?" - } - }, - "tulip": { - "encounter": { - "1": "Erlaube mir, meine Fähigkeiten einzusetzen, um deine niedlichen kleinen Pokémon noch schöner zu machen!" - }, - "victory": { - "1": "Deine Stärke hat eine Magie, die nicht wegzuwaschen ist." - }, - "defeat": { - "1": "Weißt du, in meinem Beruf verschwinden Menschen,\n$die in einem Bereich kein Talent haben, oft schnell und werden nie wieder gesehen." - } - }, - "sidney": { - "encounter": { - "1": "Mir gefällt der Blick, den du mir zuwirfst. Ich denke, du wirst mir einen guten Kampf liefern.\n$Das ist gut! Sieht wirklich gut aus! In Ordnung!\n$Du und ich, lass uns einen Kampf genießen, der nur hier stattfinden kann!" - }, - "victory": { - "1": "Nun, wie gefällt dir das? Ich habe verloren! Eh, es hat Spaß gemacht, also ist es egal." - }, - "defeat": { - "1": "Wir sind hier nicht nachtragend, okay?" - } - }, - "phoebe": { - "encounter": { - "1": "Während meines Trainings habe ich die Fähigkeit erlangt, mit Geister-Pokémon zu kommunizieren.\n$Ja, die Bindung, die ich zu Pokémon entwickelt habe, ist extrem stark.\n$Also komm, versuche nur, meinen Pokémon Schaden zuzufügen!" - }, - "victory": { - "1": "Oh, Mist. Ich habe verloren." - }, - "defeat": { - "1": "Ich freue mich darauf, dich irgendwann wieder zu bekämpfen!" - } - }, - "glacia": { - "encounter": { - "1": "Alles, was ich gesehen habe, sind Herausforderungen von schwachen Trainern und ihren Pokémon.\n$Und du? Es würde mich überaus freuen, wenn ich gegen dich alles geben könnte!" - }, - "victory": { - "1": "Du und deine Pokémon… Wie heiß eure Geister brennen!\n$Die alles verzehrende Hitze überwältigt.\n$Es ist kein Wunder, dass meine eisigen Fähigkeiten dir nichts anhaben konnten." - }, - "defeat": { - "1": "Ein leidenschaftlicher Kampf, in der Tat." - } - }, - "drake": { - "encounter": { - "1": "Um mit Pokémon als Partner zu kämpfen, weißt du, was dafür nötig ist? Weißt du, was gebraucht wird?\n$Wenn nicht, wirst du nie gegen mich gewinnen!" - }, - "victory": { - "1": "Hervorragend, muss ich sagen." - }, - "defeat": { - "1": "Ich habe alles für diesen Kampf gegeben!" - } - }, - "wallace": { - "encounter": { - "1": "Da ist etwas an dir… Eine Veränderung in deinem Auftreten.\n$Ich denke, ich spüre das bei dir. Zeig es mir. Zeig mir die Kraft, die du mit deinen Pokémon hast.\n$Und ich werde dir im Gegenzug eine Vorstellung von\n$Illusionen im Wasser von mir und meinen Pokémon präsentieren!" - }, - "victory": { - "1": "Bravo. Ich erkenne jetzt deine Authentizität und Großartigkeit als Pokémon-Trainer.\n$Ich freue mich sehr, dich und deine Pokémon kennengelernt zu haben. Du hast dich als würdig erwiesen." - }, - "defeat": { - "1": "Eine große Illusion!" - } - }, - "lorelei": { - "encounter": { - "1": "Niemand kann mich bei eisigen Pokémon übertreffen! Gefrierende Angriffe sind mächtig!\n$Deine Pokémon werden mir ausgeliefert sein, wenn sie erst einmal eingefroren sind! Hahaha!\n$Bist du bereit?" - }, - "victory": { - "1": "Wie kannst du es wagen!" - }, - "defeat": { - "1": "Es gibt nichts, was du tun kannst, wenn du erst einmal eingefroren bist." - } - }, - "will": { - "encounter": { - "1": "Ich habe auf der ganzen Welt trainiert und meine Psycho-Pokémon stark gemacht.\n$Ich kann nur besser werden! Verlieren ist keine Option!" - }, - "victory": { - "1": "Ich... ich kann es nicht... glauben..." - }, - "defeat": { - "1": "Das war knapp. Ich frage mich, was dir fehlt." - } - }, - "malva": { - "encounter": { - "1": "Ich fühle mich, als könnte mein Herz in Flammen aufgehen.\n$Ich brenne vor Hass auf dich, Wicht!" - }, - "victory": { - "1": "Was für Neuigkeiten... Ein neuer Herausforderer hat Pachira besiegt!" - }, - "defeat": { - "1": "Ich bin begeistert! Ja, begeistert, dass ich dich unter meinen Fußsohlen zerquetschen konnte." - } - }, - "hala": { - "encounter": { - "1": "Der alte Hala ist hier, um dich zum Schreien zu bringen!" - }, - "victory": { - "1": "Ich konnte die Kraft spüren, die du auf deiner Reise gewonnen hast." - }, - "defeat": { - "1": "Haha! Was für ein erfreulicher Kampf!" - } - }, - "molayne": { - "encounter": { - "1": "Ich habe die Kapitänsposition meinem Cousin Chrys gegeben,\n$aber ich bin zuversichtlich in meine Fähigkeiten.\n$Meine Stärke ist wie die einer Supernova!" - }, - "victory": { - "1": "Ich habe sicherlich einen interessanten Trainer zum Kämpfen gefunden!" - }, - "defeat": { - "1": "Ahaha. Was für ein interessanter Kampf." - } - }, - "rika": { - "encounter": { - "1": "Ich würde sagen, ich werde es dir leicht machen, aber... das wäre gelogen! Denke schnell!" - }, - "victory": { - "1": "Nicht schlecht, wirklich!" - }, - "defeat": { - "1": "Nahahaha! Du bist wirklich etwas Besonderes!" - } - }, - "bruno": { - "encounter": { - "1": "Wir werden dich mit unserer überlegenen Kraft niederschmettern! Hoo hah!" - }, - "victory": { - "1": "Warum? Wie konnte ich verlieren?" - }, - "defeat": { - "1": "Du kannst mich herausfordern, so oft du willst, aber das Ergebnis wird sich nie ändern!" - } - }, - "bugsy": { - "encounter": { - "1": "Ich bin Kai, der Arenaleiter von Azalea City. Ich bin ein großer Fan von Käfer-Pokémon." - }, - "victory": { - "1": "Wow, erstaunlich! Du bist ein Experte für Pokémon!\n$Meine Forschung ist noch nicht abgeschlossen. OK, du gewinnst." - }, - "defeat": { - "1": "Danke! Dank unseres Kampfes konnte ich auch Fortschritte in meiner Forschung machen!" - } - }, - "koga": { - "encounter": { - "1": "Fwahahahaha! Pokémon sind nicht nur rohe Gewalt - das wirst du bald genug sehen!" - }, - "victory": { - "1": "Ah! Du hast deinen Wert bewiesen!" - }, - "defeat": { - "1": "Hast du gelernt, die Techniken der Ninja zu fürchten?" - } - }, - "bertha": { - "encounter": { - "1": "Nun, würdest du dieser alten Dame zeigen, wie viel du gelernt hast?" - }, - "victory": { - "1": "Nun! Liebes Kind, ich muss sagen, das war sehr beeindruckend.\n$Deine Pokémon haben an dich geglaubt und ihr Bestes gegeben, um dir den Sieg zu sichern.\n$Obwohl ich verloren habe, finde ich mich mit einem dummen Grinsen wieder!" - }, - "defeat": { - "1": "Hahahahah! Sieht so aus, als hätte diese alte Dame gewonnen!" - } - }, - "lenora": { - "encounter": { - "1": "Nun denn, Herausforderer, ich werde erforschen,\n$wie du mit den Pokémon kämpfst, die du so liebevoll aufgezogen hast!" - }, - "victory": { - "1": "Meine Theorie über dich war korrekt. Du bist mehr als nur talentiert... \n$Du bist motiviert! Ich salutier' dir!" - }, - "defeat": { - "1": "Ah ha ha! Wenn du verlierst, analysiere warum und nutze dieses Wissen im nächsten Kampf!" - } - }, - "siebold": { - "encounter": { - "1": "Solange ich lebe, werde ich danach streben, die ultimative Küche...\n$und die stärksten Gegner im Kampf zu finden!" - }, - "victory": { - "1": "Ich werde die Erinnerung an dich und deine Pokémon für immer in meinem Herzen bewahren." - }, - "defeat": { - "1": "Unser Pokémon-Kampf war wie Nahrung für meine Seele. Er wird mich weiter antreiben.\n$So werde ich dir meinen Respekt erweisen, dass du alles im Kampf gegeben hast!" - } - }, - "roxie": { - "encounter": { - "1": "Mach dich bereit! Ich werde dir den Verstand aus dem Kopf schlagen!" - }, - "victory": { - "1": "Wahnsinn! Deine Vernunft ist schon giftiger als meine!" - }, - "defeat": { - "1": "Hey, komm schon! Sei ernst! Du musst mehr geben!" - } - }, - "olivia": { - "encounter": { - "1": "Hier ist keine Einführung nötig. Zeit, gegen mich, Mayla, zu kämpfen!" - }, - "victory": { - "1": "Wirklich lieblich... Sowohl du als auch deine Pokémon..." - }, - "defeat": { - "1": "Mmm-hmm." - } - }, - "poppy": { - "encounter": { - "1": "Oooh! Willst du einen Pokémon-Kampf mit mir führen?" - }, - "victory": { - "1": "Uagh?! Mmmuuuggghhh..." - }, - "defeat": { - "1": "Jaaa! Ich hab's geschafft! Ich hab dich besiegt! Du kannst kommen für... Für... Einen Revanchekampf?\n$Komm jederzeit für einen Revanchekampf!" - } - }, - "agatha": { - "encounter": { - "1": "Pokémon sind zum Kämpfen da! Ich zeige dir, wie ein echter Trainer kämpft!" - }, - "victory": { - "1": "Oh mein Gott! Du bist etwas Besonderes, Kind!" - }, - "defeat": { - "1": "Bahaha. So wird ein richtiger Kampf geführt!" - } - }, - "flint": { - "encounter": { - "1": "Hoffentlich bist du aufgewärmt, denn hier kommt der Urknall!" - }, - "victory": { - "1": "Unglaublich! Deine Moves sind so heiß, dass meine im Vergleich lauwarm wirken!" - }, - "defeat": { - "1": "Huh? War das alles? Ich denke, du brauchst etwas mehr Leidenschaft." - } - }, - "grimsley": { - "encounter": { - "1": "Der Gewinner nimmt alles, und es bleibt nichts für den Verlierer." - }, - "victory": { - "1": "Wenn man verliert, verliert man alles... Das nächste, wonach ich suche, wird auch der Sieg sein!" - }, - "defeat": { - "1": "Wenn jemand gewinnt, verliert derjenige, der gegen diese Person gekämpft hat." - } - }, - "caitlin": { - "encounter": { - "1": "Ich bin es, die erschien, als die Blume sich öffnete. Du, der du gewartet hast…\n$Du siehst aus wie ein Pokémon-Trainer mit verfeinerter Stärke und vertiefter Freundlichkeit.\n$Was ich in meinem Gegner suche, ist überlegene Stärke…\n$Bitte entfessle deine Kraft in vollem Umfang!" - }, - "victory": { - "1": "Meine Pokémon und ich haben so viel gelernt! Ich danke dir." - }, - "defeat": { - "1": "Ich strebe danach, mit Eleganz und Anmut zu siegen." - } - }, - "diantha": { - "encounter": { - "1": "Gegen dich und deine Pokémon zu kämpfen, die alle voller Hoffnung für die Zukunft sind...\n$Ehrlich gesagt, es erfüllt mich mit der Energie, die ich brauche, um jeden neuen Tag anzugehen!\n$Wirklich!" - }, - "victory": { - "1": "Den edlen Geist von dir und deinen Pokémon im Kampf zu erleben, hat mein Herz wirklich berührt..." - }, - "defeat": { - "1": "Oh, fantastisch! Was denkst du? Mein Team war ziemlich cool, oder?" - } - }, - "wikstrom": { - "encounter": { - "1": "Guten Tag, junger Herausforderer! Wahrlich, ich bin die berühmte Klinge aus gehärtetem Stahl,\n$Herzog Thymelot! Lasst den Kampf beginnen! En garde!" - }, - "victory": { - "1": "Ruhmreich! Das Vertrauen, das du mit deinen ehrenvollen Pokémon teilst, übertrifft sogar meines!" - }, - "defeat": { - "1": "Was für eine Magie ist das? Mein Herz, es hämmert unaufhörlich in meiner Brust!\n$Gegen einen so würdigen Gegner zu gewinnen, verleiht meiner Seele Flügel - so fliege ich!" - } - }, - "acerola": { - "encounter": { - "1": "Kämpfen macht einfach Spaß! Komm schon, ich schaffe das!" - }, - "victory": { - "1": "Ich bin... sprachlos! Wie hast du das gemacht?!" - }, - "defeat": { - "1": "Ehaha! Was für ein erstaunlicher Sieg!" - } - }, - "larry_elite": { - "encounter": { - "1": "Hallo... Ich bin's, Aoki.\n$Ich bin auch Mitglied der Top Vier, ja... Leider für mich." - }, - "victory": { - "1": "Nun, das hat uns den Wind aus den Segeln genommen..." - }, - "defeat": { - "1": "Es ist Zeit für ein Treffen mit dem Boss." - } - }, - "lance": { - "encounter": { - "1": "Ich habe auf dich gewartet. Erlaube mir, deine Fähigkeiten zu testen.", - "2": "Ich dachte, du würdest es so weit schaffen. Lass uns anfangen." - }, - "victory": { - "1": "Du hast mich besiegt. Du bist großartig!", - "2": "Ich hätte nie erwartet, dass ein anderer Trainer mich schlägt... Ich bin überrascht." - }, - "defeat": { - "1": "Das war knapp. Willst du es nochmal versuchen?", - "2": "Es ist nicht so, dass du schwach bist. Lass dich davon nicht stören." - } - }, - "karen": { - "encounter": { - "1": "Ich bin Melanie. Möchtest du einen Kampf mit meinen Unlicht-Pokémon?", - "2": "Ich bin anders als die, die du bereits getroffen hast.", - "3": "Du hast ein charmantes Team zusammengestellt. Unser Kampf wird sicher gut." - }, - "victory": { - "1": "Nein! Ich kann nicht gewinnen. Wie bist du so stark geworden?", - "2": "Ich werde nicht von meinem gewählten Weg abweichen.", - "3": "Der Champion freut sich darauf, dich kennenzulernen." - }, - "defeat": { - "1": "Das habe ich erwartet.", - "2": "Nun, das war relativ unterhaltsam.", - "3": "Komm mich jederzeit besuchen." - } - }, - "milo": { - "encounter": { - "1": "Es scheint, als würdest du Pokémon wirklich gut verstehen.\n$Das wird ein harter Kampf!\n$Ich muss mein Pokémon Dynamaximieren, wenn ich gewinnen will!" - }, - "victory": { - "1": "Die Kraft des Grases ist verwelkt... Was für ein unglaublicher Herausforderer!" - }, - "defeat": { - "1": "Das wird dich wirklich schockieren und in Ehrfurcht versetzen." - } - }, - "lucian": { - "encounter": { - "1": "Einen Moment, bitte. Das Buch, das ich lese, hat fast seinen spannenden Höhepunkt erreicht...\n$Der Held hat ein mystisches Schwert erlangt und steht vor seiner letzten Prüfung... Ah, egal.\n$Da du es so weit geschafft hast, lege ich das beiseite und kämpfe gegen dich.\n$Lass mich sehen, ob du genauso viel Ruhm erlangen wirst wie der Held meines Buches!" - }, - "victory": { - "1": "Ich sehe... Es scheint, als hättest du mich schachmatt gesetzt." - }, - "defeat": { - "1": "Ich habe einen Ruf zu wahren." - } - }, - "drasna": { - "encounter": { - "1": "Du musst ein starker Trainer sein. Ja, ganz stark...\n$Das sind wunderbare Neuigkeiten! Gegen Gegner wie dich und dein Team zu kämpfen,\n$lässt meine Pokémon wie Unkraut wachsen!" - }, - "victory": { - "1": "Oh, meine Güte. Das war wirklich ein schneller Kampf... Ich hoffe, du kommst bald wieder!" - }, - "defeat": { - "1": "Wie kann das sein?" - } - }, - "kahili": { - "encounter": { - "1": "Also, da bist du… Warum sehen wir nicht, wen die Winde heute begünstigen, dich… oder mich?" - }, - "victory": { - "1": "Es frustriert mich als Mitglied der Top Vier, aber es scheint, dass deine Stärke echt ist." - }, - "defeat": { - "1": "Das war ein Ass!" - } - }, - "hassel": { - "encounter": { - "1": "Bereite dich darauf vor, aus erster Hand zu erfahren,\n$wie sich der feurige Atem eines erbitterten Kampfes anfühlt!" - }, - "victory": { - "1": "Das Glück hat mir dieses Mal gelächelt, aber...\n$Angesichts des Verlaufs des Kampfes, wer weiß, ob ich das nächste Mal so viel Glück haben werde." - }, - "defeat": { - "1": "Das war ein Ass!" - } - }, - "blue": { - "encounter": { - "1": "Du musst ziemlich gut sein, um so weit zu kommen." - }, - "victory": { - "1": "Ich habe nur gegen ihn und jetzt gegen dich verloren… Ihn? Haha..." - }, - "defeat": { - "1": "Siehst du? Meine Stärke hat mich hierher gebracht." - } - }, - "piers": { - "encounter": { - "1": "Mach dich bereit für einen Moshpit mit mir und meiner Truppe! Spikeford, es ist Zeit zu rocken!" - }, - "victory": { - "1": "Ich und mein Team haben unser Bestes gegeben. Lass uns irgendwann wieder zu einem Kampf treffen..." - }, - "defeat": { - "1": "Meine Kehle ist heiser vom Schreien... Aber das war ein aufregender Kampf!" - } - }, - "red": { - "encounter": { - "1": "…!" - }, - "victory": { - "1": "…?" - }, - "defeat": { - "1": "…!" - } - }, - "jasmine": { - "encounter": { - "1": "Oh... Deine Pokémon sind beeindruckend. Ich denke, ich werde das genießen." - }, - "victory": { - "1": "Du bist wirklich stark. Ich muss mich auch viel mehr anstrengen." - }, - "defeat": { - "1": "Ich habe nie erwartet zu gewinnen." - } - }, - "lance_champion": { - "encounter": { - "1": "Ich bin immer noch der Champion. Ich werde nichts zurückhalten." - }, - "victory": { - "1": "Dies ist das Aufkommen eines neuen Champions." - }, - "defeat": { - "1": "Ich habe meinen Titel erfolgreich verteidigt." - } - }, - "steven": { - "encounter": { - "1": "Erzähl mir... Was hast du auf deiner Reise mit deinen Pokémon gesehen?\n$Was hast du gefühlt, als du so viele andere Trainer getroffen hast?\n$Durch dieses reiche Land zu reisen... Hat es etwas in dir geweckt?\n$Ich möchte, dass du mir alles zeigst, was du gelernt hast.\n$Meine Pokémon und ich werden dir im Gegenzug mit allem antworten, was wir wissen!" - }, - "victory": { - "1": "Also falle ich, der Champion, in der Niederlage..." - }, - "defeat": { - "1": "Das war gut verbrachte Zeit! Danke!" - } - }, - "cynthia": { - "encounter": { - "1": "Ich, Cynthia, akzeptiere deine Herausforderung! Es wird keine Pause von mir geben!" - }, - "victory": { - "1": "Egal wie viel Spaß der Kampf macht, er wird irgendwann enden..." - }, - "defeat": { - "1": "Selbst wenn du verlierst, verliere niemals deine Liebe zu Pokémon." - } - }, - "iris": { - "encounter": { - "1": "Weißt du was? Ich freue mich wirklich darauf, ernsthafte Kämpfe mit starken Trainern zu führen!\n$Ich meine, komm schon! Die Trainer, die es hierher schaffen, sind Trainer,\n$die den Sieg mit jeder Faser ihres Seins anstreben!\n$Und sie kämpfen Seite an Seite mit Pokémon, die unzählige schwierige Kämpfe durchgemacht haben!\n$Wenn ich mit solchen Leuten kämpfe, werde nicht nur ich stärker, sondern auch meine Pokémon!\n$Und wir werden uns noch besser kennenlernen! OK! Mach dich bereit!\n$Ich bin Iris, die Champion der Pokémon-Liga, und ich werde dich besiegen!" - }, - "victory": { - "1": "Aghhhh... Ich habe mein Bestes gegeben, aber wir haben verloren..." - }, - "defeat": { - "1": "Juhu! Wir haben gewonnen!" - } - }, - "hau": { - "encounter": { - "1": "Ich frage mich, ob ein Trainer anders kämpft,\n$je nachdem, ob er aus einer warmen oder einer kalten Region stammt.\n$Lass es uns testen!" - }, - "victory": { - "1": "Das war großartig! Ich denke, ich verstehe dein Vibe jetzt ein bisschen besser!" - }, - "defeat": { - "1": "Ma-an, das war eine Art Kampf!" - } - }, - "geeta": { - "encounter": { - "1": "Ich habe mich entschieden, erneut meinen Hut in den Ring zu werfen.\n$Komm jetzt... Zeig mir die Früchte deines Trainings." - }, - "victory": { - "1": "Ich freue mich auf Neuigkeiten über all deine Erfolge!" - }, - "defeat": { - "1": "Was ist los? Das ist doch nicht alles, oder?" - } - }, - "nemona": { - "encounter": { - "1": "Yesss! Ich bin so aufgeregt! Zeit, dass wir uns austoben!" - }, - "victory": { - "1": "Na gut, das ist ärgerlich, aber ich hatte trotzdem Spaß! Ich werde dich nächstes Mal erwischen!" - }, - "defeat": { - "1": "Das war ein großartiger Kampf! Definitiv fruchtbar." - } - }, - "leon": { - "encounter": { - "1": "Wir werden eine absolut großartige Zeit haben!" - }, - "victory": { - "1": "Meine Zeit als Champion ist vorbei...\n$Aber was für eine großartige Zeit war das!\n$Danke für den großartigsten Kampf, den ich je hatte!" - }, - "defeat": { - "1": "Das war eine absolut großartige Zeit!" - } - }, - "whitney": { - "encounter": { - "1": "Hey! Findest du nicht auch, dass Pokémon total süß sind?" - }, - "victory": { - "1": "Waaah! Waaah! Du bist so gemein!" - }, - "defeat": { - "1": "Und das war's!" - } - }, - "chuck": { - "encounter": { - "1": "Ha! Du willst mich herausfordern? Bist du mutig oder einfach nur unwissend?" - }, - "victory": { - "1": "Du bist stark! Würdest du mich bitte zu deinem Schüler machen?" - }, - "defeat": { - "1": "Da. Merkst du, wie viel mächtiger ich bin als du?" - } - }, - "katy": { - "encounter": { - "1": "Lass deine Wachsamkeit nicht nach, es sei denn, du willst von den Füßen gerissen werden!" - }, - "victory": { - "1": "Alle meine süßen kleinen Pokémon fielen wie Fliegen!" - }, - "defeat": { - "1": "Iss auf, mein süßes kleines Vivillon!" - } - }, - "pryce": { - "encounter": { - "1": "Jugend allein garantiert keinen Sieg! Erfahrung ist, was zählt." - }, - "victory": { - "1": "Hervorragend! Das war perfekt. Versuche nicht zu vergessen, was du jetzt fühlst." - }, - "defeat": { - "1": "Genau wie ich es mir vorgestellt habe." - } - }, - "clair": { - "encounter": { - "1": "Weißt du, wer ich bin? Und du wagst es trotzdem, mich herauszufordern?" - }, - "victory": { - "1": "Ich frage mich, wie weit du mit deinem Können kommen wirst. Das sollte faszinierend sein." - }, - "defeat": { - "1": "Das war's." - } - }, - "maylene": { - "encounter": { - "1": "Ich bin gekommen, um dich jetzt herauszufordern, und ich werde nichts zurückhalten.\n$Bitte bereite dich auf den Kampf vor!" - }, - "victory": { - "1": "Ich gestehe die Niederlage ein..." - }, - "defeat": { - "1": "Das war großartig." - } - }, - "fantina": { - "encounter": { - "1": "Du wirst mich herausfordern, ja? Aber ich werde gewinnen.\n$Das tut der Arenaleiter von Herzhofen, non?" - }, - "victory": { - "1": "Du bist so fantastisch stark. Ich weiß, warum ich verloren habe." - }, - "defeat": { - "1": "Ich bin so, so, sehr glücklich!" - } - }, - "byron": { - "encounter": { - "1": "Trainer! Du bist jung, genau wie mein Sohn, Veit. \n$Mit mehr jungen Trainern, die das Kommando übernehmen, ist die Zukunft der Pokémon hell! \n$Also, als Hürde für junge Leute nehme ich deine Herausforderung an!" - }, - "victory": { - "1": "Hmm! Meine robusten Pokémon - besiegt!" - }, - "defeat": { - "1": "Gwahahaha! Wie waren meine robusten Pokémon?!" - } - }, - "olympia": { - "encounter": { - "1": "Ein alter Brauch entscheidet über das Schicksal. Der Kampf beginnt!" - }, - "victory": { - "1": "Schaffe deinen eigenen Weg. Lass dir nichts in den Weg stellen. Dein Schicksal, deine Zukunft." - }, - "defeat": { - "1": "Unser Weg ist jetzt klar." - } - }, - "volkner": { - "encounter": { - "1": "Da du so weit gekommen bist, musst du ziemlich stark sein…\n$Ich hoffe, du bist der Trainer, der mich daran erinnert, wie viel Spaß es macht zu kämpfen!" - }, - "victory": { - "1": "Du hast mich besiegt…\n$Dein Verlangen und die edle Art, wie deine Pokémon für dich gekämpft haben…\n$Ich habe mich sogar während unseres Kampfes begeistert gefühlt. Das war ein sehr guter Kampf." - }, - "defeat": { - "1": "Es war überhaupt nicht schockierend…\n$Das ist nicht das, was ich wollte!" - } - }, - "burgh": { - "encounter": { - "1": "M'hm… Wenn ich diesen Kampf gewinne, habe ich das Gefühl,\n$dass ich ein Bild malen kann, das es so noch nie gegeben hat.\n$OK! Ich höre meine Kampf-Muse laut und deutlich. Lass uns gleich loslegen!", - "2": "Natürlich bin ich wirklich stolz auf all meine Pokémon! \n$Nun, dann... Lass uns gleich loslegen!" - }, - "victory": { - "1": "Ist es vorbei? Hat mich meine Muse verlassen?", - "2": "Hmm… Es ist vorbei! Du bist unglaublich!" - }, - "defeat": { - "1": "Wow… Irgendwie ist es doch schön, nicht wahr?", - "2": "Manchmal höre ich Leute sagen, es war ein hässlicher Sieg. \n$Ich denke, wenn du dein Bestes gibst, ist jeder Sieg schön." - } - }, - "elesa": { - "encounter": { - "1": "C'est fini! Wenn ich mir dessen sicher bin,\n$fühle ich einen elektrischen Stoß durch meinen Körper laufen!\n$Ich möchte dieses Gefühl erleben, also werden meine geliebten Pokémon\n$jetzt deinen Kopf zum Drehen bringen!" - }, - "victory": { - "1": "Ich wollte deinen Kopf zum Drehen bringen, aber du hast mich schockiert." - }, - "defeat": { - "1": "Das war irgendwie unbefriedigend… Wirst du nächstes Mal alles geben?" - } - }, - "skyla": { - "encounter": { - "1": "Es ist endlich Zeit für ein Duell! Das bedeutet den Pokémon-Kampf,\n$der entscheidet, wer an der Spitze steht, richtig? \n$Ich liebe es, auf dem Gipfel zu stehen! Weil man von hohen Orten aus für immer und ewig sehen kann! \n$Also, wie wäre es, wenn wir beide Spaß haben?" - }, - "victory": { - "1": "Dein Gegner im Kampf zu sein, ist eine neue Kraftquelle für mich. Danke!" - }, - "defeat": { - "1": "Gewinnen oder verlieren, man lernt immer etwas aus einem Kampf, richtig?" - } - }, - "brycen": { - "encounter": { - "1": "Es gibt auch Stärke darin, mit anderen Menschen und Pokémon zusammen zu sein. \n$Ihre Unterstützung zu erhalten, macht dich stärker. Ich werde dir diese Kraft zeigen!" - }, - "victory": { - "1": "Die wunderbare Kombination aus dir und deinen Pokémon! Was für eine schöne Freundschaft!" - }, - "defeat": { - "1": "Extreme Bedingungen testen und trainieren dich wirklich!" - } - }, - "drayden": { - "encounter": { - "1": "Was ich finden möchte, ist ein junger Trainer, der mir eine helle Zukunft zeigen kann.\n$Lass uns mit allem kämpfen, was wir haben: dein Können, meine Erfahrung und die Liebe,\n$mit der wir unsere Pokémon großgezogen haben!" - }, - "victory": { - "1": "Dieses intensive Gefühl, das mich nach einer Niederlage überkommt…\n$Ich weiß nicht, wie ich es beschreiben soll." - }, - "defeat": { - "1": "Harrumph! Ich weiß, dass deine Fähigkeit größer ist als das!" - } - }, - "grant": { - "encounter": { - "1": "Es gibt nur eine Sache, die ich mir wünsche. \n$Dass wir, indem wir einander übertreffen, einen Weg zu noch größeren Höhen finden." - }, - "victory": { - "1": "Du bist eine Mauer, die ich nicht überwinden kann!" - }, - "defeat": { - "1": "Gib nicht auf.\n$Das ist wirklich alles, was es dazu gibt.\n$Die wichtigsten Lektionen im Leben sind einfach." - } - }, - "korrina": { - "encounter": { - "1": "Zeit für Lady Connies großen Auftritt!" - }, - "victory": { - "1": "Es ist dein Wesen, das es deinen Pokémon ermöglicht, sich zu entwickeln!" - }, - "defeat": { - "1": "Was für ein explosiver Kampf!" - } - }, - "clemont": { - "encounter": { - "1": "Oh! Ich bin froh, dass wir uns getroffen haben!" - }, - "victory": { - "1": "Deine Leidenschaft für den Kampf inspiriert mich!" - }, - "defeat": { - "1": "Es sieht so aus, als würde meine Trainer-Wachstumsmaschine, Mach 2, wirklich funktionieren!" - } - }, - "valerie": { - "encounter": { - "1": "Oh, wenn das nicht ein junger Trainer ist… Es ist schön, dich so zu treffen.\n$Dann nehme ich an, du hast dir das Recht auf einen Kampf verdient, als Belohnung für deine Bemühungen.\n$Die schwer fassbare Fee mag zart wie eine Brise und empfindlich wie eine Blüte erscheinen,\n$aber sie ist stark." - }, - "victory": { - "1": "Ich hoffe, dass du morgen Dinge finden wirst, über die du lächeln kannst…" - }, - "defeat": { - "1": "Oh mein Gott, wie schade…" - } - }, - "wulfric": { - "encounter": { - "1": "Weißt du was? Wir reden alle groß über das, was man vom Kämpfen und von Bindungen lernt und all das…\n$Aber eigentlich mache ich es nur, weil es Spaß macht. \n$Wen kümmert das Prahlen? Lass uns kämpfen!" - }, - "victory": { - "1": "Hervorragend! Ich bin so hart wie ein Eisberg, aber du hast mich komplett durchschlagen!" - }, - "defeat": { - "1": "Kämpfe mit mir, und das passiert!" - } - }, - "kabu": { - "encounter": { - "1": "Jeder Trainer und jedes Pokémon trainiert hart, um den Sieg zu erringen.\n$Aber das bedeutet, dass auch dein Gegner hart arbeitet, um zu gewinnen.\n$Am Ende wird das Match von der Seite entschieden, die ihr wahres Potenzial entfesseln kann." - }, - "victory": { - "1": "Ich bin froh, dass ich heute gegen dich kämpfen konnte!" - }, - "defeat": { - "1": "Das ist eine großartige Möglichkeit für mich, mein eigenes Wachstum zu spüren!" - } - }, - "bea": { - "encounter": { - "1": "Hast du einen unerschütterlichen Geist, der sich nicht bewegt, egal wie du angegriffen wirst? \n$Ich denke, ich werde das einfach mal testen, oder?" - }, - "victory": { - "1": "Ich habe den Kampfgeist deiner Pokémon gespürt, als du sie in den Kampf geführt hast." - }, - "defeat": { - "1": "Das war die beste Art von Match, die man sich je wünschen kann." - } - }, - "opal": { - "encounter": { - "1": "Lass mich sehen, wie du und dein Partner-Pokémon euch verhalten!" - }, - "victory": { - "1": "Dein Rosa fehlt noch, aber du bist ein ausgezeichneter Trainer mit ausgezeichneten Pokémon." - }, - "defeat": { - "1": "Schade für dich, denke ich." - } - }, - "bede": { - "encounter": { - "1": "Ich nehme an, ich sollte zweifelsfrei beweisen, wie erbärmlich du bist und wie stark ich bin." - }, - "victory": { - "1": "Ich verstehe... Nun, das ist in Ordnung. Ich habe mich sowieso nicht wirklich angestrengt." - }, - "defeat": { - "1": "Nicht schlecht, muss ich sagen." - } - }, - "gordie": { - "encounter": { - "1": "Also, lass uns das hinter uns bringen." - }, - "victory": { - "1": "Ich möchte einfach in ein Loch kriechen... Nun, ich denke, es wäre eher wie ein Sturz von hier." - }, - "defeat": { - "1": "Kämpfe wie immer, der Sieg wird folgen!" - } - }, - "marnie": { - "encounter": { - "1": "Die Wahrheit ist, am Ende des Tages... Ich möchte wirklich nur Champion für mich selbst werden!\n$Also nimm es nicht persönlich, wenn ich dir den Hintern versohle!" - }, - "victory": { - "1": "OK, ich habe verloren... Aber ich habe viele gute Seiten von dir und deinen Pokémon gesehen!" - }, - "defeat": { - "1": "Ich hoffe, du hast unsere Kampfstrategien genossen." - } - }, - "raihan": { - "encounter": { - "1": "Ich werde den Champion besiegen, das ganze Turnier gewinnen und der Welt beweisen,\n$wie stark der großartige Roy wirklich ist!" - }, - "victory": { - "1": "Ich sehe sogar gut aus, wenn ich verliere.\n$Es ist ein echter Fluch.\n$Ich denke, es ist Zeit für ein weiteres Selfie!" - }, - "defeat": { - "1": "Lass uns ein Selfie zur Erinnerung machen." - } - }, - "brassius": { - "encounter": { - "1": "Ich nehme an, du bist bereit? Lassen wir unser gemeinsames Kunstwerk beginnen!" - }, - "victory": { - "1": "Ahhh... avant-garde!" - }, - "defeat": { - "1": "Ich werde sofort mit einem neuen Stück beginnen!" - } - }, - "iono": { - "encounter": { - "1": "Hey, Leute! Es ist Zeit für Enigmaras EnigmaTV!!! Naaaa, alles klärchen?\n$Hola, ciao und hallöle! Und schon bist du gefangen in meinem Elektronetz!\n$Wer ich bin, fragst du? Na, Enigmara natürlich! Ich bin hier die Arenaleiterin." - }, - "victory": { - "1": "Du leuchtest ja so hell wie ein tausendfacher Donnerblitz!" - }, - "defeat": { - "1": "Deine Augen gehören MIR!" - } - }, - "larry": { - "encounter": { - "1": "Wenn alles gesagt und getan ist, ist Einfachheit am stärksten." - }, - "victory": { - "1": "Eine Portion Niederlage, hm?" - }, - "defeat": { - "1": "Ich mache Schluss für heute." - } - }, - "ryme": { - "encounter": { - "1": "Komm schon, Baby! Bring mich zum Zittern bis auf die Knochen!" - }, - "victory": { - "1": "Du bist cool, mein Freund - du bewegst meine SEELE!" - }, - "defeat": { - "1": "Bis später, Baby!" - } - }, - "grusha": { - "encounter": { - "1": "Alles, was ich tun muss, ist sicherzustellen, dass die Kraft meiner Pokémon dich bis auf die Knochen kühlt!" - }, - "victory": { - "1": "Deine brennende Leidenschaft... Ich mag sie ehrlich gesagt irgendwie." - }, - "defeat": { - "1": "Es hat nicht für dich gereicht." - } - }, - "marnie_elite": { - "encounter": { - "1": "Du hast es so weit geschafft, hm? Mal sehen, ob du mit meinen Pokémon umgehen kannst!", - "2": "Ich werde mein Bestes geben, aber denke nicht, dass ich es dir leicht machen werde!" - }, - "victory": { - "1": "Ich kann nicht glauben, dass ich verloren habe... Aber du hast den Sieg verdient. Gut gemacht!", - "2": "Es sieht so aus, als hätte ich noch viel zu lernen. Toller Kampf trotzdem!" - }, - "defeat": { - "1": "Du hast gut gekämpft, aber ich habe den Vorteil! Viel Glück beim nächsten Mal!", - "2": "Es scheint, als hätte sich mein Training ausgezahlt. Danke für den Kampf!" - } - }, - "nessa_elite": { - "encounter": { - "1": "Die Gezeiten wenden sich zu meinen Gunsten. Bereit, weggespült zu werden?", - "2": "Lass uns mit diesem Kampf Wellen schlagen! Ich hoffe, du bist vorbereitet!" - }, - "victory": { - "1": "Du hast diese Gewässer perfekt navigiert... Gut gemacht!", - "2": "Es sieht so aus, als wären meine Strömungen kein Match für dich. Tolle Arbeit!" - }, - "defeat": { - "1": "Wasser findet immer einen Weg. Das war ein erfrischender Kampf!", - "2": "Du hast gut gekämpft, aber die Macht des Ozeans ist unaufhaltsam!" - } - }, - "bea_elite": { - "encounter": { - "1": "Bereite dich vor! Mein Kampfgeist brennt hell!", - "2": "Mal sehen, ob du mit meinem unaufhaltsamen Tempo mithalten kannst!" - }, - "victory": { - "1": "Deine Stärke... Sie ist beeindruckend. Du hast diesen Sieg wirklich verdient.", - "2": "Ich habe diese Intensität noch nie zuvor gespürt. Unglaubliche Leistung!" - }, - "defeat": { - "1": "Ein weiterer Sieg für mein intensives Trainingsprogramm! Gut gemacht!", - "2": "Du hast Stärke, aber ich habe härter trainiert. Toller Kampf!" - } - }, - "allister_elite": { - "encounter": { - "1": "Die Schatten fallen... Bist du bereit, dich deinen Ängsten zu stellen?", - "2": "Mal sehen, ob du mit der Dunkelheit, die ich befehle, umgehen kannst." - }, - "victory": { - "1": "Du hast die Schatten vertrieben... Für jetzt. Gut gemacht.", - "2": "Dein Licht hat meine Dunkelheit durchdrungen. Tolle Leistung." - }, - "defeat": { - "1": "Die Schatten haben gesprochen... Deine Stärke reicht nicht aus.", - "2": "Die Dunkelheit triumphiert... Vielleicht wirst du nächstes Mal das Licht sehen." - } - }, - "raihan_elite": { - "encounter": { - "1": "Ein Sturm zieht auf! Mal sehen, ob du diesen Kampf überstehst!", - "2": "Mach dich bereit, dem Auge des Sturms zu begegnen!" - }, - "victory": { - "1": "Du hast den Sturm bezwungen... Unglaubliche Leistung!", - "2": "Du hast die Winde perfekt geritten... Toller Kampf!" - }, - "defeat": { - "1": "Ein weiterer Sturm überstanden, ein weiterer Sieg errungen! Gut gekämpft!", - "2": "Du bist in meinen Sturm geraten! Viel Glück beim nächsten Mal!" - } - }, - "alder": { - "encounter": { - "1": "Mach dich bereit für einen Kampf gegen den stärksten Trainer in Einall! Mich - Lauro!" - }, - "victory": { - "1": "Gut gemacht! Du hast wirklich ein unvergleichliches Talent." - }, - "defeat": { - "1": "Ein frischer Wind weht durch mein Herz...\n$Was für ein außergewöhnliches Gefühl!" - } - }, - "kieran": { - "encounter": { - "1": "Durch harte Arbeit werde ich immer stärker und stärker!\n$Ich verliere nicht." - }, - "victory": { - "1": "Ich kann es nicht glauben...\n$Was für ein lustiger und herzzerreißender Kampf!" - }, - "defeat": { - "1": "Wow, was für ein Kampf!\n$Es ist Zeit für dich, noch härter zu trainieren." - } - }, - "rival": { - "encounter": { - "1": "@c{smile}Hey, ich habe dich gesucht! Ich weiß, dass du es nicht erwarten konntest loszugehen,\n$aber hättest ja wenigstens Tschüss sagen können...\n$@c{smile_eclosed}Du verfolgst also wirklich deinen Traum?\nIch kann es kaum glauben.\n$@c{serious_smile_fists}Da wir schon einmal hier sind, wie wäre es mit einem Kampf?\nImmerhin muss ich doch sicherstellen, dass du bereit bist.\n$@c{serious_mopen_fists}Halte dich nicht zurück, zeig mir alles was du hast!" - }, - "victory": { - "1": "@c{shock}Wow…Du hast mich komplett überrumpelt.\nBist du wirklich ein Anfänger?\n$@c{smile}Vielleicht war es einfach etwas Glück, aber…\nWer weiß, vielleicht schaffst du es irgendwann\n$ja wirklich ganz groß raus zu kommen.\n$Übrigens, der Professor hat mich gebeten dir diese Items zu geben. Die sehen wirklich cool aus.\n$@c{serious_smile_fists}Viel Glück da draußen!" - } - }, - "rival_female": { - "encounter": { - "1": "@c{smile_wave}Da bist du! Ich habe schon überall nach dir gesucht!\n@c{angry_mopen}Hast du etwas vergessen\n$deiner besten Freundin Tschüss zu sagen?\n$@c{smile_ehalf}Du folgst deinem Traum, oder?\nDas ist wirklich heute…\n$@c{smile}Naja, ich vergeben dir, dass du mich vergessen hast, aber nur unter einer Bedingung. @c{smile_wave_wink}Du musst gegen mich kämpfen!\n$@c{angry_mopen}Gib alles! Wir wollen doch nicht, dass dein Abenteuer endet bevor es begonnen hat, richtig?" - }, - "victory": { - "1": "@c{shock}Du hast gerade erst angefangen und bist schon so stark?!@d{96} @c{angry}Du hast sowas von betrogen, oder?\n$@c{smile_wave_wink}Ich mach nur Spaß!@d{64} @c{smile_eclosed}Ich habe ehrlich verloren… Ich habe das Gefühl, dass du es dort draußen weit bringen wirst.\n$@c{smile}Übrigens, der Professor hat mich gebeten dir diese Items zu geben. Ich hoffe sie sind hilfreich!\n$@c{smile_wave}Gib wie immer dein Bestes! Ich glaube an dich!" - } - }, - "rival_2": { - "encounter": { - "1": "@c{smile}Hey, du auch hier?\n@c{smile_eclosed}Immernoch ungeschlagen, hmm…?\n$@c{serious_mopen_fists}Ich weiß es sieht so aus, als wäre ich dir hierher gefolgt, aber das ist so nicht ganz richtig.\n$@c{serious_smile_fists}Ehrlicherweise kann ich es, seit du mich damals besiegt hast, garnicht erwarten erneut gegen dich zu kämpfen.\n$Ich habe selbst hart traniert. Ich werde dir diesesmal also ein würdigerer Gegner sein!.\n$@c{serious_mopen_fists}Halt dich nicht zurück, genauso wie beim letzten Mal!\nLos gehts!" - }, - "victory": { - "1": "@c{neutral_eclosed}Oh. Ich war also zu sehr von mir überzeugt.\n$@c{smile}Das ist Ok. Ich hatte mir schon gedacht, dass sowas passiert.\n\n$@c{serious_mopen_fists}Es bedeutet einfach, dass ich mich beim nächsten Mal mehr anstrengen muss!\n\n$@c{smile}Nicht, dass du wirklich Hilfe benötigen würdest, aber ich habe hier noch eins von diesen Dingern herumliegen.\n$Du kannst es haben.\n\n$@c{serious_smile_fists}Erwarte aber nicht, dass ich dir noch mehr gebe!\nIch kann meinen Rivalen doch keine Vorteile verschaffen.\n$@c{smile}Egal, pass auf dich auf!" - } - }, - "rival_2_female": { - "encounter": { - "1": "@c{smile_wave}Oh, wie schön dich hier zu trefen. Sieht so aus als wärst du noch ungeschlagen. @c{angry_mopen}Hmm… Nicht schlecht!\n$@c{angry_mopen}Ich weiß was du denkst, und nein, ich habe dich nicht verfolgt. @c{smile_eclosed}Ich bin einfach in der Gegend gewesen.\n$@c{smile_ehalf}Ich freu mich für dich, aber ich muss dich wissen lassen, dass es auch Ok ist ab und zu mal zu verlieren.\n$@c{smile}Wir lernen oft mehr aus unseren Fehlern, als aus unseren Erfolgen.\n$@c{angry_mopen}Auf jeden Fall habe ich für unseren Rückkampf hart traniert. Also zeig mir was du drauf hast!" - }, - "victory": { - "1": "@c{neutral}Ich… sollte dieses Mal doch nicht verlieren…\n$@c{smile}Na gut. Das bedeutet ich muss noch härter tranieren!\n$@c{smile_wave}Ich habe noch eins von diesen Dingern!\n@c{smile_wave_wink}Kein Grund mir zu danken~.\n$@c{angry_mopen}Das ist aber das Letzte! Du bekommst ab jett keine Geschenke mehr von mir!\n$@c{smile_wave}Bleib stark!" - }, - "defeat": { - "1": "Es ist Ok manchmal zu verlieren…" - } - }, - "rival_3": { - "encounter": { - "1": "@c{smile}Hey, schau mal wen wir hier haben! Ist schon eine Weile her.\n@c{neutral}Du bist… immernoch ungeschlagen?\n$@c{neutral_eclosed}Die Dinge waren irgendwie... seltsam.\nEs ist Zuhause einfach nicht das Gleiche ohne dich.\n$@c{serious}Ich weiß es ist selbstsüchtig, aber ich musste das einfach mal loswerden.\n$@c{neutral_eclosed}Denkst du nicht, dass du dich etwas übernommen hast?\n$@c{serious}Es ist nicht realistisch immer zu gewinnen\nWir müssen manchmal verlieren. Um daran zu wachsen.\n$@c{neutral_eclosed}Du hattest einen guten Lauf, aber es liegt noch so viel vor dir. Es wird nicht gerade einfacher. @c{neutral}Bist du bereit dafür?\n$@c{serious_mopen_fists}Falls ja, beweise es mir!" - }, - "victory": { - "1": "@c{angry_mhalf}Das ist doch Schwachsinn… Ich habe kaum aufgehört zu tranieren…\n$Warum bin ich immernoch so viel schwächer?" - } - }, - "rival_3_female": { - "encounter": { - "1": "@c{smile_wave}Lange nicht gesehen! Immernoch nicht verloren?\n@c{angry}Du fängst mich an zu nerven. @c{smile_wave_wink}Ich mach nur Spaß!\n$@c{smile_ehalf}Aber ehrlich, vermisst du dein Zuhause garnicht? Oder mich?\n$Ich… Ich meine, wir vermissen dich wirklich.\n$@c{smile_eclosed}Ich unterstütze dich bei deinem Traum, aber die Realität ist, du wirst früher oder später verlieren.\n$@c{smile}Und ich bin für dich da falls du es tust, wie immer.\n@c{angry_mopen}Also, zeig mir wie stark du geworden bist!" - }, - "victory": { - "1": "@c{shock}Nach allem was ich getan habe… war es immernoch nicht genug…?\n$Wenn es so weiter geht hole ich nie auf…" - }, - "defeat": { - "1": "Du hast dein Bestes gegeben. Lass uns nach Hause gehen." - } - }, - "rival_4": { - "encounter": { - "1": "@c{neutral}Hey.\n$Ich werde jetzt keine Gefälligkeiten mit dir austauschen.\n@c{neutral_eclosed}Ich bin hier um zu gewinnen. Mehr nicht.\n$@c{serious_mhalf_fists}Durch mein Traning habe ich gelernt mein Potenzial zu maximieren.\n$@c{smile}Man hat deutlich mehr Zeit, wenn man auf Schlaf und unnötige soziale Interaktionen verzichtet. \n$@c{serious_mopen_fists}Das ist alles nicht mehr wichtig, nicht solange ich nicht gewonnen habe.\n$@c{neutral_eclosed}Ich bin an dem Punkt an dem ich nicht mehr verliere.\n@c{smile_eclosed}Ich schätze deine Einstellung war doch nicht so falsch.\n$@c{angry_mhalf}Nur die Schwachen verlieren, und ich bin nicht mehr schwach.\n$@c{serious_mopen_fists}Bereite dich vor zu verlieren." - }, - "victory": { - "1": "@c{neutral}Was…@d{64} Was bist du?" - } - }, - "rival_4_female": { - "encounter": { - "1": "@c{neutral}Ich bins! Du hast mich doch nicht vergessen, oder?\n$@c{smile}Du solltest stolz auf dich sein. Du hast es soweit gebracht. Glückwunsch!\n$Aber hier endet deine Reise jetzt.\n$@c{smile_eclosed}Du hast etwas in mir erwachen lassen, etwas von dem ich nicht wusste, dass es da war.\n$Alles was ich jetzt mache ist tranieren. @c{smile_ehalf}Ich esse oder schlafe kaum. \n$Ich traniere meine Pokémon den ganzen Tag. Und werde immer stärker.\n$@c{neutral}Genau genommen, erkenne ich mich garnicht wieder.\n$Und jetzt habe ich endlich meinen Höhepunkt erreicht.\nNiemand kann mich jetzt noch schlagen.\n$Und weißt du was? Das ist alles wegen dir.\n@c{smile_ehalf}Ich weiß nicht ob ich dir danken, oder dich hassen soll!\n$@c{angry_mopen}Mach dich bereit!" - }, - "victory": { - "1": "@c{neutral}Was…@d{64} Was bist du?" - }, - "defeat": { - "1": "$@c{smile}Du solltest stolz darauf sein wie weit du es geschafft hast." - } - }, - "rival_5": { - "encounter": { - "1": "@c{neutral}…" - }, - "victory": { - "1": "@c{neutral}…" - } - }, - "rival_5_female": { - "encounter": { - "1": "@c{neutral}…" - }, - "victory": { - "1": "@c{neutral}…" - }, - "defeat": { - "1": "$@c{smile_ehalf}…" - } - }, - "rival_6": { - "encounter": { - "1": "@c{smile_eclosed}So sehen wir uns wieder.\n$@c{neutral}Ich hatte Zeit über alles nachzudenken.\nÜber den Grund, warum alles so merkwürdig erscheint.\n$@c{neutral_eclosed}Dein Traum, mein Antrieb dich besiegen zu wollen…\nEs ist alles Teil von etwas Größerem.\n$@c{serious}Es geht nicht um dich, oder mich… Es geht um diese Welt.\n@c{serious_mhalf_fists}Es ist mein Schicksal dich an deine Grenzen zu treiben.\n$@c{neutral_eclosed}Ob ich meine Aufgabe erfüllt habe kann ich nicht sagen, aber ich habe alles getan was ich konnte.\n$@c{neutral}Der Ort an dem wir uns befinden ist angsteinflößend… \n$Trotzdem fühlt es sich so an, als würde mich das nicht stören, als wäre ich bereits schonmal hier gewesen.\n$@c{serious_mhalf_fists}Dir geht es doch genauso, oder?\n$@c{serious}…und irgendwas hier spricht zu mir.\nDas ist alles was die Welt seit langem kennt.\n$Die Zeiten die wir zusammen verbracht haben, die so nah erscheinen, sind nichts als eine ferne Erinnerung.\n$@c{neutral_eclosed}Wer weiß, ob sie jemals real waren?\n$@c{serious_mopen_fists}Du musst weiter gehen, denn wenn du es nicht tust, wird es nie enden. Du bist der Einzige, der das schaffen kann.\n$@c{serious_smile_fists}Ich… Ich weiß nicht was das alles bedeutet, aber ich fühle, dass es wahr ist.\n$@c{serious_mopen_fists}Wenn du mich nicht hier und jetzt besiegen kannst, hast du keine Chance." - }, - "victory": { - "1": "@c{smile_eclosed}Es sieht so aus, als wäre meine Arbeit getan.\n$Ich will dass du mir eine Sache versprichst.\n@c{smile}Komm bitte nach Hause nachdem du die Welt gerettet hast." - } - }, - "rival_6_female": { - "encounter": { - "1": "@c{smile_ehalf}Jetzt sind es wieder nur wir zwei.\n$@c{smile_eclosed}Weißt du, egal wie ich es drehe und wende…\n$@c{smile_ehalf}Irgendwas stört mich an der ganzen Sache, es erscheint mir irgendwie komisch…\n$@c{smile}Du hast deinen Traum, und ich habe diesen Antrieb…\n$Ich kann nicht anders, als zu glauben, dass es einen größeren Zweck gibt.\n$@c{smile_eclosed}Ich denke, ich sollte dich an deine Grenzen treiben.\n$@c{smile_ehalf}Ich bin mir nicht sicher, ob ich meine Aufgabe erfüllt habe, aber ich habe mein Bestes gegeben.\n$Irgendwas an diesem komischen und furchteinflößenden Ort… All das scheint so klar…\n$Es… ist alles was die Welt seit langem kennt.\n$@c{smile_eclosed}Es kommt mir so vor als könnte ich mich kaum an die Erinnerungen erinnern, die wir zusammen hatten.\n$@c{smile_ehalf}Waren sie jemals real? Sie scheinen so weit weg…\n$@c{angry_mopen}Du musst weiter gehen, denn wenn du es nicht tust, wird es nie enden. Du bist der Einzige, der das schaffen kann.\n$@c{smile_ehalf}Ich… Ich weiß nicht was das alles bedeutet, aber ich fühle, dass es wahr ist.\n$@c{neutral}Wenn du mich nicht hier und jetzt besiegen kannst, hast du keine Chance." - }, - "victory": { - "1": "@c{smile_ehalf}Ich… Ich denke ich habe meine Aufgabe erfüllt.\n$@c{smile_eclosed}Versprich mir… Nachdem du die Welt geheilt hast… Komm bitte sicher nach Hause. \n$@c{smile_ehalf}…Danke." - } - } -} diff --git a/src/locales/de/egg.json b/src/locales/de/egg.json deleted file mode 100644 index dbece7e81f3..00000000000 --- a/src/locales/de/egg.json +++ /dev/null @@ -1,26 +0,0 @@ -{ - "egg": "Ei", - "greatTier": "Selten", - "ultraTier": "Episch", - "masterTier": "Legendär", - "defaultTier": "Gewöhnlich", - "hatchWavesMessageSoon": "Man kann schon etwas hören! Es wird wohl bald schlüpfen!", - "hatchWavesMessageClose": "Manchmal bewegt es sich! Es braucht wohl noch ein Weilchen.", - "hatchWavesMessageNotClose": "Was wird da wohl schlüpfen? Es wird sicher noch lange dauern.", - "hatchWavesMessageLongTime": "Dieses Ei braucht sicher noch sehr viel Zeit.", - "gachaTypeLegendary": "Erhöhte Chance auf legendäre Eier.", - "gachaTypeMove": "Erhöhte Chance auf Eier mit seltenen Attacken.", - "gachaTypeShiny": "Erhöhte Chance auf schillernde Eier.", - "selectMachine": "Wähle eine Maschine.", - "notEnoughVouchers": "Du hast nicht genug Ei-Gutscheine!", - "tooManyEggs": "Du hast schon zu viele Eier!", - "pull": "Pull", - "pulls": "Pulls", - "sameSpeciesEgg": "{{species}} wird aus dem Ei schlüpfen!", - "hatchFromTheEgg": "Ein {{pokemonName}} ist aus dem Ei geschlüpft!", - "eggMoveUnlock": "Ei-Attacke freigeschaltet: {{moveName}}", - "rareEggMoveUnlock": "Seltene Ei-Attacke freigeschaltet: {{moveName}}", - "moveUPGacha": "Mehr\nEi-Attacken!", - "shinyUPGacha": "Mehr\nSchillernde!", - "legendaryUPGacha": "erscheint\nöfter!" -} \ No newline at end of file diff --git a/src/locales/de/fight-ui-handler.json b/src/locales/de/fight-ui-handler.json deleted file mode 100644 index f803375e8de..00000000000 --- a/src/locales/de/fight-ui-handler.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "pp": "AP", - "power": "Stärke", - "accuracy": "Genauigkeit", - "abilityFlyInText": "{{passive}}{{abilityName}} von {{pokemonName}} wirkt!", - "passive": "Passive Fähigkeit ", - "teraHover": "Tera-Typ {{type}}" -} \ No newline at end of file diff --git a/src/locales/de/filter-bar.json b/src/locales/de/filter-bar.json deleted file mode 100644 index ebfeaa6a00e..00000000000 --- a/src/locales/de/filter-bar.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "genFilter": "Gen.", - "typeFilter": "Typ", - "caughtFilter": "Gefangen", - "unlocksFilter": "Freisch.", - "miscFilter": "Sonst.", - "sortFilter": "Sort.", - "all": "Alle", - "normal": "Normal", - "uncaught": "Nicht gefangen", - "passive": "Passive", - "passiveUnlocked": "Passive freigeschaltet", - "passiveLocked": "Passive gesperrt", - "passiveUnlockable": "Passive - Freischalten möglich", - "costReduction": "Kostenreduzierung", - "costReductionUnlocked": "Kosten bereits reduziert", - "costReductionLocked": "Kosten noch nicht reduziert", - "costReductionUnlockable": "Kosten können reduziert werden", - "favorite": "Favorit", - "isFavorite": "Favorit - Ja", - "notFavorite": "Favorit - Nein", - "ribbon": "Band", - "hasWon": "Hat Klassik-Modus gewonnen", - "hasNotWon": "Hat Klassik-Modus nicht gewonnen", - "hiddenAbility": "Versteckte Fähigkeit", - "hasHiddenAbility": "Versteckte Fähigkeit - Ja", - "noHiddenAbility": "Versteckte Fähigkeit - Nein", - "egg": "Ei", - "eggPurchasable": "Kauf möglich", - "pokerus": "Pokérus", - "hasPokerus": "Pokérus - Ja", - "noPokerus": "Pokérus - Nein", - "sortByNumber": "Pokédex-Nummer", - "sortByCost": "Kosten", - "sortByCandies": "Anzahl Bonbons", - "sortByIVs": "IS-Werte", - "sortByName": "Name" -} \ No newline at end of file diff --git a/src/locales/de/game-mode.json b/src/locales/de/game-mode.json deleted file mode 100644 index 214ee156b7b..00000000000 --- a/src/locales/de/game-mode.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "classic": "Klassik", - "endless": "Endlos", - "endlessSpliced": "Endlos (Fusion)", - "dailyRun": "Täglicher Run", - "unknown": "Unbekannt", - "challenge": "Herausforderung" -} \ No newline at end of file diff --git a/src/locales/de/game-stats-ui-handler.json b/src/locales/de/game-stats-ui-handler.json deleted file mode 100644 index f52c31e2ee8..00000000000 --- a/src/locales/de/game-stats-ui-handler.json +++ /dev/null @@ -1,42 +0,0 @@ -{ - "stats": "Statistiken", - "playTime": "Spielzeit", - "totalBattles": "Kämpfe insgesamt", - "starters": "Starter", - "shinyStarters": "Schillernde Starter", - "speciesSeen": "Gesehene Arten", - "speciesCaught": "Gefangene Arten", - "ribbonsOwned": "Bänder im Besitz", - "classicRuns": "Klassik-Modus Versuche", - "classicWins": "Klassik-Modus Siege", - "dailyRunAttempts": "Täglicher-Modus Versuche", - "dailyRunWins": "Täglicher-Modus Siege", - "endlessRuns": "Endlos-Modus Versuche", - "highestWaveEndless": "Höchste Welle (Endlos)", - "highestMoney": "Max. Geld im Besitz", - "highestDamage": "Höchster Schaden", - "highestHPHealed": "Höchste Heilung", - "pokemonEncountered": "Getroffene Pokémon", - "pokemonDefeated": "Besiegte Pokémon", - "pokemonCaught": "Gefangene Pokémon", - "eggsHatched": "Ausgebrütete Eier", - "subLegendsSeen": "Getroffene Sub-Legenden", - "subLegendsCaught": "Gefangene Sub-Legenden", - "subLegendsHatched": "Ausgebrütete Sub-Legenden", - "legendsSeen": "Getroffene Legenden", - "legendsCaught": "Gefangene Legenden", - "legendsHatched": "Ausgebrütete Legenden", - "mythicalsSeen": "Getroffene Mythische", - "mythicalsCaught": "Gefangene Mythische", - "mythicalsHatched": "Ausgebrütete Mythische", - "shiniesSeen": "Getroffene Schillernde", - "shiniesCaught": "Gefangene Schillernde", - "shiniesHatched": "Ausgebrütete Schillernde", - "pokemonFused": "Pokémon fusioniert", - "trainersDefeated": "Besiegte Trainer", - "eggsPulled": "Gezogene Eier", - "rareEggsPulled": "Seltene Eier Gezogen", - "epicEggsPulled": "Epische Eier Gezogen", - "legendaryEggsPulled": "Legendäre Eier Gezogen", - "manaphyEggsPulled": "Manaphy Eier Gezogen" -} \ No newline at end of file diff --git a/src/locales/de/growth.json b/src/locales/de/growth.json deleted file mode 100644 index 9f5f17f363c..00000000000 --- a/src/locales/de/growth.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "Erratic": "Unregelmäßig", - "Fast": "Schnell", - "Medium_Fast": "Schneller", - "Medium_Slow": "Langsamer", - "Slow": "Langsam", - "Fluctuating": "Schwankend" -} \ No newline at end of file diff --git a/src/locales/de/menu-ui-handler.json b/src/locales/de/menu-ui-handler.json deleted file mode 100644 index 93c3f4c38e8..00000000000 --- a/src/locales/de/menu-ui-handler.json +++ /dev/null @@ -1,30 +0,0 @@ -{ - "GAME_SETTINGS": "Spieleinstellungen", - "ACHIEVEMENTS": "Erfolge", - "STATS": "Statistiken", - "RUN_HISTORY": "Laufhistorie", - "EGG_LIST": "Eierliste", - "EGG_GACHA": "Eier-Gacha", - "MANAGE_DATA": "Daten verwalten", - "COMMUNITY": "Community", - "SAVE_AND_QUIT": "Speichern und Beenden", - "LOG_OUT": "Abmelden", - "slot": "Slot {{slotNumber}}", - "importSession": "Sitzung importieren", - "importSlotSelect": "Wähle einen Slot zum Importieren.", - "exportSession": "Sitzung exportieren", - "exportSlotSelect": "Wähle einen Slot zum Exportieren.", - "importRunHistory": "Laufhistorie importieren", - "exportRunHistory": "Laufhistorie exportieren", - "importData": "Daten importieren", - "exportData": "Daten exportieren", - "consentPreferences": "Einwilligungspräferenzen", - "linkDiscord": "Discord verbinden", - "unlinkDiscord": "Discord trennen", - "linkGoogle": "Google verbinden", - "unlinkGoogle": "Google trennen", - "cancel": "Abbrechen", - "losingProgressionWarning": "Du wirst jeglichen Fortschritt seit Anfang dieses Kampfes verlieren. Fortfahren?", - "noEggs": "Du brütest aktuell keine Eier aus!", - "donate": "Spenden" -} \ No newline at end of file diff --git a/src/locales/de/menu.json b/src/locales/de/menu.json deleted file mode 100644 index 0e2ba4dc0b3..00000000000 --- a/src/locales/de/menu.json +++ /dev/null @@ -1,57 +0,0 @@ -{ - "cancel": "Abbrechen", - "continue": "Fortfahren", - "dailyRun": "Täglicher Run (Beta)", - "loadGame": "Spiel laden", - "newGame": "Neues Spiel", - "settings": "Einstellungen", - "selectGameMode": "Wähle einen Spielmodus", - "logInOrCreateAccount": "Melde dich an oder erstelle einen Account zum starten. Keine Email nötig!", - "username": "Benutzername", - "password": "Passwort", - "login": "Anmelden", - "orUse": "Oder nutze", - "register": "Registrieren", - "emptyUsername": "Benutzername darf nicht leer sein.", - "invalidLoginUsername": "Der eingegebene Benutzername ist ungültig.", - "invalidRegisterUsername": "Benutzername darf nur Buchstaben, Zahlen oder Unterstriche enthalten.", - "invalidLoginPassword": "Das eingegebene Passwort ist ungültig.", - "invalidRegisterPassword": "Passwort muss 6 Zeichen oder länger sein.", - "usernameAlreadyUsed": "Der eingegebene Benutzername wird bereits verwendet.", - "accountNonExistent": "Der eingegebene Benutzer existiert nicht.", - "unmatchingPassword": "Das eingegebene Passwort stimmt nicht überein.", - "passwordNotMatchingConfirmPassword": "Passwort muss mit Bestätigungspasswort übereinstimmen.", - "confirmPassword": "Bestätige Passwort", - "registrationAgeWarning": "Mit der Registrierung bestätigen Sie, dass Sie 13 Jahre oder älter sind.", - "backToLogin": "Zurück zur Anmeldung", - "failedToLoadSaveData": "Speicherdaten konnten nicht geladen werden. Bitte laden Sie die Seite neu.\nÜberprüfe den #announcements-Kanal im Discord bei anhaltenden Problemen.", - "sessionSuccess": "Sitzung erfolgreich geladen.", - "failedToLoadSession": "Ihre Sitzungsdaten konnten nicht geladen werden.\nSie könnten beschädigt sein.", - "boyOrGirl": "Bist du ein Junge oder ein Mädchen?", - "evolving": "Nanu?\n{{pokemonName}} entwickelt sich!", - "stoppedEvolving": "Hm? {{pokemonName}} hat die Entwicklung \nabgebrochen.", - "pauseEvolutionsQuestion": "Die Entwicklung von {{pokemonName}} vorübergehend pausieren?\nEntwicklungen können im Gruppenmenü wieder aktiviert werden.", - "evolutionsPaused": "Entwicklung von {{pokemonName}} pausiert.", - "evolutionDone": "Glückwunsch!\nDein {{pokemonName}} entwickelte sich zu {{evolvedPokemonName}}!", - "dailyRankings": "Tägliche Rangliste", - "weeklyRankings": "Wöchentliche Rangliste", - "noRankings": "Keine Rangliste", - "positionIcon": "#", - "usernameScoreboard": "Benutzername", - "score": "Punkte", - "wave": "Welle", - "loading": "Lade…", - "loadingAsset": "Lade Asset: {{assetName}}", - "playersOnline": "Spieler Online", - "yes": "Ja", - "no": "Nein", - "disclaimer": "HAFTUNGSAUSSCHLUSS", - "disclaimerDescription": "Dieses Spiel ist ein unfertiges Produkt. Es kann spielbeinträchtigende Fehler (bis hin zum Verlust des Speicherstandes)\n aufweisen, sich ohne Vorankündigung ändern und es gibt keine Garantie dass es weiterentwickelt oder fertiggestellt wird.", - "choosePokemon": "Wähle ein Pokémon.", - "renamePokemon": "Pokémon umbennenen", - "rename": "Umbenennen", - "nickname": "Spitzname", - "errorServerDown": "Ups! Es gab einen Fehler beim Versuch\nden Server zu kontaktieren\nLasse dieses Fenster offen\nDu wirst automatisch neu verbunden.", - "noSaves": "Du hast keine gespeicherten Dateien!", - "tooManySaves": "Du hast zu viele gespeicherte Dateien!" -} diff --git a/src/locales/de/modifier-select-ui-handler.json b/src/locales/de/modifier-select-ui-handler.json deleted file mode 100644 index 3de1222c3b4..00000000000 --- a/src/locales/de/modifier-select-ui-handler.json +++ /dev/null @@ -1,12 +0,0 @@ -{ - "transfer": "Übertragen", - "reroll": "Neu rollen", - "lockRarities": "Seltenheit festsetzen", - "checkTeam": "Team überprüfen", - "transferDesc": "Übertrage ein gehaltenes Item zu einem anderen Pokémon.", - "rerollDesc": "Nutze Geld um die Items neu zu rollen.", - "lockRaritiesDesc": "Setze die Seltenheit der Items fest. (Beeinflusst die Rollkosten).", - "checkTeamDesc": "Überprüfe dein Team or nutze Formänderungsitems.", - "rerollCost": "{{formattedMoney}}₽", - "itemCost": "{{formattedMoney}}₽" -} \ No newline at end of file diff --git a/src/locales/de/modifier-type.json b/src/locales/de/modifier-type.json deleted file mode 100644 index 7c7972343d6..00000000000 --- a/src/locales/de/modifier-type.json +++ /dev/null @@ -1,607 +0,0 @@ -{ - "ModifierType": { - "AddPokeballModifierType": { - "name": "{{modifierCount}}x {{pokeballName}}", - "description": "Erhalte {{pokeballName}} x{{modifierCount}}. (Inventar: {{pokeballAmount}}) \nFangrate: {{catchRate}}" - }, - "AddVoucherModifierType": { - "name": "{{modifierCount}}x {{voucherTypeName}}", - "description": "Erhalte {{voucherTypeName}} x{{modifierCount}}." - }, - "PokemonHeldItemModifierType": { - "extra": { - "inoperable": "{{pokemonName}} kann dieses\nItem nicht nehmen!", - "tooMany": "{{pokemonName}} hat zu viele\nvon diesem Item!" - } - }, - "PokemonHpRestoreModifierType": { - "description": "Füllt {{restorePoints}} KP oder {{restorePercent}}% der KP für ein Pokémon auf. Je nachdem, welcher Wert höher ist.", - "extra": { - "fully": "Füllt die KP eines Pokémon wieder vollständig auf.", - "fullyWithStatus": "Füllt die KP eines Pokémon wieder vollständig auf und behebt alle Statusprobleme." - } - }, - "PokemonReviveModifierType": { - "description": "Belebt ein kampunfähiges Pokémon wieder und stellt {{restorePercent}}% KP wieder her." - }, - "PokemonStatusHealModifierType": { - "description": "Behebt alle Statusprobleme eines Pokémon." - }, - "PokemonPpRestoreModifierType": { - "description": "Füllt {{restorePoints}} AP der ausgewählten Attacke eines Pokémon auf.", - "extra": { - "fully": "Füllt alle AP der ausgewählten Attacke eines Pokémon auf." - } - }, - "PokemonAllMovePpRestoreModifierType": { - "description": "Stellt {{restorePoints}} AP für alle Attacken eines Pokémon auf.", - "extra": { - "fully": "Füllt alle AP für alle Attacken eines Pokémon auf." - } - }, - "PokemonPpUpModifierType": { - "description": "Erhöht die maximale Anzahl der AP der ausgewählten Attacke um {{upPoints}} für jede 5 maximale AP (maximal 3)." - }, - "PokemonNatureChangeModifierType": { - "name": "{{natureName}} Minze", - "description": "Ändert das Wesen zu {{natureName}}. Schaltet dieses Wesen permanent für diesen Starter frei." - }, - "DoubleBattleChanceBoosterModifierType": { - "description": "Vervierfacht die Chance, dass ein Kampf ein Doppelkampf wird, für bis zu {{battleCount}} Kämpfe." - }, - "TempStatStageBoosterModifierType": { - "description": "Erhöht {{stat}} aller Teammitglieder um {{amount}} für bis zu 5 Kämpfe.", - "extra": { - "stage": "eine Stufe", - "percentage": "30%" - } - }, - "AttackTypeBoosterModifierType": { - "description": "Erhöht die Stärke aller {{moveType}}-Attacken eines Pokémon um 20%." - }, - "PokemonLevelIncrementModifierType": { - "description": "Erhöht das Level eines Pokémon um {{levels}}." - }, - "AllPokemonLevelIncrementModifierType": { - "description": "Erhöht das Level aller Teammitglieder um {{levels}}." - }, - "BaseStatBoosterModifierType": { - "description": "Erhöht den {{stat}} Basiswert des Trägers um 10%. Das Stapellimit erhöht sich, je höher dein IS-Wert ist." - }, - "AllPokemonFullHpRestoreModifierType": { - "description": "Stellt 100% der KP aller Pokémon her." - }, - "AllPokemonFullReviveModifierType": { - "description": "Belebt alle kampunfähigen Pokémon wieder und stellt ihre KP vollständig wieder her." - }, - "MoneyRewardModifierType": { - "description": "Gewährt einen {{moneyMultiplier}} Geldbetrag von (₽{{moneyAmount}}).", - "extra": { - "small": "kleinen", - "moderate": "moderaten", - "large": "großen" - } - }, - "ExpBoosterModifierType": { - "description": "Erhöht die erhaltenen Erfahrungspunkte um {{boostPercent}}%." - }, - "PokemonExpBoosterModifierType": { - "description": "Erhöht die Menge der erhaltenen Erfahrungspunkte für den Träger um {{boostPercent}}%." - }, - "PokemonFriendshipBoosterModifierType": { - "description": "Erhöht den Freundschaftszuwachs pro Sieg um 50%." - }, - "PokemonMoveAccuracyBoosterModifierType": { - "description": "Erhöht die Genauigkeit der Angriffe um {{accuracyAmount}} (maximal 100)." - }, - "PokemonMultiHitModifierType": { - "description": "Attacken treffen ein weiteres mal mit einer Reduktion von 60/75/82,5% der Stärke." - }, - "TmModifierType": { - "name": "TM{{moveId}} - {{moveName}}", - "description": "Bringt einem Pokémon {{moveName}} bei." - }, - "TmModifierTypeWithInfo": { - "name": "TM{{moveId}} - {{moveName}}", - "description": "Bringt einem Pokémon {{moveName}} bei\n(Halte C oder Shift für mehr Infos)." - }, - "EvolutionItemModifierType": { - "description": "Erlaubt es bestimmten Pokémon sich zu entwickeln." - }, - "FormChangeItemModifierType": { - "description": "Erlaubt es bestimmten Pokémon ihre Form zu ändern." - }, - "FusePokemonModifierType": { - "description": "Fusioniert zwei Pokémon (überträgt die Fähigkeit, teilt Basiswerte und Typ auf, gemeinsamer Attackenpool)." - }, - "TerastallizeModifierType": { - "name": "{{teraType}} Terra-Stück", - "description": "{{teraType}} Terakristallisiert den Träger für bis zu 10 Kämpfe." - }, - "ContactHeldItemTransferChanceModifierType": { - "description": "Beim Angriff besteht eine {{chancePercent}}%ige Chance, dass das getragene Item des Gegners gestohlen wird." - }, - "TurnHeldItemTransferModifierType": { - "description": "Jede Runde erhält der Träger ein getragenes Item des Gegners." - }, - "EnemyAttackStatusEffectChanceModifierType": { - "description": "Fügt Angriffen eine {{chancePercent}}%ige Chance hinzu, {{statusEffect}} zu verursachen." - }, - "EnemyEndureChanceModifierType": { - "description": "Gibt den Träger eine {{chancePercent}}%ige Chance, einen Angriff zu überleben." - }, - "RARE_CANDY": { - "name": "Sonderbonbon" - }, - "RARER_CANDY": { - "name": "Supersondererbonbon" - }, - "MEGA_BRACELET": { - "name": "Mega-Armband", - "description": "Mega-Steine werden verfügbar." - }, - "DYNAMAX_BAND": { - "name": "Dynamax-Band", - "description": "Dyna-Pilze werden verfügbar." - }, - "TERA_ORB": { - "name": "Terakristall-Orb", - "description": "Tera-Stücke werden verfügbar." - }, - "MAP": { - "name": "Karte", - "description": "Ermöglicht es dir, an einer Kreuzung dein Ziel zu wählen." - }, - "POTION": { - "name": "Trank" - }, - "SUPER_POTION": { - "name": "Supertrank" - }, - "HYPER_POTION": { - "name": "Hypertrank" - }, - "MAX_POTION": { - "name": "Top-Trank" - }, - "FULL_RESTORE": { - "name": "Top-Genesung" - }, - "REVIVE": { - "name": "Beleber" - }, - "MAX_REVIVE": { - "name": "Top-Beleber" - }, - "FULL_HEAL": { - "name": "Hyperheiler" - }, - "SACRED_ASH": { - "name": "Zauberasche" - }, - "REVIVER_SEED": { - "name": "Belebersamen", - "description": "Belebt den Träger mit der Hälfte seiner KP wieder, sollte er durch einen direkten Treffer kampfunfähig werden." - }, - "WHITE_HERB": { - "name": "Schlohkraut", - "description": "Ein Item zum Tragen. Es hebt einmalig jede negative Statuswertveränderung auf." - }, - "ETHER": { - "name": "Äther" - }, - "MAX_ETHER": { - "name": "Top-Äther" - }, - "ELIXIR": { - "name": "Elixir" - }, - "MAX_ELIXIR": { - "name": "Top-Elixir" - }, - "PP_UP": { - "name": "AP-Plus" - }, - "PP_MAX": { - "name": "AP-Top" - }, - "LURE": { - "name": "Lockparfüm" - }, - "SUPER_LURE": { - "name": "Super-Lockparfüm" - }, - "MAX_LURE": { - "name": "Top-Lockparfüm" - }, - "MEMORY_MUSHROOM": { - "name": "Erinnerungspilz", - "description": "Lässt ein Pokémon eine vergessene Attacke wiedererlernen." - }, - "EXP_SHARE": { - "name": "EP-Teiler", - "description": "Pokémon, die nicht am Kampf teilgenommen haben, bekommen 20% der Erfahrungspunkte eines Kampfteilnehmers." - }, - "EXP_BALANCE": { - "name": "EP-Ausgleicher", - "description": "Gewichtet die in Kämpfen erhaltenen Erfahrungspunkte auf niedrigstufigere Gruppenmitglieder." - }, - "OVAL_CHARM": { - "name": "Ovalpin", - "description": "Wenn mehrere Pokémon am Kampf teilnehmen, erhählt jeder von ihnen 10% extra Erfahrungspunkte." - }, - "EXP_CHARM": { - "name": "EP-Pin" - }, - "SUPER_EXP_CHARM": { - "name": "Super-EP-Pin" - }, - "GOLDEN_EXP_CHARM": { - "name": "Goldener EP-Pin" - }, - "LUCKY_EGG": { - "name": "Glücks-Ei" - }, - "GOLDEN_EGG": { - "name": "Goldenes Ei" - }, - "SOOTHE_BELL": { - "name": "Sanftglocke" - }, - "SCOPE_LENS": { - "name": "Scope-Linse", - "description": "Ein Item zum Tragen. Es erhöht die Volltrefferquote." - }, - "DIRE_HIT": { - "name": "X-Volltreffer", - "extra": { - "raises": "Volltrefferquote" - } - }, - "LEEK": { - "name": "Lauchstange", - "description": "Ein Item, das von Porenta getragen werden kann. Diese lange Lauchstange erhöht die Volltrefferquote stark." - }, - "EVIOLITE": { - "name": "Evolith", - "description": "Ein mysteriöser Klumpen, der die Vert. u. Spez.-Vert. von Pokémon erhöht, die sich noch entwickeln können." - }, - "SOUL_DEW": { - "name": "Seelentau", - "description": "Erhöht den Einfluss des Wesens eines Pokemon auf seine Werte um 10% (additiv)." - }, - "NUGGET": { - "name": "Nugget" - }, - "BIG_NUGGET": { - "name": "Riesennugget" - }, - "RELIC_GOLD": { - "name": "Alter Dukat" - }, - "AMULET_COIN": { - "name": "Münzamulett", - "description": "Erhöht das Preisgeld um 20%." - }, - "GOLDEN_PUNCH": { - "name": "Goldschlag", - "description": "Gewährt Geld in Höhe von 50% des zugefügten Schadens." - }, - "COIN_CASE": { - "name": "Münzkorb", - "description": "Erhalte nach jedem 10ten Kampf 10% Zinsen auf dein Geld." - }, - "LOCK_CAPSULE": { - "name": "Tresorkapsel", - "description": "Erlaubt es die Seltenheitsstufe der Items festzusetzen wenn diese neu gerollt werden." - }, - "GRIP_CLAW": { - "name": "Griffklaue" - }, - "WIDE_LENS": { - "name": "Großlinse" - }, - "MULTI_LENS": { - "name": "Mehrfachlinse" - }, - "HEALING_CHARM": { - "name": "Heilungspin", - "description": "Erhöht die Effektivität von Heilungsattacken sowie Heilitems um 10% (Beleber ausgenommen)." - }, - "CANDY_JAR": { - "name": "Bonbonglas", - "description": "Erhöht die Anzahl der Level die ein Sonderbonbon erhöht um 1." - }, - "BERRY_POUCH": { - "name": "Beerentüte", - "description": "Fügt eine 30% Chance hinzu, dass Beeren nicht verbraucht werden." - }, - "FOCUS_BAND": { - "name": "Fokusband", - "description": "Fügt eine 10% Chance hinzu, dass Angriffe die zur Kampfunfähigkeit führen mit 1 KP überlebt werden." - }, - "QUICK_CLAW": { - "name": "Flinkklaue", - "description": "Fügt eine 10% Change hinzu als erster anzugreifen. (Nach Prioritätsangriffen)." - }, - "KINGS_ROCK": { - "name": "King-Stein", - "description": "Fügt eine 10% Chance hinzu, dass der Gegner nach einem Angriff zurückschreckt." - }, - "LEFTOVERS": { - "name": "Überreste", - "description": "Heilt 1/16 der maximalen KP eines Pokémon pro Runde." - }, - "SHELL_BELL": { - "name": "Muschelglocke", - "description": "Heilt den Anwender um 1/8 des von ihm zugefügten Schadens." - }, - "TOXIC_ORB": { - "name": "Toxik-Orb", - "description": "Dieser bizarre Orb vergiftet seinen Träger im Kampf schwer." - }, - "FLAME_ORB": { - "name": "Heiß-Orb", - "description": "Dieser bizarre Orb fügt seinem Träger im Kampf Verbrennungen zu." - }, - "BATON": { - "name": "Stab", - "description": "Ermöglicht das Weitergeben von Effekten beim Wechseln von Pokémon, wodurch auch Fallen umgangen werden." - }, - "SHINY_CHARM": { - "name": "Schillerpin", - "description": "Erhöht die Chance deutlich, dass ein wildes Pokémon ein schillernd ist." - }, - "ABILITY_CHARM": { - "name": "Fähigkeitspin", - "description": "Erhöht die Chance deutlich, dass ein wildes Pokémon eine versteckte Fähigkeit hat." - }, - "IV_SCANNER": { - "name": "IS-Scanner", - "description": "Erlaubt es die IS-Werte von wilden Pokémon zu scannen.\n(2 IS-Werte pro Staplung. Die besten IS-Werte zuerst)." - }, - "DNA_SPLICERS": { - "name": "DNS-Keil" - }, - "MINI_BLACK_HOLE": { - "name": "Mini schwarzes Loch" - }, - "GOLDEN_POKEBALL": { - "name": "Goldener Pokéball", - "description": "Fügt eine zusätzliche Item-Auswahlmöglichkeit nach jedem Kampf hinzu." - }, - "ENEMY_DAMAGE_BOOSTER": { - "name": "Schadensmarke", - "description": "Erhöht den Schaden um 5%." - }, - "ENEMY_DAMAGE_REDUCTION": { - "name": "Schutzmarke", - "description": "Verringert den erhaltenen Schaden um 2,5%." - }, - "ENEMY_HEAL": { - "name": "Wiederherstellungsmarke", - "description": "Heilt 2% der maximalen KP pro Runde." - }, - "ENEMY_ATTACK_POISON_CHANCE": { - "name": "Giftmarke" - }, - "ENEMY_ATTACK_PARALYZE_CHANCE": { - "name": "Lähmungsmarke" - }, - "ENEMY_ATTACK_BURN_CHANCE": { - "name": "Brandmarke" - }, - "ENEMY_STATUS_EFFECT_HEAL_CHANCE": { - "name": "Vollheilungsmarke", - "description": "Fügt eine 2,5%ige Chance hinzu, jede Runde einen Statuszustand zu heilen." - }, - "ENEMY_ENDURE_CHANCE": { - "name": "Ausdauer-Marke" - }, - "ENEMY_FUSED_CHANCE": { - "name": "Fusionsmarke", - "description": "Fügt eine 1%ige Chance hinzu, dass ein wildes Pokémon eine Fusion ist." - } - }, - "SpeciesBoosterItem": { - "LIGHT_BALL": { - "name": "Kugelblitz", - "description": "Ein Item, das von Pikachu getragen werden kann. Es erhöht den Angriff und den Spezial-Angriff." - }, - "THICK_CLUB": { - "name": "Kampfknochen", - "description": "Ein Item, das von Tragosso oder Knogga getragen werden kann. Dieser harte Knochen erhöht den Angriff." - }, - "METAL_POWDER": { - "name": "Metallstaub", - "description": "Ein Item, das von Ditto getragen werden kann. Fein und doch hart, erhöht dieses sonderbare Pulver die Verteidigung." - }, - "QUICK_POWDER": { - "name": "Flottstaub", - "description": "Ein Item, das Ditto zum Tragen gegeben werden kann. Fein und doch hart, erhöht dieses sonderbare Pulver die Initiative." - } - }, - "TempStatStageBoosterItem": { - "x_attack": "X-Angriff", - "x_defense": "X-Verteidigung", - "x_sp_atk": "X-Sp.-Ang.", - "x_sp_def": "X-Sp.-Vert.", - "x_speed": "X-Tempo", - "x_accuracy": "X-Treffer" - }, - "AttackTypeBoosterItem": { - "silk_scarf": "Seidenschal", - "black_belt": "Schwarzgurt", - "sharp_beak": "Spitzer Schnabel", - "poison_barb": "Giftstich", - "soft_sand": "Pudersand", - "hard_stone": "Granitstein", - "silver_powder": "Silberstaub", - "spell_tag": "Bannsticker", - "metal_coat": "Metallmantel", - "charcoal": "Holzkohle", - "mystic_water": "Zauberwasser", - "miracle_seed": "Wundersaat", - "magnet": "Magnet", - "twisted_spoon": "Krümmlöffel", - "never_melt_ice": "Ewiges Eis", - "dragon_fang": "Drachenzahn", - "black_glasses": "Schattenbrille", - "fairy_feather": "Feendaune" - }, - "BaseStatBoosterItem": { - "hp_up": "KP-Plus", - "protein": "Protein", - "iron": "Eisen", - "calcium": "Kalzium", - "zinc": "Zink", - "carbos": "Carbon" - }, - "EvolutionItem": { - "NONE": "Keins", - "LINKING_CORD": "Linkkabel", - "SUN_STONE": "Sonnenstein", - "MOON_STONE": "Mondstein", - "LEAF_STONE": "Blattstein", - "FIRE_STONE": "Feuerstein", - "WATER_STONE": "Wasserstein", - "THUNDER_STONE": "Donnerstein", - "ICE_STONE": "Eisstein", - "DUSK_STONE": "Finsterstein", - "DAWN_STONE": "Funkelstein", - "SHINY_STONE": "Leuchtstein", - "CRACKED_POT": "Rissige Kanne", - "SWEET_APPLE": "Süßer Apfel", - "TART_APPLE": "Saurer Apfel", - "STRAWBERRY_SWEET": "Zucker-Erdbeere", - "UNREMARKABLE_TEACUP": "Simple Teeschale", - "CHIPPED_POT": "Löchrige Kanne", - "BLACK_AUGURITE": "Schwarzaugit", - "GALARICA_CUFF": "Galarnuss-Reif", - "GALARICA_WREATH": "Galarnuss-Kranz", - "PEAT_BLOCK": "Torfblock", - "AUSPICIOUS_ARMOR": "Glorienrüstung", - "MALICIOUS_ARMOR": "Fluchrüstung", - "MASTERPIECE_TEACUP": "Edle Teeschale", - "METAL_ALLOY": "Legierungsmetall", - "SCROLL_OF_DARKNESS": "Unlicht-Schriftrolle", - "SCROLL_OF_WATERS": "Wasser-Schriftrolle", - "SYRUPY_APPLE": "Saftiger Apfel" - }, - "FormChangeItem": { - "NONE": "Keins", - "ABOMASITE": "Rexblisarnit", - "ABSOLITE": "Absolnit", - "AERODACTYLITE": "Aerodactylonit", - "AGGRONITE": "Stollossnit", - "ALAKAZITE": "Simsalanit", - "ALTARIANITE": "Altarianit", - "AMPHAROSITE": "Ampharosnit", - "AUDINITE": "Ohrdochnit", - "BANETTITE": "Banetteonit", - "BEEDRILLITE": "Bibornit", - "BLASTOISINITE": "Turtoknit", - "BLAZIKENITE": "Lohgocknit", - "CAMERUPTITE": "Cameruptnit", - "CHARIZARDITE_X": "Gluraknit X", - "CHARIZARDITE_Y": "Gluraknit Y", - "DIANCITE": "Diancienit", - "GALLADITE": "Galagladinit", - "GARCHOMPITE": "Knakracknit", - "GARDEVOIRITE": "Guardevoirnit", - "GENGARITE": "Gengarnit ", - "GLALITITE": "Firnontornit", - "GYARADOSITE": "Garadosnit", - "HERACRONITE": "Skarabornit", - "HOUNDOOMINITE": "Hundemonit ", - "KANGASKHANITE": "Kangamanit", - "LATIASITE": "Latiasnit", - "LATIOSITE": "Latiosnit", - "LOPUNNITE": "Schlapornit", - "LUCARIONITE": "Lucarionit", - "MANECTITE": "Voltensonit", - "MAWILITE": "Flunkifernit", - "MEDICHAMITE": "Meditalisnit", - "METAGROSSITE": "Metagrossnit", - "MEWTWONITE_X": "Mewtunit X", - "MEWTWONITE_Y": "Mewtunit Y", - "PIDGEOTITE": "Taubossnit", - "PINSIRITE": "Pinsirnit", - "RAYQUAZITE": "Rayquazanit", - "SABLENITE": "Zobirisnit", - "SALAMENCITE": "Brutalandanit", - "SCEPTILITE": "Gewaldronit", - "SCIZORITE": "Scheroxnit", - "SHARPEDONITE": "Tohaidonit", - "SLOWBRONITE": "Lahmusnit", - "STEELIXITE": "Stahlosnit", - "SWAMPERTITE": "Sumpexnit", - "TYRANITARITE": "Despotarnit", - "VENUSAURITE": "Bisaflornit", - "BLUE_ORB": "Blauer Edelstein", - "RED_ORB": "Roter Edelstein", - "SHARP_METEORITE": "Scharfer Meteorit", - "HARD_METEORITE": "Harter Meteorit", - "SMOOTH_METEORITE": "Glatter Meteorit", - "ADAMANT_CRYSTAL": "Adamantkristall", - "LUSTROUS_GLOBE": "Weißkristall", - "GRISEOUS_CORE": "Platinumkristall", - "REVEAL_GLASS": "Wahrspiegel", - "GRACIDEA": "Gracidea", - "MAX_MUSHROOMS": "Dyna-Pilz", - "DARK_STONE": "Dunkelstein", - "LIGHT_STONE": "Lichtstein", - "PRISON_BOTTLE": "Banngefäß", - "N_LUNARIZER": "Necrolun", - "N_SOLARIZER": "Necrosol", - "RUSTED_SWORD": "Rostiges Schwert", - "RUSTED_SHIELD": "Rostiges Schild", - "ICY_REINS_OF_UNITY": "Eisige Zügel des Bundes", - "SHADOW_REINS_OF_UNITY": "Schattige Zügel des Bundes", - "WELLSPRING_MASK": "Brunnenmaske", - "HEARTHFLAME_MASK": "Ofenmaske", - "CORNERSTONE_MASK": "Fundamentmaske", - "SHOCK_DRIVE": "Blitzmodul", - "BURN_DRIVE": "Flammenmodul", - "CHILL_DRIVE": "Gefriermodul", - "DOUSE_DRIVE": "Aquamodul", - "ULTRANECROZIUM_Z": "Ultranecrozium Z", - "FIST_PLATE": "Fausttafel", - "SKY_PLATE": "Wolkentafel", - "TOXIC_PLATE": "Gifttafel", - "EARTH_PLATE": "Erdtafel", - "STONE_PLATE": "Steintafel", - "INSECT_PLATE": "Käfertafel", - "SPOOKY_PLATE": "Spuktafel", - "IRON_PLATE": "Eisentafel", - "FLAME_PLATE": "Feuertafel", - "SPLASH_PLATE": "Wassertafel", - "MEADOW_PLATE": "Wiesentafel", - "ZAP_PLATE": "Blitztafel", - "MIND_PLATE": "Hirntafel", - "ICICLE_PLATE": "Frosttafel", - "DRACO_PLATE": "Dracotafel", - "DREAD_PLATE": "Furchttafel", - "PIXIE_PLATE": "Feentafel", - "BLANK_PLATE": "Neutraltafel", - "LEGEND_PLATE": "Legendentafel", - "FIGHTING_MEMORY": "Kampf-Disc", - "FLYING_MEMORY": "Flug-Disc", - "POISON_MEMORY": "Gift-Disc", - "GROUND_MEMORY": "Boden-Disc", - "ROCK_MEMORY": "Gesteins-Disc", - "BUG_MEMORY": "Käfer-Disc", - "GHOST_MEMORY": "Geister-Disc", - "STEEL_MEMORY": "Stahl-Disc", - "FIRE_MEMORY": "Feuer-Disc", - "WATER_MEMORY": "Wasser-Disc", - "GRASS_MEMORY": "Pflanzen-Disc", - "ELECTRIC_MEMORY": "Elektro-Disc", - "PSYCHIC_MEMORY": "Psycho-Disc", - "ICE_MEMORY": "Eis-Disc", - "DRAGON_MEMORY": "Drachen-Disc", - "DARK_MEMORY": "Unlicht-Disc", - "FAIRY_MEMORY": "Feen-Disc", - "NORMAL_MEMORY": "Normal-Disc" - } -} diff --git a/src/locales/de/modifier.json b/src/locales/de/modifier.json deleted file mode 100644 index 37227973410..00000000000 --- a/src/locales/de/modifier.json +++ /dev/null @@ -1,12 +0,0 @@ -{ - "surviveDamageApply": "{{pokemonNameWithAffix}} hält mithilfe des Items {{typeName}} durch!", - "turnHealApply": "{{typeName}} von {{pokemonNameWithAffix}} füllt einige KP auf!", - "hitHealApply": "{{typeName}} von {{pokemonNameWithAffix}} füllt einige KP auf!", - "pokemonInstantReviveApply": "{{pokemonNameWithAffix}} wurde durch {{typeName}} wiederbelebt!", - "resetNegativeStatStageApply": "Die negative Statuswertveränderung von {{pokemonNameWithAffix}} wurde durch {{typeName}} aufgehoben!", - "moneyInterestApply": "Du erhählst {{moneyAmount}} ₽ durch das Item {{typeName}}!", - "turnHeldItemTransferApply": "{{itemName}} von {{pokemonNameWithAffix}} wurde durch {{typeName}} von {{pokemonName}} absorbiert!", - "contactHeldItemTransferApply": "{{itemName}} von {{pokemonNameWithAffix}} wurde durch {{typeName}} von {{pokemonName}} geklaut!", - "enemyTurnHealApply": "{{pokemonNameWithAffix}} stellt einige KP wieder her!", - "bypassSpeedChanceApply": "Dank des Items {{itemName}} kann {{pokemonName}} schneller handeln als sonst!" -} \ No newline at end of file diff --git a/src/locales/de/move-trigger.json b/src/locales/de/move-trigger.json deleted file mode 100644 index 01b22429fb3..00000000000 --- a/src/locales/de/move-trigger.json +++ /dev/null @@ -1,71 +0,0 @@ -{ - "hitWithRecoil": "{{pokemonName}} erleidet Schaden durch Rückstoß!", - "cutHpPowerUpMove": "{{pokemonName}} nutzt seine KP um seine Attacke zu verstärken!", - "absorbedElectricity": "{{pokemonName}} absorbiert elektrische Energie!", - "switchedStatChanges": "{{pokemonName}} tauschte die Statuswerteveränderungen mit dem Ziel!", - "switchedTwoStatChanges": "{{pokemonName}} tauscht Veränderungen an {{firstStat}} und {{secondStat}} mit dem Ziel!", - "switchedStat": "{{pokemonName}} tauscht seinen {{stat}}-Wert mit dem des Zieles!", - "sharedGuard": "{{pokemonName}} addiert seine Schutzkräfte mit jenen des Zieles und teilt sie gerecht auf!", - "sharedPower": "{{pokemonName}} addiert seine Kräfte mit jenen des Zieles und teilt sie gerecht auf!", - "goingAllOutForAttack": "{{pokemonName}} legt sich ins Zeug!", - "regainedHealth": "{{pokemonName}} erholt sich!", - "keptGoingAndCrashed": "{{pokemonName}} springt daneben und verletzt sich!", - "fled": "{{pokemonName}} ist geflüchtet!", - "cannotBeSwitchedOut": "{{pokemonName}} kann nicht ausgewechselt werden!", - "swappedAbilitiesWithTarget": "{{pokemonName}} tauscht Fähigkeiten mit dem Ziel!", - "coinsScatteredEverywhere": "Es sind überall Münzen verstreut!", - "attackedByItem": "{{pokemonName}} wird von seinem Item {{itemName}} angegriffen!", - "whippedUpAWhirlwind": "{{pokemonName}} erzeugt eine Windböe!", - "flewUpHigh": "{{pokemonName}} fliegt hoch empor!", - "tookInSunlight": "{{pokemonName}} absorbiert Sonnenlicht!", - "dugAHole": "{{pokemonName}} vergräbt sich in der Erde!", - "loweredItsHead": "{{pokemonName}} zieht seinen Kopf ein!", - "isGlowing": "{{pokemonName}} leuchtet grell!", - "bellChimed": "Eine Glocke läutet!", - "foresawAnAttack": "{{pokemonName}} sieht einen Angriff voraus!", - "isTighteningFocus": "{{pokemonName}} konzentriert sich!", - "hidUnderwater": "{{pokemonName}} taucht unter!", - "soothingAromaWaftedThroughArea": "Ein wohltuendes Aroma breitet sich aus!", - "sprangUp": "{{pokemonName}} springt hoch in die Luft!", - "choseDoomDesireAsDestiny": "{{pokemonName}} äußert einen Kismetwunsch für die Zukunft!", - "vanishedInstantly": "{{pokemonName}} verschwindet augenblicklich!", - "tookTargetIntoSky": "{{pokemonName}} entführt {{targetName}} in luftige Höhen!", - "becameCloakedInFreezingLight": "{{pokemonName}} wird von einem kühlen Licht umhüllt!", - "becameCloakedInFreezingAir": "{{pokemonName}} wird in klirrend kalte Luft gehüllt!", - "isChargingPower": "{{pokemonName}} saugt Kraft in sich auf!", - "burnedItselfOut": "{{pokemonName}} braucht sein Feuer komplett auf!", - "startedHeatingUpBeak": "{{pokemonName}} erhitzt seinen Schnabel!", - "setUpShellTrap": "{{pokemonName}} hat eine Panzerfalle gelegt!", - "isOverflowingWithSpacePower": "Kosmische Kräfte strömen aus {{pokemonName}}!", - "usedUpAllElectricity": "{{pokemonName}} braucht seinen Strom komplett auf!", - "stoleItem": "{{pokemonName}} hat {{targetName}} das Item {{itemName}} geklaut!", - "incineratedItem": "{{pokemonName}} hat {{itemName}} von {{targetName}} verbrannt. Es ist somit nutzlos geworden!", - "knockedOffItem": "{{pokemonName}} schlägt das Item {{itemName}} von {{targetName}} weg!", - "tookMoveAttack": "{{pokemonName}} wurde von {{moveName}} getroffen!", - "cutOwnHpAndMaximizedStat": "{{pokemonName}} nutzt seine KP und maximiert dadurch seinen {{statName}}-Wert!", - "copiedStatChanges": "{{pokemonName}} kopiert die Statusveränderungen von {{targetName}}!", - "magnitudeMessage": "Intensität {{magnitude}}!", - "tookAimAtTarget": "{{pokemonName}} zielt auf {{targetName}}!", - "transformedIntoType": "{{pokemonName}} nimmt den Typ {{typeName}} an!", - "copiedMove": "{{pokemonName}} kopiert {{moveName}}!", - "sketchedMove": "{{pokemonName}} ahmt die Attacke {{moveName}} nach!", - "acquiredAbility": "The {{pokemonName}} nimmt die Fähigkeit {{abilityName}} an!", - "copiedTargetAbility": "{{pokemonName}} kopiert{{abilityName}} von {{targetName}}!", - "transformedIntoTarget": "{{pokemonName}} verwandelt sich in {{targetName}}!", - "tryingToTakeFoeDown": "{{pokemonName}} versucht, den Angreifer mit sich zu nehmen!", - "addType": "{{pokemonName}} nimmt zusätzlich den Typ {{typeName}} an!", - "cannotUseMove": "{{pokemonName}} kann {{moveName}} nicht einsetzen!", - "healHp": "KP von {{pokemonName}} wurden aufgefrischt!", - "sacrificialFullRestore": "Das Heilopfer von {{pokemonName}} erreicht sein Ziel!", - "invertStats": "Alle Statusveränderungen von {{pokemonName}} wurden invertiert!", - "resetStats": "Die Statusveränderungen von {{pokemonName}} wurden aufgehoben!", - "statEliminated": "Alle Statusveränderungen wurden aufgehoben!", - "faintCountdown": "{{pokemonName}} geht nach {{turnCount}} Runden K.O.!", - "copyType": "{{pokemonName}} hat den Typ von {{targetPokemonName}} angenommen!", - "suppressAbilities": "Die Fähigkeit von {{pokemonName}} wirkt nicht mehr!", - "revivalBlessing": "{{pokemonName}} ist wieder fit und kampfbereit!", - "swapArenaTags": "{{pokemonName}} hat die Effekte, die auf den beiden Seiten des Kampffeldes wirken, miteinander getauscht!", - "exposedMove": "{{pokemonName}} erkennt {{targetPokemonName}}!", - "safeguard": "{{targetName}} wird durch Bodyguard geschützt!", - "afterYou": "{{targetName}} lässt sich auf Galanterie ein!" -} diff --git a/src/locales/de/move.json b/src/locales/de/move.json deleted file mode 100644 index 3c81ccfd7df..00000000000 --- a/src/locales/de/move.json +++ /dev/null @@ -1,3810 +0,0 @@ -{ - "pound": { - "name": "Klaps", - "effect": "Ein Hieb mit den Vorderbeinen oder dem Schweif." - }, - "karateChop": { - "name": "Karateschlag", - "effect": "Gute Möglichkeit, einen Volltreffer zu landen." - }, - "doubleSlap": { - "name": "Duplexhieb", - "effect": "Trifft das Ziel zwei- bis fünfmal hintereinander mit einem Duplexhieb." - }, - "cometPunch": { - "name": "Kometenhieb", - "effect": "Trifft das Ziel zwei- bis fünfmal hintereinander mit kräftigen Hieben." - }, - "megaPunch": { - "name": "Megahieb", - "effect": "Ein unglaublich kräftiger Hieb." - }, - "payDay": { - "name": "Zahltag", - "effect": "Das Ziel wird mit Münzen beworfen. Das Geld wird nach dem Kampf aufgesammelt." - }, - "firePunch": { - "name": "Feuerschlag", - "effect": "Feuriger Schlag, der dem Ziel eventuell Verbrennungen zufügt." - }, - "icePunch": { - "name": "Eishieb", - "effect": "Ein eisiger Schlag, der das Ziel eventuell einfriert." - }, - "thunderPunch": { - "name": "Donnerschlag", - "effect": "Ein elektrischer Schlag, der das Ziel eventuell paralysiert." - }, - "scratch": { - "name": "Kratzer", - "effect": "Das Ziel wird mit scharfen Klauen zerkratzt." - }, - "viseGrip": { - "name": "Klammer", - "effect": "Das Ziel wird umklammert und zusammengequetscht." - }, - "guillotine": { - "name": "Guillotine", - "effect": "Kräftige Scheren-Attacke. Führt beim Ziel sofort zum K.O." - }, - "razorWind": { - "name": "Klingensturm", - "effect": "Eine Attacke, die über zwei Runden geht. Hohe Volltrefferquote." - }, - "swordsDance": { - "name": "Schwerttanz", - "effect": "Ein wilder Kampftanz, der den eigenen Angriffs-Wert stark erhöht." - }, - "cut": { - "name": "Zerschneider", - "effect": "Ein Basisangriff mit Schere oder Klaue. Damit können kleine Bäume gefällt werden." - }, - "gust": { - "name": "Windstoß", - "effect": "Trifft das Ziel mit einem Windstoß durch einen Flügelschlag." - }, - "wingAttack": { - "name": "Flügelschlag", - "effect": "Trifft das Ziel mit ausgebreiteten Flügeln." - }, - "whirlwind": { - "name": "Wirbelwind", - "effect": "Weht das Ziel weg und ersetzt es durch ein anderes Pokémon. In der Wildnis endet der Kampf." - }, - "fly": { - "name": "Fliegen", - "effect": "Steigt in Runde 1 empor und trifft das Ziel in Runde 2." - }, - "bind": { - "name": "Klammergriff", - "effect": "Umklammert und quetscht das Ziel über vier bis fünf Runden." - }, - "slam": { - "name": "Slam", - "effect": "Schlag mit einem langen Schweif, einer Ranke oder Ähnlichem." - }, - "vineWhip": { - "name": "Rankenhieb", - "effect": "Peitschenähnlicher Schlag mit Ranken." - }, - "stomp": { - "name": "Stampfer", - "effect": "Stampfen mit dem Fuß. Das Ziel schreckt eventuell zurück." - }, - "doubleKick": { - "name": "Doppelkick", - "effect": "Der Anwender tritt in einer Runde zweimal schnell zu." - }, - "megaKick": { - "name": "Megakick", - "effect": "Das Ziel wird mit einem extrem heftigen Tritt angegriffen." - }, - "jumpKick": { - "name": "Sprungkick", - "effect": "Der Angreifer hüpft hoch und tritt zu. Bei Misserfolg schadet er sich selbst." - }, - "rollingKick": { - "name": "Fegekick", - "effect": "Heftiger Tritt aus einer schnellen Drehbewegung. Lässt das Ziel eventuell zurückschrecken." - }, - "sandAttack": { - "name": "Sandwirbel", - "effect": "Senkt Genauigkeit des Zieles, indem ihm Sand ins Gesicht geworfen wird." - }, - "headbutt": { - "name": "Kopfnuss", - "effect": "Rammt das Ziel mit einer Kopfnuss. Ziel schreckt eventuell zurück." - }, - "hornAttack": { - "name": "Hornattacke", - "effect": "Spießt das Ziel mit einem spitzen Horn auf." - }, - "furyAttack": { - "name": "Furienschlag", - "effect": "Spießt das Ziel zwei- bis fünfmal mit spitzem Horn oder Schnabel auf." - }, - "hornDrill": { - "name": "Hornbohrer", - "effect": "K.O.-Attacke, bei der ein Horn als Bohrer eingesetzt wird." - }, - "tackle": { - "name": "Tackle", - "effect": "Trifft das Ziel mit vollem Körpereinsatz." - }, - "bodySlam": { - "name": "Bodyslam", - "effect": "Trifft das Ziel mit vollem Körpereinsatz. Bewirkt eventuell Paralyse." - }, - "wrap": { - "name": "Wickel", - "effect": "Umwickelt das Ziel über vier bis fünf Runden mit Ranken oder Ähnlichem und fügt ihm Schaden zu." - }, - "takeDown": { - "name": "Bodycheck", - "effect": "Rücksichtslose Attacke, bei der sich der Angreifer selbst leicht verletzt." - }, - "thrash": { - "name": "Fuchtler", - "effect": "Attacke über zwei bis drei Runden, die den Angreifer verwirrt." - }, - "doubleEdge": { - "name": "Risikotackle", - "effect": "Lebensgefährlicher Angriff, bei dem sich der Angreifer selbst verletzt." - }, - "tailWhip": { - "name": "Rutenschlag", - "effect": "Hieb mit dem Schweif. Senkt die Verteidigung des Zieles." - }, - "poisonSting": { - "name": "Giftstachel", - "effect": "Angriff mit Giftstachel. Das Ziel wird eventuell vergiftet." - }, - "twineedle": { - "name": "Duonadel", - "effect": "Stacheln treffen das Ziel zweimal. Das Ziel wird eventuell vergiftet." - }, - "pinMissile": { - "name": "Nadelrakete", - "effect": "Spitze Nadeln treffen das Ziel zwei- bis fünfmal hintereinander." - }, - "leer": { - "name": "Silberblick", - "effect": "Gegnerischer Verteidigungs-Wert wird durch angsteinflößenden Blick gesenkt." - }, - "bite": { - "name": "Biss", - "effect": "Beißt zu und lässt das Ziel eventuell zurückschrecken." - }, - "growl": { - "name": "Heuler", - "effect": "Der Anwender nimmt das Ziel für sich ein und senkt dessen Angriffs-Wert." - }, - "roar": { - "name": "Brüller", - "effect": "Verjagt das Ziel und ersetzt es durch ein anderes Pokémon. Beendet den Kampf in der Wildnis." - }, - "sing": { - "name": "Gesang", - "effect": "Ein Lied, das das Ziel in tiefen Schlaf versetzt." - }, - "supersonic": { - "name": "Superschall", - "effect": "Ausstoß bizarrer Schallwellen. Das Ziel wird verwirrt." - }, - "sonicBoom": { - "name": "Ultraschall", - "effect": "Das Ziel wird von einer Schockwelle getroffen, die stets 20 KP Schaden anrichtet." - }, - "disable": { - "name": "Aussetzer", - "effect": "Die zuletzt eingesetzte Attacke des Zieles wird für mehrere Runden blockiert." - }, - "acid": { - "name": "Säure", - "effect": "Versprüht ätzende Flüssigkeit, die eventuell die Spezial-Verteidigung der Gegner in der Nähe des Anwenders senkt." - }, - "ember": { - "name": "Glut", - "effect": "Schwache Feuer-Attacke, durch die das Ziel eventuell Verbrennungen erleidet." - }, - "flamethrower": { - "name": "Flammenwurf", - "effect": "Starke Feuer-Attacke, durch die das Ziel eventuell Verbrennungen erleidet." - }, - "mist": { - "name": "Weißnebel", - "effect": "Anwender schützt das Team mit einem Nebel. Verhindert Statussenkungen für fünf Runden." - }, - "waterGun": { - "name": "Aquaknarre", - "effect": "Das Ziel wird mit Wasser bespritzt." - }, - "hydroPump": { - "name": "Hydropumpe", - "effect": "Spritzt eine Menge Wasser mit Hochdruck auf das Ziel." - }, - "surf": { - "name": "Surfer", - "effect": "Eine Welle bricht über alle Pokémon in der Nähe des Anwenders herein." - }, - "iceBeam": { - "name": "Eisstrahl", - "effect": "Das Ziel wird von einem Eisstrahl getroffen und friert eventuell ein." - }, - "blizzard": { - "name": "Blizzard", - "effect": "Ein Schneesturm wütet, der das Ziel einfrieren kann." - }, - "psybeam": { - "name": "Psystrahl", - "effect": "Feuert einen Strahl ab, der das Ziel verwirren kann." - }, - "bubbleBeam": { - "name": "Blubbstrahl", - "effect": "Versprüht Blasen, die eventuell den Initiative-Wert des Zieles senken." - }, - "auroraBeam": { - "name": "Aurorastrahl", - "effect": "Regenbogenfarbener Strahl, der eventuell den Angriffs-Wert des Zieles senkt." - }, - "hyperBeam": { - "name": "Hyperstrahl", - "effect": "Starke Attacke, die den Anwender zwingt, eine Runde auszusetzen." - }, - "peck": { - "name": "Pikser", - "effect": "Greift das Ziel mit dem Schnabel oder Horn an." - }, - "drillPeck": { - "name": "Bohrschnabel", - "effect": "Korkenzieherangriff, bei dem der Schnabel als Bohrer dient." - }, - "submission": { - "name": "Überroller", - "effect": "Harte Körperattacke, bei der sich der Angreifer selbst leicht verletzt." - }, - "lowKick": { - "name": "Fußkick", - "effect": "Ein Tritt, der das Ziel umwirft. Je schwerer das Ziel ist, desto mehr Schaden fügt ihm die Attacke zu." - }, - "counter": { - "name": "Konter", - "effect": "Kontert physische Treffer und fügt dem Ziel das Doppelte des Schadens zu, den der Anwender erlitten hat." - }, - "seismicToss": { - "name": "Geowurf", - "effect": "Ziel wird mit der Kraft der Gravitation umgeworfen. Richtet Schaden gemäß Level des Angreifers an." - }, - "strength": { - "name": "Stärke", - "effect": "Das Ziel wird extrem stark getroffen. Macht Verschieben von Felsen möglich." - }, - "absorb": { - "name": "Absorber", - "effect": "Attacke, die die Hälfte des Schadens absorbiert." - }, - "megaDrain": { - "name": "Megasauger", - "effect": "Attacke, die die Hälfte des Schadens absorbiert." - }, - "leechSeed": { - "name": "Egelsamen", - "effect": "Ziel wird bepflanzt und verliert jede Runde KP, die ein Pokémon aus dem Team des Anwenders heilen." - }, - "growth": { - "name": "Wachstum", - "effect": "Der Körper wächst. Dadurch steigen Angriff und Spezial-Angriff." - }, - "razorLeaf": { - "name": "Rasierblatt", - "effect": "Trifft das Ziel mit Blättern. Hohe Volltrefferquote." - }, - "solarBeam": { - "name": "Solarstrahl", - "effect": "Absorbiert Licht in Runde 1. In Runde 2 erfolgt der Angriff." - }, - "poisonPowder": { - "name": "Giftpuder", - "effect": "Verstreut giftigen Puder auf das Ziel." - }, - "stunSpore": { - "name": "Stachelspore", - "effect": "Verstreut lähmenden Puder." - }, - "sleepPowder": { - "name": "Schlafpuder", - "effect": "Verstreut Schlafpuder, der das Ziel eventuell in Schlaf versetzt." - }, - "petalDance": { - "name": "Blättertanz", - "effect": "Angriff mit Blütenblättern für zwei bis drei Runden. Angreifer wird verwirrt." - }, - "stringShot": { - "name": "Fadenschuss", - "effect": "Umwickelt Ziele in der Nähe mit Fäden aus dem Mund und senkt den Initiative-Wert." - }, - "dragonRage": { - "name": "Drachenwut", - "effect": "Stößt eine wutgeladene Schockwelle aus, die stets 40 KP Schaden anrichtet." - }, - "fireSpin": { - "name": "Feuerwirbel", - "effect": "Das Ziel wird für vier bis fünf Runden in einem Feuerkreis gefangen." - }, - "thunderShock": { - "name": "Donnerschock", - "effect": "Eine Elektro-Attacke, die das Ziel eventuell paralysiert." - }, - "thunderbolt": { - "name": "Donnerblitz", - "effect": "Eine starke Elektro-Attacke, die das Ziel eventuell paralysiert." - }, - "thunderWave": { - "name": "Donnerwelle", - "effect": "Ein schwacher Stromstoß, der das Ziel paralysiert." - }, - "thunder": { - "name": "Donner", - "effect": "Eine verheerende Elektro-Attacke, die das Ziel eventuell paralysiert." - }, - "rockThrow": { - "name": "Steinwurf", - "effect": "Das Ziel wird mit einem kleinen Stein beworfen." - }, - "earthquake": { - "name": "Erdbeben", - "effect": "Ein mächtiges Beben, das die anderen Pokémon in der Nähe des Anwenders trifft." - }, - "fissure": { - "name": "Geofissur", - "effect": "Das Ziel wird in eine Erdspalte geworfen. Ist die Attacke erfolgreich, führt sie zu einem K.O." - }, - "dig": { - "name": "Schaufler", - "effect": "In Runde 1 gräbt sich der Anwender ein und in Runde 2 greift er an. Macht Flucht aus Höhlen möglich." - }, - "toxic": { - "name": "Toxin", - "effect": "Vergiftet das Ziel mit einem potenten Toxin schwer. Vergiftung wird von Runde zu Runde stärker." - }, - "confusion": { - "name": "Konfusion", - "effect": "Das Ziel wird von schwacher telekinetischer Energie getroffen und eventuell verwirrt." - }, - "psychic": { - "name": "Psychokinese", - "effect": "Starke Psycho-Attacke, die eventuell die Spezial-Verteidigung des Zieles senkt." - }, - "hypnosis": { - "name": "Hypnose", - "effect": "Hypnose-Attacke, die das Ziel in Schlaf versetzt." - }, - "meditate": { - "name": "Meditation", - "effect": "Anwender aktiviert Kräfte, die tief in seinem Inneren schlummern, und steigert so seinen Angriffs-Wert." - }, - "agility": { - "name": "Agilität", - "effect": "Entspannt den Körper, um den Initiative-Wert stark zu steigern." - }, - "quickAttack": { - "name": "Ruckzuckhieb", - "effect": "Sehr schneller Angriff mit Erstschlaggarantie." - }, - "rage": { - "name": "Raserei", - "effect": "Erhöht Angriff des Anwenders, wenn dieser getroffen wird, solange die Attacke aktiviert ist." - }, - "teleport": { - "name": "Teleport", - "effect": "Der Anwender tauscht den Platz mit einem anderen Team-Mitglied, sofern vorhanden. Setzen wilde Pokémon die Attacke ein, ergreifen diese die Flucht." - }, - "nightShade": { - "name": "Nachtnebel", - "effect": "Das Ziel sieht eine Illusion. Richtet Schaden gemäß dem Level des Anwenders an." - }, - "mimic": { - "name": "Mimikry", - "effect": "Kopiert die zuvor ausgeführte Attacke des Zieles. Kann im Kampf bis zur Auswechslung verwendet werden." - }, - "screech": { - "name": "Kreideschrei", - "effect": "Stößt einen Schrei aus, um die Verteidigung des Zieles stark zu senken." - }, - "doubleTeam": { - "name": "Doppelteam", - "effect": "Erzeugt durch schnelle Bewegungen Ebenbilder, um den Fluchtwert zu erhöhen." - }, - "recover": { - "name": "Genesung", - "effect": "Eine Selbstheilung. KP des Anwenders werden um 50 % des maximalen Wertes aufgefüllt." - }, - "harden": { - "name": "Härtner", - "effect": "Stärkt die Muskulatur und erhöht den Verteidigungs-Wert." - }, - "minimize": { - "name": "Komprimator", - "effect": "Anwender schrumpft, um seinen Fluchtwert stark zu erhöhen." - }, - "smokescreen": { - "name": "Rauchwolke", - "effect": "Senkt Genauigkeit des Zieles mit Rauch, Tinte oder Ähnlichem." - }, - "confuseRay": { - "name": "Konfusstrahl", - "effect": "Ein fieser Strahl, der das Ziel verwirrt." - }, - "withdraw": { - "name": "Panzerschutz", - "effect": "Rückzug in den harten Panzer. Erhöht den Verteidigungs-Wert." - }, - "defenseCurl": { - "name": "Einigler", - "effect": "Verbirgt Schwächen durch Einrollen und hebt gleichzeitig den Verteidigungs-Wert." - }, - "barrier": { - "name": "Barriere", - "effect": "Erzeugt eine Barriere, die den Verteidigungs-Wert stark erhöht." - }, - "lightScreen": { - "name": "Lichtschild", - "effect": "Erzeugt eine Lichtwand und senkt den Schaden durch Spezial-Angriffe für fünf Runden." - }, - "haze": { - "name": "Dunkelnebel", - "effect": "Erzeugt einen dunklen Nebel. Alle Veränderungen der Statuswerte der Kampfteilnehmer werden annulliert." - }, - "reflect": { - "name": "Reflektor", - "effect": "Eine mysteriöse Wand, die fünf Runden den Schaden von physischen gegnerischen Treffern reduziert." - }, - "focusEnergy": { - "name": "Energiefokus", - "effect": "Anwender atmet ein und bündelt Kraft. Die Volltrefferquote steigt dadurch." - }, - "bide": { - "name": "Geduld", - "effect": "Erträgt zwei Runden Angriffe und schlägt dann mit dem doppelten Wert des erlittenen Schadens zurück." - }, - "metronome": { - "name": "Metronom", - "effect": "Bewegt Finger, um das Gehirn zu stimulieren. Wählt zufällig eine Attacke aus." - }, - "mirrorMove": { - "name": "Spiegeltrick", - "effect": "Kopiert die letzte Attacke des Zieles und greift es an." - }, - "selfDestruct": { - "name": "Finale", - "effect": "Anwender sprengt sich, richtet rundum Riesenschaden an und wird dabei besiegt." - }, - "eggBomb": { - "name": "Eierbombe", - "effect": "Ein großes Ei wird auf das Ziel abgefeuert, um ihm zu schaden." - }, - "lick": { - "name": "Schlecker", - "effect": "Leck-Attacke mit langer Zunge. Das Ziel wird eventuell paralysiert." - }, - "smog": { - "name": "Smog", - "effect": "Angriff mit Gas. Das Ziel kann eventuell vergiftet werden." - }, - "sludge": { - "name": "Schlammbad", - "effect": "Wirft Schlamm auf das Ziel. Dieses wird eventuell vergiftet." - }, - "boneClub": { - "name": "Knochenkeule", - "effect": "Schlägt das Ziel mit einer Keule und lässt es eventuell zurückschrecken." - }, - "fireBlast": { - "name": "Feuersturm", - "effect": "Feuersbrunst, die das Ziel versengt und ihm eventuell eine Verbrennung zufügt." - }, - "waterfall": { - "name": "Kaskade", - "effect": "Eine mächtige Attacke, durch die das Ziel eventuell zurückschreckt." - }, - "clamp": { - "name": "Schnapper", - "effect": "Fängt und quetscht das Ziel über vier bis fünf Runden durch die harte Schale des Anwenders." - }, - "swift": { - "name": "Sternschauer", - "effect": "Verschießt sternförmige Strahlen, die stets treffen, auf Ziele in der Umgebung." - }, - "skullBash": { - "name": "Schädelwumme", - "effect": "Der Anwender erhöht in Runde 1 seine Verteidigung und greift in Runde 2 an." - }, - "spikeCannon": { - "name": "Dornkanone", - "effect": "Spitze Nadeln treffen das Ziel zwei- bis fünfmal hintereinander." - }, - "constrict": { - "name": "Umklammerung", - "effect": "Angriff mit langen Tentakeln oder Ranken. Senkt eventuell den Initiative-Wert." - }, - "amnesia": { - "name": "Amnesie", - "effect": "Gedächtnisverlust, der die Spezial-Verteidigung stark erhöht." - }, - "kinesis": { - "name": "Psykraft", - "effect": "Lenkt Ziel durch Verbiegen eines Löffels ab. Senkt dessen Genauigkeit." - }, - "softBoiled": { - "name": "Weichei", - "effect": "KP des Anwenders werden um 50 % der maximalen KP aufgefüllt." - }, - "highJumpKick": { - "name": "Turmkick", - "effect": "Sprungtritt mit Knie. Bei Misserfolg verletzt sich der Anwender selbst." - }, - "glare": { - "name": "Schlangenblick", - "effect": "Schüchtert Ziel mit dem Muster auf seinem Bauch ein, sodass dieses paralysiert wird." - }, - "dreamEater": { - "name": "Traumfresser", - "effect": "Attacke gegen schlafendes Ziel. Die Hälfte des zugefügten Schadens wird dem Anwender gutgeschrieben." - }, - "poisonGas": { - "name": "Giftwolke", - "effect": "Hüllt Ziele in der Umgebung in Gas ein, das sie eventuell vergiftet." - }, - "barrage": { - "name": "Stakkato", - "effect": "Wirft zwei- bis fünfmal runde Gegenstände auf das Ziel." - }, - "leechLife": { - "name": "Blutsauger", - "effect": "Die Hälfte des zugefügten Schadens wird dem Anwender gutgeschrieben." - }, - "lovelyKiss": { - "name": "Todeskuss", - "effect": "Anwender zwingt dem Ziel einen Kuss auf, der Schlaf verursacht." - }, - "skyAttack": { - "name": "Himmelsfeger", - "effect": "Anwender greift in der zweiten Runde mit hoher Volltrefferquote an. Ziel schreckt eventuell zurück." - }, - "transform": { - "name": "Wandler", - "effect": "Anwender verwandelt sich in ein Abbild des Zieles und kann so auf die gleichen Attacken zugreifen." - }, - "bubble": { - "name": "Blubber", - "effect": "Angriff mit Blasen. Initiative-Wert des Zieles wird eventuell gesenkt." - }, - "dizzyPunch": { - "name": "Irrschlag", - "effect": "Rhythmische Schläge, die das Ziel verwirren können." - }, - "spore": { - "name": "Pilzspore", - "effect": "Erzeugt eine Wolke aus einschläfernden Sporen." - }, - "flash": { - "name": "Blitz", - "effect": "Erzeugt helles Licht, das die Genauigkeit des Zieles senkt." - }, - "psywave": { - "name": "Psywelle", - "effect": "Anwender erzeugt eine mysteriöse Energiewelle, deren Intensität von Mal zu Mal anders ausfällt." - }, - "splash": { - "name": "Platscher", - "effect": "Nur ein Platscher, der überhaupt nichts bewirkt." - }, - "acidArmor": { - "name": "Säurepanzer", - "effect": "Verflüssigt Körperzellen des Anwenders. Erhöht den Verteidigungs-Wert stark." - }, - "crabhammer": { - "name": "Krabbhammer", - "effect": "Schlägt mit Schere zu. Hohe Volltrefferquote." - }, - "explosion": { - "name": "Explosion", - "effect": "Anwender explodiert, richtet bei allen Pokémon in seiner Umgebung großen Schaden an und wird selbst kampfunfähig." - }, - "furySwipes": { - "name": "Kratzfurie", - "effect": "Beharkt das Ziel zwei- bis fünfmal mit scharfen Klauen oder Sicheln." - }, - "bonemerang": { - "name": "Knochmerang", - "effect": "Ein Bumerang aus Knochen, der zweimal trifft." - }, - "rest": { - "name": "Erholung", - "effect": "Anwender wird vollkommen geheilt und schläft die folgenden zwei Runden." - }, - "rockSlide": { - "name": "Steinhagel", - "effect": "Schleudert riesige Felsen auf Ziele in der Umgebung, die eventuell zurückschrecken." - }, - "hyperFang": { - "name": "Hyperzahn", - "effect": "Angriff mit scharfen Reißzähnen. Ziel schreckt eventuell zurück." - }, - "sharpen": { - "name": "Schärfer", - "effect": "Anwender senkt die Polygonzahl, um Kanten zu erzeugen, die den Angriffs-Wert erhöhen." - }, - "conversion": { - "name": "Umwandlung", - "effect": "Wandelt den Typ des Anwenders in den Typ der ersten Attacke des Anwenders um." - }, - "triAttack": { - "name": "Triplette", - "effect": "Feuert drei Strahlen ab. Verursacht eventuell Paralyse, Verbrennung oder Einfrieren." - }, - "superFang": { - "name": "Superzahn", - "effect": "Greift mit scharfen Reißzähnen an. KP des Zieles werden halbiert." - }, - "slash": { - "name": "Schlitzer", - "effect": "Hieb mit Klauen oder Ähnlichem. Hohe Volltrefferquote." - }, - "substitute": { - "name": "Delegator", - "effect": "Anwender setzt eine kleine Menge an KP ein, um einen Doppelgänger zu erzeugen, der für ihn Schläge einsteckt." - }, - "struggle": { - "name": "Verzweifler", - "effect": "Angriff nur bei verbrauchten AP. Anwender verletzt sich selbst leicht." - }, - "sketch": { - "name": "Nachahmer", - "effect": "Anwender lernt die letzte Attacke des Zieles dauerhaft. Nachahmer verschwindet nach Gebrauch." - }, - "tripleKick": { - "name": "Dreifachkick", - "effect": "Tritt das Ziel ein- bis dreimal nacheinander. Die Härte der Tritte nimmt von Treffer zu Treffer zu." - }, - "thief": { - "name": "Raub", - "effect": "Erlaubt es, das Item des Zieles zu stehlen, solang der Anwender selbst keins bei sich trägt." - }, - "spiderWeb": { - "name": "Spinnennetz", - "effect": "Wickelt das Ziel ein. Flucht oder Tausch unmöglich." - }, - "mindReader": { - "name": "Willensleser", - "effect": "Ahnt Bewegungen des Zieles voraus, um zu gewährleisten, dass die nächste eigene Attacke trifft." - }, - "nightmare": { - "name": "Nachtmahr", - "effect": "Dem schlafenden Ziel wird durch einen Alptraum in jeder Runde Schaden zugefügt, solang es schläft." - }, - "flameWheel": { - "name": "Flammenrad", - "effect": "Feuer-Attacke, die das Ziel eventuell verbrennt." - }, - "snore": { - "name": "Schnarcher", - "effect": "Attacke nur im Schlaf möglich. Ziel schreckt eventuell zurück." - }, - "curse": { - "name": "Fluch", - "effect": "Attacke, deren Wirkung davon abhängt, ob der Anwender ein Geist-Pokémon ist." - }, - "flail": { - "name": "Dreschflegel", - "effect": "Attacke richtet mehr Schaden an, wenn eigene KP niedrig sind." - }, - "conversion2": { - "name": "Umwandlung2", - "effect": "Anwender ändert Typ und wird gegen letzten Angriffstyp resistent." - }, - "aeroblast": { - "name": "Luftstoß", - "effect": "Erzeugt Luftstrudel gegen das Ziel. Hohe Volltrefferquote." - }, - "cottonSpore": { - "name": "Baumwollsaat", - "effect": "Wattebäusche heften sich an das Ziel. Der Initiative-Wert sinkt stark." - }, - "reversal": { - "name": "Gegenschlag", - "effect": "Richtet mehr Schaden an, wenn eigene KP niedrig sind." - }, - "spite": { - "name": "Groll", - "effect": "AP der letzten Attacke des Zieles werden um 4 gesenkt." - }, - "powderSnow": { - "name": "Pulverschnee", - "effect": "Angriff mit Schnee. Das Ziel wird eventuell eingefroren." - }, - "protect": { - "name": "Schutzschild", - "effect": "Anwender weicht jeder Attacke aus. Scheitert eventuell bei Wiederholung." - }, - "machPunch": { - "name": "Tempohieb", - "effect": "Extrem schneller Hieb, der stets zuerst trifft." - }, - "scaryFace": { - "name": "Grimasse", - "effect": "Jagt dem Ziel mit einer Grimasse Angst ein. Dessen Initiative-Wert sinkt stark." - }, - "feintAttack": { - "name": "Finte", - "effect": "Anwender nähert sich mit Unschuldsmiene dem Ziel und schlägt zu, sobald dieses unachtsam wird. Ein Treffer ist gewiss." - }, - "sweetKiss": { - "name": "Bitterkuss", - "effect": "Anwender küsst das Ziel, das durch diese Niedlichkeit verwirrt wird." - }, - "bellyDrum": { - "name": "Bauchtrommel", - "effect": "Der Anwender maximiert den Angriffs-Wert auf Kosten der Hälfte seiner maximalen KP." - }, - "sludgeBomb": { - "name": "Matschbombe", - "effect": "Wirft Schlamm auf das Ziel. Dieses wird eventuell vergiftet." - }, - "mudSlap": { - "name": "Lehmschelle", - "effect": "Schadet dem Ziel durch Matsch. Dessen Genauigkeit sinkt." - }, - "octazooka": { - "name": "Octazooka", - "effect": "Schießt mit Tinte, um Schaden anzurichten und die Genauigkeit zu senken." - }, - "spikes": { - "name": "Stachler", - "effect": "Der Anwender verteilt Stacheln, die gegnerische Pokémon verletzen, die in den Kampf gerufen werden." - }, - "zapCannon": { - "name": "Blitzkanone", - "effect": "Kanonenähnlicher Elektro-Schuss, der schadet und paralysiert." - }, - "foresight": { - "name": "Scharfblick", - "effect": "Erlaubt es, Geist-Pokémon mit Normal- und Kampf-Attacken anzugreifen. Ignoriert den Fluchtwert des Zieles." - }, - "destinyBond": { - "name": "Abgangsbund", - "effect": "Wird der Anwender nach Einsatz dieser Attacke besiegt, führt dies auch beim Ziel zum K.O." - }, - "perishSong": { - "name": "Abgesang", - "effect": "Wer diese Musik hört, wird nach drei Runden besiegt. Rettung ist durch den Eintausch eines neuen Pokémon möglich." - }, - "icyWind": { - "name": "Eissturm", - "effect": "Eis-Attacke, die dem Ziel Schaden zufügt und seinen Initiative-Wert senkt." - }, - "detect": { - "name": "Scanner", - "effect": "Anwender weicht jeder Attacke aus. Scheitert eventuell bei Wiederholung." - }, - "boneRush": { - "name": "Knochenhatz", - "effect": "Greift Ziel zwei- bis fünfmal in Folge mit einem harten Knochen an." - }, - "lockOn": { - "name": "Zielschuss", - "effect": "Visiert das Ziel an und trifft in der nächsten Runde garantiert." - }, - "outrage": { - "name": "Wutanfall", - "effect": "Attacke über zwei bis drei Runden, die den Anwender verwirrt." - }, - "sandstorm": { - "name": "Sandsturm", - "effect": "Sandsturm für fünf Runden. Fügt Pokémon von jedem Typ außer Gestein, Boden und Stahl Schaden zu." - }, - "gigaDrain": { - "name": "Gigasauger", - "effect": "Das Ziel wird angegriffen und die Hälfte des zugefügten Schadens dem Angreifer als KP gutgeschrieben." - }, - "endure": { - "name": "Ausdauer", - "effect": "Nach fatalen Attacken bleibt stets 1 KP übrig. Misserfolg bei Wiederholung möglich." - }, - "charm": { - "name": "Charme", - "effect": "Betört das Ziel und reduziert dessen Angriffs-Wert stark." - }, - "rollout": { - "name": "Walzer", - "effect": "Attacke, die fünf Runden dauert. Die Härte nimmt von Mal zu Mal zu." - }, - "falseSwipe": { - "name": "Trugschlag", - "effect": "Ein Angriff, der dem Ziel zumindest 1 KP lässt." - }, - "swagger": { - "name": "Angeberei", - "effect": "Verwirrt das Ziel und erhöht dessen Angriffs-Wert stark." - }, - "milkDrink": { - "name": "Milchgetränk", - "effect": "KP des Anwenders werden um 50 % der maximalen KP aufgefüllt." - }, - "spark": { - "name": "Funkensprung", - "effect": "Elektro-Hieb, der das Ziel paralysieren kann." - }, - "furyCutter": { - "name": "Zornklinge", - "effect": "Eine Attacke mit Scheren oder Klauen, deren Härte bei aufeinanderfolgenden Treffern zunimmt." - }, - "steelWing": { - "name": "Stahlflügel", - "effect": "Trifft das Ziel mit Stahlflügeln. Verteidigungs-Wert des Anwenders steigt eventuell." - }, - "meanLook": { - "name": "Horrorblick", - "effect": "Böser Blick, der die Flucht des Zieles vereitelt." - }, - "attract": { - "name": "Anziehung", - "effect": "Angriff auf Anwender vom anderen Geschlecht wird unwahrscheinlich." - }, - "sleepTalk": { - "name": "Schlafrede", - "effect": "Anwender setzt per Zufall eine ihm bekannte Attacke im Schlaf ein." - }, - "healBell": { - "name": "Vitalglocke", - "effect": "Läutet beruhigend und heilt alle Statusprobleme im Team." - }, - "return": { - "name": "Rückkehr", - "effect": "Angriff, dessen Kraft bei Freundschaft zum Trainer größer wird." - }, - "present": { - "name": "Geschenk", - "effect": "Eine Bombe als Geschenk. Kann auch KP des Zieles wiederherstellen." - }, - "frustration": { - "name": "Frustration", - "effect": "Die Attacke wird stärker, je weniger der Anwender seinen Trainer mag." - }, - "safeguard": { - "name": "Bodyguard", - "effect": "Team des Anwenders ist fünf Runden vor Statusproblemen geschützt." - }, - "painSplit": { - "name": "Leidteiler", - "effect": "Addiert KP von Anwender und Ziel. Teilt sie gerecht auf." - }, - "sacredFire": { - "name": "Läuterfeuer", - "effect": "Mystische Feuer-Attacke, durch die das Ziel eventuell Verbrennungen erleidet." - }, - "magnitude": { - "name": "Intensität", - "effect": "Erdbebenartiger Angriff von zufälliger Stärke gegen andere Pokémon in der Umgebung des Anwenders." - }, - "dynamicPunch": { - "name": "Wuchtschlag", - "effect": "Kräftiger Schlag, der das Ziel bei Erfolg verwirrt." - }, - "megahorn": { - "name": "Vielender", - "effect": "Brutaler Ramm-Angriff mit spitzem, beeindruckendem Horn." - }, - "dragonBreath": { - "name": "Feuerodem", - "effect": "Fegt das Ziel mit zerstörerisch heißem Atem weg. Paralysiert das Ziel eventuell." - }, - "batonPass": { - "name": "Stafette", - "effect": "Tauscht das eigene Pokémon aus. Alle Statusveränderungen bleiben bestehen." - }, - "encore": { - "name": "Zugabe", - "effect": "Das Ziel wiederholt die letzte Attacke drei Runden lang." - }, - "pursuit": { - "name": "Verfolgung", - "effect": "Die Attacke richtet beim Ziel doppelten Schaden an, falls es ausgetauscht wird." - }, - "rapidSpin": { - "name": "Turbodreher", - "effect": "Trifft das Ziel mit einer Dreh-Attacke. Befreit sich unter anderem von Wickel, Klammergriff, Egelsamen und Stachler." - }, - "sweetScent": { - "name": "Lockduft", - "effect": "Lockt Ziele an und senkt deren Fluchtwert. Lockt im Gras auch wilde Pokémon an." - }, - "ironTail": { - "name": "Eisenschweif", - "effect": "Attacke mit hartem Eisenschweif. Senkt eventuell den Verteidigungs-Wert des Zieles." - }, - "metalClaw": { - "name": "Metallklaue", - "effect": "Klauen-Attacke, die eventuell den Angriffs-Wert des Anwenders erhöht." - }, - "vitalThrow": { - "name": "Überwurf", - "effect": "Anwender greift als Letzter an, hat dafür aber eine Treffergarantie beim eigenen Angriff." - }, - "morningSun": { - "name": "Morgengrauen", - "effect": "Füllt KP des Anwenders auf. Die Menge hängt vom Wetter ab." - }, - "synthesis": { - "name": "Synthese", - "effect": "Füllt KP des Anwenders auf. Die Menge hängt vom Wetter ab." - }, - "moonlight": { - "name": "Mondschein", - "effect": "Füllt KP des Anwenders auf. Die Menge hängt vom Wetter ab." - }, - "hiddenPower": { - "name": "Kraftreserve", - "effect": "Wirkung und Typ der Attacke hängen vom Anwender ab." - }, - "crossChop": { - "name": "Kreuzhieb", - "effect": "Doppelter Hieb mit den Unterarmen. Hohe Volltrefferquote." - }, - "twister": { - "name": "Windhose", - "effect": "Trifft Ziele in der Umgebung mit einem heftigen Wirbelsturm, was diese eventuell zurückschrecken lässt." - }, - "rainDance": { - "name": "Regentanz", - "effect": "Anwender erzeugt starken Regen. Die Stärke von Wasser-Attacken erhöht sich fünf Runden lang." - }, - "sunnyDay": { - "name": "Sonnentag", - "effect": "Die Sonne brennt unbarmherzig fünf Runden lang. Dadurch werden Attacken vom Typ Feuer verstärkt." - }, - "crunch": { - "name": "Knirscher", - "effect": "Beißt mit scharfen Reißzähnen zu und senkt eventuell die Verteidigung." - }, - "mirrorCoat": { - "name": "Spiegelcape", - "effect": "Kontert den Spezial-Angriff des Gegners mit doppeltem Schaden." - }, - "psychUp": { - "name": "Psycho-Plus", - "effect": "Der Anwender hypnotisiert sich selbst, um die Statusveränderungen des Zieles zu kopieren." - }, - "extremeSpeed": { - "name": "Turbotempo", - "effect": "Extrem schnelle und kraftvolle Attacke, die stets zuerst trifft." - }, - "ancientPower": { - "name": "Antik-Kraft", - "effect": "Angriff mit antiker Kraft, der alle Statuswerte erhöhen kann." - }, - "shadowBall": { - "name": "Spukball", - "effect": "Bewirft das Ziel mit gruseligem Ball und senkt eventuell die Spezial-Verteidigung." - }, - "futureSight": { - "name": "Seher", - "effect": "Zwei Runden, nachdem Seher eingesetzt wurde, erfolgt der Angriff." - }, - "rockSmash": { - "name": "Zertrümmerer", - "effect": "Diese steinbrechende Attacke kann den Verteidigungs-Wert des Zieles senken und außerhalb von Kämpfen rissige Felsen zertrümmern." - }, - "whirlpool": { - "name": "Whirlpool", - "effect": "Das Ziel wird für vier bis fünf Runden in einer Wasserhose gefangen." - }, - "beatUp": { - "name": "Prügler", - "effect": "Das gesamte Team nimmt aktiv am Kampf teil. Je mehr Pokémon, desto höher die Anzahl der Angriffe." - }, - "fakeOut": { - "name": "Mogelhieb", - "effect": "Diese Attacke trifft zuerst. Das Ziel schreckt zurück. Gelingt nur in der ersten Runde eines Kampfes." - }, - "uproar": { - "name": "Aufruhr", - "effect": "Anwender greift an, indem er über drei Runden hinweg einen Aufruhr erzeugt. Verhindert Schlaf." - }, - "stockpile": { - "name": "Horter", - "effect": "Lädt Kraft für später auf. Erhöht Verteidigung und Spezial-Verteidigung. Kann bis zu dreimal eingesetzt werden." - }, - "spitUp": { - "name": "Entfessler", - "effect": "Entlädt die Kraft, die während des Einsatzes von Horter gesammelt wurde." - }, - "swallow": { - "name": "Verzehrer", - "effect": "Absorbiert die gehortete Kraft, um KP aufzufüllen." - }, - "heatWave": { - "name": "Hitzewelle", - "effect": "Ziele werden von Sturm aus heißer Luft getroffen und verbrennen sich eventuell." - }, - "hail": { - "name": "Hagelsturm", - "effect": "Hagelsturm für fünf Runden. Schadet allen, außer Eis-Pokémon." - }, - "torment": { - "name": "Folterknecht", - "effect": "Erzürnt das Ziel, um wiederholten Einsatz derselben Attacke zu verhindern." - }, - "flatter": { - "name": "Schmeichler", - "effect": "Schmeichelt dem Ziel, um es zu verwirren. Erhöht dessen Spezial-Angriff." - }, - "willOWisp": { - "name": "Irrlicht", - "effect": "Angriff mit unheimlicher Flamme, die das Ziel verbrennt." - }, - "memento": { - "name": "Memento-Mori", - "effect": "Der Anwender wird besiegt und senkt den Angriffs-Wert und den Spezial-Angriff des Zieles stark." - }, - "facade": { - "name": "Fassade", - "effect": "Doppelte Stärke nach Verbrennung, Paralyse oder Vergiftung." - }, - "focusPunch": { - "name": "Power-Punch", - "effect": "Anwender konzentriert sich, bevor er angreift. Wird er vorher getroffen, ist die Attacke erfolglos." - }, - "smellingSalts": { - "name": "Riechsalz", - "effect": "Doppelt wirksam gegen paralysierte Ziele, heilt sie aber auch von der Paralyse." - }, - "followMe": { - "name": "Spotlight", - "effect": "Zieht Aufmerksamkeit auf sich. Gegner greift nur Anwender an." - }, - "naturePower": { - "name": "Natur-Kraft", - "effect": "Angriff mit der Kraft der Natur, dessen Typ vom Ort abhängt, wo er durchgeführt wird." - }, - "charge": { - "name": "Ladevorgang", - "effect": "Lädt Energie für die kommende Elektro-Attacke auf. Erhöht die Spezial-Verteidigung." - }, - "taunt": { - "name": "Verhöhner", - "effect": "Bringt das Ziel in Rage. Dieses kann über drei Runden hinweg nur noch angreifen." - }, - "helpingHand": { - "name": "Rechte Hand", - "effect": "Anwender steigert die Kraft eines Angriffes eines Freundes." - }, - "trick": { - "name": "Trickbetrug", - "effect": "Der Anwender überrumpelt das Ziel und tauscht mit ihm die getragenen Items." - }, - "rolePlay": { - "name": "Rollenspiel", - "effect": "Parodiert das Ziel und kopiert seine Fähigkeit." - }, - "wish": { - "name": "Wunschtraum", - "effect": "Ein Wunsch füllt in der nächsten Runde 50 % der KP des Anwenders bei diesem oder einem eingewechselten Pokémon auf." - }, - "assist": { - "name": "Zuschuss", - "effect": "Greift zufällig mit einer Attacke eines Mitstreiters an." - }, - "ingrain": { - "name": "Verwurzler", - "effect": "Verwurzelung füllt jede Runde KP auf. Austausch ist unmöglich." - }, - "superpower": { - "name": "Kraftkoloss", - "effect": "Starke Attacke, die jedoch auch den Angriff und die Verteidigung des Anwenders senkt." - }, - "magicCoat": { - "name": "Magiemantel", - "effect": "Egelsamen und alle Attacken mit Status verändernden Effekten prallen ab." - }, - "recycle": { - "name": "Aufbereitung", - "effect": "Recycling eines getragenen Items, das zuvor im Kampf verwendet wurde." - }, - "revenge": { - "name": "Vergeltung", - "effect": "Schaden verdoppelt sich, wenn der Anwender in der Runde bereits Schaden vom Ziel des Angriffes genommen hat." - }, - "brickBreak": { - "name": "Durchbruch", - "effect": "Ein beherzter Handkantenschlag. Durchbricht Barrieren wie Lichtschild und Reflektor." - }, - "yawn": { - "name": "Gähner", - "effect": "Angreifer gähnt und das Ziel schläft in der nächsten Runde ein." - }, - "knockOff": { - "name": "Abschlag", - "effect": "Schlägt das Item des Zieles weg und vereitelt so dessen Gebrauch während des Kampfes. Mehr Schaden gegen Ziele, die ein Item bei sich tragen." - }, - "endeavor": { - "name": "Notsituation", - "effect": "Trifft nur, wenn KP des Anwenders geringer als KP des Zieles sind. Senkt dessen KP auf die Höhe der KP des Anwenders." - }, - "eruption": { - "name": "Eruption", - "effect": "Explosiver Angriff. Je höher die KP des Anwenders sind, desto mehr Schaden wird angerichtet." - }, - "skillSwap": { - "name": "Fähigkeitstausch", - "effect": "Anwender tauscht Fähigkeit mit dem Ziel." - }, - "imprison": { - "name": "Begrenzer", - "effect": "Hindert Gegner am Einsatz von Attacken, die der Anwender selbst auch kennt." - }, - "refresh": { - "name": "Heilung", - "effect": "Selbstheilung bei Vergiftung, Paralyse und Verbrennung." - }, - "grudge": { - "name": "Nachspiel", - "effect": "Bei K.O. des Anwenders werden die AP der Attacke, durch die er besiegt wurde, auf 0 herabgesetzt." - }, - "snatch": { - "name": "Übernahme", - "effect": "Raubt den Effekt eingesetzter heilender oder Werte verändernder Attacken." - }, - "secretPower": { - "name": "Geheimpower", - "effect": "Angriff, der abhängig vom Anwendungsort einen unterschiedlichen Zusatz-Effekt hat." - }, - "dive": { - "name": "Taucher", - "effect": "Taucht in Runde 1 ab und greift in Runde 2 aus der Tiefe an." - }, - "armThrust": { - "name": "Armstoß", - "effect": "Schläge mit geradem Arm, die das Ziel zwei- bis fünfmal treffen." - }, - "camouflage": { - "name": "Tarnung", - "effect": "Der Typ des Anwenders passt sich der Umgebung an, sei es im Wasser, im Gras oder in einer Höhle." - }, - "tailGlow": { - "name": "Schweifglanz", - "effect": "Ein blinkendes Licht, das den Spezial-Angriff drastisch erhöht." - }, - "lusterPurge": { - "name": "Scheinwerfer", - "effect": "Angriff mit grellem Licht, der die Spezial-Verteidigung des Zieles eventuell senkt." - }, - "mistBall": { - "name": "Nebelball", - "effect": "Angriff mit einer Kugel aus Wasser, die Nebel enthält. Senkt eventuell den Spezial-Angriff des Zieles." - }, - "featherDance": { - "name": "Daunenreigen", - "effect": "Hüllt das Ziel in Daunen und senkt dessen Angriffs-Wert stark." - }, - "teeterDance": { - "name": "Taumeltanz", - "effect": "Ein Wackeltanz, der andere Pokémon in der Umgebung des Anwenders verwirrt." - }, - "blazeKick": { - "name": "Feuerfeger", - "effect": "Starker Tritt mit hoher Volltrefferquote. Verursacht eventuell Verbrennung." - }, - "mudSport": { - "name": "Lehmsuhler", - "effect": "Schwächt Elektro-Attacken, solang der Anwender am Kampf teilnimmt." - }, - "iceBall": { - "name": "Frostbeule", - "effect": "Attacke, die fünf Runden dauert. Die Härte nimmt von Mal zu Mal zu." - }, - "needleArm": { - "name": "Nietenranke", - "effect": "Angriff mit dornigen Armen. Das Ziel schreckt eventuell zurück." - }, - "slackOff": { - "name": "Tagedieb", - "effect": "Durch Müßiggang werden KP des Anwenders um 50 % der maximalen KP aufgefüllt." - }, - "hyperVoice": { - "name": "Schallwelle", - "effect": "Laute Attacke mit Schallwellen." - }, - "poisonFang": { - "name": "Giftzahn", - "effect": "Angriff mit giftigen Reißzähnen. Das Ziel wird eventuell schwer vergiftet." - }, - "crushClaw": { - "name": "Zermalmklaue", - "effect": "Angriff mit scharfen Klauen. Senkt eventuell den Verteidigungs-Wert." - }, - "blastBurn": { - "name": "Lohekanonade", - "effect": "Das Ziel wird von starker Explosion getroffen. Angreifer setzt eine Runde aus." - }, - "hydroCannon": { - "name": "Aquahaubitze", - "effect": "Das Ziel wird von Wasserkanone getroffen. Angreifer setzt eine Runde aus." - }, - "meteorMash": { - "name": "Sternenhieb", - "effect": "Angriff mit einem harten, schnellen Schlag. Erhöht eventuell Angriffs-Wert des Anwenders." - }, - "astonish": { - "name": "Erstauner", - "effect": "Anwender greift mit einem Schrei an. Ein Angriff, der das Ziel eventuell zurückschrecken lässt." - }, - "weatherBall": { - "name": "Meteorologe", - "effect": "Typ und Stärke der Attacke sind vom Wetter zum Zeitpunkt der Anwendung abhängig." - }, - "aromatherapy": { - "name": "Aromakur", - "effect": "Heilt alle Statusprobleme des Teams mit beruhigendem Duft." - }, - "fakeTears": { - "name": "Trugträne", - "effect": "Täuscht Weinen vor, um die Spezial-Verteidigung des Zieles stark zu senken." - }, - "airCutter": { - "name": "Windschnitt", - "effect": "Greift mit rasierklingenartigem Wind an. Hohe Volltrefferquote." - }, - "overheat": { - "name": "Hitzekoller", - "effect": "Angriff mit voller Kraft, der den Spezial-Angriff des Anwenders durch den Rückstoß stark senkt." - }, - "odorSleuth": { - "name": "Schnüffler", - "effect": "Erlaubt es, Geist-Pokémon mit Normal- und Kampf-Attacken anzugreifen. Ignoriert den Fluchtwert des Zieles." - }, - "rockTomb": { - "name": "Felsgrab", - "effect": "Angriff mit Felsen. Bei Erfolg wird der Initiative-Wert des Zieles gesenkt." - }, - "silverWind": { - "name": "Silberhauch", - "effect": "Angriff mit Silberstaub. Eventuell werden alle Statuswerte des Anwenders erhöht." - }, - "metalSound": { - "name": "Metallsound", - "effect": "Stößt einen spitzen Schrei aus, der die Spezial-Verteidigung des Zieles stark senkt." - }, - "grassWhistle": { - "name": "Grasflöte", - "effect": "Versetzt das Ziel durch eine schöne Melodie in Tiefschlaf." - }, - "tickle": { - "name": "Spaßkanone", - "effect": "Bringt das Ziel zum Lachen und senkt dadurch dessen Angriff und Verteidigung." - }, - "cosmicPower": { - "name": "Kosmik-Kraft", - "effect": "Erhöht Verteidigung und Spezial-Verteidigung durch eine mystische Kraft." - }, - "waterSpout": { - "name": "Fontränen", - "effect": "Wasser-Attacke, die wirkungsvoller ist, wenn KP des Anwenders hoch sind." - }, - "signalBeam": { - "name": "Ampelleuchte", - "effect": "Strahlenattacke, die das Ziel eventuell verwirrt." - }, - "shadowPunch": { - "name": "Finsterfaust", - "effect": "Angriff mit der Faust aus dem Schattenreich. Ausweichen unmöglich." - }, - "extrasensory": { - "name": "Sondersensor", - "effect": "Besonderer Angriff mit einer unsichtbaren Kraft, die das Ziel eventuell zurückschrecken lässt." - }, - "skyUppercut": { - "name": "Himmelhieb", - "effect": "Kinnhaken, der das Ziel gen Himmel schickt." - }, - "sandTomb": { - "name": "Sandgrab", - "effect": "Das Ziel leidet für vier bis fünf Runden in einer Sandhose." - }, - "sheerCold": { - "name": "Eiseskälte", - "effect": "Angriff mit Kälte, die das Ziel bei Erfolg besiegt." - }, - "muddyWater": { - "name": "Lehmbrühe", - "effect": "Greift mit Matsch an und senkt eventuell die Genauigkeit des Zieles." - }, - "bulletSeed": { - "name": "Kugelsaat", - "effect": "Der Anwender wirft zwei- bis fünfmal in rascher Folge Samen auf das Ziel." - }, - "aerialAce": { - "name": "Aero-Ass", - "effect": "Eine extrem schnelle Attacke, der das Ziel nicht ausweichen kann." - }, - "icicleSpear": { - "name": "Eisspeer", - "effect": "Feuert zwei bis fünf Eiszapfen auf das Ziel." - }, - "ironDefense": { - "name": "Eisenabwehr", - "effect": "Anwender stärkt den Körper, um den Verteidigungs-Wert stark zu erhöhen." - }, - "block": { - "name": "Rückentzug", - "effect": "Anwender versperrt den Fluchtweg des Zieles." - }, - "howl": { - "name": "Jauler", - "effect": "Anwender jault, um seinen Kampfgeist und seinen Angriffs-Wert zu erhöhen." - }, - "dragonClaw": { - "name": "Drachenklaue", - "effect": "Das Ziel wird mit riesigen, scharfen Klauen stark verletzt." - }, - "frenzyPlant": { - "name": "Flora-Statue", - "effect": "Angriff mit dickem Ast. Der Angreifer muss eine Runde aussetzen." - }, - "bulkUp": { - "name": "Protzer", - "effect": "Pumpt den Körper auf, um den Angriff und die Verteidigung zu erhöhen." - }, - "bounce": { - "name": "Sprungfeder", - "effect": "Angreifer springt und landet in der nächsten Runde auf dem Ziel. Das Ziel wird eventuell paralysiert." - }, - "mudShot": { - "name": "Lehmschuss", - "effect": "Angriff mit Lehm, der den Initiative-Wert des Zieles senkt." - }, - "poisonTail": { - "name": "Giftschweif", - "effect": "Angriff mit hoher Volltrefferquote. Diese Schweifattacke vergiftet das Ziel eventuell." - }, - "covet": { - "name": "Bezirzer", - "effect": "Bittet charmant um das getragene Item des Zieles und stiehlt es dann." - }, - "voltTackle": { - "name": "Volttackle", - "effect": "Angriff mit Elektro-Tackle. Der Anwender verletzt sich dabei. Das Ziel wird eventuell paralysiert." - }, - "magicalLeaf": { - "name": "Zauberblatt", - "effect": "Magischer Blattangriff, dem nicht auszuweichen ist." - }, - "waterSport": { - "name": "Nassmacher", - "effect": "Der Anwender lässt Wasser herabregnen und schwächt damit fünf Runden lang Feuer-Attacken." - }, - "calmMind": { - "name": "Gedankengut", - "effect": "Erhöht Spezial-Angriff und Spezial-Verteidigung durch Konzentration." - }, - "leafBlade": { - "name": "Laubklinge", - "effect": "Hieb mit scharfkantigem Blatt. Hohe Volltrefferquote." - }, - "dragonDance": { - "name": "Drachentanz", - "effect": "Ein mystischer Tanz, der den Angriffs- und Initiative-Wert erhöht." - }, - "rockBlast": { - "name": "Felswurf", - "effect": "Wirft zwei- bis fünfmal in Folge Felsblöcke auf das Ziel." - }, - "shockWave": { - "name": "Schockwelle", - "effect": "Angriff mit schnellem Elektro-Schlag. Ausweichen nicht möglich." - }, - "waterPulse": { - "name": "Aquawelle", - "effect": "Angriff mit Wasserwelle, die das Ziel eventuell verwirren kann." - }, - "doomDesire": { - "name": "Kismetwunsch", - "effect": "Angriff mit gebündeltem Licht erfolgt zwei Runden nach Attackeneinsatz." - }, - "psychoBoost": { - "name": "Psyschub", - "effect": "Angriff mit voller Kraft, der den Spezial-Angriff des Anwenders durch den Rückstoß stark senkt." - }, - "roost": { - "name": "Ruheort", - "effect": "Anwender landet und ruht sich aus. KP des Anwenders werden um 50 % der maximalen KP aufgefüllt." - }, - "gravity": { - "name": "Erdanziehung", - "effect": "Die Gravitation wird für fünf Runden erhöht. Macht Fliegen unmöglich und verhindert Schwebe." - }, - "miracleEye": { - "name": "Wunderauge", - "effect": "Erlaubt es, Unlicht-Pokémon mit Psycho-Attacken anzugreifen. Ignoriert den Fluchtwert des Zieles." - }, - "wakeUpSlap": { - "name": "Weckruf", - "effect": "Richtet großen Schaden bei einem schlafenden Ziel an, weckt es aber auch auf." - }, - "hammerArm": { - "name": "Hammerarm", - "effect": "Anwender trifft mit einem starken Hieb. Senkt Initiative des Anwenders." - }, - "gyroBall": { - "name": "Gyroball", - "effect": "Angriff mit hoher Geschwindigkeit. Je niedriger die Initiative des Anwenders, desto höher der Schaden." - }, - "healingWish": { - "name": "Heilopfer", - "effect": "Anwender geht K.O. Das an seine Stelle tretende Pokémon hat volle KP. Statusprobleme werden geheilt." - }, - "brine": { - "name": "Lake", - "effect": "Hat das Ziel die Hälfte oder weniger seiner maximalen KP, trifft diese Attacke mit doppelter Kraft." - }, - "naturalGift": { - "name": "Beerenkräfte", - "effect": "Anwender zieht aus seiner derzeitigen Beere Kraft. Sie bestimmt Typ und Stärke der Attacke." - }, - "feint": { - "name": "Offenlegung", - "effect": "Ziele, die Schutzschild oder Scanner verwenden, werden getroffen. Entfernt Effekte dieser Attacken." - }, - "pluck": { - "name": "Pflücker", - "effect": "Anwender pickt das Ziel, nimmt die Beere, falls das Ziel eine trägt, und erhält ihren Effekt." - }, - "tailwind": { - "name": "Rückenwind", - "effect": "Anwender erzeugt einen Wirbelwind, der die Initiative aller Pokémon im Team für vier Runden steigert." - }, - "acupressure": { - "name": "Akupressur", - "effect": "Anwender erhöht Druck auf Stresspunkte und steigert einen Statuswert stark." - }, - "metalBurst": { - "name": "Metallstoß", - "effect": "Attacke mit großer Kraft gegen das Ziel, das dem Anwender in derselben Runde zuletzt Schaden zufügte." - }, - "uTurn": { - "name": "Kehrtwende", - "effect": "Nach der Attacke eilt der Anwender zurück und tauscht den Platz mit einem anderen Pokémon." - }, - "closeCombat": { - "name": "Nahkampf", - "effect": "Nahkampf-Attacke ohne Rücksicht auf Verluste. Senkt Verteidigung und Spezial-Verteidigung des Anwenders." - }, - "payback": { - "name": "Gegenstoß", - "effect": "Der Anwender lädt die Attacke auf. Handelt das Ziel vor dem Anwender, verdoppelt sich die Kraft der Attacke." - }, - "assurance": { - "name": "Gewissheit", - "effect": "Hat das Ziel während der Runde schon Schaden genommen, wird die Kraft der Attacke verdoppelt." - }, - "embargo": { - "name": "Itemsperre", - "effect": "Verhindert, dass auf das Ziel Items verwendet werden." - }, - "fling": { - "name": "Schleuder", - "effect": "Anwender schleudert sein Item auf das Ziel. Kraft und Effekt der Attacke hängen vom Item ab." - }, - "psychoShift": { - "name": "Psybann", - "effect": "Anwender nutzt seine Suggestivkräfte, um eigene Statusprobleme auf das Ziel zu transferieren." - }, - "trumpCard": { - "name": "Trumpfkarte", - "effect": "Je weniger AP diese Attacke hat, desto mehr Angriffskraft besitzt sie." - }, - "healBlock": { - "name": "Heilblockade", - "effect": "Anwender verhindert für fünf Runden, dass Ziele durch Attacken, Fähigkeiten oder Items KP regenerieren." - }, - "wringOut": { - "name": "Auswringen", - "effect": "Anwender presst sein Ziel aus. Je höher die KP des Zieles, desto kraftvoller die Attacke." - }, - "powerTrick": { - "name": "Krafttrick", - "effect": "Anwender setzt Psycho-Kräfte ein, um eigenen Angriffs- mit Verteidigungs-Wert auszutauschen." - }, - "gastroAcid": { - "name": "Magensäfte", - "effect": "Anwender greift das Ziel mit eigenen Magensäften an. Entfernt Effekte von dessen Fähigkeit." - }, - "luckyChant": { - "name": "Beschwörung", - "effect": "Anwender singt eine Beschwörungsformel, die Volltreffer gegen ihn verhindert." - }, - "meFirst": { - "name": "Egotrip", - "effect": "Anwender stiehlt und führt die Attacke eines langsameren Zieles zuerst und mit größerer Kraft aus." - }, - "copycat": { - "name": "Imitator", - "effect": "Anwender imitiert gerade verwendete Attacke. Dies schlägt fehl, falls zuvor keine Attacke verwendet wurde." - }, - "powerSwap": { - "name": "Krafttausch", - "effect": "Psychische Kräfte tauschen Änderungen an Angriff und Spezial-Angriff mit denen des Zieles." - }, - "guardSwap": { - "name": "Schutztausch", - "effect": "Psychische Kräfte tauschen Änderungen an Verteidigung und Spezial-Verteidigung mit denen des Zieles." - }, - "punishment": { - "name": "Strafattacke", - "effect": "Je stärker das Ziel durch Statusveränderungen ist, desto stärker wirkt diese Attacke." - }, - "lastResort": { - "name": "Zuflucht", - "effect": "Diese Attacke kann nur eingesetzt werden, nachdem alle verfügbaren Attacken ausgeführt worden sind." - }, - "worrySeed": { - "name": "Sorgensamen", - "effect": "Ziel wird bepflanzt. Wandelt Fähigkeit in Insomnia um. Verhindert so Schlaf." - }, - "suckerPunch": { - "name": "Tiefschlag", - "effect": "Ermöglicht den Erstschlag. Gelingt aber nur, wenn das Ziel gerade eine Attacke vorbereitet." - }, - "toxicSpikes": { - "name": "Giftspitzen", - "effect": "Anwender legt eine Falle mit Giftdornen aus. In den Kampf eingewechselte gegnerische Pokémon werden vergiftet." - }, - "heartSwap": { - "name": "Statustausch", - "effect": "Anwender setzt Psycho-Kräfte ein, um Statusveränderungen des Zieles mit den eigenen zu tauschen." - }, - "aquaRing": { - "name": "Wasserring", - "effect": "Anwender umgibt sich mit einem Schleier aus Wasser. Dabei regeneriert er einige KP pro Runde." - }, - "magnetRise": { - "name": "Magnetflug", - "effect": "Anwender schwebt für fünf Runden durch elektrisch erzeugten Magnetismus." - }, - "flareBlitz": { - "name": "Flammenblitz", - "effect": "Anwender hüllt sich in Flammen und stürmt auf das Ziel zu, das sich eventuell verbrennt. Anwender nimmt selbst großen Schaden." - }, - "forcePalm": { - "name": "Kraftwelle", - "effect": "Das Ziel wird mit einer Schockwelle angegriffen, die es eventuell paralysiert." - }, - "auraSphere": { - "name": "Aurasphäre", - "effect": "Tief aus dem Inneren des Anwenders löst sich ein kraftvoller Stoß Auraenergie. Trifft in jedem Fall." - }, - "rockPolish": { - "name": "Steinpolitur", - "effect": "Anwender reduziert so gut wie möglich den Luftwiderstand. Kann Initiative-Wert stark steigern." - }, - "poisonJab": { - "name": "Gifthieb", - "effect": "Ziel wird mit vergiftetem Arm oder Tentakel verletzt. Es wird dabei eventuell vergiftet." - }, - "darkPulse": { - "name": "Finsteraura", - "effect": "Anwender greift mit fürchterlicher Aura schlechter Gedanken an. Ziel schreckt eventuell zurück." - }, - "nightSlash": { - "name": "Nachthieb", - "effect": "Anwender greift bei der ersten Gelegenheit mit scharfen Klauen an. Hohe Volltrefferquote." - }, - "aquaTail": { - "name": "Nassschweif", - "effect": "Anwender attackiert mit dem Schweif, als ob dieser eine brutale Welle in einem tosenden Sturm sei." - }, - "seedBomb": { - "name": "Samenbomben", - "effect": "Anwender lässt eine Menge Samen mit harter Schale von oben auf das Ziel fallen." - }, - "airSlash": { - "name": "Luftschnitt", - "effect": "Das Ziel wird mit einer Luftklinge angegriffen. Ziel schreckt eventuell zurück." - }, - "xScissor": { - "name": "Kreuzschere", - "effect": "Der Anwender führt eine Attacke aus, die einer Scherenbewegung ähnelt." - }, - "bugBuzz": { - "name": "Käfergebrumm", - "effect": "Anwender schlägt mit den Flügeln und erzeugt eine Schockwelle. Senkt eventuell Spezial-Verteidigung des Zieles." - }, - "dragonPulse": { - "name": "Drachenpuls", - "effect": "Das Ziel wird mit einer Schockwelle angegriffen, die aus dem offenen Maul des Anwenders kommt." - }, - "dragonRush": { - "name": "Drachenstoß", - "effect": "Anwender führt einen gefährlichen Angriff aus. Das Ziel schreckt eventuell zurück." - }, - "powerGem": { - "name": "Juwelenkraft", - "effect": "Anwender attackiert mit einem Lichtstrahl, der funkelt, als sei er aus Juwelen." - }, - "drainPunch": { - "name": "Ableithieb", - "effect": "Entzieht dem Ziel Energie. Die Hälfte des Schadens wird den KP des Anwenders zugerechnet." - }, - "vacuumWave": { - "name": "Vakuumwelle", - "effect": "Ein Faustwirbel sendet eine Vakuumwelle auf das Ziel. Erstschlaggarantie." - }, - "focusBlast": { - "name": "Fokusstoß", - "effect": "Anwender erhöht seinen mentalen Fokus und greift dann an. Senkt eventuell Spezial-Verteidigung des Zieles." - }, - "energyBall": { - "name": "Energieball", - "effect": "Anwender zieht Kraft aus der Natur und feuert sie auf das Ziel. Senkt eventuell Spezial-Verteidigung des Zieles." - }, - "braveBird": { - "name": "Sturzflug", - "effect": "Anwender greift aus niedriger Höhe an. Er erleidet bei dieser Attacke selbst großen Schaden." - }, - "earthPower": { - "name": "Erdkräfte", - "effect": "Der Boden unter dem Ziel erzittert durch die Kraft der Erde. Senkt eventuell Spezial-Verteidigung." - }, - "switcheroo": { - "name": "Wechseldich", - "effect": "Item wird in Windeseile mit dem Ziel getauscht." - }, - "gigaImpact": { - "name": "Gigastoß", - "effect": "Anwender rennt mit seiner ganzen Kraft gegen das Ziel an und muss dann eine Runde ruhen." - }, - "nastyPlot": { - "name": "Ränkeschmied", - "effect": "Anwender stimuliert sein Gehirn und hat finstere Gedanken. Steigert Spezial-Angriff stark." - }, - "bulletPunch": { - "name": "Patronenhieb", - "effect": "Das Ziel wird von ultraschnellen Hieben getroffen. Erstschlaggarantie." - }, - "avalanche": { - "name": "Lawine", - "effect": "Wurde der Anwender in dieser Runde vom Ziel getroffen, macht diese Attacke doppelten Schaden." - }, - "iceShard": { - "name": "Eissplitter", - "effect": "Das Ziel wird mit Eisklumpen beworfen. Diese Attacke hat Erstschlaggarantie." - }, - "shadowClaw": { - "name": "Dunkelklaue", - "effect": "Das Ziel wird mit scharfen Klauen aus der Schattenwelt attackiert. Hohe Volltrefferquote." - }, - "thunderFang": { - "name": "Donnerzahn", - "effect": "Anwender beißt mit elektrifizierten Reißzähnen zu. Das Ziel schreckt eventuell zurück oder wird paralysiert." - }, - "iceFang": { - "name": "Eiszahn", - "effect": "Anwender beißt mit eiskalten Reißzähnen zu. Ziel schreckt eventuell zurück oder friert ein." - }, - "fireFang": { - "name": "Feuerzahn", - "effect": "Anwender beißt mit flammenden Reißzähnen zu. Ziel schreckt eventuell zurück oder verbrennt sich." - }, - "shadowSneak": { - "name": "Schattenstoß", - "effect": "Anwender erweitert Schatten und greift das Ziel von hinten an. Erstschlaggarantie." - }, - "mudBomb": { - "name": "Schlammbombe", - "effect": "Anwender greift mit einem festen Schlammklumpen an. Senkt eventuell Genauigkeit des Zieles." - }, - "psychoCut": { - "name": "Psychoklinge", - "effect": "Das Ziel wird mit Klingen attackiert, die aus Psycho-Energie bestehen. Hohe Volltrefferquote." - }, - "zenHeadbutt": { - "name": "Zen-Kopfstoß", - "effect": "Anwender konzentriert seinen Willen und rammt das Ziel. Dieses schreckt eventuell zurück." - }, - "mirrorShot": { - "name": "Spiegelsalve", - "effect": "Anwender feuert Energiestrahl aus seinem Körper ab. Senkt eventuell Genauigkeit des Zieles." - }, - "flashCannon": { - "name": "Lichtkanone", - "effect": "Anwender sammelt Lichtenergie und feuert sie auf einmal ab. Senkt eventuell Spezial-Verteidigung des Zieles." - }, - "rockClimb": { - "name": "Kraxler", - "effect": "Eine stürmische Attacke, die das Ziel eventuell verwirrt." - }, - "defog": { - "name": "Auflockern", - "effect": "Starker Wind hebt Attacken wie Reflektor und Lichtschild des Zieles auf. Senkt außerdem den Fluchtwert." - }, - "trickRoom": { - "name": "Bizarroraum", - "effect": "Anwender erzeugt einen bizarren Raum, in dem langsame Pokémon fünf Runden lang zuerst agieren." - }, - "dracoMeteor": { - "name": "Draco Meteor", - "effect": "Kometen werden heraufbeschworen. Der Rückstoß reduziert den Spezial-Angriff des Anwenders stark." - }, - "discharge": { - "name": "Ladungsstoß", - "effect": "Anwender greift alle Pokémon im Umkreis mit Elektrizität an. Diese werden eventuell auch paralysiert." - }, - "lavaPlume": { - "name": "Flammensturm", - "effect": "Greift alles in seiner Umgebung mit tiefroten Flammen an. Ziel kann Verbrennungen erleiden." - }, - "leafStorm": { - "name": "Blättersturm", - "effect": "Anwender erzeugt einen Sturm aus scharfen Blättern. Rückstoß senkt Spezial-Angriff des Anwenders stark." - }, - "powerWhip": { - "name": "Blattgeißel", - "effect": "Anwender wirbelt seine Ranken oder Tentakel peitschenartig gegen das Ziel." - }, - "rockWrecker": { - "name": "Felswerfer", - "effect": "Anwender wirft einen riesigen Felsen auf das Ziel. In der nächsten Runde muss der Anwender ruhen." - }, - "crossPoison": { - "name": "Giftstreich", - "effect": "Ein schneidender Hieb, der das Ziel eventuell vergiftet. Hat eine hohe Volltrefferquote." - }, - "gunkShot": { - "name": "Mülltreffer", - "effect": "Anwender schießt mit Müll auf das Ziel. Vergiftet dieses eventuell." - }, - "ironHead": { - "name": "Eisenschädel", - "effect": "Ziel wird durch stahlharten Kopf des Anwenders getroffen und schreckt eventuell zurück." - }, - "magnetBomb": { - "name": "Magnetbombe", - "effect": "Ziel wird durch Haftbomben getroffen. Diese Attacke trifft immer." - }, - "stoneEdge": { - "name": "Steinkante", - "effect": "Anwender sticht das Ziel mit spitzen Steinen. Hohe Volltrefferquote." - }, - "captivate": { - "name": "Liebreiz", - "effect": "Charme-Attacke, die den Spezial-Angriff des Zieles stark senkt, falls es dem anderen Geschlecht angehört." - }, - "stealthRock": { - "name": "Tarnsteine", - "effect": "Falle mit schwebenden Steinen. In den Kampf eingewechselte Ziele nehmen Schaden." - }, - "grassKnot": { - "name": "Strauchler", - "effect": "Ziel wird durch Gras ins Straucheln gebracht. Je schwerer das Ziel, desto mehr Schaden." - }, - "chatter": { - "name": "Geschwätz", - "effect": "Attacke mit Schallwellen. Verwirrt das Ziel." - }, - "judgment": { - "name": "Urteilskraft", - "effect": "Anwender feuert unzählige Lichtstrahlen ab. Deren Typ hängt von der gehaltenen Tafel ab." - }, - "bugBite": { - "name": "Käferbiss", - "effect": "Anwender beißt das Ziel. Trägt dieses eine Beere, isst der Anwender sie und erhält ihren Effekt." - }, - "chargeBeam": { - "name": "Ladestrahl", - "effect": "Ziel wird von einem Elektrostrahl getroffen. Steigert eventuell Spezial-Angriff des Anwenders." - }, - "woodHammer": { - "name": "Holzhammer", - "effect": "Anwender attackiert mit seinem robusten Körper. Er erleidet dabei auch selbst großen Schaden." - }, - "aquaJet": { - "name": "Wasserdüse", - "effect": "Bei dieser Erstschlag-Attacke stürzt sich der Anwender so schnell auf das Ziel, dass er quasi unsichtbar wird." - }, - "attackOrder": { - "name": "Schlagbefehl", - "effect": "Anwender ruft seine Untergebenen zum Angriff. Hat eine hohe Volltrefferquote." - }, - "defendOrder": { - "name": "Blockbefehl", - "effect": "Untergebene bilden einen lebenden Schild um den Anwender. Steigert Verteidigung und Spezial-Verteidigung." - }, - "healOrder": { - "name": "Heilbefehl", - "effect": "Untergebene heilen den Anwender. KP des Anwenders werden um 50 % der maximalen KP aufgefüllt." - }, - "headSmash": { - "name": "Kopfstoß", - "effect": "Anwender greift unter Einsatz seines Lebens mit einem Kopfstoß an und nimmt dabei selbst jede Menge Schaden." - }, - "doubleHit": { - "name": "Doppelschlag", - "effect": "Anwender trifft das Ziel mit dem Schweif oder Ähnlichem. Ziel wird doppelt getroffen." - }, - "roarOfTime": { - "name": "Zeitenlärm", - "effect": "Anwender attackiert mit einer Kraft, die selbst die Zeit verzerrt. In der nächsten Runde muss er ruhen." - }, - "spacialRend": { - "name": "Raumschlag", - "effect": "Schwere, raumgreifende Attacke. Hohe Volltrefferquote." - }, - "lunarDance": { - "name": "Lunartanz", - "effect": "Anwender geht K.O. Das an seine Stelle tretende Pokémon hat dafür volle KP und AP. Statusprobleme werden geheilt." - }, - "crushGrip": { - "name": "Quetschgriff", - "effect": "Ziel wird mit großer Kraft getroffen. Je höher die KP des Zieles, desto stärker die Attacke." - }, - "magmaStorm": { - "name": "Lavasturm", - "effect": "Das Ziel wird in einen Feuersog gezogen, der vier bis fünf Runden aktiv ist." - }, - "darkVoid": { - "name": "Schlummerort", - "effect": "Das Ziel wird in eine Welt der Dunkelheit gezogen und in Schlaf versetzt." - }, - "seedFlare": { - "name": "Schocksamen", - "effect": "Anwender erzeugt eine Schockwelle. Spezial-Verteidigung des Zieles wird stark gesenkt." - }, - "ominousWind": { - "name": "Unheilböen", - "effect": "Das Ziel treffen abscheuliche Winde. Steigert eventuell alle Statuswerte des Anwenders." - }, - "shadowForce": { - "name": "Schemenkraft", - "effect": "Anwender verschwindet in Runde 1 und attackiert in Runde 2. Trifft auch, wenn sich das Ziel selbst schützt." - }, - "honeClaws": { - "name": "Klauenwetzer", - "effect": "Wetzt seine Klauen, um sie zu schärfen. Erhöht Angriff und Genauigkeit des Anwenders." - }, - "wideGuard": { - "name": "Rundumschutz", - "effect": "Schützt eine Runde lang vor Angriffen, die alle Pokémon auf deiner Seite treffen." - }, - "guardSplit": { - "name": "Schutzteiler", - "effect": "Durch Psycho-Kräfte werden Verteidigung und Spezial-Verteidigung des Anwenders und des Zieles addiert und in zwei gleiche Hälften geteilt." - }, - "powerSplit": { - "name": "Kraftteiler", - "effect": "Durch Psycho-Kräfte werden Angriff und Spezial-Angriff des Anwenders und des Zieles addiert und in zwei gleiche Hälften geteilt." - }, - "wonderRoom": { - "name": "Wunderraum", - "effect": "Anwender erzeugt bizarren Raum, in dem über fünf Runden die Verteidigung aller Pokémon mit ihrer Spezial-Verteidigung getauscht wird." - }, - "psyshock": { - "name": "Psychoschock", - "effect": "Anwender erzeugt eine seltsame Energiewelle, die dem Ziel physischen Schaden zufügt." - }, - "venoshock": { - "name": "Giftschock", - "effect": "Überschüttet das Ziel mit einer speziellen toxischen Flüssigkeit. Doppelt so stark gegen vergiftete Ziele." - }, - "autotomize": { - "name": "Autotomie", - "effect": "Anwender trennt sich von überflüssigen Körperteilen und steigert seine Initiative stark. Sein Gewicht nimmt deutlich ab." - }, - "ragePowder": { - "name": "Wutpulver", - "effect": "Anwender zieht gegnerische Aufmerksamkeit und Angriffe auf sich, indem er ein Wut erzeugendes Pulver über sich streut." - }, - "telekinesis": { - "name": "Telekinese", - "effect": "Bringt das Ziel durch Psycho-Kräfte zum Schweben. Dieses lässt sich so über drei Runden hinweg besonders leicht treffen." - }, - "magicRoom": { - "name": "Magieraum", - "effect": "Anwender erzeugt einen bizarren Raum, in dem über fünf Runden die Wirkung aller von Pokémon getragenen Items aufgehoben ist." - }, - "smackDown": { - "name": "Katapult", - "effect": "Greift das Ziel mit Steinen und Wurfgeschossen an. Fliegende Ziele fallen dabei vom Himmel und landen auf dem Boden." - }, - "stormThrow": { - "name": "Bergsturm", - "effect": "Ein Angriff mit voller Wucht und Volltreffergarantie." - }, - "flameBurst": { - "name": "Funkenflug", - "effect": "Bei Erfolg greift der Anwender mit berstenden Feuerblasen an. Die Funken der geplatzten Blasen treffen auch benachbarte Ziele." - }, - "sludgeWave": { - "name": "Schlammwoge", - "effect": "Greift Pokémon in der Nähe des Anwenders mit einer Schlammwelle an. Diese werden eventuell vergiftet." - }, - "quiverDance": { - "name": "Falterreigen", - "effect": "Anwender legt behände einen mystischen, formvollendeten Tanz aufs Parkett. Spezial-Angriff, Spezial-Verteidigung und Initiative steigen." - }, - "heavySlam": { - "name": "Rammboss", - "effect": "Anwender rammt das Ziel mit massivem Körper. Je schwerer er im Vergleich zum Ziel ist, desto stärker die Attacke." - }, - "synchronoise": { - "name": "Synchrolärm", - "effect": "Fügt Pokémon vom selben Typ, die sich in der Nähe des Anwenders aufhalten, mit seltsamen Druckwellen Schaden zu." - }, - "electroBall": { - "name": "Elektroball", - "effect": "Je höher die Initiative des Anwenders im Vergleich zum Ziel ist, desto stärker trifft dieses eine geballte Ladung Strom." - }, - "soak": { - "name": "Überflutung", - "effect": "Überschüttet das Ziel mit Unmengen an Wasser und ändert den Typ damit in Wasser um." - }, - "flameCharge": { - "name": "Nitroladung", - "effect": "Anwender hüllt sich in Flammen und greift das Ziel an. Sammelt seine Energie und erhöht dadurch die eigene Initiative." - }, - "coil": { - "name": "Einrollen", - "effect": "Anwender rollt sich zusammen und sammelt sich. Dabei werden Angriff, Verteidigung und Genauigkeit erhöht." - }, - "lowSweep": { - "name": "Fußtritt", - "effect": "Anwender greift mit blitzschnellen Bewegungen die Beine des Zieles an und senkt dessen Initiative." - }, - "acidSpray": { - "name": "Säurespeier", - "effect": "Anwender greift an, indem er eine ätzende Flüssigkeit auf das Ziel speit. Senkt dessen Spezial-Verteidigung stark." - }, - "foulPlay": { - "name": "Schmarotzer", - "effect": "Anwender macht sich die Kraft des Zieles zunutze. Je höher dessen Angriff, desto mehr Schaden richtet die Attacke an." - }, - "simpleBeam": { - "name": "Wankelstrahl", - "effect": "Bestrahlt das Ziel mit mysteriösen Energiewellen. Bei einem Treffer wird dessen Fähigkeit zu Wankelmut." - }, - "entrainment": { - "name": "Zwango", - "effect": "Anwender tanzt zu einem seltsamem Rhythmus und zwingt das Ziel mitzumachen. Dieses nimmt dabei die Fähigkeit des Anwenders an." - }, - "afterYou": { - "name": "Galanterie", - "effect": "Anwender ermöglicht dem Ziel direkt nach ihm zu handeln, solange der Anwender als Erstes zum Zug kommt." - }, - "round": { - "name": "Kanon", - "effect": "Angriff mit Gesang. Singt der Anwender mit allen im Kanon, steigt die Stärke." - }, - "echoedVoice": { - "name": "Widerhall", - "effect": "Angriff mit widerhallender Stimme. Wenn in jeder Runde ein Teilnehmer wiederholt die Attacke einsetzt, steigt die Stärke." - }, - "chipAway": { - "name": "Zermürben", - "effect": "Eine durchdachte Attacke zu rechter Zeit. Richtet unabhängig von den Statusveränderungen des Zieles Schaden an." - }, - "clearSmog": { - "name": "Klärsmog", - "effect": "Anwender greift das Ziel mit spezialgefertigten Schlammklumpen an. Setzt Statusveränderungen zurück." - }, - "storedPower": { - "name": "Kraftvorrat", - "effect": "Angriff mit angesparter Energie. Je höher die Statuswerte des Anwenders, desto stärker fällt die Attacke aus." - }, - "quickGuard": { - "name": "Rapidschutz", - "effect": "Schützt Anwender und Mitstreiter vor gegnerischen Erstschlag-Attacken." - }, - "allySwitch": { - "name": "Seitentausch", - "effect": "Wundersame Kräfte teleportieren den Anwender an den Platz eines Mitstreiters." - }, - "scald": { - "name": "Siedewasser", - "effect": "Heizt dem Ziel mit einem Schwall siedend heißen Kochwassers ein. Das Ziel erleidet dabei eventuell Verbrennungen." - }, - "shellSmash": { - "name": "Hausbruch", - "effect": "Anwender zerbricht seine Schale und senkt seine Verteidigung und Spezial-Verteidigung, aber dafür steigen Angriff, Spezial-Angriff und Initiative stark." - }, - "healPulse": { - "name": "Heilwoge", - "effect": "Anwender löst eine Schmerzen lindernde Welle aus und heilt dabei das Ziel mit der Hälfte seiner maximalen KP." - }, - "hex": { - "name": "Bürde", - "effect": "Eine Attacke, bei der der Anwender das Ziel bedrängt. Fügt Zielen mit Statusproblemen hohen Schaden zu." - }, - "skyDrop": { - "name": "Freier Fall", - "effect": "Steigt in Runde 1 mit dem Ziel in die Luft auf und lässt es in Runde 2 fallen. Das Ziel kann dabei nicht angreifen." - }, - "shiftGear": { - "name": "Gangwechsel", - "effect": "Durch Drehen der Zahnräder erhöht sich nicht nur der Angriffs-Wert, sondern auch die Initiative des Anwenders stark." - }, - "circleThrow": { - "name": "Überkopfwurf", - "effect": "Schleudert das Ziel davon und bewirkt damit, dass ein anderes Pokémon eingewechselt wird. Beendet Kämpfe gegen wilde Pokémon." - }, - "incinerate": { - "name": "Einäschern", - "effect": "Eine Feuer-Attacke. Trägt das Ziel eine Beere oder ein ähnliches Item bei sich, wird dieses von den Flammen verzehrt und geht verloren." - }, - "quash": { - "name": "Verzögerung", - "effect": "Anwender stemmt sich gegen das Ziel und bewirkt, dass dieses erst als Letztes angreift." - }, - "acrobatics": { - "name": "Akrobatik", - "effect": "Ein graziler Angriff auf das Ziel. Trägt der Anwender kein Item bei sich, richtet die Attacke großen Schaden an." - }, - "reflectType": { - "name": "Typenspiegel", - "effect": "Anwender bildet das Ziel nach und nimmt dabei dessen Typ an." - }, - "retaliate": { - "name": "Heimzahlung", - "effect": "Anwender nimmt Rache für einen besiegten Mitstreiter. Wurde in der vorigen Runde ein Mitstreiter besiegt, steigt die Kraft." - }, - "finalGambit": { - "name": "Wagemut", - "effect": "Ein Angriff, der dem Ziel Schaden in Höhe der aktuellen KP des Anwenders zufügt. Letzterer wird dadurch selbst besiegt." - }, - "bestow": { - "name": "Offerte", - "effect": "Trägt das Ziel gerade kein Item bei sich, erhält es das Item, das sich aktuell im Besitz des Anwenders befindet." - }, - "inferno": { - "name": "Inferno", - "effect": "Anwender greift das Ziel an, indem er es mit dichten Flammen umhüllt. Ziel erleidet Verbrennungen." - }, - "waterPledge": { - "name": "Wassersäulen", - "effect": "Ein Angriff mit Wassersäulen. Mit Feuersäulen kombiniert steigt die Wirkung und ein Regenbogen erscheint." - }, - "firePledge": { - "name": "Feuersäulen", - "effect": "Ein Angriff mit Feuersäulen. Mit Pflanzsäulen kombiniert steigt die Wirkung und die Umgebung wird zu einem Meer aus Feuer." - }, - "grassPledge": { - "name": "Pflanzensäulen", - "effect": "Ein Angriff mit Pflanzsäulen. Mit Wassersäulen kombiniert steigt die Wirkung und die Umgebung wird zu einem Sumpf." - }, - "voltSwitch": { - "name": "Voltwechsel", - "effect": "Anwender kehrt nach dem Angriff mit atemberaubender Geschwindigkeit zurück und tauscht Platz mit einem anderen Pokémon." - }, - "struggleBug": { - "name": "Käfertrutz", - "effect": "Anwender leistet Widerstand und greift an. Der Spezial-Angriff der Ziele sinkt." - }, - "bulldoze": { - "name": "Dampfwalze", - "effect": "Anwender greift an, indem er den Boden um sich herum plattwalzt. Die Initiative aller betroffenen Pokémon sinkt." - }, - "frostBreath": { - "name": "Eisesodem", - "effect": "Anwender greift an, indem er dem Ziel eisigen Atem entgegenhaucht. Volltreffergarantie." - }, - "dragonTail": { - "name": "Drachenrute", - "effect": "Putzt das Ziel vom Feld und wechselt es mit einem anderen Pokémon aus. Beendet Kämpfe gegen wilde Pokémon." - }, - "workUp": { - "name": "Kraftschub", - "effect": "Anwender erhält einen Kraftschub, der seinen Angriff und Spezial-Angriff erhöht." - }, - "electroweb": { - "name": "Elektronetz", - "effect": "Fängt Ziele mit einem elektrischen Netz und senkt deren Initiative." - }, - "wildCharge": { - "name": "Stromstoß", - "effect": "Anwender erzeugt Spannung und greift an, indem er auf Kollisionskurs geht. Er selbst erleidet dabei ebenfalls leichten Schaden." - }, - "drillRun": { - "name": "Schlagbohrer", - "effect": "Anwender rammt das Ziel, während er seinen Körper wie einen Bohrer dreht. Hohe Volltrefferquote." - }, - "dualChop": { - "name": "Doppelhieb", - "effect": "Versetzt dem Ziel mit massiven Extremitäten Hiebe. Angriff erfolgt zweimal hintereinander." - }, - "heartStamp": { - "name": "Herzstempel", - "effect": "Verleitet Ziel durch Kokettieren zu Unachtsamkeit und verpasst ihm dann einen harten Schlag. Ziel schreckt eventuell zurück." - }, - "hornLeech": { - "name": "Holzgeweih", - "effect": "Greift Ziel mit Astgeweih an und zapft diesem Nährstoffe ab. Anwender wird um die Hälfte des zugefügten Schadens geheilt." - }, - "sacredSword": { - "name": "Sanctoklinge", - "effect": "Schneideangriff mit langem Horn. Richtet Schaden unabhängig von Statusveränderungen des Zieles an." - }, - "razorShell": { - "name": "Kalkklinge", - "effect": "Schneideangriff mit einer scharfen Muschelschale. Senkt eventuell die Verteidigung des Zieles." - }, - "heatCrash": { - "name": "Brandstempel", - "effect": "Rempelattacke mit brennendem Körper. Je schwerer der Anwender im Vergleich zum Ziel ist, desto stärker die Attacke." - }, - "leafTornado": { - "name": "Grasmixer", - "effect": "Anwender greift an, indem er das Ziel in scharfes Blattwerk einwickelt. Kann die Genauigkeit senken." - }, - "steamroller": { - "name": "Quetschwalze", - "effect": "Anwender rollt mit rundlichem Körper über das Ziel und drückt es platt. Ziel schreckt eventuell zurück." - }, - "cottonGuard": { - "name": "Watteschild", - "effect": "Anwender schützt sich, indem er sich in einen luftigen Flaum hüllt. Erhöht die Verteidigung drastisch." - }, - "nightDaze": { - "name": "Nachtflut", - "effect": "Anwender greift Ziel mit finsteren Schockwellen an. Senkt eventuell die Genauigkeit." - }, - "psystrike": { - "name": "Psychostoß", - "effect": "Anwender erzeugt seltsame Energiewellen, die dem Ziel physischen Schaden zufügen." - }, - "tailSlap": { - "name": "Kehrschelle", - "effect": "Anwender greift das Ziel mit seiner schlagfesten Rute zwei- bis fünfmal hintereinander an." - }, - "hurricane": { - "name": "Orkan", - "effect": "Anwender greift das Ziel an, indem er es mit heftigen Windböen umgibt. Ziel wird eventuell verwirrt." - }, - "headCharge": { - "name": "Steinschädel", - "effect": "Rempelattacke mit ausgeflippter Retrofrisur. Anwender nimmt selbst leichten Schaden." - }, - "gearGrind": { - "name": "Klikkdiskus", - "effect": "Anwender greift an, indem er stählerne Zahnräder auf das Ziel schleudert. Angriff erfolgt zweimal hintereinander." - }, - "searingShot": { - "name": "Flammenball", - "effect": "Greift alles in seiner Umgebung mit tiefroten Flammen an. Ziel kann Verbrennungen erleiden." - }, - "technoBlast": { - "name": "Techblaster", - "effect": "Anwender feuert ein Lichtgeschoss auf das Ziel ab. Der Typ der Attacke hängt von dem des Moduls ab." - }, - "relicSong": { - "name": "Urgesang", - "effect": "Anwender greift mit Urgesang an, der Ziele in der Nähe im tiefsten Inneren anspricht. Diese schlafen eventuell ein." - }, - "secretSword": { - "name": "Mystoschwert", - "effect": "Schneideangriff mit dem langen Schwert des Anwenders. Die mysteriöse Kraft aus dem Horn erzeugt physischen Schaden." - }, - "glaciate": { - "name": "Eiszeit", - "effect": "Anwender greift an, indem er dem Ziel klirrend kalte Luft entgegenbläst. Senkt die Initiative des Zieles." - }, - "boltStrike": { - "name": "Blitzschlag", - "effect": "Lädt seinen Körper mit einer gewaltigen Menge an Elektrizität auf und rammt damit das Ziel. Ziel wird eventuell paralysiert." - }, - "blueFlare": { - "name": "Blauflammen", - "effect": "Anwender greift an, indem er das Ziel in wunderschöne, intensivblaue Flammen hüllt, die es eventuell verbrennen." - }, - "fieryDance": { - "name": "Feuerreigen", - "effect": "Hüllt das Ziel mit einer Feuerhose in Flammen. Kann den Spezial-Angriff des Anwenders erhöhen." - }, - "freezeShock": { - "name": "Frostvolt", - "effect": "Feuert in der zweiten Runde elektrisch geladene Eisklumpen auf das Ziel ab. Paralysiert das Ziel eventuell." - }, - "iceBurn": { - "name": "Frosthauch", - "effect": "Umgibt das Ziel in der nächsten Runde mit heftigen, alles gefrierenden Eisböen. Fügt dem Ziel eventuell Verbrennungen zu." - }, - "snarl": { - "name": "Standpauke", - "effect": "Wäscht Zielen in der Nähe mit einer ausführlichen Standpauke den Kopf und senkt dabei deren Spezial-Angriff." - }, - "icicleCrash": { - "name": "Eiszapfhagel", - "effect": "Lässt große, schwere Eiszapfen auf das Ziel herabregnen. Ziel schreckt eventuell zurück." - }, - "vCreate": { - "name": "V-Generator", - "effect": "Eine Verzweiflungsattacke. Anwender entfacht glühend heißes Feuer. Senkt dessen Verteidigung, Spezial-Verteidigung und Initiative." - }, - "fusionFlare": { - "name": "Kreuzflamme", - "effect": "Feuert eine monströse Flamme ab. Wird die Attacke durch einen gigantischen Blitz modifiziert, steigt die Stärke." - }, - "fusionBolt": { - "name": "Kreuzdonner", - "effect": "Feuert einen monströsen Blitz ab. Wird die Attacke durch eine gigantische Flamme modifiziert, steigt die Stärke." - }, - "flyingPress": { - "name": "Flying Press", - "effect": "Der Anwender stürzt sich aus der Luft auf das Ziel. Die Attacke gehört sowohl dem Typ Kampf als auch dem Typ Flug an." - }, - "matBlock": { - "name": "Tatami-Schild", - "effect": "Der Anwender richtet eine Tatami-Matte auf, um sich und sein Team vor Schaden zu schützen. Kein Schutz vor Status-Attacken." - }, - "belch": { - "name": "Rülpser", - "effect": "Der Anwender fügt dem Ziel Schaden zu, indem er es anrülpst. Diese Attacke gelingt nur nach dem Konsum einer getragenen Beere." - }, - "rototiller": { - "name": "Pflüger", - "effect": "Der Anwender pflügt den Boden und macht die Erde fruchtbarer. Erhöht den Angriff und den Spezial-Angriff von Pflanzen-Pokémon." - }, - "stickyWeb": { - "name": "Klebenetz", - "effect": "Der Anwender spinnt in der Umgebung des gegnerischen Teams ein klebriges Netz und senkt so die Initiative neu eingewechselter Pokémon." - }, - "fellStinger": { - "name": "Stachelfinale", - "effect": "Gelingt es dem Anwender, das Ziel mit dieser Attacke zu besiegen, steigt sein Angriffs-Wert stark." - }, - "phantomForce": { - "name": "Phantomkraft", - "effect": "Der Anwender verschwindet, um eine Runde lang seine Kraft zu sammeln und in der nächsten Runde anzugreifen. Durchbricht die Defensive des Zieles." - }, - "trickOrTreat": { - "name": "Halloween", - "effect": "Der Anwender lehrt das Ziel das Fürchten. Dieses nimmt dadurch zusätzlich den Typ Geist an." - }, - "nobleRoar": { - "name": "Kampfgebrüll", - "effect": "Der Anwender stößt ein Kampfgebrüll aus, das das Ziel einschüchtert und zugleich seinen Angriffs- und Spezial-Angriffs-Wert senkt." - }, - "ionDeluge": { - "name": "Plasmaschauer", - "effect": "Versprüht elektrisch geladene Partikel und bewirkt, dass Normal-Attacken den Typ Elektro annehmen." - }, - "parabolicCharge": { - "name": "Parabolladung", - "effect": "Fügt allen Pokémon in der Umgebung Schaden zu. Der Anwender wird um die Hälfte des insgesamt angerichteten Schadens geheilt." - }, - "forestsCurse": { - "name": "Waldesfluch", - "effect": "Der Anwender belegt das Ziel mit einem Waldesfluch, durch den dieses zusätzlich den Typ Pflanze annimmt." - }, - "petalBlizzard": { - "name": "Blütenwirbel", - "effect": "Der Anwender erzeugt einen turbulenten Blütenwirbel, der alle Pokémon in der Nähe erfasst und ihnen Schaden zufügt." - }, - "freezeDry": { - "name": "Gefriertrockner", - "effect": "Das Ziel wird stark abgekühlt und manchmal sogar eingefroren. Die Attacke ist sehr effektiv gegen Wasser-Pokémon." - }, - "disarmingVoice": { - "name": "Säuselstimme", - "effect": "Der Anwender stößt einen bezirzenden Ruf aus, mit dem er das Ziel in seinen Bann schlägt und ihm immer mentalen Schaden zufügt." - }, - "partingShot": { - "name": "Abgangstirade", - "effect": "Schüchtert das Ziel mit einer Abgangstirade ein, sodass dessen Angriffs- und Spezial-Angriffs-Wert sinken. Danach wird der Anwender ausgewechselt." - }, - "topsyTurvy": { - "name": "Invertigo", - "effect": "Invertiert alle Statusveränderungen des Zieles." - }, - "drainingKiss": { - "name": "Diebeskuss", - "effect": "Der Anwender stiehlt dem Ziel mit einem Kuss KP. Die Höhe der Heilung beträgt mehr als die Hälfte des beim Ziel angerichteten Schadens." - }, - "craftyShield": { - "name": "Trickschutz", - "effect": "Schützt sich und Mitstreiter mit einer mysteriösen Macht vor Status-Attacken. Es werden jedoch weiterhin KP-Schäden erlitten." - }, - "flowerShield": { - "name": "Floraschutz", - "effect": "Erhöht mit einer mysteriösen Macht die Verteidigung aller am Kampf beteiligten Pflanzen-Pokémon." - }, - "grassyTerrain": { - "name": "Grasfeld", - "effect": "Verwandelt den Untergrund fünf Runden lang in ein Grasfeld und heilt in jeder neuen Runde alle Pokémon, die den Boden berühren." - }, - "mistyTerrain": { - "name": "Nebelfeld", - "effect": "Verwandelt den Untergrund fünf Runden lang in ein Nebelfeld und schützt alle Pokémon, die den Boden berühren, vor Statusproblemen." - }, - "electrify": { - "name": "Elektrifizierung", - "effect": "Kommt die Attacke zum Einsatz, bevor das Ziel seine Attacke ausführt, nimmt diese für die Dauer dieser Runde den Typ Elektro an." - }, - "playRough": { - "name": "Knuddler", - "effect": "Der Anwender knuddelt das Ziel und greift es an. Gelegentlich sinkt dabei auch dessen Angriffs-Wert." - }, - "fairyWind": { - "name": "Feenbrise", - "effect": "Lässt eine Feenbrise aufkommen, die das Ziel erfasst und ihm Schaden zufügt." - }, - "moonblast": { - "name": "Mondgewalt", - "effect": "Der Anwender macht sich die Kraft des Mondes zunutze, um anzugreifen. Gelegentlich wird dabei der Spezial-Angriff des Zieles gesenkt." - }, - "boomburst": { - "name": "Überschallknall", - "effect": "Der Anwender greift alle Pokémon in der Umgebung mit einem gewaltigen Knall an." - }, - "fairyLock": { - "name": "Feenschloss", - "effect": "Der Anwender sperrt alle Pokémon ein und hindert sie damit in der nächsten Runde an der Flucht." - }, - "kingsShield": { - "name": "Königsschild", - "effect": "Der Anwender weicht dem gegnerischen Angriff aus und geht in die Defensive. Berührt ihn nun ein Pokémon, sinkt der Angriffs-Wert dieses Gegners." - }, - "playNice": { - "name": "Kameradschaft", - "effect": "Der Anwender schließt mit dem Ziel Freundschaft und nimmt ihm seine Angriffslust. Der Angriffs-Wert des Zieles sinkt." - }, - "confide": { - "name": "Vertrauenssache", - "effect": "Der Anwender vertraut dem Ziel ein Geheimnis an und stört auf diese Weise seine Konzentration. Der Spezial-Angriff des Zieles sinkt." - }, - "diamondStorm": { - "name": "Diamantsturm", - "effect": "Der Anwender beschwört einen zerstörerischen Diamantsturm herauf. Kann die Verteidigung des Anwenders erhöhen." - }, - "steamEruption": { - "name": "Dampfschwall", - "effect": "Der Anwender feuert einen siedend heißen Dampfschwall auf das Ziel ab. Dieses kann dabei Verbrennungen erleiden." - }, - "hyperspaceHole": { - "name": "Dimensionsloch", - "effect": "Der Anwender positioniert sich mithilfe eines Dimensionslochs direkt neben dem Ziel und durchbricht selbst Schutzschild und Scanner." - }, - "waterShuriken": { - "name": "Wasser-Shuriken", - "effect": "Der Anwender schleudert dem Ziel Wurfsterne aus einem verdickten Sekret entgegen. Eine Serien-Attacke, die zwei- bis fünfmal trifft." - }, - "mysticalFire": { - "name": "Magieflamme", - "effect": "Der Anwender greift das Ziel an, indem er ihm eine besondere, heiße Flamme entgegenbläst. Der Spezial-Angriff des Zieles sinkt." - }, - "spikyShield": { - "name": "Schutzstacheln", - "effect": "Der Anwender weicht gegnerischen Angriffen aus. Gleichzeitig nehmen alle Pokémon, die mit ihm in Berührung kommen, Schaden." - }, - "aromaticMist": { - "name": "Duftwolke", - "effect": "Der Anwender erhöht mithilfe eines mysteriösen Duftes die Spezial-Verteidigung eines Mitstreiters." - }, - "eerieImpulse": { - "name": "Mystowellen", - "effect": "Der Körper des Anwenders erzeugt mysteriöse Wellen und senkt den Spezial-Angriff des Zieles dadurch stark." - }, - "venomDrench": { - "name": "Giftfalle", - "effect": "Anwender bespritzt das Ziel mit einer speziellen Giftflüssigkeit. Senkt den Angriff, den Spezial- Angriff und die Initiative von vergifteten Zielen." - }, - "powder": { - "name": "Pulverschleuder", - "effect": "Setzt das Ziel nach Einsatz von Pulverschleuder in derselben Runde eine Feuer-Attacke ein, kommt es zu einer Explosion, die ihm schadet." - }, - "geomancy": { - "name": "Geokontrolle", - "effect": "Der Anwender saugt in Runde 1 Energie auf. In Runde 2 steigen folgende Statuswerte stark: Spezial-Angriff, Spezial-Verteidigung und Initiative." - }, - "magneticFlux": { - "name": "Magnetregler", - "effect": "Das Magnetfeld wird so manipuliert, dass Spezial- Verteidigung und Verteidigung von Team-Pokémon mit der Fähigkeit Plus oder Minus steigen." - }, - "happyHour": { - "name": "Goldene Zeiten", - "effect": "Nach Einsatz der Attacke Goldene Zeiten verdoppelt sich das Preisgeld, das du im Falle eines Sieges erhältst." - }, - "electricTerrain": { - "name": "Elektrofeld", - "effect": "Verwandelt den Untergrund fünf Runden lang in ein Elektrofeld und hindert alle Pokémon, die den Boden berühren, am Einschlafen." - }, - "dazzlingGleam": { - "name": "Zauberschein", - "effect": "Der Anwender feuert einen mächtigen Lichtblitz ab, der dem Ziel Schaden zufügt." - }, - "celebrate": { - "name": "Ehrentag", - "effect": "Das Pokémon gratuliert dir zu deinem Geburtstag!" - }, - "holdHands": { - "name": "Händchenhalten", - "effect": "Der Anwender und ein Mitstreiter reichen einander die Hände und verfallen in einen Zustand tiefster Zufriedenheit." - }, - "babyDollEyes": { - "name": "Kulleraugen", - "effect": "Der Anwender erobert das Herz des Zieles, indem er es mit Kulleraugen ansieht. Senkt den Angriffs-Wert. Erstschlaggarantie." - }, - "nuzzle": { - "name": "Wangenrubbler", - "effect": "Der Anwender lädt seine Wangen elektrisch auf und greift an, indem er sich damit am Ziel reibt. Das Ziel wird paralysiert." - }, - "holdBack": { - "name": "Zurückhaltung", - "effect": "Der Anwender hält sich beim Angriff zurück und sorgt auf diese Weise dafür, dass dem Ziel danach mindestens 1 KP verbleibt." - }, - "infestation": { - "name": "Plage", - "effect": "Der Anwender fällt vier bis fünf Runden lang wie eine Plage über das Ziel her und greift es an. In diesem Zeitraum kann es nicht fliehen." - }, - "powerUpPunch": { - "name": "Steigerungshieb", - "effect": "Die Fäuste des Anwenders härten durch wiederholtes Zuschlagen ab. Mit jedem Treffer steigt sein Angriffs-Wert." - }, - "oblivionWing": { - "name": "Unheilsschwingen", - "effect": "Der Anwender raubt dem Ziel KP. Die Höhe der Heilung beträgt mehr als die Hälfte des beim Ziel angerichteten Schadens." - }, - "thousandArrows": { - "name": "Tausend Pfeile", - "effect": "Die Attacke erfasst auch schwebende Pokémon. Erfasst sie ein Pokémon im Schwebe-Zustand, fällt es zu Boden." - }, - "thousandWaves": { - "name": "Tausend Wellen", - "effect": "Der Anwender greift mit einer Welle an, die dicht über dem Boden verläuft und alle Pokémon, die sie erfasst, an der Flucht hindert." - }, - "landsWrath": { - "name": "Bodengewalt", - "effect": "Der Anwender sammelt die Kraft des weiten Landes und greift an, indem er sie gebündelt auf das Ziel lenkt." - }, - "lightOfRuin": { - "name": "Lux Calamitatis", - "effect": "Die Attacke basiert auf der Kraft des Ewigblütlers, die als mächtiger Lichtstrahl abgefeuert wird. Der Anwender nimmt dabei selbst großen Schaden." - }, - "originPulse": { - "name": "Ursprungswoge", - "effect": "Der Anwender greift das Ziel mit unzähligen blau leuchtenden Strahlen an." - }, - "precipiceBlades": { - "name": "Abgrundsklinge", - "effect": "Der Anwender wandelt die Kraft des Erdreichs in Klingen um, mit denen er das Ziel angreift." - }, - "dragonAscent": { - "name": "Zenitstürmer", - "effect": "Der Anwender greift das Ziel aus atemberaubender Höhe im Sturzflug an. Senkt Verteidigung und Spezial-Verteidigung des Anwenders." - }, - "hyperspaceFury": { - "name": "Dimensionswahn", - "effect": "Eine Angriffsserie mit vielen Armen, die die Wirkung von Schutzschild und Scanner durchbricht. Dabei sinkt die Verteidigung des Anwenders." - }, - "breakneckBlitzPhysical": { - "name": "Hyper-Sprintangriff", - "effect": "Der durch Z-Kraft energiegeladene Anwender rennt mit ganzer Kraft gegen das Ziel. Die Stärke variiert je nach zugrunde liegender Attacke." - }, - "breakneckBlitzSpecial": { - "name": "Hyper-Sprintangriff", - "effect": "Dummy Data" - }, - "allOutPummelingPhysical": { - "name": "Fulminante Faustschläge", - "effect": "Aus Z-Kraft hergestellte Energiebälle prallen mit voller Wucht auf das Ziel. Die Stärke variiert je nach zugrunde liegender Attacke." - }, - "allOutPummelingSpecial": { - "name": "Fulminante Faustschläge", - "effect": "Dummy Data" - }, - "supersonicSkystrikePhysical": { - "name": "Finaler Steilflug", - "effect": "Der Anwender schwingt sich durch Z-Kraft in die Lüfte und stürzt sich dann auf das Ziel hinab. Die Stärke variiert je nach zugrunde liegender Attacke." - }, - "supersonicSkystrikeSpecial": { - "name": "Finaler Steilflug", - "effect": "Dummy Data" - }, - "acidDownpourPhysical": { - "name": "Vernichtender Säureregen", - "effect": "Der Anwender kreiert mit Z-Kraft ein giftiges Moor, in dem das Ziel versinkt. Die Stärke variiert je nach zugrunde liegender Attacke." - }, - "acidDownpourSpecial": { - "name": "Vernichtender Säureregen", - "effect": "Dummy Data" - }, - "tectonicRagePhysical": { - "name": "Seismische Eruption", - "effect": "Der Anwender zerrt das Ziel mit Z-Kraft tief in den Boden und kollidiert dort mit ihm. Die Stärke variiert je nach zugrunde liegender Attacke." - }, - "tectonicRageSpecial": { - "name": "Seismische Eruption", - "effect": "Dummy Data" - }, - "continentalCrushPhysical": { - "name": "Apokalyptische Steinpresse", - "effect": "Der Anwender beschwört mit Z-Kraft einen großen Felsen herbei und lässt ihn auf das Ziel fallen. Die Stärke variiert je nach zugrunde liegender Attacke." - }, - "continentalCrushSpecial": { - "name": "Apokalyptische Steinpresse", - "effect": "Dummy Data" - }, - "savageSpinOutPhysical": { - "name": "Wirbelnder Insektenhieb", - "effect": "Mithilfe von Z-Kraft umwickelt der Anwender das Ziel mit Fäden. Die Stärke variiert je nach zugrunde liegender Attacke." - }, - "savageSpinOutSpecial": { - "name": "Wirbelnder Insektenhieb", - "effect": "Dummy Data" - }, - "neverEndingNightmarePhysical": { - "name": "Ewige Nacht", - "effect": "Der Anwender beschwört mit Z-Kraft tiefen Groll herbei und lässt diesen auf das Ziel los. Die Stärke variiert je nach zugrunde liegender Attacke." - }, - "neverEndingNightmareSpecial": { - "name": "Ewige Nacht", - "effect": "Dummy Data" - }, - "corkscrewCrashPhysical": { - "name": "Turbo-Spiralkombo", - "effect": "Der Anwender wirbelt durch Z-Kraft sehr schnell umher und prallt mit dem Ziel zusammen. Die Stärke variiert je nach zugrunde liegender Attacke." - }, - "corkscrewCrashSpecial": { - "name": "Turbo-Spiralkombo", - "effect": "Dummy Data" - }, - "infernoOverdrivePhysical": { - "name": "Dynamische Maxiflamme", - "effect": "Der Anwender speit dank Z-Kraft eine gewaltige Kugel aus Flammen auf das Ziel. Die Stärke variiert je nach zugrunde liegender Attacke." - }, - "infernoOverdriveSpecial": { - "name": "Dynamische Maxiflamme", - "effect": "Dummy Data" - }, - "hydroVortexPhysical": { - "name": "Super-Wassertornado", - "effect": "Der Anwender kreiert mit Z-Kraft einen riesigen Wasserstrudel, der das Ziel verschluckt. Die Stärke variiert je nach zugrunde liegender Attacke." - }, - "hydroVortexSpecial": { - "name": "Super-Wassertornado", - "effect": "Dummy Data" - }, - "bloomDoomPhysical": { - "name": "Brillante Blütenpracht", - "effect": "Der Anwender leiht sich durch Z-Kraft die Energie von Wiesenblumen und greift das Ziel damit an. Die Stärke variiert je nach zugrunde liegender Attacke." - }, - "bloomDoomSpecial": { - "name": "Brillante Blütenpracht", - "effect": "Dummy Data" - }, - "gigavoltHavocPhysical": { - "name": "Gigavolt-Funkensalve", - "effect": "Der Anwender greift das Ziel mit durch Z-Kraft gesammelter starker Elektrizität an. Die Stärke variiert je nach zugrunde liegender Attacke." - }, - "gigavoltHavocSpecial": { - "name": "Gigavolt-Funkensalve", - "effect": "Dummy Data" - }, - "shatteredPsychePhysical": { - "name": "Psycho-Schmetterschlag", - "effect": "Der Anwender kontrolliert das Ziel mit Z-Kraft und macht ihm so das Leben schwer. Die Stärke variiert je nach zugrunde liegender Attacke." - }, - "shatteredPsycheSpecial": { - "name": "Psycho-Schmetterschlag", - "effect": "Dummy Data" - }, - "subzeroSlammerPhysical": { - "name": "Tobender Geofrost", - "effect": "Der Anwender senkt mit Z-Kraft die Temperatur drastisch und lässt das Ziel einfrieren. Die Stärke variiert je nach zugrunde liegender Attacke." - }, - "subzeroSlammerSpecial": { - "name": "Tobender Geofrost", - "effect": "Dummy Data" - }, - "devastatingDrakePhysical": { - "name": "Drastisches Drachendröhnen", - "effect": "Der Anwender materialisiert durch Z-Kraft seine Aura und greift damit das Ziel an. Die Stärke variiert je nach zugrunde liegender Attacke." - }, - "devastatingDrakeSpecial": { - "name": "Drastisches Drachendröhnen", - "effect": "Dummy Data" - }, - "blackHoleEclipsePhysical": { - "name": "Schwarzes Loch des Grauens", - "effect": "Der Anwender sammelt mit Z-Kraft dunkle Energie an, die das Ziel verschlingt. Die Stärke variiert je nach zugrunde liegender Attacke." - }, - "blackHoleEclipseSpecial": { - "name": "Black Hole Eclipse", - "effect": "Dummy Data" - }, - "twinkleTacklePhysical": { - "name": "Entzückender Sternenstoß", - "effect": "Der Anwender kreiert mit Z-Kraft eine zauberhafte Dimension und treibt dort sein Spiel mit dem Ziel. Die Stärke variiert je nach zugrunde liegender Attacke." - }, - "twinkleTackleSpecial": { - "name": "Twinkle Tackle", - "effect": "Dummy Data" - }, - "catastropika": { - "name": "Perfektes Pika-Projektil", - "effect": "Pikachu umhüllt sich durch Z-Kraft mit gewaltiger elektrischer Energie und stürzt sich mit voller Kraft auf das Ziel." - }, - "shoreUp": { - "name": "Sandsammler", - "effect": "KP des Anwenders werden um 50 % der maximalen KP aufgefüllt. Tobt ein Sandsturm, werden noch mehr KP aufgefüllt." - }, - "firstImpression": { - "name": "Überrumpler", - "effect": "Eine sehr starke Attacke, die jedoch nur erfolgreich ist, wenn sie sofort eingesetzt wird, nachdem der Anwender das Kampffeld betreten hat." - }, - "banefulBunker": { - "name": "Bunker", - "effect": "Der Anwender wird vor Angriffen geschützt. Gleichzeitig werden alle Pokémon, die mit ihm in Berührung kommen, vergiftet." - }, - "spiritShackle": { - "name": "Schattenfessel", - "effect": "Der Anwender greift das Ziel an und näht zugleich dessen Schatten am Boden fest, sodass es nicht entkommen kann." - }, - "darkestLariat": { - "name": "Dark Lariat", - "effect": "Der Anwender wirbelt mit beiden Armen und prallt so auf das Ziel. Richtet unabhängig von den Statusveränderungen des Zieles Schaden an." - }, - "sparklingAria": { - "name": "Schaumserenade", - "effect": "Durch Gesang erzeugte Blasen werden auf das Ziel geschleudert. Alle Pokémon, die dadurch Schaden erleiden, werden auch von Verbrennungen geheilt." - }, - "iceHammer": { - "name": "Eishammer", - "effect": "Anwender trifft mit einem starken Hieb. Senkt Initiative des Anwenders." - }, - "floralHealing": { - "name": "Florakur", - "effect": "KP des Zieles werden um 50 % der maximalen KP aufgefüllt. Die Wirkung steigt, wenn der Untergrund in ein Grasfeld verwandelt wurde." - }, - "highHorsepower": { - "name": "Pferdestärke", - "effect": "Der Anwender greift das Ziel mit einer heftigen Ganzkörper-Attacke an." - }, - "strengthSap": { - "name": "Kraftabsorber", - "effect": "Ein Angriff, der die KP des Anwenders um die Höhe des Angriffs-Werts des Zieles heilt. Anschließend wird der Angriff des Zieles gesenkt." - }, - "solarBlade": { - "name": "Solarklinge", - "effect": "Der Anwender absorbiert in der 1. Runde Licht, das er in der 2. Runde zu einem Schwert formt, mit dem er angreift." - }, - "leafage": { - "name": "Blattwerk", - "effect": "Der Anwender greift das Ziel mit Blättern an." - }, - "spotlight": { - "name": "Rampenlicht", - "effect": "Der Anwender lenkt die Aufmerksamkeit auf das Ziel, sodass in dieser Runde nur noch dieses Pokémon angegriffen wird." - }, - "toxicThread": { - "name": "Giftfaden", - "effect": "Der Anwender schießt giftige Fäden auf das Ziel, das dadurch vergiftet wird. Außerdem sinkt seine Initiative." - }, - "laserFocus": { - "name": "Konzentration", - "effect": "Der Anwender konzentriert sich, wodurch sein nächster Angriff garantiert ein Volltreffer wird." - }, - "gearUp": { - "name": "Hilfsmechanik", - "effect": "Der Anwender erhöht mithilfe von Zahnrädern Angriff und Spezial-Angriff von Team-Pokémon mit der Fähigkeit Plus oder Minus." - }, - "throatChop": { - "name": "Neck Strike", - "effect": "Das Pokémon, das von dieser Attacke getroffen wird, erleidet starke Schmerzen und kann deswegen zwei Runden lang keine Lärm-Attacken mehr einsetzen." - }, - "pollenPuff": { - "name": "Pollenknödel", - "effect": "Der Anwender greift mit einem Ball aus Pollen an, der beim Ziel explodiert. Mitstreiter werden von einem Ball getroffen, der ihre KP auffüllt." - }, - "anchorShot": { - "name": "Ankerschuss", - "effect": "Der Anwender greift das Ziel an, indem er es mit einer Ankerkette umwickelt. Dadurch wird das Ziel an der Flucht gehindert." - }, - "psychicTerrain": { - "name": "Psychofeld", - "effect": "Verhindert für fünf Runden, dass Pokémon am Boden von Attacken mit hoher Erstschlagquote getroffen werden. Erhöht die Stärke von Psycho-Attacken." - }, - "lunge": { - "name": "Anfallen", - "effect": "Der Anwender greift das Ziel mit ganzer Kraft an, wodurch auch der Angriffs-Wert des Zieles sinkt." - }, - "fireLash": { - "name": "Feuerpeitsche", - "effect": "Der Anwender greift das Ziel mit einer brennenden Peitsche an und senkt dabei zusätzlich dessen Verteidigungs-Wert." - }, - "powerTrip": { - "name": "Überheblichkeit", - "effect": "Der Anwender prahlt mit seiner Stärke und greift das Ziel an. Dieser Angriff ist umso stärker, je weiter die Statuswerte des Anwenders erhöht sind." - }, - "burnUp": { - "name": "Ausbrennen", - "effect": "Der Anwender nutzt das gesamte Feuer in seinem Körper, um großen Schaden auszuteilen. Die restliche Kampfdauer gehört er nicht mehr dem Typ Feuer an." - }, - "speedSwap": { - "name": "Initiativetausch", - "effect": "Der Anwender tauscht seinen Initiative-Wert mit dem des Zieles." - }, - "smartStrike": { - "name": "Schmalhorn", - "effect": "Der Anwender durchbohrt das Ziel mit seinem spitzen Horn. Diese Attacke trifft immer." - }, - "purify": { - "name": "Läuterung", - "effect": "Der Anwender heilt das Statusproblem des Zieles und füllt dadurch seine eigenen KP auf." - }, - "revelationDance": { - "name": "Wecktanz", - "effect": "Der Anwender tanzt und greift dabei das Ziel mit voller Kraft an. Die Attacke hat denselben Typ wie das Pokémon, das sie einsetzt." - }, - "coreEnforcer": { - "name": "Sanktionskern", - "effect": "Hat das Pokémon, das durch diese Attacke Schaden genommen hat, in dieser Runde bereits gehandelt, verliert es seine Fähigkeit." - }, - "tropKick": { - "name": "Tropenkick", - "effect": "Der Anwender greift den Gegner mit einem heftigen Tritt tropischer Herkunft an. Dabei sinkt auch der Angriffs-Wert des Gegners." - }, - "instruct": { - "name": "Kommando", - "effect": "Der Anwender befiehlt dem Ziel, dessen zuletzt ausgeführte Attacke sofort wieder einzusetzen." - }, - "beakBlast": { - "name": "Schnabelkanone", - "effect": "Der Anwender erhitzt zuerst seinen Schnabel und greift dann an. Pokémon, die ihn während des Erhitzens berühren, erleiden Verbrennungen." - }, - "clangingScales": { - "name": "Schuppenrasseln", - "effect": "Der Anwender erzeugt durch das Rasseln mit seinen Schuppen ein lautes Geräusch und greift an. Anschließend sinkt seine Verteidigung." - }, - "dragonHammer": { - "name": "Drachenhammer", - "effect": "Der Anwender nutzt seinen Körper wie einen Hammer und stürzt sich auf das Ziel, wodurch dieses Schaden erleidet." - }, - "brutalSwing": { - "name": "Wirbler", - "effect": "Der Anwender dreht schwungvoll seinen Körper und fügt den Pokémon in seiner Nähe dabei Schaden zu." - }, - "auroraVeil": { - "name": "Auroraschleier", - "effect": "Diese Attacke schwächt fünf Runden lang den durch physische sowie durch Spezial-Attacken erhaltenen Schaden. Kann nur bei Hagel eingesetzt werden." - }, - "sinisterArrowRaid": { - "name": "Schatten-Pfeilregen", - "effect": "Silvarro stellt mit Z-Kraft unzählige Pfeile her und lässt diese auf das Ziel niederprasseln." - }, - "maliciousMoonsault": { - "name": "Hyper Dark Crusher", - "effect": "Mit seinem durch Z-Kraft gestählten Körper stürzt sich Fuegro mit ganzer Kraft auf das Ziel." - }, - "oceanicOperetta": { - "name": "Grandiose Meeressymphonie", - "effect": "Primarene ruft mit Z-Kraft große Mengen an Wasser herbei und greift damit das Ziel an." - }, - "guardianOfAlola": { - "name": "Alolas Wächter", - "effect": "Ein gewaltiger Angriff des Schutzpatrons, der durch Z-Kraft die Kraft Alolas erlangt hat. Reduziert die verbleibenden KP des Zieles stark." - }, - "soulStealing7StarStrike": { - "name": "Sternbild des Seelenraubes", - "effect": "Marshadow schlägt mit durch Z-Kraft gestärkten Schlägen und Tritten in einer Serien-Attacke auf das Ziel ein." - }, - "stokedSparksurfer": { - "name": "Blitz-Wellenritt", - "effect": "Das Alola-Raichu greift das Ziel mithilfe von Z-Kraft mit voller Wucht an und paralysiert es." - }, - "pulverizingPancake": { - "name": "Schluss mit lustig", - "effect": "Relaxo wird von Z-Kraft erfüllt und macht Ernst. Es bringt seinen riesigen Körper in Schwung und stürzt sich mit ganzer Kraft auf das Ziel." - }, - "extremeEvoboost": { - "name": "Macht der Neun", - "effect": "Evoli macht sich durch Z-Kraft die Stärke seiner Weiterentwicklungen zunutze und erhöht seine Statuswerte stark." - }, - "genesisSupernova": { - "name": "Supernova des Ursprungs", - "effect": "Mew greift das Ziel mithilfe von Z-Kraft mit voller Wucht an. Der Untergrund wird dabei in ein Psychofeld verwandelt." - }, - "shellTrap": { - "name": "Panzerfalle", - "effect": "Der Anwender legt eine Panzerfalle. Wird er von einer physischen Attacke getroffen, explodiert die Falle und fügt dem Angreifer Schaden zu." - }, - "fleurCannon": { - "name": "Kanonenbouquet", - "effect": "Der Anwender greift das Ziel mit einem gewaltigen Strahl an. Sein eigener Spezial-Angriff sinkt dadurch stark." - }, - "psychicFangs": { - "name": "Psychobeißer", - "effect": "Der Anwender beißt das Ziel mithilfe von Psycho-Kräften. Die Attacke durchbricht auch Barrieren wie Lichtschild und Reflektor." - }, - "stompingTantrum": { - "name": "Fruststampfer", - "effect": "Von Frust getrieben greift der Anwender an. Wenn seine vorige Attacke fehlgeschlagen ist, verdoppelt sich die Stärke der Attacke." - }, - "shadowBone": { - "name": "Schattenknochen", - "effect": "Der Anwender greift das Ziel mit einem Knochen an, in dem eine Seele haust. Senkt eventuell die Verteidigung des Zieles." - }, - "accelerock": { - "name": "Turbofelsen", - "effect": "Der Anwender prallt mit großer Geschwindigkeit auf das Ziel. Hohe Erstschlagquote." - }, - "liquidation": { - "name": "Aquadurchstoß", - "effect": "Der Anwender greift das Ziel mit der Kraft des Wassers an. Senkt eventuell die Verteidigung des Zieles." - }, - "prismaticLaser": { - "name": "Prisma-Laser", - "effect": "Der Anwender feuert mithilfe von Prisma-Kraft mächtige Lichtstrahlen ab. In der nächsten Runde kann er nicht handeln." - }, - "spectralThief": { - "name": "Diebesschatten", - "effect": "Der Anwender schleicht sich in den Schatten des Zieles, stiehlt dessen erhöhte Statuswerte und fügt ihm Schaden zu." - }, - "sunsteelStrike": { - "name": "Stahlgestirn", - "effect": "Der Anwender stürzt mit der Gewalt eines Meteors auf das Ziel. Die Fähigkeit des Zieles wird dabei ignoriert." - }, - "moongeistBeam": { - "name": "Schattenstrahl", - "effect": "Der Anwender greift mit einem unheimlichen Lichtstrahl an. Diese Attacke ignoriert die Fähigkeit des Zieles." - }, - "tearfulLook": { - "name": "Tränendrüse", - "effect": "Dem Anwender stehen Tränen in den Augen, wodurch das Ziel seinen Kampfeswillen verliert. Angriff und Spezial-Angriff des Zieles sinken." - }, - "zingZap": { - "name": "Elektropikser", - "effect": "Der Anwender rammt das Ziel und schockt es mit starkem Strom. Das Ziel schreckt eventuell zurück." - }, - "naturesMadness": { - "name": "Naturzorn", - "effect": "Das Ziel wird vom Zorn der Natur getroffen und verliert dadurch die Hälfte seiner KP." - }, - "multiAttack": { - "name": "Multi-Angriff", - "effect": "Der Anwender sammelt eine große Menge Energie und greift das Ziel damit an. Der Typ der Attacke hängt von dem der Disc ab." - }, - "tenMillionVoltThunderbolt": { - "name": "Tausendfacher Donnerblitz", - "effect": "Das eine Kappe tragende Pikachu greift das Ziel mit einem durch Z-Kraft verstärkten Elektroschock an. Hohe Volltrefferquote." - }, - "mindBlown": { - "name": "Knallkopf", - "effect": "Der Anwender greift alle Pokémon in der Umgebung an, indem er seinen Kopf explodieren lässt. Dabei verletzt er sich auch selbst." - }, - "plasmaFists": { - "name": "Plasmafäuste", - "effect": "Ein Angriff mit elektrisch geladenen Fäusten, der bewirkt, dass Normal-Attacken den Typ Elektro annehmen." - }, - "photonGeyser": { - "name": "Photonen-Geysir", - "effect": "Ein Angriff mit einer Lichtsäule. Ist der Angriff höher als der Spezial-Angriff, wird die Höhe des Schadens durch den Angriff bestimmt und umgekehrt." - }, - "lightThatBurnsTheSky": { - "name": "Licht des Erlöschens", - "effect": "Ist der Angriff höher als der Spezial-Angriff, wird die Höhe des Schadens durch den Angriff bestimmt und umgekehrt. Ignoriert die Fähigkeit des Zieles." - }, - "searingSunrazeSmash": { - "name": "Schmetternde Sonnenwalze", - "effect": "Solgaleo greift das Ziel mithilfe von Z-Kraft mit voller Wucht an. Ignoriert die Fähigkeit des Zieles." - }, - "menacingMoonrazeMaelstrom": { - "name": "Geballter Mondlaser", - "effect": "Lunala greift das Ziel mithilfe von Z-Kraft mit voller Wucht an. Ignoriert die Fähigkeit des Zieles." - }, - "letsSnuggleForever": { - "name": "Herzliche Knuddelkloppe", - "effect": "Mimigma greift das Ziel mithilfe von Z-Kraft mit voller Wucht und viel Liebe an." - }, - "splinteredStormshards": { - "name": "Fataler Steinregen", - "effect": "Wolwerock greift das Ziel mithilfe von Z-Kraft mit voller Wucht an. Herrschen besondere Feldeffekte, werden diese zusätzlich neutralisiert." - }, - "clangorousSoulblaze": { - "name": "Rasselnder Seelentanz", - "effect": "Grandiras greift Gegner mithilfe von Z-Kraft mit voller Wucht an. Zusätzlich werden seine Statuswerte erhöht." - }, - "zippyZap": { - "name": "Britzelturbo", - "effect": "Ein stürmischer Blitz-Angriff mit garantierter Erstschlag- und Volltrefferquote.\n" - }, - "splishySplash": { - "name": "Plätschersurfer", - "effect": "Pikachu greift das Ziel mit einer großen, elektrisch aufgeladenen Welle an. Das Ziel wird eventuell paralysiert." - }, - "floatyFall": { - "name": "Schwebesturz", - "effect": "Pikachu schwebt nach oben und stürzt dann unvermittelt auf das Ziel herab. Das Ziel schreckt eventuell zurück." - }, - "pikaPapow": { - "name": "Pika-Flash", - "effect": "Je größer Pikachus Vertrauen zu seinem Trainer ist, desto stärker fällt dieser Angriff aus. Diese Attacke trifft immer." - }, - "bouncyBubble": { - "name": "Blubbsauger", - "effect": "Der Anwender greift mit Wasserblasen an. Seine KP werden in Höhe des vom Wasser angerichteten Schadens geheilt." - }, - "buzzyBuzz": { - "name": "Knisterladung", - "effect": "Evoli greift das Ziel mit Elektrizität an, wodurch dieses paralysiert wird." - }, - "sizzlySlide": { - "name": "Flackerbrand", - "effect": "Evoli hüllt sich in Flammen und stürzt sich beherzt auf das Ziel, welches dadurch Verbrennungen erleidet." - }, - "glitzyGlow": { - "name": "Pulsieraura", - "effect": "Evoli greift das Ziel gnadenlos mit telekinetischer Energie an. Dabei wird eine geheimnisvolle Wand erzeugt, die Spezial-Attacken des Ziels abschwächt." - }, - "baddyBad": { - "name": "Quälzone", - "effect": "Evoli zeigt sich von seiner dunklen Seite und greift an. Dabei wird eine geheimnisvolle Wand erzeugt, die physische Attacken des Ziels abschwächt." - }, - "sappySeed": { - "name": "Sprießbomben", - "effect": "Evoli lässt eine riesige Ranke wachsen, von der Samen herabfallen, die dem Ziel schaden und ihm in jeder Runde KP absaugen." - }, - "freezyFrost": { - "name": "Klirrfrost", - "effect": "Evoli greift mit einem schwarzen Kristall aus gefrorenem Nebel an. Die Statusveränderungen aller am Kampf beteiligten Pokémon werden zurückgesetzt." - }, - "sparklySwirl": { - "name": "Glitzersturm", - "effect": "Evoli greift an, indem es das Ziel in einen nahezu erstickend wohlriechenden Wirbelwind hüllt. Das Team des Anwenders wird von Statusproblemen geheilt." - }, - "veeveeVolley": { - "name": "Evo-Crash", - "effect": "Je größer Evolis Vertrauen zu seinem Trainer ist, desto stärker fällt dieser Angriff aus. Diese Attacke trifft immer." - }, - "doubleIronBash": { - "name": "Panzerfäuste", - "effect": "Der Anwender rotiert um die Schraubenmutter in seinem Brustkorb und schlägt zweimal hintereinander mit den Armen zu. Das Ziel schreckt eventuell zurück." - }, - "maxGuard": { - "name": "Dyna-Wall", - "effect": "Anwender wehrt jede Attacke ab. Scheitert eventuell bei Wiederholung." - }, - "dynamaxCannon": { - "name": "Dynamax-Kanone", - "effect": "Der Anwender schießt einen Strahl aus seinem Kern ab. Verursacht bis zu doppelt so viel Schaden, wenn das Level des Gegners höher als die Levelgrenze ist." - }, - "snipeShot": { - "name": "Präzisionsschuss", - "effect": "Die Attacke richtet sich gegen das ausgewählte Ziel, unabhängig von Fähigkeiten oder Attacken, die Angriffe auf sich ziehen." - }, - "jawLock": { - "name": "Fesselbiss", - "effect": "Anwender und Ziel können nicht ausgetauscht werden, bis einer von ihnen kampfunfähig wird. Der Effekt endet, wenn eines der Pokémon das Kampffeld verlässt." - }, - "stuffCheeks": { - "name": "Backenstopfer", - "effect": "Der Anwender frisst die Beere, die er trägt, wodurch seine Verteidigung stark erhöht wird." - }, - "noRetreat": { - "name": "Finalformation", - "effect": "Alle Statuswerte des Anwenders werden erhöht, aber dafür kann er weder ausgewechselt werden noch fliehen." - }, - "tarShot": { - "name": "Teerschuss", - "effect": "Der Anwender übergießt das Ziel mit klebrigem Teer und senkt so dessen Initiative. Dadurch wird es schwach gegenüber Feuer-Attacken." - }, - "magicPowder": { - "name": "Magiepuder", - "effect": "Das Ziel wird mit magischem Puder bestreut und nimmt den Typ Psycho an." - }, - "dragonDarts": { - "name": "Drachenpfeile", - "effect": "Der Anwender greift zweimal mit Grolldra an. Bei zwei Zielen werden beide jeweils einmal angegriffen." - }, - "teatime": { - "name": "Teatime", - "effect": "Der Anwender lädt alle am Kampf beteiligten Pokémon zu einem Teekränzchen ein, woraufhin diese die Beeren essen, die sie bei sich tragen." - }, - "octolock": { - "name": "Octoklammer", - "effect": "Das Ziel wird an der Flucht gehindert und seine Verteidigung und Spezial-Verteidigung sinken jede Runde." - }, - "boltBeak": { - "name": "Schockschnabel", - "effect": "Der Anwender sticht mit einem elektrisch aufgeladenen Schnabel zu. Kommt er vor dem Ziel zum Zug, verdoppelt sich die Stärke der Attacke." - }, - "fishiousRend": { - "name": "Kiemenbiss", - "effect": "Der Anwender beißt mit seinen harten Kiemen zu. Kommt er vor dem Ziel zum Zug, verdoppelt sich die Stärke der Attacke." - }, - "courtChange": { - "name": "Seitenwechsel", - "effect": "Durch eine mysteriöse Macht werden wirksame Effekte auf Mitstreiterseite und gegnerischer Seite getauscht." - }, - "maxFlare": { - "name": "Dyna-Brand", - "effect": "Eine Feuer-Attacke, die nur Dynamax-Pokémon einsetzen können. Die Sonne brennt unbarmherzig fünf Runden lang." - }, - "maxFlutterby": { - "name": "Dyna-Schwarm", - "effect": "Eine Käfer-Attacke, die nur Dynamax-Pokémon einsetzen können. Senkt den Spezial-Angriff des Zieles." - }, - "maxLightning": { - "name": "Dyna-Gewitter", - "effect": "Eine Elektro-Attacke, die nur Dynamax-Pokémon einsetzen können. Erzeugt fünf Runden lang ein Elektrofeld." - }, - "maxStrike": { - "name": "Dyna-Angriff", - "effect": "Eine Normal-Attacke, die nur Dynamax-Pokémon einsetzen können. Senkt die Initiative des Zieles." - }, - "maxKnuckle": { - "name": "Dyna-Faust", - "effect": "Eine Kampf-Attacke, die nur Dynamax-Pokémon einsetzen können. Erhöht den Angriff der Mitstreiterseite." - }, - "maxPhantasm": { - "name": "Dyna-Spuk", - "effect": "Eine Geister-Attacke, die nur Dynamax-Pokémon einsetzen können. Senkt die Verteidigung des Zieles." - }, - "maxHailstorm": { - "name": "Dyna-Frost", - "effect": "Eine Eis-Attacke, die nur Dynamax-Pokémon einsetzen können. Lässt fünf Runden lang einen Hagelsturm toben." - }, - "maxOoze": { - "name": "Dyna-Giftschwall", - "effect": "Eine Gift-Attacke, die nur Dynamax-Pokémon einsetzen können. Erhöht den Spezial-Angriff der Mitstreiterseite." - }, - "maxGeyser": { - "name": "Dyna-Flut", - "effect": "Eine Wasser-Attacke, die nur Dynamax-Pokémon einsetzen können. Löst fünf Runden lang strömenden Regen aus." - }, - "maxAirstream": { - "name": "Dyna-Düse", - "effect": "Eine Flug-Attacke, die nur Dynamax-Pokémon einsetzen können. Erhöht die Initiative der Mitstreiterseite." - }, - "maxStarfall": { - "name": "Dyna-Zauber", - "effect": "Eine Feen-Attacke, die nur Dynamax-Pokémon einsetzen können. Erzeugt fünf Runden lang ein Nebelfeld." - }, - "maxWyrmwind": { - "name": "Dyna-Wyrm", - "effect": "Eine Drachen-Attacke, die nur Dynamax-Pokémon einsetzen können. Senkt den Angriff des Zieles." - }, - "maxMindstorm": { - "name": "Dyna-Kinese", - "effect": "Eine Psycho-Attacke, die nur Dynamax-Pokémon einsetzen können. Erzeugt fünf Runden lang ein Psychofeld." - }, - "maxRockfall": { - "name": "Dyna-Brocken", - "effect": "Eine Gesteins-Attacke, die nur Dynamax-Pokémon einsetzen können. Lässt fünf Runden lang einen Sandsturm toben." - }, - "maxQuake": { - "name": "Dyna-Erdstoß", - "effect": "Eine Boden-Attacke, die nur Dynamax-Pokémon einsetzen können. Erhöht die Spezial-Verteidigung der Mitstreiterseite." - }, - "maxDarkness": { - "name": "Dyna-Dunkel", - "effect": "Eine Unlicht-Attacke, die nur Dynamax-Pokémon einsetzen können. Senkt die Spezial-Verteidigung des Zieles." - }, - "maxOvergrowth": { - "name": "Dyna-Flora", - "effect": "Eine Pflanzen-Attacke, die nur Dynamax-Pokémon einsetzen können. Erzeugt fünf Runden lang ein Grasfeld." - }, - "maxSteelspike": { - "name": "Dyna-Stahlzacken", - "effect": "Eine Stahl-Attacke, die nur Dynamax-Pokémon einsetzen können. Erhöht die Verteidigung der Mitstreiterseite." - }, - "clangorousSoul": { - "name": "Seelentanz", - "effect": "Der Anwender setzt eine kleine Menge an KP ein, um alle seine Statuswerte zu erhöhen." - }, - "bodyPress": { - "name": "Body Press", - "effect": "Der Anwender greift mit seinem ganzen Körper an. Je höher seine Verteidigung ist, desto mehr Schaden richtet er an." - }, - "decorate": { - "name": "Verzierung", - "effect": "Durch Verzierungen werden der Angriff und Spezial-Angriff des Zieles stark erhöht." - }, - "drumBeating": { - "name": "Trommelschläge", - "effect": "Der Anwender kontrolliert durch Trommeln Wurzeln, die das Ziel angreifen und dessen Initiative senken." - }, - "snapTrap": { - "name": "Fangeisen", - "effect": "Das Ziel wird vier bis fünf Runden lang in einem Fangeisen festgehalten und angegriffen." - }, - "pyroBall": { - "name": "Feuerball", - "effect": "Der Anwender greift mit einem Ball aus Feuer an, den er durch Anzünden eines kleinen Steins erzeugt. Fügt dem Ziel eventuell Verbrennungen zu." - }, - "behemothBlade": { - "name": "Gigantenhieb", - "effect": "Der Anwender wird zu einem riesigen Schwert und greift das Ziel an. Dynamaximierte Ziele erleiden doppelten Schaden." - }, - "behemothBash": { - "name": "Gigantenstoß", - "effect": "Der Anwender wird zu einem riesigen Schild und greift das Ziel an. Dynamaximierte Ziele erleiden doppelten Schaden." - }, - "auraWheel": { - "name": "Aura-Rad", - "effect": "Mithilfe der in den Backentaschen gespeicherten Energie greift der Anwender an und erhöht seine Initiative. Der Typ der Attacke hängt von Morpekos Form ab." - }, - "breakingSwipe": { - "name": "Breitseite", - "effect": "Der Anwender schwingt heftig seinen robusten Schweif, um damit gegnerische Pokémon anzugreifen und ihren Angriffs-Wert zu senken." - }, - "branchPoke": { - "name": "Zweigstoß", - "effect": "Der Anwender attackiert das Ziel mit einem spitzen Zweig." - }, - "overdrive": { - "name": "Overdrive", - "effect": "Der Anwender haut in die Saiten seiner Gitarre oder seines Basses und erzeugt dröhnende, kraftvolle Vibrationen, die gegnerischen Pokémon schaden." - }, - "appleAcid": { - "name": "Apfelsäure", - "effect": "Der Anwender greift mit einer aus einem sauren Apfel hergestellten säurehaltigen Flüssigkeit an. Dabei wird die Spezial-Verteidigung des Zieles gesenkt." - }, - "gravApple": { - "name": "Gravitation", - "effect": "Ein Apfel fällt aus großer Höhe herab und richtet Schaden an. Dabei wird die Verteidigung des Zieles gesenkt." - }, - "spiritBreak": { - "name": "Seelenbruch", - "effect": "Die Attacke trifft das Ziel mit so viel Wucht, dass es den Mut verliert. Dabei wird sein Spezial-Angriff gesenkt." - }, - "strangeSteam": { - "name": "Wunderdampf", - "effect": "Der Anwender stößt Dampf aus, mit dem er das Ziel angreift. Dieses wird eventuell verwirrt." - }, - "lifeDew": { - "name": "Lebenstropfen", - "effect": "Wundersames Wasser heilt die KP des Anwenders und seiner am Kampf beteiligten Mitstreiter." - }, - "obstruct": { - "name": "Abblocker", - "effect": "Der Anwender wehrt jede Attacke ab. Berührt ihn währenddessen ein Pokémon, sinkt dessen Verteidigung stark. Scheitert eventuell bei Wiederholung." - }, - "falseSurrender": { - "name": "Kniefalltrick", - "effect": "Der Anwender tut so, als würde er sich verneigen, und sticht dann mit seinem zerzausten Fell zu. Diese Attacke trifft immer." - }, - "meteorAssault": { - "name": "Sternensturm", - "effect": "Der Anwender greift mit seiner Lauchstange an. Von der Wucht der Attacke wird ihm jedoch so schwindelig, dass er in der nächsten Runde nicht handeln kann." - }, - "eternabeam": { - "name": "Unendynastrahlen", - "effect": "Der mächtigste Angriff, über den Endynalos in seiner ursprünglichen Form verfügt. In der nächsten Runde kann der Anwender nicht handeln." - }, - "steelBeam": { - "name": "Stahlstrahl", - "effect": "Der Anwender schießt Stahl, den er in seinem ganzen Körper angesammelt hat, in Form eines mächtigen Strahls ab. Dabei verletzt er sich auch selbst." - }, - "expandingForce": { - "name": "Flächenmacht", - "effect": "Der Anwender greift das Ziel mit Psycho-Kräften an. Wenn ein Psychofeld aktiv ist, steigt die Stärke und es wird allen gegnerischen Pokémon Schaden zugefügt." - }, - "steelRoller": { - "name": "Eisenwalze", - "effect": "Der Anwender greift an und zerstört dabei etwaige Felder. Ist kein Feld aktiv, schlägt die Attacke fehl." - }, - "scaleShot": { - "name": "Schuppenschuss", - "effect": "Der Anwender greift das Ziel zwei- bis fünfmal hintereinander mit Schuppen-Geschossen an. Erhöht die eigene Initiative, aber senkt die Verteidigung." - }, - "meteorBeam": { - "name": "Meteorstrahl", - "effect": "Der Anwender sammelt in Runde 1 kosmische Kräfte und erhöht damit seinen Spezial-Angriff, bevor er in Runde 2 das Ziel angreift." - }, - "shellSideArm": { - "name": "Muschelwaffe", - "effect": "Je nachdem, was höher ausfällt, richtet diese Attacke entweder physischen oder Spezial-Schaden an. Das Ziel wird eventuell vergiftet." - }, - "mistyExplosion": { - "name": "Nebelexplosion", - "effect": "Der Anwender greift alle Pokémon im Umkreis an und wird danach kampfunfähig. Die Stärke dieser Attacke steigt, wenn ein Nebelfeld aktiv ist." - }, - "grassyGlide": { - "name": "Grasrutsche", - "effect": "Der Anwender rutscht über den Boden und greift das Ziel an. Ermöglicht den Erstschlag, wenn ein Grasfeld aktiv ist." - }, - "risingVoltage": { - "name": "Hochspannung", - "effect": "Der Anwender greift mit aus dem Boden aufsteigender Elektrizität an. Die Stärke der Attacke wird verdoppelt, wenn beim Gegner ein Elektrofeld aktiv ist." - }, - "terrainPulse": { - "name": "Feldimpuls", - "effect": "Der Anwender nutzt die Kraft des aktiven Feldes für seinen Angriff. Der Typ und die Stärke der Attacke ändern sich je nach Art des aktiven Feldes." - }, - "skitterSmack": { - "name": "Krabbelkracher", - "effect": "Der Anwender kriecht hinter das Ziel, greift es an und senkt dabei dessen Spezial-Angriff." - }, - "burningJealousy": { - "name": "Neidflammen", - "effect": "Der Anwender greift mit der Energie seines Neids an und fügt allen gegnerischen Pokémon, deren Statuswerte in dieser Runde erhöht wurden, Verbrennungen zu." - }, - "lashOut": { - "name": "Frustventil", - "effect": "Der Anwender entlädt seinen Frust in einem Angriff. Die Stärke der Attacke wird verdoppelt, wenn seine Statuswerte in dieser Runde gesenkt wurden." - }, - "poltergeist": { - "name": "Poltergeist", - "effect": "Der Anwender greift das Ziel mit dessen getragenem Item an. Die Attacke schlägt fehl, wenn das Ziel kein Item trägt." - }, - "corrosiveGas": { - "name": "Korrosionsgas", - "effect": "Der Anwender greift alle Pokémon im Umkreis mit einem ätzenden Gas an. Getragene Items werden dadurch zersetzt." - }, - "coaching": { - "name": "Coaching", - "effect": "Der Anwender sorgt durch geschickte Anweisungen dafür, dass der Angriff und die Verteidigung seiner Mitstreiter steigen." - }, - "flipTurn": { - "name": "Rollwende", - "effect": "Nach der Attacke eilt der Anwender zurück und tauscht den Platz mit einem anderen Pokémon." - }, - "tripleAxel": { - "name": "Dreifach-Axel", - "effect": "Tritt das Ziel ein- bis dreimal nacheinander. Die Härte der Tritte nimmt von Treffer zu Treffer zu." - }, - "dualWingbeat": { - "name": "Doppelflügel", - "effect": "Der Anwender trifft das Ziel zweimal hintereinander mit seinen Flügeln und fügt ihm so Schaden zu." - }, - "scorchingSands": { - "name": "Brandsand", - "effect": "Der Anwender greift das Ziel mit brennend heißem Sand an und fügt ihm eventuell Verbrennungen zu." - }, - "jungleHealing": { - "name": "Dschungelheilung", - "effect": "Der Anwender wird eins mit dem Dschungel und heilt bei sich und seinen am Kampf beteiligten Mitstreitern KP und hebt jegliche Statusprobleme auf." - }, - "wickedBlow": { - "name": "Finstertreffer", - "effect": "Der Anwender hat den Stil des Unlichts gemeistert und führt einen fokussierten, harten Schlag mit Volltreffergarantie aus." - }, - "surgingStrikes": { - "name": "Trefferschwall", - "effect": "Der Anwender hat den Stil des Wassers gemeistert und führt mit fließenden Bewegungen drei Angriffe in Folge mit Volltreffergarantie aus." - }, - "thunderCage": { - "name": "Blitzgefängnis", - "effect": "Das Ziel wird für vier bis fünf Runden in einem elektrischen Käfig gefangen." - }, - "dragonEnergy": { - "name": "Drachenkräfte", - "effect": "Der Anwender wandelt seine Lebenskraft in Energie um und greift gegnerische Pokémon an. Je höher seine KP sind, desto mehr Schaden wird angerichtet." - }, - "freezingGlare": { - "name": "Eisiger Blick", - "effect": "Der Anwender greift das Ziel mit Psycho-Kräften an, die er aus seinen Augen abschießt. Das Ziel friert eventuell ein." - }, - "fieryWrath": { - "name": "Brennender Zorn", - "effect": "Der Anwender wandelt seinen Zorn in eine flammende Aura um und greift damit gegnerische Pokémon an. Diese schrecken eventuell zurück." - }, - "thunderousKick": { - "name": "Donnernder Tritt", - "effect": "Der Anwender bringt das Ziel mit blitzschnellen Bewegungen durcheinander und tritt dann zu. Senkt die Verteidigung des Zieles." - }, - "glacialLance": { - "name": "Blizzardlanze", - "effect": "Der Anwender wirft eine in einen Blizzard gehüllte Lanze aus Eis auf gegnerische Pokémon." - }, - "astralBarrage": { - "name": "Astralfragmente", - "effect": "Der Anwender greift gegnerische Pokémon mit vielen kleinen Spukgestalten an." - }, - "eerieSpell": { - "name": "Schauderspruch", - "effect": "Der Anwender greift mit gewaltigen Psycho-Kräften an. Die AP der letzten Attacke des Zieles werden um 3 Punkte gesenkt." - }, - "direClaw": { - "name": "Unheilsklauen", - "effect": "Der Anwender greift mit zerstörerischen Klauen an. Das Ziel wird eventuell vergiftet, paralysiert oder in Schlaf versetzt." - }, - "psyshieldBash": { - "name": "Barrierenstoß", - "effect": "Der Anwender hüllt sich in Psycho-Energie und rammt das Ziel. Außerdem steigt seine Verteidigung." - }, - "powerShift": { - "name": "Kraftwechsel", - "effect": "Der Anwender tauscht seinen Angriff mit seiner Verteidigung." - }, - "stoneAxe": { - "name": "Felsaxt", - "effect": "Der Anwender greift mit seinen Felsäxten an. Dadurch verstreut er schwebende Felssplitter im Umkreis des Zieles." - }, - "springtideStorm": { - "name": "Frühlingsorkan", - "effect": "Der Anwender greift gegnerische Pokémon an, indem er sie mit heftigen Windböen voller Hassliebe umgibt. Eventuell sinkt ihr Angriff." - }, - "mysticalPower": { - "name": "Mythenkraft", - "effect": "Der Anwender greift mit einer wundersamen Kraft an. Außerdem steigt sein Spezial-Angriff." - }, - "ragingFury": { - "name": "Flammenwut", - "effect": "Der Anwender wütet zwei bis drei Runden lang und speit heftige Flammen aus. Danach wird er verwirrt." - }, - "waveCrash": { - "name": "Wellentackle", - "effect": "Der Anwender hüllt sich in Wasser und stürzt sich mit dem ganzen Körper auf das Ziel, wobei er selbst großen Schaden erleidet." - }, - "chloroblast": { - "name": "Chlorostrahl", - "effect": "Der Anwender greift mit einer hohen Konzentration seines Chlorophylls an, wobei er selbst Schaden erleidet." - }, - "mountainGale": { - "name": "Frostfallwind", - "effect": "Der Anwender wirft gigantische Eisbrocken auf das Ziel. Dieses schreckt eventuell zurück." - }, - "victoryDance": { - "name": "Siegestanz", - "effect": "Der Anwender führt einen wilden Tanz auf, der den Sieg herbeiführen soll. Dies erhöht seinen Angriff, seine Verteidigung und seine Initiative." - }, - "headlongRush": { - "name": "Schmetterramme", - "effect": "Der Anwender rammt das Ziel mit dem ganzen Körper. Dadurch sinken die Verteidigung und Spezial-Verteidigung des Anwenders." - }, - "barbBarrage": { - "name": "Giftstachelregen", - "effect": "Der Anwender greift mit unzähligen Giftstacheln an und vergiftet das Ziel eventuell. Doppelt so stark gegen vergiftete Ziele." - }, - "esperWing": { - "name": "Auraschwingen", - "effect": "Ein schneidender Angriff mit durch eine Aura verstärkten Schwingen, der außerdem die Initiative des Anwenders erhöht. Hohe Volltrefferquote." - }, - "bitterMalice": { - "name": "Niedertracht", - "effect": "Der Anwender greift mit eiskaltem, schaudererregendem Hass an und senkt dabei den Angriff des Zieles." - }, - "shelter": { - "name": "Refugium", - "effect": "Der Anwender macht seine Haut so hart wie Eisen und erhöht dadurch seine Verteidigung stark." - }, - "tripleArrows": { - "name": "Drillingspfeile", - "effect": "Der Anwender tritt zu und schießt dann drei Pfeile ab. Senkt eventuell die Verteidigung des Zieles oder lässt es zurückschrecken. Hohe Volltrefferquote." - }, - "infernalParade": { - "name": "Phantomparade", - "effect": "Angriff mit unzähligen Feuerkugeln, der dem Ziel eventuell Verbrennungen zufügt. Doppelt so stark gegen Ziele mit Statusproblemen." - }, - "ceaselessEdge": { - "name": "Klingenschwall", - "effect": "Der Anwender greift mit einer klingengleichen Muschelschale an und verstreut Muschelsplitter, die Stacheln zu Füßen des Zieles werden." - }, - "bleakwindStorm": { - "name": "Polarorkan", - "effect": "Der Anwender greift mit starken, kalten Winden an, die Körper und Geist erzittern lassen. Senkt eventuell die Initiative gegnerischer Pokémon." - }, - "wildboltStorm": { - "name": "Donnerorkan", - "effect": "Der Anwender ruft ein heftiges Unwetter herbei, um mit Wind und Blitzen anzugreifen. Gegnerische Pokémon werden eventuell paralysiert." - }, - "sandsearStorm": { - "name": "Wüstenorkan", - "effect": "Der Anwender greift gegnerische Pokémon an, indem er sie mit heftigen Windböen und brennend heißem Sand umgibt. Eventuell erleiden sie Verbrennungen." - }, - "lunarBlessing": { - "name": "Lunargebet", - "effect": "Der Anwender richtet ein Gebet an den Mond und heilt bei sich und seinen am Kampf beteiligten Mitstreitern KP und hebt jegliche Statusprobleme auf." - }, - "takeHeart": { - "name": "Mutschub", - "effect": "Der Anwender fasst sich ein Herz, befreit sich von Statusproblemen und erhöht außerdem seinen Spezial-Angriff und seine Spezial-Verteidigung." - }, - "gMaxWildfire": { - "name": "Giga-Feuerflug", - "effect": "Eine Feuer-Attacke, die nur Gigadynamax-Glurak einsetzen kann. Fügt vier Runden lang Schaden zu." - }, - "gMaxBefuddle": { - "name": "Giga-Benebelung", - "effect": "Eine Käfer-Attacke, die nur Gigadynamax-Smettbo einsetzen kann. Gegnerische Pokémon werden entweder vergiftet, paralysiert oder in Schlaf versetzt." - }, - "gMaxVoltCrash": { - "name": "Giga-Blitzhagel", - "effect": "Eine Elektro-Attacke, die nur Gigadynamax-Pikachu einsetzen kann. Gegnerische Pokémon werden paralysiert." - }, - "gMaxGoldRush": { - "name": "Giga-Münzregen", - "effect": "Eine Normal-Attacke, die nur Gigadynamax-Mauzi einsetzen kann. Verwirrt Gegner und bringt nach dem Kampf Geld ein." - }, - "gMaxChiStrike": { - "name": "Giga-Fokusschlag", - "effect": "Eine Kampf-Attacke, die nur Gigadynamax-Machomei einsetzen kann. Erhöht die Volltrefferquote auf Mitstreiterseite." - }, - "gMaxTerror": { - "name": "Giga-Spuksperre", - "effect": "Eine Geister-Attacke, die nur Gigadynamax-Gengar einsetzen kann. Hindert gegnerische Pokémon an der Flucht beziehungsweise am Auswechseln." - }, - "gMaxResonance": { - "name": "Giga-Melodie", - "effect": "Eine Eis-Attacke, die nur Gigadynamax-Lapras einsetzen kann. Reduziert fünf Runden lang den erlittenen Schaden." - }, - "gMaxCuddle": { - "name": "Giga-Gekuschel", - "effect": "Eine Normal-Attacke, die nur Gigadynamax-Evoli einsetzen kann. Gegnerische Pokémon verlieben sich in es." - }, - "gMaxReplenish": { - "name": "Giga-Recycling", - "effect": "Eine Normal-Attacke, die nur Gigadynamax-Relaxo einsetzen kann. Stellt bereits verzehrte Beeren wieder her." - }, - "gMaxMalodor": { - "name": "Giga-Gestank", - "effect": "Eine Gift-Attacke, die nur Gigadynamax-Deponitox einsetzen kann. Vergiftet gegnerische Pokémon." - }, - "gMaxStonesurge": { - "name": "Giga-Geröll", - "effect": "Eine Wasser-Attacke, die nur Gigadynamax-Kamalm einsetzen kann. Verstreut viele spitze Steinbrocken auf dem Kampffeld." - }, - "gMaxWindRage": { - "name": "Giga-Sturmstoß", - "effect": "Eine Flug-Attacke, die nur Gigadynamax-Krarmor einsetzen kann. Beseitigt die Effekte von Attacken wie Reflektor und Lichtschild.." - }, - "gMaxStunShock": { - "name": "Giga-Voltschlag", - "effect": "Eine Elektro-Attacke, die nur Gigadynamax-Riffex einsetzen kann. Vergiftet oder paralysiert gegnerische Pokémon." - }, - "gMaxFinale": { - "name": "Giga-Lichtblick", - "effect": "Eine Feen-Attacke, die nur Gigadynamax-Pokusan einsetzen kann. Füllt die KP auf Mitstreiterseite auf." - }, - "gMaxDepletion": { - "name": "Giga-Dämpfer", - "effect": "Eine Drachen-Attacke, die nur Gigadynamax-Duraludon einsetzen kann. AP der letzten Attacke, die gegnerische Pokémon eingesetzt haben, werden gesenkt." - }, - "gMaxGravitas": { - "name": "Giga-Astrowellen", - "effect": "Eine Psycho-Attacke, die nur Gigadynamax-Maritellit einsetzen kann. Ändert die Erdanziehung für fünf Runden." - }, - "gMaxVolcalith": { - "name": "Giga-Schlacke", - "effect": "Eine Gesteins-Attacke, die nur Gigadynamax-Montecarbo einsetzen kann. Fügt vier Runden lang Schaden zu." - }, - "gMaxSandblast": { - "name": "Giga-Sandstoß", - "effect": "Eine Boden-Attacke, die nur Gigadynamax-Sanaconda einsetzen kann. Eine Sandhose wütet für vier bis fünf Runden." - }, - "gMaxSnooze": { - "name": "Giga-Gähnzwang", - "effect": "Eine Unlicht-Attacke, die nur Gigadynamax-Olangaar einsetzen kann. Mit einem großen Gähner wird das Ziel müde gemacht und schläft in der nächsten Runde ein." - }, - "gMaxTartness": { - "name": "Giga-Säureguss", - "effect": "Eine Pflanzen-Attacke, die nur Gigadynamax-Drapfel einsetzen kann. Senkt den Ausweichwert der gegnerischen Pokémon." - }, - "gMaxSweetness": { - "name": "Giga-Nektarflut", - "effect": "Eine Pflanzen-Attacke, die nur Gigadynamax-Schlapfel einsetzen kann. Heilt Statusprobleme auf Mitstreiterseite." - }, - "gMaxSmite": { - "name": "Giga-Sanktion", - "effect": "Eine Feen-Attacke, die nur Gigadynamax-Silembrim einsetzen kann. Verwirrt gegnerische Pokémon." - }, - "gMaxSteelsurge": { - "name": "Giga-Stahlschlag", - "effect": "Eine Stahl-Attacke, die nur Gigadynamax-Patinaraja einsetzen kann. Verstreut viele zackige Stahlsplitter auf dem Kampffeld." - }, - "gMaxMeltdown": { - "name": "Giga-Schmelze", - "effect": "Eine Stahl-Attacke, die nur Gigadynamax-Melmetal einsetzen kann. Hindert Gegner am wiederholten Einsatz derselben Attacke." - }, - "gMaxFoamBurst": { - "name": "Giga-Schaumbad", - "effect": "Eine Wasser-Attacke, die nur Gigadynamax-Kingler einsetzen kann. Senkt die Initiative der gegnerischen Pokémon stark." - }, - "gMaxCentiferno": { - "name": "Giga-Feuerkessel", - "effect": "Eine Feuer-Attacke, die nur Gigadynamax-Infernopod einsetzen kann. Schließt gegnerische Pokémon vier bis fünf Runden in wirbelnden Flammen ein." - }, - "gMaxVineLash": { - "name": "Giga-Geißel", - "effect": "Eine Pflanzen-Attacke, die nur Gigadynamax-Bisaflor einsetzen kann. Geißelt gegnerische Pokémon vier Runden lang mit peitschenartigen Ranken." - }, - "gMaxCannonade": { - "name": "Giga-Beschuss", - "effect": "Eine Wasser-Attacke, die nur Gigadynamax-Turtok einsetzen kann. Schließt gegnerische Pokémon vier Runden lang in einem Wasserwirbel ein." - }, - "gMaxDrumSolo": { - "name": "Giga-Getrommel", - "effect": "Eine Pflanzen-Attacke, die nur Gigadynamax-Gortrom einsetzen kann. Ignoriert die Effekte der gegnerischen Fähigkeiten." - }, - "gMaxFireball": { - "name": "Giga-Brandball", - "effect": "Eine Feuer-Attacke, die nur Gigadynamax-Liberlo einsetzen kann. Ignoriert die Effekte der gegnerischen Fähigkeiten." - }, - "gMaxHydrosnipe": { - "name": "Giga-Schütze", - "effect": "Eine Wasser-Attacke, die nur Gigadynamax-Intelleon einsetzen kann. Ignoriert die Effekte der gegnerischen Fähigkeiten." - }, - "gMaxOneBlow": { - "name": "Giga-Einzelhieb", - "effect": "Eine Unlicht-Attacke, die nur Gigadynamax-Wulaosu einsetzen kann. Dieser Einzelhieb ignoriert die schützende Wirkung von Dyna-Wall." - }, - "gMaxRapidFlow": { - "name": "Giga-Multihieb", - "effect": "Eine Wasser-Attacke, die nur Gigadynamax-Wulaosu einsetzen kann. Dieser Multihieb ignoriert die schützende Wirkung von Dyna-Wall." - }, - "teraBlast": { - "name": "Tera-Ausbruch", - "effect": "Ist der Anwender terakristallisiert, greift er mit Energie seines Tera-Typs an. Der Schaden hängt vom Angriff oder Spezial-Angriff ab, je nachdem, welcher Wert höher ist." - }, - "silkTrap": { - "name": "Fadenfalle", - "effect": "Der Anwender spannt eine Falle aus Fäden und wird so vor Angriffen geschützt. Berührt ihn nun ein Angreifer, sinkt dessen Initiative." - }, - "axeKick": { - "name": "Fersenkick", - "effect": "Der Anwender greift an, indem er seine erhobene Ferse hinunterschnellen lässt. Das Ziel wird eventuell verwirrt. Bei Misserfolg verletzt sich der Anwender selbst." - }, - "lastRespects": { - "name": "Letzte Ehre", - "effect": "Der Anwender rächt gefallene Mitstreiter. Je mehr kampfunfähige Pokémon sich im Team befinden, desto stärker ist die Attacke." - }, - "luminaCrash": { - "name": "Lichteinschlag", - "effect": "Der Anwender greift an, indem er ein sonderbares Licht freisetzt, das sich auch auf die Psyche auswirkt. Zudem wird die Spezial-Verteidigung des Zieles stark gesenkt." - }, - "orderUp": { - "name": "Auftischen", - "effect": "Eine Attacke mit geübten Bewegungen. Trägt der Anwender ein Nigiragi im Maul, erhöht sich je nach dessen Form ein Statuswert des Anwenders." - }, - "jetPunch": { - "name": "Düsenhieb", - "effect": "Bei dieser Erstschlag-Attacke hüllt der Anwender seine Faust in einen Strudel und greift mit einem extrem schnellen Hieb an." - }, - "spicyExtract": { - "name": "Chili-Essenz", - "effect": "Der Anwender setzt eine unglaublich scharfe Essenz frei, die den Angriff des Zieles stark erhöht, aber seine Verteidigung stark senkt." - }, - "spinOut": { - "name": "Reifendrehung", - "effect": "Der Anwender wirbelt wild umher, indem er sein Gewicht auf seine Extremitäten verlagert, und richtet so Schaden an. Seine eigene Initiative sinkt dadurch stark" - }, - "populationBomb": { - "name": "Mäuseplage", - "effect": "Der Anwender versammelt eine Schar von Artgenossen, die dann geschlossen angreift und das Ziel ein- bis zehnmal hintereinander trifft." - }, - "iceSpinner": { - "name": "Eiskreisel", - "effect": "Der Anwender hüllt seine Füße in dünnes Eis, wirbelt herum und greift so das Ziel an. Die Drehung zerstört etwaige Felder" - }, - "glaiveRush": { - "name": "Großklingenstoß", - "effect": "Der Anwender stürzt sich waghalsig auf das Ziel. Bis zum nächsten Zug des Anwenders treffen ihn gegnerische Angriffe garantiert und richten doppelten Schaden an." - }, - "revivalBlessing": { - "name": "Vitalsegen", - "effect": "Der Anwender belebt mit einem Wunsch voller Mitgefühl ein kampfunfähiges Team-Mitglied wieder und stellt die Hälfte dessen maximaler KP wieder her." - }, - "saltCure": { - "name": "Pökelsalz", - "effect": "Der Anwender pökelt das Ziel mit Salz ein, wodurch dieses jede Runde Schaden erleidet. Stahl- und Wasser-Pokémon leiden besonders darunter." - }, - "tripleDive": { - "name": "Tauchtriade", - "effect": "Der Anwender taucht mit perfekt abgestimmtem Timing ab und trifft das Ziel mit Wasserspritzern. Dabei richtet er dreimal hintereinander Schaden an." - }, - "mortalSpin": { - "name": "Letalwirbler", - "effect": "Der Anwender greift mit einer wirbelnden Attacke an, die Gegner auch vergiftet. Befreit den Anwender unter anderem von Wickel, Klammergriff und Egelsamen." - }, - "doodle": { - "name": "Abpausen", - "effect": "Der Anwender kopiert die wahre Essenz des Zieles. Dadurch erhalten alle Pokémon auf der Mitstreiterseite die Fähigkeit des Zieles." - }, - "filletAway": { - "name": "Abspaltung", - "effect": "Der Anwender setzt seine KP ein, um seinen Angriff, seinen Spezial-Angriff und seine Initiative stark zu erhöhen." - }, - "kowtowCleave": { - "name": "Kniefallspalter", - "effect": "Der Anwender fällt auf die Knie und verleitet das Ziel zu Unachtsamkeit, bevor er mit einer Klinge zuschlägt. Diese Attacke trifft garantiert." - }, - "flowerTrick": { - "name": "Blumentrick", - "effect": "Der Anwender greift an, indem er dem Ziel einen Trick-Strauß zuwirft. Diese Attacke trifft immer und hat zudem Volltreffergarantie." - }, - "torchSong": { - "name": "Loderlied", - "effect": "Der Anwender spuckt inbrünstig lodernde Flammen, als würde er singen, und versengt das Ziel. Dadurch steigt auch der Spezial-Angriff des Anwenders." - }, - "aquaStep": { - "name": "Wogentanz", - "effect": "Der Anwender neckt das Ziel mit flinken, fließenden Tanzschritten und greift es dann an. Dadurch steigt auch die Initiative des Anwenders." - }, - "ragingBull": { - "name": "Rasender Stier", - "effect": "Ein rasender Angriff eines wilden Stiers, der auch Barrieren wie Lichtschild und Reflektor durchbricht. Der Attacken-Typ hängt von der Form des Anwenders ab." - }, - "makeItRain": { - "name": "Goldrausch", - "effect": "Der Anwender greift an, indem er Unmengen an Münzen ausschüttet, senkt dabei aber seinen Spezial-Angriff. Das Geld wird nach dem Kampf aufgesammelt." - }, - "psyblade": { - "name": "Psychoschneide", - "effect": "Das Ziel wird mit einer immateriellen Klinge angegriffen. Die Stärke der Attacke steigt um 50 %, wenn beim Anwender ein Elektrofeld aktiv ist." - }, - "hydroSteam": { - "name": "Hydrodampf", - "effect": "Das Ziel wird kraftvoll mit brodelndem Wasser übergossen. Wider Erwarten sinkt die Stärke der Attacke bei starkem Sonnenlicht nicht, sondern steigt um 50 %." - }, - "ruination": { - "name": "Verderben", - "effect": "Der Anwender beschwört Verderben bringendes Unheil herauf und halbiert die KP des Zieles." - }, - "collisionCourse": { - "name": "Kollisionskurs", - "effect": "Der Anwender wechselt seine Form, während er sich gen Boden stürzt, und verursacht eine riesige Ur-Explosion. Ist die Attacke sehr effektiv, steigt ihre Stärke noch mehr." - }, - "electroDrift": { - "name": "Blitztour", - "effect": "Der Anwender wechselt bei rasantem Tempo seine Form und trifft das Ziel mit einem futuristischen Elektroschlag. Ist die Attacke sehr effektiv, steigt ihre Stärke noch mehr." - }, - "shedTail": { - "name": "Schwanzabwurf", - "effect": "Der Anwender setzt seine KP ein, um einen Doppelgänger zu erzeugen, und tauscht dann den Platz mit einem anderen Pokémon." - }, - "chillyReception": { - "name": "Eisige Stimmung", - "effect": "Der Anwender sorgt mit einem schlechten Witz für eisige Stimmung und tauscht den Platz mit einem anderen Pokémon. Erzeugt fünf Runden lang Schnee." - }, - "tidyUp": { - "name": "Aufräumen", - "effect": "Die Effekte von Stachler, Tarnsteine, Klebenetz, Giftspitzen und Delegator werden aufgehoben. Zudem steigen der Angriff und die Initiative des Anwenders." - }, - "snowscape": { - "name": "Schneelandschaft", - "effect": "Erzeugt fünf Runden lang Schnee. Dadurch wird die Verteidigung von Eis-Pokémon erhöht." - }, - "pounce": { - "name": "Anspringen", - "effect": "Der Anwender greift an, indem er das Ziel anspringt. Dadurch sinkt auch die Initiative des Zieles." - }, - "trailblaze": { - "name": "Wegbereiter", - "effect": "Der Anwender greift an, als würde er aus hohem Gras hervorspringen. Mit wendigen Schritten erhöht er seine Initiative." - }, - "chillingWater": { - "name": "Kalte Dusche", - "effect": "Der Anwender greift an, indem er das Ziel mit eiskaltem Wasser überschüttet. Das raubt dem Ziel seinen Kampfgeist und senkt so seinen Angriff." - }, - "hyperDrill": { - "name": "Hyperbohrer", - "effect": "Der Anwender lässt einen spitzen Teil seines Körpers rasant rotieren, sticht zu und durchbricht dabei auch die Wirkung von Attacken wie Schutzschild und Scanner." - }, - "twinBeam": { - "name": "Doppelstrahl", - "effect": "Der Anwender greift mit übernatürlichen Lichtstrahlen an, die er aus seinen Augen abfeuert, und trifft das Ziel zweimal hintereinander." - }, - "rageFist": { - "name": "Zornesfaust", - "effect": "Ein Angriff, für den der Anwender seinen Zorn in Energie umwandelt. Je häufiger der Anwender getroffen wurde, desto stärker wird diese Attacke." - }, - "armorCannon": { - "name": "Rüstungskanone", - "effect": "Der Anwender schießt die eigene Rüstung als glühendes Projektil auf das Ziel. Dadurch sinken die Verteidigung und Spezial-Verteidigung des Anwenders." - }, - "bitterBlade": { - "name": "Reueschwert", - "effect": "Der Anwender tränkt seine Klinge in Bedauern und Reue und greift damit an. Die Hälfte des zugefügten Schadens wird dem Anwender als KP gutgeschrieben." - }, - "doubleShock": { - "name": "Zweifachladung", - "effect": "Der Anwender nutzt die gesamte Elektrizität in seinem Körper, um großen Schaden auszuteilen. Die restliche Kampfdauer gehört er nicht mehr dem Typ Elektro an." - }, - "gigatonHammer": { - "name": "Riesenhammer", - "effect": "Der Anwender greift mit einem großen Hammer an, den er mit vollem Körpereinsatz um sich schwingt. Diese Attacke kann nicht zweimal in Folge eingesetzt werden." - }, - "comeuppance": { - "name": "Vendetta", - "effect": "Der Anwender rächt sich an dem Gegner, der ihm zuletzt mit einer Attacke Schaden zugefügt hat, indem er ihm den Schaden mit erhöhter Kraft zurückzahlt." - }, - "aquaCutter": { - "name": "Aquaschnitt", - "effect": "Der Anwender stößt Wasser unter Druck aus, um das Ziel wie mit einer Klinge anzugreifen. Hohe Volltrefferquote." - }, - "blazingTorque": { - "name": "Hitzeturbo", - "effect": "Der Anwender rammt seinen glühend heißen Motor in das Ziel. Dieses erleidet eventuell Verbrennungen." - }, - "wickedTorque": { - "name": "Finsterturbo", - "effect": "Der Anwender rammt seinen Motor mit böswilliger Absicht in das Ziel. Dieses schläft eventuell ein." - }, - "noxiousTorque": { - "name": "Toxiturbo", - "effect": "Der Anwender rammt seinen giftigen Motor in das Ziel. Dieses wird eventuell vergiftet." - }, - "combatTorque": { - "name": "Raufturbo", - "effect": "Der Anwender rammt seinen Motor gewaltvoll in das Ziel. Dieses wird eventuell paralysiert." - }, - "magicalTorque": { - "name": "Zauberturbo", - "effect": "Der Anwender rammt seinen feenartigen Motor in das Ziel. Dieses wird eventuell verwirrt." - }, - "bloodMoon": { - "name": "Blutmond", - "effect": "Der Anwender entfesselt eine gewaltige Energieladung aus einem blutroten Vollmond. Diese Attacke kann nicht zweimal in Folge eingesetzt werden." - }, - "matchaGotcha": { - "name": "Quirlschuss", - "effect": "Der Anwender verschießt gequirlten Tee. Die Hälfte des zugefügten Schadens wird ihm als KP gutgeschrieben. Das Ziel erleidet eventuell Verbrennungen." - }, - "syrupBomb": { - "name": "Sirupbombe", - "effect": "Der Anwender feuert eine klebrige Sirupbombe auf das Ziel, wodurch es in Sirup gehüllt und seine Initiative drei Runden in Folge gesenkt wird." - }, - "ivyCudgel": { - "name": "Rankenkeule", - "effect": "Der Anwender schlägt mit einer rankenumschlungenen Keule zu. Der Typ dieser Attacke hängt von der Maske des Anwenders ab. Hohe Volltrefferquote." - }, - "electroShot": { - "name": "Stromstrahl", - "effect": "Sammelt in Runde 1 Elektrizität, um den Spezial-Angriff zu erhöhen, und greift dann in Runde 2 mit Starkstrom an. Bei Regen erfolgt der Angriff sofort in Runde 1." - }, - "teraStarstorm": { - "name": "Tera-Sternhagel", - "effect": "Der Anwender greift das Ziel mit gebündelter Kristallenergie an. Wenn Terapagos diese Attacke in seiner Stellarform einsetzt, erleiden alle Gegner Schaden." - }, - "fickleBeam": { - "name": "Launenlaser", - "effect": "Der Anwender greift mit einem Laserstrahl an. Manchmal feuern mehrere seiner Köpfe Laser ab, wodurch sich die Stärke dieser Attacke verdoppelt." - }, - "burningBulwark": { - "name": "Flammenschild", - "effect": "Das brennend heiße Fell des Anwenders schützt ihn vor Angriffen. Gleichzeitig erleiden alle Pokémon, die mit ihm in Berührung kommen, Verbrennungen." - }, - "thunderclap": { - "name": "Sturmblitz", - "effect": "Bei dieser Erstschlag-Attacke lässt der Anwender einen Blitz auf das Ziel einschlagen. Sie gelingt nur, wenn dieses gerade eine Angriffsattacke vorbereitet." - }, - "mightyCleave": { - "name": "Wuchtklinge", - "effect": "Der Anwender führt mit dem in seinem Kopf gespeicherten Licht einen Schnitt aus. Diese Attacke trifft auch, wenn das Ziel sich selbst schützt." - }, - "tachyonCutter": { - "name": "Tachyon-Schnitt", - "effect": "Der Anwender greift das Ziel zweimal hintereinander mit Partikelklingen an. Der Angriff trifft garantiert." - }, - "hardPress": { - "name": "Stahlpresse", - "effect": "Der Anwender nimmt das Ziel mit Armen oder Scheren in die Mangel. Je höher die KP des Zieles, desto stärker die Attacke." - }, - "dragonCheer": { - "name": "Drachenschrei", - "effect": "Das anspornende Drachengebrüll hebt die Moral aller Mitstreiter und erhöht ihre Volltrefferquote. Der Effekt ist stärker, wenn sie dem Typ Drache angehören." - }, - "alluringVoice": { - "name": "Lockstimme", - "effect": "Der Anwender greift mit engelsgleichem Gesang an. Falls die Statuswerte des Zieles in dieser Runde erhöht wurden, wird es zusätzlich verwirrt." - }, - "temperFlare": { - "name": "Frustflamme", - "effect": "Der Anwender greift das Ziel voller Verzweiflung an. Wenn seine vorige Attacke fehlgeschlagen ist, verdoppelt sich die Stärke der Attacke." - }, - "supercellSlam": { - "name": "Donnerstoß", - "effect": "Der Anwender lädt seinen Körper mit elektrischer Energie auf und stürzt sich auf das Ziel. Bei Misserfolg verletzt sich der Anwender selbst." - }, - "psychicNoise": { - "name": "Psycholärm", - "effect": "Der Anwender greift mit unerträglichen Schallwellen an, wodurch das Ziel zwei Runden lang nicht durch Attacken, Fähigkeiten oder getragene Items geheilt werden kann." - }, - "upperHand": { - "name": "Schnellkonter", - "effect": "Der Anwender reagiert auf Bewegungen des Zieles und lässt es durch einen Schlag zurückschrecken. Gelingt nur, wenn das Ziel gerade eine Erstschlag-Attacke vorbereitet." - }, - "malignantChain": { - "name": "Giftkettung", - "effect": "Der Anwender umwickelt das Ziel mit einer Kette aus Toxinen, die in dessen Körper eindringen und ihm schaden. Das Ziel wird eventuell schwer vergiftet." - } -} diff --git a/src/locales/de/nature.json b/src/locales/de/nature.json deleted file mode 100644 index d1406f723a9..00000000000 --- a/src/locales/de/nature.json +++ /dev/null @@ -1,27 +0,0 @@ -{ - "Hardy": "Robust", - "Lonely": "Solo", - "Brave": "Mutig", - "Adamant": "Hart", - "Naughty": "Frech", - "Bold": "Kühn", - "Docile": "Sanft", - "Relaxed": "Locker", - "Impish": "Pfiffig", - "Lax": "Lasch", - "Timid": "Scheu", - "Hasty": "Hastig", - "Serious": "Ernst", - "Jolly": "Froh", - "Naive": "Naiv", - "Modest": "Mäßig", - "Mild": "Mild", - "Quiet": "Ruhig", - "Bashful": "Zaghaft", - "Rash": "Hitzig", - "Calm": "Still", - "Gentle": "Zart", - "Sassy": "Forsch", - "Careful": "Sacht", - "Quirky": "Kauzig" -} \ No newline at end of file diff --git a/src/locales/de/party-ui-handler.json b/src/locales/de/party-ui-handler.json deleted file mode 100644 index fb5a5207569..00000000000 --- a/src/locales/de/party-ui-handler.json +++ /dev/null @@ -1,47 +0,0 @@ -{ - "SEND_OUT": "Einwechseln", - "SUMMARY": "Bericht", - "CANCEL": "Abbrechen", - "RELEASE": "Freilassen", - "APPLY": "Anwenden", - "TEACH": "Erlernen", - "SPLICE": "Fusionieren", - "UNSPLICE": "Defusionieren", - "ACTIVATE": "Aktivieren", - "DEACTIVATE": "Deaktivieren", - "TRANSFER": "Übertragen", - "ALL": "Alle", - "PASS_BATON": "Stafette nutzen", - "UNPAUSE_EVOLUTION": "Entwicklung fortsetzen", - "REVIVE": "Wiederbeleben", - "RENAME": "Umbenennen", - "choosePokemon": "Wähle ein Pokémon.", - "doWhatWithThisPokemon": "Was soll mit diesem Pokémon geschehen?", - "noEnergy": "{{pokemonName}} ist nicht fit genug, um zu kämpfen!", - "hasEnergy": "{{pokemonName}} steckt noch voller Energie", - "cantBeUsed": "{{pokemonName}} kann in dieser Herausforderung nicht verwendet werden!", - "tooManyItems": "{{pokemonName}} trägt bereits zu viele dieser Items!", - "anyEffect": "Das würde keine Wirkung zeigen.", - "unpausedEvolutions": "Entwicklungen für {{pokemonName}} wurden wieder aktiviert.", - "unspliceConfirmation": "Willst du wirklich {{fusionName}} von {{pokemonName}} defusionieren? {{fusionName}} wird freigelassen.", - "wasReverted": "{{fusionName}} verwandelt sich in {{pokemonName}} zurück.", - "releaseConfirmation": "Möchtest du {{pokemonName}} wirklich freilassen?", - "releaseInBattle": "Pokémon, die aktuell im Kampf sind, können nicht freigelassen werden.", - "selectAMove": "Wähle eine Attacke.", - "changeQuantity": "Wähle ein getragenes Item aus, das übertragen werden soll. Nutze < und > um die Anzahl zu ändern.", - "selectAnotherPokemonToSplice": "Wähle ein anderes Pokémon mit dem fusioniert werden soll aus.", - "cancel": "Abbrechen", - "able": "Erlernbar!", - "notAble": "Nicht erlernbar", - "learned": "Bereits erlernt!", - "goodbye": "Auf wiedersehen, {{pokemonName}}!", - "byebye": "Byebye, {{pokemonName}}!", - "farewell": "Mach’s gut, {{pokemonName}}!", - "soLong": "Bis dann, {{pokemonName}}!", - "thisIsWhereWePart": "Nun heißt es Abschied nehmen, {{pokemonName}}!", - "illMissYou": "Ich werde dich vermissen, {{pokemonName}}!", - "illNeverForgetYou": "Ich werde dich niemals vergessen, {{pokemonName}}!", - "untilWeMeetAgain": "Bis wir uns wiedersehen, {{pokemonName}}!", - "sayonara": "Sayonara, {{pokemonName}}!", - "smellYaLater": "Also dann, man riecht sich! Ciao!, {{pokemonName}}!" -} \ No newline at end of file diff --git a/src/locales/de/pokeball.json b/src/locales/de/pokeball.json deleted file mode 100644 index 83020c072f8..00000000000 --- a/src/locales/de/pokeball.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "pokeBall": "Pokéball", - "greatBall": "Superball", - "ultraBall": "Hyperball", - "rogueBall": "Rogueball", - "masterBall": "Meisterball", - "luxuryBall": "Luxusball" -} \ No newline at end of file diff --git a/src/locales/de/pokemon-form-battle.json b/src/locales/de/pokemon-form-battle.json deleted file mode 100644 index 35060c33d0b..00000000000 --- a/src/locales/de/pokemon-form-battle.json +++ /dev/null @@ -1,14 +0,0 @@ -{ - "mega": "Mega-{{pokemonName}}", - "mega-x": "Mega-{{pokemonName}} X", - "mega-y": "Mega-{{pokemonName}} Y", - "primal": "Proto-{{pokemonName}}", - "gigantamax": "G-Dyna-{{pokemonName}}", - "eternamax": "U-Dyna-{{pokemonName}}", - "megaChange": "{{preName}} hat sich zu {{pokemonName}} mega-entwickelt!", - "gigantamaxChange": "{{preName}} hat sich zu {{pokemonName}} gigadynamaximiert!", - "eternamaxChange": "{{preName}} hat sich zu {{pokemonName}} unendynamaximiert!", - "revertChange": "{{pokemonName}} hat seine ursprüngliche Form zurückerlangt!", - "formChange": "{{preName}} hat seine Form geändert!", - "disguiseChange": "Sein Kostüm hat die Attacke absorbiert!" -} \ No newline at end of file diff --git a/src/locales/de/pokemon-form.json b/src/locales/de/pokemon-form.json deleted file mode 100644 index d621e3165fa..00000000000 --- a/src/locales/de/pokemon-form.json +++ /dev/null @@ -1,170 +0,0 @@ -{ - "pikachuCosplay": "Cosplay", - "pikachuCoolCosplay": "Rocker-Pikachu", - "pikachuBeautyCosplay": "Damen-Pikachu", - "pikachuCuteCosplay": "Star-Pikachu", - "pikachuSmartCosplay": "Professoren-Pikachu", - "pikachuToughCosplay": "Wrestler-Pikachu", - "pikachuPartner": "Partner-Pikachu", - "eeveePartner": "Partner-Evoli", - "pichuSpiky": "Strubbelohr-Pichu", - "unownA": "A", - "unownB": "B", - "unownC": "C", - "unownD": "D", - "unownE": "E", - "unownF": "F", - "unownG": "G", - "unownH": "H", - "unownI": "I", - "unownJ": "J", - "unownK": "K", - "unownL": "L", - "unownM": "M", - "unownN": "N", - "unownO": "O", - "unownP": "P", - "unownQ": "Q", - "unownR": "R", - "unownS": "S", - "unownT": "T", - "unownU": "U", - "unownV": "V", - "unownW": "W", - "unownX": "X", - "unownY": "Y", - "unownZ": "Z", - "unownExclamation": "!", - "unownQuestion": "?", - "castformSunny": "Sonnenform", - "castformRainy": "Regenform", - "castformSnowy": "Schneeform", - "deoxysNormal": "Normalform", - "burmyPlant": "Pflanzenumhang", - "burmySandy": "Sandumhang", - "burmyTrash": "Lumpenumhang", - "shellosEast": "Östliches Meer", - "shellosWest": "Westliches Meer", - "rotomHeat": "Hitze-Rotom", - "rotomWash": "Wasch-Rotom", - "rotomFrost": "Frost-Rotom", - "rotomFan": "Wirbel-Rotom", - "rotomMow": "Schneid-Rotom", - "giratinaAltered": "Wandelform", - "shayminLand": "Landform", - "basculinRedStriped": "Rotlinige Form", - "basculinBlueStriped": "Blaulinige Form", - "basculinWhiteStriped": "Weißlinige Form", - "deerlingSpring": "Frühlingsform", - "deerlingSummer": "Sommerform", - "deerlingAutumn": "Herbstform", - "deerlingWinter": "Winterform", - "tornadusIncarnate": "Inkarnationsform", - "thundurusIncarnate": "Inkarnationsform", - "landorusIncarnate": "Inkarnationsform", - "keldeoOrdinary": "Standardform", - "meloettaAria": "Gesangsform", - "meloettaPirouette": "Tanzform", - "froakieBattleBond": "Ash-Form", - "scatterbugMeadow": "Blumenmeermuster", - "scatterbugIcySnow": "Frostmuster", - "scatterbugPolar": "Schneefeldmuster", - "scatterbugTundra": "Flockenmuster", - "scatterbugContinental": "Kontinentalmuster", - "scatterbugGarden": "Ziergartenmuster", - "scatterbugElegant": "Prunkmuster", - "scatterbugModern": "Innovationsmuster", - "scatterbugMarine": "Aquamarinmuster", - "scatterbugArchipelago": "Archipelmuster", - "scatterbugHighPlains": "Dürrmuster", - "scatterbugSandstorm": "Sandmuster", - "scatterbugRiver": "Flussdeltamuster", - "scatterbugMonsoon": "Monsunmuster", - "scatterbugSavanna": "Savannenmuster", - "scatterbugSun": "Sonnenmuster", - "scatterbugOcean": "Ozeanmuster", - "scatterbugJungle": "Dschungelmuster", - "scatterbugFancy": "Fantasiemuster", - "scatterbugPokeBall": "Pokéball-Muster", - "flabebeRed": "Rotblütler", - "flabebeYellow": "Gelbblütler", - "flabebeOrange": "Orangeblütler", - "flabebeBlue": "Blaublütler", - "flabebeWhite": "Weißblütler", - "furfrouHeart": "Herzchenschnitt", - "furfrouStar": "Sternchenschnitt", - "furfrouDiamond": "Diamantenschitt", - "furfrouDebutante": "Fräuleinschnitt", - "furfrouMatron": "Damenschnitt", - "furfrouDandy": "Kavalierschnitt", - "furfrouLaReine": "Königinnenschnitt", - "furfrouKabuki": "Kabuki-Schnitt", - "furfrouPharaoh": "Herrscherschnitt", - "pumpkabooSmall": "Größe S", - "pumpkabooLarge": "Größe L", - "pumpkabooSuper": "Größe XL", - "xerneasNeutral": "Ruhe-Modus", - "xerneasActive": "Aktiv-Modus", - "zygarde50": "50% Form", - "zygarde10": "10% Form", - "zygarde50Pc": "50% Form Scharwandel", - "zygarde10Pc": "10% Form Scharwandel", - "zygardeComplete": "Optimum-Form", - "oricorioBaile": "Flamenco-Stil", - "oricorioPompom": "Cheerleading-Stil", - "oricorioPau": "Hula-Stil", - "oricorioSensu": "Buyo-Stil", - "rockruffOwnTempo": "Gleichmut", - "miniorRedMeteor": "Rote-Meteorform", - "miniorOrangeMeteor": "Oranger-Meteorform", - "miniorYellowMeteor": "Gelber-Meteorform", - "miniorGreenMeteor": "Grüner-Meteorform", - "miniorBlueMeteor": "Hellblaue-Meteorform", - "miniorIndigoMeteor": "Blaue-Meteorform", - "miniorVioletMeteor": "Violette-Meteorform", - "miniorRed": "Roter Kern", - "miniorOrange": "Oranger Kern", - "miniorYellow": "Gelber Kern", - "miniorGreen": "Grüner Kern", - "miniorBlue": "Hellblauer Kern", - "miniorIndigo": "Blauer Kern", - "miniorViolet": "Violetter Kern", - "mimikyuDisguised": "Verkleidete Form", - "mimikyuBusted": "Entlarvte Form", - "magearnaOriginal": "Originalfarbe", - "marshadowZenith": "Zenitform", - "sinisteaPhony": "Fälschungsform", - "sinisteaAntique": "Originalform", - "eiscueNoIce": "Wohlfühlkopf", - "indeedeeMale": "männlich", - "indeedeeFemale": "weiblich", - "morpekoFullBelly": "Pappsattmuster", - "zacianHeroOfManyBattles": "Heldenhafter Krieger", - "zamazentaHeroOfManyBattles": "Heldenhafter Krieger", - "zarudeDada": "Papa", - "enamorusIncarnate": "Inkarnationsform", - "squawkabillyGreenPlumage": "Grüngefiedert", - "squawkabillyBluePlumage": "Blaugefiedert", - "squawkabillyYellowPlumage": "Gelbgefiedert", - "squawkabillyWhitePlumage": "Weißgefiedert", - "tatsugiriCurly": "Gebogene Form", - "tatsugiriDroopy": "Hängende Form", - "tatsugiriStretchy": "Gestrekte Form", - "gimmighoulChest": "Truhenform", - "gimmighoulRoaming": "Wanderform", - "koraidonApexBuild": "Vollkommene Gestalt", - "koraidonLimitedBuild": "Gehemmte Gestalt", - "koraidonSprintingBuild": "Sprintgestalt", - "koraidonSwimmingBuild": "Schwimmgestalt", - "koraidonGlidingBuild": "Schwingengestalt", - "miraidonUltimateMode": "Kompletter Modus", - "miraidonLowPowerMode": "Begrenzter Modus", - "miraidonDriveMode": "Fahrmodus", - "miraidonAquaticMode": "Wassermodus", - "miraidonGlideMode": "Gleitmodus", - "poltchageistCounterfeit": "Imitationsform", - "poltchageistArtisan": "Kostbarkeitsform", - "paldeaTaurosCombat": "Gefechtsvariante", - "paldeaTaurosBlaze": "Flammenvariante", - "paldeaTaurosAqua": "Flutenvariante" -} \ No newline at end of file diff --git a/src/locales/de/pokemon-info-container.json b/src/locales/de/pokemon-info-container.json deleted file mode 100644 index 1a9bf59afec..00000000000 --- a/src/locales/de/pokemon-info-container.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "moveset": "Attacken", - "gender": "Geschlecht:", - "ability": "Fähigkeit:", - "nature": "Wesen:", - "form": "Form:" -} \ No newline at end of file diff --git a/src/locales/de/pokemon-info.json b/src/locales/de/pokemon-info.json deleted file mode 100644 index 2d625d52ba7..00000000000 --- a/src/locales/de/pokemon-info.json +++ /dev/null @@ -1,40 +0,0 @@ -{ - "Stat": { - "HP": "KP", - "HPshortened": "KP", - "ATK": "Angriff", - "ATKshortened": "Ang", - "DEF": "Verteidigung", - "DEFshortened": "Vert", - "SPATK": "Sp. Ang", - "SPATKshortened": "SpAng", - "SPDEF": "Sp. Vert", - "SPDEFshortened": "SpVert", - "SPD": "Initiative", - "SPDshortened": "Init", - "ACC": "Genauigkeit", - "EVA": "Fluchtwert" - }, - "Type": { - "UNKNOWN": "Unbekannt", - "NORMAL": "Normal", - "FIGHTING": "Kampf", - "FLYING": "Flug", - "POISON": "Gift", - "GROUND": "Boden", - "ROCK": "Gestein", - "BUG": "Käfer", - "GHOST": "Geist", - "STEEL": "Stahl", - "FIRE": "Feuer", - "WATER": "Wasser", - "GRASS": "Pflanze", - "ELECTRIC": "Elektro", - "PSYCHIC": "Psycho", - "ICE": "Eis", - "DRAGON": "Drache", - "DARK": "Unlicht", - "FAIRY": "Fee", - "STELLAR": "Stellar" - } -} \ No newline at end of file diff --git a/src/locales/de/pokemon-summary.json b/src/locales/de/pokemon-summary.json deleted file mode 100644 index 3104fc10151..00000000000 --- a/src/locales/de/pokemon-summary.json +++ /dev/null @@ -1,44 +0,0 @@ -{ - "pokemonInfo": "Pokémon Info", - "status": "Status", - "powerAccuracyCategory": "Stärke\nGenauigkeit\nKategorie", - "type": "Typ", - "unknownTrainer": "Unbekannt", - "ot": "OT", - "nature": "Wesen", - "expPoints": "Erf. Punkte", - "nextLv": "Nächstes Lvl.", - "cancel": "Abbrechen", - "memoString": "Wesen: {{natureFragment}}\n{{metFragment}}", - "metFragment": { - "normal": "Herkunft: {{biome}} - Welle {{wave}}\nMit Lv. {{level}} erhalten.", - "apparently": "Herkunft: {{biome}}\nOffenbar mit Lv. {{level}} erhalten." - }, - "natureFragment": { - "Hardy": "{{nature}}", - "Lonely": "{{nature}}", - "Brave": "{{nature}}", - "Adamant": "{{nature}}", - "Naughty": "{{nature}}", - "Bold": "{{nature}}", - "Docile": "{{nature}}", - "Relaxed": "{{nature}}", - "Impish": "{{nature}}", - "Lax": "{{nature}}", - "Timid": "{{nature}}", - "Hasty": "{{nature}}", - "Serious": "{{nature}}", - "Jolly": "{{nature}}", - "Naive": "{{nature}}", - "Modest": "{{nature}}", - "Mild": "{{nature}}", - "Quiet": "{{nature}}", - "Bashful": "{{nature}}", - "Rash": "{{nature}}", - "Calm": "{{nature}}", - "Gentle": "{{nature}}", - "Sassy": "{{nature}}", - "Careful": "{{nature}}", - "Quirky": "{{nature}}" - } -} diff --git a/src/locales/de/pokemon.json b/src/locales/de/pokemon.json deleted file mode 100644 index 7024e26f044..00000000000 --- a/src/locales/de/pokemon.json +++ /dev/null @@ -1,1084 +0,0 @@ -{ - "bulbasaur": "Bisasam", - "ivysaur": "Bisaknosp", - "venusaur": "Bisaflor", - "charmander": "Glumanda", - "charmeleon": "Glutexo", - "charizard": "Glurak", - "squirtle": "Schiggy", - "wartortle": "Schillok", - "blastoise": "Turtok", - "caterpie": "Raupy", - "metapod": "Safcon", - "butterfree": "Smettbo", - "weedle": "Hornliu", - "kakuna": "Kokuna", - "beedrill": "Bibor", - "pidgey": "Taubsi", - "pidgeotto": "Tauboga", - "pidgeot": "Tauboss", - "rattata": "Rattfratz", - "raticate": "Rattikarl", - "spearow": "Habitak", - "fearow": "Ibitak", - "ekans": "Rettan", - "arbok": "Arbok", - "pikachu": "Pikachu", - "raichu": "Raichu", - "sandshrew": "Sandan", - "sandslash": "Sandamer", - "nidoran_f": "Nidoran♀", - "nidorina": "Nidorina", - "nidoqueen": "Nidoqueen", - "nidoran_m": "Nidoran♂", - "nidorino": "Nidorino", - "nidoking": "Nidoking", - "clefairy": "Piepi", - "clefable": "Pixi", - "vulpix": "Vulpix", - "ninetales": "Vulnona", - "jigglypuff": "Pummeluff", - "wigglytuff": "Knuddeluff", - "zubat": "Zubat", - "golbat": "Golbat", - "oddish": "Myrapla", - "gloom": "Duflor", - "vileplume": "Giflor", - "paras": "Paras", - "parasect": "Parasek", - "venonat": "Bluzuk", - "venomoth": "Omot", - "diglett": "Digda", - "dugtrio": "Digdri", - "meowth": "Mauzi", - "persian": "Snobilikat", - "psyduck": "Enton", - "golduck": "Entoron", - "mankey": "Menki", - "primeape": "Rasaff", - "growlithe": "Fukano", - "arcanine": "Arkani", - "poliwag": "Quapsel", - "poliwhirl": "Quaputzi", - "poliwrath": "Quappo", - "abra": "Abra", - "kadabra": "Kadabra", - "alakazam": "Simsala", - "machop": "Machollo", - "machoke": "Maschock", - "machamp": "Machomei", - "bellsprout": "Knofensa", - "weepinbell": "Ultrigaria", - "victreebel": "Sarzenia", - "tentacool": "Tentacha", - "tentacruel": "Tentoxa", - "geodude": "Kleinstein", - "graveler": "Georok", - "golem": "Geowaz", - "ponyta": "Ponita", - "rapidash": "Gallopa", - "slowpoke": "Flegmon", - "slowbro": "Lahmus", - "magnemite": "Magnetilo", - "magneton": "Magneton", - "farfetchd": "Porenta", - "doduo": "Dodu", - "dodrio": "Dodri", - "seel": "Jurob", - "dewgong": "Jugong", - "grimer": "Sleima", - "muk": "Sleimok", - "shellder": "Muschas", - "cloyster": "Austos", - "gastly": "Nebulak", - "haunter": "Alpollo", - "gengar": "Gengar", - "onix": "Onix", - "drowzee": "Traumato", - "hypno": "Hypno", - "krabby": "Krabby", - "kingler": "Kingler", - "voltorb": "Voltobal", - "electrode": "Lektrobal", - "exeggcute": "Owei", - "exeggutor": "Kokowei", - "cubone": "Tragosso", - "marowak": "Knogga", - "hitmonlee": "Kicklee", - "hitmonchan": "Nockchan", - "lickitung": "Schlurp", - "koffing": "Smogon", - "weezing": "Smogmog", - "rhyhorn": "Rihorn", - "rhydon": "Rizeros", - "chansey": "Chaneira", - "tangela": "Tangela", - "kangaskhan": "Kangama", - "horsea": "Seeper", - "seadra": "Seemon", - "goldeen": "Goldini", - "seaking": "Golking", - "staryu": "Sterndu", - "starmie": "Starmie", - "mr_mime": "Pantimos", - "scyther": "Sichlor", - "jynx": "Rossana", - "electabuzz": "Elektek", - "magmar": "Magmar", - "pinsir": "Pinsir", - "tauros": "Tauros", - "magikarp": "Karpador", - "gyarados": "Garados", - "lapras": "Lapras", - "ditto": "Ditto", - "eevee": "Evoli", - "vaporeon": "Aquana", - "jolteon": "Blitza", - "flareon": "Flamara", - "porygon": "Porygon", - "omanyte": "Amonitas", - "omastar": "Amoroso", - "kabuto": "Kabuto", - "kabutops": "Kabutops", - "aerodactyl": "Aerodactyl", - "snorlax": "Relaxo", - "articuno": "Arktos", - "zapdos": "Zapdos", - "moltres": "Lavados", - "dratini": "Dratini", - "dragonair": "Dragonir", - "dragonite": "Dragoran", - "mewtwo": "Mewtu", - "mew": "Mew", - "chikorita": "Endivie", - "bayleef": "Lorblatt", - "meganium": "Meganie", - "cyndaquil": "Feurigel", - "quilava": "Igelavar", - "typhlosion": "Tornupto", - "totodile": "Karnimani", - "croconaw": "Tyracroc", - "feraligatr": "Impergator", - "sentret": "Wiesor", - "furret": "Wiesenior", - "hoothoot": "Hoothoot", - "noctowl": "Noctuh", - "ledyba": "Ledyba", - "ledian": "Ledian", - "spinarak": "Webarak", - "ariados": "Ariados", - "crobat": "Iksbat", - "chinchou": "Lampi", - "lanturn": "Lanturn", - "pichu": "Pichu", - "cleffa": "Pii", - "igglybuff": "Fluffeluff", - "togepi": "Togepi", - "togetic": "Togetic", - "natu": "Natu", - "xatu": "Xatu", - "mareep": "Voltilamm", - "flaaffy": "Waaty", - "ampharos": "Ampharos", - "bellossom": "Blubella", - "marill": "Marill", - "azumarill": "Azumarill", - "sudowoodo": "Mogelbaum", - "politoed": "Quaxo", - "hoppip": "Hoppspross", - "skiploom": "Hubelupf", - "jumpluff": "Papungha", - "aipom": "Griffel", - "sunkern": "Sonnkern", - "sunflora": "Sonnflora", - "yanma": "Yanma", - "wooper": "Felino", - "quagsire": "Morlord", - "espeon": "Psiana", - "umbreon": "Nachtara", - "murkrow": "Kramurx", - "slowking": "Laschoking", - "misdreavus": "Traunfugil", - "unown": "Icognito", - "wobbuffet": "Woingenau", - "girafarig": "Girafarig", - "pineco": "Tannza", - "forretress": "Forstellka", - "dunsparce": "Dummisel", - "gligar": "Skorgla", - "steelix": "Stahlos", - "snubbull": "Snubbull", - "granbull": "Granbull", - "qwilfish": "Baldorfish", - "scizor": "Scherox", - "shuckle": "Pottrott", - "heracross": "Skaraborn", - "sneasel": "Sniebel", - "teddiursa": "Teddiursa", - "ursaring": "Ursaring", - "slugma": "Schneckmag", - "magcargo": "Magcargo", - "swinub": "Quiekel", - "piloswine": "Keifel", - "corsola": "Corasonn", - "remoraid": "Remoraid", - "octillery": "Octillery", - "delibird": "Botogel", - "mantine": "Mantax", - "skarmory": "Panzaeron", - "houndour": "Hunduster", - "houndoom": "Hundemon", - "kingdra": "Seedraking", - "phanpy": "Phanpy", - "donphan": "Donphan", - "porygon2": "Porygon2", - "stantler": "Damhirplex", - "smeargle": "Farbeagle", - "tyrogue": "Rabauz", - "hitmontop": "Kapoera", - "smoochum": "Kussilla", - "elekid": "Elekid", - "magby": "Magby", - "miltank": "Miltank", - "blissey": "Heiteira", - "raikou": "Raikou", - "entei": "Entei", - "suicune": "Suicune", - "larvitar": "Larvitar", - "pupitar": "Pupitar", - "tyranitar": "Despotar", - "lugia": "Lugia", - "ho_oh": "Ho-Oh", - "celebi": "Celebi", - "treecko": "Geckarbor", - "grovyle": "Reptain", - "sceptile": "Gewaldro", - "torchic": "Flemmli", - "combusken": "Jungglut", - "blaziken": "Lohgock", - "mudkip": "Hydropi", - "marshtomp": "Moorabbel", - "swampert": "Sumpex", - "poochyena": "Fiffyen", - "mightyena": "Magnayen", - "zigzagoon": "Zigzachs", - "linoone": "Geradaks", - "wurmple": "Waumpel", - "silcoon": "Schaloko", - "beautifly": "Papinella", - "cascoon": "Panekon", - "dustox": "Pudox", - "lotad": "Loturzel", - "lombre": "Lombrero", - "ludicolo": "Kappalores", - "seedot": "Samurzel", - "nuzleaf": "Blanas", - "shiftry": "Tengulist", - "taillow": "Schwalbini", - "swellow": "Schwalboss", - "wingull": "Wingull", - "pelipper": "Pelipper", - "ralts": "Trasla", - "kirlia": "Kirlia", - "gardevoir": "Gardevoir", - "surskit": "Gehweiher", - "masquerain": "Maskeregen", - "shroomish": "Knilz", - "breloom": "Kapilz", - "slakoth": "Bummelz", - "vigoroth": "Muntier", - "slaking": "Letarking", - "nincada": "Nincada", - "ninjask": "Ninjask", - "shedinja": "Ninjatom", - "whismur": "Flurmel", - "loudred": "Krakeelo", - "exploud": "Krawumms", - "makuhita": "Makuhita", - "hariyama": "Hariyama", - "azurill": "Azurill", - "nosepass": "Nasgnet", - "skitty": "Eneco", - "delcatty": "Enekoro", - "sableye": "Zobiris", - "mawile": "Flunkifer", - "aron": "Stollunior", - "lairon": "Stollrak", - "aggron": "Stolloss", - "meditite": "Meditite", - "medicham": "Meditalis", - "electrike": "Frizelbliz", - "manectric": "Voltenso", - "plusle": "Plusle", - "minun": "Minun", - "volbeat": "Volbeat", - "illumise": "Illumise", - "roselia": "Roselia", - "gulpin": "Schluppuck", - "swalot": "Schluckwech", - "carvanha": "Kanivanha", - "sharpedo": "Tohaido", - "wailmer": "Wailmer", - "wailord": "Wailord", - "numel": "Camaub", - "camerupt": "Camerupt", - "torkoal": "Qurtel", - "spoink": "Spoink", - "grumpig": "Groink", - "spinda": "Pandir", - "trapinch": "Knacklion", - "vibrava": "Vibrava", - "flygon": "Libelldra", - "cacnea": "Tuska", - "cacturne": "Noktuska", - "swablu": "Wablu", - "altaria": "Altaria", - "zangoose": "Sengo", - "seviper": "Vipitis", - "lunatone": "Lunastein", - "solrock": "Sonnfel", - "barboach": "Schmerbe", - "whiscash": "Welsar", - "corphish": "Krebscorps", - "crawdaunt": "Krebutack", - "baltoy": "Puppance", - "claydol": "Lepumentas", - "lileep": "Liliep", - "cradily": "Wielie", - "anorith": "Anorith", - "armaldo": "Armaldo", - "feebas": "Barschwa", - "milotic": "Milotic", - "castform": "Formeo", - "kecleon": "Kecleon", - "shuppet": "Shuppet", - "banette": "Banette", - "duskull": "Zwirrlicht", - "dusclops": "Zwirrklop", - "tropius": "Tropius", - "chimecho": "Palimpalim", - "absol": "Absol", - "wynaut": "Isso", - "snorunt": "Schneppke", - "glalie": "Firnontor", - "spheal": "Seemops", - "sealeo": "Seejong", - "walrein": "Walraisa", - "clamperl": "Perlu", - "huntail": "Aalabyss", - "gorebyss": "Saganabyss", - "relicanth": "Relicanth", - "luvdisc": "Liebiskus", - "bagon": "Kindwurm", - "shelgon": "Draschel", - "salamence": "Brutalanda", - "beldum": "Tanhel", - "metang": "Metang", - "metagross": "Metagross", - "regirock": "Regirock", - "regice": "Regice", - "registeel": "Registeel", - "latias": "Latias", - "latios": "Latios", - "kyogre": "Kyogre", - "groudon": "Groudon", - "rayquaza": "Rayquaza", - "jirachi": "Jirachi", - "deoxys": "Deoxys", - "turtwig": "Chelast", - "grotle": "Chelcarain", - "torterra": "Chelterrar", - "chimchar": "Panflam", - "monferno": "Panpyro", - "infernape": "Panferno", - "piplup": "Plinfa", - "prinplup": "Pilprin", - "empoleon": "Impoleon", - "starly": "Staralili", - "staravia": "Staravia", - "staraptor": "Staraptor", - "bidoof": "Bidiza", - "bibarel": "Bidifas", - "kricketot": "Zirpurze", - "kricketune": "Zirpeise", - "shinx": "Sheinux", - "luxio": "Luxio", - "luxray": "Luxtra", - "budew": "Knospi", - "roserade": "Roserade", - "cranidos": "Koknodon", - "rampardos": "Rameidon", - "shieldon": "Schilterus", - "bastiodon": "Bollterus", - "burmy": "Burmy", - "wormadam": "Burmadame", - "mothim": "Moterpel", - "combee": "Wadribie", - "vespiquen": "Honweisel", - "pachirisu": "Pachirisu", - "buizel": "Bamelin", - "floatzel": "Bojelin", - "cherubi": "Kikugi", - "cherrim": "Kinoso", - "shellos": "Schalellos", - "gastrodon": "Gastrodon", - "ambipom": "Ambidiffel", - "drifloon": "Driftlon", - "drifblim": "Drifzepeli", - "buneary": "Haspiror", - "lopunny": "Schlapor", - "mismagius": "Traunmagil", - "honchkrow": "Kramshef", - "glameow": "Charmian", - "purugly": "Shnurgarst", - "chingling": "Klingplim", - "stunky": "Skunkapuh", - "skuntank": "Skuntank", - "bronzor": "Bronzel", - "bronzong": "Bronzong", - "bonsly": "Mobai", - "mime_jr": "Pantimimi", - "happiny": "Wonneira", - "chatot": "Plaudagei", - "spiritomb": "Kryppuk", - "gible": "Kaumalat", - "gabite": "Knarksel", - "garchomp": "Knackrack", - "munchlax": "Mampfaxo", - "riolu": "Riolu", - "lucario": "Lucario", - "hippopotas": "Hippopotas", - "hippowdon": "Hippoterus", - "skorupi": "Pionskora", - "drapion": "Piondragi", - "croagunk": "Glibunkel", - "toxicroak": "Toxiquak", - "carnivine": "Venuflibis", - "finneon": "Finneon", - "lumineon": "Lumineon", - "mantyke": "Mantirps", - "snover": "Shnebedeck", - "abomasnow": "Rexblisar", - "weavile": "Snibunna", - "magnezone": "Magnezone", - "lickilicky": "Schlurplek", - "rhyperior": "Rihornior", - "tangrowth": "Tangoloss", - "electivire": "Elevoltek", - "magmortar": "Magbrant", - "togekiss": "Togekiss", - "yanmega": "Yanmega", - "leafeon": "Folipurba", - "glaceon": "Glaziola", - "gliscor": "Skorgro", - "mamoswine": "Mamutel", - "porygon_z": "Porygon-Z", - "gallade": "Galagladi", - "probopass": "Voluminas", - "dusknoir": "Zwirrfinst", - "froslass": "Frosdedje", - "rotom": "Rotom", - "uxie": "Selfe", - "mesprit": "Vesprit", - "azelf": "Tobutz", - "dialga": "Dialga", - "palkia": "Palkia", - "heatran": "Heatran", - "regigigas": "Regigigas", - "giratina": "Giratina", - "cresselia": "Cresselia", - "phione": "Phione", - "manaphy": "Manaphy", - "darkrai": "Darkrai", - "shaymin": "Shaymin", - "arceus": "Arceus", - "victini": "Victini", - "snivy": "Serpifeu", - "servine": "Efoserp", - "serperior": "Serpiroyal", - "tepig": "Floink", - "pignite": "Ferkokel", - "emboar": "Flambirex", - "oshawott": "Ottaro", - "dewott": "Zwottronin", - "samurott": "Admurai", - "patrat": "Nagelotz", - "watchog": "Kukmarda", - "lillipup": "Yorkleff", - "herdier": "Terribark", - "stoutland": "Bissbark", - "purrloin": "Felilou", - "liepard": "Kleoparda", - "pansage": "Vegimak", - "simisage": "Vegichita", - "pansear": "Grillmak", - "simisear": "Grillchita", - "panpour": "Sodamak", - "simipour": "Sodachita", - "munna": "Somniam", - "musharna": "Somnivora", - "pidove": "Dusselgurr", - "tranquill": "Navitaub", - "unfezant": "Fasasnob", - "blitzle": "Elezeba", - "zebstrika": "Zebritz", - "roggenrola": "Kiesling", - "boldore": "Sedimantur", - "gigalith": "Brockoloss", - "woobat": "Fleknoil", - "swoobat": "Fletiamo", - "drilbur": "Rotomurf", - "excadrill": "Stalobor", - "audino": "Ohrdoch", - "timburr": "Praktibalk", - "gurdurr": "Strepoli", - "conkeldurr": "Meistagrif", - "tympole": "Schallquap", - "palpitoad": "Mebrana", - "seismitoad": "Branawarz", - "throh": "Jiutesto", - "sawk": "Karadonis", - "sewaddle": "Strawickl", - "swadloon": "Folikon", - "leavanny": "Matrifol", - "venipede": "Toxiped", - "whirlipede": "Rollum", - "scolipede": "Cerapendra", - "cottonee": "Waumboll", - "whimsicott": "Elfun", - "petilil": "Lilminip", - "lilligant": "Dressella", - "basculin": "Barschuft", - "sandile": "Ganovil", - "krokorok": "Rokkaiman", - "krookodile": "Rabigator", - "darumaka": "Flampion", - "darmanitan": "Flampivian", - "maractus": "Maracamba", - "dwebble": "Lithomith", - "crustle": "Castellith", - "scraggy": "Zurrokex", - "scrafty": "Irokex", - "sigilyph": "Symvolara", - "yamask": "Makabaja", - "cofagrigus": "Echnatoll", - "tirtouga": "Galapaflos", - "carracosta": "Karippas", - "archen": "Flapteryx", - "archeops": "Aeropteryx", - "trubbish": "Unratütox", - "garbodor": "Deponitox", - "zorua": "Zorua", - "zoroark": "Zoroark", - "minccino": "Picochilla", - "cinccino": "Chillabell", - "gothita": "Mollimorba", - "gothorita": "Hypnomorba", - "gothitelle": "Morbitesse", - "solosis": "Monozyto", - "duosion": "Mitodos", - "reuniclus": "Zytomega", - "ducklett": "Piccolente", - "swanna": "Swaroness", - "vanillite": "Gelatini", - "vanillish": "Gelatroppo", - "vanilluxe": "Gelatwino", - "deerling": "Sesokitz", - "sawsbuck": "Kronjuwild", - "emolga": "Emolga", - "karrablast": "Laukaps", - "escavalier": "Cavalanzas", - "foongus": "Tarnpignon", - "amoonguss": "Hutsassa", - "frillish": "Quabbel", - "jellicent": "Apoquallyp", - "alomomola": "Mamolida", - "joltik": "Wattzapf", - "galvantula": "Voltula", - "ferroseed": "Kastadur", - "ferrothorn": "Tentantel", - "klink": "Klikk", - "klang": "Kliklak", - "klinklang": "Klikdiklak", - "tynamo": "Zapplardin", - "eelektrik": "Zapplalek", - "eelektross": "Zapplarang", - "elgyem": "Pygraulon", - "beheeyem": "Megalon", - "litwick": "Lichtel", - "lampent": "Laternecto", - "chandelure": "Skelabra", - "axew": "Milza", - "fraxure": "Sharfax", - "haxorus": "Maxax", - "cubchoo": "Petznief", - "beartic": "Siberio", - "cryogonal": "Frigometri", - "shelmet": "Schnuthelm", - "accelgor": "Hydragil", - "stunfisk": "Flunschlik", - "mienfoo": "Lin-Fu", - "mienshao": "Wie-Shu", - "druddigon": "Shardrago", - "golett": "Golbit", - "golurk": "Golgantes", - "pawniard": "Gladiantri", - "bisharp": "Caesurio", - "bouffalant": "Bisofank", - "rufflet": "Geronimatz", - "braviary": "Washakwil", - "vullaby": "Skallyk", - "mandibuzz": "Grypheldis", - "heatmor": "Furnifraß", - "durant": "Fermicula", - "deino": "Kapuno", - "zweilous": "Duodino", - "hydreigon": "Trikephalo", - "larvesta": "Ignivor", - "volcarona": "Ramoth", - "cobalion": "Kobalium", - "terrakion": "Terrakium", - "virizion": "Viridium", - "tornadus": "Boreos", - "thundurus": "Voltolos", - "reshiram": "Reshiram", - "zekrom": "Zekrom", - "landorus": "Demeteros", - "kyurem": "Kyurem", - "keldeo": "Keldeo", - "meloetta": "Meloetta", - "genesect": "Genesect", - "chespin": "Igamaro", - "quilladin": "Igastarnish", - "chesnaught": "Brigaron", - "fennekin": "Fynx", - "braixen": "Rutena", - "delphox": "Fennexis", - "froakie": "Froxy", - "frogadier": "Amphizel", - "greninja": "Quajutsu", - "bunnelby": "Scoppel", - "diggersby": "Grebbit", - "fletchling": "Dartiri", - "fletchinder": "Dartignis", - "talonflame": "Fiaro", - "scatterbug": "Purmel", - "spewpa": "Puponcho", - "vivillon": "Vivillon", - "litleo": "Leufeo", - "pyroar": "Pyroleo", - "flabebe": "Flabébé", - "floette": "Floette", - "florges": "Florges", - "skiddo": "Mähikel", - "gogoat": "Chevrumm", - "pancham": "Pam-Pam", - "pangoro": "Pandagro", - "furfrou": "Coiffwaff", - "espurr": "Psiau", - "meowstic": "Psiaugon", - "honedge": "Gramokles", - "doublade": "Duokles", - "aegislash": "Durengard", - "spritzee": "Parfi", - "aromatisse": "Parfinesse", - "swirlix": "Flauschling", - "slurpuff": "Sabbaione", - "inkay": "Iscalar", - "malamar": "Calamanero", - "binacle": "Bithora", - "barbaracle": "Thanathora", - "skrelp": "Algitt", - "dragalge": "Tandrak", - "clauncher": "Scampisto", - "clawitzer": "Wummer", - "helioptile": "Eguana", - "heliolisk": "Elezard", - "tyrunt": "Balgoras", - "tyrantrum": "Monargoras", - "amaura": "Amarino", - "aurorus": "Amagarga", - "sylveon": "Feelinara", - "hawlucha": "Resladero", - "dedenne": "Dedenne", - "carbink": "Rocara", - "goomy": "Viscora", - "sliggoo": "Viscargot", - "goodra": "Viscogon", - "klefki": "Clavion", - "phantump": "Paragoni", - "trevenant": "Trombork", - "pumpkaboo": "Irrbis", - "gourgeist": "Pumpdjinn", - "bergmite": "Arktip", - "avalugg": "Arktilas", - "noibat": "eF-eM", - "noivern": "UHaFnir", - "xerneas": "Xerneas", - "yveltal": "Yveltal", - "zygarde": "Zygarde", - "diancie": "Diancie", - "hoopa": "Hoopa", - "volcanion": "Volcanion", - "rowlet": "Bauz", - "dartrix": "Arboretoss", - "decidueye": "Silvarro", - "litten": "Flamiau", - "torracat": "Miezunder", - "incineroar": "Fuegro", - "popplio": "Robball", - "brionne": "Marikeck", - "primarina": "Primarene", - "pikipek": "Peppeck", - "trumbeak": "Trompeck", - "toucannon": "Tukanon", - "yungoos": "Mangunior", - "gumshoos": "Manguspektor", - "grubbin": "Mabula", - "charjabug": "Akkup", - "vikavolt": "Donarion", - "crabrawler": "Krabbox", - "crabominable": "Krawell", - "oricorio": "Choreogel", - "cutiefly": "Wommel", - "ribombee": "Bandelby", - "rockruff": "Wuffels", - "lycanroc": "Wolwerock", - "wishiwashi": "Lusardin", - "mareanie": "Garstella", - "toxapex": "Aggrostella", - "mudbray": "Pampuli", - "mudsdale": "Pampross", - "dewpider": "Araqua", - "araquanid": "Aranestro", - "fomantis": "Imantis", - "lurantis": "Mantidea", - "morelull": "Bubungus", - "shiinotic": "Lamellux", - "salandit": "Molunk", - "salazzle": "Amfira", - "stufful": "Velursi", - "bewear": "Kosturso", - "bounsweet": "Frubberl", - "steenee": "Frubaila", - "tsareena": "Fruyal", - "comfey": "Curelei", - "oranguru": "Kommandutan", - "passimian": "Quartermak", - "wimpod": "Reißlaus", - "golisopod": "Tectass", - "sandygast": "Sankabuh", - "palossand": "Colossand", - "pyukumuku": "Gufa", - "type_null": "Typ:Null", - "silvally": "Amigento", - "minior": "Meteno", - "komala": "Koalelu", - "turtonator": "Tortunator", - "togedemaru": "Togedemaru", - "mimikyu": "Mimigma", - "bruxish": "Knirfish", - "drampa": "Sen-Long", - "dhelmise": "Moruda", - "jangmo_o": "Miniras", - "hakamo_o": "Mediras", - "kommo_o": "Grandiras", - "tapu_koko": "Kapu-Riki", - "tapu_lele": "Kapu-Fala", - "tapu_bulu": "Kapu-Toro", - "tapu_fini": "Kapu-Kime", - "cosmog": "Cosmog", - "cosmoem": "Cosmovum", - "solgaleo": "Solgaleo", - "lunala": "Lunala", - "nihilego": "Anego", - "buzzwole": "Masskito", - "pheromosa": "Schabelle", - "xurkitree": "Voltriant", - "celesteela": "Kaguron", - "kartana": "Katagami", - "guzzlord": "Schlingking", - "necrozma": "Necrozma", - "magearna": "Magearna", - "marshadow": "Marshadow", - "poipole": "Venicro", - "naganadel": "Agoyon", - "stakataka": "Muramura", - "blacephalon": "Kopplosio", - "zeraora": "Zeraora", - "meltan": "Meltan", - "melmetal": "Melmetal", - "grookey": "Chimpep", - "thwackey": "Chimstix", - "rillaboom": "Gortrom", - "scorbunny": "Hopplo", - "raboot": "Kickerlo", - "cinderace": "Liberlo", - "sobble": "Memmeon", - "drizzile": "Phlegleon", - "inteleon": "Intelleon", - "skwovet": "Raffel", - "greedent": "Schlaraffel", - "rookidee": "Meikro", - "corvisquire": "Kranoviz", - "corviknight": "Krarmor", - "blipbug": "Sensect", - "dottler": "Keradar", - "orbeetle": "Maritellit", - "nickit": "Kleptifux", - "thievul": "Gaunux", - "gossifleur": "Cottini", - "eldegoss": "Cottomi", - "wooloo": "Wolly", - "dubwool": "Zwollock", - "chewtle": "Kamehaps", - "drednaw": "Kamalm", - "yamper": "Voldi", - "boltund": "Bellektro", - "rolycoly": "Klonkett", - "carkol": "Wagong", - "coalossal": "Montecarbo", - "applin": "Knapfel", - "flapple": "Drapfel", - "appletun": "Schlapfel", - "silicobra": "Salanga", - "sandaconda": "Sanaconda", - "cramorant": "Urgl", - "arrokuda": "Pikuda", - "barraskewda": "Barrakiefa", - "toxel": "Toxel", - "toxtricity": "Riffex", - "sizzlipede": "Thermopod", - "centiskorch": "Infernopod", - "clobbopus": "Klopptopus", - "grapploct": "Kaocto", - "sinistea": "Fatalitee", - "polteageist": "Mortipot", - "hatenna": "Brimova", - "hattrem": "Brimano", - "hatterene": "Silembrim", - "impidimp": "Bähmon", - "morgrem": "Pelzebub", - "grimmsnarl": "Olangaar", - "obstagoon": "Barrikadax", - "perrserker": "Mauzinger", - "cursola": "Gorgasonn", - "sirfetchd": "Lauchzelot", - "mr_rime": "Pantifrost", - "runerigus": "Oghnatoll", - "milcery": "Hokumil", - "alcremie": "Pokusan", - "falinks": "Legios", - "pincurchin": "Britzigel", - "snom": "Snomnom", - "frosmoth": "Mottineva", - "stonjourner": "Humanolith", - "eiscue": "Kubuin", - "indeedee": "Servol", - "morpeko": "Morpeko", - "cufant": "Kupfanti", - "copperajah": "Patinaraja", - "dracozolt": "Lectragon", - "arctozolt": "Lecryodon", - "dracovish": "Pescragon", - "arctovish": "Pescryodon", - "duraludon": "Duraludon", - "dreepy": "Grolldra", - "drakloak": "Phandra", - "dragapult": "Katapuldra", - "zacian": "Zacian", - "zamazenta": "Zamazenta", - "eternatus": "Endynalos", - "kubfu": "Dakuma", - "urshifu": "Wulaosu", - "zarude": "Zarude", - "regieleki": "Regieleki", - "regidrago": "Regidrago", - "glastrier": "Polaross", - "spectrier": "Phantoross", - "calyrex": "Coronospa", - "wyrdeer": "Damythir", - "kleavor": "Axantor", - "ursaluna": "Ursaluna", - "basculegion": "Salmagnis", - "sneasler": "Snieboss", - "overqwil": "Myriador", - "enamorus": "Cupidos", - "sprigatito": "Felori", - "floragato": "Feliospa", - "meowscarada": "Maskagato", - "fuecoco": "Krokel", - "crocalor": "Lokroko", - "skeledirge": "Skelokrok", - "quaxly": "Kwaks", - "quaxwell": "Fuentente", - "quaquaval": "Bailonda", - "lechonk": "Ferkuli", - "oinkologne": "Fragrunz", - "tarountula": "Tarundel", - "spidops": "Spinsidias", - "nymble": "Micrick", - "lokix": "Lextremo", - "pawmi": "Pamo", - "pawmo": "Pamamo", - "pawmot": "Pamomamo", - "tandemaus": "Zwieps", - "maushold": "Famieps", - "fidough": "Hefel", - "dachsbun": "Backel", - "smoliv": "Olini", - "dolliv": "Olivinio", - "arboliva": "Olithena", - "squawkabilly": "Krawalloro", - "nacli": "Geosali", - "naclstack": "Sedisal", - "garganacl": "Saltigant", - "charcadet": "Knarbon", - "armarouge": "Crimanzo", - "ceruledge": "Azugladis", - "tadbulb": "Blipp", - "bellibolt": "Wampitz", - "wattrel": "Voltrel", - "kilowattrel": "Voltrean", - "maschiff": "Mobtiff", - "mabosstiff": "Mastifioso", - "shroodle": "Sproxi", - "grafaiai": "Affiti", - "bramblin": "Weherba", - "brambleghast": "Horrerba", - "toedscool": "Tentagra", - "toedscruel": "Tenterra", - "klawf": "Klibbe", - "capsakid": "Chilingel", - "scovillain": "Halupenjo", - "rellor": "Relluk", - "rabsca": "Skarabaks", - "flittle": "Flattutu", - "espathra": "Psiopatra", - "tinkatink": "Forgita", - "tinkatuff": "Tafforgita", - "tinkaton": "Granforgita", - "wiglett": "Schligda", - "wugtrio": "Schligdri", - "bombirdier": "Adebom", - "finizen": "Normifin", - "palafin": "Delfinator", - "varoom": "Knattox", - "revavroom": "Knattatox", - "cyclizar": "Mopex", - "orthworm": "Schlurm", - "glimmet": "Lumispross", - "glimmora": "Lumiflora", - "greavard": "Gruff", - "houndstone": "Friedwuff", - "flamigo": "Flaminkno", - "cetoddle": "Flaniwal", - "cetitan": "Kolowal", - "veluza": "Agiluza", - "dondozo": "Heerashai", - "tatsugiri": "Nigiragi", - "annihilape": "Epitaff", - "clodsire": "Suelord", - "farigiraf": "Farigiraf", - "dudunsparce": "Dummimisel", - "kingambit": "Gladimperio", - "great_tusk": "Riesenzahn", - "scream_tail": "Brüllschweif", - "brute_bonnet": "Wutpilz", - "flutter_mane": "Flatterhaar", - "slither_wing": "Kriechflügel", - "sandy_shocks": "Sandfell", - "iron_treads": "Eisenrad", - "iron_bundle": "Eisenbündel", - "iron_hands": "Eisenhand", - "iron_jugulis": "Eisenhals", - "iron_moth": "Eisenfalter", - "iron_thorns": "Eisendorn", - "frigibax": "Frospino", - "arctibax": "Cryospino", - "baxcalibur": "Espinodon", - "gimmighoul": "Gierspenst", - "gholdengo": "Monetigo", - "wo_chien": "Chongjian", - "chien_pao": "Baojian", - "ting_lu": "Dinglu", - "chi_yu": "Yuyu", - "roaring_moon": "Donnersichel", - "iron_valiant": "Eisenkrieger", - "koraidon": "Koraidon", - "miraidon": "Miraidon", - "walking_wake": "Windewoge", - "iron_leaves": "Eisenblatt", - "dipplin": "Sirapfel", - "poltchageist": "Mortcha", - "sinistcha": "Fatalitcha", - "okidogi": "Boninu", - "munkidori": "Benesaru", - "fezandipiti": "Beatori", - "ogerpon": "Ogerpon", - "archaludon": "Briduradon", - "hydrapple": "Hydrapfel", - "gouging_fire": "Keilflamme", - "raging_bolt": "Furienblitz", - "iron_boulder": "Eisenfels", - "iron_crown": "Eisenhaupt", - "terapagos": "Terapagos", - "pecharunt": "Infamomo", - "alola_rattata": "Rattfratz", - "alola_raticate": "Rattikarl", - "alola_raichu": "Raichu", - "alola_sandshrew": "Sandan", - "alola_sandslash": "Sandamer", - "alola_vulpix": "Vulpix", - "alola_ninetales": "Vulnona", - "alola_diglett": "Digda", - "alola_dugtrio": "Digdri", - "alola_meowth": "Mauzi", - "alola_persian": "Snobilikat", - "alola_geodude": "Kleinstein", - "alola_graveler": "Georok", - "alola_golem": "Geowaz", - "alola_grimer": "Sleima", - "alola_muk": "Sleimok", - "alola_exeggutor": "Kokowei", - "alola_marowak": "Knogga", - "eternal_floette": "Floette", - "galar_meowth": "Mauzi", - "galar_ponyta": "Ponita", - "galar_rapidash": "Gallopa", - "galar_slowpoke": "Flegmon", - "galar_slowbro": "Lahmus", - "galar_farfetchd": "Porenta", - "galar_weezing": "Smogmog", - "galar_mr_mime": "Pantimos", - "galar_articuno": "Arktos", - "galar_zapdos": "Zapdos", - "galar_moltres": "Lavados", - "galar_slowking": "Laschoking", - "galar_corsola": "Corasonn", - "galar_zigzagoon": "Zigzachs", - "galar_linoone": "Geradaks", - "galar_darumaka": "Flampion", - "galar_darmanitan": "Flampivian", - "galar_yamask": "Makabaja", - "galar_stunfisk": "Flunschlik", - "hisui_growlithe": "Fukano", - "hisui_arcanine": "Arkani", - "hisui_voltorb": "Voltobal", - "hisui_electrode": "Lektrobal", - "hisui_typhlosion": "Tornupto", - "hisui_qwilfish": "Baldorfish", - "hisui_sneasel": "Sniebel", - "hisui_samurott": "Admurai", - "hisui_lilligant": "Dressella", - "hisui_zorua": "Zorua", - "hisui_zoroark": "Zoroark", - "hisui_braviary": "Washakwil", - "hisui_sliggoo": "Viscargot", - "hisui_goodra": "Viscogon", - "hisui_avalugg": "Arktilas", - "hisui_decidueye": "Silvarro", - "paldea_tauros": "Tauros", - "paldea_wooper": "Felino", - "bloodmoon_ursaluna": "Ursaluna" -} \ No newline at end of file diff --git a/src/locales/de/run-history.json b/src/locales/de/run-history.json deleted file mode 100644 index 0a36afe9adc..00000000000 --- a/src/locales/de/run-history.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "victory": "Sieg!", - "defeatedWild": "Besiegt durch ", - "defeatedTrainer": "Besiegt durch ", - "defeatedTrainerDouble": "Besiegt durch Doppelkampf", - "defeatedRival": "Besiegt durch Rivalin", - "defeated": "Besiegt", - "defeatedWild_female": "Besiegt durch ", - "defeatedTrainer_female": "Besiegt durch ", - "defeatedTrainerDouble_female": "Besiegt durch Doppelkampf", - "defeatedRival_female": "Besiegt durch Rivale", - "defeated_female": "Besiegt", - "luck": "Glück", - "score": "Punkte", - "mode": "Modus", - "challengeRules": "Regeln", - "challengeMonoGen1": "Gen I", - "challengeMonoGen2": "Gen II", - "challengeMonoGen3": "Gen III", - "challengeMonoGen4": "Gen IV", - "challengeMonoGen5": "Gen V", - "challengeMonoGen6": "Gen VI", - "challengeMonoGen7": "Gen VII", - "challengeMonoGen8": "Gen VIII", - "challengeMonoGen9": "Gen IX", - "playerItems": "Spielergegenstände", - "personalBest": "Persönlicher Bestwert!", - "SPDshortened": "Init.", - "runInfo": "Durchlauf Informationen", - "money": "Geld", - "runLength": "Durchlauf Dauer", - "viewHeldItems": "Getragene Items", - "hallofFameText": "Willkommen in der Ruhmeshalle!", - "hallofFameText_female": "Willkommen in der Ruhmeshalle", - "viewHallOfFame": "Ruhmeshalle ansehen!", - "viewEndingSplash": "Endgrafik anzeigen!" -} - diff --git a/src/locales/de/save-slot-select-ui-handler.json b/src/locales/de/save-slot-select-ui-handler.json deleted file mode 100644 index 7b6e493b867..00000000000 --- a/src/locales/de/save-slot-select-ui-handler.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "overwriteData": "Den ausgewählten Speicherstand überschreiben?", - "loading": "Läd...", - "wave": "Welle", - "lv": "Lv. ", - "empty": "Leer" -} \ No newline at end of file diff --git a/src/locales/de/settings.json b/src/locales/de/settings.json deleted file mode 100644 index 31406f28d17..00000000000 --- a/src/locales/de/settings.json +++ /dev/null @@ -1,107 +0,0 @@ -{ - "boy": "Junge", - "girl": "Mädchen", - "general": "Allgemein", - "display": "Anzeige", - "audio": "Audio", - "gamepad": "Controller", - "keyboard": "Tastatur", - "gameSpeed": "Spielgeschwindigkeit", - "hpBarSpeed": "KP-Balken Geschw.", - "expGainsSpeed": "EP-Balken Geschw.", - "expPartyDisplay": "Team-EP anzeigen", - "skipSeenDialogues": "Gesehenen Dialog überspringen", - "battleStyle": "Kampfstil", - "enableRetries": "Erneut versuchen aktivieren", - "hideIvs": "IS-Scanner verstecken", - "tutorials": "Tutorials", - "touchControls": "Touch Steuerung", - "vibrations": "Vibration", - "normal": "Normal", - "fast": "Schnell", - "faster": "Schneller", - "skip": "Überspringen", - "levelUpNotifications": "Nur Lvl.-Up", - "on": "An", - "off": "Aus", - "switch": "Wechsel", - "set": "Folge", - "auto": "Auto", - "disabled": "Deaktiviert", - "language": "Sprache", - "change": "Ändern", - "uiTheme": "UI Thema", - "default": "Standard", - "legacy": "Legacy", - "windowType": "Fenster Typ", - "moneyFormat": "Währungsformat", - "damageNumbers": "Schadensnummern", - "simple": "Simpel", - "fancy": "Schön", - "abbreviated": "Abgekürzt", - "moveAnimations": "Attacken Animationen", - "showStatsOnLevelUp": "Werte beim Aufleveln anzeigen", - "candyUpgradeNotification": "Bonbon Upgrade Benachrichtigung", - "passivesOnly": "Nur Passive", - "candyUpgradeDisplay": "Bonbon Upgrade Anzeige", - "icon": "Icon", - "animation": "Animation", - "moveInfo": "Attacken-Info", - "showMovesetFlyout": "Zeige Attacken Flyout", - "showArenaFlyout": "Zeige Arena Flyout", - "showTimeOfDayWidget": "Zeige Tageszeit Widget", - "timeOfDayAnimation": "Tageszeit Animation", - "bounce": "Springen", - "timeOfDay_back": "Zurück", - "spriteSet": "Sprite Satz", - "consistent": "Konistent", - "mixedAnimated": "Gemischt animiert", - "fusionPaletteSwaps": "Fusion-Farbpalettenwechsel", - "playerGender": "Spielergeschlecht", - "typeHints": "Typhinweise", - "masterVolume": "Gesamtlautstärke", - "bgmVolume": "Hintergrundmusik", - "fieldVolume": "Rufe & Attacken", - "seVolume": "Spezialeffekte", - "uiVolume": "Benutzeroberfläche", - "musicPreference": "Musik Präferenz", - "mixed": "Gemischt", - "gamepadPleasePlug": "Bitte einen Controller anschließen oder eine Taste drücken.", - "delete": "Löschen", - "keyboardPleasePress": "Bitte eine Taste auf der Tastatur drücken.", - "reset": "Reset", - "requireReload": "Neuladen", - "action": "Aktion", - "back": "Zurück", - "pressToBind": "Zum Zuweisen drücken", - "pressButton": "Eine Taste drücken...", - "buttonUp": "Hoch", - "buttonDown": "Runter", - "buttonLeft": "Links", - "buttonRight": "Rechts", - "buttonAction": "Aktion", - "buttonMenu": "Menü", - "buttonSubmit": "Bestätigen", - "buttonCancel": "Abbrechen", - "buttonStats": "Statuswerte", - "buttonCycleForm": "Form wechseln", - "buttonCycleShiny": "Schillernd wechseln", - "buttonCycleGender": "Geschlecht wechseln", - "buttonCycleAbility": "Fähigkeit wechseln", - "buttonCycleNature": "Wesen wechseln", - "buttonCycleVariant": "Variante wechseln", - "buttonSpeedUp": "Beschleunigen", - "buttonSlowDown": "Verlangsamen", - "alt": " (Alt)", - "mute": "Stumm", - "controller": "Controller", - "gamepadSupport": "Controllerunterstützung", - "showBgmBar": "Musiknamen anzeigen", - "moveTouchControls": "Bewegung Touch Steuerung", - "shopOverlayOpacity": "Shop Overlay Deckkraft", - "shopCursorTarget": "Shop-Cursor Ziel", - "rewards": "Items", - "reroll": "Neu rollen", - "shop": "Shop", - "checkTeam": "Team überprüfen" -} diff --git a/src/locales/de/splash-messages.json b/src/locales/de/splash-messages.json deleted file mode 100644 index ac3fd345f3f..00000000000 --- a/src/locales/de/splash-messages.json +++ /dev/null @@ -1,36 +0,0 @@ -{ - "battlesWon": "Kämpfe gewonnen!", - "joinTheDiscord": "Tritt dem Discord bei!", - "infiniteLevels": "Unendliche Level!", - "everythingStacks": "Alles stapelt sich!", - "optionalSaveScumming": "Optionales Save Scumming!", - "biomes": "35 Biome!", - "openSource": "Open Source!", - "playWithSpeed": "Spiele mit fünffacher Geschwindigkeit!", - "liveBugTesting": "Live-Bug-Tests!", - "heavyInfluence": "Starker RoR2-Einfluss!", - "pokemonRiskAndPokemonRain": "Pokémon Risk and Pokémon Rain!", - "nowWithMoreSalt": "Jetzt mit 33% mehr Salz!", - "infiniteFusionAtHome": "Wir haben Infinite Fusionen zu Hause!", - "brokenEggMoves": "Übermächtige Ei-Attacken!", - "magnificent": "Herrlich!", - "mubstitute": "Melegator!", - "thatsCrazy": "Das ist verrückt!", - "oranceJuice": "Orangensaft!", - "questionableBalancing": "Fragwürdiges Balancing!", - "coolShaders": "Coole Shader!", - "aiFree": "Ohne KI!", - "suddenDifficultySpikes": "Plötzliche Schwierigkeitsspitzen!", - "basedOnAnUnfinishedFlashGame": "Basierend auf einem unfertigen Flash-Spiel!", - "moreAddictiveThanIntended": "Süchtig machender als beabsichtigt!", - "mostlyConsistentSeeds": "Meistens konsistente Seeds!", - "achievementPointsDontDoAnything": "Errungenschaftspunkte tun nichts!", - "youDoNotStartAtLevel": "Du startest nicht auf Level 2000!", - "dontTalkAboutTheManaphyEggIncident": "Wir reden nicht über den Manaphy-Ei-Vorfall!", - "alsoTryPokengine": "Versuche auch Pokéngine!", - "alsoTryEmeraldRogue": "Versuche auch Emerald Rogue!", - "alsoTryRadicalRed": "Versuche auch Radical Red!", - "eeveeExpo": "Evoli-Expo!", - "ynoproject": "YNO-Projekt!", - "breedersInSpace": "Züchter im Weltall!" -} \ No newline at end of file diff --git a/src/locales/de/starter-select-ui-handler.json b/src/locales/de/starter-select-ui-handler.json deleted file mode 100644 index e146d1bdcd9..00000000000 --- a/src/locales/de/starter-select-ui-handler.json +++ /dev/null @@ -1,45 +0,0 @@ -{ - "confirmStartTeam": "Mit diesen Pokémon losziehen?", - "confirmExit": "Willst du zurück?", - "invalidParty": "Das ist kein gültiges Team!", - "gen1": "I", - "gen2": "II", - "gen3": "III", - "gen4": "IV", - "gen5": "V", - "gen6": "VI", - "gen7": "VII", - "gen8": "VIII", - "gen9": "IX", - "growthRate": "Wachstum:", - "ability": "Fähigkeit:", - "passive": "Passiv:", - "nature": "Wesen:", - "eggMoves": "Ei-Attacken", - "addToParty": "Zum Team hinzufügen", - "removeFromParty": "Aus Team entfernen", - "toggleIVs": "DVs anzeigen/verbergen", - "manageMoves": "Attacken ändern", - "manageNature": "Wesen ändern", - "addToFavorites": "Zu Favoriten hinzufügen", - "removeFromFavorites": "Von Favoriten entfernen", - "useCandies": "Bonbons verwenden", - "selectNature": "Wähle das neue Wesen.", - "selectMoveSwapOut": "Wähle die zu ersetzende Attacke.", - "selectMoveSwapWith": "Wähle die gewünschte Attacke.", - "unlockPassive": "Passiv-Skill freischalten", - "reduceCost": "Preis reduzieren", - "sameSpeciesEgg": "Ein Ei kaufen", - "cycleShiny": ": Schillernd", - "cycleForm": ": Form", - "cycleGender": ": Geschlecht", - "cycleAbility": ": Fähigkeit", - "cycleNature": ": Wesen", - "cycleVariant": ": Seltenheit", - "goFilter": ": Zu den Filtern", - "enablePassive": "Passiv-Skill aktivieren", - "disablePassive": "Passiv-Skill deaktivieren", - "locked": "Gesperrt", - "disabled": "Deaktiviert", - "uncaught": "Ungefangen" -} \ No newline at end of file diff --git a/src/locales/de/status-effect.json b/src/locales/de/status-effect.json deleted file mode 100644 index c30d432fe79..00000000000 --- a/src/locales/de/status-effect.json +++ /dev/null @@ -1,65 +0,0 @@ -{ - "none": { - "name": "None", - "description": "", - "obtain": "", - "obtainSource": "", - "activation": "", - "overlap": "", - "heal": "" - }, - "poison": { - "name": "Gift", - "description": "Vergiftungen", - "obtain": "{{pokemonNameWithAffix}} wurde vergiftet!", - "obtainSource": "{{pokemonNameWithAffix}} wurde durch {{sourceText}} vergiftet!", - "activation": "{{pokemonNameWithAffix}} wird durch Gift verletzt!", - "overlap": "{{pokemonNameWithAffix}} ist bereits vergiftet!", - "heal": "Die Vergiftung von {{pokemonNameWithAffix}} wurde geheilt!" - }, - "toxic": { - "name": "Gift", - "description": "Vergiftungen", - "obtain": "{{pokemonNameWithAffix}} wurde schwer vergiftet!", - "obtainSource": "{{pokemonNameWithAffix}} wurde durch {{sourceText}} schwer vergiftet!", - "activation": "{{pokemonNameWithAffix}} wird durch Gift verletzt!", - "overlap": "{{pokemonNameWithAffix}} ist bereits vergiftet!", - "heal": "Die Vergiftung von {{pokemonNameWithAffix}} wurde geheilt!" - }, - "paralysis": { - "name": "Paralyse", - "description": "Paralyse", - "obtain": "{{pokemonNameWithAffix}} wurde paralysiert!\nEs kann eventuell nicht handeln!", - "obtainSource": "{{pokemonNameWithAffix}} wurde durch {{sourceText}} paralysiert,\nEs kann eventuell nicht handeln!", - "activation": "{{pokemonNameWithAffix}} ist paralysiert!\nEs kann nicht angreifen!", - "overlap": "{{pokemonNameWithAffix}} ist bereits paralysiert!", - "heal": "Die Paralyse von {{pokemonNameWithAffix}} wurde aufgehoben!" - }, - "sleep": { - "name": "Schlaf", - "description": "Einschlafen", - "obtain": "{{pokemonNameWithAffix}} ist eingeschlafen!", - "obtainSource": "{{pokemonNameWithAffix}} ist durch {{sourceText}} eingeschlafen!", - "activation": "{{pokemonNameWithAffix}} schläft tief und fest!", - "overlap": "{{pokemonNameWithAffix}} schläft bereits!", - "heal": "{{pokemonNameWithAffix}} ist aufgewacht!" - }, - "freeze": { - "name": "Gefroren", - "description": "Einfrieren", - "obtain": "{{pokemonNameWithAffix}} erstarrt zu Eis!", - "obtainSource": "{{pokemonNameWithAffix}} erstarrt durch {{sourceText}} zu Eis!", - "activation": "{{pokemonNameWithAffix}} ist eingefroren und kann nicht handeln!", - "overlap": "{{pokemonNameWithAffix}} ist bereits eingefroren!", - "heal": "{{pokemonNameWithAffix}} wurde aufgetaut!" - }, - "burn": { - "name": "Verbrennung", - "description": "Verbrennungen", - "obtain": "{{pokemonNameWithAffix}} erleidet Verbrennungen!", - "obtainSource": "{{pokemonNameWithAffix}} erleidet durch {{sourceText}} Verbrennungen!", - "activation": "Die Verbrennungen schaden {{pokemonNameWithAffix}}!", - "overlap": "{{pokemonNameWithAffix}} leidet bereits unter Verbrennungen!", - "heal": "Die Verbrennungen von {{pokemonNameWithAffix}} wurden geheilt!" - } -} \ No newline at end of file diff --git a/src/locales/de/terrain.json b/src/locales/de/terrain.json deleted file mode 100644 index 4d2ef33752c..00000000000 --- a/src/locales/de/terrain.json +++ /dev/null @@ -1,20 +0,0 @@ -{ - "misty": "Nebelfeld", - "mistyStartMessage": "Am Boden breitet sich dichter Nebel aus!", - "mistyClearMessage": "Das Nebelfeld ist wieder verschwunden!", - "mistyBlockMessage": "{{pokemonNameWithAffix}} wird vom Nebelfeld geschützt!", - - "electric": "Elektrofeld", - "electricStartMessage": "Elektrische Energie fließt durch den Boden!", - "electricClearMessage": "Das Elektrofeld ist wieder verschwunden!", - - "grassy": "Grasfeld", - "grassyStartMessage": "Dichtes Gras schießt aus dem Boden!", - "grassyClearMessage": "Das Grasfeld ist wieder verschwunden!", - - "psychic": "Psychofeld", - "psychicStartMessage": "Der Boden fühlt sich seltsam an!", - "psychicClearMessage": "Das Psychofeld ist wieder verschwunden!", - - "defaultBlockMessage": "{{pokemonNameWithAffix}} wird vom {{terrainName}} geschützt!" -} \ No newline at end of file diff --git a/src/locales/de/trainer-classes.json b/src/locales/de/trainer-classes.json deleted file mode 100644 index 45826fcd310..00000000000 --- a/src/locales/de/trainer-classes.json +++ /dev/null @@ -1,130 +0,0 @@ -{ - "ace_trainer": "Ass-Trainer", - "ace_trainer_female": "Ass-Trainerin", - "ace_duo": "Ass-Duo", - "artist": "Künstler", - "artist_female": "Künstlerin", - "backers": "Anhänger", - "backpacker": "Backpacker", - "backpacker_female": "Backpackerin", - "backpackers": "Backpacker", - "baker": "Bäckerin", - "battle_girl": "Kämpferin", - "beauty": "Schönheit", - "beginners": "Anfänger", - "biker": "Rowdy", - "black_belt": "Schwarzgurt", - "breeder": "Pokémon Züchter", - "breeder_female": "Pokémon Züchterin", - "breeders": "Pokémon Züchter", - "clerk": "Angestellter", - "clerk_female": "Angestellte", - "colleagues": "Geschäftspartner", - "crush_kin": "Mühlensippe", - "cyclist": "Biker", - "cyclist_female": "Bikerin", - "cyclists": "Biker", - "dancer": "Tänzer", - "dancer_female": "Tänzerin", - "depot_agent": "Bahnangestellter", - "doctor": "Arzt", - "doctor_female": "Ärztin", - "firebreather": "Feuerspucker", - "fisherman": "Angler", - "fisherman_female": "Angler", - "gentleman": "Gentleman", - "guitarist": "Gitarrist", - "guitarist_female": "Gitarristin", - "harlequin": "Kasper", - "hiker": "Wanderer", - "hooligans": "Rabauken", - "hoopster": "Basketballer", - "infielder": "Baseballer", - "janitor": "Hausmeister", - "lady": "Lady", - "lass": "Göre", - "linebacker": "Footballer", - "maid": "Zofe", - "madame": "Madam", - "medical_team": "Mediziner", - "musician": "Musiker", - "hex_maniac": "Hexe", - "nurse": "Pflegerin", - "nursery_aide": "Erzieherin", - "officer": "Polizist", - "parasol_lady": "Schirmdame", - "pilot": "Pilot", - "pokéfan": "Pokéfan", - "pokéfan_female": "Pokéfan", - "pokéfan_family": "Pokéfan-Pärchen", - "preschooler": "Vorschüler", - "preschooler_female": "Vorschülerin", - "preschoolers": "Vorschüler", - "psychic": "Seher", - "psychic_female": "Seherin", - "psychics": "Seher", - "pokémon_ranger": "Pokémon-Ranger", - "pokémon_ranger_female": "Pokémon-Ranger", - "pokémon_rangers": "Pokémon-Ranger", - "ranger": "Ranger", - "restaurant_staff": "Restaurant Angestellte", - "rich": "Gentleman", - "rich_female": "Reiche Dame", - "rich_boy": "Schnösel", - "rich_couple": "Reiches Paar", - "rich_kid": "Schnösel", - "rich_kid_female": "Schnöselin", - "rich_kids": "Schnösel", - "roughneck": "Raufbold", - "sailor": "Matrose", - "scientist": "Forscher", - "scientist_female": "Forscherin", - "scientists": "Forscher", - "smasher": "Tennis-Ass", - "snow_worker": "Schneearbeiter", - "snow_worker_female": "Schneearbeiterin", - "striker": "Fußballer", - "school_kid": "Schulkind", - "school_kid_female": "Schulkind", - "school_kids": "Schüler", - "swimmer": "Schwimmer", - "swimmer_female": "Schwimmerin", - "swimmers": "Schwimmerpaar", - "twins": "Zwillinge", - "veteran": "Veteran", - "veteran_female": "Veteran", - "veteran_duo": "Veteranen", - "waiter": "Servierer", - "waitress": "Serviererin", - "worker": "Arbeiter", - "worker_female": "Arbeiterin", - "workers": "Arbeiter", - "youngster": "Knirps", - "rocket_grunt": "Rüpel von Team Rocket", - "rocket_grunt_female": "Rüpel von Team Rocket", - "rocket_grunts": "Rüpel von Team Rocket", - "magma_grunt": "Rüpel von Team Magma", - "magma_grunt_female": "Rüpel von Team Magma", - "magma_grunts": "Rüpel von Team Magma", - "aqua_grunt": "Rüpel von Team Aqua", - "aqua_grunt_female": "Rüpel von Team Aqua", - "aqua_grunts": "Rüpel von Team Aqua", - "galactic_grunt": "Rüpel von Team Galaktik", - "galactic_grunt_female": "Rüpel von Team Galaktik", - "galactic_grunts": "Rüpel von Team Galaktik", - "plasma_grunt": "Rüpel von Team Plasma", - "plasma_grunt_female": "Rüpel von Team Plasma", - "plasma_grunts": "Rüpel von Team Plasma", - "flare_grunt": "Rüpel von Team Flare", - "flare_grunt_female": "Rüpel von Team Flare", - "flare_grunts": "Rüpel von Team Flare", - "aether_grunt": "Æther Foundation Personal", - "aether_grunt_female": "Æther Foundation Personal", - "aether_grunts": "Æther Foundation Personal", - "skull_grunt": "Rüpel von Team Skull", - "skull_grunt_female": "Rüpel von Team Skull", - "skull_grunts": "Rüpel von Team Skull", - "macro_grunt": "Angestellter von Macro Cosmos", - "macro_grunt_female": "Angestellte von Macro Cosmos", - "macro_grunts": "Angestellte von Macro Cosmos" -} diff --git a/src/locales/de/trainer-names.json b/src/locales/de/trainer-names.json deleted file mode 100644 index ffbb772234c..00000000000 --- a/src/locales/de/trainer-names.json +++ /dev/null @@ -1,165 +0,0 @@ -{ - "brock": "Rocko", - "misty": "Misty", - "lt_surge": "Major Bob", - "erika": "Erika", - "janine": "Janina", - "sabrina": "Sabrina", - "blaine": "Pyro", - "giovanni": "Giovanni", - "falkner": "Falk", - "bugsy": "Kai", - "whitney": "Bianka", - "morty": "Jens", - "chuck": "Hartwig", - "jasmine": "Jasmin", - "pryce": "Norbert", - "clair": "Sandra", - "roxanne": "Felizia", - "brawly": "Kamillo", - "wattson": "Walter", - "flannery": "Flavia", - "norman": "Norman", - "winona": "Wibke", - "tate": "Ben", - "liza": "Svenja", - "juan": "Juan", - "roark": "Veit", - "gardenia": "Silvana", - "maylene": "Hilda", - "crasher_wake": "Wellenbrecher Marinus", - "fantina": "Lamina", - "byron": "Adam", - "candice": "Frida", - "volkner": "Volkner", - "cilan": "Benny", - "chili": "Maik", - "cress": "Colin", - "cheren": "Cheren", - "lenora": "Aloe", - "roxie": "Mica", - "burgh": "Artie", - "elesa": "Kamilla", - "clay": "Turner", - "skyla": "Géraldine", - "brycen": "Sandro", - "drayden": "Lysander", - "marlon": "Benson", - "viola": "Viola", - "grant": "Lino", - "korrina": "Connie", - "ramos": "Amaro", - "clemont": "Citro", - "valerie": "Valerie", - "olympia": "Astrid", - "wulfric": "Galantho", - "milo": "Yarro", - "nessa": "Kate", - "kabu": "Kabu", - "bea": "Saida", - "allister": "Nio", - "opal": "Papella", - "bede": "Betys", - "gordie": "Mac", - "melony": "Mel", - "piers": "Nezz", - "marnie": "Mary", - "raihan": "Roy", - "katy": "Ronah", - "brassius": "Colzo", - "iono": "Enigmara", - "kofu": "Kombu", - "larry": "Aoki", - "ryme": "Etta", - "tulip": "Tulia", - "grusha": "Grusha", - "lorelei": "Lorelei", - "bruno": "Bruno", - "agatha": "Agathe", - "lance": "Siegfried", - "will": "Willi", - "koga": "Koga", - "karen": "Melanie", - "sidney": "Ulrich", - "phoebe": "Antonia", - "glacia": "Frosina", - "drake": "Dragan", - "aaron": "Herbaro", - "bertha": "Teresa", - "flint": "Ignaz", - "lucian": "Lucian", - "shauntal": "Anissa", - "marshal": "Eugen", - "grimsley": "Astor", - "caitlin": "Kattlea", - "malva": "Pachira", - "siebold": "Narcisse", - "wikstrom": "Thymelot", - "drasna": "Dracena", - "hala": "Hala", - "molayne": "Marlon", - "olivia": "Mayla", - "acerola": "Lola", - "kahili": "Kahili", - "rika": "Cay", - "poppy": "Poppy", - "hassel": "Sinius", - "crispin": "Matt", - "amarys": "Erin", - "lacey": "Tara", - "drayton": "Levy", - "blue": "Blau", - "red": "Rot", - "steven": "Troy", - "wallace": "Wassili", - "cynthia": "Cynthia", - "alder": "Lauro", - "iris": "Lilia", - "diantha": "Diantha", - "hau": "Tali", - "geeta": "Sagaria", - "nemona": "Nemila", - "kieran": "Jo", - "leon": "Delion", - "rival": "Finn", - "rival_female": "Ivy", - - "archer": "Atlas", - "ariana": "Athena", - "proton": "Lance", - "petrel": "Lambda", - "tabitha": "Kalle", - "courtney": "Jördis", - "shelly": "Kordula", - "matt": "Wolfgang", - "mars": "Mars", - "jupiter": "Jupiter", - "saturn": "Saturn", - "zinzolin": "Violaceus", - "rood": "Rubius", - "xerosic": "Xeros", - "bryony": "Begonia", - "faba": "Fabian", - "plumeria": "Fran", - "oleana": "Olivia", - - "maxie": "Marc", - "archie": "Adrian", - "cyrus": "Zyrus", - "ghetsis": "G-Cis", - "lysandre": "Flordelis", - "lusamine": "Samantha", - "guzma": "Bromley", - "rose": "Rose", - - "blue_red_double": "Blau & Rot", - "red_blue_double": "Rot & Blau", - "tate_liza_double": "Ben & Svenja", - "liza_tate_double": "Svenja & Ben", - "steven_wallace_double": "Troy & Wassili", - "wallace_steven_double": "Wassili & Troy", - "alder_iris_double": "Lauro & Lilia", - "iris_alder_double": "Lilia & Lauro", - "piers_marnie_double": "Nezz & Mary", - "marnie_piers_double": "Mary & Nezz" -} diff --git a/src/locales/de/trainer-titles.json b/src/locales/de/trainer-titles.json deleted file mode 100644 index 21a4b2fa7b6..00000000000 --- a/src/locales/de/trainer-titles.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "elite_four": "Top Vier", - "elite_four_female": "Top Vier", - "gym_leader": "Arenaleiter", - "gym_leader_female": "Arenaleiterin", - "gym_leader_double": "Arenaleiter-Duo", - "champion": "Champion", - "champion_female": "Champion", - "champion_double": "Champion-Duo", - "rival": "Rivale", - "professor": "Professor", - "frontier_brain": "Kampfkoryphäen", - "rocket_boss": "Rocket-Boss", - "magma_boss": "Magma-Boss", - "aqua_boss": "Aqua-Boss", - "galactic_boss": "Galaktik-Boss", - "plasma_boss": "Weiser von Team Plasma", - "flare_boss": "Flare-Boss", - "aether_boss": "Æther-Präsidentin", - "skull_boss": "Skull-Boss", - "macro_boss": "Geschäftsführer von Macro Cosmos", - "rocket_admin": "Team Rocket Vorstand", - "rocket_admin_female": "Team Rocket Vorstand", - "magma_admin": "Team Magma Vorstand", - "magma_admin_female": "Team Magma Vorstand", - "aqua_admin": "Team Aqua Vorstand", - "aqua_admin_female": "Team Aqua Vorstand", - "galactic_commander": "Team Galaktik Commander", - "galactic_commander_female": "Team Galaktik Commander", - "plasma_sage": "Weiser von Team Plasma", - "plasma_admin": "Team Plasma Vorstand", - "flare_admin": "Team Flare Vorstand", - "flare_admin_female": "Team Flare Vorstand", - "aether_admin": "Æther-Regionalleiter", - "skull_admin": "Team Skull Vorstand", - "macro_admin": "Vizepräsidentin von Macro Cosmos" - -} diff --git a/src/locales/de/tutorial.json b/src/locales/de/tutorial.json deleted file mode 100644 index 9cdb94b2cac..00000000000 --- a/src/locales/de/tutorial.json +++ /dev/null @@ -1,10 +0,0 @@ -{ - "intro": "Willkommen bei PokéRogue! Dies ist ein kampforientiertes Pokémon-Fangame mit Roguelite-Elementen.\n$Dieses Spiel ist nicht monetarisiert.\n$Wir erheben keinen Eigentumsanspruch an Pokémon oder\nverwendeten, urheberrechtlich geschützten Inhalten.\n$Das Spiel befindet sich noch in der Entwicklung, ist aber voll spielbar.\n$Für Fehlerberichte nutze bitte den PokéRogue Discord-Server.\n$Sollte das Spiel langsam laufen, überprüfe, ob in deinem Browser \"Hardwarebeschleunigung\" aktiviert ist.", - "accessMenu": "Nutze M oder Esc, um das Menü zu öffnen. Dort hast du Zugriff auf die Einstellungen und andere Funktionen.", - "menu": "In diesem Menü hast du Zugriff auf die Einstellungen.\n$Dort kannst du u. A. die Spielgeschwin-\ndigkeit und das Fensterdesign ändern.\n$Das Menü verbirgt noch andere Funktionen - probier' sie gerne aus!", - "starterSelect": "In diesem Bildschirm kannst du mit Z oder Leertaste deine\nStarter auswählen.\n$Sie begleiten dich am Anfang deines Abenteuers.\n$Jeder Starter hat einen Preis. Dein Team kann bis zu sechs\nMitglieder haben, solange der Gesamtpreis max. 10 beträgt.\n$Du kannst Geschlecht, Fähigkeit und Form beliebig auswählen,\nsobald du sie mindestens einmal gefangen hast.\n$Die DVs ergeben sich aus den Höchstwerten aller Pokémon,\ndie du bereits gefangen hast. \n$Es lohnt sich also, das selbe Pokémon mehrmals zu fangen!", - "pokerus": "Jeden Tag haben drei zufällige Pokémon einen lila Rahmen.\n$Wenn du eins von ihnen besitzt,\n$nimm es doch mal mit und sieh dir seinen Bericht an!", - "statChange": "Statuswertveränderungen halten solange an, wie dein Pokémon auf dem Feld bleibt.\n$Pokémon werden am Anfang eines Trainerkampfes oder bei einem Arealwechsel automatisch zurückgerufen.\n$Nutze C oder Shift, um aktuelle Statuswertveränderungen anzuzeigen.", - "selectItem": "Nach jedem Kampf kannst du aus 3 zufälligen Items exakt eines auswählen.\n$Es gibt u. A. Heilitems, tragbare Items und Basis-Items, die dir einen permanenten Vorteil verschaffen.\n$Die meisten tragbaren und permanenten Items werden stärker, wenn du sie mehrfach sammelst.\n$Manche Items, wie Entwicklungssteine, tauchen nur auf, wenn du sie auch nutzen kannst.\n$Mithilfe der \"Transfer\"-Option kannst du Items zwischen deinen Pokémon verschieben.\n$Sie erscheint rechts unten, sobald du einem deiner Pokémon dein Item zum Tragen gegeben hast.\n$Du kannst Heilitems auch gegen Geld erwerben. Je weiter du kommst, desto mehr stehen dir zur Auswahl.\n$Erledige deine Einkäufe als erstes, denn sobald du dein zufälliges Item auswählst, beginnt der nächste Kampf.", - "eggGacha": "Hier kannst du deine Gutscheine gegen Pokémon-Eier\ntauschen.\n$Eier schlüpfen, nachdem du eine gewisse Anzahl Kämpfe\nabsolviert hast. Je seltener das Ei, desto länger dauert es.\n$Geschlüpfte Pokémon werden nicht deinem Team hinzugefügt,\nsondern deinen verfügbaren Startern.\n$In der Regel haben sie bessere DVs als in der Wildnis\ngefangene Pokémon.\n$Es gibt sogar Pokémon, die du nur aus Eiern erhalten kannst.\n$Es gibt drei Gacha-Maschinen mit je unterschiedlichen Boni,\nalso such' dir die aus, die dir am besten gefällt!" -} \ No newline at end of file diff --git a/src/locales/de/voucher.json b/src/locales/de/voucher.json deleted file mode 100644 index 8c2804a83d3..00000000000 --- a/src/locales/de/voucher.json +++ /dev/null @@ -1,9 +0,0 @@ -{ - "vouchers": "Gutscheine", - "eggVoucher": "Ei-Gutschein", - "eggVoucherPlus": "Ei-Gutschein Plus", - "eggVoucherPremium": "Ei-Gutschein Premium", - "eggVoucherGold": "Ei-Gutschein Gold", - "locked": "Gesperrt", - "defeatTrainer": "Besiege {{trainerName}}" -} \ No newline at end of file diff --git a/src/locales/de/weather.json b/src/locales/de/weather.json deleted file mode 100644 index 6dc26b2cf8c..00000000000 --- a/src/locales/de/weather.json +++ /dev/null @@ -1,32 +0,0 @@ -{ - "sunnyStartMessage": "Die Sonnenlicht wird stärker!", - "sunnyLapseMessage": "Die Sonnenlicht ist stark.", - "sunnyClearMessage": "Die Sonnenlicht verliert wieder an Intensität.", - "rainStartMessage": "Es fängt an zu regnen!", - "rainLapseMessage": "Es regnet weiter.", - "rainClearMessage": "Der Regen lässt nach.", - "sandstormStartMessage": "Ein Sandsturm kommt auf!", - "sandstormLapseMessage": "Der Sandsturm tobt.", - "sandstormClearMessage": "Der Sandsturm legt sich.", - "sandstormDamageMessage": " Der Sandsturm fügt {{pokemonNameWithAffix}} Schaden zu!", - "hailStartMessage": "Es fängt an zu hageln!", - "hailLapseMessage": "Der Hagelsturm tobt.", - "hailClearMessage": "Der Hagelsturm legt sich.", - "hailDamageMessage": "{{pokemonNameWithAffix}} wird von Hagelkörnern getroffen!", - "snowStartMessage": "Es fängt an zu schneien!", - "snowLapseMessage": "Der Schneesturm tobt.", - "snowClearMessage": "Der Schneesturm legt sich.", - "fogStartMessage": "Am Boden breitet sich dichter Nebel aus!", - "fogLapseMessage": "Der Nebel bleibt dicht.", - "fogClearMessage": "Der Nebel lichtet sich.", - "heavyRainStartMessage": "Es fängt an, in Strömen zu regnen!", - "heavyRainLapseMessage": "Der strömende Regen hält an.", - "heavyRainClearMessage": "Der strömende Regen lässt nach.", - "harshSunStartMessage": "Das Sonnenlicht wird sehr viel stärker!", - "harshSunLapseMessage": "Das Sonnenlicht ist sehr stark.", - "harshSunClearMessage": "Das Sonnenlicht verliert an Intensität.", - "strongWindsStartMessage": "Alle Flug-Pokémon werden von rätselhaften Luftströmungen geschützt!", - "strongWindsLapseMessage": "Die rätselhafte Luftströmung hält an.", - "strongWindsEffectMessage": "Rätselhafte Luftströmungen haben den Angriff abgeschwächt!", - "strongWindsClearMessage": "Die rätselhafte Luftströmung hat sich wieder geleget." -} \ No newline at end of file diff --git a/src/locales/en/ability-trigger.json b/src/locales/en/ability-trigger.json deleted file mode 100644 index da21d80e3c7..00000000000 --- a/src/locales/en/ability-trigger.json +++ /dev/null @@ -1,64 +0,0 @@ -{ - "blockRecoilDamage": "{{pokemonName}}'s {{abilityName}}\nprotected it from recoil!", - "badDreams": "{{pokemonName}} is tormented!", - "costar": "{{pokemonName}} copied {{allyName}}'s stat changes!", - "iceFaceAvoidedDamage": "{{pokemonNameWithAffix}} avoided\ndamage with {{abilityName}}!", - "perishBody": "{{pokemonName}}'s {{abilityName}}\nwill faint both Pokémon in 3 turns!", - "poisonHeal": "{{pokemonName}}'s {{abilityName}}\nrestored its HP a little!", - "trace": "{{pokemonName}} copied {{targetName}}'s\n{{abilityName}}!", - "windPowerCharged": "Being hit by {{moveName}} charged {{pokemonName}} with power!", - "quickDraw": "{{pokemonName}} can act faster than normal, thanks to its Quick Draw!", - "disguiseAvoidedDamage": "{{pokemonNameWithAffix}}'s disguise was busted!", - "blockItemTheft": "{{pokemonNameWithAffix}}'s {{abilityName}}\nprevents item theft!", - "typeImmunityHeal": "{{pokemonNameWithAffix}}'s {{abilityName}}\nrestored its HP a little!", - "nonSuperEffectiveImmunity": "{{pokemonNameWithAffix}} avoided damage\nwith {{abilityName}}!", - "fullHpResistType": "{{pokemonNameWithAffix}} made its shell gleam!\nIt's distorting type matchups!", - "moveImmunity": "It doesn't affect {{pokemonNameWithAffix}}!", - "reverseDrain": "{{pokemonNameWithAffix}} sucked up the liquid ooze!", - "postDefendTypeChange": "{{pokemonNameWithAffix}}'s {{abilityName}}\nmade it the {{typeName}} type!", - "postDefendContactDamage": "{{pokemonNameWithAffix}}'s {{abilityName}}\nhurt its attacker!", - "postDefendAbilitySwap": "{{pokemonNameWithAffix}} swapped\nabilities with its target!", - "postDefendAbilityGive": "{{pokemonNameWithAffix}} gave its target\n{{abilityName}}!", - "postDefendMoveDisable": "{{pokemonNameWithAffix}}'s {{moveName}}\nwas disabled!", - "pokemonTypeChange": "{{pokemonNameWithAffix}} transformed into the {{moveType}} type!", - "postAttackStealHeldItem": "{{pokemonNameWithAffix}} stole\n{{defenderName}}'s {{stolenItemType}}!", - "postDefendStealHeldItem": "{{pokemonNameWithAffix}} stole\n{{attackerName}}'s {{stolenItemType}}!", - "copyFaintedAllyAbility": "{{pokemonNameWithAffix}}'s {{abilityName}} was taken over!", - "intimidateImmunity": "{{pokemonNameWithAffix}}'s {{abilityName}} prevented it from being Intimidated!", - "postSummonAllyHeal": "{{pokemonNameWithAffix}} drank down all the\nmatcha that {{pokemonName}} made!", - "postSummonClearAllyStats": "{{pokemonNameWithAffix}}'s stat changes\nwere removed!", - "postSummonTransform": "{{pokemonNameWithAffix}} transformed\ninto {{targetName}}!", - "protectStat": "{{pokemonNameWithAffix}}'s {{abilityName}}\nprevents lowering its {{statName}}!", - "statusEffectImmunityWithName": "{{pokemonNameWithAffix}}'s {{abilityName}}\nprevents {{statusEffectName}}!", - "statusEffectImmunity": "{{pokemonNameWithAffix}}'s {{abilityName}}\nprevents status problems!", - "battlerTagImmunity": "{{pokemonNameWithAffix}}'s {{abilityName}}\nprevents {{battlerTagName}}!", - "forewarn": "{{pokemonNameWithAffix}} was forewarned about {{moveName}}!", - "frisk": "{{pokemonNameWithAffix}} frisked {{opponentName}}'s {{opponentAbilityName}}!", - "postWeatherLapseHeal": "{{pokemonNameWithAffix}}'s {{abilityName}}\nrestored its HP a little!", - "postWeatherLapseDamage": "{{pokemonNameWithAffix}} is hurt\nby its {{abilityName}}!", - "postTurnLootCreateEatenBerry": "{{pokemonNameWithAffix}} harvested one {{berryName}}!", - "postTurnHeal": "{{pokemonNameWithAffix}}'s {{abilityName}}\nrestored its HP a little!", - "fetchBall": "{{pokemonNameWithAffix}} found a\n{{pokeballName}}!", - "healFromBerryUse": "{{pokemonNameWithAffix}}'s {{abilityName}}\nrestored its HP!", - "arenaTrap": "{{pokemonNameWithAffix}}'s {{abilityName}}\nprevents switching!", - "postBattleLoot": "{{pokemonNameWithAffix}} picked up\n{{itemName}}!", - "postFaintContactDamage": "{{pokemonNameWithAffix}}'s {{abilityName}}\nhurt its attacker!", - "postFaintHpDamage": "{{pokemonNameWithAffix}}'s {{abilityName}}\nhurt its attacker!", - "postSummonPressure": "{{pokemonNameWithAffix}} is exerting its Pressure!", - "weatherEffectDisappeared": "The effects of the weather disappeared.", - "postSummonMoldBreaker": "{{pokemonNameWithAffix}} breaks the mold!", - "postSummonAnticipation": "{{pokemonNameWithAffix}} shuddered!", - "postSummonTurboblaze": "{{pokemonNameWithAffix}} is radiating a blazing aura!", - "postSummonTeravolt": "{{pokemonNameWithAffix}} is radiating a bursting aura!", - "postSummonDarkAura": "{{pokemonNameWithAffix}} is radiating a Dark Aura!", - "postSummonFairyAura": "{{pokemonNameWithAffix}} is radiating a Fairy Aura!", - "postSummonAuraBreak": "{{pokemonNameWithAffix}} reversed all other Pokémon's auras!", - "postSummonNeutralizingGas": "{{pokemonNameWithAffix}}'s Neutralizing Gas filled the area!", - "postSummonAsOneGlastrier": "{{pokemonNameWithAffix}} has two Abilities!", - "postSummonAsOneSpectrier": "{{pokemonNameWithAffix}} has two Abilities!", - "postSummonVesselOfRuin": "{{pokemonNameWithAffix}}'s Vessel of Ruin lowered the {{statName}}\nof all surrounding Pokémon!", - "postSummonSwordOfRuin": "{{pokemonNameWithAffix}}'s Sword of Ruin lowered the {{statName}}\nof all surrounding Pokémon!", - "postSummonTabletsOfRuin": "{{pokemonNameWithAffix}}'s Tablets of Ruin lowered the {{statName}}\nof all surrounding Pokémon!", - "postSummonBeadsOfRuin": "{{pokemonNameWithAffix}}'s Beads of Ruin lowered the {{statName}}\nof all surrounding Pokémon!", - "preventBerryUse": "{{pokemonNameWithAffix}} is too\nnervous to eat berries!" -} diff --git a/src/locales/en/ability.json b/src/locales/en/ability.json deleted file mode 100644 index de2e063e966..00000000000 --- a/src/locales/en/ability.json +++ /dev/null @@ -1,1242 +0,0 @@ -{ - "stench": { - "name": "Stench", - "description": "By releasing stench when attacking, this Pokémon may cause the target to flinch." - }, - "drizzle": { - "name": "Drizzle", - "description": "The Pokémon makes it rain when it enters a battle." - }, - "speedBoost": { - "name": "Speed Boost", - "description": "Its Speed stat is boosted every turn." - }, - "battleArmor": { - "name": "Battle Armor", - "description": "Hard armor protects the Pokémon from critical hits." - }, - "sturdy": { - "name": "Sturdy", - "description": "It cannot be knocked out with one hit. One-hit KO moves cannot knock it out, either." - }, - "damp": { - "name": "Damp", - "description": "Prevents the use of explosive moves, such as Self-Destruct, by dampening its surroundings." - }, - "limber": { - "name": "Limber", - "description": "Its limber body protects the Pokémon from paralysis." - }, - "sandVeil": { - "name": "Sand Veil", - "description": "Boosts the Pokémon's evasiveness in a sandstorm." - }, - "static": { - "name": "Static", - "description": "The Pokémon is charged with static electricity, so contact with it may cause paralysis." - }, - "voltAbsorb": { - "name": "Volt Absorb", - "description": "Restores HP if hit by an Electric-type move instead of taking damage." - }, - "waterAbsorb": { - "name": "Water Absorb", - "description": "Restores HP if hit by a Water-type move instead of taking damage." - }, - "oblivious": { - "name": "Oblivious", - "description": "The Pokémon is oblivious, and that keeps it from being infatuated or falling for taunts." - }, - "cloudNine": { - "name": "Cloud Nine", - "description": "Eliminates the effects of weather." - }, - "compoundEyes": { - "name": "Compound Eyes", - "description": "The Pokémon's compound eyes boost its accuracy." - }, - "insomnia": { - "name": "Insomnia", - "description": "The Pokémon is suffering from insomnia and cannot fall asleep." - }, - "colorChange": { - "name": "Color Change", - "description": "The Pokémon's type becomes the type of the move used on it." - }, - "immunity": { - "name": "Immunity", - "description": "The immune system of the Pokémon prevents it from getting poisoned." - }, - "flashFire": { - "name": "Flash Fire", - "description": "Powers up the Pokémon's Fire-type moves if it's hit by one." - }, - "shieldDust": { - "name": "Shield Dust", - "description": "This Pokémon's dust blocks the additional effects of attacks taken." - }, - "ownTempo": { - "name": "Own Tempo", - "description": "This Pokémon has its own tempo, and that prevents it from becoming confused." - }, - "suctionCups": { - "name": "Suction Cups", - "description": "This Pokémon uses suction cups to stay in one spot to negate all moves and items that force switching out." - }, - "intimidate": { - "name": "Intimidate", - "description": "The Pokémon intimidates opposing Pokémon upon entering battle, lowering their Attack stat." - }, - "shadowTag": { - "name": "Shadow Tag", - "description": "This Pokémon steps on the opposing Pokémon's shadow to prevent it from escaping." - }, - "roughSkin": { - "name": "Rough Skin", - "description": "This Pokémon inflicts damage with its rough skin to the attacker on contact." - }, - "wonderGuard": { - "name": "Wonder Guard", - "description": "Its mysterious power only lets supereffective moves hit the Pokémon." - }, - "levitate": { - "name": "Levitate", - "description": "By floating in the air, the Pokémon receives full immunity to all Ground-type moves." - }, - "effectSpore": { - "name": "Effect Spore", - "description": "Contact with the Pokémon may inflict poison, sleep, or paralysis on its attacker." - }, - "synchronize": { - "name": "Synchronize", - "description": "The attacker will receive the same status condition if it inflicts a burn, poison, or paralysis to the Pokémon." - }, - "clearBody": { - "name": "Clear Body", - "description": "Prevents other Pokémon's moves or Abilities from lowering the Pokémon's stats." - }, - "naturalCure": { - "name": "Natural Cure", - "description": "All status conditions heal when the Pokémon switches out." - }, - "lightningRod": { - "name": "Lightning Rod", - "description": "The Pokémon draws in all Electric-type moves. Instead of being hit by Electric-type moves, it boosts its Sp. Atk." - }, - "sereneGrace": { - "name": "Serene Grace", - "description": "Boosts the likelihood of additional effects occurring when attacking." - }, - "swiftSwim": { - "name": "Swift Swim", - "description": "Boosts the Pokémon's Speed stat in rain." - }, - "chlorophyll": { - "name": "Chlorophyll", - "description": "Boosts the Pokémon's Speed stat in harsh sunlight." - }, - "illuminate": { - "name": "Illuminate", - "description": "By illuminating its surroundings, the Pokémon raises the likelihood of meeting wild Pokémon and prevents its accuracy from being lowered." - }, - "trace": { - "name": "Trace", - "description": "When it enters a battle, the Pokémon copies an opposing Pokémon's Ability." - }, - "hugePower": { - "name": "Huge Power", - "description": "Doubles the Pokémon's Attack stat." - }, - "poisonPoint": { - "name": "Poison Point", - "description": "Contact with the Pokémon may poison the attacker." - }, - "innerFocus": { - "name": "Inner Focus", - "description": "The Pokémon's intensely focused, and that protects the Pokémon from flinching." - }, - "magmaArmor": { - "name": "Magma Armor", - "description": "The Pokémon is covered with hot magma, which prevents the Pokémon from becoming frozen." - }, - "waterVeil": { - "name": "Water Veil", - "description": "The Pokémon is covered with a water veil, which prevents the Pokémon from getting a burn." - }, - "magnetPull": { - "name": "Magnet Pull", - "description": "Prevents Steel-type Pokémon from escaping using its magnetic force." - }, - "soundproof": { - "name": "Soundproof", - "description": "Soundproofing gives the Pokémon full immunity to all sound-based moves." - }, - "rainDish": { - "name": "Rain Dish", - "description": "The Pokémon gradually regains HP in rain." - }, - "sandStream": { - "name": "Sand Stream", - "description": "The Pokémon summons a sandstorm when it enters a battle." - }, - "pressure": { - "name": "Pressure", - "description": "By putting pressure on the opposing Pokémon, it raises their PP usage." - }, - "thickFat": { - "name": "Thick Fat", - "description": "The Pokémon is protected by a layer of thick fat, which halves the damage taken from Fire- and Ice-type moves." - }, - "earlyBird": { - "name": "Early Bird", - "description": "The Pokémon awakens from sleep twice as fast as other Pokémon." - }, - "flameBody": { - "name": "Flame Body", - "description": "Contact with the Pokémon may burn the attacker." - }, - "runAway": { - "name": "Run Away", - "description": "Enables a sure getaway from wild Pokémon." - }, - "keenEye": { - "name": "Keen Eye", - "description": "Keen eyes prevent other Pokémon from lowering this Pokémon's accuracy." - }, - "hyperCutter": { - "name": "Hyper Cutter", - "description": "The Pokémon's proud of its powerful pincers. They prevent other Pokémon from lowering its Attack stat." - }, - "pickup": { - "name": "Pickup", - "description": "The Pokémon may pick up the item an opposing Pokémon held during a battle." - }, - "truant": { - "name": "Truant", - "description": "The Pokémon can't use a move if it had used a move on the previous turn." - }, - "hustle": { - "name": "Hustle", - "description": "Boosts the Attack stat, but lowers accuracy." - }, - "cuteCharm": { - "name": "Cute Charm", - "description": "Contact with the Pokémon may cause infatuation." - }, - "plus": { - "name": "Plus", - "description": "Boosts the Sp. Atk stat of the Pokémon if an ally with the Plus or Minus Ability is also in battle." - }, - "minus": { - "name": "Minus", - "description": "Boosts the Sp. Atk stat of the Pokémon if an ally with the Plus or Minus Ability is also in battle." - }, - "forecast": { - "name": "Forecast", - "description": "The Pokémon transforms with the weather to change its type to Water, Fire, or Ice." - }, - "stickyHold": { - "name": "Sticky Hold", - "description": "Items held by the Pokémon are stuck fast and cannot be removed by other Pokémon." - }, - "shedSkin": { - "name": "Shed Skin", - "description": "The Pokémon may heal its own status conditions by shedding its skin." - }, - "guts": { - "name": "Guts", - "description": "It's so gutsy that having a status condition boosts the Pokémon's Attack stat." - }, - "marvelScale": { - "name": "Marvel Scale", - "description": "The Pokémon's marvelous scales boost the Defense stat if it has a status condition." - }, - "liquidOoze": { - "name": "Liquid Ooze", - "description": "The oozed liquid has a strong stench, which damages attackers using any draining move." - }, - "overgrow": { - "name": "Overgrow", - "description": "Powers up Grass-type moves when the Pokémon's HP is low." - }, - "blaze": { - "name": "Blaze", - "description": "Powers up Fire-type moves when the Pokémon's HP is low." - }, - "torrent": { - "name": "Torrent", - "description": "Powers up Water-type moves when the Pokémon's HP is low." - }, - "swarm": { - "name": "Swarm", - "description": "Powers up Bug-type moves when the Pokémon's HP is low." - }, - "rockHead": { - "name": "Rock Head", - "description": "Protects the Pokémon from recoil damage." - }, - "drought": { - "name": "Drought", - "description": "Turns the sunlight harsh when the Pokémon enters a battle." - }, - "arenaTrap": { - "name": "Arena Trap", - "description": "Prevents opposing Pokémon from fleeing." - }, - "vitalSpirit": { - "name": "Vital Spirit", - "description": "The Pokémon is full of vitality, and that prevents it from falling asleep." - }, - "whiteSmoke": { - "name": "White Smoke", - "description": "The Pokémon is protected by its white smoke, which prevents other Pokémon from lowering its stats." - }, - "purePower": { - "name": "Pure Power", - "description": "Using its pure power, the Pokémon doubles its Attack stat." - }, - "shellArmor": { - "name": "Shell Armor", - "description": "A hard shell protects the Pokémon from critical hits." - }, - "airLock": { - "name": "Air Lock", - "description": "Eliminates the effects of weather." - }, - "tangledFeet": { - "name": "Tangled Feet", - "description": "Raises evasiveness if the Pokémon is confused." - }, - "motorDrive": { - "name": "Motor Drive", - "description": "Boosts its Speed stat if hit by an Electric-type move instead of taking damage." - }, - "rivalry": { - "name": "Rivalry", - "description": "Becomes competitive and deals more damage to Pokémon of the same gender, but deals less to Pokémon of the opposite gender." - }, - "steadfast": { - "name": "Steadfast", - "description": "The Pokémon's determination boosts the Speed stat each time the Pokémon flinches." - }, - "snowCloak": { - "name": "Snow Cloak", - "description": "Boosts the Pokémon's evasiveness in snow." - }, - "gluttony": { - "name": "Gluttony", - "description": "Makes the Pokémon eat a held Berry when its HP drops to half or less, which is sooner than usual." - }, - "angerPoint": { - "name": "Anger Point", - "description": "The Pokémon is angered when it takes a critical hit, and that maxes its Attack stat." - }, - "unburden": { - "name": "Unburden", - "description": "Boosts the Speed stat if the Pokémon's held item is used or lost." - }, - "heatproof": { - "name": "Heatproof", - "description": "The heatproof body of the Pokémon halves the damage from Fire-type moves that hit it." - }, - "simple": { - "name": "Simple", - "description": "The stat changes the Pokémon receives are doubled." - }, - "drySkin": { - "name": "Dry Skin", - "description": "Restores HP in rain or when hit by Water-type moves. Reduces HP in harsh sunlight, and increases the damage received from Fire-type moves." - }, - "download": { - "name": "Download", - "description": "Compares an opposing Pokémon's Defense and Sp. Def stats before raising its own Attack or Sp. Atk stat—whichever will be more effective." - }, - "ironFist": { - "name": "Iron Fist", - "description": "Powers up punching moves." - }, - "poisonHeal": { - "name": "Poison Heal", - "description": "Restores HP if the Pokémon is poisoned instead of losing HP." - }, - "adaptability": { - "name": "Adaptability", - "description": "Powers up moves of the same type as the Pokémon." - }, - "skillLink": { - "name": "Skill Link", - "description": "Maximizes the number of times multistrike moves hit." - }, - "hydration": { - "name": "Hydration", - "description": "Heals status conditions if it's raining." - }, - "solarPower": { - "name": "Solar Power", - "description": "Boosts the Sp. Atk stat in harsh sunlight, but HP decreases every turn." - }, - "quickFeet": { - "name": "Quick Feet", - "description": "Boosts the Speed stat if the Pokémon has a status condition." - }, - "normalize": { - "name": "Normalize", - "description": "All the Pokémon's moves become Normal type. The power of those moves is boosted a little." - }, - "sniper": { - "name": "Sniper", - "description": "Powers up moves if they become critical hits when attacking." - }, - "magicGuard": { - "name": "Magic Guard", - "description": "The Pokémon only takes damage from attacks." - }, - "noGuard": { - "name": "No Guard", - "description": "The Pokémon employs no-guard tactics to ensure incoming and outgoing attacks always land." - }, - "stall": { - "name": "Stall", - "description": "The Pokémon moves after all other Pokémon do." - }, - "technician": { - "name": "Technician", - "description": "Powers up the Pokémon's weaker moves." - }, - "leafGuard": { - "name": "Leaf Guard", - "description": "Prevents status conditions in harsh sunlight." - }, - "klutz": { - "name": "Klutz", - "description": "The Pokémon can't use any held items." - }, - "moldBreaker": { - "name": "Mold Breaker", - "description": "Moves can be used on the target regardless of its Abilities." - }, - "superLuck": { - "name": "Super Luck", - "description": "The Pokémon is so lucky that the critical-hit ratios of its moves are boosted." - }, - "aftermath": { - "name": "Aftermath", - "description": "Damages the attacker if it contacts the Pokémon with a finishing hit." - }, - "anticipation": { - "name": "Anticipation", - "description": "The Pokémon can sense an opposing Pokémon's dangerous moves." - }, - "forewarn": { - "name": "Forewarn", - "description": "When it enters a battle, the Pokémon can tell one of the moves an opposing Pokémon has." - }, - "unaware": { - "name": "Unaware", - "description": "When attacking, the Pokémon ignores the target Pokémon's stat changes." - }, - "tintedLens": { - "name": "Tinted Lens", - "description": "The Pokémon can use \"not very effective\" moves to deal regular damage." - }, - "filter": { - "name": "Filter", - "description": "Reduces the power of supereffective attacks taken." - }, - "slowStart": { - "name": "Slow Start", - "description": "For five turns, the Pokémon's Attack and Speed stats are halved." - }, - "scrappy": { - "name": "Scrappy", - "description": "The Pokémon can hit Ghost-type Pokémon with Normal- and Fighting-type moves." - }, - "stormDrain": { - "name": "Storm Drain", - "description": "Draws in all Water-type moves. Instead of being hit by Water-type moves, it boosts its Sp. Atk." - }, - "iceBody": { - "name": "Ice Body", - "description": "The Pokémon gradually regains HP in snow." - }, - "solidRock": { - "name": "Solid Rock", - "description": "Reduces the power of supereffective attacks taken." - }, - "snowWarning": { - "name": "Snow Warning", - "description": "The Pokémon makes it snow when it enters a battle." - }, - "honeyGather": { - "name": "Honey Gather", - "description": "The Pokémon gathers Honey after a battle. The Honey is then sold for money." - }, - "frisk": { - "name": "Frisk", - "description": "When it enters a battle, the Pokémon can check an opposing Pokémon's Ability." - }, - "reckless": { - "name": "Reckless", - "description": "Powers up moves that have recoil damage." - }, - "multitype": { - "name": "Multitype", - "description": "Changes the Pokémon's type to match the Plate or Z-Crystal it holds." - }, - "flowerGift": { - "name": "Flower Gift", - "description": "Boosts the Attack and Sp. Def stats of itself and allies in harsh sunlight." - }, - "badDreams": { - "name": "Bad Dreams", - "description": "Reduces the HP of sleeping opposing Pokémon." - }, - "pickpocket": { - "name": "Pickpocket", - "description": "Steals an item from an attacker that made direct contact." - }, - "sheerForce": { - "name": "Sheer Force", - "description": "Removes additional effects to increase the power of moves when attacking." - }, - "contrary": { - "name": "Contrary", - "description": "Makes stat changes have an opposite effect." - }, - "unnerve": { - "name": "Unnerve", - "description": "Unnerves opposing Pokémon and makes them unable to eat Berries." - }, - "defiant": { - "name": "Defiant", - "description": "Boosts the Pokémon's Attack stat sharply when its stats are lowered." - }, - "defeatist": { - "name": "Defeatist", - "description": "Halves the Pokémon's Attack and Sp. Atk stats when its HP becomes half or less." - }, - "cursedBody": { - "name": "Cursed Body", - "description": "May disable a move used on the Pokémon." - }, - "healer": { - "name": "Healer", - "description": "Sometimes heals an ally's status condition." - }, - "friendGuard": { - "name": "Friend Guard", - "description": "Reduces damage done to allies." - }, - "weakArmor": { - "name": "Weak Armor", - "description": "Physical attacks to the Pokémon lower its Defense stat but sharply raise its Speed stat." - }, - "heavyMetal": { - "name": "Heavy Metal", - "description": "Doubles the Pokémon's weight." - }, - "lightMetal": { - "name": "Light Metal", - "description": "Halves the Pokémon's weight." - }, - "multiscale": { - "name": "Multiscale", - "description": "Reduces the amount of damage the Pokémon takes while its HP is full." - }, - "toxicBoost": { - "name": "Toxic Boost", - "description": "Powers up physical attacks when the Pokémon is poisoned." - }, - "flareBoost": { - "name": "Flare Boost", - "description": "Powers up special attacks when the Pokémon is burned." - }, - "harvest": { - "name": "Harvest", - "description": "May create another Berry after one is used." - }, - "telepathy": { - "name": "Telepathy", - "description": "Anticipates an ally's attack and dodges it." - }, - "moody": { - "name": "Moody", - "description": "Raises one stat sharply and lowers another every turn." - }, - "overcoat": { - "name": "Overcoat", - "description": "Protects the Pokémon from things like sand, hail, and powder." - }, - "poisonTouch": { - "name": "Poison Touch", - "description": "May poison a target when the Pokémon makes contact." - }, - "regenerator": { - "name": "Regenerator", - "description": "Restores a little HP when withdrawn from battle." - }, - "bigPecks": { - "name": "Big Pecks", - "description": "Protects the Pokémon from Defense-lowering effects." - }, - "sandRush": { - "name": "Sand Rush", - "description": "Boosts the Pokémon's Speed stat in a sandstorm." - }, - "wonderSkin": { - "name": "Wonder Skin", - "description": "Makes status moves more likely to miss." - }, - "analytic": { - "name": "Analytic", - "description": "Boosts move power when the Pokémon moves last." - }, - "illusion": { - "name": "Illusion", - "description": "Comes out disguised as the Pokémon in the party's last spot." - }, - "imposter": { - "name": "Imposter", - "description": "The Pokémon transforms itself into the Pokémon it's facing." - }, - "infiltrator": { - "name": "Infiltrator", - "description": "Passes through the opposing Pokémon's barrier, substitute, and the like and strikes." - }, - "mummy": { - "name": "Mummy", - "description": "Contact with the Pokémon changes the attacker's Ability to Mummy." - }, - "moxie": { - "name": "Moxie", - "description": "The Pokémon shows moxie, and that boosts the Attack stat after knocking out any Pokémon." - }, - "justified": { - "name": "Justified", - "description": "Being hit by a Dark-type move boosts the Attack stat of the Pokémon, for justice." - }, - "rattled": { - "name": "Rattled", - "description": "Intimidate or being hit by a Dark-, Ghost-, or Bug-type move will scare the Pokémon and boost its Speed stat." - }, - "magicBounce": { - "name": "Magic Bounce", - "description": "Reflects status moves instead of getting hit by them." - }, - "sapSipper": { - "name": "Sap Sipper", - "description": "Boosts the Attack stat if hit by a Grass-type move instead of taking damage." - }, - "prankster": { - "name": "Prankster", - "description": "Gives priority to a status move." - }, - "sandForce": { - "name": "Sand Force", - "description": "Boosts the power of Rock-, Ground-, and Steel-type moves in a sandstorm." - }, - "ironBarbs": { - "name": "Iron Barbs", - "description": "Inflicts damage on the attacker upon contact with iron barbs." - }, - "zenMode": { - "name": "Zen Mode", - "description": "Changes the Pokémon's shape when HP is half or less." - }, - "victoryStar": { - "name": "Victory Star", - "description": "Boosts the accuracy of its allies and itself." - }, - "turboblaze": { - "name": "Turboblaze", - "description": "Moves can be used on the target regardless of its Abilities." - }, - "teravolt": { - "name": "Teravolt", - "description": "Moves can be used on the target regardless of its Abilities." - }, - "aromaVeil": { - "name": "Aroma Veil", - "description": "Protects itself and its allies from attacks that limit their move choices." - }, - "flowerVeil": { - "name": "Flower Veil", - "description": "Ally Grass-type Pokémon are protected from status conditions and the lowering of their stats." - }, - "cheekPouch": { - "name": "Cheek Pouch", - "description": "Restores HP as well when the Pokémon eats a Berry." - }, - "protean": { - "name": "Protean", - "description": "Changes the Pokémon's type to the type of the move it's about to use." - }, - "furCoat": { - "name": "Fur Coat", - "description": "Halves the damage from physical moves." - }, - "magician": { - "name": "Magician", - "description": "The Pokémon steals the held item of a Pokémon it hits with a move." - }, - "bulletproof": { - "name": "Bulletproof", - "description": "Protects the Pokémon from some ball and bomb moves." - }, - "competitive": { - "name": "Competitive", - "description": "Boosts the Sp. Atk stat sharply when a stat is lowered." - }, - "strongJaw": { - "name": "Strong Jaw", - "description": "The Pokémon's strong jaw boosts the power of its biting moves." - }, - "refrigerate": { - "name": "Refrigerate", - "description": "Normal-type moves become Ice-type moves. The power of those moves is boosted a little." - }, - "sweetVeil": { - "name": "Sweet Veil", - "description": "Prevents itself and ally Pokémon from falling asleep." - }, - "stanceChange": { - "name": "Stance Change", - "description": "The Pokémon changes its form to Blade Forme when it uses an attack move and changes to Shield Forme when it uses King's Shield." - }, - "galeWings": { - "name": "Gale Wings", - "description": "Gives priority to Flying-type moves when the Pokémon's HP is full." - }, - "megaLauncher": { - "name": "Mega Launcher", - "description": "Powers up aura and pulse moves." - }, - "grassPelt": { - "name": "Grass Pelt", - "description": "Boosts the Pokémon's Defense stat on Grassy Terrain." - }, - "symbiosis": { - "name": "Symbiosis", - "description": "The Pokémon passes its item to an ally that has used up an item." - }, - "toughClaws": { - "name": "Tough Claws", - "description": "Powers up moves that make direct contact." - }, - "pixilate": { - "name": "Pixilate", - "description": "Normal-type moves become Fairy-type moves. The power of those moves is boosted a little." - }, - "gooey": { - "name": "Gooey", - "description": "Contact with the Pokémon lowers the attacker's Speed stat." - }, - "aerilate": { - "name": "Aerilate", - "description": "Normal-type moves become Flying-type moves. The power of those moves is boosted a little." - }, - "parentalBond": { - "name": "Parental Bond", - "description": "Parent and child each attacks." - }, - "darkAura": { - "name": "Dark Aura", - "description": "Powers up each Pokémon's Dark-type moves." - }, - "fairyAura": { - "name": "Fairy Aura", - "description": "Powers up each Pokémon's Fairy-type moves." - }, - "auraBreak": { - "name": "Aura Break", - "description": "The effects of \"Aura\" Abilities are reversed to lower the power of affected moves." - }, - "primordialSea": { - "name": "Primordial Sea", - "description": "The Pokémon changes the weather to nullify Fire-type attacks." - }, - "desolateLand": { - "name": "Desolate Land", - "description": "The Pokémon changes the weather to nullify Water-type attacks." - }, - "deltaStream": { - "name": "Delta Stream", - "description": "The Pokémon changes the weather to eliminate all of the Flying type's weaknesses." - }, - "stamina": { - "name": "Stamina", - "description": "Boosts the Defense stat when hit by an attack." - }, - "wimpOut": { - "name": "Wimp Out", - "description": "The Pokémon cowardly switches out when its HP becomes half or less." - }, - "emergencyExit": { - "name": "Emergency Exit", - "description": "The Pokémon, sensing danger, switches out when its HP becomes half or less." - }, - "waterCompaction": { - "name": "Water Compaction", - "description": "Boosts the Pokémon's Defense stat sharply when hit by a Water-type move." - }, - "merciless": { - "name": "Merciless", - "description": "The Pokémon's attacks become critical hits if the target is poisoned." - }, - "shieldsDown": { - "name": "Shields Down", - "description": "When its HP becomes half or less, the Pokémon's shell breaks and it becomes aggressive." - }, - "stakeout": { - "name": "Stakeout", - "description": "Doubles the damage dealt to the target's replacement if the target switches out." - }, - "waterBubble": { - "name": "Water Bubble", - "description": "Lowers the power of Fire-type moves done to the Pokémon and prevents the Pokémon from getting a burn." - }, - "steelworker": { - "name": "Steelworker", - "description": "Powers up Steel-type moves." - }, - "berserk": { - "name": "Berserk", - "description": "Boosts the Pokémon's Sp. Atk stat when it takes a hit that causes its HP to become half or less." - }, - "slushRush": { - "name": "Slush Rush", - "description": "Boosts the Pokémon's Speed stat in snow." - }, - "longReach": { - "name": "Long Reach", - "description": "The Pokémon uses its moves without making contact with the target." - }, - "liquidVoice": { - "name": "Liquid Voice", - "description": "All sound-based moves become Water-type moves." - }, - "triage": { - "name": "Triage", - "description": "Gives priority to a healing move." - }, - "galvanize": { - "name": "Galvanize", - "description": "Normal-type moves become Electric-type moves. The power of those moves is boosted a little." - }, - "surgeSurfer": { - "name": "Surge Surfer", - "description": "Doubles the Pokémon's Speed stat on Electric Terrain." - }, - "schooling": { - "name": "Schooling", - "description": "When it has a lot of HP, the Pokémon forms a powerful school. It stops schooling when its HP is low." - }, - "disguise": { - "name": "Disguise", - "description": "Once per battle, the shroud that covers the Pokémon can protect it from an attack." - }, - "battleBond": { - "name": "Battle Bond", - "description": "Defeating an opposing Pokémon strengthens the Pokémon's bond with its Trainer, and it becomes Ash-Greninja. Water Shuriken gets more powerful." - }, - "powerConstruct": { - "name": "Power Construct", - "description": "Other Cells gather to aid when its HP becomes half or less. Then the Pokémon changes its form to Complete Forme." - }, - "corrosion": { - "name": "Corrosion", - "description": "The Pokémon can poison the target even if it's a Steel or Poison type." - }, - "comatose": { - "name": "Comatose", - "description": "It's always drowsing and will never wake up. It can attack without waking up." - }, - "queenlyMajesty": { - "name": "Queenly Majesty", - "description": "Its majesty pressures the opposing Pokémon, making it unable to attack using priority moves." - }, - "innardsOut": { - "name": "Innards Out", - "description": "Damages the attacker landing the finishing hit by the amount equal to its last HP." - }, - "dancer": { - "name": "Dancer", - "description": "When another Pokémon uses a dance move, it can use a dance move following it regardless of its Speed." - }, - "battery": { - "name": "Battery", - "description": "Powers up ally Pokémon's special moves." - }, - "fluffy": { - "name": "Fluffy", - "description": "Halves the damage taken from moves that make direct contact, but doubles that of Fire-type moves." - }, - "dazzling": { - "name": "Dazzling", - "description": "Surprises the opposing Pokémon, making it unable to attack using priority moves." - }, - "soulHeart": { - "name": "Soul-Heart", - "description": "Boosts its Sp. Atk stat every time a Pokémon faints." - }, - "tanglingHair": { - "name": "Tangling Hair", - "description": "Contact with the Pokémon lowers the attacker's Speed stat." - }, - "receiver": { - "name": "Receiver", - "description": "The Pokémon copies the Ability of a defeated ally." - }, - "powerOfAlchemy": { - "name": "Power of Alchemy", - "description": "The Pokémon copies the Ability of a defeated ally." - }, - "beastBoost": { - "name": "Beast Boost", - "description": "The Pokémon boosts its most proficient stat each time it knocks out a Pokémon." - }, - "rksSystem": { - "name": "RKS System", - "description": "Changes the Pokémon's type to match the memory disc it holds." - }, - "electricSurge": { - "name": "Electric Surge", - "description": "Turns the ground into Electric Terrain when the Pokémon enters a battle." - }, - "psychicSurge": { - "name": "Psychic Surge", - "description": "Turns the ground into Psychic Terrain when the Pokémon enters a battle." - }, - "mistySurge": { - "name": "Misty Surge", - "description": "Turns the ground into Misty Terrain when the Pokémon enters a battle." - }, - "grassySurge": { - "name": "Grassy Surge", - "description": "Turns the ground into Grassy Terrain when the Pokémon enters a battle." - }, - "fullMetalBody": { - "name": "Full Metal Body", - "description": "Prevents other Pokémon's moves or Abilities from lowering the Pokémon's stats." - }, - "shadowShield": { - "name": "Shadow Shield", - "description": "Reduces the amount of damage the Pokémon takes while its HP is full." - }, - "prismArmor": { - "name": "Prism Armor", - "description": "Reduces the power of supereffective attacks taken." - }, - "neuroforce": { - "name": "Neuroforce", - "description": "Powers up moves that are super effective." - }, - "intrepidSword": { - "name": "Intrepid Sword", - "description": "Boosts the Pokémon's Attack stat when the Pokémon enters a battle." - }, - "dauntlessShield": { - "name": "Dauntless Shield", - "description": "Boosts the Pokémon's Defense stat when the Pokémon enters a battle." - }, - "libero": { - "name": "Libero", - "description": "Changes the Pokémon's type to the type of the move it's about to use." - }, - "ballFetch": { - "name": "Ball Fetch", - "description": "The Pokémon will fetch the Poké Ball from the first failed throw of the battle." - }, - "cottonDown": { - "name": "Cotton Down", - "description": "When the Pokémon is hit by an attack, it scatters cotton fluff around and lowers the Speed stat of all Pokémon except itself." - }, - "propellerTail": { - "name": "Propeller Tail", - "description": "Ignores the effects of opposing Pokémon's Abilities and moves that draw in moves." - }, - "mirrorArmor": { - "name": "Mirror Armor", - "description": "Bounces back only the stat-lowering effects that the Pokémon receives." - }, - "gulpMissile": { - "name": "Gulp Missile", - "description": "When the Pokémon uses Surf or Dive, it will come back with prey. When it takes damage, it will spit out the prey to attack." - }, - "stalwart": { - "name": "Stalwart", - "description": "Ignores the effects of opposing Pokémon's Abilities and moves that draw in moves." - }, - "steamEngine": { - "name": "Steam Engine", - "description": "Boosts the Pokémon's Speed stat drastically if hit by a Fire- or Water-type move." - }, - "punkRock": { - "name": "Punk Rock", - "description": "Boosts the power of sound-based moves. The Pokémon also takes half the damage from these kinds of moves." - }, - "sandSpit": { - "name": "Sand Spit", - "description": "The Pokémon creates a sandstorm when it's hit by an attack." - }, - "iceScales": { - "name": "Ice Scales", - "description": "The Pokémon is protected by ice scales, which halve the damage taken from special moves." - }, - "ripen": { - "name": "Ripen", - "description": "Ripens Berries and doubles their effect." - }, - "iceFace": { - "name": "Ice Face", - "description": "The Pokémon's ice head can take a physical attack as a substitute, but the attack also changes the Pokémon's appearance. The ice will be restored when it hails." - }, - "powerSpot": { - "name": "Power Spot", - "description": "Just being next to the Pokémon powers up moves." - }, - "mimicry": { - "name": "Mimicry", - "description": "Changes the Pokémon's type depending on the terrain." - }, - "screenCleaner": { - "name": "Screen Cleaner", - "description": "When the Pokémon enters a battle, the effects of Light Screen, Reflect, and Aurora Veil are nullified for both opposing and ally Pokémon." - }, - "steelySpirit": { - "name": "Steely Spirit", - "description": "Powers up ally Pokémon's Steel-type moves." - }, - "perishBody": { - "name": "Perish Body", - "description": "When hit by a move that makes direct contact, the Pokémon and the attacker will faint after three turns unless they switch out of battle." - }, - "wanderingSpirit": { - "name": "Wandering Spirit", - "description": "The Pokémon exchanges Abilities with a Pokémon that hits it with a move that makes direct contact." - }, - "gorillaTactics": { - "name": "Gorilla Tactics", - "description": "Boosts the Pokémon's Attack stat but only allows the use of the first selected move." - }, - "neutralizingGas": { - "name": "Neutralizing Gas", - "description": "If the Pokémon with Neutralizing Gas is in the battle, the effects of all Pokémon's Abilities will be nullified or will not be triggered." - }, - "pastelVeil": { - "name": "Pastel Veil", - "description": "Protects the Pokémon and its ally Pokémon from being poisoned." - }, - "hungerSwitch": { - "name": "Hunger Switch", - "description": "The Pokémon changes its form, alternating between its Full Belly Mode and Hangry Mode after the end of each turn." - }, - "quickDraw": { - "name": "Quick Draw", - "description": "Enables the Pokémon to move first occasionally." - }, - "unseenFist": { - "name": "Unseen Fist", - "description": "If the Pokémon uses moves that make direct contact, it can attack the target even if the target protects itself." - }, - "curiousMedicine": { - "name": "Curious Medicine", - "description": "When the Pokémon enters a battle, it scatters medicine from its shell, which removes all stat changes from allies." - }, - "transistor": { - "name": "Transistor", - "description": "Powers up Electric-type moves." - }, - "dragonsMaw": { - "name": "Dragon's Maw", - "description": "Powers up Dragon-type moves." - }, - "chillingNeigh": { - "name": "Chilling Neigh", - "description": "When the Pokémon knocks out a target, it utters a chilling neigh, which boosts its Attack stat." - }, - "grimNeigh": { - "name": "Grim Neigh", - "description": "When the Pokémon knocks out a target, it utters a terrifying neigh, which boosts its Sp. Atk stat." - }, - "asOneGlastrier": { - "name": "As One", - "description": "This Ability combines the effects of both Calyrex's Unnerve Ability and Glastrier's Chilling Neigh Ability." - }, - "asOneSpectrier": { - "name": "As One", - "description": "This Ability combines the effects of both Calyrex's Unnerve Ability and Spectrier's Grim Neigh Ability." - }, - "lingeringAroma": { - "name": "Lingering Aroma", - "description": "Contact with the Pokémon changes the attacker's Ability to Lingering Aroma." - }, - "seedSower": { - "name": "Seed Sower", - "description": "Turns the ground into Grassy Terrain when the Pokémon is hit by an attack." - }, - "thermalExchange": { - "name": "Thermal Exchange", - "description": "Boosts the Attack stat when the Pokémon is hit by a Fire-type move. The Pokémon also cannot be burned." - }, - "angerShell": { - "name": "Anger Shell", - "description": "When an attack causes its HP to drop to half or less, the Pokémon gets angry. This lowers its Defense and Sp. Def stats but boosts its Attack, Sp. Atk, and Speed stats." - }, - "purifyingSalt": { - "name": "Purifying Salt", - "description": "The Pokémon's pure salt protects it from status conditions and halves the damage taken from Ghost-type moves." - }, - "wellBakedBody": { - "name": "Well-Baked Body", - "description": "The Pokémon takes no damage when hit by Fire-type moves. Instead, its Defense stat is sharply boosted." - }, - "windRider": { - "name": "Wind Rider", - "description": "Boosts the Pokémon's Attack stat if Tailwind takes effect or if the Pokémon is hit by a wind move. The Pokémon also takes no damage from wind moves." - }, - "guardDog": { - "name": "Guard Dog", - "description": "Boosts the Pokémon's Attack stat if intimidated. Moves and items that would force the Pokémon to switch out also fail to work." - }, - "rockyPayload": { - "name": "Rocky Payload", - "description": "Powers up Rock-type moves." - }, - "windPower": { - "name": "Wind Power", - "description": "The Pokémon becomes charged when it is hit by a wind move, boosting the power of the next Electric-type move the Pokémon uses." - }, - "zeroToHero": { - "name": "Zero to Hero", - "description": "The Pokémon transforms into its Hero Form when it switches out." - }, - "commander": { - "name": "Commander", - "description": "When the Pokémon enters a battle, it goes inside the mouth of an ally Dondozo if one is on the field. The Pokémon then issues commands from there." - }, - "electromorphosis": { - "name": "Electromorphosis", - "description": "The Pokémon becomes charged when it takes damage, boosting the power of the next Electric-type move the Pokémon uses." - }, - "protosynthesis": { - "name": "Protosynthesis", - "description": "Boosts the Pokémon's most proficient stat in harsh sunlight or if the Pokémon is holding Booster Energy." - }, - "quarkDrive": { - "name": "Quark Drive", - "description": "Boosts the Pokémon's most proficient stat on Electric Terrain or if the Pokémon is holding Booster Energy." - }, - "goodAsGold": { - "name": "Good as Gold", - "description": "A body of pure, solid gold gives the Pokémon full immunity to other Pokémon's status moves." - }, - "vesselOfRuin": { - "name": "Vessel of Ruin", - "description": "The power of the Pokémon's ruinous vessel lowers the Sp. Atk stats of all Pokémon except itself." - }, - "swordOfRuin": { - "name": "Sword of Ruin", - "description": "The power of the Pokémon's ruinous sword lowers the Defense stats of all Pokémon except itself." - }, - "tabletsOfRuin": { - "name": "Tablets of Ruin", - "description": "The power of the Pokémon's ruinous wooden tablets lowers the Attack stats of all Pokémon except itself." - }, - "beadsOfRuin": { - "name": "Beads of Ruin", - "description": "The power of the Pokémon's ruinous beads lowers the Sp. Def stats of all Pokémon except itself." - }, - "orichalcumPulse": { - "name": "Orichalcum Pulse", - "description": "Turns the sunlight harsh when the Pokémon enters a battle. The ancient pulse thrumming through the Pokémon also boosts its Attack stat in harsh sunlight." - }, - "hadronEngine": { - "name": "Hadron Engine", - "description": "Turns the ground into Electric Terrain when the Pokémon enters a battle. The futuristic engine within the Pokémon also boosts its Sp. Atk stat on Electric Terrain." - }, - "opportunist": { - "name": "Opportunist", - "description": "If an opponent's stat is boosted, the Pokémon seizes the opportunity to boost the same stat for itself." - }, - "cudChew": { - "name": "Cud Chew", - "description": "When the Pokémon eats a Berry, it will regurgitate that Berry at the end of the next turn and eat it one more time." - }, - "sharpness": { - "name": "Sharpness", - "description": "Powers up slicing moves." - }, - "supremeOverlord": { - "name": "Supreme Overlord", - "description": "When the Pokémon enters a battle, its Attack and Sp. Atk stats are slightly boosted for each of the allies in its party that have already been defeated." - }, - "costar": { - "name": "Costar", - "description": "When the Pokémon enters a battle, it copies an ally's stat changes." - }, - "toxicDebris": { - "name": "Toxic Debris", - "description": "Scatters poison spikes at the feet of the opposing team when the Pokémon takes damage from physical moves." - }, - "armorTail": { - "name": "Armor Tail", - "description": "The mysterious tail covering the Pokémon's head makes opponents unable to use priority moves against the Pokémon or its allies." - }, - "earthEater": { - "name": "Earth Eater", - "description": "If hit by a Ground-type move, the Pokémon has its HP restored instead of taking damage." - }, - "myceliumMight": { - "name": "Mycelium Might", - "description": "The Pokémon will always act more slowly when using status moves, but these moves will be unimpeded by the Ability of the target." - }, - "mindsEye": { - "name": "Mind's Eye", - "description": "The Pokémon ignores changes to opponents' evasiveness, its accuracy can't be lowered, and it can hit Ghost types with Normal- and Fighting-type moves." - }, - "supersweetSyrup": { - "name": "Supersweet Syrup", - "description": "A sickly sweet scent spreads across the field the first time the Pokémon enters a battle, lowering the evasiveness of opposing Pokémon." - }, - "hospitality": { - "name": "Hospitality", - "description": "When the Pokémon enters a battle, it showers its ally with hospitality, restoring a small amount of the ally's HP." - }, - "toxicChain": { - "name": "Toxic Chain", - "description": "The power of the Pokémon's toxic chain may badly poison any target the Pokémon hits with a move." - }, - "embodyAspectTeal": { - "name": "Embody Aspect", - "description": "The Pokémon's heart fills with memories, causing the Teal Mask to shine and the Pokémon's Speed stat to be boosted." - }, - "embodyAspectWellspring": { - "name": "Embody Aspect", - "description": "The Pokémon's heart fills with memories, causing the Wellspring Mask to shine and the Pokémon's Sp. Def stat to be boosted." - }, - "embodyAspectHearthflame": { - "name": "Embody Aspect", - "description": "The Pokémon's heart fills with memories, causing the Hearthflame Mask to shine and the Pokémon's Attack stat to be boosted." - }, - "embodyAspectCornerstone": { - "name": "Embody Aspect", - "description": "The Pokémon's heart fills with memories, causing the Cornerstone Mask to shine and the Pokémon's Defense stat to be boosted." - }, - "teraShift": { - "name": "Tera Shift", - "description": "When the Pokémon enters a battle, it absorbs the energy around itself and transforms into its Terastal Form." - }, - "teraShell": { - "name": "Tera Shell", - "description": "The Pokémon's shell contains the powers of each type. All damage-dealing moves that hit the Pokémon when its HP is full will not be very effective." - }, - "teraformZero": { - "name": "Teraform Zero", - "description": "When Terapagos changes into its Stellar Form, it uses its hidden powers to eliminate all effects of weather and terrain, reducing them to zero." - }, - "poisonPuppeteer": { - "name": "Poison Puppeteer", - "description": "Pokémon poisoned by Pecharunt's moves will also become confused." - } -} \ No newline at end of file diff --git a/src/locales/en/achv.json b/src/locales/en/achv.json deleted file mode 100644 index 32d519fbf78..00000000000 --- a/src/locales/en/achv.json +++ /dev/null @@ -1,287 +0,0 @@ -{ - "Achievements": { - "name": "Achievements" - }, - "Locked": { - "name": "Locked" - }, - "MoneyAchv": { - "description": "Accumulate a total of ₽{{moneyAmount}}" - }, - "10K_MONEY": { - "name": "Money Haver", - "name_female": "Money Haver" - }, - "100K_MONEY": { - "name": "Rich", - "name_female": "Rich" - }, - "1M_MONEY": { - "name": "Millionaire", - "name_female": "Millionaire" - }, - "10M_MONEY": { - "name": "One Percenter", - "name_female": "One Percenter" - }, - "DamageAchv": { - "description": "Inflict {{damageAmount}} damage in one hit" - }, - "250_DMG": { - "name": "Hard Hitter" - }, - "1000_DMG": { - "name": "Harder Hitter", - "name_female": "Harder Hitter" - }, - "2500_DMG": { - "name": "That's a Lotta Damage!", - "name_female": "That's a Lotta Damage!" - }, - "10000_DMG": { - "name": "One Punch Man", - "name_female": "One Punch Woman" - }, - "HealAchv": { - "description": "Heal {{healAmount}} {{HP}} at once with a move, ability, or held item" - }, - "250_HEAL": { - "name": "Novice Healer", - "name_female": "Novice Healer" - }, - "1000_HEAL": { - "name": "Big Healer", - "name_female": "Big Healer" - }, - "2500_HEAL": { - "name": "Cleric", - "name_female": "Cleric" - }, - "10000_HEAL": { - "name": "Recovery Master", - "name_female": "Recovery Master" - }, - "LevelAchv": { - "description": "Level up a Pokémon to Lv{{level}}" - }, - "LV_100": { - "name": "But Wait, There's More!" - }, - "LV_250": { - "name": "Elite", - "name_female": "Elite" - }, - "LV_1000": { - "name": "To Go Even Further Beyond" - }, - "RibbonAchv": { - "description": "Accumulate a total of {{ribbonAmount}} Ribbons" - }, - "10_RIBBONS": { - "name": "Pokémon League Champion", - "name_female": "Pokémon League Champion" - }, - "25_RIBBONS": { - "name": "Great League Champion", - "name_female": "Great League Champion" - }, - "50_RIBBONS": { - "name": "Ultra League Champion", - "name_female": "Ultra League Champion" - }, - "75_RIBBONS": { - "name": "Rogue League Champion", - "name_female": "Rogue League Champion" - }, - "100_RIBBONS": { - "name": "Master League Champion", - "name_female": "Master League Champion" - }, - "TRANSFER_MAX_STAT_STAGE": { - "name": "Teamwork", - "description": "Baton pass to another party member with at least one stat stage maxed out" - }, - "MAX_FRIENDSHIP": { - "name": "Friendmaxxing", - "description": "Reach max friendship on a Pokémon" - }, - "MEGA_EVOLVE": { - "name": "Megamorph", - "description": "Mega evolve a Pokémon" - }, - "GIGANTAMAX": { - "name": "Absolute Unit", - "description": "Gigantamax a Pokémon" - }, - "TERASTALLIZE": { - "name": "STAB Enthusiast", - "description": "Terastallize a Pokémon" - }, - "STELLAR_TERASTALLIZE": { - "name": "The Hidden Type", - "description": "Stellar Terastallize a Pokémon" - }, - "SPLICE": { - "name": "Infinite Fusion", - "description": "Splice two Pokémon together with DNA Splicers" - }, - "MINI_BLACK_HOLE": { - "name": "A Hole Lot of Items", - "description": "Acquire a Mini Black Hole" - }, - "CATCH_MYTHICAL": { - "name": "Mythical", - "description": "Catch a mythical Pokémon" - }, - "CATCH_SUB_LEGENDARY": { - "name": "(Sub-)Legendary", - "description": "Catch a sub-legendary Pokémon" - }, - "CATCH_LEGENDARY": { - "name": "Legendary", - "description": "Catch a legendary Pokémon" - }, - "SEE_SHINY": { - "name": "Shiny", - "description": "Find a shiny Pokémon in the wild" - }, - "SHINY_PARTY": { - "name": "That's Dedication", - "name_female": "That's Dedication", - "description": "Have a full party of shiny Pokémon" - }, - "HATCH_MYTHICAL": { - "name": "Mythical Egg", - "description": "Hatch a mythical Pokémon from an egg" - }, - "HATCH_SUB_LEGENDARY": { - "name": "Sub-Legendary Egg", - "description": "Hatch a sub-legendary Pokémon from an egg" - }, - "HATCH_LEGENDARY": { - "name": "Legendary Egg", - "description": "Hatch a legendary Pokémon from an egg" - }, - "HATCH_SHINY": { - "name": "Shiny Egg", - "description": "Hatch a shiny Pokémon from an egg" - }, - "HIDDEN_ABILITY": { - "name": "Hidden Potential", - "description": "Catch a Pokémon with a hidden ability" - }, - "PERFECT_IVS": { - "name": "Certificate of Authenticity", - "description": "Get perfect IVs on a Pokémon" - }, - "CLASSIC_VICTORY": { - "name": "Undefeated", - "name_female": "Undefeated", - "description": "Beat the game in classic mode" - }, - "UNEVOLVED_CLASSIC_VICTORY": { - "name": "Bring Your Child To Work Day", - "description": "Beat the game in Classic Mode with at least one unevolved party member." - }, - "MONO_GEN_ONE": { - "name": "The Original Rival", - "description": "Complete the generation one only challenge." - }, - "MONO_GEN_TWO": { - "name": "Generation 1.5", - "description": "Complete the generation two only challenge." - }, - "MONO_GEN_THREE": { - "name": "Too much water?", - "description": "Complete the generation three only challenge." - }, - "MONO_GEN_FOUR": { - "name": "Is she really the hardest?", - "description": "Complete the generation four only challenge." - }, - "MONO_GEN_FIVE": { - "name": "All Original", - "description": "Complete the generation five only challenge." - }, - "MONO_GEN_SIX": { - "name": "Almost Royalty", - "description": "Complete the generation six only challenge." - }, - "MONO_GEN_SEVEN": { - "name": "Only Technically", - "description": "Complete the generation seven only challenge." - }, - "MONO_GEN_EIGHT": { - "name": "A Champion Time!", - "description": "Complete the generation eight only challenge." - }, - "MONO_GEN_NINE": { - "name": "She was going easy on you", - "description": "Complete the generation nine only challenge." - }, - "MonoType": { - "description": "Complete the {{type}} monotype challenge." - }, - "MONO_NORMAL": { - "name": "Extra Ordinary" - }, - "MONO_FIGHTING": { - "name": "I Know Kung Fu" - }, - "MONO_FLYING": { - "name": "Angry Birds" - }, - "MONO_POISON": { - "name": "Kanto's Favourite" - }, - "MONO_GROUND": { - "name": "Forecast: Earthquakes" - }, - "MONO_ROCK": { - "name": "Brock Hard" - }, - "MONO_BUG": { - "name": "You Like Jazz?" - }, - "MONO_GHOST": { - "name": "Who You Gonna Call?" - }, - "MONO_STEEL": { - "name": "Iron Giant" - }, - "MONO_FIRE": { - "name": "I Cast Fireball!" - }, - "MONO_WATER": { - "name": "When It Rains, It Pours" - }, - "MONO_GRASS": { - "name": "Can't Touch This" - }, - "MONO_ELECTRIC": { - "name": "Aim For The Horn!" - }, - "MONO_PSYCHIC": { - "name": "Big Brain Energy" - }, - "MONO_ICE": { - "name": "Walking On Thin Ice" - }, - "MONO_DRAGON": { - "name": "Pseudo-Legend Club" - }, - "MONO_DARK": { - "name": "It's Just A Phase" - }, - "MONO_FAIRY": { - "name": "Hey! Listen!" - }, - "FRESH_START": { - "name": "First Try!", - "description": "Complete the Fresh Start challenge." - }, - "INVERSE_BATTLE": { - "name": "Mirror rorriM", - "description": "Complete the Inverse Battle challenge.\n.egnellahc elttaB esrevnI eht etelpmoC" - } -} diff --git a/src/locales/en/arena-flyout.json b/src/locales/en/arena-flyout.json deleted file mode 100644 index 043d4127eb8..00000000000 --- a/src/locales/en/arena-flyout.json +++ /dev/null @@ -1,44 +0,0 @@ -{ - "activeBattleEffects": "Active Battle Effects", - "player": "Player", - "neutral": "Neutral", - "enemy": "Enemy", - - "sunny": "Sunny", - "rain": "Rain", - "sandstorm": "Sandstorm", - "hail": "Hail", - "snow": "Snow", - "fog": "Fog", - "heavyRain": "Heavy Rain", - "harshSun": "Harsh Sun", - "strongWinds": "Strong Winds", - - "misty": "Misty Terrain", - "electric": "Electric Terrain", - "grassy": "Grassy Terrain", - "psychic": "Psychic Terrain", - - "mudSport": "Mud Sport", - "waterSport": "Water Sport", - "spikes": "Spikes", - "toxicSpikes": "Toxic Spikes", - "mist": "Mist", - "futureSight": "Future Sight", - "doomDesire": "Doom Desire", - "wish": "Wish", - "stealthRock": "Stealth Rock", - "stickyWeb": "Sticky Web", - "trickRoom": "Trick Room", - "gravity": "Gravity", - "reflect": "Reflect", - "lightScreen": "Light Screen", - "auroraVeil": "Aurora Veil", - "quickGuard": "Quick Guard", - "wideGuard": "Wide Guard", - "matBlock": "Mat Block", - "craftyShield": "Crafty Shield", - "tailwind": "Tailwind", - "happyHour": "Happy Hour", - "safeguard": "Safeguard" -} \ No newline at end of file diff --git a/src/locales/en/arena-tag.json b/src/locales/en/arena-tag.json deleted file mode 100644 index d8fed386b24..00000000000 --- a/src/locales/en/arena-tag.json +++ /dev/null @@ -1,57 +0,0 @@ -{ - "yourTeam": "your team", - "opposingTeam": "the opposing team", - "arenaOnRemove": "{{moveName}}'s effect wore off.", - "arenaOnRemovePlayer": "{{moveName}}'s effect wore off\non your side.", - "arenaOnRemoveEnemy": "{{moveName}}'s effect wore off\non the foe's side.", - "mistOnAdd": "{{pokemonNameWithAffix}}'s team became\nshrouded in mist!", - "mistApply": "The mist prevented\nthe lowering of stats!", - "reflectOnAdd": "Reflect reduced the damage of physical moves.", - "reflectOnAddPlayer": "Reflect reduced the damage of physical moves on your side.", - "reflectOnAddEnemy": "Reflect reduced the damage of physical moves on the foe's side.", - "lightScreenOnAdd": "Light Screen reduced the damage of special moves.", - "lightScreenOnAddPlayer": "Light Screen reduced the damage of special moves on your side.", - "lightScreenOnAddEnemy": "Light Screen reduced the damage of special moves on the foe's side.", - "auroraVeilOnAdd": "Aurora Veil reduced the damage of moves.", - "auroraVeilOnAddPlayer": "Aurora Veil reduced the damage of moves on your side.", - "auroraVeilOnAddEnemy": "Aurora Veil reduced the damage of moves on the foe's side.", - "conditionalProtectOnAdd": "{{moveName}} protected team!", - "conditionalProtectOnAddPlayer": "{{moveName}} protected your team!", - "conditionalProtectOnAddEnemy": "{{moveName}} protected the\nopposing team!", - "conditionalProtectApply": "{{moveName}} protected {{pokemonNameWithAffix}}!", - "matBlockOnAdd": "{{pokemonNameWithAffix}} intends to flip up a mat\nand block incoming attacks!", - "noCritOnAddPlayer": "The {{moveName}} shielded your\nteam from critical hits!", - "noCritOnAddEnemy": "The {{moveName}} shielded the opposing\nteam from critical hits!", - "noCritOnRemove": "{{pokemonNameWithAffix}}'s {{moveName}}\nwore off!", - "wishTagOnAdd": "{{pokemonNameWithAffix}}'s wish\ncame true!", - "mudSportOnAdd": "Electricity's power was weakened!", - "mudSportOnRemove": "The effects of Mud Sport\nhave faded.", - "waterSportOnAdd": "Fire's power was weakened!", - "waterSportOnRemove": "The effects of Water Sport\nhave faded.", - "spikesOnAdd": "{{moveName}} were scattered\nall around {{opponentDesc}}'s feet!", - "spikesActivateTrap": "{{pokemonNameWithAffix}} is hurt\nby the spikes!", - "toxicSpikesOnAdd": "{{moveName}} were scattered\nall around {{opponentDesc}}'s feet!", - "toxicSpikesActivateTrapPoison": "{{pokemonNameWithAffix}} absorbed the {{moveName}}!", - "stealthRockOnAdd": "Pointed stones float in the air\naround {{opponentDesc}}!", - "stealthRockActivateTrap": "Pointed stones dug into\n{{pokemonNameWithAffix}}!", - "stickyWebOnAdd": "A {{moveName}} has been laid out on the ground around the opposing team!", - "stickyWebActivateTrap": "The opposing {{pokemonName}} was caught in a sticky web!", - "trickRoomOnAdd": "{{pokemonNameWithAffix}} twisted\nthe dimensions!", - "trickRoomOnRemove": "The twisted dimensions\nreturned to normal!", - "gravityOnAdd": "Gravity intensified!", - "gravityOnRemove": "Gravity returned to normal!", - "tailwindOnAdd": "The Tailwind blew from behind team!", - "tailwindOnAddPlayer": "The Tailwind blew from behind\nyour team!", - "tailwindOnAddEnemy": "The Tailwind blew from behind\nthe opposing team!", - "tailwindOnRemove": "Team's Tailwind petered out!", - "tailwindOnRemovePlayer": "Your team's Tailwind petered out!", - "tailwindOnRemoveEnemy": "The opposing team's Tailwind petered out!", - "happyHourOnAdd": "Everyone is caught up in the happy atmosphere!", - "happyHourOnRemove": "The atmosphere returned to normal.", - "safeguardOnAdd": "The whole field is cloaked in a mystical veil!", - "safeguardOnAddPlayer": "Your team cloaked itself in a mystical veil!", - "safeguardOnAddEnemy": "The opposing team cloaked itself in a mystical veil!", - "safeguardOnRemove": "The field is no longer protected by Safeguard!", - "safeguardOnRemovePlayer": "Your team is no longer protected by Safeguard!", - "safeguardOnRemoveEnemy": "The opposing team is no longer protected by Safeguard!" -} \ No newline at end of file diff --git a/src/locales/en/battle-info.json b/src/locales/en/battle-info.json deleted file mode 100644 index 2c9e87cb1b8..00000000000 --- a/src/locales/en/battle-info.json +++ /dev/null @@ -1,3 +0,0 @@ - { - "generation": "Generation {{generation}}" - } \ No newline at end of file diff --git a/src/locales/en/battle-message-ui-handler.json b/src/locales/en/battle-message-ui-handler.json deleted file mode 100644 index 0b2e0ba8b13..00000000000 --- a/src/locales/en/battle-message-ui-handler.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "ivBest": "Best", - "ivFantastic": "Fantastic", - "ivVeryGood": "Very Good", - "ivPrettyGood": "Pretty Good", - "ivDecent": "Decent", - "ivNoGood": "No Good" -} \ No newline at end of file diff --git a/src/locales/en/battle-scene.json b/src/locales/en/battle-scene.json deleted file mode 100644 index a0288475d69..00000000000 --- a/src/locales/en/battle-scene.json +++ /dev/null @@ -1,3 +0,0 @@ -{ - "moneyOwned": "₽{{formattedMoney}}" -} \ No newline at end of file diff --git a/src/locales/en/battle.json b/src/locales/en/battle.json deleted file mode 100644 index d04dd3eac1f..00000000000 --- a/src/locales/en/battle.json +++ /dev/null @@ -1,109 +0,0 @@ -{ - "bossAppeared": "{{bossName}} appeared.", - "trainerAppeared": "{{trainerName}}\nwould like to battle!", - "trainerAppearedDouble": "{{trainerName}}\nwould like to battle!", - "trainerSendOut": "{{trainerName}} sent out\n{{pokemonName}}!", - "singleWildAppeared": "A wild {{pokemonName}} appeared!", - "multiWildAppeared": "A wild {{pokemonName1}}\nand {{pokemonName2}} appeared!", - "playerComeBack": "Come back, {{pokemonName}}!", - "trainerComeBack": "{{trainerName}} withdrew {{pokemonName}}!", - "playerGo": "Go! {{pokemonName}}!", - "trainerGo": "{{trainerName}} sent out {{pokemonName}}!", - "switchQuestion": "Will you switch\n{{pokemonName}}?", - "trainerDefeated": "You defeated\n{{trainerName}}!", - "moneyWon": "You got\n₽{{moneyAmount}} for winning!", - "moneyPickedUp": "You picked up ₽{{moneyAmount}}!", - "pokemonCaught": "{{pokemonName}} was caught!", - "pokemonObtained": "You got {{pokemonName}}!", - "pokemonBrokeFree": "Oh no!\nThe Pokémon broke free!", - "pokemonFled": "The wild {{pokemonName}} fled!", - "playerFled": "You fled from the {{pokemonName}}!", - "addedAsAStarter": "{{pokemonName}} has been\nadded as a starter!", - "partyFull": "Your party is full.\nRelease a Pokémon to make room for {{pokemonName}}?", - "pokemon": "Pokémon", - "sendOutPokemon": "Go! {{pokemonName}}!", - "hitResultCriticalHit": "A critical hit!", - "hitResultSuperEffective": "It's super effective!", - "hitResultNotVeryEffective": "It's not very effective…", - "hitResultNoEffect": "It doesn't affect {{pokemonName}}!", - "hitResultImmune": "{{pokemonName}} is unaffected!", - "hitResultOneHitKO": "It's a one-hit KO!", - "attackFailed": "But it failed!", - "attackMissed": "{{pokemonNameWithAffix}} avoided the attack!", - "attackHitsCount": "Hit {{count}} time(s)!", - "rewardGain": "You received\n{{modifierName}}!", - "expGain": "{{pokemonName}} gained\n{{exp}} EXP. Points!", - "levelUp": "{{pokemonName}} grew to\nLv. {{level}}!", - "learnMove": "{{pokemonName}} learned\n{{moveName}}!", - "learnMovePrompt": "{{pokemonName}} wants to learn the\nmove {{moveName}}.", - "learnMoveLimitReached": "However, {{pokemonName}} already\nknows four moves.", - "learnMoveReplaceQuestion": "Should a move be forgotten and\nreplaced with {{moveName}}?", - "learnMoveStopTeaching": "Stop trying to teach\n{{moveName}}?", - "learnMoveNotLearned": "{{pokemonName}} did not learn the\nmove {{moveName}}.", - "learnMoveForgetQuestion": "Which move should be forgotten?", - "learnMoveForgetSuccess": "{{pokemonName}} forgot how to\nuse {{moveName}}.", - "countdownPoof": "@d{32}1, @d{15}2, and@d{15}… @d{15}… @d{15}… @d{15}@s{se/pb_bounce_1}Poof!", - "learnMoveAnd": "And…", - "levelCapUp": "The level cap\nhas increased to {{levelCap}}!", - "moveNotImplemented": "{{moveName}} is not yet implemented and cannot be selected.", - "moveNoPP": "There's no PP left for\nthis move!", - "moveDisabled": "{{moveName}} is disabled!", - "canOnlyUseMove": "{{pokemonName}} can only use {{moveName}}!", - "moveCannotBeSelected": "{{moveName}} cannot be selected!", - "disableInterruptedMove": "{{pokemonNameWithAffix}}'s {{moveName}}\nis disabled!", - "throatChopInterruptedMove": "The effects of Throat Chop prevent\n{{pokemonName}} from using certain moves!", - "noPokeballForce": "An unseen force\nprevents using Poké Balls.", - "noPokeballTrainer": "You can't catch\nanother trainer's Pokémon!", - "noPokeballMulti": "You can only throw a Poké Ball\nwhen there is one Pokémon remaining!", - "noPokeballStrong": "The target Pokémon is too strong to be caught!\nYou need to weaken it first!", - "noPokeballMysteryEncounter": "You aren't able to\ncatch this Pokémon!", - "noEscapeForce": "An unseen force\nprevents escape.", - "noEscapeTrainer": "You can't run\nfrom a trainer battle!", - "noEscapePokemon": "{{pokemonName}}'s {{moveName}}\nprevents {{escapeVerb}}!", - "runAwaySuccess": "You got away safely!", - "runAwayCannotEscape": "You can't escape!", - "escapeVerbSwitch": "switching", - "escapeVerbFlee": "fleeing", - "notDisabled": "{{pokemonName}}'s {{moveName}} is disabled\nno more!", - "turnEndHpRestore": "{{pokemonName}}'s HP was restored.", - "hpIsFull": "{{pokemonName}}'s\nHP is full!", - "skipItemQuestion": "Are you sure you want to skip taking an item?", - "itemStackFull": "The stack for {{fullItemName}} is full.\nYou will receive {{itemName}} instead.", - "eggHatching": "Oh?", - "eggSkipPrompt": "Skip to egg summary?", - "ivScannerUseQuestion": "Use IV Scanner on {{pokemonName}}?", - "wildPokemonWithAffix": "Wild {{pokemonName}}", - "foePokemonWithAffix": "Foe {{pokemonName}}", - "useMove": "{{pokemonNameWithAffix}} used {{moveName}}!", - "drainMessage": "{{pokemonName}} had its\nenergy drained!", - "regainHealth": "{{pokemonName}} regained\nhealth!", - "stealEatBerry": "{{pokemonName}} stole and ate\n{{targetName}}'s {{berryName}}!", - "ppHealBerry": "{{pokemonNameWithAffix}} restored PP to its move {{moveName}}\nusing its {{berryName}}!", - "hpHealBerry": "{{pokemonNameWithAffix}} restored its health using\nits {{berryName}}!", - "fainted": "{{pokemonNameWithAffix}} fainted!", - "statsAnd": "and", - "stats": "Stats", - "statRose_one": "{{pokemonNameWithAffix}}'s {{stats}} rose!", - "statRose_other": "{{pokemonNameWithAffix}}'s {{stats}} rose!", - "statSharplyRose_one": "{{pokemonNameWithAffix}}'s {{stats}} sharply rose!", - "statSharplyRose_other": "{{pokemonNameWithAffix}}'s {{stats}} sharply rose!", - "statRoseDrastically_one": "{{pokemonNameWithAffix}}'s {{stats}} rose drastically!", - "statRoseDrastically_other": "{{pokemonNameWithAffix}}'s {{stats}} rose drastically!", - "statWontGoAnyHigher_one": "{{pokemonNameWithAffix}}'s {{stats}} won't go any higher!", - "statWontGoAnyHigher_other": "{{pokemonNameWithAffix}}'s {{stats}} won't go any higher!", - "statFell_one": "{{pokemonNameWithAffix}}'s {{stats}} fell!", - "statFell_other": "{{pokemonNameWithAffix}}'s {{stats}} fell!", - "statHarshlyFell_one": "{{pokemonNameWithAffix}}'s {{stats}} harshly fell!", - "statHarshlyFell_other": "{{pokemonNameWithAffix}}'s {{stats}} harshly fell!", - "statSeverelyFell_one": "{{pokemonNameWithAffix}}'s {{stats}} severely fell!", - "statSeverelyFell_other": "{{pokemonNameWithAffix}}'s {{stats}} severely fell!", - "statWontGoAnyLower_one": "{{pokemonNameWithAffix}}'s {{stats}} won't go any lower!", - "statWontGoAnyLower_other": "{{pokemonNameWithAffix}}'s {{stats}} won't go any lower!", - "transformedIntoType": "{{pokemonName}} transformed\ninto the {{type}} type!", - "retryBattle": "Would you like to retry from the start of the battle?", - "unlockedSomething": "{{unlockedThing}}\nhas been unlocked.", - "congratulations": "Congratulations!", - "beatModeFirstTime": "{{speciesName}} beat {{gameMode}} Mode for the first time!\nYou received {{newModifier}}!", - "ppReduced": "It reduced the PP of {{targetName}}'s\n{{moveName}} by {{reduction}}!", - "mysteryEncounterAppeared": "What's this?" -} \ No newline at end of file diff --git a/src/locales/en/battler-tags.json b/src/locales/en/battler-tags.json deleted file mode 100644 index b31826b0244..00000000000 --- a/src/locales/en/battler-tags.json +++ /dev/null @@ -1,77 +0,0 @@ -{ - "trappedDesc": "trapping", - "flinchedDesc": "flinching", - "confusedDesc": "confusion", - "infatuatedDesc": "infatuation", - "seedDesc": "seeding", - "nightmareDesc": "nightmares", - "ingrainDesc": "roots", - "drowsyDesc": "drowsiness", - "rechargingLapse": "{{pokemonNameWithAffix}} must\nrecharge!", - "trappedOnAdd": "{{pokemonNameWithAffix}} can no\nlonger escape!", - "trappedOnRemove": "{{pokemonNameWithAffix}} was freed\nfrom {{moveName}}!", - "flinchedLapse": "{{pokemonNameWithAffix}} flinched!", - "confusedOnAdd": "{{pokemonNameWithAffix}} became\nconfused!", - "confusedOnRemove": "{{pokemonNameWithAffix}} snapped\nout of confusion!", - "confusedOnOverlap": "{{pokemonNameWithAffix}} is\nalready confused!", - "confusedLapse": "{{pokemonNameWithAffix}} is\nconfused!", - "confusedLapseHurtItself": "It hurt itself in its\nconfusion!", - "destinyBondLapseIsBoss": "{{pokemonNameWithAffix}} is unaffected\nby the effects of Destiny Bond.", - "destinyBondLapse": "{{pokemonNameWithAffix}} took\n{{pokemonNameWithAffix2}} down with it!", - "infatuatedOnAdd": "{{pokemonNameWithAffix}} fell in love\nwith {{sourcePokemonName}}!", - "infatuatedOnOverlap": "{{pokemonNameWithAffix}} is\nalready in love!", - "infatuatedLapse": "{{pokemonNameWithAffix}} is in love\nwith {{sourcePokemonName}}!", - "infatuatedLapseImmobilize": "{{pokemonNameWithAffix}} is\nimmobilized by love!", - "infatuatedOnRemove": "{{pokemonNameWithAffix}} got over\nits infatuation.", - "seededOnAdd": "{{pokemonNameWithAffix}} was seeded!", - "seededLapse": "{{pokemonNameWithAffix}}'s health is\nsapped by Leech Seed!", - "seededLapseShed": "{{pokemonNameWithAffix}}'s Leech Seed\nsucked up the liquid ooze!", - "nightmareOnAdd": "{{pokemonNameWithAffix}} began\nhaving a Nightmare!", - "nightmareOnOverlap": "{{pokemonNameWithAffix}} is\nalready locked in a Nightmare!", - "nightmareLapse": "{{pokemonNameWithAffix}} is locked\nin a Nightmare!", - "encoreOnAdd": "{{pokemonNameWithAffix}} got\nan Encore!", - "encoreOnRemove": "{{pokemonNameWithAffix}}'s Encore\nended!", - "helpingHandOnAdd": "{{pokemonNameWithAffix}} is ready to\nhelp {{pokemonName}}!", - "ingrainLapse": "{{pokemonNameWithAffix}} absorbed\nnutrients with its roots!", - "ingrainOnTrap": "{{pokemonNameWithAffix}} planted its roots!", - "aquaRingOnAdd": "{{pokemonNameWithAffix}} surrounded\nitself with a veil of water!", - "aquaRingLapse": "{{moveName}} restored\n{{pokemonName}}'s HP!", - "drowsyOnAdd": "{{pokemonNameWithAffix}} grew drowsy!", - "damagingTrapLapse": "{{pokemonNameWithAffix}} is hurt\nby {{moveName}}!", - "bindOnTrap": "{{pokemonNameWithAffix}} was squeezed by\n{{sourcePokemonName}}'s {{moveName}}!", - "wrapOnTrap": "{{pokemonNameWithAffix}} was Wrapped\nby {{sourcePokemonName}}!", - "vortexOnTrap": "{{pokemonNameWithAffix}} was trapped\nin the vortex!", - "clampOnTrap": "{{sourcePokemonNameWithAffix}} Clamped\n{{pokemonName}}!", - "sandTombOnTrap": "{{pokemonNameWithAffix}} became trapped\nby {{moveName}}!", - "magmaStormOnTrap": "{{pokemonNameWithAffix}} became trapped\nby swirling magma!", - "snapTrapOnTrap": "{{pokemonNameWithAffix}} got trapped\nby a snap trap!", - "thunderCageOnTrap": "{{sourcePokemonNameWithAffix}} trapped\n{{pokemonNameWithAffix}}!", - "infestationOnTrap": "{{pokemonNameWithAffix}} has been afflicted \nwith an infestation by {{sourcePokemonNameWithAffix}}!", - "protectedOnAdd": "{{pokemonNameWithAffix}}\nprotected itself!", - "protectedLapse": "{{pokemonNameWithAffix}}\nprotected itself!", - "enduringOnAdd": "{{pokemonNameWithAffix}} braced\nitself!", - "enduringLapse": "{{pokemonNameWithAffix}} endured\nthe hit!", - "sturdyLapse": "{{pokemonNameWithAffix}} endured\nthe hit!", - "perishSongLapse": "{{pokemonNameWithAffix}}'s perish count fell to {{turnCount}}.", - "centerOfAttentionOnAdd": "{{pokemonNameWithAffix}} became the center\nof attention!", - "truantLapse": "{{pokemonNameWithAffix}} is\nloafing around!", - "slowStartOnAdd": "{{pokemonNameWithAffix}} can't\nget it going!", - "slowStartOnRemove": "{{pokemonNameWithAffix}} finally\ngot its act together!", - "highestStatBoostOnAdd": "{{pokemonNameWithAffix}}'s {{statName}}\nwas heightened!", - "highestStatBoostOnRemove": "The effects of {{pokemonNameWithAffix}}'s\n{{abilityName}} wore off!", - "magnetRisenOnAdd": "{{pokemonNameWithAffix}} levitated with electromagnetism!", - "magnetRisenOnRemove": "{{pokemonNameWithAffix}}'s electromagnetism wore off!", - "critBoostOnAdd": "{{pokemonNameWithAffix}} is getting\npumped!", - "critBoostOnRemove": "{{pokemonNameWithAffix}} relaxed.", - "saltCuredOnAdd": "{{pokemonNameWithAffix}} is being salt cured!", - "saltCuredLapse": "{{pokemonNameWithAffix}} is hurt by {{moveName}}!", - "cursedOnAdd": "{{pokemonNameWithAffix}} cut its own HP and put a curse on the {{pokemonName}}!", - "cursedLapse": "{{pokemonNameWithAffix}} is afflicted by the Curse!", - "stockpilingOnAdd": "{{pokemonNameWithAffix}} stockpiled {{stockpiledCount}}!", - "disabledOnAdd": "{{pokemonNameWithAffix}}'s {{moveName}}\nwas disabled!", - "disabledLapse": "{{pokemonNameWithAffix}}'s {{moveName}}\nis no longer disabled.", - "tarShotOnAdd": "{{pokemonNameWithAffix}} became weaker to fire!", - "substituteOnAdd": "{{pokemonNameWithAffix}} put in a substitute!", - "substituteOnHit": "The substitute took damage for {{pokemonNameWithAffix}}!", - "substituteOnRemove": "{{pokemonNameWithAffix}}'s substitute faded!" -} diff --git a/src/locales/en/berry.json b/src/locales/en/berry.json deleted file mode 100644 index a4bec889877..00000000000 --- a/src/locales/en/berry.json +++ /dev/null @@ -1,46 +0,0 @@ -{ - "SITRUS": { - "name": "Sitrus Berry", - "effect": "Restores 25% HP if HP is below 50%" - }, - "LUM": { - "name": "Lum Berry", - "effect": "Cures any non-volatile status condition and confusion" - }, - "ENIGMA": { - "name": "Enigma Berry", - "effect": "Restores 25% HP if hit by a super effective move" - }, - "LIECHI": { - "name": "Liechi Berry", - "effect": "Raises Attack if HP is below 25%" - }, - "GANLON": { - "name": "Ganlon Berry", - "effect": "Raises Defense if HP is below 25%" - }, - "PETAYA": { - "name": "Petaya Berry", - "effect": "Raises Sp. Atk if HP is below 25%" - }, - "APICOT": { - "name": "Apicot Berry", - "effect": "Raises Sp. Def if HP is below 25%" - }, - "SALAC": { - "name": "Salac Berry", - "effect": "Raises Speed if HP is below 25%" - }, - "LANSAT": { - "name": "Lansat Berry", - "effect": "Raises critical hit ratio if HP is below 25%" - }, - "STARF": { - "name": "Starf Berry", - "effect": "Sharply raises a random stat if HP is below 25%" - }, - "LEPPA": { - "name": "Leppa Berry", - "effect": "Restores 10 PP to a move if its PP reaches 0" - } -} \ No newline at end of file diff --git a/src/locales/en/bgm-name.json b/src/locales/en/bgm-name.json deleted file mode 100644 index e13f580def6..00000000000 --- a/src/locales/en/bgm-name.json +++ /dev/null @@ -1,155 +0,0 @@ -{ - "music": "Music: ", - "missing_entries": "{{name}}", - "battle_kanto_champion": "B2W2 Kanto Champion Battle", - "battle_johto_champion": "B2W2 Johto Champion Battle", - "battle_hoenn_champion_g5": "B2W2 Hoenn Champion Battle", - "battle_hoenn_champion_g6": "ORAS Hoenn Champion Battle", - "battle_sinnoh_champion": "B2W2 Sinnoh Champion Battle", - "battle_champion_alder": "BW Unova Champion Battle", - "battle_champion_iris": "B2W2 Unova Champion Battle", - "battle_kalos_champion": "XY Kalos Champion Battle", - "battle_alola_champion": "USUM Alola Champion Battle", - "battle_galar_champion": "SWSH Galar Champion Battle", - "battle_champion_geeta": "SV Champion Geeta Battle", - "battle_champion_nemona": "SV Champion Nemona Battle", - "battle_champion_kieran": "SV Champion Kieran Battle", - "battle_hoenn_elite": "ORAS Elite Four Battle", - "battle_unova_elite": "BW Elite Four Battle", - "battle_kalos_elite": "XY Elite Four Battle", - "battle_alola_elite": "SM Elite Four Battle", - "battle_galar_elite": "SWSH League Tournament Battle", - "battle_paldea_elite": "SV Elite Four Battle", - "battle_bb_elite": "SV BB League Elite Four Battle", - "battle_final_encounter": "PMD RTDX Rayquaza's Domain", - "battle_final": "BW Ghetsis Battle", - "battle_kanto_gym": "B2W2 Kanto Gym Battle", - "battle_johto_gym": "B2W2 Johto Gym Battle", - "battle_hoenn_gym": "B2W2 Hoenn Gym Battle", - "battle_sinnoh_gym": "B2W2 Sinnoh Gym Battle", - "battle_unova_gym": "BW Unova Gym Battle", - "battle_kalos_gym": "XY Kalos Gym Battle", - "battle_galar_gym": "SWSH Galar Gym Battle", - "battle_paldea_gym": "SV Paldea Gym Battle", - "battle_legendary_kanto": "XY Kanto Legendary Battle", - "battle_legendary_raikou": "HGSS Raikou Battle", - "battle_legendary_entei": "HGSS Entei Battle", - "battle_legendary_suicune": "HGSS Suicune Battle", - "battle_legendary_lugia": "HGSS Lugia Battle", - "battle_legendary_ho_oh": "HGSS Ho-oh Battle", - "battle_legendary_regis_g5": "B2W2 Legendary Titan Battle", - "battle_legendary_regis_g6": "ORAS Legendary Titan Battle", - "battle_legendary_gro_kyo": "ORAS Groudon & Kyogre Battle", - "battle_legendary_rayquaza": "ORAS Rayquaza Battle", - "battle_legendary_deoxys": "ORAS Deoxys Battle", - "battle_legendary_lake_trio": "ORAS Lake Guardians Battle", - "battle_legendary_sinnoh": "ORAS Sinnoh Legendary Battle", - "battle_legendary_dia_pal": "ORAS Dialga & Palkia Battle", - "battle_legendary_origin_forme": "LA Origin Dialga & Palkia Battle", - "battle_legendary_giratina": "ORAS Giratina Battle", - "battle_legendary_arceus": "HGSS Arceus Battle", - "battle_legendary_unova": "BW Unova Legendary Battle", - "battle_legendary_kyurem": "BW Kyurem Battle", - "battle_legendary_res_zek": "BW Reshiram & Zekrom Battle", - "battle_legendary_xern_yvel": "XY Xerneas & Yveltal Battle", - "battle_legendary_tapu": "SM Tapu Battle", - "battle_legendary_sol_lun": "SM Solgaleo & Lunala Battle", - "battle_legendary_ub": "SM Ultra Beast Battle", - "battle_legendary_dusk_dawn": "USUM Dusk Mane & Dawn Wings Necrozma Battle", - "battle_legendary_ultra_nec": "USUM Ultra Necrozma Battle", - "battle_legendary_zac_zam": "SWSH Zacian & Zamazenta Battle", - "battle_legendary_glas_spec": "SWSH Glastrier & Spectrier Battle", - "battle_legendary_calyrex": "SWSH Calyrex Battle", - "battle_legendary_riders": "SWSH Ice & Shadow Rider Calyrex Battle", - "battle_legendary_birds_galar": "SWSH Galarian Legendary Birds Battle", - "battle_legendary_ruinous": "SV Treasures of Ruin Battle", - "battle_legendary_kor_mir": "SV Depths of Area Zero Battle", - "battle_legendary_loyal_three": "SV Loyal Three Battle", - "battle_legendary_ogerpon": "SV Ogerpon Battle", - "battle_legendary_terapagos": "SV Terapagos Battle", - "battle_legendary_pecharunt": "SV Pecharunt Battle", - "battle_rival": "BW Rival Battle", - "battle_rival_2": "BW N Battle", - "battle_rival_3": "BW Final N Battle", - "battle_trainer": "BW Trainer Battle", - "battle_wild": "BW Wild Battle", - "battle_wild_strong": "BW Strong Wild Battle", - "end_summit": "PMD RTDX Sky Tower Summit", - "battle_rocket_grunt": "HGSS Team Rocket Battle", - "battle_aqua_magma_grunt": "ORAS Team Aqua & Magma Battle", - "battle_galactic_grunt": "BDSP Team Galactic Battle", - "battle_plasma_grunt": "BW Team Plasma Battle", - "battle_flare_grunt": "XY Team Flare Battle", - "battle_aether_grunt": "SM Aether Foundation Battle", - "battle_skull_grunt": "SM Team Skull Battle", - "battle_macro_grunt": "SWSH Trainer Battle", - "battle_galactic_admin": "BDSP Team Galactic Admin Battle", - "battle_skull_admin": "SM Team Skull Admin Battle", - "battle_oleana": "SWSH Oleana Battle", - "battle_rocket_boss": "USUM Giovanni Battle", - "battle_aqua_magma_boss": "ORAS Archie & Maxie Battle", - "battle_galactic_boss": "BDSP Cyrus Battle", - "battle_plasma_boss": "B2W2 Ghetsis Battle", - "battle_flare_boss": "XY Lysandre Battle", - "battle_aether_boss": "SM Lusamine Battle", - "battle_skull_boss": "SM Guzma Battle", - "battle_macro_boss": "SWSH Rose Battle", - - "abyss": "PMD EoS Dark Crater", - "badlands": "PMD EoS Barren Valley", - "beach": "PMD EoS Drenched Bluff", - "cave": "PMD EoS Sky Peak Cave", - "construction_site": "PMD EoS Boulder Quarry", - "desert": "PMD EoS Northern Desert", - "dojo": "PMD EoS Marowak Dojo", - "end": "PMD RTDX Sky Tower", - "factory": "PMD EoS Concealed Ruins", - "fairy_cave": "PMD EoS Star Cave", - "forest": "PMD EoS Dusk Forest", - "grass": "PMD EoS Apple Woods", - "graveyard": "PMD EoS Mystifying Forest", - "ice_cave": "Firel - -60F", - "island": "PMD EoS Craggy Coast", - "jungle": "Lmz - Jungle", - "laboratory": "Firel - Laboratory", - "lake": "PMD EoS Crystal Cave", - "meadow": "PMD EoS Sky Peak Forest", - "metropolis": "Firel - Metropolis", - "mountain": "PMD EoS Mt. Horn", - "plains": "Firel - Route 888", - "power_plant": "Firel - The Klink", - "ruins": "PMD EoS Deep Sealed Ruin", - "sea": "Andr06 - Marine Mystique", - "seabed": "Firel - Seabed", - "slum": "Andr06 - Sneaky Snom", - "snowy_forest": "PMD EoS Sky Peak Snowfield", - "space": "Firel - Aether", - "swamp": "PMD EoS Surrounded Sea", - "tall_grass": "PMD EoS Foggy Forest", - "temple": "PMD EoS Aegis Cave", - "town": "PMD EoS Random Dungeon Theme 3", - "volcano": "Firel - Twisturn Volcano", - "wasteland": "PMD EoS Hidden Highland", - "encounter_ace_trainer": "BW Trainers' Eyes Meet (Ace Trainer)", - "encounter_backpacker": "BW Trainers' Eyes Meet (Backpacker)", - "encounter_clerk": "BW Trainers' Eyes Meet (Clerk)", - "encounter_cyclist": "BW Trainers' Eyes Meet (Cyclist)", - "encounter_lass": "BW Trainers' Eyes Meet (Lass)", - "encounter_parasol_lady": "BW Trainers' Eyes Meet (Parasol Lady)", - "encounter_pokefan": "BW Trainers' Eyes Meet (Poke Fan)", - "encounter_psychic": "BW Trainers' Eyes Meet (Psychic)", - "encounter_rich": "BW Trainers' Eyes Meet (Gentleman)", - "encounter_rival": "BW Cheren", - "encounter_roughneck": "BW Trainers' Eyes Meet (Roughneck)", - "encounter_scientist": "BW Trainers' Eyes Meet (Scientist)", - "encounter_twins": "BW Trainers' Eyes Meet (Twins)", - "encounter_youngster": "BW Trainers' Eyes Meet (Youngster)", - "heal": "BW Pokémon Heal", - "menu": "PMD EoS Welcome to the World of Pokémon!", - "title": "PMD EoS Top Menu Theme", - - "mystery_encounter_weird_dream": "PMD EoS Temporal Spire", - "mystery_encounter_fun_and_games": "PMD EoS Guildmaster Wigglytuff", - "mystery_encounter_gen_5_gts": "BW GTS", - "mystery_encounter_gen_6_gts": "XY GTS" -} diff --git a/src/locales/en/biome.json b/src/locales/en/biome.json deleted file mode 100644 index 6d79382cf3e..00000000000 --- a/src/locales/en/biome.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "unknownLocation": "Somewhere you can't remember", - "TOWN": "Town", - "PLAINS": "Plains", - "GRASS": "Grassy Field", - "TALL_GRASS": "Tall Grass", - "METROPOLIS": "Metropolis", - "FOREST": "Forest", - "SEA": "Sea", - "SWAMP": "Swamp", - "BEACH": "Beach", - "LAKE": "Lake", - "SEABED": "Seabed", - "MOUNTAIN": "Mountain", - "BADLANDS": "Badlands", - "CAVE": "Cave", - "DESERT": "Desert", - "ICE_CAVE": "Ice Cave", - "MEADOW": "Meadow", - "POWER_PLANT": "Power Plant", - "VOLCANO": "Volcano", - "GRAVEYARD": "Graveyard", - "DOJO": "Dojo", - "FACTORY": "Factory", - "RUINS": "Ancient Ruins", - "WASTELAND": "Wasteland", - "ABYSS": "Abyss", - "SPACE": "Space", - "CONSTRUCTION_SITE": "Construction Site", - "JUNGLE": "Jungle", - "FAIRY_CAVE": "Fairy Cave", - "TEMPLE": "Temple", - "SLUM": "Slum", - "SNOWY_FOREST": "Snowy Forest", - "ISLAND": "Island", - "LABORATORY": "Laboratory", - "END": "???" -} \ No newline at end of file diff --git a/src/locales/en/challenges.json b/src/locales/en/challenges.json deleted file mode 100644 index 7792755d626..00000000000 --- a/src/locales/en/challenges.json +++ /dev/null @@ -1,37 +0,0 @@ -{ - "title": "Challenge Modifiers", - "illegalEvolution": "{{pokemon}} changed into an ineligible Pokémon\nfor this challenge!", - "noneSelected": "None Selected", - "singleGeneration": { - "name": "Mono Gen", - "desc": "You can only use Pokémon from Generation {{gen}}.", - "desc_default": "You can only use Pokémon from the chosen generation.", - "gen_1": "one", - "gen_2": "two", - "gen_3": "three", - "gen_4": "four", - "gen_5": "five", - "gen_6": "six", - "gen_7": "seven", - "gen_8": "eight", - "gen_9": "nine" - }, - "singleType": { - "name": "Mono Type", - "desc": "You can only use Pokémon with the {{type}} type.", - "desc_default": "You can only use Pokémon of the chosen type." - }, - "freshStart": { - "name": "Fresh Start", - "desc": "You can only use the original starters, and only as if you had just started PokéRogue.", - "value.0": "Off", - "value.1": "On" - }, - "inverseBattle": { - "name": "Inverse Battle", - "shortName": "Inverse", - "desc": "Type matchups are reversed and no type is immune to any other type.\nDisables other challenges' achievements.", - "value.0": "Off", - "value.1": "On" - } -} diff --git a/src/locales/en/command-ui-handler.json b/src/locales/en/command-ui-handler.json deleted file mode 100644 index 5ca222234d3..00000000000 --- a/src/locales/en/command-ui-handler.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "fight": "Fight", - "ball": "Ball", - "pokemon": "Pokémon", - "run": "Run", - "actionMessage": "What will\n{{pokemonName}} do?" -} \ No newline at end of file diff --git a/src/locales/en/common.json b/src/locales/en/common.json deleted file mode 100644 index e910b7c2e09..00000000000 --- a/src/locales/en/common.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "start": "Start", - "luckIndicator": "Luck:", - "shinyOnHover": "Shiny", - "commonShiny": "Common", - "rareShiny": "Rare", - "epicShiny": "Epic" -} \ No newline at end of file diff --git a/src/locales/en/config.ts b/src/locales/en/config.ts deleted file mode 100644 index f83fec5be26..00000000000 --- a/src/locales/en/config.ts +++ /dev/null @@ -1,189 +0,0 @@ -import common from "./common.json"; -import settings from "./settings.json"; -import ability from "./ability.json"; -import abilityTriggers from "./ability-trigger.json"; -import arenaFlyout from "./arena-flyout.json"; -import arenaTag from "./arena-tag.json"; -import achv from "./achv.json"; -import battle from "./battle.json"; -import battleScene from "./battle-scene.json"; -import battleInfo from "./battle-info.json"; -import battleMessageUiHandler from "./battle-message-ui-handler.json"; -import battlerTags from "./battler-tags.json"; -import berry from "./berry.json"; -import bgmName from "./bgm-name.json"; -import biome from "./biome.json"; -import challenges from "./challenges.json"; -import commandUiHandler from "./command-ui-handler.json"; -import dialogue from "./dialogue.json"; -import battleSpecDialogue from "./dialogue-final-boss.json"; -import miscDialogue from "./dialogue-misc.json"; -import doubleBattleDialogue from "./dialogue-double-battle.json"; -import egg from "./egg.json"; -import fightUiHandler from "./fight-ui-handler.json"; -import filterBar from "./filter-bar.json"; -import gameMode from "./game-mode.json"; -import gameStatsUiHandler from "./game-stats-ui-handler.json"; -import growth from "./growth.json"; -import menu from "./menu.json"; -import menuUiHandler from "./menu-ui-handler.json"; -import modifier from "./modifier.json"; -import modifierType from "./modifier-type.json"; -import move from "./move.json"; -import nature from "./nature.json"; -import partyUiHandler from "./party-ui-handler.json"; -import pokeball from "./pokeball.json"; -import pokemon from "./pokemon.json"; -import pokemonForm from "./pokemon-form.json"; -import battlePokemonForm from "./pokemon-form-battle.json"; -import pokemonInfo from "./pokemon-info.json"; -import pokemonInfoContainer from "./pokemon-info-container.json"; -import pokemonSummary from "./pokemon-summary.json"; -import saveSlotSelectUiHandler from "./save-slot-select-ui-handler.json"; -import splashMessages from "./splash-messages.json"; -import starterSelectUiHandler from "./starter-select-ui-handler.json"; -import statusEffect from "./status-effect.json"; -import trainerTitles from "./trainer-titles.json"; -import trainerClasses from "./trainer-classes.json"; -import trainerNames from "./trainer-names.json"; -import tutorial from "./tutorial.json"; -import voucher from "./voucher.json"; -import weather from "./weather.json"; -import terrain from "./terrain.json"; -import modifierSelectUiHandler from "./modifier-select-ui-handler.json"; -import moveTriggers from "./move-trigger.json"; -import runHistory from "./run-history.json"; -import mysteryEncounterMessages from "./mystery-encounter-messages.json"; -import lostAtSea from "./mystery-encounters/lost-at-sea-dialogue.json"; -import mysteriousChest from "#app/locales/en/mystery-encounters/mysterious-chest-dialogue.json"; -import mysteriousChallengers from "#app/locales/en/mystery-encounters/mysterious-challengers-dialogue.json"; -import darkDeal from "#app/locales/en/mystery-encounters/dark-deal-dialogue.json"; -import departmentStoreSale from "#app/locales/en/mystery-encounters/department-store-sale-dialogue.json"; -import fieldTrip from "#app/locales/en/mystery-encounters/field-trip-dialogue.json"; -import fieryFallout from "#app/locales/en/mystery-encounters/fiery-fallout-dialogue.json"; -import fightOrFlight from "#app/locales/en/mystery-encounters/fight-or-flight-dialogue.json"; -import safariZone from "#app/locales/en/mystery-encounters/safari-zone-dialogue.json"; -import shadyVitaminDealer from "#app/locales/en/mystery-encounters/shady-vitamin-dealer-dialogue.json"; -import slumberingSnorlax from "#app/locales/en/mystery-encounters/slumbering-snorlax-dialogue.json"; -import trainingSession from "#app/locales/en/mystery-encounters/training-session-dialogue.json"; -import theStrongStuff from "#app/locales/en/mystery-encounters/the-strong-stuff-dialogue.json"; -import pokemonSalesman from "#app/locales/en/mystery-encounters/the-pokemon-salesman-dialogue.json"; -import offerYouCantRefuse from "#app/locales/en/mystery-encounters/an-offer-you-cant-refuse-dialogue.json"; -import delibirdy from "#app/locales/en/mystery-encounters/delibirdy-dialogue.json"; -import absoluteAvarice from "#app/locales/en/mystery-encounters/absolute-avarice-dialogue.json"; -import aTrainersTest from "#app/locales/en/mystery-encounters/a-trainers-test-dialogue.json"; -import trashToTreasure from "#app/locales/en/mystery-encounters/trash-to-treasure-dialogue.json"; -import berriesAbound from "#app/locales/en/mystery-encounters/berries-abound-dialogue.json"; -import clowningAround from "#app/locales/en/mystery-encounters/clowning-around-dialogue.json"; -import partTimer from "#app/locales/en/mystery-encounters/part-timer-dialogue.json"; -import dancingLessons from "#app/locales/en/mystery-encounters/dancing-lessons-dialogue.json"; -import weirdDream from "#app/locales/en/mystery-encounters/weird-dream-dialogue.json"; -import theWinstrateChallenge from "#app/locales/en/mystery-encounters/the-winstrate-challenge-dialogue.json"; -import teleportingHijinks from "#app/locales/en/mystery-encounters/teleporting-hijinks-dialogue.json"; -import bugTypeSuperfan from "#app/locales/en/mystery-encounters/bug-type-superfan-dialogue.json"; -import funAndGames from "#app/locales/en/mystery-encounters/fun-and-games-dialogue.json"; -import uncommonBreed from "#app/locales/en/mystery-encounters/uncommon-breed-dialogue.json"; -import globalTradeSystem from "#app/locales/en/mystery-encounters/global-trade-system-dialogue.json"; - -/** - * Dialogue/Text token injection patterns that can be used: - * - `$` will be treated as a new line for Message and Dialogue strings. - * - `@d{}` will add a time delay to text animation for Message and Dialogue strings. - * - `@s{}` will play a specified sound effect for Message and Dialogue strings. - * - `@f{}` will fade the screen to black for the given duration, then fade back in for Message and Dialogue strings. - * - `{{}}` (MYSTERY ENCOUNTERS ONLY) will auto-inject the matching dialogue token value that is stored in {@link IMysteryEncounter.dialogueTokens}. - * - (see [i18next interpolations](https://www.i18next.com/translation-function/interpolation)) for more details. - * - `@[]{}` (STATIC TEXT ONLY, NOT USEABLE WITH {@link UI.showText()} OR {@link UI.showDialogue()}) will auto-color the given text to a specified {@link TextStyle} (e.g. `TextStyle.SUMMARY_GREEN`). - */ -export const enConfig = { - ability, - abilityTriggers, - arenaFlyout, - arenaTag, - battle, - battleScene, - battleInfo, - battleMessageUiHandler, - battlePokemonForm, - battlerTags, - berry, - bgmName, - biome, - challenges, - commandUiHandler, - common, - achv, - dialogue, - battleSpecDialogue, - miscDialogue, - doubleBattleDialogue, - egg, - fightUiHandler, - filterBar, - gameMode, - gameStatsUiHandler, - growth, - menu, - menuUiHandler, - modifier, - modifierType, - move, - nature, - pokeball, - pokemon, - pokemonForm, - pokemonInfo, - pokemonInfoContainer, - pokemonSummary, - saveSlotSelectUiHandler, - settings, - splashMessages, - starterSelectUiHandler, - statusEffect, - terrain, - titles: trainerTitles, - trainerClasses, - trainerNames, - tutorial, - voucher, - weather, - partyUiHandler, - modifierSelectUiHandler, - moveTriggers, - runHistory, - mysteryEncounter: { - // DO NOT REMOVE - "unit_test_dialogue": "{{test}}{{test}} {{test{{test}}}} {{test1}} {{test\}} {{test\\}} {{test\\\}} {test}}", - mysteriousChallengers, - mysteriousChest, - darkDeal, - fightOrFlight, - slumberingSnorlax, - trainingSession, - departmentStoreSale, - shadyVitaminDealer, - fieldTrip, - safariZone, - lostAtSea, - fieryFallout, - theStrongStuff, - pokemonSalesman, - offerYouCantRefuse, - delibirdy, - absoluteAvarice, - aTrainersTest, - trashToTreasure, - berriesAbound, - clowningAround, - partTimer, - dancingLessons, - weirdDream, - theWinstrateChallenge, - teleportingHijinks, - bugTypeSuperfan, - funAndGames, - uncommonBreed, - globalTradeSystem - }, - mysteryEncounterMessages -}; diff --git a/src/locales/en/dialogue-double-battle.json b/src/locales/en/dialogue-double-battle.json deleted file mode 100644 index 4190af49d15..00000000000 --- a/src/locales/en/dialogue-double-battle.json +++ /dev/null @@ -1,84 +0,0 @@ -{ - "blue_red_double": { - "encounter": { - "1": "Blue: Hey Red, let's show them what we're made of!\n$Red: ...\n$Blue: This is Pallet Town Power!" - }, - "victory": { - "1": "Blue: That was a great battle!\n$Red: ..." - } - }, - "red_blue_double": { - "encounter": { - "1": "Red: ...!\n$Blue: He never talks much.\n$Blue: But dont let that fool you! He is a champ after all!" - }, - "victory": { - "1": "Red: ...!\n$Blue: Next time we will beat you!" - } - }, - "tate_liza_double": { - "encounter": { - "1": "Tate: Are you surprised?\n$Liza: We are two gym leaders at once!\n$Tate: We are twins!\n$Liza: We dont need to talk to understand each other!\n$Tate: Twice the power...\n$Liza: Can you handle it?" - }, - "victory": { - "1": "Tate: What? Our combination was perfect!\n$Liza: Looks like we need to train more..." - } - }, - "liza_tate_double": { - "encounter": { - "1": "Liza: Hihihi... Are you surprised?\n$Tate: Yes, we are really two gym leaders at once!\n$Liza: This is my twin brother Tate!\n$Tate: And this is my twin sister Liza!\n$Liza: Don't you think we are a perfect combination?" - }, - "victory": { - "1": "Liza: Are we...\n$Tate: ...not as strong as we thought?" - } - }, - "wallace_steven_double": { - "encounter": { - "1": "Steven: Wallace, let's show them the power of the champions!\n$Wallace: We will show you the power of Hoenn!\n$Steven: Let's go!" - }, - "victory": { - "1": "Steven: That was a great battle!\n$Wallace: We will win next time!" - } - }, - "steven_wallace_double": { - "encounter": { - "1": "Steven: Do you have any rare Pokémon?\n$Wallace: Steven... We are here for a battle, not to show off our Pokémon.\n$Steven: Oh... I see... Let's go then!" - }, - "victory": { - "1": "Steven: Now that we are done with the battle, let's show off our Pokémon!\n$Wallace: Steven..." - } - }, - "alder_iris_double": { - "encounter": { - "1": "Alder: We are the strongest trainers in Unova!\n$Iris: Fights against strong trainers are the best!" - }, - "victory": { - "1": "Alder: Wow! You are super strong!\n$Iris: We will win next time!" - } - }, - "iris_alder_double": { - "encounter": { - "1": "Iris: Welcome Challenger! I am THE Unova Champion!\n$Alder: Iris, aren't you a bit too excited?", - "1_female": "Iris: Welcome Challenger! I am THE Unova Champion!\n$Alder: Iris, aren't you a bit too excited?" - }, - "victory": { - "1": "Iris: A loss like this is not easy to take...\n$Alder: But we will only get stronger with every loss!" - } - }, - "piers_marnie_double": { - "encounter": { - "1": "Marnie: Brother, let's show them the power of Spikemuth!\n$Piers: We bring darkness!" - }, - "victory": { - "1": "Marnie: You brought light to our darkness!\n$Piers: Its too bright..." - } - }, - "marnie_piers_double": { - "encounter": { - "1": "Piers: Ready for a concert?\n$Marnie: Brother... They are here to fight, not to sing...", - "1_female": "Piers: Ready for a concert?\n$Marnie: Brother... They are here to fight, not to sing..." - }, - "victory": { - "1": "Piers: Now that was a great concert!\n$Marnie: Brother..." - } - } -} \ No newline at end of file diff --git a/src/locales/en/dialogue-final-boss.json b/src/locales/en/dialogue-final-boss.json deleted file mode 100644 index 6f99aae3e0c..00000000000 --- a/src/locales/en/dialogue-final-boss.json +++ /dev/null @@ -1,10 +0,0 @@ -{ - "encounter": "It appears the time has finally come once again.\nYou know why you have come here, do you not?\n$You were drawn here, because you have been here before.\nCountless times.\n$Though, perhaps it can be counted.\nTo be precise, this is in fact your {{cycleCount}} cycle.\n$Each cycle your mind reverts to its former state.\nEven so, somehow, remnants of your former selves remain.\n$Until now you have yet to succeed, but I sense a different presence in you this time.\n\n$You are the only one here, though it is as if there is… another.\n$Will you finally prove a formidable challenge to me?\nThe challenge I have longed after for millennia?\n$We begin.", - "encounter_female": "It appears the time has finally come once again.\nYou know why you have come here, do you not?\n$You were drawn here, because you have been here before.\nCountless times.\n$Though, perhaps it can be counted.\nTo be precise, this is in fact your {{cycleCount}} cycle.\n$Each cycle your mind reverts to its former state.\nEven so, somehow, remnants of your former selves remain.\n$Until now you have yet to succeed, but I sense a different presence in you this time.\n\n$You are the only one here, though it is as if there is… another.\n$Will you finally prove a formidable challenge to me?\nThe challenge I have longed after for millennia?\n$We begin.", - "firstStageWin": "I see. The presence I felt was indeed real.\nIt appears I no longer need to hold back.\n$Do not disappoint me.", - "secondStageWin": "…Magnificent.", - "key_ordinal_one": "st", - "key_ordinal_two": "nd", - "key_ordinal_few": "rd", - "key_ordinal_other": "th" -} \ No newline at end of file diff --git a/src/locales/en/dialogue-misc.json b/src/locales/en/dialogue-misc.json deleted file mode 100644 index 2f333b5f383..00000000000 --- a/src/locales/en/dialogue-misc.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "ending": "@c{shock}You're back?@d{32} Does that mean…@d{96} you won?!\n@c{smile_ehalf}I should have known you had it in you.\n$@c{smile_eclosed}Of course… I always had that feeling.\n@c{smile}It's over now, right? You ended the loop.\n$@c{smile_ehalf}You fulfilled your dream too, didn't you?\nYou didn't lose even once.\n$I'll be the only one to remember what you did.\n@c{angry_mopen}I'll try not to forget!\n$@c{smile_wave_wink}Just kidding!@d{64} @c{smile}I'd never forget.@d{32}\nYour legend will live on in our hearts.\n$@c{smile_wave}Anyway,@d{64} it's getting late…@d{96} I think?\nIt's hard to tell in this place.\n$Let's go home. @c{smile_wave_wink}Maybe tomorrow, we can have another battle, for old time's sake?", - "ending_female": "@c{smile}Oh? You won?@d{96} @c{smile_eclosed}I guess I should've known.\nBut, you're back now.\n$@c{smile}It's over.@d{64} You ended the loop.\n$@c{serious_smile_fists}You fulfilled your dream too, didn't you?\nYou didn't lose even once.\n$@c{neutral}I'm the only one who'll remember what you did.@d{96}\nI guess that's okay, isn't it?\n$@c{serious_smile_fists}Your legend will always live on in our hearts.\n$@c{smile_eclosed}Anyway, I've had about enough of this place, haven't you? Let's head home.\n$@c{serious_smile_fists}Maybe when we get back, we can have another battle?\nIf you're up to it.", - "ending_endless": "Congratulations on reaching the current end!\nMore content is coming soon.", - "ending_name": "Devs" -} diff --git a/src/locales/en/dialogue.json b/src/locales/en/dialogue.json deleted file mode 100644 index 39a4238355c..00000000000 --- a/src/locales/en/dialogue.json +++ /dev/null @@ -1,2937 +0,0 @@ -{ - "youngster": { - "encounter": { - "1": "Hey, wanna battle?", - "2": "Are you a new trainer too?", - "2_female": "Are you a new trainer too?", - "3": "Hey, I haven't seen you before. Let's battle!", - "4": "I just lost, so I'm trying to find more Pokémon.\nWait! You look weak! Come on, let's battle!", - "4_female": "I just lost, so I'm trying to find more Pokémon.\nWait! You look weak! Come on, let's battle!", - "5": "Have we met or not? I don't really remember. Well, I guess it's nice to meet you anyway!", - "6": "All right! Let's go!", - "7": "All right! Here I come! I'll show you my power!", - "8": "Haw haw haw... I'll show you how hawesome my Pokémon are!", - "9": "No need to waste time saying hello. Bring it on whenever you're ready!", - "9_female": "No need to waste time saying hello. Bring it on whenever you're ready!", - "10": "Don't let your guard down, or you may be crying when a kid beats you.", - "11": "I've raised my Pokémon with great care. You're not allowed to hurt them!", - "12": "Glad you made it! It won't be an easy job from here.", - "12_female": "Glad you made it! It won't be an easy job from here.", - "13": "The battles continue forever! Welcome to the world with no end!", - "13_female": "The battles continue forever! Welcome to the world with no end!" - }, - "victory": { - "1": "Wow! You're strong!", - "1_female": "Wow! You're strong!", - "2": "I didn't stand a chance, huh?", - "3": "I'll find you again when I'm older and beat you!", - "4": "Ugh. I don't have any more Pokémon.", - "5": "No way… NO WAY! How could I lose again…", - "5_female": "No way… NO WAY! How could I lose again…", - "6": "No! I lost!", - "7": "Whoa! You are incredible! I'm amazed and surprised!", - "8": "Could it be… How… My Pokémon and I are the strongest, though…", - "9": "I won't lose next time! Let's battle again sometime!", - "10": "Sheesh! Can't you see that I'm just a kid! It wasn't fair of you to go all out like that!", - "11": "Your Pokémon are more amazing! Trade with me!", - "12": "I got a little carried away earlier, but what job was I talking about?", - "13": "Ahaha! There it is! That's right! You're already right at home in this world!" - } - }, - "lass": { - "encounter": { - "1": "Let's have a battle, shall we?", - "2": "You look like a new trainer. Let's have a battle!", - "2_female": "You look like a new trainer. Let's have a battle!", - "3": "I don't recognize you. How about a battle?", - "4": "Let's have a fun Pokémon battle!", - "5": "I'll show you the ropes of how to really use Pokémon!", - "6": "A serious battle starts from a serious beginning! Are you sure you're ready?", - "6_female": "A serious battle starts from a serious beginning! Are you sure you're ready?", - "7": "You're only young once. And you only get one shot at a given battle. Soon, you'll be nothing but a memory.", - "8": "You'd better go easy on me, OK? Though I'll be seriously fighting!", - "9": "School is boring. I've got nothing to do. Yawn. I'm only battling to kill the time." - }, - "victory": { - "1": "That was impressive! I've got a lot to learn.", - "2": "I didn't think you'd beat me that bad…", - "2_female": "I didn't think you'd beat me that bad…", - "3": "I hope we get to have a rematch some day.", - "4": "That was pretty amazingly fun! You've totally exhausted me…", - "5": "You actually taught me a lesson! You're pretty amazing!", - "6": "Seriously, I lost. That is, like, seriously depressing, but you were seriously cool.", - "6_female": "Seriously, I lost. That is, like, seriously depressing, but you were seriously cool.", - "7": "I don't need memories like this. Deleting memory…", - "8": "Hey! I told you to go easy on me! Still, you're pretty cool when you're serious.", - "8_female": "Hey! I told you to go easy on me! Still, you're pretty cool when you're serious.", - "9": "I'm actually getting tired of battling… There's gotta be something new to do…" - } - }, - "breeder": { - "encounter": { - "1": "Obedient Pokémon, selfish Pokémon… Pokémon have unique characteristics.", - "2": "Even though my upbringing and behavior are poor, I've raised my Pokémon well.", - "3": "Hmm, do you discipline your Pokémon? Pampering them too much is no good." - }, - "victory": { - "1": "It is important to nurture and train each Pokémon's characteristics.", - "2": "Unlike my diabolical self, these are some good Pokémon.", - "3": "Too much praise can spoil both Pokémon and people." - }, - "defeat": { - "1": "You should not get angry at your Pokémon, even if you lose a battle.", - "2": "Right? Pretty good Pokémon, huh? I'm suited to raising things.", - "3": "No matter how much you love your Pokémon, you still have to discipline them when they misbehave." - } - }, - "breeder_female": { - "encounter": { - "1": "Pokémon never betray you. They return all the love you give them.", - "2": "Shall I give you a tip for training good Pokémon?", - "3": "I have raised these very special Pokémon using a special method." - }, - "victory": { - "1": "Ugh… It wasn't supposed to be like this. Did I administer the wrong blend?", - "2": "How could that happen to my Pokémon… What are you feeding your Pokémon?", - "3": "If I lose, that tells you I was just killing time. It doesn't damage my ego at all." - }, - "defeat": { - "1": "This proves my Pokémon have accepted my love.", - "2": "The real trick behind training good Pokémon is catching good Pokémon.", - "3": "Pokémon will be strong or weak depending on how you raise them." - } - }, - "fisherman": { - "encounter": { - "1": "Aack! You made me lose a bite!\nWhat are you going to do about it?", - "2": "Go away! You're scaring the Pokémon!", - "3": "Let's see if you can reel in a victory!" - }, - "victory": { - "1": "Just forget about it.", - "2": "Next time, I'll be reelin' in the triumph!", - "3": "Guess I underestimated the currents this time." - } - }, - "fisherman_female": { - "encounter": { - "1": "Woah! I've hooked a big one!", - "2": "Line's in, ready to reel in success!", - "3": "Ready to make waves!" - }, - "victory": { - "1": "I'll be back with a stronger hook.", - "2": "I'll reel in victory next time.", - "3": "I'm just sharpening my hooks for the comeback!" - } - }, - "swimmer": { - "encounter": { - "1": "Time to dive in!", - "2": "Let's ride the waves of victory!", - "3": "Ready to make a splash!" - }, - "victory": { - "1": "Drenched in defeat!", - "2": "A wave of defeat!", - "3": "Back to shore, I guess." - } - }, - "backpacker": { - "encounter": { - "1": "Pack up, game on!", - "2": "Let's see if you can keep pace!", - "3": "Gear up, challenger!", - "4": "I've spent 20 years trying to find myself… But where am I?" - }, - "victory": { - "1": "Tripped up this time!", - "2": "Oh, I think I'm lost.", - "3": "Dead end!", - "4": "Wait up a second! Hey! Don't you know who I am?" - } - }, - "ace_trainer": { - "encounter": { - "1": "You seem quite confident.", - "1_female": "You seem quite confident.", - "2": "Your Pokémon… Show them to me…", - "3": "Because I'm an Ace Trainer, people think I'm strong.", - "4": "Are you aware of what it takes to be an Ace Trainer?" - }, - "victory": { - "1": "Yes… You have good Pokémon…", - "2": "What?! But I'm a battling genius!", - "3": "Of course, you are the main character!", - "3_female": "Of course, you are the main character!", - "4": "OK! OK! You could be an Ace Trainer!", - "4_female": "OK! OK! You could be an Ace Trainer!" - }, - "defeat": { - "1": "I am devoting my body and soul to Pokémon battles!", - "2": "All within my expectations… Nothing to be surprised about…", - "3": "I thought I'd grow up to be a frail person who looked like they would break if you squeezed them too hard.", - "4": "Of course I'm strong and don't lose. It's important that I win gracefully." - } - }, - "parasol_lady": { - "encounter": { - "1": "Time to grace the battlefield with elegance and poise!" - }, - "victory": { - "1": "My elegance remains unbroken!" - } - }, - "twins": { - "encounter": { - "1": "Get ready, because when we team up, it's double the trouble!", - "2": "Two hearts, one strategy – let's see if you can keep up with our twin power!", - "3": "Hope you're ready for double trouble, because we're about to bring the heat!", - "3_female": "Hope you're ready for double trouble, because we're about to bring the heat!" - }, - "victory": { - "1": "We may have lost this round, but our bond remains unbreakable!", - "2": "Our twin spirit won't be dimmed for long.", - "3": "We'll come back stronger as a dynamic duo!" - }, - "defeat": { - "1": "Twin power reigns supreme!", - "2": "Two hearts, one triumph!", - "3": "Double the smiles, double the victory dance!" - } - }, - "cyclist": { - "encounter": { - "1": "Get ready to eat my dust!", - "2": "Gear up, challenger! I'm about to leave you in the dust!", - "3": "Pedal to the metal, let's see if you can keep pace!" - }, - "victory": { - "1": "Spokes may be still, but determination pedals on.", - "2": "Outpaced!", - "3": "The road to victory has many twists and turns yet to explore." - } - }, - "black_belt": { - "encounter": { - "1": "I praise your courage in challenging me! For I am the one with the strongest kick!", - "2": "Oh, I see. Would you like to be cut to pieces? Or do you prefer the role of punching bag?", - "2_female": "Oh, I see. Would you like to be cut to pieces? Or do you prefer the role of punching bag?" - }, - "victory": { - "1": "Oh. The Pokémon did the fighting. My strong kick didn't help a bit.", - "2": "Hmmm… If I was going to lose anyway, I was hoping to get totally messed up in the process." - } - }, - "battle_girl": { - "encounter": { - "1": "You don't have to try to impress me. You can lose against me." - }, - "victory": { - "1": "It's hard to say good-bye, but we are running out of time…" - } - }, - "hiker": { - "encounter": { - "1": "My middle-age spread has given me as much gravitas as the mountains I hike!", - "2": "I inherited this big-boned body from my parents… I'm like a living mountain range…" - }, - "victory": { - "1": "At least I cannot lose when it comes to BMI!", - "2": "It's not enough… It's never enough. My bad cholesterol isn't high enough…" - } - }, - "ranger": { - "encounter": { - "1": "When I am surrounded by nature, most other things cease to matter.", - "2": "When I'm living without nature in my life, sometimes I'll suddenly feel an anxiety attack coming on." - }, - "victory": { - "1": "It doesn't matter to the vastness of nature whether I win or lose…", - "2": "Something like this is pretty trivial compared to the stifling feelings of city life." - }, - "defeat": { - "1": "I won the battle. But victory is nothing compared to the vastness of nature…", - "2": "I'm sure how you feel is not so bad if you compare it to my anxiety attacks…" - } - }, - "scientist": { - "encounter": { - "1": "My research will lead this world to peace and joy." - }, - "victory": { - "1": "I am a genius… I am not supposed to lose against someone like you…" - } - }, - "school_kid": { - "encounter": { - "1": "…Heehee. I'm confident in my calculations and analysis.", - "2": "I'm gaining as much experience as I can because I want to be a Gym Leader someday." - }, - "victory": { - "1": "Ohhhh… Calculation and analysis are perhaps no match for chance…", - "2": "Even difficult, trying experiences have their purpose, I suppose." - } - }, - "artist": { - "encounter": { - "1": "I used to be popular, but now I am all washed up." - }, - "victory": { - "1": "As times change, values also change. I realized that too late." - } - }, - "guitarist": { - "encounter": { - "1": "Get ready to feel the rhythm of defeat as I strum my way to victory!" - }, - "victory": { - "1": "Silenced for now, but my melody of resilience will play on." - } - }, - "worker": { - "encounter": { - "1": "It bothers me that people always misunderstand me. I'm a lot more pure than everyone thinks." - }, - "victory": { - "1": "I really don't want my skin to burn, so I want to stay in the shade while I work." - } - }, - "worker_female": { - "encounter": { - "1": "It bothers me that people always misunderstand me.\n$I'm a lot more pure than everyone thinks." - }, - "victory": { - "1": "I really don't want my skin to burn, so I want to stay in the shade while I work." - }, - "defeat": { - "1": "My body and mind aren't necessarily always in sync." - } - }, - "worker_double": { - "encounter": { - "1": "I'll show you we can break you. We've been training in the field!" - }, - "victory": { - "1": "How strange… How could this be… I shouldn't have been outmuscled." - } - }, - "hex_maniac": { - "encounter": { - "1": "I normally only ever listen to classical music, but if I lose, I think I shall try a bit of new age!", - "2": "I grow stronger with each tear I cry." - }, - "victory": { - "1": "Is this the dawning of the age of Aquarius?", - "2": "Now I can get even stronger. I grow with every grudge." - }, - "defeat": { - "1": "New age simply refers to twentieth century classical composers, right?", - "2": "Don't get hung up on sadness or frustration. You can use your grudges to motivate yourself.", - "2_female": "Don't get hung up on sadness or frustration. You can use your grudges to motivate yourself." - } - }, - "psychic": { - "encounter": { - "1": "Hi! Focus!" - }, - "victory": { - "1": "Eeeeek!" - } - }, - "officer": { - "encounter": { - "1": "Brace yourself, because justice is about to be served!", - "2": "Ready to uphold the law and serve justice on the battlefield!" - }, - "victory": { - "1": "The weight of justice feels heavier than ever…", - "2": "The shadows of defeat linger in the precinct." - } - }, - "beauty": { - "encounter": { - "1": "My last ever battle… That's the way I'd like us to view this match…" - }, - "victory": { - "1": "It's been fun… Let's have another last battle again someday…" - } - }, - "baker": { - "encounter": { - "1": "Hope you're ready to taste defeat!", - "1_female": "Hope you're ready to taste defeat!" - }, - "victory": { - "1": "I'll bake a comeback." - } - }, - "biker": { - "encounter": { - "1": "Time to rev up and leave you in the dust!" - }, - "victory": { - "1": "I'll tune up for the next race." - } - }, - "firebreather": { - "encounter": { - "1": "My flames shall devour you!", - "2": "My soul is on fire. I'll show you how hot it burns!", - "3": "Step right up and take a look!" - }, - "victory": { - "1": "I burned down to ashes...", - "2": "Yow! That's hot!", - "3": "Ow! I scorched the tip of my nose!" - } - }, - "sailor": { - "encounter": { - "1": "Matey, you're walking the plank if you lose!", - "2": "Come on then! My sailor's pride is at stake!", - "3": "Ahoy there! Are you seasick?", - "3_female": "Ahoy there! Are you seasick?" - }, - "victory": { - "1": "Argh! Beaten by a kid!", - "2": "Your spirit sank me!", - "3": "I think it's me that's seasick..." - } - }, - "archer": { - "encounter": { - "1": "Before you go any further, let's see how you fare against us, Team Rocket!", - "2": "I have received reports that your skills are not insignificant. Let's see if they are true.", - "3": "I am Archer, an Admin of Team Rocket. And I do not go easy on enemies of our organization." - }, - "victory": { - "1": "What a blunder!", - "2": "With my current skills, I was not up to the task after all.", - "3": "F-forgive me, Giovanni... For me to be defeated by a mere trainer..." - } - }, - "ariana": { - "encounter": { - "1": "Hold it right there!\nWe can't have someone on the loose.\n$It's harmful to Team Rocket's pride, you see.", - "2": "I don't know or care if what I'm doing is right or wrong...\n$I just put my faith in Giovanni and do as I am told", - "3": "Your trip ends here. I'm going to take you down!" - }, - "victory": { - "1": "Tch, you really are strong. It's too bad.\n$If you were to join Team Rocket, you could become an Executive.", - "1_female": "Tch, you really are strong. It's too bad.\n$If you were to join Team Rocket, you could become an Executive.", - "2": "I... I'm shattered...", - "3": "Aaaieeeee! This can't be happening! I fought hard, but I still lost…" - } - }, - "proton": { - "encounter": { - "1": "What do you want? If you interrupt our work, don't expect any mercy!", - "2": "What do we have here? I am often labeled as the scariest and cruelest guy in Team Rocket…\n$I strongly urge you not to interfere with our business!", - "3": "I am Proton, an Admin of Team Rocket. I am here to put an end to your meddling!" - }, - "victory": { - "1": "The fortress came down!", - "2": "You may have won this time… But all you did was make Team Rocket's wrath grow…", - "3": "I am defeated… But I will not forget this!" - } - }, - "petrel": { - "encounter": { - "1": "Muhahaha, we've been waiting for you. Me? You don't know who I am? It is me, Giovanni.\n$The majestic Giovanni himself! Wahahaha! …Huh? I don't sound anything like Giovanni?\n$I don't even look like Giovanni? How come? I've worked so hard to mimic him!", - "2": "I am Petrel, an Admin of Team Rocket. I will not allow you to interfere with our plans!", - "3": "Rocket Executive Petrel will deal with this intruder!" - }, - "victory": { - "1": "OK, OK. I'll tell you where he is.", - "2": "I… I couldn't do a thing… Giovanni, please forgive me…", - "3": "No, I can't let this affect me. I have to inform the others…" - } - }, - "tabitha": { - "encounter": { - "1": "Hehehe! So you've come all the way here! But you're too late!", - "2": "Hehehe... Got here already, did you? We underestimated you! But this is it! \n$I'm a cut above the Grunts you've seen so far. I'm not stalling for time.\n$I'm going to pulverize you!", - "3": "I'm going to give you a little taste of pain! Resign yourself to it!" - }, - "victory": { - "1": "Hehehe! You might have beaten me, but you don't stand a chance against the boss!\n$If you get lost now, you won't have to face a sound whipping!", - "2": "Hehehe... So, I lost, too...", - "3": "Ahya! How could this be? For an Admin like me to lose to some random trainer...", - "3_female": "Ahya! How could this be? For an Admin like me to lose to some random trainer..." - } - }, - "courtney": { - "encounter": { - "1": "Don't. Get. In. My. Way.", - "2": "You... ...I want to...analyze. Ahahaha", - "3": "... Well then...Deleting..." - }, - "victory": { - "1": "Hah hah... Uhn...hah hah...", - "2": "As anticipated. Unanticipated. You. Target lock...completed.\n$Commencing...experiment. You. Forever. Aha... ♪", - "3": "That's unanticipated. ...I knew it. You...are interesting! ...Haha. ♪" - } - }, - "shelly": { - "encounter": { - "1": "Ahahahaha! You're going to meddle in Team Aqua's affairs?\n$You're either absolutely fearless, simply ignorant, or both!\n$You're so cute, you're disgusting! I'll put you down", - "2": "What's this? Who's this spoiled brat?", - "3": "Cool your jets. Be patient. I'll crush you shortly.", - "3_female": "Cool your jets. Be patient. I'll crush you shortly." - }, - "victory": { - "1": "Ahahahaha! We got meddled with unexpectedly! We're out of options.\n$We'll have to pull out. But this isn't the last you'll see of Team Aqua!\n$We have other plans! Don't you forget it!", - "2": "Ahhh?! Did I go too easy on you?!", - "3": "Uh. Are you telling me you've upped your game even more during the fight?\n$You're a brat with a bright future… My Pokémon and I don't have any strength left to fight…\n$Go on… Go and be destroyed by Archie.", - "3_female": "Uh. Are you telling me you've upped your game even more during the fight?\n$You're a brat with a bright future… My Pokémon and I don't have any strength left to fight…\n$Go on… Go and be destroyed by Archie." - } - }, - "matt": { - "encounter": { - "1": "All right then, until the boss has time for you, I'll be your opponent!", - "2": "Hooah! Full on! I'm burning up! Well! Welll! Wellllll! Let's battle it out until we've got nothing left!", - "3": "Hoo hah! I'm gonna smash you up!" - }, - "victory": { - "1": "Muwuhahaha! That battle was fun even though I lost!", - "2": "I can feel it! I can feel it, all right! The strength coming offa you!\n$More! I still want more! But looks like we're outta time...", - "3": "Oho! That's a loss I can be proud of!", - "3_female": "Oho! That's a loss I can be proud of!" - } - }, - "mars": { - "encounter": { - "1": "I'm Mars, one of Team Galactic's top Commanders.", - "2": "Team Galactic's vision for the future is unwavering. Opposition will be crushed without mercy!", - "3": "Feeling nervous? You should be!", - "3_female": "Feeling nervous? You should be!" - }, - "victory": { - "1": "This can't be happening! How did I lose?!", - "2": "You have some skill, I'll give you that.", - "3": "Defeated... This was a costly mistake." - } - }, - "jupiter": { - "encounter": { - "1": "Jupiter, Commander of Team Galactic, at your service.", - "2": "Resistance is futile. Team Galactic will prevail!", - "3": "You're trembling... scared already?" - }, - "victory": { - "1": "No way... I lost?!", - "2": "Impressive, you've got guts!", - "3": "Losing like this... How embarrassing." - } - }, - "saturn": { - "encounter": { - "1": "I am Saturn, Commander of Team Galactic.", - "2": "Our mission is absolute. Any hindrance will be obliterated!", - "3": "Is that fear I see in your eyes?" - }, - "victory": { - "1": "Impossible... Defeated by you?!", - "2": "You have proven yourself a worthy adversary.", - "3": "Bestowed in defeat... This is unacceptable." - } - }, - "zinzolin": { - "encounter": { - "1": "You could become a threat to Team Plasma, so we will eliminate you here and now!", - "1_female": "You could become a threat to Team Plasma, so we will eliminate you here and now!", - "2": "You don't have the sense to know when to quit, it seems. It's an act of mercy on my part to bring an end to this now!", - "3": "You're an impressive Trainer to have made it this far. But it ends here.", - "3_female": "You're an impressive Trainer to have made it this far. But it ends here." - }, - "victory": { - "1": "Ghetsis... I have failed you...", - "2": "It's bitter cold. I'm shivering. I'm suffering. Yet, we will stand victorious.", - "3": "Hmph. You're a smarter Trainer than I expected, but not smart enough.", - "3_female": "Hmph. You're a smarter Trainer than I expected, but not smart enough." - } - }, - "rood": { - "encounter": { - "1": "You are a threat to Team Plasma. We cannot let you walk away from here and now!", - "1_female": "You are a threat to Team Plasma. We cannot let you walk away from here and now!", - "2": "It seems you don't know when to give up. I'll make sure no one interferes with our plans!", - "3": "You are a remarkable Trainer to have made it this far. But this is where it ends.", - "3_female": "You are a remarkable Trainer to have made it this far. But this is where it ends." - }, - "victory": { - "1": "Ghetsis... I have failed my mission...", - "2": "The cold is piercing. I'm shivering. I'm suffering. Yet, we will stand triumphant.", - "3": "Hm. You are a talented Trainer, but unfortunately not talented enough." - } - }, - "xerosic": { - "encounter": { - "1": "Ah ha ha! It would be my pleasure. Come on, little Trainer! Let's see what you've got!", - "1_female": "Ah ha ha! It would be my pleasure. Come on, little Trainer! Let's see what you've got!", - "2": "Hmm... You're more powerful than you look. I wonder how much energy there is inside you.", - "2_female": "Hmm... You're more powerful than you look. I wonder how much energy there is inside you.", - "3": "I've been waiting for you! I need to do a little research on you! Come, let us begin!" - }, - "victory": { - "1": "Ah, you're quite strong. Oh yes—very strong, indeed.", - "2": "Ding-ding-ding! You did it! To the victor go the spoils!", - "2_female": "Ding-ding-ding! You did it! To the victor go the spoils!", - "3": "Wonderful! Amazing! You have tremendous skill and bravery!" - } - }, - "bryony": { - "encounter": { - "1": "I am Bryony, and it would be my pleasure to battle you. Show me what you've got.", - "2": "Impressive... You're more powerful than you appear. Let's see the true extent of your energy.", - "2_female": "Impressive... You're more powerful than you appear. Let's see the true extent of your energy.", - "3": "I've anticipated your arrival. It's time for a little test. Shall we begin?" - }, - "victory": { - "1": "You're quite strong. Oh yes—very strong, indeed.", - "2": "Ding-ding-ding! You've done well. Victory is yours.", - "3": "Wonderful! Remarkable! Your skill and bravery are commendable." - } - }, - "rocket_grunt": { - "encounter": { - "1": "Prepare for trouble!", - "2": "We're pulling a big job here! Get lost, kid!", - "2_female": "We're pulling a big job here! Get lost, kid!", - "3": "Hand over your Pokémon, or face the wrath of Team Rocket!", - "4": "You're about to experience the true terror of Team Rocket!", - "5": "Hey, kid! Me am a Team Rocket member kind of guy!", - "5_female": "Hey, kid! Me am a Team Rocket member kind of guy!" - }, - "victory": { - "1": "Team Rocket blasting off again!", - "2": "Oh no! I dropped the Lift Key!", - "3": "I blew it!", - "4": "My associates won't stand for this!", - "5": "You say what? Team Rocket bye-bye a go-go? Broken it is says you?" - } - }, - "magma_grunt": { - "encounter": { - "1": "If you get in the way of Team Magma, don’t expect any mercy!", - "2": "You'd better not interfere with our plans! We're making the world a better place!", - "3": "You're in the way! Team Magma has no time for kids like you!", - "4": "I hope you brought marshmallows because things are about to heat up!", - "5": "We're going to use the power of a volcano! It's gonna be... explosive! Get it? Heh heh!" - }, - "victory": { - "1": "Huh? I lost?!", - "2": "I can't believe I lost! I even skipped lunch for this", - "3": "No way! You're just a kid!", - "3_female": "No way! You're just a kid!", - "4": "Urrrgh... I should've ducked into our hideout right away...", - "5": "You beat me... Do you think the boss will dock my pay for this?" - } - }, - "aqua_grunt": { - "encounter": { - "1": "No one who crosses Team Aqua gets any mercy, not even kids!", - "2": "Grrr... You've got some nerve meddling with Team Aqua!", - "3": "You're about to get soaked! And not just from my water Pokémon!", - "4": "We, Team Aqua, exist for the good of all!", - "5": "Prepare to be washed away by the tides of my... uh, Pokémon! Yeah, my Pokémon!" - }, - "victory": { - "1": "You're kidding me!", - "2": "Arrgh, I didn't count on being meddled with by some meddling kid!", - "3": "I lost?! Guess I'll have to swim back to the hideout now...", - "4": "Oh, man, what a disaster... The boss is going to be furious...", - "5": "You beat me... Do you think the boss will make me walk the plank for this?" - } - }, - "galactic_grunt": { - "encounter": { - "1": "Don't mess with Team Galactic!", - "2": "Witness the power of our technology and the future we envision!", - "3": "In the name of Team Galactic, I'll eliminate anyone who stands in our way!", - "4": "Get ready to lose!", - "5": "Hope you're ready for a cosmic beatdown!", - "5_female": "Hope you're ready for a cosmic beatdown!" - }, - "victory": { - "1": "Shut down...", - "2": "This setback means nothing in the grand scheme.", - "3": "Our plans are bigger than this defeat.", - "4": "How?!", - "5": "Note to self: practice Pokémon battling, ASAP." - } - }, - "plasma_grunt": { - "encounter": { - "1": "We won't tolerate people who have different ideas!", - "2": "If I win against you, release your Pokémon!", - "3": "If you get in the way of Team Plasma, I'll take care of you!", - "4": "Team Plasma will liberate Pokémon from selfish humans like you!", - "5": "Our hairstyles are out of this world... but our battling skills? You'll find out soon enough." - }, - "victory": { - "1": "Plasmaaaaaaaaa!", - "2": "How could I lose...", - "3": "...What a weak Pokémon, I'll just have to go steal some better ones!", - "4": "Great plans are always interrupted.", - "5": "This is bad... Badbadbadbadbadbadbad! Bad for Team Plasma! Or Plasbad, for short!" - } - }, - "flare_grunt": { - "encounter": { - "1": "Your Pokémon are no match for the elegance of Team Flare.", - "2": "Hope you brought your sunglasses, because things are about to get bright!", - "2_female": "Hope you brought your sunglasses, because things are about to get bright!", - "3": "Team Flare will cleanse the world of imperfection!", - "4": "Prepare to face the brilliance of Team Flare!", - "5": "Fashion is most important to us!" - }, - "victory": { - "1": "The future doesn't look bright for me.", - "2": "Perhaps there's more to battling than I thought. Back to the drawing board.", - "3": "Gahh?! I lost?!", - "4": "Even in defeat, Team Flare's elegance shines through.", - "5": "You may have beaten me, but when I lose, I go out in style!" - } - }, - "aether_grunt": { - "encounter": { - "1": "I'll fight you with all I have to wipe you out!", - "2": "I don't care if you're a kid or what. I'll send you flying if you threaten us!", - "2_female": "I don't care if you're a kid or what. I'll send you flying if you threaten us!", - "3": "I was told to turn away Trainers, whomever they might be!", - "4": "I'll show you the power of Aether Paradise!", - "5": "Now that you've learned of the darkness at the heart of Aether Paradise, we'll need you to conveniently disappear!" - }, - "victory": { - "1": "Hmph! You seem to have a lot of skill.", - "2": "What does this mean? What does this mean!", - "3": "Hey! You're so strong that there's no way I can turn you away!", - "4": "Hmm... It seems as though I may have lost.", - "5": "Here's an impression for you: Aiyee!" - } - }, - "faba": { - "encounter": { - "1": "I, Branch Chief Faba, shall show you the harshness of the real world!", - "2": "The man who is called Aether Paradise's last line of defense is to battle a mere child?", - "2_female": "The man who is called Aether Paradise's last line of defense is to battle a mere child?", - "3": "I, Faba, am the Aether Branch Chief. The only one in the world, I'm irreplaceable." - }, - "victory": { - "1": "Aiyee!", - "2": "H-h-how can this be?! How could this child...", - "2_female": "H-h-how can this be?! How could this child...", - "3": "This is why... This is why I can't bring myself to like children." - } - }, - "skull_grunt": { - "encounter": { - "1": "We're not bad-we're just hard!", - "2": "You want some? That's how we say hello! Nice knowing you, punks!", - "2_female": "You want some? That's how we say hello! Nice knowing you, punks!", - "3": "We're just a bunch of guys and gals with a great interest in other people's Pokémon!", - "4": "Why you trying to act hard when we're already hard as bones out here, homie?", - "4_female": "Why you trying to act hard when we're already hard as bones out here, homie?", - "5": "Team Skull represent! We can't pay the rent! Had a lot of fun, but our youth was misspent!", - "5_female": "Team Skull represent! We can't pay the rent! Had a lot of fun, but our youth was misspent!" - }, - "victory": { - "1": "Huh? Is it over already?", - "2": "Time for us to break out, yo! Gotta tell y'all peace out, yo!", - "3": "We don't need your wack Pokémon anyway!", - "4": "Wha-?! This kid's way too strong-no bones about it!", - "5": "So, what? I'm lower than a Pokémon?! I already got self-esteem issues, man." - } - }, - "plumeria": { - "encounter": { - "1": " ...Hmph. You don't look like anything special to me.", - "1_female": " ...Hmph. You don't look like anything special to me.", - "2": "It takes these dumb Grunts way too long to deal with you kids...", - "3": "Mess with anyone in Team Skull, and I'll show you how serious I can get." - }, - "victory": { - "1": "Hmmph! You're pretty strong. I'll give you that.", - "1_female": "Hmmph! You're pretty strong. I'll give you that.", - "2": "Hmmph. Guess you are pretty tough. Now I understand why my Grunts waste so much time battling kids.", - "3": "Hmmph! I guess I just have to hold that loss." - } - }, - "macro_grunt": { - "encounter": { - "1": "It looks like this is the end of the line for you!", - "2": "You are a trainer aren't you? I'm afraid that doesn't give you the right to interfere in our work.", - "2_female": "You are a trainer aren't you? I'm afraid that doesn't give you the right to interfere in our work.", - "3": "I'm from Macro Cosmos Insurance! Do you have a life insurance policy?" - }, - "victory": { - "1": "I have little choice but to respectfully retreat.", - "2": "Having to give up my pocket money... Losing means I'm back in the red...", - "3": "Nobody can beat Macro Cosmos when it comes to our dedication to our work!" - } - }, - "oleana": { - "encounter": { - "1": "I won't let anyone interfere with Mr. Rose's plan!", - "2": "So, you got through all of the special staff that I had ordered to stop you. I would expect nothing less.", - "3": "For the chairman! I won't lose!" - }, - "victory": { - "1": "*sigh* I wasn't able to win... Oleana...you really are a hopeless woman.", - "2": "Arghhh! This is inexcusable... What was I thinking... Any trainer who's made it this far would be no pushover..", - "2_female": "Arghhh! This is inexcusable... What was I thinking... Any trainer who's made it this far would be no pushover..", - "3": "*sigh* I am one tired Oleana..." - } - }, - "rocket_boss_giovanni_1": { - "encounter": { - "1": "So! I must say, I am impressed you got here!" - }, - "victory": { - "1": "WHAT! This cannot be!" - }, - "defeat": { - "1": "Mark my words. Not being able to measure your own strength shows that you are still a child.", - "1_female": "Mark my words. Not being able to measure your own strength shows that you are still a child." - } - }, - "rocket_boss_giovanni_2": { - "encounter": { - "1": "My old associates need me... Are you going to get in my way?" - }, - "victory": { - "1": "How is this possible...? The precious dream of Team Rocket has become little more than an illusion..." - }, - "defeat": { - "1": "Team Rocket will be reborn again, and I will rule the world!" - } - }, - "magma_boss_maxie_1": { - "encounter": { - "1": "I will bury you by my own hand. I hope you appreciate this honor!" - }, - "victory": { - "1": "Ugh! You are... quite capable...\nI fell behind, but only by an inch..." - }, - "defeat": { - "1": "Team Magma will prevail!" - } - }, - "magma_boss_maxie_2": { - "encounter": { - "1": "You are the final obstacle remaining between me and my goals.\n$Brace yourself for my ultimate attack! Fuhahaha!" - }, - "victory": { - "1": "This... This is not.. Ngh..." - }, - "defeat": { - "1": "And now... I will transform this planet to a land ideal for humanity." - } - }, - "aqua_boss_archie_1": { - "encounter": { - "1": "I'm the leader of Team Aqua, so I'm afraid it's the rope's end for you." - }, - "victory": { - "1": "Let's meet again somewhere. I'll be sure to remember that face." - }, - "defeat": { - "1": "Brilliant! My team won't hold back now!" - } - }, - "aqua_boss_archie_2": { - "encounter": { - "1": "I've been waiting so long for this day to come.\nThis is the true power of my team!" - }, - "victory": { - "1": "Like I figured..." - }, - "defeat": { - "1": "I'll return everything in this world to its original, pure state!!" - } - }, - "galactic_boss_cyrus_1": { - "encounter": { - "1": "You were compelled to come here by such vacuous sentimentality.\n$I will make you regret paying heed to your heart!", - "1_female": "You were compelled to come here by such vacuous sentimentality.\n$I will make you regret paying heed to your heart!" - }, - "victory": { - "1": "Interesting. And quite curious." - }, - "defeat": { - "1": "I will create my new world..." - } - }, - "galactic_boss_cyrus_2": { - "encounter": { - "1": "So we meet again. It seems our fates have become intertwined.\n$But here and now, I will finally break that bond!" - }, - "victory": { - "1": "How? How? HOW?!" - }, - "defeat": { - "1": "Farewell." - } - }, - "plasma_boss_ghetsis_1": { - "encounter": { - "1": "I won't allow anyone to stop me! No matter who does what!" - }, - "victory": { - "1": "How can this be? I'm the creator of Team Plasma! I'm perfect!" - }, - "defeat": { - "1": "I am the perfect ruler of a perfect new world! Mwa ha ha!" - } - }, - "plasma_boss_ghetsis_2": { - "encounter": { - "1": "Come now! I want to see your face at the moment you lose all hope!" - }, - "victory": { - "1": "My calculations... No! My careful schemes! The world should be mine!" - }, - "defeat": { - "1": "Kyurem! Use Absofusion!" - } - }, - "flare_boss_lysandre_1": { - "encounter": { - "1": "Do you want to stop me? Show me in battle." - }, - "victory": { - "1": "You are here to stop me. But I ask you to wait. " - }, - "defeat": { - "1": "Pokemon...Shall no longer exist." - } - }, - "flare_boss_lysandre_2": { - "encounter": { - "1": "The future you want, or the future I want... Let us see which one is more deserving, shall we?" - }, - "victory": { - "1": "Whaugh!" - }, - "defeat": { - "1": "Fools with no vision will continue to befoul this beautiful world." - } - }, - "aether_boss_lusamine_1": { - "encounter": { - "1": "You're going to startle my sweet beast! It looks like I'll need to silence you first." - }, - "victory": { - "1": "How... how can you be so awful!" - }, - "defeat": { - "1": "Hmph..." - } - }, - "aether_boss_lusamine_2": { - "encounter": { - "1": "Why must you continue to pester me?! I am sick of you. Sick through and through!\n$Enough with this useless talk.. with Nihilego's power I will show you how wrong you were to come here!" - }, - "victory": { - "1": "Aaauuuggghhhhhhhhh!!!" - }, - "defeat": { - "1": "All that I want is my precious beast! I don't care about any of the rest of you!" - } - }, - "skull_boss_guzma_1": { - "encounter": { - "1": "The hated boss who beats you down and beats you down and never lets up...\n$Yeah. Big bad Guzma is here!" - }, - "victory": { - "1": "Tch. I'm gonna beat you down one of these days!" - }, - "defeat": { - "1": "And you came all the way out here just for that, huh?" - } - }, - "skull_boss_guzma_2": { - "encounter": { - "1": "Doesn't matter who I'm up against, I'm gonna beat them down!\n$That's what big bad Guzma is all about!" - }, - "victory": { - "1": "Guzma!!! What is wrong with you?!" - }, - "defeat": { - "1": "Y'all are stupid!" - } - }, - "macro_boss_rose_1": { - "encounter": { - "1": "I must provide limitless energy to ensure everlasting prosperity for everyone...\n$It is my purpose, my duty, my destiny!" - }, - "victory": { - "1": "You still don't understand, trainer...\n$We... No, I am going to change the course of history!" - }, - "defeat": { - "1": "You still don't understand a thing!" - } - }, - "macro_boss_rose_2": { - "encounter": { - "1": "I'm committed to solving the energy problem in the Galar region—and, of course, around the world.\n$My experience and accomplishments that made Macro Cosmos a success are proof my methods work.\n$I don't intend to change my mind, even if I lose." - }, - "victory": { - "1": "I'd forgotten how great Pokémon battles are! It's been so long since I battled...\n$That sure was satisfying, I accept defeat for this battle." - }, - "defeat": { - "1": "I suppose it must seem that I am doing something terrible. I don't expect you to understand.\n$But I must provide the Galar region with limitless energy to ensure everlasting prosperity." - } - }, - "stat_trainer_buck": { - "encounter": { - "1": "...I'm telling you right now. I'm seriously tough. Act surprised!", - "2": "I can feel my Pokémon shivering inside their Pokéballs!" - }, - "victory": { - "1": "Heeheehee!\nSo hot, you!", - "2": "Heeheehee!\nSo hot, you!" - }, - "defeat": { - "1": "Whoa! You're all out of gas, I guess.", - "2": "Whoa! You're all out of gas, I guess." - } - }, - "stat_trainer_cheryl": { - "encounter": { - "1": "My Pokémon have been itching for a battle.", - "2": "I should warn you, my Pokémon can be quite rambunctious." - }, - "victory": { - "1": "Striking the right balance of offense and defense... It's not easy to do.", - "2": "Striking the right balance of offense and defense... It's not easy to do." - }, - "defeat": { - "1": "Do your Pokémon need any healing?", - "2": "Do your Pokémon need any healing?" - } - }, - "stat_trainer_marley": { - "encounter": { - "1": "... OK.\nI'll do my best.", - "2": "... OK.\nI... won't lose...!" - }, - "victory": { - "1": "... Awww.", - "2": "... Awww." - }, - "defeat": { - "1": "... Goodbye.", - "2": "... Goodbye." - } - }, - "stat_trainer_mira": { - "encounter": { - "1": "You will be shocked by Mira!", - "2": "Mira will show you that Mira doesn't get lost anymore!" - }, - "victory": { - "1": "Mira wonders if she can get very far in this land.", - "2": "Mira wonders if she can get very far in this land." - }, - "defeat": { - "1": "Mira knew she would win!", - "2": "Mira knew she would win!" - } - }, - "stat_trainer_riley": { - "encounter": { - "1": "Battling is our way of greeting!", - "2": "We're pulling out all the stops to put your Pokémon down." - }, - "victory": { - "1": "At times we battle, and sometimes we team up...$It's great how Trainers can interact.", - "2": "At times we battle, and sometimes we team up...$It's great how Trainers can interact." - }, - "defeat": { - "1": "You put up quite the display.\nBetter luck next time.", - "2": "You put up quite the display.\nBetter luck next time." - } - }, - "winstrates_victor": { - "encounter": { - "1": "That's the spirit! I like you!" - }, - "victory": { - "1": "A-ha! You're stronger than I thought!" - } - }, - "winstrates_victoria": { - "encounter": { - "1": "My goodness! Aren't you young?$You must be quite the trainer to beat my husband, though.$Now I suppose it's my turn to battle!" - }, - "victory": { - "1": "Uwah! Just how strong are you?!" - } - }, - "winstrates_vivi": { - "encounter": { - "1": "You're stronger than Mom? Wow!$But I'm strong, too!\nReally! Honestly!" - }, - "victory": { - "1": "Huh? Did I really lose?\nSnivel... Grandmaaa!" - } - }, - "winstrates_vicky": { - "encounter": { - "1": "How dare you make my precious\ngranddaughter cry!$I see I need to teach you a lesson.\nPrepare to feel the sting of defeat!" - }, - "victory": { - "1": "Whoa! So strong!\nMy granddaughter wasn't lying." - } - }, - "winstrates_vito": { - "encounter": { - "1": "I trained together with my whole family,\nevery one of us!$I'm not losing to anyone!" - }, - "victory": { - "1": "I was better than everyone in my family.\nI've never lost before..." - } - }, - "brock": { - "encounter": { - "1": "My expertise on Rock-type Pokémon will take you down! Come on!", - "2": "My rock-hard willpower will overwhelm you!", - "3": "Allow me to show you the true strength of my Pokémon!" - }, - "victory": { - "1": "Your Pokémon's strength have overcome my rock-hard defenses!", - "2": "The world is huge! I'm glad to have had a chance to battle you.", - "3": "Perhaps I should go back to pursuing my dream as a Pokémon Breeder…" - }, - "defeat": { - "1": "The best offense is a good defense!\nThat's my way of doing things!", - "2": "Come study rocks with me next time to better learn how to fight them!", - "3": "Hah, all my traveling around the regions is paying off!" - } - }, - "misty": { - "encounter": { - "1": "My policy is an all out offensive with Water-type Pokémon!", - "1_female": "My policy is an all out offensive with Water-type Pokémon!", - "2": "Hiya, I'll show you the strength of my aquatic Pokémon!", - "3": "My dream was to go on a journey and battle powerful trainers…\nWill you be a sufficient challenge?" - }, - "victory": { - "1": "You really are strong… I'll admit that you are skilled…", - "2": "Grrr… You know you just got lucky, right?!", - "3": "Wow, you're too much! I can't believe you beat me!" - }, - "defeat": { - "1": "Was the mighty Misty too much for you?", - "2": "I hope you saw my Pokémon's elegant swimming techniques!", - "3": "Your Pokémon were no match for my pride and joys!" - } - }, - "lt_surge": { - "encounter": { - "1": "My Electric Pokémon saved me during the war! I'll show you how!", - "1_female": "My Electric Pokémon saved me during the war! I'll show you how!", - "2": "Ten-hut! I'll shock you into surrender!", - "3": "I'll zap you just like I do to all my enemies in battle!" - }, - "victory": { - "1": "Whoa! Your team's the real deal, kid!", - "2": "Aaargh, you're strong! Even my electric tricks lost against you.", - "2_female": "Aaargh, you're strong! Even my electric tricks lost against you.", - "3": "That was an absolutely shocking loss!" - }, - "defeat": { - "1": "Oh yeah! When it comes to Electric-type Pokémon, I'm number one in the world!", - "2": "Hahaha! That was an electrifying battle, kid!", - "3": "A Pokémon battle is war, and I have showed you first-hand combat!" - } - }, - "erika": { - "encounter": { - "1": "Ah, the weather is lovely here…\nOh, a battle? Very well then.", - "2": "My Pokémon battling skills rival that of my flower arranging skills.", - "3": "Oh, I hope the pleasant aroma of my Pokémon doesn't put me to sleep again…", - "4": "Seeing flowers in a garden is so soothing." - }, - "victory": { - "1": "Oh! I concede defeat.", - "2": "That match was most delightful.", - "3": "Ah, it appears it is my loss…", - "4": "Oh, my goodness." - }, - "defeat": { - "1": "I was afraid I would doze off…", - "2": "Oh my, it seems my Grass Pokémon overwhelmed you.", - "2_female": "Oh my, it seems my Grass Pokémon overwhelmed you.", - "3": "That battle was such a soothing experience.", - "4": "Oh… Is that all?" - } - }, - "janine": { - "encounter": { - "1": "I am mastering the art of poisonous attacks.\nI shall spar with you today!", - "2": "Father trusts that I can hold my own.\nI will prove him right!", - "3": "My ninja techniques are only second to my Father's!\nCan you keep up?" - }, - "victory": { - "1": "Even now, I still need training… I understand.", - "2": "Your battle technique has outmatched mine.", - "3": "I'm going to really apply myself and improve my skills." - }, - "defeat": { - "1": "Fufufu… the poison has sapped all your strength to battle.", - "2": "Ha! You didn't stand a chance against my superior ninja skills!", - "3": "Father's faith in me has proven to not be misplaced." - } - }, - "sabrina": { - "encounter": { - "1": "Through my psychic ability, I had a vision of your arrival!", - "2": "I dislike fighting, but if you wish, I will show you my powers!", - "3": "I can sense great ambition in you. I shall see if it not unfounded." - }, - "victory": { - "1": "Your power… It far exceeds what I foresaw…", - "2": "I failed to accurately predict your power.", - "3": "Even with my immense psychic powers, I cannot sense another as strong as you." - }, - "defeat": { - "1": "This victory… It is exactly as I foresaw in my visions!", - "2": "Perhaps it was another I sensed a great desire in…", - "3": "Hone your abilities before recklessly charging into battle.\nYou never know what the future may hold if you do…" - } - }, - "blaine": { - "encounter": { - "1": "Hah! Hope you brought a Burn Heal!", - "2": "My fiery Pokémon will incinerate all challengers!", - "3": "Get ready to play with fire!" - }, - "victory": { - "1": "I have burned down to nothing! Not even ashes remain!", - "2": "Didn't I stoke the flames high enough?", - "3": "I'm all burned out… But this makes my motivation to improve burn even hotter!" - }, - "defeat": { - "1": "My raging inferno cannot be quelled!", - "2": "My Pokémon have been powered up with the heat from this victory!", - "3": "Hah! My passion burns brighter than yours!" - } - }, - "giovanni": { - "encounter": { - "1": "I, the leader of Team Rocket, will make you feel a world of pain!", - "2": "My training here will be vital before I am to face my old associates again.", - "3": "I do not think you are prepared for the level of failure you are about to experience!", - "3_female": "I do not think you are prepared for the level of failure you are about to experience!" - }, - "victory": { - "1": "WHAT! Me, lose?! There is nothing I wish to say to you!", - "2": "Hmph… You could never understand what I hope to achieve.", - "3": "This defeat is merely delaying the inevitable.\nI will rise Team Rocket from the ashes in due time." - }, - "defeat": { - "1": "Not being able to measure your own strength shows that you are still but a child.", - "2": "Do not try to interfere with me again.", - "3": "I hope you understand how foolish challenging me was." - } - }, - "roxanne": { - "encounter": { - "1": "Would you kindly demonstrate how you battle?", - "2": "You can learn many things by battling many trainers.", - "3": "Oh, you caught me strategizing.\nWould you like to battle?" - }, - "victory": { - "1": "Oh, I appear to have lost.\nI understand.", - "2": "It seems that I still have so much more to learn when it comes to battle.", - "3": "I'll take what I learned here today to heart." - }, - "defeat": { - "1": "I have learned many things from our battle.\nI hope you have too.", - "2": "I look forward to battling you again.\nI hope you'll use what you've learned here.", - "3": "I won due to everything I have learned." - } - }, - "brawly": { - "encounter": { - "1": "Oh man, a challenger!\nLet's see what you can do!", - "1_female": "Oh man, a challenger!\nLet's see what you can do!", - "2": "You seem like a big splash.\nLet's battle!", - "3": "Time to create a storm!\nLet's go!" - }, - "victory": { - "1": "Oh woah, you've washed me out!", - "2": "You surfed my wave and crashed me down!", - "3": "I feel like I'm lost in Granite Cave!" - }, - "defeat": { - "1": "Haha, I surfed the big wave!\nChallenge me again sometime.", - "2": "Surf with me again some time!", - "3": "Just like the tides come in and out, I hope you return to challenge me again." - } - }, - "wattson": { - "encounter": { - "1": "Time to get shocked!\nWahahahaha!", - "2": "I'll make sparks fly!\nWahahahaha!", - "3": "I hope you brought Paralyz Heal!\nWahahahaha!" - }, - "victory": { - "1": "Seems like I'm out of charge!\nWahahahaha!", - "2": "You've completely grounded me!\nWahahahaha!", - "3": "Thanks for the thrill!\nWahahahaha!" - }, - "defeat": { - "1": "Recharge your batteries and challenge me again sometime!\nWahahahaha!", - "1_female": "Recharge your batteries and challenge me again sometime!\nWahahahaha!", - "2": "I hope you found our battle electrifying!\nWahahahaha!", - "3": "Aren't you shocked I won?\nWahahahaha!" - } - }, - "flannery": { - "encounter": { - "1": "Nice to meet you! Wait, no…\nI will crush you!", - "2": "I've only been a leader for a little while, but I'll smoke you!", - "3": "It's time to demonstrate the moves my grandfather has taught me! Let's battle!" - }, - "victory": { - "1": "You remind me of my grandfather…\nNo wonder I lost.", - "2": "Am I trying too hard?\nI should relax, can't get too heated.", - "3": "Losing isn't going to smother me out.\nTime to reignite training!" - }, - "defeat": { - "1": "I hope I've made my grandfather proud…\nLet's battle again some time.", - "2": "I…I can't believe I won!\nDoing things my way worked!", - "3": "Let's exchange burning hot moves again soon!" - } - }, - "norman": { - "encounter": { - "1": "I'm surprised you managed to get here.\nLet's battle.", - "2": "I'll do everything in my power as a Gym Leader to win.\nLet's go!", - "3": "You better give this your all.\nIt's time to battle!" - }, - "victory": { - "1": "I lost to you…?\nRules are rules, though.", - "2": "Was moving from Olivine a mistake…?", - "3": "I can't believe it.\nThat was a great match." - }, - "defeat": { - "1": "We both tried our best.\nI hope we can battle again soon.", - "2": "You should try challenging my kid instead.\nYou might learn something!", - "3": "Thank you for the excellent battle.\nBetter luck next time." - } - }, - "winona": { - "encounter": { - "1": "I've been soaring the skies looking for prey…\nAnd you're my target!", - "2": "No matter how our battle is, my Flying Pokémon and I will triumph with grace. Let's battle!", - "3": "I hope you aren't scared of heights.\nLet's ascend!" - }, - "victory": { - "1": "You're the first Trainer I've seen with more grace than I.\nExcellently played.", - "1_female": "You're the first Trainer I've seen with more grace than I.\nExcellently played.", - "2": "Oh, my Flying Pokémon have plummeted!\nVery well.", - "3": "Though I may have fallen, my Pokémon will continue to fly!" - }, - "defeat": { - "1": "My Flying Pokémon and I will forever dance elegantly!", - "2": "I hope you enjoyed our show.\nOur graceful dance is finished.", - "3": "Won't you come see our elegant choreography again?" - } - }, - "tate": { - "encounter": { - "1": "Hehehe…\nWere you surprised to see me without my sister?", - "1_female": "Hehehe…\nWere you surprised to see me without my sister?", - "2": "I can see what you're thinking…\nYou want to battle!", - "3": "How can you defeat someone…\nWho knows your every move?" - }, - "victory": { - "1": "It can't be helped…\nI miss Liza…", - "2": "Your bond with your Pokémon was stronger than mine.", - "3": "If I were with Liza, we would have won.\nWe can finish each other's thoughts!" - }, - "defeat": { - "1": "My Pokémon and I are superior!", - "2": "If you can't even defeat me, you'll never be able to defeat Liza either.", - "3": "It's all thanks to my strict training with Liza.\nI can make myself one with Pokémon." - } - }, - "liza": { - "encounter": { - "1": "Fufufu…\nWere you surprised to see me without my brother?", - "1_female": "Fufufu…\nWere you surprised to see me without my brother?", - "2": "I can determine what you desire…\nYou want to battle, don't you?", - "3": "How can you defeat someone…\nWho's one with their Pokémon?" - }, - "victory": { - "1": "It can't be helped…\nI miss Tate…", - "2": "Your bond with your Pokémon…\nIt's stronger than mine.", - "3": "If I were with Tate, we would have won.\nWe can finish each other's sentences!" - }, - "defeat": { - "1": "My Pokémon and I are victorious.", - "2": "If you can't even defeat me, you'll never be able to defeat Tate either.", - "3": "It's all thanks to my strict training with Tate.\nI can synchronize myself with my Pokémon." - } - }, - "juan": { - "encounter": { - "1": "Now's not the time to act coy.\nLet's battle!", - "2": "Ahahaha, You'll be witness to my artistry with Water Pokémon!", - "3": "A typhoon approaches!\nWill you be able to test me?", - "4": "Please, you shall bear witness to our artistry.\nA grand illusion of water sculpted by my Pokémon and myself!" - }, - "victory": { - "1": "You may be a genius who can take on Wallace!", - "2": "I focused on elegance while you trained.\nIt's only natural that you defeated me.", - "3": "Ahahaha!\nVery well, You have won this time.", - "4": "From you, I sense the brilliant shine of skill that will overcome all." - }, - "defeat": { - "1": "My Pokémon and I have sculpted an illusion of Water and come out victorious.", - "2": "Ahahaha, I have won, and you have lost.", - "3": "Shall I loan you my outfit? It may help you battle!\nAhahaha, I jest!", - "4": "I'm the winner! Which is to say, you lost." - } - }, - "crasher_wake": { - "encounter": { - "1": "Crash! Crash! Watch out!\nCrasher Wake…is…heeere!", - "2": "Crash! Crash! Crasher Wake!", - "3": "I'm the tidal wave of power to wash you away!" - }, - "victory": { - "1": "That puts a grin on my face!\nGuhahaha! That was a blast!", - "2": "Hunwah! It's gone and ended!\nHow will I say this…\nI want more! I wanted to battle a lot more!", - "3": "WHAAAAT!?" - }, - "defeat": { - "1": "Yeeeeah! That's right!", - "2": "I won, but I want more! I wanted to battle a lot more!", - "3": "So long!" - } - }, - "falkner": { - "encounter": { - "1": "I'll show you the real power of the magnificent bird Pokémon!", - "2": "Winds, stay with me!", - "3": "Dad! I hope you're watching me battle from above!" - }, - "victory": { - "1": "I understand… I'll bow out gracefully.", - "2": "A defeat is a defeat. You are strong indeed.", - "3": "…Shoot! Yeah, I lost." - }, - "defeat": { - "1": "Dad! I won with your cherished bird Pokémon…", - "2": "Bird Pokémon are the best after all!", - "3": "Feels like I'm catching up to my dad!" - } - }, - "nessa": { - "encounter": { - "1": "No matter what kind of plan your refined mind may be plotting, my partner and I will be sure to sink it.", - "1_female": "No matter what kind of plan your refined mind may be plotting, my partner and I will be sure to sink it.", - "2": "I'm not here to chat. I'm here to win!", - "3": "This is a little gift from my Pokémon… I hope you can take it!", - "3_female": "This is a little gift from my Pokémon… I hope you can take it!" - }, - "victory": { - "1": "You and your Pokémon are just too much…", - "2": "How…? How can this be?!", - "3": "I was totally washed away!" - }, - "defeat": { - "1": "The raging wave crashes again!", - "2": "Time to ride the wave of victory!", - "3": "Ehehe!" - } - }, - "melony": { - "encounter": { - "1": "I'm not going to hold back!", - "2": "All righty, I suppose we should get started.", - "3": "I'll freeze you solid!" - }, - "victory": { - "1": "You… You're pretty good, huh?", - "1_female": "You… You're pretty good, huh?", - "2": "If you find Gordie around, be sure to give him a right trashing, would you?", - "3": "I think you took breaking the ice a little too literally…" - }, - "defeat": { - "1": "Now do you see how severe battles can be?", - "2": "Hee! Looks like I went and won again!", - "3": "Are you holding back?" - } - }, - "marlon": { - "encounter": { - "1": "You look strong! Shoots! Let's start!", - "2": "I'm strong like the ocean's wide. You're gonna get swept away, fo' sho'.", - "2_female": "I'm strong like the ocean's wide. You're gonna get swept away, fo' sho'.", - "3": "Oh ho, so I'm facing you! That's off the wall." - }, - "victory": { - "1": "You totally rocked that! You're raising some wicked Pokémon. You got this Trainer thing down!", - "1_female": "You totally rocked that! You're raising some wicked Pokémon. You got this Trainer thing down!", - "2": "You don't just look strong, you're strong fo' reals! Eh, I was swept away, too!", - "3": "You're strong as a gnarly wave!" - }, - "defeat": { - "1": "You're tough, but it's not enough to sway the sea, 'K!", - "2": "Hee! Looks like I went and won again!", - "3": "Sweet, sweet victory!" - } - }, - "shauntal": { - "encounter": { - "1": "Excuse me. You're a challenger, right?\nI'm the Elite Four's Ghost-type Pokémon user, Shauntal, and I shall be your opponent.", - "1_female": "Excuse me. You're a challenger, right?\nI'm the Elite Four's Ghost-type Pokémon user, Shauntal, and I shall be your opponent.", - "2": "I absolutely love writing about Trainers who come here and the Pokémon they train.\nCould I use you and your Pokémon as a subject?", - "3": "Every person who works with Pokémon has a story to tell.\nWhat story is about to be told?" - }, - "victory": { - "1": "Wow. I'm dumbstruck!", - "2": "S-sorry! First, I must apologize to my Pokémon…\n\nI'm really sorry you had a bad experience because of me!", - "3": "Even in light of that, I'm still one of the Elite Four!" - }, - "defeat": { - "1": "Eheh.", - "2": "That gave me excellent material for my next novel!", - "3": "And so, another tale ends…" - } - }, - "marshal": { - "encounter": { - "1": "My mentor, Alder, sees your potential as a Trainer and is taking an interest in you.\nIt is my intention to test you--to take you to the limits of your strength. Kiai!", - "1_female": "My mentor, Alder, sees your potential as a Trainer and is taking an interest in you.\nIt is my intention to test you--to take you to the limits of your strength. Kiai!", - "2": "Victory, decisive victory, is my intention! Challenger, here I come!", - "3": "In myself, I seek to develop the strength of a fighter and shatter any weakness in myself!\nPrevailing with the force of my convictions!" - }, - "victory": { - "1": "Whew! Well done!", - "2": "As your battles continue, aim for even greater heights!", - "3": "The strength shown by you and your Pokémon has deeply impressed me…" - }, - "defeat": { - "1": "Hmm.", - "2": "That was good battle.", - "3": "Haaah! Haaah! Haiyaaaah!" - } - }, - "cheren": { - "encounter": { - "1": "You remind me of an old friend. That makes me excited about this Pokémon battle!", - "2": "Pokémon battles have no meaning if you don't think why you battle.\n$Or better said, it makes battling together with Pokémon meaningless.", - "3": "My name's Cheren! I'm a Gym Leader and a teacher! Pleasure to meet you.", - "3_female": "My name's Cheren! I'm a Gym Leader and a teacher! Pleasure to meet you." - }, - "victory": { - "1": "Thank you! I saw what was missing in me.", - "2": "Thank you! I feel like I saw a little of the way toward my ideals.", - "3": "Hmm… This is problematic." - }, - "defeat": { - "1": "As a Gym Leader, I aim to be a wall for you to overcome.", - "2": "All right!", - "3": "I made it where I am because Pokémon were by my side.\nPerhaps we need to think about why Pokémon help us not in terms of Pokémon and Trainers but as a relationship between living beings." - } - }, - "chili": { - "encounter": { - "1": "Yeeeeooow! Time to play with FIRE!! I'm the strongest of us brothers!", - "1_female": "Yeeeeooow! Time to play with FIRE!! I'm the strongest of us brothers!", - "2": "Ta-da! The Fire-type scorcher Chili--that's me--will be your opponent!", - "2_female": "Ta-da! The Fire-type scorcher Chili--that's me--will be your opponent!", - "3": "I'm going to show you what me and my blazing Fire types can do!", - "3_female": "I'm going to show you what me and my blazing Fire types can do!" - }, - "victory": { - "1": "You got me. I am… burned… out…", - "1_female": "You got me. I am… burned… out…", - "2": "Whoa ho! You're on fire!", - "2_female": "Whoa ho! You're on fire!", - "3": "Augh! You got me!" - }, - "defeat": { - "1": "I'm on fire! Play with me, and you'll get burned!", - "1_female": "I'm on fire! Play with me, and you'll get burned!", - "2": "When you play with fire, you get burned!", - "3": "I mean, c'mon, your opponent was me! You didn't have a chance!", - "3_female": "I mean, c'mon, your opponent was me! You didn't have a chance!" - } - }, - "cilan": { - "encounter": { - "1": "Nothing personal... No hard feelings... Me and my Grass-type Pokémon will...\n$Um... We're gonna battle come what may.", - "1_female": "Nothing personal... No hard feelings... Me and my Grass-type Pokémon will...\n$Um... We're gonna battle come what may.", - "2": "So, um, if you're OK with me, I'll, um, put everything I've got into being, er, you know, your opponent.", - "2_female": "So, um, if you're OK with me, I'll, um, put everything I've got into being, er, you know, your opponent.", - "3": "OK… So, um, I'm Cilan, I like Grass-type Pokémon.", - "3_female": "OK… So, um, I'm Cilan, I like Grass-type Pokémon." - }, - "victory": { - "1": "Er… Is it over now?", - "1_female": "Er… Is it over now?", - "2": "…What a surprise. You are very strong, aren't you? \n$I guess my brothers wouldn't have been able to defeat you either…", - "2_female": "…What a surprise. You are very strong, aren't you? \n$I guess my brothers wouldn't have been able to defeat you either…", - "3": "…Huh. Looks like my timing was, um, off?" - }, - "defeat": { - "1": "Huh? Did I win?", - "1_female": "Huh? Did I win?", - "2": "I guess… \n$I suppose I won, because I've been competing with my brothers Chili and Cress, and we all were able to get tougher.", - "2_female": "I guess… \n$I suppose I won, because I've been competing with my brothers Chili and Cress, and we all were able to get tougher.", - "3": "It…it was quite a thrilling experience…", - "3_female": "It…it was quite a thrilling experience…" - } - }, - "roark": { - "encounter": { - "1": "I need to see your potential as a Trainer. And, I'll need to see the toughness of the Pokémon that battle with you!", - "1_female": "I need to see your potential as a Trainer. And, I'll need to see the toughness of the Pokémon that battle with you!", - "2": "Here goes! These are my rocking Pokémon, my pride and joy!", - "3": "Rock-type Pokémon are simply the best!", - "4": "Every day, I toughened up my Pokémon by digging up Fossils nonstop.\n$Could I show you how tough I made them in a battle?", - "4_female": "Every day, I toughened up my Pokémon by digging up Fossils nonstop.\n$Could I show you how tough I made them in a battle?" - }, - "victory": { - "1": "W-what? That can't be! My buffed-up Pokémon!", - "2": "…We lost control there. Next time I'd like to challenge you to a Fossil-digging race underground.", - "2_female": "…We lost control there. Next time I'd like to challenge you to a Fossil-digging race underground.", - "3": "With skill like yours, it's natural for you to win.", - "4": "Wh-what?! It can't be! Even that wasn't enough?" - }, - "defeat": { - "1": "See? I'm proud of my rocking battle style!", - "2": "Thanks! The battle gave me confidence that I may be able to beat my dad!", - "3": "See? These are my rocking Pokémon, my pride and joy!", - "4": "I knew I would win!" - } - }, - "morty": { - "encounter": { - "1": "With a little more, I could see a future in which I meet the legendary Pokémon.\n$You're going to help me reach that level!", - "2": "It's said that a rainbow-hued Pokémon will come down to appear before a truly powerful Trainer. \n$I believed that tale, so I have secretly trained here all my life. As a result, I can now see what others cannot. \n$I see a shadow of the person who will make the Pokémon appear. \n$I believe that person is me! You're going to help me reach that level!", - "3": "Whether you choose to believe or not, mystic power does exist.", - "4": "You can bear witness to the fruits of my training.", - "5": "You must make your soul one with that of Pokémon. Can you do this?", - "6": "Say, do you want to be part of my training?" - }, - "victory": { - "1": "I'm not good enough yet…", - "2": "I see… Your journey has taken you to far-away places and you have witnessed much more than I.\n$I envy you for that…", - "2_female": "I see… Your journey has taken you to far-away places and you have witnessed much more than I.\n$I envy you for that…", - "3": "How is this possible…", - "4": "I don't think our potentials are so different.\n$But you seem to have something more than that… So be it.", - "5": "Guess I need more training.", - "6": "That's a shame." - }, - "defeat": { - "1": "I moved… one step ahead again.", - "2": "Fufufu…", - "3": "Wh-what?! It can't be! Even that wasn't enough?", - "4": "I feel like I just smashed through a really stubborn boulder!", - "5": "Ahahahah!", - "6": "I knew I would win!" - } - }, - "crispin": { - "encounter": { - "1": "I wanna win, so that's exactly what I'll do!", - "2": "I battle because I wanna battle! And you know what? That's how it should be!" - }, - "victory": { - "1": "I wanted to win…but I lost!", - "2": "I lost…'cause I couldn't win!" - }, - "defeat": { - "1": "Hey, wait a sec. Did I just win? I think I just won! Talk about satisfying!", - "2": "Wooo! That was amazing!" - } - }, - "amarys": { - "encounter": { - "1": "I want to be the one to help a certain person. That being the case, I cannot afford to lose.\n$… Our battle starts now." - }, - "victory": { - "1": "I am… not enough, I see." - }, - "defeat": { - "1": "Victory belongs to me. Well fought." - } - }, - "lacey": { - "encounter": { - "1": "I'll be facing you with my usual party as a member of the Elite Four." - }, - "victory": { - "1": "That was a great battle!" - }, - "defeat": { - "1": "Let's give your Pokémon a nice round of applause for their efforts!" - } - }, - "drayton": { - "encounter": { - "1": "Man, I love chairs. Don't you love chairs? What lifesavers. \n$I don't get why everyone doesn't just sit all the time. Standing up's tiring work!" - }, - "victory": { - "1": "Guess I should've expected that!" - }, - "defeat": { - "1": "Heh heh! Don't mind me, just scooping up a W over here. I get it if you're upset, but don't go full Kieran on me, OK?", - "1_female": "Heh heh! Don't mind me, just scooping up a W over here. I get it if you're upset, but don't go full Kieran on me, OK?" - } - }, - "ramos": { - "encounter": { - "1": "Did yeh enjoy the garden playground I made with all these sturdy plants o' mine?\n$Their strength is a sign o' my strength as a gardener and a Gym Leader! Yeh sure yer up to facing all that?", - "1_female": "Did yeh enjoy the garden playground I made with all these sturdy plants o' mine?\n$Their strength is a sign o' my strength as a gardener and a Gym Leader! Yeh sure yer up to facing all that?" - }, - "victory": { - "1": "Yeh believe in yer Pokémon… And they believe in yeh, too… It was a fine battle, sprout." - }, - "defeat": { - "1": "Hohoho… Indeed. Frail little blades o' grass'll break through even concrete." - } - }, - "viola": { - "encounter": { - "1": "Whether it's the tears of frustration that follow a loss or the blossoming of joy that comes with victory…\n$They're both great subjects for my camera! Fantastic! This'll be just fantastic! \n$Now come at me!", - "2": "My lens is always focused on victory--I won't let anything ruin this shot!" - }, - "victory": { - "1": "You and your Pokémon have shown me a whole new depth of field! Fantastic! Just fantastic!", - "2": "The world you see through a lens, and the world you see with a Pokémon by your side…\n$The same world can look entirely different depending on your view." - }, - "defeat": { - "1": "The photo from the moment of my victory will be a real winner, all right!", - "2": "Yes! I took some great photos!" - } - }, - "candice": { - "encounter": { - "1": "You want to challenge Candice? Sure thing! I was waiting for someone tough! \n$But I should tell you, I'm tough because I know how to focus.", - "2": "Pokémon, fashion, romance… It's all about focus! \n$I'll show you just what I mean. Get ready to lose!" - }, - "victory": { - "1": "I must say, I'm warmed up to you! I might even admire you a little.", - "2": "Wow! You're great! You've earned my respect! \n$I think your focus and will bowled us over totally. ", - "2_female": "Wow! You're great! You've earned my respect! \n$I think your focus and will bowled us over totally. " - }, - "defeat": { - "1": "I sensed your will to win, but I don't lose!", - "2": "See? Candice's focus! My Pokémon's focus is great, too!" - } - }, - "gardenia": { - "encounter": { - "1": "You have a winning aura about you. So, anyway, this will be fun. Let's have our battle!" - }, - "victory": { - "1": "Amazing! You're very good, aren't you?", - "1_female": "Amazing! You're very good, aren't you?" - }, - "defeat": { - "1": "Yes! My Pokémon and I are perfectly good!" - } - }, - "aaron": { - "encounter": { - "1": "Ok! Let me take you on!" - }, - "victory": { - "1": "Battling is a deep and complex affair…" - }, - "defeat": { - "1": "Victory over an Elite Four member doesn't come easily." - } - }, - "cress": { - "encounter": { - "1": "That is correct! It shall be I and my esteemed Water types that you must face in battle!" - }, - "victory": { - "1": "Lose? Me? I don't believe this." - }, - "defeat": { - "1": "This is the appropriate result when I'm your opponent." - } - }, - "allister": { - "encounter": { - "1": "'M Allister.\nH-here… I go…" - }, - "victory": { - "1": "I nearly lost my mask from the shock… That was…\n$Wow. I can see your skill for what it is." - }, - "defeat": { - "1": "Th-that was ace!" - } - }, - "clay": { - "encounter": { - "1": "Harrumph! Kept me waitin', didn't ya, kid? All right, time to see what ya can do!", - "1_female": "Harrumph! Kept me waitin', didn't ya, kid? All right, time to see what ya can do!" - }, - "victory": { - "1": "Man oh man… It feels good to go all out and still be defeated!" - }, - "defeat": { - "1": "What's important is how ya react to losin'. \n$That's why folks who use losin' as fuel to get better are tough." - } - }, - "kofu": { - "encounter": { - "1": "I'mma serve you a full course o' Water-type Pokémon! Don't try to eat 'em, though!" - }, - "victory": { - "1": "Vaultin' Veluza! Yer a lively one, aren't ya! A little TOO lively, if I do say so myself!", - "1_female": "Vaultin' Veluza! Yer a lively one, aren't ya! A little TOO lively, if I do say so myself!" - }, - "defeat": { - "1": "You come back to see me again now, ya hear?" - } - }, - "tulip": { - "encounter": { - "1": "Allow me to put my skills to use to make your cute little Pokémon even more beautiful!" - }, - "victory": { - "1": "Your strength has a magic to it that cannot be washed away." - }, - "defeat": { - "1": "You know, in my line of work, people who lack talent in one area or the other often fade away quickly—never to be heard of again." - } - }, - "sidney": { - "encounter": { - "1": "I like that look you're giving me. I guess you'll give me a good match.\n$That's good! Looking real good! All right!\n$You and me, let's enjoy a battle that can only be staged here!" - }, - "victory": { - "1": "Well, how do you like that? I lost! Eh, it was fun, so it doesn't matter." - }, - "defeat": { - "1": "No hard feelings, alright?" - } - }, - "phoebe": { - "encounter": { - "1": "While I trained, I gained the ability to commune with Ghost-type Pokémon. \n$Yes, the bond I developed with Pokémon is extremely tight. \n$So, come on, just try and see if you can even inflict damage on my Pokémon!" - }, - "victory": { - "1": "Oh, darn. I've gone and lost." - }, - "defeat": { - "1": "I look forward to battling you again sometime!" - } - }, - "glacia": { - "encounter": { - "1": "All I have seen are challenges by weak Trainers and their Pokémon. \n$What about you? It would please me to no end if I could go all out against you!" - }, - "victory": { - "1": "You and your Pokémon… How hot your spirits burn!\n$The all-consuming heat overwhelms. \n$It's no surprise that my icy skills failed to harm you." - }, - "defeat": { - "1": "A fiercely passionate battle, indeed." - } - }, - "drake": { - "encounter": { - "1": "For us to battle with Pokémon as partners, do you know what it takes? Do you know what is needed? \n$If you don't, then you will never prevail over me!" - }, - "victory": { - "1": "Superb, it should be said." - }, - "defeat": { - "1": "I gave my all for that battle!" - } - }, - "wallace": { - "encounter": { - "1": "There's something about you… A difference in your demeanor. \n$I think I sense that in you. Now, show me. Show me the power you wield with your Pokémon. \n$And I, in turn, shall present you with a performance of illusions in water by me and my Pokémon!" - }, - "victory": { - "1": "Bravo. I realize now your authenticity and magnificence as a Pokémon Trainer. \n$I find much joy in having met you and your Pokémon. You have proven yourself worthy.", - "1_female": "Bravo. I realize now your authenticity and magnificence as a Pokémon Trainer. \n$I find much joy in having met you and your Pokémon. You have proven yourself worthy." - }, - "defeat": { - "1": "A grand illusion!" - } - }, - "lorelei": { - "encounter": { - "1": "No one can best me when it comes to icy Pokémon! Freezing moves are powerful!\n$Your Pokémon will be at my mercy when they are frozen solid! Hahaha! Are you ready?", - "1_female": "No one can best me when it comes to icy Pokémon! Freezing moves are powerful!\n$Your Pokémon will be at my mercy when they are frozen solid! Hahaha! Are you ready?" - }, - "victory": { - "1": "How dare you!" - }, - "defeat": { - "1": "There's nothing you can do once you're frozen.", - "1_female": "There's nothing you can do once you're frozen." - } - }, - "will": { - "encounter": { - "1": "I have trained all around the world, making my psychic Pokémon powerful.\n$I can only keep getting better! Losing is not an option!" - }, - "victory": { - "1": "I… I can't… believe it…" - }, - "defeat": { - "1": "That was close. I wonder what it is that you lack." - } - }, - "malva": { - "encounter": { - "1": "I feel like my heart might just burst into flames. \n$I'm burning up with my hatred for you, runt!", - "1_female": "I feel like my heart might just burst into flames. \n$I'm burning up with my hatred for you, runt!" - }, - "victory": { - "1": "What news… So a new challenger has defeated Malva!", - "1_female": "What news… So a new challenger has defeated Malva!" - }, - "defeat": { - "1": "I am delighted! Yes, delighted that I could squash you beneath my heel." - } - }, - "hala": { - "encounter": { - "1": "Old Hala is here to make you holler!" - }, - "victory": { - "1": "I could feel the power you gained on your journey." - }, - "defeat": { - "1": "Haha! What a delightful battle!" - } - }, - "molayne": { - "encounter": { - "1": "I gave the captain position to my cousin Sophocles, but I'm confident in my ability. \n$My strength is like that of a supernova!" - }, - "victory": { - "1": "I certainly found an interesting Trainer to face!", - "1_female": "I certainly found an interesting Trainer to face!" - }, - "defeat": { - "1": "Ahaha. What an interesting battle." - } - }, - "rika": { - "encounter": { - "1": "I'd say I'll go easy on you, but… I'd be lying! Think fast!" - }, - "victory": { - "1": "Not bad, kiddo.", - "1_female": "Not bad, kiddo." - }, - "defeat": { - "1": "Nahahaha! You really are something else, kiddo!", - "1_female": "Nahahaha! You really are something else, kiddo!" - } - }, - "bruno": { - "encounter": { - "1": "We will grind you down with our superior power! Hoo hah!" - }, - "victory": { - "1": "Why? How could I lose?" - }, - "defeat": { - "1": "You can challenge me all you like, but the results will never change!" - } - }, - "bugsy": { - "encounter": { - "1": "I'm Bugsy! I never lose when it comes to bug Pokémon!" - }, - "victory": { - "1": "Whoa, amazing! You're an expert on Pokémon!\nMy research isn't complete yet. OK, you win.", - "1_female": "Whoa, amazing! You're an expert on Pokémon!\nMy research isn't complete yet. OK, you win." - }, - "defeat": { - "1": "Thanks! Thanks to our battle, I was also able to make progress in my research!" - } - }, - "koga": { - "encounter": { - "1": "Fwahahahaha! Pokémon are not merely about brute force--you shall see soon enough!" - }, - "victory": { - "1": "Ah! You've proven your worth!" - }, - "defeat": { - "1": "Have you learned to fear the techniques of the ninja?" - } - }, - "bertha": { - "encounter": { - "1": "Well, would you show this old lady how much you've learned?" - }, - "victory": { - "1": "Well! Dear child, I must say, that was most impressive. \n$Your Pokémon believed in you and did their best to earn you the win. \n$Even though I've lost, I find myself with this silly grin!" - }, - "defeat": { - "1": "Hahahahah! Looks like this old lady won!" - } - }, - "lenora": { - "encounter": { - "1": "Well then, challenger, I'm going to research how you battle with the Pokémon you've so lovingly raised!", - "1_female": "Well then, challenger, I'm going to research how you battle with the Pokémon you've so lovingly raised!" - }, - "victory": { - "1": "My theory about you was correct. You're more than just talented… You're motivated! I salute you!", - "1_female": "My theory about you was correct. You're more than just talented… You're motivated! I salute you!" - }, - "defeat": { - "1": "Ah ha ha! If you lose, make sure to analyze why, and use that knowledge in your next battle!" - } - }, - "siebold": { - "encounter": { - "1": "As long as I am alive, I shall strive onward to seek the ultimate cuisine... and the strongest opponents in battle!" - }, - "victory": { - "1": "I shall store my memory of you and your Pokémon forever away within my heart." - }, - "defeat": { - "1": "Our Pokémon battle was like food for my soul. It shall keep me going. \n$That is how I will pay my respects to you for giving your all in battle!" - } - }, - "roxie": { - "encounter": { - "1": "Get ready! I'm gonna knock some sense outta ya!" - }, - "victory": { - "1": "Wild! Your reason's already more toxic than mine!" - }, - "defeat": { - "1": "Hey, c'mon! Get serious! You gotta put more out there!", - "1_female": "Hey, c'mon! Get serious! You gotta put more out there!" - } - }, - "olivia": { - "encounter": { - "1": "No introduction needed here. Time to battle me, Olivia!" - }, - "victory": { - "1": "Really lovely… Both you and your Pokémon…" - }, - "defeat": { - "1": "Mmm-hmm." - } - }, - "poppy": { - "encounter": { - "1": "Oooh! Do you wanna have a Pokémon battle with me?" - }, - "victory": { - "1": "Uagh?! Mmmuuuggghhh…" - }, - "defeat": { - "1": "Yaaay! I did it! I de-feet-ed you! You can come for… For… An avenge match? \n$Come for an avenge match anytime you want!" - } - }, - "agatha": { - "encounter": { - "1": "Pokémon are for battling! I'll show you how a real Trainer battles!" - }, - "victory": { - "1": "Oh my! You're something special, child!" - }, - "defeat": { - "1": "Bahaha. That's how a proper battle's done!" - } - }, - "flint": { - "encounter": { - "1": "Hope you're warmed up, cause here comes the Big Bang!", - "1_female": "Hope you're warmed up, cause here comes the Big Bang!" - }, - "victory": { - "1": "Incredible! Your moves are so hot, they make mine look lukewarm!" - }, - "defeat": { - "1": "Huh? Is that it? I think you need a bit more passion." - } - }, - "grimsley": { - "encounter": { - "1": "The winner takes everything, and there's nothing left for the loser." - }, - "victory": { - "1": "When one loses, they lose everything… The next thing I'll look for will be victory, too!" - }, - "defeat": { - "1": "If somebody wins, the person who fought against that person will lose." - } - }, - "caitlin": { - "encounter": { - "1": "It's me who appeared when the flower opened up. You who have been waiting…\n$You look like a Pokémon Trainer with refined strength and deepened kindness. \n$What I look for in my opponent is superb strength… \n$Please unleash your power to the fullest!", - "1_female": "It's me who appeared when the flower opened up. You who have been waiting…\n$You look like a Pokémon Trainer with refined strength and deepened kindness. \n$What I look for in my opponent is superb strength… \n$Please unleash your power to the fullest!" - }, - "victory": { - "1": "My Pokémon and I learned so much! I offer you my thanks." - }, - "defeat": { - "1": "I aspire to claim victory with elegance and grace." - } - }, - "diantha": { - "encounter": { - "1": "Battling against you and your Pokémon, all of you brimming with hope for the future… \n$Honestly, it just fills me up with energy I need to keep facing each new day! It does!" - }, - "victory": { - "1": "Witnessing the noble spirits of you and your Pokémon in battle has really touched my heart…" - }, - "defeat": { - "1": "Oh, fantastic! What did you think? My team was pretty cool, right?" - } - }, - "wikstrom": { - "encounter": { - "1": "Well met, young challenger! Verily am I the famed blade of hardened steel, Duke Wikstrom! \n$Let the battle begin! En garde!", - "1_female": "Well met, young challenger! Verily am I the famed blade of hardened steel, Duke Wikstrom! \n$Let the battle begin! En garde!" - }, - "victory": { - "1": "Glorious! The trust that you share with your honorable Pokémon surpasses even mine!", - "1_female": "Glorious! The trust that you share with your honorable Pokémon surpasses even mine!" - }, - "defeat": { - "1": "What manner of magic is this? My heart, it doth hammer ceaselessly in my breast! \n$Winning against such a worthy opponent doth give my soul wings--thus do I soar!", - "1_female": "What manner of magic is this? My heart, it doth hammer ceaselessly in my breast! \n$Winning against such a worthy opponent doth give my soul wings--thus do I soar!" - } - }, - "acerola": { - "encounter": { - "1": "Battling is just plain fun! Come on, I can take you!" - }, - "victory": { - "1": "I'm… I'm speechless! How did you do it?!" - }, - "defeat": { - "1": "Ehaha! What an amazing victory!" - } - }, - "larry_elite": { - "encounter": { - "1": "Hello there… It's me, Larry.\n$I serve as a member of the Elite Four too, yes… Unfortunately for me." - }, - "victory": { - "1": "Well, that took the wind from under our wings…" - }, - "defeat": { - "1": "It's time for a meeting with the boss." - } - }, - "lance": { - "encounter": { - "1": "I've been waiting for you. Allow me to test your skill.", - "2": "I thought that you would be able to get this far. Let's get this started." - }, - "victory": { - "1": "You got me. You are magnificent!", - "1_female": "You got me. You are magnificent!", - "2": "I never expected another trainer to beat me… I'm surprised.", - "2_female": "I never expected another trainer to beat me… I'm surprised." - }, - "defeat": { - "1": "That was close. Want to try again?", - "2": "It's not that you are weak. Don't let it bother you.", - "2_female": "It's not that you are weak. Don't let it bother you." - } - }, - "karen": { - "encounter": { - "1": "I am Karen. Would you care for a showdown with my Dark-type Pokémon?", - "2": "I am unlike those you've already met.", - "3": "You've assembled a charming team. Our battle should be a good one." - }, - "victory": { - "1": "No! I can't win. How did you become so strong?", - "2": "I will not stray from my chosen path.", - "3": "The Champion is looking forward to meeting you." - }, - "defeat": { - "1": "That's about what I expected.", - "2": "Well, that was relatively entertaining.", - "3": "Come visit me anytime." - } - }, - "milo": { - "encounter": { - "1": "Sure seems like you understand Pokémon real well. \n$This is gonna be a doozy of a battle! \n$I'll have to Dynamax my Pokémon if I want to win!" - }, - "victory": { - "1": "The power of Grass has wilted… What an incredible Challenger!", - "1_female": "The power of Grass has wilted… What an incredible Challenger!" - }, - "defeat": { - "1": "This'll really leave you in shock and awe." - } - }, - "lucian": { - "encounter": { - "1": "Just a moment, please. The book I'm reading has nearly reached its thrilling climax… \n$The hero has obtained a mystic sword and is about to face their final trial… Ah, never mind. \n$Since you've made it this far, I'll put that aside and battle you. \n$Let me see if you'll achieve as much glory as the hero of my book!" - }, - "victory": { - "1": "I see… It appears you've put me in checkmate." - }, - "defeat": { - "1": "I have a reputation to uphold." - } - }, - "drasna": { - "encounter": { - "1": "You must be a strong Trainer. Yes, quite strong indeed…\n$That's just wonderful news! Facing opponents like you and your team will make my Pokémon grow like weeds!", - "1_female": "You must be a strong Trainer. Yes, quite strong indeed…\n$That's just wonderful news! Facing opponents like you and your team will make my Pokémon grow like weeds!" - }, - "victory": { - "1": "Oh, dear me. That sure was a quick battle… I do hope you'll come back again sometime!" - }, - "defeat": { - "1": "How can this be?" - } - }, - "kahili": { - "encounter": { - "1": "So, here you are… Why don't we see who the winds favor today, you… Or me?" - }, - "victory": { - "1": "It's frustrating to me as a member of the Elite Four, but it seems your strength is the real deal." - }, - "defeat": { - "1": "That was an ace!" - } - }, - "hassel": { - "encounter": { - "1": "Prepare to learn firsthand how the fiery breath of ferocious battle feels!" - }, - "victory": { - "1": "Fortune smiled on me this time, but… \n$Judging from how the match went, who knows if I will be so lucky next time." - }, - "defeat": { - "1": "That was an ace!" - } - }, - "blue": { - "encounter": { - "1": "You must be pretty good to get this far.", - "1_female": "You must be pretty good to get this far." - }, - "victory": { - "1": "I've only lost to him and now to you… Him? Hee, hee…" - }, - "defeat": { - "1": "See? My power is what got me here." - } - }, - "piers": { - "encounter": { - "1": "Get ready for a mosh pit with me and my party! Spikemuth, it's time to rock!" - }, - "victory": { - "1": "Me an' my team gave it our best. Let's meet up again for a battle some time…" - }, - "defeat": { - "1": "My throat's ragged from shoutin'… But 'at was an excitin' battle!" - } - }, - "red": { - "encounter": { - "1": "…!" - }, - "victory": { - "1": "…?" - }, - "defeat": { - "1": "…!" - } - }, - "jasmine": { - "encounter": { - "1": "Oh… Your Pokémon are impressive. I think I will enjoy this." - }, - "victory": { - "1": "You are truly strong. I'll have to try much harder, too." - }, - "defeat": { - "1": "I never expected to win." - } - }, - "lance_champion": { - "encounter": { - "1": "I am still the Champion. I won't hold anything back." - }, - "victory": { - "1": "This is the emergence of a new Champion.", - "1_female": "This is the emergence of a new Champion." - }, - "defeat": { - "1": "I successfully defended my Championship." - } - }, - "steven": { - "encounter": { - "1": "Tell me… What have you seen on your journey with your Pokémon? \n$What have you felt, meeting so many other Trainers out there? \n$Traveling this rich land… Has it awoken something inside you? \n$I want you to come at me with all that you've learned. \n$My Pokémon and I will respond in turn with all that we know!" - }, - "victory": { - "1": "So I, the Champion, fall in defeat…" - }, - "defeat": { - "1": "That was time well spent! Thank you!" - } - }, - "cynthia": { - "encounter": { - "1": "I, Cynthia, accept your challenge! There won't be any letup from me!" - }, - "victory": { - "1": "No matter how fun the battle is, it will always end sometime…" - }, - "defeat": { - "1": "Even if you lose, never lose your love of Pokémon." - } - }, - "iris": { - "encounter": { - "1": "Know what? I really look forward to having serious battles with strong Trainers! \n$I mean, come on! The Trainers who make it here are Trainers who desire victory with every fiber of their being! \n$And they are battling alongside Pokémon that have been through countless difficult battles! \n$If I battle with people like that, not only will I get stronger, my Pokémon will, too! \n$And we'll get to know each other even better! OK! Brace yourself! \n$I'm Iris, the Pokémon League Champion, and I'm going to defeat you!" - }, - "victory": { - "1": "Aghhhh… I did my best, but we lost…" - }, - "defeat": { - "1": "Yay! We won!" - } - }, - "hau": { - "encounter": { - "1": "I wonder if a Trainer battles differently depending on whether they're from a warm region or a cold region.\n$Let's test it out!" - }, - "victory": { - "1": "That was awesome! I think I kinda understand your vibe a little better now!" - }, - "defeat": { - "1": "Ma-an, that was some kinda battle!" - } - }, - "geeta": { - "encounter": { - "1": "I decided to throw my hat in the ring once more. \n$Come now… Show me the fruits of your training." - }, - "victory": { - "1": "I eagerly await news of all your achievements!" - }, - "defeat": { - "1": "What's the matter? This isn't all, is it?" - } - }, - "nemona": { - "encounter": { - "1": "Yesss! I'm so psyched! Time for us to let loose!" - }, - "victory": { - "1": "Well, that stinks, but I still had fun! I'll getcha next time!" - }, - "defeat": { - "1": "Well, that was a great battle! Fruitful for sure." - } - }, - "leon": { - "encounter": { - "1": "We're gonna have an absolutely champion time!" - }, - "victory": { - "1": "My time as Champion is over… \n$But what a champion time it's been! \n$Thank you for the greatest battle I've ever had!" - }, - "defeat": { - "1": "An absolute champion time, that was!" - } - }, - "whitney": { - "encounter": { - "1": "Hey! Don't you think Pokémon are, like, super cute?" - }, - "victory": { - "1": "Waaah! Waaah! You're so mean!", - "1_female": "Waaah! Waaah! You're so mean!" - }, - "defeat": { - "1": "And that's that!" - } - }, - "chuck": { - "encounter": { - "1": "Hah! You want to challenge me? Are you brave or just ignorant?", - "1_female": "Hah! You want to challenge me? Are you brave or just ignorant?" - }, - "victory": { - "1": "You're strong! Would you please make me your apprentice?" - }, - "defeat": { - "1": "There. Do you realize how much more powerful I am than you?" - } - }, - "katy": { - "encounter": { - "1": "Don't let your guard down unless you would like to find yourself knocked off your feet!", - "1_female": "Don't let your guard down unless you would like to find yourself knocked off your feet!" - }, - "victory": { - "1": "All of my sweet little Pokémon dropped like flies!" - }, - "defeat": { - "1": "Eat up, my cute little Vivillon!" - } - }, - "pryce": { - "encounter": { - "1": "Youth alone does not ensure victory! Experience is what counts." - }, - "victory": { - "1": "Outstanding! That was perfect. Try not to forget what you feel now." - }, - "defeat": { - "1": "Just as I envisioned." - } - }, - "clair": { - "encounter": { - "1": "Do you know who I am? And you still dare to challenge me?" - }, - "victory": { - "1": "I wonder how far you can get with your skill level. This should be fascinating." - }, - "defeat": { - "1": "That's that." - } - }, - "maylene": { - "encounter": { - "1": "I've come to challenge you now, and I won't hold anything back. \n$Please prepare yourself for battle!", - "1_female": "I've come to challenge you now, and I won't hold anything back. \n$Please prepare yourself for battle!" - }, - "victory": { - "1": "I admit defeat…" - }, - "defeat": { - "1": "That was awesome." - } - }, - "fantina": { - "encounter": { - "1": "You shall challenge me, yes? But I shall win. \n$That is what the Gym Leader of Hearthome does, non?" - }, - "victory": { - "1": "You are so fantastically strong. I know why I have lost." - }, - "defeat": { - "1": "I am so, so, very happy!" - } - }, - "byron": { - "encounter": { - "1": "Trainer! You're young, just like my son, Roark. \n$With more young Trainers taking charge, the future of Pokémon is bright! \n$So, as a wall for young people, I'll take your challenge!", - "1_female": "Trainer! You're young, just like my son, Roark. \n$With more young Trainers taking charge, the future of Pokémon is bright! \n$So, as a wall for young people, I'll take your challenge!" - }, - "victory": { - "1": "Hmm! My sturdy Pokémon--defeated!" - }, - "defeat": { - "1": "Gwahahaha! How were my sturdy Pokémon?!" - } - }, - "olympia": { - "encounter": { - "1": "An ancient custom deciding one's destiny. The battle begins!" - }, - "victory": { - "1": "Create your own path. Let nothing get in your way. Your fate, your future." - }, - "defeat": { - "1": "Our path is clear now." - } - }, - "volkner": { - "encounter": { - "1": "Since you've come this far, you must be quite strong…\n$I hope you're the Trainer who'll make me remember how fun it is to battle!", - "1_female": "Since you've come this far, you must be quite strong…\n$I hope you're the Trainer who'll make me remember how fun it is to battle!" - }, - "victory": { - "1": "You've got me beat…\n$Your desire and the noble way your Pokémon battled for you… \n$I even felt thrilled during our match. That was a very good battle." - }, - "defeat": { - "1": "It was not shocking at all… \n$That is not what I wanted!" - } - }, - "burgh": { - "encounter": { - "1": "M'hm… If I win this battle, I feel like I can draw a picture unlike any before it. \n$OK! I can hear my battle muse loud and clear. Let's get straight to it!", - "2": "Of course, I'm really proud of all of my Pokémon! \n$Well now… Let's get right to it!" - }, - "victory": { - "1": "Is it over? Has my muse abandoned me?", - "2": "Hmm… It's over! You're incredible!" - }, - "defeat": { - "1": "Wow… It's beautiful somehow, isn't it…", - "2": "Sometimes I hear people say something was an ugly win. \n$I think if you're trying your best, any win is beautiful." - } - }, - "elesa": { - "encounter": { - "1": "C'est fini! When I'm certain of that, I feel an electric jolt run through my body! \n$I want to feel the sensation, so now my beloved Pokémon are going to make your head spin!" - }, - "victory": { - "1": "I meant to make your head spin, but you shocked me instead." - }, - "defeat": { - "1": "That was unsatisfying somehow… Will you give it your all next time?" - } - }, - "skyla": { - "encounter": { - "1": "It's finally time for a showdown! That means the Pokémon battle that decides who's at the top, right? \n$I love being on the summit! 'Cause you can see forever and ever from high places! \n$So, how about you and I have some fun?" - }, - "victory": { - "1": "Being your opponent in battle is a new source of strength to me. Thank you!" - }, - "defeat": { - "1": "Win or lose, you always gain something from a battle, right?" - } - }, - "brycen": { - "encounter": { - "1": "There is also strength in being with other people and Pokémon. \n$Receiving their support makes you stronger. I'll show you this power!" - }, - "victory": { - "1": "The wonderful combination of you and your Pokémon! What a beautiful friendship!" - }, - "defeat": { - "1": "Extreme conditions really test you and train you!" - } - }, - "drayden": { - "encounter": { - "1": "What I want to find is a young Trainer who can show me a bright future. \n$Let's battle with everything we have: your skill, my experience, and the love we've raised our Pokémon with!" - }, - "victory": { - "1": "This intense feeling that floods me after a defeat… I don't know how to describe it." - }, - "defeat": { - "1": "Harrumph! I know your ability is greater than that!" - } - }, - "grant": { - "encounter": { - "1": "There is only one thing I wish for. \n$That by surpassing one another, we find a way to even greater heights." - }, - "victory": { - "1": "You are a wall that I am unable to surmount!" - }, - "defeat": { - "1": "Do not give up. \n$That is all there really is to it. \n$The most important lessons in life are simple." - } - }, - "korrina": { - "encounter": { - "1": "Time for Lady Korrina's big appearance!" - }, - "victory": { - "1": "It's your very being that allows your Pokémon to evolve!" - }, - "defeat": { - "1": "What an explosive battle!" - } - }, - "clemont": { - "encounter": { - "1": "Oh! I'm glad that we got to meet!" - }, - "victory": { - "1": "Your passion for battle inspires me!" - }, - "defeat": { - "1": "Looks like my Trainer-Grow-Stronger Machine, Mach 2 is really working!" - } - }, - "valerie": { - "encounter": { - "1": "Oh, if it isn't a young Trainer… It is lovely to get to meet you like this. \n$Then I suppose you have earned yourself the right to a battle, as a reward for your efforts. \n$The elusive Fairy may appear frail as the breeze and delicate as a bloom, but it is strong.", - "1_female": "Oh, if it isn't a young Trainer… It is lovely to get to meet you like this. \n$Then I suppose you have earned yourself the right to a battle, as a reward for your efforts. \n$The elusive Fairy may appear frail as the breeze and delicate as a bloom, but it is strong." - }, - "victory": { - "1": "I hope that you will find things worth smiling about tomorrow…" - }, - "defeat": { - "1": "Oh goodness, what a pity…" - } - }, - "wulfric": { - "encounter": { - "1": "You know what? We all talk big about what you learn from battling and bonds and all that…\n$But really, I just do it 'cause it's fun. \n$Who cares about the grandstanding? Let's get to battling!" - }, - "victory": { - "1": "Outstanding! I'm tough as an iceberg, but you smashed me through and through!" - }, - "defeat": { - "1": "Tussle with me and this is what happens!" - } - }, - "kabu": { - "encounter": { - "1": "Every Trainer and Pokémon trains hard in pursuit of victory. \n$But that means your opponent is also working hard to win. \n$In the end, the match is decided by which side is able to unleash their true potential." - }, - "victory": { - "1": "I'm glad I could battle you today!" - }, - "defeat": { - "1": "That's a great way for me to feel my own growth!" - } - }, - "bea": { - "encounter": { - "1": "Do you have an unshakable spirit that won't be moved, no matter how you are attacked? \n$I think I'll just test that out, shall I?" - }, - "victory": { - "1": "I felt the fighting spirit of your Pokémon as you led them in battle." - }, - "defeat": { - "1": "That was the best sort of match anyone could ever hope for." - } - }, - "opal": { - "encounter": { - "1": "Let me have a look at how you and your partner Pokémon behave!" - }, - "victory": { - "1": "Your pink is still lacking, but you're an excellent Trainer with excellent Pokémon.", - "1_female": "Your pink is still lacking, but you're an excellent Trainer with excellent Pokémon." - }, - "defeat": { - "1": "Too bad for you, I guess." - } - }, - "bede": { - "encounter": { - "1": "I suppose I should prove beyond doubt just how pathetic you are and how strong I am.", - "1_female": "I suppose I should prove beyond doubt just how pathetic you are and how strong I am." - }, - "victory": { - "1": "I see… Well, that's fine. I wasn't really trying all that hard anyway." - }, - "defeat": { - "1": "Not a bad job, I suppose." - } - }, - "gordie": { - "encounter": { - "1": "So, let's get this over with." - }, - "victory": { - "1": "I just want to climb into a hole… Well, I guess it'd be more like falling from here." - }, - "defeat": { - "1": "Battle like you always do, victory will follow!" - } - }, - "marnie": { - "encounter": { - "1": "The truth is, when all's said and done… I really just wanna become Champion for myself! \n$So don't take it personal when I kick your butt!" - }, - "victory": { - "1": "OK, so I lost… But I got to see a lot of the good points of you and your Pokémon!" - }, - "defeat": { - "1": "Hope you enjoyed our battle tactics." - } - }, - "raihan": { - "encounter": { - "1": "I'm going to defeat the Champion, win the whole tournament, and prove to the world just how strong the great Raihan really is!" - }, - "victory": { - "1": "I look this good even when I lose. \n$It's a real curse. \n$Guess it's time for another selfie!" - }, - "defeat": { - "1": "Let's take a selfie to remember this." - } - }, - "brassius": { - "encounter": { - "1": "I assume you are ready? Let our collaborative work of art begin!", - "1_female": "I assume you are ready? Let our collaborative work of art begin!" - }, - "victory": { - "1": "Ahhh…vant-garde!" - }, - "defeat": { - "1": "I will begin on a new piece at once!" - } - }, - "iono": { - "encounter": { - "1": "How're ya feelin' about this battle?\n$...\n$Let's get this show on the road! How strong is our challenger? \n$I 'unno! Let's find out together!", - "1_female": "How're ya feelin' about this battle?\n$...\n$Let's get this show on the road! How strong is our challenger? \n$I 'unno! Let's find out together!" - }, - "victory": { - "1": "You're as flashy and bright as a 10,000,000-volt Thunderbolt, friendo!", - "1_female": "You're as flashy and bright as a 10,000,000-volt Thunderbolt, friendo!" - }, - "defeat": { - "1": "Your eyeballs are MINE!" - } - }, - "larry": { - "encounter": { - "1": "When all's said and done, simplicity is strongest." - }, - "victory": { - "1": "A serving of defeat, huh?" - }, - "defeat": { - "1": "I'll call it a day." - } - }, - "ryme": { - "encounter": { - "1": "Come on, baby! Rattle me down to the bone!" - }, - "victory": { - "1": "You're cool, my friend—you move my SOUL!", - "1_female": "You're cool, my friend—you move my SOUL!" - }, - "defeat": { - "1": "Later, baby!" - } - }, - "grusha": { - "encounter": { - "1": "All I need to do is make sure the power of my Pokémon chills you to the bone!" - }, - "victory": { - "1": "Your burning passion… I kinda like it, to be honest." - }, - "defeat": { - "1": "Things didn't heat up for you." - } - }, - "marnie_elite": { - "encounter": { - "1": "You've made it this far, huh? Let's see if you can handle my Pokémon!", - "2": "I'll give it my best shot, but don't think I'll go easy on you!" - }, - "victory": { - "1": "I can't believe I lost... But you deserved that win. Well done!", - "2": "Looks like I've still got a lot to learn. Great battle, though!" - }, - "defeat": { - "1": "You put up a good fight, but I've got the edge! Better luck next time!", - "2": "Seems like my training's paid off. Thanks for the battle!" - } - }, - "nessa_elite": { - "encounter": { - "1": "The tides are turning in my favor. Ready to get swept away?", - "1_female": "The tides are turning in my favor. Ready to get swept away?", - "2": "Let's make some waves with this battle! I hope you're prepared!", - "2_female": "Let's make some waves with this battle! I hope you're prepared!" - }, - "victory": { - "1": "You navigated those waters perfectly... Well done!", - "2": "Looks like my currents were no match for you. Great job!" - }, - "defeat": { - "1": "Water always finds a way. That was a refreshing battle!", - "2": "You fought well, but the ocean's power is unstoppable!" - } - }, - "bea_elite": { - "encounter": { - "1": "Prepare yourself! My fighting spirit burns bright!", - "2": "Let's see if you can keep up with my relentless pace!" - }, - "victory": { - "1": "Your strength... It's impressive. You truly deserve this win.", - "2": "I've never felt this intensity before. Amazing job!" - }, - "defeat": { - "1": "Another victory for my intense training regimen! Well done!", - "2": "You've got strength, but I trained harder. Great battle!" - } - }, - "allister_elite": { - "encounter": { - "1": "Shadows fall... Are you ready to face your fears?", - "1_female": "Shadows fall... Are you ready to face your fears?", - "2": "Let's see if you can handle the darkness that I command." - }, - "victory": { - "1": "You've dispelled the shadows... For now. Well done.", - "2": "Your light pierced through my darkness. Great job." - }, - "defeat": { - "1": "The shadows have spoken... Your strength isn't enough.", - "2": "Darkness triumphs... Maybe next time you'll see the light." - } - }, - "raihan_elite": { - "encounter": { - "1": "Storm's brewing! Let's see if you can weather this fight!", - "2": "Get ready to face the eye of the storm!" - }, - "victory": { - "1": "You've bested the storm... Incredible job!", - "2": "You rode the winds perfectly... Great battle!" - }, - "defeat": { - "1": "Another storm weathered, another victory claimed! Well fought!", - "2": "You got caught in my storm! Better luck next time!", - "2_female": "You got caught in my storm! Better luck next time!" - } - }, - "alder": { - "encounter": { - "1": "Prepare yourself for a match against the strongest Trainer in Unova!" - }, - "victory": { - "1": "Well done! You certainly are an unmatched talent." - }, - "defeat": { - "1": "A fresh wind blows through my heart...\n$What an extraordinary effort!" - } - }, - "kieran": { - "encounter": { - "1": "Through hard work, I become stronger and stronger!\n$I don't lose." - }, - "victory": { - "1": "I don't believe it...\n$What a fun and heart-pounding battle!" - }, - "defeat": { - "1": "Wowzers, what a battle!\n$Time for you to train even harder." - } - }, - "rival": { - "encounter": { - "1": "@c{smile}Hey, I was looking for you! I knew you were eager to get going but I expected at least a goodbye…$@c{smile_eclosed}So you're really pursuing your dream after all? I almost can't believe it.$@c{serious_smile_fists}Since we're here, how about a battle?\nAfter all, I want to make sure you're ready.$@c{serious_mopen_fists}Don't hold back, I want you to give me everything you've got!" - }, - "victory": { - "1": "@c{shock}Wow… You cleaned me out.\nAre you actually a beginner?$@c{smile}Maybe it was a bit of luck but…Who knows you might just be able to go all the way.$By the way, the professor asked me to give you these items. They look pretty cool.$@c{serious_smile_fists}Good luck out there!" - } - }, - "rival_female": { - "encounter": { - "1": "@c{smile_wave}There you are! I've been looking everywhere for you!\n@c{angry_mopen}Did you forget to say goodbye to your best friend?\n$@c{smile_ehalf}You're going after your dream, huh?\nThat day is really today isn't it…\n$@c{smile}Anyway, I'll forgive you for forgetting me, but on one condition. @c{smile_wave_wink}You have to battle me!\n$@c{angry_mopen}Give it your all! Wouldn't want your adventure to be over before it started, right?" - }, - "victory": { - "1": "@c{shock}You just started and you're already this strong?!@d{96}\n@c{angry}You totally cheated, didn't you?\n$@c{smile_wave_wink}Just kidding!@d{64} @c{smile_eclosed}I lost fair and square… I have a feeling you're going to do really well out there.\n$@c{smile}By the way, the professor wanted me to give you some items. Hopefully they're helpful!\n$@c{smile_wave}Do your best like always! I believe in you!" - } - }, - "rival_2": { - "encounter": { - "1": "@c{smile}Hey, you're here too?\n@c{smile_eclosed}Still a perfect record, huh…?\n$@c{serious_mopen_fists}I know it kind of looks like I followed you here, but that's mostly not true.\n$@c{serious_smile_fists}Honestly though, I've been itching for a rematch since you beat me back at home.\n$I've been doing a lot of my own training so I'll definitely put up a fight this time.\n$@c{serious_mopen_fists}Don't hold back, just like before!\nLet's go!" - }, - "victory": { - "1": "@c{neutral_eclosed}Oh. I guess I was overconfident.\n$@c{smile}That's alright, though. I figured this might happen.\n@c{serious_mopen_fists}It just means I need to try harder for next time!\n\n$@c{smile}Oh, not that you really need the help, but I had an extra one of each of these lying around and figured you might want them.\n\n$@c{serious_smile_fists}Don't expect another one after this, though!\nI can't keep giving my opponent an advantage after all." - } - }, - "rival_2_female": { - "encounter": { - "1": "@c{smile_wave}Oh, fancy meeting you here. Looks like you're still undefeated. @c{angry_mopen}Huh… Not bad!\n$@c{angry_mopen}I know what you're thinking, and no, I wasn't creeping on you. @c{smile_eclosed}I just happened to be in the area.\n$@c{smile_ehalf}I'm happy for you but I just want to let you know that it's OK to lose sometimes.\n$@c{smile}We learn from our mistakes, often more than we would if we kept succeeding.\n$@c{angry_mopen}In any case, I've been training hard for our rematch, so you'd better give it your all!" - }, - "victory": { - "1": "@c{neutral}I… wasn't supposed to lose that time…\n$@c{smile}Aw well. That just means I'll have to train even harder for next time!\n$@c{smile_wave}I also got you another two of these!\n@c{smile_wave_wink}No need to thank me~.\n$@c{angry_mopen}This is the last one, though! You won't be getting anymore freebies from me after this!" - }, - "defeat": { - "1": "It's OK to lose sometimes…" - } - }, - "rival_3": { - "encounter": { - "1": "@c{smile}Hey, look who it is! It's been a while.\n@c{neutral}You're… still undefeated? Huh.\n$@c{neutral_eclosed}Things have been kind of… strange.\nIt's not the same back home without you.\n$@c{serious}I know it's selfish, but I need to get this off my chest.\n@c{neutral_eclosed}I think you're in over your head here.\n$@c{serious}Never losing once is just unrealistic.\nWe need to lose sometimes in order to grow.\n$@c{neutral_eclosed}You've had a great run but there's still so much ahead, and it only gets harder. @c{neutral}Are you prepared for that?\n$@c{serious_mopen_fists}If so, prove it to me." - }, - "victory": { - "1": "@c{angry_mhalf}This is ridiculous… I've hardly stopped training…\nHow are we still so far apart?" - } - }, - "rival_3_female": { - "encounter": { - "1": "@c{smile_wave}Long time no see! Still haven't lost, huh.\n@c{angry}You're starting to get on my nerves. @c{smile_wave_wink}Just kidding!\n$@c{smile_ehalf}But really, don't you miss home by now? Or… me?\nI… I mean, we've really missed you.\n$@c{smile_eclosed}I support you in your dream and everything, but the reality is you're going to lose sooner or later.\n$@c{smile}And when you do, I'll be there for you like always.\n@c{angry_mopen}Now, let me show you how strong I've become!" - }, - "victory": { - "1": "@c{shock}After all that… it wasn't enough…?\nYou'll never come back at this rate…" - }, - "defeat": { - "1": "You gave it your best, now let's go home." - } - }, - "rival_4": { - "encounter": { - "1": "@c{neutral}Hey.\n$I won't mince words or pleasantries with you.\n@c{neutral_eclosed}I'm here to win, plain and simple.\n$@c{serious_mhalf_fists}I've learned to maximize my potential by putting all my time into training.\n$@c{smile}You get a lot of extra time when you cut out the unnecessary sleep and social interaction.\n$@c{serious_mopen_fists}None of that matters anymore, not until I win.\n$@c{neutral_eclosed}I've even reached the point where I don't lose anymore.\n@c{smile_eclosed}I suppose your philosophy wasn't so wrong after all.\n$@c{angry_mhalf}Losing is for the weak, and I'm not weak anymore.\n$@c{serious_mopen_fists}Prepare yourself." - }, - "victory": { - "1": "@c{neutral}What…@d{64} What are you?" - } - }, - "rival_4_female": { - "encounter": { - "1": "@c{neutral}It's me! You didn't forget about me again… did you?\n$@c{smile}You should be proud of how far you made it. Congrats!\nBut it looks like it's the end of your journey.\n$@c{smile_eclosed}You've awoken something in me I never knew was there.\nIt seems like all I do now is train.\n$@c{smile_ehalf}I hardly even eat or sleep now, I just train my Pokémon all day, getting stronger every time.\n$@c{neutral}In fact, I… hardly recognize myself.\n$And now, I've finally reached peak performance.\nI don't think anyone could beat me now.\n$And you know what? It's all because of you.\n@c{smile_ehalf}I don't know whether to thank you or hate you.\n$@c{angry_mopen}Prepare yourself." - }, - "victory": { - "1": "@c{neutral}What…@d{64} What are you?" - }, - "defeat": { - "1": "$@c{smile}You should be proud of how far you made it." - } - }, - "rival_5": { - "encounter": { - "1": "@c{neutral}…" - }, - "victory": { - "1": "@c{neutral}…" - } - }, - "rival_5_female": { - "encounter": { - "1": "@c{neutral}…" - }, - "victory": { - "1": "@c{neutral}…" - }, - "defeat": { - "1": "$@c{smile_ehalf}…" - } - }, - "rival_6": { - "encounter": { - "1": "@c{smile_eclosed}We meet again.\n$@c{neutral}I've had some time to reflect on all this.\nThere's a reason this all seems so strange.\n$@c{neutral_eclosed}Your dream, my drive to beat you…\nIt's all a part of something greater.\n$@c{serious}This isn't about me, or about you… This is about the world, @c{serious_mhalf_fists}and it's my purpose to push you to your limits.\n$@c{neutral_eclosed}Whether I've fulfilled that purpose I can't say, but I've done everything in my power.\n$@c{neutral}This place we ended up in is terrifying… Yet somehow I feel unphased, like I've been here before.\n$@c{serious_mhalf_fists}You feel the same, don't you?\n$@c{serious}…and it's like something here is speaking to me.\nThis is all the world's known for a long time now.\n$Those times we cherished together that seem so recent are nothing but a distant memory.\n$@c{neutral_eclosed}Who can say whether they were ever even real in the first place.\n$@c{serious_mopen_fists}You need to keep pushing, because if you don't, it will never end. You're the only one who can do this.\n$@c{serious_smile_fists}I hardly know what any of this means, I just know that it's true.\n$@c{serious_mopen_fists}If you can't defeat me here and now, you won't stand a chance." - }, - "victory": { - "1": "@c{smile_eclosed}It looks like my work is done here.\n$I want you to promise me one thing.\n@c{smile}After you heal the world, please come home." - } - }, - "rival_6_female": { - "encounter": { - "1": "@c{smile_ehalf}So it's just us again.\n$@c{smile_eclosed}You know, I keep going around and around in my head…\n$@c{smile_ehalf}There's something to all this, why everything seems so strange now…\n$@c{smile}You have your dream, and I have this ambition in me…\n$I just can't help but feel there's a greater purpose to all this, to what we're doing, you and I.\n$@c{smile_eclosed}I think I'm supposed to push you… to your limits.\n$@c{smile_ehalf}I'm not sure if I've been doing a good job at that, but I've tried my best up to now.\n$It's something about this strange and dreadful place… Everything seems so clear…\n$This… is all the world's known for a long time now.\n$@c{smile_eclosed}It's like I can barely remember the memories we cherished together.\n$@c{smile_ehalf}Were they even real? They seem so far away now…\n$@c{angry_mopen}You need to keep pushing, because if you don't, it will never end. You're the only one who can do this.\n$@c{smile_ehalf}I… don't know what all this means… but I feel it's true.\n$@c{neutral}If you can't defeat me here and now, you won't stand a chance." - }, - "victory": { - "1": "@c{smile_ehalf}I… I think I fulfilled my purpose…\n$@c{smile_eclosed}Promise me… After you heal the world… Please… come home safe.\n$@c{smile_ehalf}…Thank you." - } - } -} diff --git a/src/locales/en/egg.json b/src/locales/en/egg.json deleted file mode 100644 index d6b352fca1e..00000000000 --- a/src/locales/en/egg.json +++ /dev/null @@ -1,27 +0,0 @@ -{ - "egg": "Egg", - "greatTier": "Rare", - "ultraTier": "Epic", - "masterTier": "Legendary", - "defaultTier": "Common", - "hatchWavesMessageSoon": "Sounds can be heard coming from inside! It will hatch soon!", - "hatchWavesMessageClose": "It appears to move occasionally. It may be close to hatching.", - "hatchWavesMessageNotClose": "What will hatch from this? It doesn't seem close to hatching.", - "hatchWavesMessageLongTime": "It looks like this Egg will take a long time to hatch.", - "gachaTypeLegendary": "Legendary Rate Up", - "gachaTypeMove": "Rare Egg Move Rate Up", - "gachaTypeShiny": "Shiny Rate Up", - "eventType": "Mystery Event", - "selectMachine": "Select a machine.", - "notEnoughVouchers": "You don't have enough vouchers!", - "tooManyEggs": "You have too many eggs!", - "pull": "Pull", - "pulls": "Pulls", - "sameSpeciesEgg": "{{species}} will hatch from this egg!", - "hatchFromTheEgg": "{{pokemonName}} hatched from the egg!", - "eggMoveUnlock": "Egg Move unlocked: {{moveName}}", - "rareEggMoveUnlock": "Rare Egg Move unlocked: {{moveName}}", - "moveUPGacha": "Move UP!", - "shinyUPGacha": "Shiny UP!", - "legendaryUPGacha": "UP!" -} \ No newline at end of file diff --git a/src/locales/en/fight-ui-handler.json b/src/locales/en/fight-ui-handler.json deleted file mode 100644 index bd6bec878c8..00000000000 --- a/src/locales/en/fight-ui-handler.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "pp": "PP", - "power": "Power", - "accuracy": "Accuracy", - "abilityFlyInText": " {{pokemonName}}’s\n{{passive}}{{abilityName}}", - "passive": "Passive ", - "teraHover": "{{type}} Terastallized" -} diff --git a/src/locales/en/filter-bar.json b/src/locales/en/filter-bar.json deleted file mode 100644 index 6e940c6886d..00000000000 --- a/src/locales/en/filter-bar.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "genFilter": "Gen", - "typeFilter": "Type", - "caughtFilter": "Caught", - "unlocksFilter": "Unlocks", - "miscFilter": "Misc", - "sortFilter": "Sort", - "all": "All", - "normal": "Not Shiny", - "uncaught": "Uncaught", - "passive": "Passive", - "passiveUnlocked": "Passive - Yes", - "passiveLocked": "Passive - No", - "passiveUnlockable": "Passive - Can Unlock", - "costReduction": "Cost Reduction", - "costReductionUnlocked": "Cost Reduction - Yes", - "costReductionLocked": "Cost Reduction - No", - "costReductionUnlockable": "Cost Reduction - Can Unlock", - "favorite": "Favorite", - "isFavorite": "Favorite - Yes", - "notFavorite": "Favorite - No", - "ribbon": "Ribbon", - "hasWon": "Ribbon - Yes", - "hasNotWon": "Ribbon - No", - "hiddenAbility": "Hidden Ability", - "hasHiddenAbility": "Hidden Ability - Yes", - "noHiddenAbility": "Hidden Ability - No", - "egg": "Egg", - "eggPurchasable": "Purchasable Egg", - "pokerus": "Pokérus", - "hasPokerus": "Pokérus - Yes", - "noPokerus": "Pokérus - No", - "sortByNumber": "No.", - "sortByCost": "Cost", - "sortByCandies": "Candy Count", - "sortByIVs": "IVs", - "sortByName": "Name" -} \ No newline at end of file diff --git a/src/locales/en/game-mode.json b/src/locales/en/game-mode.json deleted file mode 100644 index e5a4975cc40..00000000000 --- a/src/locales/en/game-mode.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "classic": "Classic", - "endless": "Endless", - "endlessSpliced": "Endless (Spliced)", - "dailyRun": "Daily Run", - "unknown": "Unknown", - "challenge": "Challenge" -} \ No newline at end of file diff --git a/src/locales/en/game-stats-ui-handler.json b/src/locales/en/game-stats-ui-handler.json deleted file mode 100644 index a7beefeabd8..00000000000 --- a/src/locales/en/game-stats-ui-handler.json +++ /dev/null @@ -1,42 +0,0 @@ -{ - "stats": "Stats", - "playTime": "Play Time", - "totalBattles": "Total Battles", - "starters": "Starters", - "shinyStarters": "Shiny Starters", - "speciesSeen": "Species Seen", - "speciesCaught": "Species Caught", - "ribbonsOwned": "Ribbons Owned", - "classicRuns": "Classic Runs", - "classicWins": "Classic Wins", - "dailyRunAttempts": "Daily Run Attempts", - "dailyRunWins": "Daily Run Wins", - "endlessRuns": "Endless Runs", - "highestWaveEndless": "Highest Wave (Endless)", - "highestMoney": "Highest Money", - "highestDamage": "Highest Damage", - "highestHPHealed": "Highest HP Healed", - "pokemonEncountered": "Pokémon Encountered", - "pokemonDefeated": "Pokémon Defeated", - "pokemonCaught": "Pokémon Caught", - "eggsHatched": "Eggs Hatched", - "subLegendsSeen": "Sub-Legends Seen", - "subLegendsCaught": "Sub-Legends Caught", - "subLegendsHatched": "Sub-Legends Hatched", - "legendsSeen": "Legends Seen", - "legendsCaught": "Legends Caught", - "legendsHatched": "Legends Hatched", - "mythicalsSeen": "Mythicals Seen", - "mythicalsCaught": "Mythicals Caught", - "mythicalsHatched": "Mythicals Hatched", - "shiniesSeen": "Shinies Seen", - "shiniesCaught": "Shinies Caught", - "shiniesHatched": "Shinies Hatched", - "pokemonFused": "Pokémon Fused", - "trainersDefeated": "Trainers Defeated", - "eggsPulled": "Eggs Pulled", - "rareEggsPulled": "Rare Eggs Pulled", - "epicEggsPulled": "Epic Eggs Pulled", - "legendaryEggsPulled": "Legendary Eggs Pulled", - "manaphyEggsPulled": "Manaphy Eggs Pulled" -} diff --git a/src/locales/en/growth.json b/src/locales/en/growth.json deleted file mode 100644 index d472343d3eb..00000000000 --- a/src/locales/en/growth.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "Erratic": "Erratic", - "Fast": "Fast", - "Medium_Fast": "Medium Fast", - "Medium_Slow": "Medium Slow", - "Slow": "Slow", - "Fluctuating": "Fluctuating" -} \ No newline at end of file diff --git a/src/locales/en/menu-ui-handler.json b/src/locales/en/menu-ui-handler.json deleted file mode 100644 index 0536fa12c2e..00000000000 --- a/src/locales/en/menu-ui-handler.json +++ /dev/null @@ -1,30 +0,0 @@ -{ - "GAME_SETTINGS": "Game Settings", - "ACHIEVEMENTS": "Achievements", - "STATS": "Stats", - "RUN_HISTORY": "Run History", - "EGG_LIST": "Egg List", - "EGG_GACHA": "Egg Gacha", - "MANAGE_DATA": "Manage Data", - "COMMUNITY": "Community", - "SAVE_AND_QUIT": "Save and Quit", - "LOG_OUT": "Log Out", - "slot": "Slot {{slotNumber}}", - "importSession": "Import Session", - "importSlotSelect": "Select a slot to import to.", - "exportSession": "Export Session", - "exportSlotSelect": "Select a slot to export from.", - "importRunHistory": "Import Run History", - "exportRunHistory": "Export Run History", - "importData": "Import Data", - "exportData": "Export Data", - "consentPreferences": "Consent Preferences", - "linkDiscord": "Link Discord", - "unlinkDiscord": "Unlink Discord", - "linkGoogle": "Link Google", - "unlinkGoogle": "Unlink Google", - "cancel": "Cancel", - "donate": "Donate", - "losingProgressionWarning": "You will lose any progress since the beginning of the battle. Proceed?", - "noEggs": "You are not hatching\nany eggs at the moment!" -} \ No newline at end of file diff --git a/src/locales/en/menu.json b/src/locales/en/menu.json deleted file mode 100644 index 91888e9db31..00000000000 --- a/src/locales/en/menu.json +++ /dev/null @@ -1,57 +0,0 @@ -{ - "cancel": "Cancel", - "continue": "Continue", - "dailyRun": "Daily Run (Beta)", - "loadGame": "Load Game", - "newGame": "New Game", - "settings": "Settings", - "selectGameMode": "Select a game mode.", - "logInOrCreateAccount": "Log in or create an account to start. No email required!", - "username": "Username", - "password": "Password", - "login": "Login", - "orUse": "Or use", - "register": "Register", - "emptyUsername": "Username must not be empty", - "invalidLoginUsername": "The provided username is invalid", - "invalidRegisterUsername": "Username must only contain letters, numbers, or underscores", - "invalidLoginPassword": "The provided password is invalid", - "invalidRegisterPassword": "Password must be 6 characters or longer", - "usernameAlreadyUsed": "The provided username is already in use", - "accountNonExistent": "The provided user does not exist", - "unmatchingPassword": "The provided password does not match", - "passwordNotMatchingConfirmPassword": "Password must match confirm password", - "confirmPassword": "Confirm Password", - "registrationAgeWarning": "By registering, you confirm you are of 13 years of age or older.", - "backToLogin": "Back to Login", - "failedToLoadSaveData": "Failed to load save data. Please reload the page.\nIf this persists, please check #announcements in Discord.", - "sessionSuccess": "Session loaded successfully.", - "failedToLoadSession": "Your session data could not be loaded.\nIt may be corrupted.", - "boyOrGirl": "Are you a boy or a girl?", - "evolving": "What?\n{{pokemonName}} is evolving!", - "stoppedEvolving": "{{pokemonName}} stopped evolving.", - "pauseEvolutionsQuestion": "Would you like to pause evolutions for {{pokemonName}}?\nEvolutions can be re-enabled from the party screen.", - "evolutionsPaused": "Evolutions have been paused for {{pokemonName}}.", - "evolutionDone": "Congratulations!\nYour {{pokemonName}} evolved into {{evolvedPokemonName}}!", - "dailyRankings": "Daily Rankings", - "weeklyRankings": "Weekly Rankings", - "noRankings": "No Rankings", - "positionIcon": "#", - "usernameScoreboard": "Username", - "score": "Score", - "wave": "Wave", - "loading": "Loading…", - "loadingAsset": "Loading asset: {{assetName}}", - "playersOnline": "Players Online", - "yes": "Yes", - "no": "No", - "disclaimer": "DISCLAIMER", - "disclaimerDescription": "This game is an unfinished product; it might have playability issues (including the potential loss of save data),\n change without notice, and may or may not be updated further or completed.", - "choosePokemon": "Choose a Pokémon.", - "renamePokemon": "Rename Pokémon", - "rename": "Rename", - "nickname": "Nickname", - "errorServerDown": "Oops! There was an issue contacting the server.\n\nYou may leave this window open,\nthe game will automatically reconnect.", - "noSaves": "You don't have any save files on record!", - "tooManySaves": "You have too many save files on record!" -} \ No newline at end of file diff --git a/src/locales/en/modifier-select-ui-handler.json b/src/locales/en/modifier-select-ui-handler.json deleted file mode 100644 index 15c930fb65e..00000000000 --- a/src/locales/en/modifier-select-ui-handler.json +++ /dev/null @@ -1,14 +0,0 @@ -{ - "transfer": "Transfer", - "reroll": "Reroll", - "lockRarities": "Lock Rarities", - "checkTeam": "Check Team", - "transferDesc": "Transfer a held item from one Pokémon to another.", - "rerollDesc": "Spend money to reroll your item options.", - "lockRaritiesDesc": "Lock item rarities on reroll (affects reroll cost).", - "checkTeamDesc": "Check your team or use a form changing item.", - "rerollCost": "₽{{formattedMoney}}", - "itemCost": "₽{{formattedMoney}}", - "continueNextWaveButton": "Continue", - "continueNextWaveDescription": "Continue to the next wave." -} \ No newline at end of file diff --git a/src/locales/en/modifier-type.json b/src/locales/en/modifier-type.json deleted file mode 100644 index c362b3f30d4..00000000000 --- a/src/locales/en/modifier-type.json +++ /dev/null @@ -1,483 +0,0 @@ -{ - "ModifierType": { - "AddPokeballModifierType": { - "name": "{{modifierCount}}x {{pokeballName}}", - "description": "Receive {{pokeballName}} x{{modifierCount}} (Inventory: {{pokeballAmount}}) \nCatch Rate: {{catchRate}}" - }, - "AddVoucherModifierType": { - "name": "{{modifierCount}}x {{voucherTypeName}}", - "description": "Receive {{voucherTypeName}} x{{modifierCount}}." - }, - "PokemonHeldItemModifierType": { - "extra": { - "inoperable": "{{pokemonName}} can't take\nthis item!", - "tooMany": "{{pokemonName}} has too many\nof this item!" - } - }, - "PokemonHpRestoreModifierType": { - "description": "Restores {{restorePoints}} HP or {{restorePercent}}% HP for one Pokémon, whichever is higher.", - "extra": { - "fully": "Fully restores HP for one Pokémon.", - "fullyWithStatus": "Fully restores HP for one Pokémon and heals any status ailment." - } - }, - "PokemonReviveModifierType": { - "description": "Revives one Pokémon and restores {{restorePercent}}% HP." - }, - "PokemonStatusHealModifierType": { - "description": "Heals any status ailment for one Pokémon." - }, - "PokemonPpRestoreModifierType": { - "description": "Restores {{restorePoints}} PP for one Pokémon move.", - "extra": { - "fully": "Restores all PP for one Pokémon move." - } - }, - "PokemonAllMovePpRestoreModifierType": { - "description": "Restores {{restorePoints}} PP for all of one Pokémon's moves.", - "extra": { - "fully": "Restores all PP for all of one Pokémon's moves." - } - }, - "PokemonPpUpModifierType": { - "description": "Permanently increases PP for one Pokémon move by {{upPoints}} for every 5 maximum PP (maximum 3)." - }, - "PokemonNatureChangeModifierType": { - "name": "{{natureName}} Mint", - "description": "Changes a Pokémon's nature to {{natureName}} and permanently unlocks the nature for the starter." - }, - "DoubleBattleChanceBoosterModifierType": { - "description": "Quadruples the chance of an encounter being a double battle for up to {{battleCount}} battles." - }, - "TempStatStageBoosterModifierType": { - "description": "Increases the {{stat}} of all party members by {{amount}} for up to 5 battles.", - "extra": { - "stage": "1 stage", - "percentage": "30%" - } - }, - "AttackTypeBoosterModifierType": { - "description": "Increases the power of a Pokémon's {{moveType}}-type moves by 20%." - }, - "PokemonLevelIncrementModifierType": { - "description": "Increases a Pokémon's level by {{levels}}." - }, - "AllPokemonLevelIncrementModifierType": { - "description": "Increases all party members' level by {{levels}}." - }, - "BaseStatBoosterModifierType": { - "description": "Increases the holder's base {{stat}} by 10%. The higher your IVs, the higher the stack limit." - }, - "PokemonBaseStatTotalModifierType": { - "name": "Shuckle Juice", - "description": "{{increaseDecrease}} all of the holder's base stats by {{statValue}}. You were {{blessCurse}} by the Shuckle.", - "extra": { - "increase": "Increases", - "decrease": "Decreases", - "blessed": "blessed", - "cursed": "cursed" - } - }, - "PokemonBaseStatFlatModifierType": { - "name": "Old Gateau", - "description": "Increases the holder's {{stats}} base stats by {{statValue}}. Found after a strange dream." - }, - "AllPokemonFullHpRestoreModifierType": { - "description": "Restores 100% HP for all Pokémon." - }, - "AllPokemonFullReviveModifierType": { - "description": "Revives all fainted Pokémon, fully restoring HP." - }, - "MoneyRewardModifierType": { - "description": "Grants a {{moneyMultiplier}} amount of money (₽{{moneyAmount}}).", - "extra": { - "small": "small", - "moderate": "moderate", - "large": "large" - } - }, - "ExpBoosterModifierType": { - "description": "Increases gain of EXP. Points by {{boostPercent}}%." - }, - "PokemonExpBoosterModifierType": { - "description": "Increases the holder's gain of EXP. Points by {{boostPercent}}%." - }, - "PokemonFriendshipBoosterModifierType": { - "description": "Increases friendship gain per victory by 50%." - }, - "PokemonMoveAccuracyBoosterModifierType": { - "description": "Increases move accuracy by {{accuracyAmount}} (maximum 100)." - }, - "PokemonMultiHitModifierType": { - "description": "Attacks hit one additional time at the cost of a 60/75/82.5% power reduction per stack respectively." - }, - "TmModifierType": { - "name": "TM{{moveId}} - {{moveName}}", - "description": "Teach {{moveName}} to a Pokémon." - }, - "TmModifierTypeWithInfo": { - "name": "TM{{moveId}} - {{moveName}}", - "description": "Teach {{moveName}} to a Pokémon\n(Hold C or Shift for more info)." - }, - "EvolutionItemModifierType": { - "description": "Causes certain Pokémon to evolve." - }, - "FormChangeItemModifierType": { - "description": "Causes certain Pokémon to change form." - }, - "FusePokemonModifierType": { - "description": "Combines two Pokémon (transfers Ability, splits base stats and types, shares move pool)." - }, - "TerastallizeModifierType": { - "name": "{{teraType}} Tera Shard", - "description": "{{teraType}} Terastallizes the holder for up to 10 battles." - }, - "ContactHeldItemTransferChanceModifierType": { - "description": "Upon attacking, there is a {{chancePercent}}% chance the foe's held item will be stolen." - }, - "TurnHeldItemTransferModifierType": { - "description": "Every turn, the holder acquires one held item from the foe." - }, - "EnemyAttackStatusEffectChanceModifierType": { - "description": "Adds a {{chancePercent}}% chance to inflict {{statusEffect}} with attack moves." - }, - "EnemyEndureChanceModifierType": { - "description": "Adds a {{chancePercent}}% chance of enduring a hit." - }, - - "RARE_CANDY": { "name": "Rare Candy" }, - "RARER_CANDY": { "name": "Rarer Candy" }, - - "MEGA_BRACELET": { "name": "Mega Bracelet", "description": "Mega Stones become available." }, - "DYNAMAX_BAND": { "name": "Dynamax Band", "description": "Max Mushrooms become available." }, - "TERA_ORB": { "name": "Tera Orb", "description": "Tera Shards become available." }, - - "MAP": { "name": "Map", "description": "Allows you to choose your destination at a crossroads." }, - - "POTION": { "name": "Potion" }, - "SUPER_POTION": { "name": "Super Potion" }, - "HYPER_POTION": { "name": "Hyper Potion" }, - "MAX_POTION": { "name": "Max Potion" }, - "FULL_RESTORE": { "name": "Full Restore" }, - - "REVIVE": { "name": "Revive" }, - "MAX_REVIVE": { "name": "Max Revive" }, - - "FULL_HEAL": { "name": "Full Heal" }, - - "SACRED_ASH": { "name": "Sacred Ash" }, - - "REVIVER_SEED": { "name": "Reviver Seed", "description": "Revives the holder for 1/2 HP upon fainting from a direct hit." }, - - "WHITE_HERB": { "name": "White Herb", "description": "An item to be held by a Pokémon. It will restore any lowered stat in battle." }, - - "ETHER": { "name": "Ether" }, - "MAX_ETHER": { "name": "Max Ether" }, - - "ELIXIR": { "name": "Elixir" }, - "MAX_ELIXIR": { "name": "Max Elixir" }, - - "PP_UP": { "name": "PP Up" }, - "PP_MAX": { "name": "PP Max" }, - - "LURE": { "name": "Lure" }, - "SUPER_LURE": { "name": "Super Lure" }, - "MAX_LURE": { "name": "Max Lure" }, - - "MEMORY_MUSHROOM": { "name": "Memory Mushroom", "description": "Recall one Pokémon's forgotten move." }, - - "EXP_SHARE": { "name": "EXP. All", "description": "Non-participants receive 20% of a single participant's EXP. Points." }, - "EXP_BALANCE": { "name": "EXP. Balance", "description": "Weighs EXP. Points received from battles towards lower-leveled party members." }, - - "OVAL_CHARM": { "name": "Oval Charm", "description": "When multiple Pokémon participate in a battle, each gets an extra 10% of the total EXP." }, - - "EXP_CHARM": { "name": "EXP. Charm" }, - "SUPER_EXP_CHARM": { "name": "Super EXP. Charm" }, - "GOLDEN_EXP_CHARM": { "name": "Golden EXP. Charm" }, - - "LUCKY_EGG": { "name": "Lucky Egg" }, - "GOLDEN_EGG": { "name": "Golden Egg" }, - - "SOOTHE_BELL": { "name": "Soothe Bell" }, - - "SCOPE_LENS": { "name": "Scope Lens", "description": "It's a lens for scoping out weak points. It boosts the holder's critical-hit ratio."}, - "DIRE_HIT": { "name": "Dire Hit", "extra": { "raises": "Critical Hit Ratio" } }, - "LEEK": { "name": "Leek", "description": "This very long and stiff stalk of leek boosts the critical-hit ratio of Farfetch'd's moves."}, - - "EVIOLITE": { "name": "Eviolite", "description": "This mysterious evolutionary lump boosts the Defense and Sp. Def stats when held by a Pokémon that can still evolve." }, - - "SOUL_DEW": { "name": "Soul Dew", "description": "Increases the influence of a Pokémon's nature on its stats by 10% (additive)." }, - - "NUGGET": { "name": "Nugget" }, - "BIG_NUGGET": { "name": "Big Nugget" }, - "RELIC_GOLD": { "name": "Relic Gold" }, - - "AMULET_COIN": { "name": "Amulet Coin", "description": "Increases money rewards by 20%." }, - "GOLDEN_PUNCH": { "name": "Golden Punch", "description": "Grants 50% of direct damage inflicted as money." }, - "COIN_CASE": { "name": "Coin Case", "description": "After every 10th battle, receive 10% of your money in interest." }, - - "LOCK_CAPSULE": { "name": "Lock Capsule", "description": "Allows you to lock item rarities when rerolling items." }, - - "GRIP_CLAW": { "name": "Grip Claw" }, - "WIDE_LENS": { "name": "Wide Lens" }, - - "MULTI_LENS": { "name": "Multi Lens" }, - - "HEALING_CHARM": { "name": "Healing Charm", "description": "Increases the effectiveness of HP restoring moves and items by 10% (excludes Revives)." }, - "CANDY_JAR": { "name": "Candy Jar", "description": "Increases the number of levels added by Rare Candy items by 1." }, - - "BERRY_POUCH": { "name": "Berry Pouch", "description": "Adds a 30% chance that a used berry will not be consumed." }, - - "FOCUS_BAND": { "name": "Focus Band", "description": "Adds a 10% chance to survive with 1 HP after being damaged enough to faint." }, - - "QUICK_CLAW": { "name": "Quick Claw", "description": "Adds a 10% chance to move first regardless of speed (after priority)." }, - - "KINGS_ROCK": { "name": "King's Rock", "description": "Adds a 10% chance an attack move will cause the opponent to flinch." }, - - "LEFTOVERS": { "name": "Leftovers", "description": "Heals 1/16 of a Pokémon's maximum HP every turn." }, - "SHELL_BELL": { "name": "Shell Bell", "description": "Heals 1/8 of a Pokémon's dealt damage." }, - - "TOXIC_ORB": { "name": "Toxic Orb", "description": "It's a bizarre orb that exudes toxins when touched and will badly poison the holder during battle." }, - "FLAME_ORB": { "name": "Flame Orb", "description": "It's a bizarre orb that gives off heat when touched and will affect the holder with a burn during battle." }, - - "EVOLUTION_TRACKER_GIMMIGHOUL": { "name": "Treasures", "description": "This Pokémon loves treasure! Keep collecting treasure and something might happen!"}, - - "BATON": { "name": "Baton", "description": "Allows passing along effects when switching Pokémon, which also bypasses traps." }, - - "SHINY_CHARM": { "name": "Shiny Charm", "description": "Dramatically increases the chance of a wild Pokémon being Shiny." }, - "ABILITY_CHARM": { "name": "Ability Charm", "description": "Dramatically increases the chance of a wild Pokémon having a Hidden Ability." }, - - "IV_SCANNER": { "name": "IV Scanner", "description": "Allows scanning the IVs of wild Pokémon. 2 IVs are revealed per stack. The best IVs are shown first." }, - - "DNA_SPLICERS": { "name": "DNA Splicers" }, - - "MINI_BLACK_HOLE": { "name": "Mini Black Hole" }, - - "GOLDEN_POKEBALL": { "name": "Golden Poké Ball", "description": "Adds 1 extra item option at the end of every battle." }, - - "ENEMY_DAMAGE_BOOSTER": { "name": "Damage Token", "description": "Increases damage by 5%." }, - "ENEMY_DAMAGE_REDUCTION": { "name": "Protection Token", "description": "Reduces incoming damage by 2.5%." }, - "ENEMY_HEAL": { "name": "Recovery Token", "description": "Heals 2% of max HP every turn." }, - "ENEMY_ATTACK_POISON_CHANCE": { "name": "Poison Token" }, - "ENEMY_ATTACK_PARALYZE_CHANCE": { "name": "Paralyze Token" }, - "ENEMY_ATTACK_BURN_CHANCE": { "name": "Burn Token" }, - "ENEMY_STATUS_EFFECT_HEAL_CHANCE": { "name": "Full Heal Token", "description": "Adds a 2.5% chance every turn to heal a status condition." }, - "ENEMY_ENDURE_CHANCE": { "name": "Endure Token" }, - "ENEMY_FUSED_CHANCE": { "name": "Fusion Token", "description": "Adds a 1% chance that a wild Pokémon will be a fusion." }, - - "MYSTERY_ENCOUNTER_SHUCKLE_JUICE": { "name": "Shuckle Juice" }, - "MYSTERY_ENCOUNTER_BLACK_SLUDGE": { "name": "Black Sludge", "description": "The stench is so powerful that shops will only sell you items at a steep cost increase." }, - "MYSTERY_ENCOUNTER_MACHO_BRACE": { "name": "Macho Brace", "description": "Defeating a Pokémon grants the holder a Macho Brace stack. Each stack slightly boosts stats, with an extra bonus at max stacks." }, - "MYSTERY_ENCOUNTER_OLD_GATEAU": { "name": "Old Gateau", "description": "Increases the holder's {{stats}} stats by {{statValue}}." }, - "MYSTERY_ENCOUNTER_GOLDEN_BUG_NET": { "name": "Golden Bug Net", "description": "Imbues the owner with luck to find Bug Type Pokémon more often. Has a strange heft to it." } - }, - "SpeciesBoosterItem": { - "LIGHT_BALL": { "name": "Light Ball", "description": "It's a mysterious orb that boosts Pikachu's Attack and Sp. Atk stats." }, - "THICK_CLUB": { "name": "Thick Club", "description": "This hard bone of unknown origin boosts Cubone or Marowak's Attack stat." }, - "METAL_POWDER": { "name": "Metal Powder", "description": "Extremely fine yet hard, this odd powder boosts Ditto's Defense stat." }, - "QUICK_POWDER": { "name": "Quick Powder", "description": "Extremely fine yet hard, this odd powder boosts Ditto's Speed stat." } - }, - "TempStatStageBoosterItem": { - "x_attack": "X Attack", - "x_defense": "X Defense", - "x_sp_atk": "X Sp. Atk", - "x_sp_def": "X Sp. Def", - "x_speed": "X Speed", - "x_accuracy": "X Accuracy" - }, - "AttackTypeBoosterItem": { - "silk_scarf": "Silk Scarf", - "black_belt": "Black Belt", - "sharp_beak": "Sharp Beak", - "poison_barb": "Poison Barb", - "soft_sand": "Soft Sand", - "hard_stone": "Hard Stone", - "silver_powder": "Silver Powder", - "spell_tag": "Spell Tag", - "metal_coat": "Metal Coat", - "charcoal": "Charcoal", - "mystic_water": "Mystic Water", - "miracle_seed": "Miracle Seed", - "magnet": "Magnet", - "twisted_spoon": "Twisted Spoon", - "never_melt_ice": "Never-Melt Ice", - "dragon_fang": "Dragon Fang", - "black_glasses": "Black Glasses", - "fairy_feather": "Fairy Feather" - }, - "BaseStatBoosterItem": { - "hp_up": "HP Up", - "protein": "Protein", - "iron": "Iron", - "calcium": "Calcium", - "zinc": "Zinc", - "carbos": "Carbos" - }, - "EvolutionItem": { - "NONE": "None", - - "LINKING_CORD": "Linking Cord", - "SUN_STONE": "Sun Stone", - "MOON_STONE": "Moon Stone", - "LEAF_STONE": "Leaf Stone", - "FIRE_STONE": "Fire Stone", - "WATER_STONE": "Water Stone", - "THUNDER_STONE": "Thunder Stone", - "ICE_STONE": "Ice Stone", - "DUSK_STONE": "Dusk Stone", - "DAWN_STONE": "Dawn Stone", - "SHINY_STONE": "Shiny Stone", - "CRACKED_POT": "Cracked Pot", - "SWEET_APPLE": "Sweet Apple", - "TART_APPLE": "Tart Apple", - "STRAWBERRY_SWEET": "Strawberry Sweet", - "UNREMARKABLE_TEACUP": "Unremarkable Teacup", - "UPGRADE": "Upgrade", - "DUBIOUS_DISC": "Dubious Disc", - "DRAGON_SCALE": "Dragon Scale", - "PRISM_SCALE": "Prism Scale", - "RAZOR_CLAW": "Razor Claw", - "RAZOR_FANG": "Razor Fang", - "REAPER_CLOTH": "Reaper Cloth", - "ELECTIRIZER": "Electirizer", - "MAGMARIZER": "Magmarizer", - "PROTECTOR": "Protector", - "SACHET": "Sachet", - "WHIPPED_DREAM": "Whipped Dream", - "LEADERS_CREST": "Leader's Crest", - "SUN_FLUTE": "Sun Flute", - "MOON_FLUTE": "Moon Flute", - - "CHIPPED_POT": "Chipped Pot", - "BLACK_AUGURITE": "Black Augurite", - "GALARICA_CUFF": "Galarica Cuff", - "GALARICA_WREATH": "Galarica Wreath", - "PEAT_BLOCK": "Peat Block", - "AUSPICIOUS_ARMOR": "Auspicious Armor", - "MALICIOUS_ARMOR": "Malicious Armor", - "MASTERPIECE_TEACUP": "Masterpiece Teacup", - "METAL_ALLOY": "Metal Alloy", - "SCROLL_OF_DARKNESS": "Scroll Of Darkness", - "SCROLL_OF_WATERS": "Scroll Of Waters", - "SYRUPY_APPLE": "Syrupy Apple" - }, - "FormChangeItem": { - "NONE": "None", - - "ABOMASITE": "Abomasite", - "ABSOLITE": "Absolite", - "AERODACTYLITE": "Aerodactylite", - "AGGRONITE": "Aggronite", - "ALAKAZITE": "Alakazite", - "ALTARIANITE": "Altarianite", - "AMPHAROSITE": "Ampharosite", - "AUDINITE": "Audinite", - "BANETTITE": "Banettite", - "BEEDRILLITE": "Beedrillite", - "BLASTOISINITE": "Blastoisinite", - "BLAZIKENITE": "Blazikenite", - "CAMERUPTITE": "Cameruptite", - "CHARIZARDITE_X": "Charizardite X", - "CHARIZARDITE_Y": "Charizardite Y", - "DIANCITE": "Diancite", - "GALLADITE": "Galladite", - "GARCHOMPITE": "Garchompite", - "GARDEVOIRITE": "Gardevoirite", - "GENGARITE": "Gengarite", - "GLALITITE": "Glalitite", - "GYARADOSITE": "Gyaradosite", - "HERACRONITE": "Heracronite", - "HOUNDOOMINITE": "Houndoominite", - "KANGASKHANITE": "Kangaskhanite", - "LATIASITE": "Latiasite", - "LATIOSITE": "Latiosite", - "LOPUNNITE": "Lopunnite", - "LUCARIONITE": "Lucarionite", - "MANECTITE": "Manectite", - "MAWILITE": "Mawilite", - "MEDICHAMITE": "Medichamite", - "METAGROSSITE": "Metagrossite", - "MEWTWONITE_X": "Mewtwonite X", - "MEWTWONITE_Y": "Mewtwonite Y", - "PIDGEOTITE": "Pidgeotite", - "PINSIRITE": "Pinsirite", - "RAYQUAZITE": "Rayquazite", - "SABLENITE": "Sablenite", - "SALAMENCITE": "Salamencite", - "SCEPTILITE": "Sceptilite", - "SCIZORITE": "Scizorite", - "SHARPEDONITE": "Sharpedonite", - "SLOWBRONITE": "Slowbronite", - "STEELIXITE": "Steelixite", - "SWAMPERTITE": "Swampertite", - "TYRANITARITE": "Tyranitarite", - "VENUSAURITE": "Venusaurite", - - "BLUE_ORB": "Blue Orb", - "RED_ORB": "Red Orb", - "SHARP_METEORITE": "Sharp Meteorite", - "HARD_METEORITE": "Hard Meteorite", - "SMOOTH_METEORITE": "Smooth Meteorite", - "ADAMANT_CRYSTAL": "Adamant Crystal", - "LUSTROUS_GLOBE": "Lustrous Globe", - "GRISEOUS_CORE": "Griseous Core", - "REVEAL_GLASS": "Reveal Glass", - "GRACIDEA": "Gracidea", - "MAX_MUSHROOMS": "Max Mushrooms", - "DARK_STONE": "Dark Stone", - "LIGHT_STONE": "Light Stone", - "PRISON_BOTTLE": "Prison Bottle", - "N_LUNARIZER": "N Lunarizer", - "N_SOLARIZER": "N Solarizer", - "RUSTED_SWORD": "Rusted Sword", - "RUSTED_SHIELD": "Rusted Shield", - "ICY_REINS_OF_UNITY": "Icy Reins Of Unity", - "SHADOW_REINS_OF_UNITY": "Shadow Reins Of Unity", - "WELLSPRING_MASK": "Wellspring Mask", - "HEARTHFLAME_MASK": "Hearthflame Mask", - "CORNERSTONE_MASK": "Cornerstone Mask", - "SHOCK_DRIVE": "Shock Drive", - "BURN_DRIVE": "Burn Drive", - "CHILL_DRIVE": "Chill Drive", - "DOUSE_DRIVE": "Douse Drive", - "ULTRANECROZIUM_Z": "Ultranecrozium Z", - - "FIST_PLATE": "Fist Plate", - "SKY_PLATE": "Sky Plate", - "TOXIC_PLATE": "Toxic Plate", - "EARTH_PLATE": "Earth Plate", - "STONE_PLATE": "Stone Plate", - "INSECT_PLATE": "Insect Plate", - "SPOOKY_PLATE": "Spooky Plate", - "IRON_PLATE": "Iron Plate", - "FLAME_PLATE": "Flame Plate", - "SPLASH_PLATE": "Splash Plate", - "MEADOW_PLATE": "Meadow Plate", - "ZAP_PLATE": "Zap Plate", - "MIND_PLATE": "Mind Plate", - "ICICLE_PLATE": "Icicle Plate", - "DRACO_PLATE": "Draco Plate", - "DREAD_PLATE": "Dread Plate", - "PIXIE_PLATE": "Pixie Plate", - "BLANK_PLATE": "Blank Plate", - "LEGEND_PLATE": "Legend Plate", - "FIGHTING_MEMORY": "Fighting Memory", - "FLYING_MEMORY": "Flying Memory", - "POISON_MEMORY": "Poison Memory", - "GROUND_MEMORY": "Ground Memory", - "ROCK_MEMORY": "Rock Memory", - "BUG_MEMORY": "Bug Memory", - "GHOST_MEMORY": "Ghost Memory", - "STEEL_MEMORY": "Steel Memory", - "FIRE_MEMORY": "Fire Memory", - "WATER_MEMORY": "Water Memory", - "GRASS_MEMORY": "Grass Memory", - "ELECTRIC_MEMORY": "Electric Memory", - "PSYCHIC_MEMORY": "Psychic Memory", - "ICE_MEMORY": "Ice Memory", - "DRAGON_MEMORY": "Dragon Memory", - "DARK_MEMORY": "Dark Memory", - "FAIRY_MEMORY": "Fairy Memory", - "NORMAL_MEMORY": "Normal Memory" - } -} diff --git a/src/locales/en/modifier.json b/src/locales/en/modifier.json deleted file mode 100644 index 47944c8adb7..00000000000 --- a/src/locales/en/modifier.json +++ /dev/null @@ -1,12 +0,0 @@ -{ - "surviveDamageApply": "{{pokemonNameWithAffix}} hung on\nusing its {{typeName}}!", - "turnHealApply": "{{pokemonNameWithAffix}} restored a little HP using\nits {{typeName}}!", - "hitHealApply": "{{pokemonNameWithAffix}} restored a little HP using\nits {{typeName}}!", - "pokemonInstantReviveApply": "{{pokemonNameWithAffix}} was revived\nby its {{typeName}}!", - "resetNegativeStatStageApply": "{{pokemonNameWithAffix}}'s lowered stats were restored\nby its {{typeName}}!", - "moneyInterestApply": "You received interest of ₽{{moneyAmount}}\nfrom the {{typeName}}!", - "turnHeldItemTransferApply": "{{pokemonNameWithAffix}}'s {{itemName}} was absorbed\nby {{pokemonName}}'s {{typeName}}!", - "contactHeldItemTransferApply": "{{pokemonNameWithAffix}}'s {{itemName}} was snatched\nby {{pokemonName}}'s {{typeName}}!", - "enemyTurnHealApply": "{{pokemonNameWithAffix}}\nrestored some HP!", - "bypassSpeedChanceApply": "{{pokemonName}} can act faster than normal, thanks to its {{itemName}}!" -} \ No newline at end of file diff --git a/src/locales/en/move-trigger.json b/src/locales/en/move-trigger.json deleted file mode 100644 index bc58e2878dd..00000000000 --- a/src/locales/en/move-trigger.json +++ /dev/null @@ -1,74 +0,0 @@ -{ - "hitWithRecoil" : "{{pokemonName}} was damaged by the recoil!", - "cutHpPowerUpMove": "{{pokemonName}} cut its own HP to power up its move!", - "absorbedElectricity": "{{pokemonName}} absorbed electricity!", - "switchedStatChanges": "{{pokemonName}} switched stat changes with the target!", - "switchedTwoStatChanges": "{{pokemonName}} switched all changes to its {{firstStat}}\nand {{secondStat}} with its target!", - "switchedStat": "{{pokemonName}} switched {{stat}} with its target!", - "sharedGuard": "{{pokemonName}} shared its guard with the target!", - "sharedPower": "{{pokemonName}} shared its power with the target!", - "shiftedStats": "{{pokemonName}} switched its {{statToSwitch}} and {{statToSwitchWith}}!", - "goingAllOutForAttack": "{{pokemonName}} is going all out for this attack!", - "regainedHealth": "{{pokemonName}} regained\nhealth!", - "keptGoingAndCrashed": "{{pokemonName}} kept going\nand crashed!", - "fled": "{{pokemonName}} fled!", - "cannotBeSwitchedOut": "{{pokemonName}} can't be switched out!", - "swappedAbilitiesWithTarget": "{{pokemonName}} swapped\nabilities with its target!", - "coinsScatteredEverywhere": "Coins were scattered everywhere!", - "attackedByItem": "{{pokemonName}} is about to be attacked by its {{itemName}}!", - "whippedUpAWhirlwind": "{{pokemonName}} whipped\nup a whirlwind!", - "flewUpHigh": "{{pokemonName}} flew\nup high!", - "tookInSunlight": "{{pokemonName}} absorbed light!", - "dugAHole": "{{pokemonName}} burrowed its way under the ground!", - "loweredItsHead": "{{pokemonName}} tucked in its head!", - "isGlowing": "{{pokemonName}} became cloaked in a harsh light!", - "bellChimed": "A bell chimed!", - "foresawAnAttack": "{{pokemonName}} foresaw\nan attack!", - "isTighteningFocus": "{{pokemonName}} is\ntightening its focus!", - "hidUnderwater": "{{pokemonName}} hid\nunderwater!", - "soothingAromaWaftedThroughArea": "A soothing aroma wafted through the area!", - "sprangUp": "{{pokemonName}} sprang up!", - "choseDoomDesireAsDestiny": "{{pokemonName}} chose\nDoom Desire as its destiny!", - "vanishedInstantly": "{{pokemonName}} vanished\ninstantly!", - "tookTargetIntoSky": "{{pokemonName}} took {{targetName}}\ninto the sky!", - "becameCloakedInFreezingLight": "{{pokemonName}} became cloaked\nin a freezing light!", - "becameCloakedInFreezingAir": "{{pokemonName}} became cloaked\nin freezing air!", - "isChargingPower": "{{pokemonName}} is absorbing power!", - "burnedItselfOut": "{{pokemonName}} burned itself out!", - "startedHeatingUpBeak": "{{pokemonName}} started\nheating up its beak!", - "setUpShellTrap": "{{pokemonName}} set a shell trap!", - "isOverflowingWithSpacePower": "{{pokemonName}} is overflowing\nwith space power!", - "usedUpAllElectricity": "{{pokemonName}} used up all its electricity!", - "stoleItem": "{{pokemonName}} stole\n{{targetName}}'s {{itemName}}!", - "incineratedItem": "{{pokemonName}} incinerated\n{{targetName}}'s {{itemName}}!", - "knockedOffItem": "{{pokemonName}} knocked off\n{{targetName}}'s {{itemName}}!", - "tookMoveAttack": "{{pokemonName}} took\nthe {{moveName}} attack!", - "cutOwnHpAndMaximizedStat": "{{pokemonName}} cut its own HP\nand maximized its {{statName}}!", - "copiedStatChanges": "{{pokemonName}} copied\n{{targetName}}'s stat changes!", - "magnitudeMessage": "Magnitude {{magnitude}}!", - "tookAimAtTarget": "{{pokemonName}} took aim\nat {{targetName}}!", - "transformedIntoType": "{{pokemonName}} transformed\ninto the {{typeName}} type!", - "copiedMove": "{{pokemonName}} copied\n{{moveName}}!", - "sketchedMove": "{{pokemonName}} sketched\n{{moveName}}!", - "acquiredAbility": "The {{pokemonName}} acquired\n{{abilityName}}!", - "copiedTargetAbility": "{{pokemonName}} copied the {{targetName}}'s\n{{abilityName}}!", - "transformedIntoTarget": "{{pokemonName}} transformed\ninto {{targetName}}!", - "tryingToTakeFoeDown": "{{pokemonName}} is hoping to take its attacker down with it!", - "addType": "{{typeName}} was added to\n{{pokemonName}}!", - "cannotUseMove": "{{pokemonName}} cannot use {{moveName}}!", - "healHp": "{{pokemonName}} had its HP restored.", - "sacrificialFullRestore": "{{pokemonName}}'s Healing Wish\nwas granted!", - "invertStats": "{{pokemonName}}'s stat changes\nwere all reversed!", - "resetStats": "{{pokemonName}}'s stat changes\nwere eliminated!", - "statEliminated": "All stat changes were eliminated!", - "faintCountdown": "{{pokemonName}}\nwill faint in {{turnCount}} turns.", - "copyType": "{{pokemonName}}'s type became the same as\n{{targetPokemonName}}'s type!", - "suppressAbilities": "{{pokemonName}}'s ability\nwas suppressed!", - "revivalBlessing": "{{pokemonName}} was revived!", - "swapArenaTags": "{{pokemonName}} swapped the battle effects affecting each side of the field!", - "exposedMove": "{{pokemonName}} identified\n{{targetPokemonName}}!", - "safeguard": "{{targetName}} is protected by Safeguard!", - "substituteOnOverlap": "{{pokemonName}} already\nhas a substitute!", - "substituteNotEnoughHp": "But it does not have enough HP\nleft to make a substitute!", - "afterYou": "{{pokemonName}} took the kind offer!" -} \ No newline at end of file diff --git a/src/locales/en/move.json b/src/locales/en/move.json deleted file mode 100644 index 7a10335ed06..00000000000 --- a/src/locales/en/move.json +++ /dev/null @@ -1,3810 +0,0 @@ -{ - "pound": { - "name": "Pound", - "effect": "The target is physically pounded with a long tail, a foreleg, or the like." - }, - "karateChop": { - "name": "Karate Chop", - "effect": "The target is attacked with a sharp chop. Critical hits land more easily." - }, - "doubleSlap": { - "name": "Double Slap", - "effect": "The target is slapped repeatedly, back and forth, two to five times in a row." - }, - "cometPunch": { - "name": "Comet Punch", - "effect": "The target is hit with a flurry of punches that strike two to five times in a row." - }, - "megaPunch": { - "name": "Mega Punch", - "effect": "The target is slugged by a punch thrown with muscle-packed power." - }, - "payDay": { - "name": "Pay Day", - "effect": "Numerous coins are hurled at the target to inflict damage. Money is earned after the battle." - }, - "firePunch": { - "name": "Fire Punch", - "effect": "The target is punched with a fiery fist. This may also leave the target with a burn." - }, - "icePunch": { - "name": "Ice Punch", - "effect": "The target is punched with an icy fist. This may also leave the target frozen." - }, - "thunderPunch": { - "name": "Thunder Punch", - "effect": "The target is punched with an electrified fist. This may also leave the target with paralysis." - }, - "scratch": { - "name": "Scratch", - "effect": "Hard, pointed, sharp claws rake the target to inflict damage." - }, - "viseGrip": { - "name": "Vise Grip", - "effect": "The target is gripped and squeezed from both sides to inflict damage." - }, - "guillotine": { - "name": "Guillotine", - "effect": "A vicious, tearing attack with big pincers. The target faints instantly if this attack hits." - }, - "razorWind": { - "name": "Razor Wind", - "effect": "In this two-turn attack, blades of wind hit opposing Pokémon on the second turn. Critical hits land more easily." - }, - "swordsDance": { - "name": "Swords Dance", - "effect": "A frenetic dance to uplift the fighting spirit. This sharply raises the user's Attack stat." - }, - "cut": { - "name": "Cut", - "effect": "The target is cut with a scythe or claw." - }, - "gust": { - "name": "Gust", - "effect": "A gust of wind is whipped up by wings and launched at the target to inflict damage." - }, - "wingAttack": { - "name": "Wing Attack", - "effect": "The target is struck with large, imposing wings spread wide to inflict damage." - }, - "whirlwind": { - "name": "Whirlwind", - "effect": "The target is blown away, and a different Pokémon is dragged out. In the wild, this ends a battle against a single Pokémon." - }, - "fly": { - "name": "Fly", - "effect": "The user flies up into the sky and then strikes its target on the next turn." - }, - "bind": { - "name": "Bind", - "effect": "Things such as long bodies or tentacles are used to bind and squeeze the target for four to five turns." - }, - "slam": { - "name": "Slam", - "effect": "The target is slammed with a long tail, vines, or the like to inflict damage." - }, - "vineWhip": { - "name": "Vine Whip", - "effect": "The target is struck with slender, whiplike vines to inflict damage." - }, - "stomp": { - "name": "Stomp", - "effect": "The target is stomped with a big foot. This may also make the target flinch." - }, - "doubleKick": { - "name": "Double Kick", - "effect": "The target is quickly kicked twice in succession using both feet." - }, - "megaKick": { - "name": "Mega Kick", - "effect": "The target is attacked by a kick launched with muscle-packed power." - }, - "jumpKick": { - "name": "Jump Kick", - "effect": "The user jumps up high, then strikes with a kick. If the kick misses, the user hurts itself." - }, - "rollingKick": { - "name": "Rolling Kick", - "effect": "The user lashes out with a quick, spinning kick. This may also make the target flinch." - }, - "sandAttack": { - "name": "Sand Attack", - "effect": "Sand is hurled in the target's face, reducing the target's accuracy." - }, - "headbutt": { - "name": "Headbutt", - "effect": "The user sticks out its head and attacks by charging straight into the target. This may also make the target flinch." - }, - "hornAttack": { - "name": "Horn Attack", - "effect": "The target is jabbed with a sharply pointed horn to inflict damage." - }, - "furyAttack": { - "name": "Fury Attack", - "effect": "The target is jabbed repeatedly with a horn or beak two to five times in a row." - }, - "hornDrill": { - "name": "Horn Drill", - "effect": "The user stabs the target with a horn that rotates like a drill. The target faints instantly if this attack hits." - }, - "tackle": { - "name": "Tackle", - "effect": "A physical attack in which the user charges and slams into the target with its whole body." - }, - "bodySlam": { - "name": "Body Slam", - "effect": "The user drops onto the target with its full body weight. This may also leave the target with paralysis." - }, - "wrap": { - "name": "Wrap", - "effect": "A long body, vines, or the like are used to wrap and squeeze the target for four to five turns." - }, - "takeDown": { - "name": "Take Down", - "effect": "A reckless, full-body charge attack for slamming into the target. This also damages the user a little." - }, - "thrash": { - "name": "Thrash", - "effect": "The user rampages and attacks for two to three turns. The user then becomes confused." - }, - "doubleEdge": { - "name": "Double-Edge", - "effect": "A reckless, life-risking tackle in which the user rushes the target. This also damages the user quite a lot." - }, - "tailWhip": { - "name": "Tail Whip", - "effect": "The user wags its tail cutely, making opposing Pokémon less wary and lowering their Defense stats." - }, - "poisonSting": { - "name": "Poison Sting", - "effect": "The user stabs the target with a poisonous stinger. This may also poison the target." - }, - "twineedle": { - "name": "Twineedle", - "effect": "The user damages the target twice in succession by jabbing it with two spikes. This may also poison the target." - }, - "pinMissile": { - "name": "Pin Missile", - "effect": "Sharp spikes are shot at the target in rapid succession. They hit two to five times in a row." - }, - "leer": { - "name": "Leer", - "effect": "The user gives opposing Pokémon an intimidating leer that lowers the Defense stat." - }, - "bite": { - "name": "Bite", - "effect": "The target is bitten with viciously sharp fangs. This may also make the target flinch." - }, - "growl": { - "name": "Growl", - "effect": "The user growls in an endearing way, making opposing Pokémon less wary. This lowers their Attack stats." - }, - "roar": { - "name": "Roar", - "effect": "The target is scared off, and a different Pokémon is dragged out. In the wild, this ends a battle against a single Pokémon." - }, - "sing": { - "name": "Sing", - "effect": "A soothing lullaby is sung in a calming voice that puts the target into a deep slumber." - }, - "supersonic": { - "name": "Supersonic", - "effect": "The user generates odd sound waves from its body that confuse the target." - }, - "sonicBoom": { - "name": "Sonic Boom", - "effect": "The target is hit with a destructive shock wave that always inflicts 20 HP damage." - }, - "disable": { - "name": "Disable", - "effect": "For four turns, this move prevents the target from using the move it last used." - }, - "acid": { - "name": "Acid", - "effect": "Opposing Pokémon are attacked with a spray of harsh acid. This may also lower their Sp. Def stats." - }, - "ember": { - "name": "Ember", - "effect": "The target is attacked with small flames. This may also leave the target with a burn." - }, - "flamethrower": { - "name": "Flamethrower", - "effect": "The target is scorched with an intense blast of fire. This may also leave the target with a burn." - }, - "mist": { - "name": "Mist", - "effect": "The user cloaks itself and its allies in a white mist that prevents any of their stats from being lowered for five turns." - }, - "waterGun": { - "name": "Water Gun", - "effect": "The target is blasted with a forceful shot of water." - }, - "hydroPump": { - "name": "Hydro Pump", - "effect": "The target is blasted by a huge volume of water launched under great pressure." - }, - "surf": { - "name": "Surf", - "effect": "The user attacks everything around it by swamping its surroundings with a giant wave." - }, - "iceBeam": { - "name": "Ice Beam", - "effect": "The target is struck with an icy-cold beam of energy. This may also leave the target frozen." - }, - "blizzard": { - "name": "Blizzard", - "effect": "A howling blizzard is summoned to strike opposing Pokémon. This may also leave the opposing Pokémon frozen." - }, - "psybeam": { - "name": "Psybeam", - "effect": "The target is attacked with a peculiar ray. This may also leave the target confused." - }, - "bubbleBeam": { - "name": "Bubble Beam", - "effect": "A spray of bubbles is forcefully ejected at the target. This may also lower the target's Speed stat." - }, - "auroraBeam": { - "name": "Aurora Beam", - "effect": "The target is hit with a rainbow-colored beam. This may also lower the target's Attack stat." - }, - "hyperBeam": { - "name": "Hyper Beam", - "effect": "The target is attacked with a powerful beam. The user can't move on the next turn." - }, - "peck": { - "name": "Peck", - "effect": "The target is jabbed with a sharply pointed beak or horn." - }, - "drillPeck": { - "name": "Drill Peck", - "effect": "A corkscrewing attack that strikes the target with a sharp beak acting as a drill." - }, - "submission": { - "name": "Submission", - "effect": "The user grabs the target and recklessly dives for the ground. This also damages the user a little." - }, - "lowKick": { - "name": "Low Kick", - "effect": "A powerful low kick that makes the target fall over. The heavier the target, the greater the move's power." - }, - "counter": { - "name": "Counter", - "effect": "A retaliation move that counters any physical attack, inflicting double the damage taken." - }, - "seismicToss": { - "name": "Seismic Toss", - "effect": "The target is thrown using the power of gravity. It inflicts damage equal to the user's level." - }, - "strength": { - "name": "Strength", - "effect": "The target is slugged with a punch thrown at maximum power." - }, - "absorb": { - "name": "Absorb", - "effect": "A nutrient-draining attack. The user's HP is restored by half the damage taken by the target." - }, - "megaDrain": { - "name": "Mega Drain", - "effect": "A nutrient-draining attack. The user's HP is restored by half the damage taken by the target." - }, - "leechSeed": { - "name": "Leech Seed", - "effect": "A seed is planted on the target. It steals some HP from the target every turn." - }, - "growth": { - "name": "Growth", - "effect": "The user's body grows all at once, raising the Attack and Sp. Atk stats." - }, - "razorLeaf": { - "name": "Razor Leaf", - "effect": "Sharp-edged leaves are launched to slash at opposing Pokémon. Critical hits land more easily." - }, - "solarBeam": { - "name": "Solar Beam", - "effect": "In this two-turn attack, the user gathers light, then blasts a bundled beam on the next turn." - }, - "poisonPowder": { - "name": "Poison Powder", - "effect": "The user scatters a cloud of poisonous dust that poisons the target." - }, - "stunSpore": { - "name": "Stun Spore", - "effect": "The user scatters a cloud of numbing powder that paralyzes the target." - }, - "sleepPowder": { - "name": "Sleep Powder", - "effect": "The user scatters a big cloud of sleep-inducing dust around the target." - }, - "petalDance": { - "name": "Petal Dance", - "effect": "The user attacks the target by scattering petals for two to three turns. The user then becomes confused." - }, - "stringShot": { - "name": "String Shot", - "effect": "Opposing Pokémon are bound with silk blown from the user's mouth that harshly lowers the Speed stat." - }, - "dragonRage": { - "name": "Dragon Rage", - "effect": "This attack hits the target with a shock wave of pure rage. This attack always inflicts 40 HP damage." - }, - "fireSpin": { - "name": "Fire Spin", - "effect": "The target becomes trapped within a fierce vortex of fire that rages for four to five turns." - }, - "thunderShock": { - "name": "Thunder Shock", - "effect": "A jolt of electricity crashes down on the target to inflict damage. This may also leave the target with paralysis." - }, - "thunderbolt": { - "name": "Thunderbolt", - "effect": "A strong electric blast crashes down on the target. This may also leave the target with paralysis." - }, - "thunderWave": { - "name": "Thunder Wave", - "effect": "The user launches a weak jolt of electricity that paralyzes the target." - }, - "thunder": { - "name": "Thunder", - "effect": "A wicked thunderbolt is dropped on the target to inflict damage. This may also leave the target with paralysis." - }, - "rockThrow": { - "name": "Rock Throw", - "effect": "The user picks up and throws a small rock at the target to attack." - }, - "earthquake": { - "name": "Earthquake", - "effect": "The user sets off an earthquake that strikes every Pokémon around it." - }, - "fissure": { - "name": "Fissure", - "effect": "The user opens up a fissure in the ground and drops the target in. The target faints instantly if this attack hits." - }, - "dig": { - "name": "Dig", - "effect": "The user burrows into the ground, then attacks on the next turn." - }, - "toxic": { - "name": "Toxic", - "effect": "A move that leaves the target badly poisoned. Its poison damage worsens every turn." - }, - "confusion": { - "name": "Confusion", - "effect": "The target is hit by a weak telekinetic force. This may also confuse the target." - }, - "psychic": { - "name": "Psychic", - "effect": "The target is hit by a strong telekinetic force. This may also lower the target's Sp. Def stat." - }, - "hypnosis": { - "name": "Hypnosis", - "effect": "The user employs hypnotic suggestion to make the target fall into a deep sleep." - }, - "meditate": { - "name": "Meditate", - "effect": "The user meditates to awaken the power deep within its body and raise its Attack stat." - }, - "agility": { - "name": "Agility", - "effect": "The user relaxes and lightens its body to move faster. This sharply raises the Speed stat." - }, - "quickAttack": { - "name": "Quick Attack", - "effect": "The user lunges at the target at a speed that makes it almost invisible. This move always goes first." - }, - "rage": { - "name": "Rage", - "effect": "As long as this move is in use, the power of rage raises the Attack stat each time the user is hit in battle." - }, - "teleport": { - "name": "Teleport", - "effect": "The user switches places with a party Pokémon in waiting, if any. If a wild Pokémon uses this move, it flees." - }, - "nightShade": { - "name": "Night Shade", - "effect": "The user makes the target see a frightening mirage. It inflicts damage equal to the user's level." - }, - "mimic": { - "name": "Mimic", - "effect": "The user copies the target's last move. The move can be used during battle until the Pokémon is switched out." - }, - "screech": { - "name": "Screech", - "effect": "An earsplitting screech harshly lowers the target's Defense stat." - }, - "doubleTeam": { - "name": "Double Team", - "effect": "By moving rapidly, the user makes illusory copies of itself to raise its evasiveness." - }, - "recover": { - "name": "Recover", - "effect": "Restoring its own cells, the user restores its own HP by half of its max HP." - }, - "harden": { - "name": "Harden", - "effect": "The user stiffens all the muscles in its body to raise its Defense stat." - }, - "minimize": { - "name": "Minimize", - "effect": "The user compresses its body to make itself look smaller, which sharply raises its evasiveness." - }, - "smokescreen": { - "name": "Smokescreen", - "effect": "The user releases an obscuring cloud of smoke or ink. This lowers the target's accuracy." - }, - "confuseRay": { - "name": "Confuse Ray", - "effect": "The target is exposed to a sinister ray that triggers confusion." - }, - "withdraw": { - "name": "Withdraw", - "effect": "The user withdraws its body into its hard shell, raising its Defense stat." - }, - "defenseCurl": { - "name": "Defense Curl", - "effect": "The user curls up to conceal weak spots and raise its Defense stat." - }, - "barrier": { - "name": "Barrier", - "effect": "The user throws up a sturdy wall that sharply raises its Defense stat." - }, - "lightScreen": { - "name": "Light Screen", - "effect": "A wondrous wall of light is put up to reduce damage from special attacks for five turns." - }, - "haze": { - "name": "Haze", - "effect": "The user creates a haze that eliminates every stat change among all the Pokémon engaged in battle." - }, - "reflect": { - "name": "Reflect", - "effect": "A wondrous wall of light is put up to reduce damage from physical attacks for five turns." - }, - "focusEnergy": { - "name": "Focus Energy", - "effect": "The user takes a deep breath and focuses so that critical hits land more easily." - }, - "bide": { - "name": "Bide", - "effect": "The user endures attacks for two turns, then strikes back to cause double the damage taken." - }, - "metronome": { - "name": "Metronome", - "effect": "The user waggles a finger and stimulates its brain into randomly using nearly any move." - }, - "mirrorMove": { - "name": "Mirror Move", - "effect": "The user counters the target by mimicking the target's last move." - }, - "selfDestruct": { - "name": "Self-Destruct", - "effect": "The user attacks everything around it by causing an explosion. The user faints upon using this move." - }, - "eggBomb": { - "name": "Egg Bomb", - "effect": "A large egg is hurled at the target with maximum force to inflict damage." - }, - "lick": { - "name": "Lick", - "effect": "The target is licked with a long tongue, causing damage. This may also leave the target with paralysis." - }, - "smog": { - "name": "Smog", - "effect": "The target is attacked with a discharge of filthy gases. This may also poison the target." - }, - "sludge": { - "name": "Sludge", - "effect": "Unsanitary sludge is hurled at the target. This may also poison the target." - }, - "boneClub": { - "name": "Bone Club", - "effect": "The user clubs the target with a bone. This may also make the target flinch." - }, - "fireBlast": { - "name": "Fire Blast", - "effect": "The target is attacked with an intense blast of all-consuming fire. This may also leave the target with a burn." - }, - "waterfall": { - "name": "Waterfall", - "effect": "The user charges at the target and may make it flinch." - }, - "clamp": { - "name": "Clamp", - "effect": "The target is clamped and squeezed by the user's very thick and sturdy shell for four to five turns." - }, - "swift": { - "name": "Swift", - "effect": "Star-shaped rays are shot at opposing Pokémon. This attack never misses." - }, - "skullBash": { - "name": "Skull Bash", - "effect": "The user tucks in its head to raise its Defense stat on the first turn, then rams the target on the next turn." - }, - "spikeCannon": { - "name": "Spike Cannon", - "effect": "Sharp spikes are shot at the target in rapid succession. They hit two to five times in a row." - }, - "constrict": { - "name": "Constrict", - "effect": "The target is attacked with long, creeping tentacles, vines, or the like. This may also lower the target's Speed stat." - }, - "amnesia": { - "name": "Amnesia", - "effect": "The user temporarily empties its mind to forget its concerns. This sharply raises the user's Sp. Def stat." - }, - "kinesis": { - "name": "Kinesis", - "effect": "The user distracts the target by bending a spoon. This lowers the target's accuracy." - }, - "softBoiled": { - "name": "Soft-Boiled", - "effect": "The user restores its own HP by up to half of its max HP." - }, - "highJumpKick": { - "name": "High Jump Kick", - "effect": "The target is attacked with a knee kick from a jump. If it misses, the user is hurt instead." - }, - "glare": { - "name": "Glare", - "effect": "The user intimidates the target with the pattern on its belly to cause paralysis." - }, - "dreamEater": { - "name": "Dream Eater", - "effect": "The user eats the dreams of a sleeping target. The user's HP is restored by half the damage taken by the target." - }, - "poisonGas": { - "name": "Poison Gas", - "effect": "A cloud of poison gas is sprayed in the face of opposing Pokémon, poisoning those it hits." - }, - "barrage": { - "name": "Barrage", - "effect": "Round objects are hurled at the target to strike two to five times in a row." - }, - "leechLife": { - "name": "Leech Life", - "effect": "The user drains the target's blood. The user's HP is restored by half the damage taken by the target." - }, - "lovelyKiss": { - "name": "Lovely Kiss", - "effect": "With a scary face, the user tries to force a kiss on the target. If it succeeds, the target falls asleep." - }, - "skyAttack": { - "name": "Sky Attack", - "effect": "A second-turn attack move where critical hits land more easily. This may also make the target flinch." - }, - "transform": { - "name": "Transform", - "effect": "The user transforms into a copy of the target right down to having the same move set." - }, - "bubble": { - "name": "Bubble", - "effect": "A spray of countless bubbles is jetted at the opposing Pokémon. This may also lower their Speed stat." - }, - "dizzyPunch": { - "name": "Dizzy Punch", - "effect": "The target is hit with rhythmically launched punches. This may also leave the target confused." - }, - "spore": { - "name": "Spore", - "effect": "The user scatters bursts of spores that induce sleep." - }, - "flash": { - "name": "Flash", - "effect": "The user flashes a bright light that cuts the target's accuracy." - }, - "psywave": { - "name": "Psywave", - "effect": "The target is attacked with an odd psychic wave. The attack varies in intensity." - }, - "splash": { - "name": "Splash", - "effect": "The user just flops and splashes around to no effect at all..." - }, - "acidArmor": { - "name": "Acid Armor", - "effect": "The user alters its cellular structure to liquefy itself, sharply raising its Defense stat." - }, - "crabhammer": { - "name": "Crabhammer", - "effect": "The target is hammered with a large pincer. Critical hits land more easily." - }, - "explosion": { - "name": "Explosion", - "effect": "The user attacks everything around it by causing a tremendous explosion. The user faints upon using this move." - }, - "furySwipes": { - "name": "Fury Swipes", - "effect": "The target is raked with sharp claws or scythes quickly two to five times in a row." - }, - "bonemerang": { - "name": "Bonemerang", - "effect": "The user throws the bone it holds. The bone loops around to hit the target twice—coming and going." - }, - "rest": { - "name": "Rest", - "effect": "The user goes to sleep for two turns. This fully restores the user's HP and heals any status conditions." - }, - "rockSlide": { - "name": "Rock Slide", - "effect": "Large boulders are hurled at opposing Pokémon to inflict damage. This may also make the opposing Pokémon flinch." - }, - "hyperFang": { - "name": "Hyper Fang", - "effect": "The user bites hard on the target with its sharp front fangs. This may also make the target flinch." - }, - "sharpen": { - "name": "Sharpen", - "effect": "The user makes its edges more jagged, which raises its Attack stat." - }, - "conversion": { - "name": "Conversion", - "effect": "The user changes its type to become the same type as the move at the top of the list of moves it knows." - }, - "triAttack": { - "name": "Tri Attack", - "effect": "The user strikes with a simultaneous three-beam attack. This may also burn, freeze, or paralyze the target." - }, - "superFang": { - "name": "Super Fang", - "effect": "The user chomps hard on the target with its sharp front fangs. This cuts the target's HP in half." - }, - "slash": { - "name": "Slash", - "effect": "The target is attacked with a slash of claws or blades. Critical hits land more easily." - }, - "substitute": { - "name": "Substitute", - "effect": "The user creates a substitute for itself using some of its HP. The substitute serves as the user's decoy." - }, - "struggle": { - "name": "Struggle", - "effect": "This attack is used in desperation only if the user has no PP. It also damages the user a little." - }, - "sketch": { - "name": "Sketch", - "effect": "It enables the user to permanently learn the move last used by the target. Once used, Sketch disappears." - }, - "tripleKick": { - "name": "Triple Kick", - "effect": "A consecutive three-kick attack that becomes more powerful with each successful hit." - }, - "thief": { - "name": "Thief", - "effect": "The user attacks and has a 30% chance to steal the target's held item simultaneously." - }, - "spiderWeb": { - "name": "Spider Web", - "effect": "The user ensnares the target with thin, gooey silk so it can't flee from battle." - }, - "mindReader": { - "name": "Mind Reader", - "effect": "The user senses the target's movements with its mind to ensure its next attack does not miss the target." - }, - "nightmare": { - "name": "Nightmare", - "effect": "A sleeping target sees a nightmare that inflicts some damage every turn." - }, - "flameWheel": { - "name": "Flame Wheel", - "effect": "The user cloaks itself in fire and charges at the target. This may also leave the target with a burn." - }, - "snore": { - "name": "Snore", - "effect": "This attack can be used only if the user is asleep. The harsh noise may also make the target flinch." - }, - "curse": { - "name": "Curse", - "effect": "A move that works differently for the Ghost type than for all other types." - }, - "flail": { - "name": "Flail", - "effect": "The user flails about aimlessly to attack. The less HP the user has, the greater the move's power." - }, - "conversion2": { - "name": "Conversion 2", - "effect": "The user changes its type to make itself resistant to the type of the attack the target used last." - }, - "aeroblast": { - "name": "Aeroblast", - "effect": "A vortex of air is shot at the target to inflict damage. Critical hits land more easily." - }, - "cottonSpore": { - "name": "Cotton Spore", - "effect": "The user releases cotton-like spores that cling to opposing Pokémon, which harshly lowers their Speed stats." - }, - "reversal": { - "name": "Reversal", - "effect": "An all-out attack that becomes more powerful the less HP the user has." - }, - "spite": { - "name": "Spite", - "effect": "The user unleashes its grudge on the move last used by the target by cutting 4 PP from it." - }, - "powderSnow": { - "name": "Powder Snow", - "effect": "The user attacks with a chilling gust of powdery snow. This may also freeze opposing Pokémon." - }, - "protect": { - "name": "Protect", - "effect": "This move enables the user to protect itself from all attacks. Its chance of failing rises if it is used in succession." - }, - "machPunch": { - "name": "Mach Punch", - "effect": "The user throws a punch at blinding speed. This move always goes first." - }, - "scaryFace": { - "name": "Scary Face", - "effect": "The user frightens the target with a scary face to harshly lower its Speed stat." - }, - "feintAttack": { - "name": "Feint Attack", - "effect": "The user approaches the target disarmingly, then throws a sucker punch. This attack never misses." - }, - "sweetKiss": { - "name": "Sweet Kiss", - "effect": "The user kisses the target with a sweet, angelic cuteness that causes confusion." - }, - "bellyDrum": { - "name": "Belly Drum", - "effect": "The user maximizes its Attack stat in exchange for HP equal to half its max HP." - }, - "sludgeBomb": { - "name": "Sludge Bomb", - "effect": "Unsanitary sludge is hurled at the target. This may also poison the target." - }, - "mudSlap": { - "name": "Mud-Slap", - "effect": "The user hurls mud in the target's face to inflict damage and lower its accuracy." - }, - "octazooka": { - "name": "Octazooka", - "effect": "The user attacks by spraying ink in the target's face or eyes. This may also lower the target's accuracy." - }, - "spikes": { - "name": "Spikes", - "effect": "The user lays a trap of spikes at the opposing team's feet. The trap hurts Pokémon that switch into battle." - }, - "zapCannon": { - "name": "Zap Cannon", - "effect": "The user fires an electric blast like a cannon to inflict damage and cause paralysis." - }, - "foresight": { - "name": "Foresight", - "effect": "Enables a Ghost-type target to be hit by Normal- and Fighting-type attacks. This also enables an evasive target to be hit." - }, - "destinyBond": { - "name": "Destiny Bond", - "effect": "After using this move, if the user faints, the Pokémon that landed the knockout hit also faints. Its chance of failing rises if it is used in succession." - }, - "perishSong": { - "name": "Perish Song", - "effect": "Any Pokémon that hears this song faints in three turns, unless it switches out of battle." - }, - "icyWind": { - "name": "Icy Wind", - "effect": "The user attacks with a gust of chilled air. This also lowers opposing Pokémon's Speed stats." - }, - "detect": { - "name": "Detect", - "effect": "This move enables the user to protect itself from all attacks. Its chance of failing rises if it is used in succession." - }, - "boneRush": { - "name": "Bone Rush", - "effect": "The user strikes the target with a hard bone two to five times in a row." - }, - "lockOn": { - "name": "Lock-On", - "effect": "The user takes sure aim at the target. This ensures the next attack does not miss the target." - }, - "outrage": { - "name": "Outrage", - "effect": "The user rampages and attacks for two to three turns. The user then becomes confused." - }, - "sandstorm": { - "name": "Sandstorm", - "effect": "A five-turn sandstorm is summoned to hurt all combatants except Rock, Ground, and Steel types. It raises the Sp. Def stat of Rock types." - }, - "gigaDrain": { - "name": "Giga Drain", - "effect": "A nutrient-draining attack. The user's HP is restored by half the damage taken by the target." - }, - "endure": { - "name": "Endure", - "effect": "The user endures any attack with at least 1 HP. Its chance of failing rises if it is used in succession." - }, - "charm": { - "name": "Charm", - "effect": "The user gazes at the target rather charmingly, making it less wary. This harshly lowers the target's Attack stat." - }, - "rollout": { - "name": "Rollout", - "effect": "The user continually rolls into the target over five turns. It becomes more powerful each time it hits." - }, - "falseSwipe": { - "name": "False Swipe", - "effect": "A restrained attack that prevents the target from fainting. The target is left with at least 1 HP." - }, - "swagger": { - "name": "Swagger", - "effect": "The user enrages and confuses the target. However, this also sharply raises the target's Attack stat." - }, - "milkDrink": { - "name": "Milk Drink", - "effect": "The user restores its own HP by up to half of its max HP." - }, - "spark": { - "name": "Spark", - "effect": "The user throws an electrically charged tackle at the target. This may also leave the target with paralysis." - }, - "furyCutter": { - "name": "Fury Cutter", - "effect": "The target is slashed with scythes or claws. This attack becomes more powerful if it hits in succession." - }, - "steelWing": { - "name": "Steel Wing", - "effect": "The target is hit with wings of steel. This may also raise the user's Defense stat." - }, - "meanLook": { - "name": "Mean Look", - "effect": "The user pins the target with a dark, arresting look. The target becomes unable to flee." - }, - "attract": { - "name": "Attract", - "effect": "If it is the opposite gender of the user, the target becomes infatuated and less likely to attack." - }, - "sleepTalk": { - "name": "Sleep Talk", - "effect": "While it is asleep, the user randomly uses one of the moves it knows." - }, - "healBell": { - "name": "Heal Bell", - "effect": "The user makes a soothing bell chime to heal the status conditions of all the party Pokémon." - }, - "return": { - "name": "Return", - "effect": "This full-power attack grows more powerful the more the user likes its Trainer." - }, - "present": { - "name": "Present", - "effect": "The user attacks by giving the target a gift with a hidden trap. It restores HP sometimes, however." - }, - "frustration": { - "name": "Frustration", - "effect": "This full-power attack grows more powerful the less the user likes its Trainer." - }, - "safeguard": { - "name": "Safeguard", - "effect": "The user creates a protective field that prevents status conditions for five turns." - }, - "painSplit": { - "name": "Pain Split", - "effect": "The user adds its HP to the target's HP, then equally shares the combined HP with the target." - }, - "sacredFire": { - "name": "Sacred Fire", - "effect": "The target is razed with a mystical fire of great intensity. This may also leave the target with a burn." - }, - "magnitude": { - "name": "Magnitude", - "effect": "The user attacks everything around it with a ground-shaking quake. Its power varies." - }, - "dynamicPunch": { - "name": "Dynamic Punch", - "effect": "The user punches the target with full, concentrated power. This confuses the target if it hits." - }, - "megahorn": { - "name": "Megahorn", - "effect": "Using its tough and impressive horn, the user rams into the target with no letup." - }, - "dragonBreath": { - "name": "Dragon Breath", - "effect": "The user exhales a mighty gust that inflicts damage. This may also leave the target with paralysis." - }, - "batonPass": { - "name": "Baton Pass", - "effect": "The user switches places with a party Pokémon in waiting and passes along any stat changes." - }, - "encore": { - "name": "Encore", - "effect": "The user compels the target to keep using the move it encored for three turns." - }, - "pursuit": { - "name": "Pursuit", - "effect": "The power of this attack move is doubled if it's used on a target that's switching out of battle." - }, - "rapidSpin": { - "name": "Rapid Spin", - "effect": "A spin attack that can also eliminate such moves as Bind, Wrap, and Leech Seed. This also raises the user's Speed stat." - }, - "sweetScent": { - "name": "Sweet Scent", - "effect": "A sweet scent that harshly lowers opposing Pokémon's evasiveness." - }, - "ironTail": { - "name": "Iron Tail", - "effect": "The target is slammed with a steel-hard tail. This may also lower the target's Defense stat." - }, - "metalClaw": { - "name": "Metal Claw", - "effect": "The target is raked with steel claws. This may also raise the user's Attack stat." - }, - "vitalThrow": { - "name": "Vital Throw", - "effect": "The user attacks last. In return, this throw move never misses." - }, - "morningSun": { - "name": "Morning Sun", - "effect": "The user restores its own HP. The amount of HP regained varies with the weather." - }, - "synthesis": { - "name": "Synthesis", - "effect": "The user restores its own HP. The amount of HP regained varies with the weather." - }, - "moonlight": { - "name": "Moonlight", - "effect": "The user restores its own HP. The amount of HP regained varies with the weather." - }, - "hiddenPower": { - "name": "Hidden Power", - "effect": "A unique attack that varies in type depending on the Pokémon using it." - }, - "crossChop": { - "name": "Cross Chop", - "effect": "The user delivers a double chop with its forearms crossed. Critical hits land more easily." - }, - "twister": { - "name": "Twister", - "effect": "The user whips up a vicious tornado to tear at opposing Pokémon. This may also make them flinch." - }, - "rainDance": { - "name": "Rain Dance", - "effect": "The user summons a heavy rain that falls for five turns, powering up Water-type moves. It lowers the power of Fire-type moves." - }, - "sunnyDay": { - "name": "Sunny Day", - "effect": "The user intensifies the sun for five turns, powering up Fire-type moves. It lowers the power of Water-type moves." - }, - "crunch": { - "name": "Crunch", - "effect": "The user crunches up the target with sharp fangs. This may also lower the target's Defense stat." - }, - "mirrorCoat": { - "name": "Mirror Coat", - "effect": "A retaliation move that counters any special attack, inflicting double the damage taken." - }, - "psychUp": { - "name": "Psych Up", - "effect": "The user hypnotizes itself into copying any stat change made by the target." - }, - "extremeSpeed": { - "name": "Extreme Speed", - "effect": "The user charges the target at blinding speed. This move always goes first." - }, - "ancientPower": { - "name": "Ancient Power", - "effect": "The user attacks with a prehistoric power. This may also raise all the user's stats at once." - }, - "shadowBall": { - "name": "Shadow Ball", - "effect": "The user hurls a shadowy blob at the target. This may also lower the target's Sp. Def stat." - }, - "futureSight": { - "name": "Future Sight", - "effect": "Two turns after this move is used, a hunk of psychic energy attacks the target." - }, - "rockSmash": { - "name": "Rock Smash", - "effect": "The user attacks with a punch. This may also lower the target's Defense stat." - }, - "whirlpool": { - "name": "Whirlpool", - "effect": "The user traps the target in a violent swirling whirlpool for four to five turns." - }, - "beatUp": { - "name": "Beat Up", - "effect": "The user gets all party Pokémon to attack the target. The more party Pokémon, the greater the number of attacks." - }, - "fakeOut": { - "name": "Fake Out", - "effect": "This attack hits first and makes the target flinch. It only works the first turn each time the user enters battle." - }, - "uproar": { - "name": "Uproar", - "effect": "The user attacks in an uproar for three turns. During that time, no Pokémon can fall asleep." - }, - "stockpile": { - "name": "Stockpile", - "effect": "The user charges up power and raises both its Defense and Sp. Def stats. The move can be used three times." - }, - "spitUp": { - "name": "Spit Up", - "effect": "The power stored using the move Stockpile is released at once in an attack. The more power is stored, the greater the move's power." - }, - "swallow": { - "name": "Swallow", - "effect": "The power stored using the move Stockpile is absorbed by the user to heal its HP. Storing more power heals more HP." - }, - "heatWave": { - "name": "Heat Wave", - "effect": "The user attacks by exhaling hot breath on opposing Pokémon. This may also leave those Pokémon with a burn." - }, - "hail": { - "name": "Hail", - "effect": "The user summons a hailstorm lasting five turns. It damages all Pokémon except Ice types." - }, - "torment": { - "name": "Torment", - "effect": "The user torments and enrages the target, making it incapable of using the same move twice in a row." - }, - "flatter": { - "name": "Flatter", - "effect": "Flattery is used to confuse the target. However, this also raises the target's Sp. Atk stat." - }, - "willOWisp": { - "name": "Will-O-Wisp", - "effect": "The user shoots a sinister flame at the target to inflict a burn." - }, - "memento": { - "name": "Memento", - "effect": "The user faints when using this move. In return, this harshly lowers the target's Attack and Sp. Atk stats." - }, - "facade": { - "name": "Facade", - "effect": "This attack move doubles its power if the user is poisoned, burned, or paralyzed." - }, - "focusPunch": { - "name": "Focus Punch", - "effect": "The user focuses its mind before launching a punch. This move fails if the user is hit before it is used." - }, - "smellingSalts": { - "name": "Smelling Salts", - "effect": "This attack's power is doubled when used on a target with paralysis. This also cures the target's paralysis, however." - }, - "followMe": { - "name": "Follow Me", - "effect": "The user draws attention to itself, making all targets take aim only at the user." - }, - "naturePower": { - "name": "Nature Power", - "effect": "This attack makes use of nature's power. Its effects vary depending on the user's environment." - }, - "charge": { - "name": "Charge", - "effect": "The user boosts the power of the Electric move it uses on the next turn. This also raises the user's Sp. Def stat." - }, - "taunt": { - "name": "Taunt", - "effect": "The target is taunted into a rage that allows it to use only attack moves for three turns." - }, - "helpingHand": { - "name": "Helping Hand", - "effect": "The user assists an ally by boosting the power of that ally's attack." - }, - "trick": { - "name": "Trick", - "effect": "The user catches the target off guard and swaps its held item with its own." - }, - "rolePlay": { - "name": "Role Play", - "effect": "The user mimics the target completely, copying the target's Ability." - }, - "wish": { - "name": "Wish", - "effect": "One turn after this move is used, the user's or its replacement's HP is restored by half the user's max HP." - }, - "assist": { - "name": "Assist", - "effect": "The user hurriedly and randomly uses a move among those known by ally Pokémon." - }, - "ingrain": { - "name": "Ingrain", - "effect": "The user lays roots that restore its HP on every turn. Because it's rooted, it can't switch out." - }, - "superpower": { - "name": "Superpower", - "effect": "The user attacks the target with great power. However, this also lowers the user's Attack and Defense stats." - }, - "magicCoat": { - "name": "Magic Coat", - "effect": "Moves like Leech Seed and moves that inflict status conditions are blocked by a barrier and reflected back to the user of those moves." - }, - "recycle": { - "name": "Recycle", - "effect": "The user recycles a held item that has been used in battle so it can be used again." - }, - "revenge": { - "name": "Revenge", - "effect": "This attack move's power is doubled if the user has been hurt by the opponent in the same turn." - }, - "brickBreak": { - "name": "Brick Break", - "effect": "The user attacks with a swift chop. It can also break barriers, such as Light Screen and Reflect." - }, - "yawn": { - "name": "Yawn", - "effect": "The user lets loose a huge yawn that lulls the target into falling asleep on the next turn." - }, - "knockOff": { - "name": "Knock Off", - "effect": "The user slaps down the target's held item, and that item can't be used in that battle. The move does more damage if the target has a held item." - }, - "endeavor": { - "name": "Endeavor", - "effect": "This attack move cuts down the target's HP to equal the user's HP." - }, - "eruption": { - "name": "Eruption", - "effect": "The user attacks opposing Pokémon with explosive fury. The lower the user's HP, the lower the move's power." - }, - "skillSwap": { - "name": "Skill Swap", - "effect": "The user employs its psychic power to exchange Abilities with the target." - }, - "imprison": { - "name": "Imprison", - "effect": "If opposing Pokémon know any move also known by the user, they are prevented from using it." - }, - "refresh": { - "name": "Refresh", - "effect": "The user rests to cure itself of poisoning, a burn, or paralysis." - }, - "grudge": { - "name": "Grudge", - "effect": "If the user faints, the user's grudge fully depletes the PP of the opponent's move that knocked it out." - }, - "snatch": { - "name": "Snatch", - "effect": "The user steals the effects of any attempts to use a healing or stat-changing move." - }, - "secretPower": { - "name": "Secret Power", - "effect": "The additional effects of this attack depend upon where it was used." - }, - "dive": { - "name": "Dive", - "effect": "Diving on the first turn, the user floats up and attacks on the next turn." - }, - "armThrust": { - "name": "Arm Thrust", - "effect": "The user lets loose a flurry of open-palmed arm thrusts that hit two to five times in a row." - }, - "camouflage": { - "name": "Camouflage", - "effect": "The user's type is changed depending on its environment, such as at water's edge, in grass, or in a cave." - }, - "tailGlow": { - "name": "Tail Glow", - "effect": "The user stares at flashing lights to focus its mind, drastically raising its Sp. Atk stat." - }, - "lusterPurge": { - "name": "Luster Purge", - "effect": "The user lets loose a damaging burst of light. This may also lower the target's Sp. Def stat." - }, - "mistBall": { - "name": "Mist Ball", - "effect": "A mist-like flurry of down envelops and damages the target. This may also lower the target's Sp. Atk stat." - }, - "featherDance": { - "name": "Feather Dance", - "effect": "The user covers the target's body with a mass of down that harshly lowers its Attack stat." - }, - "teeterDance": { - "name": "Teeter Dance", - "effect": "The user performs a wobbly dance that confuses the Pokémon around it." - }, - "blazeKick": { - "name": "Blaze Kick", - "effect": "The user launches a kick that lands a critical hit more easily. This may also leave the target with a burn." - }, - "mudSport": { - "name": "Mud Sport", - "effect": "The user kicks up mud on the battlefield. This weakens Electric-type moves for five turns." - }, - "iceBall": { - "name": "Ice Ball", - "effect": "The user attacks the target for five turns. The move's power increases each time it hits." - }, - "needleArm": { - "name": "Needle Arm", - "effect": "The user attacks by wildly swinging its thorny arms. This may also make the target flinch." - }, - "slackOff": { - "name": "Slack Off", - "effect": "The user slacks off, restoring its own HP by up to half of its max HP." - }, - "hyperVoice": { - "name": "Hyper Voice", - "effect": "The user lets loose a horribly echoing shout with the power to inflict damage." - }, - "poisonFang": { - "name": "Poison Fang", - "effect": "The user bites the target with toxic fangs. This may also leave the target badly poisoned." - }, - "crushClaw": { - "name": "Crush Claw", - "effect": "The user slashes the target with hard and sharp claws. This may also lower the target's Defense stat." - }, - "blastBurn": { - "name": "Blast Burn", - "effect": "The target is razed by a fiery explosion. The user can't move on the next turn." - }, - "hydroCannon": { - "name": "Hydro Cannon", - "effect": "The target is hit with a watery blast. The user can't move on the next turn." - }, - "meteorMash": { - "name": "Meteor Mash", - "effect": "The target is hit with a hard punch fired like a meteor. This may also raise the user's Attack stat." - }, - "astonish": { - "name": "Astonish", - "effect": "The user attacks the target while shouting in a startling fashion. This may also make the target flinch." - }, - "weatherBall": { - "name": "Weather Ball", - "effect": "This attack move varies in power and type depending on the weather." - }, - "aromatherapy": { - "name": "Aromatherapy", - "effect": "The user releases a soothing scent that heals all status conditions affecting the user's party." - }, - "fakeTears": { - "name": "Fake Tears", - "effect": "The user feigns crying to fluster the target, harshly lowering its Sp. Def stat." - }, - "airCutter": { - "name": "Air Cutter", - "effect": "The user launches razor-like wind to slash opposing Pokémon. Critical hits land more easily." - }, - "overheat": { - "name": "Overheat", - "effect": "The user attacks the target at full power. The attack's recoil harshly lowers the user's Sp. Atk stat." - }, - "odorSleuth": { - "name": "Odor Sleuth", - "effect": "Enables a Ghost-type target to be hit by Normal- and Fighting-type attacks. This also enables an evasive target to be hit." - }, - "rockTomb": { - "name": "Rock Tomb", - "effect": "Boulders are hurled at the target. This also lowers the target's Speed stat by preventing its movement." - }, - "silverWind": { - "name": "Silver Wind", - "effect": "The target is attacked with powdery scales blown by the wind. This may also raise all the user's stats." - }, - "metalSound": { - "name": "Metal Sound", - "effect": "A horrible sound like scraping metal harshly lowers the target's Sp. Def stat." - }, - "grassWhistle": { - "name": "Grass Whistle", - "effect": "The user plays a pleasant melody that lulls the target into a deep sleep." - }, - "tickle": { - "name": "Tickle", - "effect": "The user tickles the target into laughing, reducing its Attack and Defense stats." - }, - "cosmicPower": { - "name": "Cosmic Power", - "effect": "The user absorbs a mystical power from space to raise its Defense and Sp. Def stats." - }, - "waterSpout": { - "name": "Water Spout", - "effect": "The user spouts water to damage opposing Pokémon. The lower the user's HP, the lower the move's power." - }, - "signalBeam": { - "name": "Signal Beam", - "effect": "The user attacks with a sinister beam of light. This may also confuse the target." - }, - "shadowPunch": { - "name": "Shadow Punch", - "effect": "The user throws a punch from the shadows. This attack never misses." - }, - "extrasensory": { - "name": "Extrasensory", - "effect": "The user attacks with an odd, unseeable power. This may also make the target flinch." - }, - "skyUppercut": { - "name": "Sky Uppercut", - "effect": "The user attacks the target with an uppercut thrown skyward with force." - }, - "sandTomb": { - "name": "Sand Tomb", - "effect": "The user traps the target inside a harshly raging sandstorm for four to five turns." - }, - "sheerCold": { - "name": "Sheer Cold", - "effect": "The target faints instantly. It's less likely to hit the target if it's used by Pokémon other than Ice types." - }, - "muddyWater": { - "name": "Muddy Water", - "effect": "The user attacks by shooting muddy water at opposing Pokémon. This may also lower their accuracy." - }, - "bulletSeed": { - "name": "Bullet Seed", - "effect": "The user forcefully shoots seeds at the target two to five times in a row." - }, - "aerialAce": { - "name": "Aerial Ace", - "effect": "The user confounds the target with speed, then slashes. This attack never misses." - }, - "icicleSpear": { - "name": "Icicle Spear", - "effect": "The user launches sharp icicles at the target two to five times in a row." - }, - "ironDefense": { - "name": "Iron Defense", - "effect": "The user hardens its body's surface like iron, sharply raising its Defense stat." - }, - "block": { - "name": "Block", - "effect": "The user blocks the target's way with arms spread wide to prevent escape." - }, - "howl": { - "name": "Howl", - "effect": "The user howls loudly to raise the spirit of itself and allies. This raises their Attack stats." - }, - "dragonClaw": { - "name": "Dragon Claw", - "effect": "The user slashes the target with huge sharp claws." - }, - "frenzyPlant": { - "name": "Frenzy Plant", - "effect": "The user slams the target with the roots of an enormous tree. The user can't move on the next turn." - }, - "bulkUp": { - "name": "Bulk Up", - "effect": "The user tenses its muscles to bulk up its body, raising both its Attack and Defense stats." - }, - "bounce": { - "name": "Bounce", - "effect": "The user bounces up high, then drops on the target on the second turn. This may also leave the target with paralysis." - }, - "mudShot": { - "name": "Mud Shot", - "effect": "The user attacks by hurling a blob of mud at the target. This also lowers the target's Speed stat." - }, - "poisonTail": { - "name": "Poison Tail", - "effect": "The user hits the target with its tail. This may also poison the target. Critical hits land more easily." - }, - "covet": { - "name": "Covet", - "effect": "The user endearingly approaches the target, then has a 30% chance to steal the target's held item." - }, - "voltTackle": { - "name": "Volt Tackle", - "effect": "The user electrifies itself and charges the target. This also damages the user quite a lot. This attack may leave the target with paralysis." - }, - "magicalLeaf": { - "name": "Magical Leaf", - "effect": "The user scatters curious leaves that chase the target. This attack never misses." - }, - "waterSport": { - "name": "Water Sport", - "effect": "The user soaks the battlefield with water. This weakens Fire-type moves for five turns." - }, - "calmMind": { - "name": "Calm Mind", - "effect": "The user quietly focuses its mind and calms its spirit to raise its Sp. Atk and Sp. Def stats." - }, - "leafBlade": { - "name": "Leaf Blade", - "effect": "The user handles a sharp leaf like a sword and attacks by cutting its target. Critical hits land more easily." - }, - "dragonDance": { - "name": "Dragon Dance", - "effect": "The user vigorously performs a mystic, powerful dance that raises its Attack and Speed stats." - }, - "rockBlast": { - "name": "Rock Blast", - "effect": "The user hurls hard rocks at the target. Two to five rocks are launched in a row." - }, - "shockWave": { - "name": "Shock Wave", - "effect": "The user strikes the target with a quick jolt of electricity. This attack never misses." - }, - "waterPulse": { - "name": "Water Pulse", - "effect": "The user attacks the target with a pulsing blast of water. This may also confuse the target." - }, - "doomDesire": { - "name": "Doom Desire", - "effect": "Two turns after this move is used, a concentrated bundle of light blasts the target." - }, - "psychoBoost": { - "name": "Psycho Boost", - "effect": "The user attacks the target at full power. The attack's recoil harshly lowers the user's Sp. Atk stat." - }, - "roost": { - "name": "Roost", - "effect": "The user lands and rests its body. This move restores the user's HP by up to half of its max HP." - }, - "gravity": { - "name": "Gravity", - "effect": "This move enables Flying-type Pokémon or Pokémon with the Levitate Ability to be hit by Ground-type moves. Moves that involve flying can't be used." - }, - "miracleEye": { - "name": "Miracle Eye", - "effect": "Enables a Dark-type target to be hit by Psychic-type attacks. This also enables an evasive target to be hit." - }, - "wakeUpSlap": { - "name": "Wake-Up Slap", - "effect": "This attack inflicts big damage on a sleeping target. This also wakes the target up, however." - }, - "hammerArm": { - "name": "Hammer Arm", - "effect": "The user swings and hits with its strong, heavy fist. It lowers the user's Speed, however." - }, - "gyroBall": { - "name": "Gyro Ball", - "effect": "The user tackles the target with a high-speed spin. The slower the user compared to the target, the greater the move's power." - }, - "healingWish": { - "name": "Healing Wish", - "effect": "The user faints. In return, the Pokémon taking its place will have its HP restored and status conditions cured." - }, - "brine": { - "name": "Brine", - "effect": "If the target's HP is half or less, this attack will hit with double the power." - }, - "naturalGift": { - "name": "Natural Gift", - "effect": "The user draws power to attack by using its held Berry. The Berry determines the move's type and power." - }, - "feint": { - "name": "Feint", - "effect": "This attack hits a target using a move such as Protect or Detect. This also lifts the effects of those moves." - }, - "pluck": { - "name": "Pluck", - "effect": "The user pecks the target. If the target is holding a Berry, the user eats it and gains its effect." - }, - "tailwind": { - "name": "Tailwind", - "effect": "The user whips up a turbulent whirlwind that ups the Speed stats of the user and its allies for four turns." - }, - "acupressure": { - "name": "Acupressure", - "effect": "The user applies pressure to stress points, sharply boosting one of its or its allies' stats." - }, - "metalBurst": { - "name": "Metal Burst", - "effect": "The user retaliates with much greater force against the opponent that last inflicted damage on it." - }, - "uTurn": { - "name": "U-turn", - "effect": "After making its attack, the user rushes back to switch places with a party Pokémon in waiting." - }, - "closeCombat": { - "name": "Close Combat", - "effect": "The user fights the target up close without guarding itself. This also lowers the user's Defense and Sp. Def stats." - }, - "payback": { - "name": "Payback", - "effect": "The user stores power, then attacks. If the user moves after the target, this attack's power will be doubled." - }, - "assurance": { - "name": "Assurance", - "effect": "If the target has already taken some damage in the same turn, this attack's power is doubled." - }, - "embargo": { - "name": "Embargo", - "effect": "This move prevents the target from using its held item for five turns. Its Trainer is also prevented from using items on it." - }, - "fling": { - "name": "Fling", - "effect": "The user flings its held item at the target to attack. This move's power and effects depend on the item." - }, - "psychoShift": { - "name": "Psycho Shift", - "effect": "Using its psychic power of suggestion, the user transfers its status conditions to the target." - }, - "trumpCard": { - "name": "Trump Card", - "effect": "The fewer PP this move has, the greater its power." - }, - "healBlock": { - "name": "Heal Block", - "effect": "For five turns, the user prevents the opposing team from using any moves, Abilities, or held items that recover HP." - }, - "wringOut": { - "name": "Wring Out", - "effect": "The user powerfully wrings the target. The more HP the target has, the greater the move's power." - }, - "powerTrick": { - "name": "Power Trick", - "effect": "The user employs its psychic power to switch its Attack stat with its Defense stat." - }, - "gastroAcid": { - "name": "Gastro Acid", - "effect": "The user hurls up its stomach acids on the target. The fluid eliminates the effect of the target's Ability." - }, - "luckyChant": { - "name": "Lucky Chant", - "effect": "The user chants an incantation toward the sky, preventing opposing Pokémon from landing critical hits for five turns." - }, - "meFirst": { - "name": "Me First", - "effect": "The user cuts ahead of the target to copy and use the target's intended move with greater power. This move fails if it isn't used first." - }, - "copycat": { - "name": "Copycat", - "effect": "The user mimics the move used immediately before it. The move fails if no other move has been used yet." - }, - "powerSwap": { - "name": "Power Swap", - "effect": "The user employs its psychic power to switch changes to its Attack and Sp. Atk stats with the target." - }, - "guardSwap": { - "name": "Guard Swap", - "effect": "The user employs its psychic power to switch changes to its Defense and Sp. Def stats with the target." - }, - "punishment": { - "name": "Punishment", - "effect": "The more the target has powered up with stat changes, the greater the move's power." - }, - "lastResort": { - "name": "Last Resort", - "effect": "This move can be used only after the user has used all the other moves it knows in the battle." - }, - "worrySeed": { - "name": "Worry Seed", - "effect": "A seed that causes worry is planted on the target. It prevents sleep by making the target's Ability Insomnia." - }, - "suckerPunch": { - "name": "Sucker Punch", - "effect": "This move enables the user to attack first. This move fails if the target is not readying an attack." - }, - "toxicSpikes": { - "name": "Toxic Spikes", - "effect": "The user lays a trap of poison spikes at the feet of the opposing team. The spikes will poison opposing Pokémon that switch into battle." - }, - "heartSwap": { - "name": "Heart Swap", - "effect": "The user employs its psychic power to switch stat changes with the target." - }, - "aquaRing": { - "name": "Aqua Ring", - "effect": "The user envelops itself in a veil made of water. It regains some HP every turn." - }, - "magnetRise": { - "name": "Magnet Rise", - "effect": "The user levitates using electrically generated magnetism for five turns." - }, - "flareBlitz": { - "name": "Flare Blitz", - "effect": "The user cloaks itself in fire and charges the target. This also damages the user quite a lot. This attack may leave the target with a burn." - }, - "forcePalm": { - "name": "Force Palm", - "effect": "The target is attacked with a shock wave. This may also leave the target with paralysis." - }, - "auraSphere": { - "name": "Aura Sphere", - "effect": "The user lets loose a blast of aura power from deep within its body at the target. This attack never misses." - }, - "rockPolish": { - "name": "Rock Polish", - "effect": "The user polishes its body to reduce drag. This sharply raises the Speed stat." - }, - "poisonJab": { - "name": "Poison Jab", - "effect": "The target is stabbed with a tentacle, arm, or the like steeped in poison. This may also poison the target." - }, - "darkPulse": { - "name": "Dark Pulse", - "effect": "The user releases a horrible aura imbued with dark thoughts. This may also make the target flinch." - }, - "nightSlash": { - "name": "Night Slash", - "effect": "The user slashes the target the instant an opportunity arises. Critical hits land more easily." - }, - "aquaTail": { - "name": "Aqua Tail", - "effect": "The user attacks by swinging its tail as if it were a vicious wave in a raging storm." - }, - "seedBomb": { - "name": "Seed Bomb", - "effect": "The user slams a barrage of hard-shelled seeds down on the target from above." - }, - "airSlash": { - "name": "Air Slash", - "effect": "The user attacks with a blade of air that slices even the sky. This may also make the target flinch." - }, - "xScissor": { - "name": "X-Scissor", - "effect": "The user slashes at the target by crossing its scythes or claws as if they were a pair of scissors." - }, - "bugBuzz": { - "name": "Bug Buzz", - "effect": "The user generates a damaging sound wave by vibration. This may also lower the target's Sp. Def stat." - }, - "dragonPulse": { - "name": "Dragon Pulse", - "effect": "The target is attacked with a shock wave generated by the user's gaping mouth." - }, - "dragonRush": { - "name": "Dragon Rush", - "effect": "The user tackles the target while exhibiting overwhelming menace. This may also make the target flinch." - }, - "powerGem": { - "name": "Power Gem", - "effect": "The user attacks with a ray of light that sparkles as if it were made of gemstones." - }, - "drainPunch": { - "name": "Drain Punch", - "effect": "An energy-draining punch. The user's HP is restored by half the damage taken by the target." - }, - "vacuumWave": { - "name": "Vacuum Wave", - "effect": "The user whirls its fists to send a wave of pure vacuum at the target. This move always goes first." - }, - "focusBlast": { - "name": "Focus Blast", - "effect": "The user heightens its mental focus and unleashes its power. This may also lower the target's Sp. Def stat." - }, - "energyBall": { - "name": "Energy Ball", - "effect": "The user draws power from nature and fires it at the target. This may also lower the target's Sp. Def stat." - }, - "braveBird": { - "name": "Brave Bird", - "effect": "The user tucks in its wings and charges from a low altitude. This also damages the user quite a lot." - }, - "earthPower": { - "name": "Earth Power", - "effect": "The user makes the ground under the target erupt with power. This may also lower the target's Sp. Def stat." - }, - "switcheroo": { - "name": "Switcheroo", - "effect": "The user trades held items with the target faster than the eye can follow." - }, - "gigaImpact": { - "name": "Giga Impact", - "effect": "The user charges at the target using every bit of its power. The user can't move on the next turn." - }, - "nastyPlot": { - "name": "Nasty Plot", - "effect": "The user stimulates its brain by thinking bad thoughts. This sharply raises the user's Sp. Atk stat." - }, - "bulletPunch": { - "name": "Bullet Punch", - "effect": "The user strikes the target with tough punches as fast as bullets. This move always goes first." - }, - "avalanche": { - "name": "Avalanche", - "effect": "The power of this attack move is doubled if the user has been hurt by the target in the same turn." - }, - "iceShard": { - "name": "Ice Shard", - "effect": "The user flash-freezes chunks of ice and hurls them at the target. This move always goes first." - }, - "shadowClaw": { - "name": "Shadow Claw", - "effect": "The user slashes with a sharp claw made from shadows. Critical hits land more easily." - }, - "thunderFang": { - "name": "Thunder Fang", - "effect": "The user bites with electrified fangs. This may also make the target flinch or leave it with paralysis." - }, - "iceFang": { - "name": "Ice Fang", - "effect": "The user bites with cold-infused fangs. This may also make the target flinch or leave it frozen." - }, - "fireFang": { - "name": "Fire Fang", - "effect": "The user bites with flame-cloaked fangs. This may also make the target flinch or leave it with a burn." - }, - "shadowSneak": { - "name": "Shadow Sneak", - "effect": "The user extends its shadow and attacks the target from behind. This move always goes first." - }, - "mudBomb": { - "name": "Mud Bomb", - "effect": "The user launches a hard-packed mud ball to attack. This may also lower the target's accuracy." - }, - "psychoCut": { - "name": "Psycho Cut", - "effect": "The user tears at the target with blades formed by psychic power. Critical hits land more easily." - }, - "zenHeadbutt": { - "name": "Zen Headbutt", - "effect": "The user focuses its willpower to its head and attacks the target. This may also make the target flinch." - }, - "mirrorShot": { - "name": "Mirror Shot", - "effect": "The user lets loose a flash of energy at the target from its polished body. This may also lower the target's accuracy." - }, - "flashCannon": { - "name": "Flash Cannon", - "effect": "The user gathers all its light energy and releases it all at once. This may also lower the target's Sp. Def stat." - }, - "rockClimb": { - "name": "Rock Climb", - "effect": "The user attacks the target by smashing into it with incredible force. This may also confuse the target." - }, - "defog": { - "name": "Defog", - "effect": "A strong wind blows away the target's barriers such as Reflect or Light Screen. This also lowers the target's evasiveness." - }, - "trickRoom": { - "name": "Trick Room", - "effect": "The user creates a bizarre area in which slower Pokémon get to move first for five turns." - }, - "dracoMeteor": { - "name": "Draco Meteor", - "effect": "Comets are summoned down from the sky onto the target. The attack's recoil harshly lowers the user's Sp. Atk stat." - }, - "discharge": { - "name": "Discharge", - "effect": "The user strikes everything around it by letting loose a flare of electricity. This may also cause paralysis." - }, - "lavaPlume": { - "name": "Lava Plume", - "effect": "The user torches everything around it in an inferno of scarlet flames. This may also leave those it hits with a burn." - }, - "leafStorm": { - "name": "Leaf Storm", - "effect": "The user whips up a storm of leaves around the target. The attack's recoil harshly lowers the user's Sp. Atk stat." - }, - "powerWhip": { - "name": "Power Whip", - "effect": "The user violently whirls its vines, tentacles, or the like to harshly lash the target." - }, - "rockWrecker": { - "name": "Rock Wrecker", - "effect": "The user launches a huge boulder at the target to attack. The user can't move on the next turn." - }, - "crossPoison": { - "name": "Cross Poison", - "effect": "A slashing attack with a poisonous blade that may also poison the target. Critical hits land more easily." - }, - "gunkShot": { - "name": "Gunk Shot", - "effect": "The user shoots filthy garbage at the target to attack. This may also poison the target." - }, - "ironHead": { - "name": "Iron Head", - "effect": "The user slams the target with its steel-hard head. This may also make the target flinch." - }, - "magnetBomb": { - "name": "Magnet Bomb", - "effect": "The user launches steel bombs that stick to the target. This attack never misses." - }, - "stoneEdge": { - "name": "Stone Edge", - "effect": "The user stabs the target from below with sharpened stones. Critical hits land more easily." - }, - "captivate": { - "name": "Captivate", - "effect": "If any opposing Pokémon is the opposite gender of the user, it is charmed, which harshly lowers its Sp. Atk stat." - }, - "stealthRock": { - "name": "Stealth Rock", - "effect": "The user lays a trap of levitating stones around the opposing team. The trap hurts opposing Pokémon that switch into battle." - }, - "grassKnot": { - "name": "Grass Knot", - "effect": "The user snares the target with grass and trips it. The heavier the target, the greater the move's power." - }, - "chatter": { - "name": "Chatter", - "effect": "The user attacks the target with sound waves of deafening chatter. This confuses the target." - }, - "judgment": { - "name": "Judgment", - "effect": "The user releases countless shots of light at the target. This move's type varies depending on the kind of Plate the user is holding." - }, - "bugBite": { - "name": "Bug Bite", - "effect": "The user bites the target. If the target is holding a Berry, the user eats it and gains its effect." - }, - "chargeBeam": { - "name": "Charge Beam", - "effect": "The user attacks the target with an electric charge. The user may use any remaining electricity to raise its Sp. Atk stat." - }, - "woodHammer": { - "name": "Wood Hammer", - "effect": "The user slams its rugged body into the target to attack. This also damages the user quite a lot." - }, - "aquaJet": { - "name": "Aqua Jet", - "effect": "The user lunges at the target at a speed that makes it almost invisible. This move always goes first." - }, - "attackOrder": { - "name": "Attack Order", - "effect": "The user calls out its underlings to pummel the target. Critical hits land more easily." - }, - "defendOrder": { - "name": "Defend Order", - "effect": "The user calls out its underlings to shield its body, raising its Defense and Sp. Def stats." - }, - "healOrder": { - "name": "Heal Order", - "effect": "The user calls out its underlings to heal it. The user regains up to half of its max HP." - }, - "headSmash": { - "name": "Head Smash", - "effect": "The user attacks the target with a hazardous, full-power headbutt. This also damages the user terribly." - }, - "doubleHit": { - "name": "Double Hit", - "effect": "The user slams the target with a long tail, vines, or a tentacle. The target is hit twice in a row." - }, - "roarOfTime": { - "name": "Roar of Time", - "effect": "The user blasts the target with power that distorts even time. The user can't move on the next turn." - }, - "spacialRend": { - "name": "Spacial Rend", - "effect": "The user tears the target along with the space around it. Critical hits land more easily." - }, - "lunarDance": { - "name": "Lunar Dance", - "effect": "The user faints. In return, the Pokémon taking its place will have its status and HP fully restored." - }, - "crushGrip": { - "name": "Crush Grip", - "effect": "The target is crushed with great force. The more HP the target has left, the greater this move's power." - }, - "magmaStorm": { - "name": "Magma Storm", - "effect": "The target becomes trapped within a maelstrom of fire that rages for four to five turns." - }, - "darkVoid": { - "name": "Dark Void", - "effect": "Opposing Pokémon are dragged into a world of total darkness that makes them sleep." - }, - "seedFlare": { - "name": "Seed Flare", - "effect": "The user emits a shock wave from its body to attack its target. This may also harshly lower the target's Sp. Def stat." - }, - "ominousWind": { - "name": "Ominous Wind", - "effect": "The user blasts the target with a gust of repulsive wind. This may also raise all the user's stats at once." - }, - "shadowForce": { - "name": "Shadow Force", - "effect": "The user disappears, then strikes the target on the next turn. This move hits even if the target protects itself." - }, - "honeClaws": { - "name": "Hone Claws", - "effect": "The user sharpens its claws to boost its Attack stat and accuracy." - }, - "wideGuard": { - "name": "Wide Guard", - "effect": "The user and its allies are protected from wide-ranging attacks for one turn." - }, - "guardSplit": { - "name": "Guard Split", - "effect": "The user employs its psychic power to average its Defense and Sp. Def stats with those of the target." - }, - "powerSplit": { - "name": "Power Split", - "effect": "The user employs its psychic power to average its Attack and Sp. Atk stats with those of the target." - }, - "wonderRoom": { - "name": "Wonder Room", - "effect": "The user creates a bizarre area in which Pokémon's Defense and Sp. Def stats are swapped for five turns." - }, - "psyshock": { - "name": "Psyshock", - "effect": "The user materializes an odd psychic wave to attack the target. This attack does physical damage." - }, - "venoshock": { - "name": "Venoshock", - "effect": "The user drenches the target in a special poisonous liquid. This move's power is doubled if the target is poisoned." - }, - "autotomize": { - "name": "Autotomize", - "effect": "The user sheds part of its body to make itself lighter and sharply raise its Speed stat." - }, - "ragePowder": { - "name": "Rage Powder", - "effect": "The user scatters a cloud of irritating powder to draw attention to itself. Opposing Pokémon aim only at the user." - }, - "telekinesis": { - "name": "Telekinesis", - "effect": "The user makes the target float with its psychic power. The target is easier to hit for three turns." - }, - "magicRoom": { - "name": "Magic Room", - "effect": "The user creates a bizarre area in which Pokémon's held items lose their effects for five turns." - }, - "smackDown": { - "name": "Smack Down", - "effect": "The user throws a stone or similar projectile to attack the target. A flying Pokémon will fall to the ground when it's hit." - }, - "stormThrow": { - "name": "Storm Throw", - "effect": "The user strikes the target with a fierce blow. This attack always results in a critical hit." - }, - "flameBurst": { - "name": "Flame Burst", - "effect": "The user attacks the target with a bursting flame. The bursting flame damages Pokémon next to the target as well." - }, - "sludgeWave": { - "name": "Sludge Wave", - "effect": "The user strikes everything around it by swamping the area with a giant sludge wave. This may also poison those hit." - }, - "quiverDance": { - "name": "Quiver Dance", - "effect": "The user lightly performs a beautiful, mystic dance. This boosts the user's Sp. Atk, Sp. Def, and Speed stats." - }, - "heavySlam": { - "name": "Heavy Slam", - "effect": "The user slams into the target with its heavy body. The more the user outweighs the target, the greater the move's power." - }, - "synchronoise": { - "name": "Synchronoise", - "effect": "Using an odd shock wave, the user inflicts damage on any Pokémon of the same type in the area around it." - }, - "electroBall": { - "name": "Electro Ball", - "effect": "The user hurls an electric orb at the target. The faster the user is than the target, the greater the move's power." - }, - "soak": { - "name": "Soak", - "effect": "The user shoots a torrent of water at the target and changes the target's type to Water." - }, - "flameCharge": { - "name": "Flame Charge", - "effect": "Cloaking itself in flame, the user attacks the target. Then, building up more power, the user raises its Speed stat." - }, - "coil": { - "name": "Coil", - "effect": "The user coils up and concentrates. This raises its Attack and Defense stats as well as its accuracy." - }, - "lowSweep": { - "name": "Low Sweep", - "effect": "The user makes a swift attack on the target's legs, which lowers the target's Speed stat." - }, - "acidSpray": { - "name": "Acid Spray", - "effect": "The user spits fluid that works to melt the target. This harshly lowers the target's Sp. Def stat." - }, - "foulPlay": { - "name": "Foul Play", - "effect": "The user turns the target's power against it. The higher the target's Attack stat, the greater the damage it deals." - }, - "simpleBeam": { - "name": "Simple Beam", - "effect": "The user's mysterious psychic wave changes the target's Ability to Simple." - }, - "entrainment": { - "name": "Entrainment", - "effect": "The user dances with an odd rhythm that compels the target to mimic it, making the target's Ability the same as the user's." - }, - "afterYou": { - "name": "After You", - "effect": "The user helps the target and makes it use its move right after the user." - }, - "round": { - "name": "Round", - "effect": "The user attacks the target with a song. Others can join in the Round to increase the power of the attack." - }, - "echoedVoice": { - "name": "Echoed Voice", - "effect": "The user attacks the target with an echoing voice. If this move is used every turn, its power is increased." - }, - "chipAway": { - "name": "Chip Away", - "effect": "Looking for an opening, the user strikes consistently. The target's stat changes don't affect this attack's damage." - }, - "clearSmog": { - "name": "Clear Smog", - "effect": "The user attacks the target by throwing a clump of special mud. All stat changes are returned to normal." - }, - "storedPower": { - "name": "Stored Power", - "effect": "The user attacks the target with stored power. The more the user's stats are raised, the greater the move's power." - }, - "quickGuard": { - "name": "Quick Guard", - "effect": "The user protects itself and its allies from priority moves." - }, - "allySwitch": { - "name": "Ally Switch", - "effect": "The user teleports using a strange power and switches places with one of its allies." - }, - "scald": { - "name": "Scald", - "effect": "The user shoots boiling hot water at its target. This may also leave the target with a burn." - }, - "shellSmash": { - "name": "Shell Smash", - "effect": "The user breaks its shell, which lowers Defense and Sp. Def stats but sharply raises its Attack, Sp. Atk, and Speed stats." - }, - "healPulse": { - "name": "Heal Pulse", - "effect": "The user emits a healing pulse that restores the target's HP by up to half of its max HP." - }, - "hex": { - "name": "Hex", - "effect": "This relentless attack does massive damage to a target affected by status conditions." - }, - "skyDrop": { - "name": "Sky Drop", - "effect": "The user takes the target into the sky, then drops it during the next turn. The target cannot attack while in the sky." - }, - "shiftGear": { - "name": "Shift Gear", - "effect": "The user rotates its gears, raising its Attack stat and sharply raising its Speed stat." - }, - "circleThrow": { - "name": "Circle Throw", - "effect": "The target is thrown, and a different Pokémon is dragged out. In the wild, this ends a battle against a single Pokémon." - }, - "incinerate": { - "name": "Incinerate", - "effect": "The user attacks opposing Pokémon with fire. If a Pokémon is holding a certain item, such as a Berry, the item becomes burned up and unusable." - }, - "quash": { - "name": "Quash", - "effect": "The user suppresses the target and makes its move go last." - }, - "acrobatics": { - "name": "Acrobatics", - "effect": "The user nimbly strikes the target. The fewer held items, the higher the damage it inflicts." - }, - "reflectType": { - "name": "Reflect Type", - "effect": "The user reflects the target's type, making the user the same type as the target." - }, - "retaliate": { - "name": "Retaliate", - "effect": "The user gets revenge for a fainted ally. If an ally fainted in the previous turn, this move's power is increased." - }, - "finalGambit": { - "name": "Final Gambit", - "effect": "The user risks everything to attack its target. The user faints but does damage equal to its HP." - }, - "bestow": { - "name": "Bestow", - "effect": "The user passes its held item to the target when the target isn't holding an item." - }, - "inferno": { - "name": "Inferno", - "effect": "The user attacks by engulfing the target in an intense fire. This leaves the target with a burn." - }, - "waterPledge": { - "name": "Water Pledge", - "effect": "A column of water hits the target. When used with its fire equivalent, its power increases and a rainbow appears." - }, - "firePledge": { - "name": "Fire Pledge", - "effect": "A column of fire hits the target. When used with its grass equivalent, its power increases and a vast sea of fire appears." - }, - "grassPledge": { - "name": "Grass Pledge", - "effect": "A column of grass hits the target. When used with its water equivalent, its power increases and a vast swamp appears." - }, - "voltSwitch": { - "name": "Volt Switch", - "effect": "After making its attack, the user rushes back to switch places with a party Pokémon in waiting." - }, - "struggleBug": { - "name": "Struggle Bug", - "effect": "While resisting, the user attacks opposing Pokémon. This lowers the Sp. Atk stats of those hit." - }, - "bulldoze": { - "name": "Bulldoze", - "effect": "The user strikes everything around it by stomping down on the ground. This lowers the Speed stats of those hit." - }, - "frostBreath": { - "name": "Frost Breath", - "effect": "The user blows its cold breath on the target. This attack always results in a critical hit." - }, - "dragonTail": { - "name": "Dragon Tail", - "effect": "The target is knocked away, and a different Pokémon is dragged out. In the wild, this ends a battle against a single Pokémon." - }, - "workUp": { - "name": "Work Up", - "effect": "The user is roused, and its Attack and Sp. Atk stats increase." - }, - "electroweb": { - "name": "Electroweb", - "effect": "The user attacks and captures opposing Pokémon using an electric net. This lowers their Speed stats." - }, - "wildCharge": { - "name": "Wild Charge", - "effect": "The user shrouds itself in electricity and smashes into its target. This also damages the user a little." - }, - "drillRun": { - "name": "Drill Run", - "effect": "The user crashes into its target while rotating its body like a drill. Critical hits land more easily." - }, - "dualChop": { - "name": "Dual Chop", - "effect": "The user attacks its target by hitting it with brutal strikes. The target is hit twice in a row." - }, - "heartStamp": { - "name": "Heart Stamp", - "effect": "The user unleashes a vicious blow after its cute act makes the target less wary. This may also make the target flinch." - }, - "hornLeech": { - "name": "Horn Leech", - "effect": "The user drains the target's energy with its horns. The user's HP is restored by half the damage taken by the target." - }, - "sacredSword": { - "name": "Sacred Sword", - "effect": "The user attacks by slicing with a long horn. The target's stat changes don't affect this attack's damage." - }, - "razorShell": { - "name": "Razor Shell", - "effect": "The user cuts its target with sharp shells. This may also lower the target's Defense stat." - }, - "heatCrash": { - "name": "Heat Crash", - "effect": "The user slams its target with its flame-covered body. The more the user outweighs the target, the greater the move's power." - }, - "leafTornado": { - "name": "Leaf Tornado", - "effect": "The user attacks its target by encircling it in sharp leaves. This attack may also lower the target's accuracy." - }, - "steamroller": { - "name": "Steamroller", - "effect": "The user crushes its target by rolling over the target with its rolled-up body. This may also make the target flinch." - }, - "cottonGuard": { - "name": "Cotton Guard", - "effect": "The user protects itself by wrapping its body in soft cotton, which drastically raises the user's Defense stat." - }, - "nightDaze": { - "name": "Night Daze", - "effect": "The user lets loose a pitch-black shock wave at its target. This may also lower the target's accuracy." - }, - "psystrike": { - "name": "Psystrike", - "effect": "The user materializes an odd psychic wave to attack the target. This attack does physical damage." - }, - "tailSlap": { - "name": "Tail Slap", - "effect": "The user attacks by striking the target with its hard tail. It hits the target two to five times in a row." - }, - "hurricane": { - "name": "Hurricane", - "effect": "The user attacks by wrapping its opponent in a fierce wind that flies up into the sky. This may also confuse the target." - }, - "headCharge": { - "name": "Head Charge", - "effect": "The user charges its head into its target, using its powerful guard hair. This also damages the user a little." - }, - "gearGrind": { - "name": "Gear Grind", - "effect": "The user attacks by throwing steel gears at its target twice." - }, - "searingShot": { - "name": "Searing Shot", - "effect": "The user torches everything around it in an inferno of scarlet flames. This may also leave those it hits with a burn." - }, - "technoBlast": { - "name": "Techno Blast", - "effect": "The user fires a beam of light at its target. The move's type changes depending on the Drive the user holds." - }, - "relicSong": { - "name": "Relic Song", - "effect": "The user sings an ancient song and attacks by appealing to the hearts of the listening opposing Pokémon. This may also induce sleep." - }, - "secretSword": { - "name": "Secret Sword", - "effect": "The user cuts with its long horn. The odd power contained in the horn does physical damage to the target." - }, - "glaciate": { - "name": "Glaciate", - "effect": "The user attacks by blowing freezing cold air at opposing Pokémon. This lowers their Speed stats." - }, - "boltStrike": { - "name": "Bolt Strike", - "effect": "The user surrounds itself with a great amount of electricity and charges its target. This may also leave the target with paralysis." - }, - "blueFlare": { - "name": "Blue Flare", - "effect": "The user attacks by engulfing the target in an intense, yet beautiful, blue flame. This may also leave the target with a burn." - }, - "fieryDance": { - "name": "Fiery Dance", - "effect": "Cloaked in flames, the user attacks the target by dancing and flapping its wings. This may also raise the user's Sp. Atk stat." - }, - "freezeShock": { - "name": "Freeze Shock", - "effect": "On the second turn, the user hits the target with electrically charged ice. This may also leave the target with paralysis." - }, - "iceBurn": { - "name": "Ice Burn", - "effect": "On the second turn, an ultracold, freezing wind surrounds the target. This may leave the target with a burn." - }, - "snarl": { - "name": "Snarl", - "effect": "The user yells as if it's ranting about something, which lowers the Sp. Atk stats of opposing Pokémon." - }, - "icicleCrash": { - "name": "Icicle Crash", - "effect": "The user attacks by harshly dropping large icicles onto the target. This may also make the target flinch." - }, - "vCreate": { - "name": "V-create", - "effect": "With a hot flame on its forehead, the user hurls itself at its target. This lowers the user's Defense, Sp. Def, and Speed stats." - }, - "fusionFlare": { - "name": "Fusion Flare", - "effect": "The user brings down a giant flame. This move's power is increased when influenced by an enormous lightning bolt." - }, - "fusionBolt": { - "name": "Fusion Bolt", - "effect": "The user throws down a giant lightning bolt. This move's power is increased when influenced by an enormous flame." - }, - "flyingPress": { - "name": "Flying Press", - "effect": "The user dives down onto the target from the sky. This move is Fighting and Flying type simultaneously." - }, - "matBlock": { - "name": "Mat Block", - "effect": "Using a pulled-up mat as a shield, the user protects itself and its allies from damaging moves. This does not stop status moves." - }, - "belch": { - "name": "Belch", - "effect": "The user lets out a damaging belch at the target. The user must eat a held Berry to use this move." - }, - "rototiller": { - "name": "Rototiller", - "effect": "Tilling the soil, the user makes it easier for plants to grow. This raises the Attack and Sp. Atk stats of Grass-type Pokémon." - }, - "stickyWeb": { - "name": "Sticky Web", - "effect": "The user weaves a sticky net around the opposing team, which lowers their Speed stats upon switching into battle." - }, - "fellStinger": { - "name": "Fell Stinger", - "effect": "When the user knocks out a target with this move, the user's Attack stat rises drastically." - }, - "phantomForce": { - "name": "Phantom Force", - "effect": "The user vanishes somewhere, then strikes the target on the next turn. This move hits even if the target protects itself." - }, - "trickOrTreat": { - "name": "Trick-or-Treat", - "effect": "The user takes the target trick-or-treating. This adds Ghost type to the target's type." - }, - "nobleRoar": { - "name": "Noble Roar", - "effect": "Letting out a noble roar, the user intimidates the target and lowers its Attack and Sp. Atk stats." - }, - "ionDeluge": { - "name": "Ion Deluge", - "effect": "The user disperses electrically charged particles, which changes Normal-type moves to Electric-type moves." - }, - "parabolicCharge": { - "name": "Parabolic Charge", - "effect": "The user attacks everything around it. The user's HP is restored by half the damage taken by those hit." - }, - "forestsCurse": { - "name": "Forest's Curse", - "effect": "The user puts a forest curse on the target. The target is now Grass type as well." - }, - "petalBlizzard": { - "name": "Petal Blizzard", - "effect": "The user stirs up a violent petal blizzard and attacks everything around it." - }, - "freezeDry": { - "name": "Freeze-Dry", - "effect": "The user rapidly cools the target. This may also leave the target frozen. This move is super effective on Water types." - }, - "disarmingVoice": { - "name": "Disarming Voice", - "effect": "Letting out a charming cry, the user does emotional damage to opposing Pokémon. This attack never misses." - }, - "partingShot": { - "name": "Parting Shot", - "effect": "With a parting threat, the user lowers the target's Attack and Sp. Atk stats. Then it switches with a party Pokémon." - }, - "topsyTurvy": { - "name": "Topsy-Turvy", - "effect": "All stat changes affecting the target turn topsy-turvy and become the opposite of what they were." - }, - "drainingKiss": { - "name": "Draining Kiss", - "effect": "The user steals the target's HP with a kiss. The user's HP is restored by over half of the damage taken by the target." - }, - "craftyShield": { - "name": "Crafty Shield", - "effect": "The user protects itself and its allies from status moves with a mysterious power. This does not stop moves that do damage." - }, - "flowerShield": { - "name": "Flower Shield", - "effect": "The user raises the Defense stats of all Grass-type Pokémon in battle with a mysterious power." - }, - "grassyTerrain": { - "name": "Grassy Terrain", - "effect": "The user turns the ground to grass for five turns. This restores the HP of Pokémon on the ground a little every turn and powers up Grass-type moves." - }, - "mistyTerrain": { - "name": "Misty Terrain", - "effect": "This protects Pokémon on the ground from status conditions and halves damage from Dragon-type moves for five turns." - }, - "electrify": { - "name": "Electrify", - "effect": "If the target is electrified before it uses a move during that turn, the target's move becomes Electric type." - }, - "playRough": { - "name": "Play Rough", - "effect": "The user plays rough with the target and attacks it. This may also lower the target's Attack stat." - }, - "fairyWind": { - "name": "Fairy Wind", - "effect": "The user stirs up a fairy wind and strikes the target with it." - }, - "moonblast": { - "name": "Moonblast", - "effect": "Borrowing the power of the moon, the user attacks the target. This may also lower the target's Sp. Atk stat." - }, - "boomburst": { - "name": "Boomburst", - "effect": "The user attacks everything around it with the destructive power of a terrible, explosive sound." - }, - "fairyLock": { - "name": "Fairy Lock", - "effect": "By locking down the battlefield, the user keeps all Pokémon from fleeing during the next turn." - }, - "kingsShield": { - "name": "King's Shield", - "effect": "The user takes a defensive stance while it protects itself from damage. It also lowers the Attack stat of any attacker that makes direct contact." - }, - "playNice": { - "name": "Play Nice", - "effect": "The user and the target become friends, and the target loses its will to fight. This lowers the target's Attack stat." - }, - "confide": { - "name": "Confide", - "effect": "The user tells the target a secret, and the target loses its ability to concentrate. This lowers the target's Sp. Atk stat." - }, - "diamondStorm": { - "name": "Diamond Storm", - "effect": "The user whips up a storm of diamonds to damage opposing Pokémon. This may also sharply raise the user's Defense stat." - }, - "steamEruption": { - "name": "Steam Eruption", - "effect": "The user immerses the target in superheated steam. This may also leave the target with a burn." - }, - "hyperspaceHole": { - "name": "Hyperspace Hole", - "effect": "Using a hyperspace hole, the user appears right next to the target and strikes. This also hits a target using a move such as Protect or Detect." - }, - "waterShuriken": { - "name": "Water Shuriken", - "effect": "The user hits the target with throwing stars two to five times in a row. This move always goes first." - }, - "mysticalFire": { - "name": "Mystical Fire", - "effect": "The user attacks by breathing a special, hot fire. This also lowers the target's Sp. Atk stat." - }, - "spikyShield": { - "name": "Spiky Shield", - "effect": "In addition to protecting the user from attacks, this move also damages any attacker that makes direct contact." - }, - "aromaticMist": { - "name": "Aromatic Mist", - "effect": "The user raises the Sp. Def stat of an ally Pokémon by using a mysterious aroma." - }, - "eerieImpulse": { - "name": "Eerie Impulse", - "effect": "The user's body generates an eerie impulse. Exposing the target to it harshly lowers the target's Sp. Atk stat." - }, - "venomDrench": { - "name": "Venom Drench", - "effect": "Opposing Pokémon are drenched in an odd poisonous liquid. This lowers the Attack, Sp. Atk, and Speed stats of a poisoned target." - }, - "powder": { - "name": "Powder", - "effect": "The user covers the target in a combustible powder. If the target uses a Fire-type move, the powder explodes and damages the target." - }, - "geomancy": { - "name": "Geomancy", - "effect": "The user absorbs energy and sharply raises its Sp. Atk, Sp. Def, and Speed stats on the next turn." - }, - "magneticFlux": { - "name": "Magnetic Flux", - "effect": "The user manipulates magnetic fields, which raises the Defense and Sp. Def stats of ally Pokémon with the Plus or Minus Ability." - }, - "happyHour": { - "name": "Happy Hour", - "effect": "Using Happy Hour doubles the amount of prize money received after battle." - }, - "electricTerrain": { - "name": "Electric Terrain", - "effect": "The user electrifies the ground for five turns, powering up Electric-type moves. Pokémon on the ground no longer fall asleep." - }, - "dazzlingGleam": { - "name": "Dazzling Gleam", - "effect": "The user damages opposing Pokémon by emitting a powerful flash." - }, - "celebrate": { - "name": "Celebrate", - "effect": "The Pokémon congratulates you on your special day!" - }, - "holdHands": { - "name": "Hold Hands", - "effect": "The user and an ally hold hands. This makes them very happy." - }, - "babyDollEyes": { - "name": "Baby-Doll Eyes", - "effect": "The user stares at the target with its baby-doll eyes, which lowers the target's Attack stat. This move always goes first." - }, - "nuzzle": { - "name": "Nuzzle", - "effect": "The user attacks by nuzzling its electrified cheeks against the target. This also leaves the target with paralysis." - }, - "holdBack": { - "name": "Hold Back", - "effect": "The user holds back when it attacks, and the target is left with at least 1 HP." - }, - "infestation": { - "name": "Infestation", - "effect": "The target is infested and attacked for four to five turns. The target can't flee during this time." - }, - "powerUpPunch": { - "name": "Power-Up Punch", - "effect": "Striking opponents over and over makes the user's fists harder. Hitting a target raises the Attack stat." - }, - "oblivionWing": { - "name": "Oblivion Wing", - "effect": "The user absorbs its target's HP. The user's HP is restored by over half of the damage taken by the target." - }, - "thousandArrows": { - "name": "Thousand Arrows", - "effect": "This move also hits opposing Pokémon that are in the air. Those Pokémon are knocked down to the ground." - }, - "thousandWaves": { - "name": "Thousand Waves", - "effect": "The user attacks with a wave that crawls along the ground. Those it hits can't flee from battle." - }, - "landsWrath": { - "name": "Land's Wrath", - "effect": "The user gathers the energy of the land and focuses that power on opposing Pokémon to damage them." - }, - "lightOfRuin": { - "name": "Light of Ruin", - "effect": "Drawing power from the Eternal Flower, the user fires a powerful beam of light. This also damages the user quite a lot." - }, - "originPulse": { - "name": "Origin Pulse", - "effect": "The user attacks opposing Pokémon with countless beams of light that glow a deep and brilliant blue." - }, - "precipiceBlades": { - "name": "Precipice Blades", - "effect": "The user attacks opposing Pokémon by manifesting the power of the land in fearsome blades of stone." - }, - "dragonAscent": { - "name": "Dragon Ascent", - "effect": "After soaring upward, the user attacks its target by dropping out of the sky at high speeds. But it lowers its own Defense and Sp. Def stats in the process." - }, - "hyperspaceFury": { - "name": "Hyperspace Fury", - "effect": "Using its many arms, the user unleashes a barrage of attacks that ignore the effects of moves like Protect and Detect. But the user's Defense stat falls." - }, - "breakneckBlitzPhysical": { - "name": "Breakneck Blitz", - "effect": "The user builds up its momentum using its Z-Power and crashes into the target at full speed. The power varies, depending on the original move." - }, - "breakneckBlitzSpecial": { - "name": "Breakneck Blitz", - "effect": "Dummy Data" - }, - "allOutPummelingPhysical": { - "name": "All-Out Pummeling", - "effect": "The user rams an energy orb created by its Z-Power into the target with full force. The power varies, depending on the original move." - }, - "allOutPummelingSpecial": { - "name": "All-Out Pummeling", - "effect": "Dummy Data" - }, - "supersonicSkystrikePhysical": { - "name": "Supersonic Skystrike", - "effect": "The user soars up with its Z-Power and plummets toward the target at full speed. The power varies, depending on the original move." - }, - "supersonicSkystrikeSpecial": { - "name": "Supersonic Skystrike", - "effect": "Dummy Data" - }, - "acidDownpourPhysical": { - "name": "Acid Downpour", - "effect": "The user creates a poisonous swamp using its Z-Power and sinks the target into it at full force. The power varies, depending on the original move." - }, - "acidDownpourSpecial": { - "name": "Acid Downpour", - "effect": "Dummy Data" - }, - "tectonicRagePhysical": { - "name": "Tectonic Rage", - "effect": "The user burrows deep into the ground and slams into the target with the full force of its Z-Power. The power varies, depending on the original move." - }, - "tectonicRageSpecial": { - "name": "Tectonic Rage", - "effect": "Dummy Data" - }, - "continentalCrushPhysical": { - "name": "Continental Crush", - "effect": "The user summons a huge rock mountain using its Z-Power and drops it onto the target with full force. The power varies, depending on the original move." - }, - "continentalCrushSpecial": { - "name": "Continental Crush", - "effect": "Dummy Data" - }, - "savageSpinOutPhysical": { - "name": "Savage Spin-Out", - "effect": "The user binds the target with full force with threads of silk that the user spits using its Z-Power. The power varies, depending on the original move." - }, - "savageSpinOutSpecial": { - "name": "Savage Spin-Out", - "effect": "Dummy Data" - }, - "neverEndingNightmarePhysical": { - "name": "Never-Ending Nightmare", - "effect": "Deep-seated grudges summoned by the user's Z-Power trap the target. The power varies, depending on the original move." - }, - "neverEndingNightmareSpecial": { - "name": "Never-Ending Nightmare", - "effect": "Dummy Data" - }, - "corkscrewCrashPhysical": { - "name": "Corkscrew Crash", - "effect": "The user spins very fast and rams into the target with the full force of its Z-Power. The power varies, depending on the original move." - }, - "corkscrewCrashSpecial": { - "name": "Corkscrew Crash", - "effect": "Dummy Data" - }, - "infernoOverdrivePhysical": { - "name": "Inferno Overdrive", - "effect": "The user breathes a stream of intense fire toward the target with the full force of its Z-Power. The power varies depending on the original move." - }, - "infernoOverdriveSpecial": { - "name": "Inferno Overdrive", - "effect": "Dummy Data" - }, - "hydroVortexPhysical": { - "name": "Hydro Vortex", - "effect": "The user creates a huge whirling current using its Z-Power to swallow the target with full force. The power varies, depending on the original move." - }, - "hydroVortexSpecial": { - "name": "Hydro Vortex", - "effect": "Dummy Data" - }, - "bloomDoomPhysical": { - "name": "Bloom Doom", - "effect": "The user collects energy from plants using its Z-Power and attacks the target with full force. The power varies, depending on the original move." - }, - "bloomDoomSpecial": { - "name": "Bloom Doom", - "effect": "Dummy Data" - }, - "gigavoltHavocPhysical": { - "name": "Gigavolt Havoc", - "effect": "The user hits the target with a powerful electric current collected by its Z-Power. The power varies, depending on the original move." - }, - "gigavoltHavocSpecial": { - "name": "Gigavolt Havoc", - "effect": "Dummy Data" - }, - "shatteredPsychePhysical": { - "name": "Shattered Psyche", - "effect": "The user controls the target with its Z-Power and hurts the target with full force. The power varies, depending on the original move." - }, - "shatteredPsycheSpecial": { - "name": "Shattered Psyche", - "effect": "Dummy Data" - }, - "subzeroSlammerPhysical": { - "name": "Subzero Slammer", - "effect": "The user dramatically drops the temperature using its Z-Power and freezes the target with full force. The power varies, depending on the original move." - }, - "subzeroSlammerSpecial": { - "name": "Subzero Slammer", - "effect": "Dummy Data" - }, - "devastatingDrakePhysical": { - "name": "Devastating Drake", - "effect": "The user materializes its aura using its Z-Power and attacks the target with full force. The power varies, depending on the original move." - }, - "devastatingDrakeSpecial": { - "name": "Devastating Drake", - "effect": "Dummy Data" - }, - "blackHoleEclipsePhysical": { - "name": "Black Hole Eclipse", - "effect": "The user gathers dark energy using its Z-Power and sucks the target into it. The power varies, depending on the original move." - }, - "blackHoleEclipseSpecial": { - "name": "Black Hole Eclipse", - "effect": "Dummy Data" - }, - "twinkleTacklePhysical": { - "name": "Twinkle Tackle", - "effect": "The user creates a very charming space using its Z-Power and totally toys with the target. The power varies, depending on the original move." - }, - "twinkleTackleSpecial": { - "name": "Twinkle Tackle", - "effect": "Dummy Data" - }, - "catastropika": { - "name": "Catastropika", - "effect": "The user, Pikachu, surrounds itself with the maximum amount of electricity using its Z-Power and pounces on its target with full force." - }, - "shoreUp": { - "name": "Shore Up", - "effect": "The user regains up to half of its max HP. It restores more HP in a sandstorm." - }, - "firstImpression": { - "name": "First Impression", - "effect": "Although this move has great power, it only works the first turn each time the user enters battle." - }, - "banefulBunker": { - "name": "Baneful Bunker", - "effect": "In addition to protecting the user from attacks, this move also poisons any attacker that makes direct contact." - }, - "spiritShackle": { - "name": "Spirit Shackle", - "effect": "The user attacks while simultaneously stitching the target's shadow to the ground to prevent the target from escaping." - }, - "darkestLariat": { - "name": "Darkest Lariat", - "effect": "The user swings both arms and hits the target. The target's stat changes don't affect this attack's damage." - }, - "sparklingAria": { - "name": "Sparkling Aria", - "effect": "The user bursts into song, emitting many bubbles. Any Pokémon suffering from a burn will be healed by the touch of these bubbles." - }, - "iceHammer": { - "name": "Ice Hammer", - "effect": "The user swings and hits with its strong, heavy fist. It lowers the user's Speed, however." - }, - "floralHealing": { - "name": "Floral Healing", - "effect": "The user restores the target's HP by up to half of its max HP. It restores more HP when the terrain is grass." - }, - "highHorsepower": { - "name": "High Horsepower", - "effect": "The user fiercely attacks the target using its entire body." - }, - "strengthSap": { - "name": "Strength Sap", - "effect": "The user restores its HP by the same amount as the target's Attack stat. It also lowers the target's Attack stat." - }, - "solarBlade": { - "name": "Solar Blade", - "effect": "In this two-turn attack, the user gathers light and fills a blade with the light's energy, attacking the target on the next turn." - }, - "leafage": { - "name": "Leafage", - "effect": "The user attacks by pelting the target with leaves." - }, - "spotlight": { - "name": "Spotlight", - "effect": "The user shines a spotlight on the target so that only the target will be attacked during the turn." - }, - "toxicThread": { - "name": "Toxic Thread", - "effect": "The user shoots poisonous threads to poison the target and lower the target's Speed stat." - }, - "laserFocus": { - "name": "Laser Focus", - "effect": "The user concentrates intensely. The attack on the next turn always results in a critical hit." - }, - "gearUp": { - "name": "Gear Up", - "effect": "The user engages its gears to raise the Attack and Sp. Atk stats of ally Pokémon with the Plus or Minus Ability." - }, - "throatChop": { - "name": "Throat Chop", - "effect": "The user attacks the target's throat, and the resultant suffering prevents the target from using moves that emit sound for two turns." - }, - "pollenPuff": { - "name": "Pollen Puff", - "effect": "The user attacks the enemy with a pollen puff that explodes. If the target is an ally, it gives the ally a pollen puff that restores its HP instead." - }, - "anchorShot": { - "name": "Anchor Shot", - "effect": "The user entangles the target with its anchor chain while attacking. The target becomes unable to flee." - }, - "psychicTerrain": { - "name": "Psychic Terrain", - "effect": "This protects Pokémon on the ground from priority moves and powers up Psychic-type moves for five turns." - }, - "lunge": { - "name": "Lunge", - "effect": "The user makes a lunge at the target, attacking with full force. This also lowers the target's Attack stat." - }, - "fireLash": { - "name": "Fire Lash", - "effect": "The user strikes the target with a burning lash. This also lowers the target's Defense stat." - }, - "powerTrip": { - "name": "Power Trip", - "effect": "The user boasts its strength and attacks the target. The more the user's stats are raised, the greater the move's power." - }, - "burnUp": { - "name": "Burn Up", - "effect": "To inflict massive damage, the user burns itself out. After using this move, the user will no longer be Fire type." - }, - "speedSwap": { - "name": "Speed Swap", - "effect": "The user exchanges Speed stats with the target." - }, - "smartStrike": { - "name": "Smart Strike", - "effect": "The user stabs the target with a sharp horn. This attack never misses." - }, - "purify": { - "name": "Purify", - "effect": "The user heals the target's status condition. If the move succeeds, it also restores the user's own HP." - }, - "revelationDance": { - "name": "Revelation Dance", - "effect": "The user attacks the target by dancing very hard. The user's type determines the type of this move." - }, - "coreEnforcer": { - "name": "Core Enforcer", - "effect": "If the Pokémon the user has inflicted damage on have already used their moves, this move eliminates the effect of the target's Ability." - }, - "tropKick": { - "name": "Trop Kick", - "effect": "The user lands an intense kick of tropical origins on the target. This also lowers the target's Attack stat." - }, - "instruct": { - "name": "Instruct", - "effect": "The user instructs the target to use the target's last move again." - }, - "beakBlast": { - "name": "Beak Blast", - "effect": "The user first heats up its beak, and then it attacks the target. Making direct contact with the Pokémon while it's heating up its beak results in a burn." - }, - "clangingScales": { - "name": "Clanging Scales", - "effect": "The user rubs the scales on its entire body and makes a huge noise to attack opposing Pokémon. The user's Defense stat goes down after the attack." - }, - "dragonHammer": { - "name": "Dragon Hammer", - "effect": "The user uses its body like a hammer to attack the target and inflict damage." - }, - "brutalSwing": { - "name": "Brutal Swing", - "effect": "The user swings its body around violently to inflict damage on everything in its vicinity." - }, - "auroraVeil": { - "name": "Aurora Veil", - "effect": "This move reduces damage from physical and special moves for five turns. This can be used only when it is snowing." - }, - "sinisterArrowRaid": { - "name": "Sinister Arrow Raid", - "effect": "The user, Decidueye, creates countless arrows using its Z-Power and shoots the target with full force." - }, - "maliciousMoonsault": { - "name": "Malicious Moonsault", - "effect": "The user, Incineroar, strengthens its body using its Z-Power and crashes into the target with full force." - }, - "oceanicOperetta": { - "name": "Oceanic Operetta", - "effect": "The user, Primarina, summons a massive amount of water using its Z-Power and attacks the target with full force." - }, - "guardianOfAlola": { - "name": "Guardian of Alola", - "effect": "The user, the Land Spirit Pokémon, obtains Alola's energy using its Z-Power and attacks the target with full force. This reduces the target's HP greatly." - }, - "soulStealing7StarStrike": { - "name": "Soul-Stealing 7-Star Strike", - "effect": "After obtaining Z-Power, the user, Marshadow, punches and kicks the target consecutively with full force." - }, - "stokedSparksurfer": { - "name": "Stoked Sparksurfer", - "effect": "After obtaining Z-Power, the user, Alolan Raichu, attacks the target with full force. This move leaves the target with paralysis." - }, - "pulverizingPancake": { - "name": "Pulverizing Pancake", - "effect": "Z-Power brings out the true capabilities of the user, Snorlax. The Pokémon moves its enormous body energetically and attacks the target with full force." - }, - "extremeEvoboost": { - "name": "Extreme Evoboost", - "effect": "After obtaining Z-Power, the user, Eevee, gets energy from its evolved friends and boosts its stats sharply." - }, - "genesisSupernova": { - "name": "Genesis Supernova", - "effect": "After obtaining Z-Power, the user, Mew, attacks the target with full force. The terrain will be charged with psychic energy." - }, - "shellTrap": { - "name": "Shell Trap", - "effect": "The user sets a shell trap. If the user is hit by a physical move, the trap will explode and inflict damage on opposing Pokémon." - }, - "fleurCannon": { - "name": "Fleur Cannon", - "effect": "The user unleashes a strong beam. The attack's recoil harshly lowers the user's Sp. Atk stat." - }, - "psychicFangs": { - "name": "Psychic Fangs", - "effect": "The user bites the target with its psychic capabilities. This can also destroy Light Screen and Reflect." - }, - "stompingTantrum": { - "name": "Stomping Tantrum", - "effect": "Driven by frustration, the user attacks the target. If the user's previous move has failed, the power of this move doubles." - }, - "shadowBone": { - "name": "Shadow Bone", - "effect": "The user attacks by beating the target with a bone that contains a spirit. This may also lower the target's Defense stat." - }, - "accelerock": { - "name": "Accelerock", - "effect": "The user smashes into the target at high speed. This move always goes first." - }, - "liquidation": { - "name": "Liquidation", - "effect": "The user slams into the target using a full-force blast of water. This may also lower the target's Defense stat." - }, - "prismaticLaser": { - "name": "Prismatic Laser", - "effect": "The user shoots powerful lasers using the power of a prism. The user can't move on the next turn." - }, - "spectralThief": { - "name": "Spectral Thief", - "effect": "The user hides in the target's shadow, steals the target's stat boosts, and then attacks." - }, - "sunsteelStrike": { - "name": "Sunsteel Strike", - "effect": "The user slams into the target with the force of a meteor. This move can be used on the target regardless of its Abilities." - }, - "moongeistBeam": { - "name": "Moongeist Beam", - "effect": "The user emits a sinister ray to attack the target. This move can be used on the target regardless of its Abilities." - }, - "tearfulLook": { - "name": "Tearful Look", - "effect": "The user gets teary eyed to make the target lose its combative spirit. This lowers the target's Attack and Sp. Atk stats." - }, - "zingZap": { - "name": "Zing Zap", - "effect": "A strong electric blast crashes down on the target, giving it an electric shock. This may also make the target flinch." - }, - "naturesMadness": { - "name": "Nature's Madness", - "effect": "The user hits the target with the force of nature. It halves the target's HP." - }, - "multiAttack": { - "name": "Multi-Attack", - "effect": "Cloaking itself in high energy, the user slams into the target. The memory held determines the move's type." - }, - "tenMillionVoltThunderbolt": { - "name": "10,000,000 Volt Thunderbolt", - "effect": "The user, Pikachu wearing a cap, powers up a jolt of electricity using its Z-Power and unleashes it. Critical hits land more easily." - }, - "mindBlown": { - "name": "Mind Blown", - "effect": "The user attacks everything around it by causing its own head to explode. This also damages the user." - }, - "plasmaFists": { - "name": "Plasma Fists", - "effect": "The user attacks with electrically charged fists. This move changes Normal-type moves to Electric-type moves." - }, - "photonGeyser": { - "name": "Photon Geyser", - "effect": "The user attacks a target with a pillar of light. This move inflicts Attack or Sp. Atk damage—whichever stat is higher for the user." - }, - "lightThatBurnsTheSky": { - "name": "Light That Burns the Sky", - "effect": "This attack inflicts Attack or Sp. Atk damage—whichever stat is higher for the user, Necrozma. This move ignores the target's Ability." - }, - "searingSunrazeSmash": { - "name": "Searing Sunraze Smash", - "effect": "After obtaining Z-Power, the user, Solgaleo, attacks the target with full force. This move can ignore the effect of the target's Ability." - }, - "menacingMoonrazeMaelstrom": { - "name": "Menacing Moonraze Maelstrom", - "effect": "After obtaining Z-Power, the user, Lunala, attacks the target with full force. This move can ignore the effect of the target's Ability." - }, - "letsSnuggleForever": { - "name": "Let's Snuggle Forever", - "effect": "After obtaining Z-Power, the user, Mimikyu, punches the target with full force." - }, - "splinteredStormshards": { - "name": "Splintered Stormshards", - "effect": "After obtaining Z-Power, the user, Lycanroc, attacks the target with full force. This move negates the effect on the battlefield." - }, - "clangorousSoulblaze": { - "name": "Clangorous Soulblaze", - "effect": "After obtaining Z-Power, the user, Kommo-o, attacks the opposing Pokémon with full force. This move boosts the user's stats." - }, - "zippyZap": { - "name": "Zippy Zap", - "effect": "The user attacks the target with bursts of electricity at high speed. This move always goes first and results in a critical hit." - }, - "splishySplash": { - "name": "Splishy Splash", - "effect": "The user charges a huge wave with electricity and hits the opposing Pokémon with the wave. This may also leave the opposing Pokémon with paralysis." - }, - "floatyFall": { - "name": "Floaty Fall", - "effect": "The user floats in the air, and then dives at a steep angle to attack the target. This may also make the target flinch." - }, - "pikaPapow": { - "name": "Pika Papow", - "effect": "The more Pikachu loves its Trainer, the greater the move's power. It never misses." - }, - "bouncyBubble": { - "name": "Bouncy Bubble", - "effect": "The user attacks by shooting water bubbles at the target. It then absorbs water and restores its HP by the damage taken by the target." - }, - "buzzyBuzz": { - "name": "Buzzy Buzz", - "effect": "The user shoots a jolt of electricity to attack the target. This also leaves the target with paralysis." - }, - "sizzlySlide": { - "name": "Sizzly Slide", - "effect": "The user cloaks itself in fire and charges at the target. This also leaves the target with a burn." - }, - "glitzyGlow": { - "name": "Glitzy Glow", - "effect": "The user bombards the target with telekinetic force. A wondrous wall of light is put up to weaken the power of the opposing Pokémon's special moves." - }, - "baddyBad": { - "name": "Baddy Bad", - "effect": "The user acts bad and attacks the target. A wondrous wall of light is put up to weaken the power of the opposing Pokémon's physical moves." - }, - "sappySeed": { - "name": "Sappy Seed", - "effect": "The user grows a gigantic stalk that scatters seeds to attack the target. The seeds drain the target's HP every turn." - }, - "freezyFrost": { - "name": "Freezy Frost", - "effect": "The user attacks with a crystal made of cold frozen haze. It eliminates every stat change among all the Pokémon engaged in battle." - }, - "sparklySwirl": { - "name": "Sparkly Swirl", - "effect": "The user attacks the target by wrapping it with a whirlwind of an overpowering scent. This also heals all status conditions of the user's party." - }, - "veeveeVolley": { - "name": "Veevee Volley", - "effect": "The more Eevee loves its Trainer, the greater the move's power. It never misses." - }, - "doubleIronBash": { - "name": "Double Iron Bash", - "effect": "The user rotates, centering the hex nut in its chest, and then strikes with its arms twice in a row. This may also make the target flinch." - }, - "maxGuard": { - "name": "Max Guard", - "effect": "This move enables the user to protect itself from all attacks. Its chance of failing rises if it is used in succession." - }, - "dynamaxCannon": { - "name": "Dynamax Cannon", - "effect": "The user unleashes a strong beam from its core. Deals up to twice the damage if the target is overly leveled." - }, - "snipeShot": { - "name": "Snipe Shot", - "effect": "The user ignores the effects of opposing Pokémon's moves and Abilities that draw in moves, allowing this move to hit the chosen target." - }, - "jawLock": { - "name": "Jaw Lock", - "effect": "This move prevents the user and the target from switching out until either of them faints. The effect goes away if either of the Pokémon leaves the field." - }, - "stuffCheeks": { - "name": "Stuff Cheeks", - "effect": "The user eats its held Berry, then sharply raises its Defense stat." - }, - "noRetreat": { - "name": "No Retreat", - "effect": "This move raises all the user's stats but prevents the user from switching out or fleeing." - }, - "tarShot": { - "name": "Tar Shot", - "effect": "The user pours sticky tar over the target, lowering the target's Speed stat. The target becomes weaker to Fire-type moves." - }, - "magicPowder": { - "name": "Magic Powder", - "effect": "The user scatters a cloud of magic powder that changes the target to Psychic type." - }, - "dragonDarts": { - "name": "Dragon Darts", - "effect": "The user attacks twice using Dreepy. If there are two targets, this move hits each target once." - }, - "teatime": { - "name": "Teatime", - "effect": "The user has teatime with all the Pokémon in the battle. Each Pokémon eats its held Berry." - }, - "octolock": { - "name": "Octolock", - "effect": "The user locks the target in and prevents it from fleeing. This move also lowers the target's Defense and Sp. Def every turn." - }, - "boltBeak": { - "name": "Bolt Beak", - "effect": "The user stabs the target with its electrified beak. If the user attacks before the target, the power of this move is doubled." - }, - "fishiousRend": { - "name": "Fishious Rend", - "effect": "The user rends the target with its hard gills. If the user attacks before the target, the power of this move is doubled." - }, - "courtChange": { - "name": "Court Change", - "effect": "With its mysterious power, the user swaps the effects on either side of the field." - }, - "maxFlare": { - "name": "Max Flare", - "effect": "This is a Fire-type attack Dynamax Pokémon use. The user intensifies the sun for five turns." - }, - "maxFlutterby": { - "name": "Max Flutterby", - "effect": "This is a Bug-type attack Dynamax Pokémon use. This lowers the target's Sp. Atk stat." - }, - "maxLightning": { - "name": "Max Lightning", - "effect": "This is an Electric-type attack Dynamax Pokémon use. The user turns the ground into Electric Terrain for five turns." - }, - "maxStrike": { - "name": "Max Strike", - "effect": "This is a Normal-type attack Dynamax Pokémon use. This lowers the target's Speed stat." - }, - "maxKnuckle": { - "name": "Max Knuckle", - "effect": "This is a Fighting-type attack Dynamax Pokémon use. This raises ally Pokémon's Attack stats." - }, - "maxPhantasm": { - "name": "Max Phantasm", - "effect": "This is a Ghost-type attack Dynamax Pokémon use. This lowers the target's Defense stat." - }, - "maxHailstorm": { - "name": "Max Hailstorm", - "effect": "This is an Ice-type attack Dynamax Pokémon use. The user summons a hailstorm lasting five turns." - }, - "maxOoze": { - "name": "Max Ooze", - "effect": "This is a Poison-type attack Dynamax Pokémon use. This raises ally Pokémon's Sp. Atk stats." - }, - "maxGeyser": { - "name": "Max Geyser", - "effect": "This is a Water-type attack Dynamax Pokémon use. The user summons a heavy rain that falls for five turns." - }, - "maxAirstream": { - "name": "Max Airstream", - "effect": "This is a Flying-type attack Dynamax Pokémon use. This raises ally Pokémon's Speed stats." - }, - "maxStarfall": { - "name": "Max Starfall", - "effect": "This is a Fairy-type attack Dynamax Pokémon use. The user turns the ground into Misty Terrain for five turns." - }, - "maxWyrmwind": { - "name": "Max Wyrmwind", - "effect": "This is a Dragon-type attack Dynamax Pokémon use. This lowers the target's Attack stat." - }, - "maxMindstorm": { - "name": "Max Mindstorm", - "effect": "This is a Psychic-type attack Dynamax Pokémon use. The user turns the ground into Psychic Terrain for five turns." - }, - "maxRockfall": { - "name": "Max Rockfall", - "effect": "This is a Rock-type attack Dynamax Pokémon use. The user summons a sandstorm lasting five turns." - }, - "maxQuake": { - "name": "Max Quake", - "effect": "This is a Ground-type attack Dynamax Pokémon use. This raises ally Pokémon's Sp. Def stats." - }, - "maxDarkness": { - "name": "Max Darkness", - "effect": "This is a Dark-type attack Dynamax Pokémon use. This lowers the target's Sp. Def stat." - }, - "maxOvergrowth": { - "name": "Max Overgrowth", - "effect": "This is a Grass-type attack Dynamax Pokémon use. The user turns the ground into Grassy Terrain for five turns." - }, - "maxSteelspike": { - "name": "Max Steelspike", - "effect": "This is a Steel-type attack Dynamax Pokémon use. This raises ally Pokémon's Defense stats." - }, - "clangorousSoul": { - "name": "Clangorous Soul", - "effect": "The user raises all its stats by using some of its HP." - }, - "bodyPress": { - "name": "Body Press", - "effect": "The user attacks by slamming its body into the target. The higher the user's Defense, the more damage it can inflict on the target." - }, - "decorate": { - "name": "Decorate", - "effect": "The user sharply raises the target's Attack and Sp. Atk stats by decorating the target." - }, - "drumBeating": { - "name": "Drum Beating", - "effect": "The user plays its drum, controlling the drum's roots to attack the target. This also lowers the target's Speed stat." - }, - "snapTrap": { - "name": "Snap Trap", - "effect": "The user snares the target in a snap trap for four to five turns." - }, - "pyroBall": { - "name": "Pyro Ball", - "effect": "The user attacks by igniting a small stone and launching it as a fiery ball at the target. This may also leave the target with a burn." - }, - "behemothBlade": { - "name": "Behemoth Blade", - "effect": "The user wields a large, powerful sword using its whole body and cuts the target in a vigorous attack." - }, - "behemothBash": { - "name": "Behemoth Bash", - "effect": "The user's body becomes a firm shield and slams into the target fiercely." - }, - "auraWheel": { - "name": "Aura Wheel", - "effect": "Morpeko attacks and raises its Speed with the energy stored in its cheeks. This move's type changes depending on the user's form." - }, - "breakingSwipe": { - "name": "Breaking Swipe", - "effect": "The user swings its tough tail wildly and attacks opposing Pokémon. This also lowers their Attack stats." - }, - "branchPoke": { - "name": "Branch Poke", - "effect": "The user attacks the target by poking it with a sharply pointed branch." - }, - "overdrive": { - "name": "Overdrive", - "effect": "The user attacks opposing Pokémon by twanging a guitar or bass guitar, causing a huge echo and strong vibration." - }, - "appleAcid": { - "name": "Apple Acid", - "effect": "The user attacks the target with an acidic liquid created from tart apples. This also lowers the target's Sp. Def stat." - }, - "gravApple": { - "name": "Grav Apple", - "effect": "The user inflicts damage by dropping an apple from high above. This also lowers the target's Defense stat." - }, - "spiritBreak": { - "name": "Spirit Break", - "effect": "The user attacks the target with so much force that it could break the target's spirit. This also lowers the target's Sp. Atk stat." - }, - "strangeSteam": { - "name": "Strange Steam", - "effect": "The user attacks the target by emitting steam. This may also confuse the target." - }, - "lifeDew": { - "name": "Life Dew", - "effect": "The user scatters mysterious water around and restores the HP of itself and its ally Pokémon in the battle." - }, - "obstruct": { - "name": "Obstruct", - "effect": "This move enables the user to protect itself from all attacks. Its chance of failing rises if it is used in succession. Direct contact harshly lowers the attacker's Defense stat." - }, - "falseSurrender": { - "name": "False Surrender", - "effect": "The user pretends to bow its head, but then it stabs the target with its disheveled hair. This attack never misses." - }, - "meteorAssault": { - "name": "Meteor Assault", - "effect": "The user attacks wildly with its thick leek. The user can't move on the next turn, because the force of this move makes it stagger." - }, - "eternabeam": { - "name": "Eternabeam", - "effect": "This is Eternatus's most powerful attack in its original form. The user can't move on the next turn." - }, - "steelBeam": { - "name": "Steel Beam", - "effect": "The user fires a beam of steel that it collected from its entire body. This also damages the user." - }, - "expandingForce": { - "name": "Expanding Force", - "effect": "The user attacks the target with its psychic power. This move's power goes up and damages all opposing Pokémon on Psychic Terrain." - }, - "steelRoller": { - "name": "Steel Roller", - "effect": "The user attacks while destroying the terrain. This move fails when the ground hasn't turned into a terrain." - }, - "scaleShot": { - "name": "Scale Shot", - "effect": "The user attacks by shooting scales two to five times in a row. This move boosts the user's Speed stat but lowers its Defense stat." - }, - "meteorBeam": { - "name": "Meteor Beam", - "effect": "In this two-turn attack, the user gathers space power and boosts its Sp. Atk stat, then attacks the target on the next turn." - }, - "shellSideArm": { - "name": "Shell Side Arm", - "effect": "This move inflicts physical or special damage, whichever will be more effective. This may also poison the target." - }, - "mistyExplosion": { - "name": "Misty Explosion", - "effect": "The user attacks everything around it and faints upon using this move. This move's power is increased on Misty Terrain." - }, - "grassyGlide": { - "name": "Grassy Glide", - "effect": "Gliding on the ground, the user attacks the target. This move always goes first on Grassy Terrain." - }, - "risingVoltage": { - "name": "Rising Voltage", - "effect": "The user attacks with electric voltage rising from the ground. This move's power doubles when the target is on Electric Terrain." - }, - "terrainPulse": { - "name": "Terrain Pulse", - "effect": "The user utilizes the power of the terrain to attack. This move's type and power changes depending on the terrain when it's used." - }, - "skitterSmack": { - "name": "Skitter Smack", - "effect": "The user skitters behind the target to attack. This also lowers the target's Sp. Atk stat." - }, - "burningJealousy": { - "name": "Burning Jealousy", - "effect": "The user attacks with energy from jealousy. This leaves all opposing Pokémon that have had their stats boosted during the turn with a burn." - }, - "lashOut": { - "name": "Lash Out", - "effect": "The user lashes out to vent its frustration toward the target. If the user's stats were lowered during this turn, the power of this move is doubled." - }, - "poltergeist": { - "name": "Poltergeist", - "effect": "The user attacks the target by controlling the target's item. The move fails if the target doesn't have an item." - }, - "corrosiveGas": { - "name": "Corrosive Gas", - "effect": "The user surrounds everything around it with highly acidic gas and melts away items they hold." - }, - "coaching": { - "name": "Coaching", - "effect": "The user properly coaches its ally Pokémon, boosting their Attack and Defense stats." - }, - "flipTurn": { - "name": "Flip Turn", - "effect": "After making its attack, the user rushes back to switch places with a party Pokémon in waiting." - }, - "tripleAxel": { - "name": "Triple Axel", - "effect": "A consecutive three-kick attack that becomes more powerful with each successful hit." - }, - "dualWingbeat": { - "name": "Dual Wingbeat", - "effect": "The user slams the target with its wings. The target is hit twice in a row." - }, - "scorchingSands": { - "name": "Scorching Sands", - "effect": "The user throws scorching sand at the target to attack. This may also leave the target with a burn." - }, - "jungleHealing": { - "name": "Jungle Healing", - "effect": "The user becomes one with the jungle, restoring HP and healing any status conditions of itself and its ally Pokémon in battle." - }, - "wickedBlow": { - "name": "Wicked Blow", - "effect": "The user, having mastered the Dark style, strikes the target with a fierce blow. This attack always results in a critical hit." - }, - "surgingStrikes": { - "name": "Surging Strikes", - "effect": "The user, having mastered the Water style, strikes the target with a flowing motion three times in a row. This attack always results in a critical hit." - }, - "thunderCage": { - "name": "Thunder Cage", - "effect": "The user traps the target in a cage of sparking electricity for four to five turns." - }, - "dragonEnergy": { - "name": "Dragon Energy", - "effect": "Converting its life-force into power, the user attacks opposing Pokémon. The lower the user's HP, the lower the move's power." - }, - "freezingGlare": { - "name": "Freezing Glare", - "effect": "The user shoots its psychic power from its eyes to attack. This may also leave the target frozen." - }, - "fieryWrath": { - "name": "Fiery Wrath", - "effect": "The user transforms its wrath into a fire-like aura to attack. This may also make opposing Pokémon flinch." - }, - "thunderousKick": { - "name": "Thunderous Kick", - "effect": "The user overwhelms the target with lightning-like movement before delivering a kick. This also lowers the target's Defense stat." - }, - "glacialLance": { - "name": "Glacial Lance", - "effect": "The user attacks by hurling a blizzard-cloaked icicle lance at opposing Pokémon." - }, - "astralBarrage": { - "name": "Astral Barrage", - "effect": "The user attacks by sending a frightful amount of small ghosts at opposing Pokémon." - }, - "eerieSpell": { - "name": "Eerie Spell", - "effect": "The user attacks with its tremendous psychic power. This also removes 3 PP from the target's last move." - }, - "direClaw": { - "name": "Dire Claw", - "effect": "The user lashes out at the target with ruinous claws. This may also leave the target poisoned, paralyzed, or asleep." - }, - "psyshieldBash": { - "name": "Psyshield Bash", - "effect": "Cloaking itself in psychic energy, the user slams into the target. This also boosts the user's Defense stat." - }, - "powerShift": { - "name": "Power Shift", - "effect": "The user swaps its Attack and Defense stats." - }, - "stoneAxe": { - "name": "Stone Axe", - "effect": "The user swings its stone axes at the target. Stone splinters left behind by this attack float around the target." - }, - "springtideStorm": { - "name": "Springtide Storm", - "effect": "The user attacks by wrapping opposing Pokémon in fierce winds brimming with love and hate. This may also lower their Attack stats." - }, - "mysticalPower": { - "name": "Mystical Power", - "effect": "The user attacks by emitting a mysterious power. This also boosts the user's Sp. Atk stat." - }, - "ragingFury": { - "name": "Raging Fury", - "effect": "The user rampages around spewing flames for two to three turns. The user then becomes confused." - }, - "waveCrash": { - "name": "Wave Crash", - "effect": "The user shrouds itself in water and slams into the target with its whole body to inflict damage. This also damages the user quite a lot." - }, - "chloroblast": { - "name": "Chloroblast", - "effect": "The user launches its amassed chlorophyll to inflict damage on the target. This also damages the user." - }, - "mountainGale": { - "name": "Mountain Gale", - "effect": "The user hurls giant chunks of ice at the target to inflict damage. This may also make the target flinch." - }, - "victoryDance": { - "name": "Victory Dance", - "effect": "The user performs an intense dance to usher in victory, boosting its Attack, Defense, and Speed stats." - }, - "headlongRush": { - "name": "Headlong Rush", - "effect": "The user smashes into the target in a full-body tackle. This also lowers the user's Defense and Sp. Def stats." - }, - "barbBarrage": { - "name": "Barb Barrage", - "effect": "The user launches countless toxic barbs to inflict damage. This may also poison the target. This move's power is doubled if the target is already poisoned." - }, - "esperWing": { - "name": "Esper Wing", - "effect": "The user slashes the target with aura-enriched wings. This also boosts the user's Speed stat. This move has a heightened chance of landing a critical hit." - }, - "bitterMalice": { - "name": "Bitter Malice", - "effect": "The user attacks the target with spine-chilling resentment. This also lowers the target's Attack stat." - }, - "shelter": { - "name": "Shelter", - "effect": "The user makes its skin as hard as an iron shield, sharply boosting its Defense stat." - }, - "tripleArrows": { - "name": "Triple Arrows", - "effect": "The user kicks, then fires three arrows. This move has a heightened chance of landing a critical hit and may also lower the target's Defense stat or make it flinch." - }, - "infernalParade": { - "name": "Infernal Parade", - "effect": "The user attacks with myriad fireballs. This may also leave the target with a burn. This move's power is doubled if the target has a status condition." - }, - "ceaselessEdge": { - "name": "Ceaseless Edge", - "effect": "The user slashes its shell blade at the target. Shell splinters left behind by this attack remain scattered under the target as spikes." - }, - "bleakwindStorm": { - "name": "Bleakwind Storm", - "effect": "The user attacks with savagely cold winds that cause both body and spirit to tremble. This may also lower the Speed stats of opposing Pokémon." - }, - "wildboltStorm": { - "name": "Wildbolt Storm", - "effect": "The user summons a thunderous tempest and savagely attacks with lightning and wind. This may also leave opposing Pokémon with paralysis." - }, - "sandsearStorm": { - "name": "Sandsear Storm", - "effect": "The user attacks by wrapping opposing Pokémon in fierce winds and searingly hot sand. This may also leave them with a burn." - }, - "lunarBlessing": { - "name": "Lunar Blessing", - "effect": "The user receives a blessing from the crescent moon, restoring HP and curing status conditions for itself and its ally Pokémon currently in the battle." - }, - "takeHeart": { - "name": "Take Heart", - "effect": "The user lifts its spirits, curing its own status conditions and boosting its Sp. Atk and Sp. Def stats." - }, - "gMaxWildfire": { - "name": "G-Max Wildfire", - "effect": "A Fire-type attack that Gigantamax Charizard use. This move continues to deal damage to opponents for four turns." - }, - "gMaxBefuddle": { - "name": "G-Max Befuddle", - "effect": "A Bug-type attack that Gigantamax Butterfree use. This move inflicts the poisoned, paralyzed, or asleep status condition on opponents." - }, - "gMaxVoltCrash": { - "name": "G-Max Volt Crash", - "effect": "An Electric-type attack that Gigantamax Pikachu use. This move paralyzes opponents." - }, - "gMaxGoldRush": { - "name": "G-Max Gold Rush", - "effect": "A Normal-type attack that Gigantamax Meowth use. This move confuses opponents and also earns extra money." - }, - "gMaxChiStrike": { - "name": "G-Max Chi Strike", - "effect": "A Fighting-type attack that Gigantamax Machamp use. This move raises the chance of critical hits." - }, - "gMaxTerror": { - "name": "G-Max Terror", - "effect": "A Ghost-type attack that Gigantamax Gengar use. This Pokémon steps on the opposing Pokémon's shadow to prevent them from escaping." - }, - "gMaxResonance": { - "name": "G-Max Resonance", - "effect": "An Ice-type attack that Gigantamax Lapras use. This move reduces the damage received for five turns." - }, - "gMaxCuddle": { - "name": "G-Max Cuddle", - "effect": "A Normal-type attack that Gigantamax Eevee use. This move infatuates opponents." - }, - "gMaxReplenish": { - "name": "G-Max Replenish", - "effect": "A Normal-type attack that Gigantamax Snorlax use. This move restores Berries that have been eaten." - }, - "gMaxMalodor": { - "name": "G-Max Malodor", - "effect": "A Poison-type attack that Gigantamax Garbodor use. This move poisons opponents." - }, - "gMaxStonesurge": { - "name": "G-Max Stonesurge", - "effect": "A Water-type attack that Gigantamax Drednaw use. This move scatters sharp rocks around the field." - }, - "gMaxWindRage": { - "name": "G-Max Wind Rage", - "effect": "A Flying-type attack that Gigantamax Corviknight use. This move removes the effects of moves like Reflect and Light Screen." - }, - "gMaxStunShock": { - "name": "G-Max Stun Shock", - "effect": "An Electric-type attack that Gigantamax Toxtricity use. This move poisons or paralyzes opponents." - }, - "gMaxFinale": { - "name": "G-Max Finale", - "effect": "A Fairy-type attack that Gigantamax Alcremie use. This move heals the HP of allies." - }, - "gMaxDepletion": { - "name": "G-Max Depletion", - "effect": "A Dragon-type attack that Gigantamax Duraludon use. Reduces the PP of the last move used." - }, - "gMaxGravitas": { - "name": "G-Max Gravitas", - "effect": "A Psychic-type attack that Gigantamax Orbeetle use. This move changes gravity for five turns." - }, - "gMaxVolcalith": { - "name": "G-Max Volcalith", - "effect": "A Rock-type attack that Gigantamax Coalossal use. This move continues to deal damage to opponents for four turns." - }, - "gMaxSandblast": { - "name": "G-Max Sandblast", - "effect": "A Ground-type attack that Gigantamax Sandaconda use. Opponents are trapped in a raging sandstorm for four to five turns." - }, - "gMaxSnooze": { - "name": "G-Max Snooze", - "effect": "A Dark-type attack that Gigantamax Grimmsnarl use. The user lets loose a huge yawn that lulls the targets into falling asleep on the next turn." - }, - "gMaxTartness": { - "name": "G-Max Tartness", - "effect": "A Grass-type attack that Gigantamax Flapple use. This move reduces the opponents' evasiveness." - }, - "gMaxSweetness": { - "name": "G-Max Sweetness", - "effect": "A Grass-type attack that Gigantamax Appletun use. This move heals the status conditions of allies." - }, - "gMaxSmite": { - "name": "G-Max Smite", - "effect": "A Fairy-type attack that Gigantamax Hatterene use. This move confuses opponents." - }, - "gMaxSteelsurge": { - "name": "G-Max Steelsurge", - "effect": "A Steel-type attack that Gigantamax Copperajah use. This move scatters sharp spikes around the field." - }, - "gMaxMeltdown": { - "name": "G-Max Meltdown", - "effect": "A Steel-type attack that Gigantamax Melmetal use. This move makes opponents incapable of using the same move twice in a row." - }, - "gMaxFoamBurst": { - "name": "G-Max Foam Burst", - "effect": "A Water-type attack that Gigantamax Kingler use. This move harshly lowers the Speed of opponents." - }, - "gMaxCentiferno": { - "name": "G-Max Centiferno", - "effect": "A Fire-type attack that Gigantamax Centiskorch use. This move traps opponents in flames for four to five turns." - }, - "gMaxVineLash": { - "name": "G-Max Vine Lash", - "effect": "A Grass-type attack that Gigantamax Venusaur use. This move continues to deal damage to opponents for four turns." - }, - "gMaxCannonade": { - "name": "G-Max Cannonade", - "effect": "A Water-type attack that Gigantamax Blastoise use. This move continues to deal damage to opponents for four turns." - }, - "gMaxDrumSolo": { - "name": "G-Max Drum Solo", - "effect": "A Grass-type attack that Gigantamax Rillaboom use. This move can be used on the target regardless of its Abilities." - }, - "gMaxFireball": { - "name": "G-Max Fireball", - "effect": "A Fire-type attack that Gigantamax Cinderace use. This move can be used on the target regardless of its Abilities." - }, - "gMaxHydrosnipe": { - "name": "G-Max Hydrosnipe", - "effect": "A Water-type attack that Gigantamax Inteleon use. This move can be used on the target regardless of its Abilities." - }, - "gMaxOneBlow": { - "name": "G-Max One Blow", - "effect": "A Dark-type attack that Gigantamax Urshifu use. This single-strike move can ignore Max Guard." - }, - "gMaxRapidFlow": { - "name": "G-Max Rapid Flow", - "effect": "A Water-type attack that Gigantamax Urshifu use. This rapid-strike move can ignore Max Guard." - }, - "teraBlast": { - "name": "Tera Blast", - "effect": "If the user has Terastallized, it unleashes energy of its Tera Type. This move inflicts damage using the Attack or Sp. Atk stat-whichever is higher for the user." - }, - "silkTrap": { - "name": "Silk Trap", - "effect": "The user spins a silken trap, protecting itself from damage while lowering the Speed stat of any attacker that makes direct contact." - }, - "axeKick": { - "name": "Axe Kick", - "effect": "The user attacks by kicking up into the air and slamming its heel down upon the target. This may also confuse the target. If it misses, the user takes damage instead." - }, - "lastRespects": { - "name": "Last Respects", - "effect": "The user attacks to avenge its allies. The more defeated allies there are in the user's party, the greater the move's power." - }, - "luminaCrash": { - "name": "Lumina Crash", - "effect": "The user attacks by unleashing a peculiar light that even affects the mind. This also harshly lowers the target's Sp. Def stat." - }, - "orderUp": { - "name": "Order Up", - "effect": "The user attacks with elegant poise. If the user has a Tatsugiri in its mouth, this move boosts one of the user's stats based on the Tatsugiri's form." - }, - "jetPunch": { - "name": "Jet Punch", - "effect": "The user summons a torrent around its fist and punches at blinding speed. This move always goes first." - }, - "spicyExtract": { - "name": "Spicy Extract", - "effect": "The user emits an incredibly spicy extract, sharply boosting the target's Attack stat and harshly lowering the target's Defense stat." - }, - "spinOut": { - "name": "Spin Out", - "effect": "The user spins furiously by straining its legs, inflicting damage on the target. This also harshly lowers the user's Speed stat." - }, - "populationBomb": { - "name": "Population Bomb", - "effect": "The user's fellows gather in droves to perform a combo attack that hits the target one to ten times in a row." - }, - "iceSpinner": { - "name": "Ice Spinner", - "effect": "The user covers its feet in thin ice and twirls around, slamming into the target. This move's spinning motion also destroys the terrain." - }, - "glaiveRush": { - "name": "Glaive Rush", - "effect": "The user throws its entire body into a reckless charge. After this move is used, attacks on the user cannot miss and will inflict double damage until the user's next turn." - }, - "revivalBlessing": { - "name": "Revival Blessing", - "effect": "The user bestows a loving blessing, reviving a party Pokémon that has fainted and restoring half that Pokémon's max HP." - }, - "saltCure": { - "name": "Salt Cure", - "effect": "The user salt cures the target, inflicting damage every turn. Steel and Water types are more strongly affected by this move." - }, - "tripleDive": { - "name": "Triple Dive", - "effect": "The user performs a perfectly timed triple dive, hitting the target with splashes of water three times in a row." - }, - "mortalSpin": { - "name": "Mortal Spin", - "effect": "The user performs a spin attack that can also eliminate the effects of such moves as Bind, Wrap, and Leech Seed. This also poisons opposing Pokémon." - }, - "doodle": { - "name": "Doodle", - "effect": "The user captures the very essence of the target in a sketch. This changes the Abilities of the user and its ally Pokémon to that of the target." - }, - "filletAway": { - "name": "Fillet Away", - "effect": "The user sharply boosts its Attack, Sp. Atk, and Speed stats by using its own HP." - }, - "kowtowCleave": { - "name": "Kowtow Cleave", - "effect": "The user slashes at the target after kowtowing to make the target let down its guard. This attack never misses." - }, - "flowerTrick": { - "name": "Flower Trick", - "effect": "The user throws a rigged bouquet of flowers at the target. This attack never misses and always lands a critical hit." - }, - "torchSong": { - "name": "Torch Song", - "effect": "The user blows out raging flames as if singing a song, scorching the target. This also boosts the user's Sp. Atk stat." - }, - "aquaStep": { - "name": "Aqua Step", - "effect": "The user toys with the target and attacks it using light and fluid dance steps. This also boosts the user's Speed stat." - }, - "ragingBull": { - "name": "Raging Bull", - "effect": "The user performs a tackle like a raging bull. This move's type depends on the user's form. It can also break barriers, such as Light Screen and Reflect." - }, - "makeItRain": { - "name": "Make It Rain", - "effect": "The user attacks by throwing out a mass of coins. This also lowers the user's Sp. Atk stat. Money is earned after the battle." - }, - "psyblade": { - "name": "Psyblade", - "effect": "The user rends the target with an ethereal blade. This move's power is boosted by 50 percent if the user is on Electric Terrain." - }, - "hydroSteam": { - "name": "Hydro Steam", - "effect": "The user blasts the target with boiling-hot water. This move's power is not lowered in harsh sunlight but rather boosted by 50 percent." - }, - "ruination": { - "name": "Ruination", - "effect": "The user summons a ruinous disaster. This cuts the target's HP in half." - }, - "collisionCourse": { - "name": "Collision Course", - "effect": "The user transforms and crashes to the ground, causing a massive prehistoric explosion. This move's power is boosted more than usual if it's a supereffective hit." - }, - "electroDrift": { - "name": "Electro Drift", - "effect": "The user races forward at ultrafast speeds, piercing its target with futuristic electricity. This move's power is boosted more than usual if it's a supereffective hit." - }, - "shedTail": { - "name": "Shed Tail", - "effect": "The user creates a substitute for itself using its own HP before switching places with a party Pokémon in waiting." - }, - "chillyReception": { - "name": "Chilly Reception", - "effect": "The user tells a chillingly bad joke before switching places with a party Pokémon in waiting. This summons a snowstorm lasting five turns." - }, - "tidyUp": { - "name": "Tidy Up", - "effect": "The user tidies up and removes the effects of Spikes, Stealth Rock, Sticky Web, Toxic Spikes, and Substitute. This also boosts the user's Attack and Speed stats." - }, - "snowscape": { - "name": "Snowscape", - "effect": "The user summons a snowstorm lasting five turns. This boosts the Defense stats of Ice types." - }, - "pounce": { - "name": "Pounce", - "effect": "The user attacks by pouncing on the target. This also lowers the target's Speed stat." - }, - "trailblaze": { - "name": "Trailblaze", - "effect": "The user attacks suddenly as if leaping out from tall grass. The user's nimble footwork boosts its Speed stat." - }, - "chillingWater": { - "name": "Chilling Water", - "effect": "The user attacks the target by showering it with water that's so cold it saps the target's power. This also lowers the target's Attack stat." - }, - "hyperDrill": { - "name": "Hyper Drill", - "effect": "The user spins the pointed part of its body at high speed to pierce the target. This attack can hit a target using a move such as Protect or Detect." - }, - "twinBeam": { - "name": "Twin Beam", - "effect": "The user shoots mystical beams from its eyes to inflict damage. The target is hit twice in a row." - }, - "rageFist": { - "name": "Rage Fist", - "effect": "The user converts its rage into energy to attack. The more times the user has been hit by attacks, the greater the move's power." - }, - "armorCannon": { - "name": "Armor Cannon", - "effect": "The user shoots its own armor out as blazing projectiles. This also lowers the user's Defense and Sp. Def stats." - }, - "bitterBlade": { - "name": "Bitter Blade", - "effect": "The user focuses its bitter feelings toward the world of the living into a slashing attack. The user's HP is restored by up to half the damage taken by the target." - }, - "doubleShock": { - "name": "Double Shock", - "effect": "The user discharges all the electricity from its body to perform a high-damage attack. After using this move, the user will no longer be Electric type." - }, - "gigatonHammer": { - "name": "Gigaton Hammer", - "effect": "The user swings its whole body around to attack with its huge hammer. This move can't be used twice in a row." - }, - "comeuppance": { - "name": "Comeuppance", - "effect": "The user retaliates with much greater force against the opponent that last inflicted damage on it." - }, - "aquaCutter": { - "name": "Aqua Cutter", - "effect": "The user expels pressurized water to cut at the target like a blade. This move has a heightened chance of landing a critical hit." - }, - "blazingTorque": { - "name": "Blazing Torque", - "effect": "The user revs their blazing engine into the target. This may also leave the target with a burn." - }, - "wickedTorque": { - "name": "Wicked Torque", - "effect": "The user revs their engine into the target with malicious intent. This may put the target to sleep." - }, - "noxiousTorque": { - "name": "Noxious Torque", - "effect": "The user revs their poisonous engine into the target. This may also poison the target." - }, - "combatTorque": { - "name": "Combat Torque", - "effect": "The user revs their engine forcefully into the target. This may also leave the target with paralysis." - }, - "magicalTorque": { - "name": "Magical Torque", - "effect": "The user revs their fae-like engine into the target. This may also confuse the target." - }, - "bloodMoon": { - "name": "Blood Moon", - "effect": "The user unleashes the full brunt of its spirit from a full moon that shines as red as blood. This move can't be used twice in a row." - }, - "matchaGotcha": { - "name": "Matcha Gotcha", - "effect": "The user fires a blast of tea that it mixed. The user's HP is restored by up to half the damage taken by the target. This may also leave the target with a burn." - }, - "syrupBomb": { - "name": "Syrup Bomb", - "effect": "The user sets off an explosion of sticky candy syrup, which coats the target and causes the target's Speed stat to drop each turn for three turns." - }, - "ivyCudgel": { - "name": "Ivy Cudgel", - "effect": "The user strikes with an ivy-wrapped cudgel. This move's type changes depending on the mask worn by the user, and it has a heightened chance of landing a critical hit." - }, - "electroShot": { - "name": "Electro Shot", - "effect": "The user gathers electricity on the first turn, boosting its Sp. Atk stat, then fires a high-voltage shot on the next turn. The shot will be fired immediately in rain." - }, - "teraStarstorm": { - "name": "Tera Starstorm", - "effect": "With the power of its crystals, the user bombards and eliminates the target. When used by Terapagos in its Stellar Form, this move damages all opposing Pokémon." - }, - "fickleBeam": { - "name": "Fickle Beam", - "effect": "The user shoots a beam of light to inflict damage. Sometimes all the user's heads shoot beams in unison, doubling the move's power." - }, - "burningBulwark": { - "name": "Burning Bulwark", - "effect": "The user's intensely hot fur protects it from attacks and also burns any attacker that makes direct contact with it." - }, - "thunderclap": { - "name": "Thunderclap", - "effect": "This move enables the user to attack first with a jolt of electricity. This move fails if the target is not readying an attack." - }, - "mightyCleave": { - "name": "Mighty Cleave", - "effect": "The user wields the light that has accumulated atop its head to cleave the target. This move hits even if the target protects itself." - }, - "tachyonCutter": { - "name": "Tachyon Cutter", - "effect": "The user attacks by launching particle blades at the target twice in a row. This attack never misses." - }, - "hardPress": { - "name": "Hard Press", - "effect": "The target is crushed with an arm, a claw, or the like to inflict damage. The more HP the target has left, the greater the move's power." - }, - "dragonCheer": { - "name": "Dragon Cheer", - "effect": "The user raises its allies' morale with a draconic cry so that their future attacks have a heightened chance of landing critical hits. This rouses Dragon types more." - }, - "alluringVoice": { - "name": "Alluring Voice", - "effect": "The user attacks the target using its angelic voice. This also confuses the target if its stats have been boosted during the turn." - }, - "temperFlare": { - "name": "Temper Flare", - "effect": "Spurred by desperation, the user attacks the target. This move's power is doubled if the user's previous move failed." - }, - "supercellSlam": { - "name": "Supercell Slam", - "effect": "The user electrifies its body and drops onto the target to inflict damage. If this move misses, the user takes damage instead." - }, - "psychicNoise": { - "name": "Psychic Noise", - "effect": "The user attacks the target with unpleasant sound waves. For two turns, the target is prevented from recovering HP through moves, Abilities, or held items." - }, - "upperHand": { - "name": "Upper Hand", - "effect": "The user reacts to the target's movement and strikes with the heel of its palm, making the target flinch. This move fails if the target is not readying a priority move." - }, - "malignantChain": { - "name": "Malignant Chain", - "effect": "The user pours toxins into the target by wrapping them in a toxic, corrosive chain. This may also leave the target badly poisoned." - } -} diff --git a/src/locales/en/mystery-encounter-messages.json b/src/locales/en/mystery-encounter-messages.json deleted file mode 100644 index 3b81c8e46f0..00000000000 --- a/src/locales/en/mystery-encounter-messages.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "paid_money": "You paid ₽{{amount, number}}.", - "receive_money": "You received ₽{{amount, number}}!", - "affects_pokedex": "Affects Pokédex Data", - "cancel_option": "Return to encounter option select.", - "view_party_button": "View Party" -} diff --git a/src/locales/en/mystery-encounters/a-trainers-test-dialogue.json b/src/locales/en/mystery-encounters/a-trainers-test-dialogue.json deleted file mode 100644 index c96c0d5f327..00000000000 --- a/src/locales/en/mystery-encounters/a-trainers-test-dialogue.json +++ /dev/null @@ -1,47 +0,0 @@ -{ - "intro": "An extremely strong trainer approaches you...", - "buck": { - "intro_dialogue": "Yo, trainer! My name's Buck.$I have a super awesome proposal\nfor a strong trainer such as yourself!$I'm carrying two rare Pokémon Eggs with me,\nbut I'd like someone else to care for one.$If you can prove your strength as a trainer to me,\nI'll give you the rarer egg!", - "accept": "Whoooo, I'm getting fired up!", - "decline": "Darn, it looks like your\nteam isn't in peak condition.$Here, let me help with that." - }, - "cheryl": { - "intro_dialogue": "Hello, my name's Cheryl.$I have a particularly interesting request,\nfor a strong trainer such as yourself.$I'm carrying two rare Pokémon Eggs with me,\nbut I'd like someone else to care for one.$If you can prove your strength as a trainer to me,\nI'll give you the rarer Egg!", - "accept": "I hope you're ready!", - "decline": "I understand, it looks like your team\nisn't in the best condition at the moment.$Here, let me help with that." - }, - "marley": { - "intro_dialogue": "...@d{64} I'm Marley.$I have an offer for you...$I'm carrying two Pokémon Eggs with me,\nbut I'd like someone else to care for one.$If you're stronger than me,\nI'll give you the rarer Egg.", - "accept": "... I see.", - "decline": "... I see.$Your Pokémon look hurt...\nLet me help." - }, - "mira": { - "intro_dialogue": "Hi! I'm Mira!$Mira has a request\nfor a strong trainer like you!$Mira has two rare Pokémon Eggs,\nbut Mira wants someone else to take one!$If you show Mira that you're strong,\nMira will give you the rarer Egg!", - "accept": "You'll battle Mira?\nYay!", - "decline": "Aww, no battle?\nThat's okay!$Here, Mira will heal your team!" - }, - "riley": { - "intro_dialogue": "I'm Riley.$I have an odd proposal\nfor a strong trainer such as yourself.$I'm carrying two rare Pokémon Eggs with me,\nbut I'd like to give one to another trainer.$If you can prove your strength to me,\nI'll give you the rarer Egg!", - "accept": "That look you have...\nLet's do this.", - "decline": "I understand, your team looks beat up.$Here, let me help with that." - }, - "title": "A Trainer's Test", - "description": "It seems this trainer is willing to give you an Egg regardless of your decision. However, if you can manage to defeat this strong trainer, you'll receive a much rarer Egg.", - "query": "What will you do?", - "option": { - "1": { - "label": "Accept the Challenge", - "tooltip": "(-) Tough Battle\n(+) Gain a @[TOOLTIP_TITLE]{Very Rare Egg}" - }, - "2": { - "label": "Refuse the Challenge", - "tooltip": "(+) Full Heal Party\n(+) Gain an @[TOOLTIP_TITLE]{Egg}" - } - }, - "eggTypes": { - "rare": "a Rare Egg", - "epic": "an Epic Egg", - "legendary": "a Legendary Egg" - }, - "outro": "{{statTrainerName}} gave you {{eggType}}!" -} \ No newline at end of file diff --git a/src/locales/en/mystery-encounters/absolute-avarice-dialogue.json b/src/locales/en/mystery-encounters/absolute-avarice-dialogue.json deleted file mode 100644 index 1d675d93660..00000000000 --- a/src/locales/en/mystery-encounters/absolute-avarice-dialogue.json +++ /dev/null @@ -1,25 +0,0 @@ -{ - "intro": "A {{greedentName}} ambushes you\nand steals your party's berries!", - "title": "Absolute Avarice", - "description": "The {{greedentName}} has caught you totally off guard now all your berries are gone!\n\nThe {{greedentName}} looks like it's about to eat them when it pauses to look at you, interested.", - "query": "What will you do?", - "option": { - "1": { - "label": "Battle It", - "tooltip": "(-) Tough Battle\n(+) Rewards from its Berry Hoard", - "selected": "The {{greedentName}} stuffs its cheeks\nand prepares for battle!", - "boss_enraged": "{{greedentName}}'s fierce love for food has it incensed!", - "food_stash": "It looks like the {{greedentName}} was guarding an enormous stash of food!$@s{item_fanfare}Each Pokémon in your party gains a {{foodReward}}!" - }, - "2": { - "label": "Reason with It", - "tooltip": "(+) Regain Some Lost Berries", - "selected": "Your pleading strikes a chord with the {{greedentName}}.$It doesn't give all your berries back, but still tosses a few in your direction." - }, - "3": { - "label": "Let It Have the Food", - "tooltip": "(-) Lose All Berries\n(?) The {{greedentName}} Will Like You", - "selected": "The {{greedentName}} devours the entire\nstash of berries in a flash!$Patting its stomach,\nit looks at you appreciatively.$Perhaps you could feed it\nmore berries on your adventure...$@s{level_up_fanfare}The {{greedentName}} wants to join your party!" - } - } -} \ No newline at end of file diff --git a/src/locales/en/mystery-encounters/an-offer-you-cant-refuse-dialogue.json b/src/locales/en/mystery-encounters/an-offer-you-cant-refuse-dialogue.json deleted file mode 100644 index 6dd54d302ab..00000000000 --- a/src/locales/en/mystery-encounters/an-offer-you-cant-refuse-dialogue.json +++ /dev/null @@ -1,26 +0,0 @@ -{ - "intro": "You're stopped by a rich looking boy.", - "speaker": "Rich Boy", - "intro_dialogue": "Good day to you.$I can't help but notice that your\n{{strongestPokemon}} looks positively divine!$I've always wanted to have a pet like that!$I'd pay you handsomely,\nand also give you this old bauble!", - "title": "An Offer You Can't Refuse", - "description": "You're being offered a @[TOOLTIP_TITLE]{Shiny Charm} and {{price, money}} for your {{strongestPokemon}}!\n\nIt's an extremely good deal, but can you really bear to part with such a strong team member?", - "query": "What will you do?", - "option": { - "1": { - "label": "Accept the Deal", - "tooltip": "(-) Lose {{strongestPokemon}}\n(+) Gain a @[TOOLTIP_TITLE]{Shiny Charm}\n(+) Gain {{price, money}}", - "selected": "Wonderful!@d{32} Come along, {{strongestPokemon}}!$It's time to show you off to everyone at the yacht club!$They'll be so jealous!" - }, - "2": { - "label": "Extort the Kid", - "tooltip": "(+) {{option2PrimaryName}} uses {{moveOrAbility}}\n(+) Gain {{price, money}}", - "tooltip_disabled": "Your Pokémon need to have certain moves or abilities to choose this", - "selected": "My word, we're being robbed, {{liepardName}}!$You'll be hearing from my lawyers for this!" - }, - "3": { - "label": "Leave", - "tooltip": "(-) No Rewards", - "selected": "What a rotten day...$Ah, well. Let's return to the yacht club then, {{liepardName}}." - } - } -} \ No newline at end of file diff --git a/src/locales/en/mystery-encounters/berries-abound-dialogue.json b/src/locales/en/mystery-encounters/berries-abound-dialogue.json deleted file mode 100644 index 26eae2c6b88..00000000000 --- a/src/locales/en/mystery-encounters/berries-abound-dialogue.json +++ /dev/null @@ -1,26 +0,0 @@ -{ - "intro": "There's a huge berry bush\nnear that Pokémon!", - "title": "Berries Abound", - "description": "It looks like there's a strong Pokémon guarding a berry bush. Battling is the straightforward approach, but it looks strong. Perhaps a fast Pokémon could grab some berries without getting caught?", - "query": "What will you do?", - "berries": "Berries!", - "option": { - "1": { - "label": "Battle the Pokémon", - "tooltip": "(-) Hard Battle\n(+) Gain Berries", - "selected": "You approach the\nPokémon without fear." - }, - "2": { - "label": "Race to the Bush", - "tooltip": "(-) {{fastestPokemon}} Uses its Speed\n(+) Gain Berries", - "selected": "Your {{fastestPokemon}} races for the berry bush!$It manages to nab {{numBerries}} before the {{enemyPokemon}} can react!$You quickly retreat with your newfound prize.", - "selected_bad": "Your {{fastestPokemon}} races for the berry bush!$Oh no! The {{enemyPokemon}} was faster and blocked off the approach!", - "boss_enraged": "The opposing {{enemyPokemon}} has become enraged!" - }, - "3": { - "label": "Leave", - "tooltip": "(-) No Rewards", - "selected": "You leave the strong Pokémon\nwith its prize and continue on." - } - } -} \ No newline at end of file diff --git a/src/locales/en/mystery-encounters/bug-type-superfan-dialogue.json b/src/locales/en/mystery-encounters/bug-type-superfan-dialogue.json deleted file mode 100644 index 7df01326aed..00000000000 --- a/src/locales/en/mystery-encounters/bug-type-superfan-dialogue.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "intro": "An unusual trainer with all kinds of Bug paraphernalia blocks your way!", - "intro_dialogue": "Hey, trainer! I'm on a mission to find the rarest Bug Pokémon in existence!$You must love Bug Pokémon too, right?\nEveryone loves Bug Pokémon!", - "title": "The Bug-Type Superfan", - "speaker": "Bug-Type Superfan", - "description": "The trainer prattles, not even waiting for a response...\n\nIt seems the only way to get out of this situation is by catching the trainer's attention!", - "query": "What will you do?", - "option": { - "1": { - "label": "Offer to Battle", - "tooltip": "(-) Challenging Battle\n(+) Teach a Pokémon a Bug Type Move", - "selected": "A challenge, eh?\nMy bugs are more than ready for you!" - }, - "2": { - "label": "Show Your Bug Types", - "tooltip": "(+) Receive a Gift Item", - "disabled_tooltip": "You need at least 1 Bug Type Pokémon on your team to select this.", - "selected": "You show the trainer all your Bug Type Pokémon...", - "selected_0_to_1": "Huh? You only have {{numBugTypes}}...$Guess I'm wasting my breath on someone like you...", - "selected_2_to_3": "Hey, you've got {{numBugTypes}} Bug Types!\nNot bad.$Here, this might help you on your journey to catch more!", - "selected_4_to_5": "What? You have {{numBugTypes}} Bug Types?\nNice!$You're not quite at my level, but I can see shades of myself in you!\n$Take this, my young apprentice!", - "selected_6": "Whoa! {{numBugTypes}} Bug Types!\n$You must love Bug Types almost as much as I do!$Here, take this as a token of our camaraderie!" - }, - "3": { - "label": "Gift a Bug Item", - "tooltip": "(-) Give the trainer a {{requiredBugItems}}\n(+) Receive a Gift Item", - "disabled_tooltip": "You need to have a {{requiredBugItems}} to select this.", - "select_prompt": "Select an item to give.", - "invalid_selection": "Pokémon doesn't have that kind of item.", - "selected": "You hand the trainer a {{selectedItem}}.", - "selected_dialogue": "Whoa! A {{selectedItem}}, for me?\nYou're not so bad, kid!$As a token of my appreciation,\nI want you to have this special gift!$It's been passed all through my family, and now I want you to have it!" - } - }, - "battle_won": "Your knowledge and skill were perfect at exploiting our weaknesses!$In exchange for the valuable lesson,\nallow me to teach one of your Pokémon a Bug Type Move!", - "teach_move_prompt": "Select a move to teach a Pokémon.", - "confirm_no_teach": "You sure you don't want to learn one of these great moves?", - "outro": "I see great Bug Pokémon in your future!\nMay our paths cross again!$Bug out!" -} \ No newline at end of file diff --git a/src/locales/en/mystery-encounters/clowning-around-dialogue.json b/src/locales/en/mystery-encounters/clowning-around-dialogue.json deleted file mode 100644 index 17781240838..00000000000 --- a/src/locales/en/mystery-encounters/clowning-around-dialogue.json +++ /dev/null @@ -1,34 +0,0 @@ -{ - "intro": "It's...@d{64} a clown?", - "speaker": "Clown", - "intro_dialogue": "Bumbling buffoon, brace for a brilliant battle!\nYou'll be beaten by this brawling busker!", - "title": "Clowning Around", - "description": "Something is off about this encounter. The clown seems eager to goad you into a battle, but to what end?\n\nThe {{blacephalonName}} is especially strange, like it has @[TOOLTIP_TITLE]{weird types and ability.}", - "query": "What will you do?", - "option": { - "1": { - "label": "Battle the Clown", - "tooltip": "(-) Strange Battle\n(?) Affects Pokémon Abilities", - "selected": "Your pitiful Pokémon are poised for a pathetic performance!", - "apply_ability_dialogue": "A sensational showcase!\nYour savvy suits a sensational skill as spoils!", - "apply_ability_message": "The clown is offering to permanently Skill Swap one of your Pokémon's ability to {{ability}}!", - "ability_prompt": "Would you like to permanently teach a Pokémon the {{ability}} ability?", - "ability_gained": "@s{level_up_fanfare}{{chosenPokemon}} gained the {{ability}} ability!" - }, - "2": { - "label": "Remain Unprovoked", - "tooltip": "(-) Upsets the Clown\n(?) Affects Pokémon Items", - "selected": "Dismal dodger, you deny a delightful duel?\nFeel my fury!", - "selected_2": "The clown's {{blacephalonName}} uses Trick!\nAll of your {{switchPokemon}}'s items were randomly swapped!", - "selected_3": "Flustered fool, fall for my flawless deception!" - }, - "3": { - "label": "Return the Insults", - "tooltip": "(-) Upsets the Clown\n(?) Affects Pokémon Types", - "selected": "Dismal dodger, you deny a delightful duel?\nFeel my fury!", - "selected_2": "The clown's {{blacephalonName}} uses a strange move!\nAll of your team's types were randomly swapped!", - "selected_3": "Flustered fool, fall for my flawless deception!" - } - }, - "outro": "The clown and his cohorts\ndisappear in a puff of smoke." -} \ No newline at end of file diff --git a/src/locales/en/mystery-encounters/dancing-lessons-dialogue.json b/src/locales/en/mystery-encounters/dancing-lessons-dialogue.json deleted file mode 100644 index 8e2883ecb16..00000000000 --- a/src/locales/en/mystery-encounters/dancing-lessons-dialogue.json +++ /dev/null @@ -1,27 +0,0 @@ -{ - "intro": "An {{oricorioName}} dances sadly alone, without a partner.", - "title": "Dancing Lessons", - "description": "The {{oricorioName}} doesn't seem aggressive, if anything it seems sad.\n\nMaybe it just wants someone to dance with...", - "query": "What will you do?", - "option": { - "1": { - "label": "Battle It", - "tooltip": "(-) Tough Battle\n(+) Gain a Baton", - "selected": "The {{oricorioName}} is distraught and moves to defend itself!", - "boss_enraged": "The {{oricorioName}}'s fear boosted its stats!" - }, - "2": { - "label": "Learn Its Dance", - "tooltip": "(+) Teach a Pokémon Revelation Dance", - "selected": "You watch the {{oricorioName}} closely as it performs its dance...$@s{level_up_fanfare}Your {{selectedPokemon}} learned from the {{oricorioName}}!" - }, - "3": { - "label": "Show It a Dance", - "tooltip": "(-) Teach the {{oricorioName}} a Dance Move\n(+) The {{oricorioName}} Will Like You", - "disabled_tooltip": "Your Pokémon need to know a Dance move for this.", - "select_prompt": "Select a Dance type move to use.", - "selected": "The {{oricorioName}} watches in fascination as\n{{selectedPokemon}} shows off {{selectedMove}}!$It loves the display!$@s{level_up_fanfare}The {{oricorioName}} wants to join your party!" - } - }, - "invalid_selection": "This Pokémon doesn't know a Dance move" -} \ No newline at end of file diff --git a/src/locales/en/mystery-encounters/dark-deal-dialogue.json b/src/locales/en/mystery-encounters/dark-deal-dialogue.json deleted file mode 100644 index 3086ebb0f9b..00000000000 --- a/src/locales/en/mystery-encounters/dark-deal-dialogue.json +++ /dev/null @@ -1,24 +0,0 @@ - - -{ - "intro": "A strange man in a tattered coat\nstands in your way...", - "speaker": "Shady Guy", - "intro_dialogue": "Hey, you!$I've been working on a new device\nto bring out a Pokémon's latent power!$It completely rebinds the Pokémon's atoms\nat a molecular level into a far more powerful form.$Hehe...@d{64} I just need some sac-@d{32}\nErr, test subjects, to prove it works.", - "title": "Dark Deal", - "description": "The disturbing fellow holds up some Pokéballs.\n\"I'll make it worth your while! You can have these strong Pokéballs as payment, All I need is a Pokémon from your team! Hehe...\"", - "query": "What will you do?", - "option": { - "1": { - "label": "Accept", - "tooltip": "(+) 5 Rogue Balls\n(?) Enhance a Random Pokémon", - "selected_dialogue": "Let's see, that {{pokeName}} will do nicely!$Remember, I'm not responsible\nif anything bad happens!@d{32} Hehe...", - "selected_message": "The man hands you 5 Rogue Balls.${{pokeName}} hops into the strange machine...$Flashing lights and weird noises\nstart coming from the machine!$...@d{96} Something emerges\nfrom the device, raging wildly!" - }, - "2": { - "label": "Refuse", - "tooltip": "(-) No Rewards", - "selected": "Not gonna help a poor fellow out?\nPah!" - } - }, - "outro": "After the harrowing encounter,\nyou collect yourself and depart." -} \ No newline at end of file diff --git a/src/locales/en/mystery-encounters/delibirdy-dialogue.json b/src/locales/en/mystery-encounters/delibirdy-dialogue.json deleted file mode 100644 index ca1fefa3a39..00000000000 --- a/src/locales/en/mystery-encounters/delibirdy-dialogue.json +++ /dev/null @@ -1,29 +0,0 @@ - - -{ - "intro": "A pack of {{delibirdName}} have appeared!", - "title": "Delibir-dy", - "description": "The {{delibirdName}}s are looking at you expectantly, as if they want something. Perhaps giving them an item or some money would satisfy them?", - "query": "What will you give them?", - "invalid_selection": "Pokémon doesn't have that kind of item.", - "option": { - "1": { - "label": "Give Money", - "tooltip": "(-) Give the {{delibirdName}}s {{money, money}}\n(+) Receive a Gift Item", - "selected": "You toss the money to the {{delibirdName}}s,\nwho chatter amongst themselves excitedly.$They turn back to you and happily give you a present!" - }, - "2": { - "label": "Give Food", - "tooltip": "(-) Give the {{delibirdName}}s a Berry or Reviver Seed\n(+) Receive a Gift Item", - "select_prompt": "Select an item to give.", - "selected": "You toss the {{chosenItem}} to the {{delibirdName}}s,\nwho chatter amongst themselves excitedly.$They turn back to you and happily give you a present!" - }, - "3": { - "label": "Give an Item", - "tooltip": "(-) Give the {{delibirdName}}s a Held Item\n(+) Receive a Gift Item", - "select_prompt": "Select an item to give.", - "selected": "You toss the {{chosenItem}} to the {{delibirdName}}s,\nwho chatter amongst themselves excitedly.$They turn back to you and happily give you a present!" - } - }, - "outro": "The {{delibirdName}} pack happily waddles off into the distance.$What a curious little exchange!" -} \ No newline at end of file diff --git a/src/locales/en/mystery-encounters/department-store-sale-dialogue.json b/src/locales/en/mystery-encounters/department-store-sale-dialogue.json deleted file mode 100644 index d651f32665a..00000000000 --- a/src/locales/en/mystery-encounters/department-store-sale-dialogue.json +++ /dev/null @@ -1,27 +0,0 @@ -{ - "intro": "It's a lady with a ton of shopping bags.", - "speaker": "Shopper", - "intro_dialogue": "Hello! Are you here for\nthe amazing sales too?$There's a special coupon that you can\nredeem for a free item during the sale!$I have an extra one. Here you go!", - "title": "Department Store Sale", - "description": "There is merchandise in every direction! It looks like there are 4 counters where you can redeem the coupon for various items. The possibilities are endless!", - "query": "Which counter will you go to?", - "option": { - "1": { - "label": "TM Counter", - "tooltip": "(+) TM Shop" - }, - "2": { - "label": "Vitamin Counter", - "tooltip": "(+) Vitamin Shop" - }, - "3": { - "label": "Battle Item Counter", - "tooltip": "(+) X Item Shop" - }, - "4": { - "label": "Pokéball Counter", - "tooltip": "(+) Pokéball Shop" - } - }, - "outro": "What a deal! You should shop there more often." -} \ No newline at end of file diff --git a/src/locales/en/mystery-encounters/field-trip-dialogue.json b/src/locales/en/mystery-encounters/field-trip-dialogue.json deleted file mode 100644 index 61900d56cd7..00000000000 --- a/src/locales/en/mystery-encounters/field-trip-dialogue.json +++ /dev/null @@ -1,31 +0,0 @@ -{ - "intro": "It's a teacher and some school children!", - "speaker": "Teacher", - "intro_dialogue": "Hello, there! Would you be able to\nspare a minute for my students?$I'm teaching them about Pokémon moves\nand would love to show them a demonstration.$Would you mind showing us one of\nthe moves your Pokémon can use?", - "title": "Field Trip", - "description": "A teacher is requesting a move demonstration from a Pokémon. Depending on the move you choose, she might have something useful for you in exchange.", - "query": "Which move category will you show off?", - "option": { - "1": { - "label": "A Physical Move", - "tooltip": "(+) Physical Item Rewards" - }, - "2": { - "label": "A Special Move", - "tooltip": "(+) Special Item Rewards" - }, - "3": { - "label": "A Status Move", - "tooltip": "(+) Status Item Rewards" - }, - "selected": "{{pokeName}} shows off an awesome display of {{move}}!" - }, - "second_option_prompt": "Choose a move for your Pokémon to use.", - "incorrect": "...$That isn't a {{moveCategory}} move!\nI'm sorry, but I can't give you anything.$Come along children, we'll\nfind a better demonstration elsewhere.", - "incorrect_exp": "Looks like you learned a valuable lesson?$Your Pokémon also gained some experience.", - "correct": "Thank you so much for your kindness!\nI hope these items might be of use to you!", - "correct_exp": "{{pokeName}} also gained some valuable experience!", - "status": "Status", - "physical": "Physical", - "special": "Special" -} \ No newline at end of file diff --git a/src/locales/en/mystery-encounters/fiery-fallout-dialogue.json b/src/locales/en/mystery-encounters/fiery-fallout-dialogue.json deleted file mode 100644 index a1644d89a3f..00000000000 --- a/src/locales/en/mystery-encounters/fiery-fallout-dialogue.json +++ /dev/null @@ -1,26 +0,0 @@ -{ - "intro": "You encounter a blistering storm of smoke and ash!", - "title": "Fiery Fallout", - "description": "The whirling ash and embers have cut visibility to nearly zero. It seems like there might be some... source that is causing these conditions. But what could be behind a phenomenon of this magnitude?", - "query": "What will you do?", - "option": { - "1": { - "label": "Find the Source", - "tooltip": "(?) Discover the source\n(-) Hard Battle", - "selected": "You push through the storm, and find two {{volcaronaName}}s in the middle of a mating dance!$They don't take kindly to the interruption and attack!" - }, - "2": { - "label": "Hunker Down", - "tooltip": "(-) Suffer the effects of the weather", - "selected": "The weather effects cause significant\nharm as you struggle to find shelter!$Your party takes 20% Max HP damage!", - "target_burned": "Your {{burnedPokemon}} also became burned!" - }, - "3": { - "label": "Your Fire Types Help", - "tooltip": "(+) End the conditions\n(+) Gain a Charcoal", - "disabled_tooltip": "You need at least 2 Fire Type Pokémon to choose this", - "selected": "Your {{option3PrimaryName}} and {{option3SecondaryName}} guide you to where two {{volcaronaName}}s are in the middle of a mating dance!$Thankfully, your Pokémon are able to calm them,\nand they depart without issue." - } - }, - "found_charcoal": "After the weather clears,\nyour {{leadPokemon}} spots something on the ground.$@s{item_fanfare}{{leadPokemon}} gained a Charcoal!" -} \ No newline at end of file diff --git a/src/locales/en/mystery-encounters/fight-or-flight-dialogue.json b/src/locales/en/mystery-encounters/fight-or-flight-dialogue.json deleted file mode 100644 index 3eb6cb87c16..00000000000 --- a/src/locales/en/mystery-encounters/fight-or-flight-dialogue.json +++ /dev/null @@ -1,25 +0,0 @@ -{ - "intro": "Something shiny is sparkling\non the ground near that Pokémon!", - "title": "Fight or Flight", - "description": "It looks like there's a strong Pokémon guarding an item. Battling is the straightforward approach, but it looks strong. Perhaps you could steal the item, if you have the right Pokémon for the job.", - "query": "What will you do?", - "option": { - "1": { - "label": "Battle the Pokémon", - "tooltip": "(-) Hard Battle\n(+) New Item", - "selected": "You approach the\nPokémon without fear.", - "stat_boost": "The {{enemyPokemon}}'s latent strength boosted one of its stats!" - }, - "2": { - "label": "Steal the Item", - "disabled_tooltip": "Your Pokémon need to know certain moves to choose this", - "tooltip": "(+) {{option2PrimaryName}} uses {{option2PrimaryMove}}", - "selected": ".@d{32}.@d{32}.@d{32}$Your {{option2PrimaryName}} helps you out and uses {{option2PrimaryMove}}!$You nabbed the item!" - }, - "3": { - "label": "Leave", - "tooltip": "(-) No Rewards", - "selected": "You leave the strong Pokémon\nwith its prize and continue on." - } - } -} \ No newline at end of file diff --git a/src/locales/en/mystery-encounters/fun-and-games-dialogue.json b/src/locales/en/mystery-encounters/fun-and-games-dialogue.json deleted file mode 100644 index f5d7d6e8ff8..00000000000 --- a/src/locales/en/mystery-encounters/fun-and-games-dialogue.json +++ /dev/null @@ -1,30 +0,0 @@ -{ - "intro_dialogue": "Step right up, folks! Try your luck\non the brand new {{wobbuffetName}} Whack-o-matic!", - "speaker": "Showman", - "title": "Fun And Games!", - "description": "You've encountered a traveling show with a prize game! You will have @[TOOLTIP_TITLE]{3 turns} to bring the {{wobbuffetName}} as close to @[TOOLTIP_TITLE]{1 HP} as possible @[TOOLTIP_TITLE]{without KOing it} so it can wind up a huge Counter on the bell-ringing machine.\nBut be careful! If you KO the {{wobbuffetName}}, you'll have to pay for the cost of reviving it!", - "query": "Would you like to play?", - "option": { - "1": { - "label": "Play the Game", - "tooltip": "(-) Pay {{option1Money, money}}\n(+) Play {{wobbuffetName}} Whack-o-matic", - "selected": "Time to test your luck!" - }, - "2": { - "label": "Leave", - "tooltip": "(-) No Rewards", - "selected": "You hurry along your way,\nwith a slight feeling of regret." - } - }, - "ko": "Oh no! The {{wobbuffetName}} fainted!$You lose the game and\nhave to pay for the revive cost...", - "charging_continue": "The Wubboffet keeps charging its counter-swing!", - "turn_remaining_3": "Three turns remaining!", - "turn_remaining_2": "Two turns remaining!", - "turn_remaining_1": "One turn remaining!", - "end_game": "Time's up!$The {{wobbuffetName}} winds up to counter-swing and@d{16}.@d{16}.@d{16}.", - "best_result": "The {{wobbuffetName}} smacks the button so hard\nthe bell breaks off the top!$You win the grand prize!", - "great_result": "The {{wobbuffetName}} smacks the button, nearly hitting the bell!$So close!\nYou earn the second tier prize!", - "good_result": "The {{wobbuffetName}} hits the button hard enough to go midway up the scale!$You earn the third tier prize!", - "bad_result": "The {{wobbuffetName}} barely taps the button and nothing happens...$Oh no!\nYou don't win anything!", - "outro": "That was a fun little game!" -} \ No newline at end of file diff --git a/src/locales/en/mystery-encounters/global-trade-system-dialogue.json b/src/locales/en/mystery-encounters/global-trade-system-dialogue.json deleted file mode 100644 index 1cc420355b7..00000000000 --- a/src/locales/en/mystery-encounters/global-trade-system-dialogue.json +++ /dev/null @@ -1,32 +0,0 @@ -{ - "intro": "It's an interface for the Global Trade System!", - "title": "The GTS", - "description": "Ah, the GTS! A technological wonder, you can connect with anyone else around the globe to trade Pokémon with them! Will fortune smile upon your trade today?", - "query": "What will you do?", - "option": { - "1": { - "label": "Check Trade Offers", - "tooltip": "(+) Select a trade offer for one of your Pokémon", - "trade_options_prompt": "Select a Pokémon to receive through trade." - }, - "2": { - "label": "Wonder Trade", - "tooltip": "(+) Send one of your Pokémon to the GTS and get a random Pokémon in return" - }, - "3": { - "label": "Trade an Item", - "trade_options_prompt": "Select an item to send.", - "invalid_selection": "This Pokémon doesn't have legal items to trade.", - "tooltip": "(+) Send one of your Items to the GTS and get a random new Item" - }, - "4": { - "label": "Leave", - "tooltip": "(-) No Rewards", - "selected": "No time to trade today!\nYou continue on." - } - }, - "pokemon_trade_selected": "{{tradedPokemon}} will be sent to {{tradeTrainerName}}.", - "pokemon_trade_goodbye": "Goodbye, {{tradedPokemon}}!", - "item_trade_selected": "{{chosenItem}} will be sent to {{tradeTrainerName}}.$.@d{64}.@d{64}.@d{64}\n@s{level_up_fanfare}Trade complete!$You received a {{itemName}} from {{tradeTrainerName}}!", - "trade_received": "@s{evolution_fanfare}{{tradeTrainerName}} sent over {{received}}!" -} \ No newline at end of file diff --git a/src/locales/en/mystery-encounters/lost-at-sea-dialogue.json b/src/locales/en/mystery-encounters/lost-at-sea-dialogue.json deleted file mode 100644 index 41709c66799..00000000000 --- a/src/locales/en/mystery-encounters/lost-at-sea-dialogue.json +++ /dev/null @@ -1,28 +0,0 @@ -{ - "intro": "Wandering aimlessly through the sea, you've effectively gotten nowhere.", - "title": "Lost at Sea", - "description": "The sea is turbulent in this area, and you're running out of energy.\nThis is bad. Is there a way out of the situation?", - "query": "What will you do?", - "option": { - "1": { - "label": "{{option1PrimaryName}} Might Help", - "label_disabled": "Can't {{option1RequiredMove}}", - "tooltip": "(+) {{option1PrimaryName}} saves you\n(+) {{option1PrimaryName}} gains some EXP", - "tooltip_disabled": "You have no Pokémon to {{option1RequiredMove}} on", - "selected": "{{option1PrimaryName}} swims ahead, guiding you back on track.${{option1PrimaryName}} seems to also have gotten stronger in this time of need!" - }, - "2": { - "label": "{{option2PrimaryName}} Might Help", - "label_disabled": "Can't {{option2RequiredMove}}", - "tooltip": "(+) {{option2PrimaryName}} saves you\n(+) {{option2PrimaryName}} gains some EXP", - "tooltip_disabled": "You have no Pokémon to {{option2RequiredMove}} with", - "selected": "{{option2PrimaryName}} flies ahead of your boat, guiding you back on track.${{option2PrimaryName}} seems to also have gotten stronger in this time of need!" - }, - "3": { - "label": "Wander Aimlessly", - "tooltip": "(-) Each of your Pokémon lose {{damagePercentage}}% of their total HP", - "selected": "You float about in the boat, steering without direction until you finally spot a landmark you remember.$You and your Pokémon are fatigued from the whole ordeal." - } - }, - "outro": "You are back on track." -} \ No newline at end of file diff --git a/src/locales/en/mystery-encounters/mysterious-challengers-dialogue.json b/src/locales/en/mystery-encounters/mysterious-challengers-dialogue.json deleted file mode 100644 index 01f4e6092eb..00000000000 --- a/src/locales/en/mystery-encounters/mysterious-challengers-dialogue.json +++ /dev/null @@ -1,22 +0,0 @@ -{ - "intro": "Mysterious challengers have appeared!", - "title": "Mysterious Challengers", - "description": "If you defeat a challenger, you might impress them enough to receive a boon. But some look tough, are you up to the challenge?", - "query": "Who will you battle?", - "option": { - "1": { - "label": "A Clever, Mindful Foe", - "tooltip": "(-) Standard Battle\n(+) Move Item Rewards" - }, - "2": { - "label": "A Strong Foe", - "tooltip": "(-) Hard Battle\n(+) Good Rewards" - }, - "3": { - "label": "The Mightiest Foe", - "tooltip": "(-) Brutal Battle\n(+) Great Rewards" - }, - "selected": "The trainer steps forward..." - }, - "outro": "The mysterious challenger was defeated!" -} \ No newline at end of file diff --git a/src/locales/en/mystery-encounters/mysterious-chest-dialogue.json b/src/locales/en/mystery-encounters/mysterious-chest-dialogue.json deleted file mode 100644 index 1de7a5992ed..00000000000 --- a/src/locales/en/mystery-encounters/mysterious-chest-dialogue.json +++ /dev/null @@ -1,23 +0,0 @@ -{ - "intro": "You found...@d{32} a chest?", - "title": "The Mysterious Chest", - "description": "A beautifully ornamented chest stands on the ground. There must be something good inside... right?", - "query": "Will you open it?", - "option": { - "1": { - "label": "Open It", - "tooltip": "@[SUMMARY_BLUE]{(35%) Something terrible}\n@[SUMMARY_GREEN]{(40%) Okay Rewards}\n@[SUMMARY_GREEN]{(20%) Good Rewards}\n@[SUMMARY_GREEN]{(4%) Great Rewards}\n@[SUMMARY_GREEN]{(1%) Amazing Rewards}", - "selected": "You open the chest to find...", - "normal": "Just some normal tools and items.", - "good": "Some pretty nice tools and items.", - "great": "A couple great tools and items!", - "amazing": "Whoa! An amazing item!", - "bad": "Oh no!@d{32}\nThe chest was actually a {{gimmighoulName}} in disguise!$Your {{pokeName}} jumps in front of you\nbut is KOed in the process!" - }, - "2": { - "label": "Too Risky, Leave", - "tooltip": "(-) No Rewards", - "selected": "You hurry along your way,\nwith a slight feeling of regret." - } - } -} \ No newline at end of file diff --git a/src/locales/en/mystery-encounters/part-timer-dialogue.json b/src/locales/en/mystery-encounters/part-timer-dialogue.json deleted file mode 100644 index 614f1818e3f..00000000000 --- a/src/locales/en/mystery-encounters/part-timer-dialogue.json +++ /dev/null @@ -1,31 +0,0 @@ -{ - "intro": "A busy worker flags you down.", - "speaker": "Worker", - "intro_dialogue": "You look like someone with lots of capable Pokémon!$We can pay you if you're able to help us with some part-time work!", - "title": "Part-Timer", - "description": "Looks like there are plenty of tasks that need to be done. Depending how well-suited your Pokémon is to a task, they might earn more or less money.", - "query": "Which job will you choose?", - "invalid_selection": "Pokémon must be healthy enough.", - "option": { - "1": { - "label": "Make Deliveries", - "tooltip": "(-) Your Pokémon Uses its Speed\n(+) Earn @[MONEY]{Money}", - "selected": "Your {{selectedPokemon}} works a shift delivering orders to customers." - }, - "2": { - "label": "Warehouse Work", - "tooltip": "(-) Your Pokémon Uses its Strength and Endurance\n(+) Earn @[MONEY]{Money}", - "selected": "Your {{selectedPokemon}} works a shift moving items around the warehouse." - }, - "3": { - "label": "Sales Assistant", - "tooltip": "(-) Your {{option3PrimaryName}} uses {{option3PrimaryMove}}\n(+) Earn @[MONEY]{Money}", - "disabled_tooltip": "Your Pokémon need to know certain moves for this job", - "selected": "Your {{option3PrimaryName}} spends the day using {{option3PrimaryMove}} to attract customers to the business!" - } - }, - "job_complete_good": "Thanks for the assistance!\nYour {{selectedPokemon}} was incredibly helpful!$Here's your check for the day.", - "job_complete_bad": "Your {{selectedPokemon}} helped us out a bit!$Here's your check for the day.", - "pokemon_tired": "Your {{selectedPokemon}} is worn out!\nThe PP of all its moves was reduced to 2!", - "outro": "Come back and help out again sometime!" -} \ No newline at end of file diff --git a/src/locales/en/mystery-encounters/safari-zone-dialogue.json b/src/locales/en/mystery-encounters/safari-zone-dialogue.json deleted file mode 100644 index 8869f2055e5..00000000000 --- a/src/locales/en/mystery-encounters/safari-zone-dialogue.json +++ /dev/null @@ -1,46 +0,0 @@ -{ - "intro": "It's a safari zone!", - "title": "The Safari Zone", - "description": "There are all kinds of rare and special Pokémon that can be found here!\nIf you choose to enter, you'll have a time limit of 3 wild encounters where you can try to catch these special Pokémon.\n\nBeware, though. These Pokémon may flee before you're able to catch them!", - "query": "Would you like to enter?", - "option": { - "1": { - "label": "Enter", - "tooltip": "(-) Pay {{option1Money, money}}\n@[SUMMARY_GREEN]{(?) Safari Zone}", - "selected": "Time to test your luck!" - }, - "2": { - "label": "Leave", - "tooltip": "(-) No Rewards", - "selected": "You hurry along your way,\nwith a slight feeling of regret." - } - }, - "safari": { - "1": { - "label": "Throw a Pokéball", - "tooltip": "(+) Throw a Pokéball", - "selected": "You throw a Pokéball!" - }, - "2": { - "label": "Throw Bait", - "tooltip": "(+) Increases Capture Rate\n(-) Chance to Increase Flee Rate", - "selected": "You throw some bait!" - }, - "3": { - "label": "Throw Mud", - "tooltip": "(+) Decreases Flee Rate\n(-) Chance to Decrease Capture Rate", - "selected": "You throw some mud!" - }, - "4": { - "label": "Flee", - "tooltip": "(?) Flee from this Pokémon" - }, - "watching": "{{pokemonName}} is watching carefully!", - "eating": "{{pokemonName}} is eating!", - "busy_eating": "{{pokemonName}} is busy eating!", - "angry": "{{pokemonName}} is angry!", - "beside_itself_angry": "{{pokemonName}} is beside itself with anger!", - "remaining_count": "{{remainingCount}} Pokémon remaining!" - }, - "outro": "That was a fun little excursion!" -} \ No newline at end of file diff --git a/src/locales/en/mystery-encounters/shady-vitamin-dealer-dialogue.json b/src/locales/en/mystery-encounters/shady-vitamin-dealer-dialogue.json deleted file mode 100644 index d0003de07f1..00000000000 --- a/src/locales/en/mystery-encounters/shady-vitamin-dealer-dialogue.json +++ /dev/null @@ -1,27 +0,0 @@ -{ - "intro": "A man in a dark coat approaches you.", - "speaker": "Shady Salesman", - "intro_dialogue": ".@d{16}.@d{16}.@d{16}$I've got the goods if you've got the money.$Make sure your Pokémon can handle it though.", - "title": "The Vitamin Dealer", - "description": "The man opens his jacket to reveal some Pokémon vitamins. The numbers he quotes seem like a really good deal. Almost too good...\nHe offers two package deals to choose from.", - "query": "Which deal will you choose?", - "invalid_selection": "Pokémon must be healthy enough.", - "option": { - "1": { - "label": "The Cheap Deal", - "tooltip": "(-) Pay {{option1Money, money}}\n(-) Side Effects?\n(+) Chosen Pokémon Gains 2 Random Vitamins" - }, - "2": { - "label": "The Pricey Deal", - "tooltip": "(-) Pay {{option2Money, money}}\n(+) Chosen Pokémon Gains 2 Random Vitamins" - }, - "3": { - "label": "Leave", - "tooltip": "(-) No Rewards", - "selected": "Heh, wouldn't have figured you for a coward." - }, - "selected": "The man hands you two bottles and quickly disappears.${{selectedPokemon}} gained {{boost1}} and {{boost2}} boosts!" - }, - "cheap_side_effects": "But the medicine had some side effects!$Your {{selectedPokemon}} takes some damage,\nand its Nature is changed to {{newNature}}!", - "no_bad_effects": "Looks like there were no side-effects from the medicine!" -} \ No newline at end of file diff --git a/src/locales/en/mystery-encounters/slumbering-snorlax-dialogue.json b/src/locales/en/mystery-encounters/slumbering-snorlax-dialogue.json deleted file mode 100644 index cd3bb7465c4..00000000000 --- a/src/locales/en/mystery-encounters/slumbering-snorlax-dialogue.json +++ /dev/null @@ -1,25 +0,0 @@ -{ - "intro": "As you walk down a narrow pathway, you see a towering silhouette blocking your path.$You get closer to see a {{snorlaxName}} sleeping peacefully.\nIt seems like there's no way around it.", - "title": "Slumbering {{snorlaxName}}", - "description": "You could attack it to try and get it to move, or simply wait for it to wake up. Who knows how long that could take, though...", - "query": "What will you do?", - "option": { - "1": { - "label": "Battle It", - "tooltip": "(-) Fight Sleeping {{snorlaxName}}\n(+) Special Reward", - "selected": "You approach the\nPokémon without fear." - }, - "2": { - "label": "Wait for It to Move", - "tooltip": "(-) Wait a Long Time\n(+) Recover Party", - "selected": ".@d{32}.@d{32}.@d{32}$You wait for a time, but the {{snorlaxName}}'s yawns make your party sleepy...", - "rest_result": "When you all awaken, the {{snorlaxName}} is no where to be found -\nbut your Pokémon are all healed!" - }, - "3": { - "label": "Steal Its Item", - "tooltip": "(+) {{option3PrimaryName}} uses {{option3PrimaryMove}}\n(+) Special Reward", - "disabled_tooltip": "Your Pokémon need to know certain moves to choose this", - "selected": "Your {{option3PrimaryName}} uses {{option3PrimaryMove}}!$@s{item_fanfare}It steals Leftovers off the sleeping\n{{snorlaxName}} and you make out like bandits!" - } - } -} \ No newline at end of file diff --git a/src/locales/en/mystery-encounters/teleporting-hijinks-dialogue.json b/src/locales/en/mystery-encounters/teleporting-hijinks-dialogue.json deleted file mode 100644 index c295867f521..00000000000 --- a/src/locales/en/mystery-encounters/teleporting-hijinks-dialogue.json +++ /dev/null @@ -1,27 +0,0 @@ -{ - "intro": "It's a strange machine, whirring noisily...", - "title": "Teleportating Hijinks", - "description": "The machine has a sign on it that reads:\n \"To use, insert money then step into the capsule.\"\n\nPerhaps it can transport you somewhere...", - "query": "What will you do?", - "option": { - "1": { - "label": "Put Money In", - "tooltip": "(-) Pay {{price, money}}\n(?) Teleport to New Biome", - "selected": "You insert some money, and the capsule opens.\nYou step inside..." - }, - "2": { - "label": "A Pokémon Helps", - "tooltip": "(-) {{option2PrimaryName}} Helps\n(+) {{option2PrimaryName}} gains EXP\n(?) Teleport to New Biome", - "disabled_tooltip": "You need a Steel or Electric Type Pokémon to choose this", - "selected": "{{option2PrimaryName}}'s Type allows it to bypass the machine's paywall!$The capsule opens, and you step inside..." - }, - "3": { - "label": "Inspect the Machine", - "tooltip": "(-) Pokémon Battle", - "selected": "You are drawn in by the blinking lights\nand strange noises coming from the machine...$You don't even notice as a wild\nPokémon sneaks up and ambushes you!" - } - }, - "transport": "The machine shakes violently,\nmaking all sorts of strange noises!$Just as soon as it had started, it quiets once more.", - "attacked": "You step out into a completely new area, startling a wild Pokémon!$The wild Pokémon attacks!", - "boss_enraged": "The opposing {{enemyPokemon}} has become enraged!" -} \ No newline at end of file diff --git a/src/locales/en/mystery-encounters/the-pokemon-salesman-dialogue.json b/src/locales/en/mystery-encounters/the-pokemon-salesman-dialogue.json deleted file mode 100644 index 7e8091bbfff..00000000000 --- a/src/locales/en/mystery-encounters/the-pokemon-salesman-dialogue.json +++ /dev/null @@ -1,23 +0,0 @@ -{ - "intro": "A chipper elderly man approaches you.", - "speaker": "Gentleman", - "intro_dialogue": "Hello there! Have I got a deal just for YOU!", - "title": "The Pokémon Salesman", - "description": "\"This {{purchasePokemon}} is extremely unique and carries an ability not normally found in its species! I'll let you have this swell {{purchasePokemon}} for just {{price, money}}!\"\n\n\"What do you say?\"", - "description_shiny": "\"This {{purchasePokemon}} is extremely unique and has a pigment not normally found in its species! I'll let you have this swell {{purchasePokemon}} for just {{price, money}}!\"\n\n\"What do you say?\"", - "query": "What will you do?", - "option": { - "1": { - "label": "Accept", - "tooltip": "(-) Pay {{price, money}}\n(+) Gain a {{purchasePokemon}} with its Hidden Ability", - "tooltip_shiny": "(-) Pay {{price, money}}\n(+) Gain a shiny {{purchasePokemon}}", - "selected_message": "You paid an outrageous sum and bought the {{purchasePokemon}}.", - "selected_dialogue": "Excellent choice!$I can see you've a keen eye for business.$Oh, yeah...@d{64} Returns not accepted, got that?" - }, - "2": { - "label": "Refuse", - "tooltip": "(-) No Rewards", - "selected": "No?@d{32} You say no?$I'm only doing this as a favor to you!" - } - } -} \ No newline at end of file diff --git a/src/locales/en/mystery-encounters/the-strong-stuff-dialogue.json b/src/locales/en/mystery-encounters/the-strong-stuff-dialogue.json deleted file mode 100644 index b5403616c9b..00000000000 --- a/src/locales/en/mystery-encounters/the-strong-stuff-dialogue.json +++ /dev/null @@ -1,21 +0,0 @@ -{ - "intro": "It's a massive {{shuckleName}} and what appears\nto be a large stash of... juice?", - "title": "The Strong Stuff", - "description": "The {{shuckleName}} that blocks your path looks incredibly strong. Meanwhile, the juice next to it is emanating power of some kind.\n\nThe {{shuckleName}} extends its feelers in your direction. It seems like it wants to do something...", - "query": "What will you do?", - "option": { - "1": { - "label": "Approach the {{shuckleName}}", - "tooltip": "(?) Something awful or amazing might happen", - "selected": "You black out.", - "selected_2": "@f{150}When you awaken, the {{shuckleName}} is gone\nand juice stash completely drained.${{highBstPokemon1}} and {{highBstPokemon2}}\nfeel a terrible lethargy come over them!$Their base stats were reduced by {{reductionValue}}!$Your remaining Pokémon feel an incredible vigor, though!\nTheir base stats are increased by {{increaseValue}}!" - }, - "2": { - "label": "Battle the {{shuckleName}}", - "tooltip": "(-) Hard Battle\n(+) Special Rewards", - "selected": "Enraged, the {{shuckleName}} drinks some of its juice and attacks!", - "stat_boost": "The {{shuckleName}}'s juice boosts its stats!" - } - }, - "outro": "What a bizarre turn of events." -} \ No newline at end of file diff --git a/src/locales/en/mystery-encounters/the-winstrate-challenge-dialogue.json b/src/locales/en/mystery-encounters/the-winstrate-challenge-dialogue.json deleted file mode 100644 index 37807a91667..00000000000 --- a/src/locales/en/mystery-encounters/the-winstrate-challenge-dialogue.json +++ /dev/null @@ -1,22 +0,0 @@ -{ - "intro": "It's a family standing outside their house!", - "speaker": "The Winstrates", - "intro_dialogue": "We're the Winstrates!$What do you say to taking on our family in a series of Pokémon battles?", - "title": "The Winstrate Challenge", - "description": "The Winstrates are a family of 5 trainers, and they want to battle! If you beat all of them back-to-back, they'll give you a grand prize. But can you handle the heat?", - "query": "What will you do?", - "option": { - "1": { - "label": "Accept the Challenge", - "tooltip": "(-) Brutal Battle\n(+) Special Item Reward", - "selected": "Let the challenge begin!" - }, - "2": { - "label": "Refuse the Challenge", - "tooltip": "(+) Full Heal Party\n(+) Gain a Rarer Candy", - "selected": "That's too bad. Say, your team looks worn out, why don't you stay awhile and rest?" - } - }, - "victory": "Congratulations on beating our challenge!$First off, we'd like you to have this Voucher.", - "victory_2": "Also, our family uses this Macho Brace to strengthen\nour Pokémon more effectively during training.$You may not need it considering that you beat the whole lot of us, but we hope you'll accept it anyway!" -} \ No newline at end of file diff --git a/src/locales/en/mystery-encounters/training-session-dialogue.json b/src/locales/en/mystery-encounters/training-session-dialogue.json deleted file mode 100644 index f018018fe4e..00000000000 --- a/src/locales/en/mystery-encounters/training-session-dialogue.json +++ /dev/null @@ -1,33 +0,0 @@ -{ - "intro": "You've come across some\ntraining tools and supplies.", - "title": "Training Session", - "description": "These supplies look like they could be used to train a member of your party! There are a few ways you could train your Pokémon, by battling against it with the rest of your team.", - "query": "How should you train?", - "invalid_selection": "Pokémon must be healthy enough.", - "option": { - "1": { - "label": "Light Training", - "tooltip": "(-) Light Battle\n(+) Improve 2 Random IVs of Pokémon", - "finished": "{{selectedPokemon}} returns, feeling\nworn out but accomplished!$Its {{stat1}} and {{stat2}} IVs were improved!" - }, - "2": { - "label": "Moderate Training", - "tooltip": "(-) Moderate Battle\n(+) Change Pokémon's Nature", - "select_prompt": "Select a new nature\nto train your Pokémon in.", - "finished": "{{selectedPokemon}} returns, feeling\nworn out but accomplished!$Its nature was changed to {{nature}}!" - }, - "3": { - "label": "Heavy Training", - "tooltip": "(-) Harsh Battle\n(+) Change Pokémon's Ability", - "select_prompt": "Select a new ability\nto train your Pokémon in.", - "finished": "{{selectedPokemon}} returns, feeling\nworn out but accomplished!$Its ability was changed to {{ability}}!" - }, - "4": { - "label": "Leave", - "tooltip": "(-) No Rewards", - "selected": "You've no time for training.\nTime to move on." - }, - "selected": "{{selectedPokemon}} moves across\nthe clearing to face you..." - }, - "outro": "That was a successful training session!" -} \ No newline at end of file diff --git a/src/locales/en/mystery-encounters/trash-to-treasure-dialogue.json b/src/locales/en/mystery-encounters/trash-to-treasure-dialogue.json deleted file mode 100644 index fe2cb54f5b1..00000000000 --- a/src/locales/en/mystery-encounters/trash-to-treasure-dialogue.json +++ /dev/null @@ -1,19 +0,0 @@ -{ - "intro": "It's a massive pile of garbage!\nWhere did this come from?", - "title": "Trash to Treasure", - "description": "The garbage heap looms over you, and you can spot some items of value buried amidst the refuse. Are you sure you want to get covered in filth to get them, though?", - "query": "What will you do?", - "option": { - "1": { - "label": "Dig for Valuables", - "tooltip": "(-) Items in Shops Cost 3x\n(+) Gain Amazing Items", - "selected": "You wade through the garbage pile, becoming mired in filth.$There's no way any respectable shopkeeper would\nsell you items at the normal rate in your grimy state!$You'll have to pay extra for items now.$However, you found some incredible items in the garbage!" - }, - "2": { - "label": "Investigate Further", - "tooltip": "(?) Find the Source of the Garbage", - "selected": "You wander around the heap, searching for any indication as to how this might have appeared here...", - "selected_2": "Suddenly, the garbage shifts! It wasn't just garbage, it was a Pokémon!" - } - } -} \ No newline at end of file diff --git a/src/locales/en/mystery-encounters/uncommon-breed-dialogue.json b/src/locales/en/mystery-encounters/uncommon-breed-dialogue.json deleted file mode 100644 index e6f5b3d3fcd..00000000000 --- a/src/locales/en/mystery-encounters/uncommon-breed-dialogue.json +++ /dev/null @@ -1,26 +0,0 @@ -{ - "intro": "That isn't just an ordinary Pokémon!", - "title": "Uncommon Breed", - "description": "That {{enemyPokemon}} looks special compared to others of its kind. @[TOOLTIP_TITLE]{Perhaps it knows a special move?} You could battle and catch it outright, but there might also be a way to befriend it.", - "query": "What will you do?", - "option": { - "1": { - "label": "Battle the Pokémon", - "tooltip": "(-) Tricky Battle\n(+) Strong Catchable Foe", - "selected": "You approach the\n{{enemyPokemon}} without fear.", - "stat_boost": "The {{enemyPokemon}}'s heightened abilities boost its stats!" - }, - "2": { - "label": "Give It Food", - "disabled_tooltip": "You need 4 berry items to choose this", - "tooltip": "(-) Give 4 Berries\n(+) The {{enemyPokemon}} Likes You", - "selected": "You toss the berries at the {{enemyPokemon}}!$It eats them happily!$The {{enemyPokemon}} wants to join your party!" - }, - "3": { - "label": "Befriend It", - "disabled_tooltip": "Your Pokémon need to know certain moves to choose this", - "tooltip": "(+) {{option3PrimaryName}} uses {{option3PrimaryMove}}\n(+) The {{enemyPokemon}} Likes You", - "selected": "Your {{option3PrimaryName}} uses {{option3PrimaryMove}} to charm the {{enemyPokemon}}!$The {{enemyPokemon}} wants to join your party!" - } - } -} \ No newline at end of file diff --git a/src/locales/en/mystery-encounters/weird-dream-dialogue.json b/src/locales/en/mystery-encounters/weird-dream-dialogue.json deleted file mode 100644 index 44acde84002..00000000000 --- a/src/locales/en/mystery-encounters/weird-dream-dialogue.json +++ /dev/null @@ -1,22 +0,0 @@ -{ - "intro": "A shadowy woman blocks your path.\nSomething about her is unsettling...", - "speaker": "Woman", - "intro_dialogue": "I have seen your futures, your pasts...$Child, do you see them too?", - "title": "???", - "description": "The woman's words echo in your head. It wasn't just a singular voice, but a vast multitude, from all timelines and realities. You begin to feel dizzy, the question lingering on your mind...\n\n@[TOOLTIP_TITLE]{\"I have seen your futures, your pasts... Child, do you see them too?\"}", - "query": "What will you do?", - "option": { - "1": { - "label": "\"I See Them\"", - "tooltip": "@[SUMMARY_GREEN]{(?) Affects your Pokémon}", - "selected": "Her hand reaches out to touch you,\nand everything goes black.$Then...@d{64} You see everything.\nEvery timeline, all your different selves,\n past and future.$Everything that has made you,\neverything you will become...@d{64}", - "cutscene": "You see your Pokémon,@d{32} converging from\nevery reality to become something new...@d{64}", - "dream_complete": "When you awaken, the woman - was it a woman or a ghost? - is gone...$.@d{32}.@d{32}.@d{32}$Your Pokémon team has changed...\nOr is it the same team you've always had?" - }, - "2": { - "label": "Quickly Leave", - "tooltip": "(-) Affects your Pokémon", - "selected": "You tear your mind from a numbing grip, and hastily depart.$When you finally stop to collect yourself, you check the Pokémon in your team.$For some reason, all of their levels have decreased!" - } - } -} \ No newline at end of file diff --git a/src/locales/en/nature.json b/src/locales/en/nature.json deleted file mode 100644 index ad740557094..00000000000 --- a/src/locales/en/nature.json +++ /dev/null @@ -1,27 +0,0 @@ -{ - "Hardy": "Hardy", - "Lonely": "Lonely", - "Brave": "Brave", - "Adamant": "Adamant", - "Naughty": "Naughty", - "Bold": "Bold", - "Docile": "Docile", - "Relaxed": "Relaxed", - "Impish": "Impish", - "Lax": "Lax", - "Timid": "Timid", - "Hasty": "Hasty", - "Serious": "Serious", - "Jolly": "Jolly", - "Naive": "Naive", - "Modest": "Modest", - "Mild": "Mild", - "Quiet": "Quiet", - "Bashful": "Bashful", - "Rash": "Rash", - "Calm": "Calm", - "Gentle": "Gentle", - "Sassy": "Sassy", - "Careful": "Careful", - "Quirky": "Quirky" -} \ No newline at end of file diff --git a/src/locales/en/party-ui-handler.json b/src/locales/en/party-ui-handler.json deleted file mode 100644 index 8e6e8046c7e..00000000000 --- a/src/locales/en/party-ui-handler.json +++ /dev/null @@ -1,50 +0,0 @@ -{ - "SEND_OUT": "Send Out", - "SUMMARY": "Summary", - "CANCEL": "Cancel", - "RELEASE": "Release", - "APPLY": "Apply", - "TEACH": "Teach", - "SPLICE": "Splice", - "UNSPLICE": "Unsplice", - "ACTIVATE": "Activate", - "DEACTIVATE": "Deactivate", - "TRANSFER": "Transfer", - "ALL": "All", - "PASS_BATON": "Pass Baton", - "UNPAUSE_EVOLUTION": "Unpause Evolution", - "PAUSE_EVOLUTION": "Pause Evolution", - "REVIVE": "Revive", - "RENAME": "Rename", - "SELECT": "Select", - "choosePokemon": "Choose a Pokémon.", - "doWhatWithThisPokemon": "Do what with this Pokémon?", - "noEnergy": "{{pokemonName}} has no energy\nleft to battle!", - "hasEnergy": "{{pokemonName}} still has energy\nto battle!", - "cantBeUsed": "{{pokemonName}} can't be used in\nthis challenge!", - "tooManyItems": "{{pokemonName}} has too many\nof this item!", - "anyEffect": "It won't have any effect.", - "unpausedEvolutions": "Evolutions have been unpaused for {{pokemonName}}.", - "pausedEvolutions": "Evolutions have been paused for {{pokemonName}}.", - "unspliceConfirmation": "Do you really want to unsplice {{fusionName}}\nfrom {{pokemonName}}? {{fusionName}} will be lost.", - "wasReverted": "{{fusionName}} was reverted to {{pokemonName}}.", - "releaseConfirmation": "Do you really want to release {{pokemonName}}?", - "releaseInBattle": "You can't release a Pokémon that's in battle!", - "selectAMove": "Select a move.", - "changeQuantity": "Select a held item to transfer.\nUse < and > to change the quantity.", - "selectAnotherPokemonToSplice": "Select another Pokémon to splice.", - "cancel": "Cancel", - "able": "Able", - "notAble": "Not able", - "learned": "Learned", - "goodbye": "Goodbye, {{pokemonName}}!", - "byebye": "Byebye, {{pokemonName}}!", - "farewell": "Farewell, {{pokemonName}}!", - "soLong": "So long, {{pokemonName}}!", - "thisIsWhereWePart": "This is where we part, {{pokemonName}}!", - "illMissYou": "I'll miss you, {{pokemonName}}!", - "illNeverForgetYou": "I'll never forget you, {{pokemonName}}!", - "untilWeMeetAgain": "Until we meet again, {{pokemonName}}!", - "sayonara": "Sayonara, {{pokemonName}}!", - "smellYaLater": "Smell ya later, {{pokemonName}}!" -} \ No newline at end of file diff --git a/src/locales/en/pokeball.json b/src/locales/en/pokeball.json deleted file mode 100644 index 8fa7a8d726b..00000000000 --- a/src/locales/en/pokeball.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "pokeBall": "Poké Ball", - "greatBall": "Great Ball", - "ultraBall": "Ultra Ball", - "rogueBall": "Rogue Ball", - "masterBall": "Master Ball", - "luxuryBall": "Luxury Ball" -} \ No newline at end of file diff --git a/src/locales/en/pokemon-form-battle.json b/src/locales/en/pokemon-form-battle.json deleted file mode 100644 index 63a7fb793bd..00000000000 --- a/src/locales/en/pokemon-form-battle.json +++ /dev/null @@ -1,14 +0,0 @@ -{ - "mega": "Mega {{pokemonName}}", - "mega-x": "Mega {{pokemonName}} X", - "mega-y": "Mega {{pokemonName}} Y", - "primal": "Primal {{pokemonName}}", - "gigantamax": "G-Max {{pokemonName}}", - "eternamax": "E-Max {{pokemonName}}", - "megaChange": "{{preName}} Mega Evolved\ninto {{pokemonName}}!", - "gigantamaxChange": "{{preName}} Gigantamaxed\ninto {{pokemonName}}!", - "eternamaxChange": "{{preName}} Eternamaxed\ninto {{pokemonName}}!", - "revertChange": "{{pokemonName}} reverted\nto its original form!", - "formChange": "{{preName}} changed form!", - "disguiseChange": "Its disguise served it as a decoy!" -} \ No newline at end of file diff --git a/src/locales/en/pokemon-form.json b/src/locales/en/pokemon-form.json deleted file mode 100644 index ea7e0f60c90..00000000000 --- a/src/locales/en/pokemon-form.json +++ /dev/null @@ -1,170 +0,0 @@ -{ - "pikachuCosplay": "Cosplay", - "pikachuCoolCosplay": "Cool Cosplay", - "pikachuBeautyCosplay": "Beauty Cosplay", - "pikachuCuteCosplay": "Cute Cosplay", - "pikachuSmartCosplay": "Smart Cosplay", - "pikachuToughCosplay": "Tough Cosplay", - "pikachuPartner": "Partner", - "eeveePartner": "Partner", - "pichuSpiky": "Spiky", - "unownA": "A", - "unownB": "B", - "unownC": "C", - "unownD": "D", - "unownE": "E", - "unownF": "F", - "unownG": "G", - "unownH": "H", - "unownI": "I", - "unownJ": "J", - "unownK": "K", - "unownL": "L", - "unownM": "M", - "unownN": "N", - "unownO": "O", - "unownP": "P", - "unownQ": "Q", - "unownR": "R", - "unownS": "S", - "unownT": "T", - "unownU": "U", - "unownV": "V", - "unownW": "W", - "unownX": "X", - "unownY": "Y", - "unownZ": "Z", - "unownExclamation": "!", - "unownQuestion": "?", - "castformSunny": "Sunny", - "castformRainy": "Rainy", - "castformSnowy": "Snowy", - "deoxysNormal": "Normal", - "burmyPlant": "Plant", - "burmySandy": "Sandy", - "burmyTrash": "Trash", - "shellosEast": "East", - "shellosWest": "West", - "rotomHeat": "Heat", - "rotomWash": "Wash", - "rotomFrost": "Frost", - "rotomFan": "Fan", - "rotomMow": "Mow", - "giratinaAltered": "Altered", - "shayminLand": "Land", - "basculinRedStriped": "Red Striped", - "basculinBlueStriped": "Blue Striped", - "basculinWhiteStriped": "White Striped", - "deerlingSpring": "Spring", - "deerlingSummer": "Summer", - "deerlingAutumn": "Autumn", - "deerlingWinter": "Winter", - "tornadusIncarnate": "Incarnate", - "thundurusIncarnate": "Incarnate", - "landorusIncarnate": "Incarnate", - "keldeoOrdinary": "Ordinary", - "meloettaAria": "Aria", - "meloettaPirouette": "Pirouette", - "froakieBattleBond": "Battle Bond", - "scatterbugMeadow": "Meadow", - "scatterbugIcySnow": "Icy Snow", - "scatterbugPolar": "Polar", - "scatterbugTundra": "Tundra", - "scatterbugContinental": "Continental", - "scatterbugGarden": "Garden", - "scatterbugElegant": "Elegant", - "scatterbugModern": "Modern", - "scatterbugMarine": "Marine", - "scatterbugArchipelago": "Archipelago", - "scatterbugHighPlains": "High Plains", - "scatterbugSandstorm": "Sandstorm", - "scatterbugRiver": "River", - "scatterbugMonsoon": "Monsoon", - "scatterbugSavanna": "Savanna", - "scatterbugSun": "Sun", - "scatterbugOcean": "Ocean", - "scatterbugJungle": "Jungle", - "scatterbugFancy": "Fancy", - "scatterbugPokeBall": "Poké Ball", - "flabebeRed": "Red", - "flabebeYellow": "Yellow", - "flabebeOrange": "Orange", - "flabebeBlue": "Blue", - "flabebeWhite": "White", - "furfrouHeart": "Heart", - "furfrouStar": "Star", - "furfrouDiamond": "Diamond", - "furfrouDebutante": "Debutante", - "furfrouMatron": "Matron", - "furfrouDandy": "Dandy", - "furfrouLaReine": "La Reine", - "furfrouKabuki": "Kabuki", - "furfrouPharaoh": "Pharaoh", - "pumpkabooSmall": "Small", - "pumpkabooLarge": "Large", - "pumpkabooSuper": "Super", - "xerneasNeutral": "Neutral", - "xerneasActive": "Active", - "zygarde50": "50% Forme", - "zygarde10": "10% Forme", - "zygarde50Pc": "50% Forme Power Construct", - "zygarde10Pc": "10% Forme Power Construct", - "zygardeComplete": "Complete Forme", - "oricorioBaile": "Baile", - "oricorioPompom": "Pom-Pom", - "oricorioPau": "Pau", - "oricorioSensu": "Sensu", - "rockruffOwnTempo": "Own Tempo", - "miniorRedMeteor": "Red Meteor", - "miniorOrangeMeteor": "Orange Meteor", - "miniorYellowMeteor": "Yellow Meteor", - "miniorGreenMeteor": "Green Meteor", - "miniorBlueMeteor": "Blue Meteor", - "miniorIndigoMeteor": "Indigo Meteor", - "miniorVioletMeteor": "Violet Meteor", - "miniorRed": "Red", - "miniorOrange": "Orange", - "miniorYellow": "Yellow", - "miniorGreen": "Green", - "miniorBlue": "Blue", - "miniorIndigo": "Indigo", - "miniorViolet": "Violet", - "mimikyuDisguised": "Disguised", - "mimikyuBusted": "Busted", - "magearnaOriginal": "Original", - "marshadowZenith": "Zenith", - "sinisteaPhony": "Phony", - "sinisteaAntique": "Antique", - "eiscueNoIce": "No Ice", - "indeedeeMale": "Male", - "indeedeeFemale": "Female", - "morpekoFullBelly": "Full Belly", - "zacianHeroOfManyBattles": "Hero Of Many Battles", - "zamazentaHeroOfManyBattles": "Hero Of Many Battles", - "zarudeDada": "Dada", - "enamorusIncarnate": "Incarnate", - "squawkabillyGreenPlumage": "Green Plumage", - "squawkabillyBluePlumage": "Blue Plumage", - "squawkabillyYellowPlumage": "Yellow Plumage", - "squawkabillyWhitePlumage": "White Plumage", - "tatsugiriCurly": "Curly", - "tatsugiriDroopy": "Droopy", - "tatsugiriStretchy": "Stretchy", - "gimmighoulChest": "Chest", - "gimmighoulRoaming": "Roaming", - "koraidonApexBuild": "Apex Build", - "koraidonLimitedBuild": "Limited Build", - "koraidonSprintingBuild": "Sprinting Build", - "koraidonSwimmingBuild": "Swimming Build", - "koraidonGlidingBuild": "Gliding Build", - "miraidonUltimateMode": "Ultimate Mode", - "miraidonLowPowerMode": "Low Power Mode", - "miraidonDriveMode": "Drive Mode", - "miraidonAquaticMode": "Aquatic Mode", - "miraidonGlideMode": "Glide Mode", - "poltchageistCounterfeit": "Counterfeit", - "poltchageistArtisan": "Artisan", - "paldeaTaurosCombat": "Combat", - "paldeaTaurosBlaze": "Blaze", - "paldeaTaurosAqua": "Aqua" -} \ No newline at end of file diff --git a/src/locales/en/pokemon-info-container.json b/src/locales/en/pokemon-info-container.json deleted file mode 100644 index e4574e3cf3f..00000000000 --- a/src/locales/en/pokemon-info-container.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "moveset": "Moveset", - "gender": "Gender:", - "ability": "Ability:", - "nature": "Nature:", - "form": "Form:" -} \ No newline at end of file diff --git a/src/locales/en/pokemon-info.json b/src/locales/en/pokemon-info.json deleted file mode 100644 index b79daaed621..00000000000 --- a/src/locales/en/pokemon-info.json +++ /dev/null @@ -1,40 +0,0 @@ -{ - "Stat": { - "HP": "Max. HP", - "HPshortened": "HP", - "ATK": "Attack", - "ATKshortened": "Atk", - "DEF": "Defense", - "DEFshortened": "Def", - "SPATK": "Sp. Atk", - "SPATKshortened": "SpAtk", - "SPDEF": "Sp. Def", - "SPDEFshortened": "SpDef", - "SPD": "Speed", - "SPDshortened": "Spd", - "ACC": "Accuracy", - "EVA": "Evasiveness" - }, - "Type": { - "UNKNOWN": "Unknown", - "NORMAL": "Normal", - "FIGHTING": "Fighting", - "FLYING": "Flying", - "POISON": "Poison", - "GROUND": "Ground", - "ROCK": "Rock", - "BUG": "Bug", - "GHOST": "Ghost", - "STEEL": "Steel", - "FIRE": "Fire", - "WATER": "Water", - "GRASS": "Grass", - "ELECTRIC": "Electric", - "PSYCHIC": "Psychic", - "ICE": "Ice", - "DRAGON": "Dragon", - "DARK": "Dark", - "FAIRY": "Fairy", - "STELLAR": "Stellar" - } -} diff --git a/src/locales/en/pokemon-summary.json b/src/locales/en/pokemon-summary.json deleted file mode 100644 index 458fad0efe0..00000000000 --- a/src/locales/en/pokemon-summary.json +++ /dev/null @@ -1,44 +0,0 @@ -{ - "pokemonInfo": "Pokémon Info", - "status": "Status", - "powerAccuracyCategory": "Power\nAccuracy\nCategory", - "type": "Type", - "unknownTrainer": "Unknown", - "ot": "OT", - "nature": "nature", - "expPoints": "Exp. Points", - "nextLv": "Next Lv.", - "cancel": "Cancel", - "memoString": "{{natureFragment}} nature,\n{{metFragment}}", - "metFragment": { - "normal": "met at Lv{{level}},\n{{biome}}, Wave {{wave}}.", - "apparently": "apparently met at Lv{{level}},\n{{biome}}." - }, - "natureFragment": { - "Hardy": "{{nature}}", - "Lonely": "{{nature}}", - "Brave": "{{nature}}", - "Adamant": "{{nature}}", - "Naughty": "{{nature}}", - "Bold": "{{nature}}", - "Docile": "{{nature}}", - "Relaxed": "{{nature}}", - "Impish": "{{nature}}", - "Lax": "{{nature}}", - "Timid": "{{nature}}", - "Hasty": "{{nature}}", - "Serious": "{{nature}}", - "Jolly": "{{nature}}", - "Naive": "{{nature}}", - "Modest": "{{nature}}", - "Mild": "{{nature}}", - "Quiet": "{{nature}}", - "Bashful": "{{nature}}", - "Rash": "{{nature}}", - "Calm": "{{nature}}", - "Gentle": "{{nature}}", - "Sassy": "{{nature}}", - "Careful": "{{nature}}", - "Quirky": "{{nature}}" - } -} \ No newline at end of file diff --git a/src/locales/en/pokemon.json b/src/locales/en/pokemon.json deleted file mode 100644 index 9185f749cfa..00000000000 --- a/src/locales/en/pokemon.json +++ /dev/null @@ -1,1084 +0,0 @@ -{ - "bulbasaur": "Bulbasaur", - "ivysaur": "Ivysaur", - "venusaur": "Venusaur", - "charmander": "Charmander", - "charmeleon": "Charmeleon", - "charizard": "Charizard", - "squirtle": "Squirtle", - "wartortle": "Wartortle", - "blastoise": "Blastoise", - "caterpie": "Caterpie", - "metapod": "Metapod", - "butterfree": "Butterfree", - "weedle": "Weedle", - "kakuna": "Kakuna", - "beedrill": "Beedrill", - "pidgey": "Pidgey", - "pidgeotto": "Pidgeotto", - "pidgeot": "Pidgeot", - "rattata": "Rattata", - "raticate": "Raticate", - "spearow": "Spearow", - "fearow": "Fearow", - "ekans": "Ekans", - "arbok": "Arbok", - "pikachu": "Pikachu", - "raichu": "Raichu", - "sandshrew": "Sandshrew", - "sandslash": "Sandslash", - "nidoran_f": "Nidoran♀", - "nidorina": "Nidorina", - "nidoqueen": "Nidoqueen", - "nidoran_m": "Nidoran♂", - "nidorino": "Nidorino", - "nidoking": "Nidoking", - "clefairy": "Clefairy", - "clefable": "Clefable", - "vulpix": "Vulpix", - "ninetales": "Ninetales", - "jigglypuff": "Jigglypuff", - "wigglytuff": "Wigglytuff", - "zubat": "Zubat", - "golbat": "Golbat", - "oddish": "Oddish", - "gloom": "Gloom", - "vileplume": "Vileplume", - "paras": "Paras", - "parasect": "Parasect", - "venonat": "Venonat", - "venomoth": "Venomoth", - "diglett": "Diglett", - "dugtrio": "Dugtrio", - "meowth": "Meowth", - "persian": "Persian", - "psyduck": "Psyduck", - "golduck": "Golduck", - "mankey": "Mankey", - "primeape": "Primeape", - "growlithe": "Growlithe", - "arcanine": "Arcanine", - "poliwag": "Poliwag", - "poliwhirl": "Poliwhirl", - "poliwrath": "Poliwrath", - "abra": "Abra", - "kadabra": "Kadabra", - "alakazam": "Alakazam", - "machop": "Machop", - "machoke": "Machoke", - "machamp": "Machamp", - "bellsprout": "Bellsprout", - "weepinbell": "Weepinbell", - "victreebel": "Victreebel", - "tentacool": "Tentacool", - "tentacruel": "Tentacruel", - "geodude": "Geodude", - "graveler": "Graveler", - "golem": "Golem", - "ponyta": "Ponyta", - "rapidash": "Rapidash", - "slowpoke": "Slowpoke", - "slowbro": "Slowbro", - "magnemite": "Magnemite", - "magneton": "Magneton", - "farfetchd": "Farfetch'd", - "doduo": "Doduo", - "dodrio": "Dodrio", - "seel": "Seel", - "dewgong": "Dewgong", - "grimer": "Grimer", - "muk": "Muk", - "shellder": "Shellder", - "cloyster": "Cloyster", - "gastly": "Gastly", - "haunter": "Haunter", - "gengar": "Gengar", - "onix": "Onix", - "drowzee": "Drowzee", - "hypno": "Hypno", - "krabby": "Krabby", - "kingler": "Kingler", - "voltorb": "Voltorb", - "electrode": "Electrode", - "exeggcute": "Exeggcute", - "exeggutor": "Exeggutor", - "cubone": "Cubone", - "marowak": "Marowak", - "hitmonlee": "Hitmonlee", - "hitmonchan": "Hitmonchan", - "lickitung": "Lickitung", - "koffing": "Koffing", - "weezing": "Weezing", - "rhyhorn": "Rhyhorn", - "rhydon": "Rhydon", - "chansey": "Chansey", - "tangela": "Tangela", - "kangaskhan": "Kangaskhan", - "horsea": "Horsea", - "seadra": "Seadra", - "goldeen": "Goldeen", - "seaking": "Seaking", - "staryu": "Staryu", - "starmie": "Starmie", - "mr_mime": "Mr. Mime", - "scyther": "Scyther", - "jynx": "Jynx", - "electabuzz": "Electabuzz", - "magmar": "Magmar", - "pinsir": "Pinsir", - "tauros": "Tauros", - "magikarp": "Magikarp", - "gyarados": "Gyarados", - "lapras": "Lapras", - "ditto": "Ditto", - "eevee": "Eevee", - "vaporeon": "Vaporeon", - "jolteon": "Jolteon", - "flareon": "Flareon", - "porygon": "Porygon", - "omanyte": "Omanyte", - "omastar": "Omastar", - "kabuto": "Kabuto", - "kabutops": "Kabutops", - "aerodactyl": "Aerodactyl", - "snorlax": "Snorlax", - "articuno": "Articuno", - "zapdos": "Zapdos", - "moltres": "Moltres", - "dratini": "Dratini", - "dragonair": "Dragonair", - "dragonite": "Dragonite", - "mewtwo": "Mewtwo", - "mew": "Mew", - "chikorita": "Chikorita", - "bayleef": "Bayleef", - "meganium": "Meganium", - "cyndaquil": "Cyndaquil", - "quilava": "Quilava", - "typhlosion": "Typhlosion", - "totodile": "Totodile", - "croconaw": "Croconaw", - "feraligatr": "Feraligatr", - "sentret": "Sentret", - "furret": "Furret", - "hoothoot": "Hoothoot", - "noctowl": "Noctowl", - "ledyba": "Ledyba", - "ledian": "Ledian", - "spinarak": "Spinarak", - "ariados": "Ariados", - "crobat": "Crobat", - "chinchou": "Chinchou", - "lanturn": "Lanturn", - "pichu": "Pichu", - "cleffa": "Cleffa", - "igglybuff": "Igglybuff", - "togepi": "Togepi", - "togetic": "Togetic", - "natu": "Natu", - "xatu": "Xatu", - "mareep": "Mareep", - "flaaffy": "Flaaffy", - "ampharos": "Ampharos", - "bellossom": "Bellossom", - "marill": "Marill", - "azumarill": "Azumarill", - "sudowoodo": "Sudowoodo", - "politoed": "Politoed", - "hoppip": "Hoppip", - "skiploom": "Skiploom", - "jumpluff": "Jumpluff", - "aipom": "Aipom", - "sunkern": "Sunkern", - "sunflora": "Sunflora", - "yanma": "Yanma", - "wooper": "Wooper", - "quagsire": "Quagsire", - "espeon": "Espeon", - "umbreon": "Umbreon", - "murkrow": "Murkrow", - "slowking": "Slowking", - "misdreavus": "Misdreavus", - "unown": "Unown", - "wobbuffet": "Wobbuffet", - "girafarig": "Girafarig", - "pineco": "Pineco", - "forretress": "Forretress", - "dunsparce": "Dunsparce", - "gligar": "Gligar", - "steelix": "Steelix", - "snubbull": "Snubbull", - "granbull": "Granbull", - "qwilfish": "Qwilfish", - "scizor": "Scizor", - "shuckle": "Shuckle", - "heracross": "Heracross", - "sneasel": "Sneasel", - "teddiursa": "Teddiursa", - "ursaring": "Ursaring", - "slugma": "Slugma", - "magcargo": "Magcargo", - "swinub": "Swinub", - "piloswine": "Piloswine", - "corsola": "Corsola", - "remoraid": "Remoraid", - "octillery": "Octillery", - "delibird": "Delibird", - "mantine": "Mantine", - "skarmory": "Skarmory", - "houndour": "Houndour", - "houndoom": "Houndoom", - "kingdra": "Kingdra", - "phanpy": "Phanpy", - "donphan": "Donphan", - "porygon2": "Porygon2", - "stantler": "Stantler", - "smeargle": "Smeargle", - "tyrogue": "Tyrogue", - "hitmontop": "Hitmontop", - "smoochum": "Smoochum", - "elekid": "Elekid", - "magby": "Magby", - "miltank": "Miltank", - "blissey": "Blissey", - "raikou": "Raikou", - "entei": "Entei", - "suicune": "Suicune", - "larvitar": "Larvitar", - "pupitar": "Pupitar", - "tyranitar": "Tyranitar", - "lugia": "Lugia", - "ho_oh": "Ho-Oh", - "celebi": "Celebi", - "treecko": "Treecko", - "grovyle": "Grovyle", - "sceptile": "Sceptile", - "torchic": "Torchic", - "combusken": "Combusken", - "blaziken": "Blaziken", - "mudkip": "Mudkip", - "marshtomp": "Marshtomp", - "swampert": "Swampert", - "poochyena": "Poochyena", - "mightyena": "Mightyena", - "zigzagoon": "Zigzagoon", - "linoone": "Linoone", - "wurmple": "Wurmple", - "silcoon": "Silcoon", - "beautifly": "Beautifly", - "cascoon": "Cascoon", - "dustox": "Dustox", - "lotad": "Lotad", - "lombre": "Lombre", - "ludicolo": "Ludicolo", - "seedot": "Seedot", - "nuzleaf": "Nuzleaf", - "shiftry": "Shiftry", - "taillow": "Taillow", - "swellow": "Swellow", - "wingull": "Wingull", - "pelipper": "Pelipper", - "ralts": "Ralts", - "kirlia": "Kirlia", - "gardevoir": "Gardevoir", - "surskit": "Surskit", - "masquerain": "Masquerain", - "shroomish": "Shroomish", - "breloom": "Breloom", - "slakoth": "Slakoth", - "vigoroth": "Vigoroth", - "slaking": "Slaking", - "nincada": "Nincada", - "ninjask": "Ninjask", - "shedinja": "Shedinja", - "whismur": "Whismur", - "loudred": "Loudred", - "exploud": "Exploud", - "makuhita": "Makuhita", - "hariyama": "Hariyama", - "azurill": "Azurill", - "nosepass": "Nosepass", - "skitty": "Skitty", - "delcatty": "Delcatty", - "sableye": "Sableye", - "mawile": "Mawile", - "aron": "Aron", - "lairon": "Lairon", - "aggron": "Aggron", - "meditite": "Meditite", - "medicham": "Medicham", - "electrike": "Electrike", - "manectric": "Manectric", - "plusle": "Plusle", - "minun": "Minun", - "volbeat": "Volbeat", - "illumise": "Illumise", - "roselia": "Roselia", - "gulpin": "Gulpin", - "swalot": "Swalot", - "carvanha": "Carvanha", - "sharpedo": "Sharpedo", - "wailmer": "Wailmer", - "wailord": "Wailord", - "numel": "Numel", - "camerupt": "Camerupt", - "torkoal": "Torkoal", - "spoink": "Spoink", - "grumpig": "Grumpig", - "spinda": "Spinda", - "trapinch": "Trapinch", - "vibrava": "Vibrava", - "flygon": "Flygon", - "cacnea": "Cacnea", - "cacturne": "Cacturne", - "swablu": "Swablu", - "altaria": "Altaria", - "zangoose": "Zangoose", - "seviper": "Seviper", - "lunatone": "Lunatone", - "solrock": "Solrock", - "barboach": "Barboach", - "whiscash": "Whiscash", - "corphish": "Corphish", - "crawdaunt": "Crawdaunt", - "baltoy": "Baltoy", - "claydol": "Claydol", - "lileep": "Lileep", - "cradily": "Cradily", - "anorith": "Anorith", - "armaldo": "Armaldo", - "feebas": "Feebas", - "milotic": "Milotic", - "castform": "Castform", - "kecleon": "Kecleon", - "shuppet": "Shuppet", - "banette": "Banette", - "duskull": "Duskull", - "dusclops": "Dusclops", - "tropius": "Tropius", - "chimecho": "Chimecho", - "absol": "Absol", - "wynaut": "Wynaut", - "snorunt": "Snorunt", - "glalie": "Glalie", - "spheal": "Spheal", - "sealeo": "Sealeo", - "walrein": "Walrein", - "clamperl": "Clamperl", - "huntail": "Huntail", - "gorebyss": "Gorebyss", - "relicanth": "Relicanth", - "luvdisc": "Luvdisc", - "bagon": "Bagon", - "shelgon": "Shelgon", - "salamence": "Salamence", - "beldum": "Beldum", - "metang": "Metang", - "metagross": "Metagross", - "regirock": "Regirock", - "regice": "Regice", - "registeel": "Registeel", - "latias": "Latias", - "latios": "Latios", - "kyogre": "Kyogre", - "groudon": "Groudon", - "rayquaza": "Rayquaza", - "jirachi": "Jirachi", - "deoxys": "Deoxys", - "turtwig": "Turtwig", - "grotle": "Grotle", - "torterra": "Torterra", - "chimchar": "Chimchar", - "monferno": "Monferno", - "infernape": "Infernape", - "piplup": "Piplup", - "prinplup": "Prinplup", - "empoleon": "Empoleon", - "starly": "Starly", - "staravia": "Staravia", - "staraptor": "Staraptor", - "bidoof": "Bidoof", - "bibarel": "Bibarel", - "kricketot": "Kricketot", - "kricketune": "Kricketune", - "shinx": "Shinx", - "luxio": "Luxio", - "luxray": "Luxray", - "budew": "Budew", - "roserade": "Roserade", - "cranidos": "Cranidos", - "rampardos": "Rampardos", - "shieldon": "Shieldon", - "bastiodon": "Bastiodon", - "burmy": "Burmy", - "wormadam": "Wormadam", - "mothim": "Mothim", - "combee": "Combee", - "vespiquen": "Vespiquen", - "pachirisu": "Pachirisu", - "buizel": "Buizel", - "floatzel": "Floatzel", - "cherubi": "Cherubi", - "cherrim": "Cherrim", - "shellos": "Shellos", - "gastrodon": "Gastrodon", - "ambipom": "Ambipom", - "drifloon": "Drifloon", - "drifblim": "Drifblim", - "buneary": "Buneary", - "lopunny": "Lopunny", - "mismagius": "Mismagius", - "honchkrow": "Honchkrow", - "glameow": "Glameow", - "purugly": "Purugly", - "chingling": "Chingling", - "stunky": "Stunky", - "skuntank": "Skuntank", - "bronzor": "Bronzor", - "bronzong": "Bronzong", - "bonsly": "Bonsly", - "mime_jr": "Mime Jr.", - "happiny": "Happiny", - "chatot": "Chatot", - "spiritomb": "Spiritomb", - "gible": "Gible", - "gabite": "Gabite", - "garchomp": "Garchomp", - "munchlax": "Munchlax", - "riolu": "Riolu", - "lucario": "Lucario", - "hippopotas": "Hippopotas", - "hippowdon": "Hippowdon", - "skorupi": "Skorupi", - "drapion": "Drapion", - "croagunk": "Croagunk", - "toxicroak": "Toxicroak", - "carnivine": "Carnivine", - "finneon": "Finneon", - "lumineon": "Lumineon", - "mantyke": "Mantyke", - "snover": "Snover", - "abomasnow": "Abomasnow", - "weavile": "Weavile", - "magnezone": "Magnezone", - "lickilicky": "Lickilicky", - "rhyperior": "Rhyperior", - "tangrowth": "Tangrowth", - "electivire": "Electivire", - "magmortar": "Magmortar", - "togekiss": "Togekiss", - "yanmega": "Yanmega", - "leafeon": "Leafeon", - "glaceon": "Glaceon", - "gliscor": "Gliscor", - "mamoswine": "Mamoswine", - "porygon_z": "Porygon-Z", - "gallade": "Gallade", - "probopass": "Probopass", - "dusknoir": "Dusknoir", - "froslass": "Froslass", - "rotom": "Rotom", - "uxie": "Uxie", - "mesprit": "Mesprit", - "azelf": "Azelf", - "dialga": "Dialga", - "palkia": "Palkia", - "heatran": "Heatran", - "regigigas": "Regigigas", - "giratina": "Giratina", - "cresselia": "Cresselia", - "phione": "Phione", - "manaphy": "Manaphy", - "darkrai": "Darkrai", - "shaymin": "Shaymin", - "arceus": "Arceus", - "victini": "Victini", - "snivy": "Snivy", - "servine": "Servine", - "serperior": "Serperior", - "tepig": "Tepig", - "pignite": "Pignite", - "emboar": "Emboar", - "oshawott": "Oshawott", - "dewott": "Dewott", - "samurott": "Samurott", - "patrat": "Patrat", - "watchog": "Watchog", - "lillipup": "Lillipup", - "herdier": "Herdier", - "stoutland": "Stoutland", - "purrloin": "Purrloin", - "liepard": "Liepard", - "pansage": "Pansage", - "simisage": "Simisage", - "pansear": "Pansear", - "simisear": "Simisear", - "panpour": "Panpour", - "simipour": "Simipour", - "munna": "Munna", - "musharna": "Musharna", - "pidove": "Pidove", - "tranquill": "Tranquill", - "unfezant": "Unfezant", - "blitzle": "Blitzle", - "zebstrika": "Zebstrika", - "roggenrola": "Roggenrola", - "boldore": "Boldore", - "gigalith": "Gigalith", - "woobat": "Woobat", - "swoobat": "Swoobat", - "drilbur": "Drilbur", - "excadrill": "Excadrill", - "audino": "Audino", - "timburr": "Timburr", - "gurdurr": "Gurdurr", - "conkeldurr": "Conkeldurr", - "tympole": "Tympole", - "palpitoad": "Palpitoad", - "seismitoad": "Seismitoad", - "throh": "Throh", - "sawk": "Sawk", - "sewaddle": "Sewaddle", - "swadloon": "Swadloon", - "leavanny": "Leavanny", - "venipede": "Venipede", - "whirlipede": "Whirlipede", - "scolipede": "Scolipede", - "cottonee": "Cottonee", - "whimsicott": "Whimsicott", - "petilil": "Petilil", - "lilligant": "Lilligant", - "basculin": "Basculin", - "sandile": "Sandile", - "krokorok": "Krokorok", - "krookodile": "Krookodile", - "darumaka": "Darumaka", - "darmanitan": "Darmanitan", - "maractus": "Maractus", - "dwebble": "Dwebble", - "crustle": "Crustle", - "scraggy": "Scraggy", - "scrafty": "Scrafty", - "sigilyph": "Sigilyph", - "yamask": "Yamask", - "cofagrigus": "Cofagrigus", - "tirtouga": "Tirtouga", - "carracosta": "Carracosta", - "archen": "Archen", - "archeops": "Archeops", - "trubbish": "Trubbish", - "garbodor": "Garbodor", - "zorua": "Zorua", - "zoroark": "Zoroark", - "minccino": "Minccino", - "cinccino": "Cinccino", - "gothita": "Gothita", - "gothorita": "Gothorita", - "gothitelle": "Gothitelle", - "solosis": "Solosis", - "duosion": "Duosion", - "reuniclus": "Reuniclus", - "ducklett": "Ducklett", - "swanna": "Swanna", - "vanillite": "Vanillite", - "vanillish": "Vanillish", - "vanilluxe": "Vanilluxe", - "deerling": "Deerling", - "sawsbuck": "Sawsbuck", - "emolga": "Emolga", - "karrablast": "Karrablast", - "escavalier": "Escavalier", - "foongus": "Foongus", - "amoonguss": "Amoonguss", - "frillish": "Frillish", - "jellicent": "Jellicent", - "alomomola": "Alomomola", - "joltik": "Joltik", - "galvantula": "Galvantula", - "ferroseed": "Ferroseed", - "ferrothorn": "Ferrothorn", - "klink": "Klink", - "klang": "Klang", - "klinklang": "Klinklang", - "tynamo": "Tynamo", - "eelektrik": "Eelektrik", - "eelektross": "Eelektross", - "elgyem": "Elgyem", - "beheeyem": "Beheeyem", - "litwick": "Litwick", - "lampent": "Lampent", - "chandelure": "Chandelure", - "axew": "Axew", - "fraxure": "Fraxure", - "haxorus": "Haxorus", - "cubchoo": "Cubchoo", - "beartic": "Beartic", - "cryogonal": "Cryogonal", - "shelmet": "Shelmet", - "accelgor": "Accelgor", - "stunfisk": "Stunfisk", - "mienfoo": "Mienfoo", - "mienshao": "Mienshao", - "druddigon": "Druddigon", - "golett": "Golett", - "golurk": "Golurk", - "pawniard": "Pawniard", - "bisharp": "Bisharp", - "bouffalant": "Bouffalant", - "rufflet": "Rufflet", - "braviary": "Braviary", - "vullaby": "Vullaby", - "mandibuzz": "Mandibuzz", - "heatmor": "Heatmor", - "durant": "Durant", - "deino": "Deino", - "zweilous": "Zweilous", - "hydreigon": "Hydreigon", - "larvesta": "Larvesta", - "volcarona": "Volcarona", - "cobalion": "Cobalion", - "terrakion": "Terrakion", - "virizion": "Virizion", - "tornadus": "Tornadus", - "thundurus": "Thundurus", - "reshiram": "Reshiram", - "zekrom": "Zekrom", - "landorus": "Landorus", - "kyurem": "Kyurem", - "keldeo": "Keldeo", - "meloetta": "Meloetta", - "genesect": "Genesect", - "chespin": "Chespin", - "quilladin": "Quilladin", - "chesnaught": "Chesnaught", - "fennekin": "Fennekin", - "braixen": "Braixen", - "delphox": "Delphox", - "froakie": "Froakie", - "frogadier": "Frogadier", - "greninja": "Greninja", - "bunnelby": "Bunnelby", - "diggersby": "Diggersby", - "fletchling": "Fletchling", - "fletchinder": "Fletchinder", - "talonflame": "Talonflame", - "scatterbug": "Scatterbug", - "spewpa": "Spewpa", - "vivillon": "Vivillon", - "litleo": "Litleo", - "pyroar": "Pyroar", - "flabebe": "Flabébé", - "floette": "Floette", - "florges": "Florges", - "skiddo": "Skiddo", - "gogoat": "Gogoat", - "pancham": "Pancham", - "pangoro": "Pangoro", - "furfrou": "Furfrou", - "espurr": "Espurr", - "meowstic": "Meowstic", - "honedge": "Honedge", - "doublade": "Doublade", - "aegislash": "Aegislash", - "spritzee": "Spritzee", - "aromatisse": "Aromatisse", - "swirlix": "Swirlix", - "slurpuff": "Slurpuff", - "inkay": "Inkay", - "malamar": "Malamar", - "binacle": "Binacle", - "barbaracle": "Barbaracle", - "skrelp": "Skrelp", - "dragalge": "Dragalge", - "clauncher": "Clauncher", - "clawitzer": "Clawitzer", - "helioptile": "Helioptile", - "heliolisk": "Heliolisk", - "tyrunt": "Tyrunt", - "tyrantrum": "Tyrantrum", - "amaura": "Amaura", - "aurorus": "Aurorus", - "sylveon": "Sylveon", - "hawlucha": "Hawlucha", - "dedenne": "Dedenne", - "carbink": "Carbink", - "goomy": "Goomy", - "sliggoo": "Sliggoo", - "goodra": "Goodra", - "klefki": "Klefki", - "phantump": "Phantump", - "trevenant": "Trevenant", - "pumpkaboo": "Pumpkaboo", - "gourgeist": "Gourgeist", - "bergmite": "Bergmite", - "avalugg": "Avalugg", - "noibat": "Noibat", - "noivern": "Noivern", - "xerneas": "Xerneas", - "yveltal": "Yveltal", - "zygarde": "Zygarde", - "diancie": "Diancie", - "hoopa": "Hoopa", - "volcanion": "Volcanion", - "rowlet": "Rowlet", - "dartrix": "Dartrix", - "decidueye": "Decidueye", - "litten": "Litten", - "torracat": "Torracat", - "incineroar": "Incineroar", - "popplio": "Popplio", - "brionne": "Brionne", - "primarina": "Primarina", - "pikipek": "Pikipek", - "trumbeak": "Trumbeak", - "toucannon": "Toucannon", - "yungoos": "Yungoos", - "gumshoos": "Gumshoos", - "grubbin": "Grubbin", - "charjabug": "Charjabug", - "vikavolt": "Vikavolt", - "crabrawler": "Crabrawler", - "crabominable": "Crabominable", - "oricorio": "Oricorio", - "cutiefly": "Cutiefly", - "ribombee": "Ribombee", - "rockruff": "Rockruff", - "lycanroc": "Lycanroc", - "wishiwashi": "Wishiwashi", - "mareanie": "Mareanie", - "toxapex": "Toxapex", - "mudbray": "Mudbray", - "mudsdale": "Mudsdale", - "dewpider": "Dewpider", - "araquanid": "Araquanid", - "fomantis": "Fomantis", - "lurantis": "Lurantis", - "morelull": "Morelull", - "shiinotic": "Shiinotic", - "salandit": "Salandit", - "salazzle": "Salazzle", - "stufful": "Stufful", - "bewear": "Bewear", - "bounsweet": "Bounsweet", - "steenee": "Steenee", - "tsareena": "Tsareena", - "comfey": "Comfey", - "oranguru": "Oranguru", - "passimian": "Passimian", - "wimpod": "Wimpod", - "golisopod": "Golisopod", - "sandygast": "Sandygast", - "palossand": "Palossand", - "pyukumuku": "Pyukumuku", - "type_null": "Type: Null", - "silvally": "Silvally", - "minior": "Minior", - "komala": "Komala", - "turtonator": "Turtonator", - "togedemaru": "Togedemaru", - "mimikyu": "Mimikyu", - "bruxish": "Bruxish", - "drampa": "Drampa", - "dhelmise": "Dhelmise", - "jangmo_o": "Jangmo-o", - "hakamo_o": "Hakamo-o", - "kommo_o": "Kommo-o", - "tapu_koko": "Tapu Koko", - "tapu_lele": "Tapu Lele", - "tapu_bulu": "Tapu Bulu", - "tapu_fini": "Tapu Fini", - "cosmog": "Cosmog", - "cosmoem": "Cosmoem", - "solgaleo": "Solgaleo", - "lunala": "Lunala", - "nihilego": "Nihilego", - "buzzwole": "Buzzwole", - "pheromosa": "Pheromosa", - "xurkitree": "Xurkitree", - "celesteela": "Celesteela", - "kartana": "Kartana", - "guzzlord": "Guzzlord", - "necrozma": "Necrozma", - "magearna": "Magearna", - "marshadow": "Marshadow", - "poipole": "Poipole", - "naganadel": "Naganadel", - "stakataka": "Stakataka", - "blacephalon": "Blacephalon", - "zeraora": "Zeraora", - "meltan": "Meltan", - "melmetal": "Melmetal", - "grookey": "Grookey", - "thwackey": "Thwackey", - "rillaboom": "Rillaboom", - "scorbunny": "Scorbunny", - "raboot": "Raboot", - "cinderace": "Cinderace", - "sobble": "Sobble", - "drizzile": "Drizzile", - "inteleon": "Inteleon", - "skwovet": "Skwovet", - "greedent": "Greedent", - "rookidee": "Rookidee", - "corvisquire": "Corvisquire", - "corviknight": "Corviknight", - "blipbug": "Blipbug", - "dottler": "Dottler", - "orbeetle": "Orbeetle", - "nickit": "Nickit", - "thievul": "Thievul", - "gossifleur": "Gossifleur", - "eldegoss": "Eldegoss", - "wooloo": "Wooloo", - "dubwool": "Dubwool", - "chewtle": "Chewtle", - "drednaw": "Drednaw", - "yamper": "Yamper", - "boltund": "Boltund", - "rolycoly": "Rolycoly", - "carkol": "Carkol", - "coalossal": "Coalossal", - "applin": "Applin", - "flapple": "Flapple", - "appletun": "Appletun", - "silicobra": "Silicobra", - "sandaconda": "Sandaconda", - "cramorant": "Cramorant", - "arrokuda": "Arrokuda", - "barraskewda": "Barraskewda", - "toxel": "Toxel", - "toxtricity": "Toxtricity", - "sizzlipede": "Sizzlipede", - "centiskorch": "Centiskorch", - "clobbopus": "Clobbopus", - "grapploct": "Grapploct", - "sinistea": "Sinistea", - "polteageist": "Polteageist", - "hatenna": "Hatenna", - "hattrem": "Hattrem", - "hatterene": "Hatterene", - "impidimp": "Impidimp", - "morgrem": "Morgrem", - "grimmsnarl": "Grimmsnarl", - "obstagoon": "Obstagoon", - "perrserker": "Perrserker", - "cursola": "Cursola", - "sirfetchd": "Sirfetch'd", - "mr_rime": "Mr. Rime", - "runerigus": "Runerigus", - "milcery": "Milcery", - "alcremie": "Alcremie", - "falinks": "Falinks", - "pincurchin": "Pincurchin", - "snom": "Snom", - "frosmoth": "Frosmoth", - "stonjourner": "Stonjourner", - "eiscue": "Eiscue", - "indeedee": "Indeedee", - "morpeko": "Morpeko", - "cufant": "Cufant", - "copperajah": "Copperajah", - "dracozolt": "Dracozolt", - "arctozolt": "Arctozolt", - "dracovish": "Dracovish", - "arctovish": "Arctovish", - "duraludon": "Duraludon", - "dreepy": "Dreepy", - "drakloak": "Drakloak", - "dragapult": "Dragapult", - "zacian": "Zacian", - "zamazenta": "Zamazenta", - "eternatus": "Eternatus", - "kubfu": "Kubfu", - "urshifu": "Urshifu", - "zarude": "Zarude", - "regieleki": "Regieleki", - "regidrago": "Regidrago", - "glastrier": "Glastrier", - "spectrier": "Spectrier", - "calyrex": "Calyrex", - "wyrdeer": "Wyrdeer", - "kleavor": "Kleavor", - "ursaluna": "Ursaluna", - "basculegion": "Basculegion", - "sneasler": "Sneasler", - "overqwil": "Overqwil", - "enamorus": "Enamorus", - "sprigatito": "Sprigatito", - "floragato": "Floragato", - "meowscarada": "Meowscarada", - "fuecoco": "Fuecoco", - "crocalor": "Crocalor", - "skeledirge": "Skeledirge", - "quaxly": "Quaxly", - "quaxwell": "Quaxwell", - "quaquaval": "Quaquaval", - "lechonk": "Lechonk", - "oinkologne": "Oinkologne", - "tarountula": "Tarountula", - "spidops": "Spidops", - "nymble": "Nymble", - "lokix": "Lokix", - "pawmi": "Pawmi", - "pawmo": "Pawmo", - "pawmot": "Pawmot", - "tandemaus": "Tandemaus", - "maushold": "Maushold", - "fidough": "Fidough", - "dachsbun": "Dachsbun", - "smoliv": "Smoliv", - "dolliv": "Dolliv", - "arboliva": "Arboliva", - "squawkabilly": "Squawkabilly", - "nacli": "Nacli", - "naclstack": "Naclstack", - "garganacl": "Garganacl", - "charcadet": "Charcadet", - "armarouge": "Armarouge", - "ceruledge": "Ceruledge", - "tadbulb": "Tadbulb", - "bellibolt": "Bellibolt", - "wattrel": "Wattrel", - "kilowattrel": "Kilowattrel", - "maschiff": "Maschiff", - "mabosstiff": "Mabosstiff", - "shroodle": "Shroodle", - "grafaiai": "Grafaiai", - "bramblin": "Bramblin", - "brambleghast": "Brambleghast", - "toedscool": "Toedscool", - "toedscruel": "Toedscruel", - "klawf": "Klawf", - "capsakid": "Capsakid", - "scovillain": "Scovillain", - "rellor": "Rellor", - "rabsca": "Rabsca", - "flittle": "Flittle", - "espathra": "Espathra", - "tinkatink": "Tinkatink", - "tinkatuff": "Tinkatuff", - "tinkaton": "Tinkaton", - "wiglett": "Wiglett", - "wugtrio": "Wugtrio", - "bombirdier": "Bombirdier", - "finizen": "Finizen", - "palafin": "Palafin", - "varoom": "Varoom", - "revavroom": "Revavroom", - "cyclizar": "Cyclizar", - "orthworm": "Orthworm", - "glimmet": "Glimmet", - "glimmora": "Glimmora", - "greavard": "Greavard", - "houndstone": "Houndstone", - "flamigo": "Flamigo", - "cetoddle": "Cetoddle", - "cetitan": "Cetitan", - "veluza": "Veluza", - "dondozo": "Dondozo", - "tatsugiri": "Tatsugiri", - "annihilape": "Annihilape", - "clodsire": "Clodsire", - "farigiraf": "Farigiraf", - "dudunsparce": "Dudunsparce", - "kingambit": "Kingambit", - "great_tusk": "Great Tusk", - "scream_tail": "Scream Tail", - "brute_bonnet": "Brute Bonnet", - "flutter_mane": "Flutter Mane", - "slither_wing": "Slither Wing", - "sandy_shocks": "Sandy Shocks", - "iron_treads": "Iron Treads", - "iron_bundle": "Iron Bundle", - "iron_hands": "Iron Hands", - "iron_jugulis": "Iron Jugulis", - "iron_moth": "Iron Moth", - "iron_thorns": "Iron Thorns", - "frigibax": "Frigibax", - "arctibax": "Arctibax", - "baxcalibur": "Baxcalibur", - "gimmighoul": "Gimmighoul", - "gholdengo": "Gholdengo", - "wo_chien": "Wo-Chien", - "chien_pao": "Chien-Pao", - "ting_lu": "Ting-Lu", - "chi_yu": "Chi-Yu", - "roaring_moon": "Roaring Moon", - "iron_valiant": "Iron Valiant", - "koraidon": "Koraidon", - "miraidon": "Miraidon", - "walking_wake": "Walking Wake", - "iron_leaves": "Iron Leaves", - "dipplin": "Dipplin", - "poltchageist": "Poltchageist", - "sinistcha": "Sinistcha", - "okidogi": "Okidogi", - "munkidori": "Munkidori", - "fezandipiti": "Fezandipiti", - "ogerpon": "Ogerpon", - "archaludon": "Archaludon", - "hydrapple": "Hydrapple", - "gouging_fire": "Gouging Fire", - "raging_bolt": "Raging Bolt", - "iron_boulder": "Iron Boulder", - "iron_crown": "Iron Crown", - "terapagos": "Terapagos", - "pecharunt": "Pecharunt", - "alola_rattata": "Rattata", - "alola_raticate": "Raticate", - "alola_raichu": "Raichu", - "alola_sandshrew": "Sandshrew", - "alola_sandslash": "Sandslash", - "alola_vulpix": "Vulpix", - "alola_ninetales": "Ninetales", - "alola_diglett": "Diglett", - "alola_dugtrio": "Dugtrio", - "alola_meowth": "Meowth", - "alola_persian": "Persian", - "alola_geodude": "Geodude", - "alola_graveler": "Graveler", - "alola_golem": "Golem", - "alola_grimer": "Grimer", - "alola_muk": "Muk", - "alola_exeggutor": "Exeggutor", - "alola_marowak": "Marowak", - "eternal_floette": "Floette", - "galar_meowth": "Meowth", - "galar_ponyta": "Ponyta", - "galar_rapidash": "Rapidash", - "galar_slowpoke": "Slowpoke", - "galar_slowbro": "Slowbro", - "galar_farfetchd": "Farfetch'd", - "galar_weezing": "Weezing", - "galar_mr_mime": "Mr. Mime", - "galar_articuno": "Articuno", - "galar_zapdos": "Zapdos", - "galar_moltres": "Moltres", - "galar_slowking": "Slowking", - "galar_corsola": "Corsola", - "galar_zigzagoon": "Zigzagoon", - "galar_linoone": "Linoone", - "galar_darumaka": "Darumaka", - "galar_darmanitan": "Darmanitan", - "galar_yamask": "Yamask", - "galar_stunfisk": "Stunfisk", - "hisui_growlithe": "Growlithe", - "hisui_arcanine": "Arcanine", - "hisui_voltorb": "Voltorb", - "hisui_electrode": "Electrode", - "hisui_typhlosion": "Typhlosion", - "hisui_qwilfish": "Qwilfish", - "hisui_sneasel": "Sneasel", - "hisui_samurott": "Samurott", - "hisui_lilligant": "Lilligant", - "hisui_zorua": "Zorua", - "hisui_zoroark": "Zoroark", - "hisui_braviary": "Braviary", - "hisui_sliggoo": "Sliggoo", - "hisui_goodra": "Goodra", - "hisui_avalugg": "Avalugg", - "hisui_decidueye": "Decidueye", - "paldea_tauros": "Tauros", - "paldea_wooper": "Wooper", - "bloodmoon_ursaluna": "Ursaluna" -} \ No newline at end of file diff --git a/src/locales/en/run-history.json b/src/locales/en/run-history.json deleted file mode 100644 index 53596bdf629..00000000000 --- a/src/locales/en/run-history.json +++ /dev/null @@ -1,37 +0,0 @@ -{ - "victory": "Victory!", - "defeatedWild": "Defeated by ", - "defeatedTrainer": "Defeated by ", - "defeatedTrainerDouble": "Defeated by Duo", - "defeatedRival": "Defeated by Rival", - "defeated": "Defeated", - "defeatedWild_female": "Defeated by ", - "defeatedTrainer_female": "Defeated by ", - "defeatedTrainerDouble_female": "Defeated by Duo", - "defeatedRival_female": "Defeated by Rival", - "defeated_female": "Defeated", - "luck": "Luck", - "score": "Score", - "mode": "Mode", - "challengeRules": "Rule(s)", - "challengeMonoGen1": "Gen I", - "challengeMonoGen2": "Gen II", - "challengeMonoGen3": "Gen III", - "challengeMonoGen4": "Gen IV", - "challengeMonoGen5": "Gen V", - "challengeMonoGen6": "Gen VI", - "challengeMonoGen7": "Gen VII", - "challengeMonoGen8": "Gen VIII", - "challengeMonoGen9": "Gen IX", - "playerItems": "Player Items", - "personalBest": "Personal Best!", - "SPDshortened": "Vel.", - "runInfo": "Run Info", - "money": "Money", - "runLength": "Run Length", - "viewHeldItems": "Held Items", - "hallofFameText": "Welcome to the Hall of Fame!", - "hallofFameText_female": "Welcome to the Hall of Fame!", - "viewHallOfFame": "View Hall of Fame!", - "viewEndingSplash": "View ending art!" -} diff --git a/src/locales/en/save-slot-select-ui-handler.json b/src/locales/en/save-slot-select-ui-handler.json deleted file mode 100644 index 2db02b09783..00000000000 --- a/src/locales/en/save-slot-select-ui-handler.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "overwriteData": "Overwrite the data in the selected slot?", - "loading": "Loading...", - "wave": "Wave", - "lv": "Lv", - "empty": "Empty" -} \ No newline at end of file diff --git a/src/locales/en/settings.json b/src/locales/en/settings.json deleted file mode 100644 index ee8a43d7510..00000000000 --- a/src/locales/en/settings.json +++ /dev/null @@ -1,111 +0,0 @@ -{ - "boy": "Boy", - "girl": "Girl", - "general": "General", - "display": "Display", - "audio": "Audio", - "gamepad": "Gamepad", - "keyboard": "Keyboard", - "gameSpeed": "Game Speed", - "hpBarSpeed": "HP Bar Speed", - "expGainsSpeed": "EXP Gains Speed", - "expPartyDisplay": "Show EXP Party", - "skipSeenDialogues": "Skip Seen Dialogues", - "eggSkip": "Egg Skip", - "never": "Never", - "always": "Always", - "ask": "Ask", - "battleStyle": "Battle Style", - "enableRetries": "Enable Retries", - "hideIvs": "Hide IV scanner", - "tutorials": "Tutorials", - "touchControls": "Touch Controls", - "vibrations": "Vibrations", - "normal": "Normal", - "fast": "Fast", - "faster": "Faster", - "skip": "Skip", - "levelUpNotifications": "Level Up Notifications", - "on": "On", - "off": "Off", - "switch": "Switch", - "set": "Set", - "auto": "Auto", - "disabled": "Disabled", - "language": "Language", - "change": "Change", - "uiTheme": "UI Theme", - "default": "Default", - "legacy": "Legacy", - "windowType": "Window Type", - "moneyFormat": "Money Format", - "damageNumbers": "Damage Numbers", - "simple": "Simple", - "fancy": "Fancy", - "abbreviated": "Abbreviated", - "moveAnimations": "Move Animations", - "showStatsOnLevelUp": "Show Stats on Level Up", - "candyUpgradeNotification": "Candy Upgrade Notification", - "passivesOnly": "Passives Only", - "candyUpgradeDisplay": "Candy Upgrade Display", - "icon": "Icon", - "animation": "Animation", - "moveInfo": "Move Info", - "showMovesetFlyout": "Show Moveset Flyout", - "showArenaFlyout": "Show Arena Flyout", - "showTimeOfDayWidget": "Show Time of Day Widget", - "timeOfDayAnimation": "Time of Day Animation", - "bounce": "Bounce", - "timeOfDay_back": "Back", - "spriteSet": "Sprite Set", - "consistent": "Consistent", - "mixedAnimated": "Mixed Animated", - "fusionPaletteSwaps": "Fusion Palette Swaps", - "playerGender": "Player Gender", - "typeHints": "Type Hints", - "masterVolume": "Master Volume", - "bgmVolume": "BGM Volume", - "fieldVolume": "Field Volume", - "seVolume": "SE Volume", - "uiVolume": "UI Volume", - "musicPreference": "Music Preference", - "mixed": "Mixed", - "gamepadPleasePlug": "Please Plug in a Gamepad or Press a Button", - "delete": "Delete", - "keyboardPleasePress": "Please Press a Key on Your Keyboard", - "reset": "Reset", - "requireReload": "Reload Required", - "action": "Action", - "back": "Back", - "pressToBind": "Press to Bind", - "pressButton": "Press a Button...", - "buttonUp": "Up", - "buttonDown": "Down", - "buttonLeft": "Left", - "buttonRight": "Right", - "buttonAction": "Action", - "buttonMenu": "Menu", - "buttonSubmit": "Submit", - "buttonCancel": "Cancel", - "buttonStats": "Stats", - "buttonCycleForm": "Cycle Form", - "buttonCycleShiny": "Cycle Shiny", - "buttonCycleGender": "Cycle Gender", - "buttonCycleAbility": "Cycle Ability", - "buttonCycleNature": "Cycle Nature", - "buttonCycleVariant": "Cycle Variant", - "buttonSpeedUp": "Speed Up", - "buttonSlowDown": "Slow Down", - "alt": " (Alt)", - "mute": "Mute", - "controller": "Controller", - "gamepadSupport": "Gamepad Support", - "showBgmBar": "Show Music Names", - "moveTouchControls": "Move Touch Controls", - "shopOverlayOpacity": "Shop Overlay Opacity", - "shopCursorTarget": "Shop Cursor Target", - "rewards": "Rewards", - "reroll": "Reroll", - "shop": "Shop", - "checkTeam": "Check Team" -} diff --git a/src/locales/en/splash-messages.json b/src/locales/en/splash-messages.json deleted file mode 100644 index c0686e6ad75..00000000000 --- a/src/locales/en/splash-messages.json +++ /dev/null @@ -1,36 +0,0 @@ -{ - "battlesWon": "Battles Won!", - "joinTheDiscord": "Join the Discord!", - "infiniteLevels": "Infinite Levels!", - "everythingStacks": "Everything Stacks!", - "optionalSaveScumming": "Optional Save Scumming!", - "biomes": "35 Biomes!", - "openSource": "Open Source!", - "playWithSpeed": "Play with 5x Speed!", - "liveBugTesting": "Live Bug Testing!", - "heavyInfluence": "Heavy RoR2 Influence!", - "pokemonRiskAndPokemonRain": "Pokémon Risk and Pokémon Rain!", - "nowWithMoreSalt": "Now with 33% More Salt!", - "infiniteFusionAtHome": "Infinite Fusion at Home!", - "brokenEggMoves": "Broken Egg Moves!", - "magnificent": "Magnificent!", - "mubstitute": "Mubstitute!", - "thatsCrazy": "That's Crazy!", - "oranceJuice": "Orance Juice!", - "questionableBalancing": "Questionable Balancing!", - "coolShaders": "Cool Shaders!", - "aiFree": "AI-Free!", - "suddenDifficultySpikes": "Sudden Difficulty Spikes!", - "basedOnAnUnfinishedFlashGame": "Based on an Unfinished Flash Game!", - "moreAddictiveThanIntended": "More Addictive than Intended!", - "mostlyConsistentSeeds": "Mostly Consistent Seeds!", - "achievementPointsDontDoAnything": "Achievement Points Don't Do Anything!", - "youDoNotStartAtLevel": "You Do Not Start at Level 2000!", - "dontTalkAboutTheManaphyEggIncident": "Don't Talk About the Manaphy Egg Incident!", - "alsoTryPokengine": "Also Try Pokéngine!", - "alsoTryEmeraldRogue": "Also Try Emerald Rogue!", - "alsoTryRadicalRed": "Also Try Radical Red!", - "eeveeExpo": "Eevee Expo!", - "ynoproject": "YNOproject!", - "breedersInSpace": "Breeders in space!" -} \ No newline at end of file diff --git a/src/locales/en/starter-select-ui-handler.json b/src/locales/en/starter-select-ui-handler.json deleted file mode 100644 index f578f128bee..00000000000 --- a/src/locales/en/starter-select-ui-handler.json +++ /dev/null @@ -1,45 +0,0 @@ -{ - "confirmStartTeam": "Begin with these Pokémon?", - "confirmExit": "Do you want to exit?", - "invalidParty": "This is not a valid starting party!", - "gen1": "I", - "gen2": "II", - "gen3": "III", - "gen4": "IV", - "gen5": "V", - "gen6": "VI", - "gen7": "VII", - "gen8": "VIII", - "gen9": "IX", - "growthRate": "Growth Rate:", - "ability": "Ability:", - "passive": "Passive:", - "nature": "Nature:", - "eggMoves": "Egg Moves", - "addToParty": "Add to Party", - "removeFromParty": "Remove from Party", - "toggleIVs": "Toggle IVs", - "manageMoves": "Manage Moves", - "manageNature": "Manage Nature", - "addToFavorites": "Add to Favorites", - "removeFromFavorites": "Remove from Favorites", - "useCandies": "Use Candies", - "selectNature": "Select nature.", - "selectMoveSwapOut": "Select a move to swap out.", - "selectMoveSwapWith": "Select a move to swap with", - "unlockPassive": "Unlock Passive", - "reduceCost": "Reduce Cost", - "sameSpeciesEgg": "Buy an Egg", - "cycleShiny": ": Shiny", - "cycleForm": ": Form", - "cycleGender": ": Gender", - "cycleAbility": ": Ability", - "cycleNature": ": Nature", - "cycleVariant": ": Variant", - "goFilter": ": Go to filters", - "enablePassive": "Enable Passive", - "disablePassive": "Disable Passive", - "locked": "Locked", - "disabled": "Disabled", - "uncaught": "Uncaught" -} \ No newline at end of file diff --git a/src/locales/en/status-effect.json b/src/locales/en/status-effect.json deleted file mode 100644 index fdbacfdb9be..00000000000 --- a/src/locales/en/status-effect.json +++ /dev/null @@ -1,65 +0,0 @@ -{ - "none": { - "name": "None", - "description": "", - "obtain": "", - "obtainSource": "", - "activation": "", - "overlap": "", - "heal": "" - }, - "poison": { - "name": "Poison", - "description": "poisoning", - "obtain": "{{pokemonNameWithAffix}}\nwas poisoned!", - "obtainSource": "{{pokemonNameWithAffix}}\nwas poisoned by the {{sourceText}}!", - "activation": "{{pokemonNameWithAffix}} is hurt\nby poison!", - "overlap": "{{pokemonNameWithAffix}} is\nalready poisoned!", - "heal": "{{pokemonNameWithAffix}} was\ncured of its poison!" - }, - "toxic": { - "name": "Toxic", - "description": "poisoning", - "obtain": "{{pokemonNameWithAffix}}\nwas badly poisoned!", - "obtainSource": "{{pokemonNameWithAffix}}\nwas badly poisoned by the {{sourceText}}!", - "activation": "{{pokemonNameWithAffix}} is hurt\nby poison!", - "overlap": "{{pokemonNameWithAffix}} is\nalready poisoned!", - "heal": "{{pokemonNameWithAffix}} was\ncured of its poison!" - }, - "paralysis": { - "name": "Paralysis", - "description": "paralysis", - "obtain": "{{pokemonNameWithAffix}} was paralyzed,\nIt may be unable to move!", - "obtainSource": "{{pokemonNameWithAffix}} was paralyzed by the {{sourceText}}!\nIt may be unable to move!", - "activation": "{{pokemonNameWithAffix}} is paralyzed!\nIt can't move!", - "overlap": "{{pokemonNameWithAffix}} is\nalready paralyzed!", - "heal": "{{pokemonNameWithAffix}} was\nhealed of paralysis!" - }, - "sleep": { - "name": "Sleep", - "description": "sleep", - "obtain": "{{pokemonNameWithAffix}}\nfell asleep!", - "obtainSource": "{{pokemonNameWithAffix}}\nfell asleep from the {{sourceText}}!", - "activation": "{{pokemonNameWithAffix}} is fast asleep.", - "overlap": "{{pokemonNameWithAffix}} is\nalready asleep!", - "heal": "{{pokemonNameWithAffix}} woke up!" - }, - "freeze": { - "name": "Freeze", - "description": "freezing", - "obtain": "{{pokemonNameWithAffix}}\nwas frozen solid!", - "obtainSource": "{{pokemonNameWithAffix}}\nwas frozen solid by the {{sourceText}}!", - "activation": "{{pokemonNameWithAffix}} is\nfrozen solid!", - "overlap": "{{pokemonNameWithAffix}} is\nalready frozen!", - "heal": "{{pokemonNameWithAffix}} was\ndefrosted!" - }, - "burn": { - "name": "Burn", - "description": "burn", - "obtain": "{{pokemonNameWithAffix}}\nwas burned!", - "obtainSource": "{{pokemonNameWithAffix}}\nwas burned by the {{sourceText}}!", - "activation": "{{pokemonNameWithAffix}} is hurt\nby its burn!", - "overlap": "{{pokemonNameWithAffix}} is\nalready burned!", - "heal": "{{pokemonNameWithAffix}} was\nhealed of its burn!" - } -} diff --git a/src/locales/en/terrain.json b/src/locales/en/terrain.json deleted file mode 100644 index 4619ecdf111..00000000000 --- a/src/locales/en/terrain.json +++ /dev/null @@ -1,16 +0,0 @@ -{ - "misty": "Misty", - "mistyStartMessage": "Mist swirled around the battlefield!", - "mistyClearMessage": "The mist disappeared from the battlefield.", - "mistyBlockMessage": "{{pokemonNameWithAffix}} surrounds itself with a protective mist!", - "electric": "Electric", - "electricStartMessage": "An electric current ran across the battlefield!", - "electricClearMessage": "The electricity disappeared from the battlefield.", - "grassy": "Grassy", - "grassyStartMessage": "Grass grew to cover the battlefield!", - "grassyClearMessage": "The grass disappeared from the battlefield.", - "psychic": "Psychic", - "psychicStartMessage": "The battlefield got weird!", - "psychicClearMessage": "The weirdness disappeared from the battlefield!", - "defaultBlockMessage": "{{pokemonNameWithAffix}} is protected by the {{terrainName}} Terrain!" -} \ No newline at end of file diff --git a/src/locales/en/trainer-classes.json b/src/locales/en/trainer-classes.json deleted file mode 100644 index 9e30915dee6..00000000000 --- a/src/locales/en/trainer-classes.json +++ /dev/null @@ -1,130 +0,0 @@ -{ - "ace_trainer": "Ace Trainer", - "ace_trainer_female": "Ace Trainer", - "ace_duo": "Ace Duo", - "artist": "Artist", - "artist_female": "Artist", - "backers": "Backers", - "backpacker": "Backpacker", - "backpacker_female": "Backpacker", - "backpackers": "Backpackers", - "baker": "Baker", - "battle_girl": "Battle Girl", - "beauty": "Beauty", - "beginners": "Beginners", - "biker": "Biker", - "black_belt": "Black Belt", - "breeder": "Breeder", - "breeder_female": "Breeder", - "breeders": "Breeders", - "clerk": "Clerk", - "clerk_female": "Clerk", - "colleagues": "Colleagues", - "crush_kin": "Crush Kin", - "cyclist": "Cyclist", - "cyclist_female": "Cyclist", - "cyclists": "Cyclists", - "dancer": "Dancer", - "dancer_female": "Dancer", - "depot_agent": "Depot Agent", - "doctor": "Doctor", - "doctor_female": "Doctor", - "firebreather": "Firebreather", - "fisherman": "Fisherman", - "fisherman_female": "Fisherman", - "gentleman": "Gentleman", - "guitarist": "Guitarist", - "guitarist_female": "Guitarist", - "harlequin": "Harlequin", - "hiker": "Hiker", - "hooligans": "Hooligans", - "hoopster": "Hoopster", - "infielder": "Infielder", - "janitor": "Janitor", - "lady": "Lady", - "lass": "Lass", - "linebacker": "Linebacker", - "maid": "Maid", - "madame": "Madame", - "medical_team": "Medical Team", - "musician": "Musician", - "hex_maniac": "Hex Maniac", - "nurse": "Nurse", - "nursery_aide": "Nursery Aide", - "officer": "Officer", - "parasol_lady": "Parasol Lady", - "pilot": "Pilot", - "pokéfan": "Poké Fan", - "pokéfan_female": "Poké Fan", - "pokéfan_family": "Poké Fan Family", - "preschooler": "Preschooler", - "preschooler_female": "Preschooler", - "preschoolers": "Preschoolers", - "psychic": "Psychic", - "psychic_female": "Psychic", - "psychics": "Psychics", - "pokémon_ranger": "Pokémon Ranger", - "pokémon_ranger_female": "Pokémon Ranger", - "pokémon_rangers": "Pokémon Ranger", - "ranger": "Ranger", - "restaurant_staff": "Restaurant Staff", - "rich": "Rich", - "rich_female": "Rich", - "rich_boy": "Rich Boy", - "rich_couple": "Rich Couple", - "rich_kid": "Rich Kid", - "rich_kid_female": "Rich Kid", - "rich_kids": "Rich Kids", - "roughneck": "Roughneck", - "sailor": "Sailor", - "scientist": "Scientist", - "scientist_female": "Scientist", - "scientists": "Scientists", - "smasher": "Smasher", - "snow_worker": "Snow Worker", - "snow_worker_female": "Snow Worker", - "striker": "Striker", - "school_kid": "School Kid", - "school_kid_female": "School Kid", - "school_kids": "School Kids", - "swimmer": "Swimmer", - "swimmer_female": "Swimmer", - "swimmers": "Swimmers", - "twins": "Twins", - "veteran": "Veteran", - "veteran_female": "Veteran", - "veteran_duo": "Veteran Duo", - "waiter": "Waiter", - "waitress": "Waitress", - "worker": "Worker", - "worker_female": "Worker", - "workers": "Workers", - "youngster": "Youngster", - "rocket_grunt": "Rocket Grunt", - "rocket_grunts": "Rocket Grunts", - "rocket_grunt_female": "Rocket Grunt", - "magma_grunt": "Magma Grunt", - "magma_grunt_female": "Magma Grunt", - "magma_grunts": "Magma Grunts", - "aqua_grunt": "Aqua Grunt", - "aqua_grunt_female": "Aqua Grunt", - "aqua_grunts": "Aqua Grunts", - "galactic_grunt": "Galactic Grunt", - "galactic_grunt_female": "Galactic Grunt", - "galactic_grunts": "Galactic Grunts", - "plasma_grunt": "Plasma Grunt", - "plasma_grunt_female": "Plasma Grunt", - "plasma_grunts": "Plasma Grunts", - "flare_grunt": "Flare Grunt", - "flare_grunt_female": "Flare Grunt", - "flare_grunts": "Flare Grunts", - "aether_grunt": "Aether Foundation Employee", - "aether_grunt_female": "Aether Foundation Employee", - "aether_grunts": "Aether Foundation Employees", - "skull_grunt": "Team Skull Grunt", - "skull_grunt_female": "Team Skull Grunt", - "skull_grunts": "Team Skull Grunts", - "macro_grunt": "Macro Cosmos Trainer", - "macro_grunt_female": "Macro Cosmos Trainer", - "macro_grunts": "Macro Cosmos Trainers" -} diff --git a/src/locales/en/trainer-names.json b/src/locales/en/trainer-names.json deleted file mode 100644 index 467ed03e044..00000000000 --- a/src/locales/en/trainer-names.json +++ /dev/null @@ -1,176 +0,0 @@ -{ - "brock": "Brock", - "misty": "Misty", - "lt_surge": "Lt Surge", - "erika": "Erika", - "janine": "Janine", - "sabrina": "Sabrina", - "blaine": "Blaine", - "giovanni": "Giovanni", - "falkner": "Falkner", - "bugsy": "Bugsy", - "whitney": "Whitney", - "morty": "Morty", - "chuck": "Chuck", - "jasmine": "Jasmine", - "pryce": "Pryce", - "clair": "Clair", - "roxanne": "Roxanne", - "brawly": "Brawly", - "wattson": "Wattson", - "flannery": "Flannery", - "norman": "Norman", - "winona": "Winona", - "tate": "Tate", - "liza": "Liza", - "juan": "Juan", - "roark": "Roark", - "gardenia": "Gardenia", - "maylene": "Maylene", - "crasher_wake": "Crasher Wake", - "fantina": "Fantina", - "byron": "Byron", - "candice": "Candice", - "volkner": "Volkner", - "cilan": "Cilan", - "chili": "Chili", - "cress": "Cress", - "cheren": "Cheren", - "lenora": "Lenora", - "roxie": "Roxie", - "burgh": "Burgh", - "elesa": "Elesa", - "clay": "Clay", - "skyla": "Skyla", - "brycen": "Brycen", - "drayden": "Drayden", - "marlon": "Marlon", - "viola": "Viola", - "grant": "Grant", - "korrina": "Korrina", - "ramos": "Ramos", - "clemont": "Clemont", - "valerie": "Valerie", - "olympia": "Olympia", - "wulfric": "Wulfric", - "milo": "Milo", - "nessa": "Nessa", - "kabu": "Kabu", - "bea": "Bea", - "allister": "Allister", - "opal": "Opal", - "bede": "Bede", - "gordie": "Gordie", - "melony": "Melony", - "piers": "Piers", - "marnie": "Marnie", - "raihan": "Raihan", - "katy": "Katy", - "brassius": "Brassius", - "iono": "Iono", - "kofu": "Kofu", - "larry": "Larry", - "ryme": "Ryme", - "tulip": "Tulip", - "grusha": "Grusha", - "lorelei": "Lorelei", - "bruno": "Bruno", - "agatha": "Agatha", - "lance": "Lance", - "will": "Will", - "koga": "Koga", - "karen": "Karen", - "sidney": "Sidney", - "phoebe": "Phoebe", - "glacia": "Glacia", - "drake": "Drake", - "aaron": "Aaron", - "bertha": "Bertha", - "flint": "Flint", - "lucian": "Lucian", - "shauntal": "Shauntal", - "marshal": "Marshal", - "grimsley": "Grimsley", - "caitlin": "Caitlin", - "malva": "Malva", - "siebold": "Siebold", - "wikstrom": "Wikstrom", - "drasna": "Drasna", - "hala": "Hala", - "molayne": "Molayne", - "olivia": "Olivia", - "acerola": "Acerola", - "kahili": "Kahili", - "rika": "Rika", - "poppy": "Poppy", - "hassel": "Hassel", - "crispin": "Crispin", - "amarys": "Amarys", - "lacey": "Lacey", - "drayton": "Drayton", - "blue": "Blue", - "red": "Red", - "steven": "Steven", - "wallace": "Wallace", - "cynthia": "Cynthia", - "alder": "Alder", - "iris": "Iris", - "diantha": "Diantha", - "hau": "Hau", - "geeta": "Geeta", - "nemona": "Nemona", - "kieran": "Kieran", - "leon": "Leon", - "rival": "Finn", - "rival_female": "Ivy", - "archer": "Archer", - "ariana": "Ariana", - "proton": "Proton", - "petrel": "Petrel", - "tabitha": "Tabitha", - "courtney": "Courtney", - "shelly": "Shelly", - "matt": "Matt", - "mars": "Mars", - "jupiter": "Jupiter", - "saturn": "Saturn", - "zinzolin": "Zinzolin", - "rood": "Rood", - "xerosic": "Xerosic", - "bryony": "Bryony", - "faba": "Faba", - "plumeria": "Plumeria", - "oleana": "Oleana", - - "maxie": "Maxie", - "archie": "Archie", - "cyrus": "Cyrus", - "ghetsis": "Ghetsis", - "lysandre": "Lysandre", - "lusamine": "Lusamine", - "guzma": "Guzma", - "rose": "Rose", - - "blue_red_double": "Blue & Red", - "red_blue_double": "Red & Blue", - "tate_liza_double": "Tate & Liza", - "liza_tate_double": "Liza & Tate", - "steven_wallace_double": "Steven & Wallace", - "wallace_steven_double": "Wallace & Steven", - "alder_iris_double": "Alder & Iris", - "iris_alder_double": "Iris & Alder", - "marnie_piers_double": "Marnie & Piers", - "piers_marnie_double": "Piers & Marnie", - - "buck": "Buck", - "cheryl": "Cheryl", - "marley": "Marley", - "mira": "Mira", - "riley": "Riley", - "victor": "Victor", - "victoria": "Victoria", - "vivi": "Vivi", - "vicky": "Vicky", - "vito": "Vito", - "bug_type_superfan": "Bug-Type Superfan" -} diff --git a/src/locales/en/trainer-titles.json b/src/locales/en/trainer-titles.json deleted file mode 100644 index 7ef715d115f..00000000000 --- a/src/locales/en/trainer-titles.json +++ /dev/null @@ -1,40 +0,0 @@ -{ - "elite_four": "Elite Four", - "elite_four_female": "Elite Four", - "gym_leader": "Gym Leader", - "gym_leader_female": "Gym Leader", - "gym_leader_double": "Gym Leader Duo", - "champion": "Champion", - "champion_female": "Champion", - "champion_double": "Champion Duo", - "rival": "Rival", - "professor": "Professor", - "frontier_brain": "Frontier Brain", - "rocket_boss": "Team Rocket Boss", - "magma_boss": "Team Magma Boss", - "aqua_boss": "Team Aqua Boss", - "galactic_boss": "Team Galactic Boss", - "plasma_boss": "Team Plasma Boss", - "flare_boss": "Team Flare Boss", - "aether_boss": "Aether President", - "skull_boss": "Team Skull Boss", - "macro_boss": "Macro Cosmos President", - - "rocket_admin": "Team Rocket Admin", - "rocket_admin_female": "Team Rocket Admin", - "magma_admin": "Team Magma Admin", - "magma_admin_female": "Team Magma Admin", - "aqua_admin": "Team Aqua Admin", - "aqua_admin_female": "Team Aqua Admin", - "galactic_commander": "Team Galactic Commander", - "galactic_commander_female": "Team Galactic Commander", - "plasma_sage": "Team Plasma Sage", - "plasma_admin": "Team Plasma Admin", - "flare_admin": "Team Flare Admin", - "flare_admin_female": "Team Flare Admin", - "aether_admin": "Aether Foundation Admin", - "skull_admin": "Team Skull Admin", - "macro_admin": "Macro Cosmos", - - "the_winstrates": "The Winstrates'" -} diff --git a/src/locales/en/tutorial.json b/src/locales/en/tutorial.json deleted file mode 100644 index 4c43f1fd896..00000000000 --- a/src/locales/en/tutorial.json +++ /dev/null @@ -1,10 +0,0 @@ -{ - "intro": "Welcome to PokéRogue! This is a battle-focused Pokémon fangame with roguelite elements.\n$This game is not monetized and we claim no ownership of Pokémon nor of the copyrighted assets used.\n$The game is a work in progress, but fully playable.\nFor bug reports, please use the Discord community.\n$If the game runs slowly, please ensure 'Hardware Acceleration' is turned on in your browser settings.", - "accessMenu": "To access the menu, press M or Escape while awaiting input.\nThe menu contains settings and various features.", - "menu": "From this menu you can access the settings.\n$From the settings you can change game speed, window style, and other options.\n$There are also various other features here, so be sure to check them all!", - "starterSelect": "From this screen, you can select your starters by pressing\nZ or the Space bar. These are your initial party members.\n$Each starter has a value. Your party can have up to\n6 members as long as the total does not exceed 10.\n$You can also select gender, ability, and form depending on\nthe variants you've caught or hatched.\n$The IVs for a species are also the best of every one you've\ncaught or hatched, so try to get lots of the same species!", - "pokerus": "A daily random 3 selectable starters have a purple border.\n$If you see a starter you own with one of these,\ntry adding it to your party. Be sure to check its summary!", - "statChange": "Stat changes persist across battles as long as your Pokémon aren't recalled.\n$Your Pokémon are recalled before a trainer battle and before entering a new biome.\n$You can view the stat changes for any Pokémon on the field by holding C or Shift.\n$You can also view the moveset for an enemy Pokémon by holding V.\n$This only reveals moves that you've seen the Pokémon use this battle.", - "selectItem": "After every battle, you are given a choice of 3 random items.\nYou may only pick one.\n$These range from consumables, to Pokémon held items, to passive permanent items.\n$Most non-consumable item effects will stack in various ways.\n$Some items will only show up if they can be used, such as evolution items.\n$You can also transfer held items between Pokémon using the transfer option.\n$The transfer option will appear in the bottom right once you have obtained a held item.\n$You may purchase consumable items with money, and a larger variety will be available the further you get.\n$Be sure to buy these before you pick your random item, as it will progress to the next battle once you do.", - "eggGacha": "From this screen, you can redeem your vouchers for\nPokémon eggs.\n$Eggs have to be hatched and get closer to hatching after\nevery battle. Rarer eggs take longer to hatch.\n$Hatched Pokémon also won't be added to your party, they will\nbe added to your starters.\n$Pokémon hatched from eggs generally have better IVs than\nwild Pokémon.\n$Some Pokémon can only even be obtained from eggs.\n$There are 3 different machines to pull from with different\nbonuses, so pick the one that suits you best!" -} \ No newline at end of file diff --git a/src/locales/en/voucher.json b/src/locales/en/voucher.json deleted file mode 100644 index a92f589870c..00000000000 --- a/src/locales/en/voucher.json +++ /dev/null @@ -1,9 +0,0 @@ -{ - "vouchers": "Vouchers", - "eggVoucher": "Egg Voucher", - "eggVoucherPlus": "Egg Voucher Plus", - "eggVoucherPremium": "Egg Voucher Premium", - "eggVoucherGold": "Egg Voucher Gold", - "locked": "Locked", - "defeatTrainer": "Defeat {{trainerName}}" -} \ No newline at end of file diff --git a/src/locales/en/weather.json b/src/locales/en/weather.json deleted file mode 100644 index 10b6efe9828..00000000000 --- a/src/locales/en/weather.json +++ /dev/null @@ -1,32 +0,0 @@ -{ - "sunnyStartMessage": "The sunlight got bright!", - "sunnyLapseMessage": "The sunlight is strong.", - "sunnyClearMessage": "The sunlight faded.", - "rainStartMessage": "A downpour started!", - "rainLapseMessage": "The downpour continues.", - "rainClearMessage": "The rain stopped.", - "sandstormStartMessage": "A sandstorm brewed!", - "sandstormLapseMessage": "The sandstorm rages.", - "sandstormClearMessage": "The sandstorm subsided.", - "sandstormDamageMessage": "{{pokemonNameWithAffix}} is buffeted\nby the sandstorm!", - "hailStartMessage": "It started to hail!", - "hailLapseMessage": "Hail continues to fall.", - "hailClearMessage": "The hail stopped.", - "hailDamageMessage": "{{pokemonNameWithAffix}} is pelted\nby the hail!", - "snowStartMessage": "It started to snow!", - "snowLapseMessage": "The snow is falling down.", - "snowClearMessage": "The snow stopped.", - "fogStartMessage": "A thick fog emerged!", - "fogLapseMessage": "The fog continues.", - "fogClearMessage": "The fog disappeared.", - "heavyRainStartMessage": "A heavy downpour started!", - "heavyRainLapseMessage": "The heavy downpour continues.", - "heavyRainClearMessage": "The heavy rain stopped.", - "harshSunStartMessage": "The sunlight got hot!", - "harshSunLapseMessage": "The sun is scorching hot.", - "harshSunClearMessage": "The harsh sunlight faded.", - "strongWindsStartMessage": "A heavy wind began!", - "strongWindsLapseMessage": "The wind blows intensely.", - "strongWindsEffectMessage": "The mysterious air current weakened the attack!", - "strongWindsClearMessage": "The heavy wind stopped." -} \ No newline at end of file diff --git a/src/locales/es/ability-trigger.json b/src/locales/es/ability-trigger.json deleted file mode 100644 index 4380c84b8e9..00000000000 --- a/src/locales/es/ability-trigger.json +++ /dev/null @@ -1,64 +0,0 @@ -{ - "blockRecoilDamage": "¡{{abilityName}} de {{pokemonName}}\nlo protegió del daño de retroceso!", - "badDreams": "¡{{pokemonName}} está atormentado!", - "costar": "¡{{pokemonName}} copió los cambios de características de {{allyName}}!", - "iceFaceAvoidedDamage": "¡{{pokemonNameWithAffix}} evitó\ndaño con {{abilityName}}!", - "perishBody": "¡{{abilityName}} de {{pokemonName}} debilitará a ambos Pokémon en 3 turnos!", - "poisonHeal": "¡{{pokemonNameWithAffix}} restauró algunos de sus PS gracias a {{abilityName}}!", - "trace": "¡{{pokemonName}} ha copiado la habilidad {{abilityName}} \nde {{targetName}}!", - "windPowerCharged": "¡{{pokemonName}} se ha cargado de electricidad gracias a {{moveName}}!", - "quickDraw": "¡{{pokemonName}} ataca primero gracias a la habilidad Mano Rápida!", - "disguiseAvoidedDamage": "¡El disfraz de {{pokemonNameWithAffix}} se ha roto!", - "blockItemTheft": "¡{{pokemonNameWithAffix}} evitó el robo gracias a {{abilityName}}!", - "typeImmunityHeal": "¡{{pokemonNameWithAffix}} restauró algunos de sus PS gracias a {{abilityName}}!", - "nonSuperEffectiveImmunity": "¡{{pokemonNameWithAffix}} evitó el daño gracias a {{abilityName}}!", - "fullHpResistType": "¡{{pokemonNameWithAffix}} ha hecho brillar su caparazón\ny ha alterado su compatibilidad entre tipos!", - "moveImmunity": "¡No afecta a {{pokemonNameWithAffix}}!", - "reverseDrain": "¡{{pokemonNameWithAffix}} absorbió lodo líquido!", - "postDefendTypeChange": "¡{{abilityName}} de {{pokemonNameWithAffix}} cambió a tipo {{typeName}}!", - "postDefendContactDamage": "¡{{abilityName}} de {{pokemonNameWithAffix}} ha herido a su atacante!", - "postDefendAbilitySwap": "¡{{pokemonNameWithAffix}} intercambió su habilidad con su objetivo!", - "postDefendAbilityGive": "¡{{pokemonNameWithAffix}} cambió la habilidad del objetivo por {{abilityName}}!", - "postDefendMoveDisable": "¡{{moveName}} de {{pokemonNameWithAffix}} ha sido anulado!", - "pokemonTypeChange": "¡{{pokemonNameWithAffix}} ha cambiado a tipo {{moveType}}!", - "postAttackStealHeldItem": "¡{{pokemonNameWithAffix}} robó {{stolenItemType}} de {{defenderName}}!", - "postDefendStealHeldItem": "¡{{pokemonNameWithAffix}} robó {{stolenItemType}} de {{attackerName}}!", - "copyFaintedAllyAbility": "¡{{abilityName}} de {{pokemonNameWithAffix}} fue copiada!", - "intimidateImmunity": "¡{{abilityName}} de {{pokemonNameWithAffix}} evita que sea intimidado!", - "postSummonAllyHeal": "¡{{pokemonNameWithAffix}} se ha bebido el té que ha preparado {{pokemonName}}!", - "postSummonClearAllyStats": "¡Los cambios de características de {{pokemonNameWithAffix}} fueron eliminados!", - "postSummonTransform": "¡{{pokemonNameWithAffix}} se transformó en {{targetName}}!", - "protectStat": "¡{{abilityName}} de {{pokemonNameWithAffix}} evita que baje su {{statName}}!", - "statusEffectImmunityWithName": "¡{{abilityName}} de {{pokemonNameWithAffix}} evita {{statusEffectName}}!", - "statusEffectImmunity": "¡{{abilityName}} de {{pokemonNameWithAffix}} evita los problemas de estado!", - "battlerTagImmunity": "¡{{abilityName}} de {{pokemonNameWithAffix}} previene {{battlerTagName}}!", - "forewarn": "¡{{pokemonNameWithAffix}} ha detectado el movimiento {{moveName}}!", - "frisk": "¡{{pokemonNameWithAffix}} ha cacheado {{opponentAbilityName}} de {{opponentName}}!", - "postWeatherLapseHeal": "¡{{pokemonNameWithAffix}} restauró algunos de sus PS gracias a {{abilityName}}!", - "postWeatherLapseDamage": "¡{{pokemonNameWithAffix}} se hizo daño por su {{abilityName}}!", - "postTurnLootCreateEatenBerry": "¡{{pokemonNameWithAffix}} recogió una {{berryName}}!", - "postTurnHeal": "¡{{pokemonNameWithAffix}} restauró algunos de sus PS gracias a {{abilityName}}!", - "fetchBall": "¡{{pokemonNameWithAffix}} encontró {{pokeballName}}!", - "healFromBerryUse": "¡{{pokemonNameWithAffix}} se curó gracias a {{abilityName}}!", - "arenaTrap": "¡{{pokemonNameWithAffix}} impide el cambio con {{abilityName}}!", - "postBattleLoot": "¡{{pokemonNameWithAffix}} recogió {{itemName}}!", - "postFaintContactDamage": "¡{{abilityName}} de {{pokemonNameWithAffix}} hizo daño a su atacante!", - "postFaintHpDamage": "¡{{abilityName}} de {{pokemonNameWithAffix}} hizo daño a su atacante!", - "postSummonPressure": "¡{{pokemonNameWithAffix}} ejerce Presión!", - "weatherEffectDisappeared": "El tiempo atmosférico ya no ejerce ninguna influencia.", - "postSummonMoldBreaker": "¡{{pokemonNameWithAffix}} rompió el molde!", - "postSummonAnticipation": "¡{{pokemonNameWithAffix}} se anticipó!", - "postSummonTurboblaze": "¡{{pokemonNameWithAffix}} irradia un aura llameante!", - "postSummonTeravolt": "¡{{pokemonNameWithAffix}} irradia un aura chisporroteante!", - "postSummonDarkAura": "¡{{pokemonNameWithAffix}} irradia un aura oscura!", - "postSummonFairyAura": "¡{{pokemonNameWithAffix}} irradia un aura feérica!", - "postSummonAuraBreak": "¡{{pokemonNameWithAffix}} ha invertido todas las auras!", - "postSummonNeutralizingGas": "¡El Gas Reactivo de {{pokemonNameWithAffix}} se propaga por toda la zona!", - "postSummonAsOneGlastrier": "¡{{pokemonNameWithAffix}} tiene dos Habilidades!", - "postSummonAsOneSpectrier": "¡{{pokemonNameWithAffix}} tiene dos Habilidades!", - "postSummonVesselOfRuin": "¡{{pokemonNameWithAffix}} ha mermado {{statName}} de los demás Pokémon con Caldero Debacle!", - "postSummonSwordOfRuin": "¡{{pokemonNameWithAffix}} ha mermado {{statName}} de los demás Pokémon con Espada Debacle!", - "postSummonTabletsOfRuin": "¡{{pokemonNameWithAffix}} ha mermado {{statName}} de los demás Pokémon con Tablilla Debacle!", - "postSummonBeadsOfRuin": "¡{{pokemonNameWithAffix}} ha mermado {{statName}} de los demás Pokémon con Abalorio Debacle!", - "preventBerryUse": "{{pokemonNameWithAffix}} está muy nervioso y no puede comer bayas!" -} diff --git a/src/locales/es/ability.json b/src/locales/es/ability.json deleted file mode 100644 index 598694f441e..00000000000 --- a/src/locales/es/ability.json +++ /dev/null @@ -1,1242 +0,0 @@ -{ - "stench": { - "name": "Hedor", - "description": "Puede amedrentar a un Pokémon al atacarlo debido al mal olor que emana." - }, - "drizzle": { - "name": "Llovizna", - "description": "Hace que llueva al entrar en combate." - }, - "speedBoost": { - "name": "Impulso", - "description": "Aumenta su Velocidad en cada turno." - }, - "battleArmor": { - "name": "Armadura Batalla", - "description": "La robusta coraza que lo protege bloquea los golpes críticos." - }, - "sturdy": { - "name": "Robustez", - "description": "El Pokémon no puede debilitarse de un solo golpe cuando tiene los PS al máximo. También evita los movimientos fulminantes." - }, - "damp": { - "name": "Humedad", - "description": "Aumenta la humedad del entorno y evita que se puedan utilizar movimientos explosivos, tales como Autodestrucción." - }, - "limber": { - "name": "Flexibilidad", - "description": "Evita ser paralizado gracias a la flexibilidad de su cuerpo." - }, - "sandVeil": { - "name": "Velo Arena", - "description": "Aumenta su Evasión durante las tormentas de arena." - }, - "static": { - "name": "Elec. Estática", - "description": "La electricidad estática que lo envuelve puede paralizar al Pokémon que lo ataque con un movimiento de contacto." - }, - "voltAbsorb": { - "name": "Absorbe Elec", - "description": "Si lo alcanza un movimiento de tipo Eléctrico, recupera PS en vez de sufrir daño." - }, - "waterAbsorb": { - "name": "Absorbe Agua", - "description": "Si lo alcanza un movimiento de tipo Agua, recupera PS en vez de sufrir daño." - }, - "oblivious": { - "name": "Despiste", - "description": "Su indiferencia evita que sea provocado, caiga presa del enamoramiento o sufra los efectos de Intimidación." - }, - "cloudNine": { - "name": "Aclimatación", - "description": "Anula todos los efectos del tiempo atmosférico." - }, - "compoundEyes": { - "name": "Ojo Compuesto", - "description": "Aumenta la precisión de sus movimientos." - }, - "insomnia": { - "name": "Insomnio", - "description": "Su resistencia al sueño le impide quedarse dormido." - }, - "colorChange": { - "name": "Cambio Color", - "description": "Adopta el tipo del último movimiento del que es blanco." - }, - "immunity": { - "name": "Inmunidad", - "description": "Su sistema inmunitario evita el envenenamiento." - }, - "flashFire": { - "name": "Absorbe Fuego", - "description": "Si lo alcanza algún movimiento de tipo Fuego, potencia sus propios movimientos de dicho tipo." - }, - "shieldDust": { - "name": "Polvo Escudo", - "description": "El polvo de escamas que lo envuelve lo protege de los efectos secundarios de los ataques recibidos." - }, - "ownTempo": { - "name": "Ritmo Propio", - "description": "Como le gusta hacer las cosas a su manera, no le afecta la confusión ni sufre los efectos de Intimidación." - }, - "suctionCups": { - "name": "Ventosas", - "description": "Sus ventosas se aferran al suelo, con lo cual anula movimientos y objetos que fuercen el cambio de Pokémon." - }, - "intimidate": { - "name": "Intimidación", - "description": "Al entrar en combate, amilana al rival de tal manera que reduce su Ataque." - }, - "shadowTag": { - "name": "Sombra Trampa", - "description": "Pisa la sombra del rival para impedir que huya o lo cambien por otro." - }, - "roughSkin": { - "name": "Piel Tosca", - "description": "Hiere con su piel áspera al Pokémon que lo ataque con un movimiento de contacto." - }, - "wonderGuard": { - "name": "Superguarda", - "description": "Gracias a un poder misterioso, solo le hacen daño los movimientos supereficaces." - }, - "levitate": { - "name": "Levitación", - "description": "Su capacidad de flotar sobre el suelo le proporciona inmunidad frente a los movimientos de tipo Tierra." - }, - "effectSpore": { - "name": "Efecto Espora", - "description": "Puede dormir, envenenar o paralizar al Pokémon que lo ataque con un movimiento de contacto." - }, - "synchronize": { - "name": "Sincronía", - "description": "Contagia el envenenamiento, las quemaduras o la parálisis al Pokémon que le cause ese estado." - }, - "clearBody": { - "name": "Cuerpo Puro", - "description": "Evita que se reduzcan sus características a causa de movimientos o habilidades de otros Pokémon." - }, - "naturalCure": { - "name": "Cura Natural", - "description": "Sus problemas de estado desaparecen cuando se retira del combate." - }, - "lightningRod": { - "name": "Pararrayos", - "description": "Atrae y neutraliza los movimientos de tipo Eléctrico, que además le aumentan el Ataque Especial." - }, - "sereneGrace": { - "name": "Dicha", - "description": "Aumenta la probabilidad de que los movimientos causen efectos secundarios." - }, - "swiftSwim": { - "name": "Nado Rápido", - "description": "Aumenta su Velocidad cuando llueve." - }, - "chlorophyll": { - "name": "Clorofila", - "description": "Aumenta su Velocidad cuando hace sol." - }, - "illuminate": { - "name": "Iluminación", - "description": "Al iluminar el entorno, evita que su Precisión se reduzca." - }, - "trace": { - "name": "Calco", - "description": "Copia la habilidad del rival al entrar en combate." - }, - "hugePower": { - "name": "Potencia", - "description": "Duplica la potencia de sus ataques físicos." - }, - "poisonPoint": { - "name": "Punto Tóxico", - "description": "Puede envenenar al Pokémon que lo ataque con un movimiento de contacto." - }, - "innerFocus": { - "name": "Fuerza Mental", - "description": "Gracias a su profunda concentración, no se amedrenta ante los ataques de otros Pokémon ni sufre los efectos de Intimidación." - }, - "magmaArmor": { - "name": "Escudo Magma", - "description": "Gracias al magma candente que lo envuelve, no puede ser congelado." - }, - "waterVeil": { - "name": "Velo Agua", - "description": "Evita las quemaduras gracias a la capa de agua que lo envuelve." - }, - "magnetPull": { - "name": "Imán", - "description": "Su magnetismo atrae a los Pokémon de tipo Acero y les impide huir o ser cambiados por otros." - }, - "soundproof": { - "name": "Insonorizar", - "description": "Su aislamiento acústico lo protege de movimientos que usan sonido." - }, - "rainDish": { - "name": "Cura Lluvia", - "description": "Recupera PS de forma gradual cuando llueve." - }, - "sandStream": { - "name": "Chorro Arena", - "description": "Crea una tormenta de arena al entrar en combate." - }, - "pressure": { - "name": "Presión", - "description": "Presiona al rival de tal manera que este consume más PP al usar sus movimientos." - }, - "thickFat": { - "name": "Sebo", - "description": "Gracias a la gruesa capa de grasa que lo protege, reduce a la mitad el daño que recibe de ataques de tipo Fuego o Hielo." - }, - "earlyBird": { - "name": "Madrugar", - "description": "Si se duerme, tardará la mitad de tiempo en despertarse." - }, - "flameBody": { - "name": "Cuerpo Llama", - "description": "Puede quemar al Pokémon que lo ataque con un movimiento de contacto." - }, - "runAway": { - "name": "Fuga", - "description": "Puede escapar de cualquier Pokémon salvaje." - }, - "keenEye": { - "name": "Vista Lince", - "description": "Su aguda vista evita que su Precisión se reduzca." - }, - "hyperCutter": { - "name": "Corte Fuerte", - "description": "Evita que otros Pokémon le reduzcan el Ataque." - }, - "pickup": { - "name": "Recogida", - "description": "Puede que recoja un objeto del enemigo tras cada batalla, al azar." - }, - "truant": { - "name": "Pereza", - "description": "Al ejecutar un movimiento, descansará en el turno siguiente." - }, - "hustle": { - "name": "Entusiasmo", - "description": "Aumenta su ataque, pero reduce su precisión." - }, - "cuteCharm": { - "name": "Gran Encanto", - "description": "Puede causar enamoramiento al Pokémon que lo ataque con un movimiento de contacto." - }, - "plus": { - "name": "Más", - "description": "Aumenta su ataque especial si un Pokémon aliado tiene la habilidad Más o la habilidad Menos." - }, - "minus": { - "name": "Menos", - "description": "Aumenta su ataque especial si un Pokémon aliado tiene la habilidad Más o la habilidad Menos." - }, - "forecast": { - "name": "Predicción", - "description": "Cambia a tipo Agua, Fuego o Hielo en función del tiempo atmosférico." - }, - "stickyHold": { - "name": "Viscosidad", - "description": "Los objetos se quedan pegados a su cuerpo, por lo que no pueden robárselos." - }, - "shedSkin": { - "name": "Mudar", - "description": "Puede curar sus problemas de estado al mudar la piel." - }, - "guts": { - "name": "Agallas", - "description": "Si sufre un problema de estado, se arma de valor y aumenta su ataque." - }, - "marvelScale": { - "name": "Escama Especial", - "description": "Si sufre un problema de estado, sus escamas especiales reaccionan y aumenta su defensa." - }, - "liquidOoze": { - "name": "Viscosecreción", - "description": "Exuda una secreción viscosa y tóxica de intenso hedor que hiere a quienes intentan drenarle PS." - }, - "overgrow": { - "name": "Espesura", - "description": "Potencia sus movimientos de tipo Planta cuando le quedan pocos PS." - }, - "blaze": { - "name": "Mar Llamas", - "description": "Potencia sus movimientos de tipo Fuego cuando le quedan pocos PS." - }, - "torrent": { - "name": "Torrente", - "description": "Potencia sus movimientos de tipo Agua cuando le quedan pocos PS." - }, - "swarm": { - "name": "Enjambre", - "description": "Potencia sus movimientos de tipo Bicho cuando le quedan pocos PS." - }, - "rockHead": { - "name": "Cabeza Roca", - "description": "No pierde PS al usar movimientos que también hieren al usuario." - }, - "drought": { - "name": "Sequía", - "description": "El tiempo pasa a ser soleado al entrar en combate." - }, - "arenaTrap": { - "name": "Trampa Arena", - "description": "Evita que el rival huya o sea cambiado por otro." - }, - "vitalSpirit": { - "name": "Espíritu Vital", - "description": "Su determinación le impide quedarse dormido." - }, - "whiteSmoke": { - "name": "Humo Blanco", - "description": "El humo blanco que lo protege evita que otros Pokémon le reduzcan las características." - }, - "purePower": { - "name": "Energía Pura", - "description": "Duplica la potencia de sus ataques físicos gracias al yoga." - }, - "shellArmor": { - "name": "Caparazón", - "description": "La robusta coraza que lo protege bloquea los golpes críticos." - }, - "airLock": { - "name": "Esclusa de Aire", - "description": "Neutraliza todos los efectos del tiempo atmosférico." - }, - "tangledFeet": { - "name": "Tumbos", - "description": "Aumenta su evasión si está confuso." - }, - "motorDrive": { - "name": "Electromotor", - "description": "Si lo alcanza un movimiento de tipo Eléctrico, aumenta su velocidad en vez de sufrir daño." - }, - "rivalry": { - "name": "Rivalidad", - "description": "Si el objetivo es del mismo sexo, su competitividad le lleva a infligir más daño. Si es del sexo contrario, en cambio, el daño será menor." - }, - "steadfast": { - "name": "Impasible", - "description": "Cada vez que se amedrenta, aumenta su velocidad debido a su voluntad inquebrantable." - }, - "snowCloak": { - "name": "Manto Níveo", - "description": "Aumenta su evasión cuando nieva." - }, - "gluttony": { - "name": "Gula", - "description": "Cuando sus PS se ven reducidos a la mitad, engulle la baya que normalmente solo se comería cuando le quedasen pocos PS." - }, - "angerPoint": { - "name": "Irascible", - "description": "Si recibe un golpe crítico, monta en cólera y su ataque aumenta al máximo." - }, - "unburden": { - "name": "Liviano", - "description": "Aumenta su velocidad si usa o pierde el objeto que lleva." - }, - "heatproof": { - "name": "Ignífugo", - "description": "Su cuerpo, resistente al calor, reduce a la mitad el daño recibido por movimientos de tipo Fuego." - }, - "simple": { - "name": "Simple", - "description": "Duplica los cambios en las características." - }, - "drySkin": { - "name": "Piel Seca", - "description": "Pierde PS si hace sol y los recupera si llueve o recibe un movimiento de tipo Agua. Los movimientos de tipo Fuego, por su parte, le hacen más daño de lo normal." - }, - "download": { - "name": "Descarga", - "description": "Compara la defensa y la defensa especial del rival para ver cuál es inferior y aumenta su propio ataque o ataque especial según sea lo más eficaz." - }, - "ironFist": { - "name": "Puño Férreo", - "description": "Aumenta la potencia de los movimientos con los puños." - }, - "poisonHeal": { - "name": "Antídoto", - "description": "Si resulta envenenado, recupera PS en vez de perderlos." - }, - "adaptability": { - "name": "Adaptable", - "description": "Potencia aún más los movimientos cuyo tipo coincida con el suyo." - }, - "skillLink": { - "name": "Encadenado", - "description": "Ejecuta siempre los movimientos de ataque múltiple con el número máximo de golpes." - }, - "hydration": { - "name": "Hidratación", - "description": "Cura los problemas de estado si está lloviendo." - }, - "solarPower": { - "name": "Poder Solar", - "description": "Si hace sol, aumenta su ataque especial, pero pierde PS en cada turno." - }, - "quickFeet": { - "name": "Pies Rápidos", - "description": "Aumenta su velocidad si sufre problemas de estado." - }, - "normalize": { - "name": "Normalidad", - "description": "Hace que todos sus movimientos se vuelvan de tipo Normal y aumenta ligeramente su potencia." - }, - "sniper": { - "name": "Francotirador", - "description": "Potencia los golpes críticos que asesta aún más de lo normal." - }, - "magicGuard": { - "name": "Muro Mágico", - "description": "Solo recibe daño de ataques." - }, - "noGuard": { - "name": "Indefenso", - "description": "Al quedar ambos expuestos, tanto sus movimientos como los del Pokémon que lo ataque acertarán siempre." - }, - "stall": { - "name": "Rezagado", - "description": "Ejecuta su movimiento tras todos los demás." - }, - "technician": { - "name": "Experto", - "description": "Aumenta la potencia de sus movimientos débiles." - }, - "leafGuard": { - "name": "Defensa Hoja", - "description": "Evita los problemas de estado si hace sol." - }, - "klutz": { - "name": "Zoquete", - "description": "No puede usar objetos equipados." - }, - "moldBreaker": { - "name": "Rompemoldes", - "description": "Sus movimientos no se ven afectados por la habilidad del objetivo." - }, - "superLuck": { - "name": "Afortunado", - "description": "Su buena suerte aumenta la probabilidad de asestar golpes críticos." - }, - "aftermath": { - "name": "Detonación", - "description": "Daña al Pokémon que le ha dado el golpe de gracia con un movimiento de contacto." - }, - "anticipation": { - "name": "Anticipación", - "description": "Prevé los movimientos peligrosos del rival." - }, - "forewarn": { - "name": "Alerta", - "description": "Revela uno de los movimientos del rival al entrar en combate." - }, - "unaware": { - "name": "Ignorante", - "description": "Pasa por alto los cambios en las características de un Pokémon al atacarlo o recibir daño." - }, - "tintedLens": { - "name": "Cromolente", - "description": "Potencia los movimientos que no son muy eficaces, que infligen ahora un daño normal." - }, - "filter": { - "name": "Filtro", - "description": "Mitiga el daño que le infligen los movimientos supereficaces." - }, - "slowStart": { - "name": "Inicio Lento", - "description": "Reduce a la mitad su ataque y su velocidad durante cinco turnos." - }, - "scrappy": { - "name": "Intrépido", - "description": "Alcanza a Pokémon de tipo Fantasma con movimientos de tipo Normal o Lucha. Además, no sufre los efectos de Intimidación." - }, - "stormDrain": { - "name": "Colector", - "description": "Atrae y neutraliza los movimientos de tipo Agua, que además le aumentan el ataque especial." - }, - "iceBody": { - "name": "Gélido", - "description": "Recupera PS de forma gradual cuando nieva." - }, - "solidRock": { - "name": "Roca Sólida", - "description": "Mitiga el daño que le infligen los movimientos supereficaces." - }, - "snowWarning": { - "name": "Nevada", - "description": "Invoca una nevada al entrar en combate." - }, - "honeyGather": { - "name": "Recogemiel", - "description": "El Pokémon recoge miel tras cada batalla. La miel se vende inmediatamente por ₽." - }, - "frisk": { - "name": "Cacheo", - "description": "Cuando entra en combate, el Pokémon puede comprobar la habilidad de un Pokémon rival." - }, - "reckless": { - "name": "Audaz", - "description": "Potencia los movimientos que también dañan al usuario." - }, - "multitype": { - "name": "Multitipo", - "description": "Cambia su tipo al de la tabla que lleve." - }, - "flowerGift": { - "name": "Don Floral", - "description": "Si hace sol, aumenta su ataque y su defensa Especial, así como los de sus aliados." - }, - "badDreams": { - "name": "Mal Sueño", - "description": "Inflige daño a cualquier rival que esté dormido." - }, - "pickpocket": { - "name": "Hurto", - "description": "Roba el objeto del Pokémon que lo ataque con un movimiento de contacto." - }, - "sheerForce": { - "name": "Potencia Bruta", - "description": "Aumenta la potencia de sus movimientos en detrimento de los efectos secundarios, que se ven anulados." - }, - "contrary": { - "name": "Respondón", - "description": "Invierte los cambios en las características: bajan cuando les toca subir y suben cuando les toca bajar." - }, - "unnerve": { - "name": "Nerviosismo", - "description": "Pone nervioso al rival y le impide comer bayas." - }, - "defiant": { - "name": "Competitivo", - "description": "Aumenta mucho su ataque cuando el rival le reduce cualquiera de sus características." - }, - "defeatist": { - "name": "Flaqueza", - "description": "Cuando sus PS se ven reducidos a la mitad, se cansa tanto que su ataque y su ataque Especial también se ven reducidos a la mitad." - }, - "cursedBody": { - "name": "Cuerpo Maldito", - "description": "Puede anular el movimiento usado en su contra." - }, - "healer": { - "name": "Alma Cura", - "description": "A veces cura los problemas de estado de un aliado." - }, - "friendGuard": { - "name": "Compiescolta", - "description": "Reduce el daño que sufren los aliados." - }, - "weakArmor": { - "name": "Armadura Frágil", - "description": "Al recibir daño de un ataque físico, se reduce su defensa, pero aumenta mucho su velocidad." - }, - "heavyMetal": { - "name": "Metal Pesado", - "description": "Duplica su peso." - }, - "lightMetal": { - "name": "Metal Liviano", - "description": "Reduce a la mitad su peso." - }, - "multiscale": { - "name": "Multiescamas", - "description": "Reduce el daño que sufre si sus PS están al máximo." - }, - "toxicBoost": { - "name": "Ímpetu Tóxico", - "description": "Aumenta la potencia de sus ataques físicos cuando está envenenado." - }, - "flareBoost": { - "name": "Ímpetu Ardiente", - "description": "Aumenta la potencia de sus ataques especiales cuando sufre quemaduras." - }, - "harvest": { - "name": "Cosecha", - "description": "Puede reutilizar varias veces una misma baya." - }, - "telepathy": { - "name": "Telepatía", - "description": "Elude los ataques de los aliados durante el combate." - }, - "moody": { - "name": "Veleta", - "description": "Aumenta mucho una característica en cada turno, pero reduce otra." - }, - "overcoat": { - "name": "Funda", - "description": "No recibe daño de las tormentas de arena ni sufre los efectos causados por polvos o esporas." - }, - "poisonTouch": { - "name": "Toque Tóxico", - "description": "Puede envenenar al Pokémon al que ataque con un movimiento de contacto." - }, - "regenerator": { - "name": "Regeneración", - "description": "Recupera unos pocos PS cuando se retira del combate." - }, - "bigPecks": { - "name": "Sacapecho", - "description": "Impide que otros Pokémon le reduzcan la defensa." - }, - "sandRush": { - "name": "Ímpetu Arena", - "description": "Aumenta su velocidad durante las tormentas de arena." - }, - "wonderSkin": { - "name": "Piel Milagro", - "description": "Presenta una mayor resistencia ante los movimientos de estado." - }, - "analytic": { - "name": "Cálculo Final", - "description": "Aumenta la potencia de su movimiento si es el último en atacar." - }, - "illusion": { - "name": "Ilusión", - "description": "Adopta el aspecto del último Pokémon del equipo al entrar en combate para desconcertar al rival." - }, - "imposter": { - "name": "Impostor", - "description": "Se transforma en el Pokémon que tiene enfrente." - }, - "infiltrator": { - "name": "Allanamiento", - "description": "Ataca sorteando las barreras o el sustituto del objetivo." - }, - "mummy": { - "name": "Momia", - "description": "Contagia la habilidad Momia al Pokémon que lo ataque con un movimiento de contacto." - }, - "moxie": { - "name": "Autoestima", - "description": "Al debilitar a un objetivo, su confianza se refuerza de tal manera que aumenta su ataque." - }, - "justified": { - "name": "Justiciero", - "description": "Si lo alcanza un movimiento de tipo Siniestro, aumenta el ataque debido a su integridad." - }, - "rattled": { - "name": "Cobardía", - "description": "Si lo alcanza un ataque de tipo Siniestro, Bicho o Fantasma, o si sufre los efectos de Intimidación, el miedo hace que aumente su velocidad." - }, - "magicBounce": { - "name": "Espejo Mágico", - "description": "Puede devolver los movimientos de estado sin verse afectado por ellos." - }, - "sapSipper": { - "name": "Herbívoro", - "description": "Si lo alcanza un movimiento de tipo Planta, aumenta su ataque en vez de sufrir daño." - }, - "prankster": { - "name": "Bromista", - "description": "Sus movimientos de estado tienen prioridad alta." - }, - "sandForce": { - "name": "Poder Arena", - "description": "Potencia los movimientos de tipo Tierra, Acero y Roca durante las tormentas de arena." - }, - "ironBarbs": { - "name": "Punta Acero", - "description": "Inflige daño con sus púas de acero al Pokémon que lo ataque con un movimiento de contacto." - }, - "zenMode": { - "name": "Modo Daruma", - "description": "Cambia de forma si sus PS se ven reducidos a la mitad o menos." - }, - "victoryStar": { - "name": "Tinovictoria", - "description": "Aumenta su precisión y la de sus aliados." - }, - "turboblaze": { - "name": "Turbollama", - "description": "Sus movimientos no se ven afectados por la habilidad del objetivo." - }, - "teravolt": { - "name": "Terravoltaje", - "description": "Sus movimientos no se ven afectados por la habilidad del objetivo." - }, - "aromaVeil": { - "name": "Velo Aroma", - "description": "Se protege a sí mismo y a sus aliados de efectos que impiden usar movimientos." - }, - "flowerVeil": { - "name": "Velo Flor", - "description": "Evita que los Pokémon de tipo Planta aliados sufran problemas de estado o que les reduzcan sus características." - }, - "cheekPouch": { - "name": "Carrillo", - "description": "Recupera PS al comer cualquier baya." - }, - "protean": { - "name": "Mutatipo", - "description": "Al entrar en combate, cambia su tipo al del primer movimiento que va a usar." - }, - "furCoat": { - "name": "Pelaje Recio", - "description": "Reduce a la mitad el daño que recibe de ataques físicos." - }, - "magician": { - "name": "Prestidigitador", - "description": "Roba el objeto del Pokémon al que alcance con un movimiento." - }, - "bulletproof": { - "name": "Antibalas", - "description": "No le afectan las bombas ni algunos proyectiles." - }, - "competitive": { - "name": "Tenacidad", - "description": "Aumenta mucho su ataque especial cuando el rival le reduce cualquiera de sus características." - }, - "strongJaw": { - "name": "Mandíbula Fuerte", - "description": "Su robusta mandíbula le confiere una mordedura mucho más potente." - }, - "refrigerate": { - "name": "Piel Helada", - "description": "Convierte los movimientos de tipo Normal en tipo Hielo y aumenta ligeramente su potencia." - }, - "sweetVeil": { - "name": "Velo Dulce", - "description": "No cae dormido y evita también que sus aliados se duerman." - }, - "stanceChange": { - "name": "Cambio Táctico", - "description": "Adopta la Forma Filo al lanzar un ataque, o bien la Forma Escudo si usa el movimiento Escudo Real." - }, - "galeWings": { - "name": "Alas Vendaval", - "description": "Da prioridad a los movimientos de tipo Volador si sus PS están al máximo." - }, - "megaLauncher": { - "name": "Megadisparador", - "description": "Aumenta la potencia de algunos movimientos de pulsos y auras." - }, - "grassPelt": { - "name": "Manto Frondoso", - "description": "Aumenta su defensa si hay un campo de hierba en el terreno de combate." - }, - "symbiosis": { - "name": "Simbiosis", - "description": "Pasa su objeto a un aliado cuando este use el suyo." - }, - "toughClaws": { - "name": "Garra Dura", - "description": "Aumenta la potencia de los movimientos de contacto." - }, - "pixilate": { - "name": "Piel Feérica", - "description": "Convierte los movimientos de tipo Normal en tipo Hada y aumenta ligeramente su potencia." - }, - "gooey": { - "name": "Baba", - "description": "Reduce la velocidad del Pokémon que lo ataque con un movimiento de contacto." - }, - "aerilate": { - "name": "Piel Celeste", - "description": "Convierte los movimientos de tipo Normal en tipo Volador y aumenta ligeramente su potencia." - }, - "parentalBond": { - "name": "Amor Filial", - "description": "Une fuerzas con su cría y ataca dos veces." - }, - "darkAura": { - "name": "Aura Oscura", - "description": "Aumenta la potencia de los movimientos de tipo Siniestro de todos los Pokémon." - }, - "fairyAura": { - "name": "Aura Feérica", - "description": "Aumenta la potencia de los movimientos de tipo Hada de todos los Pokémon." - }, - "auraBreak": { - "name": "Rompeaura", - "description": "Invierte los efectos de las habilidades de auras, por lo que reduce la potencia de ciertos movimientos en vez de aumentarla." - }, - "primordialSea": { - "name": "Mar del Albor", - "description": "Altera el clima para anular los ataques de tipo Fuego." - }, - "desolateLand": { - "name": "Tierra del Ocaso", - "description": "Altera el clima para anular los ataques de tipo Agua." - }, - "deltaStream": { - "name": "Ráfaga Delta", - "description": "Altera el clima para anular las vulnerabilidades del tipo Volador." - }, - "stamina": { - "name": "Firmeza", - "description": "Aumenta su defensa al recibir un ataque." - }, - "wimpOut": { - "name": "Huida", - "description": "Se asusta y abandona el terreno de combate cuando sus PS se ven reducidos a la mitad." - }, - "emergencyExit": { - "name": "Retirada", - "description": "Abandona el terreno de combate cuando sus PS se ven reducidos a la mitad para evitar males mayores." - }, - "waterCompaction": { - "name": "Hidrorrefuerzo", - "description": "Aumenta mucho su defensa si lo alcanza un movimiento de tipo Agua." - }, - "merciless": { - "name": "Ensañamiento", - "description": "Hace que sus movimientos asesten siempre un golpe crítico si el objetivo está envenenado." - }, - "shieldsDown": { - "name": "Escudo Limitado", - "description": "Rompe su coraza cuando sus PS se ven reducidos a la mitad y adopta una forma ofensiva." - }, - "stakeout": { - "name": "Vigilante", - "description": "Si el objetivo de su ataque es sustituido por otro, duplica el daño que infligirá." - }, - "waterBubble": { - "name": "Pompa", - "description": "Reduce el daño que le provocan los movimientos de tipo Fuego y es inmune a las quemaduras." - }, - "steelworker": { - "name": "Acero Templado", - "description": "Potencia los movimientos de tipo Acero." - }, - "berserk": { - "name": "Cólera", - "description": "Aumenta su ataque especial si sus PS se ven reducidos a la mitad debido a algún ataque." - }, - "slushRush": { - "name": "Quitanieves", - "description": "Aumenta su velocidad cuando nieva." - }, - "longReach": { - "name": "Remoto", - "description": "Puede usar cualquier movimiento sin entrar en contacto con su objetivo." - }, - "liquidVoice": { - "name": "Voz Fluida", - "description": "Hace que todos sus movimientos que usan sonido pasen a ser de tipo Agua." - }, - "triage": { - "name": "Primer Auxilio", - "description": "Da prioridad a los movimientos que restauran PS." - }, - "galvanize": { - "name": "Piel Eléctrica", - "description": "Convierte los movimientos de tipo Normal en tipo Eléctrico y aumenta ligeramente su potencia." - }, - "surgeSurfer": { - "name": "Cola Surf", - "description": "Duplica su velocidad si hay un campo eléctrico en el terreno de combate." - }, - "schooling": { - "name": "Banco", - "description": "Forma bancos con sus congéneres cuando tiene muchos PS, lo cual le otorga más fuerza. Cuando le quedan pocos PS, el banco se dispersa." - }, - "disguise": { - "name": "Disfraz", - "description": "Puede eludir un ataque valiéndose de la tela que le cubre el cuerpo una vez por combate." - }, - "battleBond": { - "name": "Fuerte Afecto", - "description": "Al derrotar a un Pokémon, los vínculos con su Entrenador se refuerzan y aumentan su ataque, su ataque especial y su velocidad." - }, - "powerConstruct": { - "name": "Agrupamiento", - "description": "Cuando sus PS se ven reducidos a la mitad, las células se reagrupan y adopta su Forma Completa." - }, - "corrosion": { - "name": "Corrosión", - "description": "Puede envenenar incluso a Pokémon de tipo Acero o Veneno." - }, - "comatose": { - "name": "Letargo Perenne", - "description": "No despierta jamás de su profundo letargo e incluso ataca dormido." - }, - "queenlyMajesty": { - "name": "Regia Presencia", - "description": "Intimida al rival y le impide usar movimientos con prioridad contra él y sus aliados." - }, - "innardsOut": { - "name": "Revés", - "description": "Al caer debilitado, inflige al atacante un daño equivalente a los PS que le quedaran antes de recibir el golpe de gracia." - }, - "dancer": { - "name": "Pareja de Baile", - "description": "Puede copiar inmediatamente cualquier movimiento de baile que haya usado otro Pokémon presente en el combate." - }, - "battery": { - "name": "Batería", - "description": "Potencia los ataques especiales de los aliados." - }, - "fluffy": { - "name": "Peluche", - "description": "Reduce a la mitad el daño recibido por los movimientos de contacto, pero duplica el que le infligen los de tipo Fuego." - }, - "dazzling": { - "name": "Cuerpo Vívido", - "description": "Desconcierta al rival y le impide usar movimientos con prioridad contra él y sus aliados." - }, - "soulHeart": { - "name": "Coránima", - "description": "Aumenta su ataque especial cada vez que un Pokémon cae debilitado." - }, - "tanglingHair": { - "name": "Rizos Rebeldes", - "description": "Reduce la velocidad del Pokémon que lo ataque con un movimiento de contacto." - }, - "receiver": { - "name": "Receptor", - "description": "Adquiere la habilidad de un aliado debilitado." - }, - "powerOfAlchemy": { - "name": "Reacción Química", - "description": "Reacciona copiando la habilidad de un aliado debilitado." - }, - "beastBoost": { - "name": "Ultraimpulso", - "description": "Al derrotar a un Pokémon, aumenta su característica más fuerte." - }, - "rksSystem": { - "name": "Sistema Alfa", - "description": "Cambia su tipo según el disco que lleve instalado." - }, - "electricSurge": { - "name": "Electrogénesis", - "description": "Crea un campo eléctrico al entrar en combate." - }, - "psychicSurge": { - "name": "Psicogénesis", - "description": "Crea un campo psíquico al entrar en combate." - }, - "mistySurge": { - "name": "Nebulogénesis", - "description": "Crea un campo de niebla al entrar en combate." - }, - "grassySurge": { - "name": "Herbogénesis", - "description": "Crea un campo de hierba al entrar en combate." - }, - "fullMetalBody": { - "name": "Guardia Metálica", - "description": "Evita que se reduzcan sus características a causa de movimientos o habilidades de otros Pokémon." - }, - "shadowShield": { - "name": "Guardia Espectro", - "description": "Reduce el daño que sufre si sus PS están al máximo." - }, - "prismArmor": { - "name": "Armadura Prisma", - "description": "Mitiga el daño que le infligen los movimientos supereficaces." - }, - "neuroforce": { - "name": "Fuerza Cerebral", - "description": "Potencia los ataques supereficaces." - }, - "intrepidSword": { - "name": "Espada Indómita", - "description": "Aumenta su ataque al entrar en combate por primera vez." - }, - "dauntlessShield": { - "name": "Escudo Recio", - "description": "Aumenta su defensa al entrar en combate por primera vez." - }, - "libero": { - "name": "Líbero", - "description": "Al entrar en combate, cambia su tipo al del primer movimiento que va a usar." - }, - "ballFetch": { - "name": "Recogebolas", - "description": "Recupera la Poké Ball del primer intento de captura fallido." - }, - "cottonDown": { - "name": "Pelusa", - "description": "Al ser alcanzado por un ataque, suelta una pelusa de algodón que reduce la velocidad de todos los demás Pokémon." - }, - "propellerTail": { - "name": "Hélice Caudal", - "description": "Ignora los efectos de las habilidades o los movimientos que permiten a un Pokémon centrar la atención sobre sí." - }, - "mirrorArmor": { - "name": "Coraza Reflejo", - "description": "Refleja los efectos que reducen las características." - }, - "gulpMissile": { - "name": "Tragamisil", - "description": "Tras usar Surf o Buceo, emerge con una presa en la boca. Al recibir daño, ataca escupiéndola." - }, - "stalwart": { - "name": "Acérrimo", - "description": "Ignora los efectos de las habilidades o los movimientos que permiten a un Pokémon centrar la atención sobre sí." - }, - "steamEngine": { - "name": "Combustible", - "description": "Si lo alcanza un movimiento de tipo Fuego o Agua, aumenta muchísimo su velocidad." - }, - "punkRock": { - "name": "Punk Rock", - "description": "Potencia los movimientos que usan sonido y reduce a la mitad el daño que le infligen dichos movimientos." - }, - "sandSpit": { - "name": "Expulsarena", - "description": "Provoca una tormenta de arena al recibir un ataque." - }, - "iceScales": { - "name": "Escama de Hielo", - "description": "Las gélidas escamas que protegen su cuerpo reducen a la mitad el daño que le infligen los ataques especiales." - }, - "ripen": { - "name": "Maduración", - "description": "Hace madurar las bayas, por lo que duplica sus efectos." - }, - "iceFace": { - "name": "Cara de Hielo", - "description": "Absorbe el daño de un ataque físico con el hielo de la cabeza, tras lo cual cambia de forma. El hielo se regenerará la próxima vez que nieve." - }, - "powerSpot": { - "name": "Fuente Energía", - "description": "Potencia los movimientos de los Pokémon adyacentes." - }, - "mimicry": { - "name": "Mimetismo", - "description": "Cambia su tipo según el campo que haya en el terreno de combate." - }, - "screenCleaner": { - "name": "Antibarrera", - "description": "Anula los efectos de Pantalla de Luz, Reflejo y Velo Aurora tanto de rivales como de aliados al entrar en combate." - }, - "steelySpirit": { - "name": "Alma Acerada", - "description": "Potencia los movimientos de tipo Acero del Pokémon y sus aliados." - }, - "perishBody": { - "name": "Cuerpo Mortal", - "description": "Si lo alcanza un movimiento de contacto, se debilitará al cabo de 3 turnos, así como el atacante, a menos que abandonen el terreno de combate." - }, - "wanderingSpirit": { - "name": "Alma Errante", - "description": "Si lo alcanza un movimiento de contacto, intercambia su habilidad con la del atacante." - }, - "gorillaTactics": { - "name": "Monotema", - "description": "Aumenta su ataque, pero solo puede usar el primer movimiento escogido." - }, - "neutralizingGas": { - "name": "Gas Reactivo", - "description": "Anula los efectos de las habilidades de los demás Pokémon presentes mientras esté en el terreno de combate." - }, - "pastelVeil": { - "name": "Velo Pastel", - "description": "Se protege a sí mismo y a sus aliados del envenenamiento." - }, - "hungerSwitch": { - "name": "Mutapetito", - "description": "Alterna entre su Forma Saciada y Forma Voraz al final de cada turno." - }, - "quickDraw": { - "name": "Mano Rápida", - "description": "A veces, puede atacar el primero." - }, - "unseenFist": { - "name": "Puño Invisible", - "description": "Si usa un movimiento de contacto, puede infligir daño al objetivo aunque este se proteja." - }, - "curiousMedicine": { - "name": "Medicina Extraña", - "description": "Al entrar en combate, rezuma una substancia medicinal por la caracola que revierte los cambios en las características de los aliados." - }, - "transistor": { - "name": "Transistor", - "description": "Potencia los movimientos de tipo Eléctrico." - }, - "dragonsMaw": { - "name": "Mandíbula Dragón", - "description": "Potencia los movimientos de tipo Dragón." - }, - "chillingNeigh": { - "name": "Relincho Blanco", - "description": "Al derrotar a un objetivo, emite un relincho gélido y aumenta su ataque." - }, - "grimNeigh": { - "name": "Relincho Negro", - "description": "Al derrotar a un objetivo, emite un relincho aterrador y aumenta su ataque especial." - }, - "asOneGlastrier": { - "name": "Unidad Ecuestre", - "description": "El Pokémon tiene dos habilidades: Relincho Negro de Spectrier y Nerviosismo de Calyrex." - }, - "asOneSpectrier": { - "name": "Unidad Ecuestre", - "description": "El Pokémon tiene dos habilidades: Relincho Negro de Spectrier y Nerviosismo de Calyrex." - }, - "lingeringAroma": { - "name": "Olor Persistente", - "description": "Contagia la habilidad Olor Persistente al Pokémon que lo ataque con un movimiento de contacto." - }, - "seedSower": { - "name": "Disemillar", - "description": "Crea un campo de hierba al recibir un ataque." - }, - "thermalExchange": { - "name": "Termoconversión", - "description": "Evita las quemaduras y, si lo alcanza un movimiento de tipo Fuego, aumenta su ataque." - }, - "angerShell": { - "name": "Coraza Ira", - "description": "Cuando un ataque reduce sus PS a la mitad, un arrebato de cólera reduce su defensa y su defensa especial, pero aumenta su ataque, su ataque especial y su velocidad." - }, - "purifyingSalt": { - "name": "Sal Purificadora", - "description": "Su sal pura lo protege de los problemas de estado y reduce a la mitad el daño que recibe de ataques de tipo Fantasma." - }, - "wellBakedBody": { - "name": "Cuerpo Horneado", - "description": "Si lo alcanza un movimiento de tipo Fuego, aumenta mucho su defensa en vez de sufrir daño." - }, - "windRider": { - "name": "Surcavientos", - "description": "Si sopla un Viento Afín o lo alcanza un movimiento que usa viento, aumenta su ataque. Tampoco recibe daño de este último." - }, - "guardDog": { - "name": "Perro Guardián", - "description": "Aumenta su ataque si sufre los efectos de Intimidación. También anula movimientos y objetos que fuercen el cambio de Pokémon." - }, - "rockyPayload": { - "name": "Transportarrocas", - "description": "Potencia los movimientos de tipo Roca." - }, - "windPower": { - "name": "Energía Eólica", - "description": "Su cuerpo se carga de electricidad si lo alcanza un movimiento que usa viento, lo que potencia su siguiente movimiento de tipo Eléctrico." - }, - "zeroToHero": { - "name": "Cambio Heroico", - "description": "Adopta la Forma Heroica cuando se retira del combate." - }, - "commander": { - "name": "Comandar", - "description": "Si al entrar en combate coincide con un Dondozo aliado, se cuela en el interior de su boca para tomar el control." - }, - "electromorphosis": { - "name": "Dinamo", - "description": "Su cuerpo se carga de electricidad al recibir daño, lo que potencia su siguiente movimiento de tipo Eléctrico." - }, - "protosynthesis": { - "name": "Paleosíntesis", - "description": "Si hace sol o lleva un tanque de Energía Potenciadora, aumenta su característica más alta." - }, - "quarkDrive": { - "name": "Carga Cuark", - "description": "Si hay un campo eléctrico en el terreno de combate o lleva un tanque de Energía Potenciadora, aumenta su característica más alta." - }, - "goodAsGold": { - "name": "Cuerpo Áureo", - "description": "Su robusto cuerpo de oro inoxidable lo hace inmune frente a movimientos de estado de otros Pokémon." - }, - "vesselOfRuin": { - "name": "Caldero Debacle", - "description": "Reduce el ataque especial de todos los demás Pokémon con el poder de su caldero maldito." - }, - "swordOfRuin": { - "name": "Espada Debacle", - "description": "Reduce la defensa de todos los demás Pokémon con el poder de su espada maldita." - }, - "tabletsOfRuin": { - "name": "Tablilla Debacle", - "description": "Reduce el ataque de todos los demás Pokémon con el poder de sus tablillas malditas." - }, - "beadsOfRuin": { - "name": "Abalorio Debacle", - "description": "Reduce la defensa especial de todos los demás Pokémon con el poder de sus abalorios malditos." - }, - "orichalcumPulse": { - "name": "Latido Oricalco", - "description": "El tiempo pasa a ser soleado cuando entra en combate. Si hace mucho sol, su ataque aumenta gracias a su pulso primigenio." - }, - "hadronEngine": { - "name": "Motor Hadrónico", - "description": "Crea un campo eléctrico al entrar en combate. Si hay un campo eléctrico, su ataque especial aumenta gracias a su motor futurista." - }, - "opportunist": { - "name": "Oportunista", - "description": "Copia las mejoras en las características del rival, aprovechándose de la situación." - }, - "cudChew": { - "name": "Rumia", - "description": "Cuando ingiere una baya, la regurgita al final del siguiente turno y se la come por segunda vez." - }, - "sharpness": { - "name": "Cortante", - "description": "Aumenta la potencia de los movimientos cortantes." - }, - "supremeOverlord": { - "name": "General Supremo", - "description": "Al entrar en combate, su ataque y su ataque especial aumentan un poco por cada miembro del equipo que haya sido derrotado hasta el momento." - }, - "costar": { - "name": "Unísono", - "description": "Al entrar en combate, copia los cambios en las características de su aliado." - }, - "toxicDebris": { - "name": "Capa Tóxica", - "description": "Al recibir daño de un ataque físico, lanza una trampa de púas tóxicas a los pies del rival." - }, - "armorTail": { - "name": "Cola Armadura", - "description": "La extraña cola que le envuelve la cabeza impide al rival usar movimientos con prioridad contra él y sus aliados." - }, - "earthEater": { - "name": "Geofagia", - "description": "Si lo alcanza un movimiento de tipo Tierra, recupera PS en vez de sufrir daño." - }, - "myceliumMight": { - "name": "Poder Fúngico", - "description": "El Pokémon siempre actúa con lentitud cuando usa movimientos de estado, pero estos no se ven afectados por la habilidad del objetivo." - }, - "mindsEye": { - "name": "Ojo Mental", - "description": "Alcanza a Pokémon de tipo Fantasma con movimientos de tipo Normal o Lucha. Su precisión no se puede reducir e ignora los cambios en la evasión del objetivo." - }, - "supersweetSyrup": { - "name": "Néctar Dulce", - "description": "Al entrar en combate por primera vez, esparce un aroma dulzón a néctar que reduce la evasión del rival." - }, - "hospitality": { - "name": "Hospitalidad", - "description": "Al entrar en combate, restaura algunos PS de su aliado como muestra de hospitalidad." - }, - "toxicChain": { - "name": "Cadena Tóxica", - "description": "Gracias al poder de su cadena impregnada de toxinas, puede envenenar gravemente al Pokémon al que ataque." - }, - "embodyAspectTeal": { - "name": "Evocarrecuerdos", - "description": "Al evocar viejos recuerdos, el Pokémon hace brillar la máscara turquesa y aumenta su velocidad." - }, - "embodyAspectWellspring": { - "name": "Evocarrecuerdos", - "description": "Al evocar viejos recuerdos, el Pokémon hace brillar la máscara fuente y aumenta su defensa especial." - }, - "embodyAspectHearthflame": { - "name": "Evocarrecuerdos", - "description": "Al evocar viejos recuerdos, el Pokémon hace brillar la máscara horno y aumenta su ataque." - }, - "embodyAspectCornerstone": { - "name": "Evocarrecuerdos", - "description": "Al evocar viejos recuerdos, el Pokémon hace brillar la máscara cimiento y aumenta su defensa." - }, - "teraShift": { - "name": "Teracambio", - "description": "Al entrar en combate, adopta la Forma Teracristal tras absorber la energía de su alrededor." - }, - "teraShell": { - "name": "Teracaparazón", - "description": "Su caparazón encierra energía de todos los tipos. Gracias a ello, si sus PS están al máximo, el movimiento que lo alcance no será muy eficaz." - }, - "teraformZero": { - "name": "Teraformación 0", - "description": "Cuando Terapagos adopta la Forma Astral, anula todos los efectos del tiempo atmosférico y de los campos que haya en el terreno gracias a su poder oculto." - }, - "poisonPuppeteer": { - "name": "Títere Tóxico", - "description": "Los rivales que Pecharunt envenene con sus movimientos también sufrirán confusión." - } -} diff --git a/src/locales/es/achv.json b/src/locales/es/achv.json deleted file mode 100644 index 14501dbdb6b..00000000000 --- a/src/locales/es/achv.json +++ /dev/null @@ -1,178 +0,0 @@ -{ - "Achievements": { - "name": "Logros" - }, - "Locked": { - "name": "Bloqueado" - }, - "MoneyAchv": { - "description": "Acumula un total de ₽{{moneyAmount}}." - }, - "10K_MONEY": { - "name": "Ahorrador", - "name_female": "Ahorradora" - }, - "100K_MONEY": { - "name": "Rico", - "name_female": "Rica" - }, - "1M_MONEY": { - "name": "Millonario", - "name_female": "Millonaria" - }, - "10M_MONEY": { - "name": "Elusión Fiscal" - }, - "DamageAchv": { - "description": "Inflige {{damageAmount}} daño en un solo golpe." - }, - "250_DMG": { - "name": "Golpe Maestro" - }, - "1000_DMG": { - "name": "Golpe Devastador" - }, - "2500_DMG": { - "name": "¡Eso es un montón de daño!" - }, - "10000_DMG": { - "name": "One Punch Man" - }, - "HealAchv": { - "description": "Cura {{healAmount}} {{HP}} de una, con un movimiento, habilidad o objeto equipado." - }, - "250_HEAL": { - "name": "Sanador Novato", - "name_female": "Sanadora Novata" - }, - "1000_HEAL": { - "name": "Gran Sanador", - "name_female": "Gran Sanadora" - }, - "2500_HEAL": { - "name": "Clérigo", - "name_female": "Clériga" - }, - "10000_HEAL": { - "name": "Centro Pokémon" - }, - "LevelAchv": { - "description": "Sube a un Pokémon al nivel {{level}}." - }, - "LV_100": { - "name": "¡Pero espera, aún hay mas!" - }, - "LV_250": { - "name": "Élite" - }, - "LV_1000": { - "name": "Supera tus límites" - }, - "RibbonAchv": { - "description": "Acumula un total de {{ribbonAmount}} Cintas." - }, - "10_RIBBONS": { - "name": "Campeón Liga Pokémon", - "name_female": "Campeona Liga Pokémon" - }, - "25_RIBBONS": { - "name": "Campeón Liga Super", - "name_female": "Campeona Liga Super" - }, - "50_RIBBONS": { - "name": "Campeón Liga Ultra", - "name_female": "Campeona Liga Ultra" - }, - "75_RIBBONS": { - "name": "Campeón Liga Rogue", - "name_female": "Campeona Liga Rogue" - }, - "100_RIBBONS": { - "name": "Campeón Liga Master", - "name_female": "Campeona Liga Master" - }, - "TRANSFER_MAX_STAT_STAGE": { - "name": "Trabajo en Equipo", - "description": "Haz relevo a otro miembro del equipo con al menos una estadística al máximo." - }, - "MAX_FRIENDSHIP": { - "name": "Amistad Total", - "description": "Alcanza con un Pokémon la amistad al máximo." - }, - "MEGA_EVOLVE": { - "name": "Megamorfosis", - "description": "Megaevoluciona a un Pokémon." - }, - "GIGANTAMAX": { - "name": "Criatura Colosal", - "description": "Haz Gigantamax a un Pokémon." - }, - "TERASTALLIZE": { - "name": "Entusiasta del STAB", - "description": "Teracristaliza a un Pokémon." - }, - "STELLAR_TERASTALLIZE": { - "name": "El Tipo Oculto", - "description": "Teracristaliza a un Pokémon al tipo Astral." - }, - "SPLICE": { - "name": "Infinite Fusion", - "description": "Fusiona dos Pokémon con la Punta ADN." - }, - "MINI_BLACK_HOLE": { - "name": "Devorador de Objetos", - "description": "Adquiere un Mini Agujero Negro." - }, - "CATCH_MYTHICAL": { - "name": "Singular", - "description": "Captura a un Pokémon Singular." - }, - "CATCH_SUB_LEGENDARY": { - "name": "(Sub)Legendario", - "description": "Captura a un Pokémon Sublegendario." - }, - "CATCH_LEGENDARY": { - "name": "Legendario", - "description": "Captura a un Pokémon Legendario." - }, - "SEE_SHINY": { - "name": "Shiny", - "description": "Encuentra a un Pokémon Shiny salvaje." - }, - "SHINY_PARTY": { - "name": "Eso es dedicación", - "description": "Tener un equipo completo de Pokémon shiny." - }, - "HATCH_MYTHICAL": { - "name": "Huevo Singular", - "description": "Hacer eclosionar un Pokémon Singular de un huevo." - }, - "HATCH_SUB_LEGENDARY": { - "name": "Huevo Sublegendario", - "description": "Hacer eclosionar un Pokémon Sublegendario de un huevo." - }, - "HATCH_LEGENDARY": { - "name": "Huevo Legendario", - "description": "Hacer eclosionar un Pokémon Legendario de un huevo." - }, - "HATCH_SHINY": { - "name": "Huevo Shiny", - "description": "Hacer eclosionar un Pokémon Shiny de un huevo." - }, - "HIDDEN_ABILITY": { - "name": "Potencial Oculto", - "description": "Captura un Pokémon con una habilidad oculta." - }, - "PERFECT_IVS": { - "name": "Certificado de Autenticidad", - "description": "Consigue IVs perfectos en un Pokémon." - }, - "CLASSIC_VICTORY": { - "name": "Imbatible", - "description": "Completa el juego en modo clásico." - }, - "INVERSE_BATTLE": { - "name": "Espejo ojepsE", - "description": "Completa el reto de Combate Inverso.\n.osrevnI etabmoC ed oter le atelpmoC" - } -} diff --git a/src/locales/es/arena-flyout.json b/src/locales/es/arena-flyout.json deleted file mode 100644 index 64c9a489d73..00000000000 --- a/src/locales/es/arena-flyout.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "activeBattleEffects": "Efectos de terreno activos", - "player": "Jugador", - "neutral": "Neutral", - "enemy": "Enemigo", - "sunny": "Sol", - "rain": "Lluvia", - "sandstorm": "Tormenta de arena", - "hail": "Granizo", - "snow": "Nieve", - "fog": "Niebla", - "heavyRain": "Diluvio", - "harshSun": "Sol abrasador", - "strongWinds": "Turbulencias", - "misty": "Campo de niebla", - "electric": "Campo eléctrico", - "grassy": "Campo de hierba", - "psychic": "Campo psíquico", - "mudSport": "Chapoteo Lodo", - "waterSport": "Hidrochorro", - "spikes": "Púas", - "toxicSpikes": "Púas Tóxicas", - "mist": "Neblina", - "futureSight": "Premonición", - "doomDesire": "Deseo Oculto", - "wish": "Deseo", - "stealthRock": "Trampa Rocas", - "stickyWeb": "Red Vidcosa", - "trickRoom": "Espacio Raro", - "gravity": "Gravedad", - "reflect": "Reflejo", - "lightScreen": "Pantalla de Luz", - "auroraVeil": "Velo Aurora", - "quickGuard": "Anticipo", - "wideGuard": "Vasta Guardia", - "matBlock": "Escudo Tatami", - "craftyShield": "Truco Defensa", - "tailwind": "Viento Afín", - "happyHour": "Paga Extra", - "safeguard": "Velo Sagrado" -} diff --git a/src/locales/es/arena-tag.json b/src/locales/es/arena-tag.json deleted file mode 100644 index 0f63b62e784..00000000000 --- a/src/locales/es/arena-tag.json +++ /dev/null @@ -1,57 +0,0 @@ -{ - "yourTeam": "tu equipo", - "opposingTeam": "el equipo rival", - "arenaOnRemove": "Los efectos de {{moveName}} desaparecieron.", - "arenaOnRemovePlayer": "Los efectos de {{moveName}}\ndesaparecieron en tu bando.", - "arenaOnRemoveEnemy": "Los efectos de {{moveName}}\ndesaparecieron en el bando rival.", - "mistOnAdd": "¡Neblina de {{pokemonNameWithAffix}}\nha cubierto a su equipo!", - "mistApply": "¡La neblina evita los cambios de estadísticas!", - "reflectOnAdd": "¡Reflejo redujo el daño físico!", - "reflectOnAddPlayer": "¡Reflejo redujo el daño físico en tu bando!", - "reflectOnAddEnemy": "Reflejo redujo el daño físico en el bando rival.", - "lightScreenOnAdd": "¡Pantalla de Luz redujo el daño físico!", - "lightScreenOnAddPlayer": "¡Pantalla de Luz redujo el daño físico en tu bando!", - "lightScreenOnAddEnemy": "¡Pantalla de Luz redujo el daño físico en el bando enemigo!", - "auroraVeilOnAdd": "¡Velo Aurora redujo el daño físico!", - "auroraVeilOnAddPlayer": "¡Velo Aurora redujo el daño físico en tu bando!", - "auroraVeilOnAddEnemy": "¡Velo Aurora redujo el daño físico en el bando rival!", - "conditionalProtectOnAdd": "¡{{moveName}} protege a su bando!", - "conditionalProtectOnAddPlayer": "¡{{moveName}} protege a tu bando!", - "conditionalProtectOnAddEnemy": "¡{{moveName}} protege al bando rival!", - "conditionalProtectApply": "¡{{pokemonNameWithAffix}} ha sido protegido por {{moveName}}!", - "matBlockOnAdd": "¡{{pokemonNameWithAffix}} va a usar un tatami para bloquear ataques!", - "noCritOnAddPlayer": "¡{{moveName}} protege a tu bando de golpes críticos!", - "noCritOnAddEnemy": "¡{{moveName}} protege al bando rival de golpes críticos!", - "noCritOnRemove": "¡Los efectos de {{moveName}} de {{pokemonNameWithAffix}} se han disipado!", - "wishTagOnAdd": "¡El deseo de {{pokemonNameWithAffix}} se ha hecho realidad!", - "mudSportOnAdd": "¡Se han debilitado los ataques de tipo Eléctrico!", - "mudSportOnRemove": "Chapoteo Lodo ha dejado de surtir efecto.", - "waterSportOnAdd": "¡Se han debilitado los ataques\nde tipo Fuego!", - "waterSportOnRemove": "Hidrochorro ha dejado de surtir efecto.", - "spikesOnAdd": "¡El equipo de {{opponentDesc}} ha sido rodeado por {{moveName}}!", - "spikesActivateTrap": "¡Las púas han herido a {{pokemonNameWithAffix}}!", - "toxicSpikesOnAdd": "¡El equipo de {{opponentDesc}} ha sido rodeado por {{moveName}}!", - "toxicSpikesActivateTrapPoison": "¡{{pokemonNameWithAffix}} ha sido herido por {{moveName}}!", - "stealthRockOnAdd": "¡El equipo de {{opponentDesc}} ha sido rodeado por piedras puntiagudas!", - "stealthRockActivateTrap": "¡Unas piedras puntiagudas han dañado a {{pokemonNameWithAffix}}!", - "stickyWebOnAdd": "¡Una {{moveName}} se extiende a los pies del bando rival!", - "stickyWebActivateTrap": "¡{{pokemonName}} ha caído en una red viscosa!", - "trickRoomOnAdd": "¡{{pokemonNameWithAffix}} ha alterado las dimensiones!", - "trickRoomOnRemove": "Se han restaurado las dimensiones alteradas.", - "gravityOnAdd": "¡La gravedad se ha incrementado!", - "gravityOnRemove": "La gravedad ha vuelto a su estado normal.", - "tailwindOnAdd": "¡Sopla un viento afín!", - "tailwindOnAddPlayer": "¡El viento sopla a favor de tu bando!", - "tailwindOnAddEnemy": "¡El viento sopla a favor del bando rival!", - "tailwindOnRemove": "Ha dejado de soplar el viento afín.", - "tailwindOnRemovePlayer": "Ha dejado de soplar el viento que favorecía a tu equipo.", - "tailwindOnRemoveEnemy": "Ha dejado de soplar el viento que favorecía al bando rival.", - "happyHourOnAdd": "¡La felicidad se respira en el aire!", - "happyHourOnRemove": "La felicidad ya no se respira en el aire.", - "safeguardOnAdd": "¡Todos los Pokémon están protegidos por Velo Sagrado!", - "safeguardOnAddPlayer": "¡Tu equipo se ha protegido con Velo Sagrado!", - "safeguardOnAddEnemy": "¡El equipo enemigo se ha protegido con Velo Sagrado!", - "safeguardOnRemove": "¡Velo Sagrado dejó de hacer efecto!", - "safeguardOnRemovePlayer": "El efecto de Velo Sagrado en tu equipo se ha disipado.", - "safeguardOnRemoveEnemy": "El efecto de Velo Sagrado en el equipo enemigo se ha disipado." -} \ No newline at end of file diff --git a/src/locales/es/battle-info.json b/src/locales/es/battle-info.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/es/battle-info.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/es/battle-message-ui-handler.json b/src/locales/es/battle-message-ui-handler.json deleted file mode 100644 index e1b63313ab6..00000000000 --- a/src/locales/es/battle-message-ui-handler.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "ivBest": "Inmejorable", - "ivFantastic": "Fantástico", - "ivVeryGood": "Notable", - "ivPrettyGood": "Genial", - "ivDecent": "No está mal", - "ivNoGood": "Cojea un poco" -} \ No newline at end of file diff --git a/src/locales/es/battle-scene.json b/src/locales/es/battle-scene.json deleted file mode 100644 index ef916edbf08..00000000000 --- a/src/locales/es/battle-scene.json +++ /dev/null @@ -1,3 +0,0 @@ -{ - "moneyOwned": "{{formattedMoney}} ₽" -} \ No newline at end of file diff --git a/src/locales/es/battle.json b/src/locales/es/battle.json deleted file mode 100644 index c79315f297b..00000000000 --- a/src/locales/es/battle.json +++ /dev/null @@ -1,89 +0,0 @@ -{ - "bossAppeared": "¡{{bossName}} te corta el paso!", - "trainerAppeared": "¡{{trainerName}}\nte desafía!", - "trainerSendOut": "¡{{trainerName}} saca a\n{{pokemonName}}!", - "singleWildAppeared": "¡Un {{pokemonName}} salvaje te corta el paso!", - "multiWildAppeared": "¡Un {{pokemonName1}} y un {{pokemonName2}} salvajes\nte cortan el paso!", - "playerComeBack": "¡{{pokemonName}}, ven aquí!", - "trainerComeBack": "¡{{trainerName}} retira a {{pokemonName}} del combate!", - "playerGo": "¡Adelante, {{pokemonName}}!", - "trainerGo": "¡{{trainerName}} saca a {{pokemonName}}!", - "switchQuestion": "¿Quieres cambiar a\n{{pokemonName}}?", - "trainerDefeated": "¡Has derrotado a\n{{trainerName}}!", - "moneyWon": "¡Has ganado\n₽{{moneyAmount}} por vencer!", - "pokemonCaught": "¡{{pokemonName}} atrapado!", - "addedAsAStarter": "{{pokemonName}} ha sido añadido\na tus iniciales!", - "partyFull": "Tu equipo esta completo.\n¿Quieres liberar un Pokémon para meter a {{pokemonName}}?", - "pokemon": "Pokémon", - "sendOutPokemon": "¡Adelante, {{pokemonName}}!", - "hitResultCriticalHit": "¡Un golpe crítico!", - "hitResultSuperEffective": "¡Es supereficaz!", - "hitResultNotVeryEffective": "No es muy eficaz…", - "hitResultNoEffect": "No afecta a {{pokemonName}}!", - "hitResultImmune": "¡No afecta a {{pokemonName}}!", - "hitResultOneHitKO": "¡KO en 1 golpe!", - "attackFailed": "¡Pero ha fallado!", - "attackMissed": "¡{{pokemonNameWithAffix}}\nha evitado el ataque!", - "attackHitsCount": "N.º de golpes: {{count}}.", - "rewardGain": "¡Has obtenido\n{{modifierName}}!", - "expGain": "{{pokemonName}} ha ganado\n{{exp}} puntos de experiencia.", - "levelUp": "¡{{pokemonName}} ha subido al \nNv. {{level}}!", - "learnMove": "¡{{pokemonName}} ha aprendido {{moveName}}!", - "learnMovePrompt": "{{pokemonName}} quiere aprender\n{{moveName}}.", - "learnMoveLimitReached": "Pero, {{pokemonName}} ya conoce\ncuatro movimientos.", - "learnMoveReplaceQuestion": "¿Quieres sustituir uno de sus movimientos por {{moveName}}?", - "learnMoveStopTeaching": "¿Prefieres que no aprenda\n{{moveName}}?", - "learnMoveNotLearned": "{{pokemonName}} no ha aprendido {{moveName}}.", - "learnMoveForgetQuestion": "¿Qué movimiento quieres que olvide?", - "learnMoveForgetSuccess": "{{pokemonName}} ha olvidado cómo utilizar {{moveName}}.", - "countdownPoof": "@d{32}1, @d{15}2, @d{15}y@d{15}… @d{15}… @d{15}… @d{15}@s{se/pb_bounce_1}¡Puf!", - "learnMoveAnd": "Y…", - "levelCapUp": "¡Se ha incrementado el\nnivel máximo a {{levelCap}}!", - "moveNotImplemented": "{{moveName}} aún no está implementado y no se puede seleccionar.", - "moveNoPP": "¡No hay suficientes PP\npara este movimiento!", - "moveDisabled": "!No puede usar {{moveName}} porque ha sido anulado!", - "disableInterruptedMove": "¡Se ha anulado el movimiento {{moveName}}\nde {{pokemonNameWithAffix}}!", - "noPokeballForce": "Una fuerza misteriosa\nte impide usar Poké Balls.", - "noPokeballTrainer": "¡No puedes atrapar a los\nPokémon de los demás!", - "noPokeballMulti": "¡No se pueden lanzar Poké Balls\ncuando hay más de un Pokémon!", - "noPokeballStrong": "¡Este Pokémon es demasiado fuerte para ser capturado!\nNecesitas bajarle los PS primero!", - "noEscapeForce": "Una fuerza misteriosa\nte impide huir.", - "noEscapeTrainer": "¡No puedes huir de los\ncombates contra Entrenadores!", - "noEscapePokemon": "¡El movimiento {{moveName}} de {{pokemonName}} impide la huida!", - "runAwaySuccess": "¡Escapas sin problemas!", - "runAwayCannotEscape": "¡No has podido escapar!", - "escapeVerbSwitch": "cambiar", - "escapeVerbFlee": "huir", - "notDisabled": "¡El movimiento {{moveName}} de {{pokemonName}}\nya no está anulado!", - "turnEndHpRestore": "Los PS de {{pokemonName}} fueron restaurados.", - "hpIsFull": "¡Los PS de {{pokemonName}}\nestán al máximo!", - "skipItemQuestion": "¿Estás seguro de que no quieres coger un objeto?", - "itemStackFull": "El máximo número de {{fullItemName}} ha sido alcanzado. Recibirás {{itemName}} en su lugar.", - "eggHatching": "¿Y esto?", - "ivScannerUseQuestion": "¿Quieres usar el Escáner de IVs en {{pokemonName}}?", - "wildPokemonWithAffix": "El {{pokemonName}} salvaje", - "foePokemonWithAffix": "El {{pokemonName}} enemigo", - "useMove": "¡{{pokemonNameWithAffix}} usó {{moveName}}!", - "drainMessage": "¡{{pokemonName}} tuvo su\nenergía absorbida!", - "regainHealth": "¡{{pokemonName}} recuperó\nPS!", - "stealEatBerry": "¡{{pokemonName}} robó la {{berryName}}\nde {{targetName}} y se la comió!", - "fainted": "¡{{pokemonNameWithAffix}} se debilitó!", - "statsAnd": "y", - "stats": "Las estadísticas", - "statRose_one": "¡El {{stats}} de {{pokemonNameWithAffix}} ha subido!", - "statRose_other": "¡{{stats}} de\n{{pokemonNameWithAffix}} han subido!", - "statSharplyRose_one": "¡El {{stats}} de {{pokemonNameWithAffix}} ha subido mucho!", - "statSharplyRose_other": "¡{{stats}} de\n{{pokemonNameWithAffix}} han subido mucho!", - "statRoseDrastically_one": "¡El {{stats}} de {{pokemonNameWithAffix}} ha subido muchísimo!", - "statRoseDrastically_other": "¡{{stats}} de\n{{pokemonNameWithAffix}} han subido muchísimo!", - "statWontGoAnyHigher_one": "¡El {{stats}} de {{pokemonNameWithAffix}} no puede subir más!", - "statWontGoAnyHigher_other": "¡{{stats}} de\n{{pokemonNameWithAffix}} no pueden subir más!", - "statFell_one": "¡El {{stats}} de {{pokemonNameWithAffix}} ha bajado!", - "statFell_other": "¡{{stats}} de\n{{pokemonNameWithAffix}} han bajado!", - "statHarshlyFell_one": "¡El {{stats}} de {{pokemonNameWithAffix}} ha bajado mucho!", - "statHarshlyFell_other": "¡{{stats}} de\n{{pokemonNameWithAffix}} han bajado mucho!", - "statSeverelyFell_one": "¡El {{stats}} de {{pokemonNameWithAffix}} ha bajado muchísimo!", - "statSeverelyFell_other": "¡{{stats}} de\n{{pokemonNameWithAffix}} han bajado muchísimo!", - "statWontGoAnyLower_one": "¡El {{stats}} de {{pokemonNameWithAffix}} no puede bajar más!", - "statWontGoAnyLower_other": "¡{{stats}} de\n{{pokemonNameWithAffix}} no pueden bajar más!" -} diff --git a/src/locales/es/battler-tags.json b/src/locales/es/battler-tags.json deleted file mode 100644 index bb4f0fe6c8a..00000000000 --- a/src/locales/es/battler-tags.json +++ /dev/null @@ -1,77 +0,0 @@ -{ - "trappedDesc": "trampa", - "flinchedDesc": "retroceso", - "confusedDesc": "confusión", - "infatuatedDesc": "enamoramiento", - "seedDesc": "drenado", - "nightmareDesc": "pesadillas", - "ingrainDesc": "raíces", - "drowsyDesc": "sueño", - "rechargingLapse": "¡{{pokemonNameWithAffix}} necesita\nrecuperarse de su ataque!", - "trappedOnAdd": "¡{{pokemonNameWithAffix}} no puede escapar!", - "trappedOnRemove": "¡{{pokemonNameWithAffix}} se ha\nliberado de {{moveName}}!", - "flinchedLapse": "¡{{pokemonNameWithAffix}} se amedrentó!", - "confusedOnAdd": "¡{{pokemonNameWithAffix}} se encuentra confuso!", - "confusedOnRemove": "¡{{pokemonNameWithAffix}} ya no está confuso!", - "confusedOnOverlap": "¡{{pokemonNameWithAffix}} ya está confuso!", - "confusedLapse": "¡{{pokemonNameWithAffix}} está confuso!", - "confusedLapseHurtItself": "¡Está tan confuso que se ha herido a sí mismo!", - "destinyBondLapseIsBoss": "Mismo Destino no afecta a {{pokemonNameWithAffix}}.", - "destinyBondLapse": "¡{{pokemonNameWithAffix2}} ha sufrido\nel mismo destino que {{pokemonNameWithAffix}}!", - "infatuatedOnAdd": "¡{{pokemonNameWithAffix}} se ha enamorado\nde {{sourcePokemonName}}!", - "infatuatedOnOverlap": "¡{{pokemonNameWithAffix}} ya está enamorado!", - "infatuatedLapse": "¡{{pokemonNameWithAffix}} se ha enamorado\ndebido a {{sourcePokemonName}}!", - "infatuatedLapseImmobilize": "¡El enamoramiento impide que\n{{pokemonNameWithAffix}} reaccione!", - "infatuatedOnRemove": "{{pokemonNameWithAffix}} ya no está enamorado.", - "seededOnAdd": "¡{{pokemonNameWithAffix}} ha sido infectado!", - "seededLapse": "¡Las drenadoras han restado salud a {{pokemonNameWithAffix}}!", - "seededLapseShed": "¡{{pokemonNameWithAffix}} ha absorbido el lodo líquido!", - "nightmareOnAdd": "¡{{pokemonNameWithAffix}} se ha sumido en una pesadilla!", - "nightmareOnOverlap": "¡{{pokemonNameWithAffix}} ya está teniendo pesadillas!", - "nightmareLapse": "¡{{pokemonNameWithAffix}} sufre pesadillas!", - "encoreOnAdd": "¡{{pokemonNameWithAffix}} sufre los efectos de Otra Vez!", - "encoreOnRemove": "¡{{pokemonNameWithAffix}} ya no sufre los efectos de Otra Vez!", - "helpingHandOnAdd": "¡{{pokemonNameWithAffix}} se prepara\npara ayudar a {{pokemonName}}!", - "ingrainLapse": "¡{{pokemonNameWithAffix}} ha absorbido\nnutrientes a través de sus raíces!", - "ingrainOnTrap": "¡{{pokemonNameWithAffix}} ha echado raíces!", - "aquaRingOnAdd": "¡{{pokemonNameWithAffix}} se ha rodeado de un manto de agua!", - "aquaRingLapse": "¡{{pokemonName}} restauró sus PS con {{moveName}}!", - "drowsyOnAdd": "¡{{pokemonNameWithAffix}} empieza a tener sueño!", - "damagingTrapLapse": "¡{{moveName}} hiere a {{pokemonNameWithAffix}}!", - "bindOnTrap": "¡{{moveName}} de {{sourcePokemonName}} oprime a {{pokemonNameWithAffix}}!", - "wrapOnTrap": "¡{{sourcePokemonName}} ha atrapado a {{pokemonNameWithAffix}} con una constricción!", - "vortexOnTrap": "¡{{pokemonNameWithAffix}} no puede salir del torbellino!", - "clampOnTrap": "¡{{sourcePokemonNameWithAffix}} ha atenazado a \n{{pokemonName}}!", - "sandTombOnTrap": "¡{{pokemonNameWithAffix}} ha sido atrapado por {{moveName}}!", - "magmaStormOnTrap": "¡La lluvia ígnea cae sobre {{pokemonNameWithAffix}}!", - "snapTrapOnTrap": "¡{{pokemonNameWithAffix}} cayó en un cepo!", - "thunderCageOnTrap": "¡{{sourcePokemonNameWithAffix}} ha enjaulado a {{pokemonNameWithAffix}}!", - "infestationOnTrap": "¡{{pokemonNameWithAffix}} es presa del acoso de {{sourcePokemonNameWithAffix}}!", - "protectedOnAdd": "{{pokemonNameWithAffix}}\nse está protegiendo.", - "protectedLapse": "¡{{pokemonNameWithAffix}}\nse ha protegido!", - "enduringOnAdd": "{{pokemonNameWithAffix}} se prepara para resistir los ataques...", - "enduringLapse": "¡{{pokemonNameWithAffix}} ha encajado el golpe!", - "sturdyLapse": "¡{{pokemonNameWithAffix}} ha encajado el golpe!", - "perishSongLapse": "La cuenta atrás de Canto Mortal de\n{{pokemonNameWithAffix}} ha bajado a {{turnCount}}.", - "centerOfAttentionOnAdd": "¡{{pokemonNameWithAffix}} es el centro de atención!", - "truantLapse": "{{pokemonNameWithAffix}} está holgazaneando...", - "slowStartOnAdd": "¡{{pokemonNameWithAffix}} no está dando todo de sí!", - "slowStartOnRemove": "¡{{pokemonNameWithAffix}} ya puede darlo todo!", - "highestStatBoostOnAdd": "¡{{pokemonNameWithAffix}} ha reforzado su {{statName}}!", - "highestStatBoostOnRemove": "¡Los efectos de {{abilityName}}\nde {{pokemonNameWithAffix}} han desaparecido!", - "magnetRisenOnAdd": "¡{{pokemonNameWithAffix}} levita gracias a un campo electromagnético!", - "magnetRisenOnRemove": "¡El campo electromagnético de {{pokemonNameWithAffix}} se ha disipado!", - "critBoostOnAdd": "¡{{pokemonNameWithAffix}} se está preparando para luchar!", - "critBoostOnRemove": "{{pokemonNameWithAffix}} se ha relajado.", - "saltCuredOnAdd": "¡{{pokemonNameWithAffix}} está en salazón!", - "saltCuredLapse": "¡{{moveName}} ha herido a {{pokemonNameWithAffix}}!", - "cursedOnAdd": "¡{{pokemonNameWithAffix}} sacrifica algunos PS y maldice a {{pokemonName}}!", - "cursedLapse": "¡{{pokemonNameWithAffix}} es víctima de una maldición!", - "stockpilingOnAdd": "¡{{pokemonNameWithAffix}} ha reservado energía por {{stockpiledCount}}ª vez!", - "disabledOnAdd": "¡Se ha anulado el movimiento {{moveName}}\nde {{pokemonNameWithAffix}}!", - "disabledLapse": "¡El movimiento {{moveName}} de {{pokemonNameWithAffix}} ya no está anulado!", - "tarShotOnAdd": "¡{{pokemonNameWithAffix}} se ha vuelto débil ante el fuego!", - "substituteOnAdd": "¡{{pokemonNameWithAffix}} creó un sustituto!", - "substituteOnHit": "¡El sustituto recibe daño en lugar del {{pokemonNameWithAffix}}!", - "substituteOnRemove": "¡El sustituto del {{pokemonNameWithAffix}} se debilitó!" -} diff --git a/src/locales/es/berry.json b/src/locales/es/berry.json deleted file mode 100644 index befbb9a892f..00000000000 --- a/src/locales/es/berry.json +++ /dev/null @@ -1,46 +0,0 @@ -{ - "SITRUS": { - "name": "Baya Zidra", - "effect": "Restaura 25% PS si estos caen por debajo del 50%" - }, - "LUM": { - "name": "Baya Ziuela", - "effect": "Cura cualquier problema de estado" - }, - "ENIGMA": { - "name": "Baya Enigma", - "effect": "Restaura 25% PS si le alcanza un ataque supereficaz" - }, - "LIECHI": { - "name": "Baya Lichi", - "effect": "Aumenta el ataque si los PS están por debajo de 25%" - }, - "GANLON": { - "name": "Baya Gonlan", - "effect": "Aumenta la defensa si los PS están por debajo de 25%" - }, - "PETAYA": { - "name": "Baya Yapati", - "effect": "Aumenta el ataque especial si los PS están por debajo de 25%" - }, - "APICOT": { - "name": "Baya Aricoc", - "effect": "Aumenta la defensa especial si los PS están por debajo de 25%" - }, - "SALAC": { - "name": "Baya Aslac", - "effect": "Aumenta la velocidad si los PS están por debajo de 25%" - }, - "LANSAT": { - "name": "Baya Zonlan", - "effect": "Aumenta el índice de golpe crítico si los PS están por debajo de 25%" - }, - "STARF": { - "name": "Baya Arabol", - "effect": "Aumenta mucho una estadística al azar si los PS están por debajo de 25%" - }, - "LEPPA": { - "name": "Baya Zanama", - "effect": "Restaura 10 PP del primer movimiento cuyos PP bajen a 0" - } -} \ No newline at end of file diff --git a/src/locales/es/bgm-name.json b/src/locales/es/bgm-name.json deleted file mode 100644 index f0e0ab7e852..00000000000 --- a/src/locales/es/bgm-name.json +++ /dev/null @@ -1,149 +0,0 @@ -{ - "music": "Música: ", - "missing_entries": "{{name}}", - "battle_kanto_champion": "B2W2 - ¡Vs. Campeón de Kanto!", - "battle_johto_champion": "B2W2 - ¡Vs. Campeón de Johto!", - "battle_hoenn_champion_g5": "B2W2 - ¡Vs. Campeón de Hoenn!", - "battle_hoenn_champion_g6": "ORAS - ¡Vs. Campeón de Hoenn!", - "battle_sinnoh_champion": "B2W2 - ¡Vs. Campeón de Sinnoh!", - "battle_champion_alder": "BW - ¡Vs. Campeón de Teselia!", - "battle_champion_iris": "B2W2 - ¡Vs. Campeón de Teselia!", - "battle_kalos_champion": "XY - ¡Vs. Campeón de Kalos!", - "battle_alola_champion": "USUM - ¡Vs. Campeón de Alola!", - "battle_galar_champion": "SWSH - ¡Vs. Campeón de Galar!", - "battle_champion_geeta": "SV - ¡Vs. Campeona Ságita!", - "battle_champion_nemona": "SV - ¡Vs. Campeona Mencía!", - "battle_champion_kieran": "SV - ¡Vs. Campeón Cass!", - "battle_hoenn_elite": "ORAS - ¡Vs. Alto Mando!", - "battle_unova_elite": "BW - ¡Vs. Alto Mando!", - "battle_kalos_elite": "XY - ¡Vs. Alto Mando!", - "battle_alola_elite": "SM - ¡Vs. Alto Mando!", - "battle_galar_elite": "SWSH - Torneo de finalistas", - "battle_paldea_elite": "SV - ¡Vs. Alto Mando!", - "battle_bb_elite": "SV - ¡Vs. Alto Mando de la Academia Arándano!", - "battle_final_encounter": "PMD RTDX - Dominio de Rayquaza", - "battle_final": "BW - ¡Vs. Ghechis!", - "battle_kanto_gym": "B2W2 - ¡Vs. Líder de Kanto!", - "battle_johto_gym": "B2W2 - ¡Vs. Líder de Johto!", - "battle_hoenn_gym": "B2W2 - ¡Vs. Líder de Hoenn!", - "battle_sinnoh_gym": "B2W2 - ¡Vs. Líder de Sinnoh!", - "battle_unova_gym": "BW - ¡Vs. Líder de Teselia!", - "battle_kalos_gym": "XY - ¡Vs. Líder de Kalos!", - "battle_galar_gym": "SWSH - ¡Vs. Líder de Galar!", - "battle_paldea_gym": "SV - ¡Vs. Líder de Paldea!", - "battle_legendary_kanto": "XY - ¡Vs. Legendarios de Kanto!", - "battle_legendary_raikou": "HGSS - ¡Vs. Raikou!", - "battle_legendary_entei": "HGSS - ¡Vs. Entei!", - "battle_legendary_suicune": "HGSS - ¡Vs. Suicune!", - "battle_legendary_lugia": "HGSS - ¡Vs. Lugia!", - "battle_legendary_ho_oh": "HGSS - ¡Vs. Ho-oh!", - "battle_legendary_regis_g5": "B2W2 - ¡Vs. Regis!", - "battle_legendary_regis_g6": "ORAS - ¡Vs. Regis!", - "battle_legendary_gro_kyo": "ORAS - ¡Vs. Groudon/Kyogre!", - "battle_legendary_rayquaza": "ORAS - ¡Vs. Rayquaza!", - "battle_legendary_deoxys": "ORAS - ¡Vs. Deoxys!", - "battle_legendary_lake_trio": "ORAS - ¡Vs. trío del Lago!", - "battle_legendary_sinnoh": "ORAS - ¡Vs. legendarios de Sinnoh!", - "battle_legendary_dia_pal": "ORAS - ¡Vs. Dialga/Palkia!", - "battle_legendary_origin_forme": "LA - ¡Vs. Dialga & Palkia, Forma Origen!", - "battle_legendary_giratina": "ORAS - ¡Vs. Giratina!", - "battle_legendary_arceus": "HGSS - ¡Vs. Arceus!", - "battle_legendary_unova": "BW - ¡Vs. legendarios de Teselia!", - "battle_legendary_kyurem": "BW - ¡Vs. Kyurem!", - "battle_legendary_res_zek": "BW - ¡Vs. Reshiram/Zekrom!", - "battle_legendary_xern_yvel": "XY - ¡Vs. Xerneas/Yveltal!", - "battle_legendary_tapu": "SM - ¡Vs. Tapus!", - "battle_legendary_sol_lun": "SM - ¡Vs. Solgaleo/Lunala!", - "battle_legendary_ub": "SM - ¡Vs. Ultraentes!", - "battle_legendary_dusk_dawn": "USUM - ¡Vs. Necrozma Melena Crepuscular/Alas del Alba!", - "battle_legendary_ultra_nec": "USUM - ¡Vs. Ultra-Necrozma!", - "battle_legendary_zac_zam": "SWSH - ¡Vs. Zacian/Zamazenta!", - "battle_legendary_glas_spec": "SWSH - ¡Vs. Glastrier/Spectrier!", - "battle_legendary_calyrex": "SWSH - ¡Vs. Calyrex!", - "battle_legendary_riders": "SWSH - ¡Vs. Calyrex Jinete!", - "battle_legendary_birds_galar": "SWSH - ¡Vs. Aves Legendarias de Galar!", - "battle_legendary_ruinous": "SV - ¡Vs. Tesoros Funestos!", - "battle_legendary_kor_mir": "SV - ¡Batalla en el área Zero!", - "battle_legendary_loyal_three": "SV - ¡Vs. Compatrones!", - "battle_legendary_ogerpon": "SV - ¡Vs. Ogerpon!", - "battle_legendary_terapagos": "SV - ¡Vs. Terapagos!", - "battle_legendary_pecharunt": "SV - ¡Vs. Pecharunt!", - "battle_rival": "BW - ¡Vs. Rival!", - "battle_rival_2": "BW - ¡Vs N!", - "battle_rival_3": "BW - ¡Vs. N (Liga Pokémon)!", - "battle_trainer": "BW - ¡Vs. entrenador!", - "battle_wild": "BW - ¡Vs. Pokémon salvaje!", - "battle_wild_strong": "BW - ¡Vs. Pokémon salvaje raro!", - "end_summit": "PMD RTDX - Techo del cielo", - "battle_rocket_grunt": "HGSS - ¡Vs. Team Rocket!", - "battle_aqua_magma_grunt": "ORAS - ¡Vs. Equipo Aqua & Magma!", - "battle_galactic_grunt": "BDSP - ¡Vs. Equipo Galaxia!", - "battle_plasma_grunt": "BW - ¡Vs Equipo Plasma!", - "battle_flare_grunt": "XY - ¡Vs. Team Flare!", - "battle_aether_grunt": "SM - ¡Vs. Fundación Æther!", - "battle_skull_grunt": "SM - ¡Vs. Team Skull!", - "battle_macro_grunt": "SWSH - ¡Vs. entrenador!", - "battle_galactic_admin": "BDSP - ¡Vs. Comandante del Equipo Galaxia!", - "battle_skull_admin": "SM - ¡Vs. Comandante del Team Skull!", - "battle_oleana": "SWSH - ¡Vs. Olivia!", - "battle_rocket_boss": "USUM - ¡Vs. Giovanni!", - "battle_aqua_magma_boss": "ORAS - ¡Vs. Aquiles & Magno!", - "battle_galactic_boss": "BDSP - ¡Vs. Helio!", - "battle_plasma_boss": "B2W2 - ¡Vs. Ghechis Armonia!", - "battle_flare_boss": "XY - ¡Vs. Lysson!", - "battle_aether_boss": "SM - ¡Vs. Samina!", - "battle_skull_boss": "SM - ¡Vs. Guzmán!", - "battle_macro_boss": "SWSH - ¡Vs. Rose!", - "abyss": "PMD EoS - Cráter Oscuro", - "badlands": "PMD EoS - Valle Desolado", - "beach": "PMD EoS - Risco Calado", - "cave": "PMD EoS - Cueva de la Cumbre del Cielo", - "construction_site": "PMD EoS - Roquedal", - "desert": "PMD EoS - Desierto Norte", - "dojo": "PMD EoS - Dojo Marowak", - "end": "PMD RTDX - Torre del Cielo", - "factory": "PMD EoS - Ruinas Camufladas", - "fairy_cave": "PMD EoS - Cueva Estrella", - "forest": "PMD EoS - Bosque Sombrío", - "grass": "PMD EoS - Manzanar", - "graveyard": "PMD EoS - Bosque Misterio", - "ice_cave": "PMD EoS - Gran Iceberg", - "island": "PMD EoS - Costa Escarpada", - "jungle": "Lmz - Jungla", - "laboratory": "Firel - Laboratorio", - "lake": "PMD EoS - Cueva Cristal", - "meadow": "PMD EoS - Bosque de la Cumbre del Cielo", - "metropolis": "Firel - Metrópolis", - "mountain": "PMD EoS - Monte Cuerno", - "plains": "PMD EoS - Pradera de la Cumbre del Cielo", - "power_plant": "PMD EoS - Pradera Destello", - "ruins": "PMD EoS - Sima Hermética", - "sea": "Andr06 - Misticismo marino", - "seabed": "Firel - Lecho del mar", - "slum": "Andr06 - Snom sigiloso", - "snowy_forest": "PMD EoS - Campo nevado de la Cumbre del Cielo", - "space": "Firel - Æther ", - "swamp": "PMD EoS - Mar Circundante", - "tall_grass": "PMD EoS - Bosque Niebla", - "temple": "PMD EoS - Cueva Regia", - "town": "PMD EoS - Tema del territorio aleatorio 3", - "volcano": "PMD EoS - Cueva Vapor", - "wasteland": "PMD EoS - Corazón Tierra Oculta", - "encounter_ace_trainer": "BW - ¡Vs. entrenador guay!", - "encounter_backpacker": "BW - ¡Vs. mochilero!", - "encounter_clerk": "BW - ¡Vs. empresario!", - "encounter_cyclist": "BW - ¡Vs. ciclista!", - "encounter_lass": "BW - ¡Vs. chica joven!", - "encounter_parasol_lady": "BW - ¡Vs. dama parasol!", - "encounter_pokefan": "BW - ¡Vs. poké-fan!", - "encounter_psychic": "BW -¡Vs. médium!", - "encounter_rich": "BW - ¡Vs. aristócrata!", - "encounter_rival": "BW - ¡Vs. Cheren!", - "encounter_roughneck": "BW - ¡Vs. tío chungo!", - "encounter_scientist": "BW - ¡Vs. científico!", - "encounter_twins": "BW - ¡Vs. gemelas!", - "encounter_youngster": "BW - ¡Vs. chico joven!", - "heal": "BW - Cura Pokémon", - "menu": "PMD EoS - ¡Bienvenidos al mundo de los Pokémon!", - "title": "PMD EoS - Tema del menú principal" -} diff --git a/src/locales/es/biome.json b/src/locales/es/biome.json deleted file mode 100644 index ff67738a074..00000000000 --- a/src/locales/es/biome.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "unknownLocation": "En algún lugar que no puedes recordar", - "TOWN": "Pueblo", - "PLAINS": "Valle", - "GRASS": "Campo", - "TALL_GRASS": "Hierba Alta", - "METROPOLIS": "Metrópolis", - "FOREST": "Bosque", - "SEA": "Mar", - "SWAMP": "Pantano", - "BEACH": "Playa", - "LAKE": "Lago", - "SEABED": "Lecho marino", - "MOUNTAIN": "Montaña", - "BADLANDS": "Tierras Baldías", - "CAVE": "Cueva", - "DESERT": "Desierto", - "ICE_CAVE": "Cueva Helada", - "MEADOW": "Prado", - "POWER_PLANT": "Central Eléctrica", - "VOLCANO": "Volcán", - "GRAVEYARD": "Cementerio", - "DOJO": "Dojo", - "FACTORY": "Fábrica", - "RUINS": "Ruinas Antiguas", - "WASTELAND": "Páramo", - "ABYSS": "Abismo", - "SPACE": "Espacio", - "CONSTRUCTION_SITE": "Obra", - "JUNGLE": "Jungla", - "FAIRY_CAVE": "Cueva de Hadas", - "TEMPLE": "Templo", - "SLUM": "Suburbio", - "SNOWY_FOREST": "Bosque nevado", - "ISLAND": "Isla", - "LABORATORY": "Laboratorio", - "END": "???" -} \ No newline at end of file diff --git a/src/locales/es/challenges.json b/src/locales/es/challenges.json deleted file mode 100644 index 6a7db8c10c3..00000000000 --- a/src/locales/es/challenges.json +++ /dev/null @@ -1,29 +0,0 @@ -{ - "title": "Parámetros de Desafíos", - "singleGeneration": { - "name": "Monogeneración", - "desc": "Solo puedes usar Pokémon de {{gen}} generación.", - "desc_default": "Solo puedes usar Pokémon de la generación elegida.", - "gen_1": "primera", - "gen_2": "segunda", - "gen_3": "tercera", - "gen_4": "cuarta", - "gen_5": "quinta", - "gen_6": "sexta", - "gen_7": "séptima", - "gen_8": "octava", - "gen_9": "novena" - }, - "singleType": { - "name": "Monotipo", - "desc": "Solo puedes usar Pokémon with the {{type}} type.", - "desc_default": "Solo puedes usar Pokémon del tipo elegido." - }, - "inverseBattle": { - "name": "Combate Inverso", - "shortName": "Inverso", - "desc": "La efectividad de los tipos es invertida. No hay inmunidades entre tipos.\nEste reto deshabilita logros de otros retos.", - "value.0": "Desactivado", - "value.1": "Activado" - } -} \ No newline at end of file diff --git a/src/locales/es/command-ui-handler.json b/src/locales/es/command-ui-handler.json deleted file mode 100644 index 554b9548cca..00000000000 --- a/src/locales/es/command-ui-handler.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "fight": "Luchar", - "ball": "Balls", - "pokemon": "Pokémon", - "run": "Huir", - "actionMessage": "¿Qué debería\nhacer {{pokemonName}}?" -} \ No newline at end of file diff --git a/src/locales/es/common.json b/src/locales/es/common.json deleted file mode 100644 index 556ebb8454e..00000000000 --- a/src/locales/es/common.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "luckIndicator": "Suerte:", - "shinyOnHover": "Shiny", - "commonShiny": "Común", - "rareShiny": "Raro", - "epicShiny": "Épico" -} \ No newline at end of file diff --git a/src/locales/es/config.ts b/src/locales/es/config.ts deleted file mode 100644 index 8f75c08f3f6..00000000000 --- a/src/locales/es/config.ts +++ /dev/null @@ -1,113 +0,0 @@ -import common from "./common.json"; -import settings from "./settings.json"; -import ability from "./ability.json"; -import abilityTriggers from "./ability-trigger.json"; -import arenaFlyout from "./arena-flyout.json"; -import arenaTag from "./arena-tag.json"; -import achv from "./achv.json"; -import battle from "./battle.json"; -import battleScene from "./battle-scene.json"; -import battleInfo from "./battle-info.json"; -import battleMessageUiHandler from "./battle-message-ui-handler.json"; -import battlerTags from "./battler-tags.json"; -import berry from "./berry.json"; -import bgmName from "./bgm-name.json"; -import biome from "./biome.json"; -import challenges from "./challenges.json"; -import commandUiHandler from "./command-ui-handler.json"; -import dialogue from "./dialogue.json"; -import battleSpecDialogue from "./dialogue-final-boss.json"; -import miscDialogue from "./dialogue-misc.json"; -import doubleBattleDialogue from "./dialogue-double-battle.json"; -import egg from "./egg.json"; -import fightUiHandler from "./fight-ui-handler.json"; -import filterBar from "./filter-bar.json"; -import gameMode from "./game-mode.json"; -import gameStatsUiHandler from "./game-stats-ui-handler.json"; -import growth from "./growth.json"; -import menu from "./menu.json"; -import menuUiHandler from "./menu-ui-handler.json"; -import modifier from "./modifier.json"; -import modifierType from "./modifier-type.json"; -import move from "./move.json"; -import nature from "./nature.json"; -import partyUiHandler from "./party-ui-handler.json"; -import pokeball from "./pokeball.json"; -import pokemon from "./pokemon.json"; -import pokemonForm from "./pokemon-form.json"; -import battlePokemonForm from "./pokemon-form-battle.json"; -import pokemonInfo from "./pokemon-info.json"; -import pokemonInfoContainer from "./pokemon-info-container.json"; -import pokemonSummary from "./pokemon-summary.json"; -import saveSlotSelectUiHandler from "./save-slot-select-ui-handler.json"; -import splashMessages from "./splash-messages.json"; -import starterSelectUiHandler from "./starter-select-ui-handler.json"; -import statusEffect from "./status-effect.json"; -import trainerTitles from "./trainer-titles.json"; -import trainerClasses from "./trainer-classes.json"; -import trainerNames from "./trainer-names.json"; -import tutorial from "./tutorial.json"; -import voucher from "./voucher.json"; -import weather from "./weather.json"; -import terrain from "./terrain.json"; -import modifierSelectUiHandler from "./modifier-select-ui-handler.json"; -import moveTriggers from "./move-trigger.json"; -import runHistory from "./run-history.json"; - -export const esConfig = { - ability, - abilityTriggers, - arenaFlyout, - arenaTag, - battle, - battleScene, - battleInfo, - battleMessageUiHandler, - battlePokemonForm, - battlerTags, - berry, - bgmName, - biome, - challenges, - commandUiHandler, - common, - achv, - dialogue, - battleSpecDialogue, - miscDialogue, - doubleBattleDialogue, - egg, - fightUiHandler, - filterBar, - gameMode, - gameStatsUiHandler, - growth, - menu, - menuUiHandler, - modifier, - modifierType, - move, - nature, - pokeball, - pokemon, - pokemonForm, - pokemonInfo, - pokemonInfoContainer, - pokemonSummary, - saveSlotSelectUiHandler, - settings, - splashMessages, - starterSelectUiHandler, - statusEffect, - terrain, - titles: trainerTitles, - trainerClasses, - trainerNames, - tutorial, - voucher, - weather, - partyUiHandler, - modifierSelectUiHandler, - moveTriggers, - runHistory -}; diff --git a/src/locales/es/dialogue-double-battle.json b/src/locales/es/dialogue-double-battle.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/es/dialogue-double-battle.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/es/dialogue-final-boss.json b/src/locales/es/dialogue-final-boss.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/es/dialogue-final-boss.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/es/dialogue-misc.json b/src/locales/es/dialogue-misc.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/es/dialogue-misc.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/es/dialogue.json b/src/locales/es/dialogue.json deleted file mode 100644 index cbd7dbf39ad..00000000000 --- a/src/locales/es/dialogue.json +++ /dev/null @@ -1,52 +0,0 @@ -{ - "aether_grunt": { - "encounter": { - "1": "¡Lucharé con toda mi fuerza para detenerte!", - "2": "Me da igual que seas un crío. Eres una amenaza y debes irte.", - "3": "Me dijeron que mandara a todos los entrenadores por donde venían, ¡sin excepciones!", - "4": "¡Te mostraré el poder del Paraíso Æther!", - "5": "Ahora que conoces la oscuridad en lo profundo del Paraíso Æther, es hora de que vayas desapareciendo..." - }, - "victory": { - "1": "¡Vaya! Demuestras habilidad.", - "2": "¿Qué quiere decir esto? ¿Eh?", - "3": "¡Vaya! Con esa fuerza, ¡no creo que pueda detenerte!", - "4": "Vaya... parece que puede que haya perdido.", - "5": "¡Mira, te hago una mueca!: ¡Aiyee!" - } - }, - "faba": { - "encounter": { - "1": "¡Yo, Subdirector Fabio, te mostraré la cruda realidad del mundo!", - "2": "¿Yo, la última línea de defensa de Æther, battallando a un mero crío?", - "3": "Yo, Fabio, soy el Subdirector de la Fundación Æther. Soy el único en el mundo, soy irremplazable." - }, - "victory": { - "1": "¡Aaaah!", - "2": "¿C-c-cómo puede ser? Eres tan solo un niño...", - "3": "Este... este es el motivo por el que odio a los niños." - } - }, - "aether_boss_lusamine_1": { - "encounter": { - "1": "¡Vas a asustar a mi pobre criatura! Parece que tendré que silenciarte cuanto antes." - }, - "victory": { - "1": "¿Cómo?¿Cómo puedes ser tan terrible?" - }, - "defeat": { - "1": "Buff." - } - }, - "aether_boss_lusamine_2": { - "encounter": { - "1": "¡¿Por qué me sigues molestando?! Estoy cansada de ti. ¡Hasta las narices!\n$Se acabó esta charla innecesaria. Este es el poder de Nihilego, ¡te demostraré cuánto te equivocas al venir aquí!" - }, - "victory": { - "1": "¡¡¡Aaauuuggghhhhhhhhh!!!" - }, - "defeat": { - "1": "¡Todo lo que quiero es a esta preciosa criatura! ¡Los demás no me importáis!" - } - } -} diff --git a/src/locales/es/egg.json b/src/locales/es/egg.json deleted file mode 100644 index 2542d577323..00000000000 --- a/src/locales/es/egg.json +++ /dev/null @@ -1,26 +0,0 @@ -{ - "egg": "Huevo", - "greatTier": "Raro", - "ultraTier": "Épico", - "masterTier": "Legendario", - "defaultTier": "Común", - "hatchWavesMessageSoon": "Se escuchan sonidos. ¡Pronto saldrá!", - "hatchWavesMessageClose": "A veces se mueve. Debe estar a punto de salir.", - "hatchWavesMessageNotClose": "¿Qué habrá dentro? Tendrás que esperar un poco más.", - "hatchWavesMessageLongTime": "Parece que a este huevo le va a costar mucho abrirse.", - "gachaTypeLegendary": "Mayor tasa de Legendario", - "gachaTypeMove": "Mayor tasa de Movimiento Huevo Raro", - "gachaTypeShiny": "Mayor tasa de Shiny", - "selectMachine": "Seleccione una máquina.", - "notEnoughVouchers": "¡No tienes suficientes vales!", - "tooManyEggs": "¡No tienes suficiente espacio!", - "pull": "Tirada", - "pulls": "Tiradas", - "sameSpeciesEgg": "{{species}} will hatch from this egg!", - "hatchFromTheEgg": "¡Ha salido un {{pokemonName}} del Huevo!", - "eggMoveUnlock": "Mov. Huevo desbloqueado:\n{{moveName}}", - "rareEggMoveUnlock": "Mov. Huevo Raro desbloqueado:\n{{moveName}}", - "moveUPGacha": "¡Más Mov.\nHuevo Raro!", - "shinyUPGacha": "¡Más Shiny!", - "legendaryUPGacha": ", ¡mayor\nprob.!" -} diff --git a/src/locales/es/fight-ui-handler.json b/src/locales/es/fight-ui-handler.json deleted file mode 100644 index fa13f2e0e77..00000000000 --- a/src/locales/es/fight-ui-handler.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "pp": "PP", - "power": "Potencia", - "accuracy": "Precisión", - "abilityFlyInText": " {{passive}}{{pokemonName}}\n{{abilityName}}", - "passive": "Pasiva de ", - "teraHover": "Tera-tipo {{type}}" -} diff --git a/src/locales/es/filter-bar.json b/src/locales/es/filter-bar.json deleted file mode 100644 index eac148e211c..00000000000 --- a/src/locales/es/filter-bar.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "genFilter": "Gen.", - "typeFilter": "Tipo", - "caughtFilter": "Capturado", - "unlocksFilter": "Otros", - "miscFilter": "Misc.", - "sortFilter": "Orden", - "all": "Todo", - "normal": "Normal", - "uncaught": "No Capt.", - "passive": "Pasiva", - "passiveUnlocked": "Pasiva desbloq.", - "passiveLocked": "Pasiva bloq.", - "passiveUnlockable": "Pasiva - puede desbloq.", - "costReduction": "Reducción de coste", - "costReductionUnlocked": "Reducción de coste desbloq.", - "costReductionLocked": "Reducción de coste bloq.", - "costReductionUnlockable": "Red. de coste - puede desbloq.", - "favorite": "Favoritos", - "isFavorite": "Favoritos - Sí", - "notFavorite": "Favoritos - No", - "ribbon": "Cinta", - "hasWon": "Cinta - Sí", - "hasNotWon": "Cinta - No", - "hiddenAbility": "Habilidad oculta", - "hasHiddenAbility": "Habilidad oculta - Sí", - "noHiddenAbility": "Habilidad oculta - No", - "egg": "Huevo", - "eggPurchasable": "Huevo - puede comprar", - "pokerus": "Pokérus", - "hasPokerus": "Pokérus - Sí", - "noPokerus": "Pokérus - No", - "sortByNumber": "Núm.", - "sortByCost": "Coste", - "sortByCandies": "# Caramelos", - "sortByIVs": "IVs", - "sortByName": "Nombre" -} \ No newline at end of file diff --git a/src/locales/es/game-mode.json b/src/locales/es/game-mode.json deleted file mode 100644 index 0dbccb45e1f..00000000000 --- a/src/locales/es/game-mode.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "classic": "Clásico", - "endless": "Infinito", - "endlessSpliced": "Infinito (Fusión)", - "dailyRun": "Diario", - "unknown": "Desconocido", - "challenge": "Desafío" -} diff --git a/src/locales/es/game-stats-ui-handler.json b/src/locales/es/game-stats-ui-handler.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/es/game-stats-ui-handler.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/es/growth.json b/src/locales/es/growth.json deleted file mode 100644 index 4def68fde74..00000000000 --- a/src/locales/es/growth.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "Erratic": "Errático", - "Fast": "Rápido", - "Medium_Fast": "Medio Rápido", - "Medium_Slow": "Medio Lento", - "Slow": "Lento", - "Fluctuating": "Fluctuante" -} \ No newline at end of file diff --git a/src/locales/es/menu-ui-handler.json b/src/locales/es/menu-ui-handler.json deleted file mode 100644 index c906324cdbf..00000000000 --- a/src/locales/es/menu-ui-handler.json +++ /dev/null @@ -1,28 +0,0 @@ -{ - "GAME_SETTINGS": "Ajustes", - "ACHIEVEMENTS": "Logros", - "STATS": "Estadísticas", - "RUN_HISTORY": "Historial de partida", - "EGG_LIST": "Lista de Huevos", - "EGG_GACHA": "Gacha de Huevos", - "MANAGE_DATA": "Gestionar Datos", - "COMMUNITY": "Comunidad", - "SAVE_AND_QUIT": "Guardar y Salir", - "LOG_OUT": "Cerrar Sesión", - "slot": "Ranura {{slotNumber}}", - "importSession": "Importar Sesión", - "importSlotSelect": "Selecciona una ranura para importar.", - "exportSession": "Exportar Sesión", - "exportSlotSelect": "Selecciona una ranura para exportar.", - "importRunHistory":"Importar Historial de partida", - "exportRunHistory":"Exportar Historial de partida", - "importData": "Importar Datos", - "exportData": "Exportar Datos", - "consentPreferences": "Consentimiento de datos", - "linkDiscord": "Conectar Discord", - "unlinkDiscord": "Desconectar Discord", - "linkGoogle": "Conectar Google", - "unlinkGoogle": "Desconectar Google", - "cancel": "Cancelar", - "losingProgressionWarning": "Perderás cualquier progreso desde el inicio de la batalla. ¿Continuar?" -} \ No newline at end of file diff --git a/src/locales/es/menu.json b/src/locales/es/menu.json deleted file mode 100644 index a35025819fa..00000000000 --- a/src/locales/es/menu.json +++ /dev/null @@ -1,57 +0,0 @@ -{ - "cancel": "Cancelar", - "continue": "Continuar", - "dailyRun": "Reto diario (Beta)", - "loadGame": "Cargar partida", - "newGame": "Nueva partida", - "settings": "Ajustes", - "selectGameMode": "Elige un modo de juego.", - "logInOrCreateAccount": "Inicia sesión o crea una cuenta para empezar. ¡No se requiere correo electrónico!", - "username": "Usuario", - "password": "Contraseña", - "login": "Iniciar Sesión", - "orUse": "O usa", - "register": "Registrarse", - "emptyUsername": "El usuario no puede estar vacío", - "invalidLoginUsername": "El usuario no es válido", - "invalidRegisterUsername": "El usuario solo puede contener letras, números y guiones bajos.", - "invalidLoginPassword": "La contraseña no es válida", - "invalidRegisterPassword": "La contraseña debe tener 6 o más caracteres.", - "usernameAlreadyUsed": "El usuario ya está en uso", - "accountNonExistent": "El usuario no existe", - "unmatchingPassword": "La contraseña no coincide", - "passwordNotMatchingConfirmPassword": "Las contraseñas deben coincidir", - "confirmPassword": "Confirmar contraseña", - "registrationAgeWarning": "Al registrarte, confirmas tener 13 o más años de edad.", - "backToLogin": "Volver al Login", - "failedToLoadSaveData": "No se han podido cargar los datos guardados. Por favor, recarga la página.\nSi el fallo continúa, por favor comprueba #announcements en nuestro Discord.", - "sessionSuccess": "Sesión cargada con éxito.", - "failedToLoadSession": "No se han podido cargar los datos de tu sesión.\nPuede que estén corruptos.", - "boyOrGirl": "¿Eres un chico o una chica?", - "evolving": "¡Anda!\n¡{{pokemonName}} está evolucionando!", - "stoppedEvolving": "¿Eh?\n¡La evolución de {{pokemonName}} se ha detenido!", - "pauseEvolutionsQuestion": "¿Quieres detener las evoluciones de {{pokemonName}}?\nSiempre pueden ser reactivadas desde la pantalla de tu equipo.", - "evolutionsPaused": "Se han detenido las evoluciones para {{pokemonName}}.", - "evolutionDone": "¡Enhorabuena!\n¡Tu {{pokemonName}} ha evolucionado a {{evolvedPokemonName}}!", - "dailyRankings": "Rankings Diarios", - "weeklyRankings": "Rankings Semanales", - "noRankings": "Sin Rankings", - "positionIcon": "#", - "usernameScoreboard": "Usuario", - "score": "Puntos", - "wave": "Oleada", - "loading": "Cargando…", - "loadingAsset": "Cargando recurso: {{assetName}}", - "playersOnline": "Jugadores en Línea", - "yes": "Sí", - "no": "No", - "disclaimer": "AVISO", - "disclaimerDescription": "Este juego es un producto inacabado; puede tener problemas de jugabilidad (incluyendo la posible pérdida\n de datos de guardado), cambiar sin avisar, y puede o no puede ser actualizado hasta ser completado.", - "choosePokemon": "Elige un Pokémon.", - "renamePokemon": "Renombrar Pokémon.", - "rename": "Renombrar", - "nickname": "Apodo", - "errorServerDown": "¡Ups! Ha habido un problema al contactar con el servidor.\n\nPuedes mantener esta ventana abierta,\nel juego se reconectará automáticamente.", - "noSaves": "No tienes ninguna partida guardada registrada!", - "tooManySaves": "¡Tienes demasiadas partidas guardadas registradas!" -} diff --git a/src/locales/es/modifier-select-ui-handler.json b/src/locales/es/modifier-select-ui-handler.json deleted file mode 100644 index 7adcb885c9e..00000000000 --- a/src/locales/es/modifier-select-ui-handler.json +++ /dev/null @@ -1,12 +0,0 @@ -{ - "transfer": "Transferir", - "reroll": "Actualizar", - "lockRarities": "Bloquear rarezas", - "checkTeam": "Ver Equipo", - "transferDesc": "Transfiere un objeto que lleva un Pokémon a otro.", - "rerollDesc": "Gasta dinero para actualizar las opciones de objetos.", - "lockRaritiesDesc": "Bloquea las rarezas de los objetos al actualizar (afecta el costo de actualización).", - "checkTeamDesc": "Revisa tu equipo o usa un objeto que cambia de forma.", - "rerollCost": "{{formattedMoney}} ₽", - "itemCost": "{{formattedMoney}} ₽" -} \ No newline at end of file diff --git a/src/locales/es/modifier-type.json b/src/locales/es/modifier-type.json deleted file mode 100644 index 3ac4d85f793..00000000000 --- a/src/locales/es/modifier-type.json +++ /dev/null @@ -1,607 +0,0 @@ -{ - "ModifierType": { - "AddPokeballModifierType": { - "name": "{{modifierCount}}x {{pokeballName}}", - "description": "Recibes {{modifierCount}}x {{pokeballName}} (En inventario: {{pokeballAmount}}) \nRatio de captura: {{catchRate}}." - }, - "AddVoucherModifierType": { - "name": "{{modifierCount}}x {{voucherTypeName}}", - "description": "Recibes {{modifierCount}}x {{voucherTypeName}}." - }, - "PokemonHeldItemModifierType": { - "extra": { - "inoperable": "¡{{pokemonName}} no puede\nrecibir este objeto!", - "tooMany": "¡{{pokemonName}} tiene este objeto\ndemasiadas veces!" - } - }, - "PokemonHpRestoreModifierType": { - "description": "Restaura {{restorePoints}} PS o, al menos, un {{restorePercent}}% PS de un Pokémon.", - "extra": { - "fully": "Restaura todos los PS de un Pokémon.", - "fullyWithStatus": "Restaura todos los PS de un Pokémon y cura todos los problemas de estados." - } - }, - "PokemonReviveModifierType": { - "description": "Revive a un Pokémon y restaura {{restorePercent}}% PS." - }, - "PokemonStatusHealModifierType": { - "description": "Cura todos los problemas de estados de un Pokémon." - }, - "PokemonPpRestoreModifierType": { - "description": "Restaura {{restorePoints}} PP del movimiento que elijas de un Pokémon.", - "extra": { - "fully": "Restaura todos los PP del movimiento que elijas de un Pokémon." - } - }, - "PokemonAllMovePpRestoreModifierType": { - "description": "Restaura {{restorePoints}} PP de todos los movimientos de un Pokémon.", - "extra": { - "fully": "Restaura todos los PP de todos los movimientos de un Pokémon." - } - }, - "PokemonPpUpModifierType": { - "description": "Aumenta permanentemente los PP para un movimiento de un Pokémon en {{upPoints}} por cada 5 PP máximo (máximo 3)." - }, - "PokemonNatureChangeModifierType": { - "name": "Menta {{natureName}}", - "description": "Cambia la naturaleza de un Pokémon a {{natureName}} y desbloquea permanentemente dicha naturaleza para el inicial." - }, - "DoubleBattleChanceBoosterModifierType": { - "description": "Cuadruplica la posibilidad de que un encuentro sea una combate doble durante {{battleCount}} combates." - }, - "TempStatStageBoosterModifierType": { - "description": "Aumenta la est. {{stat}} de todos los miembros del equipo en {{amount}} durante 5 combates.", - "extra": { - "stage": "1 nivel", - "percentage": "30%" - } - }, - "AttackTypeBoosterModifierType": { - "description": "Aumenta la potencia de los movimientos de tipo {{moveType}} de un Pokémon en un 20%." - }, - "PokemonLevelIncrementModifierType": { - "description": "Aumenta el nivel de un Pokémon en {{levels}}." - }, - "AllPokemonLevelIncrementModifierType": { - "description": "Aumenta el nivel de todos los miembros del equipo en {{levels}}." - }, - "BaseStatBoosterModifierType": { - "description": "Aumenta la est. {{stat}} base del portador en un 10%.\nCuanto mayores sean tus IVs, mayor será el límite de acumulación." - }, - "AllPokemonFullHpRestoreModifierType": { - "description": "Restaura el 100% de los PS de todos los Pokémon." - }, - "AllPokemonFullReviveModifierType": { - "description": "Revive a todos los Pokémon debilitados y restaura completamente sus PS." - }, - "MoneyRewardModifierType": { - "description": "Otorga una {{moneyMultiplier}} cantidad de dinero (₽{{moneyAmount}}).", - "extra": { - "small": "pequeña", - "moderate": "moderada", - "large": "gran" - } - }, - "ExpBoosterModifierType": { - "description": "Aumenta la ganancia de EXP en un {{boostPercent}}%." - }, - "PokemonExpBoosterModifierType": { - "description": "Aumenta la ganancia de EXP del portador en un {{boostPercent}}%." - }, - "PokemonFriendshipBoosterModifierType": { - "description": "Aumenta la ganancia de amistad por victoria en un 50%." - }, - "PokemonMoveAccuracyBoosterModifierType": { - "description": "Aumenta la precisión de los movimiento en un {{accuracyAmount}} (máximo 100)." - }, - "PokemonMultiHitModifierType": { - "description": "Los ataques golpean una vez más a costa de una reducción de poder del 60/75/82,5% por cada objeto." - }, - "TmModifierType": { - "name": "MT{{moveId}} - {{moveName}}", - "description": "Enseña {{moveName}} a un Pokémon." - }, - "TmModifierTypeWithInfo": { - "name": "MT{{moveId}} - {{moveName}}", - "description": "Enseña {{moveName}} a un Pokémon\n(Mantén pulsado C o Shift para más info)." - }, - "EvolutionItemModifierType": { - "description": "Hace que ciertos Pokémon evolucionen." - }, - "FormChangeItemModifierType": { - "description": "Hace que ciertos Pokémon cambien de forma." - }, - "FusePokemonModifierType": { - "description": "Fusiona dos Pokémon (transfiere habilidades, divide estadísticas bases y tipos, comparte movimientos)." - }, - "TerastallizeModifierType": { - "name": "Teralito {{teraType}}", - "description": "Teracristaliza al portador al tipo {{teraType}} durante 10 combates." - }, - "ContactHeldItemTransferChanceModifierType": { - "description": "Al atacar, hay un {{chancePercent}}% de posibilidades de que robes el objeto que tiene el enemigo." - }, - "TurnHeldItemTransferModifierType": { - "description": "Cada turno, el portador roba un objeto del enemigo." - }, - "EnemyAttackStatusEffectChanceModifierType": { - "description": "Agrega un {{chancePercent}}% de probabilidad de infligir {{statusEffect}} con movimientos de ataque." - }, - "EnemyEndureChanceModifierType": { - "description": "Agrega un {{chancePercent}}% de probabilidad de resistir un ataque que lo debilitaría." - }, - "RARE_CANDY": { - "name": "Carameloraro" - }, - "RARER_CANDY": { - "name": "Caramelorarísimo" - }, - "MEGA_BRACELET": { - "name": "Megapulsera", - "description": "Las megapiedras se vuelven disponibles." - }, - "DYNAMAX_BAND": { - "name": "Maximuñequera", - "description": "Las maxisetas se vuelven disponibles." - }, - "TERA_ORB": { - "name": "Orbe Teracristal", - "description": "Los Teralitos están disponibles." - }, - "MAP": { - "name": "Mapa", - "description": "Te permite elegir tu camino al final del bioma." - }, - "POTION": { - "name": "Poción" - }, - "SUPER_POTION": { - "name": "Superpoción" - }, - "HYPER_POTION": { - "name": "Hiperpoción" - }, - "MAX_POTION": { - "name": "Máx. poción" - }, - "FULL_RESTORE": { - "name": "Restau. todo" - }, - "REVIVE": { - "name": "Revivir" - }, - "MAX_REVIVE": { - "name": "Máx. revivir" - }, - "FULL_HEAL": { - "name": "Cura total" - }, - "SACRED_ASH": { - "name": "Ceniza sagrada" - }, - "REVIVER_SEED": { - "name": "Semilla revivir", - "description": "Revive al portador con la mitad de sus PS al debilitarse por un golpe directo." - }, - "WHITE_HERB": { - "name": "Hierba blanca", - "description": "Un objeto que puede llevar un Pokémon. Restaurará cualquier estadística reducida en combate." - }, - "ETHER": { - "name": "Éter" - }, - "MAX_ETHER": { - "name": "Éter máx." - }, - "ELIXIR": { - "name": "Elixir" - }, - "MAX_ELIXIR": { - "name": "Elixir máx." - }, - "PP_UP": { - "name": "Más PP" - }, - "PP_MAX": { - "name": "Máx PP" - }, - "LURE": { - "name": "Incienso" - }, - "SUPER_LURE": { - "name": "Superincienso" - }, - "MAX_LURE": { - "name": "Incienso máximo" - }, - "MEMORY_MUSHROOM": { - "name": "Seta recuerdo", - "description": "Recuerda un movimiento olvidado de un Pokémon." - }, - "EXP_SHARE": { - "name": "Repartir EXP", - "description": "Los que no combatan reciben el 20% de la EXP." - }, - "EXP_BALANCE": { - "name": "Equilibrador EXP", - "description": "Da una mayor parte de la EXP recibida a los miembros del equipo que tengan menos nivel." - }, - "OVAL_CHARM": { - "name": "Amuleto Oval", - "description": "Cada Pokémon combatiente recibe un 10% adicional de la EXP total." - }, - "EXP_CHARM": { - "name": "Amuleto EXP" - }, - "SUPER_EXP_CHARM": { - "name": "Super Amuleto EXP" - }, - "GOLDEN_EXP_CHARM": { - "name": "Amuleto EXP Dorado" - }, - "LUCKY_EGG": { - "name": "Huevo suerte" - }, - "GOLDEN_EGG": { - "name": "Huevo dorado" - }, - "SOOTHE_BELL": { - "name": "Camp. alivio" - }, - "SCOPE_LENS": { - "name": "Periscopio", - "description": "Aumenta la probabilidad de asestar un golpe crítico." - }, - "DIRE_HIT": { - "name": "Crítico X", - "extra": { - "raises": "Critical Hit Ratio" - } - }, - "LEEK": { - "name": "Puerro", - "description": "Puerro muy largo y duro que aumenta la probabilidad de asestar un golpe crítico. Debe llevarlo Farfetch'd." - }, - "EVIOLITE": { - "name": "Mineral evolutivo", - "description": "Roca misteriosa. El Pokémon portador aumentará su Defensa y su Defensa Especial si aún puede evolucionar." - }, - "SOUL_DEW": { - "name": "Rocío bondad", - "description": "Aumenta la influencia de la naturaleza de un Pokémon en sus estadísticas en un 10% (aditivo)." - }, - "NUGGET": { - "name": "Pepita" - }, - "BIG_NUGGET": { - "name": "Maxipepita" - }, - "RELIC_GOLD": { - "name": "Real de oro" - }, - "AMULET_COIN": { - "name": "Moneda amuleto", - "description": "Aumenta el dinero ganado en un 20%." - }, - "GOLDEN_PUNCH": { - "name": "Puño Dorado", - "description": "Otorga el 50% del daño infligido como dinero." - }, - "COIN_CASE": { - "name": "Monedero", - "description": "Después de cada 10 combates, recibe el 10% de tu dinero en intereses." - }, - "LOCK_CAPSULE": { - "name": "Cápsula candado", - "description": "Permite bloquear las rarezas de los objetos al refrescar objetos." - }, - "GRIP_CLAW": { - "name": "Garra garfio" - }, - "WIDE_LENS": { - "name": "Lupa" - }, - "MULTI_LENS": { - "name": "Multilupa" - }, - "HEALING_CHARM": { - "name": "Amuleto curación", - "description": "Aumenta la efectividad de los movimientos y objetos de curacion de PS en un 10% (excepto revivir)." - }, - "CANDY_JAR": { - "name": "Tarrón de caramelos", - "description": "Aumenta la cantidad de niveles otorgados por los ítems Caramelos Raros en 1." - }, - "BERRY_POUCH": { - "name": "Saco bayas", - "description": "Añade un 30% de posibilidades de que una baya no se gaste al usarla." - }, - "FOCUS_BAND": { - "name": "Banda aguante", - "description": "Agrega un 10% de probabilidad de resistir un ataque que lo debilitaría." - }, - "QUICK_CLAW": { - "name": "Garra rápida", - "description": "Agrega un 10% de probabilidad de atacar primero independientemente de la velocidad (después de la prioridad)." - }, - "KINGS_ROCK": { - "name": "Roca del rey", - "description": "Agrega un 10% de probabilidad de que un ataque haga que el oponente retroceda." - }, - "LEFTOVERS": { - "name": "Restos", - "description": "Cura 1/16 de los PS máximo de un Pokémon cada turno." - }, - "SHELL_BELL": { - "name": "Cascabel concha", - "description": "Cura 1/8 del daño infligido por un Pokémon." - }, - "TOXIC_ORB": { - "name": "Toxiesfera", - "description": "Extraña esfera que envenena gravemente a quien la usa en combate." - }, - "FLAME_ORB": { - "name": "Llamasfera", - "description": "Extraña esfera que causa quemaduras a quien la usa en combate." - }, - "BATON": { - "name": "Testigo", - "description": "Permite pasar los efectos al cambiar de Pokémon, también evita las trampas." - }, - "SHINY_CHARM": { - "name": "Amuleto iris", - "description": "Aumenta drásticamente la posibilidad de que un Pokémon salvaje sea Shiny." - }, - "ABILITY_CHARM": { - "name": "Amuleto habilidad", - "description": "Aumenta drásticamente la posibilidad de que un Pokémon salvaje tenga una habilidad oculta." - }, - "IV_SCANNER": { - "name": "Escáner IV", - "description": "Permite escanear los IVs de Pokémon salvajes. Se revelan 2 IVs por cada objeto.\nLos mejores IVs se muestran primero." - }, - "DNA_SPLICERS": { - "name": "Punta ADN" - }, - "MINI_BLACK_HOLE": { - "name": "Mini agujero negro" - }, - "GOLDEN_POKEBALL": { - "name": "Poké Ball Dorada", - "description": "Agrega 1 opción de objeto extra al final de cada combate." - }, - "ENEMY_DAMAGE_BOOSTER": { - "name": "Ficha de daño", - "description": "Aumenta el daño en un 5%." - }, - "ENEMY_DAMAGE_REDUCTION": { - "name": "Ficha de protección", - "description": "Reduce el daño recibido en un 2,5%." - }, - "ENEMY_HEAL": { - "name": "Ficha de curación", - "description": "Cura el 2% de los PS máximo en cada turno." - }, - "ENEMY_ATTACK_POISON_CHANCE": { - "name": "Ficha veneno" - }, - "ENEMY_ATTACK_PARALYZE_CHANCE": { - "name": "Ficha parálisis" - }, - "ENEMY_ATTACK_BURN_CHANCE": { - "name": "Ficha quemadura" - }, - "ENEMY_STATUS_EFFECT_HEAL_CHANCE": { - "name": "Ficha cura total", - "description": "Agrega un 2.5% de probabilidad cada turno de curar un problema de estado." - }, - "ENEMY_ENDURE_CHANCE": { - "name": "Ficha aguante" - }, - "ENEMY_FUSED_CHANCE": { - "name": "Ficha fusión", - "description": "Agrega un 1% de probabilidad de que un Pokémon salvaje sea una fusión." - } - }, - "SpeciesBoosterItem": { - "LIGHT_BALL": { - "name": "Bola luminosa", - "description": "Asombrosa esfera que aumenta el Ataque y el Ataque Especial. Debe llevarla Pikachu." - }, - "THICK_CLUB": { - "name": "Hueso grueso", - "description": "Extraño tipo de hueso que potencia los ataques físicos. Debe llevarlo Cubone o Marowak." - }, - "METAL_POWDER": { - "name": "Polvo metálico", - "description": "Polvo muy fino, pero a la vez poderoso, que aumenta la Defensa. Debe llevarlo Ditto." - }, - "QUICK_POWDER": { - "name": "Polvo veloz", - "description": "Polvo muy fino, pero a la vez poderoso, que aumenta la Velocidad. Debe llevarlo Ditto." - } - }, - "TempStatStageBoosterItem": { - "x_attack": "Ataque X", - "x_defense": "Defensa X", - "x_sp_atk": "Ataq. Esp. X", - "x_sp_def": "Def. Esp. X", - "x_speed": "Velocidad X", - "x_accuracy": "Precisión X" - }, - "AttackTypeBoosterItem": { - "silk_scarf": "Pañuelo seda", - "black_belt": "Cinturón negro", - "sharp_beak": "Pico afilado", - "poison_barb": "Flecha venenosa", - "soft_sand": "Arena fina", - "hard_stone": "Piedra dura", - "silver_powder": "Polvo plata", - "spell_tag": "Hechizo", - "metal_coat": "Revest. metálico", - "charcoal": "Carbón", - "mystic_water": "Agua mística", - "miracle_seed": "Semilla milagro", - "magnet": "Imán", - "twisted_spoon": "Cuchara torcida", - "never_melt_ice": "Antiderretir", - "dragon_fang": "Colmillo dragón", - "black_glasses": "Gafas de sol", - "fairy_feather": "Pluma feérica" - }, - "BaseStatBoosterItem": { - "hp_up": "Más PS", - "protein": "Proteína", - "iron": "Hierro", - "calcium": "Calcio", - "zinc": "Zinc", - "carbos": "Carburante" - }, - "EvolutionItem": { - "NONE": "Ninguno", - "LINKING_CORD": "Cordón unión", - "SUN_STONE": "Piedra solar", - "MOON_STONE": "Piedra lunar", - "LEAF_STONE": "Piedra hoja", - "FIRE_STONE": "Piedra fuego", - "WATER_STONE": "Piedra agua", - "THUNDER_STONE": "Piedra trueno", - "ICE_STONE": "Piedra hielo", - "DUSK_STONE": "Piedra noche", - "DAWN_STONE": "Piedra alba", - "SHINY_STONE": "Piedra día", - "CRACKED_POT": "Tetera agrietada", - "SWEET_APPLE": "Manzana dulce", - "TART_APPLE": "Manzana ácida", - "STRAWBERRY_SWEET": "Confite fresa", - "UNREMARKABLE_TEACUP": "Cuenco mediocre", - "CHIPPED_POT": "Tetera rota", - "BLACK_AUGURITE": "Mineral negro", - "GALARICA_CUFF": "Brazal galanuez", - "GALARICA_WREATH": "Corona galanuez", - "PEAT_BLOCK": "Bloque de turba", - "AUSPICIOUS_ARMOR": "Armadura auspiciosa", - "MALICIOUS_ARMOR": "Armadura maldita", - "MASTERPIECE_TEACUP": "Cuenco exquisito", - "METAL_ALLOY": "Metal compuesto", - "SCROLL_OF_DARKNESS": "Manuscrito sombras", - "SCROLL_OF_WATERS": "Manuscrito aguas", - "SYRUPY_APPLE": "Manzana melosa" - }, - "FormChangeItem": { - "NONE": "Ninguno", - "ABOMASITE": "Abomasnowita", - "ABSOLITE": "Absolita", - "AERODACTYLITE": "Aerodactylita", - "AGGRONITE": "Aggronita", - "ALAKAZITE": "Alakazamita", - "ALTARIANITE": "Altarianita", - "AMPHAROSITE": "Ampharosita", - "AUDINITE": "Audinita", - "BANETTITE": "Banettita", - "BEEDRILLITE": "Beedrillita", - "BLASTOISINITE": "Blastoisita", - "BLAZIKENITE": "Blazikenita", - "CAMERUPTITE": "Cameruptita", - "CHARIZARDITE_X": "Charizardita X", - "CHARIZARDITE_Y": "Charizardita Y", - "DIANCITE": "Diancita", - "GALLADITE": "Galladita", - "GARCHOMPITE": "Garchompita", - "GARDEVOIRITE": "Gardevoirita", - "GENGARITE": "Gengarita", - "GLALITITE": "Glalita", - "GYARADOSITE": "Gyaradosita", - "HERACRONITE": "Heracrossita", - "HOUNDOOMINITE": "Houndoomita", - "KANGASKHANITE": "Kangaskhanita", - "LATIASITE": "Latiasita", - "LATIOSITE": "Latiosita", - "LOPUNNITE": "Lopunnita", - "LUCARIONITE": "Lucarita", - "MANECTITE": "Manectricita", - "MAWILITE": "Mawilita", - "MEDICHAMITE": "Medichamita", - "METAGROSSITE": "Metagrossita", - "MEWTWONITE_X": "Mewtwoita X", - "MEWTWONITE_Y": "Mewtwoita Y", - "PIDGEOTITE": "Pidgeotita", - "PINSIRITE": "Pinsirita", - "RAYQUAZITE": "Rayquazita", - "SABLENITE": "Sableynita", - "SALAMENCITE": "Salamencita", - "SCEPTILITE": "Sceptilita", - "SCIZORITE": "Scizorita", - "SHARPEDONITE": "Sharpedonita", - "SLOWBRONITE": "Slowbronita", - "STEELIXITE": "Steelixita", - "SWAMPERTITE": "Swampertita", - "TYRANITARITE": "Tyranitarita", - "VENUSAURITE": "Venusaurita", - "BLUE_ORB": "Prisma azul", - "RED_ORB": "Prisma rojo", - "SHARP_METEORITE": "Meteorito afilado", - "HARD_METEORITE": "Meteorito duro", - "SMOOTH_METEORITE": "Meteorito suave", - "ADAMANT_CRYSTAL": "Gran diamansfera", - "LUSTROUS_GLOBE": "Gran lustresfera", - "GRISEOUS_CORE": "Gran griseosfera", - "REVEAL_GLASS": "Espejo veraz", - "GRACIDEA": "Gracídea", - "MAX_MUSHROOMS": "Maxisetas", - "DARK_STONE": "Orbe oscuro", - "LIGHT_STONE": "Orbe claro", - "PRISON_BOTTLE": "Vasija castigo", - "N_LUNARIZER": "Necroluna", - "N_SOLARIZER": "Necrosol", - "RUSTED_SWORD": "Espada oxidada", - "RUSTED_SHIELD": "Escudo oxidado", - "ICY_REINS_OF_UNITY": "Riendas unión heladas", - "SHADOW_REINS_OF_UNITY": "Riendas unión oscuras", - "WELLSPRING_MASK": "Máscara fuente", - "HEARTHFLAME_MASK": "Máscara horno", - "CORNERSTONE_MASK": "Máscara cimiento", - "SHOCK_DRIVE": "FulgoROM", - "BURN_DRIVE": "PiroROM", - "CHILL_DRIVE": "CrioROM", - "DOUSE_DRIVE": "HidroROM", - "ULTRANECROZIUM_Z": "Ultranecrostal Z", - "FIST_PLATE": "Tabla fuerte", - "SKY_PLATE": "Tabla cielo", - "TOXIC_PLATE": "Tabla tóxica", - "EARTH_PLATE": "Tabla terrax", - "STONE_PLATE": "Tabla pétrea", - "INSECT_PLATE": "Tabla bicho", - "SPOOKY_PLATE": "Tabla terror", - "IRON_PLATE": "Tabla acero", - "FLAME_PLATE": "Tabla llama", - "SPLASH_PLATE": "Tabla linfa", - "MEADOW_PLATE": "Tabla pradal", - "ZAP_PLATE": "Tabla trueno", - "MIND_PLATE": "Tabla mental", - "ICICLE_PLATE": "Tabla helada", - "DRACO_PLATE": "Tabla draco", - "DREAD_PLATE": "Tabla oscura", - "PIXIE_PLATE": "Tabla duende", - "BLANK_PLATE": "Tabla neutra", - "LEGEND_PLATE": "Tabla legendaria", - "FIGHTING_MEMORY": "Disco lucha", - "FLYING_MEMORY": "Disco volador", - "POISON_MEMORY": "Disco veneno", - "GROUND_MEMORY": "Disco tierra", - "ROCK_MEMORY": "Disco roca", - "BUG_MEMORY": "Disco bicho", - "GHOST_MEMORY": "Disco fantasma", - "STEEL_MEMORY": "Disco acero", - "FIRE_MEMORY": "Disco fuego", - "WATER_MEMORY": "Disco agua", - "GRASS_MEMORY": "Disco planta", - "ELECTRIC_MEMORY": "Disco eléctrico", - "PSYCHIC_MEMORY": "Disco psíquico", - "ICE_MEMORY": "Disco hielo", - "DRAGON_MEMORY": "Disco dragón", - "DARK_MEMORY": "Disco siniestro", - "FAIRY_MEMORY": "Disco hada", - "NORMAL_MEMORY": "Disco normal" - } -} diff --git a/src/locales/es/modifier.json b/src/locales/es/modifier.json deleted file mode 100644 index a94e41a4574..00000000000 --- a/src/locales/es/modifier.json +++ /dev/null @@ -1,12 +0,0 @@ -{ - "surviveDamageApply": "{{pokemonNameWithAffix}} ha usado {{typeName}} y ha logrado resistir!", - "turnHealApply": "{{pokemonNameWithAffix}} ha recuperado unos pocos PS gracias a {{typeName}}!", - "hitHealApply": "{{pokemonNameWithAffix}} ha recuperado unos pocos PS gracias a {{typeName}}!", - "pokemonInstantReviveApply": "{{pokemonNameWithAffix}} ha sido revivido gracias a su {{typeName}}!", - "pokemonResetNegativeStatStageApply": "Las estadísticas bajadas de {{pokemonNameWithAffix}} fueron restauradas gracias a {{typeName}}!", - "moneyInterestApply": "Recibiste intereses de ₽{{moneyAmount}}\ngracias a {{typeName}}!", - "turnHeldItemTransferApply": "{{pokemonNameWithAffix}}'s {{itemName}} fue absorbido\npor {{pokemonName}}'s {{typeName}}!", - "contactHeldItemTransferApply": "{{pokemonNameWithAffix}}'s {{itemName}} fue robado por {{pokemonName}}'s {{typeName}}!", - "enemyTurnHealApply": "¡{{pokemonNameWithAffix}}\nrecuperó algunos PS!", - "bypassSpeedChanceApply": "¡Gracias a su {{itemName}}, {{pokemonName}} puede tener prioridad!" -} diff --git a/src/locales/es/move-trigger.json b/src/locales/es/move-trigger.json deleted file mode 100644 index 2322a49056f..00000000000 --- a/src/locales/es/move-trigger.json +++ /dev/null @@ -1,17 +0,0 @@ -{ - "switchedTwoStatChanges": "{{pokemonName}} ha intercambiado los cambios en {{firstStat}} y {{secondStat}} con los del objetivo!", - "switchedStat": "{{pokemonName}} cambia su {{stat}} por la de su objetivo!", - "sharedGuard": "{{pokemonName}} suma su capacidad defensiva a la del objetivo y la reparte equitativamente!", - "sharedPower": "{{pokemonName}} suma su capacidad ofensiva a la del objetivo y la reparte equitativamente!", - "isChargingPower": "¡{{pokemonName}} está acumulando energía!", - "burnedItselfOut": "¡El fuego interior de {{pokemonName}} se ha extinguido!", - "startedHeatingUpBeak": "¡{{pokemonName}} empieza\na calentar su pico!", - "setUpShellTrap": "¡{{pokemonName}} ha activado la Coraza Trampa!", - "isOverflowingWithSpacePower": "¡{{pokemonName}} rebosa\nenergía cósmica!", - "usedUpAllElectricity": "¡{{pokemonName}} ha descargado toda su electricidad!", - "stoleItem": "¡{{pokemonName}} robó el objeto\n{{itemName}} de {{targetName}}!", - "statEliminated": "¡Los cambios en estadísticas fueron eliminados!", - "revivalBlessing": "¡{{pokemonName}} ha revivido!", - "safeguard": "¡{{targetName}} está protegido por Velo Sagrado!", - "afterYou": "¡{{pokemonName}} ha decidido aprovechar la oportunidad!" -} diff --git a/src/locales/es/move.json b/src/locales/es/move.json deleted file mode 100644 index f4c28dd02e7..00000000000 --- a/src/locales/es/move.json +++ /dev/null @@ -1,3810 +0,0 @@ -{ - "pound": { - "name": "Destructor", - "effect": "Golpea al objetivo con las extremidades, la cola o similares." - }, - "karateChop": { - "name": "Golpe Kárate", - "effect": "Da un golpe cortante. Suele ser crítico." - }, - "doubleSlap": { - "name": "Doble Bofetón", - "effect": "Abofetea de dos a cinco veces seguidas." - }, - "cometPunch": { - "name": "Puño Cometa", - "effect": "Pega de dos a cinco veces seguidas." - }, - "megaPunch": { - "name": "Megapuño", - "effect": "Un puñetazo de gran potencia." - }, - "payDay": { - "name": "Día de Pago", - "effect": "Arroja monedas al objetivo y las recupera al final del combate." - }, - "firePunch": { - "name": "Puño Fuego", - "effect": "Puñetazo ardiente que puede causar quemaduras." - }, - "icePunch": { - "name": "Puño Hielo", - "effect": "Puñetazo helado que puede llegar a congelar." - }, - "thunderPunch": { - "name": "Puño Trueno", - "effect": "Puñetazo eléctrico que puede paralizar al adversario." - }, - "scratch": { - "name": "Arañazo", - "effect": "Araña con afiladas garras." - }, - "viseGrip": { - "name": "Agarre", - "effect": "Atenaza al objetivo y le inflige daño." - }, - "guillotine": { - "name": "Guillotina", - "effect": "Ataque cortante que debilita al oponente de un golpe si acierta." - }, - "razorWind": { - "name": "Viento Cortante", - "effect": "Primero se prepara y en el segundo turno ataca al oponente con ráfagas de viento cortante. Alta probabilidad de ser crítico." - }, - "swordsDance": { - "name": "Danza Espada", - "effect": "Baile frenético que aumenta mucho el Ataque." - }, - "cut": { - "name": "Corte", - "effect": "Corta al adversario con garras, guadañas, etc." - }, - "gust": { - "name": "Tornado", - "effect": "Crea un tornado con las alas y lo lanza contra el objetivo." - }, - "wingAttack": { - "name": "Ataque Ala", - "effect": "Extiende totalmente sus majestuosas alas para golpear al objetivo con ellas." - }, - "whirlwind": { - "name": "Remolino", - "effect": "Se lleva al objetivo, que es cambiado por otro Pokémon. Si es un Pokémon salvaje, acaba el combate." - }, - "fly": { - "name": "Vuelo", - "effect": "El usuario vuela en el primer turno y ataca en el segundo." - }, - "bind": { - "name": "Atadura", - "effect": "Ata y oprime de cuatro a cinco turnos." - }, - "slam": { - "name": "Atizar", - "effect": "Golpea con la cola o con lianas, por ejemplo, para causar daño al objetivo." - }, - "vineWhip": { - "name": "Látigo Cepa", - "effect": "Azota al objetivo con lianas delgadas y largas tan flexibles como látigos." - }, - "stomp": { - "name": "Pisotón", - "effect": "Tremendo pisotón que puede hacer que el objetivo se amedrente." - }, - "doubleKick": { - "name": "Doble Patada", - "effect": "Una patada doble. Golpea dos veces." - }, - "megaKick": { - "name": "Megapatada", - "effect": "Patada de extrema fuerza." - }, - "jumpKick": { - "name": "Patada Salto", - "effect": "Da un salto y pega una patada. Si falla, se lesiona." - }, - "rollingKick": { - "name": "Patada Giro", - "effect": "Da una patada rápida y circular. Puede hacer retroceder al objetivo." - }, - "sandAttack": { - "name": "Ataque Arena", - "effect": "Arroja arena a la cara y baja la Precisión." - }, - "headbutt": { - "name": "Golpe Cabeza", - "effect": "Potente cabezazo que puede amedrentar al objetivo." - }, - "hornAttack": { - "name": "Cornada", - "effect": "Ataca al objetivo con una cornada punzante." - }, - "furyAttack": { - "name": "Ataque Furia", - "effect": "Cornea al objetivo de dos a cinco veces." - }, - "hornDrill": { - "name": "Perforador", - "effect": "Ataque con un cuerno giratorio que fulmina al objetivo de un solo golpe si acierta." - }, - "tackle": { - "name": "Placaje", - "effect": "Embestida con todo el cuerpo." - }, - "bodySlam": { - "name": "Golpe Cuerpo", - "effect": "Salta sobre el objetivo con todo su peso y puede llegar a paralizarlo." - }, - "wrap": { - "name": "Constricción", - "effect": "Oprime al objetivo de cuatro a cinco turnos con lianas o con su cuerpo." - }, - "takeDown": { - "name": "Derribo", - "effect": "Carga desmedida que también hiere al agresor." - }, - "thrash": { - "name": "Saña", - "effect": "El usuario ataca enfurecido durante dos o tres turnos y, después, se queda confuso." - }, - "doubleEdge": { - "name": "Doble Filo", - "effect": "Ataque arriesgado que también hiere al agresor." - }, - "tailWhip": { - "name": "Látigo", - "effect": "Agita la cola para bajar la Defensa del equipo rival." - }, - "poisonSting": { - "name": "Picotazo Veneno", - "effect": "Lanza un aguijón tóxico que puede envenenar al objetivo." - }, - "twineedle": { - "name": "Doble Ataque", - "effect": "Pincha dos veces con dos espinas. Puede envenenar." - }, - "pinMissile": { - "name": "Pin Misil", - "effect": "Lanza finas púas que hieren de dos a cinco veces." - }, - "leer": { - "name": "Malicioso", - "effect": "Intimida a los rivales para bajar su Defensa." - }, - "bite": { - "name": "Mordisco", - "effect": "Un voraz bocado con dientes afilados que puede amedrentar al objetivo." - }, - "growl": { - "name": "Gruñido", - "effect": "Dulce gruñido que distrae al objetivo para que baje la guardia y reduce su Ataque." - }, - "roar": { - "name": "Rugido", - "effect": "Se lleva al objetivo, que es cambiado por otro Pokémon. Si es un Pokémon salvaje, acaba el combate." - }, - "sing": { - "name": "Canto", - "effect": "Cancioncilla que hace dormir profundamente al objetivo." - }, - "supersonic": { - "name": "Supersónico", - "effect": "El cuerpo del usuario emite unas ondas sónicas raras que confunden al objetivo." - }, - "sonicBoom": { - "name": "Bomba Sónica", - "effect": "Lanza ondas de choque que restan 20 PS al objetivo." - }, - "disable": { - "name": "Anulación", - "effect": "Desactiva el último movimiento del objetivo durante cuatro turnos." - }, - "acid": { - "name": "Ácido", - "effect": "Rocía al objetivo con un ácido corrosivo. Puede reducir la Defensa Especial." - }, - "ember": { - "name": "Ascuas", - "effect": "Ataca con llamas pequeñas que pueden causar quemaduras." - }, - "flamethrower": { - "name": "Lanzallamas", - "effect": "Ataca con una gran ráfaga de fuego que puede causar quemaduras." - }, - "mist": { - "name": "Neblina", - "effect": "Rodea de una niebla blanquecina al bando del usuario e impide que el rival reduzca sus características durante cinco turnos." - }, - "waterGun": { - "name": "Pistola Agua", - "effect": "Ataca disparando agua con gran potencia." - }, - "hydroPump": { - "name": "Hidrobomba", - "effect": "Lanza una gran masa de agua a presión para atacar." - }, - "surf": { - "name": "Surf", - "effect": "Inunda el terreno de combate con una ola gigante que golpea a los Pokémon adyacentes." - }, - "iceBeam": { - "name": "Rayo Hielo", - "effect": "Rayo de hielo que puede llegar a congelar." - }, - "blizzard": { - "name": "Ventisca", - "effect": "Tormenta de hielo que puede llegar a congelar." - }, - "psybeam": { - "name": "Psicorrayo", - "effect": "Extraño rayo que puede causar confusión." - }, - "bubbleBeam": { - "name": "Rayo Burbuja", - "effect": "Ráfaga de burbujas que puede reducir la Velocidad." - }, - "auroraBeam": { - "name": "Rayo Aurora", - "effect": "Rayo multicolor que puede reducir el Ataque." - }, - "hyperBeam": { - "name": "Hiperrayo", - "effect": "El usuario ataca al objetivo con un potente haz de luz, pero deberá descansar en el siguiente turno." - }, - "peck": { - "name": "Picotazo", - "effect": "Ensarta al objetivo con un cuerno o pico punzante." - }, - "drillPeck": { - "name": "Pico Taladro", - "effect": "Picotazo giratorio y perforador muy potente." - }, - "submission": { - "name": "Sumisión", - "effect": "El usuario se lanza al suelo con el oponente en brazos y también se hace un poco de daño." - }, - "lowKick": { - "name": "Patada Baja", - "effect": "Patada baja que derriba al objetivo. Cuanto más pesa este, más daño le causa." - }, - "counter": { - "name": "Contraataque", - "effect": "Devuelve un golpe físico por duplicado." - }, - "seismicToss": { - "name": "Sísmico", - "effect": "Aprovecha la gravedad para derribar al objetivo. Le resta tantos PS como nivel tenga el usuario." - }, - "strength": { - "name": "Fuerza", - "effect": "Ataca al objetivo golpeándolo con todas sus fuerzas." - }, - "absorb": { - "name": "Absorber", - "effect": "Un ataque que absorbe nutrientes. Quien lo usa recupera la mitad de los PS del daño que produce." - }, - "megaDrain": { - "name": "Megaagotar", - "effect": "Un ataque que absorbe nutrientes. Quien lo usa recupera la mitad de los PS del daño que produce." - }, - "leechSeed": { - "name": "Drenadoras", - "effect": "Planta semillas que absorben PS del objetivo en cada turno y que le sirven para recuperarse." - }, - "growth": { - "name": "Desarrollo", - "effect": "Hace que su cuerpo crezca a marchas forzadas con lo que aumenta su Ataque y Ataque Especial." - }, - "razorLeaf": { - "name": "Hoja Afilada", - "effect": "Corta con hojas afiladas. Un ataque que suele ser crítico." - }, - "solarBeam": { - "name": "Rayo Solar", - "effect": "El usuario absorbe luz en el primer turno y en el segundo lanza un potente rayo de energía." - }, - "poisonPowder": { - "name": "Polvo Veneno", - "effect": "Esparce polvo tóxico que envenena al objetivo." - }, - "stunSpore": { - "name": "Paralizador", - "effect": "Esparce polvo que paraliza al objetivo." - }, - "sleepPowder": { - "name": "Somnífero", - "effect": "Esparce polvo que duerme al objetivo." - }, - "petalDance": { - "name": "Danza Pétalo", - "effect": "Ataca al objetivo lanzando pétalos de dos a tres turnos y, al finalizar, el usuario se queda confuso." - }, - "stringShot": { - "name": "Disparo Demora", - "effect": "Lanza seda a los rivales y reduce mucho su Velocidad." - }, - "dragonRage": { - "name": "Furia Dragón", - "effect": "Ráfaga de furiosas ondas de choque que quitan 40 PS." - }, - "fireSpin": { - "name": "Giro Fuego", - "effect": "Un aro de fuego que atrapa al objetivo de cuatro a cinco turnos." - }, - "thunderShock": { - "name": "Impactrueno", - "effect": "Ataque eléctrico que puede paralizar al objetivo." - }, - "thunderbolt": { - "name": "Rayo", - "effect": "Potente ataque eléctrico que puede paralizar al objetivo." - }, - "thunderWave": { - "name": "Onda Trueno", - "effect": "Una ligera descarga que paraliza al objetivo." - }, - "thunder": { - "name": "Trueno", - "effect": "Un poderoso rayo que daña al objetivo y puede paralizarlo." - }, - "rockThrow": { - "name": "Lanzarrocas", - "effect": "Tira una pequeña roca al objetivo." - }, - "earthquake": { - "name": "Terremoto", - "effect": "Un terremoto que afecta a los Pokémon adyacentes." - }, - "fissure": { - "name": "Fisura", - "effect": "Abre una grieta en el suelo y mete al objetivo en ella. Fulmina al objetivo de un solo golpe si acierta." - }, - "dig": { - "name": "Excavar", - "effect": "El usuario cava durante el primer turno y ataca en el segundo." - }, - "toxic": { - "name": "Tóxico", - "effect": "Envenena gravemente al objetivo y causa un daño mayor en cada turno." - }, - "confusion": { - "name": "Confusión", - "effect": "Débil ataque telequinético que puede causar confusión." - }, - "psychic": { - "name": "Psíquico", - "effect": "Fuerte ataque telequinético que puede bajar la Defensa Especial del objetivo." - }, - "hypnosis": { - "name": "Hipnosis", - "effect": "Ataque hipnótico que hace dormir profundamente al objetivo." - }, - "meditate": { - "name": "Meditación", - "effect": "El usuario reposa y medita para potenciar el Ataque." - }, - "agility": { - "name": "Agilidad", - "effect": "Relaja el cuerpo para ganar mucha Velocidad." - }, - "quickAttack": { - "name": "Ataque Rápido", - "effect": "Ataque de una rapidez espeluznante. Este movimiento tiene prioridad alta." - }, - "rage": { - "name": "Furia", - "effect": "Al usarse, aumenta el Ataque del usuario cada vez que es golpeado." - }, - "teleport": { - "name": "Teletransporte", - "effect": "Permite al usuario cambiarse por otro Pokémon del equipo, si lo hay. Si un Pokémon salvaje usa este movimiento, huye del combate." - }, - "nightShade": { - "name": "Tinieblas", - "effect": "Produce un espejismo ante el objetivo, que pierde tantos PS como nivel tenga el usuario." - }, - "mimic": { - "name": "Mimético", - "effect": "Copia el último movimiento usado por el objetivo, y puede utilizarlo mientras esté en el combate." - }, - "screech": { - "name": "Chirrido", - "effect": "Alarido agudo que reduce mucho la Defensa del objetivo." - }, - "doubleTeam": { - "name": "Doble Equipo", - "effect": "Crea copias de sí mismo para mejorar la Evasión." - }, - "recover": { - "name": "Recuperación", - "effect": "Restaura hasta la mitad de los PS máximos." - }, - "harden": { - "name": "Fortaleza", - "effect": "Tensa la musculatura del usuario para aumentar la Defensa." - }, - "minimize": { - "name": "Reducción", - "effect": "El usuario mengua para aumentar mucho la Evasión." - }, - "smokescreen": { - "name": "Pantalla de Humo", - "effect": "Reduce la Precisión del objetivo con una nube de humo o tinta." - }, - "confuseRay": { - "name": "Rayo Confuso", - "effect": "Rayo siniestro que confunde al objetivo." - }, - "withdraw": { - "name": "Refugio", - "effect": "El usuario se resguarda en su coraza, por lo que le sube la Defensa." - }, - "defenseCurl": { - "name": "Rizo Defensa", - "effect": "Se enrosca para ocultar sus puntos débiles y aumentar la Defensa." - }, - "barrier": { - "name": "Barrera", - "effect": "Crea una barrera que aumenta mucho la Defensa." - }, - "lightScreen": { - "name": "Pantalla de Luz", - "effect": "Pared de luz que reduce durante cinco turnos el daño producido por los ataques especiales." - }, - "haze": { - "name": "Niebla", - "effect": "Neblina oscura que elimina los cambios en las características de todos los Pokémon en combate." - }, - "reflect": { - "name": "Reflejo", - "effect": "Pared de luz que reduce durante cinco turnos el daño producido por los ataques físicos." - }, - "focusEnergy": { - "name": "Foco Energía", - "effect": "Concentra energía para aumentar las posibilidades de asestar un golpe crítico." - }, - "bide": { - "name": "Venganza", - "effect": "Espera dos turnos para atacar con el doble de potencia del daño recibido." - }, - "metronome": { - "name": "Metrónomo", - "effect": "Mueve un dedo y estimula su cerebro para usar al azar casi cualquier movimiento." - }, - "mirrorMove": { - "name": "Espejo", - "effect": "Ataca al objetivo con el último movimiento que este haya usado." - }, - "selfDestruct": { - "name": "Autodestrucción", - "effect": "El atacante explota y hiere a los Pokémon adyacentes. El usuario se debilita de inmediato." - }, - "eggBomb": { - "name": "Bomba Huevo", - "effect": "Arroja un huevo enorme al objetivo con gran fuerza." - }, - "lick": { - "name": "Lengüetazo", - "effect": "Una lengua ataca al objetivo. Puede causar parálisis." - }, - "smog": { - "name": "Polución", - "effect": "Lanza un ataque con gases tóxicos que pueden llegar a envenenar." - }, - "sludge": { - "name": "Residuos", - "effect": "Arroja residuos al objetivo. Puede llegar a envenenar." - }, - "boneClub": { - "name": "Hueso Palo", - "effect": "Aporrea con un hueso. Puede hacer retroceder al objetivo." - }, - "fireBlast": { - "name": "Llamarada", - "effect": "Llama intensa que chamusca y puede causar quemaduras." - }, - "waterfall": { - "name": "Cascada", - "effect": "Embiste con un gran impulso y puede llegar a amedrentar al objetivo." - }, - "clamp": { - "name": "Tenaza", - "effect": "Atrapa y atenaza con fuerza durante cuatro o cinco turnos." - }, - "swift": { - "name": "Meteoros", - "effect": "Lanza rayos en forma de estrella que no fallan nunca." - }, - "skullBash": { - "name": "Cabezazo", - "effect": "El usuario se prepara y sube su Defensa en el primer turno y en el segundo arremete con un cabezazo." - }, - "spikeCannon": { - "name": "Clavo Cañón", - "effect": "Lanza finas púas que hieren de dos a cinco veces." - }, - "constrict": { - "name": "Restricción", - "effect": "Ataca con largos tentáculos o zarcillos que pueden bajar la Velocidad." - }, - "amnesia": { - "name": "Amnesia", - "effect": "El usuario olvida sus preocupaciones y aumenta mucho la Defensa Especial." - }, - "kinesis": { - "name": "Kinético", - "effect": "Dobla una cuchara para distraer al objetivo y reducir su Precisión." - }, - "softBoiled": { - "name": "Ovocuración", - "effect": "Restaura la mitad de los PS máximos del usuario." - }, - "highJumpKick": { - "name": "Pat. Salto Alta", - "effect": "El usuario salta muy alto y da un rodillazo. Si falla, se hará daño." - }, - "glare": { - "name": "Deslumbrar", - "effect": "Intimida y asusta al objetivo con la mirada para dejarlo paralizado." - }, - "dreamEater": { - "name": "Comesueños", - "effect": "Restaura al usuario la mitad del daño causado a un objetivo dormido." - }, - "poisonGas": { - "name": "Gas Venenoso", - "effect": "Lanza una nube de gas tóxico al objetivo. Produce envenenamiento." - }, - "barrage": { - "name": "Bombardeo", - "effect": "Arroja esferas al objetivo entre dos y cinco veces seguidas." - }, - "leechLife": { - "name": "Chupavidas", - "effect": "Restaura al usuario la mitad del daño causado al objetivo." - }, - "lovelyKiss": { - "name": "Beso Amoroso", - "effect": "Intimida al objetivo con una cara que asusta y le da un beso que lo deja dormido." - }, - "skyAttack": { - "name": "Ataque Aéreo", - "effect": "Ataca durante dos turnos y suele asestar un golpe crítico. También puede amedrentar al objetivo." - }, - "transform": { - "name": "Transformación", - "effect": "El usuario se transforma en una copia del objetivo, con los mismos movimientos." - }, - "bubble": { - "name": "Burbuja", - "effect": "Lanza burbujas a los contrincantes y puede reducir su Velocidad." - }, - "dizzyPunch": { - "name": "Puño Mareo", - "effect": "Rítmicos puñetazos que pueden causar confusión." - }, - "spore": { - "name": "Espora", - "effect": "Esparce esporas que inducen el sueño." - }, - "flash": { - "name": "Destello", - "effect": "Luz cegadora que baja la Precisión del objetivo." - }, - "psywave": { - "name": "Psicoonda", - "effect": "Ataque con una onda de energía de intensidad variable." - }, - "splash": { - "name": "Salpicadura", - "effect": "No tiene ningún efecto. Solo salpica." - }, - "acidArmor": { - "name": "Armadura Ácida", - "effect": "Transforma la estructura celular para hacerse líquido y aumenta mucho la Defensa." - }, - "crabhammer": { - "name": "Martillazo", - "effect": "Golpea con fuerza con una pinza enorme. Suele asestar un golpe crítico." - }, - "explosion": { - "name": "Explosión", - "effect": "El atacante causa una grandísima explosión y hiere a los Pokémon adyacentes. El usuario se debilita de inmediato." - }, - "furySwipes": { - "name": "Golpes Furia", - "effect": "Araña rápidamente de dos a cinco veces." - }, - "bonemerang": { - "name": "Huesomerang", - "effect": "Lanza un hueso a modo de bumerán que golpea dos veces." - }, - "rest": { - "name": "Descanso", - "effect": "Restaura todos los PS y cura todos los problemas de estado del usuario, que se duerme los dos turnos siguientes." - }, - "rockSlide": { - "name": "Avalancha", - "effect": "Lanza grandes pedruscos. Puede amedrentar al objetivo." - }, - "hyperFang": { - "name": "Hipercolmillo", - "effect": "Ataca con agudos colmillos. Puede amedrentar al objetivo." - }, - "sharpen": { - "name": "Afilar", - "effect": "El perfil del usuario se hace más afilado y su Ataque mejora." - }, - "conversion": { - "name": "Conversión", - "effect": "Cambia el tipo del usuario por el del primer movimiento en su lista." - }, - "triAttack": { - "name": "Triataque", - "effect": "Ataque con tres rayos de luz que puede paralizar, quemar o congelar al objetivo." - }, - "superFang": { - "name": "Superdiente", - "effect": "Asesta una dentellada con sus afilados incisivos que reduce a la mitad los PS del objetivo." - }, - "slash": { - "name": "Cuchillada", - "effect": "Ataca con cuchillas o con pinzas. Suele asestar un golpe crítico." - }, - "substitute": { - "name": "Sustituto", - "effect": "Utiliza parte de los PS propios para crear un sustituto que actúa como señuelo." - }, - "struggle": { - "name": "Forcejeo", - "effect": "Solo se usa como último recurso al acabarse los PP. Hiere un poco al agresor." - }, - "sketch": { - "name": "Esquema", - "effect": "Aprende de forma permanente el último movimiento utilizado por el objetivo. Es de un solo uso." - }, - "tripleKick": { - "name": "Triple Patada", - "effect": "Propina hasta tres patadas seguidas, la potencia de las cuales aumenta cada vez que acierta." - }, - "thief": { - "name": "Ladrón", - "effect": "El usuario ataca y tiene un 30% de robarle el objeto al objetivo." - }, - "spiderWeb": { - "name": "Telaraña", - "effect": "Enreda al objetivo para evitar que abandone el combate." - }, - "mindReader": { - "name": "Telépata", - "effect": "El usuario adivina los movimientos del objetivo para hacer que su siguiente ataque no falle." - }, - "nightmare": { - "name": "Pesadilla", - "effect": "El objetivo dormido sufre una pesadilla que le hace perder PS en cada turno." - }, - "flameWheel": { - "name": "Rueda Fuego", - "effect": "Ataca envuelto en fuego. Puede causar quemaduras." - }, - "snore": { - "name": "Ronquido", - "effect": "Fuerte ronquido que solo puede usarse dormido. Puede amedrentar al objetivo." - }, - "curse": { - "name": "Maldición", - "effect": "Un movimiento que tiene efectos distintos si el usuario es de tipo Fantasma o no." - }, - "flail": { - "name": "Azote", - "effect": "Ataque frenético. Cuantos menos PS tenga el usuario, más daño producirá." - }, - "conversion2": { - "name": "Conversión2", - "effect": "El usuario cambia de tipo para hacerse resistente al último tipo de movimiento usado por el objetivo." - }, - "aeroblast": { - "name": "Aerochorro", - "effect": "Lanza un chorro de aire que suele asestar un golpe crítico." - }, - "cottonSpore": { - "name": "Esporagodón", - "effect": "Adhiere esporas a los rivales para reducir mucho su Velocidad." - }, - "reversal": { - "name": "Inversión", - "effect": "Ataque desesperado que causa más daño cuantos menos PS tenga el usuario." - }, - "spite": { - "name": "Rencor", - "effect": "Da rienda suelta a su rencor para reducir 4 PP del último movimiento usado por el objetivo." - }, - "powderSnow": { - "name": "Nieve Polvo", - "effect": "Lanza nieve que puede llegar a congelar." - }, - "protect": { - "name": "Protección", - "effect": "Frena todos los ataques, pero puede fallar si se usa repetidamente." - }, - "machPunch": { - "name": "Ultrapuño", - "effect": "Puñetazo de velocidad fulminante. Este movimiento tiene prioridad alta." - }, - "scaryFace": { - "name": "Cara Susto", - "effect": "Asusta al objetivo para reducir mucho su Velocidad." - }, - "feintAttack": { - "name": "Finta", - "effect": "Engaña al objetivo para acercarse y dar un puñetazo que no falla." - }, - "sweetKiss": { - "name": "Beso Dulce", - "effect": "Da un beso con tal dulzura que causa confusión." - }, - "bellyDrum": { - "name": "Tambor", - "effect": "Reduce la mitad de los PS máximos para mejorar al máximo el Ataque." - }, - "sludgeBomb": { - "name": "Bomba Lodo", - "effect": "Arroja residuos al objetivo. Puede llegar a envenenar." - }, - "mudSlap": { - "name": "Bofetón Lodo", - "effect": "Echa lodo en la cara del objetivo para infligirle daño y reducir su Precisión." - }, - "octazooka": { - "name": "Pulpocañón", - "effect": "Dispara tinta a la cara. Puede bajar la Precisión." - }, - "spikes": { - "name": "Púas", - "effect": "Esparce púas alrededor del equipo rival que hieren a los Pokémon rivales que entran en combate." - }, - "zapCannon": { - "name": "Electrocañón", - "effect": "Dispara una descarga eléctrica que causa daño y parálisis." - }, - "foresight": { - "name": "Profecía", - "effect": "Permite atacar con cualquier movimiento a objetivos de tipo Fantasma y golpear a Pokémon evasivos." - }, - "destinyBond": { - "name": "Mismo Destino", - "effect": "Si el usuario se debilita por un ataque rival antes de usar otro movimiento, el Pokémon rival se debilitará también. Puede fallar si se usa repetidamente." - }, - "perishSong": { - "name": "Canto Mortal", - "effect": "Si un Pokémon escucha este canto y no es cambiado por otro en tres turnos, acaba debilitándose." - }, - "icyWind": { - "name": "Viento Hielo", - "effect": "Ataque con aire helado que reduce la Velocidad del objetivo." - }, - "detect": { - "name": "Detección", - "effect": "Frena todos los ataques, pero puede fallar si se usa repetidamente." - }, - "boneRush": { - "name": "Ataque Óseo", - "effect": "Hueso en ristre, aporrea al objetivo de dos a cinco veces." - }, - "lockOn": { - "name": "Fijar Blanco", - "effect": "Fija el blanco para que el siguiente ataque no falle." - }, - "outrage": { - "name": "Enfado", - "effect": "El usuario ataca enfurecido durante dos o tres turnos y, después, se queda confuso." - }, - "sandstorm": { - "name": "Tormenta Arena", - "effect": "Tormenta de arena que dura cinco turnos y hiere a todos, excepto a los de tipo Roca, Tierra y Acero, y aumenta la Defensa Especial de los de tipo Roca." - }, - "gigaDrain": { - "name": "Gigadrenado", - "effect": "Un ataque que absorbe nutrientes. Quien lo usa recupera la mitad de los PS del daño que produce." - }, - "endure": { - "name": "Aguante", - "effect": "Resiste cualquier ataque y deja al menos 1 PS. Puede fallar si se usa repetidamente." - }, - "charm": { - "name": "Encanto", - "effect": "Engatusa al objetivo y reduce mucho su Ataque." - }, - "rollout": { - "name": "Rodar", - "effect": "El atacante rueda contra el objetivo durante cinco turnos, cada vez con mayor fuerza." - }, - "falseSwipe": { - "name": "Falso Tortazo", - "effect": "Ataque moderado que no debilita al objetivo y le deja al menos 1 PS." - }, - "swagger": { - "name": "Contoneo", - "effect": "Provoca confusión en el objetivo, pero también sube mucho su Ataque." - }, - "milkDrink": { - "name": "Batido", - "effect": "Restaura la mitad de los PS máximos del usuario." - }, - "spark": { - "name": "Chispa", - "effect": "Ataque eléctrico que puede llegar a paralizar." - }, - "furyCutter": { - "name": "Corte Furia", - "effect": "Ataque con garras o guadaña que crece en intensidad si se usa repetidas veces." - }, - "steelWing": { - "name": "Ala de Acero", - "effect": "Alas macizas que golpean al objetivo y pueden subir la Defensa del usuario." - }, - "meanLook": { - "name": "Mal de Ojo", - "effect": "Mal de ojo que impide al objetivo huir del combate o ser cambiado por otro." - }, - "attract": { - "name": "Atracción", - "effect": "Si el objetivo es del sexo opuesto, se enamorará y bajará la posibilidad de que ataque." - }, - "sleepTalk": { - "name": "Sonámbulo", - "effect": "Mientras duerme, usa uno de sus movimientos elegido al azar." - }, - "healBell": { - "name": "Cascabel Cura", - "effect": "Tañido que cura los problemas de estado de todos los Pokémon del equipo." - }, - "return": { - "name": "Retribución", - "effect": "Cuanto mayor sea la amistad con el Entrenador, más poderoso será este ataque." - }, - "present": { - "name": "Presente", - "effect": "Quien lo usa ataca al objetivo dándole un regalo con una bomba trampa. Sin embargo, a veces restaura sus PS." - }, - "frustration": { - "name": "Frustración", - "effect": "Cuanto menor sea la amistad con el Entrenador, más poderoso será este ataque." - }, - "safeguard": { - "name": "Velo Sagrado", - "effect": "Un poder misterioso que protege de problemas de estado durante cinco turnos." - }, - "painSplit": { - "name": "Divide Dolor", - "effect": "Suma los PS del usuario a los del objetivo y los reparte a partes iguales." - }, - "sacredFire": { - "name": "Fuego Sagrado", - "effect": "Fuego místico de gran intensidad que puede causar quemaduras." - }, - "magnitude": { - "name": "Magnitud", - "effect": "Sacudida sísmica de intensidad variable que afecta a todos los Pokémon a su alrededor." - }, - "dynamicPunch": { - "name": "Puño Dinámico", - "effect": "Puñetazo con toda la fuerza concentrada. Causa confusión si atina." - }, - "megahorn": { - "name": "Megacuerno", - "effect": "Ensarta al objetivo con su imponente cuerno o cornamenta." - }, - "dragonBreath": { - "name": "Dragoaliento", - "effect": "Poderosa ráfaga de aliento que golpea al objetivo y puede paralizarlo." - }, - "batonPass": { - "name": "Relevo", - "effect": "Cambia el puesto con otro miembro del equipo y le pasa los cambios en las características." - }, - "encore": { - "name": "Otra Vez", - "effect": "El objetivo repite su último movimiento durante tres turnos." - }, - "pursuit": { - "name": "Persecución", - "effect": "Hace el doble de daño al objetivo que pide el relevo." - }, - "rapidSpin": { - "name": "Giro Rápido", - "effect": "Ataque giratorio que puede eliminar movimientos como Atadura, Constricción y Drenadoras. También aumenta la Velocidad del usuario." - }, - "sweetScent": { - "name": "Dulce Aroma", - "effect": "Un dulce aroma engatusa al objetivo, por lo que se reduce mucho su Evasión." - }, - "ironTail": { - "name": "Cola Férrea", - "effect": "Ataca con una cola férrea y puede reducir la Defensa del objetivo." - }, - "metalClaw": { - "name": "Garra Metal", - "effect": "Ataque con garras de acero que puede aumentar el Ataque del usuario." - }, - "vitalThrow": { - "name": "Llave Vital", - "effect": "El usuario ataca el último, pero no falla." - }, - "morningSun": { - "name": "Sol Matinal", - "effect": "Restaura PS del usuario. La cantidad varía según el tiempo que haga." - }, - "synthesis": { - "name": "Síntesis", - "effect": "Restaura PS del usuario. La cantidad varía según el tiempo que haga." - }, - "moonlight": { - "name": "Luz Lunar", - "effect": "Restaura PS del usuario. La cantidad varía según el tiempo que haga." - }, - "hiddenPower": { - "name": "Poder Oculto", - "effect": "Movimiento cuyo tipo varía en función del Pokémon que lo usa." - }, - "crossChop": { - "name": "Tajo Cruzado", - "effect": "Corte doble que suele propinar un golpe crítico." - }, - "twister": { - "name": "Ciclón", - "effect": "Crea un violento tornado para hacer trizas al objetivo. Puede amedrentarlo." - }, - "rainDance": { - "name": "Danza Lluvia", - "effect": "Genera una fuerte lluvia que refuerza los movimientos de tipo Agua durante cinco turnos y debilita los de tipo Fuego." - }, - "sunnyDay": { - "name": "Día Soleado", - "effect": "Hace que se intensifique el efecto del sol durante cinco turnos, lo que potencia los movimientos de tipo Fuego y debilita los de tipo Agua." - }, - "crunch": { - "name": "Triturar", - "effect": "Tritura con afilados colmillos y puede reducir la Defensa del objetivo." - }, - "mirrorCoat": { - "name": "Manto Espejo", - "effect": "Responde a un ataque especial ocasionando el doble del daño recibido." - }, - "psychUp": { - "name": "Autosugestión", - "effect": "El usuario se sume en un trance y copia cualquier cambio que haya en las características de su objetivo." - }, - "extremeSpeed": { - "name": "Veloc. Extrema", - "effect": "Ataque de una velocidad extrema. Este movimiento tiene prioridad alta." - }, - "ancientPower": { - "name": "Poder Pasado", - "effect": "Ataque prehistórico que puede subir todas las características." - }, - "shadowBall": { - "name": "Bola Sombra", - "effect": "Lanza una bola oscura que puede bajar la Defensa Especial del objetivo." - }, - "futureSight": { - "name": "Premonición", - "effect": "Concentra energía psíquica para golpear al objetivo dos turnos después." - }, - "rockSmash": { - "name": "Golpe Roca", - "effect": "Propina un gran puñetazo que puede reducir la Defensa del objetivo." - }, - "whirlpool": { - "name": "Torbellino", - "effect": "Una tromba de agua atrapa al objetivo durante cuatro o cinco turnos." - }, - "beatUp": { - "name": "Paliza", - "effect": "Ataque de todo el equipo Pokémon. Cuantos más haya, más veces se atacará." - }, - "fakeOut": { - "name": "Sorpresa", - "effect": "Amedrenta al objetivo con este movimiento de prioridad alta. Solo sirve en el primer turno." - }, - "uproar": { - "name": "Alboroto", - "effect": "Ataca de forma alborotada durante tres turnos. Mantiene despiertos a todos." - }, - "stockpile": { - "name": "Reserva", - "effect": "Acumula energía y sube la Defensa y la Defensa Especial. Puede utilizarse hasta tres veces." - }, - "spitUp": { - "name": "Escupir", - "effect": "Libera de una vez la energía acumulada con Reserva. La potencia del movimiento será proporcional a la cantidad de energía acumulada." - }, - "swallow": { - "name": "Tragar", - "effect": "Absorbe la energía acumulada con Reserva para recobrar salud. Cuanta más se haya acumulado, mayor será el número de PS que se recuperen." - }, - "heatWave": { - "name": "Onda Ígnea", - "effect": "Provoca un viento abrasador que puede quemar al objetivo." - }, - "hail": { - "name": "Granizo", - "effect": "Tormenta de granizo que dura cinco turnos. Hiere a todos los Pokémon excepto a los de tipo Hielo." - }, - "torment": { - "name": "Tormento", - "effect": "Atormenta y enfurece al objetivo, que no puede usar dos veces seguidas el mismo movimiento." - }, - "flatter": { - "name": "Camelo", - "effect": "Halaga al objetivo y lo confunde, pero también sube su Ataque Especial." - }, - "willOWisp": { - "name": "Fuego Fatuo", - "effect": "Siniestras llamas moradas que producen quemaduras." - }, - "memento": { - "name": "Legado", - "effect": "El usuario se debilita, pero baja mucho tanto el Ataque como el Ataque Especial del objetivo." - }, - "facade": { - "name": "Imagen", - "effect": "Si el usuario está quemado, paralizado o envenenado, ataca con el doble de potencia." - }, - "focusPunch": { - "name": "Puño Certero", - "effect": "Se concentra para dar un puñetazo. Falla si se sufre un golpe antes de su uso." - }, - "smellingSalts": { - "name": "Estímulo", - "effect": "Hace el doble de daño a objetivos paralizados, pero también cura la parálisis." - }, - "followMe": { - "name": "Señuelo", - "effect": "Llama la atención para concentrar todos los ataques de todos los del equipo rival hacia sí mismo." - }, - "naturePower": { - "name": "Adaptación", - "effect": "Usa el poder de la naturaleza para atacar. Su efecto varía según el entorno de combate." - }, - "charge": { - "name": "Carga", - "effect": "Recarga energía para potenciar el siguiente movimiento de tipo Eléctrico. También sube la Defensa Especial." - }, - "taunt": { - "name": "Mofa", - "effect": "Enfurece al objetivo para que solo use movimientos de ataque durante tres turnos." - }, - "helpingHand": { - "name": "Refuerzo", - "effect": "El usuario ayuda a un aliado reforzando la potencia de su ataque." - }, - "trick": { - "name": "Truco", - "effect": "Engaña al objetivo desprevenido e intercambia objetos." - }, - "rolePlay": { - "name": "Imitación", - "effect": "Imita al objetivo por completo y copia su habilidad." - }, - "wish": { - "name": "Deseo", - "effect": "Restaura en el siguiente turno la mitad de los PS máximos del usuario o se los pasa al Pokémon que lo sustituye." - }, - "assist": { - "name": "Ayuda", - "effect": "Usa un movimiento de un miembro del equipo elegido al azar." - }, - "ingrain": { - "name": "Arraigo", - "effect": "Echa raíces para recuperar PS en cada turno, pero impide el relevo." - }, - "superpower": { - "name": "Fuerza Bruta", - "effect": "Ataque de gran potencia, pero que reduce el Ataque y la Defensa del agresor." - }, - "magicCoat": { - "name": "Capa Mágica", - "effect": "Barrera capaz de devolver al agresor movimientos como Drenadoras y otros que alteran el estado o las características." - }, - "recycle": { - "name": "Reciclaje", - "effect": "Recicla y así recupera un objeto equipado de un solo uso que ya haya sido empleado durante el combate." - }, - "revenge": { - "name": "Desquite", - "effect": "Ataque que produce el doble de daño si el usuario resulta herido en el mismo turno." - }, - "brickBreak": { - "name": "Demolición", - "effect": "Potente ataque que también es capaz de destruir barreras como Pantalla de Luz y Reflejo." - }, - "yawn": { - "name": "Bostezo", - "effect": "Gran bostezo que induce el sueño en el objetivo en el siguiente turno." - }, - "knockOff": { - "name": "Desarme", - "effect": "Impide al objetivo usar el objeto que lleva durante el combate. La potencia del movimiento se multiplica si el objetivo lleva un objeto." - }, - "endeavor": { - "name": "Esfuerzo", - "effect": "Reduce los PS del objetivo para que igualen a los del atacante." - }, - "eruption": { - "name": "Estallido", - "effect": "Furia explosiva. Cuanto menor sea el número de PS del usuario, menos potencia tendrá el movimiento." - }, - "skillSwap": { - "name": "Intercambio", - "effect": "Usa el poder psíquico para intercambiar habilidades con el objetivo." - }, - "imprison": { - "name": "Sellar", - "effect": "Impide a los rivales usar movimientos conocidos por el usuario durante el combate." - }, - "refresh": { - "name": "Alivio", - "effect": "Descansa para curar parálisis, envenenamiento o quemaduras." - }, - "grudge": { - "name": "Rabia", - "effect": "Si el usuario se debilita al recibir un ataque, todos los PP de este último ataque serán eliminados." - }, - "snatch": { - "name": "Robo", - "effect": "Roba el efecto de los movimientos de curación o de cambio de características que se usen." - }, - "secretPower": { - "name": "Daño Secreto", - "effect": "Ataque cuyos efectos secundarios varían según el entorno de combate." - }, - "dive": { - "name": "Buceo", - "effect": "El usuario se sumerge en el primer turno y ataca en el segundo." - }, - "armThrust": { - "name": "Empujón", - "effect": "Fuertes empujones que golpean de dos a cinco veces seguidas." - }, - "camouflage": { - "name": "Camuflaje", - "effect": "Modifica el tipo del Pokémon según el terreno de combate donde esté." - }, - "tailGlow": { - "name": "Luminicola", - "effect": "Se concentra en una ráfaga de luz que sube muchísimo el Ataque Especial." - }, - "lusterPurge": { - "name": "Resplandor", - "effect": "Fogonazo de luz que inflige daño al objetivo y puede reducir su Defensa Especial." - }, - "mistBall": { - "name": "Bola Neblina", - "effect": "Bola de plumas neblinosas que inflige daño al objetivo y puede reducir su Ataque Especial." - }, - "featherDance": { - "name": "Danza Pluma", - "effect": "Envuelve al objetivo con un manto de plumas para reducir mucho su Ataque." - }, - "teeterDance": { - "name": "Danza Caos", - "effect": "Danza histérica que confunde a los Pokémon que están alrededor del usuario." - }, - "blazeKick": { - "name": "Patada Ígnea", - "effect": "Patada que suele ser un golpe crítico y puede causar quemaduras." - }, - "mudSport": { - "name": "Chapoteo Lodo", - "effect": "El usuario esparce lodo a su alrededor, lo que debilita los movimientos de tipo Eléctrico durante cinco turnos." - }, - "iceBall": { - "name": "Bola Hielo", - "effect": "El atacante rueda contra el objetivo durante cinco turnos, cada vez con mayor fuerza." - }, - "needleArm": { - "name": "Brazo Pincho", - "effect": "Pega con brazos de pinchos y puede hacer retroceder al objetivo." - }, - "slackOff": { - "name": "Relajo", - "effect": "El usuario se relaja y restaura la mitad de sus PS máximos." - }, - "hyperVoice": { - "name": "Vozarrón", - "effect": "Grito desgarrador que inflige daño al objetivo." - }, - "poisonFang": { - "name": "Colmillo Veneno", - "effect": "Mordedura con colmillos venenosos que inflige daño al objetivo y puede envenenarlo gravemente." - }, - "crushClaw": { - "name": "Garra Brutal", - "effect": "Hace trizas al objetivo con garras afiladas y puede reducir su Defensa." - }, - "blastBurn": { - "name": "Anillo Ígneo", - "effect": "Calcina al objetivo con una explosión de fuego. El usuario deberá descansar en el siguiente turno." - }, - "hydroCannon": { - "name": "Hidrocañón", - "effect": "Ataca al objetivo con un cañonazo de agua. El usuario deberá descansar en el siguiente turno." - }, - "meteorMash": { - "name": "Puño Meteoro", - "effect": "Puñetazo que impacta como un meteorito y puede subir el Ataque del agresor." - }, - "astonish": { - "name": "Impresionar", - "effect": "Lanza un grito tan tremendo que impresiona y puede amedrentar al objetivo." - }, - "weatherBall": { - "name": "Meteorobola", - "effect": "El tipo y fuerza del ataque varían según el tiempo que haga." - }, - "aromatherapy": { - "name": "Aromaterapia", - "effect": "Cura todos los problemas de estado del equipo con un suave aroma." - }, - "fakeTears": { - "name": "Llanto Falso", - "effect": "Lágrimas de cocodrilo que bajan mucho la Defensa Especial del objetivo." - }, - "airCutter": { - "name": "Aire Afilado", - "effect": "Viento cortante que azota. Suele ser un golpe crítico." - }, - "overheat": { - "name": "Sofoco", - "effect": "Ataque en toda regla que baja mucho el Ataque Especial de quien lo usa." - }, - "odorSleuth": { - "name": "Rastreo", - "effect": "Permite atacar con cualquier movimiento a objetivos de tipo Fantasma y golpear a Pokémon evasivos." - }, - "rockTomb": { - "name": "Tumba Rocas", - "effect": "Tira rocas que detienen al objetivo y bajan su Velocidad." - }, - "silverWind": { - "name": "Viento Plata", - "effect": "Fuerte viento con polvo de escamas. Puede subir todas las características de quien lo usa." - }, - "metalSound": { - "name": "Eco Metálico", - "effect": "Horrible chirrido metálico que reduce mucho la Defensa Especial del objetivo." - }, - "grassWhistle": { - "name": "Silbato", - "effect": "Agradable melodía que adormece al objetivo." - }, - "tickle": { - "name": "Cosquillas", - "effect": "Hace reír al objetivo para bajar su Ataque y Defensa." - }, - "cosmicPower": { - "name": "Masa Cósmica", - "effect": "Sube la Defensa y la Defensa Especial propias con energía mística." - }, - "waterSpout": { - "name": "Salpicar", - "effect": "Chorro de agua. Cuantos menos PS tenga el usuario, menos potencia tendrá el movimiento." - }, - "signalBeam": { - "name": "Rayo Señal", - "effect": "Ataca con un rayo de luz siniestro. Puede confundir al objetivo." - }, - "shadowPunch": { - "name": "Puño Sombra", - "effect": "Puñetazo procedente de las sombras que no falla nunca." - }, - "extrasensory": { - "name": "Paranormal", - "effect": "Emite una energía muy extraña que puede amedrentar al objetivo." - }, - "skyUppercut": { - "name": "Gancho Alto", - "effect": "Gancho ascendente de gran ímpetu." - }, - "sandTomb": { - "name": "Bucle Arena", - "effect": "Enreda al objetivo en un remolino de arena de cuatro a cinco turnos." - }, - "sheerCold": { - "name": "Frío Polar", - "effect": "Debilita al objetivo de un solo golpe. Si lo usa un Pokémon que no sea de tipo Hielo, es difícil que acierte." - }, - "muddyWater": { - "name": "Agua Lodosa", - "effect": "Ataque con agua lodosa que puede reducir la Precisión del objetivo." - }, - "bulletSeed": { - "name": "Semilladora", - "effect": "Dispara rápido de dos a cinco ráfagas de semillas de manera consecutiva." - }, - "aerialAce": { - "name": "Golpe Aéreo", - "effect": "Desconcierta al objetivo con movimientos muy rápidos antes de cercenarlo. No falla nunca." - }, - "icicleSpear": { - "name": "Carámbano", - "effect": "Ataca lanzando de dos a cinco ráfagas consecutivas de carámbanos." - }, - "ironDefense": { - "name": "Defensa Férrea", - "effect": "Fortalece el cuerpo como si fuera de hierro y sube mucho la Defensa." - }, - "block": { - "name": "Bloqueo", - "effect": "Le corta el paso al objetivo para que no pueda escapar." - }, - "howl": { - "name": "Aullido", - "effect": "Aullido que sube el ánimo y aumenta el Ataque del equipo." - }, - "dragonClaw": { - "name": "Garra Dragón", - "effect": "Araña al objetivo con garras afiladas." - }, - "frenzyPlant": { - "name": "Planta Feroz", - "effect": "Golpea con una enorme planta. El usuario deberá descansar en el siguiente turno." - }, - "bulkUp": { - "name": "Corpulencia", - "effect": "Robustece el cuerpo para subir el Ataque y la Defensa." - }, - "bounce": { - "name": "Bote", - "effect": "El usuario bota en el primer turno y golpea al objetivo en el segundo y puede llegar a paralizarlo." - }, - "mudShot": { - "name": "Disparo Lodo", - "effect": "El usuario ataca lanzando una bola de lodo al objetivo que también reduce su Velocidad." - }, - "poisonTail": { - "name": "Cola Veneno", - "effect": "Puede envenenar y dar un golpe crítico." - }, - "covet": { - "name": "Antojo", - "effect": "Se acerca con ternura al objetivo y tiene un 30% de posibilidades de robar el objeto que lleve." - }, - "voltTackle": { - "name": "Placaje Eléc", - "effect": "Quien lo usa electrifica su cuerpo para luego atacar. Se hiere mucho a sí mismo, pero puede paralizar al objetivo." - }, - "magicalLeaf": { - "name": "Hoja Mágica", - "effect": "Esparce extrañas hojas que persiguen al objetivo. No falla nunca." - }, - "waterSport": { - "name": "Hidrochorro", - "effect": "El usuario se empapa en agua, lo que debilita los movimientos de tipo Fuego durante cinco turnos." - }, - "calmMind": { - "name": "Paz Mental", - "effect": "Aumenta la concentración y calma el espíritu para subir el Ataque Especial y la Defensa Especial." - }, - "leafBlade": { - "name": "Hoja Aguda", - "effect": "Acuchilla con una hoja fina. Suele dar un golpe crítico." - }, - "dragonDance": { - "name": "Danza Dragón", - "effect": "Danza mística que sube el Ataque y la Velocidad." - }, - "rockBlast": { - "name": "Pedrada", - "effect": "Lanza pedruscos al objetivo de dos a cinco veces consecutivas." - }, - "shockWave": { - "name": "Onda Voltio", - "effect": "Ataque eléctrico muy rápido que no falla nunca." - }, - "waterPulse": { - "name": "Hidropulso", - "effect": "Ataca con una potente onda de agua. Puede confundir al objetivo." - }, - "doomDesire": { - "name": "Deseo Oculto", - "effect": "Ataca al objetivo con innumerables haces de luz dos turnos después de haber usado el movimiento." - }, - "psychoBoost": { - "name": "Psicoataque", - "effect": "Ataque en toda regla que baja mucho el Ataque Especial de quien lo usa." - }, - "roost": { - "name": "Respiro", - "effect": "Aterriza sobre la superficie para descansar. Recupera hasta la mitad del total de sus PS." - }, - "gravity": { - "name": "Gravedad", - "effect": "Durante cinco turnos, se anulan los movimientos que alzan el vuelo y los Pokémon de tipo Volador o que levitan son vulnerables a movimientos de tipo Tierra." - }, - "miracleEye": { - "name": "Gran Ojo", - "effect": "Permite atacar con cualquier movimiento a objetivos de tipo Siniestro y golpear a Pokémon evasivos." - }, - "wakeUpSlap": { - "name": "Espabila", - "effect": "Inflige gran daño a objetivos dormidos. Sin embargo, los bofetones también los despiertan." - }, - "hammerArm": { - "name": "Machada", - "effect": "Un terrible puño golpea al contrincante, pero la Velocidad del usuario se ve reducida." - }, - "gyroBall": { - "name": "Giro Bola", - "effect": "Embiste al objetivo con un potente ataque giratorio. Cuanto más lento es el usuario, más daño causa." - }, - "healingWish": { - "name": "Deseo Cura", - "effect": "El usuario se debilita, pero cura los problemas de estado del Pokémon que lo sustituye y restaura sus PS." - }, - "brine": { - "name": "Salmuera", - "effect": "Si al objetivo le queda la mitad o menos de sus PS, el ataque será el doble de fuerte." - }, - "naturalGift": { - "name": "Don Natural", - "effect": "La baya que lleva presta su fuerza para atacar. El tipo de ataque y su fuerza dependen de la baya." - }, - "feint": { - "name": "Amago", - "effect": "Permite golpear a objetivos que han utilizado movimientos como Protección o Detección y anula sus efectos." - }, - "pluck": { - "name": "Picoteo", - "effect": "Picotea al objetivo. Si este sostiene una baya, la picotea también y obtiene sus efectos." - }, - "tailwind": { - "name": "Viento Afín", - "effect": "Crea un fuerte remolino que aumenta la Velocidad de los Pokémon de tu equipo durante cuatro turnos." - }, - "acupressure": { - "name": "Acupresión", - "effect": "Aplica presión en puntos clave del cuerpo para aumentar mucho una característica al azar." - }, - "metalBurst": { - "name": "Represión Metal", - "effect": "Devuelve al rival el último ataque recibido, pero con mucha más fuerza." - }, - "uTurn": { - "name": "Ida y Vuelta", - "effect": "Tras atacar, el usuario da paso a toda prisa a otro Pokémon del equipo." - }, - "closeCombat": { - "name": "A Bocajarro", - "effect": "Lucha abiertamente contra el objetivo sin protegerse. También reduce la Defensa y la Defensa Especial del usuario." - }, - "payback": { - "name": "Vendetta", - "effect": "El usuario contraataca con el doble de fuerza si el objetivo usa un movimiento antes." - }, - "assurance": { - "name": "Buena Baza", - "effect": "Si el objetivo ya ha sufrido daño en ese turno, la fuerza del ataque se duplica." - }, - "embargo": { - "name": "Embargo", - "effect": "Impide al objetivo usar el objeto que lleva durante cinco turnos. Su Entrenador tampoco puede usar objetos con él." - }, - "fling": { - "name": "Lanzamiento", - "effect": "El usuario lanza contra el objetivo el objeto que lleva. La potencia del movimiento y su efecto varían según el objeto." - }, - "psychoShift": { - "name": "Psicocambio", - "effect": "Usa su poder mental para transferir al objetivo sus problemas de estado." - }, - "trumpCard": { - "name": "As Oculto", - "effect": "Cuantos menos PP tenga el movimiento, mayor será la fuerza para atacar." - }, - "healBlock": { - "name": "Anticura", - "effect": "Impide al objetivo usar movimientos, habilidades y objetos equipados que recuperan PS durante cinco turnos." - }, - "wringOut": { - "name": "Estrujón", - "effect": "Estruja con fuerza al objetivo. Cuantos más PS tenga el objetivo, más fuerza tendrá el ataque." - }, - "powerTrick": { - "name": "Truco Fuerza", - "effect": "El usuario emplea su poder mental para intercambiar su Ataque y su Defensa." - }, - "gastroAcid": { - "name": "Bilis", - "effect": "El usuario arroja sus jugos biliares al objetivo, lo que anula el efecto de la habilidad en uso." - }, - "luckyChant": { - "name": "Conjuro", - "effect": "Lanza al cielo un conjuro que protege a todo su equipo de golpes críticos." - }, - "meFirst": { - "name": "Yo Primero", - "effect": "Se adelanta al movimiento que pretende usar el objetivo y lo lanza antes con más fuerza. Si el usuario es más lento, falla." - }, - "copycat": { - "name": "Copión", - "effect": "Imita el movimiento usado justo antes. El movimiento falla si no se ha usado aún ninguno." - }, - "powerSwap": { - "name": "Cambiafuerza", - "effect": "El usuario emplea su poder mental para intercambiar los cambios en el Ataque y el Ataque Especial con el objetivo." - }, - "guardSwap": { - "name": "Cambiadefensa", - "effect": "El usuario emplea su poder mental para intercambiar los cambios en la Defensa y la Defensa Especial con el objetivo." - }, - "punishment": { - "name": "Castigo", - "effect": "La fuerza del ataque aumenta cuanto más se ha fortalecido el objetivo con cambios de características." - }, - "lastResort": { - "name": "Última Baza", - "effect": "Este movimiento solo puede utilizarse tras haber usado al menos una vez todos los demás conocidos por el Pokémon." - }, - "worrySeed": { - "name": "Abatidoras", - "effect": "Planta una semilla en el objetivo que le causa pesar. Sustituye la habilidad del objetivo por Insomnio y le impide dormirse." - }, - "suckerPunch": { - "name": "Golpe Bajo", - "effect": "Permite atacar con prioridad. Falla si el objetivo no está preparando ningún ataque." - }, - "toxicSpikes": { - "name": "Púas Tóxicas", - "effect": "Lanza una trampa de púas tóxicas a los pies del objetivo que envenena a los rivales que entran en combate." - }, - "heartSwap": { - "name": "Cambiaalmas", - "effect": "Usa la fuerza mental para intercambiar con el objetivo los cambios en las características." - }, - "aquaRing": { - "name": "Acua Aro", - "effect": "El usuario se cubre con un manto de agua. Recupera algunos PS en cada turno." - }, - "magnetRise": { - "name": "Levitón", - "effect": "Levita gracias a un campo magnético generado por electricidad durante cinco turnos." - }, - "flareBlitz": { - "name": "Envite Ígneo", - "effect": "El Pokémon se cubre de llamas y carga contra el objetivo, aunque él también recibe daño. Puede quemar." - }, - "forcePalm": { - "name": "Palmeo", - "effect": "Ataca al objetivo con una onda de choque y puede llegar a paralizarlo." - }, - "auraSphere": { - "name": "Esfera Aural", - "effect": "Libera, desde su interior, una inmensa descarga de aura. Es infalible." - }, - "rockPolish": { - "name": "Pulimento", - "effect": "Reduce la resistencia puliendo su cuerpo. Aumenta mucho la Velocidad." - }, - "poisonJab": { - "name": "Puya Nociva", - "effect": "Pincha al objetivo con un tentáculo o brazo envenenado. Puede llegar a envenenar al objetivo." - }, - "darkPulse": { - "name": "Pulso Umbrío", - "effect": "Libera una horrible aura llena de malos pensamientos que puede amedrentar al objetivo." - }, - "nightSlash": { - "name": "Tajo Umbrío", - "effect": "Ataca al objetivo a la primera oportunidad. Suele ser crítico." - }, - "aquaTail": { - "name": "Acua Cola", - "effect": "Ataca agitando la cola como si fuera una ola rabiosa en una tormenta devastadora." - }, - "seedBomb": { - "name": "Bomba Germen", - "effect": "Lanza al objetivo una descarga de semillas explosivas desde arriba." - }, - "airSlash": { - "name": "Tajo Aéreo", - "effect": "Ataca con un viento afilado que incluso corta el aire. También puede amedrentar al objetivo." - }, - "xScissor": { - "name": "Tijera X", - "effect": "Cruza las guadañas o las garras para atacar al objetivo como si fueran unas tijeras." - }, - "bugBuzz": { - "name": "Zumbido", - "effect": "El usuario crea una onda sónica dañina moviendo su cuerpo que también puede disminuir la Defensa Especial del objetivo." - }, - "dragonPulse": { - "name": "Pulso Dragón", - "effect": "Abre mucho la boca y libera una onda de choque con la que ataca al objetivo." - }, - "dragonRush": { - "name": "Carga Dragón", - "effect": "Ataca de forma brutal mientras intimida al objetivo. Puede amedrentarlo." - }, - "powerGem": { - "name": "Joya de Luz", - "effect": "Ataca con un rayo de luz que centellea como si lo formaran miles de joyas." - }, - "drainPunch": { - "name": "Puño Drenaje", - "effect": "Un golpe que drena energía. El Pokémon recupera la mitad de los PS arrebatados al objetivo." - }, - "vacuumWave": { - "name": "Onda Vacío", - "effect": "Gira los puños y libera una onda de vacío contra el objetivo. Este movimiento tiene prioridad alta." - }, - "focusBlast": { - "name": "Onda Certera", - "effect": "Agudiza la concentración mental y libera su poder. Puede reducir la Defensa Especial del objetivo." - }, - "energyBall": { - "name": "Energibola", - "effect": "Aúna fuerzas de la naturaleza y libera su ataque. Puede reducir la Defensa Especial del objetivo." - }, - "braveBird": { - "name": "Pájaro Osado", - "effect": "Pliega sus alas y ataca con un vuelo rasante. El Pokémon que lo usa también resulta seriamente dañado." - }, - "earthPower": { - "name": "Tierra Viva", - "effect": "La tierra a los pies del objetivo erupciona violentamente. Puede reducir la Defensa Especial del objetivo." - }, - "switcheroo": { - "name": "Trapicheo", - "effect": "Intercambia con el objetivo los objetos que llevan tan rápido que es imposible verlo a simple vista." - }, - "gigaImpact": { - "name": "Gigaimpacto", - "effect": "El usuario carga contra el objetivo con toda la fuerza que tiene y descansa en el siguiente turno." - }, - "nastyPlot": { - "name": "Maquinación", - "effect": "Estimula su cerebro pensando en cosas malas. Aumenta mucho el Ataque Especial." - }, - "bulletPunch": { - "name": "Puño Bala", - "effect": "Ataca con fuertes puñetazos tan rápidos como proyectiles. Este movimiento tiene prioridad alta." - }, - "avalanche": { - "name": "Alud", - "effect": "Este ataque inflige el doble de daño a un objetivo que haya golpeado al usuario en ese mismo turno." - }, - "iceShard": { - "name": "Esquirla Helada", - "effect": "Crea esquirlas de hielo y las lanza a gran velocidad. Este movimiento tiene prioridad alta." - }, - "shadowClaw": { - "name": "Garra Umbría", - "effect": "Ataca con una garra afilada hecha de sombras. Suele ser crítico." - }, - "thunderFang": { - "name": "Colmillo Rayo", - "effect": "El usuario muerde al objetivo con colmillos electrificados y puede hacer que se amedrente o se paralice." - }, - "iceFang": { - "name": "Colmillo Hielo", - "effect": "El usuario muerde al objetivo con colmillos helados y puede hacer que se amedrente o se congele." - }, - "fireFang": { - "name": "Colmillo Ígneo", - "effect": "El usuario muerde al objetivo con colmillos en llamas y puede hacer que se amedrente o sufra quemaduras." - }, - "shadowSneak": { - "name": "Sombra Vil", - "effect": "Extiende su sombra y ataca al objetivo por la espalda. Este movimiento tiene prioridad alta." - }, - "mudBomb": { - "name": "Bomba Fango", - "effect": "Ataca lanzando una compacta bola de fango. Puede bajar la Precisión del objetivo." - }, - "psychoCut": { - "name": "Psicocorte", - "effect": "Ataca al objetivo con cuchillas formadas por energía psíquica. Suele ser crítico." - }, - "zenHeadbutt": { - "name": "Cabezazo Zen", - "effect": "Concentra su energía psíquica en la cabeza para golpear. Puede hacer que el objetivo se amedrente." - }, - "mirrorShot": { - "name": "Disparo Espejo", - "effect": "El usuario libera un haz de energía desde su pulido cuerpo. Puede bajar la Precisión." - }, - "flashCannon": { - "name": "Foco Resplandor", - "effect": "El usuario concentra toda la luz del cuerpo y la libera. Puede bajar la Defensa Especial del objetivo." - }, - "rockClimb": { - "name": "Treparrocas", - "effect": "Ataca con una gran embestida. Puede confundir al objetivo." - }, - "defog": { - "name": "Despejar", - "effect": "Potente viento que barre los efectos de movimientos como Reflejo o Pantalla de Luz usados por el objetivo. También reduce su Evasión." - }, - "trickRoom": { - "name": "Espacio Raro", - "effect": "Crea un espacio misterioso en el que los Pokémon lentos se mueven primero durante cinco turnos." - }, - "dracoMeteor": { - "name": "Cometa Draco", - "effect": "Hace que grandes cometas caigan del cielo sobre el objetivo. Baja mucho el Ataque Especial del que lo usa." - }, - "discharge": { - "name": "Chispazo", - "effect": "Una deslumbradora onda eléctrica afecta a los Pokémon que hay combatiendo alrededor. Puede paralizar." - }, - "lavaPlume": { - "name": "Humareda", - "effect": "Un infierno de llamas daña a los Pokémon adyacentes en combate. Puede causar quemaduras." - }, - "leafStorm": { - "name": "Lluevehojas", - "effect": "Envuelve al objetivo con una lluvia de hojas afiladas, pero reduce mucho su Ataque Especial." - }, - "powerWhip": { - "name": "Latigazo", - "effect": "El usuario agita violentamente sus lianas o tentáculos para golpear al objetivo." - }, - "rockWrecker": { - "name": "Romperrocas", - "effect": "Lanza una piedra enorme contra el objetivo. El usuario deberá descansar en el siguiente turno." - }, - "crossPoison": { - "name": "Veneno X", - "effect": "Tajo que puede envenenar al objetivo. Suele ser crítico." - }, - "gunkShot": { - "name": "Lanzamugre", - "effect": "Lanza contra el objetivo basura asquerosa y puede envenenarlo." - }, - "ironHead": { - "name": "Cabeza de Hierro", - "effect": "Ataca con su cabeza dura como el hierro. Puede hacer que el objetivo se amedrente." - }, - "magnetBomb": { - "name": "Bomba Imán", - "effect": "Lanza unas bombas de hierro que se pegan al adversario. No se puede esquivar." - }, - "stoneEdge": { - "name": "Roca Afilada", - "effect": "Clava piedras muy afiladas al objetivo. Suele ser crítico." - }, - "captivate": { - "name": "Seducción", - "effect": "Si el objetivo es del sexo opuesto, queda embelesado y baja mucho su Ataque Especial." - }, - "stealthRock": { - "name": "Trampa Rocas", - "effect": "Una trampa de rocas que flota en el aire y daña a los objetivos que entran en combate." - }, - "grassKnot": { - "name": "Hierba Lazo", - "effect": "Enreda al objetivo con hierba y lo derriba. Cuanto más pesado es el objetivo, más potencia tiene el movimiento." - }, - "chatter": { - "name": "Cháchara", - "effect": "Ataca con una onda de sonido muy ruidosa compuesta por palabras y confunde al objetivo." - }, - "judgment": { - "name": "Sentencia", - "effect": "Emite incontables haces de luz. El tipo del movimiento varía según la tabla que lleve el usuario." - }, - "bugBite": { - "name": "Picadura", - "effect": "Pica al objetivo. Si el objetivo lleva una baya, el usuario se la come y se beneficia de su efecto." - }, - "chargeBeam": { - "name": "Rayo Carga", - "effect": "Lanza un rayo eléctrico contra el objetivo. Puede subir el Ataque Especial de quien lo usa." - }, - "woodHammer": { - "name": "Mazazo", - "effect": "Arremete contra el objetivo con su robusto cuerpo. El usuario se hiere seriamente a sí mismo." - }, - "aquaJet": { - "name": "Acua Jet", - "effect": "Ataque de una rapidez espeluznante. Este movimiento tiene prioridad alta." - }, - "attackOrder": { - "name": "Al Ataque", - "effect": "El usuario llama a sus súbditos para que ataquen al objetivo. Suele ser crítico." - }, - "defendOrder": { - "name": "A Defender", - "effect": "El usuario llama a sus súbditos para que formen un escudo viviente. Sube la Defensa y la Defensa Especial." - }, - "healOrder": { - "name": "Auxilio", - "effect": "El usuario llama a sus súbditos para que lo curen. Recupera hasta la mitad de los PS máximos." - }, - "headSmash": { - "name": "Testarazo", - "effect": "El usuario arriesga su vida y lanza un cabezazo con toda su fuerza. El agresor resulta seriamente dañado." - }, - "doubleHit": { - "name": "Doble Golpe", - "effect": "Golpea al objetivo dos veces seguidas con la cola u otras partes de su cuerpo." - }, - "roarOfTime": { - "name": "Distorsión", - "effect": "Ataca al objetivo usando tal energía que el tiempo se distorsiona. El usuario deberá descansar en el siguiente turno." - }, - "spacialRend": { - "name": "Corte Vacío", - "effect": "Desgarra al objetivo y el espacio a su alrededor. Suele ser crítico." - }, - "lunarDance": { - "name": "Danza Lunar", - "effect": "El usuario se debilita, pero el Pokémon que lo sustituye recupera su estado, los PS y los PP." - }, - "crushGrip": { - "name": "Agarrón", - "effect": "Estruja al objetivo con gran fuerza. Cuantos más PS le queden al objetivo, más fuerte será el ataque." - }, - "magmaStorm": { - "name": "Lluvia Ígnea", - "effect": "El objetivo queda atrapado en una tormenta de fuego que dura de cuatro a cinco turnos." - }, - "darkVoid": { - "name": "Brecha Negra", - "effect": "El objetivo es enviado a un mundo de tinieblas que lo hace dormir." - }, - "seedFlare": { - "name": "Fulgor Semilla", - "effect": "Una onda de choque se libera del cuerpo. Puede bajar mucho la Defensa Especial del objetivo." - }, - "ominousWind": { - "name": "Viento Aciago", - "effect": "Produce un viento horripilante. Puede subir de golpe todas las características del usuario." - }, - "shadowForce": { - "name": "Golpe Umbrío", - "effect": "En el primer turno, desaparece. En el segundo, golpea al objetivo aunque se esté protegiendo." - }, - "honeClaws": { - "name": "Afilagarras", - "effect": "El usuario se afila las garras para aumentar su Ataque y su Precisión." - }, - "wideGuard": { - "name": "Vasta Guardia", - "effect": "Bloquea los ataques de objetivo múltiple lanzados contra el bando del usuario durante un turno." - }, - "guardSplit": { - "name": "Isoguardia", - "effect": "El usuario emplea sus poderes para hacer la media de su Defensa y su Defensa Especial con las del objetivo y compartirlas." - }, - "powerSplit": { - "name": "Isofuerza", - "effect": "El usuario emplea sus poderes para hacer la media de su Ataque y su Ataque Especial con los del objetivo y compartirlos." - }, - "wonderRoom": { - "name": "Zona Extraña", - "effect": "Crea un espacio misterioso donde se intercambian la Defensa y la Defensa Especial de todos los Pokémon durante cinco turnos." - }, - "psyshock": { - "name": "Psicocarga", - "effect": "Crea una onda psíquica que causa daño físico al objetivo." - }, - "venoshock": { - "name": "Carga Tóxica", - "effect": "Cubre al objetivo con un líquido venenoso. La potencia del movimiento se duplica si este ya está envenenado." - }, - "autotomize": { - "name": "Aligerar", - "effect": "El usuario se desprende de partes prescindibles de su cuerpo para hacerse más ligero y aumentar mucho su Velocidad." - }, - "ragePowder": { - "name": "Polvo Ira", - "effect": "Usa un polvo que enerva a los rivales y hace que centren en el usuario su atención y sus movimientos." - }, - "telekinesis": { - "name": "Telequinesis", - "effect": "El usuario emplea su poder mental para hacer flotar al objetivo, y lo convierte en un blanco fácil durante tres turnos." - }, - "magicRoom": { - "name": "Zona Mágica", - "effect": "Crea un espacio misterioso que inutiliza todos los objetos de los Pokémon durante cinco turnos." - }, - "smackDown": { - "name": "Antiaéreo", - "effect": "Ataca lanzando una piedra o un proyectil. Si el objetivo está en el aire, lo estrella contra el suelo." - }, - "stormThrow": { - "name": "Llave Corsé", - "effect": "Lanza un golpe devastador. Siempre asesta un golpe crítico." - }, - "flameBurst": { - "name": "Pirotecnia", - "effect": "Golpea al objetivo con una llamarada que afecta también a los Pokémon adyacentes." - }, - "sludgeWave": { - "name": "Onda Tóxica", - "effect": "Una onda tóxica que daña a los Pokémon de alrededor. Puede envenenar." - }, - "quiverDance": { - "name": "Danza Aleteo", - "effect": "Danza mística que aumenta el Ataque Especial, la Defensa Especial y la Velocidad." - }, - "heavySlam": { - "name": "Cuerpo Pesado", - "effect": "El usuario golpea con todo su cuerpo. Cuanto mayor sea su peso comparado con el del objetivo, mayor será la potencia del movimiento." - }, - "synchronoise": { - "name": "Sincrorruido", - "effect": "Una extraña onda que daña a todos los Pokémon adyacentes del mismo tipo que el que la ejecuta." - }, - "electroBall": { - "name": "Bola Voltio", - "effect": "Lanza una bola eléctrica. Cuanto mayor sea la Velocidad del usuario en comparación con la del objetivo, mayor será la potencia del movimiento." - }, - "soak": { - "name": "Empapar", - "effect": "Potente lluvia que transforma al objetivo en un Pokémon de tipo Agua." - }, - "flameCharge": { - "name": "Nitrocarga", - "effect": "Llamas que golpean al objetivo y aumentan la Velocidad del atacante." - }, - "coil": { - "name": "Enrosque", - "effect": "El usuario se concentra, lo que le permite aumentar su Ataque, Defensa y Precisión." - }, - "lowSweep": { - "name": "Puntapié", - "effect": "Ataque rápido dirigido a los pies del objetivo que le hace perder Velocidad." - }, - "acidSpray": { - "name": "Bomba Ácida", - "effect": "Ataca con un líquido corrosivo que reduce mucho la Defensa Especial del objetivo." - }, - "foulPlay": { - "name": "Juego Sucio", - "effect": "El usuario emplea la fuerza del objetivo para atacarlo. Cuanto mayor es el Ataque del objetivo, más daño provoca." - }, - "simpleBeam": { - "name": "Onda Simple", - "effect": "Lanza una onda psíquica que hace que la habilidad del objetivo pase a ser Simple." - }, - "entrainment": { - "name": "Danza Amiga", - "effect": "Una extraña danza que induce al objetivo a imitarla y cambia su habilidad por la misma que la del usuario." - }, - "afterYou": { - "name": "Cede Paso", - "effect": "Si el usuario es el más rápido, permite al objetivo usar un movimiento justo tras él, adelantándose a Pokémon más rápidos." - }, - "round": { - "name": "Canon", - "effect": "Un canto que ataca al objetivo. Cuantos más Pokémon lo usan, más aumenta de potencia." - }, - "echoedVoice": { - "name": "Eco Voz", - "effect": "Un susurro que aumenta de potencia conforme el usuario y otros Pokémon lo van utilizando." - }, - "chipAway": { - "name": "Guardia Baja", - "effect": "Un ataque que busca los puntos débiles del objetivo y puede causarle daño aunque cambien sus características." - }, - "clearSmog": { - "name": "Niebla Clara", - "effect": "Ataca al objetivo con una singular bola de lodo que elimina cualquier cambio en sus características." - }, - "storedPower": { - "name": "Poder Reserva", - "effect": "Acumula poder para golpear. Cuanto más suban las características del usuario, mayor será el daño." - }, - "quickGuard": { - "name": "Anticipo", - "effect": "Se protege a sí mismo y a sus aliados de movimientos con prioridad." - }, - "allySwitch": { - "name": "Cambio de Banda", - "effect": "Extraño poder que intercambia la posición del usuario con la de un aliado sobre el terreno de combate." - }, - "scald": { - "name": "Escaldar", - "effect": "Ataca arrojando agua hirviendo al objetivo. Puede causar quemaduras." - }, - "shellSmash": { - "name": "Rompecoraza", - "effect": "El usuario rompe su coraza y baja su Defensa y Defensa Especial, pero aumenta mucho su Ataque, Ataque Especial y Velocidad." - }, - "healPulse": { - "name": "Pulso Cura", - "effect": "Una onda curativa restaura la mitad de los PS máximos del objetivo." - }, - "hex": { - "name": "Infortunio", - "effect": "Ataque que causa un gran daño a los objetivos que sufren problemas de estado." - }, - "skyDrop": { - "name": "Caída Libre", - "effect": "Primer turno: lanza al objetivo al aire. Segundo turno: lo hace caer. Mientras está en el aire, no lo deja moverse." - }, - "shiftGear": { - "name": "Cambio de Marcha", - "effect": "Al hacer girar los engranajes, el usuario mejora su Ataque y aumenta mucho su Velocidad." - }, - "circleThrow": { - "name": "Llave Giro", - "effect": "Lanza por los aires al objetivo y hace que salga otro Pokémon. Si es uno salvaje, acaba el combate." - }, - "incinerate": { - "name": "Calcinación", - "effect": "Llamas que golpean al objetivo. Si este lleva una baya o ciertos objetos, se quemarán y ya no se podrán usar." - }, - "quash": { - "name": "Último Lugar", - "effect": "Consigue que el objetivo sea el último en moverse." - }, - "acrobatics": { - "name": "Acróbata", - "effect": "Golpea ágilmente. Si el usuario no porta ningún objeto, el objetivo resulta seriamente dañado." - }, - "reflectType": { - "name": "Clonatipo", - "effect": "Cambia el tipo del Pokémon al mismo tipo que el del objetivo." - }, - "retaliate": { - "name": "Represalia", - "effect": "Venga a los amigos caídos. Si en el turno anterior han derrotado a alguno, la potencia del ataque aumentará." - }, - "finalGambit": { - "name": "Sacrificio", - "effect": "El usuario se sacrifica causándole un daño al objetivo equivalente a sus propios PS perdidos." - }, - "bestow": { - "name": "Ofrenda", - "effect": "Entrega el objeto que lleva al objetivo en caso de que este no tenga ninguno." - }, - "inferno": { - "name": "Infierno", - "effect": "Ataca con una gran ráfaga de fuego que causa quemaduras." - }, - "waterPledge": { - "name": "Voto Agua", - "effect": "Ataca con columnas de agua. Combinado con Voto Fuego, crea un arcoíris y aumenta su potencia." - }, - "firePledge": { - "name": "Voto Fuego", - "effect": "Ataca con columnas de fuego. Combinado con Voto Planta, crea un mar de llamas y aumenta su potencia." - }, - "grassPledge": { - "name": "Voto Planta", - "effect": "Ataca con columnas de hojas. Combinado con Voto Agua, crea un pantano y aumenta su potencia." - }, - "voltSwitch": { - "name": "Voltiocambio", - "effect": "Tras atacar, el usuario da paso a toda prisa a otro Pokémon del equipo." - }, - "struggleBug": { - "name": "Estoicismo", - "effect": "El usuario opone resistencia y ataca a los oponentes. También reduce su Ataque Especial." - }, - "bulldoze": { - "name": "Terratemblor", - "effect": "Sacudida sísmica que afecta a los Pokémon adyacentes y también reduce su Velocidad." - }, - "frostBreath": { - "name": "Vaho Gélido", - "effect": "Quien lo usa ataca lanzando un aliento gélido. Siempre asesta un golpe crítico." - }, - "dragonTail": { - "name": "Cola Dragón", - "effect": "Ataca al objetivo y lo obliga a cambiarse por otro Pokémon. Si es uno salvaje, acaba el combate." - }, - "workUp": { - "name": "Avivar", - "effect": "Quien lo usa se concentra y potencia su Ataque y su Ataque Especial." - }, - "electroweb": { - "name": "Electrotela", - "effect": "Atrapa y ataca a los objetivos con una telaraña eléctrica. También reduce su Velocidad." - }, - "wildCharge": { - "name": "Voltio Cruel", - "effect": "Carga eléctrica muy potente que también hiere ligeramente a quien la usa." - }, - "drillRun": { - "name": "Taladradora", - "effect": "El usuario golpea usando su cuerpo como un taladro. Suele ser crítico." - }, - "dualChop": { - "name": "Golpe Bis", - "effect": "Golpea dos veces seguidas con las partes más recias de su cuerpo." - }, - "heartStamp": { - "name": "Arrumaco", - "effect": "El usuario despista al objetivo con gestos adorables y aprovecha la ocasión para asestarle un golpe tremendo que puede hacerlo retroceder." - }, - "hornLeech": { - "name": "Asta Drenaje", - "effect": "Un golpe que drena energía. El Pokémon recupera la mitad de los PS arrebatados al objetivo." - }, - "sacredSword": { - "name": "Espada Santa", - "effect": "El usuario ataca con una espada, ignorando cualquier cambio en las características del objetivo." - }, - "razorShell": { - "name": "Concha Filo", - "effect": "Una afilada vieira ataca al objetivo. También puede hacer disminuir su Defensa." - }, - "heatCrash": { - "name": "Golpe Calor", - "effect": "El usuario ataca con su cuerpo ardiente. Cuanto mayor sea su peso comparado con el del objetivo, más daño causará." - }, - "leafTornado": { - "name": "Ciclón de Hojas", - "effect": "Tritura con afiladas hojas y puede bajar la Precisión del objetivo." - }, - "steamroller": { - "name": "Rodillo de Púas", - "effect": "El usuario se hace una bola y arrolla al objetivo con su cuerpo. Puede hacerlo retroceder." - }, - "cottonGuard": { - "name": "Rizo Algodón", - "effect": "Cubre al Pokémon con una madeja protectora. Aumenta muchísimo la Defensa." - }, - "nightDaze": { - "name": "Pulso Noche", - "effect": "Ataca al objetivo con una onda siniestra. Puede bajar su Precisión." - }, - "psystrike": { - "name": "Onda Mental", - "effect": "Crea una onda psíquica que causa daño físico al objetivo." - }, - "tailSlap": { - "name": "Plumerazo", - "effect": "Golpea con la cola de dos a cinco veces seguidas." - }, - "hurricane": { - "name": "Vendaval", - "effect": "Golpea al objetivo con un fuerte torbellino que envuelve al rival y puede confundirlo." - }, - "headCharge": { - "name": "Ariete", - "effect": "Propina un tremendo cabezazo. También daña al usuario un poco." - }, - "gearGrind": { - "name": "Rueda Doble", - "effect": "Rota dos engranajes de hierro sobre el objetivo. Golpea dos veces." - }, - "searingShot": { - "name": "Bomba Ígnea", - "effect": "Un infierno de llamas daña a los Pokémon adyacentes en combate. Puede causar quemaduras." - }, - "technoBlast": { - "name": "Tecno Shock", - "effect": "Ataca al objetivo con un gran láser. El tipo del ataque lo determina el cartucho que porta el usuario." - }, - "relicSong": { - "name": "Canto Arcaico", - "effect": "Ataca conmoviendo al objetivo con un antiguo canto. Puede dormirlo." - }, - "secretSword": { - "name": "Sable Místico", - "effect": "Ensarta al objetivo con un largo cuerno dotado de un poder místico que provoca daño físico." - }, - "glaciate": { - "name": "Mundo Gélido", - "effect": "Ataque con aire helado que baja la Velocidad del objetivo." - }, - "boltStrike": { - "name": "Ataque Fulgor", - "effect": "Ataca envolviéndose de una gran carga eléctrica y embistiendo al objetivo con ella. Puede paralizar." - }, - "blueFlare": { - "name": "Llama Azul", - "effect": "Ataca con una bella pero potente llama azul que rodea al objetivo. Puede causar quemaduras." - }, - "fieryDance": { - "name": "Danza Llama", - "effect": "Envuelve en llamas y daña al objetivo. Puede aumentar el Ataque Especial de quien lo usa." - }, - "freezeShock": { - "name": "Rayo Gélido", - "effect": "El usuario carga un bloque de hielo con electricidad en el primer turno y ataca con él en el segundo. Puede paralizar." - }, - "iceBurn": { - "name": "Llama Gélida", - "effect": "Ataca al objetivo en el segundo turno rodeándolo de un aire gélido. Puede causar quemaduras." - }, - "snarl": { - "name": "Alarido", - "effect": "Chillido desagradable que reduce el Ataque Especial del objetivo." - }, - "icicleCrash": { - "name": "Chuzos", - "effect": "Lanza grandes carámbanos. Puede amedrentar al objetivo." - }, - "vCreate": { - "name": "V de Fuego", - "effect": "Golpea con una V de llamas al objetivo. Baja la Defensa, la Defensa Especial y la Velocidad de quien lo usa." - }, - "fusionFlare": { - "name": "Llama Fusión", - "effect": "Ataca con una llamarada gigantesca. Aumenta su potencia si es influenciada por una gran energía eléctrica." - }, - "fusionBolt": { - "name": "Rayo Fusión", - "effect": "Ataca con una enorme descarga eléctrica. Aumenta su potencia si es influenciada por una gigantesca llamarada." - }, - "flyingPress": { - "name": "Plancha Voladora", - "effect": "El usuario se lanza sobre su objetivo. Este movimiento es de tipo Lucha y tipo Volador al mismo tiempo." - }, - "matBlock": { - "name": "Escudo Tatami", - "effect": "El usuario usa un tatami para escudarse de los ataques enemigos. Protege también a los aliados. No funciona contra movimientos de estado." - }, - "belch": { - "name": "Eructo", - "effect": "El usuario causa daño a su objetivo lanzándole un eructo. Para poder utilizar este movimiento, tiene que haberse comido una baya equipada." - }, - "rototiller": { - "name": "Fertilizante", - "effect": "Labra la tierra haciendo que sea más fácil cultivarla y consigue que aumente el Ataque y el Ataque Especial de los Pokémon de tipo Planta." - }, - "stickyWeb": { - "name": "Red Viscosa", - "effect": "Coloca una red pegajosa alrededor del objetivo que reduce la Velocidad de los rivales que entran en combate." - }, - "fellStinger": { - "name": "Aguijón Letal", - "effect": "Si se derrota al objetivo utilizando este movimiento, aumenta muchísimo el Ataque del usuario." - }, - "phantomForce": { - "name": "Golpe Fantasma", - "effect": "El usuario desaparece en el primer turno y ataca a su objetivo en el segundo. Permite acertar aunque el objetivo esté protegiéndose." - }, - "trickOrTreat": { - "name": "Halloween", - "effect": "Invita al objetivo a celebrar Halloween, lo que añade el tipo Fantasma a los tipos de este." - }, - "nobleRoar": { - "name": "Rugido de Guerra", - "effect": "Intimida a su oponente con un rugido de guerra, lo que hace que disminuyan tanto su Ataque como su Ataque Especial." - }, - "ionDeluge": { - "name": "Cortina Plasma", - "effect": "El Pokémon disemina partículas con carga eléctrica que convierten los movimientos de tipo Normal en tipo Eléctrico." - }, - "parabolicCharge": { - "name": "Carga Parábola", - "effect": "Inflige daño a los Pokémon adyacentes. El usuario absorbe la mitad del daño producido para restaurar sus propios PS." - }, - "forestsCurse": { - "name": "Condena Silvana", - "effect": "El objetivo es presa de la maldición del bosque, por lo que pasa a ser un Pokémon de tipo Planta, además de conservar sus tipos habituales." - }, - "petalBlizzard": { - "name": "Tormenta Floral", - "effect": "El usuario desata un intenso vendaval de pétalos que daña a los Pokémon a su alrededor." - }, - "freezeDry": { - "name": "Liofilización", - "effect": "Enfría súbitamente al objetivo e incluso puede congelarlo. Es supereficaz contra Pokémon de tipo Agua." - }, - "disarmingVoice": { - "name": "Voz Cautivadora", - "effect": "Obnubila al objetivo con su fascinante voz y le provoca daños emocionales. No falla nunca." - }, - "partingShot": { - "name": "Última Palabra", - "effect": "El usuario se cambia por otro Pokémon de su equipo, pero antes amedrenta a su oponente y hace que disminuyan su Ataque y Ataque Especial." - }, - "topsyTurvy": { - "name": "Reversión", - "effect": "Invierte por completo los cambios en las características del objetivo." - }, - "drainingKiss": { - "name": "Beso Drenaje", - "effect": "El usuario absorbe PS del objetivo con un beso y restaura su propia energía en una cantidad igual o superior a la mitad del daño infligido." - }, - "craftyShield": { - "name": "Truco Defensa", - "effect": "Usa unos misteriosos poderes para protegerse a sí mismo y a sus aliados de movimientos de estado, pero no de otro tipo de ataques." - }, - "flowerShield": { - "name": "Defensa Floral", - "effect": "Aumenta la Defensa de todos los Pokémon de tipo Planta que hay en el combate usando unos misteriosos poderes." - }, - "grassyTerrain": { - "name": "Campo de Hierba", - "effect": "Durante cinco turnos, se potencian los movimientos de tipo Planta y los Pokémon que están en contacto con el suelo recuperan PS en cada turno." - }, - "mistyTerrain": { - "name": "Campo de Niebla", - "effect": "Durante cinco turnos, los Pokémon que están en el suelo no sufren problemas de estado y se reduce a la mitad el daño de los movimientos de tipo Dragón." - }, - "electrify": { - "name": "Electrificación", - "effect": "Si el objetivo queda electrificado antes de usar un movimiento, este será de tipo Eléctrico." - }, - "playRough": { - "name": "Carantoña", - "effect": "El Pokémon que lo usa le hace cucamonas al objetivo y lo ataca. Puede disminuir el Ataque del objetivo." - }, - "fairyWind": { - "name": "Viento Feérico", - "effect": "El Pokémon que lo usa desata un vendaval feérico que arremete contra el objetivo." - }, - "moonblast": { - "name": "Fuerza Lunar", - "effect": "Invoca el poder de la luna para atacar al objetivo. Puede reducir su Ataque Especial." - }, - "boomburst": { - "name": "Estruendo", - "effect": "Ataca a todos los Pokémon a su alrededor con una potentísima onda sonora." - }, - "fairyLock": { - "name": "Cerrojo Feérico", - "effect": "Consigue que ningún Pokémon pueda huir ni ser cambiado por otro en el siguiente turno echando un cerrojo." - }, - "kingsShield": { - "name": "Escudo Real", - "effect": "El usuario adopta una postura defensiva y se protege de cualquier daño. Reduce el Ataque de cualquier Pokémon con el que entre en contacto." - }, - "playNice": { - "name": "Camaradería", - "effect": "Se hace amigo de su objetivo y consigue que a este se le quiten las ganas de combatir, lo que reduce su Ataque." - }, - "confide": { - "name": "Confidencia", - "effect": "Hace que el objetivo pierda la concentración contándole un secreto y reduce su Ataque Especial." - }, - "diamondStorm": { - "name": "Torm. Diamantes", - "effect": "Desata un devastador vendaval de diamantes para dañar a los oponentes. Puede aumentar mucho la Defensa del usuario." - }, - "steamEruption": { - "name": "Chorro de Vapor", - "effect": "Envuelve al objetivo con vapor extremadamente caliente que puede causar quemaduras." - }, - "hyperspaceHole": { - "name": "Paso Dimensional", - "effect": "El usuario aparece junto al rival usando un agujero dimensional y le asesta un golpe que movimientos como Protección o Detección no pueden evitar." - }, - "waterShuriken": { - "name": "Shuriken de Agua", - "effect": "Golpea al objetivo de dos a cinco veces seguidas con estrellas arrojadizas hechas de mucosidad. Este movimiento tiene prioridad alta." - }, - "mysticalFire": { - "name": "Llama Embrujada", - "effect": "El usuario lanza por la boca una singular llama a gran temperatura con la que ataca a su objetivo y reduce su Ataque Especial." - }, - "spikyShield": { - "name": "Barrera Espinosa", - "effect": "Protege al usuario de ataques e inflige daño a quien se los lance si entra en contacto con él." - }, - "aromaticMist": { - "name": "Niebla Aromática", - "effect": "Consigue aumentar la Defensa Especial de un Pokémon de su equipo con una fragancia misteriosa." - }, - "eerieImpulse": { - "name": "Onda Anómala", - "effect": "El usuario irradia unas raras ondas que, al alcanzar al objetivo, reducen mucho su Ataque Especial." - }, - "venomDrench": { - "name": "Trampa Venenosa", - "effect": "Impregna a su objetivo con un líquido venenoso que disminuye el Ataque, el Ataque Especial y la Velocidad. Solo afecta a Pokémon ya envenenados." - }, - "powder": { - "name": "Polvo Explosivo", - "effect": "Esparce un polvo sobre el objetivo. Si este usa un movimiento de tipo Fuego en el mismo turno, el polvo explota y le inflige daño." - }, - "geomancy": { - "name": "Geocontrol", - "effect": "Concentra energía durante el primer turno, de forma que su Velocidad, Ataque Especial y Defensa Especial aumenten mucho en el segundo." - }, - "magneticFlux": { - "name": "Aura Magnética", - "effect": "Manipula el campo magnético y logra aumentar la Defensa y la Defensa Especial de los Pokémon aliados que cuenten con las habilidades Más y Menos." - }, - "happyHour": { - "name": "Paga Extra", - "effect": "Al usar este movimiento, se duplica el dinero recibido tras el combate." - }, - "electricTerrain": { - "name": "Campo Eléctrico", - "effect": "Durante cinco turnos, se potencian los movimientos de tipo Eléctrico y los Pokémon que están en contacto con el suelo no pueden quedarse dormidos." - }, - "dazzlingGleam": { - "name": "Brillo Mágico", - "effect": "Inflige daño al objetivo con una potente luz." - }, - "celebrate": { - "name": "Celebración", - "effect": "El Pokémon te felicita en un día muy especial para ti." - }, - "holdHands": { - "name": "Manos Juntas", - "effect": "El usuario le da la mano a un aliado y ambos se sienten muy felices." - }, - "babyDollEyes": { - "name": "Ojitos Tiernos", - "effect": "Lanza una mirada al objetivo con ojos acaramelados, con lo que logra que su Ataque se reduzca. Este movimiento tiene prioridad alta." - }, - "nuzzle": { - "name": "Moflete Estático", - "effect": "El usuario frota sus mofletes cargados de electricidad contra el objetivo y consigue paralizarlo." - }, - "holdBack": { - "name": "Clemencia", - "effect": "El usuario se contiene a la hora de atacar y deja al objetivo con al menos 1 PS." - }, - "infestation": { - "name": "Acoso", - "effect": "Hostiga al objetivo durante cuatro o cinco turnos e impide que pueda huir o ser cambiado por otro mientras tanto." - }, - "powerUpPunch": { - "name": "Puño Incremento", - "effect": "Cada vez que golpea a un oponente se endurecen sus puños. Si acierta al objetivo, el Ataque del usuario aumenta." - }, - "oblivionWing": { - "name": "Ala Mortífera", - "effect": "El usuario absorbe energía del objetivo y aumenta sus PS en una cantidad igual o superior a la mitad del daño infligido." - }, - "thousandArrows": { - "name": "Mil Flechas", - "effect": "Acierta incluso a Pokémon que estén en el aire y los hace caer al suelo." - }, - "thousandWaves": { - "name": "Mil Temblores", - "effect": "El usuario genera ondas sísmicas que se propagan por el suelo y sacuden al objetivo. Los Pokémon alcanzados no podrán huir del combate ni ser cambiados por otros." - }, - "landsWrath": { - "name": "Fuerza Telúrica", - "effect": "Acumula energía de la corteza terrestre y la concentra contra los oponentes, dañándolos." - }, - "lightOfRuin": { - "name": "Luz Aniquiladora", - "effect": "El usuario emplea el poder de la Flor Eterna para lanzar un potente rayo de luz, pero sufre bastante daño al hacerlo." - }, - "originPulse": { - "name": "Pulso Primigenio", - "effect": "Ataca al objetivo con una infinidad de rayos de luz azulada." - }, - "precipiceBlades": { - "name": "Filo del Abismo", - "effect": "Hace que el poder latente de la tierra se manifieste en forma de hojas afiladas y ataca al objetivo con ellas." - }, - "dragonAscent": { - "name": "Ascenso Draco", - "effect": "El usuario se precipita desde el cielo a una velocidad de vértigo para atacar al objetivo, pero hace que bajen la Defensa y la Defensa Especial del usuario." - }, - "hyperspaceFury": { - "name": "Cerco Dimensión", - "effect": "Ataca al objetivo con una ráfaga de golpes que pasan por alto los efectos de movimientos como Protección o Detección. Baja la Defensa del usuario." - }, - "breakneckBlitzPhysical": { - "name": "Carrera Arrolladora", - "effect": "El usuario emplea el Poder Z para coger carrerilla y arremeter contra el objetivo con gran fuerza. Su potencia depende de la del movimiento original." - }, - "breakneckBlitzSpecial": { - "name": "Carrera Arrolladora", - "effect": "Dummy data" - }, - "allOutPummelingPhysical": { - "name": "Ráfaga Demoledora", - "effect": "Emplea el Poder Z para lanzar una sarta de golpes demoledores contra el objetivo. Su potencia depende de la del movimiento original." - }, - "allOutPummelingSpecial": { - "name": "Ráfaga Demoledora", - "effect": "Dummy data" - }, - "supersonicSkystrikePhysical": { - "name": "Picado Supersónico", - "effect": "El usuario emplea el Poder Z para volar muy alto y abalanzarse en picado sobre el objetivo. Su potencia depende de la del movimiento original." - }, - "supersonicSkystrikeSpecial": { - "name": "Picado Supersónico", - "effect": "Dummy data" - }, - "acidDownpourPhysical": { - "name": "Diluvio Corrosivo", - "effect": "El usuario emplea el Poder Z para crear una ciénaga venenosa en la que sumerge al objetivo. Su potencia depende de la del movimiento original." - }, - "acidDownpourSpecial": { - "name": "Diluvio Corrosivo", - "effect": "Dummy data" - }, - "tectonicRagePhysical": { - "name": "Barrena Telúrica", - "effect": "Emplea el Poder Z para abrir una profunda grieta en el suelo que se traga al oponente. Su potencia depende de la del movimiento original." - }, - "tectonicRageSpecial": { - "name": "Barrena Telúrica", - "effect": "Dummy data" - }, - "continentalCrushPhysical": { - "name": "Aplastamiento Gigalítico", - "effect": "El usuario emplea el Poder Z para crear una montaña rocosa con la que aplasta al objetivo. Su potencia depende de la del movimiento original." - }, - "continentalCrushSpecial": { - "name": "Aplastamiento Gigalítico", - "effect": "Dummy data" - }, - "savageSpinOutPhysical": { - "name": "Guadaña Sedosa", - "effect": "Emplea el Poder Z para encerrar a su oponente en un capullo contra el que arremete con fuerza. Su potencia depende de la del movimiento original." - }, - "savageSpinOutSpecial": { - "name": "Guadaña Sedosa", - "effect": "Dummy data" - }, - "neverEndingNightmarePhysical": { - "name": "Presa Espectral", - "effect": "El usuario emplea el Poder Z para invocar a unos espectros encolerizados que apresan al objetivo. Su potencia depende de la del movimiento original." - }, - "neverEndingNightmareSpecial": { - "name": "Presa Espectral", - "effect": "Dummy data" - }, - "corkscrewCrashPhysical": { - "name": "Hélice Trepanadora", - "effect": "El usuario emplea el Poder Z para girar a toda velocidad y perforar al objetivo. Su potencia depende de la del movimiento original." - }, - "corkscrewCrashSpecial": { - "name": "Hélice Trepanadora", - "effect": "Dummy data" - }, - "infernoOverdrivePhysical": { - "name": "Hecatombe Pírica", - "effect": "El usuario emplea el Poder Z para lanzar una enorme llamarada con la que calcina a su objetivo. Su potencia depende de la del movimiento original." - }, - "infernoOverdriveSpecial": { - "name": "Hecatombe Pírica", - "effect": "Dummy data" - }, - "hydroVortexPhysical": { - "name": "Hidrovórtice Abisal", - "effect": "El usuario emplea el Poder Z para crear un potente torbellino de agua que engulle al objetivo. Su potencia depende de la del movimiento original." - }, - "hydroVortexSpecial": { - "name": "Hidrovórtice Abisal", - "effect": "Dummy data" - }, - "bloomDoomPhysical": { - "name": "Megatón Floral", - "effect": "Emplea el Poder Z para concentrar la energía de la vegetación que lo rodea y atacar al objetivo. Su potencia depende de la del movimiento original." - }, - "bloomDoomSpecial": { - "name": "Megatón Floral", - "effect": "Dummy data" - }, - "gigavoltHavocPhysical": { - "name": "Gigavoltio Destructor", - "effect": "El usuario emplea el Poder Z para generar una fuerte descarga eléctrica con la que electrocuta al objetivo. Su potencia depende de la del movimiento original." - }, - "gigavoltHavocSpecial": { - "name": "Gigavoltio Destructor", - "effect": "Dummy data" - }, - "shatteredPsychePhysical": { - "name": "Disruptor Psíquico", - "effect": "Emplea el Poder Z para manipular la mente del objetivo, infligiéndole un daño ingente. Su potencia depende de la del movimiento original." - }, - "shatteredPsycheSpecial": { - "name": "Disruptor Psíquico", - "effect": "Dummy data" - }, - "subzeroSlammerPhysical": { - "name": "Crioaliento Despiadado", - "effect": "Emplea el Poder Z para lanzar un rayo de hielo que baja la temperatura de golpe y congela al objetivo. Su potencia depende de la del movimiento original." - }, - "subzeroSlammerSpecial": { - "name": "Crioaliento Despiadado", - "effect": "Dummy data" - }, - "devastatingDrakePhysical": { - "name": "Dracoaliento Devastador", - "effect": "El usuario emplea el Poder Z para materializar su aura y golpear al objetivo. Su potencia depende de la del movimiento original." - }, - "devastatingDrakeSpecial": { - "name": "Dracoaliento Devastador", - "effect": "Dummy data" - }, - "blackHoleEclipsePhysical": { - "name": "Agujero Negro Aniquilador", - "effect": "El usuario emplea el Poder Z para generar un agujero negro que absorbe al objetivo. Su potencia depende de la del movimiento original." - }, - "blackHoleEclipseSpecial": { - "name": "Agujero Negro Aniquilador", - "effect": "Dummy data" - }, - "twinkleTacklePhysical": { - "name": "Arrumaco Sideral", - "effect": "El usuario emplea el Poder Z para crear una dimensión fascinante que deja al rival a su merced. Su potencia depende de la del movimiento original." - }, - "twinkleTackleSpecial": { - "name": "Arrumaco Sideral", - "effect": "Dummy data" - }, - "catastropika": { - "name": "Pikavoltio Letal", - "effect": "Pikachu emplea el Poder Z para acumular una gran cantidad de electricidad en su cuerpo y arremeter contra el objetivo." - }, - "shoreUp": { - "name": "Recogearena", - "effect": "Restaura la mitad de los PS máximos del usuario. Durante las tormentas de arena, restaura aún más PS." - }, - "firstImpression": { - "name": "Escaramuza", - "effect": "Movimiento de gran potencia que solo puede usarse en el turno en que el usuario sale al combate." - }, - "banefulBunker": { - "name": "Búnker", - "effect": "Protege de los ataques y, al mismo tiempo, envenena al Pokémon que use un movimiento de contacto contra el usuario." - }, - "spiritShackle": { - "name": "Puntada Sombría", - "effect": "Ataca al oponente y, al mismo tiempo, fija su sombra al terreno para impedir su huida." - }, - "darkestLariat": { - "name": "Lariat Oscuro", - "effect": "Gira sobre sí mismo y golpea al oponente con ambos brazos. Ignora los cambios en las características del objetivo." - }, - "sparklingAria": { - "name": "Aria Burbuja", - "effect": "Libera burbujas al cantar. Este movimiento cura las quemaduras de los Pokémon que reciban daño." - }, - "iceHammer": { - "name": "Martillo Hielo", - "effect": "Un terrible puño golpea al contrincante, pero la Velocidad del usuario se ve reducida." - }, - "floralHealing": { - "name": "Cura Floral", - "effect": "Restaura la mitad de los PS máximos del objetivo. Es más efectivo cuando se usa en conjunción con Campo de Hierba." - }, - "highHorsepower": { - "name": "Fuerza Equina", - "effect": "Asesta un golpe devastador usando todo su cuerpo." - }, - "strengthSap": { - "name": "Absorbefuerza", - "effect": "Restaura una cantidad de PS equivalente al valor de Ataque del rival, que además verá reducida esta característica." - }, - "solarBlade": { - "name": "Cuchilla Solar", - "effect": "El usuario dedica un turno a absorber energía lumínica y concentrarla en forma de cuchilla con la que ataca al rival en el siguiente turno." - }, - "leafage": { - "name": "Follaje", - "effect": "Ataca al objetivo lanzando hojas." - }, - "spotlight": { - "name": "Foco", - "effect": "Convierte a uno de los Pokémon que están combatiendo en el foco de atención, de modo que todos los ataques se dirijan hacia él." - }, - "toxicThread": { - "name": "Hilo Venenoso", - "effect": "Ataca al objetivo con hilillos venenosos que reducen su Velocidad y lo envenenan." - }, - "laserFocus": { - "name": "Aguzar", - "effect": "El usuario se concentra para que el siguiente ataque propine un golpe crítico." - }, - "gearUp": { - "name": "Piñón Auxiliar", - "effect": "Cambia de marcha y logra aumentar el Ataque y el Ataque Especial de los Pokémon aliados que cuenten con las habilidades Más y Menos." - }, - "throatChop": { - "name": "Golpe Mordaza", - "effect": "Inflige al rival un dolor tan abrumador que le impide utilizar durante dos turnos ataques que se sirven del sonido." - }, - "pollenPuff": { - "name": "Bola de Polen", - "effect": "Ataca al objetivo con una bola explosiva. Si esta alcanza a un aliado, le hará recuperar PS." - }, - "anchorShot": { - "name": "Anclaje", - "effect": "Ataca lanzando un ancla al objetivo, que queda atrapado y no puede huir ni ser cambiado por otro." - }, - "psychicTerrain": { - "name": "Campo Psíquico", - "effect": "Durante cinco turnos, se potencian los movimientos de tipo Psíquico y los Pokémon que están en el suelo quedan protegidos contra movimientos con prioridad." - }, - "lunge": { - "name": "Plancha", - "effect": "Ataca al objetivo abalanzándose sobre él con todas sus fuerzas y reduce su Ataque." - }, - "fireLash": { - "name": "Látigo Ígneo", - "effect": "Golpea al objetivo con un látigo incandescente y reduce su Defensa." - }, - "powerTrip": { - "name": "Chulería", - "effect": "Ataca al oponente presumiendo de su fuerza. Cuanto más hayan subido las características del usuario, mayor será el daño." - }, - "burnUp": { - "name": "Llama Final", - "effect": "Utiliza hasta el último resquicio de llamas de su cuerpo para infligir un grave daño al objetivo. Tras el ataque, el usuario deja de ser de tipo Fuego." - }, - "speedSwap": { - "name": "Cambiavelocidad", - "effect": "Intercambia su Velocidad por la del objetivo." - }, - "smartStrike": { - "name": "Cuerno Certero", - "effect": "El usuario ensarta al objetivo con su afilada cornamenta. No falla nunca." - }, - "purify": { - "name": "Purificación", - "effect": "Cura los problemas de estado del Pokémon rival y a cambio recupera PS propios." - }, - "revelationDance": { - "name": "Danza Despertar", - "effect": "Ataque que consiste en un baile muy enérgico. El tipo de este ataque se corresponde con el del Pokémon que lo ejecuta." - }, - "coreEnforcer": { - "name": "Núcleo Castigo", - "effect": "Inflige daño al rival, y si este ya ha hecho uso de algún movimiento, pierde su habilidad." - }, - "tropKick": { - "name": "Patada Tropical", - "effect": "Lanza una patada con la fuerza del trópico que golpea al objetivo y reduce su Ataque." - }, - "instruct": { - "name": "Mandato", - "effect": "Fuerza al objetivo a repetir inmediatamente su último movimiento." - }, - "beakBlast": { - "name": "Pico Cañón", - "effect": "Primero aumenta la temperatura de su pico y luego ejecuta un ataque. Quema al rival si este le propina un ataque físico mientras está calentando el pico." - }, - "clangingScales": { - "name": "Fragor Escamas", - "effect": "Frota todas las escamas de su cuerpo para crear un fuerte sonido con el que ataca. Cuando el ataque termina, su Defensa se ve reducida." - }, - "dragonHammer": { - "name": "Martillo Dragón", - "effect": "Usa el cuerpo como un martillo para abalanzarse sobre su rival y causarle daño." - }, - "brutalSwing": { - "name": "Giro Vil", - "effect": "Hace pivotar su cuerpo para causar daño a los Pokémon adyacentes." - }, - "auroraVeil": { - "name": "Velo Aurora", - "effect": "Reduce el daño de los ataques físicos y especiales durante cinco turnos. Solo puede usarse cuando está nevando." - }, - "sinisterArrowRaid": { - "name": "Aluvión de Flechas Sombrías", - "effect": "Decidueye usa el Poder Z para proyectar multitud de flechas potentísimas que atraviesan a su oponente." - }, - "maliciousMoonsault": { - "name": "Hiperplancha Oscura", - "effect": "Incineroar refuerza sus músculos con el Poder Z para golpear con todas sus fuerzas a su oponente." - }, - "oceanicOperetta": { - "name": "Sinfonía de la Diva Marina", - "effect": "Primarina invoca ingentes cantidades de agua con el Poder Z para atacar con gran potencia a su rival." - }, - "guardianOfAlola": { - "name": "Cólera del Guardián", - "effect": "Los Pokémon Dios Nativo canalizan la energía de Alola gracias al Poder Z y atacan con gran fuerza a sus rivales reduciendo un gran porcentaje de sus PS." - }, - "soulStealing7StarStrike": { - "name": "Constelación Robaalmas", - "effect": "Cuando Marshadow obtiene el Poder Z, lanza una potente y continua oleada de puñetazos y patadas con la que castiga a su rival." - }, - "stokedSparksurfer": { - "name": "Surfeo Galvánico", - "effect": "Cuando un Raichu de Alola obtiene el Poder Z, lanza un potente ataque contra su enemigo y lo deja paralizado." - }, - "pulverizingPancake": { - "name": "Arrojo Intempestivo", - "effect": "Gracias al Poder Z, Snorlax puede mover su enorme cuerpo con gran agilidad y determinación, cargando sobre el oponente con todas sus fuerzas." - }, - "extremeEvoboost": { - "name": "Novena Potencia", - "effect": "Cuando Eevee obtiene el Poder Z, toma prestada la energía de sus amigos evolucionados para potenciar enormemente sus características." - }, - "genesisSupernova": { - "name": "Supernova Original", - "effect": "Mew usa el Poder Z para realizar un potente ataque contra su adversario y crear un Campo Psíquico sobre el terreno." - }, - "shellTrap": { - "name": "Coraza Trampa", - "effect": "El caparazón del Pokémon se convierte en una trampa. Si lo alcanza un ataque físico, la trampa estalla y los rivales sufren daño." - }, - "fleurCannon": { - "name": "Cañón Floral", - "effect": "El usuario emite un potente rayo, pero su Ataque Especial se reduce mucho." - }, - "psychicFangs": { - "name": "Psicocolmillo", - "effect": "Ataca a sus rivales con poderes psíquicos que además destruyen barreras como Pantalla de Luz y Reflejo." - }, - "stompingTantrum": { - "name": "Pataleta", - "effect": "Usa la frustración como revulsivo para atacar. La potencia de Pataleta se duplica si el usuario ha fallado el último movimiento usado." - }, - "shadowBone": { - "name": "Hueso Sombrío", - "effect": "Ataca golpeando con un hueso poseído por un espíritu. Puede reducir la Defensa del objetivo." - }, - "accelerock": { - "name": "Roca Veloz", - "effect": "El usuario se lanza contra el objetivo a gran velocidad. Este movimiento tiene prioridad alta." - }, - "liquidation": { - "name": "Hidroariete", - "effect": "Ataca golpeando gracias a la fuerza del agua. También puede reducir la Defensa del objetivo." - }, - "prismaticLaser": { - "name": "Láser Prisma", - "effect": "El usuario utiliza un prisma para emitir un rayo de gran potencia, pero deberá descansar en el siguiente turno." - }, - "spectralThief": { - "name": "Robasombra", - "effect": "El usuario se esconde en la sombra del objetivo y lo ataca tras robarle las mejoras en sus características." - }, - "sunsteelStrike": { - "name": "Meteoimpacto", - "effect": "Ataca al objetivo con la potencia de un meteoro, ignorando su habilidad." - }, - "moongeistBeam": { - "name": "Rayo Umbrío", - "effect": "Ataca con un rayo misterioso que ignora la habilidad del objetivo." - }, - "tearfulLook": { - "name": "Ojos Llorosos", - "effect": "Mira al objetivo con ojos llorosos para hacerle perder su espíritu combativo y reduce su Ataque y Ataque Especial." - }, - "zingZap": { - "name": "Electropunzada", - "effect": "Se lanza contra el objetivo y le suelta una potente descarga eléctrica que puede hacer que se amedrente." - }, - "naturesMadness": { - "name": "Furia Natural", - "effect": "Golpea al objetivo con la furia de la naturaleza y reduce sus PS a la mitad." - }, - "multiAttack": { - "name": "Multiataque", - "effect": "El Pokémon se rodea de una potente energía con la que golpea al rival. El tipo del movimiento depende del disco que lleva el usuario." - }, - "tenMillionVoltThunderbolt": { - "name": "Gigarrayo Fulminante", - "effect": "Los Pikachu con gorra acumulan una carga eléctrica descomunal gracias al Poder Z y la lanzan contra el objetivo. Suele ser crítico." - }, - "mindBlown": { - "name": "Cabeza Sorpresa", - "effect": "El usuario hace explotar su cabeza para atacar a los Pokémon adyacentes, aunque también se hiere a sí mismo." - }, - "plasmaFists": { - "name": "Puños Plasma", - "effect": "El usuario ataca con puños cargados de electricidad. Convierte los movimientos de tipo Normal en movimientos de tipo Eléctrico." - }, - "photonGeyser": { - "name": "Géiser Fotónico", - "effect": "El usuario ataca con una gran columna de luz. Compara sus valores de Ataque y Ataque Especial para infligir daño con el más alto de los dos." - }, - "lightThatBurnsTheSky": { - "name": "Fotodestrucción Apocalíptica", - "effect": "Necrozma escoge la característica que tenga el valor más alto entre el Ataque y el Ataque Especial para infligir daño, ignorando la habilidad del objetivo." - }, - "searingSunrazeSmash": { - "name": "Embestida Solar", - "effect": "Solgaleo ataca con toda su fuerza tras imbuirse del Poder Z. Este movimiento ignora la habilidad del objetivo." - }, - "menacingMoonrazeMaelstrom": { - "name": "Deflagración Lunar", - "effect": "Lunala ataca con toda su fuerza tras imbuirse del Poder Z. Este movimiento ignora la habilidad del objetivo." - }, - "letsSnuggleForever": { - "name": "Somanta Amistosa", - "effect": "Mimikyu ataca con toda su fuerza tras imbuirse del Poder Z y asesta una lluvia de golpes." - }, - "splinteredStormshards": { - "name": "Tempestad Rocosa", - "effect": "Lycanroc ataca con toda su fuerza tras imbuirse del Poder Z y neutraliza el campo que esté activo." - }, - "clangorousSoulblaze": { - "name": "Estruendo Implacable", - "effect": "Kommo-o ataca con toda su fuerza al objetivo tras imbuirse del Poder Z. Además, potencia sus propias características." - }, - "zippyZap": { - "name": "Pikaturbo", - "effect": "The user attacks the target with bursts of electricity at high speed. This move always goes first and raises the user's evasiveness." - }, - "splishySplash": { - "name": "Salpikasurf", - "effect": "Golpea al adversario con una ola gigante electrificada, que también puede paralizarlo." - }, - "floatyFall": { - "name": "Pikapicado", - "effect": "El usuario se suspende en el aire para, a continuación, abalanzarse súbitamente sobre el rival. Puede hacer retroceder al objetivo." - }, - "pikaPapow": { - "name": "Pikatormenta", - "effect": "Lanza una descarga eléctrica infalible que resulta más potente cuanto mayor es el cariño que siente Pikachu hacia su Entrenador." - }, - "bouncyBubble": { - "name": "Vapodrenaje", - "effect": "Ataca lanzando proyectiles de agua y recupera una cantidad de PS equivalente a la del daño causado." - }, - "buzzyBuzz": { - "name": "Joltioparálisis", - "effect": "Lanza una potente descarga eléctrica sobre el rival y lo deja paralizado." - }, - "sizzlySlide": { - "name": "Flarembestida", - "effect": "Tras envolver su cuerpo en llamas, el usuario arrolla con fuerza al rival y le provoca quemaduras." - }, - "glitzyGlow": { - "name": "Espeaura", - "effect": "Envuelve al rival con ondas psíquicas y alza un extraño muro que debilita los ataques especiales del adversario." - }, - "baddyBad": { - "name": "Umbreozona", - "effect": "Lanza un ataque haciendo gala de su faceta más umbría y alza un extraño muro que mitiga los ataques físicos del adversario." - }, - "sappySeed": { - "name": "Leafitobombas", - "effect": "Hace brotar un tallo gigante que bombardea al rival con unas semillas que le drenan PS en cada turno." - }, - "freezyFrost": { - "name": "Glaceoprisma", - "effect": "Ataca al rival con negros cristales de niebla congelada. Revierte los cambios en las características de todos los Pokémon presentes." - }, - "sparklySwirl": { - "name": "Sylveotornado", - "effect": "Ataca al rival envolviéndolo en un remolino de aroma asfixiante. Cura a los aliados de cualquier problema de estado." - }, - "veeveeVolley": { - "name": "Eevimpacto", - "effect": "Un placaje infalible que resulta más potente cuanto mayor es el cariño que siente Eevee hacia su Entrenador." - }, - "doubleIronBash": { - "name": "Ferropuño Doble", - "effect": "Usando la tuerca del pecho como eje, gira sobre sí mismo y golpea con los brazos dos veces seguidas. Puede amedrentar al rival." - }, - "maxGuard": { - "name": "Maxibarrera", - "effect": "Frena todos los ataques, pero puede fallar si se usa repetidamente." - }, - "dynamaxCannon": { - "name": "Cañón Dinamax", - "effect": "El usuario ataca emitiendo un rayo desde su núcleo. Inflinge hasta el doble de daño si el objetivo tiene más niveles de lo normal." - }, - "snipeShot": { - "name": "Disparo Certero", - "effect": "Permite atacar al objetivo seleccionado ignorando las habilidades o movimientos que permiten a un Pokémon centrar la atención sobre sí." - }, - "jawLock": { - "name": "Presa Maxilar", - "effect": "Impide que tanto el atacante como el defensor puedan huir o ser cambiados por otros hasta que uno de ellos se debilite o abandone el terreno de combate." - }, - "stuffCheeks": { - "name": "Atiborramiento", - "effect": "El usuario ingiere la baya que lleva equipada para aumentar mucho su Defensa." - }, - "noRetreat": { - "name": "Bastión Final", - "effect": "El usuario aumenta todas sus características, pero ya no puede huir ni ser cambiado por otro." - }, - "tarShot": { - "name": "Alquitranazo", - "effect": "Cubre al objetivo de un alquitrán pegajoso que reduce su Velocidad y lo vuelve débil contra el fuego." - }, - "magicPowder": { - "name": "Polvo Mágico", - "effect": "Cubre al objetivo con unos polvos mágicos que le hacen adquirir el tipo Psíquico." - }, - "dragonDarts": { - "name": "Dracoflechas", - "effect": "El usuario ataca propulsando a ambos Dreepy. En caso de haber dos adversarios, cada Dreepy golpea a su propio objetivo por separado." - }, - "teatime": { - "name": "Hora del Té", - "effect": "El usuario invita a tomar el té a todos los presentes en el terreno de combate, lo que hace que ingieran las bayas que lleven equipadas." - }, - "octolock": { - "name": "Octopresa", - "effect": "Retiene al objetivo e impide que pueda huir o ser cambiado por otro, a la vez que reduce su Defensa y su Defensa Especial cada turno." - }, - "boltBeak": { - "name": "Electropico", - "effect": "El usuario ensarta al objetivo con su pico cargado de electricidad. Si ataca en primer lugar, la potencia del movimiento se duplica." - }, - "fishiousRend": { - "name": "Branquibocado", - "effect": "El usuario agarra al objetivo con sus duras branquias. En caso de atacar antes que este último, la potencia del movimiento se duplica." - }, - "courtChange": { - "name": "Cambio de Cancha", - "effect": "Extraño poder que intercambia los efectos en el terreno de combate de ambos bandos." - }, - "maxFlare": { - "name": "Maxignición", - "effect": "Ataque de tipo Fuego ejecutado por un Pokémon Dinamax. Hace que se intensifique el efecto del sol durante cinco turnos." - }, - "maxFlutterby": { - "name": "Maxinsecto", - "effect": "Ataque de tipo Bicho ejecutado por un Pokémon Dinamax. Reduce el Ataque Especial del objetivo." - }, - "maxLightning": { - "name": "Maxitormenta", - "effect": "Ataque de tipo Eléctrico ejecutado por un Pokémon Dinamax. Crea un campo eléctrico durante cinco turnos." - }, - "maxStrike": { - "name": "Maxiataque", - "effect": "Ataque de tipo Normal ejecutado por un Pokémon Dinamax. Reduce la Velocidad del objetivo." - }, - "maxKnuckle": { - "name": "Maxipuño", - "effect": "Ataque de tipo Lucha ejecutado por un Pokémon Dinamax. Aumenta el Ataque de tu bando." - }, - "maxPhantasm": { - "name": "Maxiespectro", - "effect": "Ataque de tipo Fantasma ejecutado por un Pokémon Dinamax. Reduce la Defensa del objetivo." - }, - "maxHailstorm": { - "name": "Maxihelada", - "effect": "Ataque de tipo Hielo ejecutado por un Pokémon Dinamax. Crea una tormenta de granizo que dura cinco turnos." - }, - "maxOoze": { - "name": "Maxiácido", - "effect": "Ataque de tipo Veneno ejecutado por un Pokémon Dinamax. Aumenta el Ataque Especial de tu bando." - }, - "maxGeyser": { - "name": "Maxichorro", - "effect": "Ataque de tipo Agua ejecutado por un Pokémon Dinamax. Desata un aguacero que dura cinco turnos." - }, - "maxAirstream": { - "name": "Maxiciclón", - "effect": "Ataque de tipo Volador ejecutado por un Pokémon Dinamax. Aumenta la Velocidad de tu bando." - }, - "maxStarfall": { - "name": "Maxiestela", - "effect": "Ataque de tipo Hada ejecutado por un Pokémon Dinamax. Crea un campo de niebla durante cinco turnos." - }, - "maxWyrmwind": { - "name": "Maxidraco", - "effect": "Ataque de tipo Dragón ejecutado por un Pokémon Dinamax. Reduce el Ataque del objetivo." - }, - "maxMindstorm": { - "name": "Maxionda", - "effect": "Ataque de tipo Psíquico ejecutado por un Pokémon Dinamax. Crea un campo psíquico durante cinco turnos." - }, - "maxRockfall": { - "name": "Maxilito", - "effect": "Ataque de tipo Roca ejecutado por un Pokémon Dinamax. Levanta una tormenta de arena que dura cinco turnos." - }, - "maxQuake": { - "name": "Maxitemblor", - "effect": "Ataque de tipo Tierra ejecutado por un Pokémon Dinamax. Aumenta la Defensa Especial de tu bando." - }, - "maxDarkness": { - "name": "Maxisombra", - "effect": "Ataque de tipo Siniestro ejecutado por un Pokémon Dinamax. Reduce la Defensa Especial del objetivo." - }, - "maxOvergrowth": { - "name": "Maxiflora", - "effect": "Ataque de tipo Planta ejecutado por un Pokémon Dinamax. Crea un campo de hierba durante cinco turnos." - }, - "maxSteelspike": { - "name": "Maximetal", - "effect": "Ataque de tipo Acero ejecutado por un Pokémon Dinamax. Aumenta la Defensa de tu bando." - }, - "clangorousSoul": { - "name": "Estruendo Escama", - "effect": "Utiliza parte de los PS propios para subir sus características." - }, - "bodyPress": { - "name": "Plancha Corporal", - "effect": "El usuario usa el cuerpo para lanzar su ataque e infligir un daño directamente proporcional a su Defensa." - }, - "decorate": { - "name": "Decoración", - "effect": "Aumenta mucho el Ataque y el Ataque Especial del objetivo al decorarlo." - }, - "drumBeating": { - "name": "Batería Asalto", - "effect": "El usuario controla un tocón mediante la percusión y al atacar reduce la Velocidad del objetivo." - }, - "snapTrap": { - "name": "Cepo", - "effect": "Cepo que atrapa al objetivo durante cuatro o cinco turnos y le causa daño mientras se encuentra preso." - }, - "pyroBall": { - "name": "Balón Ígneo", - "effect": "El usuario prende una pequeña piedra para crear una bola de fuego con la que ataca al objetivo. Puede causar quemaduras." - }, - "behemothBlade": { - "name": "Tajo Supremo", - "effect": "El usuario se convierte en una espada gigante para rebanar con vigor al objetivo." - }, - "behemothBash": { - "name": "Embate Supremo", - "effect": "El usuario se convierte en un escudo gigante para golpear con vigor al objetivo." - }, - "auraWheel": { - "name": "Rueda Aural", - "effect": "La energía que acumula en las mejillas le sirve para atacar y aumentar su Velocidad. Este movimiento cambia de tipo según la forma que adopte Morpeko." - }, - "breakingSwipe": { - "name": "Vasto Impacto", - "effect": "El usuario sacude violentamente su enorme cola para golpear al objetivo y reducir su Ataque a la par." - }, - "branchPoke": { - "name": "Punzada Rama", - "effect": "Ataca pinchando al objetivo con una rama afilada." - }, - "overdrive": { - "name": "Amplificador", - "effect": "El usuario rasguea la guitarra o el bajo para generar enormes vibraciones de intensa reverberación con las que ataca al objetivo." - }, - "appleAcid": { - "name": "Ácido Málico", - "effect": "Ataca al objetivo con el fluido corrosivo que desprende una manzana ácida, lo que también reduce la Defensa Especial de este." - }, - "gravApple": { - "name": "Fuerza G", - "effect": "El usuario ataca haciendo caer una manzana desde gran altura. Reduce la Defensa del objetivo." - }, - "spiritBreak": { - "name": "Choque Anímico", - "effect": "El usuario ataca al objetivo con tal ímpetu que acaba minando su moral y, en consecuencia, reduce su Ataque Especial." - }, - "strangeSteam": { - "name": "Cautivapor", - "effect": "Desprende un humo con el que ataca al objetivo, que puede acabar confundido." - }, - "lifeDew": { - "name": "Gota Vital", - "effect": "Vierte un agua misteriosa y balsámica que restaura tanto sus propios PS como los de aquellos aliados presentes en el terreno de combate." - }, - "obstruct": { - "name": "Obstrucción", - "effect": "Frena todos los ataques, pero puede fallar si se usa repetidamente. Reduce mucho la Defensa de quien ejecute un movimiento de contacto contra el usuario." - }, - "falseSurrender": { - "name": "Irreverencia", - "effect": "El usuario finge hacer una reverencia y aprovecha la ocasión para ensartar al objetivo con su cabello alborotado. No falla nunca." - }, - "meteorAssault": { - "name": "Asalto Estelar", - "effect": "El usuario agita violentamente su grueso puerro para atacar, pero el mareo que le provocan las sacudidas le obliga a descansar en el siguiente turno." - }, - "eternabeam": { - "name": "Rayo Infinito", - "effect": "Este es el mayor ataque de Eternatus una vez adquirida su forma original. No puede moverse en el turno siguiente." - }, - "steelBeam": { - "name": "Metaláser", - "effect": "Utiliza el acero de su cuerpo para disparar un potente rayo. El usuario se hiere a sí mismo." - }, - "expandingForce": { - "name": "Vasta Fuerza", - "effect": "El usuario ataca al objetivo con sus poderes psíquicos. Cuando se usa en conjunción con un campo psíquico, aumenta su potencia e inflige daño a todos los rivales." - }, - "steelRoller": { - "name": "Allanador Férreo", - "effect": "El usuario lanza su ataque y destruye el campo activo en el terreno de combate, y falla si no hay ninguno en ese momento." - }, - "scaleShot": { - "name": "Ráfaga Escamas", - "effect": "Lanza escamas al objetivo de dos a cinco veces seguidas. Aumenta la Velocidad del usuario, pero reduce su Defensa." - }, - "meteorBeam": { - "name": "Rayo Meteórico", - "effect": "El usuario dedica el primer turno a aumentar su Ataque Especial acumulando energía cósmica y lanza su ofensiva contra el objetivo en el segundo." - }, - "shellSideArm": { - "name": "Moluscañón", - "effect": "El usuario lanza un ataque físico o especial en función de cuál inflija más daño. Puede envenenar al objetivo." - }, - "mistyExplosion": { - "name": "Bruma Explosiva", - "effect": "El usuario ataca a todos a su alrededor, pero se debilita de inmediato. La potencia del movimiento aumenta si el terreno está cubierto por un campo de niebla." - }, - "grassyGlide": { - "name": "Fitoimpulso", - "effect": "Ataca al objetivo deslizándose sobre el terreno de combate. Este movimiento tiene prioridad alta cuando el terreno está cubierto por un campo de hierba." - }, - "risingVoltage": { - "name": "Alto Voltaje", - "effect": "Ataca con una descarga eléctrica que surge del terreno de combate. La potencia del movimiento se duplica si el rival se ve afectado por un campo eléctrico." - }, - "terrainPulse": { - "name": "Pulso de Campo", - "effect": "El usuario ataca aprovechando la energía del campo activo, que determina tanto el tipo como la potencia del movimiento." - }, - "skitterSmack": { - "name": "Golpe Rastrero", - "effect": "Ataca al objetivo por la espalda de forma subrepticia y, además, reduce su Ataque Especial." - }, - "burningJealousy": { - "name": "Envidia Ardiente", - "effect": "Ataca al objetivo con la energía generada por la envidia y causa quemaduras a los Pokémon cuyas características hayan aumentado en ese turno." - }, - "lashOut": { - "name": "Desahogo", - "effect": "Ataca al rival presa de la rabia. Si el usuario ha sufrido una reducción de características en ese turno, la potencia del movimiento se duplica." - }, - "poltergeist": { - "name": "Poltergeist", - "effect": "El usuario ataca utilizando el objeto que lleva el rival. Si no tiene ninguno equipado, el movimiento falla." - }, - "corrosiveGas": { - "name": "Gas Corrosivo", - "effect": "El usuario libera un gas cáustico que envuelve a todos los que se encuentren alrededor y derrite por completo los objetos que lleven equipados." - }, - "coaching": { - "name": "Motivación", - "effect": "El usuario imparte indicaciones precisas a sus aliados, que ven aumentados su Ataque y su Defensa." - }, - "flipTurn": { - "name": "Viraje", - "effect": "Tras atacar, el usuario da paso a toda prisa a otro Pokémon del equipo." - }, - "tripleAxel": { - "name": "Triple Axel", - "effect": "Propina hasta tres patadas seguidas, la potencia de las cuales aumenta cada vez que acierta." - }, - "dualWingbeat": { - "name": "Ala Bis", - "effect": "Ataca al adversario golpeándolo dos veces con las alas." - }, - "scorchingSands": { - "name": "Arenas Ardientes", - "effect": "Ataca al objetivo arrojándole arena a temperaturas muy elevadas. Puede causar quemaduras." - }, - "jungleHealing": { - "name": "Cura Selvática", - "effect": "Al entrar en plena armonía con la selva, el usuario cura problemas de estado y restaura PS no solo de sí mismo, sino también de los aliados presentes en el terreno." - }, - "wickedBlow": { - "name": "Golpe Oscuro", - "effect": "Golpe devastador que requiere un absoluto dominio de las artes siniestras. Siempre asesta un golpe crítico." - }, - "surgingStrikes": { - "name": "Azote Torrencial", - "effect": "El usuario, dominador absoluto del líquido elemento, golpea hasta tres veces con movimientos fluidos. Siempre asesta un golpe crítico." - }, - "thunderCage": { - "name": "Electrojaula", - "effect": "El objetivo queda atrapado en una jaula electrificada que permanece en el terreno de cuatro a cinco turnos." - }, - "dragonEnergy": { - "name": "Dracoenergía", - "effect": "El usuario convierte su fuerza vital en una energía con la que ataca al objetivo. Cuantos menos PS tenga el usuario, menor será la potencia del movimiento." - }, - "freezingGlare": { - "name": "Mirada Heladora", - "effect": "A través de sus ojos emite poderes psíquicos con los que ataca al objetivo, al que puede llegar a congelar." - }, - "fieryWrath": { - "name": "Furia Candente", - "effect": "El usuario convierte su ira en un aura flamígera para lanzar su ataque. Puede amedrentar al objetivo." - }, - "thunderousKick": { - "name": "Patada Relámpago", - "effect": "El usuario desconcierta al objetivo con movimientos centelleantes y le propina una patada que, además, reduce su Defensa." - }, - "glacialLance": { - "name": "Lanza Glacial", - "effect": "El usuario ataca al objetivo lanzándole un carámbano de hielo envuelto en una ventisca." - }, - "astralBarrage": { - "name": "Orbes Espectro", - "effect": "El usuario ataca al objetivo lanzándole una ingente cantidad de pequeños fantasmas." - }, - "eerieSpell": { - "name": "Conjuro Funesto", - "effect": "El usuario ataca con un poder psíquico de inmensa potencia y elimina 3 PP del último movimiento que haya usado el objetivo." - }, - "direClaw": { - "name": "Garra Nociva", - "effect": "Ataca al objetivo con unas garras letales que pueden envenenarlo, paralizarlo o dormirlo." - }, - "psyshieldBash": { - "name": "Asalto Barrera", - "effect": "El usuario ataca envuelto en una energía psíquica que además aumenta su Defensa." - }, - "powerShift": { - "name": "Cambiapoder", - "effect": "Intercambia su Ataque por su Defensa." - }, - "stoneAxe": { - "name": "Hachazo Pétreo", - "effect": "Ataca con un hacha de piedra y, al hacerlo, se desprenden fragmentos que rodean al objetivo." - }, - "springtideStorm": { - "name": "Ciclón Primavera", - "effect": "Desata una tormenta de amor y odio con la que envuelve y ataca al objetivo. También puede reducir su Ataque." - }, - "mysticalPower": { - "name": "Poder Místico", - "effect": "Ataca desatando un misterioso poder, que también aumenta su Ataque Especial." - }, - "ragingFury": { - "name": "Erupción de Ira", - "effect": "El usuario ataca con unas violentas llamas de dos a tres turnos seguidos y, después, se queda confuso." - }, - "waveCrash": { - "name": "Envite Acuático", - "effect": "El usuario se envuelve en agua y embiste contra el objetivo, pero también se hiere seriamente a sí mismo." - }, - "chloroblast": { - "name": "Clorofiláser", - "effect": "El usuario concentra clorofila y la dispara en forma de rayo, pero también se hiere a sí mismo." - }, - "mountainGale": { - "name": "Viento Carámbano", - "effect": "Ataca con unos carámbanos grandes como icebergs que pueden amedrentar al objetivo." - }, - "victoryDance": { - "name": "Danza Triunfal", - "effect": "Ejecuta una danza frenética que invoca la victoria y aumenta el Ataque, la Defensa y la Velocidad." - }, - "headlongRush": { - "name": "Arremetida", - "effect": "El usuario arremete con todas sus fuerzas, pero se reducen su Defensa y su Defensa Especial." - }, - "barbBarrage": { - "name": "Mil Púas Tóxicas", - "effect": "Dispara un sinfín de púas tóxicas que pueden envenenar al objetivo. La potencia del movimiento se duplica si este ya está envenenado." - }, - "esperWing": { - "name": "Ala Aural", - "effect": "Corta con unas alas imbuidas de aura. Suele asestar un golpe crítico y aumenta la Velocidad del usuario." - }, - "bitterMalice": { - "name": "Rencor Reprimido", - "effect": "Ataca al objetivo sometiéndolo a su frío rencor y reduce su Ataque." - }, - "shelter": { - "name": "Retracción", - "effect": "La piel del usuario se vuelve dura como un escudo de acero, lo que aumenta mucho su Defensa." - }, - "tripleArrows": { - "name": "Triple Flecha", - "effect": "Propina un talonazo y lanza tres flechas. Suele asestar un golpe crítico y puede reducir la Defensa del objetivo o amedrentarlo." - }, - "infernalParade": { - "name": "Marcha Espectral", - "effect": "Lanza innumerables bolas de fuego al objetivo que pueden causar quemaduras. La potencia del movimiento se duplica si este ya sufre un problema de estado." - }, - "ceaselessEdge": { - "name": "Tajo Metralla", - "effect": "Ataca con una espada de conchas y, al hacerlo, se esparcen fragmentos a modo de metralla a los pies del objetivo." - }, - "bleakwindStorm": { - "name": "Vendaval Gélido", - "effect": "Ataca con un viento muy frío que estremece el cuerpo y la mente y que, además, puede reducir la Velocidad del objetivo." - }, - "wildboltStorm": { - "name": "Electormenta", - "effect": "Invoca una tormenta eléctrica que ataca al objetivo con fuertes vientos y relámpagos y puede paralizarlo." - }, - "sandsearStorm": { - "name": "Simún de Arena", - "effect": "Ataca al objetivo envolviéndolo en unas arenas tórridas y un fuerte vendaval que pueden causar quemaduras." - }, - "lunarBlessing": { - "name": "Plegaria Lunar", - "effect": "Dedica una oración a la luna creciente que restaura los PS y cura los problemas de estado del bando del usuario." - }, - "takeHeart": { - "name": "Bálsamo Osado", - "effect": "El usuario se envalentona y se cura de los problemas de estado. Además, aumenta su Ataque Especial y su Defensa Especial." - }, - "gMaxWildfire": { - "name": "Gigallamarada", - "effect": "Ataque de tipo Fuego ejecutado por un Charizard Gigamax. Inflige daño durante cuatro turnos." - }, - "gMaxBefuddle": { - "name": "Gigaestupor", - "effect": "Ataque de tipo Bicho ejecutado por un Butterfree Gigamax. Envenena, paraliza o duerme al objetivo." - }, - "gMaxVoltCrash": { - "name": "Gigatronada", - "effect": "Ataque de tipo Eléctrico ejecutado por un Pikachu Gigamax. Paraliza al objetivo." - }, - "gMaxGoldRush": { - "name": "Gigamonedas", - "effect": "Ataque de tipo Normal ejecutado por un Meowth Gigamax. Confunde al objetivo y aumenta la recompensa recibida tras el combate." - }, - "gMaxChiStrike": { - "name": "Gigapuñición", - "effect": "Ataque de tipo Lucha ejecutado por un Machamp Gigamax. Aumenta las posibilidades de que el usuario y sus aliados asesten un golpe crítico." - }, - "gMaxTerror": { - "name": "Gigaaparición", - "effect": "Ataque de tipo Fantasma ejecutado por un Gengar Gigamax. Impide que el objetivo sea cambiado por otro." - }, - "gMaxResonance": { - "name": "Gigamelodía", - "effect": "Ataque de tipo Hielo ejecutado por un Lapras Gigamax. Reduce el daño recibido durante cinco turnos." - }, - "gMaxCuddle": { - "name": "Gigaternura", - "effect": "Ataque de tipo Normal ejecutado por un Eevee Gigamax. Hace que el objetivo se enamore." - }, - "gMaxReplenish": { - "name": "Gigarreciclaje", - "effect": "Ataque de tipo Normal ejecutado por un Snorlax Gigamax. Restaura las bayas que se hayan consumido." - }, - "gMaxMalodor": { - "name": "Gigapestilencia", - "effect": "Ataque de tipo Veneno ejecutado por un Garbodor Gigamax. Envenena al objetivo." - }, - "gMaxStonesurge": { - "name": "Gigatrampa Rocas", - "effect": "Ataque de tipo Agua ejecutado por un Drednaw Gigamax. Esparce rocas afiladas por el terreno de combate." - }, - "gMaxWindRage": { - "name": "Gigahuracán", - "effect": "Ataque de tipo Volador ejecutado por un Corviknight Gigamax. Es capaz de destruir barreras como las creadas por Pantalla de Luz y Reflejo." - }, - "gMaxStunShock": { - "name": "Gigadescarga", - "effect": "Ataque de tipo Eléctrico ejecutado por un Toxtricity Gigamax. Envenena o paraliza al objetivo." - }, - "gMaxFinale": { - "name": "Gigacolofón", - "effect": "Ataque de tipo Hada ejecutado por un Alcremie Gigamax. Restaura los PS de tu bando." - }, - "gMaxDepletion": { - "name": "Gigadesgaste", - "effect": "Ataque de tipo Dragón ejecutado por un Duraludon Gigamax. Reduce PP del último movimiento usado por el objetivo." - }, - "gMaxGravitas": { - "name": "Gigabóveda", - "effect": "Ataque de tipo Psíquico ejecutado por un Orbeetle Gigamax. Intensifica la fuerza de gravedad durante cinco turnos." - }, - "gMaxVolcalith": { - "name": "Gigarroca Ígnea", - "effect": "Ataque de tipo Roca ejecutado por un Coalossal Gigamax. Inflige daño durante cuatro turnos." - }, - "gMaxSandblast": { - "name": "Gigapolvareda", - "effect": "Ataque de tipo Tierra ejecutado por un Sandaconda Gigamax. Enreda al objetivo en un remolino de arena de cuatro a cinco turnos." - }, - "gMaxSnooze": { - "name": "Gigasopor", - "effect": "Ataque de tipo Siniestro ejecutado por un Grimmsnarl Gigamax. Induce al sueño al objetivo en el siguiente turno." - }, - "gMaxTartness": { - "name": "Gigacorrosión", - "effect": "Ataque de tipo Planta ejecutado por un Flapple Gigamax. Reduce la Evasión del objetivo." - }, - "gMaxSweetness": { - "name": "Giganéctar", - "effect": "Ataque de tipo Planta ejecutado por un Appletun Gigamax. Cura los problemas de estado de tu bando." - }, - "gMaxSmite": { - "name": "Gigacastigo", - "effect": "Ataque de tipo Hada ejecutado por un Hatterene Gigamax. Confunde al objetivo." - }, - "gMaxSteelsurge": { - "name": "Gigatrampa Acero", - "effect": "Ataque de tipo Acero ejecutado por un Copperajah Gigamax. Esparce púas de acero por el terreno de combate." - }, - "gMaxMeltdown": { - "name": "Gigafundido", - "effect": "Ataque de tipo Acero ejecutado por un Melmetal Gigamax. Impide al objetivo usar el mismo movimiento dos veces seguidas." - }, - "gMaxFoamBurst": { - "name": "Gigaespuma", - "effect": "Ataque de tipo Agua ejecutado por un Kingler Gigamax. Reduce mucho la Velocidad del objetivo." - }, - "gMaxCentiferno": { - "name": "Gigacienfuegos", - "effect": "Ataque de tipo Fuego ejecutado por un Centiskorch Gigamax. Un aro de fuego atrapa al objetivo de cuatro a cinco turnos." - }, - "gMaxVineLash": { - "name": "Gigalianas", - "effect": "Ataque de tipo Planta ejecutado por un Venusaur Gigamax. Inflige daño durante cuatro turnos." - }, - "gMaxCannonade": { - "name": "Gigacañonazo", - "effect": "Ataque de tipo Agua ejecutado por un Blastoise Gigamax. Inflige daño durante cuatro turnos." - }, - "gMaxDrumSolo": { - "name": "Gigarredoble", - "effect": "Ataque de tipo Planta ejecutado por un Rillaboom Gigamax. Ignora la habilidad del objetivo." - }, - "gMaxFireball": { - "name": "Gigaesfera Ígnea", - "effect": "Ataque de tipo Fuego ejecutado por un Cinderace Gigamax. Ignora la habilidad del objetivo." - }, - "gMaxHydrosnipe": { - "name": "Gigadisparo", - "effect": "Ataque de tipo Agua ejecutado por un Inteleon Gigamax. Ignora la habilidad del objetivo." - }, - "gMaxOneBlow": { - "name": "Gigagolpe Brusco", - "effect": "Ataque de tipo Siniestro ejecutado por un Urshifu Gigamax. Propina un único golpe que acierta al objetivo aunque haya usado Maxibarrera." - }, - "gMaxRapidFlow": { - "name": "Gigagolpe Fluido", - "effect": "Ataque de tipo Agua ejecutado por un Urshifu Gigamax. Propina golpes sucesivos que aciertan al objetivo aunque haya usado Maxibarrera." - }, - "teraBlast": { - "name": "Teraexplosión", - "effect": "Si el usuario se ha teracristalizado, ataca con la energía de su teratipo. Compara sus valores de Ataque y Ataque Especial para infligir daño con el más alto de los dos." - }, - "silkTrap": { - "name": "Telatrampa", - "effect": "Tiende una trampa sedosa que protege al usuario de los ataques al tiempo que reduce la Velocidad de cualquier Pokémon con el que entre en contacto." - }, - "axeKick": { - "name": "Patada Hacha", - "effect": "Lanza una patada al aire para, acto seguido, golpear con el talón. Si falla, se hiere a sí mismo. Puede confundir al objetivo." - }, - "lastRespects": { - "name": "Homenaje Póstumo", - "effect": "Ataca para vengar a sus compañeros caídos y aplacar su desazón. Cuantos más miembros del equipo se hayan debilitado, mayor será la potencia del movimiento." - }, - "luminaCrash": { - "name": "Fotocolisión", - "effect": "Ataca proyectando una extraña luz que afecta a la mente. Reduce mucho la Defensa Especial del objetivo." - }, - "orderUp": { - "name": "Oído Cocina", - "effect": "Ataca con porte gallardo. Si lleva un Tatsugiri en la boca, aumenta una de sus características en función de la forma de este último." - }, - "jetPunch": { - "name": "Puño Jet", - "effect": "Se envuelve el puño con un torrente y propina un golpe a tal velocidad que resulta casi imperceptible. Este movimiento tiene prioridad alta." - }, - "spicyExtract": { - "name": "Extracto Picante", - "effect": "Libera un extracto extraordinariamente picante que aumenta mucho el Ataque del objetivo, pero también reduce mucho su Defensa." - }, - "spinOut": { - "name": "Quemarrueda", - "effect": "Inflige daño al objetivo ejerciendo presión sobre sus extremidades y girando violentamente sobre sí. Reduce mucho la Velocidad del usuario." - }, - "populationBomb": { - "name": "Proliferación", - "effect": "Los congéneres del usuario se agrupan y ejecutan un ataque conjunto que golpea al objetivo de una a diez veces seguidas." - }, - "iceSpinner": { - "name": "Pirueta Helada", - "effect": "Se recubre las extremidades con una fina capa de hielo y se abalanza sobre el objetivo girando sobre sí. Destruye el campo activo en el terreno de combate." - }, - "glaiveRush": { - "name": "Asalto Espadón", - "effect": "Embiste de forma temeraria con todo el cuerpo. Los ataques que reciba antes de su siguiente turno no fallarán y causarán el doble de daño." - }, - "revivalBlessing": { - "name": "Plegaria Vital", - "effect": "Pronuncia una benévola oración que revive a un Pokémon del equipo que se haya debilitado y restaura la mitad de sus PS máximos." - }, - "saltCure": { - "name": "Salazón", - "effect": "Deja en salazón al objetivo, que pierde PS cada turno. Afecta especialmente a Pokémon de tipo Acero y tipo Agua." - }, - "tripleDive": { - "name": "Triple Inmersión", - "effect": "Ejecuta una inmersión triple en perfecta sincronía que golpea al objetivo con salpicaduras de agua tres veces seguidas." - }, - "mortalSpin": { - "name": "Giro Mortífero", - "effect": "Ataque giratorio que envenena al objetivo y anula los efectos de movimientos como Atadura, Constricción y Drenadoras." - }, - "doodle": { - "name": "Decalcomanía", - "effect": "Calca la esencia misma del objetivo para atribuir su habilidad a sí mismo y a sus aliados." - }, - "filletAway": { - "name": "Deslome", - "effect": "Aumenta mucho el Ataque, el Ataque Especial y la Velocidad del usuario a costa de parte de sus PS." - }, - "kowtowCleave": { - "name": "Genufendiente", - "effect": "Se postra en ademán de reverencia para hacer que el objetivo baje la guardia y aprovecha el descuido para atacar. No falla nunca." - }, - "flowerTrick": { - "name": "Truco Floral", - "effect": "Ataca al objetivo lanzándole un ramo de flores trucado. No falla nunca y siempre asesta un golpe crítico." - }, - "torchSong": { - "name": "Canto Ardiente", - "effect": "Expele tórridas llamaradas como si entonara una canción y abrasa al objetivo con ellas. Aumenta el Ataque Especial del usuario." - }, - "aquaStep": { - "name": "Danza Acuática", - "effect": "Juguetea con el objetivo mientras ejecuta una elegante y fluida danza y le inflige daño. Aumenta la Velocidad del usuario." - }, - "ragingBull": { - "name": "Furia Taurina", - "effect": "Embiste con tremenda fiereza. Este movimiento cambia de tipo en función de la variedad del usuario y es capaz de destruir barreras como Pantalla de Luz y Reflejo." - }, - "makeItRain": { - "name": "Fiebre Dorada", - "effect": "El usuario ataca arrojando una generosa cantidad de monedas, pero su Ataque Especial se ve reducido. Al finalizar el combate, las recupera en forma de ganancias." - }, - "psyblade": { - "name": "Psicohojas", - "effect": "El usuario rebana al objetivo con una espada inmaterial. Cuando se usa en conjunción con un campo eléctrico, la potencia del movimiento aumenta un 50 %." - }, - "hydroSteam": { - "name": "Hidrovapor", - "effect": "Vierte agua hirviendo sobre el objetivo. Cuando hace sol, la potencia del movimiento aumenta un 50 % en lugar de reducirse." - }, - "ruination": { - "name": "Calamidad", - "effect": "Provoca una catástrofe devastadora que reduce a la mitad los PS del objetivo." - }, - "collisionCourse": { - "name": "Nitrochoque", - "effect": "El usuario choca contra el suelo mientras se transforma y provoca una explosión primigenia. La potencia del movimiento aumenta si el ataque es supereficaz." - }, - "electroDrift": { - "name": "Electroderrape", - "effect": "Se abalanza sobre el objetivo mientras se transforma y lo atraviesa con electricidad futurista. La potencia del movimiento aumenta si el ataque es supereficaz." - }, - "shedTail": { - "name": "Autotomía", - "effect": "El usuario se cambia por otro Pokémon del equipo, pero antes utiliza parte de los PS propios para crear un sustituto para su relevo." - }, - "chillyReception": { - "name": "Fría Acogida", - "effect": "El usuario se cambia por otro Pokémon del equipo, pero antes cuenta un chiste que tiene una acogida tan fría que hace que nieve durante cinco turnos." - }, - "tidyUp": { - "name": "Limpieza General", - "effect": "Efectúa una limpieza a fondo que anula los efectos de Púas, Trampa Rocas, Red Viscosa, Púas Tóxicas y Sustituto. Aumenta el Ataque y la Velocidad del usuario." - }, - "snowscape": { - "name": "Paisaje Nevado", - "effect": "Desata una nevada que dura cinco turnos y aumenta la Defensa de los Pokémon de tipo Hielo." - }, - "pounce": { - "name": "Brinco", - "effect": "Ataca abalanzándose sobre el objetivo y le reduce la Velocidad." - }, - "trailblaze": { - "name": "Abrecaminos", - "effect": "Ataca de pronto como si saltara desde la hierba alta. El usuario se mueve con gran agilidad y aumenta su Velocidad." - }, - "chillingWater": { - "name": "Agua Fría", - "effect": "Ataca al objetivo rociándolo con un agua gélida y desalentadora que reduce su Ataque." - }, - "hyperDrill": { - "name": "Hipertaladro", - "effect": "El usuario hace rotar la parte puntiaguda de su cuerpo a gran velocidad para atacar al objetivo. Pasa por alto los efectos de movimientos como Protección o Detección." - }, - "twinBeam": { - "name": "Láser Doble", - "effect": "Ataca emitiendo dos misteriosos haces lumínicos por los ojos que infligen daño dos veces seguidas." - }, - "rageFist": { - "name": "Puño Furia", - "effect": "Convierte su rabia en energía para atacar. Cuantos más golpes haya recibido el usuario, mayor será la potencia del movimiento." - }, - "armorCannon": { - "name": "Cañón Armadura", - "effect": "Se deshace de su armadura y arroja las partes al objetivo cuales proyectiles ardientes. Reduce la Defensa y la Defensa Especial del usuario." - }, - "bitterBlade": { - "name": "Espada Lamento", - "effect": "Imbuye la punta de su espada con su desazón por el mundo y asesta una estocada llena de rencor. El usuario recupera la mitad de los PS del daño que produce." - }, - "doubleShock": { - "name": "Electropalmas", - "effect": "Libera toda la electricidad de su cuerpo para lanzar un ataque devastador. Tras ejecutar el movimiento, el usuario deja de ser de tipo Eléctrico." - }, - "gigatonHammer": { - "name": "Martillo Colosal", - "effect": "El usuario se ayuda de su propio peso corporal para propinar un golpe con un enorme martillo. Este movimiento no puede usarse dos veces seguidas." - }, - "comeuppance": { - "name": "Resarcimiento", - "effect": "Devuelve al rival el último ataque recibido, pero con mucha más fuerza." - }, - "aquaCutter": { - "name": "Tajo Acuático", - "effect": "Expele agua a presión con la que corta al objetivo como si de una hoja se tratara. Suele asestar un golpe crítico." - }, - "blazingTorque": { - "name": "Pirochoque", - "effect": "The user revs their blazing engine into the target. This may also leave the target with a burn." - }, - "wickedTorque": { - "name": "Ominochoque", - "effect": "The user revs their engine into the target with malicious intent. This may put the target to sleep." - }, - "noxiousTorque": { - "name": "Ponzochoque", - "effect": "The user revs their poisonous engine into the target. This may also poison the target." - }, - "combatTorque": { - "name": "Pugnachoque", - "effect": "The user revs their engine forcefully into the target. This may also leave the target with paralysis." - }, - "magicalTorque": { - "name": "Feerichoque", - "effect": "The user revs their fae-like engine into the target. This may also confuse the target." - }, - "bloodMoon": { - "name": "Luna Roja", - "effect": "Ataca canalizando toda su fuerza y proyectándola a través de una luna llena de color rojo intenso. Este movimiento no puede usarse dos veces seguidas." - }, - "matchaGotcha": { - "name": "Cañón Batidor", - "effect": "Rocía al objetivo con té recién batido y recupera la mitad de los PS del daño que produce. Puede causar quemaduras." - }, - "syrupBomb": { - "name": "Bomba Caramelo", - "effect": "Impregna al objetivo con una explosión de su viscoso néctar y lo carameliza, lo que hace que su Velocidad se reduzca progresivamente durante tres turnos." - }, - "ivyCudgel": { - "name": "Garrote Liana", - "effect": "Golpea con un garrote que forma enrollando su liana. El tipo del movimiento varía según la máscara que lleve puesta el usuario. Suele asestar un golpe crítico." - }, - "electroShot": { - "name": "Electrorrayo", - "effect": "Acumula electricidad y aumenta su Ataque Especial en el primer turno y dispara una descarga de alto voltaje en el segundo. Si llueve, puede atacar en el primer turno." - }, - "teraStarstorm": { - "name": "Teraclúster", - "effect": "Ataca al objetivo irradiando el poder de sus cristales. Si Terapagos usa este movimiento en su Forma Astral, inflige daño a todos los rivales." - }, - "fickleBeam": { - "name": "Láser Veleidoso", - "effect": "Ataca disparando un haz de luz. En ocasiones, el resto de sus cabezas se unen al ataque. Cuando esto sucede, la potencia del movimiento se duplica." - }, - "burningBulwark": { - "name": "Llama Protectora", - "effect": "Emplea su ardiente pelaje para protegerse de los ataques y causarle quemaduras al atacante si este usa un movimiento de contacto." - }, - "thunderclap": { - "name": "Relámpago Súbito", - "effect": "Invoca un rayo que cae sobre el objetivo antes de que este pueda realizar cualquier acción. Falla si el objetivo no está preparando ningún ataque." - }, - "mightyCleave": { - "name": "Filo Potente", - "effect": "Rebana al objetivo con la luz que ha acumulado en la testa. Permite acertar aunque el objetivo esté protegiéndose." - }, - "tachyonCutter": { - "name": "Tajo Taquión", - "effect": "Lanza una ráfaga de cuchillas formadas por partículas contra el objetivo y le inflige daño dos veces seguidas. No falla nunca." - }, - "hardPress": { - "name": "Prensa Metálica", - "effect": "Oprime con los brazos o las pinzas. Cuantos más PS le queden al objetivo, mayor será la potencia del movimiento." - }, - "dragonCheer": { - "name": "Bramido Dragón", - "effect": "Bramido de dragón que sube la moral de los aliados y aumenta sus probabilidades de asestar un golpe crítico. Es especialmente efectivo con aliados de tipo Dragón." - }, - "alluringVoice": { - "name": "Canto Encantador", - "effect": "Ataca con un canto angelical y, si las características del objetivo han aumentado en ese turno, lo deja confuso." - }, - "temperFlare": { - "name": "Cólera Ardiente", - "effect": "Arremete contra el objetivo tras dejarse llevar por la ira. Su potencia se duplica si el movimiento del usuario falló en el turno anterior." - }, - "supercellSlam": { - "name": "Plancha Voltaica", - "effect": "El usuario electrifica su cuerpo y salta en plancha sobre el objetivo. Si falla, se hiere a sí mismo." - }, - "psychicNoise": { - "name": "Psicorruido", - "effect": "Ataca emitiendo una onda sonora desagradable que impide al objetivo usar movimientos, habilidades y objetos equipados que recuperan PS durante dos turnos." - }, - "upperHand": { - "name": "Palma Rauda", - "effect": "Se anticipa al objetivo golpeándolo rápidamente con la palma y lo amedrenta. Falla si el objetivo no está preparando un movimiento de prioridad alta." - }, - "malignantChain": { - "name": "Cadena Virulenta", - "effect": "Apresa al objetivo con una cadena hecha de ponzoña que le inocula toxinas para minarle las fuerzas. Puede envenenar gravemente." - } -} diff --git a/src/locales/es/nature.json b/src/locales/es/nature.json deleted file mode 100644 index a21fd327ef5..00000000000 --- a/src/locales/es/nature.json +++ /dev/null @@ -1,27 +0,0 @@ -{ - "Hardy": "Fuerte", - "Lonely": "Huraña", - "Brave": "Audaz", - "Adamant": "Firme", - "Naughty": "Pícara", - "Bold": "Osada", - "Docile": "Dócil", - "Relaxed": "Plácida", - "Impish": "Agitada", - "Lax": "Floja", - "Timid": "Miedosa", - "Hasty": "Activa", - "Serious": "Seria", - "Jolly": "Alegre", - "Naive": "Ingenua", - "Modest": "Modesta", - "Mild": "Afable", - "Quiet": "Mansa", - "Bashful": "Tímida", - "Rash": "Alocada", - "Calm": "Serena", - "Gentle": "Amable", - "Sassy": "Grosera", - "Careful": "Cauta", - "Quirky": "Rara" -} \ No newline at end of file diff --git a/src/locales/es/party-ui-handler.json b/src/locales/es/party-ui-handler.json deleted file mode 100644 index 0e59aee6fd1..00000000000 --- a/src/locales/es/party-ui-handler.json +++ /dev/null @@ -1,47 +0,0 @@ -{ - "SEND_OUT": "Enviar", - "SUMMARY": "Resumen", - "CANCEL": "Cancelar", - "RELEASE": "Liberar", - "APPLY": "Aplicar", - "TEACH": "Enseñar", - "SPLICE": "Fusionar", - "UNSPLICE": "Separar", - "ACTIVATE": "Activar", - "DEACTIVATE": "Desactivar", - "TRANSFER": "Transferir", - "ALL": "Todo", - "PASS_BATON": "Relevo", - "UNPAUSE_EVOLUTION": "Reanudar evolución", - "REVIVE": "Revivir", - "RENAME": "Rename", - "choosePokemon": "Elige a un Pokémon.", - "doWhatWithThisPokemon": "¿Que quieres hacer con este Pokémon?", - "noEnergy": "¡A {{pokemonName}} no le\nquedan fuerzas para luchar!", - "hasEnergy": "¡A {{pokemonName}} le\nquedan fuerzas para luchar!", - "cantBeUsed": "¡{{pokemonName}} no puede usarse en este desafío!", - "tooManyItems": "¡{{pokemonName}} tiene\ndemasiado de este objeto!", - "anyEffect": "No tendría ningún efecto.", - "unpausedEvolutions": "Se reanudaron las evoluciones de {{pokemonName}}.", - "unspliceConfirmation": "¿Seguro que quiere separar a {{fusionName}}\nde {{pokemonName}}? {{fusionName}} se perderá.", - "wasReverted": "{{fusionName}} se revirtió a {{pokemonName}}.", - "releaseConfirmation": "¿Quieres liberar a {{pokemonName}}?", - "releaseInBattle": "¡No puedes liberar un Pokémon que está en batalla!", - "selectAMove": "Selecciona un movimiento.", - "changeQuantity": "Selecciona un ítem para transferir.\nUsa < y > para calibrar.", - "selectAnotherPokemonToSplice": "Selecciona otro Pokémon para fusionar.", - "cancel": "Salir", - "able": "Apto", - "notAble": "No apto", - "learned": "Aprendido", - "goodbye": "¡Adiós, {{pokemonName}}!", - "byebye": "¡Chao, {{pokemonName}}!", - "farewell": "¡Hasta luego, {{pokemonName}}!", - "soLong": "¡Nos vemos, {{pokemonName}}!", - "thisIsWhereWePart": "¡Aquí es donde nos despedimos, {{pokemonName}}!", - "illMissYou": "¡Te echaré de menos, {{pokemonName}}!", - "illNeverForgetYou": "¡Nunca te olvidaré, {{pokemonName}}!", - "untilWeMeetAgain": "¡Hasta que nos volvamos a\nencontrar, {{pokemonName}}!", - "sayonara": "¡Sayonara, {{pokemonName}}!", - "smellYaLater": "¡Nos vemos luego, {{pokemonName}}!" -} diff --git a/src/locales/es/pokeball.json b/src/locales/es/pokeball.json deleted file mode 100644 index 9eb2a9f0d44..00000000000 --- a/src/locales/es/pokeball.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "pokeBall": "Poké Ball", - "greatBall": "Super Ball", - "ultraBall": "Ultra Ball", - "rogueBall": "Rogue Ball", - "masterBall": "Master Ball", - "luxuryBall": "Lujo Ball" -} \ No newline at end of file diff --git a/src/locales/es/pokemon-form-battle.json b/src/locales/es/pokemon-form-battle.json deleted file mode 100644 index d6eed9e93cc..00000000000 --- a/src/locales/es/pokemon-form-battle.json +++ /dev/null @@ -1,14 +0,0 @@ -{ - "mega": "Mega {{pokemonName}}", - "mega-x": "Mega {{pokemonName}} X", - "mega-y": "Mega {{pokemonName}} Y", - "primal": "{{pokemonName}} Primigenio", - "gigantamax": "G-Max {{pokemonName}}", - "eternamax": "E-Max {{pokemonName}}", - "megaChange": "¡{{preName}} ha mega-evolucionado a {{pokemonName}}!", - "gigantamaxChange": "¡{{preName}} ha gigamaxizado a {{pokemonName}}!", - "eternamaxChange": "¡{{preName}} ha eternamaxizado a {{pokemonName}}!", - "revertChange": "¡{{pokemonName}} ha revertido a su forma original!", - "formChange": "¡{{preName}} ha cambiado de forma!", - "disguiseChange": "¡El disfraz ha actuado como señuelo!" -} diff --git a/src/locales/es/pokemon-form.json b/src/locales/es/pokemon-form.json deleted file mode 100644 index 2f70038ad2d..00000000000 --- a/src/locales/es/pokemon-form.json +++ /dev/null @@ -1,170 +0,0 @@ -{ - "pikachuCosplay": "Coqueta", - "pikachuCoolCosplay": "Roquera", - "pikachuBeautyCosplay": "Aristócrata", - "pikachuCuteCosplay": "Superstar", - "pikachuSmartCosplay": "Erudita", - "pikachuToughCosplay": "Enmascarada", - "pikachuPartner": "Compañero", - "eeveePartner": "Compañero", - "pichuSpiky": "Picoreja", - "unownA": "A", - "unownB": "B", - "unownC": "C", - "unownD": "D", - "unownE": "E", - "unownF": "F", - "unownG": "G", - "unownH": "H", - "unownI": "I", - "unownJ": "J", - "unownK": "K", - "unownL": "L", - "unownM": "M", - "unownN": "N", - "unownO": "O", - "unownP": "P", - "unownQ": "Q", - "unownR": "R", - "unownS": "S", - "unownT": "T", - "unownU": "U", - "unownV": "V", - "unownW": "W", - "unownX": "X", - "unownY": "Y", - "unownZ": "Z", - "unownExclamation": "!", - "unownQuestion": "?", - "castformSunny": "Sol", - "castformRainy": "Lluvia", - "castformSnowy": "Nieve", - "deoxysNormal": "Normal", - "burmyPlant": "Planta", - "burmySandy": "Arena", - "burmyTrash": "Basura", - "shellosEast": "Este", - "shellosWest": "Oeste", - "rotomHeat": "Calor", - "rotomWash": "Lavado", - "rotomFrost": "Frío", - "rotomFan": "Ventilador", - "rotomMow": "Corte", - "giratinaAltered": "Modificada", - "shayminLand": "Tierra", - "basculinRedStriped": "Raya Roja", - "basculinBlueStriped": "Raya Azul", - "basculinWhiteStriped": "Raya Blanca", - "deerlingSpring": "Primavera", - "deerlingSummer": "Verano", - "deerlingAutumn": "Otoño", - "deerlingWinter": "Invierno", - "tornadusIncarnate": "Avatar", - "thundurusIncarnate": "Avatar", - "landorusIncarnate": "Avatar", - "keldeoOrdinary": "Habitual", - "meloettaAria": "Lírica", - "meloettaPirouette": "Danza", - "froakieBattleBond": "Fuerte Afecto", - "scatterbugMeadow": "Floral", - "scatterbugIcySnow": "Polar", - "scatterbugPolar": "Taiga", - "scatterbugTundra": "Tundra", - "scatterbugContinental": "Continental", - "scatterbugGarden": "Vergel", - "scatterbugElegant": "Oriental", - "scatterbugModern": "Moderno", - "scatterbugMarine": "Marino", - "scatterbugArchipelago": "Isleño", - "scatterbugHighPlains": "Estepa", - "scatterbugSandstorm": "Desierto", - "scatterbugRiver": "Oasis", - "scatterbugMonsoon": "Monzón", - "scatterbugSavanna": "Pantano", - "scatterbugSun": "Solar", - "scatterbugOcean": "Océano", - "scatterbugJungle": "Jungla", - "scatterbugFancy": "Fantasía", - "scatterbugPokeBall": "Poké Ball", - "flabebeRed": "Rojo", - "flabebeYellow": "Amarillo", - "flabebeOrange": "Naranja", - "flabebeBlue": "Azul", - "flabebeWhite": "Blanco", - "furfrouHeart": "Corazón", - "furfrouStar": "Estrella", - "furfrouDiamond": "Diamante", - "furfrouDebutante": "Señorita", - "furfrouMatron": "Dama", - "furfrouDandy": "Caballero", - "furfrouLaReine": "Aristócrata", - "furfrouKabuki": "Kabuki", - "furfrouPharaoh": "Faraónico", - "pumpkabooSmall": "Pequeño", - "pumpkabooLarge": "Grande", - "pumpkabooSuper": "Enorme", - "xerneasNeutral": "Relajado", - "xerneasActive": "Activo", - "zygarde50": "Al 50%", - "zygarde10": "Al 10%", - "zygarde50Pc": "Zygarde al 50%", - "zygarde10Pc": "Zygarde al 10%", - "zygardeComplete": "Zygarde Completo", - "oricorioBaile": "Apasionado", - "oricorioPompom": "Animado", - "oricorioPau": "Plácido", - "oricorioSensu": "Refinado", - "rockruffOwnTempo": "Ritmo Propio", - "miniorRedMeteor": "Núcleo Rojo", - "miniorOrangeMeteor": "Núcleo Naranja", - "miniorYellowMeteor": "Núcleo Amarillo", - "miniorGreenMeteor": "Núcleo Verde", - "miniorBlueMeteor": "Núcleo Azul", - "miniorIndigoMeteor": "Núcleo Añil", - "miniorVioletMeteor": "Núcleo Violeta", - "miniorRed": "Rojo", - "miniorOrange": "Naranja", - "miniorYellow": "Amarillo", - "miniorGreen": "Verde", - "miniorBlue": "Azul", - "miniorIndigo": "Añil", - "miniorViolet": "Violeta", - "mimikyuDisguised": "Encubierta", - "mimikyuBusted": "Descubierta", - "magearnaOriginal": "Vetusto", - "marshadowZenith": "Cénit", - "sinisteaPhony": "Falsificada", - "sinisteaAntique": "Genuina", - "eiscueNoIce": "Cara Deshielo", - "indeedeeMale": "Macho", - "indeedeeFemale": "Hembra", - "morpekoFullBelly": "Saciada", - "zacianHeroOfManyBattles": "Guerrero avezado", - "zamazentaHeroOfManyBattles": "Guerrero avezado", - "zarudeDada": "Papá", - "enamorusIncarnate": "Avatar", - "squawkabillyGreenPlumage": "Plumaje Verde", - "squawkabillyBluePlumage": "Plumaje Azul", - "squawkabillyYellowPlumage": "Plumaje Amarillo", - "squawkabillyWhitePlumage": "Plumaje Blanco", - "tatsugiriCurly": "Curvada", - "tatsugiriDroopy": "Lánguida", - "tatsugiriStretchy": "Estirada", - "gimmighoulChest": "Cofre", - "gimmighoulRoaming": "Andante", - "koraidonApexBuild": "Forma Plena", - "koraidonLimitedBuild": "Forma Limitada", - "koraidonSprintingBuild": "Forma Carrera", - "koraidonSwimmingBuild": "Forma Nado", - "koraidonGlidingBuild": "Forma Planeo", - "miraidonUltimateMode": "Modo Pleno", - "miraidonLowPowerMode": "Modo Limitado", - "miraidonDriveMode": "Modo Conducción", - "miraidonAquaticMode": "Modo Flote", - "miraidonGlideMode": "Modo Planeo", - "poltchageistCounterfeit": "Fraudulenta", - "poltchageistArtisan": "Opulenta", - "paldeaTaurosCombat": "Combatiente", - "paldeaTaurosBlaze": "Ardiente", - "paldeaTaurosAqua": "Acuático" -} diff --git a/src/locales/es/pokemon-info-container.json b/src/locales/es/pokemon-info-container.json deleted file mode 100644 index 7159c7eae71..00000000000 --- a/src/locales/es/pokemon-info-container.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "moveset": "Movimientos", - "gender": "Género:", - "ability": "Habilid:", - "nature": "Natur:" -} \ No newline at end of file diff --git a/src/locales/es/pokemon-info.json b/src/locales/es/pokemon-info.json deleted file mode 100644 index 241f5e7c5d0..00000000000 --- a/src/locales/es/pokemon-info.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "Stat": { - "HP": "PS", - "HPshortened": "PS", - "ATK": "Ataque", - "ATKshortened": "Atq.", - "DEF": "Defensa", - "DEFshortened": "Def.", - "SPATK": "Atq. Esp.", - "SPATKshortened": "AtqEs.", - "SPDEF": "Def. Esp.", - "SPDEFshortened": "DefEs.", - "SPD": "Velocidad", - "SPDshortened": "Veloc.", - "ACC": "Precisión", - "EVA": "Evasión", - "HPStat": "PS" - }, - "Type": { - "UNKNOWN": "Desconocido", - "NORMAL": "Normal", - "FIGHTING": "Lucha", - "FLYING": "Volador", - "POISON": "Veneno", - "GROUND": "Tierra", - "ROCK": "Roca", - "BUG": "Bicho", - "GHOST": "Fantasma", - "STEEL": "Acero", - "FIRE": "Fuego", - "WATER": "Agua", - "GRASS": "Planta", - "ELECTRIC": "Eléctrico", - "PSYCHIC": "Psíquico", - "ICE": "Hielo", - "DRAGON": "Dragón", - "DARK": "Siniestro", - "FAIRY": "Hada", - "STELLAR": "Astral" - } -} diff --git a/src/locales/es/pokemon-summary.json b/src/locales/es/pokemon-summary.json deleted file mode 100644 index fe33c9418cc..00000000000 --- a/src/locales/es/pokemon-summary.json +++ /dev/null @@ -1,17 +0,0 @@ -{ - "pokemonInfo": "Info. Pokémon", - "status": "Estado", - "powerAccuracyCategory": "Potencia\nPrecisión\nCategoría", - "type": "Tipo", - "unknownTrainer": "Desconocido", - "ot": "EO", - "nature": "Naturaleza", - "expPoints": "Puntos Exp.", - "nextLv": "Nv. siguiente", - "cancel": "Salir", - "memoString": "Naturaleza {{natureFragment}},\n{{metFragment}}", - "metFragment": { - "normal": "encontrado al Nv. {{level}},\n{{biome}}, Oleada {{wave}}.", - "apparently": "aparentemente encontrado al Nv. {{level}},\n{{biome}}." - } -} diff --git a/src/locales/es/pokemon.json b/src/locales/es/pokemon.json deleted file mode 100644 index 1c2b2cd97a4..00000000000 --- a/src/locales/es/pokemon.json +++ /dev/null @@ -1,1084 +0,0 @@ -{ - "bulbasaur": "Bulbasaur", - "ivysaur": "Ivysaur", - "venusaur": "Venusaur", - "charmander": "Charmander", - "charmeleon": "Charmeleon", - "charizard": "Charizard", - "squirtle": "Squirtle", - "wartortle": "Wartortle", - "blastoise": "Blastoise", - "caterpie": "Caterpie", - "metapod": "Metapod", - "butterfree": "Butterfree", - "weedle": "Weedle", - "kakuna": "Kakuna", - "beedrill": "Beedrill", - "pidgey": "Pidgey", - "pidgeotto": "Pidgeotto", - "pidgeot": "Pidgeot", - "rattata": "Rattata", - "raticate": "Raticate", - "spearow": "Spearow", - "fearow": "Fearow", - "ekans": "Ekans", - "arbok": "Arbok", - "pikachu": "Pikachu", - "raichu": "Raichu", - "sandshrew": "Sandshrew", - "sandslash": "Sandslash", - "nidoran_f": "Nidoran♀", - "nidorina": "Nidorina", - "nidoqueen": "Nidoqueen", - "nidoran_m": "Nidoran♂", - "nidorino": "Nidorino", - "nidoking": "Nidoking", - "clefairy": "Clefairy", - "clefable": "Clefable", - "vulpix": "Vulpix", - "ninetales": "Ninetales", - "jigglypuff": "Jigglypuff", - "wigglytuff": "Wigglytuff", - "zubat": "Zubat", - "golbat": "Golbat", - "oddish": "Oddish", - "gloom": "Gloom", - "vileplume": "Vileplume", - "paras": "Paras", - "parasect": "Parasect", - "venonat": "Venonat", - "venomoth": "Venomoth", - "diglett": "Diglett", - "dugtrio": "Dugtrio", - "meowth": "Meowth", - "persian": "Persian", - "psyduck": "Psyduck", - "golduck": "Golduck", - "mankey": "Mankey", - "primeape": "Primeape", - "growlithe": "Growlithe", - "arcanine": "Arcanine", - "poliwag": "Poliwag", - "poliwhirl": "Poliwhirl", - "poliwrath": "Poliwrath", - "abra": "Abra", - "kadabra": "Kadabra", - "alakazam": "Alakazam", - "machop": "Machop", - "machoke": "Machoke", - "machamp": "Machamp", - "bellsprout": "Bellsprout", - "weepinbell": "Weepinbell", - "victreebel": "Victreebel", - "tentacool": "Tentacool", - "tentacruel": "Tentacruel", - "geodude": "Geodude", - "graveler": "Graveler", - "golem": "Golem", - "ponyta": "Ponyta", - "rapidash": "Rapidash", - "slowpoke": "Slowpoke", - "slowbro": "Slowbro", - "magnemite": "Magnemite", - "magneton": "Magneton", - "farfetchd": "Farfetch'd", - "doduo": "Doduo", - "dodrio": "Dodrio", - "seel": "Seel", - "dewgong": "Dewgong", - "grimer": "Grimer", - "muk": "Muk", - "shellder": "Shellder", - "cloyster": "Cloyster", - "gastly": "Gastly", - "haunter": "Haunter", - "gengar": "Gengar", - "onix": "Onix", - "drowzee": "Drowzee", - "hypno": "Hypno", - "krabby": "Krabby", - "kingler": "Kingler", - "voltorb": "Voltorb", - "electrode": "Electrode", - "exeggcute": "Exeggcute", - "exeggutor": "Exeggutor", - "cubone": "Cubone", - "marowak": "Marowak", - "hitmonlee": "Hitmonlee", - "hitmonchan": "Hitmonchan", - "lickitung": "Lickitung", - "koffing": "Koffing", - "weezing": "Weezing", - "rhyhorn": "Rhyhorn", - "rhydon": "Rhydon", - "chansey": "Chansey", - "tangela": "Tangela", - "kangaskhan": "Kangaskhan", - "horsea": "Horsea", - "seadra": "Seadra", - "goldeen": "Goldeen", - "seaking": "Seaking", - "staryu": "Staryu", - "starmie": "Starmie", - "mr_mime": "Mr. Mime", - "scyther": "Scyther", - "jynx": "Jynx", - "electabuzz": "Electabuzz", - "magmar": "Magmar", - "pinsir": "Pinsir", - "tauros": "Tauros", - "magikarp": "Magikarp", - "gyarados": "Gyarados", - "lapras": "Lapras", - "ditto": "Ditto", - "eevee": "Eevee", - "vaporeon": "Vaporeon", - "jolteon": "Jolteon", - "flareon": "Flareon", - "porygon": "Porygon", - "omanyte": "Omanyte", - "omastar": "Omastar", - "kabuto": "Kabuto", - "kabutops": "Kabutops", - "aerodactyl": "Aerodactyl", - "snorlax": "Snorlax", - "articuno": "Articuno", - "zapdos": "Zapdos", - "moltres": "Moltres", - "dratini": "Dratini", - "dragonair": "Dragonair", - "dragonite": "Dragonite", - "mewtwo": "Mewtwo", - "mew": "Mew", - "chikorita": "Chikorita", - "bayleef": "Bayleef", - "meganium": "Meganium", - "cyndaquil": "Cyndaquil", - "quilava": "Quilava", - "typhlosion": "Typhlosion", - "totodile": "Totodile", - "croconaw": "Croconaw", - "feraligatr": "Feraligatr", - "sentret": "Sentret", - "furret": "Furret", - "hoothoot": "Hoothoot", - "noctowl": "Noctowl", - "ledyba": "Ledyba", - "ledian": "Ledian", - "spinarak": "Spinarak", - "ariados": "Ariados", - "crobat": "Crobat", - "chinchou": "Chinchou", - "lanturn": "Lanturn", - "pichu": "Pichu", - "cleffa": "Cleffa", - "igglybuff": "Igglybuff", - "togepi": "Togepi", - "togetic": "Togetic", - "natu": "Natu", - "xatu": "Xatu", - "mareep": "Mareep", - "flaaffy": "Flaaffy", - "ampharos": "Ampharos", - "bellossom": "Bellossom", - "marill": "Marill", - "azumarill": "Azumarill", - "sudowoodo": "Sudowoodo", - "politoed": "Politoed", - "hoppip": "Hoppip", - "skiploom": "Skiploom", - "jumpluff": "Jumpluff", - "aipom": "Aipom", - "sunkern": "Sunkern", - "sunflora": "Sunflora", - "yanma": "Yanma", - "wooper": "Wooper", - "quagsire": "Quagsire", - "espeon": "Espeon", - "umbreon": "Umbreon", - "murkrow": "Murkrow", - "slowking": "Slowking", - "misdreavus": "Misdreavus", - "unown": "Unown", - "wobbuffet": "Wobbuffet", - "girafarig": "Girafarig", - "pineco": "Pineco", - "forretress": "Forretress", - "dunsparce": "Dunsparce", - "gligar": "Gligar", - "steelix": "Steelix", - "snubbull": "Snubbull", - "granbull": "Granbull", - "qwilfish": "Qwilfish", - "scizor": "Scizor", - "shuckle": "Shuckle", - "heracross": "Heracross", - "sneasel": "Sneasel", - "teddiursa": "Teddiursa", - "ursaring": "Ursaring", - "slugma": "Slugma", - "magcargo": "Magcargo", - "swinub": "Swinub", - "piloswine": "Piloswine", - "corsola": "Corsola", - "remoraid": "Remoraid", - "octillery": "Octillery", - "delibird": "Delibird", - "mantine": "Mantine", - "skarmory": "Skarmory", - "houndour": "Houndour", - "houndoom": "Houndoom", - "kingdra": "Kingdra", - "phanpy": "Phanpy", - "donphan": "Donphan", - "porygon2": "Porygon2", - "stantler": "Stantler", - "smeargle": "Smeargle", - "tyrogue": "Tyrogue", - "hitmontop": "Hitmontop", - "smoochum": "Smoochum", - "elekid": "Elekid", - "magby": "Magby", - "miltank": "Miltank", - "blissey": "Blissey", - "raikou": "Raikou", - "entei": "Entei", - "suicune": "Suicune", - "larvitar": "Larvitar", - "pupitar": "Pupitar", - "tyranitar": "Tyranitar", - "lugia": "Lugia", - "ho_oh": "Ho-Oh", - "celebi": "Celebi", - "treecko": "Treecko", - "grovyle": "Grovyle", - "sceptile": "Sceptile", - "torchic": "Torchic", - "combusken": "Combusken", - "blaziken": "Blaziken", - "mudkip": "Mudkip", - "marshtomp": "Marshtomp", - "swampert": "Swampert", - "poochyena": "Poochyena", - "mightyena": "Mightyena", - "zigzagoon": "Zigzagoon", - "linoone": "Linoone", - "wurmple": "Wurmple", - "silcoon": "Silcoon", - "beautifly": "Beautifly", - "cascoon": "Cascoon", - "dustox": "Dustox", - "lotad": "Lotad", - "lombre": "Lombre", - "ludicolo": "Ludicolo", - "seedot": "Seedot", - "nuzleaf": "Nuzleaf", - "shiftry": "Shiftry", - "taillow": "Taillow", - "swellow": "Swellow", - "wingull": "Wingull", - "pelipper": "Pelipper", - "ralts": "Ralts", - "kirlia": "Kirlia", - "gardevoir": "Gardevoir", - "surskit": "Surskit", - "masquerain": "Masquerain", - "shroomish": "Shroomish", - "breloom": "Breloom", - "slakoth": "Slakoth", - "vigoroth": "Vigoroth", - "slaking": "Slaking", - "nincada": "Nincada", - "ninjask": "Ninjask", - "shedinja": "Shedinja", - "whismur": "Whismur", - "loudred": "Loudred", - "exploud": "Exploud", - "makuhita": "Makuhita", - "hariyama": "Hariyama", - "azurill": "Azurill", - "nosepass": "Nosepass", - "skitty": "Skitty", - "delcatty": "Delcatty", - "sableye": "Sableye", - "mawile": "Mawile", - "aron": "Aron", - "lairon": "Lairon", - "aggron": "Aggron", - "meditite": "Meditite", - "medicham": "Medicham", - "electrike": "Electrike", - "manectric": "Manectric", - "plusle": "Plusle", - "minun": "Minun", - "volbeat": "Volbeat", - "illumise": "Illumise", - "roselia": "Roselia", - "gulpin": "Gulpin", - "swalot": "Swalot", - "carvanha": "Carvanha", - "sharpedo": "Sharpedo", - "wailmer": "Wailmer", - "wailord": "Wailord", - "numel": "Numel", - "camerupt": "Camerupt", - "torkoal": "Torkoal", - "spoink": "Spoink", - "grumpig": "Grumpig", - "spinda": "Spinda", - "trapinch": "Trapinch", - "vibrava": "Vibrava", - "flygon": "Flygon", - "cacnea": "Cacnea", - "cacturne": "Cacturne", - "swablu": "Swablu", - "altaria": "Altaria", - "zangoose": "Zangoose", - "seviper": "Seviper", - "lunatone": "Lunatone", - "solrock": "Solrock", - "barboach": "Barboach", - "whiscash": "Whiscash", - "corphish": "Corphish", - "crawdaunt": "Crawdaunt", - "baltoy": "Baltoy", - "claydol": "Claydol", - "lileep": "Lileep", - "cradily": "Cradily", - "anorith": "Anorith", - "armaldo": "Armaldo", - "feebas": "Feebas", - "milotic": "Milotic", - "castform": "Castform", - "kecleon": "Kecleon", - "shuppet": "Shuppet", - "banette": "Banette", - "duskull": "Duskull", - "dusclops": "Dusclops", - "tropius": "Tropius", - "chimecho": "Chimecho", - "absol": "Absol", - "wynaut": "Wynaut", - "snorunt": "Snorunt", - "glalie": "Glalie", - "spheal": "Spheal", - "sealeo": "Sealeo", - "walrein": "Walrein", - "clamperl": "Clamperl", - "huntail": "Huntail", - "gorebyss": "Gorebyss", - "relicanth": "Relicanth", - "luvdisc": "Luvdisc", - "bagon": "Bagon", - "shelgon": "Shelgon", - "salamence": "Salamence", - "beldum": "Beldum", - "metang": "Metang", - "metagross": "Metagross", - "regirock": "Regirock", - "regice": "Regice", - "registeel": "Registeel", - "latias": "Latias", - "latios": "Latios", - "kyogre": "Kyogre", - "groudon": "Groudon", - "rayquaza": "Rayquaza", - "jirachi": "Jirachi", - "deoxys": "Deoxys", - "turtwig": "Turtwig", - "grotle": "Grotle", - "torterra": "Torterra", - "chimchar": "Chimchar", - "monferno": "Monferno", - "infernape": "Infernape", - "piplup": "Piplup", - "prinplup": "Prinplup", - "empoleon": "Empoleon", - "starly": "Starly", - "staravia": "Staravia", - "staraptor": "Staraptor", - "bidoof": "Bidoof", - "bibarel": "Bibarel", - "kricketot": "Kricketot", - "kricketune": "Kricketune", - "shinx": "Shinx", - "luxio": "Luxio", - "luxray": "Luxray", - "budew": "Budew", - "roserade": "Roserade", - "cranidos": "Cranidos", - "rampardos": "Rampardos", - "shieldon": "Shieldon", - "bastiodon": "Bastiodon", - "burmy": "Burmy", - "wormadam": "Wormadam", - "mothim": "Mothim", - "combee": "Combee", - "vespiquen": "Vespiquen", - "pachirisu": "Pachirisu", - "buizel": "Buizel", - "floatzel": "Floatzel", - "cherubi": "Cherubi", - "cherrim": "Cherrim", - "shellos": "Shellos", - "gastrodon": "Gastrodon", - "ambipom": "Ambipom", - "drifloon": "Drifloon", - "drifblim": "Drifblim", - "buneary": "Buneary", - "lopunny": "Lopunny", - "mismagius": "Mismagius", - "honchkrow": "Honchkrow", - "glameow": "Glameow", - "purugly": "Purugly", - "chingling": "Chingling", - "stunky": "Stunky", - "skuntank": "Skuntank", - "bronzor": "Bronzor", - "bronzong": "Bronzong", - "bonsly": "Bonsly", - "mime_jr": "Mime Jr.", - "happiny": "Happiny", - "chatot": "Chatot", - "spiritomb": "Spiritomb", - "gible": "Gible", - "gabite": "Gabite", - "garchomp": "Garchomp", - "munchlax": "Munchlax", - "riolu": "Riolu", - "lucario": "Lucario", - "hippopotas": "Hippopotas", - "hippowdon": "Hippowdon", - "skorupi": "Skorupi", - "drapion": "Drapion", - "croagunk": "Croagunk", - "toxicroak": "Toxicroak", - "carnivine": "Carnivine", - "finneon": "Finneon", - "lumineon": "Lumineon", - "mantyke": "Mantyke", - "snover": "Snover", - "abomasnow": "Abomasnow", - "weavile": "Weavile", - "magnezone": "Magnezone", - "lickilicky": "Lickilicky", - "rhyperior": "Rhyperior", - "tangrowth": "Tangrowth", - "electivire": "Electivire", - "magmortar": "Magmortar", - "togekiss": "Togekiss", - "yanmega": "Yanmega", - "leafeon": "Leafeon", - "glaceon": "Glaceon", - "gliscor": "Gliscor", - "mamoswine": "Mamoswine", - "porygon_z": "Porygon-Z", - "gallade": "Gallade", - "probopass": "Probopass", - "dusknoir": "Dusknoir", - "froslass": "Froslass", - "rotom": "Rotom", - "uxie": "Uxie", - "mesprit": "Mesprit", - "azelf": "Azelf", - "dialga": "Dialga", - "palkia": "Palkia", - "heatran": "Heatran", - "regigigas": "Regigigas", - "giratina": "Giratina", - "cresselia": "Cresselia", - "phione": "Phione", - "manaphy": "Manaphy", - "darkrai": "Darkrai", - "shaymin": "Shaymin", - "arceus": "Arceus", - "victini": "Victini", - "snivy": "Snivy", - "servine": "Servine", - "serperior": "Serperior", - "tepig": "Tepig", - "pignite": "Pignite", - "emboar": "Emboar", - "oshawott": "Oshawott", - "dewott": "Dewott", - "samurott": "Samurott", - "patrat": "Patrat", - "watchog": "Watchog", - "lillipup": "Lillipup", - "herdier": "Herdier", - "stoutland": "Stoutland", - "purrloin": "Purrloin", - "liepard": "Liepard", - "pansage": "Pansage", - "simisage": "Simisage", - "pansear": "Pansear", - "simisear": "Simisear", - "panpour": "Panpour", - "simipour": "Simipour", - "munna": "Munna", - "musharna": "Musharna", - "pidove": "Pidove", - "tranquill": "Tranquill", - "unfezant": "Unfezant", - "blitzle": "Blitzle", - "zebstrika": "Zebstrika", - "roggenrola": "Roggenrola", - "boldore": "Boldore", - "gigalith": "Gigalith", - "woobat": "Woobat", - "swoobat": "Swoobat", - "drilbur": "Drilbur", - "excadrill": "Excadrill", - "audino": "Audino", - "timburr": "Timburr", - "gurdurr": "Gurdurr", - "conkeldurr": "Conkeldurr", - "tympole": "Tympole", - "palpitoad": "Palpitoad", - "seismitoad": "Seismitoad", - "throh": "Throh", - "sawk": "Sawk", - "sewaddle": "Sewaddle", - "swadloon": "Swadloon", - "leavanny": "Leavanny", - "venipede": "Venipede", - "whirlipede": "Whirlipede", - "scolipede": "Scolipede", - "cottonee": "Cottonee", - "whimsicott": "Whimsicott", - "petilil": "Petilil", - "lilligant": "Lilligant", - "basculin": "Basculin", - "sandile": "Sandile", - "krokorok": "Krokorok", - "krookodile": "Krookodile", - "darumaka": "Darumaka", - "darmanitan": "Darmanitan", - "maractus": "Maractus", - "dwebble": "Dwebble", - "crustle": "Crustle", - "scraggy": "Scraggy", - "scrafty": "Scrafty", - "sigilyph": "Sigilyph", - "yamask": "Yamask", - "cofagrigus": "Cofagrigus", - "tirtouga": "Tirtouga", - "carracosta": "Carracosta", - "archen": "Archen", - "archeops": "Archeops", - "trubbish": "Trubbish", - "garbodor": "Garbodor", - "zorua": "Zorua", - "zoroark": "Zoroark", - "minccino": "Minccino", - "cinccino": "Cinccino", - "gothita": "Gothita", - "gothorita": "Gothorita", - "gothitelle": "Gothitelle", - "solosis": "Solosis", - "duosion": "Duosion", - "reuniclus": "Reuniclus", - "ducklett": "Ducklett", - "swanna": "Swanna", - "vanillite": "Vanillite", - "vanillish": "Vanillish", - "vanilluxe": "Vanilluxe", - "deerling": "Deerling", - "sawsbuck": "Sawsbuck", - "emolga": "Emolga", - "karrablast": "Karrablast", - "escavalier": "Escavalier", - "foongus": "Foongus", - "amoonguss": "Amoonguss", - "frillish": "Frillish", - "jellicent": "Jellicent", - "alomomola": "Alomomola", - "joltik": "Joltik", - "galvantula": "Galvantula", - "ferroseed": "Ferroseed", - "ferrothorn": "Ferrothorn", - "klink": "Klink", - "klang": "Klang", - "klinklang": "Klinklang", - "tynamo": "Tynamo", - "eelektrik": "Eelektrik", - "eelektross": "Eelektross", - "elgyem": "Elgyem", - "beheeyem": "Beheeyem", - "litwick": "Litwick", - "lampent": "Lampent", - "chandelure": "Chandelure", - "axew": "Axew", - "fraxure": "Fraxure", - "haxorus": "Haxorus", - "cubchoo": "Cubchoo", - "beartic": "Beartic", - "cryogonal": "Cryogonal", - "shelmet": "Shelmet", - "accelgor": "Accelgor", - "stunfisk": "Stunfisk", - "mienfoo": "Mienfoo", - "mienshao": "Mienshao", - "druddigon": "Druddigon", - "golett": "Golett", - "golurk": "Golurk", - "pawniard": "Pawniard", - "bisharp": "Bisharp", - "bouffalant": "Bouffalant", - "rufflet": "Rufflet", - "braviary": "Braviary", - "vullaby": "Vullaby", - "mandibuzz": "Mandibuzz", - "heatmor": "Heatmor", - "durant": "Durant", - "deino": "Deino", - "zweilous": "Zweilous", - "hydreigon": "Hydreigon", - "larvesta": "Larvesta", - "volcarona": "Volcarona", - "cobalion": "Cobalion", - "terrakion": "Terrakion", - "virizion": "Virizion", - "tornadus": "Tornadus", - "thundurus": "Thundurus", - "reshiram": "Reshiram", - "zekrom": "Zekrom", - "landorus": "Landorus", - "kyurem": "Kyurem", - "keldeo": "Keldeo", - "meloetta": "Meloetta", - "genesect": "Genesect", - "chespin": "Chespin", - "quilladin": "Quilladin", - "chesnaught": "Chesnaught", - "fennekin": "Fennekin", - "braixen": "Braixen", - "delphox": "Delphox", - "froakie": "Froakie", - "frogadier": "Frogadier", - "greninja": "Greninja", - "bunnelby": "Bunnelby", - "diggersby": "Diggersby", - "fletchling": "Fletchling", - "fletchinder": "Fletchinder", - "talonflame": "Talonflame", - "scatterbug": "Scatterbug", - "spewpa": "Spewpa", - "vivillon": "Vivillon", - "litleo": "Litleo", - "pyroar": "Pyroar", - "flabebe": "Flabébé", - "floette": "Floette", - "florges": "Florges", - "skiddo": "Skiddo", - "gogoat": "Gogoat", - "pancham": "Pancham", - "pangoro": "Pangoro", - "furfrou": "Furfrou", - "espurr": "Espurr", - "meowstic": "Meowstic", - "honedge": "Honedge", - "doublade": "Doublade", - "aegislash": "Aegislash", - "spritzee": "Spritzee", - "aromatisse": "Aromatisse", - "swirlix": "Swirlix", - "slurpuff": "Slurpuff", - "inkay": "Inkay", - "malamar": "Malamar", - "binacle": "Binacle", - "barbaracle": "Barbaracle", - "skrelp": "Skrelp", - "dragalge": "Dragalge", - "clauncher": "Clauncher", - "clawitzer": "Clawitzer", - "helioptile": "Helioptile", - "heliolisk": "Heliolisk", - "tyrunt": "Tyrunt", - "tyrantrum": "Tyrantrum", - "amaura": "Amaura", - "aurorus": "Aurorus", - "sylveon": "Sylveon", - "hawlucha": "Hawlucha", - "dedenne": "Dedenne", - "carbink": "Carbink", - "goomy": "Goomy", - "sliggoo": "Sliggoo", - "goodra": "Goodra", - "klefki": "Klefki", - "phantump": "Phantump", - "trevenant": "Trevenant", - "pumpkaboo": "Pumpkaboo", - "gourgeist": "Gourgeist", - "bergmite": "Bergmite", - "avalugg": "Avalugg", - "noibat": "Noibat", - "noivern": "Noivern", - "xerneas": "Xerneas", - "yveltal": "Yveltal", - "zygarde": "Zygarde", - "diancie": "Diancie", - "hoopa": "Hoopa", - "volcanion": "Volcanion", - "rowlet": "Rowlet", - "dartrix": "Dartrix", - "decidueye": "Decidueye", - "litten": "Litten", - "torracat": "Torracat", - "incineroar": "Incineroar", - "popplio": "Popplio", - "brionne": "Brionne", - "primarina": "Primarina", - "pikipek": "Pikipek", - "trumbeak": "Trumbeak", - "toucannon": "Toucannon", - "yungoos": "Yungoos", - "gumshoos": "Gumshoos", - "grubbin": "Grubbin", - "charjabug": "Charjabug", - "vikavolt": "Vikavolt", - "crabrawler": "Crabrawler", - "crabominable": "Crabominable", - "oricorio": "Oricorio", - "cutiefly": "Cutiefly", - "ribombee": "Ribombee", - "rockruff": "Rockruff", - "lycanroc": "Lycanroc", - "wishiwashi": "Wishiwashi", - "mareanie": "Mareanie", - "toxapex": "Toxapex", - "mudbray": "Mudbray", - "mudsdale": "Mudsdale", - "dewpider": "Dewpider", - "araquanid": "Araquanid", - "fomantis": "Fomantis", - "lurantis": "Lurantis", - "morelull": "Morelull", - "shiinotic": "Shiinotic", - "salandit": "Salandit", - "salazzle": "Salazzle", - "stufful": "Stufful", - "bewear": "Bewear", - "bounsweet": "Bounsweet", - "steenee": "Steenee", - "tsareena": "Tsareena", - "comfey": "Comfey", - "oranguru": "Oranguru", - "passimian": "Passimian", - "wimpod": "Wimpod", - "golisopod": "Golisopod", - "sandygast": "Sandygast", - "palossand": "Palossand", - "pyukumuku": "Pyukumuku", - "type_null": "Código Cero", - "silvally": "Silvally", - "minior": "Minior", - "komala": "Komala", - "turtonator": "Turtonator", - "togedemaru": "Togedemaru", - "mimikyu": "Mimikyu", - "bruxish": "Bruxish", - "drampa": "Drampa", - "dhelmise": "Dhelmise", - "jangmo_o": "Jangmo-o", - "hakamo_o": "Hakamo-o", - "kommo_o": "Kommo-o", - "tapu_koko": "Tapu Koko", - "tapu_lele": "Tapu Lele", - "tapu_bulu": "Tapu Bulu", - "tapu_fini": "Tapu Fini", - "cosmog": "Cosmog", - "cosmoem": "Cosmoem", - "solgaleo": "Solgaleo", - "lunala": "Lunala", - "nihilego": "Nihilego", - "buzzwole": "Buzzwole", - "pheromosa": "Pheromosa", - "xurkitree": "Xurkitree", - "celesteela": "Celesteela", - "kartana": "Kartana", - "guzzlord": "Guzzlord", - "necrozma": "Necrozma", - "magearna": "Magearna", - "marshadow": "Marshadow", - "poipole": "Poipole", - "naganadel": "Naganadel", - "stakataka": "Stakataka", - "blacephalon": "Blacephalon", - "zeraora": "Zeraora", - "meltan": "Meltan", - "melmetal": "Melmetal", - "grookey": "Grookey", - "thwackey": "Thwackey", - "rillaboom": "Rillaboom", - "scorbunny": "Scorbunny", - "raboot": "Raboot", - "cinderace": "Cinderace", - "sobble": "Sobble", - "drizzile": "Drizzile", - "inteleon": "Inteleon", - "skwovet": "Skwovet", - "greedent": "Greedent", - "rookidee": "Rookidee", - "corvisquire": "Corvisquire", - "corviknight": "Corviknight", - "blipbug": "Blipbug", - "dottler": "Dottler", - "orbeetle": "Orbeetle", - "nickit": "Nickit", - "thievul": "Thievul", - "gossifleur": "Gossifleur", - "eldegoss": "Eldegoss", - "wooloo": "Wooloo", - "dubwool": "Dubwool", - "chewtle": "Chewtle", - "drednaw": "Drednaw", - "yamper": "Yamper", - "boltund": "Boltund", - "rolycoly": "Rolycoly", - "carkol": "Carkol", - "coalossal": "Coalossal", - "applin": "Applin", - "flapple": "Flapple", - "appletun": "Appletun", - "silicobra": "Silicobra", - "sandaconda": "Sandaconda", - "cramorant": "Cramorant", - "arrokuda": "Arrokuda", - "barraskewda": "Barraskewda", - "toxel": "Toxel", - "toxtricity": "Toxtricity", - "sizzlipede": "Sizzlipede", - "centiskorch": "Centiskorch", - "clobbopus": "Clobbopus", - "grapploct": "Grapploct", - "sinistea": "Sinistea", - "polteageist": "Polteageist", - "hatenna": "Hatenna", - "hattrem": "Hattrem", - "hatterene": "Hatterene", - "impidimp": "Impidimp", - "morgrem": "Morgrem", - "grimmsnarl": "Grimmsnarl", - "obstagoon": "Obstagoon", - "perrserker": "Perrserker", - "cursola": "Cursola", - "sirfetchd": "Sirfetch'd", - "mr_rime": "Mr. Rime", - "runerigus": "Runerigus", - "milcery": "Milcery", - "alcremie": "Alcremie", - "falinks": "Falinks", - "pincurchin": "Pincurchin", - "snom": "Snom", - "frosmoth": "Frosmoth", - "stonjourner": "Stonjourner", - "eiscue": "Eiscue", - "indeedee": "Indeedee", - "morpeko": "Morpeko", - "cufant": "Cufant", - "copperajah": "Copperajah", - "dracozolt": "Dracozolt", - "arctozolt": "Arctozolt", - "dracovish": "Dracovish", - "arctovish": "Arctovish", - "duraludon": "Duraludon", - "dreepy": "Dreepy", - "drakloak": "Drakloak", - "dragapult": "Dragapult", - "zacian": "Zacian", - "zamazenta": "Zamazenta", - "eternatus": "Eternatus", - "kubfu": "Kubfu", - "urshifu": "Urshifu", - "zarude": "Zarude", - "regieleki": "Regieleki", - "regidrago": "Regidrago", - "glastrier": "Glastrier", - "spectrier": "Spectrier", - "calyrex": "Calyrex", - "wyrdeer": "Wyrdeer", - "kleavor": "Kleavor", - "ursaluna": "Ursaluna", - "basculegion": "Basculegion", - "sneasler": "Sneasler", - "overqwil": "Overqwil", - "enamorus": "Enamorus", - "sprigatito": "Sprigatito", - "floragato": "Floragato", - "meowscarada": "Meowscarada", - "fuecoco": "Fuecoco", - "crocalor": "Crocalor", - "skeledirge": "Skeledirge", - "quaxly": "Quaxly", - "quaxwell": "Quaxwell", - "quaquaval": "Quaquaval", - "lechonk": "Lechonk", - "oinkologne": "Oinkologne", - "tarountula": "Tarountula", - "spidops": "Spidops", - "nymble": "Nymble", - "lokix": "Lokix", - "pawmi": "Pawmi", - "pawmo": "Pawmo", - "pawmot": "Pawmot", - "tandemaus": "Tandemaus", - "maushold": "Maushold", - "fidough": "Fidough", - "dachsbun": "Dachsbun", - "smoliv": "Smoliv", - "dolliv": "Dolliv", - "arboliva": "Arboliva", - "squawkabilly": "Squawkabilly", - "nacli": "Nacli", - "naclstack": "Naclstack", - "garganacl": "Garganacl", - "charcadet": "Charcadet", - "armarouge": "Armarouge", - "ceruledge": "Ceruledge", - "tadbulb": "Tadbulb", - "bellibolt": "Bellibolt", - "wattrel": "Wattrel", - "kilowattrel": "Kilowattrel", - "maschiff": "Maschiff", - "mabosstiff": "Mabosstiff", - "shroodle": "Shroodle", - "grafaiai": "Grafaiai", - "bramblin": "Bramblin", - "brambleghast": "Brambleghast", - "toedscool": "Toedscool", - "toedscruel": "Toedscruel", - "klawf": "Klawf", - "capsakid": "Capsakid", - "scovillain": "Scovillain", - "rellor": "Rellor", - "rabsca": "Rabsca", - "flittle": "Flittle", - "espathra": "Espathra", - "tinkatink": "Tinkatink", - "tinkatuff": "Tinkatuff", - "tinkaton": "Tinkaton", - "wiglett": "Wiglett", - "wugtrio": "Wugtrio", - "bombirdier": "Bombirdier", - "finizen": "Finizen", - "palafin": "Palafin", - "varoom": "Varoom", - "revavroom": "Revavroom", - "cyclizar": "Cyclizar", - "orthworm": "Orthworm", - "glimmet": "Glimmet", - "glimmora": "Glimmora", - "greavard": "Greavard", - "houndstone": "Houndstone", - "flamigo": "Flamigo", - "cetoddle": "Cetoddle", - "cetitan": "Cetitan", - "veluza": "Veluza", - "dondozo": "Dondozo", - "tatsugiri": "Tatsugiri", - "annihilape": "Annihilape", - "clodsire": "Clodsire", - "farigiraf": "Farigiraf", - "dudunsparce": "Dudunsparce", - "kingambit": "Kingambit", - "great_tusk": "Colmilargo", - "scream_tail": "Colagrito", - "brute_bonnet": "Furioseta", - "flutter_mane": "Melenaleteo", - "slither_wing": "Reptalada", - "sandy_shocks": "Pelarena", - "iron_treads": "Ferrodada", - "iron_bundle": "Ferrosaco", - "iron_hands": "Ferropalmas", - "iron_jugulis": "Ferrocuello", - "iron_moth": "Ferropolilla", - "iron_thorns": "Ferropúas", - "frigibax": "Frigibax", - "arctibax": "Arctibax", - "baxcalibur": "Baxcalibur", - "gimmighoul": "Gimmighoul", - "gholdengo": "Gholdengo", - "wo_chien": "Wo-Chien", - "chien_pao": "Chien-Pao", - "ting_lu": "Ting-Lu", - "chi_yu": "Chi-Yu", - "roaring_moon": "Bramaluna", - "iron_valiant": "Ferropaladín", - "koraidon": "Koraidon", - "miraidon": "Miraidon", - "walking_wake": "Ondulagua", - "iron_leaves": "Ferroverdor", - "dipplin": "Dipplin", - "poltchageist": "Poltchageist", - "sinistcha": "Sinistcha", - "okidogi": "Okidogi", - "munkidori": "Munkidori", - "fezandipiti": "Fezandipiti", - "ogerpon": "Ogerpon", - "archaludon": "Archaludon", - "hydrapple": "Hydrapple", - "gouging_fire": "Flamariete", - "raging_bolt": "Electrofuria", - "iron_boulder": "Ferromole", - "iron_crown": "Ferrotesta", - "terapagos": "Terapagos", - "pecharunt": "Pecharunt", - "alola_rattata": "Rattata", - "alola_raticate": "Raticate", - "alola_raichu": "Raichu", - "alola_sandshrew": "Sandshrew", - "alola_sandslash": "Sandslash", - "alola_vulpix": "Vulpix", - "alola_ninetales": "Ninetales", - "alola_diglett": "Diglett", - "alola_dugtrio": "Dugtrio", - "alola_meowth": "Meowth", - "alola_persian": "Persian", - "alola_geodude": "Geodude", - "alola_graveler": "Graveler", - "alola_golem": "Golem", - "alola_grimer": "Grimer", - "alola_muk": "Muk", - "alola_exeggutor": "Exeggutor", - "alola_marowak": "Marowak", - "eternal_floette": "Floette", - "galar_meowth": "Meowth", - "galar_ponyta": "Ponyta", - "galar_rapidash": "Rapidash", - "galar_slowpoke": "Slowpoke", - "galar_slowbro": "Slowbro", - "galar_farfetchd": "Farfetch'd", - "galar_weezing": "Weezing", - "galar_mr_mime": "Mr. Mime", - "galar_articuno": "Articuno", - "galar_zapdos": "Zapdos", - "galar_moltres": "Moltres", - "galar_slowking": "Slowking", - "galar_corsola": "Corsola", - "galar_zigzagoon": "Zigzagoon", - "galar_linoone": "Linoone", - "galar_darumaka": "Darumaka", - "galar_darmanitan": "Darmanitan", - "galar_yamask": "Yamask", - "galar_stunfisk": "Stunfisk", - "hisui_growlithe": "Growlithe", - "hisui_arcanine": "Arcanine", - "hisui_voltorb": "Voltorb", - "hisui_electrode": "Electrode", - "hisui_typhlosion": "Typhlosion", - "hisui_qwilfish": "Qwilfish", - "hisui_sneasel": "Sneasel", - "hisui_samurott": "Samurott", - "hisui_lilligant": "Lilligant", - "hisui_zorua": "Zorua", - "hisui_zoroark": "Zoroark", - "hisui_braviary": "Braviary", - "hisui_sliggoo": "Sliggoo", - "hisui_goodra": "Goodra", - "hisui_avalugg": "Avalugg", - "hisui_decidueye": "Decidueye", - "paldea_tauros": "Tauros", - "paldea_wooper": "Wooper", - "bloodmoon_ursaluna": "Ursaluna" -} \ No newline at end of file diff --git a/src/locales/es/run-history.json b/src/locales/es/run-history.json deleted file mode 100644 index 99b30586621..00000000000 --- a/src/locales/es/run-history.json +++ /dev/null @@ -1,37 +0,0 @@ -{ - "victory": "¡Victoria!", - "defeatedWild": "Derrotado por ", - "defeatedTrainer": "Derrotado por ", - "defeatedTrainerDouble": "Derrotado por un dúo", - "defeatedRival": "Derrotado por el rival", - "defeated": "Derrotado", - "defeatedWild_female": "Derrotada por ", - "defeatedTrainer_female": "Derrotada por ", - "defeatedTrainerDouble_female": "Derrotada por un dúo", - "defeatedRival_female": "Derrotada por el rival", - "defeated_female": "Derrotada", - "luck": "Suerte", - "score": "Puntuación", - "mode": "Modo", - "challengeRules": "Regla(s)", - "challengeMonoGen1": "Gen I", - "challengeMonoGen2": "Gen II", - "challengeMonoGen3": "Gen III", - "challengeMonoGen4": "Gen IV", - "challengeMonoGen5": "Gen V", - "challengeMonoGen6": "Gen VI", - "challengeMonoGen7": "Gen VII", - "challengeMonoGen8": "Gen VIII", - "challengeMonoGen9": "Gen IX", - "playerItems": "Objetos del jugador", - "personalBest": "¡Récord personal!", - "SPDshortened": "Vel.", - "runInfo": "Info. de partida", - "money": "Dinero", - "runLength": "Duración de partida", - "viewHeldItems": "Objetos equipados", - "hallofFameText": "¡Bienvenido al Hall de la Fama!", - "hallofFameText_female": "¡Bienvenida al Hall de la Fama!", - "viewHallOfFame": "¡Ver Hall de la Fama!", - "viewEndingSplash": "¡Ver la imagen final!" -} \ No newline at end of file diff --git a/src/locales/es/save-slot-select-ui-handler.json b/src/locales/es/save-slot-select-ui-handler.json deleted file mode 100644 index bcb93a5c2cc..00000000000 --- a/src/locales/es/save-slot-select-ui-handler.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "overwriteData": "¿Sobrescribir los datos en la ranura seleccionada?", - "loading": "Cargando...", - "wave": "Oleada", - "lv": "Nv", - "empty": "Vacío" -} \ No newline at end of file diff --git a/src/locales/es/settings.json b/src/locales/es/settings.json deleted file mode 100644 index dc441d48eb8..00000000000 --- a/src/locales/es/settings.json +++ /dev/null @@ -1,107 +0,0 @@ -{ - "boy": "Chico", - "girl": "Chica", - "general": "General", - "display": "Pantalla", - "audio": "Audio", - "gamepad": "Mando", - "keyboard": "Teclado", - "gameSpeed": "Veloc. del juego", - "hpBarSpeed": "Veloc. barra PS", - "expGainsSpeed": "Veloc. de EXP", - "expPartyDisplay": "Mostrar EXP del Equipo", - "skipSeenDialogues": "Saltar diálogos leídos", - "battleStyle": "Estilo de lucha", - "enableRetries": "Activar reintento", - "hideIvs": "Ocultar escáner de IVs", - "tutorials": "Tutoriales", - "touchControls": "Control táctil", - "vibrations": "Vibración", - "normal": "Normal", - "fast": "+1", - "faster": "+2", - "skip": "Saltar", - "levelUpNotifications": "Aumentos de nivel", - "on": "Sí", - "off": "No", - "switch": "Cambiar", - "set": "Mantener", - "auto": "Auto.", - "disabled": "Desact.", - "language": "Idioma", - "change": "Cambiar", - "uiTheme": "Color UI", - "default": "Predet.", - "legacy": "Clásico", - "windowType": "Ventana", - "moneyFormat": "Formato dinero", - "damageNumbers": "Cifras de daño", - "simple": "Simple", - "fancy": "Elegante", - "abbreviated": "Abreviado", - "moveAnimations": "Animación de movs.", - "showStatsOnLevelUp": "Estadísticas al aum. nivel", - "candyUpgradeNotification": "Aviso de caramelos", - "passivesOnly": "Solo pasivas", - "candyUpgradeDisplay": "Muestra de caramelos", - "icon": "Icono", - "animation": "Animación", - "moveInfo": "Info. de movimientos", - "showMovesetFlyout": "Descripción de movimientos", - "showArenaFlyout": "Descripción de escenarios", - "showTimeOfDayWidget": "Mostrar hora del día", - "timeOfDayAnimation": "Animación hora del día", - "bounce": "Rebote", - "timeOfDay_back": "Vuelta", - "spriteSet": "Set de sprites", - "consistent": "Consistente", - "mixedAnimated": "Mixto", - "fusionPaletteSwaps": "Colores de fusión", - "playerGender": "Género del jugador", - "typeHints": "Pistas de tipos", - "masterVolume": "Volumen total", - "bgmVolume": "Volumen música", - "fieldVolume": "Volumen escenario", - "seVolume": "Volumen efectos", - "uiVolume": "Volumen sistema", - "musicPreference": "Preferencia musical", - "mixed": "Mixta", - "gamepadPleasePlug": "Conecta un mando o pulsa un botón", - "delete": "Eliminar", - "keyboardPleasePress": "Pulsa una tecla de tu teclado", - "reset": "Restablecer", - "requireReload": "Requiere reinicio", - "action": "Acción", - "back": "Atrás", - "pressToBind": "Pulsa para vincular", - "pressButton": "Pulsa un botón...", - "buttonUp": "Arriba", - "buttonDown": "Abajo", - "buttonLeft": "Izquierda", - "buttonRight": "Derecha", - "buttonAction": "Acción", - "buttonMenu": "Menú", - "buttonSubmit": "Confirmar", - "buttonCancel": "Cancelar", - "buttonStats": "Estadísticas", - "buttonCycleForm": "Cambiar forma", - "buttonCycleShiny": "Cambiar shiny", - "buttonCycleGender": "Cambiar género", - "buttonCycleAbility": "Cambiar habilidad", - "buttonCycleNature": "Cambiar naturaleza", - "buttonCycleVariant": "Cambiar variante", - "buttonSpeedUp": "Acelerar", - "buttonSlowDown": "Ralentizar", - "alt": " (Alt.)", - "mute": "Silenciar", - "controller": "Mando", - "gamepadSupport": "Soporte de mando", - "showBgmBar": "Mostrar título de canción", - "moveTouchControls": "Controles táctiles", - "shopOverlayOpacity": "Opacidad de la fase de compra", - "shopCursorTarget": "Cursor de la tienda", - "rewards": "Objetos", - "reroll": "Actualizar", - "shop": "Tienda", - "checkTeam": "Ver equipo" -} diff --git a/src/locales/es/splash-messages.json b/src/locales/es/splash-messages.json deleted file mode 100644 index b1d4820b06e..00000000000 --- a/src/locales/es/splash-messages.json +++ /dev/null @@ -1,36 +0,0 @@ -{ - "battlesWon": "¡Batallas ganadas!", - "joinTheDiscord": "¡Únete al Discord!", - "infiniteLevels": "¡Niveles infinitos!", - "everythingStacks": "¡Todo se acumula!", - "optionalSaveScumming": "¡Trampas de guardado opcionales!", - "biomes": "¡35 biomas!", - "openSource": "¡Código abierto!", - "playWithSpeed": "¡Juega a velocidad 5x!", - "liveBugTesting": "¡Testeo de bugs en directo!", - "heavyInfluence": "¡Mucha Influencia de RoR2!", - "pokemonRiskAndPokemonRain": "¡Pokémon Risk y Pokémon Rain!", - "nowWithMoreSalt": "¡Con un 33% más de polémica!", - "infiniteFusionAtHome": "¡Infinite Fusion en casa!", - "brokenEggMoves": "¡Movimientos Huevo rotos!", - "magnificent": "¡Magnífico!", - "mubstitute": "¡Mubstituto!", - "thatsCrazy": "¡De locos!", - "oranceJuice": "¡Zumo de narancia!", - "questionableBalancing": "¡Cambios en balance cuestionables!", - "coolShaders": "¡Shaders impresionantes!", - "aiFree": "¡Libre de IA!", - "suddenDifficultySpikes": "¡Saltos de dificultad repentinos!", - "basedOnAnUnfinishedFlashGame": "¡Basado en un juego Flash inacabado!", - "moreAddictiveThanIntended": "¡Más adictivo de lo previsto!", - "mostlyConsistentSeeds": "¡Semillas CASI consistentes!", - "achievementPointsDontDoAnything": "¡Los Puntos de Logro no hacen nada!", - "youDoNotStartAtLevel": "¡No empiezas al nivel 2000!", - "dontTalkAboutTheManaphyEggIncident": "¡No se habla del Incidente Manaphy!", - "alsoTryPokengine": "¡Prueba también Pokéngine!", - "alsoTryEmeraldRogue": "¡Prueba también Emerald Rogue!", - "alsoTryRadicalRed": "¡Prueba también Radical Red!", - "eeveeExpo": "¡Eevee Expo!", - "ynoproject": "¡YNOproject!", - "breedersInSpace": "Criadores... ¡EN EL ESPACIO!" -} diff --git a/src/locales/es/starter-select-ui-handler.json b/src/locales/es/starter-select-ui-handler.json deleted file mode 100644 index 69cc937d4e3..00000000000 --- a/src/locales/es/starter-select-ui-handler.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "confirmStartTeam": "¿Comenzar con estos Pokémon?", - "invalidParty": "¡Este equipo no es válido!", - "gen1": "I", - "gen2": "II", - "gen3": "III", - "gen4": "IV", - "gen5": "V", - "gen6": "VI", - "gen7": "VII", - "gen8": "VIII", - "gen9": "IX", - "growthRate": "Crecimiento:", - "ability": "Habilid:", - "passive": "Pasiva:", - "nature": "Natur:", - "eggMoves": "Mov. Huevo", - "addToParty": "Añadir al Equipo", - "removeFromParty": "Excluir del Equipo", - "toggleIVs": "Mostrar IVs", - "manageMoves": "Cambiar movs.", - "manageNature": "Cambiar natur.", - "useCandies": "Usar Caramelos", - "selectNature": "Elige Natur.", - "selectMoveSwapOut": "Elige el movimiento que sustituir.", - "selectMoveSwapWith": "Elige el movimiento que sustituirá a", - "unlockPassive": "Añadir Pasiva", - "reduceCost": "Reducir Coste", - "cycleShiny": ": Shiny", - "cycleForm": ": Forma", - "cycleGender": ": Género", - "cycleAbility": ": Habilidad", - "cycleNature": ": Naturaleza", - "cycleVariant": ": Variante", - "goFilter": ": Ir a filtros", - "enablePassive": "Activar Pasiva", - "disablePassive": "Desactivar Pasiva", - "locked": "Bloqueado", - "disabled": "No disponible", - "uncaught": "No capturado" -} \ No newline at end of file diff --git a/src/locales/es/status-effect.json b/src/locales/es/status-effect.json deleted file mode 100644 index eeb8c251e8a..00000000000 --- a/src/locales/es/status-effect.json +++ /dev/null @@ -1,65 +0,0 @@ -{ - "none": { - "name": "Ninguno", - "description": "", - "obtain": "", - "obtainSource": "", - "activation": "", - "overlap": "", - "heal": "" - }, - "poison": { - "name": "Envenenamiento", - "description": "envenenamiento", - "obtain": "¡{{pokemonNameWithAffix}}\nha sido envenenado!", - "obtainSource": "¡{{pokemonNameWithAffix}}\nha sido envenenado por {{sourceText}}!", - "activation": "¡El veneno resta PS a {{pokemonNameWithAffix}}!", - "overlap": "¡{{pokemonNameWithAffix}} ya\nestá envenenado!", - "heal": "¡{{pokemonNameWithAffix}} ya no\nestá envenenado!" - }, - "toxic": { - "name": "Envenenamiento grave", - "description": "envenenamiento grave", - "obtain": "¡{{pokemonNameWithAffix}}\nha sido gravemente envenenado!", - "obtainSource": "¡{{pokemonNameWithAffix}}\nha sido gravemente envenenado por {{sourceText}}!", - "activation": "¡El veneno resta PS a {{pokemonNameWithAffix}}!", - "overlap": "¡{{pokemonNameWithAffix}} ya\nestá envenenado!", - "heal": "¡{{pokemonNameWithAffix}} ya no\nestá envenenado!" - }, - "paralysis": { - "name": "Parálisis", - "description": "parálisis", - "obtain": "¡{{pokemonNameWithAffix}} sufre parálisis!\nQuizás no se pueda mover.", - "obtainSource": "¡{{pokemonNameWithAffix}} sufre parálisis por {{sourceText}}!\nQuizás no se pueda mover.", - "activation": "¡{{pokemonNameWithAffix}} está paralizado!\n¡No se puede mover!", - "overlap": "¡{{pokemonNameWithAffix}} ya\nestá paralizado!", - "heal": "¡{{pokemonNameWithAffix}} ya no\nestá paralizado!" - }, - "sleep": { - "name": "Dormir", - "description": "dormir", - "obtain": "¡{{pokemonNameWithAffix}}\nse ha dormido!", - "obtainSource": "¡{{pokemonNameWithAffix}}\nse ha dormido\npor culpa de {{sourceText}}!", - "activation": "¡{{pokemonNameWithAffix}} está/ndormido como un tronco.", - "overlap": "¡{{pokemonNameWithAffix}} ya\nestá dormido!", - "heal": "¡{{pokemonNameWithAffix}} se despertó!" - }, - "freeze": { - "name": "Congelamiento", - "description": "congelamiento", - "obtain": "¡{{pokemonNameWithAffix}}\nha sido congelado!", - "obtainSource": "¡{{pokemonNameWithAffix}}\nha sido congelado por {{sourceText}}!", - "activation": "¡{{pokemonNameWithAffix}} está\ncongelado!", - "overlap": "¡{{pokemonNameWithAffix}} ya\nestá congelado!", - "heal": "¡{{pokemonNameWithAffix}} se\nha descongelado!" - }, - "burn": { - "name": "Quemadura", - "description": "quemadura", - "obtain": "¡{{pokemonNameWithAffix}}\nse ha quemado!", - "obtainSource": "¡{{pokemonNameWithAffix}}\nse ha quemado por {{sourceText}}!", - "activation": "¡{{pokemonNameWithAffix}} se resiente\nde las quemaduras!", - "overlap": "¡{{pokemonNameWithAffix}} ya\nestá quemado!", - "heal": "¡{{pokemonNameWithAffix}} ya no\nestá quemado!" - } -} \ No newline at end of file diff --git a/src/locales/es/terrain.json b/src/locales/es/terrain.json deleted file mode 100644 index 912f5186180..00000000000 --- a/src/locales/es/terrain.json +++ /dev/null @@ -1,16 +0,0 @@ -{ - "misty": "Niebla", - "mistyStartMessage": "¡La niebla ha envuelto el terreno de combate!", - "mistyClearMessage": "La niebla se ha disipado.", - "mistyBlockMessage": "¡El campo de niebla ha protegido a {{pokemonNameWithAffix}} ", - "electric": "Eléctrico", - "electricStartMessage": "¡Se ha formado un campo de corriente eléctrica en el terreno\nde combate!", - "electricClearMessage": "El campo de corriente eléctrica ha desaparecido.\t", - "grassy": "Hierba", - "grassyStartMessage": "¡El terreno de combate se ha cubierto de hierba!", - "grassyClearMessage": "La hierba ha desaparecido.", - "psychic": "Psíquico", - "psychicStartMessage": "¡El terreno de combate se ha vuelto muy extraño!", - "psychicClearMessage": "Ha desaparecido la extraña sensación que se percibía en el terreno\nde combate.", - "defaultBlockMessage": "¡El campo {{terrainName}} ha protegido a {{pokemonNameWithAffix}} " -} diff --git a/src/locales/es/trainer-classes.json b/src/locales/es/trainer-classes.json deleted file mode 100644 index 0677193e4f8..00000000000 --- a/src/locales/es/trainer-classes.json +++ /dev/null @@ -1,102 +0,0 @@ -{ - "ace_trainer": "Entrenador Guay", - "ace_trainer_female": "Entrenadora Guay", - "ace_duo": "Pareja Guay", - "artist": "Artista", - "artist_female": "Artista", - "backers": "Hinchas", - "backpacker": "Mochilero", - "backpacker_female": "Mochilera", - "backpackers": "Mochileros", - "baker": "Pastelera", - "battle_girl": "Luchadora", - "beauty": "Modelo", - "beginners": "Principiantes", - "biker": "Motorista", - "black_belt": "Karateka", - "breeder": "Criapokémon", - "breeder_female": "Criapokémon", - "breeders": "Criadores", - "clerk": "Empresario", - "clerk_female": "Oficinista", - "colleagues": "Colegas Oficina", - "crush_kin": "Luchadores", - "cyclist": "Ciclista", - "cyclist_female": "Ciclista", - "cyclists": "Ciclistas", - "dancer": "Breakdancer", - "dancer_female": "Bailarina", - "depot_agent": "Ferroviario", - "doctor": "Enfermero", - "doctor_female": "Enfermera", - "firebreather": "Comefuegos", - "fisherman": "Pescador", - "fisherman_female": "Pescadora", - "gentleman": "Aristócrata", - "guitarist": "Guitarrista", - "guitarist_female": "Guitarrista", - "harlequin": "Arlequín", - "hiker": "Montañero", - "hooligans": "Pandilleros", - "hoopster": "Pívot", - "infielder": "Pitcher", - "janitor": "Limpiador", - "lady": "Damisela", - "lass": "Chica", - "linebacker": "Quarterback", - "maid": "Criada", - "madame": "Señora", - "medical_team": "Equipo Médico", - "musician": "Cantautor", - "hex_maniac": "Bruja", - "nurse": "Enfermera", - "nursery_aide": "Seño", - "officer": "Policía", - "parasol_lady": "Dama Parasol", - "pilot": "Piloto", - "pokéfan": "Pokéfan", - "pokéfan_female": "Pokéfan", - "pokéfan_family": "Pareja de Pokéfans", - "preschooler": "Preescolar", - "preschooler_female": "Preescolar", - "preschoolers": "Preescolares", - "psychic": "Médium", - "psychic_female": "Mentalista", - "psychics": "Pareja Médium", - "restaurant_staff": "Personal Restaurante", - "rich": "Bien", - "rich_female": "Bien", - "rich_boy": "Niño Bien", - "rich_couple": "Pareja Bien", - "rich_kid": "Niño Bien", - "rich_kid_female": "Niña Bien", - "rich_kids": "Niños Bien", - "roughneck": "Calvo", - "sailor": "Marinero", - "scientist": "Científico", - "scientist_female": "Científica", - "scientists": "Científicos", - "smasher": "Tenista", - "snow_worker": "Operario Nieve", - "snow_worker_female": "Operaria Nieve", - "striker": "Delantero", - "school_kid": "Colegial", - "school_kid_female": "Colegial", - "school_kids": "Colegiales", - "swimmer": "Nadador", - "swimmer_female": "Nadadora", - "swimmers": "Nadadores", - "twins": "Gemelas", - "veteran": "Veterano", - "veteran_female": "Veterana", - "veteran_duo": "Dúo Veterano", - "waiter": "Camarero", - "waitress": "Camarera", - "worker": "Operario", - "worker_female": "Operaria", - "workers": "Operarios", - "youngster": "Joven", - "aether_grunt": "Empleado de la Fundación Æther", - "aether_grunt_female": "Empleada de la Fundación Æther", - "aether_grunts": "Empleados de la Fundación Æther" -} diff --git a/src/locales/es/trainer-names.json b/src/locales/es/trainer-names.json deleted file mode 100644 index ce09a0c9037..00000000000 --- a/src/locales/es/trainer-names.json +++ /dev/null @@ -1,158 +0,0 @@ -{ - "brock": "Brock", - "misty": "Misty", - "lt_surge": "Teniente Surge", - "erika": "Erika", - "janine": "Sachiko", - "sabrina": "Sabrina", - "blaine": "Blaine", - "giovanni": "Giovanni", - "falkner": "Pegaso", - "bugsy": "Antón", - "whitney": "Blanca", - "morty": "Morti", - "chuck": "Aníbal", - "jasmine": "Yasmina", - "pryce": "Fredo", - "clair": "Débora", - "roxanne": "Petra", - "brawly": "Marcial", - "wattson": "Erico", - "flannery": "Candela", - "norman": "Norman", - "winona": "Alana", - "tate": "Vito", - "liza": "Leti", - "juan": "Galano", - "roark": "Roco", - "gardenia": "Gardenia", - "maylene": "Brega", - "crasher_wake": "Mananti", - "fantina": "Fantina", - "byron": "Acerón", - "candice": "Inverna", - "volkner": "Lectro", - "cilan": "Millo", - "chili": "Zeo", - "cress": "Maíz", - "cheren": "Cheren", - "lenora": "Aloe", - "roxie": "Hiedra", - "burgh": "Camus", - "elesa": "Camila", - "clay": "Yakón", - "skyla": "Gerania", - "brycen": "Junco", - "drayden": "Lirio", - "marlon": "Ciprián", - "viola": "Violeta", - "grant": "Lino", - "korrina": "Corelia", - "ramos": "Amaro", - "clemont": "Lem", - "valerie": "Valeria", - "olympia": "Ástrid", - "wulfric": "Édel", - "milo": "Percy", - "nessa": "Cathy", - "kabu": "Naboru", - "bea": "Judith", - "allister": "Alistair", - "opal": "Sally", - "bede": "Berto", - "gordie": "Morris", - "melony": "Mel", - "piers": "Nerio", - "marnie": "Roxy", - "raihan": "Roy", - "katy": "Araceli", - "brassius": "Brais", - "iono": "e-Nigma", - "kofu": "Fuco", - "larry": "Laureano", - "ryme": "Lima", - "tulip": "Tuli", - "grusha": "Grusha", - "lorelei": "Lorelei", - "bruno": "Bruno", - "agatha": "Agatha", - "lance": "Lance", - "will": "Mento", - "koga": "Koga", - "karen": "Karen", - "sidney": "Sixto", - "phoebe": "Fátima", - "glacia": "Nívea", - "drake": "Dracón", - "aaron": "Alecrán", - "bertha": "Gaia", - "flint": "Fausto", - "lucian": "Delos", - "shauntal": "Anís", - "marshal": "Lotto", - "grimsley": "Aza", - "caitlin": "Catleya", - "malva": "Malva", - "siebold": "Narciso", - "wikstrom": "Tileo", - "drasna": "Drácena", - "hala": "Kaudan", - "molayne": "Lario", - "olivia": "Mayla", - "acerola": "Zarala", - "kahili": "Kahili", - "rika": "Cayena", - "poppy": "Pola", - "hassel": "Hesperio", - "crispin": "Denis", - "amarys": "Nerina", - "lacey": "Aroa", - "drayton": "Levi", - "blue": "Azul", - "red": "Rojo", - "steven": "Máximo", - "wallace": "Plubio", - "cynthia": "Cintia", - "alder": "Mirto", - "iris": "Iris", - "diantha": "Dianta", - "hau": "Tilo", - "geeta": "Ságita", - "nemona": "Mencía", - "kieran": "Cass", - "leon": "Lionel", - "rival": "Finn", - "rival_female": "Ivy", - "archer": "Atlas", - "ariana": "Atenea", - "proton": "Protón", - "petrel": "Petrel", - "tabitha": "Tatiano", - "courtney": "Carola", - "shelly": "Silvina", - "matt": "Matías", - "mars": "Venus", - "jupiter": "Ceres", - "saturn": "Saturno", - "zinzolin": "Menek", - "rood": "Ruga", - "xerosic": "Xero", - "bryony": "Begonia", - "maxie": "Magno", - "archie": "Aquiles", - "cyrus": "Helio", - "ghetsis": "Ghechis", - "lysandre": "Lysson", - "faba": "Fabio", - "lusamine": "Samina", - "blue_red_double": "Azul y Rojo", - "red_blue_double": "Rojo y Azul", - "tate_liza_double": "Vito y Leti", - "liza_tate_double": "Leti y Vito", - "steven_wallace_double": "Máximo y Plubio", - "wallace_steven_double": "Plubio y Máximo", - "alder_iris_double": "Mirto e Iris", - "iris_alder_double": "Iris y Mirto", - "marnie_piers_double": "Roxy y Nerio", - "piers_marnie_double": "Nerio y Roxy" -} diff --git a/src/locales/es/trainer-titles.json b/src/locales/es/trainer-titles.json deleted file mode 100644 index 5bee9fc8c51..00000000000 --- a/src/locales/es/trainer-titles.json +++ /dev/null @@ -1,34 +0,0 @@ -{ - "elite_four": "Alto Mando", - "elite_four_female": "Alto Mando", - "gym_leader": "Líder de gimnasio", - "gym_leader_female": "Líder de gimnasio", - "gym_leader_double": "Líderes de Gimnasio", - "champion": "Campeón", - "champion_female": "Campeona", - "champion_double": "Campeones", - "rival": "Rival", - "professor": "Profesor", - "frontier_brain": "As del Frente Batalla", - "rocket_boss": "Team Rocket Boss", - "magma_boss": "Team Magma Boss", - "aqua_boss": "Team Aqua Boss", - "galactic_boss": "Team Galactic Boss", - "plasma_boss": "Team Plasma Boss", - "flare_boss": "Team Flare Boss", - "aether_boss": "Presidente Æther", - - "rocket_admin": "Team Rocket Admin", - "rocket_admin_female": "Team Rocket Admin", - "magma_admin": "Team Magma Admin", - "magma_admin_female": "Team Magma Admin", - "aqua_admin": "Team Aqua Admin", - "aqua_admin_female": "Team Aqua Admin", - "galactic_commander": "Team Galactic Commander", - "galactic_commander_female": "Team Galactic Commander", - "plasma_sage": "Team Plasma Sage", - "plasma_admin": "Team Plasma Admin", - "flare_admin": "Team Flare Admin", - "flare_admin_female": "Team Flare Admin", - "aether_admin": "Director de la Fundación Æther" -} diff --git a/src/locales/es/tutorial.json b/src/locales/es/tutorial.json deleted file mode 100644 index e19dbcf09ad..00000000000 --- a/src/locales/es/tutorial.json +++ /dev/null @@ -1,10 +0,0 @@ -{ - "intro": "¡Bienvenido/a a PokéRogue! Este es un fangame de Pokémon centrado en el combate con elementos roguelite.\n$Este juego no está monetizado y no reclamamos ningún derecho de propiedad sobre Pokémon ni sobre ninguno de\n$los recursos con copyright utilizados.\n$El juego está en desarrollo, pero es completamente jugable.\nPara reportar bugs, por favor, hazlo en nuestra\n$comunidad de Discord.\n$Si el juego va lento, por favor, asegúrate de que tengas activada la opción 'Aceleración de gráficos' en los\n$ajustes de tu navegador.", - "accessMenu": "Para acceder al menú, pulsa M o Escape cuando\ntengas el control.\n$El menú contiene los ajustes y otras funciones.", - "menu": "Desde este menú podrás acceder a los ajustes.\n$Podrás cambiar la velocidad del juego, el estilo de la ventana y demás.\n$Hay más opciones, ¡así que pruébalas todas!", - "starterSelect": "En esta pantalla, podrás elegir tus iniciales presionando Z\no Espacio. Estos serán tus miembros de equipo al comenzar.\n$Cada inicial tiene un valor. Tu equipo puede contener hasta 6\nmiembros mientras el valor total no pase de 10.\n$También puedes elegir su género, habilidad y forma\ndependiendo de las variantes que hayas conseguido.\n$Los IVs de los iniciales corresponderán al valor más alto de\nlos Pokémon de la misma especie que hayas obtenido.\n$¡Así que intenta conseguir muchos Pokémon de la misma\nespecie!", - "pokerus": "Cada día, 3 iniciales aleatorios tendrán un borde morado.\n$Si ves un inicial que tengas con este borde, prueba a\nañadirlo a tu equipo. ¡No olvides revisar sus datos!", - "statChange": "Los cambios de estadísticas se mantienen entre combates\nmientras que el Pokémon no vuelva a su Poké Ball.\n$Tus Pokémon vuelven a sus Poké Balls antes de combates contra entrenadores y de entrar a un nuevo bioma.\n$También puedes ver los cambios de estadísticas del Pokémon en campo manteniendo pulsado C o Shift.\n$También puedes ver los movimientos de un Pokémon enemigo manteniendo presionada la V.\n$Esto solo revela los movimientos que has visto usar al Pokémon en esta combate.", - "selectItem": "Tras cada combate, tendrás la opción de elegir entre tres objetos aleatorios. Solo podrás escoger uno.\n$Estos objetos pueden ser consumibles, objetos equipables u objetos pasivos permanentes (hasta acabar la partida).\n$La mayoría de los efectos de objetos no consumibles se acumularán de varias maneras.\n$Algunos objetos solo aparecerán si pueden ser utilizados, como las piedras evolutivas.\n$También puedes transferir objetos equipados entre Pokémon, utilizando la opción de transferir.\n$La opción de transferir aparecerá en la parte inferior derecha una vez hayas obtenido un objeto equipable.\n$También puedes comprar objetos consumibles con dinero y su variedad irá aumentando según tu avance.\n$Asegúrate de comprar antes de escoger una recompensa, ya que se avanzará automáticamente al siguiente combate.", - "eggGacha": "En esta pantalla podrás canjear tus vales por huevos\nde Pokémon.\n$Los huevos deben eclosionar y estarán más cerca de\nhacerlo tras cada combate.\n$Los huevos más raros tardarán más en eclosionar.\n$Los Pokémon que hayan salido del huevo no se\nañadirán a tu equipo, pero sí a tus iniciales.\n$Los Pokémon salidos de un huevo suelen tener mejores\nIVs que los Pokémon salvajes.\n$Algunos Pokémon solo pueden ser obtenidos de huevos.\n$Hay 3 máquinas diferentes entre las que elegir, cada\nuna con diferentes bonificaciones.\n$¡Así que escoge la que más te interese!" -} \ No newline at end of file diff --git a/src/locales/es/voucher.json b/src/locales/es/voucher.json deleted file mode 100644 index e55c791c94a..00000000000 --- a/src/locales/es/voucher.json +++ /dev/null @@ -1,9 +0,0 @@ -{ - "vouchers": "Vales", - "eggVoucher": "Vale Huevo", - "eggVoucherPlus": "Vale Huevo Plus", - "eggVoucherPremium": "Vale Huevo Premium", - "eggVoucherGold": "Vale Huevo Dorado", - "locked": "Bloqueado", - "defeatTrainer": "Derrota a {{trainerName}}" -} \ No newline at end of file diff --git a/src/locales/es/weather.json b/src/locales/es/weather.json deleted file mode 100644 index 44716a165dd..00000000000 --- a/src/locales/es/weather.json +++ /dev/null @@ -1,32 +0,0 @@ -{ - "sunnyStartMessage": "¡El sol esta brillando!", - "sunnyLapseMessage": "Hace mucho sol...", - "sunnyClearMessage": "Se ha ido el sol.", - "rainStartMessage": "¡Ha empezado a llover!", - "rainLapseMessage": "Sigue lloviendo...", - "rainClearMessage": "Ha dejado de llover.", - "sandstormStartMessage": "¡Se ha desatado una tormenta de arena!", - "sandstormLapseMessage": "La tormenta de arena arrecia...", - "sandstormClearMessage": "La tormenta de arena termino.", - "sandstormDamageMessage": "¡La tormenta de arena zarandea al\n{{pokemonNameWithAffix}}!", - "hailStartMessage": "¡Ha empezado a granizar!", - "hailLapseMessage": "Sigue granizando...", - "hailClearMessage": "Had dejado de granizar.", - "hailDamageMessage": "El granizo golpea al\n{{pokemonNameWithAffix}}!", - "snowStartMessage": "¡Ha empezado a nevar!", - "snowLapseMessage": "Sigue nevando...", - "snowClearMessage": "Ha dejado de nevar.", - "fogStartMessage": "La niebla es densa...", - "fogLapseMessage": "Sigue la niebla...", - "fogClearMessage": "La niebla ha desaparecido.", - "heavyRainStartMessage": "¡Ha empezado a diluviar!", - "heavyRainLapseMessage": "Sigue diluviando...", - "heavyRainClearMessage": "Ha dejado de diluviar.", - "harshSunStartMessage": "¡El sol que hace ahora es realmente abrasador!", - "harshSunLapseMessage": "El sol sigue abrasando.", - "harshSunClearMessage": "El sol vuelve a brillar como siempre.", - "strongWindsStartMessage": "¡Comenzó un fuerte viento!", - "strongWindsLapseMessage": "El viento sopla intensamente.", - "strongWindsEffectMessage": "¡Las misteriosas turbulencias atenúan el ataque!", - "strongWindsClearMessage": "El fuerte viento cesó." -} \ No newline at end of file diff --git a/src/locales/fr/ability-trigger.json b/src/locales/fr/ability-trigger.json deleted file mode 100644 index 761242b3d94..00000000000 --- a/src/locales/fr/ability-trigger.json +++ /dev/null @@ -1,64 +0,0 @@ -{ - "blockRecoilDamage": "{{abilityName}}\nde {{pokemonName}} le protège du contrecoup !", - "badDreams": "{{pokemonName}} a le sommeil agité !", - "costar": "{{pokemonName}} copie les changements de stats\nde {{allyName}} !", - "iceFaceAvoidedDamage": "{{pokemonNameWithAffix}} évite les dégâts\navec {{abilityName}} !", - "perishBody": "{{abilityName}} de {{pokemonName}}\nmettra les deux Pokémon K.O. dans trois tours !", - "poisonHeal": "{{abilityName}} de {{pokemonName}}\nrestaure un peu ses PV !", - "trace": "{{pokemonName}} copie le talent {{abilityName}}\nde {{targetName}} !", - "windPowerCharged": "{{pokemonName}} a été touché par la capacité {{moveName}} et se charge en électricité !", - "quickDraw": "Tir Vif permet à {{pokemonName}}\nd’agir plus vite que d’habitude !", - "blockItemTheft": "{{abilityName}} de {{pokemonNameWithAffix}}\nempêche son objet d’être volé !", - "typeImmunityHeal": "{{abilityName}} de {{pokemonNameWithAffix}}\nrestaure un peu ses PV !", - "nonSuperEffectiveImmunity": "{{pokemonNameWithAffix}} évite\nles dégâts avec {{abilityName}} !", - "fullHpResistType": "{{pokemonNameWithAffix}} fait briller sa carapace\net fausse les affinités de type !", - "disguiseAvoidedDamage": "Le déguisement de {{pokemonNameWithAffix}}\ntombe !", - "moveImmunity": "Ça n’affecte pas {{pokemonNameWithAffix}}…", - "reverseDrain": "{{pokemonNameWithAffix}} aspire\nle suintement !", - "postDefendTypeChange": "{{abilityName}} de {{pokemonNameWithAffix}}\nle transforme en type {{typeName}} !", - "postDefendContactDamage": "{{pokemonNameWithAffix}} est blessé\npar son talent {{abilityName}} !", - "postDefendAbilitySwap": "{{pokemonNameWithAffix}} et sa cible\néchangent leurs talents !", - "postDefendAbilityGive": "{{pokemonNameWithAffix}} donne\nle talent {{abilityName}} à sa cible !", - "postDefendMoveDisable": "La capacité {{moveName}}\nde {{pokemonNameWithAffix}} est mise sous entrave !", - "pokemonTypeChange": "{{pokemonNameWithAffix}} prend\nle type {{moveType}} !", - "postAttackStealHeldItem": "{{pokemonNameWithAffix}} vole\nl’objet {{stolenItemType}} de {{defenderName}} !", - "postDefendStealHeldItem": "{{pokemonNameWithAffix}} vole\nl’objet {{stolenItemType}} de {{attackerName}} !", - "copyFaintedAllyAbility": "{{pokemonNameWithAffix}} reçoit\nle talent {{abilityName}} !", - "intimidateImmunity": "{{abilityName}} de {{pokemonNameWithAffix}}\nl’empêche d’être intimidé !", - "postSummonAllyHeal": "{{pokemonNameWithAffix}} boit le thé\npréparé par {{pokemonName}} !", - "postSummonClearAllyStats": "Les stats de {{pokemonNameWithAffix}}\nsont revenues à la normale !", - "postSummonTransform": "{{pokemonNameWithAffix}} prend\nl’apparence de {{targetName}} !", - "protectStat": "{{abilityName}} de {{pokemonNameWithAffix}}\nempêche {{statName}} de baisser !", - "statusEffectImmunityWithName": "{{abilityName}} de {{pokemonNameWithAffix}}\nl’empêche d’être {{statusEffectName}} !", - "statusEffectImmunity": "{{abilityName}} de {{pokemonNameWithAffix}}\nempêche tout problème de statut !", - "battlerTagImmunity": "{{abilityName}} de {{pokemonNameWithAffix}}\nempêche {{battlerTagName}} !", - "forewarn": "La capacité {{moveName}}\nde {{pokemonNameWithAffix}} a été détectée !", - "frisk": "{{pokemonNameWithAffix}} fouille {{opponentName}}\net trouve son talent {{opponentAbilityName}} !", - "postWeatherLapseHeal": "{{abilityName}} de {{pokemonNameWithAffix}}\nrestaure un peu ses PV !", - "postWeatherLapseDamage": "{{pokemonNameWithAffix}} est blessé\npar son talent {{abilityName}} !", - "postTurnLootCreateEatenBerry": "{{pokemonNameWithAffix}} a récolté\nune {{berryName}} !", - "postTurnHeal": "{{abilityName}} de {{pokemonNameWithAffix}}\nrestaure un peu ses PV !", - "fetchBall": "{{pokemonNameWithAffix}} trouve\nune {{pokeballName}} !", - "healFromBerryUse": "{{abilityName}} de {{pokemonNameWithAffix}}\nrestaure un peu ses PV !", - "arenaTrap": "{{pokemonNameWithAffix}} empêche\nles changements grâce à son talent {{abilityName}} !", - "postBattleLoot": "{{pokemonNameWithAffix}} ramasse\nl’objet {{itemName}} !", - "postFaintContactDamage": "{{pokemonNameWithAffix}} est blessé\npar son talent {{abilityName}} !", - "postFaintHpDamage": "{{pokemonNameWithAffix}} est blessé\npar son talent {{abilityName}} !", - "postSummonPressure": "{{pokemonNameWithAffix}}\naugmente la pression !", - "weatherEffectDisappeared": "Les effets de la météo se dissipent !", - "postSummonMoldBreaker": "{{pokemonNameWithAffix}}\nbrise le moule !", - "postSummonAnticipation": "{{pokemonNameWithAffix}}\nest tout tremblant !", - "postSummonTurboblaze": "{{pokemonNameWithAffix}} dégage\nune aura de flammes incandescentes !", - "postSummonTeravolt": "{{pokemonNameWithAffix}} dégage\nune aura électrique instable !", - "postSummonDarkAura": "{{pokemonNameWithAffix}} dégage\nune aura ténébreuse !", - "postSummonFairyAura": "{{pokemonNameWithAffix}} dégage\nune aura enchanteresse !", - "postSummonAuraBreak": "{{pokemonNameWithAffix}} inverse\ntoutes les auras !", - "postSummonNeutralizingGas": "Le gaz inhibiteur {{pokemonNameWithAffix}}\nenvahit les lieux !", - "postSummonAsOneGlastrier": "{{pokemonNameWithAffix}}\na deux talents !", - "postSummonAsOneSpectrier": "{{pokemonNameWithAffix}}\na deux talents !", - "postSummonVesselOfRuin": "L’Urne du Fléau de {{pokemonNameWithAffix}}\naffaiblit l’{{statName}} des Pokémon alentour !", - "postSummonSwordOfRuin": "L’Épée du Fléau de {{pokemonNameWithAffix}}\naffaiblit la {{statName}} des Pokémon alentour !", - "postSummonTabletsOfRuin": "Le Bois du Fléau de {{pokemonNameWithAffix}}\naffaiblit l’{{statName}} des Pokémon alentour !", - "postSummonBeadsOfRuin": "Les Perles du Fléau de {{pokemonNameWithAffix}}\naffaiblissent la {{statName}} des Pokémon alentour !", - "preventBerryUse": "{{pokemonNameWithAffix}} est tendu\net ne peut plus manger de Baies !" -} diff --git a/src/locales/fr/ability.json b/src/locales/fr/ability.json deleted file mode 100644 index 7db44c45fa7..00000000000 --- a/src/locales/fr/ability.json +++ /dev/null @@ -1,1242 +0,0 @@ -{ - "stench": { - "name": "Puanteur", - "description": "Le Pokémon émet une odeur si nauséabonde qu’il peut effrayer sa cible en l’attaquant." - }, - "drizzle": { - "name": "Crachin", - "description": "Le Pokémon invoque la pluie quand il entre au combat." - }, - "speedBoost": { - "name": "Turbo", - "description": "La Vitesse du Pokémon augmente à chaque tour." - }, - "battleArmor": { - "name": "Armurbaston", - "description": "Le Pokémon est protégé des coups critiques par une solide carapace." - }, - "sturdy": { - "name": "Fermeté", - "description": "Le Pokémon encaisse toujours au moins une attaque s’il a tous ses PV. Il est également immunisé contre les capacités pouvant mettre K.O. en un coup." - }, - "damp": { - "name": "Moiteur", - "description": "Le Pokémon augmente l’humidité de l’air, ce qui empêche tous les Pokémon d’utiliser des capacités explosives telles que Destruction." - }, - "limber": { - "name": "Échauffement", - "description": "Le Pokémon s’est suffisamment échauffé, ce qui l’immunise contre la paralysie." - }, - "sandVeil": { - "name": "Voile Sable", - "description": "Augmente l’Esquive du Pokémon lors des tempêtes de sable." - }, - "static": { - "name": "Statik", - "description": "Le Pokémon charge son corps en électricité statique, et tout contact avec lui peut paralyser." - }, - "voltAbsorb": { - "name": "Absorbe-Volt", - "description": "Si le Pokémon est touché par une capacité Électrik, il ne subit aucun dégât et regagne des PV à la place." - }, - "waterAbsorb": { - "name": "Absorbe-Eau", - "description": "Si le Pokémon est touché par une capacité Eau, il ne subit aucun dégât et regagne des PV à la place." - }, - "oblivious": { - "name": "Benêt", - "description": "Le Pokémon est un grand benêt, ce qui l’immunise contre l’attraction, la provocation ou l’intimidation." - }, - "cloudNine": { - "name": "Ciel Gris", - "description": "Annule tous les effets liés à la météo." - }, - "compoundEyes": { - "name": "Œil Composé", - "description": "Les yeux à facettes du Pokémon augmentent la Précision de ses capacités." - }, - "insomnia": { - "name": "Insomnia", - "description": "Le Pokémon est incapable de dormir." - }, - "colorChange": { - "name": "Homochromie", - "description": "Lorsque le Pokémon est touché par une capacité, il prend le type de celle-ci." - }, - "immunity": { - "name": "Vaccin", - "description": "Le Pokémon est naturellement immunisé contre toute forme de poison." - }, - "flashFire": { - "name": "Torche", - "description": "Lorsque le Pokémon est touché par une capacité de type Feu, il absorbe la chaleur pour renforcer ses propres capacités Feu." - }, - "shieldDust": { - "name": "Écran Poudre", - "description": "Le Pokémon dispose d’un écran naturel qui le protège des effets additionnels des attaques ennemies." - }, - "ownTempo": { - "name": "Tempo Perso", - "description": "Le Pokémon vit sa vie à son propre rythme, ce qui l’immunise contre la confusion et l’intimidation." - }, - "suctionCups": { - "name": "Ventouse", - "description": "Le Pokémon est solidement fixé au sol par des ventouses, ce qui le protège des capacités ou objets qui font changer de Pokémon." - }, - "intimidate": { - "name": "Intimidation", - "description": "Le Pokémon rugit lorsqu’il arrive au combat, ce qui intimide l’ennemi et baisse son Attaque." - }, - "shadowTag": { - "name": "Marque Ombre", - "description": "Empêche les Pokémon ennemis de quitter le terrain." - }, - "roughSkin": { - "name": "Peau Dure", - "description": "Blesse l’attaquant lorsque le Pokémon subit une attaque directe." - }, - "wonderGuard": { - "name": "Garde Mystik", - "description": "Une puissance mystérieuse protège le Pokémon contre toutes les capacités, sauf celles qui sont super efficaces." - }, - "levitate": { - "name": "Lévitation", - "description": "Le Pokémon flotte, ce qui l’immunise contre les capacités de type Sol." - }, - "effectSpore": { - "name": "Pose Spore", - "description": "Peut paralyser, empoisonner ou endormir l’attaquant lorsque le Pokémon subit une attaque directe." - }, - "synchronize": { - "name": "Synchro", - "description": "Quand le Pokémon est brulé, paralysé ou empoisonné par un autre Pokémon, il partage ce statut avec celui-ci." - }, - "clearBody": { - "name": "Corps Sain", - "description": "Empêche les stats du Pokémon de baisser à cause du talent ou d’une capacité de l’adversaire." - }, - "naturalCure": { - "name": "Médic Nature", - "description": "Le Pokémon soigne ses altérations de statut en quittant le combat." - }, - "lightningRod": { - "name": "Paratonnerre", - "description": "Le Pokémon détourne sur lui les capacités de type Électrik et les neutralise, tout en augmentant son Attaque Spéciale." - }, - "sereneGrace": { - "name": "Sérénité", - "description": "Augmente les chances d’infliger des effets additionnels." - }, - "swiftSwim": { - "name": "Glissade", - "description": "Augmente la Vitesse du Pokémon s’il pleut." - }, - "chlorophyll": { - "name": "Chlorophylle", - "description": "Augmente la Vitesse du Pokémon s’il y a du soleil." - }, - "illuminate": { - "name": "Lumiattirance", - "description": "Le Pokémon illumine les alentours, facilitant les rencontres avec les Pokémon sauvages et empêche sa Précision de baisser." - }, - "trace": { - "name": "Calque", - "description": "Lorsque le Pokémon entre au combat, il calque le talent d’un ennemi pour remplacer le sien." - }, - "hugePower": { - "name": "Coloforce", - "description": "Double la puissance des attaques physiques." - }, - "poisonPoint": { - "name": "Point Poison", - "description": "Peut empoisonner l’attaquant lorsque le Pokémon subit une attaque directe." - }, - "innerFocus": { - "name": "Attention", - "description": "Le Pokémon a un mental à toute épreuve qui empêche les attaques ennemies de lui faire peur. Il est aussi immunisé contre le talent Intimidation." - }, - "magmaArmor": { - "name": "Armumagma", - "description": "Le magma qui recouvre le corps du Pokémon le protège contre le gel." - }, - "waterVeil": { - "name": "Ignifu-Voile", - "description": "Le voile qui recouvre le Pokémon le protège des brulures." - }, - "magnetPull": { - "name": "Magnépiège", - "description": "Attire les Pokémon Acier grâce à un champ magnétique, ce qui les empêche de quitter le terrain." - }, - "soundproof": { - "name": "Anti-Bruit", - "description": "Protège le Pokémon de toutes les capacités sonores." - }, - "rainDish": { - "name": "Cuvette", - "description": "Le Pokémon récupère progressivement des PV lorsqu’il pleut." - }, - "sandStream": { - "name": "Sable Volant", - "description": "Le Pokémon invoque une tempête de sable quand il entre au combat." - }, - "pressure": { - "name": "Pression", - "description": "Met la pression à l’adversaire pour le forcer à dépenser plus de PP." - }, - "thickFat": { - "name": "Isograisse", - "description": "Le Pokémon est protégé par une épaisse couche de graisse qui diminue de moitié les dégâts qu’il subit des capacités de types Feu et Glace." - }, - "earlyBird": { - "name": "Matinal", - "description": "Le Pokémon se réveille deux fois plus rapidement que les autres." - }, - "flameBody": { - "name": "Corps Ardent", - "description": "Peut bruler l’attaquant lorsque le Pokémon subit une attaque directe." - }, - "runAway": { - "name": "Fuite", - "description": "Permet de fuir n’importe quel Pokémon sauvage." - }, - "keenEye": { - "name": "Regard Vif", - "description": "Les yeux perçants du Pokémon empêchent sa Précision de baisser." - }, - "hyperCutter": { - "name": "Hyper Cutter", - "description": "Le Pokémon est armé de puissantes pinces qui font sa fierté et empêchent son Attaque d’être baissée par l’adversaire." - }, - "pickup": { - "name": "Ramassage", - "description": "Permet parfois au Pokémon de ramasser les objets que d’autres Pokémon ont utilisés. Il lui arrive aussi d’en trouver hors des combats." - }, - "truant": { - "name": "Absentéisme", - "description": "Lorsque le Pokémon utilise une capacité, il passe le tour suivant à paresser." - }, - "hustle": { - "name": "Agitation", - "description": "Améliore l’Attaque du Pokémon, mais diminue la Précision." - }, - "cuteCharm": { - "name": "Joli Sourire", - "description": "Peut séduire l’attaquant lorsque le Pokémon subit une attaque directe." - }, - "plus": { - "name": "Plus", - "description": "L’Attaque Spéciale du Pokémon augmente si un Pokémon allié a le talent Moins ou Plus." - }, - "minus": { - "name": "Moins", - "description": "L’Attaque Spéciale du Pokémon augmente si un Pokémon allié a le talent Moins ou Plus." - }, - "forecast": { - "name": "Météo", - "description": "Le Pokémon prend le type Eau, Feu ou Glace en fonction de la météo." - }, - "stickyHold": { - "name": "Glu", - "description": "Les objets sont collés au corps gluant du Pokémon, ce qui empêche ses adversaires de les dérober." - }, - "shedSkin": { - "name": "Mue", - "description": "Le Pokémon soigne parfois ses altérations de statut en muant." - }, - "guts": { - "name": "Cran", - "description": "Augmente l’Attaque du Pokémon s’il est affecté par une altération de statut." - }, - "marvelScale": { - "name": "Écaille Spéciale", - "description": "Les écailles mystérieuses du Pokémon réagissent aux altérations de statut en augmentant sa Défense." - }, - "liquidOoze": { - "name": "Suintement", - "description": "Le Pokémon suinte un liquide toxique nauséabond qui blesse tous ceux qui tentent de voler ses PV." - }, - "overgrow": { - "name": "Engrais", - "description": "Augmente la puissance des capacités de type Plante du Pokémon quand il a perdu une certaine quantité de PV." - }, - "blaze": { - "name": "Brasier", - "description": "Augmente la puissance des capacités de type Feu du Pokémon quand il a perdu une certaine quantité de PV." - }, - "torrent": { - "name": "Torrent", - "description": "Augmente la puissance des capacités de type Eau du Pokémon quand il a perdu une certaine quantité de PV." - }, - "swarm": { - "name": "Essaim", - "description": "Augmente la puissance des capacités de type Insecte du Pokémon quand il a perdu une certaine quantité de PV." - }, - "rockHead": { - "name": "Tête de Roc", - "description": "Le Pokémon peut utiliser des capacités occasionnant un contrecoup sans perdre de PV." - }, - "drought": { - "name": "Sécheresse", - "description": "Le Pokémon invoque le soleil quand il entre au combat." - }, - "arenaTrap": { - "name": "Piège Sable", - "description": "Empêche l’adversaire de quitter le terrain." - }, - "vitalSpirit": { - "name": "Esprit Vital", - "description": "Empêche le Pokémon de s’endormir." - }, - "whiteSmoke": { - "name": "Écran Fumée", - "description": "Un écran de fumée empêche l’adversaire de baisser les stats du Pokémon." - }, - "purePower": { - "name": "Force Pure", - "description": "Le Pokémon utilise sa maitrise du yoga pour doubler la puissance de ses attaques physiques." - }, - "shellArmor": { - "name": "Coque Armure", - "description": "Le Pokémon est protégé des coups critiques par sa carapace." - }, - "airLock": { - "name": "Air Lock", - "description": "Annule tous les effets de la météo." - }, - "tangledFeet": { - "name": "Pieds Confus", - "description": "Augmente l’Esquive du Pokémon s’il est confus." - }, - "motorDrive": { - "name": "Motorisé", - "description": "Si le Pokémon est touché par une capacité de type Électrik, il ne subit aucun dégât et sa Vitesse augmente." - }, - "rivalry": { - "name": "Rivalité", - "description": "Le Pokémon déteste la concurrence et inflige plus de dégâts si sa cible est du même sexe. Par contre, il en inflige moins si sa cible est du sexe opposé." - }, - "steadfast": { - "name": "Impassible", - "description": "Augmente la Vitesse du Pokémon quand il a peur." - }, - "snowCloak": { - "name": "Rideau Neige", - "description": "Augmente l’Esquive du Pokémon quand il neige." - }, - "gluttony": { - "name": "Gloutonnerie", - "description": "Si le Pokémon tient une Baie à manger en cas de PV bas, il la mange dès qu’il a perdu la moitié de ses PV." - }, - "angerPoint": { - "name": "Colérique", - "description": "Si le Pokémon subit un coup critique, il entre dans une colère noire qui augmente son Attaque au maximum." - }, - "unburden": { - "name": "Délestage", - "description": "Augmente la Vitesse du Pokémon s’il perd ou utilise l’objet qu’il tenait au début du combat." - }, - "heatproof": { - "name": "Ignifugé", - "description": "Diminue de moitié les dégâts infligés au Pokémon par les capacités de type Feu." - }, - "simple": { - "name": "Simple", - "description": "Les changements de stats sont deux fois plus importants pour le Pokémon." - }, - "drySkin": { - "name": "Peau Sèche", - "description": "Quand le soleil brille, le Pokémon perd des PV et subit plus de dégâts des capacités Feu, mais il regagne des PV lorsqu’il pleut ou s’il est touché par une capacité Eau." - }, - "download": { - "name": "Télécharge", - "description": "Le Pokémon compare la Défense et la Défense Spéciale de l’adversaire et, en fonction de la stat la plus basse, il augmente sa propre Attaque ou Attaque Spéciale." - }, - "ironFist": { - "name": "Poing de Fer", - "description": "Augmente la puissance des capacités coups de poing." - }, - "poisonHeal": { - "name": "Soin Poison", - "description": "Quand le Pokémon est empoisonné, il regagne des PV au lieu d’en perdre." - }, - "adaptability": { - "name": "Adaptabilité", - "description": "Quand le Pokémon utilise une capacité du même type que lui, le bonus de puissance qu’elle reçoit est encore plus important que normalement." - }, - "skillLink": { - "name": "Multi-Coups", - "description": "Les capacités pouvant frapper plusieurs fois frappent toujours le nombre maximal de coups." - }, - "hydration": { - "name": "Hydratation", - "description": "Soigne les altérations de statut du Pokémon quand il pleut." - }, - "solarPower": { - "name": "Force Soleil", - "description": "Quand le soleil brille, l’Attaque Spéciale du Pokémon augmente mais il perd des PV à chaque tour." - }, - "quickFeet": { - "name": "Pied Véloce", - "description": "Augmente la Vitesse du Pokémon en cas d’altération de statut." - }, - "normalize": { - "name": "Normalise", - "description": "Toutes les capacités du Pokémon deviennent de type Normal, quel que soit leur type original. Leur puissance augmente légèrement." - }, - "sniper": { - "name": "Sniper", - "description": "Lorsque le Pokémon porte un coup critique, les dégâts infligés augmentent encore plus que d’habitude." - }, - "magicGuard": { - "name": "Garde Magik", - "description": "Seules les attaques peuvent blesser le Pokémon." - }, - "noGuard": { - "name": "Annule Garde", - "description": "Les capacités du Pokémon touchent leur cible à coup sûr, mais les capacités adverses le touchent aussi à coup sûr." - }, - "stall": { - "name": "Frein", - "description": "Le Pokémon utilise toujours sa capacité en dernier." - }, - "technician": { - "name": "Technicien", - "description": "Augmente la puissance des capacités les plus faibles." - }, - "leafGuard": { - "name": "Feuille Garde", - "description": "Protège le Pokémon contre les altérations de statut quand le soleil brille." - }, - "klutz": { - "name": "Maladresse", - "description": "Le Pokémon ne peut utiliser aucun objet tenu." - }, - "moldBreaker": { - "name": "Brise Moule", - "description": "Le Pokémon ignore les talents adverses qui auraient un effet sur ses capacités." - }, - "superLuck": { - "name": "Chanceux", - "description": "Le Pokémon est tellement chanceux qu’il inflige plus fréquemment des coups critiques." - }, - "aftermath": { - "name": "Boom Final", - "description": "Si le Pokémon est mis K.O. par une attaque directe, il inflige des dégâts à l’attaquant avant de s’évanouir." - }, - "anticipation": { - "name": "Anticipation", - "description": "Le Pokémon devine si l’adversaire connait une capacité dangereuse pour lui." - }, - "forewarn": { - "name": "Prédiction", - "description": "Révèle l’une des capacités de l’adversaire quand le combat commence." - }, - "unaware": { - "name": "Inconscient", - "description": "Le Pokémon ignore les changements de stats des autres Pokémon, qu’il attaque ou soit attaqué." - }, - "tintedLens": { - "name": "Lentiteintée", - "description": "Permet à une capacité qui n’est pas très efficace d’infliger des dégâts comme si elle était efficace normalement." - }, - "filter": { - "name": "Filtre", - "description": "Diminue la puissance des attaques super efficaces subies." - }, - "slowStart": { - "name": "Début Calme", - "description": "Divise la Vitesse et l’Attaque du Pokémon par deux pendant les cinq premiers tours du combat." - }, - "scrappy": { - "name": "Querelleur", - "description": "Permet aux capacités de type Normal ou Combat du Pokémon de toucher les Pokémon de type Spectre. Immunise aussi contre le talent Intimidation." - }, - "stormDrain": { - "name": "Lavabo", - "description": "Le Pokémon détourne sur lui les capacités de type Eau et les neutralise, tout en augmentant son Attaque Spéciale." - }, - "iceBody": { - "name": "Corps Gel", - "description": "Régénère peu à peu les PV du Pokémon quand il neige." - }, - "solidRock": { - "name": "Solide Roc", - "description": "Diminue la puissance des attaques super efficaces subies." - }, - "snowWarning": { - "name": "Alerte Neige", - "description": "Le Pokémon invoque la neige quand il entre au combat." - }, - "honeyGather": { - "name": "Cherche Miel", - "description": "Le Pokémon trouve du Miel après un combat et est directement revendu contre de l’argent." - }, - "frisk": { - "name": "Fouille", - "description": "Lorsqu’il entre en combat, le Pokémon peut vérifier la capacité d’un Pokémon adverse." - }, - "reckless": { - "name": "Téméraire", - "description": "Augmente la puissance des capacités occasionnant un contrecoup." - }, - "multitype": { - "name": "Multi-Type", - "description": "Modifie le type du Pokémon en fonction de la plaque qu’il tient." - }, - "flowerGift": { - "name": "Don Floral", - "description": "Augmente l’Attaque et la Défense Spéciale du Pokémon et de ses alliés lorsque le soleil brille." - }, - "badDreams": { - "name": "Mauvais Rêve", - "description": "Inflige des dégâts aux ennemis endormis." - }, - "pickpocket": { - "name": "Pickpocket", - "description": "Vole l’objet que tient l’attaquant quand le Pokémon subit une attaque directe." - }, - "sheerForce": { - "name": "Sans Limite", - "description": "Les capacités ayant un effet additionnel le perdent, mais leur puissance augmente." - }, - "contrary": { - "name": "Contestation", - "description": "Inverse les changements de stats : les augmentations de stats se transforment en baisses, et vice-versa." - }, - "unnerve": { - "name": "Tension", - "description": "Fait stresser l’adversaire, ce qui l’empêche de manger des Baies." - }, - "defiant": { - "name": "Acharné", - "description": "Augmente beaucoup l’Attaque du Pokémon quand ses stats sont baissées par l’adversaire." - }, - "defeatist": { - "name": "Défaitiste", - "description": "Le Pokémon devient défaitiste quand ses PV tombent à la moitié, et son Attaque et son Attaque Spéciale sont divisées par deux." - }, - "cursedBody": { - "name": "Corps Maudit", - "description": "Quand le Pokémon est touché par une capacité adverse, il inflige parfois Entrave sur celle-ci." - }, - "healer": { - "name": "Cœur Soin", - "description": "Soigne parfois une altération de statut d’un allié proche." - }, - "friendGuard": { - "name": "Garde-Ami", - "description": "Diminue les dégâts subis par les alliés." - }, - "weakArmor": { - "name": "Armurouillée", - "description": "Quand le Pokémon est touché par une capacité physique, sa Défense baisse mais sa Vitesse augmente beaucoup." - }, - "heavyMetal": { - "name": "Heavy Metal", - "description": "Double le poids du Pokémon." - }, - "lightMetal": { - "name": "Light Metal", - "description": "Divise par deux le poids du Pokémon." - }, - "multiscale": { - "name": "Multiécaille", - "description": "Le Pokémon subit moins de dégâts quand ses PV sont au maximum." - }, - "toxicBoost": { - "name": "Rage Poison", - "description": "Augmente la puissance des capacités physiques quand le Pokémon est empoisonné." - }, - "flareBoost": { - "name": "Rage Brûlure", - "description": "Augmente la puissance des capacités spéciales quand le Pokémon est brulé." - }, - "harvest": { - "name": "Récolte", - "description": "Permet de réutiliser une même Baie plusieurs fois." - }, - "telepathy": { - "name": "Télépathe", - "description": "Le Pokémon anticipe et évite les attaques de ses alliés." - }, - "moody": { - "name": "Lunatique", - "description": "Augmente beaucoup une stat du Pokémon et en baisse une autre au hasard à chaque tour." - }, - "overcoat": { - "name": "Envelocape", - "description": "Protège des dégâts occasionnés par les tempêtes de sable, ainsi que des effets des capacités qui libèrent de la poudre et des spores." - }, - "poisonTouch": { - "name": "Toxitouche", - "description": "Peut empoisonner l’ennemi par simple contact." - }, - "regenerator": { - "name": "Régé-Force", - "description": "Restaure un peu de PV si le Pokémon est retiré du combat." - }, - "bigPecks": { - "name": "Cœur de Coq", - "description": "Protège des effets qui baissent la Défense." - }, - "sandRush": { - "name": "Baigne Sable", - "description": "Augmente la Vitesse lors des tempêtes de sable." - }, - "wonderSkin": { - "name": "Peau Miracle", - "description": "Le Pokémon résiste mieux aux capacités de statut." - }, - "analytic": { - "name": "Analyste", - "description": "Augmente la puissance des capacités du Pokémon s’il attaque en dernier." - }, - "illusion": { - "name": "Illusion", - "description": "Le Pokémon prend l’apparence du dernier membre de l’équipe pour tromper l’adversaire." - }, - "imposter": { - "name": "Imposteur", - "description": "Le Pokémon prend l’apparence du Pokémon adverse." - }, - "infiltrator": { - "name": "Infiltration", - "description": "Traverse les barrières et les clones adverses pour attaquer directement." - }, - "mummy": { - "name": "Momie", - "description": "Lorsque le Pokémon subit une attaque directe, le talent de l’attaquant est remplacé par Momie." - }, - "moxie": { - "name": "Impudence", - "description": "Quand le Pokémon met un ennemi K.O., sa confiance en lui ne connait plus de limite et son Attaque augmente." - }, - "justified": { - "name": "Cœur Noble", - "description": "Réveille la noblesse du Pokémon lorsqu’il subit une attaque de type Ténèbres, ce qui augmente son Attaque." - }, - "rattled": { - "name": "Phobique", - "description": "Si le Pokémon est touché par le talent Intimidation ou une attaque de type Ténèbres, Spectre ou Insecte, sa phobie se révèle et sa Vitesse augmente." - }, - "magicBounce": { - "name": "Miroir Magik", - "description": "Annule les effets des capacités de statut subies par le Pokémon et les retourne à l’envoyeur." - }, - "sapSipper": { - "name": "Herbivore", - "description": "Annule les attaques de type Plante subies par le Pokémon et augmente son Attaque." - }, - "prankster": { - "name": "Farceur", - "description": "Rend les capacités de statut du Pokémon prioritaires." - }, - "sandForce": { - "name": "Force Sable", - "description": "Augmente la puissance des capacités de types Roche, Sol et Acier en cas de tempête de sable." - }, - "ironBarbs": { - "name": "Épine de Fer", - "description": "Inflige des dégâts à l’attaquant lorsque le Pokémon subit une attaque directe." - }, - "zenMode": { - "name": "Mode Transe", - "description": "Le Pokémon change de forme quand il lui reste moins de la moitié de ses PV." - }, - "victoryStar": { - "name": "Victorieux", - "description": "Augmente la Précision du Pokémon et de ses alliés." - }, - "turboblaze": { - "name": "Turbo Brasier", - "description": "Le Pokémon ignore les talents adverses qui auraient un effet sur ses capacités." - }, - "teravolt": { - "name": "Téra-Voltage", - "description": "Le Pokémon ignore les talents adverses qui auraient un effet sur ses capacités." - }, - "aromaVeil": { - "name": "Aroma-Voile", - "description": "Protège le Pokémon et ses alliés des effets limitant le libre arbitre." - }, - "flowerVeil": { - "name": "Flora-Voile", - "description": "Empêche les alliés de type Plante de subir des baisses de stats et des altérations de statut." - }, - "cheekPouch": { - "name": "Bajoues", - "description": "Le Pokémon récupère des PV lorsqu’il consomme n’importe quelle Baie en plus de bénéficier de ses effets habituels." - }, - "protean": { - "name": "Protéen", - "description": "Le Pokémon prend le type de la capacité qu’il utilise. Ce talent ne peut se déclencher qu’une fois par entrée au combat du Pokémon." - }, - "furCoat": { - "name": "Toison Épaisse", - "description": "Divise par deux les dégâts des capacités physiques subies par le Pokémon." - }, - "magician": { - "name": "Magicien", - "description": "Les capacités volent aussi l’objet tenu par la cible." - }, - "bulletproof": { - "name": "Pare-Balles", - "description": "Protège de certaines capacités lançant des projectiles comme des bombes et des balles." - }, - "competitive": { - "name": "Battant", - "description": "Augmente beaucoup l’Attaque Spéciale du Pokémon quand ses stats ont été baissées par l’adversaire." - }, - "strongJaw": { - "name": "Prognathe", - "description": "Le Pokémon a une mâchoire robuste qui augmente la puissance de ses capacités de morsure." - }, - "refrigerate": { - "name": "Peau Gelée", - "description": "Les capacités de type Normal deviennent de type Glace. Leur puissance augmente légèrement." - }, - "sweetVeil": { - "name": "Gluco-Voile", - "description": "Le Pokémon et ses alliés ne peuvent pas s’endormir." - }, - "stanceChange": { - "name": "Déclic Tactique", - "description": "Le Pokémon prend la Forme Assaut lorsqu’il utilise une capacité offensive, et la Forme Parade lorsqu’il utilise Bouclier Royal." - }, - "galeWings": { - "name": "Ailes Bourrasque", - "description": "Quand les PV du Pokémon sont au maximum, ses capacités de type Vol sont prioritaires." - }, - "megaLauncher": { - "name": "Méga Blaster", - "description": "Augmente la puissance des capacités qui projettent une aura." - }, - "grassPelt": { - "name": "Toison Herbue", - "description": "Augmente la Défense du Pokémon si un champ herbu est actif." - }, - "symbiosis": { - "name": "Symbiose", - "description": "Quand les alliés utilisent l’objet qu’ils tiennent, le Pokémon leur donne l’objet qu’il tient en remplacement." - }, - "toughClaws": { - "name": "Griffe Dure", - "description": "Augmente la puissance des attaques directes du Pokémon." - }, - "pixilate": { - "name": "Peau Féérique", - "description": "Les capacités de type Normal deviennent de type Fée. Leur puissance augmente légèrement." - }, - "gooey": { - "name": "Poisseux", - "description": "Baisse la Vitesse de l’attaquant lorsque le Pokémon subit une attaque directe." - }, - "aerilate": { - "name": "Peau Céleste", - "description": "Les capacités de type Normal deviennent de type Vol. Leur puissance augmente légèrement." - }, - "parentalBond": { - "name": "Amour Filial", - "description": "La mère et son petit unissent leurs forces pour attaquer deux fois d’affilée." - }, - "darkAura": { - "name": "Aura Ténébreuse", - "description": "Augmente la puissance des capacités de type Ténèbres de tous les Pokémon." - }, - "fairyAura": { - "name": "Aura Féérique", - "description": "Augmente la puissance des capacités de type Fée de tous les Pokémon." - }, - "auraBreak": { - "name": "Aura Inversée", - "description": "Inverse l’effet des talents « Aura » afin que ceux-ci baissent la puissance des capacités affectées au lieu de l’augmenter." - }, - "primordialSea": { - "name": "Mer Primaire", - "description": "Altère les conditions météo pour neutraliser les attaques de type Feu." - }, - "desolateLand": { - "name": "Terre Finale", - "description": "Altère les conditions météo pour neutraliser les attaques de type Eau." - }, - "deltaStream": { - "name": "Souffle Delta", - "description": "Altère les conditions météo pour annuler les faiblesses du type Vol." - }, - "stamina": { - "name": "Endurance", - "description": "Augmente la Défense du Pokémon lorsqu’il subit une attaque." - }, - "wimpOut": { - "name": "Escampette", - "description": "Le Pokémon perd confiance quand ses PV tombent à la moitié et s’enfuit dans sa Poké Ball." - }, - "emergencyExit": { - "name": "Repli Tactique", - "description": "Le Pokémon évite les situations inutilement dangereuses. Quand ses PV tombent à la moitié, il se réfugie dans sa Poké Ball." - }, - "waterCompaction": { - "name": "Sable Humide", - "description": "Augmente beaucoup la Défense du Pokémon quand il subit une capacité de type Eau." - }, - "merciless": { - "name": "Cruauté", - "description": "Lorsque le Pokémon attaque un adversaire empoisonné, le coup est forcément critique." - }, - "shieldsDown": { - "name": "Bouclier-Carcan", - "description": "Lorsque le Pokémon perd la moitié de ses PV, son enveloppe se brise et il adopte une posture offensive." - }, - "stakeout": { - "name": "Filature", - "description": "Lorsque le Pokémon attaque une cible qui vient d’entrer sur le terrain en remplacement d’un autre Pokémon, les dégâts infligés sont doublés." - }, - "waterBubble": { - "name": "Aquabulle", - "description": "Réduit la puissance des capacités de type Feu subies par le Pokémon. Il est également immunisé contre les brulures." - }, - "steelworker": { - "name": "Expert Acier", - "description": "Augmente la puissance des attaques de type Acier." - }, - "berserk": { - "name": "Folle Furie", - "description": "Augmente l’Attaque Spéciale du Pokémon lorsque ses PV tombent à la moitié à cause d’une attaque de l’adversaire." - }, - "slushRush": { - "name": "Chasse-Neige", - "description": "Augmente la Vitesse du Pokémon quand il neige." - }, - "longReach": { - "name": "Longue Portée", - "description": "Le Pokémon est capable d’utiliser toutes ses capacités sans entrer en contact direct avec sa cible." - }, - "liquidVoice": { - "name": "Hydrata-Son", - "description": "Toutes les attaques sonores du Pokémon prennent le type Eau." - }, - "triage": { - "name": "Prioguérison", - "description": "Rend les capacités de soin prioritaires." - }, - "galvanize": { - "name": "Peau Électrique", - "description": "Les capacités de type Normal deviennent de type Électrik. Leur puissance augmente légèrement." - }, - "surgeSurfer": { - "name": "Surf Caudal", - "description": "La Vitesse du Pokémon est doublée sur un champ électrifié." - }, - "schooling": { - "name": "Banc", - "description": "Le Pokémon se rassemble avec ses congénères quand ses PV sont élevés. Quand il ne lui reste plus beaucoup de PV, le banc se disperse." - }, - "disguise": { - "name": "Fantômasque", - "description": "Le déguisement qui recouvre le corps du Pokémon est capable de le protéger d’une attaque." - }, - "battleBond": { - "name": "Synergie", - "description": "En battant un ennemi, ce Pokémon renforce ses liens avec son Dresseur, ce qui augmente son Attaque, son Attaque Spéciale et sa Vitesse." - }, - "powerConstruct": { - "name": "Rassemblement", - "description": "Lorsque le Pokémon perd la moitié de ses PV, ses Cellules se rassemblent pour l’encourager, ce qui lui permet de prendre sa Forme Parfaite." - }, - "corrosion": { - "name": "Corrosion", - "description": "Permet d’empoisonner les Pokémon de type Acier ou Poison." - }, - "comatose": { - "name": "Hypersommeil", - "description": "Le Pokémon rêve en permanence et ne se réveille jamais. Il est capable d’attaquer normalement tout en dormant." - }, - "queenlyMajesty": { - "name": "Prestance Royale", - "description": "L’adversaire est impressionné par la majesté du Pokémon et ne peut pas le viser avec une capacité prioritaire." - }, - "innardsOut": { - "name": "Expuls’Organes", - "description": "Le Pokémon inflige à l’adversaire l’ayant mis K.O. des dégâts égaux au nombre de PV qu’il lui restait avant le coup de grâce." - }, - "dancer": { - "name": "Danseuse", - "description": "Si n’importe quel Pokémon utilise une capacité dansante, le Pokémon utilise immédiatement cette danse lui aussi." - }, - "battery": { - "name": "Batterie", - "description": "Augmente la puissance des capacités spéciales des alliés." - }, - "fluffy": { - "name": "Boule de Poils", - "description": "Divise par deux les dégâts des attaques directes subies par le Pokémon, mais double les dégâts des capacités de type Feu." - }, - "dazzling": { - "name": "Corps Coloré", - "description": "L’adversaire est abasourdi par le Pokémon et ne peut pas le viser avec une capacité prioritaire." - }, - "soulHeart": { - "name": "Animacœur", - "description": "Augmente l’Attaque Spéciale du Pokémon lorsqu’un autre Pokémon est mis K.O." - }, - "tanglingHair": { - "name": "Mèche Rebelle", - "description": "Baisse la Vitesse de l’attaquant lorsque le Pokémon subit une attaque directe." - }, - "receiver": { - "name": "Receveur", - "description": "Le Pokémon reçoit le talent d’un allié mis K.O." - }, - "powerOfAlchemy": { - "name": "Osmose", - "description": "Le Pokémon acquiert le talent d’un allié mis K.O." - }, - "beastBoost": { - "name": "Boost Chimère", - "description": "Augmente la stat la plus élevée du Pokémon quand il met K.O. un autre Pokémon." - }, - "rksSystem": { - "name": "Système Alpha", - "description": "Change le type du Pokémon en fonction de la ROM équipée." - }, - "electricSurge": { - "name": "Créa-Élec", - "description": "Le Pokémon crée un champ électrifié au moment où il entre au combat." - }, - "psychicSurge": { - "name": "Créa-Psy", - "description": "Le Pokémon crée un champ psychique au moment où il entre au combat." - }, - "mistySurge": { - "name": "Créa-Brume", - "description": "Le Pokémon crée un champ brumeux au moment où il entre au combat." - }, - "grassySurge": { - "name": "Créa-Herbe", - "description": "Le Pokémon crée un champ herbu au moment où il entre au combat." - }, - "fullMetalBody": { - "name": "Métallo-Garde", - "description": "Empêche les stats du Pokémon de baisser à cause du talent ou d’une capacité de l’adversaire." - }, - "shadowShield": { - "name": "Spectro-Bouclier", - "description": "Le Pokémon subit moins de dégâts quand ses PV sont au maximum." - }, - "prismArmor": { - "name": "Prisme-Armure", - "description": "Diminue la puissance des attaques super efficaces subies." - }, - "neuroforce": { - "name": "Cérébro-Force", - "description": "Augmente encore plus la puissance des attaques super efficaces." - }, - "intrepidSword": { - "name": "Lame Indomptable", - "description": "Augmente l’Attaque du Pokémon la première fois qu’il entre au combat." - }, - "dauntlessShield": { - "name": "Égide Inflexible", - "description": "Augmente la Défense du Pokémon la première fois qu’il entre au combat." - }, - "libero": { - "name": "Libéro", - "description": "Le Pokémon prend le type de la capacité qu’il utilise. Ce talent ne peut se déclencher qu’une fois par entrée au combat du Pokémon." - }, - "ballFetch": { - "name": "Ramasse Ball", - "description": "Si le Pokémon ne tient aucun objet, il ramassera la Poké Ball lors du premier lancer raté du combat." - }, - "cottonDown": { - "name": "Effilochage", - "description": "Quand le Pokémon est touché par une attaque, il dissémine des aigrettes qui diminuent la Vitesse de tout le monde, sauf la sienne." - }, - "propellerTail": { - "name": "Propulseur", - "description": "Permet d’ignorer l’effet des capacités ou des talents qui attirent les capacités." - }, - "mirrorArmor": { - "name": "Armure Miroir", - "description": "Le Pokémon renvoie les effets réducteurs de stats qu’il reçoit." - }, - "gulpMissile": { - "name": "Dégobage", - "description": "Quand le Pokémon utilise Surf ou Plongée, il revient avec une proie. Lorsqu’il subit des dégâts par la suite, il attaque en recrachant sa proie." - }, - "stalwart": { - "name": "Nerfs d’Acier", - "description": "Permet d’ignorer l’effet des capacités ou des talents qui attirent les capacités." - }, - "steamEngine": { - "name": "Turbine", - "description": "Lorsque le Pokémon est touché par des capacités de type Eau ou Feu, sa Vitesse augmente énormément." - }, - "punkRock": { - "name": "Punk Rock", - "description": "Augmente la puissance des capacités basées sur le son. Le Pokémon ne subit que la moitié des dégâts quand il est touché par ce genre de capacités." - }, - "sandSpit": { - "name": "Expul’Sable", - "description": "Le Pokémon déclenche une tempête de sable quand il subit une attaque." - }, - "iceScales": { - "name": "Écailles Glacées", - "description": "Le Pokémon est protégé par des écailles de glace. Les dégâts qu’il subit par des capacités spéciales sont divisés par deux." - }, - "ripen": { - "name": "Mûrissement", - "description": "Le Pokémon fait murir la Baie qu’il tient et double ainsi son effet." - }, - "iceFace": { - "name": "Tête de Gel", - "description": "Le glaçon sur sa tête encaisse les attaques physiques à la place du Pokémon, mais sa destruction modifie son apparence. Le glaçon se reforme quand il neige." - }, - "powerSpot": { - "name": "Cercle d’Énergie", - "description": "Augmente la puissance des capacités des Pokémon qui se trouvent à proximité." - }, - "mimicry": { - "name": "Mimétisme", - "description": "Le Pokémon adopte le même type que le terrain lorsqu’un champ est actif." - }, - "screenCleaner": { - "name": "Brise-Barrière", - "description": "Quand le Pokémon entre au combat, les effets de Mur Lumière, Protection et Voile Aurore disparaissent pour les alliés comme pour les adversaires." - }, - "steelySpirit": { - "name": "Boost Acier", - "description": "Augmente la puissance des attaques de type Acier du Pokémon et de ses alliés." - }, - "perishBody": { - "name": "Corps Condamné", - "description": "Lorsque le Pokémon est directement touché par une capacité, l’assaillant et lui tomberont K.O. dans trois tours, à moins qu’ils ne soient remplacés entre temps." - }, - "wanderingSpirit": { - "name": "Âme Vagabonde", - "description": "Lorsque le Pokémon est directement touché par une capacité, il échange son talent avec celui de l’assaillant." - }, - "gorillaTactics": { - "name": "Entêtement", - "description": "Augmente l’Attaque, mais empêche d’utiliser toute autre capacité que celle utilisée en premier par le Pokémon." - }, - "neutralizingGas": { - "name": "Gaz Inhibiteur", - "description": "Si un Pokémon avec Gaz Inhibiteur est sur le terrain, les effets des talents de tous les autres Pokémon ne s’activent pas ou sont neutralisés." - }, - "pastelVeil": { - "name": "Voile Pastel", - "description": "Protège le Pokémon et ses alliés contre toutes les altérations de statut liées à l’empoisonnement." - }, - "hungerSwitch": { - "name": "Déclic Fringale", - "description": "À la fin de chaque tour, le Pokémon alterne entre ses formes Mode Rassasié et Mode Affamé." - }, - "quickDraw": { - "name": "Tir Vif", - "description": "Permet parfois au Pokémon d’agir en premier." - }, - "unseenFist": { - "name": "Poing Invisible", - "description": "Si le Pokémon utilise une attaque directe, celle-ci pourra toucher la cible même si elle se protège." - }, - "curiousMedicine": { - "name": "Breuvage Suspect", - "description": "Quand il entre au combat, le Pokémon répand une substance qui annule les changements de stats de ses alliés." - }, - "transistor": { - "name": "Transistor", - "description": "Augmente la puissance des capacités de type Électrik." - }, - "dragonsMaw": { - "name": "Dent de Dragon", - "description": "Augmente la puissance des capacités de type Dragon." - }, - "chillingNeigh": { - "name": "Blanche Ruade", - "description": "Quand le Pokémon met un ennemi K.O., il émet un hennissement glaçant, ce qui augmente son Attaque." - }, - "grimNeigh": { - "name": "Sombre Ruade", - "description": "Quand le Pokémon met un ennemi K.O., il émet un hennissement terrifiant qui augmente son Attaque Spéciale." - }, - "asOneGlastrier": { - "name": "Osmose Équine", - "description": "Les talents Tension de Sylveroy et Blanche Ruade de Blizzeval sont cumulés." - }, - "asOneSpectrier": { - "name": "Osmose Équine", - "description": "Les talents Tension de Sylveroy et Sombre Ruade de Spectreval sont cumulés." - }, - "lingeringAroma": { - "name": "Odeur Tenace", - "description": "Lorsque le Pokémon subit une attaque directe, le talent de l’attaquant est remplacé par Odeur Tenace." - }, - "seedSower": { - "name": "Semencier", - "description": "Le Pokémon crée un champ herbu quand il subit une attaque." - }, - "thermalExchange": { - "name": "Thermodynamique", - "description": "Lorsque le Pokémon est touché par une capacité de type Feu, il ne subit aucun dégât et son Attaque augmente." - }, - "angerShell": { - "name": "Courroupace", - "description": "Le Pokémon enrage s’il a moins de la moitié de ses PV après avoir subi une attaque. Sa Déf. et sa Déf. Spé. baissent, et son Atq., son Atq. Spé. et sa Vit. augmentent." - }, - "purifyingSalt": { - "name": "Sel Purificateur", - "description": "Le sel pur immunise le Pokémon contre les altérations de statut, et diminue de moitié les dégâts des capacités de type Spectre." - }, - "wellBakedBody": { - "name": "Bien Cuit", - "description": "Si le Pokémon est touché par une capacité de type Feu, il ne subit aucun dégât et sa Défense augmente beaucoup." - }, - "windRider": { - "name": "Aéroporté", - "description": "L’Attaque du Pokémon augmente si un vent arrière souffle ou s’il est touché par une capacité faisant appel au vent. Dans ce dernier cas, il ne subit aucun dégât." - }, - "guardDog": { - "name": "Chien de Garde", - "description": "L’Attaque du Pokémon augmente s’il subit l’effet du talent Intimidation. Les capacités ou objets qui font changer de Pokémon n’ont aucun effet sur lui." - }, - "rockyPayload": { - "name": "Porte-Roche", - "description": "Augmente la puissance des capacités de type Roche." - }, - "windPower": { - "name": "Turbine Éolienne", - "description": "Si le Pokémon est touché par une capacité faisant appel au vent, il se charge en électricité." - }, - "zeroToHero": { - "name": "Supermutation", - "description": "Le Pokémon prend sa Forme Super en quittant le combat." - }, - "commander": { - "name": "Commandant", - "description": "Si un Oyacata allié est sur le terrain quand ce Pokémon rejoint le combat, ce dernier entre dans sa bouche et devient son commandant." - }, - "electromorphosis": { - "name": "Grecharge", - "description": "Si le Pokémon subit des dégâts, il se charge en électricité." - }, - "protosynthesis": { - "name": "Paléosynthèse", - "description": "Quand le soleil brille ou que le Pokémon tient une capsule d’Énergie Booster, sa stat la plus élevée augmente." - }, - "quarkDrive": { - "name": "Charge Quantique", - "description": "Quand un champ électrifié est actif ou que le Pokémon tient une capsule d’Énergie Booster, sa stat la plus élevée augmente." - }, - "goodAsGold": { - "name": "Corps en Or", - "description": "Le corps en or pur et robuste du Pokémon l’immunise contre les capacités de statut des autres Pokémon." - }, - "vesselOfRuin": { - "name": "Urne du Fléau", - "description": "Le pouvoir de l’urne qui appelle le fléau affaiblit l’Attaque Spéciale de tous les autres Pokémon." - }, - "swordOfRuin": { - "name": "Épée du Fléau", - "description": "Le pouvoir de l’épée qui appelle le fléau affaiblit la Défense de tous les autres Pokémon." - }, - "tabletsOfRuin": { - "name": "Bois du Fléau", - "description": "Le pouvoir du bois qui appelle le fléau affaiblit l’Attaque de tous les autres Pokémon." - }, - "beadsOfRuin": { - "name": "Perles du Fléau", - "description": "Le pouvoir des perles qui appellent le fléau affaiblit la Défense Spéciale de tous les autres Pokémon." - }, - "orichalcumPulse": { - "name": "Pouls Orichalque", - "description": "Le Pokémon invoque le soleil quand il rejoint le combat. Quand les rayons du soleil sont intenses, une pulsation primitive augmente son Attaque." - }, - "hadronEngine": { - "name": "Moteur à Hadrons", - "description": "Le Pokémon crée un champ électrifié quand il rejoint le combat. Une machine du futur fait monter son Attaque Spéciale si un champ électrifié est actif." - }, - "opportunist": { - "name": "Opportuniste", - "description": "Quand les stats de l’ennemi augmentent, le Pokémon en profite pour augmenter ses stats de la même manière." - }, - "cudChew": { - "name": "Ruminant", - "description": "Quand le Pokémon mange une Baie, il la régurgite à la fin du tour suivant et la mange une nouvelle fois." - }, - "sharpness": { - "name": "Incisif", - "description": "Augmente la puissance des capacités tranchantes." - }, - "supremeOverlord": { - "name": "Général Suprême", - "description": "Quand le Pokémon entre sur le terrain, son Attaque et son Attaque Spéciale augmentent légèrement pour chaque allié mis K.O. auparavant." - }, - "costar": { - "name": "Collab", - "description": "Quand le Pokémon entre sur le terrain, il copie les changements de stats de son allié." - }, - "toxicDebris": { - "name": "Dépôt Toxique", - "description": "Quand le Pokémon est touché par une capacité physique, il répand des pics toxiques dans le camp adverse." - }, - "armorTail": { - "name": "Armure Caudale", - "description": "L’étrange queue qui recouvre la tête du Pokémon empêche ce dernier d’être visé par une capacité prioritaire." - }, - "earthEater": { - "name": "Absorbe-Terre", - "description": "Si le Pokémon est touché par une capacité de type Sol, il regagne des PV au lieu de subir des dégâts." - }, - "myceliumMight": { - "name": "Force Fongique", - "description": "Le Pokémon agit toujours plus lentement quand il utilise une capacité de statut, mais il ignore les talents adverses." - }, - "mindsEye": { - "name": "Œil Révélateur", - "description": "Le Pokémon ignore les changements d’Esquive des cibles et peut toucher les Pokémon Spectre avec des capacités Normal ou Combat. Sa Précision ne peut pas baisser." - }, - "supersweetSyrup": { - "name": "Nectar Mielleux", - "description": "La première fois que le Pokémon entre au combat, une odeur de nectar sucré se répand sur le terrain, ce qui baisse l’Esquive de l’adversaire." - }, - "hospitality": { - "name": "Aux Petits Soins", - "description": "Quand il rejoint le combat, ce Pokémon est aux petits soins avec son allié et restaure quelques PV." - }, - "toxicChain": { - "name": "Chaîne Toxique", - "description": "Grâce aux pouvoirs de sa chaine imprégnée de toxines, le Pokémon peut empoisonner gravement sa cible en la touchant avec une capacité." - }, - "embodyAspectTeal": { - "name": "Force Mémorielle", - "description": "Le Pokémon fait briller le Masque Turquoise en puisant dans ses souvenirs, ce qui augmente sa Vitesse." - }, - "embodyAspectWellspring": { - "name": "Force Mémorielle", - "description": "Le Pokémon fait briller le Masque du Puits en puisant dans ses souvenirs, ce qui augmente sa Défense Spéciale." - }, - "embodyAspectHearthflame": { - "name": "Force Mémorielle", - "description": "Le Pokémon fait briller le Masque du Fourneau en puisant dans ses souvenirs, ce qui augmente son Attaque." - }, - "embodyAspectCornerstone": { - "name": "Force Mémorielle", - "description": "Le Pokémon fait briller le Masque de la Pierre en puisant dans ses souvenirs, ce qui augmente sa Défense." - }, - "teraShift": { - "name": "Téramorphose", - "description": "Quand le Pokémon rejoint le combat, il absorbe l’énergie alentour et prend sa Forme Téracristal." - }, - "teraShell": { - "name": "Téra-Carapace", - "description": "Grâce à sa carapace qui renferme l’énergie de tous les types, les capacités subies par ce Pokémon quand ses PV sont au maximum ne sont pas très efficaces." - }, - "teraformZero": { - "name": "Téraformation 0", - "description": "Lorsque Terapagos prend sa Forme Stellaire, il utilise son pouvoir enfoui pour annuler les effets de la météo et des champs actifs." - }, - "poisonPuppeteer": { - "name": "Emprise Toxique", - "description": "Lorsque Pêchaminus empoisonne un Pokémon grâce à l’une de ses capacités, ce dernier devient également confus." - } -} diff --git a/src/locales/fr/achv.json b/src/locales/fr/achv.json deleted file mode 100644 index a557a423db7..00000000000 --- a/src/locales/fr/achv.json +++ /dev/null @@ -1,282 +0,0 @@ -{ - "Achievements": { - "name": "Succès" - }, - "Locked": { - "name": "Verrouillé" - }, - "MoneyAchv": { - "description": "Récolter un total de {{moneyAmount}} ₽." - }, - "10K_MONEY": { - "name": "Épargnant", - "name_female": "Épargnante" - }, - "100K_MONEY": { - "name": "Je possède des thunes" - }, - "1M_MONEY": { - "name": "Banquier", - "name_female": "Banquière" - }, - "10M_MONEY": { - "name": "Évadé fiscal", - "name_female": "Évadée fiscale" - }, - "DamageAchv": { - "description": "Infliger {{damageAmount}} de dégâts en un coup." - }, - "250_DMG": { - "name": "Caïd" - }, - "1000_DMG": { - "name": "Boxeur", - "name_female": "Boxeuse" - }, - "2500_DMG": { - "name": "Distributeur de pains", - "name_female": "Distributrice de pains" - }, - "10000_DMG": { - "name": "One Punch Man", - "name_female": "One Punch Woman" - }, - "HealAchv": { - "description": "Soigner {{healAmount}} {{HP}} en une fois avec une capacité,\nun talent ou un objet tenu." - }, - "250_HEAL": { - "name": "Infirmier", - "name_female": "Infirmière" - }, - "1000_HEAL": { - "name": "Médecin" - }, - "2500_HEAL": { - "name": "Clerc" - }, - "10000_HEAL": { - "name": "Centre Pokémon" - }, - "LevelAchv": { - "description": "Monter un Pokémon au N.{{level}}." - }, - "LV_100": { - "name": "Et c’est pas fini !" - }, - "LV_250": { - "name": "Élite" - }, - "LV_1000": { - "name": "Vers l’infini et au-delà" - }, - "RibbonAchv": { - "description": "Accumuler un total de {{ribbonAmount}} Rubans." - }, - "10_RIBBONS": { - "name": "Maitre de la Ligue", - "name_female": "Maitresse de la Ligue" - }, - "25_RIBBONS": { - "name": "Super Maitre de la Ligue", - "name_female": "Super Maitresse de la Ligue" - }, - "50_RIBBONS": { - "name": "Hyper Maitre de la Ligue", - "name_female": "Hyper Maitresse de la Ligue" - }, - "75_RIBBONS": { - "name": "Rogue Maitre de la Ligue", - "name_female": "Rogue Maitresse de la Ligue" - }, - "100_RIBBONS": { - "name": "Master Maitre de la Ligue", - "name_female": "Master Maitresse de la Ligue" - }, - "TRANSFER_MAX_STAT_STAGE": { - "name": "Travail d’équipe", - "description": "Utiliser Relais avec au moins une statistique montée à fond." - }, - "MAX_FRIENDSHIP": { - "name": "Copinage", - "description": "Atteindre le niveau de bonheur maximal avec un Pokémon." - }, - "MEGA_EVOLVE": { - "name": "Mégamorph", - "description": "Méga-évoluer un Pokémon." - }, - "GIGANTAMAX": { - "name": "Kaijū", - "description": "Gigamaxer un Pokémon." - }, - "TERASTALLIZE": { - "name": "J’aime les STAB", - "description": "Téracristalliser un Pokémon." - }, - "STELLAR_TERASTALLIZE": { - "name": "Le type enfoui", - "description": "Téracristalliser un Pokémon en type Stellaire." - }, - "SPLICE": { - "name": "Infinite Fusion", - "description": "Fusionner deux Pokémon avec le Pointeau ADN." - }, - "MINI_BLACK_HOLE": { - "name": "Item-stellar", - "description": "Obtenir un Mini Trou Noir." - }, - "CATCH_MYTHICAL": { - "name": "Fabuleux", - "description": "Capturer un Pokémon fabuleux." - }, - "CATCH_SUB_LEGENDARY": { - "name": "(Semi-)Légendaire", - "description": "Capturer un Pokémon semi-légendaire." - }, - "CATCH_LEGENDARY": { - "name": "Légendaire", - "description": "Capturer un Pokémon légendaire." - }, - "SEE_SHINY": { - "name": "Chromatique", - "description": "Trouver un Pokémon sauvage chromatique." - }, - "SHINY_PARTY": { - "name": "Shasseur", - "name_female": "Shasseuse", - "description": "Avoir une équipe exclusivement composée de Pokémon chromatiques." - }, - "HATCH_MYTHICAL": { - "name": "Œuf fabuleux", - "description": "Obtenir un Pokémon fabuleux dans un Œuf." - }, - "HATCH_SUB_LEGENDARY": { - "name": "Œuf semi-légendaire", - "description": "Obtenir un Pokémon semi-légendaire dans un Œuf." - }, - "HATCH_LEGENDARY": { - "name": "Œuf légendaire", - "description": "Obtenir un Pokémon légendaire dans un Œuf." - }, - "HATCH_SHINY": { - "name": "Œuf chromatique", - "description": "Obtenir un Pokémon chromatique dans un Œuf." - }, - "HIDDEN_ABILITY": { - "name": "Potentiel enfoui", - "description": "Capturer un Pokémon possédant un talent caché." - }, - "PERFECT_IVS": { - "name": "Certificat d’authenticité", - "description": "Avoir des IV parfaits sur un Pokémon." - }, - "CLASSIC_VICTORY": { - "name": "Invaincu", - "name_female": "Invaincue", - "description": "Terminer le jeu en mode Classique." - }, - "UNEVOLVED_CLASSIC_VICTORY": { - "name": "Le stagiaire de 3e", - "description": "Terminer le mode Classique avec au moins un Pokémon non-évolué dans l’équipe." - }, - "MONO_GEN_ONE": { - "name": "Le rival originel", - "description": "Terminer un challenge avec uniquement des Pokémon\nde 1re génération." - }, - "MONO_GEN_TWO": { - "name": "Entre tradition et modernité", - "description": "Terminer un challenge avec uniquement des Pokémon\nde 2e génération." - }, - "MONO_GEN_THREE": { - "name": "Too much water ?", - "description": "Terminer un challenge avec uniquement des Pokémon\nde 3e génération." - }, - "MONO_GEN_FOUR": { - "name": "Réellement la plus difficile ?", - "description": "Terminer un challenge avec uniquement des Pokémon\nde 4e génération." - }, - "MONO_GEN_FIVE": { - "name": "Recast complet", - "description": "Terminer un challenge avec uniquement des Pokémon\nde 5e génération." - }, - "MONO_GEN_SIX": { - "name": "Aristocrate", - "description": "Terminer un challenge avec uniquement des Pokémon\nde 6e génération." - }, - "MONO_GEN_SEVEN": { - "name": "Seulement techniquement", - "description": "Terminer un challenge avec uniquement des Pokémon\nde 7e génération." - }, - "MONO_GEN_EIGHT": { - "name": "L’heure de gloire", - "description": "Terminer un challenge avec uniquement des Pokémon\nde 8e génération." - }, - "MONO_GEN_NINE": { - "name": "Ça va, c’était EZ", - "description": "Terminer un challenge avec uniquement des Pokémon\nde 9e génération." - }, - "MonoType": { - "description": "Terminer un challenge en monotype {{type}}." - }, - "MONO_NORMAL": { - "name": "Extraordinairement banal" - }, - "MONO_FIGHTING": { - "name": "Je connais le kung-fu" - }, - "MONO_FLYING": { - "name": "Angry Birds" - }, - "MONO_POISON": { - "name": "Touche moi je t’empoisonne !" - }, - "MONO_GROUND": { - "name": "Prévisions : Séisme" - }, - "MONO_ROCK": { - "name": "Comme un roc" - }, - "MONO_BUG": { - "name": "Une chenille !" - }, - "MONO_GHOST": { - "name": "SOS Fantômes" - }, - "MONO_STEEL": { - "name": "De type Acier !" - }, - "MONO_FIRE": { - "name": "Allumer le feu" - }, - "MONO_WATER": { - "name": "Vacances en Bretagne" - }, - "MONO_GRASS": { - "name": "Ne pas toucher !" - }, - "MONO_ELECTRIC": { - "name": "À la masse" - }, - "MONO_PSYCHIC": { - "name": "Grocervo" - }, - "MONO_ICE": { - "name": "Froid comme la glace" - }, - "MONO_DRAGON": { - "name": "Légendes du club, ou presque" - }, - "MONO_DARK": { - "name": "Ça va lui passer" - }, - "MONO_FAIRY": { - "name": "Hey ! Listen !" - }, - "FRESH_START": { - "name": "Du premier coup !", - "description": "Terminer un challenge « Nouveau départ »." - }, - "INVERSE_BATTLE": { - "name": "La teuté à verlan", - "description": "Terminer un challenge en Combat Inversé.\nMineter un lenjcha en Ba-con Versin." - } -} diff --git a/src/locales/fr/arena-flyout.json b/src/locales/fr/arena-flyout.json deleted file mode 100644 index e90de13b20a..00000000000 --- a/src/locales/fr/arena-flyout.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "activeBattleEffects": "Effets Actifs", - "player": "Vous", - "neutral": "Neutre", - "enemy": "Ennemi", - "sunny": "Soleil", - "rain": "Pluie", - "sandstorm": "Tempête de Sable", - "hail": "Grêle", - "snow": "Neige", - "fog": "Brouillard", - "heavyRain": "Pluie Battante", - "harshSun": "Soleil Brulant", - "strongWinds": "Vent Mystérieux", - "misty": "Champ Brumeux", - "electric": "Champ Électrifié", - "grassy": "Champ Herbu", - "psychic": "Champ Psychique", - "mudSport": "Lance-Boue", - "waterSport": "Tourniquet", - "spikes": "Picots", - "toxicSpikes": "Pics Toxik", - "mist": "Brume", - "futureSight": "Prescience", - "doomDesire": "Vœu Destructeur", - "wish": "Vœu", - "stealthRock": "Piège de Roc", - "stickyWeb": "Toile Gluante", - "trickRoom": "Distorsion", - "gravity": "Gravité", - "reflect": "Protection", - "lightScreen": "Mur Lumière", - "auroraVeil": "Voile Aurore", - "quickGuard": "Prévention", - "wideGuard": "Garde Large", - "matBlock": "Tatamigaeshi", - "craftyShield": "Vigilance", - "tailwind": "Vent Arrière", - "happyHour": "Étrennes", - "safeguard": "Rune Protect" -} diff --git a/src/locales/fr/arena-tag.json b/src/locales/fr/arena-tag.json deleted file mode 100644 index 9cb2f342068..00000000000 --- a/src/locales/fr/arena-tag.json +++ /dev/null @@ -1,57 +0,0 @@ -{ - "yourTeam": "votre équipe", - "opposingTeam": "l’équipe adverse", - "arenaOnRemove": "L’effet de la capacité {{moveName}}\ns’est dissipé !", - "arenaOnRemovePlayer": "L’effet de la capacité {{moveName}}\ns’est dissipé sur votre équipe !", - "arenaOnRemoveEnemy": "L’effet de la capacité {{moveName}}\ns’est dissipé sur l’équipe ennemie !", - "mistOnAdd": "La brume enveloppe l’équipe\nde {{pokemonNameWithAffix}} !", - "mistApply": "La brume empêche les stats de baisser !", - "reflectOnAdd": "Protection augmente la résistance\naux capacités physiques !", - "reflectOnAddPlayer": "Protection augmente la résistance\nde l’équipe aux capacités physiques !", - "reflectOnAddEnemy": "Protection augmente la résistance\nde l’équipe ennemie aux capacités physiques !", - "lightScreenOnAdd": "Mur Lumière augmente la résistance\naux capacités spéciales !", - "lightScreenOnAddPlayer": "Mur Lumière augmente la résistance\nde l’équipe aux capacités spéciales !", - "lightScreenOnAddEnemy": "Mur Lumière augmente la résistance\nde l’équipe ennemie aux capacités spéciales !", - "auroraVeilOnAdd": "Voile Aurore augmente la résistance\naux capacités physiques et spéciales !", - "auroraVeilOnAddPlayer": "Voile Aurore augmente la résistance\nde l’équipe aux capacités physiques et spéciales !", - "auroraVeilOnAddEnemy": "Voile Aurore augmente la résistance\nde l’équipe ennemie aux capacités physiques et spéciales !", - "conditionalProtectOnAdd": "La capacité {{moveName}}\nprotège l’équipe !", - "conditionalProtectOnAddPlayer": "La capacité {{moveName}}\nprotège votre équipe !", - "conditionalProtectOnAddEnemy": "La capacité {{moveName}}\nprotège l’équipe ennemie !", - "conditionalProtectApply": "{{pokemonNameWithAffix}} est protégé\npar {{moveName}} !", - "matBlockOnAdd": "{{pokemonNameWithAffix}} se prépare\nà utiliser un tatami pour bloquer les attaques !", - "noCritOnAddPlayer": "{{moveName}} immunise votre équipe\ncontre les coups critiques !", - "noCritOnAddEnemy": "{{moveName}} immunise l’équipe ennemie\ncontre les coups critiques !", - "noCritOnRemove": "Les effets d’{{moveName}}\nsur {{pokemonNameWithAffix}} prennent fin !", - "wishTagOnAdd": "Le vœu de{{pokemonNameWithAffix}}\nse réalise !", - "mudSportOnAdd": "La puissance des capacités\nde type Électrik diminue !", - "mudSportOnRemove": "L’effet de Lance-Boue se dissipe !", - "waterSportOnAdd": "La puissance des capacités\nde type Feu diminue !", - "waterSportOnRemove": "L’effet de Tourniquet se dissipe !", - "spikesOnAdd": "Des {{moveName}} s’éparpillent autour de {{opponentDesc}} !", - "spikesActivateTrap": "{{pokemonNameWithAffix}} est blessé\npar les picots !", - "toxicSpikesOnAdd": "Des {{moveName}} s’éparpillent autour de {{opponentDesc}} !", - "toxicSpikesActivateTrapPoison": "{{pokemonNameWithAffix}} absorbe\n{{moveName}} !", - "stealthRockOnAdd": "Des pierres pointues lévitent\nautour de {{opponentDesc}} !", - "stealthRockActivateTrap": "Des pierres pointues\ntranspercent {{pokemonNameWithAffix}} !", - "stickyWebOnAdd": "Le terrain est couvert d’une {{moveName}}\ndu côté de l’équipe ennemie !", - "stickyWebActivateTrap": "{{pokemonName}} ennemi\nest pris dans la toile gluante !", - "trickRoomOnAdd": "{{pokemonNameWithAffix}}\nfausse les dimensions !", - "trickRoomOnRemove": "Les dimensions faussées\nreviennent à la normale !", - "gravityOnAdd": "La gravité s’intensifie !", - "gravityOnRemove": "La gravité est revenue à la normale !", - "tailwindOnAdd": "Un vent arrière souffle !", - "tailwindOnAddPlayer": "Un vent arrière souffle\nsur votre équipe !", - "tailwindOnAddEnemy": "Un vent arrière souffle\nsur l’équipe ennemie !", - "tailwindOnRemove": "Le vent arrière s’arrête !", - "tailwindOnRemovePlayer": "Le vent arrière soufflant\nsur votre équipe s’arrête !", - "tailwindOnRemoveEnemy": "Le vent arrière soufflant\nsur l’équipe ennemie s’arrête !", - "happyHourOnAdd": "L’ambiance est euphorique !", - "happyHourOnRemove": "L’ambiance se calme !", - "safeguardOnAdd": "Un voile mystérieux recouvre\ntout le terrain !", - "safeguardOnAddPlayer": "Un voile mystérieux recouvre\nvotre équipe !", - "safeguardOnAddEnemy": "Un voile mystérieux recouvre\nl’équipe ennemie !", - "safeguardOnRemove": "Le terrain n’est plus protégé\npar le voile mystérieux !", - "safeguardOnRemovePlayer": "Votre équipe n’est plus protégée\npar le voile mystérieux !", - "safeguardOnRemoveEnemy": "L’équipe ennemie n’est plus protégée\npar le voile mystérieux !" -} diff --git a/src/locales/fr/battle-info.json b/src/locales/fr/battle-info.json deleted file mode 100644 index 1408fd4d602..00000000000 --- a/src/locales/fr/battle-info.json +++ /dev/null @@ -1,3 +0,0 @@ -{ - "generation": "{{generation}}" -} diff --git a/src/locales/fr/battle-message-ui-handler.json b/src/locales/fr/battle-message-ui-handler.json deleted file mode 100644 index bc5b4c4dbce..00000000000 --- a/src/locales/fr/battle-message-ui-handler.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "ivBest": "Exceptionnel", - "ivFantastic": "Fantastique", - "ivVeryGood": "Très bon", - "ivPrettyGood": "Bon", - "ivDecent": "Passable…", - "ivNoGood": "Pas top…" -} \ No newline at end of file diff --git a/src/locales/fr/battle-scene.json b/src/locales/fr/battle-scene.json deleted file mode 100644 index ef916edbf08..00000000000 --- a/src/locales/fr/battle-scene.json +++ /dev/null @@ -1,3 +0,0 @@ -{ - "moneyOwned": "{{formattedMoney}} ₽" -} \ No newline at end of file diff --git a/src/locales/fr/battle.json b/src/locales/fr/battle.json deleted file mode 100644 index 5f5e81350e1..00000000000 --- a/src/locales/fr/battle.json +++ /dev/null @@ -1,103 +0,0 @@ -{ - "bossAppeared": "Un {{bossName}} apparait.", - "trainerAppeared": "Un combat est lancé\npar {{trainerName}} !", - "trainerAppearedDouble": "Un combat est lancé\npar {{trainerName}} !", - "trainerSendOut": "{{pokemonName}} est envoyé par\n{{trainerName}} !", - "singleWildAppeared": "Un {{pokemonName}} sauvage apparait !", - "multiWildAppeared": "Un {{pokemonName1}} et un {{pokemonName2}}\nsauvages apparaissent !", - "playerComeBack": "{{pokemonName}} !\nReviens !", - "trainerComeBack": "{{trainerName}} retire\n{{pokemonName}} !", - "playerGo": "{{pokemonName}} ! Go !", - "trainerGo": "{{pokemonName}} est envoyé par\n{{trainerName}} !", - "switchQuestion": "Voulez-vous changer\n{{pokemonName}} ?", - "trainerDefeated": "Vous avez battu\n{{trainerName}} !", - "moneyWon": "Vous remportez\n{{moneyAmount}} ₽ !", - "moneyPickedUp": "Vous obtenez {{moneyAmount}} ₽ !", - "pokemonCaught": "Vous avez attrapé\n{{pokemonName}} !", - "addedAsAStarter": "{{pokemonName}} est ajouté\ncomme starter !", - "partyFull": "Votre équipe est pleine.\nRelâcher un Pokémon pour {{pokemonName}} ?", - "pokemon": "de Pokémon", - "sendOutPokemon": "{{pokemonName}} ! Go !", - "hitResultCriticalHit": "Coup critique !", - "hitResultSuperEffective": "C’est super efficace !", - "hitResultNotVeryEffective": "Ce n’est pas très efficace…", - "hitResultNoEffect": "Ça n’affecte pas {{pokemonName}}…", - "hitResultImmune": "{{pokemonName}} n’est pas affecté !", - "hitResultOneHitKO": "K.O. en un coup !", - "attackFailed": "Mais cela échoue !", - "attackMissed": "{{pokemonNameWithAffix}}\névite l’attaque !", - "attackHitsCount": "Touché {{count}} fois !", - "rewardGain": "Vous recevez\n{{modifierName}} !", - "expGain": "{{pokemonName}} gagne\n{{exp}} Points d’Exp !", - "levelUp": "{{pokemonName}} monte au\nN. {{level}} !", - "learnMove": "{{pokemonName}} apprend\n{{moveName}} !", - "learnMovePrompt": "{{pokemonName}} veut apprendre\n{{moveName}}.", - "learnMoveLimitReached": "Cependant, {{pokemonName}} connait\ndéjà quatre capacités.", - "learnMoveReplaceQuestion": "Voulez-vous oublier une capacité\net la remplacer par {{moveName}} ?", - "learnMoveStopTeaching": "Arrêter d’apprendre\n{{moveName}} ?", - "learnMoveNotLearned": "{{pokemonName}} n’a pas appris\n{{moveName}}.", - "learnMoveForgetQuestion": "Quelle capacité doit être oubliée ?", - "learnMoveForgetSuccess": "{{pokemonName}} oublie comment\nutiliser {{moveName}}.", - "countdownPoof": "@d{32}1, @d{15}2, @d{15}et@d{15}… @d{15}… @d{15}… @d{15}@s{se/pb_bounce_1}Tadaaa !", - "learnMoveAnd": "Et…", - "levelCapUp": "La limite de niveau\na été augmentée à {{levelCap}} !", - "moveNotImplemented": "{{moveName}} n’est pas encore implémenté et ne peut pas être sélectionné.", - "moveNoPP": "Il n’y a plus de PP pour\ncette capacité !", - "moveDisabled": "{{moveName}} est sous entrave !", - "canOnlyUseMove": "{{pokemonName}} ne peut utiliser\nque la capacité {{moveName}} !", - "moveCannotBeSelected": "La capacité {{moveName}}\nne peut pas être choisie !", - "disableInterruptedMove": "Il y a une entrave sur la capacité {{moveName}}\nde{{pokemonNameWithAffix}} !", - "throatChopInterruptedMove": "Exécu-Son empêche {{pokemonName}}\nd’utiliser la capacité !", - "noPokeballForce": "Une force mystérieuse\nempêche l’utilisation des Poké Balls.", - "noPokeballTrainer": "Le Dresseur détourne la Ball\nVoler, c’est mal !", - "noPokeballMulti": "Impossible ! On ne peut pas viser\nquand il y a deux Pokémon !", - "noPokeballStrong": "Le Pokémon est trop fort pour être capturé !\nVous devez d’abord l’affaiblir !", - "noEscapeForce": "Une force mystérieuse\nempêche la fuite.", - "noEscapeTrainer": "On ne s’enfuit pas d’un\ncombat de Dresseurs !", - "noEscapePokemon": "{{moveName}} de {{pokemonName}}\nempêche {{escapeVerb}} !", - "runAwaySuccess": "Vous prenez la fuite !", - "runAwayCannotEscape": "Fuite impossible !", - "escapeVerbSwitch": "le changement", - "escapeVerbFlee": "la fuite", - "notDisabled": "La capacité {{moveName}}\nde {{pokemonName}} n’est plus sous entrave !", - "turnEndHpRestore": "{{pokemonName}} récupère des PV !", - "hpIsFull": "Les PV de {{pokemonName}}\nsont au maximum !", - "skipItemQuestion": "Êtes-vous sûr·e de ne pas vouloir prendre d’objet ?", - "itemStackFull": "Quantité maximale de {{fullItemName}} atteinte.\nVous recevez {{itemName}} à la place.", - "eggHatching": "Hein ?", - "ivScannerUseQuestion": "Utiliser le Scanner d’IV\nsur {{pokemonName}} ?", - "wildPokemonWithAffix": "{{pokemonName}} sauvage", - "foePokemonWithAffix": "{{pokemonName}} ennemi", - "useMove": "{{pokemonNameWithAffix}} utilise\n{{moveName}} !", - "stealEatBerry": "{{pokemonName}} vole et mange\nla {{berryName}} de {{targetName}} !", - "ppHealBerry": "La {{berryName}} de {{pokemonNameWithAffix}}\nrestaure les PP de sa capacité {{moveName}} !", - "hpHealBerry": "La {{berryName}} de {{pokemonNameWithAffix}}\nrestaure son énergie !", - "drainMessage": "L’énergie de {{pokemonName}}\nest drainée !", - "regainHealth": "{{pokemonName}} récupère\ndes PV !", - "fainted": "{{pokemonNameWithAffix}}\nest K.O. !", - "statsAnd": "et", - "stats": "Les stats", - "statRose_one": "{{stats}} de {{pokemonNameWithAffix}}\naugmente !", - "statRose_other": "{{stats}}\nde {{pokemonNameWithAffix}} augmentent !", - "statSharplyRose_one": "{{stats}} de {{pokemonNameWithAffix}}\naugmente beaucoup !", - "statSharplyRose_other": "{{stats}}\nde {{pokemonNameWithAffix}} augmentent beaucoup !", - "statRoseDrastically_one": "{{stats}} de {{pokemonNameWithAffix}}\naugmente énormément !", - "statRoseDrastically_other": "{{stats}}\nde {{pokemonNameWithAffix}} augmentent énormément !", - "statWontGoAnyHigher_one": "{{stats}} de {{pokemonNameWithAffix}}\nne peut plus augmenter !", - "statWontGoAnyHigher_other": "{{stats}}\nde {{pokemonNameWithAffix}} ne peuvent plus augmenter !", - "statFell_one": "{{stats}} de {{pokemonNameWithAffix}}\nbaisse !", - "statFell_other": "{{stats}}\nde {{pokemonNameWithAffix}} baissent !", - "statHarshlyFell_one": "{{stats}} de {{pokemonNameWithAffix}}\nbaisse beaucoup !", - "statHarshlyFell_other": "{{stats}}\nde {{pokemonNameWithAffix}} baissent beaucoup !", - "statSeverelyFell_one": "{{stats}} de {{pokemonNameWithAffix}}\nbaisse énormément !", - "statSeverelyFell_other": "{{stats}}\nde {{pokemonNameWithAffix}} baissent énormément !", - "statWontGoAnyLower_one": "{{stats}} de {{pokemonNameWithAffix}}\nne peut plus baisser !", - "statWontGoAnyLower_other": "{{stats}}\nde {{pokemonNameWithAffix}} ne peuvent plus baisser !", - "transformedIntoType": "{{pokemonName}} prend\nle type {{type}} !", - "ppReduced": "Les PP de la capacité {{moveName}}\nde {{targetName}} baissent de {{reduction}} !", - "retryBattle": "Voulez-vous réessayer depuis le début du combat ?", - "unlockedSomething": "{{unlockedThing}}\na été débloqué.", - "congratulations": "Félicitations !", - "beatModeFirstTime": "{{speciesName}} a battu le mode {{gameMode}} pour la première fois !\nVous avez reçu {{newModifier}} !", - "eggSkipPrompt": "Aller directement au résumé des Œufs éclos ?" -} diff --git a/src/locales/fr/battler-tags.json b/src/locales/fr/battler-tags.json deleted file mode 100644 index 4c5c7ea0df6..00000000000 --- a/src/locales/fr/battler-tags.json +++ /dev/null @@ -1,77 +0,0 @@ -{ - "trappedDesc": "le piège", - "flinchedDesc": "la peur", - "confusedDesc": "la confusion", - "infatuatedDesc": "l’amour", - "seedDesc": "l’infection", - "nightmareDesc": "les cauchemars", - "ingrainDesc": "l’enracinement", - "drowsyDesc": "la somnolence", - "rechargingLapse": "Le contrecoup empêche {{pokemonNameWithAffix}}\n de bouger !", - "trappedOnAdd": "{{pokemonNameWithAffix}}\nne peut plus s’échapper !", - "trappedOnRemove": "{{pokemonNameWithAffix}} est libéré\nde la capacité {{moveName}} !", - "flinchedLapse": "{{pokemonNameWithAffix}} a la trouille !\nIl ne peut plus attaquer !", - "confusedOnAdd": "Ça rend {{pokemonNameWithAffix}}\nconfus !", - "confusedOnRemove": "{{pokemonNameWithAffix}}\nn’est plus confus !", - "confusedOnOverlap": "{{pokemonNameWithAffix}}\nest déjà confus !", - "confusedLapse": "{{pokemonNameWithAffix}}\nest confus !", - "confusedLapseHurtItself": "Il se blesse dans sa confusion.", - "destinyBondLapseIsBoss": "{{pokemonNameWithAffix}} n’est pas affecté\nle Lien du Destin !", - "destinyBondLapse": "{{pokemonNameWithAffix}} entraine\n{{pokemonNameWithAffix2}} dans sa chute !", - "infatuatedOnAdd": "{{pokemonNameWithAffix}} est amoureux\nde {{sourcePokemonName}} !", - "infatuatedOnOverlap": "{{pokemonNameWithAffix}} est\ndéjà amoureux !", - "infatuatedLapse": "{{pokemonNameWithAffix}} est amoureux\nde {{sourcePokemonName}} !", - "infatuatedLapseImmobilize": "L’amour empêche {{pokemonNameWithAffix}}\nd’agir !", - "infatuatedOnRemove": "{{pokemonNameWithAffix}}\nn’est plus amoureux !", - "seededOnAdd": "{{pokemonNameWithAffix}} est infecté !", - "seededLapse": "Vampigraine draine l’énergie\nde {{pokemonNameWithAffix}} !", - "seededLapseShed": "La Vampigraine de {{pokemonNameWithAffix}}\naspire le suintement !", - "nightmareOnAdd": "{{pokemonNameWithAffix}} commence à cauchemarder !", - "nightmareOnOverlap": "{{pokemonNameWithAffix}} est\ndéjà prisonnier d’un cauchemar !", - "nightmareLapse": "{{pokemonNameWithAffix}}est\nprisonnier d’un cauchemar !", - "encoreOnAdd": "{{pokemonNameWithAffix}} !\nEncore une fois !", - "encoreOnRemove": "{{pokemonNameWithAffix}} n’est\nplus obligé d’utiliser la même capacité !", - "helpingHandOnAdd": "{{pokemonNameWithAffix}} est prêt\nà aider {{pokemonName}} !", - "ingrainLapse": "{{pokemonNameWithAffix}} absorbe\ndes nutriments avec ses racines !", - "ingrainOnTrap": "{{pokemonNameWithAffix}}\nplante ses racines !", - "aquaRingOnAdd": "{{pokemonNameWithAffix}} s’entoure\nd’un voile d’eau !", - "aquaRingLapse": "{{moveName}} restaure\nles PV de {{pokemonName}} !", - "drowsyOnAdd": "Ça rend {{pokemonNameWithAffix}} somnolent !", - "damagingTrapLapse": "{{pokemonNameWithAffix}} est blessé\npar la capacité {{moveName}} !", - "bindOnTrap": "{{pokemonNameWithAffix}} est pris dans\nl’étreinte de {{sourcePokemonName}} !", - "wrapOnTrap": "{{pokemonNameWithAffix}} est ligoté\npar {{sourcePokemonName}} !", - "vortexOnTrap": "{{pokemonNameWithAffix}} est piégé\ndans le tourbillon !", - "clampOnTrap": "{{sourcePokemonNameWithAffix}} est pris dans le Claquoir\nde {{pokemonName}} !", - "sandTombOnTrap": "{{pokemonNameWithAffix}} est piégé\npar {{moveName}} !", - "magmaStormOnTrap": "{{pokemonNameWithAffix}} est piégé\ndans un tourbillon de magma !", - "snapTrapOnTrap": "{{pokemonNameWithAffix}} est tombé\ndans un Troquenard !", - "thunderCageOnTrap": "{{pokemonNameWithAffix}} se fait emprisonner\npar {{sourcePokemonNameWithAffix}} !", - "infestationOnTrap": "{{pokemonNameWithAffix}} est harcelé\npar {{sourcePokemonNameWithAffix}} !", - "protectedOnAdd": "{{pokemonNameWithAffix}}\nest prêt à se protéger !", - "protectedLapse": "{{pokemonNameWithAffix}}\nse protège !", - "enduringOnAdd": "{{pokemonNameWithAffix}} se prépare\nà encaisser les coups !", - "enduringLapse": "{{pokemonNameWithAffix}}\nencaisse les coups !", - "sturdyLapse": "{{pokemonNameWithAffix}}\nencaisse les coups !", - "perishSongLapse": "Le compte à rebours de Requiem\nde {{pokemonNameWithAffix}} descend à {{turnCount}} !", - "centerOfAttentionOnAdd": "{{pokemonNameWithAffix}} devient\nle centre de l’attention !", - "truantLapse": "{{pokemonNameWithAffix}} paresse !", - "slowStartOnAdd": "{{pokemonNameWithAffix}}\nn’arrive pas à se motiver !", - "slowStartOnRemove": "{{pokemonNameWithAffix}}\narrive enfin à s’y mettre sérieusement !", - "highestStatBoostOnAdd": "{{statName}} de {{pokemonNameWithAffix}}\nest renforcée !", - "highestStatBoostOnRemove": "L’effet du talent {{abilityName}}\nde {{pokemonNameWithAffix}} se dissipe !", - "magnetRisenOnAdd": "{{pokemonNameWithAffix}} lévite\nsur un champ magnétique !", - "magnetRisenOnRemove": "Le magnétisme de{{pokemonNameWithAffix}}\nse dissipe !", - "critBoostOnAdd": "{{pokemonNameWithAffix}}\nest prêt à tout donner !", - "critBoostOnRemove": "{{pokemonNameWithAffix}} se détend.", - "saltCuredOnAdd": "{{pokemonNameWithAffix}}\nest couvert de sel !", - "saltCuredLapse": "{{pokemonNameWithAffix}} est blessé\npar la capacité {{moveName}} !", - "cursedOnAdd": "{{pokemonNameWithAffix}} sacrifie des PV\net lance une malédiction sur {{pokemonName}} !", - "cursedLapse": "{{pokemonNameWithAffix}} est touché par la malédiction !", - "stockpilingOnAdd": "{{pokemonNameWithAffix}} utilise\nla capacité Stockage {{stockpiledCount}} fois !", - "disabledOnAdd": "La capacité {{moveName}}\nde {{pokemonNameWithAffix}} est mise sous entrave !", - "disabledLapse": "La capacité {{moveName}}\nde {{pokemonNameWithAffix}} n’est plus sous entrave !", - "tarShotOnAdd": "{{pokemonNameWithAffix}} est maintenant\nvulnérable au feu !", - "substituteOnAdd": "{{pokemonNameWithAffix}}\ncrée un clone !", - "substituteOnHit": "Le clone subit les dégâts à la place\nde {{pokemonNameWithAffix}} !", - "substituteOnRemove": "Le clone de {{pokemonNameWithAffix}}\ndisparait…" -} diff --git a/src/locales/fr/berry.json b/src/locales/fr/berry.json deleted file mode 100644 index 17f28fb8dd0..00000000000 --- a/src/locales/fr/berry.json +++ /dev/null @@ -1,46 +0,0 @@ -{ - "SITRUS": { - "name": "Baie Sitrus", - "effect": "Restaure 25% des PV du porteur s’ils sont inférieurs à 50%." - }, - "LUM": { - "name": "Baie Prine", - "effect": "Soigne tout problème de statut et la confusion du porteur." - }, - "ENIGMA": { - "name": "Baie Enigma", - "effect": "Restaure 25% des PV du porteur s’il est touché par une capacité super efficace." - }, - "LIECHI": { - "name": "Baie Lichii", - "effect": "Augmente l’Attaque du porteur si ses PV sont inférieurs à 25%." - }, - "GANLON": { - "name": "Baie Lingan", - "effect": "Augmente la Défense du porteur si ses PV sont inférieurs à 25%." - }, - "PETAYA": { - "name": "Baie Pitaye", - "effect": "Augmente l’Atq. Spé. du porteur si ses PV sont inférieurs à 25%." - }, - "APICOT": { - "name": "Baie Abriko", - "effect": "Augmente la Déf. Spé. du porteur si ses PV sont inférieurs à 25%." - }, - "SALAC": { - "name": "Baie Sailak", - "effect": "Augmente la Vitesse du porteur si ses PV sont inférieurs à 25%." - }, - "LANSAT": { - "name": "Baie Lansat", - "effect": "Augmente le taux de coups critiques du porteur si ses PV sont inférieurs à 25%." - }, - "STARF": { - "name": "Baie Frista", - "effect": "Augmente énormément une statistique au hasard du porteur si ses PV sont inférieurs à 25%." - }, - "LEPPA": { - "name": "Baie Mepo", - "effect": "Restaure 10 PP à une capacité du porteur dès que ses PP tombent à 0." - } -} diff --git a/src/locales/fr/bgm-name.json b/src/locales/fr/bgm-name.json deleted file mode 100644 index ecf0075e79d..00000000000 --- a/src/locales/fr/bgm-name.json +++ /dev/null @@ -1,150 +0,0 @@ -{ - "music": "♪ : ", - "missing_entries": "{{name}}", - "battle_kanto_champion": "N2B2 - Vs. Maitre de Kanto", - "battle_johto_champion": "N2B2 - Vs. Maitre de Johto", - "battle_hoenn_champion_g5": "N2B2 - Vs. Maitre de Hoenn", - "battle_hoenn_champion_g6": "ROSA - Vs. Maitre de Hoenn", - "battle_sinnoh_champion": "N2B2 - Vs. Maitresse de Sinnoh", - "battle_champion_alder": "NB - Vs. Maitre d’Unys", - "battle_champion_iris": "N2B2 - Vs. Maitresse d’Unys", - "battle_kalos_champion": "XY - Maitresse de Kalos", - "battle_alola_champion": "USUL - Maitre d’Alola", - "battle_galar_champion": "ÉB - Maitre de Galar", - "battle_champion_geeta": "ÉV - Vs. Alisma la Maitresse", - "battle_champion_nemona": "ÉV - Vs. Menzi la Maitresse", - "battle_champion_kieran": "ÉV - Vs. Kassis le Maitre", - "battle_hoenn_elite": "ROSA - Vs. Conseil 4", - "battle_unova_elite": "NB - Vs. Conseil 4", - "battle_kalos_elite": "XY - Vs. Conseil 4", - "battle_alola_elite": "SL - Vs. Conseil 4", - "battle_galar_elite": "ÉB - Vs. Tournoi des Champions", - "battle_paldea_elite": "ÉV - Vs. Conseil 4", - "battle_bb_elite": "ÉV - Vs. Conseil 4 de l’Institut Myrtille", - "battle_final_encounter": "PDM ÉdS DX - Vs. Rayquaza", - "battle_final": "NB - Vs. Ghetis", - "battle_kanto_gym": "N2B2 - Vs. Champion·ne d’Arène de Kanto", - "battle_johto_gym": "N2B2 - Vs. Champion·ne d’Arène de Johto", - "battle_hoenn_gym": "N2B2 - Vs. Champion·ne d’Arène de Hoenn", - "battle_sinnoh_gym": "N2B2 - Vs. Champion·ne d’Arène de Sinnoh", - "battle_unova_gym": "NB - Vs. Champion·ne d’Arène d’Unys", - "battle_kalos_gym": "XY - Vs. Champion·ne d’Arène de Kalos", - "battle_galar_gym": "ÉB - Vs. Champion·ne d’Arène de Galar", - "battle_paldea_gym": "ÉV - Vs. Champion·ne d’Arène de Paldea", - "battle_legendary_kanto": "XY - Vs. Légendaire de Kanto", - "battle_legendary_raikou": "HGSS - Vs. Raikou", - "battle_legendary_entei": "HGSS - Vs. Entei", - "battle_legendary_suicune": "HGSS - Vs. Suicune", - "battle_legendary_lugia": "HGSS - Vs. Lugia", - "battle_legendary_ho_oh": "HGSS - Vs. Ho-oh", - "battle_legendary_regis_g5": "N2B2 - Vs. Colosses Légendaires", - "battle_legendary_regis_g6": "ROSA - Vs. Colosses Légendaires", - "battle_legendary_gro_kyo": "ROSA - Vs. Groudon/Kyogre", - "battle_legendary_rayquaza": "ROSA - Vs. Rayquaza", - "battle_legendary_deoxys": "ROSA - Vs. Deoxys", - "battle_legendary_lake_trio": "ROSA - Vs. Gardiens des Lacs", - "battle_legendary_sinnoh": "ROSA - Vs. Légendaire de Sinnoh", - "battle_legendary_dia_pal": "ROSA - Vs. Dialga/Palkia", - "battle_legendary_origin_forme": "LPA - Vs. Dialga/Palkia Originel", - "battle_legendary_giratina": "ROSA - Vs. Giratina", - "battle_legendary_arceus": "HGSS - Vs. Arceus", - "battle_legendary_unova": "NB - Vs. Légendaire d’Unys", - "battle_legendary_kyurem": "NB - Vs. Kyurem", - "battle_legendary_res_zek": "NB - Vs. Reshiram/Zekrom", - "battle_legendary_xern_yvel": "XY - Vs. Xerneas/Yveltal", - "battle_legendary_tapu": "SL - Vs. Divinités gardiennes d’Alola", - "battle_legendary_sol_lun": "SL - Vs. Solgaleo/Lunala", - "battle_legendary_ub": "SL - Vs. Ultra-Chimère", - "battle_legendary_dusk_dawn": "USUL - Vs. Necrozma Crinière du Couchant/Ailes de l’Aurore", - "battle_legendary_ultra_nec": "USUL - Vs. Ultra-Necrozma", - "battle_legendary_zac_zam": "ÉB - Vs. Zacian/Zamazenta", - "battle_legendary_glas_spec": "ÉB - Vs. Blizzeval/Spectreval", - "battle_legendary_calyrex": "ÉB - Vs. Sylveroy", - "battle_legendary_riders": "ÉB - Vs. Sylveroy Cavalier du Froid/d’Effroi", - "battle_legendary_birds_galar": "ÉB - Vs. Oiseaux Légendaires de Galar", - "battle_legendary_ruinous": "ÉV - Vs. Trésors du fléau", - "battle_legendary_kor_mir": "ÉV - Profondeurs de la Zone Zéro (Combat)", - "battle_legendary_loyal_three": "ÉV - Vs. Adoramis", - "battle_legendary_ogerpon": "ÉV - Vs. Ogerpon", - "battle_legendary_terapagos": "ÉV - Vs. Terapagos", - "battle_legendary_pecharunt": "ÉV - Vs. Pêchaminus", - "battle_rival": "NB - Vs. Rival", - "battle_rival_2": "NB - Vs. N", - "battle_rival_3": "NB - Combat final Vs. N", - "battle_trainer": "NB - Vs. Dresseur·euse", - "battle_wild": "NB - Vs. Pokémon sauvage", - "battle_wild_strong": "NB - Vs. Pokémon puissant sauvage", - "end_summit": "PDM ÉdS DX - Tour Céleste (Sommet)", - "battle_rocket_grunt": "HGSS Vs. Team Rocket", - "battle_aqua_magma_grunt": "ROSA Vs. Team Aqua/Magma", - "battle_galactic_grunt": "DÉPS Vs. Team Galaxie", - "battle_plasma_grunt": "NB - Vs. Team Plasma", - "battle_flare_grunt": "XY - Vs. Team Flare", - "battle_aether_grunt": "SL - Vs. Fondation Æther", - "battle_skull_grunt": "SL - Vs. Team Skull", - "battle_macro_grunt": "ÉB - Vs. Macro Cosmos", - "battle_galactic_admin": "DÉPS - Vs. Admin Team Galaxie", - "battle_skull_admin": "SL - Vs. Admin Team Skull", - "battle_oleana": "ÉB - Vs. Liv", - "battle_rocket_boss": "USUL - Vs. Giovanni", - "battle_aqua_magma_boss": "ROSA - Vs. Arthur/Max", - "battle_galactic_boss": "DÉPS - Vs. Hélio", - "battle_plasma_boss": "N2B2 - Vs. Ghetis", - "battle_flare_boss": "XY - Vs. Lysandre", - "battle_aether_boss": "SL - Vs. Elsa-Mina", - "battle_skull_boss": "SL - Vs. Guzma", - "battle_macro_boss": "ÉB - Vs. Shehroz", - - "abyss": "PDM EdC - Cratère Obscur", - "badlands": "PDM EdC - Vallée Stérile", - "beach": "PDM EdC - Falaise Trempée", - "cave": "PDM EdC - Pic Céleste (grotte)", - "construction_site": "PDM EdC - Carrière Rocher", - "desert": "PDM EdC - Désert du Nord", - "dojo": "PDM EdC - Dojo Ossatueur", - "end": "PDM EdC - Tour Céleste", - "factory": "PDM EdC - Ruines Cachées", - "fairy_cave": "PDM EdC - Caverne Étoile", - "forest": "PDM EdC - Forêt Crépuscule", - "grass": "PDM EdC - Bois aux Pommes", - "graveyard": "PDM EdC - Forêt Trompeuse", - "ice_cave": "PDM EdC - Montagne Glacier", - "island": "PDM EdC - Côte Escarpée", - "jungle": "Lmz - Jungle", - "laboratory": "Firel - Laboratory", - "lake": "PDM EdC - Caverne Cristal", - "meadow": "PDM EdC - Pic Céleste (forêt)", - "metropolis": "Firel - Metropolis", - "mountain": "PDM EdC - Mont Corne", - "plains": "PDM EdC - Pic Céleste (prairie)", - "power_plant": "PDM EdC - Plaines Élek", - "ruins": "PDM EdC - Ruine Scellée", - "sea": "Andr06 - Marine Mystique", - "seabed": "Firel - Seabed", - "slum": "Andr06 - Sneaky Snom", - "snowy_forest": "PDM EdC - Pic Céleste (plaine enneigée)", - "space": "Firel - Aether", - "swamp": "PDM EdC - Mer Fermée", - "tall_grass": "PDM EdC - Forêt Brumeuse", - "temple": "PDM EdC - Grotte Égide", - "town": "PDM EdC - Donjon aléatoire - Thème 3", - "volcano": "PDM EdC - Grotte Étuve", - "wasteland": "PDM EdC - Terres Illusoires", - "encounter_ace_trainer": "NB - Regards croisés (Topdresseur·euse)", - "encounter_backpacker": "NB - Regards croisés (Randonneur·euse)", - "encounter_clerk": "NB - Regards croisés (Employé·e)", - "encounter_cyclist": "NB - Regards croisés (Cycliste)", - "encounter_lass": "NB - Regards croisés (Fillette)", - "encounter_parasol_lady": "NB - Regards croisés (Sœur Parasol)", - "encounter_pokefan": "NB - Regards croisés (Pokéfan)", - "encounter_psychic": "NB - Regards croisés (Kinésiste)", - "encounter_rich": "NB - Regards croisés (Gentleman)", - "encounter_rival": "NB - Tcheren", - "encounter_roughneck": "NB - Regards croisés (Loubard)", - "encounter_scientist": "NB - Regards croisés (Scientifique)", - "encounter_twins": "NB - Regards croisés (Jumelles)", - "encounter_youngster": "NB - Regards croisés (Gamin)", - "heal": "NB - Soin de Pokémon", - "menu": "PDM EdC - Bienvenue dans le monde de Pokémon !", - "title": "PDM EdC - Menu Principal" -} diff --git a/src/locales/fr/biome.json b/src/locales/fr/biome.json deleted file mode 100644 index e1012c7ea9e..00000000000 --- a/src/locales/fr/biome.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "unknownLocation": "vous avez oublié où", - "TOWN": "Ville", - "PLAINS": "Plaines", - "GRASS": "Herbes", - "TALL_GRASS": "Hautes Herbes", - "METROPOLIS": "Métropole", - "FOREST": "Forêt", - "SEA": "Mer", - "SWAMP": "Marécage", - "BEACH": "Plage", - "LAKE": "Lac", - "SEABED": "Fonds Marins", - "MOUNTAIN": "Montagne", - "BADLANDS": "Terres Sauvages", - "CAVE": "Grotte", - "DESERT": "Désert", - "ICE_CAVE": "Caverne Gelée", - "MEADOW": "Prairie", - "POWER_PLANT": "Centrale", - "VOLCANO": "Volcan", - "GRAVEYARD": "Cimetière", - "DOJO": "Dojo", - "FACTORY": "Usine", - "RUINS": "Ruines", - "WASTELAND": "Terres Désolées", - "ABYSS": "Gouffre", - "SPACE": "Espace", - "CONSTRUCTION_SITE": "Chantier", - "JUNGLE": "Jungle", - "FAIRY_CAVE": "Grotte Féérique", - "TEMPLE": "Temple", - "SLUM": "Bidonville", - "SNOWY_FOREST": "Forêt Enneigée", - "ISLAND": "Ile", - "LABORATORY": "Laboratoire", - "END": "???" -} \ No newline at end of file diff --git a/src/locales/fr/challenges.json b/src/locales/fr/challenges.json deleted file mode 100644 index 86a21881a50..00000000000 --- a/src/locales/fr/challenges.json +++ /dev/null @@ -1,37 +0,0 @@ -{ - "title": "Paramètres du Challenge", - "illegalEvolution": "{{pokemon}} est devenu\ninéligible pour ce challenge !", - "noneSelected": "Aucun sélectionné", - "singleGeneration": { - "name": "Monogénération", - "desc": "Vous ne pouvez choisir que des Pokémon de {{gen}} génération.", - "desc_default": "Vous ne pouvez choisir que des Pokémon de la génération sélectionnée.", - "gen_1": "1re", - "gen_2": "2e", - "gen_3": "3e", - "gen_4": "4e", - "gen_5": "5e", - "gen_6": "6e", - "gen_7": "7e", - "gen_8": "8e", - "gen_9": "9e" - }, - "singleType": { - "name": "Monotype", - "desc": "Vous ne pouvez choisir que des Pokémon de type {{type}}.", - "desc_default": "Vous ne pouvez choisir que des Pokémon du type sélectionné." - }, - "freshStart": { - "name": "Nouveau départ", - "desc": "Vous ne pouvez choisir que les starters de base du jeu, comme si vous le recommenciez.", - "value.0": "Non", - "value.1": "Oui" - }, - "inverseBattle": { - "name": "Combat Inversé", - "shortName": "Inversé", - "desc": "Les affinités de la table des types sont inversées et plus aucun type n’a d’immunité.\nDésactive les succès des autres challenges.", - "value.0": "Non", - "value.1": "Oui" - } -} diff --git a/src/locales/fr/command-ui-handler.json b/src/locales/fr/command-ui-handler.json deleted file mode 100644 index 82733837375..00000000000 --- a/src/locales/fr/command-ui-handler.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "fight": "Attaque", - "ball": "Ball", - "pokemon": "Pokémon", - "run": "Fuite", - "actionMessage": "Que doit faire\n{{pokemonName}} ?" -} diff --git a/src/locales/fr/common.json b/src/locales/fr/common.json deleted file mode 100644 index 623177d1e2b..00000000000 --- a/src/locales/fr/common.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "start": "Lancer", - "luckIndicator": "Chance :", - "shinyOnHover": "Chromatique", - "commonShiny": "Commun", - "rareShiny": "Rare", - "epicShiny": "Épique" -} diff --git a/src/locales/fr/config.ts b/src/locales/fr/config.ts deleted file mode 100644 index f79374cd3b9..00000000000 --- a/src/locales/fr/config.ts +++ /dev/null @@ -1,113 +0,0 @@ -import common from "./common.json"; -import settings from "./settings.json"; -import ability from "./ability.json"; -import abilityTriggers from "./ability-trigger.json"; -import arenaFlyout from "./arena-flyout.json"; -import arenaTag from "./arena-tag.json"; -import achv from "./achv.json"; -import battle from "./battle.json"; -import battleScene from "./battle-scene.json"; -import battleInfo from "./battle-info.json"; -import battleMessageUiHandler from "./battle-message-ui-handler.json"; -import battlerTags from "./battler-tags.json"; -import berry from "./berry.json"; -import bgmName from "./bgm-name.json"; -import biome from "./biome.json"; -import challenges from "./challenges.json"; -import commandUiHandler from "./command-ui-handler.json"; -import dialogue from "./dialogue.json"; -import battleSpecDialogue from "./dialogue-final-boss.json"; -import miscDialogue from "./dialogue-misc.json"; -import doubleBattleDialogue from "./dialogue-double-battle.json"; -import egg from "./egg.json"; -import fightUiHandler from "./fight-ui-handler.json"; -import filterBar from "./filter-bar.json"; -import gameMode from "./game-mode.json"; -import gameStatsUiHandler from "./game-stats-ui-handler.json"; -import growth from "./growth.json"; -import menu from "./menu.json"; -import menuUiHandler from "./menu-ui-handler.json"; -import modifier from "./modifier.json"; -import modifierType from "./modifier-type.json"; -import move from "./move.json"; -import nature from "./nature.json"; -import partyUiHandler from "./party-ui-handler.json"; -import pokeball from "./pokeball.json"; -import pokemon from "./pokemon.json"; -import pokemonForm from "./pokemon-form.json"; -import battlePokemonForm from "./pokemon-form-battle.json"; -import pokemonInfo from "./pokemon-info.json"; -import pokemonInfoContainer from "./pokemon-info-container.json"; -import pokemonSummary from "./pokemon-summary.json"; -import saveSlotSelectUiHandler from "./save-slot-select-ui-handler.json"; -import splashMessages from "./splash-messages.json"; -import starterSelectUiHandler from "./starter-select-ui-handler.json"; -import statusEffect from "./status-effect.json"; -import trainerTitles from "./trainer-titles.json"; -import trainerClasses from "./trainer-classes.json"; -import trainerNames from "./trainer-names.json"; -import tutorial from "./tutorial.json"; -import voucher from "./voucher.json"; -import weather from "./weather.json"; -import terrain from "./terrain.json"; -import modifierSelectUiHandler from "./modifier-select-ui-handler.json"; -import moveTriggers from "./move-trigger.json"; -import runHistory from "./run-history.json"; - -export const frConfig = { - ability, - abilityTriggers, - arenaFlyout, - arenaTag, - battle, - battleScene, - battleInfo, - battleMessageUiHandler, - battlePokemonForm, - battlerTags, - berry, - bgmName, - biome, - challenges, - commandUiHandler, - common, - achv, - dialogue, - battleSpecDialogue, - miscDialogue, - doubleBattleDialogue, - egg, - fightUiHandler, - filterBar, - gameMode, - gameStatsUiHandler, - growth, - menu, - menuUiHandler, - modifier, - modifierType, - move, - nature, - pokeball, - pokemon, - pokemonForm, - pokemonInfo, - pokemonInfoContainer, - pokemonSummary, - saveSlotSelectUiHandler, - settings, - splashMessages, - starterSelectUiHandler, - statusEffect, - terrain, - titles: trainerTitles, - trainerClasses, - trainerNames, - tutorial, - voucher, - weather, - partyUiHandler, - modifierSelectUiHandler, - moveTriggers, - runHistory, -}; diff --git a/src/locales/fr/dialogue-double-battle.json b/src/locales/fr/dialogue-double-battle.json deleted file mode 100644 index fbc5d56ed26..00000000000 --- a/src/locales/fr/dialogue-double-battle.json +++ /dev/null @@ -1,83 +0,0 @@ -{ - "blue_red_double": { - "encounter": { - "1": "Blue : Hé Red, montrons-lui de quel bois on se chauffe !\n$Red : …\n$Blue : Voilà la puissance du Bourg Palette !" - }, - "victory": { - "1": "Blue : C’était un magnifique combat !\n$Red : …" - } - }, - "red_blue_double": { - "encounter": { - "1": "Red : … !\n$Blue : Il est pas très loquace.\n$Blue : Mais ne te laisse pas avoir, ça reste un Maitre Pokémon !" - }, - "victory": { - "1": "Red : … !\n$Blue : La prochaine fois, on va te battre !" - } - }, - "tate_liza_double": { - "encounter": { - "1": "Lévy : Héhéhé… Tu en fais une drôle de tête.\n$Tatia : Tu ne t’attendais pas à rencontrer deux Champions, n’est-ce pas ?\n$Lévy : Nous sommes des jumeaux !\n$Tatia : Nous n’avons pas besoin de parler entre nous !\n$Lévy : Tu crois pouvoir briser…\n$Tatia : … Notre duo parfait ?" - }, - "victory": { - "1": "Lévy : Quoi ? Notre combinaison était parfaite !\n$Tatia : Nous avons encore besoin d’entrainement…" - } - }, - "liza_tate_double": { - "encounter": { - "1": "Tatia : Hihih… Si tu voyais ta tête !\n$Lévy : Oui, nous sommes deux Champions en un !\n$Tatia : Voici mon frère, Lévy…\n$Lévy : … Et ma sœur, Tatia !\n$Tatia : Tu ne penses pas que notre combinaison est parfaite ?" - }, - "victory": { - "1": "Tatia : Quoi ? Notre combinaison…\n$Lévy : … a échoué !" - } - }, - "wallace_steven_double": { - "encounter": { - "1": "Pierre R. : Marc, montrons-lui la puissance des Maitres !\n$Marc : Tu vas gouter au pouvoir de Hoenn !\n$Pierre R. : C’est parti !" - }, - "victory": { - "1": "Pierre R. : C’était un beau combat !\n$Marc : Ce sera notre tour la prochaine fois !" - } - }, - "steven_wallace_double": { - "encounter": { - "1": "Pierre R. : Excuse-moi, aurais-tu des Pokémon rares ?\n$Marc : Pierre… Nous sommes là pour nous battre, pas pour frimer avec nos Pokémon.\n$Pierre R. : Oh… Je vois… Commençons alors !" - }, - "victory": { - "1": "Pierre R. : Bien, maintenant que ce combat est clos, montrons-nous nos Pokémon !\n$Marc : Pierre…" - } - }, - "alder_iris_double": { - "encounter": { - "1": "Goyah : Nous sommes l’élite des Dresseurs d’Unys !\n$Iris : Rien de mieux que des combats contre des prodiges !" - }, - "victory": { - "1": "Goyah : INCROYABLE ! T’es trop doué !\n$Iris : On gagnera la prochaine fois !" - } - }, - "iris_alder_double": { - "encounter": { - "1": "Iris : Bienvenue, Dresseur ! Je suis LA Maitresse d’Unys !\n$Goyah : Iris, concentre-toi s’il te plait…" - }, - "victory": { - "1": "Iris : On a tout donné et pourtant…\n$Goyah : Cette défaite ne pourra que nous être bénéfique !" - } - }, - "piers_marnie_double": { - "encounter": { - "1": "Rosemary : Frérot, montrons-lui la puissance de Smashings !\n$Peterson : Nous sommes les ténèbres !" - }, - "victory": { - "1": "Rosemary : T’as amené la lumière dans les ténèbres !\n$Peterson : P’têtre un peu trop…" - } - }, - "marnie_piers_double": { - "encounter": { - "1": "Peterson : Chauds pour un concert ?\n$Rosemary : Frérot… Il est pas là pour chanter, mais se battre…", - "1_female": "Peterson : Chauds pour un concert ?\n$Rosemary : Frérot… Elle est pas là pour chanter, mais se battre…" - }, - "victory": { - "1": "Peterson : Ça c’est du rock !\n$Rosemary : Frérot…" - } - } -} diff --git a/src/locales/fr/dialogue-final-boss.json b/src/locales/fr/dialogue-final-boss.json deleted file mode 100644 index b7226ebb480..00000000000 --- a/src/locales/fr/dialogue-final-boss.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "encounter": "Une fois de plus, te revoilà.\nSais-tu que ce n’est point là ta première venue ?\n$Tu as été appelé ici parce que t’y es déjà venu.\nUn nombre inimaginable de fois.\n$Mais allons-y, faisons le décompte.\nTu en es très précisément à ton {{cycleCount}}e cycle.\n$Chaque cycle réinitialise ton souvenir du précédent.\nMais étrangement, des bribes subsistent en toi.\n$Jusqu’à maintenant, tu as toujours échoué. Mais je ressens quelque chose de différent cette fois-ci.\n\n$Tu es la seule présence ici, bien que j’ai le sentiment d’en ressentir… une autre.\n$Vas-tu enfin me livrer un affrontement digne de ce nom ?\nCe challenge dont je rêve depuis un millénaire ?\n$Commençons.", - "encounter_female": "Une fois de plus, te revoilà.\nSais-tu que ce n’est point là ta première venue ?\n$Tu as été appelée ici parce que t’y es déjà venue.\nUn nombre inimaginable de fois.\n$Mais allons-y, faisons le décompte.\nTu en es très précisément à ton {{cycleCount}}e cycle.\n$Chaque cycle réinitialise ton souvenir du précédent.\nMais étrangement, des bribes subsistent en toi.\n$Jusqu’à maintenant, tu as toujours échoué. Mais je ressens quelque chose de différent cette fois-ci.\n\n$Tu es la seule présence ici, bien que j’ai le sentiment d’en ressentir… une autre.\n$Vas-tu enfin me livrer un affrontement digne de ce nom ?\nCe challenge dont je rêve depuis un millénaire ?\n$Commençons.", - "firstStageWin": "Je vois. Cette présence était bien réelle.\nJe n’ai donc plus besoin de retenir mes coups.\n$Ne me déçoit pas.", - "secondStageWin": "… Magnifique." -} diff --git a/src/locales/fr/dialogue-misc.json b/src/locales/fr/dialogue-misc.json deleted file mode 100644 index 864bd53eab5..00000000000 --- a/src/locales/fr/dialogue-misc.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "ending": "@c{shock}T’es revenu ?@d{32} Ça veut dire…@d{96} que t’as gagné ?!\n@c{smile_ehalf}J’aurais dû m’en douter.\n$@c{smile_eclosed}Bien sûr… J’ai toujours eu ce sentiment.\n@c{smile}C’est fini maintenant hein ? T’as brisé ce cycle.\n$@c{smile_ehalf}T’as aussi accompli ton rêve non ?\nTu n’as pas connu la moindre défaite.\n$Je serai la seule à me souvenir de ce que t’as fait.\n@c{angry_mopen}Je tâcherai de ne pas oublier !\n$@c{smile_wave_wink}J’déconne !@d{64} @c{smile}Jamais j’oublierai.@d{32}\nTa légende vivra à jamais dans nos cœurs.\n$@c{smile_wave}Bon,@d{64} il se fait tard…@d{96} je crois ?\nDifficile à dire ici.\n$Rentrons, @c{smile_wave_wink}et demain on se fera un p’tit combat, comme au bon vieux temps ?", - "ending_female": "@c{smile}Oh ? T’as gagné ?@d{96} @c{smile_eclosed}J’aurais dû m’en douter.\nMais te voilà enfin de retour.\n$@c{smile}C’est terminé.@d{64} T’as brisé ce cycle infernal.\n$@c{serious_smile_fists}T’as aussi accompli ton rêve non ?\nTu n’as pas connu la moindre défaite.\n$@c{neutral}Je suis le seul à me souvenir de ce que t’as fait.@d{96}\nJe pense que ça ira, non ?\n$@c{serious_smile_fists}Ta légende vivra à jamais dans nos cœurs.\n$@c{smile_eclosed}Bref, j’en ai un peu marre de ce endroit, pas toi ? Rentrons à la maison.\n$@c{serious_smile_fists}On se fera un p’tit combat une fois rentrés ?\nSi t’es d’accord.", - "ending_endless": "Félicitations ! Vous avez atteint la fin actuelle.\nPlus de contenu à venir bientôt !", - "ending_name": "Les devs" -} diff --git a/src/locales/fr/dialogue.json b/src/locales/fr/dialogue.json deleted file mode 100644 index adc58de0563..00000000000 --- a/src/locales/fr/dialogue.json +++ /dev/null @@ -1,704 +0,0 @@ -{ - "youngster": { - "encounter": { - "1": "Hé ! Combat ?", - "2": "Toi aussi tu débutes ?", - "3": "Hé, j’me souviens pas de ta tête. Combat !", - "4": "J’ai perdu, alors j’essaye de capturer d’autres Pokémon.\nHé, t’as l’air faible toi ! Allez, combat !", - "5": "On s’connait ? J’ai comme un doute. Dans tous les cas, sympa de te rencontrer !", - "6": "Allez, c’est parti !", - "7": "Attention, me voilà !\nTu vas voir comment j’suis fort !", - "8": "Coucou… Tu veux voir mes bô Pokémon ?", - "9": "Trêve de mondanités. Ramène-toi quand tu le sens !", - "10": "Baisse pas ta garde si tu veux pas pleurer d’avoir perdu face à un gamin.", - "11": "J’ai tout donné pour élever mes Pokémon. Attention à toi si tu leur fait du mal !", - "12": "Incroyable que t’y sois parvenu ! Mais la suite va pas être une partie de plaisir.", - "12_female": "Incroyable que t’y sois parvenue ! Mais la suite va pas être une partie de plaisir.", - "13": "Les combats sont éternels ! Bienvenue dans un monde sans fin !" - }, - "victory": { - "1": "Hé, mais t’es trop fort !", - "1_female": "Hé, mais t’es trop forte !", - "2": "En vrai j’avais aucune chance hein ?", - "3": "J’te retrouverai un jour, et là j’te battrai !", - "4": "Arg… J’ai plus aucun Pokémon.", - "5": "Non… IMPOSSIBLE ! Pourquoi j’ai encore perdu…", - "6": "Non ! J’ai perdu !", - "7": "Waah ! T’es trop incroyable ! J’suis bouche bée !", - "8": "Pourquoi… Comment… Pourtant on est les plus forts, mes Pokémon et moi…", - "9": "J’perdrai pas la prochaine fois ! Remettons ça un jour !", - "10": "Weeeesh ! Tu vois que j’suis qu’un gamin ? C’est pas juste de me bully comme ça !", - "11": "Tes Pokémon sont trop incroyables !\n… P’tit échange ?", - "12": "Je me suis fait un peu aider plus tôt, mais de quel taf je parlais ?", - "13": "Ahaha ! Et voilà, ça y est !\nT’es déjà comme chez toi dans ce monde !" - } - }, - "lass": { - "encounter": { - "1": "Affrontons-nous, d’accord ?", - "2": "T’as l’air d’un nouveau Dresseur. Battons nous !", - "2_female": "T’as l’air d’une nouvelle Dresseuse. Battons nous !", - "3": "Je te connais pas. Ça te dis de te battre ?", - "4": "Prenons du bon temps avec ce combat Pokémon !", - "5": "Je vais t’apprendre à te battre avec tes Pokémon !", - "6": "Un combat doit toujours être pris au sérieux.\nT’es prêt à te battre ?", - "6_female": "Un combat doit toujours être pris au sérieux.\nT’es prête à te battre ?", - "7": "Tu seras pas jeune éternellement. T’as qu’une chance pendant un combat. Bientôt, tu seras plus qu’un souvenir.", - "8": "Tu ferais mieux d’y aller doucement avec moi. Mais je vais me battre sérieusement !", - "9": "Je m’ennuie à l’école. Y’a rien à y faire. *Baille*\nJe me bats juste pour passer le temps." - }, - "victory": { - "1": "Wah, c’était impressionnant ! J’ai encore beaucoup à apprendre.", - "2": "Je ne pensais pas que je perdrais comme ça…", - "2_female": "Je pensais pas que je perdrais comme ça…", - "3": "J’espère que j’aurai ma revanche un jour.", - "4": "C’était super amusant ! Mais ce combat m’a épuisée…", - "5": "Tu m’as appris une belle leçon ! T’es vraiment incroyable !", - "6": "Vraiment ? J’ai perdu… ? Bon, ça arrive, mais c’était cool quand même.", - "6_female": "Vraiment ? J’ai perdu… ? Bon, ça arrive, mais c’était cool quand même.", - "7": "J’ai pas besoin de ce genre de souvenirs.\n*Suppression de mémoire en cours…*", - "8": "Hé ! Je t’avais dit d’y aller doucement avec moi ! Mais t’es vraiment si cool quand tu te bats sérieusement…", - "9": "J’en ai marre des combats Pokémon…\nJe vais chercher d’autres trucs à faire…" - } - }, - "breeder": { - "encounter": { - "1": "Qu’ils soient obéissants ou égoïstes… Les Pokémon ont des caractéristiques uniques.", - "2": "Même si mes choix et ma personnalité ne sont pas fous, je pense quand même bien avoir élevé mes Pokémon.", - "3": "Hum, t’es pas trop laxiste avec tes Pokémon ?\nTrop les chouchouter n’est pas bon." - }, - "victory": { - "1": "Il est primordial de nourrir et développer toutes les caractéristiques de chaque Pokémon.", - "2": "Contrairement à moi, ces Pokémon ont un bon fond.", - "3": "Trop d’éloges peut ruiner les Pokémon et les gens." - }, - "defeat": { - "1": "Tu ne devrais pas t’énerver sur tes Pokémon, même après une défaite.", - "2": "Alors ? Pas mal mes Pokémon, hein ? Je suis fait pour ça.", - "3": "Peu importe à quel point t’aimes tes Pokémon, il faut toujours de la discipline s’ils se comportent mal." - } - }, - "breeder_female": { - "encounter": { - "1": "Les Pokémon ne trahissent jamais. Ils te rendront toujours l’amour que tu leur donne.", - "2": "Puis-je te donner une astuce pour mieux élever tes Pokémon ?", - "3": "J’ai élevé mes Pokémon en utilisant une méthode très spéciale." - }, - "victory": { - "1": "Arg… C’était pas supposé se passer comme ça. Leur ai-je administré la mauvaise préparation ?", - "2": "Comment ça a pu arriver…\nAvec quoi nourris-tu tes Pokémon ?", - "3": "Si je perds, c’est juste pour te dire que je tuais le temps. Mon ego n’est absolument pas touché…" - }, - "defeat": { - "1": "C’est la preuve que mes Pokémon reconnaissent tout mon amour.", - "2": "Le seul secret derrière des Pokémon bien entrainés, c’est surtout d’en capturer des bons.", - "3": "La force des Pokémon dépend de ta capacité à savoir les élever correctement." - } - }, - "fisherman": { - "encounter": { - "1": "Aaah non ! J’avais une touche !\nTu comptes faire quoi pour arranger ça ?", - "2": "Bouge de là ! Tu fais peur aux Pokémon !", - "3": "Voyons si t’arrives à ferrer une victoire !" - }, - "victory": { - "1": "Vas-y là, oublie.", - "2": "La prochaine fois, je vais me repêcher !", - "3": "Je présume que j’ai sous-estimé les courants…" - } - }, - "fisherman_female": { - "encounter": { - "1": "Oh la belle prise !", - "2": "Ma ligne est en place, prête à ferrer le succès !", - "3": "Prête à faire des vagues !" - }, - "victory": { - "1": "Je suppose que je vais avoir besoin d’un plus gros hameçon.", - "2": "La ligne s’est brisée, j’ai pas pu la ferrer…", - "3": "Attends que j’aiguise mes hameçons pour la revanche !" - } - }, - "swimmer": { - "encounter": { - "1": "C’est l’heure de plonger dans le vif !", - "2": "C’est le moment de surfer sur les vagues de la victoire !", - "3": "Je vais t’éclabousser de mon talent !" - }, - "victory": { - "1": "Tu m’as complètement séché", - "2": "Il semblerait que ce soit celles de la défaite…", - "3": "Retour sur la terre ferme je suppose" - } - }, - "backpacker": { - "encounter": { - "1": "Fais ton sac, on y va !", - "2": "Voyons si t’arrives à garder le rythme !", - "3": "Accélère le pas, camarade !", - "4": "J’ai passé 20 ans à la recherche de moi-même…\nMais où suis-je ?" - }, - "victory": { - "1": "J’ai trébuché !", - "2": "Ah, je crois que je me suis paumé.", - "3": "Ah, une impasse !", - "4": "Hé ! Attends une seconde…\nTu saurais pas qui je suis ?" - } - }, - "ace_trainer": { - "encounter": { - "1": "T’as l’air plutôt confiant.", - "1_female": "T’as l’air plutôt confiante.", - "2": "Tes Pokémon… Montre-les-moi…", - "3": "Les gens pensent que je suis fort par que je suis un Topdresseur.", - "4": "T’es au courant de ce que ça signifie d’être un Topdresseur ?" - }, - "victory": { - "1": "Très bien… T’as de bons Pokémon…", - "2": "Quoi ?! Mais c’est moi le génie des combats !", - "3": "Évidemment que t’es le personnage principal !", - "4": "OK ! OK ! Tu pourrais être un Topdresseur !", - "4_female": "OK ! OK ! Tu pourrais être une Topdresseuse !" - }, - "defeat": { - "1": "Je me dévoue corps et âme aux combats Pokémon !", - "2": "Comme prévu… Vraiment aucune surprise…", - "3": "Et moi qui pensais qu’en grandissant, j’allais rester frêle et fragile, à me briser à la moindre étreinte.", - "4": "Évidemment que je suis fort et encore moins un perdant. C’est important de gagner avec grâce." - } - }, - "parasol_lady": { - "encounter": { - "1": "Honorons ce terrain de combat avec élégance et équilibre !" - }, - "victory": { - "1": "Mon élégance demeure inébranlable !" - } - }, - "rocket_grunt": { - "encounter": { - "1": "Nous sommes de retour !", - "2": "Ça bosse dur, ici ! Alors du balai !", - "3": "File-nous tes Pokémon ou tu vas gouter à la colère de la Team Rocket !", - "4": "Sois témoin de ce qu’est une vraie terreur de la Team Rocket!", - "5": "Hé gamin ! Moi être guy member of la Team Rocket !", - "5_female": "Hé gamine ! Moi être guy member of la Team Rocket !" - }, - "victory": { - "1": "Une fois de plus la Team Rocket s’envole vers d’autres cieux !", - "2": "Mince! J’ai laissé tomber\nla Clé Ascenseur !", - "3": "J’ai tout foiré !", - "4": "Mes compagnons vont me venger !", - "5": "Toi dire quoi ? Forget que tu m’as vu !\nYou n’as rien seen !" - } - }, - "magma_grunt": { - "encounter": { - "1": "N’espère pas recevoir de la pitié si tu te mets sur le chemin de la Team Magma !", - "2": "Ne te mêle pas de nos affaires ! On va rendre ce monde meilleur !", - "3": "Hors de mon chemin ! La Team Magma n’a pas de temps pour les gamins !", - "4": "J’espère que t’as quelques marshmallows, car ça va chauffer !", - "5": "On va utiliser le puissance d’un volcan ! Ça va être… explosif ! Tu l’as… ? Héhé !" - }, - "victory": { - "1": "Je…?\nJ’ai perdu ?!", - "2": "Je peux pas croire que j’ai pas pris mon déjeuner juste pour ça…", - "3": "Impossible ! T’es qu’un gosse !", - "3_female": "Impossible ! T’es qu’une gosse !", - "4": "Aahhh…\nJ’aurais dû directement rentrer à la planque…", - "5": "Tu m’as démoli… Tu crois que le boss va suspendre mon salaire ?" - } - }, - "aqua_grunt": { - "encounter": { - "1": "Aucune pitié si tu te mets sur le chemin de la Team Aqua, même pour un gamin !", - "2": "Grrr…\nTu as eu le culot de t’opposer à la Team Aqua !", - "3": "Je vais te liquéfier !\nEt ce sera pas qu’à cause des mes Pokémon Eau !", - "4": "Nous, la Team Aqua, existons pour le bien commun !", - "5": "Prépare-toi à te faire emporter par le courant de…\nEuh… Mes Pokémon ! Oui, mes Pokémon !" - }, - "victory": { - "1": "Comment ça ?", - "2": "Ah, j’avais pas prévu d’être gêné par un mouflet qui se mêle de tout !", - "3": "J’ai perdu ?! Super, j’ai plus qu’à nager jusqu’à la planque maintenant…", - "4": "Oh non quelle angoisse…\nLe boss va me démonter…", - "5": "Je suis battu… Tu penses que le boss va me faire subir le supplice de la planche ?…" - } - }, - "galactic_grunt": { - "encounter": { - "1": "Ne te mets pas en travers de la Team Galaxie !", - "2": "Sois témoin de la puissance de notre technologie et du futur qui se profile !", - "3": "Au nom de la Team Galaxie, j’éliminerai quiconque se mettra sur notre route !", - "4": "Prépare ta défaite !", - "5": "J’espère que t’es prêt à te prendre une raclée de l’espace !", - "5_female": "J’espère que t’es prête à te prendre une raclée de l’espace !" - }, - "victory": { - "1": "Désactivation…", - "2": "Cet échec n’est qu’une poussière face à nos ambitions débordantes.", - "3": "Notre projet est bien plus important que cette défaite.", - "4": "Comment ?!", - "5": "Note à moi-même :\nM’entrainer aux combats Pokémon. Ça urge…" - } - }, - "plasma_grunt": { - "encounter": { - "1": "Pas de quartiers à quiconque ne suit pas notre idéal !", - "2": "Si je gagne, tu relâches tous tes Pokémon !", - "3": "Si tu te mets en travers de la Team Plasma, je m’occuperai de toi personnellement !", - "4": "La Team Plasma va libérer les Pokémon de tous les humains égoïstes dans ton genre !", - "5": "Nos coupes sont lunaires… Mais en combat ?\nTu vas vite le découvrir." - }, - "victory": { - "1": "Plasmaaaaaaaaa !", - "2": "Comment ai-je pu perdre…", - "3": "… Ce Pokémon est nul, j’vais aller en voler de meilleurs !", - "4": "Les plans ambitieux connaissent toujours leurs lots d’interruptions.", - "5": "C’est mauvais… MAUVAIS MAUVAIS MAUVAIS MAUVAIS !\nVa falloir battre en retraite, c’est la méga cata !" - } - }, - "flare_grunt": { - "encounter": { - "1": "Tes Pokémon ne sont pas dignes de l’élégance de la Team Flare.", - "2": "T’as des lunettes de soleil j’espère ?\nCar prépare-toi à être ébloui !", - "2_female": "T’as des lunettes de soleil j’espère ?\nCar prépare-toi à être éblouie !", - "3": "La Team Flare va purifier ce monde de toute imperfection !", - "4": "Prépare-toi à découvrir l’indiscutable sens du style de la Team Flare !", - "5": "La mode, c’est important !" - }, - "victory": { - "1": "Mon futur n’a pas l’air si radieux.", - "2": "Les combats semblent être plus complexes que je le pensais.\nRetour aux planches à dessin.", - "3": "Ehhhh ?! J’ai perdu ?!", - "4": "Même dans la défaite, l’élégance de la Team Flare continue de rayonner sur ce monde.", - "5": "J’appelle pas ça perdre, j’appelle ça échouer avec panache !" - } - }, - "aether_grunt": { - "encounter": { - "1": "Je vais te mettre ta raclée !", - "2": "J’en ai rien à faire que tu sois une gosse. Tu vas tutoyer les étoiles si tu nous menaces !", - "2_female": "J’en ai rien à faire que tu sois une gosse. Tu vas tutoyer les étoiles si tu nous menaces !", - "3": "J’ai pour ordre de ne laisser passer aucun Dresseur, peu importe qui c’est !", - "4": "Je vais te montrer le pouvoir du Paradis Æther !", - "5": "Maintenant que t’es au courant de ce qu’il se passe au cœur du Paradis Æther, fais-moi une faveur et disparait !" - }, - "victory": { - "1": "C’est plutôt toi qui devrait m’apprendre à en mettre…", - "2": "Pardon ? J’ai pas compris…", - "3": "Peu importe les ordres, jamais j’aurais pu te retenir en fait…", - "4": "Mhh… Il semblerait que j’ai perdu.", - "5": "C’est plutôt moi qui va disparaitre je crois." - } - }, - "faba": { - "encounter": { - "1": "Moi, Directeur Saubohne, je vais te montrer de quel bois je me chauffe !", - "2": "Donc là, l’homme supposé être la dernière ligne défense du Paradis Æther doit affronter un mioche ?", - "2_female": "Donc là, l’homme supposé être la dernière ligne défense du Paradis Æther doit affronter un mioche ?", - "3": "S’il n’y a qu’un seul nom à retenir au sein de la Fondation Æther, c’est le mien : Saubohne !" - }, - "victory": { - "1": "Gloups !", - "2": "Malheur ! J’ai perdu face à un simple enfant ?!", - "2_female": "Malheur ! J’ai perdu face à une simple enfant ?!", - "3": "J’ai HORREUR des enfants !" - } - }, - "skull_grunt": { - "encounter": { - "1": "Oush oush ! On est pas méchants, sauf si tu viens nous allumer la mèche-han !", - "2": "Ce manque de respect, j’hallucine ! T’es allé trop loin, le mioche !", - "2_female": "Ce manque de respect, j’hallucine ! T’es allée trop loin, la mioche !", - "3": "On est juste des gars et des meufs normaux, on voit un Pokémon on le prend !", - "4": "Pourquoi tu te la joue comme ça ? C'est avec tes dents que t’vas jouer frérot.", - "4_female": "Pourquoi tu te la joue comme ça ? C'est avec tes dents que t’vas jouer ma reus.", - "5": "Cousin, écoute-nous bien ! ♪\nSe taper dessus, ça sert à rien ! ♪\n$Tu t’incrustes chez nous, ça s’fait pas ! ♪\nMais on est sympa, on a un plan pour toi ! ♪", - "5_female": "Cousine, écoute-nous bien ! ♪\nSe taper dessus, ça sert à rien ! ♪\n$Tu t’incrustes chez nous, ça s’fait pas ! ♪\nMais on est sympa, on a un plan pour toi ! ♪" - }, - "victory": { - "1": "Hein ? C’est déjà terminé ?", - "2": "… Ça craint grave ! On s’tire !", - "3": "Ouais de toute on en avait pas b’soin de ton Pokémon… Ah ah…", - "4": "Ouh là, c’est bon, j’en demandais pas tant…", - "5": "On pèse plus que des Pokémon, t’entends ?\nAlors tu vas nous respecter, oush !" - } - }, - "plumeria": { - "encounter": { - "1": "Tsk. T’es un gamin tout ce qu’il y a de plus banal, en fait.", - "1_female": "Tsk. T’es une gamine tout ce qu’il y a de plus banal, en fait.", - "2": "Abrutis de sbires. Trop incompétents pour arriver à se débarasser de gamins…", - "3": "Si tu touches encore à un cheveu de mes lascars, tu vas pas comprendre c’qui t’arrive !" - }, - "victory": { - "1": "Tsk. T’es pas mauvais. J’te l’accorde.", - "1_female": "Tsk. T’es pas mauvaise. J’te l’accorde.", - "2": "Tsk. J’dois reconnaitre que t’en as dans le ventre.\n$Maintenant, j’comprends pourquoi mes gars n’arrêtent pas de se faire battre par toi.", - "3": "Tsk. J’crois que j'ai plus qu’à assumer ma défaite." - } - }, - "macro_grunt": { - "encounter": { - "1": "Hop hop hop ! Terminus !", - "2": "T’es un Dresseur n’est-ce pas ?\n$J’ai bien peur ce que ne soit pas une excuse suffisante pour nous interrompre dans notre travail.", - "2_female": "T’es une Dresseuse n’est-ce pas ?\n$J’ai bien peur ce que ne soit pas une excuse suffisante pour nous interrompre dans notre travail.", - "3": "Je travaille à Macro Cosmos Assurances !\nBesoin d’une assurance-vie ?" - }, - "victory": { - "1": "Je n’ai d’autre choix que respectueusement me retirer.", - "2": "Mon argent de poche…\nPlus qu’à manger des pâtes pour la fin du mois…", - "3": "Chez Macro Cosmos, rien n’est comparable à notre dévotion au travail !" - } - }, - "oleana": { - "encounter": { - "1": "Je ne laisserai personne interférer avec les projets du président Shehroz.", - "2": "Je vois que vous avez su vous défaire de mes subalternes.\n$Mais assez joué. Il est temps de rentrer chez vous, maintenant.", - "3": "Je gagnerai en votre nom, monsieur le président." - }, - "victory": { - "1": "*soupir* Comment ai-je fait pour perdre ainsi… ?\nJe ne suis vraiment pas à la hauteur…", - "2": "Ah ! Quelle erreur… Je n’aurais pas dû sous-estimer un Dresseur de ton calibre…", - "2_female": "Ah ! Quelle erreur… Je n’aurais pas dû sous-estimer une Dresseuse de ton calibre…", - "3": "*soupir* Je suis fatiguée parton…" - } - }, - "rocket_boss_giovanni_1": { - "encounter": { - "1": "Bien. Je dois admettre que je suis impressionné de te voir ici !" - }, - "victory": { - "1": "QUOI ? IMPOSSIBLE !" - }, - "defeat": { - "1": "Retiens bien. Ton incapacité à évaluer ta propre force est\nla démonstration claire que tu n’es encore qu’un gamin.", - "1_female": "Retiens bien. Ton incapacité à évaluer ta propre force est\nla démonstration claire que tu n’es encore qu’une gamine." - } - }, - "rocket_boss_giovanni_2": { - "encounter": { - "1": "Mes anciens collaborateurs m’attendent.\nComptes-tu m’en empêcher ?" - }, - "victory": { - "1": "Comment c’est possible… ? Le grand dessein de la Team Rocket n’est plus qu’une illusion…" - }, - "defeat": { - "1": "La Team Rocket renaitra, et je dominerai le monde !" - } - }, - "magma_boss_maxie_1": { - "encounter": { - "1": "Je vais t’enterrer de mes propres mains.\nJ’espère que t’apprécieras cet honneur !" - }, - "victory": { - "1": "Gnn… ! Tu… T’as du répondant…\nCe sentiment d’être à la traine, de si peu…" - }, - "defeat": { - "1": "La Team Magma vaincra !" - } - }, - "magma_boss_maxie_2": { - "encounter": { - "1": "T’es le dernier rempart entravant mes objectifs. Prépare-toi à mon ultime riposte ! Hahahaha !" - }, - "victory": { - "1": "Ce… Ce n’est pas… Gnn…" - }, - "defeat": { - "1": "L’heure est venue…\nJe vais transformer cette planète en paradis pour l’humanité." - } - }, - "aqua_boss_archie_1": { - "encounter": { - "1": "Je suis le Leader de la Team Aqua.\nJ’ai bien peur que pour toi, ce soit fin de parcours." - }, - "victory": { - "1": "Retrouvons-nous.\nJe me souviendrai de ton visage." - }, - "defeat": { - "1": "Magnifique !\nPlus rien ne peut nous retenir !" - } - }, - "aqua_boss_archie_2": { - "encounter": { - "1": "J’ai attendu ce moment depuis si longtemps.\nVoici la vraie puissance de la Team Aqua !" - }, - "victory": { - "1": "Comme si j’y avait cru…" - }, - "defeat": { - "1": "Je rendrai à ce monde sa pureté originelle !" - } - }, - "galactic_boss_cyrus_1": { - "encounter": { - "1": "Tu t’es senti obligé de venir ici dans un acte vide de sens. Je vais te le faire regretter.", - "1_female": "Tu t’es sentie obligée de venir ici dans un acte vide de sens. Je vais te le faire regretter." - }, - "victory": { - "1": "Intéressant. Et plutôt curieux." - }, - "defeat": { - "1": "Je le créerai, mon nouveau monde…" - } - }, - "galactic_boss_cyrus_2": { - "encounter": { - "1": "Nous y revoilà. Il semblerait que nos destinées soient entremêlées. Il est l’heure d’y mettre un terme." - }, - "victory": { - "1": "Comment. Comment ?\nCOMMENT ?!" - }, - "defeat": { - "1": "Adieu." - } - }, - "plasma_boss_ghetsis_1": { - "encounter": { - "1": "Je n’accepterai pas qu’on me barre la route !\nPeu importe qui fait quoi !" - }, - "victory": { - "1": "Comment ? Je suis le leader de la Team Plasma !\nJe suis parfait !" - }, - "defeat": { - "1": "Je suis le parfait monarque d’un monde parfait !\nHahaha !" - } - }, - "plasma_boss_ghetsis_2": { - "encounter": { - "1": "Viens ! Je veux voir ton visage à l’instant même où l’espoir quittera ton corps !" - }, - "victory": { - "1": "Mes calculs… Non ! Mes plans étaient parfaits !\nCe monde devrait être mien !" - }, - "defeat": { - "1": "Kyurem ! Fusiorption !!!" - } - }, - "flare_boss_lysandre_1": { - "encounter": { - "1": "Comptes-tu m’arrêter ? Prouve-le." - }, - "victory": { - "1": "T’es venu m’arrêter. Mais je te demande d’attendre." - }, - "defeat": { - "1": "Les Pokémon… Ne devraient plus exister." - } - }, - "flare_boss_lysandre_2": { - "encounter": { - "1": "Ton futur ou le mien…\nVoyons lequel mérite plus d’aboutir." - }, - "victory": { - "1": "Ohhhh… !" - }, - "defeat": { - "1": "Les ignorants sans aucune vision n’auront donc de cesse de souiller ce monde." - } - }, - "brock": { - "encounter": { - "1": "Mon expertise des types Roche va te mettre au sol ! En garde !", - "2": "Tu veux toujours te battre avec moi ? Même en sachant que tu vas perdre ?", - "3": "Laisse-moi de montrer la véritable force de mes Pokémon Roche !" - }, - "victory": { - "1": "J’étais trop sûr de moi, c’est pour ça que j’ai perdu.", - "2": "Ce monde est vaste ! Je suis honoré d’avoir pu t’affronter.", - "3": "Peut-être bien que je n’aurais pas dû abandonner ma vocation d’Éleveur…" - }, - "defeat": { - "1": "La défense est la meilleure des attaques !\nTelle est ma méthode !", - "2": "Viens étudier des roches avec moi la prochaine fois si tu veux apprendre à mieux les aborder !", - "3": "Tout ce temps à voyager autour du monde paie enfin !" - } - }, - "misty": { - "encounter": { - "1": "Ma tactique ? Attaquer avec des Pokémon Eau !", - "2": "Je vais te prouver le tsunami que sont mes Pokémon aquatiques !", - "3": "Mon rêve, c’était de voyager et de défier des Dresseurs super forts. Seras-tu à la hauteur ?" - }, - "victory": { - "1": "OK. T’es pas naze… Je le reconnais…", - "2": "Pfff… T’as juste eu de la chance hein ?!", - "3": "Ouah ! T’es super balèze !" - }, - "defeat": { - "1": "Qu’en dis-tu ? C’est ça, la puissance des Pokémon Eau !", - "2": "J’espère que t’as pris note des élégantes techniques de nage de mes Pokémon !", - "3": "Tes Pokémon ne jouent visiblement pas dans le même bassin…" - } - }, - "lt_surge": { - "encounter": { - "1": "T’as pas froid aux yeux, soldat ! Les combats Pokémon, c’est la guerre !", - "2": "Tu as du guts pour venir me fight ici ! Je vais te shock !", - "3": "Compte tes dents, tu vas morfler !\nMes Pokémon Électrik vont t’atomiser !" - }, - "victory": { - "1": "Whoo ! T’iras loin toi.", - "2": "Oh noes ! Mes tricks électriques sont à plat…\nYou are very fortiche!", - "3": "Tu es very costaud ! Je vais training very dur mes Pokémon, moi too, et on sera Number One !" - }, - "defeat": { - "1": "Oh yeah !\nMes Pokémon Électrik sont les best du monde !", - "2": "Oh yeah, baby ! I am trop fort !", - "3": "Une combat Pokémon, c’est comme une guerre et t’as eu droit à une bataille de premier ordre !" - } - }, - "erika": { - "encounter": { - "1": "Il fait beau, aujourd’hui, n’est-ce pas… ?\nQuoi un combat… ? Très bien…", - "2": "L’arrangement floral est ma spécialité, et mes Pokémon sont de type Plante. Quoi ? Tu veux te battre ?", - "3": "Il fait beau… Le soleil brille… Les plantes bourgeonnent… Je m’ennuie…", - "4": "Voir un tel jardin rempli de fleurs est si apaisant…" - }, - "victory": { - "1": "Bien joué, c’est mérité.", - "2": "Dommage, on s’amusait si bien…", - "3": "Oh non, le combat est terminé…", - "4": "Aaah, ça fait du bien !\nMerci, j’en avais besoin." - }, - "defeat": { - "1": "J’ai failli m’endormir…", - "2": "Oh non… Mes Pokémon Plante ont l’air de t’avoir bien endormi…", - "2_female": "Oh non… Mes Pokémon Plante ont l’air de t’avoir bien endormie…", - "3": "Ce combat était si apaisant…", - "4": "Oh non… C’est tout ?" - } - }, - "alder": { - "encounter": { - "1": "Prépare-toi pour un combat contre le meilleur Dresseur d’Unys !" - }, - "victory": { - "1": "Bien joué ! Tu as sans aucun doute un talent inégalé." - }, - "defeat": { - "1": "Une brise fraiche traverse mon cœur…\n$Quel effort extraordinaire !" - } - }, - "kieran": { - "encounter": { - "1": "Grâce à un travail acharné, je deviens de plus en plus fort !\n$Je ne perdrai pas." - }, - "victory": { - "1": "Je n’y crois pas…\n$Quel combat amusant et palpitant !" - }, - "defeat": { - "1": "Eh beh, quel combat !\n$Il est temps pour toi de t’entrainer encore plus dur." - } - }, - "rival": { - "encounter": { - "1": "@c{smile}Ah, je te cherchais ! Je savais que t’étais pressée de partir, mais je m’attendais quand même à un au revoir…\n$@c{smile_eclosed}T’as finalement décidé de réaliser ton rêve ?\nJ’ai peine à y croire.\n$@c{serious_smile_fists}Vu que t’es là, ça te dis un petit combat ?\nJe voudrais quand même m’assurer que t’es prête.\n$@c{serious_mopen_fists}Surtout ne te retiens pas et donne-moi tout ce que t’as !" - }, - "victory": { - "1": "@c{shock}Wah… Tu m’as vraiment lavé.\nT’es vraiment une débutante ?\n$@c{smile}T’as peut-être eu de la chance, mais…\nPeut-être que t’arriveras jusqu’au bout du chemin.\n$D’ailleurs, le prof m’a demandé de te filer ces objets.\nIls ont l’air sympas.\n$@c{serious_smile_fists}Bonne chance à toi !" - } - }, - "rival_female": { - "encounter": { - "1": "@c{smile_wave}Ah, te voilà ! Je t’ai cherché partout !\n@c{angry_mopen}On oublie de dire au revoir à sa meilleure amie ?\n$@c{smile_ehalf}T’as décidé de réaliser ton rêve, hein ?\nCe jour est donc vraiment arrivé…\n$@c{smile}Je veux bien te pardonner de m’avoir oubliée,\nà une condition. @c{smile_wave_wink}Que tu m’affronte !\n$@c{angry_mopen}Donne tout ! Ce serait dommage que ton aventure finisse avant d’avoir commencé, hein ?" - }, - "victory": { - "1": "@c{shock}Tu viens de commencer et t’es déjà si fort ?!@d{96}\n@c{angry}T’as triché non ? Avoue !\n$@c{smile_wave_wink}J’déconne !@d{64} @c{smile_eclosed}J’ai perdu dans les règles…\nJ’ai le sentiment que tu vas très bien t’en sortir.\n$@c{smile}D’ailleurs, le prof veut que je te donne ces quelques objets. Ils te seront utiles, pour sûr !\n$@c{smile_wave}Fais de ton mieux, comme toujours !\nJe crois fort en toi !" - } - }, - "rival_2": { - "encounter": { - "1": "@c{smile}Hé, toi aussi t’es là ?\n@c{smile_eclosed}Toujours invaincue, hein… ?\n$@c{serious_mopen_fists}Je sais que j’ai l’air de t’avoir suivie ici, mais c’est pas complètement vrai.\n$@c{serious_smile_fists}Pour être honnête, ça me démangeait d’avoir une revanche depuis que tu m’as battu.\n$Je me suis beaucoup entrainé, alors sois sure que je vais pas retenir mes coups cette fois.\n$@c{serious_mopen_fists}Et comme la dernière fois, ne te retiens pas !\nC’est parti !" - }, - "victory": { - "1": "@c{neutral_eclosed}Oh. Je crois que j’ai trop pris la confiance.\n$@c{smile}Pas grave, c’est OK. Je me doutais que ça arriverait.\n@c{serious_mopen_fists}Je vais juste devoir encore plus m’entrainer !\n\n$@c{smile}Ah, et pas que t’aies réellement besoin d’aide, mais j’ai ça en trop sur moi qui pourrait t’intéresser.\n\n$@c{serious_smile_fists}Mais n’espère plus en avoir d’autres !\nJe peux pas passer mon temps à aider mon adversaire.\n$@c{smile}Bref, prends soin de toi !" - } - }, - "rival_2_female": { - "encounter": { - "1": "@c{smile_wave}Hé, sympa de te croiser ici. T’as toujours l’air invaincu. @c{angry_mopen}Eh… Pas mal !\n$@c{angry_mopen}Je sais à quoi tu penses et non, je t’espionne pas.\n@c{smile_eclosed}C’est juste que j’étais aussi dans le coin.\n$@c{smile_ehalf}Heureuse pour toi, mais je veux juste te rappeler que c’est pas grave de perdre parfois.\n$@c{smile}On apprend de nos erreurs, souvent plus que si on ne connaissait que le succès.\n$@c{angry_mopen}Dans tous les cas je me suis bien entrainée pour cette revanche, t’as intérêt à tout donner !" - }, - "victory": { - "1": "@c{neutral}Je… J’étais pas encore supposée perdre…\n$@c{smile}Bon. Ça veut juste dire que je vais devoir encore plus m’entrainer !\n$@c{smile_wave}J’ai aussi ça en rab pour toi !\n@c{smile_wave_wink}Inutile de me remercier ~.\n$@c{angry_mopen}C’étaient les derniers, terminé les cadeaux après ceux-là !\n$@c{smile_wave}Allez, tiens le coup !" - }, - "defeat": { - "1": "Je suppose que c’est parfois normal de perdre…" - } - }, - "rival_3": { - "encounter": { - "1": "@c{smile}Hé, mais qui voilà ! Ça fait un bail.\n@c{neutral}T’es… toujours invaincue ? Incroyable.\n$@c{neutral_eclosed}Tout est devenu un peu… étrange.\nC’est plus pareil sans toi au village.\n$@c{serious}Je sais que c’est égoïste, mais j’ai besoin d’expier ça.\n@c{neutral_eclosed}Je crois que tout ça te dépasse.\n$@c{serious}Ne jamais perdre, c’est juste irréaliste.\nGrandir, c’est parfois aussi savoir perdre.\n$@c{neutral_eclosed}T’as un beau parcours, mais il y a encore tellement à venir et ça va pas s’arranger. @c{neutral}T’es prête pour ça ?\n$@c{serious_mopen_fists}Si tu l’es, alors prouve-le." - }, - "victory": { - "1": "@c{angry_mhalf}C’est lunaire… J’ai presque fait que m’entrainer…\nAlors pourquoi il y a encore un tel écart entre nous ?" - } - }, - "rival_3_female": { - "encounter": { - "1": "@c{smile_wave}Ça fait une éternité ! Toujours debout hein ?\n@c{angry}Tu commences à me pousser à bout là. @c{smile_wave_wink}T’inquiètes j’déconne !\n$@c{smile_ehalf}Mais en vrai, ta maison te manque pas ? Ou… Moi ?\nJ… Je veux dire… Tu me manques vraiment beaucoup.\n$@c{smile_eclosed}Je te soutiendrai toujours dans tes ambitions, mais la vérité est que tu finiras par perdre un jour ou l’autre.\n$@c{smile}Quand ça arrivera, je serai là pour toi, comme toujours.\n@c{angry_mopen}Maintenant, montre-moi à quel point t’es devenu fort !" - }, - "victory": { - "1": "@c{shock}Après tout ça… Ça te suffit toujours pas… ?\nTu reviendras jamais à ce rythme…" - }, - "defeat": { - "1": "T’as fait de ton mieux.\nAllez, rentrons à la maison." - } - }, - "rival_4": { - "encounter": { - "1": "@c{neutral}Hé.\n$Je vais pas y aller par quatre chemins avec toi.\n@c{neutral_eclosed}Je suis là pour gagner. Simple, basique.\n$@c{serious_mhalf_fists}J’ai appris à maximiser tout mon potentiel en m’entrainant d’arrachepied.\n$@c{smile}C’est fou tout le temps que tu peux te dégager si tu dors pas en sacrifiant ta vie sociale.\n$@c{serious_mopen_fists}Plus rien n’a d’importance désormais, pas tant que j’aurai pas gagné.\n$@c{neutral_eclosed}J’ai atteint un stade où je ne peux plus perdre.\n@c{smile_eclosed}Je présume que ta philosophie était pas si fausse finalement.\n$@c{angry_mhalf}La défaite, c’est pour les faibles, et je ne suis plus un faible.\n$@c{serious_mopen_fists}Tiens-toi prête." - }, - "victory": { - "1": "@c{neutral}Que…@d{64} Qui es-tu ?" - } - }, - "rival_4_female": { - "encounter": { - "1": "@c{neutral}C’est moi ! Tu m’as pas encore oubliée… n’est-ce pas ?\n$@c{smile}Tu devrais être fier d’être arrivé aussi loin. GG !\nMais c’est certainement pas la fin de ton aventure.\n$@c{smile_eclosed}T’as éveillé en moi quelque chose que j’ignorais.\nTout mon temps passe dans l’entrainement.\n$@c{smile_ehalf}Je dors et je mange à peine, je m’entraine juste tous les jours, et deviens de plus en plus forte.\n$@c{neutral}En vrai, Je… J’ai de la peine à me reconnaitre.\n$Mais maintenant, je suis au top de mes capacités.\nJe doute que tu sois de nouveau capable de me battre.\n$Et tu sais quoi ? Tout ça, c’est de ta faute.\n@c{smile_ehalf}Et j’ignore si je dois te remercier ou te haïr.\n$@c{angry_mopen}Tiens-toi prêt." - }, - "victory": { - "1": "@c{neutral}Que…@d{64} Qui es-tu ?" - }, - "defeat": { - "1": "$@c{smile}Tu devrais être fier d’être arrivé jusque là." - } - }, - "rival_5": { - "encounter": { - "1": "@c{neutral}…" - }, - "victory": { - "1": "@c{neutral}…" - } - }, - "rival_5_female": { - "encounter": { - "1": "@c{neutral}…" - }, - "victory": { - "1": "@c{neutral}…" - }, - "defeat": { - "1": "$@c{smile_ehalf}…" - } - }, - "rival_6": { - "encounter": { - "1": "@c{smile_eclosed}Nous y revoilà.\n$@c{neutral}J’ai eu du temps pour réfléchir à tout ça.\nIl y a une raison à pourquoi tout semble étrange.\n$@c{neutral_eclosed}Ton rêve, ma volonté de te battre…\nFont partie de quelque chose de plus grand.\n$@c{serious}C’est même pas à propos de moi, ni de toi… Mais du monde, @c{serious_mhalf_fists}et te repousser dans tes limites est ma mission.\n$@c{neutral_eclosed}J’ignore si je serai capable de l’accomplir, mais je ferai tout ce qui est en mon pouvoir.\n$@c{neutral}Cet endroit est terrifiant… Et pourtant il m’a l’air familier, comme si j’y avais déjà mis les pieds.\n$@c{serious_mhalf_fists}Tu ressens la même chose, pas vrai ?\n$@c{serious}… et c’est comme si quelque chose ici me parlait.\n$Comme si c’était tout ce que ce monde avait toujours connu.\n$Ces précieux moments ensemble qui semblent si proches ne sont rien de plus qu’un lointain souvenir.\n$@c{neutral_eclosed}D’ailleurs, qui peut dire aujourd’hui qu’ils ont pu être réels ?\n$@c{serious_mopen_fists}Il faut que tu persévères. Si tu t’arrêtes, ça n’aura jamais de fin et t’es la seule à en être capable.\n$@c{serious_smile_fists}Difficile de comprendre le sens de tout ça, je sais juste que c’est la réalité.\n$@c{serious_mopen_fists}Si tu ne parviens pas à me battre ici et maintenant, tu n’as aucune chance." - }, - "victory": { - "1": "@c{smile_eclosed}J’ai fait ce que j’avais à faire.\n$Promets-moi juste une chose.\n@c{smile}Après avoir réparé ce monde… Rentre à la maison." - } - }, - "rival_6_female": { - "encounter": { - "1": "@c{smile_ehalf}C’est donc encore entre toi et moi.\n$@c{smile_eclosed}Tu sais, j’ai beau retouner ça dans tous les sens…\n$@c{smile_ehalf}Quelque chose peut expliquer tout ça, pourquoi tout semble si étrange…\n$@c{smile}T’as tes rêves, j’ai mes ambitions…\n$J’ai juste le sentiment qu’il y a un grand dessein derrière tout ça, derrière ce qu’on fait toi et moi.\n$@c{smile_eclosed}Je crois que mon but est de… repousser tes limites.\n$@c{smile_ehalf}Je suis pas certaine de bien être douée à cet exercice, mais je fais de mon mieux.\n$Cet endroit épouvantable cache quelque chose d’étrange… Tout semble si limpide…\n$Comme… si c’était tout ce que ce monde avait toujours connu.\n$@c{smile_eclosed}J’ai le sentiment que nos précieux moments ensemble sont devenus si flous.\n$@c{smile_ehalf}Ont-ils au moins été réels ? Tout semble si loin maintenant…\n$@c{angry_mopen}Il faut que tu persévères. Si tu t’arrêtes, ça n’aura jamais de fin et t’es le seul à en être capable.\n$@c{smile_ehalf}Je… j’ignore le sens de tout ça… Mais je sais que c’est la réalité.\n$@c{neutral}Si tu ne parviens pas à me battre ici et maintenant, tu n’as aucune chance." - }, - "victory": { - "1": "@c{smile_ehalf}Je… Je crois que j’ai rempli ma mission…\n$@c{smile_eclosed}Promets-moi… Après avoir réparé ce monde… Reviens à la maison sain et sauf.\n$@c{smile_ehalf}… Merci." - } - } -} diff --git a/src/locales/fr/egg.json b/src/locales/fr/egg.json deleted file mode 100644 index cbc912e9d50..00000000000 --- a/src/locales/fr/egg.json +++ /dev/null @@ -1,26 +0,0 @@ -{ - "egg": "Œuf", - "greatTier": "Rare", - "ultraTier": "Épique", - "masterTier": "Légendaire", - "defaultTier": "Commun", - "hatchWavesMessageSoon": "Il fait du bruit.\nIl va éclore !", - "hatchWavesMessageClose": "Il bouge de temps en temps. Il devrait bientôt éclore.", - "hatchWavesMessageNotClose": "Qu’est-ce qui va en sortir ? Ça va mettre du temps.", - "hatchWavesMessageLongTime": "Cet Œuf va surement mettre du temps à éclore.", - "gachaTypeLegendary": "Taux de Légendaires élevé", - "gachaTypeMove": "Taux de Capacité Œuf Rare élevé", - "gachaTypeShiny": "Taux de Chromatiques élevé", - "selectMachine": "Sélectionnez une machine.", - "notEnoughVouchers": "Vous n’avez pas assez de coupons !", - "tooManyEggs": "Vous avez trop d’Œufs !", - "pull": "Tirage", - "pulls": "Tirages", - "sameSpeciesEgg": "Un {{species}} sortira de cet Œuf !", - "hatchFromTheEgg": "{{pokemonName}} sort de l’Œuf !", - "eggMoveUnlock": "Capacité Œuf débloquée :\n{{moveName}}", - "rareEggMoveUnlock": "Capacité Œuf Rare débloquée :\n{{moveName}}", - "moveUPGacha": "Bonus Capacité\nŒuf Rare !", - "shinyUPGacha": "Bonus\nChromatique !", - "legendaryUPGacha": "Bonus !" -} diff --git a/src/locales/fr/fight-ui-handler.json b/src/locales/fr/fight-ui-handler.json deleted file mode 100644 index bd4e6b52566..00000000000 --- a/src/locales/fr/fight-ui-handler.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "pp": "PP", - "power": "Puissance", - "accuracy": "Précision", - "abilityFlyInText": " {{passive}}{{abilityName}}\nde {{pokemonName}}", - "passive": "Passif ", - "teraHover": "Téracristal {{type}}" -} diff --git a/src/locales/fr/filter-bar.json b/src/locales/fr/filter-bar.json deleted file mode 100644 index 9436933ad6d..00000000000 --- a/src/locales/fr/filter-bar.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "genFilter": "Gen", - "typeFilter": "Type", - "caughtFilter": "Capturés", - "unlocksFilter": "Amélio.", - "miscFilter": "Divers", - "sortFilter": "Tri", - "all": "Tous", - "normal": "Normal", - "uncaught": "Non-capturé", - "passive": "Passif", - "passiveUnlocked": "Passif débloqué", - "passiveLocked": "Passif verrouillé", - "passiveUnlockable": "Passif déblocable", - "costReduction": "Cout réduit", - "costReductionUnlocked": "Cout réduit débloqué", - "costReductionLocked": "Cout réduit verrouillé", - "costReductionUnlockable": "Cout réduit déblocable", - "favorite": "Favoris", - "isFavorite": "Favoris uniquement", - "notFavorite": "Sans Favoris", - "ribbon": "Ruban", - "hasWon": "Ruban - Avec", - "hasNotWon": "Ruban - Sans", - "hiddenAbility": "Talent caché", - "hasHiddenAbility": "Talent caché - Avec", - "noHiddenAbility": "Talent caché - Sans", - "egg": "Œuf", - "eggPurchasable": "Œuf achetable", - "pokerus": "Pokérus", - "hasPokerus": "Pokérus - Avec", - "noPokerus": "Pokérus - Sans", - "sortByNumber": "Par N°", - "sortByCost": "Par cout", - "sortByCandies": "Par bonbons", - "sortByIVs": "Par IV", - "sortByName": "Par nom" -} \ No newline at end of file diff --git a/src/locales/fr/game-mode.json b/src/locales/fr/game-mode.json deleted file mode 100644 index 73a8d9c60f9..00000000000 --- a/src/locales/fr/game-mode.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "classic": "Classique", - "endless": "Infini", - "endlessSpliced": "Infini (Fusions)", - "dailyRun": "Défi du jour", - "unknown": "Inconnu", - "challenge": "Challenge" -} diff --git a/src/locales/fr/game-stats-ui-handler.json b/src/locales/fr/game-stats-ui-handler.json deleted file mode 100644 index 16221ab7e08..00000000000 --- a/src/locales/fr/game-stats-ui-handler.json +++ /dev/null @@ -1,42 +0,0 @@ -{ - "stats": "Statistiques", - "playTime": "Temps de jeu", - "totalBattles": "Total combats", - "shinyStarters": "Starters chroma", - "starters": "Starters", - "speciesSeen": "Espèces vues", - "speciesCaught": "Espèces capt.", - "ribbonsOwned": "Rubans possédés", - "classicRuns": "Parties en Classique", - "classicWins": "Victoires en Classique", - "dailyRunAttempts": "Essais Défi du jour", - "dailyRunWins": "Victoires Défi du jour", - "endlessRuns": "Parties en Infini", - "highestWaveEndless": "Record vagues (Infini)", - "highestMoney": "Record d’argent", - "highestDamage": "Record de dégâts", - "highestHPHealed": "Record PV soignés", - "pokemonEncountered": "Pokémon rencontrés", - "pokemonDefeated": "Pokémon battus", - "pokemonCaught": "Pokémon capturés", - "eggsHatched": "Œufs éclos", - "subLegendsSeen": "Semi-légendaires vus", - "subLegendsCaught": "Semi-légendaires capt.", - "subLegendsHatched": "Semi-légendaires éclos", - "legendsSeen": "Legendaires vus", - "legendsCaught": "Légendaires capt.", - "legendsHatched": "Légendaires éclos", - "mythicalsSeen": "Fabuleux vus", - "mythicalsCaught": "Fabuleux capt.", - "mythicalsHatched": "Fabuleux éclos", - "shiniesSeen": "Chromatiques vus", - "shiniesCaught": "Chromatiques capt.", - "shiniesHatched": "Chromatiques éclos", - "pokemonFused": "Pokémon fusionnés", - "trainersDefeated": "Dresseurs battus", - "eggsPulled": "Œufs obtenus", - "rareEggsPulled": "Œufs Rares", - "epicEggsPulled": "Œufs Épiques", - "legendaryEggsPulled": "Œufs Légendaires", - "manaphyEggsPulled": "Œufs de Manaphy" -} \ No newline at end of file diff --git a/src/locales/fr/growth.json b/src/locales/fr/growth.json deleted file mode 100644 index 4688e625cf7..00000000000 --- a/src/locales/fr/growth.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "Erratic": "Erratique", - "Fast": "Rapide", - "Medium_Fast": "Moyenne-Rapide", - "Medium_Slow": "Moyenne-Lente", - "Slow": "Lente", - "Fluctuating": "Fluctuante" -} \ No newline at end of file diff --git a/src/locales/fr/menu-ui-handler.json b/src/locales/fr/menu-ui-handler.json deleted file mode 100644 index b8627bf91b5..00000000000 --- a/src/locales/fr/menu-ui-handler.json +++ /dev/null @@ -1,30 +0,0 @@ -{ - "GAME_SETTINGS": "Paramètres", - "ACHIEVEMENTS": "Succès", - "STATS": "Statistiques", - "RUN_HISTORY": "Historique", - "EGG_LIST": "Liste des Œufs", - "EGG_GACHA": "Gacha-Œufs", - "MANAGE_DATA": "Mes données", - "COMMUNITY": "Communauté", - "SAVE_AND_QUIT": "Sauver & quitter", - "LOG_OUT": "Déconnexion", - "slot": "Emplacement {{slotNumber}}", - "importSession": "Importer session", - "importSlotSelect": "Sélectionnez l’emplacement vers lequel importer les données.", - "exportSession": "Exporter session", - "exportSlotSelect": "Sélectionnez l’emplacement depuis lequel exporter les données.", - "importData": "Importer données", - "exportData": "Exporter données", - "importRunHistory":"Importer historique", - "exportRunHistory":"Exporter historique", - "consentPreferences": "Gérer les cookies", - "linkDiscord": "Lier à Discord", - "unlinkDiscord": "Délier Discord", - "linkGoogle": "Lier à Google", - "unlinkGoogle": "Délier Google", - "cancel": "Retour", - "losingProgressionWarning": "Vous allez perdre votre progression depuis le début du combat. Continuer ?", - "noEggs": "Vous ne faites actuellement\néclore aucun Œuf !", - "donate": "Faire un don" -} diff --git a/src/locales/fr/menu.json b/src/locales/fr/menu.json deleted file mode 100644 index 35cd06606a7..00000000000 --- a/src/locales/fr/menu.json +++ /dev/null @@ -1,57 +0,0 @@ -{ - "cancel": "Annuler", - "continue": "Continuer", - "dailyRun": "Défi du jour (Bêta)", - "loadGame": "Charger la partie", - "newGame": "Nouvelle partie", - "settings": "Paramètres", - "selectGameMode": "Sélectionnez un mode de jeu.", - "logInOrCreateAccount": "Connectez-vous ou créez un compte pour commencer.\nAucun e-mail requis !", - "username": "Nom d’utilisateur", - "password": "Mot de passe", - "login": "Connexion", - "orUse": "Ou utilisez", - "register": "S’inscrire", - "emptyUsername": "Le nom d’utilisateur est manquant", - "invalidLoginUsername": "Le nom d’utilisateur n’est pas valide", - "invalidRegisterUsername": "Le nom d’utilisateur ne doit contenir que\ndes lettres, chiffres ou traits bas", - "invalidLoginPassword": "Le mot de passe n’est pas valide", - "invalidRegisterPassword": "Le mot de passe doit contenir 6 caractères ou plus", - "usernameAlreadyUsed": "Le nom d’utilisateur est déjà utilisé", - "accountNonExistent": "Le nom d’utilisateur n’existe pas", - "unmatchingPassword": "Le mot de passe est incorrect", - "passwordNotMatchingConfirmPassword": "Les mots de passe ne correspondent pas", - "confirmPassword": "Confirmer le MDP", - "registrationAgeWarning": "En vous inscrivant, vous certifiez que vous avez 13 ans ou plus.", - "backToLogin": "Retour", - "failedToLoadSaveData": "Échec du chargement des données. Veuillez recharger\nla page. Si cela persiste, contactez l’administrateur.", - "sessionSuccess": "Session chargée avec succès.", - "failedToLoadSession": "Vos données de session n’ont pas pu être chargées.\nElles pourraient être corrompues.", - "boyOrGirl": "Es-tu un garçon ou une fille ?", - "evolving": "Quoi ?\n{{pokemonName}} évolue !", - "stoppedEvolving": "Hein ?\n{{pokemonName}} n’évolue plus !", - "pauseEvolutionsQuestion": "Interrompre les évolutions pour {{pokemonName}} ?\nElles peuvent être réactivées depuis l’écran d’équipe.", - "evolutionsPaused": "Les évolutions de {{pokemonName}}\nsont interrompues.", - "evolutionDone": "Félicitations !\n{{pokemonName}} a évolué en {{evolvedPokemonName}} !", - "dailyRankings": "Classement du jour", - "weeklyRankings": "Classement de la semaine", - "noRankings": "Pas de classement", - "positionIcon": "#", - "usernameScoreboard": "Utilisateur", - "score": "Score", - "wave": "Vague", - "loading": "Chargement…", - "loadingAsset": "Chargement des ressources : {{assetName}}", - "playersOnline": "Joueurs connectés", - "yes": "Oui", - "no": "Non", - "disclaimer": "AVERTISSEMENT", - "disclaimerDescription": "Ce jeu n’est pas un produit fini.\nIl peut contenir des problèmes de jouabilité, dont de possibles pertes de sauvegardes,\ndes modifications sans avertissement et pourrait à tout moment cesser d’être mis à jour.", - "choosePokemon": "Sélectionnez un Pokémon.", - "renamePokemon": "Renommer le Pokémon", - "rename": "Renommer", - "nickname": "Surnom", - "errorServerDown": "Oupsi ! Un problème de connexion au serveur est survenu.\n\nVous pouvez garder cette fenêtre ouverte,\nle jeu se reconnectera automatiquement.", - "noSaves": "Vous n’avez aucune sauvegarde enregistrée !", - "tooManySaves": "Vous avez trop de sauvegardes enregistrées !" -} diff --git a/src/locales/fr/modifier-select-ui-handler.json b/src/locales/fr/modifier-select-ui-handler.json deleted file mode 100644 index d1de2d222a8..00000000000 --- a/src/locales/fr/modifier-select-ui-handler.json +++ /dev/null @@ -1,12 +0,0 @@ -{ - "transfer": "Transférer", - "reroll": "Relancer", - "lockRarities": "Bloquer la rareté", - "checkTeam": "Consulter Équipe", - "transferDesc": "Transférer un objet tenu par un Pokémon vers un autre.", - "rerollDesc": "Payer pour relancer les objets gratuits proposés.", - "lockRaritiesDesc": "Assure la relance de proposer des objets gratuits de rareté égale ou supérieure. Affecte le cout de relance.", - "checkTeamDesc": "Consulter votre équipe ou utiliser un objet\nde changement de forme.", - "rerollCost": "{{formattedMoney}} ₽", - "itemCost": "{{formattedMoney}} ₽" -} \ No newline at end of file diff --git a/src/locales/fr/modifier-type.json b/src/locales/fr/modifier-type.json deleted file mode 100644 index 4f8033b50d7..00000000000 --- a/src/locales/fr/modifier-type.json +++ /dev/null @@ -1,446 +0,0 @@ -{ - "ModifierType": { - "AddPokeballModifierType": { - "name": "{{pokeballName}} x{{modifierCount}}", - "description": "Recevez {{modifierCount}} {{pokeballName}}·s. (Inventaire : {{pokeballAmount}})\nTaux de capture : {{catchRate}}" - }, - "AddVoucherModifierType": { - "name": "{{voucherTypeName}} x{{modifierCount}}", - "description": "Recevez {{modifierCount}} {{voucherTypeName}}." - }, - "PokemonHeldItemModifierType": { - "extra": { - "inoperable": "{{pokemonName}} ne peut pas\nporter cet objet !", - "tooMany": "{{pokemonName}} porte trop\nd’exemplaires de cet objet !" - } - }, - "PokemonHpRestoreModifierType": { - "description": "Restaure {{restorePoints}} PV ou {{restorePercent}}% des PV totaux d’un Pokémon, en fonction duquel des deux est le plus élevé.", - "extra": { - "fully": "Restaure tous les PV d’un Pokémon.", - "fullyWithStatus": "Restaure tous les PV d’un Pokémon et soigne tous ses problèmes de statut." - } - }, - "PokemonReviveModifierType": { - "description": "Ranime un Pokémon et restaure {{restorePercent}}% de ses PV." - }, - "PokemonStatusHealModifierType": { - "description": "Soigne tous les problèmes de statut d’un Pokémon." - }, - "PokemonPpRestoreModifierType": { - "description": "Restaure {{restorePoints}} PP à une capacité d’un Pokémon.", - "extra": { - "fully": "Restaure tous les PP à une capacité d’un Pokémon." - } - }, - "PokemonAllMovePpRestoreModifierType": { - "description": "Restaure {{restorePoints}} PP à toutes les capacités d’un Pokémon.", - "extra": { - "fully": "Restaure tous les PP à toutes les capacités d’un Pokémon." - } - }, - "PokemonPpUpModifierType": { - "description": "Augmente le max de PP de {{upPoints}} à une capacité d’un Pokémon pour chaque 5 PP max (max : 3)." - }, - "PokemonNatureChangeModifierType": { - "name": "Aromate {{natureName}}", - "description": "Donne la nature {{natureName}} à un Pokémon et la débloque pour le starter lui étant lié." - }, - "DoubleBattleChanceBoosterModifierType": { - "description": "Quadruple les chances de tomber sur un combat double pendant {{battleCount}} combats." - }, - "TempStatStageBoosterModifierType": { - "description": "Augmente {{amount}} {{stat}} de toute l’équipe pendant 5 combats.", - "extra": { - "stage": "d’un cran", - "percentage": "de 30%" - } - }, - "AttackTypeBoosterModifierType": { - "description": "Augmente de 20% la puissance des capacités de type {{moveType}} d’un Pokémon." - }, - "PokemonLevelIncrementModifierType": { - "description": "Fait monter un Pokémon de {{levels}} niveau·x." - }, - "AllPokemonLevelIncrementModifierType": { - "description": "Fait monter toute l’équipe de {{levels}} niveau·x." - }, - "BaseStatBoosterModifierType": { - "description": "Augmente de 10% {{stat}} de base de son porteur. Plus les IV sont hauts, plus il peut en porter." - }, - "AllPokemonFullHpRestoreModifierType": { - "description": "Restaure tous les PV de toute l’équipe." - }, - "AllPokemonFullReviveModifierType": { - "description": "Ranime et restaure tous les PV de tous les Pokémon K.O. ." - }, - "MoneyRewardModifierType": { - "description": "Octroie une {{moneyMultiplier}} somme d’argent.\n({{moneyAmount}} ₽)", - "extra": { - "small": "petite", - "moderate": "moyenne", - "large": "grande" - } - }, - "ExpBoosterModifierType": { - "description": "Augmente de {{boostPercent}}% le gain de Points d’Exp." - }, - "PokemonExpBoosterModifierType": { - "description": "Augmente de {{boostPercent}}% le gain de Points d’Exp du porteur." - }, - "PokemonFriendshipBoosterModifierType": { - "description": "Augmente le gain de bonheur de 50% par victoire." - }, - "PokemonMoveAccuracyBoosterModifierType": { - "description": "Augmente de {{accuracyAmount}} la précision des capacités (maximum 100)." - }, - "PokemonMultiHitModifierType": { - "description": "Frappe une fois de plus en échange d’une baisse de puissance de respectivement 60/75/82,5% par cumul." - }, - "TmModifierType": { - "name": "CT{{moveId}} - {{moveName}}", - "description": "Apprend la capacité {{moveName}} à un Pokémon." - }, - "TmModifierTypeWithInfo": { - "name": "CT{{moveId}} - {{moveName}}", - "description": "Apprend la capacité {{moveName}} à un Pokémon.\n(Maintenez C ou Maj pour plus d’infos)" - }, - "EvolutionItemModifierType": { - "description": "Permet à certains Pokémon d’évoluer à son contact." - }, - "FormChangeItemModifierType": { - "description": "Permet à certains Pokémon de changer de forme à son contact." - }, - "FusePokemonModifierType": { - "description": "Fusionne deux Pokémon (transfère le talent, sépare les stats de base et les types, partage les capacités)." - }, - "TerastallizeModifierType": { - "name": "Téra-Éclat {{teraType}}", - "description": "Téracristallise son porteur en type {{teraType}} pendant 10 combats." - }, - "ContactHeldItemTransferChanceModifierType": { - "description": "{{chancePercent}}% de chances de voler un objet de l’adversaire en l’attaquant." - }, - "TurnHeldItemTransferModifierType": { - "description": "À chaque tour, son porteur obtient un objet de son adversaire." - }, - "EnemyAttackStatusEffectChanceModifierType": { - "description": "Ajoute {{chancePercent}}% de chances d’infliger le statut {{statusEffect}} avec des capacités offensives." - }, - "EnemyEndureChanceModifierType": { - "description": "Ajoute {{chancePercent}}% de chances d’encaisser un coup." - }, - - "RARE_CANDY": { "name": "Super Bonbon" }, - "RARER_CANDY": { "name": "Hyper Bonbon" }, - - "MEGA_BRACELET": { "name": "Méga-Bracelet", "description": "Débloque les Méga-Gemmes dans la boutique." }, - "DYNAMAX_BAND": { "name": "Poignet Dynamax", "description": "Débloque le Dynamax." }, - "TERA_ORB": { "name": "Orbe Téracristal", "description": "Débloque les Téra-Éclats dans la boutique." }, - - "MAP": { "name": "Carte", "description": "Vous permet de choisir votre destination à un croisement." }, - - "POTION": { "name": "Potion" }, - "SUPER_POTION": { "name": "Super Potion" }, - "HYPER_POTION": { "name": "Hyper Potion" }, - "MAX_POTION": { "name": "Potion Max" }, - "FULL_RESTORE": { "name": "Guérison" }, - - "REVIVE": { "name": "Rappel" }, - "MAX_REVIVE": { "name": "Rappel Max" }, - - "FULL_HEAL": { "name": "Total Soin" }, - - "SACRED_ASH": { "name": "Cendre Sacrée" }, - - "REVIVER_SEED": { "name": "Résugraine", "description": "Ranime et restaure la moitié des PV de son porteur s’il est mis K.O. par une capacité directe." }, - - "WHITE_HERB": { "name": "Herbe Blanche", "description": "Restaure toute stat ayant subi une baisse en combat." }, - - "ETHER": { "name": "Huile" }, - "MAX_ETHER": { "name": "Huile Max" }, - - "ELIXIR": { "name": "Élixir" }, - "MAX_ELIXIR": { "name": "Élixir Max" }, - - "PP_UP": { "name": "PP Plus" }, - "PP_MAX": { "name": "PP Max" }, - - "LURE": { "name": "Parfum" }, - "SUPER_LURE": { "name": "Super Parfum" }, - "MAX_LURE": { "name": "Parfum Max" }, - - "MEMORY_MUSHROOM": { "name": "Champi Mémoriel", "description": "Remémore une capacité à un Pokémon." }, - - "EXP_SHARE": { "name": "Multi Exp", "description": "Tous les non-participants reçoivent 20% des Points d’Exp d’un participant." }, - "EXP_BALANCE": { "name": "Équilibr’Exp", "description": "Équilibre les Points d’Exp à l’avantage des membres de l’équipe aux plus bas niveaux." }, - - "OVAL_CHARM": { "name": "Charme Ovale", "description": "Quand plusieurs Pokémon sont en combat, chacun gagne 10% supplémentaires du total d’Exp." }, - - "EXP_CHARM": { "name": "Charme Exp" }, - "SUPER_EXP_CHARM": { "name": "Super Charme Exp" }, - "GOLDEN_EXP_CHARM": { "name": "Charme Exp Doré" }, - - "LUCKY_EGG": { "name": "Œuf Chance" }, - "GOLDEN_EGG": { "name": "Œuf d’Or" }, - - "SOOTHE_BELL": { "name": "Grelot Zen" }, - - "SCOPE_LENS": { "name": "Lentilscope", "description": "Une lentille qui augmente d’un cran le taux de critiques du porteur." }, - "DIRE_HIT": { "name": "Muscle +", "extra": { "raises": "Taux de critique" } }, - "LEEK": { "name": "Poireau", "description": "À faire tenir à Canarticho ou Palarticho. Un poireau très long et solide qui augmente de 2 crans le taux de critiques." }, - - "EVIOLITE": { "name": "Évoluroc", "description": "Augmente de 50% la Défense et Déf. Spé. si le porteur peut évoluer, 25% aux fusions dont une moitié le peut encore." }, - - "SOUL_DEW": { "name": "Rosée Âme", "description": "Augmente de 10% l’influence de la nature d’un Pokémon sur ses statistiques. Effet cumulatif." }, - - "NUGGET": { "name": "Pépite" }, - "BIG_NUGGET": { "name": "Maxi Pépite" }, - "RELIC_GOLD": { "name": "Vieux Ducat" }, - - "AMULET_COIN": { "name": "Pièce Rune", "description": "Augmente de 20% les gains d’argent." }, - "GOLDEN_PUNCH": { "name": "Poing Doré", "description": "La moitié des dégâts infligés sont convertis en argent." }, - "COIN_CASE": { "name": "Boite Jetons", "description": "Tous les 10 combats, recevez 10% de votre argent en intérêts." }, - - "LOCK_CAPSULE": { "name": "Poké Écrin", "description": "Permet de choisir de bloquer le niveau de rareté lors d’une relance des objets gratuits proposés." }, - - "GRIP_CLAW": { "name": "Accro Griffe" }, - "WIDE_LENS": { "name": "Loupe" }, - - "MULTI_LENS": { "name": "Lentille Multi" }, - - "HEALING_CHARM": { "name": "Charme Soin", "description": "Augmente de 10% l’efficacité des capacités et objets de soin de PV (hors Rappels)." }, - "CANDY_JAR": { "name": "Bonbonnière", "description": "Augmente de 1 le nombre de niveaux gagnés à l’utilisation d’un Super Bonbon ou d’un Hyper Bonbon." }, - - "BERRY_POUCH": { "name": "Sac à Baies", "description": "Ajoute 30% de chances qu’une Baie utilisée ne soit pas consommée." }, - - "FOCUS_BAND": { "name": "Bandeau", "description": "Ajoute 10% de chances de survivre avec 1 PV si les dégâts reçus pouvaient mettre K.O. ." }, - - "QUICK_CLAW": { "name": "Vive Griffe", "description": "Ajoute 10% de chances d’agir en premier, indépendamment de la Vitesse (après la priorité)." }, - - "KINGS_ROCK": { "name": "Roche Royale", "description": "Ajoute 10% de chances qu’une capacité offensive apeure l’adversaire." }, - - "LEFTOVERS": { "name": "Restes", "description": "Soigne à chaque tour 1/16 des PV max d’un Pokémon." }, - "SHELL_BELL": { "name": "Grelot Coque", "description": "Soigne son porteur avec 1/8 des dégâts qu’il inflige à un Pokémon." }, - - "TOXIC_ORB": { "name": "Orbe Toxique", "description": "Empoisonne gravement son porteur à la fin du tour s’il n’a pas déjà de problème de statut." }, - "FLAME_ORB": { "name": "Orbe Flamme", "description": "Brule son porteur à la fin du tour s’il n’a pas déjà de problème de statut." }, - - "BATON": { "name": "Bâton", "description": "Permet de transmettre les effets en cas de changement de Pokémon. Ignore les pièges." }, - - "SHINY_CHARM": { "name": "Charme Chroma", "description": "Augmente énormément les chances de rencontrer un Pokémon sauvage chromatique." }, - "ABILITY_CHARM": { "name": "Charme Talent", "description": "Augmente énormément les chances de rencontrer un Pokémon sauvage avec un talent caché." }, - - "IV_SCANNER": { "name": "Scanner d’IV", "description": "Révèle la qualité de deux IV d’un Pokémon sauvage par scanner possédé. Les meilleurs IV sont révélés en priorité." }, - - "DNA_SPLICERS": { "name": "Pointeau ADN" }, - - "MINI_BLACK_HOLE": { "name": "Mini Trou Noir" }, - - "GOLDEN_POKEBALL": { "name": "Poké Ball Dorée", "description": "Ajoute un choix d’objet à la fin de chaque combat" }, - - "ENEMY_DAMAGE_BOOSTER": { "name": "Jeton Dégâts", "description": "Augmente les dégâts de 5%." }, - "ENEMY_DAMAGE_REDUCTION": { "name": "Jeton Protection", "description": "Diminue les dégâts reçus de 2,5%." }, - "ENEMY_HEAL": { "name": "Jeton Soin", "description": "Soigne 2% des PV max à chaque tour." }, - "ENEMY_ATTACK_POISON_CHANCE": { "name": "Jeton Poison" }, - "ENEMY_ATTACK_PARALYZE_CHANCE": { "name": "Jeton Paralysie" }, - "ENEMY_ATTACK_BURN_CHANCE": { "name": "Jeton Brulure" }, - "ENEMY_STATUS_EFFECT_HEAL_CHANCE": { "name": "Jeton Total Soin", "description": "Ajoute 2,5% de chances à chaque tour de se soigner d’un problème de statut." }, - "ENEMY_ENDURE_CHANCE": { "name": "Jeton Ténacité" }, - "ENEMY_FUSED_CHANCE": { "name": "Jeton Fusion", "description": "Ajoute 1% de chances qu’un Pokémon sauvage soit une fusion." } - }, - "SpeciesBoosterItem": { - "LIGHT_BALL": { "name": "Balle Lumière", "description": "À faire tenir à Pikachu. Un orbe énigmatique qui double son Attaque et son Atq. Spé. ." }, - "THICK_CLUB": { "name": "Masse Os", "description": "À faire tenir à Osselait ou à Ossatueur, formes d’Alola incluses. Un os dur qui double leur Attaque." }, - "METAL_POWDER": { "name": "Poudre Métal", "description": "À faire tenir à Métamorph. Cette poudre étrange, très fine mais résistante, double sa Défense." }, - "QUICK_POWDER": { "name": "Poudre Vite", "description": "À faire tenir à Métamorph. Cette poudre étrange, très fine mais résistante, double sa Vitesse." } - }, - "TempStatStageBoosterItem": { - "x_attack": "Attaque +", - "x_defense": "Défense +", - "x_sp_atk": "Atq. Spé. +", - "x_sp_def": "Déf. Spé. +", - "x_speed": "Vitesse +", - "x_accuracy": "Précision +" - }, - "AttackTypeBoosterItem": { - "silk_scarf": "Mouchoir Soie", - "black_belt": "Ceinture Noire", - "sharp_beak": "Bec Pointu", - "poison_barb": "Pic Venin", - "soft_sand": "Sable Doux", - "hard_stone": "Pierre Dure", - "silver_powder": "Poudre Argentée", - "spell_tag": "Rune Sort", - "metal_coat": "Peau Métal", - "charcoal": "Charbon", - "mystic_water": "Eau Mystique", - "miracle_seed": "Graine Miracle", - "magnet": "Aimant", - "twisted_spoon": "Cuillère Tordue", - "never_melt_ice": "Glace Éternelle", - "dragon_fang": "Croc Dragon", - "black_glasses": "Lunettes Noires", - "fairy_feather": "Plume Enchantée" - }, - "BaseStatBoosterItem": { - "hp_up": "PV Plus", - "protein": "Protéine", - "iron": "Fer", - "calcium": "Calcium", - "zinc": "Zinc", - "carbos": "Carbone" - }, - "EvolutionItem": { - "NONE": "Aucun", - - "LINKING_CORD": "Fil de Liaison", - "SUN_STONE": "Pierre Soleil", - "MOON_STONE": "Pierre Lune", - "LEAF_STONE": "Pierre Plante", - "FIRE_STONE": "Pierre Feu", - "WATER_STONE": "Pierre Eau", - "THUNDER_STONE": "Pierre Foudre", - "ICE_STONE": "Pierre Glace", - "DUSK_STONE": "Pierre Nuit", - "DAWN_STONE": "Pierre Aube", - "SHINY_STONE": "Pierre Éclat", - "CRACKED_POT": "Théière Fêlée", - "SWEET_APPLE": "Pomme Sucrée", - "TART_APPLE": "Pomme Acidulée", - "STRAWBERRY_SWEET": "Fraise en Sucre", - "UNREMARKABLE_TEACUP": "Bol Médiocre", - - "CHIPPED_POT": "Théière Ébréchée", - "BLACK_AUGURITE": "Obsidienne", - "GALARICA_CUFF": "Bracelet Galanoa", - "GALARICA_WREATH": "Couronne Galanoa", - "PEAT_BLOCK": "Bloc de Tourbe", - "AUSPICIOUS_ARMOR": "Armure de la Fortune", - "MALICIOUS_ARMOR": "Armure de la Rancune", - "MASTERPIECE_TEACUP": "Bol Exceptionnel", - "METAL_ALLOY": "Métal Composite", - "SCROLL_OF_DARKNESS": "Rouleau des Ténèbres", - "SCROLL_OF_WATERS": "Rouleau de l’Eau", - "SYRUPY_APPLE": "Pomme Nectar" - }, - "FormChangeItem": { - "NONE": "Aucun", - - "ABOMASITE": "Blizzarite", - "ABSOLITE": "Absolite", - "AERODACTYLITE": "Ptéraïte", - "AGGRONITE": "Galekingite", - "ALAKAZITE": "Alakazamite", - "ALTARIANITE": "Altarite", - "AMPHAROSITE": "Pharampite", - "AUDINITE": "Nanméouïte", - "BANETTITE": "Branettite", - "BEEDRILLITE": "Dardargnite", - "BLASTOISINITE": "Tortankite", - "BLAZIKENITE": "Braségalite", - "CAMERUPTITE": "Caméruptite", - "CHARIZARDITE_X": "Dracaufite X", - "CHARIZARDITE_Y": "Dracaufite Y", - "DIANCITE": "Diancite", - "GALLADITE": "Gallamite", - "GARCHOMPITE": "Carchacrokite", - "GARDEVOIRITE": "Gardevoirite", - "GENGARITE": "Ectoplasmite", - "GLALITITE": "Oniglalite", - "GYARADOSITE": "Léviatorite", - "HERACRONITE": "Scarhinoïte", - "HOUNDOOMINITE": "Démolossite", - "KANGASKHANITE": "Kangourexite", - "LATIASITE": "Latiasite", - "LATIOSITE": "Latiosite", - "LOPUNNITE": "Lockpinite", - "LUCARIONITE": "Lucarite", - "MANECTITE": "Élecsprintite", - "MAWILITE": "Mysdibulite", - "MEDICHAMITE": "Charminite", - "METAGROSSITE": "Métalossite", - "MEWTWONITE_X": "Mewtwoïte X", - "MEWTWONITE_Y": "Mewtwoïte Y", - "PIDGEOTITE": "Roucarnagite", - "PINSIRITE": "Scarabruite", - "RAYQUAZITE": "Rayquazite", - "SABLENITE": "Ténéfixite", - "SALAMENCITE": "Drattakite", - "SCEPTILITE": "Jungkite", - "SCIZORITE": "Cizayoxite", - "SHARPEDONITE": "Sharpedite", - "SLOWBRONITE": "Flagadossite", - "STEELIXITE": "Steelixite", - "SWAMPERTITE": "Laggronite", - "TYRANITARITE": "Tyranocivite", - "VENUSAURITE": "Florizarrite", - - "BLUE_ORB": "Gemme Bleue", - "RED_ORB": "Gemme Rouge", - "SHARP_METEORITE": "Méteorite Aiguisée", - "HARD_METEORITE": "Méteorite Solide", - "SMOOTH_METEORITE": "Méteorite Lisse", - "ADAMANT_CRYSTAL": "Globe Adamant", - "LUSTROUS_GLOBE": "Globe Perlé", - "GRISEOUS_CORE": "Globe Platiné", - "REVEAL_GLASS": "Miroir Sacré", - "GRACIDEA": "Gracidée", - "MAX_MUSHROOMS": "Maxi Champis", - "DARK_STONE": "Galet Noir", - "LIGHT_STONE": "Galet Blanc", - "PRISON_BOTTLE": "Vase Scellé", - "N_LUNARIZER": "Necroluna", - "N_SOLARIZER": "Necrosol", - "RUSTED_SWORD": "Épée Rouillée", - "RUSTED_SHIELD": "Bouclier Rouillé", - "ICY_REINS_OF_UNITY": "Rênes de l’Unité du Froid", - "SHADOW_REINS_OF_UNITY": "Rênes de l’Unité d’Effroi", - "WELLSPRING_MASK": "Masque du Puits", - "HEARTHFLAME_MASK": "Masque du Fourneau", - "CORNERSTONE_MASK": "Masque de la Pierre", - "SHOCK_DRIVE": "Module Choc", - "BURN_DRIVE": "Module Pyro", - "CHILL_DRIVE": "Module Cryo", - "DOUSE_DRIVE": "Module Aqua", - "ULTRANECROZIUM_Z": "Ultranécrozélite", - - "FIST_PLATE": "Plaque Poing", - "SKY_PLATE": "Plaque Ciel", - "TOXIC_PLATE": "Plaque Toxicité", - "EARTH_PLATE": "Plaque Terre", - "STONE_PLATE": "Plaque Roc", - "INSECT_PLATE": "Plaque Insecte", - "SPOOKY_PLATE": "Plaque Fantôme", - "IRON_PLATE": "Plaque Fer", - "FLAME_PLATE": "Plaque Flamme", - "SPLASH_PLATE": "Plaque Hydro", - "MEADOW_PLATE": "Plaque Herbe", - "ZAP_PLATE": "Plaque Volt", - "MIND_PLATE": "Plaque Esprit", - "ICICLE_PLATE": "Plaque Glace", - "DRACO_PLATE": "Plaque Draco", - "DREAD_PLATE": "Plaque Ombre", - "PIXIE_PLATE": "Plaque Pixie", - "BLANK_PLATE": "Plaque Renouveau", - "LEGEND_PLATE": "Plaque Légende", - "FIGHTING_MEMORY": "ROM Combat", - "FLYING_MEMORY": "ROM Vol", - "POISON_MEMORY": "ROM Poison", - "GROUND_MEMORY": "ROM Sol", - "ROCK_MEMORY": "ROM Roche", - "BUG_MEMORY": "ROM Insecte", - "GHOST_MEMORY": "ROM Spectre", - "STEEL_MEMORY": "ROM Acier", - "FIRE_MEMORY": "ROM Feu", - "WATER_MEMORY": "ROM Eau", - "GRASS_MEMORY": "ROM Plante", - "ELECTRIC_MEMORY": "ROM Électrik", - "PSYCHIC_MEMORY": "ROM Psy", - "ICE_MEMORY": "ROM Glace", - "DRAGON_MEMORY": "ROM Dragon", - "DARK_MEMORY": "ROM Ténèbres", - "FAIRY_MEMORY": "ROM Fée", - "NORMAL_MEMORY": "ROM Normal" - } -} diff --git a/src/locales/fr/modifier.json b/src/locales/fr/modifier.json deleted file mode 100644 index 101b1d56164..00000000000 --- a/src/locales/fr/modifier.json +++ /dev/null @@ -1,12 +0,0 @@ -{ - "surviveDamageApply": "{{pokemonNameWithAffix}} tient bon\ngrâce à son {{typeName}} !", - "turnHealApply": "Les PV de {{pokemonNameWithAffix}}\nsont un peu restaurés par les {{typeName}} !", - "hitHealApply": "Les PV de {{pokemonNameWithAffix}}\nsont un peu restaurés par le {{typeName}} !", - "pokemonInstantReviveApply": "{{pokemonNameWithAffix}} a repris connaissance\navec sa {{typeName}} et est prêt à se battre de nouveau !", - "resetNegativeStatStageApply": "Les stats baissées de {{pokemonNameWithAffix}}\nsont restaurées par l’{{typeName}} !", - "moneyInterestApply": "La {{typeName}} vous rapporte\n{{moneyAmount}} ₽ d’intérêts !", - "turnHeldItemTransferApply": "{{itemName}} de {{pokemonNameWithAffix}} est absorbé·e\npar le {{typeName}} de {{pokemonName}} !", - "contactHeldItemTransferApply": "{{itemName}} de {{pokemonNameWithAffix}} est volé·e\npar l’{{typeName}} de {{pokemonName}} !", - "enemyTurnHealApply": "{{pokemonNameWithAffix}}\nrestaure un peu ses PV !", - "bypassSpeedChanceApply": "{{itemName}} de {{pokemonName}}\nlui permet d’agir plus vite que d’habitude !" -} diff --git a/src/locales/fr/move-trigger.json b/src/locales/fr/move-trigger.json deleted file mode 100644 index 6f9d9d4dd63..00000000000 --- a/src/locales/fr/move-trigger.json +++ /dev/null @@ -1,74 +0,0 @@ -{ - "hitWithRecoil": "{{pokemonName}} est blessé par le contrecoup !", - "cutHpPowerUpMove": "{{pokemonName}} sacrifie des PV\net augmente la puissance de ses capacités !", - "absorbedElectricity": "{{pokemonName}} absorbe de l’électricité !", - "switchedStatChanges": "{{pokemonName}} permute\nles changements de stats avec ceux de sa cible !", - "switchedTwoStatChanges": "{{pokemonName}} permute les changements de {{firstStat}} et de {{secondStat}} avec ceux de sa cible !", - "switchedStat": "{{pokemonName}} et sa cible échangent leur {{stat}} !", - "sharedGuard": "{{pokemonName}} additionne sa garde à celle de sa cible et redistribue le tout équitablement !", - "sharedPower": "{{pokemonName}} additionne sa force à celle de sa cible et redistribue le tout équitablement !", - "shiftedStats": "{{pokemonName}} échange {{statToSwitch}} et {{statToSwitchWith}} !", - "goingAllOutForAttack": "{{pokemonName}} a pris\ncette capacité au sérieux !", - "regainedHealth": "{{pokemonName}}\nrécupère des PV !", - "keptGoingAndCrashed": "{{pokemonName}}\ns’écrase au sol !", - "fled": "{{pokemonName}}\nprend la fuite !", - "cannotBeSwitchedOut": "Impossible de rappeler {{pokemonName}}\nau combat.", - "swappedAbilitiesWithTarget": "{{pokemonName}} et sa cible\néchangent leurs talents !", - "coinsScatteredEverywhere": "Il pleut des pièces !", - "attackedByItem": "{{pokemonName}} est attaqué\npar son propre objet {{itemName}} !", - "whippedUpAWhirlwind": "{{pokemonName}}se prépare\nà lancer une bourrasque !", - "flewUpHigh": "{{pokemonName}} s’envole !", - "tookInSunlight": "{{pokemonName}}\nabsorbe la lumière !", - "dugAHole": "{{pokemonName}}\nse cache dans le sol !", - "loweredItsHead": "{{pokemonName}}\nbaisse la tête !", - "isGlowing": "{{pokemonName}} est entouré\nd’une lumière intense !", - "bellChimed": "Un grelot sonne !", - "foresawAnAttack": "{{pokemonName}}\nprévoit une attaque !", - "isTighteningFocus": "{{pokemonName}} se concentre\nau maximum !", - "hidUnderwater": "{{pokemonName}}\nse cache sous l’eau !", - "soothingAromaWaftedThroughArea": "Une odeur apaisante flotte dans l’air !", - "sprangUp": "{{pokemonName}}\nse propulse dans les airs !", - "choseDoomDesireAsDestiny": "{{pokemonName}}souhaite\nle déclenchement de la capacité Vœu Destructeur !", - "vanishedInstantly": "{{pokemonName}}\ndisparait instantanément !", - "tookTargetIntoSky": "{{pokemonName}} emporte\n{{targetName}} haut dans le ciel !", - "becameCloakedInFreezingLight": "{{pokemonName}} est baigné\nd’une lumière blafarde !", - "becameCloakedInFreezingAir": "{{pokemonName}} est entouré\nd’un air glacial !", - "isChargingPower": "{{pokemonName}}\nconcentre son énergie !", - "burnedItselfOut": "Le feu intérieur de {{pokemonName}}\ns’est entièrement consumé !", - "startedHeatingUpBeak": "{{pokemonName}}\nfait chauffer son bec !", - "setUpShellTrap": "{{pokemonName}} déclenche\nle Carapiège !", - "isOverflowingWithSpacePower": "La puissance du cosmos afflue dans le corps\nde {{pokemonName}} !", - "usedUpAllElectricity": "{{pokemonName}}a utilisé\ntoute son électricité !", - "stoleItem": "{{pokemonName}} vole\nl’objet {{itemName}} de {{targetName}} !", - "incineratedItem": "{{pokemonName}} brule\nla {{itemName}} de {{targetName}} !", - "knockedOffItem": "{{pokemonName}} fait tomber\nl’objet {{itemName}} de {{targetName}} !", - "tookMoveAttack": "{{pokemonName}}\nsubit l’attaque {{moveName}} !", - "cutOwnHpAndMaximizedStat": "{{pokemonName}} sacrifie des PV\net monte son {{statName}} au maximum !", - "copiedStatChanges": "{{pokemonName}} copie\nles changements de stats de {{targetName}} !", - "magnitudeMessage": "Ampleur {{magnitude}} !", - "tookAimAtTarget": "{{pokemonName}} vise\n{{targetName}} !", - "transformedIntoType": "{{pokemonName}} prend\nle type {{typeName}} !", - "copiedMove": "{{pokemonName}} copie\nla capacité {{moveName}} !", - "sketchedMove": "{{pokemonName}} utilise Gribouille\npour copier {{moveName}} !", - "acquiredAbility": "Le talent de {{pokemonName}}\ndevient {{abilityName}} !", - "copiedTargetAbility": "{{pokemonName}} copie le talent\n{{abilityName}} de {{targetName}} !", - "transformedIntoTarget": "{{pokemonName}} prend\nl’apparence de {{targetName}} !", - "tryingToTakeFoeDown": "{{pokemonName}} veut entrainer\nson assaillant dans sa chute !", - "addType": "{{pokemonName}} gagne\nle type {{typeName}}.", - "cannotUseMove": "{{pokemonName}} ne peut pas\nutiliser la capacité {{moveName}} !", - "healHp": "{{pokemonName}}\nrécupère des PV !", - "sacrificialFullRestore": "Le Vœu Soin est exaucé et profite\nà {{pokemonName}} !", - "invertStats": "Les changements de stats\nde {{pokemonName}} sont inversés !", - "resetStats": "Les changements de stats\nde {{pokemonName}} ont tous été annulés !", - "statEliminated": "Les changements de stats ont tous été annulés !", - "faintCountdown": "{{pokemonName}}\nsera K.O. dans {{turnCount}} tours !", - "copyType": "{{pokemonName}} prend le type\nde {{targetPokemonName}} !", - "suppressAbilities": "Le talent de {{pokemonName}}\na été rendu inactif !", - "revivalBlessing": "{{pokemonName}} a repris connaissance\net est prêt à se battre de nouveau !", - "swapArenaTags": "Les effets affectant chaque côté du terrain\nont été échangés par {{pokemonName}} !", - "exposedMove": "{{targetPokemonName}} est identifié\npar {{pokemonName}} !", - "safeguard": "{{targetName}} est protégé\npar la capacité Rune Protect !", - "substituteOnOverlap": "{{pokemonName}} a déjà\nun clone !", - "substituteNotEnoughHp": "Mais il est trop faible\npour créer un clone !", - "afterYou": "{{pokemonName}} accepte\navec joie !" -} diff --git a/src/locales/fr/move.json b/src/locales/fr/move.json deleted file mode 100644 index 957895b5db9..00000000000 --- a/src/locales/fr/move.json +++ /dev/null @@ -1,3810 +0,0 @@ -{ - "pound": { - "name": "Écras’Face", - "effect": "Le lanceur écrase la cible avec l’un de ses membres, tels qu’une de ses pattes avant ou sa longue queue." - }, - "karateChop": { - "name": "Poing Karaté", - "effect": "L’ennemi est tranché violemment. Taux de critique élevé." - }, - "doubleSlap": { - "name": "Torgnoles", - "effect": "Gifle rapidement l’ennemi de deux à cinq fois d’affilée." - }, - "cometPunch": { - "name": "Poing Comète", - "effect": "Une tornade de coups de poing qui frappe de deux à cinq fois d’affilée." - }, - "megaPunch": { - "name": "Ultimapoing", - "effect": "La cible reçoit un coup de poing d’une grande puissance." - }, - "payDay": { - "name": "Jackpot", - "effect": "Des pièces sont lancées sur la cible. Permet d’obtenir de l’argent à la fin du combat." - }, - "firePunch": { - "name": "Poing Feu", - "effect": "Un coup de poing enflammé vient frapper la cible, ce qui peut la bruler (10% de chances)." - }, - "icePunch": { - "name": "Poing Glace", - "effect": "Un coup de poing glacé vient frapper la cible, ce qui peut la geler (10% de chances)." - }, - "thunderPunch": { - "name": "Poing Éclair", - "effect": "Un coup de poing électrique vient frapper la cible, ce qui peut la paralyser (10% de chances)." - }, - "scratch": { - "name": "Griffe", - "effect": "Lacère la cible avec des griffes acérées pour lui infliger des dégâts." - }, - "viseGrip": { - "name": "Force Poigne", - "effect": "La cible est attrapée et compressée par les côtés." - }, - "guillotine": { - "name": "Guillotine", - "effect": "Des pinces lacèrent violemment la cible, la mettant K.O. sur le coup si elle est touchée." - }, - "razorWind": { - "name": "Coupe-Vent", - "effect": "Attaque en deux tours. Des lames de vent frappent l’ennemi au second tour. Taux de critique élevé." - }, - "swordsDance": { - "name": "Danse Lames", - "effect": "Une danse frénétique qui exalte l’esprit combatif. Augmente beaucoup l’Attaque du lanceur." - }, - "cut": { - "name": "Coupe", - "effect": "Coupe la cible avec des lames ou des griffes." - }, - "gust": { - "name": "Tornade", - "effect": "Le lanceur bat des ailes pour générer une bourrasque qui blesse la cible." - }, - "wingAttack": { - "name": "Cru-Ailes", - "effect": "Le lanceur déploie largement ses ailes majestueuses pour attaquer la cible." - }, - "whirlwind": { - "name": "Cyclone", - "effect": "Éjecte le Pokémon ennemi et le remplace par un autre. Lors d’un combat contre un Pokémon sauvage seul, met fin au combat." - }, - "fly": { - "name": "Vol", - "effect": "Le lanceur s’envole au premier tour et frappe au second." - }, - "bind": { - "name": "Étreinte", - "effect": "Le lanceur ligote la cible avec son corps allongé ou ses tentacules pour la compresser durant quatre à cinq tours." - }, - "slam": { - "name": "Souplesse", - "effect": "Le lanceur utilise l’un de ses membres, tels qu’une queue ou une liane, pour infliger des dégâts à la cible." - }, - "vineWhip": { - "name": "Fouet Lianes", - "effect": "Fouette la cible avec de fines lianes pour infliger des dégâts." - }, - "stomp": { - "name": "Écrasement", - "effect": "Écrase la cible avec un énorme pied, ce qui peut aussi l’apeurer (30% de chances)." - }, - "doubleKick": { - "name": "Double Pied", - "effect": "Deux coups de pied qui frappent la cible deux fois d’affilée." - }, - "megaKick": { - "name": "Ultimawashi", - "effect": "Un coup de pied surpuissant qui frappe la cible." - }, - "jumpKick": { - "name": "Pied Sauté", - "effect": "Le lanceur s’envole pour décocher un coup de pied sauté. S’il échoue, le lanceur se blesse." - }, - "rollingKick": { - "name": "Mawashi Geri", - "effect": "Le lanceur effectue un coup de pied tournoyant et extrêmement rapide. Peut apeurer l’ennemi (30% de chances)." - }, - "sandAttack": { - "name": "Jet de Sable", - "effect": "Lance du sable au visage de la cible pour baisser sa Précision." - }, - "headbutt": { - "name": "Coup d’Boule", - "effect": "Le lanceur donne un coup de tête à la cible qui peut aussi l’apeurer (30% de chances)." - }, - "hornAttack": { - "name": "Koud’Korne", - "effect": "Frappe la cible d’un coup de corne pointue pour infliger des dégâts." - }, - "furyAttack": { - "name": "Furie", - "effect": "Frappe la cible deux à cinq fois d’affilée avec un membre pointu tel qu’un bec ou une corne." - }, - "hornDrill": { - "name": "Empal’Korne", - "effect": "Un coup de corne en vrille qui empale la cible, la mettant K.O. sur le coup si elle est touchée." - }, - "tackle": { - "name": "Charge", - "effect": "Le lanceur charge la cible et la percute de tout son poids." - }, - "bodySlam": { - "name": "Plaquage", - "effect": "Le lanceur se laisse tomber sur la cible de tout son poids, ce qui peut aussi la paralyser (30% de chances)." - }, - "wrap": { - "name": "Ligotage", - "effect": "Le lanceur ligote la cible avec son corps allongé ou ses tentacules pour la compresser durant quatre à cinq tours." - }, - "takeDown": { - "name": "Bélier", - "effect": "Une charge violente qui blesse aussi légèrement le lanceur." - }, - "thrash": { - "name": "Mania", - "effect": "Une attaque furieuse qui dure de deux à trois tours. Le lanceur devient confus." - }, - "doubleEdge": { - "name": "Damoclès", - "effect": "Une charge dangereuse et imprudente. Blesse aussi gravement le lanceur." - }, - "tailWhip": { - "name": "Mimi-Queue", - "effect": "Le lanceur remue son adorable queue pour tromper la vigilance de la cible et baisser sa Défense." - }, - "poisonSting": { - "name": "Dard-Venin", - "effect": "Un dard toxique transperce la cible et peut aussi l’empoisonner (30% de chances)." - }, - "twineedle": { - "name": "Double Dard", - "effect": "Un double coup de dard qui transperce l’ennemi deux fois d’affilée. Peut aussi l’empoisonner (36% de chances)." - }, - "pinMissile": { - "name": "Dard-Nuée", - "effect": "Envoie une rafale de dards. Peut toucher de deux à cinq fois." - }, - "leer": { - "name": "Groz’Yeux", - "effect": "Le lanceur fait les gros yeux à la cible pour l’intimider et baisser sa Défense." - }, - "bite": { - "name": "Morsure", - "effect": "Le lanceur utilise ses canines tranchantes pour mordre la cible, ce qui peut aussi l’apeurer (30% de chances)." - }, - "growl": { - "name": "Rugissement", - "effect": "Le lanceur pousse un cri tout mimi pour tromper la vigilance de la cible et baisser son Attaque." - }, - "roar": { - "name": "Hurlement", - "effect": "Effraie le Pokémon ennemi et le remplace par un autre. Lors d’un combat contre un Pokémon sauvage seul, met fin au combat." - }, - "sing": { - "name": "Berceuse", - "effect": "Une berceuse plonge la cible dans un profond sommeil." - }, - "supersonic": { - "name": "Ultrason", - "effect": "Le lanceur produit d’étranges ondes sonores qui rendent la cible confuse." - }, - "sonicBoom": { - "name": "Sonic Boom", - "effect": "Une onde de choc destructrice qui inflige toujours 20 PV de dégâts." - }, - "disable": { - "name": "Entrave", - "effect": "Empêche la cible de répéter sa dernière attaque. Dure quatre tours." - }, - "acid": { - "name": "Acide", - "effect": "Le lanceur attaque la cible avec un jet d’acide corrosif qui peut aussi baisser sa Défense Spéciale." - }, - "ember": { - "name": "Flammèche", - "effect": "La cible est attaquée par une faible flamme qui peut aussi la bruler." - }, - "flamethrower": { - "name": "Lance-Flammes", - "effect": "La cible reçoit un torrent de flammes qui peut aussi la bruler (10% de chances)." - }, - "mist": { - "name": "Brume", - "effect": "Une brume blanche enveloppe le lanceur et ses alliés et empêche la réduction des stats pour cinq tours." - }, - "waterGun": { - "name": "Pistolet à O", - "effect": "De l’eau est projetée avec force sur la cible." - }, - "hydroPump": { - "name": "Hydrocanon", - "effect": "Un puissant jet d’eau est dirigé sur la cible." - }, - "surf": { - "name": "Surf", - "effect": "Une énorme vague s’abat sur le champ de bataille et inflige des dégâts à tous les Pokémon autour du lanceur." - }, - "iceBeam": { - "name": "Laser Glace", - "effect": "Un rayon de glace frappe la cible, ce qui peut aussi la geler (10% de chances)." - }, - "blizzard": { - "name": "Blizzard", - "effect": "Une violente tempête de neige s’abat sur la cible, ce qui peut aussi la geler (10% de chances)." - }, - "psybeam": { - "name": "Rafale Psy", - "effect": "Un étrange rayon frappe la cible, ce qui peut aussi la rendre confuse." - }, - "bubbleBeam": { - "name": "Bulles d’O", - "effect": "Des bulles sont envoyées avec puissance sur la cible, ce qui peut aussi baisser sa Vitesse." - }, - "auroraBeam": { - "name": "Onde Boréale", - "effect": "Le lanceur envoie un rayon arc-en-ciel sur la cible, ce qui peut aussi baisser son Attaque." - }, - "hyperBeam": { - "name": "Ultralaser", - "effect": "Le lanceur projette un puissant rayon sur la cible, mais doit se reposer au tour suivant." - }, - "peck": { - "name": "Picpic", - "effect": "Le lanceur frappe la cible d’un bec acéré ou d’une corne pointue pour infliger des dégâts." - }, - "drillPeck": { - "name": "Bec Vrille", - "effect": "Une attaque utilisant le bec comme une perceuse." - }, - "submission": { - "name": "Sacrifice", - "effect": "Le lanceur agrippe l’ennemi et l’écrase au sol. Blesse aussi légèrement le lanceur." - }, - "lowKick": { - "name": "Balayage", - "effect": "Un grand coup de pied bas qui fauche la cible. Plus celle-ci est lourde, plus la puissance de cette capacité augmente." - }, - "counter": { - "name": "Riposte", - "effect": "Une riposte qui répond à toute attaque physique en infligeant le double de dégâts." - }, - "seismicToss": { - "name": "Frappe Atlas", - "effect": "La cible est projetée grâce au pouvoir de la gravité. Cette capacité inflige des dégâts égaux au niveau du lanceur." - }, - "strength": { - "name": "Force", - "effect": "Le lanceur cogne la cible de toutes ses forces." - }, - "absorb": { - "name": "Vole-Vie", - "effect": "Une attaque qui absorbe les nutriments et convertit la moitié des dégâts infligés en PV pour le lanceur." - }, - "megaDrain": { - "name": "Méga-Sangsue", - "effect": "Une attaque qui absorbe les nutriments et convertit la moitié des dégâts infligés en PV pour le lanceur." - }, - "leechSeed": { - "name": "Vampigraine", - "effect": "Une graine est semée sur la cible. À chaque tour, elle lui dérobe des PV que le lanceur récupère." - }, - "growth": { - "name": "Croissance", - "effect": "Le corps du lanceur se développe. Augmente l’Attaque et l’Attaque Spéciale." - }, - "razorLeaf": { - "name": "Tranch’Herbe", - "effect": "Des feuilles aiguisées comme des rasoirs entaillent la cible. Taux de critiques élevé." - }, - "solarBeam": { - "name": "Lance-Soleil", - "effect": "Le lanceur absorbe une grande quantité de lumière au premier tour et envoie un rayon puissant au tour suivant." - }, - "poisonPowder": { - "name": "Poudre Toxik", - "effect": "Une poudre toxique empoisonne la cible." - }, - "stunSpore": { - "name": "Para-Spore", - "effect": "Le lanceur répand sur la cible une poudre qui la paralyse." - }, - "sleepPowder": { - "name": "Poudre Dodo", - "effect": "Le lanceur répand une poudre soporifique qui endort la cible." - }, - "petalDance": { - "name": "Danse Fleurs", - "effect": "Le lanceur attaque en projetant des pétales pendant deux à trois tours avant de céder à la confusion." - }, - "stringShot": { - "name": "Sécrétion", - "effect": "Le lanceur crache de la soie pour ligoter la cible et beaucoup baisser sa Vitesse." - }, - "dragonRage": { - "name": "Draco-Rage", - "effect": "La colère du lanceur déclenche une onde de choc destructrice qui inflige toujours 40 PV de dégâts." - }, - "fireSpin": { - "name": "Danse Flammes", - "effect": "Un tourbillon de flammes emprisonne la cible pendant quatre à cinq tours." - }, - "thunderShock": { - "name": "Éclair", - "effect": "Une décharge électrique tombe sur la cible, ce qui peut aussi la paralyser (10% de chances)." - }, - "thunderbolt": { - "name": "Tonnerre", - "effect": "Une grosse décharge électrique tombe sur la cible, ce qui peut aussi la paralyser (10% de chances)." - }, - "thunderWave": { - "name": "Cage Éclair", - "effect": "Un faible choc électrique paralyse la cible." - }, - "thunder": { - "name": "Fatal-Foudre", - "effect": "La foudre tombe sur la cible pour lui infliger des dégâts, ce qui peut aussi la paralyser (30% de chances)." - }, - "rockThrow": { - "name": "Jet-Pierres", - "effect": "Le lanceur soulève une pierre et la lance sur la cible." - }, - "earthquake": { - "name": "Séisme", - "effect": "Le lanceur provoque un tremblement de terre touchant tous les Pokémon autour de lui." - }, - "fissure": { - "name": "Abime", - "effect": "Le lanceur fait tomber la cible dans une crevasse. Si cette attaque réussit, elle met K.O. sur le coup." - }, - "dig": { - "name": "Tunnel", - "effect": "Le lanceur creuse au premier tour et frappe au second." - }, - "toxic": { - "name": "Toxik", - "effect": "Le lanceur empoisonne gravement la cible. Les dégâts dus au poison augmentent à chaque tour." - }, - "confusion": { - "name": "Choc Mental", - "effect": "Une faible vague télékinétique frappe la cible, ce qui peut aussi la plonger dans la confusion." - }, - "psychic": { - "name": "Psyko", - "effect": "Une puissante force télékinétique frappe la cible, ce qui peut aussi faire baisser sa Défense Spéciale." - }, - "hypnosis": { - "name": "Hypnose", - "effect": "Le lanceur hypnotise la cible pour la plonger dans un profond sommeil." - }, - "meditate": { - "name": "Yoga", - "effect": "Le lanceur médite pour éveiller son pouvoir latent et augmenter son Attaque." - }, - "agility": { - "name": "Hâte", - "effect": "Le lanceur se relaxe et allège son corps pour beaucoup augmenter sa Vitesse." - }, - "quickAttack": { - "name": "Vive-Attaque", - "effect": "Le lanceur fonce sur la cible si rapidement qu’on parvient à peine à le discerner. Frappe en priorité." - }, - "rage": { - "name": "Frénésie", - "effect": "Une fois activée, cette capacité augmente l’Attaque du lanceur à mesure que celui-ci subit des attaques." - }, - "teleport": { - "name": "Téléport", - "effect": "Permet de changer de place avec un autre Pokémon de l’équipe s’il y en a. Quand cette capacité est utilisée par un Pokémon sauvage, celui-ci fuit le combat." - }, - "nightShade": { - "name": "Ombre Nocturne", - "effect": "Le lanceur invoque un mirage et inflige des dégâts égaux au niveau du lanceur." - }, - "mimic": { - "name": "Copie", - "effect": "Le lanceur copie la dernière capacité utilisée par la cible et la conserve tant qu’il reste au combat." - }, - "screech": { - "name": "Grincement", - "effect": "Le lanceur émet un son strident qui donne envie de se boucher les oreilles. Baisse beaucoup la Défense de la cible." - }, - "doubleTeam": { - "name": "Reflet", - "effect": "Le lanceur se déplace si vite qu’il crée des copies illusoires de lui-même, augmentant son Esquive." - }, - "recover": { - "name": "Soin", - "effect": "Un soin qui permet au lanceur de récupérer jusqu’à la moitié de ses PV max." - }, - "harden": { - "name": "Armure", - "effect": "Le lanceur contracte tous ses muscles pour augmenter sa Défense." - }, - "minimize": { - "name": "Lilliput", - "effect": "Le lanceur comprime son corps pour se faire tout petit et beaucoup augmenter son Esquive." - }, - "smokescreen": { - "name": "Brouillard", - "effect": "Le lanceur disperse un nuage d’encre ou de fumée qui réduit la Précision de la cible." - }, - "confuseRay": { - "name": "Onde Folie", - "effect": "Une lumière étrange qui plonge la cible dans un état de confusion." - }, - "withdraw": { - "name": "Repli", - "effect": "Le lanceur se recroqueville dans sa carapace, ce qui augmente sa Défense." - }, - "defenseCurl": { - "name": "Boul’Armure", - "effect": "Le lanceur s’enroule pour cacher ses points faibles, ce qui augmente sa Défense." - }, - "barrier": { - "name": "Bouclier", - "effect": "Le lanceur érige un mur solide qui augmente beaucoup sa Défense." - }, - "lightScreen": { - "name": "Mur Lumière", - "effect": "Crée un fabuleux mur de lumière qui réduit les dégâts causés par les capacités spéciales pendant cinq tours." - }, - "haze": { - "name": "Buée Noire", - "effect": "Crée un brouillard qui annule les changements de stats de tous les Pokémon au combat." - }, - "reflect": { - "name": "Protection", - "effect": "Crée un fabuleux mur de lumière qui réduit les dégâts causés par les capacités physiques pendant cinq tours." - }, - "focusEnergy": { - "name": "Puissance", - "effect": "Le lanceur prend une profonde inspiration et se concentre pour augmenter son taux de critiques." - }, - "bide": { - "name": "Patience", - "effect": "Le lanceur encaisse les coups durant deux tours et réplique en infligeant le double des dégâts subis." - }, - "metronome": { - "name": "Métronome", - "effect": "Le lanceur agite un doigt et stimule son cerveau pour utiliser presque n’importe quelle capacité au hasard." - }, - "mirrorMove": { - "name": "Mimique", - "effect": "Le lanceur riposte à l’attaque de l’ennemi avec la même attaque." - }, - "selfDestruct": { - "name": "Destruction", - "effect": "Le lanceur explose en blessant tous les Pokémon autour de lui. Le lanceur tombe K.O." - }, - "eggBomb": { - "name": "Bombe Œuf", - "effect": "De toutes ses forces, le lanceur jette un gros œuf sur l’ennemi pour lui infliger des dégâts." - }, - "lick": { - "name": "Léchouille", - "effect": "Un grand coup de langue qui inflige des dégâts à la cible et peut aussi la paralyser (30% de chances)." - }, - "smog": { - "name": "Purédpois", - "effect": "Le lanceur attaque à l’aide d’une éruption de gaz répugnants qui peuvent aussi empoisonner la cible." - }, - "sludge": { - "name": "Détritus", - "effect": "Des détritus toxiques sont projetés sur la cible, ce qui peut aussi l’empoisonner (30% de chances)." - }, - "boneClub": { - "name": "Massd’Os", - "effect": "Le lanceur frappe l’ennemi à grands coups d’os. Peut aussi l’apeurer (10% de chances)." - }, - "fireBlast": { - "name": "Déflagration", - "effect": "Un déluge de flammes ardentes submerge la cible, ce qui peut aussi la bruler (10% de chances)." - }, - "waterfall": { - "name": "Cascade", - "effect": "Le lanceur charge la cible avec une intensité remarquable, ce qui peut l’apeurer (20% de chances)." - }, - "clamp": { - "name": "Claquoir", - "effect": "Le lanceur piège l’ennemi dans sa dure coquille et l’écrase pendant quatre à cinq tours." - }, - "swift": { - "name": "Météores", - "effect": "Le lanceur envoie des rayons d’étoiles qui touchent toujours la cible." - }, - "skullBash": { - "name": "Coud’Krâne", - "effect": "Le lanceur baisse la tête pour augmenter sa Défense au premier tour et percuter l’ennemi au second." - }, - "spikeCannon": { - "name": "Picanon", - "effect": "Envoie une rafale de dards. Peut toucher de deux à cinq fois." - }, - "constrict": { - "name": "Constriction", - "effect": "De longs tentacules ou lianes attaquent l’ennemi. Peut aussi baisser sa Vitesse." - }, - "amnesia": { - "name": "Amnésie", - "effect": "Le lanceur fait le vide dans son esprit pour oublier ses soucis. Augmente beaucoup sa Défense Spéciale." - }, - "kinesis": { - "name": "Télékinésie", - "effect": "Le lanceur distrait l’ennemi en pliant une cuiller, ce qui baisse sa Précision." - }, - "softBoiled": { - "name": "E-Coque", - "effect": "Le lanceur récupère jusqu’à la moitié de ses PV max." - }, - "highJumpKick": { - "name": "Pied Voltige", - "effect": "Le lanceur s’élance pour effectuer un coup de genou sauté. S’il échoue, le lanceur se blesse." - }, - "glare": { - "name": "Regard Médusant", - "effect": "Le lanceur intimide la cible grâce à son regard terrifiant pour la paralyser." - }, - "dreamEater": { - "name": "Dévorêve", - "effect": "Le lanceur mange le rêve de la cible endormie et récupère en PV la moitié des dégâts infligés." - }, - "poisonGas": { - "name": "Gaz Toxik", - "effect": "Le lanceur empoisonne la cible en lui projetant un nuage de gaz toxique au visage." - }, - "barrage": { - "name": "Pilonnage", - "effect": "Projette de deux à cinq grosses boules sur l’ennemi." - }, - "leechLife": { - "name": "Vampirisme", - "effect": "Une attaque qui aspire le sang de la cible. La moitié des dégâts sont convertis en PV pour le lanceur." - }, - "lovelyKiss": { - "name": "Grobisou", - "effect": "Le lanceur fait un bisou à l’ennemi en prenant une mine effrayante. Endort l’ennemi." - }, - "skyAttack": { - "name": "Piqué", - "effect": "Une attaque en deux tours au taux de critiques élevé, qui peut aussi apeurer la cible (30% de chances)." - }, - "transform": { - "name": "Morphing", - "effect": "Le lanceur devient une copie de sa cible et obtient la même palette de capacités." - }, - "bubble": { - "name": "Écume", - "effect": "Des bulles frappent l’ennemi. Peut réduire sa Vitesse." - }, - "dizzyPunch": { - "name": "Uppercut", - "effect": "Un enchainement de coups de poing cadencés frappe l’ennemi. Peut aussi le rendre confus." - }, - "spore": { - "name": "Spore", - "effect": "Le lanceur répand un nuage de spores qui endort." - }, - "flash": { - "name": "Flash", - "effect": "Explosion lumineuse qui fait baisser la Précision de l’ennemi." - }, - "psywave": { - "name": "Vague Psy", - "effect": "Une étrange onde d’énergie chaude frappe l’ennemi. Cette attaque est d’intensité variable." - }, - "splash": { - "name": "Trempette", - "effect": "Le lanceur barbote et éclabousse les environs. Cette capacité n’a aucun effet." - }, - "acidArmor": { - "name": "Acidarmure", - "effect": "Le lanceur modifie sa structure moléculaire pour se liquéfier et beaucoup augmenter sa Défense." - }, - "crabhammer": { - "name": "Pince-Masse", - "effect": "Une grande pince martèle la cible. Taux de critiques élevé." - }, - "explosion": { - "name": "Explosion", - "effect": "Le lanceur explose et inflige des dégâts à tous les Pokémon autour de lui. Met K.O. le lanceur." - }, - "furySwipes": { - "name": "Combo-Griffe", - "effect": "La cible est lacérée par des faux ou des griffes de deux à cinq fois d’affilée." - }, - "bonemerang": { - "name": "Osmerang", - "effect": "Le lanceur projette son os comme un boomerang. Cette attaque frappe à l’aller et au retour." - }, - "rest": { - "name": "Repos", - "effect": "Le lanceur regagne tous ses PV et ses altérations de statut sont soignées, puis il dort pendant deux tours." - }, - "rockSlide": { - "name": "Éboulement", - "effect": "Le lanceur envoie de gros rochers sur la cible pour lui infliger des dégâts, ce qui peut aussi l’apeurer (30% de chances)." - }, - "hyperFang": { - "name": "Croc de Mort", - "effect": "Le lanceur mord l’ennemi à l’aide de ses incisives aiguisées. Peut aussi l’apeurer (10% de chances)." - }, - "sharpen": { - "name": "Affutage", - "effect": "Le lanceur réduit son nombre de polygones pour accentuer ses angles et augmenter son Attaque." - }, - "conversion": { - "name": "Conversion", - "effect": "Le lanceur change de type pour prendre celui de la première capacité de sa liste." - }, - "triAttack": { - "name": "Triplattaque", - "effect": "Le lanceur envoie trois boules d’énergie simultanément qui peuvent aussi paralyser, bruler ou geler la cible (6.67% de chances)." - }, - "superFang": { - "name": "Croc Fatal", - "effect": "Une vilaine morsure d’incisives qui réduit de moitié les PV de la cible." - }, - "slash": { - "name": "Tranche", - "effect": "Le lanceur donne un coup de griffe ou de faux. Taux de critiques élevé." - }, - "substitute": { - "name": "Clonage", - "effect": "Le lanceur crée un clone en sacrifiant quelques PV. Ce clone sert de leurre." - }, - "struggle": { - "name": "Lutte", - "effect": "Une attaque désespérée, utilisée quand le lanceur n’a plus de PP. Le blesse aussi légèrement." - }, - "sketch": { - "name": "Gribouille", - "effect": "Le lanceur apprend la dernière capacité utilisée par la cible. Gribouille disparait après utilisation." - }, - "tripleKick": { - "name": "Triple Pied", - "effect": "Une salve de un à trois coups de pied dont la puissance augmente à chaque coup porté." - }, - "thief": { - "name": "Larcin", - "effect": "Le lanceur attaque la cible et vole son objet. Le lanceur ne peut rien voler s’il tient déjà un objet." - }, - "spiderWeb": { - "name": "Toile", - "effect": "Le lanceur enserre l’ennemi à l’aide d’une fine soie gluante pour l’empêcher de fuir le combat." - }, - "mindReader": { - "name": "Lire-Esprit", - "effect": "Le lanceur analyse les mouvements de l’ennemi pour être sûr de toucher au coup suivant." - }, - "nightmare": { - "name": "Cauchemar", - "effect": "Un cauchemar qui inflige des dégâts à chaque tour à un ennemi endormi." - }, - "flameWheel": { - "name": "Roue de Feu", - "effect": "Le lanceur s’entoure de feu et charge la cible, ce qui peut aussi la bruler (10% de chances)." - }, - "snore": { - "name": "Ronflement", - "effect": "Une attaque qui ne fonctionne que si le lanceur est endormi. Le boucan peut aussi apeurer la cible (30% de chances)." - }, - "curse": { - "name": "Malédiction", - "effect": "Une capacité à l’effet différent selon que le lanceur est un Pokémon Spectre ou non." - }, - "flail": { - "name": "Gigotage", - "effect": "Le lanceur attaque en gigotant dans tous les sens. Plus ses PV sont bas, plus l’attaque est puissante." - }, - "conversion2": { - "name": "Conversion 2", - "effect": "Le lanceur change de type pour être résistant au type de la dernière attaque lancée par sa cible." - }, - "aeroblast": { - "name": "Aéroblast", - "effect": "Le lanceur projette une tornade sur l’ennemi pour infliger des dégâts. Taux de critique élevé." - }, - "cottonSpore": { - "name": "Spore Coton", - "effect": "Le lanceur libère des spores cotonneuses qui collent à la cible et baissent beaucoup sa Vitesse." - }, - "reversal": { - "name": "Contre", - "effect": "Le lanceur ne retient plus ses coups. Plus ses PV sont bas, plus la puissance de cette capacité augmente." - }, - "spite": { - "name": "Dépit", - "effect": "Le lanceur exprime son ressentiment en retirant 4 PP à la dernière capacité utilisée par la cible." - }, - "powderSnow": { - "name": "Poudreuse", - "effect": "Le lanceur projette de la neige poudreuse qui peut aussi geler la cible (10% de chances)." - }, - "protect": { - "name": "Abri", - "effect": "Le lanceur se protège de toutes les attaques. Peut échouer si utilisée plusieurs fois de suite." - }, - "machPunch": { - "name": "Mach Punch", - "effect": "Coup de poing fulgurant. Frappe en priorité." - }, - "scaryFace": { - "name": "Grimace", - "effect": "Le lanceur fait une grimace qui effraie la cible et réduit beaucoup sa Vitesse." - }, - "feintAttack": { - "name": "Feinte", - "effect": "Le lanceur s’approche l’air de rien avant de frapper par surprise. N’échoue jamais." - }, - "sweetKiss": { - "name": "Doux Baiser", - "effect": "Le lanceur envoie un bisou si mignon et désarmant qu’il plonge la cible dans la confusion." - }, - "bellyDrum": { - "name": "Cognobidon", - "effect": "Améliore l’Attaque au maximum en sacrifiant la moitié des PV max." - }, - "sludgeBomb": { - "name": "Bombe Beurk", - "effect": "Des détritus toxiques sont projetés sur la cible, ce qui peut aussi l’empoisonner (30% de chances)." - }, - "mudSlap": { - "name": "Coud’Boue", - "effect": "Le lanceur envoie de la boue au visage de la cible pour infliger des dégâts et baisser sa Précision." - }, - "octazooka": { - "name": "Octazooka", - "effect": "Le lanceur attaque en projetant de l’encre au visage de l’ennemi. Peut aussi baisser sa Précision." - }, - "spikes": { - "name": "Picots", - "effect": "Le lanceur disperse des picots sur le sol pour blesser tout ennemi qui entre au combat." - }, - "zapCannon": { - "name": "Élecanon", - "effect": "Un boulet de canon électrifié qui inflige des dégâts à la cible et la paralyse." - }, - "foresight": { - "name": "Clairvoyance", - "effect": "Permet de toucher un Pokémon Spectre avec n’importe quelle capacité ou de toucher un ennemi insaisissable." - }, - "destinyBond": { - "name": "Lien du Destin", - "effect": "Si un assaillant porte un coup fatal au lanceur après qu’il a activé cette capacité, ils sont tous les deux mis K.O. La capacité échoue si elle est immédiatement réutilisée." - }, - "perishSong": { - "name": "Requiem", - "effect": "Tout Pokémon qui entend ce requiem est K.O. dans trois tours à moins qu’il ne soit remplacé." - }, - "icyWind": { - "name": "Vent Glace", - "effect": "Une bourrasque de vent froid blesse la cible et réduit sa Vitesse." - }, - "detect": { - "name": "Détection", - "effect": "Le lanceur se protège de toutes les attaques. Peut échouer si utilisée plusieurs fois de suite." - }, - "boneRush": { - "name": "Charge Os", - "effect": "Le lanceur frappe la cible avec un os de deux à cinq fois d’affilée." - }, - "lockOn": { - "name": "Verrouillage", - "effect": "Le lanceur verrouille la cible pour ne pas la rater au tour suivant." - }, - "outrage": { - "name": "Colère", - "effect": "Le lanceur enrage et attaque pendant deux ou trois tours avant de devenir confus." - }, - "sandstorm": { - "name": "Tempête de Sable", - "effect": "Une tempête de sable blesse tous les Pokémon pendant cinq tours, sauf ceux de type Roche, Sol ou Acier. Augmente la Défense Spéciale des Pokémon Roche." - }, - "gigaDrain": { - "name": "Giga-Sangsue", - "effect": "Une attaque qui absorbe les nutriments et convertit la moitié des dégâts infligés en PV pour le lanceur." - }, - "endure": { - "name": "Ténacité", - "effect": "Le lanceur résiste aux attaques avec 1 PV. Peut échouer si utilisée plusieurs fois de suite." - }, - "charm": { - "name": "Charme", - "effect": "Le lanceur fait les yeux doux pour berner la cible et beaucoup réduire son Attaque." - }, - "rollout": { - "name": "Roulade", - "effect": "Un rocher roule sur la cible pendant cinq tours. L’attaque gagne en puissance à chaque coup." - }, - "falseSwipe": { - "name": "Faux-Chage", - "effect": "Le lanceur retient ses coups pour que la cible garde au moins 1 PV et ne tombe pas K.O." - }, - "swagger": { - "name": "Vantardise", - "effect": "Fait enrager la cible et la plonge dans la confusion, mais augmente beaucoup son Attaque." - }, - "milkDrink": { - "name": "Lait à Boire", - "effect": "Le lanceur récupère jusqu’à la moitié de ses PV max." - }, - "spark": { - "name": "Étincelle", - "effect": "Le lanceur envoie une charge électrique sur la cible qui peut aussi la paralyser (30% de chances)." - }, - "furyCutter": { - "name": "Taillade", - "effect": "Un coup de faux ou de griffe dont la puissance augmente quand il touche plusieurs fois d’affilée." - }, - "steelWing": { - "name": "Ailes d’Acier", - "effect": "Le lanceur frappe la cible avec des ailes d’acier, ce qui peut aussi augmenter la Défense du lanceur." - }, - "meanLook": { - "name": "Regard Noir", - "effect": "Le lanceur pétrifie la cible en lui lançant un regard noir qui la rend incapable de quitter le terrain." - }, - "attract": { - "name": "Attraction", - "effect": "Si la cible est du sexe opposé, elle tombe amoureuse et rechigne alors à attaquer." - }, - "sleepTalk": { - "name": "Blabla Dodo", - "effect": "Le lanceur utilise une de ses capacités au hasard. Il ne peut utiliser cette capacité que quand il dort." - }, - "healBell": { - "name": "Glas de Soin", - "effect": "Carillon apaisant qui soigne les altérations de statut de tous les Pokémon de l’équipe." - }, - "return": { - "name": "Retour", - "effect": "Plus le Pokémon apprécie son Dresseur, plus la puissance de cette attaque furieuse augmente." - }, - "present": { - "name": "Cadeau", - "effect": "Le lanceur attaque en offrant un cadeau piégé à la cible, mais le cadeau peut parfois restaurer les PV de celle-ci à la place." - }, - "frustration": { - "name": "Frustration", - "effect": "Moins le Pokémon aime son Dresseur, plus cette attaque est puissante." - }, - "safeguard": { - "name": "Rune Protect", - "effect": "Crée un champ protecteur qui empêche toutes les altérations de statut pendant cinq tours." - }, - "painSplit": { - "name": "Balance", - "effect": "Le lanceur ajoute ses PV à ceux de sa cible et les répartit équitablement." - }, - "sacredFire": { - "name": "Feu Sacré", - "effect": "Le lanceur génère un feu mystique d’une intensité redoutable pour attaquer l’ennemi. Peut aussi le bruler (50% de chances)." - }, - "magnitude": { - "name": "Ampleur", - "effect": "Provoque un tremblement de terre d’intensité variable qui affecte tous les Pokémon alentour. L’efficacité varie." - }, - "dynamicPunch": { - "name": "Dynamo-Poing", - "effect": "Le lanceur rassemble ses forces et envoie un coup de poing à la cible, ce qui la rend confuse à coup sûr." - }, - "megahorn": { - "name": "Mégacorne", - "effect": "Le lanceur inflige un grand coup de corne à la cible." - }, - "dragonBreath": { - "name": "Draco-Souffle", - "effect": "Le lanceur souffle fort sur la cible pour lui infliger des dégâts, ce qui peut aussi la paralyser (30% de chances)." - }, - "batonPass": { - "name": "Relais", - "effect": "Le lanceur échange sa place et tout changement de stats avec un Pokémon de l’équipe." - }, - "encore": { - "name": "Encore", - "effect": "Le lanceur oblige la cible à répéter la dernière capacité utilisée durant trois tours." - }, - "pursuit": { - "name": "Poursuite", - "effect": "Une attaque qui inflige deux fois plus de dégâts à un ennemi qui s’apprête à être remplacé." - }, - "rapidSpin": { - "name": "Tour Rapide", - "effect": "Le lanceur attaque en tournant sur lui-même. Sa Vitesse augmente également. Il se libère également des effets de capacités comme Étreinte, Ligotage ou Vampigraine." - }, - "sweetScent": { - "name": "Doux Parfum", - "effect": "Un doux parfum qui réduit beaucoup l’Esquive de la cible." - }, - "ironTail": { - "name": "Queue de Fer", - "effect": "Le lanceur attaque la cible avec une queue de fer, ce qui peut aussi baisser la Défense de la cible." - }, - "metalClaw": { - "name": "Griffe Acier", - "effect": "Attaque avec des griffes d’acier. Peut aussi augmenter l’Attaque du lanceur." - }, - "vitalThrow": { - "name": "Corps Perdu", - "effect": "Le lanceur porte son coup en dernier. En échange, cette capacité n’échoue jamais." - }, - "morningSun": { - "name": "Aurore", - "effect": "Un soin qui restaure des PV au lanceur. Son efficacité varie en fonction de la météo." - }, - "synthesis": { - "name": "Synthèse", - "effect": "Un soin qui restaure des PV au lanceur. Son efficacité varie en fonction de la météo." - }, - "moonlight": { - "name": "Rayon Lune", - "effect": "Un soin qui restaure des PV au lanceur. Son efficacité varie en fonction de la météo." - }, - "hiddenPower": { - "name": "Puissance Cachée", - "effect": "Attaque dont le type dépend du Pokémon qui l’utilise." - }, - "crossChop": { - "name": "Coup Croix", - "effect": "Le lanceur délivre un coup double en croisant les avant-bras. Taux de critiques élevé." - }, - "twister": { - "name": "Ouragan", - "effect": "Le lanceur déclenche un terrible ouragan sur la cible, ce qui peut aussi apeurer celle-ci (20% de chances)." - }, - "rainDance": { - "name": "Danse Pluie", - "effect": "Invoque de fortes pluies qui durent cinq tours, augmentant la puissance des capacités de type Eau et baissant celle des capacités de type Feu." - }, - "sunnyDay": { - "name": "Zénith", - "effect": "Fait briller le soleil pendant cinq tours, augmentant la puissance des capacités de type Feu et baissant celle des capacités de type Eau." - }, - "crunch": { - "name": "Mâchouille", - "effect": "Le lanceur mord la cible de ses crocs pointus, ce qui peut aussi baisser sa Défense." - }, - "mirrorCoat": { - "name": "Voile Miroir", - "effect": "Une riposte qui contre n’importe quelle capacité spéciale en infligeant le double des dégâts subis." - }, - "psychUp": { - "name": "Boost", - "effect": "Une autohypnose qui permet au lanceur de copier les changements de stats de la cible." - }, - "extremeSpeed": { - "name": "Vitesse Extrême", - "effect": "Le lanceur charge à une vitesse renversante. Frappe en priorité." - }, - "ancientPower": { - "name": "Pouvoir Antique", - "effect": "Une attaque préhistorique qui peut augmenter toutes les stats du lanceur d’un seul coup." - }, - "shadowBall": { - "name": "Ball’Ombre", - "effect": "Le lanceur projette une grande ombre sur la cible qui peut aussi faire baisser la Défense Spéciale de celle-ci." - }, - "futureSight": { - "name": "Prescience", - "effect": "De l’énergie psychique vient frapper la cible deux tours après l’utilisation de cette capacité." - }, - "rockSmash": { - "name": "Éclate-Roc", - "effect": "Le lanceur porte un coup de poing à la cible, ce qui peut baisser la Défense de celle-ci." - }, - "whirlpool": { - "name": "Siphon", - "effect": "Le lanceur piège la cible dans une trombe d’eau pendant quatre à cinq tours." - }, - "beatUp": { - "name": "Baston", - "effect": "Le lanceur appelle tous les Pokémon de son équipe à attaquer. Plus ils sont nombreux, plus il y a d’attaques." - }, - "fakeOut": { - "name": "Bluff", - "effect": "Le lanceur frappe en priorité et apeure la cible. La capacité ne fonctionne que si elle est utilisée immédiatement en entrant au combat." - }, - "uproar": { - "name": "Brouhaha", - "effect": "Le lanceur attaque en rugissant durant trois tours. Pendant ce temps, aucun Pokémon ne peut s’endormir." - }, - "stockpile": { - "name": "Stockage", - "effect": "Le lanceur emmagasine de l’énergie et augmente sa Défense et sa Défense Spéciale. Peut être utilisée trois fois." - }, - "spitUp": { - "name": "Relâche", - "effect": "Libère dans une attaque l’énergie précédemment emmagasinée avec Stockage. La puissance augmente en fonction du nombre de fois où Stockage a été utilisée." - }, - "swallow": { - "name": "Avale", - "effect": "Le lanceur absorbe l’énergie emmagasinée avec Stockage pour restaurer ses PV. Le nombre de PV soignés augmente en fonction du nombre de fois où Stockage a été utilisée." - }, - "heatWave": { - "name": "Canicule", - "effect": "Le lanceur provoque une vague de chaleur qui peut aussi bruler la cible (10% de chances)." - }, - "hail": { - "name": "Grêle", - "effect": "Invoque une tempête de grêle qui dure cinq tours. Ne blesse pas les Pokémon de type Glace." - }, - "torment": { - "name": "Tourmente", - "effect": "Le lanceur irrite la cible pour l’empêcher d’utiliser la même capacité deux fois de suite." - }, - "flatter": { - "name": "Flatterie", - "effect": "Rend la cible confuse, mais augmente son Attaque Spéciale." - }, - "willOWisp": { - "name": "Feu Follet", - "effect": "Le lanceur projette des flammes maléfiques à la cible pour lui infliger une brulure." - }, - "memento": { - "name": "Souvenir", - "effect": "Le lanceur est mis K.O., mais l’Attaque et l’Attaque Spéciale de la cible baissent beaucoup." - }, - "facade": { - "name": "Façade", - "effect": "Une capacité dont la puissance double lorsque le lanceur est empoisonné, paralysé ou brulé." - }, - "focusPunch": { - "name": "Mitra-Poing", - "effect": "Le lanceur se concentre avant d’attaquer. Échoue s’il est touché avant d’avoir frappé." - }, - "smellingSalts": { - "name": "Stimulant", - "effect": "Cette attaque est doublement efficace sur les Pokémon paralysés, mais elle soigne leur paralysie." - }, - "followMe": { - "name": "Par Ici", - "effect": "Le lanceur attire l’attention des cibles présentes pour les forcer à n’attaquer que le lanceur." - }, - "naturePower": { - "name": "Force Nature", - "effect": "Une attaque qui tire sa force de la nature. Son type varie selon le terrain." - }, - "charge": { - "name": "Chargeur", - "effect": "Le lanceur se charge en électricité, ce qui augmente la puissance de la prochaine capacité Électrik qu’il utilisera. Sa Défense Spéciale augmente également." - }, - "taunt": { - "name": "Provoc", - "effect": "Le lanceur provoque la cible, ce qui oblige celle-ci à n’utiliser que des capacités qui infligent des dégâts pendant trois tours." - }, - "helpingHand": { - "name": "Coup d’Main", - "effect": "Le lanceur donne un coup de main à son allié, qui voit la puissance de ses capacités augmenter." - }, - "trick": { - "name": "Tour de Magie", - "effect": "Le lanceur prend la cible au dépourvu et l’oblige à échanger son objet contre le sien." - }, - "rolePlay": { - "name": "Imitation", - "effect": "Imite la cible et copie son talent." - }, - "wish": { - "name": "Vœu", - "effect": "Un vœu qui permet au lanceur ou au Pokémon entrant sur le terrain au tour suivant de récupérer la moitié des PV max du lanceur." - }, - "assist": { - "name": "Assistance", - "effect": "Le lanceur se dépêche d’utiliser une capacité au hasard parmi celles des Pokémon de l’équipe." - }, - "ingrain": { - "name": "Racines", - "effect": "Le lanceur plante ses racines et récupère des PV à chaque tour. Une fois enraciné, il ne peut plus fuir." - }, - "superpower": { - "name": "Surpuissance", - "effect": "Une attaque puissante, mais qui baisse l’Attaque et la Défense du lanceur." - }, - "magicCoat": { - "name": "Reflet Magik", - "effect": "Une barrière qui renvoie les capacités comme Vampigraine et celles affectant le statut et les stats." - }, - "recycle": { - "name": "Recyclage", - "effect": "Recycle un objet tenu à usage unique déjà utilisé lors du combat pour pouvoir l’utiliser à nouveau." - }, - "revenge": { - "name": "Vendetta", - "effect": "Une attaque deux fois plus puissante si le lanceur a été blessé par l’ennemi durant ce tour." - }, - "brickBreak": { - "name": "Casse-Brique", - "effect": "Le lanceur attaque avec le tranchant de la main. Permet aussi de briser les barrières comme Mur Lumière et Protection." - }, - "yawn": { - "name": "Bâillement", - "effect": "Le lanceur fait bâiller la cible, qui s’endort au tour suivant." - }, - "knockOff": { - "name": "Sabotage", - "effect": "Fait plus de dégâts aux cibles qui tiennent un objet. De plus, fait tomber cet objet et empêche la cible de l’utiliser jusqu’à la fin du combat." - }, - "endeavor": { - "name": "Effort", - "effect": "Une attaque qui réduit les PV de la cible au niveau des PV du lanceur." - }, - "eruption": { - "name": "Éruption", - "effect": "Le lanceur laisse exploser sa colère. Plus ses PV sont bas, moins l’attaque est puissante." - }, - "skillSwap": { - "name": "Échange", - "effect": "Le lanceur utilise ses pouvoirs psychiques pour échanger son talent avec la cible." - }, - "imprison": { - "name": "Possessif", - "effect": "Si la cible et le lanceur ont des capacités en commun, la cible ne pourra pas les utiliser." - }, - "refresh": { - "name": "Régénération", - "effect": "Le lanceur se repose pour guérir d’un empoisonnement, d’une brulure ou d’une paralysie." - }, - "grudge": { - "name": "Rancune", - "effect": "Si le lanceur est mis K.O., sa rancune épuise les PP de la capacité utilisée par l’ennemi pour le mettre K.O." - }, - "snatch": { - "name": "Saisie", - "effect": "Lorsqu’une capacité de soin ou de changement de stats est utilisée, le lanceur vole ses effets." - }, - "secretPower": { - "name": "Force Cachée", - "effect": "Les effets de cette attaque varient en fonction de l’environnement." - }, - "dive": { - "name": "Plongée", - "effect": "Le lanceur plonge sous l’eau au premier tour et frappe au second." - }, - "armThrust": { - "name": "Cogne", - "effect": "Un déluge de coups adressés avec la paume qui frappe de deux à cinq fois d’affilée." - }, - "camouflage": { - "name": "Camouflage", - "effect": "Modifie le type du lanceur en fonction du terrain, comme une berge, une grotte, l’herbe, etc." - }, - "tailGlow": { - "name": "Lumi-Queue", - "effect": "Le lanceur regarde un flash lumineux fixement. Augmente énormément son Attaque Spéciale." - }, - "lusterPurge": { - "name": "Lumi-Éclat", - "effect": "Le lanceur libère un éclair lumineux. Peut aussi baisser la Défense Spéciale de l’ennemi." - }, - "mistBall": { - "name": "Ball’Brume", - "effect": "Une bulle de brume inflige des dégâts à l’ennemi. Peut aussi réduire son Attaque Spéciale." - }, - "featherDance": { - "name": "Danse Plumes", - "effect": "Une montagne de plumes ensevelit la cible et réduit beaucoup son Attaque." - }, - "teeterDance": { - "name": "Danse Folle", - "effect": "Danse qui rend confus tous les Pokémon autour du lanceur." - }, - "blazeKick": { - "name": "Pied Bruleur", - "effect": "Le lanceur envoie un coup de pied au taux de critiques élevé. Peut aussi bruler la cible (10% de chances)." - }, - "mudSport": { - "name": "Lance-Boue", - "effect": "Asperge les alentours de boue. Affaiblit les capacités Électrik pendant cinq tours." - }, - "iceBall": { - "name": "Ball’Glace", - "effect": "Frappe l’ennemi pendant cinq tours. L’attaque gagne en puissance à chaque coup." - }, - "needleArm": { - "name": "Poing Dard", - "effect": "Le lanceur attaque en fouettant l’ennemi de ses bras épineux. Peut aussi l’apeurer (30% de chances)." - }, - "slackOff": { - "name": "Paresse", - "effect": "Le lanceur se tourne les pouces et récupère jusqu’à la moitié de ses PV max." - }, - "hyperVoice": { - "name": "Mégaphone", - "effect": "Le lanceur pousse un cri dont l’écho terrifiant a le pouvoir d’infliger des dégâts à la cible." - }, - "poisonFang": { - "name": "Crochet Venin", - "effect": "Le lanceur mord la cible avec ses crocs toxiques, ce qui peut aussi l’empoisonner gravement (50% de chances)." - }, - "crushClaw": { - "name": "Éclate Griffe", - "effect": "Le lanceur lacère la cible avec des griffes solides et aiguisées, ce qui peut aussi baisser la Défense de celle-ci." - }, - "blastBurn": { - "name": "Rafale Feu", - "effect": "Une explosion ardente consume la cible. Le lanceur doit se reposer au tour suivant." - }, - "hydroCannon": { - "name": "Hydroblast", - "effect": "Le lanceur projette un missile d’eau sur la cible, mais il doit se reposer au tour suivant." - }, - "meteorMash": { - "name": "Poing Météore", - "effect": "Un coup de poing lancé à la vitesse d’un météore. Peut aussi augmenter l’Attaque du lanceur." - }, - "astonish": { - "name": "Étonnement", - "effect": "Le lanceur attaque la cible en poussant un cri terrifiant qui peut aussi l’apeurer (30% de chances)." - }, - "weatherBall": { - "name": "Ball’Météo", - "effect": "Une capacité dont la puissance et le type varient en fonction du temps qu’il fait." - }, - "aromatherapy": { - "name": "Aromathérapie", - "effect": "Le lanceur libère un parfum apaisant qui guérit tous les problèmes de statut de l’équipe." - }, - "fakeTears": { - "name": "Croco Larme", - "effect": "Le lanceur fait semblant de pleurer pour troubler la cible et beaucoup baisser sa Défense Spéciale." - }, - "airCutter": { - "name": "Tranch’Air", - "effect": "Le lanceur appelle des vents tranchants qui lacèrent la cible. Taux de critiques élevé." - }, - "overheat": { - "name": "Surchauffe", - "effect": "Le lanceur attaque la cible à pleine puissance, mais le contrecoup baisse beaucoup l’Attaque Spéciale du lanceur." - }, - "odorSleuth": { - "name": "Flair", - "effect": "Permet de toucher un Pokémon Spectre avec n’importe quelle capacité ou de toucher un ennemi insaisissable." - }, - "rockTomb": { - "name": "Tomberoche", - "effect": "Des rochers frappent la cible et baissent sa Vitesse." - }, - "silverWind": { - "name": "Vent Argenté", - "effect": "Vent qui projette des écailles poudreuses sur l’ennemi. Peut aussi monter toutes les stats du lanceur." - }, - "metalSound": { - "name": "Strido-Son", - "effect": "Un cri horrible tel un crissement métallique qui réduit beaucoup la Défense Spéciale de la cible." - }, - "grassWhistle": { - "name": "Siffl’Herbe", - "effect": "Le lanceur joue une douce mélodie qui plonge l’ennemi dans un profond sommeil." - }, - "tickle": { - "name": "Chatouille", - "effect": "Le lanceur chatouille la cible, ce qui baisse son Attaque et sa Défense." - }, - "cosmicPower": { - "name": "Force Cosmique", - "effect": "Le lanceur absorbe un pouvoir mystique spatial qui augmente sa Défense et sa Défense Spéciale." - }, - "waterSpout": { - "name": "Giclédo", - "effect": "Le lanceur attaque avec un jet d’eau. Moins il a de PV et moins l’attaque est puissante." - }, - "signalBeam": { - "name": "Rayon Signal", - "effect": "Le lanceur projette un rayon de lumière sinistre. Peut aussi rendre l’ennemi confus." - }, - "shadowPunch": { - "name": "Poing Ombre", - "effect": "Le lanceur se fond dans les ombres pour porter un coup de poing. N’échoue jamais." - }, - "extrasensory": { - "name": "Extrasenseur", - "effect": "Le lanceur attaque avec un pouvoir étrange et invisible qui peut aussi apeurer la cible (10% de chances)." - }, - "skyUppercut": { - "name": "Stratopercut", - "effect": "Le lanceur attaque avec un uppercut. Il envoie son poing vers le ciel de toutes ses forces." - }, - "sandTomb": { - "name": "Tourbi-Sable", - "effect": "Le lanceur emprisonne la cible dans une tempête de sable terrifiante qui dure de quatre à cinq tours." - }, - "sheerCold": { - "name": "Glaciation", - "effect": "Une vague de froid glacial frappe la cible pour la mettre K.O. en un coup. Cela a peu de chances de réussir si le lanceur ne possède pas le type Glace." - }, - "muddyWater": { - "name": "Ocroupi", - "effect": "Le lanceur attaque en projetant de l’eau boueuse. Peut aussi réduire la Précision de la cible." - }, - "bulletSeed": { - "name": "Balle Graine", - "effect": "Le lanceur mitraille la cible avec une rafale de graines. De deux à cinq rafales sont lancées à la suite." - }, - "aerialAce": { - "name": "Aéropique", - "effect": "Le lanceur prend la cible de vitesse et la lacère. N’échoue jamais." - }, - "icicleSpear": { - "name": "Stalactite", - "effect": "Le lanceur jette des pics de glace sur la cible, de deux à cinq fois de suite." - }, - "ironDefense": { - "name": "Mur de Fer", - "effect": "L’épiderme du lanceur devient dur comme du fer, ce qui augmente beaucoup sa Défense." - }, - "block": { - "name": "Barrage", - "effect": "Le lanceur bloque la route de la cible pour empêcher sa fuite." - }, - "howl": { - "name": "Grondement", - "effect": "Le lanceur pousse un grand cri d’encouragement, ce qui augmente son Attaque et celle de ses alliés." - }, - "dragonClaw": { - "name": "Draco-Griffe", - "effect": "Le lanceur lacère la cible de ses grandes griffes aiguisées." - }, - "frenzyPlant": { - "name": "Végé-Attaque", - "effect": "Un violent coup de racines s’abat sur la cible. Le lanceur doit se reposer au tour suivant." - }, - "bulkUp": { - "name": "Gonflette", - "effect": "Le lanceur tend ses muscles pour se gonfler, ce qui booste son Attaque et sa Défense." - }, - "bounce": { - "name": "Rebond", - "effect": "Le lanceur bondit très haut et plonge sur la cible au second tour, ce qui peut aussi la paralyser (30% de chances)." - }, - "mudShot": { - "name": "Tir de Boue", - "effect": "Le lanceur attaque en projetant de la boue sur la cible, ce qui réduit aussi la Vitesse de celle-ci." - }, - "poisonTail": { - "name": "Queue-Poison", - "effect": "Le lanceur attaque la cible avec sa queue, ce qui peut aussi l’empoisonner (10% de chances). Taux de critiques élevés." - }, - "covet": { - "name": "Implore", - "effect": "Le lanceur s’approche de la cible avec un air angélique afin de dérober l’objet qu’elle tient." - }, - "voltTackle": { - "name": "Électacle", - "effect": "Le lanceur électrifie son corps avant de charger. Le choc blesse aussi gravement le lanceur et peut paralyser la cible (10% de chances)." - }, - "magicalLeaf": { - "name": "Feuille Magik", - "effect": "Le lanceur disperse d’étranges feuilles qui poursuivent la cible. N’échoue jamais." - }, - "waterSport": { - "name": "Tourniquet", - "effect": "Asperge d’eau les alentours. Affaiblit les capacités de type Feu pendant cinq tours." - }, - "calmMind": { - "name": "Plénitude", - "effect": "Le lanceur se concentre et fait le vide dans son esprit pour augmenter son Attaque Spéciale et sa Défense Spéciale." - }, - "leafBlade": { - "name": "Lame Feuille", - "effect": "Une feuille coupante comme une lame entaille la cible. Taux de critiques élevé." - }, - "dragonDance": { - "name": "Danse Draco", - "effect": "Une danse mystique dont le rythme effréné augmente l’Attaque et la Vitesse du lanceur." - }, - "rockBlast": { - "name": "Boule Roc", - "effect": "Le lanceur projette un rocher sur la cible de deux à cinq fois d’affilée." - }, - "shockWave": { - "name": "Onde de Choc", - "effect": "Le lanceur envoie un choc électrique rapide à la cible. N’échoue jamais." - }, - "waterPulse": { - "name": "Vibraqua", - "effect": "Le lanceur projette une aura aquatique sur la cible, et peut la rendre confuse." - }, - "doomDesire": { - "name": "Vœu Destructeur", - "effect": "Le lanceur génère une sphère lumineuse qu’il projette sur l’ennemi deux tours plus tard." - }, - "psychoBoost": { - "name": "Psycho-Boost", - "effect": "Attaque l’ennemi à pleine puissance. Le contrecoup baisse beaucoup l’Attaque Spéciale du lanceur." - }, - "roost": { - "name": "Atterrissage", - "effect": "Le lanceur atterrit et se repose. Restaure jusqu’à la moitié de ses PV max." - }, - "gravity": { - "name": "Gravité", - "effect": "Pendant cinq tours, les Pokémon Vol ou qui ont Lévitation deviennent sensibles aux capacités Sol, et les capacités volantes deviennent inutilisables." - }, - "miracleEye": { - "name": "Œil Miracle", - "effect": "Permet de toucher un Pokémon Ténèbres avec les capacités de type Psy ou de toucher un ennemi ayant beaucoup d’esquive." - }, - "wakeUpSlap": { - "name": "Réveil Forcé", - "effect": "Cette attaque inflige d’importants dégâts à un Pokémon endormi. Mais elle le réveille également." - }, - "hammerArm": { - "name": "Marto-Poing", - "effect": "Le lanceur donne un puissant coup de poing à la cible, ce qui réduit la Vitesse du lanceur." - }, - "gyroBall": { - "name": "Gyroballe", - "effect": "Le lanceur effectue une rotation rapide et frappe la cible. Plus la Vitesse du lanceur est basse par rapport à celle de la cible, plus il inflige de dégâts." - }, - "healingWish": { - "name": "Vœu Soin", - "effect": "Le lanceur tombe K.O. pour soigner les altérations de statut et les PV du Pokémon qui viendra le remplacer sur le terrain." - }, - "brine": { - "name": "Saumure", - "effect": "La puissance de cette capacité est doublée lorsque la cible a moins de la moitié de ses PV." - }, - "naturalGift": { - "name": "Don Naturel", - "effect": "Avant d’attaquer, le lanceur rassemble ses forces grâce à sa Baie. Elle détermine le type et la puissance de l’attaque." - }, - "feint": { - "name": "Ruse", - "effect": "Une attaque capable de toucher une cible qui utilise une capacité similaire à Détection ou Abri, et annule l’effet de cette capacité." - }, - "pluck": { - "name": "Picore", - "effect": "Le lanceur picore la cible. Si cette dernière tient une Baie, le lanceur la mange et profite de ses effets." - }, - "tailwind": { - "name": "Vent Arrière", - "effect": "Génère une rafale de vent qui augmente la Vitesse des Pokémon de l’équipe pendant quatre tours." - }, - "acupressure": { - "name": "Acupression", - "effect": "Le lanceur utilise sa connaissance des points de pression pour beaucoup augmenter une stat." - }, - "metalBurst": { - "name": "Fulmifer", - "effect": "Le lanceur contre-attaque avec un coup infligeant des dégâts supérieurs à ceux de la dernière capacité qui l’a blessé." - }, - "uTurn": { - "name": "Demi-Tour", - "effect": "Après son attaque, le lanceur revient à toute vitesse et change de place avec un Pokémon de l’équipe prêt à combattre." - }, - "closeCombat": { - "name": "Close Combat", - "effect": "Le lanceur ne pense plus à se protéger et frappe sa cible violemment au corps à corps. Cette capacité baisse la Défense et la Défense Spéciale du lanceur." - }, - "payback": { - "name": "Représailles", - "effect": "Le lanceur charge son énergie, puis attaque. La puissance de la capacité est doublée si le lanceur agit après la cible." - }, - "assurance": { - "name": "Assurance", - "effect": "La puissance de cette capacité est deux fois plus élevée si la cible a déjà été blessée durant ce tour." - }, - "embargo": { - "name": "Embargo", - "effect": "Empêche la cible d’utiliser un objet tenu et son Dresseur d’utiliser un objet sur lui pendant cinq tours." - }, - "fling": { - "name": "Dégommage", - "effect": "Le lanceur envoie l’objet qu’il tient sur la cible. La puissance et les effets dépendent de l’objet." - }, - "psychoShift": { - "name": "Échange Psy", - "effect": "Le lanceur transfère ses problèmes de statut à l’ennemi grâce à son pouvoir de suggestion." - }, - "trumpCard": { - "name": "Atout", - "effect": "Moins cette capacité possède de PP, plus elle est puissante." - }, - "healBlock": { - "name": "Anti-Soin", - "effect": "Le lanceur empêche l’ennemi de récupérer des PV à l’aide de capacités, talents ou objets tenus, pendant cinq tours." - }, - "wringOut": { - "name": "Essorage", - "effect": "Le lanceur essore l’ennemi. Plus l’ennemi a de PV, plus cette attaque est puissante." - }, - "powerTrick": { - "name": "Astuce Force", - "effect": "Le lanceur utilise ses pouvoirs psychiques pour échanger sa Défense et son Attaque." - }, - "gastroAcid": { - "name": "Suc Digestif", - "effect": "Le lanceur répand ses sucs digestifs sur la cible. Le fluide neutralise le talent de celle-ci." - }, - "luckyChant": { - "name": "Air Veinard", - "effect": "Le lanceur envoie une incantation vers le ciel et protège l’équipe des coups critiques pendant cinq tours." - }, - "meFirst": { - "name": "Moi d’Abord", - "effect": "Le lanceur vole la capacité prévue par l’ennemi et l’utilise en faisant plus de dégâts. Il doit frapper en premier." - }, - "copycat": { - "name": "Photocopie", - "effect": "Le lanceur imite la dernière capacité employée. Échoue si aucune capacité n’a été utilisée." - }, - "powerSwap": { - "name": "Permuforce", - "effect": "Le lanceur utilise un pouvoir psychique qui échange les changements de son Attaque et de son Attaque Spéciale avec celles de la cible." - }, - "guardSwap": { - "name": "Permugarde", - "effect": "Le lanceur utilise un pouvoir psychique qui échange les changements de sa Défense et de sa Défense Spéciale avec celles de la cible." - }, - "punishment": { - "name": "Punition", - "effect": "Plus l’ennemi a utilisé d’augmentations de stats et plus cette capacité est puissante." - }, - "lastResort": { - "name": "Dernier Recours", - "effect": "Cette capacité ne peut être utilisée qu’après que le lanceur a utilisé toutes les autres." - }, - "worrySeed": { - "name": "Soucigraine", - "effect": "Plante sur la cible une graine qui la rend soucieuse et remplace son talent par Insomnia, l’empêchant ainsi de dormir." - }, - "suckerPunch": { - "name": "Coup Bas", - "effect": "Permet au lanceur de frapper en priorité. Échoue si la cible ne prépare pas une attaque." - }, - "toxicSpikes": { - "name": "Pics Toxik", - "effect": "Le lanceur éparpille des pics autour de la cible, ce qui empoisonne les Pokémon entrant au combat de ce côté." - }, - "heartSwap": { - "name": "Permucœur", - "effect": "Le lanceur utilise un pouvoir psychique pour échanger ses changements de stats avec la cible." - }, - "aquaRing": { - "name": "Anneau Hydro", - "effect": "Un voile d’eau recouvre le lanceur et régénère ses PV à chaque tour." - }, - "magnetRise": { - "name": "Vol Magnétik", - "effect": "Le lanceur utilise l’électricité pour générer un champ magnétique et léviter durant cinq tours." - }, - "flareBlitz": { - "name": "Boutefeu", - "effect": "Le lanceur s’embrase avant de charger la cible, ce qui peut la bruler (10% de chances). Le choc blesse aussi gravement le lanceur." - }, - "forcePalm": { - "name": "Forte-Paume", - "effect": "Une onde de choc frappe la cible, ce qui peut aussi la paralyser (30% de chances)." - }, - "auraSphere": { - "name": "Aurasphère", - "effect": "Le lanceur puise au fond de lui-même pour dégager une aura et projeter de l’énergie sur la cible. N’échoue jamais." - }, - "rockPolish": { - "name": "Poliroche", - "effect": "Le lanceur polit son corps pour diminuer sa résistance au vent. Augmente beaucoup la Vitesse." - }, - "poisonJab": { - "name": "Direct Toxik", - "effect": "Le lanceur attaque la cible avec un tentacule, un bras, ou un autre membre imprégné de poison, ce qui peut aussi empoisonner la cible (30% de chances)." - }, - "darkPulse": { - "name": "Vibrobscur", - "effect": "Le lanceur projette une horrible aura chargée de pensées maléfiques, ce qui peut aussi apeurer la cible." - }, - "nightSlash": { - "name": "Tranche-Nuit", - "effect": "Le lanceur lacère la cible à la première occasion. Taux de critiques élevé." - }, - "aquaTail": { - "name": "Hydro-Queue", - "effect": "Le lanceur attaque en balançant sa queue comme une lame de fond en pleine tempête." - }, - "seedBomb": { - "name": "Canon Graine", - "effect": "Le lanceur déclenche un déluge de grosses graines à la coque solide sur la cible." - }, - "airSlash": { - "name": "Lame d’Air", - "effect": "Le lanceur attaque avec une lame d’air capable de fendre le ciel, ce qui peut aussi apeurer la cible (30% de chances)." - }, - "xScissor": { - "name": "Plaie Croix", - "effect": "Le lanceur taillade la cible en utilisant ses faux ou ses griffes comme une paire de ciseaux." - }, - "bugBuzz": { - "name": "Bourdon", - "effect": "Le lanceur fait vibrer son corps pour lancer une vague sonique, ce qui peut aussi baisser la Défense Spéciale de la cible." - }, - "dragonPulse": { - "name": "Draco-Choc", - "effect": "Le lanceur ouvre la bouche pour projeter une aura qui frappe la cible." - }, - "dragonRush": { - "name": "Draco-Charge", - "effect": "Le lanceur frappe la cible en prenant un air menaçant, ce qui peut aussi l’apeurer (20% de chances)." - }, - "powerGem": { - "name": "Rayon Gemme", - "effect": "Le lanceur attaque avec un rayon de lumière qui scintille comme s’il était composé de gemmes." - }, - "drainPunch": { - "name": "Vampi-Poing", - "effect": "Un coup de poing qui draine l’énergie. Convertit la moitié des dégâts infligés en PV pour le lanceur." - }, - "vacuumWave": { - "name": "Onde Vide", - "effect": "Le lanceur agite son poing pour projeter une onde de vide. Frappe en priorité." - }, - "focusBlast": { - "name": "Exploforce", - "effect": "Le lanceur rassemble ses forces et laisse éclater son pouvoir, ce qui peut aussi baisser la Défense Spéciale de la cible." - }, - "energyBall": { - "name": "Éco-Sphère", - "effect": "Le lanceur utilise les pouvoirs de la nature pour attaquer la cible, ce qui peut aussi baisser la Défense Spéciale de celle-ci." - }, - "braveBird": { - "name": "Rapace", - "effect": "Le lanceur replie ses ailes et charge en rase-mottes. Blesse gravement le lanceur." - }, - "earthPower": { - "name": "Telluriforce", - "effect": "De terribles séismes secouent la cible et peuvent aussi baisser sa Défense Spéciale." - }, - "switcheroo": { - "name": "Passe-Passe", - "effect": "Le lanceur échange son objet avec celui de la cible à une vitesse que l’œil a du mal à suivre." - }, - "gigaImpact": { - "name": "Giga Impact", - "effect": "Le lanceur charge la cible de toute ses forces et doit ensuite se reposer au tour suivant." - }, - "nastyPlot": { - "name": "Machination", - "effect": "Stimule l’esprit par de mauvaises pensées. Augmente beaucoup l’Attaque Spéciale du lanceur." - }, - "bulletPunch": { - "name": "Pisto-Poing", - "effect": "Le lanceur envoie des coups de poing aussi rapides que des balles de revolver. Frappe en priorité." - }, - "avalanche": { - "name": "Avalanche", - "effect": "Une capacité dont la puissance est doublée si le lanceur a été blessé par la cible durant ce tour." - }, - "iceShard": { - "name": "Éclats Glace", - "effect": "Le lanceur crée des éclats de glace qu’il envoie sur la cible. Frappe en priorité." - }, - "shadowClaw": { - "name": "Griffe Ombre", - "effect": "Attaque avec une griffe puissante faite d’ombres. Taux de critiques élevé." - }, - "thunderFang": { - "name": "Crocs Éclair", - "effect": "Le lanceur utilise une morsure électrifiée qui peut aussi paralyser (10% de chances) ou apeurer la cible (10% de chances)." - }, - "iceFang": { - "name": "Crocs Givre", - "effect": "Le lanceur utilise une morsure glaciale qui peut aussi geler (10% de chances) ou apeurer la cible (10% de chances)." - }, - "fireFang": { - "name": "Crocs Feu", - "effect": "Le lanceur utilise une morsure enflammée qui peut aussi bruler (10% de chances) ou apeurer (10% de chances) la cible." - }, - "shadowSneak": { - "name": "Ombre Portée", - "effect": "Le lanceur étend son ombre pour frapper par-derrière. Frappe en priorité." - }, - "mudBomb": { - "name": "Boue-Bombe", - "effect": "Le lanceur attaque à l’aide d’une boule de boue solidifiée. Peut aussi baisser la Précision de l’ennemi." - }, - "psychoCut": { - "name": "Coupe Psycho", - "effect": "Le lanceur entaille la cible grâce à des lames faites d’énergie psychique. Taux de critiques élevé." - }, - "zenHeadbutt": { - "name": "Psykoud’Boul", - "effect": "Le lanceur concentre sa volonté et donne un coup de tête à la cible, ce qui peut aussi apeurer celle-ci (20% de chances)." - }, - "mirrorShot": { - "name": "Miroi-Tir", - "effect": "Le corps poli du lanceur libère un éclair d’énergie. Peut aussi baisser la Précision de l’ennemi." - }, - "flashCannon": { - "name": "Luminocanon", - "effect": "Le lanceur concentre son énergie lumineuse et la fait exploser, ce qui peut aussi baisser la Défense Spéciale de la cible." - }, - "rockClimb": { - "name": "Escalade", - "effect": "Le lanceur se jette violemment sur l’ennemi. Peut aussi le rendre confus." - }, - "defog": { - "name": "Anti-Brume", - "effect": "Un grand coup de vent disperse Protection ou Mur Lumière de la cible et diminue également son Esquive." - }, - "trickRoom": { - "name": "Distorsion", - "effect": "Le lanceur crée une zone mystérieuse où les Pokémon les plus lents frappent en priorité pendant cinq tours." - }, - "dracoMeteor": { - "name": "Draco-Météore", - "effect": "Le lanceur invoque des comètes. Le contrecoup réduit beaucoup son Attaque Spéciale." - }, - "discharge": { - "name": "Coup d’Jus", - "effect": "Un flamboiement d’électricité frappe tous les Pokémon autour du lanceur. Peut aussi les paralyser (30% de chances)." - }, - "lavaPlume": { - "name": "Ébullilave", - "effect": "Des flammes s’abattent sur tous les Pokémon autour du lanceur, ce qui peut aussi les bruler (10% de chances)." - }, - "leafStorm": { - "name": "Tempête Verte", - "effect": "Invoque une tempête de feuilles acérées. Le contrecoup réduit beaucoup l’Attaque Spéciale du lanceur." - }, - "powerWhip": { - "name": "Mégafouet", - "effect": "Le lanceur fait virevolter violemment ses lianes ou ses tentacules pour fouetter la cible." - }, - "rockWrecker": { - "name": "Roc-Boulet", - "effect": "Le lanceur attaque en projetant un gros rocher sur l’ennemi. Il doit se reposer au tour suivant." - }, - "crossPoison": { - "name": "Poison Croix", - "effect": "Un coup tranchant qui peut empoisonner la cible (10% de chances). Taux de critiques élevé." - }, - "gunkShot": { - "name": "Détricanon", - "effect": "Le lanceur envoie des détritus sur la cible, ce qui peut aussi l’empoisonner (30% de chances)." - }, - "ironHead": { - "name": "Tête de Fer", - "effect": "Le lanceur heurte la cible avec sa tête dure comme de l’acier, ce qui peut aussi l’apeurer (30% de chances)." - }, - "magnetBomb": { - "name": "Bombe Aimant", - "effect": "Le lanceur projette des bombes d’acier qui collent à l’ennemi. N’échoue jamais." - }, - "stoneEdge": { - "name": "Lame de Roc", - "effect": "Le lanceur transperce la cible avec des rochers aiguisés. Taux de critiques élevé." - }, - "captivate": { - "name": "Séduction", - "effect": "Si l’ennemi est de sexe opposé au lanceur, il est séduit et son Attaque Spéciale baisse beaucoup." - }, - "stealthRock": { - "name": "Piège de Roc", - "effect": "Le lanceur fait flotter des pierres autour de la cible qui blessent tout adversaire entrant au combat." - }, - "grassKnot": { - "name": "Nœud Herbe", - "effect": "Le lanceur fait des nœuds dans l’herbe pour faire trébucher la cible. Plus la cible est lourde, plus la puissance de cette capacité augmente." - }, - "chatter": { - "name": "Babil", - "effect": "Attaque avec les ondes sonores assourdissantes qu’il émet en bavardant. Rend l’ennemi confus." - }, - "judgment": { - "name": "Jugement", - "effect": "Le lanceur libère une myriade de rayons de lumière. Le type varie selon la plaque que tient le lanceur." - }, - "bugBite": { - "name": "Piqure", - "effect": "Le lanceur pique la cible. Si celle-ci tient une Baie, le lanceur la dévore et obtient son effet." - }, - "chargeBeam": { - "name": "Rayon Chargé", - "effect": "Le lanceur tire un rayon chargé d’électricité. Peut aussi augmenter son Attaque Spéciale." - }, - "woodHammer": { - "name": "Martobois", - "effect": "Le lanceur heurte la cible de son corps robuste, ce qui blesse aussi gravement le lanceur." - }, - "aquaJet": { - "name": "Aqua-Jet", - "effect": "Le lanceur fonce sur la cible si rapidement qu’on parvient à peine à le discerner. Frappe en priorité." - }, - "attackOrder": { - "name": "Appel Attaque", - "effect": "Le lanceur appelle ses subalternes pour frapper la cible. Taux de critiques élevé." - }, - "defendOrder": { - "name": "Appel Défense", - "effect": "Le lanceur appelle ses subalternes pour former un bouclier qui augmente sa Défense et sa Défense Spéciale." - }, - "healOrder": { - "name": "Appel Soins", - "effect": "Le lanceur appelle ses sous-fifres pour le soigner. Il récupère jusqu’à la moitié de ses PV max." - }, - "headSmash": { - "name": "Fracass’Tête", - "effect": "Le lanceur assène un coup de tête désespéré, ce qui le blesse aussi très gravement." - }, - "doubleHit": { - "name": "Coup Double", - "effect": "Le lanceur frappe la cible deux fois d’affilée à l’aide de sa queue ou d’un autre membre." - }, - "roarOfTime": { - "name": "Hurle-Temps", - "effect": "Le lanceur frappe si fort qu’il affecte le cours du temps. Il se repose au tour suivant." - }, - "spacialRend": { - "name": "Spatio-Rift", - "effect": "Le lanceur déchire la cible et l’espace autour de lui. Taux de critiques élevé." - }, - "lunarDance": { - "name": "Danse Lune", - "effect": "Le lanceur tombe K.O. pour soigner totalement le Pokémon qui prendra sa place au combat." - }, - "crushGrip": { - "name": "Presse", - "effect": "Une force puissante écrase l’ennemi. Plus il lui reste de PV et plus l’attaque est puissante." - }, - "magmaStorm": { - "name": "Vortex Magma", - "effect": "La cible est prise dans un tourbillon de feu qui dure de quatre à cinq tours." - }, - "darkVoid": { - "name": "Trou Noir", - "effect": "L’ennemi est plongé dans les ténèbres. Il tombe dans un profond sommeil." - }, - "seedFlare": { - "name": "Fulmigraine", - "effect": "Le corps du lanceur émet une onde de choc. Peut aussi beaucoup baisser la Défense Spéciale de la cible." - }, - "ominousWind": { - "name": "Vent Mauvais", - "effect": "Le lanceur crée une violente bourrasque. Peut aussi augmenter toutes ses stats." - }, - "shadowForce": { - "name": "Revenant", - "effect": "Le lanceur disparait au premier tour et frappe la cible au deuxième. Cette capacité fonctionne même si la cible se protège." - }, - "honeClaws": { - "name": "Aiguisage", - "effect": "Le lanceur s’aiguise les griffes. Augmente l’Attaque et la Précision." - }, - "wideGuard": { - "name": "Garde Large", - "effect": "Bloque les attaques visant tous les alliés pendant un tour." - }, - "guardSplit": { - "name": "Partage Garde", - "effect": "Additionne la Défense et la Défense Spéciale du lanceur et de sa cible et les redistribue équitablement entre les deux." - }, - "powerSplit": { - "name": "Partage Force", - "effect": "Additionne l’Attaque Spéciale et l’Attaque du lanceur et de sa cible et les redistribue équitablement entre les deux." - }, - "wonderRoom": { - "name": "Zone Étrange", - "effect": "Le lanceur crée une zone mystérieuse où la Défense et la Défense Spéciale de tous les Pokémon sont inversées pendant cinq tours." - }, - "psyshock": { - "name": "Choc Psy", - "effect": "Le lanceur matérialise des ondes mystérieuses qu’il projette sur la cible, ce qui inflige des dégâts physiques à celle-ci." - }, - "venoshock": { - "name": "Choc Venin", - "effect": "Le lanceur asperge la cible d’un poison spécial. La puissance de la capacité est doublée si la cible est empoisonnée." - }, - "autotomize": { - "name": "Allègement", - "effect": "Le lanceur se débarrasse des parties inutiles de son corps. Son poids diminue et sa Vitesse augmente beaucoup." - }, - "ragePowder": { - "name": "Poudre Fureur", - "effect": "Le lanceur s’asperge d’une poudre irritante pour attirer l’attention et diriger toutes les attaques ennemies sur lui." - }, - "telekinesis": { - "name": "Lévikinésie", - "effect": "Un pouvoir qui fait flotter l’ennemi dans les airs. Pendant trois tours, il devient plus facile à atteindre." - }, - "magicRoom": { - "name": "Zone Magique", - "effect": "Le lanceur crée une zone mystérieuse où les objets tenus par tous les Pokémon n’ont plus aucun effet pendant cinq tours." - }, - "smackDown": { - "name": "Anti-Air", - "effect": "Le lanceur jette un projectile sur la cible. Si cette dernière vole, elle tombe au sol." - }, - "stormThrow": { - "name": "Yama Arashi", - "effect": "Un coup très puissant dont l’effet est toujours critique." - }, - "flameBurst": { - "name": "Rebondifeu", - "effect": "Quand l’attaque atteint sa cible, elle projette des flammes qui touchent tout ennemi situé à côté." - }, - "sludgeWave": { - "name": "Cradovague", - "effect": "Une vague de détritus attaque tous les Pokémon autour du lanceur. Peut aussi empoisonner (10% de chances)." - }, - "quiverDance": { - "name": "Papillodanse", - "effect": "Une danse mystique dont le rythme parfait augmente l’Attaque Spéciale, la Défense Spéciale et la Vitesse du lanceur." - }, - "heavySlam": { - "name": "Tacle Lourd", - "effect": "Le lanceur se jette sur la cible de tout son poids. Plus il est lourd par rapport à la cible, plus la puissance de cette capacité augmente." - }, - "synchronoise": { - "name": "Synchropeine", - "effect": "Des ondes mystérieuses blessent tous les Pokémon alentour qui sont du même type que le lanceur." - }, - "electroBall": { - "name": "Boule Élek", - "effect": "Le lanceur envoie une boule d’électricité. Plus la Vitesse du lanceur est élevée par rapport à celle de la cible, plus la puissance de la capacité augmente." - }, - "soak": { - "name": "Détrempage", - "effect": "Le lanceur projette beaucoup d’eau sur sa cible, qui devient de type Eau." - }, - "flameCharge": { - "name": "Nitrocharge", - "effect": "Le lanceur s’entoure de flammes pour attaquer la cible. Il se concentre et sa Vitesse augmente." - }, - "coil": { - "name": "Enroulement", - "effect": "Le lanceur s’enroule sur lui-même et se concentre. Son Attaque, sa Défense et sa Précision augmentent." - }, - "lowSweep": { - "name": "Balayette", - "effect": "Un coup rapide qui affecte la mobilité de la cible et diminue sa Vitesse." - }, - "acidSpray": { - "name": "Bombe Acide", - "effect": "Le lanceur projette un liquide acide qui fait fondre la cible, ce qui diminue beaucoup la Défense Spéciale de celle-ci." - }, - "foulPlay": { - "name": "Tricherie", - "effect": "Le lanceur utilise la force de la cible. Plus l’Attaque de celle-ci est élevée, plus le lanceur inflige de dégâts." - }, - "simpleBeam": { - "name": "Rayon Simple", - "effect": "Le lanceur envoie des ondes mystérieuses à la cible, dont le talent est remplacé par le talent Simple." - }, - "entrainment": { - "name": "Ten-Danse", - "effect": "Le lanceur danse sur un rythme étrange. Il force sa cible à l’imiter, ce qui lui fait adopter son talent." - }, - "afterYou": { - "name": "Après Vous", - "effect": "S’il est le premier à agir, le lanceur permet à sa cible d’utiliser une capacité juste après lui." - }, - "round": { - "name": "Chant Canon", - "effect": "Le lanceur attaque la cible en chantant. Si plusieurs Pokémon déclenchent cette attaque à la suite, la puissance augmente." - }, - "echoedVoice": { - "name": "Écho", - "effect": "Un cri retentissant blesse la cible. Si le lanceur ou d’autres Pokémon utilisent cette capacité à chaque tour, la puissance augmente." - }, - "chipAway": { - "name": "Attrition", - "effect": "Une attaque puissante quand l’ennemi baisse sa garde. Inflige des dégâts sans tenir compte des changements de stats." - }, - "clearSmog": { - "name": "Bain de Smog", - "effect": "Le lanceur projette de la boue bizarre sur la cible. Les changements de stats de la cible sont annulés." - }, - "storedPower": { - "name": "Force Ajoutée", - "effect": "Le lanceur attaque la cible avec une force cumulée. Plus les stats du lanceur sont augmentées, plus la puissance de cette capacité augmente." - }, - "quickGuard": { - "name": "Prévention", - "effect": "Protège le lanceur et ses alliés des attaques prioritaires." - }, - "allySwitch": { - "name": "Interversion", - "effect": "Le lanceur se téléporte à l’aide d’un pouvoir mystérieux. Il échange sa place avec celle d’un allié sur le terrain. Peut échouer si utilisée plusieurs fois de suite." - }, - "scald": { - "name": "Ébullition", - "effect": "Le lanceur projette un jet d’eau bouillante sur la cible, ce qui peut aussi la bruler (30% de chances)." - }, - "shellSmash": { - "name": "Exuviation", - "effect": "Le lanceur brise sa carapace. Il baisse sa Défense et sa Défense Spéciale, mais augmente beaucoup son Attaque, son Attaque Spéciale et sa Vitesse." - }, - "healPulse": { - "name": "Vibra Soin", - "effect": "Le lanceur projette une aura de bien-être qui fait récupérer la moitié de ses PV max à la cible." - }, - "hex": { - "name": "Châtiment", - "effect": "Une attaque acharnée qui cause davantage de dégâts à la cible si elle a une altération de statut." - }, - "skyDrop": { - "name": "Chute Libre", - "effect": "Le lanceur emmène l’ennemi dans les airs au premier tour et le lâche dans le vide au second. L’ennemi saisi ne peut pas attaquer." - }, - "shiftGear": { - "name": "Change-Vitesse", - "effect": "Le lanceur fait tourner ses engrenages. Cela augmente son Attaque et augmente beaucoup sa Vitesse." - }, - "circleThrow": { - "name": "Projection", - "effect": "Le lanceur fait une projection sur un Pokémon ennemi et le remplace par un autre. Lors d’un combat contre un Pokémon sauvage seul, cela met fin au combat." - }, - "incinerate": { - "name": "Calcination", - "effect": "Des flammes calcinent la cible. Si elle tient un objet, une Baie par exemple, celui-ci est brulé et devient inutilisable." - }, - "quash": { - "name": "À la Queue", - "effect": "Retient la cible de force, l’obligeant à agir en dernier." - }, - "acrobatics": { - "name": "Acrobatie", - "effect": "Le lanceur frappe la cible avec agilité. S’il ne tient pas d’objet, l’attaque inflige davantage de dégâts." - }, - "reflectType": { - "name": "Copie-Type", - "effect": "Le lanceur adopte le même type que la cible." - }, - "retaliate": { - "name": "Vengeance", - "effect": "Le lanceur venge un allié K.O. Si un Pokémon de l’équipe a été mis K.O. au tour d’avant, la puissance augmente." - }, - "finalGambit": { - "name": "Tout ou Rien", - "effect": "Une attaque très risquée. Le lanceur perd tous ses PV restants et inflige autant de dégâts à la cible." - }, - "bestow": { - "name": "Passe-Cadeau", - "effect": "Si la cible ne tient pas d’objet, le lanceur lui donne l’objet qu’il tient." - }, - "inferno": { - "name": "Feu d’Enfer", - "effect": "La cible est entourée d’un torrent de flammes ardentes qui la brulent." - }, - "waterPledge": { - "name": "Aire d’Eau", - "effect": "Une masse d’eau s’abat sur la cible. Si cette capacité est utilisée en même temps qu’Aire de Feu, la puissance augmente et un arc-en-ciel apparait." - }, - "firePledge": { - "name": "Aire de Feu", - "effect": "Une masse de feu s’abat sur la cible. Si cette capacité est utilisée en même temps qu’Aire d’Herbe, la puissance augmente et une mer de feu apparait." - }, - "grassPledge": { - "name": "Aire d’Herbe", - "effect": "Une masse végétale s’abat sur la cible. Si cette capacité est utilisée en même temps qu’Aire d’Eau, la puissance augmente et un marécage apparait." - }, - "voltSwitch": { - "name": "Change Éclair", - "effect": "Après son attaque, le lanceur revient à toute vitesse et change de place avec un Pokémon de l’équipe prêt au combat." - }, - "struggleBug": { - "name": "Survinsecte", - "effect": "Le lanceur frappe en se débattant de toutes ses forces, et baisse l’Attaque Spéciale de la cible." - }, - "bulldoze": { - "name": "Piétisol", - "effect": "Le lanceur piétine le sol et inflige des dégâts à tous les Pokémon autour de lui. Baisse aussi leur Vitesse." - }, - "frostBreath": { - "name": "Souffle Glacé", - "effect": "Un souffle froid blesse la cible. L’effet est toujours critique." - }, - "dragonTail": { - "name": "Draco-Queue", - "effect": "Un coup puissant qui blesse la cible et l’envoie au loin. Lors d’un combat contre un Pokémon sauvage seul, met fin au combat." - }, - "workUp": { - "name": "Rengorgement", - "effect": "Le lanceur se rengorge et augmente son Attaque et son Attaque Spéciale." - }, - "electroweb": { - "name": "Toile Élek", - "effect": "Le lanceur attaque la cible en l’attrapant dans un filet électrique. Baisse aussi la Vitesse de la cible." - }, - "wildCharge": { - "name": "Éclair Fou", - "effect": "Une charge électrique violente qui blesse aussi légèrement le lanceur." - }, - "drillRun": { - "name": "Tunnelier", - "effect": "Le lanceur tourne sur lui-même comme une perceuse et se jette sur la cible. Taux de critiques élevé." - }, - "dualChop": { - "name": "Double Baffe", - "effect": "Le lanceur frappe l’ennemi deux fois d’affilée avec les parties les plus robustes de son corps." - }, - "heartStamp": { - "name": "Crève-Cœur", - "effect": "Déconcentre l’ennemi avec des mouvements mignons avant de le frapper violemment. Peut aussi l’apeurer (30% de chances)." - }, - "hornLeech": { - "name": "Encornebois", - "effect": "Un coup de cornes qui draine l’énergie de la cible. La capacité convertit la moitié des dégâts infligés en PV pour le lanceur." - }, - "sacredSword": { - "name": "Lame Sainte", - "effect": "Un violent coup d’épée qui lacère la cible et lui inflige des dégâts en ignorant ses changements de stats." - }, - "razorShell": { - "name": "Coqui-Lame", - "effect": "Un coquillage aiguisé lacère la cible et peut aussi baisser sa Défense." - }, - "heatCrash": { - "name": "Tacle Feu", - "effect": "Le lanceur projette son corps enflammé contre la cible. Plus il est lourd par rapport à la cible, plus la puissance de cette capacité augmente." - }, - "leafTornado": { - "name": "Phytomixeur", - "effect": "L’ennemi est pris dans un tourbillon de feuilles acérées. Peut aussi baisser sa Précision." - }, - "steamroller": { - "name": "Bulldoboule", - "effect": "Le lanceur se roule en boule et écrase son ennemi. Peut aussi l’apeurer (30% de chances)." - }, - "cottonGuard": { - "name": "Cotogarde", - "effect": "Le lanceur se protège en s’emmitouflant dans du coton. Sa Défense augmente énormément." - }, - "nightDaze": { - "name": "Explonuit", - "effect": "Le lanceur attaque avec une onde de choc ténébreuse qui peut aussi baisser la Précision de la cible." - }, - "psystrike": { - "name": "Frappe Psy", - "effect": "Le lanceur matérialise des ondes mystérieuses qu’il projette sur la cible, ce qui inflige des dégâts physiques à celle-ci." - }, - "tailSlap": { - "name": "Plumo-Queue", - "effect": "Le lanceur frappe la cible de deux à cinq fois d’affilée avec sa queue robuste." - }, - "hurricane": { - "name": "Vent Violent", - "effect": "Le lanceur déclenche une tempête de vents violents qui s’abat sur la cible, et peut aussi la rendre confuse." - }, - "headCharge": { - "name": "Peignée", - "effect": "Le lanceur donne un coup avec sa tête couronnée d’une fière crinière. Blesse aussi légèrement le lanceur." - }, - "gearGrind": { - "name": "Lancécrou", - "effect": "Le lanceur jette deux écrous d’acier qui frappent l’ennemi deux fois d’affilée." - }, - "searingShot": { - "name": "Incendie", - "effect": "Des boules de feu s’abattent sur tous les Pokémon autour du lanceur. Peut aussi les bruler (30% de chances)." - }, - "technoBlast": { - "name": "Techno-Buster", - "effect": "Le lanceur projette un rayon lumineux sur l’ennemi. Le type varie selon le Module que tient le lanceur." - }, - "relicSong": { - "name": "Chant Antique", - "effect": "Le lanceur attaque la cible en lui chantant une chanson d’un autre temps qui peut aussi l’endormir." - }, - "secretSword": { - "name": "Lame Ointe", - "effect": "L’ennemi est lacéré par une longue corne. Son pouvoir mystérieux inflige des dégâts physiques." - }, - "glaciate": { - "name": "Ère Glaciaire", - "effect": "Un souffle de vent qui congèle tout sur son passage s’abat sur l’ennemi. Réduit aussi sa Vitesse." - }, - "boltStrike": { - "name": "Charge Foudre", - "effect": "Le lanceur s’enveloppe d’une charge électrique surpuissante et se jette sur l’ennemi. Peut aussi le paralyser (20% de chances)." - }, - "blueFlare": { - "name": "Flamme Bleue", - "effect": "De magnifiques et redoutables flammes bleues fondent sur l’ennemi. Peut aussi le bruler (20% de chances)." - }, - "fieryDance": { - "name": "Danse du Feu", - "effect": "Le lanceur s’enveloppe de flammes et attaque la cible, Cela peut aussi augmenter l’Attaque Spéciale du lanceur." - }, - "freezeShock": { - "name": "Éclair Gelé", - "effect": "Projette un bloc de glace électrifié sur l’ennemi au second tour. Peut aussi le paralyser (30% de chances)." - }, - "iceBurn": { - "name": "Feu Glacé", - "effect": "Au second tour, le lanceur projette un souffle de vent glacial dévastateur sur l’ennemi. Peut aussi le bruler (30% de chances)." - }, - "snarl": { - "name": "Aboiement", - "effect": "Le lanceur hurle sur la cible et baisse l’Attaque Spéciale de celle-ci." - }, - "icicleCrash": { - "name": "Chute Glace", - "effect": "Le lanceur envoie de gros blocs de glace sur la cible pour lui infliger des dégâts, ce qui peut aussi l’apeurer (30% de chances)." - }, - "vCreate": { - "name": "Coup Victoire", - "effect": "Le lanceur fait jaillir des flammes ardentes de son front et se jette sur la cible, ce qui baisse la Défense, la Défense Spéciale et la Vitesse du lanceur." - }, - "fusionFlare": { - "name": "Flamme Croix", - "effect": "Projette une boule de feu gigantesque. L’effet augmente sous l’influence d’Éclair Croix." - }, - "fusionBolt": { - "name": "Éclair Croix", - "effect": "Projette un orbe électrique gigantesque. L’effet augmente sous l’influence de Flamme Croix." - }, - "flyingPress": { - "name": "Flying Press", - "effect": "Une attaque en piqué depuis le ciel, à la fois de type Combat et de type Vol." - }, - "matBlock": { - "name": "Tatamigaeshi", - "effect": "Retourne un tatami pour bloquer, comme avec un bouclier, les capacités visant le lanceur ou ses alliés. N’a pas d’effet sur les attaques de statut." - }, - "belch": { - "name": "Éructation", - "effect": "Le lanceur se tourne vers la cible et lui éructe dessus, infligeant des dégâts. Ne fonctionne que si le lanceur consomme une Baie tenue." - }, - "rototiller": { - "name": "Fertilisation", - "effect": "Laboure le sol et le rend plus fertile. Augmente l’Attaque et l’Attaque Spéciale des Pokémon de type Plante." - }, - "stickyWeb": { - "name": "Toile Gluante", - "effect": "Le lanceur déploie une toile visqueuse autour de la cible qui ralentit la Vitesse de tout adversaire entrant au combat." - }, - "fellStinger": { - "name": "Dard Mortel", - "effect": "Le lanceur augmente énormément son Attaque si une cible est mise K.O. par cette capacité." - }, - "phantomForce": { - "name": "Hantise", - "effect": "Le lanceur disparait au premier tour et frappe au second. Cette attaque passe outre les protections." - }, - "trickOrTreat": { - "name": "Halloween", - "effect": "Insuffle à la cible l’esprit d’Halloween, et ajoute le type Spectre à ses types actuels." - }, - "nobleRoar": { - "name": "Râle Mâle", - "effect": "Le lanceur pousse un rugissement qui intimide la cible et diminue l’Attaque et l’Attaque Spéciale de celle-ci." - }, - "ionDeluge": { - "name": "Déluge Plasmique", - "effect": "Diffuse des particules saturées d’électricité qui transforment les capacités de type Normal en capacités de type Électrik." - }, - "parabolicCharge": { - "name": "Parabocharge", - "effect": "Inflige des dégâts à tous les Pokémon autour du lanceur. Il récupère en PV la moitié des dégâts infligés." - }, - "forestsCurse": { - "name": "Maléfice Sylvain", - "effect": "La cible est charmée par l’esprit de la forêt. Le type Plante est ajouté à ses types actuels." - }, - "petalBlizzard": { - "name": "Tempête Florale", - "effect": "Déclenche une violente tempête de fleurs qui inflige des dégâts à tous les Pokémon alentour." - }, - "freezeDry": { - "name": "Lyophilisation", - "effect": "Le lanceur refroidit violemment la cible et peut la geler (10% de chances). Super efficace sur les Pokémon de type Eau." - }, - "disarmingVoice": { - "name": "Voix Enjôleuse", - "effect": "Le lanceur laisse s’échapper une voix enchanteresse qui inflige des dégâts psychiques à la cible. N’échoue jamais." - }, - "partingShot": { - "name": "Dernier Mot", - "effect": "Le lanceur menace la cible dans une ultime tirade avant de changer de place avec un autre Pokémon. Réduit l’Attaque et l’Attaque Spéciale de la cible." - }, - "topsyTurvy": { - "name": "Renversement", - "effect": "Inverse tous les changements de stats de la cible." - }, - "drainingKiss": { - "name": "Vampibaiser", - "effect": "Le lanceur aspire la force vitale de la cible par un baiser qui rend au lanceur un nombre de PV supérieur ou égal à la moitié des dégâts infligés." - }, - "craftyShield": { - "name": "Vigilance", - "effect": "Utilise une force mystérieuse pour protéger l’équipe des capacités de statut. Ne protège pas des autres capacités." - }, - "flowerShield": { - "name": "Garde Florale", - "effect": "Grâce à une force mystérieuse, la Défense de tous les Pokémon Plante au combat augmente." - }, - "grassyTerrain": { - "name": "Champ Herbu", - "effect": "Pendant cinq tours, les Pokémon au sol récupèrent quelques PV à chaque tour et la puissance des capacités de type Plante augmente." - }, - "mistyTerrain": { - "name": "Champ Brumeux", - "effect": "Pendant cinq tours, les Pokémon au sol ne peuvent pas subir d’altération de statut et les dégâts infligés par les capacités de type Dragon sont divisés par deux." - }, - "electrify": { - "name": "Électrisation", - "effect": "Si le lanceur attaque avant la cible, les capacités de celle-ci seront de type Électrik jusqu’à la fin du tour." - }, - "playRough": { - "name": "Câlinerie", - "effect": "Le lanceur attaque la cible en lui faisant des câlineries, ce qui peut aussi diminuer l’Attaque de celle-ci." - }, - "fairyWind": { - "name": "Vent Féérique", - "effect": "Le lanceur déchaine un vent magique qui cingle la cible." - }, - "moonblast": { - "name": "Pouvoir Lunaire", - "effect": "Le lanceur attaque la cible grâce au pouvoir de la lune, ce qui peut diminuer l’Attaque Spéciale de celle-ci." - }, - "boomburst": { - "name": "Bang Sonique", - "effect": "Attaque les Pokémon alentour grâce à une onde sonore assourdissante qui détruit tout sur son passage." - }, - "fairyLock": { - "name": "Verrou Enchanté", - "effect": "Des chaines entourent la zone de combat, empêchant tous les Pokémon de quitter le terrain au tour suivant." - }, - "kingsShield": { - "name": "Bouclier Royal", - "effect": "Prend une posture défensive pour bloquer les dégâts. Diminue beaucoup l’Attaque de tout Pokémon qui entre en contact avec le lanceur." - }, - "playNice": { - "name": "Camaraderie", - "effect": "La cible se lie d’amitié avec le lanceur et perd sa combativité, ce qui diminue son Attaque." - }, - "confide": { - "name": "Confidence", - "effect": "Le lanceur dévoile des secrets à la cible, qui perd alors sa concentration et voit son Attaque Spéciale diminuer." - }, - "diamondStorm": { - "name": "Orage Adamantin", - "effect": "Provoque une tempête de diamants qui inflige des dégâts. Peut beaucoup augmenter la Défense du lanceur." - }, - "steamEruption": { - "name": "Jet de Vapeur", - "effect": "Le lanceur projette de la vapeur extrêmement chaude sur la cible, ce qui peut aussi la bruler (30% de chances)." - }, - "hyperspaceHole": { - "name": "TrouDimensionnel", - "effect": "Le lanceur crée une faille dimensionnelle pour attaquer soudainement la cible de côté. Ignore même les capacités comme Abri ou Détection." - }, - "waterShuriken": { - "name": "Sheauriken", - "effect": "Le lanceur attaque la cible avec des shuriken de mucus. Cette capacité frappe en priorité deux à cinq fois d’affilée en un tour." - }, - "mysticalFire": { - "name": "Feu Ensorcelé", - "effect": "Le lanceur attaque en soufflant des flammes brulantes par la bouche et diminue l’Attaque Spéciale de la cible." - }, - "spikyShield": { - "name": "Pico-Défense", - "effect": "Protège des attaques, et diminue les PV de tout assaillant qui entre en contact avec le lanceur." - }, - "aromaticMist": { - "name": "Brume Capiteuse", - "effect": "Grâce à un parfum mystérieux, augmente la Défense Spéciale d’un allié." - }, - "eerieImpulse": { - "name": "Ondes Étranges", - "effect": "Le corps du lanceur produit des ondes anormales qui enveloppent la cible et diminuent beaucoup son Attaque Spéciale." - }, - "venomDrench": { - "name": "Piège de Venin", - "effect": "Sécrète un liquide empoisonné. Diminue l’Attaque, l’Attaque Spéciale et la Vitesse de l’ennemi empoisonné." - }, - "powder": { - "name": "Nuée de Poudre", - "effect": "L’ennemi est pris dans un nuage de poudre. S’il utilise une capacité de type Feu lors du même tour, le nuage explose et lui inflige des dégâts." - }, - "geomancy": { - "name": "Géo-Contrôle", - "effect": "Le lanceur absorbe de l’énergie au premier tour et augmente beaucoup son Attaque Spéciale, sa Défense Spéciale et sa Vitesse au second." - }, - "magneticFlux": { - "name": "Magné-Contrôle", - "effect": "Manipule les champs magnétiques pour augmenter la Défense et la Défense Spéciale des Pokémon alliés dotés du talent Plus ou du talent Moins." - }, - "happyHour": { - "name": "Étrennes", - "effect": "Utilisée pendant un combat, multiplie par deux l’argent gagné à la fin." - }, - "electricTerrain": { - "name": "Champ Électrifié", - "effect": "Pendant cinq tours, le terrain se charge d’électricité. Les Pokémon au sol ne peuvent pas s’endormir et la puissance des capacités de type Électrik augmente." - }, - "dazzlingGleam": { - "name": "Éclat Magique", - "effect": "Le lanceur libère une puissante décharge lumineuse qui inflige des dégâts à l’ennemi." - }, - "celebrate": { - "name": "Célébration", - "effect": "Le Pokémon vous souhaite plein de bonnes choses pour cet évènement spécial." - }, - "holdHands": { - "name": "Mains Jointes", - "effect": "Le lanceur et un allié se prennent la main, ce qui les rend heureux." - }, - "babyDollEyes": { - "name": "Regard Touchant", - "effect": "Le lanceur fixe la cible d’un air très attendrissant qui la touche et diminue son Attaque. Agit en priorité." - }, - "nuzzle": { - "name": "Frotte-Frimousse", - "effect": "Le lanceur attaque en frottant ses bajoues chargées d’électricité, ce qui paralyse la cible." - }, - "holdBack": { - "name": "Retenue", - "effect": "Le lanceur attaque avec retenue, et laisse au moins 1 PV à la cible." - }, - "infestation": { - "name": "Harcèlement", - "effect": "Cette attaque perdure pendant quatre à cinq tours. La cible ne peut pas quitter le terrain pendant cette période." - }, - "powerUpPunch": { - "name": "Poing Boost", - "effect": "À force de frapper, les poings deviennent plus durs. Augmente l’Attaque du lanceur si l’ennemi est touché." - }, - "oblivionWing": { - "name": "Mort’Ailes", - "effect": "Vole l’énergie de la cible. Rend au lanceur un nombre de PV supérieur ou égal à la moitié des dégâts infligés." - }, - "thousandArrows": { - "name": "Myria-Flèches", - "effect": "Touche même les Pokémon dans les airs. Dans ce cas, la cible retombe au sol." - }, - "thousandWaves": { - "name": "Myria-Vagues", - "effect": "Attaque avec des vagues glissant au sol. L’ennemi pris dedans ne peut pas s’échapper." - }, - "landsWrath": { - "name": "Force Chtonienne", - "effect": "Utilise la puissance du sol et la concentre sur l’ennemi pour infliger des dégâts." - }, - "lightOfRuin": { - "name": "Lumière du Néant", - "effect": "Utilise la puissance de la fleur Éternelle pour lancer un formidable rayon d’énergie. Blesse aussi gravement le lanceur." - }, - "originPulse": { - "name": "Onde Originelle", - "effect": "Le lanceur projette une aura, et d’innombrables rayons lumineux d’un bleu étincelant s’abattent sur la cible." - }, - "precipiceBlades": { - "name": "Lame Pangéenne", - "effect": "Le Pokémon transforme la puissance de la terre et attaque la cible avec une lame acérée." - }, - "dragonAscent": { - "name": "Draco-Ascension", - "effect": "Le Pokémon s’abat à toute vitesse sur la cible depuis les hautes couches de l’atmosphère. Baisse la Défense et la Défense Spéciale du lanceur." - }, - "hyperspaceFury": { - "name": "Furie Dimension", - "effect": "Le Pokémon utilise sa multitude de bras pour infliger une nuée de coups qui ignorent les capacités telles qu’Abri ou Détection. Baisse la Défense du lanceur." - }, - "breakneckBlitzPhysical": { - "name": "Turbo-Charge Bulldozer", - "effect": "Le Pokémon utilise la Force Z pour s’élancer à toute vitesse sur l’adversaire. La puissance varie selon celle de la capacité originale." - }, - "breakneckBlitzSpecial": { - "name": "Turbo-Charge Bulldozer", - "effect": "Dummy Data" - }, - "allOutPummelingPhysical": { - "name": "Combo Hyper-Furie", - "effect": "Le Pokémon utilise la Force Z pour créer une boule d’énergie qu’il projette sur l’adversaire. La puissance varie selon celle de la capacité originale." - }, - "allOutPummelingSpecial": { - "name": "Combo Hyper-Furie", - "effect": "Dummy Data" - }, - "supersonicSkystrikePhysical": { - "name": "Piqué Supersonique", - "effect": "Le Pokémon utilise la Force Z pour s’envoler très haut dans le ciel avant de plonger sur l’adversaire. La puissance varie selon celle de la capacité originale." - }, - "supersonicSkystrikeSpecial": { - "name": "Piqué Supersonique", - "effect": "Dummy Data" - }, - "acidDownpourPhysical": { - "name": "Déluge Causti-Toxique", - "effect": "Le Pokémon utilise la Force Z pour répandre un marécage empoisonné où l’adversaire sombre. La puissance varie selon celle de la capacité originale." - }, - "acidDownpourSpecial": { - "name": "Déluge Causti-Toxique", - "effect": "Dummy Data" - }, - "tectonicRagePhysical": { - "name": "Éruption Géo-Sismique", - "effect": "Le Pokémon utilise la Force Z pour entrainer l’adversaire dans les profondeurs de la terre. La puissance varie selon celle de la capacité originale." - }, - "tectonicRageSpecial": { - "name": "Éruption Géo-Sismique", - "effect": "Dummy Data" - }, - "continentalCrushPhysical": { - "name": "Apocalypse Gigalithique", - "effect": "Le Pokémon utilise la Force Z pour créer un immense rocher et écraser l’adversaire avec. La puissance varie selon celle de la capacité originale." - }, - "continentalCrushSpecial": { - "name": "Apocalypse Gigalithique", - "effect": "Dummy Data" - }, - "savageSpinOutPhysical": { - "name": "Cocon Fatal", - "effect": "Le Pokémon utilise la Force Z pour cracher de longs fils de soie et enserrer l’adversaire. La puissance varie selon celle de la capacité originale." - }, - "savageSpinOutSpecial": { - "name": "Cocon Fatal", - "effect": "Dummy Data" - }, - "neverEndingNightmarePhysical": { - "name": "Appel des Ombres Éternelles", - "effect": "Le Pokémon utilise la Force Z pour invoquer des esprits rancuniers qui s’abattent sur l’adversaire. La puissance varie selon celle de la capacité originale." - }, - "neverEndingNightmareSpecial": { - "name": "Appel des Ombres Éternelles", - "effect": "Dummy Data" - }, - "corkscrewCrashPhysical": { - "name": "Vrille Maximum", - "effect": "Le Pokémon utilise la Force Z pour tourner à toute vitesse et écraser l’adversaire. La puissance varie selon celle de la capacité originale." - }, - "corkscrewCrashSpecial": { - "name": "Vrille Maximum", - "effect": "Dummy Data" - }, - "infernoOverdrivePhysical": { - "name": "Pyro-Explosion Cataclysmique", - "effect": "Le Pokémon utilise la Force Z pour cracher une boule de feu qui réduit l’adversaire en cendres. La puissance varie selon celle de la capacité originale." - }, - "infernoOverdriveSpecial": { - "name": "Pyro-Explosion Cataclysmique", - "effect": "Dummy Data" - }, - "hydroVortexPhysical": { - "name": "Super Tourbillon Abyssal", - "effect": "Le Pokémon utilise la Force Z pour créer un tourbillon gigantesque qui avale l’adversaire. La puissance varie selon celle de la capacité originale." - }, - "hydroVortexSpecial": { - "name": "Super Tourbillon Abyssal", - "effect": "Dummy Data" - }, - "bloomDoomPhysical": { - "name": "Pétalexplosion Éblouissante", - "effect": "Le Pokémon utilise la Force Z pour libérer l’énergie des plantes et attaquer l’adversaire. La puissance varie selon celle de la capacité originale." - }, - "bloomDoomSpecial": { - "name": "Pétalexplosion Éblouissante", - "effect": "Dummu Data" - }, - "gigavoltHavocPhysical": { - "name": "Fulguro-Lance Gigavolt", - "effect": "Le Pokémon utilise la Force Z pour générer un courant électrique puissant qu’il projette sur l’adversaire. La puissance varie selon celle de la capacité originale." - }, - "gigavoltHavocSpecial": { - "name": "Fulguro-Lance Gigavolt", - "effect": "Dummy Data" - }, - "shatteredPsychePhysical": { - "name": "Psycho-Pulvérisation EX", - "effect": "Le Pokémon utilise la Force Z pour manipuler l’adversaire et lui infliger de sérieux dégâts. La puissance varie selon celle de la capacité originale." - }, - "shatteredPsycheSpecial": { - "name": "Psycho-Pulvérisation EX", - "effect": "Dummy Data" - }, - "subzeroSlammerPhysical": { - "name": "Laser Cryogénique", - "effect": "Le Pokémon utilise la Force Z pour baisser la température brutalement et congeler l’adversaire. La puissance varie selon celle de la capacité originale." - }, - "subzeroSlammerSpecial": { - "name": "Laser Cryogénique", - "effect": "Dummy Data" - }, - "devastatingDrakePhysical": { - "name": "Chaos Draconique", - "effect": "Le Pokémon utilise la Force Z pour matérialiser son aura et assaillir l’adversaire. La puissance varie selon celle de la capacité originale." - }, - "devastatingDrakeSpecial": { - "name": "Chaos Draconique", - "effect": "Dummy Data" - }, - "blackHoleEclipsePhysical": { - "name": "Trou Noir des Ombres", - "effect": "Le Pokémon utilise la Force Z pour rassembler l’énergie négative et y aspirer l’adversaire. La puissance varie selon celle de la capacité originale." - }, - "blackHoleEclipseSpecial": { - "name": "Trou Noir des Ombres", - "effect": "Dummy Data" - }, - "twinkleTacklePhysical": { - "name": "Impact Choupinova", - "effect": "Le Pokémon utilise la Force Z pour créer une dimension irréelle où l’adversaire est à sa merci. La puissance varie selon celle de la capacité originale." - }, - "twinkleTackleSpecial": { - "name": "Impact Choupinova", - "effect": "Dummy Data" - }, - "catastropika": { - "name": "Pikachute Foudroyante", - "effect": "Pikachu utilise la Force Z pour concentrer toute son électricité avant de se jeter à toute vitesse sur l’adversaire." - }, - "shoreUp": { - "name": "Amass’Sable", - "effect": "Le lanceur récupère jusqu’à la moitié de ses PV max. Durant une tempête de sable, il en récupère encore plus." - }, - "firstImpression": { - "name": "Escarmouche", - "effect": "Une capacité très puissante, mais qui ne fonctionne que lorsque le lanceur entre au combat." - }, - "banefulBunker": { - "name": "Blockhaus", - "effect": "Le lanceur se protège contre les attaques, et si un assaillant utilise une attaque directe contre lui, il l’empoisonne." - }, - "spiritShackle": { - "name": "Tisse Ombre", - "effect": "Une attaque qui coud la cible à son ombre, ce qui l’empêche de s’enfuir." - }, - "darkestLariat": { - "name": "Dark Lariat", - "effect": "Le lanceur étend les bras et frappe l’adversaire en tournant violemment. Il inflige des dégâts et ignore les changements de stats de la cible." - }, - "sparklingAria": { - "name": "Aria de l’Écume", - "effect": "Le lanceur émet plusieurs bulles en chantant. Soigne les brulures des Pokémon touchés par ces bulles." - }, - "iceHammer": { - "name": "Marteau de Glace", - "effect": "Le lanceur donne un puissant coup de poing à la cible, ce qui réduit la Vitesse du lanceur." - }, - "floralHealing": { - "name": "Soin Floral", - "effect": "Rend la moitié de ses PV max à la cible. Plus efficace sur un Champ Herbu." - }, - "highHorsepower": { - "name": "Cavalerie Lourde", - "effect": "Le lanceur attaque violemment en utilisant tout son poids." - }, - "strengthSap": { - "name": "Vole-Force", - "effect": "Rend au lanceur une quantité de PV équivalente à la stat d’Attaque de la cible, puis baisse celle-ci." - }, - "solarBlade": { - "name": "Lame Solaire", - "effect": "Le lanceur absorbe une grande quantité de lumière au premier tour et attaque au second tour en libérant cette énergie sous la forme d’une lame." - }, - "leafage": { - "name": "Feuillage", - "effect": "Le lanceur attaque la cible avec des feuilles." - }, - "spotlight": { - "name": "Projecteur", - "effect": "Met un Pokémon sous le feu des projecteurs et force tout le monde à le viser." - }, - "toxicThread": { - "name": "Fil Toxique", - "effect": "Tisse un fil imprégné de venin. Empoisonne la cible et baisse sa Vitesse." - }, - "laserFocus": { - "name": "Affilage", - "effect": "Le lanceur se concentre pour être sûr de porter un coup critique au tour suivant." - }, - "gearUp": { - "name": "Engrenage", - "effect": "Change de réglage pour augmenter l’Attaque et l’Attaque Spéciale des alliés ayant les talents Plus ou Minus." - }, - "throatChop": { - "name": "Exécu-Son", - "effect": "Inflige une douleur tellement violente à la cible qu’elle ne peut plus émettre de sons pendant deux tours." - }, - "pollenPuff": { - "name": "Boule Pollen", - "effect": "Sur un ennemi, le lanceur envoie une boule explosive qui fait des dégâts. Sur un allié, il envoie du bon pollen nutritif qui fait récupérer des PV." - }, - "anchorShot": { - "name": "Ancrage", - "effect": "Le lanceur jette son ancre sur la cible pour l’attaquer. Une fois accrochée, elle l’empêche de s’enfuir." - }, - "psychicTerrain": { - "name": "Champ Psychique", - "effect": "Pendant cinq tours, les Pokémon au sol ne peuvent plus subir d’attaques prioritaires et la puissance des capacités de type Psy augmente." - }, - "lunge": { - "name": "Furie-Bond", - "effect": "Le lanceur se jette sur la cible de toutes ses forces pour lui infliger des dégâts et baisser son Attaque." - }, - "fireLash": { - "name": "Fouet de Feu", - "effect": "Frappe la cible avec un fouet incandescent et baisse sa Défense." - }, - "powerTrip": { - "name": "Arrogance", - "effect": "Ivre de puissance, le lanceur attaque de toutes ses forces. Plus ses stats ont été augmentées, plus la puissance de cette capacité augmente." - }, - "burnUp": { - "name": "Flamme Ultime", - "effect": "Le Pokémon se consume et les flammes de son corps infligent des dégâts élevés à la cible. Le lanceur perd le type Feu." - }, - "speedSwap": { - "name": "Permuvitesse", - "effect": "Intervertit la Vitesse du lanceur et celle de la cible." - }, - "smartStrike": { - "name": "Estocorne", - "effect": "Le lanceur transperce la cible avec sa corne effilée. N’échoue jamais." - }, - "purify": { - "name": "Purification", - "effect": "Le lanceur soigne les altérations de statut de la cible, ce qui lui permet de regagner des PV." - }, - "revelationDance": { - "name": "Danse Éveil", - "effect": "Le lanceur attaque en dansant avec enthousiasme. Le type de la capacité est le même que celui du lanceur." - }, - "coreEnforcer": { - "name": "Sanction Suprême", - "effect": "La cible subit des dégâts et, si elle a déjà agi à ce tour, elle perd aussi son talent." - }, - "tropKick": { - "name": "Botte Sucrette", - "effect": "Un coup de pied chaud comme les tropiques qui inflige des dégâts à la cible et baisse son Attaque." - }, - "instruct": { - "name": "Sommation", - "effect": "Force la cible à lancer immédiatement la dernière capacité qu’elle a utilisée." - }, - "beakBlast": { - "name": "Bec-Canon", - "effect": "Le lanceur fait chauffer son bec avant d’attaquer. S’il subit une attaque directe pendant la montée en température, l’attaquant sera brulé." - }, - "clangingScales": { - "name": "Vibrécaille", - "effect": "Le lanceur déclenche un vacarme en frottant ses écailles les unes contre les autres pour attaquer. Baisse la Défense du lanceur." - }, - "dragonHammer": { - "name": "Draco-Marteau", - "effect": "Le lanceur utilise son corps comme un véritable marteau pour écraser la cible." - }, - "brutalSwing": { - "name": "Centrifugifle", - "effect": "Le lanceur pivote pour prendre de l’élan et infliger des dégâts." - }, - "auroraVeil": { - "name": "Voile Aurore", - "effect": "Réduit les dégâts causés par les capacités physiques et spéciales durant cinq tours. Ne peut être utilisée que lorsqu’il neige." - }, - "sinisterArrowRaid": { - "name": "Fureur des Plumes Spectrales", - "effect": "Archéduc utilise la Force Z pour créer un nuage de flèches qui transpercent la cible." - }, - "maliciousMoonsault": { - "name": "Dark Body Press", - "effect": "Félinferno utilise la Force Z pour gonfler ses muscles et écraser la cible de toutes ses forces." - }, - "oceanicOperetta": { - "name": "Symphonie des Ondines", - "effect": "Oratoria utilise la Force Z pour rassembler une grande quantité d’eau et la projeter sur la cible à pleine puissance." - }, - "guardianOfAlola": { - "name": "Colère du Gardien d’Alola", - "effect": "Le Pokémon Tutélaire utilise la Force Z et déchaine toute la puissance d’Alola sur sa cible. Inflige des dégâts en fonction des PV restants de celle-ci." - }, - "soulStealing7StarStrike": { - "name": "Fauche-Âme des Sept Étoiles", - "effect": "Marshadow concentre toute la Force Z dans ses poings et ses pieds pour infliger un déluge de coups à la cible." - }, - "stokedSparksurfer": { - "name": "Électro-Surf Survolté", - "effect": "Le Raichu de la région d’Alola utilise la Force Z pour frapper la cible et la paralyser." - }, - "pulverizingPancake": { - "name": "Gare au Ronflex", - "effect": "Ronflex utilise la Force Z pour montrer ce qu’il a dans le ventre et écraser la cible de tout son poids." - }, - "extremeEvoboost": { - "name": "Neuf pour Un", - "effect": "Évoli utilise la Force Z pour emprunter la puissance de tous ses amis évolués et beaucoup augmenter toutes ses stats." - }, - "genesisSupernova": { - "name": "Supernova Originelle", - "effect": "Mew utilise la Force Z pour attaquer la cible. Le terrain devient un Champ Psychique." - }, - "shellTrap": { - "name": "Carapiège", - "effect": "Pose une carapace piégée. Si l’adversaire utilise une capacité physique, la carapace explose et lui inflige des dégâts." - }, - "fleurCannon": { - "name": "Canon Floral", - "effect": "Envoie un rayon laser dévastateur. Baisse beaucoup l’Attaque Spéciale du lanceur." - }, - "psychicFangs": { - "name": "Psycho-Croc", - "effect": "Le lanceur mord la cible avec ses pouvoirs psychiques. Brise aussi les barrières comme Mur Lumière et Protection." - }, - "stompingTantrum": { - "name": "Trépignement", - "effect": "Le lanceur attaque en utilisant sa frustration. S’il a utilisé une capacité qui a échoué au tour précédent, la puissance de Trépignement est doublée." - }, - "shadowBone": { - "name": "Os Ombre", - "effect": "Le lanceur frappe avec un os possédé par l’âme d’un défunt. Peut aussi baisser la Défense de la cible." - }, - "accelerock": { - "name": "Vif Roc", - "effect": "Le lanceur charge la cible à toute vitesse. Frappe en priorité." - }, - "liquidation": { - "name": "Aqua-Brèche", - "effect": "Le lanceur utilise la force de l’eau pour attaquer. Peut aussi baisser la Défense de la cible." - }, - "prismaticLaser": { - "name": "Laser Prisme", - "effect": "Le lanceur utilise la puissance d’un prisme pour envoyer un laser destructeur, mais il doit se reposer au tour suivant." - }, - "spectralThief": { - "name": "Clepto-Mânes", - "effect": "Le lanceur plonge dans l’ombre de la cible, vole ses augmentations de stats et l’attaque." - }, - "sunsteelStrike": { - "name": "Choc Météore", - "effect": "Le lanceur fonce sur la cible à la vitesse d’une météorite. Ignore le talent de l’ennemi." - }, - "moongeistBeam": { - "name": "Rayon Spectral", - "effect": "Le lanceur attaque avec un rayon de lumière mystérieux. Ignore le talent de la cible." - }, - "tearfulLook": { - "name": "Larme à l’Œil", - "effect": "Le lanceur regarde la cible avec des yeux remplis de larmes. Celle-ci perd toute combativité et voit son Attaque et son Attaque Spéciale baisser." - }, - "zingZap": { - "name": "Électrikipik", - "effect": "Le lanceur fonce sur la cible et lui envoie un puissant choc électrique, ce qui peut aussi l’effrayer." - }, - "naturesMadness": { - "name": "Ire de la Nature", - "effect": "Le lanceur déchaine toute la colère de la nature pour baisser les PV de la cible de moitié." - }, - "multiAttack": { - "name": "Coup Varia-Type", - "effect": "Le Pokémon s’entoure d’une puissante énergie avant de foncer sur sa cible. Le type de la capacité dépend de la ROM installée." - }, - "tenMillionVoltThunderbolt": { - "name": "Giga-Tonnerre", - "effect": "Le Pikachu à casquette utilise la Force Z pour augmenter sa puissance électrique avant de la déchainer sur la cible. Taux de critique élevé." - }, - "mindBlown": { - "name": "Caboche-Kaboum", - "effect": "Le lanceur fait exploser sa tête pour attaquer toutes les cibles autour de lui. Il subit aussi des dégâts." - }, - "plasmaFists": { - "name": "Plasma Punch", - "effect": "Le lanceur attaque en projetant de l’électricité avec ses poings. Convertit les capacités de type Normal en type Électrik." - }, - "photonGeyser": { - "name": "Photo-Geyser", - "effect": "Le lanceur fait jaillir un pilier de lumière. Compare l’Attaque et l’Attaque Spéciale, et utilise celle qui infligera le plus de dégâts." - }, - "lightThatBurnsTheSky": { - "name": "Apocalypsis Luminis", - "effect": "Compare l’Attaque et l’Attaque Spéciale, et utilise celle qui infligera le plus de dégâts. Ignore le talent de la cible." - }, - "searingSunrazeSmash": { - "name": "Hélio-Choc Dévastateur", - "effect": "Baigné dans la Force Z, Solgaleo attaque en déchainant toute sa puissance. Ignore le talent de la cible." - }, - "menacingMoonrazeMaelstrom": { - "name": "Rayons Séléno-Explosifs", - "effect": "Baigné dans la Force Z, Lunala attaque en déchainant toute sa puissance. Ignore le talent de la cible." - }, - "letsSnuggleForever": { - "name": "Patati-Patattrape", - "effect": "Mimiqui concentre toute la Force Z dans son corps, et attaque dans le plus grand fracas !" - }, - "splinteredStormshards": { - "name": "Hurlement des Roches-Lames", - "effect": "Lougaroc utilise la Force Z pour attaquer la cible de toutes ses forces. Efface aussi tout Champ existant." - }, - "clangorousSoulblaze": { - "name": "Dracacophonie Flamboyante", - "effect": "Ékaïser utilise la Force Z pour frapper l’ennemi de toutes ses forces. Augmente aussi ses stats." - }, - "zippyZap": { - "name": "Pika-Sprint", - "effect": "Une attaque électrique rapide comme l’éclair qui inflige un coup critique à coup sûr. Frappe en priorité." - }, - "splishySplash": { - "name": "Pika-Splash", - "effect": "Pikachu frappe l’adversaire avec une vague géante chargée d’électricité. Peut aussi paralyser l’ennemi." - }, - "floatyFall": { - "name": "Pika-Piqué", - "effect": "Pikachu prend de la hauteur avant de fondre sur son adversaire. Peut aussi apeurer l’ennemi." - }, - "pikaPapow": { - "name": "Pika-Fracas", - "effect": "Plus le lanceur est heureux, plus l’attaque est puissante." - }, - "bouncyBubble": { - "name": "Évo-Thalasso", - "effect": "L’adversaire est frappé par des bulles d’eau qui sont ensuite absorbées pour récupérer un nombre de PV égal aux dégâts infligés à l’ennemi." - }, - "buzzyBuzz": { - "name": "Évo-Dynamo", - "effect": "Une attaque qui foudroie et paralyse l’adversaire." - }, - "sizzlySlide": { - "name": "Évo-Flambo", - "effect": "Évoli s’embrase et percure violemment l’adversaire. Brule aussi l’ennemi." - }, - "glitzyGlow": { - "name": "Évo-Psycho", - "effect": "Évoli submerge l’adversaire sous un flot d’ondes psychiques et crée un mur fabuleux qui réduit les dégâts causés par les attaques spéciales de l’ennemi" - }, - "baddyBad": { - "name": "Évo-Ténébro", - "effect": "Évoli fait appel à son côté sombre pour attaquer l’adversaire et créer un mur fabuleux qui réduit les dégâts causés par les attaques physiques de l’ennemi." - }, - "sappySeed": { - "name": "Évo-Écolo", - "effect": "Une liane géante surgit du sol et bombarde l’adversaire de graines qui lui dérobent des PV à chaque tour. Ces PV sont ensuite absorbés par Évoli." - }, - "freezyFrost": { - "name": "Évo-Congélo", - "effect": "Évoli frappe l’adversaire avec un cristal de buée noire gelée. Annule les changements de stats de tous les Pokémon au combat." - }, - "sparklySwirl": { - "name": "Évo-Fabulo", - "effect": "Une attaque qui enserre l’adversaire dans un tourbillon de senteurs oppressantes. Guérit toutes les altérations de statut de l’équipe." - }, - "veeveeVolley": { - "name": "Évo-Chardasso", - "effect": "Le lanceur lance une attaque dès lors qu’un signe apparait sur le terrain. Les dégâts infligés sont proportionnels à l’affection de votre Pokémon" - }, - "doubleIronBash": { - "name": "Écrous d’Poing", - "effect": "Le lanceur fait pivoter l’écrou de sa poitrine deux fois d’affilée pour frapper l’adversaire avec ses bras. Peut apeurer l’ennemi (30% de chances)." - }, - "maxGuard": { - "name": "Gardomax", - "effect": "Le lanceur se protège de toutes les attaques. Peut échouer si utilisée plusieurs fois de suite." - }, - "dynamaxCannon": { - "name": "Canon Dynamax", - "effect": "Le lanceur attaque en libérant l’énergie concentrée dans son noyau. Inflige jusqu’à deux fois plus de dégâts si l’adversaire a un niveau très élevé." - }, - "snipeShot": { - "name": "Tir de Précision", - "effect": "Le lanceur parvient toujours à viser la cible voulue, en ignorant l’effet des talents et des capacités capables de détourner les attaques." - }, - "jawLock": { - "name": "Croque Fort", - "effect": "Le lanceur et sa cible ne peuvent plus être échangés jusqu’à ce que l’un d’entre eux tombe K.O. L’effet est annulé si l’un des deux Pokémon quitte le terrain." - }, - "stuffCheeks": { - "name": "Garde-à-Joues", - "effect": "Le lanceur mange la Baie qu’il tient, ce qui augmente beaucoup sa Défense." - }, - "noRetreat": { - "name": "Ultime Bastion", - "effect": "Le lanceur voit toutes ses stats augmenter, mais en contrepartie, il ne peut plus quitter le terrain." - }, - "tarShot": { - "name": "Goudronnage", - "effect": "Le lanceur recouvre sa cible de goudron liquide pour baisser sa Vitesse et la rendre vulnérable au feu." - }, - "magicPowder": { - "name": "Poudre Magique", - "effect": "Le lanceur recouvre sa cible d’une poudre magique qui change son type en Psy." - }, - "dragonDarts": { - "name": "Draco-Flèches", - "effect": "Le lanceur attaque en propulsant deux Fantyrm. S’il y a deux cibles, chacune d’entre elles est frappée par un Fantyrm." - }, - "teatime": { - "name": "Thérémonie", - "effect": "Le lanceur invite tous les Pokémon sur le terrain à prendre le gouter autour d’une tasse de thé. Ceux qui tiennent une Baie la mangent." - }, - "octolock": { - "name": "Octoprise", - "effect": "Empêche l’ennemi de fuir ou de quitter le terrain. Baisse la Défense et la Défense Spécial de l’ennemi chaque tour." - }, - "boltBeak": { - "name": "Prise de Bec", - "effect": "Inflige des dégâts et les double si le lanceur attaque avant l’ennemi." - }, - "fishiousRend": { - "name": "Branchicrok", - "effect": "Inflige des dégâts et les double si le lanceur attaque avant l’ennemi." - }, - "courtChange": { - "name": "Change-Côté", - "effect": "Une force mystérieuse intervertit les effets affectant chaque côté du terrain." - }, - "maxFlare": { - "name": "Pyromax", - "effect": "Une attaque de type Feu que seuls les Pokémon Dynamax peuvent utiliser. Fait briller le soleil pendant cinq tours." - }, - "maxFlutterby": { - "name": "Insectomax", - "effect": "Une attaque de type Insecte que seuls les Pokémon Dynamax peuvent utiliser. Baisse l’Attaque Spéciale de la cible." - }, - "maxLightning": { - "name": "Fulguromax", - "effect": "Une attaque de type Électrik que seuls les Pokémon Dynamax peuvent utiliser. Crée un Champ Électrifié qui dure cinq tours." - }, - "maxStrike": { - "name": "Normalomax", - "effect": "Une attaque de type Normal que seuls les Pokémon Dynamax peuvent utiliser. Baisse la Vitesse de la cible." - }, - "maxKnuckle": { - "name": "Pugilomax", - "effect": "Une attaque de type Combat que seuls les Pokémon dynamax peuvent utiliser. Augmente l’Attaque des Alliés." - }, - "maxPhantasm": { - "name": "Spectromax", - "effect": "Une attaque de type Spectre que seuls les Pokémon Dynamax peuvent utiliser. Baisse la Défense de la cible." - }, - "maxHailstorm": { - "name": "Cryomax", - "effect": "Une attaque de type Glace que seuls les Pokémon Dynamax peuvent utiliser. Invoque une tempête de grêle qui dure cinq tours." - }, - "maxOoze": { - "name": "Toxinomax", - "effect": "Une attaque de type Poison que seuls les Pokémon Dynamax peuvent utiliser. Augmente l’Attaque Spéciale des alliés." - }, - "maxGeyser": { - "name": "Hydromax", - "effect": "Une attaque de type Eau que seuls les Pokémon Dynamax peuvent utiliser. Invoque de fortes pluies qui durent cinq tours." - }, - "maxAirstream": { - "name": "Aéromax", - "effect": "Une attaque de type Vol que seuls les Pokémon Dynamax peuvent utiliser. Augmente la Vitesse des alliés." - }, - "maxStarfall": { - "name": "Enchantomax", - "effect": "Une attaque de type Fée que seuls les Pokémon Dynamax peuvent utiliser. Crée un Champ Brumeux qui dure cinq tours." - }, - "maxWyrmwind": { - "name": "Dracomax", - "effect": "Une attaque de type Dragon que seuls les Pokémon Dynamax peuvent utiliser. Baisse l’Attaque de la cible." - }, - "maxMindstorm": { - "name": "Psychomax", - "effect": "Une attaque de type Psy que seuls les Pokémon Dynamax peuvent utiliser. Crée un Champ Psychique qui dure cinq tours." - }, - "maxRockfall": { - "name": "Lithomax", - "effect": "Une attaque de type Roche que seuls les Pokémon Dynamax peuvent utiliser. Invoque une tempête de sable qui dure cinq tours." - }, - "maxQuake": { - "name": "Sismomax", - "effect": "Une attaque de type Sol que seuls les Pokémon Dynamax peuvent utiliser. Augmente la Défense Spéciale des alliés." - }, - "maxDarkness": { - "name": "Sinistromax", - "effect": "Une attaque de type Ténèbres que seuls les Pokémon Dynamax peuvent utiliser. Baisse la Défense Spéciale de la cible." - }, - "maxOvergrowth": { - "name": "Phytomax", - "effect": "Une attaque de type Plante que seuls les Pokémon Dynamax peuvent utiliser. Crée un Champ Herbu qui dure cinq tours." - }, - "maxSteelspike": { - "name": "Métallomax", - "effect": "Une attaque de type Acier que seuls les Pokémon Dynamax peuvent utiliser. Augmente la Défense des alliés." - }, - "clangorousSoul": { - "name": "Dracacophonie", - "effect": "Sacrifie une partie de ses PV pour augmenter toutes ses statistiques." - }, - "bodyPress": { - "name": "Big Splash", - "effect": "Le lanceur utilise son corps pour attaquer sa cible. Plus la Défense du lanceur est élevée, plus les dégâts infligés sont importants." - }, - "decorate": { - "name": "Nappage", - "effect": "Augmente fortement l’Attaque et l’Attaque Spéciale de la cible." - }, - "drumBeating": { - "name": "Tambour Battant", - "effect": "Le lanceur bat son tambour pour en diriger les racines sur la cible, l’attaquer, et baisser sa Vitesse." - }, - "snapTrap": { - "name": "Troquenard", - "effect": "Bloque l’ennemi pendant 4 à 5 tours." - }, - "pyroBall": { - "name": "Ballon Brulant", - "effect": "Le lanceur attaque avec un ballon fait à partir d’un caillou enflammé. Peut aussi bruler la cible (10% de chances)." - }, - "behemothBlade": { - "name": "Gladius Maximus", - "effect": "Le lanceur se transforme en une immense épée et pourfend sa cible. Cette capacité inflige le double de dégâts aux Pokémon Dynamax." - }, - "behemothBash": { - "name": "Aegis Maxima", - "effect": "Le lanceur se transforme en un immense bouclier et charge sa cible. Cette capacité inflige le double de dégâts aux Pokémon Dynamax." - }, - "auraWheel": { - "name": "Roue Libre", - "effect": "Inflige et change en type Ténèbres" - }, - "breakingSwipe": { - "name": "Abattage", - "effect": "Le lanceur balaie violemment le camp adverse avec son immense queue. Baisse l’Attaque de la cible." - }, - "branchPoke": { - "name": "Tapotige", - "effect": "Le lanceur attaque sa cible en la piquant avec une branche pointue." - }, - "overdrive": { - "name": "Overdrive", - "effect": "Le lanceur gratte ses cordes de guitare ou de basse pour créer de violentes vibrations sonores qui blessent la cible." - }, - "appleAcid": { - "name": "Acide Malique", - "effect": "Le lanceur projette un liquide corrosif créé à partir d’une pomme acide sur la cible, ce qui baisse la Défense Spéciale de celle-ci." - }, - "gravApple": { - "name": "Force G", - "effect": "Le lanceur fait tomber une pomme de très haut sur la cible, ce qui baisse la Défense de celle-ci." - }, - "spiritBreak": { - "name": "Choc Émotionnel", - "effect": "Le lanceur attaque la cible avec une telle force que celle-ci peut s’en retrouver profondément troublée et voir son Attaque Spéciale baisser." - }, - "strangeSteam": { - "name": "Vapeur Féérique", - "effect": "Inflige des dégâts et peut rendre confus l’ennemi." - }, - "lifeDew": { - "name": "Fontaine de Vie", - "effect": "Le lanceur projette une eau mystérieuse sur le terrain pour restaurer ses PV et ceux de ses alliés au combat." - }, - "obstruct": { - "name": "Blocage", - "effect": "Protège le lanceur des attaques de contact. Baisse la Défense de deux crans si l’ennemi a tenté une attaque de contact." - }, - "falseSurrender": { - "name": "Fourbette", - "effect": "Le lanceur fait semblant de se prosterner et utilise ses cheveux pour transpercer sa cible. N’échoue jamais." - }, - "meteorAssault": { - "name": "Joute Astrale", - "effect": "Inflige de gros dégâts mais oblige le lanceur à se reposer pendant un tour." - }, - "eternabeam": { - "name": "Laser Infinimax", - "effect": "Inflige de gros dégâts mais oblige le lanceur à se reposer pendant un tour." - }, - "steelBeam": { - "name": "Métalaser", - "effect": "Le lanceur concentre du métal issu de tout son corps en un rayon qu’il projette violemment sur sa cible. Il subit aussi des dégâts." - }, - "expandingForce": { - "name": "Vaste Pouvoir", - "effect": "Le lanceur attaque la cible avec ses pouvoirs psychiques. Si un champ psychique est actif, la puissance de cette capacité augmente et elle touche tous les ennemis." - }, - "steelRoller": { - "name": "Métalliroue", - "effect": "Une attaque qui inflige des dégâts et fait disparaitre le champ actif, mais qui échoue s’il n’y en a pas à ce moment." - }, - "scaleShot": { - "name": "Rafale Écailles", - "effect": "Le lanceur projette des écailles sur la cible de deux à cinq fois d’affilée. Augmente la Vitesse, mais diminue la Défense." - }, - "meteorBeam": { - "name": "Laser Météore", - "effect": "Le lanceur concentre l’énergie cosmique au premier tour, ce qui augmente son Attaque Spéciale, et frappe au second." - }, - "shellSideArm": { - "name": "Kokiyarme", - "effect": "Une attaque physique ou spéciale, en fonction de ce qui inflige le plus de dégâts à la cible. Peut aussi empoisonner." - }, - "mistyExplosion": { - "name": "Explo-Brume", - "effect": "Le lanceur frappe tous les Pokémon autour de lui en explosant, ce qui le met K.O. La puissance de cette attaque augmente si un champ brumeux est actif." - }, - "grassyGlide": { - "name": "Gliss’Herbe", - "effect": "Le lanceur attaque la cible en glissant sur le terrain. Frappe toujours en priorité si un champ herbu est actif." - }, - "risingVoltage": { - "name": "Monte-Tension", - "effect": "Des éclairs surgissent du sol et frappent la cible. La puissance de cette attaque est doublée si la cible est sur un champ électrifié." - }, - "terrainPulse": { - "name": "Champlification", - "effect": "Une attaque qui utilise la force des champs pour projeter une aura. Son type et sa puissance varient selon le champ actif." - }, - "skitterSmack": { - "name": "Ravage Rampant", - "effect": "Le lanceur rampe derrière la cible pour l’attaquer, ce qui baisse l’Attaque Spéciale de celle-ci." - }, - "burningJealousy": { - "name": "Feu Envieux", - "effect": "Le lanceur attaque sa cible avec toute sa jalousie. Cette capacité brule tout Pokémon dont les stats ont augmenté pendant ce tour." - }, - "lashOut": { - "name": "Cent Rancunes", - "effect": "Le lanceur frappe la cible avec toute sa rancune. Si les stats du lanceur ont diminué pendant ce tour, la puissance de cette attaque est doublée." - }, - "poltergeist": { - "name": "Esprit Frappeur", - "effect": "Le lanceur manipule l’objet tenu par la cible pour l’attaquer. Cette capacité échoue si celle-ci ne tient rien." - }, - "corrosiveGas": { - "name": "Gaz Corrosif", - "effect": "Un gaz corrosif qui enveloppe tous les Pokémon alentour et qui dissout les objets qu’ils tiennent." - }, - "coaching": { - "name": "Coaching", - "effect": "Le lanceur coache ses alliés, augmentant ainsi leur Attaque et leur Défense." - }, - "flipTurn": { - "name": "Eau Revoir", - "effect": "Après son attaque, le lanceur revient à toute vitesse et change de place avec un Pokémon de l’équipe prêt à combattre." - }, - "tripleAxel": { - "name": "Triple Axel", - "effect": "Une série d’un à trois coups de pied distincts dont la puissance augmente à chaque fois que la capacité touche sa cible." - }, - "dualWingbeat": { - "name": "Double Volée", - "effect": "Le lanceur frappe la cible avec ses ailes deux fois d’affilée." - }, - "scorchingSands": { - "name": "Sable Ardent", - "effect": "Le lanceur projette du sable chauffé à blanc sur la cible, ce qui peut aussi la bruler (30% de chances)." - }, - "jungleHealing": { - "name": "Selve Salvatrice", - "effect": "Le lanceur fait appel au pouvoir de la jungle pour restaurer les PV et soigner les altérations d’état de ses alliés et de lui-même." - }, - "wickedBlow": { - "name": "Poing Obscur", - "effect": "Le lanceur assène un coup puissant à la cible. Cette technique qui inflige toujours un coup critique est réservée à ceux qui maitrisent la puissance des Ténèbres." - }, - "surgingStrikes": { - "name": "Torrent de Coups", - "effect": "Le lanceur assène trois coups fluides à la cible. Cette technique qui inflige toujours un coup critique est réservée à ceux qui maitrisent la puissance de l’Eau." - }, - "thunderCage": { - "name": "Voltageôle", - "effect": "Le lanceur frappe la cible, et le piège dans une prison électrique qui dure de quatre à cinq tours." - }, - "dragonEnergy": { - "name": "Draco-Énergie", - "effect": "Le lanceur utilise son énergie vitale pour attaquer la cible. Moins il a de PV, moins l’attaque est puissante." - }, - "freezingGlare": { - "name": "Regard Glaçant", - "effect": "Les yeux du lanceur tirent des rayons psychiques qui attaquent la cible et peuvent aussi la geler (10% de chances)." - }, - "fieryWrath": { - "name": "Fureur Ardente", - "effect": "Le lanceur canalise sa colère et la transforme en émanation brulante, avec laquelle il attaque la cible, ce qui peut aussi apeurer celle-ci (20% de chances)." - }, - "thunderousKick": { - "name": "Coup Fulgurant", - "effect": "Le lanceur assène un coup de pied à la cible à la vitesse de l’éclair. Baisse aussi la Défense de la cible." - }, - "glacialLance": { - "name": "Lance de Glace", - "effect": "Le lanceur attaque la cible avec une lance de glace entourée d’un blizzard." - }, - "astralBarrage": { - "name": "Éclat Spectral", - "effect": "Le lanceur attaque la cible avec une multitude de petits spectres." - }, - "eerieSpell": { - "name": "Sort Sinistre", - "effect": "Le lanceur attaque avec de puissants pouvoirs psychiques et retire 3 PP de la dernière capacité utilisée par la cible." - }, - "direClaw": { - "name": "Griffes Funestes", - "effect": "Le lanceur attaque avec des griffes destructrices en visant les points faibles. La cible peut aussi être empoisonnée, paralysée, ou endormie." - }, - "psyshieldBash": { - "name": "Sprint Bouclier", - "effect": "Le lanceur s’enveloppe d’énergie psychique et frappe sa cible de plein fouet. Cela augmente également la Défense du lanceur." - }, - "powerShift": { - "name": "Échange Force", - "effect": "Le lanceur échange son Attaque avec sa Défense." - }, - "stoneAxe": { - "name": "Hache de Pierre", - "effect": "Le lanceur attaque le point faible de sa cible avec sa hache de pierre. Les débris de pierre se mettent alors à flotter autour de la cible." - }, - "springtideStorm": { - "name": "Typhon Passionné", - "effect": "Le lanceur déclenche un violent typhon de haine et d’amour qui s’abat sur la cible. Peut baisser l’Attaque de celle-ci." - }, - "mysticalPower": { - "name": "Force Mystique", - "effect": "Le lanceur attaque en libérant un pouvoir mystique. Cela augmente également son Attaque Spéciale." - }, - "ragingFury": { - "name": "Grand Courroux", - "effect": "Le lanceur se déchaine et attaque en projetant de violentes flammes pendant deux ou trois tours. Il devient ensuite confus." - }, - "waveCrash": { - "name": "Aquatacle", - "effect": "Le lanceur se recouvre entièrement d’eau avant de charger sa cible. Cela blesse aussi gravement le lanceur." - }, - "chloroblast": { - "name": "Herblast", - "effect": "Le lanceur tire un concentré de sa propre chlorophylle sur la cible, ce qui le blesse également." - }, - "mountainGale": { - "name": "Bise Glaciaire", - "effect": "Le lanceur envoie un bloc de glace de la taille d’un iceberg sur la cible, ce qui peut aussi l’apeurer (30% de chances)." - }, - "victoryDance": { - "name": "Danse Victoire", - "effect": "Le lanceur danse vigoureusement pour invoquer la victoire, ce qui augmente son Attaque, sa Défense et sa Vitesse." - }, - "headlongRush": { - "name": "Assaut Frontal", - "effect": "Le lanceur charge la cible de toutes ses forces, ce qui baisse la Défense et la Défense Spéciale du lanceur." - }, - "barbBarrage": { - "name": "Multitoxik", - "effect": "Une multitude de pointes toxiques frappent la cible et peuvent l’empoisonner. La puissance est doublée si celle-ci est déjà empoisonnée (30% de chances en Style Normal et 50% de chances en Style Puissant)." - }, - "esperWing": { - "name": "Ailes Psycho", - "effect": "Le lanceur entaille la cible avec ses ailes renforcées par une émanation psychique. Taux de critiques élevé. Cela augmente la Vitesse du lanceur." - }, - "bitterMalice": { - "name": "Cœur de Rancœur", - "effect": "Une rancœur glaciale frappe la cible et baisse son Attaque." - }, - "shelter": { - "name": "Mur Fumigène", - "effect": "Rend la peau du lanceur dure comme un mur de fer, ce qui augmente beaucoup sa Défense." - }, - "tripleArrows": { - "name": "Triple Flèche", - "effect": "Le lanceur donne un coup de pied et tire trois flèches simultanément, ce qui peut baisser la Défense de la cible ou l’apeurer (30% de chances). Taux de critiques élevé." - }, - "infernalParade": { - "name": "Cortège Funèbre", - "effect": "Une multitude de boules de feu frappent la cible, ce qui peut aussi la bruler (30% de chances et 50% en Style Puissant). La puissance est doublée si celle-ci souffre d’une altération de statut." - }, - "ceaselessEdge": { - "name": "Vagues à Lames", - "effect": "Des lames de coquillages entaillent la cible en visant ses points faibles. Les débris de coquillage se répandent sous la forme de picots aux pieds de la cible." - }, - "bleakwindStorm": { - "name": "Typhon Hivernal", - "effect": "Le lanceur déclenche un typhon froid et brutal qui fait trembler le cœur et le corps de la cible, ce qui peut aussi baisser sa Vitesse." - }, - "wildboltStorm": { - "name": "Typhon Fulgurant", - "effect": "Le lanceur déclenche un violent typhon orageux dont les rafales et la foudre frappent la cible, ce qui peut aussi la paralyser (30% de chances en Style Normal et 50% en Style Puissant)." - }, - "sandsearStorm": { - "name": "Typhon Pyrosable", - "effect": "Le lanceur déclenche un violent typhon mêlé à du sable ardent qui s’abat sur la cible, ce qui peut la bruler (30% de chances et 50% en Style Puissant)." - }, - "lunarBlessing": { - "name": "Prière Lunaire", - "effect": "Le lanceur adresse une prière à la lune pour restaurer les PV et soigner ses altérations de statut ainsi que celles de ses alliés." - }, - "takeHeart": { - "name": "Extravaillance", - "effect": "Le lanceur fait preuve de bravoure pour soigner ses altérations de statut et augmenter sa puissance offensive et défensive." - }, - "gMaxWildfire": { - "name": "Fournaise G-Max", - "effect": "Une attaque de type Feu que seul un Dracaufeu Gigamax peut utiliser. Pendant quatre tours, la cible continue de subir des dégâts." - }, - "gMaxBefuddle": { - "name": "Illusion G-Max", - "effect": "Une attaque de type Insecte que seul un Papilusion Gigamax peut utiliser. Empoisonne, paralyse ou endort la cible." - }, - "gMaxVoltCrash": { - "name": "Foudre G-Max", - "effect": "Une attaque de type Électrik que seul un Pikachu Gigamax peut utiliser. Paralyse la cible." - }, - "gMaxGoldRush": { - "name": "Pactole G-Max", - "effect": "Une attaque de type Normal que seul un Miaouss Gigamax peut utiliser. Rend la cible confuse et permet d’obtenir de l’argent à la fin du combat." - }, - "gMaxChiStrike": { - "name": "Frappe G-Max", - "effect": "Une attaque de type Combat que seul un Mackogneur Gigamax peut utiliser. Augmente le taux de critiques du lanceur et de ses alliés." - }, - "gMaxTerror": { - "name": "Hantise G-Max", - "effect": "Une attaque de type Spectre que seul un Ectoplasma Gigamax peut utiliser. Empêche les Pokémon ennemis de quitter le combat." - }, - "gMaxResonance": { - "name": "Résonance G-Max", - "effect": "Une attaque de type Glace que seul un Lokhlass Gigamax peut utiliser. Réduit les dégâts causés par des capacités pendant cinq tours." - }, - "gMaxCuddle": { - "name": "Câlin G-Max", - "effect": "Une attaque de type Normal que seul un Évoli Gigamax peut utiliser. Rend la cible amoureuse." - }, - "gMaxReplenish": { - "name": "Récolte G-Max", - "effect": "Une attaque de type Normal que seul un Ronflex Gigamax peut utiliser. Restaure une Baie tenue qui a déjà été mangée." - }, - "gMaxMalodor": { - "name": "Pestilence G-Max", - "effect": "Une attaque de type Poison que seul un Miasmax Gigamax peut utiliser. Empoisonne la cible." - }, - "gMaxStonesurge": { - "name": "Récif G-Max", - "effect": "Une attaque de type Eau que seul un Torgamord Gigamax peut utiliser. Disperse des pierres aiguisées sur le terrain." - }, - "gMaxWindRage": { - "name": "Rafale G-Max", - "effect": "Une attaque de type Vol que seul un Corvaillus Gigamax peut utiliser. Permet de briser les barrières comme Protection et Mur Lumière." - }, - "gMaxStunShock": { - "name": "Choc G-Max", - "effect": "Une attaque de type Électrik que seul un Salarsen Gigamax peut utiliser. Empoisonne ou paralyse la cible." - }, - "gMaxFinale": { - "name": "Cure G-Max", - "effect": "Une attaque de type Fée que seul un Charmilly Gigamax peut utiliser. Restaure des PV aux alliés." - }, - "gMaxDepletion": { - "name": "Usure G-Max", - "effect": "Une attaque de type Dragon que seul un Duralugon Gigamax peut utiliser. Baisse les PP de la dernière capacité utilisée par la cible." - }, - "gMaxGravitas": { - "name": "Ondes G-Max", - "effect": "Une attaque de type Psy que seul un Astronelle Gigamax peut utiliser. Intensifie la gravité pendant cinq tours." - }, - "gMaxVolcalith": { - "name": "Téphra G-Max", - "effect": "Une attaque de type Roche que seul un Monthracite Gigamax peut utiliser. Pendant quatre tours, la cible continue de subir des dégâts." - }, - "gMaxSandblast": { - "name": "Enlisement G-Max", - "effect": "Une attaque de type Sol que seul un Dunaconda Gigamax peut utiliser. Emprisonne la cible dans une tempête de sable qui dure de quatre à cinq tours." - }, - "gMaxSnooze": { - "name": "Torpeur G-Max", - "effect": "Une attaque de type Ténèbres que seul un Angoliath Gigamax peut utiliser. Fait bâiller la cible qui s’endort au tour suivant." - }, - "gMaxTartness": { - "name": "Corrosion G-Max", - "effect": "Une attaque de type Plante que seul un Pomdrapi Gigamax peut utiliser. Réduit l’Esquive de la cible." - }, - "gMaxSweetness": { - "name": "Nectar G-Max", - "effect": "Une attaque de type Plante que seul un Dratatin Gigamax peut utiliser. Soigne les altérations de statut des alliés." - }, - "gMaxSmite": { - "name": "Sentence G-Max", - "effect": "Une attaque de type Fée que seul un Sorcilence Gigamax peut utiliser. Rend la cible confuse." - }, - "gMaxSteelsurge": { - "name": "Percée G-Max", - "effect": "Une attaque de type Acier que seul un Pachyradjah Gigamax peut utiliser. Disperse des pics aiguisés sur le terrain." - }, - "gMaxMeltdown": { - "name": "Fonte G-Max", - "effect": "Une attaque de type Acier que seul un Melmetal Gigamax peut utiliser. Empêche la cible d’utiliser la même capacité deux fois de suite." - }, - "gMaxFoamBurst": { - "name": "Bulles G-Max", - "effect": "Une attaque de type Eau que seul un Krabboss Gigamax peut utiliser. Réduit beaucoup la Vitesse de la cible." - }, - "gMaxCentiferno": { - "name": "Combustion G-Max", - "effect": "Une attaque de type Feu que seul un Scolocendre Gigamax peut utiliser. Emprisonne la cible dans un tourbillon de flammes qui dure de quatre à cinq tours." - }, - "gMaxVineLash": { - "name": "Fouet G-Max", - "effect": "Une attaque de type Plante que seul un Florizarre Gigamax peut utiliser. Inflige des dégâts à la cible pendant quatre tours." - }, - "gMaxCannonade": { - "name": "Canonnade G-Max", - "effect": "Une attaque de type Eau que seul un Tortank Gigamax peut utiliser. Inflige des dégâts à la cible pendant quatre tours." - }, - "gMaxDrumSolo": { - "name": "Percussion G-Max", - "effect": "Une attaque de type Plante que seul un Gorythmic Gigamax peut utiliser. Ignore le talent de la cible." - }, - "gMaxFireball": { - "name": "Pyroball G-Max", - "effect": "Une attaque de type Feu que seul un Pyrobut Gigamax peut utiliser. Ignore le talent de la cible." - }, - "gMaxHydrosnipe": { - "name": "Gâchette G-Max", - "effect": "Une attaque de type Eau que seul un Lézargus Gigamax peut utiliser. Ignore le talent de la cible." - }, - "gMaxOneBlow": { - "name": "Coup Final G-Max", - "effect": "Une attaque de type Ténèbres que seul un Shifours Gigamax peut utiliser. Cette frappe unique permet d’ignorer la capacité Gardomax." - }, - "gMaxRapidFlow": { - "name": "Multicoup G-Max", - "effect": "Une attaque de type Eau que seul un Shifours Gigamax peut utiliser. Cet enchainement de coups permet d’ignorer la capacité Gardomax." - }, - "teraBlast": { - "name": "Téra Explosion", - "effect": "Si le lanceur est téracristallisé, il libère l’énergie de son type Téracristal. La capacité utilise l’Attaque ou l’Attaque Spéciale, selon ce qui infligera le plus de dégâts." - }, - "silkTrap": { - "name": "Piège de Fil", - "effect": "Le lanceur déploie un piège de fil pour se protéger contre les attaques, et si un assaillant utilise une attaque directe contre lui, la Vitesse de l’assaillant baisse." - }, - "axeKick": { - "name": "Talon-Marteau", - "effect": "Le lanceur donne un coup de talon descendant à la cible, ce qui peut aussi la rendre confuse. S’il échoue, le lanceur se blesse." - }, - "lastRespects": { - "name": "Hommage Posthume", - "effect": "Le lanceur attaque pour venger ses alliés. Plus le nombre de Pokémon alliés mis K.O. est élevé, plus la puissance de cette capacité augmente." - }, - "luminaCrash": { - "name": "Lumino-Impact", - "effect": "Le lanceur attaque en émettant une étrange lumière qui ébranle l’esprit de la cible. Cela baisse beaucoup la Défense Spéciale de la cible." - }, - "orderUp": { - "name": "Plat du Jour", - "effect": "Le lanceur attaque avec adresse et élégance. S’il a un Nigirigon dans la gueule, une de ses stats augmente en fonction de la forme de celui-ci." - }, - "jetPunch": { - "name": "Poing Sonique", - "effect": "Le lanceur enveloppe son poing d’un torrent furieux et attaque si rapidement qu’on peine à le discerner. Frappe en priorité." - }, - "spicyExtract": { - "name": "Habanerage", - "effect": "Le lanceur relâche un concentré extrêmement pimenté sur la cible, ce qui augmente beaucoup l’Attaque de celle-ci, mais baisse aussi beaucoup sa Défense." - }, - "spinOut": { - "name": "Dérapage", - "effect": "Le lanceur met tout son poids sur ses pattes et effectue de violentes rotations, ce qui inflige des dégâts à la cible, mais baisse beaucoup la Vitesse du lanceur." - }, - "populationBomb": { - "name": "Prolifération", - "effect": "Le lanceur et ses congénères prolifèrent en masse et attaquent ensemble d’une à dix fois d’affilée." - }, - "iceSpinner": { - "name": "Cryo-Pirouette", - "effect": "Le lanceur enveloppe ses jambes d’une fine couche de glace et heurte la cible en tournant sur lui-même. Ses rotations détruisent le champ actif sur le terrain." - }, - "glaiveRush": { - "name": "Charge Glaive", - "effect": "Le lanceur se jette dans une charge inconsciente sur la cible. Au tour suivant, l’attaque de la cible inflige le double de dégâts et n’échoue jamais." - }, - "revivalBlessing": { - "name": "Second Souffle", - "effect": "Dans un élan de compassion, le lanceur adresse une prière afin de ranimer un Pokémon de l’équipe K.O. en lui rendant la moitié de ses PV." - }, - "saltCure": { - "name": "Salaison", - "effect": "Le lanceur couvre la cible de sel, ce qui lui inflige des dégâts à chaque tour. Si la cible est de type Acier ou Eau, ces dégâts sont plus élevés." - }, - "tripleDive": { - "name": "Triple Plongeon", - "effect": "Le lanceur effectue des plongeons parfaitement cadencés pour éclabousser la cible et lui infliger des dégâts trois fois d’affilée." - }, - "mortalSpin": { - "name": "Toupie Éclat", - "effect": "Le lanceur attaque en tournant sur lui-même et empoisonne la cible. Il se libère également des effets de capacités comme Étreinte, Ligotage ou Vampigraine." - }, - "doodle": { - "name": "Décalquage", - "effect": "Le lanceur capture l’essence de la cible et la décalque. Le talent du lanceur et de ses alliés devient alors identique à celui de la cible." - }, - "filletAway": { - "name": "Décharnement", - "effect": "Le lanceur sacrifie des PV pour beaucoup augmenter son Attaque, son Attaque Spéciale, et sa Vitesse." - }, - "kowtowCleave": { - "name": "Génusection", - "effect": "Le lanceur se prosterne devant la cible et profite de cette distraction pour l’attaquer avec une lame. N’échoue jamais." - }, - "flowerTrick": { - "name": "Magie Florale", - "effect": "Le lanceur attaque en jetant un bouquet de fleurs piégé sur la cible. N’échoue jamais et inflige toujours un coup critique." - }, - "torchSong": { - "name": "Chant Flamboyant", - "effect": "Le lanceur carbonise la cible en projetant sur elle de vives flammes créées par un chant. Cette capacité augmente l’Attaque Spéciale du lanceur." - }, - "aquaStep": { - "name": "Danse Aquatique", - "effect": "Le lanceur se joue de la cible et lui inflige des dégâts avec ses pas de danse gracieux et légers. Cette capacité augmente la Vitesse du lanceur." - }, - "ragingBull": { - "name": "Taurogne", - "effect": "Le lanceur charge la cible comme un taureau enragé. Le type de cette capacité dépend de la race du lanceur, et brise les barrières comme Mur Lumière et Protection." - }, - "makeItRain": { - "name": "Ruée d’Or", - "effect": "Le lanceur attaque en lançant de nombreuses pièces, ce qui baisse son Attaque Spéciale. Permet d’obtenir plus d’argent à la fin du combat." - }, - "psyblade": { - "name": "Lame Psychique", - "effect": "Le lanceur lacère la cible à l’aide d’une lame intangible. S’il se trouve dans un champ électrifié, la puissance de cette capacité augmente de 50 %." - }, - "hydroSteam": { - "name": "Hydrovapeur", - "effect": "Le lanceur asperge la cible avec un puissant jet d’eau bouillante. Quand le soleil brille, la puissance de cette capacité augmente de 50 % au lieu de baisser." - }, - "ruination": { - "name": "Cataclysme", - "effect": "Le lanceur déclenche un cataclysme qui baisse les PV de la cible de moitié." - }, - "collisionCourse": { - "name": "Nitro Crash", - "effect": "Le lanceur change de forme et s’écrase sur la cible dans une explosion antique. Si la capacité est super efficace, elle inflige encore plus de dégâts que d’ordinaire." - }, - "electroDrift": { - "name": "Turbo Volt", - "effect": "Le lanceur change de forme et fonce sur la cible en la perforant d’électricité futuriste. Si la capacité est super efficace, sa puissance augmente encore plus." - }, - "shedTail": { - "name": "Queulonage", - "effect": "Le lanceur crée un clone en sacrifiant des PV, puis il revient et échange sa place avec un Pokémon de l’équipe prêt à combattre." - }, - "chillyReception": { - "name": "Neigeux de Mots", - "effect": "Le lanceur fait un si mauvais jeu de mots qu’il jette un froid et échange sa place avec un Pokémon de l’équipe prêt à combattre. La neige tombe pendant cinq tours." - }, - "tidyUp": { - "name": "Grand Nettoyage", - "effect": "Le lanceur fait le ménage sur le terrain, ce qui annule les effets de Picots, Piège de Roc, Toile Gluante, Pics Toxik, et Clonage. Augmente l’Attaque et la Vitesse du lanceur." - }, - "snowscape": { - "name": "Chute de Neige", - "effect": "Le lanceur invoque une tempête de neige qui dure cinq tours, ce qui augmente la Défense des Pokémon de type Glace." - }, - "pounce": { - "name": "Bond", - "effect": "Le lanceur attaque en bondissant sur la cible, ce qui baisse la Vitesse de celle-ci." - }, - "trailblaze": { - "name": "Désherbaffe", - "effect": "Le lanceur surgit des hautes herbes pour attaquer la cible. Les mouvements agiles du lanceur augmentent sa Vitesse." - }, - "chillingWater": { - "name": "Douche Froide", - "effect": "Le lanceur attaque la cible en l’arrosant d’une eau si froide qu’elle détériore son esprit combatif. Baisse l’Attaque de la cible." - }, - "hyperDrill": { - "name": "Hyperceuse", - "effect": "Le lanceur fait tourner à toute vitesse la partie pointue de son corps afin de transpercer la cible. Ignore même les capacités comme Abri ou Détection." - }, - "twinBeam": { - "name": "Double Laser", - "effect": "Le lanceur projette d’étranges rayons lumineux avec ses yeux et inflige des dégâts deux fois d’affilée." - }, - "rageFist": { - "name": "Poing de Colère", - "effect": "Le lanceur transforme sa colère en énergie pour attaquer. Plus il a subi d’attaques, plus la puissance de cette capacité augmente." - }, - "armorCannon": { - "name": "Canon Blindé", - "effect": "Le lanceur tire un boulet de canon ardent provenant de sa propre armure sur la cible. Cela baisse la Défense et la Défense Spéciale du lanceur." - }, - "bitterBlade": { - "name": "Lame en Peine", - "effect": "Le lanceur concentre son amertume du monde des vivants dans la pointe de ses épées et tranche la cible. La moitié des dégâts infligés sont convertis en PV pour le lanceur." - }, - "doubleShock": { - "name": "Double Décharge", - "effect": "Le lanceur libère toute l’électricité contenue dans son corps pour infliger des dégâts élevés à la cible. Le lanceur perd le type Électrik." - }, - "gigatonHammer": { - "name": "Marteau Mastoc", - "effect": "Le lanceur met tout son corps à contribution pour attaquer la cible avec un immense marteau. Cette capacité ne peut pas être utilisée deux fois d’affilée." - }, - "comeuppance": { - "name": "Vindicte", - "effect": "Le lanceur contre-attaque avec un coup infligeant des dégâts supérieurs à ceux de la dernière capacité qui l’a blessé." - }, - "aquaCutter": { - "name": "Tranch’Aqua", - "effect": "Le lanceur projette de l’eau pressurisée qui entaille la cible comme une lame. Taux de critiques élevé." - }, - "blazingTorque": { - "name": "Crash Brulant", - "effect": "Crash Brulant inflige des dégâts et possède 30 % de chances de bruler l’adversaire." - }, - "wickedTorque": { - "name": "Crash Obscur", - "effect": "Crash Obscur inflige des dégâts et possède 10 % de chances d’endormir l’adversaire." - }, - "noxiousTorque": { - "name": "Crash Toxique", - "effect": "Crash Toxique inflige des dégâts et possède 30 % de chances d’empoisonner l’adversaire." - }, - "combatTorque": { - "name": "Crash Musclé", - "effect": "Crash Musclé inflige des dégâts et possède 30 % de chances de paralyser l’adversaire." - }, - "magicalTorque": { - "name": "Crash Magique", - "effect": "Crash Magique inflige des dégâts et possède 30 % de chances de rendre l’adversaire confus." - }, - "bloodMoon": { - "name": "Lune Rouge", - "effect": "Le lanceur concentre toute son énergie dans la lune rouge sang sur son front et la projette sur la cible. Cette capacité ne peut pas être utilisée deux fois d’affilée." - }, - "matchaGotcha": { - "name": "Mortier Matcha", - "effect": "Le lanceur remue son thé et en bombarde la cible. La moitié des dégâts infligés sont convertis en PV pour le lanceur. Cette capacité peut aussi bruler la cible." - }, - "syrupBomb": { - "name": "Bombe au Sirop", - "effect": "Le lanceur jette une bombe qui recouvre la cible de sirop gluant et fait progressivement baisser la Vitesse de la cible pendant trois tours." - }, - "ivyCudgel": { - "name": "Massue Liane", - "effect": "Le lanceur frappe la cible à l’aide d’une massue entourée d’une liane. Le type de cette capacité varie en fonction du masque que porte le lanceur. Taux de critiques élevé." - }, - "electroShot": { - "name": "Fulgurayon", - "effect": "Le lanceur absorbe de l’électricité au premier tour, ce qui augmente son Attaque Spéciale, et envoie une puissante décharge au second. S’il pleut, il l’envoie au premier tour." - }, - "teraStarstorm": { - "name": "Pluie Térastrale", - "effect": "Le lanceur bombarde la cible afin de l’éliminer grâce au pouvoir des cristaux. Si le lanceur est Terapagos sous sa Forme Stellaire, la capacité touche tous les ennemis." - }, - "fickleBeam": { - "name": "Laser Hasard", - "effect": "Le lanceur attaque en tirant un rayon lumineux. Il arrive parfois que toutes les têtes agissent ensemble, ce qui double la puissance de la capacité." - }, - "burningBulwark": { - "name": "Rempart Brulant", - "effect": "Le lanceur se protège contre les attaques grâce à son pelage incandescent, et si un assaillant utilise une attaque directe contre lui, il le brule." - }, - "thunderclap": { - "name": "Vif Éclair", - "effect": "Permet au lanceur d’attaquer la cible en priorité avec une décharge électrique. Échoue si la cible ne prépare pas une attaque." - }, - "mightyCleave": { - "name": "Lame Puissante", - "effect": "Le lanceur pourfend la cible avec la lumière accumulée sur sa tête. Cette attaque passe outre les protections." - }, - "tachyonCutter": { - "name": "Lame Tachyonique", - "effect": "Le lanceur concentre des particules élémentaires pour créer une lame qui inflige des dégâts à la cible deux fois d’affilée. N’échoue jamais." - }, - "hardPress": { - "name": "Pression Extrême", - "effect": "Le lanceur écrase la cible avec ses bras ou ses pinces. Plus il reste de PV à la cible, plus la puissance de la capacité augmente." - }, - "dragonCheer": { - "name": "Cri Draconique", - "effect": "Le lanceur galvanise ses alliés avec un encouragement draconique qui augmente leur taux de critiques. L’effet est plus puissant si les alliés ont le type Dragon." - }, - "alluringVoice": { - "name": "Voix Envoutante", - "effect": "Le lanceur attaque la cible avec sa voix angélique. Cette capacité rend la cible confuse si ses stats ont augmenté pendant ce tour." - }, - "temperFlare": { - "name": "Indignition", - "effect": "Le lanceur utilise la force de son dépit pour attaquer. S’il a utilisé une capacité qui a échoué au tour précédent, la puissance d’Indignition est doublée." - }, - "supercellSlam": { - "name": "Volt Assaut", - "effect": "Le lanceur se charge en électricité et fond sur la cible. S’il échoue, le lanceur se blesse." - }, - "psychicNoise": { - "name": "Dissonance Psy", - "effect": "Le lanceur attaque avec des ondes sonores dissonantes. Cela empêche la cible de récupérer des PV à l’aide de capacités, talents ou objets tenus pendant 2 tours." - }, - "upperHand": { - "name": "Prio-Parade", - "effect": "Le lanceur réagit instinctivement au moindre mouvement et donne un coup de paume qui apeure la cible. Échoue si cette dernière n’a pas utilisé une attaque prioritaire." - }, - "malignantChain": { - "name": "Chaine Malsaine", - "effect": "Le lanceur ligote la cible avec une chaine faite de poison et lui injecte un venin corrosif, ce qui peut aussi gravement l’empoisonner." - } -} diff --git a/src/locales/fr/nature.json b/src/locales/fr/nature.json deleted file mode 100644 index 95f2ef64142..00000000000 --- a/src/locales/fr/nature.json +++ /dev/null @@ -1,27 +0,0 @@ -{ - "Hardy": "Hardi", - "Lonely": "Solo", - "Brave": "Brave", - "Adamant": "Rigide", - "Naughty": "Mauvais", - "Bold": "Assuré", - "Docile": "Docile", - "Relaxed": "Relax", - "Impish": "Malin", - "Lax": "Lâche", - "Timid": "Timide", - "Hasty": "Pressé", - "Serious": "Sérieux", - "Jolly": "Jovial", - "Naive": "Naïf", - "Modest": "Modeste", - "Mild": "Doux", - "Quiet": "Discret", - "Bashful": "Pudique", - "Rash": "Foufou", - "Calm": "Calme", - "Gentle": "Gentil", - "Sassy": "Malpoli", - "Careful": "Prudent", - "Quirky": "Bizarre" -} \ No newline at end of file diff --git a/src/locales/fr/party-ui-handler.json b/src/locales/fr/party-ui-handler.json deleted file mode 100644 index a11640c80b3..00000000000 --- a/src/locales/fr/party-ui-handler.json +++ /dev/null @@ -1,49 +0,0 @@ -{ - "SEND_OUT": "Envoyer", - "SUMMARY": "Résumé", - "CANCEL": "Annuler", - "RELEASE": "Relâcher", - "APPLY": "Appliquer", - "TEACH": "Apprendre", - "SPLICE": "Fusionner", - "UNSPLICE": "Séparer", - "ACTIVATE": "Activer", - "DEACTIVATE": "Désactiver", - "TRANSFER": "Transférer", - "ALL": "Tout", - "PASS_BATON": "Relais", - "UNPAUSE_EVOLUTION": "Réactiver Évolution", - "PAUSE_EVOLUTION": "Interrompre Évolution", - "REVIVE": "Ranimer", - "RENAME": "Renommer", - "choosePokemon": "Sélectionnez un Pokémon.", - "doWhatWithThisPokemon": "Que faire avec ce Pokémon ?", - "noEnergy": "{{pokemonName}} n’a plus l’énergie\nde se battre !", - "hasEnergy": "{{pokemonName}} peut toujours\nse battre !", - "cantBeUsed": "{{pokemonName}} ne peut pas\nse battre pour ce challenge !", - "tooManyItems": "{{pokemonName}} porte trop\nd’exemplaires de cet objet !", - "anyEffect": "Cela n’aura aucun effet.", - "unpausedEvolutions": "{{pokemonName}} peut de nouveau évoluer.", - "pausedEvolutions": "{{pokemonName}} ne peut plus évoluer.", - "unspliceConfirmation": "Voulez-vous vraiment séparer {{fusionName}}\nde {{pokemonName}} ? {{fusionName}} sera perdu.", - "wasReverted": "{{fusionName}} est redevenu {{pokemonName}}.", - "releaseConfirmation": "Voulez-vous relâcher {{pokemonName}} ?", - "releaseInBattle": "Vous ne pouvez pas relâcher un Pokémon en combat !", - "selectAMove": "Sélectionnez une capacité.", - "changeQuantity": "Sélect. un objet à transférer.\nChangez la quantité avec < et >.", - "selectAnotherPokemonToSplice": "Sélectionnez un autre Pokémon à séparer.", - "cancel": "Sortir", - "able": "Apte", - "notAble": "Pas Apte", - "learned": "Appris", - "goodbye": "Au revoir, {{pokemonName}} !", - "byebye": "Bye-bye, {{pokemonName}} !", - "farewell": "Adieu, {{pokemonName}} !", - "soLong": "Salut, {{pokemonName}} !", - "thisIsWhereWePart": "C’est là qu’on se sépare, {{pokemonName}} !", - "illMissYou": "Tu vas me manquer, {{pokemonName}} !", - "illNeverForgetYou": "Je ne t’oublierai pas, {{pokemonName}} !", - "untilWeMeetAgain": "À la prochaine, {{pokemonName}} !", - "sayonara": "Sayonara, {{pokemonName}} !", - "smellYaLater": "À la revoyure, {{pokemonName}} !" -} diff --git a/src/locales/fr/pokeball.json b/src/locales/fr/pokeball.json deleted file mode 100644 index a2589141907..00000000000 --- a/src/locales/fr/pokeball.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "pokeBall": "Poké Ball", - "greatBall": "Super Ball", - "ultraBall": "Hyper Ball", - "rogueBall": "Rogue Ball", - "masterBall": "Master Ball", - "luxuryBall": "Luxe Ball" -} \ No newline at end of file diff --git a/src/locales/fr/pokemon-form-battle.json b/src/locales/fr/pokemon-form-battle.json deleted file mode 100644 index b100622f03f..00000000000 --- a/src/locales/fr/pokemon-form-battle.json +++ /dev/null @@ -1,14 +0,0 @@ -{ - "mega": "Méga-{{pokemonName}}", - "mega-x": "Méga-{{pokemonName}} X", - "mega-y": "Méga-{{pokemonName}} Y", - "primal": "Primo-{{pokemonName}}", - "gigantamax": "{{pokemonName}} Gigamax", - "eternamax": "{{pokemonName}} Infinimax", - "megaChange": "{{preName}} méga-évolue\nen {{pokemonName}} !", - "gigantamaxChange": "{{preName}} se gigamaxe\nen {{pokemonName}} !", - "eternamaxChange": "{{preName}} devient\n{{pokemonName}} !", - "revertChange": "{{pokemonName}} retourne\nà sa forme initiale !", - "formChange": "{{preName}} change de forme !", - "disguiseChange": "Le déguisement absorbe l’attaque !" -} \ No newline at end of file diff --git a/src/locales/fr/pokemon-form.json b/src/locales/fr/pokemon-form.json deleted file mode 100644 index 44f2bcecf2c..00000000000 --- a/src/locales/fr/pokemon-form.json +++ /dev/null @@ -1,170 +0,0 @@ -{ - "pikachuCosplay": "Cosplayeur", - "pikachuCoolCosplay": "Cosplay Rockeur", - "pikachuBeautyCosplay": "Cosplay Lady", - "pikachuCuteCosplay": "Cosplay Star", - "pikachuSmartCosplay": "Cosplay Docteur", - "pikachuToughCosplay": "Cosplay Catcheur", - "pikachuPartner": "Partenaire", - "eeveePartner": "Partenaire", - "pichuSpiky": "Troizépi", - "unownA": "A", - "unownB": "B", - "unownC": "C", - "unownD": "D", - "unownE": "E", - "unownF": "F", - "unownG": "G", - "unownH": "H", - "unownI": "I", - "unownJ": "J", - "unownK": "K", - "unownL": "L", - "unownM": "M", - "unownN": "N", - "unownO": "O", - "unownP": "P", - "unownQ": "Q", - "unownR": "R", - "unownS": "S", - "unownT": "T", - "unownU": "U", - "unownV": "V", - "unownW": "W", - "unownX": "X", - "unownY": "Y", - "unownZ": "Z", - "unownExclamation": "!", - "unownQuestion": "?", - "castformSunny": "Solaire", - "castformRainy": "Eau de Pluie", - "castformSnowy": "Blizzard", - "deoxysNormal": "Normal", - "burmyPlant": "Plante", - "burmySandy": "Sable", - "burmyTrash": "Déchet", - "shellosEast": "Orient", - "shellosWest": "Occident", - "rotomHeat": "Chaleur", - "rotomWash": "Lavage", - "rotomFrost": "Froid", - "rotomFan": "Hélice", - "rotomMow": "Tonte", - "giratinaAltered": "Alternatif", - "shayminLand": "Terrestre", - "basculinRedStriped": "Motif Rouge", - "basculinBlueStriped": "Motif Bleu", - "basculinWhiteStriped": "Motif Blanc", - "deerlingSpring": "Printemps", - "deerlingSummer": "Été", - "deerlingAutumn": "Automne", - "deerlingWinter": "Hiver", - "tornadusIncarnate": "Avatar", - "thundurusIncarnate": "Avatar", - "landorusIncarnate": "Avatar", - "keldeoOrdinary": "Normal", - "meloettaAria": "Chant", - "meloettaPirouette": "Danse", - "froakieBattleBond": "Synergie", - "scatterbugMeadow": "Floraison", - "scatterbugIcySnow": "Blizzard", - "scatterbugPolar": "Banquise", - "scatterbugTundra": "Glace", - "scatterbugContinental": "Continent", - "scatterbugGarden": "Verdure", - "scatterbugElegant": "Monarchie", - "scatterbugModern": "Métropole", - "scatterbugMarine": "Rivage", - "scatterbugArchipelago": "Archipel", - "scatterbugHighPlains": "Sécheresse", - "scatterbugSandstorm": "Sable", - "scatterbugRiver": "Delta", - "scatterbugMonsoon": "Cyclone", - "scatterbugSavanna": "Mangrove", - "scatterbugSun": "Zénith", - "scatterbugOcean": "Levant", - "scatterbugJungle": "Jungle", - "scatterbugFancy": "Fantaisie", - "scatterbugPokeBall": "Poké Ball", - "flabebeRed": "Rouge", - "flabebeYellow": "Jaune", - "flabebeOrange": "Orange", - "flabebeBlue": "Bleu", - "flabebeWhite": "Blanc", - "furfrouHeart": "Cœur", - "furfrouStar": "Étoile", - "furfrouDiamond": "Diamant", - "furfrouDebutante": "Demoiselle", - "furfrouMatron": "Madame", - "furfrouDandy": "Monsieur", - "furfrouLaReine": "Reine", - "furfrouKabuki": "Kabuki", - "furfrouPharaoh": "Pharaon", - "pumpkabooSmall": "Mini", - "pumpkabooLarge": "Maxi", - "pumpkabooSuper": "Ultra", - "xerneasNeutral": "Paisible", - "xerneasActive": "Déchaîné", - "zygarde50": "Forme 50%", - "zygarde10": "Forme 10%", - "zygarde50Pc": "Rassemblement Forme 50%", - "zygarde10Pc": "Rassemblement Forme 10%", - "zygardeComplete": "Parfait", - "oricorioBaile": "Flamenco", - "oricorioPompom": "Pom-Pom", - "oricorioPau": "Hula", - "oricorioSensu": "Buyō", - "rockruffOwnTempo": "Tempo Perso", - "miniorRedMeteor": "Météore Rouge", - "miniorOrangeMeteor": "Météore Orange", - "miniorYellowMeteor": "Météore Jaune", - "miniorGreenMeteor": "Météore Vert", - "miniorBlueMeteor": "Météore Bleu", - "miniorIndigoMeteor": "Météore Indigo", - "miniorVioletMeteor": "Météore Violet", - "miniorRed": "Rouge", - "miniorOrange": "Orange", - "miniorYellow": "Jaune", - "miniorGreen": "Vert", - "miniorBlue": "Bleu", - "miniorIndigo": "Indigo", - "miniorViolet": "Violet", - "mimikyuDisguised": "Déguisé", - "mimikyuBusted": "Démasqué", - "magearnaOriginal": "Couleur du Passé", - "marshadowZenith": "Zénith", - "sinisteaPhony": "Contrefaçon", - "sinisteaAntique": "Authentique", - "eiscueNoIce": "Tête Dégel", - "indeedeeMale": "Mâle", - "indeedeeFemale": "Femelle", - "morpekoFullBelly": "Rassasié", - "zacianHeroOfManyBattles": "Héros Aguerri", - "zamazentaHeroOfManyBattles": "Héros Aguerri", - "zarudeDada": "Papa", - "enamorusIncarnate": "Avatar", - "squawkabillyGreenPlumage": "Plumage Vert", - "squawkabillyBluePlumage": "Plumage Bleu", - "squawkabillyYellowPlumage": "Plumage Jaune", - "squawkabillyWhitePlumage": "Plumage Blanc", - "tatsugiriCurly": "Courbé", - "tatsugiriDroopy": "Affalé", - "tatsugiriStretchy": "Raide", - "gimmighoulChest": "Coffre", - "gimmighoulRoaming": "Marche", - "koraidonApexBuild": "Final", - "koraidonLimitedBuild": "Limité", - "koraidonSprintingBuild": "Course", - "koraidonSwimmingBuild": "Nage", - "koraidonGlidingBuild": "Vol", - "miraidonUltimateMode": "Ultime", - "miraidonLowPowerMode": "Bridé", - "miraidonDriveMode": "Terrestre", - "miraidonAquaticMode": "Aquatique", - "miraidonGlideMode": "Aérien", - "poltchageistCounterfeit": "Imitation", - "poltchageistArtisan": "Onéreux", - "paldeaTaurosCombat": "Combatif", - "paldeaTaurosBlaze": "Flamboyant", - "paldeaTaurosAqua": "Aquatique" -} \ No newline at end of file diff --git a/src/locales/fr/pokemon-info-container.json b/src/locales/fr/pokemon-info-container.json deleted file mode 100644 index 084310f7c94..00000000000 --- a/src/locales/fr/pokemon-info-container.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "moveset": "Capacités", - "gender": "Sexe :", - "ability": "Talent :", - "nature": "Nature :", - "form": "Forme :" -} diff --git a/src/locales/fr/pokemon-info.json b/src/locales/fr/pokemon-info.json deleted file mode 100644 index 4e53a31035d..00000000000 --- a/src/locales/fr/pokemon-info.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "Stat": { - "HP": "PV", - "HPshortened": "PV", - "ATK": "Attaque", - "ATKshortened": "Atq", - "DEF": "Défense", - "DEFshortened": "Déf", - "SPATK": "Atq. Spé.", - "SPATKshortened": "AtqSp", - "SPDEF": "Déf. Spé.", - "SPDEFshortened": "DéfSp", - "SPD": "Vitesse", - "SPDshortened": "Vit", - "ACC": "Précison", - "EVA": "Esquive", - "HPStat": "PV" - }, - "Type": { - "UNKNOWN": "???", - "NORMAL": "Normal", - "FIGHTING": "Combat", - "FLYING": "Vol", - "POISON": "Poison", - "GROUND": "Sol", - "ROCK": "Roche", - "BUG": "Insecte", - "GHOST": "Spectre", - "STEEL": "Acier", - "FIRE": "Feu", - "WATER": "Eau", - "GRASS": "Plante", - "ELECTRIC": "Électrik", - "PSYCHIC": "Psy", - "ICE": "Glace", - "DRAGON": "Dragon", - "DARK": "Ténèbres", - "FAIRY": "Fée", - "STELLAR": "Stellaire" - } -} diff --git a/src/locales/fr/pokemon-summary.json b/src/locales/fr/pokemon-summary.json deleted file mode 100644 index a038b3a51f9..00000000000 --- a/src/locales/fr/pokemon-summary.json +++ /dev/null @@ -1,44 +0,0 @@ -{ - "pokemonInfo": "Info Pokémon", - "status": "Statut", - "powerAccuracyCategory": "Puissance\nPrécision\nCatégorie", - "type": "Type", - "unknownTrainer": "Inconnu", - "ot": "D.O.", - "nature": "de nature", - "expPoints": "Points Exp.", - "nextLv": "N. suivant", - "cancel": "Annuler", - "memoString": "{{natureFragment}} de nature,\n{{metFragment}}", - "metFragment": { - "normal": "rencontré au N.{{level}},\n{{biome}}, Vague {{wave}}.", - "apparently": "apparemment rencontré au N.{{level}},\n{{biome}}." - }, - "natureFragment": { - "Hardy": "{{nature}}", - "Lonely": "{{nature}}", - "Brave": "{{nature}}", - "Adamant": "{{nature}}", - "Naughty": "{{nature}}", - "Bold": "{{nature}}", - "Docile": "{{nature}}", - "Relaxed": "{{nature}}", - "Impish": "{{nature}}", - "Lax": "{{nature}}", - "Timid": "{{nature}}", - "Hasty": "{{nature}}", - "Serious": "{{nature}}", - "Jolly": "{{nature}}", - "Naive": "{{nature}}", - "Modest": "{{nature}}", - "Mild": "{{nature}}", - "Quiet": "{{nature}}", - "Bashful": "{{nature}}", - "Rash": "{{nature}}", - "Calm": "{{nature}}", - "Gentle": "{{nature}}", - "Sassy": "{{nature}}", - "Careful": "{{nature}}", - "Quirky": "{{nature}}" - } -} diff --git a/src/locales/fr/pokemon.json b/src/locales/fr/pokemon.json deleted file mode 100644 index 3d6636c538a..00000000000 --- a/src/locales/fr/pokemon.json +++ /dev/null @@ -1,1084 +0,0 @@ -{ - "bulbasaur": "Bulbizarre", - "ivysaur": "Herbizarre", - "venusaur": "Florizarre", - "charmander": "Salamèche", - "charmeleon": "Reptincel", - "charizard": "Dracaufeu", - "squirtle": "Carapuce", - "wartortle": "Carabaffe", - "blastoise": "Tortank", - "caterpie": "Chenipan", - "metapod": "Chrysacier", - "butterfree": "Papilusion", - "weedle": "Aspicot", - "kakuna": "Coconfort", - "beedrill": "Dardargnan", - "pidgey": "Roucool", - "pidgeotto": "Roucoups", - "pidgeot": "Roucarnage", - "rattata": "Rattata", - "raticate": "Rattatac", - "spearow": "Piafabec", - "fearow": "Rapasdepic", - "ekans": "Abo", - "arbok": "Arbok", - "pikachu": "Pikachu", - "raichu": "Raichu", - "sandshrew": "Sabelette", - "sandslash": "Sablaireau", - "nidoran_f": "Nidoran♀", - "nidorina": "Nidorina", - "nidoqueen": "Nidoqueen", - "nidoran_m": "Nidoran♂", - "nidorino": "Nidorino", - "nidoking": "Nidoking", - "clefairy": "Mélofée", - "clefable": "Mélodelfe", - "vulpix": "Goupix", - "ninetales": "Feunard", - "jigglypuff": "Rondoudou", - "wigglytuff": "Grodoudou", - "zubat": "Nosferapti", - "golbat": "Nosferalto", - "oddish": "Mystherbe", - "gloom": "Ortide", - "vileplume": "Rafflesia", - "paras": "Paras", - "parasect": "Parasect", - "venonat": "Mimitoss", - "venomoth": "Aéromite", - "diglett": "Taupiqueur", - "dugtrio": "Triopikeur", - "meowth": "Miaouss", - "persian": "Persian", - "psyduck": "Psykokwak", - "golduck": "Akwakwak", - "mankey": "Férosinge", - "primeape": "Colossinge", - "growlithe": "Caninos", - "arcanine": "Arcanin", - "poliwag": "Ptitard", - "poliwhirl": "Têtarte", - "poliwrath": "Tartard", - "abra": "Abra", - "kadabra": "Kadabra", - "alakazam": "Alakazam", - "machop": "Machoc", - "machoke": "Machopeur", - "machamp": "Mackogneur", - "bellsprout": "Chétiflor", - "weepinbell": "Boustiflor", - "victreebel": "Empiflor", - "tentacool": "Tentacool", - "tentacruel": "Tentacruel", - "geodude": "Racaillou", - "graveler": "Gravalanch", - "golem": "Grolem", - "ponyta": "Ponyta", - "rapidash": "Galopa", - "slowpoke": "Ramoloss", - "slowbro": "Flagadoss", - "magnemite": "Magnéti", - "magneton": "Magnéton", - "farfetchd": "Canarticho", - "doduo": "Doduo", - "dodrio": "Dodrio", - "seel": "Otaria", - "dewgong": "Lamantine", - "grimer": "Tadmorv", - "muk": "Grotadmorv", - "shellder": "Kokiyas", - "cloyster": "Crustabri", - "gastly": "Fantominus", - "haunter": "Spectrum", - "gengar": "Ectoplasma", - "onix": "Onix", - "drowzee": "Soporifik", - "hypno": "Hypnomade", - "krabby": "Krabby", - "kingler": "Krabboss", - "voltorb": "Voltorbe", - "electrode": "Électrode", - "exeggcute": "Noeunoeuf", - "exeggutor": "Noadkoko", - "cubone": "Osselait", - "marowak": "Ossatueur", - "hitmonlee": "Kicklee", - "hitmonchan": "Tygnon", - "lickitung": "Excelangue", - "koffing": "Smogo", - "weezing": "Smogogo", - "rhyhorn": "Rhinocorne", - "rhydon": "Rhinoféros", - "chansey": "Leveinard", - "tangela": "Saquedeneu", - "kangaskhan": "Kangourex", - "horsea": "Hypotrempe", - "seadra": "Hypocéan", - "goldeen": "Poissirène", - "seaking": "Poissoroy", - "staryu": "Stari", - "starmie": "Staross", - "mr_mime": "M. Mime", - "scyther": "Insécateur", - "jynx": "Lippoutou", - "electabuzz": "Élektek", - "magmar": "Magmar", - "pinsir": "Scarabrute", - "tauros": "Tauros", - "magikarp": "Magicarpe", - "gyarados": "Léviator", - "lapras": "Lokhlass", - "ditto": "Métamorph", - "eevee": "Évoli", - "vaporeon": "Aquali", - "jolteon": "Voltali", - "flareon": "Pyroli", - "porygon": "Porygon", - "omanyte": "Amonita", - "omastar": "Amonistar", - "kabuto": "Kabuto", - "kabutops": "Kabutops", - "aerodactyl": "Ptéra", - "snorlax": "Ronflex", - "articuno": "Artikodin", - "zapdos": "Électhor", - "moltres": "Sulfura", - "dratini": "Minidraco", - "dragonair": "Draco", - "dragonite": "Dracolosse", - "mewtwo": "Mewtwo", - "mew": "Mew", - "chikorita": "Germignon", - "bayleef": "Macronium", - "meganium": "Méganium", - "cyndaquil": "Héricendre", - "quilava": "Feurisson", - "typhlosion": "Typhlosion", - "totodile": "Kaiminus", - "croconaw": "Crocrodil", - "feraligatr": "Aligatueur", - "sentret": "Fouinette", - "furret": "Fouinar", - "hoothoot": "Hoothoot", - "noctowl": "Noarfang", - "ledyba": "Coxy", - "ledian": "Coxyclaque", - "spinarak": "Mimigal", - "ariados": "Migalos", - "crobat": "Nostenfer", - "chinchou": "Loupio", - "lanturn": "Lanturn", - "pichu": "Pichu", - "cleffa": "Mélo", - "igglybuff": "Toudoudou", - "togepi": "Togepi", - "togetic": "Togetic", - "natu": "Natu", - "xatu": "Xatu", - "mareep": "Wattouat", - "flaaffy": "Lainergie", - "ampharos": "Pharamp", - "bellossom": "Joliflor", - "marill": "Marill", - "azumarill": "Azumarill", - "sudowoodo": "Simularbre", - "politoed": "Tarpaud", - "hoppip": "Granivol", - "skiploom": "Floravol", - "jumpluff": "Cotovol", - "aipom": "Capumain", - "sunkern": "Tournegrin", - "sunflora": "Héliatronc", - "yanma": "Yanma", - "wooper": "Axoloto", - "quagsire": "Maraiste", - "espeon": "Mentali", - "umbreon": "Noctali", - "murkrow": "Cornèbre", - "slowking": "Roigada", - "misdreavus": "Feuforêve", - "unown": "Zarbi", - "wobbuffet": "Qulbutoké", - "girafarig": "Girafarig", - "pineco": "Pomdepik", - "forretress": "Foretress", - "dunsparce": "Insolourdo", - "gligar": "Scorplane", - "steelix": "Steelix", - "snubbull": "Snubbull", - "granbull": "Granbull", - "qwilfish": "Qwilfish", - "scizor": "Cizayox", - "shuckle": "Caratroc", - "heracross": "Scarhino", - "sneasel": "Farfuret", - "teddiursa": "Teddiursa", - "ursaring": "Ursaring", - "slugma": "Limagma", - "magcargo": "Volcaropod", - "swinub": "Marcacrin", - "piloswine": "Cochignon", - "corsola": "Corayon", - "remoraid": "Rémoraid", - "octillery": "Octillery", - "delibird": "Cadoizo", - "mantine": "Démanta", - "skarmory": "Airmure", - "houndour": "Malosse", - "houndoom": "Démolosse", - "kingdra": "Hyporoi", - "phanpy": "Phanpy", - "donphan": "Donphan", - "porygon2": "Porygon2", - "stantler": "Cerfrousse", - "smeargle": "Queulorior", - "tyrogue": "Debugant", - "hitmontop": "Kapoera", - "smoochum": "Lippouti", - "elekid": "Élekid", - "magby": "Magby", - "miltank": "Écrémeuh", - "blissey": "Leuphorie", - "raikou": "Raikou", - "entei": "Entei", - "suicune": "Suicune", - "larvitar": "Embrylex", - "pupitar": "Ymphect", - "tyranitar": "Tyranocif", - "lugia": "Lugia", - "ho_oh": "Ho-Oh", - "celebi": "Celebi", - "treecko": "Arcko", - "grovyle": "Massko", - "sceptile": "Jungko", - "torchic": "Poussifeu", - "combusken": "Galifeu", - "blaziken": "Braségali", - "mudkip": "Gobou", - "marshtomp": "Flobio", - "swampert": "Laggron", - "poochyena": "Medhyèna", - "mightyena": "Grahyèna", - "zigzagoon": "Zigzaton", - "linoone": "Linéon", - "wurmple": "Chenipotte", - "silcoon": "Armulys", - "beautifly": "Charmillon", - "cascoon": "Blindalys", - "dustox": "Papinox", - "lotad": "Nénupiot", - "lombre": "Lombre", - "ludicolo": "Ludicolo", - "seedot": "Grainipiot", - "nuzleaf": "Pifeuil", - "shiftry": "Tengalice", - "taillow": "Nirondelle", - "swellow": "Hélédelle", - "wingull": "Goélise", - "pelipper": "Bekipan", - "ralts": "Tarsal", - "kirlia": "Kirlia", - "gardevoir": "Gardevoir", - "surskit": "Arakdo", - "masquerain": "Maskadra", - "shroomish": "Balignon", - "breloom": "Chapignon", - "slakoth": "Parecool", - "vigoroth": "Vigoroth", - "slaking": "Monaflèmit", - "nincada": "Ningale", - "ninjask": "Ninjask", - "shedinja": "Munja", - "whismur": "Chuchmur", - "loudred": "Ramboum", - "exploud": "Brouhabam", - "makuhita": "Makuhita", - "hariyama": "Hariyama", - "azurill": "Azurill", - "nosepass": "Tarinor", - "skitty": "Skitty", - "delcatty": "Delcatty", - "sableye": "Ténéfix", - "mawile": "Mysdibule", - "aron": "Galekid", - "lairon": "Galegon", - "aggron": "Galeking", - "meditite": "Méditikka", - "medicham": "Charmina", - "electrike": "Dynavolt", - "manectric": "Élecsprint", - "plusle": "Posipi", - "minun": "Négapi", - "volbeat": "Muciole", - "illumise": "Lumivole", - "roselia": "Rosélia", - "gulpin": "Gloupti", - "swalot": "Avaltout", - "carvanha": "Carvanha", - "sharpedo": "Sharpedo", - "wailmer": "Wailmer", - "wailord": "Wailord", - "numel": "Chamallot", - "camerupt": "Camérupt", - "torkoal": "Chartor", - "spoink": "Spoink", - "grumpig": "Groret", - "spinda": "Spinda", - "trapinch": "Kraknoix", - "vibrava": "Vibraninf", - "flygon": "Libégon", - "cacnea": "Cacnea", - "cacturne": "Cacturne", - "swablu": "Tylton", - "altaria": "Altaria", - "zangoose": "Mangriff", - "seviper": "Séviper", - "lunatone": "Séléroc", - "solrock": "Solaroc", - "barboach": "Barloche", - "whiscash": "Barbicha", - "corphish": "Écrapince", - "crawdaunt": "Colhomard", - "baltoy": "Balbuto", - "claydol": "Kaorine", - "lileep": "Lilia", - "cradily": "Vacilys", - "anorith": "Anorith", - "armaldo": "Armaldo", - "feebas": "Barpau", - "milotic": "Milobellus", - "castform": "Morphéo", - "kecleon": "Kecleon", - "shuppet": "Polichombr", - "banette": "Branette", - "duskull": "Skelénox", - "dusclops": "Téraclope", - "tropius": "Tropius", - "chimecho": "Éoko", - "absol": "Absol", - "wynaut": "Okéoké", - "snorunt": "Stalgamin", - "glalie": "Oniglali", - "spheal": "Obalie", - "sealeo": "Phogleur", - "walrein": "Kaimorse", - "clamperl": "Coquiperl", - "huntail": "Serpang", - "gorebyss": "Rosabyss", - "relicanth": "Relicanth", - "luvdisc": "Lovdisc", - "bagon": "Draby", - "shelgon": "Drackhaus", - "salamence": "Drattak", - "beldum": "Terhal", - "metang": "Métang", - "metagross": "Métalosse", - "regirock": "Regirock", - "regice": "Regice", - "registeel": "Registeel", - "latias": "Latias", - "latios": "Latios", - "kyogre": "Kyogre", - "groudon": "Groudon", - "rayquaza": "Rayquaza", - "jirachi": "Jirachi", - "deoxys": "Deoxys", - "turtwig": "Tortipouss", - "grotle": "Boskara", - "torterra": "Torterra", - "chimchar": "Ouisticram", - "monferno": "Chimpenfeu", - "infernape": "Simiabraz", - "piplup": "Tiplouf", - "prinplup": "Prinplouf", - "empoleon": "Pingoléon", - "starly": "Étourmi", - "staravia": "Étourvol", - "staraptor": "Étouraptor", - "bidoof": "Keunotor", - "bibarel": "Castorno", - "kricketot": "Crikzik", - "kricketune": "Mélokrik", - "shinx": "Lixy", - "luxio": "Luxio", - "luxray": "Luxray", - "budew": "Rozbouton", - "roserade": "Roserade", - "cranidos": "Kranidos", - "rampardos": "Charkos", - "shieldon": "Dinoclier", - "bastiodon": "Bastiodon", - "burmy": "Cheniti", - "wormadam": "Cheniselle", - "mothim": "Papilord", - "combee": "Apitrini", - "vespiquen": "Apireine", - "pachirisu": "Pachirisu", - "buizel": "Mustébouée", - "floatzel": "Mustéflott", - "cherubi": "Ceribou", - "cherrim": "Ceriflor", - "shellos": "Sancoki", - "gastrodon": "Tritosor", - "ambipom": "Capidextre", - "drifloon": "Baudrive", - "drifblim": "Grodrive", - "buneary": "Laporeille", - "lopunny": "Lockpin", - "mismagius": "Magirêve", - "honchkrow": "Corboss", - "glameow": "Chaglam", - "purugly": "Chaffreux", - "chingling": "Korillon", - "stunky": "Moufouette", - "skuntank": "Moufflair", - "bronzor": "Archéomire", - "bronzong": "Archéodong", - "bonsly": "Manzaï", - "mime_jr": "Mime Jr.", - "happiny": "Ptiravi", - "chatot": "Pijako", - "spiritomb": "Spiritomb", - "gible": "Griknot", - "gabite": "Carmache", - "garchomp": "Carchacrok", - "munchlax": "Goinfrex", - "riolu": "Riolu", - "lucario": "Lucario", - "hippopotas": "Hippopotas", - "hippowdon": "Hippodocus", - "skorupi": "Rapion", - "drapion": "Drascore", - "croagunk": "Cradopaud", - "toxicroak": "Coatox", - "carnivine": "Vortente", - "finneon": "Écayon", - "lumineon": "Luminéon", - "mantyke": "Babimanta", - "snover": "Blizzi", - "abomasnow": "Blizzaroi", - "weavile": "Dimoret", - "magnezone": "Magnézone", - "lickilicky": "Coudlangue", - "rhyperior": "Rhinastoc", - "tangrowth": "Bouldeneu", - "electivire": "Élekable", - "magmortar": "Maganon", - "togekiss": "Togekiss", - "yanmega": "Yanmega", - "leafeon": "Phyllali", - "glaceon": "Givrali", - "gliscor": "Scorvol", - "mamoswine": "Mammochon", - "porygon_z": "Porygon-Z", - "gallade": "Gallame", - "probopass": "Tarinorme", - "dusknoir": "Noctunoir", - "froslass": "Momartik", - "rotom": "Motisma", - "uxie": "Créhelf", - "mesprit": "Créfollet", - "azelf": "Créfadet", - "dialga": "Dialga", - "palkia": "Palkia", - "heatran": "Heatran", - "regigigas": "Regigigas", - "giratina": "Giratina", - "cresselia": "Cresselia", - "phione": "Phione", - "manaphy": "Manaphy", - "darkrai": "Darkrai", - "shaymin": "Shaymin", - "arceus": "Arceus", - "victini": "Victini", - "snivy": "Vipélierre", - "servine": "Lianaja", - "serperior": "Majaspic", - "tepig": "Gruikui", - "pignite": "Grotichon", - "emboar": "Roitiflam", - "oshawott": "Moustillon", - "dewott": "Mateloutre", - "samurott": "Clamiral", - "patrat": "Ratentif", - "watchog": "Miradar", - "lillipup": "Ponchiot", - "herdier": "Ponchien", - "stoutland": "Mastouffe", - "purrloin": "Chacripan", - "liepard": "Léopardus", - "pansage": "Feuillajou", - "simisage": "Feuiloutan", - "pansear": "Flamajou", - "simisear": "Flamoutan", - "panpour": "Flotajou", - "simipour": "Flotoutan", - "munna": "Munna", - "musharna": "Mushana", - "pidove": "Poichigeon", - "tranquill": "Colombeau", - "unfezant": "Déflaisan", - "blitzle": "Zébibron", - "zebstrika": "Zéblitz", - "roggenrola": "Nodulithe", - "boldore": "Géolithe", - "gigalith": "Gigalithe", - "woobat": "Chovsourir", - "swoobat": "Rhinolove", - "drilbur": "Rototaupe", - "excadrill": "Minotaupe", - "audino": "Nanméouïe", - "timburr": "Charpenti", - "gurdurr": "Ouvrifier", - "conkeldurr": "Bétochef", - "tympole": "Tritonde", - "palpitoad": "Batracné", - "seismitoad": "Crapustule", - "throh": "Judokrak", - "sawk": "Karaclée", - "sewaddle": "Larveyette", - "swadloon": "Couverdure", - "leavanny": "Manternel", - "venipede": "Venipatte", - "whirlipede": "Scobolide", - "scolipede": "Brutapode", - "cottonee": "Doudouvet", - "whimsicott": "Farfaduvet", - "petilil": "Chlorobule", - "lilligant": "Fragilady", - "basculin": "Bargantua", - "sandile": "Mascaïman", - "krokorok": "Escroco", - "krookodile": "Crocorible", - "darumaka": "Darumarond", - "darmanitan": "Darumacho", - "maractus": "Maracachi", - "dwebble": "Crabicoque", - "crustle": "Crabaraque", - "scraggy": "Baggiguane", - "scrafty": "Baggaïd", - "sigilyph": "Cryptéro", - "yamask": "Tutafeh", - "cofagrigus": "Tutankafer", - "tirtouga": "Carapagos", - "carracosta": "Mégapagos", - "archen": "Arkéapti", - "archeops": "Aéroptéryx", - "trubbish": "Miamiasme", - "garbodor": "Miasmax", - "zorua": "Zorua", - "zoroark": "Zoroark", - "minccino": "Chinchidou", - "cinccino": "Pashmilla", - "gothita": "Scrutella", - "gothorita": "Mesmérella", - "gothitelle": "Sidérella", - "solosis": "Nucléos", - "duosion": "Méios", - "reuniclus": "Symbios", - "ducklett": "Couaneton", - "swanna": "Lakmécygne", - "vanillite": "Sorbébé", - "vanillish": "Sorboul", - "vanilluxe": "Sorbouboul", - "deerling": "Vivaldaim", - "sawsbuck": "Haydaim", - "emolga": "Emolga", - "karrablast": "Carabing", - "escavalier": "Lançargot", - "foongus": "Trompignon", - "amoonguss": "Gaulet", - "frillish": "Viskuse", - "jellicent": "Moyade", - "alomomola": "Mamanbo", - "joltik": "Statitik", - "galvantula": "Mygavolt", - "ferroseed": "Grindur", - "ferrothorn": "Noacier", - "klink": "Tic", - "klang": "Clic", - "klinklang": "Cliticlic", - "tynamo": "Anchwatt", - "eelektrik": "Lampéroie", - "eelektross": "Ohmassacre", - "elgyem": "Lewsor", - "beheeyem": "Neitram", - "litwick": "Funécire", - "lampent": "Mélancolux", - "chandelure": "Lugulabre", - "axew": "Coupenotte", - "fraxure": "Incisache", - "haxorus": "Tranchodon", - "cubchoo": "Polarhume", - "beartic": "Polagriffe", - "cryogonal": "Hexagel", - "shelmet": "Escargaume", - "accelgor": "Limaspeed", - "stunfisk": "Limonde", - "mienfoo": "Kungfouine", - "mienshao": "Shaofouine", - "druddigon": "Drakkarmin", - "golett": "Gringolem", - "golurk": "Golemastoc", - "pawniard": "Scalpion", - "bisharp": "Scalproie", - "bouffalant": "Frison", - "rufflet": "Furaiglon", - "braviary": "Gueriaigle", - "vullaby": "Vostourno", - "mandibuzz": "Vaututrice", - "heatmor": "Aflamanoir", - "durant": "Fermite", - "deino": "Solochi", - "zweilous": "Diamat", - "hydreigon": "Trioxhydre", - "larvesta": "Pyronille", - "volcarona": "Pyrax", - "cobalion": "Cobaltium", - "terrakion": "Terrakium", - "virizion": "Viridium", - "tornadus": "Boréas", - "thundurus": "Fulguris", - "reshiram": "Reshiram", - "zekrom": "Zekrom", - "landorus": "Démétéros", - "kyurem": "Kyurem", - "keldeo": "Keldeo", - "meloetta": "Meloetta", - "genesect": "Genesect", - "chespin": "Marisson", - "quilladin": "Boguérisse", - "chesnaught": "Blindépique", - "fennekin": "Feunnec", - "braixen": "Roussil", - "delphox": "Goupelin", - "froakie": "Grenousse", - "frogadier": "Croâporal", - "greninja": "Amphinobi", - "bunnelby": "Sapereau", - "diggersby": "Excavarenne", - "fletchling": "Passerouge", - "fletchinder": "Braisillon", - "talonflame": "Flambusard", - "scatterbug": "Lépidonille", - "spewpa": "Pérégrain", - "vivillon": "Prismillon", - "litleo": "Hélionceau", - "pyroar": "Némélios", - "flabebe": "Flabébé", - "floette": "Floette", - "florges": "Florges", - "skiddo": "Cabriolaine", - "gogoat": "Chevroum", - "pancham": "Pandespiègle", - "pangoro": "Pandarbare", - "furfrou": "Couafarel", - "espurr": "Psystigri", - "meowstic": "Mistigrix", - "honedge": "Monorpale", - "doublade": "Dimoclès", - "aegislash": "Exagide", - "spritzee": "Fluvetin", - "aromatisse": "Cocotine", - "swirlix": "Sucroquin", - "slurpuff": "Cupcanaille", - "inkay": "Sepiatop", - "malamar": "Sepiatroce", - "binacle": "Opermine", - "barbaracle": "Golgopathe", - "skrelp": "Venalgue", - "dragalge": "Kravarech", - "clauncher": "Flingouste", - "clawitzer": "Gamblast", - "helioptile": "Galvaran", - "heliolisk": "Iguolta", - "tyrunt": "Ptyranidur", - "tyrantrum": "Rexillius", - "amaura": "Amagara", - "aurorus": "Dragmara", - "sylveon": "Nymphali", - "hawlucha": "Brutalibré", - "dedenne": "Dedenne", - "carbink": "Strassie", - "goomy": "Mucuscule", - "sliggoo": "Colimucus", - "goodra": "Muplodocus", - "klefki": "Trousselin", - "phantump": "Brocélôme", - "trevenant": "Desséliande", - "pumpkaboo": "Pitrouille", - "gourgeist": "Banshitrouye", - "bergmite": "Grelaçon", - "avalugg": "Séracrawl", - "noibat": "Sonistrelle", - "noivern": "Bruyverne", - "xerneas": "Xerneas", - "yveltal": "Yveltal", - "zygarde": "Zygarde", - "diancie": "Diancie", - "hoopa": "Hoopa", - "volcanion": "Volcanion", - "rowlet": "Brindibou", - "dartrix": "Efflèche", - "decidueye": "Archéduc", - "litten": "Flamiaou", - "torracat": "Matoufeu", - "incineroar": "Félinferno", - "popplio": "Otaquin", - "brionne": "Otarlette", - "primarina": "Oratoria", - "pikipek": "Picassaut", - "trumbeak": "Piclairon", - "toucannon": "Bazoucan", - "yungoos": "Manglouton", - "gumshoos": "Argouste", - "grubbin": "Larvibule", - "charjabug": "Chrysapile", - "vikavolt": "Lucanon", - "crabrawler": "Crabagarre", - "crabominable": "Crabominable", - "oricorio": "Plumeline", - "cutiefly": "Bombydou", - "ribombee": "Rubombelle", - "rockruff": "Rocabot", - "lycanroc": "Lougaroc", - "wishiwashi": "Froussardine", - "mareanie": "Vorastérie", - "toxapex": "Prédastérie", - "mudbray": "Tiboudet", - "mudsdale": "Bourrinos", - "dewpider": "Araqua", - "araquanid": "Tarenbulle", - "fomantis": "Mimantis", - "lurantis": "Floramantis", - "morelull": "Spododo", - "shiinotic": "Lampignon", - "salandit": "Tritox", - "salazzle": "Malamandre", - "stufful": "Nounourson", - "bewear": "Chelours", - "bounsweet": "Croquine", - "steenee": "Candine", - "tsareena": "Sucreine", - "comfey": "Guérilande", - "oranguru": "Gouroutan", - "passimian": "Quartermac", - "wimpod": "Sovkipou", - "golisopod": "Sarmuraï", - "sandygast": "Bacabouh", - "palossand": "Trépassable", - "pyukumuku": "Concombaffe", - "type_null": "Type:0", - "silvally": "Silvallié", - "minior": "Météno", - "komala": "Dodoala", - "turtonator": "Boumata", - "togedemaru": "Togedemaru", - "mimikyu": "Mimiqui", - "bruxish": "Denticrisse", - "drampa": "Draïeul", - "dhelmise": "Sinistrail", - "jangmo_o": "Bébécaille", - "hakamo_o": "Écaïd", - "kommo_o": "Ékaïser", - "tapu_koko": "Tokorico", - "tapu_lele": "Tokopiyon", - "tapu_bulu": "Tokotoro", - "tapu_fini": "Tokopisco", - "cosmog": "Cosmog", - "cosmoem": "Cosmovum", - "solgaleo": "Solgaleo", - "lunala": "Lunala", - "nihilego": "Zéroïd", - "buzzwole": "Mouscoto", - "pheromosa": "Cancrelove", - "xurkitree": "Câblifère", - "celesteela": "Bamboiselle", - "kartana": "Katagami", - "guzzlord": "Engloutyran", - "necrozma": "Necrozma", - "magearna": "Magearna", - "marshadow": "Marshadow", - "poipole": "Vémini", - "naganadel": "Mandrillon", - "stakataka": "Ama-Ama", - "blacephalon": "Pierroteknik", - "zeraora": "Zeraora", - "meltan": "Meltan", - "melmetal": "Melmetal", - "grookey": "Ouistempo", - "thwackey": "Badabouin", - "rillaboom": "Gorythmic", - "scorbunny": "Flambino", - "raboot": "Lapyro", - "cinderace": "Pyrobut", - "sobble": "Larméléon", - "drizzile": "Arrozard", - "inteleon": "Lézargus", - "skwovet": "Rongourmand", - "greedent": "Rongrigou", - "rookidee": "Minisange", - "corvisquire": "Bleuseille", - "corviknight": "Corvaillus", - "blipbug": "Larvadar", - "dottler": "Coléodôme", - "orbeetle": "Astronelle", - "nickit": "Goupilou", - "thievul": "Roublenard", - "gossifleur": "Tournicoton", - "eldegoss": "Blancoton", - "wooloo": "Moumouton", - "dubwool": "Moumouflon", - "chewtle": "Khélocrok", - "drednaw": "Torgamord", - "yamper": "Voltoutou", - "boltund": "Fulgudog", - "rolycoly": "Charbi", - "carkol": "Wagomine", - "coalossal": "Monthracite", - "applin": "Verpom", - "flapple": "Pomdrapi", - "appletun": "Dratatin", - "silicobra": "Dunaja", - "sandaconda": "Dunaconda", - "cramorant": "Nigosier", - "arrokuda": "Embrochet", - "barraskewda": "Hastacuda", - "toxel": "Toxizap", - "toxtricity": "Salarsen", - "sizzlipede": "Grillepattes", - "centiskorch": "Scolocendre", - "clobbopus": "Poulpaf", - "grapploct": "Krakos", - "sinistea": "Théffroi", - "polteageist": "Polthégeist", - "hatenna": "Bibichut", - "hattrem": "Chapotus", - "hatterene": "Sorcilence", - "impidimp": "Grimalin", - "morgrem": "Fourbelin", - "grimmsnarl": "Angoliath", - "obstagoon": "Ixon", - "perrserker": "Berserkatt", - "cursola": "Corayôme", - "sirfetchd": "Palarticho", - "mr_rime": "M. Glaquette", - "runerigus": "Tutétékri", - "milcery": "Crèmy", - "alcremie": "Charmilly", - "falinks": "Hexadron", - "pincurchin": "Wattapik", - "snom": "Frissonille", - "frosmoth": "Beldeneige", - "stonjourner": "Dolman", - "eiscue": "Bekaglaçon", - "indeedee": "Wimessir", - "morpeko": "Morpeko", - "cufant": "Charibari", - "copperajah": "Pachyradjah", - "dracozolt": "Galvagon", - "arctozolt": "Galvagla", - "dracovish": "Hydragon", - "arctovish": "Hydragla", - "duraludon": "Duralugon", - "dreepy": "Fantyrm", - "drakloak": "Dispareptil", - "dragapult": "Lanssorien", - "zacian": "Zacian", - "zamazenta": "Zamazenta", - "eternatus": "Éthernatos", - "kubfu": "Wushours", - "urshifu": "Shifours", - "zarude": "Zarude", - "regieleki": "Regieleki", - "regidrago": "Regidrago", - "glastrier": "Blizzeval", - "spectrier": "Spectreval", - "calyrex": "Sylveroy", - "wyrdeer": "Cerbyllin", - "kleavor": "Hachécateur", - "ursaluna": "Ursaking", - "basculegion": "Paragruel", - "sneasler": "Farfurex", - "overqwil": "Qwilpik", - "enamorus": "Amovénus", - "sprigatito": "Poussacha", - "floragato": "Matourgeon", - "meowscarada": "Miascarade", - "fuecoco": "Chochodile", - "crocalor": "Crocogril", - "skeledirge": "Flâmigator", - "quaxly": "Coiffeton", - "quaxwell": "Canarbello", - "quaquaval": "Palmaval", - "lechonk": "Gourmelet", - "oinkologne": "Fragroin", - "tarountula": "Tissenboule", - "spidops": "Filentrappe", - "nymble": "Lilliterelle", - "lokix": "Gambex", - "pawmi": "Pohm", - "pawmo": "Pohmotte", - "pawmot": "Pohmarmotte", - "tandemaus": "Compagnol", - "maushold": "Famignol", - "fidough": "Pâtachiot", - "dachsbun": "Briochien", - "smoliv": "Olivini", - "dolliv": "Olivado", - "arboliva": "Arboliva", - "squawkabilly": "Tapatoès", - "nacli": "Selutin", - "naclstack": "Amassel", - "garganacl": "Gigansel", - "charcadet": "Charbambin", - "armarouge": "Carmadura", - "ceruledge": "Malvalame", - "tadbulb": "Têtampoule", - "bellibolt": "Ampibidou", - "wattrel": "Zapétrel", - "kilowattrel": "Fulgulairo", - "maschiff": "Grondogue", - "mabosstiff": "Dogrino", - "shroodle": "Gribouraigne", - "grafaiai": "Tag-Tag", - "bramblin": "Virovent", - "brambleghast": "Virevorreur", - "toedscool": "Terracool", - "toedscruel": "Terracruel", - "klawf": "Craparoi", - "capsakid": "Pimito", - "scovillain": "Scovilain", - "rellor": "Léboulérou", - "rabsca": "Bérasca", - "flittle": "Flotillon", - "espathra": "Cléopsytra", - "tinkatink": "Forgerette", - "tinkatuff": "Forgella", - "tinkaton": "Forgelina", - "wiglett": "Taupikeau", - "wugtrio": "Triopikeau", - "bombirdier": "Lestombaile", - "finizen": "Dofin", - "palafin": "Superdofin", - "varoom": "Vrombi", - "revavroom": "Vrombotor", - "cyclizar": "Motorizard", - "orthworm": "Ferdeter", - "glimmet": "Germéclat", - "glimmora": "Floréclat", - "greavard": "Toutombe", - "houndstone": "Tomberro", - "flamigo": "Flamenroule", - "cetoddle": "Piétacé", - "cetitan": "Balbalèze", - "veluza": "Délestin", - "dondozo": "Oyacata", - "tatsugiri": "Nigirigon", - "annihilape": "Courrousinge", - "clodsire": "Terraiste", - "farigiraf": "Farigiraf", - "dudunsparce": "Deusolourdo", - "kingambit": "Scalpereur", - "great_tusk": "Fort-Ivoire", - "scream_tail": "Hurle-Queue", - "brute_bonnet": "Fongus-Furie", - "flutter_mane": "Flotte-Mèche", - "slither_wing": "Rampe-Ailes", - "sandy_shocks": "Pelage-Sablé", - "iron_treads": "Roue-de-Fer", - "iron_bundle": "Hotte-de-Fer", - "iron_hands": "Paume-de-Fer", - "iron_jugulis": "Têtes-de-Fer", - "iron_moth": "Mite-de-Fer", - "iron_thorns": "Épine-de-Fer", - "frigibax": "Frigodo", - "arctibax": "Cryodo", - "baxcalibur": "Glaivodo", - "gimmighoul": "Mordudor", - "gholdengo": "Gromago", - "wo_chien": "Chongjian", - "chien_pao": "Baojian", - "ting_lu": "Dinglu", - "chi_yu": "Yuyu", - "roaring_moon": "Rugit-Lune", - "iron_valiant": "Garde-de-Fer", - "koraidon": "Koraidon", - "miraidon": "Miraidon", - "walking_wake": "Serpente-Eau", - "iron_leaves": "Vert-de-Fer", - "dipplin": "Pomdramour", - "poltchageist": "Poltchageist", - "sinistcha": "Théffroyable", - "okidogi": "Félicanis", - "munkidori": "Fortusimia", - "fezandipiti": "Favianos", - "ogerpon": "Ogerpon", - "archaludon": "Pondralugon", - "hydrapple": "Pomdorochi", - "gouging_fire": "Feu-Perçant", - "raging_bolt": "Ire-Foudre", - "iron_boulder": "Roc-de-Fer", - "iron_crown": "Chef-de-Fer", - "terapagos": "Terapagos", - "pecharunt": "Pêchaminus", - "alola_rattata": "Rattata", - "alola_raticate": "Rattatac", - "alola_raichu": "Raichu", - "alola_sandshrew": "Sabelette", - "alola_sandslash": "Sablaireau", - "alola_vulpix": "Goupix", - "alola_ninetales": "Feunard", - "alola_diglett": "Taupiqueur", - "alola_dugtrio": "Triopikeur", - "alola_meowth": "Miaouss", - "alola_persian": "Persian", - "alola_geodude": "Racaillou", - "alola_graveler": "Gravalanch", - "alola_golem": "Grolem", - "alola_grimer": "Tadmorv", - "alola_muk": "Grotadmorv", - "alola_exeggutor": "Noadkoko", - "alola_marowak": "Ossatueur", - "eternal_floette": "Floette", - "galar_meowth": "Miaouss", - "galar_ponyta": "Ponyta", - "galar_rapidash": "Galopa", - "galar_slowpoke": "Ramoloss", - "galar_slowbro": "Flagadoss", - "galar_farfetchd": "Canarticho", - "galar_weezing": "Smogogo", - "galar_mr_mime": "M. Mime", - "galar_articuno": "Artikodin", - "galar_zapdos": "Électhor", - "galar_moltres": "Sulfura", - "galar_slowking": "Roigada", - "galar_corsola": "Corayon", - "galar_zigzagoon": "Zigzaton", - "galar_linoone": "Linéon", - "galar_darumaka": "Darumarond", - "galar_darmanitan": "Darumacho", - "galar_yamask": "Tutafeh", - "galar_stunfisk": "Limonde", - "hisui_growlithe": "Caninos", - "hisui_arcanine": "Arcanin", - "hisui_voltorb": "Voltorbe", - "hisui_electrode": "Électrode", - "hisui_typhlosion": "Typhlosion", - "hisui_qwilfish": "Qwilfish", - "hisui_sneasel": "Farfuret", - "hisui_samurott": "Clamiral", - "hisui_lilligant": "Fragilady", - "hisui_zorua": "Zorua", - "hisui_zoroark": "Zoroark", - "hisui_braviary": "Gueriaigle", - "hisui_sliggoo": "Colimucus", - "hisui_goodra": "Muplodocus", - "hisui_avalugg": "Séracrawl", - "hisui_decidueye": "Archéduc", - "paldea_tauros": "Tauros", - "paldea_wooper": "Axoloto", - "bloodmoon_ursaluna": "Ursaking" -} \ No newline at end of file diff --git a/src/locales/fr/run-history.json b/src/locales/fr/run-history.json deleted file mode 100644 index 1def265acf1..00000000000 --- a/src/locales/fr/run-history.json +++ /dev/null @@ -1,37 +0,0 @@ -{ - "victory": "Victoire !", - "defeatedWild": "Battu par ", - "defeatedTrainer": "Battu par ", - "defeatedTrainerDouble": "Battu par Duo", - "defeatedRival": "Battu par Rivale", - "defeated": "Vaincu", - "defeatedWild_female": "Battue par ", - "defeatedTrainer_female": "Battue par ", - "defeatedTrainerDouble_female": "Battue par Duo", - "defeatedRival_female": "Battue par Rival", - "defeated_female": "Vaincue", - "luck": "Chance ", - "score": "Score", - "mode": "Mode ", - "challengeRules": "Règles ", - "challengeMonoGen1": "1G", - "challengeMonoGen2": "2G", - "challengeMonoGen3": "3G", - "challengeMonoGen4": "4G", - "challengeMonoGen5": "5G", - "challengeMonoGen6": "6G", - "challengeMonoGen7": "7G", - "challengeMonoGen8": "8G", - "challengeMonoGen9": "9G", - "playerItems": "Objets Dresseur", - "personalBest": "Record personnel !", - "SPDshortened": "Vit.", - "runInfo": "Infos session", - "money": "Argent", - "runLength": "Durée session ", - "viewHeldItems": "Objets tenus", - "hallofFameText": "Bienvenue au Panthéon !", - "hallofFameText_female": "Bienvenue au Panthéon !", - "viewHallOfFame": "Voir le Panthéon", - "viewEndingSplash": "Voir l’illustration\nde fin" -} \ No newline at end of file diff --git a/src/locales/fr/save-slot-select-ui-handler.json b/src/locales/fr/save-slot-select-ui-handler.json deleted file mode 100644 index 4fe6b791a49..00000000000 --- a/src/locales/fr/save-slot-select-ui-handler.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "overwriteData": "Effacer les données de l’emplacement sélectionné ?", - "loading": "Chargement…", - "wave": "Vague", - "lv": "N.", - "empty": "Vide" -} \ No newline at end of file diff --git a/src/locales/fr/settings.json b/src/locales/fr/settings.json deleted file mode 100644 index e310f5d5733..00000000000 --- a/src/locales/fr/settings.json +++ /dev/null @@ -1,111 +0,0 @@ -{ - "boy": "Garçon", - "girl": "Fille", - "general": "Général", - "display": "Affichage", - "audio": "Audio", - "gamepad": "Manette", - "keyboard": "Clavier", - "gameSpeed": "Vitesse du jeu", - "hpBarSpeed": "Vit. barre de PV", - "expGainsSpeed": "Vit. barre d’Exp", - "expPartyDisplay": "Afficher Exp équipe", - "skipSeenDialogues": "Passer dialogues connus", - "eggSkip": "Animation d’éclosion", - "never": "Jamais", - "always": "Toujours", - "ask": "Demander", - "battleStyle": "Style de combat", - "enableRetries": "Activer les réessais", - "hideIvs": "Masquer Scanner d’IV", - "tutorials": "Tutoriels", - "touchControls": "Contrôles tactiles", - "vibrations": "Vibrations", - "normal": "Normal", - "fast": "Rapide", - "faster": "Plus rapide", - "skip": "Passer", - "levelUpNotifications": "Notif. gain de N.", - "on": "Activé", - "off": "Désactivé", - "switch": "Choix", - "set": "Défini", - "auto": "Auto", - "disabled": "Désactivé", - "language": "Langue", - "change": "Changer", - "uiTheme": "Interface", - "default": "Par défaut", - "legacy": "Ancienne", - "windowType": "Type de fenêtre", - "moneyFormat": "Format de l’argent", - "damageNumbers": "Affichage dégâts", - "simple": "Simple", - "fancy": "Amélioré", - "abbreviated": "Abrégé", - "moveAnimations": "Animations de combat", - "showStatsOnLevelUp": "Afficher stats à la montée de N.", - "candyUpgradeNotification": "Notif amélioration de bonbon", - "passivesOnly": "Passifs", - "candyUpgradeDisplay": "Amélioration bonbon", - "icon": "Icône", - "animation": "Animation", - "moveInfo": "Infos de capacité", - "showMovesetFlyout": "Afficher volet de capacités", - "showArenaFlyout": "Afficher volet d’arène", - "showTimeOfDayWidget": "Widget d’heure", - "timeOfDayAnimation": "Animation d’heure", - "bounce": "Sauter", - "timeOfDay_back": "Retour", - "spriteSet": "Ensemble de sprites", - "consistent": "Consistant", - "mixedAnimated": "Mixte", - "fusionPaletteSwaps": "Palettes de fusion", - "playerGender": "Genre de l’avatar", - "typeHints": "Indications de type", - "masterVolume": "Vol. principal", - "bgmVolume": "Vol. musique", - "fieldVolume": "Vol. combats", - "seVolume": "Vol. effets", - "uiVolume": "Vol. menus", - "musicPreference": "Préf. musicale", - "mixed": "Mixte", - "gamepadPleasePlug": "Veuillez brancher une manette ou appuyer sur un bouton.", - "delete": "Supprimer", - "keyboardPleasePress": "Veuillez appuyer sur une touche de votre clavier.", - "reset": "Réinitialiser", - "requireReload": "Redémarrage requis", - "action": "Action", - "back": "Retour", - "pressToBind": "Sélectionnez pour assigner", - "pressButton": "Appuyez sur un bouton…", - "buttonUp": "Haut", - "buttonDown": "Bas", - "buttonLeft": "Gauche", - "buttonRight": "Droite", - "buttonAction": "Action", - "buttonMenu": "Menu", - "buttonSubmit": "Valider", - "buttonCancel": "Annuler", - "buttonStats": "Stats", - "buttonCycleForm": "Modifier Forme", - "buttonCycleShiny": "Modifier Chromatique", - "buttonCycleGender": "Modifier Sexe", - "buttonCycleAbility": "Modifier Capacité", - "buttonCycleNature": "Modifier Nature", - "buttonCycleVariant": "Modifier Variant", - "buttonSpeedUp": "Accélérer", - "buttonSlowDown": "Ralentir", - "alt": " (Alt)", - "mute": "Muet", - "controller": "Controller", - "gamepadSupport": "Gamepad Support", - "showBgmBar": "Titre de la musique", - "moveTouchControls": "Déplacer les contrôles tactiles", - "shopOverlayOpacity": "Opacité boutique", - "shopCursorTarget": "Choix après relance", - "rewards": "Obj. gratuits", - "reroll": "Relance", - "shop": "Boutique", - "checkTeam": "Équipe" -} diff --git a/src/locales/fr/splash-messages.json b/src/locales/fr/splash-messages.json deleted file mode 100644 index 9dd3e86fb32..00000000000 --- a/src/locales/fr/splash-messages.json +++ /dev/null @@ -1,36 +0,0 @@ -{ - "battlesWon": "combats gagnés !", - "joinTheDiscord": "Rejoins le Discord !", - "infiniteLevels": "Niveaux infinis !", - "everythingStacks": "Tout se cumule !", - "optionalSaveScumming": "Optional Save Scumming !", - "biomes": "35 biomes !", - "openSource": "Open Source !", - "playWithSpeed": "Joue en vitesse x5 !", - "liveBugTesting": "Tests de bugs en direct !", - "heavyInfluence": "Grosse influence de RoR2 !", - "pokemonRiskAndPokemonRain": "Pokémon Risk et Pokémon Rain !", - "nowWithMoreSalt": "Désormais avec 33% de sel en plus !", - "infiniteFusionAtHome": "Infinite Fusion, chez vous !", - "brokenEggMoves": "Des Capacités Œuf craquées !", - "magnificent": "Magnifique !", - "mubstitute": "Mubstitute !", - "thatsCrazy": "C’est une dinguerie !", - "oranceJuice": "Jus d’orange !", - "questionableBalancing": "Équilibrage douteux !", - "coolShaders": "Cool shaders !", - "aiFree": "Garanti sans IA !", - "suddenDifficultySpikes": "De soudains pics de difficultés !", - "basedOnAnUnfinishedFlashGame": "Basé sur un jeu Flash abandonné !", - "moreAddictiveThanIntended": "Plus addictif que prévu !", - "mostlyConsistentSeeds": "Des seeds à peu près stables !", - "achievementPointsDontDoAnything": "Les Points de Succès servent à rien !", - "youDoNotStartAtLevel": "Ne commence pas au Niveau 2000 !", - "dontTalkAboutTheManaphyEggIncident": "Ne parle pas de l’incident de l’Œuf de Manaphy !", - "alsoTryPokengine": "Essaye aussi Pokéngine !", - "alsoTryEmeraldRogue": "Essaye aussi Emerald Rogue!", - "alsoTryRadicalRed": "Essaye aussi Radical Red !", - "eeveeExpo": "Eevee Expo !", - "ynoproject": "YNOproject !", - "breedersInSpace": "Des Éleveurs dans l’espace !" -} diff --git a/src/locales/fr/starter-select-ui-handler.json b/src/locales/fr/starter-select-ui-handler.json deleted file mode 100644 index 518329607bb..00000000000 --- a/src/locales/fr/starter-select-ui-handler.json +++ /dev/null @@ -1,45 +0,0 @@ -{ - "confirmStartTeam": "Commencer avec ces Pokémon ?", - "confirmExit": "Êtes-vous sûr·e de vouloir quitter ?", - "invalidParty": "Cette équipe de départ est invalide !", - "gen1": "1G", - "gen2": "2G", - "gen3": "3G", - "gen4": "4G", - "gen5": "5G", - "gen6": "6G", - "gen7": "7G", - "gen8": "8G", - "gen9": "9G", - "growthRate": "Croissance :", - "ability": "Talent :", - "passive": "Passif :", - "nature": "Nature :", - "eggMoves": "Capacités Œuf", - "addToParty": "Ajouter à l’équipe", - "removeFromParty": "Retirer de l’équipe", - "toggleIVs": "Voir les IV", - "manageMoves": "Modifier les Capacités", - "manageNature": "Modifier la Nature", - "addToFavorites": "Ajouter aux Favoris", - "removeFromFavorites": "Retirer des Favoris", - "useCandies": "Utiliser des Bonbons", - "selectNature": "Sélectionnez une nature.", - "selectMoveSwapOut": "Sélectionnez la capacité à échanger.", - "selectMoveSwapWith": "Sélectionnez laquelle échanger avec", - "unlockPassive": "Débloquer Passif", - "reduceCost": "Diminuer le cout", - "sameSpeciesEgg": "Acheter un Œuf", - "cycleShiny": ": Chromatique", - "cycleForm": ": Forme", - "cycleGender": ": Sexe", - "cycleAbility": ": Talent", - "cycleNature": ": Nature", - "cycleVariant": ": Variant", - "goFilter": ": Aller aux filtres", - "enablePassive": "Activer Passif", - "disablePassive": "Désactiver Passif", - "locked": "Verrouillé", - "disabled": "Désactivé", - "uncaught": "Non-capturé" -} \ No newline at end of file diff --git a/src/locales/fr/status-effect.json b/src/locales/fr/status-effect.json deleted file mode 100644 index bfb7121f522..00000000000 --- a/src/locales/fr/status-effect.json +++ /dev/null @@ -1,65 +0,0 @@ -{ - "none": { - "name": "Aucun", - "description": "", - "obtain": "", - "obtainSource": "", - "activation": "", - "overlap": "", - "heal": "" - }, - "poison": { - "name": "Empoisonnement", - "description": "empoisonné", - "obtain": "{{pokemonNameWithAffix}} est\nempoisonné !", - "obtainSource": "{{pokemonNameWithAffix}} est\nempoisonné par {{sourceText}} !", - "activation": "{{pokemonNameWithAffix}}\nsouffre du poison !", - "overlap": "{{pokemonNameWithAffix}} est\ndéjà empoisonné.", - "heal": "{{pokemonNameWithAffix}} n’est\nplus empoisonné !" - }, - "toxic": { - "name": "Empoisonnement grave", - "description": "gravement empoisonné", - "obtain": "{{pokemonNameWithAffix}} est\ngravement empoisonné !", - "obtainSource": "{{pokemonNameWithAffix}} est\ngravement empoisonné par {{sourceText}} !", - "activation": "{{pokemonNameWithAffix}}\nsouffre du poison !", - "overlap": "{{pokemonNameWithAffix}} est\ndéjà empoisonné.", - "heal": "{{pokemonNameWithAffix}} n’est\nplus empoisonné !" - }, - "paralysis": { - "name": "Paralysie", - "description": "paralysé", - "obtain": "{{pokemonNameWithAffix}} est paralysé !\nIl aura du mal à attaquer !", - "obtainSource": "{{pokemonNameWithAffix}} est paralysé\npar {{sourceText}} ! Il aura du mal à attaquer !", - "activation": "{{pokemonNameWithAffix}} est paralysé !\nIl n’a pas pu attaquer !", - "overlap": "{{pokemonNameWithAffix}} est\ndéjà paralysé.", - "heal": "{{pokemonNameWithAffix}} n’est\nplus paralysé !" - }, - "sleep": { - "name": "Sommeil", - "description": "endormi", - "obtain": "{{pokemonNameWithAffix}}\ns’est endormi !", - "obtainSource": "{{pokemonNameWithAffix}} est\nendormi par {{sourceText}} !", - "activation": "{{pokemonNameWithAffix}}\ndort profondément.", - "overlap": "{{pokemonNameWithAffix}}\ndort déjà.", - "heal": "{{pokemonNameWithAffix}}\nse réveille !" - }, - "freeze": { - "name": "Gelé", - "description": "gelé", - "obtain": "{{pokemonNameWithAffix}} est\ngelé !", - "obtainSource": "{{pokemonNameWithAffix}} est\ngelé par {{sourceText}} !", - "activation": "{{pokemonNameWithAffix}} est gelé !\nIl ne peut plus attaquer !", - "overlap": "{{pokemonNameWithAffix}} est\ndéjà gelé.", - "heal": "{{pokemonNameWithAffix}} n’est\nplus gelé !" - }, - "burn": { - "name": "Brulure", - "description": "brulé", - "obtain": "{{pokemonNameWithAffix}} est\nbrulé !", - "obtainSource": "{{pokemonNameWithAffix}} est\nbrulé par {{sourceText}} !", - "activation": "{{pokemonNameWithAffix}}\nsouffre de sa brulure !", - "overlap": "{{pokemonNameWithAffix}} est\ndéjà brulé.", - "heal": "{{pokemonNameWithAffix}} n’est\nplus brulé !" - } -} diff --git a/src/locales/fr/terrain.json b/src/locales/fr/terrain.json deleted file mode 100644 index 217db57075c..00000000000 --- a/src/locales/fr/terrain.json +++ /dev/null @@ -1,16 +0,0 @@ -{ - "misty": "Brumeux", - "mistyStartMessage": "La brume recouvre le terrain !", - "mistyClearMessage": "La brume qui recouvrait le terrain se dissipe…", - "mistyBlockMessage": "La brume enveloppe {{pokemonNameWithAffix}} !", - "electric": "Électrifié", - "electricStartMessage": "De l’électricité parcourt le terrain !", - "electricClearMessage": "L’électricité parcourant le terrain s’est dissipée…", - "grassy": "Herbu", - "grassyStartMessage": "Un beau gazon pousse sur le terrain !", - "grassyClearMessage": "Le gazon disparait…", - "psychic": "Psychique", - "psychicStartMessage": "Le sol se met à réagir de façon bizarre…", - "psychicClearMessage": "Le sol redevient normal !", - "defaultBlockMessage": "{{pokemonNameWithAffix}} est protégé\npar le Champ {{terrainName}} !" -} \ No newline at end of file diff --git a/src/locales/fr/trainer-classes.json b/src/locales/fr/trainer-classes.json deleted file mode 100644 index b7027cf544f..00000000000 --- a/src/locales/fr/trainer-classes.json +++ /dev/null @@ -1,130 +0,0 @@ -{ - "ace_trainer": "Topdresseur", - "ace_trainer_female": "Topdresseuse", - "ace_duo": "Topdresseurs", - "artist": "Artiste", - "artist_female": "Artiste", - "backers": "Pompom Girls", - "backpacker": "Randonneur", - "backpacker_female": "Randonneuse", - "backpackers": "Randonneurs", - "baker": "Boulangère", - "battle_girl": "Combattante", - "beauty": "Canon", - "beginners": "Débutants", - "biker": "Motard", - "black_belt": "Karatéka", - "breeder": "Éleveur", - "breeder_female": "Éleveuse", - "breeders": "Éleveurs", - "clerk": "Employé", - "clerk_female": "Employée", - "colleagues": "Collègues de Bureau", - "crush_kin": "Duo Baston", - "cyclist": "Cycliste", - "cyclist_female": "Cycliste", - "cyclists": "Cyclistes", - "dancer": "Danseur", - "dancer_female": "Danseuse", - "depot_agent": "Cheminot", - "doctor": "Docteur", - "doctor_female": "Docteure", - "firebreather": "Crache-Feu", - "fisherman": "Pêcheur", - "fisherman_female": "Pêcheuse", - "gentleman": "Gentleman", - "guitarist": "Guitariste", - "guitarist_female": "Guitariste", - "harlequin": "Clown", - "hiker": "Montagnard", - "hooligans": "Loubards", - "hoopster": "Basketteur", - "infielder": "Baseballeur", - "janitor": "Nettoyeur", - "lady": "Mademoiselle", - "lass": "Fillette", - "linebacker": "Quaterback", - "maid": "Gouvernante", - "madame": "Mondaine", - "medical_team": "Médecins", - "musician": "Musicien", - "hex_maniac": "Mystimaniac", - "nurse": "Infirmière", - "nursery_aide": "Institutrice", - "officer": "Policier", - "parasol_lady": "Sœur Parasol", - "pilot": "Pilote", - "pokéfan": "Poké Fan", - "pokéfan_female": "Poké Fan", - "pokéfan_family": "Couple de Pokéfans", - "preschooler": "Petit", - "preschooler_female": "Petite", - "preschoolers": "Petits", - "psychic": "Kinésiste", - "psychic_female": "Kinésiste", - "psychics": "Kinésistes", - "pokémon_ranger": "Pokémon Ranger", - "pokémon_ranger_female": "Pokémon Ranger", - "pokémon_rangers": "Pokémon Rangers", - "ranger": "Ranger", - "restaurant_staff": "Serveurs", - "rich": "Gentleman", - "rich_female": "Mondaine", - "rich_boy": "Gentleman", - "rich_couple": "Couple de Bourgeois", - "rich_kid": "Richard", - "rich_kid_female": "Mademoiselle", - "rich_kids": "Richards", - "roughneck": "Loubard", - "sailor": "Marin", - "scientist": "Scientifique", - "scientist_female": "Scientifique", - "scientists": "Scientifiques", - "smasher": "Tenniswoman", - "snow_worker": "Ouvrier Alpin", - "snow_worker_female": "Ouvrière Alpine", - "striker": "Footballeur", - "school_kid": "Élève", - "school_kid_female": "Élève", - "school_kids": "Élèves", - "swimmer": "Nageur", - "swimmer_female": "Nageuse", - "swimmers": "Nageurs", - "twins": "Jumelles", - "veteran": "Vénérable", - "veteran_female": "Vénérable", - "veteran_duo": "Vénérables", - "waiter": "Serveur", - "waitress": "Serveuse", - "worker": "Ouvrier", - "worker_female": "Ouvrière", - "workers": "Ouvriers", - "youngster": "Gamin", - "rocket_grunt": "Sbire de la Team Rocket", - "rocket_grunts": "Sbires de la Team Rocket", - "rocket_grunt_female": "Sbire de la Team Rocket", - "magma_grunt": "Sbire de la Team Magma", - "magma_grunt_female": "Sbire de la Team Magma", - "magma_grunts": "Sbires de la Team Magma", - "aqua_grunt": "Sbire de la Team Aqua", - "aqua_grunt_female": "Sbire de la Team Aqua", - "aqua_grunts": "Sbires de la Team Aqua", - "galactic_grunt": "Sbire de la Team Galaxie", - "galactic_grunt_female": "Sbire de la Team Galaxie", - "galactic_grunts": "Sbires de la Team Galaxie", - "plasma_grunt": "Sbire de la Team Plasma", - "plasma_grunt_female": "Sbire de la Team Plasma", - "plasma_grunts": "Sbires de la Team Plasma", - "flare_grunt": "Sbire de la Team Flare", - "flare_grunt_female": "Sbire de la Team Flare", - "flare_grunts": "Sbires de la Team Flare", - "aether_grunt": "Employé de la Fondation Æther", - "aether_grunt_female": "Employée de la Fondation Æther", - "aether_grunts": "Employés de la Fondation Æther", - "skull_grunt": "Sbire de la Team Skull", - "skull_grunt_female": "Sbire de la Team Skull", - "skull_grunts": "Sbires de la Team Skull", - "macro_grunt": "Employé de Macro Cosmos", - "macro_grunt_female": "Employée de Macro Cosmos", - "macro_grunts": "Employés de Macro Cosmos" -} diff --git a/src/locales/fr/trainer-names.json b/src/locales/fr/trainer-names.json deleted file mode 100644 index beec7e0c313..00000000000 --- a/src/locales/fr/trainer-names.json +++ /dev/null @@ -1,164 +0,0 @@ -{ - "brock": "Pierre", - "misty": "Ondine", - "lt_surge": "Major Bob", - "erika": "Erika", - "janine": "Jeannine", - "sabrina": "Morgane", - "blaine": "Auguste", - "giovanni": "Giovanni", - "falkner": "Albert", - "bugsy": "Hector", - "whitney": "Blanche", - "morty": "Mortimer", - "chuck": "Chuck", - "jasmine": "Jasmine", - "pryce": "Frédo", - "clair": "Sandra", - "roxanne": "Roxanne", - "brawly": "Bastien", - "wattson": "Voltère", - "flannery": "Adriane", - "norman": "Norman", - "winona": "Alizée", - "tate": "Lévy", - "liza": "Tatia", - "juan": "Juan", - "roark": "Pierrick", - "gardenia": "Flo", - "maylene": "Mélina", - "crasher_wake": "Lovis", - "fantina": "Kiméra", - "byron": "Charles", - "candice": "Gladys", - "volkner": "Tanguy", - "cilan": "Rachid", - "chili": "Armando", - "cress": "Noa", - "cheren": "Tcheren", - "lenora": "Aloé", - "roxie": "Strykna", - "burgh": "Artie", - "elesa": "Inezia", - "clay": "Bardane", - "skyla": "Carolina", - "brycen": "Zhu", - "drayden": "Watson", - "marlon": "Amana", - "viola": "Violette", - "grant": "Lino", - "korrina": "Cornélia", - "ramos": "Amaro", - "clemont": "Lem", - "valerie": "Valériane", - "olympia": "Astera", - "wulfric": "Urup", - "milo": "Percy", - "nessa": "Donna", - "kabu": "Kabu", - "bea": "Faïza", - "allister": "Alistair", - "opal": "Sally", - "bede": "Travis", - "gordie": "Chaz", - "melony": "Lona", - "piers": "Peterson", - "marnie": "Rosemary", - "raihan": "Roy", - "katy": "Éra", - "brassius": "Colza", - "iono": "Mashynn", - "kofu": "Kombu", - "larry": "Okuba", - "ryme": "Laïm", - "tulip": "Tully", - "grusha": "Grusha", - "lorelei": "Olga", - "bruno": "Aldo", - "agatha": "Agatha", - "lance": "Peter", - "will": "Clément", - "koga": "Koga", - "karen": "Marion", - "sidney": "Damien", - "phoebe": "Spectra", - "glacia": "Glacia", - "drake": "Aragon", - "aaron": "Aaron", - "bertha": "Terry", - "flint": "Adrien", - "lucian": "Lucio", - "shauntal": "Anis", - "marshal": "Kunz", - "grimsley": "Pieris", - "caitlin": "Percila", - "malva": "Malva", - "siebold": "Narcisse", - "wikstrom": "Thyméo", - "drasna": "Dracéna", - "hala": "Pectorius", - "molayne": "Molène", - "olivia": "Alyxia", - "acerola": "Margie", - "kahili": "Kahili", - "rika": "Cayenn", - "poppy": "Popi", - "hassel": "Hassa", - "crispin": "Rubépin", - "amarys": "Nérine", - "lacey": "Taro", - "drayton": "Irido", - "blue": "Blue", - "red": "Red", - "steven": "Pierre Rochard", - "wallace": "Marc", - "cynthia": "Cynthia", - "alder": "Goyah", - "iris": "Iris", - "diantha": "Dianthéa", - "hau": "Tili", - "geeta": "Alisma", - "nemona": "Menzi", - "kieran": "Kass", - "leon": "Tarak", - "rival": "Gwenaël", - "rival_female": "Papina", - "archer": "Amos", - "ariana": "Ariane", - "proton": "Lance", - "petrel": "Lambda", - "tabitha": "Kelvin", - "courtney": "Courtney", - "shelly": "Sarah", - "matt": "Matthieu", - "mars": "Mars", - "jupiter": "Jupiter", - "saturn": "Saturne", - "zinzolin": "Lilien", - "rood": "Carmine", - "xerosic": "Xanthin", - "bryony": "Brasénie", - "faba": "Saubohne", - "plumeria": "Apocyne", - "oleana": "Liv", - - "maxie": "Max", - "archie": "Arthur", - "cyrus": "Hélio", - "ghetsis": "Ghetis", - "lysandre": "Lysandre", - "lusamine": "Elsa-Mina", - "guzma": "Guzma", - "rose": "Shehroz", - - "blue_red_double": "Blue & Red", - "red_blue_double": "Red & Blue", - "tate_liza_double": "Lévy & Tatia", - "liza_tate_double": "Tatia & Lévy", - "steven_wallace_double": "Pierre R. & Marc", - "wallace_steven_double": "Marc & Pierre R.", - "alder_iris_double": "Goyah & Iris", - "iris_alder_double": "Iris & Goyah", - "marnie_piers_double": "Rosemary & Peterson", - "piers_marnie_double": "Peterson & Rosemary" -} diff --git a/src/locales/fr/trainer-titles.json b/src/locales/fr/trainer-titles.json deleted file mode 100644 index 6d966bbd9ec..00000000000 --- a/src/locales/fr/trainer-titles.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "elite_four": "Conseil 4", - "elite_four_female": "Conseil 4", - "gym_leader": "Champion d’Arène", - "gym_leader_female": "Championne d’Arène", - "gym_leader_double": "Duo de Champions", - "champion": "Maitre", - "champion_female": "Maitresse", - "champion_double": "Duo de Maitres", - "rival": "Rival·e", - "professor": "Professeur·e", - "frontier_brain": "Meneur·euse de Zone", - "rocket_boss": "Leader de la Team Rocket", - "magma_boss": "Leader de la Team Magma", - "aqua_boss": "Leader de la Team Aqua", - "galactic_boss": "Leader de la Team Galaxie", - "plasma_boss": "Leader de la Team Plasma", - "flare_boss": "Leader de la Team Flare", - "aether_boss": "Présidente d’Æther", - "skull_boss": "Boss de la Team Skull", - "macro_boss": "Président de Macro Cosmos", - - "rocket_admin": "Admin Team Rocket", - "rocket_admin_female": "Admin Team Rocket", - "magma_admin": "Admin Team Magma", - "magma_admin_female": "Admin Team Magma", - "aqua_admin": "Admin Team Aqua", - "aqua_admin_female": "Admin Team Aqua", - "galactic_commander": "Admin Team Galaxie", - "galactic_commander_female": "Admin Team Galaxie", - "plasma_sage": "Sage Plasma", - "plasma_admin": "Admin Team Plasma", - "flare_admin": "Manager de la Team Flare", - "flare_admin_female": "Manageuse de la Team Flare", - "aether_admin": "Directeur d’Æther", - "skull_admin": "Admin Team Skull", - "macro_admin": "Macro Cosmos" -} diff --git a/src/locales/fr/tutorial.json b/src/locales/fr/tutorial.json deleted file mode 100644 index 3236bdafea2..00000000000 --- a/src/locales/fr/tutorial.json +++ /dev/null @@ -1,10 +0,0 @@ -{ - "intro": "Bienvenue dans PokéRogue, un fangame axé sur les combats Pokémon avec des éléments roguelite !\n$Ce jeu n’est pas monétisé et nous ne prétendons à la propriété d’aucun élément sous copyright utilisé.\n$Bien qu’en développement permanent, PokéRogue reste entièrement jouable.\n$Tout signalement de bugs et d’erreurs quelconques passe par le serveur Discord.\n$Si le jeu est lent, vérifiez que l’Accélération Matérielle est activée dans les paramètres du navigateur.", - "accessMenu": "Accédez au menu avec M ou Échap lors de l’attente d’une\naction.\n$Il contient les paramètres et diverses fonctionnalités.", - "menu": "Vous pouvez accéder aux paramètres depuis ce menu.\n$Vous pouvez entre autres y changer la vitesse du jeu ou le style de fenêtre…\n$Mais également des tonnes d’autres fonctionnalités, jetez-y un œil !", - "starterSelect": "Choisissez vos starters depuis cet écran avec Z ou Espace.\nIls formeront votre équipe de départ.\n$Chacun possède une valeur. Votre équipe peut avoir\njusqu’à 6 membres, sans dépasser un cout de 10.\n$Vous pouvez aussi choisir le sexe, le talent et la forme en\nfonction des variants déjà capturés ou éclos.\n$Les IV d’un starter sont les meilleurs de tous ceux de\nson espèce déjà possédés. Obtenez-en plusieurs !", - "pokerus": "Chaque jour, 3 starters tirés aléatoirement ont un contour violet.\n$Si un starter que vous possédez l’a, essayez de l’ajouter à votre équipe. Vérifiez bien son résumé !", - "statChange": "Les changements de stats persistent à travers\nles combats tant que le Pokémon n’est pas rappelé.\n$Vos Pokémon sont rappelés avant un combat de\nDresseur et avant d’entrer dans un nouveau biome.\n$Vous pouvez voir en combat les changements de stats\nd’un Pokémon en maintenant C ou Maj.\n$Vous pouvez également voir les capacités de l’adversaire\nen maintenant V.\n$Seules les capacités que le Pokémon a utilisées dans\nce combat sont consultables.", - "selectItem": "Après chaque combat, vous avez le choix entre 3 objets\ntirés au sort. Vous ne pouvez en prendre qu’un.\n$Cela peut être des objets consommables, des objets à\nfaire tenir, ou des objets passifs aux effets permanents.\n$La plupart des effets des objets non-consommables se cumuleront de diverses manières.\n$Certains objets n’apparaitront que s’ils ont une utilité immédiate, comme les objets d’évolution.\n$Vous pouvez aussi transférer des objets tenus entre\nPokémon en utilisant l’option de transfert.\n$L’option de transfert apparait en bas à droite dès\nqu’un Pokémon de l’équipe porte un objet.\n$Vous pouvez acheter des consommables avec de\nl’argent. Plus vous progressez, plus le choix sera large.\n$Choisir un des objets gratuits déclenchera le prochain\ncombat, donc faites bien tous vos achats avant.", - "eggGacha": "Depuis cet écran, vous pouvez utiliser vos coupons\npour recevoir Œufs de Pokémon au hasard.\n$Les Œufs éclosent après avoir remporté un certain nombre de combats.\n$Plus ils sont rares, plus ils mettent de temps.\n$Les Pokémon éclos ne rejoindront pas votre équipe, mais seront ajoutés à vos starters.\n$Les Pokémon issus d’Œufs ont généralement de meilleurs IV que les Pokémon sauvages.\n$Certains Pokémon ne peuvent être obtenus que dans des Œufs.\n$Il y a 3 différentes machines à actionner avec différents\nbonus, prenez celle qui vous convient le mieux !" -} diff --git a/src/locales/fr/voucher.json b/src/locales/fr/voucher.json deleted file mode 100644 index ef6126b4435..00000000000 --- a/src/locales/fr/voucher.json +++ /dev/null @@ -1,9 +0,0 @@ -{ - "vouchers": "Coupons", - "eggVoucher": "Coupon Œuf", - "eggVoucherPlus": "Coupon Œuf +", - "eggVoucherPremium": "Coupon Œuf Premium", - "eggVoucherGold": "Coupon Œuf Or", - "locked": "Verrouillé", - "defeatTrainer": "Vaincre {{trainerName}}" -} diff --git a/src/locales/fr/weather.json b/src/locales/fr/weather.json deleted file mode 100644 index 7afe538b064..00000000000 --- a/src/locales/fr/weather.json +++ /dev/null @@ -1,32 +0,0 @@ -{ - "sunnyStartMessage": "Les rayons du soleil brillent !", - "sunnyLapseMessage": "Les rayons du soleil brillent fort !", - "sunnyClearMessage": "Les rayons du soleil s’affaiblissent !", - "rainStartMessage": "Il commence à pleuvoir !", - "rainLapseMessage": "La pluie continue de tomber !", - "rainClearMessage": "La pluie s’est arrêtée !", - "sandstormStartMessage": "Une tempête de sable se prépare !", - "sandstormLapseMessage": "La tempête de sable fait rage !", - "sandstormClearMessage": "La tempête de sable se calme !", - "sandstormDamageMessage": "La tempête de sable inflige des dégâts\nà {{pokemonNameWithAffix}} !", - "hailStartMessage": "Il commence à grêler !", - "hailLapseMessage": "La grêle continue de tomber !", - "hailClearMessage": "La grêle s’est arrêtée !", - "hailDamageMessage": "La grêle inflige des dégâts\nà {{pokemonNameWithAffix}} !", - "snowStartMessage": "Il commence à neiger !", - "snowLapseMessage": "Il y a une tempête de neige !", - "snowClearMessage": "La neige s’est arrêtée !", - "fogStartMessage": "Le brouillard devient épais…", - "fogLapseMessage": "Le brouillard continue !", - "fogClearMessage": "Le brouillard s’est dissipé !", - "heavyRainStartMessage": "Une pluie battante s’abat soudainement !", - "heavyRainLapseMessage": "La pluie battante continue.", - "heavyRainClearMessage": "La pluie battante s’est arrêtée…", - "harshSunStartMessage": "Les rayons du soleil s’intensifient !", - "harshSunLapseMessage": "Les rayons du soleil sont brulants !", - "harshSunClearMessage": "Les rayons du soleil s’affaiblissent !", - "strongWindsStartMessage": "Un vent mystérieux se lève !", - "strongWindsLapseMessage": "Le vent mystérieux souffle violemment !", - "strongWindsEffectMessage": "Le courant aérien mystérieux affaiblit l’attaque !", - "strongWindsClearMessage": "Le vent mystérieux s’est dissipé…" -} diff --git a/src/locales/it/ability-trigger.json b/src/locales/it/ability-trigger.json deleted file mode 100644 index 333cb5719d8..00000000000 --- a/src/locales/it/ability-trigger.json +++ /dev/null @@ -1,64 +0,0 @@ -{ - "blockRecoilDamage": "{{abilityName}} di {{pokemonName}}\nl'ha protetto dal contraccolpo!", - "badDreams": "{{pokemonName}} è tormentato dagli incubi!", - "costar": "{{pokemonName}} ha copiato le modifiche alle statistiche\ndel suo alleato {{allyName}}!", - "iceFaceAvoidedDamage": "{{pokemonNameWithAffix}} ha evitato\ni danni grazie a {{abilityName}}!", - "perishBody": "{{abilityName}} di {{pokemonName}}\nmanderà KO entrambi i Pokémon dopo 3 turni!", - "poisonHeal": "{{pokemonName}} recupera alcuni PS\ncon {{abilityName}}!", - "trace": "L'abilità {{abilityName}} di {{targetName}}\nviene copiata da {{pokemonName}} con Traccia!", - "windPowerCharged": "Venire colpito da {{moveName}} ha caricato {{pokemonName}}!", - "quickDraw": "{{pokemonName}} agisce più rapidamente del normale grazie a Colpolesto!", - "blockItemTheft": "{{abilityName}} di {{pokemonNameWithAffix}}\nlo rende immune ai furti!", - "typeImmunityHeal": "{{pokemonName}} recupera alcuni PS\ncon {{abilityName}}!", - "nonSuperEffectiveImmunity": "{{pokemonNameWithAffix}} evita il colpo\ncon {{abilityName}}!", - "fullHpResistType": "{{pokemonNameWithAffix}} fa risplendere la sua corazza\ne altera i rapporti tra i tipi!", - "disguiseAvoidedDamage": "{{pokemonNameWithAffix}} è stato smascherato!", - "moveImmunity": "Non ha effetto su {{pokemonNameWithAffix}}!", - "reverseDrain": "{{pokemonNameWithAffix}} ha assorbito la melma!", - "postDefendTypeChange": "{{abilityName}} di {{pokemonNameWithAffix}}\nlo ha reso di tipo {{typeName}}!", - "postDefendContactDamage": "{{abilityName}} di {{pokemonNameWithAffix}} ha\ndanneggiato il Pokémon che l'ha attaccato!", - "postDefendAbilitySwap": "{{pokemonNameWithAffix}} scambia\nla sua abilità con il bersaglio", - "postDefendAbilityGive": "{{abilityName}} di {{pokemonNameWithAffix}}\nviene ceduta al bersaglio!", - "postDefendMoveDisable": "La mossa {{moveName}} di {{pokemonNameWithAffix}}\nè stata bloccata!", - "pokemonTypeChange": "{{pokemonNameWithAffix}} è diventato di tipo {{moveType}}!", - "postAttackStealHeldItem": "{{pokemonNameWithAffix}} ruba\n{{stolenItemType}} di {{defenderName}}!", - "postDefendStealHeldItem": "{{pokemonNameWithAffix}} ruba\n{{stolenItemType}} di {{attackerName}}!", - "copyFaintedAllyAbility": "L'abilità {{abilityName}} di {{pokemonNameWithAffix}} è passata all'alleato!", - "intimidateImmunity": "{{abilityName}} impedisce a {{pokemonNameWithAffix}} di\nessere intimidito!", - "postSummonAllyHeal": "{{pokemonNameWithAffix}} beve il\ntè che {{pokemonName}} gli ha preparato!", - "postSummonClearAllyStats": "Le statistiche di {{pokemonNameWithAffix}}\ntornano alla normalità!", - "postSummonTransform": "{{pokemonNameWithAffix}} assume le sembianze\ndi {{targetName}}!", - "protectStat": "{{abilityName}} di {{pokemonNameWithAffix}}\npreviene la riduzione del/della suo/a {{statName}}!", - "statusEffectImmunityWithName": "{{abilityName}} di {{pokemonNameWithAffix}}\nnon gli fa subire il/lo/la {{statusEffectName}}!", - "statusEffectImmunity": "{{abilityName}} di {{pokemonNameWithAffix}}\npreviene i problemi di stato!", - "battlerTagImmunity": "{{abilityName}} di {{pokemonNameWithAffix}}\npreviene {{battlerTagName}}!", - "forewarn": "{{pokemonNameWithAffix}} è stato messo in guardia da {{moveName}}!", - "frisk": "{{pokemonNameWithAffix}} perquisice {{opponentName}}\ne trova la sua abilità, {{opponentAbilityName}}!", - "postWeatherLapseHeal": "{{pokemonNameWithAffix}} recupera alcuni PS\ncon {{abilityName}}!", - "postWeatherLapseDamage": "{{pokemonNameWithAffix}} subisce danni\na causa della sua abilità, {{abilityName}}!", - "postTurnLootCreateEatenBerry": "{{pokemonNameWithAffix}} raccoglie una {{berryName}}!", - "postTurnHeal": "{{pokemonNameWithAffix}} recupera alcuni PS\ncon {{abilityName}}!", - "fetchBall": "{{pokemonNameWithAffix}} ha trovato una\n{{pokeballName}}!", - "healFromBerryUse": "{{abilityName}} di {{pokemonNameWithAffix}}\nristabilisce parte dei PS!", - "arenaTrap": "L’abilità {{abilityName}} di {{pokemonNameWithAffix}}\nimpedisce la sostituzione!", - "postBattleLoot": "{{pokemonNameWithAffix}} ha raccolto\nil/l'/lo/la {{itemName}}!", - "postFaintContactDamage": "{{abilityName}} di {{pokemonNameWithAffix}}\nferisce il Pokémon che lo ha attaccato!", - "postFaintHpDamage": "{{abilityName}} di {{pokemonNameWithAffix}}\nferisce il Pokémon che lo ha attaccato!", - "postSummonPressure": "{{pokemonNameWithAffix}} fa pressione!", - "weatherEffectDisappeared": "Le condizioni atmosferiche non hanno alcun effetto.", - "postSummonMoldBreaker": "{{pokemonNameWithAffix}} ha l’abilità Rompiforma!", - "postSummonAnticipation": "{{pokemonNameWithAffix}} rabbrividisce!", - "postSummonTurboblaze": "{{pokemonNameWithAffix}} emana un’aura infuocata!", - "postSummonTeravolt": "{{pokemonNameWithAffix}} emana un’aura repulsiva!", - "postSummonDarkAura": "L’abilità Auratetra di {{pokemonNameWithAffix}} è attiva.", - "postSummonFairyAura": "L’abilità Aurafolletto di {{pokemonNameWithAffix}} è attiva.", - "postSummonAuraBreak": "{{pokemonNameWithAffix}} inverte gli effetti di tutte le aure!", - "postSummonNeutralizingGas": "Il Gas Reagente di {{pokemonNameWithAffix}}\nsi diffonde tutt’intorno!", - "postSummonAsOneGlastrier": "{{pokemonNameWithAffix}} ha due abilità!", - "postSummonAsOneSpectrier": "{{pokemonNameWithAffix}} ha due abilità!", - "postSummonVesselOfRuin": "La/l'{{statName}} dei Pokémon intorno si indebolisce a causa\ndell'abilità Vaso Nefasto di {{pokemonNameWithAffix}}!", - "postSummonSwordOfRuin": "La/l'{{statName}} dei Pokémon intorno si indebolisce a causa\ndell'abilità Spada Nefasta di {{pokemonNameWithAffix}}!", - "postSummonTabletsOfRuin": "La/l'{{statName}} dei Pokémon intorno si indebolisce a causa\ndell'abilità Amuleto Nefasto di {{pokemonNameWithAffix}}!", - "postSummonBeadsOfRuin": "La/l'{{statName}} dei Pokémon intorno si indebolisce a causa\ndell'abilità Monile Nefasto di {{pokemonNameWithAffix}}!", - "preventBerryUse": "{{pokemonNameWithAffix}} non riesce a\nmangiare le bacche per l'agitazione!" -} diff --git a/src/locales/it/ability.json b/src/locales/it/ability.json deleted file mode 100644 index 18eb133d824..00000000000 --- a/src/locales/it/ability.json +++ /dev/null @@ -1,1242 +0,0 @@ -{ - "stench": { - "name": "Tanfo", - "description": "Quando il Pokémon attacca il bersaglio, può farlo tentennare grazie al cattivo odore che emana." - }, - "drizzle": { - "name": "Piovischio", - "description": "Quando il Pokémon entra in campo, attira la pioggia." - }, - "speedBoost": { - "name": "Acceleratore", - "description": "La Velocità aumenta a ogni turno." - }, - "battleArmor": { - "name": "Lottascudo", - "description": "Il Pokémon è protetto da una dura corazza che gli evita di subire brutti colpi." - }, - "sturdy": { - "name": "Vigore", - "description": "Evita che il Pokémon vada KO in un sol colpo se ha tutti i PS, e lo rende immune alle mosse che causano KO immediato." - }, - "damp": { - "name": "Umidità", - "description": "Aumenta l'umidità circostante, impedendo l'uso di Autodistruzione e di altre mosse esplosive." - }, - "limber": { - "name": "Scioltezza", - "description": "Il corpo flessibile del Pokémon gli impedisce di subire gli effetti della paralisi." - }, - "sandVeil": { - "name": "Sabbiavelo", - "description": "L'elusione aumenta durante le tempeste di sabbia." - }, - "static": { - "name": "Statico", - "description": "Il Pokémon si ricopre di elettricità statica e può causare paralisi a chi è entrato in contatto con lui." - }, - "voltAbsorb": { - "name": "Assorbivolt", - "description": "Se il Pokémon viene colpito da una mossa di tipo Elettro, recupera PS anziché subire danni." - }, - "waterAbsorb": { - "name": "Assorbacqua", - "description": "Se il Pokémon viene colpito da una mossa di tipo Acqua, recupera PS anziché subire danni." - }, - "oblivious": { - "name": "Indifferenza", - "description": "L'imperturbabilità del Pokémon lo protegge da infatuazioni, provocazioni e dall'effetto di Prepotenza." - }, - "cloudNine": { - "name": "Antimeteo", - "description": "Neutralizza gli effetti di tutte le condizioni atmosferiche." - }, - "compoundEyes": { - "name": "Insettocchi", - "description": "La precisione del Pokémon aumenta grazie ai suoi occhi composti." - }, - "insomnia": { - "name": "Insonnia", - "description": "Il Pokémon soffre d'insonnia e non può addormentarsi." - }, - "colorChange": { - "name": "Cambiacolore", - "description": "Il Pokémon acquisisce il tipo della mossa subita." - }, - "immunity": { - "name": "Immunità", - "description": "L'immunità naturale del Pokémon gli impedisce di essere avvelenato." - }, - "flashFire": { - "name": "Fuocardore", - "description": "Se il Pokémon subisce una mossa di tipo Fuoco, ne sfrutta il calore per potenziare le proprie mosse di tipo Fuoco." - }, - "shieldDust": { - "name": "Polvoscudo", - "description": "Il Pokémon è protetto da uno strato di scaglie che annulla gli effetti aggiuntivi delle mosse subite." - }, - "ownTempo": { - "name": "Mente Locale", - "description": "Il Pokémon affronta la vita al proprio ritmo e per questo non può essere confuso o subire l'effetto di Prepotenza." - }, - "suctionCups": { - "name": "Ventose", - "description": "Il Pokémon resiste a strumenti e mosse che causano la sostituzione appiccicandosi al terreno con le ventose." - }, - "intimidate": { - "name": "Prepotenza", - "description": "Quando il Pokémon entra in campo, la sua prepotenza crea soggezione, riducendo l'Attacco degli avversari intimiditi." - }, - "shadowTag": { - "name": "Pedinombra", - "description": "Il Pokémon impedisce la fuga o la sostituzione degli avversari di cui calpesta l'ombra." - }, - "roughSkin": { - "name": "Cartavetro", - "description": "Quando il Pokémon subisce un attacco, grazie alla sua pelle ruvida infligge a sua volta danni al Pokémon con cui è entrato in contatto." - }, - "wonderGuard": { - "name": "Magidifesa", - "description": "Un potere misterioso protegge il Pokémon e lo rende vulnerabile solo alle mosse superefficaci." - }, - "levitate": { - "name": "Levitazione", - "description": "La capacità di levitare conferisce al Pokémon immunità agli attacchi di tipo Terra." - }, - "effectSpore": { - "name": "Spargispora", - "description": "Può causare avvelenamento, paralisi o sonno a chi attacca il Pokémon entrando in contatto con lui." - }, - "synchronize": { - "name": "Sincronismo", - "description": "Se un Pokémon con questa abilità viene avvelenato, paralizzato o scottato, contagia con lo stesso problema di stato chi lo ha causato." - }, - "clearBody": { - "name": "Corpochiaro", - "description": "Impedisce la diminuzione delle statistiche causata da abilità o mosse di altri Pokémon." - }, - "naturalCure": { - "name": "Alternacura", - "description": "Quando il Pokémon lascia il campo, guarisce dai problemi di stato." - }, - "lightningRod": { - "name": "Parafulmine", - "description": "Il Pokémon attira e neutralizza le mosse di tipo Elettro, facendo aumentare il suo Attacco Speciale." - }, - "sereneGrace": { - "name": "Leggiadro", - "description": "Rende più probabili gli effetti aggiuntivi delle mosse." - }, - "swiftSwim": { - "name": "Nuotovelox", - "description": "Se piove, la Velocità aumenta." - }, - "chlorophyll": { - "name": "Clorofilla", - "description": "Se la luce del sole è intensa, la Velocità aumenta." - }, - "illuminate": { - "name": "Risplendi", - "description": "Illuminando l'ambiente circostante, impedisce che la precisione del pokémon sia diminuita." - }, - "trace": { - "name": "Traccia", - "description": "Quando il Pokémon entra in campo, copia l'abilità di un avversario." - }, - "hugePower": { - "name": "Macroforza", - "description": "Raddoppia la potenza degli attacchi fisici del Pokémon." - }, - "poisonPoint": { - "name": "Velenopunto", - "description": "Può avvelenare chi entra in contatto con il Pokémon." - }, - "innerFocus": { - "name": "Forza Interiore", - "description": "La capacità di concentrazione del Pokémon evita che tentenni per gli attacchi subiti e lo protegge dall'effetto di Prepotenza." - }, - "magmaArmor": { - "name": "Magmascudo", - "description": "Il magma riveste il corpo del Pokémon impedendogli di venire congelato." - }, - "waterVeil": { - "name": "Idrovelo", - "description": "Un velo d'acqua riveste il corpo del Pokémon impedendogli di venire scottato." - }, - "magnetPull": { - "name": "Magnetismo", - "description": "La carica magnetica attrae i Pokémon di tipo Acciaio impedendogli la fuga o la sostituzione." - }, - "soundproof": { - "name": "Antisuono", - "description": "Il Pokémon è dotato di una sorta di isolamento acustico che lo rende immune alle mosse basate sul suono." - }, - "rainDish": { - "name": "Copripioggia", - "description": "Il Pokémon recupera PS quando piove." - }, - "sandStream": { - "name": "Sabbiafiume", - "description": "Quando il Pokémon entra in campo, scatena una tempesta di sabbia." - }, - "pressure": { - "name": "Pressione", - "description": "Il Pokémon mette pressione agli avversari, facendogli consumare più PP." - }, - "thickFat": { - "name": "Grassospesso", - "description": "Il Pokémon è protetto da uno spesso strato di grasso che dimezza il danno causato da mosse di tipo Fuoco e Ghiaccio." - }, - "earlyBird": { - "name": "Sveglialampo", - "description": "Anche se il Pokémon si addormenta, può risvegliarsi due volte più velocemente." - }, - "flameBody": { - "name": "Corpodifuoco", - "description": "Può scottare chi entra in contatto con il Pokémon." - }, - "runAway": { - "name": "Fugafacile", - "description": "Garantisce la fuga dai Pokémon selvatici." - }, - "keenEye": { - "name": "Sguardofermo", - "description": "La vista acuta del Pokémon impedisce che la sua precisione diminuisca." - }, - "hyperCutter": { - "name": "Ipertaglio", - "description": "Le possenti chele o tenaglie di cui è dotato il Pokémon fanno sì che il suo Attacco non possa essere diminuito da altri." - }, - "pickup": { - "name": "Raccolta", - "description": "Il Pokémon può raccogliere strumenti usati da altri durante la lotta. Potrebbe raccogliere strumenti anche fuori dalla lotta." - }, - "truant": { - "name": "Pigrone", - "description": "Quando il Pokémon usa una mossa, nel turno successivo si riposerà." - }, - "hustle": { - "name": "Tuttafretta", - "description": "L'Attacco aumenta, ma la precisione diminuisce." - }, - "cuteCharm": { - "name": "Incantevole", - "description": "Può causare infatuazione a chi entra in contatto con il Pokémon." - }, - "plus": { - "name": "Più", - "description": "L'Attacco Speciale aumenta se ci sono alleati con l'abilità Meno o Più." - }, - "minus": { - "name": "Meno", - "description": "L'Attacco Speciale aumenta se ci sono alleati con l'abilità Meno o Più." - }, - "forecast": { - "name": "Previsioni", - "description": "Cambia il tipo del Pokémon in Acqua, Fuoco o Ghiaccio in base alle condizioni atmosferiche." - }, - "stickyHold": { - "name": "Antifurto", - "description": "Gli strumenti restano appiccicati al corpo adesivo del Pokémon e non possono essere rubati." - }, - "shedSkin": { - "name": "Muta", - "description": "Il Pokémon può guarire dai problemi di stato facendo la muta completa della pelle." - }, - "guts": { - "name": "Dentistretti", - "description": "Se il Pokémon è affetto da un problema di stato, tira fuori la grinta e aumenta il proprio Attacco." - }, - "marvelScale": { - "name": "Pelledura", - "description": "Se il Pokémon è affetto da un problema di stato, le squame sulla sua pelle si induriscono aumentando la sua Difesa." - }, - "liquidOoze": { - "name": "Melma", - "description": "La melma del Pokémon infligge danni a chi la assorbe, facendogli perdere PS a causa del fortissimo tanfo." - }, - "overgrow": { - "name": "Erbaiuto", - "description": "Quando al Pokémon rimangono pochi PS, la potenza delle sue mosse di tipo Erba aumenta." - }, - "blaze": { - "name": "Aiutofuoco", - "description": "Quando al Pokémon rimangono pochi PS, la potenza delle sue mosse di tipo Fuoco aumenta." - }, - "torrent": { - "name": "Acquaiuto", - "description": "Quando al Pokémon rimangono pochi PS, la potenza delle sue mosse di tipo Acqua aumenta." - }, - "swarm": { - "name": "Aiutinsetto", - "description": "Quando al Pokémon rimangono pochi PS, la potenza delle sue mosse di tipo Coleottero aumenta." - }, - "rockHead": { - "name": "Testadura", - "description": "Anche se il Pokémon usa delle mosse che causano un contraccolpo, non perde PS." - }, - "drought": { - "name": "Siccità", - "description": "Quando il Pokémon entra in campo, la luce solare diventa intensa." - }, - "arenaTrap": { - "name": "Trappoarena", - "description": "Impedisce la fuga agli avversari." - }, - "vitalSpirit": { - "name": "Spiritovivo", - "description": "Il Pokémon è talmente vivace che non può addormentarsi." - }, - "whiteSmoke": { - "name": "Fumochiaro", - "description": "Il Pokémon è protetto da un fumo chiaro che impedisce ai nemici di diminuire le sue statistiche." - }, - "purePower": { - "name": "Forzapura", - "description": "L'Attacco del Pokémon raddoppia grazie alla sua padronanza delle tecniche yoga." - }, - "shellArmor": { - "name": "Guscioscudo", - "description": "Il Pokémon è protetto da un guscio robusto che gli evita di subire brutti colpi." - }, - "airLock": { - "name": "Riparo", - "description": "Neutralizza gli effetti di tutte le condizioni atmosferiche." - }, - "tangledFeet": { - "name": "Intricopiedi", - "description": "Se il Pokémon è confuso, la sua elusione aumenta." - }, - "motorDrive": { - "name": "Elettrorapid", - "description": "Se il Pokémon viene colpito da una mossa di tipo Elettro, la neutralizza e sfrutta la carica elettrica per aumentare la propria Velocità." - }, - "rivalry": { - "name": "Antagonismo", - "description": "Rende più forti contro nemici dello stesso sesso, ma più deboli contro nemici di sesso opposto." - }, - "steadfast": { - "name": "Cuordeciso", - "description": "Se il Pokémon tentenna, il suo animo indomito si risveglia e la sua Velocità aumenta." - }, - "snowCloak": { - "name": "Mantelneve", - "description": "Se grandina, l'elusione aumenta." - }, - "gluttony": { - "name": "Voracità", - "description": "Il Pokémon non attende di aver perso molti PS per mangiare certe bacche, ma lo fa non appena i suoi PS scendono a metà o meno." - }, - "angerPoint": { - "name": "Grancollera", - "description": "Se il Pokémon subisce un brutto colpo, monta su tutte le furie e il suo Attacco aumenta al massimo." - }, - "unburden": { - "name": "Agiltecnica", - "description": "Se il Pokémon usa o perde uno strumento, la sua Velocità aumenta." - }, - "heatproof": { - "name": "Antifuoco", - "description": "Il corpo termoresistente del Pokémon dimezza i danni che subisce dalle mosse di tipo Fuoco." - }, - "simple": { - "name": "Disinvoltura", - "description": "Raddoppia le modifiche alle statistiche." - }, - "drySkin": { - "name": "Pellearsa", - "description": "Il Pokémon recupera PS se piove o se subisce mosse di tipo Acqua, ma perde PS con la luce solare intensa. Subisce più danni da mosse di tipo Fuoco." - }, - "download": { - "name": "Download", - "description": "Il Pokémon analizza Difesa e Difesa Speciale del nemico e, a seconda di qual è più bassa, aumenta il proprio Attacco o Attacco Speciale." - }, - "ironFist": { - "name": "Ferropugno", - "description": "Potenzia le mosse che utilizzano pugni." - }, - "poisonHeal": { - "name": "Velencura", - "description": "Se il Pokémon è avvelenato, recupera PS anziché perderli." - }, - "adaptability": { - "name": "Adattabilità", - "description": "Potenzia di molto le mosse dello stesso tipo del Pokémon." - }, - "skillLink": { - "name": "Abillegame", - "description": "Le mosse multicolpo mandano a segno sempre il massimo dei colpi possibili." - }, - "hydration": { - "name": "Idratazione", - "description": "Se piove, il Pokémon guarisce dai problemi di stato." - }, - "solarPower": { - "name": "Solarpotere", - "description": "Se la luce del sole è intensa, l'Attacco Speciale aumenta, ma il Pokémon perde PS a ogni turno." - }, - "quickFeet": { - "name": "Piedisvelti", - "description": "Se il Pokémon è affetto da un problema di stato, la Velocità aumenta." - }, - "normalize": { - "name": "Normalità", - "description": "Tutte le mosse del Pokémon diventano di tipo Normale e la loro potenza aumenta un po'." - }, - "sniper": { - "name": "Cecchino", - "description": "Aumenta ulteriormente i danni inflitti dai brutti colpi." - }, - "magicGuard": { - "name": "Magicscudo", - "description": "Il Pokémon subisce danni solo dagli attacchi." - }, - "noGuard": { - "name": "Nullodifesa", - "description": "Il Pokémon e chiunque lo attacchi abbassano la guardia e le loro mosse vanno sempre a segno." - }, - "stall": { - "name": "Rallentatore", - "description": "Il Pokémon agisce sempre per ultimo." - }, - "technician": { - "name": "Tecnico", - "description": "Potenzia le mosse più deboli del Pokémon." - }, - "leafGuard": { - "name": "Fogliamanto", - "description": "Se la luce del sole è intensa, evita i problemi di stato." - }, - "klutz": { - "name": "Impaccio", - "description": "Il Pokémon non può usare lo strumento che ha con sé." - }, - "moldBreaker": { - "name": "Rompiforma", - "description": "Quando il Pokémon attacca, ignora l'abilità del bersaglio se questa ha effetto sulle mosse." - }, - "superLuck": { - "name": "Supersorte", - "description": "L'incredibile fortuna del Pokémon aumenta la sua probabilità di infliggere brutti colpi." - }, - "aftermath": { - "name": "Scoppio", - "description": "Chi manda KO questo Pokémon con un attacco diretto subisce dei danni." - }, - "anticipation": { - "name": "Presagio", - "description": "Rivela se il nemico ha mosse pericolose." - }, - "forewarn": { - "name": "Premonizione", - "description": "Quando il Pokémon entra in campo, rivela una delle mosse del nemico." - }, - "unaware": { - "name": "Imprudenza", - "description": "Quando il Pokémon attacca, ignora le modifiche alle statistiche del nemico." - }, - "tintedLens": { - "name": "Lentifumé", - "description": "Permette alle mosse non molto efficaci di infliggere danni normalmente." - }, - "filter": { - "name": "Filtro", - "description": "Riduce i danni subiti dalle mosse superefficaci." - }, - "slowStart": { - "name": "Lentoinizio", - "description": "Dimezza per cinque turni l'Attacco e la Velocità." - }, - "scrappy": { - "name": "Nervisaldi", - "description": "Permette di colpire Pokémon di tipo Spettro con mosse di tipo Normale e Lotta." - }, - "stormDrain": { - "name": "Acquascolo", - "description": "Il Pokémon attira e neutralizza le mosse di tipo Acqua e fa aumentare il proprio Attacco Speciale." - }, - "iceBody": { - "name": "Corpogelo", - "description": "Se grandina, il Pokémon recupera PS." - }, - "solidRock": { - "name": "Solidroccia", - "description": "Riduce i danni subiti dalle mosse superefficaci." - }, - "snowWarning": { - "name": "Scendineve", - "description": "Quando il Pokémon entra in campo, causa l'inizio di una nevicata." - }, - "honeyGather": { - "name": "Mielincetta", - "description": "Il Pokémon raccoglie del miele dopo ogni battaglia. Esso viene poi venduto." - }, - "frisk": { - "name": "Indagine", - "description": "Quando entra in battaglia, il Pokémon può controllare il Potere di un Pokémon avversario." - }, - "reckless": { - "name": "Temerarietà", - "description": "Potenzia le mosse che causano contraccolpo." - }, - "multitype": { - "name": "Multitipo", - "description": "Cambia il tipo del Pokémon a seconda della lastra o del Cristallo Z che ha con sé." - }, - "flowerGift": { - "name": "Regalfiore", - "description": "Se la luce del sole è intensa, aumenta l'Attacco e la Difesa Speciale del Pokémon e dei suoi alleati." - }, - "badDreams": { - "name": "Sogniamari", - "description": "Infligge danni ai nemici addormentati." - }, - "pickpocket": { - "name": "Arraffalesto", - "description": "Se il Pokémon viene colpito da un attacco diretto, ruba lo strumento di chi lo ha attaccato." - }, - "sheerForce": { - "name": "Forzabruta", - "description": "Aumenta la potenza delle mosse, ma ne annulla gli effetti aggiuntivi." - }, - "contrary": { - "name": "Inversione", - "description": "Le modifiche alle statistiche hanno effetto inverso: le statistiche aumentano quando dovrebbero diminuire e viceversa." - }, - "unnerve": { - "name": "Agitazione", - "description": "Il nemico viene intimidito e non può mangiare bacche." - }, - "defiant": { - "name": "Agonismo", - "description": "L'Attacco aumenta di molto quando le statistiche diminuiscono a causa di un nemico." - }, - "defeatist": { - "name": "Sconforto", - "description": "Quando i PS scendono a metà o meno, il Pokémon si scoraggia e l'Attacco e l'Attacco Speciale vengono dimezzati." - }, - "cursedBody": { - "name": "Corpofunesto", - "description": "Può bloccare la mossa subita dal Pokémon." - }, - "healer": { - "name": "Curacuore", - "description": "A volte cura i problemi di stato degli alleati." - }, - "friendGuard": { - "name": "Amicoscudo", - "description": "I danni inflitti agli alleati del Pokémon vengono ridotti." - }, - "weakArmor": { - "name": "Sottilguscio", - "description": "Se il Pokémon subisce danni da mosse fisiche, la Difesa diminuisce e la Velocità aumenta di molto." - }, - "heavyMetal": { - "name": "Metalpesante", - "description": "Raddoppia il peso del Pokémon." - }, - "lightMetal": { - "name": "Metalleggero", - "description": "Dimezza il peso del Pokémon." - }, - "multiscale": { - "name": "Multisquame", - "description": "Se i PS sono al massimo, riduce il danno subito." - }, - "toxicBoost": { - "name": "Velenimpeto", - "description": "Se il Pokémon è avvelenato, la potenza delle sue mosse fisiche aumenta." - }, - "flareBoost": { - "name": "Bruciaimpeto", - "description": "Se il Pokémon è scottato, la potenza delle sue mosse speciali aumenta." - }, - "harvest": { - "name": "Coglibacche", - "description": "Può ricreare una bacca utilizzata." - }, - "telepathy": { - "name": "Telepatia", - "description": "Il Pokémon prevede ed evita gli attacchi degli alleati." - }, - "moody": { - "name": "Altalena", - "description": "A ogni turno, aumenta di molto una statistica e ne riduce un'altra." - }, - "overcoat": { - "name": "Copricapo", - "description": "Rende immuni ai danni da grandine e tempesta di sabbia, alle mosse Spora, Cottonspora, Sonnifero, Paralizzante e alle mosse “polvere”." - }, - "poisonTouch": { - "name": "Velentocco", - "description": "Il Pokémon può avvelenare il nemico al solo contatto." - }, - "regenerator": { - "name": "Rigenergia", - "description": "Il Pokémon recupera un po' di PS quando lascia il campo." - }, - "bigPecks": { - "name": "Pettinfuori", - "description": "Evita che la Difesa diminuisca." - }, - "sandRush": { - "name": "Remasabbia", - "description": "Se c'è una tempesta di sabbia, la Velocità aumenta." - }, - "wonderSkin": { - "name": "Splendicute", - "description": "Il Pokémon resiste più facilmente alle mosse di stato." - }, - "analytic": { - "name": "Ponderazione", - "description": "Se il Pokémon agisce per ultimo, la potenza della mossa aumenta." - }, - "illusion": { - "name": "Illusione", - "description": "Il Pokémon entra in campo con le sembianze dell'ultimo Pokémon della squadra." - }, - "imposter": { - "name": "Sosia", - "description": "Il Pokémon si trasforma nel nemico che ha davanti." - }, - "infiltrator": { - "name": "Intrapasso", - "description": "Il Pokémon attacca evitando le barriere e il sostituto del nemico." - }, - "mummy": { - "name": "Mummia", - "description": "Al contatto con il Pokémon, l'abilità del nemico diventa Mummia." - }, - "moxie": { - "name": "Arroganza", - "description": "Quando manda un nemico KO, il Pokémon si fa sicuro di sé e aumenta il proprio Attacco." - }, - "justified": { - "name": "Giustizia", - "description": "Quando il Pokémon viene colpito da una mossa di tipo Buio, il suo forte senso di giustizia fa sì che l'Attacco aumenti." - }, - "rattled": { - "name": "Paura", - "description": "Le mosse di tipo Buio, Spettro e Coleottero spaventano il Pokémon aumentandone la Velocità." - }, - "magicBounce": { - "name": "Magispecchio", - "description": "Il Pokémon respinge al mittente le mosse di stato senza subirne gli effetti." - }, - "sapSipper": { - "name": "Mangiaerba", - "description": "Se il Pokémon viene colpito da una mossa di tipo Erba, la neutralizza e aumenta il proprio Attacco." - }, - "prankster": { - "name": "Burla", - "description": "Le mosse di stato del Pokémon acquistano priorità alta." - }, - "sandForce": { - "name": "Silicoforza", - "description": "Potenzia le mosse di tipo Roccia, Terra e Acciaio durante le tempeste di sabbia." - }, - "ironBarbs": { - "name": "Spineferrate", - "description": "Se il Pokémon viene colpito da un attacco diretto, infligge danni a sua volta con le sue spine di ferro." - }, - "zenMode": { - "name": "Stato Zen", - "description": "Cambia la forma del Pokémon se i PS scendono a metà o meno." - }, - "victoryStar": { - "name": "Vittorstella", - "description": "Aumenta la precisione di tutta la squadra." - }, - "turboblaze": { - "name": "Piroturbina", - "description": "Quando il Pokémon attacca, ignora l'abilità del bersaglio se questa ha effetto sulle mosse." - }, - "teravolt": { - "name": "Teravolt", - "description": "Quando il Pokémon attacca, ignora l'abilità del bersaglio se questa ha effetto sulle mosse." - }, - "aromaVeil": { - "name": "Aromavelo", - "description": "Protegge tutta la squadra da effetti che ne limitano la libertà di scelta delle mosse." - }, - "flowerVeil": { - "name": "Fiorvelo", - "description": "Rende gli alleati di tipo Erba immuni alla diminuzione delle statistiche e ai problemi di stato." - }, - "cheekPouch": { - "name": "Guancegonfie", - "description": "Quando il Pokémon mangia una bacca, recupera anche dei PS." - }, - "protean": { - "name": "Mutatipo", - "description": "Cambia il tipo del Pokémon in quello della mossa che usa." - }, - "furCoat": { - "name": "Foltopelo", - "description": "Dimezza il danno subito dalle mosse fisiche." - }, - "magician": { - "name": "Prestigiatore", - "description": "Quando chi la usa colpisce un Pokémon con una mossa, gli ruba lo strumento." - }, - "bulletproof": { - "name": "Antiproiettile", - "description": "Protegge da alcune mosse a base di proiettili e bombe." - }, - "competitive": { - "name": "Tenacia", - "description": "L'Attacco Speciale aumenta di molto quando le statistiche diminuiscono a causa di un nemico." - }, - "strongJaw": { - "name": "Ferromascella", - "description": "La robusta mascella del Pokémon permette morsi molto potenti." - }, - "refrigerate": { - "name": "Pellegelo", - "description": "Le mosse di tipo Normale diventano di tipo Ghiaccio e la loro potenza aumenta un po'." - }, - "sweetVeil": { - "name": "Dolcevelo", - "description": "Rende il Pokémon e i suoi alleati immuni al sonno." - }, - "stanceChange": { - "name": "Accendilotta", - "description": "Assume la Forma Spada se usa una mossa d'attacco e la Forma Scudo se usa Scudo Reale." - }, - "galeWings": { - "name": "Aliraffica", - "description": "Se il Pokémon ha tutti i PS, le sue mosse di tipo Volante acquistano priorità alta." - }, - "megaLauncher": { - "name": "Megalancio", - "description": "Potenzia le mosse \"pulsar\", Forzasfera e Ondasana." - }, - "grassPelt": { - "name": "Peloderba", - "description": "In presenza di un Campo Erboso, la Difesa aumenta." - }, - "symbiosis": { - "name": "Simbiosi", - "description": "Se un alleato usa uno strumento, il Pokémon gli passa il proprio." - }, - "toughClaws": { - "name": "Unghiedure", - "description": "Potenzia le mosse che causano un contatto fisico." - }, - "pixilate": { - "name": "Pellefolletto", - "description": "Le mosse di tipo Normale diventano di tipo Folletto e la loro potenza aumenta un po'." - }, - "gooey": { - "name": "Viscosità", - "description": "Se il Pokémon viene colpito da un attacco diretto, la Velocità di chi l'ha colpito diminuisce." - }, - "aerilate": { - "name": "Pellecielo", - "description": "Le mosse di tipo Normale diventano di tipo Volante e la loro potenza aumenta un po'." - }, - "parentalBond": { - "name": "Amorefiliale", - "description": "Il Pokémon e il suo piccolo attaccano insieme." - }, - "darkAura": { - "name": "Auratetra", - "description": "Potenzia le mosse di tipo Buio di tutti i Pokémon." - }, - "fairyAura": { - "name": "Aurafolletto", - "description": "Potenzia le mosse di tipo Folletto di tutti i Pokémon." - }, - "auraBreak": { - "name": "Frangiaura", - "description": "Inverte gli effetti di tutte le aure riducendone la potenza." - }, - "primordialSea": { - "name": "Mare Primordiale", - "description": "Crea un clima che rende inefficaci gli attacchi di tipo Fuoco." - }, - "desolateLand": { - "name": "Terra Estrema", - "description": "Crea un clima che rende inefficaci gli attacchi di tipo Acqua." - }, - "deltaStream": { - "name": "Flusso Delta", - "description": "Crea un clima che annulla i punti deboli del tipo Volante." - }, - "stamina": { - "name": "Sopportazione", - "description": "Se il Pokémon subisce un attacco, la sua Difesa aumenta." - }, - "wimpOut": { - "name": "Fuggifuggi", - "description": "Se i PS scendono a metà o meno, il Pokémon si fa prendere dalla paura e abbandona la lotta in tutta fretta." - }, - "emergencyExit": { - "name": "Passoindietro", - "description": "Se i PS scendono a metà o meno, il Pokémon abbandona la lotta per sfuggire al pericolo." - }, - "waterCompaction": { - "name": "Idrorinforzo", - "description": "Se il Pokémon subisce una mossa di tipo Acqua, la sua Difesa aumenta di molto." - }, - "merciless": { - "name": "Spietatezza", - "description": "Gli attacchi sferrati su un bersaglio avvelenato producono sempre brutti colpi." - }, - "shieldsDown": { - "name": "Scudosoglia", - "description": "Se i PS scendono a metà o meno, il guscio si rompe e il Pokémon si prepara all'offensiva." - }, - "stakeout": { - "name": "Sorveglianza", - "description": "Raddoppia i danni inflitti a un bersaglio che è appena entrato in campo per sostituire un altro Pokémon." - }, - "waterBubble": { - "name": "Bolladacqua", - "description": "Riduce i danni subiti dalle mosse di tipo Fuoco e rende immuni alle scottature." - }, - "steelworker": { - "name": "Tempracciaio", - "description": "Aumenta la potenza delle mosse di tipo Acciaio." - }, - "berserk": { - "name": "Furore", - "description": "Se i PS scendono a metà o meno a causa di un attacco, l'Attacco Speciale aumenta." - }, - "slushRush": { - "name": "Spalaneve", - "description": "Se grandina, la Velocità aumenta." - }, - "longReach": { - "name": "Distacco", - "description": "Il Pokémon è in grado di usare tutte le sue mosse senza entrare in contatto diretto con il bersaglio." - }, - "liquidVoice": { - "name": "Idrovoce", - "description": "Le mosse del Pokémon basate sul suono diventano di tipo Acqua." - }, - "triage": { - "name": "Primacura", - "description": "Le mosse che ripristinano direttamente i PS del Pokémon acquistano priorità alta." - }, - "galvanize": { - "name": "Pellelettro", - "description": "Le mosse di tipo Normale diventano di tipo Elettro e la loro potenza aumenta un po'." - }, - "surgeSurfer": { - "name": "Codasurf", - "description": "In presenza di un Campo Elettrico, la Velocità raddoppia." - }, - "schooling": { - "name": "Banco", - "description": "Quando ha molti PS, il Pokémon forma un banco con i propri simili e si rafforza. Quando ne ha pochi, il banco si disperde." - }, - "disguise": { - "name": "Fantasmanto", - "description": "Il panno che ricopre il Pokémon lo protegge da un singolo attacco." - }, - "battleBond": { - "name": "Morfosintonia", - "description": "Se il Pokémon manda KO un nemico, il legame con l'Allenatore si rafforza, attivando la trasformazione in Greninja Forma Ash. Acqualame si potenzia." - }, - "powerConstruct": { - "name": "Sciamefusione", - "description": "Se i PS del Pokémon scendono a metà o meno, le cellule si raggruppano e gli permettono di assumere la Forma Perfetta." - }, - "corrosion": { - "name": "Corrosione", - "description": "Il Pokémon è in grado di avvelenare il bersaglio anche se questo è di tipo Acciaio o Veleno." - }, - "comatose": { - "name": "Sonno Assoluto", - "description": "Il Pokémon si trova in un costante stato di dormiveglia che gli impedisce di svegliarsi. Può attaccare anche da addormentato." - }, - "queenlyMajesty": { - "name": "Regalità", - "description": "L'aura di regalità del Pokémon impedisce al nemico di attaccarlo con mosse che hanno priorità alta." - }, - "innardsOut": { - "name": "Espellinterno", - "description": "Se il Pokémon viene mandato KO da un attacco, infligge a chi lo ha sferrato tanti danni quanti erano i suoi PS prima di ricevere il colpo." - }, - "dancer": { - "name": "Sincrodanza", - "description": "Permette al Pokémon di copiare immediatamente qualsiasi mossa basata sulla danza usata da un altro Pokémon in campo." - }, - "battery": { - "name": "Batteria", - "description": "Aumenta la potenza delle mosse speciali degli alleati." - }, - "fluffy": { - "name": "Morbidone", - "description": "Dimezza il danno causato dagli attacchi diretti di un nemico, ma raddoppia quello subito dalle mosse di tipo Fuoco." - }, - "dazzling": { - "name": "Corposgargiante", - "description": "Il Pokémon sbalordisce il nemico e non gli permette di attaccarlo con mosse che hanno priorità alta." - }, - "soulHeart": { - "name": "Cuoreanima", - "description": "Aumenta l'Attacco Speciale ogni volta che un Pokémon va KO." - }, - "tanglingHair": { - "name": "Boccolidoro", - "description": "Se il Pokémon viene colpito da un attacco diretto, la Velocità di chi l'ha colpito diminuisce." - }, - "receiver": { - "name": "Ricezione", - "description": "Il Pokémon acquisisce l'abilità di un alleato andato KO." - }, - "powerOfAlchemy": { - "name": "Forza Chimica", - "description": "Il Pokémon trasforma la propria abilità in quella di un alleato andato KO." - }, - "beastBoost": { - "name": "Ultraboost", - "description": "Quando il Pokémon manda KO un altro Pokémon, aumenta la propria statistica di punta." - }, - "rksSystem": { - "name": "Sistema Primevo", - "description": "Il tipo del Pokémon cambia in base alla ROM installata." - }, - "electricSurge": { - "name": "Elettrogenesi", - "description": "Quando il Pokémon entra in campo, lo trasforma in un Campo Elettrico." - }, - "psychicSurge": { - "name": "Psicogenesi", - "description": "Quando il Pokémon entra in campo, lo trasforma in un Campo Psichico." - }, - "mistySurge": { - "name": "Nebbiogenesi", - "description": "Quando il Pokémon entra in campo, lo trasforma in un Campo Nebbioso." - }, - "grassySurge": { - "name": "Erbogenesi", - "description": "Quando il Pokémon entra in campo, lo trasforma in un Campo Erboso." - }, - "fullMetalBody": { - "name": "Metalprotezione", - "description": "Impedisce la diminuzione delle statistiche causata da abilità o mosse di altri Pokémon." - }, - "shadowShield": { - "name": "Spettroguardia", - "description": "Se i PS sono al massimo, riduce il danno subito." - }, - "prismArmor": { - "name": "Scudoprisma", - "description": "Riduce i danni subiti dalle mosse superefficaci." - }, - "neuroforce": { - "name": "Cerebroforza", - "description": "Potenzia le mosse superefficaci." - }, - "intrepidSword": { - "name": "Spada Indomita", - "description": "Quando il Pokémon entra in campo, il suo Attacco aumenta." - }, - "dauntlessShield": { - "name": "Scudo Saldo", - "description": "Quando il Pokémon entra in campo, la sua Difesa aumenta." - }, - "libero": { - "name": "Libero", - "description": "Cambia il tipo del Pokémon in quello della mossa che usa." - }, - "ballFetch": { - "name": "Raccattapalle", - "description": "Se il Pokémon non ha uno strumento con sé, raccoglie la Poké Ball del primo tentativo di cattura fallito." - }, - "cottonDown": { - "name": "Lanugine", - "description": "Se il Pokémon subisce un attacco, sparge della lanugine che diminuisce la Velocità di tutti i Pokémon in campo tranne la sua." - }, - "propellerTail": { - "name": "Elicopinna", - "description": "Permette di ignorare gli effetti di mosse e abilità che attirano altre mosse." - }, - "mirrorArmor": { - "name": "Blindospecchio", - "description": "Rimanda al mittente le diminuzioni alle statistiche subite." - }, - "gulpMissile": { - "name": "Inghiottimissile", - "description": "Quando usa Surf o Sub, il Pokémon cattura una preda. Se subisce dei danni, la sputa fuori per attaccare." - }, - "stalwart": { - "name": "Volontà di Ferro", - "description": "Permette di ignorare gli effetti di mosse e abilità che attirano altre mosse." - }, - "steamEngine": { - "name": "Vapormacchina", - "description": "Se il Pokémon viene colpito da una mossa di tipo Acqua o Fuoco, la sua Velocità aumenta moltissimo." - }, - "punkRock": { - "name": "Punk Rock", - "description": "Aumenta la potenza delle mosse basate sul suono. Inoltre, dimezza i danni subiti dal Pokémon se viene colpito da tali mosse." - }, - "sandSpit": { - "name": "Sputasabbia", - "description": "Quando il Pokémon viene colpito da un attacco, scatena una tempesta di sabbia." - }, - "iceScales": { - "name": "Geloscaglie", - "description": "Scaglie di ghiaccio proteggono il Pokémon dalle mosse speciali, dimezzandone i danni subiti." - }, - "ripen": { - "name": "Maturazione", - "description": "Fa maturare le bacche raddoppiandone gli effetti." - }, - "iceFace": { - "name": "Gelofaccia", - "description": "Grazie al ghiaccio sulla testa, il Pokémon può incassare i danni causati da mosse fisiche, ma cambia forma. Torna al suo stato originale quando grandina." - }, - "powerSpot": { - "name": "Fonte Energetica", - "description": "Potenzia le mosse di chi si trova nelle immediate vicinanze." - }, - "mimicry": { - "name": "Mimetismo", - "description": "Il tipo del Pokémon cambia a seconda dello stato del campo." - }, - "screenCleaner": { - "name": "Annullabarriere", - "description": "Quando il Pokémon entra in campo, annulla l'effetto di Schermoluce, Riflesso e Velaurora sia per i nemici che per gli alleati." - }, - "steelySpirit": { - "name": "Spiritoferreo", - "description": "Potenzia gli attacchi di tipo Acciaio degli alleati." - }, - "perishBody": { - "name": "Ultimotocco", - "description": "Se il Pokémon viene colpito da un attacco diretto, dopo tre turni va KO assieme a chi lo ha attaccato. Se uno dei due viene sostituito, non va KO." - }, - "wanderingSpirit": { - "name": "Anima Errante", - "description": "Se il Pokémon subisce un attacco diretto, scambia la sua abilità con quella di chi lo ha colpito." - }, - "gorillaTactics": { - "name": "Vigorilla", - "description": "Aumenta l'Attacco ma costringe il Pokémon a usare solo la prima mossa selezionata." - }, - "neutralizingGas": { - "name": "Gas Reagente", - "description": "Se in campo c'è un Pokémon con Gas Reagente, gli effetti delle abilità di tutti gli altri Pokémon vengono annullati o non si attivano." - }, - "pastelVeil": { - "name": "Pastelvelo", - "description": "Protegge il Pokémon e gli alleati dai problemi di stato causati dal veleno." - }, - "hungerSwitch": { - "name": "Pancialterna", - "description": "Alla fine di ogni turno cambia forma, alternando tra Motivo Panciapiena e Motivo Panciavuota." - }, - "quickDraw": { - "name": "Pugni Invisibili", - "description": "Quando il Pokémon utilizza un attacco diretto, gli effetti di mosse protettive vengono ignorati." - }, - "unseenFist": { - "name": "Colpolesto", - "description": "A volte permette al Pokémon di agire per primo." - }, - "curiousMedicine": { - "name": "Stranofarmaco", - "description": "Quando il Pokémon entra in campo, sparge un farmaco dalla conchiglia che annulla le modifiche alle statistiche degli alleati." - }, - "transistor": { - "name": "Transistor", - "description": "Potenzia le mosse di tipo Elettro." - }, - "dragonsMaw": { - "name": "Dragomascelle", - "description": "Potenzia le mosse di tipo Drago." - }, - "chillingNeigh": { - "name": "Nitrito Bianco", - "description": "Quando manda KO il nemico, emette un nitrito agghiacciante, aumentando il proprio Attacco." - }, - "grimNeigh": { - "name": "Nitrito Nero", - "description": "Quando manda KO il nemico, emette un nitrito spettrale, aumentando il proprio Attacco Speciale." - }, - "asOneGlastrier": { - "name": "Sintonia Equina", - "description": "Il Pokémon ha una doppia abilità: Agitazione di Calyrex e Nitrito Bianco di Glastrier" - }, - "asOneSpectrier": { - "name": "Sintonia Equina", - "description": "Il Pokémon ha una doppia abilità: Agitazione di Calyrex e Nitrito Nero di Spectrier." - }, - "lingeringAroma": { - "name": "Odore Tenace", - "description": "L'abilità di chi entra in contatto con il Pokémon diventa Odore Tenace." - }, - "seedSower": { - "name": "Spargisemi", - "description": "Se il Pokémon subisce un attacco, il terreno entra nello stato di Campo Erboso." - }, - "thermalExchange": { - "name": "Termoscambio", - "description": "Impedisce al Pokémon di venire scottato e aumenta il suo Attacco se subisce una mossa di tipo Fuoco." - }, - "angerShell": { - "name": "Iraguscio", - "description": "Se un attacco subìto porta i PS a metà o meno, la rabbia del Pokémon ne riduce la Difesa e la Difesa Speciale ma ne aumenta l'Attacco, l'Attacco Speciale e la Velocità." - }, - "purifyingSalt": { - "name": "Sale Purificante", - "description": "Protegge il Pokémon dai problemi di stato e dimezza il danno causato dalle mosse di tipo Spettro." - }, - "wellBakedBody": { - "name": "Bentostato", - "description": "Se il Pokémon viene colpito da una mossa di tipo Fuoco, la neutralizza e aumenta di molto la propria Difesa." - }, - "windRider": { - "name": "Vento Propizio", - "description": "L'Attacco aumenta se vengono usate mosse come Ventoincoda o se il Pokémon è colpito da una mossa basata sul vento, che viene inoltre neutralizzata." - }, - "guardDog": { - "name": "Cane da Guardia", - "description": "Il Pokémon resiste a strumenti e mosse che causano la sostituzione. Se subisce l'effetto di Prepotenza, il suo Attacco aumenta." - }, - "rockyPayload": { - "name": "Portamassi", - "description": "Aumenta la potenza delle mosse di tipo Roccia." - }, - "windPower": { - "name": "Energia Eolica", - "description": "Se il Pokémon è esposto a una mossa basata sul vento, si carica di elettricità." - }, - "zeroToHero": { - "name": "Supercambio", - "description": "Se il Pokémon lascia il campo, assume la Forma Possente." - }, - "commander": { - "name": "Torre di Comando", - "description": "Quando il Pokémon entra in campo ed è presente un Dondozo alleato, si ficca nella bocca di quest'ultimo e da lì impartisce ordini." - }, - "electromorphosis": { - "name": "Convertivolt", - "description": "Se il Pokémon subisce danni, si carica di elettricità." - }, - "protosynthesis": { - "name": "Paleoattivazione", - "description": "Quando il Pokémon ha con sé una Capsula energetica o la luce solare è intensa, la sua statistica più alta aumenta." - }, - "quarkDrive": { - "name": "Carica Quark", - "description": "Quando il Pokémon ha con sé una Capsula energetica o è in presenza di un Campo Elettrico, la sua statistica più alta aumenta." - }, - "goodAsGold": { - "name": "Corpo Aureo", - "description": "Grazie al robusto e inossidabile corpo d'oro, il Pokémon è immune alle mosse di stato sferrate da altri." - }, - "vesselOfRuin": { - "name": "Vaso Nefasto", - "description": "L'Attacco Speciale degli altri Pokémon viene indebolito dal potere del vaso che richiama le disgrazie." - }, - "swordOfRuin": { - "name": "Spada Nefasta", - "description": "La Difesa degli altri Pokémon viene indebolita dal potere della spada che richiama le disgrazie." - }, - "tabletsOfRuin": { - "name": "Amuleto Nefasto", - "description": "L'Attacco degli altri Pokémon viene indebolito dal potere delle tavolette che richiamano le disgrazie." - }, - "beadsOfRuin": { - "name": "Monile Nefasto", - "description": "La Difesa Speciale degli altri Pokémon viene indebolita dal potere dei gioielli che richiamano le disgrazie." - }, - "orichalcumPulse": { - "name": "Ritmo d'Oricalco", - "description": "Quando il Pokémon entra in campo, la luce solare diventa intensa. Con la luce solare intensa l'Attacco del Pokémon aumenta grazie al battito dell'antichità." - }, - "hadronEngine": { - "name": "Motore Adronico", - "description": "Quando il Pokémon entra in campo, il terreno entra nello stato di Campo Elettrico. In presenza di Campo Elettrico l'Attacco Speciale aumenta grazie al motore del futuro." - }, - "opportunist": { - "name": "Scrocco", - "description": "Quando la statistica di un avversario viene aumentata, il Pokémon se ne approfitta e aumenta anche la propria." - }, - "cudChew": { - "name": "Ruminante", - "description": "Se il Pokémon mangia una bacca, alla fine del turno successivo questa risale dal suo stomaco per essere mangiata una seconda volta." - }, - "sharpness": { - "name": "Affilama", - "description": "Aumenta la potenza delle mosse che tagliano il bersaglio." - }, - "supremeOverlord": { - "name": "Generale Supremo", - "description": "Quando il Pokémon entra in campo, il suo Attacco e il suo Attacco Speciale aumentano un po' per ciascuno dei suoi compagni di squadra andati KO." - }, - "costar": { - "name": "Coprotagonismo", - "description": "Quando il Pokémon entra in campo, copia le modifiche alle statistiche dell'alleato." - }, - "toxicDebris": { - "name": "Mantossina", - "description": "Se il Pokémon subisce danni da mosse fisiche, piazza ai piedi degli avversari una trappola di punte velenose." - }, - "armorTail": { - "name": "Codarmatura", - "description": "La misteriosa coda che avvolge la testa del Pokémon impedisce agli avversari di usare mosse che hanno priorità alta contro di lui o i suoi alleati." - }, - "earthEater": { - "name": "Mangiaterra", - "description": "Se il Pokémon viene colpito da una mossa di tipo Terra, recupera PS anziché subire danni." - }, - "myceliumMight": { - "name": "Micoforza", - "description": "Quando usa mosse di stato, il Pokémon agisce più lentamente, ma ignora l'abilità del bersaglio se questa ha effetto su tali mosse." - }, - "mindsEye": { - "name": "Occhio Interiore", - "description": "Permette di colpire bersagli di tipo Spettro con mosse di tipo Normale e Lotta, di ignorare modifiche alla loro elusione e di non veder ridotta la propria precisione." - }, - "supersweetSyrup": { - "name": "Sciroppo Sublime", - "description": "La prima volta che il Pokémon entra in campo, spande un odore dolciastro che diminuisce l'elusione degli avversari." - }, - "hospitality": { - "name": "Ospitalità", - "description": "Quando un Pokémon con questa abilità entra in campo ricopre di attenzioni l'alleato, restituendogli un po' dei suoi PS." - }, - "toxicChain": { - "name": "Catena Tossica", - "description": "Quando il Pokémon colpisce il bersaglio con una mossa, può iperavvelenarlo grazie al potere della catena intrisa di tossine." - }, - "embodyAspectTeal": { - "name": "Albergamemorie", - "description": "Il Pokémon riporta alla mente vecchi ricordi, facendo risplendere la Maschera Focolare e aumentando il proprio Velocità." - }, - "embodyAspectWellspring": { - "name": "Albergamemorie", - "description": "Il Pokémon riporta alla mente vecchi ricordi, facendo risplendere la Maschera Fondamenta e aumentando la propria Difesa Speciale." - }, - "embodyAspectHearthflame": { - "name": "Albergamemorie", - "description": "Il Pokémon riporta alla mente vecchi ricordi, facendo risplendere la Maschera Fondamenta e aumentando la propria Attacco." - }, - "embodyAspectCornerstone": { - "name": "Albergamemorie", - "description": "Il Pokémon riporta alla mente vecchi ricordi, facendo risplendere la Maschera Fondamenta e aumentando la propria Difesa." - }, - "teraShift": { - "name": "Teramorfosi", - "description": "Quando il Pokémon entra in campo, assorbe l'energia circostante e assume la Forma Teracristal." - }, - "teraShell": { - "name": "Teraguscio", - "description": "Grazie al suo guscio che racchiude il potere di tutti i tipi, se il Pokémon ha tutti i PS, le mosse che subisce non saranno molto efficaci." - }, - "teraformZero": { - "name": "Zeroformazione", - "description": "Quando assume la Forma Astrale, Terapagos azzera tutti gli effetti delle condizioni atmosferiche e lo stato del terreno di lotta grazie al suo potere occulto." - }, - "poisonPuppeteer": { - "name": "\tMalia Tossica", - "description": "I Pokémon avvelenati dalle mosse di Pecharunt entreranno anche in stato di confusione." - } -} \ No newline at end of file diff --git a/src/locales/it/achv.json b/src/locales/it/achv.json deleted file mode 100644 index d1607f6c548..00000000000 --- a/src/locales/it/achv.json +++ /dev/null @@ -1,264 +0,0 @@ -{ - "Achievements": { - "name": "Obiettivi" - }, - "Locked": { - "name": "Bloccato" - }, - "MoneyAchv": { - "description": "Accumula {{moneyAmount}} PokéDollari" - }, - "10K_MONEY": { - "name": "Benestante" - }, - "100K_MONEY": { - "name": "Ricco" - }, - "1M_MONEY": { - "name": "Milionario" - }, - "10M_MONEY": { - "name": "La numero uno" - }, - "DamageAchv": { - "description": "Infliggi {{damageAmount}} danni in un colpo" - }, - "250_DMG": { - "name": "Grandi danni!" - }, - "1000_DMG": { - "name": "Incredibili danni" - }, - "2500_DMG": { - "name": "Danni a palate!" - }, - "10000_DMG": { - "name": "One Punch Man" - }, - "HealAchv": { - "description": "Cura {{healAmount}} {{HP}} tramite mossa, abilità, o oggetto" - }, - "250_HEAL": { - "name": "Paramedico" - }, - "1000_HEAL": { - "name": "Dottore" - }, - "2500_HEAL": { - "name": "Chierico" - }, - "10000_HEAL": { - "name": "Mastro Curatore" - }, - "LevelAchv": { - "description": "Porta un pokémon a Lv{{level}}" - }, - "LV_100": { - "name": "E Non Finisce Qui!" - }, - "LV_250": { - "name": "Elite" - }, - "LV_1000": { - "name": "Verso l'Infinito ed Oltre!" - }, - "RibbonAchv": { - "description": "Accumula un Totale di {{ribbonAmount}} Nastri" - }, - "10_RIBBONS": { - "name": "Campione Lega Pokémon" - }, - "25_RIBBONS": { - "name": "Campione Lega Estesa" - }, - "50_RIBBONS": { - "name": "Campione Lega Ultra" - }, - "75_RIBBONS": { - "name": "Campione Lega Rogue" - }, - "100_RIBBONS": { - "name": "Campione Lega Assoluta" - }, - "TRANSFER_MAX_STAT_STAGE": { - "name": "Lavoro di Squadra", - "description": "Trasferisci almeno sei bonus statistiche tramite staffetta" - }, - "MAX_FRIENDSHIP": { - "name": "Amiconi", - "description": "Raggiungi amicizia massima con un Pokémon" - }, - "MEGA_EVOLVE": { - "name": "Megamorfosi", - "description": "Megaevolvi un Pokémon" - }, - "GIGANTAMAX": { - "name": "Grosso e Cattivo", - "description": "Ottieni una gigamax" - }, - "TERASTALLIZE": { - "name": "STAB Per Tutti", - "description": "Teracristallizza un Pokémon" - }, - "STELLAR_TERASTALLIZE": { - "name": "Tipo Segreto", - "description": "Teracristallizza un Pokémon stellare" - }, - "SPLICE": { - "name": "Fusione Infinita", - "description": "Fondi due Pokémon insieme tramite cuneo DNA" - }, - "MINI_BLACK_HOLE": { - "name": "Universo di Oggetti", - "description": "Ottieni un Mini Buco Nero" - }, - "CATCH_MYTHICAL": { - "name": "Mitico", - "description": "Cattura un Pokémon mitico" - }, - "CATCH_SUB_LEGENDARY": { - "name": "(Semi)Leggendario", - "description": "Cattura un Pokémon semileggendario" - }, - "CATCH_LEGENDARY": { - "name": "Leggendario", - "description": "Cattura un Pokémon leggendario" - }, - "SEE_SHINY": { - "name": "Cromatico", - "description": "Trova un Pokémon shiny in natura" - }, - "SHINY_PARTY": { - "name": "Dedizione Totale", - "description": "Riempi la squadra di Pokémon shiny" - }, - "HATCH_MYTHICAL": { - "name": "Uovo Mitico", - "description": "Schiudi l'uovo di un Pokémon mitico" - }, - "HATCH_SUB_LEGENDARY": { - "name": "Uovo (Semi)Leggendario", - "description": "Schiudi l'uovo di un Pokémon semileggendario" - }, - "HATCH_LEGENDARY": { - "name": "Uovo Leggendario", - "description": "Schiudi l'uovo di un Pokémon leggendario" - }, - "HATCH_SHINY": { - "name": "Uovo Cromatico", - "description": "Schiudi l'uovo di un Pokémon shiny" - }, - "HIDDEN_ABILITY": { - "name": "Potenziale Nascosto", - "description": "Cattura un Pokémon con abilità nascosta" - }, - "PERFECT_IVS": { - "name": "Certificato di Autenticità", - "description": "Ottieni un Pokémon con IV perfetti" - }, - "CLASSIC_VICTORY": { - "name": "Imbattuto", - "description": "Vinci in modalità classica" - }, - "UNEVOLVED_CLASSIC_VICTORY": { - "name": "Alternanza scuola-lavoro", - "description": "Completa la modalità classica con almeno un membro della squadra non evoluto completamente." - }, - "MONO_GEN_ONE": { - "name": "Rivale Originale", - "description": "Completa la modalità sfida di prima generazione." - }, - "MONO_GEN_TWO": { - "name": "Generazione 1.5", - "description": "Completa la modalità sfida di seconda generazione." - }, - "MONO_GEN_THREE": { - "name": "Troppa Acqua?", - "description": "Completa la modalità sfida di terza generazione." - }, - "MONO_GEN_FOUR": { - "name": "È Davvero La Più Forte?", - "description": "Completa la modalità sfida di quarta generazione." - }, - "MONO_GEN_FIVE": { - "name": "Tutti Originali", - "description": "Completa la modalità sfida di quinta generazione." - }, - "MONO_GEN_SIX": { - "name": "Vita e Morte", - "description": "Completa la modalità sfida di sesta generazione." - }, - "MONO_GEN_SEVEN": { - "name": "Troppo amichevoli?", - "description": "Completa la modalità sfida di settima generazione." - }, - "MONO_GEN_EIGHT": { - "name": "It's champion time!", - "description": "Completa la modalità sfida di ottava generazione." - }, - "MONO_GEN_NINE": { - "name": "Paradossalmente sbalorditivi", - "description": "Completa la modalità sfida di nona generazione." - }, - "MonoType": { - "description": "Completa la modalità sfida monotipo {{type}}" - }, - "MONO_NORMAL": { - "name": "Un tipo semplice" - }, - "MONO_FIGHTING": { - "name": "Conosco il Kung-fu" - }, - "MONO_FLYING": { - "name": "È un uccello? È un aereo?" - }, - "MONO_POISON": { - "name": "I migliori di Kanto" - }, - "MONO_GROUND": { - "name": "Con i piedi per terra" - }, - "MONO_ROCK": { - "name": "Forte come una roccia!" - }, - "MONO_BUG": { - "name": "Metodo Guzma" - }, - "MONO_GHOST": { - "name": "Sono fantasmi, caro Watson" - }, - "MONO_STEEL": { - "name": "Pugno di ferro" - }, - "MONO_FIRE": { - "name": "Giocare col fuoco" - }, - "MONO_WATER": { - "name": "Piove sul bagnato" - }, - "MONO_GRASS": { - "name": "L'erba del vicino è sempre più verde" - }, - "MONO_ELECTRIC": { - "name": "Elettrizzante" - }, - "MONO_PSYCHIC": { - "name": "Mentalista" - }, - "MONO_ICE": { - "name": "Rompere il ghiaccio" - }, - "MONO_DRAGON": { - "name": "Sangue di drago" - }, - "MONO_DARK": { - "name": "Solo una fase" - }, - "MONO_FAIRY": { - "name": "Follettini e follettine" - }, - "FRESH_START": { - "name": "Buona la prima!", - "description": "Completa la modalità sfida 'Un nuovo inizio'." - } -} diff --git a/src/locales/it/arena-flyout.json b/src/locales/it/arena-flyout.json deleted file mode 100644 index 31c2a4c0015..00000000000 --- a/src/locales/it/arena-flyout.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "activeBattleEffects": "Effetti attivi in campo", - "player": "Giocatore", - "neutral": "Neutrali", - "enemy": "Nemico", - "sunny": "Sole", - "rain": "Pioggia", - "sandstorm": "Tempesta di sabbia", - "hail": "Grandine", - "snow": "Neve", - "fog": "Nebbia", - "heavyRain": "Acquazzone", - "harshSun": "Luce accecante", - "strongWinds": "Corrente d'aria misteriosa", - "misty": "Campo Nebbioso", - "electric": "Campo Elettrico", - "grassy": "Campo Erboso", - "psychic": "Campo Psichico", - "mudSport": "Fangata", - "waterSport": "Docciascudo", - "spikes": "Punte", - "toxicSpikes": "Fielepunte", - "mist": "Nebbia", - "futureSight": "Divinazione", - "doomDesire": "Desiderio Fatale", - "wish": "Desiderio", - "stealthRock": "Levitoroccia", - "stickyWeb": "Rete Vischiosa", - "trickRoom": "Distortozona", - "gravity": "Gravità", - "reflect": "Riflesso", - "lightScreen": "Schermoluce", - "auroraVeil": "Velaurora", - "quickGuard": "Anticipo", - "wideGuard": "Bodyguard", - "matBlock": "Ribaltappeto", - "craftyShield": "Truccodifesa", - "tailwind": "Ventoincoda", - "happyHour": "Cuccagna", - "safeguard": "Salvaguardia" -} diff --git a/src/locales/it/arena-tag.json b/src/locales/it/arena-tag.json deleted file mode 100644 index a1c5ee5b3c9..00000000000 --- a/src/locales/it/arena-tag.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "safeguardOnAdd": "Un velo mistico ricopre il campo!", - "safeguardOnAddPlayer": "Un velo mistico ricopre la tua squadra!", - "safeguardOnAddEnemy": "Un velo mistico ricopre la squadra avversaria!", - "safeguardOnRemove": "Il campo non è più protetto da Salvaguardia!", - "safeguardOnRemovePlayer": "La tua squadra non è più protetta da Salvaguardia!", - "safeguardOnRemoveEnemy": "La squadra avversaria non è più protetta da Salvaguardia!" -} \ No newline at end of file diff --git a/src/locales/it/battle-info.json b/src/locales/it/battle-info.json deleted file mode 100644 index 57bfa03f2f3..00000000000 --- a/src/locales/it/battle-info.json +++ /dev/null @@ -1,3 +0,0 @@ -{ - "generation": "{{generation}} generazione" -} \ No newline at end of file diff --git a/src/locales/it/battle-message-ui-handler.json b/src/locales/it/battle-message-ui-handler.json deleted file mode 100644 index 06449cb3029..00000000000 --- a/src/locales/it/battle-message-ui-handler.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "ivBest": "Stellare", - "ivFantastic": "Eccellente", - "ivVeryGood": "Notevole", - "ivPrettyGood": "Normale", - "ivDecent": "Sufficiente", - "ivNoGood": "Mediocre" -} \ No newline at end of file diff --git a/src/locales/it/battle-scene.json b/src/locales/it/battle-scene.json deleted file mode 100644 index ef916edbf08..00000000000 --- a/src/locales/it/battle-scene.json +++ /dev/null @@ -1,3 +0,0 @@ -{ - "moneyOwned": "{{formattedMoney}} ₽" -} \ No newline at end of file diff --git a/src/locales/it/battle.json b/src/locales/it/battle.json deleted file mode 100644 index 9b187756025..00000000000 --- a/src/locales/it/battle.json +++ /dev/null @@ -1,99 +0,0 @@ -{ - "bossAppeared": "{{bossName}} è apparso.", - "trainerAppeared": "{{trainerName}}\nvuole combattere!", - "trainerAppearedDouble": "{{trainerName}}\nvogliono combattere!", - "trainerSendOut": "{{trainerName}} manda in campo\n{{pokemonName}}!", - "singleWildAppeared": "È apparso {{pokemonName}} selvatico!", - "multiWildAppeared": "Sono apparsi {{pokemonName1}}\ne {{pokemonName2}} salvatici!", - "playerComeBack": "Rientra, {{pokemonName}}!", - "trainerComeBack": "{{trainerName}} ha ritirato {{pokemonName}}!", - "playerGo": "Vai! {{pokemonName}}!", - "trainerGo": "{{trainerName}} manda in campo {{pokemonName}}!", - "switchQuestion": "Vuoi cambiare\n{{pokemonName}}?", - "trainerDefeated": "Hai sconfitto\n{{trainerName}}!", - "moneyWon": "Hai vinto {{moneyAmount}}₽", - "moneyPickedUp": "Hai raccolto ₽{{moneyAmount}}!", - "pokemonCaught": "Preso! {{pokemonName}} è stato catturato!", - "addedAsAStarter": "{{pokemonName}} è stato\naggiunto agli starter!", - "partyFull": "La tua squadra è al completo.\nVuoi liberare un Pokémon per far spazio a {{pokemonName}}?", - "pokemon": "Pokémon", - "sendOutPokemon": "Vai! {{pokemonName}}!", - "hitResultCriticalHit": "Brutto colpo!", - "hitResultSuperEffective": "È superefficace!", - "hitResultNotVeryEffective": "Non è molto efficace…", - "hitResultNoEffect": "Non ha effetto su {{pokemonName}}!", - "hitResultImmune": "{{pokemonName}} è incolume!", - "hitResultOneHitKO": "KO con un colpo!", - "attackFailed": "Ma ha fallito!", - "attackMissed": "{{pokemonNameWithAffix}}\nevita l’attacco!", - "attackHitsCount": "Colpito {{count}} volta/e!", - "rewardGain": "Ricevi\n{{modifierName}}!", - "expGain": "{{pokemonName}} ha guadagnato\n{{exp}} Punti Esperienza!", - "levelUp": "{{pokemonName}} è salito al\nlivello {{level}}!", - "learnMove": "{{pokemonName}} impara\n{{moveName}}!", - "learnMovePrompt": "{{pokemonName}} vorrebbe imparare\n{{moveName}}.", - "learnMoveLimitReached": "Tuttavia, {{pokemonName}}\nconosce già quattro mosse.", - "learnMoveReplaceQuestion": "Vuoi che ne dimentichi una e al suo\nposto apprenda {{moveName}}?", - "learnMoveStopTeaching": "Vuoi smettere di fargli imparare\n{{moveName}}?", - "learnMoveNotLearned": "{{pokemonName}} non ha imparato\n{{moveName}}.", - "learnMoveForgetQuestion": "Quale mossa deve dimenticare?", - "learnMoveForgetSuccess": "{{pokemonName}} ha dimenticato la mossa\n{{moveName}}.", - "countdownPoof": "@d{32}1, @d{15}2, @d{15}e@d{15}… @d{15}… @d{15}… @d{15}@s{se/pb_bounce_1}ta-daaaa!", - "learnMoveAnd": "E…", - "levelCapUp": "Il livello massimo\nè aumentato a {{levelCap}}!", - "moveNotImplemented": "{{moveName}} non è ancora implementata e non può essere selezionata.", - "moveNoPP": "Non ci sono PP rimanenti\nper questa mossa!", - "moveDisabled": "{{moveName}} è disabilitata!", - "disableInterruptedMove": "La mossa {{moveName}} di\n{{pokemonNameWithAffix}} è bloccata!", - "noPokeballForce": "Una forza misteriosa\nimpedisce l'uso delle Poké Ball.", - "noPokeballTrainer": "Non puoi catturare\nPokémon di altri allenatori!", - "noPokeballMulti": "Puoi lanciare una Poké Ball\nsolo quando rimane un singolo Pokémon!", - "noPokeballStrong": "Il Pokémon avversario è troppo forte per essere catturato!\nDevi prima indebolirlo.", - "noEscapeForce": "Una forza misteriosa\nimpedisce la fuga.", - "noEscapeTrainer": "Non puoi sottrarti\nalla lotta con un'allenatore!", - "noEscapePokemon": "{{moveName}} di {{pokemonName}}\npreviene la {{escapeVerb}}!", - "runAwaySuccess": "Scampato pericolo!", - "runAwayCannotEscape": "Non puoi fuggire!", - "escapeVerbSwitch": "cambiando", - "escapeVerbFlee": "fuggendo", - "notDisabled": "{{moveName}} di {{pokemonName}} non è più\ndisabilitata!", - "turnEndHpRestore": "{{pokemonName}} ha recuperato dei PS.", - "hpIsFull": "{{pokemonName}} ha già\ntutti i PS!", - "skipItemQuestion": "Sei sicuro di non voler prendere nessun oggetto?", - "itemStackFull": "The stack for {{fullItemName}} is full.\nYou will receive {{itemName}} instead.", - "eggHatching": "Oh?", - "ivScannerUseQuestion": "Vuoi usare lo scanner di IV su {{pokemonName}}?", - "stealEatBerry": "{{pokemonName}} ha rubato e mangiato\nla {{berryName}} di {{targetName}}!", - "ppHealBerry": "{{pokemonNameWithAffix}} recupera i PP della mossa {{moveName}}\ncon la sua {{berryName}}!", - "hpHealBerry": "{{pokemonNameWithAffix}} ristabilisce la sua salute\ncon la sua {{berryName}}!", - "wildPokemonWithAffix": "{{pokemonName}} selvatico", - "foePokemonWithAffix": "{{pokemonName}} avversario", - "useMove": "{{pokemonNameWithAffix}} usa {{moveName}}!", - "drainMessage": "Viene prelevata energia\n da{{pokemonName}}!", - "regainHealth": "{{pokemonName}} ha rigenerato\npunti salute!", - "fainted": "{{pokemonNameWithAffix}} non è più in\ngrado di combattere!", - "statsAnd": "e", - "stats": "statistiche", - "statRose_one": "La statistica {{stats}} di {{pokemonNameWithAffix}} è aumentata!", - "statRose_other": "Le statistiche {{stats}} di {{pokemonNameWithAffix}} sono aumentate!", - "statSharplyRose_one": "La statistica {{stats}} di {{pokemonNameWithAffix}} è aumentata molto!", - "statSharplyRose_other": "Le statistiche {{stats}} di {{pokemonNameWithAffix}} sono aumentate molto!", - "statRoseDrastically_one": "La statistica {{stats}} di {{pokemonNameWithAffix}} è aumentata drasticamente!", - "statRoseDrastically_other": "Le statistiche {{stats}} di {{pokemonNameWithAffix}} sono aumentate drasticamente!", - "statWontGoAnyHigher_one": "La statistica {{stats}} di {{pokemonNameWithAffix}} non può aumentare di più!", - "statWontGoAnyHigher_other": "Le statistiche {{stats}} di {{pokemonNameWithAffix}} non possono aumentare di più!", - "statFell_one": "La statistica {{stats}} di {{pokemonNameWithAffix}} è diminuita!", - "statFell_other": "Le statistiche {{stats}} di {{pokemonNameWithAffix}} sono diminuite!", - "statHarshlyFell_one": "La statistica {{stats}} di {{pokemonNameWithAffix}} è diminuita molto!", - "statHarshlyFell_other": "Le statistiche {{stats}} di {{pokemonNameWithAffix}} sono diminuite molto!", - "statSeverelyFell_one": "La statistica {{stats}} di {{pokemonNameWithAffix}} è diminuita drasticamente!", - "statSeverelyFell_other": "Le statistiche {{stats}} di {{pokemonNameWithAffix}} sono diminuite drasticamente!", - "statWontGoAnyLower_one": "La statistica {{stats}} di {{pokemonNameWithAffix}} non può diminuire di più!", - "statWontGoAnyLower_other": "Le statistiche {{stats}} di {{pokemonNameWithAffix}} non possono diminuire di più!", - "transformedIntoType": "{{pokemonName}} diventa\ndi tipo {{type}} type!", - "retryBattle": "Vuoi riprovare dall'inizio della lotta?", - "unlockedSomething": "{{unlockedThing}}\nè stato/a sbloccato/a.", - "congratulations": "Congratulazioni!", - "beatModeFirstTime": "{{speciesName}} ha completato la modalità {{gameMode}} per la prima volta!\nHai ricevuto {{newModifier}}!", - "ppReduced": "I PP della mossa {{moveName}} di\n{{targetName}} sono stati ridotti di {{reduction}}!" -} diff --git a/src/locales/it/battler-tags.json b/src/locales/it/battler-tags.json deleted file mode 100644 index 6ab69f4efa2..00000000000 --- a/src/locales/it/battler-tags.json +++ /dev/null @@ -1,77 +0,0 @@ -{ - "trappedDesc": "intrappolando", - "flinchedDesc": "tentennando", - "confusedDesc": "confuso", - "infatuatedDesc": "infatuato", - "seedDesc": "pieno di semi", - "nightmareDesc": "incubi", - "ingrainDesc": "radici", - "drowsyDesc": "assonnato", - "rechargingLapse": "{{pokemonNameWithAffix}} deve\nricaricarsi!", - "trappedOnAdd": "{{pokemonNameWithAffix}} non può\npiù fuggire!", - "trappedOnRemove": "{{pokemonNameWithAffix}} è stato liberato\nda {{moveName}}", - "flinchedLapse": "{{pokemonNameWithAffix}} tentenna!", - "confusedOnAdd": "{{pokemonNameWithAffix}} è\nconfuso!", - "confusedOnRemove": "{{pokemonNameWithAffix}} non\nè più confuso!", - "confusedOnOverlap": "{{pokemonNameWithAffix}} è\ngià confuso!", - "confusedLapse": "{{pokemonNameWithAffix}} è\nconfuso!", - "confusedLapseHurtItself": "Si colpisce da solo per via della\nconfusione!", - "destinyBondLapseIsBoss": "{{pokemonNameWithAffix}} è immune\na Destinobbligato.", - "destinyBondLapse": "{{pokemonNameWithAffix}} trascina\ncon sé{{pokemonNameWithAffix2}}!", - "infatuatedOnAdd": "{{pokemonNameWithAffix}} si è infatuato\ndi {{sourcePokemonName}}!", - "infatuatedOnOverlap": "{{pokemonNameWithAffix}} è\ngià infatuato!", - "infatuatedLapse": "{{pokemonNameWithAffix}} è infatuato\ndi {{sourcePokemonName}}!", - "infatuatedLapseImmobilize": "{{pokemonNameWithAffix}} è\nimmobilizzato dall'infatuazione!", - "infatuatedOnRemove": "{{pokemonNameWithAffix}} non è\npiù infatuato.", - "seededOnAdd": "{{pokemonNameWithAffix}} è pieno di semi!", - "seededLapse": "La salute di {{pokemonNameWithAffix}}\nviene prelevata da Parassiseme!", - "seededLapseShed": "Parassiseme di {{pokemonNameWithAffix}}\nha risucchiato la melma!", - "nightmareOnAdd": "{{pokemonNameWithAffix}} sta\navendo un Incubo!", - "nightmareOnOverlap": "{{pokemonNameWithAffix}} sta\ngià avendo un Incubo!", - "nightmareLapse": "{{pokemonNameWithAffix}} è bloccato\nin un Incubo!", - "encoreOnAdd": "{{pokemonNameWithAffix}} ha\nsubito Ripeti!", - "encoreOnRemove": "L'effetto di Ripeti su {{pokemonNameWithAffix}}\n è terminato!", - "helpingHandOnAdd": "{{pokemonNameWithAffix}} è pronto ad\naiutare {{pokemonName}}!", - "ingrainLapse": "{{pokemonNameWithAffix}} assorbe\nnutrienti dalle sue radici!", - "ingrainOnTrap": "{{pokemonNameWithAffix}} ha messo le radici!", - "aquaRingOnAdd": "{{pokemonNameWithAffix}} si è circondato\ncon un velo d'acqua!", - "aquaRingLapse": "{{moveName}} ha ripristinato\ni PS di {{pokemonName}}!", - "drowsyOnAdd": "{{pokemonNameWithAffix}} sta per addormentarsi!", - "damagingTrapLapse": "{{pokemonNameWithAffix}} subisce danni\nper via di {{moveName}}!", - "bindOnTrap": "{{pokemonNameWithAffix}} viene schiacciato da\n{{moveName}} di {{sourcePokemonName}}!", - "wrapOnTrap": "{{pokemonNameWithAffix}} è stato avvinghiato\nda {{sourcePokemonName}}!", - "vortexOnTrap": "{{pokemonNameWithAffix}} è intrappolato\nnel vortice!", - "clampOnTrap": "{{sourcePokemonNameWithAffix}} sta intenagliando\n{{pokemonName}}!", - "sandTombOnTrap": "{{pokemonNameWithAffix}} è intrappolato\nda {{moveName}}!", - "magmaStormOnTrap": "{{pokemonNameWithAffix}} è intrappolato\nnel magma vorticoso!", - "snapTrapOnTrap": "{{pokemonNameWithAffix}} è intrappolato\nin una tagliola!", - "thunderCageOnTrap": "{{sourcePokemonNameWithAffix}} ha intrappolato\n{{pokemonNameWithAffix}}!", - "infestationOnTrap": "{{pokemonNameWithAffix}} ha subito un\ninfestazione da parte di {{sourcePokemonNameWithAffix}}!", - "protectedOnAdd": "{{pokemonNameWithAffix}}\nsi è protetto!", - "protectedLapse": "{{pokemonNameWithAffix}}\nsi è protetto!", - "enduringOnAdd": "{{pokemonNameWithAffix}} si prepara a\nsubire il colpo!", - "enduringLapse": "{{pokemonNameWithAffix}} resiste\nal colpo!", - "sturdyLapse": "{{pokemonNameWithAffix}} ha resistito\ngrazie a Vigore!", - "perishSongLapse": "Il conto alla rovescia di Ultimocanto per {{pokemonNameWithAffix}} scende a {{turnCount}}.", - "centerOfAttentionOnAdd": "{{pokemonNameWithAffix}} è al centro\ndell’attenzione!", - "truantLapse": "{{pokemonNameWithAffix}} sta\nciondolando!", - "slowStartOnAdd": "{{pokemonNameWithAffix}} non\ningrana!", - "slowStartOnRemove": "{{pokemonNameWithAffix}} ritrova\nlo slancio!", - "highestStatBoostOnAdd": "{{statName}} di {{pokemonNameWithAffix}}\nviene aumentato/a!", - "highestStatBoostOnRemove": "Gli effetti di {{abilityName}}\ndi {{pokemonNameWithAffix}} sono cessati!", - "magnetRisenOnAdd": "{{pokemonNameWithAffix}} si solleva in aria\na causa dell’elettromagnetismo!", - "magnetRisenOnRemove": "L’effetto dell’elettromagnetismo di {{pokemonNameWithAffix}}\nè terminato!", - "critBoostOnAdd": "{{pokemonNameWithAffix}} si prepara\nalla lotta!", - "critBoostOnRemove": "{{pokemonNameWithAffix}} si è rilassato.", - "saltCuredOnAdd": "{{pokemonNameWithAffix}} è stato messo sotto sale!", - "saltCuredLapse": "{{pokemonNameWithAffix}} viene colpito da {{moveName}}!", - "cursedOnAdd": "{{pokemonNameWithAffix}} ha sacrificato metà dei suoi PS per\nlanciare una maledizione su {{pokemonName}}!", - "cursedLapse": "{{pokemonNameWithAffix}} subisce la maledizione!", - "stockpilingOnAdd": "{{pokemonNameWithAffix}} ha usato Accumulo per la\n{{stockpiledCount}}ª volta!", - "disabledOnAdd": "La mossa {{moveName}} di\n{{pokemonNameWithAffix}} è stata bloccata!", - "disabledLapse": "La mossa {{moveName}} di\n{{pokemonNameWithAffix}} non è più bloccata!", - "tarShotOnAdd": "{{pokemonNameWithAffix}} è diventato vulnerabile\nal tipo Fuoco!", - "substituteOnAdd": "Appare un sostituto di {{pokemonNameWithAffix}}!", - "substituteOnHit": "Il sostituto viene colpito al posto di {{pokemonNameWithAffix}}!", - "substituteOnRemove": "Il sostituto di {{pokemonNameWithAffix}} svanisce!" -} diff --git a/src/locales/it/berry.json b/src/locales/it/berry.json deleted file mode 100644 index bb0ea99affd..00000000000 --- a/src/locales/it/berry.json +++ /dev/null @@ -1,46 +0,0 @@ -{ - "SITRUS": { - "name": "Baccacedro", - "effect": "Restituisce il 25% dei PS se i PS sono sotto il 50%" - }, - "LUM": { - "name": "Baccaprugna", - "effect": "Se tenuta da un Pokémon risolve qualsiasi problema di stato" - }, - "ENIGMA": { - "name": "Baccaenigma", - "effect": "Restituisce il 25% dei PS se viene colpito da una mossa superefficace" - }, - "LIECHI": { - "name": "Baccalici", - "effect": "Aumenta l'Attacco se i PS sono sotto il 25%" - }, - "GANLON": { - "name": "Baccalongan", - "effect": "Aumenta la Difesa se i PS sono sotto il 25%" - }, - "PETAYA": { - "name": "Baccapitaya", - "effect": "Aumenta l'Attacco Speciale se i PS sono sotto il 25%" - }, - "APICOT": { - "name": "Baccacocca", - "effect": "Aumenta la Difesa Speciale se i PS sono sotto il 25%" - }, - "SALAC": { - "name": "Baccasalak", - "effect": "Aumenta la Velocità se i PS sono sotto il 25%" - }, - "LANSAT": { - "name": "Baccalangsa", - "effect": "Aumenta la probabilità di Colpo Critico se i PS sono sotto il 25%" - }, - "STARF": { - "name": "Baccambola", - "effect": "Aumenta drasticamente una statistica casuale se i PS sono sotto il 25%" - }, - "LEPPA": { - "name": "Baccamela", - "effect": "Ripristina 10 PP a una mossa se i suoi PP raggiungono lo 0" - } -} \ No newline at end of file diff --git a/src/locales/it/bgm-name.json b/src/locales/it/bgm-name.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/it/bgm-name.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/it/biome.json b/src/locales/it/biome.json deleted file mode 100644 index e2613e29b25..00000000000 --- a/src/locales/it/biome.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "unknownLocation": "Da qualche parte che non ricordi", - "TOWN": "Città", - "PLAINS": "Pianure", - "GRASS": "Campo erboso", - "TALL_GRASS": "Erba alta", - "METROPOLIS": "Metropoli", - "FOREST": "Foresta", - "SEA": "Mare", - "SWAMP": "Palude", - "BEACH": "Spiaggia", - "LAKE": "Lago", - "SEABED": "Fondale", - "MOUNTAIN": "Montagna", - "BADLANDS": "Calanchi", - "CAVE": "Caverna", - "DESERT": "Deserto", - "ICE_CAVE": "Caverna ghiacciata", - "MEADOW": "Prato", - "POWER_PLANT": "Centrale elettrica", - "VOLCANO": "Vulcano", - "GRAVEYARD": "Cimitero", - "DOJO": "Dojo", - "FACTORY": "Fabbrica", - "RUINS": "Antiche rovine", - "WASTELAND": "Terra Desolata", - "ABYSS": "Abisso", - "SPACE": "Spazio", - "CONSTRUCTION_SITE": "Cantiere", - "JUNGLE": "Giungla", - "FAIRY_CAVE": "Caverna fatata", - "TEMPLE": "Tempio", - "SLUM": "Bassifondi", - "SNOWY_FOREST": "Foresta innevata", - "ISLAND": "Isola", - "LABORATORY": "Laboratorio", - "END": "???" -} \ No newline at end of file diff --git a/src/locales/it/challenges.json b/src/locales/it/challenges.json deleted file mode 100644 index 6e7701ef7d0..00000000000 --- a/src/locales/it/challenges.json +++ /dev/null @@ -1,29 +0,0 @@ -{ - "title": "Modificatori delle sfide", - "illegalEvolution": "{{pokemon}} non è più utilizzabile\nsecondo le regole della sfida!", - "singleGeneration": { - "name": "Mono gen", - "desc": "Puoi usare solo Pokémon di {{gen}} generazione.", - "desc_default": "Puoi usare solo Pokémon della generazione selezionata.", - "gen_1": "1ª", - "gen_2": "2ª", - "gen_3": "3ª", - "gen_4": "4ª", - "gen_5": "5ª", - "gen_6": "6ª", - "gen_7": "7ª", - "gen_8": "8ª", - "gen_9": "9ª" - }, - "singleType": { - "name": "Mono tipo", - "desc": "Puoi usare solo Pokémon di tipo {{type}}.", - "desc_default": "Puoi usare solo Pokémon del tipo selezionato." - }, - "freshStart": { - "name": "Un nuovo inizio", - "desc": "Puoi usare solo gli starter originali, e come se avessi appena cominciato Pokérogue.", - "value.0": "Off", - "value.1": "On" - } -} \ No newline at end of file diff --git a/src/locales/it/command-ui-handler.json b/src/locales/it/command-ui-handler.json deleted file mode 100644 index 9446f3304b1..00000000000 --- a/src/locales/it/command-ui-handler.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "fight": "Lotta", - "ball": "Borsa", - "pokemon": "Pokémon", - "run": "Fuga", - "actionMessage": "Cosa deve fare {{pokemonName}}?" -} \ No newline at end of file diff --git a/src/locales/it/common.json b/src/locales/it/common.json deleted file mode 100644 index 1b89d057a94..00000000000 --- a/src/locales/it/common.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "start": "Inizia", - "luckIndicator": "Fortuna:", - "shinyOnHover": "Shiny", - "commonShiny": "Comune", - "rareShiny": "Raro", - "epicShiny": "Epico" -} \ No newline at end of file diff --git a/src/locales/it/config.ts b/src/locales/it/config.ts deleted file mode 100644 index a8cd1e4e0bd..00000000000 --- a/src/locales/it/config.ts +++ /dev/null @@ -1,113 +0,0 @@ -import common from "./common.json"; -import settings from "./settings.json"; -import ability from "./ability.json"; -import abilityTriggers from "./ability-trigger.json"; -import arenaFlyout from "./arena-flyout.json"; -import arenaTag from "./arena-tag.json"; -import achv from "./achv.json"; -import battle from "./battle.json"; -import battleScene from "./battle-scene.json"; -import battleInfo from "./battle-info.json"; -import battleMessageUiHandler from "./battle-message-ui-handler.json"; -import battlerTags from "./battler-tags.json"; -import berry from "./berry.json"; -import bgmName from "./bgm-name.json"; -import biome from "./biome.json"; -import challenges from "./challenges.json"; -import commandUiHandler from "./command-ui-handler.json"; -import dialogue from "./dialogue.json"; -import battleSpecDialogue from "./dialogue-final-boss.json"; -import miscDialogue from "./dialogue-misc.json"; -import doubleBattleDialogue from "./dialogue-double-battle.json"; -import egg from "./egg.json"; -import fightUiHandler from "./fight-ui-handler.json"; -import filterBar from "./filter-bar.json"; -import gameMode from "./game-mode.json"; -import gameStatsUiHandler from "./game-stats-ui-handler.json"; -import growth from "./growth.json"; -import menu from "./menu.json"; -import menuUiHandler from "./menu-ui-handler.json"; -import modifier from "./modifier.json"; -import modifierType from "./modifier-type.json"; -import move from "./move.json"; -import nature from "./nature.json"; -import partyUiHandler from "./party-ui-handler.json"; -import pokeball from "./pokeball.json"; -import pokemon from "./pokemon.json"; -import pokemonForm from "./pokemon-form.json"; -import battlePokemonForm from "./pokemon-form-battle.json"; -import pokemonInfo from "./pokemon-info.json"; -import pokemonInfoContainer from "./pokemon-info-container.json"; -import pokemonSummary from "./pokemon-summary.json"; -import saveSlotSelectUiHandler from "./save-slot-select-ui-handler.json"; -import splashMessages from "./splash-messages.json"; -import starterSelectUiHandler from "./starter-select-ui-handler.json"; -import statusEffect from "./status-effect.json"; -import trainerTitles from "./trainer-titles.json"; -import trainerClasses from "./trainer-classes.json"; -import trainerNames from "./trainer-names.json"; -import tutorial from "./tutorial.json"; -import voucher from "./voucher.json"; -import weather from "./weather.json"; -import terrain from "./terrain.json"; -import modifierSelectUiHandler from "./modifier-select-ui-handler.json"; -import moveTriggers from "./move-trigger.json"; -import runHistory from "./run-history.json"; - -export const itConfig = { - ability, - abilityTriggers, - arenaFlyout, - arenaTag, - battle, - battleScene, - battleInfo, - battleMessageUiHandler, - battlePokemonForm, - battlerTags, - berry, - bgmName, - biome, - challenges, - commandUiHandler, - common, - achv, - dialogue, - battleSpecDialogue, - miscDialogue, - doubleBattleDialogue, - egg, - fightUiHandler, - filterBar, - gameMode, - gameStatsUiHandler, - growth, - menu, - menuUiHandler, - modifier, - modifierType, - move, - nature, - pokeball, - pokemon, - pokemonForm, - pokemonInfo, - pokemonInfoContainer, - pokemonSummary, - saveSlotSelectUiHandler, - settings, - splashMessages, - starterSelectUiHandler, - statusEffect, - terrain, - titles: trainerTitles, - trainerClasses, - trainerNames, - tutorial, - voucher, - weather, - partyUiHandler, - modifierSelectUiHandler, - moveTriggers, - runHistory, -}; diff --git a/src/locales/it/dialogue-double-battle.json b/src/locales/it/dialogue-double-battle.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/it/dialogue-double-battle.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/it/dialogue-final-boss.json b/src/locales/it/dialogue-final-boss.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/it/dialogue-final-boss.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/it/dialogue-misc.json b/src/locales/it/dialogue-misc.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/it/dialogue-misc.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/it/dialogue.json b/src/locales/it/dialogue.json deleted file mode 100644 index 9e26dfeeb6e..00000000000 --- a/src/locales/it/dialogue.json +++ /dev/null @@ -1 +0,0 @@ -{} \ No newline at end of file diff --git a/src/locales/it/egg.json b/src/locales/it/egg.json deleted file mode 100644 index 9f3baddf975..00000000000 --- a/src/locales/it/egg.json +++ /dev/null @@ -1,26 +0,0 @@ -{ - "egg": "Uovo", - "defaultTier": "Comune", - "greatTier": "Raro", - "ultraTier": "Epico", - "masterTier": "Leggendario", - "hatchWavesMessageSoon": "Si sentono dei rumori provenienti dall'interno. Si schiuderà presto!", - "hatchWavesMessageClose": "Sembra muoversi di tanto in tanto. Potrebbe essere prossimo alla schiusa.", - "hatchWavesMessageNotClose": "Cosa uscirà da qui? Pare che non si schiuderà presto.", - "hatchWavesMessageLongTime": "Sembra che questo uovo impiegherà ancora molto tempo per schiudersi.", - "gachaTypeLegendary": "Tasso dei leggendari aumentato", - "gachaTypeMove": "Tasso delle mosse rare da uova aumentato", - "gachaTypeShiny": "Tasso degli shiny aumentato", - "selectMachine": "Seleziona un macchinario.", - "notEnoughVouchers": "Non hai abbastanza biglietti!", - "tooManyEggs": "Hai troppe uova!", - "pull": "tiro", - "pulls": "tiri", - "sameSpeciesEgg": "{{species}} si schiuderà da quest'uovo!", - "hatchFromTheEgg": "Dall’Uovo è nato {{pokemonName}}!", - "eggMoveUnlock": "Mossa da uovo sbloccata: {{moveName}}", - "rareEggMoveUnlock": "Mossa da uovo rara sbloccata: {{moveName}}", - "moveUPGacha": "Mossa +", - "shinyUPGacha": "Shiny +", - "legendaryUPGacha": "+" -} \ No newline at end of file diff --git a/src/locales/it/fight-ui-handler.json b/src/locales/it/fight-ui-handler.json deleted file mode 100644 index 1c24112a1a7..00000000000 --- a/src/locales/it/fight-ui-handler.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "pp": "PP", - "power": "Potenza", - "accuracy": "Precisione", - "abilityFlyInText": "{{passive}}{{pokemonName}}\n{{abilityName}}", - "passive": "Passiva di ", - "teraHover": "Teracristallizzato {{type}}" -} diff --git a/src/locales/it/filter-bar.json b/src/locales/it/filter-bar.json deleted file mode 100644 index d2346d8d3b1..00000000000 --- a/src/locales/it/filter-bar.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "genFilter": "Gen", - "typeFilter": "Tipo", - "caughtFilter": "Catturati", - "unlocksFilter": "Altro", - "miscFilter": "Misc", - "sortFilter": "Ordina", - "all": "Tutto", - "normal": "Non shiny", - "uncaught": "Mancante", - "passive": "Passiva", - "passiveUnlocked": "Passiva sbloccata", - "passiveLocked": "Passiva bloccata", - "passiveUnlockable": "Passiva sbloccabile", - "costReduction": "Riduzione costo", - "costReductionUnlocked": "Costo ridotto", - "costReductionLocked": "Costo non ridotto", - "costReductionUnlockable": "Costo riducibile", - "favorite": "Preferiti", - "isFavorite": "Preferiti - Sì", - "notFavorite": "Preferiti - No", - "ribbon": "Fiocco", - "hasWon": "Fiocco - Sì", - "hasNotWon": "Fiocco - No", - "hiddenAbility": "Abilità speciale", - "hasHiddenAbility": "Abilità speciale - Sì", - "noHiddenAbility": "Abilità speciale - No", - "egg": "Uova", - "eggPurchasable": "Uovo acquistabile", - "pokerus": "Pokérus", - "hasPokerus": "Pokérus - Sì", - "noPokerus": "Pokérus - No", - "sortByNumber": "Num. Dex", - "sortByCost": "Costo", - "sortByCandies": "Caramelle", - "sortByIVs": "IVs", - "sortByName": "Nome" -} \ No newline at end of file diff --git a/src/locales/it/game-mode.json b/src/locales/it/game-mode.json deleted file mode 100644 index 4b0f0448bef..00000000000 --- a/src/locales/it/game-mode.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "classic": "Classica", - "endless": "Infinita", - "endlessSpliced": "Infinita (fusioni)", - "dailyRun": "Run giornaliera", - "unknown": "Sconosciuta", - "challenge": "Sfida" -} \ No newline at end of file diff --git a/src/locales/it/game-stats-ui-handler.json b/src/locales/it/game-stats-ui-handler.json deleted file mode 100644 index 605b759b69e..00000000000 --- a/src/locales/it/game-stats-ui-handler.json +++ /dev/null @@ -1,42 +0,0 @@ -{ - "stats": "Statistiche", - "playTime": "Tempo di gioco", - "totalBattles": "Battaglie totali", - "starters": "Starters", - "shinyStarters": "Starters shiny", - "speciesSeen": "Specie viste", - "speciesCaught": "Specie catturate", - "ribbonsOwned": "Fiocchi ottenuti", - "classicRuns": "Totale run (classica)", - "classicWins": "Totale Vittorie (classica)", - "dailyRunAttempts": "Tentativi di run giornaliere", - "dailyRunWins": "Run giornaliere vinte", - "endlessRuns": "Run in modalità infinita", - "highestWaveEndless": "Orda più alta (Infinita)", - "highestMoney": "Miglior patrimonio", - "highestDamage": "Danni maggiori inflitti", - "highestHPHealed": "PS maggiori rigenerati", - "pokemonEncountered": "Pokémon incontrati", - "pokemonDefeated": "Pokémon sconfitti", - "pokemonCaught": "Pokémon catturati", - "eggsHatched": "Uova schiuse", - "subLegendsSeen": "Semi-leggendari visti", - "subLegendsCaught": "Semi-leggendari catturati", - "subLegendsHatched": "Semi-leggendari schiusi", - "legendsSeen": "Leggendari visti", - "legendsCaught": "Leggendari catturati", - "legendsHatched": "Leggendari schiusi", - "mythicalsSeen": "Mitici visti", - "mythicalsCaught": "Mitici catturati", - "mythicalsHatched": "Mitici schiusi", - "shiniesSeen": "Shiny visti", - "shiniesCaught": "Shiny catturati", - "shiniesHatched": "Shiny schiusi", - "pokemonFused": "Pokémon fusi", - "trainersDefeated": "Allenatori sconfitti", - "eggsPulled": "Uova ottenute", - "rareEggsPulled": "Uova rare ottenute", - "epicEggsPulled": "Uova epiche ottenute", - "legendaryEggsPulled": "Uova leggendarie ottenute", - "manaphyEggsPulled": "Uova di Manaphy ottenute" -} \ No newline at end of file diff --git a/src/locales/it/growth.json b/src/locales/it/growth.json deleted file mode 100644 index c7dd0507eeb..00000000000 --- a/src/locales/it/growth.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "Erratic": "Irregolare", - "Fast": "Veloce", - "Medium_Fast": "Medio-Veloce", - "Medium_Slow": "Medio-Lenta", - "Slow": "Lenta", - "Fluctuating": "Fluttuante" -} \ No newline at end of file diff --git a/src/locales/it/menu-ui-handler.json b/src/locales/it/menu-ui-handler.json deleted file mode 100644 index 7776825f1fe..00000000000 --- a/src/locales/it/menu-ui-handler.json +++ /dev/null @@ -1,29 +0,0 @@ -{ - "GAME_SETTINGS": "Impostazioni", - "ACHIEVEMENTS": "Obiettivi", - "STATS": "Statistiche", - "RUN_HISTORY": "Run precedenti", - "EGG_LIST": "Lista uova", - "EGG_GACHA": "Macchine uova", - "MANAGE_DATA": "Gestisci dati", - "COMMUNITY": "Community", - "SAVE_AND_QUIT": "Salva ed esci", - "LOG_OUT": "Disconnettiti", - "slot": "Slot {{slotNumber}}", - "importSession": "Importa sessione", - "importSlotSelect": "Seleziona uno slot in cui importare.", - "exportSession": "Esporta sessione", - "exportSlotSelect": "Seleziona uno slot da cui esportare.", - "importRunHistory":"Importa run precedenti", - "exportRunHistory":"Esporta run precedenti", - "importData": "Importa dati", - "exportData": "Esporta dati", - "consentPreferences": "Consenti preferenze", - "linkDiscord": "Collega Discord", - "unlinkDiscord": "Scollega Discord", - "linkGoogle": "Collega Google", - "unlinkGoogle": "Scollega Google", - "cancel": "Annulla", - "losingProgressionWarning": "Perderai tutti i progressi dall'inizio della battaglia. Confermi?", - "noEggs": "Non stai schiudendo\nuova al momento!" -} \ No newline at end of file diff --git a/src/locales/it/menu.json b/src/locales/it/menu.json deleted file mode 100644 index 5a40ae05087..00000000000 --- a/src/locales/it/menu.json +++ /dev/null @@ -1,57 +0,0 @@ -{ - "cancel": "Annulla", - "continue": "Continua", - "newGame": "Nuova partita", - "loadGame": "Carica partita", - "settings": "Impostazioni", - "dailyRun": "Run giornaliera (Beta)", - "selectGameMode": "Seleziona una modalità di gioco.", - "logInOrCreateAccount": "Accedi o crea un nuovo account per iniziare. Non è richiesta un'email!", - "username": "Nome utente", - "password": "Password", - "login": "Accedi", - "orUse": "O usa", - "register": "Registrati", - "emptyUsername": "Nome utente mancante!", - "invalidLoginUsername": "Nome utente non valido!", - "invalidRegisterUsername": "Il nome utente può contenere solo lettere, numeri o trattini bassi", - "invalidLoginPassword": "Password non valida!", - "invalidRegisterPassword": "La password deve contenere almeno 6 caratteri", - "usernameAlreadyUsed": "Il nome utente inserito è stato già utilizzato!", - "accountNonExistent": "Account inesistente!", - "unmatchingPassword": "La password inserita non è corretta!", - "passwordNotMatchingConfirmPassword": "La password deve essere uguale alla conferma password!", - "confirmPassword": "Conferma password", - "registrationAgeWarning": "Registrandoti confermi di avere 13 anni o più.", - "backToLogin": "Torna all'accesso", - "failedToLoadSaveData": "Impossibile caricare i dati di salvataggio. Ricarica la pagina.\nSe il problema persiste, contatta l'amministratore.", - "sessionSuccess": "Sessione caricata correttamente.", - "failedToLoadSession": "Impossibile caricare i dati della sessione.\nPotrebbero essere danneggiati.", - "boyOrGirl": "Sei un ragazzo o una ragazza?", - "dailyRankings": "Classifica giornaliera", - "weeklyRankings": "Classifica settimanale", - "noRankings": "Nessuna classifica", - "positionIcon": "#", - "usernameScoreboard": "Nome utente", - "score": "Punteggio", - "wave": "Onda", - "loading": "Caricamento…", - "loadingAsset": "Caricamento asset: {{assetName}}", - "playersOnline": "Giocatori online", - "evolving": "Cosa?\n{{pokemonName}} si sta evolvendo!", - "stoppedEvolving": "{{pokemonName}} ha smesso di evolversi.", - "pauseEvolutionsQuestion": "Vuoi sospendere le evoluzioni per {{pokemonName}}?\nPossono essere riattivate dalla schermata del party.", - "evolutionsPaused": "Le evoluzioni sono state sospese per {{pokemonName}}.", - "evolutionDone": "Congratulazioni!\n{{pokemonName}} si è evoluto in {{evolvedPokemonName}}!", - "yes": "Si", - "no": "No", - "disclaimer": "DISCLAIMER", - "disclaimerDescription": "Questo gioco è un prodotto incompleto; si potrebbero riscontrare errori (inclusa la perdita dei dati di salvataggio),\ncambiamenti impercettibili, e non è detto che venga aggiornato nel tempo o mai completato del tutto.", - "choosePokemon": "Scegli un Pokémon.", - "renamePokemon": "Rinomina un Pokémon", - "rename": "Rinomina", - "nickname": "Nickname", - "errorServerDown": "Poffarbacco! C'è stato un errore nella comunicazione col server.\n\nPuoi lasciare questa finestra aperta,\nil gioco si riconnetterà automaticamente.", - "noSaves": "Non ci sono file di salvataggio registrati!", - "tooManySaves": "Ci sono troppi file di salvataggio registrati!" -} diff --git a/src/locales/it/modifier-select-ui-handler.json b/src/locales/it/modifier-select-ui-handler.json deleted file mode 100644 index f07d8dd2680..00000000000 --- a/src/locales/it/modifier-select-ui-handler.json +++ /dev/null @@ -1,12 +0,0 @@ -{ - "transfer": "Trasferisci", - "reroll": "Rerolla", - "lockRarities": "Blocca le rarità", - "checkTeam": "Stato squadra", - "transferDesc": "Trasferisci un oggetto da un Pokémon ad un altro.", - "rerollDesc": "Spendi soldi per rerollare le ricompense.", - "lockRaritiesDesc": "Blocca le rarità al reroll (influisce sui costi).", - "checkTeamDesc": "Controlla la squadra Pokémon.", - "rerollCost": "{{formattedMoney}}₽", - "itemCost": "{{formattedMoney}}₽" -} \ No newline at end of file diff --git a/src/locales/it/modifier-type.json b/src/locales/it/modifier-type.json deleted file mode 100644 index f06755bdfa0..00000000000 --- a/src/locales/it/modifier-type.json +++ /dev/null @@ -1,607 +0,0 @@ -{ - "ModifierType": { - "AddPokeballModifierType": { - "name": "{{modifierCount}}x {{pokeballName}}", - "description": "Ricevi {{pokeballName}} x{{modifierCount}} (Inventario: {{pokeballAmount}}) \nTasso di cattura: {{catchRate}}." - }, - "AddVoucherModifierType": { - "name": "{{modifierCount}}x {{voucherTypeName}}.", - "description": "Ricevi {{voucherTypeName}} x{{modifierCount}}." - }, - "PokemonHeldItemModifierType": { - "extra": { - "inoperable": "{{pokemonName}} non può prendere\nquesto oggetto!", - "tooMany": "{{pokemonName}} possiede già\nquesto oggetto in abbondanza." - } - }, - "PokemonHpRestoreModifierType": { - "description": "Restituisce {{restorePoints}} PS o {{restorePercent}}% PS ad un Pokémon, a seconda del valore più alto.", - "extra": { - "fully": "Restituisce tutti i PS ad un Pokémon.", - "fullyWithStatus": "Restituisce tutti i PS ad un Pokémon e lo cura da ogni problema di stato." - } - }, - "PokemonReviveModifierType": { - "description": "Rianima un Pokémon esausto e gli restituisce il {{restorePercent}}% dei PS totali." - }, - "PokemonStatusHealModifierType": { - "description": "Cura tutti i problemi di stato di un Pokémon." - }, - "PokemonPpRestoreModifierType": { - "description": "Restituisce {{restorePoints}} PP per una mossa di un Pokémon.", - "extra": { - "fully": "Restituisce tutti i PP di una mossa." - } - }, - "PokemonAllMovePpRestoreModifierType": { - "description": "Restituisce {{restorePoints}} PP a tutte le mosse di un Pokémon.", - "extra": { - "fully": "Restituisce tutti i PP a tutte le mosse di un Pokémon." - } - }, - "PokemonPpUpModifierType": { - "description": "Aumenta i PP di una mossa di {{upPoints}} per ogni 5 PP (massimo 3)." - }, - "PokemonNatureChangeModifierType": { - "name": "Menta {{natureName}}.", - "description": "Cambia la natura del Pokémon in {{natureName}} e sblocca la natura nel menu degli starter." - }, - "DoubleBattleChanceBoosterModifierType": { - "description": "Quadruplica la possibilità di imbattersi in doppie battaglie per {{battleCount}} battaglie." - }, - "TempStatStageBoosterModifierType": { - "description": "Aumenta la statistica {{stat}} di {{amount}}\na tutti i Pokémon nel gruppo per 5 battaglie", - "extra": { - "stage": "un livello", - "percentage": "30%" - } - }, - "AttackTypeBoosterModifierType": { - "description": "Aumenta la potenza delle mosse di tipo {{moveType}} del 20% per un Pokémon." - }, - "PokemonLevelIncrementModifierType": { - "description": "Aumenta il livello di un Pokémon di {{levels}}." - }, - "AllPokemonLevelIncrementModifierType": { - "description": "Aumenta il livello di tutti i Pokémon della squadra di {{levels}}." - }, - "BaseStatBoosterModifierType": { - "description": "Aumenta l'/la {{stat}} di base del possessore del 10%." - }, - "AllPokemonFullHpRestoreModifierType": { - "description": "Restituisce il 100% dei PS a tutti i Pokémon." - }, - "AllPokemonFullReviveModifierType": { - "description": "Rianima tutti i Pokémon esausti restituendogli tutti i PS." - }, - "MoneyRewardModifierType": { - "description": "Garantisce una {{moneyMultiplier}} quantità di soldi (₽{{moneyAmount}}).", - "extra": { - "small": "contenuta", - "moderate": "moderata", - "large": "grande" - } - }, - "ExpBoosterModifierType": { - "description": "Aumenta il guadagno di Punti Esperienza del {{boostPercent}}%." - }, - "PokemonExpBoosterModifierType": { - "description": "Aumenta il guadagno di Punti Esperienza del possessore del {{boostPercent}}%." - }, - "PokemonFriendshipBoosterModifierType": { - "description": "Aumenta del 50% il guadagno di amicizia per vittoria." - }, - "PokemonMoveAccuracyBoosterModifierType": { - "description": "Aumenta la precisione delle mosse di {{accuracyAmount}} (massimo 100)." - }, - "PokemonMultiHitModifierType": { - "description": "Gli attacchi colpiscono una volta in più al costo di una riduzione di potenza del 60/75/82,5% per mossa." - }, - "TmModifierType": { - "name": "MT{{moveId}} - {{moveName}}.", - "description": "Insegna {{moveName}} a un Pokémon." - }, - "TmModifierTypeWithInfo": { - "name": "MT{{moveId}} - {{moveName}}", - "description": "Insegna {{moveName}} a un Pokémon\n(Tieni premuto C o Shift per maggiori informazioni)." - }, - "EvolutionItemModifierType": { - "description": "Fa evolvere determinate specie di Pokémon." - }, - "FormChangeItemModifierType": { - "description": "Fa cambiare forma a determinati Pokémon." - }, - "FusePokemonModifierType": { - "description": "Combina due Pokémon (trasferisce i poteri, divide le statistiche e i tipi base, condivide il pool di mosse)." - }, - "TerastallizeModifierType": { - "name": "Teralite {{teraType}}", - "description": "Teracristallizza in {{teraType}} il possessore per massimo 10 battaglie." - }, - "ContactHeldItemTransferChanceModifierType": { - "description": "Quando il possessore attacca, c'è una probabilità del {{chancePercent}}% che l'oggetto in possesso del nemico gli venga rubato." - }, - "TurnHeldItemTransferModifierType": { - "description": "Ogni turno, il possessore acquisisce un oggetto posseduto dal nemico." - }, - "EnemyAttackStatusEffectChanceModifierType": { - "description": "Aggiunge una probabilità del {{chancePercent}}% di infliggere {{statusEffect}} con le mosse d'attacco." - }, - "EnemyEndureChanceModifierType": { - "description": "Aggiunge una probabilità del {{probabilitàPercent}}% di resistere ad un colpo." - }, - "RARE_CANDY": { - "name": "Caramella rara" - }, - "RARER_CANDY": { - "name": "Caramella molto rara" - }, - "MEGA_BRACELET": { - "name": "Megapolsiera", - "description": "Le megapietre diventano disponibili." - }, - "DYNAMAX_BAND": { - "name": "Polsino Dynamax", - "description": "I fungomax diventano disponibili." - }, - "TERA_ORB": { - "name": "Terasfera", - "description": "I teraliti diventano disponibili." - }, - "MAP": { - "name": "Mappa", - "description": "Permette di scegliere la propria strada a un bivio." - }, - "POTION": { - "name": "Pozione" - }, - "SUPER_POTION": { - "name": "Superpozione" - }, - "HYPER_POTION": { - "name": "Iperpozione" - }, - "MAX_POTION": { - "name": "Pozione max" - }, - "FULL_RESTORE": { - "name": "Ricarica totale" - }, - "REVIVE": { - "name": "Revitalizzante" - }, - "MAX_REVIVE": { - "name": "Revitalizzante max" - }, - "FULL_HEAL": { - "name": "Cura totale" - }, - "SACRED_ASH": { - "name": "Cenere magica" - }, - "REVIVER_SEED": { - "name": "Revitalseme", - "description": "Il possessore recupera 1/2 di PS in caso di KO causato da un colpo diretto." - }, - "WHITE_HERB": { - "name": "Erbachiara", - "description": "Strumento da dare a un Pokémon. Ripristina le statistiche ridotte in lotta." - }, - "ETHER": { - "name": "Etere" - }, - "MAX_ETHER": { - "name": "Etere max" - }, - "ELIXIR": { - "name": "Elisir" - }, - "MAX_ELIXIR": { - "name": "Elisir max" - }, - "PP_UP": { - "name": "PP-su" - }, - "PP_MAX": { - "name": "PP-max" - }, - "LURE": { - "name": "Esca" - }, - "SUPER_LURE": { - "name": "Super esca" - }, - "MAX_LURE": { - "name": "Esca max" - }, - "MEMORY_MUSHROOM": { - "name": "Fungo della memoria", - "description": "Permette di insegnare nuovamente una mossa dimenticata ad un Pokémon." - }, - "EXP_SHARE": { - "name": "Condividi esperienza", - "description": "Tutti i Pokémon della squadra ricevono il 20% dei Punti Esperienza dalla lotta, anche se non vi hanno partecipato." - }, - "EXP_BALANCE": { - "name": "Bilancia esperienza", - "description": "Bilancia i Punti Esperienza ricevuti verso i Pokémon della squadra di livello inferiore." - }, - "OVAL_CHARM": { - "name": "Ovamuleto", - "description": "Quando più Pokémon partecipano a una battaglia, ognuno di essi riceve il 10% in più dell'esperienza totale." - }, - "EXP_CHARM": { - "name": "Esperienzamuleto" - }, - "SUPER_EXP_CHARM": { - "name": "Esperienzamuleto super" - }, - "GOLDEN_EXP_CHARM": { - "name": "Esperienzamuleto dorato" - }, - "LUCKY_EGG": { - "name": "Fortunuovo" - }, - "GOLDEN_EGG": { - "name": "Uovo dorato" - }, - "SOOTHE_BELL": { - "name": "Calmanella" - }, - "SCOPE_LENS": { - "name": "Mirino", - "description": "Lente che aumenta la probabilità di sferrare brutti colpi." - }, - "DIRE_HIT": { - "name": "Supercolpo", - "extra": { - "raises": "Tasso di brutti colpi" - } - }, - "LEEK": { - "name": "Porro", - "description": "Strumento da dare a Farfetch'd. Lungo gambo di porro che aumenta la probabilità di sferrare brutti colpi." - }, - "EVIOLITE": { - "name": "Evolcondensa", - "description": "Misteriosa materia evolutiva. Aumenta la Difesa e la Difesa Speciale di un Pokémon che può ancora evolversi." - }, - "SOUL_DEW": { - "name": "Cuorugiada", - "description": "Aumenta del 10% l'influenza della natura di un Pokémon sulle sue statistiche (cumulativo)." - }, - "NUGGET": { - "name": "Pepita" - }, - "BIG_NUGGET": { - "name": "Granpepita" - }, - "RELIC_GOLD": { - "name": "Dobloantico" - }, - "AMULET_COIN": { - "name": "Monetamuleto", - "description": "Aumenta le ricompense in denaro del 20%." - }, - "GOLDEN_PUNCH": { - "name": "Pugno dorato", - "description": "Fornisce il 50% dei danni inflitti sottoforma di denaro." - }, - "COIN_CASE": { - "name": "Salvadanaio", - "description": "Dopo ogni 10° battaglia, fornisce il 10% del proprio denaro in interessi." - }, - "LOCK_CAPSULE": { - "name": "Capsula scrigno", - "description": "Permette di bloccare le rarità degli oggetti quando si fa un reroll (i costi variano in base alle rarità)." - }, - "GRIP_CLAW": { - "name": "Presartigli" - }, - "WIDE_LENS": { - "name": "Grandelente" - }, - "MULTI_LENS": { - "name": "Multilente" - }, - "HEALING_CHARM": { - "name": "Curamuleto", - "description": "Aumenta del 10% l'efficacia delle mosse e degli oggetti che ripristinano i PS (escluse le rianimazioni)." - }, - "CANDY_JAR": { - "name": "Barattolo di caramelle", - "description": "Aumenta di 1 il numero di livelli aggiunti dalle caramelle rare." - }, - "BERRY_POUCH": { - "name": "Porta bacche", - "description": "Aggiunge il 30% di possibilità che una bacca usata non venga consumata." - }, - "FOCUS_BAND": { - "name": "Bandana", - "description": "Il possessore ottiene il 10% di possibilità aggiuntivo di evitare un potenziale KO e rimanere con un solo PS." - }, - "QUICK_CLAW": { - "name": "Rapidartigli", - "description": "Aggiunge una probabilità del 10% di muoversi per primi, indipendentemente dalla velocità (priorità escluse)." - }, - "KINGS_ROCK": { - "name": "Roccia di re", - "description": "Aggiunge il 10% di possibilità che una mossa d'attacco faccia tentennare l'avversario." - }, - "LEFTOVERS": { - "name": "Avanzi", - "description": "Ripristina 1/16 dei PS massimi di un Pokémon ogni turno." - }, - "SHELL_BELL": { - "name": "Conchinella", - "description": "Cura il possessore di 1/8 del danno inflitto ad un Pokémon." - }, - "TOXIC_ORB": { - "name": "Tossicsfera", - "description": "Sfera bizzarra che iperavvelena chi l’ha con sé in una lotta." - }, - "FLAME_ORB": { - "name": "Fiammosfera", - "description": "Sfera bizzarra che procura una scottatura a chi l’ha con sé in una lotta." - }, - "BATON": { - "name": "Staffetta", - "description": "Permette di trasmettere gli effetti quando si cambia Pokémon, aggirando anche le trappole." - }, - "SHINY_CHARM": { - "name": "Cromamuleto", - "description": "Misterioso amuleto luminoso che aumenta la probabilità di incontrare Pokémon cromatici." - }, - "ABILITY_CHARM": { - "name": "Abilitamuleto", - "description": "Aumenta drasticamente la possibilità che un Pokémon selvatico abbia un'abilità nascosta." - }, - "IV_SCANNER": { - "name": "Scanner IV", - "description": "Permette di scansionare gli IV dei Pokémon selvatici. Vengono rivelati 2 IV per ogni scanner. I migliori IV vengono mostrati per primi." - }, - "DNA_SPLICERS": { - "name": "Cuneo DNA" - }, - "MINI_BLACK_HOLE": { - "name": "Piccolo buco nero" - }, - "GOLDEN_POKEBALL": { - "name": "Poké Ball dorata", - "description": "Aggiunge 1 opzione di oggetto extra alla fine di ogni battaglia." - }, - "ENEMY_DAMAGE_BOOSTER": { - "name": "Gettone del danno", - "description": "Aumenta i danni inflitti del 5%." - }, - "ENEMY_DAMAGE_REDUCTION": { - "name": "Gettone della protezione", - "description": "Riduce i danni ricevuti del 2.5%." - }, - "ENEMY_HEAL": { - "name": "Gettone del recupero", - "description": "Cura il 2% dei PS massimi ogni turno." - }, - "ENEMY_ATTACK_POISON_CHANCE": { - "name": "Gettone del veleno" - }, - "ENEMY_ATTACK_PARALYZE_CHANCE": { - "name": "Gettone della paralisi" - }, - "ENEMY_ATTACK_BURN_CHANCE": { - "name": "Gettone della bruciatura" - }, - "ENEMY_STATUS_EFFECT_HEAL_CHANCE": { - "name": "Gettone guarigione completa", - "description": "Aggiunge una probabilità del 2.5% a ogni turno di guarire da un problema di stato." - }, - "ENEMY_ENDURE_CHANCE": { - "name": "Gettone di resistenza" - }, - "ENEMY_FUSED_CHANCE": { - "name": "Gettone della fusione", - "description": "Aggiunge l'1% di possibilità che un Pokémon selvatico sia una fusione." - } - }, - "SpeciesBoosterItem": { - "LIGHT_BALL": { - "name": "Elettropalla", - "description": "Strumento da dare a Pikachu. Sfera insolita che aumenta l’Attacco e l’Attacco Speciale." - }, - "THICK_CLUB": { - "name": "Osso spesso", - "description": "Strumento da dare a Cubone o Marowak. Osso duro che aumenta l’Attacco." - }, - "METAL_POWDER": { - "name": "Metalpolvere", - "description": "Strumento da dare a Ditto. Strana polvere finissima e al tempo stesso dura che migliora la Difesa." - }, - "QUICK_POWDER": { - "name": "Velopolvere", - "description": "Strumento da dare a Ditto. Questa strana polvere, fine e al contempo dura, aumenta la Velocità." - } - }, - "TempStatStageBoosterItem": { - "x_attack": "Attacco X", - "x_defense": "Difesa X", - "x_sp_atk": "Att. Speciale X", - "x_sp_def": "Dif. Speciale X", - "x_speed": "Velocità X", - "x_accuracy": "Precisione X" - }, - "AttackTypeBoosterItem": { - "silk_scarf": "Sciarpa seta", - "black_belt": "Cinturanera", - "sharp_beak": "Beccaffilato", - "poison_barb": "Velenaculeo", - "soft_sand": "Sabbia soffice", - "hard_stone": "Pietradura", - "silver_powder": "Argenpolvere", - "spell_tag": "Spettrotarga", - "metal_coat": "Metalcopertura", - "charcoal": "Carbonella", - "mystic_water": "Acqua magica", - "miracle_seed": "Miracolseme", - "magnet": "Magnete", - "twisted_spoon": "Cucchiaio torto", - "never_melt_ice": "Gelomai", - "dragon_fang": "Dente di drago", - "black_glasses": "Occhialineri", - "fairy_feather": "Piuma fatata" - }, - "BaseStatBoosterItem": { - "hp_up": "PS-su", - "protein": "Proteina", - "iron": "Ferro", - "calcium": "Calcio", - "zinc": "Zinco", - "carbos": "Carburante" - }, - "EvolutionItem": { - "NONE": "Nessuno", - "LINKING_CORD": "Filo dell'unione", - "SUN_STONE": "Pietrasolare", - "MOON_STONE": "Pietralunare", - "LEAF_STONE": "Pietrafoglia", - "FIRE_STONE": "Pietrafocaia", - "WATER_STONE": "Pietraidrica", - "THUNDER_STONE": "Pietratuono", - "ICE_STONE": "Pietragelo", - "DUSK_STONE": "Neropietra", - "DAWN_STONE": "Pietralbore", - "SHINY_STONE": "Pietrabrillo", - "CRACKED_POT": "Teiera rotta", - "SWEET_APPLE": "Dolcepomo", - "TART_APPLE": "Aspropomo", - "STRAWBERRY_SWEET": "Bonbonfragola", - "UNREMARKABLE_TEACUP": "Tazza dozzinale", - "CHIPPED_POT": "Teiera crepata", - "BLACK_AUGURITE": "Augite nera", - "GALARICA_CUFF": "Fascia Galarnoce", - "GALARICA_WREATH": "Corona Galarnoce", - "PEAT_BLOCK": "Blocco di torba", - "AUSPICIOUS_ARMOR": "Armatura fausta", - "MALICIOUS_ARMOR": "Armatura infausta", - "MASTERPIECE_TEACUP": "Tazza eccezionale", - "METAL_ALLOY": "Metallo composito", - "SCROLL_OF_DARKNESS": "Rotolo del Buio", - "SCROLL_OF_WATERS": "Rotolo dell'Acqua", - "SYRUPY_APPLE": "Sciroppomo" - }, - "FormChangeItem": { - "NONE": "Nessuno", - "ABOMASITE": "Abomasnowite", - "ABSOLITE": "Absolite", - "AERODACTYLITE": "Aerodactylite", - "AGGRONITE": "Aggronite", - "ALAKAZITE": "Alakazamite", - "ALTARIANITE": "Altarite", - "AMPHAROSITE": "Ampharosite", - "AUDINITE": "Audinite", - "BANETTITE": "Banettite", - "BEEDRILLITE": "Beedrillite", - "BLASTOISINITE": "Blastoisite", - "BLAZIKENITE": "Blazikenite", - "CAMERUPTITE": "Cameruptite", - "CHARIZARDITE_X": "Charizardite X", - "CHARIZARDITE_Y": "Charizardite Y", - "DIANCITE": "Diancite", - "GALLADITE": "Galladite", - "GARCHOMPITE": "Garchompite", - "GARDEVOIRITE": "Gardevoirite", - "GENGARITE": "Gengarite", - "GLALITITE": "Glalite", - "GYARADOSITE": "Gyaradosite", - "HERACRONITE": "Heracronite", - "HOUNDOOMINITE": "Houndoomite", - "KANGASKHANITE": "Kangaskhanite", - "LATIASITE": "Latiasite", - "LATIOSITE": "Latiosite", - "LOPUNNITE": "Lopunnite", - "LUCARIONITE": "Lucarite", - "MANECTITE": "Manectricite", - "MAWILITE": "Mawilite", - "MEDICHAMITE": "Medichamite", - "METAGROSSITE": "Metagrossite", - "MEWTWONITE_X": "Mewtwoite X", - "MEWTWONITE_Y": "Mewtwoite Y", - "PIDGEOTITE": "Pidgeotite", - "PINSIRITE": "Pinsirite", - "RAYQUAZITE": "Rayquazite", - "SABLENITE": "Sableyite", - "SALAMENCITE": "Salamencite", - "SCEPTILITE": "Sceptilite", - "SCIZORITE": "Scizorite", - "SHARPEDONITE": "Sharpedite", - "SLOWBRONITE": "Slowbroite", - "STEELIXITE": "Steelixite", - "SWAMPERTITE": "Swampertite", - "TYRANITARITE": "Tyranitarite", - "VENUSAURITE": "Venusaurite", - "BLUE_ORB": "Gemma Blu", - "RED_ORB": "Gemma Rossa", - "SHARP_METEORITE": "Meteorite Tagliente", - "HARD_METEORITE": "Meteorite Dura", - "SMOOTH_METEORITE": "Meteorite Liscia", - "ADAMANT_CRYSTAL": "Adamasferoide", - "LUSTROUS_GLOBE": "Splendisferoide", - "GRISEOUS_CORE": "Grigiosferoide", - "REVEAL_GLASS": "Verispecchio", - "GRACIDEA": "Gracidea", - "MAX_MUSHROOMS": "Fungomax", - "DARK_STONE": "Scurolite", - "LIGHT_STONE": "Chiarolite", - "PRISON_BOTTLE": "Vaso del Vincolo", - "N_LUNARIZER": "Necrolunix", - "N_SOLARIZER": "Necrosolix", - "RUSTED_SWORD": "Spada Rovinata", - "RUSTED_SHIELD": "Scudo Rovinato", - "ICY_REINS_OF_UNITY": "Briglie Legame Giaccio", - "SHADOW_REINS_OF_UNITY": "Briglie legame Ombra", - "WELLSPRING_MASK": "Maschera Pozzo", - "HEARTHFLAME_MASK": "Maschera Focolare", - "CORNERSTONE_MASK": "Maschera Fondamenta", - "SHOCK_DRIVE": "Voltmodulo", - "BURN_DRIVE": "Piromodulo", - "CHILL_DRIVE": "Gelomodulo", - "DOUSE_DRIVE": "Idromodulo", - "ULTRANECROZIUM_Z": "Ultranecrozium Z", - "FIST_PLATE": "Lastrapugno", - "SKY_PLATE": "Lastracielo", - "TOXIC_PLATE": "Lastrafiele", - "EARTH_PLATE": "Lastrageo", - "STONE_PLATE": "Lastrapietra", - "INSECT_PLATE": "Lastrabaco", - "SPOOKY_PLATE": "Lastratetra", - "IRON_PLATE": "Lastraferro", - "FLAME_PLATE": "Lastrarogo", - "SPLASH_PLATE": "Lastraidro", - "MEADOW_PLATE": "Lastraprato", - "ZAP_PLATE": "Lastrasaetta", - "MIND_PLATE": "Lastramente", - "ICICLE_PLATE": "Lastragelo", - "DRACO_PLATE": "Lastradrakon", - "DREAD_PLATE": "Lastratimore", - "PIXIE_PLATE": "Lastraspiritello", - "BLANK_PLATE": "Lastraripristino", - "LEGEND_PLATE": "Lastraleggenda", - "FIGHTING_MEMORY": "ROM Lotta", - "FLYING_MEMORY": "ROM Volante", - "POISON_MEMORY": "ROM Veleno", - "GROUND_MEMORY": "ROM Terra", - "ROCK_MEMORY": "ROM Roccia", - "BUG_MEMORY": "ROM Coleottero", - "GHOST_MEMORY": "ROM Spettro", - "STEEL_MEMORY": "ROM Acciaio", - "FIRE_MEMORY": "ROM Fuoco", - "WATER_MEMORY": "ROM Acqua", - "GRASS_MEMORY": "ROM Erba", - "ELECTRIC_MEMORY": "ROM Elettro", - "PSYCHIC_MEMORY": "ROM Psico", - "ICE_MEMORY": "ROM Ghiaccio", - "DRAGON_MEMORY": "ROM Drago", - "DARK_MEMORY": "ROM Buio", - "FAIRY_MEMORY": "ROM Folletto", - "NORMAL_MEMORY": "ROM Normale" - } -} diff --git a/src/locales/it/modifier.json b/src/locales/it/modifier.json deleted file mode 100644 index c42bf04bc8a..00000000000 --- a/src/locales/it/modifier.json +++ /dev/null @@ -1,12 +0,0 @@ -{ - "surviveDamageApply": "{{pokemonNameWithAffix}} resiste\ngrazie al/alla suo/a {{typeName}}!", - "turnHealApply": "{{pokemonNameWithAffix}} recupera alcuni PS con\nil/la suo/a {{typeName}}!", - "hitHealApply": "{{pokemonNameWithAffix}} recupera alcuni PS con\nil/la suo/a {{typeName}}!", - "pokemonInstantReviveApply": "{{pokemonNameWithAffix}} torna in forze\ngrazie al/alla suo/a {{typeName}}!", - "resetNegativeStatStageApply": "La riduzione alle statistiche di {{pokemonNameWithAffix}}\nviene annullata grazie al/alla suo/a {{typeName}}!", - "moneyInterestApply": "Ricevi un interesse pari a {{moneyAmount}}₽\ngrazie al/allo/a {{typeName}}!", - "turnHeldItemTransferApply": "Il/l'/lo/la {{itemName}} di {{pokemonNameWithAffix}} è stato assorbito\ndal {{typeName}} di {{pokemonName}}!", - "contactHeldItemTransferApply": "Il/l'/lo/la {{itemName}} di {{pokemonNameWithAffix}} è stato rubato\nda {{pokemonName}} con {{typeName}}!", - "enemyTurnHealApply": "{{pokemonNameWithAffix}}\nristabilisce parte dei PS!", - "bypassSpeedChanceApply": "{{pokemonName}} agisce più rapidamente del normale grazie al suo {{itemName}}!" -} \ No newline at end of file diff --git a/src/locales/it/move-trigger.json b/src/locales/it/move-trigger.json deleted file mode 100644 index c8fb390e53f..00000000000 --- a/src/locales/it/move-trigger.json +++ /dev/null @@ -1,71 +0,0 @@ -{ - "hitWithRecoil": "{{pokemonName}} ha subito il contraccolpo!", - "cutHpPowerUpMove": "{{pokemonName}} riduce i suoi PS per potenziare la sua mossa!", - "absorbedElectricity": "{{pokemonName}} assorbe elettricità!", - "switchedStatChanges": "{{pokemonName}} scambia con il bersaglio le modifiche alle statistiche!", - "switchedTwoStatChanges": "{{pokemonName}} scambia con il bersaglio le modifiche a {{firstStat}} e {{secondStat}}!", - "switchedStat": "{{pokemonName}} scambia la sua {{stat}} con quella del bersaglio!", - "sharedGuard": "{{pokemonName}} somma le sue capacità difensive con quelle del bersaglio e le ripartisce equamente!", - "sharedPower": "{{pokemonName}} somma le sue capacità offensive con quelle del bersaglio e le ripartisce equamente!", - "goingAllOutForAttack": "{{pokemonName}} fa sul serio!", - "regainedHealth": "{{pokemonName}} s'è\nripreso!", - "keptGoingAndCrashed": "{{pokemonName}} si sbilancia e\nsi schianta!", - "fled": "{{pokemonName}} è fuggito!", - "cannotBeSwitchedOut": "{{pokemonName}} non può essere sostituito!", - "swappedAbilitiesWithTarget": "{{pokemonName}} scambia la sua\nabilità con il bersaglio!", - "coinsScatteredEverywhere": "Ci sono monete sparse ovunque!", - "attackedByItem": "{{itemName}} attacca {{pokemonName}}!", - "whippedUpAWhirlwind": "{{pokemonName}} genera un\nuragano!", - "flewUpHigh": "{{pokemonName}} vola\nin alto!", - "tookInSunlight": "{{pokemonName}} assorbe la luce!", - "dugAHole": "{{pokemonName}} si nasconde sottoterra!", - "loweredItsHead": "{{pokemonName}} abbassa la testa!", - "isGlowing": "{{pokemonName}} è avvolto da una luce intensa!", - "bellChimed": "\tSi sente suonare una campanella!", - "foresawAnAttack": "{{pokemonName}} presagisce\nl’attacco imminente!", - "isTighteningFocus": "{{pokemonName}} si concentra al massimo!", - "hidUnderwater": "{{pokemonName}} sparisce\nsott’acqua!", - "soothingAromaWaftedThroughArea": "Un gradevole profumo si diffonde nell’aria!", - "sprangUp": "{{pokemonName}} spicca un gran balzo!", - "choseDoomDesireAsDestiny": "{{pokemonName}} ipoteca\nil futuro con Desiderio Fatale!", - "vanishedInstantly": "{{pokemonName}} sparisce\nimprovvisamente!", - "tookTargetIntoSky": "{{pokemonName}} trascina\nin aria {{targetName}}!", - "becameCloakedInFreezingLight": "{{pokemonName}} è avvolto da\nuna luce fredda!", - "becameCloakedInFreezingAir": "{{pokemonName}} è avvolto da\nun’atmosfera gelida!", - "isChargingPower": "{{pokemonName}} accumula energia!", - "burnedItselfOut": "Le fiamme di {{pokemonName}} si sono spente!", - "startedHeatingUpBeak": "{{pokemonName}} inizia a\nscaldare il becco!", - "setUpShellTrap": "{{pokemonName}} ha preparato\nla Gusciotrappola!", - "isOverflowingWithSpacePower": "La forza dell’universo pervade {{pokemonName}}!", - "usedUpAllElectricity": "{{pokemonName}} ha usato tutta la sua elettricità!", - "stoleItem": "{{pokemonName}} ruba\nil/lo/la {{itemName}} di {{targetName}}!", - "incineratedItem": "{{pokemonName}} incenerisce\nil/lo/la {{itemName}} di {{targetName}}!", - "knockedOffItem": "{{pokemonName}} fa cadere\nil/lo/la {{itemName}} di {{targetName}}!", - "tookMoveAttack": "{{pokemonName}} attira\nl'attacco {{moveName}} su di sé!", - "cutOwnHpAndMaximizedStat": "{{pokemonName}} riduce i suoi PS\ne aumenta al massimo il/la suo/a {{statName}}!", - "copiedStatChanges": "{{pokemonName}} copia\nle modifiche alle statistiche di {{targetName}}!", - "magnitudeMessage": "Magnitudo {{magnitude}}!", - "tookAimAtTarget": "{{pokemonName}} prende la mira\nsu {{targetName}}!", - "transformedIntoType": "{{pokemonName}} è diventato\ndi tipo {{typeName}}!", - "copiedMove": "{{pokemonName}} copia\n{{moveName}}!", - "sketchedMove": "{{pokemonName}} disegna uno schizzo\ndella mossa {{moveName}}!", - "acquiredAbility": "L’abilità di {{pokemonName}}\nè ora {{abilityName}}!", - "copiedTargetAbility": "{{pokemonName}} copia l’abilità {{abilityName}}\ndi {{targetName}}!", - "transformedIntoTarget": "{{pokemonName}} assume le sembianze\ndi {{targetName}}!", - "tryingToTakeFoeDown": "{{pokemonName}} tenta di far subire a chi lo manda KO la sua stessa sorte!", - "addType": "Adesso {{pokemonName}} è anche\ndi tipo {{typeName}}!", - "cannotUseMove": "{{pokemonName}} non può usare {{moveName}}!", - "healHp": "{{pokemonName}} ha recuperato dei PS.", - "sacrificialFullRestore": "{{pokemonName}} riceve i benefici\neffetti di Curardore!", - "invertStats": "Le modifiche alle statistiche di {{pokemonName}}\nvengono invertite!", - "resetStats": "Tutte le modifiche alle statistiche sono state annullate!", - "statEliminated": "Tutte le modifiche alle statistiche sono state annullate!", - "faintCountdown": "{{pokemonName}}\nandrà KO dopo {{turnCount}} turni.", - "copyType": "{{pokemonName}} assume il tipo\ndi {{targetPokemonName}}!", - "suppressAbilities": "L’abilità di {{pokemonName}}\nperde ogni efficacia!", - "revivalBlessing": "{{pokemonName}} torna in forze!", - "swapArenaTags": "{{pokemonName}} ha invertito gli effetti attivi\nnelle due metà del campo!", - "exposedMove": "{{pokemonName}} ha identificato\n{{targetPokemonName}}!", - "safeguard": "Salvaguardia protegge {{targetName}}!", - "afterYou": "{{pokemonName}} approfitta della cortesia!" -} diff --git a/src/locales/it/move.json b/src/locales/it/move.json deleted file mode 100644 index f5bb1954278..00000000000 --- a/src/locales/it/move.json +++ /dev/null @@ -1,3810 +0,0 @@ -{ - "pound": { - "name": "Botta", - "effect": "Colpisce il nemico con la coda o le zampe anteriori." - }, - "karateChop": { - "name": "Colpokarate", - "effect": "Colpisce il nemico con un colpo netto. Probabile brutto colpo." - }, - "doubleSlap": { - "name": "Doppiasberla", - "effect": "Schiaffeggia il nemico da due a cinque volte di fila." - }, - "cometPunch": { - "name": "Cometapugno", - "effect": "Colpisce il nemico con una scarica di pugni da due a cinque volte di fila." - }, - "megaPunch": { - "name": "Megapugno", - "effect": "Colpisce il nemico con un pugno poderoso." - }, - "payDay": { - "name": "Giornopaga", - "effect": "Colpisce il nemico con una gran quantità di monete recuperabili dopo la lotta." - }, - "firePunch": { - "name": "Fuocopugno", - "effect": "Colpisce il nemico con un pugno ardente che può scottarlo." - }, - "icePunch": { - "name": "Gelopugno", - "effect": "Colpisce il nemico con un pugno di ghiaccio che può congelarlo." - }, - "thunderPunch": { - "name": "Tuonopugno", - "effect": "Colpisce il nemico con un pugno elettrico che può paralizzarlo." - }, - "scratch": { - "name": "Graffio", - "effect": "Infligge danni al nemico con artigli acuminati, duri e affilati." - }, - "viseGrip": { - "name": "Presa", - "effect": "Stringe il nemico in una morsa usando enormi e possenti tenaglie." - }, - "guillotine": { - "name": "Ghigliottina", - "effect": "Attacca il nemico con pericolose tenaglie. Se l'attacco va a segno, il nemico va subito KO." - }, - "razorWind": { - "name": "Ventagliente", - "effect": "Chi la usa genera un turbine al primo turno e attacca al secondo. Probabile brutto colpo." - }, - "swordsDance": { - "name": "Danzaspada", - "effect": "Danza frenetica che incrementa lo spirito combattivo. Chi la usa aumenta di molto il suo Attacco." - }, - "cut": { - "name": "Taglio", - "effect": "Attacca il nemico con artigli o falci affilate. Fuori dalla lotta si usa per tagliare piccoli alberi." - }, - "gust": { - "name": "Raffica", - "effect": "Infligge danni al nemico con una folata di vento sollevata dalle ali." - }, - "wingAttack": { - "name": "Attacco d'Ala", - "effect": "Infligge danni al nemico spiegando delle grandi ali possenti." - }, - "whirlwind": { - "name": "Turbine", - "effect": "Il bersaglio è spazzato via ed è costretto a lasciare il posto ad un altro. Se è selvatico, la lotta finisce." - }, - "fly": { - "name": "Volo", - "effect": "Chi la usa si alza in volo per attaccare al turno seguente. Fuori dalla lotta permette di volare in città già visitate." - }, - "bind": { - "name": "Legatutto", - "effect": "Lega e stritola il nemico per quattro o cinque turni con tentacoli o con un corpo lungo." - }, - "slam": { - "name": "Schianto", - "effect": "Infligge danni al nemico con una coda, una liana o simili." - }, - "vineWhip": { - "name": "Frustata", - "effect": "Infligge danni al nemico con liane sottili simili a fruste." - }, - "stomp": { - "name": "Pestone", - "effect": "Colpisce il nemico con un grosso piede e può anche farlo tentennare." - }, - "doubleKick": { - "name": "Doppiocalcio", - "effect": "Colpisce il nemico due volte con un paio di rapidi calci inferti con entrambi i piedi." - }, - "megaKick": { - "name": "Megacalcio", - "effect": "Colpisce il nemico con un calcio sferrato con la forza di muscoli poderosi." - }, - "jumpKick": { - "name": "Calciosalto", - "effect": "Permette di saltare in alto per attaccare con un calcio. Se non va a buon fine, chi la usa si ferisce." - }, - "rollingKick": { - "name": "Calciorullo", - "effect": "Chi la usa infierisce sul nemico con un calcio rotante. Può anche farlo tentennare." - }, - "sandAttack": { - "name": "Turbosabbia", - "effect": "Getta sabbia in faccia al nemico e ne riduce la precisione." - }, - "headbutt": { - "name": "Bottintesta", - "effect": "Chi la usa si lancia diritto di testa contro il nemico. Può anche far tentennare." - }, - "hornAttack": { - "name": "Incornata", - "effect": "Danneggia il nemico infilzandolo con un corno affilato." - }, - "furyAttack": { - "name": "Furia", - "effect": "Infilza il nemico con corna affilate o un becco da due a cinque volte di fila." - }, - "hornDrill": { - "name": "Perforcorno", - "effect": "Colpisce il nemico con un corno perforante come un trapano. Se il colpo va a segno, il nemico va KO." - }, - "tackle": { - "name": "Azione", - "effect": "Attacco fisico che colpisce il nemico investendolo con tutto il corpo." - }, - "bodySlam": { - "name": "Corposcontro", - "effect": "Chi la usa carica il nemico con tutto il corpo. Può causarne anche la paralisi." - }, - "wrap": { - "name": "Avvolgibotta", - "effect": "Avvolge e stritola il nemico con un corpo lungo o con piante rampicanti per quattro o cinque turni." - }, - "takeDown": { - "name": "Riduttore", - "effect": "Carica spericolata con tutto il corpo contro il nemico. Danneggia un po' anche chi la usa." - }, - "thrash": { - "name": "Colpo", - "effect": "Assale e attacca il nemico per due o tre turni, ma confonde chi la usa." - }, - "doubleEdge": { - "name": "Sdoppiatore", - "effect": "Carica spietata e pericolosa che danneggia molto anche chi la usa." - }, - "tailWhip": { - "name": "Colpocoda", - "effect": "Chi la usa agita la coda per distrarre i nemici, riducendone la Difesa." - }, - "poisonSting": { - "name": "Velenospina", - "effect": "Colpisce il nemico con un aculeo tossico che può anche avvelenarlo." - }, - "twineedle": { - "name": "Doppio Ago", - "effect": "Colpisce il nemico due volte di seguito con un paio di aghi. Può anche avvelenarlo." - }, - "pinMissile": { - "name": "Missilspillo", - "effect": "Il nemico viene colpito da due a cinque volte con spilli appuntiti in rapida successione." - }, - "leer": { - "name": "Fulmisguardo", - "effect": "Il nemico viene guardato con sguardo intimidatorio da occhi acuti. Viene ridotta la difesa dell'avversario." - }, - "bite": { - "name": "Morso", - "effect": "Il nemico viene morso da denti affilatissimi che possono farlo tentennare." - }, - "growl": { - "name": "Ruggito", - "effect": "Il Pokémon ruggisce con cattiveria. Viene ridotto l'attacco dell'avversario." - }, - "roar": { - "name": "Boato", - "effect": "Il bersaglio è costretto a lasciare il campo e viene sostituito. Mette fine alle lotte contro Pokémon selvatici." - }, - "sing": { - "name": "Canto", - "effect": "Una ninna nanna è cantata con voce calma per far addormentare il nemico." - }, - "supersonic": { - "name": "Supersuono", - "effect": "Chi la usa genera dal proprio corpo strane onde acustiche che possono confondere il nemico." - }, - "sonicBoom": { - "name": "Sonicboom", - "effect": "Il nemico viene colpito con un suono distruttivo che infligge un danno sempre 20 PS." - }, - "disable": { - "name": "Inibitore", - "effect": "Per quattro turni impedisce al bersaglio di riutilizzare l'ultima mossa usata." - }, - "acid": { - "name": "Acido", - "effect": "Colpisce i nemici intorno spruzzando un acido corrosivo. Può anche ridurne la Difesa Speciale." - }, - "ember": { - "name": "Braciere", - "effect": "Il Pokémon attacca con piccole fiamme. Possono scottare il nemico." - }, - "flamethrower": { - "name": "Lanciafiamme", - "effect": "Il nemico viene colpito da intense fiammate che possono anche scottarlo." - }, - "mist": { - "name": "Nebbia", - "effect": "Chi la usa attira una nebbia che blocca la riduzione alle statistiche della sua squadra per cinque turni." - }, - "waterGun": { - "name": "Pistolacqua", - "effect": "Il nemico è colpito da un potente getto d'acqua." - }, - "hydroPump": { - "name": "Idropompa", - "effect": "Il nemico è travolto da un potente getto d'acqua spruzzato ad altissima pressione." - }, - "surf": { - "name": "Surf", - "effect": "Un'onda enorme sommerge il campo di lotta. Fuori dalla lotta si usa per spostarsi sull'acqua." - }, - "iceBeam": { - "name": "Geloraggio", - "effect": "Il nemico è colpito da un raggio di energia gelida che può anche congelarlo." - }, - "blizzard": { - "name": "Bora", - "effect": "Colpisce i bersagli con una tremenda tempesta di ghiaccio che può anche congelarli." - }, - "psybeam": { - "name": "Psicoraggio", - "effect": "Il nemico è attaccato con un raggio psichico. Può anche lasciare il nemico confuso." - }, - "bubbleBeam": { - "name": "Bollaraggio", - "effect": "Colpisce il nemico con una forte scarica di bolle. Può anche ridurne la Velocità." - }, - "auroraBeam": { - "name": "Raggiaurora", - "effect": "Il nemico viene colpito da un fascio color arcobaleno. Può ridurre l'attacco dell'avversario." - }, - "hyperBeam": { - "name": "Iper Raggio", - "effect": "Colpisce il nemico con un potente raggio. Chi la usa salta il turno successivo per recuperare energia." - }, - "peck": { - "name": "Beccata", - "effect": "Colpisce il nemico con un becco appuntito o un corno." - }, - "drillPeck": { - "name": "Perforbecco", - "effect": "Attacco a spirale con un becco aguzzo che fa da trapano." - }, - "submission": { - "name": "Sottomissione", - "effect": "Chi la usa carica il nemico in modo spericolato, ma danneggia anche se stesso." - }, - "lowKick": { - "name": "Colpo Basso", - "effect": "Un calcio basso e potente che fa cadere il nemico. Danneggia maggiormente i nemici più pesanti." - }, - "counter": { - "name": "Contrattacco", - "effect": "Una mossa di ritorsione che contrasta qualsiasi attacco fisico, infliggendo il doppio dei danni subiti." - }, - "seismicToss": { - "name": "Movimento Sismico", - "effect": "Colpisce il bersaglio con la forza di gravità. Infligge un danno pari al livello di chi la usa." - }, - "strength": { - "name": "Forza", - "effect": "Colpisce il nemico con un'enorme energia. Fuori dalla lotta si usa per spostare i massi." - }, - "absorb": { - "name": "Assorbimento", - "effect": "Mossa che assorbe PS. Chi la usa recupera una quantità di PS pari alla metà del danno inferto." - }, - "megaDrain": { - "name": "Megassorbimento", - "effect": "Mossa che assorbe PS. Chi la usa recupera un quantità di PS pari alla metà del danno inferto." - }, - "leechSeed": { - "name": "Parassiseme", - "effect": "Vengono piantati semi sul bersaglio. Questi sottraggono PS a ogni turno permettendo a chi la usa di curarsi." - }, - "growth": { - "name": "Crescita", - "effect": "Provoca la crescita immediata del corpo e l'aumento dell'Attacco e dell'Attacco Speciale di chi la usa." - }, - "razorLeaf": { - "name": "Foglielama", - "effect": "Foglie taglienti sferzano i nemici intorno. Probabile brutto colpo." - }, - "solarBeam": { - "name": "Solarraggio", - "effect": "Chi la usa assorbe luce al primo turno per proiettare un raggio intenso al turno successivo." - }, - "poisonPowder": { - "name": "Velenpolvere", - "effect": "Una nube di polvere velenosa è sparsa sul nemico. Può avvelenare il bersaglio." - }, - "stunSpore": { - "name": "Paralizzante", - "effect": "Investe il bersaglio con una nuvola di polvere che paralizza." - }, - "sleepPowder": { - "name": "Sonnifero", - "effect": "Investe il bersaglio con una grande nuvola di polvere soporifera che lo fa addormentare." - }, - "petalDance": { - "name": "Petalodanza", - "effect": "Attacca il nemico cospargendolo di petali per due o tre turni, ma chi la usa rimane confuso." - }, - "stringShot": { - "name": "Millebave", - "effect": "Chi la usa produce della seta che avvolge i nemici e ne riduce la Velocità." - }, - "dragonRage": { - "name": "Ira di Drago", - "effect": "Colpisce il nemico con un'onda d'urto generata dall'ira. Questo attacco provoca sempre un danno di 40 PS." - }, - "fireSpin": { - "name": "Turbofuoco", - "effect": "Intrappola il bersaglio in un turbine di fuoco che dura per quattro o cinque turni." - }, - "thunderShock": { - "name": "Tuonoshock", - "effect": "Danneggia il bersaglio con una scarica elettrica che può anche paralizzarlo." - }, - "thunderbolt": { - "name": "Fulmine", - "effect": "Il bersaglio viene colpito da una potente scarica elettrica che può anche paralizzarlo." - }, - "thunderWave": { - "name": "Tuononda", - "effect": "Il nemico viene colpito da una debole scarica elettrica che, se va a segno, ne causa la paralisi." - }, - "thunder": { - "name": "Tuono", - "effect": "Il nemico è colpito da un lampo molto violento che può anche paralizzarlo." - }, - "rockThrow": { - "name": "Sassata", - "effect": "Chi la usa solleva una roccia e la lancia contro il nemico." - }, - "earthquake": { - "name": "Terremoto", - "effect": "Chi la usa provoca un potente sisma che colpisce gli altri Pokémon in campo." - }, - "fissure": { - "name": "Abisso", - "effect": "Chi la usa crea una spaccatura nel terreno e cerca di gettarvici dentro il nemico. Se va a segno, il nemico va KO." - }, - "dig": { - "name": "Fossa", - "effect": "Chi la usa scava al primo turno e attacca al successivo. Fuori dalla lotta fa uscire da alcuni luoghi." - }, - "toxic": { - "name": "Tossina", - "effect": "Una mossa che lascia l'obiettivo gravemente avvelenato. Il danno da veleno peggiora ad ogni turno." - }, - "confusion": { - "name": "Confusione", - "effect": "Colpisce il nemico con una leggera forza telecinetica e può anche confonderlo." - }, - "psychic": { - "name": "Psichico", - "effect": "Il nemico viene colpito da una potente forza telecinetica che può anche ridurne la Difesa Speciale." - }, - "hypnosis": { - "name": "Ipnosi", - "effect": "Chi la usa si avvale della suggestione ipnotica per far addormentare il nemico." - }, - "meditate": { - "name": "Meditazione", - "effect": "Il Pokémon medita risvegliando il potere nel profondo del suo corpo ed aumentando il suo Attacco." - }, - "agility": { - "name": "Agilità", - "effect": "Chi la usa rilassa e alleggerisce il proprio corpo per far salire di molto la Velocità." - }, - "quickAttack": { - "name": "Attacco Rapido", - "effect": "Chi la usa colpisce sempre per primo e ad una tale velocità da rendersi quasi invisibile." - }, - "rage": { - "name": "Ira", - "effect": "Questa mossa ha il potere di aumentare la statistica Attacco ogni volta che chi la usa viene colpito durante una lotta." - }, - "teleport": { - "name": "Teletrasporto", - "effect": "Fa fuggire dai Pokémon selvatici. Fuori dalla lotta porta all'ultimo Centro Pokémon visitato." - }, - "nightShade": { - "name": "Ombra Notturna", - "effect": "Fa apparire un orribile miraggio al nemico e infligge un danno pari al livello di chi la usa." - }, - "mimic": { - "name": "Mimica", - "effect": "Copia l'ultima mossa usata dal bersaglio. La mossa copiata si può utilizzare fino alla sostituzione del Pokémon." - }, - "screech": { - "name": "Stridio", - "effect": "Stridio assordante che riduce di molto la Difesa del nemico." - }, - "doubleTeam": { - "name": "Doppioteam", - "effect": "Chi la usa si muove in fretta e crea copie illusorie di se stesso che aumentano la capacità di elusione." - }, - "recover": { - "name": "Ripresa", - "effect": "Una mossa di auto-guarigione. Il Pokémon ripristina i suoi PS fino a metà dei suoi PS massimi." - }, - "harden": { - "name": "Rafforzatore", - "effect": "Tutti i muscoli del corpo si tonificano per aumentare la Difesa." - }, - "minimize": { - "name": "Minimizzato", - "effect": "Il corpo di chi la usa si comprime e diventa più piccolo. La sua capacità di elusione aumenta di molto." - }, - "smokescreen": { - "name": "Muro di Fumo", - "effect": "Il Pokémon rilascia un'oscura cortina di fumo che riduce la precisione del nemico." - }, - "confuseRay": { - "name": "Stordiraggio", - "effect": "Il nemico è colpito da un raggio sinistro che lo confonde." - }, - "withdraw": { - "name": "Ritirata", - "effect": "Il corpo si ritira nel suo duro guscio per aumentare la Difesa." - }, - "defenseCurl": { - "name": "Ricciolscudo", - "effect": "Chi la usa si raggomitola per nascondere i punti deboli e aumentare la propria Difesa." - }, - "barrier": { - "name": "Barriera", - "effect": "Innalza una barriera resistente che aumenta molto la Difesa." - }, - "lightScreen": { - "name": "Schermoluce", - "effect": "Innalza una barriera di luce fantastica per ridurre i danni degli attacchi speciali alla squadra per cinque turni." - }, - "haze": { - "name": "Nube", - "effect": "Chi la usa crea una nube nera che annulla ogni modifica delle statistiche di tutti i Pokémon in campo." - }, - "reflect": { - "name": "Riflesso", - "effect": "Innalza una barriera di luce fantastica per ridurre i danni degli attacchi fisici alla squadra per cinque turni." - }, - "focusEnergy": { - "name": "Focalenergia", - "effect": "Chi la usa fa un profondo respiro e si concentra per rendere più probabili i brutti colpi." - }, - "bide": { - "name": "Pazienza", - "effect": "Chi la usa subisce attacchi per due turni e poi restituisce il danno moltiplicato per due." - }, - "metronome": { - "name": "Metronomo", - "effect": "Il Pokémon fa di no con il dito e stimola il cervello a usare a caso una delle tante mosse esistenti." - }, - "mirrorMove": { - "name": "Speculmossa", - "effect": "Chi la usa colpisce il bersaglio copiandone l'ultima mossa usata." - }, - "selfDestruct": { - "name": "Autodistruzione", - "effect": "Chi la usa esplode e infligge danni agli altri Pokémon in campo, ma poi va KO." - }, - "eggBomb": { - "name": "Uovobomba", - "effect": "Colpisce il nemico con un grande uovo scaraventato con enorme forza." - }, - "lick": { - "name": "Leccata", - "effect": "Una lingua lunga infligge danni al nemico e può anche paralizzarlo." - }, - "smog": { - "name": "Smog", - "effect": "Colpisce il nemico con una scarica di gas maleodoranti. Può anche avvelenarlo." - }, - "sludge": { - "name": "Fango", - "effect": "Lancio di fango malsano che arreca danno al nemico. Può anche avvelenarlo." - }, - "boneClub": { - "name": "Ossoclava", - "effect": "Il Pokémon colpisce il nemico con un bastone d'osso. Può anche fare tentennare l'obiettivo." - }, - "fireBlast": { - "name": "Fuocobomba", - "effect": "Investe il nemico con un'intensa fiammata che fa terra bruciata. Può anche scottarlo." - }, - "waterfall": { - "name": "Cascata", - "effect": "Carica il nemico a grande velocità e può farlo tentennare. Fuori dalla lotta fa risalire le cascate." - }, - "clamp": { - "name": "Tenaglia", - "effect": "Chi la usa intrappola e stritola il nemico con la sua corazza spessa e forte per quattro o cinque turni." - }, - "swift": { - "name": "Comete", - "effect": "Colpisce i nemici con raggi a forma di stella. Questo attacco è infallibile." - }, - "skullBash": { - "name": "Capocciata", - "effect": "Chi la usa ritira la testa per aumentare la Difesa e poi attacca al turno successivo." - }, - "spikeCannon": { - "name": "Sparalance", - "effect": "Il nemico viene colpito da due a cinque volte in rapida successione da spilli appuntiti." - }, - "constrict": { - "name": "Limitazione", - "effect": "Colpisce il nemico con lunghi tentacoli o piante rampicanti. Può anche ridurne la Velocità." - }, - "amnesia": { - "name": "Amnesia", - "effect": "Vuoto di memoria che aumenta esponenzialmente la difesa speciale." - }, - "kinesis": { - "name": "Cinèsi", - "effect": "Chi la usa distrae il bersaglio piegando un cucchiaio e ne riduce la precisione." - }, - "softBoiled": { - "name": "Covauova", - "effect": "Chi la usa recupera metà dei propri PS massimi. Fuori dalla lotta può anche far trasferire PS ai propri compagni." - }, - "highJumpKick": { - "name": "Calcinvolo", - "effect": "Chi la usa colpisce il nemico con una ginocchiata in volo: se fallisce, subisce danni." - }, - "glare": { - "name": "Sguardo Feroce", - "effect": "Chi la usa spaventa il nemico con uno sguardo terrificante e ne causa la paralisi." - }, - "dreamEater": { - "name": "Mangiasogni", - "effect": "Attacco che funziona solo su un nemico che dorme. Chi lo usa riceve metà dei PS persi dal nemico." - }, - "poisonGas": { - "name": "Velenogas", - "effect": "Spruzza in faccia al nemico una nuvola di gas tossico che avvelena." - }, - "barrage": { - "name": "Attacco Pioggia", - "effect": "Piovono enormi sfere sulla testa del nemico da due a cinque volte di fila." - }, - "leechLife": { - "name": "Sanguisuga", - "effect": "Mossa succhiasangue. Chi la usa recupera una quantità di PS pari alla metà del danno inferto." - }, - "lovelyKiss": { - "name": "Demonbacio", - "effect": "Chi la usa intimidisce il bersaglio con una faccia paurosa e gli schiocca un bacio che lo fa addormentare." - }, - "skyAttack": { - "name": "Aeroattacco", - "effect": "Un attacco in due turni e probabile brutto colpo. Può anche far tentennare il nemico." - }, - "transform": { - "name": "Trasformazione", - "effect": "Chi la usa si trasforma in una copia esatta del bersaglio per sfruttarne le caratteristiche." - }, - "bubble": { - "name": "Bolla", - "effect": "Uno spruzzo di bolle viene lanciato sul nemico. Può ridurne la velocità." - }, - "dizzyPunch": { - "name": "Stordipugno", - "effect": "Colpisce il bersaglio con una sequenza di pugni che può anche confonderlo." - }, - "spore": { - "name": "Spora", - "effect": "Nube di spore che fa sempre addormentare il bersaglio." - }, - "flash": { - "name": "Flash", - "effect": "Il Pokémon usa un lampo di luce contro il nemico riducendone la precisione. Può essere usata per illuminare luoghi oscuri." - }, - "psywave": { - "name": "Psiconda", - "effect": "Il nemico è attaccato con una strana onda di energia. L'intensità dell'attacco è variabile." - }, - "splash": { - "name": "Splash", - "effect": "Chi la usa sguazza nell'acqua, senza ottenere alcun effetto." - }, - "acidArmor": { - "name": "Scudo Acido", - "effect": "Il Pokémon modifica la sua struttura cellulare liquefandosi, per aumentare esponenzialmente la sua difesa." - }, - "crabhammer": { - "name": "Martellata", - "effect": "Colpisce il nemico con una grande tenaglia. Probabile brutto colpo." - }, - "explosion": { - "name": "Esplosione", - "effect": "Chi la usa esplode per infliggere danni agli altri Pokémon attorno, ma va KO." - }, - "furySwipes": { - "name": "Sfuriate", - "effect": "Colpisce il nemico con artigli o falci affilate da due a cinque volte in rapida successione." - }, - "bonemerang": { - "name": "Ossomerang", - "effect": "Chi la usa lancia l'osso che tiene. L'osso colpisce due volte e ritorna come un vero e proprio boomerang." - }, - "rest": { - "name": "Riposo", - "effect": "Il Pokémon si addormenta per due turni per curare tutti i PS e qualsiasi problema di stato." - }, - "rockSlide": { - "name": "Frana", - "effect": "I nemici vengono colpiti da grandi massi che possono anche farli tentennare." - }, - "hyperFang": { - "name": "Iperzanna", - "effect": "Il Pokémon morde il nemico con zanne taglienti. Può anche farlo tentennare." - }, - "sharpen": { - "name": "Affilatore", - "effect": "Chi la usa riduce il numero di poligoni sul proprio corpo per accentuarne gli spigoli e aumentare l'Attacco." - }, - "conversion": { - "name": "Conversione", - "effect": "Il tipo di chi la usa muta in quello di una sua mossa a caso." - }, - "triAttack": { - "name": "Tripletta", - "effect": "Colpisce il nemico con tre sfere simultanee che possono anche paralizzarlo, scottarlo o congelarlo." - }, - "superFang": { - "name": "Superzanna", - "effect": "Chi la usa salta sul nemico azzannandolo con i suoi incisivi affilati e facendogli perdere metà dei PS." - }, - "slash": { - "name": "Lacerazione", - "effect": "Attacca il nemico con artigli, falci o altro. Probabile brutto colpo." - }, - "substitute": { - "name": "Sostituto", - "effect": "Chi la usa crea una copia di se stesso usando alcuni PS. La copia serve come esca per il nemico." - }, - "struggle": { - "name": "Scontro", - "effect": "Mossa da usare solo in caso estremo, quando non si hanno più PP. Danneggia anche chi la usa." - }, - "sketch": { - "name": "Schizzo", - "effect": "Permette a chi la usa di imparare l'ultima mossa usata dal bersaglio. La nuova mossa appresa sostituisce Schizzo." - }, - "tripleKick": { - "name": "Triplocalcio", - "effect": "Chi la usa esegue fino a tre calci consecutivi la cui potenza aumenta ad ogni colpo." - }, - "thief": { - "name": "Furto", - "effect": "Il Pokémon attacca e contemporaneamente ruba lo strumento tenuto dal nemico. Non ruberà nulla, se si possiede già uno strumento." - }, - "spiderWeb": { - "name": "Ragnatela", - "effect": "Copre il nemico con un filo di seta sottile e appiccicoso. Il nemico non può fuggire." - }, - "mindReader": { - "name": "Leggimente", - "effect": "Il Pokémon percepisce i movimenti del nemico con la mente per garantire il successo della mossa successiva." - }, - "nightmare": { - "name": "Incubo", - "effect": "Il nemico addormentato ha un incubo e perde PS ad ogni turno." - }, - "flameWheel": { - "name": "Ruotafuoco", - "effect": "Il Pokémon si avvolge nel fuoco e carica il nemico. Può scottare." - }, - "snore": { - "name": "Russare", - "effect": "Mossa da usare solo mentre si dorme. Il chiasso assordante può anche far tentennare il nemico." - }, - "curse": { - "name": "Maledizione", - "effect": "Una mossa che agisce in modo diverso se chi la usa è di tipo Spettro." - }, - "flail": { - "name": "Flagello", - "effect": "Chi la usa si dimena per attaccare. È più efficace se i suoi PS sono bassi." - }, - "conversion2": { - "name": "Conversione2", - "effect": "Chi la usa cambia tipo per rendersi resistente al tipo dell'ultima mossa usata dal bersaglio." - }, - "aeroblast": { - "name": "Aerocolpo", - "effect": "Colpisce il nemico con un vortice d'aria per danneggiarlo. Probabile brutto colpo." - }, - "cottonSpore": { - "name": "Cottonspora", - "effect": "Rilascia spore simili al cotone che si attaccano ai nemici nei paraggi e ne riducono di molto la Velocità." - }, - "reversal": { - "name": "Contropiede", - "effect": "Chi la usa attacca con tutte le sue forze. Più i PS sono bassi, maggiore è la potenza di questa mossa." - }, - "spite": { - "name": "Dispetto", - "effect": "Chi la usa sfoga la propria rabbia sull'ultima mossa usata dal bersaglio e le sottrae quattro PP." - }, - "powderSnow": { - "name": "Polneve", - "effect": "Attacca il nemico con una raffica di neve farinosa e può anche congelarlo." - }, - "protect": { - "name": "Protezione", - "effect": "Permette di eludere tutti gli attacchi. Se usata in successione può fallire." - }, - "machPunch": { - "name": "Pugnorapido", - "effect": "Chi la usa tira un pugno a velocità impressionante e colpisce di sicuro per primo." - }, - "scaryFace": { - "name": "Visotruce", - "effect": "Chi la usa spaventa il nemico con una faccia terribile e ne riduce di molto la Velocità." - }, - "feintAttack": { - "name": "Finta", - "effect": "Chi la usa si avvicina al nemico facendo finta di niente, per poi scagliare un pugno infallibile a tradimento." - }, - "sweetKiss": { - "name": "Dolcebacio", - "effect": "Chi la usa bacia il nemico con una dolcezza angelica, confondendolo." - }, - "bellyDrum": { - "name": "Panciamburo", - "effect": "Chi la usa massimizza l'Attacco in cambio di metà dei PS massimi." - }, - "sludgeBomb": { - "name": "Fangobomba", - "effect": "Chi la usa attacca lanciando fango sul bersaglio. Può anche avvelenarlo." - }, - "mudSlap": { - "name": "Fangosberla", - "effect": "Chi la usa butta fango in faccia al nemico per arrecargli danni e ridurne la precisione." - }, - "octazooka": { - "name": "Octazooka", - "effect": "Chi la usa spruzza del'inchiostro in faccia al nemico. Può anche ridurne la precisione." - }, - "spikes": { - "name": "Punte", - "effect": "Chi la usa piazza sul terreno una trappola di punte che danneggia i nemici quando scendono in campo." - }, - "zapCannon": { - "name": "Falcecannone", - "effect": "Chi la usa provoca un'esplosione elettrica che infligge danni e paralizza il nemico." - }, - "foresight": { - "name": "Preveggenza", - "effect": "Chi la usa rende i Pokémon di tipo Spettro vulnerabili a qualsiasi tipo di mossa e può, inoltre, colpire i nemici sfuggenti." - }, - "destinyBond": { - "name": "Destinobbligato", - "effect": "Se chi la usa va KO prima del proprio turno, chi ha sferrato il colpo da KO fa la stessa fine." - }, - "perishSong": { - "name": "Ultimocanto", - "effect": "Ogni Pokémon che sente questo canto va KO in tre turni, se non lo si sostituisce." - }, - "icyWind": { - "name": "Ventogelato", - "effect": "Chi la usa attacca i nemici con una folata di aria gelida e ne riduce anche la Velocità." - }, - "detect": { - "name": "Individua", - "effect": "Consente al Pokémon di evitare tutti gli attacchi. Può fallire se usato in successione." - }, - "boneRush": { - "name": "Ossoraffica", - "effect": "Chi la usa colpisce il nemico con un osso duro, da 2 a 5 volte di fila." - }, - "lockOn": { - "name": "Localizza", - "effect": "Chi la usa punta il nemico con precisione. La mossa successiva andrà a segno." - }, - "outrage": { - "name": "Oltraggio", - "effect": "Chi la usa sfoga la sua ira e attacca il nemico per due o tre turni prima di essere lasciato in preda alla confusione." - }, - "sandstorm": { - "name": "Terrempesta", - "effect": "Causa una tempesta di sabbia per cinque turni che danneggia tutti i tipi in campo esclusi Terra, Roccia e Acciaio." - }, - "gigaDrain": { - "name": "Gigassorbimento", - "effect": "Mossa che assorbe PS. Chi la usa recupera un quantità di PS pari alla metà del danno inferto." - }, - "endure": { - "name": "Resistenza", - "effect": "Chi la usa resta con un PS anche se subisce un colpo da KO in quel turno. Usata in successione può fallire." - }, - "charm": { - "name": "Fascino", - "effect": "Ammalia il nemico con lo sguardo per renderlo meno cauto. Riduce molto l'Attacco del nemico." - }, - "rollout": { - "name": "Rotolamento", - "effect": "Chi la usa colpisce il nemico rotolando per cinque turni, con aumento progressivo della potenza ogni volta che va a segno." - }, - "falseSwipe": { - "name": "Falsofinale", - "effect": "Chi la usa trattiene il colpo per impedire al nemico di andare KO, lasciandolo con almeno un PS." - }, - "swagger": { - "name": "Bullo", - "effect": "Chi la usa provoca il bersaglio e lo confonde, facendo aumentare però di molto il suo Attacco." - }, - "milkDrink": { - "name": "Buonlatte", - "effect": "Chi la usa recupera metà dei propri PS massimi. Fuori dalla lotta può anche far trasferire PS ai propri compagni." - }, - "spark": { - "name": "Scintilla", - "effect": "Colpisce il nemico con una carica elettrica e può anche paralizzarlo." - }, - "furyCutter": { - "name": "Tagliofuria", - "effect": "Colpisce il nemico con falci o artigli. Se usata in successione aumenta di potenza ogni volta che va a segno." - }, - "steelWing": { - "name": "Alacciaio", - "effect": "Colpisce il nemico con ali d'acciaio. Può anche aumentare la Difesa di chi la usa." - }, - "meanLook": { - "name": "Malosguardo", - "effect": "Chi la usa blocca il nemico con uno sguardo oscuro e ammaliante, impedendogli la fuga." - }, - "attract": { - "name": "Attrazione", - "effect": "Se il nemico è del sesso opposto, s'infatua e attacca con meno probabilità." - }, - "sleepTalk": { - "name": "Sonnolalia", - "effect": "Chi la usa sfodera a caso una delle proprie mosse mentre sta dormendo." - }, - "healBell": { - "name": "Rintoccasana", - "effect": "Chi la usa fa suonare le campane per curare completamente tutta la squadra." - }, - "return": { - "name": "Ritorno", - "effect": "Mossa che diventa tanto più potente quanto maggiore è il grado di affezione del Pokémon per il proprio Allenatore." - }, - "present": { - "name": "Regalino", - "effect": "Chi la usa dà un regalo bomba al bersaglio. A volte, però, può fargli recuperare PS." - }, - "frustration": { - "name": "Frustrazione", - "effect": "Mossa che diventa tanto più potente quanto minore è il grado di affezione del Pokémon per il proprio Allenatore." - }, - "safeguard": { - "name": "Salvaguardia", - "effect": "Chi la usa crea un campo protettivo che difende tutta la squadra dai problemi di stato per cinque turni." - }, - "painSplit": { - "name": "Malcomune", - "effect": "Chi la usa somma i propri PS a quelli di un altro Pokémon per poi dividerli in parti uguali." - }, - "sacredFire": { - "name": "Magifuoco", - "effect": "Colpisce il nemico con un fuoco mistico di enorme intensità che può anche causargli una scottatura." - }, - "magnitude": { - "name": "Magnitudo", - "effect": "Chi la usa scatena un terremoto d'intensità variabile che danneggia gli altri Pokémon in campo." - }, - "dynamicPunch": { - "name": "Dinamipugno", - "effect": "Colpisce il nemico con un pugno davvero forte. Se va a segno, lo confonde." - }, - "megahorn": { - "name": "Megacorno", - "effect": "Chi la usa utilizza il suo corno per montare con grande forza il nemico." - }, - "dragonBreath": { - "name": "Dragospiro", - "effect": "Investe il nemico con una raffica potentissima che arreca danni. Può anche paralizzarlo." - }, - "batonPass": { - "name": "Staffetta", - "effect": "Chi la usa è sostituito da un Pokémon della squadra, che eredita anche ogni modifica alle statistiche." - }, - "encore": { - "name": "Ripeti", - "effect": "Chi la usa costringe il nemico a continuare ad utilizzare solo l'ultima mossa utilizzata da 2 a 6 turni." - }, - "pursuit": { - "name": "Inseguimento", - "effect": "Una mossa d'attacco che infligge un danno doppio se il nemico è in fase di sostituzione." - }, - "rapidSpin": { - "name": "Rapigiro", - "effect": "Un attacco roteante che elimina gli effetti delle mosse Legatutto, Avvolgibotta, Parassiseme e Punte." - }, - "sweetScent": { - "name": "Profumino", - "effect": "Un dolce profumo che alletta il nemico per ridurne l'elusione. Attira anche Pokémon selvatici." - }, - "ironTail": { - "name": "Codacciaio", - "effect": "Il nemico viene colpito da una robusta coda d'acciaio. Può anche ridurne la Difesa." - }, - "metalClaw": { - "name": "Ferrartigli", - "effect": "Colpisce il nemico con artigli d'acciaio. Può anche aumentare l'Attacco di chi la usa." - }, - "vitalThrow": { - "name": "Vitaltiro", - "effect": "Chi la usa attacca per ultimo, ma il colpo è sempre infallibile." - }, - "morningSun": { - "name": "Mattindoro", - "effect": "Chi la usa recupera PS. Il numero di PS recuperati dipende dalle condizioni atmosferiche." - }, - "synthesis": { - "name": "Sintesi", - "effect": "Chi la usa recupera PS. Il numero di PS recuperati dipende dalle condizioni atmosferiche." - }, - "moonlight": { - "name": "Lucelunare", - "effect": "Chi la usa recupera PS. Il numero di PS recuperati dipende dalle condizioni atmosferiche." - }, - "hiddenPower": { - "name": "Introforza", - "effect": "Mossa singolare che cambia tipo e potenza a seconda del Pokémon che la usa." - }, - "crossChop": { - "name": "Incrocolpo", - "effect": "Investe il nemico con un colpo sferrato con entrambe le braccia incrociate. Probabile brutto colpo." - }, - "twister": { - "name": "Tornado", - "effect": "Un potente tornado si abbatte sul nemico. Può anche far tentennare." - }, - "rainDance": { - "name": "Pioggiadanza", - "effect": "Chi la usa provoca una forte pioggia per cinque turni, potenziando le mosse di tipo Acqua." - }, - "sunnyDay": { - "name": "Giornodisole", - "effect": "Chi la usa intensifica i raggi solari per cinque turni, potenziando le mosse di tipo Fuoco." - }, - "crunch": { - "name": "Sgranocchio", - "effect": "Il nemico viene morso con denti affilati. Può anche ridurne la Difesa." - }, - "mirrorCoat": { - "name": "Specchiovelo", - "effect": "Mossa che replica ogni attacco speciale, arrecando il doppio del danno ricevuto." - }, - "psychUp": { - "name": "Psicamisù", - "effect": "Chi la usa s'ipnotizza per copiare ogni modifica alle statistiche del bersaglio." - }, - "extremeSpeed": { - "name": "Extrarapido", - "effect": "Chi la usa carica il nemico a velocità impressionante ed attacca sempre per primo." - }, - "ancientPower": { - "name": "Forzantica", - "effect": "Colpisce il nemico con una forza primordiale. Può aumentare tutte le statistiche." - }, - "shadowBall": { - "name": "Palla Ombra", - "effect": "Lancia sul nemico una sfera nera. Può anche ridurne la Difesa Speciale." - }, - "futureSight": { - "name": "Divinazione", - "effect": "Due turni dopo l'utilizzo di questa mossa, il nemico viene attaccato con energia psichica." - }, - "rockSmash": { - "name": "Spaccaroccia", - "effect": "Il nemico viene colpito da un pugno in grado di frantumare anche la roccia. Può anche ridurne la Difesa." - }, - "whirlpool": { - "name": "Mulinello", - "effect": "Intrappola il nemico in un turbine d'acqua che dura per quattro o cinque turni infliggendogli dei danni ogni turno." - }, - "beatUp": { - "name": "Picchiaduro", - "effect": "Chi la usa chiama in aiuto i Pokémon della squadra: più ce ne sono, maggiore è il numero di attacchi." - }, - "fakeOut": { - "name": "Bruciapelo", - "effect": "Mossa che fa agire per primo e fa tentennare il nemico. Funziona solo appena sceso in campo." - }, - "uproar": { - "name": "Baraonda", - "effect": "Chi la usa attacca per tre turni con un frastuono che non fa dormire nessuno." - }, - "stockpile": { - "name": "Accumulo", - "effect": "Chi la usa accumula energia aumentando la Difesa e la Difesa Speciale. Si può utilizzare tre volte." - }, - "spitUp": { - "name": "Sfoghenergia", - "effect": "Tutta l'energia accumulata in precedenza con Accumulo è rilasciata nell'attacco. Maggiore è l'energia, più danni si arrecano." - }, - "swallow": { - "name": "Introenergia", - "effect": "Chi la usa assorbe l'energia raccolta con la mossa Accumulo e recupera PS. Maggiore è l'energia, più PS si recuperano." - }, - "heatWave": { - "name": "Ondacalda", - "effect": "Chi la usa investe i nemici con una folata di vento caldo. Può anche scottare." - }, - "hail": { - "name": "Grandine", - "effect": "Chi la usa causa una grandinata che dura cinque turni. Danneggia tutti i Pokémon tranne quelli di tipo Ghiaccio." - }, - "torment": { - "name": "Attaccalite", - "effect": "Chi la usa tormenta e fa infuriare il nemico, impedendogli di usare la stessa mossa due volte di seguito." - }, - "flatter": { - "name": "Adulazione", - "effect": "Adula il bersaglio e lo confonde, ma ne aumenta l'Attacco Speciale." - }, - "willOWisp": { - "name": "Fuocofatuo", - "effect": "Fiamme intense di colore viola causano una scottatura al nemico." - }, - "memento": { - "name": "Memento", - "effect": "Chi la usa va KO. Tuttavia, riduce di molto l'Attacco e l'Attacco Speciale del nemico." - }, - "facade": { - "name": "Facciata", - "effect": "Mossa d'attacco che raddoppia la potenza se chi la usa è scottato, avvelenato o paralizzato." - }, - "focusPunch": { - "name": "Centripugno", - "effect": "Chi la usa prende la mira prima di sferrare un pugno. Fallirà se verrà colpito prima di eseguire la mossa." - }, - "smellingSalts": { - "name": "Maniereforti", - "effect": "Infligge un danno doppio ad un bersaglio paralizzato, ma ne cura anche la paralisi." - }, - "followMe": { - "name": "Sonoqui", - "effect": "Chi la usa attrae l'attenzione su di sé, costringendo i nemici a sceglierlo sempre come bersaglio." - }, - "naturePower": { - "name": "Naturforza", - "effect": "Mossa che fa uso della forza della natura. Il suo effetto varia in base all'ambiente." - }, - "charge": { - "name": "Sottocarica", - "effect": "Potenzia la mossa di tipo Elettro usata subito dopo. Aumenta anche la Difesa Speciale di chi la usa." - }, - "taunt": { - "name": "Provocazione", - "effect": "Provoca il nemico, inducendolo ad usare solo mosse d'attacco per tre turni." - }, - "helpingHand": { - "name": "Altruismo", - "effect": "Mossa che aumenta la potenza dell'attacco di un alleato." - }, - "trick": { - "name": "Raggiro", - "effect": "Chi la usa coglie il bersaglio in contropiede e l'obbliga a cambiare il suo strumento con il proprio." - }, - "rolePlay": { - "name": "Giocodiruolo", - "effect": "Chi la usa mima in tutto il bersaglio, copiandone l'abilità." - }, - "wish": { - "name": "Desiderio", - "effect": "Permette di recuperare metà dei PS massimi al turno successivo." - }, - "assist": { - "name": "Assistente", - "effect": "Chi la usa utilizza in fretta e a caso una delle mosse degli altri Pokémon della squadra." - }, - "ingrain": { - "name": "Radicamento", - "effect": "Chi la usa mette delle radici che gli fanno recuperare PS a ogni turno. Non può essere sostituito." - }, - "superpower": { - "name": "Troppoforte", - "effect": "Chi la usa attacca il nemico con grande forza, ma il suo Attacco e la sua Difesa diminuiscono." - }, - "magicCoat": { - "name": "Magivelo", - "effect": "Una barriera rimanda al mittente l'effetto di mosse come Parassiseme e di mosse che influenzano lo stato." - }, - "recycle": { - "name": "Riciclo", - "effect": "Chi la usa ricicla uno strumento tenuto, già usato nella lotta, e lo può riutilizzare." - }, - "revenge": { - "name": "Vendetta", - "effect": "Mossa d'attacco che infligge un danno doppio se si è stati colpiti dal nemico nello stesso turno." - }, - "brickBreak": { - "name": "Breccia", - "effect": "Colpisce il nemico con una mano e rompe barriere come Riflesso e Schermoluce." - }, - "yawn": { - "name": "Sbadiglio", - "effect": "Chi la usa fa un grande sbadiglio che addormenta il nemico al turno seguente." - }, - "knockOff": { - "name": "Privazione", - "effect": "Attacco che blocca anche lo strumento tenuto dal nemico, impedendone l'uso nella lotta." - }, - "endeavor": { - "name": "Rimonta", - "effect": "Attacco che riduce i PS del nemico a una quantità pari ai PS di chi la usa." - }, - "eruption": { - "name": "Eruzione", - "effect": "Attacco impetuoso ed esplosivo la cui potenza è proporzionale ai PS di chi lo usa." - }, - "skillSwap": { - "name": "Baratto", - "effect": "Chi la usa sfrutta le sue facoltà mentali per scambiare l'abilità con il bersaglio." - }, - "imprison": { - "name": "Esclusiva", - "effect": "Chi la usa impedisce al nemico di usare mosse che conoscono entrambi." - }, - "refresh": { - "name": "Rinfrescata", - "effect": "Chi la usa riposa per curarsi da avvelenamento, paralisi e scottatura." - }, - "grudge": { - "name": "Rancore", - "effect": "Se chi la usa va KO, i PP della mossa nemica che lo ha messo fuori gioco si azzerano." - }, - "snatch": { - "name": "Scippo", - "effect": "Chi la usa ruba e utilizza la mossa curativa o modifica-statistiche che il bersaglio stava per usare." - }, - "secretPower": { - "name": "Forzasegreta", - "effect": "Attacco che può avere un effetto aggiuntivo a seconda del luogo in cui si trova chi lo usa." - }, - "dive": { - "name": "Sub", - "effect": "Chi la usa si tuffa in acqua per emergere e attaccare al turno seguente. Fuori dalla lotta permette di immergersi sott'acqua." - }, - "armThrust": { - "name": "Sberletese", - "effect": "Raffica di ceffoni che colpisce da due a cinque volte di fila." - }, - "camouflage": { - "name": "Camuffamento", - "effect": "Modifica il tipo di chi la usa a seconda del luogo, ad esempio sull'acqua, nell'erba o in una grotta." - }, - "tailGlow": { - "name": "Codadiluce", - "effect": "Chi la usa fissa una luce forte per concentrarsi e aumentare moltissimo l'Attacco Speciale." - }, - "lusterPurge": { - "name": "Abbagliante", - "effect": "Chi la usa scatena un'esplosione abbagliante che può anche ridurre la Difesa Speciale del Pokémon colpito." - }, - "mistBall": { - "name": "Foschisfera", - "effect": "Una sfera coperta di nebbia danneggia il nemico. Può anche ridurre l'Attacco Speciale." - }, - "featherDance": { - "name": "Danzadipiume", - "effect": "Chi la usa copre il nemico con un manto di piume che riduce di molto il suo Attacco." - }, - "teeterDance": { - "name": "Strampadanza", - "effect": "Chi la usa esegue una danza goffa che confonde tutti i Pokémon attorno." - }, - "blazeKick": { - "name": "Calciardente", - "effect": "Chi la usa tira un calcio. Probabile brutto colpo. Può anche causare una scottatura." - }, - "mudSport": { - "name": "Fangata", - "effect": "Chi la usa si ricopre di fango indebolendo le mosse di tipo Elettro finché resta in campo." - }, - "iceBall": { - "name": "Palla Gelo", - "effect": "Chi la usa attacca il nemico rotolando per cinque turni, con aumento progressivo della potenza ogni volta che va a segno." - }, - "needleArm": { - "name": "Pugnospine", - "effect": "Chi la usa attacca colpendo il bersaglio con i suoi arti pieni di spine. Può far tentennare il Pokémon colpito." - }, - "slackOff": { - "name": "Pigro", - "effect": "Chi la usa si rilassa recuperando metà dei propri PS massimi." - }, - "hyperVoice": { - "name": "Granvoce", - "effect": "Chi la usa lancia un urlo straziante che danneggia i nemici." - }, - "poisonFang": { - "name": "Velenodenti", - "effect": "Chi la usa morde il nemico con denti avvelenati che possono anche iperavvelenarlo." - }, - "crushClaw": { - "name": "Tritartigli", - "effect": "Colpisce il nemico con artigli robusti e affilati che possono ridurne la Difesa." - }, - "blastBurn": { - "name": "Incendio", - "effect": "Potente esplosione che danneggia il nemico, ma fa saltare il turno successivo a chi la provoca." - }, - "hydroCannon": { - "name": "Idrocannone", - "effect": "Colpisce il nemico con un potente getto d'acqua. Chi la usa salta il turno successivo." - }, - "meteorMash": { - "name": "Meteorpugno", - "effect": "Colpisce il nemico con un pugno veloce come una meteora. Può far pure salire l'Attacco di chi la usa." - }, - "astonish": { - "name": "Sgomento", - "effect": "Chi la usa attacca il bersaglio emettendo un verso terrificante. Può anche farlo tentennare." - }, - "weatherBall": { - "name": "Palla Clima", - "effect": "Mossa d'attacco che varia tipo e forza in base alle condizioni atmosferiche." - }, - "aromatherapy": { - "name": "Aromaterapia", - "effect": "Chi la usa rilascia un dolce profumo che cura tutti problemi di stato propri e degli alleati." - }, - "fakeTears": { - "name": "Falselacrime", - "effect": "Chi la usa inscena un pianto teatrale per commuovere il nemico. Ne riduce di molto la Difesa Speciale." - }, - "airCutter": { - "name": "Aerasoio", - "effect": "Chi la usa provoca un vento tagliente che sferza i nemici. Probabile brutto colpo." - }, - "overheat": { - "name": "Vampata", - "effect": "Chi la usa sferra un potente attacco, ma il contraccolpo riduce di molto il suo Attacco Speciale." - }, - "odorSleuth": { - "name": "Segugio", - "effect": "Chi la usa rende i Pokémon di tipo Spettro vulnerabili a qualsiasi tipo di mossa e può, inoltre, colpire i nemici sfuggenti." - }, - "rockTomb": { - "name": "Rocciotomba", - "effect": "Colpisce il nemico con rocce. Inoltre, lo rallenta riducendone la Velocità." - }, - "silverWind": { - "name": "Ventargenteo", - "effect": "Attacca con un forte vento di polvere di squame. Tutte le statistiche di chi la usa possono salire." - }, - "metalSound": { - "name": "Ferrostrido", - "effect": "Orribile stridio, simile a quello prodotto dal metallo, che riduce di molto la Difesa Speciale del nemico." - }, - "grassWhistle": { - "name": "Meloderba", - "effect": "Una dolce melodia culla il bersaglio e lo costringe ad addormentarsi." - }, - "tickle": { - "name": "Solletico", - "effect": "Chi la usa solletica il nemico e lo fa ridere, riducendo il suo Attacco e la sua Difesa." - }, - "cosmicPower": { - "name": "Cosmoforza", - "effect": "Chi la usa assorbe una forza mistica dallo spazio che aumenta la Difesa e la Difesa Speciale." - }, - "waterSpout": { - "name": "Zampillo", - "effect": "Lancia un getto d'acqua contro il nemico che ha davanti e quelli adiacenti. La potenza è proporzionale al numero di PS di chi la usa." - }, - "signalBeam": { - "name": "Segnoraggio", - "effect": "Chi la usa attacca con uno strano raggio di luce che può anche confondere il Pokémon colpito." - }, - "shadowPunch": { - "name": "Pugnodombra", - "effect": "Il nemico riceve un pugno proveniente dalle tenebre. Questa mossa è infallibile." - }, - "extrasensory": { - "name": "Extrasenso", - "effect": "Chi la usa attacca con una misteriosa forza invisibile. Può far tentennare il nemico." - }, - "skyUppercut": { - "name": "Stramontante", - "effect": "Chi la usa attacca il nemico con un montante che può arrivare fino in cielo." - }, - "sandTomb": { - "name": "Sabbiotomba", - "effect": "Chi la usa intrappola il nemico in un turbine di sabbia per quattro o cinque turni." - }, - "sheerCold": { - "name": "Purogelo", - "effect": "Ondata di freddo penetrante che, se va a segno, fa andare KO il nemico." - }, - "muddyWater": { - "name": "Fanghiglia", - "effect": "Chi la usa attacca con un getto di fango che può anche ridurre la precisione dei nemici." - }, - "bulletSeed": { - "name": "Semitraglia", - "effect": "Chi la usa spara da due a cinque raffiche di semi contro il bersaglio in successione." - }, - "aerialAce": { - "name": "Aeroassalto", - "effect": "Chi la usa attacca il nemico a grande velocità. Questa mossa è infallibile." - }, - "icicleSpear": { - "name": "Gelolancia", - "effect": "Chi la usa spara ghiaccioli affilati contro il nemico da due a cinque volte di fila." - }, - "ironDefense": { - "name": "Ferroscudo", - "effect": "Il corpo di chi la usa si indurisce come il ferro, facendone salire di molto la Difesa." - }, - "block": { - "name": "Blocco", - "effect": "Chi la usa sbarra la strada al nemico impedendone la fuga o la sostituzione." - }, - "howl": { - "name": "Gridodilotta", - "effect": "Chi la usa emette un verso molto forte per darsi coraggio e aumentare l'Attacco." - }, - "dragonClaw": { - "name": "Dragartigli", - "effect": "Chi la usa attacca con artigli affilati che graffiano il nemico rapidamente e con grande forza." - }, - "frenzyPlant": { - "name": "Radicalbero", - "effect": "Un groviglio di radici colpisce il nemico. Chi la usa salta il turno successivo." - }, - "bulkUp": { - "name": "Granfisico", - "effect": "Chi la usa tende i muscoli per gonfiare il corpo, aumentando Difesa e Attacco." - }, - "bounce": { - "name": "Rimbalzo", - "effect": "Chi la usa balza in alto e ricade sul nemico dopo un turno. Può anche paralizzare." - }, - "mudShot": { - "name": "Colpodifango", - "effect": "Chi la usa attacca lanciando fango sul nemico. Riduce anche la Velocità." - }, - "poisonTail": { - "name": "Velenocoda", - "effect": "Chi la usa colpisce con la coda e può avvelenare il nemico. Probabile brutto colpo." - }, - "covet": { - "name": "Supplica", - "effect": "Chi la usa attacca il bersaglio sorridendo e gli ruba lo strumento che tiene." - }, - "voltTackle": { - "name": "Locomovolt", - "effect": "Chi la usa si carica di elettricità e poi attacca. Può paralizzare il nemico. Il contraccolpo causa seri danni." - }, - "magicalLeaf": { - "name": "Fogliamagica", - "effect": "Chi la usa sparpaglia strane foglie che inseguono il bersaglio. Questa mossa è infallibile." - }, - "waterSport": { - "name": "Docciascudo", - "effect": "Chi la usa s'impregna d'acqua indebolendo le mosse di tipo Fuoco finché resta in campo." - }, - "calmMind": { - "name": "Calmamente", - "effect": "Chi la usa, meditando, placa il proprio spirito per aumentare l'Attacco Speciale e la Difesa Speciale." - }, - "leafBlade": { - "name": "Fendifoglia", - "effect": "Colpisce il nemico usando una foglia affilata come una spada. Probabile brutto colpo." - }, - "dragonDance": { - "name": "Dragodanza", - "effect": "Danza mistica e vigorosa che aumenta l'Attacco e la Velocità di chi la usa." - }, - "rockBlast": { - "name": "Cadutamassi", - "effect": "Colpisce il nemico con dei massi pesanti lanciati in rapida successione. Il numero di massi varia da due a cinque." - }, - "shockWave": { - "name": "Ondashock", - "effect": "Chi la usa colpisce il nemico con una scossa di elettricità. È impossibile eludere questa mossa." - }, - "waterPulse": { - "name": "Idropulsar", - "effect": "Il nemico viene colpito da un getto d'acqua potentissimo che può anche confonderlo." - }, - "doomDesire": { - "name": "Desiderio Fatale", - "effect": "Intensa luce solare che colpisce il nemico dopo due turni dall'uso della mossa." - }, - "psychoBoost": { - "name": "Psicoslancio", - "effect": "Chi la usa sferra un potente attacco, ma il contraccolpo riduce di molto il suo Attacco Speciale." - }, - "roost": { - "name": "Trespolo", - "effect": "Chi la usa sta fermo e riposa, recuperando metà dei propri PS massimi." - }, - "gravity": { - "name": "Gravità", - "effect": "Intensifica la gravità per cinque turni. Le mosse che fanno volare e Levitazione sono inutilizzabili." - }, - "miracleEye": { - "name": "Miracolvista", - "effect": "Chi la usa rende i Pokémon di tipo Buio vulnerabili a qualsiasi tipo di mossa e può, inoltre, colpire i nemici sfuggenti." - }, - "wakeUpSlap": { - "name": "Svegliopacca", - "effect": "Un attacco che infligge doppi danni se il nemico è Addormentato. Inoltre, lo sveglierà dal sonno." - }, - "hammerArm": { - "name": "Martelpugno", - "effect": "Chi la usa colpisce il nemico con il suo pugno forte e pesante, ma perde Velocità." - }, - "gyroBall": { - "name": "Vortexpalla", - "effect": "Chi la usa colpisce il nemico con un vortice rapidissimo. Più lento è chi la usa, maggiore è il danno." - }, - "healingWish": { - "name": "Curardore", - "effect": "Chi la usa va KO, ma il Pokémon che lo sostituisce recupera tutti i PS e risolve i problemi di stato." - }, - "brine": { - "name": "Acquadisale", - "effect": "Se i PS del nemico sono scesi a metà o meno, questa mossa colpirà con il doppio della potenza." - }, - "naturalGift": { - "name": "Dononaturale", - "effect": "Chi la usa trae forza dalla Bacca che tiene. Da questa dipendono il tipo e la forza dell'attacco." - }, - "feint": { - "name": "Fintoattacco", - "effect": "Un attacco che colpisce un nemico che ha usato Protezione od Individua. Ne rimuoverà inoltre gli effetti." - }, - "pluck": { - "name": "Spennata", - "effect": "Chi la usa becca il bersaglio. Inoltre, se questi tiene una Bacca, gliela ruba e ne sfrutta gli effetti." - }, - "tailwind": { - "name": "Ventoincoda", - "effect": "Chi la usa crea turbolente raffiche di vento che aumentano la sua Velocità e quella di tutti i Pokémon della squadra." - }, - "acupressure": { - "name": "Acupressione", - "effect": "Chi la usa esercita pressione su alcuni punti nevralgici e aumenta di molto una statistica a caso." - }, - "metalBurst": { - "name": "Metalscoppio", - "effect": "Chi la usa si vendica sul nemico che l'ha appena ferito con una mossa anche più potente." - }, - "uTurn": { - "name": "Retromarcia", - "effect": "Dopo aver selezionato questo attacco, chi la usa colpisce il nemico per poi essere sostituito con un altro Pokémon della squadra." - }, - "closeCombat": { - "name": "Zuffa", - "effect": "Chi la usa attacca abbassando la guardia. La propria Difesa e la Difesa Speciale si riducono." - }, - "payback": { - "name": "Rivincita", - "effect": "Chi la usa accumula forza, poi attacca. La potenza raddoppia se agisce dopo il Pokémon nemico." - }, - "assurance": { - "name": "Garanzia", - "effect": "Se il nemico ha già subito dei danni nello stesso turno, la potenza di questa mossa raddoppia." - }, - "embargo": { - "name": "Divieto", - "effect": "Impedisce al nemico di usare lo strumento che tiene e al suo Allenatore di usarne altri sul Pokémon." - }, - "fling": { - "name": "Lancio", - "effect": "Chi la usa lancia sul nemico lo strumento che tiene. La forza e l'effetto dipendono dallo strumento." - }, - "psychoShift": { - "name": "Psicotrasfer", - "effect": "Con la forza psichica e la suggestione, chi la usa può trasferire i suoi problemi di stato al Pokémon colpito." - }, - "trumpCard": { - "name": "Asso", - "effect": "Minori PP rimangono a questa mossa, e maggiori danni apporterà al nemico." - }, - "healBlock": { - "name": "Anticura", - "effect": "Chi la usa impedisce al nemico di utilizzare mosse o abilità recupera-PS per cinque turni." - }, - "wringOut": { - "name": "Strizzata", - "effect": "Chi la usa stritola con forza il nemico. Più PS ha il nemico, maggiore è la potenza della mossa." - }, - "powerTrick": { - "name": "Ingannoforza", - "effect": "Mossa psichica che permette a chi la usa di scambiare i valori delle sue statistiche di Attacco e Difesa." - }, - "gastroAcid": { - "name": "Gastroacido", - "effect": "Chi la usa lancia acidi gastrici sul nemico. Il fluido annulla l'abilità del nemico." - }, - "luckyChant": { - "name": "Fortuncanto", - "effect": "Chi la usa rivolge un incantesimo al cielo, impedendo al nemico di sferrare brutti colpi alla squadra." - }, - "meFirst": { - "name": "Precedenza", - "effect": "Se chi la usa è più veloce del nemico, gli ruba la mossa e gliela ritorce contro con potenza persino maggiore." - }, - "copycat": { - "name": "Copione", - "effect": "Chi la usa imita l'ultima mossa usata dal nemico. La mossa fallisce se questo non ha selezionato alcuna mossa." - }, - "powerSwap": { - "name": "Barattoforza", - "effect": "Chi la usa sfrutta la sua forza psichica per scambiare le modifiche ad Attacco e Attacco Speciale con il bersaglio." - }, - "guardSwap": { - "name": "Barattoscudo", - "effect": "Chi la usa sfrutta la sua forza psichica per scambiare le modifiche a Difesa e a Difesa Speciale con il bersaglio." - }, - "punishment": { - "name": "Punizione", - "effect": "Questa mossa diventa più potente ogni volta che il nemico aumenta le proprie statistiche." - }, - "lastResort": { - "name": "Ultimascelta", - "effect": "Per usare questa mossa, bisogna prima avvalersi in lotta di tutte le altre mosse conosciute." - }, - "worrySeed": { - "name": "Affannoseme", - "effect": "Un seme che causa ansia viene piantato sul bersaglio. Ne muta l'abilità in Insonnia e ne previene o rimuove il sonno." - }, - "suckerPunch": { - "name": "Sbigoattacco", - "effect": "Chi la usa può attaccare per primo. Fallisce se il nemico non sta preparando un attacco." - }, - "toxicSpikes": { - "name": "Fielepunte", - "effect": "Chi la usa piazza ai piedi del nemico delle punte avvelenate. Avvelena ogni nemico che entra in lotta." - }, - "heartSwap": { - "name": "Cuorbaratto", - "effect": "Chi la usa sfrutta la sua forza psichica per scambiare le modifiche alle statistiche con il bersaglio." - }, - "aquaRing": { - "name": "Acquanello", - "effect": "Chi la usa si avvolge in un velo d'acqua. Recupera alcuni PS ad ogni turno." - }, - "magnetRise": { - "name": "Magnetascesa", - "effect": "Chi la usa si solleva in aria per cinque turni grazie a un campo elettromagnetico." - }, - "flareBlitz": { - "name": "Fuococarica", - "effect": "Chi la usa si ricopre di fuoco e carica il bersaglio, ma subisce il contraccolpo. Può anche scottare." - }, - "forcePalm": { - "name": "Palmoforza", - "effect": "Chi la usa attacca con un'onda d'urto che può anche paralizzare il bersaglio." - }, - "auraSphere": { - "name": "Sferapulsar", - "effect": "Chi la usa rilascia una forza eterea dal profondo del corpo. La mossa è infallibile." - }, - "rockPolish": { - "name": "Lucidatura", - "effect": "Chi la usa leviga il proprio corpo per ridurne l'attrito. Aumenta di molto la Velocità." - }, - "poisonJab": { - "name": "Velenpuntura", - "effect": "Il nemico viene colpito con un tentacolo od un braccio intriso di veleno. Può anche avvelenarlo." - }, - "darkPulse": { - "name": "Neropulsar", - "effect": "Chi la usa emana un'aura impregnata di oscuri pensieri. Può anche far tentennare il Pokémon colpito." - }, - "nightSlash": { - "name": "Nottesferza", - "effect": "Chi la usa colpisce il nemico appena si presenta l'occasione. Probabile brutto colpo." - }, - "aquaTail": { - "name": "Idrondata", - "effect": "Chi la usa attacca agitando la coda come se fosse una violenta ondata in una tempesta furiosa." - }, - "seedBomb": { - "name": "Semebomba", - "effect": "Chi la usa emette una raffica di semi dal guscio duro che colpiscono il bersaglio dall'alto." - }, - "airSlash": { - "name": "Eterelama", - "effect": "Chi la usa attacca con un vento tagliente che squarcia il cielo. Può anche far tentennare il Pokémon colpito." - }, - "xScissor": { - "name": "Forbice X", - "effect": "Chi la usa colpisce il nemico usando le sue falci o artigli come se fossero un paio di forbici." - }, - "bugBuzz": { - "name": "Ronzio", - "effect": "Chi la usa muove le ali per creare un suono che danneggia il nemico. Può anche ridurne la Difesa Speciale." - }, - "dragonPulse": { - "name": "Dragopulsar", - "effect": "Chi la usa attacca un'onda d'urto generata spalancando la bocca." - }, - "dragonRush": { - "name": "Dragofuria", - "effect": "Chi la usa attacca con fare minaccioso e in questo modo può anche far tentennare il nemico." - }, - "powerGem": { - "name": "Gemmoforza", - "effect": "Chi la usa attacca con un raggio di luce che brilla come se fosse fatto di pietre preziose." - }, - "drainPunch": { - "name": "Assorbipugno", - "effect": "Pugno che assorbe energia. Fa recuperare una quantità di PS pari alla metà del danno inferto." - }, - "vacuumWave": { - "name": "Vuotonda", - "effect": "Chi la usa rotea i pugni per lanciare un'onda di vuoto assoluto verso il nemico. Attacca per primo." - }, - "focusBlast": { - "name": "Focalcolpo", - "effect": "Chi la usa incrementa la sua concentrazione mentale per scatenare il suo potere. Può ridurre la Difesa Speciale del nemico." - }, - "energyBall": { - "name": "Energipalla", - "effect": "Chi la usa attinge energia dalla natura e la scaglia contro il bersaglio. Può anche ridurne la Difesa Speciale." - }, - "braveBird": { - "name": "Baldeali", - "effect": "Chi la usa si nasconde sotto le ali e carica da bassa quota. Tuttavia, subisce considerevoli danni." - }, - "earthPower": { - "name": "Geoforza", - "effect": "Dal terreno sotto il nemico si sprigiona una forza devastante. Può anche ridurne la Difesa Speciale." - }, - "switcheroo": { - "name": "Rapidscambio", - "effect": "Chi la usa scambia in maniera fulminea il proprio oggetto con quello del nemico." - }, - "gigaImpact": { - "name": "Gigaimpatto", - "effect": "Chi la usa carica il nemico usando tutta la sua forza, ma al turno successivo deve riposare." - }, - "nastyPlot": { - "name": "Congiura", - "effect": "Chi la usa stimola il cervello pensando a cose cattive. Aumenta di molto l'Attacco Speciale." - }, - "bulletPunch": { - "name": "Pugnoscarica", - "effect": "Chi la usa attacca con una scarica di pugni veloci come proiettili. Con questa mossa si colpisce per primi." - }, - "avalanche": { - "name": "Slavina", - "effect": "Un attacco che infligge doppi danni se l'utilizzatore ha subito un attacco nello stesso turno." - }, - "iceShard": { - "name": "Geloscheggia", - "effect": "Chi la usa crea dei pezzi di ghiaccio e li lancia. Con questa mossa si colpisce per primi." - }, - "shadowClaw": { - "name": "Ombrartigli", - "effect": "Chi la usa attacca con artigli d'ombra che colpiscono con gran forza. Probabile brutto colpo." - }, - "thunderFang": { - "name": "Fulmindenti", - "effect": "Chi la usa morde con denti elettrificati che possono anche paralizzare o far tentennare il nemico." - }, - "iceFang": { - "name": "Gelodenti", - "effect": "Chi la usa morde il nemico con denti di ghiaccio. Può causare congelamento e tentennamento." - }, - "fireFang": { - "name": "Rogodenti", - "effect": "Chi la usa morde il nemico con denti infuocati. Può causare scottatura e tentennamento." - }, - "shadowSneak": { - "name": "Furtivombra", - "effect": "Chi la usa estende la sua ombra e attacca il nemico alle spalle. Con questa mossa si colpisce per primi." - }, - "mudBomb": { - "name": "Pantanobomba", - "effect": "Chi la usa lancia dure palle di fango sul nemico. Può anche ridurne la Precisione." - }, - "psychoCut": { - "name": "Psicotaglio", - "effect": "Chi la usa colpisce il nemico con lame fatte di forza psichica. Probabile brutto colpo." - }, - "zenHeadbutt": { - "name": "Cozzata Zen", - "effect": "Chi la usa concentra la forza nella testa e si lancia contro il nemico. Può anche farlo tentennare." - }, - "mirrorShot": { - "name": "Cristalcolpo", - "effect": "Chi la usa colpisce il nemico lanciando fasci d'energia dal suo corpo. Può ridurne la precisione." - }, - "flashCannon": { - "name": "Cannonflash", - "effect": "Chi la usa attacca raccogliendo e rilasciando energia luminosa. Può ridurre la Difesa Speciale del nemico." - }, - "rockClimb": { - "name": "Scalaroccia", - "effect": "Chi la usa carica con impeto incredibile. Il colpo può confondere il nemico." - }, - "defog": { - "name": "Scacciabruma", - "effect": "Chi la usa spazza via barriere come Riflesso e Schermoluce con un forte vento e riduce la capacità d'elusione del nemico." - }, - "trickRoom": { - "name": "Distortozona", - "effect": "Chi la usa crea una dimensione in cui i Pokémon più lenti si muovono per primi per cinque turni." - }, - "dracoMeteor": { - "name": "Dragobolide", - "effect": "Attacca con meteore che cadono dal cielo. Il contraccolpo fa calare di molto l'Attacco Speciale di chi la usa." - }, - "discharge": { - "name": "Scarica", - "effect": "Chi la usa colpisce i Pokémon che ha intorno con un bagliore elettrico. Può anche causare paralisi." - }, - "lavaPlume": { - "name": "Lavasbuffo", - "effect": "Chi la usa lancia fiamme scarlatte sugli altri Pokémon in campo. Può anche scottare." - }, - "leafStorm": { - "name": "Verdebufera", - "effect": "Si forma una tempesta di foglie affilate. Il contraccolpo riduce di molto l'Attacco Speciale di chi la usa." - }, - "powerWhip": { - "name": "Vigorcolpo", - "effect": "Chi la usa agita violentemente liane o tentacoli per sferzare il bersaglio." - }, - "rockWrecker": { - "name": "Devastomasso", - "effect": "Chi la usa attacca il nemico con un enorme masso, ma si deve riposare al turno successivo." - }, - "crossPoison": { - "name": "Velenocroce", - "effect": "Attacco con zanne avvelenate che può anche avvelenare il Pokémon colpito. Probabile brutto colpo." - }, - "gunkShot": { - "name": "Sporcolancio", - "effect": "Chi la usa attacca il nemico con rifiuti sudici che possono anche avvelenarlo." - }, - "ironHead": { - "name": "Metaltestata", - "effect": "Chi la usa colpisce il nemico con la sua testa dura come l'acciaio. Può anche farlo tentennare." - }, - "magnetBomb": { - "name": "Bombagnete", - "effect": "Chi la usa lancia bombe d'acciaio che si attaccano al nemico. Una mossa infallibile." - }, - "stoneEdge": { - "name": "Pietrataglio", - "effect": "Chi la usa colpisce il nemico dal basso con pietre affilate. Probabile brutto colpo." - }, - "captivate": { - "name": "Incanto", - "effect": "Se il nemico è del sesso opposto di chi la usa, sarà ammaliato e il suo Attacco Speciale diminuirà di molto." - }, - "stealthRock": { - "name": "Levitoroccia", - "effect": "Chi la usa piazza una trappola di rocce sospese che danneggia i nemici che entrano in lotta." - }, - "grassKnot": { - "name": "Laccioerboso", - "effect": "Chi la usa intrappola il bersaglio con l'erba e lo fa cadere. Danneggia maggiormente i Pokémon più pesanti." - }, - "chatter": { - "name": "Schiamazzo", - "effect": "Chi la usa attacca creando un'onda sonora con le parole imparate. Può anche confondere il nemico." - }, - "judgment": { - "name": "Giudizio", - "effect": "Chi la usa rilascia numerosi colpi di luce. Il tipo varia a seconda della Lastra tenuta." - }, - "bugBite": { - "name": "Coleomorso", - "effect": "Chi la usa morde il nemico. Inoltre, se questi tiene una Bacca, gliela ruba e ne sfrutta gli effetti." - }, - "chargeBeam": { - "name": "Raggioscossa", - "effect": "Chi la usa lancia un fascio di elettricità molto intensa. Può anche aumentare il suo Attacco Speciale." - }, - "woodHammer": { - "name": "Mazzuolegno", - "effect": "Chi la usa si lancia con tutto il corpo contro il bersaglio, ma subisce anche considerevoli danni." - }, - "aquaJet": { - "name": "Acquagetto", - "effect": "Chi la usa colpisce sempre per primo e a una tale velocità da rendersi quasi invisibile." - }, - "attackOrder": { - "name": "Comandourto", - "effect": "Chi la usa raduna i suoi sgherri per colpire il nemico. Probabile brutto colpo." - }, - "defendOrder": { - "name": "Comandoscudo", - "effect": "Chi la usa raduna i suoi sgherri per creare uno scudo, aumentando Difesa e Difesa Speciale." - }, - "healOrder": { - "name": "Comandocura", - "effect": "Chi la usa raduna i propri sgherri per farsi curare. Recupera metà dei PS massimi." - }, - "headSmash": { - "name": "Zuccata", - "effect": "Chi la usa attacca con tutta la potenza di cui dispone, ma subisce danni considerevoli." - }, - "doubleHit": { - "name": "Doppiosmash", - "effect": "Chi la usa colpisce il nemico con la coda due volte di fila." - }, - "roarOfTime": { - "name": "Fragortempo", - "effect": "Chi la usa colpisce il nemico con una forza capace di alterare il tempo, ma deve stare fermo il turno dopo." - }, - "spacialRend": { - "name": "Fendispazio", - "effect": "Chi la usa lacera il nemico e lo spazio che lo circonda. Probabile brutto colpo." - }, - "lunarDance": { - "name": "Lunardanza", - "effect": "Chi la usa va KO. Il Pokémon che lo sostituisce risolve i propri problemi di stato e recupera PS e PP." - }, - "crushGrip": { - "name": "Sbriciolmano", - "effect": "Colpisce il nemico con grande forza. Più PS ha il nemico, maggiore è la potenza della mossa." - }, - "magmaStorm": { - "name": "Magmaclisma", - "effect": "Intrappola il nemico in un turbine di fuoco che dura per quattro o cinque turni." - }, - "darkVoid": { - "name": "Vuototetro", - "effect": "Trascina i nemici in un mondo di totale oscurità e li fa addormentare." - }, - "seedFlare": { - "name": "Infuriaseme", - "effect": "Chi la usa genera un'onda d'urto dal suo corpo. Può anche ridurre di molto la Difesa Speciale del bersaglio." - }, - "ominousWind": { - "name": "Funestovento", - "effect": "Chi la usa crea una raffica di vento ripugnante. Può aumentare tutte le statistiche di chi la usa." - }, - "shadowForce": { - "name": "Oscurotuffo", - "effect": "Chi la usa sparisce e poi colpisce il nemico al turno successivo. Evita pure Protezione o Individua." - }, - "honeClaws": { - "name": "Unghiaguzze", - "effect": "Chi la usa affila i propri artigli, aumentando Attacco e precisione." - }, - "wideGuard": { - "name": "Bodyguard", - "effect": "Chi la usa para tutti i colpi diretti alla intera squadra per un turno. Se usata in successione può fallire." - }, - "guardSplit": { - "name": "Paridifesa", - "effect": "Chi la usa sfrutta la sua forza psichica per sommare Difesa e Difesa Speciale a quelle del bersaglio e dividerle equamente." - }, - "powerSplit": { - "name": "Pariattacco", - "effect": "Chi la usa sfrutta la sua forza psichica per sommare Attacco e Attacco Speciale a quelli del bersaglio e dividerli equamente." - }, - "wonderRoom": { - "name": "Mirabilzona", - "effect": "Chi la usa crea una dimensione in cui Difesa e Difesa Speciale di tutti i Pokémon vengono scambiate per cinque turni." - }, - "psyshock": { - "name": "Psicoshock", - "effect": "Chi la usa attacca il bersaglio facendo materializzare un misterioso raggio psichico che provoca danni fisici." - }, - "venoshock": { - "name": "Velenoshock", - "effect": "Lancia uno speciale liquido tossico sul bersaglio. Se questi è avvelenato, il danno provocato raddoppia." - }, - "autotomize": { - "name": "Sganciapesi", - "effect": "Chi la usa si libera di tutti i pesi in eccesso, alleggerendosi e aumentando di molto la propria Velocità." - }, - "ragePowder": { - "name": "Polverabbia", - "effect": "Chi la usa attira l'attenzione dei nemici cospargendosi di una polvere irritante e diventando bersaglio di tutti gli attacchi." - }, - "telekinesis": { - "name": "Telecinesi", - "effect": "Chi la usa fa fluttuare in aria il bersaglio, rendendolo facile da colpire per tre turni." - }, - "magicRoom": { - "name": "Magicozona", - "effect": "Chi la usa crea una dimensione in cui l'effetto degli strumenti tenuti da tutti i Pokémon è annullato per cinque turni." - }, - "smackDown": { - "name": "Abbattimento", - "effect": "Chi la usa lancia una pietra o un proiettile. Può colpire anche un bersaglio in volo e farlo cadere." - }, - "stormThrow": { - "name": "Tempestretta", - "effect": "Chi la usa sferra un colpo micidiale al bersaglio, stritolandolo. Brutto colpo assicurato." - }, - "flameBurst": { - "name": "Pirolancio", - "effect": "Chi la usa emana una fiammata che colpisce il bersaglio e si propaga fino a raggiungere i Pokémon accanto." - }, - "sludgeWave": { - "name": "Fangonda", - "effect": "Lancia un'onda di fango che attacca tutti i Pokémon nelle vicinanze. Può anche avvelenare." - }, - "quiverDance": { - "name": "Eledanza", - "effect": "Danza leggiadra ed elegante che aumenta l'Attacco Speciale, la Difesa Speciale e la Velocità di chi la usa." - }, - "heavySlam": { - "name": "Pesobomba", - "effect": "Chi la usa si lancia contro il bersaglio con tutto il proprio peso. Più è pesante rispetto ad esso e più danni causa." - }, - "synchronoise": { - "name": "Sincrumore", - "effect": "Chi la usa infligge danni a tutti i Pokémon del suo stesso tipo che ha vicino usando misteriose onde elettromagnetiche." - }, - "electroBall": { - "name": "Energisfera", - "effect": "Chi la usa attacca con una sfera d'energia elettrica. Più è rapido rispetto al bersaglio e più danni arreca." - }, - "soak": { - "name": "Inondazione", - "effect": "Chi la usa proietta un lungo getto d'acqua contro il bersaglio e lo rende un Pokémon di tipo Acqua." - }, - "flameCharge": { - "name": "Nitrocarica", - "effect": "Chi la usa si copre di fuoco e attacca il bersaglio. Concentrandosi aumenta, inoltre, la propria Velocità." - }, - "coil": { - "name": "Arrotola", - "effect": "Chi la usa si concentra, aumentando Attacco, Difesa e precisione." - }, - "lowSweep": { - "name": "Calciobasso", - "effect": "Chi la usa colpisce con un attacco fulmineo la parte inferiore del corpo del bersaglio, riducendone la Velocità." - }, - "acidSpray": { - "name": "Acidobomba", - "effect": "Chi la usa attacca il bersaglio con un acido altamente corrosivo. Il fluido riduce di molto la Difesa Speciale del bersaglio." - }, - "foulPlay": { - "name": "Ripicca", - "effect": "Chi la usa sfrutta la forza del bersaglio. Il danno inflitto è proporzionale all'Attacco dell'avversario." - }, - "simpleBeam": { - "name": "Ondisinvolta", - "effect": "Chi la usa emette un misterioso raggio psichico che trasforma l'abilità del Pokémon colpito in Disinvoltura." - }, - "entrainment": { - "name": "Saltamicizia", - "effect": "Chi la usa saltella con un buffo ritmo, invitando il bersaglio a imitarlo e rendendo la sua abilità identica alla propria." - }, - "afterYou": { - "name": "Cortesia", - "effect": "Chi la usa aiuta un bersaglio più lento permettendogli di agire subito dopo." - }, - "round": { - "name": "Coro", - "effect": "Attacca il bersaglio con una melodia. Se usata ripetutamente da uno o più Pokémon i danni inflitti aumentano." - }, - "echoedVoice": { - "name": "Echeggiavoce", - "effect": "Attacca il bersaglio con la propria voce echeggiante. Se usata a ripetizione da uno o più Pokémon il danno aumenta." - }, - "chipAway": { - "name": "Insidia", - "effect": "Chi la usa attacca non appena il bersaglio abbassa la guardia. Il danno inflitto prescinde dalle modifiche alle statistiche." - }, - "clearSmog": { - "name": "Pulifumo", - "effect": "Attacca il bersaglio lanciandogli contro una nuvola di fumo speciale, che annulla ogni modifica alle statistiche." - }, - "storedPower": { - "name": "Veicolaforza", - "effect": "Attacca il bersaglio con l'energia accumulata. Più sono state aumentate le statistiche, maggiore è il danno inflitto." - }, - "quickGuard": { - "name": "Anticipo", - "effect": "Chi la usa protegge tutta la squadra dalle mosse dei nemici che fanno colpire per primi. Se usata in successione può fallire." - }, - "allySwitch": { - "name": "Cambiaposto", - "effect": "Chi la usa si teletrasporta al posto di un compagno in campo, grazie ad un misterioso potere." - }, - "scald": { - "name": "Idrovampata", - "effect": "Chi la usa attacca il bersaglio con un getto d'acqua bollente che può anche scottarlo." - }, - "shellSmash": { - "name": "Gettaguscio", - "effect": "Chi la usa si disfa del guscio. Difesa e Dif. Sp. calano, ma aumentano di molto Attacco, Att. Sp. e Velocità." - }, - "healPulse": { - "name": "Curapulsar", - "effect": "Chi la usa lancia un'onda rilassante che fa recuperare al bersaglio metà dei suoi PS massimi." - }, - "hex": { - "name": "Sciagura", - "effect": "Attacco che causa un danno enorme se il bersaglio ha problemi di stato." - }, - "skyDrop": { - "name": "Cadutalibera", - "effect": "Porta il bersaglio in cielo e lo scaglia a terra al turno successivo. Il bersaglio catturato non può muoversi." - }, - "shiftGear": { - "name": "Cambiomarcia", - "effect": "Facendo ruotare gli ingranaggi, chi la usa aumenta non solo il proprio Attacco, ma anche di molto la propria Velocità." - }, - "circleThrow": { - "name": "Ribaltiro", - "effect": "Il bersaglio è scaraventato via ed è costretto a lasciare il posto a un altro. Se è selvatico, la lotta finisce." - }, - "incinerate": { - "name": "Bruciatutto", - "effect": "Attacca il nemico con una fiammata. Se il nemico ha una Bacca, viene divorata dalle fiamme." - }, - "quash": { - "name": "Spintone", - "effect": "Chi la usa trattiene il bersaglio, costringendolo ad agire per ultimo." - }, - "acrobatics": { - "name": "Acrobazia", - "effect": "Attacca rapidamente il bersaglio. Se chi la usa non ha uno strumento, infligge al nemico grossi danni." - }, - "reflectType": { - "name": "Riflettipo", - "effect": "Chi la usa cambia il proprio tipo in quello del bersaglio." - }, - "retaliate": { - "name": "Nemesi", - "effect": "Vendica un compagno messo KO. Se ciò è accaduto al turno precedente, il danno è maggiore." - }, - "finalGambit": { - "name": "Azzardo", - "effect": "Chi la usa attacca con tutta la potenza di cui dispone e va KO, ma infligge al bersaglio un danno pari ai PS che ha perso." - }, - "bestow": { - "name": "Cediregalo", - "effect": "Chi la usa consegna il proprio strumento al bersaglio se ne è sprovvisto." - }, - "inferno": { - "name": "Marchiatura", - "effect": "Il bersaglio viene avvolto da intense fiammate che causano scottature." - }, - "waterPledge": { - "name": "Acquapatto", - "effect": "Attacca il nemico con una colonna d'acqua. Se usata con Fiammapatto, aumentano gli effetti e un arcobaleno appare in cielo." - }, - "firePledge": { - "name": "Fiammapatto", - "effect": "Attacca il nemico con una colonna di fuoco. Se usata con Erbapatto, aumentano gli effetti e il campo diventa un mare di fuoco." - }, - "grassPledge": { - "name": "Erbapatto", - "effect": "Attacca il bersaglio con una colonna d'erba. Se usata con Acquapatto, gli effetti aumentano e il campo diventa una palude." - }, - "voltSwitch": { - "name": "Invertivolt", - "effect": "Chi usa questa mossa fa marcia indietro per farsi sostituire dopo aver sferrato l'attacco." - }, - "struggleBug": { - "name": "Entomoblocco", - "effect": "Colpisce i nemici opponendo resistenza e riducendo il loro Attacco Speciale." - }, - "bulldoze": { - "name": "Battiterra", - "effect": "Chi la usa calpesta il terreno e scatena un terremoto che danneggia tutti i Pokémon nei paraggi e ne riduce anche la Velocità." - }, - "frostBreath": { - "name": "Alitogelido", - "effect": "Chi la usa attacca il bersaglio con un soffio d'aria gelida. Brutto colpo assicurato." - }, - "dragonTail": { - "name": "Codadrago", - "effect": "Chi la usa fa volar via il bersaglio in modo che venga sostituito. Se il bersaglio è un Pokémon selvatico, la lotta finisce." - }, - "workUp": { - "name": "Cuordileone", - "effect": "Chi la usa si tira su di morale, aumentando il proprio Attacco e l'Attacco Speciale." - }, - "electroweb": { - "name": "Elettrotela", - "effect": "Chi la usa attacca i nemici catturandoli con una ragnatela elettrica e riducendone la Velocità." - }, - "wildCharge": { - "name": "Sprizzalampo", - "effect": "Chi la usa si carica di elettricità per poi scagliarsi sul bersaglio, ma subisce dei danni per il contraccolpo." - }, - "drillRun": { - "name": "Giravvita", - "effect": "Chi la usa si scaglia sul bersaglio ruotando su se stesso come un trapano perforante. Probabile brutto colpo." - }, - "dualChop": { - "name": "Doppiocolpo", - "effect": "Chi la usa attacca due volte il bersaglio con dei colpi estremamente forti." - }, - "heartStamp": { - "name": "Cuorestampo", - "effect": "Chi la usa distrae il nemico con un faccino innocente per poi sferrargli un colpo devastante che può farlo tentennare." - }, - "hornLeech": { - "name": "Legnicorno", - "effect": "Chi la usa infilza il bersaglio con le corna e assorbe una quantità di PS pari a metà del danno inferto." - }, - "sacredSword": { - "name": "Spadasolenne", - "effect": "Chi la usa taglia il nemico con una spada magica. Il danno inflitto ignora le modifiche alle statistiche del bersaglio." - }, - "razorShell": { - "name": "Conchilama", - "effect": "Chi la usa colpisce il bersaglio con il suo guscio affilato. Il colpo può anche ridurre la Difesa del bersaglio." - }, - "heatCrash": { - "name": "Marchiafuoco", - "effect": "Chi la usa carica con il suo corpo rovente. Più è pesante rispetto al bersaglio e più danni causa." - }, - "leafTornado": { - "name": "Vorticerba", - "effect": "Chi la usa avvolge e attacca il bersaglio con foglie affilate che possono anche ridurne la precisione." - }, - "steamroller": { - "name": "Rulloduro", - "effect": "Chi la usa ruota su se stesso ad alta velocità e schiaccia il bersaglio. Può anche farlo tentennare." - }, - "cottonGuard": { - "name": "Cotonscudo", - "effect": "Chi la usa avvolge il proprio corpo con del cotone molto morbido, proteggendosi e aumentando moltissimo la propria Difesa." - }, - "nightDaze": { - "name": "Urtoscuro", - "effect": "Chi la usa attacca il bersaglio con un'onda d'urto oscura che può ridurne la precisione." - }, - "psystrike": { - "name": "Psicobotta", - "effect": "Chi la usa attacca il bersaglio facendo materializzare un misterioso raggio psichico che provoca danni fisici." - }, - "tailSlap": { - "name": "Spazzasberla", - "effect": "Chi la usa colpisce il bersaglio con la sua coda dura da due a cinque volte di fila." - }, - "hurricane": { - "name": "Tifone", - "effect": "Chi la usa attacca il bersaglio avvolgendolo con un vento fortissimo. Può anche confonderlo." - }, - "headCharge": { - "name": "Ricciolata", - "effect": "Chi la usa carica il bersaglio con la sua testa in stile afro, ma subisce un po' di danni per il contraccolpo." - }, - "gearGrind": { - "name": "Ingracolpo", - "effect": "Chi la usa colpisce il bersaglio due volte di fila lanciandogli contro dei dischi d'acciaio." - }, - "searingShot": { - "name": "Sparafuoco", - "effect": "Chi la usa lancia fiamme scarlatte sui Pokémon intorno a sé. Può anche scottare." - }, - "technoBlast": { - "name": "Tecnobotto", - "effect": "Chi la usa rilascia un colpo di luce contro il bersaglio. Il tipo varia a seconda del modulo che ha." - }, - "relicSong": { - "name": "Cantoantico", - "effect": "Chi la usa attacca i nemici intonando un'antica melodia che colpisce il loro spirito. Può anche farli addormentare." - }, - "secretSword": { - "name": "Spadamistica", - "effect": "Chi la usa attacca il bersaglio tagliandolo con una spada mistica. La misteriosa energia sprigionata provoca danni fisici." - }, - "glaciate": { - "name": "Gelamondo", - "effect": "Chi la usa attacca i nemici con una folata d'aria gelida e ne riduce anche la Velocità." - }, - "boltStrike": { - "name": "Lucesiluro", - "effect": "Colpisce il bersaglio con una possente carica elettrica e può anche paralizzarlo." - }, - "blueFlare": { - "name": "Fuocoblu", - "effect": "Chi la usa attacca il bersaglio avvolgendolo con magnifiche e intense fiamme blu che possono anche scottarlo." - }, - "fieryDance": { - "name": "Voldifuoco", - "effect": "Chi la usa avvolge il bersaglio tra le fiamme. Può anche aumentare l'Attacco Speciale." - }, - "freezeShock": { - "name": "Elettrogelo", - "effect": "Chi la usa lancia contro il nemico al turno successivo una sfera di ghiaccio ricoperta di elettricità. Può anche paralizzarlo." - }, - "iceBurn": { - "name": "Vampagelida", - "effect": "Chi la usa attacca il bersaglio al turno successivo e lo avvolge in un soffio d'aria congelata. Può anche scottarlo." - }, - "snarl": { - "name": "Urlorabbia", - "effect": "Chi la usa si mette a urlare per un po', riducendo l'Attacco Speciale dei nemici." - }, - "icicleCrash": { - "name": "Scagliagelo", - "effect": "Chi la usa attacca violentemente il nemico con grosse stalattiti di ghiaccio che possono anche farlo tentennare." - }, - "vCreate": { - "name": "Generatore V", - "effect": "Chi la usa carica emettendo fiamme ardenti dalla fronte, a costo di una riduzione di Difesa, Difesa Speciale e Velocità." - }, - "fusionFlare": { - "name": "Incrofiamma", - "effect": "Chi la usa lancia una fiammata enorme. Se usata in combinazione con Incrotuono, il danno provocato dalla mossa aumenta." - }, - "fusionBolt": { - "name": "Incrotuono", - "effect": "Chi la usa lancia un fulmine enorme. Se usata in combinazione con Incrofiamma, il danno provocato dalla mossa aumenta." - }, - "flyingPress": { - "name": "Schiacciatuffo", - "effect": "Chi la usa si tuffa sul bersaglio dall'alto. È una mossa di tipo Lotta e Volante allo stesso tempo." - }, - "matBlock": { - "name": "Ribaltappeto", - "effect": "Chi la usa protegge se stesso e i propri alleati dai danni di mosse nemiche, adoperando un tappetino come scudo. Non è efficace contro mosse di stato." - }, - "belch": { - "name": "Rutto", - "effect": "Chi la usa attacca il bersaglio con un rutto potente. Per utilizzare questa mossa, il Pokémon deve mangiare la bacca che possiede." - }, - "rototiller": { - "name": "Aracampo", - "effect": "Chi la usa dissoda la terra per far crescere meglio l'erba. Questa mossa aumenta l'attacco e l'attacco speciale dei Pokémon di tipo Erba." - }, - "stickyWeb": { - "name": "Rete Vischiosa", - "effect": "Chi la usa intreccia una rete appiccicosa attorno alla squadra avversaria, diminuendo la Velocità dei Pokémon nemici che entreranno in campo." - }, - "fellStinger": { - "name": "Pungiglione", - "effect": "L'Attacco di chi la usa aumenta notevolmente se grazie alla mossa il bersaglio va KO." - }, - "phantomForce": { - "name": "Spettrotuffo", - "effect": "Chi la usa scompare improvvisamente per attaccare poi nel turno seguente. Questa mossa neutralizza le difese del bersaglio." - }, - "trickOrTreat": { - "name": "Halloween", - "effect": "Il bersaglio viene invitato a festeggiare Halloween e aggiunge così al proprio tipo anche il tipo Spettro." - }, - "nobleRoar": { - "name": "Urlo", - "effect": "Chi la usa emette un urlo potente che intimidisce il bersaglio, riducendone l'Attacco e l'Attacco Speciale." - }, - "ionDeluge": { - "name": "Pioggiaplasma", - "effect": "Chi la usa disperde delle particelle elettrizzate che trasformano le mosse di tipo Normale in mosse di tipo Elettro." - }, - "parabolicCharge": { - "name": "Caricaparabola", - "effect": "Chi la usa attacca tutto ciò che lo circonda e recupera PS pari alla metà del danno inflitto." - }, - "forestsCurse": { - "name": "Boscomalocchio", - "effect": "Il Pokémon invoca la maledizione del bosco sul bersaglio, che acquisisce così anche il tipo Erba." - }, - "petalBlizzard": { - "name": "Fiortempesta", - "effect": "Infligge danni ai Pokémon che ha intorno attaccandoli con una tempesta di fiori." - }, - "freezeDry": { - "name": "Liofilizzazione", - "effect": "Chi la usa raffredda rapidamente il bersaglio. Può anche congelarlo. Questa mossa è superefficace contro i Pokémon Acqua." - }, - "disarmingVoice": { - "name": "Incantavoce", - "effect": "Chi la usa infligge un danno spirituale ai nemici nei paraggi con una voce suadente. L'attacco andrà immancabilmente a segno." - }, - "partingShot": { - "name": "Monito", - "effect": "Nessuna descrizione disponibile." - }, - "topsyTurvy": { - "name": "Sottosopra", - "effect": "Inverte tutte le modifiche alle statistiche del Pokémon bersaglio." - }, - "drainingKiss": { - "name": "Assorbibacio", - "effect": "Un bacio fatato che assorbe le energie al nemico." - }, - "craftyShield": { - "name": "Truccodifesa", - "effect": "Chi la usa protegge se stesso e i suoi alleati usando un potere misterioso. Non blocca le mosse che infliggono danno." - }, - "flowerShield": { - "name": "Fiordifesa", - "effect": "Grazie a un misterioso potere, aumenta la Difesa di tutti i Pokémon di tipo Erba presenti in campo." - }, - "grassyTerrain": { - "name": "Campo Erboso", - "effect": "Per cinque turni trasforma il terreno di lotta in un campo erboso, facendo recuperare PS ai Pokémon a terra in ogni turno." - }, - "mistyTerrain": { - "name": "Campo Nebbioso", - "effect": "Per cinque turni trasforma il terreno di lotta in un campo nebbioso, impedendo ai Pokémon a terra di essere colpiti da problemi di stato." - }, - "electrify": { - "name": "Elettrocontagio", - "effect": "Se si contagia il bersaglio prima che usi la sua mossa, per quel turno le sue mosse saranno di tipo Elettro." - }, - "playRough": { - "name": "Carineria", - "effect": "Chi la usa attacca il bersaglio con delle carinerie. Può anche ridurne l'attacco." - }, - "fairyWind": { - "name": "Vento di Fata", - "effect": "Attacca con un forte vento fatato." - }, - "moonblast": { - "name": "Forza Lunare", - "effect": "Accumula la forza proveniente dalla luna e la libera sul nemico. Può ridurre l'Attacco Speciale." - }, - "boomburst": { - "name": "Ondaboato", - "effect": "Colpisce i Pokémon che ha intorno con la forza di un boato distruttivo." - }, - "fairyLock": { - "name": "Blocco Fatato", - "effect": "Bloccando il campo di battaglia, chi la usa impedisce a tutti i Pokémon di fuggire durante il prossimo turno." - }, - "kingsShield": { - "name": "Scudo Reale", - "effect": "L'utilizzatore assume una posizione difensiva mentre si difende. Riduce inoltre l'Attacco di ogni utilizzatore di mosse da contatto." - }, - "playNice": { - "name": "Simpatia", - "effect": "Chi la usa diventa amico del bersaglio, rabbonendolo e riducendone così l'Attacco." - }, - "confide": { - "name": "Confidenza", - "effect": "Chi la usa svela dei segreti al bersaglio, distraendolo e riducendone l'Attacco Speciale." - }, - "diamondStorm": { - "name": "Diamantempesta", - "effect": "Colpisce i nemici che ha intorno con una tempesta di diamanti. Può anche aumentare la Difesa di chi la usa." - }, - "steamEruption": { - "name": "Vaporscoppio", - "effect": "Travolge il bersaglio con un'ondata di vapore rovente che può anche scottarlo." - }, - "hyperspaceHole": { - "name": "Forodimensionale", - "effect": "Chi la usa, sfrutta un passaggio interdimensionale per comparire a fianco del bersaglio e colpirlo, eludendo mosse come Protezione e Individua." - }, - "waterShuriken": { - "name": "Acqualame", - "effect": "Chi la usa attacca sempre per primo, colpendo il bersaglio con uno shuriken di muco da due a cinque volte di fila." - }, - "mysticalFire": { - "name": "Magifiamma", - "effect": "Colpisce il bersaglio soffiandogli contro delle fiammate incredibilmente roventi, riducendone l'Attacco Speciale." - }, - "spikyShield": { - "name": "Agodifesa", - "effect": "Protegge dagli attacchi, riducendo inoltre i PS dei Pokémon che entrano in contatto con chi la usa." - }, - "aromaticMist": { - "name": "Nebularoma", - "effect": "Aumenta la Difesa Speciale di un alleato tramite un misterioso aroma." - }, - "eerieImpulse": { - "name": "Elettromistero", - "effect": "Il corpo dell'utilizzatore genera un impulso misterioso. Esponendovi il bersaglio, ne riduce di molto l'Attacco Speciale." - }, - "venomDrench": { - "name": "Velenotrappola", - "effect": "Emette un liquido particolare che riduce l'Attacco, l'Attacco Speciale e la Velocità dei nemici avvelenati intorno a chi la usa." - }, - "powder": { - "name": "Pulviscoppio", - "effect": "Il bersaglio viene coperto da un pulviscolo che esplode danneggiandolo se questi utilizza una mossa di tipo Fuoco nello stesso turno." - }, - "geomancy": { - "name": "Geocontrollo", - "effect": "Un'energia pura forza della natura si sprigiona per tutto il campo." - }, - "magneticFlux": { - "name": "Controllo Polare", - "effect": "Tramite il controllo dei campi magnetici, aumenta la Difesa e la Difesa Speciale dei Pokémon alleati dotati dell'abilità Più o Meno." - }, - "happyHour": { - "name": "Cuccagna", - "effect": "Questa mossa raddoppia la ricompensa ricevuta dopo aver vinto una lotta." - }, - "electricTerrain": { - "name": "Campo Elettrico", - "effect": "Per cinque turni trasforma il terreno di lotta in un campo elettrico, impedendo ai Pokémon a terra di addormentarsi." - }, - "dazzlingGleam": { - "name": "Magibrillio", - "effect": "Emette una luce potentissima che infligge danni al bersaglio." - }, - "celebrate": { - "name": "Auguri", - "effect": "Il Pokémon ti fa gli auguri nel tuo giorno speciale" - }, - "holdHands": { - "name": "Mano nella mano", - "effect": "Il Pokémon che la usa e un alleato si prendono per mano e fanno salti di gioia." - }, - "babyDollEyes": { - "name": "Occhioni Teneri", - "effect": "Chi la usa rivolge i propri occhioni languidi al bersaglio, riducendone l'Attacco. Colpisce sempre per primo." - }, - "nuzzle": { - "name": "Elettrococcola", - "effect": "Nonostante il tenero nome è una mossa piuttosto pericolosa." - }, - "holdBack": { - "name": "Riguardo", - "effect": "Chi la usa attacca il bersaglio, modulando il colpo in modo da lasciargli almeno un PS." - }, - "infestation": { - "name": "Assillo", - "effect": "Chi la usa lancia un attacco che tormenta il bersaglio per quattro o cinque turni, durante i quali gli impedisce di fuggire." - }, - "powerUpPunch": { - "name": "Crescipugno", - "effect": "Rende i pugni più duri a ogni colpo inferto. Se i pugni vanno a segno, aumenta l'Attacco." - }, - "oblivionWing": { - "name": "Ali del Fato", - "effect": "Chi la usa assorbe energia dal bersaglio recuperando una quantità di PS pari a più della metà del danno inferto." - }, - "thousandArrows": { - "name": "Mille Frecce", - "effect": "Colpisce anche i Pokémon che fluttuano in aria. I nemici nei paraggi vengono scaraventati a terra." - }, - "thousandWaves": { - "name": "Mille Onde", - "effect": "Un’onda strisciante investe i nemici intorno impedendo loro di fuggire." - }, - "landsWrath": { - "name": "Forza Tellurica", - "effect": "Chi la usa raccoglie energia tellurica e ne concentra il potere sui nemici che ha intorno danneggiandoli." - }, - "lightOfRuin": { - "name": "Luce Nefasta", - "effect": "Traendo potere dal Fiore Eterno, chi lo utilizza spara un potente raggio di luce. Ciò danneggia parecchio anche chi la usa." - }, - "originPulse": { - "name": "Primopulsar", - "effect": "Attacca i nemici intorno colpendoli con miriadi di raggi di luce blu." - }, - "precipiceBlades": { - "name": "Spade Telluriche", - "effect": "Attacca i nemici intorno trasformando la potenza della terra in lame affilate." - }, - "dragonAscent": { - "name": "Ascesa del Drago", - "effect": "Permette di proiettarsi in aria e fiondarsi sul bersaglio attaccando ad altissima velocità. Riduce la Difesa e la Difesa Speciale di chi la usa." - }, - "hyperspaceFury": { - "name": "Urtodimensionale", - "effect": "Permette di attaccare ripetutamente grazie ai molti arti, ignorando mosse come Protezione o Individua. Riduce la Difesa di chi la usa." - }, - "breakneckBlitzPhysical": { - "name": "Carica Travolgente", - "effect": "Grazie al Potere Z, chi la usa accumula energia e si lancia a tutta forza contro il bersaglio. La potenza varia a seconda della mossa su cui si basa." - }, - "breakneckBlitzSpecial": { - "name": "Carica Travolgente", - "effect": "Dati Mancanti" - }, - "allOutPummelingPhysical": { - "name": "Iperscarica Furiosa", - "effect": "Chi la usa scaglia sul bersaglio una scarica di colpi carichi di Potere Z. La potenza varia a seconda della mossa su cui si basa." - }, - "allOutPummelingSpecial": { - "name": "Iperscarica Furiosa", - "effect": "Dati Mancanti" - }, - "supersonicSkystrikePhysical": { - "name": "Picchiata Devastante", - "effect": "Chi la usa si serve del Potere Z per alzarsi in volo e attaccare il bersaglio piombandogli addosso. La potenza varia a seconda della mossa su cui si basa." - }, - "supersonicSkystrikeSpecial": { - "name": "Picchiata Devastante", - "effect": "Dati Mancanti" - }, - "acidDownpourPhysical": { - "name": "Acidiluvio Corrosivo", - "effect": "Chi la usa sfrutta il Potere Z per creare una palude velenosa che sommerge il bersaglio. La potenza varia a seconda della mossa su cui si basa." - }, - "acidDownpourSpecial": { - "name": "Acidiluvio Corrosivo", - "effect": "Dati Mancanti" - }, - "tectonicRagePhysical": { - "name": "Furore della Terra", - "effect": "Grazie al Potere Z, chi la usa si tuffa nelle viscere della terra e colpisce con violenza il bersaglio. La potenza varia a seconda della mossa su cui si basa." - }, - "tectonicRageSpecial": { - "name": "Furore della Terra", - "effect": "Dati Mancanti" - }, - "continentalCrushPhysical": { - "name": "Gigamacigno Polverizzante", - "effect": "Grazie al Potere Z, chi la usa crea un masso enorme e lo lancia sul bersaglio schiacciandolo. La potenza varia a seconda della mossa su cui si basa." - }, - "continentalCrushSpecial": { - "name": "Gigamacigno Polverizzante", - "effect": "Dati Mancanti" - }, - "savageSpinOutPhysical": { - "name": "Bozzolo Fatale", - "effect": "Chi la usa sfrutta il potere Z per creare dei filamenti che intrappolano il bersaglio. La potenza varia a seconda della mossa su cui si basa." - }, - "savageSpinOutSpecial": { - "name": "Bozzolo Fatale", - "effect": "Dati Mancanti" - }, - "neverEndingNightmarePhysical": { - "name": "Abbraccio Spettrale", - "effect": "Grazie al Potere Z, chi la usa intrappola il bersaglio in una morsa generata dal proprio rancore. La potenza varia a seconda della mossa su cui si basa." - }, - "neverEndingNightmareSpecial": { - "name": "Abbraccio Spettrale", - "effect": "Dati Mancanti" - }, - "corkscrewCrashPhysical": { - "name": "Spirale Perforante", - "effect": "Grazie al Potere Z, chi la usa vortica su se stesso e si scaglia sul bersaglio con tutte le sue forze. La potenza varia a seconda della mossa su cui si basa" - }, - "corkscrewCrashSpecial": { - "name": "Spirale Perforante", - "effect": "Dati Mancanti" - }, - "infernoOverdrivePhysical": { - "name": "Fiammobomba Detonante", - "effect": "Chi la usa sfrutta il Potere Z per emettere fiamme incandescenti che inceneriscono il bersaglio. La potenza varia a seconda della mossa su cui si basa." - }, - "infernoOverdriveSpecial": { - "name": "Fiammobomba Detonante", - "effect": "Dati Mancanti" - }, - "hydroVortexPhysical": { - "name": "Idrovortice Abissale", - "effect": "Grazie al Potere Z, chi la usa crea un enorme vortice che inghiotte il bersaglio. La potenza varia a seconda della mossa su cui si basa." - }, - "hydroVortexSpecial": { - "name": "Idrovortice Abissale", - "effect": "Dati Mancanti" - }, - "bloomDoomPhysical": { - "name": "Floriscoppio Sfolgorante", - "effect": "Grazie al Potere Z, chi la usa concentra l'energia delle piante per scatenare un potente attacco. La potenza varia a seconda della mossa su cui si basa." - }, - "bloomDoomSpecial": { - "name": "Floriscoppio Sfolgorante", - "effect": "Dati Mancanti" - }, - "gigavoltHavocPhysical": { - "name": "Gigascarica Folgorante", - "effect": "Grazie al Potere Z, chi la usa genera una fortissima scarica elettrica che colpisce il bersaglio. La potenza varia a seconda della mossa su cui si basa." - }, - "gigavoltHavocSpecial": { - "name": "Gigascarica Folgorante", - "effect": "Dati Mancanti" - }, - "shatteredPsychePhysical": { - "name": "Impatto Psicocinetico", - "effect": "Chi la usa si serve del Potere Z per manipolare la mente del bersaglio causando ingenti danni. La potenza varia a seconda della mossa su cui si basa." - }, - "shatteredPsycheSpecial": { - "name": "Impatto Psicocinetico", - "effect": "Dati Mancanti" - }, - "subzeroSlammerPhysical": { - "name": "Criodistruzione Polare", - "effect": "Chi la usa sfrutta il Potere Z per far calare di colpo la temperatura e congelare il bersaglio. La potenza varia a seconda della mossa su cui si basa." - }, - "subzeroSlammerSpecial": { - "name": "Criodistruzione Polare", - "effect": "Dati Mancanti" - }, - "devastatingDrakePhysical": { - "name": "Dragoschianto Finale", - "effect": "Grazie al Potere Z, chi la usa materializza la propria aura per colpire con forza il nemico. La potenza varia a seconda della mossa su cui si basa." - }, - "devastatingDrakeSpecial": { - "name": "Dragoschianto Finale", - "effect": "Dati Mancanti" - }, - "blackHoleEclipsePhysical": { - "name": "Buco Nero del Non Ritorno", - "effect": "Chi la usa si serve del Potere Z per concentrare energia negativa con cui inghiotte il bersaglio. La potenza varia a seconda della mossa su cui si basa." - }, - "blackHoleEclipseSpecial": { - "name": "Buco Nero del Non Ritorno", - "effect": "Dati Mancanti" - }, - "twinkleTacklePhysical": { - "name": "Astroimpatto Fatato", - "effect": "Grazie al Potere Z, chi la usa crea una dimensione fatata in cui fa ciò che vuole del proprio bersaglio. La potenza varia a seconda della mossa su cui si basa." - }, - "twinkleTackleSpecial": { - "name": "Astroimpatto Fatato", - "effect": "Dati Mancanti" - }, - "catastropika": { - "name": "Super Pikaboom", - "effect": "Grazie al Potere Z, Pikachu accumula un'enorme quantità di energia elettrica e si lancia contro il bersaglio a tutta forza." - }, - "shoreUp": { - "name": "Sabbiaccumulo", - "effect": "Chi la usa recupera metà dei propri PS massimi. Durante le tempeste di sabbia ne recupera di più." - }, - "firstImpression": { - "name": "Schermaglia", - "effect": "È una mossa molto potente, ma funziona solo appena scesi in campo." - }, - "banefulBunker": { - "name": "Fortino", - "effect": "L'utilizzatore si protegge e se l'avversario attacca con una mossa da contatto viene avvelenato." - }, - "spiritShackle": { - "name": "Cucitura d'Ombra", - "effect": "Chi la usa attacca il bersaglio e fissa la sua ombra a terra impedendogli di fuggire." - }, - "darkestLariat": { - "name": "Braccioteso", - "effect": "Chi la usa attacca il bersaglio mulinando gli arti. Il danno inflitto ignora le modifiche alle statistiche del bersaglio." - }, - "sparklingAria": { - "name": "Canto Effimero", - "effect": "Chi la usa si mette a cantare emettendo tanti palloncini d’acqua. I Pokémon che subiscono danni da questa mossa guariscono dalle scottature." - }, - "iceHammer": { - "name": "Martelgelo", - "effect": "Infligge danni al bersaglio colpendolo con un pugno molto potente. Riduce la velocità di chi la usa." - }, - "floralHealing": { - "name": "Cura Floreale", - "effect": "Fa recuperare metà dei PS massimi al bersaglio. È più efficace quando il terreno di lotta è nello stato di Campo Erboso." - }, - "highHorsepower": { - "name": "Forza Equina", - "effect": "Il Pokémon travolge il bersaglio con un attacco possente." - }, - "strengthSap": { - "name": "Assorbiforza", - "effect": "Fa recuperare una quantità di PS pari all'Attacco del bersaglio, che vedrà diminuire questa statistica." - }, - "solarBlade": { - "name": "Lama Solare", - "effect": "Il Pokémon assorbe la luce al primo turno per poi condensarla in una lama e attaccare al turno successivo." - }, - "leafage": { - "name": "Fogliame", - "effect": "Attacca il bersaglio con delle foglie." - }, - "spotlight": { - "name": "Riflettore", - "effect": "Nessuna descrizione disponibile." - }, - "toxicThread": { - "name": "Velenotela", - "effect": "Avvelena il bersaglio avvolgendolo con filamenti tossici e ne riduce la Velocità." - }, - "laserFocus": { - "name": "Concentrazione", - "effect": "Chi la usa si concentra e nel turno successivo metterà sicuramente a segno un brutto colpo." - }, - "gearUp": { - "name": "Marciainpiù", - "effect": "Dà una marcia in più agli alleati con le abilità Meno o Più aumentandone l’Attacco e l’Attacco Speciale." - }, - "throatChop": { - "name": "Colpo Infernale", - "effect": "Chi viene colpito da questa mossa prova un dolore lancinante e non può più usare mosse basate sul suono per due turni." - }, - "pollenPuff": { - "name": "Sferapolline", - "effect": "Chi la usa attacca il nemico con una sfera esplosiva. Se colpisce degli alleati, fa recuperare loro dei PS." - }, - "anchorShot": { - "name": "Colpo d'Ancora", - "effect": "Chi la usa colpisce il nemico con un'ancora e lo intrappola nella catena impedendogli di fuggire." - }, - "psychicTerrain": { - "name": "Campo Psichico", - "effect": "Per cinque turni il terreno entra nello stato di Campo Psichico: i Pokémon a terra non subiscono mosse ad alta priorità e la potenza delle mosse di tipo Psico aumenta." - }, - "lunge": { - "name": "Assalto", - "effect": "Chi la usa si lancia con tutte le sue forze sul bersaglio e ne riduce l'Attacco." - }, - "fireLash": { - "name": "Frusta di Fuoco", - "effect": "Colpisce il bersaglio con una frusta infuocata e ne riduce la Difesa." - }, - "powerTrip": { - "name": "Tracotanza", - "effect": "Chi la usa attacca il bersaglio sfoggiando la propria forza. Più le sue statistiche sono state aumentate, più la mossa è potente." - }, - "burnUp": { - "name": "Ultima Fiamma", - "effect": "Chi la usa attacca sfruttando tutta la sua potenza incendiaria per infliggere gravi danni al bersaglio, ma come conseguenza perde il tipo Fuoco." - }, - "speedSwap": { - "name": "Velociscambio", - "effect": "Chi la usa scambia la propria Velocità con quella del bersaglio." - }, - "smartStrike": { - "name": "Sottilcorno", - "effect": "Chi la usa colpisce il bersaglio con un corno appuntito. Questa mossa va sempre a segno." - }, - "purify": { - "name": "Purificazione", - "effect": "Il bersaglio della mossa viene curato dalle alterazioni di stato inoltre l'utilizzatore ripristina i propri PS se la mossa va a segno." - }, - "revelationDance": { - "name": "Mutadanza", - "effect": "Chi la usa si lancia in una danza e attacca il nemico con tutte le sue forze. Il tipo della mossa corrisponde al tipo del Pokémon che la usa." - }, - "coreEnforcer": { - "name": "Nucleocastigo", - "effect": "Il bersaglio subisce dei danni e, se ha già agito nel turno, perde la sua abilità." - }, - "tropKick": { - "name": "Tropicalcio", - "effect": "Chi la usa colpisce il bersaglio con un potente calcio sfruttando una tecnica originaria dei paesi tropicali e ne riduce l'Attacco." - }, - "instruct": { - "name": "Imposizione", - "effect": "Nessuna descrizione disponibile." - }, - "beakBlast": { - "name": "Cannonbecco", - "effect": "Chi la usa arroventa il proprio becco e poi attacca. Se un Pokémon lo colpisce con un attacco diretto mentre sta accumulando calore, resta scottato." - }, - "clangingScales": { - "name": "Clamorsquame", - "effect": "Chi la usa attacca il bersaglio con un suono fortissimo che genera sfregando le scaglie del corpo. Dopo aver attaccato, la sua Difesa diminuisce." - }, - "dragonHammer": { - "name": "Marteldrago", - "effect": "Chi la usa infligge danni al bersaglio usando il proprio corpo come se fosse un martello." - }, - "brutalSwing": { - "name": "Vorticolpo", - "effect": "Chi la usa infligge danni intorno a sé facendo ruotare una parte del suo corpo." - }, - "auroraVeil": { - "name": "Velaurora", - "effect": "Questa mossa riduce i danni provocati dalle mosse fisiche e speciali per 5 turni. Può essere usata solo mentre grandina." - }, - "sinisterArrowRaid": { - "name": "Dardoassalto Spettrale", - "effect": "Grazie al Potere Z, Decidueye crea una formazione di frecce che colpisce il bersaglio a gran velocità." - }, - "maliciousMoonsault": { - "name": "Iperschianto delle Tenebre", - "effect": "Grazie al Potere Z, Incineroar richiama tutta la sua forza e si lancia impetuosamente sul bersaglio." - }, - "oceanicOperetta": { - "name": "Sinfonia del Mare", - "effect": "Grazie al Potere Z, Primarina concentra un’enorme quantità d’acqua e attacca il bersaglio con una potenza smisurata." - }, - "guardianOfAlola": { - "name": "Collera del Guardiano", - "effect": "Grazie al Potere Z, il Nume Locale evoca l’energia di Alola e attacca con grande potenza, facendo perdere al bersaglio la maggior parte dei suoi PS." - }, - "soulStealing7StarStrike": { - "name": "Colpo Eptastellare Rubanima", - "effect": "Grazie al Potere Z, Marshadow fa appello a tutte le sue forze e colpisce il bersaglio con una scarica di calci e pugni potentissimi." - }, - "stokedSparksurfer": { - "name": "Elettrosurf Folgorante", - "effect": "Grazie al Potere Z, il Raichu di Alola attacca con tutta la sua potenza e paralizza il bersaglio." - }, - "pulverizingPancake": { - "name": "Adesso Faccio sul Serio", - "effect": "Grazie al Potere Z, Snorlax tira fuori la grinta e, muovendo energicamente il suo enorme corpo, attacca il bersaglio con tutta la sua forza." - }, - "extremeEvoboost": { - "name": "Potenziamento Eevolutivo", - "effect": "Grazie al Potere Z, Eevee evoca a sé tutta l’energia delle sue possibili evoluzioni e aumenta di molto le sue statistiche" - }, - "genesisSupernova": { - "name": "Supernova delle Origini", - "effect": "Grazie al Potere Z, Mew attacca il bersaglio con tutta la sua forza e genera un Campo Psichico a terra." - }, - "shellTrap": { - "name": "Gusciotrappola", - "effect": "Il guscio del Pokémon diventa una trappola. Se un nemico lo colpisce con una mossa fisica, innesca un'esplosione e subisce dei danni." - }, - "fleurCannon": { - "name": "Cannonfiore", - "effect": "Colpisce il bersaglio con un potente raggio, ma riduce di molto l'Attacco Speciale di chi la usa." - }, - "psychicFangs": { - "name": "Psicozanna", - "effect": "L'utilizzatore morde il bersaglio, rompendo barriere come Schermoluce e Riflesso." - }, - "stompingTantrum": { - "name": "Battipiedi", - "effect": "Chi la usa attacca battendo i piedi per la rabbia. Se la mossa usata al turno precedente non è andata a segno, la potenza raddoppia." - }, - "shadowBone": { - "name": "Ossotetro", - "effect": "Chi la usa colpisce il bersaglio con un osso in cui alberga uno spirito. Può anche ridurne la Difesa." - }, - "accelerock": { - "name": "Rocciarapida", - "effect": "Chi la usa attacca il bersaglio colpendolo a tutta velocità. Questa mossa ha priorità alta." - }, - "liquidation": { - "name": "Idrobreccia", - "effect": "Chi la usa colpisce il bersaglio con la forza dell'acqua. Può anche ridurne la Difesa." - }, - "prismaticLaser": { - "name": "Prismalaser", - "effect": "Chi la usa proietta dei potenti raggi di luce grazie alla potenza del suo prisma, ma non può agire nel turno successivo." - }, - "spectralThief": { - "name": "Ombrafurto", - "effect": "Chi la usa ruba gli aumenti delle statistiche del bersaglio, poi si nasconde nella sua ombra e lo attacca." - }, - "sunsteelStrike": { - "name": "Astrocarica", - "effect": "Chi la usa travolge il bersaglio con la potenza di una meteora. Questo attacco ignora l'abilità del bersaglio." - }, - "moongeistBeam": { - "name": "Raggio d'Ombra", - "effect": "Chi la usa proietta sul bersaglio un misterioso raggio di luce. Questo attacco ignora l'abilità del bersaglio." - }, - "tearfulLook": { - "name": "Occhionilucidi", - "effect": "Chi la usa guarda il bersaglio con gli occhi pieni di lacrime e gli fa perdere lo spirito combattivo, riducendone l'Attacco e l'Attacco Speciale" - }, - "zingZap": { - "name": "Elettropizzico", - "effect": "Chi la usa colpisce il bersaglio investendolo con una potente scarica elettrica che può anche farlo tentennare." - }, - "naturesMadness": { - "name": "Ira della Natura", - "effect": "Scatena l’ira della natura sul bersaglio e ne dimezza i PS." - }, - "multiAttack": { - "name": "Multiattacco", - "effect": "Chi la usa si avvolge in un potente campo energetico e colpisce il bersaglio. Il tipo della mossa varia in base alla ROM installata." - }, - "tenMillionVoltThunderbolt": { - "name": "Iperfulmine", - "effect": "Grazie al Potere Z, Pikachu con il berretto scatena una potentissima scarica elettrica. Probabile brutto colpo." - }, - "mindBlown": { - "name": "Sbalorditesta", - "effect": "Chi la usa fa esplodere la propria testa per attaccare tutti i Pokémon che ha intorno, ma subisce danni." - }, - "plasmaFists": { - "name": "Pugni Plasma", - "effect": "Chi la usa attacca con pugni carichi di elettricità. Trasforma le mosse di tipo Normale in mosse di tipo Elettro." - }, - "photonGeyser": { - "name": "Geyser Fotonico", - "effect": "Infligge danni in base all’Attacco o all’Attacco Speciale scegliendo il più alto tra i due. Questo attacco ignora l’abilità del bersaglio." - }, - "lightThatBurnsTheSky": { - "name": "Fotodistruzione Apocalittica", - "effect": "Infligge danni in base all’Attacco o all’Attacco Speciale scegliendo il più alto tra i due. Questo attacco ignora l’abilità del bersaglio." - }, - "searingSunrazeSmash": { - "name": "Supercollisione Solare", - "effect": "Grazie al Potere Z, Solgaleo attacca il bersaglio con tutta la sua forza. Questo attacco ignora l’abilità del bersaglio se questa ha effetto sulle mosse." - }, - "menacingMoonrazeMaelstrom": { - "name": "Deflagrazione Lunare", - "effect": "Grazie al Potere Z, Lunala attacca il bersaglio con tutta la sua forza. Questo attacco ignora l’abilità del bersaglio se questa ha effetto sulle mosse." - }, - "letsSnuggleForever": { - "name": "Dolcesacco di Botte", - "effect": "Grazie al Potere Z, Mimikyu fa appello a tutte le sue forze e attacca il bersaglio tempestandolo di colpi." - }, - "splinteredStormshards": { - "name": "Litotempesta Radiale", - "effect": "Grazie al Potere Z, Lycanroc attacca il bersaglio con tutta la sua forza. Questa mossa annulla anche gli eventuali campi attivi." - }, - "clangorousSoulblaze": { - "name": "Dracofonia Divampante", - "effect": "Grazie al Potere Z, Kommo-o attacca i nemici con tutta la sua forza. Inoltre, aumenta le proprie statistiche." - }, - "zippyZap": { - "name": "Sprintaboom", - "effect": "Un attacco elettrico ad altissima velocità. Questa mossa ha priorità alta e infligge sicuramente un brutto colpo." - }, - "splishySplash": { - "name": "Surfasplash", - "effect": "Colpisce il bersaglio con un'enorme onda caricata di elettricità che può anche paralizzarlo." - }, - "floatyFall": { - "name": "Piombaflap", - "effect": "Chi la usa si libra in aria per poi piombare addosso al bersaglio. Può anche far tentennare il Pokémon colpito." - }, - "pikaPapow": { - "name": "Pikasaetta", - "effect": "Questa mossa infallibile diventa più potente con il rafforzarsi del rapporto tra Pikachu e l'Allenatore." - }, - "bouncyBubble": { - "name": "Bollaslurp", - "effect": "Chi la usa colpisce il bersaglio con una raffica di bolle, per poi assorbirle e recuperare una quantità di PS pari alla del danno inferto." - }, - "buzzyBuzz": { - "name": "Elettrozap", - "effect": "Colpisce il bersaglio con una scarica elettrica che lo paralizza." - }, - "sizzlySlide": { - "name": "Fiammabam", - "effect": "Chi la usa viene avvolto dalle fiamme e colpisce il bersaglio con forza, scottandolo." - }, - "glitzyGlow": { - "name": "Auraswoosh", - "effect": "Colpisce il bersaglio ripetutamente con onde di forza psicocinetica e innalza una barriera fantastica che riduce i danni degli attacchi speciali nemici." - }, - "baddyBad": { - "name": "Zona Buiabuia", - "effect": "Chi la usa scatena l’oscurità che ha dentro, colpendo il bersaglio e innalzando una barriera fantastica che riduce i danni degli attacchi fisici nemici." - }, - "sappySeed": { - "name": "Bombafrush", - "effect": "Fa crescere un'enorme pianta che colpisce il bersaglio con una pioggia di semi. Questi sottraggono PS a ogni turno permettendo a chi la usa di curarsi." - }, - "freezyFrost": { - "name": "Scricchiagelo", - "effect": "Chi la usa attacca il bersaglio con un cristallo formato da una nube nera congelata, che annulla ogni modifica alle statistiche di tutti i Pokémon." - }, - "sparklySwirl": { - "name": "Sbrilluccibufera", - "effect": "Chi la usa attacca il bersaglio avvolgendolo in un turbine di profumi soffocanti e cura i problemi di stato propri e degli alleati." - }, - "veeveeVolley": { - "name": "Eeveempatto", - "effect": "Questa mossa infallibile diventa più potente con il rafforzarsi del rapporto tra Eevee e l'Allenatore." - }, - "doubleIronBash": { - "name": "Pugni Corazzati", - "effect": "L'utilizzatore ruota, centrando il dado esagonale nel petto, quindi colpisce con le braccia due volte di seguito. Ciò potrebbe anche far tentennare il bersaglio." - }, - "maxGuard": { - "name": "Dynabarriera", - "effect": "Questa mossa permette di eludere tutti gli attacchi. Se usata in successione può fallire." - }, - "dynamaxCannon": { - "name": "Cannone Dynamax", - "effect": "Il Pokémon attacca emettendo dal suo nucleo l'energia concentrata nel corpo. Se il bersaglio è overlivellato, i danni inflitti aumentano." - }, - "snipeShot": { - "name": "Tiromirato", - "effect": "Permette di attaccare il bersaglio ignorando gli effetti di mosse e abilità che alterano le mosse" - }, - "jawLock": { - "name": "Morsostretto", - "effect": "Impedisce a chi la usa e al bersaglio di essere sostituiti finché non vanno KO. L'effetto svanisce se uno dei due lascia il campo." - }, - "stuffCheeks": { - "name": "Riempiguance", - "effect": "Se chi la usa ha con sé una bacca, la mangia e la sua Difesa aumenta di molto." - }, - "noRetreat": { - "name": "Spalle al Muro", - "effect": "Il Pokémon aumenta tutte le sue statistiche ma non può più fuggire o essere sostituito." - }, - "tarShot": { - "name": "Colpocatrame", - "effect": "Chi la usa getta catrame appiccicoso sul bersaglio abbassandone la Velocità e rendendolo vulnerabile al tipo Fuoco." - }, - "magicPowder": { - "name": "Magipolvere", - "effect": "Chi la usa getta addosso al bersaglio una polvere magica che lo rende di tipo Psico." - }, - "dragonDarts": { - "name": "Dragofrecce", - "effect": "L'utilizzatore attacca due volte usando Dreepy. Se ci sono due obiettivi, questa mossa colpisce una volta ogni obiettivo." - }, - "teatime": { - "name": "Ora del Tè", - "effect": "Chi la usa invita tutti i Pokémon in campo a prendere il tè. Quelli che hanno con sé una bacca la mangiano." - }, - "octolock": { - "name": "Tentacolock", - "effect": "Chi la usa immobilizza il bersaglio impedendogli di fuggire e ne diminuisce la Difesa e la Difesa Speciale a ogni turno." - }, - "boltBeak": { - "name": "Beccoshock", - "effect": "Chi la usa attacca il bersaglio con il becco appuntito carico d'elettricità. Se attacca per primo, la potenza della mossa raddoppia." - }, - "fishiousRend": { - "name": "Branchiomorso", - "effect": "Chi la usa morde il bersaglio con le dure branchie. Se attacca per primo, la potenza della mossa raddoppia." - }, - "courtChange": { - "name": "Cambiocampo", - "effect": "Una forza misteriosa inverte gli effetti attivi sul campo alleato e sul campo avversario." - }, - "maxFlare": { - "name": "Dynafiammata", - "effect": "Un attacco di tipo Fuoco che può essere eseguito dai Pokémon dynamaxizzati. Intensifica i raggi solari per cinque turni." - }, - "maxFlutterby": { - "name": "Dynainsetto", - "effect": "Un attacco di tipo Coleottero che può essere eseguito dai Pokémon dynamaxizzati. Riduce l'Attacco Speciale degli avversari." - }, - "maxLightning": { - "name": "Dynasaetta", - "effect": "Un attacco di tipo Elettro che può essere eseguito dai Pokémon dynamaxizzati. Per cinque turni il terreno entra nello stato di Campo Elettrico." - }, - "maxStrike": { - "name": "Dynattacco", - "effect": "Un attacco di tipo Normale che può essere eseguito dai Pokémon dynamaxizzati. Riduce la Velocità degli avversari." - }, - "maxKnuckle": { - "name": "Dynapugno", - "effect": "Un attacco di tipo Lotta che può essere eseguito dai Pokémon dynamaxizzati. Aumenta l'Attacco degli alleati." - }, - "maxPhantasm": { - "name": "Dynavuoto", - "effect": "Un attacco di tipo Spettro che può essere eseguito dai Pokémon dynamaxizzati. Riduce la Difesa degli avversari." - }, - "maxHailstorm": { - "name": "Dynagelo", - "effect": "Un attacco di tipo Ghiaccio che può essere eseguito dai Pokémon dynamaxizzati. Causa una nevicata che dura per cinque turni." - }, - "maxOoze": { - "name": "Dynacorrosione", - "effect": "Un attacco di tipo Veleno che può essere eseguito dai Pokémon dynamaxizzati. Aumenta l'Attacco Speciale degli alleati." - }, - "maxGeyser": { - "name": "Dynaflusso", - "effect": "Un attacco di tipo Acqua che può essere eseguito dai Pokémon dynamaxizzati. Provoca una forte pioggia per cinque turni." - }, - "maxAirstream": { - "name": "Dynajet", - "effect": "Un attacco di tipo Volante che può essere eseguito dai Pokémon dynamaxizzati. Aumenta la Velocità degli alleati." - }, - "maxStarfall": { - "name": "Dynafata", - "effect": "Un attacco di tipo Folletto che può essere eseguito dai Pokémon dynamaxizzati. Per cinque turni il terreno entra nello stato di Campo Nebbioso." - }, - "maxWyrmwind": { - "name": "Dynadragone", - "effect": "Un attacco di tipo Drago che può essere eseguito dai Pokémon dynamaxizzati. Riduce l'Attacco degli avversari." - }, - "maxMindstorm": { - "name": "Dynapsiche", - "effect": "Un attacco di tipo Psico che può essere eseguito dai Pokémon dynamaxizzati. Per cinque turni il terreno entra nello stato di Campo Psichico." - }, - "maxRockfall": { - "name": "Dynamacigno", - "effect": "Un attacco di tipo Roccia che può essere eseguito dai Pokémon dynamaxizzati. Causa una tempesta di sabbia per cinque turni." - }, - "maxQuake": { - "name": "Dynasisma", - "effect": "Un attacco di tipo Terra che può essere eseguito dai Pokémon dynamaxizzati. Aumenta la Difesa Speciale degli alleati." - }, - "maxDarkness": { - "name": "Dynatenebre", - "effect": "Un attacco di tipo Buio che può essere eseguito dai Pokémon dynamaxizzati. Riduce la Difesa Speciale degli avversari." - }, - "maxOvergrowth": { - "name": "Dynaflora", - "effect": "Un attacco di tipo Erba che può essere eseguito dai Pokémon dynamaxizzati. Per cinque turni il terreno entra nello stato di Campo Erboso." - }, - "maxSteelspike": { - "name": "Dynametallo", - "effect": "Un attacco di tipo Acciaio che può essere eseguito dai Pokémon dynamaxizzati. Aumenta la Difesa degli alleati." - }, - "clangorousSoul": { - "name": "Dracofonia", - "effect": "Chi la usa sacrifica un po' dei suoi PS per aumentare tutte le sue statistiche." - }, - "bodyPress": { - "name": "Schiacciacorpo", - "effect": "Chi la usa schiaccia il bersaglio con il suo corpo. Più la sua Difesa è alta, maggiori sono i danni inflitti." - }, - "decorate": { - "name": "Decorazione", - "effect": "Chi la usa agghinda il bersaglio con delle decorazioni aumentandone di molto l'Attacco e l'Attacco Speciale." - }, - "drumBeating": { - "name": "Tamburattacco", - "effect": "Chi la usa percuote il proprio tamburo per controllarne le radici e attaccare il bersaglio, riducendone la Velocità." - }, - "snapTrap": { - "name": "Tagliola", - "effect": "Chi la usa intrappola il bersaglio in una tagliola e lo attacca per quattro o cinque turni." - }, - "pyroBall": { - "name": "Palla Infuocata", - "effect": "l Pokémon attacca con una palla creata incendiando una piccola pietra. Può anche scottare il bersaglio." - }, - "behemothBlade": { - "name": "Taglio Maestoso", - "effect": "Il Pokémon brandisce un'enorme spada e attacca vibrando un poderoso fendente." - }, - "behemothBash": { - "name": "Colpo Maestoso", - "effect": "Il Pokémon trasforma il suo corpo in un robusto scudo e attacca caricando con forza." - }, - "auraWheel": { - "name": "Ruota d'Aura", - "effect": "Il Pokémon emette l'energia accumulata nelle guance per attaccare e aumentare la Velocità. Il tipo della mossa cambia in base alla forma assunta da Morpeko." - }, - "breakingSwipe": { - "name": "Vastoimpatto", - "effect": "Chi la usa attacca i nemici intorno con la sua robusta coda riducendone l'Attacco." - }, - "branchPoke": { - "name": "Ramostoccata", - "effect": "Chi la usa attacca il bersaglio con un ramo incredibilmente appuntito." - }, - "overdrive": { - "name": "Overdrive", - "effect": "Chi la usa suona la chitarra o il basso creando un'onda sonora potentissima con cui attacca il bersaglio." - }, - "appleAcid": { - "name": "Acido Malico", - "effect": "Il Pokémon attacca il bersaglio con un liquido acido ricavato da mele aspre riducendone la Difesa Speciale." - }, - "gravApple": { - "name": "Forza G", - "effect": "Il Pokémon fa cadere una mela sul bersaglio da una grande altezza, infliggendogli danni e riducendone la Difesa." - }, - "spiritBreak": { - "name": "Frantumanima", - "effect": "Chi la usa attacca il bersaglio con un tale impeto da fargli perdere la voglia di lottare e ne riduce l'Attacco Speciale" - }, - "strangeSteam": { - "name": "Vapore Incantato", - "effect": "Il Pokémon attacca il bersaglio con getti di vapore che possono anche confonderlo." - }, - "lifeDew": { - "name": "Goccia Vitale", - "effect": "Il Pokémon sparge tutt'intorno dell'acqua misteriosa che fa recuperare PS a sé e agli alleati in campo." - }, - "obstruct": { - "name": "Sbarramento", - "effect": "Permette di eludere tutti gli attacchi. Se usata in successione può fallire. Se un Pokémon tocca chi la usa, la sua Difesa diminuisce di molto." - }, - "falseSurrender": { - "name": "Supplicolpo", - "effect": "Chi la usa finge di abbassare la testa a mo' di supplica e attacca il bersaglio con i suoi capelli scarmigliati. Questa mossa va sempre a segno." - }, - "meteorAssault": { - "name": "Sfolgorassalto", - "effect": "Chi la usa attacca il bersaglio brandendo un grosso gambo, ma perde l'equilibrio e nel turno successivo non può agire." - }, - "eternabeam": { - "name": "Raggio Infinito", - "effect": "È l'attacco più potente di Eternatus quando assume la sua forma originale. Nel turno successivo non può agire." - }, - "steelBeam": { - "name": "Raggio d'Acciaio", - "effect": "Il Pokémon utilizza l'acciaio del proprio corpo per sparare un violento raggio, ma subisce danni." - }, - "expandingForce": { - "name": "Vastenergia", - "effect": "Chi la usa attacca il bersaglio con energia psichica. Se utilizzata quando è attivo un Campo Psichico, la mossa aumenta di potenza e danneggia tutti i nemici." - }, - "steelRoller": { - "name": "Ferrorullo", - "effect": "Chi la usa attacca eliminando lo stato del terreno di lotta. La mossa fallisce se nel terreno non è attivo alcuno stato." - }, - "scaleShot": { - "name": "Squamacolpo", - "effect": "Il Pokémon attacca lanciando delle squame da due a cinque volte di fila. Aumenta la Velocità di chi la usa, ma ne riduce la Difesa." - }, - "meteorBeam": { - "name": "Raggiometeora", - "effect": "Chi la usa accumula l'energia dello spazio nel primo turno per aumentare l'Attacco Speciale, quindi attacca nel turno successivo." - }, - "shellSideArm": { - "name": "Armaguscio", - "effect": "Il Pokémon esegue un attacco fisico o speciale, in base a quale causa danni maggiori. Può anche avvelenare il bersaglio." - }, - "mistyExplosion": { - "name": "Nebbioscoppio", - "effect": "Chi la usa attacca tutti i Pokémon che ha intorno, ma poi va KO. La potenza delle mosse aumenta quando è attivo un Campo Nebbioso." - }, - "grassyGlide": { - "name": "Erboscivolata", - "effect": "Chi la usa attacca il bersaglio scivolando sul terreno. Se utilizzata quando è attivo un Campo Erboso, ha priorità alta." - }, - "risingVoltage": { - "name": "Elettroimpennata", - "effect": "Chi la usa attacca con dell'elettricità che si alza dal suolo. La potenza della mossa raddoppia quando l'avversario si trova in un Campo Elettrico." - }, - "terrainPulse": { - "name": "Campopulsar", - "effect": "Chi la usa attacca sfruttando l'energia del terreno di lotta. Il tipo e la potenza della mossa variano a seconda dello stato del terreno stesso." - }, - "skitterSmack": { - "name": "Strisciacolpo", - "effect": "Chi la usa attacca il bersaglio strisciandogli alle spalle e riducendo il suo Attacco Speciale." - }, - "burningJealousy": { - "name": "Fiamminvidia", - "effect": "Chi la usa attacca con la forza dell'invidia, causando una scottatura a tutti i Pokémon le cui statistiche sono aumentate durante quel turno." - }, - "lashOut": { - "name": "Sfogarabbia", - "effect": "Chi la usa attacca il bersaglio con tutta la propria ira. Se ha subito riduzioni delle statistiche durante quel turno, la potenza della mossa raddoppia." - }, - "poltergeist": { - "name": "Poltergeist", - "effect": "Chi la usa attacca utilizzando lo strumento del bersaglio. La mossa fallisce se quest'ultimo non ha uno strumento." - }, - "corrosiveGas": { - "name": "Gas Corrosivo", - "effect": "Chi la usa avvolge gli altri Pokémon attorno in un gas altamente acido, dissolvendo i loro strumenti." - }, - "coaching": { - "name": "Coaching", - "effect": "Chi la usa aumenta l'Attacco e la Difesa di tutti gli alleati dando loro indicazioni precise." - }, - "flipTurn": { - "name": "Virata", - "effect": "Chi usa questa mossa fa marcia indietro per farsi sostituire dopo aver sferrato l'attacco." - }, - "tripleAxel": { - "name": "Triplo Axel", - "effect": "Il Pokémon attacca sferrando fino a tre calci consecutivi. Ogni volta che la mossa va a segno, la sua potenza aumenta." - }, - "dualWingbeat": { - "name": "Doppia Ala", - "effect": "Il Pokémon attacca il bersaglio urtandolo con le ali e infliggendogli danni due volte di fila." - }, - "scorchingSands": { - "name": "Sabbiardente", - "effect": "Chi la usa attacca il bersaglio scagliandogli addosso della sabbia incandescente. Può anche scottarlo." - }, - "jungleHealing": { - "name": "Giunglacura", - "effect": "Il Pokémon diventa tutt'uno con la giungla, ripristinando i PS e curando i problemi di stato per sé e per gli alleati in campo." - }, - "wickedBlow": { - "name": "Pugnotenebra", - "effect": "Il Pokémon sferra un singolo colpo potentissimo, massima espressione dello stile di tipo Buio. Brutto colpo assicurato." - }, - "surgingStrikes": { - "name": "Idroraffica", - "effect": "Il Pokémon sferra una fluida serie di tre attacchi, massima espressione dello stile di tipo Acqua. Brutto colpo assicurato." - }, - "thunderCage": { - "name": "Elettrogabbia", - "effect": "Il Pokémon attacca il bersaglio imprigionandolo in una gabbia di elettricità, che sprigiona corrente per quattro o cinque turni." - }, - "dragonEnergy": { - "name": "Dragoenergia", - "effect": "\tIl Pokémon attacca il bersaglio convertendo la propria forza vitale in energia. Più i suoi PS sono bassi, più la potenza della mossa diminuisce." - }, - "freezingGlare": { - "name": "Sguardo Gelido", - "effect": "Il Pokémon attacca rilasciando energia psichica dagli occhi. Può congelare il bersaglio." - }, - "fieryWrath": { - "name": "Furia Ardente", - "effect": "ERR\tIl Pokémon attacca trasformando la sua rabbia in un'aura simile a fiamme. Può anche far tentennare il bersaglio.ORE" - }, - "thunderousKick": { - "name": "Calcio Tonante", - "effect": "Il Pokémon sferra calci al bersaglio dopo averlo distratto con movimenti fulminei, riducendone la Difesa." - }, - "glacialLance": { - "name": "Lancia Glaciale", - "effect": "Il Pokémon attacca il bersaglio scagliando una lancia di ghiaccio accompagnata da una tormenta di neve." - }, - "astralBarrage": { - "name": "Schegge Astrali", - "effect": "Il Pokémon attacca il bersaglio scatenandogli contro una miriade di piccoli spettri." - }, - "eerieSpell": { - "name": "Inquietantesimo", - "effect": "Il Pokémon attacca con i suoi potenti poteri psichici. Sottrae 3 PP all'ultima mossa usata dall'avversario." - }, - "direClaw": { - "name": "Artigli Fatali", - "effect": "Il Pokémon attacca il bersaglio con artigli distruttori. Può anche causargli avvelenamento, paralisi o sonno." - }, - "psyshieldBash": { - "name": "Barrierassalto", - "effect": "Il Pokémon si carica di energia psichica per poi schiantarsi sul bersaglio. Inoltre, aumenta la propria Difesa." - }, - "powerShift": { - "name": "Scambioforza", - "effect": "Il Pokémon scambia il suo Attacco con la Difesa." - }, - "stoneAxe": { - "name": "Rocciascure", - "effect": "Il Pokémon attacca il bersaglio con delle scuri di roccia. I frammenti rocciosi dispersi dall'attacco restano sospesi intorno al bersaglio." - }, - "springtideStorm": { - "name": "Tempesta Zefirea", - "effect": "Il Pokémon attacca il bersaglio avvolgendolo con un vento fortissimo di odio e amore. Può anche ridurne l'Attacco." - }, - "mysticalPower": { - "name": "Forza Mistica", - "effect": "Il Pokémon attacca emettendo un misterioso potere. Inoltre, aumenta il proprio Attacco Speciale." - }, - "ragingFury": { - "name": "Ira Furente", - "effect": "Il Pokémon s'infuria e sputa fiammate per due o tre turni, ma rimane confuso." - }, - "waveCrash": { - "name": "Ondaschianto", - "effect": "Il Pokémon si avvolge in uno strato d'acqua e si lancia sul bersaglio, ma subisce seri danni." - }, - "chloroblast": { - "name": "Clorofillaser", - "effect": "Il Pokémon attacca concentrando la clorofilla nel proprio corpo per poi lanciarla, ma subisce danni." - }, - "mountainGale": { - "name": "Soffio d'Iceberg", - "effect": "\tIl Pokémon attacca colpendo il bersaglio con un blocco di ghiaccio grande come un iceberg. Può anche far tentennare il bersaglio." - }, - "victoryDance": { - "name": "Danzavittoria", - "effect": "Il Pokémon si lancia in una danza sfrenata per invocare la vittoria e aumenta l'Attacco, la Difesa e la Velocità." - }, - "headlongRush": { - "name": "Scontro Frontale", - "effect": "Il Pokémon si schianta sul bersaglio con tutte le forze. La sua Difesa e la sua Difesa Speciale diminuiscono." - }, - "barbBarrage": { - "name": "Mille Fielespine", - "effect": "Il bersaglio viene colpito da una miriade di spine tossiche che possono anche avvelenarlo. Se il bersaglio è già avvelenato, la potenza della mossa raddoppia." - }, - "esperWing": { - "name": "Ali d'Aura", - "effect": "Il Pokémon falcia il bersaglio con ali rafforzate da un'aura. Probabile brutto colpo. Inoltre, la Velocità aumenta." - }, - "bitterMalice": { - "name": "Livore", - "effect": "Il Pokémon attacca con una furia che fa raggelare il sangue nelle vene del bersaglio, riducendone l'Attacco." - }, - "shelter": { - "name": "Barricata", - "effect": "Il Pokémon indurisce la propria pelle come uno scudo di ferro, aumentando di molto la Difesa." - }, - "tripleArrows": { - "name": "Triplodardo", - "effect": "Il Pokémon sferra un calcio per poi scoccare tre dardi insieme. Può ridurre la Difesa del bersaglio o farlo tentennare. Probabile brutto colpo." - }, - "infernalParade": { - "name": "Corteo Spettrale", - "effect": "Il Pokémon attacca con innumerevoli sfere di fuoco che possono anche scottare il bersaglio. Se questo è affetto da problemi di stato, la potenza della mossa raddoppia." - }, - "ceaselessEdge": { - "name": "Lama Milleflutti", - "effect": "Il Pokémon attacca il bersaglio con la spada conchiglia. I frammenti di conchiglie formano una trappola di punte ai piedi del bersaglio." - }, - "bleakwindStorm": { - "name": "Tempesta Boreale", - "effect": "Il Pokémon attacca il bersaglio con venti gelidi e sferzanti che lo fanno tremare anima e corpo. Può anche ridurne la Velocità." - }, - "wildboltStorm": { - "name": "Tempesta Tonante", - "effect": "Il Pokémon chiama a sé una tempesta di fulmini e raffiche di vento con cui attacca violentemente il bersaglio. Può anche paralizzarlo." - }, - "sandsearStorm": { - "name": "Tempesta Ardente", - "effect": "Il Pokémon attacca il bersaglio avvolgendolo con sabbia ardente e un vento fortissimo che possono scottarlo." - }, - "lunarBlessing": { - "name": "Invocaluna", - "effect": "\tIl Pokémon rivolge una preghiera alla luna crescente, ripristinando i PS e curando i problemi di stato per sé e per gli alleati in campo." - }, - "takeHeart": { - "name": "Baldimpulso", - "effect": "Il Pokémon prende coraggio e guarisce dai problemi di stato. Inoltre, aumenta l'Attacco Speciale e la Difesa Speciale." - }, - "gMaxWildfire": { - "name": "Gigavampa", - "effect": "Attacco di tipo Fuoco eseguito da Charizard Gigamax. Infligge danni per quattro turni." - }, - "gMaxBefuddle": { - "name": "Gigastupore", - "effect": "Attacco di tipo Coleottero eseguito da Butterfree Gigamax. Avvelena, paralizza o addormenta i nemici." - }, - "gMaxVoltCrash": { - "name": "Gigapikafolgori", - "effect": "Attacco di tipo Elettro eseguito da Pikachu Gigamax. Paralizza i nemici." - }, - "gMaxGoldRush": { - "name": "Gigamonete", - "effect": "Attacco di tipo Normale eseguito da Meowth Gigamax. Confonde i nemici e permette anche di ricevere una ricompensa maggiore." - }, - "gMaxChiStrike": { - "name": "Gigapugnointuito", - "effect": "Attacco di tipo Lotta eseguito da Machamp Gigamax. Aumenta la probabilità di sferrare brutti colpi." - }, - "gMaxTerror": { - "name": "Gigaillusione", - "effect": "Attacco di tipo Spettro eseguito da Gengar Gigamax. Il Pokémon calpesta l'ombra del nemico impedendogli la fuga o la sostituzione." - }, - "gMaxResonance": { - "name": "Gigamelodia", - "effect": "Attacco di tipo Ghiaccio eseguito da Lapras Gigamax. Riduce i danni subiti per cinque turni." - }, - "gMaxCuddle": { - "name": "Gigabbraccio", - "effect": "Attacco di tipo Normale eseguito da Eevee Gigamax. Fa infatuare i nemici." - }, - "gMaxReplenish": { - "name": "Gigarinnovamento", - "effect": "Attacco di tipo Normale eseguito da Snorlax Gigamax. Rigenera le bacche mangiate." - }, - "gMaxMalodor": { - "name": "Gigafetore", - "effect": "Attacco di tipo Veleno eseguito da Garbodor Gigamax. Avvelena i nemici." - }, - "gMaxStonesurge": { - "name": "Gigarocciagetto", - "effect": "Attacco di tipo Acqua eseguito da Drednaw Gigamax. Sparge rocce aguzze sul campo di lotta." - }, - "gMaxWindRage": { - "name": "Gigaciclone", - "effect": "Attacco di tipo Volante eseguito da Corviknight Gigamax. Annulla l'effetto di mosse come Riflesso e Schermoluce." - }, - "gMaxStunShock": { - "name": "Gigatoxiscossa", - "effect": "Attacco di tipo Elettro eseguito da Toxtricity Gigamax. Avvelena o paralizza i nemici." - }, - "gMaxFinale": { - "name": "Gigagranfinale", - "effect": "Attacco di tipo Folletto eseguito da Alcremie Gigamax. Fa recuperare PS agli alleati." - }, - "gMaxDepletion": { - "name": "Gigalogoramento", - "effect": "Attacco di tipo Drago eseguito da Duraludon Gigamax. Toglie PP all'ultima mossa usata dai nemici." - }, - "gMaxGravitas": { - "name": "Gigagravitoforza", - "effect": "Attacco di tipo Psico eseguito da Orbeetle Gigamax. Cambia la gravità per cinque turni." - }, - "gMaxVolcalith": { - "name": "Gigalapilli", - "effect": "Attacco di tipo Roccia eseguito da Coalossal Gigamax. Infligge danni per quattro turni." - }, - "gMaxSandblast": { - "name": "Gigavortisabbia", - "effect": "Attacco di tipo Terra eseguito da Sandaconda Gigamax. Scatena un turbine di sabbia per quattro o cinque turni." - }, - "gMaxSnooze": { - "name": "Gigatorpore", - "effect": "Attacco di tipo Buio eseguito da Grimmsnarl Gigamax. Chi la usa fa un grande sbadiglio che fa addormentare il nemico al turno successivo." - }, - "gMaxTartness": { - "name": "Gigattaccoacido", - "effect": "Attacco di tipo Erba eseguito da Flapple Gigamax. Riduce l’elusione dei nemici." - }, - "gMaxSweetness": { - "name": "Gigambrosia", - "effect": "Attacco di tipo Erba eseguito da Appletun Gigamax. Cura i problemi di stato degli alleati." - }, - "gMaxSmite": { - "name": "Gigacastigo", - "effect": "Attacco di tipo Folletto eseguito da Hatterene Gigamax. Confonde i nemici." - }, - "gMaxSteelsurge": { - "name": "Gigaferroaculei", - "effect": "Attacco di tipo Acciaio eseguito da Copperajah Gigamax. Sparge pezzi di metallo acuminati sul campo di lotta." - }, - "gMaxMeltdown": { - "name": "Gigaliquefazione", - "effect": "ERAttacco di tipo Acciaio eseguito da Melmetal Gigamax. Impedisce ai nemici di usare la stessa mossa due volte di seguito.RORE" - }, - "gMaxFoamBurst": { - "name": "Gigaschiuma", - "effect": "Attacco di tipo Acqua eseguito da Kingler Gigamax. Riduce di molto la Velocità dei nemici." - }, - "gMaxCentiferno": { - "name": "Gigamillefiamme", - "effect": "Attacco di tipo Fuoco eseguito da Centiskorch Gigamax. Intrappola i nemici nelle fiamme per quattro o cinque turni." - }, - "gMaxVineLash": { - "name": "Gigasferzata", - "effect": "Attacco di tipo Erba eseguito da Venusaur Gigamax. Infligge danni per quattro turni." - }, - "gMaxCannonade": { - "name": "Gigacannonata", - "effect": "Attacco di tipo Acqua eseguito da Blastoise Gigamax. Infligge danni per quattro turni." - }, - "gMaxDrumSolo": { - "name": "Gigarullio", - "effect": "Attacco di tipo Erba eseguito da Rillaboom Gigamax. Ignora le abilità dei nemici." - }, - "gMaxFireball": { - "name": "Gigafiammopalla", - "effect": "Attacco di tipo Fuoco eseguito da Cinderace Gigamax. Ignora le abilità dei nemici." - }, - "gMaxHydrosnipe": { - "name": "Gigasparomirato", - "effect": "Attacco di tipo Acqua eseguito da Inteleon Gigamax. Ignora le abilità dei nemici." - }, - "gMaxOneBlow": { - "name": "Gigasingolcolpo", - "effect": "Attacco di tipo Buio eseguito da Urshifu Gigamax che ignora gli effetti della Dynabarriera." - }, - "gMaxRapidFlow": { - "name": "Gigapluricolpo", - "effect": "\tAttacco di tipo Acqua eseguito da Urshifu Gigamax che ignora gli effetti della Dynabarriera." - }, - "teraBlast": { - "name": "Terascoppio", - "effect": "Se il Pokémon è teracristallizzato, attacca con l'energia del suo teratipo. Infligge danni in base all'Attacco o all'Attacco Speciale scegliendo il più alto tra i due." - }, - "silkTrap": { - "name": "Telatrappola", - "effect": "Il Pokémon tesse una trappola di tela che lo protegge dagli attacchi e riduce la Velocità di chi entra in contatto con lui." - }, - "axeKick": { - "name": "Calcio ad Ascia", - "effect": "Il Pokémon attacca sferrando un calcio dall'alto verso il basso che può confondere il bersaglio. Se la mossa fallisce, il Pokémon subisce dei danni." - }, - "lastRespects": { - "name": "Omaggio ai KO", - "effect": "Il Pokémon attacca per placare il risentimento dei suoi compagni di squadra. Più sono quelli andati KO, più la potenza della mossa aumenta." - }, - "luminaCrash": { - "name": "Fotocollisione", - "effect": "Il Pokémon attacca sparando una luce bizzarra che agisce anche sulla psiche. Riduce di molto la Difesa Speciale del bersaglio." - }, - "orderUp": { - "name": "Alta Cucina", - "effect": "Il Pokémon attacca con deliziose movenze. Se ha in bocca un Tatsugiri, una sua statistica aumenta in base alla forma di quest'ultimo." - }, - "jetPunch": { - "name": "Pugnojet", - "effect": "Il Pokémon avvolge il pugno in una corrente impetuosa e sferra un colpo a una tale velocità da rendersi quasi invisibile. Questo attacco ha priorità alta." - }, - "spicyExtract": { - "name": "Essenza Piccante", - "effect": "Il Pokémon secerne un'essenza straordinariamente piccante. Aumenta di molto l'Attacco del bersaglio ma ne diminuisce di molto la Difesa." - }, - "spinOut": { - "name": "Slittaruote", - "effect": "Il Pokémon infligge danni caricando le estremità e ruotandole vorticosamente. La sua Velocità diminuisce di molto." - }, - "populationBomb": { - "name": "Infestazione", - "effect": "Il Pokémon si riunisce con i suoi simili in un gruppo brulicante che collabora per attaccare e colpisce da una a dieci volte di fila." - }, - "iceSpinner": { - "name": "Vortighiaccio", - "effect": "Il Pokémon avvolge gli arti inferiori in un sottile strato di ghiaccio e si scontra con il bersaglio piroettando. Il movimento rotatorio distrugge il terreno di lotta." - }, - "glaiveRush": { - "name": "Spadoncarica", - "effect": "Il Pokémon si lancia in una carica avventata. Fino al suo prossimo turno, il Pokémon riceverà il doppio dei danni dagli attacchi altrui, che andranno sempre a segno." - }, - "revivalBlessing": { - "name": "Preghiera Vitale", - "effect": "Il Pokémon intona una preghiera compassionevole, rianimando un Pokémon della squadra esausto e restituendogli metà dei suoi PS." - }, - "saltCure": { - "name": "Sotto Sale", - "effect": "Il Pokémon mette sotto sale il bersaglio, infliggendogli danni a ogni turno. I Pokémon di tipo Acciaio e di tipo Acqua sono particolarmente vulnerabili a questa mossa." - }, - "tripleDive": { - "name": "Triplo Tuffo", - "effect": "Il Pokémon si lancia in un triplo tuffo perfettamente coordinato, colpendo il bersaglio con degli schizzi d'acqua e infliggendogli danni tre volte di fila." - }, - "mortalSpin": { - "name": "Glitturbine", - "effect": "Attacco rotante che elimina gli effetti di mosse come Legatutto, Avvolgibotta e Parassiseme. Aumenta anche la Velocità di chi la usa." - }, - "doodle": { - "name": "Ricalco", - "effect": "Il Pokémon cattura l'essenza del bersaglio con un ricalco, copiandone l'abilità e applicandola a se stesso e ai suoi alleati." - }, - "filletAway": { - "name": "Alleggerimento", - "effect": "Il Pokémon sacrifica dei PS per far aumentare di molto l'Attacco, l'Attacco Speciale e la Velocità." - }, - "kowtowCleave": { - "name": "Genufendente", - "effect": "Il Pokémon si genuflette per far abbassare la guardia al bersaglio e poi fenderlo. Questo attacco va sempre a segno." - }, - "flowerTrick": { - "name": "Prestigiafiore", - "effect": "\tIl Pokémon attacca il bersaglio lanciandogli addosso un mazzo di fiori truccato. Questo attacco va sempre a segno, infliggendo anche un brutto colpo." - }, - "torchSong": { - "name": "Canzone Ardente", - "effect": "Il Pokémon abbrustolisce il bersaglio soffiandogli addosso fiamme ardenti come se intonasse una canzone. Inoltre, il suo Attacco Speciale aumenta." - }, - "aquaStep": { - "name": "Idroballetto", - "effect": "Il Pokémon si prende gioco del bersaglio con passi di danza leggiadri e fluidi come l’acqua, infliggendogli danni. Inoltre, la sua Velocità aumenta." - }, - "ragingBull": { - "name": "Scatenatoro", - "effect": "Il Pokémon carica il bersaglio con furia cieca, rompendo barriere come Schermoluce e Riflesso. Il tipo di questa mossa dipende dalla forma di chi la usa." - }, - "makeItRain": { - "name": "Corsa all'Oro", - "effect": "Il Pokémon attacca lanciando una gran quantità di monete recuperabili dopo la lotta, ma riduce il proprio Attacco Speciale." - }, - "psyblade": { - "name": "Psicolama", - "effect": "Il Pokémon falcia il bersaglio con una lama eterea. La potenza della mossa aumenta del 50% quando è attivo un Campo Elettrico." - }, - "hydroSteam": { - "name": "Idrovapore", - "effect": "Il Pokémon ricopre con forza il bersaglio di acqua bollente. Con la luce solare intensa, la potenza di questa mossa aumenta del 50% anziché diminuire." - }, - "ruination": { - "name": "Catastrofe", - "effect": "Il Pokémon invoca una terribile disgrazia, dimezzando i PS del bersaglio." - }, - "collisionCourse": { - "name": "Turboschianto", - "effect": "Il Pokémon si schianta al suolo mentre si trasforma, causando un'esplosione primordiale. La potenza della mossa aumenta se questa è superefficace sul bersaglio." - }, - "electroDrift": { - "name": "Fulmiscatto", - "effect": "Il Pokémon saetta mentre si trasforma, trafiggendo il bersaglio con una scossa futuristica. La potenza della mossa aumenta se questa è superefficace sul bersaglio." - }, - "shedTail": { - "name": "Tagliacoda", - "effect": "Chi la usa crea una copia di se stesso usando parte dei suoi PS e si fa sostituire da un altro Pokémon della squadra." - }, - "chillyReception": { - "name": "Freddura", - "effect": "Chi la usa dice una freddura che fa raggelare i presenti per poi farsi sostituire da un altro Pokémon della squadra. Causa una nevicata che dura per cinque turni." - }, - "tidyUp": { - "name": "Pulizie", - "effect": "Il Pokémon fa le pulizie, annullando gli effetti di Punte, Levitoroccia, Rete Vischiosa, Fielepunte e Sostituto. Inoltre, aumenta il suo Attacco e la sua Velocità." - }, - "snowscape": { - "name": "Vista Innevata", - "effect": "Il Pokémon causa una nevicata che dura per cinque turni e aumenta la Difesa dei Pokémon di tipo Ghiaccio." - }, - "pounce": { - "name": "Balzo", - "effect": "Il Pokémon fa un balzo e attacca il bersaglio, riducendone inoltre la Velocità." - }, - "trailblaze": { - "name": "Apripista", - "effect": "Il Pokémon attacca come se saltasse fuori dall'erba alta e si muove con passo leggiadro, aumentando la propria Velocità." - }, - "chillingWater": { - "name": "Doccia Fredda", - "effect": "Il Pokémon attacca il bersaglio con una doccia d'acqua talmente fredda da farlo demoralizzare, riducendone l'Attacco." - }, - "hyperDrill": { - "name": "Ipertrapano", - "effect": "Il Pokémon fa roteare rapidamente la parte appuntita del suo corpo, perforando il bersaglio ed eludendo mosse come Protezione e Individua." - }, - "twinBeam": { - "name": "Doppioraggio", - "effect": "Il Pokémon attacca il bersaglio con misteriosi raggi di luce emessi dagli occhi che infliggono danni due volte di fila." - }, - "rageFist": { - "name": "Pugno Furibondo", - "effect": "Il Pokémon trasforma la sua furia in energia e la utilizza per attaccare. Più attacchi ha subito il Pokémon, più la potenza della mossa aumenta." - }, - "armorCannon": { - "name": "Corazza Cannone", - "effect": "Il Pokémon si libera della sua corazza, scagliandola sul bersaglio come una raffica di proiettili incandescenti. La sua Difesa e la sua Difesa Speciale diminuiscono." - }, - "bitterBlade": { - "name": "Lama del Rimorso", - "effect": "Il Pokémon concentra nelle lame tutti i rimorsi accumulati nel mondo dei vivi e assale il bersaglio, recuperando una quantità di PS pari a metà del danno inflitto." - }, - "doubleShock": { - "name": "Doppiolampo", - "effect": "Il Pokémon libera tutta la sua potenza elettrica per infliggere gravi danni al bersaglio, ma come conseguenza perde il tipo Elettro." - }, - "gigatonHammer": { - "name": "Granmartello", - "effect": "Chi la usa attacca il bersaglio brandendo un enorme martello. La mossa non può essere usata per due volte di fila." - }, - "comeuppance": { - "name": "Ritorsione", - "effect": "Il Pokémon restituisce con gli interessi i danni subiti all'ultimo avversario che l'ha colpito." - }, - "aquaCutter": { - "name": "Idrotaglio", - "effect": "\tIl Pokémon espelle acqua ad alta pressione e falcia il bersaglio con un fendente tagliente quanto una lama. Probabile brutto colpo." - }, - "blazingTorque": { - "name": "Turboustione", - "effect": "L'utilizzatore accende il suo motore ardente verso il bersaglio. Ciò potrebbe anche lasciare il bersaglio con una bruciatura." - }, - "wickedTorque": { - "name": "Turbotenebra", - "effect": "L'utente accende il proprio motore nel bersaglio con intenti dannosi. Ciò potrebbe addormentare il bersaglio." - }, - "noxiousTorque": { - "name": "Turbotossina", - "effect": "L'utilizzatore fa girare il suo motore velenoso verso il bersaglio. Ciò potrebbe anche avvelenare il bersaglio." - }, - "combatTorque": { - "name": "Turborissa", - "effect": "L'utente accelera con forza il proprio motore verso il bersaglio. Ciò potrebbe anche lasciare il bersaglio paralizzato." - }, - "magicalTorque": { - "name": "Turboincanto", - "effect": "L'utilizzatore fa girare il proprio motore fatato verso il bersaglio. Ciò potrebbe anche confondere l'obiettivo." - }, - "bloodMoon": { - "name": "Luna Rossa", - "effect": "Il Pokémon attacca rilasciando tutta la sua energia, confluita in una luna piena rossa come il sangue. Questa mossa non può essere usata due volte di fila." - }, - "matchaGotcha": { - "name": "Spruzzatè", - "effect": "Il Pokémon attacca mescolando del tè e spruzzandolo, recuperando una quantità di PS pari alla metà del danno inflitto. Può anche scottare il bersaglio." - }, - "syrupBomb": { - "name": "Bomba Sciroppata", - "effect": "\tIl Pokémon fa esplodere dello sciroppo viscoso sul bersaglio, ricoprendolo e facendogli diminuire la Velocità per tre turni." - }, - "ivyCudgel": { - "name": "Clava di Liane", - "effect": "Il Pokémon colpisce con una clava avvolta da liane. Il tipo della mossa varia in base alla maschera indossata. Probabile brutto colpo." - }, - "electroShot": { - "name": "Elettroraggio", - "effect": "Il Pokémon accumula elettricità e aumenta l'Attacco Speciale al primo turno, per poi rilasciare una potente scarica al turno successivo o, se piove, immediatamente." - }, - "teraStarstorm": { - "name": "Teracluster", - "effect": "Il Pokémon elimina il bersaglio irradiando il potere dei cristalli. Se Terapagos assume la Forma Astrale, la mossa infligge danni a tutti gli avversari." - }, - "fickleBeam": { - "name": "Irregolaser", - "effect": "Il Pokémon attacca rilasciando raggi di luce. Talvolta i laser vengono emessi da tutte le teste, contribuendo a raddoppiare la potenza della mossa." - }, - "burningBulwark": { - "name": "Egida Ignea", - "effect": "Il Pokémon blocca gli attacchi avversari con la pelliccia incandescente che scotta chi entra in contatto con lui." - }, - "thunderclap": { - "name": "Saetta", - "effect": "Il Pokémon abbatte una scarica elettrica sul bersaglio prima che questi possa attaccare. La mossa fallisce se il bersaglio sferra una mossa che non è di attacco." - }, - "mightyCleave": { - "name": "Taglio Poderoso", - "effect": "Il Pokémon fende il bersaglio con la luce immagazzinata nella testa, ignorando gli effetti delle mosse protettive." - }, - "tachyonCutter": { - "name": "Tachiontaglio", - "effect": "Il Pokémon emette delle lame particellari in successione, infliggendo danni due volte di fila. Questo attacco va sempre a segno." - }, - "hardPress": { - "name": "Pressa d'Acciaio", - "effect": "Il Pokémon schiaccia il bersaglio usando i propri arti. Più PS rimangono al bersaglio, maggiore è la potenza della mossa." - }, - "dragonCheer": { - "name": "Grido del Drago", - "effect": "Il Pokémon incita gli alleati con un inno ai draghi, aumentando la probabilità che sferrino brutti colpi. Particolarmente efficace con alleati di tipo Drago." - }, - "alluringVoice": { - "name": "Ammaliavoce", - "effect": "Il Pokémon attacca sfruttando il suo canto angelico, confondendo il bersaglio se le sue statistiche sono aumentate nello stesso turno." - }, - "temperFlare": { - "name": "Rabbia Bruciante", - "effect": "Il Pokémon attacca con l'impeto di chi è pronto a tutto. Se la mossa usata al turno precedente non è andata a segno, la potenza raddoppia." - }, - "supercellSlam": { - "name": "Elettrotuffo", - "effect": "Il Pokémon si schianta sul bersaglio dopo essersi elettrificato. Se la mossa fallisce, il Pokémon subisce dei danni." - }, - "psychicNoise": { - "name": "Psicorumore", - "effect": "\tl Pokémon investe il bersaglio con insopportabili onde sonore che gli impediscono di recuperare PS con mosse, abilità o strumenti che ha con sé per due turni." - }, - "upperHand": { - "name": "Colpo di Mano", - "effect": "Il Pokémon reagisce al movimento del bersaglio e, colpendo con il palmo, lo fa tentennare. Se il bersaglio non sferra un attacco ad alta priorità, la mossa fallisce." - }, - "malignantChain": { - "name": "Intossicatena", - "effect": "Il Pokémon logora il bersaglio avvolgendolo con le sue catene fatte di veleno e iniettandogli delle tossine che possono anche iperavvelenarlo." - } -} diff --git a/src/locales/it/nature.json b/src/locales/it/nature.json deleted file mode 100644 index 92b64acb3ab..00000000000 --- a/src/locales/it/nature.json +++ /dev/null @@ -1,27 +0,0 @@ -{ - "Hardy": "Ardita", - "Lonely": "Schiva", - "Brave": "Audace", - "Adamant": "Decisa", - "Naughty": "Birbona", - "Bold": "Sicura", - "Docile": "Docile", - "Relaxed": "Placida", - "Impish": "Scaltra", - "Lax": "Fiacca", - "Timid": "Timida", - "Hasty": "Lesta", - "Serious": "Seria", - "Jolly": "Allegra", - "Naive": "Ingenua", - "Modest": "Modesta", - "Mild": "Mite", - "Quiet": "Quieta", - "Bashful": "Ritrosa", - "Rash": "Ardente", - "Calm": "Calma", - "Gentle": "Gentile", - "Sassy": "Vivace", - "Careful": "Cauta", - "Quirky": "Furba" -} \ No newline at end of file diff --git a/src/locales/it/party-ui-handler.json b/src/locales/it/party-ui-handler.json deleted file mode 100644 index 95466779727..00000000000 --- a/src/locales/it/party-ui-handler.json +++ /dev/null @@ -1,47 +0,0 @@ -{ - "SEND_OUT": "Manda in campo", - "SUMMARY": "Sommario", - "CANCEL": "Annulla", - "RELEASE": "Rilascia", - "APPLY": "Applica", - "TEACH": "Insegna", - "SPLICE": "Unisci", - "UNSPLICE": "Dividi", - "ACTIVATE": "Attiva", - "DEACTIVATE": "Disattiva", - "TRANSFER": "Trasferisci", - "ALL": "Tutto", - "PASS_BATON": "Staffetta", - "UNPAUSE_EVOLUTION": "Consenti evoluzione", - "REVIVE": "Revitalizza", - "RENAME": "Rinomina", - "choosePokemon": "Scegli un Pokémon.", - "doWhatWithThisPokemon": "Hai selezionato questo Pokémon.", - "noEnergy": "{{pokemonName}} non ha più energie\nper lottare!", - "hasEnergy": "{{pokemonName}} ha ancora energie\nper lottare!", - "cantBeUsed": "{{pokemonName}} non può essere usato\nin questa sfida!", - "tooManyItems": "{{pokemonName}} possiede già\nquest'oggetto in abbondanza!", - "anyEffect": "Non avrebbe alcun effetto.", - "unpausedEvolutions": "{{pokemonName}} può di nuovo evolversi.", - "unspliceConfirmation": "Vuoi davvero dividere {{fusionName}}\nda {{pokemonName}}? {{fusionName}} andrà perduto.", - "wasReverted": "{{fusionName}} è tornato ad essere {{pokemonName}}.", - "releaseConfirmation": "Vuoi davvero liberare {{pokemonName}}?", - "releaseInBattle": "Non puoi liberare un Pokémon che sta combattendo!", - "selectAMove": "Scegli una mossa.", - "changeQuantity": "Scegli un oggetto da trasferire.\nUsa < e > per cambiarne la quantità.", - "selectAnotherPokemonToSplice": "Scegli un altro Pokémon da unire.", - "cancel": "Annulla", - "able": "Sì!", - "notAble": "No!", - "learned": "La conosce!", - "goodbye": "Addio, {{pokemonName}}!", - "byebye": "Ciao ciao, {{pokemonName}}!", - "farewell": "Arrivederci, {{pokemonName}}!", - "soLong": "È stato bello, {{pokemonName}}!", - "thisIsWhereWePart": "Le nostre strade si dividono, {{pokemonName}}!", - "illMissYou": "Mi mancherai, {{pokemonName}}!", - "illNeverForgetYou": "Non ti dimenticherò, {{pokemonName}}!", - "untilWeMeetAgain": "Alla prossima, {{pokemonName}}!", - "sayonara": "Sayonara, {{pokemonName}}!", - "smellYaLater": "Ci becchiamo, {{pokemonName}}!" -} diff --git a/src/locales/it/pokeball.json b/src/locales/it/pokeball.json deleted file mode 100644 index d63f0671906..00000000000 --- a/src/locales/it/pokeball.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "pokeBall": "Poké Ball", - "greatBall": "Mega Ball", - "ultraBall": "Ultra Ball", - "rogueBall": "Rogue Ball", - "masterBall": "Master Ball", - "luxuryBall": "Chic Ball" -} \ No newline at end of file diff --git a/src/locales/it/pokemon-form-battle.json b/src/locales/it/pokemon-form-battle.json deleted file mode 100644 index 3c9b36f8150..00000000000 --- a/src/locales/it/pokemon-form-battle.json +++ /dev/null @@ -1,14 +0,0 @@ -{ - "mega": "Mega {{pokemonName}}", - "mega-x": "Mega {{pokemonName}} X", - "mega-y": "Mega {{pokemonName}} Y", - "primal": "Archeo {{pokemonName}}", - "gigantamax": "GigaMax {{pokemonName}}", - "eternamax": "EternaMax {{pokemonName}}", - "megaChange": "{{preName}} si evolve\nin {{pokemonName}}!", - "gigantamaxChange": "{{preName}} si Gigamaxxizza\nin {{pokemonName}}!", - "eternamaxChange": "{{preName}} si Dynamaxxa infinitamente\nin {{pokemonName}}!", - "revertChange": "{{pokemonName}} è tornato\nalla sua forma originaria!", - "formChange": "{{preName}} ha cambiato forma!", - "disguiseChange": "Il costume ha assorbito l’attacco!" -} \ No newline at end of file diff --git a/src/locales/it/pokemon-form.json b/src/locales/it/pokemon-form.json deleted file mode 100644 index 505173e4c8a..00000000000 --- a/src/locales/it/pokemon-form.json +++ /dev/null @@ -1,170 +0,0 @@ -{ - "pikachuCosplay": "Cosplay", - "pikachuCoolCosplay": "Cosplay classe", - "pikachuBeautyCosplay": "Cosplay bellezza", - "pikachuCuteCosplay": "Cosplay grazie", - "pikachuSmartCosplay": "Cosplay acume", - "pikachuToughCosplay": "Cosplay grinta", - "pikachuPartner": "Compagno", - "eeveePartner": "Compagno", - "pichuSpiky": "Spunzorek", - "unownA": "A", - "unownB": "B", - "unownC": "C", - "unownD": "D", - "unownE": "E", - "unownF": "F", - "unownG": "G", - "unownH": "H", - "unownI": "I", - "unownJ": "J", - "unownK": "K", - "unownL": "L", - "unownM": "M", - "unownN": "N", - "unownO": "O", - "unownP": "P", - "unownQ": "Q", - "unownR": "R", - "unownS": "S", - "unownT": "T", - "unownU": "U", - "unownV": "V", - "unownW": "W", - "unownX": "X", - "unownY": "Y", - "unownZ": "Z", - "unownExclamation": "!", - "unownQuestion": "?", - "castformSunny": "Sole", - "castformRainy": "Pioggia", - "castformSnowy": "Nuvola di neve", - "deoxysNormal": "Normale", - "burmyPlant": "Pianta", - "burmySandy": "Sabbia", - "burmyTrash": "Scarti", - "shellosEast": "Est", - "shellosWest": "Ovest", - "rotomHeat": "Calore", - "rotomWash": "Lavaggio", - "rotomFrost": "Gelo", - "rotomFan": "Vortice", - "rotomMow": "Taglio", - "giratinaAltered": "Alterata", - "shayminLand": "Terra", - "basculinRedStriped": "Linearossa", - "basculinBlueStriped": "Lineablu", - "basculinWhiteStriped": "Lineabianca", - "deerlingSpring": "Primavera", - "deerlingSummer": "Estate", - "deerlingAutumn": "Autunno", - "deerlingWinter": "Inverno", - "tornadusIncarnate": "Incarnazione", - "thundurusIncarnate": "Incarnazione", - "landorusIncarnate": "Incarnazione", - "keldeoOrdinary": "Normale", - "meloettaAria": "Canto", - "meloettaPirouette": "Danza", - "froakieBattleBond": "Morfosintonia", - "scatterbugMeadow": "Giardinfiore", - "scatterbugIcySnow": "Nevi perenni", - "scatterbugPolar": "Nordico", - "scatterbugTundra": "Manto di neve", - "scatterbugContinental": "Continentale", - "scatterbugGarden": "Prato", - "scatterbugElegant": "Eleganza", - "scatterbugModern": "Trendy", - "scatterbugMarine": "Marino", - "scatterbugArchipelago": "Arcipelago", - "scatterbugHighPlains": "Deserto", - "scatterbugSandstorm": "Sabbia", - "scatterbugRiver": "Fluviale", - "scatterbugMonsoon": "Pluviale", - "scatterbugSavanna": "Savana", - "scatterbugSun": "Solare", - "scatterbugOcean": "Oceanico", - "scatterbugJungle": "Giungla", - "scatterbugFancy": "Sbarazzino", - "scatterbugPokeBall": "Poké Ball", - "flabebeRed": "Rosso", - "flabebeYellow": "Giallo", - "flabebeOrange": "Arancione", - "flabebeBlue": "Blu", - "flabebeWhite": "Bianco", - "furfrouHeart": "Cuore", - "furfrouStar": "Stella", - "furfrouDiamond": "Diamante", - "furfrouDebutante": "Signorina", - "furfrouMatron": "Gentildonna", - "furfrouDandy": "Gentiluomo", - "furfrouLaReine": "Regina", - "furfrouKabuki": "Kabuki", - "furfrouPharaoh": "Faraone", - "pumpkabooSmall": "Mini", - "pumpkabooLarge": "Grande", - "pumpkabooSuper": "Maxi", - "xerneasNeutral": "Relax", - "xerneasActive": "Attivo", - "zygarde50": "Forma 50%", - "zygarde10": "Forma 10%", - "zygarde50Pc": "Forma 50% Sciamefusione", - "zygarde10Pc": "Forma 10% Sciamefusione", - "zygardeComplete": "Forma perfetta", - "oricorioBaile": "Flamenco", - "oricorioPompom": "Cheerdance", - "oricorioPau": "Hula", - "oricorioSensu": "Buyō", - "rockruffOwnTempo": "Mentelocale", - "miniorRedMeteor": "Nucleo Rosso", - "miniorOrangeMeteor": "Nucleo Arancione", - "miniorYellowMeteor": "Nucleo Giallo", - "miniorGreenMeteor": "Nucleo Verde", - "miniorBlueMeteor": "Nucleo Azzurro", - "miniorIndigoMeteor": "Nucleo Indaco", - "miniorVioletMeteor": "Nucleo Violetto", - "miniorRed": "Rosso", - "miniorOrange": "Arancione", - "miniorYellow": "Giallo", - "miniorGreen": "Verde", - "miniorBlue": "Azzurro", - "miniorIndigo": "Indaco", - "miniorViolet": "Violetto", - "mimikyuDisguised": "Mascherata", - "mimikyuBusted": "Smascherata", - "magearnaOriginal": "Colore Antico", - "marshadowZenith": "Zenith", - "sinisteaPhony": "Contraffatta", - "sinisteaAntique": "Autentica", - "eiscueNoIce": "Liquefaccia", - "indeedeeMale": "Maschio", - "indeedeeFemale": "Femmina", - "morpekoFullBelly": "Panciapiena", - "zacianHeroOfManyBattles": "Eroe di Mille Lotte", - "zamazentaHeroOfManyBattles": "Eroe di Mille Lotte", - "zarudeDada": "Papà", - "enamorusIncarnate": "Incarnazione", - "squawkabillyGreenPlumage": "Piume Verdi", - "squawkabillyBluePlumage": "Piume Azzurre", - "squawkabillyYellowPlumage": "Piume Gialle", - "squawkabillyWhitePlumage": "Piume Bianche", - "tatsugiriCurly": "Arcuata", - "tatsugiriDroopy": "Adagiata", - "tatsugiriStretchy": "Tesa", - "gimmighoulChest": "Scrigno", - "gimmighoulRoaming": "Ambulante", - "koraidonApexBuild": "Foggia Integrale", - "koraidonLimitedBuild": "Foggia Parziale", - "koraidonSprintingBuild": "Foggia Scattante", - "koraidonSwimmingBuild": "Foggia Nautica", - "koraidonGlidingBuild": "Foggia Librata", - "miraidonUltimateMode": "Assetto Completo", - "miraidonLowPowerMode": "Assetto Limitato", - "miraidonDriveMode": "Assetto Sprint", - "miraidonAquaticMode": "Assetto Nuoto", - "miraidonGlideMode": "Assetto Planata", - "poltchageistCounterfeit": "Taroccata", - "poltchageistArtisan": "Pregiata", - "paldeaTaurosCombat": "Combattiva", - "paldeaTaurosBlaze": "Infuocata", - "paldeaTaurosAqua": "Acquatica" -} \ No newline at end of file diff --git a/src/locales/it/pokemon-info-container.json b/src/locales/it/pokemon-info-container.json deleted file mode 100644 index f3de9081ebc..00000000000 --- a/src/locales/it/pokemon-info-container.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "moveset": "Set di mosse", - "gender": "Genere:", - "ability": "Abilità:", - "nature": "Natura:", - "form": "Forma:" -} diff --git a/src/locales/it/pokemon-info.json b/src/locales/it/pokemon-info.json deleted file mode 100644 index 4b655dbe1ce..00000000000 --- a/src/locales/it/pokemon-info.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "Stat": { - "HP": "PS Max", - "HPshortened": "PS", - "ATK": "Attacco", - "ATKshortened": "Att", - "DEF": "Difesa", - "DEFshortened": "Dif", - "SPATK": "Att. Sp.", - "SPATKshortened": "AttSp", - "SPDEF": "Dif. Sp.", - "SPDEFshortened": "DifSp", - "SPD": "Velocità", - "SPDshortened": "Vel", - "ACC": "Precisione", - "EVA": "Elusione", - "HPStat": "PS" - }, - "Type": { - "UNKNOWN": "Sconosciuto", - "NORMAL": "Normale", - "FIGHTING": "Lotta", - "FLYING": "Volante", - "POISON": "Veleno", - "GROUND": "Terra", - "ROCK": "Roccia", - "BUG": "Coleottero", - "GHOST": "Spettro", - "STEEL": "Acciaio", - "FIRE": "Fuoco", - "WATER": "Acqua", - "GRASS": "Erba", - "ELECTRIC": "Elettro", - "PSYCHIC": "Psico", - "ICE": "Ghiaccio", - "DRAGON": "Drago", - "DARK": "Buio", - "FAIRY": "Folletto", - "STELLAR": "Astrale" - } -} diff --git a/src/locales/it/pokemon-summary.json b/src/locales/it/pokemon-summary.json deleted file mode 100644 index 81cd9a278b8..00000000000 --- a/src/locales/it/pokemon-summary.json +++ /dev/null @@ -1,17 +0,0 @@ -{ - "pokemonInfo": "Info Pokémon", - "status": "Stato", - "powerAccuracyCategory": "Potenza\nPrecisione\nCategoria", - "type": "Tipo", - "unknownTrainer": "Sconosciuto", - "ot": "AO", - "nature": "natura", - "expPoints": "Punti Esp.", - "nextLv": "Prossimo Lv.", - "cancel": "Annulla", - "memoString": "Natura {{natureFragment}},\n{{metFragment}}", - "metFragment": { - "normal": "incontrato al Lv.{{level}},\n{{biome}}, Onda {{wave}}.", - "apparently": "apparentemente incontrato al Lv.{{level}},\n{{biome}}." - } -} diff --git a/src/locales/it/pokemon.json b/src/locales/it/pokemon.json deleted file mode 100644 index dcc4cc7f310..00000000000 --- a/src/locales/it/pokemon.json +++ /dev/null @@ -1,23 +0,0 @@ -{ - "type_null": "Tipo Zero", - "great_tusk": "Grandizanne", - "scream_tail": "Codaurlante", - "brute_bonnet": "Fungofurioso", - "flutter_mane": "Crinealato", - "slither_wing": "Alirasenti", - "sandy_shocks": "Peldisabbia", - "iron_treads": "Solcoferreo", - "iron_bundle": "Saccoferreo", - "iron_hands": "Manoferrea", - "iron_jugulis": "Colloferreo", - "iron_moth": "Falenaferrea", - "iron_thorns": "Spineferree", - "roaring_moon": "Lunaruggente", - "iron_valiant": "Eroeferreo", - "walking_wake": "Acquecrespe", - "iron_leaves": "Fogliaferrea", - "gouging_fire": "Vampeaguzze", - "raging_bolt": "Furiatonante", - "iron_boulder": "Massoferreo", - "iron_crown": "Capoferreo" -} diff --git a/src/locales/it/run-history.json b/src/locales/it/run-history.json deleted file mode 100644 index 87f5a746303..00000000000 --- a/src/locales/it/run-history.json +++ /dev/null @@ -1,37 +0,0 @@ -{ - "victory": "Vittoria!", - "defeatedWild": "Sconfitto da ", - "defeatedTrainer": "Sconfitto da ", - "defeatedTrainerDouble": "Sconfitto dalla coppia ", - "defeatedRival": "Sconfitto dalla rivale", - "defeated": "Sconfitto", - "defeatedWild_female": "Sconfitta da ", - "defeatedTrainer_female": "Sconfitta da ", - "defeatedTrainerDouble_female": "Sconfitta dalla coppia ", - "defeatedRival_female": "Sconfitta dal rivale", - "defeated_female": "Sconfitta", - "luck": "Fortuna", - "score": "Punteggio", - "mode": "Modalità", - "challengeRules": "Regola/e", - "challengeMonoGen1": "1ª gen", - "challengeMonoGen2": "2ª gen", - "challengeMonoGen3": "3ª gen", - "challengeMonoGen4": "4ª gen", - "challengeMonoGen5": "5ª gen", - "challengeMonoGen6": "6ª gen", - "challengeMonoGen7": "7ª gen", - "challengeMonoGen8": "8ª gen", - "challengeMonoGen9": "9ª gen", - "playerItems": "Oggetti giocatore", - "personalBest": "Record personale!", - "SPDshortened": "Vel.", - "runInfo": "Info Run", - "money": "Patrimonio", - "runLength": "Durata Run", - "viewHeldItems": "Oggetti equip.", - "hallofFameText": "Benvenuto alla Sala d'Onore!", - "hallofFameText_female": "Benvenuto alla Sala d'Onore!", - "viewHallOfFame": "Vai alla Sala d'Onore!", - "viewEndingSplash": "Vai all'arte finale!" -} \ No newline at end of file diff --git a/src/locales/it/save-slot-select-ui-handler.json b/src/locales/it/save-slot-select-ui-handler.json deleted file mode 100644 index bd2f12003de..00000000000 --- a/src/locales/it/save-slot-select-ui-handler.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "overwriteData": "Sovrascrivere i dati nello slot selezionato?", - "loading": "Caricamento...", - "wave": "Onda", - "lv": "Lv", - "empty": "Vuoto" -} \ No newline at end of file diff --git a/src/locales/it/settings.json b/src/locales/it/settings.json deleted file mode 100644 index c09f5e22d4d..00000000000 --- a/src/locales/it/settings.json +++ /dev/null @@ -1,15 +0,0 @@ -{ - "boy": "Ragazzo", - "girl": "Ragazza", - "general": "Generale", - "uiVolume": "Volume UI ", - "gamepadSupport": "Supporto Gamepad", - "showBgmBar": "Mostra Nomi Musica", - "moveTouchControls": "Move Touch Controls", - "shopOverlayOpacity": "Opacità Finestra Negozio", - "shopCursorTarget": "Target Cursore Negozio", - "rewards": "Oggetti", - "reroll": "Rerolla", - "shop": "Negozio", - "checkTeam": "Squadra" -} diff --git a/src/locales/it/splash-messages.json b/src/locales/it/splash-messages.json deleted file mode 100644 index 55018d0ada0..00000000000 --- a/src/locales/it/splash-messages.json +++ /dev/null @@ -1,36 +0,0 @@ -{ - "battlesWon": "Battaglie Vinte!", - "joinTheDiscord": "Entra nel Discord!", - "infiniteLevels": "Livelli Infiniti!", - "everythingStacks": "Tutto si impila!", - "optionalSaveScumming": "Salvataggi Facoltativi!", - "biomes": "35 Biomi!", - "openSource": "Open Source!", - "playWithSpeed": "Gioca con la velocità aumentata di 5 volte!", - "liveBugTesting": "Test dei Bug in Tempo Reale!", - "heavyInfluence": "Influenzato da RoR2!", - "pokemonRiskAndPokemonRain": "Pokémon Risk e Pokémon Rain!", - "nowWithMoreSalt": "Adesso con il 33% di sale in più!", - "infiniteFusionAtHome": "Fusioni Infinite a Casa!", - "brokenEggMoves": "Mosse delle Uova Rotte!", - "magnificent": "Magnifico!", - "mubstitute": "Mubstitute!", - "thatsCrazy": "È Pazzesco!", - "oranceJuice": "Succo d'Arancia!", - "questionableBalancing": "Bilanciamento Discutibile!", - "coolShaders": "Shader fantastici!", - "aiFree": "Senza Intelligenza Artificiale!", - "suddenDifficultySpikes": "Picchi di Difficoltà Improvvisi!", - "basedOnAnUnfinishedFlashGame": "Basato su un Gioco Flash Incompiuto!", - "moreAddictiveThanIntended": "Crea Dipendeza più del Dovuto!", - "mostlyConsistentSeeds": "Seeds Consistenti!", - "achievementPointsDontDoAnything": "I Punti Obiettivo non Fanno Nulla!", - "youDoNotStartAtLevel": "Non Cominci dal Livello 2000!", - "dontTalkAboutTheManaphyEggIncident": "Non Parlare dell'Incidente dell'Uovo di Manaphy!", - "alsoTryPokengine": "Prova anche Pokéngine!", - "alsoTryEmeraldRogue": "Prova anche Emerald Rogue!", - "alsoTryRadicalRed": "Prova anche Radical Red!", - "eeveeExpo": "Eevee Expo!", - "ynoproject": "YNOproject!", - "breedersInSpace": "Allevapokémon nello spazio!" -} \ No newline at end of file diff --git a/src/locales/it/starter-select-ui-handler.json b/src/locales/it/starter-select-ui-handler.json deleted file mode 100644 index 04137993d33..00000000000 --- a/src/locales/it/starter-select-ui-handler.json +++ /dev/null @@ -1,45 +0,0 @@ -{ - "confirmStartTeam": "Vuoi iniziare con questi Pokémon?", - "confirmExit": "Vuoi tornare alla schermata principale?", - "invalidParty": "Questo squadra iniziale non è valida!", - "gen1": "1ª", - "gen2": "2ª", - "gen3": "3ª", - "gen4": "4ª", - "gen5": "5ª", - "gen6": "6ª", - "gen7": "7ª", - "gen8": "8ª", - "gen9": "9ª", - "growthRate": "Vel. Crescita:", - "ability": "Abilità:", - "passive": "Passiva:", - "nature": "Natura:", - "eggMoves": "Mosse da uova", - "addToParty": "Aggiungi al gruppo", - "removeFromParty": "Rimuovi dal gruppo", - "toggleIVs": "Vedi/Nascondi IV", - "manageMoves": "Gestisci mosse", - "manageNature": "Gestisci natura", - "addToFavorites": "Aggiungi ai preferiti", - "removeFromFavorites": "Rimuovi dai preferiti", - "useCandies": "Usa caramelle", - "selectNature": "Seleziona natura.", - "selectMoveSwapOut": "Seleziona una mossa da scambiare.", - "selectMoveSwapWith": "Seleziona una mossa da scambiare con", - "sameSpeciesEgg": "Compra un uovo", - "unlockPassive": "Sblocca passiva", - "reduceCost": "Riduci costo", - "cycleShiny": ": Shiny", - "cycleForm": ": Forma", - "cycleGender": ": Genere", - "cycleAbility": ": Abilità", - "cycleNature": ": Natura", - "cycleVariant": ": Variante", - "goFilter": ": Vai ai filtri", - "enablePassive": "Attiva passiva", - "disablePassive": "Disattiva passiva", - "locked": "Bloccato", - "disabled": "Disabilitato", - "uncaught": "Non catturato" -} \ No newline at end of file diff --git a/src/locales/it/status-effect.json b/src/locales/it/status-effect.json deleted file mode 100644 index 6270bbb10a5..00000000000 --- a/src/locales/it/status-effect.json +++ /dev/null @@ -1,11 +0,0 @@ -{ - "none": { - "name": "None", - "description": "", - "obtain": "", - "obtainSource": "", - "activation": "", - "overlap": "", - "heal": "" - } -} \ No newline at end of file diff --git a/src/locales/it/terrain.json b/src/locales/it/terrain.json deleted file mode 100644 index d0a584d74ab..00000000000 --- a/src/locales/it/terrain.json +++ /dev/null @@ -1,16 +0,0 @@ -{ - "misty": "Nebbioso", - "mistyStartMessage": "Ai piedi dei Pokémon si addensa la nebbia.", - "mistyClearMessage": "La nebbia si dissolve.", - "mistyBlockMessage": "Il Campo Nebbioso protegge {{pokemonNameWithAffix}}!", - "electric": "Elettrico", - "electricStartMessage": "Ai piedi dei Pokémon si accumula dell’elettricità.", - "electricClearMessage": "L’elettricità svanisce.", - "grassy": "Erboso", - "grassyStartMessage": "Ai piedi dei Pokémon cresce rigogliosa l’erba.", - "grassyClearMessage": "L’erba sparisce.", - "psychic": "Psichico", - "psychicStartMessage": "Nel campo si avverte una strana sensazione...", - "psychicClearMessage": "La strana sensazione nel campo è svanita!", - "defaultBlockMessage": "Il Campo {{terrainName}} protegge {{pokemonNameWithAffix}}!" -} diff --git a/src/locales/it/trainer-classes.json b/src/locales/it/trainer-classes.json deleted file mode 100644 index 205a7c59d42..00000000000 --- a/src/locales/it/trainer-classes.json +++ /dev/null @@ -1,130 +0,0 @@ -{ - "ace_trainer": "Fantallenatore", - "ace_trainer_female": "Fantallenatrice", - "ace_duo": "Fantallenatori", - "artist": "Artista", - "artist_female": "Artista", - "backers": "Fan", - "backpacker": "Giramondo", - "backpacker_female": "Giramondo", - "backpackers": "Giramondo", - "baker": "Panettiera", - "battle_girl": "Combat Girl", - "beauty": "Bellezza", - "beginners": "Novellini", - "biker": "Centauro", - "black_belt": "Cinturanera", - "breeder": "Allevapokémon", - "breeder_female": "Allevapokémon", - "breeders": "Allevapokémon", - "clerk": "Affarista", - "clerk_female": "Donna in carriera", - "colleagues": "Soci in affari", - "crush_kin": "Duo Lotta", - "cyclist": "Ciclista", - "cyclist_female": "Ciclista", - "cyclists": "Ciclisti", - "dancer": "Ballerino", - "dancer_female": "Ballerina", - "depot_agent": "Ferroviario", - "doctor": "Medico", - "doctor_female": "Medica", - "firebreather": "Mangiafuoco", - "fisherman": "Pescatore", - "fisherman_female": "Pescatrice", - "gentleman": "Gentiluomo", - "guitarist": "Chitarrista", - "guitarist_female": "Chitarrista", - "harlequin": "Buffone", - "hiker": "Montanaro", - "hooligans": "Teppisti", - "hoopster": "Cestista", - "infielder": "Battitore", - "janitor": "Netturbino", - "lady": "Lady", - "lass": "Pupa", - "linebacker": "Quarterback", - "maid": "Domestica", - "madame": "Madame", - "medical_team": "Équipe medica", - "musician": "Musicista", - "hex_maniac": "Streghetta", - "nurse": "Infermiera", - "nursery_aide": "Maestrina", - "officer": "Guardia", - "parasol_lady": "Ombrellina", - "pilot": "Pilota", - "pokéfan": "PokéFan", - "pokéfan_female": "PokéFan", - "pokéfan_family": "Famiglia PokéFan", - "preschooler": "Bimbo", - "preschooler_female": "Bimba", - "preschoolers": "Bimbi", - "psychic": "Sensitivo", - "psychic_female": "Sensitiva", - "psychics": "Sensitivi", - "pokémon_ranger": "Pokémon Ranger", - "pokémon_ranger_female": "Pokémon Ranger", - "pokémon_rangers": "Duo Ranger", - "ranger": "Ranger", - "restaurant_staff": "Personale del ristorante", - "rich": "Ricco", - "rich_female": "Ricca", - "rich_boy": "Elegantone", - "rich_couple": "Ricchi", - "rich_kid": "Bimbo ricco", - "rich_kid_female": "Bimba ricca", - "rich_kids": "Bimbi ricchi", - "roughneck": "Zuccapelata", - "sailor": "Marinaio", - "scientist": "Scienziato", - "scientist_female": "Scienziata", - "scientists": "Scienziati", - "smasher": "Tennista", - "snow_worker": "Lavoratore", - "snow_worker_female": "Lavoratrice", - "striker": "Calciatore", - "school_kid": "Alunno", - "school_kid_female": "Alunna", - "school_kids": "Alunni", - "swimmer": "Nuotatore", - "swimmer_female": "Nuotatrice", - "swimmers": "Nuotatori", - "twins": "Gemelli", - "veteran": "Veterano", - "veteran_female": "Veterana", - "veteran_duo": "Veterani", - "waiter": "Cameriere", - "waitress": "Cameriera", - "worker": "Operaio", - "worker_female": "Lavoratrice", - "workers": "Lavoratori", - "youngster": "Bullo", - "rocket_grunt": "Recluta Team Rocket", - "rocket_grunt_female": "Recluta Team Rocket", - "rocket_grunts": "Reclute Team Rocket", - "magma_grunt": "Recluta Team Magma", - "magma_grunt_female": "Recluta Team Magma", - "magma_grunts": "Reclute Team Magma", - "aqua_grunt": "Recluta Team Idro", - "aqua_grunt_female": "Recluta Team Idro", - "aqua_grunts": "Recluta Team Idro", - "galactic_grunt": "Recluta Team Galassia", - "galactic_grunt_female": "Recluta Team Galassia", - "galactic_grunts": "Reclute Team Galassia", - "plasma_grunt": "Seguace Plasma", - "plasma_grunt_female": "Seguace Plasma", - "plasma_grunts": "Seguaci Plasma", - "flare_grunt": "Recluta Team Flare", - "flare_grunt_female": "Recluta Team Flare", - "flare_grunts": "Reclute Team Flare", - "aether_grunt": "Dipendente (Fondazione Æther)", - "aether_grunt_female": "Dipendente (Fondazione Æther)", - "aether_grunts": "Dipendenti (Fondazione Æther)", - "skull_grunt": "Recluta Team Skull", - "skull_grunt_female": "Recluta Team Skull", - "skull_grunts": "Reclute Team Skull", - "macro_grunt": "Impiegato Macro Cosmos", - "macro_grunt_female": "Impiegata Macro Cosmos", - "macro_grunts": "Impiegati Macro Cosmos" -} diff --git a/src/locales/it/trainer-names.json b/src/locales/it/trainer-names.json deleted file mode 100644 index 6d1373c0bb3..00000000000 --- a/src/locales/it/trainer-names.json +++ /dev/null @@ -1,160 +0,0 @@ -{ - "brock": "Brock", - "misty": "Misty", - "lt_surge": "Lt. Surge", - "erika": "Erika", - "janine": "Nina", - "sabrina": "Sabrina", - "blaine": "Blaine", - "giovanni": "Giovanni", - "falkner": "Valerio", - "bugsy": "Raffaello", - "whitney": "Chiara", - "morty": "Angelo", - "chuck": "Furio", - "jasmine": "Jasmine", - "pryce": "Alfredo", - "clair": "Sandra", - "roxanne": "Petra", - "brawly": "Rudi", - "wattson": "Walter", - "flannery": "Fiammetta", - "norman": "Norman", - "winona": "Alice", - "tate": "Tell", - "liza": "Pat", - "juan": "Rodolfo", - "roark": "Pedro", - "gardenia": "Gardenia", - "maylene": "Marzia", - "crasher_wake": "Omar", - "fantina": "Fannie", - "byron": "Ferruccio", - "candice": "Bianca", - "volkner": "Corrado", - "cilan": "Spighetto", - "chili": "Chicco", - "cress": "Maisello", - "cheren": "Komor", - "lenora": "Aloé", - "roxie": "Velia", - "burgh": "Artemisio", - "elesa": "Camelia", - "clay": "Rafan", - "skyla": "Anemone", - "brycen": "Silvestro", - "drayden": "Aristide", - "marlon": "Ciprian", - "viola": "Violetta", - "grant": "Lino", - "korrina": "Ornella", - "ramos": "Amur", - "clemont": "Lem", - "valerie": "Valérie", - "olympia": "Astra", - "wulfric": "Edel", - "milo": "Yarrow", - "nessa": "Azzurra", - "kabu": "Kabu", - "bea": "Fabia", - "allister": "Onion", - "opal": "Poppy", - "bede": "Beet", - "gordie": "Milo", - "melony": "Melania", - "piers": "Ginepro", - "marnie": "Mary", - "raihan": "Raihan", - "katy": "Aceria", - "brassius": "Brassius", - "iono": "Kissara", - "kofu": "Algaro", - "larry": "Ubaldo", - "ryme": "Ryme", - "tulip": "Tulipa", - "grusha": "Grusha", - "lorelei": "Lorelei", - "bruno": "Bruno", - "agatha": "Agatha", - "lance": "Lance", - "will": "Pino", - "koga": "Koga", - "karen": "Karen", - "sidney": "Fosco", - "phoebe": "Ester", - "glacia": "Frida", - "drake": "Drake", - "aaron": "Aaron", - "bertha": "Terrie", - "flint": "Vulcano", - "lucian": "Luciano", - "shauntal": "Antemia", - "marshal": "Marzio", - "grimsley": "Mirton", - "caitlin": "Catlina", - "malva": "Malva", - "siebold": "Narciso", - "wikstrom": "Timeos", - "drasna": "Lila", - "hala": "Hala", - "molayne": "Tapso", - "olivia": "Olive", - "acerola": "Mapli", - "kahili": "Kahili", - "rika": "Rika", - "poppy": "Poppy", - "hassel": "Oranzio", - "crispin": "Piros", - "amarys": "Erin", - "lacey": "Rupi", - "drayton": "Aris", - "blue": "Blu", - "red": "Rosso", - "steven": "Rocco", - "wallace": "Adriano", - "cynthia": "Camilla", - "alder": "Nardo", - "iris": "Iris", - "diantha": "Diantha", - "hau": "Hau", - "geeta": "Alisma", - "nemona": "Nemi", - "kieran": "Riben", - "leon": "Dandel", - "rival": "Finn", - "rival_female": "Ivy", - "archer": "Archer", - "ariana": "Atena", - "proton": "Milas", - "petrel": "Maxus", - "tabitha": "Ottavio", - "courtney": "Rossella", - "shelly": "Ada", - "matt": "Alan", - "mars": "Martes", - "jupiter": "Giovia", - "saturn": "Saturno", - "zinzolin": "Violante", - "rood": "Ross", - "xerosic": "Xante", - "bryony": "Bromelia", - "faba": "Vicio", - - "maxie": "Max", - "archie": "Ivan", - "cyrus": "Cyrus", - "ghetsis": "Ghecis", - "lysandre": "Elisio", - "lusamine": "Samina", - "guzma": "Guzman", - "blue_red_double": "Blu & Rosso", - "red_blue_double": "Rosso & Blu", - "tate_liza_double": "Tell & Pat", - "liza_tate_double": "Pat & Tell", - "steven_wallace_double": "Rocco & Adriano", - "wallace_steven_double": "Adriano & Rocco", - "alder_iris_double": "Nardo & Iris", - "iris_alder_double": "Iris & Nardo", - "marnie_piers_double": "Mary & Ginepro", - "piers_marnie_double": "Ginepro & Mary" -} diff --git a/src/locales/it/trainer-titles.json b/src/locales/it/trainer-titles.json deleted file mode 100644 index eff152795cd..00000000000 --- a/src/locales/it/trainer-titles.json +++ /dev/null @@ -1,39 +0,0 @@ -{ - "elite_four": "Superquattro", - "elite_four_female": "Superquattro", - "gym_leader": "Capopalestra", - "gym_leader_female": "Capopalestra", - "gym_leader_double": "Duo Capopalestra", - "champion": "Campione", - "champion_female": "Campionessa", - "champion_double": "Duo Campioni", - "rival": "Rivale", - "professor": "Professore", - "frontier_brain": "Asso lotta", - "rocket_boss": "Capo Rocket", - "magma_boss": "Capo Magma", - "aqua_boss": "Capo Idro", - "galactic_boss": "Capo Galassia", - "plasma_boss": "Capo Plasma", - "flare_boss": "Capo Flare", - "aether_boss": "Direttrice Æther", - "skull_boss": "Capo Team Skull", - "macro_boss": "Presidente Macro Cosmos", - - "rocket_admin": "Tenente Team Rocket", - "rocket_admin_female": "Tenente Team Rocket", - "magma_admin": "Magmatenente", - "magma_admin_female": "Magmatenente", - "aqua_admin": "Idrotenente", - "aqua_admin_female": "Idrotenente", - "galactic_commander": "Comandante Galassia", - "galactic_commander_female": "Comandante Galassia", - "plasma_sage": "Saggio Team Plasma", - "plasma_admin": "Tenente Team Plasma", - "flare_admin": "Ufficiale Team Flare", - "flare_admin_female": "Ufficiale Team Flare", - "aether_admin": "Capo Filiale Æther", - "skull_admin": "Ufficiale Team Skull", - "macro_admin": "Vicepresidente Macro Cosmos" -} - diff --git a/src/locales/it/tutorial.json b/src/locales/it/tutorial.json deleted file mode 100644 index 6937d59408e..00000000000 --- a/src/locales/it/tutorial.json +++ /dev/null @@ -1,10 +0,0 @@ -{ - "intro": "Benvenuto in PokéRogue! Questo gioco si concentra sulle battaglie, con elementi roguelite.\n$Questo gioco non è monetizzato e non siamo proprietari di Pokémon ed assets presenti nel gioco.\n$Il progetto è work-in-progress, ma giocabile al 100%.\nPer segnalare eventuali bug è possibile contattarci al nostro apposito Discord.\n$Se il gioco risulta 'lento', assicurati di aver abilitato l'accelerazione hardware nelle impostazioni del tuo browser", - "accessMenu": "Per accedere al menu, premi M o esc.\nDal menu puoi modificare le impostazioni, controllare la wiki ed accedere a varie features.", - "menu": "Da questo menu puoi accedere alle impostazioni.\n$Esse ti permettono di cambiare velocità di gioco, stile delle finestre ed altre opzioni.\n$Ci sono varie funzionalità: controlla bene e non perderti nulla!", - "starterSelect": "Da questa schermata puoi selezionare il tuo starter.\nQuesti sono i membri iniziali della tua squadra.\n$Ogni starter ha un valore. Puoi avere fino a \n6 Pokèmon, avendo a disposizione un massimo di 10 punti.\n$Puoi anche selezionare genere, abilità, e forma a seconda delle\nvarianti che hai catturato o schiuso.\n$Le IVs di una specie sono le migliori rispetto a tutte quelle che hai\ncatturato o schiuso, quindi prova a catturarne il piu possibile!", - "pokerus": "Giornalmente 3 starter casuali disponibili avranno il bordo viola.\n$Se possiedi uno di questi starter,\nprova ad aggiungerlo alla squadra. Ricorda di controllarne le info!", - "statChange": "I cambiamenti alle statistiche persistono fintanto che i tuoi pokèmon restano in campo.\n$I tuoi pokemon verranno richiamati quando incontrerai un allenatore o al cambiamento di bioma.\n$Puoi anche vedere i cambiamenti alle statistiche in corso tenendo premuto C o Shift", - "selectItem": "Dopo ogni battaglia potrai scegliere tra 3 oggetti.\nPotrai prenderne solo uno.\n$Questi spaziano tra consumabili, oggetti tenuti da Pokèmon o con un effetto passivo permanente.\n$La maggior parte degli oggetti non consumabili possono accumulare i loro effetti in diversi modi.\n$Alcuni risulteranno inoltre disponibili solo se possono essere usati, come ad esempio gli oggetti evolutivi.\n$Puoi anche passare un oggetto tenuto da un Pokèmon a un altro attraverso l'opzione 'trasferisci strumento'.\n$Quest'ultima sarà disponibile solo dopo aver assegnato uno strumento ad un Pokèmon.\n$Puoi acquistare consumabili con le monete; progredendo saranno poi disponibili ulteriori oggetti.\n$Assicurati di fare un acquisto prima di selezionare un item casuale, poichè dopo aver fatto ciò passerai subito alla lotta successiva.", - "eggGacha": "Da questa schermata puoi riscattare i tuoi vouchers in cambio di\nuova Pokèmon.\n$Le uova vanno schiuse, e saranno sempre più vicine alla schiusura dopo\nogni battaglia. Le uova più rare impiegheranno più battaglie per la schiusura.\n$I Pokémon schiusi non verranno aggiunti alla tua squadra, ma saranno\ninvece aggiunti ai tuoi starters.\n$I Pokémon schiusi hanno (generalmente) IVs migliori rispetto ai\n Pokémon selvatici.\n$Inoltre, alcuni Pokémon possono essere ottenuti solo tramite uova.\n$Ci sono 3 diversi macchinari con differenti\nbonus, scegli quello che preferisci!" -} \ No newline at end of file diff --git a/src/locales/it/voucher.json b/src/locales/it/voucher.json deleted file mode 100644 index 296be55d223..00000000000 --- a/src/locales/it/voucher.json +++ /dev/null @@ -1,9 +0,0 @@ -{ - "vouchers": "Vouchers", - "eggVoucher": "Voucher uovo", - "eggVoucherPlus": "Voucher uovo plus", - "eggVoucherPremium": "Voucher uovo premium", - "eggVoucherGold": "Voucher uovo dorato", - "locked": "Bloccato", - "defeatTrainer": "Sconfiggi {{trainerName}}" -} \ No newline at end of file diff --git a/src/locales/it/weather.json b/src/locales/it/weather.json deleted file mode 100644 index 63e3c420917..00000000000 --- a/src/locales/it/weather.json +++ /dev/null @@ -1,32 +0,0 @@ -{ - "sunnyStartMessage": "La luce solare è intensa!", - "sunnyLapseMessage": "La luce solare è forte.", - "sunnyClearMessage": "La luce solare si sta attenuando.", - "rainStartMessage": "Ha iniziato a piovere!", - "rainLapseMessage": "La pioggia continua.", - "rainClearMessage": "Ha smesso di piovere.", - "sandstormStartMessage": "Si è scatenata una tempesta di sabbia!", - "sandstormLapseMessage": "La tempesta di sabbia infuria.", - "sandstormClearMessage": "La tempesta di sabbia si è placata.", - "sandstormDamageMessage": "{{pokemonNameWithAffix}} è stato colpito\ndalla tempesta di sabbia!", - "hailStartMessage": "Ha iniziato a grandinare!", - "hailLapseMessage": "La grandine continua a cadere.", - "hailClearMessage": "Ha smesso di grandinare.", - "hailDamageMessage": "{{pokemonNameWithAffix}} è stato colpito\ndalla grandine!", - "snowStartMessage": "Ha iniziato a nevicare!", - "snowLapseMessage": "La neve sta continuando a cadere.", - "snowClearMessage": "Ha smesso di nevicare!.", - "fogStartMessage": "È emersa una fitta nebbia!", - "fogLapseMessage": "La nebbia continua.", - "fogClearMessage": "La nebbia è scomparsa.", - "heavyRainStartMessage": "Ha iniziato a piovere forte!", - "heavyRainLapseMessage": "La pioggia battente continua.", - "heavyRainClearMessage": "La pioggia battente è cessata.", - "harshSunStartMessage": "La luce solare è molto intensa!", - "harshSunLapseMessage": "La luce solare è estremamente calda.", - "harshSunClearMessage": "La luce solare si sta attenuando.", - "strongWindsStartMessage": "È apparsa una corrente d'aria misteriosa!", - "strongWindsLapseMessage": "La corrente d'aria soffia intensamente.", - "strongWindsEffectMessage": "La corrente misteriosa indebolisce l’attacco!", - "strongWindsClearMessage": "La corrente d'aria è cessata." -} \ No newline at end of file diff --git a/src/locales/ja/ability-trigger.json b/src/locales/ja/ability-trigger.json deleted file mode 100644 index 26d27701aef..00000000000 --- a/src/locales/ja/ability-trigger.json +++ /dev/null @@ -1,64 +0,0 @@ -{ - "blockRecoilDamage": "{{pokemonName}}は {{abilityName}}で 反動ダメージを 受けない!", - "badDreams": "{{pokemonName}}は ナイトメアに うなされている!", - "costar": "{{pokemonName}}は {{allyName}}の\n能力変化を コピーした!", - "iceFaceAvoidedDamage": "{{pokemonNameWithAffix}}は\n{{abilityName}}で ダメージを 受けない!", - "perishBody": "{{pokemonName}}の {{abilityName}}で\nおたがいは 3ターン後に ほろびいてしまう!", - "poisonHeal": "{{pokemonName}}は {{abilityName}}で 回復した!", - "trace": "{{pokemonName}}は 相手の {{targetName}}の\n{{abilityName}}を トレースした!", - "windPowerCharged": "{{pokemonNameWithAffix}}は\n{{moveName}}を 受けて じゅうでんした!", - "quickDraw": "{{pokemonName}}は クイックドロウで\n行動が はやくなった!", - "disguiseAvoidedDamage": "{{pokemonNameWithAffix}}の\nばけのかわが はがれた!", - "blockItemTheft": "{{pokemonNameWithAffix}}の {{abilityName}}で\n道具を うばわれない!", - "typeImmunityHeal": "{{pokemonNameWithAffix}}は {{abilityName}}で\n体力を 回復した!", - "nonSuperEffectiveImmunity": "{{pokemonNameWithAffix}}は {{abilityName}}で\nダメージを 受けない。", - "fullHpResistType": "{{pokemonNameWithAffix}}は\n甲羅を かがやかせ タイプ相性を 歪める!", - "moveImmunity": "{{pokemonNameWithAffix}}には\n効果が ないようだ…", - "reverseDrain": "{{pokemonNameWithAffix}}は\nヘドロえきを 吸い取った!", - "postDefendTypeChange": "{{pokemonNameWithAffix}}は {{abilityName}}で\n{{typeName}}タイプに なった!", - "postDefendContactDamage": "{{pokemonNameWithAffix}}は {{abilityName}}で\n相手を キズつけた!", - "postDefendAbilitySwap": "{{pokemonNameWithAffix}}は\nおたがいの 特性を 入れ替えた!", - "postDefendAbilityGive": "{{pokemonNameWithAffix}}は\n特性が {{abilityName}}に なっちゃった!", - "postDefendMoveDisable": "{{pokemonNameWithAffix}}の\n{{moveName}}を 封じこめた!", - "pokemonTypeChange": "{{pokemonNameWithAffix}}は\n{{moveType}}タイプに なった!", - "postAttackStealHeldItem": "{{pokemonNameWithAffix}}は {{defenderName}}から\n{{stolenItemType}}を うばいとった!", - "postDefendStealHeldItem": "{{pokemonNameWithAffix}}は {{attackerName}}から\n{{stolenItemType}}を うばいとった!", - "copyFaintedAllyAbility": "{{pokemonNameWithAffix}}の\n{{abilityName}}を 引き継いだ!", - "intimidateImmunity": "{{pokemonNameWithAffix}}は\n{{abilityName}}の 効果で 能力が 下がらない!", - "postSummonAllyHeal": "{{pokemonNameWithAffix}}が たてた お茶を\n{{pokemonName}}は 飲みほした!", - "postSummonClearAllyStats": "{{pokemonNameWithAffix}}の\n能力変化が 元に戻った!", - "postSummonTransform": "{{pokemonNameWithAffix}}は\n{{targetName}}に 変身した!", - "protectStat": "{{pokemonNameWithAffix}}は {{abilityName}}の 効果で\n{{statName}}が 下がらない!", - "statusEffectImmunityWithName": "{{pokemonNameWithAffix}}は {{abilityName}}で\n{{statusEffectName}}に ならない!", - "statusEffectImmunity": "{{pokemonNameWithAffix}}は {{abilityName}}で\n状態異常に ならない!", - "battlerTagImmunity": "{{pokemonNameWithAffix}}は {{abilityName}}で]\n{{battlerTagName}}を 無視した!", - "forewarn": "{{pokemonNameWithAffix}}の\n{{moveName}}を 読み取った!", - "frisk": "{{pokemonNameWithAffix}}は {{opponentName}}の\n{{opponentAbilityName}}を お見通しだ!", - "postWeatherLapseHeal": "{{pokemonNameWithAffix}}は {{abilityName}}で\n体力を 回復した!", - "postWeatherLapseDamage": "{{pokemonNameWithAffix}}は\n{{abilityName}}の ダメージを 受けた!", - "postTurnLootCreateEatenBerry": "{{pokemonNameWithAffix}}は\n{{berryName}}を 収穫した!", - "postTurnHeal": "{{pokemonNameWithAffix}}は {{abilityName}}で\n体力を 回復した!", - "fetchBall": "{{pokemonNameWithAffix}}は\n{{pokeballName}}を 拾ってきた!", - "healFromBerryUse": "{{pokemonNameWithAffix}}は {{abilityName}}で\n体力を 回復した!", - "arenaTrap": "{{pokemonNameWithAffix}}の {{abilityName}}で\n入れ替えることが できない!", - "postBattleLoot": "{{pokemonNameWithAffix}}は\n{{itemName}}を 拾った!", - "postFaintContactDamage": "{{pokemonNameWithAffix}}は {{abilityName}}で\n相手に ダメージを 与えた!", - "postFaintHpDamage": "{{pokemonNameWithAffix}}は {{abilityName}}で\n相手に ダメージを 与えた!", - "postSummonPressure": "{{pokemonNameWithAffix}}は\nプレッシャーを 放っている!", - "weatherEffectDisappeared": "天候の影響が なくなった!", - "postSummonMoldBreaker": "{{pokemonNameWithAffix}}は\nかたやぶりだ!", - "postSummonAnticipation": "{{pokemonNameWithAffix}}は\nみぶるいした!", - "postSummonTurboblaze": "{{pokemonNameWithAffix}}は\n燃え盛(もえさか)る オーラを 放っている!", - "postSummonTeravolt": "{{pokemonNameWithAffix}}は\n弾(はじ)ける オーラを 放っている!", - "postSummonDarkAura": "{{pokemonNameWithAffix}}は\nダークオーラを 放っている!", - "postSummonFairyAura": "{{pokemonNameWithAffix}}は\nフェアリーオーラを 放っている!", - "postSummonAuraBreak": "{{pokemonNameWithAffix}}は\nすべての オーラを 制圧する!", - "postSummonNeutralizingGas": "あたりに かがくへんかガスが 充満した!", - "postSummonAsOneGlastrier": "{{pokemonNameWithAffix}}は\nふたつの 特性を あわせ持つ!", - "postSummonAsOneSpectrier": "{{pokemonNameWithAffix}}は\nふたつの 特性を あわせ持つ!", - "postSummonVesselOfRuin": "{{pokemonNameWithAffix}}の わざわいのうつわで\nまわりの {{statName}}が 弱まった!", - "postSummonSwordOfRuin": "{{pokemonNameWithAffix}}の わざわいのつるぎで\nまわりの {{statName}}が 弱まった!", - "postSummonTabletsOfRuin": "{{pokemonNameWithAffix}}の わざわいのおふだ\nまわりの {{statName}}が 弱まった!", - "postSummonBeadsOfRuin": "{{pokemonNameWithAffix}}の わざわいのたまで\nまわりの {{statName}}が 弱まった!", - "preventBerryUse": "{{pokemonNameWithAffix}}は 緊張して\nきのみが 食べられなくなった!" -} diff --git a/src/locales/ja/ability.json b/src/locales/ja/ability.json deleted file mode 100644 index c44eeb06234..00000000000 --- a/src/locales/ja/ability.json +++ /dev/null @@ -1,1242 +0,0 @@ -{ - "stench": { - "name": "あくしゅう", - "description": "臭い においを 放つことによって 攻撃した ときに 相手を ひるませることが ある。" - }, - "drizzle": { - "name": "あめふらし", - "description": "登場 したときに 天気を 雨に する。" - }, - "speedBoost": { - "name": "かそく", - "description": "毎ターン 素早さが 上がる。" - }, - "battleArmor": { - "name": "カブトアーマー", - "description": "硬い 甲羅に 守られて 相手の 攻撃が 急所に 当たらない。" - }, - "sturdy": { - "name": "がんじょう", - "description": "相手の 技を 受けても 一撃で 倒されることが ない。 一撃必殺技も 効かない。" - }, - "damp": { - "name": "しめりけ", - "description": "あたりを 湿らせることに よって じばく などの 爆発する 技を だれも 使えなくなる。" - }, - "limber": { - "name": "じゅうなん", - "description": "柔軟な 体によって まひ状態に ならない。" - }, - "sandVeil": { - "name": "すながくれ", - "description": "砂あらしの とき 回避率が 上がる。" - }, - "static": { - "name": "せいでんき", - "description": "静電気を 体に まとい 触った 相手を まひさせる ことがある。" - }, - "voltAbsorb": { - "name": "ちくでん", - "description": "でんきタイプの 技を 受けると ダメージを 受けずに 回復する。" - }, - "waterAbsorb": { - "name": "ちょすい", - "description": "みずタイプの 技を 受けると ダメージを 受けずに 回復する。" - }, - "oblivious": { - "name": "どんかん", - "description": "鈍感なので メロメロや ちょうはつ状態に ならない。" - }, - "cloudNine": { - "name": "ノーてんき", - "description": "あらゆる 天気の 影響が なくなって しまう。" - }, - "compoundEyes": { - "name": "ふくがん", - "description": "複眼を 持っているため 技の 命中率が 上がる。" - }, - "insomnia": { - "name": "ふみん", - "description": "眠れない 体質 なので ねむり状態に ならない。" - }, - "colorChange": { - "name": "へんしょく", - "description": "相手から 受けた 技の タイプに 自分の タイプが 変化 する。" - }, - "immunity": { - "name": "めんえき", - "description": "体内に 免疫を 持っているため どく状態に ならない。" - }, - "flashFire": { - "name": "もらいび", - "description": "ほのおタイプの 技を 受けると 炎を もらい 自分が 出す ほのおタイプの 技が 強くなる。" - }, - "shieldDust": { - "name": "りんぷん", - "description": "りんぷんに 守られて 技の 追加効果を 受けなくなる。" - }, - "ownTempo": { - "name": "マイペース", - "description": "マイペースなので こんらん状態に ならない。" - }, - "suctionCups": { - "name": "きゅうばん", - "description": "吸盤で 地面に 張り付き ポケモンを 入れ替えさせる 技や 道具が 効かなくなる。" - }, - "intimidate": { - "name": "いかく", - "description": "登場 したとき 威嚇して 相手を 萎縮させ 相手の 攻撃を 下げて しまう。" - }, - "shadowTag": { - "name": "かげふみ", - "description": "相手の 影を 踏み 逃げたり 交代 できなくする。" - }, - "roughSkin": { - "name": "さめはだ", - "description": "攻撃を 受けたとき 自分に 触れた 相手を ざらざらの 肌で キズつける。" - }, - "wonderGuard": { - "name": "ふしぎなまもり", - "description": "効果バツグンの 技しか 当たらない 不思議な 力。" - }, - "levitate": { - "name": "ふゆう", - "description": "地面から 浮くことによって じめんタイプの 技を 受けない。" - }, - "effectSpore": { - "name": "ほうし", - "description": "攻撃で 自分に 触れた 相手を どくや まひや ねむり状態に する ことがある。" - }, - "synchronize": { - "name": "シンクロ", - "description": "自分が なってしまった どくや まひや やけどを 相手に うつす。" - }, - "clearBody": { - "name": "クリアボディ", - "description": "相手の 技や 特性で 能力を 下げられない。" - }, - "naturalCure": { - "name": "しぜんかいふく", - "description": "手持ちに ひっこむと 状態異常が 治る。" - }, - "lightningRod": { - "name": "ひらいしん", - "description": "でんきタイプの 技を 自分に 寄せつけ ダメージを 受けずに 特攻が 上がる。" - }, - "sereneGrace": { - "name": "てんのめぐみ", - "description": "天の恵みの おかげで 技の 追加効果が でやすい。" - }, - "swiftSwim": { - "name": "すいすい", - "description": "天気が 雨のとき 素早さが 上がる。" - }, - "chlorophyll": { - "name": "ようりょくそ", - "description": "天気が 晴れのとき 素早さが 上がる。" - }, - "illuminate": { - "name": "はっこう", - "description": "あたりを 明るくすることで 命中率を 下げられない。" - }, - "trace": { - "name": "トレース", - "description": "登場 したとき 相手の 特性を トレースして 同じ 特性に なる。" - }, - "hugePower": { - "name": "ちからもち", - "description": "物理攻撃の 威力が 2倍になる。" - }, - "poisonPoint": { - "name": "どくのトゲ", - "description": "自分に 触った 相手を どく状態に することがある。" - }, - "innerFocus": { - "name": "せいしんりょく", - "description": "鍛えられた 精神に よって 相手の 攻撃に ひるまない。" - }, - "magmaArmor": { - "name": "マグマのよろい", - "description": "熱い マグマを 身にまとい こおり状態に ならない。" - }, - "waterVeil": { - "name": "みずのベール", - "description": "水のベールを 身にまとい やけど状態に ならない。" - }, - "magnetPull": { - "name": "じりょく", - "description": "はがねタイプの ポケモンを 磁力で 引きつけて 逃げられなくする。" - }, - "soundproof": { - "name": "ぼうおん", - "description": "音を 遮断 することに よって 音の 攻撃を 受けない。" - }, - "rainDish": { - "name": "あめうけざら", - "description": "天気が 雨のとき 少しずつ HPを 回復する。" - }, - "sandStream": { - "name": "すなおこし", - "description": "登場 したとき 天気を 砂あらしにする。" - }, - "pressure": { - "name": "プレッシャー", - "description": "プレッシャーを あたえて 相手の 使う 技の PPを 多く 減らす。" - }, - "thickFat": { - "name": "あついしぼう", - "description": "厚い 脂肪で 守られているので ほのおタイプと こおりタイプの 技の ダメージを 半減させる。" - }, - "earlyBird": { - "name": "はやおき", - "description": "ねむり状態に なっても 2倍の 早さで 目覚める ことが できる。" - }, - "flameBody": { - "name": "ほのおのからだ", - "description": "自分に 触った 相手を やけど状態に する ことがある。" - }, - "runAway": { - "name": "にげあし", - "description": "野生の ポケモンから 必ず 逃げられる。" - }, - "keenEye": { - "name": "するどいめ", - "description": "鋭い 目の おかげで 命中率を 下げられない。" - }, - "hyperCutter": { - "name": "かいりきバサミ", - "description": "力自慢の ハサミを 持っているので 相手に 攻撃を 下げられない。" - }, - "pickup": { - "name": "ものひろい", - "description": "戦闘が 終わったとき 相手の 持った 道具を 一つ 拾ってくることが ある。" - }, - "truant": { - "name": "なまけ", - "description": "技を 出すと 次の ターンは 休んでしまう。" - }, - "hustle": { - "name": "はりきり", - "description": "自分の 攻撃が 高くなるが 命中率が 下がる。" - }, - "cuteCharm": { - "name": "メロメロボディ", - "description": "自分に 触った 相手を メロメロに することが ある。" - }, - "plus": { - "name": "プラス", - "description": "プラスか マイナスの 特性を 持つ ポケモンが 仲間に いると 自分の 特攻が 上がる。" - }, - "minus": { - "name": "マイナス", - "description": "プラスか マイナスの 特性を 持つ ポケモンが 仲間に いると 自分の 特攻が 上がる。" - }, - "forecast": { - "name": "てんきや", - "description": "天気の 影響を 受けて みずタイプ ほのおタイプ こおりタイプの どれかに 変化する。" - }, - "stickyHold": { - "name": "ねんちゃく", - "description": "粘着質の 体に 道具が くっついているため 相手に 道具を 奪われない。" - }, - "shedSkin": { - "name": "だっぴ", - "description": "体の 皮を 脱ぎ捨てることで 状態異常を 治すことが ある。" - }, - "guts": { - "name": "こんじょう", - "description": "状態異常に なると 根性を だして 攻撃が 上がる。" - }, - "marvelScale": { - "name": "ふしぎなうろこ", - "description": "状態異常に なると 不思議なウロコが 反応して 防御が 上がる。" - }, - "liquidOoze": { - "name": "ヘドロえき", - "description": "ヘドロ液を 吸い取った 相手は 強烈な 悪臭で ダメージを 受けて HPを 減らす。" - }, - "overgrow": { - "name": "しんりょく", - "description": "HPが 減ったとき くさタイプの 技の 威力が 上がる。" - }, - "blaze": { - "name": "もうか", - "description": "HPが 減ったとき ほのおタイプの 技の 威力が 上がる。" - }, - "torrent": { - "name": "げきりゅう", - "description": "HPが 減ったとき みずタイプの 技の 威力が 上がる。" - }, - "swarm": { - "name": "むしのしらせ", - "description": "HPが 減ったとき むしタイプの 技の 威力が 上がる。" - }, - "rockHead": { - "name": "いしあたま", - "description": "反動を 受ける 技を 出しても HPが 減らない。" - }, - "drought": { - "name": "ひでり", - "description": "登場 したときに 天気を 晴れに する。" - }, - "arenaTrap": { - "name": "ありじごく", - "description": "戦闘で 相手を 逃げられなくする。" - }, - "vitalSpirit": { - "name": "やるき", - "description": "やる気を だすことに よって ねむり状態に ならない。" - }, - "whiteSmoke": { - "name": "しろいけむり", - "description": "白い煙に 守られて 相手に 能力を 下げられない。" - }, - "purePower": { - "name": "ヨガパワー", - "description": "ヨガの 力で 物理攻撃の 威力が 2倍に なる。" - }, - "shellArmor": { - "name": "シェルアーマー", - "description": "硬い 殻に 守られ 相手の 攻撃が 急所に 当たらない。" - }, - "airLock": { - "name": "エアロック", - "description": "あらゆる 天気の 影響が なくなって しまう。" - }, - "tangledFeet": { - "name": "ちどりあし", - "description": "こんらん状態の ときは 回避率が アップする。" - }, - "motorDrive": { - "name": "でんきエンジン", - "description": "でんきタイプの 技を 受けると ダメージを 受けずに 素早さが 上がる。" - }, - "rivalry": { - "name": "とうそうしん", - "description": "性別が 同じだと 闘争心を 燃やして 強くなる。 性別が 違うと 弱くなる。" - }, - "steadfast": { - "name": "ふくつのこころ", - "description": "ひるむ たびに 不屈の心を 燃やして 素早さが 上がる。" - }, - "snowCloak": { - "name": "ゆきがくれ", - "description": "天気が ゆきのとき 回避率が 上がる。" - }, - "gluttony": { - "name": "くいしんぼう", - "description": "HPが 少なくなったら 食べる きのみを HP 半分の 時に 食べてしまう。" - }, - "angerPoint": { - "name": "いかりのつぼ", - "description": "急所に 攻撃が 当たると 怒りくるって 攻撃力が 最大に なる。" - }, - "unburden": { - "name": "かるわざ", - "description": "持っていた 道具が なくなると 素早さが 上がる。" - }, - "heatproof": { - "name": "たいねつ", - "description": "耐熱の 体に よって ほのおタイプの 技の 威力を 半減させる。" - }, - "simple": { - "name": "たんじゅん", - "description": "能力 変化が いつもの 2倍に なる。" - }, - "drySkin": { - "name": "かんそうはだ", - "description": "天気が 雨の時や みずタイプの 技で HPが 回復し はれの時や ほのおタイプの 技で 減ってしまう。" - }, - "download": { - "name": "ダウンロード", - "description": "相手の 防御と 特防を くらべて 低い ほうの 能力に あわせて 自分の 攻撃か 特攻を 上げる。" - }, - "ironFist": { - "name": "てつのこぶし", - "description": "パンチを 使う 技の 威力が 上がる。" - }, - "poisonHeal": { - "name": "ポイズンヒール", - "description": "どく状態に なると HPが 減らずに 増えていく。" - }, - "adaptability": { - "name": "てきおうりょく", - "description": "自分と おなじ タイプの 技の 威力が 上がる。" - }, - "skillLink": { - "name": "スキルリンク", - "description": "連続技を 使うと いつも 最高回数 出すことが できる。" - }, - "hydration": { - "name": "うるおいボディ", - "description": "天気が 雨のとき 状態異常が 治る。" - }, - "solarPower": { - "name": "サンパワー", - "description": "天気が 晴れると 特攻が 上がるが 毎ターン HPが 減る。" - }, - "quickFeet": { - "name": "はやあし", - "description": "状態異常に なると 素早さが 上がる。" - }, - "normalize": { - "name": "ノーマルスキン", - "description": "どんな タイプの 技でも すべて ノーマルタイプに なる。 威力が 少し 上がる。" - }, - "sniper": { - "name": "スナイパー", - "description": "攻撃を 急所に 当てると 威力が さらに 上がる。" - }, - "magicGuard": { - "name": "マジックガード", - "description": "攻撃 以外では ダメージを 受けない。" - }, - "noGuard": { - "name": "ノーガード", - "description": "ノーガード戦法に よって お互いの 出す 技が かならず 当たる ようになる。" - }, - "stall": { - "name": "あとだし", - "description": "技を 出す 順番が かならず 最後に なる。" - }, - "technician": { - "name": "テクニシャン", - "description": "威力が 低い 技の 威力を 高くして 攻撃できる。" - }, - "leafGuard": { - "name": "リーフガード", - "description": "天気が 晴れのときは 状態異常に ならない。" - }, - "klutz": { - "name": "ぶきよう", - "description": "持っている 道具を 使うことが できない。" - }, - "moldBreaker": { - "name": "かたやぶり", - "description": "相手の 特性に ジャマされる ことなく 相手に 技を 出すことが できる。" - }, - "superLuck": { - "name": "きょううん", - "description": "強運を 持っているため 相手の 急所に 攻撃が 当たりやすい。" - }, - "aftermath": { - "name": "ゆうばく", - "description": "ひんしに なったとき 触った 相手に ダメージを あたえる。" - }, - "anticipation": { - "name": "きけんよち", - "description": "相手の 持つ 危険な 技を 察知する ことができる。" - }, - "forewarn": { - "name": "よちむ", - "description": "登場 したとき 相手の 持つ 技を ひとつだけ 読み取る。" - }, - "unaware": { - "name": "てんねん", - "description": "相手の 能力の 変化を 無視して 攻撃が できる。" - }, - "tintedLens": { - "name": "いろめがね", - "description": "効果が いまひとつの 技を 通常の 威力で 出すことが できる。" - }, - "filter": { - "name": "フィルター", - "description": "効果バツグンに なってしまう 攻撃の 威力を 弱める ことが できる。" - }, - "slowStart": { - "name": "スロースタート", - "description": "5ターンの あいだ 攻撃と 素早さが 半分に なる。" - }, - "scrappy": { - "name": "きもったま", - "description": "ゴーストタイプの ポケモンに ノーマルタイプと かくとうタイプの 技を 当てることが できる。" - }, - "stormDrain": { - "name": "よびみず", - "description": "みずタイプの 技を 自分に よせつけ ダメージは 受けずに 特攻が 上がる。" - }, - "iceBody": { - "name": "アイスボディ", - "description": "天気が ゆきのとき HPを 少しずつ 回復 する。" - }, - "solidRock": { - "name": "ハードロック", - "description": "効果バツグンに なってしまう 攻撃の 威力を 弱める ことが できる。" - }, - "snowWarning": { - "name": "ゆきふらし", - "description": "登場 したときに 天気を ゆきに する。" - }, - "honeyGather": { - "name": "みつあつめ", - "description": "戦闘が 終わったとき あまいミツを 拾う。そのあまいミツが 売られて お金を もらう。" - }, - "frisk": { - "name": "おみとおし", - "description": "登場 したとき 相手の 持ち物を 見通すことが できる。" - }, - "reckless": { - "name": "すてみ", - "description": "反動で ダメージを 受ける 技の 威力が 上がる。" - }, - "multitype": { - "name": "マルチタイプ", - "description": "持っている プレートや Zクリスタルの タイプによって 自分の タイプが 変わる。" - }, - "flowerGift": { - "name": "フラワーギフト", - "description": "天気が 晴れのとき 自分と 味方の 攻撃と 特防の 能力が 上がる。" - }, - "badDreams": { - "name": "ナイトメア", - "description": "ねむり状態の 相手に ダメージを あたえる。" - }, - "pickpocket": { - "name": "わるいてぐせ", - "description": "触られた 相手の 道具を 盗んで しまう。" - }, - "sheerForce": { - "name": "ちからずく", - "description": "技の 追加効果は なくなるが そのぶん 高い 威力で 技を 出すことが できる。" - }, - "contrary": { - "name": "あまのじゃく", - "description": "能力の 変化が 逆転して 上がるときに 下がり 下がるときに 上がる。" - }, - "unnerve": { - "name": "きんちょうかん", - "description": "相手を 緊張させて きのみを 食べられなく させる。" - }, - "defiant": { - "name": "まけんき", - "description": "能力を 下げられると 攻撃が ぐーんと 上がる。" - }, - "defeatist": { - "name": "よわき", - "description": "HPが 半分に なると 弱気に なって 攻撃と 特攻が 半減する。" - }, - "cursedBody": { - "name": "のろわれボディ", - "description": "攻撃を 受けると 相手の 技を かなしばり状態に することが ある。" - }, - "healer": { - "name": "いやしのこころ", - "description": "状態異常の 味方を たまに 治してあげる。" - }, - "friendGuard": { - "name": "フレンドガード", - "description": "味方の ダメージを 減らすことが できる。" - }, - "weakArmor": { - "name": "くだけるよろい", - "description": "物理技で ダメージを 受けると 防御が 下がり 素早さが ぐーんと 上がる。" - }, - "heavyMetal": { - "name": "ヘヴィメタル", - "description": "自分の 重さが 2倍に なる。" - }, - "lightMetal": { - "name": "ライトメタル", - "description": "自分の 重さが 半分に なる。" - }, - "multiscale": { - "name": "マルチスケイル", - "description": "HPが 満タンの ときに 受ける ダメージが 少なくなる。" - }, - "toxicBoost": { - "name": "どくぼうそう", - "description": "どく状態に なったとき 物理技の 威力が 上がる。" - }, - "flareBoost": { - "name": "ねつぼうそう", - "description": "やけど状態に なったとき 特殊技の 威力が 上がる。" - }, - "harvest": { - "name": "しゅうかく", - "description": "使った きのみを 何回も 作りだす。" - }, - "telepathy": { - "name": "テレパシー", - "description": "味方の 攻撃を 読み取って 技を 回避する。" - }, - "moody": { - "name": "ムラっけ", - "description": "毎ターン 能力の どれかが ぐーんと 上がって どれかが 下がる。" - }, - "overcoat": { - "name": "ぼうじん", - "description": "すなあらしや あられなどの ダメージを 受けない。 粉の 技を 受けない。" - }, - "poisonTouch": { - "name": "どくしゅ", - "description": "触る だけで 相手を どく 状態に することがある。" - }, - "regenerator": { - "name": "さいせいりょく", - "description": "手持ちに 引っ込むと HPが 少し 回復する。" - }, - "bigPecks": { - "name": "はとむね", - "description": "防御を 下げる 効果を 受けない。" - }, - "sandRush": { - "name": "すなかき", - "description": "天気が すなあらし のとき 素早さが 上がる。" - }, - "wonderSkin": { - "name": "ミラクルスキン", - "description": "変化技を 受けにくい 体に なっている。" - }, - "analytic": { - "name": "アナライズ", - "description": "いちばん 最後に 技を 出すと 技の 威力が 上がる。" - }, - "illusion": { - "name": "イリュージョン", - "description": "手持ちの いちばん うしろに いる ポケモンに なりきって 登場して 相手を 化かす。" - }, - "imposter": { - "name": "かわりもの", - "description": "目の前の ポケモンに 変身 してしまう。" - }, - "infiltrator": { - "name": "すりぬけ", - "description": "相手の 壁や 身代わりを すりぬけて 攻撃 できる" - }, - "mummy": { - "name": "ミイラ", - "description": "相手に 触られると 相手を ミイラに してしまう。" - }, - "moxie": { - "name": "じしんかじょう", - "description": "相手を 倒すと 自信が ついて 攻撃が 上がる。" - }, - "justified": { - "name": "せいぎのこころ", - "description": "あくタイプの 攻撃を 受けると 正義感で 攻撃が 上がる。" - }, - "rattled": { - "name": "びびり", - "description": "あく ゴースト むしタイプの 攻撃を 受けたり いかくを されると びびって 素早さが 上がる。" - }, - "magicBounce": { - "name": "マジックミラー", - "description": "相手に だされた 変化技を 受けずに そのまま 返す ことが できる。" - }, - "sapSipper": { - "name": "そうしょく", - "description": "くさタイプの 技を 受けると ダメージを 受けずに 攻撃が 上がる。" - }, - "prankster": { - "name": "いたずらごころ", - "description": "変化技を 先制で 出すことが できる。" - }, - "sandForce": { - "name": "すなのちから", - "description": "天気が すなあらしの とき いわタイプと じめんタイプと はがねタイプの 威力が 上がる。" - }, - "ironBarbs": { - "name": "てつのトゲ", - "description": "自分に 触った 相手に 鉄のトゲで ダメージを あたえる。" - }, - "zenMode": { - "name": "ダルマモード", - "description": "HPが 半分 以下に なると 姿が 変化する。" - }, - "victoryStar": { - "name": "しょうりのほし", - "description": "自分や 味方の 命中率が 上がる。" - }, - "turboblaze": { - "name": "ターボブレイズ", - "description": "相手の 特性に ジャマされる ことなく 相手に 技を 出すことが できる。" - }, - "teravolt": { - "name": "テラボルテージ", - "description": "相手の 特性に ジャマされる ことなく 相手に 技を 出すことが できる。" - }, - "aromaVeil": { - "name": "アロマベール", - "description": "自分と 味方への メンタル 攻撃を 防ぐことが できる。" - }, - "flowerVeil": { - "name": "フラワーベール", - "description": "味方の 草ポケモンは 能力が 下がらず 状態異常にも ならない。" - }, - "cheekPouch": { - "name": "ほおぶくろ", - "description": "どんな きのみでも 食べると HPも 回復する。" - }, - "protean": { - "name": "へんげんじざい", - "description": "自分が 出す 技と 同じ タイプに 変化する。" - }, - "furCoat": { - "name": "ファーコート", - "description": "相手から 受ける 物理技の ダメージが 半分に なる。" - }, - "magician": { - "name": "マジシャン", - "description": "技を 当てた 相手の 道具を 奪ってしまう。" - }, - "bulletproof": { - "name": "ぼうだん", - "description": "相手の 弾や 爆弾などの 技を 防ぐことが できる。" - }, - "competitive": { - "name": "かちき", - "description": "能力を 下げられると 特攻が ぐーんと 上がる。" - }, - "strongJaw": { - "name": "がんじょうあご", - "description": "あごが 頑丈で 噛む 技の 威力が 高くなる。" - }, - "refrigerate": { - "name": "フリーズスキン", - "description": "ノーマルタイプの 技が こおりタイプに なる。 威力が 少し 上がる。" - }, - "sweetVeil": { - "name": "スイートベール", - "description": "味方の ポケモンは 眠らなくなる。" - }, - "stanceChange": { - "name": "バトルスイッチ", - "description": "攻撃技を 出すと ブレードフォルムに 技 キングシールドを 出すと シールドフォルムに 変化する。" - }, - "galeWings": { - "name": "はやてのつばさ", - "description": "HPが 満タン だと ひこうタイプの 技を 先制で 出すことが できる。" - }, - "megaLauncher": { - "name": "メガランチャー", - "description": "波動の 技の 威力が 高くなる。" - }, - "grassPelt": { - "name": "くさのけがわ", - "description": "グラスフィールドのとき 防御が 上がる。" - }, - "symbiosis": { - "name": "きょうせい", - "description": "味方が 道具を 使うと 自分の 持っている 道具を 味方に 渡す。" - }, - "toughClaws": { - "name": "かたいツメ", - "description": "相手に 接触する 技の 威力が 高くなる。" - }, - "pixilate": { - "name": "フェアリースキン", - "description": "ノーマルタイプの 技が フェアリータイプになる。 威力が 少し 上がる。" - }, - "gooey": { - "name": "ぬめぬめ", - "description": "攻撃で 自分に 触れた 相手の 素早さを 下げる。" - }, - "aerilate": { - "name": "スカイスキン", - "description": "ノーマルタイプの 技が ひこうタイプになる。 威力が 少し 上がる。" - }, - "parentalBond": { - "name": "おやこあい", - "description": "親子 2匹で 2回 攻撃することが できる。" - }, - "darkAura": { - "name": "ダークオーラ", - "description": "全員の あくタイプの 技が 強くなる。" - }, - "fairyAura": { - "name": "フェアリーオーラ", - "description": "全員の フェアリータイプの 技が 強くなる。" - }, - "auraBreak": { - "name": "オーラブレイク", - "description": "オーラの 効果を 逆転させて 威力を 下げる。" - }, - "primordialSea": { - "name": "はじまりのうみ", - "description": "ほのおタイプの 攻撃を 受けない 天気にする。" - }, - "desolateLand": { - "name": "おわりのだいち", - "description": "みずタイプの 攻撃を 受けない 天気にする。" - }, - "deltaStream": { - "name": "デルタストリーム", - "description": "ひこうタイプの 弱点が なくなる 天気にする。" - }, - "stamina": { - "name": "じきゅうりょく", - "description": "攻撃を 受けると 防御が 上がる。" - }, - "wimpOut": { - "name": "にげごし", - "description": "HPが 半分に なると あわてて 逃げ出して 手持ちに 引っ込んで しまう。" - }, - "emergencyExit": { - "name": "ききかいひ", - "description": "HPが 半分に なると 危険を 回避するため 手持ちに 引っ込んで しまう。" - }, - "waterCompaction": { - "name": "みずがため", - "description": "みずタイプの 技を 受けると 防御が ぐーんと 上がる。" - }, - "merciless": { - "name": "ひとでなし", - "description": "どく状態の 相手を 攻撃すると かならず 急所に 当たる。" - }, - "shieldsDown": { - "name": "リミットシールド", - "description": "HPが 半分に なると 殻が 壊れて 攻撃的に なる。" - }, - "stakeout": { - "name": "はりこみ", - "description": "交代で 出てきた 相手に 2倍の ダメージで 攻撃 できる。" - }, - "waterBubble": { - "name": "すいほう", - "description": "自分に 対する ほのおタイプの 技の 威力を 下げる。 やけど しない。" - }, - "steelworker": { - "name": "はがねつかい", - "description": "はがねタイプの 技の 威力が 上がる。" - }, - "berserk": { - "name": "ぎゃくじょう", - "description": "相手の 攻撃で HPが 半分に なると 特攻が 上がる。" - }, - "slushRush": { - "name": "ゆきかき", - "description": "天気が ゆき のとき 素早さが 上がる。" - }, - "longReach": { - "name": "えんかく", - "description": "すべての 技を 相手に 接触 しないで 出すことが できる。" - }, - "liquidVoice": { - "name": "うるおいボイス", - "description": "すべての 音技が みずタイプに なる。" - }, - "triage": { - "name": "ヒーリングシフト", - "description": "回復技を 先制で 出すことが できる。" - }, - "galvanize": { - "name": "エレキスキン", - "description": "ノーマルタイプの 技が でんきタイプになる。 威力が 少し 上がる。" - }, - "surgeSurfer": { - "name": "サーフテール", - "description": "エレキフィールド のとき 素早さが 2倍に なる。" - }, - "schooling": { - "name": "ぎょぐん", - "description": "HPが 多いときは 群れて 強くなる。 HPの 残りが 少なくなると 群れは 散り散りに なってしまう。" - }, - "disguise": { - "name": "ばけのかわ", - "description": "体を 被う 化けの皮で 1回 攻撃を 防ぐことが できる。" - }, - "battleBond": { - "name": "きずなへんげ", - "description": "相手を 倒すと トレーナーとの キズナが 深まり サトシゲッコウガに 変化する。みずしゅりけんが 強くなる。" - }, - "powerConstruct": { - "name": "スワームチェンジ", - "description": "HPが 半分に なると セルたちが 応援に 駆けつけ パーフェクトフォルムに 姿を 変える。" - }, - "corrosion": { - "name": "ふしょく", - "description": "はがねタイプや どくタイプも どく状態に することが できる。" - }, - "comatose": { - "name": "ぜったいねむり", - "description": "つねに 夢うつつの 状態で 絶対に 目覚めない。 眠ったまま 攻撃が できる。" - }, - "queenlyMajesty": { - "name": "じょおうのいげん", - "description": "相手に 威圧感を あたえ こちらに むかって 先制技を 出せない ようにする。" - }, - "innardsOut": { - "name": "とびだすなかみ", - "description": "相手に 倒されたとき HPの 残りの ぶんだけ 相手に ダメージを あたえる。" - }, - "dancer": { - "name": "おどりこ", - "description": "だれかが 踊り技を 使うと 自分も それに 続いて 踊り技を 出すことが できる。" - }, - "battery": { - "name": "バッテリー", - "description": "味方の 特殊技の 威力を 上げる。" - }, - "fluffy": { - "name": "もふもふ", - "description": "相手から 受けた 接触する 技の ダメージを 半減するが ほのおタイプの 技の ダメージは 2倍になる。" - }, - "dazzling": { - "name": "ビビッドボディ", - "description": "相手を びっくり させて こちらに むかって 先制技を 出せない ようにする。" - }, - "soulHeart": { - "name": "ソウルハート", - "description": "ポケモンが ひんしに なるたびに 特攻が 上がる。" - }, - "tanglingHair": { - "name": "カーリーヘアー", - "description": "攻撃で 自分に 触れた 相手の 素早さを 下げる。" - }, - "receiver": { - "name": "レシーバー", - "description": "倒された 味方の 特性を 受け継いで 同じ 特性に なる。" - }, - "powerOfAlchemy": { - "name": "かがくのちから", - "description": "倒された 味方の 特性を 受け継いで 同じ 特性に なる。" - }, - "beastBoost": { - "name": "ビーストブースト", - "description": "相手を 倒したとき 自分の いちばん 高い 能力が 上がる。" - }, - "rksSystem": { - "name": "ARシステム", - "description": "持っている メモリで 自分の タイプが 変わる。" - }, - "electricSurge": { - "name": "エレキメイカー", - "description": "登場 したときに エレキフィールドを はりめぐらせる。" - }, - "psychicSurge": { - "name": "サイコメイカー", - "description": "登場 したときに サイコフィールドを はりめぐらせる。" - }, - "mistySurge": { - "name": "ミストメイカー", - "description": "登場 したときに ミストフィールドを はりめぐらせる。" - }, - "grassySurge": { - "name": "グラスメイカー", - "description": "登場 したときに グラスフィールドを はりめぐらせる。" - }, - "fullMetalBody": { - "name": "メタルプロテクト", - "description": "相手の 技や 特性で 能力を 下げられない。" - }, - "shadowShield": { - "name": "ファントムガード", - "description": "HPが 満タンの ときに 受ける ダメージが 少なくなる。" - }, - "prismArmor": { - "name": "プリズムアーマー", - "description": "効果バツグンに なってしまう 攻撃の 威力を 弱める ことが できる。" - }, - "neuroforce": { - "name": "ブレインフォース", - "description": "効果バツグンの 攻撃で 威力が さらに 上がる。" - }, - "intrepidSword": { - "name": "ふとうのけん", - "description": "登場 したときに 攻撃が 上がる。" - }, - "dauntlessShield": { - "name": "ふくつのたて", - "description": "登場 したときに 防御が 上がる。" - }, - "libero": { - "name": "リベロ", - "description": "自分が 出す 技と 同じ タイプに 変化する。" - }, - "ballFetch": { - "name": "たまひろい", - "description": "1回目に 投げて 失敗 した モンスターボールを 拾ってくる。" - }, - "cottonDown": { - "name": "わたげ", - "description": "攻撃を 受けると わたげを ばらまいて 自分以外の ポケモン すべての 素早さを 下げる。" - }, - "propellerTail": { - "name": "スクリューおびれ", - "description": "相手の 技を 引き受ける 特性や 技の 影響を 無視 できる。" - }, - "mirrorArmor": { - "name": "ミラーアーマー", - "description": "自分が 受けた 能力 ダウンの 効果 だけを 跳ね返す。" - }, - "gulpMissile": { - "name": "うのミサイル", - "description": "なみのりか ダイビングを すると 獲物を くわえてくる。 ダメージを 受けると 獲物を 吐きだして 攻撃。" - }, - "stalwart": { - "name": "すじがねいり", - "description": "相手の 技を 引き受ける 特性や 技の 影響を 無視 できる。" - }, - "steamEngine": { - "name": "じょうききかん", - "description": "みずタイプ ほのおタイプの 技を 受けると 素早さが ぐぐーんと 上がる。" - }, - "punkRock": { - "name": "パンクロック", - "description": "音技の 威力が 上がる。 受けた 音技の ダメージは 半分に なる。" - }, - "sandSpit": { - "name": "すなはき", - "description": "攻撃を 受けると 砂あらしを 起こす。" - }, - "iceScales": { - "name": "こおりのりんぷん", - "description": "こおりのりんぷんに 守られて 特殊攻撃で 受ける ダメージが 半減 する。" - }, - "ripen": { - "name": "じゅくせい", - "description": "熟成 させることで きのみの 効果が 倍に なる。" - }, - "iceFace": { - "name": "アイスフェイス", - "description": "物理攻撃は 頭の 氷が みがわりに なるが 姿も 変わる。 氷は あられが 降ると 元に戻る。" - }, - "powerSpot": { - "name": "パワースポット", - "description": "隣に いるだけで 技の 威力が 上がる。" - }, - "mimicry": { - "name": "ぎたい", - "description": "フィールドの 状態に あわせて ポケモンの タイプが 変わる。" - }, - "screenCleaner": { - "name": "バリアフリー", - "description": "登場 したときに 敵と 味方の ひかりのかべ リフレクター オーロラベールの 効果が 消える。" - }, - "steelySpirit": { - "name": "はがねのせいしん", - "description": "味方の はがねタイプの 攻撃の 威力が 上がる。" - }, - "perishBody": { - "name": "ほろびのボディ", - "description": "接触する 技を 受けると お互い 3ターン たつと ひんしになる。 交代すると 効果は なくなる。" - }, - "wanderingSpirit": { - "name": "さまようたましい", - "description": "接触する 技で 攻撃 してきた ポケモンと 特性を 入れ替える。" - }, - "gorillaTactics": { - "name": "ごりむちゅう", - "description": "攻撃は 上がるが 最初に 選んだ 技しか 出せなくなる。" - }, - "neutralizingGas": { - "name": "かがくへんかガス", - "description": "かがくへんかガスの ポケモンが 場にいると すべての ポケモンの 特性の 効果が 消えたり 発動 しなくなる。" - }, - "pastelVeil": { - "name": "パステルベール", - "description": "自分も 味方も どくの 状態異常を 受けなくなる。" - }, - "hungerSwitch": { - "name": "はらぺこスイッチ", - "description": "ターンの 終わりに まんぷくもよう はらぺこもよう まんぷくもよう……と 交互に 姿を 変える。" - }, - "quickDraw": { - "name": "クイックドロウ", - "description": "相手より 先に 行動できることが ある。" - }, - "unseenFist": { - "name": "ふかしのこぶし", - "description": "相手に 接触する 技なら 守りの 効果を 無視して 攻撃することが できる。" - }, - "curiousMedicine": { - "name": "きみょうなくすり", - "description": "登場 したときに 貝がらから 薬を 振りまいて 味方の 能力変化を 元に戻す。" - }, - "transistor": { - "name": "トランジスタ", - "description": "でんきタイプの 技の 威力が 上がる。" - }, - "dragonsMaw": { - "name": "りゅうのあぎと", - "description": "ドラゴンタイプの 技の 威力が 上がる。" - }, - "chillingNeigh": { - "name": "しろのいななき", - "description": "相手を 倒すと 冷たい 声で いなないて 攻撃が 上がる。" - }, - "grimNeigh": { - "name": "くろのいななき", - "description": "相手を 倒すと 恐ろしい 声で いなないて 特攻が 上がる。" - }, - "asOneGlastrier": { - "name": "じんばいったい", - "description": "バドレックスの きんちょうかんと ブリザポスの しろのいななきの 二つの 特性を あわせ持つ。" - }, - "asOneSpectrier": { - "name": "じんばいったい", - "description": "バドレックスの きんちょうかんと レイスポスの くろのいななきの 二つの 特性を あわせ持つ。" - }, - "lingeringAroma": { - "name": "とれないにおい", - "description": "直接攻撃を受けたとき、相手の特性もとれないにおいにする。" - }, - "seedSower": { - "name": "こぼれダネ", - "description": "攻撃を 受けると グラスフィールドに する。" - }, - "thermalExchange": { - "name": "ねつこうかん", - "description": "ほのおタイプの 技を 受けると 攻撃が 上がる。 やけど状態に ならない。" - }, - "angerShell": { - "name": "いかりのこうら", - "description": "相手の攻撃で HPが 半分に なると 怒りで 防御と 特防が 下がるが 攻撃 特攻 素早さが 上がる。" - }, - "purifyingSalt": { - "name": "きよめのしお", - "description": "清らかな塩で 状態異常に ならない。 ゴーストタイプの 技の ダメージを 半減させる。" - }, - "wellBakedBody": { - "name": "こんがりボディ", - "description": "ほのおタイプの 技を 受けると ダメージを 受けずに 防御が ぐーんと 上がる。" - }, - "windRider": { - "name": "かぜのり", - "description": "おいかぜが 吹いたり 風技を 受けると ダメージを 受けずに 攻撃が 上がる。" - }, - "guardDog": { - "name": "ばんけん", - "description": "いかく されると 攻撃が 上がる。 ポケモンを 入れ替えさせる 技や 道具が 効かない。" - }, - "rockyPayload": { - "name": "いわはこび", - "description": "いわタイプの 技の 威力が 上がる。" - }, - "windPower": { - "name": "ふうりょくでんき", - "description": "風技を 受けると じゅうでん 状態に なる。" - }, - "zeroToHero": { - "name": "マイティチェンジ", - "description": "手持ちに ひっこむと マイティフォルムに 変化する。" - }, - "commander": { - "name": "しれいとう", - "description": "登場したとき 味方に ヘイラッシャが いると 口の中に 入って そこから 指令を だす。" - }, - "electromorphosis": { - "name": "でんきにかえる", - "description": "ダメージを 受けると じゅうでん 状態に なる。" - }, - "protosynthesis": { - "name": "こだいかっせい", - "description": "ブーストエナジーを 持たせるか 天気が 晴れのとき いちばん 高い能力が 上がる。" - }, - "quarkDrive": { - "name": "クォークチャージ", - "description": "ブーストエナジーを 持たせるか エレキフィールドのとき いちばん 高い能力が 上がる。" - }, - "goodAsGold": { - "name": "おうごんのからだ", - "description": "酸化せず 丈夫な 黄金の体は 相手からの 変化技を 受けない。" - }, - "vesselOfRuin": { - "name": "わざわいのうつわ", - "description": "災厄を 呼ぶ 器の力で 自分以外の 特攻が 弱くなる。" - }, - "swordOfRuin": { - "name": "わざわいのつるぎ", - "description": "災厄を 呼ぶ 剣の力で 自分以外の 防御が 弱くなる。" - }, - "tabletsOfRuin": { - "name": "わざわいのおふだ", - "description": "災厄を 呼ぶ 木札の力で 自分以外の 攻撃が 弱くなる。" - }, - "beadsOfRuin": { - "name": "わざわいのたま", - "description": "災厄を 呼ぶ 勾玉の力で 自分以外の 特防が 弱くなる。" - }, - "orichalcumPulse": { - "name": "ひひいろのこどう", - "description": "登場したとき 天気を 晴れにする。 日差しが 強いと 古代の 鼓動により 攻撃が 高まる。" - }, - "hadronEngine": { - "name": "ハドロンエンジン", - "description": "登場したとき エレキフィールドを はる。 エレキフィールドだと 未来の 機関により 特攻が 高まる。" - }, - "opportunist": { - "name": "びんじょう", - "description": "相手の 能力が 上がったとき 自分も 便乗して 同じように 能力を 上げる。" - }, - "cudChew": { - "name": "はんすう", - "description": "きのみを 食べると 次のターンの 終わりに 胃から 出して もう1回だけ 食べる。" - }, - "sharpness": { - "name": "きれあじ", - "description": "相手を 切る技の 威力が 上がる。" - }, - "supremeOverlord": { - "name": "そうだいしょう", - "description": "登場したとき 今まで 倒された 味方の 数が 多いほど 少しずつ 攻撃と 特攻が 上がる。" - }, - "costar": { - "name": "きょうえん", - "description": "登場 したときに 味方の 能力変化を コピーする。" - }, - "toxicDebris": { - "name": "どくげしょう", - "description": "物理技で ダメージを 受けると 相手の 足下に どくびしが ちらばる。" - }, - "armorTail": { - "name": "テイルアーマー", - "description": "頭を包む 謎のしっぽが こちらに むかって 先制技を 出せない ようにする。" - }, - "earthEater": { - "name": "どしょく", - "description": "じめんタイプの 技を 受けると ダメージを 受けずに 回復する。" - }, - "myceliumMight": { - "name": "きんしのちから", - "description": "変化技を 出すとき 必ず 行動が 遅くなるが 相手の 特性に ジャマされない。" - }, - "mindsEye": { - "name": "しんがん", - "description": "ノーマル かくとうタイプの技を ゴーストタイプに 当てることが できる。 相手の 回避率の 変化を 無視し 命中率も 下げられない。" - }, - "supersweetSyrup": { - "name": "かんろなミツ", - "description": "最初に 登場 したとき 甘ったるい 蜜の香りを ふりまいて 相手の 回避率を 下げる。" - }, - "hospitality": { - "name": "おもてなし", - "description": "登場したとき 味方を もてなして HPを 少しだけ 回復してあげる。" - }, - "toxicChain": { - "name": "どくのくさり", - "description": "毒素を ふくんだ 鎖の力で 技を 当てた 相手を 猛毒の状態に することが ある。" - }, - "embodyAspectTeal": { - "name": "おもかげやどし", - "description": "思い出を 心に 宿すことで みどりのめんを かがやかせ 自分の 素早さを 上げる。" - }, - "embodyAspectWellspring": { - "name": "おもかげやどし", - "description": "思い出を 心に 宿すことで いどのめんを かがやかせ 自分の 特防を 上げる。" - }, - "embodyAspectHearthflame": { - "name": "おもかげやどし", - "description": "思い出を 心に 宿すことで かまどのめんを かがやかせ 自分の 攻撃を 上げる。" - }, - "embodyAspectCornerstone": { - "name": "おもかげやどし", - "description": "思い出を 心に 宿すことで いしずえのめんを かがやかせ 自分の 防御を 上げる。" - }, - "teraShift": { - "name": "テラスチェンジ", - "description": "登場したとき 周囲の エネルギーを 吸収し テラスタルフォルムに 変化する。" - }, - "teraShell": { - "name": "テラスシェル", - "description": "全タイプの力を 秘めた甲羅は HPが 満タンの ときに 受ける ダメージを すべて 今ひとつに する。" - }, - "teraformZero": { - "name": "ゼロフォーミング", - "description": "テラパゴスが ステラフォルムに なったとき 秘められた力で 天気と フィールドの 影響を すべて ゼロにする。" - }, - "poisonPuppeteer": { - "name": "どくくぐつ", - "description": "モモワロウの 技によって どく状態に なった 相手は こんらん状態にも なってしまう。" - } -} diff --git a/src/locales/ja/achv.json b/src/locales/ja/achv.json deleted file mode 100644 index fd5e4b9e6c4..00000000000 --- a/src/locales/ja/achv.json +++ /dev/null @@ -1,269 +0,0 @@ -{ - "Achievements": { - "name": "実績" - }, - "Locked": { - "name": "なし" - }, - "MoneyAchv": { - "description": "一回の ランで {{moneyAmount}}円を 稼ぐ" - }, - "10K_MONEY": { - "name": "お金を持つ人" - }, - "100K_MONEY": { - "name": "富豪" - }, - "1M_MONEY": { - "name": "百万長者" - }, - "10M_MONEY": { - "name": "超富裕層" - }, - "DamageAchv": { - "description": "一撃で HP{{damageAmount}}の ダメージを 与える" - }, - "250_DMG": { - "name": "力持ち" - }, - "1000_DMG": { - "name": "強者" - }, - "2500_DMG": { - "name": "カカロット" - }, - "10000_DMG": { - "name": "ワンパンマン", - "name_female": "ワンパンウーマン" - }, - "HealAchv": { - "description": "一つの 技や 特性や 持たせたアイテムで\n{{HP}}{{healAmount}}を 一気に 回復する" - }, - "250_HEAL": { - "name": "回復発見者" - }, - "1000_HEAL": { - "name": "大いなる治療者" - }, - "2500_HEAL": { - "name": "回復達人" - }, - "10000_HEAL": { - "name": "ジョーイさん" - }, - "LevelAchv": { - "description": "一つの ポケモンを Lv.{{level}}まで 上げる" - }, - "LV_100": { - "name": "まだまだだよ" - }, - "LV_250": { - "name": "天王" - }, - "LV_1000": { - "name": "向こうの向こうを超え" - }, - "RibbonAchv": { - "description": "{{ribbonAmount}}巻の リボンを 積もる" - }, - "10_RIBBONS": { - "name": "ポケモンリーグチャンピオン" - }, - "25_RIBBONS": { - "name": "スーパーリーグチャンピオン" - }, - "50_RIBBONS": { - "name": "ハイパーリーグチャンピオン" - }, - "75_RIBBONS": { - "name": "ローグリーグチャンピオン" - }, - "100_RIBBONS": { - "name": "マスターリーグチャンピオン" - }, - "TRANSFER_MAX_STAT_STAGE": { - "name": "連係プレー", - "description": "少なくとも 一つの 能力を 最大まで あげて\n他の 手持ちポケモンに バトンタッチする" - }, - "MAX_FRIENDSHIP": { - "name": "マブ達", - "description": "一つの 手持ちポケモンの 仲良し度を 最大に 上げる" - }, - "MEGA_EVOLVE": { - "name": "ザ・アブソリュート", - "description": "一つの 手持ちポケモンを メガシンカさせる" - }, - "GIGANTAMAX": { - "name": "太ーくて堪らない", - "description": "一つの 手持ちポケモンを キョダイマックスさせる" - }, - "TERASTALLIZE": { - "name": "一致好き", - "description": "一つの 手持ちポケモンを テラスタルさせる" - }, - "STELLAR_TERASTALLIZE": { - "name": "隠れたタイプ", - "description": "一つの 手持ちポケモンを ステラ・テラスタルさせる" - }, - "SPLICE": { - "name": "インフィニット・フュージョン", - "description": "遺伝子のくさびで 二つの ポケモンを 吸収合体させる" - }, - "MINI_BLACK_HOLE": { - "name": "アイテムホーリック", - "description": "ミニブラックホールを 手に入れる" - }, - "CATCH_MYTHICAL": { - "name": "幻", - "description": "幻の ポケモンを 捕まえる" - }, - "CATCH_SUB_LEGENDARY": { - "name": "準・伝説", - "description": "準伝説の ポケモンを 捕まえる" - }, - "CATCH_LEGENDARY": { - "name": "ザ・伝説", - "description": "伝説の ポケモンを 捕まえる" - }, - "SEE_SHINY": { - "name": "色とりどりに光る", - "description": "野生の 色違いポケモンを みつける" - }, - "SHINY_PARTY": { - "name": "きらきら努力家", - "description": "手持ちポケモンは 全員 色違いポケモンに する" - }, - "HATCH_MYTHICAL": { - "name": "幻のタマゴ", - "description": "幻の ポケモンを タマゴから 生まれる" - }, - "HATCH_SUB_LEGENDARY": { - "name": "準伝説のタマゴ", - "description": "準伝説の ポケモンを タマゴから 生まれる" - }, - "HATCH_LEGENDARY": { - "name": "伝説のタマゴ", - "description": "伝説の ポケモンを タマゴから 生まれる" - }, - "HATCH_SHINY": { - "name": "色違いタマゴ", - "description": "色違いポケモンを タマゴから 生まれる" - }, - "HIDDEN_ABILITY": { - "name": "底力", - "description": "隠れ特性がある ポケモンを 捕まえる" - }, - "PERFECT_IVS": { - "name": "個体値の賞状", - "description": "一つの ポケモンの 個体値を すべて 最大に する" - }, - "CLASSIC_VICTORY": { - "name": "無双", - "description": "クラシックモードを クリアする" - }, - "UNEVOLVED_CLASSIC_VICTORY": { - "name": "はじめてのおつかい", - "description": "少なくとも 一つの 進化していない 手持ちポケモンで\nクラシックモードを クリアする" - }, - "MONO_GEN_ONE": { - "name": "原始", - "description": "1世代の 単一世代チャレンジを クリアする" - }, - "MONO_GEN_TWO": { - "name": "懐かしいカンジョウ", - "description": "2世代の 単一世代チャレンジを クリアする" - }, - "MONO_GEN_THREE": { - "name": "水浸し", - "description": "3世代の 単一世代チャレンジを クリアする" - }, - "MONO_GEN_FOUR": { - "name": "神々の地", - "description": "4世代の 単一世代チャレンジを クリアする" - }, - "MONO_GEN_FIVE": { - "name": "ニューヨーカー", - "description": "5世代の 単一世代チャレンジを クリアする" - }, - "MONO_GEN_SIX": { - "name": "サヴァ・サヴァ", - "description": "6世代の 単一世代チャレンジを クリアする" - }, - "MONO_GEN_SEVEN": { - "name": "アローラ・オエ", - "description": "7世代の 単一世代チャレンジを クリアする" - }, - "MONO_GEN_EIGHT": { - "name": "チャンピオン タイムを 楽しめ!", - "description": "8世代の 単一世代チャレンジを クリアする" - }, - "MONO_GEN_NINE": { - "name": "ネモに甘えたでしょう", - "description": "9世代の 単一世代チャレンジを クリアする" - }, - "MonoType": { - "description": "{{type}}タイプの 単一タイプチャレンジを クリアする" - }, - "MONO_NORMAL": { - "name": "超凡人" - }, - "MONO_FIGHTING": { - "name": "八千以上だ!!" - }, - "MONO_FLYING": { - "name": "翼をください" - }, - "MONO_POISON": { - "name": "カントーの名物" - }, - "MONO_GROUND": { - "name": "自信でユラユラ" - }, - "MONO_ROCK": { - "name": "タケシの挑戦状" - }, - "MONO_BUG": { - "name": "チョウチョウ戦者" - }, - "MONO_GHOST": { - "name": "貞子ちゃん" - }, - "MONO_STEEL": { - "name": "ハガネーター" - }, - "MONO_FIRE": { - "name": "NIGHT OF FIRE" - }, - "MONO_WATER": { - "name": "土砂降リスト" - }, - "MONO_GRASS": { - "name": "www" - }, - "MONO_ELECTRIC": { - "name": "パチピカペコ" - }, - "MONO_PSYCHIC": { - "name": "陽キャ" - }, - "MONO_ICE": { - "name": "ありのまま" - }, - "MONO_DRAGON": { - "name": "龍が如く" - }, - "MONO_DARK": { - "name": "陰キャ" - }, - "MONO_FAIRY": { - "name": "あらハート満タンになった" - }, - "FRESH_START": { - "name": "一発で!", - "description": "出直しチャレンジを クリアする" - }, - "INVERSE_BATTLE": { - "name": "カガミよミガカ", - "description": "反転バトルチャレンジを クリアする\nるすアリク をジンレャチルトバ転反" - } -} diff --git a/src/locales/ja/arena-flyout.json b/src/locales/ja/arena-flyout.json deleted file mode 100644 index 8585b8e8fb4..00000000000 --- a/src/locales/ja/arena-flyout.json +++ /dev/null @@ -1,44 +0,0 @@ -{ - "activeBattleEffects": "場の効果", - "player": "味方", - "neutral": "場の全員", - "enemy": "相手", - - "sunny": "晴れ", - "rain": "雨", - "sandstorm": "砂あらし", - "hail": "あられ", - "snow": "雪", - "fog": "きり", - "heavyRain": "強い雨", - "harshSun": "大日照り", - "strongWinds": "乱気流", - - "misty": "ミストフィールド", - "electric": "エレキフィールド", - "grassy": "グラスフィールド", - "psychic": "サイコフィールド", - - "mudSport": "どろあそび", - "waterSport": "みずあそび", - "spikes": "まきびし", - "toxicSpikes": "どくびし", - "mist": "しろいきり", - "futureSight": "みらいよち", - "doomDesire": "はめつのねがい", - "wish": "ねがいごと", - "stealthRock": "ステルスロック", - "stickyWeb": "ねばねばネット", - "trickRoom": "トリックルーム", - "gravity": "じゅうりょく", - "reflect": "リフレクター", - "lightScreen": "ひかりのかべ", - "auroraVeil": "オーロラベール", - "quickGuard": "ファストガード", - "wideGuard": "ワイドガード", - "matBlock": "たたみがえし", - "craftyShield": "トリックガード", - "tailwind": "おいかぜ", - "happyHour": "ハッピータイム", - "safeguard": "しんぴなまもり" -} diff --git a/src/locales/ja/arena-tag.json b/src/locales/ja/arena-tag.json deleted file mode 100644 index a81942338fd..00000000000 --- a/src/locales/ja/arena-tag.json +++ /dev/null @@ -1,57 +0,0 @@ -{ - "yourTeam": "味方", - "opposingTeam": "相手", - "arenaOnRemove": "{{moveName}}の 効果が 切れた", - "arenaOnRemovePlayer": "{{moveName}}の 効果が\n味方から 切れた", - "arenaOnRemoveEnemy": "{{moveName}}の 効果が\n相手から 切れた", - "mistOnAdd": "{{pokemonNameWithAffix}}の 味方は\n白い霧に 包まれた!", - "mistApply": "白い霧が\n能力変化の 削減から 守った!", - "reflectOnAdd": "リフレクターで 物理ダメージを さげた", - "reflectOnAddPlayer": "味方の リフレクターで\n物理ダメージを さげた", - "reflectOnAddEnemy": "相手の リフレクターで\n物理ダメージを さげた", - "lightScreenOnAdd": "ひかりのかべで\n特殊ダメージを さげた", - "lightScreenOnAddPlayer": "味方の ひかりのかべで\n特殊ダメージを さげた", - "lightScreenOnAddEnemy": "相手の ひかりのかべで\n特殊ダメージを さげた", - "auroraVeilOnAdd": "オーロラベールで\n攻撃の ダメージを さげた", - "auroraVeilOnAddPlayer": "味方の オーロラベールで\n攻撃ダメージを さげた", - "auroraVeilOnAddEnemy": "相手の オーロラベールで\n攻撃ダメージを さげた", - "conditionalProtectOnAdd": "{{moveName}}に 守られた!", - "conditionalProtectOnAddPlayer": "見方が {{moveName}}に 守られた!", - "conditionalProtectOnAddEnemy": "相手が {{moveName}}に 守られた!", - "conditionalProtectApply": "{{pokemonNameWithAffix}}が\n{{moveName}}に 守られた!", - "matBlockOnAdd": "{{pokemonNameWithAffix}}は\nたたみがえしを ねらっている!", - "noCritOnAddPlayer": "{{moveName}}の 力で 味方の急所が 隠れた!", - "noCritOnAddEnemy": "{{moveName}}の 力で 相手の急所が 隠れた!", - "noCritOnRemove": "{{pokemonNameWithAffix}}の {{moveName}}の\n効果が なくなった!", - "wishTagOnAdd": "{{pokemonNameWithAffix}}の\nねがいごとが かなった!", - "mudSportOnAdd": "電気の威力が 弱まった!", - "mudSportOnRemove": "どろあそびの 効果が なくなった!", - "waterSportOnAdd": "炎の威力が 弱まった!", - "waterSportOnRemove": "みずあそびの 効果が なくなった!", - "spikesOnAdd": "{{opponentDesc}}の 足下に\n{{moveName}}が 散らばった!", - "spikesActivateTrap": "{{pokemonNameWithAffix}}は\nまきびしの ダメージを 受けた!", - "toxicSpikesOnAdd": "{{opponentDesc}}の 足下に\n{{moveName}}が 散らばった!", - "toxicSpikesActivateTrapPoison": "{{pokemonNameWithAffix}}は {{moveName}}で 毒を あびた!", - "stealthRockOnAdd": "{{opponentDesc}}の 周りに\nとがった岩が ただよい始めた!", - "stealthRockActivateTrap": "{{pokemonNameWithAffix}}に\nとがった岩が 食い込んだ!", - "stickyWebOnAdd": "相手の 足下に\n{{moveName}}が 広がった!", - "stickyWebActivateTrap": "相手の {{pokemonName}}は\nねばねばネットに ひっかかった!", - "trickRoomOnAdd": "{{pokemonNameWithAffix}}は\n時空を ゆがめた!", - "trickRoomOnRemove": "ゆがんだ 時空が 元に戻った!", - "gravityOnAdd": "じゅうりょくが 強くなった!", - "gravityOnRemove": "じゅうりょくが 元に戻った!", - "tailwindOnAdd": "追い風が 吹き始めた!", - "tailwindOnAddPlayer": "味方に\n追い風が 吹き始めた!", - "tailwindOnAddEnemy": "相手に\n追い風が 吹き始めた!", - "tailwindOnRemove": "追い風が 止んだ!", - "tailwindOnRemovePlayer": "味方の 追い風が 止んだ!", - "tailwindOnRemoveEnemy": "相手の 追い風が 止んだ!", - "happyHourOnAdd": "みんなが ハッピーな気分に\n包まれた!", - "happyHourOnRemove": "みんなの 気分が 元に戻った", - "safeguardOnAdd": "場の全体は 神秘のベールに 包まれた!", - "safeguardOnAddPlayer": "味方は 神秘のベールに 包まれた!", - "safeguardOnAddEnemy": "相手は 神秘のベールに 包まれた!", - "safeguardOnRemove": "場の全体を 包んでいた\n神秘のベールが なくなった!", - "safeguardOnRemovePlayer": "味方を 包んでいた\n神秘のベールが なくなった!", - "safeguardOnRemoveEnemy": "相手を 包んでいた\n神秘のベールが なくなった!" -} diff --git a/src/locales/ja/battle-info.json b/src/locales/ja/battle-info.json deleted file mode 100644 index 2959cdda332..00000000000 --- a/src/locales/ja/battle-info.json +++ /dev/null @@ -1,3 +0,0 @@ -{ - "generation": "{{generation}}世代" -} diff --git a/src/locales/ja/battle-message-ui-handler.json b/src/locales/ja/battle-message-ui-handler.json deleted file mode 100644 index 126d1abf26e..00000000000 --- a/src/locales/ja/battle-message-ui-handler.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "ivBest": "さいこう", - "ivFantastic": "すばらしい", - "ivVeryGood": "すごくいい", - "ivPrettyGood": "かなりいい", - "ivDecent": "まぁまぁ", - "ivNoGood": "ダメかも" -} \ No newline at end of file diff --git a/src/locales/ja/battle-scene.json b/src/locales/ja/battle-scene.json deleted file mode 100644 index 426b6910564..00000000000 --- a/src/locales/ja/battle-scene.json +++ /dev/null @@ -1,3 +0,0 @@ -{ - "moneyOwned": "{{formattedMoney}}円" -} \ No newline at end of file diff --git a/src/locales/ja/battle.json b/src/locales/ja/battle.json deleted file mode 100644 index 1fe24068cdf..00000000000 --- a/src/locales/ja/battle.json +++ /dev/null @@ -1,100 +0,0 @@ -{ - "bossAppeared": "{{bossName}}が 現れた!", - "trainerAppeared": "{{trainerName}}が\n勝負を しかけてきた!", - "trainerAppearedDouble": "{{trainerName}}が\n勝負を しかけてきた!", - "trainerSendOut": "{{trainerName}}は\n{{pokemonName}}を 繰り出した!", - "singleWildAppeared": "あっ! 野生の {{pokemonName}}が 飛び出してきた!", - "multiWildAppeared": "あっ! 野生の {{pokemonName1}}と\n{{pokemonName2}}が 飛び出してきた!", - "playerComeBack": "{{pokemonName}}! 戻れ!", - "trainerComeBack": "{{trainerName}}は\n{{pokemonName}}を 引っ込めた!", - "playerGo": "ゆけっ! {{pokemonName}}!", - "trainerGo": "{{trainerName}}は\n{{pokemonName}}を 繰り出した!", - "switchQuestion": "{{pokemonName}}を\n入れ替えますか?", - "trainerDefeated": "{{trainerName}} との 勝負に 勝った!", - "moneyWon": "賞金として ₽{{moneyAmount}}を 手に入れた!", - "moneyPickedUp": "₽{{moneyAmount}}を 拾った!", - "pokemonCaught": "{{pokemonName}}を 捕まえたぞ!", - "addedAsAStarter": "今から {{pokemonName}}は 最初のパートナーとして 選べられる!", - "partyFull": "手持ちが いっぱいです。\n{{pokemonName}}を入れる ために ポケモンを 一つ 逃がすか?", - "pokemon": "ポケモン", - "sendOutPokemon": "頑張れ! {{pokemonName}}!", - "hitResultCriticalHit": "急所に 当たった!", - "hitResultSuperEffective": "効果は バツグンだ!", - "hitResultNotVeryEffective": "効果は 今ひとつの ようだ……", - "hitResultNoEffect": "{{pokemonName}}には 効果が ないようだ…", - "hitResultImmune": "{{pokemonName}}には\n全然 効いてない!", - "hitResultOneHitKO": "一撃必殺!", - "attackFailed": "しかし うまく 決まらなかった!!", - "attackMissed": "{{pokemonNameWithAffix}}には 当たらなかった!", - "attackHitsCount": "{{count}}かい 当たった!", - "rewardGain": "{{modifierName}}を 手に入れた!", - "expGain": "{{pokemonName}}は\n{{exp}}経験値を もらった!", - "levelUp": "{{pokemonName}}は\nレベル{{level}}に 上がった!", - "learnMove": "{{pokemonName}}は 新しく\n{{moveName}}を 覚えた!", - "learnMovePrompt": "{{pokemonName}}は 新しく\n{{moveName}}を 覚えたい……", - "learnMoveLimitReached": "しかし {{pokemonName}}は 技を 4つ\n覚えるので せいいっぱいだ!", - "learnMoveReplaceQuestion": "{{moveName}}の 代わりに\n他の 技を 忘れさせますか?", - "learnMoveStopTeaching": "それでは {{moveName}}を\n覚えるのを 諦めますか?", - "learnMoveNotLearned": "{{pokemonName}}は {{moveName}}を\n覚えずに 終わった!", - "learnMoveForgetQuestion": "どの 技を\n忘れさせたい?", - "learnMoveForgetSuccess": "{{pokemonName}}は {{moveName}}の\n使い方を きれいに 忘れた!", - "countdownPoof": "@d{32}1 @d{15}2の @d{15}… @d{15}… @d{15}… @d{15}@s{se/pb_bounce_1}ポカン!", - "learnMoveAnd": "そして…", - "levelCapUp": "レベルキャップの\n{{levelCap}}に 上がった!", - "moveNotImplemented": "{{moveName}}は まだ 実装されておらず 選択できません。", - "moveNoPP": "しかし 技の\n残りポイントが なかった!", - "moveDisabled": "かなしばりで\n{{moveName}}が 出せない!", - "disableInterruptedMove": "{{pokemonNameWithAffix}}は かなしばりで\n{{moveName}}が 出せない!", - "noPokeballForce": "見えない 力の せいで\nボールが 投げられない!", - "noPokeballTrainer": "人の ものを 取ったら 泥棒!", - "noPokeballMulti": "相手の ポケモンが 一つしか\nいない 前に ボールが 使えない!", - "noPokeballStrong": "相手の ポケモンが 強すぎて 捕まえられない!\nまずは 弱めよう!", - "noEscapeForce": "見えない 力の せいで\n逃げることが できない!", - "noEscapeTrainer": "ダメだ! 勝負の最中に\n相手に 背中を 見せられない!", - "noEscapePokemon": "{{pokemonName}}の {{moveName}}で\n{{escapeVerb}}!", - "runAwaySuccess": " うまく 逃げ切れた!", - "runAwayCannotEscape": "逃げることが できない!", - "escapeVerbSwitch": "入れ替えることが できない", - "escapeVerbFlee": "逃げることが できない", - "notDisabled": "{{pokemonName}}の かなしばりが 溶けた!\nまた {{moveName}}が 使えられる!", - "turnEndHpRestore": "{{pokemonName}}の 体力が 回復した!", - "hpIsFull": "{{pokemonName}}の\n体力が 満タンだ!", - "skipItemQuestion": "本当に アイテムを 取らずに 進みますか?", - "itemStackFull": "{{fullItemName}}の スタックが いっぱいです。\n代わりに {{itemName}}を 取得します。", - "eggHatching": "おや?", - "eggSkipPrompt": "タマゴは ふかします!\nタマゴまとめに 飛ばしますか?", - "ivScannerUseQuestion": "{{pokemonName}}を\n個体値スキャナーで 操作しますか?", - "wildPokemonWithAffix": "野生の {{pokemonName}}", - "foePokemonWithAffix": "相手の {{pokemonName}}", - "useMove": "{{pokemonNameWithAffix}}の {{moveName}}!", - "drainMessage": "{{pokemonName}}から\n体力を 吸い取った!", - "regainHealth": "{{pokemonName}}は\n体力を 回復した!", - "stealEatBerry": "{{pokemonName}}は {{targetName}}の\n{{berryName}}を うばって 食べた!", - "ppHealBerry": "{{pokemonNameWithAffix}}は {{berryName}}で {{moveName}}のPPを 回復した!", - "hpHealBerry": "{{pokemonNameWithAffix}}は {{berryName}}で 体力を 回復した!", - "fainted": "{{pokemonNameWithAffix}}は 倒れた!", - "statsAnd": "と ", - "stats": "能力", - "statRose_one": "{{pokemonNameWithAffix}}の {{stats}}が 上がった!", - "statRose_other": "{{pokemonNameWithAffix}}の {{stats}}が 上がった!", - "statSharplyRose_one": "{{pokemonNameWithAffix}}の {{stats}}が ぐーんと 上がった!", - "statSharplyRose_other": "{{pokemonNameWithAffix}}の {{stats}}が ぐーんと 上がった!", - "statRoseDrastically_one": "{{pokemonNameWithAffix}}の {{stats}}が ぐぐーんと 上がった!", - "statRoseDrastically_other": "{{pokemonNameWithAffix}}の {{stats}}が ぐぐーんと 上がった!", - "statWontGoAnyHigher_one": "{{pokemonNameWithAffix}}の {{stats}}が もう 上がらない!", - "statWontGoAnyHigher_other": "{{pokemonNameWithAffix}}の {{stats}}が もう 上がらない!", - "statFell_one": "{{pokemonNameWithAffix}}の {{stats}}が 下がった!", - "statFell_other": "{{pokemonNameWithAffix}}の {{stats}}が 下がった!", - "statHarshlyFell_one": "{{pokemonNameWithAffix}}の {{stats}}が がくっと 下がった!", - "statHarshlyFell_other": "{{pokemonNameWithAffix}}の {{stats}}が がくっと 下がった!", - "statSeverelyFell_one": "{{pokemonNameWithAffix}}の {{stats}}が がくーんと 下がった!", - "statSeverelyFell_other": "{{pokemonNameWithAffix}}の {{stats}}が がくーんと 下がった!", - "statWontGoAnyLower_one": "{{pokemonNameWithAffix}}の {{stats}}が もう 下がらない!", - "statWontGoAnyLower_other": "{{pokemonNameWithAffix}}の {{stats}}が もう 下がらない!", - "transformedIntoType": "{{pokemonName}}は\n{{type}}タイプに 変身した!", - "retryBattle": "このバトルの 始まりから やり直しますか?", - "unlockedSomething": "{{unlockedThing}}\nを アンロックした!", - "congratulations": "おめでとうございます!!", - "beatModeFirstTime": "初めて {{speciesName}}が {{gameMode}}モードを クリアした!\n{{newModifier}}を 手に入れた!", - "ppReduced": "{{targetName}}の {{moveName}}を {{reduction}}削った!" -} diff --git a/src/locales/ja/battler-tags.json b/src/locales/ja/battler-tags.json deleted file mode 100644 index f8c6d44c0b4..00000000000 --- a/src/locales/ja/battler-tags.json +++ /dev/null @@ -1,74 +0,0 @@ -{ - "trappedDesc": "捕らわれること", - "flinchedDesc": "ひるむこと", - "confusedDesc": "混乱", - "infatuatedDesc": "メロメロ", - "seedDesc": "種を植えつくこと", - "nightmareDesc": "あくむ", - "ingrainDesc": "根", - "drowsyDesc": "ねむけ", - "rechargingLapse": "{{pokemonNameWithAffix}}は 攻撃の 反動で 動けない!", - "trappedOnAdd": "{{pokemonNameWithAffix}}は もう 逃げられない!", - "trappedOnRemove": "{{pokemonNameWithAffix}}は\n{{moveName}}の 効果が 解けた!", - "flinchedLapse": "{{pokemonNameWithAffix}}は ひるんで 技が出せない!", - "confusedOnAdd": "{{pokemonNameWithAffix}}は 混乱 した!", - "confusedOnRemove": "{{pokemonNameWithAffix}}の 混乱が 解けた!", - "confusedOnOverlap": "{{pokemonNameWithAffix}}は すでに 混乱している!", - "confusedLapse": "{{pokemonNameWithAffix}}は 混乱している!", - "confusedLapseHurtItself": "わけも わからず 自分を 攻撃した!", - "destinyBondLapseIsBoss": "{{pokemonNameWithAffix}}を みちづれに できない!", - "destinyBondLapse": "{{pokemonNameWithAffix}}は 相手を みちづれに した!", - "infatuatedOnAdd": "{{pokemonNameWithAffix}}は {{sourcePokemonName}}に メロメロに なった!", - "infatuatedOnOverlap": "{{pokemonNameWithAffix}}は すでに メロメロだ!", - "infatuatedLapse": "{{pokemonNameWithAffix}}は {{sourcePokemonName}}に メロメロだ!", - "infatuatedLapseImmobilize": "{{pokemonNameWithAffix}}は メロメロで 技が出せなかった!", - "infatuatedOnRemove": "{{pokemonNameWithAffix}}は メロメロ状態が 治った!", - "seededOnAdd": "{{pokemonNameWithAffix}}に 種を 植えつけた!", - "seededLapse": "やどりぎが {{pokemonNameWithAffix}}の 体力を うばう!", - "seededLapseShed": "{{pokemonNameWithAffix}}は ヘドロえきを 吸い取った!", - "nightmareOnAdd": "{{pokemonNameWithAffix}}は あくむを 見始めた!", - "nightmareOnOverlap": "{{pokemonNameWithAffix}}は すでに うなされている!", - "nightmareLapse": "{{pokemonNameWithAffix}}は あくむに うなされている!", - "encoreOnAdd": "{{pokemonNameWithAffix}}は アンコールを 受けた!", - "encoreOnRemove": "{{pokemonNameWithAffix}}の アンコール状態が 解けた!", - "helpingHandOnAdd": "{{pokemonNameWithAffix}}は {{pokemonName}}を\nてだすけする 体制に 入った!", - "ingrainLapse": "{{pokemonNameWithAffix}}は 根から\n養分(ようぶん)を 吸い取った!", - "ingrainOnTrap": "{{pokemonNameWithAffix}}は 根を 張った!", - "aquaRingOnAdd": "{{pokemonNameWithAffix}}は 水のリングを まとった!", - "aquaRingLapse": "{{pokemonName}}は {{moveName}}で\n体力を 回復した!", - "drowsyOnAdd": "{{pokemonNameWithAffix}} の ねむけを 誘(さそ)った!", - "damagingTrapLapse": "{{pokemonNameWithAffix}}は {{moveName}}の ダメージを 受けた!", - "bindOnTrap": "{{pokemonNameWithAffix}}は {{sourcePokemonName}}に 締め付けられた!", - "wrapOnTrap": "{{pokemonNameWithAffix}}は {{sourcePokemonName}}に 巻き付かれた!", - "vortexOnTrap": "{{pokemonNameWithAffix}}は 渦(うず)の中に 閉じ込められた!", - "clampOnTrap": "{{pokemonName}}は {{sourcePokemonNameWithAffix}}の\nからに 挟まれた!", - "sandTombOnTrap": "{{pokemonNameWithAffix}}は {{moveName}}に 捕らわれた!", - "magmaStormOnTrap": "{{pokemonNameWithAffix}}は マグマの\n 渦(うず)に 閉じ込められた!", - "snapTrapOnTrap": "{{pokemonNameWithAffix}}は トラバサミに 捕らわれた!", - "thunderCageOnTrap": "{{sourcePokemonNameWithAffix}}は {{pokemonNameWithAffix}}に 閉じ込められた!", - "infestationOnTrap": "{{pokemonNameWithAffix}}は {{sourcePokemonNameWithAffix}}に まとわりつかれた!", - "protectedOnAdd": "{{pokemonNameWithAffix}}は\nまもりの 体制に 入った!", - "protectedLapse": "{{pokemonNameWithAffix}}は\n攻撃から 身を守った!", - "enduringOnAdd": "{{pokemonNameWithAffix}}は\nこらえる 体制に 入った!", - "enduringLapse": "{{pokemonNameWithAffix}}は\n攻撃を こらえた!", - "sturdyLapse": "{{pokemonNameWithAffix}}は\n攻撃を こらえた!", - "perishSongLapse": "{{pokemonNameWithAffix}}の ほろびのカウントが {{turnCount}}になった!", - "centerOfAttentionOnAdd": "{{pokemonNameWithAffix}}は 注目の 的になった!", - "truantLapse": "{{pokemonNameWithAffix}}は 怠(なま)けている!", - "slowStartOnAdd": "{{pokemonNameWithAffix}}は 調子が 上がらない!", - "slowStartOnRemove": "{{pokemonNameWithAffix}}は 調子を 取り戻した!", - "highestStatBoostOnAdd": "{{pokemonNameWithAffix}}の {{statName}}が\n上がっている 状態に なった!", - "highestStatBoostOnRemove": "{{pokemonNameWithAffix}}の {{abilityName}}の 効果が なくなった!", - "magnetRisenOnAdd": "{{pokemonNameWithAffix}}は 電磁力(でんじりょく)で 浮かび上がった!", - "magnetRisenOnRemove": "{{pokemonNameWithAffix}}は 電磁力(でんじりょく)が なくなった!", - "critBoostOnAdd": "{{pokemonNameWithAffix}}は 張り切っている!", - "critBoostOnRemove": "{{pokemonNameWithAffix}}は 落ち着いた。", - "saltCuredOnAdd": "{{pokemonNameWithAffix}}は しおづけに なった!", - "saltCuredLapse": "{{pokemonNameWithAffix}}は {{moveName}}の\n ダメージを 受けている", - "cursedOnAdd": "{{pokemonNameWithAffix}}は 自分の 体力を 削って\n{{pokemonName}}に のろいを かけた!", - "cursedLapse": "{{pokemonNameWithAffix}}は のろわれている!", - "stockpilingOnAdd": "{{pokemonNameWithAffix}}は {{stockpiledCount}}つ たくわえた!", - "disabledOnAdd": "{{pokemonNameWithAffix}}の\n{{moveName}}\nを 封じこめた!", - "disabledLapse": "{{pokemonNameWithAffix}}の\nかなしばりが 解けた!", - "tarShotOnAdd": "{{pokemonNameWithAffix}}は ほのおに 弱くなった!" -} diff --git a/src/locales/ja/berry.json b/src/locales/ja/berry.json deleted file mode 100644 index 1d1e01296d1..00000000000 --- a/src/locales/ja/berry.json +++ /dev/null @@ -1,46 +0,0 @@ -{ - "SITRUS": { - "name": "オボンのみ", - "effect": "持たせると HPが 50%以下に なるとき HPを 25% 回復する" - }, - "LUM": { - "name": "ラムのみ", - "effect": "持たせると 状態異常や 混乱に なるとき 回復する" - }, - "ENIGMA": { - "name": "ナゾのみ", - "effect": "持たせると 効果バツグンの 技を 受けたとき HPを 25%回復する" - }, - "LIECHI": { - "name": "チイラのみ", - "effect": "持たせると HPが 25%以下に なるとき 攻撃が あがる" - }, - "GANLON": { - "name": "リュガのみ", - "effect": "持たせると HPが 25%以下に なるとき 防御が あがる" - }, - "PETAYA": { - "name": "ヤタピのみ", - "effect": "持たせると HPが 25%以下に なるとき 特攻が あがる" - }, - "APICOT": { - "name": "ズアのみ", - "effect": "持たせると HPが 25%以下に なるとき 特防が あがる" - }, - "SALAC": { - "name": "カムラのみ", - "effect": "持たせると HPが 25%以下に なるとき 素早さが あがる" - }, - "LANSAT": { - "name": "サンのみ", - "effect": "持たせると HPが 25%以下に なるとき 攻撃が 急所に 当たりやすくなる" - }, - "STARF": { - "name": "スターのみ", - "effect": "持たせると HPが 25%以下に なるとき どれか 1つの 能力が ぐーんと あがる" - }, - "LEPPA": { - "name": "ヒメリのみ", - "effect": "持たせると PPが0になる 技の PPを 10回復する" - } -} diff --git a/src/locales/ja/bgm-name.json b/src/locales/ja/bgm-name.json deleted file mode 100644 index fc3d4c0fdd2..00000000000 --- a/src/locales/ja/bgm-name.json +++ /dev/null @@ -1,150 +0,0 @@ -{ - "music": "BGM: ", - "missing_entries": "{{name}}", - "battle_kanto_champion": "B2W2 戦闘!チャンピオン(カントー)", - "battle_johto_champion": "B2W2 戦闘!チャンピオン(ジョウト)", - "battle_hoenn_champion_g5": "B2W2 戦闘!チャンピオン(ホウエン)", - "battle_hoenn_champion_g6": "ORAS 決戦!ダイゴ", - "battle_sinnoh_champion": "B2W2 戦闘!チャンピオン(シンオウ)", - "battle_champion_alder": "BW チャンピオン アデク", - "battle_champion_iris": "B2W2 戦闘!チャンピオンアイリス", - "battle_kalos_champion": "XY 戦闘!チャンピオン", - "battle_alola_champion": "USUM 頂上決戦!ハウ", - "battle_galar_champion": "SWSH 決戦!チャンピオンダンデ", - "battle_champion_geeta": "SV 戦闘!トップチャンピオン", - "battle_champion_nemona": "SV 戦闘!チャンピオンネモ", - "battle_champion_kieran": "SV 戦闘!チャンピオンスグリ", - "battle_hoenn_elite": "ORAS 戦闘!四天王", - "battle_unova_elite": "BW 戦闘!四天王", - "battle_kalos_elite": "XY 戦闘!四天王", - "battle_alola_elite": "SM 戦闘!四天王", - "battle_galar_elite": "SWSH 戦闘!ファイナルトーナメント!", - "battle_paldea_elite": "SV 戦闘!四天王", - "battle_bb_elite": "SV 戦闘!ブルベリーグ四天王", - "battle_final_encounter": "ポケダンDX レックウザ登場", - "battle_final": "BW 戦闘!ゲーチス", - "battle_kanto_gym": "B2W2 戦闘!ジムリーダー(カントー)", - "battle_johto_gym": "B2W2 戦闘!ジムリーダー(ジョウト)", - "battle_hoenn_gym": "B2W2 戦闘!ジムリーダー(ホウエン)", - "battle_sinnoh_gym": "B2W2 戦闘!ジムリーダー(シンオウ)", - "battle_unova_gym": "BW 戦闘!ジムリーダー", - "battle_kalos_gym": "XY 戦闘!ジムリーダー", - "battle_galar_gym": "SWSH 戦闘!ジムリーダー", - "battle_paldea_gym": "SV 戦闘!ジムリーダー", - "battle_legendary_kanto": "XY 戦闘!ミュウツー", - "battle_legendary_raikou": "HGSS 戦闘!ライコウ", - "battle_legendary_entei": "HGSS 戦闘!エンテイ", - "battle_legendary_suicune": "HGSS 戦闘!スイクン", - "battle_legendary_lugia": "HGSS 戦闘!ルギア", - "battle_legendary_ho_oh": "HGSS 戦闘!ホウオウ", - "battle_legendary_regis_g5": "B2W2 戦闘!レジロック・レジアイス・レジスチル", - "battle_legendary_regis_g6": "ORAS 戦闘!レジロック・レジアイス・レジスチル", - "battle_legendary_gro_kyo": "ORAS 戦闘!ゲンシカイキ", - "battle_legendary_rayquaza": "ORAS 戦闘!超古代ポケモン", - "battle_legendary_deoxys": "ORAS 戦闘!デオキシス", - "battle_legendary_lake_trio": "ORAS 戦闘!ユクシー・エムリット・アグノム", - "battle_legendary_sinnoh": "ORAS 戦闘!伝説のポケモン(シンオウ)", - "battle_legendary_dia_pal": "ORAS 戦闘!ディアルガ・パルキア", - "battle_legendary_origin_forme": "LA 戦い:ディアルガ・パルキア(オリジンフォルム)", - "battle_legendary_giratina": "ORAS 戦闘!ギラティナ", - "battle_legendary_arceus": "HGSS アルセウス", - "battle_legendary_unova": "BW 戦闘!伝説のポケモン", - "battle_legendary_kyurem": "BW 戦闘!キュレム", - "battle_legendary_res_zek": "BW 戦闘!ゼクロム・レシラム", - "battle_legendary_xern_yvel": "XY 戦闘!ゼルネアス・イベルタル・ジガルデ", - "battle_legendary_tapu": "SM 戦闘!カプ", - "battle_legendary_sol_lun": "SM 戦闘!ソルガレオ・ルナアーラ", - "battle_legendary_ub": "SM 戦闘!ウルトラビースト", - "battle_legendary_dusk_dawn": "USUM 戦闘!日食・月食ネクロズマ", - "battle_legendary_ultra_nec": "USUM 戦闘!ウルトラネクロズマ", - "battle_legendary_zac_zam": "SWSH 戦闘!ザシアン・ザマゼンタ", - "battle_legendary_glas_spec": "SWSH 戦闘!ブリザポス・レイスポス", - "battle_legendary_calyrex": "SWSH 戦闘!バドレックス", - "battle_legendary_riders": "SWSH 戦闘!豊穣の王", - "battle_legendary_birds_galar": "SWSH 戦闘!伝説のとりポケモン", - "battle_legendary_ruinous": "SV 戦闘!災厄ポケモン", - "battle_legendary_kor_mir": "SV 戦闘!エリアゼロのポケモン", - "battle_legendary_loyal_three": "SV 戦闘!ともっこ", - "battle_legendary_ogerpon": "SV 戦闘!オーガポン", - "battle_legendary_terapagos": "SV 戦闘!テラパゴス", - "battle_legendary_pecharunt": "SV 戦闘!モモワロウ", - "battle_rival": "BW 戦闘!チェレン・ベル", - "battle_rival_2": "BW 戦闘!N", - "battle_rival_3": "BW 決戦!N", - "battle_trainer": "BW 戦闘!トレーナー", - "battle_wild": "BW 戦闘!野生ポケモン", - "battle_wild_strong": "BW 戦闘!強い野生ポケモン", - "end_summit": "ポケダンDX 天空の塔 最上階", - "battle_rocket_grunt": "HGSS 戦闘!ロケット団", - "battle_aqua_magma_grunt": "ORAS 戦闘!アクア団・マグマ団", - "battle_galactic_grunt": "BDSP 戦闘!ギンガ団", - "battle_plasma_grunt": "BW 戦闘!プラズマ団", - "battle_flare_grunt": "XY 戦闘!フレア団", - "battle_aether_grunt": "SM 戦闘!エーテル財団トレーナー", - "battle_skull_grunt": "SM 戦闘!スカル団", - "battle_macro_grunt": "SWSH 戦闘!トレーナー", - "battle_galactic_admin": "BDSP 戦闘!ギンガ団幹部", - "battle_skull_admin": "SM 戦闘!スカル団幹部", - "battle_oleana": "SWSH 戦闘!オリーヴ", - "battle_rocket_boss": "USUM 戦闘!レインボーロケット団ボス", - "battle_aqua_magma_boss": "ORAS 戦闘!アクア団・マグマ団のリーダー", - "battle_galactic_boss": "BDSP 戦闘!ギンガ団ボス", - "battle_plasma_boss": "B2W2 戦闘!ゲーチス", - "battle_flare_boss": "XY 戦闘!フラダリ", - "battle_aether_boss": "SM 戦闘!ルザミーネ", - "battle_skull_boss": "SM 戦闘!スカル団ボス", - "battle_macro_boss": "SWSH 戦闘!ローズ", - - "abyss": "ポケダン空 やみのかこう", - "badlands": "ポケダン空 こかつのたに", - "beach": "ポケダン空 しめったいわば", - "cave": "ポケダン空 そらのいただき(どうくつ)", - "construction_site": "ポケダン空 きょだいがんせきぐん", - "desert": "ポケダン空 きたのさばく", - "dojo": "ポケダン空 ガラガラどうじょう", - "end": "ポケダンDX 天空の塔", - "factory": "ポケダン空 かくされたいせき", - "fairy_cave": "ポケダン空 ほしのどうくつ", - "forest": "ポケダン空 くろのもり", - "grass": "ポケダン空 リンゴのもり", - "graveyard": "ポケダン空 しんぴのもり", - "ice_cave": "ポケダン空 だいひょうざん", - "island": "ポケダン空 えんがんのいわば", - "jungle": "Lmz - Jungle(ジャングル)", - "laboratory": "Firel - Laboratory(ラボラトリー)", - "lake": "ポケダン空 すいしょうのどうくつ", - "meadow": "ポケダン空 そらのいただき(もり)", - "metropolis": "Firel - Metropolis(大都市)", - "mountain": "ポケダン空 ツノやま", - "plains": "ポケダン空 そらのいただき(そうげん)", - "power_plant": "ポケダン空 エレキへいげん", - "ruins": "ポケダン空 ふういんのいわば", - "sea": "Andr06 - Marine Mystique(海の神秘性)", - "seabed": "Firel - Seabed(海底)", - "slum": "Andr06 - Sneaky Snom(ずるいユキハミ)", - "snowy_forest": "ポケダン空 そらのいただき(ゆきやま)", - "space": "Firel - Aether(エーテル)", - "swamp": "ポケダン空 とざされたうみ", - "tall_grass": "ポケダン空 のうむのもり", - "temple": "ポケダン空 ばんにんのどうくつ", - "town": "ポケダン空 ランダムダンジョン3", - "volcano": "ポケダン空 ねっすいのどうくつ", - "wasteland": "ポケダン空 まぼろしのだいち", - "encounter_ace_trainer": "BW 視線!エリートトレーナー", - "encounter_backpacker": "BW 視線!バックパッカー", - "encounter_clerk": "BW 視線!ビジネスマン", - "encounter_cyclist": "BW 視線!サイクリング", - "encounter_lass": "BW 視線!ミニスカート", - "encounter_parasol_lady": "BW 視線!パラソルおねえさん", - "encounter_pokefan": "BW 視線!だいすきクラブ", - "encounter_psychic": "BW 視線!サイキッカー", - "encounter_rich": "BW 視線!ジェントルマン", - "encounter_rival": "BW チェレンのテーマ", - "encounter_roughneck": "BW 視線!スキンヘッズ", - "encounter_scientist": "BW 視線!けんきゅういん", - "encounter_twins": "BW 視線!ふたごちゃん", - "encounter_youngster": "BW 視線!たんぱんこぞう", - "heal": "BW 回復", - "menu": "ポケダン空 ようこそ! ポケモンたちのせかいへ!", - "title": "ポケダン空 トップメニュー" -} diff --git a/src/locales/ja/biome.json b/src/locales/ja/biome.json deleted file mode 100644 index b94810649d4..00000000000 --- a/src/locales/ja/biome.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "unknownLocation": "覚えていない場所", - "TOWN": "タウン", - "PLAINS": "平原", - "GRASS": "草原", - "TALL_GRASS": "長い草むら", - "METROPOLIS": "シティ", - "FOREST": "森", - "SEA": "海", - "SWAMP": "沼", - "BEACH": "海辺", - "LAKE": "湖", - "SEABED": "海底", - "MOUNTAIN": "山", - "BADLANDS": "悪地", - "CAVE": "洞窟", - "DESERT": "砂漠", - "ICE_CAVE": "氷の洞窟", - "MEADOW": "花畑", - "POWER_PLANT": "発電所", - "VOLCANO": "火山", - "GRAVEYARD": "墓場", - "DOJO": "道場", - "FACTORY": "工場", - "RUINS": "古の遺跡", - "WASTELAND": "荒地", - "ABYSS": "深淵", - "SPACE": "宇宙", - "CONSTRUCTION_SITE": "工事現場", - "JUNGLE": "ジャングル", - "FAIRY_CAVE": "フェアリーの洞窟", - "TEMPLE": "神殿", - "SLUM": "スラム", - "SNOWY_FOREST": "雪の森", - "ISLAND": "島", - "LABORATORY": "ラボ", - "END": "???" -} diff --git a/src/locales/ja/challenges.json b/src/locales/ja/challenges.json deleted file mode 100644 index d137df14086..00000000000 --- a/src/locales/ja/challenges.json +++ /dev/null @@ -1,36 +0,0 @@ -{ - "title": "チャレンジの設定", - "illegalEvolution": "{{pokemon}}は このチャレンジで\n対象外の ポケモンに なってしまった!", - "singleGeneration": { - "name": "単一世代", - "desc": "{{gen}}世代からの ポケモンしか 使えません", - "desc_default": "選んだ 世代からの ポケモンしか 使えません", - "gen_1": "1", - "gen_2": "2", - "gen_3": "3", - "gen_4": "4", - "gen_5": "5", - "gen_6": "6", - "gen_7": "7", - "gen_8": "8", - "gen_9": "9" - }, - "singleType": { - "name": "単一タイプ", - "desc": "{{type}}タイプの ポケモンしか 使えません", - "desc_default": "選んだ タイプの ポケモンしか 使えません" - }, - "freshStart": { - "name": "出直し", - "desc": "ポケローグを 始めた ばかりの ような ままで ゲーム開始の スターターしか 使えません", - "value.0": "オフ", - "value.1": "オン" - }, - "inverseBattle": { - "name": "反転バトル", - "shortName": "反バ", - "desc": "タイプ相性が 反転で、なんの タイプも 「効果はなし」が ありません\n他の チャレンジの 実績が 無効に されます", - "value.0": "オフ", - "value.1": "オン" - } -} diff --git a/src/locales/ja/command-ui-handler.json b/src/locales/ja/command-ui-handler.json deleted file mode 100644 index 6248a19785f..00000000000 --- a/src/locales/ja/command-ui-handler.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "fight": "たたかう", - "ball": "ボール", - "pokemon": "ポケモン", - "run": "にげる", - "actionMessage": "{{pokemonName}}は どうする?" -} diff --git a/src/locales/ja/common.json b/src/locales/ja/common.json deleted file mode 100644 index d10e3e42c70..00000000000 --- a/src/locales/ja/common.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "start": "スタート", - "luckIndicator": "運:", - "shinyOnHover": "色違い", - "commonShiny": "ふつう", - "rareShiny": "レア", - "epicShiny": "超レア" -} diff --git a/src/locales/ja/config.ts b/src/locales/ja/config.ts deleted file mode 100644 index f8afd6eb167..00000000000 --- a/src/locales/ja/config.ts +++ /dev/null @@ -1,113 +0,0 @@ -import common from "./common.json"; -import settings from "./settings.json"; -import ability from "./ability.json"; -import abilityTriggers from "./ability-trigger.json"; -import arenaFlyout from "./arena-flyout.json"; -import arenaTag from "./arena-tag.json"; -import achv from "./achv.json"; -import battle from "./battle.json"; -import battleScene from "./battle-scene.json"; -import battleInfo from "./battle-info.json"; -import battleMessageUiHandler from "./battle-message-ui-handler.json"; -import battlerTags from "./battler-tags.json"; -import berry from "./berry.json"; -import bgmName from "./bgm-name.json"; -import biome from "./biome.json"; -import challenges from "./challenges.json"; -import commandUiHandler from "./command-ui-handler.json"; -import dialogue from "./dialogue.json"; -import battleSpecDialogue from "./dialogue-final-boss.json"; -import miscDialogue from "./dialogue-misc.json"; -import doubleBattleDialogue from "./dialogue-double-battle.json"; -import egg from "./egg.json"; -import fightUiHandler from "./fight-ui-handler.json"; -import filterBar from "./filter-bar.json"; -import gameMode from "./game-mode.json"; -import gameStatsUiHandler from "./game-stats-ui-handler.json"; -import growth from "./growth.json"; -import menu from "./menu.json"; -import menuUiHandler from "./menu-ui-handler.json"; -import modifier from "./modifier.json"; -import modifierType from "./modifier-type.json"; -import move from "./move.json"; -import nature from "./nature.json"; -import partyUiHandler from "./party-ui-handler.json"; -import pokeball from "./pokeball.json"; -import pokemon from "./pokemon.json"; -import pokemonForm from "./pokemon-form.json"; -import battlePokemonForm from "./pokemon-form-battle.json"; -import pokemonInfo from "./pokemon-info.json"; -import pokemonInfoContainer from "./pokemon-info-container.json"; -import pokemonSummary from "./pokemon-summary.json"; -import saveSlotSelectUiHandler from "./save-slot-select-ui-handler.json"; -import splashMessages from "./splash-messages.json"; -import starterSelectUiHandler from "./starter-select-ui-handler.json"; -import statusEffect from "./status-effect.json"; -import trainerTitles from "./trainer-titles.json"; -import trainerClasses from "./trainer-classes.json"; -import trainerNames from "./trainer-names.json"; -import tutorial from "./tutorial.json"; -import voucher from "./voucher.json"; -import weather from "./weather.json"; -import terrain from "./terrain.json"; -import modifierSelectUiHandler from "./modifier-select-ui-handler.json"; -import moveTriggers from "./move-trigger.json"; -import runHistory from "./run-history.json"; - -export const jaConfig = { - ability, - abilityTriggers, - arenaFlyout, - arenaTag, - battle, - battleScene, - battleInfo, - battleMessageUiHandler, - battlePokemonForm, - battlerTags, - berry, - bgmName, - biome, - challenges, - commandUiHandler, - common, - achv, - dialogue, - battleSpecDialogue, - miscDialogue, - doubleBattleDialogue, - egg, - fightUiHandler, - filterBar, - gameMode, - gameStatsUiHandler, - growth, - menu, - menuUiHandler, - modifier, - modifierType, - move, - nature, - pokeball, - pokemon, - pokemonForm, - pokemonInfo, - pokemonInfoContainer, - pokemonSummary, - saveSlotSelectUiHandler, - settings, - splashMessages, - starterSelectUiHandler, - statusEffect, - terrain, - titles: trainerTitles, - trainerClasses, - trainerNames, - tutorial, - voucher, - weather, - partyUiHandler, - modifierSelectUiHandler, - moveTriggers, - runHistory, -}; diff --git a/src/locales/ja/dialogue-double-battle.json b/src/locales/ja/dialogue-double-battle.json deleted file mode 100644 index b2632f3b990..00000000000 --- a/src/locales/ja/dialogue-double-battle.json +++ /dev/null @@ -1,84 +0,0 @@ -{ - "blue_red_double": { - "encounter": { - "1": "Blue: Hey Red, let's show them what we're made of!\n$Red: ...\n$Blue: This is Pallet Town Power!" - }, - "victory": { - "1": "Blue: That was a great battle!\n$Red: ..." - } - }, - "red_blue_double": { - "encounter": { - "1": "Red: ...!\n$Blue: He never talks much.\n$Blue: But dont let that fool you! He is a champ after all!" - }, - "victory": { - "1": "Red: ...!\n$Blue: Next time we will beat you!" - } - }, - "tate_liza_double": { - "encounter": { - "1": "Tate: Are you surprised?\n$Liza: We are two gym leaders at once!\n$Tate: We are twins!\n$Liza: We dont need to talk to understand each other!\n$Tate: Twice the power...\n$Liza: Can you handle it?" - }, - "victory": { - "1": "Tate: What? Our combination was perfect!\n$Liza: Looks like we need to train more..." - } - }, - "liza_tate_double": { - "encounter": { - "1": "Liza: Hihihi... Are you surprised?\n$Tate: Yes, we are really two gym leaders at once!\n$Liza: This is my twin brother Tate!\n$Tate: And this is my twin sister Liza!\n$Liza: Don't you think we are a perfect combination?" - }, - "victory": { - "1": "Liza: Are we...\n$Tate: ...not as strong as we thought?" - } - }, - "wallace_steven_double": { - "encounter": { - "1": "Steven: Wallace, let's show them the power of the champions!\n$Wallace: We will show you the power of Hoenn!\n$Steven: Let's go!" - }, - "victory": { - "1": "Steven: That was a great battle!\n$Wallace: We will win next time!" - } - }, - "steven_wallace_double": { - "encounter": { - "1": "Steven: Do you have any rare Pokémon?\n$Wallace: Steven... We are here for a battle, not to show off our Pokémon.\n$Steven: Oh... I see... Let's go then!" - }, - "victory": { - "1": "Steven: Now that we are done with the battle, let's show off our Pokémon!\n$Wallace: Steven..." - } - }, - "alder_iris_double": { - "encounter": { - "1": "Alder: We are the strongest trainers in Unova!\n$Iris: Fights against strong trainers are the best!" - }, - "victory": { - "1": "Alder: Wow! You are super strong!\n$Iris: We will win next time!" - } - }, - "iris_alder_double": { - "encounter": { - "1": "Iris: Welcome Challenger! I am THE Unova Champion!\n$Alder: Iris, aren't you a bit too excited?", - "1_female": "Iris: Welcome Challenger! I am THE Unova Champion!\n$Alder: Iris, aren't you a bit too excited?" - }, - "victory": { - "1": "Iris: A loss like this is not easy to take...\n$Alder: But we will only get stronger with every loss!" - } - }, - "piers_marnie_double": { - "encounter": { - "1": "Marnie: Brother, let's show them the power of Spikemuth!\n$Piers: We bring darkness!" - }, - "victory": { - "1": "Marnie: You brought light to our darkness!\n$Piers: Its too bright..." - } - }, - "marnie_piers_double": { - "encounter": { - "1": "Piers: Ready for a concert?\n$Marnie: Brother... They are here to fight, not to sing...", - "1_female": "Piers: Ready for a concert?\n$Marnie: Brother... They are here to fight, not to sing..." - }, - "victory": { - "1": "Piers: Now that was a great concert!\n$Marnie: Brother..." - } - } -} diff --git a/src/locales/ja/dialogue-final-boss.json b/src/locales/ja/dialogue-final-boss.json deleted file mode 100644 index f20d0f013d1..00000000000 --- a/src/locales/ja/dialogue-final-boss.json +++ /dev/null @@ -1,10 +0,0 @@ -{ - "encounter": "It appears the time has finally come once again.\nYou know why you have come here, do you not?\n$You were drawn here, because you have been here before.\nCountless times.\n$Though, perhaps it can be counted.\nTo be precise, this is in fact your {{cycleCount}} cycle.\n$Each cycle your mind reverts to its former state.\nEven so, somehow, remnants of your former selves remain.\n$Until now you have yet to succeed, but I sense a different presence in you this time.\n\n$You are the only one here, though it is as if there is… another.\n$Will you finally prove a formidable challenge to me?\nThe challenge I have longed after for millennia?\n$We begin.", - "encounter_female": "It appears the time has finally come once again.\nYou know why you have come here, do you not?\n$You were drawn here, because you have been here before.\nCountless times.\n$Though, perhaps it can be counted.\nTo be precise, this is in fact your {{cycleCount}} cycle.\n$Each cycle your mind reverts to its former state.\nEven so, somehow, remnants of your former selves remain.\n$Until now you have yet to succeed, but I sense a different presence in you this time.\n\n$You are the only one here, though it is as if there is… another.\n$Will you finally prove a formidable challenge to me?\nThe challenge I have longed after for millennia?\n$We begin.", - "firstStageWin": "I see. The presence I felt was indeed real.\nIt appears I no longer need to hold back.\n$Do not disappoint me.", - "secondStageWin": "…Magnificent.", - "key_ordinal_one": "st", - "key_ordinal_two": "nd", - "key_ordinal_few": "rd", - "key_ordinal_other": "th" -} diff --git a/src/locales/ja/dialogue-misc.json b/src/locales/ja/dialogue-misc.json deleted file mode 100644 index 2f333b5f383..00000000000 --- a/src/locales/ja/dialogue-misc.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "ending": "@c{shock}You're back?@d{32} Does that mean…@d{96} you won?!\n@c{smile_ehalf}I should have known you had it in you.\n$@c{smile_eclosed}Of course… I always had that feeling.\n@c{smile}It's over now, right? You ended the loop.\n$@c{smile_ehalf}You fulfilled your dream too, didn't you?\nYou didn't lose even once.\n$I'll be the only one to remember what you did.\n@c{angry_mopen}I'll try not to forget!\n$@c{smile_wave_wink}Just kidding!@d{64} @c{smile}I'd never forget.@d{32}\nYour legend will live on in our hearts.\n$@c{smile_wave}Anyway,@d{64} it's getting late…@d{96} I think?\nIt's hard to tell in this place.\n$Let's go home. @c{smile_wave_wink}Maybe tomorrow, we can have another battle, for old time's sake?", - "ending_female": "@c{smile}Oh? You won?@d{96} @c{smile_eclosed}I guess I should've known.\nBut, you're back now.\n$@c{smile}It's over.@d{64} You ended the loop.\n$@c{serious_smile_fists}You fulfilled your dream too, didn't you?\nYou didn't lose even once.\n$@c{neutral}I'm the only one who'll remember what you did.@d{96}\nI guess that's okay, isn't it?\n$@c{serious_smile_fists}Your legend will always live on in our hearts.\n$@c{smile_eclosed}Anyway, I've had about enough of this place, haven't you? Let's head home.\n$@c{serious_smile_fists}Maybe when we get back, we can have another battle?\nIf you're up to it.", - "ending_endless": "Congratulations on reaching the current end!\nMore content is coming soon.", - "ending_name": "Devs" -} diff --git a/src/locales/ja/dialogue.json b/src/locales/ja/dialogue.json deleted file mode 100644 index 6130ade1cb4..00000000000 --- a/src/locales/ja/dialogue.json +++ /dev/null @@ -1,2827 +0,0 @@ -{ - "youngster": { - "encounter": { - "1": "よっ 勝負する?", - "2": "あっ 君も 駆け出し トレーナーだね?", - "2_female": "あっ きみも 駆け出し トレーナーだね?", - "3": "あっ 初めてみる 人! 勝負だ!", - "4": "さっき 負けて 悔しいから ポケモン 探してるんだよ。\nでも 君 弱そうだな…… よしっ! 勝負 しようぜ!", - "4_female": "さっき 負けて 悔しいから ポケモン 探してるんだよ。\nでも 君 弱そうだな…… よしっ! 勝負 しようぜ!", - "5": "お久しぶりかな? 初めましてかな?\n覚えてないけど ヨロシクね!", - "6": "よーし 行くぞー!", - "7": "よっしゃ 行っくぜー!\n僕の パワー 見せてやる!", - "8": "へへへ…… 見せて あげるね!\n僕の ポケモンの すごさを!", - "9": "挨拶 なんて よかよか! いつでも かかってきんしゃい!", - "9_female": "挨拶 なんて よかよか! いつでも かかってきんしゃい!", - "10": "小僧  だからって 油断してると\n君 泣いちゃう かもしれないよー.", - "11": "大事に 育てた ポケモンだぞー!\n絶対 倒しちゃ ダメなんだぞ!", - "12": "よく来たな!\nこっから 先は 一筋縄じゃ いかないぞ!", - "12_female": "よく来たな!\nこっから 先は 一筋縄じゃ いかないぞ!", - "13": "勝負は 続くよ! いつまでも!\n終わりなき 世界へ ようこそ!", - "13_female": "勝負は 続くよ!\nいつまでも! 終わりなき 世界へ ようこそ!" - }, - "victory": { - "1": "スゴッ! 君 強いんだ!", - "1_femal1e": "スゴッ! 君 強いんだ!", - "2": "敵わなかったね?", - "3": "僕 大きくなったら 絶対 君を 倒すよ!", - "4": "ゲッ 戦えるポケモン もう いない…", - "5": "トホ…… トホホーイ……\nまた 負けちゃったよ……", - "5_female": "トホ…… トホホーイ……\nまた 負けちゃったよ……", - "6": "うわー! 負けたー!!", - "7": "すごいな 君の パワーは!\nビックリで ドッキリだよ!", - "8": "そんな…… どうして……\n僕の ポケモンは サイキョー なのに……", - "9": "また バトルして くれよな!\n次は 負けないからな!", - "10": "も~! 僕は 小僧だけ だよ!\nそんな全力で 戦っちゃ ひどいぞ!", - "11": "君の ポケモンの 方が すごい!\n僕のと 交換しておくれよ!", - "12": "さっきは 勢いで 言ったけど\n一筋縄って どんな縄?", - "13": "あはは さすが! さすがだね!\nもう 君も この世界の 住人だ!" - } - }, - "lass": { - "encounter": { - "1": "Let's have a battle, shall we?", - "2": "You look like a new trainer. Let's have a battle!", - "2_female": "You look like a new trainer. Let's have a battle!", - "3": "I don't recognize you. How about a battle?", - "4": "Let's have a fun Pokémon battle!", - "5": "I'll show you the ropes of how to really use Pokémon!", - "6": "A serious battle starts from a serious beginning! Are you sure you're ready?", - "6_female": "A serious battle starts from a serious beginning! Are you sure you're ready?", - "7": "You're only young once. And you only get one shot at a given battle. Soon, you'll be nothing but a memory.", - "8": "You'd better go easy on me, OK? Though I'll be seriously fighting!", - "9": "School is boring. I've got nothing to do. Yawn. I'm only battling to kill the time." - }, - "victory": { - "1": "That was impressive! I've got a lot to learn.", - "2": "I didn't think you'd beat me that bad…", - "2_female": "I didn't think you'd beat me that bad…", - "3": "I hope we get to have a rematch some day.", - "4": "That was pretty amazingly fun! You've totally exhausted me…", - "5": "You actually taught me a lesson! You're pretty amazing!", - "6": "Seriously, I lost. That is, like, seriously depressing, but you were seriously cool.", - "6_female": "Seriously, I lost. That is, like, seriously depressing, but you were seriously cool.", - "7": "I don't need memories like this. Deleting memory…", - "8": "Hey! I told you to go easy on me! Still, you're pretty cool when you're serious.", - "8_female": "Hey! I told you to go easy on me! Still, you're pretty cool when you're serious.", - "9": "I'm actually getting tired of battling… There's gotta be something new to do…" - } - }, - "breeder": { - "encounter": { - "1": "Obedient Pokémon, selfish Pokémon… Pokémon have unique characteristics.", - "2": "Even though my upbringing and behavior are poor, I've raised my Pokémon well.", - "3": "Hmm, do you discipline your Pokémon? Pampering them too much is no good." - }, - "victory": { - "1": "It is important to nurture and train each Pokémon's characteristics.", - "2": "Unlike my diabolical self, these are some good Pokémon.", - "3": "Too much praise can spoil both Pokémon and people." - }, - "defeat": { - "1": "You should not get angry at your Pokémon, even if you lose a battle.", - "2": "Right? Pretty good Pokémon, huh? I'm suited to raising things.", - "3": "No matter how much you love your Pokémon, you still have to discipline them when they misbehave." - } - }, - "breeder_female": { - "encounter": { - "1": "Pokémon never betray you. They return all the love you give them.", - "2": "Shall I give you a tip for training good Pokémon?", - "3": "I have raised these very special Pokémon using a special method." - }, - "victory": { - "1": "Ugh… It wasn't supposed to be like this. Did I administer the wrong blend?", - "2": "How could that happen to my Pokémon… What are you feeding your Pokémon?", - "3": "If I lose, that tells you I was just killing time. It doesn't damage my ego at all." - }, - "defeat": { - "1": "This proves my Pokémon have accepted my love.", - "2": "The real trick behind training good Pokémon is catching good Pokémon.", - "3": "Pokémon will be strong or weak depending on how you raise them." - } - }, - "fisherman": { - "encounter": { - "1": "Aack! You made me lose a bite!\nWhat are you going to do about it?", - "2": "Go away! You're scaring the Pokémon!", - "3": "Let's see if you can reel in a victory!" - }, - "victory": { - "1": "Just forget about it.", - "2": "Next time, I'll be reelin' in the triumph!", - "3": "Guess I underestimated the currents this time." - } - }, - "fisherman_female": { - "encounter": { - "1": "Woah! I've hooked a big one!", - "2": "Line's in, ready to reel in success!", - "3": "Ready to make waves!" - }, - "victory": { - "1": "I'll be back with a stronger hook.", - "2": "I'll reel in victory next time.", - "3": "I'm just sharpening my hooks for the comeback!" - } - }, - "swimmer": { - "encounter": { - "1": "Time to dive in!", - "2": "Let's ride the waves of victory!", - "3": "Ready to make a splash!" - }, - "victory": { - "1": "Drenched in defeat!", - "2": "A wave of defeat!", - "3": "Back to shore, I guess." - } - }, - "backpacker": { - "encounter": { - "1": "Pack up, game on!", - "2": "Let's see if you can keep pace!", - "3": "Gear up, challenger!", - "4": "I've spent 20 years trying to find myself… But where am I?" - }, - "victory": { - "1": "Tripped up this time!", - "2": "Oh, I think I'm lost.", - "3": "Dead end!", - "4": "Wait up a second! Hey! Don't you know who I am?" - } - }, - "ace_trainer": { - "encounter": { - "1": "You seem quite confident.", - "1_female": "You seem quite confident.", - "2": "Your Pokémon… Show them to me…", - "3": "Because I'm an Ace Trainer, people think I'm strong.", - "4": "Are you aware of what it takes to be an Ace Trainer?" - }, - "victory": { - "1": "Yes… You have good Pokémon…", - "2": "What?! But I'm a battling genius!", - "3": "Of course, you are the main character!", - "3_female": "Of course, you are the main character!", - "4": "OK! OK! You could be an Ace Trainer!", - "4_female": "OK! OK! You could be an Ace Trainer!" - }, - "defeat": { - "1": "I am devoting my body and soul to Pokémon battles!", - "2": "All within my expectations… Nothing to be surprised about…", - "3": "I thought I'd grow up to be a frail person who looked like they would break if you squeezed them too hard.", - "4": "Of course I'm strong and don't lose. It's important that I win gracefully." - } - }, - "parasol_lady": { - "encounter": { - "1": "Time to grace the battlefield with elegance and poise!" - }, - "victory": { - "1": "My elegance remains unbroken!" - } - }, - "twins": { - "encounter": { - "1": "Get ready, because when we team up, it's double the trouble!", - "2": "Two hearts, one strategy – let's see if you can keep up with our twin power!", - "3": "Hope you're ready for double trouble, because we're about to bring the heat!", - "3_female": "Hope you're ready for double trouble, because we're about to bring the heat!" - }, - "victory": { - "1": "We may have lost this round, but our bond remains unbreakable!", - "2": "Our twin spirit won't be dimmed for long.", - "3": "We'll come back stronger as a dynamic duo!" - }, - "defeat": { - "1": "Twin power reigns supreme!", - "2": "Two hearts, one triumph!", - "3": "Double the smiles, double the victory dance!" - } - }, - "cyclist": { - "encounter": { - "1": "Get ready to eat my dust!", - "2": "Gear up, challenger! I'm about to leave you in the dust!", - "3": "Pedal to the metal, let's see if you can keep pace!" - }, - "victory": { - "1": "Spokes may be still, but determination pedals on.", - "2": "Outpaced!", - "3": "The road to victory has many twists and turns yet to explore." - } - }, - "black_belt": { - "encounter": { - "1": "I praise your courage in challenging me! For I am the one with the strongest kick!", - "2": "Oh, I see. Would you like to be cut to pieces? Or do you prefer the role of punching bag?", - "2_female": "Oh, I see. Would you like to be cut to pieces? Or do you prefer the role of punching bag?" - }, - "victory": { - "1": "Oh. The Pokémon did the fighting. My strong kick didn't help a bit.", - "2": "Hmmm… If I was going to lose anyway, I was hoping to get totally messed up in the process." - } - }, - "battle_girl": { - "encounter": { - "1": "You don't have to try to impress me. You can lose against me." - }, - "victory": { - "1": "It's hard to say good-bye, but we are running out of time…" - } - }, - "hiker": { - "encounter": { - "1": "My middle-age spread has given me as much gravitas as the mountains I hike!", - "2": "I inherited this big-boned body from my parents… I'm like a living mountain range…" - }, - "victory": { - "1": "At least I cannot lose when it comes to BMI!", - "2": "It's not enough… It's never enough. My bad cholesterol isn't high enough…" - } - }, - "ranger": { - "encounter": { - "1": "When I am surrounded by nature, most other things cease to matter.", - "2": "When I'm living without nature in my life, sometimes I'll suddenly feel an anxiety attack coming on." - }, - "victory": { - "1": "It doesn't matter to the vastness of nature whether I win or lose…", - "2": "Something like this is pretty trivial compared to the stifling feelings of city life." - }, - "defeat": { - "1": "I won the battle. But victory is nothing compared to the vastness of nature…", - "2": "I'm sure how you feel is not so bad if you compare it to my anxiety attacks…" - } - }, - "scientist": { - "encounter": { - "1": "My research will lead this world to peace and joy." - }, - "victory": { - "1": "I am a genius… I am not supposed to lose against someone like you…" - } - }, - "school_kid": { - "encounter": { - "1": "…Heehee. I'm confident in my calculations and analysis.", - "2": "I'm gaining as much experience as I can because I want to be a Gym Leader someday." - }, - "victory": { - "1": "Ohhhh… Calculation and analysis are perhaps no match for chance…", - "2": "Even difficult, trying experiences have their purpose, I suppose." - } - }, - "artist": { - "encounter": { - "1": "I used to be popular, but now I am all washed up." - }, - "victory": { - "1": "As times change, values also change. I realized that too late." - } - }, - "guitarist": { - "encounter": { - "1": "Get ready to feel the rhythm of defeat as I strum my way to victory!" - }, - "victory": { - "1": "Silenced for now, but my melody of resilience will play on." - } - }, - "worker": { - "encounter": { - "1": "It bothers me that people always misunderstand me. I'm a lot more pure than everyone thinks." - }, - "victory": { - "1": "I really don't want my skin to burn, so I want to stay in the shade while I work." - } - }, - "worker_female": { - "encounter": { - "1": "It bothers me that people always misunderstand me.\n$I'm a lot more pure than everyone thinks." - }, - "victory": { - "1": "I really don't want my skin to burn, so I want to stay in the shade while I work." - }, - "defeat": { - "1": "My body and mind aren't necessarily always in sync." - } - }, - "worker_double": { - "encounter": { - "1": "I'll show you we can break you. We've been training in the field!" - }, - "victory": { - "1": "How strange… How could this be… I shouldn't have been outmuscled." - } - }, - "hex_maniac": { - "encounter": { - "1": "I normally only ever listen to classical music, but if I lose, I think I shall try a bit of new age!", - "2": "I grow stronger with each tear I cry." - }, - "victory": { - "1": "Is this the dawning of the age of Aquarius?", - "2": "Now I can get even stronger. I grow with every grudge." - }, - "defeat": { - "1": "New age simply refers to twentieth century classical composers, right?", - "2": "Don't get hung up on sadness or frustration. You can use your grudges to motivate yourself.", - "2_female": "Don't get hung up on sadness or frustration. You can use your grudges to motivate yourself." - } - }, - "psychic": { - "encounter": { - "1": "Hi! Focus!" - }, - "victory": { - "1": "Eeeeek!" - } - }, - "officer": { - "encounter": { - "1": "Brace yourself, because justice is about to be served!", - "2": "Ready to uphold the law and serve justice on the battlefield!" - }, - "victory": { - "1": "The weight of justice feels heavier than ever…", - "2": "The shadows of defeat linger in the precinct." - } - }, - "beauty": { - "encounter": { - "1": "My last ever battle… That's the way I'd like us to view this match…" - }, - "victory": { - "1": "It's been fun… Let's have another last battle again someday…" - } - }, - "baker": { - "encounter": { - "1": "Hope you're ready to taste defeat!", - "1_female": "Hope you're ready to taste defeat!" - }, - "victory": { - "1": "I'll bake a comeback." - } - }, - "biker": { - "encounter": { - "1": "Time to rev up and leave you in the dust!" - }, - "victory": { - "1": "I'll tune up for the next race." - } - }, - "firebreather": { - "encounter": { - "1": "My flames shall devour you!", - "2": "My soul is on fire. I'll show you how hot it burns!", - "3": "Step right up and take a look!" - }, - "victory": { - "1": "I burned down to ashes...", - "2": "Yow! That's hot!", - "3": "Ow! I scorched the tip of my nose!" - } - }, - "sailor": { - "encounter": { - "1": "Matey, you're walking the plank if you lose!", - "2": "Come on then! My sailor's pride is at stake!", - "3": "Ahoy there! Are you seasick?", - "3_female": "Ahoy there! Are you seasick?" - }, - "victory": { - "1": "Argh! Beaten by a kid!", - "2": "Your spirit sank me!", - "3": "I think it's me that's seasick..." - } - }, - "archer": { - "encounter": { - "1": "Before you go any further, let's see how you fare against us, Team Rocket!", - "2": "I have received reports that your skills are not insignificant. Let's see if they are true.", - "3": "I am Archer, an Admin of Team Rocket. And I do not go easy on enemies of our organization." - }, - "victory": { - "1": "What a blunder!", - "2": "With my current skills, I was not up to the task after all.", - "3": "F-forgive me, Giovanni... For me to be defeated by a mere trainer..." - } - }, - "ariana": { - "encounter": { - "1": "Hold it right there! We can't someone on the loose.\n$It's harmful to Team Rocket's pride, you see.", - "2": "I don't know or care if what I'm doing is right or wrong...\n$I just put my faith in Giovanni and do as I am told", - "3": "Your trip ends here. I'm going to take you down!" - }, - "victory": { - "1": "Tch, you really are strong. It's too bad.\n$If you were to join Team Rocket, you could become an Executive.", - "1_female": "Tch, you really are strong. It's too bad.\n$If you were to join Team Rocket, you could become an Executive.", - "2": "I... I'm shattered...", - "3": "Aaaieeeee! This can't be happening! I fought hard, but I still lost…" - } - }, - "proton": { - "encounter": { - "1": "What do you want? If you interrupt our work, don't expect any mercy!", - "2": "What do we have here? I am often labeled as the scariest and cruelest guy in Team Rocket…\n$I strongly urge you not to interfere with our business!", - "3": "I am Proton, an Admin of Team Rocket. I am here to put an end to your meddling!" - }, - "victory": { - "1": "The fortress came down!", - "2": "You may have won this time… But all you did was make Team Rocket's wrath grow…", - "3": "I am defeated… But I will not forget this!" - } - }, - "petrel": { - "encounter": { - "1": "Muhahaha, we've been waiting for you. Me? You don't know who I am? It is me, Giovanni.\n$The majestic Giovanni himself! Wahahaha! …Huh? I don't sound anything like Giovanni?\n$I don't even look like Giovanni? How come? I've worked so hard to mimic him!", - "2": "I am Petrel, an Admin of Team Rocket. I will not allow you to interfere with our plans!", - "3": "Rocket Executive Petrel will deal with this intruder!" - }, - "victory": { - "1": "OK, OK. I'll tell you where he is.", - "2": "I… I couldn't do a thing… Giovanni, please forgive me…", - "3": "No, I can't let this affect me. I have to inform the others…" - } - }, - "tabitha": { - "encounter": { - "1": "Hehehe! So you've come all the way here! But you're too late!", - "2": "Hehehe... Got here already, did you? We underestimated you! But this is it! \n$I'm a cut above the Grunts you've seen so far. I'm not stalling for time.\n$I'm going to pulverize you!", - "3": "I'm going to give you a little taste of pain! Resign yourself to it!" - }, - "victory": { - "1": "Hehehe! You might have beaten me, but you don't stand a chance against the boss!\n$If you get lost now, you won't have to face a sound whipping!", - "2": "Hehehe... So, I lost, too...", - "3": "Ahya! How could this be? For an Admin like me to lose to some random trainer...", - "3_female": "Ahya! How could this be? For an Admin like me to lose to some random trainer..." - } - }, - "courtney": { - "encounter": { - "1": "Don't. Get. In. My. Way.", - "2": "You... ...I want to...analyze. Ahahaha", - "3": "... Well then...Deleting..." - }, - "victory": { - "1": "Hah hah... Uhn...hah hah...", - "2": "As anticipated. Unanticipated. You. Target lock...completed.\n$Commencing...experiment. You. Forever. Aha... ♪", - "3": "That's unanticipated. ...I knew it. You...are interesting! ...Haha. ♪" - } - }, - "shelly": { - "encounter": { - "1": "Ahahahaha! You're going to meddle in Team Aqua's affairs?\n$You're either absolutely fearless, simply ignorant, or both!\n$You're so cute, you're disgusting! I'll put you down", - "2": "What's this? Who's this spoiled brat?", - "3": "Cool your jets. Be patient. I'll crush you shortly.", - "3_female": "Cool your jets. Be patient. I'll crush you shortly." - }, - "victory": { - "1": "Ahahahaha! We got meddled with unexpectedly! We're out of options.\n$We'll have to pull out. But this isn't the last you'll see of Team Aqua!\n$We have other plans! Don't you forget it!", - "2": "Ahhh?! Did I go too easy on you?!", - "3": "Uh. Are you telling me you've upped your game even more during the fight?\n$You're a brat with a bright future… My Pokémon and I don't have any strength left to fight…\n$Go on… Go and be destroyed by Archie.", - "3_female": "Uh. Are you telling me you've upped your game even more during the fight?\n$You're a brat with a bright future… My Pokémon and I don't have any strength left to fight…\n$Go on… Go and be destroyed by Archie." - } - }, - "matt": { - "encounter": { - "1": "All right then, until the boss has time for you, I'll be your opponent!", - "2": "Hooah! Full on! I'm burning up! Well! Welll! Wellllll! Let's battle it out until we've got nothing left!", - "3": "Hoo hah! I'm gonna smash you up!" - }, - "victory": { - "1": "Muwuhahaha! That battle was fun even though I lost!", - "2": "I can feel it! I can feel it, all right! The strength coming offa you!\n$More! I still want more! But looks like we're outta time...", - "3": "Oho! That's a loss I can be proud of!", - "3_female": "Oho! That's a loss I can be proud of!" - } - }, - "mars": { - "encounter": { - "1": "I'm Mars, one of Team Galactic's top Commanders.", - "2": "Team Galactic's vision for the future is unwavering. Opposition will be crushed without mercy!", - "3": "Feeling nervous? You should be!", - "3_female": "Feeling nervous? You should be!" - }, - "victory": { - "1": "This can't be happening! How did I lose?!", - "2": "You have some skill, I'll give you that.", - "3": "Defeated... This was a costly mistake." - } - }, - "jupiter": { - "encounter": { - "1": "Jupiter, Commander of Team Galactic, at your service.", - "2": "Resistance is futile. Team Galactic will prevail!", - "3": "You're trembling... scared already?" - }, - "victory": { - "1": "No way... I lost?!", - "2": "Impressive, you've got guts!", - "3": "Losing like this... How embarrassing." - } - }, - "saturn": { - "encounter": { - "1": "I am Saturn, Commander of Team Galactic.", - "2": "Our mission is absolute. Any hindrance will be obliterated!", - "3": "Is that fear I see in your eyes?" - }, - "victory": { - "1": "Impossible... Defeated by you?!", - "2": "You have proven yourself a worthy adversary.", - "3": "Bestowed in defeat... This is unacceptable." - } - }, - "zinzolin": { - "encounter": { - "1": "You could become a threat to Team Plasma, so we will eliminate you here and now!", - "1_female": "You could become a threat to Team Plasma, so we will eliminate you here and now!", - "2": "You don't have the sense to know when to quit, it seems. It's an act of mercy on my part to bring an end to this now!", - "3": "You're an impressive Trainer to have made it this far. But it ends here.", - "3_female": "You're an impressive Trainer to have made it this far. But it ends here." - }, - "victory": { - "1": "Ghetsis... I have failed you...", - "2": "It's bitter cold. I'm shivering. I'm suffering. Yet, we will stand victorious.", - "3": "Hmph. You're a smarter Trainer than I expected, but not smart enough.", - "3_female": "Hmph. You're a smarter Trainer than I expected, but not smart enough." - } - }, - "rood": { - "encounter": { - "1": "You are a threat to Team Plasma. We cannot let you walk away from here and now!", - "1_female": "You are a threat to Team Plasma. We cannot let you walk away from here and now!", - "2": "It seems you don't know when to give up. I'll make sure no one interferes with our plans!", - "3": "You are a remarkable Trainer to have made it this far. But this is where it ends.", - "3_female": "You are a remarkable Trainer to have made it this far. But this is where it ends." - }, - "victory": { - "1": "Ghetsis... I have failed my mission...", - "2": "The cold is piercing. I'm shivering. I'm suffering. Yet, we will stand triumphant.", - "3": "Hm. You are a talented Trainer, but unfortunately not talented enough." - } - }, - "xerosic": { - "encounter": { - "1": "Ah ha ha! It would be my pleasure. Come on, little Trainer! Let's see what you've got!", - "1_female": "Ah ha ha! It would be my pleasure. Come on, little Trainer! Let's see what you've got!", - "2": "Hmm... You're more powerful than you look. I wonder how much energy there is inside you.", - "2_female": "Hmm... You're more powerful than you look. I wonder how much energy there is inside you.", - "3": "I've been waiting for you! I need to do a little research on you! Come, let us begin!" - }, - "victory": { - "1": "Ah, you're quite strong. Oh yes—very strong, indeed.", - "2": "Ding-ding-ding! You did it! To the victor go the spoils!", - "2_female": "Ding-ding-ding! You did it! To the victor go the spoils!", - "3": "Wonderful! Amazing! You have tremendous skill and bravery!" - } - }, - "bryony": { - "encounter": { - "1": "I am Bryony, and it would be my pleasure to battle you. Show me what you've got.", - "2": "Impressive... You're more powerful than you appear. Let's see the true extent of your energy.", - "2_female": "Impressive... You're more powerful than you appear. Let's see the true extent of your energy.", - "3": "I've anticipated your arrival. It's time for a little test. Shall we begin?" - }, - "victory": { - "1": "You're quite strong. Oh yes—very strong, indeed.", - "2": "Ding-ding-ding! You've done well. Victory is yours.", - "3": "Wonderful! Remarkable! Your skill and bravery are commendable." - } - }, - "rocket_grunt": { - "encounter": { - "1": "Prepare for trouble!", - "2": "We're pulling a big job here! Get lost, kid!", - "2_female": "We're pulling a big job here! Get lost, kid!", - "3": "Hand over your Pokémon, or face the wrath of Team Rocket!", - "4": "You're about to experience the true terror of Team Rocket!", - "5": "Hey, kid! Me am a Team Rocket member kind of guy!", - "5_female": "Hey, kid! Me am a Team Rocket member kind of guy!" - }, - "victory": { - "1": "Team Rocket blasting off again!", - "2": "Oh no! I dropped the Lift Key!", - "3": "I blew it!", - "4": "My associates won't stand for this!", - "5": "You say what? Team Rocket bye-bye a go-go? Broken it is says you?" - } - }, - "magma_grunt": { - "encounter": { - "1": "If you get in the way of Team Magma, don’t expect any mercy!", - "2": "You'd better not interfere with our plans! We're making the world a better place!", - "3": "You're in the way! Team Magma has no time for kids like you!", - "4": "I hope you brought marshmallows because things are about to heat up!", - "5": "We're going to use the power of a volcano! It's gonna be... explosive! Get it? Heh heh!" - }, - "victory": { - "1": "Huh? I lost?!", - "2": "I can't believe I lost! I even skipped lunch for this", - "3": "No way! You're just a kid!", - "3_female": "No way! You're just a kid!", - "4": "Urrrgh... I should've ducked into our hideout right away...", - "5": "You beat me... Do you think the boss will dock my pay for this?" - } - }, - "aqua_grunt": { - "encounter": { - "1": "No one who crosses Team Aqua gets any mercy, not even kids!", - "2": "Grrr... You've got some nerve meddling with Team Aqua!", - "3": "You're about to get soaked! And not just from my water Pokémon!", - "4": "We, Team Aqua, exist for the good of all!", - "5": "Prepare to be washed away by the tides of my... uh, Pokémon! Yeah, my Pokémon!" - }, - "victory": { - "1": "You're kidding me!", - "2": "Arrgh, I didn't count on being meddled with by some meddling kid!", - "3": "I lost?! Guess I'll have to swim back to the hideout now...", - "4": "Oh, man, what a disaster... The boss is going to be furious...", - "5": "You beat me... Do you think the boss will make me walk the plank for this?" - } - }, - "galactic_grunt": { - "encounter": { - "1": "Don't mess with Team Galactic!", - "2": "Witness the power of our technology and the future we envision!", - "3": "In the name of Team Galactic, I'll eliminate anyone who stands in our way!", - "4": "Get ready to lose!", - "5": "Hope you're ready for a cosmic beatdown!", - "5_female": "Hope you're ready for a cosmic beatdown!" - }, - "victory": { - "1": "Shut down...", - "2": "This setback means nothing in the grand scheme.", - "3": "Our plans are bigger than this defeat.", - "4": "How?!", - "5": "Note to self: practice Pokémon battling, ASAP." - } - }, - "plasma_grunt": { - "encounter": { - "1": "We won't tolerate people who have different ideas!", - "2": "If I win against you, release your Pokémon!", - "3": "If you get in the way of Team Plasma, I'll take care of you!", - "4": "Team Plasma will liberate Pokémon from selfish humans like you!", - "5": "Our hairstyles are out of this world... but our battling skills? You'll find out soon enough." - }, - "victory": { - "1": "Plasmaaaaaaaaa!", - "2": "How could I lose...", - "3": "...What a weak Pokémon, I'll just have to go steal some better ones!", - "4": "Great plans are always interrupted.", - "5": "This is bad... Badbadbadbadbadbadbad! Bad for Team Plasma! Or Plasbad, for short!" - } - }, - "flare_grunt": { - "encounter": { - "1": "Your Pokémon are no match for the elegance of Team Flare.", - "2": "Hope you brought your sunglasses, because things are about to get bright!", - "2_female": "Hope you brought your sunglasses, because things are about to get bright!", - "3": "Team Flare will cleanse the world of imperfection!", - "4": "Prepare to face the brilliance of Team Flare!", - "5": "Fashion is most important to us!" - }, - "victory": { - "1": "The future doesn't look bright for me.", - "2": "Perhaps there's more to battling than I thought. Back to the drawing board.", - "3": "Gahh?! I lost?!", - "4": "Even in defeat, Team Flare's elegance shines through.", - "5": "You may have beaten me, but when I lose, I go out in style!" - } - }, - "aether_grunt": { - "encounter": { - "1": "I'll fight you with all I have to wipe you out!", - "2": "I don't care if you're a kid or what. I'll send you flying if you threaten us!", - "2_female": "I don't care if you're a kid or what. I'll send you flying if you threaten us!", - "3": "I was told to turn away Trainers, whomever they might be!", - "4": "I'll show you the power of Aether Paradise!", - "5": "Now that you've learned of the darkness at the heart of Aether Paradise, we'll need you to conveniently disappear!" - }, - "victory": { - "1": "Hmph! You seem to have a lot of skill.", - "2": "What does this mean? What does this mean!", - "3": "Hey! You're so strong that there's no way I can turn you away!", - "4": "Hmm... It seems as though I may have lost.", - "5": "Here's an impression for you: Aiyee!" - } - }, - "faba": { - "encounter": { - "1": "I, Branch Chief Faba, shall show you the harshness of the real world!", - "2": "The man who is called Aether Paradise's last line of defense is to battle a mere child?", - "2_female": "The man who is called Aether Paradise's last line of defense is to battle a mere child?", - "3": "I, Faba, am the Aether Branch Chief. The only one in the world, I'm irreplaceable." - }, - "victory": { - "1": "Aiyee!", - "2": "H-h-how can this be?! How could this child...", - "2_female": "H-h-how can this be?! How could this child...", - "3": "This is why... This is why I can't bring myself to like children." - } - }, - "skull_grunt": { - "encounter": { - "1": "We're not bad-we're just hard!", - "2": "You want some? That's how we say hello! Nice knowing you, punks!", - "2_female": "You want some? That's how we say hello! Nice knowing you, punks!", - "3": "We're just a bunch of guys and gals with a great interest in other people's Pokémon!", - "4": "Why you trying to act hard when we're already hard as bones out here, homie?", - "4_female": "Why you trying to act hard when we're already hard as bones out here, homie?", - "5": "Team Skull represent! We can't pay the rent! Had a lot of fun, but our youth was misspent!", - "5_female": "Team Skull represent! We can't pay the rent! Had a lot of fun, but our youth was misspent!" - }, - "victory": { - "1": "Huh? Is it over already?", - "2": "Time for us to break out, yo! Gotta tell y'all peace out, yo!", - "3": "We don't need your wack Pokémon anyway!", - "4": "Wha-?! This kid's way too strong-no bones about it!", - "5": "So, what? I'm lower than a Pokémon?! I already got self-esteem issues, man." - } - }, - "plumeria": { - "encounter": { - "1": " ...Hmph. You don't look like anything special to me.", - "1_female": " ...Hmph. You don't look like anything special to me.", - "2": "It takes these dumb Grunts way too long to deal with you kids...", - "3": "Mess with anyone in Team Skull, and I'll show you how serious I can get." - }, - "victory": { - "1": "Hmmph! You're pretty strong. I'll give you that.", - "1_female": "Hmmph! You're pretty strong. I'll give you that.", - "2": "Hmmph. Guess you are pretty tough. Now I understand why my Grunts waste so much time battling kids.", - "3": "Hmmph! I guess I just have to hold that loss." - } - }, - "macro_grunt": { - "encounter": { - "1": "It looks like this is the end of the line for you!", - "2": "You are a trainer aren't you? I'm afraid that doesn't give you the right to interfere in our work.", - "2_female": "You are a trainer aren't you? I'm afraid that doesn't give you the right to interfere in our work.", - "3": "I'm from Macro Cosmos Insurance! Do you have a life insurance policy?" - }, - "victory": { - "1": "I have little choice but to respectfully retreat.", - "2": "Having to give up my pocket money... Losing means I'm back in the red...", - "3": "Nobody can beat Macro Cosmos when it comes to our dedication to our work!" - } - }, - "oleana": { - "encounter": { - "1": "I won't let anyone interfere with Mr. Rose's plan!", - "2": "So, you got through all of the special staff that I had ordered to stop you. I would expect nothing less.", - "3": "For the chairman! I won't lose!" - }, - "victory": { - "1": "*sigh* I wasn't able to win... Oleana...you really are a hopeless woman.", - "2": "Arghhh! This is inexcusable... What was I thinking... Any trainer who's made it this far would be no pushover..", - "2_female": "Arghhh! This is inexcusable... What was I thinking... Any trainer who's made it this far would be no pushover..", - "3": "*sigh* I am one tired Oleana..." - } - }, - "rocket_boss_giovanni_1": { - "encounter": { - "1": "So! I must say, I am impressed you got here!" - }, - "victory": { - "1": "WHAT! This cannot be!" - }, - "defeat": { - "1": "Mark my words. Not being able to measure your own strength shows that you are still a child.", - "1_female": "Mark my words. Not being able to measure your own strength shows that you are still a child." - } - }, - "rocket_boss_giovanni_2": { - "encounter": { - "1": "My old associates need me... Are you going to get in my way?" - }, - "victory": { - "1": "How is this possible...? The precious dream of Team Rocket has become little more than an illusion..." - }, - "defeat": { - "1": "Team Rocket will be reborn again, and I will rule the world!" - } - }, - "magma_boss_maxie_1": { - "encounter": { - "1": "I will bury you by my own hand. I hope you appreciate this honor!" - }, - "victory": { - "1": "Ugh! You are... quite capable...\nI fell behind, but only by an inch..." - }, - "defeat": { - "1": "Team Magma will prevail!" - } - }, - "magma_boss_maxie_2": { - "encounter": { - "1": "You are the final obstacle remaining between me and my goals.\n$Brace yourself for my ultimate attack! Fuhahaha!" - }, - "victory": { - "1": "This... This is not.. Ngh..." - }, - "defeat": { - "1": "And now... I will transform this planet to a land ideal for humanity." - } - }, - "aqua_boss_archie_1": { - "encounter": { - "1": "I'm the leader of Team Aqua, so I'm afraid it's the rope's end for you." - }, - "victory": { - "1": "Let's meet again somewhere. I'll be sure to remember that face." - }, - "defeat": { - "1": "Brilliant! My team won't hold back now!" - } - }, - "aqua_boss_archie_2": { - "encounter": { - "1": "I've been waiting so long for this day to come.\nThis is the true power of my team!" - }, - "victory": { - "1": "Like I figured..." - }, - "defeat": { - "1": "I'll return everything in this world to its original, pure state!!" - } - }, - "galactic_boss_cyrus_1": { - "encounter": { - "1": "You were compelled to come here by such vacuous sentimentality.\n$I will make you regret paying heed to your heart!", - "1_female": "You were compelled to come here by such vacuous sentimentality.\n$I will make you regret paying heed to your heart!" - }, - "victory": { - "1": "Interesting. And quite curious." - }, - "defeat": { - "1": "I will create my new world..." - } - }, - "galactic_boss_cyrus_2": { - "encounter": { - "1": "So we meet again. It seems our fates have become intertwined.\n$But here and now, I will finally break that bond!" - }, - "victory": { - "1": "How? How? HOW?!" - }, - "defeat": { - "1": "Farewell." - } - }, - "plasma_boss_ghetsis_1": { - "encounter": { - "1": "I won't allow anyone to stop me! No matter who does what!" - }, - "victory": { - "1": "How can this be? I'm the creator of Team Plasma! I'm perfect!" - }, - "defeat": { - "1": "I am the perfect ruler of a perfect new world! Mwa ha ha!" - } - }, - "plasma_boss_ghetsis_2": { - "encounter": { - "1": "Come now! I want to see your face at the moment you lose all hope!" - }, - "victory": { - "1": "My calculations... No! My careful schemes! The world should be mine!" - }, - "defeat": { - "1": "Kyurem! Use Absofusion!" - } - }, - "flare_boss_lysandre_1": { - "encounter": { - "1": "Do you want to stop me? Show me in battle." - }, - "victory": { - "1": "You are here to stop me. But I ask you to wait. " - }, - "defeat": { - "1": "Pokemon...Shall no longer exist." - } - }, - "flare_boss_lysandre_2": { - "encounter": { - "1": "The future you want, or the future I want... Let us see which one is more deserving, shall we?" - }, - "victory": { - "1": "Whaugh!" - }, - "defeat": { - "1": "Fools with no vision will continue to befoul this beautiful world." - } - }, - "aether_boss_lusamine_1": { - "encounter": { - "1": "You're going to startle my sweet beast! It looks like I'll need to silence you first." - }, - "victory": { - "1": "How... how can you be so awful!" - }, - "defeat": { - "1": "Hmph..." - } - }, - "aether_boss_lusamine_2": { - "encounter": { - "1": "Why must you continue to pester me?! I am sick of you. Sick through and through!\n$Enough with this useless talk.. with Nihilego's power I will show you how wrong you were to come here!" - }, - "victory": { - "1": "Aaauuuggghhhhhhhhh!!!" - }, - "defeat": { - "1": "All that I want is my precious beast! I don't care about any of the rest of you!" - } - }, - "skull_boss_guzma_1": { - "encounter": { - "1": "The hated boss who beats you down and beats you down and never lets up...\n$Yeah. Big bad Guzma is here!" - }, - "victory": { - "1": "Tch. I'm gonna beat you down one of these days!" - }, - "defeat": { - "1": "And you came all the way out here just for that, huh?" - } - }, - "skull_boss_guzma_2": { - "encounter": { - "1": "Doesn't matter who I'm up against, I'm gonna beat them down!\n$That's what big bad Guzma is all about!" - }, - "victory": { - "1": "Guzma!!! What is wrong with you?!" - }, - "defeat": { - "1": "Y'all are stupid!" - } - }, - "macro_boss_rose_1": { - "encounter": { - "1": "I must provide limitless energy to ensure everlasting prosperity for everyone...\n$It is my purpose, my duty, my destiny!" - }, - "victory": { - "1": "You still don't understand, trainer...\n$We... No, I am going to change the course of history!" - }, - "defeat": { - "1": "You still don't understand a thing!" - } - }, - "macro_boss_rose_2": { - "encounter": { - "1": "I'm committed to solving the energy problem in the Galar region—and, of course, around the world.\n$My experience and accomplishments that made Macro Cosmos a success are proof my methods work.\n$I don't intend to change my mind, even if I lose." - }, - "victory": { - "1": "I'd forgotten how great Pokémon battles are! It's been so long since I battled...\n$That sure was satisfying, I accept defeat for this battle." - }, - "defeat": { - "1": "I suppose it must seem that I am doing something terrible. I don't expect you to understand.\n$But I must provide the Galar region with limitless energy to ensure everlasting prosperity." - } - }, - "brock": { - "encounter": { - "1": "My expertise on Rock-type Pokémon will take you down! Come on!", - "2": "My rock-hard willpower will overwhelm you!", - "3": "Allow me to show you the true strength of my Pokémon!" - }, - "victory": { - "1": "Your Pokémon's strength have overcome my rock-hard defenses!", - "2": "The world is huge! I'm glad to have had a chance to battle you.", - "3": "Perhaps I should go back to pursuing my dream as a Pokémon Breeder…" - }, - "defeat": { - "1": "The best offense is a good defense!\nThat's my way of doing things!", - "2": "Come study rocks with me next time to better learn how to fight them!", - "3": "Hah, all my traveling around the regions is paying off!" - } - }, - "misty": { - "encounter": { - "1": "My policy is an all out offensive with Water-type Pokémon!", - "1_female": "My policy is an all out offensive with Water-type Pokémon!", - "2": "Hiya, I'll show you the strength of my aquatic Pokémon!", - "3": "My dream was to go on a journey and battle powerful trainers…\nWill you be a sufficient challenge?" - }, - "victory": { - "1": "You really are strong… I'll admit that you are skilled…", - "2": "Grrr… You know you just got lucky, right?!", - "3": "Wow, you're too much! I can't believe you beat me!" - }, - "defeat": { - "1": "Was the mighty Misty too much for you?", - "2": "I hope you saw my Pokémon's elegant swimming techniques!", - "3": "Your Pokémon were no match for my pride and joys!" - } - }, - "lt_surge": { - "encounter": { - "1": "My Electric Pokémon saved me during the war! I'll show you how!", - "1_female": "My Electric Pokémon saved me during the war! I'll show you how!", - "2": "Ten-hut! I'll shock you into surrender!", - "3": "I'll zap you just like I do to all my enemies in battle!" - }, - "victory": { - "1": "Whoa! Your team's the real deal, kid!", - "2": "Aaargh, you're strong! Even my electric tricks lost against you.", - "2_female": "Aaargh, you're strong! Even my electric tricks lost against you.", - "3": "That was an absolutely shocking loss!" - }, - "defeat": { - "1": "Oh yeah! When it comes to Electric-type Pokémon, I'm number one in the world!", - "2": "Hahaha! That was an electrifying battle, kid!", - "3": "A Pokémon battle is war, and I have showed you first-hand combat!" - } - }, - "erika": { - "encounter": { - "1": "Ah, the weather is lovely here…\nOh, a battle? Very well then.", - "2": "My Pokémon battling skills rival that of my flower arranging skills.", - "3": "Oh, I hope the pleasant aroma of my Pokémon doesn't put me to sleep again…", - "4": "Seeing flowers in a garden is so soothing." - }, - "victory": { - "1": "Oh! I concede defeat.", - "2": "That match was most delightful.", - "3": "Ah, it appears it is my loss…", - "4": "Oh, my goodness." - }, - "defeat": { - "1": "I was afraid I would doze off…", - "2": "Oh my, it seems my Grass Pokémon overwhelmed you.", - "2_female": "Oh my, it seems my Grass Pokémon overwhelmed you.", - "3": "That battle was such a soothing experience.", - "4": "Oh… Is that all?" - } - }, - "janine": { - "encounter": { - "1": "I am mastering the art of poisonous attacks.\nI shall spar with you today!", - "2": "Father trusts that I can hold my own.\nI will prove him right!", - "3": "My ninja techniques are only second to my Father's!\nCan you keep up?" - }, - "victory": { - "1": "Even now, I still need training… I understand.", - "2": "Your battle technique has outmatched mine.", - "3": "I'm going to really apply myself and improve my skills." - }, - "defeat": { - "1": "Fufufu… the poison has sapped all your strength to battle.", - "2": "Ha! You didn't stand a chance against my superior ninja skills!", - "3": "Father's faith in me has proven to not be misplaced." - } - }, - "sabrina": { - "encounter": { - "1": "Through my psychic ability, I had a vision of your arrival!", - "2": "I dislike fighting, but if you wish, I will show you my powers!", - "3": "I can sense great ambition in you. I shall see if it not unfounded." - }, - "victory": { - "1": "Your power… It far exceeds what I foresaw…", - "2": "I failed to accurately predict your power.", - "3": "Even with my immense psychic powers, I cannot sense another as strong as you." - }, - "defeat": { - "1": "This victory… It is exactly as I foresaw in my visions!", - "2": "Perhaps it was another I sensed a great desire in…", - "3": "Hone your abilities before recklessly charging into battle.\nYou never know what the future may hold if you do…" - } - }, - "blaine": { - "encounter": { - "1": "Hah! Hope you brought a Burn Heal!", - "2": "My fiery Pokémon will incinerate all challengers!", - "3": "Get ready to play with fire!" - }, - "victory": { - "1": "I have burned down to nothing! Not even ashes remain!", - "2": "Didn't I stoke the flames high enough?", - "3": "I'm all burned out… But this makes my motivation to improve burn even hotter!" - }, - "defeat": { - "1": "My raging inferno cannot be quelled!", - "2": "My Pokémon have been powered up with the heat from this victory!", - "3": "Hah! My passion burns brighter than yours!" - } - }, - "giovanni": { - "encounter": { - "1": "I, the leader of Team Rocket, will make you feel a world of pain!", - "2": "My training here will be vital before I am to face my old associates again.", - "3": "I do not think you are prepared for the level of failure you are about to experience!", - "3_female": "I do not think you are prepared for the level of failure you are about to experience!" - }, - "victory": { - "1": "WHAT! Me, lose?! There is nothing I wish to say to you!", - "2": "Hmph… You could never understand what I hope to achieve.", - "3": "This defeat is merely delaying the inevitable.\nI will rise Team Rocket from the ashes in due time." - }, - "defeat": { - "1": "Not being able to measure your own strength shows that you are still but a child.", - "2": "Do not try to interfere with me again.", - "3": "I hope you understand how foolish challenging me was." - } - }, - "roxanne": { - "encounter": { - "1": "Would you kindly demonstrate how you battle?", - "2": "You can learn many things by battling many trainers.", - "3": "Oh, you caught me strategizing.\nWould you like to battle?" - }, - "victory": { - "1": "Oh, I appear to have lost.\nI understand.", - "2": "It seems that I still have so much more to learn when it comes to battle.", - "3": "I'll take what I learned here today to heart." - }, - "defeat": { - "1": "I have learned many things from our battle.\nI hope you have too.", - "2": "I look forward to battling you again.\nI hope you'll use what you've learned here.", - "3": "I won due to everything I have learned." - } - }, - "brawly": { - "encounter": { - "1": "Oh man, a challenger!\nLet's see what you can do!", - "1_female": "Oh man, a challenger!\nLet's see what you can do!", - "2": "You seem like a big splash.\nLet's battle!", - "3": "Time to create a storm!\nLet's go!" - }, - "victory": { - "1": "Oh woah, you've washed me out!", - "2": "You surfed my wave and crashed me down!", - "3": "I feel like I'm lost in Granite Cave!" - }, - "defeat": { - "1": "Haha, I surfed the big wave!\nChallenge me again sometime.", - "2": "Surf with me again some time!", - "3": "Just like the tides come in and out, I hope you return to challenge me again." - } - }, - "wattson": { - "encounter": { - "1": "Time to get shocked!\nWahahahaha!", - "2": "I'll make sparks fly!\nWahahahaha!", - "3": "I hope you brought Paralyz Heal!\nWahahahaha!" - }, - "victory": { - "1": "Seems like I'm out of charge!\nWahahahaha!", - "2": "You've completely grounded me!\nWahahahaha!", - "3": "Thanks for the thrill!\nWahahahaha!" - }, - "defeat": { - "1": "Recharge your batteries and challenge me again sometime!\nWahahahaha!", - "1_female": "Recharge your batteries and challenge me again sometime!\nWahahahaha!", - "2": "I hope you found our battle electrifying!\nWahahahaha!", - "3": "Aren't you shocked I won?\nWahahahaha!" - } - }, - "flannery": { - "encounter": { - "1": "Nice to meet you! Wait, no…\nI will crush you!", - "2": "I've only been a leader for a little while, but I'll smoke you!", - "3": "It's time to demonstrate the moves my grandfather has taught me! Let's battle!" - }, - "victory": { - "1": "You remind me of my grandfather…\nNo wonder I lost.", - "2": "Am I trying too hard?\nI should relax, can't get too heated.", - "3": "Losing isn't going to smother me out.\nTime to reignite training!" - }, - "defeat": { - "1": "I hope I've made my grandfather proud…\nLet's battle again some time.", - "2": "I…I can't believe I won!\nDoing things my way worked!", - "3": "Let's exchange burning hot moves again soon!" - } - }, - "norman": { - "encounter": { - "1": "I'm surprised you managed to get here.\nLet's battle.", - "2": "I'll do everything in my power as a Gym Leader to win.\nLet's go!", - "3": "You better give this your all.\nIt's time to battle!" - }, - "victory": { - "1": "I lost to you…?\nRules are rules, though.", - "2": "Was moving from Olivine a mistake…?", - "3": "I can't believe it.\nThat was a great match." - }, - "defeat": { - "1": "We both tried our best.\nI hope we can battle again soon.", - "2": "You should try challenging my kid instead.\nYou might learn something!", - "3": "Thank you for the excellent battle.\nBetter luck next time." - } - }, - "winona": { - "encounter": { - "1": "I've been soaring the skies looking for prey…\nAnd you're my target!", - "2": "No matter how our battle is, my Flying Pokémon and I will triumph with grace. Let's battle!", - "3": "I hope you aren't scared of heights.\nLet's ascend!" - }, - "victory": { - "1": "You're the first Trainer I've seen with more grace than I.\nExcellently played.", - "1_female": "You're the first Trainer I've seen with more grace than I.\nExcellently played.", - "2": "Oh, my Flying Pokémon have plummeted!\nVery well.", - "3": "Though I may have fallen, my Pokémon will continue to fly!" - }, - "defeat": { - "1": "My Flying Pokémon and I will forever dance elegantly!", - "2": "I hope you enjoyed our show.\nOur graceful dance is finished.", - "3": "Won't you come see our elegant choreography again?" - } - }, - "tate": { - "encounter": { - "1": "Hehehe…\nWere you surprised to see me without my sister?", - "1_female": "Hehehe…\nWere you surprised to see me without my sister?", - "2": "I can see what you're thinking…\nYou want to battle!", - "3": "How can you defeat someone…\nWho knows your every move?" - }, - "victory": { - "1": "It can't be helped…\nI miss Liza…", - "2": "Your bond with your Pokémon was stronger than mine.", - "3": "If I were with Liza, we would have won.\nWe can finish each other's thoughts!" - }, - "defeat": { - "1": "My Pokémon and I are superior!", - "2": "If you can't even defeat me, you'll never be able to defeat Liza either.", - "3": "It's all thanks to my strict training with Liza.\nI can make myself one with Pokémon." - } - }, - "liza": { - "encounter": { - "1": "Fufufu…\nWere you surprised to see me without my brother?", - "1_female": "Fufufu…\nWere you surprised to see me without my brother?", - "2": "I can determine what you desire…\nYou want to battle, don't you?", - "3": "How can you defeat someone…\nWho's one with their Pokémon?" - }, - "victory": { - "1": "It can't be helped…\nI miss Tate…", - "2": "Your bond with your Pokémon…\nIt's stronger than mine.", - "3": "If I were with Tate, we would have won.\nWe can finish each other's sentences!" - }, - "defeat": { - "1": "My Pokémon and I are victorious.", - "2": "If you can't even defeat me, you'll never be able to defeat Tate either.", - "3": "It's all thanks to my strict training with Tate.\nI can synchronize myself with my Pokémon." - } - }, - "juan": { - "encounter": { - "1": "Now's not the time to act coy.\nLet's battle!", - "2": "Ahahaha, You'll be witness to my artistry with Water Pokémon!", - "3": "A typhoon approaches!\nWill you be able to test me?", - "4": "Please, you shall bear witness to our artistry.\nA grand illusion of water sculpted by my Pokémon and myself!" - }, - "victory": { - "1": "You may be a genius who can take on Wallace!", - "2": "I focused on elegance while you trained.\nIt's only natural that you defeated me.", - "3": "Ahahaha!\nVery well, You have won this time.", - "4": "From you, I sense the brilliant shine of skill that will overcome all." - }, - "defeat": { - "1": "My Pokémon and I have sculpted an illusion of Water and come out victorious.", - "2": "Ahahaha, I have won, and you have lost.", - "3": "Shall I loan you my outfit? It may help you battle!\nAhahaha, I jest!", - "4": "I'm the winner! Which is to say, you lost." - } - }, - "crasher_wake": { - "encounter": { - "1": "Crash! Crash! Watch out!\nCrasher Wake…is…heeere!", - "2": "Crash! Crash! Crasher Wake!", - "3": "I'm the tidal wave of power to wash you away!" - }, - "victory": { - "1": "That puts a grin on my face!\nGuhahaha! That was a blast!", - "2": "Hunwah! It's gone and ended!\nHow will I say this…\nI want more! I wanted to battle a lot more!", - "3": "WHAAAAT!?" - }, - "defeat": { - "1": "Yeeeeah! That's right!", - "2": "I won, but I want more! I wanted to battle a lot more!", - "3": "So long!" - } - }, - "falkner": { - "encounter": { - "1": "I'll show you the real power of the magnificent bird Pokémon!", - "2": "Winds, stay with me!", - "3": "Dad! I hope you're watching me battle from above!" - }, - "victory": { - "1": "I understand… I'll bow out gracefully.", - "2": "A defeat is a defeat. You are strong indeed.", - "3": "…Shoot! Yeah, I lost." - }, - "defeat": { - "1": "Dad! I won with your cherished bird Pokémon…", - "2": "Bird Pokémon are the best after all!", - "3": "Feels like I'm catching up to my dad!" - } - }, - "nessa": { - "encounter": { - "1": "No matter what kind of plan your refined mind may be plotting, my partner and I will be sure to sink it.", - "1_female": "No matter what kind of plan your refined mind may be plotting, my partner and I will be sure to sink it.", - "2": "I'm not here to chat. I'm here to win!", - "3": "This is a little gift from my Pokémon… I hope you can take it!", - "3_female": "This is a little gift from my Pokémon… I hope you can take it!" - }, - "victory": { - "1": "You and your Pokémon are just too much…", - "2": "How…? How can this be?!", - "3": "I was totally washed away!" - }, - "defeat": { - "1": "The raging wave crashes again!", - "2": "Time to ride the wave of victory!", - "3": "Ehehe!" - } - }, - "melony": { - "encounter": { - "1": "I'm not going to hold back!", - "2": "All righty, I suppose we should get started.", - "3": "I'll freeze you solid!" - }, - "victory": { - "1": "You… You're pretty good, huh?", - "1_female": "You… You're pretty good, huh?", - "2": "If you find Gordie around, be sure to give him a right trashing, would you?", - "3": "I think you took breaking the ice a little too literally…" - }, - "defeat": { - "1": "Now do you see how severe battles can be?", - "2": "Hee! Looks like I went and won again!", - "3": "Are you holding back?" - } - }, - "marlon": { - "encounter": { - "1": "You look strong! Shoots! Let's start!", - "2": "I'm strong like the ocean's wide. You're gonna get swept away, fo' sho'.", - "2_female": "I'm strong like the ocean's wide. You're gonna get swept away, fo' sho'.", - "3": "Oh ho, so I'm facing you! That's off the wall." - }, - "victory": { - "1": "You totally rocked that! You're raising some wicked Pokémon. You got this Trainer thing down!", - "1_female": "You totally rocked that! You're raising some wicked Pokémon. You got this Trainer thing down!", - "2": "You don't just look strong, you're strong fo' reals! Eh, I was swept away, too!", - "3": "You're strong as a gnarly wave!" - }, - "defeat": { - "1": "You're tough, but it's not enough to sway the sea, 'K!", - "2": "Hee! Looks like I went and won again!", - "3": "Sweet, sweet victory!" - } - }, - "shauntal": { - "encounter": { - "1": "Excuse me. You're a challenger, right?\nI'm the Elite Four's Ghost-type Pokémon user, Shauntal, and I shall be your opponent.", - "1_female": "Excuse me. You're a challenger, right?\nI'm the Elite Four's Ghost-type Pokémon user, Shauntal, and I shall be your opponent.", - "2": "I absolutely love writing about Trainers who come here and the Pokémon they train.\nCould I use you and your Pokémon as a subject?", - "3": "Every person who works with Pokémon has a story to tell.\nWhat story is about to be told?" - }, - "victory": { - "1": "Wow. I'm dumbstruck!", - "2": "S-sorry! First, I must apologize to my Pokémon…\n\nI'm really sorry you had a bad experience because of me!", - "3": "Even in light of that, I'm still one of the Elite Four!" - }, - "defeat": { - "1": "Eheh.", - "2": "That gave me excellent material for my next novel!", - "3": "And so, another tale ends…" - } - }, - "marshal": { - "encounter": { - "1": "My mentor, Alder, sees your potential as a Trainer and is taking an interest in you.\nIt is my intention to test you--to take you to the limits of your strength. Kiai!", - "1_female": "My mentor, Alder, sees your potential as a Trainer and is taking an interest in you.\nIt is my intention to test you--to take you to the limits of your strength. Kiai!", - "2": "Victory, decisive victory, is my intention! Challenger, here I come!", - "3": "In myself, I seek to develop the strength of a fighter and shatter any weakness in myself!\nPrevailing with the force of my convictions!" - }, - "victory": { - "1": "Whew! Well done!", - "2": "As your battles continue, aim for even greater heights!", - "3": "The strength shown by you and your Pokémon has deeply impressed me…" - }, - "defeat": { - "1": "Hmm.", - "2": "That was good battle.", - "3": "Haaah! Haaah! Haiyaaaah!" - } - }, - "cheren": { - "encounter": { - "1": "You remind me of an old friend. That makes me excited about this Pokémon battle!", - "2": "Pokémon battles have no meaning if you don't think why you battle.\n$Or better said, it makes battling together with Pokémon meaningless.", - "3": "My name's Cheren! I'm a Gym Leader and a teacher! Pleasure to meet you.", - "3_female": "My name's Cheren! I'm a Gym Leader and a teacher! Pleasure to meet you." - }, - "victory": { - "1": "Thank you! I saw what was missing in me.", - "2": "Thank you! I feel like I saw a little of the way toward my ideals.", - "3": "Hmm… This is problematic." - }, - "defeat": { - "1": "As a Gym Leader, I aim to be a wall for you to overcome.", - "2": "All right!", - "3": "I made it where I am because Pokémon were by my side.\nPerhaps we need to think about why Pokémon help us not in terms of Pokémon and Trainers but as a relationship between living beings." - } - }, - "chili": { - "encounter": { - "1": "Yeeeeooow! Time to play with FIRE!! I'm the strongest of us brothers!", - "1_female": "Yeeeeooow! Time to play with FIRE!! I'm the strongest of us brothers!", - "2": "Ta-da! The Fire-type scorcher Chili--that's me--will be your opponent!", - "2_female": "Ta-da! The Fire-type scorcher Chili--that's me--will be your opponent!", - "3": "I'm going to show you what me and my blazing Fire types can do!", - "3_female": "I'm going to show you what me and my blazing Fire types can do!" - }, - "victory": { - "1": "You got me. I am… burned… out…", - "1_female": "You got me. I am… burned… out…", - "2": "Whoa ho! You're on fire!", - "2_female": "Whoa ho! You're on fire!", - "3": "Augh! You got me!" - }, - "defeat": { - "1": "I'm on fire! Play with me, and you'll get burned!", - "1_female": "I'm on fire! Play with me, and you'll get burned!", - "2": "When you play with fire, you get burned!", - "3": "I mean, c'mon, your opponent was me! You didn't have a chance!", - "3_female": "I mean, c'mon, your opponent was me! You didn't have a chance!" - } - }, - "cilan": { - "encounter": { - "1": "Nothing personal... No hard feelings... Me and my Grass-type Pokémon will...\n$Um... We're gonna battle come what may.", - "1_female": "Nothing personal... No hard feelings... Me and my Grass-type Pokémon will...\n$Um... We're gonna battle come what may.", - "2": "So, um, if you're OK with me, I'll, um, put everything I've got into being, er, you know, your opponent.", - "2_female": "So, um, if you're OK with me, I'll, um, put everything I've got into being, er, you know, your opponent.", - "3": "OK… So, um, I'm Cilan, I like Grass-type Pokémon.", - "3_female": "OK… So, um, I'm Cilan, I like Grass-type Pokémon." - }, - "victory": { - "1": "Er… Is it over now?", - "1_female": "Er… Is it over now?", - "2": "…What a surprise. You are very strong, aren't you? \n$I guess my brothers wouldn't have been able to defeat you either…", - "2_female": "…What a surprise. You are very strong, aren't you? \n$I guess my brothers wouldn't have been able to defeat you either…", - "3": "…Huh. Looks like my timing was, um, off?" - }, - "defeat": { - "1": "Huh? Did I win?", - "1_female": "Huh? Did I win?", - "2": "I guess… \n$I suppose I won, because I've been competing with my brothers Chili and Cress, and we all were able to get tougher.", - "2_female": "I guess… \n$I suppose I won, because I've been competing with my brothers Chili and Cress, and we all were able to get tougher.", - "3": "It…it was quite a thrilling experience…", - "3_female": "It…it was quite a thrilling experience…" - } - }, - "roark": { - "encounter": { - "1": "I need to see your potential as a Trainer. And, I'll need to see the toughness of the Pokémon that battle with you!", - "1_female": "I need to see your potential as a Trainer. And, I'll need to see the toughness of the Pokémon that battle with you!", - "2": "Here goes! These are my rocking Pokémon, my pride and joy!", - "3": "Rock-type Pokémon are simply the best!", - "4": "Every day, I toughened up my Pokémon by digging up Fossils nonstop.\n$Could I show you how tough I made them in a battle?", - "4_female": "Every day, I toughened up my Pokémon by digging up Fossils nonstop.\n$Could I show you how tough I made them in a battle?" - }, - "victory": { - "1": "W-what? That can't be! My buffed-up Pokémon!", - "2": "…We lost control there. Next time I'd like to challenge you to a Fossil-digging race underground.", - "2_female": "…We lost control there. Next time I'd like to challenge you to a Fossil-digging race underground.", - "3": "With skill like yours, it's natural for you to win.", - "4": "Wh-what?! It can't be! Even that wasn't enough?" - }, - "defeat": { - "1": "See? I'm proud of my rocking battle style!", - "2": "Thanks! The battle gave me confidence that I may be able to beat my dad!", - "3": "See? These are my rocking Pokémon, my pride and joy!", - "4": "I knew I would win!" - } - }, - "morty": { - "encounter": { - "1": "With a little more, I could see a future in which I meet the legendary Pokémon.\n$You're going to help me reach that level!", - "2": "It's said that a rainbow-hued Pokémon will come down to appear before a truly powerful Trainer. \n$I believed that tale, so I have secretly trained here all my life. As a result, I can now see what others cannot. \n$I see a shadow of the person who will make the Pokémon appear. \n$I believe that person is me! You're going to help me reach that level!", - "3": "Whether you choose to believe or not, mystic power does exist.", - "4": "You can bear witness to the fruits of my training.", - "5": "You must make your soul one with that of Pokémon. Can you do this?", - "6": "Say, do you want to be part of my training?" - }, - "victory": { - "1": "I'm not good enough yet…", - "2": "I see… Your journey has taken you to far-away places and you have witnessed much more than I.\n$I envy you for that…", - "2_female": "I see… Your journey has taken you to far-away places and you have witnessed much more than I.\n$I envy you for that…", - "3": "How is this possible…", - "4": "I don't think our potentials are so different.\n$But you seem to have something more than that… So be it.", - "5": "Guess I need more training.", - "6": "That's a shame." - }, - "defeat": { - "1": "I moved… one step ahead again.", - "2": "Fufufu…", - "3": "Wh-what?! It can't be! Even that wasn't enough?", - "4": "I feel like I just smashed through a really stubborn boulder!", - "5": "Ahahahah!", - "6": "I knew I would win!" - } - }, - "crispin": { - "encounter": { - "1": "I wanna win, so that's exactly what I'll do!", - "2": "I battle because I wanna battle! And you know what? That's how it should be!" - }, - "victory": { - "1": "I wanted to win…but I lost!", - "2": "I lost…'cause I couldn't win!" - }, - "defeat": { - "1": "Hey, wait a sec. Did I just win? I think I just won! Talk about satisfying!", - "2": "Wooo! That was amazing!" - } - }, - "amarys": { - "encounter": { - "1": "I want to be the one to help a certain person. That being the case, I cannot afford to lose.\n$… Our battle starts now." - }, - "victory": { - "1": "I am… not enough, I see." - }, - "defeat": { - "1": "Victory belongs to me. Well fought." - } - }, - "lacey": { - "encounter": { - "1": "I'll be facing you with my usual party as a member of the Elite Four." - }, - "victory": { - "1": "That was a great battle!" - }, - "defeat": { - "1": "Let's give your Pokémon a nice round of applause for their efforts!" - } - }, - "drayton": { - "encounter": { - "1": "Man, I love chairs. Don't you love chairs? What lifesavers. \n$I don't get why everyone doesn't just sit all the time. Standing up's tiring work!" - }, - "victory": { - "1": "Guess I should've expected that!" - }, - "defeat": { - "1": "Heh heh! Don't mind me, just scooping up a W over here. I get it if you're upset, but don't go full Kieran on me, OK?", - "1_female": "Heh heh! Don't mind me, just scooping up a W over here. I get it if you're upset, but don't go full Kieran on me, OK?" - } - }, - "ramos": { - "encounter": { - "1": "Did yeh enjoy the garden playground I made with all these sturdy plants o' mine?\n$Their strength is a sign o' my strength as a gardener and a Gym Leader! Yeh sure yer up to facing all that?", - "1_female": "Did yeh enjoy the garden playground I made with all these sturdy plants o' mine?\n$Their strength is a sign o' my strength as a gardener and a Gym Leader! Yeh sure yer up to facing all that?" - }, - "victory": { - "1": "Yeh believe in yer Pokémon… And they believe in yeh, too… It was a fine battle, sprout." - }, - "defeat": { - "1": "Hohoho… Indeed. Frail little blades o' grass'll break through even concrete." - } - }, - "viola": { - "encounter": { - "1": "Whether it's the tears of frustration that follow a loss or the blossoming of joy that comes with victory…\n$They're both great subjects for my camera! Fantastic! This'll be just fantastic! \n$Now come at me!", - "2": "My lens is always focused on victory--I won't let anything ruin this shot!" - }, - "victory": { - "1": "You and your Pokémon have shown me a whole new depth of field! Fantastic! Just fantastic!", - "2": "The world you see through a lens, and the world you see with a Pokémon by your side…\n$The same world can look entirely different depending on your view." - }, - "defeat": { - "1": "The photo from the moment of my victory will be a real winner, all right!", - "2": "Yes! I took some great photos!" - } - }, - "candice": { - "encounter": { - "1": "You want to challenge Candice? Sure thing! I was waiting for someone tough! \n$But I should tell you, I'm tough because I know how to focus.", - "2": "Pokémon, fashion, romance… It's all about focus! \n$I'll show you just what I mean. Get ready to lose!" - }, - "victory": { - "1": "I must say, I'm warmed up to you! I might even admire you a little.", - "2": "Wow! You're great! You've earned my respect! \n$I think your focus and will bowled us over totally. ", - "2_female": "Wow! You're great! You've earned my respect! \n$I think your focus and will bowled us over totally. " - }, - "defeat": { - "1": "I sensed your will to win, but I don't lose!", - "2": "See? Candice's focus! My Pokémon's focus is great, too!" - } - }, - "gardenia": { - "encounter": { - "1": "You have a winning aura about you. So, anyway, this will be fun. Let's have our battle!" - }, - "victory": { - "1": "Amazing! You're very good, aren't you?", - "1_female": "Amazing! You're very good, aren't you?" - }, - "defeat": { - "1": "Yes! My Pokémon and I are perfectly good!" - } - }, - "aaron": { - "encounter": { - "1": "Ok! Let me take you on!" - }, - "victory": { - "1": "Battling is a deep and complex affair…" - }, - "defeat": { - "1": "Victory over an Elite Four member doesn't come easily." - } - }, - "cress": { - "encounter": { - "1": "That is correct! It shall be I and my esteemed Water types that you must face in battle!" - }, - "victory": { - "1": "Lose? Me? I don't believe this." - }, - "defeat": { - "1": "This is the appropriate result when I'm your opponent." - } - }, - "allister": { - "encounter": { - "1": "'M Allister.\nH-here… I go…" - }, - "victory": { - "1": "I nearly lost my mask from the shock… That was…\n$Wow. I can see your skill for what it is." - }, - "defeat": { - "1": "Th-that was ace!" - } - }, - "clay": { - "encounter": { - "1": "Harrumph! Kept me waitin', didn't ya, kid? All right, time to see what ya can do!", - "1_female": "Harrumph! Kept me waitin', didn't ya, kid? All right, time to see what ya can do!" - }, - "victory": { - "1": "Man oh man… It feels good to go all out and still be defeated!" - }, - "defeat": { - "1": "What's important is how ya react to losin'. \n$That's why folks who use losin' as fuel to get better are tough." - } - }, - "kofu": { - "encounter": { - "1": "I'mma serve you a full course o' Water-type Pokémon! Don't try to eat 'em, though!" - }, - "victory": { - "1": "Vaultin' Veluza! Yer a lively one, aren't ya! A little TOO lively, if I do say so myself!", - "1_female": "Vaultin' Veluza! Yer a lively one, aren't ya! A little TOO lively, if I do say so myself!" - }, - "defeat": { - "1": "You come back to see me again now, ya hear?" - } - }, - "tulip": { - "encounter": { - "1": "Allow me to put my skills to use to make your cute little Pokémon even more beautiful!" - }, - "victory": { - "1": "Your strength has a magic to it that cannot be washed away." - }, - "defeat": { - "1": "You know, in my line of work, people who lack talent in one area or the other often fade away quickly—never to be heard of again." - } - }, - "sidney": { - "encounter": { - "1": "I like that look you're giving me. I guess you'll give me a good match.\n$That's good! Looking real good! All right!\n$You and me, let's enjoy a battle that can only be staged here!" - }, - "victory": { - "1": "Well, how do you like that? I lost! Eh, it was fun, so it doesn't matter." - }, - "defeat": { - "1": "No hard feelings, alright?" - } - }, - "phoebe": { - "encounter": { - "1": "While I trained, I gained the ability to commune with Ghost-type Pokémon. \n$Yes, the bond I developed with Pokémon is extremely tight. \n$So, come on, just try and see if you can even inflict damage on my Pokémon!" - }, - "victory": { - "1": "Oh, darn. I've gone and lost." - }, - "defeat": { - "1": "I look forward to battling you again sometime!" - } - }, - "glacia": { - "encounter": { - "1": "All I have seen are challenges by weak Trainers and their Pokémon. \n$What about you? It would please me to no end if I could go all out against you!" - }, - "victory": { - "1": "You and your Pokémon… How hot your spirits burn!\n$The all-consuming heat overwhelms. \n$It's no surprise that my icy skills failed to harm you." - }, - "defeat": { - "1": "A fiercely passionate battle, indeed." - } - }, - "drake": { - "encounter": { - "1": "For us to battle with Pokémon as partners, do you know what it takes? Do you know what is needed? \n$If you don't, then you will never prevail over me!" - }, - "victory": { - "1": "Superb, it should be said." - }, - "defeat": { - "1": "I gave my all for that battle!" - } - }, - "wallace": { - "encounter": { - "1": "There's something about you… A difference in your demeanor. \n$I think I sense that in you. Now, show me. Show me the power you wield with your Pokémon. \n$And I, in turn, shall present you with a performance of illusions in water by me and my Pokémon!" - }, - "victory": { - "1": "Bravo. I realize now your authenticity and magnificence as a Pokémon Trainer. \n$I find much joy in having met you and your Pokémon. You have proven yourself worthy.", - "1_female": "Bravo. I realize now your authenticity and magnificence as a Pokémon Trainer. \n$I find much joy in having met you and your Pokémon. You have proven yourself worthy." - }, - "defeat": { - "1": "A grand illusion!" - } - }, - "lorelei": { - "encounter": { - "1": "No one can best me when it comes to icy Pokémon! Freezing moves are powerful!\n$Your Pokémon will be at my mercy when they are frozen solid! Hahaha! Are you ready?", - "1_female": "No one can best me when it comes to icy Pokémon! Freezing moves are powerful!\n$Your Pokémon will be at my mercy when they are frozen solid! Hahaha! Are you ready?" - }, - "victory": { - "1": "How dare you!" - }, - "defeat": { - "1": "There's nothing you can do once you're frozen.", - "1_female": "There's nothing you can do once you're frozen." - } - }, - "will": { - "encounter": { - "1": "I have trained all around the world, making my psychic Pokémon powerful.\n$I can only keep getting better! Losing is not an option!" - }, - "victory": { - "1": "I… I can't… believe it…" - }, - "defeat": { - "1": "That was close. I wonder what it is that you lack." - } - }, - "malva": { - "encounter": { - "1": "I feel like my heart might just burst into flames. \n$I'm burning up with my hatred for you, runt!", - "1_female": "I feel like my heart might just burst into flames. \n$I'm burning up with my hatred for you, runt!" - }, - "victory": { - "1": "What news… So a new challenger has defeated Malva!", - "1_female": "What news… So a new challenger has defeated Malva!" - }, - "defeat": { - "1": "I am delighted! Yes, delighted that I could squash you beneath my heel." - } - }, - "hala": { - "encounter": { - "1": "Old Hala is here to make you holler!" - }, - "victory": { - "1": "I could feel the power you gained on your journey." - }, - "defeat": { - "1": "Haha! What a delightful battle!" - } - }, - "molayne": { - "encounter": { - "1": "I gave the captain position to my cousin Sophocles, but I'm confident in my ability. \n$My strength is like that of a supernova!" - }, - "victory": { - "1": "I certainly found an interesting Trainer to face!", - "1_female": "I certainly found an interesting Trainer to face!" - }, - "defeat": { - "1": "Ahaha. What an interesting battle." - } - }, - "rika": { - "encounter": { - "1": "I'd say I'll go easy on you, but… I'd be lying! Think fast!" - }, - "victory": { - "1": "Not bad, kiddo.", - "1_female": "Not bad, kiddo." - }, - "defeat": { - "1": "Nahahaha! You really are something else, kiddo!", - "1_female": "Nahahaha! You really are something else, kiddo!" - } - }, - "bruno": { - "encounter": { - "1": "We will grind you down with our superior power! Hoo hah!" - }, - "victory": { - "1": "Why? How could I lose?" - }, - "defeat": { - "1": "You can challenge me all you like, but the results will never change!" - } - }, - "bugsy": { - "encounter": { - "1": "I'm Bugsy! I never lose when it comes to bug Pokémon!" - }, - "victory": { - "1": "Whoa, amazing! You're an expert on Pokémon!\nMy research isn't complete yet. OK, you win.", - "1_female": "Whoa, amazing! You're an expert on Pokémon!\nMy research isn't complete yet. OK, you win." - }, - "defeat": { - "1": "Thanks! Thanks to our battle, I was also able to make progress in my research!" - } - }, - "koga": { - "encounter": { - "1": "Fwahahahaha! Pokémon are not merely about brute force--you shall see soon enough!" - }, - "victory": { - "1": "Ah! You've proven your worth!" - }, - "defeat": { - "1": "Have you learned to fear the techniques of the ninja?" - } - }, - "bertha": { - "encounter": { - "1": "Well, would you show this old lady how much you've learned?" - }, - "victory": { - "1": "Well! Dear child, I must say, that was most impressive. \n$Your Pokémon believed in you and did their best to earn you the win. \n$Even though I've lost, I find myself with this silly grin!" - }, - "defeat": { - "1": "Hahahahah! Looks like this old lady won!" - } - }, - "lenora": { - "encounter": { - "1": "Well then, challenger, I'm going to research how you battle with the Pokémon you've so lovingly raised!", - "1_female": "Well then, challenger, I'm going to research how you battle with the Pokémon you've so lovingly raised!" - }, - "victory": { - "1": "My theory about you was correct. You're more than just talented… You're motivated! I salute you!", - "1_female": "My theory about you was correct. You're more than just talented… You're motivated! I salute you!" - }, - "defeat": { - "1": "Ah ha ha! If you lose, make sure to analyze why, and use that knowledge in your next battle!" - } - }, - "siebold": { - "encounter": { - "1": "As long as I am alive, I shall strive onward to seek the ultimate cuisine... and the strongest opponents in battle!" - }, - "victory": { - "1": "I shall store my memory of you and your Pokémon forever away within my heart." - }, - "defeat": { - "1": "Our Pokémon battle was like food for my soul. It shall keep me going. \n$That is how I will pay my respects to you for giving your all in battle!" - } - }, - "roxie": { - "encounter": { - "1": "Get ready! I'm gonna knock some sense outta ya!" - }, - "victory": { - "1": "Wild! Your reason's already more toxic than mine!" - }, - "defeat": { - "1": "Hey, c'mon! Get serious! You gotta put more out there!", - "1_female": "Hey, c'mon! Get serious! You gotta put more out there!" - } - }, - "olivia": { - "encounter": { - "1": "No introduction needed here. Time to battle me, Olivia!" - }, - "victory": { - "1": "Really lovely… Both you and your Pokémon…" - }, - "defeat": { - "1": "Mmm-hmm." - } - }, - "poppy": { - "encounter": { - "1": "Oooh! Do you wanna have a Pokémon battle with me?" - }, - "victory": { - "1": "Uagh?! Mmmuuuggghhh…" - }, - "defeat": { - "1": "Yaaay! I did it! I de-feet-ed you! You can come for… For… An avenge match? \n$Come for an avenge match anytime you want!" - } - }, - "agatha": { - "encounter": { - "1": "Pokémon are for battling! I'll show you how a real Trainer battles!" - }, - "victory": { - "1": "Oh my! You're something special, child!" - }, - "defeat": { - "1": "Bahaha. That's how a proper battle's done!" - } - }, - "flint": { - "encounter": { - "1": "Hope you're warmed up, cause here comes the Big Bang!", - "1_female": "Hope you're warmed up, cause here comes the Big Bang!" - }, - "victory": { - "1": "Incredible! Your moves are so hot, they make mine look lukewarm!" - }, - "defeat": { - "1": "Huh? Is that it? I think you need a bit more passion." - } - }, - "grimsley": { - "encounter": { - "1": "The winner takes everything, and there's nothing left for the loser." - }, - "victory": { - "1": "When one loses, they lose everything… The next thing I'll look for will be victory, too!" - }, - "defeat": { - "1": "If somebody wins, the person who fought against that person will lose." - } - }, - "caitlin": { - "encounter": { - "1": "It's me who appeared when the flower opened up. You who have been waiting…\n$You look like a Pokémon Trainer with refined strength and deepened kindness. \n$What I look for in my opponent is superb strength… \n$Please unleash your power to the fullest!", - "1_female": "It's me who appeared when the flower opened up. You who have been waiting…\n$You look like a Pokémon Trainer with refined strength and deepened kindness. \n$What I look for in my opponent is superb strength… \n$Please unleash your power to the fullest!" - }, - "victory": { - "1": "My Pokémon and I learned so much! I offer you my thanks." - }, - "defeat": { - "1": "I aspire to claim victory with elegance and grace." - } - }, - "diantha": { - "encounter": { - "1": "Battling against you and your Pokémon, all of you brimming with hope for the future… \n$Honestly, it just fills me up with energy I need to keep facing each new day! It does!" - }, - "victory": { - "1": "Witnessing the noble spirits of you and your Pokémon in battle has really touched my heart…" - }, - "defeat": { - "1": "Oh, fantastic! What did you think? My team was pretty cool, right?" - } - }, - "wikstrom": { - "encounter": { - "1": "Well met, young challenger! Verily am I the famed blade of hardened steel, Duke Wikstrom! \n$Let the battle begin! En garde!", - "1_female": "Well met, young challenger! Verily am I the famed blade of hardened steel, Duke Wikstrom! \n$Let the battle begin! En garde!" - }, - "victory": { - "1": "Glorious! The trust that you share with your honorable Pokémon surpasses even mine!", - "1_female": "Glorious! The trust that you share with your honorable Pokémon surpasses even mine!" - }, - "defeat": { - "1": "What manner of magic is this? My heart, it doth hammer ceaselessly in my breast! \n$Winning against such a worthy opponent doth give my soul wings--thus do I soar!", - "1_female": "What manner of magic is this? My heart, it doth hammer ceaselessly in my breast! \n$Winning against such a worthy opponent doth give my soul wings--thus do I soar!" - } - }, - "acerola": { - "encounter": { - "1": "Battling is just plain fun! Come on, I can take you!" - }, - "victory": { - "1": "I'm… I'm speechless! How did you do it?!" - }, - "defeat": { - "1": "Ehaha! What an amazing victory!" - } - }, - "larry_elite": { - "encounter": { - "1": "Hello there… It's me, Larry.\n$I serve as a member of the Elite Four too, yes… Unfortunately for me." - }, - "victory": { - "1": "Well, that took the wind from under our wings…" - }, - "defeat": { - "1": "It's time for a meeting with the boss." - } - }, - "lance": { - "encounter": { - "1": "I've been waiting for you. Allow me to test your skill.", - "2": "I thought that you would be able to get this far. Let's get this started." - }, - "victory": { - "1": "You got me. You are magnificent!", - "1_female": "You got me. You are magnificent!", - "2": "I never expected another trainer to beat me… I'm surprised.", - "2_female": "I never expected another trainer to beat me… I'm surprised." - }, - "defeat": { - "1": "That was close. Want to try again?", - "2": "It's not that you are weak. Don't let it bother you.", - "2_female": "It's not that you are weak. Don't let it bother you." - } - }, - "karen": { - "encounter": { - "1": "I am Karen. Would you care for a showdown with my Dark-type Pokémon?", - "2": "I am unlike those you've already met.", - "3": "You've assembled a charming team. Our battle should be a good one." - }, - "victory": { - "1": "No! I can't win. How did you become so strong?", - "2": "I will not stray from my chosen path.", - "3": "The Champion is looking forward to meeting you." - }, - "defeat": { - "1": "That's about what I expected.", - "2": "Well, that was relatively entertaining.", - "3": "Come visit me anytime." - } - }, - "milo": { - "encounter": { - "1": "Sure seems like you understand Pokémon real well. \n$This is gonna be a doozy of a battle! \n$I'll have to Dynamax my Pokémon if I want to win!" - }, - "victory": { - "1": "The power of Grass has wilted… What an incredible Challenger!", - "1_female": "The power of Grass has wilted… What an incredible Challenger!" - }, - "defeat": { - "1": "This'll really leave you in shock and awe." - } - }, - "lucian": { - "encounter": { - "1": "Just a moment, please. The book I'm reading has nearly reached its thrilling climax… \n$The hero has obtained a mystic sword and is about to face their final trial… Ah, never mind. \n$Since you've made it this far, I'll put that aside and battle you. \n$Let me see if you'll achieve as much glory as the hero of my book!" - }, - "victory": { - "1": "I see… It appears you've put me in checkmate." - }, - "defeat": { - "1": "I have a reputation to uphold." - } - }, - "drasna": { - "encounter": { - "1": "You must be a strong Trainer. Yes, quite strong indeed…\n$That's just wonderful news! Facing opponents like you and your team will make my Pokémon grow like weeds!", - "1_female": "You must be a strong Trainer. Yes, quite strong indeed…\n$That's just wonderful news! Facing opponents like you and your team will make my Pokémon grow like weeds!" - }, - "victory": { - "1": "Oh, dear me. That sure was a quick battle… I do hope you'll come back again sometime!" - }, - "defeat": { - "1": "How can this be?" - } - }, - "kahili": { - "encounter": { - "1": "So, here you are… Why don't we see who the winds favor today, you… Or me?" - }, - "victory": { - "1": "It's frustrating to me as a member of the Elite Four, but it seems your strength is the real deal." - }, - "defeat": { - "1": "That was an ace!" - } - }, - "hassel": { - "encounter": { - "1": "Prepare to learn firsthand how the fiery breath of ferocious battle feels!" - }, - "victory": { - "1": "Fortune smiled on me this time, but… \n$Judging from how the match went, who knows if I will be so lucky next time." - }, - "defeat": { - "1": "That was an ace!" - } - }, - "blue": { - "encounter": { - "1": "You must be pretty good to get this far.", - "1_female": "You must be pretty good to get this far." - }, - "victory": { - "1": "I've only lost to him and now to you… Him? Hee, hee…" - }, - "defeat": { - "1": "See? My power is what got me here." - } - }, - "piers": { - "encounter": { - "1": "Get ready for a mosh pit with me and my party! Spikemuth, it's time to rock!" - }, - "victory": { - "1": "Me an' my team gave it our best. Let's meet up again for a battle some time…" - }, - "defeat": { - "1": "My throat's ragged from shoutin'… But 'at was an excitin' battle!" - } - }, - "red": { - "encounter": { - "1": "…!" - }, - "victory": { - "1": "…?" - }, - "defeat": { - "1": "…!" - } - }, - "jasmine": { - "encounter": { - "1": "Oh… Your Pokémon are impressive. I think I will enjoy this." - }, - "victory": { - "1": "You are truly strong. I'll have to try much harder, too." - }, - "defeat": { - "1": "I never expected to win." - } - }, - "lance_champion": { - "encounter": { - "1": "I am still the Champion. I won't hold anything back." - }, - "victory": { - "1": "This is the emergence of a new Champion.", - "1_female": "This is the emergence of a new Champion." - }, - "defeat": { - "1": "I successfully defended my Championship." - } - }, - "steven": { - "encounter": { - "1": "Tell me… What have you seen on your journey with your Pokémon? \n$What have you felt, meeting so many other Trainers out there? \n$Traveling this rich land… Has it awoken something inside you? \n$I want you to come at me with all that you've learned. \n$My Pokémon and I will respond in turn with all that we know!" - }, - "victory": { - "1": "So I, the Champion, fall in defeat…" - }, - "defeat": { - "1": "That was time well spent! Thank you!" - } - }, - "cynthia": { - "encounter": { - "1": "I, Cynthia, accept your challenge! There won't be any letup from me!" - }, - "victory": { - "1": "No matter how fun the battle is, it will always end sometime…" - }, - "defeat": { - "1": "Even if you lose, never lose your love of Pokémon." - } - }, - "iris": { - "encounter": { - "1": "Know what? I really look forward to having serious battles with strong Trainers! \n$I mean, come on! The Trainers who make it here are Trainers who desire victory with every fiber of their being! \n$And they are battling alongside Pokémon that have been through countless difficult battles! \n$If I battle with people like that, not only will I get stronger, my Pokémon will, too! \n$And we'll get to know each other even better! OK! Brace yourself! \n$I'm Iris, the Pokémon League Champion, and I'm going to defeat you!" - }, - "victory": { - "1": "Aghhhh… I did my best, but we lost…" - }, - "defeat": { - "1": "Yay! We won!" - } - }, - "hau": { - "encounter": { - "1": "I wonder if a Trainer battles differently depending on whether they're from a warm region or a cold region.\n$Let's test it out!" - }, - "victory": { - "1": "That was awesome! I think I kinda understand your vibe a little better now!" - }, - "defeat": { - "1": "Ma-an, that was some kinda battle!" - } - }, - "geeta": { - "encounter": { - "1": "I decided to throw my hat in the ring once more. \n$Come now… Show me the fruits of your training." - }, - "victory": { - "1": "I eagerly await news of all your achievements!" - }, - "defeat": { - "1": "What's the matter? This isn't all, is it?" - } - }, - "nemona": { - "encounter": { - "1": "Yesss! I'm so psyched! Time for us to let loose!" - }, - "victory": { - "1": "Well, that stinks, but I still had fun! I'll getcha next time!" - }, - "defeat": { - "1": "Well, that was a great battle! Fruitful for sure." - } - }, - "leon": { - "encounter": { - "1": "We're gonna have an absolutely champion time!" - }, - "victory": { - "1": "My time as Champion is over… \n$But what a champion time it's been! \n$Thank you for the greatest battle I've ever had!" - }, - "defeat": { - "1": "An absolute champion time, that was!" - } - }, - "whitney": { - "encounter": { - "1": "Hey! Don't you think Pokémon are, like, super cute?" - }, - "victory": { - "1": "Waaah! Waaah! You're so mean!", - "1_female": "Waaah! Waaah! You're so mean!" - }, - "defeat": { - "1": "And that's that!" - } - }, - "chuck": { - "encounter": { - "1": "Hah! You want to challenge me? Are you brave or just ignorant?", - "1_female": "Hah! You want to challenge me? Are you brave or just ignorant?" - }, - "victory": { - "1": "You're strong! Would you please make me your apprentice?" - }, - "defeat": { - "1": "There. Do you realize how much more powerful I am than you?" - } - }, - "katy": { - "encounter": { - "1": "Don't let your guard down unless you would like to find yourself knocked off your feet!", - "1_female": "Don't let your guard down unless you would like to find yourself knocked off your feet!" - }, - "victory": { - "1": "All of my sweet little Pokémon dropped like flies!" - }, - "defeat": { - "1": "Eat up, my cute little Vivillon!" - } - }, - "pryce": { - "encounter": { - "1": "Youth alone does not ensure victory! Experience is what counts." - }, - "victory": { - "1": "Outstanding! That was perfect. Try not to forget what you feel now." - }, - "defeat": { - "1": "Just as I envisioned." - } - }, - "clair": { - "encounter": { - "1": "Do you know who I am? And you still dare to challenge me?" - }, - "victory": { - "1": "I wonder how far you can get with your skill level. This should be fascinating." - }, - "defeat": { - "1": "That's that." - } - }, - "maylene": { - "encounter": { - "1": "I've come to challenge you now, and I won't hold anything back. \n$Please prepare yourself for battle!", - "1_female": "I've come to challenge you now, and I won't hold anything back. \n$Please prepare yourself for battle!" - }, - "victory": { - "1": "I admit defeat…" - }, - "defeat": { - "1": "That was awesome." - } - }, - "fantina": { - "encounter": { - "1": "You shall challenge me, yes? But I shall win. \n$That is what the Gym Leader of Hearthome does, non?" - }, - "victory": { - "1": "You are so fantastically strong. I know why I have lost." - }, - "defeat": { - "1": "I am so, so, very happy!" - } - }, - "byron": { - "encounter": { - "1": "Trainer! You're young, just like my son, Roark. \n$With more young Trainers taking charge, the future of Pokémon is bright! \n$So, as a wall for young people, I'll take your challenge!", - "1_female": "Trainer! You're young, just like my son, Roark. \n$With more young Trainers taking charge, the future of Pokémon is bright! \n$So, as a wall for young people, I'll take your challenge!" - }, - "victory": { - "1": "Hmm! My sturdy Pokémon--defeated!" - }, - "defeat": { - "1": "Gwahahaha! How were my sturdy Pokémon?!" - } - }, - "olympia": { - "encounter": { - "1": "An ancient custom deciding one's destiny. The battle begins!" - }, - "victory": { - "1": "Create your own path. Let nothing get in your way. Your fate, your future." - }, - "defeat": { - "1": "Our path is clear now." - } - }, - "volkner": { - "encounter": { - "1": "Since you've come this far, you must be quite strong…\n$I hope you're the Trainer who'll make me remember how fun it is to battle!", - "1_female": "Since you've come this far, you must be quite strong…\n$I hope you're the Trainer who'll make me remember how fun it is to battle!" - }, - "victory": { - "1": "You've got me beat…\n$Your desire and the noble way your Pokémon battled for you… \n$I even felt thrilled during our match. That was a very good battle." - }, - "defeat": { - "1": "It was not shocking at all… \n$That is not what I wanted!" - } - }, - "burgh": { - "encounter": { - "1": "M'hm… If I win this battle, I feel like I can draw a picture unlike any before it. \n$OK! I can hear my battle muse loud and clear. Let's get straight to it!", - "2": "Of course, I'm really proud of all of my Pokémon! \n$Well now… Let's get right to it!" - }, - "victory": { - "1": "Is it over? Has my muse abandoned me?", - "2": "Hmm… It's over! You're incredible!" - }, - "defeat": { - "1": "Wow… It's beautiful somehow, isn't it…", - "2": "Sometimes I hear people say something was an ugly win. \n$I think if you're trying your best, any win is beautiful." - } - }, - "elesa": { - "encounter": { - "1": "C'est fini! When I'm certain of that, I feel an electric jolt run through my body! \n$I want to feel the sensation, so now my beloved Pokémon are going to make your head spin!" - }, - "victory": { - "1": "I meant to make your head spin, but you shocked me instead." - }, - "defeat": { - "1": "That was unsatisfying somehow… Will you give it your all next time?" - } - }, - "skyla": { - "encounter": { - "1": "It's finally time for a showdown! That means the Pokémon battle that decides who's at the top, right? \n$I love being on the summit! 'Cause you can see forever and ever from high places! \n$So, how about you and I have some fun?" - }, - "victory": { - "1": "Being your opponent in battle is a new source of strength to me. Thank you!" - }, - "defeat": { - "1": "Win or lose, you always gain something from a battle, right?" - } - }, - "brycen": { - "encounter": { - "1": "There is also strength in being with other people and Pokémon. \n$Receiving their support makes you stronger. I'll show you this power!" - }, - "victory": { - "1": "The wonderful combination of you and your Pokémon! What a beautiful friendship!" - }, - "defeat": { - "1": "Extreme conditions really test you and train you!" - } - }, - "drayden": { - "encounter": { - "1": "What I want to find is a young Trainer who can show me a bright future. \n$Let's battle with everything we have: your skill, my experience, and the love we've raised our Pokémon with!" - }, - "victory": { - "1": "This intense feeling that floods me after a defeat… I don't know how to describe it." - }, - "defeat": { - "1": "Harrumph! I know your ability is greater than that!" - } - }, - "grant": { - "encounter": { - "1": "There is only one thing I wish for. \n$That by surpassing one another, we find a way to even greater heights." - }, - "victory": { - "1": "You are a wall that I am unable to surmount!" - }, - "defeat": { - "1": "Do not give up. \n$That is all there really is to it. \n$The most important lessons in life are simple." - } - }, - "korrina": { - "encounter": { - "1": "Time for Lady Korrina's big appearance!" - }, - "victory": { - "1": "It's your very being that allows your Pokémon to evolve!" - }, - "defeat": { - "1": "What an explosive battle!" - } - }, - "clemont": { - "encounter": { - "1": "Oh! I'm glad that we got to meet!" - }, - "victory": { - "1": "Your passion for battle inspires me!" - }, - "defeat": { - "1": "Looks like my Trainer-Grow-Stronger Machine, Mach 2 is really working!" - } - }, - "valerie": { - "encounter": { - "1": "Oh, if it isn't a young Trainer… It is lovely to get to meet you like this. \n$Then I suppose you have earned yourself the right to a battle, as a reward for your efforts. \n$The elusive Fairy may appear frail as the breeze and delicate as a bloom, but it is strong.", - "1_female": "Oh, if it isn't a young Trainer… It is lovely to get to meet you like this. \n$Then I suppose you have earned yourself the right to a battle, as a reward for your efforts. \n$The elusive Fairy may appear frail as the breeze and delicate as a bloom, but it is strong." - }, - "victory": { - "1": "I hope that you will find things worth smiling about tomorrow…" - }, - "defeat": { - "1": "Oh goodness, what a pity…" - } - }, - "wulfric": { - "encounter": { - "1": "You know what? We all talk big about what you learn from battling and bonds and all that…\n$But really, I just do it 'cause it's fun. \n$Who cares about the grandstanding? Let's get to battling!" - }, - "victory": { - "1": "Outstanding! I'm tough as an iceberg, but you smashed me through and through!" - }, - "defeat": { - "1": "Tussle with me and this is what happens!" - } - }, - "kabu": { - "encounter": { - "1": "Every Trainer and Pokémon trains hard in pursuit of victory. \n$But that means your opponent is also working hard to win. \n$In the end, the match is decided by which side is able to unleash their true potential." - }, - "victory": { - "1": "I'm glad I could battle you today!" - }, - "defeat": { - "1": "That's a great way for me to feel my own growth!" - } - }, - "bea": { - "encounter": { - "1": "Do you have an unshakable spirit that won't be moved, no matter how you are attacked? \n$I think I'll just test that out, shall I?" - }, - "victory": { - "1": "I felt the fighting spirit of your Pokémon as you led them in battle." - }, - "defeat": { - "1": "That was the best sort of match anyone could ever hope for." - } - }, - "opal": { - "encounter": { - "1": "Let me have a look at how you and your partner Pokémon behave!" - }, - "victory": { - "1": "Your pink is still lacking, but you're an excellent Trainer with excellent Pokémon.", - "1_female": "Your pink is still lacking, but you're an excellent Trainer with excellent Pokémon." - }, - "defeat": { - "1": "Too bad for you, I guess." - } - }, - "bede": { - "encounter": { - "1": "I suppose I should prove beyond doubt just how pathetic you are and how strong I am.", - "1_female": "I suppose I should prove beyond doubt just how pathetic you are and how strong I am." - }, - "victory": { - "1": "I see… Well, that's fine. I wasn't really trying all that hard anyway." - }, - "defeat": { - "1": "Not a bad job, I suppose." - } - }, - "gordie": { - "encounter": { - "1": "So, let's get this over with." - }, - "victory": { - "1": "I just want to climb into a hole… Well, I guess it'd be more like falling from here." - }, - "defeat": { - "1": "Battle like you always do, victory will follow!" - } - }, - "marnie": { - "encounter": { - "1": "The truth is, when all's said and done… I really just wanna become Champion for myself! \n$So don't take it personal when I kick your butt!" - }, - "victory": { - "1": "OK, so I lost… But I got to see a lot of the good points of you and your Pokémon!" - }, - "defeat": { - "1": "Hope you enjoyed our battle tactics." - } - }, - "raihan": { - "encounter": { - "1": "I'm going to defeat the Champion, win the whole tournament, and prove to the world just how strong the great Raihan really is!" - }, - "victory": { - "1": "I look this good even when I lose. \n$It's a real curse. \n$Guess it's time for another selfie!" - }, - "defeat": { - "1": "Let's take a selfie to remember this." - } - }, - "brassius": { - "encounter": { - "1": "I assume you are ready? Let our collaborative work of art begin!", - "1_female": "I assume you are ready? Let our collaborative work of art begin!" - }, - "victory": { - "1": "Ahhh…vant-garde!" - }, - "defeat": { - "1": "I will begin on a new piece at once!" - } - }, - "iono": { - "encounter": { - "1": "How're ya feelin' about this battle?\n$...\n$Let's get this show on the road! How strong is our challenger? \n$I 'unno! Let's find out together!", - "1_female": "How're ya feelin' about this battle?\n$...\n$Let's get this show on the road! How strong is our challenger? \n$I 'unno! Let's find out together!" - }, - "victory": { - "1": "You're as flashy and bright as a 10,000,000-volt Thunderbolt, friendo!", - "1_female": "You're as flashy and bright as a 10,000,000-volt Thunderbolt, friendo!" - }, - "defeat": { - "1": "Your eyeballs are MINE!" - } - }, - "larry": { - "encounter": { - "1": "When all's said and done, simplicity is strongest." - }, - "victory": { - "1": "A serving of defeat, huh?" - }, - "defeat": { - "1": "I'll call it a day." - } - }, - "ryme": { - "encounter": { - "1": "Come on, baby! Rattle me down to the bone!" - }, - "victory": { - "1": "You're cool, my friend—you move my SOUL!", - "1_female": "You're cool, my friend—you move my SOUL!" - }, - "defeat": { - "1": "Later, baby!" - } - }, - "grusha": { - "encounter": { - "1": "All I need to do is make sure the power of my Pokémon chills you to the bone!" - }, - "victory": { - "1": "Your burning passion… I kinda like it, to be honest." - }, - "defeat": { - "1": "Things didn't heat up for you." - } - }, - "marnie_elite": { - "encounter": { - "1": "You've made it this far, huh? Let's see if you can handle my Pokémon!", - "2": "I'll give it my best shot, but don't think I'll go easy on you!" - }, - "victory": { - "1": "I can't believe I lost... But you deserved that win. Well done!", - "2": "Looks like I've still got a lot to learn. Great battle, though!" - }, - "defeat": { - "1": "You put up a good fight, but I've got the edge! Better luck next time!", - "2": "Seems like my training's paid off. Thanks for the battle!" - } - }, - "nessa_elite": { - "encounter": { - "1": "The tides are turning in my favor. Ready to get swept away?", - "1_female": "The tides are turning in my favor. Ready to get swept away?", - "2": "Let's make some waves with this battle! I hope you're prepared!", - "2_female": "Let's make some waves with this battle! I hope you're prepared!" - }, - "victory": { - "1": "You navigated those waters perfectly... Well done!", - "2": "Looks like my currents were no match for you. Great job!" - }, - "defeat": { - "1": "Water always finds a way. That was a refreshing battle!", - "2": "You fought well, but the ocean's power is unstoppable!" - } - }, - "bea_elite": { - "encounter": { - "1": "Prepare yourself! My fighting spirit burns bright!", - "2": "Let's see if you can keep up with my relentless pace!" - }, - "victory": { - "1": "Your strength... It's impressive. You truly deserve this win.", - "2": "I've never felt this intensity before. Amazing job!" - }, - "defeat": { - "1": "Another victory for my intense training regimen! Well done!", - "2": "You've got strength, but I trained harder. Great battle!" - } - }, - "allister_elite": { - "encounter": { - "1": "Shadows fall... Are you ready to face your fears?", - "1_female": "Shadows fall... Are you ready to face your fears?", - "2": "Let's see if you can handle the darkness that I command." - }, - "victory": { - "1": "You've dispelled the shadows... For now. Well done.", - "2": "Your light pierced through my darkness. Great job." - }, - "defeat": { - "1": "The shadows have spoken... Your strength isn't enough.", - "2": "Darkness triumphs... Maybe next time you'll see the light." - } - }, - "raihan_elite": { - "encounter": { - "1": "Storm's brewing! Let's see if you can weather this fight!", - "2": "Get ready to face the eye of the storm!" - }, - "victory": { - "1": "You've bested the storm... Incredible job!", - "2": "You rode the winds perfectly... Great battle!" - }, - "defeat": { - "1": "Another storm weathered, another victory claimed! Well fought!", - "2": "You got caught in my storm! Better luck next time!", - "2_female": "You got caught in my storm! Better luck next time!" - } - }, - "alder": { - "encounter": { - "1": "Prepare yourself for a match against the strongest Trainer in Unova!" - }, - "victory": { - "1": "Well done! You certainly are an unmatched talent." - }, - "defeat": { - "1": "A fresh wind blows through my heart...\n$What an extraordinary effort!" - } - }, - "kieran": { - "encounter": { - "1": "Through hard work, I become stronger and stronger!\n$I don't lose." - }, - "victory": { - "1": "I don't believe it...\n$What a fun and heart-pounding battle!" - }, - "defeat": { - "1": "Wowzers, what a battle!\n$Time for you to train even harder." - } - }, - "rival": { - "encounter": { - "1": "@c{smile}あっ、ここに いたんだ! 旅に 出る前に 「じゃ またね!」って くらい 聞きたかったよ……$@c{smile_eclosed}やっぱり 夢を 追ってこうと しているんだ? 信じられない ほどね……$@c{serious_smile_fists}じゃあ、 ここまで 来たから バトルしよっか? 覚悟してるかを 確かめたい から!$@c{serious_mopen_fists}遠慮せずに 全力で かかってこいぜ!" - }, - "victory": { - "1": "@c{shock}ウワッ、カンゼンに ぶっ壊したぜ。\n初心者だとは 思えないほど……$@c{smile}たぶん 運が良っかった だけが……\n最後まで 行ける素質が あるかもな!$こっちの アイテムを あげよう、 博士に そう言いつけたから。 結構 スゴそうな もんだ!$@c{serious_smile_fists}ここからも ガンバレ!" - } - }, - "rival_female": { - "encounter": { - "1": "@c{smile_wave}あ、ついに 見つけた! あちこち 探したのよ! \n@c{angry_mopen}だーい親友に お別れを 言うまでも 忘れちゃった?$@c{smile_ehalf}大切な 夢を 追っていくのね?\n やっぱり、この日が 来たのね……$@c{smile}とにかく! アタシを 忘れちゃったのを 許せる 条件は 一つ: \n@c{smile_wave_wink}アタシと バトルだ!$@c{angry_mopen}全力で かかってきなさい!\n冒険が 第一歩で 終わっちゃうと もったいない でしょう?" - }, - "victory": { - "1": "@c{shock}始まった バッカリなのに そんなに強い?!@d{96}\n@c{angry}完全に チートだろう?\n$@c{smile_wave_wink}なんちゃって!@d{64} @c{smile_eclosed}正々堂々と 負けたよ。 冒険 上手く行ける 気がするね!\n$@c{smile}ところで、こっち! 博士からの アイテムを あげるわ。きっと 便利だと 思うよ!\n$@c{smile_wave}いつも通り 頑張ってね! 信じてるから!" - } - }, - "rival_2": { - "encounter": { - "1": "@c{smile}おや、なんと グウゼン。\n@c{smile_eclosed}今までも パーフェクトに 勝った ようだな……\n$@c{serious_mopen_fists}なんか 忍び寄った みたいだとは 分かるけど、 そんなことない… ほとんどはな。\n$@c{serious_smile_fists}ぶっちゃけ言うと、 オレが 負けた時から 再戦したくて ウズウズしてたぜ。\n$張り切って 特訓したから 今は ちゃんと 勢い 見せるんだ。\n$@c{serious_mopen_fists}今回も 遠慮しな!\n行こうぜ!" - }, - "victory": { - "1": "@c{neutral_eclosed}あ。 自信過剰かも。\n$@c{smile}いいけどさ、 こうなるのを 見込んだから。\n@c{serious_mopen_fists}次回まで もっと頑張らなくちゃ ってことだよな!\n\n$@c{smile}きっと 助け 要らないんだが、 もう一つの アイテムが 欲しいかと 思ったから あげるぜ。\n\n$@c{serious_smile_fists}でも これで ラストだ!\n相手に 利点を あげ続けると 行けないんだろう!" - } - }, - "rival_2_female": { - "encounter": { - "1": "@c{smile_wave}あっ、 こんなとこで 偶然だね! まだ 倒れないようだ。@c{angry_mopen}フム、えらいえらい!\n$@c{angry_mopen}考えてるのは 分かる、 つきまとってるワケ じゃないから!@c{smile_eclosed}この辺に いただけよ。\n$@c{smile_ehalf}ここまで 頑張っていて 良かったけど、 時々 負けることも 大丈夫だと 知ってるよね?\n$@c{smile}みんなは 失敗から 学ぶ… いつまでも 成功し続ける よりもね。\n$@c{angry_mopen}とにかく! 再戦の ために 大変 トレーニングしてたから 全・勢・力で 戦おう!" - }, - "victory": { - "1": "@c{neutral}…今回は 負ける はずじゃなかった…\n$@c{smile}しょうがないね。 次回まで もっともっと トレーニングしなくちゃ ってこと!\n$@c{smile_wave}そして! もう二つの アイテム、 どうぞ!\n@c{smile_wave_wink}「ありがと」なんて 必要ない!\n$@c{angry_mopen}でもね、 これで 最後! 今から サービス 一つも あげないよ~" - }, - "defeat": { - "1": "時々 負けることも いいんだよ…" - } - }, - "rival_3": { - "encounter": { - "1": "@c{smile}Hey, look who it is! It's been a while.\n@c{neutral}You're… still undefeated? Huh.\n$@c{neutral_eclosed}Things have been kind of… strange.\nIt's not the same back home without you.\n$@c{serious}I know it's selfish, but I need to get this off my chest.\n@c{neutral_eclosed}I think you're in over your head here.\n$@c{serious}Never losing once is just unrealistic.\nWe need to lose sometimes in order to grow.\n$@c{neutral_eclosed}You've had a great run but there's still so much ahead, and it only gets harder. @c{neutral}Are you prepared for that?\n$@c{serious_mopen_fists}If so, prove it to me." - }, - "victory": { - "1": "@c{angry_mhalf}This is ridiculous… I've hardly stopped training…\nHow are we still so far apart?" - } - }, - "rival_3_female": { - "encounter": { - "1": "@c{smile_wave}ヒサブリ~! まだ 負けてないね。\n@c{angry}だんだん イラッと来る。@c{smile_wave_wink}なんちゃって!\n$@c{smile_ehalf}でもよ、 本当に ふるさとが 恋しくないの? それとも… アタシ…?\nずっと会いたいよ… あの、みんなはね!\n$@c{smile_eclosed}夢を 叶ってるのを 応援してるけど、 実際は やがて 負ける。\n$@c{smile}その時が 来たら アタシは いつも通り そばにいるよ。\n@c{angry_mopen}さあ、 ここまで 頑張ってきた アタシの 力を 見せさせて!" - }, - "victory": { - "1": "@c{shock}もう… 足りなかった…?\nこのままで 決して 帰らない だろう……" - }, - "defeat": { - "1": "ベストを 尽くした。 じゃ、 帰りましょう。" - } - }, - "rival_4": { - "encounter": { - "1": "@c{neutral}Hey.\n$I won't mince words or pleasantries with you.\n@c{neutral_eclosed}I'm here to win, plain and simple.\n$@c{serious_mhalf_fists}I've learned to maximize my potential by putting all my time into training.\n$@c{smile}You get a lot of extra time when you cut out the unnecessary sleep and social interaction.\n$@c{serious_mopen_fists}None of that matters anymore, not until I win.\n$@c{neutral_eclosed}I've even reached the point where I don't lose anymore.\n@c{smile_eclosed}I suppose your philosophy wasn't so wrong after all.\n$@c{angry_mhalf}Losing is for the weak, and I'm not weak anymore.\n$@c{serious_mopen_fists}Prepare yourself." - }, - "victory": { - "1": "@c{neutral}What…@d{64} What are you?" - } - }, - "rival_4_female": { - "encounter": { - "1": "@c{neutral}アタシよ! また 忘れちゃった… のね?\n$@c{smile}こんな 遠くまで 来たのは 鼻が高いことだよ! おめでと~\nしかし、 ここは 終着点だね。\n$@c{smile_eclosed}アタシの 中にある 全然 知らなかった 部分を 目覚めたよ。\n今は、 トレーニングしか してないみたい。\n$@c{smile_ehalf}食べたり 寝たりも しなくて 朝から晩まで ポケモンを 育って、 毎日 昨日より 強くなってる。\n$@c{neutral}実は… もう 自分 認識できない。\n$結局、 峠を越して まるで カミに なった。\n今は 誰にも アタシを 倒せないと 思う。\n$ねえ、分かる? 全ては アンタの お陰で。\n@c{smile_ehalf}お礼を言うか アンタのこと嫌いか どうしたらいいの 分からない。\n$@c{angry_mopen}覚悟しなさい。" - }, - "victory": { - "1": "@c{neutral}一体…@d{64} 何モノか…?" - }, - "defeat": { - "1": "$@c{smile}ここまで 頑張ってたのを 誇りに思ってね。" - } - }, - "rival_5": { - "encounter": { - "1": "@c{neutral}…" - }, - "victory": { - "1": "@c{neutral}…" - } - }, - "rival_5_female": { - "encounter": { - "1": "@c{neutral}…" - }, - "victory": { - "1": "@c{neutral}…" - }, - "defeat": { - "1": "$@c{smile_ehalf}…" - } - }, - "rival_6": { - "encounter": { - "1": "@c{smile_eclosed}We meet again.\n$@c{neutral}I've had some time to reflect on all this.\nThere's a reason this all seems so strange.\n$@c{neutral_eclosed}Your dream, my drive to beat you…\nIt's all a part of something greater.\n$@c{serious}This isn't about me, or about you… This is about the world, @c{serious_mhalf_fists}and it's my purpose to push you to your limits.\n$@c{neutral_eclosed}Whether I've fulfilled that purpose I can't say, but I've done everything in my power.\n$@c{neutral}This place we ended up in is terrifying… Yet somehow I feel unphased, like I've been here before.\n$@c{serious_mhalf_fists}You feel the same, don't you?\n$@c{serious}…and it's like something here is speaking to me.\nThis is all the world's known for a long time now.\n$Those times we cherished together that seem so recent are nothing but a distant memory.\n$@c{neutral_eclosed}Who can say whether they were ever even real in the first place.\n$@c{serious_mopen_fists}You need to keep pushing, because if you don't, it will never end. You're the only one who can do this.\n$@c{serious_smile_fists}I hardly know what any of this means, I just know that it's true.\n$@c{serious_mopen_fists}If you can't defeat me here and now, you won't stand a chance." - }, - "victory": { - "1": "@c{smile_eclosed}It looks like my work is done here.\n$I want you to promise me one thing.\n@c{smile}After you heal the world, please come home." - } - }, - "rival_6_female": { - "encounter": { - "1": "@c{smile_ehalf}また アタシたちだけに なった。\n$@c{smile_eclosed}ねえ、 頭の中に グルグル 巡ることが あってよ。\n$@c{smile_ehalf}アタシとアナタの 間に 起こしたことも, この変な感情も……\n$@c{smile}アナタの夢、 アタシの野心…\n$アタシたちが し続けることも 全ては… より高い 目的が あると思うよ。\n$@c{smile_eclosed}最果ての 限界まで 押すこと… それは アタシの 役割だと思う。\n$@c{smile_ehalf}今まで 役割を 上手く果たせたかは 分からないけど…… 一生懸命 頑張った。\n$こんな奇妙な 恐ろしい場所で なんか… 全てが 明らかに 見られるみたい。\n$昔から… これだけしかは この世界こそ そのもの。\n$@c{smile_eclosed}アタシたちが 大切にした 心にギュッと 抱いた思い出… もう 思い出せない。\n$@c{smile_ehalf}本当は 全部 ウソだったの? 今は 遠い彼方に あるみたい。\n$@c{angry_mopen}アナタは 最後まで 戦い続けなければ 決して 終わらない。 アナタしか できないのよ。\n$@c{smile_ehalf}この全ての 意味、 全然 分からないけど… 真実だと 感じてる。\n$@c{neutral}今ここで アタシを 倒せないと 最後に 勝ち目は ナイ。" - }, - "victory": { - "1": "@c{smile_ehalf}役割… 果たせたと思う。\n$@c{smile_eclosed}ね、 約束して。 この世界を 癒やしたら… お願い 無事に 帰って。\n$@c{smile_ehalf}……ありがとう。" - } - } -} diff --git a/src/locales/ja/egg.json b/src/locales/ja/egg.json deleted file mode 100644 index 91b1442c56c..00000000000 --- a/src/locales/ja/egg.json +++ /dev/null @@ -1,26 +0,0 @@ -{ - "egg": "タマゴ", - "greatTier": "レア", - "ultraTier": "超レア", - "masterTier": "伝説", - "defaultTier": "ふつう", - "hatchWavesMessageSoon": "中から 音が 聞こえてくる! もうすぐ 生まれそう!", - "hatchWavesMessageClose": "時々 動いている みたい。生まれるまで もう ちょっとかな?", - "hatchWavesMessageNotClose": "なにが 生まれてくるのかな? 生まれるまで まだまだ 時間が かかりそう。", - "hatchWavesMessageLongTime": "この タマゴは 生まれるまで かなり 時間が かかりそう。", - "gachaTypeLegendary": "伝説確率アップ", - "gachaTypeMove": "レアなタマゴ技確率アップ", - "gachaTypeShiny": "色違い確率アップ", - "selectMachine": "ガチャマシンを選択", - "notEnoughVouchers": "タマゴクーポンが足りません!", - "tooManyEggs": "タマゴが一杯です!", - "pull": "回引く", - "pulls": "回引く", - "sameSpeciesEgg": "{{species}}は このタマゴから 生まれる!", - "hatchFromTheEgg": "{{pokemonName}}は タマゴから 生まれた!", - "eggMoveUnlock": "タマゴ技: {{moveName}}を 覚えた!", - "rareEggMoveUnlock": "レアなタマゴ技: {{moveName}}を 覚えた!!", - "moveUPGacha": "技 UP!", - "shinyUPGacha": "色違い UP!", - "legendaryUPGacha": "UP!" -} diff --git a/src/locales/ja/fight-ui-handler.json b/src/locales/ja/fight-ui-handler.json deleted file mode 100644 index 72cf32f1cd5..00000000000 --- a/src/locales/ja/fight-ui-handler.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "pp": "PP", - "power": "威力", - "accuracy": "命中", - "abilityFlyInText": " {{pokemonName}}の\n{{passive}}{{abilityName}}", - "passive": "パッシブ ", - "teraHover": "{{type}}テラスタル" -} diff --git a/src/locales/ja/filter-bar.json b/src/locales/ja/filter-bar.json deleted file mode 100644 index 891b7d87674..00000000000 --- a/src/locales/ja/filter-bar.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "genFilter": "世代", - "typeFilter": "タイプ", - "caughtFilter": "捕獲", - "unlocksFilter": "解放", - "miscFilter": "その他", - "sortFilter": "並べ替え", - "all": "すべて", - "normal": "非色違い", - "uncaught": "未捕獲", - "passive": "パッシブ", - "passiveUnlocked": "パッシブ - 解放済み", - "passiveLocked": "パッシブ - 未解放", - "passiveUnlockable": "パッシブ - 解放可能", - "costReduction": "ポイント削減", - "costReductionUnlocked": "ポイント削減 - 解放済み", - "costReductionLocked": "ポイント削減 - 未解放", - "costReductionUnlockable": "ポイント削減 - 解放可能", - "favorite": "お気に入り", - "isFavorite": "お気に入り - あり", - "notFavorite": "お気に入り - なし", - "ribbon": "リボン", - "hasWon": "リボン - あり", - "hasNotWon": "リボン - なし", - "hiddenAbility": "隠れ特性", - "hasHiddenAbility": "隠れ特性 - あり", - "noHiddenAbility": "隠れ特性 - なし", - "egg": "タマゴ", - "eggPurchasable": "タマゴ - 購入可能", - "pokerus": "ポケルス", - "hasPokerus": "ポケルス - あり", - "noPokerus": "ポケルス - なし", - "sortByNumber": "No.", - "sortByCost": "ポイント", - "sortByCandies": "アメの数", - "sortByIVs": "個体値", - "sortByName": "名前" -} diff --git a/src/locales/ja/game-mode.json b/src/locales/ja/game-mode.json deleted file mode 100644 index dc04b36932f..00000000000 --- a/src/locales/ja/game-mode.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "classic": "クラシック", - "endless": "エンドレス", - "endlessSpliced": "エンドレス(吸収合体)", - "dailyRun": "デイリーラン", - "unknown": "???", - "challenge": "チャレンジ" -} diff --git a/src/locales/ja/game-stats-ui-handler.json b/src/locales/ja/game-stats-ui-handler.json deleted file mode 100644 index 25301aa4297..00000000000 --- a/src/locales/ja/game-stats-ui-handler.json +++ /dev/null @@ -1,42 +0,0 @@ -{ - "stats": "統計", - "playTime": "プレイ時間", - "totalBattles": "合計バトル数", - "starters": "スターター数", - "shinyStarters": "色違いスターター数", - "speciesSeen": "合計発見数", - "speciesCaught": "合計捕獲数", - "ribbonsOwned": "リボン数", - "classicRuns": "クラシックラン", - "classicWins": "クラシック勝利", - "dailyRunAttempts": "デイリーラン", - "dailyRunWins": "デイリーラン勝利", - "endlessRuns": "エンドレスラン", - "highestWaveEndless": "エンドレス最高ラウンド", - "highestMoney": "最大貯金", - "highestDamage": "最大ダメージ", - "highestHPHealed": "最大HP回復", - "pokemonEncountered": "遭遇したポケモン", - "pokemonDefeated": "倒したポケモン", - "pokemonCaught": "捕まえたポケモン", - "eggsHatched": "ふかしたタマゴ", - "subLegendsSeen": "見つけた順伝説ポケモン", - "subLegendsCaught": "捕まえた準伝説ポケモン", - "subLegendsHatched": "ふかした準伝説ポケモン", - "legendsSeen": "見つけた伝説ポケモン", - "legendsCaught": "捕まえた伝説ポケモン", - "legendsHatched": "ふかした伝説ポケモン", - "mythicalsSeen": "見つけた幻ポケモン", - "mythicalsCaught": "捕まえた幻ポケモン", - "mythicalsHatched": "ふかした幻ポケモン", - "shiniesSeen": "見つけた色違いポケモン", - "shiniesCaught": "捕まえた色違いポケモン", - "shiniesHatched": "ふかした色違いポケモン", - "pokemonFused": "吸収合体したポケモン", - "trainersDefeated": "倒したトレーナー", - "eggsPulled": "引いたタマゴ", - "rareEggsPulled": "引いたレアタマゴ", - "epicEggsPulled": "引いた超レアタマゴ", - "legendaryEggsPulled": "引いた伝説タマゴ", - "manaphyEggsPulled": "引いたマナフィタマゴ" -} diff --git a/src/locales/ja/growth.json b/src/locales/ja/growth.json deleted file mode 100644 index e5c1317632f..00000000000 --- a/src/locales/ja/growth.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "Erratic": "60万タイプ", - "Fast": "80万タイプ", - "Medium_Fast": "100万タイプ", - "Medium_Slow": "105万タイプ", - "Slow": "125万タイプ", - "Fluctuating": "164万タイプ" -} diff --git a/src/locales/ja/menu-ui-handler.json b/src/locales/ja/menu-ui-handler.json deleted file mode 100644 index 851c8478e9d..00000000000 --- a/src/locales/ja/menu-ui-handler.json +++ /dev/null @@ -1,29 +0,0 @@ -{ - "GAME_SETTINGS": "設定", - "ACHIEVEMENTS": "実績", - "STATS": "統計", - "RUN_HISTORY": "ラン歴", - "EGG_LIST": "タマゴリスト", - "EGG_GACHA": "タマゴガチャ", - "MANAGE_DATA": "データ管理", - "COMMUNITY": "コミュニティ", - "SAVE_AND_QUIT": "セーブして終了", - "LOG_OUT": "ログアウト", - "slot": "スロット {{slotNumber}}", - "importSession": "セッションをインポート", - "importSlotSelect": "インポート先の スロットを 選んでください", - "exportSession": "セッションをエクスポート", - "exportSlotSelect": "エクスポート元の スロットを 選んでください", - "importRunHistory": "ラン歴をインポート", - "exportRunHistory": "ラン歴をエクスポート", - "importData": "データをインポート", - "exportData": "データをエクスポート", - "consentPreferences": "同意設定", - "linkDiscord": "Discord連携", - "unlinkDiscord": "Discord連携解除", - "linkGoogle": "Google連携", - "unlinkGoogle": "Google連携解除", - "cancel": "キャンセル", - "losingProgressionWarning": "戦闘開始からの データが セーブされません。\nよろしいですか?", - "noEggs": "現在は タマゴを ふかしていません!" -} diff --git a/src/locales/ja/menu.json b/src/locales/ja/menu.json deleted file mode 100644 index f0914a7941c..00000000000 --- a/src/locales/ja/menu.json +++ /dev/null @@ -1,57 +0,0 @@ -{ - "cancel": "キャンセル", - "continue": "つづきから", - "dailyRun": "日替わりラン(ベータ版)", - "loadGame": "セーブを読み込む", - "newGame": "はじめから", - "settings": "設定", - "selectGameMode": "ゲームモードを 選んでください。", - "logInOrCreateAccount": "始めるには、ログイン、または 登録して ください。\nメールアドレスは 必要が ありません!", - "username": "ユーザー名", - "password": "パスワード", - "login": "ログイン", - "orUse": "他の\nログイン方法", - "register": "登録", - "emptyUsername": "ユーザー名を 空にする ことは できません", - "invalidLoginUsername": "入力されたユーザー名は無効です", - "invalidRegisterUsername": "ユーザー名には 英文字、 数字、 アンダースコアのみを 含くむ必要が あります", - "invalidLoginPassword": "入力したパスワードは無効です", - "invalidRegisterPassword": "パスワードは 6文字以上 でなければなりません", - "usernameAlreadyUsed": "入力したユーザー名は すでに 使用されています", - "accountNonExistent": "入力したユーザーは 存在しません", - "unmatchingPassword": "入力したパスワードが 一致しません", - "passwordNotMatchingConfirmPassword": "パスワードは パスワード確認と 一致する 必要があります", - "confirmPassword": "パスワード確認", - "registrationAgeWarning": "登録では 13歳以上 であることを 確認します。", - "backToLogin": "ログインへ", - "failedToLoadSaveData": "セーブデータの 読み込みは 不可能でした。ページを 再読み込み してください。\n長い間に続く 場合は 管理者に 連絡してください。", - "sessionSuccess": "セッションが 正常に 読み込まれました。", - "failedToLoadSession": "セッションデータを 読み込むことが できませんでした。\nデータが 破損している 可能性が あります。", - "boyOrGirl": "男の子?\nそれとも 女の子?", - "evolving": "…おや!?\n{{pokemonName}}の 様子が…!", - "stoppedEvolving": "あれ…? {{pokemonName}}の 変化が 止まった!", - "pauseEvolutionsQuestion": "{{pokemonName}}の 進化を 休止しますか?\n後で 手持ち画面から 進化を また 可能にできます。", - "evolutionsPaused": "{{pokemonName}}の 進化を 休止しました。", - "evolutionDone": "おめでとう!\n{{pokemonName}}は {{evolvedPokemonName}}に 進化した!", - "dailyRankings": "今日のランキング", - "weeklyRankings": "今週のランキング", - "noRankings": "ランキングなし", - "positionIcon": "#", - "usernameScoreboard": "ユーザー名", - "score": "スコア", - "wave": "波", - "loading": "読み込み中…", - "loadingAsset": "読み込み中:{{assetName}}", - "playersOnline": "オンラインのプレイヤー", - "yes": "はい", - "no": "いいえ", - "disclaimer": "免責", - "disclaimerDescription": "このゲームは 未完成作品です。\nセーブデータの 損失を含める ゲーム性に関する 問題が 起きる可能性が あります。\nなお、ゲームは 予告なく変更される 可能性もあり、\nさらに更新され、完成されるとも 限りません。", - "choosePokemon": "ポケモンを選ぶ", - "renamePokemon": "ニックネームを変える", - "rename": "名前を変える", - "nickname": "ニックネーム", - "errorServerDown": "おや!\nサーバーとの 接続中に 問題が 発生しました。\nゲームは 自動的に 再接続されます から\nウィンドウは 開いたままに しておいても よろしいです。", - "noSaves": "何の セーブファイルも ありません!", - "tooManySaves": "セーブファイルが いっぱいです!" -} diff --git a/src/locales/ja/modifier-select-ui-handler.json b/src/locales/ja/modifier-select-ui-handler.json deleted file mode 100644 index d7428c8e373..00000000000 --- a/src/locales/ja/modifier-select-ui-handler.json +++ /dev/null @@ -1,12 +0,0 @@ -{ - "transfer": "アイテム移行", - "reroll": "選択肢変更", - "lockRarities": "レア度を固定", - "checkTeam": "手持ちを確認", - "transferDesc": "手持ちポケモンの 持たせるアイテムを 移行する", - "rerollDesc": "お金を 使って アイテムの 選択肢を 変更する", - "lockRaritiesDesc": "選択肢を 変更するときの レア度を 固定する\n(選択肢変更の価格は変わる)", - "checkTeamDesc": "手持ちポケモンの 状態を 確認する\nフォルムチェンジアイテムを 有効・無効にする", - "rerollCost": "{{formattedMoney}}円", - "itemCost": "{{formattedMoney}}円" -} diff --git a/src/locales/ja/modifier-type.json b/src/locales/ja/modifier-type.json deleted file mode 100644 index a2e62bd941e..00000000000 --- a/src/locales/ja/modifier-type.json +++ /dev/null @@ -1,446 +0,0 @@ -{ - "ModifierType": { - "AddPokeballModifierType": { - "name": "{{modifierCount}}x {{pokeballName}}", - "description": "{{pokeballName}}を {{modifierCount}}個 手に入れる (所有: {{pokeballAmount}})\n捕捉率:{{catchRate}}" - }, - "AddVoucherModifierType": { - "name": "{{modifierCount}}x {{voucherTypeName}}", - "description": "{{voucherTypeName}}を {{modifierCount}}個 手に入れる" - }, - "PokemonHeldItemModifierType": { - "extra": { - "inoperable": "{{pokemonName}}は このアイテムを\n持つ ことが できません!", - "tooMany": "{{pokemonName}}は このアイテムを\n持ちすぎています!" - } - }, - "PokemonHpRestoreModifierType": { - "description": "ポケモン 一匹の {{restorePoints}}HP、または {{restorePercent}}% のどちらか 高い方を 回復する", - "extra": { - "fully": "ポケモン 1匹の HPを すべて 回復する", - "fullyWithStatus": "ポケモン 1匹の HPと 状態異常を すべて 回復する" - } - }, - "PokemonReviveModifierType": { - "description": "ひんしに なった ポケモン 1匹を 元気にした上で\nHPを {{restorePercent}}% 回復する" - }, - "PokemonStatusHealModifierType": { - "description": "ポケモン 1匹の 状態の 異常を すべて 回復する" - }, - "PokemonPpRestoreModifierType": { - "description": "ポケモンが 覚えている 技のうち\n1つの PPを 10だけ 回復する", - "extra": { - "fully": "ポケモンが 覚えている 技のうち\n1つの PPを すべて 回復する" - } - }, - "PokemonAllMovePpRestoreModifierType": { - "description": "ポケモンが 覚えている 4つの 技の PPを {{restorePoints}}ずつ 回復する", - "extra": { - "fully": "ポケモンが 覚えている 4つの 技の PPを すべて 回復する" - } - }, - "PokemonPpUpModifierType": { - "description": "ポケモンが 覚えている 技のうち 1つの PPの 最大値を 5ごとに {{upPoints}}ポイントずつ 上げる(最大3)" - }, - "PokemonNatureChangeModifierType": { - "name": "{{natureName}}ミント", - "description": "ポケモン 1匹の 性格を 「{{natureName}}」に 変える。\nその上、スターター画面でも {{natureName}}が 選べるように なる。" - }, - "DoubleBattleChanceBoosterModifierType": { - "description": "バトル{{battleCount}}回の間  ダブルバトルになる  確率を 4倍に する" - }, - "TempStatStageBoosterModifierType": { - "description": "全員の 手持ちポケモンの {{stat}}を 最大5回の バトルの間に {{amount}} 上げる", - "extra": { - "stage": "1段階", - "percentage": "30%" - } - }, - "AttackTypeBoosterModifierType": { - "description": "ポケモンの {{moveType}}タイプの 技の 威力を 20% 上げる" - }, - "PokemonLevelIncrementModifierType": { - "description": "ポケモンの レベルを {{levels}} 上げる" - }, - "AllPokemonLevelIncrementModifierType": { - "description": "手持ちポケモンの 全員のレベルを {{levels}} 上げる" - }, - "BaseStatBoosterModifierType": { - "description": "ポケモンの 基本の{{stat}}を 10% あげる。\n個体値が 高けば高いほど 持てる限界が 上がる" - }, - "AllPokemonFullHpRestoreModifierType": { - "description": "手持ちポケモン 全員の HPを すべて 回復する" - }, - "AllPokemonFullReviveModifierType": { - "description": "ひんしに なってしまった ポケモン 全員の HPを すべて 回復する" - }, - "MoneyRewardModifierType": { - "description": "{{moneyMultiplier}}額の 円を 与える({{moneyAmount}}円)", - "extra": { - "small": "小", - "moderate": "ある金", - "large": "多" - } - }, - "ExpBoosterModifierType": { - "description": "もらえる 経験値を {{boostPercent}}% 増やす" - }, - "PokemonExpBoosterModifierType": { - "description": "持っているポケモンの もらう経験値を {{boostPercent}}% 増やす" - }, - "PokemonFriendshipBoosterModifierType": { - "description": "持っているポケモンの なかよし度の収穫が 勝利ごとに 50% 上がる" - }, - "PokemonMoveAccuracyBoosterModifierType": { - "description": "技の 命中率を {{accuracyAmount}} 増やす(最大 100)" - }, - "PokemonMultiHitModifierType": { - "description": "持たせると 攻撃が もう一度 当たるが、\n威力が 減る(1個:60%減る/2個:75%減る/3個:82.5%減る)" - }, - "TmModifierType": { - "name": "TM{{moveId}}\n{{moveName}}", - "description": "ポケモンに {{moveName}}を 教える" - }, - "TmModifierTypeWithInfo": { - "name": "TM{{moveId}}\n{{moveName}}", - "description": "ポケモンに {{moveName}}を 教える\n(Cキー/Shiftキーを押すと 技情報が見える)" - }, - "EvolutionItemModifierType": { - "description": "ある特定の ポケモンを 進化させる" - }, - "FormChangeItemModifierType": { - "description": "ある特定の ポケモンを フォームチェンジさせる" - }, - "FusePokemonModifierType": { - "description": "2匹の ポケモンを 吸収合体する(特性が移動し、基本能力とタイプを分け、覚える技を共有する)" - }, - "TerastallizeModifierType": { - "name": "テラピース{{teraType}}", - "description": "ポケモンを {{teraType}}タイプに テラスタルさせる(最大10回のバトルの間)" - }, - "ContactHeldItemTransferChanceModifierType": { - "description": "持っているポケモンが 攻撃すると 相手の持っている\nアイテムを {{chancePercent}}%の 確率で 盗む" - }, - "TurnHeldItemTransferModifierType": { - "description": "毎ターン 相手から 一つの 持っている\nアイテム を吸い込んで 盗む" - }, - "EnemyAttackStatusEffectChanceModifierType": { - "description": "攻撃技に {{chancePercent}}%の 確率で {{statusEffect}}を 与える" - }, - "EnemyEndureChanceModifierType": { - "description": "ひんしに なりそうな 技を 受けても\n{{chancePercent}}%の 確率で HPを 1だけ 残して 耐える" - }, - - "RARE_CANDY": { "name": "ふしぎなアメ" }, - "RARER_CANDY": { "name": "ふかしぎなアメ" }, - - "MEGA_BRACELET": { "name": "メガバングル", "description": "メガストーンが 見つけられる ように なる" }, - "DYNAMAX_BAND": { "name": "ダイマックスバンド", "description": "ダイキノコが 見つけられる ように なる" }, - "TERA_ORB": { "name": "テラスタルオーブ", "description": "テラピースが 見つけられる ように なる" }, - - "MAP": { "name": "ちず", "description": "分かれ道で 行き先が 選べる よう になる" }, - - "POTION": { "name": "キズぐすり" }, - "SUPER_POTION": { "name": "いいキズぐすり" }, - "HYPER_POTION": { "name": "すごいキズぐすり" }, - "MAX_POTION": { "name": "まんたんのくすり" }, - "FULL_RESTORE": { "name": "かいふくのくすり" }, - - "REVIVE": { "name": "げんきのかけら" }, - "MAX_REVIVE": { "name": "げんきのかたまり" }, - - "FULL_HEAL": { "name": "なんでもなおし" }, - - "SACRED_ASH": { "name": "せいなるはい" }, - - "REVIVER_SEED": { "name": "ふっかつのタネ", "description": "持たせると 直接攻撃から ひんしに なれば\n復活して HPを 50% 回復する" }, - - "WHITE_HERB":{ "name": "しろいハーブ", "description": "持たせた ポケモンの能力が さがったとき 1度だけ 元の状態に 戻す" }, - - "ETHER": { "name": "ピーピーエイド" }, - "MAX_ETHER": { "name": "ピーピーリカバー" }, - - "ELIXIR": { "name": "ピーピーエイダー" }, - "MAX_ELIXIR": { "name": "ピーピーマックス" }, - - "PP_UP": { "name": "ポイントアップ" }, - "PP_MAX": { "name": "ポイントマックス" }, - - "LURE": { "name": "むしよせコロン" }, - "SUPER_LURE": { "name": "シルバーコロン" }, - "MAX_LURE": { "name": "ゴールドコロン" }, - - "MEMORY_MUSHROOM": { "name": "きおくのキノコ", "description": "1匹の ポケモンの 忘れた技を 1つ 覚えさせる" }, - - "EXP_SHARE": { "name": "がくしゅうそうち", "description": "バトルに 参加していない ポケモンが 参加したポケモンの 経験値を 20% もらう" }, - "EXP_BALANCE": { "name": "バランスそうち", "description": "レベルが低い 手持ちポケモンの もらう 経験値が 増える" }, - - "OVAL_CHARM": { "name": "まるいおまもり", "description": "バトルに 複数の ポケモンが 参加すると、\n経験値が 参加したポケモンずつ 10% 増える" }, - - "EXP_CHARM": { "name": "けいけんおまもり" }, - "SUPER_EXP_CHARM": { "name": "いいけいけんおまもり" }, - "GOLDEN_EXP_CHARM": { "name": "ゴールドけいけんちおまもり" }, - - "LUCKY_EGG": { "name": "しあわせタマゴ" }, - "GOLDEN_EGG": { "name": "ゴールドタマゴ" }, - - "SOOTHE_BELL": { "name": "やすらぎのすず" }, - - "SCOPE_LENS": { "name": "ピントレンズ", "description": "弱点が 見える レンズ。\n持たせた ポケモンの技が 急所に 当たりやすくなる"}, - "DIRE_HIT": { "name": "クリティカット", "extra": { "raises": "急所率" } }, - "LEEK": { "name": "ながねぎ", "description": "とても長くて 硬いクキ。\nカモネギに 持たせると 技が 急所に 当たりやすくなる"}, - - "EVIOLITE": { "name": "しんかのきせき", "description": "進化の不思議な かたまり。\n持たせると 進化前ポケモンの 防御と 特防が あがる" }, - - "SOUL_DEW": { "name": "こころのしずく", "description": "持たせると ポケモンの 性格が 能力に与える 影響は 10% 増える(合算)" }, - - "NUGGET": { "name": "きんのたま" }, - "BIG_NUGGET": { "name": "でかいきんのたま" }, - "RELIC_GOLD": { "name": "こだいのきんか" }, - - "AMULET_COIN": { "name": "おまもりこばん", "description": "もらえる お金が 20% 増える" }, - "GOLDEN_PUNCH": { "name": "ゴールドパンチ", "description": "持たせると 与える 直接なダメージの 50%が お金として もらえる" }, - "COIN_CASE": { "name": "コインケース", "description": "10回の バトルごとに 持ち金の 10%を 利子として 受け取れる" }, - - "LOCK_CAPSULE": { "name": "ロックカプセル", "description": "ご褒美の 選択肢変更するとき アイテムの レア度を固定できる ように なる" }, - - "GRIP_CLAW": { "name": "ねばりのかぎづめ" }, - "WIDE_LENS": { "name": "こうかくレンズ" }, - - "MULTI_LENS": { "name": "マルチレンズ" }, - - "HEALING_CHARM": { "name": "かいふくおまもり", "description": "回復する 技や アイテムの 効果を 10% あげる(復活アイテムは除く)" }, - "CANDY_JAR": { "name": "アメボトル", "description": "ふしぎなアメや ふかしぎなアメで あげるレベルを 1 増える" }, - - "BERRY_POUCH": { "name": "きのみぶくろ", "description": "使ったきのみは 無くならない 30%の可能性を 加える" }, - - "FOCUS_BAND": { "name": "きあいのハチマキ", "description": "持たせると ひんしに なりそうな 技を 受けても\n10%の可能性で HPを 1だけ 残して 耐える" }, - - "QUICK_CLAW": { "name": "せんせいのツメ", "description": "持たせると 10%の可能性で 相手より 先に 行動できる (優先技のあと)" }, - - "KINGS_ROCK": { "name": "おうじゃのしるし", "description": "持たせると 攻撃して ダメージを 与えたときに\n10%の可能性で 相手を ひるませる" }, - - "LEFTOVERS": { "name": "たべのこし", "description": "持たせると 毎ターン 最大HPの 1/16を 回復する" }, - "SHELL_BELL": { "name": "かいがらのすず", "description": "持たせると ポケモンが 相手に 与えたダメージの 1/8をHPとして 回復する." }, - - "TOXIC_ORB": { "name": "どくどくだま", "description": "触ると 毒をだす 不思議な玉。\n持たせると 戦闘中に 猛毒の状態に なる" }, - "FLAME_ORB": { "name": "かえんだま", "description": "触ると 熱をだす 不思議な玉。\n持たせると 戦闘中に やけどの状態に なる。" }, - - "BATON": { "name": "バトン", "description": "持たせると 入れ替えるとき 控えのポケモンが\n能力変化を 受けつげる (逃げられなくする 技や 特性も 回避する)" }, - - "SHINY_CHARM": { "name": "ひかるおまもり", "description": "色違いの ポケモンと 大きく 出会いやすくなる" }, - "ABILITY_CHARM": { "name": "とくせいおまもり", "description": "隠れ特性がある ポケモンと 大きく 出会いやすくなる" }, - - "IV_SCANNER": { "name": "こたいちスキャナー", "description": "野生ポケモンの 個体値を 検査できる。 一つのスキャナーあたり\n個体値が 2つ 見える。 最高の 個体値が 最初に 見える。" }, - - "DNA_SPLICERS": { "name": "いでんしのくさび" }, - - "MINI_BLACK_HOLE": { "name": "ミニブラックホール" }, - - "GOLDEN_POKEBALL": { "name": "ゴールドモンスターボール", "description": "バトル後に もう 一つの ご褒美の 選択肢を 加える" }, - - "ENEMY_DAMAGE_BOOSTER": { "name": "ダメージトークン", "description": "ダメージを 5% あげる" }, - "ENEMY_DAMAGE_REDUCTION": { "name": "ぼうごトークン", "description": "受けたダメージを 2.5% さげる" }, - "ENEMY_HEAL": { "name": "かいふくトークン", "description": "毎ターン 最大HPの 2%を 回復する" }, - "ENEMY_ATTACK_POISON_CHANCE": { "name": "どくトークン" }, - "ENEMY_ATTACK_PARALYZE_CHANCE": { "name": "まひトークン" }, - "ENEMY_ATTACK_BURN_CHANCE": { "name": "やけどトークン" }, - "ENEMY_STATUS_EFFECT_HEAL_CHANCE": { "name": "なんでもなおしトークン", "description": "毎ターン 状態異常を 治せる 2.5%の可能性を 加える" }, - "ENEMY_ENDURE_CHANCE": { "name": "こらえるトークン" }, - "ENEMY_FUSED_CHANCE": { "name": "がったいトークン", "description": "野生ポケモンは 吸収合体している 1%の可能性を 加える" } - }, - "SpeciesBoosterItem": { - "LIGHT_BALL": { "name": "でんきだま", "description": "ピカチュウに 持たせると 攻撃と 特攻が あがる 不思議な玉" }, - "THICK_CLUB": { "name": "ふといホネ", "description": "なにかの 硬いホネ。 カラカラ または ガラガラに 持たせると 攻撃が あがる" }, - "METAL_POWDER": { "name": "メタルパウダー", "description": "メタモンに 持たせると 防御が あがる 不思議な粉。 とても こまかくて 硬い" }, - "QUICK_POWDER": { "name": "スピードパウダー", "description": "メタモンに 持たせると 素早さが あがる 不思議な粉。 とても こまかくて 硬い" } - }, - "TempStatStageBoosterItem": { - "x_attack": "プラスパワー", - "x_defense": "ディフェンダー", - "x_sp_atk": "スペシャルアップ", - "x_sp_def": "スペシャルガード", - "x_speed": "スピーダー", - "x_accuracy": "ヨクアタール" - }, - "AttackTypeBoosterItem": { - "silk_scarf": "シルクのスカーフ", - "black_belt": "くろおび", - "sharp_beak": "するどいくちばし", - "poison_barb": "どくバリ", - "soft_sand": "やわらかいすな", - "hard_stone": "かたいいし", - "silver_powder": "ぎんのこな", - "spell_tag": "のろいのおふだ", - "metal_coat": "メタルコート", - "charcoal": "もくたん", - "mystic_water": "しんぴのしずく", - "miracle_seed": "きせきのタネ", - "magnet": "じしゃく", - "twisted_spoon": "まがったスプーン", - "never_melt_ice": "とけないこおり", - "dragon_fang": "りゅうのキバ", - "black_glasses": "くろいメガネ", - "fairy_feather": "ようせいのハネ" - }, - "BaseStatBoosterItem": { - "hp_up": "マックスアップ", - "protein": "タウリン", - "iron": "ブロムヘキシン", - "calcium": "リゾチウム", - "zinc": "キトサン", - "carbos": "インドメタシン" - }, - "EvolutionItem": { - "NONE": "なし", - - "LINKING_CORD": "つながりのヒモ", - "SUN_STONE": "たいようのいし", - "MOON_STONE": "つきのいし", - "LEAF_STONE": "リーフのいし", - "FIRE_STONE": "ほのおのいし", - "WATER_STONE": "みずのいし", - "THUNDER_STONE": "かみなりのいし", - "ICE_STONE": "こおりのいし", - "DUSK_STONE": "やみのいし", - "DAWN_STONE": "めざめいし", - "SHINY_STONE": "ひかりのいし", - "CRACKED_POT": "われたポット", - "SWEET_APPLE": "あまーいりんご", - "TART_APPLE": "すっぱいりんご", - "STRAWBERRY_SWEET": "いちごアメざいく", - "UNREMARKABLE_TEACUP": "ボンサクのちゃわん", - - "CHIPPED_POT": "かけたポット", - "BLACK_AUGURITE": "くろのきせき", - "GALARICA_CUFF": "ガラナツブレス", - "GALARICA_WREATH": "ガラナツリース", - "PEAT_BLOCK": "ピートブロック", - "AUSPICIOUS_ARMOR": "イワイノヨロイ", - "MALICIOUS_ARMOR": "ノロイノヨロイ", - "MASTERPIECE_TEACUP": "ケッサクのちゃわん", - "METAL_ALLOY": "ふくごうきんぞく", - "SCROLL_OF_DARKNESS": "あくのかけじく", - "SCROLL_OF_WATERS": "みずのかけじく", - "SYRUPY_APPLE": "みついりりんご" - }, - "FormChangeItem": { - "NONE": "なし", - - "ABOMASITE": "ユキノオナイト", - "ABSOLITE": "アブソルナイト", - "AERODACTYLITE": "プテラナイト", - "AGGRONITE": "ボスゴドラナイト", - "ALAKAZITE": "フーディナイト", - "ALTARIANITE": "チルタリスナイト", - "AMPHAROSITE": "デンリュウナイト", - "AUDINITE": "タブンネナイト", - "BANETTITE": "ジュペッタナイト", - "BEEDRILLITE": "スピアナイト", - "BLASTOISINITE": "カメックスナイト", - "BLAZIKENITE": "バシャーモナイト", - "CAMERUPTITE": "バクーダナイト", - "CHARIZARDITE_X": "リザードナイトX", - "CHARIZARDITE_Y": "リザードナイトY", - "DIANCITE": "ディアンシナイト", - "GALLADITE": "エルレイドナイト", - "GARCHOMPITE": "ガブリアスナイト", - "GARDEVOIRITE": "サーナイトナイト", - "GENGARITE": "ゲンガナイト", - "GLALITITE": "オニゴーリナイト", - "GYARADOSITE": "ギャラドスナイト", - "HERACRONITE": "ヘラクロスナイト", - "HOUNDOOMINITE": "ヘルガナイト", - "KANGASKHANITE": "ガルーラナイト", - "LATIASITE": "ラティアスナイト", - "LATIOSITE": "ラティオスナイト", - "LOPUNNITE": "ミミロップナイト", - "LUCARIONITE": "ルカリオナイト", - "MANECTITE": "ライボルトナイト", - "MAWILITE": "クチートナイト", - "MEDICHAMITE": "チャーレムナイト", - "METAGROSSITE": "メタグロスナイト", - "MEWTWONITE_X": "ミュウツナイトX", - "MEWTWONITE_Y": "ミュウツナイトY", - "PIDGEOTITE": "ピジョットナイト", - "PINSIRITE": "カイロスナイト", - "RAYQUAZITE": "レックウザナイト", - "SABLENITE": "ヤミラミナイト", - "SALAMENCITE": "ボーマンダナイト", - "SCEPTILITE": "ジュカインナイト", - "SCIZORITE": "ハッサムナイト", - "SHARPEDONITE": "サメハダナイト", - "SLOWBRONITE": "ヤドランナイト", - "STEELIXITE": "ハガネールナイト", - "SWAMPERTITE": "ラグラージナイト", - "TYRANITARITE": "バンギラスナイト", - "VENUSAURITE": "フシギバナイト", - - "BLUE_ORB": "あいいろのたま", - "RED_ORB": "べにいろのたま", - "SHARP_METEORITE": "シャープなうんせき", - "HARD_METEORITE": "かたいうんせき", - "SMOOTH_METEORITE": "やわらかいうんせき", - "ADAMANT_CRYSTAL": "だいこんごうだま", - "LUSTROUS_GLOBE": "だいしらたま", - "GRISEOUS_CORE": "だいはっきんだま", - "REVEAL_GLASS": "うつしかがみ", - "GRACIDEA": "グラシデアのはな", - "MAX_MUSHROOMS": "ダイキノコ", - "DARK_STONE": "ダークストーン", - "LIGHT_STONE": "ライトストーン", - "PRISON_BOTTLE": "いましめのツボ", - "N_LUNARIZER": "ネクロプラスルナ", - "N_SOLARIZER": "ネクロプラスソル", - "RUSTED_SWORD": "くちたけん", - "RUSTED_SHIELD": "くちたたて", - "ICY_REINS_OF_UNITY": "つめたいキズナのタヅナ", - "SHADOW_REINS_OF_UNITY": "くろいキズナのタヅナ", - "WELLSPRING_MASK": "いどのめん", - "HEARTHFLAME_MASK": "かまどのめん", - "CORNERSTONE_MASK": "いしずえのめん", - "SHOCK_DRIVE": "イナズマカセット", - "BURN_DRIVE": "ブレイズカセット", - "CHILL_DRIVE": "フリーズカセット", - "DOUSE_DRIVE": "アクアカセット", - "ULTRANECROZIUM_Z": "ウルトラネクロZ", - - "FIST_PLATE": "こぶしのプレート", - "SKY_PLATE": "あおぞらプレート", - "TOXIC_PLATE": "もうどくプレート", - "EARTH_PLATE": "だいちのプレート", - "STONE_PLATE": "がんせきプレート", - "INSECT_PLATE": "たまむしプレート", - "SPOOKY_PLATE": "もののけプレート", - "IRON_PLATE": "こうてつプレート", - "FLAME_PLATE": "ひのたまプレート", - "SPLASH_PLATE": "しずくプレート", - "MEADOW_PLATE": "みどりのプレート", - "ZAP_PLATE": "いかずちプレート", - "MIND_PLATE": "ふしぎのプレート", - "ICICLE_PLATE": "つららのプレート", - "DRACO_PLATE": "りゅうのプレート", - "DREAD_PLATE": "こわもてプレート", - "PIXIE_PLATE": "せいれいプレート", - "BLANK_PLATE": "まっさらプレート", - "LEGEND_PLATE": "レジェンドプレート", - "FIGHTING_MEMORY": "ファイトメモリ", - "FLYING_MEMORY": "フライングメモリ", - "POISON_MEMORY": "ポイズンメモリ", - "GROUND_MEMORY": "グラウンドメモリ", - "ROCK_MEMORY": "ロックメモリ", - "BUG_MEMORY": "バグメモリ", - "GHOST_MEMORY": "ゴーストメモリ", - "STEEL_MEMORY": "スチールメモリ", - "FIRE_MEMORY": "ファイヤーメモリ", - "WATER_MEMORY": "ウオーターメモリ", - "GRASS_MEMORY": "グラスメモリ", - "ELECTRIC_MEMORY": "エレクトロメモリ", - "PSYCHIC_MEMORY": "サイキックメモリ", - "ICE_MEMORY": "アイスメモリ", - "DRAGON_MEMORY": "ドラゴンメモリ", - "DARK_MEMORY": "ダークメモリ", - "FAIRY_MEMORY": "フェアリーメモリ", - "NORMAL_MEMORY": "ノーマルメモリ" - } -} diff --git a/src/locales/ja/modifier.json b/src/locales/ja/modifier.json deleted file mode 100644 index c33bb9be151..00000000000 --- a/src/locales/ja/modifier.json +++ /dev/null @@ -1,12 +0,0 @@ -{ - "surviveDamageApply": "{{pokemonNameWithAffix}}は\n{{typeName}}で もちこたえた!", - "turnHealApply": "{{pokemonNameWithAffix}}は\n{{typeName}}で 少し 体力を 回復した!", - "hitHealApply": "{{pokemonNameWithAffix}}は\n{{typeName}}で 少し 体力を 回復した!", - "pokemonInstantReviveApply": "{{pokemonNameWithAffix}}は\n{{typeName}}で 復活した!", - "resetNegativeStatStageApply": "{{pokemonNameWithAffix}}は {{typeName}}で\n下がった能力が 元に戻った!", - "moneyInterestApply": "{{typeName}}から {{moneyAmount}}円 取得した!", - "turnHeldItemTransferApply": "{{pokemonName}}の {{typeName}}が\n{{pokemonNameWithAffix}}の {{itemName}}を 吸い取った!", - "contactHeldItemTransferApply": "{{pokemonName}}の {{typeName}}が\n{{pokemonNameWithAffix}}の {{itemName}}を 奪い取った!", - "enemyTurnHealApply": "{{pokemonNameWithAffix}}は\n体力を 回復!", - "bypassSpeedChanceApply": "{{pokemonName}}は {{itemName}}で\n行動が はやくなった!" -} diff --git a/src/locales/ja/move-trigger.json b/src/locales/ja/move-trigger.json deleted file mode 100644 index fbefe883836..00000000000 --- a/src/locales/ja/move-trigger.json +++ /dev/null @@ -1,70 +0,0 @@ -{ - "hitWithRecoil": "{{pokemonName}}は\n反動による ダメージを 受けた!", - "cutHpPowerUpMove": "{{pokemonName}}は\n体力を 削って 技の 威力を 上がった!", - "absorbedElectricity": "{{pokemonName}}は\n 電気を 吸収した!", - "switchedStatChanges": "{{pokemonName}}は 相手と 自分の\n能力変化を 入れ替えた!", - "switchedTwoStatChanges": "{{pokemonName}}は 相手と 自分の {{firstStat}}と\n{{secondStat}}の 能力変化を 入れ替えた!", - "switchedStat": "{{pokemonName}}は 相手と {{stat}}を 入れ替えた!", - "sharedGuard": "{{pokemonName}}は\nお互いのガードを シェアした!", - "sharedPower": "{{pokemonName}}は\nお互いのパワーを シェアした!", - "goingAllOutForAttack": "{{pokemonName}}は\n本気を 出した!", - "regainedHealth": "{{pokemonName}}は\n体力を 回復した!", - "keptGoingAndCrashed": "勢い余って {{pokemonName}}は\n地面に ぶつかった!", - "fled": "{{pokemonName}}は 逃げ出した!", - "cannotBeSwitchedOut": "{{pokemonName}}を\n戻すことが できない!", - "swappedAbilitiesWithTarget": "{{pokemonName}}は\nお互いの 特性を 入れ替えた!", - "coinsScatteredEverywhere": "小判が 辺りに 散らばった!", - "attackedByItem": "{{pokemonName}}に\n{{itemName}}が おそいかかる!", - "whippedUpAWhirlwind": "{{pokemonName}}の 周りで\n空気が 渦を巻く!", - "flewUpHigh": "{{pokemonName}}は\n空高く 飛び上がった!", - "tookInSunlight": "{{pokemonName}}は\n光を 吸収した!", - "dugAHole": "{{pokemonName}}は\n地面に 潜った!", - "loweredItsHead": "{{pokemonName}}は\n首を 引っ込めた!", - "isGlowing": "{{pokemonName}}を\n激しい光が 包む!", - "bellChimed": "鈴の音が 響き渡った!", - "foresawAnAttack": "{{pokemonName}}は\n未来に 攻撃を 予知した!", - "isTighteningFocus": "{{pokemonName}}は\n集中力を 高めている!", - "hidUnderwater": "{{pokemonName}}は\n水中に 身を潜めた!", - "soothingAromaWaftedThroughArea": "心地よい 香りが 広がった!", - "sprangUp": "{{pokemonName}}は\n高く 飛び跳ねた!", - "choseDoomDesireAsDestiny": "{{pokemonName}}は\nはめつのねがいを 未来に 託した!", - "vanishedInstantly": "{{pokemonName}}の 姿が\n一瞬にして 消えた!", - "tookTargetIntoSky": "{{pokemonName}}は {{targetName}}を\n上空に 連れ去った!", - "becameCloakedInFreezingLight": "{{pokemonName}}は\n冷たい光に 包まれた!", - "becameCloakedInFreezingAir": "{{pokemonName}}は\n凍える空気に 包まれた!", - "isChargingPower": "{{pokemonName}}は\nパワーを 溜め込んでいる!", - "burnedItselfOut": "{{pokemonName}}の 炎は 燃え尽きた!", - "startedHeatingUpBeak": "{{pokemonName}}は\nクチバシを 加熱し始めた!", - "setUpShellTrap": "{{pokemonName}}は\nトラップシェルを 仕掛けた!", - "isOverflowingWithSpacePower": "{{pokemonName}}に\n宇宙の 力が 溢れ出す!", - "usedUpAllElectricity": "{{pokemonName}}は\n電気を 使い切った!", - "stoleItem": "{{pokemonName}}は\n{{targetName}}の {{itemName}}を 盗んだ!", - "incineratedItem": "{{pokemonName}}は\n{{targetName}}の {{itemName}}を 燃やした!", - "knockedOffItem": "{{pokemonName}}は\n{{targetName}}の {{itemName}}を はたき落とした!", - "tookMoveAttack": "{{pokemonName}}は\n{{moveName}}の 攻撃を 受けた!", - "cutOwnHpAndMaximizedStat": "{{pokemonName}}は\n体力を 削って {{statName}}全開!", - "copiedStatChanges": "{{pokemonName}}は {{targetName}}の\n能力変化を コピーした!", - "magnitudeMessage": "マグニチュード{{magnitude}}!", - "tookAimAtTarget": "{{pokemonName}}は {{targetName}}に\n狙いを 定めた!", - "transformedIntoType": "{{pokemonName}}は\n{{typeName}}タイプに なった!", - "copiedMove": "{{pokemonName}}は\n{{moveName}}を コピーした!", - "sketchedMove": "{{pokemonName}}は\n{{moveName}}を スケッチした!", - "acquiredAbility": "{{pokemonName}}の 特性が\n{{abilityName}}に なった!", - "copiedTargetAbility": "{{pokemonName}}は\n{{targetName}}の {{abilityName}}を コピーした!", - "transformedIntoTarget": "{{pokemonName}}は\n{{targetName}}に 変身した!", - "tryingToTakeFoeDown": "{{pokemonName}}は 相手を\nみちづれに しようとしている!", - "addType": "{{pokemonName}}に\n{{typeName}}タイプが 追加された!", - "cannotUseMove": "{{pokemonName}}は\n{{moveName}}を 使えなかった!", - "healHp": "{{pokemonName}}の\n体力が 回復した!", - "sacrificialFullRestore": "{{pokemonName}}の\nいやしのねがいが 叶った!", - "invertStats": "{{pokemonName}}は\n能力変化が ひっくり返った!", - "resetStats": "{{pokemonName}}の\n能力変化が 元に戻った!", - "statEliminated": "全ての 能力変化が 元に戻った!", - "faintCountdown": "{{pokemonName}}は\n{{turnCount}}ターン後に 滅びてしまう!", - "copyType": "{{pokemonName}}は {{targetPokemonName}}と\n同じタイプに なった!", - "suppressAbilities": "{{pokemonName}}の 特性が 効かなくなった!", - "revivalBlessing": "{{pokemonName}}は\n復活して 戦えるようになった!", - "swapArenaTags": "{{pokemonName}}は\nお互いの 場の 効果を 入れ替えた!", - "exposedMove": "{{pokemonName}}は {{targetPokemonName}}の\n正体を 見破った!", - "afterYou": "{{pokemonName}}は\nお言葉に 甘えることにした!" -} diff --git a/src/locales/ja/move.json b/src/locales/ja/move.json deleted file mode 100644 index 2e602407902..00000000000 --- a/src/locales/ja/move.json +++ /dev/null @@ -1,3810 +0,0 @@ -{ - "pound": { - "name": "はたく", - "effect": "長い しっぽや 手などを 使って 相手を はたいて 攻撃する。" - }, - "karateChop": { - "name": "からてチョップ", - "effect": "鋭い チョップで 相手を たたいて 攻撃する。 急所に 当たりやすい。" - }, - "doubleSlap": { - "name": "おうふくビンタ", - "effect": "おうふく ビンタで 相手を たたいて 攻撃する。 2ー5回の 間 連続で だす。" - }, - "cometPunch": { - "name": "れんぞくパンチ", - "effect": "どとうの パンチで 相手を なぐりつけて 攻撃する。 2ー5回の 間 連続で だす。" - }, - "megaPunch": { - "name": "メガトンパンチ", - "effect": "力を こめた パンチで 相手を 攻撃する。" - }, - "payDay": { - "name": "ネコにこばん", - "effect": "相手の 体に 小判を 投げつけて 攻撃する。 戦闘の あとで お金が もらえる。" - }, - "firePunch": { - "name": "ほのおのパンチ", - "effect": "炎を こめた パンチで 相手を 攻撃する。 やけど状態に することが ある。" - }, - "icePunch": { - "name": "れいとうパンチ", - "effect": "冷気を こめた パンチで 相手を 攻撃する。 こおり状態に することが ある。" - }, - "thunderPunch": { - "name": "かみなりパンチ", - "effect": "電撃を こめた パンチで 相手を 攻撃する。 まひ状態に することが ある。" - }, - "scratch": { - "name": "ひっかく", - "effect": "硬く とがった 鋭い ツメで 相手を ひっかいて 攻撃する。" - }, - "viseGrip": { - "name": "はさむ", - "effect": "相手を 両側から はさんで ダメージを あたえる。" - }, - "guillotine": { - "name": "ハサミギロチン", - "effect": "大きな ハサミで 相手を 切り裂いて 攻撃する。 当たれば 一撃で ひんしに する。" - }, - "razorWind": { - "name": "かまいたち", - "effect": "風の 刃を つくり 2ターン目に 相手を 攻撃する。 急所に 当たりやすい。" - }, - "swordsDance": { - "name": "つるぎのまい", - "effect": "戦いの舞を 激しく おどって 気合を 高める。 自分の 攻撃を ぐーんと あげる。" - }, - "cut": { - "name": "いあいぎり", - "effect": "カマや ツメなどで 相手を 切りつけて 攻撃する。" - }, - "gust": { - "name": "かぜおこし", - "effect": "翼で おこした 激しい 風を 相手に ぶつけて 攻撃する。" - }, - "wingAttack": { - "name": "つばさでうつ", - "effect": "大きく ひろげた りっぱな 翼を 相手に ぶつけて 攻撃する。" - }, - "whirlwind": { - "name": "ふきとばし", - "effect": "相手を 吹きとばして 控えの ポケモンを ひきずりだす。 野生の 場合は 戦闘が 終わる。" - }, - "fly": { - "name": "そらをとぶ", - "effect": "1ターン目で 空へ 飛び 2ターン目に 相手を 攻撃する。" - }, - "bind": { - "name": "しめつける", - "effect": "長い 体や つるなどを 使い 4ー5ターンの 間 相手を 締めつけて 攻撃する。" - }, - "slam": { - "name": "たたきつける", - "effect": "長い しっぽや つるなどを 使い 相手を たたきつけて 攻撃する。" - }, - "vineWhip": { - "name": "つるのムチ", - "effect": "ムチのように しなる 細長い つるで 相手を たたきつけて 攻撃する。" - }, - "stomp": { - "name": "ふみつけ", - "effect": "大きな 足で 相手を 踏みつけて 攻撃する。 相手を ひるませることが ある。" - }, - "doubleKick": { - "name": "にどげり", - "effect": "2本の 足で 相手を けとばして 攻撃する。 2回連続で ダメージを 与える。" - }, - "megaKick": { - "name": "メガトンキック", - "effect": "ものすごい 力を こめた キックで 相手を けとばして 攻撃する。" - }, - "jumpKick": { - "name": "とびげり", - "effect": "高い ジャンプからの キックで 相手を 攻撃する。 はずすと 自分が ダメージを 受ける。" - }, - "rollingKick": { - "name": "まわしげり", - "effect": "体を 素早く 回転させながら けとばして 攻撃する。 相手を ひるませる ことが ある。" - }, - "sandAttack": { - "name": "すなかけ", - "effect": "相手の 顔に 砂を かけて 命中率を さげる。" - }, - "headbutt": { - "name": "ずつき", - "effect": "頭を 突きだして まっすぐ つっこんで 攻撃する。 相手を ひるませることが ある。" - }, - "hornAttack": { - "name": "つのでつく", - "effect": "鋭く とがった つので 相手を 攻撃する。" - }, - "furyAttack": { - "name": "みだれづき", - "effect": "つのや くちばしで 相手を つついて 攻撃する。 2ー5回の 間 連続で だす。" - }, - "hornDrill": { - "name": "つのドリル", - "effect": "回転する つのを 相手に 突き刺して 攻撃する。 当たれば 一撃で ひんしに する。" - }, - "tackle": { - "name": "たいあたり", - "effect": "相手に むかって 全身で ぶつかっていき 攻撃する。" - }, - "bodySlam": { - "name": "のしかかり", - "effect": "全身で 相手に のしかかり 攻撃する。 まひ状態に することが ある。" - }, - "wrap": { - "name": "まきつく", - "effect": "長い 体や つるなどを 使って 4ー5ターンの 間 相手に まきついて 攻撃する。" - }, - "takeDown": { - "name": "とっしん", - "effect": "すごい 勢いで 相手に ぶつかって 攻撃する。 自分も 少し ダメージを 受ける。" - }, - "thrash": { - "name": "あばれる", - "effect": "2ー3ターンの 間 暴れまくって 相手を 攻撃する。 暴れたあとは 混乱する。" - }, - "doubleEdge": { - "name": "すてみタックル", - "effect": "命を 懸けて 相手に 突進して 攻撃する。 自分も かなり ダメージを 受ける。" - }, - "tailWhip": { - "name": "しっぽをふる", - "effect": "しっぽを 左右に かわいく ふって 油断を 誘う。 相手の 防御を さげる。" - }, - "poisonSting": { - "name": "どくばり", - "effect": "毒の ある ハリを 相手に 突き刺して 攻撃する。 毒状態に することが ある。" - }, - "twineedle": { - "name": "ダブルニードル", - "effect": "2本の ハリを 相手に 突き刺し 2回連続で ダメージ。 毒状態に することが ある。" - }, - "pinMissile": { - "name": "ミサイルばり", - "effect": "鋭い ハリを 相手に 発射して 攻撃する。 2ー5回の 間 連続で だす。" - }, - "leer": { - "name": "にらみつける", - "effect": "鋭い 目つきで おびえさせて 相手の 防御を さげる。" - }, - "bite": { - "name": "かみつく", - "effect": "鋭く とがった 歯で かみついて 攻撃する。 相手を ひるませることが ある。" - }, - "growl": { - "name": "なきごえ", - "effect": "かわいい なきごえを 聞かせて 気を ひき 油断を させて 相手の 攻撃を さげる。" - }, - "roar": { - "name": "ほえる", - "effect": "相手を 逃がして 控えの ポケモンを ひきずりだす。 野生の 場合は 戦闘が 終わる。" - }, - "sing": { - "name": "うたう", - "effect": "心地好い きれいな 歌声を 聞かせて 相手を 眠り状態に する。" - }, - "supersonic": { - "name": "ちょうおんぱ", - "effect": "特殊な 音波を 体から 発して 相手を 混乱させる。" - }, - "sonicBoom": { - "name": "ソニックブーム", - "effect": "衝撃波を 相手に ぶつけて 攻撃する。 20の ダメージを 決まって 与える。" - }, - "disable": { - "name": "かなしばり", - "effect": "相手の 動きを とめて 直前に だしていた 技を 4ターンの 間 使えなくする。" - }, - "acid": { - "name": "ようかいえき", - "effect": "強い 酸を 相手に かけて 攻撃する。 相手の 特防を さげることが ある。" - }, - "ember": { - "name": "ひのこ", - "effect": "小さな 炎を 相手に 発射して 攻撃する。 やけど状態に することが ある。" - }, - "flamethrower": { - "name": "かえんほうしゃ", - "effect": "激しい 炎を 相手に 発射して 攻撃する。 やけど状態に することが ある。" - }, - "mist": { - "name": "しろいきり", - "effect": "白い霧で 体を おおう。 5ターンの 間 相手に 能力を さげられなく なる。" - }, - "waterGun": { - "name": "みずでっぽう", - "effect": "水を 勢いよく 相手に 発射して 攻撃する。" - }, - "hydroPump": { - "name": "ハイドロポンプ", - "effect": "大量の 水を 激しい 勢いで 相手に 発射して 攻撃する。" - }, - "surf": { - "name": "なみのり", - "effect": "大きな 波で 自分の 周りに いるものを 攻撃する。" - }, - "iceBeam": { - "name": "れいとうビーム", - "effect": "凍える ビームを 相手に 発射して 攻撃する。 こおり状態に することが ある。" - }, - "blizzard": { - "name": "ふぶき", - "effect": "激しい 吹雪を 相手に 吹きつけて 攻撃する。 こおり状態に することが ある。" - }, - "psybeam": { - "name": "サイケこうせん", - "effect": "不思議な 光線を 相手に 発射して 攻撃する。 混乱させることが ある。" - }, - "bubbleBeam": { - "name": "バブルこうせん", - "effect": "泡を 勢いよく 相手に 発射して 攻撃する。 素早さを さげる ことが ある。" - }, - "auroraBeam": { - "name": "オーロラビーム", - "effect": "にじいろの ビームを 相手に 発射して 攻撃する。 攻撃を さげる ことが ある。" - }, - "hyperBeam": { - "name": "はかいこうせん", - "effect": "強い 光線を 相手に 発射して 攻撃する。 次の ターンは 動けなくなる。" - }, - "peck": { - "name": "つつく", - "effect": "鋭く とがった くちばしや つので 相手を 突いて 攻撃する。" - }, - "drillPeck": { - "name": "ドリルくちばし", - "effect": "回転しながら とがった くちばしを 相手に 突き刺して 攻撃する。" - }, - "submission": { - "name": "じごくぐるま", - "effect": "地面に 自分ごと 相手を 投げつけて 攻撃する。 自分も 少し ダメージを 受ける。" - }, - "lowKick": { - "name": "けたぐり", - "effect": "足を 強く けり 相手を 転ばせて 攻撃する。 相手が 重いほど 威力が あがる。" - }, - "counter": { - "name": "カウンター", - "effect": "相手から 受けた 物理攻撃の ダメージを 2倍に して 同じ 相手に 返す。" - }, - "seismicToss": { - "name": "ちきゅうなげ", - "effect": "引力を 使い 投げとばす。 自分の レベルと 同じ ダメージを 相手に 与える。" - }, - "strength": { - "name": "かいりき", - "effect": "こん身の 力で 相手を なぐりつけて 攻撃する。" - }, - "absorb": { - "name": "すいとる", - "effect": "養分を 吸い取り 攻撃する。 相手に 与えた ダメージの 半分の HPを 回復できる。" - }, - "megaDrain": { - "name": "メガドレイン", - "effect": "養分を 吸い取り 攻撃する。 相手に 与えた ダメージの 半分の HPを 回復できる。" - }, - "leechSeed": { - "name": "やどりぎのタネ", - "effect": "植えつけた 相手の HPを 毎ターン 少しだけ 吸い取り 自分の HPを 回復する。" - }, - "growth": { - "name": "せいちょう", - "effect": "体を 一気に 大きく 生長させて 攻撃と 特攻を あげる。" - }, - "razorLeaf": { - "name": "はっぱカッター", - "effect": "はっぱを とばして 相手を 切りつけて 攻撃する。 急所に 当たりやすい。" - }, - "solarBeam": { - "name": "ソーラービーム", - "effect": "1ターン目に 光を いっぱいに 集め 2ターン目に 光の 束を 発射して 攻撃する。" - }, - "poisonPowder": { - "name": "どくのこな", - "effect": "毒の ある 粉を たくさん ふりまいて 相手を 毒状態に する。" - }, - "stunSpore": { - "name": "しびれごな", - "effect": "しびれる 粉を たくさん ふりまいて 相手を まひ状態に する。" - }, - "sleepPowder": { - "name": "ねむりごな", - "effect": "眠くなる 粉を たくさん ふりまいて 相手を 眠り状態に する。" - }, - "petalDance": { - "name": "はなびらのまい", - "effect": "2ー3ターンの 間 花を まきちらして 相手を 攻撃する。 まきちらした あとは 混乱する。" - }, - "stringShot": { - "name": "いとをはく", - "effect": "口から 吹きだした 糸を まきつけて 相手の 素早さを がくっと さげる。" - }, - "dragonRage": { - "name": "りゅうのいかり", - "effect": "怒りの 衝撃波を 相手に ぶつけて 攻撃する。 40の ダメージを 決まって 与える。" - }, - "fireSpin": { - "name": "ほのおのうず", - "effect": "激しく 渦をまく 炎の中に 4ー5ターンの 間 相手を 閉じこめて 攻撃する。" - }, - "thunderShock": { - "name": "でんきショック", - "effect": "電気の 刺激を 相手に 浴びせて 攻撃する。 まひ状態に することが ある。" - }, - "thunderbolt": { - "name": "10まんボルト", - "effect": "強い 電撃を 相手に 浴びせて 攻撃する。 まひ状態に することが ある。" - }, - "thunderWave": { - "name": "でんじは", - "effect": "弱い 電撃を 浴びせることで 相手を まひ状態に する。" - }, - "thunder": { - "name": "かみなり", - "effect": "激しい 雷を 相手に 落として 攻撃する。 まひ状態に することが ある。" - }, - "rockThrow": { - "name": "いわおとし", - "effect": "小さな 岩を 持ちあげて 相手に 投げつけて 攻撃する。" - }, - "earthquake": { - "name": "じしん", - "effect": "地震の 衝撃で 自分の 周りに いるものを 攻撃する。" - }, - "fissure": { - "name": "じわれ", - "effect": "地割れの 裂け目に 相手を 落として 攻撃する。 当たれば 一撃で ひんしに する。" - }, - "dig": { - "name": "あなをほる", - "effect": "1ターン目に 潜り 2ターン目で 相手を 攻撃する。" - }, - "toxic": { - "name": "どくどく", - "effect": "相手を 猛毒の 状態に する。 ターンが すすむほど 毒の ダメージが 増えていく。" - }, - "confusion": { - "name": "ねんりき", - "effect": "弱い 念力を 相手に 送って 攻撃する。 相手を 混乱させることが ある。" - }, - "psychic": { - "name": "サイコキネシス", - "effect": "強い 念力を 相手に 送って 攻撃する。 相手の 特防を さげることが ある。" - }, - "hypnosis": { - "name": "さいみんじゅつ", - "effect": "眠気を 誘う 暗示を かけて 相手を 眠り状態に する。" - }, - "meditate": { - "name": "ヨガのポーズ", - "effect": "眠っている 力を 体の 奥から ひきだして 自分の 攻撃を あげる。" - }, - "agility": { - "name": "こうそくいどう", - "effect": "力を ぬいて 体を 軽くして 高速で 動く。 自分の 素早さを ぐーんと あげる。" - }, - "quickAttack": { - "name": "でんこうせっか", - "effect": "目にも 留まらぬ ものすごい 速さで 相手に つっこむ。 必ず 先制攻撃 できる。" - }, - "rage": { - "name": "いかり", - "effect": "技を だしたときに 攻撃を 受けると 怒りの 力で 攻撃が あがる。" - }, - "teleport": { - "name": "テレポート", - "effect": "ひかえの ポケモンが いるときに 使うと 入れ替わる。 野生の ポケモンは 逃げてしまう。" - }, - "nightShade": { - "name": "ナイトヘッド", - "effect": "恐ろしい 幻を みせて 自分の レベルと 同じだけの ダメージを 相手に 与える。" - }, - "mimic": { - "name": "ものまね", - "effect": "相手が 最後に 使った 技を 戦闘の あいだ 自分の 技に することが できる。" - }, - "screech": { - "name": "いやなおと", - "effect": "おもわず 耳を ふさぎたくなる いやなおとを だして 相手の 防御を がくっと さげる。" - }, - "doubleTeam": { - "name": "かげぶんしん", - "effect": "素早い 動きで 分身を つくり 相手を まどわせて 回避率を あげる。" - }, - "recover": { - "name": "じこさいせい", - "effect": "細胞を 再生させて 自分の 最大HPの 半分の HPを 回復する。" - }, - "harden": { - "name": "かたくなる", - "effect": "全身に 力を こめて 体を 硬くして 自分の 防御を あげる。" - }, - "minimize": { - "name": "ちいさくなる", - "effect": "体を ちぢめて 小さく みせて 自分の 回避率を ぐーんと あげる。" - }, - "smokescreen": { - "name": "えんまく", - "effect": "煙や 墨などを 吹きかけて 相手の 命中率を さげる。" - }, - "confuseRay": { - "name": "あやしいひかり", - "effect": "怪しい 光を 相手に みせて まどわせる。 相手を 混乱させる。" - }, - "withdraw": { - "name": "からにこもる", - "effect": "殻に 潜りこんで 身を守り 自分の 防御を あげる。" - }, - "defenseCurl": { - "name": "まるくなる", - "effect": "体を まるめて ちぢこまり 自分の 防御を あげる。" - }, - "barrier": { - "name": "バリアー", - "effect": "頑丈な 壁を つくって 自分の 防御を ぐーんと あげる。" - }, - "lightScreen": { - "name": "ひかりのかべ", - "effect": "5ターンの 間 不思議な かべで 相手から 受ける 特殊攻撃の ダメージを 弱める。" - }, - "haze": { - "name": "くろいきり", - "effect": "黒い霧を だして 戦闘に でている ポケモン 全員の 能力変化を もとに もどす。" - }, - "reflect": { - "name": "リフレクター", - "effect": "5ターンの 間 不思議な かべで 相手から 受ける 物理攻撃の ダメージを 弱める。" - }, - "focusEnergy": { - "name": "きあいだめ", - "effect": "深く 息を 吸い 気合を こめる。 自分の 攻撃が 急所に 当たりやすくなる。" - }, - "bide": { - "name": "がまん", - "effect": "2ターンの 間 攻撃に たえて 受けた ダメージを 2倍にして 相手に 返す。" - }, - "metronome": { - "name": "ゆびをふる", - "effect": "指をふり 自分の 脳を 刺激して すべての 技の なかから どれか 1つを くりだす。" - }, - "mirrorMove": { - "name": "オウムがえし", - "effect": "相手の 使った 技を まねして 自分も 同じ技を 使う。" - }, - "selfDestruct": { - "name": "じばく", - "effect": "爆発を おこして 自分の 周りに いるものを 攻撃する。 使ったあとに ひんしに なる。" - }, - "eggBomb": { - "name": "タマゴばくだん", - "effect": "大きな タマゴを 力いっぱい 相手に 投げつけて 攻撃する。" - }, - "lick": { - "name": "したでなめる", - "effect": "長い 舌で 相手を なめまわして 攻撃する。 まひ状態に することが ある。" - }, - "smog": { - "name": "スモッグ", - "effect": "汚れた ガスを 相手に 吹きつけて 攻撃する。 毒状態に することが ある。" - }, - "sludge": { - "name": "ヘドロこうげき", - "effect": "汚い ヘドロを 相手に 投げつけて 攻撃する。 毒状態に することが ある。" - }, - "boneClub": { - "name": "ホネこんぼう", - "effect": "手に 持った ホネで 相手を なぐりつけて 攻撃する。 相手を ひるませることが ある。" - }, - "fireBlast": { - "name": "だいもんじ", - "effect": "大の字の 炎で 相手を 焼きつくす。 やけど状態に することが ある。" - }, - "waterfall": { - "name": "たきのぼり", - "effect": "すごい 勢いで 相手に つっこむ。 相手を ひるませることが ある。" - }, - "clamp": { - "name": "からではさむ", - "effect": "とても 頑丈な ぶあつい 殻に 4ー5ターンの 間 相手を はさんで 攻撃する。" - }, - "swift": { - "name": "スピードスター", - "effect": "星型の 光を 発射して 相手を 攻撃する。 攻撃は 必ず 命中する。" - }, - "skullBash": { - "name": "ロケットずつき", - "effect": "1ターン目に 頭を ひっこめて 防御を あげる。 2ターン目に 相手を 攻撃する。" - }, - "spikeCannon": { - "name": "とげキャノン", - "effect": "鋭い ハリを 相手に 発射して 攻撃する。 2ー5回の 間 連続で だす。" - }, - "constrict": { - "name": "からみつく", - "effect": "触手や ツタなどを からみつけて 攻撃する。相手の 素早さを さげることが ある。" - }, - "amnesia": { - "name": "ドわすれ", - "effect": "頭を からにして 一瞬 なにかを 忘れることで 自分の 特防を ぐーんと あげる。" - }, - "kinesis": { - "name": "スプーンまげ", - "effect": "スプーンを まげて 注意を ひき 相手の 命中率を さげる。" - }, - "softBoiled": { - "name": "タマゴうみ", - "effect": "最大HPの 半分 自分の HPを 回復する。" - }, - "highJumpKick": { - "name": "とびひざげり", - "effect": "ジャンプからの ひざげりで 相手を 攻撃する。 はずすと 自分が ダメージを 受ける。" - }, - "glare": { - "name": "へびにらみ", - "effect": "おなかの 模様で おびえさせて 相手を まひの 状態に する。" - }, - "dreamEater": { - "name": "ゆめくい", - "effect": "寝ている 相手の 夢を 食べて 攻撃する。 ダメージの 半分の HPを 回復する。" - }, - "poisonGas": { - "name": "どくガス", - "effect": "毒ガスを 相手の 顔に 吹きかけて 毒の 状態に する。" - }, - "barrage": { - "name": "たまなげ", - "effect": "まるい ものを 相手に 投げつけて 攻撃する。 2ー5回の 間 連続で だす。" - }, - "leechLife": { - "name": "きゅうけつ", - "effect": "血を 吸い取って 相手を 攻撃する。 与えた ダメージの 半分の HPを 回復できる。" - }, - "lovelyKiss": { - "name": "あくまのキッス", - "effect": "恐ろしい 顔で キスを せまる。 相手を 眠り状態に する。" - }, - "skyAttack": { - "name": "ゴッドバード", - "effect": "2ターン目に 相手を 攻撃する。 たまに ひるませる。 急所にも 当たりやすい。" - }, - "transform": { - "name": "へんしん", - "effect": "相手の ポケモンに 変身することで 相手と まったく 同じ 技が 使える。" - }, - "bubble": { - "name": "あわ", - "effect": "無数の 泡を 相手に 吹きかけて 攻撃する。 相手の 素早さを さげることが ある。" - }, - "dizzyPunch": { - "name": "ピヨピヨパンチ", - "effect": "リズミカルに パンチを くりだして 相手を 攻撃する。 混乱させることが ある。" - }, - "spore": { - "name": "キノコのほうし", - "effect": "催眠効果の ある 胞子を パラパラと ふりまき 相手を 眠り状態に する。" - }, - "flash": { - "name": "フラッシュ", - "effect": "まぶしい 光で 相手の 命中率を さげる。" - }, - "psywave": { - "name": "サイコウェーブ", - "effect": "不思議な 念波を 相手に 発射して 攻撃する。 使うたびに ダメージが 変わる。" - }, - "splash": { - "name": "はねる", - "effect": "攻撃もせずに ピョン ピョンと 跳ねるだけで なにも おこらない……。" - }, - "acidArmor": { - "name": "とける", - "effect": "細胞の 変化で 液状に なり 自分の 防御を ぐーんと あげる。" - }, - "crabhammer": { - "name": "クラブハンマー", - "effect": "大きな ハサミを 相手に たたきつけて 攻撃する。 急所に 当たりやすい。" - }, - "explosion": { - "name": "だいばくはつ", - "effect": "大きな 爆発で 自分の 周りに いるものを 攻撃する。 使ったあとに ひんしに なる。" - }, - "furySwipes": { - "name": "みだれひっかき", - "effect": "ツメや カマなどで 相手を ひっかいて 攻撃する。 2ー5回の 間 連続で だす。" - }, - "bonemerang": { - "name": "ホネブーメラン", - "effect": "手に 持った ホネを 相手に 投げつけ 行きと 帰りの 2回連続で ダメージを 与える。" - }, - "rest": { - "name": "ねむる", - "effect": "2ターンの 間 眠り続ける。 自分の HPと 状態異常を すべて 回復する。" - }, - "rockSlide": { - "name": "いわなだれ", - "effect": "大きな 岩を 激しく ぶつけて 攻撃する。 相手を ひるませることが ある。" - }, - "hyperFang": { - "name": "ひっさつまえば", - "effect": "鋭い 前歯で 強く かみついて 攻撃する。 相手を ひるませることが ある。" - }, - "sharpen": { - "name": "かくばる", - "effect": "体の かどを 増やして カクカクに なることで 自分の 攻撃を あげる。" - }, - "conversion": { - "name": "テクスチャー", - "effect": "自分の タイプを おぼえている 技で 一番 上の 技と 同じ タイプに する。" - }, - "triAttack": { - "name": "トライアタック", - "effect": "3つの 光線で 攻撃する。 まひか やけどか こおり状態の どれかに することが ある。" - }, - "superFang": { - "name": "いかりのまえば", - "effect": "鋭い 前歯で 激しく かみついて 攻撃する。 相手の HPは 半分に なる。" - }, - "slash": { - "name": "きりさく", - "effect": "ツメや カマなどで 相手を 切り裂いて 攻撃する。 急所に 当たりやすい。" - }, - "substitute": { - "name": "みがわり", - "effect": "自分の HPを 少し 削って 分身を だす。 分身は 自分の 身代わりに なる。" - }, - "struggle": { - "name": "わるあがき", - "effect": "自分の PPが なくなると あがいて 相手を 攻撃する。 自分も 少し ダメージを 受ける。" - }, - "sketch": { - "name": "スケッチ", - "effect": "相手が 使った 技を 自分の ものに する。 1回 使うと スケッチは 消える。" - }, - "tripleKick": { - "name": "トリプルキック", - "effect": "3回連続で キックを くりだして 攻撃する。 技が 当たるたびに 威力は あがる。" - }, - "thief": { - "name": "どろぼう", - "effect": "攻撃と 同時に 道具を 盗もうとする。 盗む 可能性は 30%。" - }, - "spiderWeb": { - "name": "クモのす", - "effect": "ネバネバした 細い 糸を グルグルと からませて 相手を 戦闘から 逃げられなくする。" - }, - "mindReader": { - "name": "こころのめ", - "effect": "相手の 動きを 心で 感じて 次の 攻撃が 必ず 相手に 当たるように する。" - }, - "nightmare": { - "name": "あくむ", - "effect": "眠り状態の 相手に 悪夢を みせて 毎ターン 少しずつ HPを 減らしていく。" - }, - "flameWheel": { - "name": "かえんぐるま", - "effect": "炎を まとい 相手に 突進して 攻撃する。 やけど状態に することが ある。" - }, - "snore": { - "name": "いびき", - "effect": "自分が 寝ているときに 雑音を だして 攻撃する。 相手を ひるませることが ある。" - }, - "curse": { - "name": "のろい", - "effect": "使う ポケモンが ゴーストタイプと それ以外 とでは 効果が 変わる。" - }, - "flail": { - "name": "じたばた", - "effect": "じたばた 暴れて 攻撃する。 自分の HPが 少ないほど 技の 威力は あがる。" - }, - "conversion2": { - "name": "テクスチャー2", - "effect": "相手が 最後に 使った技に 抵抗できる ように 自分の タイプを 変化させる。" - }, - "aeroblast": { - "name": "エアロブラスト", - "effect": "空気の 渦を 発射して 攻撃する。 急所に 当たりやすい。" - }, - "cottonSpore": { - "name": "わたほうし", - "effect": "綿のような フワフワの 胞子を まとわり つかせて 相手の 素早さを がくっと さげる。" - }, - "reversal": { - "name": "きしかいせい", - "effect": "力を ふりしぼり 攻撃する。 自分の HPが 少ないほど 技の 威力は あがる。" - }, - "spite": { - "name": "うらみ", - "effect": "相手が 最後に 使った技に 恨みを 抱いて その技の PPを 4だけ 減らす。" - }, - "powderSnow": { - "name": "こなゆき", - "effect": "冷たい 粉雪を 相手に 吹きつけて 攻撃する。 こおり状態に することが ある。" - }, - "protect": { - "name": "まもる", - "effect": "相手の 攻撃を まったく 受けない。 連続で だすと 失敗しやすい。" - }, - "machPunch": { - "name": "マッハパンチ", - "effect": "目にも 留まらぬ ものすごい 速さで パンチを くりだす。 必ず 先制攻撃 できる。" - }, - "scaryFace": { - "name": "こわいかお", - "effect": "恐ろしい 顔で にらみ おびえさせて 相手の 素早さを がくっと さげる。" - }, - "feintAttack": { - "name": "だましうち", - "effect": "さりげなく 相手に ちかづき 油断した すきを みて なぐりつける。 攻撃は 必ず 命中する。" - }, - "sweetKiss": { - "name": "てんしのキッス", - "effect": "天使のように かわいく キスして 相手を 混乱させる。" - }, - "bellyDrum": { - "name": "はらだいこ", - "effect": "自分の HPを 最大HPの 半分 減らして 自分の 攻撃を 最大に あげる。" - }, - "sludgeBomb": { - "name": "ヘドロばくだん", - "effect": "汚い ヘドロを 相手に 投げつけて 攻撃する。 毒状態に することが ある。" - }, - "mudSlap": { - "name": "どろかけ", - "effect": "相手の 顔などに 泥を 投げつけて 攻撃する。 命中率を さげる。" - }, - "octazooka": { - "name": "オクタンほう", - "effect": "相手の 顔などに 墨を 吹きかけて 攻撃する。 命中率を さげることが ある。" - }, - "spikes": { - "name": "まきびし", - "effect": "相手の 足下に まきびしを しかける。交代で でてきた 相手の ポケモンに ダメージを 与える。" - }, - "zapCannon": { - "name": "でんじほう", - "effect": "大砲の ような 電気を 発射して 攻撃する。 相手を まひの 状態に する。" - }, - "foresight": { - "name": "みやぶる", - "effect": "ゴーストタイプに 効果がない 技や 回避率の 高い 相手に 攻撃が 当たるように なる。" - }, - "destinyBond": { - "name": "みちづれ", - "effect": "技のあと 相手の 攻撃で ひんしに なると 攻撃 相手も ひんしにする。 連続して 出すと 失敗する。" - }, - "perishSong": { - "name": "ほろびのうた", - "effect": "歌を 聴いた ポケモンは 3ターン たつと ひんしに なる。 交代すると 効果は なくなる。" - }, - "icyWind": { - "name": "こごえるかぜ", - "effect": "凍てつく 冷気を 相手に 吹きつけて 攻撃する。 相手の 素早さを さげる。" - }, - "detect": { - "name": "みきり", - "effect": "相手の 攻撃を まったく 受けない。 連続で だすと 失敗しやすい。" - }, - "boneRush": { - "name": "ボーンラッシュ", - "effect": "硬い ホネで 相手を なぐりつけて 攻撃する。 2ー5回の 間 連続で だす。" - }, - "lockOn": { - "name": "ロックオン", - "effect": "照準を しっかり あわせて 次の 攻撃が 必ず 相手に 当たるように する。" - }, - "outrage": { - "name": "げきりん", - "effect": "2ー3ターンの 間 暴れまくって 相手を 攻撃する。 暴れたあとは 混乱する。" - }, - "sandstorm": { - "name": "すなあらし", - "effect": "5ターンの 間 砂あらしで いわ じめん はがねタイプ 以外に ダメージ。 いわタイプの 特防が あがる。" - }, - "gigaDrain": { - "name": "ギガドレイン", - "effect": "養分を 吸い取り 攻撃する。 相手に 与えた ダメージの 半分の HPを 回復できる。" - }, - "endure": { - "name": "こらえる", - "effect": "攻撃を 受けても HPを 必ず 1だけ 残せる。 連続で だすと 失敗しやすい。" - }, - "charm": { - "name": "あまえる", - "effect": "かわいく みつめて 油断を 誘い 相手の 攻撃を がくっと さげる。" - }, - "rollout": { - "name": "ころがる", - "effect": "5ターンの 間 転がり続けて 攻撃する。 技が 当たるたびに 威力が あがる。" - }, - "falseSwipe": { - "name": "みねうち", - "effect": "相手の HPが 必ず 1だけ 残るように 手加減して 攻撃する。" - }, - "swagger": { - "name": "いばる", - "effect": "相手を 怒らせて 混乱させる。 怒りで 相手の 攻撃は ぐーんと あがってしまう。" - }, - "milkDrink": { - "name": "ミルクのみ", - "effect": "最大HPの 半分 自分の HPを 回復する。" - }, - "spark": { - "name": "スパーク", - "effect": "電気を まとい 相手に 突進して 攻撃する。 まひ状態に することが ある。" - }, - "furyCutter": { - "name": "れんぞくぎり", - "effect": "カマや ツメなどで 相手を 切りつけて 攻撃する。 連続で 当てると 威力が あがる。" - }, - "steelWing": { - "name": "はがねのつばさ", - "effect": "硬い 翼を 相手に たたきつけて 攻撃する。 自分の 防御が あがることが ある。" - }, - "meanLook": { - "name": "くろいまなざし", - "effect": "吸いこまれるような 黒い まなざしで じっと みつめて 相手を 戦闘から 逃げられなくする。" - }, - "attract": { - "name": "メロメロ", - "effect": "♂なら♀を ♀なら♂を 誘惑して メロメロに する。 相手は 技が だしにくくなる。" - }, - "sleepTalk": { - "name": "ねごと", - "effect": "自分が おぼえている 技の うち どれか 1つを くりだす。 自分が 寝ているときだけ 使える。" - }, - "healBell": { - "name": "いやしのすず", - "effect": "心地好い 鈴の 音色を 聞かせて 味方 全員の 状態異常を 回復 する。" - }, - "return": { - "name": "おんがえし", - "effect": "トレーナーの ために 全力で 相手を 攻撃する。 なついているほど 威力は あがる。" - }, - "present": { - "name": "プレゼント", - "effect": "わなを しかけた 箱を 相手に わたして 攻撃する。HPが 回復して しまうことも ある。" - }, - "frustration": { - "name": "やつあたり", - "effect": "不満を はらすため 全力で 相手を 攻撃する。 なついていないほど 威力は あがる。" - }, - "safeguard": { - "name": "しんぴのまもり", - "effect": "5ターンの 間 不思議な 力に 守られて 状態異常に ならなくなる。" - }, - "painSplit": { - "name": "いたみわけ", - "effect": "自分の HPと 相手の HPを あわせて それを 自分と 相手で なかよく わける。" - }, - "sacredFire": { - "name": "せいなるほのお", - "effect": "神秘の 炎で 相手を 焼きつくして 攻撃する。 やけど状態に することが ある。" - }, - "magnitude": { - "name": "マグニチュード", - "effect": "地面を 揺らして 自分の 周りに いるものを 攻撃する。 技の 威力は いろいろ 変わる。" - }, - "dynamicPunch": { - "name": "ばくれつパンチ", - "effect": "こん身の 力で パンチを くりだして 攻撃する。 相手を 必ず 混乱させる。" - }, - "megahorn": { - "name": "メガホーン", - "effect": "硬くて りっぱな つので おもいっきり 相手を 突き刺して 攻撃する。" - }, - "dragonBreath": { - "name": "りゅうのいぶき", - "effect": "ものすごい 息を 相手に 吹きつけて 攻撃する。 まひ状態に することが ある。" - }, - "batonPass": { - "name": "バトンタッチ", - "effect": "控えの ポケモンと 入れ替わる。 能力変化は 替わった ポケモンが そのまま 受けつぐ。" - }, - "encore": { - "name": "アンコール", - "effect": "相手に アンコールした 技を 3回 続けて 出させる。" - }, - "pursuit": { - "name": "おいうち", - "effect": "相手 ポケモンが 入れ替わるときに 技を だしていると 倍の 威力で 攻撃できる。" - }, - "rapidSpin": { - "name": "こうそくスピン", - "effect": "回転して 相手を 攻撃する。 しめつける まきつく やどりぎのタネ など 吹きとばす。自分の 素早さも あがる。" - }, - "sweetScent": { - "name": "あまいかおり", - "effect": "香りで 相手の 回避率を がくっと さげる。" - }, - "ironTail": { - "name": "アイアンテール", - "effect": "硬い しっぽで 相手を たたきつけて 攻撃する。 相手の 防御を さげることが ある。" - }, - "metalClaw": { - "name": "メタルクロー", - "effect": "鋼鉄の ツメで 相手を 切り裂いて 攻撃する。 自分の 攻撃が あがることが ある。" - }, - "vitalThrow": { - "name": "あてみなげ", - "effect": "相手より あとに 攻撃する。 そのかわり 自分の 攻撃は 必ず 命中する。" - }, - "morningSun": { - "name": "あさのひざし", - "effect": "自分の HPを 回復する。 天気に よって 回復の 量が 変化する。" - }, - "synthesis": { - "name": "こうごうせい", - "effect": "自分の HPを 回復する。 天気に よって 回復の 量が 変化する。" - }, - "moonlight": { - "name": "つきのひかり", - "effect": "自分の HPを 回復する。 天気に よって 回復の 量が 変化する。" - }, - "hiddenPower": { - "name": "めざめるパワー", - "effect": "技を 使った ポケモンに よって 技の タイプが 変わる。" - }, - "crossChop": { - "name": "クロスチョップ", - "effect": "両手チョップを 相手に たたきつけて 攻撃する。 急所に 当たりやすい。" - }, - "twister": { - "name": "たつまき", - "effect": "竜巻を おこして 相手を まきこみ 攻撃する。 相手を ひるませることが ある。" - }, - "rainDance": { - "name": "あまごい", - "effect": "5ターンの 間 雨を 降らせて みずタイプの 威力を あげる。 ほのおタイプの 威力は さがる。" - }, - "sunnyDay": { - "name": "にほんばれ", - "effect": "5ターンの 間 日差しを 強くして ほのおタイプの 威力を あげる。 みずタイプの 威力は さがる。" - }, - "crunch": { - "name": "かみくだく", - "effect": "鋭い 歯で 相手を かみくだいて 攻撃する。 相手の 防御を さげることが ある。" - }, - "mirrorCoat": { - "name": "ミラーコート", - "effect": "相手から 受けた 特殊攻撃の ダメージを 2倍に して その相手に 返す。" - }, - "psychUp": { - "name": "じこあんじ", - "effect": "自分に 暗示を かけることで 能力変化の 状態を 相手と 同じにする。" - }, - "extremeSpeed": { - "name": "しんそく", - "effect": "目にも 留まらぬ ものすごい 速さで 相手に 突進して 攻撃する。 必ず 先制攻撃 できる。" - }, - "ancientPower": { - "name": "げんしのちから", - "effect": "原始の 力で 攻撃する。 自分の すべての 能力が あがることが ある。" - }, - "shadowBall": { - "name": "シャドーボール", - "effect": "黒い影の 塊を 投げつけて 攻撃する。 相手の 特防を さげることが ある。" - }, - "futureSight": { - "name": "みらいよち", - "effect": "技を 使った 2ターン後に 相手に 念力の 塊を 送って 攻撃する。" - }, - "rockSmash": { - "name": "いわくだき", - "effect": "パンチで 攻撃する。相手の 防御を さげる ことが ある。" - }, - "whirlpool": { - "name": "うずしお", - "effect": "激しく 渦をまく 水の中に 4ー5ターンの 間 相手を 閉じこめて 攻撃する。" - }, - "beatUp": { - "name": "ふくろだたき", - "effect": "味方 全員で 攻撃する。 仲間の ポケモンが 多いほど 技の 攻撃回数が 増える。" - }, - "fakeOut": { - "name": "ねこだまし", - "effect": "先制攻撃で 相手を ひるませる。 戦闘に でたら すぐに ださないと 成功しない。" - }, - "uproar": { - "name": "さわぐ", - "effect": "3ターンの 間 騒いで 相手を 攻撃する。 そのあいだは だれも 眠れなくなる。" - }, - "stockpile": { - "name": "たくわえる", - "effect": "力を 蓄えて 自分の 防御と 特防を あげる。 最大 3回まで 蓄えられる。" - }, - "spitUp": { - "name": "はきだす", - "effect": "蓄えた 力を 相手に ぶつけて 攻撃する。 蓄えているほど 威力が あがる。" - }, - "swallow": { - "name": "のみこむ", - "effect": "蓄えた 力を のみこんで 自分の HPを 回復する。 蓄えているほど 回復する。" - }, - "heatWave": { - "name": "ねっぷう", - "effect": "熱い 息を 相手に 吹きつけて 攻撃する。 やけど状態に することが ある。" - }, - "hail": { - "name": "あられ", - "effect": "5ターンの 間 あられを 降らして こおりタイプで ない ポケモン 全員に ダメージを 与える。" - }, - "torment": { - "name": "いちゃもん", - "effect": "相手に いちゃもんを つけて 同じ 技を 2回連続で だせなくする。" - }, - "flatter": { - "name": "おだてる", - "effect": "相手を おだてて 混乱させる。 同時に 相手の 特攻も あげてしまう。" - }, - "willOWisp": { - "name": "おにび", - "effect": "不気味で 怪しい 炎を 放って 相手を やけどの 状態に する。" - }, - "memento": { - "name": "おきみやげ", - "effect": "自分は ひんしに なるが そのかわりに 相手の 攻撃と 特攻を がくっと さげる。" - }, - "facade": { - "name": "からげんき", - "effect": "自分が 毒 まひ やけど 状態のとき 相手に くりだすと 技の 威力が 2倍に なる。" - }, - "focusPunch": { - "name": "きあいパンチ", - "effect": "精神を 高めて パンチを くりだす。 技を だすまでに 攻撃を 受けると 失敗する。" - }, - "smellingSalts": { - "name": "きつけ", - "effect": "まひ状態の 相手には 威力が 2倍に なるが かわりに 相手の まひが 治る。" - }, - "followMe": { - "name": "このゆびとまれ", - "effect": "自分に 注目させて 相手からの 攻撃を すべて 自分に むけさせる。" - }, - "naturePower": { - "name": "しぜんのちから", - "effect": "自然の 力で 攻撃する。 使う 場所で でてくる 技が 変化する。" - }, - "charge": { - "name": "じゅうでん", - "effect": "次の ターンに だす でんきタイプの 技の 威力を あげる。 自分の 特防も あがる。" - }, - "taunt": { - "name": "ちょうはつ", - "effect": "相手を 怒らせる。 3ターンの 間 相手は ダメージを 与える 技しか だせなくなる。" - }, - "helpingHand": { - "name": "てだすけ", - "effect": "仲間を 助ける。 てだすけ された ポケモンの 技の 威力は いつもより 大きくなる。" - }, - "trick": { - "name": "トリック", - "effect": "相手の すきを ついて 自分と 相手の 持ち物を 交換する。" - }, - "rolePlay": { - "name": "なりきり", - "effect": "相手に なりきって 自分も 相手と 同じ 特性に 変化する。" - }, - "wish": { - "name": "ねがいごと", - "effect": "次の ターンに 自分 もしくは 入れ替わった ポケモンの HPを 最大HPの 半分 回復する。" - }, - "assist": { - "name": "ねこのて", - "effect": "大急ぎで 味方の 助けを かりて 味方の ポケモンが おぼえている 技を どれか 1つ 使う。" - }, - "ingrain": { - "name": "ねをはる", - "effect": "大地に 根を 張り 毎ターン 自分の HPを 回復する。 根を 張っているので 入れ替えられない。" - }, - "superpower": { - "name": "ばかぢから", - "effect": "すごい 力を 発揮して 相手を 攻撃する。自分の 攻撃と 防御が さがる。" - }, - "magicCoat": { - "name": "マジックコート", - "effect": "状態異常に なる 技や やどりぎのタネ などを だされたとき 相手に 跳ね返す。" - }, - "recycle": { - "name": "リサイクル", - "effect": "戦闘中に 使って なくなった 自分の 持ち物を 再生させて 使えるように する。" - }, - "revenge": { - "name": "リベンジ", - "effect": "相手から 技を 受けていると その相手に 対して 与える ダメージが 2倍に なる。" - }, - "brickBreak": { - "name": "かわらわり", - "effect": "手刀を 勢いよく 振りおろして 相手を 攻撃する。 ひかりのかべや リフレクター なども 破壊できる。" - }, - "yawn": { - "name": "あくび", - "effect": "大きな あくびで 眠気を 誘う。 次の ターンに 相手を 眠り状態に する。" - }, - "knockOff": { - "name": "はたきおとす", - "effect": "相手の 持ち物を はたき 落として 戦闘が 終わるまで 使えなくする。 物を持つ 相手には ダメージが増す。" - }, - "endeavor": { - "name": "がむしゃら", - "effect": "相手の HPが 自分の HPと 同じくらいに なるように ダメージを 与える。" - }, - "eruption": { - "name": "ふんか", - "effect": "怒りを 爆発させて 相手を 攻撃する。 自分の HPが 少ないほど 技の 威力は さがる。" - }, - "skillSwap": { - "name": "スキルスワップ", - "effect": "超能力で 自分の 特性と 相手の 特性を 入れ替える。" - }, - "imprison": { - "name": "ふういん", - "effect": "相手が 自分と 同じ 技を おぼえていたら 相手だけ その技を 使えなくする。" - }, - "refresh": { - "name": "リフレッシュ", - "effect": "体を やすめて 自分が おっている 毒 まひ やけどの 状態異常を 治す。" - }, - "grudge": { - "name": "おんねん", - "effect": "相手の 技で ひんしに されたとき おんねんを かけて その技の PPを 0に する。" - }, - "snatch": { - "name": "よこどり", - "effect": "相手が 使おうと した 回復技や 能力変化の 技を うばって 自分に 使う。" - }, - "secretPower": { - "name": "ひみつのちから", - "effect": "使う場所で 追加効果が 変化する 攻撃。" - }, - "dive": { - "name": "ダイビング", - "effect": "1ターン目で 潜り 2ターン目に 浮きあがって 攻撃する。" - }, - "armThrust": { - "name": "つっぱり", - "effect": "ひらいた 両手で 相手を つっぱって 攻撃する。 2ー5回の 間 連続で だす。" - }, - "camouflage": { - "name": "ほごしょく", - "effect": "水辺や 草むら どうくつなど いる 場所に あわせて 自分の タイプを 変える。" - }, - "tailGlow": { - "name": "ほたるび", - "effect": "点滅する 光を 眺めて 自分の 精神を 統一し 特攻を ぐぐーんと あげる。" - }, - "lusterPurge": { - "name": "ラスターパージ", - "effect": "まばゆい 光を 解放して 攻撃する。 相手の 特防を さげることが ある。" - }, - "mistBall": { - "name": "ミストボール", - "effect": "霧状の 羽毛で 包みこみ 攻撃する。 相手の 特攻を さげることが ある。" - }, - "featherDance": { - "name": "フェザーダンス", - "effect": "羽毛を ふりまいて 相手の 体に からませる。 相手の 攻撃を がくっと さげる。" - }, - "teeterDance": { - "name": "フラフラダンス", - "effect": "フラフラと ダンスを おどって 自分の 周りに いるものを 混乱状態に させる。" - }, - "blazeKick": { - "name": "ブレイズキック", - "effect": "攻撃した 相手を やけど状態に することが ある。 急所にも 当たりやすい。" - }, - "mudSport": { - "name": "どろあそび", - "effect": "あたりを 泥まみれにする。 5ターンの 間 でんきタイプの 技を 弱める。" - }, - "iceBall": { - "name": "アイスボール", - "effect": "5ターンの 間 相手を 攻撃する。 技が 当たるたび 威力が あがる。" - }, - "needleArm": { - "name": "ニードルアーム", - "effect": "トゲの 腕を 激しく ふるって 攻撃する。 相手を ひるませることが ある。" - }, - "slackOff": { - "name": "なまける", - "effect": "怠けて やすむ。 自分の HPを 最大HPの 半分 回復する。" - }, - "hyperVoice": { - "name": "ハイパーボイス", - "effect": "うるさく 響く 大きな 振動を 相手に 与えて 攻撃する。" - }, - "poisonFang": { - "name": "どくどくのキバ", - "effect": "毒の ある キバで 相手に かみついて 攻撃する。 猛毒を おわせる ことが ある。" - }, - "crushClaw": { - "name": "ブレイククロー", - "effect": "硬く 鋭い ツメで 切り裂いて 攻撃する。 相手の 防御を さげることが ある。" - }, - "blastBurn": { - "name": "ブラストバーン", - "effect": "爆発の 炎で 相手を 焼きつくして 攻撃する。 次の ターンは 動けなくなる。" - }, - "hydroCannon": { - "name": "ハイドロカノン", - "effect": "水の 大砲を 相手に 発射して 攻撃する。 次の ターンは 動けなくなる。" - }, - "meteorMash": { - "name": "コメットパンチ", - "effect": "すい星の ごとく パンチを くりだして 相手を 攻撃する。 自分の 攻撃が あがることが ある。" - }, - "astonish": { - "name": "おどろかす", - "effect": "大きな 声などで 不意に 驚かして 攻撃する。 相手を ひるませることが ある。" - }, - "weatherBall": { - "name": "ウェザーボール", - "effect": "使ったときの 天気に よって 技の タイプと 威力が 変わる。" - }, - "aromatherapy": { - "name": "アロマセラピー", - "effect": "心地好い やすらぐ 香りを かがせて 味方全員の 状態異常を 回復する。" - }, - "fakeTears": { - "name": "うそなき", - "effect": "ないた ふりをして 涙を 流す。 こまらせる ことで 相手の 特防を がくっと さげる。" - }, - "airCutter": { - "name": "エアカッター", - "effect": "鋭い 風で 相手を 切りつけて 攻撃する。 急所に 当たりやすい。" - }, - "overheat": { - "name": "オーバーヒート", - "effect": "フルパワーで 相手を 攻撃する。 使うと 反動で 自分の 特攻が がくっと さがる。" - }, - "odorSleuth": { - "name": "かぎわける", - "effect": "ゴーストタイプに 効果がない 技や 回避率の 高い 相手に 攻撃が 当たるように なる。" - }, - "rockTomb": { - "name": "がんせきふうじ", - "effect": "岩石を 投げつけて 攻撃する。 相手の 動きを 封じることで 素早さを さげる。" - }, - "silverWind": { - "name": "ぎんいろのかぜ", - "effect": "風に りんぷんを のせて 相手を 攻撃する。自分の すべての 能力が あがることが ある。" - }, - "metalSound": { - "name": "きんぞくおん", - "effect": "金属を こすって でるような いやな 音を 聞かせる。 相手の 特防を がくっと さげる。" - }, - "grassWhistle": { - "name": "くさぶえ", - "effect": "心地好い 笛の 音色を 聞かせて 相手を 眠りの 状態に する。" - }, - "tickle": { - "name": "くすぐる", - "effect": "体を くすぐり 笑わせる ことで 相手の 攻撃と 防御を さげる。" - }, - "cosmicPower": { - "name": "コスモパワー", - "effect": "宇宙から 神秘の 力を とりこむ ことで 自分の 防御と 特防を あげる。" - }, - "waterSpout": { - "name": "しおふき", - "effect": "潮を 吹きつけて 攻撃する。 自分の HPが 少ないほど 技の 威力は さがる。" - }, - "signalBeam": { - "name": "シグナルビーム", - "effect": "不思議な 光を 発射して 攻撃する。 相手を 混乱させることが ある。" - }, - "shadowPunch": { - "name": "シャドーパンチ", - "effect": "影に まぎれて パンチを くりだす。 攻撃は 必ず 命中する。" - }, - "extrasensory": { - "name": "じんつうりき", - "effect": "みえない 不思議な 力を 送って 攻撃する。 相手を ひるませることが ある。" - }, - "skyUppercut": { - "name": "スカイアッパー", - "effect": "空に むかうような 高い アッパーで 相手を 突きあげて 攻撃する。" - }, - "sandTomb": { - "name": "すなじごく", - "effect": "激しく 吹きあれる 砂あらしの 中に 4ー5ターンの 間 相手を 閉じこめて 攻撃する。" - }, - "sheerCold": { - "name": "ぜったいれいど", - "effect": "相手を 一撃で 瀕死に する。 こおりタイプ 以外の ポケモンが 使うと 当たりにくい。" - }, - "muddyWater": { - "name": "だくりゅう", - "effect": "濁った 水を 相手に 発射して 攻撃する。 命中率を さげることが ある。" - }, - "bulletSeed": { - "name": "タネマシンガン", - "effect": "タネを 勢いよく 相手に 発射して 攻撃する。 2ー5回の 間 連続で だす。" - }, - "aerialAce": { - "name": "つばめがえし", - "effect": "素早い 動きで 相手を ほんろうして 切りつける。 攻撃は 必ず 命中する。" - }, - "icicleSpear": { - "name": "つららばり", - "effect": "鋭い 氷柱を 相手に 発射して 攻撃する。 2ー5回の 間 連続で だす。" - }, - "ironDefense": { - "name": "てっぺき", - "effect": "皮膚を 鉄のように 硬くする ことで 自分の 防御を ぐーんと あげる。" - }, - "block": { - "name": "とおせんぼう", - "effect": "両手を ひろげて たちはだかり 相手の 逃げ道を ふさいで 逃げられなくする。" - }, - "howl": { - "name": "とおぼえ", - "effect": "大声で ほえて 気合を 高め 自分と 味方の 攻撃を あげる。" - }, - "dragonClaw": { - "name": "ドラゴンクロー", - "effect": "鋭く とがった 巨大な ツメで 相手を 切り裂いて 攻撃する。" - }, - "frenzyPlant": { - "name": "ハードプラント", - "effect": "大きな 樹木で 相手を たたきつけて 攻撃する。 次の ターンは 動けなくなる。" - }, - "bulkUp": { - "name": "ビルドアップ", - "effect": "体に 力を こめて 筋肉を ぶあつく することで 自分の 攻撃と 防御を あげる。" - }, - "bounce": { - "name": "とびはねる", - "effect": "空高く 飛び跳ねて 2ターン目に 相手を 攻撃する。 まひ状態に することが ある。" - }, - "mudShot": { - "name": "マッドショット", - "effect": "泥の 塊を 相手に 投げつけて 攻撃する。 同時に 相手の 素早さを さげる。" - }, - "poisonTail": { - "name": "ポイズンテール", - "effect": "しっぽで たたく。 毒状態に することが あり 急所にも 当たりやすい。" - }, - "covet": { - "name": "ほしがる", - "effect": "かわいく あまえながら 相手に ちかづき 持っている 道具を うばおうとする。 うばう 可能性は 30%。" - }, - "voltTackle": { - "name": "ボルテッカー", - "effect": "電気を まとって 突進する。 自分も かなり ダメージを 受ける。 まひ状態に することが ある。" - }, - "magicalLeaf": { - "name": "マジカルリーフ", - "effect": "相手を 追跡する 不思議な はっぱを まきちらす。 攻撃は 必ず 命中する。" - }, - "waterSport": { - "name": "みずあそび", - "effect": "あたりを 水で びしょびしょにする。 5ターンの 間 ほのおタイプの 技を 弱める。" - }, - "calmMind": { - "name": "めいそう", - "effect": "静かに 精神を 統一し 心を 鎮めることで 自分の 特攻と 特防を あげる。" - }, - "leafBlade": { - "name": "リーフブレード", - "effect": "はっぱを 剣のように あやつり 相手を 切りつけて 攻撃する。 急所に 当たりやすい。" - }, - "dragonDance": { - "name": "りゅうのまい", - "effect": "神秘的で 力強い 舞を 激しく おどる。 自分の 攻撃と 素早さを あげる。" - }, - "rockBlast": { - "name": "ロックブラスト", - "effect": "硬い 岩石を 相手に 発射して 攻撃する。 2ー5回の 間 連続で だす。" - }, - "shockWave": { - "name": "でんげきは", - "effect": "電撃を 素早く 相手に 浴びせる。 攻撃は 必ず 命中する。" - }, - "waterPulse": { - "name": "みずのはどう", - "effect": "水の 振動を 相手に 与えて 攻撃する。 相手を 混乱させることが ある。" - }, - "doomDesire": { - "name": "はめつのねがい", - "effect": "技を 使った 2ターン後に 無数の 光の 束で 相手を 攻撃する。" - }, - "psychoBoost": { - "name": "サイコブースト", - "effect": "フルパワーで 相手を 攻撃する。 使うと 反動で 自分の 特攻が がくっと さがる。" - }, - "roost": { - "name": "はねやすめ", - "effect": "地面に 降りて 体を やすめる。 最大HPの 半分の HPを 回復する。" - }, - "gravity": { - "name": "じゅうりょく", - "effect": "5ターンの間 ふゆうや ひこうタイプに じめんタイプの 技が 当たるようになる。 空中に 飛ぶ 技も 使えない。" - }, - "miracleEye": { - "name": "ミラクルアイ", - "effect": "あくタイプに 効果がない 技や 回避率の 高い 相手に 攻撃が 当たるように なる。" - }, - "wakeUpSlap": { - "name": "めざましビンタ", - "effect": "眠り状態の 相手に 大きな ダメージを 与える。 かわりに 相手は 眠りから さめる。" - }, - "hammerArm": { - "name": "アームハンマー", - "effect": "強くて 重い こぶしを ふるって ダメージを 与える。 自分の 素早さが さがる。" - }, - "gyroBall": { - "name": "ジャイロボール", - "effect": "体を 高速に 回転させて 体当たりする。相手より 素早さが 低いほど 強い。" - }, - "healingWish": { - "name": "いやしのねがい", - "effect": "自分は ひんしに なるが 控えから でてくる ポケモンの 状態異常と HPを 回復する。" - }, - "brine": { - "name": "しおみず", - "effect": "相手が HPの 半分くらい きずを おっていると 技の 威力が 2倍に なる。" - }, - "naturalGift": { - "name": "しぜんのめぐみ", - "effect": "きのみから 力を もらい 攻撃する。持たせた きのみで 技の タイプと 威力が 変わる。" - }, - "feint": { - "name": "フェイント", - "effect": "まもるや みきり などを している 相手に 攻撃が できる。 守りの 効果を 解除させる。" - }, - "pluck": { - "name": "ついばむ", - "effect": "くちばしで 攻撃。 相手が きのみを 持っているとき 食べて きのみの 効果を 受けられる。" - }, - "tailwind": { - "name": "おいかぜ", - "effect": "激しく 吹きあれる 風の渦を つくり 4ターンの 間 味方 全員の 素早さを あげる。" - }, - "acupressure": { - "name": "つぼをつく", - "effect": "つぼおしで 体を 活性化させる。 能力の どれか 1つを ぐーんと あげる。" - }, - "metalBurst": { - "name": "メタルバースト", - "effect": "技を だす前に 最後に 受けた 技の ダメージを 大きくして だした 相手に 返す。" - }, - "uTurn": { - "name": "とんぼがえり", - "effect": "攻撃したあと ものすごい スピードで もどってきて 控えの ポケモンと 入れ替わる。" - }, - "closeCombat": { - "name": "インファイト", - "effect": "守りを 捨てて 相手の ふところに 突撃する。 自分の 防御と 特防が さがる。" - }, - "payback": { - "name": "しっぺがえし", - "effect": "ためこんで 攻撃する。 相手より あとに 攻撃できると 技の 威力は 2倍に なる。" - }, - "assurance": { - "name": "ダメおし", - "effect": "そのターンに 相手が すでに ダメージを 受けていたら 技の 威力は 2倍に なる。" - }, - "embargo": { - "name": "さしおさえ", - "effect": "持たせた 道具を 5ターンの 間 使えなくする。 トレーナーも その ポケモンには 道具を 使えない。" - }, - "fling": { - "name": "なげつける", - "effect": "持たせた 道具を 素早く 投げつけて 攻撃する。 道具で 威力と 効果が 変わる。" - }, - "psychoShift": { - "name": "サイコシフト", - "effect": "超能力で 暗示を かけて 自分の 受けている 状態異常を 相手に うつす。" - }, - "trumpCard": { - "name": "きりふだ", - "effect": "きりふだの 残り PPが 少なければ 少ないほど 技の 威力が あがる。" - }, - "healBlock": { - "name": "かいふくふうじ", - "effect": "5ターンの 間 技や 特性や 持っている 道具によって HPを 回復 できなくする。" - }, - "wringOut": { - "name": "しぼりとる", - "effect": "強く 締めあげて 攻撃を する。 相手の HPが 残っているほど 威力は あがる。" - }, - "powerTrick": { - "name": "パワートリック", - "effect": "超能力で 自分の 攻撃と 防御の 力を 交換する。" - }, - "gastroAcid": { - "name": "いえき", - "effect": "胃液を 相手の 体に 吐きつける。 ついた 胃液は 相手の 特性の 効果を 消す。" - }, - "luckyChant": { - "name": "おまじない", - "effect": "天に むかって おいのりを ささげ 5ターンの 間 相手の 攻撃を 急所に 当たらなくする。" - }, - "meFirst": { - "name": "さきどり", - "effect": "威力を あげて 相手が だそうとする 技を 先にだす。 先に だせないと 失敗する。" - }, - "copycat": { - "name": "まねっこ", - "effect": "直前に でた 技を まねして 同じ 技を だす。 技が でていないと 失敗する。" - }, - "powerSwap": { - "name": "パワースワップ", - "effect": "超能力で 自分と 相手の 攻撃と 特攻の 能力変化を 入れ替える。" - }, - "guardSwap": { - "name": "ガードスワップ", - "effect": "超能力で 自分と 相手の 防御と 特防の 能力変化を 入れ替える。" - }, - "punishment": { - "name": "おしおき", - "effect": "能力変化で 相手が パワーアップ しているほど 技の 威力が あがる。" - }, - "lastResort": { - "name": "とっておき", - "effect": "戦闘中に おぼえている 技を すべて 使うと はじめて だせる とっておきの 技。" - }, - "worrySeed": { - "name": "なやみのタネ", - "effect": "心を なやませる タネを 植えつける。 相手を 眠れなくして 特性を ふみんに する。" - }, - "suckerPunch": { - "name": "ふいうち", - "effect": "相手より 先に 攻撃 できる。 相手が だす技が 攻撃技でないと 失敗する。" - }, - "toxicSpikes": { - "name": "どくびし", - "effect": "相手の 足下に どくびしを しかける。 交代で でてきた 相手の ポケモンに 毒を おわせる。" - }, - "heartSwap": { - "name": "ハートスワップ", - "effect": "超能力で 自分と 相手に かかっている 能力変化を 入れ替える。" - }, - "aquaRing": { - "name": "アクアリング", - "effect": "自分の 体の 周りを 水で つくった ベールで おおう。 毎ターン HPを 回復する。" - }, - "magnetRise": { - "name": "でんじふゆう", - "effect": "電気で つくった 磁力の 力で 宙に 浮かぶ。 5ターンの 間 浮遊できる。" - }, - "flareBlitz": { - "name": "フレアドライブ", - "effect": "炎を まとって 突進する。 自分も かなり ダメージを 受ける。 やけど状態に することが ある。" - }, - "forcePalm": { - "name": "はっけい", - "effect": "相手の 体に 衝撃波を 当てて 攻撃する。 まひ状態に することが ある。" - }, - "auraSphere": { - "name": "はどうだん", - "effect": "体の 奥から 波導の 力を 相手に うち放つ。 攻撃は 必ず 命中する。" - }, - "rockPolish": { - "name": "ロックカット", - "effect": "自分の 体を 磨いて 空気の 抵抗を 少なくする。素早さを ぐーんと あげることが できる。" - }, - "poisonJab": { - "name": "どくづき", - "effect": "毒に そまった 触手や 腕で 相手を 突き刺す。 毒状態に することが ある。" - }, - "darkPulse": { - "name": "あくのはどう", - "effect": "体から 悪意に みちた 恐ろしい オーラを 発する。 相手を ひるませることが ある。" - }, - "nightSlash": { - "name": "つじぎり", - "effect": "一瞬の すきを ついて 相手を 切りはらう。 急所に 当たりやすい。" - }, - "aquaTail": { - "name": "アクアテール", - "effect": "激しく あれくるう 荒波の ように 大きな しっぽを ふって 相手を 攻撃する。" - }, - "seedBomb": { - "name": "タネばくだん", - "effect": "硬い 殻を もつ 大きな タネを 上から たたきつけて 相手を 攻撃する。" - }, - "airSlash": { - "name": "エアスラッシュ", - "effect": "空をも 切り裂く 空気の 刃で 攻撃する。 相手を ひるませることが ある。" - }, - "xScissor": { - "name": "シザークロス", - "effect": "カマや ツメを ハサミのように 交差させながら 相手を 切り裂く。" - }, - "bugBuzz": { - "name": "むしのさざめき", - "effect": "振動で 音波を おこして 攻撃する。相手の 特防を さげることが ある。" - }, - "dragonPulse": { - "name": "りゅうのはどう", - "effect": "大きな 口から 衝撃波を まきおこして 相手を 攻撃する。" - }, - "dragonRush": { - "name": "ドラゴンダイブ", - "effect": "すさまじい 殺気で 威圧しながら 体当たりする。 相手を ひるませることが ある。" - }, - "powerGem": { - "name": "パワージェム", - "effect": "宝石のように きらめく 光を 発射して 相手を 攻撃する。" - }, - "drainPunch": { - "name": "ドレインパンチ", - "effect": "こぶしから 相手の 力を 吸い取る。 与えた ダメージの 半分の HPを 回復できる。" - }, - "vacuumWave": { - "name": "しんくうは", - "effect": "こぶしを ふって 真空の 波を まきおこす。 必ず 先制攻撃できる。" - }, - "focusBlast": { - "name": "きあいだま", - "effect": "気合を 高めて ありったけの 力を 放出する。 相手の 特防を さげることが ある。" - }, - "energyBall": { - "name": "エナジーボール", - "effect": "自然から 集めた 命の力を 発射する。 相手の 特防を さげることがある。" - }, - "braveBird": { - "name": "ブレイブバード", - "effect": "はねを おりたたみ 低空飛行で 突撃する。 自分も かなり ダメージを 受ける。" - }, - "earthPower": { - "name": "だいちのちから", - "effect": "相手の 足下へ 大地の力を 放出する。相手の 特防を さげることが ある。" - }, - "switcheroo": { - "name": "すりかえ", - "effect": "目にも とまらぬ 速さで 自分と 相手の 持ち物を 交換する。" - }, - "gigaImpact": { - "name": "ギガインパクト", - "effect": "持てる 力を すべて 使って 相手に 突撃する。 次の ターンは 動けなくなる。" - }, - "nastyPlot": { - "name": "わるだくみ", - "effect": "悪いことを 考えて 頭を 活性化させる。 自分の 特攻を ぐーんと あげる。" - }, - "bulletPunch": { - "name": "バレットパンチ", - "effect": "弾丸の ような 速くて 硬い パンチを 相手に くりだす。 必ず 先制攻撃 できる。" - }, - "avalanche": { - "name": "ゆきなだれ", - "effect": "相手から 技を 受けていると その 相手に 対して 技の 威力が 2倍に なる。" - }, - "iceShard": { - "name": "こおりのつぶて", - "effect": "氷の塊を 一瞬で つくり 相手に 素早く 放つ。 必ず 先制攻撃 できる。" - }, - "shadowClaw": { - "name": "シャドークロー", - "effect": "影から つくった 鋭い ツメで 相手を 切り裂く。 急所に 当たりやすい。" - }, - "thunderFang": { - "name": "かみなりのキバ", - "effect": "電気を ためた キバで かみつく。 相手を ひるませたり まひ状態に することが ある。" - }, - "iceFang": { - "name": "こおりのキバ", - "effect": "冷気を ひめた キバで かみつく。 相手を ひるませたり こおり状態に することが ある。" - }, - "fireFang": { - "name": "ほのおのキバ", - "effect": "炎を まとった キバで かみつく。 相手を ひるませたり やけど状態に することが ある。" - }, - "shadowSneak": { - "name": "かげうち", - "effect": "影を のばして 相手の 背後から 攻撃する。 必ず 先制攻撃 できる。" - }, - "mudBomb": { - "name": "どろばくだん", - "effect": "硬い 泥の 弾を 相手に 発射して 攻撃する。 命中率を さげることが ある。" - }, - "psychoCut": { - "name": "サイコカッター", - "effect": "実体化させた 心の 刃で 相手を 切り裂く。 急所に 当たりやすい。" - }, - "zenHeadbutt": { - "name": "しねんのずつき", - "effect": "思念の 力を 額に 集めて 攻撃する。 相手を ひるませることが ある。" - }, - "mirrorShot": { - "name": "ミラーショット", - "effect": "磨きあげられた 体から せん光の 力を 相手に 放つ。 命中率を さげることが ある。" - }, - "flashCannon": { - "name": "ラスターカノン", - "effect": "体の 光を 一点に 集めて 力を 放つ。 相手の 特防を さげることが ある。" - }, - "rockClimb": { - "name": "ロッククライム", - "effect": "すごい 勢いで 相手に つっこみ 攻撃する。 相手を 混乱させることが ある。" - }, - "defog": { - "name": "きりばらい", - "effect": "強い風で 相手の リフレクターや ひかりのかべ などを はらいのける。 回避率も さげる。" - }, - "trickRoom": { - "name": "トリックルーム", - "effect": "まか不思議な 空間を つくる。 5ターンの 間 遅い ポケモンから 行動できる。" - }, - "dracoMeteor": { - "name": "りゅうせいぐん", - "effect": "天空から 隕石を 相手に 落とす。使うと 反動で 自分の 特攻が がくっと さがる。" - }, - "discharge": { - "name": "ほうでん", - "effect": "まばゆい 電撃で 自分の 周りに いるものを 攻撃する。 まひ状態に することが ある。" - }, - "lavaPlume": { - "name": "ふんえん", - "effect": "真っ赤な 炎で 自分の 周りに いるものを 攻撃する。 やけど状態に することが ある。" - }, - "leafStorm": { - "name": "リーフストーム", - "effect": "とがった はっぱで 相手に あらしを おこす。使うと 反動で 自分の 特攻が がくっと さがる。" - }, - "powerWhip": { - "name": "パワーウィップ", - "effect": "ツタや 触手を 激しく ふるって 相手を たたきつけ 攻撃する。" - }, - "rockWrecker": { - "name": "がんせきほう", - "effect": "巨大な 岩を 相手に 発射して 攻撃する。 次の ターンは 動けなくなる。" - }, - "crossPoison": { - "name": "クロスポイズン", - "effect": "毒の 刃で 相手を 切り裂く。 毒状態に することが あり 急所にも 当たりやすい。" - }, - "gunkShot": { - "name": "ダストシュート", - "effect": "汚い ゴミを 相手に ぶつけて 攻撃する。 毒状態に することが ある。" - }, - "ironHead": { - "name": "アイアンヘッド", - "effect": "鋼の ような 硬い 頭で 攻撃する。 相手を ひるませることが ある。" - }, - "magnetBomb": { - "name": "マグネットボム", - "effect": "相手に 吸いつく 鋼の 爆弾を 発射する。 攻撃は 必ず 命中 する。" - }, - "stoneEdge": { - "name": "ストーンエッジ", - "effect": "とがった 岩を 相手に 突き刺して 攻撃する。 急所に 当たりやすい。" - }, - "captivate": { - "name": "ゆうわく", - "effect": "♂なら♀を ♀なら♂を 誘惑して 相手の 特攻を がくっと さげる。" - }, - "stealthRock": { - "name": "ステルスロック", - "effect": "相手の 周りに 無数の 岩を 浮かべて 交代で でてきた 相手の ポケモンに ダメージを 与える。" - }, - "grassKnot": { - "name": "くさむすび", - "effect": "草を からませて 相手を 転ばせる。相手が 重いほど 威力が あがる。" - }, - "chatter": { - "name": "おしゃべり", - "effect": "とても うるさい おしゃべりの 音波で 相手を 攻撃する。 相手を 混乱させる。" - }, - "judgment": { - "name": "さばきのつぶて", - "effect": "無数の 光弾を 相手に 放出する。 自分の 持つ プレートに より タイプが 変わる。" - }, - "bugBite": { - "name": "むしくい", - "effect": "かみついて 攻撃する。 相手が きのみを 持っているとき 食べて きのみの 効果を 受けられる。" - }, - "chargeBeam": { - "name": "チャージビーム", - "effect": "電撃の 束を 相手に 発射する。電気を ためて 自分の 特攻を あげることが ある。" - }, - "woodHammer": { - "name": "ウッドハンマー", - "effect": "硬い 胴体を 相手に たたきつけて 攻撃する。 自分も かなり ダメージを 受ける。" - }, - "aquaJet": { - "name": "アクアジェット", - "effect": "目にも 留まらぬ ものすごい 速さで 相手に つっこむ。 必ず 先制攻撃 できる。" - }, - "attackOrder": { - "name": "こうげきしれい", - "effect": "しもべを 呼びだして 相手に むかって 攻撃させる。 急所に 当たりやすい。" - }, - "defendOrder": { - "name": "ぼうぎょしれい", - "effect": "しもべを 呼びだして 自分の 体に おおい つかせる。防御と 特防を あげることが できる。" - }, - "healOrder": { - "name": "かいふくしれい", - "effect": "しもべを 呼びだして きずを 治す。 最大HPの 半分 自分の HPを 回復する。" - }, - "headSmash": { - "name": "もろはのずつき", - "effect": "命を 懸けて こん身の 力で 相手に ずつきを する。 自分も ものすごい ダメージを 受ける。" - }, - "doubleHit": { - "name": "ダブルアタック", - "effect": "しっぽなどを 使い 相手を たたいて 攻撃する。 2回連続で ダメージを 与える。" - }, - "roarOfTime": { - "name": "ときのほうこう", - "effect": "時間が ゆがむほどの 力を うちだして 相手を 攻撃する。 次の ターンは 動けなくなる。" - }, - "spacialRend": { - "name": "あくうせつだん", - "effect": "周りの 空間ごと 相手を 引き裂き ダメージを 与える。 急所に 当たりやすい。" - }, - "lunarDance": { - "name": "みかづきのまい", - "effect": "自分は ひんしに なるが 控えから でてくる ポケモンの すべての 状態を 回復する。" - }, - "crushGrip": { - "name": "にぎりつぶす", - "effect": "すさまじい 力で 相手を にぎりつぶす。 相手の HPが 残っているほど 威力が あがる。" - }, - "magmaStorm": { - "name": "マグマストーム", - "effect": "激しく 燃えたぎる 炎の なかに 4ー5ターンの 間 相手を 閉じこめて 攻撃する。" - }, - "darkVoid": { - "name": "ダークホール", - "effect": "暗黒の 世界に ひきずり 落として 相手を 眠り状態に する。" - }, - "seedFlare": { - "name": "シードフレア", - "effect": "体の 中から 衝撃波を 発生させる。相手の 特防を がくっと さげることが ある。" - }, - "ominousWind": { - "name": "あやしいかぜ", - "effect": "みのけも よだつ 突風で 相手を 攻撃する。自分の すべての 能力が あがることが ある。" - }, - "shadowForce": { - "name": "シャドーダイブ", - "effect": "1ターン目で 姿を 消して 2ターン目に 相手を 攻撃する。 守っていても 攻撃は 当たる。" - }, - "honeClaws": { - "name": "つめとぎ", - "effect": "ツメを 磨いて 鋭く する。 自分の 攻撃と 命中率を あげる。" - }, - "wideGuard": { - "name": "ワイドガード", - "effect": "味方全員に 当たる 攻撃を 1ターンの 間 防ぐ。" - }, - "guardSplit": { - "name": "ガードシェア", - "effect": "超能力で 自分と 相手の 防御と 特防を たして 半分に わける。" - }, - "powerSplit": { - "name": "パワーシェア", - "effect": "超能力で 自分と 相手の 攻撃と 特攻を たして 半分に わける。" - }, - "wonderRoom": { - "name": "ワンダールーム", - "effect": "まか不思議な 空間を つくる。 5ターンのあいだ すべてのポケモンの 防御と 特防が 入れ替わる。" - }, - "psyshock": { - "name": "サイコショック", - "effect": "不思議な 念波を 実体化して 相手を 攻撃する。 物理的な ダメージを 与える。" - }, - "venoshock": { - "name": "ベノムショック", - "effect": "特殊な 毒液を 浴びせかける。 毒状態の 相手には 威力が 2倍に なる。" - }, - "autotomize": { - "name": "ボディパージ", - "effect": "体の ムダな 部分を 削る。 自分の 素早さを ぐーんと あげて 体重も 軽くなる。" - }, - "ragePowder": { - "name": "いかりのこな", - "effect": "イライラさせる 粉を 自分に ふりかけて 注意を ひく。 相手の 攻撃を すべて 自分に むける。" - }, - "telekinesis": { - "name": "テレキネシス", - "effect": "超能力で 相手を 浮かせる。 3ターンの 間 攻撃が 相手に 当たりやすく なる。" - }, - "magicRoom": { - "name": "マジックルーム", - "effect": "まか不思議な 空間を つくる。 5ターンの間 すべてのポケモンの 道具の 効果が なくなる。" - }, - "smackDown": { - "name": "うちおとす", - "effect": "石や 弾を 投げて 飛んでいる 相手を 攻撃する。 相手は うち落とされて 地面に 落ちる。" - }, - "stormThrow": { - "name": "やまあらし", - "effect": "強烈な 一撃を 相手に くりだす。攻撃は 必ず 急所に 当たる。" - }, - "flameBurst": { - "name": "はじけるほのお", - "effect": "当たると はじける 炎で 相手を 攻撃する。はじけた 炎は 隣の 相手にも ふりかかる。" - }, - "sludgeWave": { - "name": "ヘドロウェーブ", - "effect": "ヘドロの 波で 自分の 周りに いるものを 攻撃する。 毒状態に することが ある。" - }, - "quiverDance": { - "name": "ちょうのまい", - "effect": "神秘的で 美しい 舞を 軽やかに おどる。 自分の 特攻と 特防と 素早さを あげる。" - }, - "heavySlam": { - "name": "ヘビーボンバー", - "effect": "重たい 体で 相手に ぶつかって 攻撃する。 自分が 相手より 重いほど 威力が あがる。" - }, - "synchronoise": { - "name": "シンクロノイズ", - "effect": "不思議な 電波で 周りに いる 自分と 同じ タイプの ポケモンに ダメージを 与える。" - }, - "electroBall": { - "name": "エレキボール", - "effect": "電気の 塊を 相手に ぶつける。相手より 素早さが 速いほど 威力が あがる。" - }, - "soak": { - "name": "みずびたし", - "effect": "たくさんの 水を 浴びせかけて 相手を みずタイプに する。" - }, - "flameCharge": { - "name": "ニトロチャージ", - "effect": "炎を まとい 相手を 攻撃する。 力を ためて 自分の 素早さを あげる。" - }, - "coil": { - "name": "とぐろをまく", - "effect": "とぐろを まいて 集中する。 自分の 攻撃と 防御と 命中率を あげる。" - }, - "lowSweep": { - "name": "ローキック", - "effect": "素早い 動きで 相手の 足を ねらって 攻撃する。 相手の 素早さを さげる。" - }, - "acidSpray": { - "name": "アシッドボム", - "effect": "相手を とかす 液体を 吐きだして 攻撃する。 相手の 特防を がくっと さげる。" - }, - "foulPlay": { - "name": "イカサマ", - "effect": "相手の 力を 利用する。 戦っている 相手の 攻撃が 高いほど ダメージが あがる。" - }, - "simpleBeam": { - "name": "シンプルビーム", - "effect": "なぞの 念波を 相手に 送る。 念波を 受けとった 相手は 特性が たんじゅんに なる。" - }, - "entrainment": { - "name": "なかまづくり", - "effect": "不思議な リズムで おどる。 動きを まねさせて 自分と 相手の 特性を 同じに する。" - }, - "afterYou": { - "name": "おさきにどうぞ", - "effect": "相手の 行動を サポートして 自分の 行動の あとに 続けて 動けるように する。" - }, - "round": { - "name": "りんしょう", - "effect": "歌で 相手を 攻撃する。 みんなで 輪唱すると 続けて だすことが でき 威力も あがる。" - }, - "echoedVoice": { - "name": "エコーボイス", - "effect": "響く 声で 相手を 攻撃する。 毎ターン だれかが 技を 使い続けると 威力が あがる。" - }, - "chipAway": { - "name": "なしくずし", - "effect": "すきを みて 堅実に 攻撃する。 相手の 能力変化に 関係なく ダメージを 与える。" - }, - "clearSmog": { - "name": "クリアスモッグ", - "effect": "特殊な 泥の 塊を 相手に 投げつけて 攻撃する。 能力変化を もとに もどす。" - }, - "storedPower": { - "name": "アシストパワー", - "effect": "蓄積された パワーで 相手を 攻撃する。自分の 能力が あがっているほど 威力が あがる。" - }, - "quickGuard": { - "name": "ファストガード", - "effect": "自分と 味方を 相手の 先制攻撃から 守る。" - }, - "allySwitch": { - "name": "サイドチェンジ", - "effect": "不思議な 力で テレポートして 自分と 味方の 居場所を 入れ替える。" - }, - "scald": { - "name": "ねっとう", - "effect": "熱く 煮えたぎる 水を 相手に 発射して 攻撃する。 やけど状態に することが ある。" - }, - "shellSmash": { - "name": "からをやぶる", - "effect": "殻を やぶって 自分の 防御 特防を さげるが 攻撃 特攻 素早さを ぐーんと あげる。" - }, - "healPulse": { - "name": "いやしのはどう", - "effect": "いやしのはどうを とばして 最大HPの 半分 相手の HPを 回復する。" - }, - "hex": { - "name": "たたりめ", - "effect": "たたみかける ように 攻撃する。 状態異常の 相手に 大きな ダメージを 与える。" - }, - "skyDrop": { - "name": "フリーフォール", - "effect": "1ターン目で 相手を 空へ 連れさり 2ターン目に 落として 攻撃する。 連れさられた 相手は 動けない。" - }, - "shiftGear": { - "name": "ギアチェンジ", - "effect": "歯車を 回して 自分の 攻撃を あげる だけでなく 素早さも ぐーんと あげる。" - }, - "circleThrow": { - "name": "ともえなげ", - "effect": "相手を 投げとばして 控えの ポケモンを ひきずりだす。 野生の 場合は 戦闘が 終わる。" - }, - "incinerate": { - "name": "やきつくす", - "effect": "炎で 相手を 攻撃する。 相手が きのみなどを 持っているとき 燃やして 使えなくする。" - }, - "quash": { - "name": "さきおくり", - "effect": "相手を おさえつけて 行動の 順番を 最後に する。" - }, - "acrobatics": { - "name": "アクロバット", - "effect": "軽やかに 相手を 攻撃する。 自分が 道具を 持っていないとき 大きな ダメージを 与える。" - }, - "reflectType": { - "name": "ミラータイプ", - "effect": "相手の タイプを 反射して 自分も 同じ タイプに なる。" - }, - "retaliate": { - "name": "かたきうち", - "effect": "倒れた 味方の かたきを 討つ。 前の ターンに 味方が 倒されていると 威力が あがる。" - }, - "finalGambit": { - "name": "いのちがけ", - "effect": "命懸けで 相手を 攻撃する。 自分は ひんしに なるが 相手に HP分の ダメージを 与える。" - }, - "bestow": { - "name": "ギフトパス", - "effect": "相手が 道具を 持っていないとき 自分が 持っている 道具を 相手に わたす。" - }, - "inferno": { - "name": "れんごく", - "effect": "激しい 炎で 相手を 包みこみ 攻撃する。 やけど状態に する。" - }, - "waterPledge": { - "name": "みずのちかい", - "effect": "水の柱で 攻撃する。 ほのおと 組みあわせると 威力が あがって 空に にじが かかる。" - }, - "firePledge": { - "name": "ほのおのちかい", - "effect": "炎の柱で 攻撃する。 くさと 組みあわせると 威力が あがって 周りが 火の海に なる。" - }, - "grassPledge": { - "name": "くさのちかい", - "effect": "草の柱で 攻撃する。 みずと 組みあわせると 威力が あがって あたりが 湿原に なる。" - }, - "voltSwitch": { - "name": "ボルトチェンジ", - "effect": "攻撃したあと ものすごい スピードで もどってきて 控えの ポケモンと 入れ替わる。" - }, - "struggleBug": { - "name": "むしのていこう", - "effect": "抵抗して 相手を 攻撃する。 相手の 特攻を さげる。" - }, - "bulldoze": { - "name": "じならし", - "effect": "地面を 踏みならして 自分の 周りに いるものを 攻撃する。 相手の 素早さを さげる。" - }, - "frostBreath": { - "name": "こおりのいぶき", - "effect": "冷たい 息を 相手に 吹きつけて 攻撃する。 必ず 急所に 当たる。" - }, - "dragonTail": { - "name": "ドラゴンテール", - "effect": "相手を はじきとばして 控えの ポケモンを ひきずりだす。 野生の 場合は 戦闘が 終わる。" - }, - "workUp": { - "name": "ふるいたてる", - "effect": "自分を 奮いたてて 攻撃と 特攻を あげる。" - }, - "electroweb": { - "name": "エレキネット", - "effect": "電気の ネットで 相手を 捕まえて 攻撃する。 相手の 素早さを さげる。" - }, - "wildCharge": { - "name": "ワイルドボルト", - "effect": "電気を まとって 相手に ぶつかって 攻撃する。 自分も 少し ダメージを 受ける。" - }, - "drillRun": { - "name": "ドリルライナー", - "effect": "ドリルのように 体を 回転しながら 相手に 体当たりする。 急所に 当たりやすい。" - }, - "dualChop": { - "name": "ダブルチョップ", - "effect": "体の 硬い部分で 相手を たたいて 攻撃する。 2回連続で ダメージを 与える。" - }, - "heartStamp": { - "name": "ハートスタンプ", - "effect": "かわいい しぐさで 油断させて 強烈な 一撃を 浴びせる。 相手を ひるませることが ある。" - }, - "hornLeech": { - "name": "ウッドホーン", - "effect": "つのを 突き刺して 相手の 養分を 吸い取る。 与えた ダメージの 半分の HPを 回復できる。" - }, - "sacredSword": { - "name": "せいなるつるぎ", - "effect": "長い つので 切りつけ 攻撃する。 相手の 能力変化に 関係なく ダメージを 与える。" - }, - "razorShell": { - "name": "シェルブレード", - "effect": "鋭い 貝殻で 切りつけて 攻撃する。 相手の 防御を さげることが ある。" - }, - "heatCrash": { - "name": "ヒートスタンプ", - "effect": "燃える 体で 相手に ぶつかって 攻撃する。 自分が 相手より 重いほど 威力が あがる。" - }, - "leafTornado": { - "name": "グラスミキサー", - "effect": "鋭い はっぱで 相手を 包みこんで 攻撃する。 命中率を さげることが ある。" - }, - "steamroller": { - "name": "ハードローラー", - "effect": "まるめた 体で 回転して 相手を おしつぶす。 相手を ひるませることが ある。" - }, - "cottonGuard": { - "name": "コットンガード", - "effect": "フワフワの 綿毛で 自分の 体を 包みこんで 守る。 防御を ぐぐーんと あげる。" - }, - "nightDaze": { - "name": "ナイトバースト", - "effect": "暗黒の 衝撃波を とばして 相手を 攻撃する。 命中率を さげることが ある。" - }, - "psystrike": { - "name": "サイコブレイク", - "effect": "不思議な 念波を 実体化して 相手を 攻撃する。 物理的な ダメージを 与える。" - }, - "tailSlap": { - "name": "スイープビンタ", - "effect": "硬い しっぽで 相手を たたいて 攻撃する。 2ー5回の 間 連続で だす。" - }, - "hurricane": { - "name": "ぼうふう", - "effect": "強烈な 風で 相手を 包みこんで 攻撃する。 相手を 混乱させることが ある。" - }, - "headCharge": { - "name": "アフロブレイク", - "effect": "すごい アフロの 頭で 相手に 突進して 攻撃する。 自分も 少し ダメージを 受ける。" - }, - "gearGrind": { - "name": "ギアソーサー", - "effect": "鋼鉄の ギアを 相手に 投げつけて 攻撃する。 2回連続で ダメージを 与える。" - }, - "searingShot": { - "name": "かえんだん", - "effect": "真っ赤な 炎で 自分の 周りに いるものを 攻撃する。 やけど状態に することが ある。" - }, - "technoBlast": { - "name": "テクノバスター", - "effect": "光弾を 相手に 放出する。 自分の 持つ カセットにより タイプが 変わる。" - }, - "relicSong": { - "name": "いにしえのうた", - "effect": "いにしえのうたを 相手に 聞かせて 心に うったえて 攻撃する。 眠り状態に することが ある。" - }, - "secretSword": { - "name": "しんぴのつるぎ", - "effect": "長い つので 切りつけ 攻撃する。 つのが まとった 不思議な 力は 物理的な ダメージを 与える。" - }, - "glaciate": { - "name": "こごえるせかい", - "effect": "凍えるような 冷気を 相手に 吹きつけて 攻撃する。 相手の 素早さを さげる。" - }, - "boltStrike": { - "name": "らいげき", - "effect": "ぼうだいな 電気を 身に まとって 相手に 突進して 攻撃する。 まひ状態に することが ある。" - }, - "blueFlare": { - "name": "あおいほのお", - "effect": "美しくも 激しい 青い炎で 相手を 包みこんで 攻撃する。 やけど状態に することが ある。" - }, - "fieryDance": { - "name": "ほのおのまい", - "effect": "炎を まとい はばたいて 相手を 攻撃する。自分の 特攻が あがることが ある。" - }, - "freezeShock": { - "name": "フリーズボルト", - "effect": "電気を まとった 氷の 塊で 2ターン目に 相手を たたきつける。 まひ状態に することが ある。" - }, - "iceBurn": { - "name": "コールドフレア", - "effect": "すべてを 凍らせる 激しい 冷気で 2ターン目に 相手を 包みこむ。 やけど状態に することが ある。" - }, - "snarl": { - "name": "バークアウト", - "effect": "まくしたてる ように 怒鳴りつけて 相手の 特攻を さげる。" - }, - "icicleCrash": { - "name": "つららおとし", - "effect": "大きな 氷柱を 激しく ぶつけて 攻撃する。 相手を ひるませることが ある。" - }, - "vCreate": { - "name": "Vジェネレート", - "effect": "灼熱の 炎を 額から 発生させて 捨て身の 体当たり。 防御 特防 素早さが さがる。" - }, - "fusionFlare": { - "name": "クロスフレイム", - "effect": "巨大な 炎を たたきつける。 巨大な 雷の 影響を受け 技の 威力が あがる。" - }, - "fusionBolt": { - "name": "クロスサンダー", - "effect": "巨大な 雷を たたきつける。 巨大な 炎の 影響を受け 技の 威力が あがる。" - }, - "flyingPress": { - "name": "フライングプレス", - "effect": "空中から 相手に ダイブする。 この技は かくとうタイプと 同時に ひこうタイプでも ある。" - }, - "matBlock": { - "name": "たたみがえし", - "effect": "かえした タタミを 盾にして 自分や 味方への 技の ダメージを 防ぐ。 変化技は 防ぐことが できない。" - }, - "belch": { - "name": "ゲップ", - "effect": "相手に 向かって ゲップを 浴びせて ダメージを 与える。 きのみを 食べないと だせない。" - }, - "rototiller": { - "name": "たがやす", - "effect": "地面を 耕して 草木が 育ちやすいようにする。 くさタイプの 攻撃と 特攻が あがる。" - }, - "stickyWeb": { - "name": "ねばねばネット", - "effect": "相手の 周りに ねばねばした ネットを はりめぐらせ 交代で でてきた 相手の 素早さを さげる。" - }, - "fellStinger": { - "name": "とどめばり", - "effect": "この 技を 使って 相手を 倒すと 攻撃が ぐぐーんと あがる。" - }, - "phantomForce": { - "name": "ゴーストダイブ", - "effect": "1ターンめで どこかに 消えて 2ターンめに 相手を 攻撃する。 守りを 無視して 攻撃できる。" - }, - "trickOrTreat": { - "name": "ハロウィン", - "effect": "相手を ハロウィンに 誘う。 相手の タイプに ゴーストタイプが 追加される。" - }, - "nobleRoar": { - "name": "おたけび", - "effect": "おたけびを あげて 相手を 威嚇し 相手の 攻撃と 特攻を さげる。" - }, - "ionDeluge": { - "name": "プラズマシャワー", - "effect": "電気を 帯びた 粒子を 拡散し ノーマルタイプの 技を でんきタイプに してしまう。" - }, - "parabolicCharge": { - "name": "パラボラチャージ", - "effect": "周りにいる ポケモン 全員に ダメージ。 与えた ダメージの 半分を 自分が 回復する。" - }, - "forestsCurse": { - "name": "もりののろい", - "effect": "相手に 森ののろいを かける。 のろいを かけられた 相手は タイプに くさタイプが 追加される。" - }, - "petalBlizzard": { - "name": "はなふぶき", - "effect": "激しい 花吹雪を 起こし 周りに いるものに 攻撃して ダメージを 与える。" - }, - "freezeDry": { - "name": "フリーズドライ", - "effect": "相手を 急激に 冷やして こおり 状態に することが ある。 みずタイプにも 効果バツグンになる。" - }, - "disarmingVoice": { - "name": "チャームボイス", - "effect": "魅惑の 鳴き声を だして 相手に 精神的な ダメージを 与える。 攻撃は 必ず 命中 する。" - }, - "partingShot": { - "name": "すてゼリフ", - "effect": "すてゼリフで 相手を いかくし 攻撃と 特攻を さげたのち 控えの ポケモンと 入れ替わる。" - }, - "topsyTurvy": { - "name": "ひっくりかえす", - "effect": "相手に かかっている すべての 能力変化を ひっくり返して 逆にする。" - }, - "drainingKiss": { - "name": "ドレインキッス", - "effect": "キッスによって 相手から HPを 吸い取る。 与えた ダメージの 半分以上 HPを 回復する。" - }, - "craftyShield": { - "name": "トリックガード", - "effect": "不思議な 力を 使って 味方への 変化技を 防ぐ。 ダメージ技は 受けてしまう。" - }, - "flowerShield": { - "name": "フラワーガード", - "effect": "不思議な 力を 使って 場にいる くさタイプの ポケモン 全員の 防御を あげる。" - }, - "grassyTerrain": { - "name": "グラスフィールド", - "effect": "5ターンの 間 グラスフィールドにする。 地面にいると 毎ターン 回復する。 くさタイプの 威力が あがる。" - }, - "mistyTerrain": { - "name": "ミストフィールド", - "effect": "5ターンの 間 地面にいると 状態異常に ならず ドラゴン技の ダメージも 半分になる。" - }, - "electrify": { - "name": "そうでん", - "effect": "相手が 技を だす前に そうでん すると そのターン 相手の 技は でんきタイプになる。" - }, - "playRough": { - "name": "じゃれつく", - "effect": "相手に じゃれついて 攻撃する。 相手の 攻撃を さげる ことがある。" - }, - "fairyWind": { - "name": "ようせいのかぜ", - "effect": "ようせいのかぜを 起こし 相手に 吹きつけて 攻撃する。" - }, - "moonblast": { - "name": "ムーンフォース", - "effect": "月の パワーを かりて 相手を 攻撃する。 相手の 特攻を さげる ことがある。" - }, - "boomburst": { - "name": "ばくおんぱ", - "effect": "すさまじい 爆音の 破壊力に よって 周りに いるものを 攻撃する。" - }, - "fairyLock": { - "name": "フェアリーロック", - "effect": "ロックを かけることによって 次のターン すべての ポケモンを 逃げられなくする。" - }, - "kingsShield": { - "name": "キングシールド", - "effect": "相手の 攻撃を 防ぐと 同時に 防御態勢になる。 触れた 相手の 攻撃を さげる。" - }, - "playNice": { - "name": "なかよくする", - "effect": "相手と なかよくなって 戦う 気力を 失わせ 相手の 攻撃を さげる。" - }, - "confide": { - "name": "ないしょばなし", - "effect": "ないしょばなしを することで 相手の 集中力を 失わせ 相手の 特攻を さげる。" - }, - "diamondStorm": { - "name": "ダイヤストーム", - "effect": "ダイヤの 嵐を 巻き起こし ダメージを 与える。 自分の 防御を ぐーんと あげることが ある。" - }, - "steamEruption": { - "name": "スチームバースト", - "effect": "ものすごく 熱い 蒸気を 相手に 浴びせる。 相手は やけどする ことがある。" - }, - "hyperspaceHole": { - "name": "いじげんホール", - "effect": "異次元ホールで 突然 相手の 真横に 現れ 攻撃する。 まもるや みきり なども 無視 できる。" - }, - "waterShuriken": { - "name": "みずしゅりけん", - "effect": "粘液で できた 手裏剣を 2ー5回の 間 連続で だす。 必ず 先制攻撃 できる。" - }, - "mysticalFire": { - "name": "マジカルフレイム", - "effect": "口から 吐きだす 特別 熱い 炎で 攻撃する。 相手の 特攻を さげる。" - }, - "spikyShield": { - "name": "ニードルガード", - "effect": "相手の 攻撃を 防ぐと 同時に 触れた 相手の 体力を 削って しまう。" - }, - "aromaticMist": { - "name": "アロマミスト", - "effect": "不思議な アロマの 香りによって 味方の 特防を あげる。" - }, - "eerieImpulse": { - "name": "かいでんぱ", - "effect": "体から かいでんぱを 放ち 相手に 浴びせる ことによって 特攻を がくっと さげる。" - }, - "venomDrench": { - "name": "ベノムトラップ", - "effect": "特殊な 毒液を 浴びせかける。 毒状態の 相手は 攻撃 特攻 素早さが さがる。" - }, - "powder": { - "name": "ふんじん", - "effect": "ふんじんを 浴びせた 相手が ほのお技を 使うと 爆発して ダメージを 与える。" - }, - "geomancy": { - "name": "ジオコントロール", - "effect": "1ターン目で エネルギーを 吸収し 2ターン目に 特攻 特防 素早さを ぐーんと あげる。" - }, - "magneticFlux": { - "name": "じばそうさ", - "effect": "磁場を 操作 することによって 特性 プラスと マイナスの 防御 特防が あがる。" - }, - "happyHour": { - "name": "ハッピータイム", - "effect": "ハッピータイムの 技を 使うと 戦闘の あとで もらえる お金が 倍になる。" - }, - "electricTerrain": { - "name": "エレキフィールド", - "effect": "5ターンの 間 エレキフィールドにする。 地面にいる ポケモンは 眠らない。 でんきタイプの 威力が あがる。" - }, - "dazzlingGleam": { - "name": "マジカルシャイン", - "effect": "強力な 光を 放ち 相手に ダメージを 与える。" - }, - "celebrate": { - "name": "おいわい", - "effect": "ポケモンが とっても ハッピーな あなたのことを お祝い してくれる。" - }, - "holdHands": { - "name": "てをつなぐ", - "effect": "味方の ポケモン 同士が 手をつなぐ。 とっても 幸せな 気持ちに なれる。" - }, - "babyDollEyes": { - "name": "つぶらなひとみ", - "effect": "つぶらなひとみで 相手を みつめて 攻撃を さげる。 必ず 先制攻撃 できる。" - }, - "nuzzle": { - "name": "ほっぺすりすり", - "effect": "電気を 帯びた ほっぺを すりつけて 攻撃。 相手を まひ状態に する。" - }, - "holdBack": { - "name": "てかげん", - "effect": "手加減 した 攻撃で 相手の HPを 必ず 1だけ 残す。" - }, - "infestation": { - "name": "まとわりつく", - "effect": "4ー5ターンの 間 相手に まとわりついて 攻撃する。 そのあいだ 相手は 逃げられない。" - }, - "powerUpPunch": { - "name": "グロウパンチ", - "effect": "繰り返し 打つことで だんだん こぶしが 固くなる。 相手に 当てると 攻撃が あがる。" - }, - "oblivionWing": { - "name": "デスウイング", - "effect": "ねらいを 定めた 相手から HPを 吸い取る。 与えた ダメージの 半分以上 HPを 回復する。" - }, - "thousandArrows": { - "name": "サウザンアロー", - "effect": "浮いている ポケモンにも 当たる。 浮いていた 相手は 撃ち落とされて 地面に 落ちる。" - }, - "thousandWaves": { - "name": "サウザンウェーブ", - "effect": "地をはう 波によって 攻撃。 波に 巻き込まれた 相手は 戦闘から 逃げられなくなる。" - }, - "landsWrath": { - "name": "グランドフォース", - "effect": "大地の パワーを 集め 力を 相手に 集中させて ダメージを 与える。" - }, - "lightOfRuin": { - "name": "はめつのひかり", - "effect": "永遠の花 の パワーを かりて 強力な 光線を 撃ちだす。 自分も かなりの ダメージを 受ける。" - }, - "originPulse": { - "name": "こんげんのはどう", - "effect": "青白く 輝く 無数の 光線で 相手を 攻撃する。" - }, - "precipiceBlades": { - "name": "だんがいのつるぎ", - "effect": "大地の 力を 刃に 変えて 相手を 攻撃する。" - }, - "dragonAscent": { - "name": "ガリョウテンセイ", - "effect": "大空から 急速落下 して 相手を 攻撃する。 自分の 防御と 特防が さがる。" - }, - "hyperspaceFury": { - "name": "いじげんラッシュ", - "effect": "たくさんの 腕で まもるや みきり などを 無視した 連続攻撃。 自分の 防御が さがる。" - }, - "breakneckBlitzPhysical": { - "name": "ウルトラダッシュアタック", - "effect": "Zパワーで 勢いを つけて 全力で 相手に ぶつかる。 元になった 技で 威力が 変わる。" - }, - "breakneckBlitzSpecial": { - "name": "ウルトラダッシュアタック", - "effect": "ダミーデータ" - }, - "allOutPummelingPhysical": { - "name": "ぜんりょくむそうげきれつけん", - "effect": "Zパワーで 作った エネルギーの 弾を 全力で 相手に ぶつける。 元になった 技で 威力が 変わる。" - }, - "allOutPummelingSpecial": { - "name": "ぜんりょくむそうげきれつけん", - "effect": "ダミーデータ" - }, - "supersonicSkystrikePhysical": { - "name": "ファイナルダイブクラッシュ", - "effect": "Zパワーで 勢いよく 飛びあがり 相手に 向かって 全力で 落下。 元になった 技で 威力が 変わる。" - }, - "supersonicSkystrikeSpecial": { - "name": "ファイナルダイブクラッシュ", - "effect": "ダミーデータ" - }, - "acidDownpourPhysical": { - "name": "アシッドポイズンデリート", - "effect": "Zパワーで 毒の 沼を 湧きあがらせ 全力で 相手を 沈める。 元になった 技で 威力が 変わる。" - }, - "acidDownpourSpecial": { - "name": "アシッドポイズンデリート", - "effect": "ダミーデータ" - }, - "tectonicRagePhysical": { - "name": "ライジングランドオーバー", - "effect": "Zパワーで 地面の 奥深くに 潜り 全力で 相手に ぶつかる。 元になった 技で 威力が 変わる。" - }, - "tectonicRageSpecial": { - "name": "ライジングランドオーバー", - "effect": "ダミーデータ" - }, - "continentalCrushPhysical": { - "name": "ワールズエンドフォール", - "effect": "Zパワーで 大きな 岩山を 呼びだし 全力で 相手に ぶつける。 元になった 技で 威力が 変わる。" - }, - "continentalCrushSpecial": { - "name": "ワールズエンドフォール", - "effect": "ダミーデータ" - }, - "savageSpinOutPhysical": { - "name": "ぜったいほしょくかいてんざん", - "effect": "Zパワーで 吐きだした 糸が 全力で 相手を 縛りつける。 元になった 技で 威力が 変わる。" - }, - "savageSpinOutSpecial": { - "name": "ぜったいほしょくかいてんざん", - "effect": "ダミーデータ" - }, - "neverEndingNightmarePhysical": { - "name": "むげんあんやへのいざない", - "effect": "Zパワーで 呼びよせた 強い 怨念が 全力で 相手に 降りかかる。 元になった 技で 威力が 変わる。" - }, - "neverEndingNightmareSpecial": { - "name": "むげんあんやへのいざない", - "effect": "ダミーデータ" - }, - "corkscrewCrashPhysical": { - "name": "ちょうぜつらせんれんげき", - "effect": "Zパワーで 高速回転を おこない 全力で 相手に ぶつかる。 元になった 技で 威力が 変わる。" - }, - "corkscrewCrashSpecial": { - "name": "ちょうぜつらせんれんげき", - "effect": "ダミーデータ" - }, - "infernoOverdrivePhysical": { - "name": "ダイナミックフルフレイム", - "effect": "Zパワーで 燃えさかる 炎を 吐きだし 全力で 相手に ぶつける。 元になった 技で 威力が 変わる。" - }, - "infernoOverdriveSpecial": { - "name": "ダイナミックフルフレイム", - "effect": "ダミーデータ" - }, - "hydroVortexPhysical": { - "name": "スーパーアクアトルネード", - "effect": "Zパワーで 大きな 渦潮を 作り 全力で 相手を 飲みこむ。 元になった 技で 威力が 変わる。" - }, - "hydroVortexSpecial": { - "name": "スーパーアクアトルネード", - "effect": "ダミーデータ" - }, - "bloomDoomPhysical": { - "name": "ブルームシャインエクストラ", - "effect": "Zパワーで 草花の エネルギーを 借り 全力で 相手を 攻撃する。 元になった 技で 威力が 変わる。" - }, - "bloomDoomSpecial": { - "name": "ブルームシャインエクストラ", - "effect": "ダミーデータ" - }, - "gigavoltHavocPhysical": { - "name": "スパーキングギガボルト", - "effect": "Zパワーで 溜めた 強い 電気を 全力で 相手に ぶつける。 元になった 技で 威力が 変わる。" - }, - "gigavoltHavocSpecial": { - "name": "スパーキングギガボルト", - "effect": "ダミーデータ" - }, - "shatteredPsychePhysical": { - "name": "マキシマムサイブレイカー", - "effect": "Zパワーで 相手を 操り 全力で 痛い 思いを させる。 元になった 技で 威力が 変わる。" - }, - "shatteredPsycheSpecial": { - "name": "マキシマムサイブレイカー", - "effect": "ダミーデータ" - }, - "subzeroSlammerPhysical": { - "name": "レイジングジオフリーズ", - "effect": "Zパワーで 気温を 急激に 下げ 全力で 相手を 凍らせる。 元になった 技で 威力が 変わる。" - }, - "subzeroSlammerSpecial": { - "name": "レイジングジオフリーズ", - "effect": "ダミーデータ" - }, - "devastatingDrakePhysical": { - "name": "アルティメットドラゴンバーン", - "effect": "Zパワーで オーラを 実体化し 全力で 相手に 襲いかかる。 元になった 技で 威力が 変わる。" - }, - "devastatingDrakeSpecial": { - "name": "アルティメットドラゴンバーン", - "effect": "ダミーデータ" - }, - "blackHoleEclipsePhysical": { - "name": "ブラックホールイクリプス", - "effect": "Zパワーで 悪の エネルギーを 集め 全力で 相手を 吸いよせる。 元になった 技で 威力が 変わる。" - }, - "blackHoleEclipseSpecial": { - "name": "ブラックホールイクリプス", - "effect": "ダミーデータ" - }, - "twinkleTacklePhysical": { - "name": "ラブリースターインパクト", - "effect": "Zパワーで 魅惑の 空間を 作り 全力で 相手を もてあそぶ。 元になった 技で 威力が 変わる。" - }, - "twinkleTackleSpecial": { - "name": "ラブリースターインパクト", - "effect": "ダミーデータ" - }, - "catastropika": { - "name": "ひっさつのピカチュート", - "effect": "Zパワーで 最大 電力を 身に まとったピカチュウが 全力で 相手に 飛び掛る。" - }, - "shoreUp": { - "name": "すなあつめ", - "effect": "最大HPの 半分 自分の HPを 回復する。 すなあらしの時は 多く 回復。" - }, - "firstImpression": { - "name": "であいがしら", - "effect": "威力が 高い 技 だが 戦闘に 出たら すぐに 出さないと 成功 しない。" - }, - "banefulBunker": { - "name": "トーチカ", - "effect": "相手の 攻撃を 防ぐと 同時に 触れた 相手に 毒を 与えてしまう。" - }, - "spiritShackle": { - "name": "かげぬい", - "effect": "攻撃と 同時に 相手の 影を 縫い付けて 逃げられなくする。" - }, - "darkestLariat": { - "name": "DDラリアット", - "effect": "両腕を 回し 相手に 当てる。 相手の 能力変化に 関係なく ダメージを 与える。" - }, - "sparklingAria": { - "name": "うたかたのアリア", - "effect": "歌うことによって たくさんの バルーンを 放出する。 技を 受けると やけどが 治る。" - }, - "iceHammer": { - "name": "アイスハンマー", - "effect": "強くて 重い こぶしを ふるって ダメージを 与える。 自分の 素早さが さがる。" - }, - "floralHealing": { - "name": "フラワーヒール", - "effect": "最大HPの 半分 相手の HPを 回復する。 グラスフィールドの時 効果が あがる。" - }, - "highHorsepower": { - "name": "10まんばりき", - "effect": "全身を 使って 相手に 猛アタックする。" - }, - "strengthSap": { - "name": "ちからをすいとる", - "effect": "相手の 攻撃力と 同じだけ 自分の HPを 回復する。 そして 相手の 攻撃を さげる。" - }, - "solarBlade": { - "name": "ソーラーブレード", - "effect": "1ターン目に 光を いっぱいに 集め 2ターン目に その 力を 剣に 込めて 攻撃する。" - }, - "leafage": { - "name": "このは", - "effect": "はっぱを 相手に 当てて 攻撃する。" - }, - "spotlight": { - "name": "スポットライト", - "effect": "ポケモンに スポットライトを 当て そのターンに そのポケモンしか 狙えない ようにする。" - }, - "toxicThread": { - "name": "どくのいと", - "effect": "毒の 混じった 糸を 吹き付ける。 相手を 毒にして 素早さを さげる。" - }, - "laserFocus": { - "name": "とぎすます", - "effect": "精神を 集中して 次の 攻撃を 必ず 急所に 当てる。" - }, - "gearUp": { - "name": "アシストギア", - "effect": "ギアを 入れる ことによって 特性 プラスと マイナスの 攻撃と 特攻が あがる。" - }, - "throatChop": { - "name": "じごくづき", - "effect": "この 技を 受けた 相手は 地獄の 苦しみから 2ターンの間 音の 技を 出すことが できなくなる。" - }, - "pollenPuff": { - "name": "かふんだんご", - "effect": "敵には 爆発する だんごを 使って 攻撃。 味方には 回復する だんごを 与える。" - }, - "anchorShot": { - "name": "アンカーショット", - "effect": "アンカーを 相手に からませて 攻撃する。 相手は 逃げることが できなくなる。" - }, - "psychicTerrain": { - "name": "サイコフィールド", - "effect": "5ターンの間 地面にいると 先制技を 受けない。 エスパータイプの 威力が あがる。" - }, - "lunge": { - "name": "とびかかる", - "effect": "全力で 相手に 飛びかかって 攻撃。 相手の 攻撃を さげる。" - }, - "fireLash": { - "name": "ほのおのムチ", - "effect": "焼けたムチで 相手を 打ちつける。 攻撃を 受けた 相手は 防御が さがる。" - }, - "powerTrip": { - "name": "つけあがる", - "effect": "自分の 強さを 鼻高々に 攻撃する。自分の 能力が あがって いるほど 威力が あがる。" - }, - "burnUp": { - "name": "もえつきる", - "effect": "全身の ほのおを すべて 燃やして 大ダメージを 与える。 自分の ほのおタイプが なくなる。" - }, - "speedSwap": { - "name": "スピードスワップ", - "effect": "相手の 素早さと 自分の 素早さを 入れ替えてしまう。" - }, - "smartStrike": { - "name": "スマートホーン", - "effect": "とがった つので 相手を 突き刺して 攻撃する。 攻撃は 必ず 命中する。" - }, - "purify": { - "name": "じょうか", - "effect": "相手の 状態異常を 治す。 治すと 自分は HPを 回復 することが できる。" - }, - "revelationDance": { - "name": "めざめるダンス", - "effect": "全力で 踊って 攻撃する。 この 技の タイプは 自分の タイプと 同じになる。" - }, - "coreEnforcer": { - "name": "コアパニッシャー", - "effect": "ダメージを 与えた 相手が すでに 行動を 終えていたら 相手の 特性を 消してしまう。" - }, - "tropKick": { - "name": "トロピカルキック", - "effect": "南国 由来の 熱い キックを 相手に 浴びせる。 相手の 攻撃を さげる。" - }, - "instruct": { - "name": "さいはい", - "effect": "相手が 出した 技を 指示して もう一度 出させることが できる。" - }, - "beakBlast": { - "name": "くちばしキャノン", - "effect": "最初に クチバシを 加熱してから 攻撃を くりだす。 加熱中に さわると やけどする。" - }, - "clangingScales": { - "name": "スケイルノイズ", - "effect": "全身の うろこを こすり 大きな 音を 出して 攻撃する。 攻撃後 自分の 防御が さがる。" - }, - "dragonHammer": { - "name": "ドラゴンハンマー", - "effect": "体を ハンマーのように 使って 相手に 襲いかかり ダメージを 与える。" - }, - "brutalSwing": { - "name": "ぶんまわす", - "effect": "自分の 体を ぶんまわして 相手に ダメージを 与える。" - }, - "auroraVeil": { - "name": "オーロラベール", - "effect": "5ターンの 間 物理と 特殊の ダメージを 弱める。 ゆきの 時しか 出すことが できない。" - }, - "sinisterArrowRaid": { - "name": "シャドーアローズストライク", - "effect": "Zパワーで 無数の 矢を 作りだした ジュナイパーが 全力で 相手を 射抜く 攻撃。" - }, - "maliciousMoonsault": { - "name": "ハイパーダーククラッシャー", - "effect": "Zパワーで タフな 肉体を 得た ガオガエンが 全力で 相手に ぶつかって 攻撃する。" - }, - "oceanicOperetta": { - "name": "わだつみのシンフォニア", - "effect": "Zパワーで 大量の 水を 呼んだ アシレーヌが 全力で 相手を 攻撃する。" - }, - "guardianOfAlola": { - "name": "ガーディアン・デ・アローラ", - "effect": "Zパワーで アローラの 力を 得た とちがみポケモン 全力の 攻撃。 相手の 残りHPを たくさん 減らす。" - }, - "soulStealing7StarStrike": { - "name": "しちせいだっこんたい", - "effect": "Zパワーを 得た マーシャドーが パンチと キックの 連続技を 全力で 相手に 叩き込む。" - }, - "stokedSparksurfer": { - "name": "ライトニングサーフライド", - "effect": "Zパワーを 得た アローラ地方の ライチュウが 全力で 攻撃する。 相手を まひ 状態に する。" - }, - "pulverizingPancake": { - "name": "ほんきをだす こうげき", - "effect": "Zパワーで 本気を 出した カビゴンが 巨体を 躍動させて 全力で 相手に 襲いかかる。" - }, - "extremeEvoboost": { - "name": "ナインエボルブースト", - "effect": "Zパワーを 得た イーブイが 進化した 仲間たちの 力を 借りて 能力を ぐーんと 上げる。" - }, - "genesisSupernova": { - "name": "オリジンズスーパーノヴァ", - "effect": "Zパワーを 得た ミュウが 全力で 相手を 攻撃する。 足元が サイコフィールドになる。" - }, - "shellTrap": { - "name": "トラップシェル", - "effect": "こうらの トラップを しかける。 相手が 物理技を 出すと 爆発して ダメージを 与える。" - }, - "fleurCannon": { - "name": "フルールカノン", - "effect": "強力な ビームを 放ったあと 自分の 特攻が がくっと さがる。" - }, - "psychicFangs": { - "name": "サイコファング", - "effect": "サイコパワーで かみついて 相手を 攻撃する。 ひかりのかべや リフレクター なども 破壊できる。" - }, - "stompingTantrum": { - "name": "じだんだ", - "effect": "悔しさを バネにして 攻撃する。 前の ターンに 技を 外していると 威力が 倍に なる。" - }, - "shadowBone": { - "name": "シャドーボーン", - "effect": "魂の 宿った ホネで 相手を なぐりつけて 攻撃する。 相手の 防御を さげる ことがある。" - }, - "accelerock": { - "name": "アクセルロック", - "effect": "素早い スピードで 相手に ぶつかって 攻撃する。 必ず 先制攻撃 できる。" - }, - "liquidation": { - "name": "アクアブレイク", - "effect": "水の 力で 相手に ぶつかって 攻撃する。 相手の 防御を さげる ことがある。" - }, - "prismaticLaser": { - "name": "プリズムレーザー", - "effect": "プリズムの 力で 強力な 光線を 発射する。 次の ターンは 動けなくなる。" - }, - "spectralThief": { - "name": "シャドースチール", - "effect": "相手の 影に 潜り込み 相手の 能力アップを 奪って 攻撃する。" - }, - "sunsteelStrike": { - "name": "メテオドライブ", - "effect": "流星の ような 勢いで 突進する。 相手の 特性を 無視して 攻撃 することが できる。" - }, - "moongeistBeam": { - "name": "シャドーレイ", - "effect": "怪しい 光線を 放って 攻撃する。相手の 特性を 無視して 攻撃 することが できる。" - }, - "tearfulLook": { - "name": "なみだめ", - "effect": "なみだめに なって 相手の 戦力を 喪失させる。 相手の 攻撃と 特攻が さがる。" - }, - "zingZap": { - "name": "びりびりちくちく", - "effect": "相手に ぶつかって 強力な 電気を浴びせ びりびりちくちく させる。 相手を ひるませる ことが ある。" - }, - "naturesMadness": { - "name": "しぜんのいかり", - "effect": "自然の 怒りを 相手に ぶつける。 相手の HPは 半分に なる。" - }, - "multiAttack": { - "name": "マルチアタック", - "effect": "高い エネルギーを まといつつ 相手に ぶつかって 攻撃する。 メモリに より タイプが 変わる。" - }, - "tenMillionVoltThunderbolt": { - "name": "1000まんボルト", - "effect": "帽子を かぶった ピカチュウが Zパワーで パワーアップした 電撃を 放つ。 急所に 当たりやすい。" - }, - "mindBlown": { - "name": "ビックリヘッド", - "effect": "自分の 頭を 爆発 させて 周りの すべてを 攻撃する。 自分も ダメージを 受けてしまう。" - }, - "plasmaFists": { - "name": "プラズマフィスト", - "effect": "電気を まとった こぶしで 攻撃。 ノーマルタイプの 技を でんきタイプに してしまう。" - }, - "photonGeyser": { - "name": "フォトンゲイザー", - "effect": "光の 柱で 攻撃する。 攻撃と 特攻を 比べて 高いほうで ダメージを 与える。" - }, - "lightThatBurnsTheSky": { - "name": "てんこがすめつぼうのひかり", - "effect": "ネクロズマが 相手の 特性の 効果を 無視して 攻撃と 特攻の 高い方で ダメージを 与える。" - }, - "searingSunrazeSmash": { - "name": "サンシャインスマッシャー", - "effect": "Zパワーを 得た ソルガレオが 全力で 攻撃する。 相手の 特性の 効果を 無視できる。" - }, - "menacingMoonrazeMaelstrom": { - "name": "ムーンライトブラスター", - "effect": "Zパワーを 得た ルナアーラが 全力で 攻撃する。 相手の 特性の 効果を 無視できる。" - }, - "letsSnuggleForever": { - "name": "ぽかぼかフレンドタイム", - "effect": "Zパワーを 得た ミミッキュが 全力で ぽかぽか 攻撃。" - }, - "splinteredStormshards": { - "name": "ラジアルエッジストーム", - "effect": "Zパワーを 得た ルガルガンが 全力で 攻撃する。 追加で フィールド状態を 打ち消す。" - }, - "clangorousSoulblaze": { - "name": "ブレイジングソウルビート", - "effect": "Zパワーを 得た ジャラランガが 全力で 相手を 攻撃する。 追加で 自分の 能力が 上がる。" - }, - "zippyZap": { - "name": "ばちばちアクセル", - "effect": "猛スピードの 電撃 アタック。 必ず 先制攻撃 できて 急所に あたる。" - }, - "splishySplash": { - "name": "ざぶざぶサーフ", - "effect": "大きな 波に 電気を あびせ 相手に ぶつけて 攻撃する。 まひ状態に することが ある。" - }, - "floatyFall": { - "name": "ふわふわフォール", - "effect": "ふんわりと 浮かび あがり 一気に 急降下して 攻撃。 相手を ひるませることが ある。" - }, - "pikaPapow": { - "name": "ピカピカサンダー", - "effect": "トレーナーへの 大好きな 気持ちが 強いほど 威力が あがる 電撃。 必ず 命中する。" - }, - "bouncyBubble": { - "name": "いきいきバブル", - "effect": "水のかたまりを ぶつけて 攻撃。 水を 吸いとり ダメージの 半分の HPを 回復する。" - }, - "buzzyBuzz": { - "name": "びりびりエレキ", - "effect": "電気を 飛ばし 相手に あびせて 攻撃する。 相手を まひ状態に する。" - }, - "sizzlySlide": { - "name": "めらめらバーン", - "effect": "炎を まとった 体で 勢いよく 相手に ぶつかる。 相手を やけど状態に する。" - }, - "glitzyGlow": { - "name": "どばどばオーラ", - "effect": "念力を これでもかと あびせる。 相手の 特殊攻撃を 弱める 不思議な かべを つくりだす。" - }, - "baddyBad": { - "name": "わるわるゾーン", - "effect": "わるさを アピールして 攻撃。 相手の 物理攻撃を 弱める 不思議な かべを つくりだす。" - }, - "sappySeed": { - "name": "すくすくボンバー", - "effect": "巨大な ツルを 生やし タネを 撒きちらかして 攻撃する。 タネは 毎ターン 相手の HPを 吸いとる。" - }, - "freezyFrost": { - "name": "こちこちフロスト", - "effect": "冷たく 凍った くろいきりの 結晶で 攻撃。 全員の 能力変化を もとに もどす。" - }, - "sparklySwirl": { - "name": "きらきらストーム", - "effect": "むせかえる ような 香りの 竜巻で 相手を つつんで 攻撃。 味方の 状態異常を 回復する。" - }, - "veeveeVolley": { - "name": "ブイブイブレイク", - "effect": "イーブイの トレーナーへの 大好きな 気持ちが 強いほど 威力が あがる 体当たり。 必ず 命中する。" - }, - "doubleIronBash": { - "name": "ダブルパンツァー", - "effect": "胸の ナットを 軸に 回転して 2回 続けて うでを たたきつける。 相手を ひるませる ことが ある。" - }, - "maxGuard": { - "name": "ダイウォール", - "effect": "相手の 攻撃を まったく 受けない。 連続で だすと 失敗しやすい。" - }, - "dynamaxCannon": { - "name": "ダイマックスほう", - "effect": "コアから ビームを 放つ。相手の レベルが 過度に 上がっている 場合は 与える ダメージが 最大 2倍に 増える。" - }, - "snipeShot": { - "name": "ねらいうち", - "effect": "相手の 技を 引き受ける 特性や 技の 影響を 無視して 選んだ 相手を 攻撃 できる。" - }, - "jawLock": { - "name": "くらいつく", - "effect": "お互い ひんしに なるまで 交代が できなくなる。 どちらかの ポケモンが いなくなると 効果は消える。" - }, - "stuffCheeks": { - "name": "ほおばる", - "effect": "持っている きのみを 食べて 防御を ぐーんと あげる。" - }, - "noRetreat": { - "name": "はいすいのじん", - "effect": "自分の すべての 能力が 上がるが 交代 したり 逃げることが できなくなる。" - }, - "tarShot": { - "name": "タールショット", - "effect": "ねばねばの タールを 浴びせて 相手の 素早さを 下げる。 相手は ほのおが 弱点に なる。" - }, - "magicPowder": { - "name": "まほうのこな", - "effect": "まほうのこなを 浴びせて 相手を エスパータイプに 変化させる。" - }, - "dragonDarts": { - "name": "ドラゴンアロー", - "effect": "ドラメシヤで 2回 攻撃。 相手が 2匹 いるときは それぞれに 1回ずつ 攻撃する。" - }, - "teatime": { - "name": "おちゃかい", - "effect": "おちゃかいを ひらいて 場にいる ポケモンが それぞれ 持っている きのみを 食べる。" - }, - "octolock": { - "name": "たこがため", - "effect": "相手を 逃げられなくする。 かためられた 相手は 毎ターン 防御と 特防が 下がる。" - }, - "boltBeak": { - "name": "でんげきくちばし", - "effect": "電気を まとった くちばしで 刺す。 相手より 先に 攻撃できると 技の 威力は 2倍に なる。" - }, - "fishiousRend": { - "name": "エラがみ", - "effect": "かたい エラで かみつく。 相手より 先に 攻撃できると 技の 威力は 2倍に なる。" - }, - "courtChange": { - "name": "コートチェンジ", - "effect": "不思議な 力で お互いの 場の 効果を 入れ替える。" - }, - "maxFlare": { - "name": "ダイバーン", - "effect": "ダイマックスした ポケモンが 繰りだす ほのおタイプの 攻撃。 5ターンの 間 日差しを 強くする。" - }, - "maxFlutterby": { - "name": "ダイワーム", - "effect": "ダイマックスした ポケモンが 繰りだす むしタイプの 攻撃。 相手の 特攻を 下げる。" - }, - "maxLightning": { - "name": "ダイサンダー", - "effect": "ダイマックスした ポケモンが 繰りだす でんきタイプの 攻撃。 5ターンの 間 エレキフィールドにする。" - }, - "maxStrike": { - "name": "ダイアタック", - "effect": "ダイマックスした ポケモンが 繰りだす ノーマルタイプの 攻撃。 相手の 素早さを 下げる。" - }, - "maxKnuckle": { - "name": "ダイナックル", - "effect": "ダイマックスした ポケモンが 繰りだす かくとうタイプの 攻撃。 味方の 攻撃を 上げる。" - }, - "maxPhantasm": { - "name": "ダイホロウ", - "effect": "ダイマックスした ポケモンが 繰りだす ゴーストタイプの 攻撃。 相手の 防御を 下げる。" - }, - "maxHailstorm": { - "name": "ダイアイス", - "effect": "ダイマックスした ポケモンが 繰りだす こおりタイプの 攻撃。 5ターンの 間 あられを 降らす。" - }, - "maxOoze": { - "name": "ダイアシッド", - "effect": "ダイマックスした ポケモンが 繰りだす どくタイプの 攻撃。 味方の 特攻を 上げる。" - }, - "maxGeyser": { - "name": "ダイストリーム", - "effect": "ダイマックスした ポケモンが 繰りだす みずタイプの 攻撃。 5ターンの 間 雨を 降らせる。" - }, - "maxAirstream": { - "name": "ダイジェット", - "effect": "ダイマックスした ポケモンが 繰りだす ひこうタイプの 攻撃。 味方の 素早さを 上げる。" - }, - "maxStarfall": { - "name": "ダイフェアリー", - "effect": "ダイマックスした ポケモンが 繰りだす フェアリータイプの 攻撃。 5ターンの 間 ミストフィールドにする。" - }, - "maxWyrmwind": { - "name": "ダイドラグーン", - "effect": "ダイマックスした ポケモンが 繰りだす ドラゴンタイプの 攻撃。 相手の 攻撃を 下げる。" - }, - "maxMindstorm": { - "name": "ダイサイコ", - "effect": "ダイマックスした ポケモンが 繰りだす エスパータイプの 攻撃。 5ターンの 間 サイコフィールドにする。" - }, - "maxRockfall": { - "name": "ダイロック", - "effect": "ダイマックスした ポケモンが 繰りだす いわタイプの 攻撃。 5ターンの 間 砂あらしにする。" - }, - "maxQuake": { - "name": "ダイアース", - "effect": "ダイマックスした ポケモンが 繰りだす じめんタイプの 攻撃。 味方の 特防を 上げる。" - }, - "maxDarkness": { - "name": "ダイアーク", - "effect": "ダイマックスした ポケモンが 繰りだす あくタイプの 攻撃。 相手の 特防を 下げる。" - }, - "maxOvergrowth": { - "name": "ダイソウゲン", - "effect": "ダイマックスした ポケモンが 繰りだす くさタイプの 攻撃。 5ターンの 間 グラスフィールドにする。" - }, - "maxSteelspike": { - "name": "ダイスチル", - "effect": "ダイマックスした ポケモンが 繰りだす はがねタイプの 攻撃。 味方の 防御を 上げる。" - }, - "clangorousSoul": { - "name": "ソウルビート", - "effect": "自分の HPを 少し 削って すべての 能力を 上げる。" - }, - "bodyPress": { - "name": "ボディプレス", - "effect": "体を ぶつけて 攻撃。 防御が 高いほど 与える ダメージが 増える。" - }, - "decorate": { - "name": "デコレーション", - "effect": "かざりつけを することで 相手の 攻撃と 特攻を ぐーんと 上げる。" - }, - "drumBeating": { - "name": "ドラムアタック", - "effect": "ドラムの 根っこを ドラミングで コントロールして こうげき することで 相手の 素早さを 下げる。" - }, - "snapTrap": { - "name": "トラバサミ", - "effect": "トラバサミで 捕らえて 4-5ターンの 間 相手を はさんで 攻撃する。" - }, - "pyroBall": { - "name": "かえんボール", - "effect": "小石を 燃やした 炎の ボールで 相手を 攻撃する。 やけど 状態に することが ある。" - }, - "behemothBlade": { - "name": "きょじゅうざん", - "effect": "全身で 強大な剣を 振りかざし 勢いよく 切りかかって 攻撃する。" - }, - "behemothBash": { - "name": "きょじゅうだん", - "effect": "全身を 強固な盾へと 変化させ 勢いよく ぶつかって 攻撃する。" - }, - "auraWheel": { - "name": "オーラぐるま", - "effect": "ほほぶくろに 溜めた エネルギーで 攻撃し 自分の 素早さを あげる。 モルペコの 姿で タイプが 変わる。" - }, - "breakingSwipe": { - "name": "ワイドブレイカー", - "effect": "きょうじんな しっぽを 激しく ふりはらって 相手を 攻撃する。 相手の 攻撃を 下げる。" - }, - "branchPoke": { - "name": "えだづき", - "effect": "するどく とがった 枝で 相手を 突いて 攻撃する。" - }, - "overdrive": { - "name": "オーバードライブ", - "effect": "ギターや ベースを かきならして 激しく 響く 大きな 振動を 相手に 与えて 攻撃する。" - }, - "appleAcid": { - "name": "りんごさん", - "effect": "すっぱい りんごから つくりだした 酸性の 液体で 攻撃。 相手の 特防を 下げる。" - }, - "gravApple": { - "name": "Gのちから", - "effect": "高いところから りんごを 落として ダメージを 与える。 相手の 防御を 下げる。" - }, - "spiritBreak": { - "name": "ソウルクラッシュ", - "effect": "食らうと くじけるほどの 勢いで 攻撃。 相手の 特攻を 下げる。" - }, - "strangeSteam": { - "name": "ワンダースチーム", - "effect": "煙を 噴出して 相手を 攻撃。 混乱 させることが ある。" - }, - "lifeDew": { - "name": "いのちのしずく", - "effect": "不思議な 水を ふりまいて 自分と 場にいる 味方の HPを 回復する。" - }, - "obstruct": { - "name": "ブロッキング", - "effect": "相手の 攻撃を まったく 受けない。 連続で だすと 失敗しやすい。 触れると 防御が がくっと 下がる。" - }, - "falseSurrender": { - "name": "どげざつき", - "effect": "頭を 下げる ふりを しながら 振りみだした 髪の毛を 突き刺す。 攻撃は 必ず 命中する。" - }, - "meteorAssault": { - "name": "スターアサルト", - "effect": "太い クキを ふりまわして 攻撃。 ただし 自分も よろめいてしまうため 次の ターンは 動けなくなる。" - }, - "eternabeam": { - "name": "ムゲンダイビーム", - "effect": "本来の 姿と なった ムゲンダイナ 最大の 攻撃。 次の ターンは 動けなくなる。" - }, - "steelBeam": { - "name": "てっていこうせん", - "effect": "全身から 集めた はがねを ビームとして 激しく 撃ちだす。 自分も ダメージを 受けてしまう。" - }, - "expandingForce": { - "name": "ワイドフォース", - "effect": "サイコパワーで 相手を 攻撃する。 サイコフィールドの時 威力が あがり すべての 相手に ダメージを 与える。" - }, - "steelRoller": { - "name": "アイアンローラー", - "effect": "フィールドを 破壊しながら 攻撃。 なんらかの フィールド状態に 変わっていないと 技は 失敗する。" - }, - "scaleShot": { - "name": "スケイルショット", - "effect": "ウロコを 撃ちだして 攻撃する。 2ー5回の 間 連続で だす。 素早さが あがるが 防御が さがる。" - }, - "meteorBeam": { - "name": "メテオビーム", - "effect": "1ターン目に 宇宙の 力を 集めることで 特攻が あがり 2ターン目に 相手を 攻撃する。" - }, - "shellSideArm": { - "name": "シェルアームズ", - "effect": "物理か 特殊か より多く ダメージを 与えられる 能力で 攻撃する。 毒状態に することが ある。" - }, - "mistyExplosion": { - "name": "ミストバースト", - "effect": "自分の 周りに いる すべてを 攻撃するが 使うと 瀕死になる。 ミストフィールドで 威力が あがる。" - }, - "grassyGlide": { - "name": "グラススライダー", - "effect": "地面を 滑るように 相手を 攻撃。 グラスフィールドの時 必ず 先制攻撃 できる。" - }, - "risingVoltage": { - "name": "ライジングボルト", - "effect": "地面から 立ちのぼる 電撃で 攻撃。 相手が エレキフィールドに いる時 技の 威力が 2倍に なる。" - }, - "terrainPulse": { - "name": "だいちのはどう", - "effect": "フィールドの力を 借りて 攻撃。 使った時の フィールドの状態に よって 技の タイプと 威力が 変わる。" - }, - "skitterSmack": { - "name": "はいよるいちげき", - "effect": "背後から はいより 攻撃する。 相手の 特攻を さげる。" - }, - "burningJealousy": { - "name": "しっとのほのお", - "effect": "しっとの エネルギーで 相手を 攻撃。 そのターン 能力が あがった ポケモンを やけどの 状態に する。" - }, - "lashOut": { - "name": "うっぷんばらし", - "effect": "相手への いらだちを ぶつけて 攻撃。 そのターンに 能力を さげられていると 技の 威力が 2倍に なる。" - }, - "poltergeist": { - "name": "ポルターガイスト", - "effect": "相手の 持ち物を あやつって 攻撃。 相手が 道具を 持っていない 場合は 失敗する。" - }, - "corrosiveGas": { - "name": "ふしょくガス", - "effect": "強い 酸性の ガスで 周りに いるものを 包みこみ 持っている 道具を 溶かしてしまう。" - }, - "coaching": { - "name": "コーチング", - "effect": "的確な 指導を おこなうことで 味方 全員の 攻撃と 防御を 上げる。" - }, - "flipTurn": { - "name": "クイックターン", - "effect": "攻撃したあと ものすごい スピードで もどってきて 控えの ポケモンと 入れ替わる。" - }, - "tripleAxel": { - "name": "トリプルアクセル", - "effect": "3回連続で キックを くりだして 攻撃する。 技が 当たるたびに 威力は あがる。" - }, - "dualWingbeat": { - "name": "ダブルウイング", - "effect": "翼を 相手に ぶつけて 攻撃する。 2回連続で ダメージを 与える。" - }, - "scorchingSands": { - "name": "ねっさのだいち", - "effect": "熱く 焼けた 砂を 相手に ぶつけて 攻撃する。 やけど状態に することが ある。" - }, - "jungleHealing": { - "name": "ジャングルヒール", - "effect": "ジャングルと 一体化して 自分と 場にいる 味方の HPと 状態を 回復する。" - }, - "wickedBlow": { - "name": "あんこくきょうだ", - "effect": "あくの型を 極めし 強烈な 一撃。 必ず 急所に 当たる。" - }, - "surgingStrikes": { - "name": "すいりゅうれんだ", - "effect": "みずの型を 極めし 流れるような 3回の 連撃。 必ず 急所に 当たる。" - }, - "thunderCage": { - "name": "サンダープリズン", - "effect": "ほとばしる 電気の おりの 中に 4ー5ターンの 間 相手を 閉じこめて 攻撃する。" - }, - "dragonEnergy": { - "name": "ドラゴンエナジー", - "effect": "生命力を パワーに 変え 相手を 攻撃する。 自分の HPが 少ないほど 技の 威力は さがる。" - }, - "freezingGlare": { - "name": "いてつくしせん", - "effect": "両目から サイコパワーを 撃ちだして 攻撃する。 こおり状態に することが ある。" - }, - "fieryWrath": { - "name": "もえあがるいかり", - "effect": "怒りを 炎の ような オーラに 変えて 攻撃する。 相手を ひるませることが ある。" - }, - "thunderousKick": { - "name": "らいめいげり", - "effect": "雷の ような 動きで 相手を 翻弄しながら キックする。 相手の 防御を さげる。" - }, - "glacialLance": { - "name": "ブリザードランス", - "effect": "吹雪を まとった 氷の 槍を 相手に 投げつけて 攻撃する。" - }, - "astralBarrage": { - "name": "アストラルビット", - "effect": "たくさんの 小さな 霊体を 相手に ぶつけて 攻撃する。" - }, - "eerieSpell": { - "name": "ぶきみなじゅもん", - "effect": "強力な サイコパワーで 攻撃。 相手が 最後に 使った技の PPを 3だけ 減らす。" - }, - "direClaw": { - "name": "フェイタルクロー", - "effect": "破滅的なツメで 攻撃する。 相手を どく まひ ねむりの いずれかの状態に することも ある。" - }, - "psyshieldBash": { - "name": "バリアーラッシュ", - "effect": "思念のエネルギーを まといながら 相手に ぶつかっていく。 自分の 防御を あげる。" - }, - "powerShift": { - "name": "パワーシフト", - "effect": "自分の 攻撃と防御を 入れ替える。" - }, - "stoneAxe": { - "name": "がんせきアックス", - "effect": "岩の斧で 攻撃する。 ばらまかれた 岩の破片が 相手の 周りに 浮かぶ。" - }, - "springtideStorm": { - "name": "はるのあらし", - "effect": "愛憎 入りまじった 強烈な風で 相手を 包みこんで 攻撃する。 相手の 攻撃を さげることが ある。" - }, - "mysticalPower": { - "name": "しんぴのちから", - "effect": "不思議な力を 放出して 攻撃する。 自分の 特攻が あがる。" - }, - "ragingFury": { - "name": "だいふんげき", - "effect": "2-3ターンの 間 炎を 放ちながら 暴れまわる。 暴れたあとは 混乱する。" - }, - "waveCrash": { - "name": "ウェーブタックル", - "effect": "水を まといつつ 全身で 相手に ぶつかるが 自分も かなりの ダメージ を受ける。" - }, - "chloroblast": { - "name": "クロロブラスト", - "effect": "自身の 葉緑素を 集約し 放出して 攻撃する。 自分も ダメージを 受けてしまう。" - }, - "mountainGale": { - "name": "ひょうざんおろし", - "effect": "氷山のような 大きな 氷塊を ぶつけて 攻撃する。 相手を ひるませることが ある。" - }, - "victoryDance": { - "name": "しょうりのまい", - "effect": "勝利を 呼びこむ 舞を 激しく 踊って 自分の 攻撃と 防御と 素早さを あげる。" - }, - "headlongRush": { - "name": "ぶちかまし", - "effect": "全身全霊の たいあたりを くらわせる。 自分の 防御と 特防が さがる。" - }, - "barbBarrage": { - "name": "どくばりセンボン", - "effect": "無数の毒針で 相手を 毒状態に することもある。 相手が 毒状態だと 威力は 2倍になる。" - }, - "esperWing": { - "name": "オーラウイング", - "effect": "オーラで 強化した翼で 切り裂く。 急所に 当たりやすい。 自分の 素早さを あげる。" - }, - "bitterMalice": { - "name": "うらみつらみ", - "effect": "背筋が 凍るような 怨念で 攻撃して 相手の 攻撃を さげる。" - }, - "shelter": { - "name": "たてこもる", - "effect": "皮膚を 鉄の盾のように 硬くすることで 自分の 防御を ぐーんと あげる。" - }, - "tripleArrows": { - "name": "3ぼんのや", - "effect": "足技のあと 3本の矢を 同時に放つ。 相手の 防御を さげたり ひるませることが ある。 急所に 当たりやすい。" - }, - "infernalParade": { - "name": "ひゃっきやこう", - "effect": "無数の火の玉で 攻撃して やけど状態に することが ある。 相手が 状態異常だと 威力は 2倍。" - }, - "ceaselessEdge": { - "name": "ひけん・ちえなみ", - "effect": "貝殻の剣で 攻撃する。 ばらまかれた 貝殻の破片は 相手の 足下に まきびし となって 散らばる。" - }, - "bleakwindStorm": { - "name": "こがらしあらし", - "effect": "身も心も 震える 冷たく 激しい風で 攻撃する。 相手の 素早さを さげることが ある。" - }, - "wildboltStorm": { - "name": "かみなりあらし", - "effect": "嵐を 起こし 雷雲を 呼びよせ 雷と風で 激しく 攻撃をする。 相手を まひ状態に することもある。" - }, - "sandsearStorm": { - "name": "ねっさのあらし", - "effect": "熱く焼けた砂と 強烈な風で 包みこんで 攻撃する。 相手を やけど状態に することがある。" - }, - "lunarBlessing": { - "name": "みかづきのいのり", - "effect": "みかづきに いのりを ささげて 自分と 場にいる 味方の HPと 状態を 回復する。" - }, - "takeHeart": { - "name": "ブレイブチャージ", - "effect": "心を 奮わせて 自分の 状態異常を 治し さらには 特攻と 特防を あげる。" - }, - "gMaxWildfire": { - "name": "キョダイゴクエン", - "effect": "キョダイマックスした リザードンが 繰りだす ほのおタイプの 攻撃。 4ターンの 間 ダメージを 与える。" - }, - "gMaxBefuddle": { - "name": "キョダイコワク", - "effect": "キョダイマックスした バタフリーが 繰り出す むしタイプの 攻撃。 毒・まひ・眠りの どれかに する。" - }, - "gMaxVoltCrash": { - "name": "キョダイバンライ", - "effect": "キョダイマックスした ピカチュウが 繰りだす でんきタイプの 攻撃。 相手を まひ状態に する。" - }, - "gMaxGoldRush": { - "name": "キョダイコバン", - "effect": "キョダイマックスした ニャースが 繰り出す ノーマルタイプの 攻撃。 相手を 混乱させ お金も もらえる。" - }, - "gMaxChiStrike": { - "name": "キョダイシンゲキ", - "effect": "キョダイマックスした カイリキーが 繰りだす かくとうタイプの 攻撃。 急所に 当たりやすく なる。" - }, - "gMaxTerror": { - "name": "キョダイゲンエイ", - "effect": "キョダイマックスした ゲンガーが 繰りだす ゴーストタイプの 攻撃。 影を 踏み 交代 できなくする。" - }, - "gMaxResonance": { - "name": "キョダイセンリツ", - "effect": "キョダイマックスした ラプラスが 繰りだす こおりタイプの 攻撃。 5ターンの 間 ダメージを 弱める。" - }, - "gMaxCuddle": { - "name": "キョダイホーヨー", - "effect": "キョダイマックスした イーブイが 繰りだす ノーマルタイプの 攻撃。 相手を メロメロに する。" - }, - "gMaxReplenish": { - "name": "キョダイサイセイ", - "effect": "キョダイマックスした カビゴンが 繰りだす ノーマルタイプの 攻撃。 食べた きのみを 再生する。" - }, - "gMaxMalodor": { - "name": "キョダイシュウキ", - "effect": "キョダイマックスした ダストダスが 繰りだす どくタイプの 攻撃。 相手を 毒 状態に する。" - }, - "gMaxStonesurge": { - "name": "キョダイガンジン", - "effect": "キョダイマックスした カジリガメが 繰りだす みずタイプの 攻撃。 鋭い 無数の 岩を ばらまく。" - }, - "gMaxWindRage": { - "name": "キョダイフウゲキ", - "effect": "キョダイマックスした アーマーガアが 繰りだす ひこうタイプの 攻撃。 リフレクターや ひかりのかべを 消し去る。" - }, - "gMaxStunShock": { - "name": "キョダイカンデン", - "effect": "キョダイマックスした ストリンダーが 繰り出す でんきタイプの 攻撃。 相手を 毒 か まひ どちらかにする。" - }, - "gMaxFinale": { - "name": "キョダイダンエン", - "effect": "キョダイマックスした マホイップが 繰りだす フェアリータイプの 攻撃。 味方の HPを 回復する。" - }, - "gMaxDepletion": { - "name": "キョダイゲンスイ", - "effect": "キョダイマックスした ジュラルドンが 繰りだす ドラゴンタイプの 攻撃。 最後に 使われた わざPPを 減らす。" - }, - "gMaxGravitas": { - "name": "キョダイテンドウ", - "effect": "キョダイマックスした イオルブが 繰りだす エスパータイプの 攻撃。 5ターンの 間 重力が 変わる。" - }, - "gMaxVolcalith": { - "name": "キョダイフンセキ", - "effect": "キョダイマックスした セキタンザンが 繰りだす いわタイプの 攻撃。 4ターンの 間 ダメージを 与える。" - }, - "gMaxSandblast": { - "name": "キョダイサジン", - "effect": "キョダイマックスした サダイジャが 繰りだす じめんタイプの 攻撃。 4-5ターンの間 砂が 吹き荒れる。" - }, - "gMaxSnooze": { - "name": "キョダイスイマ", - "effect": "キョダイマックスした オーロンゲが 繰りだす あくタイプの 攻撃。 大きな あくびで 眠気を 誘う。" - }, - "gMaxTartness": { - "name": "キョダイサンゲキ", - "effect": "キョダイマックスした アップリューが 繰りだす くさタイプの 攻撃。 相手の 回避率を 下げる。" - }, - "gMaxSweetness": { - "name": "キョダイカンロ", - "effect": "キョダイマックスした タルップルが 繰りだす くさタイプの 攻撃。 味方の 状態異常を 回復する。" - }, - "gMaxSmite": { - "name": "キョダイテンバツ", - "effect": "キョダイマックスした ブリムオンが 繰りだす フェアリータイプの 攻撃。 相手を 混乱させる。" - }, - "gMaxSteelsurge": { - "name": "キョダイコウジン", - "effect": "キョダイマックスした ダイオウドウが 繰りだす タイプの 攻撃。 鋭い 無数の とげを ばらまく。" - }, - "gMaxMeltdown": { - "name": "キョダイユウゲキ", - "effect": "キョダイマックスした メルメタルが 繰りだす はがねタイプの 攻撃。 同じ 技を 連続で 出せなくする。" - }, - "gMaxFoamBurst": { - "name": "キョダイホウマツ", - "effect": "キョダイマックスした キングラーが 繰りだす みずタイプの 攻撃。 相手の 素早さを がくっと さげる。" - }, - "gMaxCentiferno": { - "name": "キョダイヒャッカ", - "effect": "キョダイマックスした マルヤクデが 繰りだす ほのおタイプの 攻撃。 4-5ターンの間 炎に 閉じこめる。" - }, - "gMaxVineLash": { - "name": "キョダイベンタツ", - "effect": "キョダイマックスした フシギバナが 繰りだす くさタイプの 攻撃。 4ターンの 間 ダメージを 与える。" - }, - "gMaxCannonade": { - "name": "キョダイホウゲキ", - "effect": "キョダイマックスした カメックスが 繰りだす みずタイプの 攻撃。 4ターンの 間 ダメージを 与える。" - }, - "gMaxDrumSolo": { - "name": "キョダイコランダ", - "effect": "キョダイマックスした ゴリランダーが 繰りだす くさタイプの 攻撃。 相手の 特性に ジャマされない。" - }, - "gMaxFireball": { - "name": "キョダイカキュウ", - "effect": "キョダイマックスした エースバーンが 繰りだす ほのおタイプの 攻撃。 相手の 特性に ジャマされない。" - }, - "gMaxHydrosnipe": { - "name": "キョダイソゲキ", - "effect": "キョダイマックスした インテレオンが 繰りだす みずタイプの 攻撃。 相手の 特性に ジャマされない。" - }, - "gMaxOneBlow": { - "name": "キョダイイチゲキ", - "effect": "キョダイマックスした ウーラオスが 繰りだす あくタイプの 攻撃。 ダイウォールを 無視できる 一撃。" - }, - "gMaxRapidFlow": { - "name": "キョダイレンゲキ", - "effect": "キョダイマックスした ウーラオスが 繰りだす みずタイプの 攻撃。 ダイウォールを 無視できる 連撃。" - }, - "teraBlast": { - "name": "テラバースト", - "effect": "テラスタルだと テラスタイプの エネルギーを 放出して 攻撃する。 攻撃と 特攻を 比べて 高いほうで ダメージを 与える。" - }, - "silkTrap": { - "name": "スレッドトラップ", - "effect": "糸の罠を はりめぐらせる。 相手の 攻撃を 防ぐと 同時に 触れた 相手の 素早さを さげる。" - }, - "axeKick": { - "name": "かかとおとし", - "effect": "蹴りあげた かかとを 落として 攻撃する。 相手を 混乱させることが ある。 はずすと 自分が ダメージを 受ける。" - }, - "lastRespects": { - "name": "おはかまいり", - "effect": "仲間の 無念を 晴らすため 攻撃する。 倒された 味方のポケモンが 多いほど 技の 威力が 増える。" - }, - "luminaCrash": { - "name": "ルミナコリジョン", - "effect": "精神にも 作用する 奇妙な光を 放って 攻撃する。 相手の 特防を がくっと さげる。" - }, - "orderUp": { - "name": "いっちょうあがり", - "effect": "いなせな 身のこなしで 攻撃。 口の中に シャリタツが いると そのすがたによって 能力が あがる。" - }, - "jetPunch": { - "name": "ジェットパンチ", - "effect": "激流を こぶしに まとって 目にも 留まらぬ パンチを くりだす。 必ず 先制攻撃 できる。" - }, - "spicyExtract": { - "name": "ハバネロエキス", - "effect": "とんでもなく 辛いエキスを 出す。 相手の 攻撃が ぐーんと あがり 防御が がくっと さがる。" - }, - "spinOut": { - "name": "ホイールスピン", - "effect": "足に 負荷を かけることにより 激しく 回転して ダメージを 与える。 自分の 素早さが がくっと さがる。" - }, - "populationBomb": { - "name": "ネズミざん", - "effect": "仲間たちが わらわらと 集まって コンビネーションで 攻撃を 与えていく。 1-10回の 間 連続で あたる。" - }, - "iceSpinner": { - "name": "アイススピナー", - "effect": "足に 薄い氷を まとい クルクルと 回りながら ぶつかる。 回転の 動きによって フィールドを 壊す。" - }, - "glaiveRush": { - "name": "きょけんとつげき", - "effect": "体を 投げだす 無謀な突撃。 技のあと 相手からの 攻撃は 必ず 命中し ダメージが 2倍に なってしまう。" - }, - "revivalBlessing": { - "name": "さいきのいのり", - "effect": "慈愛の心で いのることにより 控えにいる ひんしの ポケモンを HPを 半分の状態で 復活させる。" - }, - "saltCure": { - "name": "しおづけ", - "effect": "相手を しおづけ状態に して 毎ターン ダメージを 与える。 はがね みずタイプは より 苦しむ。" - }, - "tripleDive": { - "name": "トリプルダイブ", - "effect": "息のあった 飛びこみを することで 相手に 水しぶきを あてる。 3回連続で ダメージを 与える。" - }, - "mortalSpin": { - "name": "キラースピン", - "effect": "回転して 相手を 攻撃する。 しめつける まきつく やどりぎのタネ など 吹きとばす。 相手を 毒状態に する。" - }, - "doodle": { - "name": "うつしえ", - "effect": "相手の本質を とらえて うつしだし 自分と 味方を 相手と 同じ 特性に 変化させる。" - }, - "filletAway": { - "name": "みをけずる", - "effect": "自分の HPを けずって 自分の 攻撃と 特攻と 素早さを ぐーんと あげる。" - }, - "kowtowCleave": { - "name": "ドゲザン", - "effect": "土下座して 相手を 油断させておいて 切りかかる。 攻撃は 必ず 命中する。" - }, - "flowerTrick": { - "name": "トリックフラワー", - "effect": "細工がある 花たばを 相手に 投げて 攻撃する。 必ず 命中して 急所にも 当たる。" - }, - "torchSong": { - "name": "フレアソング", - "effect": "燃えたぎる 火炎を 歌うように 吹きつけて 相手を 焦がす。 自分の 特攻を あげる。" - }, - "aquaStep": { - "name": "アクアステップ", - "effect": "水もしたたる かろやかな 足どりで 相手を 翻弄し ダメージを 与える。 自分の 素早さを あげる。" - }, - "ragingBull": { - "name": "レイジングブル", - "effect": "怒り狂う あばれうしの 猛烈な タックル。 フォルムで 技のタイプが 変わり ひかりのかべや リフレクターなども 破壊できる。" - }, - "makeItRain": { - "name": "ゴールドラッシュ", - "effect": "大量のコインを ぶちまけて 攻撃。 自分の 特攻が さがる。 戦闘の あとで お金も もらえる。" - }, - "psyblade": { - "name": "サイコブレイド", - "effect": "実体のない刃で 相手を 切り裂く。 エレキフィールドに いるとき 技の威力が 1.5倍に なる。" - }, - "hydroSteam": { - "name": "ハイドロスチーム", - "effect": "煮えたぎる水を 勢いよく 浴びせる。 日差しが 強いとき 技の威力が さがるどころか 1.5倍になる。" - }, - "ruination": { - "name": "カタストロフィ", - "effect": "破滅的な 災厄を 巻き起こし 相手の HPを 半分に する。" - }, - "collisionCourse": { - "name": "アクセルブレイク", - "effect": "変形しながら 荒々しく 落下し いにしえの 大爆発を 引き起こす。 弱点をつくと さらに 威力が 増す。" - }, - "electroDrift": { - "name": "イナズマドライブ", - "effect": "変形しながら 超高速で 走行し 未知なる 電撃が 相手を つらぬく。 弱点をつくと さらに 威力が 増す。" - }, - "shedTail": { - "name": "しっぽきり", - "effect": "自分の HPを 削って 分身を だしたあと もどってきて 控えの ポケモンと 入れ替わる。" - }, - "chillyReception": { - "name": "さむいギャグ", - "effect": "場を 凍らせる ギャグを 言い残し 控えの ポケモンと 入れ替わる。 5ターンの 間 ゆきを 降らす。" - }, - "tidyUp": { - "name": "おかたづけ", - "effect": "まきびし ステルスロック ねばねばネット どくびし みがわりを すべて かたづける。 自分の 攻撃と 素早さが あがる。" - }, - "snowscape": { - "name": "ゆきげしき", - "effect": "5ターンの 間 ゆきを 降らせる。 こおりタイプの 防御が あがる。" - }, - "pounce": { - "name": "とびつく", - "effect": "相手に 飛びついて 攻撃する。 相手の 素早さを さげる。" - }, - "trailblaze": { - "name": "くさわけ", - "effect": "草むらから 飛びだすように 攻撃する。 軽快な 足どりに よって 自分の 素早さを あげる。" - }, - "chillingWater": { - "name": "ひやみず", - "effect": "相手の 元気を 失わせるくらい 冷たい水を 浴びせて 攻撃する。 相手の 攻撃を さげる。" - }, - "hyperDrill": { - "name": "ハイパードリル", - "effect": "とがった 体の部位を 急速に 回転させ つらぬく。 まもるや みきり なども 無視 できる。" - }, - "twinBeam": { - "name": "ツインビーム", - "effect": "両目から 不可思議な 光線を 発射して 攻撃する。 2回連続で ダメージを 与える。" - }, - "rageFist": { - "name": "ふんどのこぶし", - "effect": "怒りを エネルギーに 変えて 攻撃。 受けた 攻撃の 回数が 多いほど 技の 威力が あがる。" - }, - "armorCannon": { - "name": "アーマーキャノン", - "effect": "みずからの ヨロイを 燃えたぎる 弾として 撃ち出して 攻撃する。 自分の 防御と 特防が さがる。" - }, - "bitterBlade": { - "name": "むねんのつるぎ", - "effect": "この世への 未練を 剣先に こめて 切りつける。 与えた ダメージの 半分の HPを 回復できる。" - }, - "doubleShock": { - "name": "でんこうそうげき", - "effect": "全身の でんきを すべて 放って 大ダメージを 与える。 自分の でんきタイプが なくなる。" - }, - "gigatonHammer": { - "name": "デカハンマー", - "effect": "大きな ハンマーを 体ごと ぶんまわして 攻撃する。 この技は 2回連続で だせない。" - }, - "comeuppance": { - "name": "ほうふく", - "effect": "技を だす前に 最後に 受けた 技の ダメージを 大きくして だした 相手に 返す。" - }, - "aquaCutter": { - "name": "アクアカッター", - "effect": "加圧された 水を 刃のように 噴射して 相手を 切り裂く。 急所に 当たりやすい。" - }, - "blazingTorque": { - "name": "バーンアクセル", - "effect": "メラメラの エンジンを 吹かして 相手に ぶつかる。やけど状態に することが ある。" - }, - "wickedTorque": { - "name": "ダークアクセル", - "effect": "悪意で エンジンを 吹かして 相手に ぶつかる。眠り状態に することが ある。" - }, - "noxiousTorque": { - "name": "ポイズンアクセル", - "effect": "有毒な エンジンを 吹かして 相手に ぶつかる。毒状態に することが ある。" - }, - "combatTorque": { - "name": "ファイトアクセル", - "effect": "力いっぱい エンジンを 吹かして 相手に ぶつかる。まひ状態に することが ある。" - }, - "magicalTorque": { - "name": "マジカルアクセル", - "effect": "幻想的な エンジンを 吹かして 相手に ぶつかる。混乱させることが ある。" - }, - "bloodMoon": { - "name": "ブラッドムーン", - "effect": "血のように 赤い満月から ありったけの 気迫を 撃ちだす。 この技は 2回連続で だせない。" - }, - "matchaGotcha": { - "name": "シャカシャカほう", - "effect": "かきまぜた お茶の 大砲は 与えた ダメージの 半分を 回復して やけど状態に することも ある。" - }, - "syrupBomb": { - "name": "みずあめボム", - "effect": "ねっとりした みずあめを 爆発させ 相手を あめまみれ 状態にして 3ターンの間 素早さを さげ続ける。" - }, - "ivyCudgel": { - "name": "ツタこんぼう", - "effect": "ツタを まきつけた こん棒で なぐる。 かぶっている お面で タイプが 変わる。 急所に 当たりやすい。" - }, - "electroShot": { - "name": "エレクトロビーム", - "effect": "1ターン目に 電気を 集めて 特攻が あがり 2ターン目に 高圧の 電気を 発射する。 天気が 雨のときは すぐに 発射できる。" - }, - "teraStarstorm": { - "name": "テラクラスター", - "effect": "結晶の力を 照射し 敵を 排除する。 テラパゴスが ステラフォルムで 放つと すべての 相手に ダメージを 与える。" - }, - "fickleBeam": { - "name": "きまぐレーザー", - "effect": "光線を 発射して 攻撃する。 ときどき ほかの首も 協力して レーザーを 放ち 威力が 2倍に なる。" - }, - "burningBulwark": { - "name": "かえんのまもり", - "effect": "相手の 攻撃を 超高熱の 体毛で 防ぎ 同時に 触れた 相手に やけどを 与えてしまう。" - }, - "thunderclap": { - "name": "じんらい", - "effect": "相手より 先に 電撃を 浴びせる。 相手が だす技が 攻撃技でないと 失敗する。" - }, - "mightyCleave": { - "name": "パワフルエッジ", - "effect": "頭部に 蓄積した 光で 切断する。 守りを 無視して 攻撃できる。" - }, - "tachyonCutter": { - "name": "タキオンカッター", - "effect": "粒子の刃を たて続けに 発射して 2回連続で ダメージを 与える。 攻撃は 必ず 命中する。" - }, - "hardPress": { - "name": "ハードプレス", - "effect": "腕やハサミで 相手を 圧迫する。 相手の HPが 残っているほど 威力が あがる。" - }, - "dragonCheer": { - "name": "ドラゴンエール", - "effect": "竜の鼓舞で 士気を 上げて 味方の技が 急所に 当たりやすくなる。 ドラゴンタイプだと より 鼓舞される。" - }, - "alluringVoice": { - "name": "みわくのボイス", - "effect": "天使のような 歌声で 相手を 攻撃。 そのターン 能力が あがった ポケモンを 混乱の 状態に する。" - }, - "temperFlare": { - "name": "やけっぱち", - "effect": "自棄になった 勢いで 攻撃する。 前の ターンに 技を 外していると 威力が 倍に なる。" - }, - "supercellSlam": { - "name": "サンダーダイブ", - "effect": "体を 帯電させ て相手に のしかかる。 はずすと 自分が ダメージを 受ける。" - }, - "psychicNoise": { - "name": "サイコノイズ", - "effect": "不快な音波を 相手に 浴びせて 攻撃。 2ターンの間 技や 特性や 持っている 道具によって HPを 回復できなくなる。" - }, - "upperHand": { - "name": "はやてがえし", - "effect": "動きに 反応して 掌底を 打ちこみ 相手を ひるませる。 相手が だす技が 先制攻撃でないと 失敗する。" - }, - "malignantChain": { - "name": "じゃどくのくさり", - "effect": "毒でできた鎖を 相手に 巻きつけ 毒素を 流しこんで 蝕む。 猛毒の 状態に することが ある。" - } -} diff --git a/src/locales/ja/nature.json b/src/locales/ja/nature.json deleted file mode 100644 index 8d7d37b7e74..00000000000 --- a/src/locales/ja/nature.json +++ /dev/null @@ -1,27 +0,0 @@ -{ - "Hardy": "がんばりや", - "Lonely": "さみしがり", - "Brave": "ゆうかん", - "Adamant": "いじっぱり", - "Naughty": "やんちゃ", - "Bold": "ずぶとい", - "Docile": "すなお", - "Relaxed": "のんき", - "Impish": "わんぱく", - "Lax": "のうてんき", - "Timid": "おくびょう", - "Hasty": "せっかち", - "Serious": "まじめ", - "Jolly": "ようき", - "Naive": "むじゃき", - "Modest": "ひかえめ", - "Mild": "おっとり", - "Quiet": "れいせい", - "Bashful": "てれや", - "Rash": "うっかりや", - "Calm": "おだやか", - "Gentle": "おとなしい", - "Sassy": "なまいき", - "Careful": "しんちょう", - "Quirky": "きまぐれ" -} \ No newline at end of file diff --git a/src/locales/ja/party-ui-handler.json b/src/locales/ja/party-ui-handler.json deleted file mode 100644 index 096d8d5bcba..00000000000 --- a/src/locales/ja/party-ui-handler.json +++ /dev/null @@ -1,47 +0,0 @@ -{ - "SEND_OUT": "入れ替える", - "SUMMARY": "強さを見る", - "CANCEL": "やめる", - "RELEASE": "逃がす", - "APPLY": "使う", - "TEACH": "教える", - "SPLICE": "吸収合体", - "UNSPLICE": "合体を分離", - "ACTIVATE": "有効にする", - "DEACTIVATE": "無効にする", - "TRANSFER": "アイテムを移動", - "ALL": "全部", - "PASS_BATON": "バトンタッチ", - "UNPAUSE_EVOLUTION": "進化を有効にする", - "REVIVE": "復活する", - "RENAME": "名前を変える", - "choosePokemon": "ポケモンを 選んで ください。", - "doWhatWithThisPokemon": "このポケモンを どうする?", - "noEnergy": "{{pokemonName}}は 戦うための\n元気が 残っていません!", - "hasEnergy": "{{pokemonName}}は まだまだ 元気だ!", - "cantBeUsed": "{{pokemonName}}は このチャレンジで\n使えられません!", - "tooManyItems": "{{pokemonName}}は このアイテムが\nこれ以上 持ちきれない!", - "anyEffect": "使っても 効果がないよ", - "unpausedEvolutions": "{{pokemonName}}は また 進化できる。", - "unspliceConfirmation": "本当に {{pokemonName}}を {{fusionName}}から\n分離しますか? {{fusionName}}は なくなる。", - "wasReverted": "{{fusionName}}は {{pokemonName}}に 回帰した。", - "releaseConfirmation": "本当に {{pokemonName}}を 逃がしますか?", - "releaseInBattle": "戦闘中の ポケモンを\n逃がすことは できません!", - "selectAMove": "技を 選んでください。", - "changeQuantity": "移動する アイテムを 選んでください。\n< と > で 数量が 変えられる。", - "selectAnotherPokemonToSplice": "もう一つの ポケモンを 選んで 合体する。", - "cancel": "キャンセル", - "able": "可能", - "notAble": "不可能", - "learned": "覚えている", - "goodbye": "グッバイ {{pokemonName}}!", - "byebye": "ばいばい {{pokemonName}}!", - "farewell": "さようなら {{pokemonName}}!", - "soLong": "じゃあね {{pokemonName}}!", - "thisIsWhereWePart": "これでお別れだね {{pokemonName}}!", - "illMissYou": "恋しく思うよ {{pokemonName}}!", - "illNeverForgetYou": "一生忘れない {{pokemonName}}!", - "untilWeMeetAgain": "また出会える日まで、{{pokemonName}}!", - "sayonara": "さらば {{pokemonName}}!", - "smellYaLater": "そんじゃ あばよ {{pokemonName}}!" -} diff --git a/src/locales/ja/pokeball.json b/src/locales/ja/pokeball.json deleted file mode 100644 index 5ed68867460..00000000000 --- a/src/locales/ja/pokeball.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "pokeBall": "モンスターボール", - "greatBall": "スーパーボール", - "ultraBall": "ハイパーボール", - "rogueBall": "ローグボール", - "masterBall": "マスターボール", - "luxuryBall": "ゴージャスボール" -} \ No newline at end of file diff --git a/src/locales/ja/pokemon-form-battle.json b/src/locales/ja/pokemon-form-battle.json deleted file mode 100644 index adbc7b4b3da..00000000000 --- a/src/locales/ja/pokemon-form-battle.json +++ /dev/null @@ -1,14 +0,0 @@ -{ - "mega": "メガ{{pokemonName}}", - "mega-x": "メガ{{pokemonName}}X", - "mega-y": "メガ{{pokemonName}}Y", - "primal": "ゲンシ{{pokemonName}}", - "gigantamax": "キョダイ{{pokemonName}}", - "eternamax": "E・{{pokemonName}}", - "megaChange": "{{preName}}は\nメガ{{pokemonName}}に メガシンカした!", - "gigantamaxChange": "{{preName}}は\nキョダイマックスした!", - "eternamaxChange": "{{preName}}は\nムゲンダイマックスした!", - "revertChange": "{{pokemonName}}は\n元の姿に 戻った!", - "formChange": "{{preName}}は\n姿を 変えた!", - "disguiseChange": "ばけのかわが みがわりに なった!" -} diff --git a/src/locales/ja/pokemon-form.json b/src/locales/ja/pokemon-form.json deleted file mode 100644 index 76124904456..00000000000 --- a/src/locales/ja/pokemon-form.json +++ /dev/null @@ -1,170 +0,0 @@ -{ - "pikachuCosplay": "コスプレ", - "pikachuCoolCosplay": "クールなコスプレ", - "pikachuBeautyCosplay": "きれいなコスプレ", - "pikachuCuteCosplay": "かわいいコスプレ", - "pikachuSmartCosplay": "かしこいコスプレ", - "pikachuToughCosplay": "パワフルなコスプレ", - "pikachuPartner": "パートナー", - "eeveePartner": "パートナー", - "pichuSpiky": "ギザみみ", - "unownA": "A", - "unownB": "B", - "unownC": "C", - "unownD": "D", - "unownE": "E", - "unownF": "F", - "unownG": "G", - "unownH": "H", - "unownI": "I", - "unownJ": "J", - "unownK": "K", - "unownL": "L", - "unownM": "M", - "unownN": "N", - "unownO": "O", - "unownP": "P", - "unownQ": "Q", - "unownR": "R", - "unownS": "S", - "unownT": "T", - "unownU": "U", - "unownV": "V", - "unownW": "W", - "unownX": "X", - "unownY": "Y", - "unownZ": "Z", - "unownExclamation": "!", - "unownQuestion": "?", - "castformSunny": "たいよう", - "castformRainy": "あまみず", - "castformSnowy": "ゆきぐも", - "deoxysNormal": "ノーマル", - "burmyPlant": "くさき", - "burmySandy": "すなち", - "burmyTrash": "ゴミ", - "shellosEast": "ひがし", - "shellosWest": "にし", - "rotomHeat": "ヒート", - "rotomWash": "ウォッシュ", - "rotomFrost": "フロスト", - "rotomFan": "スピン", - "rotomMow": "カット", - "giratinaAltered": "アナザー", - "shayminLand": "ランド", - "basculinRedStriped": "赤筋", - "basculinBlueStriped": "青筋", - "basculinWhiteStriped": "白筋", - "deerlingSpring": "春", - "deerlingSummer": "夏", - "deerlingAutumn": "秋", - "deerlingWinter": "冬", - "tornadusIncarnate": "けしん", - "thundurusIncarnate": "けしん", - "landorusIncarnate": "けしん", - "keldeoOrdinary": "いつも", - "meloettaAria": "ボイス", - "meloettaPirouette": "ステップ", - "froakieBattleBond": "きずなへんげ", - "scatterbugMeadow": "はなぞの", - "scatterbugIcySnow": "ひょうせつ", - "scatterbugPolar": "ゆきぐに", - "scatterbugTundra": "せつげん", - "scatterbugContinental": "たいりく", - "scatterbugGarden": "ていえん", - "scatterbugElegant": "みやび", - "scatterbugModern": "モダン", - "scatterbugMarine": "マリン", - "scatterbugArchipelago": "ぐんとう", - "scatterbugHighPlains": "こうや", - "scatterbugSandstorm": "さじん", - "scatterbugRiver": "たいが", - "scatterbugMonsoon": "スコール", - "scatterbugSavanna": "サバンナ", - "scatterbugSun": "たいよう", - "scatterbugOcean": "オーシャン", - "scatterbugJungle": "ジャングル", - "scatterbugFancy": "ファンシー", - "scatterbugPokeBall": "ボール", - "flabebeRed": "赤", - "flabebeYellow": "黄", - "flabebeOrange": "オレンジ", - "flabebeBlue": "青", - "flabebeWhite": "白", - "furfrouHeart": "ハート", - "furfrouStar": "スター", - "furfrouDiamond": "ダイア", - "furfrouDebutante": "レディ", - "furfrouMatron": "マダム", - "furfrouDandy": "ジェントル", - "furfrouLaReine": "クイーン", - "furfrouKabuki": "カブキ", - "furfrouPharaoh": "キングダム", - "pumpkabooSmall": "ちいさい", - "pumpkabooLarge": "おおきい", - "pumpkabooSuper": "とくだい", - "xerneasNeutral": "リラックス", - "xerneasActive": "アクティブ", - "zygarde50": "50%フォルム", - "zygarde10": "10%フォルム", - "zygarde50Pc": "50%フォルム スワームチェンジ", - "zygarde10Pc": "10%フォルム スワームチェンジ", - "zygardeComplete": "パーフェクトフォルム", - "oricorioBaile": "めらめら", - "oricorioPompom": "ぱちぱち", - "oricorioPau": "ふらふら", - "oricorioSensu": "まいまい", - "rockruffOwnTempo": "マイペース", - "miniorRedMeteor": "赤 りゅうせい", - "miniorOrangeMeteor": "オレンジ りゅうせい", - "miniorYellowMeteor": "黄 りゅうせい", - "miniorGreenMeteor": "緑 りゅうせい", - "miniorBlueMeteor": "水色 りゅうせい", - "miniorIndigoMeteor": "青 りゅうせい", - "miniorVioletMeteor": "紫 りゅうせい", - "miniorRed": "赤", - "miniorOrange": "オレンジ", - "miniorYellow": "黄", - "miniorGreen": "緑", - "miniorBlue": "水色", - "miniorIndigo": "青", - "miniorViolet": "紫", - "mimikyuDisguised": "ばけたすがた", - "mimikyuBusted": "ばれたすがた", - "magearnaOriginal": "500ねんまえ", - "marshadowZenith": "Zパワー", - "sinisteaPhony": "がんさく", - "sinisteaAntique": "しんさく", - "eiscueNoIce": "ナイスなし", - "indeedeeMale": "オス", - "indeedeeFemale": "メス", - "morpekoFullBelly": "まんぷく", - "zacianHeroOfManyBattles": "れきせんのゆうしゃ", - "zamazentaHeroOfManyBattles": "れきせんのゆうしゃ", - "zarudeDada": "とうちゃん", - "enamorusIncarnate": "けしん", - "squawkabillyGreenPlumage": "グリーンフェザー", - "squawkabillyBluePlumage": "ブルーフェザー", - "squawkabillyYellowPlumage": "イエローフェザー", - "squawkabillyWhitePlumage": "ホワイトフェザー", - "tatsugiriCurly": "そったすがた", - "tatsugiriDroopy": "たれたすがた", - "tatsugiriStretchy": "のびたすがた", - "gimmighoulChest": "はこ", - "gimmighoulRoaming": "とほ", - "koraidonApexBuild": "かんぜんけいたい", - "koraidonLimitedBuild":"せいげんけいたい", - "koraidonSprintingBuild":"しっそうけいたい", - "koraidonSwimmingBuild":"ゆうえいけいたい", - "koraidonGlidingBuild":"かっくうけいたい", - "miraidonUltimateMode":"コンプリートモード", - "miraidonLowPowerMode":"リミテッドモード", - "miraidonDriveMode":"ドライブモード", - "miraidonAquaticMode":"フロートモード", - "miraidonGlideMode":"グライドモード", - "poltchageistCounterfeit": "マガイモノ", - "poltchageistArtisan": "タカイモノ", - "paldeaTaurosCombat": "コンバット", - "paldeaTaurosBlaze": "ブレイズ", - "paldeaTaurosAqua": "ウォーター" -} \ No newline at end of file diff --git a/src/locales/ja/pokemon-info-container.json b/src/locales/ja/pokemon-info-container.json deleted file mode 100644 index 287eed23c74..00000000000 --- a/src/locales/ja/pokemon-info-container.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "moveset": "技", - "gender": "性別:", - "ability": "特性:", - "nature": "性格:", - "form": "姿:" -} diff --git a/src/locales/ja/pokemon-info.json b/src/locales/ja/pokemon-info.json deleted file mode 100644 index 456b4949839..00000000000 --- a/src/locales/ja/pokemon-info.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "Stat": { - "HP": "HP", - "HPshortened": "HP", - "ATK": "攻撃", - "ATKshortened": "攻撃", - "DEF": "防御", - "DEFshortened": "防御", - "SPATK": "特攻", - "SPATKshortened": "特攻", - "SPDEF": "特防", - "SPDEFshortened": "特防", - "SPD": "素早さ", - "SPDshortened": "素早さ", - "ACC": "命中", - "EVA": "回避", - "HPStat": "HP" - }, - "Type": { - "UNKNOWN": "???", - "NORMAL": "ノーマル", - "FIGHTING": "かくとう", - "FLYING": "ひこう", - "POISON": "どく", - "GROUND": "じめん", - "ROCK": "いわ", - "BUG": "むし", - "GHOST": "ゴースト", - "STEEL": "はがね", - "FIRE": "ほのお", - "WATER": "みず", - "GRASS": "くさ", - "ELECTRIC": "でんき", - "PSYCHIC": "エスパー", - "ICE": "こおり", - "DRAGON": "ドラゴン", - "DARK": "あく", - "FAIRY": "フェアリー", - "STELLAR": "ステラ" - } -} diff --git a/src/locales/ja/pokemon-summary.json b/src/locales/ja/pokemon-summary.json deleted file mode 100644 index 9465bcd346d..00000000000 --- a/src/locales/ja/pokemon-summary.json +++ /dev/null @@ -1,44 +0,0 @@ -{ - "pokemonInfo": "ポケモン情報", - "status": "ステータス", - "powerAccuracyCategory": "威力\n命中\n分類", - "type": "タイプ", - "unknownTrainer": "???", - "ot": "親", - "nature": "性格", - "expPoints": "経験値", - "nextLv": "次のレベルまで", - "cancel": "キャンセル", - "memoString": "{{natureFragment}}な性格。\n{{metFragment}}", - "metFragment": { - "normal": "ラウンド{{wave}}に{{biome}}で\nLv.{{level}}の時に出会った。", - "apparently": "{{biome}}で\nLv.{{level}}の時に出会ったようだ。" - }, - "natureFragment": { - "Hardy": "{{nature}}", - "Lonely": "{{nature}}", - "Brave": "{{nature}}", - "Adamant": "{{nature}}", - "Naughty": "{{nature}}", - "Bold": "{{nature}}", - "Docile": "{{nature}}", - "Relaxed": "{{nature}}", - "Impish": "{{nature}}", - "Lax": "{{nature}}", - "Timid": "{{nature}}", - "Hasty": "{{nature}}", - "Serious": "{{nature}}", - "Jolly": "{{nature}}", - "Naive": "{{nature}}", - "Modest": "{{nature}}", - "Mild": "{{nature}}", - "Quiet": "{{nature}}", - "Bashful": "{{nature}}", - "Rash": "{{nature}}", - "Calm": "{{nature}}", - "Gentle": "{{nature}}", - "Sassy": "{{nature}}", - "Careful": "{{nature}}", - "Quirky": "{{nature}}" - } -} diff --git a/src/locales/ja/pokemon.json b/src/locales/ja/pokemon.json deleted file mode 100644 index e6fcd02a750..00000000000 --- a/src/locales/ja/pokemon.json +++ /dev/null @@ -1,1084 +0,0 @@ -{ - "bulbasaur": "フシギダネ", - "ivysaur": "フシギソウ", - "venusaur": "フシギバナ", - "charmander": "ヒトカゲ", - "charmeleon": "リザード", - "charizard": "リザードン", - "squirtle": "ゼニガメ", - "wartortle": "カメール", - "blastoise": "カメックス", - "caterpie": "キャタピー", - "metapod": "トランセル", - "butterfree": "バタフリー", - "weedle": "ビードル", - "kakuna": "コクーン", - "beedrill": "スピアー", - "pidgey": "ポッポ", - "pidgeotto": "ピジョン", - "pidgeot": "ピジョット", - "rattata": "コラッタ", - "raticate": "ラッタ", - "spearow": "オニスズメ", - "fearow": "オニドリル", - "ekans": "アーボ", - "arbok": "アーボック", - "pikachu": "ピカチュウ", - "raichu": "ライチュウ", - "sandshrew": "サンド", - "sandslash": "サンドパン", - "nidoran_f": "ニドラン♀", - "nidorina": "ニドリーナ", - "nidoqueen": "ニドクイン", - "nidoran_m": "ニドラン♂", - "nidorino": "ニドリーノ", - "nidoking": "ニドキング", - "clefairy": "ピッピ", - "clefable": "ピクシー", - "vulpix": "ロコン", - "ninetales": "キュウコン", - "jigglypuff": "プリン", - "wigglytuff": "プクリン", - "zubat": "ズバット", - "golbat": "ゴルバット", - "oddish": "ナゾノクサ", - "gloom": "クサイハナ", - "vileplume": "ラフレシア", - "paras": "パラス", - "parasect": "パラセクト", - "venonat": "コンパン", - "venomoth": "モルフォン", - "diglett": "ディグダ", - "dugtrio": "ダグトリオ", - "meowth": "ニャース", - "persian": "ペルシアン", - "psyduck": "コダック", - "golduck": "ゴルダック", - "mankey": "マンキー", - "primeape": "オコリザル", - "growlithe": "ガーディ", - "arcanine": "ウインディ", - "poliwag": "ニョロモ", - "poliwhirl": "ニョロゾ", - "poliwrath": "ニョロボン", - "abra": "ケーシィ", - "kadabra": "ユンゲラー", - "alakazam": "フーディン", - "machop": "ワンリキー", - "machoke": "ゴーリキー", - "machamp": "カイリキー", - "bellsprout": "マダツボミ", - "weepinbell": "ウツドン", - "victreebel": "ウツボット", - "tentacool": "メノクラゲ", - "tentacruel": "ドククラゲ", - "geodude": "イシツブテ", - "graveler": "ゴローン", - "golem": "ゴローニャ", - "ponyta": "ポニータ", - "rapidash": "ギャロップ", - "slowpoke": "ヤドン", - "slowbro": "ヤドラン", - "magnemite": "コイル", - "magneton": "レアコイル", - "farfetchd": "カモネギ", - "doduo": "ドードー", - "dodrio": "ドードリオ", - "seel": "パウワウ", - "dewgong": "ジュゴン", - "grimer": "ベトベター", - "muk": "ベトベトン", - "shellder": "シェルダー", - "cloyster": "パルシェン", - "gastly": "ゴース", - "haunter": "ゴースト", - "gengar": "ゲンガー", - "onix": "イワーク", - "drowzee": "スリープ", - "hypno": "スリーパー", - "krabby": "クラブ", - "kingler": "キングラー", - "voltorb": "ビリリダマ", - "electrode": "マルマイン", - "exeggcute": "タマタマ", - "exeggutor": "ナッシー", - "cubone": "カラカラ", - "marowak": "ガラガラ", - "hitmonlee": "サワムラー", - "hitmonchan": "エビワラー", - "lickitung": "ベロリンガ", - "koffing": "ドガース", - "weezing": "マタドガス", - "rhyhorn": "サイホーン", - "rhydon": "サイドン", - "chansey": "ラッキー", - "tangela": "モンジャラ", - "kangaskhan": "ガルーラ", - "horsea": "タッツー", - "seadra": "シードラ", - "goldeen": "トサキント", - "seaking": "アズマオウ", - "staryu": "ヒトデマン", - "starmie": "スターミー", - "mr_mime": "バリヤード", - "scyther": "ストライク", - "jynx": "ルージュラ", - "electabuzz": "エレブー", - "magmar": "ブーバー", - "pinsir": "カイロス", - "tauros": "ケンタロス", - "magikarp": "コイキング", - "gyarados": "ギャラドス", - "lapras": "ラプラス", - "ditto": "メタモン", - "eevee": "イーブイ", - "vaporeon": "シャワーズ", - "jolteon": "サンダース", - "flareon": "ブースター", - "porygon": "ポリゴン", - "omanyte": "オムナイト", - "omastar": "オムスター", - "kabuto": "カブト", - "kabutops": "カブトプス", - "aerodactyl": "プテラ", - "snorlax": "カビゴン", - "articuno": "フリーザー", - "zapdos": "サンダー", - "moltres": "ファイヤー", - "dratini": "ミニリュウ", - "dragonair": "ハクリュー", - "dragonite": "カイリュー", - "mewtwo": "ミュウツー", - "mew": "ミュウ", - "chikorita": "チコリータ", - "bayleef": "ベイリーフ", - "meganium": "メガニウム", - "cyndaquil": "ヒノアラシ", - "quilava": "マグマラシ", - "typhlosion": "バクフーン", - "totodile": "ワニノコ", - "croconaw": "アリゲイツ", - "feraligatr": "オーダイル", - "sentret": "オタチ", - "furret": "オオタチ", - "hoothoot": "ホーホー", - "noctowl": "ヨルノズク", - "ledyba": "レディバ", - "ledian": "レディアン", - "spinarak": "イトマル", - "ariados": "アリアドス", - "crobat": "クロバット", - "chinchou": "チョンチー", - "lanturn": "ランターン", - "pichu": "ピチュー", - "cleffa": "ピィ", - "igglybuff": "ププリン", - "togepi": "トゲピー", - "togetic": "トゲチック", - "natu": "ネイティ", - "xatu": "ネイティオ", - "mareep": "メリープ", - "flaaffy": "モココ", - "ampharos": "デンリュウ", - "bellossom": "キレイハナ", - "marill": "マリル", - "azumarill": "マリルリ", - "sudowoodo": "ウソッキー", - "politoed": "ニョロトノ", - "hoppip": "ハネッコ", - "skiploom": "ポポッコ", - "jumpluff": "ワタッコ", - "aipom": "エイパム", - "sunkern": "ヒマナッツ", - "sunflora": "キマワリ", - "yanma": "ヤンヤンマ", - "wooper": "ウパー", - "quagsire": "ヌオー", - "espeon": "エーフィ", - "umbreon": "ブラッキー", - "murkrow": "ヤミカラス", - "slowking": "ヤドキング", - "misdreavus": "ムウマ", - "unown": "アンノーン", - "wobbuffet": "ソーナンス", - "girafarig": "キリンリキ", - "pineco": "クヌギダマ", - "forretress": "フォレトス", - "dunsparce": "ノコッチ", - "gligar": "グライガー", - "steelix": "ハガネール", - "snubbull": "ブルー", - "granbull": "グランブル", - "qwilfish": "ハリーセン", - "scizor": "ハッサム", - "shuckle": "ツボツボ", - "heracross": "ヘラクロス", - "sneasel": "ニューラ", - "teddiursa": "ヒメグマ", - "ursaring": "リングマ", - "slugma": "マグマッグ", - "magcargo": "マグカルゴ", - "swinub": "ウリムー", - "piloswine": "イノムー", - "corsola": "サニーゴ", - "remoraid": "テッポウオ", - "octillery": "オクタン", - "delibird": "デリバード", - "mantine": "マンタイン", - "skarmory": "エアームド", - "houndour": "デルビル", - "houndoom": "ヘルガー", - "kingdra": "キングドラ", - "phanpy": "ゴマゾウ", - "donphan": "ドンファン", - "porygon2": "ポリゴン2", - "stantler": "オドシシ", - "smeargle": "ドーブル", - "tyrogue": "バルキー", - "hitmontop": "カポエラー", - "smoochum": "ムチュール", - "elekid": "エレキッド", - "magby": "ブビィ", - "miltank": "ミルタンク", - "blissey": "ハピナス", - "raikou": "ライコウ", - "entei": "エンテイ", - "suicune": "スイクン", - "larvitar": "ヨーギラス", - "pupitar": "サナギラス", - "tyranitar": "バンギラス", - "lugia": "ルギア", - "ho_oh": "ホウオウ", - "celebi": "セレビィ", - "treecko": "キモリ", - "grovyle": "ジュプトル", - "sceptile": "ジュカイン", - "torchic": "アチャモ", - "combusken": "ワカシャモ", - "blaziken": "バシャーモ", - "mudkip": "ミズゴロウ", - "marshtomp": "ヌマクロー", - "swampert": "ラグラージ", - "poochyena": "ポチエナ", - "mightyena": "グラエナ", - "zigzagoon": "ジグザグマ", - "linoone": "マッスグマ", - "wurmple": "ケムッソ", - "silcoon": "カラサリス", - "beautifly": "アゲハント", - "cascoon": "マユルド", - "dustox": "ドクケイル", - "lotad": "ハスボー", - "lombre": "ハスブレロ", - "ludicolo": "ルンパッパ", - "seedot": "タネボー", - "nuzleaf": "コノハナ", - "shiftry": "ダーテング", - "taillow": "スバメ", - "swellow": "オオスバメ", - "wingull": "キャモメ", - "pelipper": "ペリッパー", - "ralts": "ラルトス", - "kirlia": "キルリア", - "gardevoir": "サーナイト", - "surskit": "アメタマ", - "masquerain": "アメモース", - "shroomish": "キノココ", - "breloom": "キノガッサ", - "slakoth": "ナマケロ", - "vigoroth": "ヤルキモノ", - "slaking": "ケッキング", - "nincada": "ツチニン", - "ninjask": "テッカニン", - "shedinja": "ヌケニン", - "whismur": "ゴニョニョ", - "loudred": "ドゴーム", - "exploud": "バクオング", - "makuhita": "マクノシタ", - "hariyama": "ハリテヤマ", - "azurill": "ルリリ", - "nosepass": "ノズパス", - "skitty": "エネコ", - "delcatty": "エネコロロ", - "sableye": "ヤミラミ", - "mawile": "クチート", - "aron": "ココドラ", - "lairon": "コドラ", - "aggron": "ボスゴドラ", - "meditite": "アサナン", - "medicham": "チャーレム", - "electrike": "ラクライ", - "manectric": "ライボルト", - "plusle": "プラスル", - "minun": "マイナン", - "volbeat": "バルビート", - "illumise": "イルミーゼ", - "roselia": "ロゼリア", - "gulpin": "ゴクリン", - "swalot": "マルノーム", - "carvanha": "キバニア", - "sharpedo": "サメハダー", - "wailmer": "ホエルコ", - "wailord": "ホエルオー", - "numel": "ドンメル", - "camerupt": "バクーダ", - "torkoal": "コータス", - "spoink": "バネブー", - "grumpig": "ブーピッグ", - "spinda": "パッチール", - "trapinch": "ナックラー", - "vibrava": "ビブラーバ", - "flygon": "フライゴン", - "cacnea": "サボネア", - "cacturne": "ノクタス", - "swablu": "チルット", - "altaria": "チルタリス", - "zangoose": "ザングース", - "seviper": "ハブネーク", - "lunatone": "ルナトーン", - "solrock": "ソルロック", - "barboach": "ドジョッチ", - "whiscash": "ナマズン", - "corphish": "ヘイガニ", - "crawdaunt": "シザリガー", - "baltoy": "ヤジロン", - "claydol": "ネンドール", - "lileep": "リリーラ", - "cradily": "ユレイドル", - "anorith": "アノプス", - "armaldo": "アーマルド", - "feebas": "ヒンバス", - "milotic": "ミロカロス", - "castform": "ポワルン", - "kecleon": "カクレオン", - "shuppet": "カゲボウズ", - "banette": "ジュペッタ", - "duskull": "ヨマワル", - "dusclops": "サマヨール", - "tropius": "トロピウス", - "chimecho": "チリーン", - "absol": "アブソル", - "wynaut": "ソーナノ", - "snorunt": "ユキワラシ", - "glalie": "オニゴーリ", - "spheal": "タマザラシ", - "sealeo": "トドグラー", - "walrein": "トドゼルガ", - "clamperl": "パールル", - "huntail": "ハンテール", - "gorebyss": "サクラビス", - "relicanth": "ジーランス", - "luvdisc": "ラブカス", - "bagon": "タツベイ", - "shelgon": "コモルー", - "salamence": "ボーマンダ", - "beldum": "ダンバル", - "metang": "メタング", - "metagross": "メタグロス", - "regirock": "レジロック", - "regice": "レジアイス", - "registeel": "レジスチル", - "latias": "ラティアス", - "latios": "ラティオス", - "kyogre": "カイオーガ", - "groudon": "グラードン", - "rayquaza": "レックウザ", - "jirachi": "ジラーチ", - "deoxys": "デオキシス", - "turtwig": "ナエトル", - "grotle": "ハヤシガメ", - "torterra": "ドダイトス", - "chimchar": "ヒコザル", - "monferno": "モウカザル", - "infernape": "ゴウカザル", - "piplup": "ポッチャマ", - "prinplup": "ポッタイシ", - "empoleon": "エンペルト", - "starly": "ムックル", - "staravia": "ムクバード", - "staraptor": "ムクホーク", - "bidoof": "ビッパ", - "bibarel": "ビーダル", - "kricketot": "コロボーシ", - "kricketune": "コロトック", - "shinx": "コリンク", - "luxio": "ルクシオ", - "luxray": "レントラー", - "budew": "スボミー", - "roserade": "ロズレイド", - "cranidos": "ズガイドス", - "rampardos": "ラムパルド", - "shieldon": "タテトプス", - "bastiodon": "トリデプス", - "burmy": "ミノムッチ", - "wormadam": "ミノマダム", - "mothim": "ガーメイル", - "combee": "ミツハニー", - "vespiquen": "ビークイン", - "pachirisu": "パチリス", - "buizel": "ブイゼル", - "floatzel": "フローゼル", - "cherubi": "チェリンボ", - "cherrim": "チェリム", - "shellos": "カラナクシ", - "gastrodon": "トリトドン", - "ambipom": "エテボース", - "drifloon": "フワンテ", - "drifblim": "フワライド", - "buneary": "ミミロル", - "lopunny": "ミミロップ", - "mismagius": "ムウマージ", - "honchkrow": "ドンカラス", - "glameow": "ニャルマー", - "purugly": "ブニャット", - "chingling": "リーシャン", - "stunky": "スカンプー", - "skuntank": "スカタンク", - "bronzor": "ドーミラー", - "bronzong": "ドータクン", - "bonsly": "ウソハチ", - "mime_jr": "マネネ", - "happiny": "ピンプク", - "chatot": "ペラップ", - "spiritomb": "ミカルゲ", - "gible": "フカマル", - "gabite": "ガバイト", - "garchomp": "ガブリアス", - "munchlax": "ゴンベ", - "riolu": "リオル", - "lucario": "ルカリオ", - "hippopotas": "ヒポポタス", - "hippowdon": "カバルドン", - "skorupi": "スコルピ", - "drapion": "ドラピオン", - "croagunk": "グレッグル", - "toxicroak": "ドクロッグ", - "carnivine": "マスキッパ", - "finneon": "ケイコウオ", - "lumineon": "ネオラント", - "mantyke": "タマンタ", - "snover": "ユキカブリ", - "abomasnow": "ユキノオー", - "weavile": "マニューラ", - "magnezone": "ジバコイル", - "lickilicky": "ベロベルト", - "rhyperior": "ドサイドン", - "tangrowth": "モジャンボ", - "electivire": "エレキブル", - "magmortar": "ブーバーン", - "togekiss": "トゲキッス", - "yanmega": "メガヤンマ", - "leafeon": "リーフィア", - "glaceon": "グレイシア", - "gliscor": "グライオン", - "mamoswine": "マンムー", - "porygon_z": "ポリゴンZ", - "gallade": "エルレイド", - "probopass": "ダイノーズ", - "dusknoir": "ヨノワール", - "froslass": "ユキメノコ", - "rotom": "ロトム", - "uxie": "ユクシー", - "mesprit": "エムリット", - "azelf": "アグノム", - "dialga": "ディアルガ", - "palkia": "パルキア", - "heatran": "ヒードラン", - "regigigas": "レジギガス", - "giratina": "ギラティナ", - "cresselia": "クレセリア", - "phione": "フィオネ", - "manaphy": "マナフィ", - "darkrai": "ダークライ", - "shaymin": "シェイミ", - "arceus": "アルセウス", - "victini": "ビクティニ", - "snivy": "ツタージャ", - "servine": "ジャノビー", - "serperior": "ジャローダ", - "tepig": "ポカブ", - "pignite": "チャオブー", - "emboar": "エンブオー", - "oshawott": "ミジュマル", - "dewott": "フタチマル", - "samurott": "ダイケンキ", - "patrat": "ミネズミ", - "watchog": "ミルホッグ", - "lillipup": "ヨーテリー", - "herdier": "ハーデリア", - "stoutland": "ムーランド", - "purrloin": "チョロネコ", - "liepard": "レパルダス", - "pansage": "ヤナップ", - "simisage": "ヤナッキー", - "pansear": "バオップ", - "simisear": "バオッキー", - "panpour": "ヒヤップ", - "simipour": "ヒヤッキー", - "munna": "ムンナ", - "musharna": "ムシャーナ", - "pidove": "マメパト", - "tranquill": "ハトーボー", - "unfezant": "ケンホロウ", - "blitzle": "シママ", - "zebstrika": "ゼブライカ", - "roggenrola": "ダンゴロ", - "boldore": "ガントル", - "gigalith": "ギガイアス", - "woobat": "コロモリ", - "swoobat": "ココロモリ", - "drilbur": "モグリュー", - "excadrill": "ドリュウズ", - "audino": "タブンネ", - "timburr": "ドッコラー", - "gurdurr": "ドテッコツ", - "conkeldurr": "ローブシン", - "tympole": "オタマロ", - "palpitoad": "ガマガル", - "seismitoad": "ガマゲロゲ", - "throh": "ナゲキ", - "sawk": "ダゲキ", - "sewaddle": "クルミル", - "swadloon": "クルマユ", - "leavanny": "ハハコモリ", - "venipede": "フシデ", - "whirlipede": "ホイーガ", - "scolipede": "ペンドラー", - "cottonee": "モンメン", - "whimsicott": "エルフーン", - "petilil": "チュリネ", - "lilligant": "ドレディア", - "basculin": "バスラオ", - "sandile": "メグロコ", - "krokorok": "ワルビル", - "krookodile": "ワルビアル", - "darumaka": "ダルマッカ", - "darmanitan": "ヒヒダルマ", - "maractus": "マラカッチ", - "dwebble": "イシズマイ", - "crustle": "イワパレス", - "scraggy": "ズルッグ", - "scrafty": "ズルズキン", - "sigilyph": "シンボラー", - "yamask": "デスマス", - "cofagrigus": "デスカーン", - "tirtouga": "プロトーガ", - "carracosta": "アバゴーラ", - "archen": "アーケン", - "archeops": "アーケオス", - "trubbish": "ヤブクロン", - "garbodor": "ダストダス", - "zorua": "ゾロア", - "zoroark": "ゾロアーク", - "minccino": "チラーミィ", - "cinccino": "チラチーノ", - "gothita": "ゴチム", - "gothorita": "ゴチミル", - "gothitelle": "ゴチルゼル", - "solosis": "ユニラン", - "duosion": "ダブラン", - "reuniclus": "ランクルス", - "ducklett": "コアルヒー", - "swanna": "スワンナ", - "vanillite": "バニプッチ", - "vanillish": "バニリッチ", - "vanilluxe": "バイバニラ", - "deerling": "シキジカ", - "sawsbuck": "メブキジカ", - "emolga": "エモンガ", - "karrablast": "カブルモ", - "escavalier": "シュバルゴ", - "foongus": "タマゲタケ", - "amoonguss": "モロバレル", - "frillish": "プルリル", - "jellicent": "ブルンゲル", - "alomomola": "ママンボウ", - "joltik": "バチュル", - "galvantula": "デンチュラ", - "ferroseed": "テッシード", - "ferrothorn": "ナットレイ", - "klink": "ギアル", - "klang": "ギギアル", - "klinklang": "ギギギアル", - "tynamo": "シビシラス", - "eelektrik": "シビビール", - "eelektross": "シビルドン", - "elgyem": "リグレー", - "beheeyem": "オーベム", - "litwick": "ヒトモシ", - "lampent": "ランプラー", - "chandelure": "シャンデラ", - "axew": "キバゴ", - "fraxure": "オノンド", - "haxorus": "オノノクス", - "cubchoo": "クマシュン", - "beartic": "ツンベアー", - "cryogonal": "フリージオ", - "shelmet": "チョボマキ", - "accelgor": "アギルダー", - "stunfisk": "マッギョ", - "mienfoo": "コジョフー", - "mienshao": "コジョンド", - "druddigon": "クリムガン", - "golett": "ゴビット", - "golurk": "ゴルーグ", - "pawniard": "コマタナ", - "bisharp": "キリキザン", - "bouffalant": "バッフロン", - "rufflet": "ワシボン", - "braviary": "ウォーグル", - "vullaby": "バルチャイ", - "mandibuzz": "バルジーナ", - "heatmor": "クイタラン", - "durant": "アイアント", - "deino": "モノズ", - "zweilous": "ジヘッド", - "hydreigon": "サザンドラ", - "larvesta": "メラルバ", - "volcarona": "ウルガモス", - "cobalion": "コバルオン", - "terrakion": "テラキオン", - "virizion": "ビリジオン", - "tornadus": "トルネロス", - "thundurus": "ボルトロス", - "reshiram": "レシラム", - "zekrom": "ゼクロム", - "landorus": "ランドロス", - "kyurem": "キュレム", - "keldeo": "ケルディオ", - "meloetta": "メロエッタ", - "genesect": "ゲノセクト", - "chespin": "ハリマロン", - "quilladin": "ハリボーグ", - "chesnaught": "ブリガロン", - "fennekin": "フォッコ", - "braixen": "テールナー", - "delphox": "マフォクシー", - "froakie": "ケロマツ", - "frogadier": "ゲコガシラ", - "greninja": "ゲッコウガ", - "bunnelby": "ホルビー", - "diggersby": "ホルード", - "fletchling": "ヤヤコマ", - "fletchinder": "ヒノヤコマ", - "talonflame": "ファイアロー", - "scatterbug": "コフキムシ", - "spewpa": "コフーライ", - "vivillon": "ビビヨン", - "litleo": "シシコ", - "pyroar": "カエンジシ", - "flabebe": "フラベベ", - "floette": "フラエッテ", - "florges": "フラージェス", - "skiddo": "メェークル", - "gogoat": "ゴーゴート", - "pancham": "ヤンチャム", - "pangoro": "ゴロンダ", - "furfrou": "トリミアン", - "espurr": "ニャスパー", - "meowstic": "ニャオニクス", - "honedge": "ヒトツキ", - "doublade": "ニダンギル", - "aegislash": "ギルガルド", - "spritzee": "シュシュプ", - "aromatisse": "フレフワン", - "swirlix": "ペロッパフ", - "slurpuff": "ペロリーム", - "inkay": "マーイーカ", - "malamar": "カラマネロ", - "binacle": "カメテテ", - "barbaracle": "ガメノデス", - "skrelp": "クズモー", - "dragalge": "ドラミドロ", - "clauncher": "ウデッポウ", - "clawitzer": "ブロスター", - "helioptile": "エリキテル", - "heliolisk": "エレザード", - "tyrunt": "チゴラス", - "tyrantrum": "ガチゴラス", - "amaura": "アマルス", - "aurorus": "アマルルガ", - "sylveon": "ニンフィア", - "hawlucha": "ルチャブル", - "dedenne": "デデンネ", - "carbink": "メレシー", - "goomy": "ヌメラ", - "sliggoo": "ヌメイル", - "goodra": "ヌメルゴン", - "klefki": "クレッフィ", - "phantump": "ボクレー", - "trevenant": "オーロット", - "pumpkaboo": "バケッチャ", - "gourgeist": "パンプジン", - "bergmite": "カチコール", - "avalugg": "クレベース", - "noibat": "オンバット", - "noivern": "オンバーン", - "xerneas": "ゼルネアス", - "yveltal": "イベルタル", - "zygarde": "ジガルデ", - "diancie": "ディアンシー", - "hoopa": "フーパ", - "volcanion": "ボルケニオン", - "rowlet": "モクロー", - "dartrix": "フクスロー", - "decidueye": "ジュナイパー", - "litten": "ニャビー", - "torracat": "ニャヒート", - "incineroar": "ガオガエン", - "popplio": "アシマリ", - "brionne": "オシャマリ", - "primarina": "アシレーヌ", - "pikipek": "ツツケラ", - "trumbeak": "ケララッパ", - "toucannon": "ドデカバシ", - "yungoos": "ヤングース", - "gumshoos": "デカグース", - "grubbin": "アゴジムシ", - "charjabug": "デンヂムシ", - "vikavolt": "クワガノン", - "crabrawler": "マケンカニ", - "crabominable": "ケケンカニ", - "oricorio": "オドリドリ", - "cutiefly": "アブリー", - "ribombee": "アブリボン", - "rockruff": "イワンコ", - "lycanroc": "ルガルガン", - "wishiwashi": "ヨワシ", - "mareanie": "ヒドイデ", - "toxapex": "ドヒドイデ", - "mudbray": "ドロバンコ", - "mudsdale": "バンバドロ", - "dewpider": "シズクモ", - "araquanid": "オニシズクモ", - "fomantis": "カリキリ", - "lurantis": "ラランテス", - "morelull": "ネマシュ", - "shiinotic": "マシェード", - "salandit": "ヤトウモリ", - "salazzle": "エンニュート", - "stufful": "ヌイコグマ", - "bewear": "キテルグマ", - "bounsweet": "アマカジ", - "steenee": "アママイコ", - "tsareena": "アマージョ", - "comfey": "キュワワー", - "oranguru": "ヤレユータン", - "passimian": "ナゲツケサル", - "wimpod": "コソクムシ", - "golisopod": "グソクムシャ", - "sandygast": "スナバァ", - "palossand": "シロデスナ", - "pyukumuku": "ナマコブシ", - "type_null": "タイプ:ヌル", - "silvally": "シルヴァディ", - "minior": "メテノ", - "komala": "ネッコアラ", - "turtonator": "バクガメス", - "togedemaru": "トゲデマル", - "mimikyu": "ミミッキュ", - "bruxish": "ハギギシリ", - "drampa": "ジジーロン", - "dhelmise": "ダダリン", - "jangmo_o": "ジャラコ", - "hakamo_o": "ジャランゴ", - "kommo_o": "ジャラランガ", - "tapu_koko": "カプ・コケコ", - "tapu_lele": "カプ・テテフ", - "tapu_bulu": "カプ・ブルル", - "tapu_fini": "カプ・レヒレ", - "cosmog": "コスモッグ", - "cosmoem": "コスモウム", - "solgaleo": "ソルガレオ", - "lunala": "ルナアーラ", - "nihilego": "ウツロイド", - "buzzwole": "マッシブーン", - "pheromosa": "フェローチェ", - "xurkitree": "デンジュモク", - "celesteela": "テッカグヤ", - "kartana": "カミツルギ", - "guzzlord": "アクジキング", - "necrozma": "ネクロズマ", - "magearna": "マギアナ", - "marshadow": "マーシャドー", - "poipole": "ベベノム", - "naganadel": "アーゴヨン", - "stakataka": "ツンデツンデ", - "blacephalon": "ズガドーン", - "zeraora": "ゼラオラ", - "meltan": "メルタン", - "melmetal": "メルメタル", - "grookey": "サルノリ", - "thwackey": "バチンキー", - "rillaboom": "ゴリランダー", - "scorbunny": "ヒバニー", - "raboot": "ラビフット", - "cinderace": "エースバーン", - "sobble": "メッソン", - "drizzile": "ジメレオン", - "inteleon": "インテレオン", - "skwovet": "ホシガリス", - "greedent": "ヨクバリス", - "rookidee": "ココガラ", - "corvisquire": "アオガラス", - "corviknight": "アーマーガア", - "blipbug": "サッチムシ", - "dottler": "レドームシ", - "orbeetle": "イオルブ", - "nickit": "クスネ", - "thievul": "フォクスライ", - "gossifleur": "ヒメンカ", - "eldegoss": "ワタシラガ", - "wooloo": "ウールー", - "dubwool": "バイウールー", - "chewtle": "カムカメ", - "drednaw": "カジリガメ", - "yamper": "ワンパチ", - "boltund": "パルスワン", - "rolycoly": "タンドン", - "carkol": "トロッゴン", - "coalossal": "セキタンザン", - "applin": "カジッチュ", - "flapple": "アップリュー", - "appletun": "タルップル", - "silicobra": "スナヘビ", - "sandaconda": "サダイジャ", - "cramorant": "ウッウ", - "arrokuda": "サシカマス", - "barraskewda": "カマスジョー", - "toxel": "エレズン", - "toxtricity": "ストリンダー", - "sizzlipede": "ヤクデ", - "centiskorch": "マルヤクデ", - "clobbopus": "タタッコ", - "grapploct": "オトスパス", - "sinistea": "ヤバチャ", - "polteageist": "ポットデス", - "hatenna": "ミブリム", - "hattrem": "テブリム", - "hatterene": "ブリムオン", - "impidimp": "ベロバー", - "morgrem": "ギモー", - "grimmsnarl": "オーロンゲ", - "obstagoon": "タチフサグマ", - "perrserker": "ニャイキング", - "cursola": "サニゴーン", - "sirfetchd": "ネギガナイト", - "mr_rime": "バリコオル", - "runerigus": "デスバーン", - "milcery": "マホミル", - "alcremie": "マホイップ", - "falinks": "タイレーツ", - "pincurchin": "バチンウニ", - "snom": "ユキハミ", - "frosmoth": "モスノウ", - "stonjourner": "イシヘンジン", - "eiscue": "コオリッポ", - "indeedee": "イエッサン", - "morpeko": "モルペコ", - "cufant": "ゾウドウ", - "copperajah": "ダイオウドウ", - "dracozolt": "パッチラゴン", - "arctozolt": "パッチルドン", - "dracovish": "ウオノラゴン", - "arctovish": "ウオチルドン", - "duraludon": "ジュラルドン", - "dreepy": "ドラメシヤ", - "drakloak": "ドロンチ", - "dragapult": "ドラパルト", - "zacian": "ザシアン", - "zamazenta": "ザマゼンタ", - "eternatus": "ムゲンダイナ", - "kubfu": "ダクマ", - "urshifu": "ウーラオス", - "zarude": "ザルード", - "regieleki": "レジエレキ", - "regidrago": "レジドラゴ", - "glastrier": "ブリザポス", - "spectrier": "レイスポス", - "calyrex": "バドレックス", - "wyrdeer": "アヤシシ", - "kleavor": "バサギリ", - "ursaluna": "ガチグマ", - "basculegion": "イダイトウ", - "sneasler": "オオニューラ", - "overqwil": "ハリーマン", - "enamorus": "ラブトロス", - "sprigatito": "ニャオハ", - "floragato": "ニャローテ", - "meowscarada": "マスカーニャ", - "fuecoco": "ホゲータ", - "crocalor": "アチゲータ", - "skeledirge": "ラウドボーン", - "quaxly": "クワッス", - "quaxwell": "ウェルカモ", - "quaquaval": "ウェーニバル", - "lechonk": "グルトン", - "oinkologne": "パフュートン", - "tarountula": "タマンチュラ", - "spidops": "ワナイダー", - "nymble": "マメバッタ", - "lokix": "エクスレッグ", - "pawmi": "パモ", - "pawmo": "パモット", - "pawmot": "パーモット", - "tandemaus": "ワッカネズミ", - "maushold": "イッカネズミ", - "fidough": "パピモッチ", - "dachsbun": "バウッツェル", - "smoliv": "ミニーブ", - "dolliv": "オリーニョ", - "arboliva": "オリーヴァ", - "squawkabilly": "イキリンコ", - "nacli": "コジオ", - "naclstack": "ジオヅム", - "garganacl": "キョジオーン", - "charcadet": "カルボウ", - "armarouge": "グレンアルマ", - "ceruledge": "ソウブレイズ", - "tadbulb": "ズピカ", - "bellibolt": "ハラバリー", - "wattrel": "カイデン", - "kilowattrel": "タイカイデン", - "maschiff": "オラチフ", - "mabosstiff": "マフィティフ", - "shroodle": "シルシュルー", - "grafaiai": "タギングル", - "bramblin": "アノクサ", - "brambleghast": "アノホラグサ", - "toedscool": "ノノクラゲ", - "toedscruel": "リククラゲ", - "klawf": "ガケガニ", - "capsakid": "カプサイジ", - "scovillain": "スコヴィラン", - "rellor": "シガロコ", - "rabsca": "ベラカス", - "flittle": "ヒラヒナ", - "espathra": "クエスパトラ", - "tinkatink": "カヌチャン", - "tinkatuff": "ナカヌチャン", - "tinkaton": "デカヌチャン", - "wiglett": "ウミディグダ", - "wugtrio": "ウミトリオ", - "bombirdier": "オトシドリ", - "finizen": "ナミイルカ", - "palafin": "イルカマン", - "varoom": "ブロロン", - "revavroom": "ブロロローム", - "cyclizar": "モトトカゲ", - "orthworm": "ミミズズ", - "glimmet": "キラーメ", - "glimmora": "キラフロル", - "greavard": "ボチ", - "houndstone": "ハカドッグ", - "flamigo": "カラミンゴ", - "cetoddle": "アルクジラ", - "cetitan": "ハルクジラ", - "veluza": "ミガルーサ", - "dondozo": "ヘイラッシャ", - "tatsugiri": "シャリタツ", - "annihilape": "コノヨザル", - "clodsire": "ドオー", - "farigiraf": "リキキリン", - "dudunsparce": "ノココッチ", - "kingambit": "ドドゲザン", - "great_tusk": "イダイナキバ", - "scream_tail": "サケブシッポ", - "brute_bonnet": "アラブルタケ", - "flutter_mane": "ハバタクカミ", - "slither_wing": "チヲハウハネ", - "sandy_shocks": "スナノケガワ", - "iron_treads": "テツノワダチ", - "iron_bundle": "テツノツツミ", - "iron_hands": "テツノカイナ", - "iron_jugulis": "テツノコウベ", - "iron_moth": "テツノドクガ", - "iron_thorns": "テツノイバラ", - "frigibax": "セビエ", - "arctibax": "セゴール", - "baxcalibur": "セグレイブ", - "gimmighoul": "コレクレー", - "gholdengo": "サーフゴー", - "wo_chien": "チオンジェン", - "chien_pao": "パオジアン", - "ting_lu": "ディンルー", - "chi_yu": "イーユイ", - "roaring_moon": "トドロクツキ", - "iron_valiant": "テツノブジン", - "koraidon": "コライドン", - "miraidon": "ミライドン", - "walking_wake": "ウネルミナモ", - "iron_leaves": "テツノイサハ ", - "dipplin": "カミッチュ", - "poltchageist": "チャデス", - "sinistcha": "ヤバソチャ", - "okidogi": "イイネイヌ", - "munkidori": "マシマシラ", - "fezandipiti": "キチキギス", - "ogerpon": "オーガポン", - "archaludon": "ブリジュラス", - "hydrapple": "カミツオロチ", - "gouging_fire": "ウガツホムラ", - "raging_bolt": "タケルライコ", - "iron_boulder": "テツノイワオ", - "iron_crown": "テツノカシラ", - "terapagos": "テラパゴス", - "pecharunt": "モモワロウ", - "alola_rattata": "コラッタ", - "alola_raticate": "ラッタ", - "alola_raichu": "ライチュウ", - "alola_sandshrew": "サンド", - "alola_sandslash": "サンドパン", - "alola_vulpix": "ロコン", - "alola_ninetales": "キュウコン", - "alola_diglett": "ディグダ", - "alola_dugtrio": "ダグトリオ", - "alola_meowth": "ニャース", - "alola_persian": "ペルシアン", - "alola_geodude": "イシツブテ", - "alola_graveler": "ゴローン", - "alola_golem": "ゴローニャ", - "alola_grimer": "ベトベター", - "alola_muk": "ベトベトン", - "alola_exeggutor": "ナッシー", - "alola_marowak": "ガラガラ", - "eternal_floette": "フラエッテ", - "galar_meowth": "ニャース", - "galar_ponyta": "ポニータ", - "galar_rapidash": "ギャロップ", - "galar_slowpoke": "ヤドン", - "galar_slowbro": "ヤドラン", - "galar_farfetchd": "カモネギ", - "galar_weezing": "マタドガス", - "galar_mr_mime": "バリヤード", - "galar_articuno": "フリーザー", - "galar_zapdos": "サンダー", - "galar_moltres": "ファイヤー", - "galar_slowking": "ヤドキング", - "galar_corsola": "サニーゴ", - "galar_zigzagoon": "ジグザグマ", - "galar_linoone": "マッスグマ", - "galar_darumaka": "ダルマッカ", - "galar_darmanitan": "ヒヒダルマ", - "galar_yamask": "デスマス", - "galar_stunfisk": "マッギョ", - "hisui_growlithe": "ガーディ", - "hisui_arcanine": "ウインディ", - "hisui_voltorb": "ビリリダマ", - "hisui_electrode": "マルマイン", - "hisui_typhlosion": "バクフーン", - "hisui_qwilfish": "ハリーセン", - "hisui_sneasel": "ニューラ", - "hisui_samurott": "ダイケンキ", - "hisui_lilligant": "ドレディア", - "hisui_zorua": "ゾロア", - "hisui_zoroark": "ゾロアーク", - "hisui_braviary": "ウォーグル", - "hisui_sliggoo": "ヌメイル", - "hisui_goodra": "ヌメルゴン", - "hisui_avalugg": "クレベース", - "hisui_decidueye": "ジュナイパー", - "paldea_tauros": "ケンタロス", - "paldea_wooper": "ウパー", - "bloodmoon_ursaluna": "ガチグマ" -} diff --git a/src/locales/ja/run-history.json b/src/locales/ja/run-history.json deleted file mode 100644 index 3bf9de32c68..00000000000 --- a/src/locales/ja/run-history.json +++ /dev/null @@ -1,37 +0,0 @@ -{ - "victory": "勝利!", - "defeatedWild": "倒された相手:", - "defeatedTrainer": "倒された相手:", - "defeatedTrainerDouble": "倒された相手:", - "defeatedRival": "倒された相手:", - "defeated": "敗北", - "defeatedWild_female": "倒された相手:", - "defeatedTrainer_female": "倒された相手:", - "defeatedTrainerDouble_female": "倒された相手:", - "defeatedRival_female": "倒された相手:", - "defeated_female": "敗北", - "luck": "運", - "score": "スコア", - "mode": "モード", - "challengeRules": "チャレンジ", - "challengeMonoGen1": "I世代", - "challengeMonoGen2": "II世代", - "challengeMonoGen3": "III世代", - "challengeMonoGen4": "IV世代", - "challengeMonoGen5": "V世代", - "challengeMonoGen6": "VI世代", - "challengeMonoGen7": "VII世代", - "challengeMonoGen8": "VIII世代", - "challengeMonoGen9": "IX世代", - "playerItems": "プレイヤーアイテム", - "personalBest": "自己ベスト!", - "SPDshortened": "速さ", - "runInfo": "ラン情報", - "money": "お金", - "runLength": "時間", - "viewHeldItems": "持たせたアイテム", - "hallofFameText": "殿堂入り おめでとう!", - "hallofFameText_female": "殿堂入り おめでとう!", - "viewHallOfFame": "殿堂登録を見る!", - "viewEndingSplash": "クリア後のアートを見る!" -} diff --git a/src/locales/ja/save-slot-select-ui-handler.json b/src/locales/ja/save-slot-select-ui-handler.json deleted file mode 100644 index 73250a08f4b..00000000000 --- a/src/locales/ja/save-slot-select-ui-handler.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "overwriteData": "選択した スロットに データを 上書きします?", - "loading": "読込中…", - "wave": "ラウンド", - "lv": "Lv", - "empty": "なし" -} diff --git a/src/locales/ja/settings.json b/src/locales/ja/settings.json deleted file mode 100644 index afb2f94a047..00000000000 --- a/src/locales/ja/settings.json +++ /dev/null @@ -1,107 +0,0 @@ -{ - "boy": "男の子", - "girl": "女の子", - "general": "全般", - "display": "ディスプレイ", - "audio": "音声", - "gamepad": "コントローラー", - "keyboard": "キーボード", - "gameSpeed": "ゲームの速さ", - "hpBarSpeed": "HPバー増減の速さ", - "expGainsSpeed": "経験値バー増加の速さ", - "expPartyDisplay": "手持ちの経験値取得表示", - "skipSeenDialogues": "もう見た話をスキップ", - "battleStyle": "試合のルール", - "enableRetries": "再挑戦を有効にする", - "hideIvs": "個体値スキャナーを隠す", - "tutorials": "チュートリアル", - "touchControls": "タッチ操作", - "vibrations": "振動", - "normal": "普通", - "fast": "早い", - "faster": "とても早い", - "skip": "飛ばす", - "levelUpNotifications": "レベルアップ時のみ", - "on": "オン", - "off": "オフ", - "switch": "入れ替え", - "set": "勝ち抜き", - "auto": "自動", - "disabled": "無効", - "language": "言語", - "change": "変更", - "uiTheme": "UIテーマ", - "default": "デフォルト", - "legacy": "レガシー", - "windowType": "ウィンドウタイプ", - "moneyFormat": "お金の表示形式", - "damageNumbers": "ダメージ表示", - "simple": "シンプル", - "fancy": "オシャレ", - "abbreviated": "省略", - "moveAnimations": "戦闘アニメーション", - "showStatsOnLevelUp": "レベルアップ時のステータス表示", - "candyUpgradeNotification": "飴アプグレ通知", - "passivesOnly": "パッシブのみ", - "candyUpgradeDisplay": "飴アプグレ表示", - "icon": "アイコン", - "animation": "アニメーション", - "moveInfo": "技情報", - "showMovesetFlyout": "技情報表示", - "showArenaFlyout": "戦場情報表示", - "showTimeOfDayWidget": "時刻指標", - "timeOfDayAnimation": "時刻指標アニメーション", - "bounce": "跳ねる", - "timeOfDay_back": "跳ね返る", - "spriteSet": "スプライト設定", - "consistent": "一貫", - "mixedAnimated": "アニメーションミックス", - "fusionPaletteSwaps": "吸収合体ポケモンの色違い", - "playerGender": "プレイヤーの性別", - "typeHints": "タイプ相性ヒント", - "masterVolume": "マスターボリューム", - "bgmVolume": "BGMボリューム", - "fieldVolume": "フィールドボリューム", - "seVolume": "SEボリューム", - "uiVolume": "UIボリューム", - "musicPreference": "BGM設定", - "mixed": "ミックス", - "gamepadPleasePlug": "コントローラーを 接続してください\nまたは、ボタンを 押してください", - "delete": "削除", - "keyboardPleasePress": "キーを押してください", - "reset": "リセット", - "requireReload": "再読み込みが必要", - "action": "決定", - "back": "戻る", - "pressToBind": "押下でキーバインド", - "pressButton": "ボタンを押してください", - "buttonUp": "上", - "buttonDown": "下", - "buttonLeft": "左", - "buttonRight": "右", - "buttonAction": "決定", - "buttonMenu": "メニュー", - "buttonSubmit": "提出", - "buttonCancel": "キャンセル", - "buttonStats": "能力変化表示", - "buttonCycleForm": "フォルム変更", - "buttonCycleShiny": "色違い変更", - "buttonCycleGender": "性別変更", - "buttonCycleAbility": "特性変更", - "buttonCycleNature": "性格変更", - "buttonCycleVariant": "色変更", - "buttonSpeedUp": "速さを上げる", - "buttonSlowDown": "速さを下げる", - "alt": "(代替)", - "mute": "ミュート", - "controller": "コントローラー", - "gamepadSupport": "コントローラーサポート", - "showBgmBar": "BGMの名前を表示", - "moveTouchControls": "タッチ移動操作", - "shopOverlayOpacity": "ショップオーバレイ不透明度", - "shopCursorTarget": "ショップカーソル初位置", - "rewards": "ご褒美", - "reroll": "選択肢変更", - "shop": "ショップ", - "checkTeam": "手持ちを確認" -} diff --git a/src/locales/ja/splash-messages.json b/src/locales/ja/splash-messages.json deleted file mode 100644 index b7378e7a916..00000000000 --- a/src/locales/ja/splash-messages.json +++ /dev/null @@ -1,36 +0,0 @@ -{ - "battlesWon": "Battles Won!", - "joinTheDiscord": "Join the Discord!", - "infiniteLevels": "Infinite Levels!", - "everythingStacks": "Everything Stacks!", - "optionalSaveScumming": "Optional Save Scumming!", - "biomes": "35 Biomes!", - "openSource": "Open Source!", - "playWithSpeed": "Play with 5x Speed!", - "liveBugTesting": "Live Bug Testing!", - "heavyInfluence": "Heavy RoR2 Influence!", - "pokemonRiskAndPokemonRain": "Pokémon Risk and Pokémon Rain!", - "nowWithMoreSalt": "Now with 33% More Salt!", - "infiniteFusionAtHome": "Infinite Fusion at Home!", - "brokenEggMoves": "Broken Egg Moves!", - "magnificent": "Magnificent!", - "mubstitute": "Mubstitute!", - "thatsCrazy": "That's Crazy!", - "oranceJuice": "Orance Juice!", - "questionableBalancing": "Questionable Balancing!", - "coolShaders": "Cool Shaders!", - "aiFree": "AI-Free!", - "suddenDifficultySpikes": "Sudden Difficulty Spikes!", - "basedOnAnUnfinishedFlashGame": "Based on an Unfinished Flash Game!", - "moreAddictiveThanIntended": "More Addictive than Intended!", - "mostlyConsistentSeeds": "Mostly Consistent Seeds!", - "achievementPointsDontDoAnything": "Achievement Points Don't Do Anything!", - "youDoNotStartAtLevel": "You Do Not Start at Level 2000!", - "dontTalkAboutTheManaphyEggIncident": "Don't Talk About the Manaphy Egg Incident!", - "alsoTryPokengine": "Also Try Pokéngine!", - "alsoTryEmeraldRogue": "Also Try Emerald Rogue!", - "alsoTryRadicalRed": "Also Try Radical Red!", - "eeveeExpo": "Eevee Expo!", - "ynoproject": "YNOproject!", - "breedersInSpace": "Breeders in space!" -} diff --git a/src/locales/ja/starter-select-ui-handler.json b/src/locales/ja/starter-select-ui-handler.json deleted file mode 100644 index cefc5322385..00000000000 --- a/src/locales/ja/starter-select-ui-handler.json +++ /dev/null @@ -1,45 +0,0 @@ -{ - "confirmStartTeam": "この手持ちで 始めますか?", - "confirmExit": "終了しますか?", - "invalidParty": "手持ちは チャレンジの 条件で 認められない!", - "gen1": "1世代", - "gen2": "2世代", - "gen3": "3世代", - "gen4": "4世代", - "gen5": "5世代", - "gen6": "6世代", - "gen7": "7世代", - "gen8": "8世代", - "gen9": "9世代", - "growthRate": "経験値タイプ:", - "ability": "特性:", - "passive": "パッシブ:", - "nature": "性格:", - "eggMoves": "タマゴ技", - "addToParty": "手持ちに入れる", - "removeFromParty": "手持ちから除く", - "toggleIVs": "個体値を表示", - "manageMoves": "技を並び替える", - "manageNature": "性格を変える", - "addToFavorites": "お気に入りにする", - "removeFromFavorites": "お気に入りから除く", - "useCandies": "アメを使う", - "selectNature": "性格を選んでください。", - "selectMoveSwapOut": "入れ替えたい技を選んでください。", - "selectMoveSwapWith": "他の技と交換してください。", - "unlockPassive": "パッシブを開放", - "reduceCost": "ポイントを減らす", - "sameSpeciesEgg": "タマゴを買う", - "cycleShiny": ": 色違い変更", - "cycleForm": ": フォルム変更", - "cycleGender": ": 性別変更", - "cycleAbility": ": 特性変更", - "cycleNature": ": 性格変更", - "cycleVariant": ": 色変更", - "goFilter": ": フィルタ へ ", - "enablePassive": "パッシブ - オン", - "disablePassive": "パッシブ - オフ", - "locked": "非開放", - "disabled": "無効", - "uncaught": "捕まっていない" -} diff --git a/src/locales/ja/status-effect.json b/src/locales/ja/status-effect.json deleted file mode 100644 index 8dafbbdcba7..00000000000 --- a/src/locales/ja/status-effect.json +++ /dev/null @@ -1,65 +0,0 @@ -{ - "none": { - "name": "なし", - "description": "", - "obtain": "", - "obtainSource": "", - "activation": "", - "overlap": "", - "heal": "" - }, - "poison": { - "name": "どく", - "description": "どく", - "obtain": "{{pokemonNameWithAffix}}は\n毒を あびた!", - "obtainSource": "{{pokemonNameWithAffix}}は\n{{sourceText}}で 毒を あびた!", - "activation": "{{pokemonNameWithAffix}}は\n毒の ダメージを 受けた!", - "overlap": "{{pokemonNameWithAffix}}は すでに\n毒を あびている", - "heal": "{{pokemonNameWithAffix}}の 毒は\nきれいさっぱり なくなった!" - }, - "toxic": { - "name": "もうどく", - "description": "もうどく", - "obtain": "{{pokemonNameWithAffix}}は\n猛毒を あびた!", - "obtainSource": "{{pokemonNameWithAffix}}は\n{{sourceText}}で 猛毒を あびた!", - "activation": "{{pokemonNameWithAffix}}は\n毒の ダメージを受けた!", - "overlap": "{{pokemonNameWithAffix}}は すでに\n毒を あびている", - "heal": "{{pokemonNameWithAffix}}の 毒は\nきれいさっぱり なくなった!" - }, - "paralysis": { - "name": "まひ", - "description": "まひ", - "obtain": "{{pokemonNameWithAffix}}は まひして\n技が でにくくなった!", - "obtainSource": "{{pokemonNameWithAffix}}は {{sourceText}}で まひして\n技が でにくくなった!", - "activation": "{{pokemonNameWithAffix}}は\n体が しびれて 動けない!", - "overlap": "{{pokemonNameWithAffix}}は\nすでに まひしている", - "heal": "{{pokemonNameWithAffix}}の\nしびれが とれた!" - }, - "sleep": { - "name": "ねむり", - "description": "ねむり", - "obtain": "{{pokemonNameWithAffix}}は\n眠ってしまった!", - "obtainSource": "{{pokemonNameWithAffix}}は\n{{sourceText}}で 眠ってしまった!", - "activation": "{{pokemonNameWithAffix}}は\nぐうぐう 眠っている", - "overlap": "{{pokemonNameWithAffix}}は\nすでに 眠っている", - "heal": "{{pokemonNameWithAffix}}は\n目を 覚ました!" - }, - "freeze": { - "name": "こおり", - "description": "こおり", - "obtain": "{{pokemonNameWithAffix}}は\n凍りついた!", - "obtainSource": "{{pokemonNameWithAffix}}は\n{{sourceText}}で 凍りついた!", - "activation": "{{pokemonNameWithAffix}}は\n凍ってしまって 動けない!", - "overlap": "{{pokemonNameWithAffix}}は\nすでに 凍っている", - "heal": "{{pokemonNameWithAffix}}は\nこおり状態が 治った!" - }, - "burn": { - "name": "やけど", - "description": "やけど", - "obtain": "{{pokemonNameWithAffix}}は\nやけどを 負った!", - "obtainSource": "{{pokemonNameWithAffix}}は\n{{sourceText}}で やけどを 負った!", - "activation": "{{pokemonNameWithAffix}}は\nやけどの ダメージを 受けた!", - "overlap": "{{pokemonNameWithAffix}}は すでに\nやけどを 負っている", - "heal": "{{pokemonNameWithAffix}}の\nやけどが 治った!" - } -} \ No newline at end of file diff --git a/src/locales/ja/terrain.json b/src/locales/ja/terrain.json deleted file mode 100644 index 1e0fc60fc62..00000000000 --- a/src/locales/ja/terrain.json +++ /dev/null @@ -1,16 +0,0 @@ -{ - "misty": "ミストフィールド", - "mistyStartMessage": "足下に 霧(きり)が立ち込めた!", - "mistyClearMessage": "足下の 霧(きり)が消え去った!", - "mistyBlockMessage": "{{pokemonNameWithAffix}}は\nミストフィールドに 守られている!", - "electric": "エレキフィールド", - "electricStartMessage": "足下に 電気が かけめぐる!", - "electricClearMessage": "足下の 電気が 消え去った!", - "grassy": "グラスフィールド", - "grassyStartMessage": "足下に 草がおいしげった!", - "grassyClearMessage": "足下の 草が消え去った!", - "psychic": "サイコフィールド", - "psychicStartMessage": "足元が 不思議な感じに なった!", - "psychicClearMessage": "足元の 不思議感が 消え去った!", - "defaultBlockMessage": "{{pokemonNameWithAffix}}は\n{{terrainName}}に 守られている!" -} \ No newline at end of file diff --git a/src/locales/ja/trainer-classes.json b/src/locales/ja/trainer-classes.json deleted file mode 100644 index aba294fbbbd..00000000000 --- a/src/locales/ja/trainer-classes.json +++ /dev/null @@ -1,130 +0,0 @@ -{ - "ace_trainer": "エリートトレーナー", - "ace_trainer_female": "エリートトレーナー", - "ace_duo": "エリートコンビ", - "artist": "芸術家", - "artist_female": "芸術家", - "backers": "ファンクラブ", - "backpacker": "バックパッカー", - "backpacker_female": "バックパッカー", - "backpackers": "バックパッカーズ", - "baker": "ベーカリー", - "battle_girl": "バトルガール", - "beauty": "大人のおねえさん", - "beginners": "初心者", - "biker": "暴走族", - "black_belt": "カラテ王", - "breeder": "ポケモンブリーダー", - "breeder_female": "ポケモンブリーダー", - "breeders": "ブリーダーコンビ", - "clerk": "ビジネスマン", - "clerk_female": "OL", - "colleagues": "ビジネスパートナー", - "crush_kin": "格闘兄妹", - "cyclist": "サイクリング", - "cyclist_female": "サイクリング", - "cyclists": "サイクリングチーム", - "dancer": "ダンサー", - "dancer_female": "ダンサー", - "depot_agent": "鉄道員", - "doctor": "ドクター", - "doctor_female": "ドクター", - "firebreather": "火吹きやろう", - "fisherman": "釣り人", - "fisherman_female": "釣り人", - "gentleman": "ジェントルマン", - "guitarist": "ギタリスト", - "guitarist_female": "ギタリスト", - "harlequin": "クラウン", - "hiker": "山男", - "hooligans": "バッドチーム", - "hoopster": "バスケ選手", - "infielder": "野球選手", - "janitor": "清掃員", - "lady": "お嬢さま", - "lass": "ミニスカート", - "linebacker": "フットボーラー", - "maid": "メイド", - "madame": "マダム", - "medical_team": "医療チーム", - "musician": "ミュージシャン", - "hex_maniac": "オカルトマニア", - "nurse": "ナース", - "nursery_aide": "保育士", - "officer": "お巡りさん", - "parasol_lady": "パラソルおねえさん", - "pilot": "パイロット", - "pokéfan": "大好きクラブ", - "pokéfan_female": "大好きクラブ", - "pokéfan_family": "大好き夫婦", - "preschooler": "園児", - "preschooler_female": "園児", - "preschoolers": "園児たち", - "psychic": "サイキッカー", - "psychic_female": "サイキッカー", - "psychics": "サイキッ家", - "pokémon_ranger": "ポケモンレンジャー", - "pokémon_ranger_female": "ポケモンレンジャー", - "pokémon_rangers": "レンジャーズ", - "ranger": "レンジャー", - "restaurant_staff": "レストランスタッフ", - "rich": "お金持ち", - "rich_female": "お金持ち", - "rich_boy": "お坊っちゃま", - "rich_couple": "お二人さま", - "rich_kid": "ブルジョワ男子", - "rich_kid_female": "ブルジョワ女子", - "rich_kids": "ブルジョワ子達", - "roughneck": "スキンヘッズ", - "sailor": "船乗り", - "scientist": "研究員", - "scientist_female": "研究員", - "scientists": "研究チーム", - "smasher": "テニスプレイヤー", - "snow_worker": "冷凍作業員", - "snow_worker_female": "冷凍作業員", - "striker": "サッカー選手", - "school_kid": "塾帰り", - "school_kid_female": "塾帰り", - "school_kids": "塾生たち", - "swimmer": "海パンやろう", - "swimmer_female": "ビキニのおねえさん", - "swimmers": "水着カップル", - "twins": "双子ちゃん", - "veteran": "ベテラントレーナー", - "veteran_female": "ベテラントレーナー", - "veteran_duo": "ベテランコンビ", - "waiter": "ウエーター", - "waitress": "ウエートレス", - "worker": "作業員", - "worker_female": "作業員", - "workers": "作業班", - "youngster": "短パン小僧", - "rocket_grunt": "ロケット団の下っ端", - "rocket_grunts": " ロケット団の下っ端", - "rocket_grunt_female": "ロケット団の下っ端", - "magma_grunt": "マグマ団の下っ端", - "magma_grunt_female": "マグマ団の下っ端", - "magma_grunts": "マグマ団の下っ端", - "aqua_grunt": "アクア団の下っ端", - "aqua_grunt_female": "アクア団の下っ端", - "aqua_grunts": "アクア団の下っ端", - "galactic_grunt": "ギンガ団の下っ端", - "galactic_grunt_female": "ギンガ団の下っ端", - "galactic_grunts": "ギンガ団の下っ端", - "plasma_grunt": "プラスマ団の下っ端", - "plasma_grunt_female": "プラズマ団の下っ端", - "plasma_grunts": "プラズマ団の下っ端", - "flare_grunt": "フレア団の下っ端", - "flare_grunt_female": "フレア団の下っ端", - "flare_grunts": "フレア団の下っ端", - "aether_grunt": "エーテル財団の職員", - "aether_grunt_female": "エーテル財団の職員", - "aether_grunts": "エーテル財団の職員", - "skull_grunt": "スカル団の下っ端", - "skull_grunt_female": "スカル団の下っ端", - "skull_grunts": "スカル団の下っ端", - "macro_grunt": "マクロコスモスのトレーナ", - "macro_grunt_female": "マクロコスモスのトレーナ", - "macro_grunts": "マクロコスモスのトレーナ" -} diff --git a/src/locales/ja/trainer-names.json b/src/locales/ja/trainer-names.json deleted file mode 100644 index 70841734b5b..00000000000 --- a/src/locales/ja/trainer-names.json +++ /dev/null @@ -1,164 +0,0 @@ -{ - "brock": "タケシ", - "misty": "カスミ", - "lt_surge": "マチス", - "erika": "エリカ", - "janine": "アンズ", - "sabrina": "ナツメ", - "blaine": "カツラ", - "giovanni": "サカキ", - "falkner": "ハヤト", - "bugsy": "ツクシ", - "whitney": "アカネ", - "morty": "マツバ", - "chuck": "シジマ", - "jasmine": "ミカン", - "pryce": "ヤナギ", - "clair": "イブキ", - "roxanne": "ツツジ", - "brawly": "トウキ", - "wattson": "テッセン", - "flannery": "アスナ", - "norman": "センリ", - "winona": "ナギ", - "tate": "フウ", - "liza": "ラン", - "juan": "アダン", - "roark": "ヒョウタ", - "gardenia": "ナタネ", - "maylene": "スモモ", - "crasher_wake": "マキシ", - "fantina": "メリッサ", - "byron": "トウガン", - "candice": "スズナ", - "volkner": "デンジ", - "cilan": "デント", - "chili": "ポッド", - "cress": "コーン", - "cheren": "チェレン", - "lenora": "アロエ", - "roxie": "ホミカ", - "burgh": "アーティ", - "elesa": "カミツレ", - "clay": "ヤーコン", - "skyla": "フウロ", - "brycen": "ハチク", - "drayden": "シャガ", - "marlon": "シズイ", - "viola": "ビオラ", - "grant": "ザクロ", - "korrina": "コルニ", - "ramos": "フクジ", - "clemont": "シトロン", - "valerie": "マーシュ", - "olympia": "ゴジカ", - "wulfric": "ウルップ", - "milo": "ヤロー", - "nessa": "ルリナ", - "kabu": "カブ", - "bea": "サイトウ", - "allister": "オニオン", - "opal": "ポプラ", - "bede": "ビート", - "gordie": "マクワ", - "melony": "メロン", - "piers": "ネズ", - "marnie": "マリィ", - "raihan": "キバナ", - "katy": "カエデ", - "brassius": "コルサ", - "iono": " ナンジャモ", - "kofu": "ハイダイ", - "larry": "アオキ", - "ryme": "ライム", - "tulip": "リップ", - "grusha": "グルーシャ", - "lorelei": "カンナ", - "bruno": "シバ", - "agatha": "キクコ", - "lance": "ワタル", - "will": "イツキ", - "koga": "キョウ", - "karen": "カリン", - "sidney": "カゲツ", - "phoebe": "フヨウ", - "glacia": "プリム", - "drake": "ゲンジ", - "aaron": "リョウ", - "bertha": "キクノ", - "flint": "オーバ", - "lucian": "ゴヨウ", - "shauntal": "シキミ", - "marshal": "レンブ", - "grimsley": "ギーマ", - "caitlin": "カトレア", - "malva": "パキラ", - "siebold": "ズミ", - "wikstrom": "ガンピ", - "drasna": "ドラセナ", - "hala": "ハラ", - "molayne": "マーレイン", - "olivia": "ライチ", - "acerola": "アセロラ", - "kahili": "カヒリ", - "rika": "チリ", - "poppy": "ポピー", - "hassel": "ハッサク", - "crispin": "アカマツ", - "amarys": "ネリネ", - "lacey": "タロ", - "drayton": "カキツバタ", - "blue": "グリーン", - "red": "レッド", - "steven": "ダイゴ", - "wallace": "ミクリ", - "cynthia": "シロナ", - "alder": "アデク", - "iris": "アイリス", - "diantha": "カルネ", - "hau": "ハウ", - "geeta": "オモダカ", - "nemona": "ネモ", - "kieran": "スグリ", - "leon": "ダンデ", - "rival": "フィン", - "rival_female": "アイヴィー", - "archer": "アポロ", - "ariana": "アテナ", - "proton": "ランス", - "petrel": "ラムダ", - "tabitha": "ホムラ", - "courtney": "カガリ", - "shelly": "イズミ", - "matt": "ウシオ", - "mars": "マーズ", - "jupiter": "ジュピター", - "saturn": "サターン", - "zinzolin": "ヴィオ", - "rood": "ロット", - "xerosic": "クセロシキ", - "bryony": "バラ", - "faba": "ザオボー", - "plumeria": "プルメリ", - "oleana": "オリーヴ", - - "maxie": "マツブサ", - "archie": "アオギリ", - "cyrus": "アカギ", - "ghetsis": "ゲーチス", - "lysandre": "フラダリ", - "lusamine": "ルザミーネ", - "guzma": "グズマ", - "rose": "ローズ", - - "blue_red_double": "グリーンとレッド", - "red_blue_double": "レッドとグリーン", - "tate_liza_double": "フウとラン", - "liza_tate_double": "ランとフウ", - "steven_wallace_double": "ダイゴとミクリ", - "wallace_steven_double": "ミクリとダイゴ", - "alder_iris_double": "アデクとアイリス", - "iris_alder_double": "アイリスとアデク", - "marnie_piers_double": "マリィとネズ", - "piers_marnie_double": "ネズとマリィ" -} diff --git a/src/locales/ja/trainer-titles.json b/src/locales/ja/trainer-titles.json deleted file mode 100644 index b3829c701e5..00000000000 --- a/src/locales/ja/trainer-titles.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "elite_four": "四天王", - "elite_four_female": "四天王", - "gym_leader": "ジムリーダー", - "gym_leader_female": "ジムリーダー", - "gym_leader_double": "ジムリーダーコンビ", - "champion": "チャンピオン", - "champion_female": "チャンピオン", - "champion_double": "チャンピオンコンビ", - "rival": "ライバル", - "professor": "ポケモン博士", - "frontier_brain": "フロンティアブレーン", - "rocket_boss": "ロケット団ボス", - "magma_boss": "マグマ団リーダー", - "aqua_boss": "アクア団リーダー", - "galactic_boss": "ギンガ団ボス", - "plasma_boss": "プラズマ団ボス", - "flare_boss": "フレア団ボス", - "aether_boss": "エーテル代表", - "skull_boss": "スカル団ボス", - "macro_boss": "マクロコスモス社長", - - "rocket_admin": "ロケット団幹部", - "rocket_admin_female": "ロケット団幹部", - "magma_admin": "マグマ団幹部", - "magma_admin_female": "マグマロケット団幹部", - "aqua_admin": "アクア団幹部", - "aqua_admin_female": "アクア団幹部", - "galactic_commander": "ギンガ団幹部", - "galactic_commander_female": "ギンガ団幹部", - "plasma_sage": "プラズマ団賢人", - "plasma_admin": "プラズマ団賢人", - "flare_admin": "フレア団幹部", - "flare_admin_female": "フレア団幹部", - "aether_admin": "エーテル支部長", - "skull_admin": "スカル団幹部", - "macro_admin": "マクロコスモス" -} diff --git a/src/locales/ja/tutorial.json b/src/locales/ja/tutorial.json deleted file mode 100644 index 99019b03f7f..00000000000 --- a/src/locales/ja/tutorial.json +++ /dev/null @@ -1,10 +0,0 @@ -{ - "intro": "PokéRogueへ ようこそ! ローグライク要素が\n加わった バトル中心の ポケモンファンゲームです。\n$このゲームは 収益を上げず、Pokémonおよび 使用される\n著作権資産に 対する所有権を 主張しません。\n$ゲームは まだ開発中ですが、完全に プレイすることが できます。\nバグ報告は ディスコードコミュニティを ご利用ください。\n$ゲームが 遅い場合は、ブラウザ設定で「ハードウェア\nアクセラレーション」が オンになっている ことを 確認してください。", - "accessMenu": "メニューを開くには 入力待ちの間に Mキー/Escを 押してください。\nメニューには 設定や 様々な機能が 含まれています。", - "menu": "このメニューから 設定が 開けます。\n$設定では、ゲームの速さや ウィンドウタイプなどの オプションを 変更できます。\n$ここには 様々な機能が ありますので、\nぜひ 確認してみてください!", - "starterSelect": "この画面では Zキー/空白キーを押して ポケモンが 選択できます。\n選んだポケモンは 最初の手持ちに なります。\n$各ポケモンは ポイントが ある。最大6つを 選べますが\nポケモンのポイントが 合計10を超えては いけません。\n$ポケモンを 捕まえたり タマゴからふかしたり することで\n選択できる 性別、特性、フォルムなどの 幅を広げられます。\n$個体値も 徐々に 累積して 高くなるので、\n同じポケモンを たくさん 捕まえて みてください!", - "pokerus": "毎日、無作為に スターターの\n3種類には 紫色の枠が 表示されます。\n$登録された スターターの 中に いれば、\n手持ちに加えて 強さを 確認してみましょう!", - "statChange": "ポケモンを 入れ替えない限り、\n次のバトルでも 能力変化は なくなりません。\n$その代わりに、トレーナーバトルや 新しいバイオームに\n入る直前に 自動的に 能力変化は 元に戻ります。\n$Cキー/Shiftキーを 押し続けると、\n場にいるポケモンの 能力変化を 確認できます。\n$Vキーを押すと、\n相手が出した技も 確認できます。\n$ただし、現在のバトルでの 相手ポケモンが\nすでに使った 技のみが 表示されます。", - "selectItem": "バトルが 終わるたびには、「ショップ」という\n画面で 3つのご褒美から 1つが選べます。\n$種類は 消耗品、ポケモンの持ち物や道具、\n永続的な パッシブアイテムなど 様々です。\n$ほとんどの 消耗しない 道具は\n効果が 累積されます。\n$例えば 進化アイテムなどの ご褒美は\n使用できる 場合にのみ 登場します。\n$持ち物や道具が\n手持ちポケモン間に 移動できる\n$持ち物や道具が あれば、ショップ画面の\n右下に「アイテム移行」が 表示されます。\n$ショップ画面で お金で 消耗品を 買えます。\nラウンドが 進むにつれて 買えるアイテムが 増えます。\n$ご褒美を 選択すると 次のラウンドに\n進むから、まず 消耗品を 買ってください。", - "eggGacha": "この画面では、「タマゴクーポン」で\nポケモンのタマゴを 取得できます。\n$タマゴは ラウンドが進めるうちに ふかします。\nタマゴのふかは レア度によって 時間が かかります。\n$ふかしたポケモンは 手持ちに 加えられず、\nスターターに 登録されます。\n$ふかしたポケモンは 一般的に\n野生ポケモンよりも 高い個体値があります。\n$あるポケモンは タマゴからしか 手に入りません。\n$各ガチャマシンは 個性的なボーナスが あるますから、\n好きな方から 引いてみてください!," -} diff --git a/src/locales/ja/voucher.json b/src/locales/ja/voucher.json deleted file mode 100644 index eabe384bc98..00000000000 --- a/src/locales/ja/voucher.json +++ /dev/null @@ -1,9 +0,0 @@ -{ - "vouchers": "クーポン", - "eggVoucher": "タマゴクーポン", - "eggVoucherPlus": "タマゴクーポン・プラス", - "eggVoucherPremium": "タマゴクーポン・プレミアム", - "eggVoucherGold": "タマゴクーポン・ゴールド", - "locked": "なし", - "defeatTrainer": "{{trainerName}}を 倒す" -} \ No newline at end of file diff --git a/src/locales/ja/weather.json b/src/locales/ja/weather.json deleted file mode 100644 index e2d3c6c4e32..00000000000 --- a/src/locales/ja/weather.json +++ /dev/null @@ -1,32 +0,0 @@ -{ - "sunnyStartMessage": "日差しが 強くなった!", - "sunnyLapseMessage": "日差しが 強い!", - "sunnyClearMessage": "日差しが 元に戻った!", - "rainStartMessage": "雨が 降り始めた!", - "rainLapseMessage": "雨が 降っている!", - "rainClearMessage": "雨が あがった!", - "sandstormStartMessage": "砂あらしが 吹き始めた!", - "sandstormLapseMessage": "砂あらしが 吹きあれる!", - "sandstormClearMessage": "砂あらしが おさまった!", - "sandstormDamageMessage": "砂あらしが\n{{pokemonNameWithAffix}}を 襲う!", - "hailStartMessage": "あられが 降り始めた!", - "hailLapseMessage": "あられが 降っている!", - "hailClearMessage": "あられが 止んだ!", - "hailDamageMessage": "あられが\n{{pokemonNameWithAffix}}を 襲う!", - "snowStartMessage": "雪が 降り始めた!", - "snowLapseMessage": "雪が 降っている!", - "snowClearMessage": "雪が 止んだ!", - "fogStartMessage": "足下に 霧が 立ち込めた!", - "fogLapseMessage": "足下に 霧が 立ち込めている!", - "fogClearMessage": "足下の 霧が 消え去った!", - "heavyRainStartMessage": "強い雨が 降り始めた!", - "heavyRainLapseMessage": "強い雨が 降っている!", - "heavyRainClearMessage": "強い雨が あがった!", - "harshSunStartMessage": "日差しが とても強くなった!", - "harshSunLapseMessage": "日差しが とても強い!", - "harshSunClearMessage": "日差しが 元に戻った!", - "strongWindsStartMessage": "謎の 乱気流が\nひこうポケモンを 護る!", - "strongWindsLapseMessage": "謎の 乱気流の 勢いは 止まらない!", - "strongWindsEffectMessage": "謎の 乱気流が 攻撃を 弱めた!", - "strongWindsClearMessage": "謎の 乱気流が おさまった!" -} diff --git a/src/locales/ko/ability-trigger.json b/src/locales/ko/ability-trigger.json deleted file mode 100644 index b1f100c5c36..00000000000 --- a/src/locales/ko/ability-trigger.json +++ /dev/null @@ -1,64 +0,0 @@ -{ - "blockRecoilDamage": "{{pokemonName}}[[는]] {{abilityName}} 때문에\n반동 데미지를 받지 않는다!", - "badDreams": "{{pokemonName}}[[는]]\n나이트메어 때문에 시달리고 있다!", - "costar": "{{pokemonName}}[[는]] {{allyName}}의\n능력 변화를 복사했다!", - "iceFaceAvoidedDamage": "{{pokemonNameWithAffix}}[[는]] {{abilityName}} 때문에\n데미지를 받지 않는다!", - "perishBody": "{{pokemonName}}의 {{abilityName}} 때문에\n양쪽 포켓몬 모두는 3턴 후에 쓰러져 버린다!", - "poisonHeal": "{{pokemonName}}[[는]] {{abilityName}}[[로]]인해\n조금 회복했다.", - "trace": "{{pokemonName}}[[는]] 상대 {{targetName}}의 \n{{abilityName}}[[를]] 트레이스했다!", - "windPowerCharged": "{{pokemonName}}[[는]]\n{{moveName}}에 맞아 충전되었다!", - "quickDraw": "{{pokemonName}}[[는]]\n퀵드로에 의해 행동이 빨라졌다!", - "disguiseAvoidedDamage": "{{pokemonNameWithAffix}}의 정체가 드러났다!", - "blockItemTheft": "{{pokemonNameWithAffix}}의 {{abilityName}}에 의해\n도구를 빼앗기지 않는다!", - "typeImmunityHeal": "{{pokemonNameWithAffix}}[[는]]\n{{abilityName}}[[로]] 체력이 회복되었다!", - "nonSuperEffectiveImmunity": "{{pokemonNameWithAffix}}[[는]] {{abilityName}} 때문에\n데미지를 입지 않는다!", - "fullHpResistType": "{{pokemonNameWithAffix}}[[는]] 등껍질을 빛나게 하여\n타입 상성을 왜곡시켰다!!", - "moveImmunity": "{{pokemonNameWithAffix}}에게는\n효과가 없는 것 같다...", - "reverseDrain": "{{pokemonNameWithAffix}}[[는]]\n해감액을 흡수했다!", - "postDefendTypeChange": "{{pokemonNameWithAffix}}[[는]] {{abilityName}}[[로]] 인해\n{{typeName}}타입이 됐다!", - "postDefendContactDamage": "{{pokemonNameWithAffix}}[[는]] {{abilityName}}[[로]]\n상대를 상처입혔다!", - "postDefendAbilitySwap": "{{pokemonNameWithAffix}}[[는]]\n서로의 특성을 교체했다!", - "postDefendAbilityGive": "{{pokemonNameWithAffix}}[[는]]\n특성이 {{abilityName}}[[가]] 되어 버렸다!", - "postDefendMoveDisable": "{{pokemonNameWithAffix}}의\n{{moveName}}[[를]] 봉인했다!", - "pokemonTypeChange": "{{pokemonNameWithAffix}}[[는]]\n{{moveType}}타입이 됐다!", - "postAttackStealHeldItem": "{{pokemonNameWithAffix}}[[는]] {{defenderName}}[[로]]부터\n{{stolenItemType}}[[를]] 빼앗았다!", - "postDefendStealHeldItem": "{{pokemonNameWithAffix}}[[는]] {{attackerName}}[[로]]부터\n{{stolenItemType}}[[를]] 빼앗았다!", - "copyFaintedAllyAbility": "{{pokemonNameWithAffix}}의\n{{abilityName}}[[를]] 이어받았다!", - "intimidateImmunity": "{{pokemonNameWithAffix}}[[는]]\n{{abilityName}}의 효과로 능력이 떨어지지 않는다!", - "postSummonAllyHeal": "{{pokemonNameWithAffix}}[[가]] 내온 차를\n{{pokemonName}}[[가]] 모두 비웠다!", - "postSummonClearAllyStats": "{{pokemonNameWithAffix}}의\n능력 변화가 원래대로 되돌아왔다!", - "postSummonTransform": "{{pokemonNameWithAffix}}[[는]]\n{{targetName}}[[로]] 변신했다!!", - "protectStat": "{{pokemonNameWithAffix}}[[는]] {{abilityName}}의 효과로\n{{statName}}[[가]] 떨어지지 않는다!", - "statusEffectImmunityWithName": "{{pokemonNameWithAffix}}[[는]] {{abilityName}} 때문에\n{{statusEffectName}}에 걸리지 않는다!", - "statusEffectImmunity": "{{pokemonNameWithAffix}}[[는]] {{abilityName}} 때문에\n상태 이상이 되지 않는다!", - "battlerTagImmunity": "{{pokemonNameWithAffix}}[[는]] {{abilityName}}[[로]]\n{{battlerTagName}}[[를]] 무시했다!", - "forewarn": "{{pokemonNameWithAffix}}의\n{{moveName}}[[를]] 간파했다!", - "frisk": "{{pokemonNameWithAffix}}[[는]] {{opponentName}}의\n{{opponentAbilityName}}[[를]] 통찰했다!", - "postWeatherLapseHeal": "{{pokemonNameWithAffix}}[[는]]\n{{abilityName}}[[로]] 체력이 회복되었다!", - "postWeatherLapseDamage": "{{pokemonNameWithAffix}}[[는]]\n{{abilityName}}에 의한 데미지를 입었다!", - "postTurnLootCreateEatenBerry": "{{pokemonNameWithAffix}}[[는]]\n{{berryName}}[[를]] 수확했다!", - "postTurnHeal": "{{pokemonNameWithAffix}}[[는]]\n{{abilityName}}[[로]] 체력이 회복되었다!", - "fetchBall": "{{pokemonNameWithAffix}}[[는]]\n{{pokeballName}}[[를]] 주워 왔다!", - "healFromBerryUse": "{{pokemonNameWithAffix}}[[는]]\n{{abilityName}}[[로]] 체력이 회복되었다!", - "arenaTrap": "{{pokemonNameWithAffix}}의 {{abilityName}} 때문에\n바꿀 수 없다!", - "postBattleLoot": "{{pokemonNameWithAffix}}[[는]]\n{{itemName}}[[를]] 주웠다!", - "postFaintContactDamage": "{{pokemonNameWithAffix}}[[는]] {{abilityName}}[[로]]\n상대에게 데미지를 입혔다!", - "postFaintHpDamage": "{{pokemonNameWithAffix}}[[는]] {{abilityName}}[[로]]\n상대에게 데미지를 입혔다!", - "postSummonPressure": "{{pokemonNameWithAffix}}[[는]]\n프레셔를 발산하고 있다!", - "weatherEffectDisappeared": "날씨의 영향이 없어졌다!", - "postSummonMoldBreaker": "{{pokemonNameWithAffix}}의\n틀깨기!", - "postSummonAnticipation": "{{pokemonNameWithAffix}}[[는]]\n몸을 떨었다!", - "postSummonTurboblaze": "{{pokemonNameWithAffix}}[[는]]\n활활 타오르는 오라를 발산하고 있다!", - "postSummonTeravolt": "{{pokemonNameWithAffix}}[[는]]\n세차게 튀는 오라를 발산하고 있다!", - "postSummonDarkAura": "{{pokemonNameWithAffix}}[[는]]\n다크오라를 발산하고 있다!", - "postSummonFairyAura": "{{pokemonNameWithAffix}}[[는]]\n페어리오라를 발산하고 있다!", - "postSummonAuraBreak": "{{pokemonNameWithAffix}}[[는]]\n모든 오라를 제압한다!", - "postSummonNeutralizingGas": "주위가 화학변화가스로 가득 찼다!", - "postSummonAsOneGlastrier": "{{pokemonNameWithAffix}}[[는]]\n두 가지 특성을 겸비한다!", - "postSummonAsOneSpectrier": "{{pokemonNameWithAffix}}[[는]]\n두 가지 특성을 겸비한다!", - "postSummonVesselOfRuin": "{{pokemonNameWithAffix}}의 재앙의그릇에 의해\n주위의 {{statName}}[[가]] 약해졌다!", - "postSummonSwordOfRuin": "{{pokemonNameWithAffix}}의 재앙의검에 의해\n주위의 {{statName}}[[가]] 약해졌다!", - "postSummonTabletsOfRuin": "{{pokemonNameWithAffix}}의 재앙의목간에 의해\n주위의 {{statName}}[[가]] 약해졌다!", - "postSummonBeadsOfRuin": "{{pokemonNameWithAffix}}의 재앙의구슬에 의해\n주위의 {{statName}}[[가]] 약해졌다!", - "preventBerryUse": "{{pokemonNameWithAffix}}[[는]] 긴장해서\n나무열매를 먹을 수 없게 되었다!" -} diff --git a/src/locales/ko/ability.json b/src/locales/ko/ability.json deleted file mode 100644 index 420d27c6011..00000000000 --- a/src/locales/ko/ability.json +++ /dev/null @@ -1,1242 +0,0 @@ -{ - "stench": { - "name": "악취", - "description": "악취를 풍겨서 공격했을 때 상대가 풀죽을 때가 있다." - }, - "drizzle": { - "name": "잔비", - "description": "등장했을 때 날씨를 비로 만든다." - }, - "speedBoost": { - "name": "가속", - "description": "매 턴 스피드가 올라간다." - }, - "battleArmor": { - "name": "전투무장", - "description": "단단한 껍질에 보호받아 상대의 공격이 급소에 맞지 않는다." - }, - "sturdy": { - "name": "옹골참", - "description": "상대 기술을 받아도 일격으로 쓰러지지 않는다. 일격필살 기술도 효과 없다." - }, - "damp": { - "name": "습기", - "description": "주변을 습하게 함으로써 자폭 등 폭발하는 기술을 아무도 못 쓰게 한다." - }, - "limber": { - "name": "유연", - "description": "유연한 몸으로 인해 마비 상태가 되지 않는다." - }, - "sandVeil": { - "name": "모래숨기", - "description": "모래바람일 때 회피율이 올라간다." - }, - "static": { - "name": "정전기", - "description": "정전기를 몸에 둘러 접촉한 상대를 마비시킬 때가 있다." - }, - "voltAbsorb": { - "name": "축전", - "description": "전기타입의 기술을 받으면 데미지를 받지 않고 회복한다." - }, - "waterAbsorb": { - "name": "저수", - "description": "물타입의 기술을 받으면 데미지를 받지 않고 회복한다." - }, - "oblivious": { - "name": "둔감", - "description": "둔감해서 헤롱헤롱이나 도발 상태가 되지 않는다." - }, - "cloudNine": { - "name": "날씨부정", - "description": "모든 날씨의 영향이 없어진다." - }, - "compoundEyes": { - "name": "복안", - "description": "복안을 가지고 있어 기술의 명중률이 올라간다." - }, - "insomnia": { - "name": "불면", - "description": "잠들지 못하는 체질이라 잠듦 상태가 되지 않는다." - }, - "colorChange": { - "name": "변색", - "description": "상대에게 받은 기술의 타입으로 자신의 타입이 변화한다." - }, - "immunity": { - "name": "면역", - "description": "체내에 면역을 가지고 있어 독 상태가 되지 않는다." - }, - "flashFire": { - "name": "타오르는불꽃", - "description": "불꽃타입의 기술을 받으면 불꽃을 받아서 자신이 사용하는 불꽃타입의 기술이 강해진다." - }, - "shieldDust": { - "name": "인분", - "description": "인분에 보호받아 기술의 추가 효과를 받지 않게 된다." - }, - "ownTempo": { - "name": "마이페이스", - "description": "마이페이스라서 혼란 상태가 되지 않는다." - }, - "suctionCups": { - "name": "흡반", - "description": "흡반으로 지면에 달라붙어 포켓몬을 교체시키는 기술이나 도구의 효과를 발휘하지 못하게 한다." - }, - "intimidate": { - "name": "위협", - "description": "등장했을 때 위협해서 상대를 위축시켜 상대의 공격을 떨어뜨린다." - }, - "shadowTag": { - "name": "그림자밟기", - "description": "상대의 그림자를 밟아 도망치거나 교체할 수 없게 한다." - }, - "roughSkin": { - "name": "까칠한피부", - "description": "공격을 받았을 때 자신에게 접촉한 상대를 까칠까칠한 피부로 상처를 입힌다." - }, - "wonderGuard": { - "name": "불가사의부적", - "description": "효과가 굉장한 기술만 맞는 불가사의한 힘." - }, - "levitate": { - "name": "부유", - "description": "땅에서 뜨는 것으로 땅타입의 기술을 받지 않는다." - }, - "effectSpore": { - "name": "포자", - "description": "공격으로 자신에게 접촉한 상대를 독이나 마비, 잠듦 상태로 만들 때가 있다." - }, - "synchronize": { - "name": "싱크로", - "description": "자신이 걸린 독이나 마비, 화상을 상대에게 옮긴다." - }, - "clearBody": { - "name": "클리어바디", - "description": "상대 기술이나 특성으로 능력이 떨어지지 않는다." - }, - "naturalCure": { - "name": "자연회복", - "description": "지닌 포켓몬으로 돌아오면 상태 이상이 회복된다." - }, - "lightningRod": { - "name": "피뢰침", - "description": "전기타입의 기술을 자신에게 끌어모아 데미지를 받지 않고 특수공격을 올린다." - }, - "sereneGrace": { - "name": "하늘의은총", - "description": "하늘의 은총 덕분에 기술의 추가 효과가 나오기 쉽다." - }, - "swiftSwim": { - "name": "쓱쓱", - "description": "비가 오는 날씨일 때 스피드가 올라간다." - }, - "chlorophyll": { - "name": "엽록소", - "description": "날씨가 맑을 때 스피드가 올라간다." - }, - "illuminate": { - "name": "발광", - "description": "주변을 밝게 하여 명중률이 떨어지지 않는다." - }, - "trace": { - "name": "트레이스", - "description": "등장했을 때 상대의 특성을 트레이스해서 같은 특성이 된다." - }, - "hugePower": { - "name": "천하장사", - "description": "물리공격의 위력이 2배가 된다." - }, - "poisonPoint": { - "name": "독가시", - "description": "자신과 접촉한 상대를 독 상태로 만들 때가 있다." - }, - "innerFocus": { - "name": "정신력", - "description": "단련한 정신으로 인하여 상대의 공격에 풀죽지 않는다." - }, - "magmaArmor": { - "name": "마그마의무장", - "description": "뜨거운 마그마를 몸에 둘러서 얼음 상태가 되지 않는다." - }, - "waterVeil": { - "name": "수의베일", - "description": "물의 베일을 몸에 둘러서 화상 상태가 되지 않는다." - }, - "magnetPull": { - "name": "자력", - "description": "강철타입의 포켓몬을 자력으로 끌어모아 도망칠 수 없게 한다." - }, - "soundproof": { - "name": "방음", - "description": "소리를 차단하는 것으로 소리 공격을 받지 않는다." - }, - "rainDish": { - "name": "젖은접시", - "description": "비가 오는 날씨일 때 조금씩 HP를 회복한다." - }, - "sandStream": { - "name": "모래날림", - "description": "등장했을 때 날씨를 모래바람으로 만든다." - }, - "pressure": { - "name": "프레셔", - "description": "프레셔를 줘서 상대가 쓰는 기술의 PP를 많이 줄인다." - }, - "thickFat": { - "name": "두꺼운지방", - "description": "두꺼운 지방으로 보호되고 있어 불꽃타입과 얼음타입의 기술의 데미지를 반감시킨다." - }, - "earlyBird": { - "name": "일찍기상", - "description": "잠듦 상태가 되어도 2배 스피드로 깨어날 수 있다." - }, - "flameBody": { - "name": "불꽃몸", - "description": "자신과 접촉한 상대를 화상 상태로 만들 때가 있다." - }, - "runAway": { - "name": "도주", - "description": "야생 포켓몬으로부터 반드시 도망칠 수 있다." - }, - "keenEye": { - "name": "날카로운눈", - "description": "날카로운 눈 덕분에 명중률이 떨어지지 않는다." - }, - "hyperCutter": { - "name": "괴력집게", - "description": "힘이 자랑인 집게를 가지고 있어 상대가 공격을 떨어뜨리지 못한다." - }, - "pickup": { - "name": "픽업", - "description": "상대가 지닌 도구를 주워올 때가 있다." - }, - "truant": { - "name": "게으름", - "description": "기술을 사용하면 다음 턴은 쉰다." - }, - "hustle": { - "name": "의욕", - "description": "자신의 공격이 높아지지만 명중률이 떨어진다." - }, - "cuteCharm": { - "name": "헤롱헤롱바디", - "description": "자신과 접촉한 상대를 헤롱헤롱 상태로 만들 때가 있다." - }, - "plus": { - "name": "플러스", - "description": "플러스나 마이너스의 특성을 가진 포켓몬이 동료에 있으면 자신의 특수공격이 올라간다." - }, - "minus": { - "name": "마이너스", - "description": "플러스나 마이너스의 특성을 가진 포켓몬이 동료에 있으면 자신의 특수공격이 올라간다." - }, - "forecast": { - "name": "기분파", - "description": "날씨의 영향을 받아 물타입, 불꽃타입, 얼음타입 중 하나로 변화한다." - }, - "stickyHold": { - "name": "점착", - "description": "점착질의 몸에 도구가 달라붙어 있어 상대에게 도구를 뺏기지 않는다." - }, - "shedSkin": { - "name": "탈피", - "description": "몸의 껍질을 벗어 던져 상태 이상을 회복할 때가 있다." - }, - "guts": { - "name": "근성", - "description": "상태 이상이 되면 근성을 보여서 공격이 올라간다." - }, - "marvelScale": { - "name": "이상한비늘", - "description": "상태 이상이 되면 이상한 비늘이 반응해서 방어가 올라간다." - }, - "liquidOoze": { - "name": "해감액", - "description": "해감액을 흡수한 상대는 강렬한 악취로 데미지를 받아 HP가 줄어든다." - }, - "overgrow": { - "name": "심록", - "description": "HP가 줄었을 때 풀타입 기술의 위력이 올라간다." - }, - "blaze": { - "name": "맹화", - "description": "HP가 줄었을 때 불꽃타입 기술의 위력이 올라간다." - }, - "torrent": { - "name": "급류", - "description": "HP가 줄었을 때 물타입 기술의 위력이 올라간다." - }, - "swarm": { - "name": "벌레의알림", - "description": "HP가 줄었을 때 벌레타입 기술의 위력이 올라간다." - }, - "rockHead": { - "name": "돌머리", - "description": "반동을 받는 기술을 사용해도 HP가 줄지 않는다." - }, - "drought": { - "name": "가뭄", - "description": "등장했을 때 날씨를 맑음으로 만든다." - }, - "arenaTrap": { - "name": "개미지옥", - "description": "배틀에서 상대를 도망칠 수 없게 한다." - }, - "vitalSpirit": { - "name": "의기양양", - "description": "의기양양해져서 잠듦 상태가 되지 않는다." - }, - "whiteSmoke": { - "name": "하얀연기", - "description": "하얀 연기의 보호를 받아 상대가 능력을 떨어뜨릴 수 없다." - }, - "purePower": { - "name": "순수한힘", - "description": "요가의 힘으로 물리공격의 위력이 2배가 된다." - }, - "shellArmor": { - "name": "조가비갑옷", - "description": "단단한 껍질의 보호를 받아 상대의 공격이 급소에 맞지 않는다." - }, - "airLock": { - "name": "에어록", - "description": "모든 날씨의 영향이 없어진다." - }, - "tangledFeet": { - "name": "갈지자걸음", - "description": "혼란 상태일 때는 회피율이 올라간다." - }, - "motorDrive": { - "name": "전기엔진", - "description": "전기타입의 기술을 받으면 데미지를 받지 않고 스피드가 올라간다." - }, - "rivalry": { - "name": "투쟁심", - "description": "성별이 같으면 투쟁심을 불태워 강해진다. 성별이 다르면 약해진다." - }, - "steadfast": { - "name": "불굴의마음", - "description": "풀죽을 때마다 불굴의 마음을 불태워 스피드가 올라간다." - }, - "snowCloak": { - "name": "눈숨기", - "description": "날씨가 눈일 때 회피율이 올라간다." - }, - "gluttony": { - "name": "먹보", - "description": "HP가 줄어들면 먹을 나무열매를 HP가 절반일 때 먹어버린다." - }, - "angerPoint": { - "name": "분노의경혈", - "description": "급소에 공격이 맞으면 크게 분노해 공격력이 최대가 된다." - }, - "unburden": { - "name": "곡예", - "description": "지니던 도구가 없어지면 스피드가 올라간다." - }, - "heatproof": { - "name": "내열", - "description": "내열인 몸으로 인해 불꽃타입 공격의 데미지를 반감한다." - }, - "simple": { - "name": "단순", - "description": "능력 변화가 평소의 2배가 된다." - }, - "drySkin": { - "name": "건조피부", - "description": "비가 오는 날씨나 물타입의 기술로 HP가 회복되고 맑을 때나 불꽃타입의 기술로는 줄어든다." - }, - "download": { - "name": "다운로드", - "description": "상대의 방어와 특수방어를 비교해서 낮은 쪽 능력에 맞춰서 자신의 공격이나 특수공격을 올린다." - }, - "ironFist": { - "name": "철주먹", - "description": "펀치를 사용하는 기술의 위력이 올라간다." - }, - "poisonHeal": { - "name": "포이즌힐", - "description": "독 상태가 되면 HP가 줄지 않고 증가한다." - }, - "adaptability": { - "name": "적응력", - "description": "자신과 같은 타입의 기술 위력이 올라간다." - }, - "skillLink": { - "name": "스킬링크", - "description": "연속 기술을 사용하면 항상 최고 횟수를 사용할 수 있다." - }, - "hydration": { - "name": "촉촉바디", - "description": "비가 오는 날씨일 때 상태 이상이 회복된다." - }, - "solarPower": { - "name": "선파워", - "description": "날씨가 맑으면 특수공격이 올라가지만 매 턴 HP가 줄어든다." - }, - "quickFeet": { - "name": "속보", - "description": "상태 이상이 되면 스피드가 올라간다." - }, - "normalize": { - "name": "노말스킨", - "description": "어떤 타입의 기술도 모두 노말타입이 된다. 위력이 조금 올라간다." - }, - "sniper": { - "name": "스나이퍼", - "description": "공격을 급소에 맞혔을 때 위력이 더욱 올라간다." - }, - "magicGuard": { - "name": "매직가드", - "description": "공격 이외에는 데미지를 입지 않는다." - }, - "noGuard": { - "name": "노가드", - "description": "노가드전법에 따라 서로가 사용하는 기술이 반드시 맞게 된다." - }, - "stall": { - "name": "시간벌기", - "description": "기술을 사용하는 순서가 반드시 마지막이 된다." - }, - "technician": { - "name": "테크니션", - "description": "위력이 약한 기술의 위력을 올려서 공격할 수 있다." - }, - "leafGuard": { - "name": "리프가드", - "description": "날씨가 맑을 때는 상태 이상이 되지 않는다." - }, - "klutz": { - "name": "서투름", - "description": "지니고 있는 도구를 쓸 수 없다." - }, - "moldBreaker": { - "name": "틀깨기", - "description": "상대 특성에 방해받지 않고 상대에게 기술을 쓸 수 있다." - }, - "superLuck": { - "name": "대운", - "description": "대운을 가지고 있어 상대의 급소에 공격이 맞기 쉽다." - }, - "aftermath": { - "name": "유폭", - "description": "기절했을 때 접촉한 상대에게 데미지를 준다." - }, - "anticipation": { - "name": "위험예지", - "description": "상대가 지닌 위험한 기술을 감지할 수 있다." - }, - "forewarn": { - "name": "예지몽", - "description": "등장했을 때 상대가 지닌 기술을 하나만 꿰뚫어본다." - }, - "unaware": { - "name": "천진", - "description": "상대의 능력 변화를 무시하고 공격할 수 있다." - }, - "tintedLens": { - "name": "색안경", - "description": "효과가 별로인 기술을 통상의 위력으로 쓸 수 있다." - }, - "filter": { - "name": "필터", - "description": "효과가 굉장한 공격의 위력을 약하게 만든다." - }, - "slowStart": { - "name": "슬로스타트", - "description": "5턴 동안 공격과 스피드가 절반이 된다." - }, - "scrappy": { - "name": "배짱", - "description": "고스트타입 포켓몬에게 노말타입과 격투타입의 기술을 맞게 한다." - }, - "stormDrain": { - "name": "마중물", - "description": "물타입의 기술을 자신에게 끌어모아 데미지는 받지 않고 특수공격이 올라간다." - }, - "iceBody": { - "name": "아이스바디", - "description": "날씨가 눈일 때 HP를 조금씩 회복한다." - }, - "solidRock": { - "name": "하드록", - "description": "효과가 굉장한 공격의 위력을 약하게 만든다." - }, - "snowWarning": { - "name": "눈퍼뜨리기", - "description": "등장했을 때 날씨를 눈으로 만든다." - }, - "honeyGather": { - "name": "꿀모으기", - "description": "배틀이 끝났을 때 달콤한꿀을 주울 때가 있다. 배틀 후에 꿀을 팔아 돈을 받을 수 있다." - }, - "frisk": { - "name": "통찰", - "description": "등장했을 때 상대의 특성을 통찰할 수 있다." - }, - "reckless": { - "name": "이판사판", - "description": "반동 데미지를 받는 기술의 위력이 올라간다." - }, - "multitype": { - "name": "멀티타입", - "description": "지니고 있는 플레이트나 Z크리스탈 타입에 따라 자신의 타입이 바뀐다." - }, - "flowerGift": { - "name": "플라워기프트", - "description": "날씨가 맑을 때 자신과 같은 편의 공격과 특수방어의 능력이 올라간다." - }, - "badDreams": { - "name": "나이트메어", - "description": "잠듦 상태의 상대에게 데미지를 준다." - }, - "pickpocket": { - "name": "나쁜손버릇", - "description": "접촉한 상대의 도구를 훔친다." - }, - "sheerForce": { - "name": "우격다짐", - "description": "기술의 추가 효과가 없어지지만 그만큼 높은 위력으로 기술을 사용할 수 있다." - }, - "contrary": { - "name": "심술꾸러기", - "description": "능력의 변화가 역전해서 올라갈 때 떨어지고 떨어질 때 올라간다." - }, - "unnerve": { - "name": "긴장감", - "description": "상대를 긴장시켜 나무열매를 먹지 못하게 한다." - }, - "defiant": { - "name": "오기", - "description": "능력이 떨어지면 공격이 크게 올라간다." - }, - "defeatist": { - "name": "무기력", - "description": "HP가 절반이 되면 무기력해져서 공격과 특수공격이 반감된다." - }, - "cursedBody": { - "name": "저주받은바디", - "description": "공격을 받으면 상대의 기술을 사슬묶기 상태로 만들 때가 있다." - }, - "healer": { - "name": "치유의마음", - "description": "같은 편의 상태 이상을 가끔 회복시킨다." - }, - "friendGuard": { - "name": "프렌드가드", - "description": "같은 편의 데미지를 줄일 수 있다." - }, - "weakArmor": { - "name": "깨어진갑옷", - "description": "물리 기술로 데미지를 받으면 방어가 떨어지고 스피드가 크게 올라간다." - }, - "heavyMetal": { - "name": "헤비메탈", - "description": "자신의 무게가 2배가 된다." - }, - "lightMetal": { - "name": "라이트메탈", - "description": "자신의 무게가 절반이 된다." - }, - "multiscale": { - "name": "멀티스케일", - "description": "HP가 꽉 찼을 때 받는 데미지가 줄어든다." - }, - "toxicBoost": { - "name": "독폭주", - "description": "독 상태가 되었을 때 물리 기술의 위력이 올라간다." - }, - "flareBoost": { - "name": "열폭주", - "description": "화상 상태가 되었을 때 특수 기술의 위력이 올라간다." - }, - "harvest": { - "name": "수확", - "description": "사용한 나무열매를 몇 번이고 만들어 낸다." - }, - "telepathy": { - "name": "텔레파시", - "description": "같은 편의 공격의 낌새를 읽고 기술을 회피한다." - }, - "moody": { - "name": "변덕쟁이", - "description": "매 턴 능력 중 하나가 크게 오르고 하나가 떨어진다." - }, - "overcoat": { - "name": "방진", - "description": "모래바람이나 싸라기눈 등의 데미지를 입지 않는다. 가루의 기술을 받지 않는다." - }, - "poisonTouch": { - "name": "독수", - "description": "접촉하기만 해도 상대를 독 상태로 만들 때가 있다." - }, - "regenerator": { - "name": "재생력", - "description": "지닌 포켓몬으로 돌아오면 HP를 조금 회복한다." - }, - "bigPecks": { - "name": "부풀린가슴", - "description": "방어를 떨어뜨리는 효과를 받지 않는다." - }, - "sandRush": { - "name": "모래헤치기", - "description": "날씨가 모래바람일 때 스피드가 올라간다." - }, - "wonderSkin": { - "name": "미라클스킨", - "description": "변화 기술을 받기 어려운 몸으로 되어 있다." - }, - "analytic": { - "name": "애널라이즈", - "description": "제일 마지막에 기술을 쓰면 기술의 위력이 올라간다." - }, - "illusion": { - "name": "일루전", - "description": "지닌 포켓몬 중 제일 뒤에 있는 포켓몬으로 둔갑하여 나와서 상대를 속인다." - }, - "imposter": { - "name": "괴짜", - "description": "눈앞의 포켓몬으로 변신해버린다." - }, - "infiltrator": { - "name": "틈새포착", - "description": "상대의 벽이나 대타출동을 뚫고 공격할 수 있다." - }, - "mummy": { - "name": "미라", - "description": "상대가 접촉하면 상대를 미라로 만들어버린다." - }, - "moxie": { - "name": "자기과신", - "description": "상대를 쓰러뜨리면 자신감이 붙어서 공격이 올라간다." - }, - "justified": { - "name": "정의의마음", - "description": "악타입 공격을 받으면 정의감으로 공격이 올라간다." - }, - "rattled": { - "name": "주눅", - "description": "위협이나 악타입과 고스트타입과 벌레타입의 기술에 주눅이 들어 스피드가 올라간다." - }, - "magicBounce": { - "name": "매직미러", - "description": "상대가 쓴 변화 기술을 받지 않고 그대로 되받아칠 수 있다." - }, - "sapSipper": { - "name": "초식", - "description": "풀타입 기술을 받으면 데미지를 입지 않고 공격이 올라간다." - }, - "prankster": { - "name": "짓궂은마음", - "description": "변화 기술을 먼저 쓸 수 있다." - }, - "sandForce": { - "name": "모래의힘", - "description": "날씨가 모래바람일 때 바위타입과 땅타입과 강철타입의 위력이 올라간다." - }, - "ironBarbs": { - "name": "철가시", - "description": "자신과 접촉한 상대에게 철가시로 데미지를 준다." - }, - "zenMode": { - "name": "달마모드", - "description": "HP가 절반 이하가 되면 모습이 변화한다." - }, - "victoryStar": { - "name": "승리의별", - "description": "자신과 같은 편의 명중률이 올라간다." - }, - "turboblaze": { - "name": "터보블레이즈", - "description": "상대 특성에 방해받지 않고 상대에게 기술을 쓸 수 있다." - }, - "teravolt": { - "name": "테라볼티지", - "description": "상대 특성에 방해받지 않고 상대에게 기술을 쓸 수 있다." - }, - "aromaVeil": { - "name": "아로마베일", - "description": "자신과 같은 편으로 향하는 멘탈 공격을 막을 수 있다." - }, - "flowerVeil": { - "name": "플라워베일", - "description": "같은 편의 풀타입 포켓몬은 능력이 떨어지지 않고 상태 이상도 되지 않는다." - }, - "cheekPouch": { - "name": "볼주머니", - "description": "어떤 나무열매라도 먹으면 HP도 회복한다." - }, - "protean": { - "name": "변환자재", - "description": "자신이 사용한 기술과 같은 타입으로 변화한다." - }, - "furCoat": { - "name": "퍼코트", - "description": "상대로부터 받는 물리 기술의 데미지가 절반이 된다." - }, - "magician": { - "name": "매지션", - "description": "기술을 맞은 상대의 도구를 빼앗아 버린다." - }, - "bulletproof": { - "name": "방탄", - "description": "상대 구슬이나 폭탄 등 기술을 막을 수 있다." - }, - "competitive": { - "name": "승기", - "description": "능력이 떨어지면 특수공격이 크게 올라간다." - }, - "strongJaw": { - "name": "옹골찬턱", - "description": "턱이 튼튼하여 무는 기술의 위력이 올라간다." - }, - "refrigerate": { - "name": "프리즈스킨", - "description": "노말타입의 기술이 얼음타입이 된다. 위력이 조금 올라간다." - }, - "sweetVeil": { - "name": "스위트베일", - "description": "같은 편의 포켓몬이 잠들지 않게 된다." - }, - "stanceChange": { - "name": "배틀스위치", - "description": "공격 기술을 쓰면 블레이드폼으로 기술 킹실드를 쓰면 실드폼으로 변한다." - }, - "galeWings": { - "name": "질풍날개", - "description": "HP가 꽉 찼을 때 비행타입의 기술을 먼저 쓸 수 있다." - }, - "megaLauncher": { - "name": "메가런처", - "description": "파동 기술의 위력이 올라간다." - }, - "grassPelt": { - "name": "풀모피", - "description": "그래스필드일 때 방어가 올라간다." - }, - "symbiosis": { - "name": "공생", - "description": "같은 편이 도구를 쓰면 자신이 지니고 있는 도구를 같은 편에게 건넨다." - }, - "toughClaws": { - "name": "단단한발톱", - "description": "상대에게 접촉하는 기술의 위력이 올라간다." - }, - "pixilate": { - "name": "페어리스킨", - "description": "노말타입의 기술이 페어리타입이 된다. 위력이 조금 올라간다." - }, - "gooey": { - "name": "미끈미끈", - "description": "공격으로 자신과 접촉한 상대의 스피드를 떨어뜨린다." - }, - "aerilate": { - "name": "스카이스킨", - "description": "노말타입의 기술이 비행타입이 된다. 위력이 조금 올라간다." - }, - "parentalBond": { - "name": "부자유친", - "description": "부모와 자식 2마리로 2번 공격할 수 있다." - }, - "darkAura": { - "name": "다크오라", - "description": "전원의 악타입 기술이 강해진다." - }, - "fairyAura": { - "name": "페어리오라", - "description": "전원의 페어리타입 기술이 강해진다." - }, - "auraBreak": { - "name": "오라브레이크", - "description": "오라의 효과를 역전시켜 위력을 떨어뜨린다." - }, - "primordialSea": { - "name": "시작의바다", - "description": "불꽃타입의 공격을 받지 않는 날씨로 만든다." - }, - "desolateLand": { - "name": "끝의대지", - "description": "물타입의 공격을 받지 않는 날씨로 만든다." - }, - "deltaStream": { - "name": "델타스트림", - "description": "비행타입의 약점이 없어지는 날씨로 만든다." - }, - "stamina": { - "name": "지구력", - "description": "공격을 받으면 방어가 올라간다." - }, - "wimpOut": { - "name": "도망태세", - "description": "HP가 절반이 되면 황급히 도망쳐서 지닌 포켓몬으로 돌아간다." - }, - "emergencyExit": { - "name": "위기회피", - "description": "HP가 절반이 되면 위험을 회피하기 위해 지닌 포켓몬으로 돌아간다." - }, - "waterCompaction": { - "name": "꾸덕꾸덕굳기", - "description": "물타입의 기술을 받으면 방어가 크게 올라간다." - }, - "merciless": { - "name": "무도한행동", - "description": "독 상태의 상대를 공격하면 반드시 급소에 맞는다." - }, - "shieldsDown": { - "name": "리밋실드", - "description": "HP가 절반이 되면 껍질이 깨져 공격적으로 된다." - }, - "stakeout": { - "name": "잠복", - "description": "교체로 나온 상대에게 2배 데미지로 공격할 수 있다." - }, - "waterBubble": { - "name": "수포", - "description": "자신을 향하는 불꽃타입 기술의 위력을 떨어뜨린다. 화상을 입지 않는다." - }, - "steelworker": { - "name": "강철술사", - "description": "강철타입 기술의 위력이 올라간다." - }, - "berserk": { - "name": "발끈", - "description": "상대의 공격으로 HP가 절반이 되면 특수공격이 올라간다." - }, - "slushRush": { - "name": "눈치우기", - "description": "날씨가 눈일 때 스피드가 올라간다." - }, - "longReach": { - "name": "원격", - "description": "모든 기술을 상대에게 접촉하지 않고 사용할 수 있다." - }, - "liquidVoice": { - "name": "촉촉보이스", - "description": "모든 소리 기술이 물타입이 된다." - }, - "triage": { - "name": "힐링시프트", - "description": "회복 기술을 먼저 사용할 수 있다." - }, - "galvanize": { - "name": "일렉트릭스킨", - "description": "노말타입 기술이 전기타입이 된다. 위력이 조금 올라간다." - }, - "surgeSurfer": { - "name": "서핑테일", - "description": "일렉트릭필드일 때 스피드가 2배가 된다." - }, - "schooling": { - "name": "어군", - "description": "HP가 많을 때 무리지어 강해진다. HP가 얼마 남지 않으면 무리는 뿔뿔이 흩어진다." - }, - "disguise": { - "name": "탈", - "description": "몸을 덮는 탈로 1번 공격을 막을 수 있다." - }, - "battleBond": { - "name": "유대변화", - "description": "상대를 쓰러뜨리면 트레이너와의 유대감이 깊어져서 지우개굴닌자로 변한다. 물수리검이 강해진다." - }, - "powerConstruct": { - "name": "스웜체인지", - "description": "HP가 절반이 되면 셀들이 응원하러 달려와 퍼펙트폼으로 모습이 변한다." - }, - "corrosion": { - "name": "부식", - "description": "강철타입이나 독타입도 독 상태로 만들 수 있다." - }, - "comatose": { - "name": "절대안깸", - "description": "항상 비몽사몽 상태로 절대 깨지 않는다. 잠든 상태로 공격할 수 있다." - }, - "queenlyMajesty": { - "name": "여왕의위엄", - "description": "상대에게 위압감을 줘서 이쪽을 향한 선제 기술을 사용할 수 없게 한다." - }, - "innardsOut": { - "name": "내용물분출", - "description": "상대가 쓰러뜨렸을 때 HP의 남은 양만큼 상대에게 데미지를 준다." - }, - "dancer": { - "name": "무희", - "description": "누군가 춤 기술을 쓰면 자신도 이어서 춤 기술을 쓸 수 있다." - }, - "battery": { - "name": "배터리", - "description": "같은 편 특수 기술의 위력을 올린다." - }, - "fluffy": { - "name": "복슬복슬", - "description": "상대로부터 받은 접촉하는 기술의 데미지를 반감시키지만 불꽃타입 기술의 데미지는 2배가 된다." - }, - "dazzling": { - "name": "비비드바디", - "description": "상대를 놀라게 해서 이쪽을 향한 선제 기술을 사용할 수 없게 한다." - }, - "soulHeart": { - "name": "소울하트", - "description": "포켓몬이 기절할 때마다 특수공격이 올라간다." - }, - "tanglingHair": { - "name": "컬리헤어", - "description": "공격으로 자신에게 접촉한 상대의 스피드를 떨어뜨린다." - }, - "receiver": { - "name": "리시버", - "description": "쓰러진 같은 편의 특성을 이어받아 같은 특성으로 바뀐다." - }, - "powerOfAlchemy": { - "name": "화학의힘", - "description": "쓰러진 같은 편의 특성을 이어받아 같은 특성으로 바뀐다." - }, - "beastBoost": { - "name": "비스트부스트", - "description": "상대를 기절시켰을 때 자신의 가장 높은 능력이 올라간다." - }, - "rksSystem": { - "name": "AR시스템", - "description": "지니고 있는 메모리로 자신의 타입이 변한다." - }, - "electricSurge": { - "name": "일렉트릭메이커", - "description": "등장했을 때 일렉트릭필드를 사용한다." - }, - "psychicSurge": { - "name": "사이코메이커", - "description": "등장했을 때 사이코필드를 사용한다." - }, - "mistySurge": { - "name": "미스트메이커", - "description": "등장했을 때 미스트필드를 사용한다." - }, - "grassySurge": { - "name": "그래스메이커", - "description": "등장했을 때 그래스필드를 사용한다." - }, - "fullMetalBody": { - "name": "메탈프로텍트", - "description": "상대 기술이나 특성으로 능력이 떨어지지 않는다." - }, - "shadowShield": { - "name": "스펙터가드", - "description": "HP가 꽉 찼을 때 받는 데미지가 줄어든다." - }, - "prismArmor": { - "name": "프리즘아머", - "description": "효과가 굉장한 공격의 위력을 약하게 만든다." - }, - "neuroforce": { - "name": "브레인포스", - "description": "효과가 굉장한 공격의 위력이 더욱 올라간다." - }, - "intrepidSword": { - "name": "불요의검", - "description": "등장했을 때 공격이 올라간다." - }, - "dauntlessShield": { - "name": "불굴의방패", - "description": "등장했을 때 방어가 올라간다." - }, - "libero": { - "name": "리베로", - "description": "자신이 사용한 기술과 같은 타입으로 변화한다." - }, - "ballFetch": { - "name": "볼줍기", - "description": "첫 번째로 실패한 몬스터볼을 주워온다." - }, - "cottonDown": { - "name": "솜털", - "description": "공격을 받으면 솜털을 흩뿌려서 자신을 제외한 모든 포켓몬의 스피드를 떨어뜨린다." - }, - "propellerTail": { - "name": "스크루지느러미", - "description": "상대의 기술을 끌어모으는 특성이나 기술의 영향을 받지 않는다." - }, - "mirrorArmor": { - "name": "미러아머", - "description": "자신이 받는 능력 다운 효과에 한해 되받아친다." - }, - "gulpMissile": { - "name": "그대로꿀꺽미사일", - "description": "파도타기나 다이빙을 쓰면 먹이를 물어온다. 데미지를 받으면 먹이를 토해내서 공격한다." - }, - "stalwart": { - "name": "굳건한신념", - "description": "상대의 기술을 끌어모으는 특성이나 기술의 영향을 받지 않는다." - }, - "steamEngine": { - "name": "증기기관", - "description": "물타입이나 불꽃타입 기술을 받으면 스피드가 매우 크게 올라간다." - }, - "punkRock": { - "name": "펑크록", - "description": "소리 기술의 위력이 올라간다. 상대로부터 받는 소리 기술의 데미지는 절반이 된다." - }, - "sandSpit": { - "name": "모래뿜기", - "description": "공격을 받으면 모래바람을 일으킨다." - }, - "iceScales": { - "name": "얼음인분", - "description": "얼음인분의 보호를 받아 특수공격으로 받는 데미지가 절반이 된다." - }, - "ripen": { - "name": "숙성", - "description": "나무열매를 숙성시켜서 효과가 2배가 된다." - }, - "iceFace": { - "name": "아이스페이스", - "description": "물리공격을 머리의 얼음이 대신 맞아주지만 모습도 바뀐다. 얼음은 싸라기눈이 내리면 원래대로 돌아온다." - }, - "powerSpot": { - "name": "파워스폿", - "description": "옆에 있기만 해도 기술의 위력이 올라간다." - }, - "mimicry": { - "name": "의태", - "description": "필드의 상태에 따라 포켓몬의 타입이 바뀐다." - }, - "screenCleaner": { - "name": "배리어프리", - "description": "등장했을 때 상대와 같은 편의 빛의장막, 리플렉터, 오로라베일의 효과가 사라진다." - }, - "steelySpirit": { - "name": "강철정신", - "description": "같은 편의 강철타입 공격의 위력이 올라간다." - }, - "perishBody": { - "name": "멸망의바디", - "description": "접촉하는 기술을 받으면 3턴 후에 양쪽 모두 기절한다. 교체되면 효과가 없어진다." - }, - "wanderingSpirit": { - "name": "떠도는영혼", - "description": "접촉하는 기술로 공격해온 포켓몬과 특성을 바꾼다." - }, - "gorillaTactics": { - "name": "무아지경", - "description": "공격이 올라가지만 처음에 선택한 기술 외에는 쓸 수 없게 된다." - }, - "neutralizingGas": { - "name": "화학변화가스", - "description": "화학변화가스를 가진 포켓몬이 배틀에 나와 있으면 모든 포켓몬이 가진 특성의 효과가 사라지거나 발동하지 않게 된다." - }, - "pastelVeil": { - "name": "파스텔베일", - "description": "자신과 같은 편이 독의 상태 이상 효과를 받지 않게 된다." - }, - "hungerSwitch": { - "name": "꼬르륵스위치", - "description": "턴이 끝날 때마다 배부른 모양, 배고픈 모양, 배부른 모양...으로 번갈아서 모습을 바꾼다." - }, - "quickDraw": { - "name": "퀵드로", - "description": "상대보다 먼저 행동할 수도 있다." - }, - "unseenFist": { - "name": "보이지않는주먹", - "description": "상대에게 접촉하는 기술을 사용하면 방어의 효과를 무시하고 공격할 수 있다." - }, - "curiousMedicine": { - "name": "기묘한약", - "description": "등장했을 때 조개껍질에서 약을 흩뿌려서 능력 변화를 원래대로 되돌린다." - }, - "transistor": { - "name": "트랜지스터", - "description": "전기타입 기술의 위력이 올라간다." - }, - "dragonsMaw": { - "name": "용의턱", - "description": "드래곤타입 기술의 위력이 올라간다." - }, - "chillingNeigh": { - "name": "백의울음", - "description": "상대를 쓰러뜨리면 차가운 울음소리를 내면서 공격이 올라간다." - }, - "grimNeigh": { - "name": "흑의울음", - "description": "상대를 쓰러뜨리면 무서운 울음소리를 내면서 특수공격이 올라간다." - }, - "asOneGlastrier": { - "name": "혼연일체", - "description": "버드렉스의 긴장감과 블리자포스의 백의울음 두 가지 특성을 겸비한다." - }, - "asOneSpectrier": { - "name": "혼연일체", - "description": "버드렉스의 긴장감과 레이스포스의 흑의울음 두 가지 특성을 겸비한다." - }, - "lingeringAroma": { - "name": "가시지않는향기", - "description": "상대가 접촉하면 가시지 않는 향기가 상대에게 배어 버린다." - }, - "seedSower": { - "name": "넘치는씨", - "description": "공격을 받으면 필드를 그래스필드로 만든다." - }, - "thermalExchange": { - "name": "열교환", - "description": "불꽃타입 기술로 공격받으면 공격이 올라간다. 화상 상태가 되지 않는다." - }, - "angerShell": { - "name": "분노의껍질", - "description": "상대의 공격에 의해 HP가 절반이 되면 화가 나서 방어와 특수방어가 떨어지지만 공격, 특수공격, 스피드가 올라간다." - }, - "purifyingSalt": { - "name": "정화의소금", - "description": "깨끗한 소금에 의해 상태 이상이 되지 않는다. 고스트타입 기술의 데미지를 반감시킨다." - }, - "wellBakedBody": { - "name": "노릇노릇바디", - "description": "불꽃타입 기술로 공격받으면 데미지를 입지 않고 방어가 크게 올라간다." - }, - "windRider": { - "name": "바람타기", - "description": "순풍이 불거나 바람 기술로 공격받으면 데미지를 받지 않고 공격이 올라간다." - }, - "guardDog": { - "name": "파수견", - "description": "위협을 받으면 공격이 올라간다. 포켓몬을 교체시키는 기술이나 도구의 효과를 받지 않는다." - }, - "rockyPayload": { - "name": "바위나르기", - "description": "바위타입 기술의 위력이 올라간다." - }, - "windPower": { - "name": "풍력발전", - "description": "바람 기술로 공격받으면 충전 상태가 된다." - }, - "zeroToHero": { - "name": "마이티체인지", - "description": "지닌 포켓몬으로 돌아오면 마이티폼으로 변한다." - }, - "commander": { - "name": "사령탑", - "description": "등장했을 때 같은 편에 어써러셔가 있으면 입속에 들어가 안에서 지시를 내린다." - }, - "electromorphosis": { - "name": "전기로바꾸기", - "description": "데미지를 받으면 충전 상태가 된다." - }, - "protosynthesis": { - "name": "고대활성", - "description": "부스트에너지를 지니고 있거나 날씨가 맑을 때 가장 높은 능력이 올라간다." - }, - "quarkDrive": { - "name": "쿼크차지", - "description": "부스트에너지를 지니고 있거나 일렉트릭필드일 때 가장 높은 능력이 올라간다." - }, - "goodAsGold": { - "name": "황금몸", - "description": "산화하지 않는 튼튼한 황금몸 덕분에 상대의 변화 기술의 영향을 받지 않는다." - }, - "vesselOfRuin": { - "name": "재앙의그릇", - "description": "재앙을 부르는 그릇의 힘으로 자신을 제외한 모든 포켓몬의 특수 공격을 약하게 만든다." - }, - "swordOfRuin": { - "name": "재앙의검", - "description": "재앙을 부르는 검의 힘으로 자신을 제외한 모든 포켓몬의 방어를 약하게 만든다." - }, - "tabletsOfRuin": { - "name": "재앙의목간", - "description": "재앙을 부르는 목간의 힘으로 자신을 제외한 모든 포켓몬의 공격을 약하게 만든다." - }, - "beadsOfRuin": { - "name": "재앙의구슬", - "description": "재앙을 부르는 곡옥의 힘으로 자신을 제외한 모든 포켓몬의 특수방어를 약하게 만든다." - }, - "orichalcumPulse": { - "name": "진홍빛고동", - "description": "등장했을 때 날씨를 맑음으로 만든다. 햇살이 강하면 고대의 고동에 의해 공격이 강화된다." - }, - "hadronEngine": { - "name": "하드론엔진", - "description": "등장했을 때 일렉트릭필드를 전개한다. 일렉트릭필드일 때 미래 기관에 의해 특수공격이 강화된다." - }, - "opportunist": { - "name": "편승", - "description": "상대의 능력이 올라가면 자신도 편승해서 똑같이 자신도 올린다." - }, - "cudChew": { - "name": "되새김질", - "description": "한 번에 한하여 나무열매를 먹으면 다음 턴이 끝날 때 위에서 꺼내서 또 먹는다." - }, - "sharpness": { - "name": "예리함", - "description": "상대를 베는 기술의 위력이 올라간다." - }, - "supremeOverlord": { - "name": "총대장", - "description": "등장했을 때 지금까지 쓰러진 같은 편의 수가 많을수록 조금씩 공격과 특수공격이 올라간다." - }, - "costar": { - "name": "협연", - "description": "등장했을 때 같은 편의 능력 변화를 복사한다." - }, - "toxicDebris": { - "name": "독치장", - "description": "물리 기술로 데미지를 받으면 상대의 발밑에 독압정을 뿌린다." - }, - "armorTail": { - "name": "테일아머", - "description": "머리를 감싸고 있는 수수께끼의 꼬리가 이쪽을 향한 선제 기술을 사용할 수 없게 한다." - }, - "earthEater": { - "name": "흙먹기", - "description": "땅타입의 기술로 공격받으면 데미지를 받지 않고 회복한다." - }, - "myceliumMight": { - "name": "균사의힘", - "description": "변화 기술을 사용할 때 반드시 행동이 느려지지만 상대 특성에 방해받지 않는다." - }, - "mindsEye": { - "name": "심안", - "description": "노말타입과 격투타입 기술을 고스트타입에게 맞힐 수 있다. 상대의 회피율 변화를 무시하고 명중률도 떨어지지 않는다." - }, - "supersweetSyrup": { - "name": "감미로운꿀", - "description": "처음 등장했을 때 감미로운 꿀의 향기를 흩뿌려서 상대의 회피율을 떨어뜨린다." - }, - "hospitality": { - "name": "대접", - "description": "등장했을 때 같은 편을 대접해서 HP를 조금 회복시킨다." - }, - "toxicChain": { - "name": "독사슬", - "description": "독소를 머금은 사슬의 힘으로 기술에 맞은 상대를 맹독 상태로 만들 때가 있다." - }, - "embodyAspectTeal": { - "name": "초상투영", - "description": "마음속에 깃든 추억의 힘으로 벽록의가면을 빛나게 하여 자신의 스피드를 올린다." - }, - "embodyAspectWellspring": { - "name": "초상투영", - "description": "마음속에 깃든 추억의 힘으로 우물의가면을 빛나게 하여 자신의 특수방어를 올린다." - }, - "embodyAspectHearthflame": { - "name": "초상투영", - "description": "마음속에 깃든 추억의 힘으로 화덕의가면을 빛나게 하여 자신의 공격력을 올린다." - }, - "embodyAspectCornerstone": { - "name": "초상투영", - "description": "마음속에 깃든 추억의 힘으로 주춧돌의가면을 빛나게 하여 자신의 방어력을 올린다." - }, - "teraShift": { - "name": "테라체인지", - "description": "등장했을 때 주위의 에너지를 흡수하여 테라스탈폼으로 변한다." - }, - "teraShell": { - "name": "테라셸", - "description": "모든 타입의 힘이 담긴 등껍질이 HP가 꽉 찼을 때 받는 데미지를 모두 효과가 별로이게 만든다." - }, - "teraformZero": { - "name": "제로포밍", - "description": "테라파고스가 스텔라폼이 되었을 때 숨겨진 힘에 의해 날씨와 필드의 영향을 모두 무효로 만든다." - }, - "poisonPuppeteer": { - "name": "독조종", - "description": "복숭악동의 기술에 의해 독 상태가 된 상대는 혼란 상태도 되어 버린다." - } -} \ No newline at end of file diff --git a/src/locales/ko/achv.json b/src/locales/ko/achv.json deleted file mode 100644 index 9364c1c55b6..00000000000 --- a/src/locales/ko/achv.json +++ /dev/null @@ -1,268 +0,0 @@ -{ - "Achievements": { - "name": "업적" - }, - "Locked": { - "name": "미완료" - }, - "MoneyAchv": { - "description": "누적 소지금 ₽{{moneyAmount}} 달성" - }, - "10K_MONEY": { - "name": "돈 좀 있나?" - }, - "100K_MONEY": { - "name": "부자" - }, - "1M_MONEY": { - "name": "백만장자" - }, - "10M_MONEY": { - "name": "상위 1프로" - }, - "DamageAchv": { - "description": "한 번의 공격만으로 {{damageAmount}} 데미지" - }, - "250_DMG": { - "name": "강타자" - }, - "1000_DMG": { - "name": "최강타자" - }, - "2500_DMG": { - "name": "때릴 줄 아시는군요!" - }, - "10000_DMG": { - "name": "원펀맨" - }, - "HealAchv": { - "description": "기술이나 특성, 지닌 도구로 한 번에 {{healAmount}} {{HP}} 회복" - }, - "250_HEAL": { - "name": "견습 힐러" - }, - "1000_HEAL": { - "name": "상급 힐러" - }, - "2500_HEAL": { - "name": "클레릭" - }, - "10000_HEAL": { - "name": "회복 마스터" - }, - "LevelAchv": { - "description": "포켓몬 Lv{{level}} 달성" - }, - "LV_100": { - "name": "잠깐, 여기가 끝이 아니라구!" - }, - "LV_250": { - "name": "엘리트" - }, - "LV_1000": { - "name": "더 먼 곳을 향해" - }, - "RibbonAchv": { - "description": "총 {{ribbonAmount}}개의 리본 획득" - }, - "10_RIBBONS": { - "name": "포켓몬 리그 챔피언" - }, - "25_RIBBONS": { - "name": "슈퍼 리그 챔피언" - }, - "50_RIBBONS": { - "name": "하이퍼 리그 챔피언" - }, - "75_RIBBONS": { - "name": "로그 리그 챔피언" - }, - "100_RIBBONS": { - "name": "마스터 리그 챔피언" - }, - "TRANSFER_MAX_STAT_STAGE": { - "name": "팀워크", - "description": "한 개 이상의 능력치가 최대 랭크일 때 배턴터치 사용" - }, - "MAX_FRIENDSHIP": { - "name": "친밀 맥스", - "description": "최대 친밀도 달성" - }, - "MEGA_EVOLVE": { - "name": "메가변환", - "description": "포켓몬을 메가진화" - }, - "GIGANTAMAX": { - "name": "엄청난 것", - "description": "포켓몬을 다이맥스" - }, - "TERASTALLIZE": { - "name": "반짝반짝", - "description": "포켓몬을 테라스탈" - }, - "STELLAR_TERASTALLIZE": { - "name": "숨겨진 타입", - "description": "포켓몬을 스텔라 테라스탈" - }, - "SPLICE": { - "name": "끝없는 융합", - "description": "유전자쐐기로 두 포켓몬을 융합" - }, - "MINI_BLACK_HOLE": { - "name": "도구가 가득한 구멍", - "description": "미니 블랙홀 획득" - }, - "CATCH_MYTHICAL": { - "name": "환상", - "description": "환상의 포켓몬 포획" - }, - "CATCH_SUB_LEGENDARY": { - "name": "(준)전설", - "description": "준전설 포켓몬 포획" - }, - "CATCH_LEGENDARY": { - "name": "전설", - "description": "전설의 포켓몬 포획" - }, - "SEE_SHINY": { - "name": "다른 색", - "description": "야생의 색이 다른 포켓몬 발견" - }, - "SHINY_PARTY": { - "name": "찐사랑", - "description": "색이 다른 포켓몬만으로 파티 구성" - }, - "HATCH_MYTHICAL": { - "name": "환상의 알", - "description": "알에서 환상의 포켓몬이 부화" - }, - "HATCH_SUB_LEGENDARY": { - "name": "준전설 알", - "description": "알에서 준전설 포켓몬이 부화" - }, - "HATCH_LEGENDARY": { - "name": "전설의 알", - "description": "알에서 전설의 포켓몬이 부화" - }, - "HATCH_SHINY": { - "name": "빛나는 알", - "description": "알에서 색이 다른 포켓몬이 부화" - }, - "HIDDEN_ABILITY": { - "name": "숨은 잠재력", - "description": "숨겨진 특성을 지닌 포켓몬을 포획" - }, - "PERFECT_IVS": { - "name": "진짜배기 증명서", - "description": "최고의 개체값을 지닌 포켓몬 획득" - }, - "CLASSIC_VICTORY": { - "name": "무패", - "description": "클래식 모드 클리어" - }, - "UNEVOLVED_CLASSIC_VICTORY": { - "name": "우리집 꿈나무", - "description": "최종 진화형이 아닌 포켓몬을 데리고 클래식 모드 클리어." - }, - "MONO_GEN_ONE": { - "name": "근본 라이벌", - "description": "1세대 챌린지 모드 클리어." - }, - "MONO_GEN_TWO": { - "name": "이거 1.5세대죠?", - "description": "2세대 챌린지 모드 클리어." - }, - "MONO_GEN_THREE": { - "name": "Too much water?", - "description": "3세대 챌린지 모드 클리어." - }, - "MONO_GEN_FOUR": { - "name": "난천이 진짜 최강인가요?", - "description": "4세대 챌린지 모드 클리어." - }, - "MONO_GEN_FIVE": { - "name": "100% 오리지널!", - "description": "5세대 챌린지 모드 클리어." - }, - "MONO_GEN_SIX": { - "name": "크루아상 안에 뭐 들었나요?", - "description": "6세대 챌린지 모드 클리어." - }, - "MONO_GEN_SEVEN": { - "name": "기술적으로는…", - "description": "7세대 챌린지 모드 클리어." - }, - "MONO_GEN_EIGHT": { - "name": "챔피언 타임!", - "description": "8세대 챌린지 모드 클리어." - }, - "MONO_GEN_NINE": { - "name": "걔, 봐 준 거야", - "description": "9세대 챌린지 모드 클리어." - }, - "MonoType": { - "description": "{{type}} 타입 챌린지 모드 클리어." - }, - "MONO_NORMAL": { - "name": "심플한 것이 가장 강한 것" - }, - "MONO_FIGHTING": { - "name": "태권도 할 줄 알아요" - }, - "MONO_FLYING": { - "name": "추락하는 것은 날개가 있다" - }, - "MONO_POISON": { - "name": "관동 지방 최애 타입" - }, - "MONO_GROUND": { - "name": "전기 안 통해요" - }, - "MONO_ROCK": { - "name": "웅골참" - }, - "MONO_BUG": { - "name": "독침붕처럼 쏴라" - }, - "MONO_GHOST": { - "name": "무서운 게 딱 좋아!" - }, - "MONO_STEEL": { - "name": "강철 심장" - }, - "MONO_FIRE": { - "name": "불타오르네" - }, - "MONO_WATER": { - "name": "물 들어올 때 노 젓기" - }, - "MONO_GRASS": { - "name": "초록은 동색" - }, - "MONO_ELECTRIC": { - "name": "찌릿찌릿" - }, - "MONO_PSYCHIC": { - "name": "1세대 최강" - }, - "MONO_ICE": { - "name": "얼음땡" - }, - "MONO_DRAGON": { - "name": "용용 죽겠지" - }, - "MONO_DARK": { - "name": "어둠의 다크" - }, - "MONO_FAIRY": { - "name": "설마 자시안으로?" - }, - "FRESH_START": { - "name": "첫트!", - "description": "새 출발 챌린지 모드 클리어." - }, - "INVERSE_BATTLE": { - "name": "상성 전문가(였던 것)", - "description": "거꾸로 배틀 챌린지 모드 클리어." - } -} diff --git a/src/locales/ko/arena-flyout.json b/src/locales/ko/arena-flyout.json deleted file mode 100644 index e4b271691a5..00000000000 --- a/src/locales/ko/arena-flyout.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "activeBattleEffects": "배틀 효과 상태", - "player": "플레이어", - "neutral": "공통", - "enemy": "상대", - "sunny": "쾌청", - "rain": "비", - "sandstorm": "모래바람", - "hail": "싸라기눈", - "snow": "눈", - "fog": "안개", - "heavyRain": "강한 비", - "harshSun": "강한 쾌청", - "strongWinds": "난기류", - "misty": "미스트필드", - "electric": "일렉트릭필드", - "grassy": "그래스필드", - "psychic": "사이코필드", - "mudSport": "흙놀이", - "waterSport": "물놀이", - "spikes": "압정", - "toxicSpikes": "독압정", - "mist": "흰안개", - "futureSight": "미래예지", - "doomDesire": "파멸의소원", - "wish": "희망사항", - "stealthRock": "스텔스록", - "stickyWeb": "끈적끈적네트", - "trickRoom": "트릭룸", - "gravity": "중력", - "reflect": "리플렉터", - "lightScreen": "빛의장막", - "auroraVeil": "오로라베일", - "quickGuard": "패스트가드", - "wideGuard": "와이드가드", - "matBlock": "마룻바닥세워막기", - "craftyShield": "트릭가드", - "tailwind": "순풍", - "happyHour": "해피타임", - "safeguard": "신비의부적" -} diff --git a/src/locales/ko/arena-tag.json b/src/locales/ko/arena-tag.json deleted file mode 100644 index ce9922ab3bf..00000000000 --- a/src/locales/ko/arena-tag.json +++ /dev/null @@ -1,57 +0,0 @@ -{ - "yourTeam": "우리 편", - "opposingTeam": "상대 편", - "arenaOnRemove": "{{moveName}}의 효과가 사라졌다!", - "arenaOnRemovePlayer": "우리 편 {{moveName}}의\n효과가 사라졌다!", - "arenaOnRemoveEnemy": "상대 편 {{moveName}}의\n효과가 사라졌다!", - "mistOnAdd": "{{pokemonNameWithAffix}} 편은\n흰안개에 둘러싸였다!", - "mistApply": "흰안개의 효과로\n능력은 떨어지지 않는다!", - "reflectOnAdd": "리플렉터로\n물리공격에 강해졌다!", - "reflectOnAddPlayer": "우리 편은 리플렉터로\n물리공격에 강해졌다!", - "reflectOnAddEnemy": "상대는 리플렉터로\n물리공격에 강해졌다!", - "lightScreenOnAdd": "빛의장막으로\n특수공격에 강해졌다!", - "lightScreenOnAddPlayer": "우리 편은 빛의장막으로\n특수공격에 강해졌다!", - "lightScreenOnAddEnemy": "상대는 빛의장막으로\n특수공격에 강해졌다!", - "auroraVeilOnAdd": "오로라베일로\n물리공격과 특수공격에 강해졌다!", - "auroraVeilOnAddPlayer": "우리 편은 오로라베일로\n물리공격과 특수공격에 강해졌다!", - "auroraVeilOnAddEnemy": "상대는 오로라베일로\n물리공격과 특수공격에 강해졌다!", - "conditionalProtectOnAdd": "팀을\n{{moveName}}[[가]] 보호하고 있다!", - "conditionalProtectOnAddPlayer": "우리 편 주변을\n{{moveName}}[[가]] 보호하고 있다!", - "conditionalProtectOnAddEnemy": "상대 주변을\n{{moveName}}[[가]] 보호하고 있다!", - "conditionalProtectApply": "{{pokemonNameWithAffix}}[[를]]\n{{moveName}}[[가]] 지켜주고 있다!", - "matBlockOnAdd": "{{pokemonNameWithAffix}}[[는]]\n마룻바닥세워막기를 노리고 있다!", - "noCritOnAddPlayer": "{{moveName}}의 힘으로\n우리 편의 급소가 숨겨졌다!", - "noCritOnAddEnemy": "{{moveName}}의 힘으로\n상대의 급소가 숨겨졌다!", - "noCritOnRemove": "{{pokemonNameWithAffix}}의 {{moveName}}[[가]] 풀렸다!", - "wishTagOnAdd": "{{pokemonNameWithAffix}}의\n희망사항이 이루어졌다!", - "mudSportOnAdd": "전기의 위력이 약해졌다!", - "mudSportOnRemove": "흙놀이의 효과가\n없어졌다!", - "waterSportOnAdd": "불꽃의 위력이 약해졌다!", - "waterSportOnRemove": "물놀이의 효과가\n없어졌다!", - "spikesOnAdd": "{{opponentDesc}}의 발밑에\n압정이 뿌려졌다!", - "spikesActivateTrap": "{{pokemonNameWithAffix}}[[는]]\n압정뿌리기의 데미지를 입었다!", - "toxicSpikesOnAdd": "{{opponentDesc}}의 발밑에\n독압정이 뿌려졌다!", - "toxicSpikesActivateTrapPoison": "{{pokemonNameWithAffix}}[[는]]\n{{moveName}}[[를]] 흡수했다!", - "stealthRockOnAdd": "{{opponentDesc}} 주변에\n뾰족한 바위가 떠다니기 시작했다!!", - "stealthRockActivateTrap": "{{pokemonNameWithAffix}}에게\n뾰족한 바위가 박혔다!", - "stickyWebOnAdd": "{{opponentDesc}} 발밑에\n{{moveName}}[[가]] 펼쳐졌다!", - "stickyWebActivateTrap": "{{pokemonName}}[[는]]\n끈적끈적네트에 걸렸다!", - "trickRoomOnAdd": "{{pokemonNameWithAffix}}[[는]]\n시공을 뒤틀었다!", - "trickRoomOnRemove": "뒤틀린 시공이 원래대로 되돌아왔다!", - "gravityOnAdd": "중력이 강해졌다!", - "gravityOnRemove": "중력이 원래대로 되돌아왔다!", - "tailwindOnAdd": "순풍이 불기 시작했다!", - "tailwindOnAddPlayer": "우리 편에게\n순풍이 불기 시작했다!", - "tailwindOnAddEnemy": "상대에게\n순풍이 불기 시작했다!", - "tailwindOnRemove": "순풍이 멈췄다!", - "tailwindOnRemovePlayer": "우리 편의\n순풍이 멈췄다!", - "tailwindOnRemoveEnemy": "상대의\n순풍이 멈췄다!", - "happyHourOnAdd": "모두 행복한 기분에\n휩싸였다!", - "happyHourOnRemove": "기분이 원래대로 돌아왔다.", - "safeguardOnAdd": "필드 전체가 신비의 베일에 둘러싸였다!", - "safeguardOnAddPlayer": "우리 편은 신비의 베일에 둘러싸였다!", - "safeguardOnAddEnemy": "상대 편은 신비의 베일에 둘러싸였다!", - "safeguardOnRemove": "필드를 감싸던 신비의 베일이 없어졌다!", - "safeguardOnRemovePlayer": "우리 편을 감싸던 신비의 베일이 없어졌다!", - "safeguardOnRemoveEnemy": "상대 편을 감싸던 신비의 베일이 없어졌다!" -} \ No newline at end of file diff --git a/src/locales/ko/battle-info.json b/src/locales/ko/battle-info.json deleted file mode 100644 index 8f95af52b20..00000000000 --- a/src/locales/ko/battle-info.json +++ /dev/null @@ -1,3 +0,0 @@ -{ - "generation": "{{generation}}" -} \ No newline at end of file diff --git a/src/locales/ko/battle-message-ui-handler.json b/src/locales/ko/battle-message-ui-handler.json deleted file mode 100644 index b1ffecf75e5..00000000000 --- a/src/locales/ko/battle-message-ui-handler.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "ivBest": "최고", - "ivFantastic": "훌륭하다", - "ivVeryGood": "굉장히 좋다", - "ivPrettyGood": "상당히 좋다", - "ivDecent": "적당하다", - "ivNoGood": "별로인 듯" -} \ No newline at end of file diff --git a/src/locales/ko/battle-scene.json b/src/locales/ko/battle-scene.json deleted file mode 100644 index a0288475d69..00000000000 --- a/src/locales/ko/battle-scene.json +++ /dev/null @@ -1,3 +0,0 @@ -{ - "moneyOwned": "₽{{formattedMoney}}" -} \ No newline at end of file diff --git a/src/locales/ko/battle.json b/src/locales/ko/battle.json deleted file mode 100644 index 154ca04fd49..00000000000 --- a/src/locales/ko/battle.json +++ /dev/null @@ -1,103 +0,0 @@ -{ - "bossAppeared": "{{bossName}}[[가]] 나타났다.", - "trainerAppeared": "{{trainerName}}[[가]]\n승부를 걸어왔다!", - "trainerAppearedDouble": "{{trainerName}}[[가]]\n승부를 걸어왔다!", - "trainerSendOut": "{{trainerName}}[[는]]\n{{pokemonName}}[[를]] 내보냈다!", - "singleWildAppeared": "앗! 야생 {{pokemonName}}[[가]]\n튀어나왔다!", - "multiWildAppeared": "야생 {{pokemonName1}}[[와]]\n{{pokemonName2}}[[가]] 튀어나왔다!", - "playerComeBack": "돌아와, {{pokemonName}}!", - "trainerComeBack": "{{trainerName}}[[는]] {{pokemonName}}[[를]] 넣어버렸다!", - "playerGo": "가랏! {{pokemonName}}!", - "trainerGo": "{{trainerName}}[[는]] {{pokemonName}}[[를]] 내보냈다!", - "switchQuestion": "{{pokemonName}}[[를]]\n교체하시겠습니까?", - "trainerDefeated": "{{trainerName}}[[와]]의\n승부에서 이겼다!", - "moneyWon": "상금으로\n₽{{moneyAmount}}을 손에 넣었다!", - "moneyPickedUp": "₽{{moneyAmount}}을 주웠다!", - "pokemonCaught": "신난다-!\n{{pokemonName}}[[를]] 잡았다!", - "addedAsAStarter": "{{pokemonName}}[[가]]\n스타팅 포켓몬에 추가되었다!", - "partyFull": "지닌 포켓몬이 가득 찼습니다. {{pokemonName}}[[를]]\n대신해 포켓몬을 놓아주시겠습니까?", - "pokemon": "포켓몬", - "sendOutPokemon": "가랏! {{pokemonName}}!", - "hitResultCriticalHit": "급소에 맞았다!", - "hitResultSuperEffective": "효과가 굉장했다!", - "hitResultNotVeryEffective": "효과가 별로인 듯하다…", - "hitResultNoEffect": "{{pokemonName}}에게는\n효과가 없는 것 같다…", - "hitResultImmune": "{{pokemonName}}에게는\n전혀 효과가 없다!", - "hitResultOneHitKO": "일격필살!", - "attackFailed": "그러나 실패하고 말았다!!", - "attackMissed": "{{pokemonNameWithAffix}}에게는\n맞지 않았다!", - "attackHitsCount": "{{count}}번 맞았다!", - "rewardGain": "{{modifierName}}[[를]] 받았다!", - "expGain": "{{pokemonName}}[[는]]\n{{exp}} 경험치를 얻었다!", - "levelUp": "{{pokemonName}}[[는]]\n레벨 {{level}}[[로]] 올랐다!", - "learnMove": "{{pokemonName}}[[는]] 새로\n{{moveName}}[[를]] 배웠다!", - "learnMovePrompt": "{{pokemonName}}[[는]] 새로\n{{moveName}}[[를]] 배우고 싶다!…", - "learnMoveLimitReached": "그러나 {{pokemonName}}[[는]] 기술을 4개\n알고 있으므로 더 이상 배울 수 없다!", - "learnMoveReplaceQuestion": "{{moveName}} 대신 다른 기술을 잊게 하겠습니까?", - "learnMoveStopTeaching": "그럼… {{moveName}}[[를]]\n배우는 것을 포기하겠습니까?", - "learnMoveNotLearned": "{{pokemonName}}[[는]] {{moveName}}[[를]]\n결국 배우지 않았다!", - "learnMoveForgetQuestion": "어느 기술을 잊게 하고싶은가?", - "learnMoveForgetSuccess": "{{pokemonName}}[[는]] {{moveName}}[[를]] 깨끗이 잊었다!", - "countdownPoof": "@d{32}1, @d{15}2, @d{15}… @d{15}… @d{30}@s{se/pb_bounce_1}짠!", - "learnMoveAnd": "그리고…", - "levelCapUp": "레벨의 최대치가\n{{levelCap}}까지 상승했다!", - "moveNotImplemented": "{{moveName}}[[는]] 아직 구현되지 않아 사용할 수 없다…", - "moveNoPP": "기술의 남은 포인트가 없다!", - "moveDisabled": "{{moveName}}[[를]] 쓸 수 없다!", - "canOnlyUseMove": "{{pokemonName}}[[는]]\n{{moveName}}밖에 쓸 수 없다!", - "moveCannotBeSelected": "{{moveName}}[[를]] 쓸 수 없다!", - "disableInterruptedMove": "{{pokemonNameWithAffix}}의 {{moveName}}[[는]]\n사용할 수 없다.", - "throatChopInterruptedMove": "{{pokemonName}}[[는]]\n지옥찌르기 효과로 기술을 쓸 수 없다!", - "noPokeballForce": "본 적 없는 힘이\n볼을 사용하지 못하게 한다.", - "noPokeballTrainer": "다른 트레이너의 포켓몬은 잡을 수 없다!", - "noPokeballMulti": "안돼! 2마리 있어서\n목표를 정할 수가 없어…!", - "noPokeballStrong": "너무 강해서 잡을 수가 없다!\n먼저 약화시켜야 한다!", - "noEscapeForce": "본 적 없는 힘이\n도망칠 수 없게 한다.", - "noEscapeTrainer": "안돼! 승부 도중에\n상대에게 등을 보일 순 없어!", - "noEscapePokemon": "{{pokemonName}}의 {{moveName}}때문에\n{{escapeVerb}} 수 없다!", - "runAwaySuccess": "무사히 도망쳤다!", - "runAwayCannotEscape": "도망칠 수 없었다!", - "escapeVerbSwitch": "교체할", - "escapeVerbFlee": "도망칠", - "notDisabled": "{{pokemonName}}의\n{{moveName}} 사슬묶기가 풀렸다!", - "turnEndHpRestore": "{{pokemonName}}의\n체력이 회복되었다!", - "hpIsFull": "그러나 {{pokemonName}}의\n체력이 가득 찬 상태다!", - "skipItemQuestion": "아이템을 받지 않고 넘어가시겠습니까?", - "itemStackFull": "{{fullItemName}}의 소지 한도에 도달했습니다.\n{{itemname}}[[를]] 대신 받습니다.", - "eggHatching": "어라…?", - "eggSkipPrompt": "알 부화 요약 화면으로 바로 넘어가시겠습니까?", - "ivScannerUseQuestion": "{{pokemonName}}에게 개체값탐지기를 사용하시겠습니까?", - "wildPokemonWithAffix": "야생 {{pokemonName}}", - "foePokemonWithAffix": "상대 {{pokemonName}}", - "useMove": "{{pokemonNameWithAffix}}의 {{moveName}}!", - "drainMessage": "{{pokemonName}}[[로]]부터\n체력을 흡수했다!", - "stealEatBerry": "{{pokemonName}}[[가]]\n{{targetName}}의 {{berryName}}[[를]] 빼앗아 먹었다!", - "ppHealBerry": "{{pokemonNameWithAffix}}[[는]] {{berryName}}[[로]]\n{{moveName}}의 PP를 회복했다!", - "hpHealBerry": "{{pokemonNameWithAffix}}[[는]] {{berryName}}[[로]]\n체력을 회복했다!", - "regainHealth": "{{pokemonName}}[[는]]\n체력을 회복했다!", - "fainted": "{{pokemonNameWithAffix}}[[는]] 쓰러졌다!", - "statsAnd": "그리고", - "stats": "스테이터스", - "statRose_one": "{{pokemonNameWithAffix}}의\n{{stats}}[[가]] 올라갔다!", - "statRose_other": "{{pokemonNameWithAffix}}의\n{{stats}}[[가]] 올라갔다!", - "statSharplyRose_one": "{{pokemonNameWithAffix}}의\n{{stats}}[[가]] 크게 올라갔다!", - "statSharplyRose_other": "{{pokemonNameWithAffix}}의\n{{stats}}[[가]] 크게 올라갔다!", - "statRoseDrastically_one": "{{pokemonNameWithAffix}}의\n{{stats}}[[가]] 매우 크게 올라갔다!", - "statRoseDrastically_other": "{{pokemonNameWithAffix}}의\n{{stats}}[[가]] 매우 크게 올라갔다!", - "statWontGoAnyHigher_one": "{{pokemonNameWithAffix}}의\n{{stats}}[[는]] 더 올라가지 않는다!", - "statWontGoAnyHigher_other": "{{pokemonNameWithAffix}}의\n{{stats}}[[는]] 더 올라가지 않는다!", - "statFell_one": "{{pokemonNameWithAffix}}의\n{{stats}}[[가]] 떨어졌다!", - "statFell_other": "{{pokemonNameWithAffix}}의\n{{stats}}[[가]] 떨어졌다!", - "statHarshlyFell_one": "{{pokemonNameWithAffix}}의\n{{stats}}[[가]] 크게 떨어졌다!", - "statHarshlyFell_other": "{{pokemonNameWithAffix}}의\n{{stats}}[[가]] 크게 떨어졌다!", - "statSeverelyFell_one": "{{pokemonNameWithAffix}}의\n{{stats}}[[가]] 매우 크게 떨어졌다!", - "statSeverelyFell_other": "{{pokemonNameWithAffix}}의\n{{stats}}[[가]] 매우 크게 떨어졌다!", - "statWontGoAnyLower_one": "{{pokemonNameWithAffix}}의\n{{stats}}[[는]] 더 떨어지지 않는다!", - "statWontGoAnyLower_other": "{{pokemonNameWithAffix}}의\n{{stats}}[[는]] 더 떨어지지 않는다!", - "transformedIntoType": "{{pokemonName}}[[는]]\n{{type}}타입이 됐다!", - "retryBattle": "이 배틀의 처음부터 재도전하시겠습니까?", - "unlockedSomething": "{{unlockedThing}}[[가]]\n해금되었다.", - "congratulations": "축하합니다!", - "beatModeFirstTime": "{{speciesName}}[[가]] {{gameMode}} 모드를 처음으로 클리어했다!\n{{newModifier}}[[를]] 손에 넣었다!", - "ppReduced": "{{targetName}}의\n{{moveName}}[[를]] {{reduction}} 깎았다!" -} diff --git a/src/locales/ko/battler-tags.json b/src/locales/ko/battler-tags.json deleted file mode 100644 index 1cd6c86377e..00000000000 --- a/src/locales/ko/battler-tags.json +++ /dev/null @@ -1,77 +0,0 @@ -{ - "trappedDesc": "함정", - "flinchedDesc": "풀죽음", - "confusedDesc": "혼란", - "infatuatedDesc": "헤롱헤롱", - "seedDesc": "씨뿌리기", - "nightmareDesc": "악몽", - "ingrainDesc": "뿌리", - "drowsyDesc": "졸음", - "rechargingLapse": "공격의 반동으로\n{{pokemonNameWithAffix}}[[는]] 움직일 수 없다!", - "trappedOnAdd": "{{pokemonNameWithAffix}}[[는]]\n이제 도망칠 수 없다!", - "trappedOnRemove": "{{pokemonNameWithAffix}}[[는]]\n{{moveName}}로부터 풀려났다!", - "flinchedLapse": "{{pokemonNameWithAffix}}[[는]] 풀이 죽어\n움직일 수 없었다!", - "confusedOnAdd": "{{pokemonNameWithAffix}}[[는]]\n혼란에 빠졌다!", - "confusedOnRemove": "{{pokemonNameWithAffix}}의\n혼란이 풀렸다!", - "confusedOnOverlap": "{{pokemonNameWithAffix}}[[는]]\n이미 혼란에 빠져 있다", - "confusedLapse": "{{pokemonNameWithAffix}}[[는]]\n혼란에 빠져 있다!", - "confusedLapseHurtItself": "영문도 모른채\n자신을 공격했다!", - "destinyBondLapseIsBoss": "{{pokemonNameWithAffix}}[[는]]\n길동무의 영향을 받지 않는다.", - "destinyBondLapse": "{{pokemonNameWithAffix}}[[는]] {{pokemonNameWithAffix2}}[[를]]\n길동무로 삼았다!", - "infatuatedOnAdd": "{{pokemonNameWithAffix}}[[는]]\n헤롱헤롱해졌다!", - "infatuatedOnOverlap": "{{pokemonNameWithAffix}}[[는]]\n이미 헤롱헤롱해있다!", - "infatuatedLapse": "{{pokemonNameWithAffix}}[[는]]\n{{sourcePokemonName}}에게 헤롱헤롱해 있다!", - "infatuatedLapseImmobilize": "{{pokemonNameWithAffix}}[[는]] 헤롱헤롱해서\n기술을 쓸 수 없었다!", - "infatuatedOnRemove": "{{pokemonNameWithAffix}}[[는]]\n헤롱헤롱 상태에서 벗어났다.", - "seededOnAdd": "{{pokemonNameWithAffix}}에게\n씨앗을 심었다!", - "seededLapse": "씨뿌리기가 {{pokemonNameWithAffix}}의\n체력을 빼앗는다!", - "seededLapseShed": "{{pokemonNameWithAffix}}[[는]]\n씨앗을 날려버렸다!", - "nightmareOnAdd": "{{pokemonNameWithAffix}}[[는]]\n악몽을 꾸기 시작했다!", - "nightmareOnOverlap": "{{pokemonNameWithAffix}}[[는]]\n이미 악몽을 꾸고 있다!", - "nightmareLapse": "{{pokemonNameWithAffix}}[[는]]\n악몽에 시달리고 있다!", - "encoreOnAdd": "{{pokemonNameWithAffix}}[[는]]\n앙코르를 받았다!", - "encoreOnRemove": "{{pokemonNameWithAffix}}의\n앙코르 상태가 풀렸다!", - "helpingHandOnAdd": "{{pokemonNameWithAffix}}[[는]] {{pokemonName}}에게\n도우미가 되어주려 한다!", - "ingrainLapse": "{{pokemonNameWithAffix}}[[는]] 뿌리로부터\n양분을 흡수했다!", - "ingrainOnTrap": "{{pokemonNameWithAffix}}[[는]] 뿌리를 뻗었다!", - "aquaRingOnAdd": "{{pokemonNameWithAffix}}[[는]]\n물의 베일을 둘러썼다!", - "aquaRingLapse": "{{moveName}} 효과로\n{{pokemonName}}[[는]] HP를 회복했다!", - "drowsyOnAdd": "{{pokemonNameWithAffix}}의\n졸음을 유도했다!", - "damagingTrapLapse": "{{pokemonNameWithAffix}}[[는]] {{moveName}}의\n데미지를 입고 있다!", - "bindOnTrap": "{{pokemonNameWithAffix}}[[는]] {{sourcePokemonName}}에게\n{{moveName}}[[를]] 당했다!", - "wrapOnTrap": "{{pokemonNameWithAffix}}[[는]] {{sourcePokemonName}}에게\n휘감겼다!", - "vortexOnTrap": "{{pokemonNameWithAffix}}[[는]]\n소용돌이 속에 갇혔다!", - "clampOnTrap": "{{sourcePokemonNameWithAffix}}[[는]] {{pokemonName}}의\n껍질에 꼈다!", - "sandTombOnTrap": "{{pokemonNameWithAffix}}[[는]]\n{{moveName}}에 붙잡혔다!", - "magmaStormOnTrap": "{{pokemonNameWithAffix}}[[는]]\n마그마의 소용돌이에 갇혔다!", - "snapTrapOnTrap": "{{pokemonNameWithAffix}}[[는]]\n집게덫에 붙잡혔다!", - "thunderCageOnTrap": "{{sourcePokemonNameWithAffix}}[[는]]\n{{pokemonNameWithAffix}}를 가두었다!", - "infestationOnTrap": "{{pokemonNameWithAffix}}[[는]]\n{{sourcePokemonNameWithAffix}}에게 엉겨 붙었다!", - "protectedOnAdd": "{{pokemonNameWithAffix}}[[는]]\n방어 태세에 들어갔다!", - "protectedLapse": "{{pokemonNameWithAffix}}[[는]]\n공격으로부터 몸을 지켰다!", - "enduringOnAdd": "{{pokemonNameWithAffix}}[[는]]\n버티기 태세에 들어갔다!", - "enduringLapse": "{{pokemonNameWithAffix}}[[는]]\n공격을 버텼다!", - "sturdyLapse": "{{pokemonNameWithAffix}}[[는]]\n공격을 버텼다!", - "perishSongLapse": "{{pokemonNameWithAffix}}의 멸망의\n카운트가 {{turnCount}}[[가]] 되었다!", - "centerOfAttentionOnAdd": "{{pokemonNameWithAffix}}[[는]]\n주목의 대상이 되었다!", - "truantLapse": "{{pokemonNameWithAffix}}[[는]] 게으름을 피우고 있다!", - "slowStartOnAdd": "{{pokemonNameWithAffix}}[[는]] 컨디션이\n좋아지지 않는다!", - "slowStartOnRemove": "{{pokemonNameWithAffix}} 는 마침내\n컨디션을 회복했다!", - "highestStatBoostOnAdd": "{{pokemonNameWithAffix}}의\n{{statName}}[[가]] 올라갔다!", - "highestStatBoostOnRemove": "{{pokemonNameWithAffix}}의\n{{abilityName}} 효과가 사라졌다!", - "magnetRisenOnAdd": "{{pokemonNameWithAffix}}[[는]]\n전자력으로 떠올랐다!", - "magnetRisenOnRemove": "{{pokemonNameWithAffix}}의\n전자력이 없어졌다!", - "critBoostOnAdd": "{{pokemonNameWithAffix}}[[는]]\n의욕이 넘치고 있다!", - "critBoostOnRemove": "{{pokemonNameWithAffix}}[[는]] 평소로 돌아왔다.", - "saltCuredOnAdd": "{{pokemonNameWithAffix}}[[는]]\n소금에 절여졌다!", - "saltCuredLapse": "{{pokemonNameWithAffix}}[[는]] 소금절이의\n데미지를 입고 있다.", - "cursedOnAdd": "{{pokemonNameWithAffix}}[[는]] 자신의 체력을 깎아서\n{{pokemonName}}에게 저주를 걸었다!", - "cursedLapse": "{{pokemonNameWithAffix}}[[는]]\n저주받고 있다!", - "stockpilingOnAdd": "{{pokemonNameWithAffix}}[[는]]\n{{stockpiledCount}}개 비축했다!", - "disabledOnAdd": "{{pokemonNameWithAffix}}의 {{moveName}}[[는]]\n사용할 수 없다!", - "disabledLapse": "{{pokemonNameWithAffix}}의 {{moveName}}[[는]]\n이제 사용할 수 있다.", - "tarShotOnAdd": "{{pokemonNameWithAffix}}[[는]] 불꽃에 약해졌다!", - "substituteOnAdd": "{{pokemonNameWithAffix}}의\n대타가 나타났다!", - "substituteOnHit": "{{pokemonNameWithAffix}}[[를]] 대신하여\n대타가 공격을 받았다!", - "substituteOnRemove": "{{pokemonNameWithAffix}}의\n대타는 사라져 버렸다..." -} diff --git a/src/locales/ko/berry.json b/src/locales/ko/berry.json deleted file mode 100644 index 4681df53fb5..00000000000 --- a/src/locales/ko/berry.json +++ /dev/null @@ -1,46 +0,0 @@ -{ - "SITRUS": { - "name": "자뭉열매", - "effect": "지니게 하면 HP가 50% 미만일 때 HP를 25% 회복" - }, - "LUM": { - "name": "리샘열매", - "effect": "지니게 하면 모든 상태 이상과 혼란을 회복" - }, - "ENIGMA": { - "name": "의문열매", - "effect": "지니게 하면 효과가 뛰어난 기술에 당했을 때 HP를 25% 회복" - }, - "LIECHI": { - "name": "치리열매", - "effect": "지니게 하면 HP가 25% 미만일 때 자신의 공격이 상승" - }, - "GANLON": { - "name": "용아열매", - "effect": "지니게 하면 HP가 25% 미만일 때 자신의 방어가 상승" - }, - "PETAYA": { - "name": "야타비열매", - "effect": "지니게 하면 HP가 25% 미만일 때 자신의 특수공격이 상승" - }, - "APICOT": { - "name": "규살열매", - "effect": "지니게 하면 HP가 25% 미만일 때 자신의 특수방어가 상승" - }, - "SALAC": { - "name": "캄라열매", - "effect": "지니게 하면 HP가 25% 미만일 때 자신의 스피드가 상승" - }, - "LANSAT": { - "name": "랑사열매", - "effect": "지니게 하면 HP가 25% 미만일 때 공격이 급소를 맞히기 쉬워짐" - }, - "STARF": { - "name": "스타열매", - "effect": "지니게 하면 HP가 25% 미만일 때 능력 중의 하나가 크게 상승" - }, - "LEPPA": { - "name": "과사열매", - "effect": "지니게 하면 기술의 PP가 0이 되었을 때 PP를 10만큼 회복" - } -} \ No newline at end of file diff --git a/src/locales/ko/bgm-name.json b/src/locales/ko/bgm-name.json deleted file mode 100644 index 5295e2d8708..00000000000 --- a/src/locales/ko/bgm-name.json +++ /dev/null @@ -1,149 +0,0 @@ -{ - "music": "Music: ", - "missing_entries": "{{name}}", - "battle_kanto_champion": "BW2 관동 챔피언 배틀", - "battle_johto_champion": "BW2 성도 챔피언 배틀", - "battle_hoenn_champion_g5": "BW2 호연 챔피언 배틀", - "battle_hoenn_champion_g6": "ORAS 호연 챔피언 배틀", - "battle_sinnoh_champion": "BW2 신오 챔피언 배틀", - "battle_champion_alder": "BW 하나 챔피언 배틀", - "battle_champion_iris": "BW2 하나 챔피언 배틀", - "battle_kalos_champion": "XY 칼로스 챔피언 배틀", - "battle_alola_champion": "USUM 알로라 챔피언 배틀", - "battle_galar_champion": "SWSH 가라르 챔피언 배틀", - "battle_champion_geeta": "SV 챔피언 테사 배틀", - "battle_champion_nemona": "SV 챔피언 네모 배틀", - "battle_champion_kieran": "SV 챔피언 카지 배틀", - "battle_hoenn_elite": "ORAS 사천왕 배틀", - "battle_unova_elite": "BW 사천왕 배틀", - "battle_kalos_elite": "XY 사천왕 배틀", - "battle_alola_elite": "SM 사천왕 배틀", - "battle_galar_elite": "SWSH 리그 토너먼트 배틀", - "battle_paldea_elite": "SV 사천왕 배틀", - "battle_bb_elite": "SV 블루베리 리그 사천왕 배틀", - "battle_final_encounter": "불가사의 던전 구조대 DX 레쿠쟈의 영역", - "battle_final": "BW 게치스 배틀", - "battle_kanto_gym": "BW2 관동 체육관 배틀", - "battle_johto_gym": "BW2 성도 체육관 배틀", - "battle_hoenn_gym": "BW2 호연 체육관 배틀", - "battle_sinnoh_gym": "BW2 신오 체육관 배틀", - "battle_unova_gym": "BW 하나 체육관 배틀", - "battle_kalos_gym": "XY 칼로스 체육관 배틀", - "battle_galar_gym": "SWSH 가라르 체육관 배틀", - "battle_paldea_gym": "SV 팔데아 체육관 배틀", - "battle_legendary_kanto": "XY 관동 전설 조우 배틀", - "battle_legendary_raikou": "HGSS 라이코 배틀", - "battle_legendary_entei": "HGSS 엔테이 배틀", - "battle_legendary_suicune": "HGSS 스이쿤 배틀", - "battle_legendary_lugia": "HGSS 루기아 배틀", - "battle_legendary_ho_oh": "HGSS 칠색조 배틀", - "battle_legendary_regis_g5": "BW2 레지시리즈 배틀", - "battle_legendary_regis_g6": "ORAS 레지시리즈 배틀", - "battle_legendary_gro_kyo": "ORAS 그란돈 & 가이오가 배틀", - "battle_legendary_rayquaza": "ORAS 레쿠쟈 배틀", - "battle_legendary_deoxys": "ORAS 데오키시스 배틀", - "battle_legendary_lake_trio": "ORAS 호수의 수호신 배틀", - "battle_legendary_sinnoh": "ORAS 신오 전설 조우 배틀", - "battle_legendary_dia_pal": "ORAS 디아루가 & 펄기아 배틀", - "battle_legendary_origin_forme": "LA 오리진 디아루가 & 펄기아 배틀", - "battle_legendary_giratina": "ORAS 기라티나 배틀", - "battle_legendary_arceus": "HGSS 아르세우스 배틀", - "battle_legendary_unova": "BW 하나 전설 조우 배틀", - "battle_legendary_kyurem": "BW 큐레무 배틀", - "battle_legendary_res_zek": "BW 레시라무 & 제크로무 배틀", - "battle_legendary_xern_yvel": "XY 제르네아스 & 이벨타르 배틀", - "battle_legendary_tapu": "SM 섬 수호신 배틀", - "battle_legendary_sol_lun": "SM 솔가레오 & 루나아라 배틀", - "battle_legendary_ub": "SM 울트라비스트 배틀", - "battle_legendary_dusk_dawn": "USUM 황혼의 갈기 & 새벽의 날개 네크로즈마 배틀", - "battle_legendary_ultra_nec": "USUM 울트라 네크로즈마 배틀", - "battle_legendary_zac_zam": "SWSH 자시안 & 자마젠타 배틀", - "battle_legendary_glas_spec": "SWSH 블리자포스 & 레이스포스 배틀", - "battle_legendary_calyrex": "SWSH 버드렉스 배틀", - "battle_legendary_riders": "SWSH 백마 & 흑마 버드렉스 배틀", - "battle_legendary_birds_galar": "SWSH 가라르 전설의 새 배틀", - "battle_legendary_ruinous": "SV 재앙의 보물 배틀", - "battle_legendary_kor_mir": "SV 에리어 제로 배틀", - "battle_legendary_loyal_three": "SV 세벗들 배틀", - "battle_legendary_ogerpon": "SV 오거폰 배틀", - "battle_legendary_terapagos": "SV 테라파고스 배틀", - "battle_legendary_pecharunt": "SV 복숭악동 배틀", - "battle_rival": "BW 라이벌 배틀", - "battle_rival_2": "BW N 배틀", - "battle_rival_3": "BW 최종전 N 배틀", - "battle_trainer": "BW 트레이너 배틀", - "battle_wild": "BW 야생 포켓몬 배틀", - "battle_wild_strong": "BW 강한 야생 포켓몬 조우 배틀", - "end_summit": "불가사의 던전 구조대 DX 천공의 탑 꼭대기", - "battle_rocket_grunt": "HGSS 로켓단 배틀", - "battle_aqua_magma_grunt": "ORAS 아쿠아단 & 마그마단 배틀", - "battle_galactic_grunt": "BDSP 갤럭시단 배틀", - "battle_plasma_grunt": "BW 플라스마단 배틀", - "battle_flare_grunt": "XY 플레어단 배틀", - "battle_aether_grunt": "SM 에테르재단 배틀", - "battle_skull_grunt": "SM 스컬단 배틀", - "battle_macro_grunt": "SWSH 트레이너 배틀", - "battle_galactic_admin": "BDSP 갤럭시단 간부 배틀", - "battle_skull_admin": "SM 스컬단 간부 배틀", - "battle_oleana": "SWSH 올리브 배틀", - "battle_rocket_boss": "USUM 비주기 배틀", - "battle_aqua_magma_boss": "ORAS 아강 & 마적 배틀", - "battle_galactic_boss": "BDSP 태홍 배틀", - "battle_plasma_boss": "B2W2 게치스 배틀", - "battle_flare_boss": "XY 플라드리 배틀", - "battle_aether_boss": "SM 루자미네 배틀", - "battle_skull_boss": "SM 구즈마 배틀", - "battle_macro_boss": "SWSH 로즈 배틀", - "abyss": "불가사의 던전 하늘의 탐험대 어둠의 화구", - "badlands": "불가사의 던전 하늘의 탐험대 불모의 계곡", - "beach": "불가사의 던전 하늘의 탐험대 축축한 암반", - "cave": "불가사의 던전 하늘의 탐험대 하늘 꼭대기 동굴", - "construction_site": "불가사의 던전 하늘의 탐험대 바위 채석장", - "desert": "불가사의 던전 하늘의 탐험대 북쪽 사막", - "dojo": "불가사의 던전 하늘의 탐험대 텅구리 도장", - "end": "불가사의 던전 구조대DX 천공의 탑", - "factory": "불가사의 던전 하늘의 탐험대 숨겨진 유적", - "fairy_cave": "불가사의 던전 하늘의 탐험대 별의 동굴", - "forest": "불가사의 던전 하늘의 탐험대 검은 숲", - "grass": "불가사의 던전 하늘의 탐험대 사과의 숲", - "graveyard": "불가사의 던전 하늘의 탐험대 신비의 숲", - "ice_cave": "불가사의 던전 하늘의 탐험대 광대한 얼음산", - "island": "불가사의 던전 하늘의 탐험대 연안의 암반", - "jungle": "Lmz - Jungle", - "laboratory": "Firel - Laboratory", - "lake": "불가사의 던전 하늘의 탐험대 수정 동굴", - "meadow": "불가사의 던전 하늘의 탐험대 하늘 꼭대기 숲", - "metropolis": "Firel - Metropolis", - "mountain": "불가사의 던전 하늘의 탐험대 뿔산", - "plains": "불가사의 던전 하늘의 탐험대 하늘 꼭대기 초원", - "power_plant": "불가사의 던전 하늘의 탐험대 일렉트릭 평원", - "ruins": "불가사의 던전 하늘의 탐험대 봉인의 암반", - "sea": "Andr06 - Marine Mystique", - "seabed": "Firel - Seabed", - "slum": "Andr06 - Sneaky Snom", - "snowy_forest": "불가사의 던전 하늘의 탐험대 하늘 꼭대기 설원", - "space": "Firel - Aether", - "swamp": "불가사의 던전 하늘의 탐험대 폐쇄되어진 바다", - "tall_grass": "불가사의 던전 하늘의 탐험대 짙은 안개의 숲", - "temple": "불가사의 던전 하늘의 탐험대 파수꾼의 동굴", - "town": "불가사의 던전 하늘의 탐험대 랜덤 던전 테마 3", - "volcano": "불가사의 던전 하늘의 탐험대 열수의 동굴", - "wasteland": "불가사의 던전 하늘의 탐험대 환상의 대지", - "encounter_ace_trainer": "BW 눈이 마주치면 승부! (엘리트 트레이너)", - "encounter_backpacker": "BW 눈이 마주치면 승부! (등산가)", - "encounter_clerk": "BW 눈이 마주치면 승부! (회사원)", - "encounter_cyclist": "BW 눈이 마주치면 승부! (사이클링)", - "encounter_lass": "BW 눈이 마주치면 승부! (짧은 치마)", - "encounter_parasol_lady": "BW 눈이 마주치면 승부! (파라솔 아가씨)", - "encounter_pokefan": "BW 눈이 마주치면 승부! (애호가클럽)", - "encounter_psychic": "BW 눈이 마주치면 승부! (초능력자)", - "encounter_rich": "BW 눈이 마주치면 승부! (신사)", - "encounter_rival": "BW 체렌", - "encounter_roughneck": "BW 눈이 마주치면 승부! (빡빡이)", - "encounter_scientist": "BW 눈이 마주치면 승부! (연구원)", - "encounter_twins": "BW 눈이 마주치면 승부! (쌍둥이)", - "encounter_youngster": "BW 눈이 마주치면 승부! (반바지 꼬마)", - "heal": "BW 포켓몬 센터", - "menu": "불가사의 던전 하늘의 탐험대 포켓몬 세계에 온 것을 환영한다!", - "title": "불가사의 던전 하늘의 탐험대 메뉴 테마" -} diff --git a/src/locales/ko/biome.json b/src/locales/ko/biome.json deleted file mode 100644 index 8149c2c2c48..00000000000 --- a/src/locales/ko/biome.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "unknownLocation": "기억할 수 없는 곳", - "TOWN": "마을", - "PLAINS": "평야", - "GRASS": "풀숲", - "TALL_GRASS": "높은 풀숲", - "METROPOLIS": "대도시", - "FOREST": "숲", - "SEA": "바다", - "SWAMP": "늪지", - "BEACH": "해변", - "LAKE": "호수", - "SEABED": "해저", - "MOUNTAIN": "산", - "BADLANDS": "악지", - "CAVE": "동굴", - "DESERT": "사막", - "ICE_CAVE": "얼음 동굴", - "MEADOW": "목초지", - "POWER_PLANT": "발전소", - "VOLCANO": "화산", - "GRAVEYARD": "묘지", - "DOJO": "도장", - "FACTORY": "공장", - "RUINS": "고대 유적", - "WASTELAND": "황무지", - "ABYSS": "심연", - "SPACE": "우주", - "CONSTRUCTION_SITE": "공사장", - "JUNGLE": "정글", - "FAIRY_CAVE": "페어리 동굴", - "TEMPLE": "사원", - "SLUM": "슬럼", - "SNOWY_FOREST": "눈덮인 숲", - "ISLAND": "섬", - "LABORATORY": "연구소", - "END": "???" -} \ No newline at end of file diff --git a/src/locales/ko/challenges.json b/src/locales/ko/challenges.json deleted file mode 100644 index 07a9052eebf..00000000000 --- a/src/locales/ko/challenges.json +++ /dev/null @@ -1,37 +0,0 @@ -{ - "title": "챌린지 조건 설정", - "illegalEvolution": "{{pokemon}}[[는]] 현재의 챌린지에\n부적합한 포켓몬이 되었습니다!", - "noneSelected": "미선택", - "singleGeneration": { - "name": "단일 세대", - "desc": "{{gen}}의 포켓몬만 사용할 수 있습니다.", - "desc_default": "선택한 세대의 포켓몬만 사용할 수 있습니다.", - "gen_1": "1세대", - "gen_2": "2세대", - "gen_3": "3세대", - "gen_4": "4세대", - "gen_5": "5세대", - "gen_6": "6세대", - "gen_7": "7세대", - "gen_8": "8세대", - "gen_9": "9세대" - }, - "singleType": { - "name": "단일 타입", - "desc": "{{type}} 타입의 포켓몬만 사용할 수 있습니다.", - "desc_default": "선택한 타입의 포켓몬만 사용할 수 있습니다." - }, - "freshStart": { - "name": "새 출발", - "desc": "포켓로그를 처음 시작했던 때처럼 강화가 전혀 되지 않은 오리지널 스타팅 포켓몬만 고를 수 있습니다.", - "value.0": "해제", - "value.1": "설정" - }, - "inverseBattle": { - "name": "거꾸로 배틀", - "shortName": "거꾸로", - "desc": "타입 상성이 반대로 바뀌고 면역 타입은 약점 타입이 됩니다.\n설정 시 다른 챌린지 업적은 달성할 수 없습니다.", - "value.0": "해제", - "value.1": "설정" - } -} \ No newline at end of file diff --git a/src/locales/ko/command-ui-handler.json b/src/locales/ko/command-ui-handler.json deleted file mode 100644 index 15cfba7196b..00000000000 --- a/src/locales/ko/command-ui-handler.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "fight": "싸운다", - "ball": "볼", - "pokemon": "포켓몬", - "run": "도망간다", - "actionMessage": "{{pokemonName}}[[는]] 무엇을 할까?" -} \ No newline at end of file diff --git a/src/locales/ko/common.json b/src/locales/ko/common.json deleted file mode 100644 index f67eae67155..00000000000 --- a/src/locales/ko/common.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "start": "시작", - "luckIndicator": "행운:", - "shinyOnHover": "색이 다른", - "commonShiny": "커먼", - "rareShiny": "레어", - "epicShiny": "에픽" -} \ No newline at end of file diff --git a/src/locales/ko/config.ts b/src/locales/ko/config.ts deleted file mode 100644 index 978cdc83002..00000000000 --- a/src/locales/ko/config.ts +++ /dev/null @@ -1,113 +0,0 @@ -import common from "./common.json"; -import settings from "./settings.json"; -import ability from "./ability.json"; -import abilityTriggers from "./ability-trigger.json"; -import arenaFlyout from "./arena-flyout.json"; -import arenaTag from "./arena-tag.json"; -import achv from "./achv.json"; -import battle from "./battle.json"; -import battleScene from "./battle-scene.json"; -import battleInfo from "./battle-info.json"; -import battleMessageUiHandler from "./battle-message-ui-handler.json"; -import battlerTags from "./battler-tags.json"; -import berry from "./berry.json"; -import bgmName from "./bgm-name.json"; -import biome from "./biome.json"; -import challenges from "./challenges.json"; -import commandUiHandler from "./command-ui-handler.json"; -import dialogue from "./dialogue.json"; -import battleSpecDialogue from "./dialogue-final-boss.json"; -import miscDialogue from "./dialogue-misc.json"; -import doubleBattleDialogue from "./dialogue-double-battle.json"; -import egg from "./egg.json"; -import fightUiHandler from "./fight-ui-handler.json"; -import filterBar from "./filter-bar.json"; -import gameMode from "./game-mode.json"; -import gameStatsUiHandler from "./game-stats-ui-handler.json"; -import growth from "./growth.json"; -import menu from "./menu.json"; -import menuUiHandler from "./menu-ui-handler.json"; -import modifier from "./modifier.json"; -import modifierType from "./modifier-type.json"; -import move from "./move.json"; -import nature from "./nature.json"; -import partyUiHandler from "./party-ui-handler.json"; -import pokeball from "./pokeball.json"; -import pokemon from "./pokemon.json"; -import pokemonForm from "./pokemon-form.json"; -import battlePokemonForm from "./pokemon-form-battle.json"; -import pokemonInfo from "./pokemon-info.json"; -import pokemonInfoContainer from "./pokemon-info-container.json"; -import pokemonSummary from "./pokemon-summary.json"; -import saveSlotSelectUiHandler from "./save-slot-select-ui-handler.json"; -import splashMessages from "./splash-messages.json"; -import starterSelectUiHandler from "./starter-select-ui-handler.json"; -import statusEffect from "./status-effect.json"; -import trainerTitles from "./trainer-titles.json"; -import trainerClasses from "./trainer-classes.json"; -import trainerNames from "./trainer-names.json"; -import tutorial from "./tutorial.json"; -import voucher from "./voucher.json"; -import weather from "./weather.json"; -import terrain from "./terrain.json"; -import modifierSelectUiHandler from "./modifier-select-ui-handler.json"; -import moveTriggers from "./move-trigger.json"; -import runHistory from "./run-history.json"; - -export const koConfig = { - ability, - abilityTriggers, - arenaFlyout, - arenaTag, - battle, - battleScene, - battleInfo, - battleMessageUiHandler, - battlePokemonForm, - battlerTags, - berry, - bgmName, - biome, - challenges, - commandUiHandler, - common, - achv, - dialogue, - battleSpecDialogue, - miscDialogue, - doubleBattleDialogue, - egg, - fightUiHandler, - filterBar, - gameMode, - gameStatsUiHandler, - growth, - menu, - menuUiHandler, - modifier, - modifierType, - move, - nature, - pokeball, - pokemon, - pokemonForm, - pokemonInfo, - pokemonInfoContainer, - pokemonSummary, - saveSlotSelectUiHandler, - settings, - splashMessages, - starterSelectUiHandler, - statusEffect, - terrain, - titles: trainerTitles, - trainerClasses, - trainerNames, - tutorial, - voucher, - weather, - partyUiHandler, - modifierSelectUiHandler, - moveTriggers, - runHistory, -}; diff --git a/src/locales/ko/dialogue-double-battle.json b/src/locales/ko/dialogue-double-battle.json deleted file mode 100644 index 134b8ade71e..00000000000 --- a/src/locales/ko/dialogue-double-battle.json +++ /dev/null @@ -1,82 +0,0 @@ -{ - "blue_red_double": { - "encounter": { - "1": "그린: 어이 레드! 우리가 누군지 보여주자고!\n$레드: ...\n$그린: 태초마을의 힘을 보여주지!" - }, - "victory": { - "1": "그린: 훌륭한 승부였어!\n$레드: ..." - } - }, - "red_blue_double": { - "encounter": { - "1": "레드: ...!\n$그린: 이 녀석은 여전히 말이 없구나.\n$그린: 그렇지만 방심해선 안 돼! 그래도 챔피언이라고!" - }, - "victory": { - "1": "레드: ...!\n$그린: 다음에는 우리가 이길 테다!" - } - }, - "tate_liza_double": { - "encounter": { - "1": "풍: 에헤헤... 체육관 관장이\n$란: 두 명이나 있어서 놀랐지?\n$풍: 우리는 쌍둥이!\n$란: 굳이 말을 하지 않아도 서로가 무슨 생각을 하고 있는지\n$풍: 자동으로 머릿속에 떠오르니까\n$란: 호흡을 척척 맞출 수가 있지!" - }, - "victory": { - "1": "풍: 우, 우리들의\n$란: 팀워크가...!" - } - }, - "liza_tate_double": { - "encounter": { - "1": "란: 우후후... 체육관 관장이\n$풍: 두 명이나 있어서 놀랐어?\n$란: 우리는 쌍둥이!\n$풍: 완벽한 우리의 콤비네이션을\n$란: 과연 네가 깨뜨릴 수 있을까?" - }, - "victory": { - "1": "란: 우리들이 생각한 만큼\n$풍: 우리가 강하지 않았던 걸까?" - } - }, - "wallace_steven_double": { - "encounter": { - "1": "성호: 윤진! 우리 챔피언의 힘을 보여주자!\n$윤진: 호연의 힘을 보여주마!\n$성호: 간다!" - }, - "victory": { - "1": "성호: 훌륭한 승부였어!\n$윤진: 다음엔 우리가 이길 거다!" - } - }, - "steven_wallace_double": { - "encounter": { - "1": "성호: 너 혹시 희귀한 포켓몬 가지고 있니?\n$윤진: 성호야... 우리는 포켓몬을 자랑하러 온 게 아니라 승부하러 온 거야.\n$성호: 오... 그렇지... 그럼 간다!" - }, - "victory": { - "1": "성호: 이제 승부는 끝났으니 포켓몬을 자랑해 볼까!\n$윤진: 성호야..." - } - }, - "alder_iris_double": { - "encounter": { - "1": "노간주: 우리는 하나 지방 최강의 트레이너들이란다!\n$아이리스: 이렇게 강한 트레이너와 싸울 수 있어서 정말 기뻐~!!" - }, - "victory": { - "1": "노간주: 장하구나! 실로 견줄 자가 천하에 없도다!\n$아이리스: 다음 번엔 우리가 꼭 이길 거야~!" - } - }, - "iris_alder_double": { - "encounter": { - "1": "아이리스: 어서 와, 도전자! 내가 바로 하나 지방 챔피언이야~!\n$노간주: 아이리스야, 너무 흥분한 것 아니냐?" - }, - "victory": { - "1": "아이리스: 후와아아아아... 최선을 다했는데도... 우리가 져버렸네!\n$노간주: 하지만 우리의 패배를 발판 삼아 나아가리라!" - } - }, - "piers_marnie_double": { - "encounter": { - "1": "마리: 오빠, 스파이크마을의 힘을 보여주자!\n$두송: 우리가 어둠을 불러올 것이다!" - }, - "victory": { - "1": "마리: 네가 우리의 어둠에 빛을 불러왔구나!\n$두송: 여긴 너무 밝네..." - } - }, - "marnie_piers_double": { - "encounter": { - "1": "두송: 콘서트 즐길 준비 됐어?\n$마리: 오빠... 얘들은 노래가 아니라 승부를 하러 왔어..." - }, - "victory": { - "1": "두송: 훌륭한 콘서트였다!\n$마리: 오빠..." - } - } -} \ No newline at end of file diff --git a/src/locales/ko/dialogue-final-boss.json b/src/locales/ko/dialogue-final-boss.json deleted file mode 100644 index d9b8dfc4526..00000000000 --- a/src/locales/ko/dialogue-final-boss.json +++ /dev/null @@ -1,5 +0,0 @@ -{ - "encounter": "드디어 때가 다시 도래했다.\n당도한 연유를 아는가?\n$이미 도달한 적이 있기에 이 자리에 있다.\n셀 수도 없이 많이.\n$아니, 사실 셀 수는 있지.\n정확히 너의 {{cycleCount}}번째다.\n$매 번 태초의 정신으로 되돌아갔을 뿐.\n하지만 어떻게든, 흔적은 남는다.\n$실패만을 반복했을 뿐이지만,\n지금은 네 안에 무언가가 있구나.\n\n$홀로 선 것처럼 보이나, 무언가 이질적인…\n$마침내 그간의 갈망을 해소해주는가?\n수천 년 간 기다려온 도전을?\n$시작하지.", - "firstStageWin": "그렇군. 정말로 있었어.\n이제 주저할 필요는 없다.\n$실망시키지 않도록.", - "secondStageWin": "…고무적이군." -} \ No newline at end of file diff --git a/src/locales/ko/dialogue-misc.json b/src/locales/ko/dialogue-misc.json deleted file mode 100644 index f24fc79ea99..00000000000 --- a/src/locales/ko/dialogue-misc.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "ending": "@c{shock}돌아왔구나?@d{32} 그 말은…@d{96} 이겼어?!\n@c{smile_ehalf}그럴 줄 알았다니까.\n$@c{smile_eclosed}물론… 언제나 느껴왔지.\n@c{smile}끝난 거, 맞지? 이 굴레를 말이야.\n$@c{smile_ehalf}네 꿈도 이뤘고 말이야.\n어떻게 한번도 안 졌대?\n$네가 한 일은 나만 기억하게 될 모양이지만.\n@c{angry_mopen}나, 안 까먹어볼 테니까!\n$@c{smile_wave_wink}농담이야!@d{64} @c{smile}절대 안 잊어버릴 거야.@d{32}\n마음 속엔 쭉 남아있을 수 있게.\n$@c{smile_wave}어쨌든,@d{64} 시간이 좀 늦었어…@d{96}\n이런 곳에서 할 말은 아닌가?\n$집에 가자. @c{smile_wave_wink}아마 내일은,\n추억을 되짚어보기 위한 배틀을 해볼 수 있을 거야.", - "ending_female": "@c{smile}오? 이긴거야?@d{96} @c{smile_eclosed}진즉 알았어야 했는데.\n아무튼, 돌아왔구나.\n$@c{smile}다 끝난거야.@d{64} 네가 굴레를 끝장냈어.\n$@c{serious_smile_fists}네 꿈도 이뤄졌고말야.\n진짜로 한 번도 안 졌잖아.\n$@c{neutral}기억하는 건 우리들 뿐일 모양이지만.@d{96}\n그래도, 괜찮지?\n$@c{serious_smile_fists}오늘의 일은\n너와 나의 마음 속에 항상 함께할 거야.\n$@c{smile_eclosed}여기 구경도 충분히 했으니\n이제 집에 가자.\n$@c{serious_smile_fists}되돌아가서, 다시 배틀을 할 수도 있지 않을까?\n네가 원한다면 말야.", - "ending_endless": "끝에 도달하신 것을 축하드립니다!\n더 많은 컨텐츠를 기다려주세요.", - "ending_name": "Devs" -} diff --git a/src/locales/ko/dialogue.json b/src/locales/ko/dialogue.json deleted file mode 100644 index 13fcd64a8d3..00000000000 --- a/src/locales/ko/dialogue.json +++ /dev/null @@ -1,2691 +0,0 @@ -{ - "youngster": { - "encounter": { - "1": "거기 너! 나와 배틀 어때?", - "2": "넌 새내기 트레이너구나. 맞지?", - "3": "거기 너! 처음보는 얼굴인데? 나랑 배틀하자!", - "4": "방금 배틀에서 져서 새로운 포켓몬을 찾는 중이야.\n잠깐! 넌 약해보이는데? 어서 나와 배틀하자!", - "5": "우리 만난 적이 있었던가? 잘 기억은 안나지만 어쨌든 만나서 반가워!", - "6": "좋아! 시작하자!", - "7": "좋아! 내가 왔다! 내 힘을 보여주지!", - "8": "하하하… 내 포켓몬이 얼마나 멋진지 보여주겠어!", - "9": "인사할 시간도 없어. 준비가 되었다면 이리 와!", - "10": "긴장을 늦추지마. 그렇지 않으면 어린이에게 맞아 울지도 몰라.", - "11": "난 내 포켓몬들을 소중히 키웠어. 내 포켓몬에게 상처를 입히게 놔두지 않겠어!", - "12": "여기까지 잘 왔구나! 하지만 지금부턴 쉽지 않을거야.", - "13": "배틀은 끝나지 않아! 끝없는 배틀의 세계에 온 것을 환영해!" - }, - "victory": { - "1": "우와! 넌 강하구나!", - "2": "하? 난 기회가 없었어.", - "3": "내가 조금 더 큰 다음엔 널 찾아서 때리겠어!", - "4": "으.. 더이상 가지고 있는 포켓몬이 없어.", - "5": "말도 안돼… 안돼! 내가 또 지다니…", - "6": "안돼! 내가 지다니!", - "7": "우와! 정말 깜짝 놀랐어! 넌 정말 강하구나!", - "8": "이럴수가… 내 포켓몬과 난 최강인데… 어떻게…", - "9": "다음엔 지지 않을거야! 다음에 다시 배틀하자!", - "10": "쳇! 내가 어린애인게 보이지 않아?! 그렇게 최선을 다하는건 불공평해!", - "11": "네 포켓몬은 정말 굉장하구나! 나와 교환하자!", - "12": "내가 잠깐 정신이 나갔었나 봐. 내가 무슨 말을 하고 있었지?", - "13": "아하! 거기구나! 좋아! 넌 이미 이 세계에 머무를 곳이 있구나!" - } - }, - "lass": { - "encounter": { - "1": "나랑 배틀하자, 어때?", - "2": "넌 신입 트레이너구나. 나랑 배틀하자!", - "3": "너 거기 있었구나? 나랑 배틀할래?", - "4": "재밌는 포켓몬 배틀하자!", - "5": "내가 포켓몬을 어떻게 다뤄야하는지 보여줄게!", - "6": "진정한 배틀은 진지한 자세부터 시작이야! 준비됐어?", - "7": "젊음이 한순간이듯 배틀에서 네 기회도 단 한번만 주어질거야. 곧 넌 추억속으로 사라질거야.", - "8": "나에겐 살살해도 돼, 알았지? 그래도 난 진지하게 싸울거야!", - "9": "학교는 지겨워. 나는 할 일이 없어. 하암~ 난 그저 시간을 때우기 위해 싸울뿐이야." - }, - "victory": { - "1": "인상적이었어! 난 아직 배울게 많구나.", - "2": "내가 이렇게까지 크게 질 줄은 몰랐어…", - "3": "언젠가 우리가 다시 배틀할 수 있을 날을 기다릴게.", - "4": "놀라울 정도로 엄청 재미있었어! 넌 날 완전히 지치게 만들어버렸네…", - "5": "넌 나에게 진짜 교훈을 주었어! 넌 정말 대단해!", - "6": "세상에, 내가 지다니. 이거 정말 우울하지만… 넌 정말 멋있었어.", - "7": "난 이런 기억따윈 필요없어. 잊어버리겠어…", - "8": "거기 너! 살살하라고 했지! 그래도 넌 진지할때 정말 멋지구나!", - "9": "사실 배틀하는 것이 지루하던 참이야… 뭔가 새로운 것이 없을까?" - } - }, - "breeder": { - "encounter": { - "1": "순종적인 포켓몬, 이기적인 포켓몬… 포켓몬들은 각기 다른 성격을 가지고 있지.", - "2": "내 태도가 그렇게 좋진 않아도, 내 포켓몬들은 잘 키웠어.", - "3": "음, 넌 포켓몬들을 훈육하니? 너무 심하게 하는 것은 좋지 않다고." - }, - "victory": { - "1": "각 포켓몬의 성격을 이해하고 육성하는 건 중요해.", - "2": "사악한 나와는 달리 좋은 포켓몬들도 있지.", - "3": "과도한 칭찬은 사람과 포켓몬 모두에게 독이 될 수 있어." - }, - "defeat": { - "1": "배틀에서 지더라도 포켓몬에게 화를 내면 안돼.", - "2": "어때? 꽤 괜찮은 포켓몬이지? 난 무언가 기르는 게 꽤 잘 맞더라고.", - "3": "네가 포켓몬을 얼마나 사랑하는지와 관계없이, 그들이 잘못을 저지르면 바로잡아야 해." - } - }, - "breeder_female": { - "encounter": { - "1": "포켓몬은 절대 널 배신하지 않아. 네가 주는 사랑을 고스란히 되돌려 준다구.", - "2": "좋은 포켓몬을 키우는 팁을 알려줄까?", - "3": "난 아주 특별한 방법으로 아주 특별한 포켓몬들을 키웠지!" - }, - "victory": { - "1": "이런… 이렇게 될 리가 없는데. 내가 블렌딩을 잘못 썼나?", - "2": "내 포켓몬에게 이런 일이… 넌 네 포켓몬에게 뭘 먹이는 거야?", - "3": "내가 지는 건 그저 내가 시간을 때우고 있었다는 걸 알려주는 거지. 내 자존심엔 전혀 상처가 되지 않는다구." - }, - "defeat": { - "1": "이건 내 포켓몬들이 내 사랑을 받아들였다는 걸 입증하지.", - "2": "좋은 포켓몬을 키우는 진짜 비결은 좋은 포켓몬을 잡는 거야.", - "3": "포켓몬의 강함과 약함은 네가 어떻게 키우느냐에 따라 결정되지." - } - }, - "fisherman": { - "encounter": { - "1": "앗! 너 때문에 한 마리 놓쳤잖아! 어떻게 할 거야?", - "2": "저리 가! 네가 포켓몬들을 놀래키고 있잖아!", - "3": "네가 승리를 낚을 수 있을지 한번 보자고!" - }, - "victory": { - "1": "그냥 잊어버려.", - "2": "다음 번엔 내가 승리의 나팔을 울리고 있을거다!", - "3": "이번엔 내가 물살을 과소평가했나보군." - } - }, - "fisherman_female": { - "encounter": { - "1": "월척이다!", - "2": "낚시대는 던져졌고, 이젠 성공을 끌어올리는 일만 남았다!", - "3": "파도를 일으킬 준비는 끝났어!" - }, - "victory": { - "1": "더 튼튼한 바늘을 가지고 돌아올테다.", - "2": "다음번엔 꼭 성공을 낚을 거야!", - "3": "다시 돌아올 날을 기다리며 바늘을 다듬고 있을게!" - } - }, - "swimmer": { - "encounter": { - "1": "뛰어들 시간이다!", - "2": "승리의 파도 속으로!", - "3": "첨벙댈 준비는 끝났어!" - }, - "victory": { - "1": "패배에 젖어버렸어…", - "2": "패배의 파도였군.", - "3": "해변으로 돌아갈 시간이군." - } - }, - "backpacker": { - "encounter": { - "1": "게임 시작이야! 짐 단단히 싸놓으라구!", - "2": "네가 속도를 유지할 수 있을지 보자!", - "3": "각오 단단히 하라고!", - "4": "20년 동안 나 자신을 찾기 위해 헤매왔어… 근데 내가 어디 있지?" - }, - "victory": { - "1": "이번엔 걸려 넘어져 버렸네!", - "2": "내가 속도를 잃어버렸잖아!", - "3": "막다른 길이야!", - "4": "잠깐! 그래 거기, 혹시 내가 누군지 아나?" - } - }, - "ace_trainer": { - "encounter": { - "1": "너는 꽤 자신만만해 보이는구나.", - "2": "너의 포켓몬들… 나에게 보여줘…", - "3": "내가 엘리트 트레이너라서, 사람들은 내가 강하다고 생각해.", - "4": "엘리트 트레이너가 되려면 무엇이 필요한지 알고 있니?" - }, - "victory": { - "1": "그러네… 넌 좋은 포켓몬을 가졌구나…", - "2": "뭐? 말도 안 돼, 난 배틀 천재라구!", - "3": "그래도 역시, 네가 주인공이구나!", - "4": "좋아! 좋아! 너도 엘리트 트레이너가 될 수 있겠어!" - }, - "defeat": { - "1": "난 내 몸과 마음을 포켓몬 배틀에 바치고 있어!", - "2": "모두 예상된 일이었어… 이건 놀랄 일이 아니야…", - "3": "난 내가 강하게 압박하면 무너질 연약한 사람이라고 생각했어.", - "4": "난 강하고, 지지 않아. 그저 멋지게 이길 수 없었기 때문이야." - } - }, - "parasol_lady": { - "encounter": { - "1": "우아함과 침착함으로 승부하겠습니다!" - }, - "victory": { - "1": "그래도 제 우아함은 무너지지 않아요!" - } - }, - "twins": { - "encounter": { - "1": "각오해, 우리가 한 팀이 되면 두 배로 강해진다구!", - "2": "마음은 두 개지만 우리는 하나 – 네가 쌍둥이의 파워를 따라잡을 수 있는지 보겠어!", - "3": "두 배로 각오하는 게 좋을 거야. 우리가 곧 화나게 할 거거든!" - }, - "victory": { - "1": "비록 우리는 졌지만, 우리의 관계는 깨지지 않아!", - "2": "그래도 우리의 영혼은 오랫동안 흐려지지 않을 거야.", - "3": "더 강력한 듀오로 강해져서 돌아오겠어!" - }, - "defeat": { - "1": "우리 쌍둥이의 파워는 최고야!", - "2": "마음은 두 개지만 승리는 하나!", - "3": "미소도 두 배, 승리의 댄스도 두 배!" - } - }, - "cyclist": { - "encounter": { - "1": "내가 만든 먼지나 마실 준비하시지!", - "2": "준비하라구! 난 널 먼지 속에 놓고 올 거니까!", - "3": "전력을 다해야 할 거야, 네가 날 따라올 수 있는지 지켜보겠어!" - }, - "victory": { - "1": "바퀴가 움직이지 않더라도, 나의 페달은 그렇지 않아.", - "2": "이런, 따라잡혔어!", - "3": "승리로 가는 길에는 아직 만나지 못한 우여곡절이 많이 있구나." - } - }, - "black_belt": { - "encounter": { - "1": "네 용기가 대단하구나! 난 최고의 발차기 실력을 갖추고 있다구!", - "2": "오, 알겠어. 산산조각이 나고 싶구나? 아니면 샌드백이 되고 싶은 거야?" - }, - "victory": { - "1": "이런, 포켓몬이 배틀을 하는 동안 내 발차기는 전혀 도움이 되지 않았어.", - "2": "음… 어차피 내가 질거라면, 완전 엉망진창이 되길 바랬는데…" - } - }, - "battle_girl": { - "encounter": { - "1": "감동을 주려고 노력할 필요는 없어. 네가 질 수도 있으니까." - }, - "victory": { - "1": "작별인사는 어렵지만, 우리에겐 시간이 얼마 안 남았네…" - } - }, - "hiker": { - "encounter": { - "1": "중년으로 접어들면서 등산해왔던 산처럼 진중해졌습니다!", - "2": "살아있는 산같은… 큰 체격을 부모님이 물려주셨죠…" - }, - "victory": { - "1": "적어도 BMI에 대해서는 질 수 없습니다!", - "2": "부족해… 절대로 충분하지 않아. 저의 콜레스테롤이 부족합니다…" - } - }, - "ranger": { - "encounter": { - "1": "자연에 둘러싸여 있으면, 다른 건 중요하지 않게 느껴져.", - "2": "인생에서 자연을 빼고 살면, 가끔 갑자기 마음이 불안해지지." - }, - "victory": { - "1": "광활한 자연 앞에서는 내가 이기든 지든 상관없어…", - "2": "도시 생활의 답답한 느낌에 비하면 이런 것은 아주 사소한 일지." - }, - "defeat": { - "1": "내가 이겼네. 그러나 승리는 광대한 자연에 비하면 아무것도 아니야…", - "2": "내 마음속 불안함과 비교하면, 당신 기분은 그렇게 나쁘지 않을텐데…" - } - }, - "scientist": { - "encounter": { - "1": "제 연구는 이 세상을 평화와 기쁨으로 이끌 겁니다." - }, - "victory": { - "1": "전 천재니까… 당신 같은 사람에게 질 수 없는데…" - } - }, - "school_kid": { - "encounter": { - "1": "…헤헷. 계산과 분석에는 자신 있어.", - "2": "언젠가 체육관 관장이 되고 싶어서, 최대한 많은 경험을 쌓고 있어." - }, - "victory": { - "1": "으아아… 이번에는 아마 계산과 분석이 빗나간 것 같아…", - "2": "내가 보기엔, 어렵고 힘든 경험도 나름의 의미가 있는 것 같아." - } - }, - "artist": { - "encounter": { - "1": "예전엔 인기가 많았지만, 지금은 모두 사라졌다네." - }, - "victory": { - "1": "시대가 변하면, 가치관도 변하지. 난 그걸 너무 늦게 깨달았어." - } - }, - "guitarist": { - "encounter": { - "1": "패배의 리듬을 느낄 준비는 됐겠지? 내가 승리할 거니까!" - }, - "victory": { - "1": "지금은 조용하지만, 회복의 멜로디를 연주할 거야." - } - }, - "worker": { - "encounter": { - "1": "사람들이 저를 오해하는 게 신경 쓰여요. 전 생각보다 훨씬 깨끗하답니다." - }, - "victory": { - "1": "피부가 타는 게 싫어서, 일하는 동안엔 그늘에 머물고 싶어요." - } - }, - "worker_female": { - "encounter": { - "1": "사람들이 나를 오해하는 게 신경 쓰여.\n$나는 생각보다 훨씬 깨끗한데." - }, - "victory": { - "1": "피부가 타는 게 싫어서, 일하는 동안엔 그늘에 머물고 싶어." - }, - "defeat": { - "1": "생각처럼 몸이 잘 안따라주네." - } - }, - "worker_double": { - "encounter": { - "1": "너를 무너뜨릴 수 있다는 것을 보여줄게. 우리는 실전 경험이 있거든!" - }, - "victory": { - "1": "이상하네… 어떻게 이럴 수 있지… 힘으로 압도할 수 없다니." - } - }, - "hex_maniac": { - "encounter": { - "1": "평소에는 클래식 음악만 들었는데, 지면 뉴에이지도 좀 들어볼까!", - "2": "눈물을 흘릴 때마다 더 강해지는 것 같아." - }, - "victory": { - "1": "지금이 물병자리 시대의 시작일까?", - "2": "이제 나는 더 강해지겠지. 모든 원한과 함께 성장하겠어." - }, - "defeat": { - "1": "뉴에이지란 단순히 20세기 클래식 작곡가들을 말하는 거, 맞지?", - "2": "슬픔이나 좌절에 얽매이지 마. 넌 그 원한을 원동력으로 사용할 수 있어." - } - }, - "psychic": { - "encounter": { - "1": "안녕! 집중해!" - }, - "victory": { - "1": "에에에에엣!" - } - }, - "officer": { - "encounter": { - "1": "마음의 준비를 하시죠, 정의가 곧 실행될 거니까요!", - "2": "법을 지키고 정의를 위해 봉사할 준비가 되었습니다!" - }, - "victory": { - "1": "정의의 무게가 그 어느 때보다 무겁게 느껴집니다…", - "2": "패배의 그림자가 관할 경찰서에 남았습니다." - } - }, - "beauty": { - "encounter": { - "1": "나의 마지막 배틀… 이 승부를 그렇게 봐주셨으면 좋겠어요…" - }, - "victory": { - "1": "즐거웠어요… 언젠가 또 다른 마지막 승부를 하죠…" - } - }, - "baker": { - "encounter": { - "1": "패배의 맛을 볼 준비는 됐겠지!" - }, - "victory": { - "1": "실력이든 빵이든, 굽고 나면 단단해지는 법이라네." - } - }, - "biker": { - "encounter": { - "1": "힘차게 먼지 속으로 출발할 시간입니다!" - }, - "victory": { - "1": "다음 경주를 위해 준비해야겠습니다." - } - }, - "firebreather": { - "encounter": { - "1": "내 불꽃이 너를 삼킬 테니까!", - "2": "내 영혼은 불타고 있다. 얼마나 뜨겁게 타는지 보여주지!", - "3": "이리 올라와서 보도록!" - }, - "victory": { - "1": "하얗게 불태웠다………", - "2": "큭! 제법 뜨겁군!", - "3": "으윽! 코끝에 화상을 입었다!" - } - }, - "sailor": { - "encounter": { - "1": "친구여, 진다면 널빤지 행이야!", - "2": "덤벼! 내 선원으로서 자존심이 위태롭군!", - "3": "여어 거기! 뱃멀미 하나?" - }, - "victory": { - "1": "크윽! 꼬맹이한테 지다니!", - "2": "네 영혼이 나를 침몰시켰어!", - "3": "내가 뱃멀미가 나는 것 같군…" - } - }, - "archer": { - "encounter": { - "1": "더 나아가기 전에 우리 로켓단과 맞설 만한지 한 번 봅시다!", - "2": "당신의 실력이 예사롭지 않다는 소식을 들었습니다. 정말인지 한 번 보지요.", - "3": "…저는 로켓단의 간부 아폴로. 우리 조직의 적에게는 봐 주지 않습니다!" - }, - "victory": { - "1": "…이런 실수를 하다니!", - "2": "역시 지금의 저는 무리였군요…", - "3": "비, 비주기님, 용서해주십시오…제가 일개 트레이너한테 당하다니…" - } - }, - "ariana": { - "encounter": { - "1": "거기까지다~!! 너 같은 놈을 언제까지고 설치게 두었다가는 \n$로켓단의 프라이드는 상처 입고 상처 입어서 상처투성이가 돼 버린다고-!", - "2": "내가 하는 일이 옳은지 그른지는 상관 없어…\n$그저 비주기님을 믿고 따르는 것 뿐이니까-!", - "3": "네 여정은 여기서 끝이야. 내가 널 이길 테니까-!" - }, - "victory": { - "1": "어머, 강하군. 안타깝네.\n$네가 로켓단에 있었다면 간부가 될 수 있었을 텐데.", - "2": "사…산산조각났네…", - "3": "으이이이익! 온 힘을 다해서 싸웠는데…이래도 이길 수 없다니!" - } - }, - "proton": { - "encounter": { - "1": "뭐죠? 우리 일에 끼어든다면 자비를 바라지 마십시오!", - "2": "뭐죠? 나는 로켓단에서 제일 냉혹하다고 불리는 남자…\n$우리 일을 방해하도록 그냥 놔두지 않겠습니다!", - "3": "나는 로켓단의 간부 랜스. 당신의 참견도 여기까지입니다!" - }, - "victory": { - "1": "요새가 무너져내렸네요…", - "2": "나한테 이긴 건 결국 로켓단의 분노를 강하게 했을 뿐이예요…", - "3": "나는 졌지만, 결코 이 일을 잊지 않을 겁니다!" - } - }, - "petrel": { - "encounter": { - "1": "후후훗, 잘 왔구나. 오잉? 내가 누군지 알아? 비주기야.\n$비주기님이라고, 우-하하! …엥? 전혀 안 닮았다고?\n$비주기님으로는 안 보인다고? 제길- 열심히 연습했는데!", - "2": "나는 로켓단의 간부 람다. 우리 계획을 방해하는 건 용납할 수 없다!", - "3": "이 로켓단 간부 람다가 네놈 불청객을 처리해 주지!" - }, - "victory": { - "1": "조…좋아. 비주기님이 어디 계신지 알려주지.", - "2": "크으으… 이 내가 당해낼 수 없다니… 비주기님, 용서해주십시오…", - "3": "안돼, 이런다고 나한테 어쩔 수는 없어. 다른 사람들에게 알려야겠어…" - } - }, - "tabitha": { - "encounter": { - "1": "우효효효! 그래 당신 여기까지 왔구나! 그치만 늦었어요!", - "2": "우효효… 벌써 여기까지 왔네요? 우리가 당신을 과소평가했어요. 하지만 이제 시작입니다! \n$이 호걸님은 이제까지 본 조무래기들과는 차원이 다르답니다! 우물쭈물 시간을 끌지 않아요.\n$확실하게 보내주마! 우효효효효효효!!", - "3": "여기서 어른의 무서움을 제대로 알려주지! 받아랏-!" - }, - "victory": { - "1": "우효효! 이 호걸은 이겼을지 몰라도 마적님한테는 안 될 겁니다!\n$차라리 여기서 졌다면 무자비한 채찍질은 피했을텐데 말이죠!", - "2": "우효~! 이야 이건 예상 밖의 전개인데!?", - "3": "우효! 어떻게?! 이 호걸님이 이런 일개 트레이너에게…" - } - }, - "courtney": { - "encounter": { - "1": "…그 …네가 가진 …우리…마그마단이 원하는 것", - "2": "…………그럼 …………삭제하겠습니다", - "3": "……애널라이즈 ……하고 싶어 ……아하하하♪" - }, - "victory": { - "1": "……하아하아… ……으 …하아하아…", - "2": "………예상대로 ………예상외 ………너 …………타깃 록 ………했으니까\n$……엑스페리먼트 ……할 테니까 ………너를………계속………아핫…♪", - "3": "……예상외 ………… ……역시 ……너…재미있어…! ………아하하…♪" - } - }, - "shelly": { - "encounter": { - "1": "엥? 우리 아쿠아단의 일에 끼어들겠다고?\n$…좋아! 기본적인 예의도 모르는 애송이한테는 제대로 그 버릇을 고쳐줘야지…\n$겁먹고 도망쳐도 용서 따위 없을 줄 알아! 우하하하!", - "2": "아앙? 뭐야? 이 건방진 꼬맹이는…", - "3": "침착해. 조급해 하지 말라고… 금방 박살내 줄 테니까." - }, - "victory": { - "1": "아아아아앙!? 예상치 못하게 방해받았잖아! 어쩔 수 없네.\n$여기선 물러나야겠네. 그렇지만 네가 아쿠아단을 만나는 게 이게 마지막은 아닐 거야.\n$우리는 다른 계획도 있거든! 잊지 마!", - "2": "크윽…!? 너무 봐줬나…!", - "3": "…으윽 …싸우면서 더욱 실력이 좋아졌다고…!?\n$장래가 무서워지는 애송이네… …나와 내 포켓몬들은 더 이상 싸울 힘이 남아 있지 않아.\n$…가 …가서 아강님한테 아주 혼쭐이나 나 버려." - } - }, - "matt": { - "encounter": { - "1": "…그래서 말이지, 리더님이 시간이 나실 때까진 내가 상대해 주마!", - "2": "후우하앗!! 맥시멈!! 끓어어!! 오르기 시작했다아아앗!!!!! 그래! 그래! 그래애앳!!! 힘이 다할 때까지 해보자아아!!!", - "3": "UPAAAAA!!! 짓뭉개주마아아아아!!" - }, - "victory": { - "1": "흐~하하하핫!!! 졌지만 즐거운 승부였다!", - "2": "확 확 느껴지는데! 네놈들의 강함이 말이야!\n$제대로 붙었다고 하기엔 조금 모자라지만 이제 타임오버 같네…", - "3": "오우오웃! 흥분되는 패배로다!" - } - }, - "mars": { - "encounter": { - "1": "난 갤럭시단 간부인 마스! 강하고 아름답지!", - "2": "갤럭시단의 미래에 대한 비전은 흔들림 없지. 방해한다면 무자비하게 짓밟아 주마!", - "3": "두렵지 않아? 넌 그래야만 할 걸!" - }, - "victory": { - "1": "갤럭시단의 간부로서… 이런 일은 있을 수 없어!!", - "2": "넌 능력 있구나. 그건 인정하지.", - "3": "아-이런 이런! 졌잖아!" - } - }, - "jupiter": { - "encounter": { - "1": "무슨 볼일이라도? 좋아! 갤럭시단 간부인 나 주피터가 상대해주지.", - "2": "발버둥쳐 봐야 소용 없어. 갤럭시단이 승리할 거니까!", - "3": "너 떨고 있네… 무서운 거지?" - }, - "victory": { - "1": "일개 트레이너에게 지다니 방심이란 무섭구나.", - "2": "다음에는 내가 울려 주고 말겠어!", - "3": "흥! 강하네. 하지만 보스는 당할 수 없어" - } - }, - "saturn": { - "encounter": { - "1": "나는 갤럭시단의 간부 새턴. 모든 것은 모두를 위해 그리고 갤럭시단을 위해!", - "2": "갤럭시단을 방해한다면 일말의 가능성도 모두 제거한다!", - "3": "여기까지 왔으니 갤럭시단 나름의 접대를 해 주지." - }, - "victory": { - "1": "이럴 수가… 너한테 졌다고?!", - "2": "…역시 강해! 갤럭시단에 맞설 만하군.", - "3": "강하다! 하지만 불쌍하군." - } - }, - "zinzolin": { - "encounter": { - "1": "너는 플라스마단에게 있어 불안요소가 될 것이다. 여기서 제거하겠다!", - "2": "이런 이런… 내가 이런 곳에서 싸워야만 하다니!", - "3": "여기까지 오다니 대단한 트레이너군. 그러나 여기가 끝이다." - }, - "victory": { - "1": "게치스님… 제가 실패했습니다…", - "2": "그건 그렇고 힘들구먼. 나는 떨고 있다. 괴롭지만 살아 있다. 그것이야말로 살아 있다는 실감!", - "3": "흐음. 의외로 똑똑한 트레이너군. 하지만 생각만큼은 아니야." - } - }, - "rood": { - "encounter": { - "1": "너는 플라스마단에 위협이 되는구나. 너라는 트레이너가 어떤 인물인지 승부로 알아봐야겠다.", - "2": "오호! 싸늘하구먼… 이런 곳에서 싸울 줄이야!", - "3": "너는 여기까지 온 것으로 보니 뛰어난 트레이너구나. 그렇다만 이젠 끝이다." - }, - "victory": { - "1": "게치스님… 임무를 실패했습니다…", - "2": "나는 떨고 있다. 나는 괴롭지만 이겨냈다.", - "3": "음… 너는 재능이 있는 트레이너구나. 하지만 충분하지는 않다." - } - }, - "xerosic": { - "encounter": { - "1": "오오- 네 소문은 많이 들었다. 자, 이리 와 보거라!", - "2": "너 강하구나. 에너지를 얼마나 갖고 있지?", - "3": "기다리고 있었어! 너를 조사하겠다. 자 시작한다!" - }, - "victory": { - "1": "강하구나, 너는. 응, 정말 강해, 너는.", - "2": "뭣이라! 넌 굉장하군! 너의 포켓몬도 대단하군!", - "3": "굉장하구나 너! 아주 굉장해! 나는 너를 인정하겠다!" - } - }, - "bryony": { - "encounter": { - "1": "나는 바라. 당신과 싸울 수 있어 기쁘군요. 한 번 보여주시죠.", - "2": "인상적이군요… 보기보다 강해요. 에너지가 어디까지 뻗어나가는지 봅시다.", - "3": "도착할 줄 알았습니다. 시작할까요?" - }, - "victory": { - "1": "어라? 이길 확률은 어디까지나 확률. 절대적이진 않네.", - "2": "확률을 무시하는 트레이너, 네 파워의 원천은 뭐지?", - "3": "놀랍군! 칭찬할 만 해." - } - }, - "rocket_grunt": { - "encounter": { - "1": "트러블에 대비하도록!", - "2": "우리는 위업을 이루는 중이라고! 저리 비켜, 꼬마 녀석!", - "3": "포켓몬을 넘기지 않겠다면, 로켓단이 징벌하겠다!", - "4": "로켓단의 진정한 공포를 보여주마!", - "5": "헤이, 키드! 미는 로켓단의 멤버라구요!" - }, - "victory": { - "1": "로켓단은 다시 떠오를 거니까!", - "2": "이런! 엘리베이터 키를 떨어뜨렸어!", - "3": "실패했군!", - "4": "내 동료들이 가만히 있지 않을 거다!", - "5": "유 쎄이 왓? 로켓단이 바이바이? 유한테 브레이킹?" - } - }, - "magma_grunt": { - "encounter": { - "1": " 마그마단을 방해한다면, 자비는 없닷!", - "2": "계획을 방해하지 않는 게 좋을 거다! 우리는 세상을 더 나은 곳으로 만들고 있거든!", - "3": "방해꾼 녀석! 마그단은 너 같은 꼬마들을 상대할 시간이 없어!", - "4": "마시멜로를 갖고 있었으면 좋겠네. 왜냐하면… 곧 뜨거워질 테니까!", - "5": "화산의 힘을 사용할 거야! 그건 정말로… 폭발적일 테니까! 알아들었지? 헤헷!" - }, - "victory": { - "1": "하? 내가 졌어?!", - "2": "내가 지다니! 이것 때문에 점심도 거르고 왔는데.", - "3": "말도 안돼! 넌 아직 어린애잖아!", - "4": "으윽… 당장 은신처로 숨을 걸 그랬나…", - "5": "네가 이겼어… 이것 때문에 보스가, 내 월급 깎으려나?" - } - }, - "aqua_grunt": { - "encounter": { - "1": "아쿠아단을 넘본 사람에게는 자비는 없다, 꼬마도 마찬가지야!", - "2": "쯧… 아쿠아단에 참견하다니 오지랖이 넓군!", - "3": "흠뻑 물을 뒤집어쓰게 될 거다! 내 물 포켓몬의 공격 뿐만이 아니야!", - "4": "우리, 아쿠아단은, 모두를 위해 존재한다!", - "5": "내가 떠밀… 아니, 파도에 떠내려갈 준비나 하라고! 내 포켓몬이 그렇게 만들 테니까 " - }, - "victory": { - "1": "말도 안 돼!", - "2": "크윽, 참견쟁이 꼬마에게 당하다니!", - "3": "내가 졌다고?! 헤엄쳐서 은신처로 돌아가야겠군…", - "4": "이런, 완전 망했군… 보스가 화를 내실텐데…", - "5": "네가 이겼어… 이것 때문에 보스가, 나를 판자 위로 보내는 거 아냐?" - } - }, - "galactic_grunt": { - "encounter": { - "1": "갤럭시단을 방해하지 마!", - "2": "기술의 힘과 우리가 꿈꾸는 미래를 목격하라!", - "3": "갤럭시단으로서, 우리를 방해하는 자는 누구든 제거하겠다!", - "4": "질 준비나 하라고!", - "5": "우주에서 싸울 준비는 됐겠지!" - }, - "victory": { - "1": "사격 중지…… ", - "2": "이런 좌절이라도, 우리의 큰 계획 앞엔 아무 의미도 못 돼.", - "3": "우리의 계획은 이번 패배보다 크거든.", - "4": "어떻게 한 거지?!", - "5": "메모해야겠군. 최대한 포켓몬 배틀을 ASAP으로 연습할 것." - } - }, - "plasma_grunt": { - "encounter": { - "1": "다른 생각을 가진사람들은 용납하지 않겠다!", - "2": "내가 이기면, 네 포켓몬들을 놓아주도록 해!", - "3": "플라즈마단을 방해한다면, 내가 처리해주지!", - "4": "플라즈마단은 너 같은 이기적인 인간에게서 포켓몬을 해방할 것이다!", - "5": "우리 스타일링은 정말 대단하지… 배틀 실력은 어떻냐고? 곧 알게 될거야." - }, - "victory": { - "1": "플라-스마-!", - "2": "내가 지다니…", - "3": "…포켓몬이 너무 약해, 더 좋은 포켓몬을 훔치러 가야겠군!", - "4": "훌륭한 계획은 항상 방해를 받는다니깐.", - "5": "이건 나빠… 나빠나빠나빠나빠나빠! 플라스마단에 나빠! 줄여서, 플라나빠!" - } - }, - "flare_grunt": { - "encounter": { - "1": "네 포켓몬, 플레어단의 우아함에 상대가 되지 않는다고.", - "2": "선글라스를 가져왔길 바랄게. 곧 밝게 빛날 테니까!", - "3": "플레어단이 세상의 불완전함을 정화할 거야!", - "4": "플레어단의 광채를 마주칠 준비는 됐겠지!", - "5": "패션이 우리한텐 가장 중요하다고!" - }, - "victory": { - "1": "미래가 밝아 보이질 않네.", - "2": "생각했던 것보다 전투에는 많은 요소가 있는 것 같군. 다시 계획을 짜야겠어.", - "3": "아앗?! 내가 졌어?!", - "4": "패배 속에서도, 플레어단의 우아함은 빛나고 있다고.", - "5": "네가 이긴 것 같네. 그렇지만 졌어도, 난 우아하게 퇴장할 거니까!" - } - }, - "aether_grunt": { - "encounter": { - "1": "죽을 각오로 퇴치하겠습니다!", - "2": "소중한 연구라고! 애라도 가만두지 않겠어!", - "3": "어떤 트레이너든 물리치라고 들었다고!", - "4": "에테르파라다이스의 파워를 보여드리겠습니다!", - "5": "에테르파라다이스 중심의 어둠을 알아내다니. 이제 사라져 주셔야겠습니다!" - }, - "victory": { - "1": "흥! 실력이 대단하시군요.", - "2": "이게 뭐하는 상황이지? 무슨 결과냐고!", - "3": "이런! 넌 너무 강해서 물리칠 방법도 없다고!", - "4": "으음… 제가 진 것처럼 보이네요.", - "5": "이 느낌을 한마디로 하면. 게에이~힝!!" - } - }, - "faba": { - "encounter": { - "1": "나, 에테르재단의 자우보! 꼬맹이 녀석에게 현실을 보여주겠어요!", - "2": "에테르파라다이스 마지막 보루라고 불리는, 이 자우보에게 애를 상대하라고요?", - "3": "에테르재단의 지부장이라면 세계에 단 한 명… 이 자우보뿐입니다." - }, - "victory": { - "1": "게에이~힝!!", - "2": "뭐 뭐뭐뭐 뭐가 어떻게 된 거죠? 내가 애를 상대로…", - "3": "이래서 애는… 좋아할 수가 없어요." - } - }, - "skull_grunt": { - "encounter": { - "1": "나쁜 짓 안해-그냥 사는 게 힘들 뿐스컬!", - "2": "껌 하나 드실? 이게 우리가 인사하는 방식YO! 만나서 반갑스컬!", - "3": "우린 그냥 다른 사람의 포켓몬에 관심이 많을 뿐임다!", - "4": "어이 어이! 잘난 체하는 녀석한테 무시당하고 있잖스컬!!", - "5": "우리는 리프리젠트 땡땡이 스컬-! 집세는 못 내겠지만-! 정말 즐거웠지만, 청춘을 날려YO!" - }, - "victory": { - "1": "엥? 벌써 끝났슴까?", - "2": "미는 엑시트! 유는 피쓰풀!", - "3": "꼬마 녀석의 이상한 포켓몬엔 관심 없어!", - "4": "뭐야-?! 너무 강해서 뼈도 못 추리겠어!", - "5": "우리가 포켓몬보다 아래야!? 소중히 대해주면 안 돼? 으응!?" - } - }, - "plumeria": { - "encounter": { - "1": "…아무것도 느껴지지 않는 평~범한 애로 보이는데!", - "2": "워낙 애들 상대로 우물쭈물 하길래 오래 걸릴 줄 알았지…", - "3": "누구라도 스컬단 또 방해하면, 정말로 혼내줄 테니까!" - }, - "victory": { - "1": "흥! 대단하군.", - "2": "흐음, 너 참 대단하군. 애들을 상대로 질질 끈 이유가 이해될 정도로 강해.", - "3": "흠. 이 손실은 그냥 안고 가야겠어." - } - }, - "macro_grunt": { - "encounter": { - "1": "당신은 여기서 끝날 것 같네요!", - "2": "당신은 트레이너 맞죠? 하지만 우리를 방해하는 건 용납 못 합니다!", - "3": "매크로코스모스 생명입니다! 가입하신 실비보험은 있으신가요?" - }, - "victory": { - "1": "순순히 물러나는 것 말고는 선택지가 없군요.", - "2": "용돈을 뺏기다니… 패배는 적자로 이어지는구나…", - "3": "매크로코스모스 생명에 관한 일이라면 누구에게도 지지 않을 텐데…" - } - }, - "oleana": { - "encounter": { - "1": "로즈님을 방해하는 것은 절대로 용서할 수 없으니까요!", - "2": "저의 지시를 따르는 특별한 스태프들을 아무렇지도 않게 쓰러뜨리다니. …더 기대되는 것도 없네요.", - "3": "로즈님을 위해서라면! 질 수 없습니다!" - }, - "victory": { - "1": "아아… 이기지 못하다니… 올리브… 넌 정말 구제 불능이구나.", - "2": "하아아…! 이런 실수를 하다니… 승리를 거듭한 트레이너의 실력을 너무 얕잡아봤던 모양이네요.", - "3": "아아… 이 올리브님 조금 지쳤어…" - } - }, - "rocket_boss_giovanni_1": { - "encounter": { - "1": "그래서! 여기까지 오다니, 감탄이 절로 나오는군!" - }, - "victory": { - "1": "하! 이럴 순 없어!" - }, - "defeat": { - "1": "자신의 힘을 측정하지 못하는 걸 보아하니, 아직 별볼일 없는 꼬맹이로군. 내 말을 명심하도록. " - } - }, - "rocket_boss_giovanni_2": { - "encounter": { - "1": "옛 친구들이 나를 필요로 하고 있다…… 그런데도 방해하겠다는 건가?" - }, - "victory": { - "1": "어떻게 이런 일이…?\n로켓단의 소중한 꿈이 환상에 불과해졌군…… " - }, - "defeat": { - "1": "로켓단은 다시 태어난다, 그리고 세상을 지배할 것이다!" - } - }, - "magma_boss_maxie_1": { - "encounter": { - "1": "내 손으로 널 파묻어주지. 영광으로 알도록!" - }, - "victory": { - "1": "윽! 꽤… 제법이군…\n내가 뒤쳐졌지만, 겨우 한 끝이다…" - }, - "defeat": { - "1": "마그마단이 앞선다!" - } - }, - "magma_boss_maxie_2": { - "encounter": { - "1": "나와 내 목표 사이에 남은 마지막 장애물이로군.\n최후의 공격에 대비하도록! 후하하하!" - }, - "victory": { - "1": "이런… 이럴 수는… 없어… " - }, - "defeat": { - "1": "이제부터… 인류의 이상을 위해 대지를 더 늘려가겠다." - } - }, - "aqua_boss_archie_1": { - "encounter": { - "1": "내가 아쿠아단의 리더다, 유감스럽게도 넌 이게 끝이겠군." - }, - "victory": { - "1": "다시 어딘가에서 만나도록하지. 그 얼굴 기억해둘테니까." - }, - "defeat": { - "1": "좋군! 이제 아쿠아단을 막아설 것은 없다!" - } - }, - "aqua_boss_archie_2": { - "encounter": { - "1": "이 날이 오는 것을 너무 오래 기다렸군.\n이것이 우리의 진정한 힘이다!" - }, - "victory": { - "1": "내가 생각했던 것들이…… " - }, - "defeat": { - "1": "이 세상을 원래의 순수한 상태로 되돌리겠다, 그 모든 것을!!" - } - }, - "galactic_boss_cyrus_1": { - "encounter": { - "1": "넌 공허한 감정에 이끌려 이곳에 오게된 것이다.\n마음에 귀를 기울인 것을 후회하게 해주지!" - }, - "victory": { - "1": "흥미롭군. 게다가 꽤 궁금해졌어." - }, - "defeat": { - "1": "새로운 세상을 만들 것이다…" - } - }, - "galactic_boss_cyrus_2": { - "encounter": { - "1": "이런 우리가 다시 만나게 됐군. 우리의 운명이 얽히게 된 것 같군.\n 하지만 지금 여기서, 나는 마침내 그 끈을 끊을 것이다!" - }, - "victory": { - "1": "어떻게? 어째서? 어떻게?!" - }, - "defeat": { - "1": "작별이로군." - } - }, - "plasma_boss_ghetsis_1": { - "encounter": { - "1": "누구도 저를 막을 수 없습니다! 무슨 짓을 하더라도!" - }, - "victory": { - "1": "…어떻게 된 거지? 이 몸은 플라스마단을 만들어낸 완벽한 남자라고! " - }, - "defeat": { - "1": "세계를 바꿀 완전한 지배자가 아니었단 말인가!? …흐하하!" - } - }, - "plasma_boss_ghetsis_2": { - "encounter": { - "1": "오시죠! 당신이 모든 희망을 잃는 순간의 얼굴을 보겠습니다!" - }, - "victory": { - "1": "내 계산이… 틀려! 내 치밀한 계획이 틀리다니! 세상은 내 것이어야 하는데!" - }, - "defeat": { - "1": "큐레무! 합체해라!" - } - }, - "flare_boss_lysandre_1": { - "encounter": { - "1": "나를 막겠다고? 배틀로 증명하도록." - }, - "victory": { - "1": "네가 나를 여기서 막았군. 하지만 잠시 기다리도록. " - }, - "defeat": { - "1": "포켓몬은… 더 이상 존재하지 않는다." - } - }, - "flare_boss_lysandre_2": { - "encounter": { - "1": "너의 미래와 나의 미래… 어느 쪽이 옳은지 서로의 포켓몬에게 묻도록 하지." - }, - "victory": { - "1": "크윽!" - }, - "defeat": { - "1": "우매한 자들이 이 아름다운 세상을 계속 더럽히고 있군." - } - }, - "aether_boss_lusamine_1": { - "encounter": { - "1": "비스트가 놀라잖아! …우선은 너를 조용히 시켜야겠어." - }, - "victory": { - "1": "……너무해!" - }, - "defeat": { - "1": "흐음…" - } - }, - "aether_boss_lusamine_2": { - "encounter": { - "1": "그렇게 말했는데도! …왜 이리 끈질긴 거야! 정말 진절머리가 나.\n$더 말해봐야 소용 없겠지… 텅비드의 힘으로 네가 여기까지 온 걸 후회하게 해줄게!" - }, - "victory": { - "1": "………아아아웃!!" - }, - "defeat": { - "1": "나는 비스트만 있으면 돼! 너희가 어떻게 되든 상관없어!" - } - }, - "skull_boss_guzma_1": { - "encounter": { - "1": "박살 내고 박살 내도 절대 봐주지 않아…\n$모두가 싫어하는 구즈마가 여기 있다!" - }, - "victory": { - "1": "쯧. 너는 내가 박살 내주겠어!" - }, - "defeat": { - "1": "겨우 그걸 위해서 일부러 온 거야?" - } - }, - "skull_boss_guzma_2": { - "encounter": { - "1": "누구든지 박살 낸다!\n$그것이 구즈마님의 아이덴티티!!" - }, - "victory": { - "1": "구즈마!!! 뭐 하고 있는 거야?!" - }, - "defeat": { - "1": "너희들 바보군!" - } - }, - "macro_boss_rose_1": { - "encounter": { - "1": "내게는 모든 사람이 영원히 마음을 놓고 발전할 수 있도록…\n$무한한 에너지를 가져다 줘야 한다는 신념과 사명이 있단다!" - }, - "victory": { - "1": "아직 무르군… 트레이너.\n$역사는 바뀔 것이네! 이 나의 손에 의해서 말이지" - }, - "defeat": { - "1": "자네는 여전히 깨닫지 못했군!" - } - }, - "macro_boss_rose_2": { - "encounter": { - "1": "나는 가라르를 포함한— 전 세계의 에너지 문제를 해결하기 위해 최선을 다하고 있어.\n$매크로코스모스를 성공으로 이끈 경험과 성과는 내 방식이 효율적이라는 증거란다.\n$생각을 바꿀 마음은 없어. 내가 지더라도." - }, - "victory": { - "1": "포켓몬 승부는 좋군! 오랜만에 싸워보니 만족스러워…\n$제법 괜찮군. 패배를 인정하지." - }, - "defeat": { - "1": "너희가 보기에는 내가 끔찍한 짓을 벌이고 있는 것처럼 보이겠지? 조금도 이해가 가지 않을 거야.\n$하지만 난 가라르지방의 영원한 번영을 위해서 무한한 에너지를 가져다줘야 해." - } - }, - "brock": { - "encounter": { - "1": "내 전문인 바위 타입 포켓몬으로 널 쓰러뜨려줄게! 덤벼!", - "2": "바위같은 의지로 널 압도하겠어!", - "3": "내 포켓몬의 진정한 힘을 보여줄게!" - }, - "victory": { - "1": "네 포켓몬의 힘이 바위같은 내 방어를 이겼어!", - "2": "세상은 넓구나! 너랑 겨뤄볼 수 있어서 즐거웠어.", - "3": "아마도 난 포켓몬 브리더의 꿈을 이루러 가야할지도…" - }, - "defeat": { - "1": "최선의 공격은 적절한 방어지!\n그게 내 방식이야!", - "2": "다음에 나한테 더 배우러와. 바위타입과 어떻게 싸워야하는지 알려주지!", - "3": "아, 여러 지역을 돌아다니며 여행한 보람이 있군!" - } - }, - "misty": { - "encounter": { - "1": "내 방침은 물타입 포켓몬으로 공격하고 공격하고 또 공격하는 거!", - "2": "아하핫, 너한테 내 물타입 포켓몬들의 힘을 보여줄게!", - "3": "내 꿈은 여행을 다니며 강한 트레이너들과 배틀하는 거였어…\n네가 그 충분한 도전자가 될 수 있는지 볼까?" - }, - "victory": { - "1": "너 정말로 강하구나… 그 실력 인정하도록 할게…", - "2": "으으… 너 그냥 운이 좋았던거야, 그치?!", - "3": "우와, 너 대단해! 날 이기다니 믿을 수 없어!" - }, - "defeat": { - "1": "최강인 최이슬! 너한테 좀 심했나?", - "2": "내 포켓몬들의 우아한 수영 테크닉을 봤길 바랄게!", - "3": "내 프라이드와 즐거움엔 네 포켓몬들은 상대가 안 돼. " - } - }, - "lt_surge": { - "encounter": { - "1": "마이 전기 포켓몬은 전쟁에서 미를 구했어요! 하우를 유에게 보여줄게요!", - "2": "헤이! 쇼크로 유를 항복시키겠어요!", - "3": "배틀에서 마이 에너미에게 했던 것처럼 유에게도 펀치를 날리겠어요!" - }, - "victory": { - "1": "와우, 키드! 유어 팀은 진짜 대단하군요!", - "2": "으흐흑, 유는 스트롱하네요! 마이 전기 트릭도 유에겐 로스트입니다.", - "3": "앱솔루트하고 쇼킹한 패배였어요!" - }, - "defeat": { - "1": "오우 예! 전기 타입 포켓몬이라면, 미가 월드에서 넘버 원이에요!", - "2": "하하하! 키드, 이것이 찌릿찌릿 일렉트릭 배틀입니다!", - "3": "포켓몬 배틀은 전쟁, 앤드 나는 유에게 직접 전투를 보여줬습니다!" - } - }, - "erika": { - "encounter": { - "1": "아, 오늘은 날씨가 좋네요…\n음, 배틀일까요? 그럼 더 좋죠.", - "2": "제 포켓몬들의 배틀 실력은 제 꽃꽂이 실력만큼 대단하답니다.", - "3": "아, 제 포켓몬의 달콤한 향기가 저를 다시 잠들게 하지 않았으면 좋겠는데……", - "4": "정원에서 꽃을 보면 마음이 편안해져요.”." - }, - "victory": { - "1": "앗! 제 패배를 인정합니다.", - "2": "방금 경기 정말 달콤했어요.", - "3": "아, 제가 진 것 같네요…", - "4": "앗, 맙소사." - }, - "defeat": { - "1": "저 조금 걱정했어요. 너무 졸려서…", - "2": "어머, 제 풀 포켓몬이 당신을 압도한 것 같네요.", - "3": "이 배틀 정말로 편안한 경험이었네요.", - "4": "어머… 이게 끝인가요?" - } - }, - "janine": { - "encounter": { - "1": "난 독을 사용하는 인술을 갈고 닦고 있어.\n오늘 수련에서는 너랑 대련할거야!", - "2": "아버지는 내가 잘해낼 수 있다고 신뢰하셔.\n 그게 맞는다는 걸 증명할게!", - "3": "내 인술은 아버지한테 뒤처지지 않아! 따라올 수 있겠어? " - }, - "victory": { - "1": "역시 아직도, 난 더 수련이 필요해… 납득했어.", - "2": "네 배틀 기술이 내 인술보다 한 수위야.", - "3": "더 스스로 갈고 닦아서, 내 인술을 향상 시키겠어." - }, - "defeat": { - "1": "후후후… 독이 네 기력을 모두 가져가버렸네.", - "2": "하핫, 너 내 인술에 맞설 기회를 잡지 못했구나!", - "3": "나를 향한 아버지의 신뢰, 틀리지 않았다는 걸 증명해냈어." - } - }, - "sabrina": { - "encounter": { - "1": "내 초능력을 통해서, 너의 도착은 예상하고 있었어!", - "2": "싸우는 건 좋아하지 않지만 네가 원한다면… 나의 힘을 보여줄게!", - "3": "네게서 큰 염원이 느껴져. 그것이 근거 없는 것이 아닌지 지켜보겠어." - }, - "victory": { - "1": "너의 힘은… 내가 예견했던 것보다 훨씬 뛰어나…", - "2": "나는 너의 힘을 정확하게 예측하지 못했어.", - "3": "나 엄청난 초능력을 가지고도, 너처럼 강한 사람을 느끼지 못했네." - }, - "defeat": { - "1": "이 승리는… 내가 환상에서 예견한 그대로네!", - "2": "아마도 그건, 내가 깊이 느꼈던 또 다른 염원이었을거야…", - "3": "무모하게 배틀에 임하기 전에 능력을 갈고닦도록.\n넌 미래가 어떻게 될지 예지할 수 없으니까…" - } - }, - "blaine": { - "encounter": { - "1": "우오오~옷! 화상치료제는 잘 준비했는가!", - "2": "나의 포켓몬은 모든 것을 불꽃으로 태워버리는 강한 녀석들뿐이다!", - "3": "불꽃과 함께할 준비는 됐는가!" - }, - "victory": { - "1": "아무것도 남지 않고 불타버렸다! 재조차 남지 않았어!", - "2": "내가 불을 너무 세게 피우지 않았나?", - "3": "불태웠다… 하지만 이건 불꽃을 향상시키려는 내 동기를 더욱 뜨겁게 만드는군!" - }, - "defeat": { - "1": "나의 타오르는 불길은 진압할 수 없다!", - "2": "내 포켓몬은 이번 승리의 열기로 더욱 강해졌다!", - "3": "하! 내 열정이 네 것보다 더 밝게 타오르고 있군!" - } - }, - "giovanni": { - "encounter": { - "1": "나, 로켓단의 리더가, 고통의 세계를 느끼게 해주마!", - "2": "옛 동료들과 다시 만나기 전, 이곳에서의 훈련은 매우 중요하겠군.", - "3": "너는 곧 경험하게 될 실패에 대한 준비가 되어 있지 않군!" - }, - "victory": { - "1": "하! 내가 졌다고?! 더 이상 할말이 없군!", - "2": "흐음… 넌 내가 이루고자 하는 것을 결코 이해할 수 없을 거다.", - "3": "이 패배는 피할 수 없는 것을 단지 지연시킬 뿐.\n때가 되면 잿더미에서 로켓단을 일으켜 세울 것이다." - }, - "defeat": { - "1": "자신의 힘을 스스로 잴수 없다는 것은 네가 아직 꼬맹이라는 것을 보여준다고 할 수 있지.", - "2": "다시는 나를 방해하지 말도록.", - "3": "나에게 도전하는 것이 얼마나 어리석은 짓인지 이해했으면 좋겠군." - } - }, - "roxanne": { - "encounter": { - "1": "당신이 어떻게 싸우는지 보여주시겠어요?", - "2": "당신은 여러 트레이너와 싸우면서 많은 것을 배울 수 있을거예요.", - "3": "아, 전략짜는 거 들켰네요.\n배틀할까요?" - }, - "victory": { - "1": "아, 제가 진 것 같네요.\n승복하겠습니다.", - "2": "전 아직도 포켓몬 배틀에 대해서 한참 더 배워야할 것 같네요.", - "3": "오늘 여기서 배운 것들을 마음에 담아둬야겠어요." - }, - "defeat": { - "1": "전 방금 승부에서 많은 것을 배웠습니다.\n당신도 그랬길 바래요.", - "2": "다시 붙을 날이 기대되네요.\n당신이 여기서 배운 걸 활용할 수 있길 바랍니다.", - "3": "여태까지 공부해온 것 덕분에 이겼네요." - } - }, - "brawly": { - "encounter": { - "1": "오, 도전자잖아!\n어디 한 번 볼까!", - "2": "넌 큰 파란을 일으킬 것 같군.\n승부다!", - "3": "폭풍을 일으킬 시간이야!\n가자!" - }, - "victory": { - "1": "우와, 너 날 씻겨버렸네!", - "2": "내 파도를 타고, 나까지 밀어내다니!", - "3": "바위 동굴에서 길을 잃은 기분이야!" - }, - "defeat": { - "1": "하핫, 난 큰 파도를 탔다고!\n언제 또 도전해주라.", - "2": "언젠가 또 같이 서핑하자고!", - "3": "파도가 밀려왔다가 밀려나듯, 언젠가 너도 다시 도전하러 와." - } - }, - "wattson": { - "encounter": { - "1": "찌릿찌릿해질 때가 됐군!\n와하하하핫!", - "2": "스파크가 튀도록 해주마!\n와하하하하!", - "3": "와하하하하!\n마비 치료제를 가져왔길 바라네!" - }, - "victory": { - "1": "이 몸 배터리가 다 됐군!\n와하하하하!", - "2": "자네 완전히 날 좌초시켰군!\n와하하하핫!", - "3": "스릴 넘치는 배틀, 고맙네!\n와하하하하하!" - }, - "defeat": { - "1": "자네의 배터리 재충전하게. 그리고 나에게 도전하러 돌아오도록!\n와하하하핫!", - "2": "방금 배틀이 자네에게 짜릿짜릿했길 바란다네!\n와하하하하!", - "3": "자네 혹시 내가 이겨서 충격 받았나?\n와하하하핫!" - } - }, - "flannery": { - "encounter": { - "1": "어서오세요! 잠깐, 아냐…\n너를 무너뜨려줄게!", - "2": "난 체육관 관장이 된지는 얼마 안됐지만, 널 태워버릴거야!", - "3": "할아버지에게 배운 기술을 한 수 보여줄게! 승부다!" - }, - "victory": { - "1": "너 우리 할아버지를 생각나게 하네…\n내가 진 게 놀랍진 않아.", - "2": "나 너무 열심히 하는 건가?\n너무 열 올리면 안되니깐, 진정해야겠어.", - "3": "패배는 날 꺼뜨릴 수 없어.\n트레이닝으로 다시 불을 붙일 때야!" - }, - "defeat": { - "1": "할아버지가 자랑스러워하시길…\n언젠가 다시 배틀하자.", - "2": "내…내가 이기다니!\n내 방식대로 한 게 통했어!", - "3": "조만간 다시 뜨겁게 불타오르는 배틀을 하자!" - } - }, - "norman": { - "encounter": { - "1": "여기까지 오다니 놀랍군.\n한 번 겨뤄볼까.", - "2": "관장으로서 최선을 다해 널 이길 거란다.\n가자!", - "3": "최선을 다하는 게 좋을 거야.\n승부할 시간이다!" - }, - "victory": { - "1": "내가 지다니…?\n규칙은 규칙이니, 흐음.", - "2": "담청시티에서 이사한 게 문제였나…?", - "3": "믿을 수 없구나.\n훌륭한 승부였어." - }, - "defeat": { - "1": "우린 둘 다 최선을 다했지.\n다시 대결할 수 있었으면 좋겠구나.", - "2": "우리 집 꼬마에게 도전해보는 것도 좋겠군.\n아마 뭔가 배울 수 있을거다!", - "3": "방금 전 배틀 완벽했어.\n다음에도 행운이 함께하길." - } - }, - "winona": { - "encounter": { - "1": "저는 먹이를 찾아서 하늘을 날아다녔어요…\n그리고 당신은 제 타겟입니다!", - "2": "배틀이 어떻게 되든, 전 제 비행 포켓몬과 우아하게 승리하겠어요. 승부합시다!", - "3": "당신이 높은 곳을 무서워하지 않기를.\n자, 날아올라요!" - }, - "victory": { - "1": "저보다 우아하게 나서는 트레이너는 처음 봤습니다.\n훌륭하시네요.", - "2": "이런, 제 비행 포켓몬이 추락해버렸네요!\n훌륭한 배틀이었습니다.", - "3": "비록 전 떨어졌지만, 제 포켓몬은 다시 날아갈 겁니다!" - }, - "defeat": { - "1": "제 비행 포켓몬과 영원히 우아하게 춤출게요.", - "2": "우리의 쇼가 즐거웠길 바라요.\n우아한 춤은 끝났습니다.", - "3": "우리의 엘레강스한 안무를 다시 보러오지 않을래요?" - } - }, - "tate": { - "encounter": { - "1": "헤헤헤…\n내가 란과 같이 있지 않아서 놀랐지?", - "2": "네가 무슨 생각을 하는지 알아…\n승부하고 싶은거지!", - "3": "네 움직임을 모두 알고 있는데…\n어떻게 이기려고?" - }, - "victory": { - "1": "어쩔 수 없지…\n란이 보고싶다아…", - "2": "너와 네 포켓몬과의 유대, 나보다 더 견고한걸.", - "3": "란이랑 함께였다면, 우리가 이겼어.\n둘이선 더 잘 할 수 있다구!" - }, - "defeat": { - "1": "내 포켓몬과 나는 우수하다구!", - "2": "날 못 이긴다면, 넌 란한테도 절대로 못 이겨.", - "3": "란과 함께한 엄격한 훈련 덕이야.\n덕분에 포켓몬과 하나가 될 수 있었어." - } - }, - "liza": { - "encounter": { - "1": "후후후…\n내가 풍과 같이 있지 않아서 놀랐지?", - "2": "네가 무얼 바라는지 알아…\n포켓몬 배틀, 맞지?", - "3": "포켓몬과 하나가 된 사람…\n어떻게 이기려고?" - }, - "victory": { - "1": "어쩔 수 없지…\n풍이 보고싶다아…", - "2": "너와 네 포켓몬과의 유대, 나보다 더 견고한걸.", - "3": "풍이랑 함께였다면, 우리가 이겼어.\n둘이선 더 잘 할 수 있다구!" - }, - "defeat": { - "1": "내 포켓몬과 내가 승리한거야.", - "2": "날 못 이긴다면, 넌 풍한테도 절대로 못 이겨.", - "3": "풍과 함께한 엄격한 훈련 덕이야.\n덕분에 포켓몬과 싱크로 될 수 있었어." - } - }, - "juan": { - "encounter": { - "1": "지금은 겸양을 부릴 때가 아니군요.\n승부합시다!", - "2": "아하하하, 물 포켓몬과 함께 아트를 보여드리겠습니다!", - "3": "태풍이 다가오는군요!\n저를 테스트해주시겠습니까?", - "4": "자, 마음껏 봐주십시오.\n저와 포켓몬이 이루어내는 물의 일루전을!" - }, - "victory": { - "1": "당신은 윤진 관장을 뛰어넘을 지니어스군요!", - "2": "당신이 훈련할 때 저는 엘레강스에 집중했습니다.\n당신이 이기는 건 당연하죠.", - "3": "아하하하하!\n잘했습니다, 이번엔 당신이 이겼네요.", - "4": "모든 것을 극복하는 브릴리언트 스킬, 당신에게 느껴지네요." - }, - "defeat": { - "1": "저와 포켓몬이 이루어내는 물의 일루전이 승리했습니다.", - "2": "아하하핫, 저는 이겼고, 당신은 졌습니다.", - "3": "겉옷 빌려드릴까요? 아마도 배틀에 도움이 될겁니다!\n아하하하, 농담입니다!", - "4": "제가 승리자군요! 그리고, 당신은 졌네요." - } - }, - "crasher_wake": { - "encounter": { - "1": "철썩! 철썩! 조심해라!\n맥시멈 가면이…지금…간다!", - "2": "철썩! 철썩! 파도의 맥시멈 가면!", - "3": "밀물같은 힘으로 쓸려나가도록 해보실까!!" - }, - "victory": { - "1": "저절로 웃음이 나오게 되는군!\n크하하핫! 정말 훌륭했다!", - "2": "우왓! 끝나버렸나!\n뭐랄까…\n좀 더 싸우고 싶은 기분이야!", - "3": "이럴수가!?" - }, - "defeat": { - "1": "으하하핫! 보람차군!", - "2": "내가 이겼지만, 아쉽군! 좀 더 배틀하고 싶은데!", - "3": "잘 가게나!" - } - }, - "falkner": { - "encounter": { - "1": "넓은 하늘을 화려하게 나는 새 포켓몬의 진정한 강함을 알게 해주겠다!", - "2": "바람이여, 나에게 오라!", - "3": "아버지, 내 시합을 하늘에서도 봐줘!" - }, - "victory": { - "1": "알았다… 미련없이 땅에 내려가지.", - "2": "패배는 패배니까. 넌 정말 강하군.", - "3": "…큭! 그래, 내가 졌다." - }, - "defeat": { - "1": "아버지! 소중히 여기던 새 포켓몬으로 이겼어…", - "2": "언제나 새 포켓몬이 최강이다!", - "3": "아버지를 따라 잡은 기분이군!" - } - }, - "nessa": { - "encounter": { - "1": "똑똑한 네가 어떤 계획을 세우고 있든지, 나와 내 파트너가 가라앉혀줄 테니까 문제 없어.", - "2": "잡담하려고 나온 게 아니야. 이기려고 나온 거지!", - "3": "이건 내 포켓몬이 주는 작은 선물이야… 네가 잘 받아줘야 해!" - }, - "victory": { - "1": "너와 네 포켓몬 정말로 너무…", - "2": "어째서…? 어떻게 이럴 수 있지?!", - "3": "완전히 씻겨 나갔잖아!" - }, - "defeat": { - "1": "성난 파도가 다시 부딪혀올거니까!", - "2": "승리의 파도를 탈 시간이야!", - "3": "에헤헤!" - } - }, - "melony": { - "encounter": { - "1": "봐주지는 않을 거란다!", - "2": "그럼 이제, 시작해도 될 것 같네.", - "3": "영하의 세계로 안내해주마!" - }, - "victory": { - "1": "너… 꽤 하는구나?", - "2": "만약 주변에서 마쿠와를 찾는다면, 그 때는 따끔한 맛을 보여주도록 하렴, 알았지?", - "3": "아이스 브레이킹을 너무 문자 그대로 받아들인 것 같은데…" - }, - "defeat": { - "1": "이제 전투가 얼마나 치열할 수 있는 지 알겠니?", - "2": "아하하! 내가 또 이긴 것 같네!", - "3": "너 혹시 봐준거니?" - } - }, - "marlon": { - "encounter": { - "1": "너 강해보이네! 받아라! 승부 시작이야!", - "2": "난 넓은 대양처럼 강인하다고. 너 분명히 휩쓸려 갈거야.", - "3": "오, 내가 너를 마주 보고 있군! 둘다 파도에서 떨어지겠어." - }, - "victory": { - "1": "너… 좋은 포켓몬을 키우고 있구나! 꽤 하는군! 끝내주는 트레이너야!", - "2": "강해 보이는 게 아니고 진짜 강하구나! 에-, 나도 휩쓸려버렸어!", - "3": "넌 거친 파도처럼 강인하구나!" - }, - "defeat": { - "1": "넌 강하지만, 바다를 흔들기에는 역부족이네, 그치!", - "2": "아하핫! 내가 또 이긴 것 같네!", - "3": "달콤하네, 승리 역시 달콤하고!" - } - }, - "shauntal": { - "encounter": { - "1": "미안합니다. 도전자이시죠?\n고스트포켓몬 조련사인 사천왕 망초가 상대하겠습니다.", - "2": "겨루었던 트레이너와 포켓몬의 마음이 통하는 모습을 이야기로 만드는 것을 좋아해서요!\n그러니까 당신들에 대한 취재를 허락해 주세요?", - "3": "포켓몬과 함께 일하는 모든 사람들은 각자 이야기를 갖고 있죠.\n어떤 이야기를 들려드릴까요?" - }, - "victory": { - "1": "…우와. 저 아연실색 망연자실이에요!", - "2": "미-미 미안합니다! 먼저 포켓몬에게 사과해야지…\n\n나 때문에 괴로운 기억을 만들게 돼서 정말 미안해!", - "3": "그치만, 전 여전히 사천왕인걸요!" - }, - "defeat": { - "1": "에헤헤.", - "2": "다음 소설의 완벽한 소재를 얻었다!", - "3": "그리고 이렇게, 또 다른 이야기가 끝났습니다…" - } - }, - "marshal": { - "encounter": { - "1": "노간주 스승님이, 잠재력을 보고 네게 관심을 갖고 계시더군.\n그 힘의 한계까지 데려가는 것이 이번 의도다! 그럼 간다!", - "2": "승리, 압도적인 승리, 내가 바라는 것이다! 강인한 도전자여, 간다!", - "3": "깨뜨리는 것은 약한 자신, 관철하는 것은 강한 신념!\n 그리고 바라는 것은 압도적인 승리!" - }, - "victory": { - "1": "후우! 잘 싸웠다!", - "2": "역시 대단하구나! 싸워서 더욱더 높은 곳을 노려라…!", - "3": "너와 네 포켓몬이 보여준 그 힘, 감명 깊군…" - }, - "defeat": { - "1": "흐음.", - "2": "좋은 승부였다.", - "3": "하압! 하압! 히야아아압!!!!" - } - }, - "cheren": { - "encounter": { - "1": "넌 내 오랜 친구가 생각나게 하는군. 그 덕분에 이 배틀이 기대돼!", - "2": "왜 하고 있는지 생각하지 않으면, 포켓몬 배틀은 의미가 없어 . \n$좋게 말하면, 함께 포켓몬과 승부하는 것이 무의미해 지는 것이지.", - "3": "내 이름은 체렌! 체육관 관장이자 선생님을 하고 있지! 널 만나게 되서 기쁘군." - }, - "victory": { - "1": "고마워! 내 안에 무엇이 부족했는지 알게 됐네.", - "2": "고마워! 내가 추구하는 이상에 조금 다가간 것 같아.", - "3": "으음… 이건 문제가 있군." - }, - "defeat": { - "1": "체육관 관장으로서, 나는 넘어야할 벽이 되고자 하고 있거든.", - "2": "좋았어!", - "3": "포켓몬이 곁에 있었기 때문에 여기까지 올 수 있었어.\n생명체와 생명체라는 동등한 관계에서 포켓몬이 우리에게 도움을 주는 이유를 생각해 볼 필요는 있지." - } - }, - "chili": { - "encounter": { - "1": "이얏호-! 형제중 가장 강한 나하고 놀자고!", - "2": "짜잔! 불꽃타입 불꽃의 남자 팟, 바로 너의 상대가 되어주지!", - "3": "나와 내 불타오르는 불꽃타입 포켓몬들이 뭘 할수 있는지 보여주지!" - }, - "victory": { - "1": "졌지만… 모 두 불 태 웠 어!!", - "2": "와우! 불태워졌네!", - "3": "으악! 너가 나를 이겨버렸잖아!" - }, - "defeat": { - "1": "난 지금 불타오르고 있어, 나와 싸우게 된다면 넌 다치게 될거야!", - "2": "불장난하면 밤에 이불에 지도를 그리는 법이지!", - "3": "그러니까, 상대가 나였잖아? 너에게는 처음부터 기회가 없었다고!" - } - }, - "cilan": { - "encounter": { - "1": "개인적으로 받아들이지 마세요… 감정 상하지도 말고요… 저와 제 풀타입 포켓몬들이라면…\n$음… 무슨 일이 있더라도 배틀을 할 겁니다.", - "2": "네. 저로 괜찮다면 진심을 담아서 상대해 드리겠습니다.", - "3": "네… 그, 음, 저는 덴트입니다, 풀타입 포켓몬을 좋아합니다." - }, - "victory": { - "1": "…에- 그게… 끝나버렸나요?", - "2": "…놀랐습니다. 당신 아주 강하군요. \n$팟이나 콘이라도 이길 수 없었을 것 같습니다…", - "3": "…어라, 타이밍이 좀 잘못된것 같네요?" - }, - "defeat": { - "1": "어라? 제가 이긴 건가요?", - "2": "제 생각엔… \n$아무래도 제가 이겼어야만 했을 거라 생각합니다, 팟과 콘이랑 배틀하면서 우리는 모두 더 강해졌기 때문이죠.", - "3": "정말… 아주 짜릿한 경험이었습니다…" - } - }, - "roark": { - "encounter": { - "1": "트레이너로서 너의 실력이 어느 정도인지 그리고 함께 싸울 포켓몬이 얼마나 강한지 확인해보겠어!", - "2": "자 간다! 내 자랑이자 기쁨인 바위타입 포켓몬들이야!", - "3": "바위타입 포켓몬이야말로 최고지!", - "4": "트레이너로서 너의 실력이 어느 정도인지 그리고 함께 싸울 포켓몬이 얼마나 강한지 확인해보겠어!" - }, - "victory": { - "1": "이-이럴수가! 열심히 단련시킨 포켓몬들이!", - "2": "…져버린 건가. 다음엔 지하통로에서 화석캐기 승부를 하고 싶구나.", - "3": "네 실력이라면 승리는 당연한 결과겠지.", - "4": "뭐-뭐야?! 이럴 수가! 이것도 부족했단 말인가?", - "5": "내가 실수했군." - }, - "defeat": { - "1": "봤지? 이게 바로 내가 자랑하는 바위 스타일 전투야!", - "2": "고마워! 이번 승부로 아버지를 이길 수 있겠다는 자신감이 생겼어!", - "3": "정말 단단한 바위를 뚫고 나온 기분인데!" - } - }, - "morty": { - "encounter": { - "1": "조금만 더 노력하면, 내가 전설의 포켓몬을 만나는 미래가 보여.\n$내가 그 수준에 도달할 수 있게 도와줘!", - "2": "커다란 무지개색 포켓몬은 진정한 강함을 가진 트레이너 앞에 나타난다는 이야기가 있어. \n$난 그 이야기를 믿고, 줄곧 이 곳에서 몰래 수행하고 있어. 그 결과로, 다른 사람들은 볼 수 없는 것을 볼 수 있게 됐지. \n$내겐 그 포켓몬을 나타나게 할 사람의 그림자가 보이거든. \n$난 그게 나라고 믿어! 넌 내가 그 수준에 올라갈 수 있도록 도와줘야겠어!", - "3": "네가 믿든 믿지 않든, 불가사의한 힘은 존재해.", - "4": "넌 내 수련의 결실을 보게 될 거야.", - "5": "포켓몬과 너의 영혼을 하나로 만들어야 해. 가능하겠어?", - "6": "저기, 너 내 수행의 일부분이 되고 싶은거지?" - }, - "victory": { - "1": "나는 아직 멀었구나…", - "2": "그래… 여행으로 먼 곳을 돌아다니면서, 나보다 훨씬 많은 것을 봐왔구나.\n$네가 조금 부럽네…", - "3": "이게 어떻게 가능한 거지…", - "4": "우리의 잠재력은 그렇게 다르진 않은 것 같아.\n$그치만 넌 그것과 다른 무언가를 많이 갖고 있는 것 같네… 흐음.", - "5": "수련이 더 필요하겠군.", - "6": "안타깝게 됐네." - }, - "defeat": { - "1": "내가…다시 한 발짝 앞섰어.", - "2": "후후훗…", - "3": "뭐-뭐야?! 이럴 수가! 그것도 부족해?", - "4": "정말 단단한 바위를 뚫고 나온 기분인데!", - "5": "아하하하하!", - "6": "내가 이길 줄 알았어!" - } - }, - "crispin": { - "encounter": { - "1": "이기고 싶으니까 이기고 말겠어!", - "2": "싸우고 싶으면 싸운다! 이거면 충분하지 않아!?" - }, - "victory": { - "1": "이기고 싶었는데…졌잖아!", - "2": "이기지 못해서…지고 말았어!" - }, - "defeat": { - "1": "잠시만. 나 지금 이긴거지? 이긴 거 맞지! 기분 좋은데!", - "2": "우와아! 이거 굉장한데!" - } - }, - "amarys": { - "encounter": { - "1": "네리네는 그 사람을 구원하고 싶습니다. 그렇기에 패배는 용납되지 않습니다.\n$… 승부를 시작합니다." - }, - "victory": { - "1": "네리네는… 안 된다는 건가요." - }, - "defeat": { - "1": "네리네가 승리했습니다. 수고하셨습니다." - } - }, - "lacey": { - "encounter": { - "1": "이번에는 사천왕으로서 승부하는 거니까 평소 사용하는 아이들로 상대해 드릴게요!" - }, - "victory": { - "1": "멋진 포켓몬 배틀이었어요!" - }, - "defeat": { - "1": "당신의 포켓몬의 노력에 박수를 보내주세요!" - } - }, - "drayton": { - "encounter": { - "1": "의자는 좋은 거야. 너도 그렇게 생각해? 정말 고마운 물건이지. \n$왜 다들 앉지 않는 걸까. 서 있는 건 힘들잖아!" - }, - "victory": { - "1": "전보다 더 강해질 줄이야!" - }, - "defeat": { - "1": "헤헤헷! 내 승리야. 분한 건 알겠지만 카지처럼 나가떨어지지마, 응?" - } - }, - "ramos": { - "encounter": { - "1": "그래, 올곧게 자란 초목을 모아서 만든 풀 정글짐은 어땠는가?\n$자네가 느낀 그것이 나의 체육관 관장으로서의 실력이네! 한번 확인해 보겠나?" - }, - "victory": { - "1": "포켓몬은 자네를 믿고, 자네는 그들을 믿는다…가슴이 후련해지는 승부였구먼." - }, - "defeat": { - "1": "호호호…연약해 보이는 풀잎은 콘크리트도 뚫을 수 있다네." - } - }, - "viola": { - "encounter": { - "1": "패배의 분함도 승리의 순간도…\n$둘 다 최고의 피사체야! 정말 멋져 멋져! \n$자, 그럼 덤비렴!", - "2": "나 비올라는 셔트 찬스를 노리는 것처럼--승리를 노릴 거야!" - }, - "victory": { - "1": "너와 네 포켓몬은 최고의 콤비구나! 정말 멋져 멋져!", - "2": "렌즈 너머의 세계와 포켓몬의 마음으로 보는 세계…\n$똑같이 보이는 풍경이지만 다양한 세계가 겹쳐져 있는 거야." - }, - "defeat": { - "1": "내가 승리한 순간을 찍은 사진은 정말 멋져 멋져!", - "2": "좋아! 멋진 사진을 찍었어!" - } - }, - "candice": { - "encounter": { - "1": "나, 무청에게 도전하고 싶은거야? 좋아! 강한 사람을 기다리고 있었으니까!\n$그치만 말해두는데, 집중하는 방법을 아는 나도 강력하거든.", - "2": "포켓몬도 멋도 연애도 정신 집중이 중요하다고!\n$무슨 뜻인지 보여줄테니까 각오해!" - }, - "victory": { - "1": "있지, 나 조금 불타오르게 됐어! 널 조금 존경하게 될지도 몰라.", - "2": "우와! 제법인데! 내가 존경하게 만들다니!\n$네 집중력과 의지, 완전히 나를 압도하는 같아. " - }, - "defeat": { - "1": "이기고자 하는 의지는 전해졌지만, 난 지지 않았어!", - "2": "봤지? 무청의 집중력! 내 포켓몬의 집중력도 대단하다구!" - } - }, - "gardenia": { - "encounter": { - "1": "너에게선 승리의 기운이 느껴져. 어쨌든 재밌을 것 같아. 포켓몬 승부하자!" - }, - "victory": { - "1": "대단해! 너 정말 강하구나!" - }, - "defeat": { - "1": "그렇지! 나와 포켓몬은 완벽해!" - } - }, - "aaron": { - "encounter": { - "1": "좋습니다! 그럼 상대해 드리죠!" - }, - "victory": { - "1": "승부는 딥하고 컴플렉스한 일이네요…" - }, - "defeat": { - "1": "사천왕을 상대로 하는 승리는 쉽게 오지 않는다구요." - } - }, - "cress": { - "encounter": { - "1": "맞습니다! 당신은 저와 제 자랑스러운 물타입 포켓몬들과 상대하게 될것입니다." - }, - "victory": { - "1": "곤란하네… 이 콘이 질 줄이야." - }, - "defeat": { - "1": "제가 당신의 상대였기 때문에 이건 당연한 결과였습니다." - } - }, - "allister": { - "encounter": { - "1": "……어니언이야.\n……가 간다…" - }, - "victory": { - "1": "충격을 받아서… 가면을 떨어뜨릴 뻔 했지만…\n$네가 얼마나 강한지 확실히 봤어." - }, - "defeat": { - "1": "이-이게 내 실력이니까!" - } - }, - "clay": { - "encounter": { - "1": "실망스럽군! 나를 기다리게 하다니, 이 꼬마가. 아무튼 실력을 확인해 볼까!" - }, - "victory": { - "1": "이런 이런… 진심으로 싸워서 진 거라 오히려 시원한 기분이군!" - }, - "defeat": { - "1": "중요한 것은 패배에 어떻게 반응하는 거다. \n$그렇기 때문에 패배를 연료로 삼아 나아가는 사람들은 강인하지." - } - }, - "kofu": { - "encounter": { - "1": "물포켓몬의 풀코스를! 배 터지게 먹여 주도록 하마!" - }, - "victory": { - "1": "우옷! 우오오옷! 이렇게 팔팔한 트레이너가 다 있다니!" - }, - "defeat": { - "1": "젊은 친구! 다음에 또 만나기를 기대하고 있으마!" - } - }, - "tulip": { - "encounter": { - "1": "리파의 기술로 너의 포켓몬들을 지금보다 훨~씬 아름답게 만들어 줄게!" - }, - "victory": { - "1": "너의 강함은 풀 수 없는 매직이구나." - }, - "defeat": { - "1": "…리파의 업계에서는 어중간한 재능을 가진 사람은 대체로 금방 사라져 버려." - } - }, - "sidney": { - "encounter": { - "1": "음, 좋은 표정이야. 꽤나 즐길 수 있겠는데.\n$좋아! 아주 좋아! 좋았어!\n$우리 함께, 포켓몬리그에서만 맛볼 수 있는 배틀을 즐겨보도록 하자!" - }, - "victory": { - "1": "이런, 이런 져버렸군? 뭐, 꽤 즐겼으니 상관없지만." - }, - "defeat": { - "1": "기분 나빠하지 마, 알겠지?" - } - }, - "phoebe": { - "encounter": { - "1": "송화산에서 수행하면서, 고스트 타입 포켓몬과 마음이 통하게 됐어. \n$응, 나와 내 포켓몬의 유대감은 정말 강해! \n$이런 내 포켓몬들에게 과연 데미지를 줄 수 있을지 한번 시험해봐!" - }, - "victory": { - "1": "아- 아, 내가 져버렸다." - }, - "defeat": { - "1": "언젠가 다시 승부할 수 있기를 기대할게!" - } - }, - "glacia": { - "encounter": { - "1": "이곳에 도전하러 오는 건 모두 어설픈 트레이너와 포켓몬뿐…. \n$당신은 어떤가요? 제 진짜 실력을 발휘해도 괜찮을 정도라면 정말 기쁠텐데 말이죠…!" - }, - "victory": { - "1": "당신과… 당신 포켓몬들의 뜨거운 혼!\n$정말로 압도적인 뜨거움이네요. \n$내 얼음 기술로 피해를 주지 못한 것도 놀랍지 않을정도로요!" - }, - "defeat": { - "1": "저런, 정말로 치열한 승부였네요." - } - }, - "drake": { - "encounter": { - "1": "파트너로 포켓몬과 함께하는 승부에 무엇이 필요한지 넌 알고 있는가? \n$그걸 모른다면 넌 이 몸을 이길 수 없다!" - }, - "victory": { - "1": "훌륭하다, 라고 할 만 하군!" - }, - "defeat": { - "1": "난 승부에서 최선을 다했으니까!" - } - }, - "wallace": { - "encounter": { - "1": "뭐랄까, 너의 분위기가 조금 변한 것 같은… \n$그런 느낌이 드는군. 자, 그럼 한번 확인해볼까? 너와 포켓몬의 힘을. \n$그리고 확실하게 보여주도록 하지. 나와 포켓몬에 의한 물의 일루전을!" - }, - "victory": { - "1": "훌륭하군. 넌 정말 굉장한 포켓몬 트레이너다. \n$그런 너와 너의 포켓몬을 만나게 된 걸 기쁘게 생각해. 스스로 그 가치를 증명하다니!" - }, - "defeat": { - "1": "거대한 일루전이로군!" - } - }, - "lorelei": { - "encounter": { - "1": "얼음포켓몬을 내보내면 대적할 사람이 없지! 상대를 얼린다는 건 매우 강력한 공격이야.\n$네 포켓몬이 꽁꽁 얼면 그때부턴 내 손바닥 위거든! 아하하! 준비됐어?" - }, - "victory": { - "1": "어떻게 감히!" - }, - "defeat": { - "1": "얼어붙은 넌 아무것도 할 수 없어." - } - }, - "will": { - "encounter": { - "1": "나는 전세계를 돌아다니며, 강한 에스퍼 포켓몬을 만들도록 수행해왔다.\n$계속 더 정진하겠다! 패배는 선택지에 없어!" - }, - "victory": { - "1": "이… 내가… 믿을수 없어…" - }, - "defeat": { - "1": "근소한 차이였다. 네게 부족한 것이 무엇인지 궁금하군." - } - }, - "malva": { - "encounter": { - "1": "심장이 불에 타버릴 것만 같아요. \n$당신에 대한 증오로 불타고 있거든요, 얄미운 트레이너!" - }, - "victory": { - "1": "도전자가… 사천왕 파키라에게서 멋지게 승리를 쟁취했습니다!" - }, - "defeat": { - "1": "기쁘네요! 당신을 짓밟을 수 있어서 말이죠!" - } - }, - "hala": { - "encounter": { - "1": "그럼…진심을 담아서 진지한 할라로 임하겠다!" - }, - "victory": { - "1": "네가 순례하면서 갖추게 된 강함을 느낄 수 있었다." - }, - "defeat": { - "1": "하하! 경쾌한 승부였구나!" - } - }, - "molayne": { - "encounter": { - "1": "사촌인 마마네에게 캡틴 자리는 줬지만, 아직 실력에는 자신 있어요. \n$제 실력은 초신성처럼 빛나니까요!" - }, - "victory": { - "1": "확실히 겨룰 흥미로운 트레이너를 찾았네요!" - }, - "defeat": { - "1": "아하하. 흥미로운 배틀이었네요." - } - }, - "rika": { - "encounter": { - "1": "실컷 귀여워해 줄 테니까… 한 번 열심히 해 보라고!" - }, - "victory": { - "1": "너, 꽤 하는구나!" - }, - "defeat": { - "1": "아하하! 제법인데! 역시 너는 재밌는 녀석이라니까!" - } - }, - "bruno": { - "encounter": { - "1": "우월한 힘으로 너를 부숴주지! 우! 하~앗!" - }, - "victory": { - "1": "하? 어떻게 내가 진 거지?" - }, - "defeat": { - "1": "얼마든지 내게 도전 할 수 있지만, 결과는 절대 바뀌지 않을 거다!" - } - }, - "bugsy": { - "encounter": { - "1": "내 이름은 호일! 벌레 포켓몬에 대해서라면 누구에게도 지지 않아!" - }, - "victory": { - "1": "우와, 대단해! 넌 포켓몬 전문가구나!\n내 연구는 아직 안 끝났네. 응, 네가 이겼어." - }, - "defeat": { - "1": "고마워! 방금 승부 덕분에, 내 연구도 진전을 이룬 것 같아!" - } - }, - "koga": { - "encounter": { - "1": "후하하하! 포켓몬은 단순히 강한 것만이 아니다--곧 알려주지!" - }, - "victory": { - "1": "하! 스스로 증명해냈군!" - }, - "defeat": { - "1": "인술을 피하는 방법을 배워보겠나?" - } - }, - "bertha": { - "encounter": { - "1": "그럼, 할머니가 네가 얼마나 해낼 수 있는지 보도록 할게?" - }, - "victory": { - "1": "좋아! 꼬마야, 정말로, 인상적이었단다.\n$네 포켓몬은 너를 믿고 승리를 위해 최선을 다했구나.\n$비록 내가 졌지만, 좋아서 바보같이 웃음이 나오는구나!" - }, - "defeat": { - "1": "호호호! 이 할머니가 이겼구나!" - } - }, - "lenora": { - "encounter": { - "1": "자 그럼 도전자여, 애정을 담아 키운 포켓몬으로 어떤 방식으로 싸우는지 연구해 보겠다!" - }, - "victory": { - "1": "너에 대한 내 가설이 맞았네. 재능만 있는 게 아니라… 대단한 녀석이구나! 너 반할것 같잖아!" - }, - "defeat": { - "1": "아 하 하! 패배했다면, 그 이유를 분석하고, 다음 승부에서 그 지식을 활용하도록!" - } - }, - "siebold": { - "encounter": { - "1": "살아가는 동안, 궁극적인 요리와 강력한 상대를 찾기 위해… 열과 성을 다할 것입니다!" - }, - "victory": { - "1": "당신에 대한 기억을 제 가슴 속에 담아두겠습니다." - }, - "defeat": { - "1": "우리의 포켓몬 배틀은 영혼의 양식과 같습니다. 그건 저를 계속 지탱할 거예요. \n$이것이 제가 전투에서 모든 것을 바친 당신에게, 경의를 표하는 방법입니다!" - } - }, - "roxie": { - "encounter": { - "1": "간다! 너의 이성을 싹 날려줄 거야!!" - }, - "victory": { - "1": "굉-장해! 네 이성, 이미 나보다 TOXIC해버렸잖아!" - }, - "defeat": { - "1": "헤이, 잠깐-! 좀 더 진지해져! 넌 더 날아가야한다구!" - } - }, - "olivia": { - "encounter": { - "1": "여기에 소개는 필요 없지. 자, 라이치님과 승부할 시간이다!" - }, - "victory": { - "1": "정말 훌륭하군… 당신과 포켓몬 둘 다…" - }, - "defeat": { - "1": "흐-음." - } - }, - "poppy": { - "encounter": { - "1": "우와~! 뽀삐와 포켓몬 승부가 하고 싶으세요?" - }, - "victory": { - "1": "훌쩍, 으에엥~" - }, - "defeat": { - "1": "만세~! 만세~ 목수, 성공했어요! \n$에헴! 리벤지 매치는 언제든지 받아 줄게요!" - } - }, - "agatha": { - "encounter": { - "1": "포켓몬은 싸우게 하려고 있는 것이야! 진정한 싸움이라는 것을 보여주겠다!" - }, - "victory": { - "1": "이런! 넌 무언가 특별하구나, 꼬마야!" - }, - "defeat": { - "1": "바하하하. 제대로 된 승부는 이렇게 하는거다!" - } - }, - "flint": { - "encounter": { - "1": "뜨겁게 타오를 준비는 됐겠지, 이제 곧 대폭발이 다가올테니까!" - }, - "victory": { - "1": "놀랍군! 네 기술이 너무 뜨거워서, 내가 미적지근해보이잖아!" - }, - "defeat": { - "1": "하? 그게 다야? 좀 더 열정이 필요해보이는걸." - } - }, - "grimsley": { - "encounter": { - "1": "이긴 자가 모든 것을 갖고 패배한 자에겐 아무것도 남지 않는다." - }, - "victory": { - "1": "누군가가 이기면 상대한 누군가가 진다… 난 다음 승리를 목표로 하겠어!" - }, - "defeat": { - "1": "누군가가 이기면, 그 사람과 싸운 사람은 지게 되는 것이지." - } - }, - "caitlin": { - "encounter": { - "1": "피어난 꽃에서 나타난 것은 나. 거기 있는 당신…\n$강함과 상냥함을 함께 갖춘 포켓몬 트레이너인 것 같네. \n$이 카틀레야가 대전 상대로 원하는 건 최고의 강함… \n$너도 그 실력을 마음껏 펼쳐 봐!" - }, - "victory": { - "1": "대전을 통해서 저도 포켓몬도 성장합니다. 감사드립니다." - }, - "defeat": { - "1": "더욱 엘레강트하고 엑셀런트하게 승리를 쟁취하고 싶거든." - } - }, - "diantha": { - "encounter": { - "1": "미래를 향한 희망으로 빛나는 당신과, 당신의 포켓몬을 상대로 승부하는 것…\n$솔직히, 매일매일 새로운 날을 위해 필요한 에너지가 채워지는 것 같아요! 정말로요!" - }, - "victory": { - "1": "고귀한 영혼을 지닌 포켓몬과 트레이너의 모습에 격하게 마음이 흔들려서…" - }, - "defeat": { - "1": "정말, 환상적이야! 어떻게 생각하시나요? 저의 포켓몬들, 꽤 멋있었죠?" - } - }, - "wikstrom": { - "encounter": { - "1": "잘 왔네, 젊은 도전자여! 이 몸은 사천왕 중 한 명인 강철의 남자 간피다! \n$자 그럼 간다, 간다! 간닷!" - }, - "victory": { - "1": "정말 영광이군! 자네의 포켓몬과 서로 신뢰하는 힘, 날 능가하는군!!" - }, - "defeat": { - "1": "이게 무슨 마법이지? 내 마음의 떨림이 멈추질 않는군! \n$가치 있는 상대를 이기는 것은 영혼에 날개를 달아주는 것과 같지--그런 내가 비상하는 것일까!" - } - }, - "acerola": { - "encounter": { - "1": "포켓몬 배틀은 언제나 재미있지! 자, 내가 상대해줄게!" - }, - "victory": { - "1": "아세로라… 입이 딱 벌어졌어! 어떻게 해낸 거야?!" - }, - "defeat": { - "1": "후아~! 놀라운 승리네!" - } - }, - "larry_elite": { - "encounter": { - "1": "…안녕하십니까, 청목입니다.\n$귀찮게도 저는 사천왕도 겸임하고 있습니다." - }, - "victory": { - "1": "날고 있는 새포켓몬도 떨어뜨릴 기세로군요." - }, - "defeat": { - "1": "치프와 만나기로 한 시각이군요." - } - }, - "lance": { - "encounter": { - "1": "널 기다리고 있었다. 그 실력을 시험해보겠어.", - "2": "여기까지 올 수 있을거라고 생각했다. 슬슬 시작해볼까." - }, - "victory": { - "1": "날 따라잡았군. 훌륭해!", - "2": "다른 트레이너가 날 이길 거라곤 생각 못했는데… 놀랍군." - }, - "defeat": { - "1": "근소하군. 다시 해볼까?", - "2": "네가 약해서가 아니다. 신경쓰지 말도록." - } - }, - "karen": { - "encounter": { - "1": "난 카렌! 내 악 타입 포켓몬과의 승부를 원하니?", - "2": "난 네가 이전에 만났던 트레이너들과는 달라.", - "3": "강한 포켓몬, 약한 포켓몬, 그런 건 사람이 멋대로 정하는 것." - }, - "victory": { - "1": "좋아하는 마음이 전해진다면 포켓몬도 답할거야. 그렇게 강해지는 거지", - "2": "난 내가 선택한 길을 걸어갈거야.", - "3": "챔피언이 너를 기다리고 있어." - }, - "defeat": { - "1": "정말 강한 트레이너라면 좋아하는 포켓몬으로 이길 수 있도록 열심히 해야 해.", - "2": "뭐, 비교적 재밌었어.", - "3": "언제라도 다시 찾아와, 상대해줄게." - } - }, - "milo": { - "encounter": { - "1": "그렇다는 건 당신이 포켓몬을 아주 깊게 이해하고 있다는 뜻이겠죠? \n$이거 만만치 않은 승부가 되겠네요! \n$저도 다이맥스를 사용해야겠어요!" - }, - "victory": { - "1": "풀의 힘이 모두 시들어버리다니… 당신은 굉장한 도전자시군요!" - }, - "defeat": { - "1": "충격과 공포를 전해드리겠습니다." - } - }, - "lucian": { - "encounter": { - "1": "잠깐, 기다려주세요. 제가 읽던 책이 거의 클라이맥스에 도달했거든요…\n$주인공이 성스러운 검을 얻었고 마지막 시련을 앞두고 있는데… 아, 신경 쓰지 마세요.\n$여기까지 왔으니, 그건 제쳐두고 당신과 싸워야겠습니다.\n$당신이 과연 주인공이 될 그릇인지 확인해 보도록 하죠!" - }, - "victory": { - "1": "그렇군요… 결국 체크메이트인가요." - }, - "defeat": { - "1": "제 평판을 지켜냈네요." - } - }, - "drasna": { - "encounter": { - "1": "당신 강하시죠? 그것도 상당히 꽤 말이에요…\n$어머 기뻐라! 그런 상대와 놀면 포켓몬들도 쑥쑥 크겠어요!" - }, - "victory": { - "1": "어머머 벌써 끝나버리다니… 미안해요, 괜찮으면 또 오세요!" - }, - "defeat": { - "1": "어머, 웬일이야?" - } - }, - "kahili": { - "encounter": { - "1": "자, 여기에서… 승리의 바람이 부는 쪽은 당신과 저 중에 어느 쪽일까요?" - }, - "victory": { - "1": "사천왕으로서 분하지만 당신들의 강함은 진정한 강함이군요." - }, - "defeat": { - "1": "이것이 에이스니까요!" - } - }, - "hassel": { - "encounter": { - "1": "맹렬하게 몰아치는 승부의 숨결을 직접 가르쳐 드리겠습니다!!" - }, - "victory": { - "1": "이번에는 당신이 승리를 쟁취했군요. \n$하지만, 시합의 흐름을 보니… 다음 승부는 또 어떻게 될지 모르겠네요." - }, - "defeat": { - "1": "저에게 더 배우고 싶은 것이 있으시다면 또 승부하도록 하죠." - } - }, - "blue": { - "encounter": { - "1": "여기까지 왔다니, 실력이 꽤 봐줄만 할 것 같은데." - }, - "victory": { - "1": "그 녀석한테만 지는 줄 알았는데… 누구냐고? 하, 하…" - }, - "defeat": { - "1": "봤지? 여기까지 온 내 실력." - } - }, - "piers": { - "encounter": { - "1": "뜨거운 현장을 즐길 준비는 됐겠지! 스파이크 마을, it's time to rock!" - }, - "victory": { - "1": "나도 내 멤버들도 최선을 다했어. 다음에 또 배틀하자고…" - }, - "defeat": { - "1": "소리를 지르느라 목이 가버렸군… 그렇지만 박진감 넘치는 배틀이었다!" - } - }, - "red": { - "encounter": { - "1": "…!" - }, - "victory": { - "1": "…?" - }, - "defeat": { - "1": "…!" - } - }, - "jasmine": { - "encounter": { - "1": "와… 당신의 포켓몬은 인상적이네요. 재미있을 것 같아요." - }, - "victory": { - "1": "당신은 정말 강하네요. 저도 더 열심히 노력해야겠어요." - }, - "defeat": { - "1": "이길 줄은 몰랐어요." - } - }, - "lance_champion": { - "encounter": { - "1": "여전히 난 챔피언이다. 더이상 주저할 게 없군." - }, - "victory": { - "1": "새로운 챔피언의 등장이군." - }, - "defeat": { - "1": "성공적으로 챔피언 자리를 지켜냈다." - } - }, - "steven": { - "encounter": { - "1": "넌… 포켓몬과 함께 모험을 하면서 무엇을 봤지? \n$많은 트레이너와 만나면서 무엇을 느꼈지? \n$풍요로운 이 지역을 돌아다니면서, 네 안에서 눈뜨기 시작한 무언가… \n$그 모든 것을 나에게 쏟아부었으면 좋겠어. \n$나와 내 포켓몬들도 전력을 다해 상대해줄 테니까!" - }, - "victory": { - "1": "챔피언인 내가 질 줄이야…" - }, - "defeat": { - "1": "덕분에 즐거웠어! 고마워!" - } - }, - "cynthia": { - "encounter": { - "1": "나, 난천은, 네 도전을 받아들일게! 온 힘을 다해 너와 시합하겠어!" - }, - "victory": { - "1": "포켓몬 배틀보다 재밌는 것은 없지만, 언젠간 끝나기 마련이니…" - }, - "defeat": { - "1": "비록 졌어도, 포켓몬에 대한 사랑은 잃지 않도록 해." - } - }, - "iris": { - "encounter": { - "1": "나는 말이지, 강한 트레이너와의 진지한 승부를 즐겨!\n$왜냐면 그렇잖아! 이곳에 오는 건 마음 깊이 승리를 추구하는 트레이너. \n#함께 싸우는 건 수많은 승부를 헤쳐온 포켓몬.\n$그런 상대와 겨룰 수 있다면 나도! 내 포켓몬도!\n$더욱더 강해지고 서로 알 수 있으니까! 으응! 그럼 간다! \n$포켓몬리그 챔피언 아이리스! 당신을 이기겠습니다!!" - }, - "victory": { - "1": "후와아아아… 힘을 모두 발휘했는데도 우리가 졌네." - }, - "defeat": { - "1": "우와! 이겼다!" - } - }, - "hau": { - "encounter": { - "1": "트레이너가 따뜻한 지역 출신인지 추운 지역 출신인지에 따라 배틀 스타일이 달라지는지 궁금해졌어.\n$그럼 테스트 해볼게~!" - }, - "victory": { - "1": "멋진데~! 이제 너의 스타일을 조금 더 잘 알게된 것 같아!" - }, - "defeat": { - "1": "이런, 그건 그냥 승부였는데~!" - } - }, - "geeta": { - "encounter": { - "1": "그 도전장, 한 번 더 승낙하도록 하죠. \n$자… 훈련의 결실을 보여주세요." - }, - "victory": { - "1": "당신이 이룰 업적에 대한 소식들, 기다리고 있겠습니다!" - }, - "defeat": { - "1": "무슨 문제라도 있나요? 이게 전부라니, 그럴리 없잖아요?" - } - }, - "nemona": { - "encounter": { - "1": "만세! 나 너무 기대돼! 이제 전력으로 승부하는거야~!" - }, - "victory": { - "1": "우와, 조금 문제 있지만, 그래도 너무 재밌었어! 다음에는 지지 않을거야!" - }, - "defeat": { - "1": "우와, 너무 멋진 승부였어! 정말로 강하네." - } - }, - "leon": { - "encounter": { - "1": "레츠, 챔피언 타임!!!" - }, - "victory": { - "1": "챔피언 타임은 끝났어… \n$하지만 정말 멋진 시간이었지! \n$최고의 시합을 만들어줘서 고맙다!" - }, - "defeat": { - "1": "최고의 챔피언 타임이었어, 정말로!" - } - }, - "whitney": { - "encounter": { - "1": "있지! 포켓몬들 말이야, 정말 너무 귀엽지?" - }, - "victory": { - "1": "흑! 으아앙! 너무해!" - }, - "defeat": { - "1": "이걸로 끝!" - } - }, - "chuck": { - "encounter": { - "1": "하! 나에게 도전하겠다고? 용감한 거냐, 아니면 그냥 무모한 거냐?" - }, - "victory": { - "1": "자네 강하군! 나를 제자로 삼아주겠나?" - }, - "defeat": { - "1": "자. 내가 자네보다 얼마나 더 강력한지 깨달았겠지?" - } - }, - "katy": { - "encounter": { - "1": "쓰러지고 싶지 않다면 방심하지 말고 열심히 해 봐~" - }, - "victory": { - "1": "내 포켓몬들 모두 지쳐서 헤벌레~ 해졌어~" - }, - "defeat": { - "1": "비비용~ 많~이 먹으렴~" - } - }, - "pryce": { - "encounter": { - "1": "젊음만으로는 승리를 보장할 수 없다! 중요한 것은 경험이다." - }, - "victory": { - "1": "특출하군! 완벽해. 지금 이 느낌을 잊지 말도록." - }, - "defeat": { - "1": "내가 예상했던 그대로군." - } - }, - "clair": { - "encounter": { - "1": "내가 누군지 알지? 그런데도 감히 내게 도전해?" - }, - "victory": { - "1": "네 실력이 어디까지 올라갈 수 있는지 궁금하네. 아주 흥미진진하겠어." - }, - "defeat": { - "1": "끝이다." - } - }, - "maylene": { - "encounter": { - "1": "지금 당신에게 도전하러 왔어요.\n$전력을 다할 테니 각오하세요!" - }, - "victory": { - "1": "나의 패배입니다…" - }, - "defeat": { - "1": "멋진 승부였습니다." - } - }, - "fantina": { - "encounter": { - "1": "당신도 도전해 보세요. 전 당신을 이기겠어요.\n$그것이 체육관 관장!" - }, - "victory": { - "1": "당신 최고로 강해요. 나 진 것 알아요." - }, - "defeat": { - "1": "너무, 너무 행복해요!" - } - }, - "byron": { - "encounter": { - "1": "젊은 트레이너여! 자네는 내 아들 강석처럼 젊군.\n$젊은 트레이너가 많아질수록, 포켓몬의 미래도 밝지!\n$그러니, 젊은이들이 넘어야할 벽으로서 상대해주겠다!" - }, - "victory": { - "1": "흠! 내 견고한 포켓몬이--져버렸군!" - }, - "defeat": { - "1": "으하하핫! 내 견고한 포켓몬은 어땠나?!" - } - }, - "olympia": { - "encounter": { - "1": "이 의식은 앞으로의 길을 정하는 것입니다. 포켓몬 승부를 시작해볼까요!" - }, - "victory": { - "1": "당신이라면 별이라도 움직여서 가야 할 길을 만들어 낼 것 같습니다." - }, - "defeat": { - "1": "우리의 길은 이제 분명해졌습니다." - } - }, - "volkner": { - "encounter": { - "1": "여기까지 왔으니, 넌 꽤 강하겠군…\n$네가 내게 포켓몬 승부의 즐거움을 상기시켜 줄 트레이너이길 바란다!" - }, - "victory": { - "1": "너 나를 이겼군…\n$네 열정과 포켓몬이 그런 너를 위해 싸워준 고귀한 방식…\n$심지어 스릴까지 넘쳤다. 아주 좋은 승부였어." - }, - "defeat": { - "1": "전혀 충격적이지 않았다…\n$이런 건 원하지 않았어!" - } - }, - "burgh": { - "encounter": { - "1": "으-음… 이번 배틀에서 이기면, 예전과는 다른 그림을 그릴 수 있을 것 같아. \n$맞아! 난 승리 뮤즈의 목소리를 선명하게 들을 수 있거든. 그럼 승부다!", - "2": "물론, 난 내 포켓몬을 자랑스럽게 생각하거든! \n$자 그럼… 바로 승부할까!" - }, - "victory": { - "1": "벌써 끝이라고? 뮤즈가 나를 버리고 떠나버렸나?", - "2": "아우… 져버렸네! 너 굉장히 강하잖아!" - }, - "defeat": { - "1": "우와… 왠지 뭔가 아름답네, 그치…", - "2": "가끔 사람들이 못난 승리라고 말하는 걸 듣곤 해. \n$그치만 난 최선을 다했다면, 어떤 승리든 아름답다고 생각하거든." - } - }, - "elesa": { - "encounter": { - "1": "컴플리트…! 확신이 들때면, 내 몸을 통하는 전기가 짜릿짜릿하게 느껴져! \n$그 감각을 느끼고 싶으니까…, 다음은 사랑스러운 포켓몬들로 너를 어질어질하게 할게!" - }, - "victory": { - "1": "어질어질하게 만들 셈이였는데, 너한테는 짜릿짜릿하게 당해버렸네." - }, - "defeat": { - "1": "왠지 부족한 기분이야… 다음에는 최선을 다할 수 있지?" - } - }, - "skyla": { - "encounter": { - "1": "드디어 대결의 시간이야! 누가 정상에 오를지 결정짓는 포켓몬 배틀, 그치? \n$난 정상에 있는 게 좋아! 높은 곳에서는 항상 멀리 볼 수 있으니까! \n$그럼, 다음은 나랑 더욱 즐거운 것을 할까?" - }, - "victory": { - "1": "배틀에서 네 상대가 되는 거, 뭔가 새로운 모티브가 되네. 고마워!" - }, - "defeat": { - "1": "이기든 지든, 항상 무언가를 얻게 돼, 그치?" - } - }, - "brycen": { - "encounter": { - "1": "다른사람이나 포켓몬과 함께 있을 때도 힘이 생긴다. \n$그 도움을 받는 것이 너를 강하게 만들었겠지. 그 힘을 보이거라!" - }, - "victory": { - "1": "너와 포켓몬과! 멋진 콤비네이션! 아름다운 우정!" - }, - "defeat": { - "1": "극한에서 시험받고 단련하도록!" - } - }, - "drayden": { - "encounter": { - "1": "지금 찾는 것은 밝은 미래를 보여줄 젋은 트레이너의 존재. \n$승부에서 모든 걸 보이도록. 네 기술, 내 경험, 그리고 포켓몬을 키워온 사랑도 함께!" - }, - "victory": { - "1": "패배하여 끓어오르는 이 마음… 뭐라고 표현해야 좋을까." - }, - "defeat": { - "1": "실망스럽군! 난 자네의 능력이 그보다 더 크다는 걸 알고있네!" - } - }, - "grant": { - "encounter": { - "1": "제가 바라는 것은 단 하나뿐입니다. \n$서로가 서로를 뛰어넘어, 더 높은 벽에 도달하는 것입니다." - }, - "victory": { - "1": "내 앞에 솟아 있는 높은 벽… 그건 바로 당신입니다." - }, - "defeat": { - "1": "인생에서 중요한 교훈은 간단합니다.\n$포기하지 않는 것.\n$이것이 전부입니다." - } - }, - "korrina": { - "encounter": { - "1": "코르니 납시오!" - }, - "victory": { - "1": "네 존재가 너의 포켓몬을 점점 진화시키고 있어!" - }, - "defeat": { - "1": "정말 멋진 배틀이었어!" - } - }, - "clemont": { - "encounter": { - "1": "아앗! 잘 부탁드립니다!" - }, - "victory": { - "1": "당신들의 승부를 향한 마음에 자극을 받았습니다!" - }, - "defeat": { - "1": "저의 슈퍼트레이닝 발명품이 효과가 있는 것 같군요!" - } - }, - "valerie": { - "encounter": { - "1": "어라,트레이너님… 슝슝 워프해서… 이렇게 만나서 반갑네. \n$그리고 내가 보기엔 당신은 노력했기에, 이 승부에 참가할 수 있게 된 것 같아. \n$찾기 힘든 요정 같은 페어리 타입, 우리 포켓몬들 사뿐하고 화사하지만 강하다구." - }, - "victory": { - "1": "난 당신이 내일을 생각하며 웃을 수 있는 것들을 찾길 바라고 있을게…" - }, - "defeat": { - "1": "앗 이런, 가엾어라…" - } - }, - "wulfric": { - "encounter": { - "1": "그거 알아? 그거… 전투와 유대감을 통해 배운다거나 하는… 거 뭐더라, 음.\n$여튼 말이지, 난 그냥 재밌어서 하는 거야. \n$내 자랑은 별로 듣고 싶지 않으려나? 자, 포켓몬을 꺼내자!" - }, - "victory": { - "1": "그거야, 바로 그거! 멋지다고. 단단한 얼음을 깨부쉈구나!" - }, - "defeat": { - "1": "나와 싸우면 그런 일이 벌어진다니까!" - } - }, - "kabu": { - "encounter": { - "1": "모든 트레이너와 포켓몬은 이기기 위해 훈련을 하고 있다. \n$하지만 싸우는 상대 역시 그만큼 노력하고 있지. \n$ 결국 승부는 실전에서, 얼마만큼 제 실력을 발휘할 수 있느냐에 달렸다." - }, - "victory": { - "1": "오늘 너와 싸울 수 있어서 참 기뻤다!" - }, - "defeat": { - "1": "내 성장을 체감하게 되는군!" - } - }, - "bea": { - "encounter": { - "1": "당신은 과연, 어떤 공격에도 흔들리지 않는 마음을 가졌을까요? \n$제가 시험해보겠습니다, 준비는 되셨습니까?" - }, - "victory": { - "1": "당신이 데리고 있는 포켓몬에게서 무예의 혼을 느꼈습니다." - }, - "defeat": { - "1": "누구나 바랄 법한 최고의 경기였습니다." - } - }, - "opal": { - "encounter": { - "1": "그럼 너의 파트너 포켓몬 다루는 실력을 내게 보여주거라!" - }, - "victory": { - "1": "핑크는 부족하지만, 너희는 좋은 트레이너와 포켓몬이구나." - }, - "defeat": { - "1": "내가 보기엔, 불합격이란다." - } - }, - "bede": { - "encounter": { - "1": "의심할 여지 없이 증명하겠습니다. 당신이 한심한지, 그리고 내가 얼마나 강한지!" - }, - "victory": { - "1": "잘 봤습니다… 뭐, 꽤 괜찮네요. 전 그렇게 열심히 하지도 않았으니까요." - }, - "defeat": { - "1": "이런 결과, 나쁘지 않군요." - } - }, - "gordie": { - "encounter": { - "1": "그럼, 빨리 끝내도록 하죠." - }, - "victory": { - "1": "구멍이 있다면 들어가고 싶군요… 아니지, 여기선 빠지고 싶다고 해야하나?" - }, - "defeat": { - "1": "이런 배틀이라면, 매번 승리가 따라올 것 같네요!" - } - }, - "marnie": { - "encounter": { - "1": "사실은, 말했던 일들이 해결 되고 나면… 결국은 나 자신이 챔피언이 되고싶다는 걸 알았으니까! \n$그러니까 너의 팀을 기분 좋게 잠들게 해주겠어!" - }, - "victory": { - "1": "응, 그래서 내가 졌구나… 그치만 너와 네 포켓몬의 좋은 점을 많이 볼 수 있었어!" - }, - "defeat": { - "1": "우리의 배틀 방식을 즐겼길 바라." - } - }, - "raihan": { - "encounter": { - "1": "챔피언도 쓰러뜨리고, 토너먼트에서도 우승해서, 위대한 나 금랑님이 얼마나 강한지 세계에 증명 해보실까!" - }, - "victory": { - "1": "역시 난 진 다음에도 멋있네! \n$조금 분하지만…. \n$기념으로 셀카라도 찍어둘까…!" - }, - "defeat": { - "1": "자, 이 순간을 기억하기 위한 셀카를 찍자고." - } - }, - "brassius": { - "encounter": { - "1": "준비는 됐겠지!? 그럼, 우리 둘의 예술적인 합작품을 한번 만들어 보도록 할까!" - }, - "victory": { - "1": "아… 아방가르드!!" - }, - "defeat": { - "1": "바로 신작을 만들러 가야 하니 이만 실례하겠다!" - } - }, - "iono": { - "encounter": { - "1": "자~ 오늘의 각오는~ 모야모야~?\n$...\n$그럼, 이제 시작해 볼까! \n$도전자님의 실력은 과연 과연~!?" - }, - "victory": { - "1": "너의 반짝임은 1000만볼트!" - }, - "defeat": { - "1": "당신의 눈길을 일렉트릭네트로 뾰로롱!" - } - }, - "larry": { - "encounter": { - "1": "그렇습니다. 심플한 것이 가장 강한 것입니다!" - }, - "victory": { - "1": "허, 이걸로 한 방 먹은 게 되었군요." - }, - "defeat": { - "1": "오늘은 저는 이만 실례하겠습니다." - } - }, - "ryme": { - "encounter": { - "1": "나의 영혼 흔들어 봐 Come On!" - }, - "victory": { - "1": "너의 Cool한 Youth 나의 Soul이 Move!" - }, - "defeat": { - "1": "Bye Bye Baby~!" - } - }, - "grusha": { - "encounter": { - "1": "내가 너를 철저하게 얼려 버리면 고민할 것도 없겠지!" - }, - "victory": { - "1": "너의 그 열기… 싫지 않아." - }, - "defeat": { - "1": "너에겐 아직 열기가 부족하구나." - } - }, - "marnie_elite": { - "encounter": { - "1": "여기까지 왔구나? 포켓몬 다루는 실력 좀 볼까!", - "2": "최선을 다할 거니까, 쉽게 넘어갈 수 있을 거라고 생각하지 마!" - }, - "victory": { - "1": "내가 지다니 믿을 수 없어… 그렇지만 네가 바란 것도 이런 승리였겠지. 잘했어!", - "2": "난 여전히 배울 게 많은 것 같아. 그래도, 멋진 승부였어!" - }, - "defeat": { - "1": "잘 싸웠지만, 내가 위야! 다음에는 더 잘해봐!", - "2": "트레이닝이 제값을 하는 것 같네. 승부에 응해줘서 고마워!" - } - }, - "nessa_elite": { - "encounter": { - "1": "조류가 오늘은 내 편인 것 같네. 휩쓸릴 준비 됐어?", - "2": "이번 승부로 파도를 일으키는 거야! 준비는 됐겠지!" - }, - "victory": { - "1": "너 그런 바다를 완벽하게 버텨냈네… 잘했어!", - "2": "내 쪽의 해류가 너와 맞지 않았던 거 같네. 잘했어!" - }, - "defeat": { - "1": "물은 항상 자기 길을 찾아 흐르지. 상쾌한 승부였어!", - "2": "잘 싸웠지만, 바다의 힘은 막을 수 없다고!" - } - }, - "bea_elite": { - "encounter": { - "1": "준비는 되셨겠죠! 제 투지가 불타고 있습니다!", - "2": "가차 없는 제 속도를 따라잡으실 수 있는지 지켜보겠습니다!" - }, - "victory": { - "1": "당신의 힘… 인상적이군요. 정말로 이기실 만합니다.", - "2": "이런 강렬함은 처음 느껴봅니다. 대단하군요!" - }, - "defeat": { - "1": "치열했던 훈련으로 또 한번 승리를 거두게 뒀군요! 고생하셨습니다!", - "2": "당신도 힘냈겠지만, 제가 더 열심히 훈련했거든요. 좋은 배틀이었습니다!" - } - }, - "allister_elite": { - "encounter": { - "1": "그림자가 떨어지네… 두려움에 맞설 준비는 됐어?", - "2": "내가 다루는 어둠을 감당할 수 있는지 지켜볼게." - }, - "victory": { - "1": "너 그림자를 쫓아내 버렸구나… 일단은. 잘했어.", - "2": "네 빛이 어둠을 관통해 버렸네. 훌륭해." - }, - "defeat": { - "1": "그림자가 말했어… 네 힘은 아직 부족한 것 같아.", - "2": "어둠의 승리… 다음번에는 빛을 보게 될 거야." - } - }, - "raihan_elite": { - "encounter": { - "1": "폭풍이 몰아치는군! 네가 이 배틀에서도 견뎌낼 수 있는지 지켜보겠어!", - "2": "폭풍의 눈과 마주칠 준비는 됐겠지!" - }, - "victory": { - "1": "폭풍을 이겨내다니… 정말 놀라운걸!", - "2": "너 바람에 완벽하게 올라탔구나… 대단한 승부였어!" - }, - "defeat": { - "1": "폭풍을 견디고, 또 다른 승리도 잡아버렸네! 좋은 승부였어!", - "2": "넌 내 폭풍을 잡아냈잖아! 다음엔 더 잘해봐!" - } - }, - "alder": { - "encounter": { - "1": "하나지방에서 가장 강한 트레이너를 상대할 준비는 됐나?" - }, - "victory": { - "1": "장하구나! 실로 견줄 자가 천하에 없도다!" - }, - "defeat": { - "1": "나의 마음에 상쾌한 바람이 지나갔다...\n$정말 대단한 노력이다!" - } - }, - "kieran": { - "encounter": { - "1": "난 노력을 통해 강해지고 또 강해지지!\n$난 지지 않아." - }, - "victory": { - "1": "믿을 수 없어...\n$정말 재밌고 가슴 뛰는 배틀이었어!" - }, - "defeat": { - "1": "세상에 마상에! 정말 멋진 배틀이었어!\n$네가 더 열심히 훈련할 시간이야." - } - }, - "rival": { - "encounter": { - "1": "@c{smile}오, 찾았다! 떠나려는 건 알고 있었지만\n인사정도는 해줄 줄 알았는데…\n$@c{smile_eclosed}그러니까 정말로 꿈을 좇겠다는 거지?\n듣고도 못 믿었다니까.\n$@c{serious_smile_fists}여기까지 온 김에, 배틀은 어때?\n준비가 됐나 보자구.\n$@c{serious_mopen_fists}망설이지 말고,\n너의 진면목을 보여봐!" - }, - "victory": { - "1": "@c{shock}와… 정말 깔끔하게 당했네.\n초보자 맞아?\n$@c{smile}운이 따른 건지도 모르겠지만…\n그래도 정말 꿈을 이룰 지도.\n$그나저나, 박사님께서 이걸 전해달라고 하시더라.\n좋아 보이던데.\n$@c{serious_smile_fists}아무튼, 힘 내는거야!" - } - }, - "rival_female": { - "encounter": { - "1": "@c{smile_wave}여깄구나! 찾고 있었어!\n@c{angry_mopen}절친한테 작별인사도 안 하는거야?\n$@c{smile_ehalf}꿈을 향해 떠나는거구나. 그렇지?\n이런 날이 오긴 하네…\n$@c{smile}아무튼, 날 까먹고 가버린 건 용서해주겠어.\n@c{smile_wave_wink}배틀을 해준다면 말야!\n$@c{angry_mopen}최선을 다 해 봐.\n모험을 시작과 동시에 끝내고 싶지 않다면!" - }, - "victory": { - "1": "@c{shock}왜 벌써 이렇게 센 건데?!@d{96}\n@c{angry}아니면 뭔가 속임수, 그런 거?\n$@c{smile_wave_wink}농담, 농담!@d{64} @c{smile_eclosed}내가 진 거 맞아…\n너 정말 앞으로도 잘 하겠는데.\n$@c{smile}아 그래, 박사님께서 전해달라던 물건.\n도움이 되면 좋겠어!\n$@c{smile_wave}항상 최선을 다 하라구! 믿고 있을게!" - } - }, - "rival_2": { - "encounter": { - "1": "@c{smile}어라, 너 여깄었구나?\n@c{smile_eclosed}아직도 전승 중이라, 이거지…?\n$@c{serious_mopen_fists}널 쫓아서 온 것 같아 보이겠지만, 오해야.\n$@c{serious_smile_fists}그래도 솔직히 그 때부터 쭉 재대결이 간절했어.\n$그 동안의 훈련도 있겠다 마침 좋은 기회같지?\n$@c{serious_mopen_fists}자, 전처럼!\n배틀이야!" - }, - "victory": { - "1": "@c{neutral_eclosed}이런. 자신감이 과했나봐.\n$@c{smile}그래, 또 지고 말았네.\n@c{serious_mopen_fists}좀 더 열심히 훈련을 해야겠어!\n\n$@c{smile}너한테 도움이 필요할 것 같지는 않지만, 이거.\n남는 게 있어서 말이야.\n$@c{serious_smile_fists}물론 이번이 마지막이야, 알겠지?\n공평하게 하지 않으면 그게 내 핑계거리가 되고 말거야.\n$@c{smile}이제 갈게. 앞으로도 조심하고, 이벤트도 즐겁게 보내!" - } - }, - "rival_2_female": { - "encounter": { - "1": "@c{smile_wave}우연이네, 이런 곳에서 만나고.\n아직 연전연승이구나? @c{angry_mopen}나쁘지 않아!\n$@c{angry_mopen}무슨 생각하고있는지 알겠어, 하지만 아냐.\n@c{smile_eclosed}우연히 근처에 있었을 뿐이라구.\n$@c{smile_ehalf}그래도 마침, 가끔은 지는것도 괜찮다고 알려주고 싶었는데.\n$@c{smile}우린 실수를 통해서도 성장할 수 있잖아.\n때로는 성공을 반복할 때보다도 더 많이 말야.\n$@c{angry_mopen}어쨌든간에, 나도 이런 때를 위해 훈련해왔으니까,\n너도 최선을 다 하는게 좋을 거야!" - }, - "victory": { - "1": "@c{neutral}이… 번에도 져버릴 줄이야…\n$@c{smile}으, 그래. 더 열심히 훈련하면 되겠지!\n$@c{smile_wave}이것도 하나 더 챙겨왔으니 받아!\n@c{smile_wave_wink}감사 인사는 됐다구~.\n$@c{angry_mopen}하지만, 마지막이야!\n또 이렇게 공짜로 나눠주진 않을 테니까!\n$@c{smile_wave}그럼! 이벤트 잘 즐기고!" - }, - "defeat": { - "1": "가끔은 지는 것도 괜찮아…" - } - }, - "rival_3": { - "encounter": { - "1": "@c{smile}이게 누구야! 오랜만이야.\n@c{neutral}역시나… 쭉 이기고 있었구나?\n$@c{neutral_eclosed}상황이 좀… 그렇더라. \n혼자 마을로 돌아가봤자 너 없인 예전같아질 수 없겠지.\n$@c{serious}이기적인 이야기란건 알지만 말해야겠어.\n@c{neutral_eclosed}너 지금 좀 아닌 것 같아.\n$@c{serious}계속 이기기만 하겠다는 건 너무 비현실적이야.\n사람은 원래 꺾여가며 성장하는 거라고.\n$@c{neutral_eclosed}물론 지금까지는 잘 해왔다고 생각하겠지만,\n갈 길이 멀지. @c{neutral}대비는 되어 있어?\n$@c{serious_mopen_fists}그렇다면, 내게 증명해 줘." - }, - "victory": { - "1": "@c{angry_mhalf}말도 안 돼… 한시도 쉬지 않고 훈련했는데…\n어째서 전혀 닿을 수 없는거야?" - } - }, - "rival_3_female": { - "encounter": { - "1": "@c{smile_wave}오랜만이야! 아직도 안 졌구나.\n@c{angry}거슬리게 말야. @c{smile_wave_wink}농담이야!\n$@c{smile_ehalf}하지만 진짜, 고향이 그립진 않아? 집이나… 나는?\n나… 나는, 네가 정말 그리웠어.\n$@c{smile_eclosed}난 너의 꿈과 모든 것을 응원하지만,\n넌 언젠가 패배를 겪게 될 거야.\n$@c{smile}그 땐 언제나처럼 내가 곁에 있어줄게.\n@c{angry_mopen}내가 얼마나 강해졌는지도, 지금 보여 줄 테니까!" - }, - "victory": { - "1": "@c{shock}이렇게까지 했는데도… 모자랐던 거야…?\n이러면 정말로 너는 이제 영영…" - }, - "defeat": { - "1": "최선을 다 했지.\n집에 갈 시간이야." - } - }, - "rival_4": { - "encounter": { - "1": "@c{neutral}안녕.\n$잡담은 넘어가자.\n@c{neutral_eclosed}너에게 이기기 위해 찾아왔어. 간단하지.\n$@c{serious_mhalf_fists}이제 잠재력을 끌어내는 법은 확실히 알겠어.\n$@c{smile}잠이나 사회적인 활동들.\n줄일 수 있는 불필요한 시간이 아주 많더라.\n$@c{serious_mopen_fists}오직 승리 뿐이야.\n이제 아무것도 중요하지 않아.\n$@c{neutral_eclosed}나도 이제 더 이상은 지지 않게 됐어.\n@c{smile_eclosed}네 그 철학이 완전히 틀린 건 아니었나봐.\n$@c{angry_mhalf}패배는 약자에게 주어지는 것이고, 난 더 이상 약하지 않아.\n$@c{serious_mopen_fists}준비해." - }, - "victory": { - "1": "@c{neutral}너…@d{64} 너 대체 뭐야?" - } - }, - "rival_4_female": { - "encounter": { - "1": "@c{neutral}나야! 날 잊어버리고 있던 건… 아니지?\n$@c{smile}네 업적에 자랑스러워 할 때가 됐어. 축하해!\n하지만 네 여행도 여기까지야.\n$@c{smile_eclosed}너는 나도 모르던 내 안의 무언가를 일깨웠어.\n이제 훈련 말고는 아무것도 하지 않아.\n$@c{smile_ehalf}먹지도 자지도 않고, 그저 하루종일.\n더 강해지고 있어.\n$@c{neutral}사실, 나… 이제 내가 뭔지도 잘 모르겠어.\n$그렇지만 기량만은, 정점에 다다랐지.\n아무도 내게 이길 수 없을거야.\n$그거 알아? 이게 전부 네 덕이야.\n@c{smile_ehalf}감사해야할지 증오해야할지 모르겠네.\n$@c{angry_mopen}준비해." - }, - "victory": { - "1": "@c{neutral}너…@d{64} 너 대체 뭐야?" - }, - "defeat": { - "1": "$@c{smile}네가 키운 상대야. 자랑스럽지?" - } - }, - "rival_5": { - "encounter": { - "1": "@c{neutral}…" - }, - "victory": { - "1": "@c{neutral}…" - } - }, - "rival_5_female": { - "encounter": { - "1": "@c{neutral}…" - }, - "victory": { - "1": "@c{neutral}…" - }, - "defeat": { - "1": "$@c{smile_ehalf}…" - } - }, - "rival_6": { - "encounter": { - "1": "@c{smile_eclosed}다시 만났구나.\n$@c{neutral}모든 걸 되짚어 봤어.\n이 기이함에도 이유가 있더라.\n$@c{neutral_eclosed}널 이기고자 하는 욕구, 아니면 네 꿈…\n이건 그저 더 큰 무언가의 일부일 뿐이었어.\n$@c{serious}개인의 문제가 아니라 세계 전체가 엮인 일이었고…\n@c{serious_mhalf_fists}난 널 한계까지 밀어붙이기 위한 도구였던 거지.\n$@c{neutral_eclosed}내가 잘 쓰였는진 모르겠지만 어쨌든 최선을 다 했고.\n$@c{neutral}끝끝내 도착한 이곳은 끔찍하지만…\n언젠가 와 본 것 같아.\n$@c{serious_mhalf_fists}너도 그렇게 느끼지?\n$@c{serious}…그리고 무언가가 이야기하고 있어.\n오랫동안 세상에 알려져온 무언가가.\n$우리가 함께했던 소중한 시간들은 이제 그저 아득해.\n$@c{neutral_eclosed}실제로 일어난 일이긴 할까?\n$@c{serious_mopen_fists}너는 계속 나아가야 해. 그렇지 않으면 끝나지 않아.\n오직 너만이 할 수 있어.\n$@c{serious_smile_fists}잘 모르겠지만, 하나만은 확실해.\n$@c{serious_mopen_fists}여기서 날 쓰러뜨리지 못한다면, 너에게 기회는 없을거란걸." - }, - "victory": { - "1": "@c{smile_eclosed}내 역할은 여기까진 것 같아.\n$하나만 약속해 줘.\n@c{smile}세상을 원래대로 되돌리고 나면, 집으로 돌아오는거야." - } - }, - "rival_6_female": { - "encounter": { - "1": "@c{smile_ehalf}또 이렇게 만났네.\n$@c{smile_eclosed}나 머릿속이 빙글빙글 도는 것 같아…\n$@c{smile_ehalf}모든 것이 이상하게 보이는 이유.\n분명 뭔가가 있어…\n$@c{smile}너는 너의 꿈이 있고,\n나는 나의 야망이 있지…\n$이 모든것, 우리가 하고 있는 모든 일들이\n더 큰 무언가를 위한 것임을 느낄 수밖에 없어.\n$@c{smile_eclosed}나는 아마 너를…\n한계까지 몰아붙여야 하는 거야.\n$@c{smile_ehalf}잘 해왔는지는 모르겠는데, 최선은 다 했어.\n$이 이상하고 무서운 곳…\n모든게 선명하게 보이고…\n$이건… 오래전부터 세상에 알려져온 전부.\n$@c{smile_eclosed}우리가 함께해온 추억들이, 이제는 거의 떠오르지 않아.\n$@c{smile_ehalf}실제로 일어났던 일일까? 너무 멀게만 느껴지는데…\n$@c{angry_mopen}계속 나아가야 해. 안 그러면, 영원히 끝나지 않을 거야. \n오직 너만이 할 수 있어.\n$@c{smile_ehalf}난… 이 모든게 무슨 의미가 있는지는 잘 모르겠지만…\n이거 하나는 느끼고 있어.\n$@c{neutral}여기서 날 쓰러뜨리지 못한다면, 너에게 기회는 없을거란걸." - }, - "victory": { - "1": "@c{smile_ehalf}나… 내 소임을 다 한 기분이야…\n$@c{smile_eclosed}약속해 줘… 세상을 원래대로 되돌리고서… \n집으로… 무사히 돌아오는 거야.\n$@c{smile_ehalf}…고마워." - } - } -} diff --git a/src/locales/ko/egg.json b/src/locales/ko/egg.json deleted file mode 100644 index 96985be8cfe..00000000000 --- a/src/locales/ko/egg.json +++ /dev/null @@ -1,26 +0,0 @@ -{ - "egg": "알", - "greatTier": "레어", - "ultraTier": "에픽", - "masterTier": "레전더리", - "defaultTier": "커먼", - "hatchWavesMessageSoon": "안에서 소리가 들려온다! 이제 곧 태어날 것 같아!", - "hatchWavesMessageClose": "가끔 움직이고 있는 것 같다. 태어나기까지 이제 조금 남은 건가?", - "hatchWavesMessageNotClose": "무엇이 태어날까? 태어나기까지 아직 시간이 걸릴 것 같다.", - "hatchWavesMessageLongTime": "이 알은 태어나기까지 상당한 시간이 걸릴 것 같다.", - "gachaTypeLegendary": "레전더리 확률 업", - "gachaTypeMove": "희귀 알 기술 확률 업", - "gachaTypeShiny": "색이 다른 포켓몬 확률 업", - "selectMachine": "사용할 뽑기 기계를 골라주세요.", - "notEnoughVouchers": "바우처가 충분하지 않습니다!", - "tooManyEggs": "알을 너무 많이 갖고 있습니다!", - "pull": "뽑기", - "pulls": "뽑기", - "sameSpeciesEgg": "{{species}}[[가]] 이 알에서 부화할 거야!", - "hatchFromTheEgg": "알이 부화해서\n{{pokemonName}}[[가]] 태어났다!", - "eggMoveUnlock": "알 기술 {{moveName}}[[를]]\n사용할 수 있게 되었다!", - "rareEggMoveUnlock": "레어 알 기술 {{moveName}}[[를]]\n사용할 수 있게 되었다!", - "moveUPGacha": "알 기술 UP!", - "shinyUPGacha": "색이 다른 포켓몬\nUP!", - "legendaryUPGacha": "UP!" -} \ No newline at end of file diff --git a/src/locales/ko/fight-ui-handler.json b/src/locales/ko/fight-ui-handler.json deleted file mode 100644 index d950e605896..00000000000 --- a/src/locales/ko/fight-ui-handler.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "pp": "PP", - "power": "위력", - "accuracy": "명중률", - "abilityFlyInText": " {{pokemonName}}의\n{{passive}}{{abilityName}}", - "passive": "패시브 ", - "teraHover": "{{type}} 테라스탈" -} diff --git a/src/locales/ko/filter-bar.json b/src/locales/ko/filter-bar.json deleted file mode 100644 index b2104e61750..00000000000 --- a/src/locales/ko/filter-bar.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "genFilter": "세대", - "typeFilter": "타입", - "caughtFilter": "포획", - "unlocksFilter": "해금", - "miscFilter": "기타", - "sortFilter": "정렬", - "all": "전체", - "normal": "기본", - "uncaught": "미포획", - "passive": "패시브", - "passiveUnlocked": "패시브 해금", - "passiveLocked": "패시브 잠김", - "passiveUnlockable": "패시브 해금 가능", - "costReduction": "코스트 감소", - "costReductionUnlocked": "코스트 감소됨", - "costReductionLocked": "코스트 감소 없음", - "costReductionUnlockable": "코스트 감소 가능", - "favorite": "즐겨찾기", - "isFavorite": "즐겨찾기 등록됨", - "notFavorite": "즐겨찾기 제외됨", - "ribbon": "클리어 여부", - "hasWon": "클리어 완료", - "hasNotWon": "클리어 안함", - "hiddenAbility": "숨겨진 특성", - "hasHiddenAbility": "숨겨진 특성 보유", - "noHiddenAbility": "숨겨진 특성 없음", - "egg": "알", - "eggPurchasable": "알 구매 가능", - "pokerus": "포켓러스", - "hasPokerus": "포켓러스 감염", - "noPokerus": "포켓러스 없음", - "sortByNumber": "도감번호", - "sortByCost": "코스트", - "sortByCandies": "사탕 수", - "sortByIVs": "개체값", - "sortByName": "이름" -} \ No newline at end of file diff --git a/src/locales/ko/game-mode.json b/src/locales/ko/game-mode.json deleted file mode 100644 index 8fd619aceeb..00000000000 --- a/src/locales/ko/game-mode.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "classic": "클래식", - "endless": "엔드리스", - "endlessSpliced": "엔드리스(융합체)", - "dailyRun": "데일리 런", - "unknown": "언노운", - "challenge": "챌린지" -} \ No newline at end of file diff --git a/src/locales/ko/game-stats-ui-handler.json b/src/locales/ko/game-stats-ui-handler.json deleted file mode 100644 index bf184acc32b..00000000000 --- a/src/locales/ko/game-stats-ui-handler.json +++ /dev/null @@ -1,42 +0,0 @@ -{ - "stats": "통계", - "playTime": "플레이타임", - "totalBattles": "배틀 수", - "starters": "스타팅", - "shinyStarters": "색다른 스타팅", - "speciesSeen": "만난 종류", - "speciesCaught": "잡은 종류", - "ribbonsOwned": "리본 소지", - "classicRuns": "클래식 플레이", - "classicWins": "클래식 클리어", - "dailyRunAttempts": "데일리 런 플레이", - "dailyRunWins": "데일리 런 클리어", - "endlessRuns": "엔드리스 플레이", - "highestWaveEndless": "최대 웨이브(엔드리스)", - "highestMoney": "최고 소지금", - "highestDamage": "최대 데미지", - "highestHPHealed": "최대 회복량", - "pokemonEncountered": "만난 포켓몬", - "pokemonDefeated": "쓰러뜨린 포켓몬", - "pokemonCaught": "잡은 포켓몬", - "eggsHatched": "부화시킨 알", - "subLegendsSeen": "만난 준전설", - "subLegendsCaught": "잡은 준전설", - "subLegendsHatched": "부화시킨 준전설", - "legendsSeen": "만난 전설", - "legendsCaught": "잡은 전설", - "legendsHatched": "부화시킨 전설", - "mythicalsSeen": "만난 환상", - "mythicalsCaught": "잡은 환상", - "mythicalsHatched": "부화시킨 환상", - "shiniesSeen": "만난 색다른", - "shiniesCaught": "잡은 색다른", - "shiniesHatched": "부화시킨 색다른", - "pokemonFused": "포켓몬 합체", - "trainersDefeated": "트레이너 승리", - "eggsPulled": "뽑은 알", - "rareEggsPulled": "뽑은 레어 알", - "epicEggsPulled": "뽑은 에픽 알", - "legendaryEggsPulled": "뽑은 레전더리 알", - "manaphyEggsPulled": "뽑은 마나피 알" -} \ No newline at end of file diff --git a/src/locales/ko/growth.json b/src/locales/ko/growth.json deleted file mode 100644 index cd69c9f1cc1..00000000000 --- a/src/locales/ko/growth.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "Erratic": "불규칙", - "Fast": "빠름", - "Medium_Fast": "중간 빠름", - "Medium_Slow": "중간 느림", - "Slow": "느림", - "Fluctuating": "변동" -} \ No newline at end of file diff --git a/src/locales/ko/menu-ui-handler.json b/src/locales/ko/menu-ui-handler.json deleted file mode 100644 index 7fecbf7c25f..00000000000 --- a/src/locales/ko/menu-ui-handler.json +++ /dev/null @@ -1,29 +0,0 @@ -{ - "GAME_SETTINGS": "게임 설정", - "ACHIEVEMENTS": "업적", - "STATS": "통계", - "RUN_HISTORY": "플레이 이력", - "EGG_LIST": "알 목록", - "EGG_GACHA": "알 뽑기", - "MANAGE_DATA": "데이터 관리", - "COMMUNITY": "커뮤니티", - "SAVE_AND_QUIT": "저장 후 나가기", - "LOG_OUT": "로그아웃", - "slot": "슬롯 {{slotNumber}}", - "importSession": "세션 불러오기", - "importSlotSelect": "불러올 슬롯을 골라주세요.", - "exportSession": "세션 내보내기", - "exportSlotSelect": "내보낼 슬롯을 골라주세요.", - "importRunHistory":"플레이 이력 불러오기", - "exportRunHistory":"플레이 이력 내보내기", - "importData": "데이터 불러오기", - "exportData": "데이터 내보내기", - "consentPreferences": "쿠키 설정 동의", - "linkDiscord": "디스코드 연동", - "unlinkDiscord": "디스코드 연동해제", - "linkGoogle": "구글 연동", - "unlinkGoogle": "구글 연동해제", - "cancel": "취소", - "losingProgressionWarning": "전투 시작으로부터의 진행 상황을 잃게 됩니다. 계속하시겠습니까?", - "noEggs": "부화중인 알이 없습니다!" -} \ No newline at end of file diff --git a/src/locales/ko/menu.json b/src/locales/ko/menu.json deleted file mode 100644 index a9db630f7a1..00000000000 --- a/src/locales/ko/menu.json +++ /dev/null @@ -1,57 +0,0 @@ -{ - "cancel": "취소", - "continue": "계속하기", - "dailyRun": "데일리 런 (베타)", - "loadGame": "불러오기", - "newGame": "새 게임", - "settings": "설정", - "selectGameMode": "게임 모드를 선택해주세요.", - "logInOrCreateAccount": "로그인 또는 등록을 해 주세요. 개인정보를 요구하지 않습니다!", - "username": "이름", - "password": "비밀번호", - "login": "로그인", - "orUse": "혹은", - "register": "등록", - "emptyUsername": "이름은 비워둘 수 없습니다", - "invalidLoginUsername": "사용할 수 없는 이름입니다", - "invalidRegisterUsername": "이름은 알파벳, 숫자, 언더바(_)만 사용할 수 있습니다", - "invalidLoginPassword": "사용할 수 없는 비밀번호입니다", - "invalidRegisterPassword": "비밀번호는 여섯글자 이상이어야 합니다", - "usernameAlreadyUsed": "이미 사용중인 이름입니다", - "accountNonExistent": "등록되지 않은 이름입니다", - "unmatchingPassword": "비밀번호가 틀립니다", - "passwordNotMatchingConfirmPassword": "비밀번호가 일치하지 않습니다", - "confirmPassword": "비밀번호 재입력", - "registrationAgeWarning": "13세 이상입니다.", - "backToLogin": "로그인 화면으로", - "failedToLoadSaveData": "데이터를 불러올 수 없었습니다. 페이지를 새로고침해주세요.\n문제가 지속된다면, 디스코드 #Announcements 채널을 확인해주세요.", - "sessionSuccess": "세션 불러오기 성공.", - "failedToLoadSession": "세션을 불러올 수 없었습니다.\n파일이 손상되었을 수 있습니다.", - "boyOrGirl": "너는 남자니?\n아니면 여자니?", - "evolving": "…오잉!?\n{{pokemonName}}의 모습이…!", - "stoppedEvolving": "얼라리…?\n{{pokemonName}}의 변화가 멈췄다!", - "pauseEvolutionsQuestion": "{{pokemonName}}[[를]] 진화하지 않게 만드시겠습니까?\n포켓몬 화면에서 다시 활성화시킬 수 있습니다.", - "evolutionsPaused": "{{pokemonName}}의 진화가 비활성화되었다.", - "evolutionDone": "축하합니다! {{pokemonName}}[[는]]\n{{evolvedPokemonName}}[[로]] 진화했습니다!", - "dailyRankings": "일간 랭킹", - "weeklyRankings": "주간 랭킹", - "noRankings": "랭킹 정보 없음", - "positionIcon": "#", - "usernameScoreboard": "이름", - "score": "점수", - "wave": "웨이브", - "loading": "로딩 중…", - "loadingAsset": "리소스 로드 중: {{assetName}}", - "playersOnline": "플레이어 온라인", - "yes": "예", - "no": "아니오", - "disclaimer": "면책 조항", - "disclaimerDescription": "이 게임은 완전히 개발되지 않았습니다- (세이브 데이터 소실을 포함) 플레이에 지장을 주는 문제가 생길 수 있으며,\n공지 없이 업데이트가 진행 혹은 중지될 수 있습니다.", - "choosePokemon": "포켓몬을 선택하세요.", - "renamePokemon": "포켓몬의 닉네임은?", - "rename": "닉네임 바꾸기", - "nickname": "닉네임", - "errorServerDown": "서버 연결 중 문제가 발생했습니다.\n\n이 창을 종료하지 않고 두면,\n게임은 자동으로 재접속됩니다.", - "noSaves": "기기에 세이브 파일이 없습니다!", - "tooManySaves": "기기에 세이브 파일이 너무 많습니다!" -} diff --git a/src/locales/ko/modifier-select-ui-handler.json b/src/locales/ko/modifier-select-ui-handler.json deleted file mode 100644 index 04b47542e14..00000000000 --- a/src/locales/ko/modifier-select-ui-handler.json +++ /dev/null @@ -1,12 +0,0 @@ -{ - "transfer": "건네주기", - "reroll": "갱신", - "lockRarities": "희귀도 고정", - "checkTeam": "파티 확인", - "transferDesc": "지닌 물건을 다른 포켓몬에게 건네줍니다.", - "rerollDesc": "돈을 소모하여 아이템 목록을 새로 고칩니다.", - "lockRaritiesDesc": "갱신되는 아이템의 희귀도가 고정됩니다(갱신 비용 증가).", - "checkTeamDesc": "파티를 확인하거나 폼 변경 아이템을 사용합니다.", - "rerollCost": "₽{{formattedMoney}}", - "itemCost": "₽{{formattedMoney}}" -} \ No newline at end of file diff --git a/src/locales/ko/modifier-type.json b/src/locales/ko/modifier-type.json deleted file mode 100644 index e957fd0d58a..00000000000 --- a/src/locales/ko/modifier-type.json +++ /dev/null @@ -1,607 +0,0 @@ -{ - "ModifierType": { - "AddPokeballModifierType": { - "name": "{{pokeballName}} {{modifierCount}}개", - "description": "{{pokeballName}} {{modifierCount}}개 (현재: {{pokeballAmount}}개)를 획득한다.\n포획률: {{catchRate}}" - }, - "AddVoucherModifierType": { - "name": "{{voucherTypeName}} {{modifierCount}}장", - "description": "{{voucherTypeName}} {{modifierCount}}장을 획득한다." - }, - "PokemonHeldItemModifierType": { - "extra": { - "inoperable": "{{pokemonName}}[[는]]\n이 아이템을 얻을 수 없다!", - "tooMany": "{{pokemonName}}[[는]]\n이 아이템을 너무 많이 갖고 있다!" - } - }, - "PokemonHpRestoreModifierType": { - "description": "포켓몬 1마리의 HP를 {{restorePoints}} 또는 {{restorePercent}}% 중\n높은 수치만큼 회복한다.", - "extra": { - "fully": "포켓몬 1마리의 HP를 모두 회복한다.", - "fullyWithStatus": "포켓몬 1마리의 HP와 상태 이상을 모두 회복한다." - } - }, - "PokemonReviveModifierType": { - "description": "기절해 버린 포켓몬 1마리의 HP를 {{restorePercent}}%까지 회복한다." - }, - "PokemonStatusHealModifierType": { - "description": "포켓몬 1마리의 상태 이상을 모두 회복한다." - }, - "PokemonPpRestoreModifierType": { - "description": "포켓몬이 기억하고 있는 기술 중 1개의 PP를 {{restorePoints}}만큼 회복한다.", - "extra": { - "fully": "포켓몬이 기억하고 있는 기술 중 1개의 PP를 모두 회복한다." - } - }, - "PokemonAllMovePpRestoreModifierType": { - "description": "포켓몬이 기억하고 있는 4개의 기술 PP를 {{restorePoints}}씩 회복한다.", - "extra": { - "fully": "포켓몬이 기억하고 있는 4개의 기술 PP를 모두 회복한다." - } - }, - "PokemonPpUpModifierType": { - "description": "포켓몬이 기억하고 있는 기술 중 1개의 PP 최대치를 5마다 {{upPoints}}씩 상승시킨다. (최대 3)" - }, - "PokemonNatureChangeModifierType": { - "name": "{{natureName}}민트", - "description": "포켓몬의 성격을 {{natureName}}[[로]] 바꾸고 스타팅에도 등록한다." - }, - "DoubleBattleChanceBoosterModifierType": { - "description": "{{battleCount}}번의 배틀 동안 더블 배틀이 등장할 확률이 4배가 된다." - }, - "TempStatStageBoosterModifierType": { - "description": "자신의 모든 포켓몬이 5번의 배틀 동안 {{stat}}[[가]] {{amount}}단계 증가한다.", - "extra": { - "stage": "1 스테이지", - "percentage": "30%" - } - }, - "AttackTypeBoosterModifierType": { - "description": "지니게 하면 {{moveType}}타입 기술의 위력이 20% 상승한다." - }, - "PokemonLevelIncrementModifierType": { - "description": "포켓몬 1마리의 레벨이 {{levels}}만큼 상승한다." - }, - "AllPokemonLevelIncrementModifierType": { - "description": "자신의 모든 포켓몬의 레벨이 {{levels}}만큼 상승한다." - }, - "BaseStatBoosterModifierType": { - "description": "지니게 하면 {{stat}} 종족값을 10% 올려준다. 개체값이 높을수록 더 많이 누적시킬 수 있다." - }, - "AllPokemonFullHpRestoreModifierType": { - "description": "자신의 포켓몬의 HP를 모두 회복한다." - }, - "AllPokemonFullReviveModifierType": { - "description": "기절해 버린 포켓몬 전원의 HP를 완전히 회복한다." - }, - "MoneyRewardModifierType": { - "description": "{{moneyMultiplier}} 양의 돈을 획득한다. (₽{{moneyAmount}})", - "extra": { - "small": "적은", - "moderate": "적당한", - "large": "많은" - } - }, - "ExpBoosterModifierType": { - "description": "포켓몬이 받는 경험치가 {{boostPercent}}% 증가한다." - }, - "PokemonExpBoosterModifierType": { - "description": "지니게 한 포켓몬은 받는 경험치가 {{boostPercent}}% 증가한다." - }, - "PokemonFriendshipBoosterModifierType": { - "description": "배틀 승리로 얻는 친밀도가 50% 증가한다." - }, - "PokemonMoveAccuracyBoosterModifierType": { - "description": "기술의 명중률이 {{accuracyAmount}} 증가한다. (최대 100)" - }, - "PokemonMultiHitModifierType": { - "description": "지닌 개수(최대 3개)마다 추가 공격을 하는 대신, 공격력이 60%(1개)/75%(2개)/82.5%(3개)만큼 감소합니다." - }, - "TmModifierType": { - "name": "No.{{moveId}} {{moveName}}", - "description": "포켓몬에게 {{moveName}}[[를]] 가르침." - }, - "TmModifierTypeWithInfo": { - "name": "No.{{moveId}} {{moveName}}", - "description": "포켓몬에게 {{moveName}}[[를]] 가르침.\n(C 또는 Shift를 꾹 눌러 정보 확인)" - }, - "EvolutionItemModifierType": { - "description": "어느 특정 포켓몬을 진화시킨다." - }, - "FormChangeItemModifierType": { - "description": "어느 특정 포켓몬을 폼 체인지시킨다." - }, - "FusePokemonModifierType": { - "description": "두 포켓몬을 결합시킨다. (특성 변환, 종족값과 타입 분배, 기술폭 공유)" - }, - "TerastallizeModifierType": { - "name": "테라피스 {{teraType}}", - "description": "지니게 하면 10번의 배틀 동안 {{teraType}} 테라스탈타입으로 테라스탈한다." - }, - "ContactHeldItemTransferChanceModifierType": { - "description": "공격했을 때, {{chancePercent}}%의 확률로 상대의 도구를 도둑질한다." - }, - "TurnHeldItemTransferModifierType": { - "description": "매 턴, 지닌 포켓몬은 상대로부터 도구를 하나 획득한다." - }, - "EnemyAttackStatusEffectChanceModifierType": { - "description": "공격했을 때 {{statusEffect}} 상태로 만들 확률이 {{chancePercent}}% 추가된다." - }, - "EnemyEndureChanceModifierType": { - "description": "받은 공격을 버텨낼 확률이 {{chancePercent}}% 추가된다." - }, - "RARE_CANDY": { - "name": "이상한사탕" - }, - "RARER_CANDY": { - "name": "더이상한사탕" - }, - "MEGA_BRACELET": { - "name": "메가링", - "description": "메가스톤을 사용할 수 있게 된다." - }, - "DYNAMAX_BAND": { - "name": "다이맥스 밴드", - "description": "다이버섯을 사용할 수 있게 된다." - }, - "TERA_ORB": { - "name": "테라스탈오브", - "description": "테라피스를 사용할 수 있게 된다." - }, - "MAP": { - "name": "지도", - "description": "갈림길에서 목적지를 선택할 수 있다." - }, - "POTION": { - "name": "상처약" - }, - "SUPER_POTION": { - "name": "좋은상처약" - }, - "HYPER_POTION": { - "name": "고급상처약" - }, - "MAX_POTION": { - "name": "풀회복약" - }, - "FULL_RESTORE": { - "name": "회복약" - }, - "REVIVE": { - "name": "기력의조각" - }, - "MAX_REVIVE": { - "name": "기력의덩어리" - }, - "FULL_HEAL": { - "name": "만병통치제" - }, - "SACRED_ASH": { - "name": "성스러운분말" - }, - "REVIVER_SEED": { - "name": "부활의씨앗", - "description": "포켓몬이 공격을 받고 쓰러지려 할 때 HP를 절반 회복한다." - }, - "WHITE_HERB": { - "name": "하양허브", - "description": "지니게 한 포켓몬의 능력이 떨어졌을 때 원래 상태로 돌아온다." - }, - "ETHER": { - "name": "PP에이드" - }, - "MAX_ETHER": { - "name": "PP회복" - }, - "ELIXIR": { - "name": "PP에이더" - }, - "MAX_ELIXIR": { - "name": "PP맥스" - }, - "PP_UP": { - "name": "포인트업" - }, - "PP_MAX": { - "name": "포인트맥스" - }, - "LURE": { - "name": "더블배틀코롱" - }, - "SUPER_LURE": { - "name": "실버코롱" - }, - "MAX_LURE": { - "name": "골드코롱" - }, - "MEMORY_MUSHROOM": { - "name": "기억버섯", - "description": "포켓몬이 잊어버린 기술을 떠올린다." - }, - "EXP_SHARE": { - "name": "학습장치", - "description": "배틀에 참여하지 않아도 20%의 경험치를 받을 수 있게 된다." - }, - "EXP_BALANCE": { - "name": "균형학습장치", - "description": "레벨이 낮은 포켓몬이 받는 경험치를 가중시킨다." - }, - "OVAL_CHARM": { - "name": "둥근부적", - "description": "여러 마리의 포켓몬이 배틀에 참여할 경우, 전체 경험치의 10%씩을 추가로 획득한다." - }, - "EXP_CHARM": { - "name": "경험부적" - }, - "SUPER_EXP_CHARM": { - "name": "좋은경험부적" - }, - "GOLDEN_EXP_CHARM": { - "name": "황금경험부적" - }, - "LUCKY_EGG": { - "name": "행복의알" - }, - "GOLDEN_EGG": { - "name": "황금의알" - }, - "SOOTHE_BELL": { - "name": "평온의방울" - }, - "SCOPE_LENS": { - "name": "초점렌즈", - "description": "약점이 보이는 렌즈. 지니게 한 포켓몬의 기술이 급소에 맞기 쉬워진다." - }, - "DIRE_HIT": { - "name": "크리티컬커터", - "extra": { - "raises": "급소율" - } - }, - "LEEK": { - "name": "대파", - "description": "매우 길고 단단한 줄기. 파오리에게 지니게 하면 기술이 급소에 맞기 쉬워진다." - }, - "EVIOLITE": { - "name": "진화의휘석", - "description": "진화의 이상한 덩어리. 지니게 하면 진화 전 포켓몬의 방어와 특수방어가 올라간다." - }, - "SOUL_DEW": { - "name": "마음의물방울", - "description": "지닌 포켓몬의 성격의 효과가 10% 증가한다. (합연산)" - }, - "NUGGET": { - "name": "금구슬" - }, - "BIG_NUGGET": { - "name": "큰금구슬" - }, - "RELIC_GOLD": { - "name": "고대의금화" - }, - "AMULET_COIN": { - "name": "부적금화", - "description": "받는 돈이 20% 증가한다." - }, - "GOLDEN_PUNCH": { - "name": "골든펀치", - "description": "주는 데미지의 50%만큼 돈을 획득한다." - }, - "COIN_CASE": { - "name": "동전케이스", - "description": "매 열 번째 배틀마다, 가진 돈의 10%를 이자로 획득한다." - }, - "LOCK_CAPSULE": { - "name": "록캡슐", - "description": "받을 아이템을 갱신할 때 희귀도를 고정시킬 수 있게 된다." - }, - "GRIP_CLAW": { - "name": "끈기갈고리손톱" - }, - "WIDE_LENS": { - "name": "광각렌즈" - }, - "MULTI_LENS": { - "name": "멀티렌즈" - }, - "HEALING_CHARM": { - "name": "치유의부적", - "description": "HP를 회복하는 기술이나 도구를 썼을 때 효율이 10% 증가한다. (부활 제외)" - }, - "CANDY_JAR": { - "name": "사탕단지", - "description": "이상한사탕 종류의 아이템이 올려주는 레벨이 1 증가한다." - }, - "BERRY_POUCH": { - "name": "열매주머니", - "description": "사용한 나무열매가 소모되지 않을 확률이 30% 추가된다." - }, - "FOCUS_BAND": { - "name": "기합의머리띠", - "description": "기절할 듯한 데미지를 받아도 HP를 1 남겨서 견딜 확률이 10% 추가된다." - }, - "QUICK_CLAW": { - "name": "선제공격손톱", - "description": "상대보다 먼저 행동할 수 있게 될 확률이 10% 추가된다. (우선도 처리 이후)" - }, - "KINGS_ROCK": { - "name": "왕의징표석", - "description": "공격해서 데미지를 줄 때 상대를 풀죽일 확률이 10% 추가된다." - }, - "LEFTOVERS": { - "name": "먹다남은음식", - "description": "포켓몬의 HP가 매 턴 최대 체력의 1/16씩 회복된다." - }, - "SHELL_BELL": { - "name": "조개껍질방울", - "description": "포켓몬이 준 데미지의 1/8씩을 회복한다." - }, - "TOXIC_ORB": { - "name": "맹독구슬", - "description": "이 도구를 지닌 포켓몬은 턴이 끝나는 시점에 상태이상에 걸리지 않았다면 맹독 상태가 된다." - }, - "FLAME_ORB": { - "name": "화염구슬", - "description": "이 도구를 지닌 포켓몬은 턴이 끝나는 시점에 상태이상에 걸리지 않았다면 화상 상태가 된다." - }, - "BATON": { - "name": "바톤", - "description": "포켓몬을 교체할 때 효과를 넘겨줄 수 있으며, 함정의 영향을 받지 않게 함" - }, - "SHINY_CHARM": { - "name": "빛나는부적", - "description": "야생 포켓몬이 색이 다른 포켓몬으로 등장할 확률을 급격히 높인다." - }, - "ABILITY_CHARM": { - "name": "특성부적", - "description": "야생 포켓몬이 숨겨진 특성을 가지고 등장할 확률을 급격히 높인다." - }, - "IV_SCANNER": { - "name": "개체값탐지기", - "description": "야생 포켓몬의 개체값을 확인 가능하다. 높은 값부터, 확인할 수 있는 개체값이 두 종류씩 추가된다." - }, - "DNA_SPLICERS": { - "name": "유전자쐐기" - }, - "MINI_BLACK_HOLE": { - "name": "미니 블랙홀" - }, - "GOLDEN_POKEBALL": { - "name": "황금몬스터볼", - "description": "전투 후 획득하는 아이템의 선택지가 하나 더 늘어난다." - }, - "ENEMY_DAMAGE_BOOSTER": { - "name": "데미지 토큰", - "description": "주는 데미지를 5% 증가시킨다." - }, - "ENEMY_DAMAGE_REDUCTION": { - "name": "보호 토큰", - "description": "받는 데미지를 2.5% 감소시킨다." - }, - "ENEMY_HEAL": { - "name": "회복 토큰", - "description": "매 턴 최대 체력의 2%를 회복한다." - }, - "ENEMY_ATTACK_POISON_CHANCE": { - "name": "독 토큰" - }, - "ENEMY_ATTACK_PARALYZE_CHANCE": { - "name": "마비 토큰" - }, - "ENEMY_ATTACK_BURN_CHANCE": { - "name": "화상 토큰" - }, - "ENEMY_STATUS_EFFECT_HEAL_CHANCE": { - "name": "만병통치 토큰", - "description": "매 턴 상태이상에서 회복될 확률이 2.5% 추가된다." - }, - "ENEMY_ENDURE_CHANCE": { - "name": "버티기 토큰" - }, - "ENEMY_FUSED_CHANCE": { - "name": "합체 토큰", - "description": "야생 포켓몬이 합체되어 등장할 확률이 1% 추가된다." - } - }, - "SpeciesBoosterItem": { - "LIGHT_BALL": { - "name": "전기구슬", - "description": "피카츄에게 지니게 하면 공격과 특수공격이 올라가는 이상한 구슬." - }, - "THICK_CLUB": { - "name": "굵은뼈", - "description": "무언가의 단단한 뼈. 탕구리 혹은 텅구리에게 지니게 하면 공격이 올라간다." - }, - "METAL_POWDER": { - "name": "금속파우더", - "description": "메타몽에게 지니게 하면 방어가 올라가는 이상한 가루. 매우 잘고 단단하다." - }, - "QUICK_POWDER": { - "name": "스피드파우더", - "description": "메타몽에게 지니게 하면 스피드가 올라가는 이상한 가루. 매우 잘고 단단하다." - } - }, - "TempStatStageBoosterItem": { - "x_attack": "플러스파워", - "x_defense": "디펜드업", - "x_sp_atk": "스페셜업", - "x_sp_def": "스페셜가드", - "x_speed": "스피드업", - "x_accuracy": "잘-맞히기" - }, - "AttackTypeBoosterItem": { - "silk_scarf": "실크스카프", - "black_belt": "검은띠", - "sharp_beak": "예리한부리", - "poison_barb": "독바늘", - "soft_sand": "부드러운모래", - "hard_stone": "딱딱한돌", - "silver_powder": "은빛가루", - "spell_tag": "저주의부적", - "metal_coat": "금속코트", - "charcoal": "목탄", - "mystic_water": "신비의물방울", - "miracle_seed": "기적의씨", - "magnet": "자석", - "twisted_spoon": "휘어진스푼", - "never_melt_ice": "녹지않는얼음", - "dragon_fang": "용의이빨", - "black_glasses": "검은안경", - "fairy_feather": "요정의깃털" - }, - "BaseStatBoosterItem": { - "hp_up": "맥스업", - "protein": "타우린", - "iron": "사포닌", - "calcium": "리보플라빈", - "zinc": "키토산", - "carbos": "알칼로이드" - }, - "EvolutionItem": { - "NONE": "None", - "LINKING_CORD": "연결의끈", - "SUN_STONE": "태양의돌", - "MOON_STONE": "달의돌", - "LEAF_STONE": "리프의돌", - "FIRE_STONE": "불꽃의돌", - "WATER_STONE": "물의돌", - "THUNDER_STONE": "천둥의돌", - "ICE_STONE": "얼음의돌", - "DUSK_STONE": "어둠의돌", - "DAWN_STONE": "각성의돌", - "SHINY_STONE": "빛의돌", - "CRACKED_POT": "깨진포트", - "SWEET_APPLE": "달콤한사과", - "TART_APPLE": "새콤한사과", - "STRAWBERRY_SWEET": "딸기사탕공예", - "UNREMARKABLE_TEACUP": "범작찻잔", - "CHIPPED_POT": "이빠진포트", - "BLACK_AUGURITE": "검은휘석", - "GALARICA_CUFF": "가라두구팔찌", - "GALARICA_WREATH": "가라두구머리장식", - "PEAT_BLOCK": "피트블록", - "AUSPICIOUS_ARMOR": "축복받은갑옷", - "MALICIOUS_ARMOR": "저주받은갑옷", - "MASTERPIECE_TEACUP": "걸작찻잔", - "METAL_ALLOY": "복합금속", - "SCROLL_OF_DARKNESS": "악의 족자", - "SCROLL_OF_WATERS": "물의 족자", - "SYRUPY_APPLE": "꿀맛사과" - }, - "FormChangeItem": { - "NONE": "None", - "ABOMASITE": "눈설왕나이트", - "ABSOLITE": "앱솔나이트", - "AERODACTYLITE": "프테라나이트", - "AGGRONITE": "보스로라나이트", - "ALAKAZITE": "후딘나이트", - "ALTARIANITE": "파비코리나이트", - "AMPHAROSITE": "전룡나이트", - "AUDINITE": "다부니나이트", - "BANETTITE": "다크펫나이트", - "BEEDRILLITE": "독침붕나이트", - "BLASTOISINITE": "거북왕나이트", - "BLAZIKENITE": "번치코나이트", - "CAMERUPTITE": "폭타나이트", - "CHARIZARDITE_X": "리자몽나이트 X", - "CHARIZARDITE_Y": "리자몽나이트 Y", - "DIANCITE": "디안시나이트", - "GALLADITE": "엘레이드나이트", - "GARCHOMPITE": "한카리아스나이트", - "GARDEVOIRITE": "가디안나이트", - "GENGARITE": "팬텀나이트", - "GLALITITE": "얼음귀신나이트", - "GYARADOSITE": "갸라도스나이트", - "HERACRONITE": "헤라크로스나이트", - "HOUNDOOMINITE": "헬가나이트", - "KANGASKHANITE": "캥카나이트", - "LATIASITE": "라티아스나이트", - "LATIOSITE": "라티오스나이트", - "LOPUNNITE": "이어롭나이트", - "LUCARIONITE": "루카리오나이트", - "MANECTITE": "썬더볼트나이트", - "MAWILITE": "입치트나이트", - "MEDICHAMITE": "요가램나이트", - "METAGROSSITE": "메타그로스나이트", - "MEWTWONITE_X": "뮤츠나이트 X", - "MEWTWONITE_Y": "뮤츠나이트 Y", - "PIDGEOTITE": "피죤투나이트", - "PINSIRITE": "쁘사이저나이트", - "RAYQUAZITE": "레쿠쟈나이트", - "SABLENITE": "깜까미나이트", - "SALAMENCITE": "보만다나이트", - "SCEPTILITE": "나무킹나이트", - "SCIZORITE": "핫삼나이트", - "SHARPEDONITE": "샤크니아나이트", - "SLOWBRONITE": "야도란나이트", - "STEELIXITE": "강철톤나이트", - "SWAMPERTITE": "대짱이나이트", - "TYRANITARITE": "마기라스나이트", - "VENUSAURITE": "이상해꽃나이트", - "BLUE_ORB": "쪽빛구슬", - "RED_ORB": "주홍구슬", - "SHARP_METEORITE": "뾰족한운석", - "HARD_METEORITE": "단단한운석", - "SMOOTH_METEORITE": "부드러운운석", - "ADAMANT_CRYSTAL": "큰금강옥", - "LUSTROUS_GLOBE": "큰백옥", - "GRISEOUS_CORE": "큰백금옥", - "REVEAL_GLASS": "비추는거울", - "GRACIDEA": "그라시데아꽃", - "MAX_MUSHROOMS": "다이버섯", - "DARK_STONE": "다크스톤", - "LIGHT_STONE": "라이트스톤", - "PRISON_BOTTLE": "굴레의항아리", - "N_LUNARIZER": "네크로플러스루나", - "N_SOLARIZER": "네크로플러스솔", - "RUSTED_SWORD": "녹슨검", - "RUSTED_SHIELD": "녹슨방패", - "ICY_REINS_OF_UNITY": "차가운유대의고삐", - "SHADOW_REINS_OF_UNITY": "검은유대의고삐", - "WELLSPRING_MASK": "우물의가면", - "HEARTHFLAME_MASK": "화덕의가면", - "CORNERSTONE_MASK": "주춧돌의가면", - "SHOCK_DRIVE": "번개카세트", - "BURN_DRIVE": "블레이즈카세트", - "CHILL_DRIVE": "프리즈카세트", - "DOUSE_DRIVE": "아쿠아카세트", - "ULTRANECROZIUM_Z": "울트라네크로Z", - "FIST_PLATE": "주먹플레이트", - "SKY_PLATE": "푸른하늘플레이트", - "TOXIC_PLATE": "맹독플레이트", - "EARTH_PLATE": "대지플레이트", - "STONE_PLATE": "암석플레이트", - "INSECT_PLATE": "비단벌레플레이트", - "SPOOKY_PLATE": "원령플레이트", - "IRON_PLATE": "강철플레이트", - "FLAME_PLATE": "불구슬플레이트", - "SPLASH_PLATE": "물방울플레이트", - "MEADOW_PLATE": "초록플레이트", - "ZAP_PLATE": "우뢰플레이트", - "MIND_PLATE": "이상한플레이트", - "ICICLE_PLATE": "고드름플레이트", - "DRACO_PLATE": "용의플레이트", - "DREAD_PLATE": "공포플레이트", - "PIXIE_PLATE": "정령플레이트", - "BLANK_PLATE": "순백플레이트", - "LEGEND_PLATE": "레전드플레이트", - "FIGHTING_MEMORY": "파이팅메모리", - "FLYING_MEMORY": "플라잉메모리", - "POISON_MEMORY": "포이즌메모리", - "GROUND_MEMORY": "그라운드메모리", - "ROCK_MEMORY": "록메모리", - "BUG_MEMORY": "버그메모리", - "GHOST_MEMORY": "고스트메모리", - "STEEL_MEMORY": "스틸메모리", - "FIRE_MEMORY": "파이어메모리", - "WATER_MEMORY": "워터메모리", - "GRASS_MEMORY": "그래스메모리", - "ELECTRIC_MEMORY": "일렉트릭메모리", - "PSYCHIC_MEMORY": "사이킥메모리", - "ICE_MEMORY": "아이스메모리", - "DRAGON_MEMORY": "드래곤메모리", - "DARK_MEMORY": "다크메모리", - "FAIRY_MEMORY": "페어리메모리", - "NORMAL_MEMORY": "일반메모리" - } -} diff --git a/src/locales/ko/modifier.json b/src/locales/ko/modifier.json deleted file mode 100644 index b04e51f30cb..00000000000 --- a/src/locales/ko/modifier.json +++ /dev/null @@ -1,12 +0,0 @@ -{ - "surviveDamageApply": "{{pokemonNameWithAffix}}[[는]]\n{{typeName}}[[로]] 버텼다!!", - "turnHealApply": "{{pokemonNameWithAffix}}[[는]]\n{{typeName}}[[로]] 인해 조금 회복했다.", - "hitHealApply": "{{pokemonNameWithAffix}}[[는]]\n{{typeName}}[[로]] 인해 조금 회복했다.", - "pokemonInstantReviveApply": "{{pokemonNameWithAffix}}[[는]] {{typeName}}[[로]]\n정신을 차려 싸울 수 있게 되었다!", - "resetNegativeStatStageApply": "{{pokemonNameWithAffix}}[[는]] {{typeName}}[[로]]\n상태를 원래대로 되돌렸다!", - "moneyInterestApply": "{{typeName}}[[로]]부터\n₽{{moneyAmount}}[[를]] 받았다!", - "turnHeldItemTransferApply": "{{pokemonName}}의 {{typeName}}[[는]]\n{{pokemonNameWithAffix}}의 {{itemName}}[[를]] 흡수했다!", - "contactHeldItemTransferApply": "{{pokemonName}}의 {{typeName}}[[는]]\n{{pokemonNameWithAffix}}의 {{itemName}}[[를]] 가로챘다!", - "enemyTurnHealApply": "{{pokemonNameWithAffix}}의\n체력이 약간 회복되었다!", - "bypassSpeedChanceApply": "{{pokemonName}}[[는]] {{itemName}}[[로]]\n행동이 빨라졌다!" -} diff --git a/src/locales/ko/move-trigger.json b/src/locales/ko/move-trigger.json deleted file mode 100644 index a8a6c0cf86f..00000000000 --- a/src/locales/ko/move-trigger.json +++ /dev/null @@ -1,72 +0,0 @@ -{ - "hitWithRecoil": "{{pokemonName}}[[는]]\n반동으로 데미지를 입었다!", - "cutHpPowerUpMove": "{{pokemonName}}[[는]]\n체력을 깎아서 자신의 기술을 강화했다!", - "absorbedElectricity": "{{pokemonName}}는(은)\n전기를 흡수했다!", - "switchedStatChanges": "{{pokemonName}}[[는]] 상대와 자신의\n능력 변화를 바꿨다!", - "switchedTwoStatChanges": "{{pokemonName}} 상대와 자신의 {{firstStat}}과 {{secondStat}}의 능력 변화를 바꿨다!", - "switchedStat": "{{pokemonName}}[[는]] 서로의 {{stat}}[[를]] 교체했다!", - "sharedGuard": "{{pokemonName}}[[는]] 서로의 가드를 셰어했다!", - "sharedPower": "{{pokemonName}}[[는]] 서로의 파워를 셰어했다!", - "shiftedStats": "{{pokemonName}}[[는]] {{statToSwitch}}[[와]] {{statToSwitchWith}}[[를]] 바꿨다!", - "goingAllOutForAttack": "{{pokemonName}}[[는]]\n전력을 다하기 시작했다!", - "regainedHealth": "{{pokemonName}}[[는]]\n기력을 회복했다!", - "keptGoingAndCrashed": "{{pokemonName}}[[는]]\n의욕이 넘쳐서 땅에 부딪쳤다!", - "fled": "{{pokemonName}}[[는]]\n도망쳤다!", - "cannotBeSwitchedOut": "{{pokemonName}}[[를]]\n돌아오게 할 수 없습니다!", - "swappedAbilitiesWithTarget": "{{pokemonName}}[[는]]\n서로의 특성을 교체했다!", - "coinsScatteredEverywhere": "돈이 주위에 흩어졌다!", - "attackedByItem": "{{itemName}}[[가]]\n{{pokemonName}}에게 덤벼들었다!", - "whippedUpAWhirlwind": "{{pokemonName}}의 주위에서\n공기가 소용돌이친다!", - "flewUpHigh": "{{pokemonName}}는(은)\n하늘 높이 날아올랐다!", - "tookInSunlight": "{{pokemonName}}는(은)\n빛을 흡수했다!", - "dugAHole": "{{pokemonName}}는(은)\n땅으로 파고들었다!", - "loweredItsHead": "{{pokemonName}}는(은)\n목을 움츠렸다!", - "isGlowing": "{{pokemonName}}를(을)\n강렬한 빛이 감쌌다!", - "bellChimed": "방울소리가 울려 퍼졌다!", - "foresawAnAttack": "{{pokemonName}}는(은)\n미래의 공격을 예지했다!", - "isTighteningFocus": "{{pokemonName}}[[는]]\n집중력을 높이고 있다!", - "hidUnderwater": "{{pokemonName}}는(은)\n물속에 몸을 숨겼다!", - "soothingAromaWaftedThroughArea": "기분 좋은 향기가 퍼졌다!", - "sprangUp": "{{pokemonName}}는(은)\n높이 뛰어올랐다!", - "choseDoomDesireAsDestiny": "{{pokemonName}}는(은)\n파멸의소원을 미래에 맡겼다!", - "vanishedInstantly": "{{pokemonName}}의 모습이\n일순간에 사라졌다!", - "tookTargetIntoSky": "{{pokemonName}}는(은) {{targetName}}를(을)\n상공으로 데려갔다!", - "becameCloakedInFreezingLight": "{{pokemonName}}는(은)\n차가운 빛에 둘러싸였다!", - "becameCloakedInFreezingAir": "{{pokemonName}}는(은)\n차디찬 공기에 둘러싸였다!", - "isChargingPower": "{{pokemonName}}는(은)\n파워를 모으고 있다!", - "burnedItselfOut": "{{pokemonName}}의 불꽃은 다 타 버렸다!", - "startedHeatingUpBeak": "{{pokemonName}}는(은)\n부리를 가열하기 시작했다!", - "setUpShellTrap": "{{pokemonName}}[[는]]\n트랩셸을 설치했다!", - "isOverflowingWithSpacePower": "{{pokemonName}}에게서\n우주의 힘이 넘쳐난다!", - "usedUpAllElectricity": "{{pokemonName}}[[는]]\n전기를 다 써 버렸다!", - "stoleItem": "{{pokemonName}}[[는]] {{targetName}}[[로]]부터\n{{itemName}}[[을]] 빼앗았다!", - "incineratedItem": "{{pokemonName}}[[는]] {{targetName}}의\n{{itemName}}[[를]] 불태워서 없애버렸다!", - "knockedOffItem": "{{pokemonName}}[[는]] {{targetName}}의\n{{itemName}}[[를]] 탁 쳐서 떨구었다!", - "tookMoveAttack": "{{pokemonName}}[[는]]\n{{moveName}} 공격을 끌어들였다!", - "cutOwnHpAndMaximizedStat": "{{pokemonName}}[[는]] 체력을 깎아서\n{{statName}}[[를]] 풀 파워로 만들었다!", - "copiedStatChanges": "{{pokemonName}}[[는]] {{targetName}}의\n능력 변화를 복사했다!", - "magnitudeMessage": "매그니튜드{{magnitude}}!", - "tookAimAtTarget": "{{pokemonName}}[[는]] 목표를\n{{targetName}}[[로]] 결정했다!", - "transformedIntoType": "{{pokemonName}}[[는]]\n{{typeName}}타입이 됐다!", - "copiedMove": "{{pokemonName}}[[는]]\n{{moveName}}[[를]] 복사했다!", - "sketchedMove": "{{pokemonName}}[[는]]\n{{moveName}}[[를]] 스케치했다!", - "acquiredAbility": "{{pokemonName}}[[는]]\n{{abilityName}}[[가]] 되었다!", - "copiedTargetAbility": "{{pokemonName}}[[는]] {{targetName}}의\n{{abilityName}}[[를]] 복사했다!", - "transformedIntoTarget": "{{pokemonName}}[[는]]\n{{targetName}}[[로]] 변신했다!", - "tryingToTakeFoeDown": "{{pokemonName}}[[는]] 상대를\n길동무로 삼으려 하고 있다!", - "addType": "{{pokemonName}}에게\n{{typeName}}타입이 추가되었다!", - "cannotUseMove": "{{pokemonName}}[[는]]\n{{moveName}}[[를]] 쓸 수 없다!", - "healHp": "{{pokemonName}}의\n체력이 회복되었다!", - "sacrificialFullRestore": "{{pokemonName}}의\n치유소원이 이루어졌다!", - "invertStats": "{{pokemonName}}[[는]]\n능력 변화가 뒤집혔다!", - "resetStats": "{{pokemonName}}의 모든 상태가\n원래대로 되돌아왔다!", - "statEliminated": "모든 상태가 원래대로 되돌아왔다!", - "faintCountdown": "{{pokemonName}}[[는]]\n{{turnCount}}턴 후에 쓰러져 버린다!", - "copyType": "{{pokemonName}}[[는]]\n{{targetPokemonName}}[[와]] 같은 타입이 되었다!", - "suppressAbilities": "{{pokemonName}}의\n특성이 효과를 발휘하지 못하게 되었다!", - "revivalBlessing": "{{pokemonName}}[[는]]\n정신을 차려 싸울 수 있게 되었다!", - "swapArenaTags": "{{pokemonName}}[[는]]\n서로의 필드 효과를 교체했다!", - "exposedMove": "{{pokemonName}}[[는]]\n{{targetPokemonName}}의 정체를 꿰뚫어 보았다!", - "safeguard": "{{targetName}}[[는]] 신비의 베일이 지켜 주고 있다!", - "afterYou": "{{pokemonName}}[[는]]\n배려를 받아들이기로 했다!" -} diff --git a/src/locales/ko/move.json b/src/locales/ko/move.json deleted file mode 100644 index a06bb2b3e27..00000000000 --- a/src/locales/ko/move.json +++ /dev/null @@ -1,3810 +0,0 @@ -{ - "pound": { - "name": "막치기", - "effect": "긴 꼬리나 손 등을 사용하여 상대를 때려서 공격한다." - }, - "karateChop": { - "name": "태권당수", - "effect": "날카로운 당수로 상대를 때려서 공격한다. 급소에 맞기 쉽다." - }, - "doubleSlap": { - "name": "연속뺨치기", - "effect": "연속 뺨치기로 상대를 때려서 공격한다. 2-5회 동안 연속으로 쓴다." - }, - "cometPunch": { - "name": "연속펀치", - "effect": "노도 같은 펀치로 상대를 세게 때려서 공격한다. 2-5회 동안 연속으로 쓴다." - }, - "megaPunch": { - "name": "메가톤펀치", - "effect": "힘을 담은 펀치로 상대를 공격한다." - }, - "payDay": { - "name": "고양이돈받기", - "effect": "상대의 몸에 돈을 세게 던져서 공격한다. 배틀 후에 돈을 받을 수 있다." - }, - "firePunch": { - "name": "불꽃펀치", - "effect": "불꽃을 담은 펀치로 상대를 공격한다. 화상 상태로 만들 때가 있다." - }, - "icePunch": { - "name": "냉동펀치", - "effect": "냉기를 담은 펀치로 상대를 공격한다. 얼음 상태로 만들 때가 있다." - }, - "thunderPunch": { - "name": "번개펀치", - "effect": "전격을 담은 펀치로 상대를 공격한다. 마비 상태로 만들 때가 있다." - }, - "scratch": { - "name": "할퀴기", - "effect": "단단하고 뾰족한 날카로운 손톱으로 상대를 할퀴어서 공격한다." - }, - "viseGrip": { - "name": "찝기", - "effect": "상대를 양쪽에서 집어서 데미지를 준다." - }, - "guillotine": { - "name": "가위자르기", - "effect": "큰 집게로 상대를 베어 갈라 공격한다. 맞으면 일격에 기절한다." - }, - "razorWind": { - "name": "칼바람", - "effect": "바람의 칼날을 만들어 2턴째에 상대를 공격한다. 급소에 맞기 쉽다." - }, - "swordsDance": { - "name": "칼춤", - "effect": "싸움의 춤을 격렬하게 춰서 기세를 높인다. 자신의 공격을 크게 올린다." - }, - "cut": { - "name": "풀베기", - "effect": "낫이나 발톱 등으로 상대를 베어 공격한다." - }, - "gust": { - "name": "바람일으키기", - "effect": "날개로 일으킨 격한 바람을 상대에게 부딪쳐서 공격한다." - }, - "wingAttack": { - "name": "날개치기", - "effect": "크게 펼친 훌륭한 날개를 상대에게 부딪쳐서 공격한다." - }, - "whirlwind": { - "name": "날려버리기", - "effect": "상대를 날려버려서 교대할 포켓몬을 끌어낸다. 야생의 경우에는 배틀이 끝난다." - }, - "fly": { - "name": "공중날기", - "effect": "1턴째에 하늘을 날아 2턴째에 상대를 공격한다." - }, - "bind": { - "name": "조이기", - "effect": "긴 몸이나 덩굴 등을 써서 4-5턴 동안 상대를 조여 공격한다." - }, - "slam": { - "name": "힘껏치기", - "effect": "긴 꼬리나 덩굴 등을 사용해 상대를 힘껏 쳐서 공격한다." - }, - "vineWhip": { - "name": "덩굴채찍", - "effect": "채찍처럼 휘어지는 가늘고 긴 덩굴로 상대를 힘껏 쳐서 공격한다." - }, - "stomp": { - "name": "짓밟기", - "effect": "큰 발로 상대를 짓밟아서 공격한다. 상대를 풀죽게 만들 때가 있다." - }, - "doubleKick": { - "name": "두번차기", - "effect": "2개의 다리로 상대를 걷어차서 공격한다. 2회 연속으로 데미지를 준다." - }, - "megaKick": { - "name": "메가톤킥", - "effect": "굉장한 힘을 담은 킥으로 상대를 걷어차서 공격한다." - }, - "jumpKick": { - "name": "점프킥", - "effect": "높이 점프해서 킥으로 상대를 공격한다. 빗나가면 자신이 데미지를 입는다." - }, - "rollingKick": { - "name": "돌려차기", - "effect": "몸을 재빨리 회전시키며 걷어차서 공격한다. 상대를 풀죽게 만들 때가 있다." - }, - "sandAttack": { - "name": "모래뿌리기", - "effect": "상대의 얼굴에 모래를 뿌려서 명중률을 떨어뜨린다." - }, - "headbutt": { - "name": "박치기", - "effect": "머리를 내밀어 곧장 돌진하여 공격한다. 상대를 풀죽게 만들 때가 있다." - }, - "hornAttack": { - "name": "뿔찌르기", - "effect": "날카롭고 뾰족한 뿔로 상대를 공격한다." - }, - "furyAttack": { - "name": "마구찌르기", - "effect": "뿔이나 부리로 상대를 찔러서 공격한다. 2-5회 동안 연속으로 쓴다." - }, - "hornDrill": { - "name": "뿔드릴", - "effect": "회전하는 뿔을 상대에게 꿰찔러서 공격한다. 맞으면 일격에 기절한다." - }, - "tackle": { - "name": "몸통박치기", - "effect": "상대를 향해서 몸 전체를 부딪쳐가며 공격한다." - }, - "bodySlam": { - "name": "누르기", - "effect": "몸 전체로 상대를 덮쳐눌러 공격한다. 마비 상태로 만들 때가 있다." - }, - "wrap": { - "name": "김밥말이", - "effect": "긴 몸이나 덩굴 등을 사용해 4-5턴 동안 상대를 휘감아 공격한다." - }, - "takeDown": { - "name": "돌진", - "effect": "굉장한 기세로 상대에게 부딪쳐 공격한다. 자신도 조금 데미지를 입는다." - }, - "thrash": { - "name": "난동부리기", - "effect": "2-3턴 동안 마구 난동 부려서 공격한다. 난동 부린 뒤에는 혼란에 빠진다." - }, - "doubleEdge": { - "name": "이판사판태클", - "effect": "목숨을 걸고 상대에게 돌진하여 공격을 한다. 자신도 상당한 데미지를 입는다." - }, - "tailWhip": { - "name": "꼬리흔들기", - "effect": "꼬리를 좌우로 귀엽게 흔들어 방심을 유도한다. 상대의 방어를 떨어뜨린다." - }, - "poisonSting": { - "name": "독침", - "effect": "독이 있는 침을 상대에게 꿰찔러서 공격한다. 독 상태로 만들 때가 있다." - }, - "twineedle": { - "name": "더블니들", - "effect": "2개의 침을 상대에게 꿰찔러 2회 연속으로 데미지를 준다. 독 상태로 만들 때가 있다." - }, - "pinMissile": { - "name": "바늘미사일", - "effect": "날카로운 침을 상대에게 발사해서 공격한다. 2-5회 동안 연속으로 쓴다." - }, - "leer": { - "name": "째려보기", - "effect": "날카로운 눈초리로 겁을 주어 상대의 방어를 떨어뜨린다." - }, - "bite": { - "name": "물기", - "effect": "날카롭고 뾰족한 이빨로 물어서 공격한다. 상대를 풀죽게 만들 때가 있다." - }, - "growl": { - "name": "울음소리", - "effect": "귀여운 울음소리를 들려주고 관심을 끌어 방심한 사이에 상대의 공격을 떨어뜨린다." - }, - "roar": { - "name": "울부짖기", - "effect": "상대를 도망가게 해서 교대할 포켓몬을 끌어낸다. 야생의 경우에는 배틀이 끝난다." - }, - "sing": { - "name": "노래하기", - "effect": "기분 좋은 예쁜 노랫소리를 들려주고 상대를 잠듦 상태로 만든다." - }, - "supersonic": { - "name": "초음파", - "effect": "특수한 음파를 몸에서 발산하여 상대를 혼란시킨다." - }, - "sonicBoom": { - "name": "소닉붐", - "effect": "충격파를 상대에 부딪쳐서 공격한다. 언제나 20의 데미지를 준다." - }, - "disable": { - "name": "사슬묶기", - "effect": "상대의 움직임을 막아 바로 전에 쓴 기술을 4턴 동안 사용할 수 없게 만든다." - }, - "acid": { - "name": "용해액", - "effect": "강한 산을 상대에게 끼얹어 공격한다. 상대의 특수방어를 떨어뜨릴 때가 있다." - }, - "ember": { - "name": "불꽃세례", - "effect": "작은 불꽃을 상대에게 발사하여 공격한다. 화상 상태로 만들 때가 있다." - }, - "flamethrower": { - "name": "화염방사", - "effect": "세찬 불꽃을 상대에게 발사하여 공격한다. 화상 상태로 만들 때가 있다." - }, - "mist": { - "name": "흰안개", - "effect": "하얀 안개로 몸을 덮는다. 5턴 동안 상대에 의해 능력이 떨어지지 않게 된다." - }, - "waterGun": { - "name": "물대포", - "effect": "물을 기세 좋게 상대에게 발사하여 공격한다." - }, - "hydroPump": { - "name": "하이드로펌프", - "effect": "대량의 물을 세찬 기세로 상대에게 발사하여 공격한다." - }, - "surf": { - "name": "파도타기", - "effect": "큰 파도로 자신의 주위에 있는 포켓몬을 공격한다." - }, - "iceBeam": { - "name": "냉동빔", - "effect": "냉동빔을 상대에게 발사하여 공격한다. 얼음 상태로 만들 때가 있다." - }, - "blizzard": { - "name": "눈보라", - "effect": "세찬 눈보라를 상대에게 내뿜어 공격한다. 얼음 상태로 만들 때가 있다." - }, - "psybeam": { - "name": "환상빔", - "effect": "이상한 광선을 상대에게 발사하여 공격한다. 혼란시킬 때가 있다." - }, - "bubbleBeam": { - "name": "거품광선", - "effect": "거품을 기세 좋게 상대에게 발사하여 공격한다. 스피드를 떨어뜨릴 때가 있다." - }, - "auroraBeam": { - "name": "오로라빔", - "effect": "무지개색의 빔을 상대에게 발사하여 공격한다. 공격을 떨어뜨릴 때가 있다." - }, - "hyperBeam": { - "name": "파괴광선", - "effect": "강한 광선을 상대에게 발사하여 공격한다. 다음 턴은 움직일 수 없다." - }, - "peck": { - "name": "쪼기", - "effect": "날카롭고 뾰족한 부리나 뿔로 상대를 쪼아서 공격한다." - }, - "drillPeck": { - "name": "회전부리", - "effect": "회전하면서 뾰족한 부리를 상대에게 꿰찔러 공격한다." - }, - "submission": { - "name": "지옥의바퀴", - "effect": "땅에 자신과 함께 상대를 내던져 공격한다. 자신도 조금 데미지를 입는다." - }, - "lowKick": { - "name": "안다리걸기", - "effect": "발을 강하게 걸고 상대를 넘어뜨려 공격한다. 상대가 무거울수록 위력이 올라간다." - }, - "counter": { - "name": "카운터", - "effect": "상대로부터 받은 물리공격의 데미지를 2배로 만들어 같은 상대에게 돌려준다." - }, - "seismicToss": { - "name": "지구던지기", - "effect": "인력을 사용해 내던진다. 자신의 레벨과 똑같은 데미지를 상대에게 준다." - }, - "strength": { - "name": "괴력", - "effect": "혼신의 힘으로 상대를 세게 때려서 공격한다." - }, - "absorb": { - "name": "흡수", - "effect": "양분을 흡수하여 공격한다. 입힌 데미지의 절반에 해당하는 HP를 회복할 수 있다." - }, - "megaDrain": { - "name": "메가드레인", - "effect": "양분을 흡수하여 공격한다. 입힌 데미지의 절반에 해당하는 HP를 회복할 수 있다." - }, - "leechSeed": { - "name": "씨뿌리기", - "effect": "씨가 뿌려진 상대의 HP를 매 턴 조금씩 흡수하여 자신의 HP를 회복한다." - }, - "growth": { - "name": "성장", - "effect": "몸을 일시에 크게 성장시켜 공격과 특수공격을 올린다." - }, - "razorLeaf": { - "name": "잎날가르기", - "effect": "잎사귀를 날려 상대를 베어 공격한다. 급소에 맞기 쉽다." - }, - "solarBeam": { - "name": "솔라빔", - "effect": "1턴째에 빛을 가득 모아 2턴째에 빛의 다발을 발사하여 공격한다." - }, - "poisonPowder": { - "name": "독가루", - "effect": "독이 있는 가루를 많이 흩뿌려서 상대를 독 상태로 만든다." - }, - "stunSpore": { - "name": "저리가루", - "effect": "저리가루를 많이 흩뿌려서 상대를 마비 상태로 만든다." - }, - "sleepPowder": { - "name": "수면가루", - "effect": "잠이 오는 가루를 많이 흩뿌려서 상대를 잠듦 상태로 만든다." - }, - "petalDance": { - "name": "꽃잎댄스", - "effect": "2-3턴 동안 꽃을 흩뿌려서 상대를 공격한다. 흩뿌린 뒤에는 혼란에 빠진다." - }, - "stringShot": { - "name": "실뿜기", - "effect": "입에서 뿜어낸 실을 휘감아서 상대의 스피드를 크게 떨어뜨린다." - }, - "dragonRage": { - "name": "용의분노", - "effect": "분노의 충격파를 상대에게 부딪쳐서 공격한다. 언제나 40의 데미지를 준다." - }, - "fireSpin": { - "name": "회오리불꽃", - "effect": "세차게 소용돌이치는 불꽃 속에 4-5턴 동안 상대를 가두어 공격한다." - }, - "thunderShock": { - "name": "전기쇼크", - "effect": "전기 자극을 상대에게 날려서 공격한다. 마비 상태로 만들 때가 있다." - }, - "thunderbolt": { - "name": "10만볼트", - "effect": "강한 전격을 상대에게 날려서 공격한다. 마비 상태로 만들 때가 있다." - }, - "thunderWave": { - "name": "전기자석파", - "effect": "약한 전격을 날려서 상대를 마비 상태로 만든다." - }, - "thunder": { - "name": "번개", - "effect": "강한 번개를 상대에게 떨어뜨려 공격한다. 마비 상태로 만들 때가 있다." - }, - "rockThrow": { - "name": "돌떨구기", - "effect": "작은 바위를 들어올려 상대에게 내던져서 공격한다." - }, - "earthquake": { - "name": "지진", - "effect": "지진의 충격으로 자신의 주위에 있는 포켓몬을 공격한다." - }, - "fissure": { - "name": "땅가르기", - "effect": "땅이 갈라진 곳에 상대를 떨어뜨려 공격한다. 맞으면 일격에 기절한다." - }, - "dig": { - "name": "구멍파기", - "effect": "1턴째에 파고들어 2턴째에 상대를 공격한다." - }, - "toxic": { - "name": "맹독", - "effect": "상대를 맹독의 상태로 만든다. 턴이 진행될수록 독의 데미지가 증가한다." - }, - "confusion": { - "name": "염동력", - "effect": "약한 염동력을 상대에게 보내어 공격한다. 상대를 혼란시킬 때가 있다." - }, - "psychic": { - "name": "사이코키네시스", - "effect": "강한 염동력을 상대에게 보내어 공격한다. 상대의 특수방어를 떨어뜨릴 때가 있다." - }, - "hypnosis": { - "name": "최면술", - "effect": "졸음을 유도하는 암시를 걸어서 상대를 잠듦 상태로 만든다." - }, - "meditate": { - "name": "요가포즈", - "effect": "잠들어 있는 힘을 몸속에서 끌어내어 자신의 공격을 올린다." - }, - "agility": { - "name": "고속이동", - "effect": "힘을 빼고 몸을 가볍게 해서 고속으로 움직인다. 자신의 스피드를 크게 올린다." - }, - "quickAttack": { - "name": "전광석화", - "effect": "눈에 보이지 않는 굉장한 속도로 상대에게 돌진한다. 반드시 선제공격할 수 있다." - }, - "rage": { - "name": "분노", - "effect": "기술을 썼을 때 공격을 받으면 분노의 힘으로 공격이 올라간다." - }, - "teleport": { - "name": "순간이동", - "effect": "교대할 포켓몬이 있을 때 사용하면 교체한다. 야생 포켓몬은 도망가 버린다." - }, - "nightShade": { - "name": "나이트헤드", - "effect": "무시무시한 환상을 보게 해서 자신의 레벨과 똑같은 만큼의 데미지를 상대에게 준다." - }, - "mimic": { - "name": "흉내내기", - "effect": "상대가 마지막에 사용한 기술을 배틀을 하는 동안 자신의 기술로 만들 수 있다." - }, - "screech": { - "name": "싫은소리", - "effect": "그만 귀를 막아버리고 싶은 싫은 소리를 내어 상대의 방어를 크게 떨어뜨린다." - }, - "doubleTeam": { - "name": "그림자분신", - "effect": "재빠른 움직임으로 분신을 만들어 상대를 혼란시켜 회피율을 올린다." - }, - "recover": { - "name": "HP회복", - "effect": "세포를 재생시켜 자신의 최대 HP의 절반만큼 HP를 회복한다." - }, - "harden": { - "name": "단단해지기", - "effect": "전신에 힘을 담아 몸을 단단하게 해서 자신의 방어를 올린다." - }, - "minimize": { - "name": "작아지기", - "effect": "몸을 축소하여 작게 보임으로써 자신의 회피율을 크게 올린다." - }, - "smokescreen": { - "name": "연막", - "effect": "연기나 먹물을 내뿜어 상대의 명중률을 떨어뜨린다." - }, - "confuseRay": { - "name": "이상한빛", - "effect": "이상한 빛을 상대에게 비춰 당황하게 한다. 상대를 혼란시킨다." - }, - "withdraw": { - "name": "껍질에숨기", - "effect": "껍질에 숨어 몸을 보호하여 자신의 방어를 올린다." - }, - "defenseCurl": { - "name": "웅크리기", - "effect": "몸을 둥글게 웅크려서 자신의 방어를 올린다." - }, - "barrier": { - "name": "배리어", - "effect": "튼튼한 장막을 만들어 자신의 방어를 크게 올린다." - }, - "lightScreen": { - "name": "빛의장막", - "effect": "5턴 동안 이상한 장막을 쳐서 상대로부터 받는 특수공격의 데미지를 약하게 한다." - }, - "haze": { - "name": "흑안개", - "effect": "흑안개를 뿜어 배틀에 참가 중인 포켓몬 전원의 능력 변화를 원래대로 돌린다." - }, - "reflect": { - "name": "리플렉터", - "effect": "5턴 동안 이상한 장막을 쳐서 상대로부터 받는 물리공격의 데미지를 약하게 한다." - }, - "focusEnergy": { - "name": "기충전", - "effect": "깊게 숨을 들이마셔 기합을 넣는다. 자신의 공격이 급소에 맞기 쉬워진다." - }, - "bide": { - "name": "참기", - "effect": "2턴 동안 공격을 견뎌 입은 데미지를 2배로 만들어 상대에게 돌려준다." - }, - "metronome": { - "name": "손가락흔들기", - "effect": "손가락을 흔들어 자신의 뇌를 자극해서 모든 기술 중 어느 하나를 날린다." - }, - "mirrorMove": { - "name": "따라하기", - "effect": "상대가 사용한 기술을 흉내 내어 자신도 똑같은 기술을 쓴다." - }, - "selfDestruct": { - "name": "자폭", - "effect": "폭발을 일으켜서 자신의 주위에 있는 포켓몬을 공격한다. 쓰고 나서 기절하게 된다." - }, - "eggBomb": { - "name": "알폭탄", - "effect": "큰 알을 온 힘을 다해 상대에게 내던져서 공격한다." - }, - "lick": { - "name": "핥기", - "effect": "긴 혀로 상대를 핥아서 공격한다. 마비 상태로 만들 때가 있다." - }, - "smog": { - "name": "스모그", - "effect": "더러운 가스를 상대에게 내뿜어 공격한다. 독 상태로 만들 때가 있다." - }, - "sludge": { - "name": "오물공격", - "effect": "더러운 오물을 상대에게 내던져서 공격한다. 독 상태로 만들 때가 있다." - }, - "boneClub": { - "name": "뼈다귀치기", - "effect": "손에 들고 있는 뼈로 상대를 세게 때려서 공격한다. 상대를 풀죽게 만들 때가 있다." - }, - "fireBlast": { - "name": "불대문자", - "effect": "큰 대자의 불꽃으로 상대를 불태운다. 화상 상태로 만들 때가 있다." - }, - "waterfall": { - "name": "폭포오르기", - "effect": "굉장한 기세로 상대에게 돌진한다. 상대를 풀죽게 만들 때가 있다." - }, - "clamp": { - "name": "껍질끼우기", - "effect": "매우 튼튼하고 두꺼운 껍질에 4-5턴 동안 상대를 끼워서 공격한다." - }, - "swift": { - "name": "스피드스타", - "effect": "별 모양의 빛을 발사해서 상대를 공격한다. 공격은 반드시 명중한다." - }, - "skullBash": { - "name": "로켓박치기", - "effect": "1턴째에 머리를 움츠려 방어를 올린다. 2턴째에 상대를 공격한다." - }, - "spikeCannon": { - "name": "가시대포", - "effect": "날카로운 침을 상대에게 발사해서 공격한다. 2-5회 동안 연속으로 쓴다." - }, - "constrict": { - "name": "휘감기", - "effect": "촉수나 덩굴 등을 휘감아서 공격한다. 상대의 스피드를 떨어뜨릴 때가 있다." - }, - "amnesia": { - "name": "망각술", - "effect": "머리를 비워서 순간적으로 무언가를 잊어버림으로써 자신의 특수방어를 크게 올린다." - }, - "kinesis": { - "name": "숟가락휘기", - "effect": "숟가락을 휘어서 주의를 끌어 상대의 명중률을 낮춘다." - }, - "softBoiled": { - "name": "알낳기", - "effect": "자신의 최대 HP 절반을 회복한다." - }, - "highJumpKick": { - "name": "무릎차기", - "effect": "점프해서 무릎차기로 상대를 공격한다. 빗나가면 자신이 데미지를 입는다." - }, - "glare": { - "name": "뱀눈초리", - "effect": "배의 무늬로 겁을 주어 상대를 마비 상태로 만든다." - }, - "dreamEater": { - "name": "꿈먹기", - "effect": "잠자고 있는 상대의 꿈을 먹어 공격한다. 데미지의 절반을 HP로 회복한다." - }, - "poisonGas": { - "name": "독가스", - "effect": "독가스를 상대의 얼굴에 내뿜어 독 상태로 만든다." - }, - "barrage": { - "name": "구슬던지기", - "effect": "둥근 것을 상대에게 내던져서 공격한다. 2-5회 동안 연속으로 쓴다." - }, - "leechLife": { - "name": "흡혈", - "effect": "피를 빨아서 상대를 공격한다. 준 데미지의 절반을 HP로 회복한다." - }, - "lovelyKiss": { - "name": "악마의키스", - "effect": "무서운 얼굴로 키스한다. 상대를 잠듦 상태로 만든다." - }, - "skyAttack": { - "name": "불새", - "effect": "2턴째에 상대를 공격한다. 가끔 풀죽게 만든다. 급소에도 맞기 쉽다." - }, - "transform": { - "name": "변신", - "effect": "상대 포켓몬으로 변신하여 상대와 완전히 똑같은 기술을 사용할 수 있다." - }, - "bubble": { - "name": "거품", - "effect": "매우 많은 거품을 상대에게 내뿜어 공격한다. 상대의 스피드를 떨어뜨릴 때가 있다." - }, - "dizzyPunch": { - "name": "잼잼펀치", - "effect": "리드미컬한 펀치를 날려 상대를 공격한다. 혼란시킬 때가 있다." - }, - "spore": { - "name": "버섯포자", - "effect": "최면 효과가 있는 포자를 훌훌 흩뿌려서 상대를 잠듦 상태로 만든다." - }, - "flash": { - "name": "플래시", - "effect": "눈이 부신 빛으로 상대의 명중률을 떨어뜨린다." - }, - "psywave": { - "name": "사이코웨이브", - "effect": "이상한 염력파를 상대에게 발사하여 공격한다. 사용할 때마다 데미지가 바뀐다." - }, - "splash": { - "name": "튀어오르기", - "effect": "공격도 하지 않고 팔딱팔딱 튈 뿐 아무 일도 일어나지 않는다..." - }, - "acidArmor": { - "name": "녹기", - "effect": "세포의 변화로 액체가 되어 자신의 방어를 크게 올린다." - }, - "crabhammer": { - "name": "집게해머", - "effect": "큰 집게를 상대에게 내리쳐서 공격한다. 급소에 맞기 쉽다." - }, - "explosion": { - "name": "대폭발", - "effect": "큰 폭발로 자신의 주위에 있는 포켓몬을 공격한다. 쓰고 나서는 기절한다." - }, - "furySwipes": { - "name": "마구할퀴기", - "effect": "손톱이나 낫 등으로 상대를 할퀴어서 공격한다. 2-5회 동안 연속으로 쓴다." - }, - "bonemerang": { - "name": "뼈다귀부메랑", - "effect": "손에 들고 있는 뼈를 상대에게 날려서 날아갈 때와 돌아올 때 2회 연속 데미지를 준다." - }, - "rest": { - "name": "잠자기", - "effect": "2턴 동안 계속 잠잔다. 자신의 HP와 상태 이상을 모두 회복한다." - }, - "rockSlide": { - "name": "스톤샤워", - "effect": "큰 바위를 세차게 부딪쳐서 공격한다. 상대를 풀죽게 만들 때가 있다." - }, - "hyperFang": { - "name": "필살앞니", - "effect": "날카로운 앞니로 강하게 물어서 공격한다. 상대를 풀죽게 만들 때가 있다." - }, - "sharpen": { - "name": "각지기", - "effect": "몸의 각을 늘려서 더욱 각지게 하여 자신의 공격을 올린다." - }, - "conversion": { - "name": "텍스처", - "effect": "자신의 타입을 배운 기술 중 가장 위에 있는 기술과 같은 타입으로 바꾼다." - }, - "triAttack": { - "name": "트라이어택", - "effect": "3개의 광선으로 공격한다. 마비, 화상 또는 얼음 상태 중 어느 하나로 만들 때가 있다." - }, - "superFang": { - "name": "분노의앞니", - "effect": "날카로운 앞니로 강하게 물어서 공격한다. 상대의 HP는 절반이 된다." - }, - "slash": { - "name": "베어가르기", - "effect": "발톱이나 낫 등으로 상대를 베어 갈라서 공격한다. 급소에 맞기 쉽다." - }, - "substitute": { - "name": "대타출동", - "effect": "자신의 HP를 조금 깎아서 분신을 만든다. 분신은 자신의 대타가 된다." - }, - "struggle": { - "name": "발버둥", - "effect": "자신의 PP가 떨어지면 발버둥 쳐 상대를 공격한다. 자신도 조금 데미지를 입는다." - }, - "sketch": { - "name": "스케치", - "effect": "상대가 쓴 기술을 자신의 것으로 만든다. 한 번 사용하면 스케치는 사라진다." - }, - "tripleKick": { - "name": "트리플킥", - "effect": "3회 연속으로 킥을 날려 공격한다. 기술이 맞을 때마다 위력이 올라간다." - }, - "thief": { - "name": "도둑질", - "effect": "공격과 동시에 30%의 확률로 도구를 훔친다." - }, - "spiderWeb": { - "name": "거미집", - "effect": "끈적끈적하고 가는 실을 칭칭 휘감아 상대를 배틀에서 도망칠 수 없게 한다." - }, - "mindReader": { - "name": "마음의눈", - "effect": "상대의 움직임을 마음으로 읽고 다음 공격이 반드시 상대에게 명중되게 한다." - }, - "nightmare": { - "name": "악몽", - "effect": "잠듦 상태의 상대에게 악몽을 꾸게 하여 매 턴 조금씩 HP를 떨어뜨려 간다." - }, - "flameWheel": { - "name": "화염바퀴", - "effect": "불꽃을 둘러 상대에게 돌진하여 공격한다. 화상 상태로 만들 때가 있다." - }, - "snore": { - "name": "코골기", - "effect": "자신이 잠들어 있을 때 소음을 내어 공격한다. 상대를 풀죽게 만들 때가 있다." - }, - "curse": { - "name": "저주", - "effect": "기술을 쓰는 포켓몬이 고스트타입일 때와 그 이외의 타입일 때는 효과가 다르다." - }, - "flail": { - "name": "바둥바둥", - "effect": "바둥바둥 난동 부려서 공격한다. 자신의 HP가 적을수록 기술의 위력이 올라간다." - }, - "conversion2": { - "name": "텍스처2", - "effect": "상대가 마지막으로 쓴 기술에 저항할 수 있도록 자신의 타입을 변화시킨다." - }, - "aeroblast": { - "name": "에어로블라스트", - "effect": "공기의 소용돌이를 발사하여 공격한다. 급소에 맞기 쉽다." - }, - "cottonSpore": { - "name": "목화포자", - "effect": "솜처럼 폭신폭신한 포자를 착 달라붙게 해서 상대의 스피드를 크게 떨어뜨린다." - }, - "reversal": { - "name": "기사회생", - "effect": "힘을 쥐어짜서 공격한다. 자신의 HP가 적을수록 기술의 위력이 올라간다." - }, - "spite": { - "name": "원한", - "effect": "상대가 마지막으로 사용한 기술에 원한을 품어 그 기술의 PP를 4만큼 줄인다." - }, - "powderSnow": { - "name": "눈싸라기", - "effect": "차가운 가랑눈을 상대에게 내뿜어 공격한다. 얼음 상태로 만들 때가 있다." - }, - "protect": { - "name": "방어", - "effect": "상대의 공격을 전혀 받지 않는다. 연속으로 쓰면 실패하기 쉽다." - }, - "machPunch": { - "name": "마하펀치", - "effect": "눈에 보이지 않는 굉장한 속도로 펀치를 날린다. 반드시 선제공격을 할 수 있다." - }, - "scaryFace": { - "name": "겁나는얼굴", - "effect": "무서운 얼굴로 노려보고 겁주어 상대의 스피드를 크게 떨어뜨린다." - }, - "feintAttack": { - "name": "속여때리기", - "effect": "슬금슬금 상대에게 다가가 방심한 틈을 타서 세게 때린다. 공격은 반드시 명중한다." - }, - "sweetKiss": { - "name": "천사의키스", - "effect": "천사처럼 귀엽게 키스하여 상대를 혼란시킨다." - }, - "bellyDrum": { - "name": "배북", - "effect": "자신의 HP를 최대 HP의 절반만큼 감소시켜 자신의 공격을 최대로 올린다." - }, - "sludgeBomb": { - "name": "오물폭탄", - "effect": "더러운 오물을 상대에게 내던져서 공격한다. 독 상태로 만들 때가 있다." - }, - "mudSlap": { - "name": "진흙뿌리기", - "effect": "상대의 얼굴 등에 진흙을 내던져서 공격한다. 명중률을 떨어뜨린다." - }, - "octazooka": { - "name": "대포무노포", - "effect": "상대의 얼굴 등에 먹물을 내뿜어 공격한다. 명중률을 떨어뜨릴 때가 있다." - }, - "spikes": { - "name": "압정뿌리기", - "effect": "상대의 발밑에 압정을 뿌린다. 교체된 상대 포켓몬에게 데미지를 준다." - }, - "zapCannon": { - "name": "전자포", - "effect": "대포처럼 전기를 발사해서 공격한다. 상대를 마비 상태로 만든다." - }, - "foresight": { - "name": "꿰뚫어보기", - "effect": "고스트타입에 효과가 없는 기술이나 회피율이 높은 상대라 할지라도 공격이 맞게 된다." - }, - "destinyBond": { - "name": "길동무", - "effect": "기술을 쓴 뒤 상대의 공격으로 기절했을 때 공격 상대도 기절하게 한다. 연속으로 쓰면 실패한다." - }, - "perishSong": { - "name": "멸망의노래", - "effect": "노래를 들은 포켓몬은 3턴이 지나면 기절한다. 교체되면 효과가 없어진다." - }, - "icyWind": { - "name": "얼어붙은바람", - "effect": "차가운 냉기를 상대에게 내뿜어 공격한다. 상대의 스피드를 떨어뜨린다." - }, - "detect": { - "name": "판별", - "effect": "상대의 공격을 전혀 받지 않는다. 연속으로 쓰면 실패하기 쉽다." - }, - "boneRush": { - "name": "본러시", - "effect": "단단한 뼈로 상대를 세게 때려서 공격한다. 2-5회 동안 연속으로 쓴다." - }, - "lockOn": { - "name": "록온", - "effect": "조준을 잘 맞춰 다음 공격이 반드시 상대에게 명중하도록 한다." - }, - "outrage": { - "name": "역린", - "effect": "2-3턴 동안 마구 난동 부려서 공격한다. 난동 부린 뒤에는 혼란에 빠진다." - }, - "sandstorm": { - "name": "모래바람", - "effect": "5턴 동안 모래바람을 일으켜 바위 땅, 강철타입 이외의 상대에게 데미지를 준다. 바위타입의 특수방어가 올라간다." - }, - "gigaDrain": { - "name": "기가드레인", - "effect": "양분을 흡수하여 공격한다. 입힌 데미지의 절반에 해당하는 HP를 회복할 수 있다." - }, - "endure": { - "name": "버티기", - "effect": "공격을 받아도 HP를 반드시 1만큼은 남긴다. 연속으로 쓰면 실패하기 쉽다." - }, - "charm": { - "name": "애교부리기", - "effect": "귀엽게 바라보고 방심을 유도하여 상대의 공격을 크게 떨어뜨린다." - }, - "rollout": { - "name": "구르기", - "effect": "5턴 동안 구르기를 반복하여 공격한다. 기술이 맞을 때마다 위력이 올라간다." - }, - "falseSwipe": { - "name": "칼등치기", - "effect": "상대의 HP가 반드시 1만 남도록 조절하여 공격한다." - }, - "swagger": { - "name": "뽐내기", - "effect": "상대를 화내게 해서 혼란시킨다. 분노로 상대의 공격은 크게 올라가 버린다." - }, - "milkDrink": { - "name": "우유마시기", - "effect": "자신의 최대 HP 절반을 회복한다." - }, - "spark": { - "name": "스파크", - "effect": "전기를 둘러 상대에게 돌진하여 공격한다. 마비 상태로 만들 때가 있다." - }, - "furyCutter": { - "name": "연속자르기", - "effect": "낫이나 발톱 등으로 상대를 베어 공격한다. 연속으로 맞히면 위력이 올라간다." - }, - "steelWing": { - "name": "강철날개", - "effect": "단단한 날개를 상대에게 부딪쳐서 공격한다. 자신의 방어가 올라갈 때가 있다." - }, - "meanLook": { - "name": "검은눈빛", - "effect": "빨려 들어갈 것 같은 까만 눈빛으로 가만히 응시하여 상대를 배틀에서 도망갈 수 없게 한다." - }, - "attract": { - "name": "헤롱헤롱", - "effect": "수컷은 암컷을 암컷은 수컷을 유혹하여 헤롱헤롱하게 만든다. 상대가 기술을 쓰기 어려워진다." - }, - "sleepTalk": { - "name": "잠꼬대", - "effect": "자신이 배운 기술 중 하나를 무작위로 날린다. 자신이 잠들어 있을 때만 쓸 수 있다." - }, - "healBell": { - "name": "치료방울", - "effect": "기분 좋은 방울소리를 들려주어 같은 편 전원의 상태 이상을 회복한다." - }, - "return": { - "name": "은혜갚기", - "effect": "트레이너를 위해 전력으로 상대를 공격한다. 친밀할수록 위력이 올라간다." - }, - "present": { - "name": "프레젠트", - "effect": "덫을 설치한 상자를 상대에게 건네어 공격한다. HP가 회복돼버릴 때도 있다." - }, - "frustration": { - "name": "화풀이", - "effect": "불만을 풀기 위해 전력으로 상대를 공격한다. 친밀하지 않을수록 위력이 올라간다." - }, - "safeguard": { - "name": "신비의부적", - "effect": "5턴 동안 이상한 힘의 보호를 받아 상태 이상이 되지 않는다." - }, - "painSplit": { - "name": "아픔나누기", - "effect": "자신의 HP와 상대의 HP를 합친 것을 자신과 상대가 사이좋게 나눈다." - }, - "sacredFire": { - "name": "성스러운불꽃", - "effect": "신비한 불꽃으로 상대를 태워서 공격한다. 화상 상태로 만들 때가 있다." - }, - "magnitude": { - "name": "매그니튜드", - "effect": "땅을 흔들어서 자신의 주위에 있는 포켓몬을 공격한다. 기술의 위력이 여러모로 바뀐다." - }, - "dynamicPunch": { - "name": "폭발펀치", - "effect": "혼신의 힘으로 펀치를 날려서 공격한다. 상대를 반드시 혼란시킨다." - }, - "megahorn": { - "name": "메가혼", - "effect": "단단하고 훌륭한 뿔로 마음껏 상대를 꿰찔러서 공격한다." - }, - "dragonBreath": { - "name": "용의숨결", - "effect": "굉장한 숨결을 상대에게 내뿜어 공격한다. 마비 상태로 만들 때가 있다." - }, - "batonPass": { - "name": "배턴터치", - "effect": "교대 포켓몬과 바뀐다. 능력 변화는 바뀐 포켓몬이 그대로 이어받는다." - }, - "encore": { - "name": "앙코르", - "effect": "상대에게 앙코르를 외쳐서 기술을 3번 연속으로 쓰게 한다." - }, - "pursuit": { - "name": "따라가때리기", - "effect": "상대 포켓몬이 교체될 때 기술을 쓰면 2배의 위력으로 공격할 수 있다." - }, - "rapidSpin": { - "name": "고속스핀", - "effect": "회전해서 상대를 공격한다. 조이기, 김밥말이, 씨뿌리기 등을 날려버린다. 자신의 스피드도 오른다." - }, - "sweetScent": { - "name": "달콤한향기", - "effect": "향기로 상대의 회피율을 크게 떨어뜨린다." - }, - "ironTail": { - "name": "아이언테일", - "effect": "단단한 꼬리로 상대를 힘껏 쳐서 공격한다. 상대의 방어를 떨어뜨릴 때가 있다." - }, - "metalClaw": { - "name": "메탈클로", - "effect": "강철의 발톱으로 상대를 베어 갈라 공격한다. 자신의 공격이 올라갈 때도 있다." - }, - "vitalThrow": { - "name": "받아던지기", - "effect": "상대보다 나중에 공격한다. 그 대신 자신의 공격은 반드시 명중한다." - }, - "morningSun": { - "name": "아침햇살", - "effect": "자신의 HP를 회복한다. 날씨에 따라 회복량이 변한다." - }, - "synthesis": { - "name": "광합성", - "effect": "자신의 HP를 회복한다. 날씨에 따라 회복량이 변한다." - }, - "moonlight": { - "name": "달빛", - "effect": "자신의 HP를 회복한다. 날씨에 따라 회복량이 변한다." - }, - "hiddenPower": { - "name": "잠재파워", - "effect": "기술을 쓴 포켓몬에 따라 기술의 타입이 바뀐다." - }, - "crossChop": { - "name": "크로스촙", - "effect": "양손으로 당수를 상대에게 힘껏 쳐서 공격한다. 급소에 맞기 쉽다." - }, - "twister": { - "name": "회오리", - "effect": "회오리를 일으켜 상대를 끌어들여 공격한다. 상대를 풀죽게 만들 때가 있다." - }, - "rainDance": { - "name": "비바라기", - "effect": "5턴 동안 비를 내리게 해서 물타입 기술의 위력을 올린다. 불꽃타입의 위력은 떨어진다." - }, - "sunnyDay": { - "name": "쾌청", - "effect": "5턴 동안 햇살을 강하게 해서 불꽃타입 기술의 위력을 올린다. 물타입의 위력은 떨어진다." - }, - "crunch": { - "name": "깨물어부수기", - "effect": "날카로운 이빨로 상대를 깨물어 부숴서 공격한다. 상대의 방어를 떨어뜨릴 때가 있다." - }, - "mirrorCoat": { - "name": "미러코트", - "effect": "상대에게 받은 특수공격의 데미지를 2배로 만들어 그 상대에게 돌려준다." - }, - "psychUp": { - "name": "자기암시", - "effect": "자신에게 암시를 걸어서 능력 변화 상태를 상대와 똑같은 상태로 만든다." - }, - "extremeSpeed": { - "name": "신속", - "effect": "눈에 보이지 않는 굉장한 속도로 상대에게 돌진하여 공격한다. 반드시 선제공격을 할 수 있다." - }, - "ancientPower": { - "name": "원시의힘", - "effect": "원시의 힘으로 공격한다. 자신의 모든 능력이 오를 때가 있다." - }, - "shadowBall": { - "name": "섀도볼", - "effect": "까만 그림자의 덩어리를 내던져서 공격한다. 상대의 특수방어를 떨어뜨릴 때가 있다." - }, - "futureSight": { - "name": "미래예지", - "effect": "기술을 사용한 2턴 뒤에 상대에게 염동력의 덩어리를 보내어 공격한다." - }, - "rockSmash": { - "name": "바위깨기", - "effect": "펀치로 공격한다. 상대의 방어를 떨어뜨릴 때가 있다." - }, - "whirlpool": { - "name": "바다회오리", - "effect": "세차게 소용돌이치는 물속에 4-5턴 동안 상대를 가두어 공격한다." - }, - "beatUp": { - "name": "집단구타", - "effect": "같은 편 전원이 공격한다. 동료 포켓몬이 많을수록 기술의 공격 횟수가 증가한다." - }, - "fakeOut": { - "name": "속이기", - "effect": "선제공격으로 상대를 풀죽게 한다. 배틀에 나가서 바로 쓰지 않으면 성공할 수 없다." - }, - "uproar": { - "name": "소란피기", - "effect": "3턴 동안 소란 피워 공격한다. 그동안은 아무도 잠들지 않게 된다." - }, - "stockpile": { - "name": "비축하기", - "effect": "힘을 비축해서 자신의 방어와 특수방어를 올린다. 최대 3회까지 비축할 수 있다." - }, - "spitUp": { - "name": "토해내기", - "effect": "비축된 힘을 상대에게 부딪쳐서 공격한다. 비축된 만큼 위력이 올라간다." - }, - "swallow": { - "name": "꿀꺽", - "effect": "비축된 힘을 꿀꺽해서 자신의 HP를 회복한다. 비축된 만큼 회복한다." - }, - "heatWave": { - "name": "열풍", - "effect": "뜨거운 숨결을 상대에게 내뿜어 공격한다. 화상 상태로 만들 때가 있다." - }, - "hail": { - "name": "싸라기눈", - "effect": "5턴 동안 싸라기눈을 내리게 해서 얼음타입이 아닌 포켓몬 모두에게 데미지를 준다." - }, - "torment": { - "name": "트집", - "effect": "상대에게 트집을 잡아서 똑같은 기술을 2회 연속으로 쓸 수 없게 한다." - }, - "flatter": { - "name": "부추기기", - "effect": "상대를 부추겨서 혼란시킨다. 동시에 상대의 특수공격도 올라가 버린다." - }, - "willOWisp": { - "name": "도깨비불", - "effect": "으스스하고 괴상한 불꽃을 쏘아 상대를 화상 상태로 만든다." - }, - "memento": { - "name": "추억의선물", - "effect": "자신은 기절하게 되지만 그 대신 상대의 공격과 특수공격을 크게 떨어뜨린다." - }, - "facade": { - "name": "객기", - "effect": "자신이 독, 마비, 화상 상태일 때 날리면 기술의 위력이 2배가 된다." - }, - "focusPunch": { - "name": "힘껏펀치", - "effect": "정신력을 높여 펀치를 날린다. 기술을 쓰기 전에 공격을 받으면 실패한다." - }, - "smellingSalts": { - "name": "정신차리기", - "effect": "마비 상태의 상대에게는 위력이 2배가 되지만 대신 상대의 마비가 풀린다." - }, - "followMe": { - "name": "날따름", - "effect": "자신에게 주목시켜 상대로부터의 공격을 모두 자신에게 향하게 한다." - }, - "naturePower": { - "name": "자연의힘", - "effect": "자연의 힘으로 공격한다. 사용하는 장소에 따라 나오는 기술이 변화한다." - }, - "charge": { - "name": "충전", - "effect": "다음 턴에 쓸 전기타입 기술의 위력을 올린다. 자신의 특수방어도 올라간다." - }, - "taunt": { - "name": "도발", - "effect": "상대를 화나게 한다. 3턴 동안 상대는 데미지를 주는 기술밖에 쓸 수 없게 된다." - }, - "helpingHand": { - "name": "도우미", - "effect": "동료를 돕는다. 도움받은 포켓몬이 쓰는 기술의 위력은 여느 때보다 커진다." - }, - "trick": { - "name": "트릭", - "effect": "상대의 빈틈을 노려 자신과 상대가 지닌 물건을 바꿔치기한다." - }, - "rolePlay": { - "name": "역할", - "effect": "상대의 역할을 하여 자신도 상대와 같은 특성으로 변화한다." - }, - "wish": { - "name": "희망사항", - "effect": "다음 턴에 자신 또는 교체한 포켓몬의 HP를 최대 HP의 절반만큼 회복한다." - }, - "assist": { - "name": "조수", - "effect": "서둘러서 같은 편의 도움을 받아 같은 편 포켓몬이 기억하고 있는 기술 중 하나를 쓴다." - }, - "ingrain": { - "name": "뿌리박기", - "effect": "대지에 뿌리를 박아 매 턴마다 자신의 HP를 회복한다. 뿌리 박고 있으므로 교체할 수 없다." - }, - "superpower": { - "name": "엄청난힘", - "effect": "엄청난 힘을 발휘하여 상대를 공격한다. 자신의 공격과 방어가 떨어진다." - }, - "magicCoat": { - "name": "매직코트", - "effect": "상대가 상태 이상이 되는 기술이나 씨뿌리기 등을 썼을 때 되받아친다." - }, - "recycle": { - "name": "리사이클", - "effect": "배틀 중에 사용하여 없어진 자신의 지닌 물건을 재생시켜 사용할 수 있게 한다." - }, - "revenge": { - "name": "리벤지", - "effect": "상대에게 기술을 받으면 그 상대에게 주는 데미지가 2배가 된다." - }, - "brickBreak": { - "name": "깨트리기", - "effect": "수도로 기세 좋게 내려쳐서 상대를 공격한다. 빛의장막이나 리플렉터 등도 파괴할 수 있다." - }, - "yawn": { - "name": "하품", - "effect": "큰 하품으로 졸음을 유도한다. 다음 턴에 상대를 잠듦 상태로 만든다." - }, - "knockOff": { - "name": "탁쳐서떨구기", - "effect": "상대의 지닌 물건을 탁 쳐서 떨어뜨려 배틀이 끝날 때까지 사용할 수 없게 한다. 물건을 가진 상대에게는 데미지를 더 준다." - }, - "endeavor": { - "name": "죽기살기", - "effect": "상대의 HP가 자신의 HP와 같아지도록 데미지를 준다." - }, - "eruption": { - "name": "분화", - "effect": "분노를 폭발시켜 상대를 공격한다. 자신의 HP가 적을수록 기술의 위력이 떨어진다." - }, - "skillSwap": { - "name": "스킬스왑", - "effect": "초능력으로 자신의 특성과 상대의 특성을 바꾼다." - }, - "imprison": { - "name": "봉인", - "effect": "상대가 자신과 같은 기술을 배웠다면 상대만 그 기술을 사용할 수 없게 한다." - }, - "refresh": { - "name": "리프레시", - "effect": "몸을 쉬게 하여 자신이 입은 독, 마비, 화상의 상태 이상을 치료한다." - }, - "grudge": { - "name": "원념", - "effect": "상대의 기술로 기절하면 원념을 담아 그 기술의 PP를 0으로 만든다." - }, - "snatch": { - "name": "가로채기", - "effect": "상대가 사용하려고 한 회복 기술이나 능력 변화의 기술을 빼앗아 자신에게 쓴다." - }, - "secretPower": { - "name": "비밀의힘", - "effect": "사용하는 장소에 따라 추가 효과가 변화하는 공격이다." - }, - "dive": { - "name": "다이빙", - "effect": "1턴째에 잠수했다가 2턴째에 떠올라 공격한다." - }, - "armThrust": { - "name": "손바닥치기", - "effect": "펼친 양손으로 상대를 번갈아 쳐서 공격한다. 2-5회 동안 연속으로 쓴다." - }, - "camouflage": { - "name": "보호색", - "effect": "물가나 풀밭, 동굴 등 있는 장소에 맞춰서 자신의 타입을 바꾼다." - }, - "tailGlow": { - "name": "반딧불", - "effect": "깜빡거리는 빛을 바라보고 자신의 정신을 통일하여 특수공격을 매우 크게 올린다." - }, - "lusterPurge": { - "name": "러스터퍼지", - "effect": "눈부신 빛을 발산하여 공격한다. 상대의 특수방어를 떨어뜨릴 때가 있다." - }, - "mistBall": { - "name": "미스트볼", - "effect": "안개의 깃털로 둘러싸 공격한다. 상대의 특수공격을 떨어뜨릴 때가 있다." - }, - "featherDance": { - "name": "깃털댄스", - "effect": "깃털을 흩뿌려 상대의 몸에 휘감는다. 상대의 공격을 크게 떨어뜨린다." - }, - "teeterDance": { - "name": "흔들흔들댄스", - "effect": "흔들흔들 댄스를 춰서 주위에 있는 포켓몬을 혼란 상태로 만든다." - }, - "blazeKick": { - "name": "블레이즈킥", - "effect": "공격한 상대를 화상 상태로 만들 때가 있다. 급소에도 맞기 쉽다." - }, - "mudSport": { - "name": "흙놀이", - "effect": "주위를 진흙투성이로 만든다. 5턴 동안 전기타입의 기술을 약하게 한다." - }, - "iceBall": { - "name": "아이스볼", - "effect": "5턴 동안 상대를 공격한다. 기술이 맞을 때마다 위력이 올라간다." - }, - "needleArm": { - "name": "바늘팔", - "effect": "바늘팔을 세차게 흔들어 공격한다. 상대를 풀죽게 만들 때가 있다." - }, - "slackOff": { - "name": "게으름피우기", - "effect": "게으름 피우며 쉰다. 자신의 HP를 최대 HP의 절반만큼 회복한다." - }, - "hyperVoice": { - "name": "하이퍼보이스", - "effect": "시끄럽게 울리는 큰 진동을 상대에게 전달하여 공격한다." - }, - "poisonFang": { - "name": "맹독엄니", - "effect": "독이 있는 이빨로 상대를 물어서 공격한다. 맹독을 주입할 때가 있다." - }, - "crushClaw": { - "name": "브레이크클로", - "effect": "단단하고 날카로운 손톱으로 베어 갈라서 공격한다. 상대의 방어를 떨어뜨릴 때가 있다." - }, - "blastBurn": { - "name": "블라스트번", - "effect": "폭발하는 불꽃으로 상대를 태워서 공격한다. 다음 턴은 움직일 수 없다." - }, - "hydroCannon": { - "name": "하이드로캐논", - "effect": "물의 대포를 상대에게 발사해서 공격한다. 다음 턴은 움직일 수 없다." - }, - "meteorMash": { - "name": "코멧펀치", - "effect": "혜성과 같은 펀치를 날려서 상대를 공격한다. 자신의 공격이 올라갈 때가 있다." - }, - "astonish": { - "name": "놀래키기", - "effect": "큰 소리 등으로 불시에 놀래켜서 공격한다. 상대를 풀죽게 만들 때가 있다." - }, - "weatherBall": { - "name": "웨더볼", - "effect": "사용했을 때의 날씨에 따라서 기술 타입과 위력이 바뀐다." - }, - "aromatherapy": { - "name": "아로마테라피", - "effect": "기분 좋은 평온한 향기를 맡게 하여 같은 편 모두의 상태 이상을 회복한다." - }, - "fakeTears": { - "name": "거짓울음", - "effect": "우는 척을 하며 눈물을 흘린다. 난처하게 만들어 상대의 특수방어를 크게 떨어뜨린다." - }, - "airCutter": { - "name": "에어커터", - "effect": "날카로운 바람으로 상대를 베어 공격한다. 급소에 맞기 쉽다." - }, - "overheat": { - "name": "오버히트", - "effect": "풀 파워로 상대를 공격한다. 쓰면 반동으로 자신의 특수공격이 크게 떨어진다." - }, - "odorSleuth": { - "name": "냄새구별", - "effect": "고스트타입에 효과가 없는 기술이나 회피율이 높은 상대라 할지라도 공격이 맞게 된다." - }, - "rockTomb": { - "name": "암석봉인", - "effect": "암석을 내던져서 공격한다. 상대의 움직임을 봉인함으로써 스피드를 떨어뜨린다." - }, - "silverWind": { - "name": "은빛바람", - "effect": "바람에 날개 가루를 날려서 상대를 공격한다. 자신의 모든 능력이 올라갈 때가 있다." - }, - "metalSound": { - "name": "금속음", - "effect": "금속을 긁을 때 나는 듯한 싫은 소리를 들려준다. 상대의 특수방어를 크게 떨어뜨린다." - }, - "grassWhistle": { - "name": "풀피리", - "effect": "기분 좋은 피리 소리를 들려주어 상대를 잠듦 상태로 만든다." - }, - "tickle": { - "name": "간지르기", - "effect": "몸을 간질여 웃게 만들어서 상대의 공격과 방어를 떨어뜨린다." - }, - "cosmicPower": { - "name": "코스믹파워", - "effect": "우주로부터 신비한 힘을 손에 넣음으로써 자신의 방어와 특수방어를 올린다." - }, - "waterSpout": { - "name": "해수스파우팅", - "effect": "바닷물을 내뿜어 공격한다. 자신의 HP가 적을수록 기술의 위력이 떨어진다." - }, - "signalBeam": { - "name": "시그널빔", - "effect": "이상한 빛을 발사해서 공격한다. 상대를 혼란시킬 때가 있다." - }, - "shadowPunch": { - "name": "섀도펀치", - "effect": "그림자에 섞여 펀치를 날린다. 공격은 반드시 명중한다." - }, - "extrasensory": { - "name": "신통력", - "effect": "보이지 않는 이상한 힘을 보내어 공격한다. 상대를 풀죽게 만들 때가 있다." - }, - "skyUppercut": { - "name": "스카이어퍼", - "effect": "하늘을 향하는 듯한 높은 업퍼로 상대를 밀어올려 공격한다." - }, - "sandTomb": { - "name": "모래지옥", - "effect": "세차게 불어대는 모래바람 속에 4-5턴 동안 상대를 가두어 공격한다." - }, - "sheerCold": { - "name": "절대영도", - "effect": "상대를 일격에 기절시킨다. 얼음타입 이외의 포켓몬이 사용하면 잘 맞지 않는다." - }, - "muddyWater": { - "name": "탁류", - "effect": "탁해진 물을 상대에게 발사하여 공격한다. 명중률을 떨어뜨릴 때가 있다." - }, - "bulletSeed": { - "name": "씨기관총", - "effect": "씨앗을 기세 좋게 상대에게 발사하여 공격한다. 2-5회 동안 연속으로 쓴다." - }, - "aerialAce": { - "name": "제비반환", - "effect": "재빠른 움직임으로 상대를 농락해 벤다. 공격은 반드시 명중한다." - }, - "icicleSpear": { - "name": "고드름침", - "effect": "날카로운 고드름을 상대에게 발사하여 공격한다. 2-5회 동안 연속으로 쓴다." - }, - "ironDefense": { - "name": "철벽", - "effect": "피부를 쇠처럼 단단하게 만듦으로써 자신의 방어를 크게 올린다." - }, - "block": { - "name": "블록", - "effect": "양팔을 벌려 막아서서 상대의 도주로를 가로막아 도망칠 수 없게 한다." - }, - "howl": { - "name": "멀리짖기", - "effect": "큰 소리로 짖고 기합을 높여 자신과 같은 편의 공격을 올린다." - }, - "dragonClaw": { - "name": "드래곤클로", - "effect": "날카롭고 뾰족한 거대한 발톱으로 상대를 베어 갈라서 공격한다." - }, - "frenzyPlant": { - "name": "하드플랜트", - "effect": "큰 나무로 상대를 힘껏 쳐서 공격한다. 다음 턴은 움직일 수 없게 된다." - }, - "bulkUp": { - "name": "벌크업", - "effect": "몸에 힘을 담아 근육을 두껍게 해서 자신의 공격과 방어를 올린다." - }, - "bounce": { - "name": "뛰어오르기", - "effect": "하늘 높이 뛰어올라 2턴째에 상대를 공격한다. 마비 상태로 만들 때가 있다." - }, - "mudShot": { - "name": "머드샷", - "effect": "진흙 덩어리를 상대에게 내던져서 공격한다. 동시에 상대의 스피드를 떨어뜨린다." - }, - "poisonTail": { - "name": "포이즌테일", - "effect": "꼬리로 때린다. 독 상태로 만들 때가 있고 급소에도 맞기 쉽다." - }, - "covet": { - "name": "탐내기", - "effect": "귀엽게 애교부리며 상대에게 다가가 30%의 확률로 지니고 있는 도구를 뺏는다." - }, - "voltTackle": { - "name": "볼트태클", - "effect": "전기를 한데 모아 돌진한다. 자신도 상당한 데미지를 입는다. 마비 상태로 만들 때가 있다." - }, - "magicalLeaf": { - "name": "매지컬리프", - "effect": "상대를 추적하는 이상한 잎사귀를 흩뿌린다. 공격은 반드시 명중한다." - }, - "waterSport": { - "name": "물놀이", - "effect": "주위를 물로 흠뻑 젖게 만든다. 5턴 동안 불꽃타입의 기술을 약하게 한다." - }, - "calmMind": { - "name": "명상", - "effect": "조용히 정신을 통일하고 마음을 가라앉혀서 자신의 특수공격과 특수방어를 올린다." - }, - "leafBlade": { - "name": "리프블레이드", - "effect": "잎사귀를 칼처럼 이용해 상대를 베어 공격한다. 급소에 맞기 쉽다." - }, - "dragonDance": { - "name": "용의춤", - "effect": "신비롭고 힘센 춤을 격렬하게 춘다. 자신의 공격과 스피드를 올린다." - }, - "rockBlast": { - "name": "록블라스트", - "effect": "단단한 암석을 상대에게 발사하여 공격한다. 2-5회 동안 연속으로 쓴다." - }, - "shockWave": { - "name": "전격파", - "effect": "전격을 재빠르게 상대에게 날린다. 공격은 반드시 명중한다." - }, - "waterPulse": { - "name": "물의파동", - "effect": "물의 진동을 상대에게 가하여 공격한다. 상대를 혼란시킬 때가 있다." - }, - "doomDesire": { - "name": "파멸의소원", - "effect": "기술을 사용한 2턴 뒤에 무수한 빛의 다발이 상대를 공격한다." - }, - "psychoBoost": { - "name": "사이코부스트", - "effect": "풀 파워로 상대를 공격한다. 쓰면 반동으로 자신의 특수공격이 크게 떨어진다." - }, - "roost": { - "name": "날개쉬기", - "effect": "땅에 내려와 몸을 쉬게 한다. 최대 HP의 절반만큼 HP를 회복한다." - }, - "gravity": { - "name": "중력", - "effect": "5턴 동안 부유나 비행타입에 땅타입의 기술이 맞게 된다. 공중으로 나는 기술도 사용할 수 없다." - }, - "miracleEye": { - "name": "미라클아이", - "effect": "악타입에 효과가 없는 기술이나 회피율이 높은 상대라 할지라도 공격이 맞게 된다." - }, - "wakeUpSlap": { - "name": "잠깨움뺨치기", - "effect": "잠듦 상태의 상대에게 큰 데미지를 준다. 대신 상대는 잠에서 깬다." - }, - "hammerArm": { - "name": "암해머", - "effect": "강하고 무거운 주먹을 휘둘러 데미지를 준다. 자신의 스피드가 떨어진다." - }, - "gyroBall": { - "name": "자이로볼", - "effect": "몸을 고속으로 회전시켜 몸통박치기한다. 상대보다 스피드가 낮을수록 위력은 올라간다." - }, - "healingWish": { - "name": "치유소원", - "effect": "자신은 기절하지만 교대하여 나오는 포켓몬의 상태 이상과 HP를 회복한다." - }, - "brine": { - "name": "소금물", - "effect": "상대가 HP의 절반 정도 상처를 입고 있으면 기술의 위력이 2배가 된다." - }, - "naturalGift": { - "name": "자연의은혜", - "effect": "나무열매에서 힘을 얻어 공격한다. 지니게 한 나무열매에 따라 기술의 타입과 위력이 바뀐다." - }, - "feint": { - "name": "페인트", - "effect": "방어나 판별 등을 하고 있는 상대에게 공격할 수 있다. 방어 효과를 해제시킨다." - }, - "pluck": { - "name": "쪼아대기", - "effect": "부리로 공격한다. 상대가 나무열매를 지니고 있을 때 먹어서 나무열매의 효과를 받을 수 있다." - }, - "tailwind": { - "name": "순풍", - "effect": "세차게 불어대는 바람의 소용돌이를 만들어 4턴 동안 같은 편 모두의 스피드를 올린다." - }, - "acupressure": { - "name": "경혈찌르기", - "effect": "경혈을 눌러 몸을 활성화시킨다. 능력 중 하나를 크게 올린다." - }, - "metalBurst": { - "name": "메탈버스트", - "effect": "기술을 쓰기 전에 마지막으로 받은 기술의 데미지를 늘려서 기술을 쓴 상대에게 돌려준다." - }, - "uTurn": { - "name": "유턴", - "effect": "공격한 뒤 굉장한 스피드로 돌아와서 교대 포켓몬과 교체한다." - }, - "closeCombat": { - "name": "인파이트", - "effect": "방어를 포기하고 상대 쪽으로 깊숙이 돌격한다. 자신의 방어와 특수방어가 떨어진다." - }, - "payback": { - "name": "보복", - "effect": "모아서 공격한다. 상대보다 나중에 공격할 수 있으면 기술의 위력은 2배가 된다." - }, - "assurance": { - "name": "승부굳히기", - "effect": "그 턴에 상대가 이미 데미지를 입었다면 기술의 위력은 2배가 된다." - }, - "embargo": { - "name": "금제", - "effect": "지니게 한 도구를 5턴 동안 쓸 수 없게 한다. 트레이너도 그 포켓몬에게는 도구를 쓸 수 없다." - }, - "fling": { - "name": "내던지기", - "effect": "지니게 한 도구를 재빠르게 내던져서 공격한다. 도구에 따라 위력과 효과가 바뀐다." - }, - "psychoShift": { - "name": "사이코시프트", - "effect": "초능력으로 암시를 걸어서 자신에게 걸려 있는 상태 이상을 상대에게 옮긴다." - }, - "trumpCard": { - "name": "마지막수단", - "effect": "마지막수단의 남은 PP가 적으면 적을수록 기술의 위력이 올라간다." - }, - "healBlock": { - "name": "회복봉인", - "effect": "5턴 동안 기술이나 특성, 지니고 있는 도구에 의한 HP 회복을 할 수 없게 한다." - }, - "wringOut": { - "name": "쥐어짜기", - "effect": "강하게 조여 공격을 한다. 상대의 HP가 많이 남아 있을수록 위력이 올라간다." - }, - "powerTrick": { - "name": "파워트릭", - "effect": "초능력으로 자신의 공격과 방어의 힘을 교환한다." - }, - "gastroAcid": { - "name": "위액", - "effect": "상대의 몸에 위액을 내뱉는다. 달라붙은 위액은 상대의 특성 효과를 지운다." - }, - "luckyChant": { - "name": "주술", - "effect": "하늘을 향해 기도를 올려 5턴 동안 상대의 공격을 급소에 맞지 않게 한다." - }, - "meFirst": { - "name": "선취", - "effect": "위력을 올려 상대가 쓰려고 하는 기술을 먼저 쓴다. 먼저 쓰지 않으면 실패한다." - }, - "copycat": { - "name": "흉내쟁이", - "effect": "직전에 나온 기술을 흉내 내어 같은 기술을 쓴다. 기술이 나오지 않았으면 실패한다." - }, - "powerSwap": { - "name": "파워스왑", - "effect": "초능력으로 자신과 상대의 공격과 특수공격의 능력 변화를 교체한다." - }, - "guardSwap": { - "name": "가드스왑", - "effect": "초능력으로 자신과 상대의 방어와 특수방어의 능력 변화를 교체한다." - }, - "punishment": { - "name": "혼내기", - "effect": "능력 변화로 상대가 파워업한 만큼 기술의 위력이 올라간다." - }, - "lastResort": { - "name": "비장의무기", - "effect": "배틀 중에 기억하고 있는 기술을 모두 사용하면 그때부터 쓸 수 있는 필살기이다." - }, - "worrySeed": { - "name": "고민씨", - "effect": "마음을 괴롭히는 씨앗을 심는다. 상대를 잠잘 수 없게 해서 특성을 불면으로 만든다." - }, - "suckerPunch": { - "name": "기습", - "effect": "상대보다 먼저 공격할 수 있다. 상대가 쓴 기술이 공격기술이 아니면 실패한다." - }, - "toxicSpikes": { - "name": "독압정", - "effect": "상대의 발밑에 독 압정을 뿌린다. 교체로 나온 상대 포켓몬에게 독을 퍼지게 한다." - }, - "heartSwap": { - "name": "하트스왑", - "effect": "초능력으로 자신과 상대에 걸려 있는 능력 변화를 교체한다." - }, - "aquaRing": { - "name": "아쿠아링", - "effect": "자신의 몸 주변을 물로 만든 베일로 덮는다. 매 턴 HP를 회복한다." - }, - "magnetRise": { - "name": "전자부유", - "effect": "전기로 만든 자력의 힘으로 허공에 뜬다. 5턴 동안 부유할 수 있다." - }, - "flareBlitz": { - "name": "플레어드라이브", - "effect": "불꽃을 두르고 돌진한다. 자신도 상당한 데미지를 입는다. 화상 상태로 만들 때가 있다." - }, - "forcePalm": { - "name": "발경", - "effect": "상대의 몸에 충격파를 부딪쳐 공격한다. 마비 상태로 만들 때가 있다." - }, - "auraSphere": { - "name": "파동탄", - "effect": "몸속에서 파동의 힘을 끌어내 상대에게 쏜다. 공격은 반드시 명중한다." - }, - "rockPolish": { - "name": "록커트", - "effect": "자신의 몸을 갈아 공기의 저항을 적게 한다. 스피드를 크게 올릴 수 있다." - }, - "poisonJab": { - "name": "독찌르기", - "effect": "독에 물든 촉수나 팔로 상대를 꿰찌른다. 독 상태로 만들 때가 있다." - }, - "darkPulse": { - "name": "악의파동", - "effect": "몸에서 악의로 가득한 무서운 오라를 발한다. 상대를 풀죽게 만들 때가 있다." - }, - "nightSlash": { - "name": "깜짝베기", - "effect": "순간적으로 틈을 노려 상대를 베어 버린다. 급소에 맞기 쉽다." - }, - "aquaTail": { - "name": "아쿠아테일", - "effect": "세차게 날뛰는 거친 파도와 같이 큰 꼬리를 흔들어서 상대를 공격한다." - }, - "seedBomb": { - "name": "씨폭탄", - "effect": "단단한 껍질을 가지고 있는 큰 씨앗을 위에서 힘껏 내던져 상대를 공격한다." - }, - "airSlash": { - "name": "에어슬래시", - "effect": "하늘까지 베어 가르는 공기의 칼날로 공격한다. 상대를 풀죽게 만들 때가 있다." - }, - "xScissor": { - "name": "시저크로스", - "effect": "낫이나 발톱을 가위처럼 교차시키면서 상대를 베어 가른다." - }, - "bugBuzz": { - "name": "벌레의야단법석", - "effect": "진동으로 음파를 일으켜서 공격한다. 상대의 특수방어를 떨어뜨릴 때가 있다." - }, - "dragonPulse": { - "name": "용의파동", - "effect": "큰 입으로 충격파를 일으켜서 상대를 공격한다." - }, - "dragonRush": { - "name": "드래곤다이브", - "effect": "굉장한 살기로 위압하면서 몸통박치기한다. 상대를 풀죽게 만들 때가 있다." - }, - "powerGem": { - "name": "파워젬", - "effect": "보석처럼 반짝이는 빛을 발사하여 상대를 공격한다." - }, - "drainPunch": { - "name": "드레인펀치", - "effect": "주먹으로 상대의 힘을 흡수한다. 입힌 데미지의 절반에 해당하는 HP를 회복할 수 있다." - }, - "vacuumWave": { - "name": "진공파", - "effect": "주먹을 흔들어 진공의 파도를 일으킨다. 반드시 선제공격을 할 수 있다." - }, - "focusBlast": { - "name": "기합구슬", - "effect": "기합을 높여서 혼신의 힘을 방출한다. 상대의 특수방어를 떨어뜨릴 때가 있다." - }, - "energyBall": { - "name": "에너지볼", - "effect": "자연으로부터 모은 생명의 힘을 발사한다. 상대의 특수방어를 떨어뜨릴 때가 있다." - }, - "braveBird": { - "name": "브레이브버드", - "effect": "날개를 접어 저공비행으로 돌격한다. 자신도 상당한 데미지를 입는다." - }, - "earthPower": { - "name": "대지의힘", - "effect": "상대의 발밑에 대지의 힘을 방출한다. 상대의 특수방어를 떨어뜨릴 때가 있다." - }, - "switcheroo": { - "name": "바꿔치기", - "effect": "눈에 보이지 않는 속도로 자신과 상대가 지닌 물건을 교환한다." - }, - "gigaImpact": { - "name": "기가임팩트", - "effect": "가진 힘을 모두 사용해서 상대에게 돌격한다. 다음 턴은 움직일 수 없다." - }, - "nastyPlot": { - "name": "나쁜음모", - "effect": "나쁜 일을 생각해서 머리를 활성화시킨다. 자신의 특수공격을 크게 올린다." - }, - "bulletPunch": { - "name": "불릿펀치", - "effect": "탄환처럼 빠르고 단단한 펀치를 상대에게 날린다. 반드시 선제공격을 할 수 있다." - }, - "avalanche": { - "name": "눈사태", - "effect": "상대로부터 기술을 받으면 그 상대에 대해서 기술의 위력이 2배가 된다." - }, - "iceShard": { - "name": "얼음뭉치", - "effect": "얼음덩어리를 순식간에 만들어 상대에게 빠르게 쏜다. 반드시 선제공격을 할 수 있다." - }, - "shadowClaw": { - "name": "섀도클로", - "effect": "그림자로 만든 날카로운 발톱으로 상대를 베어 가른다. 급소에 맞기 쉽다." - }, - "thunderFang": { - "name": "번개엄니", - "effect": "전기를 모은 이빨로 문다. 상대를 풀죽게 하거나 마비 상태로 만들 때가 있다." - }, - "iceFang": { - "name": "얼음엄니", - "effect": "냉기를 품은 이빨로 문다. 상대를 풀죽게 하거나 얼음 상태로 만들 때가 있다." - }, - "fireFang": { - "name": "불꽃엄니", - "effect": "불꽃을 두른 이빨로 문다. 상대를 풀죽게 하거나 화상 상태로 만들 때가 있다." - }, - "shadowSneak": { - "name": "야습", - "effect": "그림자를 늘려 상대의 배후에서 공격한다. 반드시 선제공격할 수 있다." - }, - "mudBomb": { - "name": "진흙폭탄", - "effect": "단단한 진흙구슬을 상대에게 발사하여 공격한다. 명중률을 떨어뜨릴 때가 있다." - }, - "psychoCut": { - "name": "사이코커터", - "effect": "실체화시킨 마음의 칼날로 상대를 베어 가른다. 급소에 맞기 쉽다." - }, - "zenHeadbutt": { - "name": "사념의박치기", - "effect": "사념의 힘을 이마에 모아서 공격한다. 상대를 풀죽게 만들 때가 있다." - }, - "mirrorShot": { - "name": "미러샷", - "effect": "갈고닦은 몸에서 섬광의 힘을 상대에게 쏜다. 명중률을 떨어뜨릴 때가 있다." - }, - "flashCannon": { - "name": "러스터캐논", - "effect": "몸의 빛을 한곳에 모아서 힘을 방출한다. 상대의 특수방어를 떨어뜨릴 때가 있다." - }, - "rockClimb": { - "name": "록클라임", - "effect": "굉장한 기세로 상대에게 돌진하여 공격한다. 상대를 혼란시킬 때가 있다." - }, - "defog": { - "name": "안개제거", - "effect": "강한 바람으로 상대의 리플렉터나 빛의장막 등을 제거한다. 회피율도 떨어뜨린다." - }, - "trickRoom": { - "name": "트릭룸", - "effect": "이상한 공간을 만든다. 5턴 동안 느린 포켓몬부터 행동할 수 있다." - }, - "dracoMeteor": { - "name": "용성군", - "effect": "천공에서 운석을 상대에게 떨어뜨린다. 사용하면 반동으로 자신의 특수공격이 크게 떨어진다." - }, - "discharge": { - "name": "방전", - "effect": "눈부신 전격으로 자신의 주위에 있는 포켓몬을 공격한다. 마비 상태로 만들 때가 있다." - }, - "lavaPlume": { - "name": "분연", - "effect": "새빨간 불꽃으로 자신의 주위에 있는 포켓몬을 공격한다. 화상 상태로 만들 때가 있다." - }, - "leafStorm": { - "name": "리프스톰", - "effect": "뾰족한 잎사귀로 상대에게 돌풍을 일으킨다. 사용하면 반동으로 자신의 특수공격이 크게 떨어진다." - }, - "powerWhip": { - "name": "파워휩", - "effect": "덩굴이나 촉수를 세차게 흔들어 상대를 힘껏 쳐서 공격한다." - }, - "rockWrecker": { - "name": "암석포", - "effect": "거대한 바위를 상대에게 발사하여 공격한다. 다음 턴은 움직일 수 없게 된다." - }, - "crossPoison": { - "name": "크로스포이즌", - "effect": "독 칼날로 상대를 베어 가른다. 독 상태로 만들 때가 있고 급소에도 맞기 쉽다." - }, - "gunkShot": { - "name": "더스트슈트", - "effect": "더러운 쓰레기를 상대에게 부딪쳐서 공격한다. 독 상태로 만들 때가 있다." - }, - "ironHead": { - "name": "아이언헤드", - "effect": "강철과 같은 단단한 머리로 공격한다. 상대를 풀죽게 만들 때가 있다." - }, - "magnetBomb": { - "name": "마그넷봄", - "effect": "상대에게 달라붙는 강철의 폭탄을 발사한다. 공격은 반드시 명중한다." - }, - "stoneEdge": { - "name": "스톤에지", - "effect": "뾰족한 바위를 상대에게 꿰찔러서 공격한다. 급소에 맞기 쉽다." - }, - "captivate": { - "name": "유혹", - "effect": "수컷은 암컷을 암컷은 수컷을 유혹하여 상대의 특수공격을 크게 떨어뜨린다." - }, - "stealthRock": { - "name": "스텔스록", - "effect": "상대의 주위에 무수한 바위를 띄워 교체해서 나온 상대 포켓몬에게 데미지를 준다." - }, - "grassKnot": { - "name": "풀묶기", - "effect": "풀을 휘감아서 상대를 쓰러뜨린다. 상대가 무거울수록 위력이 올라간다." - }, - "chatter": { - "name": "수다", - "effect": "매우 시끄럽고 수다스러운 음파로 상대를 공격한다. 상대를 혼란시킨다." - }, - "judgment": { - "name": "심판의뭉치", - "effect": "무수한 광탄을 상대에게 방출한다. 자신이 가지고 있는 플레이트에 따라 타입이 바뀐다." - }, - "bugBite": { - "name": "벌레먹기", - "effect": "물어서 공격한다. 상대가 나무열매를 지니고 있을 때 먹어서 나무열매의 효과를 받을 수 있다." - }, - "chargeBeam": { - "name": "차지빔", - "effect": "전격의 다발을 상대에게 발사한다. 전기를 모아서 자신의 특수공격을 올릴 때가 있다." - }, - "woodHammer": { - "name": "우드해머", - "effect": "단단한 몸통을 상대에게 부딪쳐서 공격한다. 자신도 상당한 데미지를 입는다." - }, - "aquaJet": { - "name": "아쿠아제트", - "effect": "눈에 보이지 않는 굉장한 속도로 상대에게 돌진한다. 반드시 선제공격할 수 있다." - }, - "attackOrder": { - "name": "공격지령", - "effect": "부하를 불러내어 상대를 향해서 공격시킨다. 급소에 맞기 쉽다." - }, - "defendOrder": { - "name": "방어지령", - "effect": "부하를 불러내어 자신의 몸을 뒤덮게 한다. 방어와 특수방어를 올릴 수 있다." - }, - "healOrder": { - "name": "회복지령", - "effect": "부하를 불러내어 상처를 회복한다. 최대 HP의 절반만큼 자신의 HP를 회복한다." - }, - "headSmash": { - "name": "양날박치기", - "effect": "목숨을 걸고 혼신의 힘으로 상대에게 박치기를 한다. 자신도 굉장한 데미지를 입는다." - }, - "doubleHit": { - "name": "더블어택", - "effect": "꼬리 등을 써서 상대를 때려 공격한다. 2회 연속으로 데미지를 준다." - }, - "roarOfTime": { - "name": "시간의포효", - "effect": "시간이 뒤틀릴 정도의 힘을 사용해서 상대를 공격한다. 다음 턴은 움직일 수 없다." - }, - "spacialRend": { - "name": "공간절단", - "effect": "주위의 공간과 더불어 상대를 찢어서 데미지를 준다. 급소에 맞기 쉽다." - }, - "lunarDance": { - "name": "초승달춤", - "effect": "자신은 기절하지만 교대하여 나오는 포켓몬의 모든 상태를 회복한다." - }, - "crushGrip": { - "name": "묵사발", - "effect": "굉장한 힘으로 상대를 묵사발로 만든다. 상대의 HP가 남아 있을수록 위력이 올라간다." - }, - "magmaStorm": { - "name": "마그마스톰", - "effect": "세차게 타오르는 불꽃 속에 4-5턴 동안 상대를 가두어 공격한다." - }, - "darkVoid": { - "name": "다크홀", - "effect": "암흑의 세계로 끌고 가서 떨어뜨려 상대를 잠듦 상태로 만든다." - }, - "seedFlare": { - "name": "시드플레어", - "effect": "몸속에서 충격파를 발생시킨다. 상대의 특수방어를 크게 떨어뜨릴 때가 있다." - }, - "ominousWind": { - "name": "괴상한바람", - "effect": "소름이 끼칠 만한 돌풍으로 상대를 공격한다. 자신의 모든 능력이 올라갈 때가 있다." - }, - "shadowForce": { - "name": "섀도다이브", - "effect": "1턴째에 모습을 감춰 2턴째에 상대를 공격한다. 방어하고 있어도 공격은 맞는다." - }, - "honeClaws": { - "name": "손톱갈기", - "effect": "손톱을 갈아 날카롭게 한다. 자신의 공격과 명중률을 올린다." - }, - "wideGuard": { - "name": "와이드가드", - "effect": "같은 편 전원에게 향하는 공격을 1턴 동안 막는다." - }, - "guardSplit": { - "name": "가드셰어", - "effect": "초능력으로 자신과 상대의 방어와 특수방어를 더해서 반으로 나눈다." - }, - "powerSplit": { - "name": "파워셰어", - "effect": "초능력으로 자신과 상대의 공격과 특수공격을 더해서 반으로 나눈다." - }, - "wonderRoom": { - "name": "원더룸", - "effect": "이상한 공간을 만든다. 5턴 동안 모든 포켓몬의 방어와 특수방어가 바뀐다." - }, - "psyshock": { - "name": "사이코쇼크", - "effect": "이상한 염력파를 실체화하여 상대를 공격한다. 물리적인 데미지를 준다." - }, - "venoshock": { - "name": "베놈쇼크", - "effect": "특수한 독액을 끼얹는다. 독 상태의 상대에게는 위력이 2배가 된다." - }, - "autotomize": { - "name": "바디퍼지", - "effect": "몸의 쓸모없는 부분을 깎는다. 자신의 스피드를 크게 올리고 체중도 가벼워진다." - }, - "ragePowder": { - "name": "분노가루", - "effect": "안절부절못하게 하는 가루를 자신에게 뿌려서 주의를 끈다. 상대의 공격은 모두 자신에게 향한다." - }, - "telekinesis": { - "name": "텔레키네시스", - "effect": "초능력으로 상대를 띄운다. 3턴 동안 공격이 상대에게 맞기 쉬워진다." - }, - "magicRoom": { - "name": "매직룸", - "effect": "이상한 공간을 만든다. 5턴 동안 모든 포켓몬의 도구의 효과가 사라진다." - }, - "smackDown": { - "name": "떨어뜨리기", - "effect": "돌이나 구슬을 던져서 날고 있는 상대를 공격한다. 맞은 상대는 땅에 떨어진다." - }, - "stormThrow": { - "name": "업어후리기", - "effect": "강렬한 일격을 상대에게 날린다. 공격은 반드시 급소에 맞는다." - }, - "flameBurst": { - "name": "불꽃튀기기", - "effect": "맞으면 튀는 불꽃으로 상대를 공격한다. 튕긴 불꽃은 옆의 상대에게도 쏟아진다." - }, - "sludgeWave": { - "name": "오물웨이브", - "effect": "오물 파도로 자신의 주위에 있는 포켓몬을 공격한다. 독 상태로 만들 때가 있다." - }, - "quiverDance": { - "name": "나비춤", - "effect": "신비롭고 아름다운 춤을 경쾌하게 춘다. 자신의 특수공격과 특수방어와 스피드를 올린다." - }, - "heavySlam": { - "name": "헤비봄버", - "effect": "무거운 몸으로 상대에게 부딪쳐 공격한다. 자신이 상대보다 무거울수록 위력이 올라간다." - }, - "synchronoise": { - "name": "싱크로노이즈", - "effect": "이상한 전파로 주위에 있는 자신과 같은 타입의 포켓몬에게 데미지를 준다." - }, - "electroBall": { - "name": "일렉트릭볼", - "effect": "전기 덩어리를 상대에게 부딪쳐서 공격한다. 상대보다 스피드가 빠를수록 위력이 올라간다." - }, - "soak": { - "name": "물붓기", - "effect": "많은 물을 끼얹어서 상대를 물타입으로 바꾼다." - }, - "flameCharge": { - "name": "니트로차지", - "effect": "불꽃을 둘러 상대를 공격한다. 힘을 모아서 자신의 스피드를 올린다." - }, - "coil": { - "name": "똬리틀기", - "effect": "똬리를 틀어서 집중한다. 자신의 공격과 방어와 명중률을 올린다." - }, - "lowSweep": { - "name": "로킥", - "effect": "재빠른 움직임으로 상대의 다리를 노려 공격한다. 상대의 스피드를 떨어뜨린다." - }, - "acidSpray": { - "name": "애시드봄", - "effect": "상대를 녹이는 액체를 토해내서 공격한다. 상대의 특수방어를 크게 떨어뜨린다." - }, - "foulPlay": { - "name": "속임수", - "effect": "상대의 힘을 이용한다. 싸우고 있는 상대의 공격이 높을수록 데미지가 올라간다." - }, - "simpleBeam": { - "name": "심플빔", - "effect": "수수께끼의 염력파를 상대에게 보낸다. 염력파를 받은 상대는 특성이 단순으로 바뀐다." - }, - "entrainment": { - "name": "동료만들기", - "effect": "이상한 리듬으로 춤춘다. 움직임을 흉내 내게 해서 자신과 상대의 특성을 똑같게 만든다." - }, - "afterYou": { - "name": "당신먼저", - "effect": "상대의 행동을 도와서 자신이 행동한 뒤에 바로 움직일 수 있도록 한다." - }, - "round": { - "name": "돌림노래", - "effect": "노래로 상대를 공격한다. 함께 돌림노래를 하면 계속해서 쓸 수 있고 위력도 올라간다." - }, - "echoedVoice": { - "name": "에코보이스", - "effect": "울리는 목소리로 상대를 공격한다. 매 턴 누군가 이 기술을 계속해서 쓰면 위력이 올라간다." - }, - "chipAway": { - "name": "야금야금", - "effect": "틈을 보며 착실하게 공격한다. 상대의 능력 변화에 관계없이 데미지를 준다." - }, - "clearSmog": { - "name": "클리어스모그", - "effect": "특수한 진흙 덩어리를 상대에게 내던져서 공격한다. 능력 변화를 원래대로 돌린다." - }, - "storedPower": { - "name": "어시스트파워", - "effect": "축적된 파워로 상대를 공격한다. 자신의 능력이 올라가 있는 만큼 위력이 오른다." - }, - "quickGuard": { - "name": "패스트가드", - "effect": "자신과 같은 편을 상대의 선제공격으로부터 지킨다." - }, - "allySwitch": { - "name": "사이드체인지", - "effect": "이상한 힘으로 순간이동하여 자신과 같은 편의 위치를 바꾼다." - }, - "scald": { - "name": "열탕", - "effect": "뜨겁게 끓어오르는 물을 상대에게 발사해서 공격한다. 화상 상태로 만들 때가 있다." - }, - "shellSmash": { - "name": "껍질깨기", - "effect": "껍질을 깨서 자신의 방어와 특수방어를 떨어뜨리지만 공격과 특수공격, 스피드를 크게 올린다." - }, - "healPulse": { - "name": "치유파동", - "effect": "치유파동을 날려서 최대 HP의 절반만큼 상대의 HP를 회복한다." - }, - "hex": { - "name": "병상첨병", - "effect": "엎친 데 덮친 격으로 공격한다. 상태 이상인 상대에게 큰 데미지를 준다." - }, - "skyDrop": { - "name": "프리폴", - "effect": "1턴째에 상대를 하늘로 끌고 가서 2턴째에 떨어뜨려 공격한다. 끌려간 상대는 움직일 수 없다." - }, - "shiftGear": { - "name": "기어체인지", - "effect": "톱니바퀴를 돌려서 자신의 공격을 올리는 것뿐만 아니라 스피드도 크게 올린다." - }, - "circleThrow": { - "name": "배대뒤치기", - "effect": "상대를 내던져서 교대할 포켓몬을 끌어낸다. 야생의 경우에는 배틀이 끝난다." - }, - "incinerate": { - "name": "불태우기", - "effect": "불꽃으로 상대를 공격한다. 상대가 나무열매 등을 지니고 있을 때 불태워서 쓸 수 없게 만든다." - }, - "quash": { - "name": "순서미루기", - "effect": "상대를 억눌러서 행동의 순서를 마지막으로 만든다." - }, - "acrobatics": { - "name": "애크러뱃", - "effect": "경쾌하게 상대를 공격한다. 도구를 적게 지니고 있을수록 더 큰 데미지를 준다." - }, - "reflectType": { - "name": "미러타입", - "effect": "상대의 타입을 반사해서 자신도 똑같은 타입이 된다." - }, - "retaliate": { - "name": "원수갚기", - "effect": "쓰러진 같은 편의 원수를 갚는다. 앞 턴에서 같은 편이 쓰러지면 위력이 올라간다." - }, - "finalGambit": { - "name": "목숨걸기", - "effect": "목숨을 걸고 상대를 공격한다. 자신은 기절하게 되지만 상대에게 HP만큼의 데미지를 준다." - }, - "bestow": { - "name": "기프트패스", - "effect": "상대가 도구를 지니고 있지 않을 때 자신이 지니고 있는 도구를 상대에게 건넨다." - }, - "inferno": { - "name": "연옥", - "effect": "격렬한 불꽃으로 상대를 둘러싸 공격한다. 화상 상태로 만든다." - }, - "waterPledge": { - "name": "물의맹세", - "effect": "물기둥으로 공격한다. 불꽃과 조합하면 위력이 올라가고 하늘에 무지개가 걸린다." - }, - "firePledge": { - "name": "불꽃의맹세", - "effect": "불꽃기둥으로 공격한다. 풀과 조합하면 위력이 올라가고 주위가 불바다가 된다." - }, - "grassPledge": { - "name": "풀의맹세", - "effect": "풀기둥으로 공격한다. 물과 조합하면 위력이 올라가고 주변이 습지초원이 된다." - }, - "voltSwitch": { - "name": "볼트체인지", - "effect": "공격한 뒤 굉장한 스피드로 돌아와서 교대 포켓몬과 교체한다." - }, - "struggleBug": { - "name": "벌레의저항", - "effect": "저항해서 상대를 공격한다. 상대의 특수공격을 떨어뜨린다." - }, - "bulldoze": { - "name": "땅고르기", - "effect": "땅을 힘껏 밟아 자신의 주위에 있는 포켓몬을 공격한다. 상대의 스피드를 떨어뜨린다." - }, - "frostBreath": { - "name": "얼음숨결", - "effect": "차가운 숨결을 상대에게 내뿜어 공격한다. 반드시 급소에 맞는다." - }, - "dragonTail": { - "name": "드래곤테일", - "effect": "상대를 튕겨내서 교대할 포켓몬을 끌어낸다. 야생의 경우에는 배틀이 끝난다." - }, - "workUp": { - "name": "분발", - "effect": "스스로 분발해서 공격과 특수공격을 올린다." - }, - "electroweb": { - "name": "일렉트릭네트", - "effect": "전기 네트로 상대를 붙잡아서 공격한다. 상대의 스피드를 떨어뜨린다." - }, - "wildCharge": { - "name": "와일드볼트", - "effect": "전기를 두르고 상대에게 부딪쳐 공격한다. 자신도 조금 데미지를 입는다." - }, - "drillRun": { - "name": "드릴라이너", - "effect": "드릴처럼 몸을 회전시켜서 상대에게 몸통박치기한다. 급소에 맞기 쉽다." - }, - "dualChop": { - "name": "더블촙", - "effect": "몸의 단단한 부분으로 상대를 때려 공격한다. 2회 연속으로 데미지를 준다." - }, - "heartStamp": { - "name": "하트스탬프", - "effect": "귀여운 모습으로 방심시켜서 강렬한 일격을 날린다. 상대를 풀죽게 만들 때가 있다." - }, - "hornLeech": { - "name": "우드혼", - "effect": "뿔을 꿰찔러서 상대의 양분을 흡수한다. 입힌 데미지의 절반에 해당하는 HP를 회복할 수 있다." - }, - "sacredSword": { - "name": "성스러운칼", - "effect": "긴 뿔로 베어 공격한다. 상대의 능력 변화에 관계없이 데미지를 준다." - }, - "razorShell": { - "name": "셸블레이드", - "effect": "날카로운 조개껍질로 베어 공격한다. 상대의 방어를 떨어뜨릴 때가 있다." - }, - "heatCrash": { - "name": "히트스탬프", - "effect": "불타는 몸으로 상대에게 부딪쳐서 공격한다. 자신이 상대보다 무거울수록 위력이 올라간다." - }, - "leafTornado": { - "name": "그래스믹서", - "effect": "날카로운 잎사귀로 상대를 둘러싸서 공격한다. 명중률을 떨어뜨릴 때가 있다." - }, - "steamroller": { - "name": "하드롤러", - "effect": "둥글게 뭉친 몸을 회전하여 상대를 뭉개 버린다. 상대를 풀죽게 만들 때가 있다." - }, - "cottonGuard": { - "name": "코튼가드", - "effect": "푹신푹신한 솜털로 자신의 몸을 둘러싸서 지킨다. 방어를 매우 크게 올린다." - }, - "nightDaze": { - "name": "나이트버스트", - "effect": "암흑의 충격파를 날려서 상대를 공격한다. 명중률을 떨어뜨릴 때가 있다." - }, - "psystrike": { - "name": "사이코브레이크", - "effect": "이상한 염력파를 실체화하여 상대를 공격한다. 물리적인 데미지를 준다." - }, - "tailSlap": { - "name": "스위프뺨치기", - "effect": "단단한 꼬리로 상대를 때려서 공격한다. 2-5회 동안 연속으로 쓴다." - }, - "hurricane": { - "name": "폭풍", - "effect": "강렬한 바람으로 상대를 둘러싸서 공격한다. 상대를 혼란시킬 때가 있다." - }, - "headCharge": { - "name": "아프로브레이크", - "effect": "굉장한 아프로 머리로 상대에게 돌진하여 공격한다. 자신도 조금 데미지를 입는다." - }, - "gearGrind": { - "name": "기어소서", - "effect": "강철의 기어를 상대에게 던져서 공격한다. 2회 연속으로 데미지를 준다." - }, - "searingShot": { - "name": "화염탄", - "effect": "새빨간 불꽃으로 자신의 주위에 있는 포켓몬을 공격한다. 화상 상태로 만들 때가 있다." - }, - "technoBlast": { - "name": "테크노버스터", - "effect": "광탄을 상대에게 방출한다. 자신이 지니고 있는 카세트에 의해 타입이 바뀐다." - }, - "relicSong": { - "name": "옛노래", - "effect": "옛 노래를 상대에게 들려주고 마음에 호소하여 공격한다. 잠듦 상태로 만들 때가 있다." - }, - "secretSword": { - "name": "신비의칼", - "effect": "긴 뿔로 베어 공격한다. 뿔이 머금은 이상한 힘은 물리적인 데미지를 준다." - }, - "glaciate": { - "name": "얼어붙은세계", - "effect": "차가운 냉기를 상대에게 내뿜어 공격한다. 상대의 스피드를 떨어뜨린다." - }, - "boltStrike": { - "name": "뇌격", - "effect": "방대한 전기를 몸에 둘러 상대에게 돌진해서 공격한다. 마비 상태로 만들 때가 있다." - }, - "blueFlare": { - "name": "푸른불꽃", - "effect": "아름다우면서도 격렬한 푸른불꽃으로 상대를 둘러싸서 공격한다. 화상 상태로 만들 때가 있다." - }, - "fieryDance": { - "name": "불꽃춤", - "effect": "불꽃을 두른 날개를 쳐서 공격한다. 자신의 특수공격이 오를 때가 있다." - }, - "freezeShock": { - "name": "프리즈볼트", - "effect": "전기를 두른 얼음덩어리로 2턴째에 상대를 내리친다. 마비 상태로 만들 때가 있다." - }, - "iceBurn": { - "name": "콜드플레어", - "effect": "모든 것을 얼려버리는 격렬한 냉기로 2턴째에 상대를 둘러싼다. 화상 상태로 만들 때가 있다." - }, - "snarl": { - "name": "바크아웃", - "effect": "호되게 호통을 쳐서 상대의 특수공격을 떨어뜨린다." - }, - "icicleCrash": { - "name": "고드름떨구기", - "effect": "큰 고드름을 격렬하게 부딪쳐서 공격한다. 상대를 풀죽게 만들 때가 있다." - }, - "vCreate": { - "name": "V제너레이트", - "effect": "작열하는 불꽃을 이마에서 발생시켜 이판사판으로 몸통박치기한다. 방어, 특수방어, 스피드가 떨어진다." - }, - "fusionFlare": { - "name": "크로스플레임", - "effect": "거대한 불꽃을 내리친다. 거대한 천둥의 영향을 받아 기술의 위력이 올라간다." - }, - "fusionBolt": { - "name": "크로스썬더", - "effect": "거대한 천둥을 내리친다. 거대한 불꽃의 영향을 받아 기술의 위력이 올라간다." - }, - "flyingPress": { - "name": "플라잉프레스", - "effect": "공중에서 상대에게 다이브한다. 이 기술은 격투타입임과 동시에 비행타입이기도 하다." - }, - "matBlock": { - "name": "마룻바닥세워막기", - "effect": "뒤집어 세운 마룻바닥을 방패로 하여 자신과 같은 편으로 향하는 기술 데미지를 막는다. 변화 기술은 막을 수 없다." - }, - "belch": { - "name": "트림", - "effect": "상대를 향해 트림을 하여 데미지를 준다. 나무열매를 먹지 않으면 쓸 수 없다." - }, - "rototiller": { - "name": "일구기", - "effect": "땅을 일구어 초목이 자라기 쉽게 한다. 풀타입의 공격과 특수공격이 오른다." - }, - "stickyWeb": { - "name": "끈적끈적네트", - "effect": "상대의 주위에 끈적끈적한 네트를 둘러 펼쳐 교체되어 나온 상대의 스피드를 떨어뜨린다." - }, - "fellStinger": { - "name": "마지막일침", - "effect": "이 기술을 사용하여 상대를 쓰러뜨리면 공격이 매우 크게 오른다." - }, - "phantomForce": { - "name": "고스트다이브", - "effect": "1턴째에 어디론가 사라져서 2턴째에 상대를 공격한다. 기술 방어를 무시하고 공격할 수 있다." - }, - "trickOrTreat": { - "name": "핼러윈", - "effect": "상대를 핼러윈으로 초대한다. 상대 타입에 고스트타입이 추가된다." - }, - "nobleRoar": { - "name": "부르짖기", - "effect": "우렁차게 부르짖어서 상대를 위협하여 상대의 공격과 특수공격을 떨어뜨린다." - }, - "ionDeluge": { - "name": "플라스마샤워", - "effect": "전기를 띤 입자를 확산시켜 노말타입 기술을 전기타입으로 바꿔버린다." - }, - "parabolicCharge": { - "name": "파라볼라차지", - "effect": "주위에 있는 모든 포켓몬에게 데미지를 준다. 준 데미지의 절반을 자신이 회복한다." - }, - "forestsCurse": { - "name": "숲의저주", - "effect": "상대에게 숲의 저주를 건다. 저주에 걸린 상대는 타입에 풀타입이 추가된다." - }, - "petalBlizzard": { - "name": "꽃보라", - "effect": "세찬 꽃보라를 일으켜서 주위에 있는 포켓몬을 공격하여 데미지를 준다." - }, - "freezeDry": { - "name": "프리즈드라이", - "effect": "상대를 급격히 차갑게 하여 얼음 상태로 만들 때가 있다. 물타입 포켓몬에게도 효과가 굉장해진다." - }, - "disarmingVoice": { - "name": "차밍보이스", - "effect": "매혹적인 울음소리를 내어 상대에게 정신적 데미지를 준다. 공격은 반드시 명중한다." - }, - "partingShot": { - "name": "막말내뱉기", - "effect": "막말을 내뱉어 상대를 위협하여 공격과 특수공격을 떨어뜨린 후 교대 포켓몬과 교체한다." - }, - "topsyTurvy": { - "name": "뒤집어엎기", - "effect": "상대에게 걸려 있는 모든 능력 변화를 뒤집어서 반대로 만든다." - }, - "drainingKiss": { - "name": "드레인키스", - "effect": "키스로 상대의 HP를 흡수한다. 준 데미지의 반 이상 HP를 회복한다." - }, - "craftyShield": { - "name": "트릭가드", - "effect": "이상한 힘을 사용하여 같은 편을 공격하는 변화 기술을 막는다. 데미지 기술은 받는다." - }, - "flowerShield": { - "name": "플라워가드", - "effect": "이상한 힘을 사용하여 배틀에 나와 있는 모든 풀타입 포켓몬의 방어를 올린다." - }, - "grassyTerrain": { - "name": "그래스필드", - "effect": "5턴 동안 그래스필드로 만든다. 땅에 있으면 매 턴 회복한다. 풀타입의 위력이 올라간다." - }, - "mistyTerrain": { - "name": "미스트필드", - "effect": "5턴 동안 땅에 있으면 상태 이상이 되지 않고 드래곤타입 기술의 데미지도 절반이 된다." - }, - "electrify": { - "name": "송전", - "effect": "상대가 기술을 쓰기 전에 송전하면 그 턴에 상대가 사용하는 기술은 전기타입이 된다." - }, - "playRough": { - "name": "치근거리기", - "effect": "상대에게 치근거리며 공격한다. 상대의 공격을 떨어뜨릴 때가 있다." - }, - "fairyWind": { - "name": "요정의바람", - "effect": "요정의 바람을 일으켜 상대에게 몰아쳐서 공격한다." - }, - "moonblast": { - "name": "문포스", - "effect": "달의 파워를 빌려서 상대를 공격한다. 상대의 특수공격을 떨어뜨릴 때가 있다." - }, - "boomburst": { - "name": "폭음파", - "effect": "무시무시한 폭음의 파괴력으로 주위에 있는 포켓몬을 공격한다." - }, - "fairyLock": { - "name": "페어리록", - "effect": "록을 걸어 다음 턴의 모든 포켓몬을 도망가지 못하게 한다." - }, - "kingsShield": { - "name": "킹실드", - "effect": "상대의 공격을 막음과 동시에 방어 태세를 갖춘다. 접촉한 상대의 공격을 떨어뜨린다." - }, - "playNice": { - "name": "친해지기", - "effect": "상대와 친해져서 싸울 마음을 잃게 하여 상대의 공격을 떨어뜨린다." - }, - "confide": { - "name": "비밀이야기", - "effect": "비밀 이야기를 해서 상대의 집중력을 잃게 하여 특수공격을 떨어뜨린다." - }, - "diamondStorm": { - "name": "다이아스톰", - "effect": "다이아 폭풍을 일으켜 데미지를 준다. 자신의 방어를 크게 올릴 때가 있다." - }, - "steamEruption": { - "name": "스팀버스트", - "effect": "상대에게 굉장히 뜨거운 증기를 뿜는다. 상대는 화상을 입기도 한다." - }, - "hyperspaceHole": { - "name": "이차원홀", - "effect": "이차원홀로 갑자기 상대 바로 옆에 나타나 공격한다. 방어나 판별 등도 무시할 수 있다." - }, - "waterShuriken": { - "name": "물수리검", - "effect": "점액으로 만든 수리검을 2-5회 동안 연속으로 던진다. 반드시 선제공격할 수 있다." - }, - "mysticalFire": { - "name": "매지컬플레임", - "effect": "입에서 내뱉는 아주 뜨거운 불꽃으로 공격한다. 상대의 특수공격을 떨어뜨린다." - }, - "spikyShield": { - "name": "니들가드", - "effect": "상대의 공격을 막음과 동시에 접촉한 상대의 체력을 떨어뜨린다." - }, - "aromaticMist": { - "name": "아로마미스트", - "effect": "신비한 아로마 향으로 같은 편의 특수방어를 올린다." - }, - "eerieImpulse": { - "name": "괴전파", - "effect": "몸에서 발생시킨 괴전파를 상대에게 쏘아 특수공격을 크게 떨어뜨린다." - }, - "venomDrench": { - "name": "베놈트랩", - "effect": "특수한 독액을 끼얹는다. 독 상태인 상대는 공격, 특수공격, 스피드가 떨어진다." - }, - "powder": { - "name": "분진", - "effect": "분진을 뒤집어쓴 상대가 불꽃 기술을 쓰면 폭발하여 데미지를 준다." - }, - "geomancy": { - "name": "지오컨트롤", - "effect": "1턴째에 에너지를 흡수하여 2턴째에 특수공격, 특수방어, 스피드를 크게 올린다." - }, - "magneticFlux": { - "name": "자기장조작", - "effect": "자기장 조작으로 인해 특성 플러스와 마이너스의 방어, 특수방어가 오른다." - }, - "happyHour": { - "name": "해피타임", - "effect": "해피타임 기술을 쓰면 배틀 후에 받을 수 있는 돈이 배가 된다." - }, - "electricTerrain": { - "name": "일렉트릭필드", - "effect": "5턴 동안 일렉트릭필드로 만든다. 땅에 있는 포켓몬은 잠들지 않는다. 전기타입의 위력이 올라간다." - }, - "dazzlingGleam": { - "name": "매지컬샤인", - "effect": "강력한 빛을 내어 상대에게 데미지를 준다." - }, - "celebrate": { - "name": "축하", - "effect": "포켓몬이 매우 행복한 당신을 축하해 준다." - }, - "holdHands": { - "name": "손에손잡기", - "effect": "같은 편 포켓몬끼리 손에 손을 잡는다. 굉장히 행복한 기분이 들게 된다." - }, - "babyDollEyes": { - "name": "초롱초롱눈동자", - "effect": "초롱초롱한 눈동자로 상대를 바라보며 공격을 떨어뜨린다. 반드시 선제공격할 수 있다." - }, - "nuzzle": { - "name": "볼부비부비", - "effect": "전기가 흐르는 볼을 비벼서 공격한다. 상대를 마비 상태로 만든다." - }, - "holdBack": { - "name": "적당히손봐주기", - "effect": "적당히 공격하여 상대의 HP를 반드시 1은 남긴다." - }, - "infestation": { - "name": "엉겨붙기", - "effect": "4-5턴 동안 상대에게 엉겨 붙어서 공격한다. 그동안 상대는 도망갈 수 없다." - }, - "powerUpPunch": { - "name": "그로우펀치", - "effect": "반복하여 때리면 점점 주먹이 단단해진다. 상대를 때리면 공격이 오른다." - }, - "oblivionWing": { - "name": "데스윙", - "effect": "조준한 상대로부터 HP를 흡수한다. 준 데미지의 반 이상 HP를 회복한다." - }, - "thousandArrows": { - "name": "사우전드애로", - "effect": "떠 있는 포켓몬도 맞힐 수 있다. 떠 있던 상대는 맞아서 땅에 떨어진다." - }, - "thousandWaves": { - "name": "사우전드웨이브", - "effect": "땅 위를 뻗어 나가는 파도로 공격한다. 파도에 휩쓸린 상대는 전투에서 도망칠 수 없게 된다." - }, - "landsWrath": { - "name": "그라운드포스", - "effect": "대지의 힘을 모으고 그 힘을 상대에게 집중시켜서 데미지를 준다." - }, - "lightOfRuin": { - "name": "파멸의빛", - "effect": "영원의 꽃의 파워를 빌려서 강력한 광선을 쏜다. 자신도 상당한 데미지를 입는다." - }, - "originPulse": { - "name": "근원의파동", - "effect": "파랗게 빛나는 무수한 광선으로 상대를 공격한다." - }, - "precipiceBlades": { - "name": "단애의칼", - "effect": "대지의 힘을 칼날로 바꿔 상대를 공격한다." - }, - "dragonAscent": { - "name": "화룡점정", - "effect": "넓은 하늘에서 급속으로 강하하여 상대를 공격한다. 자신의 방어와 특수방어가 떨어진다." - }, - "hyperspaceFury": { - "name": "이차원러시", - "effect": "많은 팔로 방어와 판별 등을 무시하는 연속 공격이다. 자신의 방어가 떨어진다." - }, - "breakneckBlitzPhysical": { - "name": "울트라대시어택", - "effect": "Z파워로 기세를 몰아 전력으로 상대에게 부딪친다. 원래 기술에 따라 위력이 변한다." - }, - "breakneckBlitzSpecial": { - "name": "울트라대시어택", - "effect": "Dummy Data" - }, - "allOutPummelingPhysical": { - "name": "전력무쌍격렬권", - "effect": "Z파워로 만든 에너지 구슬을 전력으로 상대에게 부딪친다. 원래 기술에 따라 위력이 변한다." - }, - "allOutPummelingSpecial": { - "name": "전력무쌍격렬권", - "effect": "Dummy Data" - }, - "supersonicSkystrikePhysical": { - "name": "파이널다이브클래시", - "effect": "Z파워로 기세 좋게 날아올라 상대를 향해 전력으로 낙하한다. 원래 기술에 따라 위력이 변한다." - }, - "supersonicSkystrikeSpecial": { - "name": "파이널다이브클래시", - "effect": "Dummy Data" - }, - "acidDownpourPhysical": { - "name": "애시드포이즌딜리트", - "effect": "Z파워로 독의 늪을 만들어 전력으로 상대를 가라앉힌다. 원래 기술에 따라 위력이 변한다." - }, - "acidDownpourSpecial": { - "name": "애시드포이즌딜리트", - "effect": "Dummy Data" - }, - "tectonicRagePhysical": { - "name": "라이징랜드오버", - "effect": "Z파워로 땅 깊숙이 파고들어 전력으로 상대에게 부딪친다. 원래 기술에 따라 위력이 변한다." - }, - "tectonicRageSpecial": { - "name": "라이징랜드오버", - "effect": "Dummy Data" - }, - "continentalCrushPhysical": { - "name": "월즈엔드폴", - "effect": "Z파워로 큰 바위산을 불러내 전력으로 상대에게 부딪친다. 원래 기술에 따라 위력이 변한다." - }, - "continentalCrushSpecial": { - "name": "월즈엔드폴", - "effect": "Dummy Data" - }, - "savageSpinOutPhysical": { - "name": "절대포식회전참", - "effect": "Z파워로 뱉어낸 실이 전력으로 상대를 붙들어 맨다. 원래 기술에 따라 위력이 변한다." - }, - "savageSpinOutSpecial": { - "name": "절대포식회전참", - "effect": "Dummy Data" - }, - "neverEndingNightmarePhysical": { - "name": "무한암야로의유인", - "effect": "Z파워로 불러낸 강한 원념이 전력으로 상대에게 쏟아진다. 원래 기술에 따라 위력이 변한다." - }, - "neverEndingNightmareSpecial": { - "name": "무한암야로의유인", - "effect": "Dummy Data" - }, - "corkscrewCrashPhysical": { - "name": "초월나선연격", - "effect": "Z파워로 고속 회전을 하여 전력으로 상대에게 부딪친다. 원래 기술에 따라 위력이 변한다." - }, - "corkscrewCrashSpecial": { - "name": "초월나선연격", - "effect": "Dummy Data" - }, - "infernoOverdrivePhysical": { - "name": "다이내믹풀플레임", - "effect": "Z파워로 활활 타는 불꽃을 뱉어내 전력으로 상대에게 부딪친다. 원래 기술에 따라 위력이 변한다." - }, - "infernoOverdriveSpecial": { - "name": "다이내믹풀플레임", - "effect": "Dummy Data" - }, - "hydroVortexPhysical": { - "name": "슈퍼아쿠아토네이도", - "effect": "Z파워로 큰 바다회오리를 만들어 전력으로 상대를 집어삼킨다. 원래 기술에 따라 위력이 변한다." - }, - "hydroVortexSpecial": { - "name": "슈퍼아쿠아토네이도", - "effect": "Dummy Data" - }, - "bloomDoomPhysical": { - "name": "블룸샤인엑스트라", - "effect": "Z파워로 화초들의 에너지를 빌려 전력으로 상대를 공격한다. 원래 기술에 따라 위력이 변한다." - }, - "bloomDoomSpecial": { - "name": "블룸샤인엑스트라", - "effect": "Dummy Data" - }, - "gigavoltHavocPhysical": { - "name": "스파킹기가볼트", - "effect": "Z파워로 비축한 강한 전기를 전력으로 상대에게 부딪친다. 원래 기술에 따라 위력이 변한다." - }, - "gigavoltHavocSpecial": { - "name": "스파킹기가볼트", - "effect": "Dummy Data" - }, - "shatteredPsychePhysical": { - "name": "맥시멈사이브레이커", - "effect": "Z파워로 상대를 조종해 전력으로 매서운 맛을 보여준다. 원래 기술에 따라 위력이 변한다." - }, - "shatteredPsycheSpecial": { - "name": "맥시멈사이브레이커", - "effect": "Dummy Data" - }, - "subzeroSlammerPhysical": { - "name": "레이징지오프리즈", - "effect": "Z파워로 기온을 급격하게 떨어뜨려 전력으로 상대를 얼린다. 원래 기술에 따라 위력이 변한다." - }, - "subzeroSlammerSpecial": { - "name": "레이징지오프리즈", - "effect": "Dummy Data" - }, - "devastatingDrakePhysical": { - "name": "얼티메이트드래곤번", - "effect": "Z파워로 오라를 실체화시켜 전력으로 상대를 공격한다. 원래 기술에 따라 위력이 변한다." - }, - "devastatingDrakeSpecial": { - "name": "얼티메이트드래곤번", - "effect": "Dummy Data" - }, - "blackHoleEclipsePhysical": { - "name": "블랙홀이클립스", - "effect": "Z파워로 어둠의 에너지를 모아 전력으로 상대를 끌어당긴다. 원래 기술에 따라 위력이 변한다." - }, - "blackHoleEclipseSpecial": { - "name": "블랙홀이클립스", - "effect": "Dummy Data" - }, - "twinkleTacklePhysical": { - "name": "러블리스타임팩트", - "effect": "Z파워로 매혹의 공간을 만들어 전력으로 상대를 가지고 논다. 원래 기술에 따라 위력이 변한다." - }, - "twinkleTackleSpecial": { - "name": "러블리스타임팩트", - "effect": "Dummy Data" - }, - "catastropika": { - "name": "필살피카슛", - "effect": "Z파워로 최대 전력을 몸에 두른 피카츄가 전력으로 상대에게 덤벼든다." - }, - "shoreUp": { - "name": "모래모으기", - "effect": "자신의 최대 HP 절반을 회복한다. 모래바람일 때는 많이 회복한다." - }, - "firstImpression": { - "name": "만나자마자", - "effect": "위력이 높은 기술이지만 배틀에 나가서 바로 쓰지 않으면 성공할 수 없다." - }, - "banefulBunker": { - "name": "토치카", - "effect": "상대의 공격을 막음과 동시에 접촉한 상대에게 독을 퍼뜨린다." - }, - "spiritShackle": { - "name": "그림자꿰매기", - "effect": "공격과 동시에 상대의 그림자를 꿰매 도망칠 수 없게 한다." - }, - "darkestLariat": { - "name": "DD래리어트", - "effect": "양팔을 돌려 상대에게 부딪친다. 상대의 능력 변화에 상관없이 데미지를 준다." - }, - "sparklingAria": { - "name": "물거품아리아", - "effect": "노래 부르는 것으로 많은 벌룬을 방출한다. 기술에 맞으면 화상이 낫는다." - }, - "iceHammer": { - "name": "아이스해머", - "effect": "강하고 무거운 주먹을 휘둘러 데미지를 준다. 자신의 스피드가 떨어진다." - }, - "floralHealing": { - "name": "플라워힐", - "effect": "최대 HP의 절반만큼 상대의 HP를 회복한다. 그래스필드일 때 효과가 올라간다." - }, - "highHorsepower": { - "name": "10만마력", - "effect": "온몸을 써서 상대에게 맹렬히 어택한다." - }, - "strengthSap": { - "name": "힘흡수", - "effect": "상대 공격력과 동일하게 자신의 HP를 회복한다. 그리고 상대의 공격을 떨어뜨린다." - }, - "solarBlade": { - "name": "솔라블레이드", - "effect": "1턴째에 빛을 가득 모아 2턴째에 그 힘을 검에 담아 공격한다." - }, - "leafage": { - "name": "나뭇잎", - "effect": "잎을 상대에 맞춰 공격한다." - }, - "spotlight": { - "name": "스포트라이트", - "effect": "포켓몬에게 스포트라이트를 비춰 그 턴에서 그 포켓몬만 공격할 수 있게 한다." - }, - "toxicThread": { - "name": "독실", - "effect": "독이 섞인 실을 뿜어낸다. 상대를 독 상태로 만들고 스피드를 떨어뜨린다." - }, - "laserFocus": { - "name": "예민해지기", - "effect": "정신을 집중해서 다음 공격을 반드시 급소에 맞춘다." - }, - "gearUp": { - "name": "어시스트기어", - "effect": "기어를 넣는 것으로 특성 플러스와 마이너스의 공격과 특수공격이 올라간다." - }, - "throatChop": { - "name": "지옥찌르기", - "effect": "이 기술에 맞은 상대는 지옥의 고통 때문에 2턴 동안 소리 기술을 낼 수 없다." - }, - "pollenPuff": { - "name": "꽃가루경단", - "effect": "상대에게는 폭발하는 경단을 사용하여 공격한다. 같은 편에게는 회복하는 경단을 준다." - }, - "anchorShot": { - "name": "앵커샷", - "effect": "앵커를 상대에게 휘감아서 공격한다. 상대는 도망칠 수 없게 된다." - }, - "psychicTerrain": { - "name": "사이코필드", - "effect": "5턴 동안 땅에 있으면 선제공격을 받지 않는다. 에스퍼타입의 위력이 올라간다." - }, - "lunge": { - "name": "덤벼들기", - "effect": "전력으로 상대에게 덤벼들며 공격한다. 상대의 공격을 떨어뜨린다." - }, - "fireLash": { - "name": "불꽃채찍", - "effect": "불타는 채찍으로 상대를 친다. 공격을 받은 상대는 방어가 떨어진다." - }, - "powerTrip": { - "name": "기어오르기", - "effect": "자신의 강함을 뻐기고 공격한다. 자신의 능력이 올라가 있는 만큼 위력이 오른다." - }, - "burnUp": { - "name": "불사르기", - "effect": "전신의 불꽃을 모두 태워서 큰 데미지를 준다. 자신의 불꽃타입이 없어진다." - }, - "speedSwap": { - "name": "스피드스왑", - "effect": "상대의 스피드와 자신의 스피드를 교체한다." - }, - "smartStrike": { - "name": "스마트혼", - "effect": "뾰족한 뿔로 상대를 꿰찔러서 공격한다. 공격은 반드시 명중한다." - }, - "purify": { - "name": "정화", - "effect": "상대의 상태 이상을 회복한다. 회복하면 자신은 HP를 회복할 수 있다." - }, - "revelationDance": { - "name": "잠재댄스", - "effect": "전력으로 춤추며 공격한다. 이 기술의 타입은 자신의 타입과 같아진다." - }, - "coreEnforcer": { - "name": "코어퍼니셔", - "effect": "데미지를 준 상대가 이미 행동을 끝냈다면 상대의 특성을 없애버린다." - }, - "tropKick": { - "name": "트로피컬킥", - "effect": "남쪽 나라에서 유래된 뜨거운 킥을 상대에게 날린다. 상대의 공격을 떨어뜨린다." - }, - "instruct": { - "name": "지휘", - "effect": "상대에게 지시하여 상대가 쓴 기술을 다시 한번 쓰게 할 수 있다." - }, - "beakBlast": { - "name": "부리캐논", - "effect": "먼저 부리를 가열시킨 다음 공격을 날린다. 가열 중에 만지면 화상을 입는다." - }, - "clangingScales": { - "name": "스케일노이즈", - "effect": "전신의 비늘을 비벼서 큰 소리를 내 공격한다. 공격 후 자신의 방어가 떨어진다." - }, - "dragonHammer": { - "name": "드래곤해머", - "effect": "몸을 해머처럼 써서 상대를 덮쳐 데미지를 준다." - }, - "brutalSwing": { - "name": "세차게휘두르기", - "effect": "자신의 몸을 세차게 휘둘러서 상대에게 데미지를 준다." - }, - "auroraVeil": { - "name": "오로라베일", - "effect": "5턴 동안 물리와 특수 기술의 데미지를 약하게 한다. 설경일 때만 쓸 수 있다." - }, - "sinisterArrowRaid": { - "name": "섀도애로우즈스트라이크", - "effect": "Z파워로 무수한 화살을 만들어낸 모크나이퍼가 전력으로 상대를 꿰뚫는 공격이다." - }, - "maliciousMoonsault": { - "name": "하이퍼다크크러셔", - "effect": "Z파워로 강한 육체를 얻은 어흥염이 전력으로 상대에게 부딪쳐 공격한다." - }, - "oceanicOperetta": { - "name": "바다의심포니", - "effect": "Z파워로 대량의 물을 부른 누리레느가 전력으로 상대를 공격한다." - }, - "guardianOfAlola": { - "name": "알로라의수호자", - "effect": "Z파워로 알로라의 힘을 얻은 토속신포켓몬 전력의 공격. 상대의 남은 HP를 많이 줄인다." - }, - "soulStealing7StarStrike": { - "name": "칠성탈혼퇴", - "effect": "Z파워를 얻은 마샤도가 펀치와 킥의 연속기술을 전력으로 상대에게 퍼붓는다." - }, - "stokedSparksurfer": { - "name": "라이트닝서프라이드", - "effect": "Z파워를 얻은 알로라지방의 라이츄가 전력으로 공격한다. 상대를 마비 상태로 만든다." - }, - "pulverizingPancake": { - "name": "진심의공격", - "effect": "Z파워로 진심을 낸 잠만보가 거대한 몸을 움직여서 전력으로 상대를 공격한다." - }, - "extremeEvoboost": { - "name": "나인이볼부스트", - "effect": "Z파워를 얻은 이브이가 진화한 동료들의 힘을 빌려 능력을 크게 올린다." - }, - "genesisSupernova": { - "name": "오리진즈슈퍼노바", - "effect": "Z파워를 얻은 뮤가 전력으로 상대를 공격한다. 발밑이 사이코필드가 된다." - }, - "shellTrap": { - "name": "트랩셸", - "effect": "껍질의 트랩을 설치한다. 상대가 물리 기술을 쓰면 폭발해서 데미지를 준다." - }, - "fleurCannon": { - "name": "플뢰르캐논", - "effect": "강력한 빔을 발산한 후 자신의 특수공격이 크게 떨어진다." - }, - "psychicFangs": { - "name": "사이코팽", - "effect": "사이코 파워로 물어서 상대를 공격한다. 빛의장막이나 리플렉터도 파괴할 수 있다." - }, - "stompingTantrum": { - "name": "분함의발구르기", - "effect": "분함을 발판 삼아 공격한다. 앞 턴에서 기술이 빗나갔다면 위력이 배가 된다." - }, - "shadowBone": { - "name": "섀도본", - "effect": "영혼이 머물고 있는 뼈로 상대를 세게 때려서 공격한다. 상대의 방어를 떨어뜨릴 때가 있다." - }, - "accelerock": { - "name": "액셀록", - "effect": "재빠른 스피드로 상대에게 부딪쳐서 공격한다. 반드시 선제공격할 수 있다." - }, - "liquidation": { - "name": "아쿠아브레이크", - "effect": "물의 힘으로 상대에게 부딪쳐서 공격한다. 상대의 방어를 떨어뜨릴 때가 있다." - }, - "prismaticLaser": { - "name": "프리즘레이저", - "effect": "프리즘의 힘으로 강력한 광선을 발사한다. 다음 턴은 움직일 수 없다." - }, - "spectralThief": { - "name": "섀도스틸", - "effect": "상대의 그림자에 숨어들어 상대의 능력이 올라가는 것을 뺏어 공격한다." - }, - "sunsteelStrike": { - "name": "메테오드라이브", - "effect": "유성 같은 기세로 돌진한다. 상대의 특성을 무시하고 공격할 수 있다." - }, - "moongeistBeam": { - "name": "섀도레이", - "effect": "괴상한 광선을 쏘아 공격한다. 상대의 특성을 무시하고 공격할 수 있다." - }, - "tearfulLook": { - "name": "눈물그렁그렁", - "effect": "눈물을 그렁그렁거려 상대의 전의를 상실하게 한다. 상대의 공격과 특수공격이 떨어진다." - }, - "zingZap": { - "name": "찌리리따끔따끔", - "effect": "상대에게 부딪쳐 강력한 전기를 날려서 찌리리따끔따끔하게 만든다. 상대를 풀죽게 만들 때가 있다." - }, - "naturesMadness": { - "name": "자연의분노", - "effect": "자연의 분노를 상대에게 부딪친다. 상대의 HP는 절반이 된다." - }, - "multiAttack": { - "name": "멀티어택", - "effect": "높은 에너지를 둘러싸 상대에게 부딪쳐 공격한다. 메모리에 따라 타입이 바뀐다." - }, - "tenMillionVoltThunderbolt": { - "name": "1000만볼트", - "effect": "모자를 쓴 피카츄가 Z파워로 파워업한 전격을 쏜다. 급소에 맞기 쉽다." - }, - "mindBlown": { - "name": "깜짝헤드", - "effect": "자신의 머리를 폭발시켜 주위의 모든 것을 공격한다. 자신도 데미지를 받는다." - }, - "plasmaFists": { - "name": "플라스마피스트", - "effect": "전기를 두른 주먹으로 공격한다. 노말타입 기술을 전기타입으로 바꿔버린다." - }, - "photonGeyser": { - "name": "포톤가이저", - "effect": "빛의 기둥으로 공격한다. 공격과 특수공격을 비교해서 높은 쪽으로 데미지를 준다." - }, - "lightThatBurnsTheSky": { - "name": "하늘을태우는멸망의빛", - "effect": "네크로즈마가 상대의 특성 효과를 무시하고 공격과 특수공격 중 높은 쪽으로 데미지를 준다." - }, - "searingSunrazeSmash": { - "name": "선샤인스매셔", - "effect": "Z파워를 얻은 솔가레오가 전력으로 공격한다. 상대의 특성 효과를 무시할 수 있다." - }, - "menacingMoonrazeMaelstrom": { - "name": "문라이트블래스터", - "effect": "Z파워를 얻은 루나아라가 전력으로 공격한다. 상대의 특성 효과를 무시할 수 있다." - }, - "letsSnuggleForever": { - "name": "투닥투닥프렌드타임", - "effect": "Z파워를 얻은 따라큐가 전력으로 투닥투닥 공격한다." - }, - "splinteredStormshards": { - "name": "레이디얼에지스톰", - "effect": "Z파워를 얻은 루가루암이 전력으로 공격한다. 추가로 필드 상태를 없앤다." - }, - "clangorousSoulblaze": { - "name": "브레이징소울비트", - "effect": "Z파워를 얻은 짜랑고우거가 전력으로 상대를 공격한다. 추가로 자신의 능력이 올라간다." - }, - "zippyZap": { - "name": "파찌파찌액셀", - "effect": "맹렬한 속도의 전격 공격. 반드시 선제공격할 수 있고 급소에 맞는다." - }, - "splishySplash": { - "name": "참방참방서핑", - "effect": "커다란 파도에 전기를 날리고 상대에게 부딪쳐서 공격한다. 마비 상태로 만들 때가 있다." - }, - "floatyFall": { - "name": "둥실둥실폴", - "effect": "두둥실 떠오른 다음 단숨에 급강하해서 공격한다. 상대를 풀죽게 만들 때가 있다." - }, - "pikaPapow": { - "name": "피카피카썬더", - "effect": "트레이너를 좋아하는 피카츄의 마음이 강할수록 위력이 올라가는 전격. 반드시 명중한다." - }, - "bouncyBubble": { - "name": "생생버블", - "effect": "물덩어리를 부딪쳐서 공격한다. 물을 흡수하여 준 데미지만큼 HP를 회복한다." - }, - "buzzyBuzz": { - "name": "찌릿찌릿일렉", - "effect": "전기를 상대에게 날려서 공격한다. 상대를 마비 상태로 만든다." - }, - "sizzlySlide": { - "name": "이글이글번", - "effect": "불꽃을 두른 몸으로 기세 좋게 상대에게 부딪친다. 상대를 화상 상태로 만든다." - }, - "glitzyGlow": { - "name": "콸콸오라", - "effect": "염동력을 한가득 날린다. 상대의 특수공격을 약하게 만드는 이상한 장막을 만든다." - }, - "baddyBad": { - "name": "아그아그존", - "effect": "악함을 어필해서 공격한다. 상대의 물리공격을 약하게 만드는 이상한 장막을 만든다." - }, - "sappySeed": { - "name": "쑥쑥봄버", - "effect": "거대한 덩굴을 자라게 하고 씨를 흩뿌려서 공격한다. 씨는 매 턴 상대의 HP를 흡수한다." - }, - "freezyFrost": { - "name": "꽁꽁프로스트", - "effect": "차갑게 얼어붙은 흑안개의 결정으로 공격한다. 전원의 능력 변화를 원래대로 돌린다." - }, - "sparklySwirl": { - "name": "반짝반짝스톰", - "effect": "숨 막힐 듯 진한 향기의 회오리로 상대를 휘감아 공격한다. 같은 편의 상태 이상을 회복한다." - }, - "veeveeVolley": { - "name": "브이브이브레이크", - "effect": "트레이너를 좋아하는 이브이의 마음이 강할수록 위력이 올라가는 몸통박치기. 반드시 명중한다." - }, - "doubleIronBash": { - "name": "더블펀처", - "effect": "가슴의 너트를 축으로 회전시켜 2번 연속 팔로 힘껏 친다. 상대를 풀죽게 만들 때가 있다." - }, - "maxGuard": { - "name": "다이월", - "effect": "상대의 공격을 전혀 받지 않는다. 연속으로 쓰면 실패하기 쉽다." - }, - "dynamaxCannon": { - "name": "다이맥스포", - "effect": "코어에서 빔을 발사해서 공격한다. 상대가 웨이브 레벨 최대치를 초과했다면, 초과한 정도에 비례하여 데미지가 최대 2배가 된다." - }, - "snipeShot": { - "name": "노려맞히기", - "effect": "상대의 기술을 끌어모으는 특성이나 기술의 영향을 무시하고 선택한 상대를 공격할 수 있다." - }, - "jawLock": { - "name": "물고버티기", - "effect": "어느 한쪽이 기절할 때까지 교체할 수 없게 된다. 한쪽의 포켓몬이 없어지면 효과가 사라진다." - }, - "stuffCheeks": { - "name": "볼가득넣기", - "effect": "지니고 있는 나무열매를 먹고 방어를 크게 올린다." - }, - "noRetreat": { - "name": "배수의진", - "effect": "자신의 모든 능력이 올라가지만 교체하거나 도망칠 수 없게 된다." - }, - "tarShot": { - "name": "타르샷", - "effect": "끈적끈적한 타르를 날려서 상대의 스피드를 떨어뜨린다. 상대는 불꽃이 약점이 된다." - }, - "magicPowder": { - "name": "마법가루", - "effect": "마법가루를 날려서 상대를 에스퍼타입으로 바꾼다." - }, - "dragonDarts": { - "name": "드래곤애로", - "effect": "드라꼰으로 2번 공격한다. 상대가 2마리일 때는 각각 1번씩 공격한다." - }, - "teatime": { - "name": "다과회", - "effect": "다과회를 열어서 배틀에 나와 있는 포켓몬이 각각 지니고 있는 나무열매를 먹는다." - }, - "octolock": { - "name": "문어굳히기", - "effect": "상대를 도망칠 수 없게 한다. 굳히기에 당한 상대는 매 턴 방어와 특수방어가 떨어진다." - }, - "boltBeak": { - "name": "전격부리", - "effect": "전기를 두른 부리로 찌른다. 상대보다 먼저 공격하면 기술의 위력은 2배가 된다." - }, - "fishiousRend": { - "name": "아가미물기", - "effect": "단단한 아가미로 문다. 상대보다 먼저 공격하면 기술의 위력은 2배가 된다." - }, - "courtChange": { - "name": "코트체인지", - "effect": "이상한 힘으로 서로의 필드 효과를 교체한다." - }, - "maxFlare": { - "name": "다이번", - "effect": "다이맥스한 포켓몬이 날리는 불꽃타입의 공격. 5턴 동안 햇살을 강하게 만든다." - }, - "maxFlutterby": { - "name": "다이웜", - "effect": "다이맥스한 포켓몬이 날리는 벌레타입의 공격. 상대의 특수공격을 떨어뜨린다." - }, - "maxLightning": { - "name": "다이썬더", - "effect": "다이맥스한 포켓몬이 날리는 전기타입의 공격. 5턴 동안 일렉트릭필드로 만든다." - }, - "maxStrike": { - "name": "다이어택", - "effect": "다이맥스한 포켓몬이 날리는 노말타입의 공격. 상대의 스피드를 떨어뜨린다." - }, - "maxKnuckle": { - "name": "다이너클", - "effect": "다이맥스한 포켓몬이 날리는 격투타입의 공격. 같은 편의 공격을 올린다." - }, - "maxPhantasm": { - "name": "다이할로우", - "effect": "다이맥스한 포켓몬이 날리는 고스트타입의 공격. 상대의 방어를 떨어뜨린다." - }, - "maxHailstorm": { - "name": "다이아이스", - "effect": "다이맥스한 포켓몬이 날리는 얼음타입의 공격. 5턴 동안 싸라기눈을 내리게 한다." - }, - "maxOoze": { - "name": "다이애시드", - "effect": "다이맥스한 포켓몬이 날리는 독타입의 공격. 같은 편의 특수공격을 올린다." - }, - "maxGeyser": { - "name": "다이스트림", - "effect": "다이맥스한 포켓몬이 날리는 물타입의 공격. 5턴 동안 비를 내리게 한다." - }, - "maxAirstream": { - "name": "다이제트", - "effect": "다이맥스한 포켓몬이 날리는 비행타입의 공격. 같은 편의 스피드를 올린다." - }, - "maxStarfall": { - "name": "다이페어리", - "effect": "다이맥스한 포켓몬이 날리는 페어리타입의 공격. 5턴 동안 미스트필드로 만든다." - }, - "maxWyrmwind": { - "name": "다이드라군", - "effect": "다이맥스한 포켓몬이 날리는 드래곤타입의 공격. 상대의 공격을 떨어뜨린다." - }, - "maxMindstorm": { - "name": "다이사이코", - "effect": "다이맥스한 포켓몬이 날리는 에스퍼타입의 공격. 5턴 동안 사이코필드로 만든다." - }, - "maxRockfall": { - "name": "다이록", - "effect": "다이맥스한 포켓몬이 날리는 바위타입의 공격. 5턴 동안 날씨를 모래바람으로 만든다." - }, - "maxQuake": { - "name": "다이어스", - "effect": "다이맥스한 포켓몬이 날리는 땅타입의 공격. 같은 편의 특수방어를 올린다." - }, - "maxDarkness": { - "name": "다이아크", - "effect": "다이맥스한 포켓몬이 날리는 악타입의 공격. 상대의 특수방어를 떨어뜨린다." - }, - "maxOvergrowth": { - "name": "다이그래스", - "effect": "다이맥스한 포켓몬이 날리는 풀타입의 공격. 5턴 동안 그래스필드로 만든다." - }, - "maxSteelspike": { - "name": "다이스틸", - "effect": "다이맥스한 포켓몬이 날리는 강철타입의 공격. 같은 편의 방어를 올린다." - }, - "clangorousSoul": { - "name": "소울비트", - "effect": "자신의 HP를 조금 깎아서 모든 능력을 올린다." - }, - "bodyPress": { - "name": "바디프레스", - "effect": "몸을 부딪쳐서 공격한다. 방어가 높을수록 주는 데미지가 올라간다." - }, - "decorate": { - "name": "데코레이션", - "effect": "데코레이션을 해서 상대의 공격과 특수공격을 크게 올린다." - }, - "drumBeating": { - "name": "드럼어택", - "effect": "드럼의 뿌리를 연주로 조종해서 공격하는 것으로 상대의 스피드를 떨어뜨린다." - }, - "snapTrap": { - "name": "집게덫", - "effect": "집게덫으로 붙잡은 뒤 4-5턴 동안 상대를 끼워서 공격한다." - }, - "pyroBall": { - "name": "화염볼", - "effect": "작은 돌을 태운 불꽃의 공으로 상대를 공격한다. 화상 상태로 만들 때가 있다." - }, - "behemothBlade": { - "name": "거수참", - "effect": "크고 강한 검을 온몸으로 치켜든 다음 기세 좋게 베어서 공격한다." - }, - "behemothBash": { - "name": "거수탄", - "effect": "온몸을 강하고 튼튼한 방패로 바꾼 다음 기세 좋게 부딪혀서 공격한다." - }, - "auraWheel": { - "name": "오라휠", - "effect": "볼주머니에 저장해둔 에너지로 공격하고 자신의 스피드를 올린다. 모르페코의 모습에 따라 타입이 바뀐다." - }, - "breakingSwipe": { - "name": "와이드브레이커", - "effect": "강인한 꼬리를 세차게 휘둘러서 상대를 공격한다. 상대의 공격을 떨어뜨린다." - }, - "branchPoke": { - "name": "가지찌르기", - "effect": "날카롭고 뾰족한 가지로 상대를 찔러서 공격한다." - }, - "overdrive": { - "name": "오버드라이브", - "effect": "기타나 베이스를 쳐서 큰 울림과 강한 진동을 상대에게 전달하여 공격한다." - }, - "appleAcid": { - "name": "사과산", - "effect": "새콤한 사과에서 만들어 낸 산성 액체로 공격한다. 상대의 특수방어를 떨어뜨린다." - }, - "gravApple": { - "name": "G의힘", - "effect": "높은 곳에서 사과를 떨어뜨려서 데미지를 준다. 상대의 방어를 떨어뜨린다." - }, - "spiritBreak": { - "name": "소울크래시", - "effect": "맞으면 기가 꺾여버릴 것 같은 기세로 공격한다. 상대의 특수공격을 떨어뜨린다." - }, - "strangeSteam": { - "name": "원더스팀", - "effect": "연기를 분출해서 상대를 공격한다. 혼란시킬 때가 있다." - }, - "lifeDew": { - "name": "생명의물방울", - "effect": "신비한 물을 흩뿌려서 자신과 배틀에 나와 있는 같은 편의 HP를 회복한다." - }, - "obstruct": { - "name": "블로킹", - "effect": "상대의 공격을 전혀 받지 않는다. 연속으로 쓰면 실패하기 쉽다. 접촉한 상대의 방어를 크게 떨어뜨린다." - }, - "falseSurrender": { - "name": "사죄의찌르기", - "effect": "고개를 숙이는 척하면서 흐트러진 머리카락으로 찌른다. 공격은 반드시 명중한다." - }, - "meteorAssault": { - "name": "스타어설트", - "effect": "굵은 줄기를 휘둘러서 공격한다. 단 자신도 비틀거리기 때문에 다음 턴은 움직일 수 없다." - }, - "eternabeam": { - "name": "무한다이빔", - "effect": "본래의 모습이 된 무한다이노 최대의 공격. 다음 턴은 움직일 수 없다." - }, - "steelBeam": { - "name": "철제광선", - "effect": "전신에서 끌어모은 강철을 빔으로 바꿔 세차게 발사한다. 자신도 데미지를 받는다." - }, - "expandingForce": { - "name": "와이드포스", - "effect": "사이코 파워로 상대를 공격한다. 사이코필드일 때는 위력이 오르며 모든 상대에게 데미지를 준다." - }, - "steelRoller": { - "name": "아이언롤러", - "effect": "필드를 파괴하면서 공격한다. 필드가 어떤 상태로든 변해 있지 않은 경우 기술은 실패한다." - }, - "scaleShot": { - "name": "스케일샷", - "effect": "비늘을 쏘아서 공격한다. 2-5회 동안 연속으로 쓴다. 스피드가 올라가지만 방어가 떨어진다." - }, - "meteorBeam": { - "name": "메테오빔", - "effect": "1턴째에 우주의 힘을 모아서 특수공격을 올리고 2턴째에 상대를 공격한다." - }, - "shellSideArm": { - "name": "셸암즈", - "effect": "물리와 특수 중 더 많은 데미지를 줄 수 있는 능력으로 공격한다. 독 상태로 만들 때가 있다." - }, - "mistyExplosion": { - "name": "미스트버스트", - "effect": "자신의 주위에 있는 모두를 공격하지만 사용하면 기절한다. 미스트필드일 때 위력이 올라간다." - }, - "grassyGlide": { - "name": "그래스슬라이더", - "effect": "지면에 미끄러지듯 상대를 공격한다. 그래스필드일 때 반드시 선제공격할 수 있다." - }, - "risingVoltage": { - "name": "라이징볼트", - "effect": "지면에서 올라오는 전격으로 공격한다. 상대가 일렉트릭필드 위에 있을 때 기술의 위력이 2배가 된다." - }, - "terrainPulse": { - "name": "대지의파동", - "effect": "필드의 힘을 빌려서 공격한다. 사용했을 때의 필드 상태에 따라서 기술 타입과 위력이 바뀐다." - }, - "skitterSmack": { - "name": "엄습하는일격", - "effect": "배후에서 엄습해서 공격한다. 상대의 특수공격을 떨어뜨린다." - }, - "burningJealousy": { - "name": "질투의불꽃", - "effect": "질투의 에너지로 상대를 공격한다. 그 턴에 능력이 올라간 포켓몬을 화상 상태로 만든다." - }, - "lashOut": { - "name": "분풀이", - "effect": "상대에 대한 울분이 담긴 공격을 한다. 그 턴에 능력이 떨어져 있으면 기술의 위력이 2배가 된다." - }, - "poltergeist": { - "name": "폴터가이스트", - "effect": "상대의 지닌 물건을 조종해서 공격한다. 상대가 도구를 지니고 있지 않으면 실패한다." - }, - "corrosiveGas": { - "name": "부식가스", - "effect": "주위에 있는 모든 것을 강력한 산성 가스로 뒤덮어서 지니고 있는 도구를 녹여버린다." - }, - "coaching": { - "name": "코칭", - "effect": "적절한 지도를 통해서 같은 편 전원의 공격과 방어를 올린다." - }, - "flipTurn": { - "name": "퀵턴", - "effect": "공격한 뒤 굉장한 스피드로 돌아와서 교대 포켓몬과 교체한다." - }, - "tripleAxel": { - "name": "트리플악셀", - "effect": "3회 연속으로 킥을 날려 공격한다. 기술이 맞을 때마다 위력이 올라간다." - }, - "dualWingbeat": { - "name": "더블윙", - "effect": "날개를 상대에게 부딪쳐서 공격한다. 2회 연속으로 데미지를 준다." - }, - "scorchingSands": { - "name": "열사의대지", - "effect": "뜨겁게 달궈진 모래를 상대에게 부딪쳐서 공격한다. 화상 상태로 만들 때가 있다." - }, - "jungleHealing": { - "name": "정글힐", - "effect": "정글과 하나가 되어 자신과 배틀에 나와 있는 같은 편의 HP와 모든 상태를 회복한다." - }, - "wickedBlow": { - "name": "암흑강타", - "effect": "악의 태세가 극에 달하여 강렬한 일격을 날린다. 반드시 급소에 맞는다." - }, - "surgingStrikes": { - "name": "수류연타", - "effect": "물의 태세가 극에 달하여 물 흐르듯 3회의 연격을 날린다. 반드시 급소에 맞는다." - }, - "thunderCage": { - "name": "썬더프리즌", - "effect": "전기가 흐르는 우리 안에 4-5턴 동안 상대를 가두어 공격한다." - }, - "dragonEnergy": { - "name": "드래곤에너지", - "effect": "생명력을 파워로 바꿔서 상대를 공격한다. 자신의 HP가 적을수록 기술의 위력이 떨어진다." - }, - "freezingGlare": { - "name": "얼어붙는시선", - "effect": "두 눈에서 사이코 파워를 발사해서 공격한다. 얼음 상태로 만들 때가 있다." - }, - "fieryWrath": { - "name": "타오르는분노", - "effect": "분노를 불꽃 같은 오라로 바꿔서 공격한다. 상대를 풀죽게 만들 때가 있다." - }, - "thunderousKick": { - "name": "천둥차기", - "effect": "번개 같은 움직임으로 상대를 농락하며 킥을 날린다. 상대의 방어를 떨어뜨린다." - }, - "glacialLance": { - "name": "블리자드랜스", - "effect": "눈보라를 두른 얼음의 창을 상대에게 던져서 공격한다." - }, - "astralBarrage": { - "name": "아스트랄비트", - "effect": "수많은 작은 영체를 상대에게 부딪쳐서 공격한다." - }, - "eerieSpell": { - "name": "섬뜩한주문", - "effect": "강력한 사이코 파워로 공격한다. 상대가 마지막으로 사용한 기술의 PP를 3만큼 줄인다." - }, - "direClaw": { - "name": "페이탈클로", - "effect": "치명적인 손톱으로 공격한다. 상대를 독, 마비, 잠듦 중 하나의 상태로 만들 때가 있다." - }, - "psyshieldBash": { - "name": "배리어러시", - "effect": "사념의 에너지를 두른 채로 상대에게 부딪친다. 자신의 방어를 올린다." - }, - "powerShift": { - "name": "파워시프트", - "effect": "자신의 공격력과 방어력을 바꾼다." - }, - "stoneAxe": { - "name": "암석액스", - "effect": "암석 도끼로 공격한다. 흩어진 암석 파편은 상대의 주위에 떠다니게 된다." - }, - "springtideStorm": { - "name": "봄의폭풍", - "effect": "애증 섞인 강렬한 바람으로 상대를 둘러싸서 공격한다. 상대의 공격을 떨어뜨릴 때가 있다." - }, - "mysticalPower": { - "name": "신비의힘", - "effect": "신비한 힘으로 자신을 강화한다. 자신의 특수공격이 올라간다." - }, - "ragingFury": { - "name": "대격분", - "effect": "2~3턴 동안 불꽃을 마구 뿜어 대며 난동을 부린다. 난동 부린 뒤에는 혼란에 빠진다." - }, - "waveCrash": { - "name": "웨이브태클", - "effect": "물을 두르고 온몸으로 상대에게 부딪친다. 자신도 상당한 데미지를 입는다." - }, - "chloroblast": { - "name": "클로로블라스트", - "effect": "엽록소를 모은 뒤 발사하여 공격한다. 자신도 데미지를 입는다." - }, - "mountainGale": { - "name": "빙산바람", - "effect": "빙산처럼 커다란 얼음덩어리를 부딪쳐서 공격한다. 상대를 풀죽게 만들 때가 있다." - }, - "victoryDance": { - "name": "승리의춤", - "effect": "승리를 부르는 춤을 격렬하게 춘다. 자신의 공격과 방어와 스피드를 올린다." - }, - "headlongRush": { - "name": "들이받기", - "effect": "온 힘을 다한 몸통박치기를 날린다. 자신의 방어와 특수방어가 떨어진다." - }, - "barbBarrage": { - "name": "독침천밭", - "effect": "무수히 많은 독침으로 공격한다. 상대를 독 상태로 만들 때가 있다. 상대가 독 상태인 경우 위력이 2배가 된다." - }, - "esperWing": { - "name": "오라윙", - "effect": "오라로 강화한 날개로 베어 가른다. 급소에 맞기 쉽다. 자신의 스피드를 올린다." - }, - "bitterMalice": { - "name": "천추지한", - "effect": "등골이 서늘해지는 원념으로 공격해서 상대의 공격을 떨어뜨린다." - }, - "shelter": { - "name": "농성", - "effect": "피부를 강철 방패처럼 단단하게 만들어서 자신의 방어를 크게 올린다." - }, - "tripleArrows": { - "name": "3연화살", - "effect": "발 기술을 사용하고 3개의 화살을 동시에 발사한다. 상대의 방어를 떨어뜨리거나 풀죽게 만들 때가 있다. 급소에 맞기 쉽다." - }, - "infernalParade": { - "name": "백귀야행", - "effect": "무수히 많은 불덩이로 공격한다. 화상 상태로 만들 때가 있다. 상대가 상태 이상인 경우 위력이 2배가 된다." - }, - "ceaselessEdge": { - "name": "비검천중파", - "effect": "조개껍질 검으로 공격한다. 조개껍질 파편은 압정이 되어 상대의 발밑에 흩어진다." - }, - "bleakwindStorm": { - "name": "찬바람폭풍", - "effect": "심신을 모두 떨게 만드는 차갑고도 거친 바람으로 공격한다. 상대의 스피드를 떨어뜨릴 때가 있다." - }, - "wildboltStorm": { - "name": "번개폭풍", - "effect": "폭풍을 일으키고 뇌운을 불러서 번개와 바람으로 매섭게 공격한다. 상대를 마비 상태로 만들 때가 있다." - }, - "sandsearStorm": { - "name": "열사의폭풍", - "effect": "뜨겁게 달궈진 모래와 강렬한 바람으로 상대를 둘러싸서 공격한다. 상대를 화상 상태로 만들 때가 있다." - }, - "lunarBlessing": { - "name": "초승달의기도", - "effect": "초승달에 기도를 하여 자신과 같은 편의 HP와 상태 이상을 모두 회복한다." - }, - "takeHeart": { - "name": "브레이브차지", - "effect": "기운을 고조시켜서 자신의 상태 이상을 회복하고 특수공격과 특수방어를 올린다." - }, - "gMaxWildfire": { - "name": "거다이옥염", - "effect": "거다이맥스한 리자몽이 사용하는 불꽃타입 공격. 4턴 동안 데미지를 준다." - }, - "gMaxBefuddle": { - "name": "거다이고혹", - "effect": "거다이맥스한 버터플이 사용하는 벌레타입 공격. 독 마비 잠듦 중 어느 하나로 만든다." - }, - "gMaxVoltCrash": { - "name": "거다이만뢰", - "effect": "거다이맥스한 피카츄가 사용하는 전기타입 공격. 상대를 마비 상태로 만든다." - }, - "gMaxGoldRush": { - "name": "거다이금화", - "effect": "거다이맥스한 나옹이 사용하는 노말타입 공격. 상대를 혼란시키고 돈도 받을 수 있다." - }, - "gMaxChiStrike": { - "name": "거다이회심격", - "effect": "거다이맥스한 괴력몬이 사용하는 격투타입 공격. 급소에 맞기 쉬워진다." - }, - "gMaxTerror": { - "name": "거다이환영", - "effect": "거다이맥스한 팬텀이 사용하는 고스트타입 공격. 그림자를 밟아 교체할 수 없게 한다." - }, - "gMaxResonance": { - "name": "거다이선율", - "effect": "거다이맥스한 라프라스가 사용하는 얼음타입 공격. 5턴 동안 데미지를 약하게 한다." - }, - "gMaxCuddle": { - "name": "거다이포옹", - "effect": "거다이맥스한 이브이가 사용하는 노말타입 공격. 상대를 헤롱헤롱하게 만든다." - }, - "gMaxReplenish": { - "name": "거다이재생", - "effect": "거다이맥스한 잠만보가 사용하는 노말타입 공격. 먹은 나무열매를 재생한다." - }, - "gMaxMalodor": { - "name": "거다이악취", - "effect": "거다이맥스한 더스트나가 사용하는 독타입 공격. 상대를 독 상태로 만든다." - }, - "gMaxStonesurge": { - "name": "거다이암진", - "effect": "거다이맥스한 갈가부기가 사용하는 물타입 공격. 예리한 바위를 무수히 뿌린다." - }, - "gMaxWindRage": { - "name": "거다이풍격", - "effect": "거다이맥스한 아머까오가 사용하는 비행타입 공격. 리플렉터나 빛의장막을 없앤다." - }, - "gMaxStunShock": { - "name": "거다이감전", - "effect": "거다이맥스한 스트린더가 사용하는 전기타입 공격. 독이나 마비 상태로 만든다." - }, - "gMaxFinale": { - "name": "거다이단원", - "effect": "거다이맥스한 마휘핑이 사용하는 페어리타입 공격. 같은 편의 HP를 회복한다." - }, - "gMaxDepletion": { - "name": "거다이감쇠", - "effect": "거다이맥스한 두랄루돈이 사용하는 드래곤타입 공격. 마지막에 사용한 기술의 PP를 줄인다." - }, - "gMaxGravitas": { - "name": "거다이천도", - "effect": "거다이맥스한 이올브가 사용하는 에스퍼타입 공격. 5턴 동안 중력이 바뀐다." - }, - "gMaxVolcalith": { - "name": "거다이분석", - "effect": "거다이맥스한 석탄산이 사용하는 바위타입 공격. 4턴 동안 데미지를 준다." - }, - "gMaxSandblast": { - "name": "거다이사진", - "effect": "거다이맥스한 사다이사가 사용하는 땅타입 공격. 4-5턴 동안 거친 모래바람이 분다." - }, - "gMaxSnooze": { - "name": "거다이수마", - "effect": "거다이맥스한 오롱털이 사용하는 악타입 공격. 큰 하품으로 졸음을 유도한다." - }, - "gMaxTartness": { - "name": "거다이산격", - "effect": "거다이맥스한 애프룡이 사용하는 풀타입 공격. 상대의 회피율을 떨어뜨린다." - }, - "gMaxSweetness": { - "name": "거다이감로", - "effect": "거다이맥스한 단지래플이 사용하는 풀타입 공격. 같은 편의 상태 이상을 회복한다." - }, - "gMaxSmite": { - "name": "거다이천벌", - "effect": "거다이맥스한 브리무음이 사용하는 페어리타입 공격. 상대를 혼란시킨다." - }, - "gMaxSteelsurge": { - "name": "거다이강철진", - "effect": "거다이맥스한 대왕끼리동이 사용하는 강철타입 공격. 예리한 가시를 무수히 뿌린다." - }, - "gMaxMeltdown": { - "name": "거다이융격", - "effect": "거다이맥스한 멜메탈이 사용하는 강철타입 공격. 똑같은 기술을 2회 연속으로 쓸 수 없게 한다." - }, - "gMaxFoamBurst": { - "name": "거다이포말", - "effect": "거다이맥스한 킹크랩이 사용하는 물타입 공격. 상대의 스피드를 크게 떨어뜨린다." - }, - "gMaxCentiferno": { - "name": "거다이백화", - "effect": "거다이맥스한 다태우지네가 사용하는 불꽃타입 공격. 4-5턴 동안 불꽃 속에 가둔다." - }, - "gMaxVineLash": { - "name": "거다이편달", - "effect": "거다이맥스한 이상해꽃이 사용하는 풀타입 공격. 4턴 동안 데미지를 준다." - }, - "gMaxCannonade": { - "name": "거다이포격", - "effect": "거다이맥스한 거북왕이 사용하는 물타입 공격. 4턴 동안 데미지를 준다." - }, - "gMaxDrumSolo": { - "name": "거다이난타", - "effect": "거다이맥스한 고릴타가 사용하는 풀타입 공격. 상대의 특성에 영향을 받지 않는다." - }, - "gMaxFireball": { - "name": "거다이화염구", - "effect": "거다이맥스한 에이스번이 사용하는 불꽃타입 공격. 상대의 특성에 영향을 받지 않는다." - }, - "gMaxHydrosnipe": { - "name": "거다이저격", - "effect": "거다이맥스한 인텔리레온이 사용하는 물타입 공격. 상대의 특성에 영향을 받지 않는다." - }, - "gMaxOneBlow": { - "name": "거다이일격", - "effect": "거다이맥스한 우라오스가 사용하는 악타입 공격. 다이월을 무시하는 일격을 날린다." - }, - "gMaxRapidFlow": { - "name": "거다이연격", - "effect": "거다이맥스한 우라오스가 사용하는 물타입 공격. 다이월을 무시하는 연격을 날린다." - }, - "teraBlast": { - "name": "테라버스트", - "effect": "테라스탈 중이면, 테라스탈타입의 에너지를 방출해서 공격한다. 공격과 특수공격을 비교해서 높은 쪽으로 데미지를 준다." - }, - "silkTrap": { - "name": "스레드트랩", - "effect": "실로 함정을 만들어 둘러친다. 상대의 공격을 막음과 동시에 접촉한 상대의 스피드를 떨어뜨린다." - }, - "axeKick": { - "name": "발꿈치찍기", - "effect": "발꿈치를 들어 올린 뒤 내리찍어 공격한다. 상대를 혼란시킬 때가 있다. 빗나가면 자신이 데미지를 입는다." - }, - "lastRespects": { - "name": "성묘", - "effect": "동료의 한을 풀어 주기 위해 공격한다. 쓰러진 같은 편 포켓몬이 많을수록 기술의 위력이 올라간다." - }, - "luminaCrash": { - "name": "루미나콜리전", - "effect": "정신에도 작용하는 기묘한 빛을 발산해서 공격한다. 상대의 특수방어를 크게 떨어뜨린다." - }, - "orderUp": { - "name": "한판내기", - "effect": "멋들어진 몸놀림으로 공격한다. 입속에 싸리용이 있으면 싸리용의 모습에 따라 능력이 올라간다." - }, - "jetPunch": { - "name": "제트펀치", - "effect": "거센 물살을 주먹에 둘러 눈에 보이지 않는 속도로 펀치를 날린다. 반드시 선제공격할 수 있다." - }, - "spicyExtract": { - "name": "하바네로엑기스", - "effect": "어마어마하게 매운 엑기스를 발사한다. 상대의 공격이 크게 오르고 방어는 크게 떨어진다." - }, - "spinOut": { - "name": "휠스핀", - "effect": "발에 부하를 걸어 격렬하게 회전하며 데미지를 준다. 자신의 스피드가 크게 떨어진다." - }, - "populationBomb": { - "name": "찍찍베기", - "effect": "여기저기서 동료들을 모아서 화려한 콤비네이션으로 공격한다. 1~10회 연속으로 공격한다." - }, - "iceSpinner": { - "name": "아이스스피너", - "effect": "발에 얇은 얼음을 두르고 빙글빙글 회전하며 부딪친다. 회전 운동에 의해 필드가 파괴된다." - }, - "glaiveRush": { - "name": "대검돌격", - "effect": "몸을 내던지는 무모한 돌격. 기술을 사용한 다음, 상대의 공격이 반드시 명중하고 데미지를 2배로 입게 된다." - }, - "revivalBlessing": { - "name": "회생의기도", - "effect": "자애로운 마음으로 기도를 하여 기절한 교대 포켓몬을 HP가 절반인 상태로 부활시킨다." - }, - "saltCure": { - "name": "소금절이", - "effect": "상대를 소금절이 상태로 만들어 매 턴 데미지를 준다. 강철타입이나 물타입에게 더 고통스럽다." - }, - "tripleDive": { - "name": "트리플다이브", - "effect": "호흡이 척척 맞게 다이빙해서 상대에게 물보라를 끼얹는다. 3회 연속으로 데미지를 준다." - }, - "mortalSpin": { - "name": "킬러스핀", - "effect": "회전해서 상대를 공격한다. 조이기, 김밥말이, 씨뿌리기 등의 효과를 날려버린다. 상대를 독 상태로 만든다." - }, - "doodle": { - "name": "베껴그리기", - "effect": "상대의 본질을 꿰뚫어 보고 베껴서 자신과 같은 편을 상대와 같은 특성으로 바꾼다." - }, - "filletAway": { - "name": "제살깎기", - "effect": "자신의 HP를 깎아서 자신의 공격, 특수공격, 스피드를 크게 올린다." - }, - "kowtowCleave": { - "name": "도각참", - "effect": "머리를 조아려 상대를 방심하게 만든 뒤에 베어 버린다. 공격은 반드시 명중한다." - }, - "flowerTrick": { - "name": "트릭플라워", - "effect": "숨겨진 장치가 있는 꽃다발을 상대에게 던져서 공격한다. 반드시 명중하며 급소에 맞는다." - }, - "torchSong": { - "name": "플레어송", - "effect": "활활 타오르는 불꽃을 노래하듯 뿜어서 상대를 태워 버린다. 자신의 특수공격을 올린다." - }, - "aquaStep": { - "name": "아쿠아스텝", - "effect": "물 흐르듯 민첩하고 경쾌한 발재간으로 상대를 농락하며 데미지를 준다. 자신의 스피드를 올린다." - }, - "ragingBull": { - "name": "레이징불", - "effect": "분노해 날뛰는 성난소의 맹렬한 태클. 폼에 따라 기술의 타입이 달라지고 빛의장막이나 리플렉터 등도 파괴할 수 있다." - }, - "makeItRain": { - "name": "골드러시", - "effect": "대량의 코인을 날려서 공격한다. 자신의 특수공격이 떨어진다. 배틀 후에 돈을 받을 수 있다." - }, - "psyblade": { - "name": "사이코블레이드", - "effect": "실체가 없는 칼날로 상대를 베어 가른다. 일렉트릭필드 위에 있을 때 기술의 위력이 1.5배가 된다." - }, - "hydroSteam": { - "name": "하이드로스팀", - "effect": "펄펄 끓는 물을 기세 좋게 뿜어낸다. 햇살이 강할 때 기술의 위력이 떨어지기는커녕 1.5배가 된다." - }, - "ruination": { - "name": "카타스트로피", - "effect": "파멸적인 재앙에 휩쓸리게 하여 상대의 HP를 절반으로 만든다." - }, - "collisionCourse": { - "name": "액셀브레이크", - "effect": "변형하며 거칠게 낙하한 다음 고대의 대폭발을 일으킨다. 약점인 상대에게는 위력이 더욱 올라간다." - }, - "electroDrift": { - "name": "라이트닝드라이브", - "effect": "변형하며 초고속으로 달려서 미지의 전격으로 상대를 관통한다. 약점인 상대에게는 위력이 더욱 올라간다." - }, - "shedTail": { - "name": "꼬리자르기", - "effect": "자신의 HP를 깎아서 분신을 만든 뒤, 돌아와서 교대 포켓몬과 교체한다." - }, - "chillyReception": { - "name": "썰렁개그", - "effect": "자리를 얼어붙게 만드는 개그를 하고 교대 포켓몬과 교체한다. 5턴 동안 눈을 내리게 한다." - }, - "tidyUp": { - "name": "정리정돈", - "effect": "압정뿌리기, 스텔스록, 끈적끈적네트, 독압정, 대타출동을 모두 정리한다. 자신의 공격력과 스피드가 올라간다." - }, - "snowscape": { - "name": "설경", - "effect": "5턴 동안 눈을 내리게 한다. 얼음타입의 방어가 올라간다." - }, - "pounce": { - "name": "달려들기", - "effect": "상대에게 달려들어 공격한다. 상대의 스피드를 떨어뜨린다." - }, - "trailblaze": { - "name": "개척하기", - "effect": "풀숲에서 튀어나오듯이 공격한다. 경쾌한 발재간으로 자신의 스피드를 올린다." - }, - "chillingWater": { - "name": "찬물끼얹기", - "effect": "상대의 기운이 빠질 정도로 차가운 물을 끼얹어서 공격한다. 상대의 공격을 떨어뜨린다." - }, - "hyperDrill": { - "name": "하이퍼드릴", - "effect": "뾰족한 신체 부위를 급속도로 회전시켜 관통한다. 방어나 판별 등도 무시할 수 있다." - }, - "twinBeam": { - "name": "트윈빔", - "effect": "두 눈에서 불가사의한 광선을 발사해서 공격한다. 2회 연속으로 데미지를 준다." - }, - "rageFist": { - "name": "분노의주먹", - "effect": "분노를 에너지로 바꿔서 공격한다. 받은 공격의 횟수가 많을수록 기술의 위력이 올라간다." - }, - "armorCannon": { - "name": "아머캐논", - "effect": "자신의 갑옷을 활활 타오르는 탄환으로 발사해서 공격한다. 자신의 방어와 특수방어가 떨어진다." - }, - "bitterBlade": { - "name": "원념의칼", - "effect": "현세의 미련을 칼끝에 담아 베어 버린다. 입힌 데미지의 절반에 해당하는 HP를 회복할 수 있다." - }, - "doubleShock": { - "name": "전광쌍격", - "effect": "전신의 전기를 모두 방출해서 큰 데미지를 준다. 자신의 전기타입이 없어진다." - }, - "gigatonHammer": { - "name": "거대해머", - "effect": "거대한 해머를 온몸으로 휘둘러서 공격한다. 이 기술은 2회 연속으로 쓸 수 없다." - }, - "comeuppance": { - "name": "앙갚음", - "effect": "기술을 쓰기 전에 마지막으로 받은 기술의 데미지를 늘려서 기술을 쓴 상대에게 돌려준다." - }, - "aquaCutter": { - "name": "아쿠아커터", - "effect": "압력을 가한 물을 칼날처럼 분사해서 상대를 베어 가른다. 급소에 맞기 쉽다." - }, - "blazingTorque": { - "name": "번액셀", - "effect": "타오르는 엔진으로 상대에게 부릉거린다. 화상 상태로 만들 때가 있다." - }, - "wickedTorque": { - "name": "다크액셀", - "effect": "악의적으로 상대를 향해 부릉거린다. 잠듦 상태로 만들 때가 있다." - }, - "noxiousTorque": { - "name": "포이즌액셀", - "effect": "독성 엔진으로 상대에게 부릉거린다. 독 상태로 만들 때가 있다." - }, - "combatTorque": { - "name": "파이트액셀", - "effect": "상대를 향해 기세 좋게 부릉거린다. 마비 상태로 만들 때가 있다." - }, - "magicalTorque": { - "name": "매지컬액셀", - "effect": "메르헨틱한 엔진으로 상대에게 부릉거린다. 상대를 혼란시킬 때가 있다." - }, - "bloodMoon": { - "name": "블러드문", - "effect": "피와 같이 붉은 보름달에서 혼신의 기백을 발사한다. 이 기술은 2회 연속으로 쓸 수 없다." - }, - "matchaGotcha": { - "name": "휘적휘적포", - "effect": "휘저은 차를 대포처럼 발사해 준 데미지의 절반을 HP로 회복한다. 화상 상태로 만들 때도 있다." - }, - "syrupBomb": { - "name": "시럽봄", - "effect": "끈적끈적한 물엿을 폭발시킨다. 상대를 물엿범벅 상태로 만들어서 3턴 동안 계속 스피드를 떨어뜨린다." - }, - "ivyCudgel": { - "name": "덩굴방망이", - "effect": "덩굴을 휘감은 방망이로 때린다. 쓰고 있는 가면에 따라 타입이 바뀐다. 급소에 맞기 쉽다." - }, - "electroShot": { - "name": "일렉트로빔", - "effect": "1턴째에 전기를 모아서 특수공격을 올리고 2턴째에 고압의 전기를 발사한다. 비가 오는 날씨일 때는 바로 발사할 수 있다." - }, - "teraStarstorm": { - "name": "테라클러스터", - "effect": "결정의 힘을 내리쬐어 적을 없애 버린다. 테라파고스가 스텔라폼일 때 사용하면 모든 상대에게 데미지를 준다." - }, - "fickleBeam": { - "name": "변덕레이저", - "effect": "광선을 발사해서 공격한다. 가끔 다른 머리도 협력해서 레이저를 발사하여 위력이 2배가 된다." - }, - "burningBulwark": { - "name": "화염의수호", - "effect": "상대의 공격을 초고열의 털로 방어하는 동시에 접촉한 상대를 화상 상태로 만든다." - }, - "thunderclap": { - "name": "질풍신뢰", - "effect": "상대보다 먼저 전격을 퍼붓는다. 상대가 쓴 기술이 공격 기술이 아니면 실패한다." - }, - "mightyCleave": { - "name": "파워풀에지", - "effect": "머리에 축적된 빛으로 절단한다. 기술 방어를 무시하고 공격할 수 있다." - }, - "tachyonCutter": { - "name": "타키온커터", - "effect": "입자로 된 칼날을 연이어 발사해서 2회 연속으로 데미지를 준다. 공격은 반드시 명중한다." - }, - "hardPress": { - "name": "하드프레스", - "effect": "팔이나 집게로 상대를 압박한다. 상대의 HP가 남아 있을수록 위력이 올라간다." - }, - "dragonCheer": { - "name": "드래곤옐", - "effect": "용의 북돋움으로 사기를 높여서 같은 편의 기술이 급소에 맞기 쉬워진다. 드래곤타입이면 더욱더 사기가 북돋는다." - }, - "alluringVoice": { - "name": "매혹의보이스", - "effect": "천사와도 같은 노랫소리로 상대를 공격한다. 그 턴에 능력이 올라간 포켓몬을 혼란 상태로 만든다." - }, - "temperFlare": { - "name": "열불내기", - "effect": "자포자기하는 기세로 공격한다. 앞 턴에서 기술이 빗나갔다면 위력이 배가 된다." - }, - "supercellSlam": { - "name": "썬더다이브", - "effect": "몸에 전기를 두르고 상대를 덮친다. 빗나가면 자신이 데미지를 입는다." - }, - "psychicNoise": { - "name": "사이코노이즈", - "effect": "불쾌한 음파를 상대에게 날려서 공격한다. 2턴 동안 상대는 기술이나 특성 또는 지니고 있는 도구로 HP를 회복할 수 없게 된다." - }, - "upperHand": { - "name": "기선제압", - "effect": "움직임에 반응하여 손바닥으로 밀쳐서 상대를 풀죽게 한다. 상대가 쓴 기술이 선제공격 기술이 아니면 실패한다." - }, - "malignantChain": { - "name": "악독사슬", - "effect": "독으로 된 사슬로 상대를 휘감은 뒤 독소를 흘려보내어 해치운다. 맹독 상태로 만들 때가 있다." - } -} diff --git a/src/locales/ko/nature.json b/src/locales/ko/nature.json deleted file mode 100644 index 5c025f44612..00000000000 --- a/src/locales/ko/nature.json +++ /dev/null @@ -1,27 +0,0 @@ -{ - "Hardy": "노력", - "Lonely": "외로움", - "Brave": "용감", - "Adamant": "고집", - "Naughty": "개구쟁이", - "Bold": "대담", - "Docile": "온순", - "Relaxed": "무사태평", - "Impish": "장난꾸러기", - "Lax": "촐랑", - "Timid": "겁쟁이", - "Hasty": "성급", - "Serious": "성실", - "Jolly": "명랑", - "Naive": "천진난만", - "Modest": "조심", - "Mild": "의젓", - "Quiet": "냉정", - "Bashful": "수줍음", - "Rash": "덜렁", - "Calm": "차분", - "Gentle": "얌전", - "Sassy": "건방", - "Careful": "신중", - "Quirky": "변덕" -} \ No newline at end of file diff --git a/src/locales/ko/party-ui-handler.json b/src/locales/ko/party-ui-handler.json deleted file mode 100644 index 6e7ba120b71..00000000000 --- a/src/locales/ko/party-ui-handler.json +++ /dev/null @@ -1,50 +0,0 @@ -{ - "SEND_OUT": "교체한다", - "SUMMARY": "능력치를 본다", - "CANCEL": "그만둔다", - "RELEASE": "놓아준다", - "APPLY": "사용한다", - "TEACH": "가르친다", - "SPLICE": "융합", - "UNSPLICE": "융합 해제", - "ACTIVATE": "발동", - "DEACTIVATE": "해제", - "TRANSFER": "건넨다", - "ALL": "전부", - "PASS_BATON": "배턴터치한다", - "UNPAUSE_EVOLUTION": "진화 재개", - "PAUSE_EVOLUTION": "진화 중지", - "REVIVE": "되살린다", - "RENAME": "닉네임 바꾸기", - "SELECT": "선택한다", - "choosePokemon": "포켓몬을 선택하세요.", - "doWhatWithThisPokemon": "포켓몬을 어떻게 하겠습니까?", - "noEnergy": "{{pokemonName}}[[는]] 싸울 수 있는\n기력이 남아 있지 않습니다!", - "hasEnergy": "{{pokemonName}}[[는]]\n아직도 힘이 넘친다!", - "cantBeUsed": "{{pokemonName}}[[는]] 이 챌린지에서는\n쓸 수 없습니다.", - "tooManyItems": "{{pokemonName}}[[는]] 지닌 도구의 수가\n너무 많습니다", - "anyEffect": "써도 효과가 없다.", - "unpausedEvolutions": "{{pokemonName}}의 진화가 재개되었다.", - "pausedEvolutions": "{{pokemonName}}[[가]] 진화하지 않도록 했다.", - "unspliceConfirmation": "{{pokemonName}}로부터 {{fusionName}}의 융합을 해제하시겠습니까?\n{{fusionName}}는 사라지게 됩니다.", - "wasReverted": "{{fusionName}}은 {{pokemonName}}의 모습으로 돌아갔습니다!", - "releaseConfirmation": "{{pokemonName}}[[를]]\n정말 놓아주겠습니까?", - "releaseInBattle": "전투 중인 포켓몬은\n놓아줄 수 없습니다.", - "selectAMove": "기술을 선택해 주십시오", - "changeQuantity": "건네줄 지닌 도구를 선택해 주십시오.\n< 와 > 로 수량을 변경할 수 있습니다.", - "selectAnotherPokemonToSplice": "융합할 포켓몬을 선택해 주십시오.", - "cancel": "그만둔다", - "able": "배운다!", - "notAble": "배우지 못함", - "learned": "알고 있다", - "goodbye": "잘 가, {{pokemonName}}!", - "byebye": "바이바이, {{pokemonName}}!", - "farewell": "작별이야, {{pokemonName}}!", - "soLong": "안녕, {{pokemonName}}!", - "thisIsWhereWePart": "여기서 헤어지자, {{pokemonName}}!", - "illMissYou": "보고 싶을거야, {{pokemonName}}!", - "illNeverForgetYou": "잊지 못할거야, {{pokemonName}}!", - "untilWeMeetAgain": "다시 만날 때까지, {{pokemonName}}!", - "sayonara": "사요나라, {{pokemonName}}!", - "smellYaLater": "또 보자, {{pokemonName}}!" -} \ No newline at end of file diff --git a/src/locales/ko/pokeball.json b/src/locales/ko/pokeball.json deleted file mode 100644 index eab6ac91df6..00000000000 --- a/src/locales/ko/pokeball.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "pokeBall": "몬스터볼", - "greatBall": "슈퍼볼", - "ultraBall": "하이퍼볼", - "rogueBall": "로그볼", - "masterBall": "마스터볼", - "luxuryBall": "럭셔리볼" -} \ No newline at end of file diff --git a/src/locales/ko/pokemon-form-battle.json b/src/locales/ko/pokemon-form-battle.json deleted file mode 100644 index 2dca2b7cf66..00000000000 --- a/src/locales/ko/pokemon-form-battle.json +++ /dev/null @@ -1,14 +0,0 @@ -{ - "mega": "메가{{pokemonName}}", - "mega-x": "메가{{pokemonName}}X", - "mega-y": "메가{{pokemonName}}Y", - "primal": "원시{{pokemonName}}", - "gigantamax": "거다이맥스 {{pokemonName}}", - "eternamax": "무한다이맥스 {{pokemonName}}", - "megaChange": "{{preName}}[[는]]\n{{pokemonName}}[[로]] 메가진화했다!", - "gigantamaxChange": "{{preName}}[[는]]\n{{pokemonName}}가 되었다!", - "eternamaxChange": "{{preName}}[[는]]\n{{pokemonName}}가 되었다!", - "revertChange": "{{pokemonName}}[[는]]\n원래 모습으로 되돌아왔다!", - "formChange": "{{preName}}[[는]]\n다른 모습으로 변화했다!", - "disguiseChange": "탈이 대타가 되었다!" -} \ No newline at end of file diff --git a/src/locales/ko/pokemon-form.json b/src/locales/ko/pokemon-form.json deleted file mode 100644 index 885f9a9b891..00000000000 --- a/src/locales/ko/pokemon-form.json +++ /dev/null @@ -1,170 +0,0 @@ -{ - "pikachuCosplay": "옷갈아입기", - "pikachuCoolCosplay": "하드록", - "pikachuBeautyCosplay": "마담", - "pikachuCuteCosplay": "아이돌", - "pikachuSmartCosplay": "닥터", - "pikachuToughCosplay": "마스크드", - "pikachuPartner": "파트너", - "eeveePartner": "파트너", - "pichuSpiky": "삐쭉귀", - "unownA": "A", - "unownB": "B", - "unownC": "C", - "unownD": "D", - "unownE": "E", - "unownF": "F", - "unownG": "G", - "unownH": "H", - "unownI": "I", - "unownJ": "J", - "unownK": "K", - "unownL": "L", - "unownM": "M", - "unownN": "N", - "unownO": "O", - "unownP": "P", - "unownQ": "Q", - "unownR": "R", - "unownS": "S", - "unownT": "T", - "unownU": "U", - "unownV": "V", - "unownW": "W", - "unownX": "X", - "unownY": "Y", - "unownZ": "Z", - "unownExclamation": "!", - "unownQuestion": "?", - "castformSunny": "태양의 모습", - "castformRainy": "빗방울의 모습", - "castformSnowy": "설운의 모습", - "deoxysNormal": "노말폼", - "burmyPlant": "초목도롱", - "burmySandy": "모래땅도롱", - "burmyTrash": "슈레도롱", - "shellosEast": "동쪽바다의 모습", - "shellosWest": "서쪽바다의 모습", - "rotomHeat": "히트", - "rotomWash": "워시", - "rotomFrost": "프로스트", - "rotomFan": "스핀", - "rotomMow": "커트", - "giratinaAltered": "어나더폼", - "shayminLand": "랜드폼", - "basculinRedStriped": "적색근의 모습", - "basculinBlueStriped": "청색근의 모습", - "basculinWhiteStriped": "백색근의 모습", - "deerlingSpring": "봄의 모습", - "deerlingSummer": "여름의 모습", - "deerlingAutumn": "가을의 모습", - "deerlingWinter": "겨울의 모습", - "tornadusIncarnate": "화신폼", - "thundurusIncarnate": "화신폼", - "landorusIncarnate": "화신폼", - "keldeoOrdinary": "평상시 모습", - "meloettaAria": "보이스폼", - "meloettaPirouette": "스텝폼", - "froakieBattleBond": "유대변화", - "scatterbugMeadow": "화원의 모양", - "scatterbugIcySnow": "빙설의 모양", - "scatterbugPolar": "설국의 모양", - "scatterbugTundra": "설원의 모양", - "scatterbugContinental": "대륙의 모양", - "scatterbugGarden": "정원의 모양", - "scatterbugElegant": "우아한 모양", - "scatterbugModern": "모던한 모양", - "scatterbugMarine": "마린의 모양", - "scatterbugArchipelago": "군도의 모양", - "scatterbugHighPlains": "황야의 모양", - "scatterbugSandstorm": "사진의 모양", - "scatterbugRiver": "대하의 모양", - "scatterbugMonsoon": "스콜의 모양", - "scatterbugSavanna": "사바나의 모양", - "scatterbugSun": "태양의 모양", - "scatterbugOcean": "오션의 모양", - "scatterbugJungle": "정글의 모양", - "scatterbugFancy": "팬시한 모양", - "scatterbugPokeBall": "볼의 모양", - "flabebeRed": "빨간 꽃", - "flabebeYellow": "노란 꽃", - "flabebeOrange": "오렌지색 꽃", - "flabebeBlue": "파란 꽃", - "flabebeWhite": "하얀 꽃", - "furfrouHeart": "하트컷", - "furfrouStar": "스타컷", - "furfrouDiamond": "다이아컷", - "furfrouDebutante": "레이디컷", - "furfrouMatron": "마담컷", - "furfrouDandy": "젠틀컷", - "furfrouLaReine": "퀸컷", - "furfrouKabuki": "가부키컷", - "furfrouPharaoh": "킹덤컷", - "pumpkabooSmall": "작은 사이즈", - "pumpkabooLarge": "큰 사이즈", - "pumpkabooSuper": "특대 사이즈", - "xerneasNeutral": "릴랙스모드", - "xerneasActive": "액티브모드", - "zygarde50": "50%폼", - "zygarde10": "10%폼", - "zygarde50Pc": "스웜체인지 50%폼", - "zygarde10Pc": "스웜체인지 10%폼", - "zygardeComplete": "퍼펙트폼", - "oricorioBaile": "이글이글스타일", - "oricorioPompom": "파칙파칙스타일", - "oricorioPau": "훌라훌라스타일", - "oricorioSensu": "하늘하늘스타일", - "rockruffOwnTempo": "마이페이스", - "miniorRedMeteor": "유성의 모습(빨강)", - "miniorOrangeMeteor": "유성의 모습(주황)", - "miniorYellowMeteor": "유성의 모습(노랑)", - "miniorGreenMeteor": "유성의 모습(초록)", - "miniorBlueMeteor": "유성의 모습(옥색)", - "miniorIndigoMeteor": "유성의 모습(파랑)", - "miniorVioletMeteor": "유성의 모습(보라)", - "miniorRed": "빨간색 코어", - "miniorOrange": "주황색 코어", - "miniorYellow": "노란색 코어", - "miniorGreen": "초록색 코어", - "miniorBlue": "옥색 코어", - "miniorIndigo": "파란색 코어", - "miniorViolet": "보라색 코어", - "mimikyuDisguised": "둔갑한 모습", - "mimikyuBusted": "들킨 모습", - "magearnaOriginal": "500년 전의 색", - "marshadowZenith": "투지를 불태운 마샤도", - "sinisteaPhony": "위작품", - "sinisteaAntique": "진작품", - "eiscueNoIce": "나이스페이스", - "indeedeeMale": "수컷의 모습", - "indeedeeFemale": "암컷의 모습", - "morpekoFullBelly": "배부른 모양", - "zacianHeroOfManyBattles": "역전의 용사", - "zamazentaHeroOfManyBattles": "역전의 용사", - "zarudeDada": "아빠", - "enamorusIncarnate": "화신폼", - "squawkabillyGreenPlumage": "그린 페더", - "squawkabillyBluePlumage": "블루 페더", - "squawkabillyYellowPlumage": "옐로 페더", - "squawkabillyWhitePlumage": "화이트 페더", - "tatsugiriCurly": "젖힌 모습", - "tatsugiriDroopy": "늘어진 모습", - "tatsugiriStretchy": "뻗은 모습", - "gimmighoulChest": "상자폼", - "gimmighoulRoaming": "도보폼", - "koraidonApexBuild": "완전형태", - "koraidonLimitedBuild": "제한형태", - "koraidonSprintingBuild": "질주형태", - "koraidonSwimmingBuild": "유영형태", - "koraidonGlidingBuild": "활공형태", - "miraidonUltimateMode": "컴플리트모드", - "miraidonLowPowerMode": "리미티드모드", - "miraidonDriveMode": "드라이브모드", - "miraidonAquaticMode": "플로트모드", - "miraidonGlideMode": "글라이드모드", - "poltchageistCounterfeit": "가짜배기의 모습", - "poltchageistArtisan": "알짜배기의 모습", - "paldeaTaurosCombat": "컴뱃종", - "paldeaTaurosBlaze": "블레이즈종", - "paldeaTaurosAqua": "워터종" -} \ No newline at end of file diff --git a/src/locales/ko/pokemon-info-container.json b/src/locales/ko/pokemon-info-container.json deleted file mode 100644 index 95e44212e03..00000000000 --- a/src/locales/ko/pokemon-info-container.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "moveset": "기술", - "gender": "성별:", - "ability": "특성:", - "nature": "성격:", - "form": "폼:" -} \ No newline at end of file diff --git a/src/locales/ko/pokemon-info.json b/src/locales/ko/pokemon-info.json deleted file mode 100644 index c708ee93c6e..00000000000 --- a/src/locales/ko/pokemon-info.json +++ /dev/null @@ -1,40 +0,0 @@ -{ - "Stat": { - "HP": "HP", - "HPshortened": "HP", - "ATK": "공격", - "ATKshortened": "공격", - "DEF": "방어", - "DEFshortened": "방어", - "SPATK": "특수공격", - "SPATKshortened": "특공", - "SPDEF": "특수방어", - "SPDEFshortened": "특방", - "SPD": "스피드", - "SPDshortened": "스피드", - "ACC": "명중률", - "EVA": "회피율" - }, - "Type": { - "UNKNOWN": "Unknown", - "NORMAL": "노말", - "FIGHTING": "격투", - "FLYING": "비행", - "POISON": "독", - "GROUND": "땅", - "ROCK": "바위", - "BUG": "벌레", - "GHOST": "고스트", - "STEEL": "강철", - "FIRE": "불꽃", - "WATER": "물", - "GRASS": "풀", - "ELECTRIC": "전기", - "PSYCHIC": "에스퍼", - "ICE": "얼음", - "DRAGON": "드래곤", - "DARK": "악", - "FAIRY": "페어리", - "STELLAR": "스텔라" - } -} diff --git a/src/locales/ko/pokemon-summary.json b/src/locales/ko/pokemon-summary.json deleted file mode 100644 index ca4b7a22b65..00000000000 --- a/src/locales/ko/pokemon-summary.json +++ /dev/null @@ -1,44 +0,0 @@ -{ - "pokemonInfo": "스테이터스", - "status": "상태 이상", - "powerAccuracyCategory": "위력\n명중\n분류", - "type": "타입", - "unknownTrainer": "알수없음", - "ot": "어버이", - "nature": "성격", - "expPoints": "현재 경험치", - "nextLv": "다음 레벨까지", - "cancel": "그만둔다", - "memoString": "{{natureFragment}}.\n{{metFragment}}", - "metFragment": { - "normal": "{{biome}}에서 웨이브{{wave}},\n레벨 {{level}}일 때 만났다.", - "apparently": "{{biome}}에서\n레벨 {{level}}일 때 만난 것 같다." - }, - "natureFragment": { - "Hardy": "{{nature}}하는 성격", - "Lonely": "{{nature}}을 타는 성격", - "Brave": "{{nature}}한 성격", - "Adamant": "{{nature}}스러운 성격", - "Naughty": "{{nature}}같은 성격", - "Bold": "{{nature}}한 성격", - "Docile": "{{nature}}한 성격", - "Relaxed": "{{nature}}한 성격", - "Impish": "{{nature}}같은 성격", - "Lax": "{{nature}}거리는 성격", - "Timid": "{{nature}}같은 성격", - "Hasty": "{{nature}}한 성격", - "Serious": "{{nature}}한 성격", - "Jolly": "{{nature}}한 성격", - "Naive": "{{nature}}한 성격", - "Modest": "{{nature}}스러운 성격", - "Mild": "{{nature}}한 성격", - "Quiet": "{{nature}}한 성격", - "Bashful": "{{nature}}을 타는 성격", - "Rash": "{{nature}}거리는 성격", - "Calm": "{{nature}}한 성격", - "Gentle": "{{nature}}한 성격", - "Sassy": "{{nature}}진 성격", - "Careful": "{{nature}}한 성격", - "Quirky": "{{nature}}스러운 성격" - } -} diff --git a/src/locales/ko/pokemon.json b/src/locales/ko/pokemon.json deleted file mode 100644 index d419c3397b2..00000000000 --- a/src/locales/ko/pokemon.json +++ /dev/null @@ -1,1084 +0,0 @@ -{ - "bulbasaur": "이상해씨", - "ivysaur": "이상해풀", - "venusaur": "이상해꽃", - "charmander": "파이리", - "charmeleon": "리자드", - "charizard": "리자몽", - "squirtle": "꼬부기", - "wartortle": "어니부기", - "blastoise": "거북왕", - "caterpie": "캐터피", - "metapod": "단데기", - "butterfree": "버터플", - "weedle": "뿔충이", - "kakuna": "딱충이", - "beedrill": "독침붕", - "pidgey": "구구", - "pidgeotto": "피죤", - "pidgeot": "피죤투", - "rattata": "꼬렛", - "raticate": "레트라", - "spearow": "깨비참", - "fearow": "깨비드릴조", - "ekans": "아보", - "arbok": "아보크", - "pikachu": "피카츄", - "raichu": "라이츄", - "sandshrew": "모래두지", - "sandslash": "고지", - "nidoran_f": "니드런♀", - "nidorina": "니드리나", - "nidoqueen": "니드퀸", - "nidoran_m": "니드런♂", - "nidorino": "니드리노", - "nidoking": "니드킹", - "clefairy": "삐삐", - "clefable": "픽시", - "vulpix": "식스테일", - "ninetales": "나인테일", - "jigglypuff": "푸린", - "wigglytuff": "푸크린", - "zubat": "주뱃", - "golbat": "골뱃", - "oddish": "뚜벅쵸", - "gloom": "냄새꼬", - "vileplume": "라플레시아", - "paras": "파라스", - "parasect": "파라섹트", - "venonat": "콘팡", - "venomoth": "도나리", - "diglett": "디그다", - "dugtrio": "닥트리오", - "meowth": "나옹", - "persian": "페르시온", - "psyduck": "고라파덕", - "golduck": "골덕", - "mankey": "망키", - "primeape": "성원숭", - "growlithe": "가디", - "arcanine": "윈디", - "poliwag": "발챙이", - "poliwhirl": "슈륙챙이", - "poliwrath": "강챙이", - "abra": "캐이시", - "kadabra": "윤겔라", - "alakazam": "후딘", - "machop": "알통몬", - "machoke": "근육몬", - "machamp": "괴력몬", - "bellsprout": "모다피", - "weepinbell": "우츠동", - "victreebel": "우츠보트", - "tentacool": "왕눈해", - "tentacruel": "독파리", - "geodude": "꼬마돌", - "graveler": "데구리", - "golem": "딱구리", - "ponyta": "포니타", - "rapidash": "날쌩마", - "slowpoke": "야돈", - "slowbro": "야도란", - "magnemite": "코일", - "magneton": "레어코일", - "farfetchd": "파오리", - "doduo": "두두", - "dodrio": "두트리오", - "seel": "쥬쥬", - "dewgong": "쥬레곤", - "grimer": "질퍽이", - "muk": "질뻐기", - "shellder": "셀러", - "cloyster": "파르셀", - "gastly": "고오스", - "haunter": "고우스트", - "gengar": "팬텀", - "onix": "롱스톤", - "drowzee": "슬리프", - "hypno": "슬리퍼", - "krabby": "크랩", - "kingler": "킹크랩", - "voltorb": "찌리리공", - "electrode": "붐볼", - "exeggcute": "아라리", - "exeggutor": "나시", - "cubone": "탕구리", - "marowak": "텅구리", - "hitmonlee": "시라소몬", - "hitmonchan": "홍수몬", - "lickitung": "내루미", - "koffing": "또가스", - "weezing": "또도가스", - "rhyhorn": "뿔카노", - "rhydon": "코뿌리", - "chansey": "럭키", - "tangela": "덩쿠리", - "kangaskhan": "캥카", - "horsea": "쏘드라", - "seadra": "시드라", - "goldeen": "콘치", - "seaking": "왕콘치", - "staryu": "별가사리", - "starmie": "아쿠스타", - "mr_mime": "마임맨", - "scyther": "스라크", - "jynx": "루주라", - "electabuzz": "에레브", - "magmar": "마그마", - "pinsir": "쁘사이저", - "tauros": "켄타로스", - "magikarp": "잉어킹", - "gyarados": "갸라도스", - "lapras": "라프라스", - "ditto": "메타몽", - "eevee": "이브이", - "vaporeon": "샤미드", - "jolteon": "쥬피썬더", - "flareon": "부스터", - "porygon": "폴리곤", - "omanyte": "암나이트", - "omastar": "암스타", - "kabuto": "투구", - "kabutops": "투구푸스", - "aerodactyl": "프테라", - "snorlax": "잠만보", - "articuno": "프리져", - "zapdos": "썬더", - "moltres": "파이어", - "dratini": "미뇽", - "dragonair": "신뇽", - "dragonite": "망나뇽", - "mewtwo": "뮤츠", - "mew": "뮤", - "chikorita": "치코리타", - "bayleef": "베이리프", - "meganium": "메가니움", - "cyndaquil": "브케인", - "quilava": "마그케인", - "typhlosion": "블레이범", - "totodile": "리아코", - "croconaw": "엘리게이", - "feraligatr": "장크로다일", - "sentret": "꼬리선", - "furret": "다꼬리", - "hoothoot": "부우부", - "noctowl": "야부엉", - "ledyba": "레디바", - "ledian": "레디안", - "spinarak": "페이검", - "ariados": "아리아도스", - "crobat": "크로뱃", - "chinchou": "초라기", - "lanturn": "랜턴", - "pichu": "피츄", - "cleffa": "삐", - "igglybuff": "푸푸린", - "togepi": "토게피", - "togetic": "토게틱", - "natu": "네이티", - "xatu": "네이티오", - "mareep": "메리프", - "flaaffy": "보송송", - "ampharos": "전룡", - "bellossom": "아르코", - "marill": "마릴", - "azumarill": "마릴리", - "sudowoodo": "꼬지모", - "politoed": "왕구리", - "hoppip": "통통코", - "skiploom": "두코", - "jumpluff": "솜솜코", - "aipom": "에이팜", - "sunkern": "해너츠", - "sunflora": "해루미", - "yanma": "왕자리", - "wooper": "우파", - "quagsire": "누오", - "espeon": "에브이", - "umbreon": "블래키", - "murkrow": "니로우", - "slowking": "야도킹", - "misdreavus": "무우마", - "unown": "안농", - "wobbuffet": "마자용", - "girafarig": "키링키", - "pineco": "피콘", - "forretress": "쏘콘", - "dunsparce": "노고치", - "gligar": "글라이거", - "steelix": "강철톤", - "snubbull": "블루", - "granbull": "그랑블루", - "qwilfish": "침바루", - "scizor": "핫삼", - "shuckle": "단단지", - "heracross": "헤라크로스", - "sneasel": "포푸니", - "teddiursa": "깜지곰", - "ursaring": "링곰", - "slugma": "마그마그", - "magcargo": "마그카르고", - "swinub": "꾸꾸리", - "piloswine": "메꾸리", - "corsola": "코산호", - "remoraid": "총어", - "octillery": "대포무노", - "delibird": "딜리버드", - "mantine": "만타인", - "skarmory": "무장조", - "houndour": "델빌", - "houndoom": "헬가", - "kingdra": "킹드라", - "phanpy": "코코리", - "donphan": "코리갑", - "porygon2": "폴리곤2", - "stantler": "노라키", - "smeargle": "루브도", - "tyrogue": "배루키", - "hitmontop": "카포에라", - "smoochum": "뽀뽀라", - "elekid": "에레키드", - "magby": "마그비", - "miltank": "밀탱크", - "blissey": "해피너스", - "raikou": "라이코", - "entei": "앤테이", - "suicune": "스이쿤", - "larvitar": "애버라스", - "pupitar": "데기라스", - "tyranitar": "마기라스", - "lugia": "루기아", - "ho_oh": "칠색조", - "celebi": "세레비", - "treecko": "나무지기", - "grovyle": "나무돌이", - "sceptile": "나무킹", - "torchic": "아차모", - "combusken": "영치코", - "blaziken": "번치코", - "mudkip": "물짱이", - "marshtomp": "늪짱이", - "swampert": "대짱이", - "poochyena": "포챠나", - "mightyena": "그라에나", - "zigzagoon": "지그제구리", - "linoone": "직구리", - "wurmple": "개무소", - "silcoon": "실쿤", - "beautifly": "뷰티플라이", - "cascoon": "카스쿤", - "dustox": "독케일", - "lotad": "연꽃몬", - "lombre": "로토스", - "ludicolo": "로파파", - "seedot": "도토링", - "nuzleaf": "잎새코", - "shiftry": "다탱구", - "taillow": "테일로", - "swellow": "스왈로", - "wingull": "갈모매", - "pelipper": "패리퍼", - "ralts": "랄토스", - "kirlia": "킬리아", - "gardevoir": "가디안", - "surskit": "비구술", - "masquerain": "비나방", - "shroomish": "버섯꼬", - "breloom": "버섯모", - "slakoth": "게을로", - "vigoroth": "발바로", - "slaking": "게을킹", - "nincada": "토중몬", - "ninjask": "아이스크", - "shedinja": "껍질몬", - "whismur": "소곤룡", - "loudred": "노공룡", - "exploud": "폭음룡", - "makuhita": "마크탕", - "hariyama": "하리뭉", - "azurill": "루리리", - "nosepass": "코코파스", - "skitty": "에나비", - "delcatty": "델케티", - "sableye": "깜까미", - "mawile": "입치트", - "aron": "가보리", - "lairon": "갱도라", - "aggron": "보스로라", - "meditite": "요가랑", - "medicham": "요가램", - "electrike": "썬더라이", - "manectric": "썬더볼트", - "plusle": "플러시", - "minun": "마이농", - "volbeat": "볼비트", - "illumise": "네오비트", - "roselia": "로젤리아", - "gulpin": "꼴깍몬", - "swalot": "꿀꺽몬", - "carvanha": "샤프니아", - "sharpedo": "샤크니아", - "wailmer": "고래왕자", - "wailord": "고래왕", - "numel": "둔타", - "camerupt": "폭타", - "torkoal": "코터스", - "spoink": "피그점프", - "grumpig": "피그킹", - "spinda": "얼루기", - "trapinch": "톱치", - "vibrava": "비브라바", - "flygon": "플라이곤", - "cacnea": "선인왕", - "cacturne": "밤선인", - "swablu": "파비코", - "altaria": "파비코리", - "zangoose": "쟝고", - "seviper": "세비퍼", - "lunatone": "루나톤", - "solrock": "솔록", - "barboach": "미꾸리", - "whiscash": "메깅", - "corphish": "가재군", - "crawdaunt": "가재장군", - "baltoy": "오뚝군", - "claydol": "점토도리", - "lileep": "릴링", - "cradily": "릴리요", - "anorith": "아노딥스", - "armaldo": "아말도", - "feebas": "빈티나", - "milotic": "밀로틱", - "castform": "캐스퐁", - "kecleon": "켈리몬", - "shuppet": "어둠대신", - "banette": "다크펫", - "duskull": "해골몽", - "dusclops": "미라몽", - "tropius": "트로피우스", - "chimecho": "치렁", - "absol": "앱솔", - "wynaut": "마자", - "snorunt": "눈꼬마", - "glalie": "얼음귀신", - "spheal": "대굴레오", - "sealeo": "씨레오", - "walrein": "씨카이저", - "clamperl": "진주몽", - "huntail": "헌테일", - "gorebyss": "분홍장이", - "relicanth": "시라칸", - "luvdisc": "사랑동이", - "bagon": "아공이", - "shelgon": "쉘곤", - "salamence": "보만다", - "beldum": "메탕", - "metang": "메탕구", - "metagross": "메타그로스", - "regirock": "레지락", - "regice": "레지아이스", - "registeel": "레지스틸", - "latias": "라티아스", - "latios": "라티오스", - "kyogre": "가이오가", - "groudon": "그란돈", - "rayquaza": "레쿠쟈", - "jirachi": "지라치", - "deoxys": "테오키스", - "turtwig": "모부기", - "grotle": "수풀부기", - "torterra": "토대부기", - "chimchar": "불꽃숭이", - "monferno": "파이숭이", - "infernape": "초염몽", - "piplup": "팽도리", - "prinplup": "팽태자", - "empoleon": "엠페르트", - "starly": "찌르꼬", - "staravia": "찌르버드", - "staraptor": "찌르호크", - "bidoof": "비버니", - "bibarel": "비버통", - "kricketot": "귀뚤뚜기", - "kricketune": "귀뚤톡크", - "shinx": "꼬링크", - "luxio": "럭시오", - "luxray": "렌트라", - "budew": "꼬몽울", - "roserade": "로즈레이드", - "cranidos": "두개도스", - "rampardos": "램펄드", - "shieldon": "방패톱스", - "bastiodon": "바리톱스", - "burmy": "도롱충이", - "wormadam": "도롱마담", - "mothim": "나메일", - "combee": "세꿀버리", - "vespiquen": "비퀸", - "pachirisu": "파치리스", - "buizel": "브이젤", - "floatzel": "플로젤", - "cherubi": "체리버", - "cherrim": "체리꼬", - "shellos": "깝질무", - "gastrodon": "트리토돈", - "ambipom": "겟핸보숭", - "drifloon": "흔들풍손", - "drifblim": "둥실라이드", - "buneary": "이어롤", - "lopunny": "이어롭", - "mismagius": "무우마직", - "honchkrow": "돈크로우", - "glameow": "나옹마", - "purugly": "몬냥이", - "chingling": "랑딸랑", - "stunky": "스컹뿡", - "skuntank": "스컹탱크", - "bronzor": "동미러", - "bronzong": "동탁군", - "bonsly": "꼬지지", - "mime_jr": "흉내내", - "happiny": "핑복", - "chatot": "페라페", - "spiritomb": "화강돌", - "gible": "딥상어동", - "gabite": "한바이트", - "garchomp": "한카리아스", - "munchlax": "먹고자", - "riolu": "리오르", - "lucario": "루카리오", - "hippopotas": "히포포타스", - "hippowdon": "하마돈", - "skorupi": "스콜피", - "drapion": "드래피온", - "croagunk": "삐딱구리", - "toxicroak": "독개굴", - "carnivine": "무스틈니", - "finneon": "형광어", - "lumineon": "네오라이트", - "mantyke": "타만타", - "snover": "눈쓰개", - "abomasnow": "눈설왕", - "weavile": "포푸니라", - "magnezone": "자포코일", - "lickilicky": "내룸벨트", - "rhyperior": "거대코뿌리", - "tangrowth": "덩쿠림보", - "electivire": "에레키블", - "magmortar": "마그마번", - "togekiss": "토게키스", - "yanmega": "메가자리", - "leafeon": "리피아", - "glaceon": "글레이시아", - "gliscor": "글라이온", - "mamoswine": "맘모꾸리", - "porygon_z": "폴리곤Z", - "gallade": "엘레이드", - "probopass": "대코파스", - "dusknoir": "야느와르몽", - "froslass": "눈여아", - "rotom": "로토무", - "uxie": "유크시", - "mesprit": "엠라이트", - "azelf": "아그놈", - "dialga": "디아루가", - "palkia": "펄기아", - "heatran": "히드런", - "regigigas": "레지기가스", - "giratina": "기라티나", - "cresselia": "크레세리아", - "phione": "피오네", - "manaphy": "마나피", - "darkrai": "다크라이", - "shaymin": "쉐이미", - "arceus": "아르세우스", - "victini": "비크티니", - "snivy": "주리비얀", - "servine": "샤비", - "serperior": "샤로다", - "tepig": "뚜꾸리", - "pignite": "챠오꿀", - "emboar": "염무왕", - "oshawott": "수댕이", - "dewott": "쌍검자비", - "samurott": "대검귀", - "patrat": "보르쥐", - "watchog": "보르그", - "lillipup": "요테리", - "herdier": "하데리어", - "stoutland": "바랜드", - "purrloin": "쌔비냥", - "liepard": "레파르다스", - "pansage": "야나프", - "simisage": "야나키", - "pansear": "바오프", - "simisear": "바오키", - "panpour": "앗차프", - "simipour": "앗차키", - "munna": "몽나", - "musharna": "몽얌나", - "pidove": "콩둘기", - "tranquill": "유토브", - "unfezant": "켄호로우", - "blitzle": "줄뮤마", - "zebstrika": "제브라이카", - "roggenrola": "단굴", - "boldore": "암트르", - "gigalith": "기가이어스", - "woobat": "또르박쥐", - "swoobat": "맘박쥐", - "drilbur": "두더류", - "excadrill": "몰드류", - "audino": "다부니", - "timburr": "으랏차", - "gurdurr": "토쇠골", - "conkeldurr": "노보청", - "tympole": "동챙이", - "palpitoad": "두까비", - "seismitoad": "두빅굴", - "throh": "던지미", - "sawk": "타격귀", - "sewaddle": "두르보", - "swadloon": "두르쿤", - "leavanny": "모아머", - "venipede": "마디네", - "whirlipede": "휠구", - "scolipede": "펜드라", - "cottonee": "소미안", - "whimsicott": "엘풍", - "petilil": "치릴리", - "lilligant": "드레디어", - "basculin": "배쓰나이", - "sandile": "깜눈크", - "krokorok": "악비르", - "krookodile": "악비아르", - "darumaka": "달막화", - "darmanitan": "불비달마", - "maractus": "마라카치", - "dwebble": "돌살이", - "crustle": "암팰리스", - "scraggy": "곤율랭", - "scrafty": "곤율거니", - "sigilyph": "심보러", - "yamask": "데스마스", - "cofagrigus": "데스니칸", - "tirtouga": "프로토가", - "carracosta": "늑골라", - "archen": "아켄", - "archeops": "아케오스", - "trubbish": "깨봉이", - "garbodor": "더스트나", - "zorua": "조로아", - "zoroark": "조로아크", - "minccino": "치라미", - "cinccino": "치라치노", - "gothita": "고디탱", - "gothorita": "고디보미", - "gothitelle": "고디모아젤", - "solosis": "유니란", - "duosion": "듀란", - "reuniclus": "란쿨루스", - "ducklett": "꼬지보리", - "swanna": "스완나", - "vanillite": "바닐프티", - "vanillish": "바닐리치", - "vanilluxe": "배바닐라", - "deerling": "사철록", - "sawsbuck": "바라철록", - "emolga": "에몽가", - "karrablast": "딱정곤", - "escavalier": "슈바르고", - "foongus": "깜놀버슬", - "amoonguss": "뽀록나", - "frillish": "탱그릴", - "jellicent": "탱탱겔", - "alomomola": "맘복치", - "joltik": "파쪼옥", - "galvantula": "전툴라", - "ferroseed": "철시드", - "ferrothorn": "너트령", - "klink": "기어르", - "klang": "기기어르", - "klinklang": "기기기어르", - "tynamo": "저리어", - "eelektrik": "저리릴", - "eelektross": "저리더프", - "elgyem": "리그레", - "beheeyem": "벰크", - "litwick": "불켜미", - "lampent": "램프라", - "chandelure": "샹델라", - "axew": "터검니", - "fraxure": "액슨도", - "haxorus": "액스라이즈", - "cubchoo": "코고미", - "beartic": "툰베어", - "cryogonal": "프리지오", - "shelmet": "쪼마리", - "accelgor": "어지리더", - "stunfisk": "메더", - "mienfoo": "비조푸", - "mienshao": "비조도", - "druddigon": "크리만", - "golett": "골비람", - "golurk": "골루그", - "pawniard": "자망칼", - "bisharp": "절각참", - "bouffalant": "버프론", - "rufflet": "수리둥보", - "braviary": "워글", - "vullaby": "벌차이", - "mandibuzz": "버랜지나", - "heatmor": "앤티골", - "durant": "아이앤트", - "deino": "모노두", - "zweilous": "디헤드", - "hydreigon": "삼삼드래", - "larvesta": "활화르바", - "volcarona": "불카모스", - "cobalion": "코바르온", - "terrakion": "테라키온", - "virizion": "비리디온", - "tornadus": "토네로스", - "thundurus": "볼트로스", - "reshiram": "레시라무", - "zekrom": "제크로무", - "landorus": "랜드로스", - "kyurem": "큐레무", - "keldeo": "케르디오", - "meloetta": "메로엣타", - "genesect": "게노세크트", - "chespin": "도치마론", - "quilladin": "도치보구", - "chesnaught": "브리가론", - "fennekin": "푸호꼬", - "braixen": "테르나", - "delphox": "마폭시", - "froakie": "개구마르", - "frogadier": "개굴반장", - "greninja": "개굴닌자", - "bunnelby": "파르빗", - "diggersby": "파르토", - "fletchling": "화살꼬빈", - "fletchinder": "불화살빈", - "talonflame": "파이어로", - "scatterbug": "분이벌레", - "spewpa": "분떠도리", - "vivillon": "비비용", - "litleo": "레오꼬", - "pyroar": "화염레오", - "flabebe": "플라베베", - "floette": "플라엣테", - "florges": "플라제스", - "skiddo": "메이클", - "gogoat": "고고트", - "pancham": "판짱", - "pangoro": "부란다", - "furfrou": "트리미앙", - "espurr": "냐스퍼", - "meowstic": "냐오닉스", - "honedge": "단칼빙", - "doublade": "쌍검킬", - "aegislash": "킬가르도", - "spritzee": "슈쁘", - "aromatisse": "프레프티르", - "swirlix": "나룸퍼프", - "slurpuff": "나루림", - "inkay": "오케이징", - "malamar": "칼라마네로", - "binacle": "거북손손", - "barbaracle": "거북손데스", - "skrelp": "수레기", - "dragalge": "드래캄", - "clauncher": "완철포", - "clawitzer": "블로스터", - "helioptile": "목도리키텔", - "heliolisk": "일레도리자드", - "tyrunt": "티고라스", - "tyrantrum": "견고라스", - "amaura": "아마루스", - "aurorus": "아마루르가", - "sylveon": "님피아", - "hawlucha": "루차불", - "dedenne": "데덴네", - "carbink": "멜리시", - "goomy": "미끄메라", - "sliggoo": "미끄네일", - "goodra": "미끄래곤", - "klefki": "클레피", - "phantump": "나목령", - "trevenant": "대로트", - "pumpkaboo": "호바귀", - "gourgeist": "펌킨인", - "bergmite": "꽁어름", - "avalugg": "크레베이스", - "noibat": "음뱃", - "noivern": "음번", - "xerneas": "제르네아스", - "yveltal": "이벨타르", - "zygarde": "지가르데", - "diancie": "디안시", - "hoopa": "후파", - "volcanion": "볼케니온", - "rowlet": "나몰빼미", - "dartrix": "빼미스로우", - "decidueye": "모크나이퍼", - "litten": "냐오불", - "torracat": "냐오히트", - "incineroar": "어흥염", - "popplio": "누리공", - "brionne": "키요공", - "primarina": "누리레느", - "pikipek": "콕코구리", - "trumbeak": "크라파", - "toucannon": "왕큰부리", - "yungoos": "영구스", - "gumshoos": "형사구스", - "grubbin": "턱지충이", - "charjabug": "전지충이", - "vikavolt": "투구뿌논", - "crabrawler": "오기지게", - "crabominable": "모단단게", - "oricorio": "춤추새", - "cutiefly": "에블리", - "ribombee": "에리본", - "rockruff": "암멍이", - "lycanroc": "루가루암", - "wishiwashi": "약어리", - "mareanie": "시마사리", - "toxapex": "더시마사리", - "mudbray": "머드나기", - "mudsdale": "만마드", - "dewpider": "물거미", - "araquanid": "깨비물거미", - "fomantis": "짜랑랑", - "lurantis": "라란티스", - "morelull": "자마슈", - "shiinotic": "마셰이드", - "salandit": "야도뇽", - "salazzle": "염뉴트", - "stufful": "포곰곰", - "bewear": "이븐곰", - "bounsweet": "달콤아", - "steenee": "달무리나", - "tsareena": "달코퀸", - "comfey": "큐아링", - "oranguru": "하랑우탄", - "passimian": "내던숭이", - "wimpod": "꼬시레", - "golisopod": "갑주무사", - "sandygast": "모래꿍", - "palossand": "모래성이당", - "pyukumuku": "해무기", - "type_null": "타입:널", - "silvally": "실버디", - "minior": "메테노", - "komala": "자말라", - "turtonator": "폭거북스", - "togedemaru": "토게데마루", - "mimikyu": "따라큐", - "bruxish": "치갈기", - "drampa": "할비롱", - "dhelmise": "타타륜", - "jangmo_o": "짜랑꼬", - "hakamo_o": "짜랑고우", - "kommo_o": "짜랑고우거", - "tapu_koko": "카푸꼬꼬꼭", - "tapu_lele": "카푸나비나", - "tapu_bulu": "카푸브루루", - "tapu_fini": "카푸느지느", - "cosmog": "코스모그", - "cosmoem": "코스모움", - "solgaleo": "솔가레오", - "lunala": "루나아라", - "nihilego": "텅비드", - "buzzwole": "매시붕", - "pheromosa": "페로코체", - "xurkitree": "전수목", - "celesteela": "철화구야", - "kartana": "종이신도", - "guzzlord": "악식킹", - "necrozma": "네크로즈마", - "magearna": "마기아나", - "marshadow": "마샤도", - "poipole": "베베놈", - "naganadel": "아고용", - "stakataka": "차곡차곡", - "blacephalon": "두파팡", - "zeraora": "제라오라", - "meltan": "멜탄", - "melmetal": "멜메탈", - "grookey": "흥나숭", - "thwackey": "채키몽", - "rillaboom": "고릴타", - "scorbunny": "염버니", - "raboot": "래비풋", - "cinderace": "에이스번", - "sobble": "울머기", - "drizzile": "누겔레온", - "inteleon": "인텔리레온", - "skwovet": "탐리스", - "greedent": "요씽리스", - "rookidee": "파라꼬", - "corvisquire": "파크로우", - "corviknight": "아머까오", - "blipbug": "두루지벌레", - "dottler": "레돔벌레", - "orbeetle": "이올브", - "nickit": "훔처우", - "thievul": "폭슬라이", - "gossifleur": "꼬모카", - "eldegoss": "백솜모카", - "wooloo": "우르", - "dubwool": "배우르", - "chewtle": "깨물부기", - "drednaw": "갈가부기", - "yamper": "멍파치", - "boltund": "펄스멍", - "rolycoly": "탄동", - "carkol": "탄차곤", - "coalossal": "석탄산", - "applin": "과사삭벌레", - "flapple": "애프룡", - "appletun": "단지래플", - "silicobra": "모래뱀", - "sandaconda": "사다이사", - "cramorant": "윽우지", - "arrokuda": "찌로꼬치", - "barraskewda": "꼬치조", - "toxel": "일레즌", - "toxtricity": "스트린더", - "sizzlipede": "태우지네", - "centiskorch": "다태우지네", - "clobbopus": "때때무노", - "grapploct": "케오퍼스", - "sinistea": "데인차", - "polteageist": "포트데스", - "hatenna": "몸지브림", - "hattrem": "손지브림", - "hatterene": "브리무음", - "impidimp": "메롱꿍", - "morgrem": "쏘겨모", - "grimmsnarl": "오롱털", - "obstagoon": "가로막구리", - "perrserker": "나이킹", - "cursola": "산호르곤", - "sirfetchd": "창파나이트", - "mr_rime": "마임꽁꽁", - "runerigus": "데스판", - "milcery": "마빌크", - "alcremie": "마휘핑", - "falinks": "대여르", - "pincurchin": "찌르성게", - "snom": "누니머기", - "frosmoth": "모스노우", - "stonjourner": "돌헨진", - "eiscue": "빙큐보", - "indeedee": "에써르", - "morpeko": "모르페코", - "cufant": "끼리동", - "copperajah": "대왕끼리동", - "dracozolt": "파치래곤", - "arctozolt": "파치르돈", - "dracovish": "어래곤", - "arctovish": "어치르돈", - "duraludon": "두랄루돈", - "dreepy": "드라꼰", - "drakloak": "드래런치", - "dragapult": "드래펄트", - "zacian": "자시안", - "zamazenta": "자마젠타", - "eternatus": "무한다이노", - "kubfu": "치고마", - "urshifu": "우라오스", - "zarude": "자루도", - "regieleki": "레지에레키", - "regidrago": "레지드래고", - "glastrier": "블리자포스", - "spectrier": "레이스포스", - "calyrex": "버드렉스", - "wyrdeer": "신비록", - "kleavor": "사마자르", - "ursaluna": "다투곰", - "basculegion": "대쓰여너", - "sneasler": "포푸니크", - "overqwil": "장침바루", - "enamorus": "러브로스", - "sprigatito": "나오하", - "floragato": "나로테", - "meowscarada": "마스카나", - "fuecoco": "뜨아거", - "crocalor": "악뜨거", - "skeledirge": "라우드본", - "quaxly": "꾸왁스", - "quaxwell": "아꾸왁", - "quaquaval": "웨이니발", - "lechonk": "맛보돈", - "oinkologne": "퍼퓨돈", - "tarountula": "타랜툴라", - "spidops": "트래피더", - "nymble": "콩알뚜기", - "lokix": "엑스레그", - "pawmi": "빠모", - "pawmo": "빠모트", - "pawmot": "빠르모트", - "tandemaus": "두리쥐", - "maushold": "파밀리쥐", - "fidough": "쫀도기", - "dachsbun": "바우첼", - "smoliv": "미니브", - "dolliv": "올리뇨", - "arboliva": "올리르바", - "squawkabilly": "시비꼬", - "nacli": "베베솔트", - "naclstack": "스태솔트", - "garganacl": "콜로솔트", - "charcadet": "카르본", - "armarouge": "카디나르마", - "ceruledge": "파라블레이즈", - "tadbulb": "빈나두", - "bellibolt": "찌리배리", - "wattrel": "찌리비", - "kilowattrel": "찌리비크", - "maschiff": "오라티프", - "mabosstiff": "마피티프", - "shroodle": "땃쭈르", - "grafaiai": "태깅구르", - "bramblin": "그푸리", - "brambleghast": "공푸리", - "toedscool": "들눈해", - "toedscruel": "육파리", - "klawf": "절벼게", - "capsakid": "캡싸이", - "scovillain": "스코빌런", - "rellor": "구르데", - "rabsca": "베라카스", - "flittle": "하느라기", - "espathra": "클레스퍼트라", - "tinkatink": "어리짱", - "tinkatuff": "벼리짱", - "tinkaton": "두드리짱", - "wiglett": "바다그다", - "wugtrio": "바닥트리오", - "bombirdier": "떨구새", - "finizen": "맨돌핀", - "palafin": "돌핀맨", - "varoom": "부르롱", - "revavroom": "부르르룸", - "cyclizar": "모토마", - "orthworm": "꿈트렁", - "glimmet": "초롱순", - "glimmora": "킬라플로르", - "greavard": "망망이", - "houndstone": "묘두기", - "flamigo": "꼬이밍고", - "cetoddle": "터벅고래", - "cetitan": "우락고래", - "veluza": "가비루사", - "dondozo": "어써러셔", - "tatsugiri": "싸리용", - "annihilape": "저승갓숭", - "clodsire": "토오", - "farigiraf": "키키링", - "dudunsparce": "노고고치", - "kingambit": "대도각참", - "great_tusk": "위대한엄니", - "scream_tail": "우렁찬꼬리", - "brute_bonnet": "사나운버섯", - "flutter_mane": "날개치는머리", - "slither_wing": "땅을기는날개", - "sandy_shocks": "모래털가죽", - "iron_treads": "무쇠바퀴", - "iron_bundle": "무쇠보따리", - "iron_hands": "무쇠손", - "iron_jugulis": "무쇠머리", - "iron_moth": "무쇠독나방", - "iron_thorns": "무쇠가시", - "frigibax": "드니차", - "arctibax": "드니꽁", - "baxcalibur": "드닐레이브", - "gimmighoul": "모으령", - "gholdengo": "타부자고", - "wo_chien": "총지엔", - "chien_pao": "파오젠", - "ting_lu": "딩루", - "chi_yu": "위유이", - "roaring_moon": "고동치는달", - "iron_valiant": "무쇠무인", - "koraidon": "코라이돈", - "miraidon": "미라이돈", - "walking_wake": "굽이치는물결", - "iron_leaves": "무쇠잎새", - "dipplin": "과미르", - "poltchageist": "차데스", - "sinistcha": "그우린차", - "okidogi": "조타구", - "munkidori": "이야후", - "fezandipiti": "기로치", - "ogerpon": "오거폰", - "archaludon": "브리두라스", - "hydrapple": "과미드라", - "gouging_fire": "꿰뚫는화염", - "raging_bolt": "날뛰는우레", - "iron_boulder": "무쇠암석", - "iron_crown": "무쇠감투", - "terapagos": "테라파고스", - "pecharunt": "복숭악동", - "alola_rattata": "꼬렛", - "alola_raticate": "레트라", - "alola_raichu": "라이츄", - "alola_sandshrew": "모래두지", - "alola_sandslash": "고지", - "alola_vulpix": "식스테일", - "alola_ninetales": "나인테일", - "alola_diglett": "디그다", - "alola_dugtrio": "닥트리오", - "alola_meowth": "나옹", - "alola_persian": "페르시온", - "alola_geodude": "꼬마돌", - "alola_graveler": "데구리", - "alola_golem": "딱구리", - "alola_grimer": "질퍽이", - "alola_muk": "질뻐기", - "alola_exeggutor": "나시", - "alola_marowak": "텅구리", - "eternal_floette": "플라엣테", - "galar_meowth": "나옹", - "galar_ponyta": "포니타", - "galar_rapidash": "날쌩마", - "galar_slowpoke": "야돈", - "galar_slowbro": "야도란", - "galar_farfetchd": "파오리", - "galar_weezing": "또도가스", - "galar_mr_mime": "마임맨", - "galar_articuno": "프리져", - "galar_zapdos": "썬더", - "galar_moltres": "파이어", - "galar_slowking": "야도킹", - "galar_corsola": "코산호", - "galar_zigzagoon": "지그제구리", - "galar_linoone": "직구리", - "galar_darumaka": "달막화", - "galar_darmanitan": "불비달마", - "galar_yamask": "데스마스", - "galar_stunfisk": "메더", - "hisui_growlithe": "가디", - "hisui_arcanine": "윈디", - "hisui_voltorb": "찌리리공", - "hisui_electrode": "붐볼", - "hisui_typhlosion": "블레이범", - "hisui_qwilfish": "침바루", - "hisui_sneasel": "포푸니", - "hisui_samurott": "대검귀", - "hisui_lilligant": "드레디어", - "hisui_zorua": "조로아", - "hisui_zoroark": "조로아크", - "hisui_braviary": "워글", - "hisui_sliggoo": "미끄네일", - "hisui_goodra": "미끄래곤", - "hisui_avalugg": "크레베이스", - "hisui_decidueye": "모크나이퍼", - "paldea_tauros": "켄타로스", - "paldea_wooper": "우파", - "bloodmoon_ursaluna": "다투곰" -} \ No newline at end of file diff --git a/src/locales/ko/run-history.json b/src/locales/ko/run-history.json deleted file mode 100644 index dbf50efc632..00000000000 --- a/src/locales/ko/run-history.json +++ /dev/null @@ -1,37 +0,0 @@ -{ - "victory": "승리!", - "defeatedWild": "야생에서 패배: ", - "defeatedTrainer": "트레이너에게 패배: ", - "defeatedTrainerDouble": "더블 배틀에서 패배", - "defeatedRival": "라이벌에게 패배", - "defeated": "패배", - "defeatedWild_female": "야생에서 패배: ", - "defeatedTrainer_female": "트레이너에게 패배: ", - "defeatedTrainerDouble_female": "더블 배틀에서 패배", - "defeatedRival_female": "라이벌에게 패배", - "defeated_female": "패배", - "luck": "행운", - "score": "점수", - "mode": "모드", - "challengeRules": "규칙", - "challengeMonoGen1": "1세대", - "challengeMonoGen2": "2세대", - "challengeMonoGen3": "3세대", - "challengeMonoGen4": "4세대", - "challengeMonoGen5": "5세대", - "challengeMonoGen6": "6세대", - "challengeMonoGen7": "7세대", - "challengeMonoGen8": "8세대", - "challengeMonoGen9": "9세대", - "playerItems": "플레이어 아이템", - "personalBest": "개인 최고기록!", - "SPDshortened": "스피드", - "runInfo": "플레이 정보", - "money": "소지금", - "runLength": "플레이 타임", - "viewHeldItems": "도구", - "hallofFameText": "전당 등록을 축하합니다!", - "hallofFameText_female": "전당 등록을 축하합니다!", - "viewHallOfFame": "전당 보기", - "viewEndingSplash": "엔딩 화면 보기" -} diff --git a/src/locales/ko/save-slot-select-ui-handler.json b/src/locales/ko/save-slot-select-ui-handler.json deleted file mode 100644 index f3f18ea9ecc..00000000000 --- a/src/locales/ko/save-slot-select-ui-handler.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "overwriteData": "선택한 슬롯에 데이터를 덮어쓰시겠습니까?", - "loading": "로딩 중...", - "wave": "웨이브", - "lv": "Lv", - "empty": "빈 슬롯" -} \ No newline at end of file diff --git a/src/locales/ko/settings.json b/src/locales/ko/settings.json deleted file mode 100644 index d0655009a3c..00000000000 --- a/src/locales/ko/settings.json +++ /dev/null @@ -1,111 +0,0 @@ -{ - "boy": "남자", - "girl": "여자", - "general": "일반", - "display": "디스플레이", - "audio": "오디오", - "gamepad": "게임패드", - "keyboard": "키보드", - "gameSpeed": "게임 속도", - "hpBarSpeed": "HP 바 속도", - "expGainsSpeed": "경험치 획득 속도", - "expPartyDisplay": "파티 경험치 표시", - "skipSeenDialogues": "본 대화 생략", - "eggSkip": "알 스킵", - "never": "안 함", - "always": "항상", - "ask": "확인하기", - "battleStyle": "시합 룰", - "enableRetries": "재도전 허용", - "hideIvs": "개체값탐지기 효과 끄기", - "tutorials": "튜토리얼", - "touchControls": "터치 컨트롤", - "vibrations": "진동", - "normal": "보통", - "fast": "빠르게", - "faster": "더 빠르게", - "skip": "스킵", - "levelUpNotifications": "레벨업 알림", - "on": "설정", - "off": "해제", - "switch": "교체", - "set": "토너먼트", - "auto": "자동", - "disabled": "비활성", - "language": "언어", - "change": "변경", - "uiTheme": "UI 테마", - "default": "기본", - "legacy": "레거시", - "windowType": "윈도우 타입", - "moneyFormat": "소지금 표시", - "damageNumbers": "데미지 숫자 표시", - "simple": "심플", - "fancy": "팬시", - "abbreviated": "축약", - "moveAnimations": "배틀 애니메이션", - "showStatsOnLevelUp": "레벨업 능력치 표시", - "candyUpgradeNotification": "사탕 업그레이드 알림", - "passivesOnly": "패시브만", - "candyUpgradeDisplay": "사탕 업그레이드 표시", - "icon": "아이콘", - "animation": "애니메이션", - "moveInfo": "기술 정보", - "showMovesetFlyout": "상대 기술 보기", - "showArenaFlyout": "배틀 효과 보기", - "showTimeOfDayWidget": "시간 위젯", - "timeOfDayAnimation": "시간 애니메이션", - "bounce": "흔들림", - "timeOfDay_back": "고정", - "spriteSet": "스프라이트 표시", - "consistent": "기본", - "mixedAnimated": "믹스", - "fusionPaletteSwaps": "셰이더 적용", - "playerGender": "플레이어 성별", - "typeHints": "상성 힌트", - "masterVolume": "마스터 볼륨", - "bgmVolume": "BGM 볼륨", - "fieldVolume": "전투효과 볼륨", - "seVolume": "SE 볼륨", - "uiVolume": "UI 볼륨", - "musicPreference": "음악 설정", - "mixed": "믹스", - "gamepadPleasePlug": "게임패드를 연결하거나 버튼을 입력하세요", - "delete": "삭제", - "keyboardPleasePress": "키보드의 키를 입력하세요", - "reset": "리셋", - "requireReload": "새로고침 필요", - "action": "액션", - "back": "고정", - "pressToBind": "할당을 위해 입력하세요", - "pressButton": "버튼을 입력하세요", - "buttonUp": "위", - "buttonDown": "아래", - "buttonLeft": "왼쪽", - "buttonRight": "오른쪽", - "buttonAction": "액션", - "buttonMenu": "메뉴", - "buttonSubmit": "확인", - "buttonCancel": "취소", - "buttonStats": "스탯", - "buttonCycleForm": "폼 변환", - "buttonCycleShiny": "색이 다른 변환", - "buttonCycleGender": "성별 변환", - "buttonCycleAbility": "특성 변환", - "buttonCycleNature": "성격 변환", - "buttonCycleVariant": "색상 변환", - "buttonSpeedUp": "속도 올리기", - "buttonSlowDown": "속도 내리기", - "alt": " (대체)", - "mute": "음소거", - "controller": "컨트롤러", - "gamepadSupport": "게임패드 지원", - "showBgmBar": "BGM 제목 보여주기", - "moveTouchControls": "터치 컨트롤 이동", - "shopOverlayOpacity": "상점 오버레이 투명도", - "shopCursorTarget": "상점 커서 위치", - "rewards": "아이템", - "reroll": "갱신", - "shop": "상점", - "checkTeam": "파티 확인" -} diff --git a/src/locales/ko/splash-messages.json b/src/locales/ko/splash-messages.json deleted file mode 100644 index 6cf7ce050b7..00000000000 --- a/src/locales/ko/splash-messages.json +++ /dev/null @@ -1,36 +0,0 @@ -{ - "battlesWon": "전투에서 승리하세요!", - "joinTheDiscord": "디스코드에 가입하세요!", - "infiniteLevels": "무한한 레벨!", - "everythingStacks": "모든 것이 누적됩니다!", - "optionalSaveScumming": "원한다면 세이브 노가다를!", - "biomes": "35개의 지역!", - "openSource": "오픈소스!", - "playWithSpeed": "5배속으로 플레이해봐요!", - "liveBugTesting": "라이브 버그 테스트!", - "heavyInfluence": "RoR2에 강하게 영감을 받았어요!", - "pokemonRiskAndPokemonRain": "포켓몬 '리스크' 오브 포켓몬 '레인'!", - "nowWithMoreSalt": "이제 33% 더 과몰입 가능!", - "infiniteFusionAtHome": "집에서 인피니트 퓨전을 즐겨보세요!", - "brokenEggMoves": "알기술까기!", - "magnificent": "Magnificent!", - "mubstitute": "Mubstitute!", - "thatsCrazy": "미쳤습니다!", - "oranceJuice": "오렌지 쥬스!", - "questionableBalancing": "의심스러운 밸런싱!", - "coolShaders": "쿨한 셰이더!", - "aiFree": "AI-Free!", - "suddenDifficultySpikes": "돌연사 가능!", - "basedOnAnUnfinishedFlashGame": "무한 플래시게임 기반!", - "moreAddictiveThanIntended": "기획보다 중독적이에요!", - "mostlyConsistentSeeds": "일관성있는 랜덤 시드!", - "achievementPointsDontDoAnything": "업적 포인트는 아무것도 하지 않습니다!", - "youDoNotStartAtLevel": "레벨 2000에서 시작하지 않아요!", - "dontTalkAboutTheManaphyEggIncident": "마나피 알 사건에 대해선 이야기하지 맙시다!", - "alsoTryPokengine": "Pokéngine도 해봐요!", - "alsoTryEmeraldRogue": "Emerald Rogue도 해봐요!", - "alsoTryRadicalRed": "Radical Red도 해봐요!", - "eeveeExpo": "Eevee Expo!", - "ynoproject": "YNOproject!", - "breedersInSpace": "충격!우주에 브리더 진짜 계심ㄷㄷ" -} \ No newline at end of file diff --git a/src/locales/ko/starter-select-ui-handler.json b/src/locales/ko/starter-select-ui-handler.json deleted file mode 100644 index a8419800d9d..00000000000 --- a/src/locales/ko/starter-select-ui-handler.json +++ /dev/null @@ -1,45 +0,0 @@ -{ - "confirmStartTeam": "이 포켓몬들로 시작하시겠습니까?", - "confirmExit": "나가시겠습니까?", - "invalidParty": "스타팅 포켓몬 파티에 적합하지 않습니다!", - "gen1": "1세대", - "gen2": "2세대", - "gen3": "3세대", - "gen4": "4세대", - "gen5": "5세대", - "gen6": "6세대", - "gen7": "7세대", - "gen8": "8세대", - "gen9": "9세대", - "growthRate": "성장 속도", - "ability": "특성:", - "passive": "패시브:", - "nature": "성격:", - "eggMoves": "알 기술", - "addToParty": "파티에 추가", - "removeFromParty": "파티에서 제외", - "toggleIVs": "개체값 토글", - "manageMoves": "기술 관리", - "manageNature": "성격 관리", - "addToFavorites": "즐겨찾기에 추가", - "removeFromFavorites": "즐겨찾기에서 제외", - "useCandies": "사탕 사용", - "selectNature": "교체할 성격을 선택해주세요.", - "selectMoveSwapOut": "교체할 기술을 선택해주세요.", - "selectMoveSwapWith": "교체될 기술을 선택해주세요. 대상:", - "sameSpeciesEgg": "알 구매하기", - "unlockPassive": "패시브 해금", - "reduceCost": "코스트 줄이기", - "cycleShiny": ": 색이 다른", - "cycleForm": ": 폼", - "cycleGender": ": 암수", - "cycleAbility": ": 특성", - "cycleNature": ": 성격", - "cycleVariant": ": 색상", - "goFilter": ": 필터로 이동", - "enablePassive": "패시브 활성화", - "disablePassive": "패시브 비활성화", - "locked": "잠김", - "disabled": "비활성", - "uncaught": "미등록" -} \ No newline at end of file diff --git a/src/locales/ko/status-effect.json b/src/locales/ko/status-effect.json deleted file mode 100644 index d65243a8a24..00000000000 --- a/src/locales/ko/status-effect.json +++ /dev/null @@ -1,65 +0,0 @@ -{ - "none": { - "name": "없음", - "description": "", - "obtain": "", - "obtainSource": "", - "activation": "", - "overlap": "", - "heal": "" - }, - "poison": { - "name": "독", - "description": "독", - "obtain": "{{pokemonNameWithAffix}}의\n몸에 독이 퍼졌다!", - "obtainSource": "{{pokemonNameWithAffix}}[[는]]\n{{sourceText}} 때문에 몸에 독이 퍼졌다!", - "activation": "{{pokemonNameWithAffix}}[[는]]\n독에 의한 데미지를 입었다!", - "overlap": "{{pokemonNameWithAffix}}[[는]] 이미\n몸에 독이 퍼진 상태다.", - "heal": "{{pokemonNameWithAffix}}의 독은\n말끔하게 해독됐다!" - }, - "toxic": { - "name": "맹독", - "description": "독", - "obtain": "{{pokemonNameWithAffix}}의\n몸에 맹독이 퍼졌다!", - "obtainSource": "{{pokemonNameWithAffix}}[[는]]\n{{sourceText}} 때문에 몸에 맹독이 퍼졌다!", - "activation": "{{pokemonNameWithAffix}}[[는]]\n독에 의한 데미지를 입었다!", - "overlap": "{{pokemonNameWithAffix}}[[는]] 이미\n몸에 독이 퍼진 상태다.", - "heal": "{{pokemonNameWithAffix}}의 독은\n말끔하게 해독됐다!" - }, - "paralysis": { - "name": "마비", - "description": "마비", - "obtain": "{{pokemonNameWithAffix}}[[는]] 마비되어\n기술이 나오기 어려워졌다!", - "obtainSource": "{{pokemonNameWithAffix}}[[는]] {{sourceText}} 때문에\n마비되어 기술이 나오기 어려워졌다!", - "activation": "{{pokemonNameWithAffix}}[[는]]\n몸이 저려서 움직일 수 없다!", - "overlap": "{{pokemonNameWithAffix}}[[는]]\n이미 마비되어 있다!", - "heal": "{{pokemonNameWithAffix}}의\n몸저림이 풀렸다!" - }, - "sleep": { - "name": "잠듦", - "description": "잠듦", - "obtain": "{{pokemonNameWithAffix}}[[는]]\n잠들어 버렸다!", - "obtainSource": "{{pokemonNameWithAffix}}[[는]]\n{{sourceText}} 때문에 잠들어 버렸다!", - "activation": "{{pokemonNameWithAffix}}[[는]]\n쿨쿨 잠들어 있다.", - "overlap": "{{pokemonNameWithAffix}}[[는]]\n이미 잠들어 있다.", - "heal": "{{pokemonNameWithAffix}}[[는]]\n눈을 떴다!" - }, - "freeze": { - "name": "얼음", - "description": "얼음", - "obtain": "{{pokemonNameWithAffix}}[[는]]\n얼어붙었다!", - "obtainSource": "{{pokemonNameWithAffix}}[[는]]\n{{sourceText}} 때문에 얼어붙었다!", - "activation": "{{pokemonNameWithAffix}}[[는]]\n얼어 버려서 움직일 수 없다!", - "overlap": "{{pokemonNameWithAffix}}[[는]]\n이미 얼어 있다.", - "heal": "{{pokemonNameWithAffix}}의\n얼음 상태가 나았다!" - }, - "burn": { - "name": "화상", - "description": "화상", - "obtain": "{{pokemonNameWithAffix}}[[는]]\n화상을 입었다!", - "obtainSource": "{{pokemonNameWithAffix}}[[는]]\n{{sourceText}} 때문에 화상을 입었다!", - "activation": "{{pokemonNameWithAffix}}[[는]]\n화상 데미지를 입었다!", - "overlap": "{{pokemonNameWithAffix}}[[는]] 이미\n화상을 입은 상태다.", - "heal": "{{pokemonNameWithAffix}}의\n화상이 나았다!" - } -} \ No newline at end of file diff --git a/src/locales/ko/terrain.json b/src/locales/ko/terrain.json deleted file mode 100644 index b0229b88d39..00000000000 --- a/src/locales/ko/terrain.json +++ /dev/null @@ -1,16 +0,0 @@ -{ - "misty": "미스트필드", - "mistyStartMessage": "발밑이 안개로 자욱해졌다!", - "mistyClearMessage": "발밑의 안개가 사라졌다!", - "mistyBlockMessage": "{{pokemonNameWithAffix}}[[를]]\n미스트필드가 지켜주고 있다!", - "electric": "일렉트릭필드", - "electricStartMessage": "발밑에 전기가 흐르기 시작했다!", - "electricClearMessage": "발밑의 전기가 사라졌다!", - "grassy": "그래스필드", - "grassyStartMessage": "발밑에 풀이 무성해졌다!", - "grassyClearMessage": "발밑의 풀이 사라졌다!", - "psychic": "사이코필드", - "psychicStartMessage": "발밑에서 이상한 느낌이 든다!", - "psychicClearMessage": "발밑의 이상한 느낌이 사라졌다!", - "defaultBlockMessage": "{{pokemonNameWithAffix}}[[를]]\n{{terrainName}}[[가]] 지켜주고 있다!" -} \ No newline at end of file diff --git a/src/locales/ko/trainer-classes.json b/src/locales/ko/trainer-classes.json deleted file mode 100644 index da6c6f4aceb..00000000000 --- a/src/locales/ko/trainer-classes.json +++ /dev/null @@ -1,130 +0,0 @@ -{ - "ace_trainer": "엘리트 트레이너", - "ace_trainer_female": "엘리트 트레이너", - "ace_duo": "엘리트 콤비", - "artist": "예술가", - "artist_female": "예술가", - "backers": "팬클럽", - "backpacker": "백팩커", - "backpacker_female": "백팩커", - "backpackers": "백팩커", - "baker": "제빵사", - "battle_girl": "배틀걸", - "beauty": "아가씨", - "beginners": "반바지 꼬마 & 짧은 치마", - "biker": "폭주족", - "black_belt": "태권왕", - "breeder": "포켓몬 브리더", - "breeder_female": "포켓몬 브리더", - "breeders": "포켓몬 브리더", - "clerk": "비즈니스맨", - "clerk_female": "여사원", - "colleagues": "비즈니스 파트너", - "crush_kin": "배틀 커플", - "cyclist": "사이클링", - "cyclist_female": "사이클링", - "cyclists": "사이클링", - "dancer": "댄서", - "dancer_female": "댄서", - "depot_agent": "역무원", - "doctor": "의사", - "doctor_female": "간호사", - "firebreather": "불놀이꾼", - "fisherman": "낚시꾼", - "fisherman_female": "낚시꾼", - "gentleman": "신사", - "guitarist": "기타리스트", - "guitarist_female": "기타리스트", - "harlequin": "어릿광대", - "hiker": "등산가", - "hooligans": "폭주족 & 빡빡이", - "hoopster": "농구선수", - "infielder": "야구선수", - "janitor": "청소부", - "lady": "아기씨", - "lass": "짧은 치마", - "linebacker": "미식축구선수", - "maid": "메이드", - "madame": "마담", - "medical_team": "의료팀", - "musician": "뮤지션", - "hex_maniac": "오컬트마니아", - "nurse": "간호사", - "nursery_aide": "보육사", - "officer": "경찰관", - "parasol_lady": "파라솔 아가씨", - "pilot": "파일럿", - "pokéfan": "애호가클럽", - "pokéfan_female": "애호가클럽", - "pokéfan_family": "애호가부부", - "preschooler": "보육원아", - "preschooler_female": "보육원아", - "preschoolers": "보육원아", - "psychic": "초능력자", - "psychic_female": "초능력자", - "psychics": "초능력자", - "pokémon_ranger": "포켓몬 레인저", - "pokémon_ranger_female": "포켓몬 레인저", - "pokémon_rangers": "포켓몬 레인저", - "ranger": "포켓몬 레인저", - "restaurant_staff": "레스토랑 직원", - "rich": "신사", - "rich_female": "마담", - "rich_boy": "도련님", - "rich_couple": "신사 & 마담", - "rich_kid": "도련님", - "rich_kid_female": "아가씨", - "rich_kids": "도련님 & 아가씨", - "roughneck": "빡빡이", - "scientist": "연구원", - "scientist_female": "연구원", - "scientists": "연구원", - "smasher": "테니스선수", - "snow_worker": "작업원", - "snow_worker_female": "작업원", - "sailor": "선원", - "striker": "축구선수", - "school_kid": "학원끝난 아이", - "school_kid_female": "학원끝난 아이", - "school_kids": "학원끝난 아이", - "swimmer": "수영팬티 소년", - "swimmer_female": "비키니 아가씨", - "swimmers": "수영팬티 소년 & 비키니 아가씨", - "twins": "쌍둥이", - "veteran": "베테랑 트레이너", - "veteran_female": "베테랑 트레이너", - "veteran_duo": "베테랑 콤비", - "waiter": "웨이터", - "waitress": "웨이트리스", - "worker": "작업원", - "worker_female": "작업원", - "workers": "작업원", - "youngster": "반바지 꼬마", - "rocket_grunt": "로켓단 조무래기", - "rocket_grunt_female": "로켓단 조무래기", - "rocket_grunts": "로켓단 조무래기들", - "magma_grunt": "마그마단 조무래기", - "magma_grunt_female": "마그마단 조무래기", - "magma_grunts": "마그마단 조무래기들", - "aqua_grunt": "아쿠아단 조무래기", - "aqua_grunt_female": "아쿠아단 조무래기", - "aqua_grunts": "아쿠아단 조무래기들", - "galactic_grunt": "갤럭시단 조무래기", - "galactic_grunt_female": "갤럭시단 조무래기", - "galactic_grunts": "갤럭시단 조무래기들", - "plasma_grunt": "플라스마단 조무래기", - "plasma_grunt_female": "플라스마단 조무래기", - "plasma_grunts": "플라스마단 조무래기들", - "flare_grunt": "플레어단 조무래기", - "flare_grunt_female": "플레어단 조무래기", - "flare_grunts": "플레어단 조무래기들", - "aether_grunt": "에테르재단 직원", - "aether_grunt_female": "에테르재단 직원", - "aether_grunts": "에테르재단 직원들", - "skull_grunt": "스컬단 조무래기", - "skull_grunt_female": "스컬단 조무래기", - "skull_grunts": "스컬단 조무래기들", - "macro_grunt": "매크로코스모스 직원", - "macro_grunt_female": "매크로코스모스 직원", - "macro_grunts": "매크로코스모스 직원들" -} diff --git a/src/locales/ko/trainer-names.json b/src/locales/ko/trainer-names.json deleted file mode 100644 index f1357a428ba..00000000000 --- a/src/locales/ko/trainer-names.json +++ /dev/null @@ -1,164 +0,0 @@ -{ - "brock": "웅", - "misty": "이슬", - "lt_surge": "마티스", - "erika": "민화", - "janine": "도희", - "sabrina": "초련", - "blaine": "강연", - "giovanni": "비주기", - "falkner": "비상", - "bugsy": "호일", - "whitney": "꼭두", - "morty": "유빈", - "chuck": "사도", - "jasmine": "규리", - "pryce": "류옹", - "clair": "이향", - "roxanne": "원규", - "brawly": "철구", - "wattson": "암페어", - "flannery": "민지", - "norman": "종길", - "winona": "은송", - "tate": "풍", - "liza": "란", - "juan": "아단", - "roark": "강석", - "gardenia": "유채", - "maylene": "자두", - "crasher_wake": "맥실러", - "fantina": "멜리사", - "byron": "동관", - "candice": "무청", - "volkner": "전진", - "cilan": "덴트", - "chili": "팟", - "cress": "콘", - "cheren": "체렌", - "lenora": "알로에", - "roxie": "보미카", - "burgh": "아티", - "elesa": "카밀레", - "clay": "야콘", - "skyla": "풍란", - "brycen": "담죽", - "drayden": "사간", - "marlon": "시즈", - "viola": "비올라", - "grant": "자크로", - "korrina": "코르니", - "ramos": "후쿠지", - "clemont": "시트론", - "valerie": "마슈", - "olympia": "고지카", - "wulfric": "우르프", - "milo": "아킬", - "nessa": "야청", - "kabu": "순무", - "bea": "채두", - "allister": "어니언", - "opal": "포플러", - "bede": "비트", - "gordie": "마쿠와", - "melony": "멜론", - "piers": "두송", - "marnie": "마리", - "raihan": "금랑", - "katy": "단풍", - "brassius": "콜사", - "iono": "모야모", - "kofu": "곤포", - "larry": "청목", - "ryme": "라임", - "tulip": "리파", - "grusha": "그루샤", - "lorelei": "칸나", - "bruno": "시바", - "agatha": "국화", - "lance": "목호", - "will": "일목", - "koga": "독수", - "karen": "카렌", - "sidney": "혁진", - "phoebe": "회연", - "glacia": "미혜", - "drake": "권수", - "aaron": "충호", - "bertha": "들국화", - "flint": "대엽", - "lucian": "오엽", - "shauntal": "망초", - "marshal": "연무", - "grimsley": "블래리", - "caitlin": "카틀레야", - "malva": "파키라", - "siebold": "즈미", - "wikstrom": "간피", - "drasna": "드라세나", - "hala": "할라", - "molayne": "멀레인", - "olivia": "라이치", - "acerola": "아세로라", - "kahili": "카일리", - "rika": "칠리", - "poppy": "뽀삐", - "hassel": "팔자크", - "crispin": "하솔", - "amarys": "네리네", - "lacey": "타로", - "drayton": "제빈", - "blue": "그린", - "red": "레드", - "steven": "성호", - "wallace": "윤진", - "cynthia": "난천", - "alder": "노간주", - "iris": "아이리스", - "diantha": "카르네", - "hau": "하우", - "geeta": "테사", - "nemona": "네모", - "kieran": "카지", - "leon": "단델", - "rival": "핀", - "rival_female": "아이비", - "archer": "아폴로", - "ariana": "아테나", - "proton": "랜스", - "petrel": "람다", - "tabitha": "호걸", - "courtney": "구열", - "shelly": "이연", - "matt": "해조", - "mars": "마스", - "jupiter": "주피터", - "saturn": "새턴", - "zinzolin": "비오", - "rood": "로트", - "xerosic": "크세로시키", - "bryony": "바라", - "faba": "자우보", - "plumeria": "플루메리", - "oleana": "올리브", - - "maxie": "마적", - "archie": "아강", - "cyrus": "태홍", - "ghetsis": "게치스", - "lysandre": "플라드리", - "lusamine": "루자미네", - "guzma": "구즈마", - "rose": "로즈", - - "blue_red_double": "그린 & 레드", - "red_blue_double": "레드 & 그린", - "tate_liza_double": "풍 & 란", - "liza_tate_double": "란 & 풍", - "steven_wallace_double": "성호 & 윤진", - "wallace_steven_double": "윤진 & 성호", - "alder_iris_double": "노간주 & 아이리스", - "iris_alder_double": "아이리스 & 노간주", - "marnie_piers_double": "마리 & 두송", - "piers_marnie_double": "두송 & 마리" -} diff --git a/src/locales/ko/trainer-titles.json b/src/locales/ko/trainer-titles.json deleted file mode 100644 index 7cff2207817..00000000000 --- a/src/locales/ko/trainer-titles.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "elite_four": "사천왕", - "elite_four_female": "사천왕", - "gym_leader": "체육관 관장", - "gym_leader_female": "체육관 관장", - "gym_leader_double": "체육관 관장 듀오", - "champion": "챔피언", - "champion_female": "챔피언", - "champion_double": "챔피언 듀오", - "rival": "라이벌", - "professor": "박사", - "frontier_brain": "프런티어 브레인", - "rocket_boss": "로켓단 보스", - "magma_boss": "마그마단 보스", - "aqua_boss": "아쿠아단 보스", - "galactic_boss": "갤럭시단 보스", - "plasma_boss": "플라스마단 보스", - "flare_boss": "플레어단 보스", - "aether_boss": "에테르재단 대표", - "skull_boss": "스컬단 보스", - "macro_boss": "매크로코스모스 사장", - - "rocket_admin": "로켓단 간부", - "rocket_admin_female": "로켓단 간부", - "magma_admin": "마그마단 간부", - "magma_admin_female": "마그마단 간부", - "aqua_admin": "아쿠아단 간부", - "aqua_admin_female": "아쿠아단 간부", - "galactic_commander": "갤럭시단 간부", - "galactic_commander_female": "갤럭시단 간부", - "plasma_sage": "플라스마단 현인", - "plasma_admin": "플라스마단 간부", - "flare_admin": "플레어단 간부", - "flare_admin_female": "플레어단 간부", - "aether_admin": "에테르재단 지부장", - "skull_admin": "스컬단 간부", - "macro_admin": "매크로코스모스 간부" -} diff --git a/src/locales/ko/tutorial.json b/src/locales/ko/tutorial.json deleted file mode 100644 index b5304f43098..00000000000 --- a/src/locales/ko/tutorial.json +++ /dev/null @@ -1,10 +0,0 @@ -{ - "intro": "포켓로그에 오신 것을 환영합니다! 로그라이트 요소가 가미된 전투 중심의 포켓몬 팬게임입니다.\n$이 게임은 수익을 창출하지 않으며 Pokémon 및 사용된 저작권 자산에 대한 소유권을 주장하지 않습니다.\n$게임은 아직 작업중이지만 완전히 플레이할 수 있습니다.\n버그 신고는 디스코드 커뮤니티를 이용해 주시기 바랍니다.\n$게임이 느릴 경우 브라우저 설정에서 '하드웨어 가속'이 켜져 있는지 확인해주세요.", - "accessMenu": "메뉴에 액세스하려면 입력을 기다리는 동안 M 또는 Esc를 누릅니다.\n메뉴에는 설정과 다양한 기능이 포함되어 있습니다.", - "menu": "이 메뉴에서 설정에 액세스할 수 있습니다.\n$설정에서 게임 속도, 윈도우 스타일 및 기타 옵션을 변경할 수 있습니다.\n$여기에는 다양한 다른 기능도 있으니 꼭 확인해보세요!", - "starterSelect": "이 화면에서 Z나 스페이스바로 스타팅을 선택할 수 있습니다.\n이들은 당신의 첫 번째 파티 멤버들입니다.\n$최대 6마리의 파티로 시작할 수 있지만\n포켓몬에 따라 코스트가 있어 총합 10을 넘겨선 안 됩니다.\n$계속 잡거나 부화시켜서\n선택할 수 있는 성별, 특성, 폼 등의 폭을 넓힐 수 있습니다.\n$개체값도 점점 누적되어 높아지므로,\n같은 포켓몬을 많이 잡아보세요!", - "pokerus": "매일 랜덤 스타팅 세 종류에 보라색 테두리가 쳐집니다.\n$등록된 스타팅 중에 있다면,\n파티에 추가해서 능력치 화면을 확인해봅시다!", - "statChange": "포켓몬은 교체하지 않으면 다음 전투에서도 능력치 변화가 유지됩니다.\n$대신 트레이너 배틀이나 새로운 바이옴 입장 직전에 자동으로 들여보내지게 됩니다.\n$C 또는 Shift를 꾹 눌러 현재 포켓몬의 능력치 변화를 볼 수도 있습니다.\n$V를 눌러 상대방이 사용했던 기술도 확인할 수 있습니다.\n$단, 이번 배틀에서 상대 포켓몬이 이미 사용한 기술만 나타납니다.", - "selectItem": "전투가 끝날때마다 무작위 아이템 3개 중 하나를 선택하여 얻습니다.\n$종류는 소모품, 포켓몬의 지닌 도구, 영구적 패시브 아이템에 이르기까지 다양합니다.\n$대부분의 소모되지 않는 도구는 효과가 누적됩니다.\n$진화용과 같은 일부분의 아이템은 사용할 수 있는 경우에만 등장합니다.\n$지닌 도구 건네주기 기능을 사용해 포켓몬끼리 도구를 옮겨 지닐 수도 있습니다.\n$지닌 도구가 있다면 아이템 선택 화면 오른쪽 하단에 건네주기 기능이 표시됩니다.\n$돈으로 소모품을 구입할 수도 있으며, 웨이브 진행에 따라 구입 가능한 종류가 늘어납니다.\n$아이템을 선택하면 다음 웨이브로 넘어가므로, 소모품 구입을 먼저 해 주세요.", - "eggGacha": "이 화면에서 포켓몬 알 바우처를\n사용해 뽑기를 할 수 있습니다.\n$알은 전투를 반복하다 보면 부화합니다.\n희귀할 수록 더 오래 걸립니다.\n$부화시킨 포켓몬은 파티에 추가되지 않고\n스타팅에 등록될 것입니다.\n$알에서 부화한 포켓몬은 일반적으로\n야생에서 잡은 포켓몬보다 더 높은 개체값을 지닙니다.\n$일부 포켓몬은 알에서만 얻을 수 있습니다.\n$각 뽑기 기계가 각각 다른 보너스를 가지고 있으므로,\n원하는 쪽을 사용해보세요!" -} \ No newline at end of file diff --git a/src/locales/ko/voucher.json b/src/locales/ko/voucher.json deleted file mode 100644 index 7864754fbbe..00000000000 --- a/src/locales/ko/voucher.json +++ /dev/null @@ -1,9 +0,0 @@ -{ - "vouchers": "바우처", - "eggVoucher": "알 바우처", - "eggVoucherPlus": "알 바우처 플러스", - "eggVoucherPremium": "알 바우처 프리미엄", - "eggVoucherGold": "알 바우처 골드", - "locked": "미획득", - "defeatTrainer": "{{trainerName}}에게 승리" -} \ No newline at end of file diff --git a/src/locales/ko/weather.json b/src/locales/ko/weather.json deleted file mode 100644 index 286bf54cb17..00000000000 --- a/src/locales/ko/weather.json +++ /dev/null @@ -1,32 +0,0 @@ -{ - "sunnyStartMessage": "햇살이 강해졌다!", - "sunnyLapseMessage": "햇살이 강하다", - "sunnyClearMessage": "햇살이 원래대로 되돌아왔다!", - "rainStartMessage": "비가 내리기 시작했다!", - "rainLapseMessage": "비가 계속 내리고 있다", - "rainClearMessage": "비가 그쳤다!", - "sandstormStartMessage": "모래바람이 불기 시작했다!", - "sandstormLapseMessage": "모래바람이 세차게 분다", - "sandstormClearMessage": "모래바람이 가라앉았다!", - "sandstormDamageMessage": "모래바람이\n{{pokemonNameWithAffix}}[[를]] 덮쳤다!", - "hailStartMessage": "싸라기눈이 내리기 시작했다!", - "hailLapseMessage": "싸라기눈이 계속 내리고 있다", - "hailClearMessage": "싸라기눈이 그쳤다!", - "hailDamageMessage": "싸라기눈이\n{{pokemonNameWithAffix}}[[를]] 덮쳤다!", - "snowStartMessage": "눈이 내리기 시작했다!", - "snowLapseMessage": "눈이 계속 내리고 있다", - "snowClearMessage": "눈이 그쳤다!", - "fogStartMessage": "발밑이 안개로 자욱해졌다!", - "fogLapseMessage": "발밑이 안개로 자욱하다", - "fogClearMessage": "발밑의 안개가 사라졌다!", - "heavyRainStartMessage": "강한 비가 내리기 시작했다!", - "heavyRainLapseMessage": "강한 비가 계속 내리고 있다", - "heavyRainClearMessage": "강한 비가 그쳤다!", - "harshSunStartMessage": "햇살이 아주 강해졌다!", - "harshSunLapseMessage": "햇살이 아주 강하다", - "harshSunClearMessage": "햇살이 원래대로 되돌아왔다!", - "strongWindsStartMessage": "수수께끼의 난기류가\n비행포켓몬을 지킨다!", - "strongWindsLapseMessage": "수수께끼의 난기류가 강렬하게 불고 있다", - "strongWindsEffectMessage": "수수께끼의 난기류가 공격을 약하게 만들었다!", - "strongWindsClearMessage": "수수께끼의 난기류가 멈췄다!" -} \ No newline at end of file diff --git a/src/locales/pt_BR/ability-trigger.json b/src/locales/pt_BR/ability-trigger.json deleted file mode 100644 index cd47fd8e3dc..00000000000 --- a/src/locales/pt_BR/ability-trigger.json +++ /dev/null @@ -1,63 +0,0 @@ -{ - "blockRecoilDamage": "{{abilityName}} de {{pokemonName}}\nprotegeu-o do dano reverso!", - "badDreams": "{{pokemonName}} está tendo pesadelos!", - "costar": "{{pokemonName}} copiou as mudanças\nde atributo de {{allyName}}!", - "iceFaceAvoidedDamage": "{{pokemonNameWithAffix}} evitou\ndanos com sua {{abilityName}}!", - "perishBody": "{{abilityName}} de {{pokemonName}}\nirá desmaiar ambos os Pokémon em 3 turnos!", - "poisonHeal": "{{abilityName}} de {{pokemonName}}\nrestaurou seus PS um pouco!", - "trace": "{{pokemonName}} copiou {{abilityName}}\nde {{targetName}}!", - "windPowerCharged": "Ser atingido por {{moveName}} carregou {{pokemonName}} com poder!", - "quickDraw": "{{pokemonName}} pode agir mais rápido que o normal\ngraças ao seu Quick Draw!", - "disguiseAvoidedDamage": "O disfarce de {{pokemonNameWithAffix}} foi descoberto!", - "blockItemTheft": "{{abilityName}} de {{pokemonNameWithAffix}}\nprevine o roubo de itens!", - "typeImmunityHeal": "{{abilityName}} de {{pokemonNameWithAffix}}\nrestaurou um pouco de PS!", - "nonSuperEffectiveImmunity": "{{pokemonNameWithAffix}} evitou dano\ncom {{abilityName}}!", - "fullHpResistType": "{{pokemonNameWithAffix}} fez seu casco brilhar!\nEstá distorcendo o confronte de tipos!", - "moveImmunity": "Isso não afeta {{pokemonNameWithAffix}}!", - "reverseDrain": "{{pokemonNameWithAffix}} absorveu a gosma líquida!", - "postDefendTypeChange": "{{abilityName}} de {{pokemonNameWithAffix}}\ntransformou-o no tipo {{typeName}}!", - "postDefendContactDamage": "{{abilityName}} de {{pokemonNameWithAffix}}\feriu seu adversário!", - "postDefendAbilitySwap": "{{pokemonNameWithAffix}} trocou\nde habilidades com seu alvo!", - "postDefendAbilityGive": "{{pokemonNameWithAffix}} deu a seu alvo\na habilidade {{abilityName}}!", - "postDefendMoveDisable": "{{moveName}} de {{pokemonNameWithAffix}}\nfoi desabilitado!", - "pokemonTypeChange": "{{pokemonNameWithAffix}} se transformou no tipo {{moveType}}!", - "postAttackStealHeldItem": "{{pokemonNameWithAffix}} roubou\n{{stolenItemType}} de {{defenderName}}!", - "postDefendStealHeldItem": "{{pokemonNameWithAffix}} roubou\n{{stolenItemType}} de {{attackerName}}!", - "copyFaintedAllyAbility": "A habilidade {{abilityName}} de {{pokemonNameWithAffix}} foi tomada!", - "intimidateImmunity": "{{abilityName}} de {{pokemonNameWithAffix}} previniu-o(a) de ser intimidado(a)!", - "postSummonAllyHeal": "{{pokemonNameWithAffix}} bebeu todo o\nchá mate que {{pokemonName}} fez!", - "postSummonClearAllyStats": "As mudanças de atributo de {{pokemonNameWithAffix}}\nforam removidas!", - "postSummonTransform": "{{pokemonNameWithAffix}} se transformou\nem {{targetName}}!", - "protectStat": "{{abilityName}} de {{pokemonNameWithAffix}}\nprevine-o(a) de diminuir seu(sua) {{statName}}!", - "statusEffectImmunityWithName": "{{pokemonNameWithAffix}} de {{abilityName}}\nprevine {{statusEffectName}}!", - "statusEffectImmunity": "{{abilityName}} de {{pokemonNameWithAffix}}\nprevine condições de estado!", - "battlerTagImmunity": "{{abilityName}} de {{pokemonNameWithAffix}}\nprevine {{battlerTagName}}!", - "forewarn": "{{pokemonNameWithAffix}} foi avisado sobre {{moveName}}!", - "frisk": "{{pokemonNameWithAffix}} inspecionou a habilidade {{opponentAbilityName}} de {{opponentName}}!", - "postWeatherLapseHeal": "{{abilityName}} de {{pokemonNameWithAffix}}\nrestaurou um pouco de PS!", - "postWeatherLapseDamage": "{{pokemonNameWithAffix}} foi ferido\npor seu(sua) {{abilityName}}!", - "postTurnLootCreateEatenBerry": "{{pokemonNameWithAffix}} colheu uma {{berryName}}!", - "postTurnHeal": "{{abilityName}} de {{pokemonNameWithAffix}}\nrestaurou um pouco de PS!", - "fetchBall": "{{pokemonNameWithAffix}} encontrou uma\n{{pokeballName}}!", - "healFromBerryUse": "{{abilityName}} de {{pokemonNameWithAffix}}\nrestaurou PS!", - "arenaTrap": "{{abilityName}} de {{pokemonNameWithAffix}}\nprevine trocas!", - "postBattleLoot": "{{pokemonNameWithAffix}} pegou um(a)\n{{itemName}}!", - "postFaintContactDamage": "{{abilityName}} de {{pokemonNameWithAffix}}\nferiu seu adversário!", - "postFaintHpDamage": "{{abilityName}} de {{pokemonNameWithAffix}}\nferiu seu adversário!", - "postSummonPressure": "{{pokemonNameWithAffix}} está exercendo sua pressão!", - "weatherEffectDisappeared": "Os efeitos do clima desapareceram.", - "postSummonMoldBreaker": "{{pokemonNameWithAffix}} quebra o molde!", - "postSummonAnticipation": "{{pokemonNameWithAffix}} se arrepiou!", - "postSummonTurboblaze": "{{pokemonNameWithAffix}} está irradiando uma aura ardente!", - "postSummonTeravolt": "{{pokemonNameWithAffix}} está irradiando uma aura explosiva!", - "postSummonDarkAura": "{{pokemonNameWithAffix}} está irradiando uma aura sombria!", - "postSummonFairyAura": "{{pokemonNameWithAffix}} está irradiando uma aura de fada!!", - "postSummonNeutralizingGas": "O Neutralizing Gas de {{pokemonNameWithAffix}} se espalhou pelo campo de batalha!", - "postSummonAsOneGlastrier": "{{pokemonNameWithAffix}} tem duas Habilidades!", - "postSummonAsOneSpectrier": "{{pokemonNameWithAffix}} tem duas Habilidades!", - "postSummonVesselOfRuin": "Vessel of Ruin de {{pokemonNameWithAffix}} reduziu o {{statName}}\nde todos os Pokémon em volta!", - "postSummonSwordOfRuin": "Sword of Ruin de {{pokemonNameWithAffix}} reduziu a {{statName}}\nde todos os Pokémon em volta!", - "postSummonTabletsOfRuin": "Tablets of Ruin de {{pokemonNameWithAffix}} reduziu o {{statName}}\nde todos os Pokémon em volta!", - "postSummonBeadsOfRuin": "Beads of Ruin de {{pokemonNameWithAffix}} reduziu a {{statName}}\nde todos os Pokémon em volta!", - "preventBerryUse": "{{pokemonNameWithAffix}} está nervoso\ndemais para comer frutas!" -} \ No newline at end of file diff --git a/src/locales/pt_BR/ability.json b/src/locales/pt_BR/ability.json deleted file mode 100644 index c4180ff01dd..00000000000 --- a/src/locales/pt_BR/ability.json +++ /dev/null @@ -1,1242 +0,0 @@ -{ - "stench": { - "name": "Stench", - "description": "Liberando um forte odor enquanto ataca, este Pokémon pode fazer o alvo hesitar." - }, - "drizzle": { - "name": "Drizzle", - "description": "O Pokémon faz chover ao entrar em batalha." - }, - "speedBoost": { - "name": "Speed Boost", - "description": "Seu atributo de Velocidade é aumentado a cada turno." - }, - "battleArmor": { - "name": "Battle Armor", - "description": "Uma forte armadura protege o Pokémon de golpes críticos." - }, - "sturdy": { - "name": "Sturdy", - "description": "Impede que seja nocauteado com apenas um golpe, se estiver com seus PS ao máximo. Também evita que movimentos de golpes fatais o derrubem." - }, - "damp": { - "name": "Damp", - "description": "Previne o uso de movimentos explosivos, como a Autodestruição, aumentando a umidade dos arredores." - }, - "limber": { - "name": "Limber", - "description": "Seu corpo maleável protege o Pokémon da paralisia." - }, - "sandVeil": { - "name": "Sand Veil", - "description": "Aumenta a evasão do Pokémon durante as tempestades de areia." - }, - "static": { - "name": "Static", - "description": "O Pokémon é carregado com energia estática, então entrar em contato com ele pode causar paralisia." - }, - "voltAbsorb": { - "name": "Volt Absorb", - "description": "Se for atingido por um movimento do tipo Elétrico, ele restaura seus PS ao invés de receber dano." - }, - "waterAbsorb": { - "name": "Water Absorb", - "description": "Se for atingido por um movimento do tipo Água, ele restaura seus PS ao invés de receber dano." - }, - "oblivious": { - "name": "Oblivious", - "description": "Sua indiferença impede que o Pokémon fique apaixonado ou seja provocado por outro Pokémon." - }, - "cloudNine": { - "name": "Cloud Nine", - "description": "Anula todos os efeitos climáticos na batalha." - }, - "compoundEyes": { - "name": "Compound Eyes", - "description": "O olho preciso do Pokémon aumenta sua precisão." - }, - "insomnia": { - "name": "Insomnia", - "description": "Este Pokémon está sofrendo com insônia e não pode adormecer." - }, - "colorChange": { - "name": "Color Change", - "description": "Este Pokémon se torna do tipo do último ataque que sofreu." - }, - "immunity": { - "name": "Immunity", - "description": "O sistema imunológico deste Pokémon impede que ele seja envenenado." - }, - "flashFire": { - "name": "Flash Fire", - "description": "Fortalece movimentos do tipo Fogo quando atingido por um." - }, - "shieldDust": { - "name": "Shield Dust", - "description": "A poeira desse Pokémon bloqueia efeitos adicionais dos ataques recebidos." - }, - "ownTempo": { - "name": "Own Tempo", - "description": "Este Pokémon tem seu próprio ritmo, que o impede de ficar confuso." - }, - "suctionCups": { - "name": "Suction Cups", - "description": "Este Pokémon usa sua ventosas para fixar-se no lugar, negando todos os movimentos e itens que o obriguem a recuar." - }, - "intimidate": { - "name": "Intimidate", - "description": "Quando entra em batalha, este Pokémon intimida o Pokémon adversário, diminuindo seu Ataque." - }, - "shadowTag": { - "name": "Shadow Tag", - "description": "Este Pokémon pisa na sombra do Pokémon adversário, impedindo que ele escape da batalha." - }, - "roughSkin": { - "name": "Rough Skin", - "description": "Quando recebe um ataque direto, usa sua pele áspera para infligir dano ao Pokémon atacante." - }, - "wonderGuard": { - "name": "Wonder Guard", - "description": "Devido seu misterioso poder, apenas movimentos supereficazes acertam esse Pokémon." - }, - "levitate": { - "name": "Levitate", - "description": "Através da levitação esse Pokémon se torna completamente imune a movimentos do tipo Terra." - }, - "effectSpore": { - "name": "Effect Spore", - "description": "Contato direto com o Pokémon pode infligir paralisia, sono ou envenenamento ao atacante." - }, - "synchronize": { - "name": "Synchronize", - "description": "O atacante sofrerá a mesma mudança de estado se causar queima, envenenamento ou paralisia ao Pokémon." - }, - "clearBody": { - "name": "Clear Body", - "description": "Previne que Habilidades e movimentos de outros Pokémon diminuam os atributos deste Pokémon." - }, - "naturalCure": { - "name": "Natural Cure", - "description": "Quando este Pokémon recua, todas mudanças de estado são curadas." - }, - "lightningRod": { - "name": "Lightning Rod", - "description": "O Pokémon absorve todos os movimentos do tipo Elétrico e, ao invés de sofrer dano, aumenta seu Ataque Esp." - }, - "sereneGrace": { - "name": "Serene Grace", - "description": "Aumenta a probabilidade de ocorrerem efeitos adicionais ao atacar." - }, - "swiftSwim": { - "name": "Swift Swim", - "description": "A Velocidade do Pokémon é aumentada quando chove." - }, - "chlorophyll": { - "name": "Chlorophyll", - "description": "A Velocidade do Pokémon é aumentada sob sol forte." - }, - "illuminate": { - "name": "Illuminate", - "description": "Ilumina os arredores, aumentado a possibilidade de encontrar Pokémon selvagens." - }, - "trace": { - "name": "Trace", - "description": "Quando entra em batalha, o Pokémon copia a Habilidade de um Pokémon adversário." - }, - "hugePower": { - "name": "Huge Power", - "description": "Dobra o Ataque do Pokémon." - }, - "poisonPoint": { - "name": "Poison Point", - "description": "Contato direto com o Pokémon pode envenenar o atacante." - }, - "innerFocus": { - "name": "Inner Focus", - "description": "O foco extraordinário do Pokémon o impede de hesitar." - }, - "magmaArmor": { - "name": "Magma Armor", - "description": "O magma escaldante que cobre o Pokémon previne seu congelamento." - }, - "waterVeil": { - "name": "Water Veil", - "description": "O véu de água que cobre o Pokémon previne que ele seja queimado." - }, - "magnetPull": { - "name": "Magnet Pull", - "description": "Impede que Pokémon do tipo Aço escapem através da utilização de sua força magnética." - }, - "soundproof": { - "name": "Soundproof", - "description": "Antirruído dá ao Pokémon imunidade completa a todos movimentos baseados em som." - }, - "rainDish": { - "name": "Rain Dish", - "description": "O Pokémon recupera PS gradualmente na chuva." - }, - "sandStream": { - "name": "Sand Stream", - "description": "Quando entra em batalha o Pokémon conjura uma tempestade de areia." - }, - "pressure": { - "name": "Pressure", - "description": "Pressionando o Pokémon adversário, ele aumenta o custo de PP para o adversário usar um movimento." - }, - "thickFat": { - "name": "Thick Fat", - "description": "Movimentos dos tipos Fogo e Água têm seu dano reduzido pela metade devido à grossa camada de gordura que protege o Pokémon." - }, - "earlyBird": { - "name": "Early Bird", - "description": "O Pokémon acorda duas vezes mais rápido que outros Pokémon." - }, - "flameBody": { - "name": "Flame Body", - "description": "Contato direto com o Pokémon pode queimar o atacante." - }, - "runAway": { - "name": "Run Away", - "description": "Torna a fuga de encontros com Pokémon selvagem garantida." - }, - "keenEye": { - "name": "Keen Eye", - "description": "Seu olhar extremamente aguçado evita que outros Pokémon diminuam sua Precisão." - }, - "hyperCutter": { - "name": "Hyper Cutter", - "description": "Suas poderosas pinças enchem o Pokémon de orgulho. Elas impedem que outros Pokémon diminuam seu atributo de Ataque." - }, - "pickup": { - "name": "Pickup", - "description": "Após uma batalha, o Pokémon pegará um item que um adversário deixou cair." - }, - "truant": { - "name": "Truant", - "description": "Se utilizar um movimento, o Pokémon precisará descansar no turno seguinte." - }, - "hustle": { - "name": "Hustle", - "description": "Aumenta seu Ataque em troca de diminuir a precisão." - }, - "cuteCharm": { - "name": "Cute Charm", - "description": "Contato direto com o Pokémon pode causar paixão ao atacante." - }, - "plus": { - "name": "Plus", - "description": "Aumenta o Ataque Esp. do Pokémon se estiver em batalha com um aliado que tenha as Habilidades Plus ou Minus." - }, - "minus": { - "name": "Minus", - "description": "Aumenta o Ataque Esp. do Pokémon se estiver em batalha com um aliado que tenha as Habilidades Mais ou Menos." - }, - "forecast": { - "name": "Forecast", - "description": "O tipo do Pokémon altera-se para Água, Fogo ou Gelo, dependendo do clima." - }, - "stickyHold": { - "name": "Sticky Hold", - "description": "Outros Pokémon não podem remover itens que este Pokémon esteja segurando." - }, - "shedSkin": { - "name": "Shed Skin", - "description": "O Pokémon pode curar-se de mudanças de estado através da troca de pele." - }, - "guts": { - "name": "Guts", - "description": "É tão corajoso que ser afetado por uma mudança de estado aumenta seu Ataque." - }, - "marvelScale": { - "name": "Marvel Scale", - "description": "Se for afetado por uma mudança de estado, as escamas maravilhosas do Pokémon aumentarão sua Defesa." - }, - "liquidOoze": { - "name": "Liquid Ooze", - "description": "Exala uma substância tóxica com fedor terrível que causa dano a qualquer atacante que use um movimento de dreno." - }, - "overgrow": { - "name": "Overgrow", - "description": "Fortalece os movimentos do tipo Grama quando o Pokémon está com poucos PS." - }, - "blaze": { - "name": "Blaze", - "description": "Fortalece os movimentos do tipo Fogo quando o Pokémon está com poucos PS." - }, - "torrent": { - "name": "Torrent", - "description": "Fortalece os movimentos do tipo Água quando o Pokémon está com poucos PS." - }, - "swarm": { - "name": "Swarm", - "description": "Fortalece os movimentos do tipo Inseto quando o Pokémon está com poucos PS." - }, - "rockHead": { - "name": "Rock Head", - "description": "Protege o Pokémon de dano colateral." - }, - "drought": { - "name": "Drought", - "description": "Intensifica a luz solar quando o Pokémon entra em batalha." - }, - "arenaTrap": { - "name": "Arena Trap", - "description": "Impede que Pokémon adversários fujam." - }, - "vitalSpirit": { - "name": "Vital Spirit", - "description": "Sua determinação o impede de adormecer." - }, - "whiteSmoke": { - "name": "White Smoke", - "description": "O Pokémon é protegido por sua fumaça branca que previne que outros Pokémon diminuam seus atributos." - }, - "purePower": { - "name": "Pure Power", - "description": "O Pokémon dobra seu Ataque usando seu poder puro." - }, - "shellArmor": { - "name": "Shell Armor", - "description": "A robusta couraça que protege o Pokémon bloqueia os golpes críticos." - }, - "airLock": { - "name": "Air Lock", - "description": "Elimina efeitos climáticos." - }, - "tangledFeet": { - "name": "Tangled Feet", - "description": "Sua evasão aumenta se estiver confuso." - }, - "motorDrive": { - "name": "Motor Drive", - "description": "O Pokémon absorve todos os movimentos do tipo Elétrico e, ao invés de sofrer dano, aumenta seu atributo de Velocidade." - }, - "rivalry": { - "name": "Rivalry", - "description": "Sua competitividade faz com que cause mais dano a Pokémon do mesmo gênero, enquanto causa dano reduzido a Pokémon do gênero oposto." - }, - "steadfast": { - "name": "Steadfast", - "description": "A determinação do Pokémon faz com que sua Velocidade aumente cada vez que ele hesita." - }, - "snowCloak": { - "name": "Snow Cloak", - "description": "Aumenta a evasão numa tempestade de granizo." - }, - "gluttony": { - "name": "Gluttony", - "description": "Se estiver segurando uma fruta, a consumirá quando seus PS caírem abaixo da metade, o que é mais cedo que o usual." - }, - "angerPoint": { - "name": "Anger Point", - "description": "Quando recebe um acerto crítico se enraivece, e com isso, aumenta seu Ataque." - }, - "unburden": { - "name": "Unburden", - "description": "Se o item que o Pokémon estiver segurando for usado ou perdido, sua Velocidade aumentará." - }, - "heatproof": { - "name": "Heatproof", - "description": "O corpo a prova de calor desse Pokémon corta pela metade o dano de ataques do tipo Fogo que o acertam." - }, - "simple": { - "name": "Simple", - "description": "Duplica as mudanças de atributos do Pokémon." - }, - "drySkin": { - "name": "Dry Skin", - "description": "Durante chuva ou se for atingido por movimentos de Água, recupera PS. Durante sol forte tem seus PS máximo reduzido e leva dano aumentado do tipo Fogo." - }, - "download": { - "name": "Download", - "description": "Compara Defesa e Defesa Esp. do Pokémon adversário antes de aumentar seu próprio Ataque Esp. ou Ataque, a depender de qual será mais efetivo." - }, - "ironFist": { - "name": "Iron Fist", - "description": "Fortalece movimentos de soco." - }, - "poisonHeal": { - "name": "Poison Heal", - "description": "Se o Pokémon estiver envenenado, recuperará PS ao invés de perdê-los." - }, - "adaptability": { - "name": "Adaptability", - "description": "Fortalece movimentos do mesmo tipo do Pokémon." - }, - "skillLink": { - "name": "Skill Link", - "description": "Faz com que movimentos de repetição acertem sempre o máximo de vezes possível." - }, - "hydration": { - "name": "Hydration", - "description": "Cura mudanças de estado durante a chuva." - }, - "solarPower": { - "name": "Solar Power", - "description": "Aumenta o Ataque Esp. durante o sol forte, entretanto perde um pouco de PS a cada turno." - }, - "quickFeet": { - "name": "Quick Feet", - "description": "Aumenta a Velocidade se o Pokémon sofrer uma mudança de estado." - }, - "normalize": { - "name": "Normalize", - "description": "Todos os movimentos do Pokémon se tornam do tipo Normal. Aumenta um pouco o poder desses movimentos." - }, - "sniper": { - "name": "Sniper", - "description": "Aumenta o poder dos ataques caso sejam críticos." - }, - "magicGuard": { - "name": "Magic Guard", - "description": "O Pokémon só recebe dano de movimentos de ataque." - }, - "noGuard": { - "name": "No Guard", - "description": "Para garantir que todos os ataques atinjam o oponente, o Pokémon adota uma estratégia de desguarnecimento, porém, isso faz com que todos ataques o atinjam." - }, - "stall": { - "name": "Stall", - "description": "O Pokémon age somente após todos os outros agirem." - }, - "technician": { - "name": "Technician", - "description": "Aumenta o poder dos ataques mais fracos do Pokémon." - }, - "leafGuard": { - "name": "Leaf Guard", - "description": "Previne mudanças de estado sob o sol forte." - }, - "klutz": { - "name": "Klutz", - "description": "O Pokémon não pode usar nenhum item que esteja segurando." - }, - "moldBreaker": { - "name": "Mold Breaker", - "description": "Movimentos podem atingir independentemente da Habilidade do alvo." - }, - "superLuck": { - "name": "Super Luck", - "description": "O Pokémon é tão sortudo que tem a sua probabilidade de realizar golpes críticos aumentada." - }, - "aftermath": { - "name": "Aftermath", - "description": "Caso o Pokémon seja derrotado em decorrência de um movimento de contato, o atacante recebe dano." - }, - "anticipation": { - "name": "Anticipation", - "description": "O Pokémon pode sentir movimentos perigosos vindos do Pokémon adversário." - }, - "forewarn": { - "name": "Forewarn", - "description": "Quando entra em batalha, o Pokémon pode dizer um dos movimentos do Pokémon adversário." - }, - "unaware": { - "name": "Unaware", - "description": "Quando está atacando, o Pokémon ignora mudanças de atributos do Pokémon adversário." - }, - "tintedLens": { - "name": "Tinted Lens", - "description": "Movimentos que seriam “pouco eficazes” causam dano normalmente quando usados pelo Pokémon." - }, - "filter": { - "name": "Filter", - "description": "Ataques supereficazes recebidos dão menos dano." - }, - "slowStart": { - "name": "Slow Start", - "description": "O Ataque e a Velocidade do Pokémon são cortados pela metade por cinco turnos." - }, - "scrappy": { - "name": "Scrappy", - "description": "O Pokémon pode atingir Pokémon do tipo Fantasma com ataques dos tipos Normal e Lutador." - }, - "stormDrain": { - "name": "Storm Drain", - "description": "Atrai todos movimentos do tipo Água para si. Ao invés de receber dano desses ataques, tem seu Ataque Esp. aumentado." - }, - "iceBody": { - "name": "Ice Body", - "description": "O Pokémon recupera PS gradualmente durante as tempestades de granizo." - }, - "solidRock": { - "name": "Solid Rock", - "description": "Reduz o dano recebido de ataques supereficazes." - }, - "snowWarning": { - "name": "Snow Warning", - "description": "O Pokémon conjura uma tempestade de granizo quando entra em batalha." - }, - "honeyGather": { - "name": "Honey Gather", - "description": "The Pokémon gathers Honey after a battle. The Honey is then sold for money." - }, - "frisk": { - "name": "Frisk", - "description": "Quando entra em batalha, o Pokémon pode checar a Habilidade do adversário." - }, - "reckless": { - "name": "Reckless", - "description": "Fortalece movimentos que têm dano colateral." - }, - "multitype": { - "name": "Multitype", - "description": "Altera o tipo do Pokémon para o mesmo da Placa ou Cristal Z em sua posse." - }, - "flowerGift": { - "name": "Flower Gift", - "description": "Sob sol forte, o Ataque e a Defesa Esp. do Pokémon e de seus aliados são aumentados." - }, - "badDreams": { - "name": "Bad Dreams", - "description": "Reduz os PS de Pokémon adversários que estiverem dormindo." - }, - "pickpocket": { - "name": "Pickpocket", - "description": "Rouba o item de um atacante que tenha feito contato direto." - }, - "sheerForce": { - "name": "Sheer Force", - "description": "Aumenta o poder de seus movimentos quando ataca, em detrimento de seus efeitos adicionais que são anulados." - }, - "contrary": { - "name": "Contrary", - "description": "Faz as mudanças de atributos terem efeito contrário." - }, - "unnerve": { - "name": "Unnerve", - "description": "Enerva Pokémon adversários, impossibilitando que eles consumam Frutas." - }, - "defiant": { - "name": "Defiant", - "description": "Aumenta bruscamente o Ataque do Pokémon quando seus atributos são diminuídos pelo adversário." - }, - "defeatist": { - "name": "Defeatist", - "description": "Quando fica com metade ou menos dos PS totais, corta o Ataque e Ataque Esp. do Pokémon pela metade." - }, - "cursedBody": { - "name": "Cursed Body", - "description": "Pode desabilitar um movimento utilizado no Pokémon." - }, - "healer": { - "name": "Healer", - "description": "Às vezes cura mudanças de estado de um aliado." - }, - "friendGuard": { - "name": "Friend Guard", - "description": "Reduz o dano causado em aliados." - }, - "weakArmor": { - "name": "Weak Armor", - "description": "Ataques físicos ao Pokémon diminuem sua Defesa, mas aumenta bruscamente sua Velocidade." - }, - "heavyMetal": { - "name": "Heavy Metal", - "description": "Dobra o peso do Pokémon." - }, - "lightMetal": { - "name": "Light Metal", - "description": "Divide o peso do Pokémon pela metade." - }, - "multiscale": { - "name": "Multiscale", - "description": "Reduz o dano que o Pokémon recebe quando está com os PS cheios." - }, - "toxicBoost": { - "name": "Toxic Boost", - "description": "Fortalece ataques físicos quando o Pokémon está envenenado." - }, - "flareBoost": { - "name": "Flare Boost", - "description": "Fortalece ataques especiais quando o Pokémon está queimado." - }, - "harvest": { - "name": "Harvest", - "description": "Pode criar outra Fruta após consumir uma." - }, - "telepathy": { - "name": "Telepathy", - "description": "Prevê os ataques de um aliado em combate e desvia de todos eles." - }, - "moody": { - "name": "Moody", - "description": "Aumenta bruscamente um atributo e diminui outro a cada turno." - }, - "overcoat": { - "name": "Overcoat", - "description": "Protege o Pokémon de coisas como areia, geada e pó." - }, - "poisonTouch": { - "name": "Poison Touch", - "description": "Pode envenenar um alvo quando o Pokémon faz contato." - }, - "regenerator": { - "name": "Regenerator", - "description": "Recupera um pouco de PS quando recua da batalha." - }, - "bigPecks": { - "name": "Big Pecks", - "description": "Protege o Pokémon de efeitos que diminuam a Defesa." - }, - "sandRush": { - "name": "Sand Rush", - "description": "Aumenta a Velocidade do Pokémon durante uma tempestade de areia." - }, - "wonderSkin": { - "name": "Wonder Skin", - "description": "Torna movimentos de atributos mais suscetíveis ao erro." - }, - "analytic": { - "name": "Analytic", - "description": "Aumenta o poder do movimento quando o Pokémon age por último." - }, - "illusion": { - "name": "Illusion", - "description": "Entra em batalha disfarçado, na forma do Pokémon que ocupar o último lugar na equipe." - }, - "imposter": { - "name": "Imposter", - "description": "O Pokémon se transforma no Pokémon que está enfrentando." - }, - "infiltrator": { - "name": "Infiltrator", - "description": "Ignora barreiras, substitutos e coisas do tipo utilizadas pelo Pokémon adversário e ataca normalmente." - }, - "mummy": { - "name": "Mummy", - "description": "Contato direto com o Pokémon altera a Habilidade do atacante para Múmia." - }, - "moxie": { - "name": "Moxie", - "description": "O Pokémon demonstra arrogância, e isso faz com que seu Ataque aumente após derrotar qualquer Pokémon." - }, - "justified": { - "name": "Justified", - "description": "Ser atingido por movimentos do tipo Sombrio aumenta o Ataque do Pokémon, por justiça." - }, - "rattled": { - "name": "Rattled", - "description": "Movimentos dos tipos Sombrio, Fantasma e Inseto assustam o Pokémon, aumentando sua Velocidade" - }, - "magicBounce": { - "name": "Magic Bounce", - "description": "Ao invés de ser atingido por movimentos de atributos, reflete-os." - }, - "sapSipper": { - "name": "Sap Sipper", - "description": "Se for atingido por um movimento do tipo Grama, ao invés de receber dano, aumenta seu Ataque." - }, - "prankster": { - "name": "Prankster", - "description": "Dá prioridade a movimentos de estado." - }, - "sandForce": { - "name": "Sand Force", - "description": "Fortalece o poder dos movimentos do tipo Pedra, Terra e Aço em uma tempestade de areia." - }, - "ironBarbs": { - "name": "Iron Barbs", - "description": "Os espinhos de ferro infligem dano a um atacante que fizer contato direto." - }, - "zenMode": { - "name": "Zen Mode", - "description": "Quando o Pokémon tem seus PS reduzidos à metade ou menos, muda de forma." - }, - "victoryStar": { - "name": "Victory Star", - "description": "Aumenta a Precisão sua e de seus aliados." - }, - "turboblaze": { - "name": "Turboblaze", - "description": "Movimentos podem atingir independentemente da Habilidade do alvo." - }, - "teravolt": { - "name": "Teravolt", - "description": "Movimentos podem atingir independentemente da Habilidade do alvo." - }, - "aromaVeil": { - "name": "Aroma Veil", - "description": "Protege a si mesmo e a seus aliados de ataques que limitem a escolha de movimentos." - }, - "flowerVeil": { - "name": "Flower Veil", - "description": "Pokémon aliados do tipo Grama são protegidos de mudanças de estado e diminuição de seus atributos." - }, - "cheekPouch": { - "name": "Cheek Pouch", - "description": "Quando o Pokémon consome uma Fruta, também recupera um pouco de PS." - }, - "protean": { - "name": "Protean", - "description": "Muda o tipo do Pokémon para o tipo do movimento que ele vai utilizar." - }, - "furCoat": { - "name": "Fur Coat", - "description": "Reduz o dano de movimentos físicos pela metade." - }, - "magician": { - "name": "Magician", - "description": "O Pokémon rouba o item que um Pokémon alvo estiver segurando quando acerta um movimento." - }, - "bulletproof": { - "name": "Bulletproof", - "description": "Protege o Pokémon de alguns movimentos de bola e bomba." - }, - "competitive": { - "name": "Competitive", - "description": "Aumenta bruscamente o Ataque Esp. quando um atributo é diminuído." - }, - "strongJaw": { - "name": "Strong Jaw", - "description": "A poderosa mandíbula do Pokémon aumenta o poder dos seus movimentos de mordida." - }, - "refrigerate": { - "name": "Refrigerate", - "description": "Movimentos do tipo Normal se tornam do tipo Gelo. Aumenta um pouco o poder desses movimentos." - }, - "sweetVeil": { - "name": "Sweet Veil", - "description": "Previne a si e a Pokémon aliados de caírem no sono." - }, - "stanceChange": { - "name": "Stance Change", - "description": "O Pokemon muda para Forma Espada quando usa um movimento de ataque, e muda para a Forma Escudo quando usa o movimento Escudo do Rei." - }, - "galeWings": { - "name": "Gale Wings", - "description": "Quando o Pokémon está com os PS cheios, dá prioridade a movimentos do tipo Voador." - }, - "megaLauncher": { - "name": "Mega Launcher", - "description": "Fortalece movimentos de aura e pulso." - }, - "grassPelt": { - "name": "Grass Pelt", - "description": "Aumenta a Defesa do Pokémon em Terreno de Grama." - }, - "symbiosis": { - "name": "Symbiosis", - "description": "O Pokémon entrega seu item para um aliado que já tiver utilizado seu próprio item." - }, - "toughClaws": { - "name": "Tough Claws", - "description": "Fortalece movimentos que façam contato direto." - }, - "pixilate": { - "name": "Pixilate", - "description": "Movimentos do tipo Normal se tornam do tipo Fada. Aumenta um pouco o poder desses movimentos." - }, - "gooey": { - "name": "Gooey", - "description": "Contato direto com o Pokémon diminui o atributo de Velocidade do atacante." - }, - "aerilate": { - "name": "Aerilate", - "description": "Movimentos do tipo Normal se tornam do tipo Voador. Aumenta um pouco o poder desses movimentos." - }, - "parentalBond": { - "name": "Parental Bond", - "description": "Une suas forças com sua cria para atacar duas vezes." - }, - "darkAura": { - "name": "Dark Aura", - "description": "Fortalece movimentos do tipo Sombrio de todos os Pokémon." - }, - "fairyAura": { - "name": "Fairy Aura", - "description": "Fortalece movimentos do tipo Fada de todos os Pokémon." - }, - "auraBreak": { - "name": "Aura Break", - "description": "Os efeitos de Habilidades de “Aura” são revertidos para diminuir o poder de movimentos afetados." - }, - "primordialSea": { - "name": "Primordial Sea", - "description": "O Pokémon muda o clima para neutralizar ataques do tipo Fogo." - }, - "desolateLand": { - "name": "Desolate Land", - "description": "O Pokémon muda o clima para neutralizar ataques do tipo Água." - }, - "deltaStream": { - "name": "Delta Stream", - "description": "O Pokémon muda o clima para eliminar todas as vulnerabilidades do tipo Voador." - }, - "stamina": { - "name": "Stamina", - "description": "Aumenta a Defesa quando atingido por um ataque." - }, - "wimpOut": { - "name": "Wimp Out", - "description": "Quando fica com metade ou menos de seus PS, recua covardemente da batalha." - }, - "emergencyExit": { - "name": "Emergency Exit", - "description": "Quando fica com metade ou menos de seus PS, sentindo que está em perigo, o Pokémon recua da batalha." - }, - "waterCompaction": { - "name": "Water Compaction", - "description": "Aumenta bruscamente a Defesa do Pokémon quando atingido por um movimento do tipo Água." - }, - "merciless": { - "name": "Merciless", - "description": "Os ataques do Pokémon se tornam críticos se o alvo estiver envenenado." - }, - "shieldsDown": { - "name": "Shields Down", - "description": "Quando fica com metade ou menos de seus PS, o Pokémon quebra sua carapaça e se torna agressivo." - }, - "stakeout": { - "name": "Stakeout", - "description": "Caso o alvo recue da batalha, dobra o dano causado ao Pokémon suplente." - }, - "waterBubble": { - "name": "Water Bubble", - "description": "Diminui o poder de movimentos do tipo Fogo usados contra o Pokémon e o impede de ficar queimado." - }, - "steelworker": { - "name": "Steelworker", - "description": "Fortalece os movimentos do tipo Aço." - }, - "berserk": { - "name": "Berserk", - "description": "Quando é atingido por um movimento que deixa seus PS na metade ou menos, aumenta seu Ataque Esp.." - }, - "slushRush": { - "name": "Slush Rush", - "description": "Aumenta a Velocidade do Pokémon em uma tempestade de granizo." - }, - "longReach": { - "name": "Long Reach", - "description": "O Pokémon usa seus movimentos sem fazer contato direto com o alvo." - }, - "liquidVoice": { - "name": "Liquid Voice", - "description": "Todos os movimentos baseados em som se tornam do tipo Água." - }, - "triage": { - "name": "Triage", - "description": "Concede prioridade para movimentos de cura." - }, - "galvanize": { - "name": "Galvanize", - "description": "Movimentos do tipo Normal se transformam em movimentos do tipo Elétrico. Aumenta um pouco o poder desses movimentos." - }, - "surgeSurfer": { - "name": "Surge Surfer", - "description": "Dobra a Velocidade do Pokémon em Terreno Elétrico." - }, - "schooling": { - "name": "Schooling", - "description": "Quando está com bastante PS, o Pokémon forma um poderoso cardume, que se desfaz quando seus PS ficam baixos." - }, - "disguise": { - "name": "Disguise", - "description": "Uma vez por batalha, a mortalha que cobre o Pokémon pode protegê-lo de um ataque." - }, - "battleBond": { - "name": "Battle Bond", - "description": "Derrotar um Pokémon adversário fortalece os laços entre Pokémon e Treinador, fazendo com que se torne Greninja do Ash, e fortalecendo o ataque Shuriken de Água." - }, - "powerConstruct": { - "name": "Power Construct", - "description": "Quando seus PS ficam da metade para baixo, outras Células se agrupam para auxiliá-lo, fazendo com que o Pokémon mude para sua Forma Completa." - }, - "corrosion": { - "name": "Corrosion", - "description": "O Pokémon pode envenenar o alvo mesmo que ele seja dos tipos Aço ou Venenoso." - }, - "comatose": { - "name": "Comatose", - "description": "Está sempre cochilando e nunca acordará, entretanto, pode atacar sem acordar." - }, - "queenlyMajesty": { - "name": "Queenly Majesty", - "description": "Sua magnificência pressiona o Pokémon adversário, impossibilitando-o de utilizar movimentos de prioridade." - }, - "innardsOut": { - "name": "Innards Out", - "description": "Ao ser nocauteado, inflige dano ao adversário igual ao valor de PS que possuía antes de ser atacado." - }, - "dancer": { - "name": "Dancer", - "description": "Quando outro Pokémon usa um movimento de dança, pode usar um movimento de dança na sequência independentemente de sua Velocidade." - }, - "battery": { - "name": "Battery", - "description": "Fortalece os movimentos especiais dos Pokémon aliados." - }, - "fluffy": { - "name": "Fluffy", - "description": "Corta pela metade o dano recebido de movimentos que fazem contato direto, porém, dobra o dano dos ataques do tipo Fogo." - }, - "dazzling": { - "name": "Dazzling", - "description": "Surpreende o Pokémon adversário, impedindo-o de atacar usando movimentos de prioridade." - }, - "soulHeart": { - "name": "Soul-Heart", - "description": "Aumenta seu atributo de Ataque Esp. toda vez que um Pokémon desmaia." - }, - "tanglingHair": { - "name": "Tangling Hair", - "description": "Contato direto com o Pokémon diminui o atributo de Velocidade do atacante." - }, - "receiver": { - "name": "Receiver", - "description": "O Pokémon copia a Habilidade de um aliado derrotado." - }, - "powerOfAlchemy": { - "name": "Power of Alchemy", - "description": "O Pokémon copia a Habilidade de um aliado derrotado." - }, - "beastBoost": { - "name": "Beast Boost", - "description": "O Pokémon aumentará seu melhor atributo sempre que derrotar outro Pokémon." - }, - "rksSystem": { - "name": "RKS System", - "description": "Troca o tipo do Pokémon para igualar com o disco de memória que ele tiver instalado." - }, - "electricSurge": { - "name": "Electric Surge", - "description": "Quando o Pokémon entra em batalha, altera o terreno para Terreno Elétrico." - }, - "psychicSurge": { - "name": "Psychic Surge", - "description": "Quando o Pokémon entra em batalha, altera o terreno para Terreno Psíquico." - }, - "mistySurge": { - "name": "Misty Surge", - "description": "Quando o Pokémon entra em batalha, altera o terreno para Terreno Enevoado." - }, - "grassySurge": { - "name": "Grassy Surge", - "description": "Quando o Pokémon entra em batalha, altera o terreno para Terreno de Grama." - }, - "fullMetalBody": { - "name": "Full Metal Body", - "description": "Previne que as Habilidades e movimentos de outros Pokémon diminuam os atributos deste Pokémon." - }, - "shadowShield": { - "name": "Shadow Shield", - "description": "Reduz a quantidade de dano que o Pokémon recebe enquanto estiver com seus PS ao máximo." - }, - "prismArmor": { - "name": "Prism Armor", - "description": "Reduz o dano recebido por movimentos supereficazes." - }, - "neuroforce": { - "name": "Neuroforce", - "description": "Fortalece movimentos supereficazes." - }, - "intrepidSword": { - "name": "Intrepid Sword", - "description": "Aumenta o atributo de Ataque ao entrar em batalha." - }, - "dauntlessShield": { - "name": "Dauntless Shield", - "description": "Aumenta o atributo de Defesa ao entrar em batalha." - }, - "libero": { - "name": "Libero", - "description": "Muda o tipo do Pokémon para o tipo do movimento que ele estiver prestes a usar." - }, - "ballFetch": { - "name": "Ball Fetch", - "description": "Se o Pokémon não estiver segurando nenhum item, ele irá buscar a primeira Poké Bola que falhou em capturar um Pokémon na batalha." - }, - "cottonDown": { - "name": "Cotton Down", - "description": "Quando o Pokémon é atingido por um ataque, ele espalha algodão à volta, diminuindo o atributo de Velocidade de todos os Pokémon, exceto ele mesmo." - }, - "propellerTail": { - "name": "Propeller Tail", - "description": "Ignora os efeitos de Habilidades e movimentos de Pokémon adversários que redirecionam e atraem movimentos para si." - }, - "mirrorArmor": { - "name": "Mirror Armor", - "description": "Devolve apenas os efeitos redutores de atributos que o Pokémon recebe." - }, - "gulpMissile": { - "name": "Gulp Missile", - "description": "Quando o Pokémon usa Surf ou Dive, volta com uma presa. Quando recebe dano, cospe a presa no atacante." - }, - "stalwart": { - "name": "Stalwart", - "description": "Ignora os efeitos de Habilidades e movimentos de Pokémon adversários que redirecionam e atraem movimentos para si." - }, - "steamEngine": { - "name": "Steam Engine", - "description": "Aumenta drasticamente a Velocidade, se for atingido por um movimento do tipo Água ou Fogo." - }, - "punkRock": { - "name": "Punk Rock", - "description": "Aumenta o poder dos movimentos baseados em som. O Pokémon também recebe metade do dano desses tipos de movimentos." - }, - "sandSpit": { - "name": "Sand Spit", - "description": "O Pokémon cria uma tempestade de areia quando é atingido por um ataque." - }, - "iceScales": { - "name": "Ice Scales", - "description": "As gélidas escamas que rodeiam seu corpo reduzem à metade o dano recebido por movimentos especiais." - }, - "ripen": { - "name": "Ripen", - "description": "Amadurece Frutas e dobram seus efeitos." - }, - "iceFace": { - "name": "Ice Face", - "description": "Sua cabeça de gelo pode receber ataques físicos como substituto, mas faz com que a aparência do Pokémon mude. O gelo é restaurado no granizo." - }, - "powerSpot": { - "name": "Power Spot", - "description": "O simples fato de estar próximo ao Pokémon fortalece o poder de movimentos." - }, - "mimicry": { - "name": "Mimicry", - "description": "Muda o tipo do Pokémon dependendo do terreno." - }, - "screenCleaner": { - "name": "Screen Cleaner", - "description": "Quando o Pokémon entra em batalha os efeitos de Tela de Luz, Refletir e Véu Aurora são anulados, tanto para Pokémon aliados quanto para oponentes." - }, - "steelySpirit": { - "name": "Steely Spirit", - "description": "Fortalece o poder dos movimentos do tipo Aço de Pokémon aliados." - }, - "perishBody": { - "name": "Perish Body", - "description": "Quando for atingido por um ataque que cause contato direto, tanto o Pokémon quanto o atacante desmaiarão após três turnos, a não ser que recuem da batalha." - }, - "wanderingSpirit": { - "name": "Wandering Spirit", - "description": "O Pokémon troca de Habilidade com um Pokémon que o atinja com um movimento que faz contato direto." - }, - "gorillaTactics": { - "name": "Gorilla Tactics", - "description": "Aumenta o Ataque do Pokémon, entretanto, só permite que ele utilize o primeiro movimento escolhido." - }, - "neutralizingGas": { - "name": "Neutralizing Gas", - "description": "Se o Pokémon com Gás Neutralizador está na batalha, os efeitos das Habilidades de todos os Pokémon serão anuladas ou não serão ativados." - }, - "pastelVeil": { - "name": "Pastel Veil", - "description": "Protege o Pokémon e seu aliado de serem envenenados." - }, - "hungerSwitch": { - "name": "Hunger Switch", - "description": "O Pokémon troca sua forma, alternando entre o Modo Satisfeito e Modo Voraz ao fim de cada turno." - }, - "quickDraw": { - "name": "Quick Draw", - "description": "Permite que o Pokémon aja primeiro ocasionalmente." - }, - "unseenFist": { - "name": "Unseen Fist", - "description": "Se o Pokémon utilizar movimentos que façam contato direto, pode atacar seu alvo mesmo que ele tenha se protegido." - }, - "curiousMedicine": { - "name": "Curious Medicine", - "description": "Quando o Pokémon entra em uma batalha, espalha medicamentos de sua concha que removem de aliados todas mudanças de estado." - }, - "transistor": { - "name": "Transistor", - "description": "Fortalece movimentos do tipo Elétrico." - }, - "dragonsMaw": { - "name": "Dragon's Maw", - "description": "Fortalece movimentos do tipo Dragão." - }, - "chillingNeigh": { - "name": "Chilling Neigh", - "description": "Quando o Pokémon derrota um alvo, emite um relincho assustador que aumenta seu Ataque." - }, - "grimNeigh": { - "name": "Grim Neigh", - "description": "Quando o Pokémon derrota um alvo, emite um relincho assustador que aumenta seu Ataque Esp." - }, - "asOneGlastrier": { - "name": "As One", - "description": "Esta habilidade combina os efeitos da habilidade Unnerve de Calyrex e da habilidade Chilling Neigh de Glastrier." - }, - "asOneSpectrier": { - "name": "As One", - "description": "Essa Habilidade combina os efeitos das Habilidades Enervar de Calyrex e Relincho Negro de Spectrier." - }, - "lingeringAroma": { - "name": "Lingering Aroma", - "description": "O contato com o Pokémon muda a Habilidade do atacante para Lingering Aroma." - }, - "seedSower": { - "name": "Seed Sower", - "description": "Transforma o solo em Terreno de Grama quando o Pokémon é atingido por um ataque." - }, - "thermalExchange": { - "name": "Thermal Exchange", - "description": "Aumenta o atributo de Ataque quando o Pokémon é atingido por um movimento do tipo Fogo. O Pokémon também não pode ser queimado." - }, - "angerShell": { - "name": "Anger Shell", - "description": "Quando um ataque faz com que seu HP caia para metade ou menos, o Pokémon se enfurece. Isso reduz seus atributos de Defesa e Defesa Especial, mas aumenta seus atributos de Ataque, Ataque Especial e Velocidade." - }, - "purifyingSalt": { - "name": "Purifying Salt", - "description": "O sal puro do Pokémon o protege de condições de estado e reduz pela metade o dano recebido de movimentos do tipo Fantasma." - }, - "wellBakedBody": { - "name": "Well-Baked Body", - "description": "O Pokémon não recebe dano quando atingido por movimentos do tipo Fogo. Em vez disso, seu atributo de Defesa é aumentado drasticamente." - }, - "windRider": { - "name": "Wind Rider", - "description": "Aumenta o atributo de Ataque do Pokémon se o Vento de Cauda tiver efeito ou se o Pokémon for atingido por um movimento de vento. O Pokémon também não recebe dano de movimentos de vento." - }, - "guardDog": { - "name": "Guard Dog", - "description": "Aumenta o atributo de Ataque do Pokémon se intimidado. Movimentos e itens que forçariam o Pokémon a trocar também falham em funcionar." - }, - "rockyPayload": { - "name": "Rocky Payload", - "description": "Aumenta o poder dos movimentos do tipo Pedra." - }, - "windPower": { - "name": "Wind Power", - "description": "O Pokémon fica carregado quando é atingido por um movimento de vento, aumentando o poder do próximo movimento do tipo Elétrico que o Pokémon usa." - }, - "zeroToHero": { - "name": "Zero to Hero", - "description": "O Pokémon se transforma em sua Forma Herói quando é trocado." - }, - "commander": { - "name": "Commander", - "description": "Quando o Pokémon entra em batalha, ele entra na boca de um Dondozo aliado se ele estiver no campo. O Pokémon então emite comandos de lá." - }, - "electromorphosis": { - "name": "Electromorphosis", - "description": "O Pokémon fica carregado quando sofre dano, aumentando o poder do próximo movimento do tipo Elétrico que o Pokémon usa." - }, - "protosynthesis": { - "name": "Protosynthesis", - "description": "Aumenta o atributo mais proficiente do Pokémon sob sol intenso ou se o Pokémon estiver segurando Booster Energy." - }, - "quarkDrive": { - "name": "Quark Drive", - "description": "Aumenta o atributo mais proficiente do Pokémon em Terreno Elétrico ou se o Pokémon estiver segurando Booster Energy." - }, - "goodAsGold": { - "name": "Good as Gold", - "description": "Um corpo de ouro puro dá ao Pokémon imunidade completa aos movimentos de status de outros Pokémon." - }, - "vesselOfRuin": { - "name": "Vessel of Ruin", - "description": "O poder do recipiente de ruínas do Pokémon reduz os atributos de Ataque Especial de todos os Pokémon exceto o dele." - }, - "swordOfRuin": { - "name": "Sword of Ruin", - "description": "O poder da espada de ruínas do Pokémon reduz os atributos de Defesa de todos os Pokémon exceto o dele." - }, - "tabletsOfRuin": { - "name": "Tablets of Ruin", - "description": "O poder das tábuas de ruínas do Pokémon reduz os atributos de Ataque de todos os Pokémon exceto o dele." - }, - "beadsOfRuin": { - "name": "Beads of Ruin", - "description": "O poder das contas de ruínas do Pokémon reduz os atributos de Defesa Especial de todos os Pokémon exceto o dele." - }, - "orichalcumPulse": { - "name": "Orichalcum Pulse", - "description": "Torna a luz solar intensa quando o Pokémon entra em batalha. O antigo pulso vibrante do Pokémon também aumenta seu atributo de Ataque sob sol intenso." - }, - "hadronEngine": { - "name": "Hadron Engine", - "description": "Transforma o solo em Terreno Elétrico quando o Pokémon entra em batalha. O motor futurista dentro do Pokémon também aumenta seu atributo de Ataque Especial em Terreno Elétrico." - }, - "opportunist": { - "name": "Opportunist", - "description": "Se um atributo de um oponente for aumentado, o Pokémon aproveita a oportunidade para aumentar o mesmo atributo para si mesmo." - }, - "cudChew": { - "name": "Cud Chew", - "description": "Quando o Pokémon come uma Berry, ele a regurgita no final do próximo turno e come novamente." - }, - "sharpness": { - "name": "Sharpness", - "description": "Aumenta o poder dos movimentos de corte." - }, - "supremeOverlord": { - "name": "Supreme Overlord", - "description": "Quando o Pokémon entra em batalha, seus atributos de Ataque e Ataque Especial são levemente aumentados para cada um dos aliados em sua equipe que já foram derrotados." - }, - "costar": { - "name": "Costar", - "description": "Quando o Pokémon entra em batalha, ele copia as mudanças de atributos de um aliado." - }, - "toxicDebris": { - "name": "Toxic Debris", - "description": "Espalha espinhos venenosos aos pés da equipe adversária quando o Pokémon sofre dano de movimentos físicos." - }, - "armorTail": { - "name": "Armor Tail", - "description": "A cauda misteriosa que cobre a cabeça do Pokémon impede que oponentes usem movimentos de prioridade contra o Pokémon ou seus aliados." - }, - "earthEater": { - "name": "Earth Eater", - "description": "Se for atingido por um movimento do tipo Terra, o Pokémon restaura seu HP em vez de sofrer dano." - }, - "myceliumMight": { - "name": "Mycelium Might", - "description": "O Pokémon sempre agirá mais lentamente quando usar movimentos de status, mas esses movimentos não serão impedidos pela Habilidade do alvo." - }, - "mindsEye": { - "name": "Mind's Eye", - "description": "O Pokémon ignora mudanças na evasividade dos oponentes, sua precisão não pode ser reduzida, e ele pode atingir tipos Fantasma com movimentos dos tipos Normal e Lutador." - }, - "supersweetSyrup": { - "name": "Supersweet Syrup", - "description": "Um aroma doce e enjoativo se espalha pelo campo na primeira vez que o Pokémon entra em batalha, reduzindo a evasividade dos Pokémon oponentes." - }, - "hospitality": { - "name": "Hospitality", - "description": "Quando o Pokémon entra em batalha, ele banha seu aliado com hospitalidade, restaurando uma pequena quantidade do HP do aliado." - }, - "toxicChain": { - "name": "Toxic Chain", - "description": "O poder da cadeia tóxica do Pokémon pode envenenar gravemente qualquer alvo que o Pokémon atinja com um movimento." - }, - "embodyAspectTeal": { - "name": "Embody Aspect", - "description": "O coração do Pokémon se enche de memórias, fazendo com que a Máscara Teal brilhe e aumente o atributo de Velocidade do Pokémon." - }, - "embodyAspectWellspring": { - "name": "Embody Aspect", - "description": "O coração do Pokémon se enche de memórias, fazendo com que a Máscara Wellspring brilhe e aumente o atributo de Defesa Especial do Pokémon." - }, - "embodyAspectHearthflame": { - "name": "Embody Aspect", - "description": "O coração do Pokémon se enche de memórias, fazendo com que a Máscara Hearthflame brilhe e aumente o atributo de Ataque do Pokémon." - }, - "embodyAspectCornerstone": { - "name": "Embody Aspect", - "description": "O coração do Pokémon se enche de memórias, fazendo com que a Máscara Cornerstone brilhe e aumente o atributo de Defesa do Pokémon." - }, - "teraShift": { - "name": "Tera Shift", - "description": "Quando o Pokémon entra em batalha, ele absorve a energia ao seu redor e se transforma em sua Forma Terastal." - }, - "teraShell": { - "name": "Tera Shell", - "description": "A casca do Pokémon contém os poderes de cada tipo. Todos os movimentos que causam dano que atingem o Pokémon quando seu HP está cheio não serão muito eficazes." - }, - "teraformZero": { - "name": "Teraform Zero", - "description": "Quando Terapagos muda para sua Forma Estelar, ele usa seus poderes ocultos para eliminar todos os efeitos do clima e do terreno, reduzindo-os a zero." - }, - "poisonPuppeteer": { - "name": "Poison Puppeteer", - "description": "Pokémon envenenados pelos movimentos de Pecharunt também ficarão confusos." - } -} diff --git a/src/locales/pt_BR/achv.json b/src/locales/pt_BR/achv.json deleted file mode 100644 index 93e982b60ea..00000000000 --- a/src/locales/pt_BR/achv.json +++ /dev/null @@ -1,272 +0,0 @@ -{ - "Achievements": { - "name": "Conquistas" - }, - "Locked": { - "name": "Não conquistado" - }, - "MoneyAchv": { - "description": "Acumule um total de ₽{{moneyAmount}}" - }, - "10K_MONEY": { - "name": "Chuva de Dinheiro" - }, - "100K_MONEY": { - "name": "Tô Rica!" - }, - "1M_MONEY": { - "name": "Quem Quer Ser Um Milionário?" - }, - "10M_MONEY": { - "name": "Tio Patinhas" - }, - "DamageAchv": { - "description": "Inflija {{damageAmount}} de dano em um único golpe" - }, - "250_DMG": { - "name": "Essa Doeu!" - }, - "1000_DMG": { - "name": "Essa Doeu Mais!" - }, - "2500_DMG": { - "name": "Essa Doeu Muito!" - }, - "10000_DMG": { - "name": "Essa Doeu Pra Caramba!" - }, - "HealAchv": { - "description": "Cure {{healAmount}} {{HP}} de uma vez só com um movimento, habilidade ou item segurado" - }, - "250_HEAL": { - "name": "Residente" - }, - "1000_HEAL": { - "name": "Enfermeiro", - "name_female": "Enfermeira" - }, - "2500_HEAL": { - "name": "Médico", - "name_female": "Médica" - }, - "10000_HEAL": { - "name": "Médico de Plantão", - "name_female": "Médica de Plantão" - }, - "LevelAchv": { - "description": "Aumente o nível de um Pokémon para o Nv{{level}}" - }, - "LV_100": { - "name": "Calma Que Tem Mais!" - }, - "LV_250": { - "name": "Treinador de Elite", - "name_female": "Treinadora de Elite" - }, - "LV_1000": { - "name": "Ao Infinito e Além!" - }, - "RibbonAchv": { - "description": "Acumule um total de {{ribbonAmount}} Fitas" - }, - "10_RIBBONS": { - "name": "Fita de Bronze" - }, - "25_RIBBONS": { - "name": "Fita de Prata" - }, - "50_RIBBONS": { - "name": "Fita de Ouro" - }, - "75_RIBBONS": { - "name": "Fita de Platina" - }, - "100_RIBBONS": { - "name": "Fita de Diamante" - }, - "TRANSFER_MAX_STAT_STAGE": { - "name": "Trabalho em Equipe", - "description": "Use Baton Pass com pelo menos um atributo aumentado ao máximo" - }, - "MAX_FRIENDSHIP": { - "name": "Melhores Amigos", - "description": "Alcance a amizade máxima com um Pokémon" - }, - "MEGA_EVOLVE": { - "name": "Megamorfose", - "description": "Megaevolua um Pokémon" - }, - "GIGANTAMAX": { - "name": "Ficou Gigante!", - "description": "Gigantamax um Pokémon" - }, - "TERASTALLIZE": { - "name": "Terastalização", - "description": "Terastalize um Pokémon" - }, - "STELLAR_TERASTALLIZE": { - "name": "Estrela Cadente", - "description": "Terastalize um Pokémon para o tipo Estelar" - }, - "SPLICE": { - "name": "Fusão!", - "description": "Funda dois Pokémon com um Splicer de DNA" - }, - "MINI_BLACK_HOLE": { - "name": "Buraco Sem Fundo", - "description": "Adquira um Mini Buraco Negro" - }, - "CATCH_MYTHICAL": { - "name": "Mítico", - "description": "Capture um Pokémon Mítico" - }, - "CATCH_SUB_LEGENDARY": { - "name": "Quase Lendário", - "description": "Capture um Pokémon Semi-Lendário" - }, - "CATCH_LEGENDARY": { - "name": "Lendário", - "description": "Capture um Pokémon Lendário" - }, - "SEE_SHINY": { - "name": "Ué, Tá Brilhando?", - "description": "Encontre um Pokémon Shiny selvagem" - }, - "SHINY_PARTY": { - "name": "Tá Todo Mundo Brilhando!", - "description": "Tenha uma equipe formada por 6 Pokémon Shiny" - }, - "HATCH_MYTHICAL": { - "name": "Ovo Mítico", - "description": "Choque um Pokémon Mítico" - }, - "HATCH_SUB_LEGENDARY": { - "name": "Ovo Semi-Lendário", - "description": "Choque um Pokémon Semi-Lendário" - }, - "HATCH_LEGENDARY": { - "name": "Ovo Lendário", - "description": "Choque um Pokémon Lendário" - }, - "HATCH_SHINY": { - "name": "Ovo Shiny", - "description": "Choque um Pokémon Shiny" - }, - "HIDDEN_ABILITY": { - "name": "Potencial Oculto", - "description": "Capture um Pokémon com uma Habilidade Oculta" - }, - "PERFECT_IVS": { - "name": "Perfeição Certificada", - "description": "Obtenha IVs perfeitos em um Pokémon" - }, - "CLASSIC_VICTORY": { - "name": "Invencível", - "description": "Vença o jogo no modo clássico" - }, - "UNEVOLVED_CLASSIC_VICTORY": { - "name": "Tire as Crianças da Sala", - "description": "Vença o jogo no Modo Clássico com pelo menos um membro da equipe não evoluído." - }, - "MONO_GEN_ONE": { - "name": "O Início de Tudo", - "description": "Complete o desafio da geração um." - }, - "MONO_GEN_TWO": { - "name": "Geração 1.5", - "description": "Complete o desafio da geração dois." - }, - "MONO_GEN_THREE": { - "name": "Será que tem muita água?", - "description": "Complete o desafio da geração três." - }, - "MONO_GEN_FOUR": { - "name": "Essa foi a mais difícil?", - "description": "Complete o desafio da geração quatro." - }, - "MONO_GEN_FIVE": { - "name": "Nada original", - "description": "Complete o desafio da geração cinco." - }, - "MONO_GEN_SIX": { - "name": "Esse croissant tem recheio?", - "description": "Complete o desafio da geração seis." - }, - "MONO_GEN_SEVEN": { - "name": "Z-Move ou Se vira nos 30?", - "description": "Complete o desafio da geração sete." - }, - "MONO_GEN_EIGHT": { - "name": "Finalmente ele ganhou!", - "description": "Complete o desafio da geração oito." - }, - "MONO_GEN_NINE": { - "name": "Isso aqui tá muito fácil!", - "description": "Complete o desafio da geração nove." - }, - "MonoType": { - "description": "Complete o desafio de monotipo {{type}}." - }, - "MONO_NORMAL": { - "name": "Extra Ordinário" - }, - "MONO_FIGHTING": { - "name": "Briga de Rua" - }, - "MONO_FLYING": { - "name": "Rinha de Pidgeys" - }, - "MONO_POISON": { - "name": "Menina Veneno" - }, - "MONO_GROUND": { - "name": "Comendo Poeira" - }, - "MONO_ROCK": { - "name": "...Tanto Bate Até Que Fura" - }, - "MONO_BUG": { - "name": "Vida de Inseto" - }, - "MONO_GHOST": { - "name": "Fantasminha Camarada" - }, - "MONO_STEEL": { - "name": "Levantando Ferro" - }, - "MONO_FIRE": { - "name": "Tá Pegando Fogo, Bicho!" - }, - "MONO_WATER": { - "name": "Água Mole em Pedra Dura..." - }, - "MONO_GRASS": { - "name": "Jardim Botânico" - }, - "MONO_ELECTRIC": { - "name": "Choque de Realidade" - }, - "MONO_PSYCHIC": { - "name": "Preciso de Terapia" - }, - "MONO_ICE": { - "name": "Era do Gelo" - }, - "MONO_DRAGON": { - "name": "Caverna do Dragão" - }, - "MONO_DARK": { - "name": "É Só Uma Fase" - }, - "MONO_FAIRY": { - "name": "Clube das Winx" - }, - "FRESH_START": { - "name": "De Primeira!", - "description": "Complete o desafio de novo começo." - }, - "INVERSE_BATTLE": { - "name": "A torre da derrotA", - "description": "Complete o desafio da Batalha Inversa.\n.asrevnI ahlataB ad oifased o etelpmoC" - } -} diff --git a/src/locales/pt_BR/arena-flyout.json b/src/locales/pt_BR/arena-flyout.json deleted file mode 100644 index a4be2727b27..00000000000 --- a/src/locales/pt_BR/arena-flyout.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "activeBattleEffects": "Efeitos de Batalha Ativos", - "player": "Jogador", - "neutral": "Neutro", - "enemy": "Inimigo", - "sunny": "Ensolarado", - "rain": "Chuva", - "sandstorm": "Tempestade de Areia", - "hail": "Granizo", - "snow": "Neve", - "fog": "Névoa", - "heavyRain": "Chuva Forte", - "harshSun": "Sol Forte", - "strongWinds": "Ventos Fortes", - "misty": "Terreno Enevoado", - "electric": "Terreno Elétrico", - "grassy": "Terreno de Planta", - "psychic": "Terreno Psíquico", - "mudSport": "Mud Sport", - "waterSport": "Water Sport", - "spikes": "Spikes", - "toxicSpikes": "Toxic Spikes", - "mist": "Mist", - "futureSight": "Future Sight", - "doomDesire": "Doom Desire", - "wish": "Wish", - "stealthRock": "Stealth Rock", - "stickyWeb": "Sticky Web", - "trickRoom": "Trick Room", - "gravity": "Gravity", - "reflect": "Reflect", - "lightScreen": "Light Screen", - "auroraVeil": "Aurora Veil", - "quickGuard": "Quick Guard", - "wideGuard": "Wide Guard", - "matBlock": "Mat Block", - "craftyShield": "Crafty Shield", - "tailwind": "Tailwind", - "happyHour": "Happy Hour", - "safeguard": "Safeguard" -} diff --git a/src/locales/pt_BR/arena-tag.json b/src/locales/pt_BR/arena-tag.json deleted file mode 100644 index 7ab1ecea721..00000000000 --- a/src/locales/pt_BR/arena-tag.json +++ /dev/null @@ -1,57 +0,0 @@ -{ - "yourTeam": "sua equipe", - "opposingTeam": "a equipe adversária", - "arenaOnRemove": "O efeito de {{moveName}} acabou.", - "arenaOnRemovePlayer": "O efeito de {{moveName}} acabou\nem sua equipe.", - "arenaOnRemoveEnemy": "O efeito de {{moveName}} acabou\nna equipe adversária.", - "mistOnAdd": "A equipe de {{pokemonNameWithAffix}} está protegida\npela névoa!", - "mistApply": "A névoa previne\na diminuição de atributos!", - "reflectOnAdd": "Reflect reduziu o dano de movimentos físicos.", - "reflectOnAddPlayer": "Reflect reduziu o dano de movimentos físicos em sua equipe.", - "reflectOnAddEnemy": "Reflect reduziu o dano de movimentos físicos na equipe adversária.", - "lightScreenOnAdd": "Light Screen reduziu o dano de movimentos especiais.", - "lightScreenOnAddPlayer": "Light Screen reduziu o dano de movimentos especiais em sua equipe.", - "lightScreenOnAddEnemy": "Light Screen reduziu o dano de movimentos especiais na equipe adversária.", - "auroraVeilOnAdd": "Aurora Veil reduziu o dano de movimentos.", - "auroraVeilOnAddPlayer": "Aurora Veil reduziu o dano de movimentos em sua equipe.", - "auroraVeilOnAddEnemy": "Aurora Veil reduziu o dano de movimentos na equipe adversária.", - "conditionalProtectOnAdd": "{{moveName}} protegeu a equipe!", - "conditionalProtectOnAddPlayer": "{{moveName}} protegeu sua equipe!", - "conditionalProtectOnAddEnemy": "{{moveName}} protegeu a\nequipe adversária!", - "conditionalProtectApply": "{{moveName}} protegeu {{pokemonNameWithAffix}}!", - "matBlockOnAdd": "{{pokemonNameWithAffix}} pretende levantar um tapete\npara bloquear ataques!", - "noCritOnAddPlayer": "{{moveName}} protegeu sua\nequipe de acertos críticos!", - "noCritOnAddEnemy": "{{moveName}} protegeu a\nequipe adversária de acertos críticos", - "noCritOnRemove": "{{moveName}} de {{pokemonNameWithAffix}}\nacabou!", - "wishTagOnAdd": "O desejo de {{pokemonNameWithAffix}}\nfoi concedido!", - "mudSportOnAdd": "O poder de movimentos elétricos foi enfraquecido!", - "mudSportOnRemove": "Os efeitos de Mud Sport\nsumiram.", - "waterSportOnAdd": "O poder de movimentos de fogo foi enfraquecido!", - "waterSportOnRemove": "Os efeitos de Water Sport\nsumiram.", - "spikesOnAdd": "{{moveName}} foram espalhados\nno chão ao redor de {{opponentDesc}}!", - "spikesActivateTrap": "{{pokemonNameWithAffix}} foi ferido\npelos espinhos!", - "toxicSpikesOnAdd": "{{moveName}} foram espalhados\nno chão ao redor de {{opponentDesc}}!", - "toxicSpikesActivateTrapPoison": "{{pokemonNameWithAffix}} absorveu os {{moveName}}!", - "stealthRockOnAdd": "Pedras pontiagudas estão flutuando\nao redor de {{opponentDesc}}!", - "stealthRockActivateTrap": "{{pokemonNameWithAffix}} foi atingido\npor pedras pontiagudas!", - "stickyWebOnAdd": "Uma {{moveName}} foi espalhada no chão ao redor da equipe adversária!", - "stickyWebActivateTrap": "{{pokemonName}} adversário foi pego por uma Sticky Web!", - "trickRoomOnAdd": "{{pokemonNameWithAffix}} distorceu\nas dimensões!", - "trickRoomOnRemove": "As dimensões distorcidas\nretornaram ao normal!", - "gravityOnAdd": "A gravidade aumentou!", - "gravityOnRemove": "A gravidade retornou ao normal!", - "tailwindOnAdd": "O Tailwind soprou de trás de sua equipe!", - "tailwindOnAddPlayer": "O Tailwind soprou de trás de\nsua equipe!", - "tailwindOnAddEnemy": "O Tailwind soprou de trás da\nequipe adversária!", - "tailwindOnRemove": "O Tailwind de sua equipe acabou!", - "tailwindOnRemovePlayer": "O Tailwind de sua equipe acabou!", - "tailwindOnRemoveEnemy": "O Tailwind da equipe adversária acabou!", - "happyHourOnAdd": "Todos foram envolvidos por uma atmosfera alegre!", - "happyHourOnRemove": "A atmosfera retornou ao normal.", - "safeguardOnAdd": "O campo de batalha está envolto num véu místico!", - "safeguardOnAddPlayer": "Sua equipe se envolveu num véu místico!", - "safeguardOnAddEnemy": "A equipe adversária se envolveu num véu místico!", - "safeguardOnRemove": "O campo não está mais protegido por Safeguard!", - "safeguardOnRemovePlayer": "Sua equipe não está mais protegido por Safeguard!", - "safeguardOnRemoveEnemy": "A equipe adversária não está mais protegido por Safeguard!" -} \ No newline at end of file diff --git a/src/locales/pt_BR/battle-info.json b/src/locales/pt_BR/battle-info.json deleted file mode 100644 index 0fd211c5c85..00000000000 --- a/src/locales/pt_BR/battle-info.json +++ /dev/null @@ -1,3 +0,0 @@ -{ - "generation": "Geração {{generation}}" -} \ No newline at end of file diff --git a/src/locales/pt_BR/battle-message-ui-handler.json b/src/locales/pt_BR/battle-message-ui-handler.json deleted file mode 100644 index ee7062bccba..00000000000 --- a/src/locales/pt_BR/battle-message-ui-handler.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "ivBest": "Perfeito", - "ivFantastic": "Fantástico", - "ivVeryGood": "Muito Bom", - "ivPrettyGood": "Bom", - "ivDecent": "Regular", - "ivNoGood": "Ruim" -} \ No newline at end of file diff --git a/src/locales/pt_BR/battle-scene.json b/src/locales/pt_BR/battle-scene.json deleted file mode 100644 index a0288475d69..00000000000 --- a/src/locales/pt_BR/battle-scene.json +++ /dev/null @@ -1,3 +0,0 @@ -{ - "moneyOwned": "₽{{formattedMoney}}" -} \ No newline at end of file diff --git a/src/locales/pt_BR/battle.json b/src/locales/pt_BR/battle.json deleted file mode 100644 index 08eeb99e0cd..00000000000 --- a/src/locales/pt_BR/battle.json +++ /dev/null @@ -1,100 +0,0 @@ -{ - "bossAppeared": "{{bossName}} apareceu.", - "trainerAppeared": "{{trainerName}}\nquer batalhar!", - "trainerAppearedDouble": "{{trainerName}}\nquerem batalhar!", - "singleWildAppeared": "Um {{pokemonName}} selvagem apareceu!", - "trainerSendOut": "{{trainerName}} escolheu\n{{pokemonName}}!", - "multiWildAppeared": "Um {{pokemonName1}} e um {{pokemonName2}} selvagens\napareceram!", - "playerComeBack": "{{pokemonName}}, retorne!", - "trainerComeBack": "{{trainerName}} retirou {{pokemonName}} da batalha!", - "playerGo": "{{pokemonName}}, eu escolho você!", - "trainerGo": "{{trainerName}} escolheu {{pokemonName}}!", - "switchQuestion": "Quer trocar\nde {{pokemonName}}?", - "trainerDefeated": "Você derrotou\n{{trainerName}}!", - "moneyWon": "Você ganhou\n₽{{moneyAmount}} por vencer!", - "moneyPickedUp": "Você pegou ₽{{moneyAmount}} do chão!", - "pokemonCaught": "{{pokemonName}} foi capturado!", - "addedAsAStarter": "{{pokemonName}} foi adicionado\naos seus iniciais!", - "partyFull": "Sua equipe está cheia.\nSolte um Pokémon para ter espaço para {{pokemonName}}?", - "pokemon": "Pokémon", - "sendOutPokemon": "{{pokemonName}}, eu escolho você!!", - "hitResultCriticalHit": "Foi um acerto crítico!", - "hitResultSuperEffective": "É supereficaz!", - "hitResultNotVeryEffective": "É pouco eficaz...", - "hitResultNoEffect": "Isso não afeta {{pokemonName}}!", - "hitResultImmune": "{{pokemonName}} não é afetado!", - "hitResultOneHitKO": "Foi um nocaute de um golpe!", - "attackFailed": "Mas falhou!", - "attackMissed": "{{pokemonNameWithAffix}} desviou do ataque!", - "attackHitsCount": "Acertou {{count}} vezes.", - "rewardGain": "Você recebeu\n{{modifierName}}!", - "expGain": "{{pokemonName}} ganhou\n{{exp}} pontos de experiência.", - "levelUp": "{{pokemonName}} subiu para \nNv. {{level}}!", - "learnMove": "{{pokemonName}} aprendeu {{moveName}}!", - "learnMovePrompt": "{{pokemonName}} quer aprender\n{{moveName}}.", - "learnMoveLimitReached": "Porém, {{pokemonName}} já sabe\nquatro movimentos.", - "learnMoveReplaceQuestion": "Quer substituir um de seus movimentos por {{moveName}}?", - "learnMoveStopTeaching": "Você não quer aprender\n{{moveName}}?", - "learnMoveNotLearned": "{{pokemonName}} não aprendeu {{moveName}}.", - "learnMoveForgetQuestion": "Qual movimento quer esquecer?", - "learnMoveForgetSuccess": "{{pokemonName}} esqueceu como usar {{moveName}}.", - "countdownPoof": "@d{32}1, @d{15}2, @d{15}e@d{15}… @d{15}… @d{15}… @d{15}@s{se/pb_bounce_1}Puf!", - "learnMoveAnd": "E…", - "levelCapUp": "O nível máximo aumentou\npara {{levelCap}}!", - "moveNotImplemented": "{{moveName}} ainda não foi implementado e não pode ser usado.", - "moveNoPP": "Não há mais PP\npara esse movimento!", - "moveDisabled": "Não se pode usar {{moveName}} porque foi desabilitado!", - "disableInterruptedMove": "{{moveName}} de {{pokemonNameWithAffix}}\nestá desabilitado!", - "noPokeballForce": "Uma força misteriosa\nte impede de usar Poké Bolas.", - "noPokeballTrainer": "Não se pode capturar\nPokémon dos outros!", - "noPokeballMulti": "Não se pode lançar Poké Bolas\nquando há mais de um Pokémon!", - "noPokeballStrong": "Este Pokémon é forte demais para ser capturado!\nÉ preciso enfraquecê-lo primeiro!", - "noEscapeForce": "Uma força misteriosa\nte impede de fugir.", - "noEscapeTrainer": "Não se pode fugir de\nbatalhas contra treinadores!", - "noEscapePokemon": "O movimento {{moveName}} de {{pokemonName}} te impede de fugir!", - "runAwaySuccess": "Você fugiu com sucesso.", - "runAwayCannotEscape": "Você nao conseguiu fugir!", - "escapeVerbSwitch": "trocar", - "escapeVerbFlee": "fugir", - "notDisabled": "O movimento {{moveName}}\nnão está mais desabilitado!", - "turnEndHpRestore": "Os PS de {{pokemonName}} foram restaurados!", - "hpIsFull": "Os PS de {{pokemonName}}\njá estão cheios!", - "skipItemQuestion": "Tem certeza de que não quer escolher um item?", - "itemStackFull": "O estoque de {{fullItemName}} está cheio.\nVocê receberá {{itemName}} no lugar.", - "eggHatching": "Opa?", - "eggSkipPrompt": "Pular para súmario de ovos?", - "ivScannerUseQuestion": "Quer usar o Scanner de IVs em {{pokemonName}}?", - "wildPokemonWithAffix": "{{pokemonName}} selvagem", - "foePokemonWithAffix": "{{pokemonName}} adversário", - "useMove": "{{pokemonNameWithAffix}} usou {{moveName}}!", - "drainMessage": "{{pokemonName}} teve sua\nenergia drenada!", - "regainHealth": "{{pokemonName}} recuperou\npontos de saúde!", - "stealEatBerry": "{{pokemonName}} roubou e comeu\na {{berryName}} de {{targetName}}!", - "ppHealBerry": "{{pokemonNameWithAffix}} restaurou PP do movimento {{moveName}}\nusando sua {{berryName}}!", - "hpHealBerry": "{{pokemonNameWithAffix}} restarou sua saúde usando\nsua {{berryName}}!", - "fainted": "{{pokemonNameWithAffix}} desmaiou!", - "statsAnd": "e", - "stats": "Os atributos", - "statRose_one": "{{stats}} de {{pokemonNameWithAffix}} aumentou!", - "statRose_other": "{{stats}} de {{pokemonNameWithAffix}} aumentaram!", - "statSharplyRose_one": "{{stats}} de {{pokemonNameWithAffix}} aumentou bruscamente!", - "statSharplyRose_other": "{{stats}} de {{pokemonNameWithAffix}} aumentaram bruscamente!", - "statRoseDrastically_one": "{{stats}} de {{pokemonNameWithAffix}} aumentou drasticamente!", - "statRoseDrastically_other": "{{stats}} de {{pokemonNameWithAffix}} aumentaram drasticamente!", - "statWontGoAnyHigher_one": "{{stats}} de {{pokemonNameWithAffix}} não vai mais aumentar!", - "statWontGoAnyHigher_other": "{{stats}} de {{pokemonNameWithAffix}} não vão mais aumentar!", - "statFell_one": "{{stats}} de {{pokemonNameWithAffix}} diminuiu!", - "statFell_other": "{{stats}} de {{pokemonNameWithAffix}} diminuíram!", - "statHarshlyFell_one": "{{stats}} de {{pokemonNameWithAffix}} diminuiu duramente!", - "statHarshlyFell_other": "{{stats}} de {{pokemonNameWithAffix}} diminuíram duramente!", - "statSeverelyFell_one": "{{stats}} de {{pokemonNameWithAffix}} diminuiu severamente!", - "statSeverelyFell_other": "{{stats}} de {{pokemonNameWithAffix}} diminuíram severamente!", - "statWontGoAnyLower_one": "{{stats}} de {{pokemonNameWithAffix}} não vai mais diminuir!", - "statWontGoAnyLower_other": "{{stats}} de {{pokemonNameWithAffix}} não vão mais diminuir!", - "transformedIntoType": "{{pokemonName}} se transformou\nno tipo {{type}}!", - "ppReduced": "O PP do movimento {{moveName}} de\n{{targetName}} foi reduzido em {{reduction}}!", - "retryBattle": "Você gostaria de tentar novamente desde o início da batalha?", - "unlockedSomething": "{{unlockedThing}}\nfoi desbloqueado.", - "congratulations": "Parabéns!", - "beatModeFirstTime": "{{speciesName}} venceu o Modo {{gameMode}} pela primeira vez!\nVocê recebeu {{newModifier}}!" -} diff --git a/src/locales/pt_BR/battler-tags.json b/src/locales/pt_BR/battler-tags.json deleted file mode 100644 index ce645a3d24f..00000000000 --- a/src/locales/pt_BR/battler-tags.json +++ /dev/null @@ -1,77 +0,0 @@ -{ - "trappedDesc": "o aprisionamento", - "flinchedDesc": "a hesitação", - "confusedDesc": "a confusão", - "infatuatedDesc": "a paixão", - "seedDesc": "sementes", - "nightmareDesc": "os pesadelos", - "ingrainDesc": "o enraizamento", - "drowsyDesc": "a sonolência", - "rechargingLapse": "{{pokemonNameWithAffix}} precisa\nrecarregar!", - "trappedOnAdd": "{{pokemonNameWithAffix}} não pode\nmais escapar!", - "trappedOnRemove": "{{pokemonNameWithAffix}} foi liberto\nde {{moveName}}!", - "flinchedLapse": "{{pokemonNameWithAffix}} hesitou!", - "confusedOnAdd": "{{pokemonNameWithAffix}} ficou\nconfuso!", - "confusedOnRemove": "{{pokemonNameWithAffix}} saiu\nde sua confusão!", - "confusedOnOverlap": "{{pokemonNameWithAffix}} já\nestá confuso!", - "confusedLapse": "{{pokemonNameWithAffix}} está\nconfuso!", - "confusedLapseHurtItself": "Se machucou em sua\nconfusão!", - "destinyBondLapseIsBoss": "{{pokemonNameWithAffix}} não é afetado\npelos efeitos de Destiny Bond.", - "destinyBondLapse": "{{pokemonNameWithAffix}} levou\n{{pokemonNameWithAffix2}} junto com ele!", - "infatuatedOnAdd": "{{pokemonNameWithAffix}} se apaixonou\npor {{sourcePokemonName}}!", - "infatuatedOnOverlap": "{{pokemonNameWithAffix}} já\nestá apaixonado!", - "infatuatedLapse": "{{pokemonNameWithAffix}} está apaixonado\npor {{sourcePokemonName}}!", - "infatuatedLapseImmobilize": "{{pokemonNameWithAffix}} está\nimobilizado pelo amor!", - "infatuatedOnRemove": "{{pokemonNameWithAffix}} superou\nsua paixão.", - "seededOnAdd": "{{pokemonNameWithAffix}} foi semeado!", - "seededLapse": "A saúde de {{pokemonNameWithAffix}}\nfoi sugada pelo Leech Seed!", - "seededLapseShed": "O Leech Seed de{{pokemonNameWithAffix}}\nsugou todo o gotejamento!", - "nightmareOnAdd": "{{pokemonNameWithAffix}} começou\na ter um Nightmare!", - "nightmareOnOverlap": "{{pokemonNameWithAffix}} já\nestá preso em um Nightmare!", - "nightmareLapse": "{{pokemonNameWithAffix}} está preso\nem um Nightmare!", - "encoreOnAdd": "{{pokemonNameWithAffix}} ganhou\num Encore!", - "encoreOnRemove": "O Encore de {{pokemonNameWithAffix}}\nacabou!", - "helpingHandOnAdd": "{{pokemonNameWithAffix}} está pronto para\najudar {{pokemonName}}!", - "ingrainLapse": "{{pokemonNameWithAffix}} absorveu\nnutrientes com suas raízes!", - "ingrainOnTrap": "{{pokemonNameWithAffix}} plantou suas raízes!", - "aquaRingOnAdd": "{{pokemonNameWithAffix}} se cercou\ncom um véu de água!", - "aquaRingLapse": "{{moveName}} restaurou\nPS de {{pokemonName}}!", - "drowsyOnAdd": "{{pokemonNameWithAffix}} ficou com sono!", - "damagingTrapLapse": "{{pokemonNameWithAffix}} foi ferido\npelo {{moveName}}!", - "bindOnTrap": "{{pokemonNameWithAffix}} foi espremido\npelo {{moveName}} de {{sourcePokemonName}}!", - "wrapOnTrap": "{{pokemonNameWithAffix}} foi enrolado\npor {{sourcePokemonName}}!", - "vortexOnTrap": "{{pokemonNameWithAffix}} ficou preso\nno vórtice!", - "clampOnTrap": "{{sourcePokemonNameWithAffix}} prendeu\n{{pokemonName}}!", - "sandTombOnTrap": "{{pokemonNameWithAffix}} foi preso\npor {{moveName}}!", - "magmaStormOnTrap": "{{pokemonNameWithAffix}} foi preso\npor um redemoinho de magma!", - "snapTrapOnTrap": "{{pokemonNameWithAffix}} foi preso\npor uma armadilha!", - "thunderCageOnTrap": "{{sourcePokemonNameWithAffix}} prendeu\n{{pokemonNameWithAffix}}!", - "infestationOnTrap": "{{pokemonNameWithAffix}} foi ferido por \numa infestação de {{sourcePokemonNameWithAffix}}!", - "protectedOnAdd": "{{pokemonNameWithAffix}}\nse protegeu!", - "protectedLapse": "{{pokemonNameWithAffix}}\nse protegeu!", - "enduringOnAdd": "{{pokemonNameWithAffix}} está\npreparado!", - "enduringLapse": "{{pokemonNameWithAffix}} suportou\no golpe!", - "sturdyLapse": "{{pokemonNameWithAffix}} suportou\no golpe!", - "perishSongLapse": "O tempo restante de {{pokemonNameWithAffix}} diminuiu para {{turnCount}}.", - "centerOfAttentionOnAdd": "{{pokemonNameWithAffix}} virou o centro\ndas atenções!", - "truantLapse": "{{pokemonNameWithAffix}} está\nviajando na maionese!", - "slowStartOnAdd": "{{pokemonNameWithAffix}} não\nestá preparado!", - "slowStartOnRemove": "{{pokemonNameWithAffix}} finalmente\nconseguiu se recompor!", - "highestStatBoostOnAdd": "O atributo de {{statName}} de\n{{pokemonNameWithAffix}} aumentou!", - "highestStatBoostOnRemove": "Os efeitos do {{abilityName}} de\n{{pokemonNameWithAffix}} acabaram!", - "magnetRisenOnAdd": "{{pokemonNameWithAffix}} levitou com eletromagnetismo!", - "magnetRisenOnRemove": "O eletromagnetismo de {{pokemonNameWithAffix}} sumiu!", - "critBoostOnAdd": "{{pokemonNameWithAffix}} está ficando\nbombado!", - "critBoostOnRemove": "{{pokemonNameWithAffix}} relaxou.", - "saltCuredOnAdd": "{{pokemonNameWithAffix}} está sendo curado com sal!", - "saltCuredLapse": "{{pokemonNameWithAffix}} foi ferido pelo {{moveName}}!", - "cursedOnAdd": "{{pokemonNameWithAffix}} cortou seus PS pela metade e amaldiçoou {{pokemonName}}!", - "cursedLapse": "{{pokemonNameWithAffix}} foi ferido pelo Curse!", - "stockpilingOnAdd": "{{pokemonNameWithAffix}} estocou {{stockpiledCount}}!", - "disabledOnAdd": "{{moveName}} de {{pokemonNameWithAffix}}\nfoi desabilitado!", - "disabledLapse": "{{moveName}} de {{pokemonNameWithAffix}}\nnão está mais desabilitado.", - "tarShotOnAdd": "{{pokemonNameWithAffix}} tornou-se mais fraco ao fogo!", - "substituteOnAdd": "{{pokemonNameWithAffix}} colocou um substituto!", - "substituteOnHit": "O substituto tomou o dano pelo {{pokemonNameWithAffix}}!", - "substituteOnRemove": "O substituto de {{pokemonNameWithAffix}} desbotou!" -} diff --git a/src/locales/pt_BR/berry.json b/src/locales/pt_BR/berry.json deleted file mode 100644 index 0ca5d3de286..00000000000 --- a/src/locales/pt_BR/berry.json +++ /dev/null @@ -1,46 +0,0 @@ -{ - "SITRUS": { - "name": "Fruta Sitrus", - "effect": "Restaura 25% dos PS se os PS estiverem abaixo de 50%" - }, - "LUM": { - "name": "Fruta Lum", - "effect": "Cura qualquer mudança de estado ou confusão" - }, - "ENIGMA": { - "name": "Fruta Enigma", - "effect": "Restaura 25% dos PS se atingido por um golpe supereficaz" - }, - "LIECHI": { - "name": "Fruta Liechi", - "effect": "Aumenta o Ataque se os PS estiverem abaixo de 25%" - }, - "GANLON": { - "name": "Fruta Ganlon", - "effect": "Aumenta a Defesa se os PS estiverem abaixo de 25%" - }, - "PETAYA": { - "name": "Fruta Petaya", - "effect": "Aumenta o Ataque Especial se os PS estiverem abaixo de 25%" - }, - "APICOT": { - "name": "Fruta Apicot", - "effect": "Aumenta a Defesa Especial se os PS estiverem abaixo de 25%" - }, - "SALAC": { - "name": "Fruta Salac", - "effect": "Aumenta a Velocidade se os PS estiverem abaixo de 25%" - }, - "LANSAT": { - "name": "Fruta Lansat", - "effect": "Aumenta a chance de acerto crítico se os PS estiverem abaixo de 25%" - }, - "STARF": { - "name": "Fruta Starf", - "effect": "Aumenta drasticamente um atributo aleatório se os PS estiverem abaixo de 25%" - }, - "LEPPA": { - "name": "Fruta Leppa", - "effect": "Restaura 10 PP de um movimento se seus PP acabarem" - } -} \ No newline at end of file diff --git a/src/locales/pt_BR/bgm-name.json b/src/locales/pt_BR/bgm-name.json deleted file mode 100644 index 86d8ce3e790..00000000000 --- a/src/locales/pt_BR/bgm-name.json +++ /dev/null @@ -1,150 +0,0 @@ -{ - "music": "Música: ", - "missing_entries": "{{name}}", - "battle_kanto_champion": "B2W2 Batalha do Campeão de Kanto", - "battle_johto_champion": "B2W2 Batalha do Campeão de Johto", - "battle_hoenn_champion_g5": "B2W2 Batalha do Campeão de Hoenn", - "battle_hoenn_champion_g6": "ORAS Batalha do Campeão de Hoenn", - "battle_sinnoh_champion": "B2W2 Batalha do Campeão de Sinnoh", - "battle_champion_alder": "BW Batalha do Campeão de Unova", - "battle_champion_iris": "B2W2 Batalha do Campeão de Unova", - "battle_kalos_champion": "XY Batalha do Campeão de Kalos", - "battle_alola_champion": "USUM Batalha do Campeão de Alola", - "battle_galar_champion": "SWSH Batalha do Campeão de Galar", - "battle_champion_geeta": "SV Batalha da Campeã Geeta", - "battle_champion_nemona": "SV Batalha da Campeã Nemona", - "battle_champion_kieran": "SV Batalha do Campeão Kieran", - "battle_hoenn_elite": "ORAS Batalha da Elite dos Quatro", - "battle_unova_elite": "BW Batalha da Elite dos Quatro", - "battle_kalos_elite": "XY Batalha da Elite dos Quatro", - "battle_alola_elite": "SM Batalha da Elite dos Quatro", - "battle_galar_elite": "SWSH Batalha da Liga Pokémon", - "battle_paldea_elite": "SV Batalha da Elite dos Quatro", - "battle_bb_elite": "SV Liga BB Batalha da Elite dos Quatro", - "battle_final_encounter": "PMD RTDX Domínio do Rayquaza", - "battle_final": "BW Batalha do Ghetsis", - "battle_kanto_gym": "B2W2 Batalha de Ginásio de Kanto", - "battle_johto_gym": "B2W2 Batalha de Ginásio de Johto", - "battle_hoenn_gym": "B2W2 Batalha de Ginásio de Hoenn", - "battle_sinnoh_gym": "B2W2 Batalha de Ginásio de Sinnoh", - "battle_unova_gym": "BW Batalha de Ginásio de Unova", - "battle_kalos_gym": "XY Batalha de Ginásio de Kalos", - "battle_galar_gym": "SWSH Batalha de Ginásio de Galar", - "battle_paldea_gym": "SV Batalha de Ginásio de Paldea", - "battle_legendary_kanto": "XY Batalha dos Lendários de Kanto", - "battle_legendary_raikou": "HGSS Batalha do Raikou", - "battle_legendary_entei": "HGSS Batalha do Entei", - "battle_legendary_suicune": "HGSS Batalha do Suicune", - "battle_legendary_lugia": "HGSS Batalha do Lugia", - "battle_legendary_ho_oh": "HGSS Batalha do Ho-Oh", - "battle_legendary_regis_g5": "B2W2 Batalha dos Titãs Lendários", - "battle_legendary_regis_g6": "ORAS Batalha dos Titãs Lendários", - "battle_legendary_gro_kyo": "ORAS Batalha do Groudon & Kyogre", - "battle_legendary_rayquaza": "ORAS Batalha do Rayquaza", - "battle_legendary_deoxys": "ORAS Batalha do Deoxys", - "battle_legendary_lake_trio": "ORAS Batalha do Trio dos Lagos", - "battle_legendary_sinnoh": "ORAS Batalha dos Lendários de Sinnoh", - "battle_legendary_dia_pal": "ORAS Batalha do Dialga & Palkia", - "battle_legendary_origin_forme": "LA Origin Batalha com Dialga & Palkia", - "battle_legendary_giratina": "ORAS Batalha do Giratina", - "battle_legendary_arceus": "HGSS Batalha do Arceus", - "battle_legendary_unova": "BW Batalha dos Lendários de Unova", - "battle_legendary_kyurem": "BW Batalha do Kyurem", - "battle_legendary_res_zek": "BW Batalha do Reshiram & Zekrom", - "battle_legendary_xern_yvel": "XY Batalha do Xerneas & Yveltal", - "battle_legendary_tapu": "SM Batalha dos Guardiões de Alola", - "battle_legendary_sol_lun": "SM Batalha do Solgaleo & Lunala", - "battle_legendary_ub": "SM Batalha das Ultracriaturas", - "battle_legendary_dusk_dawn": "USUM Batalha do Necrozma Crepúsculo & Alvorada", - "battle_legendary_ultra_nec": "USUM Batalha do Necrozma Ultra", - "battle_legendary_zac_zam": "SWSH Batalha do Zacian & Zamazenta", - "battle_legendary_glas_spec": "SWSH Batalha do Glastrier & Spectrier", - "battle_legendary_calyrex": "SWSH Batalha do Calyrex", - "battle_legendary_riders": "SWSH Batalha com Ice & Shadow Rider Calyrex", - "battle_legendary_birds_galar": "SWSH Batalha dos Pássaros Lendários de Galar", - "battle_legendary_ruinous": "SV Batalha dos Lendários Ruinosos", - "battle_legendary_kor_mir": "SV Batalha das Cavernas da Área Zero", - "battle_legendary_loyal_three": "SV Batalha dos Três Leais", - "battle_legendary_ogerpon": "SV Batalha do Ogerpon", - "battle_legendary_terapagos": "SV Batalha do Terapagos", - "battle_legendary_pecharunt": "SV Batalha do Pecharunt", - "battle_rival": "BW Batalha do Rival", - "battle_rival_2": "BW Batalha do N", - "battle_rival_3": "BW Batalha Final do N", - "battle_trainer": "BW Batalha de Treinador", - "battle_wild": "BW Batalha de Pokémon Selvagem", - "battle_wild_strong": "BW Batalha de Pokémon Selvagem Forte", - "end_summit": "PMD RTDX Cume da Torre do Céu", - "battle_rocket_grunt": "HGSS Batalha da Equipe Rocket", - "battle_aqua_magma_grunt": "ORAS Batalha da Equipe Aqua & Magma", - "battle_galactic_grunt": "BDSP Batalha da Equipe Galáctica", - "battle_plasma_grunt": "BW Batalha da Equipe Plasma", - "battle_flare_grunt": "XY Batalha da Equipe Flare", - "battle_aether_grunt": "SM Batalha da Fundação Aether", - "battle_skull_grunt": "SM Batalha da Equipe Skull", - "battle_macro_grunt": "SWSH Batalha de Treinador", - "battle_galactic_admin": "BDSP Batalha com Admin da Equipe Galáctica", - "battle_skull_admin": "SM Batalha com Admin da Euipe Skull", - "battle_oleana": "SWSH Batalha da Oleana", - "battle_rocket_boss": "USUM Batalha do Giovanni", - "battle_aqua_magma_boss": "ORAS Batalha do Maxie & Archie", - "battle_galactic_boss": "BDSP Batalha do Cyrus", - "battle_plasma_boss": "B2W2 Batalha do Ghetsis", - "battle_flare_boss": "XY Batalha do Lysandre", - "battle_aether_boss": "SM Batalha da Lusamine", - "battle_skull_boss": "SM Batalha do Guzma", - "battle_macro_boss": "SWSH Batalha do Rose", - - "abyss": "PMD EoS Dark Crater", - "badlands": "PMD EoS Barren Valley", - "beach": "PMD EoS Drenched Bluff", - "cave": "PMD EoS Sky Peak Cave", - "construction_site": "PMD EoS Boulder Quarry", - "desert": "PMD EoS Northern Desert", - "dojo": "PMD EoS Marowak Dojo", - "end": "PMD RTDX Sky Tower", - "factory": "PMD EoS Concealed Ruins", - "fairy_cave": "PMD EoS Star Cave", - "forest": "PMD EoS Dusk Forest", - "grass": "PMD EoS Apple Woods", - "graveyard": "PMD EoS Mystifying Forest", - "ice_cave": "PMD EoS Vast Ice Mountain", - "island": "PMD EoS Craggy Coast", - "jungle": "Lmz - Jungle", - "laboratory": "Firel - Laboratory", - "lake": "PMD EoS Crystal Cave", - "meadow": "PMD EoS Sky Peak Forest", - "metropolis": "Firel - Metropolis", - "mountain": "PMD EoS Mt. Horn", - "plains": "PMD EoS Sky Peak Prairie", - "power_plant": "PMD EoS Far Amp Plains", - "ruins": "PMD EoS Deep Sealed Ruin", - "sea": "Andr06 - Marine Mystique", - "seabed": "Firel - Seabed", - "slum": "Andr06 - Sneaky Snom", - "snowy_forest": "PMD EoS Sky Peak Snowfield", - "space": "Firel - Aether", - "swamp": "PMD EoS Surrounded Sea", - "tall_grass": "PMD EoS Foggy Forest", - "temple": "PMD EoS Aegis Cave", - "town": "PMD EoS Random Dungeon Theme 3", - "volcano": "PMD EoS Steam Cave", - "wasteland": "PMD EoS Hidden Highland", - "encounter_ace_trainer": "BW Encontro com Treinador (Treinador Ás)", - "encounter_backpacker": "BW Encontro com Treinador (Mochileiro)", - "encounter_clerk": "BW Encontro com Treinador (Funcionário)", - "encounter_cyclist": "BW Encontro com Treinador (Ciclista)", - "encounter_lass": "BW Encontro com Treinador (Senhorita)", - "encounter_parasol_lady": "BW Encontro com Treinador (Moça de Sombrinha)", - "encounter_pokefan": "BW Encontro com Treinador (Pokéfã)", - "encounter_psychic": "BW Encontro com Treinador (Médium)", - "encounter_rich": "BW Encontro com Treinador (Cavalheiro)", - "encounter_rival": "BW Cheren", - "encounter_roughneck": "BW Encontro com Treinador (Arruaceiro)", - "encounter_scientist": "BW Encontro com Treinador (Cientista)", - "encounter_twins": "BW Encontro com Treinador (Gêmeos)", - "encounter_youngster": "BW Encontro com Treinador (Jovem)", - "heal": "BW Centro Pokémon", - "menu": "PMD EoS Bem-vindo ao Mundo dos Pokémon!", - "title": "PMD EoS Menu Principal" -} diff --git a/src/locales/pt_BR/biome.json b/src/locales/pt_BR/biome.json deleted file mode 100644 index d10f22eb487..00000000000 --- a/src/locales/pt_BR/biome.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "unknownLocation": "em algum lugar do qual você não se lembra", - "TOWN": "Cidade", - "PLAINS": "Planície", - "GRASS": "Grama", - "TALL_GRASS": "Grama Alta", - "METROPOLIS": "Metrópole", - "FOREST": "Floresta", - "SEA": "Mar", - "SWAMP": "Pântano", - "BEACH": "Praia", - "LAKE": "Lago", - "SEABED": "Fundo do Mar", - "MOUNTAIN": "Montanha", - "BADLANDS": "Terras Áridas", - "CAVE": "Caverna", - "DESERT": "Deserto", - "ICE_CAVE": "Caverna de Gelo", - "MEADOW": "Prado", - "POWER_PLANT": "Usina Elétrica", - "VOLCANO": "Vulcão", - "GRAVEYARD": "Cemitério", - "DOJO": "Dojo", - "FACTORY": "Fábrica", - "RUINS": "Ruínas Abandonadas", - "WASTELAND": "Terras Arrasadas", - "ABYSS": "Abismo", - "SPACE": "Espaço", - "CONSTRUCTION_SITE": "Canteiro de Obras", - "JUNGLE": "Selva", - "FAIRY_CAVE": "Caverna das Fadas", - "TEMPLE": "Templo", - "SLUM": "Favela", - "SNOWY_FOREST": "Floresta Nevada", - "ISLAND": "Ilha", - "LABORATORY": "Laboratório", - "END": "???" -} \ No newline at end of file diff --git a/src/locales/pt_BR/challenges.json b/src/locales/pt_BR/challenges.json deleted file mode 100644 index 9dc613651a6..00000000000 --- a/src/locales/pt_BR/challenges.json +++ /dev/null @@ -1,37 +0,0 @@ -{ - "title": "Desafios", - "illegalEvolution": "{{pokemon}} não pode ser escolhido\nnesse desafio!", - "noneSelected": "Nada Selecionado", - "singleGeneration": { - "name": "Geração Única", - "desc": "Você só pode user Pokémon da {{gen}} geração.", - "desc_default": "Você só pode user Pokémon de uma única geração.", - "gen_1": "primeira", - "gen_2": "segunda", - "gen_3": "terceira", - "gen_4": "quarta", - "gen_5": "quinta", - "gen_6": "sexta", - "gen_7": "sétima", - "gen_8": "oitava", - "gen_9": "nona" - }, - "singleType": { - "name": "Monotipo", - "desc": "Você só pode user Pokémon do tipo {{type}}.", - "desc_default": "Você só pode user Pokémon de um único tipo." - }, - "freshStart": { - "name": "Novo Começo", - "desc": "Você só pode usar os iniciais originais, como se tivesse acabado de começar o PokéRogue.", - "value.0": "Desligado", - "value.1": "Ligado" - }, - "inverseBattle": { - "name": "Batalha Inversa", - "shortName": "Inversa", - "desc": "Fraquezas e resistências de tipos são invertidas e nenhum tipo é imune a outro tipo.\nDesativa as conquistas de outros desafios.", - "value.0": "Desligado", - "value.1": "Ligado" - } -} \ No newline at end of file diff --git a/src/locales/pt_BR/command-ui-handler.json b/src/locales/pt_BR/command-ui-handler.json deleted file mode 100644 index fcd8e7026b4..00000000000 --- a/src/locales/pt_BR/command-ui-handler.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "fight": "Lutar", - "ball": "Bolas", - "pokemon": "Pokémon", - "run": "Fugir", - "actionMessage": "O que {{pokemonName}}\ndeve fazer?" -} \ No newline at end of file diff --git a/src/locales/pt_BR/common.json b/src/locales/pt_BR/common.json deleted file mode 100644 index a5ec4381f26..00000000000 --- a/src/locales/pt_BR/common.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "start": "Iniciar", - "luckIndicator": "Sorte:", - "shinyOnHover": "Shiny", - "commonShiny": "Comum", - "rareShiny": "Raro", - "epicShiny": "Épico" -} \ No newline at end of file diff --git a/src/locales/pt_BR/config.ts b/src/locales/pt_BR/config.ts deleted file mode 100644 index 9e8377149c1..00000000000 --- a/src/locales/pt_BR/config.ts +++ /dev/null @@ -1,113 +0,0 @@ -import common from "./common.json"; -import settings from "./settings.json"; -import ability from "./ability.json"; -import abilityTriggers from "./ability-trigger.json"; -import arenaFlyout from "./arena-flyout.json"; -import arenaTag from "./arena-tag.json"; -import achv from "./achv.json"; -import battle from "./battle.json"; -import battleScene from "./battle-scene.json"; -import battleInfo from "./battle-info.json"; -import battleMessageUiHandler from "./battle-message-ui-handler.json"; -import battlerTags from "./battler-tags.json"; -import berry from "./berry.json"; -import bgmName from "./bgm-name.json"; -import biome from "./biome.json"; -import challenges from "./challenges.json"; -import commandUiHandler from "./command-ui-handler.json"; -import dialogue from "./dialogue.json"; -import battleSpecDialogue from "./dialogue-final-boss.json"; -import miscDialogue from "./dialogue-misc.json"; -import doubleBattleDialogue from "./dialogue-double-battle.json"; -import egg from "./egg.json"; -import fightUiHandler from "./fight-ui-handler.json"; -import filterBar from "./filter-bar.json"; -import gameMode from "./game-mode.json"; -import gameStatsUiHandler from "./game-stats-ui-handler.json"; -import growth from "./growth.json"; -import menu from "./menu.json"; -import menuUiHandler from "./menu-ui-handler.json"; -import modifier from "./modifier.json"; -import modifierType from "./modifier-type.json"; -import move from "./move.json"; -import nature from "./nature.json"; -import partyUiHandler from "./party-ui-handler.json"; -import pokeball from "./pokeball.json"; -import pokemon from "./pokemon.json"; -import pokemonForm from "./pokemon-form.json"; -import battlePokemonForm from "./pokemon-form-battle.json"; -import pokemonInfo from "./pokemon-info.json"; -import pokemonInfoContainer from "./pokemon-info-container.json"; -import pokemonSummary from "./pokemon-summary.json"; -import saveSlotSelectUiHandler from "./save-slot-select-ui-handler.json"; -import splashMessages from "./splash-messages.json"; -import starterSelectUiHandler from "./starter-select-ui-handler.json"; -import statusEffect from "./status-effect.json"; -import trainerTitles from "./trainer-titles.json"; -import trainerClasses from "./trainer-classes.json"; -import trainerNames from "./trainer-names.json"; -import tutorial from "./tutorial.json"; -import voucher from "./voucher.json"; -import weather from "./weather.json"; -import terrain from "./terrain.json"; -import modifierSelectUiHandler from "./modifier-select-ui-handler.json"; -import moveTriggers from "./move-trigger.json"; -import runHistory from "./run-history.json"; - -export const ptBrConfig = { - ability, - abilityTriggers, - arenaFlyout, - arenaTag, - battle, - battleScene, - battleInfo, - battleMessageUiHandler, - battlePokemonForm, - battlerTags, - berry, - bgmName, - biome, - challenges, - commandUiHandler, - common, - achv, - dialogue, - battleSpecDialogue, - miscDialogue, - doubleBattleDialogue, - egg, - fightUiHandler, - filterBar, - gameMode, - gameStatsUiHandler, - growth, - menu, - menuUiHandler, - modifier, - modifierType, - move, - nature, - pokeball, - pokemon, - pokemonForm, - pokemonInfo, - pokemonInfoContainer, - pokemonSummary, - saveSlotSelectUiHandler, - settings, - splashMessages, - starterSelectUiHandler, - statusEffect, - terrain, - titles: trainerTitles, - trainerClasses, - trainerNames, - tutorial, - voucher, - weather, - partyUiHandler, - modifierSelectUiHandler, - moveTriggers, - runHistory: runHistory, -}; diff --git a/src/locales/pt_BR/dialogue-double-battle.json b/src/locales/pt_BR/dialogue-double-battle.json deleted file mode 100644 index 4d1c7d90c9b..00000000000 --- a/src/locales/pt_BR/dialogue-double-battle.json +++ /dev/null @@ -1,83 +0,0 @@ -{ - "blue_red_double": { - "encounter": { - "1": "Blue: Ei Red, vamos mostrar do que somos feitos!\n$Red: ...\n$Blue: Este é o poder da Cidade de Pallet!" - }, - "victory": { - "1": "Blue: Essa foi uma ótima batalha!\n$Red: ..." - } - }, - "red_blue_double": { - "encounter": { - "1": "Red: ...!\n$Blue: Ele nunca fala muito.\n$Blue: Mas não se deixe enganar! Ele é um campeão, afinal!" - }, - "victory": { - "1": "Red: ...!\n$Blue: Da próxima vez, vamos vencer você!" - } - }, - "tate_liza_double": { - "encounter": { - "1": "Tate: Está surpreso?\n$Liza: Somos dois líderes de ginásio ao mesmo tempo!\n$Tate: Somos gêmeos!\n$Liza: Não precisamos falar para nos entender!\n$Tate: Duas vezes o poder...\n$Liza: Você consegue lidar com isso?" - }, - "victory": { - "1": "Tate: O quê? Nossa combinação foi perfeita!\n$Liza: Parece que precisamos treinar mais..." - } - }, - "liza_tate_double": { - "encounter": { - "1": "Liza: Hihihi... Está surpreso?\n$Tate: Sim, somos realmente dois líderes de ginásio ao mesmo tempo!\n$Liza: Este é meu irmão gêmeo Tate!\n$Tate: E esta é minha irmã gêmea Liza!\n$Liza: Não acha que somos uma combinação perfeita?" - }, - "victory": { - "1": "Liza: Nós somos...\n$Tate: ...não tão fortes quanto pensávamos?" - } - }, - "wallace_steven_double": { - "encounter": { - "1": "Steven: Wallace, vamos mostrar a eles o poder dos campeões!\n$Wallace: Vamos mostrar o poder de Hoenn!\n$Steven: Vamos lá!" - }, - "victory": { - "1": "Steven: Essa foi uma ótima batalha!\n$Wallace: Vamos vencer da próxima vez!" - } - }, - "steven_wallace_double": { - "encounter": { - "1": "Steven: Você tem algum Pokémon raro?\n$Wallace: Steven... Estamos aqui para uma batalha, não para mostrar nossos Pokémon.\n$Steven: Ah... Entendi... Vamos lá então!" - }, - "victory": { - "1": "Steven: Agora que terminamos a batalha, vamos mostrar nossos Pokémon!\n$Wallace: Steven..." - } - }, - "alder_iris_double": { - "encounter": { - "1": "Alder: Somos os treinadores mais fortes de Unova!\n$Iris: Lutas contra treinadores fortes são as melhores!" - }, - "victory": { - "1": "Alder: Uau! Você é super forte!\n$Iris: Vamos vencer da próxima vez!" - } - }, - "iris_alder_double": { - "encounter": { - "1": "Iris: Bem-vindo, Desafiante! Eu sou A Campeã de Unova!\n$Alder: Iris, você não está um pouco empolgada demais?", - "1_female": "Iris: Bem-vinda, Desafiante! Eu sou A Campeã de Unova!\n$Alder: Iris, você não está um pouco empolgada demais?" - }, - "victory": { - "1": "Iris: Uma derrota como essa não é fácil de engolir...\n$Alder: Mas só ficaremos mais fortes a cada derrota!" - } - }, - "piers_marnie_double": { - "encounter": { - "1": "Marnie: Irmão, vamos mostrar a eles o poder de Spikemuth!\n$Piers: Nós trazemos a escuridão!" - }, - "victory": { - "1": "Marnie: Você trouxe luz para nossa escuridão!\n$Piers: Está muito claro..." - } - }, - "marnie_piers_double": { - "encounter": { - "1": "Piers: Prontos para um show?\n$Marnie: Irmão... Eles estão aqui para lutar, não para cantar..." - }, - "victory": { - "1": "Piers: Agora esse foi um ótimo show!\n$Marnie: Irmão..." - } - } -} \ No newline at end of file diff --git a/src/locales/pt_BR/dialogue-final-boss.json b/src/locales/pt_BR/dialogue-final-boss.json deleted file mode 100644 index 7009f00db5b..00000000000 --- a/src/locales/pt_BR/dialogue-final-boss.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "encounter": "Parece que a hora finalmente chegou novamente.\nVocê sabe por que veio aqui, não sabe?\n$Você foi atraído para cá, porque já esteve aqui antes.\nInúmeras vezes.\n$Embora talvez isso possa ser contado.\nPara ser preciso, este é de fato o seu {{cycleCount}}º ciclo.\n$A cada ciclo, sua mente retorna ao seu estado anterior.\nMesmo assim, de alguma forma, vestígios de seus antigos \"eus\" permanecem.\n$Até agora, você ainda não conseguiu, mas sinto uma presença diferente em você desta vez.\n\n$Você é o único aqui, embora pareça haver... outro.\n$Você finalmente vai se mostrar um desafio formidável para mim?\nO desafio que anseio há milênios?\n$Vamos começar.", - "encounter_female": "Parece que a hora finalmente chegou novamente.\nVocê sabe por que veio aqui, não sabe?\n$Você foi atraída para cá, porque já esteve aqui antes.\nInúmeras vezes.\n$Embora talvez isso possa ser contado.\nPara ser preciso, este é de fato o seu {{cycleCount}}º ciclo.\n$A cada ciclo, sua mente retorna ao seu estado anterior.\nMesmo assim, de alguma forma, vestígios de seus antigos \"eus\" permanecem.\n$Até agora, você ainda não conseguiu, mas sinto uma presença diferente em você desta vez.\n\n$Você é a única aqui, embora pareça haver... outro.\n$Você finalmente vai se mostrar um desafio formidável para mim?\nO desafio que anseio há milênios?\n$Vamos começar.", - "firstStageWin": "Entendo. A presença que senti era realmente real.\nParece que não preciso mais me segurar.\n$Não me decepcione.", - "secondStageWin": "…Magnífico." -} \ No newline at end of file diff --git a/src/locales/pt_BR/dialogue-misc.json b/src/locales/pt_BR/dialogue-misc.json deleted file mode 100644 index 10e50aaa7e1..00000000000 --- a/src/locales/pt_BR/dialogue-misc.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "ending": "@c{shock}Você está de volta?@d{32} Isso significa que…@d{96} você venceu?!\n@c{smile_ehalf}Eu deveria saber que você conseguiria.\n$@c{smile_eclosed}Claro… Eu sempre tive essa sensação.\n@c{smile}Acabou agora, certo? Você quebrou o ciclo.\n$@c{smile_ehalf}Você também realizou seu sonho, não foi?\nVocê não perdeu nenhuma vez.\n$Eu serei a única a lembrar o que você fez.\n@c{angry_mopen}Eu tentarei não esquecer!\n$@c{smile_wave_wink}Brincadeirinha!@d{64} @c{smile}Eu nunca esqueceria.@d{32}\nSua lenda viverá em nossos corações.\n$@c{smile_wave}De qualquer forma,@d{64} está ficando tarde…@d{96} Eu acho?\nÉ difícil dizer neste lugar.\n$Vamos para casa. @c{smile_wave_wink}Talvez amanhã possamos ter outra batalha, pelos velhos tempos?", - "ending_female": "@c{smile}Oh? Você venceu?@d{96} @c{smile_eclosed}Acho que eu deveria saber.\nMas, você está de volta agora.\n$@c{smile}Acabou.@d{64} Você quebrou o ciclo.\n$@c{serious_smile_fists}Você também realizou seu sonho, não é?\nVocê não perdeu nenhuma vez.\n$@c{neutral}Eu sou o único que vai lembrar o que você fez.@d{96}\nAcho que está tudo bem, não é?\n$@c{serious_smile_fists}Sua lenda sempre viverá em nossos corações.\n$@c{smile_eclosed}Enfim, já tive o suficiente deste lugar, não é? Vamos para casa.\n$@c{serious_smile_fists}Talvez quando voltarmos, possamos ter outra batalha?\nSe você estiver disposto.", - "ending_endless": "Parabéns por alcançar o final atual!\nMais conteúdo chegará em breve.", - "ending_name": "Desenvolvedores" -} diff --git a/src/locales/pt_BR/dialogue.json b/src/locales/pt_BR/dialogue.json deleted file mode 100644 index 2f39442ee5a..00000000000 --- a/src/locales/pt_BR/dialogue.json +++ /dev/null @@ -1,2809 +0,0 @@ -{ - "youngster": { - "encounter": { - "1": "Eai, quer batalhar?", - "2": "Você também é um treinador novo?", - "2_female": "Você também é uma treinadora nova?", - "3": "Eai, nunca te vi antes. Vamos batalhar!", - "4": "Acabei de perder, então estou tentando encontrar mais Pokémon.\nEspera! Você parece fraco! Vamos batalhar!", - "4_female": "Acabei de perder, então estou tentando encontrar mais Pokémon.\nEspera! Você parece fraca! Vamos batalhar!", - "5": "A gente já se conheceu antes? Não lembro muito bem. Enfim, prazer te conhecer!", - "6": "Beleza! Vamos nessa!", - "7": "Beleza! Lá vou eu! Vou te mostrar meu poder!", - "8": "Hahaha... Vou te mostrar o quão incríveis são meus Pokémon!", - "9": "Sem perder tempo com cumprimentos. Vamos logo, quando estiver pronto!", - "9_female": "Sem perder tempo com cumprimentos. Vamos logo, quando estiver pronta!", - "10": "Não baixe a guarda, ou você pode acabar chorando quando uma criança te vencer.", - "11": "Eu criei meus Pokémon com muito cuidado. Você não tem permissão para machucá-los!", - "12": "Que bom que você chegou! Não vai ser fácil daqui pra frente.", - "13": "As batalhas continuam para sempre! Bem-vinda ao mundo sem fim!", - "13_female": "As batalhas continuam para sempre! Bem-vindo ao mundo sem fim!" - }, - "victory": { - "1": "Uau! Você é forte!", - "2": "Eu não tive chance, né?", - "3": "Vou te encontrar de novo quando for mais velho e te vencer!", - "4": "Ugh. Não tenho mais Pokémon.", - "5": "Não acredito… NÃO ACREDITO! Como pude perder de novo…", - "5_female": "Não acredito… NÃO ACREDITO! Como pude de novo…", - "6": "Não! Eu perdi!", - "7": "Uau! Você é incrível! Estou surpreso!", - "8": "Pode ser… Como… Eu e meus Pokémon somos os mais fortes, porém…", - "9": "Não vou perder da próxima vez! Vamos batalhar de novo algum dia!", - "10": "Aff! Não vê que sou apenas uma criança? Não foi justo você ir com tudo!", - "11": "Seus Pokémon são incríveis! Troca comigo!", - "12": "Me empolguei um pouco antes, mas sobre qual trabalho eu estava falando?", - "13": "Ahaha! É isso aí! Você já está em casa nesse mundo!" - } - }, - "lass": { - "encounter": { - "1": "Vamos batalhar, pode ser?", - "2": "Você parece um treinador novo. Vamos batalhar!", - "2_female": "Você parece uma treinadora nova. Vamos batalhar!", - "3": "Não te reconheço. Que tal uma batalha?", - "4": "Vamos ter uma batalha Pokémon divertida!", - "5": "Vou te mostrar como realmente usar Pokémon!", - "6": "Uma batalha séria começa com um começo sério! Tem certeza que está pronto?", - "6_female": "Uma batalha séria começa com um começo sério! Tem certeza que está pronta?", - "7": "Você só é jovem uma vez. E só tem uma chance em cada batalha. Logo, você será apenas uma memória.", - "8": "Vai com calma comigo, tá? Mas vou lutar sério!", - "9": "A escola é chata. Não tenho nada para fazer. Só estou batalhando para passar o tempo." - }, - "victory": { - "1": "Isso foi impressionante! Tenho muito a aprender.", - "2": "Não pensei que você me venceria tão fácil…", - "3": "Espero que possamos ter uma revanche um dia.", - "4": "Isso foi incrivelmente divertido! Você me esgotou totalmente…", - "5": "Você realmente me ensinou uma lição! Você é incrível!", - "6": "Sério, eu perdi. Isso é, tipo, seriamente deprimente, mas você foi seriamente legal.", - "7": "Não preciso de memórias como essa. Deletando memória…", - "8": "Ei! Eu te disse para pegar leve comigo! Mesmo assim, você é legal quando fica sério.", - "8_female": "Ei! Eu te disse para pegar leve comigo! Mesmo assim, você é legal quando fica séria.", - "9": "Estou realmente cansando de batalhar… Deve haver algo novo para fazer…" - } - }, - "breeder": { - "encounter": { - "1": "Pokémon obedientes, Pokémon egoístas… Pokémon têm características únicas.", - "2": "Embora minha criação e comportamento sejam ruins, criei meus Pokémon bem.", - "3": "Hmm, você disciplina seus Pokémon? Mimar demais não é bom." - }, - "victory": { - "1": "É importante nutrir e treinar as características de cada Pokémon.", - "2": "Ao contrário do meu lado diabólico, esses são bons Pokémon.", - "3": "Muito elogio pode estragar tanto Pokémon quanto pessoas." - }, - "defeat": { - "1": "Você não deve ficar com raiva dos seus Pokémon, mesmo se perder uma batalha.", - "2": "Certo? Pokémon bons, né? Eu sou adequado para criar coisas.", - "3": "Não importa o quanto você ame seus Pokémon, ainda precisa discipliná-los quando se comportam mal." - } - }, - "breeder_female": { - "encounter": { - "1": "Pokémon nunca te traem. Eles retribuem todo o amor que você dá a eles.", - "2": "Quer uma dica para treinar bons Pokémon?", - "3": "Eu criei esses Pokémon muito especiais usando um método especial." - }, - "victory": { - "1": "Ugh… Não era para ser assim. Será que administrei a mistura errada?", - "2": "Como isso aconteceu com meus Pokémon… O que você está dando de comer aos seus Pokémon?", - "3": "Se eu perder, isso significa que eu estava só matando o tempo. Não machuca meu ego nem um pouco." - }, - "defeat": { - "1": "Isso prova que meus Pokémon aceitaram meu amor.", - "2": "O verdadeiro truque para treinar bons Pokémon é capturar bons Pokémon.", - "3": "Pokémon serão fortes ou fracos dependendo de como você os cria." - } - }, - "fisherman": { - "encounter": { - "1": "Anem! Você me fez perder uma fisgada!\nO que vai fazer sobre isso?", - "2": "Sai daqui! Você está assustando os Pokémon!", - "3": "Vamos ver se você consegue fisgar uma vitória!" - }, - "victory": { - "1": "Esqueça isso.", - "2": "Da próxima vez, eu vou pescar a vitória!", - "3": "Acho que subestimei a força das correntes dessa vez." - } - }, - "fisherman_female": { - "encounter": { - "1": "Uau! Peguei um grande!", - "2": "Linha lançada, pronta para pescar o sucesso!", - "3": "Pronta para fazer ondas!" - }, - "victory": { - "1": "Vou voltar com um anzol mais forte.", - "2": "Vou pescar a vitória na próxima vez.", - "3": "Estou só afiando meus anzóis para a revanche!" - } - }, - "swimmer": { - "encounter": { - "1": "Hora de mergulhar!", - "2": "Vamos surfar nas ondas da vitória!", - "3": "Pronto para fazer um splash!" - }, - "victory": { - "1": "Molhado na derrota!", - "2": "Uma onda de derrota!", - "3": "De volta à praia, eu acho." - } - }, - "backpacker": { - "encounter": { - "1": "Prepare-se, vamos começar!", - "2": "Vamos ver se você consegue acompanhar!", - "3": "Prepare-se, desafiante!", - "4": "Passei 20 anos tentando me encontrar… Mas onde estou?" - }, - "victory": { - "1": "Dessa vez tropecei!", - "2": "Ah, acho que estou perdido.", - "3": "Caminho sem saída!", - "4": "Espere um segundo! Ei! Você não sabe quem eu sou?" - } - }, - "ace_trainer": { - "encounter": { - "1": "Você parece bastante confiante.", - "2": "Seus Pokémon… Mostre-os para mim…", - "3": "Como sou um Treinador Ás, as pessoas acham que sou forte.", - "4": "Você sabe o que é preciso para ser um Treinador Ás?" - }, - "victory": { - "1": "Sim… Você tem bons Pokémon…", - "2": "O quê?! Mas sou um gênio das batalhas!", - "3": "Claro, você é o personagem principal!", - "3_female": "Claro, você é a personagem principal!", - "4": "OK! OK! Você poderia ser um Treinador Ás!", - "4_female": "OK! OK! Você poderia ser uma Treinador Ás!" - }, - "defeat": { - "1": "Estou dedicando corpo e alma às batalhas de Pokémon!", - "2": "Tudo dentro das minhas expectativas… Nada para se surpreender…", - "3": "Eu achava que cresceria para ser uma pessoa frágil que parecia que quebraria se você apertasse muito.", - "4": "Claro que sou forte e não perco. É importante ganhar com graça." - } - }, - "parasol_lady": { - "encounter": { - "1": "Hora de embelezar o campo de batalha com elegância e postura!" - }, - "victory": { - "1": "Minha elegância permanece inabalável!" - } - }, - "twins": { - "encounter": { - "1": "Prepare-se, porque quando nos unimos, é o dobro do problema!", - "2": "Dois corações, uma estratégia – vamos ver se você consegue acompanhar nosso poder de gêmeos!", - "3": "Espero que esteja pronto para o dobro do problema, porque estamos prestes a causar!", - "3_female": "Espero que esteja pronta para o dobro do problema, porque estamos prestes a causar!" - }, - "victory": { - "1": "Podemos ter perdido essa rodada, mas nosso vínculo permanece inquebrável!", - "2": "Nosso espírito de gêmeos não será apagado por muito tempo.", - "3": "Voltaremos mais fortes como uma dupla dinâmica!" - }, - "defeat": { - "1": "O poder dos gêmeos reina supremo!", - "2": "Dois corações, um triunfo!", - "3": "Dobro de sorrisos, dobro da dança da vitória!" - } - }, - "cyclist": { - "encounter": { - "1": "Prepare-se para comer poeira!", - "2": "Prepare-se, desafiante! Estou prestes a te deixar para trás!", - "3": "Pé no pedal, vamos ver se você consegue acompanhar!" - }, - "victory": { - "1": "As rodas podem estar paradas, mas a determinação continua a pedalar.", - "2": "Fui mais rápido!", - "3": "O caminho para a vitória tem muitas curvas e voltas para explorar." - } - }, - "black_belt": { - "encounter": { - "1": "Elogio sua coragem ao me desafiar! Pois eu sou o que tem o chute mais forte!", - "2": "Oh, entendo. Você gostaria de ser cortado em pedaços? Ou prefere o papel de saco de pancadas?", - "2_female": "Oh, entendo. Você gostaria de ser cortada em pedaços? Ou prefere o papel de saco de pancadas?" - }, - "victory": { - "1": "Oh. Os Pokémon fizeram a luta. Meu chute forte não ajudou em nada.", - "2": "Hmmm… Se eu ia perder de qualquer maneira, esperava ficar totalmente destruído no processo." - } - }, - "battle_girl": { - "encounter": { - "1": "Você não precisa tentar me impressionar. Você pode perder contra mim." - }, - "victory": { - "1": "É difícil dizer adeus, mas estamos ficando sem tempo…" - } - }, - "hiker": { - "encounter": { - "1": "Minha barriga de meia-idade me deu tanta gravidade quanto as montanhas que eu escalo!", - "2": "Herdei esse corpo ossudo dos meus pais… Sou como uma cadeia de montanhas viva…" - }, - "victory": { - "1": "Pelo menos não posso perder quando se trata de IMC!", - "2": "Não é suficiente… Nunca é suficiente. Meu colesterol ruim não está alto o suficiente…" - } - }, - "ranger": { - "encounter": { - "1": "Quando estou cercado pela natureza, a maioria das outras coisas deixa de importar.", - "2": "Quando estou vivendo sem natureza na minha vida, às vezes sinto uma crise de ansiedade se aproximando." - }, - "victory": { - "1": "Não importa para a vastidão da natureza se eu ganhar ou perder…", - "2": "Algo assim é bastante trivial comparado aos sentimentos sufocantes da vida na cidade." - }, - "defeat": { - "1": "Ganhei a batalha. Mas a vitória não é nada comparada à vastidão da natureza…", - "2": "Tenho certeza de que como você se sente não é tão ruim se comparar aos meus ataques de ansiedade…" - } - }, - "scientist": { - "encounter": { - "1": "Minha pesquisa levará este mundo à paz e alegria." - }, - "victory": { - "1": "Sou um gênio… Não devo perder para alguém como você…" - } - }, - "school_kid": { - "encounter": { - "1": "Heehee. Estou confiante nos meus cálculos e análises.", - "2": "Estou ganhando o máximo de experiência que posso porque quero ser um Líder de Ginásio um dia." - }, - "victory": { - "1": "Aff… Cálculo e análise talvez não sejam páreo para o acaso…", - "2": "Até experiências difíceis e desafiadoras têm seu propósito, eu acho." - } - }, - "artist": { - "encounter": { - "1": "Eu costumava ser popular, mas agora estou acabado." - }, - "victory": { - "1": "À medida que os tempos mudam, os valores também mudam. Percebi isso tarde demais." - } - }, - "guitarist": { - "encounter": { - "1": "Prepare-se para sentir o ritmo da derrota enquanto eu toco minha vitória!" - }, - "victory": { - "1": "Silenciado por agora, mas minha melodia de resiliência continuará a tocar." - } - }, - "worker": { - "encounter": { - "1": "Me incomoda que as pessoas sempre me entendam mal. Sou muito mais puro do que todos pensam." - }, - "victory": { - "1": "Eu realmente não quero que minha pele queime, então quero ficar na sombra enquanto trabalho." - } - }, - "worker_female": { - "encounter": { - "1": "Me incomoda que as pessoas sempre me entendam mal.\n$Sou muito mais pura do que todos pensam." - }, - "victory": { - "1": "Eu realmente não quero que minha pele queime, então quero ficar na sombra enquanto trabalho." - }, - "defeat": { - "1": "Meu corpo e mente nem sempre estão necessariamente em sincronia." - } - }, - "worker_double": { - "encounter": { - "1": "Vou te mostrar que podemos te quebrar. Estamos treinando no campo!" - }, - "victory": { - "1": "Que estranho… Como isso pode ser… Não deveria ter sido superado." - } - }, - "hex_maniac": { - "encounter": { - "1": "Normalmente, só escuto música clássica, mas se eu perder, acho que vou tentar um pouco de new age!", - "2": "Eu fico mais forte a cada lágrima que derramo." - }, - "victory": { - "1": "É o início da era de Aquário?", - "2": "Agora posso ficar ainda mais forte. Cresço com cada rancor." - }, - "defeat": { - "1": "New age se refere simplesmente aos compositores clássicos do século XX, certo?", - "2": "Não fique preso na tristeza ou frustração. Você pode usar seus rancores para se motivar.", - "2_female": "Não fique presa na tristeza ou frustração. Você pode usar seus rancores para se motivar." - } - }, - "psychic": { - "encounter": { - "1": "Oi! Concentre-se!" - }, - "victory": { - "1": "Perdi minha concentração!" - } - }, - "officer": { - "encounter": { - "1": "Prepare-se, porque a justiça está prestes a ser servida!", - "2": "Pronto para defender a lei e servir a justiça no campo de batalha!" - }, - "victory": { - "1": "O peso da justiça parece mais pesado do que nunca…", - "2": "As sombras da derrota pairam no distrito." - } - }, - "beauty": { - "encounter": { - "1": "Minha última batalha… É assim que eu gostaria que víssemos esta partida…" - }, - "victory": { - "1": "Foi divertido… Vamos ter outra última batalha algum dia…" - } - }, - "baker": { - "encounter": { - "1": "Espero que esteja pronto para saborear a derrota!", - "1_female": "Espero que esteja pronta para saborear a derrota!" - }, - "victory": { - "1": "Vou assar uma revanche." - } - }, - "biker": { - "encounter": { - "1": "Hora de acelerar e te deixar na poeira!" - }, - "victory": { - "1": "Vou me ajustar para a próxima corrida." - } - }, - "firebreather": { - "encounter": { - "1": "Minhas chamas irão te consumir!", - "2": "Minha alma está pegando fogo. Irei te mostrar como queima!", - "3": "Cola aqui e dá uma olhada!" - }, - "victory": { - "1": "Fui reduzido a cinzas…", - "2": "Uau! Isso foi quente!", - "3": "Ai! Queimei minha língua!" - } - }, - "sailor": { - "encounter": { - "1": "Mano, você vai andar na prancha se perder!", - "2": "Vem com tudo! Sou um marinheiro com orgulho!", - "3": "Ahoy marujo! Tá enjoado, é?!", - "3_female": "Ahoy maruja! Tá enjoada, é?!" - }, - "victory": { - "1": "Argh! Perdi pra uma criança!", - "2": "Sua vontade de ganhar me afogou!", - "3": "Estou achando que quem tá enjoado sou eu..." - } - }, - "archer": { - "encounter": { - "1": "Antes de você ir mais longe, vamos ver como você se sai contra nós, Equipe Rocket!", - "2": "Eu tenho recebido relatórios de que suas habilidades não são insignificantes. Vamos ver se são verdadeiros.", - "3": "Eu sou Archer, um Admin da Equipe Rocket. E não tenho piedade dos inimigos da nossa organização." - }, - "victory": { - "1": "Que vexame!", - "2": "Com minhas habilidades atuais, eu não estava à altura da tarefa, afinal.", - "3": "M-me perdoe, Giovanni... Por ser derrotado por um mero treinador..." - } - }, - "ariana": { - "encounter": { - "1": "Pera aí! Não podemos deixar alguém solto por aí. Isso é prejudicial para o orgulho da Equipe Rocket, entende?", - "2": "Eu não sei ou me importo se o que estou fazendo é certo ou errado... Eu apenas coloco minha fé em Giovanni e faço o que me é dito.", - "3": "Sua viagem termina aqui. Vou te derrubar!" - }, - "victory": { - "1": "Uau, você é forte. Que desperdício. Se você se juntasse à Equipe Rocket, poderia se tornar um Executivo.", - "1_female": "Uau, você é forte. Que desperdício. Se você se juntasse à Equipe Rocket, poderia se tornar uma Executiva.", - "2": "Eu... Eu estou arrasada...", - "3": "Aaaieeeee! Isso não pode estar acontecendo! Eu lutei muito, mas ainda perdi…" - } - }, - "proton": { - "encounter": { - "1": "O que você quer? Se você interromper nosso trabalho, não espere misericórdia!", - "2": "O que temos aqui? Costumam me chamar de o cara mais assustador e cruel da Equipe Rocket… Eu recomendo fortemente que você não interfira nos nossos negócios!", - "3": "Eu sou Proton, um Admin da Equipe Rocket. Estou aqui para acabar com a sua intromissão!" - }, - "victory": { - "1": "A fortaleza caiu!", - "2": "Você pode ter vencido desta vez… Mas tudo o que fez foi aumentar a ira da Equipe Rocket…", - "3": "Fui derrotado… Mas não esquecerei disso!" - } - }, - "petrel": { - "encounter": { - "1": "Muhahaha, estávamos esperando por você. Eu? Você não sabe quem eu sou? Sou eu, Giovanni. O majestoso Giovanni em pessoa! Wahahaha! ...Huh? Eu não pareço nada com Giovanni? Eu nem mesmo pareço com Giovanni? Como assim? Trabalhei tanto para imitá-lo!", - "2": "Eu sou Petrel, um Admin da Equipe Rocket. Não permitirei que você interfira em nossos planos!", - "3": "O Executivo da Rocket, Petrel, vai lidar com este intruso!" - }, - "victory": { - "1": "OK, OK. Vou te contar onde ele está.", - "2": "Eu... Eu não consegui fazer nada... Giovanni, por favor, me perdoe...", - "3": "Não, eu não posso deixar isso me afetar. Tenho que informar os outros…" - } - }, - "tabitha": { - "encounter": { - "1": "Hehehe! Então você veio até aqui! Mas você chegou tarde demais!", - "2": "Hehehe... Já chegou aqui, não é? Nós subestimamos você! Mas é isso! Eu sou um passo acima dos Capangas que você viu até agora. Não estou ganhando tempo. Vou te pulverizar!", - "3": "Vou te dar um gostinho da dor! Resigne-se a isso!" - }, - "victory": { - "1": "Hehehe! Você pode ter me derrotado, mas não tem chance contra o Chefe! Se você se perder agora, não terá que enfrentar uma surra sonora!", - "2": "Hehehe... Então, eu também perdi...", - "3": "Ahya! Como isso pode ser? Para um Admin como eu perder para um treinador qualquer...", - "3_female": "Ahya! Como isso pode ser? Para um Admin como eu perder para uma treinadora qualquer..." - } - }, - "courtney": { - "encounter": { - "1": "A coisa... A coisa que você segura... É o que... É o que nós da Equipe Magma procuramos...", - "2": "... Bem então... Deletando...", - "3": "...Ha. ...Analisando... ...Hah♪" - }, - "victory": { - "1": "... ...Mudar...o mundo.", - "2": "Como antecipado. Não antecipado. Você. Bloqueio de alvo... concluído. Iniciando... experimento. Você. Para sempre. Aha... ♪", - "3": "... De novo? Isso não foi antecipado. ...Eu sabia. Você... é interessante! ...Haha. ♪" - } - }, - "shelly": { - "encounter": { - "1": "Ahahahaha! Você vai se meter nos assuntos da Equipe Aqua? Você é absolutamente destemido, simplesmente ignorante ou ambos! Você é tão fofo que chega a ser nojento! Vou te derrubar", - "1_female": "Ahahahaha! Você vai se meter nos assuntos da Equipe Aqua? Você é absolutamente destemida, simplesmente ignorante ou ambos! Você é tão fofa que chega a ser nojenta! Vou te derrubar", - "2": "O que é isso? Quem é essa criança mimada?", - "3": "Relaxe. Seja paciente. Vou te esmagar em breve." - }, - "victory": { - "1": "Ahahahaha! Fomos surpreendidos inesperadamente! Estamos sem opções. Teremos que recuar. Mas esta não é a última vez que você verá a Equipe Aqua! Temos outros planos! Não se esqueça disso!", - "2": "Ahhh?! Fui muito fácil com você?!", - "3": "Uh. Você está me dizendo que melhorou seu jogo ainda mais durante a luta? Você é um pirralho com um futuro brilhante… Meu Pokémon e eu não temos mais forças para lutar… Vá em frente… Vá e seja destruído por Archie.", - "3_female": "Uh. Você está me dizendo que melhorou seu jogo ainda mais durante a luta? Você é uma pirralha com um futuro brilhante… Meu Pokémon e eu não temos mais forças para lutar… Vá em frente… Vá e seja destruída por Archie." - } - }, - "matt": { - "encounter": { - "1": "Hoohahaha! O que, você tem um parafuso solto ou algo assim? Olhe para você, pequena pessoa Makuhita!", - "2": "Oho! Você! Você é aquela criança engraçada!", - "3": "O que você está fazendo aqui? Você nos seguiu?" - }, - "victory": { - "1": "Muito bem, até que o Chefe tenha tempo para você, serei seu oponente!", - "2": "Posso sentir! Posso sentir, tudo bem! A força saindo de você! Mais! Eu ainda quero mais! Mas parece que estamos sem tempo...", - "3": "Isso foi divertido! Eu sabia que você me mostraria um bom tempo! Estou ansioso para enfrentá-lo novamente algum dia!", - "3_female": "Isso foi divertido! Eu sabia que você me mostraria um bom tempo! Estou ansioso para enfrentá-la novamente algum dia!" - } - }, - "mars": { - "encounter": { - "1": "Sou Mars, uma das principais Comandantes da Equipe Galáctica.", - "2": "A visão da Equipe Galáctica para o futuro é inabalável. A oposição será esmagada sem piedade!", - "3": "Sentindo-se nervoso? Você deveria estar!", - "3_female": "Sentindo-se nervosa? Você deveria estar!" - }, - "victory": { - "1": "Isso não pode estar acontecendo! Como eu perdi?!", - "2": "Você tem alguma habilidade, eu admito isso.", - "3": "Derrotada... Este foi um erro caro." - } - }, - "jupiter": { - "encounter": { - "1": "Júpiter, Comandante da Equipe Galáctica, ao seu serviço.", - "2": "A resistência é inútil. A Equipe Galáctica prevalecerá!", - "3": "Você está tremendo... já está com medo?" - }, - "victory": { - "1": "De jeito nenhum... Eu perdi?!", - "2": "Impressionante, você tem coragem!", - "3": "Perder assim... Que embaraço." - } - }, - "saturn": { - "encounter": { - "1": "Eu sou Saturno, Comandante da Equipe Galáctica.", - "2": "Nossa missão é absoluta. Qualquer obstáculo será obliterado!", - "3": "É medo o que vejo em seus olhos?" - }, - "victory": { - "1": "Impossível... Derrotado por você?!", - "2": "Você provou ser um adversário digno.", - "3": "Derrotado... Isso é inaceitável." - } - }, - "zinzolin": { - "encounter": { - "1": "Você poderia se tornar uma ameaça para a Equipe Plasma, então vamos eliminá-lo aqui e agora!", - "1_female": "Você poderia se tornar uma ameaça para a Equipe Plasma, então vamos eliminá-la aqui e agora!", - "2": "Oh, pelo amor de Deus... Eu não esperava ter que lutar neste frio congelante!", - "3": "Você é um treinador impressionante para ter chegado tão longe. Mas termina aqui.", - "3_female": "Você é uma treinadora impressionante para ter chegado tão longe. Mas termina aqui." - }, - "victory": { - "1": "Ghetsis... Eu falhei com você...", - "2": "Está amargamente frio. Estou tremendo. Estou sofrendo. Ainda assim, estou vitorioso.", - "3": "Hmph. Você é um treinador mais esperto do que eu esperava, mas não esperto o suficiente.", - "3_female": "Hmph. Você é uma treinadora mais esperta do que eu esperava, mas não esperta o suficiente." - } - }, - "rood": { - "encounter": { - "1": "Você é uma ameaça para a Equipe Plasma. Não podemos deixá-lo ir embora daqui e agora!", - "1_female": "Você é uma ameaça para a Equipe Plasma. Não podemos deixá-la ir embora daqui e agora!", - "2": "Oh, este vento gelado... Eu nunca pensei que teria que lutar aqui!", - "3": "Você é um treinador notável para ter chegado tão longe. Mas é aqui que termina.", - "3_female": "Você é uma treinadora notável para ter chegado tão longe. Mas é aqui que termina." - }, - "victory": { - "1": "Ghetsis... Eu falhei em minha missão...", - "2": "O frio é penetrante. Estou tremendo. Estou sofrendo. Ainda assim, triunfei.", - "3": "Hm. Você é um treinador talentoso, mas infelizmente não talentoso o suficiente.", - "3_female": "Hm. Você é uma treinadora talentosa, mas infelizmente não talentosa o suficiente." - } - }, - "xerosic": { - "encounter": { - "1": "Ah ha ha! Será um prazer. Vamos lá, pequeno treinador! Vamos ver o que você tem!", - "1_female": "Ah ha ha! Será um prazer. Vamos lá, pequena treinadora! Vamos ver o que você tem!", - "2": "Hmm... Você é mais poderoso do que parece. Eu me pergunto quanta energia há dentro de você.", - "2_female": "Hmm... Você é mais poderosa do que parece. Eu me pergunto quanta energia há dentro de você.", - "3": "Eu estava esperando por você! Preciso fazer uma pequena pesquisa sobre você! Vamos começar!" - }, - "victory": { - "1": "Ah, você é bastante forte. Oh sim—muito forte, de fato.", - "2": "Ding-ding-ding! Você conseguiu! Ao vencedor, os despojos!", - "2_female": "Ding-ding-ding! Você conseguiu! À vencedora, os despojos!", - "3": "Maravilhoso! Incrível! Você tem uma tremenda habilidade e coragem!" - } - }, - "bryony": { - "encounter": { - "1": "Eu sou Bryony, e será um prazer lutar com você. Mostre-me o que você tem.", - "2": "Impressionante... Você é mais poderoso do que parece. Vamos ver a verdadeira extensão de sua energia.", - "2_female": "Impressionante... Você é mais poderosa do que parece. Vamos ver a verdadeira extensão de sua energia.", - "3": "Eu antecipei sua chegada. É hora de um pequeno teste. Vamos começar?" - }, - "victory": { - "1": "Você é bastante forte. Oh sim—muito forte, de fato.", - "2": "Ding-ding-ding! Você se saiu bem. A vitória é sua.", - "3": "Maravilhoso! Notável! Sua habilidade e coragem são admiráveis." - } - }, - "rocket_grunt": { - "encounter": { - "1": "Se prepara pra encrenca!", - "2": "Estamos realizando um grande trabalho aqui! Cai fora, moleque!", - "2_female": "Estamos realizando um grande trabalho aqui! Cai fora, garota!", - "3": "Entregue seus Pokémon ou enfrente a ira da Equipe Rocket!", - "4": "Você está prestes a experimentar o verdadeiro terror da Equipe Rocket!", - "5": "Ei, moleque! Eu sou um tipo de cara da Equipe Rocket!", - "5_female": "Ei, garota! Eu sou um tipo de cara da Equipe Rocket!" - }, - "victory": { - "1": "Equipe Rocket decolando de novo!", - "2": "Oh não! Eu deixei a Chave de Elevação cair!", - "3": "Eu estraguei tudo!", - "4": "Meus associados não vão tolerar isso!", - "5": "Você diz o que? Equipe Rocket tchau-tchau a vai-vai? Quebrado é diz você?" - } - }, - "magma_grunt": { - "encounter": { - "1": "Se você se meter com a Equipe Magma, não teremos piedade!", - "2": "É melhor você não interferir em nossos planos! Estamos tornando o mundo um lugar melhor!", - "3": "Você está no caminho! A Equipe Magma não tem tempo para crianças como você!", - "4": "Espero que você tenha trazido marshmallows porque as coisas estão prestes a esquentar!", - "5": "Vamos usar o poder de um vulcão! Vai ser... explosivo! Entendeu? Heh heh!" - }, - "victory": { - "1": "Ahn? Eu perdi?!", - "2": "Não posso acreditar que perdi! Até pulei o almoço por isso.", - "3": "De jeito nenhum! Você é apenas uma criança!", - "4": "Urrrgh... Eu deveria ter me escondido em nosso esconderijo imediatamente...", - "5": "Você me venceu... Você acha que o chefe vai cortar meu salário por isso?" - } - }, - "aqua_grunt": { - "encounter": { - "1": "Não pegamos leve com quem se mete com a Equipe Aqua, nem mesmo crianças!", - "2": "Grrr... Você tem coragem de se intrometer com a Equipe Aqua!", - "3": "Você está prestes a se molhar! E não apenas por causa dos meus Pokémon aquáticos!", - "4": "Nós, da Equipe Aqua, existimos para o bem de todos!", - "5": "Prepare-se para ser levado pelas ondas do meu... uh, Pokémon! Sim, meu Pokémon!" - }, - "victory": { - "1": "Tá de brincadeira!", - "2": "Arrgh, eu não contei que seria atrapalhado por uma criança intrometida!", - "3": "Eu perdi?! Acho que vou ter que nadar de volta para o esconderijo agora...", - "4": "Oh, cara, que desastre... O chefe vai ficar furioso...", - "5": "Você me venceu... Você acha que o chefe vai me fazer andar na prancha por isso?" - } - }, - "galactic_grunt": { - "encounter": { - "1": "Não mexa com a Equipe Galáctica!", - "2": "Presencie o poder da nossa tecnologia e o futuro que vislumbramos!", - "3": "Em nome da Equipe Galáctica, eliminarei qualquer um que ficar em nosso caminho!", - "4": "Prepare-se para perder!", - "5": "Espero que você esteja pronto para uma surra cósmica!", - "5_female": "Espero que você esteja pronta para uma surra cósmica!" - }, - "victory": { - "1": "Fui amassado...", - "2": "Este contratempo não significa nada no grande esquema.", - "3": "Nossos planos são maiores que esta derrota.", - "4": "Como?!", - "5": "Nota para mim mesmo: praticar batalhas Pokémon, o mais rápido possível." - } - }, - "plasma_grunt": { - "encounter": { - "1": "Não toleramos pessoas que pensam diferente de nós!", - "2": "Se eu ganhar de você, liberte seus Pokémon!", - "3": "Se você atrapalhar a Equipe Plasma, eu cuidarei de você!", - "4": "A Equipe Plasma vai libertar os Pokémon de humanos egoístas como você!", - "5": "Nossos penteados são de outro mundo... mas nossas habilidades de batalha? Você descobrirá em breve." - }, - "victory": { - "1": "Plasmaaaaaaaaa!", - "2": "Como eu pude perder...", - "3": "...Que Pokémon fraco, vou ter que roubar alguns melhores!", - "4": "Grandes planos são sempre interrompidos.", - "5": "Isso é ruim... Ruim ruim ruim ruim ruim ruim ruim! Ruim para a Equipe Plasma! Ou Plasruim, para abreviar!" - } - }, - "flare_grunt": { - "encounter": { - "1": "Seus Pokémon não são páreo para a elegância da Equipe Flare.", - "2": "Espero que você tenha trazido seus óculos de sol, porque as coisas vão ficar brilhantes!", - "3": "A Equipe Flare vai purificar o mundo da imperfeição!", - "4": "Prepare-se para enfrentar o brilho da Equipe Flare!", - "5": "A moda é o mais importante para nós!" - }, - "victory": { - "1": "O futuro não parece brilhante para mim.", - "2": "Talvez haja mais na batalha do que eu pensei. De volta à prancheta.", - "3": "Gahh?! Eu perdi?!", - "4": "Mesmo na derrota, a elegância da Equipe Flare brilha.", - "5": "Você pode ter me vencido, mas quando eu perco, eu saio com estilo!" - } - }, - "aether_grunt": { - "encounter": { - "1": "Eu vou lutar com tudo o que tenho para te eliminar!", - "2": "Eu não me importo se você é uma criança ou o que. Eu vou te mandar voando se você nos ameaçar!", - "3": "Me mandaram afastar Treinadores, não importa quem sejam!", - "4": "Eu vou te mostrar o poder do Paraíso Aether!", - "5": "Agora que você descobriu a escuridão no coração do Paraíso Aether, precisamos que você desapareça convenientemente!" - }, - "victory": { - "1": "Aff! Você parece ter muita habilidade.", - "2": "O que isso significa? O que isso significa!", - "3": "Ei! Você é tão forte que não há como eu te afastar!", - "4": "Hmm... Parece que eu posso ter perdido.", - "5": "Aqui está uma resposta para você: Aiyee!" - } - }, - "faba": { - "encounter": { - "1": "Eu, o Chefe de Ramo Faba, vou te mostrar a dureza do mundo real!", - "2": "O homem chamado de última linha de defesa do Paraíso Aether vai batalhar com uma mera criança?", - "3": "Eu, Faba, sou o Chefe de Ramo do Paraíso Aether. O único no mundo, eu sou insubstituível." - }, - "victory": { - "1": "Aiyee!", - "2": "C-c-como assim?! Como uma criança...", - "3": "Isso é por que... Isso é por que eu não consigo gostar de crianças." - } - }, - "skull_grunt": { - "encounter": { - "1": "Nós não somos maus, somos apenas durões!", - "2": "Quer um pouco de nós? É assim que dizemos olá! Prazer em conhecê-los, otários!", - "3": "Somos só um bando de caras e minas com um grande interesse nos Pokémon dos outros!", - "4": "Por que você está tentando agir durão quando já somos durões como ossos aqui fora, mano?", - "5": "Equipe Skull na área! Não podemos pagar o aluguel! Nos divertimos muito, mas nossa juventude foi desperdiçada!" - }, - "victory": { - "1": "Ahn? Já acabou?", - "2": "Hora de dar o fora, mano! Vamos ter que dizer tchau, mano!", - "3": "Nem precisamos dos seus Pokémon fracotes mesmo!", - "4": "Que?! Esse muleque é muito forte! Não tem como negar!", - "5": "Então, o que? Eu sou pior que um Pokémon?! Eu já tenho problemas de autoestima, cara." - } - }, - "plumeria": { - "encounter": { - "1": " ...Hmph. Você não parece nada especial para mim.", - "2": "Esses Capangas gastam muito tempo tentando lidar com crianças como você...", - "3": "Mexe com qualquer um da Equipe Skull, e eu vou te mostrar o quão séria eu posso ficar." - }, - "victory": { - "1": "Aff! Você é bem forte. Tenho que admitir.", - "2": "Aff! Você é bem forte. Agora eu entendi por que meus Capangas gastam tanto tempo batalhando com crianças.", - "3": "Aff! Acho que eu só tenho que aceitar essa derrota." - } - }, - "macro_grunt": { - "encounter": { - "1": "Parece que aqui é o fim da linha para você!", - "2": "Você é um treinador, não é? Temo que isso não lhe dê o direito de interferir em nosso trabalho.", - "3": "Sou da Macro Cosmos Seguros! Já tem um seguro de vida?" - }, - "victory": { - "1": "Eu não tenho muita escolha a não ser recuar respeitosamente.", - "2": "Ter que desistir do meu dinheiro... Perder significa que estou de volta no vermelho...", - "3": "Ninguém pode vencer a Macro Cosmos quando se trata de nossa dedicação ao trabalho!" - } - }, - "oleana": { - "encounter": { - "1": "Eu não vou deixar ninguém interferir no plano do Sr. Rose!", - "2": "Então, você passou por todo o pessoal especial que eu ordenei para te parar. Eu não esperaria nada menos.", - "3": "Pelo presidente! Eu não vou perder!" - }, - "victory": { - "1": "*suspiro* Eu não consegui vencer... Oleana... você realmente é uma mulher sem esperança.", - "2": "Aff! Isso é inaceitável... O que eu estava pensando... Qualquer treinador que chega tão longe não seria um fracote...", - "3": "*suspiro* Eu sou uma Oleana cansada..." - } - }, - "rocket_boss_giovanni_1": { - "encounter": { - "1": "Tenho que admitir, estou impressionado que tenha chegado até aqui!" - }, - "victory": { - "1": "QUÊ! Isso não é possível!" - }, - "defeat": { - "1": "Guarde minhas palavras.\nNão ser capaz de medir sua própria força mostra que você ainda é uma criança." - } - }, - "rocket_boss_giovanni_2": { - "encounter": { - "1": "Meus antigos associados precisam de mim... Você vai ficar no meu caminho?" - }, - "victory": { - "1": "Como isso é possível...?\nO precioso sonho da Equipe Rocket se tornou pouco mais que uma ilusão..." - }, - "defeat": { - "1": "A Equipe Rocket renascerá, e eu dominarei o mundo!" - } - }, - "magma_boss_maxie_1": { - "encounter": { - "1": "Eu vou te enterrar com minhas próprias mãos.\nEspero que você aprecie essa honra!" - }, - "victory": { - "1": "Ugh! Você é... bastante capaz...\nEu fiquei para trás, mas apenas por um triz..." - }, - "defeat": { - "1": "A Equipe Magma vai prevalecer!" - } - }, - "magma_boss_maxie_2": { - "encounter": { - "1": "Você é o último obstáculo entre mim e meus objetivos.\nPrepare-se para meu ataque final! Fuhahaha!" - }, - "victory": { - "1": "Isso... Isso não é... Ngh..." - }, - "defeat": { - "1": "E agora... Eu transformarei este planeta em uma terra ideal para a humanidade." - } - }, - "aqua_boss_archie_1": { - "encounter": { - "1": "Eu sou o líder da Equipe Aqua, então temo que esse seja o fim da linha para você." - }, - "victory": { - "1": "Vamos nos encontrar de novo em algum lugar. Eu vou ter certeza de lembrar desse rosto." - }, - "defeat": { - "1": "Brilhante! Nada vai parar minha equipe agora!" - } - }, - "aqua_boss_archie_2": { - "encounter": { - "1": "Estive esperando tanto tempo por este dia.\nEste é o verdadeiro poder da minha equipe!" - }, - "victory": { - "1": "Como eu suspeitava..." - }, - "defeat": { - "1": "Eu vou voltar tudo neste mundo ao seu estado puro e original!!" - } - }, - "galactic_boss_cyrus_1": { - "encounter": { - "1": "Você foi compelido a vir aqui por tal sentimentalismo vazio\nEu farei você se arrepender de ter ouvido seu coração!", - "1_female": "Você foi compelida a vir aqui por tal sentimentalismo vazio\nEu farei você se arrepender de ter ouvido seu coração!" - }, - "victory": { - "1": "Interessante. E bastante curioso." - }, - "defeat": { - "1": "Eu criarei meu novo mundo..." - } - }, - "galactic_boss_cyrus_2": { - "encounter": { - "1": "Nos encontramos novamente. Parece que nossos destinos estão entrelaçados.\nMas aqui e agora, eu finalmente quebrarei esse vínculo!" - }, - "victory": { - "1": "Como? Como? COMO?!" - }, - "defeat": { - "1": "Até logo." - } - }, - "plasma_boss_ghetsis_1": { - "encounter": { - "1": "Ninguém pode me deter! Não importa quem seja ou o que faça!" - }, - "victory": { - "1": "Como isso é possível? Eu sou o criador da Equipe Plasma! Eu sou perfeito!" - }, - "defeat": { - "1": "Eu sou o governante perfeito de um novo mundo perfeito! Mwa ha ha!" - } - }, - "plasma_boss_ghetsis_2": { - "encounter": { - "1": "Vamos! Eu quero ver sua cara depois que você perder toda a esperança!" - }, - "victory": { - "1": "Meus cálculos... Não! Meus planos cuidadosos! O mundo deveria ser meu!" - }, - "defeat": { - "1": "Kyurem! Use Absofusion!" - } - }, - "flare_boss_lysandre_1": { - "encounter": { - "1": "Você está aqui para me deter? Mostre-me em batalha." - }, - "victory": { - "1": "Você está aqui para me deter. Mas eu peço que você espere." - }, - "defeat": { - "1": "Pokémon... não devem mais existir." - } - }, - "flare_boss_lysandre_2": { - "encounter": { - "1": "O futuro que você quer, ou o futuro que eu quero... Vamos ver qual é o mais merecedor, não é mesmo?" - }, - "victory": { - "1": "Uau!" - }, - "defeat": { - "1": "Tolos sem visão continuarão a poluir este belo mundo." - } - }, - "aether_boss_lusamine_1": { - "encounter": { - "1": "Você vai assustar minha fera querida! Parece que eu vou precisar te silenciar primeiro." - }, - "victory": { - "1": "Como... como você pode ser tão terrível!" - }, - "defeat": { - "1": "Aff..." - } - }, - "aether_boss_lusamine_2": { - "encounter": { - "1": "Por que você continua a me incomodar?! Estou cansada de você. Cansada até a alma!\n$Chega de papo furado... Com o poder de Nihilego, vou mostrar o quão errado você estava em vir aqui!" - }, - "victory": { - "1": "Aaauuuggghhhhhhhhh!!!" - }, - "defeat": { - "1": "Tudo o que eu quero é minha fera preciosa! Eu não me importo com nenhum de vocês!" - } - }, - "skull_boss_guzma_1": { - "encounter": { - "1": "O odiado chefe que te bate e te bate e nunca para...\n$É. O grande e mau Guzma está aqui!" - }, - "victory": { - "1": "Tss. Eu vou te bater um dia desses!" - }, - "defeat": { - "1": "E você veio até aqui só pra isso, né?" - } - }, - "skull_boss_guzma_2": { - "encounter": { - "1": "Não importa contra quem eu esteja, eu vou derrotá-los!\n$Isso é o que o grande e mau Guzma é!" - }, - "victory": { - "1": "Guzma!!! O que há de errado com você?!" - }, - "defeat": { - "1": "Vocês são tudo uns idiotas!" - } - }, - "macro_boss_rose_1": { - "encounter": { - "1": "Devo fornecer energia ilimitada para garantir a prosperidade eterna para todos...\n$É meu propósito, meu dever, meu destino!" - }, - "victory": { - "1": "Você ainda não entendeu, treinador...\n$Nós... Não, eu vou mudar o rumo da história!" - }, - "defeat": { - "1": "Você ainda não entende nada!" - } - }, - "macro_boss_rose_2": { - "encounter": { - "1": "Estou comprometido em resolver o problema de energia na região de Galar e, claro, em todo o mundo.\n$Minha experiência e conquistas que fizeram da Macro Cosmos um sucesso são a prova de que meus métodos funcionam.\n$Não pretendo mudar de ideia, mesmo que eu perca." - }, - "victory": { - "1": "Eu esqueci o quão incríveis são as batalhas Pokémon! Faz tanto tempo desde que eu batalhei...\n$Isso foi realmente satisfatório, eu aceito a derrota para esta batalha." - }, - "defeat": { - "1": "Eu suponho que deve parecer que estou fazendo algo terrível. Eu não espero que você entenda.\n$Mas eu devo fornecer à região de Galar energia ilimitada para garantir prosperidade eterna." - } - }, - "brock": { - "encounter": { - "1": "Minha especialidade em Pokémon do tipo Pedra vai te derrubar! Vamos lá!", - "2": "Minha vontade firme como pedra vai te sobrecarregar!", - "3": "Permita-me mostrar a verdadeira força dos meus Pokémon!" - }, - "victory": { - "1": "A força dos seus Pokémon superou minhas defesas de pedra!", - "2": "O mundo é enorme! Estou feliz por ter tido a chance de batalhar com você.", - "3": "Talvez eu deva voltar a perseguir meu sonho de ser Criador de Pokémon…" - }, - "defeat": { - "1": "A melhor defesa é um bom ataque!\nEssa é a minha maneira de fazer as coisas!", - "2": "Venha estudar rochas comigo da próxima vez para aprender melhor a combatê-las!", - "3": "Hah, todas as minhas viagens pelas regiões estão valendo a pena!" - } - }, - "misty": { - "encounter": { - "1": "Minha política é um ataque total com Pokémon do tipo Água!", - "2": "Oi, vou mostrar a força dos meus Pokémon aquáticos!", - "3": "Meu sonho era viajar e batalhar com treinadores poderosos…\nVocê será um desafio suficiente?" - }, - "victory": { - "1": "Você realmente é forte… Vou admitir que você é habilidoso…", - "1_female": "Você realmente é forte… Vou admitir que você é habilidosa…", - "2": "Hmm… Você sabe que só teve sorte, certo?!", - "3": "Uau, você é demais! Não acredito que me venceu!" - }, - "defeat": { - "1": "A poderosa Misty foi demais para você?", - "2": "Espero que você tenha visto as técnicas de natação elegantes dos meus Pokémon!", - "3": "Seus Pokémon não foram páreo para meus orgulhos e alegrias!" - } - }, - "lt_surge": { - "encounter": { - "1": "Meus Pokémon Elétricos me salvaram durante a guerra! Vou te mostrar como!", - "2": "Em sentido! Vou te chocar até você se render!", - "3": "Vou te eletrizar como faço com todos os meus inimigos na batalha!" - }, - "victory": { - "1": "Whoa! Seu time é de verdade, garoto!", - "1_female": "Whoa! Seu time é de verdade, garota!", - "2": "Uau, você é forte! Até meus truques elétricos perderam para você.", - "3": "Isso foi uma derrota absolutamente chocante!" - }, - "defeat": { - "1": "Oh sim! Quando se trata de Pokémon do tipo Elétrico, sou o número um do mundo!", - "2": "Hahaha! Foi uma batalha eletrizante, garoto!", - "2_female": "Hahaha! Foi uma batalha eletrizante, garota!", - "3": "Uma batalha de Pokémon é guerra, e eu te mostrei combate em primeira mão!" - } - }, - "erika": { - "encounter": { - "1": "Ah, o tempo está adorável aqui…\nOh, uma batalha? Muito bem então.", - "2": "Minhas habilidades de batalha Pokémon rivalizam com minhas habilidades de arranjo de flores.", - "3": "Oh, espero que o aroma agradável dos meus Pokémon não me faça dormir de novo…", - "4": "Ver flores em um jardim é tão calmante." - }, - "victory": { - "1": "Oh! Eu concedo a derrota.", - "2": "Aquela partida foi muito agradável.", - "3": "Ah, parece que perdi…", - "4": "Oh, meu Deus." - }, - "defeat": { - "1": "Tinha medo de adormecer…", - "2": "Oh, meu Deus, parece que meus Pokémon de Grama te dominaram.", - "3": "Essa batalha foi uma experiência tão calmante.", - "4": "Oh… É só isso?" - } - }, - "janine": { - "encounter": { - "1": "Estou dominando a arte dos ataques venenosos.\nVou lutar com você hoje!", - "2": "Meu pai confia que posso me defender.\nVou provar que ele está certo!", - "3": "Minhas técnicas de ninja só perdem para as do meu pai!\nVocê consegue acompanhar?" - }, - "victory": { - "1": "Ainda preciso de treinamento… Entendi.", - "2": "Sua técnica de batalha superou a minha.", - "3": "Vou me aplicar de verdade e melhorar minhas habilidades." - }, - "defeat": { - "1": "Hehe… o veneno drenou todas as suas forças para lutar.", - "2": "Ha! Você não teve chance contra minhas habilidades superiores de ninja!", - "3": "A fé do meu pai em mim não foi mal colocada." - } - }, - "sabrina": { - "encounter": { - "1": "Através da minha habilidade psíquica, tive uma visão da sua chegada!", - "2": "Não gosto de lutar, mas se você quiser, vou mostrar meus poderes!", - "3": "Posso sentir grande ambição em você. Vou ver se não é infundada." - }, - "victory": { - "1": "Seu poder… Ele supera o que eu previa…", - "2": "Não consegui prever seu poder com precisão.", - "3": "Mesmo com meus imensos poderes psíquicos, não consigo sentir outro tão forte quanto você." - }, - "defeat": { - "1": "Essa vitória… É exatamente como previ nas minhas visões!", - "2": "Talvez fosse outra pessoa que eu sentisse um grande desejo…", - "3": "Aprimore suas habilidades antes de entrar em batalha precipitadamente.\nVocê nunca sabe o que o futuro pode reservar se fizer isso…" - } - }, - "blaine": { - "encounter": { - "1": "Hah! Espero que tenha trazido uma Cura de Queimadura!", - "2": "Meus Pokémon de Fogo vão incinerar todos os desafiantes!", - "3": "Prepare-se para brincar com fogo!" - }, - "victory": { - "1": "Queimei até não restar nada! Nem cinzas sobraram!", - "2": "Não acendi as chamas alto o suficiente?", - "3": "Estou completamente exausto… Mas isso faz minha motivação para melhorar queimar ainda mais!" - }, - "defeat": { - "1": "Meu inferno ardente não pode ser apagado!", - "2": "Meus Pokémon foram fortalecidos com o calor desta vitória!", - "3": "Hah! Minha paixão queima mais do que a sua!" - } - }, - "giovanni": { - "encounter": { - "1": "Eu, o líder da Equipe Rocket, vou te fazer sentir um mundo de dor!", - "2": "Meu treinamento aqui será vital antes de enfrentar meus antigos associados novamente.", - "3": "Não acho que você está preparado para o nível de fracasso que está prestes a experimentar!", - "3_female": "Não acho que você está preparada para o nível de fracasso que está prestes a experimentar!" - }, - "victory": { - "1": "O QUE! Eu, perder?! Não tenho nada a dizer a você!", - "2": "Hmm… Você nunca entenderia o que quero alcançar.", - "3": "Esta derrota está apenas adiando o inevitável.\nVou ressurgir a Equipe Rocket das cinzas a tempo." - }, - "defeat": { - "1": "Não ser capaz de medir sua própria força mostra que você ainda é apenas uma criança.", - "2": "Não tente interferir comigo novamente.", - "3": "Espero que entenda o quão tolo foi me desafiar." - } - }, - "roxanne": { - "encounter": { - "1": "Você poderia gentilmente demonstrar como batalha?", - "2": "Você pode aprender muitas coisas batalhando com muitos treinadores.", - "3": "Oh, você me pegou estrategizando.\nGostaria de batalhar?" - }, - "victory": { - "1": "Oh, parece que perdi.\nEu entendo.", - "2": "Parece que ainda tenho muito mais a aprender quando se trata de batalhas.", - "3": "Vou levar o que aprendi aqui hoje a sério." - }, - "defeat": { - "1": "Aprendi muitas coisas com nossa batalha.\nEspero que você também tenha aprendido.", - "2": "Espero batalhar com você novamente.\nEspero que use o que aprendeu aqui.", - "3": "Venci devido a tudo o que aprendi." - } - }, - "brawly": { - "encounter": { - "1": "Oh cara, um desafiante!\nVamos ver o que você pode fazer!", - "1_female": "Oh cara, uma desafiante!\nVamos ver o que você pode fazer!", - "2": "Você parece uma grande onda.\nVamos batalhar!", - "3": "Hora de criar uma tempestade!\nVamos!" - }, - "victory": { - "1": "Uau, você me derrotou!", - "2": "Você surfou minha onda e me derrubou!", - "3": "Sinto-me perdido na Caverna Granito!" - }, - "defeat": { - "1": "Haha, eu surfei a grande onda!\nDesafie-me novamente algum dia.", - "2": "Surfe comigo novamente algum dia!", - "3": "Assim como as marés vão e vêm, espero que você volte para me desafiar novamente." - } - }, - "wattson": { - "encounter": { - "1": "Hora de levar um choque!\nWahahahaha!", - "2": "Vou fazer faíscas voarem!\nWahahahaha!", - "3": "Espero que tenha trazido Cura de Paralisia!\nWahahahaha!" - }, - "victory": { - "1": "Parece que estou sem carga!\nWahahahaha!", - "2": "Você me aterrissou completamente!\nWahahahaha!", - "3": "Obrigado pela emoção!\nWahahahaha!" - }, - "defeat": { - "1": "Você está totalmente carregado agora!\nWahahahaha!", - "1_female": "Você está totalmente carregada agora!\nWahahahaha!", - "2": "Espero ver você faíscando em batalhas futuras!\nWahahahaha!", - "3": "Wahahahaha! Que batalha eletrizante!" - } - }, - "flannery": { - "encounter": { - "1": "Meus Pokémon de fogo estão prontos para queimar a concorrência!\nVamos nessa!", - "2": "Prepare-se para sentir o calor da minha determinação!\nNão vou segurar nada!", - "3": "Minhas habilidades vão incinerar você!\nPrepare-se para a batalha mais quente da sua vida!" - }, - "victory": { - "1": "Essa derrota só faz minha determinação queimar mais!", - "2": "Essa perda não apagará minhas chamas!\nEstarei de volta mais forte!", - "3": "Vou usar essa experiência para reacender meu espírito competitivo!" - }, - "defeat": { - "1": "Minhas chamas nunca se apagarão!\nSou muito apaixonada por isso!", - "2": "Você foi incrível!\nVamos fazer isso de novo algum dia!", - "3": "Que batalha ardente!\nMal posso esperar pela próxima!" - } - }, - "norman": { - "encounter": { - "1": "Você está pronto para enfrentar a força pura do meu time?\nVou te mostrar o poder do equilíbrio!", - "2": "Minha experiência em batalha vai fazer você suar!\nPrepare-se!", - "3": "Treinei meu time rigorosamente.\nVamos ver se você consegue igualar!" - }, - "victory": { - "1": "Parece que subestimei você.\nFoi uma batalha dura.", - "2": "Você é forte, mas ainda há muito para aprender.", - "3": "Essa derrota não abalará minha determinação.\nEstarei de volta mais forte!" - }, - "defeat": { - "1": "Você lutou bravamente!\nEspero batalhar com você novamente.", - "2": "Sua força é incrível!\nNão posso esperar pela nossa próxima batalha.", - "3": "Foi uma honra batalhar com você!\nAté a próxima!" - } - }, - "winona": { - "encounter": { - "1": "Tenho sobrevoado os céus em busca de presas...\nE você é meu alvo!", - "2": "Não importa como será nossa batalha, meus Pokémon Voadores e eu triunfaremos com graça. Vamos batalhar!", - "3": "Espero que você não tenha medo de altura.\nVamos subir!" - }, - "victory": { - "1": "Você é o primeiro Treinador que vejo com mais graça do que eu.\nJogou excelentemente.", - "1_female": "Você é a primeira Treinadora que vejo com mais graça do que eu.\nJogou excelentemente.", - "2": "Oh, meus Pokémon Voadores despencaram!\nMuito bem.", - "3": "Embora eu tenha caído, meus Pokémon continuarão a voar!" - }, - "defeat": { - "1": "Meus Pokémon Voadores e eu sempre dançaremos com elegância!", - "2": "Espero que tenha gostado do nosso show.\nNossa dança graciosa terminou.", - "3": "Você não quer ver nossa coreografia elegante novamente?" - } - }, - "tate": { - "encounter": { - "1": "Hehehe... Ficou surpreso de me ver sem minha irmã?", - "1_female": "Hehehe... Ficou surpresa de me ver sem minha irmã?", - "2": "Posso ver o que você está pensando...\nVocê quer batalhar!", - "3": "Como você pode derrotar alguém...\nQue sabe todos os seus movimentos?" - }, - "victory": { - "1": "Não pode ser ajudado...\nSinto falta da Liza...", - "2": "Seu vínculo com seus Pokémon era mais forte que o meu.", - "3": "Se eu estivesse com Liza, teríamos vencido.\nConseguimos completar os pensamentos um do outro!" - }, - "defeat": { - "1": "Meus Pokémon e eu somos superiores!", - "2": "Se você não consegue nem me derrotar, nunca será capaz de derrotar Liza também.", - "3": "Tudo graças ao meu treinamento rigoroso com Liza.\nPosso me tornar um com os Pokémon." - } - }, - "liza": { - "encounter": { - "1": "Fufufu... Ficou surpreso de me ver sem meu irmão?", - "1_female": "Fufufu... Ficou surpresa de me ver sem meu irmão?", - "2": "Posso determinar o que você deseja...\nVocê quer batalhar, não quer?", - "3": "Como você pode derrotar alguém...\nQue é um com seus Pokémon?" - }, - "victory": { - "1": "Não pode ser ajudado...\nSinto falta do Tate...", - "2": "Seu vínculo com seus Pokémon...\nÉ mais forte que o meu.", - "3": "Se eu estivesse com Tate, teríamos vencido.\nPodemos terminar as frases um do outro!" - }, - "defeat": { - "1": "Meus Pokémon e eu somos vitoriosos.", - "2": "Se você não consegue nem me derrotar, nunca será capaz de derrotar Tate também.", - "3": "Tudo graças ao meu treinamento rigoroso com Tate.\nPosso me sincronizar com meus Pokémon." - } - }, - "juan": { - "encounter": { - "1": "Agora não é hora de agir timidamente.\nVamos batalhar!", - "2": "Ahahaha, você será testemunha da minha arte com Pokémon de Água!", - "3": "Um tufão se aproxima!\nVocê será capaz de me testar?", - "4": "Por favor, você será testemunha da nossa arte.\nUma grande ilusão de água esculpida por meus Pokémon e por mim!" - }, - "victory": { - "1": "Você pode ser um gênio que pode enfrentar Wallace!", - "2": "Eu me concentrei na elegância enquanto você treinava.\nÉ natural que você me derrotasse.", - "3": "Ahahaha!\nMuito bem, você venceu desta vez.", - "4": "De você, sinto o brilho brilhante da habilidade que superará tudo." - }, - "defeat": { - "1": "Meus Pokémon e eu esculpimos uma ilusão de Água e saímos vitoriosos.", - "2": "Ahahaha, eu venci, e você perdeu.", - "3": "Posso emprestar meu traje? Pode te ajudar a batalhar!\nAhahaha, estou brincando!", - "4": "Eu sou o vencedor! O que quer dizer, você perdeu." - } - }, - "crasher_wake": { - "encounter": { - "1": "Crash! Crash! Cuidado!\nDemolidor Wake… está… aqui!", - "2": "Crash! Crash! Demolidor Wake!", - "3": "Sou a onda de poder que vai te lavar!" - }, - "victory": { - "1": "Isso coloca um sorriso no meu rosto!\nGuhahaha! Foi uma explosão!", - "2": "Hunwah! Acabou e terminou!\nComo vou dizer isso...\nQuero mais! Queria batalhar muito mais!", - "3": "O QUÊ?!" - }, - "defeat": { - "1": "Siiiiim! Isso mesmo!", - "2": "Eu venci, mas quero mais! Queria batalhar muito mais!", - "3": "Até logo!" - } - }, - "falkner": { - "encounter": { - "1": "Vou mostrar o verdadeiro poder dos magníficos Pokémon pássaros!", - "2": "Ventos, fiquem comigo!", - "3": "Pai! Espero que esteja vendo minha batalha de cima!" - }, - "victory": { - "1": "Eu entendo... Vou sair graciosamente.", - "2": "Uma derrota é uma derrota. Você é realmente forte.", - "3": "...Droga! Sim, eu perdi." - }, - "defeat": { - "1": "Pai! Venci com seus amados Pokémon pássaros...", - "2": "Pokémon pássaros são os melhores afinal!", - "3": "Sinto que estou alcançando meu pai!" - } - }, - "nessa": { - "encounter": { - "1": "Não importa que tipo de plano sua mente refinada possa estar tramando, meu parceiro e eu vamos afundá-lo.", - "1_female": "Não importa que tipo de plano sua mente refinada possa estar tramando, meu parceiro e eu vamos afundá-la.", - "2": "Não estou aqui para conversar. Estou aqui para vencer!", - "3": "Este é um pequeno presente dos meus Pokémon... Espero que você possa recebê-lo!", - "3_female": "Este é um pequeno presente dos meus Pokémon... Espero que você possa recebê-la!" - }, - "victory": { - "1": "Você e seus Pokémon são demais...", - "2": "Como...? Como isso pode ser?!", - "3": "Fui totalmente arrastada!" - }, - "defeat": { - "1": "A onda furiosa ataca novamente!", - "2": "Hora de surfar na onda da vitória!", - "3": "Hehe!" - } - }, - "melony": { - "encounter": { - "1": "Não vou me segurar!", - "2": "Tudo bem, acho que devemos começar.", - "3": "Vou congelar você completamente!" - }, - "victory": { - "1": "Você... Você é muito bom, hein?", - "1_female": "Você... Você é muito boa, hein?", - "2": "Se você encontrar Gordie por aí, certifique-se de dar uma boa surra nele, ok?", - "3": "Acho que você levou a quebra de gelo um pouco literalmente demais..." - }, - "defeat": { - "1": "Agora você vê como as batalhas podem ser severas?", - "2": "Hee! Parece que ganhei de novo!", - "3": "Você está segurando?" - } - }, - "marlon": { - "encounter": { - "1": "Você parece forte! Vamos começar!", - "2": "Sou forte como a amplitude do oceano. Você vai ser varrido, com certeza.", - "2_female": "Sou forte como a amplitude do oceano. Você vai ser varrida, com certeza.", - "3": "Oh ho, então estou enfrentando você! Isso é fora do comum." - }, - "victory": { - "1": "Você foi incrível! Está criando alguns Pokémon incríveis. Você dominou a coisa de Treinador!", - "1_female": "Você foi incrível! Está criando alguns Pokémon incríveis. Você dominou a coisa de Treinadora!", - "2": "Você não apenas parece forte, você é forte de verdade! Eh, eu também fui varrido!", - "3": "Você é forte como uma onda impressionante!" - }, - "defeat": { - "1": "Você é forte, mas não é o suficiente para mudar o mar, ok!", - "2": "Hee! Parece que ganhei de novo!", - "3": "Doce, doce vitória!" - } - }, - "shauntal": { - "encounter": { - "1": "Com licença. Você é um desafiante, certo?\nSou a usuária de Pokémon do tipo Fantasma da Elite dos Quatro, Shauntal, e serei sua oponente.", - "1_female": "Com licença. Você é uma desafiante, certo?\nSou a usuária de Pokémon do tipo Fantasma da Elite dos Quatro, Shauntal, e serei sua oponente.", - "2": "Adoro escrever sobre Treinadores que vêm aqui e os Pokémon que treinam.\nPosso usar você e seus Pokémon como tema?", - "3": "Cada pessoa que trabalha com Pokémon tem uma história para contar.\nQue história está prestes a ser contada?" - }, - "victory": { - "1": "Uau. Estou sem palavras!", - "2": "D-desculpe! Primeiro, preciso me desculpar com meus Pokémon...\n\nLamento muito que você tenha tido uma experiência ruim por minha causa!", - "3": "Mesmo com isso, ainda sou uma da Elite dos Quatro!" - }, - "defeat": { - "1": "Hehe.", - "2": "Isso me deu um excelente material para meu próximo romance!", - "3": "E assim, outra história termina..." - } - }, - "marshal": { - "encounter": { - "1": "Meu mentor, Alder, vê seu potencial como Treinador e está interessado em você.\nMeu objetivo é testá-lo—levar você aos limites da sua força. Kiai!", - "1_female": "Meu mentor, Alder, vê seu potencial como Treinadora e está interessado em você.\nMeu objetivo é testá-la—levar você aos limites da sua força. Kiai!", - "2": "Vitória, vitória decisiva, é meu objetivo! Desafiante, aqui vou eu!", - "3": "Em mim mesmo, procuro desenvolver a força de um lutador e eliminar qualquer fraqueza em mim!\nPrevalecendo com a força de minhas convicções!" - }, - "victory": { - "1": "Ufa! Bem feito!", - "2": "À medida que suas batalhas continuarem, mire em alturas ainda maiores!", - "3": "A força demonstrada por você e seus Pokémon me impressionou profundamente..." - }, - "defeat": { - "1": "Hmm.", - "2": "Isso foi uma boa batalha.", - "3": "Haaah! Haaah! Haiyaaaah!" - } - }, - "cheren": { - "encounter": { - "1": "Você me lembra um velho amigo. Isso me deixa animado para essa batalha Pokémon!", - "2": "As batalhas Pokémon não têm sentido se você não pensa por que você batalha.\nOu melhor, isso torna as batalhas junto com Pokémon sem sentido.", - "3": "Meu nome é Cheren! Sou um Líder de Ginásio e professor! Prazer em conhecê-lo.", - "3_female": "Meu nome é Cheren! Sou um Líder de Ginásio e professor! Prazer em conhecê-la." - }, - "victory": { - "1": "Obrigado! Vi o que estava faltando em mim.", - "2": "Obrigado! Sinto que vi um pouco do caminho em direção aos meus ideais.", - "3": "Hmm... Isso é problemático." - }, - "defeat": { - "1": "Como Líder de Ginásio, meu objetivo é ser um obstáculo para você superar.", - "2": "Tudo bem!", - "3": "Cheguei onde estou porque os Pokémon estavam ao meu lado.\nTalvez precisemos pensar por que os Pokémon nos ajudam, não em termos de Pokémon e Treinadores, mas como uma relação entre seres vivos." - } - }, - "chili": { - "encounter": { - "1": "Ihuuu! Hora de brincar com FOGO!! Sou o mais forte dos nossos irmãos!", - "1_female": "Yeeeeeooow! Hora de brincar com FOGO!! Eu sou o mais forte de nós irmãos!", - "2": "Ta-da! O incendiário do tipo Fogo Chili—sou eu—será seu oponente!", - "2_female": "Tcharan! O escaldante Chili tipo Fogo (sou eu) será seu oponente!", - "3": "Vou mostrar o que eu e meus tipos de Fogo podemos fazer!", - "3_female": "Vou te mostrar o que eu e meus ardentes tipo Fogo podemos fazer!" - }, - "victory": { - "1": "Você me pegou. Estou... queimado...", - "1_female": "Você me pegou. Eu estou… queimado… esgotado…", - "2": "Uau! Você está pegando fogo!", - "2_female": "Uau! Você tá pegando fogo!", - "3": "Ai! Você me pegou!" - }, - "defeat": { - "1": "Estou pegando fogo! Jogue comigo, e você se queimará!", - "1_female": "Estou pegando fogo! Brinque comigo e você vai se queimar!", - "2": "Quando você brinca com fogo, você se queima!", - "3": "Quero dizer, vamos lá, seu oponente era eu! Você não tinha chance!", - "3_female": "Quero dizer, fala sério, seu oponente era eu! Você não teve chance!" - } - }, - "cilan": { - "encounter": { - "1": "Nada pessoal... Sem ressentimentos... Eu e meus Pokémon do tipo Grama vamos...\nUm... Vamos batalhar, aconteça o que acontecer.", - "1_female": "Nada pessoal... Sem ressentimentos... Eu e meus Pokémon do tipo Grama vamos...\n$Hum... Nós iremos batalhar, aconteça o que acontecer.", - "2": "Então, hum, se você está bem comigo, vou, hum, colocar tudo o que tenho em ser, er, você sabe, seu oponente.", - "2_female": "Então, hum, se você estiver bem comigo, eu vou, hum, dar tudo o que tenho para ser, hum, você sabe, seu oponente.", - "3": "OK… Então, hum, eu sou o Cilan, gosto de Pokémon do tipo Grama.", - "3_female": "OK... Então, eu sou Cilan, eu gosto de Pokémon do tipo Grama." - }, - "victory": { - "1": "Er... Acabou agora?", - "1_female": "Er… Já acabou?", - "2": "…Que surpresa. Você é muito forte, não é?\nAcho que meus irmãos também não teriam sido capazes de te derrotar...", - "2_female": "…Que surpresa. Você é muito forte, não é? \n$Eu acho que meus irmãos também não conseguiriam derrotar você…", - "3": "…Huh. Parece que meu timing estava, hum, errado?" - }, - "defeat": { - "1": "Huh? Ganhei?", - "1_female": "Hein? Eu ganhei?", - "2": "Acho...\nSuponho que ganhei, porque competi com meus irmãos Chili e Cress, e todos conseguimos ficar mais fortes.", - "2_female": "Eu acho... \n$Eu acho que ganhei, porque eu estava competindo com meus irmãos Chili e Cress, e todos nós conseguimos ficar mais fortes.", - "3": "Foi... uma experiência bastante emocionante...", - "3_female": "Foi… foi uma experiência bastante emocionante…" - } - }, - "roark": { - "encounter": { - "1": "Preciso ver seu potencial como Treinador. E, vou precisar ver a dureza dos Pokémon que batalham com você!", - "1_female": "Preciso ver seu potencial como Treinadora. E, vou precisar ver a dureza dos Pokémon que batalham com você!", - "2": "Vamos lá! Estes são meus Pokémon de pedra, meu orgulho e alegria!", - "3": "Pokémon do tipo Pedra são simplesmente os melhores!", - "4": "Preciso ver seu potencial como Treinador. E, vou precisar ver a dureza dos Pokémon que batalham com você!", - "4_female": "Preciso ver seu potencial como Treinadora. E, vou precisar ver a dureza dos Pokémon que batalham com você!" - }, - "victory": { - "1": "O-o que? Isso não pode ser! Meus Pokémon fortificados!", - "2": "...Perdemos o controle. Da próxima vez, gostaria de desafiá-lo a uma corrida de escavação de fósseis no subsolo.", - "2_female": "...Perdemos o controle. Da próxima vez, gostaria de desafiá-la a uma corrida de escavação de fósseis no subsolo.", - "3": "Com habilidade como a sua, é natural que você vença.", - "4": "O-o que?! Não pode ser! Nem isso foi suficiente?", - "5": "Eu estraguei tudo." - }, - "defeat": { - "1": "Veja? Estou orgulhoso do meu estilo de batalha rochoso!", - "2": "Obrigado! A batalha me deu confiança de que talvez eu consiga vencer meu pai!", - "3": "Sinto como se tivesse acabado de quebrar uma pedra muito teimosa!" - } - }, - "morty": { - "encounter": { - "1": "Com um pouco mais, eu poderia ver um futuro em que encontro o Pokémon lendário.\nVocê vai me ajudar a alcançar esse nível!", - "2": "Dizem que um Pokémon com cores de arco-íris aparecerá diante de um Treinador verdadeiramente poderoso.\nAcreditei nessa história, então treinei secretamente aqui a vida toda. Como resultado, agora posso ver o que os outros não podem.\nVejo uma sombra da pessoa que fará o Pokémon aparecer.\nAcredito que essa pessoa sou eu! Você vai me ajudar a alcançar esse nível!", - "3": "Quer você escolha acreditar ou não, o poder místico existe.", - "4": "Você pode testemunhar os frutos do meu treinamento.", - "5": "Você deve fazer sua alma se tornar uma com a dos Pokémon. Você pode fazer isso?", - "6": "Diga, você quer fazer parte do meu treinamento?" - }, - "victory": { - "1": "Ainda não sou bom o suficiente...", - "2": "Eu vejo... Sua jornada o levou a lugares distantes e você testemunhou muito mais do que eu.\nEu invejo você por isso...", - "2_female": "Eu vejo... Sua jornada a levou a lugares distantes e você testemunhou muito mais do que eu.\nEu invejo você por isso...", - "3": "Como isso é possível...", - "4": "Não acho que nossos potenciais sejam tão diferentes.\nMas você parece ter algo mais do que isso... Que seja.", - "5": "Acho que preciso de mais treinamento.", - "6": "Isso é uma pena." - }, - "defeat": { - "1": "Eu me movi... mais um passo adiante.", - "2": "Fufufu...", - "3": "O-o que?! Não pode ser! Nem isso foi suficiente?", - "4": "Sinto como se tivesse acabado de quebrar uma pedra muito teimosa!", - "5": "Ahahahah!", - "6": "Eu sabia que venceria!" - } - }, - "crispin": { - "encounter": { - "1": "Quero vencer, então é exatamente isso que vou fazer!", - "2": "Eu batalho porque quero batalhar! E sabe de uma coisa? É assim que deve ser!" - }, - "victory": { - "1": "Queria vencer... mas perdi!", - "2": "Eu perdi... porque não consegui vencer!" - }, - "defeat": { - "1": "Ei, espere um segundo. Eu acabei de vencer? Acho que acabei de vencer! Que satisfação!", - "2": "Uou! Isso foi incrível!" - } - }, - "amarys": { - "encounter": { - "1": "Quero ser a pessoa a ajudar alguém em particular. Sendo assim, não posso me dar ao luxo de perder.\n... Nossa batalha começa agora." - }, - "victory": { - "1": "Eu sou... não o suficiente, eu vejo." - }, - "defeat": { - "1": "A vitória pertence a mim. Bem lutado." - } - }, - "lacey": { - "encounter": { - "1": "Vou enfrentar você com meu time usual como membro da Elite dos Quatro." - }, - "victory": { - "1": "Foi uma excelente batalha. Estou ansiosa para o próximo desafio." - }, - "defeat": { - "1": "Fufufu... Nada mal.\nDesafiantes que derrotam a Elite dos Quatro são dignos de notar." - } - }, - "drayton": { - "encounter": { - "1": "Cara, eu amo cadeiras. Você não ama cadeiras? Que salva-vidas.\n$Não entendo por que todo mundo não fica sentado o tempo todo. Ficar de pé é cansativo!" - }, - "victory": { - "1": "Acho que deveria ter esperado por isso!" - }, - "defeat": { - "1": "Heh heh! Não ligue para mim, só pegando uma vitória aqui. Entendo se você estiver chateado, mas não vá dar uma de Kieran comigo, OK?", - "1_female": "Heh heh! Não ligue para mim, só pegando uma vitória aqui. Entendo se você estiver chateada, mas não vá dar uma de Kieran comigo, OK?" - } - }, - "ramos": { - "encounter": { - "1": "Você gostou do jardim de diversão que fiz com todas essas plantas resistentes minhas?\n$A força delas é um sinal da minha força como jardineiro e Líder de Ginásio! Você tem certeza de que está pronto para enfrentar tudo isso?", - "1_female": "Você gostou do jardim de diversão que fiz com todas essas plantas resistentes minhas?\n$A força delas é um sinal da minha força como jardineiro e Líder de Ginásio! Você tem certeza de que está pronta para enfrentar tudo isso?" - }, - "victory": { - "1": "Você acredita nos seus Pokémon... E eles acreditam em você também... Foi uma boa batalha, broto." - }, - "defeat": { - "1": "Hohoho... De fato. Pequenas lâminas frágeis de grama conseguem quebrar até mesmo concreto." - } - }, - "viola": { - "encounter": { - "1": "Seja as lágrimas de frustração que seguem uma derrota ou o florescer da alegria que vem com a vitória…\n$Ambos são ótimos temas para minha câmera! Fantástico! Isso vai ser simplesmente fantástico!\n$Agora venha para cima de mim!", - "2": "Minha lente está sempre focada na vitória – não vou deixar nada estragar esta foto!" - }, - "victory": { - "1": "Você e seus Pokémon me mostraram uma nova profundidade de campo! Fantástico! Simplesmente fantástico!", - "2": "O mundo que você vê através de uma lente, e o mundo que você vê com um Pokémon ao seu lado…\n$O mesmo mundo pode parecer completamente diferente dependendo do seu ponto de vista." - }, - "defeat": { - "1": "A foto do momento da minha vitória vai ser um verdadeiro sucesso!", - "2": "Sim! Tirei ótimas fotos!" - } - }, - "candice": { - "encounter": { - "1": "Você quer desafiar a Candice? Com certeza! Eu estava esperando por alguém forte!\n$Mas devo te avisar, sou forte porque sei como focar.", - "2": "Pokémon, moda, romance… É tudo uma questão de foco!\n$Vou te mostrar exatamente o que quero dizer. Prepare-se para perder!" - }, - "victory": { - "1": "Devo dizer, estou aquecida para você! Posso até te admirar um pouco.", - "2": "Uau! Você é ótimo! Ganhou meu respeito!\n$Acho que seu foco e vontade nos derrubaram totalmente.", - "2_female": "Uau! Você é ótima! Ganhou meu respeito!\n$Acho que seu foco e vontade nos derrubaram totalmente." - }, - "defeat": { - "1": "Eu senti sua vontade de vencer, mas eu não perco!", - "2": "Viu? O foco da Candice! O foco dos meus Pokémon também é ótimo!" - } - }, - "gardenia": { - "encounter": { - "1": "Você tem uma aura vencedora. Então, de qualquer forma, isso vai ser divertido. Vamos ter nossa batalha!" - }, - "victory": { - "1": "Incrível! Você é muito bom, não é?", - "1_female": "Incrível! Você é muito boa, não é?" - }, - "defeat": { - "1": "Sim! Meus Pokémon e eu somos perfeitamente bons!" - } - }, - "aaron": { - "encounter": { - "1": "Ok! Deixe-me enfrentar você!" - }, - "victory": { - "1": "Batalhar é um assunto profundo e complexo..." - }, - "defeat": { - "1": "Vencer um membro da Elite dos Quatro não é fácil." - } - }, - "cress": { - "encounter": { - "1": "Isso mesmo! Serei eu e meus estimados tipos Água que você deve enfrentar na batalha!" - }, - "victory": { - "1": "Perder? Eu? Não acredito nisso." - }, - "defeat": { - "1": "Este é o resultado apropriado quando eu sou seu oponente." - } - }, - "allister": { - "encounter": { - "1": "Sou Allister.\nA-aqui... vou eu..." - }, - "victory": { - "1": "Quase perdi minha máscara de tanto choque... Isso foi…\n$Uau. Posso ver sua habilidade pelo que ela é." - }, - "defeat": { - "1": "I-isso foi incrível!" - } - }, - "clay": { - "encounter": { - "1": "Harrumph! Me deixou esperando, não foi, garoto? Tudo bem, hora de ver o que você pode fazer!", - "1_female": "Harrumph! Me deixou esperando, não foi, garota? Tudo bem, hora de ver o que você pode fazer!" - }, - "victory": { - "1": "Cara, como é bom dar tudo de si e ainda assim ser derrotado!" - }, - "defeat": { - "1": "O que importa é como você reage à derrota.\n$É por isso que as pessoas que usam a derrota como combustível para melhorar são duras." - } - }, - "kofu": { - "encounter": { - "1": "Vou te servir um prato completo de Pokémon do tipo Água! Mas não tente comê-los!" - }, - "victory": { - "1": "Vaultin' Veluza! Você é animado, não é! Um pouco ANIMADO DEMAIS, se me permite dizer!", - "1_female": "Vaultin' Veluza! Você é animada, não é! Um pouco ANIMADA DEMAIS, se me permite dizer!" - }, - "defeat": { - "1": "Volte para me ver novamente, ouviu?" - } - }, - "tulip": { - "encounter": { - "1": "Permita-me usar minhas habilidades para deixar seus lindos Pokémon ainda mais bonitos!" - }, - "victory": { - "1": "Sua força tem uma magia que não pode ser apagada." - }, - "defeat": { - "1": "Você sabe, na minha linha de trabalho, pessoas que carecem de talento em uma área ou outra frequentemente desaparecem rapidamente - nunca mais se ouve falar delas." - } - }, - "sidney": { - "encounter": { - "1": "Gostei desse olhar que você me deu. Acho que você vai ser um bom desafio.\n$Isso é ótimo! Parece muito bom! Vamos nessa!\n$Você e eu, vamos curtir uma batalha que só pode acontecer aqui!" - }, - "victory": { - "1": "E aí, gostou? Eu perdi! Mas foi divertido, então não importa." - }, - "defeat": { - "1": "Sem ressentimentos, beleza?" - } - }, - "phoebe": { - "encounter": { - "1": "Enquanto treinava, adquiri a habilidade de me comunicar com Pokémon do tipo Fantasma. \n$Sim, o vínculo que desenvolvi com os Pokémon é extremamente forte. \n$Então, vamos lá, tente ver se você consegue até mesmo causar dano aos meus Pokémon!" - }, - "victory": { - "1": "Ah, droga. Eu perdi." - }, - "defeat": { - "1": "Estou ansiosa para batalhar com você de novo algum dia!" - } - }, - "glacia": { - "encounter": { - "1": "Tudo o que vi foram desafios de Treinadores fracos e seus Pokémon. \n$E você? Ficaria extremamente satisfeita se pudesse dar tudo de mim contra você!" - }, - "victory": { - "1": "Você e seus Pokémon… Como seus espíritos queimam!\n$O calor consumido é esmagador. \n$Não é surpresa que minhas habilidades geladas falharam em te machucar." - }, - "defeat": { - "1": "Uma batalha intensamente apaixonada, sem dúvida." - } - }, - "drake": { - "encounter": { - "1": "Para nós, batalhar com Pokémon como parceiros, você sabe o que é necessário? Você sabe o que precisa? \n$Se não souber, nunca prevalecerá contra mim!" - }, - "victory": { - "1": "Excelente, deve-se dizer." - }, - "defeat": { - "1": "Dei meu máximo nessa batalha!" - } - }, - "wallace": { - "encounter": { - "1": "Há algo em você… Uma diferença na sua postura. \n$Acho que sinto isso em você. Agora, me mostre. Mostre-me o poder que você tem com seus Pokémon. \n$E eu, por minha vez, apresentarei uma performance de ilusões na água com meus Pokémon!" - }, - "victory": { - "1": "Bravo. Agora percebo sua autenticidade e magnificência como Treinador de Pokémon. \n$Tenho muita alegria em ter conhecido você e seus Pokémon. Você se mostrou digno.", - "1_female": "Bravo. Agora percebo sua autenticidade e magnificência como Treinadora de Pokémon. \n$Tenho muita alegria em ter conhecido você e seus Pokémon. Você se mostrou digna." - }, - "defeat": { - "1": "Uma grande ilusão!" - } - }, - "lorelei": { - "encounter": { - "1": "Ninguém me supera quando se trata de Pokémon gelados! Movimentos congelantes são poderosos!\n$Seus Pokémon estarão à minha mercê quando estiverem congelados! Hahaha! Está pronto?", - "1_female": "Ninguém me supera quando se trata de Pokémon gelados! Movimentos congelantes são poderosos!\n$Seus Pokémon estarão à minha mercê quando estiverem congelados! Hahaha! Está pronta?" - }, - "victory": { - "1": "Como ousa!" - }, - "defeat": { - "1": "Não há nada que você possa fazer quando está congelado.", - "1_female": "Não há nada que você possa fazer quando está congelada." - } - }, - "will": { - "encounter": { - "1": "Treinei por todo o mundo, tornando meus Pokémon psíquicos poderosos.\n$Eu só posso melhorar! Perder não é uma opção!" - }, - "victory": { - "1": "Eu… Eu não… acredito…" - }, - "defeat": { - "1": "Isso foi por pouco. Me pergunto o que está faltando em você." - } - }, - "malva": { - "encounter": { - "1": "Sinto que meu coração pode explodir em chamas. \n$Estou ardendo de ódio por você, pirralho!", - "1_female": "Sinto que meu coração pode explodir em chamas. \n$Estou ardendo de ódio por você, pirralha!" - }, - "victory": { - "1": "Que novidade… Um novo desafiador derrotou Malva!", - "1_female": "Que novidade… Uma nova desafiadora derrotou Malva!" - }, - "defeat": { - "1": "Estou encantada! Sim, encantada por poder esmagar você sob meu calcanhar." - } - }, - "hala": { - "encounter": { - "1": "O velho Hala está aqui para fazer você gritar!" - }, - "victory": { - "1": "Pude sentir o poder que você ganhou na sua jornada." - }, - "defeat": { - "1": "Haha! Que batalha deliciosa!" - } - }, - "molayne": { - "encounter": { - "1": "Dei a posição de capitão ao meu primo Sophocles, mas estou confiante na minha habilidade. \n$Minha força é como a de uma supernova!" - }, - "victory": { - "1": "Certamente encontrei um Treinador interessante para enfrentar!", - "1_female": "Certamente encontrei uma Treinadora interessante para enfrentar!" - }, - "defeat": { - "1": "Ahaha. Que batalha interessante." - } - }, - "rika": { - "encounter": { - "1": "Eu diria que vou pegar leve com você, mas… estaria mentindo! Pense rápido!" - }, - "victory": { - "1": "Nada mal, garoto.", - "1_female": "Nada mal, garota." - }, - "defeat": { - "1": "Nahahaha! Você realmente é algo mais, garoto!", - "1_female": "Nahahaha! Você realmente é algo mais, garota!" - } - }, - "bruno": { - "encounter": { - "1": "Nós vamos te triturar com nosso poder superior! Hoo hah!" - }, - "victory": { - "1": "Por quê? Como eu poderia perder?" - }, - "defeat": { - "1": "Você pode me desafiar o quanto quiser, mas os resultados nunca vão mudar!" - } - }, - "bugsy": { - "encounter": { - "1": "Sou Bugsy! Eu nunca perco quando se trata de Pokémon do tipo Inseto!" - }, - "victory": { - "1": "Uau, incrível! Você é um especialista em Pokémon!\nMinha pesquisa ainda não está completa. OK, você venceu.", - "1_female": "Uau, incrível! Você é uma especialista em Pokémon!\nMinha pesquisa ainda não está completa. OK, você venceu." - }, - "defeat": { - "1": "Obrigado! Graças à nossa batalha, eu também pude fazer progressos na minha pesquisa!" - } - }, - "koga": { - "encounter": { - "1": "Fwahahahaha! Pokémon não são apenas sobre força bruta--você verá em breve!" - }, - "victory": { - "1": "Ah! Você provou seu valor!" - }, - "defeat": { - "1": "Você aprendeu a temer as técnicas do ninja?" - } - }, - "bertha": { - "encounter": { - "1": "Bem, você mostraria a esta velha senhora o quanto aprendeu?" - }, - "victory": { - "1": "Bem! Querida criança, devo dizer, isso foi muito impressionante. \n$Seus Pokémon acreditaram em você e fizeram o melhor para te dar a vitória. \n$Mesmo tendo perdido, me encontro com esse sorriso bobo!" - }, - "defeat": { - "1": "Hahahahah! Parece que esta velha senhora ganhou!" - } - }, - "lenora": { - "encounter": { - "1": "Bem, desafiador, vou pesquisar como você batalha com os Pokémon que criou com tanto carinho!", - "1_female": "Bem, desafiadora, vou pesquisar como você batalha com os Pokémon que criou com tanto carinho!" - }, - "victory": { - "1": "Minha teoria sobre você estava correta. Você é mais do que talentoso… Você é motivado! Eu te saúdo!", - "1_female": "Minha teoria sobre você estava correta. Você é mais do que talentosa… Você é motivada! Eu te saúdo!" - }, - "defeat": { - "1": "Ah ha ha! Se você perder, certifique-se de analisar o porquê e use esse conhecimento na próxima batalha!" - } - }, - "siebold": { - "encounter": { - "1": "Enquanto eu estiver vivo, continuarei em busca da culinária suprema... e dos oponentes mais fortes em batalha!" - }, - "victory": { - "1": "Guardarei minha memória de você e seus Pokémon para sempre em meu coração." - }, - "defeat": { - "1": "Nossa batalha Pokémon foi como alimento para minha alma. Isso vai me manter em frente. \n$É assim que vou prestar meus respeitos a você por dar tudo de si na batalha!" - } - }, - "roxie": { - "encounter": { - "1": "Prepare-se! Vou arrancar algum senso de você!" - }, - "victory": { - "1": "Selvagem! Sua razão já é mais tóxica que a minha!" - }, - "defeat": { - "1": "Ei, vamos lá! Seja sério! Você tem que dar mais de si!", - "1_female": "Ei, vamos lá! Seja séria! Você tem que dar mais de si!" - } - }, - "olivia": { - "encounter": { - "1": "Não precisa de introdução aqui. Hora de batalhar comigo, Olivia!" - }, - "victory": { - "1": "Realmente encantador… Tanto você quanto seus Pokémon…" - }, - "defeat": { - "1": "Mmm-hmm." - } - }, - "poppy": { - "encounter": { - "1": "Oooh! Você quer ter uma batalha Pokémon comigo?" - }, - "victory": { - "1": "Uagh?! Mmmuuuggghhh…" - }, - "defeat": { - "1": "Yaaay! Eu consegui! Eu der-ro-tei você! Você pode vir para… Para… Uma revanche? \n$Venha para uma revanche quando quiser!" - } - }, - "agatha": { - "encounter": { - "1": "Pokémon são para batalhas! Vou te mostrar como um verdadeiro Treinador batalha!" - }, - "victory": { - "1": "Oh meu! Você é algo especial, criança!" - }, - "defeat": { - "1": "Bahaha. É assim que uma batalha adequada é feita!" - } - }, - "flint": { - "encounter": { - "1": "Espero que você esteja aquecido, porque aqui vem o Big Bang!", - "1_female": "Espero que você esteja aquecida, porque aqui vem o Big Bang!" - }, - "victory": { - "1": "Incrível! Seus movimentos são tão quentes que fazem os meus parecerem mornos!" - }, - "defeat": { - "1": "Huh? Isso é tudo? Acho que você precisa de um pouco mais de paixão." - } - }, - "grimsley": { - "encounter": { - "1": "O vencedor leva tudo, e não sobra nada para o perdedor." - }, - "victory": { - "1": "Quando se perde, perde-se tudo… A próxima coisa que vou procurar será a vitória, também!" - }, - "defeat": { - "1": "Se alguém vence, a pessoa que lutou contra essa pessoa perde." - } - }, - "caitlin": { - "encounter": { - "1": "Sou eu que apareci quando a flor se abriu. Você que estava esperando…\n$Você parece um Treinador de Pokémon com força refinada e bondade profunda. \n$O que eu procuro no meu oponente é uma força soberba… \n$Por favor, libere seu poder ao máximo!", - "1_female": "Sou eu que apareci quando a flor se abriu. Você que estava esperando…\n$Você parece uma Treinadora de Pokémon com força refinada e bondade profunda. \n$O que eu procuro no meu oponente é uma força soberba… \n$Por favor, libere seu poder ao máximo!" - }, - "victory": { - "1": "Meus Pokémon e eu aprendemos muito! Agradeço a você." - }, - "defeat": { - "1": "Aspiro a reivindicar a vitória com elegância e graça." - } - }, - "diantha": { - "encounter": { - "1": "Batalhar contra você e seus Pokémon, todos vocês cheios de esperança para o futuro… \n$Honestamente, isso apenas me enche da energia que preciso para continuar enfrentando cada novo dia! Sim!" - }, - "victory": { - "1": "Testemunhar os espíritos nobres de você e seus Pokémon em batalha realmente tocou meu coração…" - }, - "defeat": { - "1": "Oh, fantástico! O que achou? Minha equipe foi bem legal, né?" - } - }, - "wikstrom": { - "encounter": { - "1": "Bem encontrado, jovem desafiador! Verdadeiramente sou a lâmina famosa de aço endurecido, Duque Wikstrom! \n$Que a batalha comece! En garde!", - "1_female": "Bem encontrado, jovem desafiadora! Verdadeiramente sou a lâmina famosa de aço endurecido, Duque Wikstrom! \n$Que a batalha comece! En garde!" - }, - "victory": { - "1": "Glorioso! A confiança que você compartilha com seu honrado Pokémon supera até mesmo a minha!", - "1_female": "Gloriosa! A confiança que você compartilha com seu honrado Pokémon supera até mesmo a minha!" - }, - "defeat": { - "1": "Que tipo de magia é essa? Meu coração bate incessantemente no meu peito! \n$Vencer contra um oponente tão digno dá asas à minha alma--assim eu voo!", - "1_female": "Que tipo de magia é essa? Meu coração bate incessantemente no meu peito! \n$Vencer contra uma oponente tão digna dá asas à minha alma--assim eu voo!" - } - }, - "acerola": { - "encounter": { - "1": "Batalhar é simplesmente divertido! Vamos lá, eu posso te derrotar!" - }, - "victory": { - "1": "Eu… Estou sem palavras! Como você conseguiu?!" - }, - "defeat": { - "1": "Ehaha! Que vitória incrível!" - } - }, - "larry_elite": { - "encounter": { - "1": "Olá… Sou eu, Larry.\n$Eu também sou membro da Elite dos Quatro, sim… Infelizmente para mim." - }, - "victory": { - "1": "Bem, isso tirou o vento debaixo das nossas asas…" - }, - "defeat": { - "1": "É hora de uma reunião com o chefe." - } - }, - "lance": { - "encounter": { - "1": "Estive esperando por você. Permita-me testar suas habilidades.", - "2": "Achei que você conseguiria chegar tão longe. Vamos começar." - }, - "victory": { - "1": "Você me pegou. Você é magnífico!", - "1_female": "Você me pegou. Você é magnífica!", - "2": "Nunca esperei que outro Treinador me derrotasse… Estou surpreso.", - "2_female": "Nunca esperei que outra Treinadora me derrotasse… Estou surpreso." - }, - "defeat": { - "1": "Isso foi por pouco. Quer tentar de novo?", - "2": "Não é que você seja fraco. Não se incomode com isso.", - "2_female": "Não é que você seja fraca. Não se incomode com isso." - } - }, - "karen": { - "encounter": { - "1": "Eu sou Karen. Você gostaria de um duelo com meus Pokémon do tipo Sombrio?", - "2": "Sou diferente daqueles que você já conheceu.", - "3": "Você montou uma equipe charmosa. Nossa batalha deve ser boa." - }, - "victory": { - "1": "Não! Eu não posso vencer. Como você ficou tão forte?", - "2": "Não me desviarei do meu caminho escolhido.", - "3": "O Campeão está ansioso para te conhecer." - }, - "defeat": { - "1": "Isso era o que eu esperava.", - "2": "Bem, isso foi relativamente divertido.", - "3": "Venha me visitar a qualquer momento." - } - }, - "milo": { - "encounter": { - "1": "Parece que você entende bem os Pokémon. \n$Isso vai ser uma batalha e tanto! \n$Vou ter que usar a Dynamax no meu Pokémon se eu quiser vencer!" - }, - "victory": { - "1": "O poder da Grama murchou… Que desafiador incrível!", - "1_female": "O poder da Grama murchou… Que desafiadora incrível!" - }, - "defeat": { - "1": "Isso realmente vai te deixar em choque e admiração." - } - }, - "lucian": { - "encounter": { - "1": "Só um momento, por favor. O livro que estou lendo está quase no clímax emocionante… \n$O herói obteve uma espada mística e está prestes a enfrentar sua prova final… Ah, tanto faz. \n$Já que você chegou tão longe, vou deixar isso de lado e batalhar com você. \n$Deixe-me ver se você alcançará tanta glória quanto o herói do meu livro!" - }, - "victory": { - "1": "Eu vejo… Parece que você me colocou em xeque-mate." - }, - "defeat": { - "1": "Tenho uma reputação a manter." - } - }, - "drasna": { - "encounter": { - "1": "Você deve ser um Treinador forte. Sim, bastante forte…\n$Isso é uma notícia maravilhosa! Enfrentar oponentes como você e sua equipe fará meus Pokémon crescerem como ervas daninhas!", - "1_female": "Você deve ser uma Treinadora forte. Sim, bastante forte…\n$Isso é uma notícia maravilhosa! Enfrentar oponentes como você e sua equipe fará meus Pokémon crescerem como ervas daninhas!" - }, - "victory": { - "1": "Oh, meu Deus. Isso foi uma batalha rápida… Espero que você volte novamente algum dia!" - }, - "defeat": { - "1": "Como isso é possível?" - } - }, - "kahili": { - "encounter": { - "1": "Então, aqui está você… Por que não vemos para quem os ventos favorecem hoje, você… ou eu?" - }, - "victory": { - "1": "É frustrante para mim como membro da Elite dos Quatro, mas parece que sua força é real." - }, - "defeat": { - "1": "Essa foi uma jogada de mestre!" - } - }, - "hassel": { - "encounter": { - "1": "Prepare-se para aprender em primeira mão como é a respiração ardente de uma batalha feroz!" - }, - "victory": { - "1": "A sorte sorriu para mim desta vez, mas… \n$Julgando pelo andamento da luta, quem sabe se serei tão sortudo na próxima vez." - }, - "defeat": { - "1": "Essa foi uma jogada de mestre!" - } - }, - "blue": { - "encounter": { - "1": "Você deve ser muito bom para chegar tão longe.", - "1_female": "Você deve ser muito boa para chegar tão longe." - }, - "victory": { - "1": "Só perdi para ele e agora para você… Ele? Hee, hee…" - }, - "defeat": { - "1": "Viu? Meu poder é o que me trouxe até aqui." - } - }, - "piers": { - "encounter": { - "1": "Prepare-se para uma mosh pit comigo e minha galera! Spikemuth, é hora de roquear!" - }, - "victory": { - "1": "Eu e minha equipe demos o nosso melhor. Vamos nos encontrar novamente para uma batalha algum dia…" - }, - "defeat": { - "1": "Minha garganta está desgastada de tanto gritar… Mas essa foi uma batalha empolgante!" - } - }, - "red": { - "encounter": { - "1": "…!" - }, - "victory": { - "1": "…?" - }, - "defeat": { - "1": "…!" - } - }, - "jasmine": { - "encounter": { - "1": "Oh… Seus Pokémon são impressionantes. Acho que vou gostar disso." - }, - "victory": { - "1": "Você é realmente forte. Vou ter que me esforçar muito mais também." - }, - "defeat": { - "1": "Eu nunca esperei ganhar." - } - }, - "lance_champion": { - "encounter": { - "1": "Ainda sou o Campeão. Não vou segurar nada." - }, - "victory": { - "1": "Esta é a emergência de um novo Campeão.", - "1_female": "Esta é a emergência de uma nova Campeã." - }, - "defeat": { - "1": "Defendi com sucesso meu Campeonato." - } - }, - "steven": { - "encounter": { - "1": "Diga-me… O que você viu na sua jornada com seus Pokémon? \n$O que você sentiu, encontrando tantos outros Treinadores por aí? \n$Viajar por esta terra rica… Isso despertou algo dentro de você? \n$Quero que você venha até mim com tudo o que aprendeu. \n$Meus Pokémon e eu responderemos com tudo o que sabemos!" - }, - "victory": { - "1": "Então eu, o Campeão, caio em derrota…" - }, - "defeat": { - "1": "Esse tempo foi bem gasto! Obrigado!" - } - }, - "cynthia": { - "encounter": { - "1": "Eu, Cynthia, aceito seu desafio! Não haverá nenhuma trégua da minha parte!" - }, - "victory": { - "1": "Não importa o quão divertida a batalha seja, ela sempre terminará algum dia…" - }, - "defeat": { - "1": "Mesmo que você perca, nunca perca o amor pelos Pokémon." - } - }, - "iris": { - "encounter": { - "1": "Sabe de uma coisa? Estou realmente ansiosa para ter batalhas sérias com Treinadores fortes! \n$Quero dizer, vamos lá! Os Treinadores que chegam aqui são Treinadores que desejam a vitória com todas as fibras do seu ser! \n$E eles estão batalhando ao lado de Pokémon que passaram por inúmeras batalhas difíceis! \n$Se eu batalhar com pessoas assim, não só eu ficarei mais forte, meus Pokémon também! \n$E nós vamos nos conhecer ainda melhor! OK! Prepare-se! \n$Sou Iris, a Campeã da Liga Pokémon, e vou te derrotar!" - }, - "victory": { - "1": "Aghhhh… Eu dei o meu melhor, mas nós perdemos…" - }, - "defeat": { - "1": "Yay! Nós vencemos!" - } - }, - "hau": { - "encounter": { - "1": "Eu me pergunto se um Treinador batalha de maneira diferente dependendo se ele é de uma região quente ou fria.\n$Vamos testar isso!" - }, - "victory": { - "1": "Isso foi incrível! Acho que entendi um pouco melhor seu estilo agora!" - }, - "defeat": { - "1": "Cara, essa foi uma batalha e tanto!" - } - }, - "geeta": { - "encounter": { - "1": "Decidi entrar na batalha mais uma vez. \n$Venha agora… Mostre-me os frutos do seu treinamento." - }, - "victory": { - "1": "Estou ansiosa para notícias de todas as suas conquistas!" - }, - "defeat": { - "1": "Qual o problema? Isso é tudo?" - } - }, - "nemona": { - "encounter": { - "1": "Yesss! Estou tão empolgada! Hora de soltar tudo!" - }, - "victory": { - "1": "Bem, isso foi ruim, mas ainda me diverti! Eu te pego na próxima!" - }, - "defeat": { - "1": "Bem, essa foi uma ótima batalha! Frutífera, com certeza." - } - }, - "leon": { - "encounter": { - "1": "Vamos ter um tempo absolutamente campeão!" - }, - "victory": { - "1": "Meu tempo como Campeão acabou… \n$Mas que tempo campeão foi! \n$Obrigado pela melhor batalha que já tive!" - }, - "defeat": { - "1": "Um tempo absolutamente campeão, foi!" - } - }, - "whitney": { - "encounter": { - "1": "Eai! Você não acha que os Pokémon são, tipo, super fofos?" - }, - "victory": { - "1": "Waaah! Waaah! Você é tão mau!", - "1_female": "Waaah! Waaah! Você é tão má!" - }, - "defeat": { - "1": "E é isso!" - } - }, - "chuck": { - "encounter": { - "1": "Hah! Você quer me desafiar? É corajoso ou apenas ignorante?", - "1_female": "Hah! Você quer me desafiar? É corajosa ou apenas ignorante?" - }, - "victory": { - "1": "Você é forte! Por favor, me faça seu aprendiz?" - }, - "defeat": { - "1": "Aí está. Você percebe o quanto sou mais poderoso que você?" - } - }, - "katy": { - "encounter": { - "1": "Não baixe a guarda, a menos que queira se ver jogado no chão!", - "1_female": "Não baixe a guarda, a menos que queira se ver jogada no chão!" - }, - "victory": { - "1": "Todos os meus adoráveis Pokémon caíram como moscas!" - }, - "defeat": { - "1": "Coma, meu adorável Vivillon!" - } - }, - "pryce": { - "encounter": { - "1": "A juventude sozinha não garante a vitória! Experiência é o que conta." - }, - "victory": { - "1": "Excelente! Isso foi perfeito. Tente não esquecer o que sente agora." - }, - "defeat": { - "1": "Exatamente como eu imaginei." - } - }, - "clair": { - "encounter": { - "1": "Você sabe quem eu sou? E ainda se atreve a me desafiar?" - }, - "victory": { - "1": "Eu me pergunto até onde você pode ir com seu nível de habilidade. Isso deve ser fascinante." - }, - "defeat": { - "1": "E é isso." - } - }, - "maylene": { - "encounter": { - "1": "Vim desafiá-lo agora e não vou segurar nada. \n$Por favor, prepare-se para a batalha!", - "1_female": "Vim desafiá-la agora e não vou segurar nada. \n$Por favor, prepare-se para a batalha!" - }, - "victory": { - "1": "Eu admito a derrota…" - }, - "defeat": { - "1": "Isso foi incrível." - } - }, - "fantina": { - "encounter": { - "1": "Você vai me desafiar, não é? Mas eu vou ganhar. \n$É o que a Líder do Ginásio de Hearthome faz, não?" - }, - "victory": { - "1": "Você é tão incrivelmente forte. Sei porque perdi." - }, - "defeat": { - "1": "Estou tão, tão, muito feliz!" - } - }, - "byron": { - "encounter": { - "1": "Treinador! Você é jovem, assim como meu filho, Roark. \n$Com mais Treinadores jovens assumindo o comando, o futuro dos Pokémon é brilhante! \n$Então, como uma parede para os jovens, aceitarei seu desafio!", - "1_female": "Treinadora! Você é jovem, assim como meu filho, Roark. \n$Com mais Treinadores jovens assumindo o comando, o futuro dos Pokémon é brilhante! \n$Então, como uma parede para os jovens, aceitarei seu desafio!" - }, - "victory": { - "1": "Hmm! Meus Pokémon robustos--derrotados!" - }, - "defeat": { - "1": "Gwahahaha! Como foram meus Pokémon robustos?!" - } - }, - "olympia": { - "encounter": { - "1": "Um costume antigo decidindo o destino de alguém. A batalha começa!" - }, - "victory": { - "1": "Crie seu próprio caminho. Não deixe nada te atrapalhar. Seu destino, seu futuro." - }, - "defeat": { - "1": "Nosso caminho está claro agora." - } - }, - "volkner": { - "encounter": { - "1": "Já que você chegou tão longe, deve ser bastante forte…\n$Espero que você seja o Treinador que me faça lembrar como é divertido batalhar!", - "1_female": "Já que você chegou tão longe, deve ser bastante forte…\n$Espero que você seja a Treinadora que me faça lembrar como é divertido batalhar!" - }, - "victory": { - "1": "Você me venceu…\n$Seu desejo e a maneira nobre como seus Pokémon batalharam por você… \n$Eu até me senti emocionado durante nossa luta. Foi uma batalha muito boa." - }, - "defeat": { - "1": "Não foi nada chocante…\n$Isso não é o que eu queria!" - } - }, - "burgh": { - "encounter": { - "1": "M'hm… Se eu ganhar esta batalha, sinto que posso desenhar um quadro diferente de qualquer outro. \n$OK! Posso ouvir minha musa da batalha claramente. Vamos direto ao ponto!", - "2": "Claro, estou realmente orgulhoso de todos os meus Pokémon! \n$Bem agora… Vamos direto ao ponto!" - }, - "victory": { - "1": "Acabou? Minha musa me abandonou?", - "2": "Hmm… Acabou! Você é incrível!" - }, - "defeat": { - "1": "Uau… É bonito de alguma forma, não é…", - "2": "Às vezes ouço as pessoas dizerem que foi uma vitória feia. \n$Acho que se você está dando o seu melhor, qualquer vitória é bonita." - } - }, - "elesa": { - "encounter": { - "1": "C'est fini! Quando tenho certeza disso, sinto um choque elétrico percorrer meu corpo! \n$Quero sentir essa sensação, então agora meus amados Pokémon vão fazer sua cabeça girar!" - }, - "victory": { - "1": "Eu queria fazer sua cabeça girar, mas você me surpreendeu." - }, - "defeat": { - "1": "Isso foi insatisfatório de alguma forma… Você dará tudo de si na próxima vez?" - } - }, - "skyla": { - "encounter": { - "1": "Finalmente é hora do confronto! Isso significa a batalha Pokémon que decide quem está no topo, certo? \n$Eu amo estar no topo! Porque você pode ver para sempre e sempre de lugares altos! \n$Então, que tal nós nos divertirmos?" - }, - "victory": { - "1": "Ser seu oponente na batalha é uma nova fonte de força para mim. Obrigada!" - }, - "defeat": { - "1": "Ganhar ou perder, você sempre ganha algo com uma batalha, certo?" - } - }, - "brycen": { - "encounter": { - "1": "Há também força em estar com outras pessoas e Pokémon. \n$Receber o apoio deles te fortalece. Vou te mostrar esse poder!" - }, - "victory": { - "1": "A maravilhosa combinação de você e seus Pokémon! Que amizade linda!" - }, - "defeat": { - "1": "Condições extremas realmente testam e treinam você!" - } - }, - "drayden": { - "encounter": { - "1": "O que eu quero encontrar é um jovem Treinador que possa me mostrar um futuro brilhante. \n$Vamos batalhar com tudo o que temos: sua habilidade, minha experiência e o amor com que criamos nossos Pokémon!" - }, - "victory": { - "1": "Esse sentimento intenso que me invade após uma derrota… Não sei como descrevê-lo." - }, - "defeat": { - "1": "Harrumph! Sei que sua habilidade é maior que isso!" - } - }, - "grant": { - "encounter": { - "1": "Só há uma coisa que desejo. \n$Que, superando um ao outro, encontremos um caminho para alturas ainda maiores." - }, - "victory": { - "1": "Você é uma parede que não consigo superar!" - }, - "defeat": { - "1": "Não desista. \n$Isso é tudo o que realmente importa. \n$As lições mais importantes da vida são simples." - } - }, - "korrina": { - "encounter": { - "1": "Hora da grande aparição de Lady Korrina!" - }, - "victory": { - "1": "É o seu próprio ser que permite que seus Pokémon evoluam!" - }, - "defeat": { - "1": "Que batalha explosiva!" - } - }, - "clemont": { - "encounter": { - "1": "Oh! Estou feliz por termos nos encontrado!" - }, - "victory": { - "1": "Sua paixão pela batalha me inspira!" - }, - "defeat": { - "1": "Parece que minha Máquina Treinadora-Crescer-Forte, Mach 2 está realmente funcionando!" - } - }, - "valerie": { - "encounter": { - "1": "Oh, se não é um jovem Treinador… É adorável conhecê-lo assim. \n$Então, suponho que você ganhou o direito a uma batalha, como recompensa por seus esforços. \n$Uma elusiva Fada pode parecer frágil como a brisa e delicado como uma flor, mas é forte.", - "1_female": "Oh, se não é uma jovem Treinadora… É adorável conhecê-la assim. \n$Então, suponho que você ganhou o direito a uma batalha, como recompensa por seus esforços. \n$Uma elusiva Fada pode parecer frágil como a brisa e delicado como uma flor, mas é forte." - }, - "victory": { - "1": "Espero que você encontre coisas para sorrir amanhã…" - }, - "defeat": { - "1": "Oh meu Deus, que pena…" - } - }, - "wulfric": { - "encounter": { - "1": "Sabe de uma coisa? Todos falamos muito sobre o que você aprende com as batalhas e os laços e tudo mais…\n$Mas realmente, eu só faço isso porque é divertido. \n$Quem se importa com o grandioso? Vamos batalhar!" - }, - "victory": { - "1": "Incrível! Sou duro como um iceberg, mas você me quebrou por completo!" - }, - "defeat": { - "1": "Lute comigo e é isso que acontece!" - } - }, - "kabu": { - "encounter": { - "1": "Todo Treinador e Pokémon treina duro em busca da vitória. \n$Mas isso significa que seu oponente também está se esforçando para vencer. \n$No final, a partida é decidida por qual lado é capaz de liberar seu verdadeiro potencial." - }, - "victory": { - "1": "Estou feliz por poder lutar com você hoje!" - }, - "defeat": { - "1": "É uma ótima maneira de sentir meu próprio crescimento!" - } - }, - "bea": { - "encounter": { - "1": "Você tem um espírito inabalável que não será movido, não importa como você seja atacado? \n$Acho que vou testar isso, certo?" - }, - "victory": { - "1": "Senti o espírito de luta de seus Pokémon enquanto você os liderava na batalha." - }, - "defeat": { - "1": "Essa foi a melhor partida que alguém poderia esperar." - } - }, - "opal": { - "encounter": { - "1": "Deixe-me ver como você e seu Pokémon parceiro se comportam!" - }, - "victory": { - "1": "Seu rosa ainda está faltando, mas você é um Treinador excelente com Pokémon excelentes.", - "1_female": "Seu rosa ainda está faltando, mas você é uma Treinadora excelente com Pokémon excelentes." - }, - "defeat": { - "1": "Muito ruim para você, eu acho." - } - }, - "bede": { - "encounter": { - "1": "Suponho que devo provar além de qualquer dúvida o quão patético você é e quão forte eu sou.", - "1_female": "Suponho que devo provar além de qualquer dúvida o quão patética você é e quão forte eu sou." - }, - "victory": { - "1": "Eu vejo… Bem, tudo bem. Eu não estava me esforçando muito de qualquer maneira." - }, - "defeat": { - "1": "Bom trabalho, eu suponho." - } - }, - "gordie": { - "encounter": { - "1": "Então, vamos acabar com isso." - }, - "victory": { - "1": "Eu só quero me enterrar em um buraco… Bem, acho que seria mais como cair daqui." - }, - "defeat": { - "1": "Batalhe como sempre faz, a vitória seguirá!" - } - }, - "marnie": { - "encounter": { - "1": "A verdade é que, quando tudo está dito e feito… Eu realmente só quero me tornar Campeã por mim mesma! \n$Então, não leve para o pessoal quando eu chutar seu traseiro!" - }, - "victory": { - "1": "OK, então eu perdi… Mas consegui ver muitos dos pontos bons de você e seus Pokémon!" - }, - "defeat": { - "1": "Espero que você tenha gostado das nossas táticas de batalha." - } - }, - "raihan": { - "encounter": { - "1": "Vou derrotar o Campeão, vencer todo o torneio e provar ao mundo o quão forte o grande Raihan realmente é!" - }, - "victory": { - "1": "Eu pareço bem mesmo quando perco. \n$É uma verdadeira maldição. \n$Acho que é hora de mais uma selfie!" - }, - "defeat": { - "1": "Vamos tirar uma selfie para lembrar disso." - } - }, - "brassius": { - "encounter": { - "1": "Pressuponho que você está pronto? Que nossa obra de arte colaborativa comece!", - "1_female": "Pressuponho que você está pronta? Que nossa obra de arte colaborativa comece!" - }, - "victory": { - "1": "Ahhh…avant-garde!" - }, - "defeat": { - "1": "Começarei uma nova peça imediatamente!" - } - }, - "iono": { - "encounter": { - "1": "Como você está se sentindo sobre esta batalha?\n$...\n$Vamos começar o show! Quão forte é o nosso desafiador? \n$Eu não sei! Vamos descobrir juntos!", - "1_female": "Como você está se sentindo sobre esta batalha?\n$...\n$Vamos começar o show! Quão forte é o nossa desafiadora? \n$Eu não sei! Vamos descobrir juntos!" - }, - "victory": { - "1": "Você é tão chamativo e brilhante quanto um Raio do Trovão de 10.000.000 volts, amigo!", - "1_female": "Você é tão chamativa e brilhante quanto um Raio do Trovão de 10.000.000 volts, amiga!" - }, - "defeat": { - "1": "Seus olhos são MEUS!" - } - }, - "larry": { - "encounter": { - "1": "Quando tudo está dito e feito, a simplicidade é mais forte." - }, - "victory": { - "1": "Uma porção de derrota, hein?" - }, - "defeat": { - "1": "Vou encerrar o dia." - } - }, - "ryme": { - "encounter": { - "1": "Vamos lá, baby! Me agite até os ossos!" - }, - "victory": { - "1": "Você é legal, meu amigo, você move minha ALMA!", - "1_female": "Você é legal, minha amiga, você move minha ALMA!" - }, - "defeat": { - "1": "Até mais, baby!" - } - }, - "grusha": { - "encounter": { - "1": "Tudo o que preciso fazer é garantir que o poder do meu Pokémon te arrependa até os ossos!" - }, - "victory": { - "1": "Sua paixão ardente... Eu meio que gosto, para ser honesto." - }, - "defeat": { - "1": "As coisas não esquentaram para você." - } - }, - "marnie_elite": { - "encounter": { - "1": "Você chegou até aqui, hein? Vamos ver se você pode lidar com meus Pokémon!", - "2": "Vou dar o meu melhor, mas não pense que vou pegar leve com você!" - }, - "victory": { - "1": "Não acredito que perdi... Mas você mereceu essa vitória. Bem feito!", - "2": "Parece que ainda tenho muito a aprender. Porém, grande batalha!" - }, - "defeat": { - "1": "Você lutou bem, mas eu tenho a vantagem! Melhor sorte na próxima vez!", - "2": "Parece que meu treinamento valeu a pena. Obrigado pela batalha!" - } - }, - "nessa_elite": { - "encounter": { - "1": "As marés estão mudando a meu favor. Pronto para ser levado pela corrente?", - "1_female": "As marés estão mudando a meu favor. Pronta para ser levada pela corrente?", - "2": "Vamos fazer ondas com esta batalha! Espero que esteja preparado!", - "2_female": "Vamos fazer ondas com esta batalha! Espero que esteja preparada!" - }, - "victory": { - "1": "Você navegou nessas águas perfeitamente... Bem feito!", - "2": "Parece que minhas correntes não foram páreo para você. Bom trabalho!" - }, - "defeat": { - "1": "A água sempre encontra um caminho. Essa foi uma batalha refrescante!", - "2": "Você lutou bem, mas o poder do oceano é imparável!" - } - }, - "bea_elite": { - "encounter": { - "1": "Prepare-se! Meu espírito de luta brilha intensamente!", - "2": "Vamos ver se você consegue acompanhar meu ritmo implacável!" - }, - "victory": { - "1": "Sua força... É impressionante. Você realmente merece essa vitória.", - "2": "Nunca senti essa intensidade antes. Trabalho incrível!" - }, - "defeat": { - "1": "Outra vitória para meu rigoroso regime de treinamento! Bem feito!", - "2": "Você tem força, mas eu treinei mais. Grande batalha!" - } - }, - "allister_elite": { - "encounter": { - "1": "As sombras caem... Você está pronto para enfrentar seus medos?", - "1_female": "As sombras caem... Você está pronta para enfrentar seus medos?", - "2": "Vamos ver se você pode lidar com a escuridão que eu comando." - }, - "victory": { - "1": "Você dissipou as sombras... Por enquanto. Bem feito.", - "2": "Sua luz atravessou minha escuridão. Ótimo trabalho." - }, - "defeat": { - "1": "As sombras falaram... Sua força não é suficiente.", - "2": "A escuridão triunfa... Talvez na próxima vez você veja a luz." - } - }, - "raihan_elite": { - "encounter": { - "1": "Tempestade se formando! Vamos ver se você aguenta essa luta!", - "2": "Prepare-se para enfrentar o olho da tempestade!" - }, - "victory": { - "1": "Você enfrentou a tempestade... Trabalho incrível!", - "2": "Você navegou nos ventos perfeitamente... Grande batalha!" - }, - "defeat": { - "1": "Outra tempestade enfrentada, outra vitória conquistada! Bem lutado!", - "2": "Você foi pego na minha tempestade! Melhor sorte na próxima vez!", - "2_female": "Você foi pega na minha tempestade! Melhor sorte na próxima vez!" - } - }, - "alder": { - "encounter": { - "1": "Se prepare para uma batalha contra o Treinador mais forte de Unova!" - }, - "victory": { - "1": "Muito bem! Você certamente é um talento incomparável." - }, - "defeat": { - "1": "Um vento fresco sopra em meu coração...\n$Que esforço extraordinário!" - } - }, - "kieran": { - "encounter": { - "1": "Através do trabalho duro, eu me torno cada vez mais forte!\n$Eu não perco." - }, - "victory": { - "1": "Eu não acredito...\n$Que batalha divertida e emocionante!" - }, - "defeat": { - "1": "Uau, que batalha!\n$Hora de você treinar ainda mais." - } - }, - "rival": { - "encounter": { - "1": "@c{smile}Eai, estava procurando você! Sabia que você estava ansioso para começar, mas esperava pelo menos um tchau…\n$@c{smile_eclosed}Então você está realmente perseguindo seu sonho, hein?\n Quase não consigo acreditar.\n$@c{serious_smile_fists}Já que estamos aqui, que tal uma batalha?\nAfinal, quero ter certeza de que você está pronto.\n$@c{serious_mopen_fists}Não se segure, quero que você dê tudo de si!" - }, - "victory": { - "1": "@c{shock}Caramba… Você me limpou.\nVocê é mesmo um novato?\n$@c{smile}Talvez tenha sido um pouco de sorte, mas…\nQuem sabe você consiga chegar até o fim.\n$Aliás, o professor me pediu para te dar esses itens. Eles parecem bem legais.\n$@c{serious_smile_fists}Boa sorte lá fora!" - } - }, - "rival_female": { - "encounter": { - "1": "@c{smile_wave}Aí está você! Procurei você em todo lugar!\n@c{angry_mopen}Esqueceu de se despedir da sua melhor amiga?\n$@c{smile_ehalf}Você está indo atrás do seu sonho, né?\nEsse dia realmente chegou, não é…\n$@c{smile}Enfim, vou te perdoar por ter me esquecido, mas com uma condição. @c{smile_wave_wink}Você tem que lutar comigo!\n$@c{angry_mopen}Dê o seu melhor! Não quer que sua aventura acabe antes de começar, né?" - }, - "victory": { - "1": "@c{shock}Você acabou de começar e já está tão forte?!@d{96}\n@c{angry}Você trapaceou, não foi?\n$@c{smile_wave_wink}Brincadeirinha!@d{64} @c{smile_eclosed}Eu perdi de forma justa… Tenho a sensação de que você vai se sair muito bem lá fora.\n$@c{smile}Aliás, o professor pediu para eu te dar alguns itens. Espero que sejam úteis!\n$@c{smile_wave}Dê o seu melhor, como sempre! Eu acredito em você!" - } - }, - "rival_2": { - "encounter": { - "1": "@c{smile}Eai, você também está aqui?\n@c{smile_eclosed}Ainda com um recorde perfeito, hein…?\n$@c{serious_mopen_fists}Sei que parece que eu te segui até aqui, mas isso não é totalmente verdade.\n$@c{serious_smile_fists}Sinceramente, tenho estado ansioso por uma revanche desde que você me venceu em casa.\n$Tenho treinado bastante, então vou dar uma luta difícil desta vez.\n$@c{serious_mopen_fists}Não se segure, assim como antes!\nVamos lá!" - }, - "victory": { - "1": "@c{neutral_eclosed}Ah. Acho que fui confiante demais.\n$@c{smile}Tudo bem, no entanto. Eu imaginei que isso poderia acontecer.\n@c{serious_mopen_fists}Isso só significa que preciso me esforçar mais para a próxima vez!\n\n$@c{smile}Ah, não que você precise realmente de ajuda, mas eu tinha um extra desses itens e pensei que você poderia querer.\n$@c{serious_smile_fists}Não espere outro depois deste!\nNão posso continuar dando vantagem ao meu oponente.\n$@c{smile}Enfim, cuide-se, e aproveite o evento!" - } - }, - "rival_2_female": { - "encounter": { - "1": "@c{smile_wave}Oh, que surpresa te encontrar aqui. Parece que você ainda está invicto. @c{angry_mopen}Hum… Nada mal!\n$@c{angry_mopen}Eu sei o que você está pensando, e não, eu não estava te espionando. @c{smile_eclosed}Acontece que eu estava na área.\n$@c{smile_ehalf}Estou feliz por você, mas só quero te avisar que está tudo bem perder às vezes.\n$@c{smile}Aprendemos com nossos erros, muitas vezes mais do que se continuássemos vencendo.\n$@c{angry_mopen}De qualquer forma, tenho treinado duro para nossa revanche, então é melhor você dar o seu melhor!" - }, - "victory": { - "1": "@c{neutral}Eu… não era para eu perder dessa vez…\n$@c{smile}Ah bem. Isso só significa que vou ter que treinar ainda mais para a próxima vez!\n$@c{smile_wave}Também consegui mais dois desses para você!\n@c{smile_wave_wink}Não precisa me agradecer~.\n$@c{angry_mopen}Estes são os últimos, hein! Você não vai ganhar mais nenhum presente de mim depois desse!\n$@c{smile_wave}Continue assim, e aproveite o evento!" - }, - "defeat": { - "1": "Está tudo bem perder às vezes…" - } - }, - "rival_3": { - "encounter": { - "1": "@c{smile}Eai, olha quem é! Faz um tempo.\n@c{neutral}Você… ainda está invicto? Hum.\n$@c{neutral_eclosed}As coisas têm sido meio… estranhas.\nNão é a mesma coisa em casa sem você.\n$@c{serious}Eu sei que é egoísta, mas preciso desabafar.\n@c{neutral_eclosed}Acho que você está se metendo em algo grande demais aqui.\n$@c{serious}Nunca perder é irrealista.\nPrecisamos perder às vezes para crescer.\n$@c{neutral_eclosed}Você teve uma grande jornada, mas ainda há muito pela frente, e só vai ficar mais difícil. @c{neutral}Você está preparado para isso?\n$@c{serious_mopen_fists}Se sim, prove para mim." - }, - "victory": { - "1": "@c{angry_mhalf}Isso é ridículo… Eu mal parei de treinar…\nComo ainda estamos tão distantes?" - } - }, - "rival_3_female": { - "encounter": { - "1": "@c{smile_wave}Quanto tempo! Ainda não perdeu, né.\n@c{angry}Você está começando a me irritar. @c{smile_wave_wink}Brincadeirinha!\n$@c{smile_ehalf}Mas sério, você não sente saudades de casa? Ou… de mim?\nEu… Eu quero dizer, sentimos muito a sua falta.\n$@c{smile_eclosed}Eu apoio o seu sonho e tudo mais, mas a realidade é que você vai perder mais cedo ou mais tarde.\n$@c{smile}E quando isso acontecer, estarei lá para você, como sempre.\n@c{angry_mopen}Agora, deixe-me mostrar o quão forte eu me tornei!" - }, - "victory": { - "1": "@c{shock}Depois de tudo isso… não foi o suficiente…?\nVocê nunca vai voltar a esse ritmo…" - }, - "defeat": { - "1": "Você deu o seu melhor, agora vamos para casa." - } - }, - "rival_4": { - "encounter": { - "1": "@c{neutral}Oi.\n$Não vou enrolar com você.\n@c{neutral_eclosed}Estou aqui para vencer, simples assim.\n$@c{serious_mhalf_fists}Aprendi a maximizar meu potencial dedicando todo o meu tempo ao treino.\n$@c{smile}Você ganha muito tempo extra quando corta o sono e a interação social desnecessários.\n$@c{serious_mopen_fists}Nada disso importa mais, não até eu vencer.\n$@c{neutral_eclosed}Cheguei ao ponto de não perder mais.\n@c{smile_eclosed}Acho que sua filosofia não estava tão errada afinal.\n$@c{angry_mhalf}Perder é para os fracos, e eu não sou mais fraco.\n$@c{serious_mopen_fists}Prepare-se." - }, - "victory": { - "1": "@c{neutral}O que…@d{64} O que é você?" - } - }, - "rival_4_female": { - "encounter": { - "1": "@c{neutral}Sou eu! Você não esqueceu de mim de novo… esqueceu?\n$@c{smile}Você deveria se orgulhar de até onde chegou. Parabéns!\nMas parece que é o fim da sua jornada.\n$@c{smile_eclosed}Você despertou algo em mim que eu nunca soube que existia.\nParece que agora tudo o que faço é treinar.\n$@c{smile_ehalf}Eu mal como ou durmo agora, só treino meus Pokémon o dia todo, ficando mais forte a cada vez.\n$@c{neutral}Na verdade, eu… mal me reconheço.\n$E agora, finalmente atingi o desempenho máximo.\nNão acho que alguém poderia me vencer agora.\n$E sabe de uma coisa? É tudo por sua causa.\n@c{smile_ehalf}Eu não sei se te agradeço ou te odeio.\n$@c{angry_mopen}Prepare-se." - }, - "victory": { - "1": "@c{neutral}O que…@d{64} O que é você?" - }, - "defeat": { - "1": "$@c{smile}Você deveria se orgulhar de até onde chegou." - } - }, - "rival_5": { - "encounter": { - "1": "@c{neutral}…" - }, - "victory": { - "1": "@c{neutral}…" - } - }, - "rival_5_female": { - "encounter": { - "1": "@c{neutral}…" - }, - "victory": { - "1": "@c{neutral}…" - }, - "defeat": { - "1": "$@c{smile_ehalf}…" - } - }, - "rival_6": { - "encounter": { - "1": "@c{smile_eclosed}Nos encontramos de novo.\n$@c{neutral}Tive um tempo para refletir sobre tudo isso.\nHá uma razão para tudo isso parecer tão estranho.\n$@c{neutral_eclosed}Seu sonho, minha vontade de te vencer…\nTudo faz parte de algo maior.\n$@c{serious}Isso não é sobre mim, nem sobre você… É sobre o mundo, @c{serious_mhalf_fists}e é meu propósito te levar ao limite.\n$@c{neutral_eclosed}Se cumpri esse propósito, não posso dizer, mas fiz tudo ao meu alcance.\n$@c{neutral}Este lugar em que acabamos é assustador… Mas de alguma forma me sinto indiferente, como se já tivesse estado aqui antes.\n$@c{serious_mhalf_fists}Você sente o mesmo, não sente?\n$@c{serious}…é como se algo aqui estivesse falando comigo.\nIsso é tudo o que o mundo conhece há muito tempo.\n$Aqueles momentos que apreciamos juntos que parecem tão recentes não passam de uma memória distante.\n$@c{neutral_eclosed}Quem pode dizer se eles foram realmente reais em primeiro lugar.\n$@c{serious_mopen_fists}Você precisa continuar empurrando, porque se não o fizer, isso nunca vai acabar. Você é o único que pode fazer isso.\n$@c{serious_smile_fists}Eu mal sei o que tudo isso significa, só sei que é verdade.\n$@c{serious_mopen_fists}Se você não pode me derrotar aqui e agora, você não terá chance." - }, - "victory": { - "1": "@c{smile_eclosed}Parece que meu trabalho aqui está feito.\n$Quero que você me prometa uma coisa.\n@c{smile}Depois que curar o mundo, por favor, volte para casa." - } - }, - "rival_6_female": { - "encounter": { - "1": "@c{smile_ehalf}Então somos só nós de novo.\n$@c{smile_eclosed}Sabe, continuo pensando nisso…\n$@c{smile_ehalf}Há algo nisso tudo, por que tudo parece tão estranho agora…\n$@c{smile}Você tem seu sonho, e eu tenho essa ambição em mim…\n$Não consigo evitar sentir que há um propósito maior em tudo isso, no que estamos fazendo, você e eu.\n$@c{smile_eclosed}Acho que devo te levar ao limite.\n$@c{smile_ehalf}Não tenho certeza se estou fazendo um bom trabalho nisso, mas tentei meu melhor até agora.\n$Há algo neste lugar estranho e terrível… Tudo parece tão claro…\n$Isso… é tudo o que o mundo conhece há muito tempo.\n$@c{smile_eclosed}É como se eu mal pudesse lembrar das memórias que apreciamos juntos.\n$@c{smile_ehalf}Elas foram reais? Elas parecem tão distantes agora…\n$@c{angry_mopen}Você precisa continuar empurrando, porque se não o fizer, isso nunca vai acabar. Você é o único que pode fazer isso.\n$@c{smile_ehalf}Eu… não sei o que tudo isso significa… mas sinto que é verdade.\n$@c{neutral}Se você não pode me derrotar aqui e agora, você não terá chance." - }, - "victory": { - "1": "@c{smile_ehalf}Eu… acho que cumpri meu propósito…\n$@c{smile_eclosed}Prometa-me… Depois que curar o mundo… Por favor… volte para casa.\n$@c{smile_ehalf}…Obrigada." - } - } -} diff --git a/src/locales/pt_BR/egg.json b/src/locales/pt_BR/egg.json deleted file mode 100644 index a14217858b5..00000000000 --- a/src/locales/pt_BR/egg.json +++ /dev/null @@ -1,26 +0,0 @@ -{ - "egg": "Ovo", - "greatTier": "Raro", - "ultraTier": "Épico", - "masterTier": "Lendário", - "defaultTier": "Comum", - "hatchWavesMessageSoon": "Barulhos podem ser ouvidos vindo de dentro! Vai chocar em breve!", - "hatchWavesMessageClose": "Parece se mover ocasionalmente. Pode estar perto de chocar.", - "hatchWavesMessageNotClose": "O que vai nascer disso? Não parece estar perto de chocar.", - "hatchWavesMessageLongTime": "Parece que este ovo vai demorar bastante para chocar.", - "gachaTypeLegendary": "Chance de Lendário Aumentada", - "gachaTypeMove": "Chance de Movimento de Ovo Raro Aumentada", - "gachaTypeShiny": "Chance de Shiny Aumentada", - "selectMachine": "Escolha uma máquina.", - "notEnoughVouchers": "Você não tem vouchers suficientes!", - "tooManyEggs": "Você já tem muitos ovos!", - "pull": "Prêmio", - "pulls": "Prêmios", - "sameSpeciesEgg": "{{species}} vai rachar desse ovo!", - "hatchFromTheEgg": "{{pokemonName}} nasceu do ovo!", - "eggMoveUnlock": "Movimento de Ovo desbloqueado: {{moveName}}", - "rareEggMoveUnlock": "Movimento Raro de Ovo desbloqueado: {{moveName}}", - "moveUPGacha": "Movimento\nde Ovo Bônus!", - "shinyUPGacha": "Shiny Bônus!", - "legendaryUPGacha": "Bônus!" -} \ No newline at end of file diff --git a/src/locales/pt_BR/fight-ui-handler.json b/src/locales/pt_BR/fight-ui-handler.json deleted file mode 100644 index 8fc41f523eb..00000000000 --- a/src/locales/pt_BR/fight-ui-handler.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "pp": "PP", - "power": "Poder", - "accuracy": "Precisão", - "abilityFlyInText": " {{passive}}{{pokemonName}}\n{{abilityName}}", - "passive": "Passiva de ", - "teraHover": "Terastalizado {{type}}" -} diff --git a/src/locales/pt_BR/filter-bar.json b/src/locales/pt_BR/filter-bar.json deleted file mode 100644 index 05898796d9f..00000000000 --- a/src/locales/pt_BR/filter-bar.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "genFilter": "Ger.", - "typeFilter": "Tipo", - "caughtFilter": "Capturado", - "unlocksFilter": "Desbloqueios", - "miscFilter": "Outros", - "sortFilter": "Ordem", - "all": "Tudo", - "normal": "Normal", - "uncaught": "Não Capturado", - "passive": "Passiva", - "passiveUnlocked": "Passiva Desbloqueada", - "passiveLocked": "Passiva Bloqueada", - "passiveUnlockable": "Passiva - Pode Desbloquear", - "costReduction": "Redução de Custo", - "costReductionUnlocked": "Redução de Custo Desbloq.", - "costReductionLocked": "Redução de Custo Bloqueada", - "costReductionUnlockable": "Redução de Custo Disponível", - "favorite": "Favoritos", - "isFavorite": "Favoritos - Sim", - "notFavorite": "Favoritos - Não", - "ribbon": "Fita", - "hasWon": "Fita - Sim", - "hasNotWon": "Fita - Não", - "hiddenAbility": "Habilidade Oculta", - "hasHiddenAbility": "Habilidade Oculta - Sim", - "noHiddenAbility": "Habilidade Oculta - Não", - "egg": "Ovo", - "eggPurchasable": "Ovo Comprável", - "pokerus": "Pokérus", - "hasPokerus": "Pokérus - Sim", - "noPokerus": "Pokérus - Não", - "sortByNumber": "Número", - "sortByCost": "Custo", - "sortByCandies": "# Doces", - "sortByIVs": "IVs", - "sortByName": "Nome" -} \ No newline at end of file diff --git a/src/locales/pt_BR/game-mode.json b/src/locales/pt_BR/game-mode.json deleted file mode 100644 index 9aa0f286959..00000000000 --- a/src/locales/pt_BR/game-mode.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "classic": "Clássico", - "endless": "Infinito", - "endlessSpliced": "Infinito (Fusões)", - "dailyRun": "Desafio Diário", - "unknown": "Desconhecido", - "challenge": "Desafio" -} \ No newline at end of file diff --git a/src/locales/pt_BR/game-stats-ui-handler.json b/src/locales/pt_BR/game-stats-ui-handler.json deleted file mode 100644 index eb36f484cc3..00000000000 --- a/src/locales/pt_BR/game-stats-ui-handler.json +++ /dev/null @@ -1,42 +0,0 @@ -{ - "stats": "Estatísticas", - "playTime": "Tempo de Jogo", - "totalBattles": "Total de Batalhas", - "starters": "Iniciais", - "shinyStarters": "Iniciais Shiny", - "speciesSeen": "Espécies Vistas", - "speciesCaught": "Capturadas", - "ribbonsOwned": "Fitas Obtidas", - "classicRuns": "Jogos Clássicos", - "classicWins": "Vitórias Clássicas", - "dailyRunAttempts": "Jogos de Desafio Diário", - "dailyRunWins": "Vitórias de Desafio Diário", - "endlessRuns": "Jogos Infinitos", - "highestWaveEndless": "Maior Onda (Infinito)", - "highestMoney": "Maior Dinheiro", - "highestDamage": "Maior Dano", - "highestHPHealed": "Maior PS Curado", - "pokemonEncountered": "Pokémon Encontrados", - "pokemonDefeated": "Pokémon Derrotados", - "pokemonCaught": "Pokémon Capturados", - "eggsHatched": "Ovos Chocados", - "subLegendsSeen": "Sub-Lendários Vistos", - "subLegendsCaught": "Sub-Lend. Capturados", - "subLegendsHatched": "Sub-Lendários Chocados", - "legendsSeen": "Lendários Vistos", - "legendsCaught": "Lendários Capturados", - "legendsHatched": "Lendários Chocados", - "mythicalsSeen": "Míticos Vistos", - "mythicalsCaught": "Míticos Capturados", - "mythicalsHatched": "Míticos Chocados", - "shiniesSeen": "Shinies Vistos", - "shiniesCaught": "Shinies Capturados", - "shiniesHatched": "Shinies Chocados", - "pokemonFused": "Pokémon Fundidos", - "trainersDefeated": "Treinadores Derrotados", - "eggsPulled": "Ovos Ganhos", - "rareEggsPulled": "Ovos Raros Ganhos", - "epicEggsPulled": "Ovos Épicos Ganhos", - "legendaryEggsPulled": "Ovos Lendários Ganhos", - "manaphyEggsPulled": "Ovos de Manaphy Ganhos" -} \ No newline at end of file diff --git a/src/locales/pt_BR/growth.json b/src/locales/pt_BR/growth.json deleted file mode 100644 index d9b11dc23c3..00000000000 --- a/src/locales/pt_BR/growth.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "Erratic": "Muito Rápido", - "Fast": "Rápido", - "Medium_Fast": "Meio Rápido", - "Medium_Slow": "Meio Lento", - "Slow": "Lento", - "Fluctuating": "Muito Lento" -} \ No newline at end of file diff --git a/src/locales/pt_BR/menu-ui-handler.json b/src/locales/pt_BR/menu-ui-handler.json deleted file mode 100644 index df654976d68..00000000000 --- a/src/locales/pt_BR/menu-ui-handler.json +++ /dev/null @@ -1,29 +0,0 @@ -{ - "GAME_SETTINGS": "Configurações", - "ACHIEVEMENTS": "Conquistas", - "STATS": "Estatísticas", - "RUN_HISTORY": "Histórico de Jogos", - "EGG_LIST": "Incubadora", - "EGG_GACHA": "Gacha de ovos", - "MANAGE_DATA": "Gerenciar dados", - "COMMUNITY": "Comunidade", - "SAVE_AND_QUIT": "Salvar e sair", - "LOG_OUT": "Logout", - "slot": "Slot {{slotNumber}}", - "importSession": "Importar sessão", - "importSlotSelect": "Selecione um slot para importar.", - "exportSession": "Exportar sessão", - "exportSlotSelect": "Selecione um slot para exportar.", - "importRunHistory": "Importar Histórico de Jogos", - "exportRunHistory": "Exportar Histórico de Jogos", - "importData": "Importar dados", - "exportData": "Exportar dados", - "consentPreferences": "Opções de Privacidade", - "linkDiscord": "Conectar Discord", - "unlinkDiscord": "Desconectar Discord", - "linkGoogle": "Conectar Google", - "unlinkGoogle": "Desconectar Google", - "cancel": "Cancelar", - "losingProgressionWarning": "Você vai perder todo o progresso desde o início da batalha. Confirmar?", - "noEggs": "Você não está chocando nenhum ovo\nno momento!" -} diff --git a/src/locales/pt_BR/menu.json b/src/locales/pt_BR/menu.json deleted file mode 100644 index 415796f91ed..00000000000 --- a/src/locales/pt_BR/menu.json +++ /dev/null @@ -1,55 +0,0 @@ -{ - "cancel": "Cancelar", - "continue": "Continuar", - "dailyRun": "Desafio Diário (Beta)", - "loadGame": "Carregar Jogo", - "newGame": "Novo Jogo", - "settings": "Configurações", - "selectGameMode": "Escolha um modo de jogo.", - "logInOrCreateAccount": "Inicie uma sessão ou crie uma conta para começar. Não é necessário email!", - "username": "Nome de Usuário", - "password": "Senha", - "login": "Iniciar sessão", - "orUse": "Ou use", - "register": "Registrar-se", - "emptyUsername": "Nome de usuário vazio", - "invalidLoginUsername": "Nome de usuário inválido", - "invalidRegisterUsername": "O nome de usuário só pode conter letras, números e sublinhados", - "invalidLoginPassword": "Senha inválida", - "invalidRegisterPassword": "A senha deve ter pelo menos 6 caracteres", - "usernameAlreadyUsed": "Esse nome de usuário já está em uso", - "accountNonExistent": "Esse nome de usuário não existe", - "unmatchingPassword": "Senha incorreta", - "passwordNotMatchingConfirmPassword": "As senhas não coincidem", - "confirmPassword": "Confirmar senha", - "registrationAgeWarning": "Se registrando, você confirma que tem pelo menos 13 anos de idade.", - "backToLogin": "Voltar ao Login", - "failedToLoadSaveData": "Não foi possível carregar os dados de salvamento. Por favor, recarregue a página.\nSe a falha persistir, contate o administrador.", - "sessionSuccess": "Sessão carregada com sucesso.", - "failedToLoadSession": "Não foi possível carregar os dados da sua sessão.\nEles podem estar corrompidos.", - "boyOrGirl": "Você é um menino ou uma menina?", - "evolving": "Quê?\n{{pokemonName}} tá evoluindo!", - "stoppedEvolving": "{{pokemonName}} parou de evoluir.", - "pauseEvolutionsQuestion": "Gostaria de pausar evoluções para {{pokemonName}}?\nEvoluções podem ser religadas na tela de equipe.", - "evolutionsPaused": "Evoluções foram paradas para {{pokemonName}}.", - "evolutionDone": "Parabéns!\nSeu {{pokemonName}} evoluiu para {{evolvedPokemonName}}!", - "dailyRankings": "Classificação Diária", - "weeklyRankings": "Classificação Semanal", - "noRankings": "Sem Classificação", - "positionIcon": "#", - "usernameScoreboard": "Usuário", - "score": "Pontuação", - "wave": "Onda", - "loading": "Carregando…", - "loadingAsset": "Carregando recurso: {{assetName}}", - "playersOnline": "Jogadores Ativos", - "yes": "Sim", - "no": "Não", - "disclaimer": "AVISO", - "disclaimerDescription": "Este jogo é um produto inacabado; ele pode ter problemas de jogabilidade (incluindo possíveis\n perdas de dados salvos), sofrer alterações sem aviso prévio e pode ou não ser atualizado ou concluído.", - "choosePokemon": "Escolha um Pokémon.", - "renamePokemon": "Renomear Pokémon", - "rename": "Renomear", - "nickname": "Apelido", - "errorServerDown": "Opa! Não foi possível conectar-se ao servidor.\n\nVocê pode deixar essa janela aberta,\npois o jogo irá se reconectar automaticamente." -} \ No newline at end of file diff --git a/src/locales/pt_BR/modifier-select-ui-handler.json b/src/locales/pt_BR/modifier-select-ui-handler.json deleted file mode 100644 index 4aef7f145ae..00000000000 --- a/src/locales/pt_BR/modifier-select-ui-handler.json +++ /dev/null @@ -1,12 +0,0 @@ -{ - "transfer": "Alterar", - "reroll": "Atualizar", - "lockRarities": "Travar Raridades", - "checkTeam": "Checar Time", - "transferDesc": "Transfira um item segurado de um Pokémon para outro.", - "rerollDesc": "Gaste dinheiro para atualizar as suas opções de itens.", - "lockRaritiesDesc": "Trava a raridade dos itens na atualização (afeta o custo da atualização).", - "checkTeamDesc": "Cheque seu time ou use um item de mudança de forma.", - "rerollCost": "₽{{formattedMoney}}", - "itemCost": "₽{{formattedMoney}}" -} \ No newline at end of file diff --git a/src/locales/pt_BR/modifier-type.json b/src/locales/pt_BR/modifier-type.json deleted file mode 100644 index f20a4ef3d0f..00000000000 --- a/src/locales/pt_BR/modifier-type.json +++ /dev/null @@ -1,607 +0,0 @@ -{ - "ModifierType": { - "AddPokeballModifierType": { - "name": "{{modifierCount}}x {{pokeballName}}", - "description": "Ganhe {{modifierCount}}x {{pokeballName}} (Mochila: {{pokeballAmount}}) \nChance de captura: {{catchRate}}." - }, - "AddVoucherModifierType": { - "name": "{{modifierCount}}x {{voucherTypeName}}", - "description": "Ganhe {{modifierCount}}x {{voucherTypeName}}." - }, - "PokemonHeldItemModifierType": { - "extra": { - "inoperable": "{{pokemonName}} não pode\nsegurar esse item!", - "tooMany": "{{pokemonName}} tem muitos\nmuitos deste item!" - } - }, - "PokemonHpRestoreModifierType": { - "description": "Restaura {{restorePoints}} PS ou {{restorePercent}}% PS de um Pokémon, o que for maior.", - "extra": { - "fully": "Restaura totalmente os PS de um Pokémon.", - "fullyWithStatus": "Restaura totalmente os PS de um Pokémon e cura qualquer mudança de estado." - } - }, - "PokemonReviveModifierType": { - "description": "Reanima um Pokémon e restaura {{restorePercent}}% PS." - }, - "PokemonStatusHealModifierType": { - "description": "Cura uma mudança de estado de um Pokémon." - }, - "PokemonPpRestoreModifierType": { - "description": "Restaura {{restorePoints}} PP para um movimento de um Pokémon.", - "extra": { - "fully": "Restaura todos os PP para um movimento de um Pokémon." - } - }, - "PokemonAllMovePpRestoreModifierType": { - "description": "Restaura {{restorePoints}} PP para todos os movimentos de um Pokémon.", - "extra": { - "fully": "Restaura todos os PP para todos os movimentos de um Pokémon." - } - }, - "PokemonPpUpModifierType": { - "description": "Aumenta permanentemente os PP para o movimento de um Pokémon em {{upPoints}} para cada 5 PP máximos (máximo 3)." - }, - "PokemonNatureChangeModifierType": { - "name": "Hortelã {{natureName}}", - "description": "Muda a natureza do Pokémon para {{natureName}} e a desbloqueia permanentemente." - }, - "DoubleBattleChanceBoosterModifierType": { - "description": "Quadruplica as chances de encontrar uma batalha em dupla por {{battleCount}} batalhas." - }, - "TempStatStageBoosterModifierType": { - "description": "Aumenta o atributo de {{stat}} para todos os membros da equipe em {{amount}} por 5 batalhas.", - "extra": { - "stage": "um nível", - "percentage": "30%" - } - }, - "AttackTypeBoosterModifierType": { - "description": "Aumenta o poder dos ataques do tipo {{moveType}} de um Pokémon em 20%." - }, - "PokemonLevelIncrementModifierType": { - "description": "Aumenta em {{levels}} o nível de um Pokémon." - }, - "AllPokemonLevelIncrementModifierType": { - "description": "Aumenta em {{levels}} o nível de todos os membros da equipe." - }, - "BaseStatBoosterModifierType": { - "description": "Aumenta o atributo base de {{stat}} em 10%. Quanto maior os IVs, maior o limite de aumento." - }, - "AllPokemonFullHpRestoreModifierType": { - "description": "Restaura totalmente os PS de todos os Pokémon." - }, - "AllPokemonFullReviveModifierType": { - "description": "Reanima todos os Pokémon, restaurando totalmente seus PS." - }, - "MoneyRewardModifierType": { - "description": "Garante uma quantidade {{moneyMultiplier}} de dinheiro (₽{{moneyAmount}}).", - "extra": { - "small": "pequena", - "moderate": "moderada", - "large": "grande" - } - }, - "ExpBoosterModifierType": { - "description": "Aumenta o ganho de pontos de experiência em {{boostPercent}}%." - }, - "PokemonExpBoosterModifierType": { - "description": "Aumenta o ganho de pontos de experiência de quem segura em {{boostPercent}}%." - }, - "PokemonFriendshipBoosterModifierType": { - "description": "Aumenta o ganho de amizade por vitória em 50%." - }, - "PokemonMoveAccuracyBoosterModifierType": { - "description": "Aumenta a precisão dos movimentos em {{accuracyAmount}} (máximo 100)." - }, - "PokemonMultiHitModifierType": { - "description": "Ataques acertam uma vez adicional ao custo de uma redução de poder de 60/75/82.5% por item, respectivamente." - }, - "TmModifierType": { - "name": "TM{{moveId}} - {{moveName}}", - "description": "Ensina {{moveName}} a um Pokémon." - }, - "TmModifierTypeWithInfo": { - "name": "TM{{moveId}} - {{moveName}}", - "description": "Ensina {{moveName}} a um Pokémon\n(Segure C ou Shift para mais informações)." - }, - "EvolutionItemModifierType": { - "description": "Faz certos Pokémon evoluírem." - }, - "FormChangeItemModifierType": { - "description": "Faz certos Pokémon mudarem de forma." - }, - "FusePokemonModifierType": { - "description": "Combina dois Pokémon (transfere Habilidade, divide os atributos base e tipos, compartilha os movimentos)." - }, - "TerastallizeModifierType": { - "name": "Fragmento Tera {{teraType}}", - "description": "Terastalize um Pokémon para o tipo {{teraType}} por 10 ondas." - }, - "ContactHeldItemTransferChanceModifierType": { - "description": "Quando atacar, tem {{chancePercent}}% de chance de roubar um item do oponente." - }, - "TurnHeldItemTransferModifierType": { - "description": "Todo turno, o Pokémon ganha um item aleatório do oponente." - }, - "EnemyAttackStatusEffectChanceModifierType": { - "description": "Ganha {{chancePercent}}% de chance de infligir {{statusEffect}} com ataques." - }, - "EnemyEndureChanceModifierType": { - "description": "Ganha {{chancePercent}}% de chance de sobreviver a um ataque que o faria desmaiar." - }, - "RARE_CANDY": { - "name": "Doce Raro" - }, - "RARER_CANDY": { - "name": "Doce Raríssimo" - }, - "MEGA_BRACELET": { - "name": "Mega Bracelete", - "description": "Mega Pedras ficam disponíveis." - }, - "DYNAMAX_BAND": { - "name": "Bracelete Dynamax", - "description": "Cogumáximos ficam disponíveis." - }, - "TERA_ORB": { - "name": "Orbe Tera", - "description": "Fragmentos Tera ficam disponíveis." - }, - "MAP": { - "name": "Mapa", - "description": "Permite escolher a próxima rota." - }, - "POTION": { - "name": "Poção" - }, - "SUPER_POTION": { - "name": "Super Poção" - }, - "HYPER_POTION": { - "name": "Hiper Poção" - }, - "MAX_POTION": { - "name": "Poção Máxima" - }, - "FULL_RESTORE": { - "name": "Restaurador" - }, - "REVIVE": { - "name": "Reanimador" - }, - "MAX_REVIVE": { - "name": "Reanimador Máximo" - }, - "FULL_HEAL": { - "name": "Cura Total" - }, - "SACRED_ASH": { - "name": "Cinza Sagrada" - }, - "REVIVER_SEED": { - "name": "Semente Reanimadora", - "description": "Após desmaiar por um ataque direto, reanima com 50% de PS." - }, - "WHITE_HERB": { - "name": "Erva Branca", - "description": "Restaura quaisquer atributos diminuídos em batalha." - }, - "ETHER": { - "name": "Éter" - }, - "MAX_ETHER": { - "name": "Éter Máximo" - }, - "ELIXIR": { - "name": "Elixir" - }, - "MAX_ELIXIR": { - "name": "Elixir Máximo" - }, - "PP_UP": { - "name": "Mais PP" - }, - "PP_MAX": { - "name": "PP Máximo" - }, - "LURE": { - "name": "Incenso" - }, - "SUPER_LURE": { - "name": "Super Incenso" - }, - "MAX_LURE": { - "name": "Incenso Máximo" - }, - "MEMORY_MUSHROOM": { - "name": "Cogumemória", - "description": "Relembra um movimento esquecido." - }, - "EXP_SHARE": { - "name": "Compart. de Exp.", - "description": "Distribui pontos de experiência para todos os membros da equipe." - }, - "EXP_BALANCE": { - "name": "Balanceador de Exp.", - "description": "Distribui pontos de experiência principalmente para os Pokémon mais fracos." - }, - "OVAL_CHARM": { - "name": "Amuleto Oval", - "description": "Quando vários Pokémon participam de uma batalha, cada um recebe 10% extra de pontos de experiência." - }, - "EXP_CHARM": { - "name": "Amuleto de Exp." - }, - "SUPER_EXP_CHARM": { - "name": "Super Amuleto de Exp." - }, - "GOLDEN_EXP_CHARM": { - "name": "Amuleto de Exp. Dourado" - }, - "LUCKY_EGG": { - "name": "Ovo da Sorte" - }, - "GOLDEN_EGG": { - "name": "Ovo Dourado" - }, - "SOOTHE_BELL": { - "name": "Guizo" - }, - "SCOPE_LENS": { - "name": "Lentes de Mira", - "description": "Estas lentes facilitam o foco em pontos fracos. Aumenta a chance de acerto crítico de quem a segurar." - }, - "DIRE_HIT": { - "name": "Direto", - "extra": { - "raises": "Chance de Acerto Crítico" - } - }, - "LEEK": { - "name": "Alho-poró", - "description": "Esse talo de alho-poró muito longo e rígido aumenta a taxa de acerto crítico dos movimentos do Farfetch'd." - }, - "EVIOLITE": { - "name": "Eviolita", - "description": "Esse misterioso caroço evolutivo aumenta os atributos de Defesa e Def. Esp. quando segurado por um Pokémon que ainda pode evoluir." - }, - "SOUL_DEW": { - "name": "Joia da Alma", - "description": "Aumenta a influência da natureza de um Pokémon em seus atributos em 10% (cumulativo)." - }, - "NUGGET": { - "name": "Pepita" - }, - "BIG_NUGGET": { - "name": "Pepita Grande" - }, - "RELIC_GOLD": { - "name": "Relíquia de Ouro" - }, - "AMULET_COIN": { - "name": "Moeda Amuleto", - "description": "Aumenta a recompensa de dinheiro em 50%." - }, - "GOLDEN_PUNCH": { - "name": "Soco Dourado", - "description": "Concede 50% do dano causado em dinheiro." - }, - "COIN_CASE": { - "name": "Moedeira", - "description": "Após cada 10ª batalha, recebe 10% de seu dinheiro em juros." - }, - "LOCK_CAPSULE": { - "name": "Cápsula de Travamento", - "description": "Permite que você trave raridades de itens ao rolar novamente." - }, - "GRIP_CLAW": { - "name": "Garra-Aperto" - }, - "WIDE_LENS": { - "name": "Lente Ampla" - }, - "MULTI_LENS": { - "name": "Multi Lentes" - }, - "HEALING_CHARM": { - "name": "Amuleto de Cura", - "description": "Aumenta a eficácia dos movimentos e itens que restauram PS em 10% (exceto Reanimador)." - }, - "CANDY_JAR": { - "name": "Pote de Doces", - "description": "Aumenta o número de níveis adicionados pelo Doce Raro em 1." - }, - "BERRY_POUCH": { - "name": "Bolsa de Berries", - "description": "Adiciona uma chance de 30% de que uma berry usada não seja consumida." - }, - "FOCUS_BAND": { - "name": "Bandana", - "description": "Adiciona uma chance de 10% de sobreviver com 1 PS após ser danificado o suficiente para desmaiar." - }, - "QUICK_CLAW": { - "name": "Garra Rápida", - "description": "Adiciona uma chance de 10% de atacar primeiro, ignorando sua velocidade (após prioridades)." - }, - "KINGS_ROCK": { - "name": "Pedra do Rei", - "description": "Adiciona uma chance de 10% de movimentos fazerem o oponente hesitar." - }, - "LEFTOVERS": { - "name": "Sobras", - "description": "Cura 1/16 dos PS máximos de um Pokémon a cada turno." - }, - "SHELL_BELL": { - "name": "Concha-Sino", - "description": "Cura 1/8 do dano causado por um Pokémon." - }, - "TOXIC_ORB": { - "name": "Esfera Tóxica", - "description": "Uma esfera estranha que exala toxinas quando tocada e envenena seriamente quem a segurar." - }, - "FLAME_ORB": { - "name": "Esfera da Chama", - "description": "Uma esfera estranha que aquece quando tocada e queima quem a segurar." - }, - "BATON": { - "name": "Bastão", - "description": "Permite passar mudanças de atributo ao trocar Pokémon, ignorando armadilhas." - }, - "SHINY_CHARM": { - "name": "Amuleto Brilhante", - "description": "Aumenta drasticamente a chance de um Pokémon selvagem ser Shiny." - }, - "ABILITY_CHARM": { - "name": "Amuleto de Habilidade", - "description": "Aumenta drasticamente a chance de um Pokémon selvagem ter uma Habilidade Oculta." - }, - "IV_SCANNER": { - "name": "Scanner de IVs", - "description": "Permite escanear os IVs de Pokémon selvagens. 2 IVs são revelados por item. Os melhores IVs são mostrados primeiro." - }, - "DNA_SPLICERS": { - "name": "Splicer de DNA" - }, - "MINI_BLACK_HOLE": { - "name": "Mini Buraco Negro" - }, - "GOLDEN_POKEBALL": { - "name": "Poké Bola Dourada", - "description": "Adiciona 1 opção de item extra ao final de cada batalha." - }, - "ENEMY_DAMAGE_BOOSTER": { - "name": "Token de Dano", - "description": "Aumenta o dano em 5%." - }, - "ENEMY_DAMAGE_REDUCTION": { - "name": "Token de Proteção", - "description": "Reduz o dano recebido em 2,5%." - }, - "ENEMY_HEAL": { - "name": "Token de Recuperação", - "description": "Cura 2% dos PS máximos a cada turno." - }, - "ENEMY_ATTACK_POISON_CHANCE": { - "name": "Token de Veneno" - }, - "ENEMY_ATTACK_PARALYZE_CHANCE": { - "name": "Token de Paralisia" - }, - "ENEMY_ATTACK_BURN_CHANCE": { - "name": "Token de Queimadura" - }, - "ENEMY_STATUS_EFFECT_HEAL_CHANCE": { - "name": "Token de Cura Total", - "description": "Adiciona uma chance de 2.5% a cada turno de curar uma condição de status." - }, - "ENEMY_ENDURE_CHANCE": { - "name": "Token de Persistência" - }, - "ENEMY_FUSED_CHANCE": { - "name": "Token de Fusão", - "description": "Adiciona uma chance de 1% de que um Pokémon selvagem seja uma fusão." - } - }, - "SpeciesBoosterItem": { - "LIGHT_BALL": { - "name": "Bola de Luz", - "description": "Orbe intrigante que aumenta os atributos de Ataque e Ataque Esp. de Pikachu." - }, - "THICK_CLUB": { - "name": "Osso Grosso", - "description": "Este duro osso de origem desconhecida aumenta o atributo de Ataque de Cubone ou Marowak." - }, - "METAL_POWDER": { - "name": "Pó Metálico", - "description": "Extremamente fino, porém duro, este pó estranho aumenta o atributo de Defesa de Ditto." - }, - "QUICK_POWDER": { - "name": "Pó Veloz", - "description": "Extremamente fino, porém duro, este pó estranho aumenta o atributo de Velocidade de Ditto." - } - }, - "TempStatStageBoosterItem": { - "x_attack": "Ataque X", - "x_defense": "Defesa X", - "x_sp_atk": "Ataque Esp. X", - "x_sp_def": "Defesa Esp. X", - "x_speed": "Velocidade X", - "x_accuracy": "Precisão X" - }, - "AttackTypeBoosterItem": { - "silk_scarf": "Lenço de Seda", - "black_belt": "Faixa Preta", - "sharp_beak": "Bico Afiado", - "poison_barb": "Farpa Venenosa", - "soft_sand": "Areia Macia", - "hard_stone": "Pedra Dura", - "silver_powder": "Pó de Prata", - "spell_tag": "Talismã de Feitiço", - "metal_coat": "Revestimento Metálico", - "charcoal": "Carvão", - "mystic_water": "Água Mística", - "miracle_seed": "Semente Milagrosa", - "magnet": "Ímã", - "twisted_spoon": "Colher Torcida", - "never_melt_ice": "Gelo Eterno", - "dragon_fang": "Presa de Dragão", - "black_glasses": "Óculos Escuros", - "fairy_feather": "Pena de Fada" - }, - "BaseStatBoosterItem": { - "hp_up": "Mais PS", - "protein": "Proteína", - "iron": "Ferro", - "calcium": "Cálcio", - "zinc": "Zinco", - "carbos": "Carboidrato" - }, - "EvolutionItem": { - "NONE": "None", - "LINKING_CORD": "Cabo de Conexão", - "SUN_STONE": "Pedra do Sol", - "MOON_STONE": "Pedra da Lua", - "LEAF_STONE": "Pedra da Folha", - "FIRE_STONE": "Pedra do Fogo", - "WATER_STONE": "Pedra da Água", - "THUNDER_STONE": "Pedra do Trovão", - "ICE_STONE": "Pedra do Gelo", - "DUSK_STONE": "Pedra do Crepúsculo", - "DAWN_STONE": "Pedra da Alvorada", - "SHINY_STONE": "Pedra Brilhante", - "CRACKED_POT": "Vaso Quebrado", - "SWEET_APPLE": "Maçã Doce", - "TART_APPLE": "Maçã Azeda", - "STRAWBERRY_SWEET": "Doce de Morango", - "UNREMARKABLE_TEACUP": "Xícara Comum", - "CHIPPED_POT": "Pote Lascado", - "BLACK_AUGURITE": "Mineral Negro", - "GALARICA_CUFF": "Bracelete de Galar", - "GALARICA_WREATH": "Coroa de Galar", - "PEAT_BLOCK": "Bloco de Turfa", - "AUSPICIOUS_ARMOR": "Armadura Prometida", - "MALICIOUS_ARMOR": "Armadura Maldita", - "MASTERPIECE_TEACUP": "Xícara Excepcional", - "METAL_ALLOY": "Liga de Metal", - "SCROLL_OF_DARKNESS": "Pergaminho da Escuridão", - "SCROLL_OF_WATERS": "Pergaminho da Água", - "SYRUPY_APPLE": "Xarope de Maçã" - }, - "FormChangeItem": { - "NONE": "None", - "ABOMASITE": "Abomasita", - "ABSOLITE": "Absolita", - "AERODACTYLITE": "Aerodactylita", - "AGGRONITE": "Aggronita", - "ALAKAZITE": "Alakazita", - "ALTARIANITE": "Altarianita", - "AMPHAROSITE": "Ampharosita", - "AUDINITE": "Audinita", - "BANETTITE": "Banettita", - "BEEDRILLITE": "Beedrillita", - "BLASTOISINITE": "Blastoisinita", - "BLAZIKENITE": "Blazikenita", - "CAMERUPTITE": "Cameruptita", - "CHARIZARDITE_X": "Charizardita X", - "CHARIZARDITE_Y": "Charizardita Y", - "DIANCITE": "Diancita", - "GALLADITE": "Galladita", - "GARCHOMPITE": "Garchompita", - "GARDEVOIRITE": "Gardevoirita", - "GENGARITE": "Gengarita", - "GLALITITE": "Glalitita", - "GYARADOSITE": "Gyaradosita", - "HERACRONITE": "Heracronita", - "HOUNDOOMINITE": "Houndoominita", - "KANGASKHANITE": "Kangaskhanita", - "LATIASITE": "Latiasita", - "LATIOSITE": "Latiosita", - "LOPUNNITE": "Lopunnita", - "LUCARIONITE": "Lucarionita", - "MANECTITE": "Manectita", - "MAWILITE": "Mawilita", - "MEDICHAMITE": "Medichamita", - "METAGROSSITE": "Metagrossita", - "MEWTWONITE_X": "Mewtwonita X", - "MEWTWONITE_Y": "Mewtwonita Y", - "PIDGEOTITE": "Pidgeotita", - "PINSIRITE": "Pinsirita", - "RAYQUAZITE": "Rayquazita", - "SABLENITE": "Sablenita", - "SALAMENCITE": "Salamencita", - "SCEPTILITE": "Sceptilita", - "SCIZORITE": "Scizorita", - "SHARPEDONITE": "Sharpedonita", - "SLOWBRONITE": "Slowbronita", - "STEELIXITE": "Steelixita", - "SWAMPERTITE": "Swampertita", - "TYRANITARITE": "Tyranitarita", - "VENUSAURITE": "Venusaurita", - "BLUE_ORB": "Orbe Azul", - "RED_ORB": "Orbe Vermelha", - "SHARP_METEORITE": "Meteorito Afiado", - "HARD_METEORITE": "Meteorito Duro", - "SMOOTH_METEORITE": " Meteorito Liso", - "ADAMANT_CRYSTAL": "Cristal Adamante", - "LUSTROUS_GLOBE": "Globo Brilhante", - "GRISEOUS_CORE": "Núcleo Platinado", - "REVEAL_GLASS": "Espelho da Verdade", - "GRACIDEA": "Gracídea", - "MAX_MUSHROOMS": "Cogumáximo", - "DARK_STONE": "Pedra das Trevas", - "LIGHT_STONE": "Pedra da Luz", - "PRISON_BOTTLE": "Garrafa Prisão", - "N_LUNARIZER": "Lunarizador N", - "N_SOLARIZER": "Solarizador N", - "RUSTED_SWORD": "Espada Enferrujada", - "RUSTED_SHIELD": "Escudo Enferrujado", - "ICY_REINS_OF_UNITY": "Rédeas de Gelo da União", - "SHADOW_REINS_OF_UNITY": "Rédeas Sombrias da União", - "WELLSPRING_MASK": "Máscara Nascente", - "HEARTHFLAME_MASK": "Máscara Fornalha", - "CORNERSTONE_MASK": "Máscara Alicerce", - "SHOCK_DRIVE": "MagneDisco", - "BURN_DRIVE": "IgneDisco", - "CHILL_DRIVE": "CrioDisco", - "DOUSE_DRIVE": "HidroDisco", - "ULTRANECROZIUM_Z": "Ultranecrozium Z", - "FIST_PLATE": "Placa do Punho", - "SKY_PLATE": "Placa do Céu", - "TOXIC_PLATE": "Placa Tóxica", - "EARTH_PLATE": "Placa Terrestre", - "STONE_PLATE": "Placa de Pedra", - "INSECT_PLATE": "Placa de Insetos", - "SPOOKY_PLATE": "Placa Assustadora", - "IRON_PLATE": "Placa de Ferro", - "FLAME_PLATE": "Placa da Chama", - "SPLASH_PLATE": "Placa de Respingo", - "MEADOW_PLATE": "Placa da Planície", - "ZAP_PLATE": "Placa Elétrica", - "MIND_PLATE": "Placa Mental", - "ICICLE_PLATE": "Placa de Gelo", - "DRACO_PLATE": "Placa do Dragão", - "DREAD_PLATE": "Placa Sombria", - "PIXIE_PLATE": "Placa de Fada", - "BLANK_PLATE": "Placa em Branco", - "LEGEND_PLATE": "Placa Lendária", - "FIGHTING_MEMORY": "Memória de Lutador", - "FLYING_MEMORY": "Memória Voadora", - "POISON_MEMORY": "Memória Venenosa", - "GROUND_MEMORY": "Memória Terrestre", - "ROCK_MEMORY": "Memória da Rocha", - "BUG_MEMORY": "Memória de Insetos", - "GHOST_MEMORY": "Memória Fantasma", - "STEEL_MEMORY": "Memória de Aço", - "FIRE_MEMORY": "Memória de Fogo", - "WATER_MEMORY": "Memória da Água", - "GRASS_MEMORY": "Memória de Planta", - "ELECTRIC_MEMORY": "Memória Elétrica", - "PSYCHIC_MEMORY": "Memória Psíquica", - "ICE_MEMORY": "Memória de Gelo", - "DRAGON_MEMORY": "Memória do Dragão", - "DARK_MEMORY": "Memória Sombria", - "FAIRY_MEMORY": "Memória de Fada", - "NORMAL_MEMORY": "Memória Normal" - } -} diff --git a/src/locales/pt_BR/modifier.json b/src/locales/pt_BR/modifier.json deleted file mode 100644 index 38622de579e..00000000000 --- a/src/locales/pt_BR/modifier.json +++ /dev/null @@ -1,12 +0,0 @@ -{ - "surviveDamageApply": "{{pokemonNameWithAffix}} aguentou o tranco\nusando sua {{typeName}}!", - "turnHealApply": "{{pokemonNameWithAffix}} restaurou um pouco de PS usando\nsuas {{typeName}}!", - "hitHealApply": "{{pokemonNameWithAffix}} restaurou um pouco de PS usando\nsua {{typeName}}!", - "pokemonInstantReviveApply": "{{pokemonNameWithAffix}} foi reanimado\npor sua {{typeName}}!", - "resetNegativeStatStageApply": "Os atributos diminuídos de {{pokemonNameWithAffix}} foram\nrestaurados por seu(sua) {{typeName}}!", - "moneyInterestApply": "Você recebeu um juros de ₽{{moneyAmount}}\nde sua {{typeName}}!", - "turnHeldItemTransferApply": "{{itemName}} de {{pokemonNameWithAffix}} foi absorvido(a)\npelo {{typeName}} de {{pokemonName}}!", - "contactHeldItemTransferApply": "{{itemName}} de {{pokemonNameWithAffix}} foi pego(a)\npela {{typeName}} de {{pokemonName}}!", - "enemyTurnHealApply": "{{pokemonNameWithAffix}}\nrestaurou um pouco de seus PS!", - "bypassSpeedChanceApply": "{{pokemonName}} se move mais rápido que o normal graças à sua {{itemName}}!" -} \ No newline at end of file diff --git a/src/locales/pt_BR/move-trigger.json b/src/locales/pt_BR/move-trigger.json deleted file mode 100644 index 4549f83cdf1..00000000000 --- a/src/locales/pt_BR/move-trigger.json +++ /dev/null @@ -1,67 +0,0 @@ -{ - "hitWithRecoil": "{{pokemonName}} foi ferido pelo dano reverso!", - "cutHpPowerUpMove": "{{pokemonName}} diminuiu seus PS para aumentar o poder do ataque!", - "absorbedElectricity": "{{pokemonName}} absorveu eletricidade!", - "switchedStatChanges": "{{pokemonName}} trocou as mudanças de atributo com o alvo!", - "goingAllOutForAttack": "{{pokemonName}} está arriscando tudo nesse ataque!", - "regainedHealth": "{{pokemonName}} recuperou/nsaúde!", - "keptGoingAndCrashed": "{{pokemonName}} errou o alvo/ne se arrebentou!", - "fled": "{{pokemonName}} fugiu!", - "cannotBeSwitchedOut": "{{pokemonName}} não pode ser trocado!", - "swappedAbilitiesWithTarget": "{{pokemonName}} trocou/nde habilidades com o alvo!", - "coinsScatteredEverywhere": "Moedas foram espalhadas por toda parte!", - "attackedByItem": "{{pokemonName}} está prestes a ser atacado por {{itemName}}!", - "whippedUpAWhirlwind": "{{pokemonName}} criou\num redemoinho de vento!", - "flewUpHigh": "{{pokemonName}} voou\nbem alto!", - "tookInSunlight": "{{pokemonName}} absorveu a luz do sol!", - "dugAHole": "{{pokemonName}} cavou um buraco no chão!", - "loweredItsHead": "{{pokemonName}} abaixou sua cabeça!", - "isGlowing": "{{pokemonName}} ficou envolto em uma luz forte!", - "bellChimed": "Um sino tocou!", - "foresawAnAttack": "{{pokemonName}} previu/num ataque!", - "isTighteningFocus": "{{pokemonName}} está\naumentando seu foco!", - "hidUnderwater": "{{pokemonName}} se escondeu/nembaixo d'água!", - "soothingAromaWaftedThroughArea": "Um aroma suave se espalhou pelo ambiente!", - "sprangUp": "{{pokemonName}} se levantou!", - "choseDoomDesireAsDestiny": "{{pokemonName}} escolheu\no Desejo da Perdição como seu destino!", - "vanishedInstantly": "{{pokemonName}} desapareceu\nde repente!", - "tookTargetIntoSky": "{{pokemonName}} levou {{targetName}}\npara o céu!", - "becameCloakedInFreezingLight": "{{pokemonName}} ficou envolto/nem uma luz congelante!", - "becameCloakedInFreezingAir": "{{pokemonName}} ficou envolto/nem ar congelante!", - "isChargingPower": "{{pokemonName}} está absorvendo energia!", - "burnedItselfOut": "{{pokemonName}} apagou seu próprio fogo!", - "startedHeatingUpBeak": "{{pokemonName}} começou\na esquentar seu bico!", - "setUpShellTrap": "{{pokemonName}} armou uma armadilha de carapaça!", - "isOverflowingWithSpacePower": "{{pokemonName}} está sobrecarregado\ncom energia espacial!", - "usedUpAllElectricity": "{{pokemonName}} usou toda a sua eletricidade!", - "stoleItem": "{{pokemonName}} roubou/no(a) {{itemName}} de {{targetName}}!", - "incineratedItem": "{{pokemonName}} incinerou\na {{itemName}} de {{targetName}}!", - "knockedOffItem": "{{pokemonName}} derrubou\no(a) {{itemName}} de {{targetName}}!", - "tookMoveAttack": "{{pokemonName}} pegou\no movimento {{moveName}}!", - "cutOwnHpAndMaximizedStat": "{{pokemonName}} reduziu seus PS\ne maximizou seu atributo de {{statName}}!", - "copiedStatChanges": "{{pokemonName}} copiou\nas mudanças de atributo de {{targetName}}!", - "magnitudeMessage": "Magnitude {{magnitude}}!", - "tookAimAtTarget": "{{pokemonName}} mirou\nem {{targetName}}!", - "transformedIntoType": "{{pokemonName}} se transformou\nem tipo {{typeName}}!", - "copiedMove": "{{pokemonName}} copiou\no movimento {{moveName}}!", - "sketchedMove": "{{pokemonName}} desenhou\no movimento {{moveName}}!", - "acquiredAbility": "{{pokemonName}} adquiriu\na habilidade {{abilityName}}!", - "copiedTargetAbility": "{{pokemonName}} copiou a habilidade\nde {{targetName}}!", - "transformedIntoTarget": "{{pokemonName}} se transformou\nem um(a) {{targetName}}!", - "tryingToTakeFoeDown": "{{pokemonName}} está tentando derrubar o atacante com ele!", - "addType": "{{pokemonName}} recebeu\no tipo {{typeName}}!", - "cannotUseMove": "{{pokemonName}} não pode usar {{moveName}}!", - "healHp": "{{pokemonName}} teve seus PS recuperados.", - "sacrificialFullRestore": "O Healing Wish de {{pokemonName}}\nfoi concedido!", - "invertStats": "As mudanças de atributo de {{pokemonName}}\nforam revertidas!", - "resetStats": "As mudanças de atributo de {{pokemonName}}\nforam eliminadas!", - "statEliminated": "Todas as mudanças de atributo foram eliminadas!", - "faintCountdown": "{{pokemonName}}\nirá desmaiar em {{turnCount}} turnos.", - "copyType": "O tipo de {{pokemonName}}\nmudou para combinar com {{targetPokemonName}}!", - "suppressAbilities": "A habilidade de {{pokemonName}}\nfoi suprimida!", - "revivalBlessing": "{{pokemonName}} foi reanimado!", - "swapArenaTags": "{{pokemonName}} trocou os efeitos de batalha que afetam cada lado do campo!", - "exposedMove": "{{pokemonName}} identificou\n{{targetPokemonName}}!", - "safeguard": "{{targetName}} está protegido por Safeguard!", - "afterYou": "{{pokemonName}} aceitou a gentil oferta!" -} diff --git a/src/locales/pt_BR/move.json b/src/locales/pt_BR/move.json deleted file mode 100644 index c463665f1ad..00000000000 --- a/src/locales/pt_BR/move.json +++ /dev/null @@ -1,3810 +0,0 @@ -{ - "pound": { - "name": "Pound", - "effect": "O alvo é golpeado com uma pata, uma cauda longa, ou com algo desse tipo." - }, - "karateChop": { - "name": "Karate Chop", - "effect": "O alvo é atacado com um golpe cortante. Golpes críticos ocorrem mais facilmente." - }, - "doubleSlap": { - "name": "Double Slap", - "effect": "O alvo é estapeado repetidamente, de duas a cinco vezes seguidas." - }, - "cometPunch": { - "name": "Comet Punch", - "effect": "O alvo é atingido com uma sequência de socos que acertam de duas a cinco vezes seguidas." - }, - "megaPunch": { - "name": "Mega Punch", - "effect": "O alvo é atingido por um soco desferido com grande força muscular." - }, - "payDay": { - "name": "Pay Day", - "effect": "Várias moedas são lançadas no alvo para causar dano. O Treinador recebe o dinheiro após a batalha." - }, - "firePunch": { - "name": "Fire Punch", - "effect": "O alvo é atingido por um punho flamejante. Isso pode deixar o alvo queimado." - }, - "icePunch": { - "name": "Ice Punch", - "effect": "O alvo é atingido por um punho gelado. Isso pode deixar o alvo congelado." - }, - "thunderPunch": { - "name": "Thunder Punch", - "effect": "O alvo é atingido por um punho eletrificado. Isso também pode deixar o alvo paralisado." - }, - "scratch": { - "name": "Scratch", - "effect": "Garras duras, pontiagudas e afiadas rasgam o alvo para causar dano." - }, - "viseGrip": { - "name": "Vise Grip", - "effect": "O alvo é agarrado e espremido de ambos os lados para causar dano." - }, - "guillotine": { - "name": "Guillotine", - "effect": "Um ataque violento e destruidor com grandes pinças. Se o golpe acertar, o alvo desmaiará instantaneamente." - }, - "razorWind": { - "name": "Razor Wind", - "effect": "Neste ataque de dois turnos, lâminas de vento golpeiam Pokémon adversários no segundo turno. Golpes críticos ocorrem mais facilmente." - }, - "swordsDance": { - "name": "Swords Dance", - "effect": "Uma dança frenética para elevar o espírito de luta. Aumenta bruscamente o Ataque do usuário." - }, - "cut": { - "name": "Cut", - "effect": "O alvo é cortado com uma foice ou garra." - }, - "gust": { - "name": "Gust", - "effect": "Uma rajada de vento é levantada por asas e lançada no alvo para causar dano." - }, - "wingAttack": { - "name": "Wing Attack", - "effect": "O alvo é atingido por asas grandes e imponentes, amplamente abertas para causar dano." - }, - "whirlwind": { - "name": "Whirlwind", - "effect": "O alvo é soprado para fora da batalha, dando lugar a outro Pokémon. Em batalhas selvagens, a batalha termina caso seja contra um único Pokémon." - }, - "fly": { - "name": "Fly", - "effect": "O usuário levanta vôo e ataca o alvo no próximo turno." - }, - "bind": { - "name": "Bind", - "effect": "Um longo corpo ou tentáculos são utilizados para prender o alvo e espremê-lo por quatro ou cinco turnos." - }, - "slam": { - "name": "Slam", - "effect": "O alvo é atingido com uma longa cauda, vinhas ou algo parecido para infligir dano." - }, - "vineWhip": { - "name": "Vine Whip", - "effect": "O usuário utiliza-se de vinhas finas como chicote para infligir dano." - }, - "stomp": { - "name": "Stomp", - "effect": "O alvo é pisoteado por um grande pé. Isso também pode fazer o alvo hesitar." - }, - "doubleKick": { - "name": "Double Kick", - "effect": "O alvo é atingido rapidamente com um chute duas vezes seguidas usando ambos os pés." - }, - "megaKick": { - "name": "Mega Kick", - "effect": "O alvo é atingido por um chute desferido com grande força muscular." - }, - "jumpKick": { - "name": "Jump Kick", - "effect": "O usuário pula alto, depois golpeia com um chute. Se o chute erra, o usuário se fere." - }, - "rollingKick": { - "name": "Rolling Kick", - "effect": "O usuário desfere um rápido chute giratório. Isso também pode fazer o alvo hesitar." - }, - "sandAttack": { - "name": "Sand Attack", - "effect": "Areia é lançada no rosto do alvo, reduzindo sua Precisão." - }, - "headbutt": { - "name": "Headbutt", - "effect": "O usuário direciona sua cabeça e ataca, avançando diretamente sobre o alvo. Isso também pode fazer o alvo hesitar." - }, - "hornAttack": { - "name": "Horn Attack", - "effect": "O alvo é perfurado por um chifre pontudo e afiado para infligir dano." - }, - "furyAttack": { - "name": "Fury Attack", - "effect": "O alvo é perfurado repetidamente por um chifre ou bico, de duas a cinco vezes seguidas." - }, - "hornDrill": { - "name": "Horn Drill", - "effect": "O usuário perfura o alvo com um chifre que gira como uma broca. Se o golpe acertar, o alvo desmaia instantaneamente." - }, - "tackle": { - "name": "Tackle", - "effect": "Um ataque físico cujo o usuário vai para cima do alvo e lhe atinge com todo o seu corpo." - }, - "bodySlam": { - "name": "Body Slam", - "effect": "O usuário se lança para cima do alvo com todo o peso de seu corpo. Isso pode deixar o alvo paralisado." - }, - "wrap": { - "name": "Wrap", - "effect": "Um longo corpo, vinhas ou algo assim, são usados para embrulhar e apertar o alvo por quatro ou cinco turnos." - }, - "takeDown": { - "name": "Take Down", - "effect": "Uma investida corporal imprudente para golpear o alvo. Isso também fere um pouco o usuário." - }, - "thrash": { - "name": "Thrash", - "effect": "O usuário fica furioso e ataca com violência de dois a três turnos. O usuário então se torna confuso." - }, - "doubleEdge": { - "name": "Double-Edge", - "effect": "Uma investida imprudente e muito perigosa. Isso também fere bastante o usuário." - }, - "tailWhip": { - "name": "Tail Whip", - "effect": "O usuário balança sua cauda de maneira fofa, baixando a guarda do Pokémon adversário e diminuindo sua Defesa." - }, - "poisonSting": { - "name": "Poison Sting", - "effect": "O usuário perfura o alvo com um ferrão venenoso. Isso também pode envenenar o alvo." - }, - "twineedle": { - "name": "Twineedle", - "effect": "O usuário causa dano duas vezes seguidas, perfurando o alvo com dois ferrões. Isso também pode envenenar o alvo." - }, - "pinMissile": { - "name": "Pin Missile", - "effect": "Espinhos afiados são lançados no alvo em rápida sucessão. Eles acertam de duas a cinco vezes seguidas." - }, - "leer": { - "name": "Leer", - "effect": "O usuário lança um olhar intimidador no Pokémon oponente, reduzindo sua Defesa." - }, - "bite": { - "name": "Bite", - "effect": "O alvo é mordido ferozmente com presas afiadas. Isso também pode fazer o alvo hesitar." - }, - "growl": { - "name": "Growl", - "effect": "O usuário rosna de maneira agradável, baixando a guarda do Pokémon adversário. Isso diminui o Ataque do oponente." - }, - "roar": { - "name": "Roar", - "effect": "O alvo se assusta, retorna para a sua Poké Bola e um outro Pokémon toma o seu lugar. O combate é encerrado contra um único Pokémon selvagem." - }, - "sing": { - "name": "Sing", - "effect": "Uma suave canção de ninar é cantada com uma voz calma, colocando o alvo em sono profundo." - }, - "supersonic": { - "name": "Supersonic", - "effect": "O usuário gera estranhas ondas sonoras de seu corpo que confundem o alvo." - }, - "sonicBoom": { - "name": "Sonic Boom", - "effect": "O alvo é atingido com uma onda de choque destrutiva que sempre causa dano de 20 PS." - }, - "disable": { - "name": "Disable", - "effect": "Por quatro turnos, este movimento impede que o alvo utilize o último movimento usado por ele." - }, - "acid": { - "name": "Acid", - "effect": "Os Pokémon adversários são atacados com um jato de um forte ácido. Isso pode diminuir a Defesa Especial." - }, - "ember": { - "name": "Ember", - "effect": "O alvo é atacado com pequenas chamas. Também pode deixar o alvo com uma queimadura." - }, - "flamethrower": { - "name": "Flamethrower", - "effect": "O usuário queima o alvo com uma grande explosão de fogo. Também pode deixar o alvo com uma queimadura." - }, - "mist": { - "name": "Mist", - "effect": "O usuário esconde a si mesmo e seus aliados em uma neblina branca que impede que seus atributos sejam reduzidos por cinco turnos." - }, - "waterGun": { - "name": "Water Gun", - "effect": "O alvo é atingido por um disparo forte de água." - }, - "hydroPump": { - "name": "Hydro Pump", - "effect": "O alvo é atingido por um enorme volume de água lançado sob uma forte pressão." - }, - "surf": { - "name": "Surf", - "effect": "O usuário ataca tudo ao seu redor, inundando os arredores com uma onda gigante." - }, - "iceBeam": { - "name": "Ice Beam", - "effect": "O alvo é atingido por um raio de energia congelante. Isso também pode deixar o alvo congelado." - }, - "blizzard": { - "name": "Blizzard", - "effect": "Uma enorme nevasca é invocada para atacar o Pokémon oponente. Também pode deixar o alvo congelado." - }, - "psybeam": { - "name": "Psybeam", - "effect": "O alvo é atacado por um feixe peculiar. Isso também pode deixar o alvo confuso." - }, - "bubbleBeam": { - "name": "Bubble Beam", - "effect": "Um jato de bolhas é borrifado com intensidade no alvo. Isso também pode diminuir a Velocidade do alvo." - }, - "auroraBeam": { - "name": "Aurora Beam", - "effect": "O alvo é atingido por um raio colorido como o arco-íris. Isso também pode diminuir o Ataque do alvo." - }, - "hyperBeam": { - "name": "Hyper Beam", - "effect": "O alvo é atingido por um raio poderoso. O usuário não poderá se mover no próximo turno." - }, - "peck": { - "name": "Peck", - "effect": "O alvo é atingido por um bico ou chifre pontudo." - }, - "drillPeck": { - "name": "Drill Peck", - "effect": "Um ataque giratório com um bico afiado que age como uma broca." - }, - "submission": { - "name": "Submission", - "effect": "O usuário agarra o alvo e, imprudentemente, mergulha em direção ao chão. Isso também fere um pouco o usuário." - }, - "lowKick": { - "name": "Low Kick", - "effect": "Um poderoso chute baixo que derruba o alvo. Quanto mais pesado o alvo for, maior o poder do movimento." - }, - "counter": { - "name": "Counter", - "effect": "Um movimento de retaliação que neutraliza qualquer ataque físico, causando o dobro do dano recebido." - }, - "seismicToss": { - "name": "Seismic Toss", - "effect": "O alvo é lançado usando o poder da gravidade. Isso causa dano igual ao nível do usuário." - }, - "strength": { - "name": "Strength", - "effect": "O alvo é atingido por um soco dado com o máximo de força." - }, - "absorb": { - "name": "Absorb", - "effect": "Um ataque que drena nutrientes. O usuário recupera PS pela metade do dano infligido ao alvo." - }, - "megaDrain": { - "name": "Mega Drain", - "effect": "Um ataque que drena nutrientes. O usuário recupera PS pela metade do dano infligido ao alvo." - }, - "leechSeed": { - "name": "Leech Seed", - "effect": "Uma semente é plantada no alvo. Isso rouba alguns pontos de PS do alvo a cada turno." - }, - "growth": { - "name": "Growth", - "effect": "O corpo do usuário cresce de uma vez só, aumentando seu Ataque e Ataque Especial." - }, - "razorLeaf": { - "name": "Razor Leaf", - "effect": "Folhas superafiadas são lançadas para cortar os Pokémon adversários. Golpes críticos ocorrem mais facilmente." - }, - "solarBeam": { - "name": "Solar Beam", - "effect": "Neste ataque de dois turnos, o usuário absorve luz, então dispara um raio focalizado no próximo turno." - }, - "poisonPowder": { - "name": "Poison Powder", - "effect": "O usuário espalha uma nuvem de poeira tóxica que envenena o alvo." - }, - "stunSpore": { - "name": "Stun Spore", - "effect": "O usuário espalha uma nuvem de esporos entorpecentes que paralisam o alvo." - }, - "sleepPowder": { - "name": "Sleep Powder", - "effect": "O usuário espalha uma grande nuvem de pó sonífero ao redor do alvo." - }, - "petalDance": { - "name": "Petal Dance", - "effect": "O usuário ataca o alvo espalhando pétalas de dois a três turnos. O usuário então fica confuso." - }, - "stringShot": { - "name": "String Shot", - "effect": "O Pokémon adversário é enrolado com uma seda expelida da boca do usuário, o que reduz duramente sua Velocidade." - }, - "dragonRage": { - "name": "Dragon Rage", - "effect": "Este ataque atinge o alvo com uma onda de choque de pura fúria. Este ataque sempre causa 40 PS de dano." - }, - "fireSpin": { - "name": "Fire Spin", - "effect": "O alvo fica preso dentro de um vórtice feroz de fogo que se prolonga por quatro ou cinco turnos." - }, - "thunderShock": { - "name": "Thunder Shock", - "effect": "Um choque elétrico que cai sobre o alvo causando dano. Isso também pode deixar o alvo paralisado." - }, - "thunderbolt": { - "name": "Thunderbolt", - "effect": "Uma forte explosão elétrica que cai sobre o alvo. Também pode deixar o alvo com paralisia." - }, - "thunderWave": { - "name": "Thunder Wave", - "effect": "O usuário lança um choque elétrico fraco que paralisa o alvo." - }, - "thunder": { - "name": "Thunder", - "effect": "Um raio cruel despenca no alvo para causar dano. Isso também pode deixar o alvo com paralisia." - }, - "rockThrow": { - "name": "Rock Throw", - "effect": "Para atacar, o usuário pega uma pequena rocha e joga no alvo." - }, - "earthquake": { - "name": "Earthquake", - "effect": "O usuário desencadeia um terremoto que atinge todos os Pokémon ao seu redor." - }, - "fissure": { - "name": "Fissure", - "effect": "O usuário abre uma fissura no chão e joga o alvo nela. O alvo desmaiará instantaneamente se esse ataque acertar." - }, - "dig": { - "name": "Dig", - "effect": "O usuário se entoca, então ataca no próximo turno." - }, - "toxic": { - "name": "Toxic", - "effect": "Um movimento que deixa o alvo seriamente envenenado. Seu dano venenoso aumenta a cada turno." - }, - "confusion": { - "name": "Confusion", - "effect": "O alvo é atingido por uma força telecinética fraca. Isso também pode deixar o alvo confuso." - }, - "psychic": { - "name": "Psychic", - "effect": "O alvo é atingido por uma força telecinética poderosa. Isso também pode diminuir a Defesa Especial do alvo." - }, - "hypnosis": { - "name": "Hypnosis", - "effect": "O usuário implanta uma sugestão hipnótica para fazer o alvo cair em um sono profundo." - }, - "meditate": { - "name": "Meditate", - "effect": "O usuário medita para despertar o poder profundo do seu corpo para aumentar seu Ataque." - }, - "agility": { - "name": "Agility", - "effect": "O usuário relaxa o corpo para se mover rapidamente. Isso aumenta bruscamente sua Velocidade." - }, - "quickAttack": { - "name": "Quick Attack", - "effect": "O usuário ataca o alvo em uma velocidade que o torna quase invisível. Esse movimento tem prioridade." - }, - "rage": { - "name": "Rage", - "effect": "Enquanto este movimento estiver em uso, o poder da ira aumenta o Ataque toda vez que o usuário for atingido em batalha." - }, - "teleport": { - "name": "Teleport", - "effect": "Use para fugir de qualquer Pokémon selvagem." - }, - "nightShade": { - "name": "Night Shade", - "effect": "O usuário faz com que o alvo veja uma miragem assustadora. Isso causa dano igual ao nível do usuário." - }, - "mimic": { - "name": "Mimic", - "effect": "O usuário copia o último movimento do alvo. O movimento pode ser usado durante a batalha até que o Pokémon seja trocado." - }, - "screech": { - "name": "Screech", - "effect": "Um grito estridente que reduz duramente o atributo de Defesa do alvo." - }, - "doubleTeam": { - "name": "Double Team", - "effect": "Movendo-se rapidamente, o usuário faz cópias ilusórias para aumentar sua Evasão." - }, - "recover": { - "name": "Recover", - "effect": "Restaurando suas células, o usuário restaura metade do seu máximo de PS." - }, - "harden": { - "name": "Harden", - "effect": "O usuário enrijece todos os músculos do seu corpo para aumentar seu atributo de Defesa." - }, - "minimize": { - "name": "Minimize", - "effect": "O usuário comprime seu corpo para se parecer menor, o que aumenta bruscamente sua Evasão." - }, - "smokescreen": { - "name": "Smokescreen", - "effect": "O usuário lança uma nuvem obscura de fumaça ou tinta. Isso diminui a Precisão do alvo." - }, - "confuseRay": { - "name": "Confuse Ray", - "effect": "O alvo é exposto a um raio sinistro que leva à confusão." - }, - "withdraw": { - "name": "Withdraw", - "effect": "O usuário retrai seu corpo para dentro de seu casco duro, aumentando o seu atributo de Defesa." - }, - "defenseCurl": { - "name": "Defense Curl", - "effect": "O usuário se enrola para esconder os pontos fracos e aumentar seu atributo de Defesa." - }, - "barrier": { - "name": "Barrier", - "effect": "O usuário ergue uma barreira robusta que aumenta bruscamente a sua Defesa." - }, - "lightScreen": { - "name": "Light Screen", - "effect": "Uma incrível parede de luz é erguida para reduzir o dano de ataques especiais por cinco turnos." - }, - "haze": { - "name": "Haze", - "effect": "O usuário cria uma névoa que elimina todas as alterações de atributos de todos os Pokémon em batalha." - }, - "reflect": { - "name": "Reflect", - "effect": "Uma incrível parede de luz é erguida para reduzir o dano de ataques físicos por cinco turnos." - }, - "focusEnergy": { - "name": "Focus Energy", - "effect": "O usuário respira fundo e concentra-se para que golpes críticos ocorram mais facilmente." - }, - "bide": { - "name": "Bide", - "effect": "O usuário resiste a ataques por dois turnos, e revida causando o dobro do dano recebido." - }, - "metronome": { - "name": "Metronome", - "effect": "O usuário balança um dedo e estimula seu cérebro para usar aleatoriamente quase qualquer movimento." - }, - "mirrorMove": { - "name": "Mirror Move", - "effect": "O usuário contra-ataca o alvo imitando seu último movimento utilizado." - }, - "selfDestruct": { - "name": "Self-Destruct", - "effect": "O usuário ataca tudo ao seu redor causando uma explosão. O usuário desmaia por usar esse golpe." - }, - "eggBomb": { - "name": "Egg Bomb", - "effect": "Um ovo grande é arremessado contra o alvo com força máxima para causar dano." - }, - "lick": { - "name": "Lick", - "effect": "O alvo é lambido com uma língua comprida, causando dano. Isso também pode deixar o alvo paralisado." - }, - "smog": { - "name": "Smog", - "effect": "O alvo é atacado com uma descarga de gases poluentes. Isso também pode envenenar o alvo." - }, - "sludge": { - "name": "Sludge", - "effect": "Lodo insalubre é no arremessado no alvo. Isso também pode causar envenenamento." - }, - "boneClub": { - "name": "Bone Club", - "effect": "O usuário golpeia o alvo com um osso. Isso também pode o fazer o alvo hesitar." - }, - "fireBlast": { - "name": "Fire Blast", - "effect": "O alvo é atacado com uma intensa explosão de fogo consumidor. Isso também pode deixar o alvo com uma queimadura." - }, - "waterfall": { - "name": "Waterfall", - "effect": "O usuário investe no alvo e pode fazê-lo hesitar." - }, - "clamp": { - "name": "Clamp", - "effect": "O alvo é apertado e imprensado pela concha densa e robusta do usuário por quatro ou cinco turnos." - }, - "swift": { - "name": "Swift", - "effect": "Raios em formato de estrela são disparados no Pokémon adversário. Esse ataque nunca erra." - }, - "skullBash": { - "name": "Skull Bash", - "effect": "O usuário retrai sua cabeça para aumentar a Defesa no primeiro turno e depois se choca com o alvo no próximo turno." - }, - "spikeCannon": { - "name": "Spike Cannon", - "effect": "Espinhos afiados são lançados no alvo em rápida sucessão. Eles acertam de duas a cinco vezes seguidas." - }, - "constrict": { - "name": "Constrict", - "effect": "O alvo é atacado com longos e sorrateiros tentáculos ou vinhas. Isso também pode diminuir a Velocidade do alvo." - }, - "amnesia": { - "name": "Amnesia", - "effect": "O usuário esvazia sua mente para esquecer suas preocupações. Aumenta bruscamente a Defesa Especial." - }, - "kinesis": { - "name": "Kinesis", - "effect": "O usuário distrai o alvo entortando uma colher. Isso diminui a Precisão do alvo." - }, - "softBoiled": { - "name": "Soft-Boiled", - "effect": "O usuário restaura os próprios PS pela metade dos seus PS máximos." - }, - "highJumpKick": { - "name": "High Jump Kick", - "effect": "O alvo é atacado com uma joelhada de um pulo. Caso erre, o usuário se machuca." - }, - "glare": { - "name": "Glare", - "effect": "O usuário intimida o alvo com o padrão em sua barriga para causar paralisia." - }, - "dreamEater": { - "name": "Dream Eater", - "effect": "O usuário se alimenta dos sonhos de um alvo adormecido. Ele absorve metade do dano causado para curar seus PS." - }, - "poisonGas": { - "name": "Poison Gas", - "effect": "Uma nuvem de gás venenoso é assoprada no rosto do Pokémon adversário. Isso pode envenenar os alvos." - }, - "barrage": { - "name": "Barrage", - "effect": "Objetos redondos são lançados no alvo para acertar de duas a cinco vezes seguidas." - }, - "leechLife": { - "name": "Leech Life", - "effect": "O usuário drena o sangue do alvo. Os PS do usuário são restaurados pela metade do dano recebido pelo alvo." - }, - "lovelyKiss": { - "name": "Lovely Kiss", - "effect": "Com uma face assustadora, o usuário tenta beijar o alvo à força. Se conseguir, o alvo cai no sono." - }, - "skyAttack": { - "name": "Sky Attack", - "effect": "Um movimento de dois turnos onde golpes críticos ocorrem mais facilmente. Também pode fazer o alvo hesitar." - }, - "transform": { - "name": "Transform", - "effect": "O usuário transforma-se em uma cópia do alvo, conseguindo os mesmos movimentos do adversário." - }, - "bubble": { - "name": "Bubble", - "effect": "Um jato de incontáveis bolhas é disparado no Pokémon adversário. Isso também pode diminuir a velocidade do alvo." - }, - "dizzyPunch": { - "name": "Dizzy Punch", - "effect": "O alvo é atingido com socos dados ritmicamente. Isso também pode deixar alvo confuso." - }, - "spore": { - "name": "Spore", - "effect": "O usuário espalha rajadas de esporos que induzem sono ao alvo." - }, - "flash": { - "name": "Flash", - "effect": "O usuário pisca uma luz brilhante que reduz a Precisão do alvo." - }, - "psywave": { - "name": "Psywave", - "effect": "O alvo é atacado com uma estranha onda psíquica. O ataque varia de intensidade." - }, - "splash": { - "name": "Splash", - "effect": "O usuário apenas debate-se no chão e espirra água ao seu redor sem efeito algum..." - }, - "acidArmor": { - "name": "Acid Armor", - "effect": "O usuário altera sua estrutura celular para se liquefazer, aumentando bruscamente o seu atributo de Defesa." - }, - "crabhammer": { - "name": "Crabhammer", - "effect": "O alvo é martelado com uma grande pinça. Golpes críticos acertam mais facilmente." - }, - "explosion": { - "name": "Explosion", - "effect": "O usuário ataca tudo o que estiver à sua volta causando uma tremenda explosão. O usuário desmaia ao usar esse movimento." - }, - "furySwipes": { - "name": "Fury Swipes", - "effect": "O alvo é atacado com garras afiadas ou foices rapidamente, de duas a cinco vezes seguidas." - }, - "bonemerang": { - "name": "Bonemerang", - "effect": "O usuário arremessa o osso que segura. O osso gira, atingindo o alvo duas vezes, indo e voltando." - }, - "rest": { - "name": "Rest", - "effect": "O usuário dorme por dois turnos. Isso restaura completamente os PS do usuário e cura quaisquer condições negativas." - }, - "rockSlide": { - "name": "Rock Slide", - "effect": "Pedras grandes são arremessadas no Pokémon oponente para causar dano. Isso também pode fazer o Pokémon oponente hesitar." - }, - "hyperFang": { - "name": "Hyper Fang", - "effect": "O usuário morde o alvo com força, usando as suas afiadas presas frontais. Isso também pode fazer o alvo hesitar." - }, - "sharpen": { - "name": "Sharpen", - "effect": "O usuário abaixa o número de polígonos, ficando mais pontiagudo. Isso aumenta o seu atributo de Ataque." - }, - "conversion": { - "name": "Conversion", - "effect": "O usuário muda seu tipo para o mesmo tipo do movimento no topo da lista dos movimentos que conhece no momento." - }, - "triAttack": { - "name": "Tri Attack", - "effect": "O usuário golpeia com um ataque de três raios simultâneos. Também pode queimar, congelar ou paralisar o alvo." - }, - "superFang": { - "name": "Super Fang", - "effect": "O usuário mastiga com força o alvo usando suas afiadas presas frontais. Isso corta os PS do alvo pela metade." - }, - "slash": { - "name": "Slash", - "effect": "O alvo é atacado com um açoite de garras ou lâminas. Golpes críticos ocorrem mais facilmente." - }, - "substitute": { - "name": "Substitute", - "effect": "O usuário faz uma cópia de si mesmo usando parte de seus PS. A cópia serve como uma isca para o usuário." - }, - "struggle": { - "name": "Struggle", - "effect": "Um ataque usado em desespero, apenas se o usuário não tiver PP. Isso também causa um pouco de dano no usuário." - }, - "sketch": { - "name": "Sketch", - "effect": "Permite que o usuário aprenda permanentemente o último movimento usado pelo alvo. Assim que for usado, o Esboço desaparece." - }, - "tripleKick": { - "name": "Triple Kick", - "effect": "Um ataque de três chutes consecutivos que se fortalece a cada golpe acertado." - }, - "thief": { - "name": "Thief", - "effect": "O usuário ataca e rouba o item segurado por seu alvo simultaneamente. O usuário não pode roubar algo se ele já segurar um item." - }, - "spiderWeb": { - "name": "Spider Web", - "effect": "O usuário enlaça o alvo com uma teia fina e grudenta, para que ele não possa fugir da batalha." - }, - "mindReader": { - "name": "Mind Reader", - "effect": "O usuário pressente os movimentos do alvo com sua mente para ter certeza que o seu próximo ataque não o erre." - }, - "nightmare": { - "name": "Nightmare", - "effect": "Um alvo que dorme terá um pesadelo que causará dano a cada turno." - }, - "flameWheel": { - "name": "Flame Wheel", - "effect": "O usuário se envolve em fogo e dispara em direção ao alvo. Isso também pode causar queimaduras no oponente." - }, - "snore": { - "name": "Snore", - "effect": "Um ataque que só pode ser usado se o usuário estiver dormindo. O barulho alto pode fazer o alvo hesitar." - }, - "curse": { - "name": "Curse", - "effect": "Um movimento que funciona diferente com o tipo Fantasma do que com outros tipos." - }, - "flail": { - "name": "Flail", - "effect": "O usuário agita os membros sem rumo para atacar. Quanto menores forem os PS do usuário, melhor será o movimento." - }, - "conversion2": { - "name": "Conversion 2", - "effect": "O usuário muda a própria tipagem para se fazer resistente ao tipo do último ataque usado pelo oponente." - }, - "aeroblast": { - "name": "Aeroblast", - "effect": "Um vortex de vento é atirado em direção ao alvo para causar dano. Golpes críticos ocorrem mais facilmente." - }, - "cottonSpore": { - "name": "Cotton Spore", - "effect": "O usuário solta esporos de algodão que grudam no Pokémon adversário. Isso prejudica bruscamente a Velocidade do oponente." - }, - "reversal": { - "name": "Reversal", - "effect": "Um ataque total que fica mais forte quanto menos PS o usuário possuir." - }, - "spite": { - "name": "Spite", - "effect": "O usuário libera todo o seu rancor no último movimento usado pelo oponente, cortando 4 PP do mesmo." - }, - "powderSnow": { - "name": "Powder Snow", - "effect": "O usuário ataca com uma brisa congelante de Neve em Pó. Isso talvez possa congelar o Pokémon adversário." - }, - "protect": { - "name": "Protect", - "effect": "Permite que o usuário desvie de todos os ataques. A sua chance de falhar aumenta, caso seja usado em sucessão." - }, - "machPunch": { - "name": "Mach Punch", - "effect": "O usuário soca numa velocidade incompreensível. Esse movimento tem prioridade." - }, - "scaryFace": { - "name": "Scary Face", - "effect": "O usuário assusta o alvo com uma cara assustadora para prejudicar duramente a velocidade do oponente." - }, - "feintAttack": { - "name": "Feint Attack", - "effect": "O usuário se aproxima do alvo amigavelmente, então ataca com um soco inesperado. Esse ataque nunca erra." - }, - "sweetKiss": { - "name": "Sweet Kiss", - "effect": "O usuário beija o alvo com uma fofura doce e angelical, causando confusão." - }, - "bellyDrum": { - "name": "Belly Drum", - "effect": "O usuário maximiza seu Ataque em troca de PS igual à metade do seu PS máximo." - }, - "sludgeBomb": { - "name": "Sludge Bomb", - "effect": "Lodo insalubre é no arremessado no alvo. Isso também pode causar envenenamento." - }, - "mudSlap": { - "name": "Mud-Slap", - "effect": "O usuário arremessa lama no rosto do adversário para causar dano e prejudicar sua precisão." - }, - "octazooka": { - "name": "Octazooka", - "effect": "O usuário ataca jogando tinta no rosto ou nos olhos do alvo. Isso pode prejudicar a Precisão do alvo." - }, - "spikes": { - "name": "Spikes", - "effect": "O usuário lança armadilhas de espinhos nos pés da equipe adversária. As armadilhas ferem os Pokémon que são trocados em batalha." - }, - "zapCannon": { - "name": "Zap Cannon", - "effect": "O usuário atira uma explosão elétrica como um canhão para infligir dano e causar paralisia." - }, - "foresight": { - "name": "Foresight", - "effect": "Permite que um alvo do tipo Fantasma seja atingido por ataques do tipo Normal e Lutador. Isso também permite que um alvo evasivo seja acertado." - }, - "destinyBond": { - "name": "Destiny Bond", - "effect": "Quando esse movimento é usado, caso o usuário desmaie, o Pokémon que acertou o nocaute também desmaiará. A chance de falhar aumenta se usado em sucessão." - }, - "perishSong": { - "name": "Perish Song", - "effect": "Qualquer Pokémon que ouvir essa Canção desmaiará em três turnos, a não ser que ele seja retirado da batalha." - }, - "icyWind": { - "name": "Icy Wind", - "effect": "O usuário ataca com uma rajada de ar arrepiante. Isso também prejudica a Velocidade do Pokémon adversário." - }, - "detect": { - "name": "Detect", - "effect": "Permite que o usuário desvie de todos os ataques. A sua chance de falhar aumenta, caso seja usado em sucessão." - }, - "boneRush": { - "name": "Bone Rush", - "effect": "O usuário atinge o alvo com um osso duro de duas a cinco vezes seguidas." - }, - "lockOn": { - "name": "Lock-On", - "effect": "O usuário foca sua mira no alvo. Isso garante que o próximo ataque não erre o alvo." - }, - "outrage": { - "name": "Outrage", - "effect": "O usuário fica furioso e ataca com violência de dois a três turnos. O usuário então se torna confuso." - }, - "sandstorm": { - "name": "Sandstorm", - "effect": "Uma tempestade de areia é invocada durante 5 turnos para ferir todos os combatentes, exceto os tipos Pedra, Terra e Aço. Isso aumenta a Defesa Especial dos tipo Pedra." - }, - "gigaDrain": { - "name": "Giga Drain", - "effect": "Um ataque que drena nutrientes. O usuário recupera PS pela metade do dano infligido ao alvo." - }, - "endure": { - "name": "Endure", - "effect": "O usuário resiste a qualquer ataque com pelo menos 1 PS. A chance de falhar aumenta caso seja usado em sucessão." - }, - "charm": { - "name": "Charm", - "effect": "O usuário contempla o alvo com um olhar charmoso, fazendo-o ficar menos atento. Isso prejudica duramente o Ataque do oponente." - }, - "rollout": { - "name": "Rollout", - "effect": "O usuário rola continuamente em direção ao alvo por cinco turnos. O ataque fica mais forte a cada acerto." - }, - "falseSwipe": { - "name": "False Swipe", - "effect": "Um ataque moderado que previne que o alvo desmaie. O alvo é deixado com pelo menos 1 de PS." - }, - "swagger": { - "name": "Swagger", - "effect": "O usuário enfurece e confunde o alvo. Entretanto, isso também aumenta bruscamente o Ataque do alvo." - }, - "milkDrink": { - "name": "Milk Drink", - "effect": "O usuário restaura os próprios PS pela metade dos seus PS máximos." - }, - "spark": { - "name": "Spark", - "effect": "O usuário direciona uma investida carregada com eletricidade no alvo. Isso pode paralisar o alvo." - }, - "furyCutter": { - "name": "Fury Cutter", - "effect": "O alvo é cortado com foices ou garras. Esse ataque se torna mais poderoso se usado em sucessão." - }, - "steelWing": { - "name": "Steel Wing", - "effect": "O alvo é atingido com asas de aço. Isso também pode aumentar a Defesa do usuário." - }, - "meanLook": { - "name": "Mean Look", - "effect": "O usuário encara o alvo com um olhar sombrio e opressor. O alvo se torna incapaz de fugir." - }, - "attract": { - "name": "Attract", - "effect": "Caso o adversário seja do gênero oposto ao usuário, o alvo se apaixona e se torna menos suscetível a atacar." - }, - "sleepTalk": { - "name": "Sleep Talk", - "effect": "Enquanto está dormindo, o usuário usa aleatoriamente um dos movimentos que tem conhecimento." - }, - "healBell": { - "name": "Heal Bell", - "effect": "O usuário toca um sino calmante para curar condições de estados de todos os Pokémon aliados na equipe." - }, - "return": { - "name": "Return", - "effect": "Um ataque poderoso que fica mais poderoso à medida que o usuário gosta de seu Treinador." - }, - "present": { - "name": "Present", - "effect": "O usuário ataca o alvo entregando um presente com uma armadilha oculta. Entretanto, às vezes cura os PS do alvo." - }, - "frustration": { - "name": "Frustration", - "effect": "Um ataque poderoso que fica mais poderoso à medida que o usuário desgosta de seu Treinador." - }, - "safeguard": { - "name": "Safeguard", - "effect": "O usuário cria um campo protetor que previne condições de estado por cinco turnos." - }, - "painSplit": { - "name": "Pain Split", - "effect": "O usuário adiciona os próprios PS aos PS do alvo, então compartilha igualmente os PS combinados com o alvo." - }, - "sacredFire": { - "name": "Sacred Fire", - "effect": "O usuário é arrasado com uma rajada de fogo místico de grande intensidade. Isso pode deixar o alvo queimado." - }, - "magnitude": { - "name": "Magnitude", - "effect": "O usuário ataca tudo ao seu redor com um grande tremor. Seu poder varia." - }, - "dynamicPunch": { - "name": "Dynamic Punch", - "effect": "O usuário soca o alvo com sua força totalmente concentrada. Em caso de acerto, confundirá o alvo." - }, - "megahorn": { - "name": "Megahorn", - "effect": "Usando seu impressionante chifre resistente, o usuário golpeia o alvo sem trégua." - }, - "dragonBreath": { - "name": "Dragon Breath", - "effect": "O usuário sopra uma poderosa rajada que causa dano. Isso também pode paralisar o alvo." - }, - "batonPass": { - "name": "Baton Pass", - "effect": "O usuário troca de lugar com um Pokémon da equipe em espera e passa para ele quaisquer mudanças de atributos." - }, - "encore": { - "name": "Encore", - "effect": "O usuário enaltece o alvo para que ele continue usando o movimento que ele usou por último durante três turnos." - }, - "pursuit": { - "name": "Pursuit", - "effect": "Um ataque que causa o dobro do dano caso seja usado em um alvo que esteja sendo trocado para fora da batalha." - }, - "rapidSpin": { - "name": "Rapid Spin", - "effect": "Um ataque giratório que pode anular movimentos como Enlaçar, Embrulho, Sanguessuga e Espinhos." - }, - "sweetScent": { - "name": "Sweet Scent", - "effect": "Um aroma doce que prejudica duramente a Evasão do Pokémon adversário." - }, - "ironTail": { - "name": "Iron Tail", - "effect": "O alvo é esmagado com uma cauda dura como aço. Isso também pode prejudicar a Defesa do alvo." - }, - "metalClaw": { - "name": "Metal Claw", - "effect": "O alvo é cortado com garras de metal. Isso também pode aumentar o Ataque do usuário." - }, - "vitalThrow": { - "name": "Vital Throw", - "effect": "O usuário sempre ataca por último. Em troca, esse arremesso nunca erra." - }, - "morningSun": { - "name": "Morning Sun", - "effect": "O usuário restaura os próprios PS. A quantidade de PS recuperada varia conforme o clima." - }, - "synthesis": { - "name": "Synthesis", - "effect": "O usuário restaura os próprios PS. A quantidade de PS recuperada varia conforme o clima." - }, - "moonlight": { - "name": "Moonlight", - "effect": "O usuário restaura os próprios PS. A quantidade de PS recuperada varia conforme o clima." - }, - "hiddenPower": { - "name": "Hidden Power", - "effect": "Um ataque único que varia em tipo dependendo do Pokémon que está utilizando." - }, - "crossChop": { - "name": "Cross Chop", - "effect": "O usuário dá um golpe duplo com seus antebraços cruzados. Golpes críticos ocorrem mais facilmente." - }, - "twister": { - "name": "Twister", - "effect": "O usuário rapidamente cria um tornado vicioso para rasgar os Pokémon adversários. Isso pode fazê-los hesitar." - }, - "rainDance": { - "name": "Rain Dance", - "effect": "O usuário invoca uma chuva intensa que continua caindo por cinco turnos, fortalecendo os movimentos do tipo Água. Também enfraquece os movimentos do tipo fogo." - }, - "sunnyDay": { - "name": "Sunny Day", - "effect": "O usuário intensifica o sol por cinco turnos, fortalecendo os ataques do tipo Fogo. Também enfraquece os movimentos do tipo água." - }, - "crunch": { - "name": "Crunch", - "effect": "O usuário mastiga o alvo com presas afiadas. Isso também pode prejudicar a Defesa do alvo." - }, - "mirrorCoat": { - "name": "Mirror Coat", - "effect": "Um movimento de retaliação que contra-ataca qualquer ataque especial, infligindo o dobro do dano recebido." - }, - "psychUp": { - "name": "Psych Up", - "effect": "O usuário hipnotiza a si mesmo para copiar qualquer mudança de atributo feita pelo alvo." - }, - "extremeSpeed": { - "name": "Extreme Speed", - "effect": "O usuário ataca o alvo numa velocidade invisível ao olho nu. Esse movimento tem prioridade." - }, - "ancientPower": { - "name": "Ancient Power", - "effect": "O usuário ataca com um poder pré-histórico. Isso também pode fortalecer todos os atributos do usuário de uma vez." - }, - "shadowBall": { - "name": "Shadow Ball", - "effect": "O usuário arremessa uma esfera sombria no alvo. Isso também pode prejudicar a Defesa Especial do alvo." - }, - "futureSight": { - "name": "Future Sight", - "effect": "Dois turnos após esse movimento ser usado, uma grande quantidade de energia psíquica atinge o alvo." - }, - "rockSmash": { - "name": "Rock Smash", - "effect": "O usuário ataca com um soco. Isso também pode prejudicar o atributo de Defesa do alvo." - }, - "whirlpool": { - "name": "Whirlpool", - "effect": "O usuário prende o alvo num violento redemoinho por quatro ou cinco turnos." - }, - "beatUp": { - "name": "Beat Up", - "effect": "O usuário reúne todos os Pokémon da equipe para atacar o alvo. Quanto maior o número de Pokémon na equipe, maior será o número de ataques." - }, - "fakeOut": { - "name": "Fake Out", - "effect": "Um ataque que acerta primeiro e faz o alvo hesitar. Só funciona no primeiro turno do usuário em batalha." - }, - "uproar": { - "name": "Uproar", - "effect": "O usuário ataca gritando por três turnos. Durante esse tempo, ninguém pode cair no sono." - }, - "stockpile": { - "name": "Stockpile", - "effect": "O usuário carrega seu poder e fortalece a Defesa e a Defesa Especial. O movimento pode ser usado três vezes." - }, - "spitUp": { - "name": "Spit Up", - "effect": "O poder carregado usando o movimento Estocagem é liberado de uma só vez em um ataque. Quanto mais poder é armazenado, maior a força do movimento." - }, - "swallow": { - "name": "Swallow", - "effect": "O poder carregado usando o movimento Estocagem é absorvido pelo usuário para curar PS. Quanto mais poder for armazenado, mais PS serão recuperados." - }, - "heatWave": { - "name": "Heat Wave", - "effect": "O usuário ataca exalando um sopro ardente nos Pokémon adversários. Isso também pode deixar esses Pokémon queimados." - }, - "hail": { - "name": "Hail", - "effect": "O usuário invoca uma tempestade de granizo durante cinco turnos. Isso fere todos os Pokémon, exceto os tipo Gelo." - }, - "torment": { - "name": "Torment", - "effect": "O usuário atormenta o alvo, fazendo-o incapaz de usar o mesmo movimento duas vezes seguidas." - }, - "flatter": { - "name": "Flatter", - "effect": "Bajulação é usada para confundir o oponente. Entretanto, isso também fortalece o Ataque Especial do alvo." - }, - "willOWisp": { - "name": "Will-O-Wisp", - "effect": "O usuário atira uma sinistra chama azulada no alvo para causar uma queimadura." - }, - "memento": { - "name": "Memento", - "effect": "O usuário desmaia quando usa esse movimento. Em troca, prejudica duramente o Ataque e o Ataque Especial do alvo." - }, - "facade": { - "name": "Facade", - "effect": "Um ataque que dobra de poder caso o usuário esteja envenenado, queimado ou paralisado." - }, - "focusPunch": { - "name": "Focus Punch", - "effect": "O usuário foca sua mente antes de dar um soco. Esse ataque falhará caso o usuário seja atingido antes de executá-lo." - }, - "smellingSalts": { - "name": "Smelling Salts", - "effect": "Esse ataque causa o dobro do dano em um alvo paralisado. Entretanto, isso também cura a paralisia do alvo." - }, - "followMe": { - "name": "Follow Me", - "effect": "O usuário chama a atenção para si mesmo, fazendo todos os alvos mirarem apenas nele." - }, - "naturePower": { - "name": "Nature Power", - "effect": "Um ataque que faz uso do poder da natureza. Seus efeitos variam dependendo do ambiente ao redor do usuário." - }, - "charge": { - "name": "Charge", - "effect": "O usuário fortalece o poder do golpe do tipo Elétrico usado no próximo turno. Isso também fortalece a Defesa Especial do usuário." - }, - "taunt": { - "name": "Taunt", - "effect": "O alvo é provocado e fica em fúria, fazendo-o usar apenas movimentos de ataque por três turnos." - }, - "helpingHand": { - "name": "Helping Hand", - "effect": "O usuário auxilia um aliado, fortalecendo o poder do ataque desse aliado." - }, - "trick": { - "name": "Trick", - "effect": "O usuário pega o alvo de surpresa e faz uma troca de itens com o alvo." - }, - "rolePlay": { - "name": "Role Play", - "effect": "O usuário imita o alvo completamente, copiando a Habilidade natural do alvo." - }, - "wish": { - "name": "Wish", - "effect": "Um turno após esse movimento ter sido usado, os PS do usuário ou de seu substituinte são restaurados pela metade dos PS máximos do usuário." - }, - "assist": { - "name": "Assist", - "effect": "O usuário na pressa usa aleatoriamente um dos movimentos conhecidos pelos outros Pokémon na equipe." - }, - "ingrain": { - "name": "Ingrain", - "effect": "O usuário planta suas raízes para curar seus PS por turno. Devido ao enraizamento, ele não pode sair da batalha." - }, - "superpower": { - "name": "Superpower", - "effect": "O usuário ataca o alvo com grande poder. Entretanto, isso também prejudica o Ataque e Defesa do usuário." - }, - "magicCoat": { - "name": "Magic Coat", - "effect": "Uma barreira que reflete de volta ao alvo movimentos como Semente Drenante e movimentos que reduzem atributos." - }, - "recycle": { - "name": "Recycle", - "effect": "O usuário recicla um item segurado que já foi usado em batalha para que possa ser usado de novo." - }, - "revenge": { - "name": "Revenge", - "effect": "Um movimento atacante que inflige o dobro do dano se o usuário foi ferido pelo adversário no mesmo turno." - }, - "brickBreak": { - "name": "Brick Break", - "effect": "O usuário ataca com um corte veloz. Isso também quebra barreiras como Tela de Luz e Refletir." - }, - "yawn": { - "name": "Yawn", - "effect": "O usuário dá um grande e preguiçoso bocejo que acalma o alvo, fazendo-o cair no sono no próximo turno." - }, - "knockOff": { - "name": "Knock Off", - "effect": "O usuário dá um tapa no item segurado pelo alvo e esse item não poderá mais ser usado naquela batalha. Caso possua um item, o alvo receberá mais dano." - }, - "endeavor": { - "name": "Endeavor", - "effect": "Um movimento de ataque que corta os PS do alvo para que se equalize aos PS do usuário." - }, - "eruption": { - "name": "Eruption", - "effect": "O usuário ataca o Pokémon adversário com uma fúria explosiva. Quanto menor for os PS do usuário, menor será o poder do movimento." - }, - "skillSwap": { - "name": "Skill Swap", - "effect": "O usuário utiliza seu poder psíquico para trocar de Habilidade com o alvo." - }, - "imprison": { - "name": "Imprison", - "effect": "Se os Pokémon adversários conhecerem algum movimento também conhecido pelo usuário, eles não poderão usá-lo." - }, - "refresh": { - "name": "Refresh", - "effect": "O usuário descansa para curar a si mesmo de envenenamentos, queimaduras ou paralisias." - }, - "grudge": { - "name": "Grudge", - "effect": "Se o usuário desmaiar, o rancor do usuário vai esgotar completamente os PP do movimento que o nocauteou." - }, - "snatch": { - "name": "Snatch", - "effect": "O usuário rouba o efeito de qualquer tentativa de usar um movimento de cura ou mudança de atributo." - }, - "secretPower": { - "name": "Secret Power", - "effect": "Os efeitos adicionais deste movimento variam dependendo do ambiente ao redor do usuário." - }, - "dive": { - "name": "Dive", - "effect": "Mergulhando no primeiro turno, o usuário emerge e ataca no próximo turno." - }, - "armThrust": { - "name": "Arm Thrust", - "effect": "O usuário solta uma sequência de golpes braçais com as palmas abertas, de duas a cinco vezes seguidas." - }, - "camouflage": { - "name": "Camouflage", - "effect": "O tipo do usuário é mudado dependendo do ambiente ao seu redor, como na margem da água, rodeado por grama ou dentro de uma caverna." - }, - "tailGlow": { - "name": "Tail Glow", - "effect": "O usuário direciona seu olhar à luzes piscantes para focar sua mente, aumentando drasticamente o seu Ataque Especial." - }, - "lusterPurge": { - "name": "Luster Purge", - "effect": "O usuário libera uma explosão de luz letal. Isso pode prejudicar a Defesa Especial do alvo." - }, - "mistBall": { - "name": "Mist Ball", - "effect": "Um amalgamado de penas nevoentas envolvem e ferem o alvo. Isso pode prejudicar o Ataque Especial do alvo." - }, - "featherDance": { - "name": "Feather Dance", - "effect": "O usuário cobre o corpo do alvo com uma grande massa de penas que prejudicam duramente o Ataque do alvo." - }, - "teeterDance": { - "name": "Teeter Dance", - "effect": "O usuário performa uma dança desajeitada que confunde os Pokémon ao seu redor." - }, - "blazeKick": { - "name": "Blaze Kick", - "effect": "O usuário lança um chute que acerta golpes críticos com mais facilidade. Isso também pode deixar o alvo queimado." - }, - "mudSport": { - "name": "Mud Sport", - "effect": "O usuário chuta lama ao redor do campo de batalha. Isso enfraquece os golpes do tipo Elétrico por cinco turnos." - }, - "iceBall": { - "name": "Ice Ball", - "effect": "O usuário ataca continuamente por cinco turnos. O ataque se torna mais forte cada vez que acerta." - }, - "needleArm": { - "name": "Needle Arm", - "effect": "O usuário ataca selvagemente balançando seus braços pontiagudos. Isso pode fazer o alvo hesitar." - }, - "slackOff": { - "name": "Slack Off", - "effect": "O usuário relaxa, restaurando os próprios PS pela metade dos seus PS máximos." - }, - "hyperVoice": { - "name": "Hyper Voice", - "effect": "O usuário libera um horrível grito estridente com o poder de infligir dano." - }, - "poisonFang": { - "name": "Poison Fang", - "effect": "O usuário morde o alvo com suas presas tóxicas. Isso pode envenenar seriamente o alvo." - }, - "crushClaw": { - "name": "Crush Claw", - "effect": "O usuário retalha o alvo com garras duras e afiadas. Isso pode prejudicar a Defesa do alvo." - }, - "blastBurn": { - "name": "Blast Burn", - "effect": "O alvo é arrasado por uma ardente explosão. O usuário não pode se mover no próximo turno." - }, - "hydroCannon": { - "name": "Hydro Cannon", - "effect": "O alvo é acertado por uma explosão aquática. O usuário não pode se mover no próximo turno." - }, - "meteorMash": { - "name": "Meteor Mash", - "effect": "O alvo é acertado por um soco forte disparado como um meteoro. Isso pode fortalecer o Ataque do usuário." - }, - "astonish": { - "name": "Astonish", - "effect": "O usuário ataca o alvo enquanto grita de forma alarmante. Isso pode fazer o alvo hesitar." - }, - "weatherBall": { - "name": "Weather Ball", - "effect": "Um ataque que varia de poder e tipo dependendo do clima." - }, - "aromatherapy": { - "name": "Aromatherapy", - "effect": "O usuário lança uma fragrância calmante que cura todos os estados negativos afetando a equipe do usuário." - }, - "fakeTears": { - "name": "Fake Tears", - "effect": "O usuário finge chorar para perturbar o alvo, duramente prejudicando a sua Defesa Especial." - }, - "airCutter": { - "name": "Air Cutter", - "effect": "O usuário lança uma rajada de vento afiado para cortar seus oponentes. Golpes críticos ocorrem mais facilmente." - }, - "overheat": { - "name": "Overheat", - "effect": "O usuário ataca o alvo com seu poder máximo; contudo, o efeito colateral diminui o Ataque Especial do usuário." - }, - "odorSleuth": { - "name": "Odor Sleuth", - "effect": "Permite que um alvo do tipo Fantasma seja atingido por ataques do tipo Normal e Lutador. Isso também permite que um alvo evasivo seja acertado." - }, - "rockTomb": { - "name": "Rock Tomb", - "effect": "Rochas são arremessadas no alvo. Isso também diminui a Velocidade do alvo, impedindo que se movimente." - }, - "silverWind": { - "name": "Silver Wind", - "effect": "O alvo é atacado com escamas pulverulentas sopradas pelo vento. Isso pode aumentar todos os atributos do usuário." - }, - "metalSound": { - "name": "Metal Sound", - "effect": "Um som horrível que lembra metal sendo raspado, isso prejudica duramente a Defesa Especial do alvo." - }, - "grassWhistle": { - "name": "Grass Whistle", - "effect": "O usuário toca uma agradável melodia que acalma o alvo, fazendo-o entrar em sono profundo." - }, - "tickle": { - "name": "Tickle", - "effect": "O usuário faz cócegas no alvo, o fazendo rir, reduzindo seus atributos de Ataque e Defesa." - }, - "cosmicPower": { - "name": "Cosmic Power", - "effect": "O usuário absorve energia mística do espaço para aumentar sua Defesa e Defesa Especial." - }, - "waterSpout": { - "name": "Water Spout", - "effect": "O usuário jorra água para ferir os Pokémon oponentes. Quanto menos PS o usuário tiver, menor será o poder do movimento." - }, - "signalBeam": { - "name": "Signal Beam", - "effect": "O usuário ataca com um raio de luz sinistro. Isso também pode confundir o alvo." - }, - "shadowPunch": { - "name": "Shadow Punch", - "effect": "O usuário dispara um soco dentre as sombras. Esse ataque nunca erra." - }, - "extrasensory": { - "name": "Extrasensory", - "effect": "O usuário ataca com um poder estranho e incompreensível. Isso também pode fazer o alvo hesitar." - }, - "skyUppercut": { - "name": "Sky Uppercut", - "effect": "O usuário ataca o alvo com um gancho de direita poderoso direcionado ao céu." - }, - "sandTomb": { - "name": "Sand Tomb", - "effect": "O usuário prende o alvo dentro de uma violenta tempestade de areia por quatro ou cinco turnos." - }, - "sheerCold": { - "name": "Sheer Cold", - "effect": "O alvo desmaia instantaneamente. É mais difícil de acertar se o usuário não for um tipo Gelo." - }, - "muddyWater": { - "name": "Muddy Water", - "effect": "O usuário ataca atirando água barrenta nos Pokémon adversários. Isso também pode diminuir a Precisão deles." - }, - "bulletSeed": { - "name": "Bullet Seed", - "effect": "O usuário atira sementes com grande força no alvo de duas a cinco vezes seguidas." - }, - "aerialAce": { - "name": "Aerial Ace", - "effect": "O usuário confunde o alvo com sua velocidade e então ataca. Esse ataque nunca erra." - }, - "icicleSpear": { - "name": "Icicle Spear", - "effect": "O usuário arremessa lanças afiadas de gelo no alvo de duas a cinco vezes seguidas." - }, - "ironDefense": { - "name": "Iron Defense", - "effect": "O usuário endurece a superfície de seu corpo como aço, bruscamente fortalecendo sua Defesa." - }, - "block": { - "name": "Block", - "effect": "O usuário bloqueia o caminho do alvo com seus braços amplamente abertos para prevenir escapatória." - }, - "howl": { - "name": "Howl", - "effect": "O usuário uiva alto para fortalecer seu espirito, o que aumenta seu Ataque." - }, - "dragonClaw": { - "name": "Dragon Claw", - "effect": "O usuário corta o alvo com grandes garras afiadas." - }, - "frenzyPlant": { - "name": "Frenzy Plant", - "effect": "O usuário esmaga o alvo com uma enorme árvore. O usuário não pode se mover no próximo turno." - }, - "bulkUp": { - "name": "Bulk Up", - "effect": "O usuário flexiona os seus músculos para fortalecer seu corpo, aumentando os seus atributos de Ataque e Defesa." - }, - "bounce": { - "name": "Bounce", - "effect": "O usuário pula alto e então cai em cima do alvo no segundo turno. Isso também pode deixar o alvo com paralisia." - }, - "mudShot": { - "name": "Mud Shot", - "effect": "O usuário ataca arremessando uma bola de lama ao alvo. Isso também diminui a Velocidade do alvo." - }, - "poisonTail": { - "name": "Poison Tail", - "effect": "O usuário acerta o alvo com sua cauda. Isso também pode envenenar o alvo. Golpes críticos ocorrem mais facilmente." - }, - "covet": { - "name": "Covet", - "effect": "O usuário, despretensiosamente, se aproxima do alvo e então rouba o item segurado pelo alvo." - }, - "voltTackle": { - "name": "Volt Tackle", - "effect": "O usuário eletrifica a si próprio e então ataca. Isso também fere muito o usuário. Pode deixar o alvo com paralisia." - }, - "magicalLeaf": { - "name": "Magical Leaf", - "effect": "O usuário espalha folhas peculiares que perseguem o alvo. Esse ataque nunca erra." - }, - "waterSport": { - "name": "Water Sport", - "effect": "O usuário encharca o campo de batalha. Isso enfraquece os movimentos do tipo Fogo por cinco turnos." - }, - "calmMind": { - "name": "Calm Mind", - "effect": "O usuário silenciosamente focaliza sua mente e acalma o seu espírito para aumentar ambos os atributos especiais." - }, - "leafBlade": { - "name": "Leaf Blade", - "effect": "O usuário empunha uma folha afiada como uma espada e ataca cortando o alvo. Golpes críticos acertam mais facilmente." - }, - "dragonDance": { - "name": "Dragon Dance", - "effect": "O usuário, energicamente, performa uma dança mística e poderosa para aumentar seu Ataque e Velocidade." - }, - "rockBlast": { - "name": "Rock Blast", - "effect": "O usuário arremessa rochas duras no alvo. Duas a cinco rochas são lançadas em sequência." - }, - "shockWave": { - "name": "Shock Wave", - "effect": "O usuário atinge o alvo com um repentino ataque de eletricidade. Esse ataque nunca erra." - }, - "waterPulse": { - "name": "Water Pulse", - "effect": "O usuário ataca o alvo com uma pulsante explosão de água. Talvez isso confunda o alvo." - }, - "doomDesire": { - "name": "Doom Desire", - "effect": "Dois turnos após esse movimento ter sido usado, o usuário explode o alvo com um feixe de luz concentrado." - }, - "psychoBoost": { - "name": "Psycho Boost", - "effect": "O usuário ataca o alvo com poder máximo. O efeito colateral do ataque prejudica duramente o Ataque Especial do usuário." - }, - "roost": { - "name": "Roost", - "effect": "O usuário pousa e descansa seu corpo. Isso restaura os PS do usuário pela metade do seu máximo de PS." - }, - "gravity": { - "name": "Gravity", - "effect": "Permite que Pokémon do tipo Voador ou Pokémon com a Habilidade Levitação possam ser atingidos por golpes do tipo Terra. Golpes que envolvam voar ficam inutilizados." - }, - "miracleEye": { - "name": "Miracle Eye", - "effect": "Permite que um alvo tipo Sombrio seja atingido por ataques do tipo Psíquico. Isso também permite que um alvo evasivo possa ser atingido." - }, - "wakeUpSlap": { - "name": "Wake-Up Slap", - "effect": "Esse ataque causa muito dano em um alvo que estiver dormindo; entretanto, isso também acorda o alvo." - }, - "hammerArm": { - "name": "Hammer Arm", - "effect": "O usuário balança seus braços e atinge com seus fortes e pesados punhos. Isso diminui a Velocidade do usuário." - }, - "gyroBall": { - "name": "Gyro Ball", - "effect": "O alvo é acertado com um giro em alta velocidade. Quanto mais lento for o usuário comparado ao alvo, maior será o poder do movimento." - }, - "healingWish": { - "name": "Healing Wish", - "effect": "O usuário desmaia. Em troca, o Pokémon que tomará seu lugar terá seus PS restaurados e condições negativas curadas." - }, - "brine": { - "name": "Brine", - "effect": "Se os PS do alvo estiverem pela metade ou menos, esse ataque terá o dobro do poder." - }, - "naturalGift": { - "name": "Natural Gift", - "effect": "O usuário canaliza o poder para atacar usando a Fruta que está segurando. A Fruta determina o tipo e o poder do movimento." - }, - "feint": { - "name": "Feint", - "effect": "Um ataque que acerta um alvo usando Proteção ou Detectar. Isso também extingue os efeitos desses movimentos." - }, - "pluck": { - "name": "Pluck", - "effect": "O usuário bica o alvo. Caso o alvo esteja segurando uma Fruta, o usuário a come e ganha seu efeito." - }, - "tailwind": { - "name": "Tailwind", - "effect": "O usuário forma um turbulento redemoinho que aumenta a Velocidade do usuário e de seus seus aliados por quatro turnos." - }, - "acupressure": { - "name": "Acupressure", - "effect": "O usuário aplica pressão em pontos de estresse, bruscamente fortalecendo um de seus atributos ou de seus aliados." - }, - "metalBurst": { - "name": "Metal Burst", - "effect": "O usuário revida com muito mais força contra o alvo que lhe infligiu dano por ultimo." - }, - "uTurn": { - "name": "U-turn", - "effect": "Depois de fazer o seu ataque, o usuário corre de volta para trocar de lugar com um Pokémon da própria equipe." - }, - "closeCombat": { - "name": "Close Combat", - "effect": "O usuário luta com o alvo de perto sem se defender. Isso diminui a Defesa e Defesa Especial do usuário." - }, - "payback": { - "name": "Payback", - "effect": "O usuário acumula poder, então ataca. Se o usuário se mover depois do alvo, o poder deste ataque será dobrado." - }, - "assurance": { - "name": "Assurance", - "effect": "Caso o alvo já tenha recebido dano no mesmo turno, o poder desse ataque é dobrado." - }, - "embargo": { - "name": "Embargo", - "effect": "Este movimento previne que o alvo use o seu item por cinco turnos. Seu Treinador também estará restrito de usar itens nele." - }, - "fling": { - "name": "Fling", - "effect": "O usuário arremessa seu item no alvo para atacar. O poder e o efeito deste movimento dependem do item utilizado." - }, - "psychoShift": { - "name": "Psycho Shift", - "effect": "Usando seu poder psíquico da sugestão, o usuário transfere suas condições de estado para o alvo." - }, - "trumpCard": { - "name": "Trump Card", - "effect": "Quanto menos PP este movimento tiver, maior será sua força." - }, - "healBlock": { - "name": "Heal Block", - "effect": "Por cinco turnos, o usuário previne que a equipe adversária use quaisquer movimentos, Habilidades, ou itens segurados para recuperar PS." - }, - "wringOut": { - "name": "Wring Out", - "effect": "O usuário torce o alvo com força bruta. Quando mais PS o alvo possuir, maior será o poder do movimento." - }, - "powerTrick": { - "name": "Power Trick", - "effect": "O usuário usufrui de seu poder psíquico para trocar os atributos de seu Ataque com sua Defesa." - }, - "gastroAcid": { - "name": "Gastro Acid", - "effect": "O usuário arremessa os ácidos de seu estômago no alvo. O fluido elimina o efeito da habilidade do alvo." - }, - "luckyChant": { - "name": "Lucky Chant", - "effect": "O usuário recita um encantamento em direção ao céu, prevenindo que os Pokémon oponentes acertem golpes críticos." - }, - "meFirst": { - "name": "Me First", - "effect": "O usuário corta a ação do alvo para roubar seu movimento e usá-lo com maior poder. Esse movimento falha caso não seja usado primeiro." - }, - "copycat": { - "name": "Copycat", - "effect": "O usuário imita o movimento imediatamente usado antes dele. O movimento falha caso nenhum outro movimento tenha sido usado." - }, - "powerSwap": { - "name": "Power Swap", - "effect": "O usuário usufrui de seu poder psíquico para trocar mudanças de atributos feitas ao seu Ataque e Ataque Especial com os do alvo." - }, - "guardSwap": { - "name": "Guard Swap", - "effect": "O usuário usufrui de seu poder psíquico para trocar mudanças de atributos feitas à sua Defesa e Defesa Especial com as do alvo." - }, - "punishment": { - "name": "Punishment", - "effect": "Quanto mais os atributos do alvo estiverem fortalecidos, maior será o poder desse movimento." - }, - "lastResort": { - "name": "Last Resort", - "effect": "Este movimento somente pode ser usado depois de o usuário ter usado todos os outros movimentos que ele conhece em batalha." - }, - "worrySeed": { - "name": "Worry Seed", - "effect": "Uma semente que causa preocupação é plantada no alvo. Isso previne o sono, fazendo a Habilidade do alvo se tornar Insônia." - }, - "suckerPunch": { - "name": "Sucker Punch", - "effect": "Esse movimento permite que o usuário ataque primeiro. Esse ataque falha caso o alvo não esteja preparando um ataque." - }, - "toxicSpikes": { - "name": "Toxic Spikes", - "effect": "O usuário planta uma armadilha de espinhos venenosos nos pés da equipe adversária. Os espinhos envenenam os Pokémon que entram em batalha." - }, - "heartSwap": { - "name": "Heart Swap", - "effect": "O usuário usufrui de seu poder psíquico para trocar mudanças de atributos com o oponente." - }, - "aquaRing": { - "name": "Aqua Ring", - "effect": "O usuário envolve-se em um véu feito de água. Ele recupera um pouco de PS a cada turno." - }, - "magnetRise": { - "name": "Magnet Rise", - "effect": "O usuário levita usando magnetismo gerado por eletricidade por cinco turnos." - }, - "flareBlitz": { - "name": "Flare Blitz", - "effect": "O usuário cobre o próprio corpo com chamas e avança no alvo. Isso também fere muito o usuário e pode deixar o alvo com uma queimadura." - }, - "forcePalm": { - "name": "Force Palm", - "effect": "O alvo é atacado com uma onda de choque. Isso também pode deixar o alvo com paralisia." - }, - "auraSphere": { - "name": "Aura Sphere", - "effect": "O usuário libera uma explosão de poder da aura de seu corpo no alvo. Esse ataque nunca erra." - }, - "rockPolish": { - "name": "Rock Polish", - "effect": "O usuário pule seu corpo para reduzir entraves. Isso pode aumentar bruscamente a Velocidade." - }, - "poisonJab": { - "name": "Poison Jab", - "effect": "O alvo é perfurado com um tentáculo ou braço banhado com veneno. Isso também pode envenenar o alvo." - }, - "darkPulse": { - "name": "Dark Pulse", - "effect": "O usuário descarrega uma horrível aura imbuída com pensamentos obscuros. Isso também pode fazer o alvo hesitar." - }, - "nightSlash": { - "name": "Night Slash", - "effect": "O usuário retalha o alvo no instante que surge uma oportunidade. Golpes críticos ocorrem mais facilmente." - }, - "aquaTail": { - "name": "Aqua Tail", - "effect": "O usuário ataca balançando sua cauda como se fosse uma violenta e furiosa tempestade." - }, - "seedBomb": { - "name": "Seed Bomb", - "effect": "O usuário atira uma barragem de sementes de casca dura acertando o alvo por cima." - }, - "airSlash": { - "name": "Air Slash", - "effect": "O usuário ataca com uma lâmina de ar que corta até mesmo o céu. Isso pode fazer o alvo hesitar." - }, - "xScissor": { - "name": "X-Scissor", - "effect": "O usuário cutila o alvo cruzando suas foices ou garras como se elas fossem um par de tesouras." - }, - "bugBuzz": { - "name": "Bug Buzz", - "effect": "O usuário gera uma dolorosa onda de som. Isso também pode diminuir o atributo de Defesa Especial do alvo." - }, - "dragonPulse": { - "name": "Dragon Pulse", - "effect": "O alvo é atacado com uma onda de choque gerada pela boca aberta do usuário." - }, - "dragonRush": { - "name": "Dragon Rush", - "effect": "O usuário ataca o alvo enquanto demonstra uma ameaça esmagadora. Isso também pode fazer o alvo hesitar." - }, - "powerGem": { - "name": "Power Gem", - "effect": "O usuário ataca com um raio de luz que brilha como se fosse feito de pedras preciosas." - }, - "drainPunch": { - "name": "Drain Punch", - "effect": "Um soco que drena energia. Os PS do usuário são curados pela metade do dano infligido ao alvo." - }, - "vacuumWave": { - "name": "Vacuum Wave", - "effect": "O usuário rodopia seus punhos para lançar uma onda de vácuo puro no alvo. Esse movimento tem prioridade." - }, - "focusBlast": { - "name": "Focus Blast", - "effect": "O usuário eleva seu foco mental e libera o seu poder. Isso também pode diminuir a Defesa Especial do alvo." - }, - "energyBall": { - "name": "Energy Ball", - "effect": "O usuário extrai o poder da natureza e dispara no alvo. Isso também pode diminuir a Defesa Especial do alvo." - }, - "braveBird": { - "name": "Brave Bird", - "effect": "O usuário dobra suas asas e avança de uma baixa altitude. Isso também fere muito o usuário." - }, - "earthPower": { - "name": "Earth Power", - "effect": "O usuário faz o solo debaixo do alvo emergir com poder. Isso também pode diminuir a Defesa Especial do alvo." - }, - "switcheroo": { - "name": "Switcheroo", - "effect": "O usuário troca de itens com o alvo mais rápido do que os olhos podem acompanhar." - }, - "gigaImpact": { - "name": "Giga Impact", - "effect": "O usuário investe no alvo usando absolutamente todo o seu poder. O usuário não poderá se mover no próximo turno." - }, - "nastyPlot": { - "name": "Nasty Plot", - "effect": "O usuário estimula seu cérebro com pensamentos malvados. Isso bruscamente aumenta o Ataque Especial do usuário." - }, - "bulletPunch": { - "name": "Bullet Punch", - "effect": "O usuário atinge o alvo com socos fortes tão rápidos como tiros. Esse movimento tem prioridade." - }, - "avalanche": { - "name": "Avalanche", - "effect": "Um ataque que inflige o dobro do dano caso o usuário já tenha sido ferido pelo alvo no mesmo turno." - }, - "iceShard": { - "name": "Ice Shard", - "effect": "O usuário congela rapidamente cristais de gelo e os arremessa no alvo. Esse movimento tem prioridade." - }, - "shadowClaw": { - "name": "Shadow Claw", - "effect": "O usuário corta com uma garra afiada feita de sombras. Golpes críticos ocorrem mais facilmente." - }, - "thunderFang": { - "name": "Thunder Fang", - "effect": "O usuário morde com presas eletrificadas. Isso também pode fazer o alvo hesitar ou deixá-lo paralisado." - }, - "iceFang": { - "name": "Ice Fang", - "effect": "O usuário morde com presas infundidas com gelo. Isso também pode fazer o alvo hesitar ou deixá-lo congelado." - }, - "fireFang": { - "name": "Fire Fang", - "effect": "O usuário morde com presas cobertas de fogo. Isso também pode fazer o alvo hesitar ou deixá-lo queimado." - }, - "shadowSneak": { - "name": "Shadow Sneak", - "effect": "O usuário estende a própria sombra e ataca o alvo por trás. Esse movimento tem prioridade." - }, - "mudBomb": { - "name": "Mud Bomb", - "effect": "O usuário lança uma bola concentrada de lama para atacar. Isso também pode diminuir a Precisão do alvo." - }, - "psychoCut": { - "name": "Psycho Cut", - "effect": "O usuário corta o alvo com lâminas materializadas com poder psíquico. Golpes críticos ocorrem mais facilmente." - }, - "zenHeadbutt": { - "name": "Zen Headbutt", - "effect": "O usuário foca sua força de vontade em sua cabeça e ataca o alvo. Isso também pode fazer o alvo hesitar." - }, - "mirrorShot": { - "name": "Mirror Shot", - "effect": "O usuário libera um clarão de energia vindo de seu corpo polido no alvo. Isso pode diminuir a Precisão do alvo." - }, - "flashCannon": { - "name": "Flash Cannon", - "effect": "O usuário reúne toda a sua energia de luz e lança de uma só vez. Isso também pode diminuir a Defesa Especial do alvo." - }, - "rockClimb": { - "name": "Rock Climb", - "effect": "O usuário ataca o alvo o esmagando com uma incrível força bruta. Isso pode confundir o alvo." - }, - "defog": { - "name": "Defog", - "effect": "Um vento forte que dispersa as barreiras do alvo como Refletir ou Tela de Luz. Isso também diminui a Evasiva do oponente." - }, - "trickRoom": { - "name": "Trick Room", - "effect": "O usuário cria uma área bizarra onde Pokémon mais lentos se movem primeiro por cinco turnos." - }, - "dracoMeteor": { - "name": "Draco Meteor", - "effect": "Cometas são invocados do céu e caem sobre o alvo. O efeito colateral do ataque duramente prejudica o atributo de Ataque Especial do usuário." - }, - "discharge": { - "name": "Discharge", - "effect": "O usuário atinge tudo ao seu redor liberando uma explosão de eletricidade. Isso também pode causar paralisia." - }, - "lavaPlume": { - "name": "Lava Plume", - "effect": "O usuário queima tudo ao seu redor com um inferno de chamas escarlate. Isso também pode causar uma queimadura em alvos atingidos." - }, - "leafStorm": { - "name": "Leaf Storm", - "effect": "O usuário cria uma tempestade de folhas ao redor do alvo. Isso diminui duramente o Ataque Especial do usuário." - }, - "powerWhip": { - "name": "Power Whip", - "effect": "O usuário rodopia suas vinhas ou tentáculos com vigor para chicotear o alvo cruelmente." - }, - "rockWrecker": { - "name": "Rock Wrecker", - "effect": "O usuário lança uma grande rocha no alvo. O usuário não pode se mover no próximo turno." - }, - "crossPoison": { - "name": "Cross Poison", - "effect": "Um ataque cortante com uma lâmina envenenada que pode envenenar o alvo. Golpes críticos ocorrem mais facilmente." - }, - "gunkShot": { - "name": "Gunk Shot", - "effect": "O usuário atira lixo repugnante no alvo. Isso também pode envenenar o alvo." - }, - "ironHead": { - "name": "Iron Head", - "effect": "O usuário acerta o alvo com sua cabeça dura como aço. Isso também pode fazer o alvo hesitar." - }, - "magnetBomb": { - "name": "Magnet Bomb", - "effect": "O usuário lança bombas de aço que grudam no alvo. Esse ataque nunca erra." - }, - "stoneEdge": { - "name": "Stone Edge", - "effect": "O usuário perfura o alvo por baixo com pedras afiadas. Golpes críticos ocorrem mais facilmente." - }, - "captivate": { - "name": "Captivate", - "effect": "Se algum dos Pokémon oponentes forem do gênero oposto do usuário, ele se encanta, o que diminui duramente o seu Ataque Especial." - }, - "stealthRock": { - "name": "Stealth Rock", - "effect": "O usuário planta armadilhas de pedras levitantes ao redor da equipe oponente. A armadilha fere os Pokémon oponentes que entrarem em campo." - }, - "grassKnot": { - "name": "Grass Knot", - "effect": "O usuário planta uma armadilha com grama e o alvo tropeça nela. Quanto mais pesado o alvo for, maior é o poder do movimento." - }, - "chatter": { - "name": "Chatter", - "effect": "O usuário ataca o alvo com ondas de som vindas de sua tagarelagem ensurdecedora. Isso confunde o alvo." - }, - "judgment": { - "name": "Judgment", - "effect": "O usuário libera incontáveis tiros de luz no alvo. A tipagem desse movimento varia dependendo do tipo de Placa que o usuário está segurando." - }, - "bugBite": { - "name": "Bug Bite", - "effect": "O usuário morde o alvo. Caso o alvo esteja segurando uma Fruta, o usuário a come e ganha seu efeito." - }, - "chargeBeam": { - "name": "Charge Beam", - "effect": "O usuário ataca com uma carga elétrica. O usuário pode usar a eletricidade que sobrar para fortalecer seu Ataque Especial." - }, - "woodHammer": { - "name": "Wood Hammer", - "effect": "O usuário usa seu corpo rígido para golpear o alvo. Isso também fere muito o usuário." - }, - "aquaJet": { - "name": "Aqua Jet", - "effect": "O usuário ataca o alvo em uma velocidade que o torna quase invisível. Esse movimento tem prioridade." - }, - "attackOrder": { - "name": "Attack Order", - "effect": "O usuário ordena que seus subordinados ataquem o alvo. Golpes críticos ocorrem mais facilmente." - }, - "defendOrder": { - "name": "Defend Order", - "effect": "O usuário ordena que seus subordinados protejam seu corpo, aumentando seus atributos de Defesa e Defesa Especial." - }, - "healOrder": { - "name": "Heal Order", - "effect": "O usuário ordena que seus subordinados o curem. O usuário restaura até metade de seus PS máximos." - }, - "headSmash": { - "name": "Head Smash", - "effect": "O usuário usa toda a sua força para acertar uma perigosa cabeçada destrutiva no alvo. Isso também fere terrivelmente o usuário." - }, - "doubleHit": { - "name": "Double Hit", - "effect": "O usuário golpeia o alvo com uma longa cauda, vinhas, ou um tentáculo. O alvo é acertado duas vezes seguidas." - }, - "roarOfTime": { - "name": "Roar of Time", - "effect": "O usuário bombardeia o alvo com tamanho poder que distorce até mesmo o tempo; porém, não se moverá no próximo turno." - }, - "spacialRend": { - "name": "Spacial Rend", - "effect": "O usuário rasga a existência do alvo junto com o espaço ao seu redor. Golpes críticos ocorrem mais facilmente." - }, - "lunarDance": { - "name": "Lunar Dance", - "effect": "O usuário desmaia. Em troca, o Pokémon que tomará seu lugar terá suas condições negativas e PS restaurados." - }, - "crushGrip": { - "name": "Crush Grip", - "effect": "O alvo é esmagado com grande força. Quanto mais PS o alvo possuir, maior será o poder desse movimento." - }, - "magmaStorm": { - "name": "Magma Storm", - "effect": "O alvo é preso dentro de um turbilhão de fogo que arde de quatro a cinco turnos." - }, - "darkVoid": { - "name": "Dark Void", - "effect": "Pokémon oponentes são sugados para dentro de um mundo de total escuridão que os faz dormir." - }, - "seedFlare": { - "name": "Seed Flare", - "effect": "O usuário emite uma onda de choque de seu corpo para atacar o alvo. Isso também pode diminuir duramente a Defesa Especial do alvo." - }, - "ominousWind": { - "name": "Ominous Wind", - "effect": "O usuário ataca o alvo com uma rajada de vento repulsivo. Talvez aumente todos os atributos do usuário de uma vez." - }, - "shadowForce": { - "name": "Shadow Force", - "effect": "O usuário desaparece, então atinge o alvo no próximo turno. Esse movimento acerta o alvo mesmo que ele proteja a si mesmo." - }, - "honeClaws": { - "name": "Hone Claws", - "effect": "O usuário afia suas garras para fortalecer seu Ataque e sua Precisão." - }, - "wideGuard": { - "name": "Wide Guard", - "effect": "O usuário e seus aliados são protegidos de ataques de longo alcance por um turno." - }, - "guardSplit": { - "name": "Guard Split", - "effect": "O usuário usufrui de seu poder psíquico para equalizar seus atributos de Defesa e Defesa Especial com o alvo." - }, - "powerSplit": { - "name": "Power Split", - "effect": "O usuário usufrui de seu poder psíquico para igualar seus atributos de Ataque e Ataque Especial com o alvo." - }, - "wonderRoom": { - "name": "Wonder Room", - "effect": "O usuário cria uma área bizarra onde os atributos de Defesa e Defesa Especial dos Pokémon são trocados por cinco turnos." - }, - "psyshock": { - "name": "Psyshock", - "effect": "O usuário materializa uma estranha onda psíquica para atacar o alvo. Esse ataque inflige dano físico." - }, - "venoshock": { - "name": "Venoshock", - "effect": "O usuário encharca o alvo com um líquido venenoso especial. O poder desse movimento dobra se o alvo estiver envenenado." - }, - "autotomize": { - "name": "Autotomize", - "effect": "O usuário perde parte de seu corpo para se tornar mais leve e bruscamente aumentar seu atributo de Velocidade." - }, - "ragePowder": { - "name": "Rage Powder", - "effect": "O usuário espalha uma nuvem de pó irritante para chamar a atenção para si mesmo. Oponentes miram apenas no usuário." - }, - "telekinesis": { - "name": "Telekinesis", - "effect": "O usuário faz o alvo flutuar usando o seu poder psíquico. O alvo fica propício a ser atingido por três turnos." - }, - "magicRoom": { - "name": "Magic Room", - "effect": "O usuário cria uma área bizarra onde os itens dos Pokémon perdem seus efeitos por cinco turnos." - }, - "smackDown": { - "name": "Smack Down", - "effect": "O usuário atira uma pedra ou algum projétil similar para atacar o oponente. Um Pokémon voador irá cair no chão quando for acertado." - }, - "stormThrow": { - "name": "Storm Throw", - "effect": "O usuário atinge o alvo com um golpe poderoso. Esse ataque sempre resulta em um golpe critico." - }, - "flameBurst": { - "name": "Flame Burst", - "effect": "O usuário ataca o alvo com uma chama explosiva. A explosão da chama também fere os Pokémon próximos ao alvo." - }, - "sludgeWave": { - "name": "Sludge Wave", - "effect": "O usuário atinge tudo à volta inundando a área com uma grande onda de sedimentos. Isso também pode envenenar os atingidos." - }, - "quiverDance": { - "name": "Quiver Dance", - "effect": "O usuário delicadamente executa uma linda dança mística. Isso fortalece os atributos de Ataque Especial, Defesa Especial e Velocidade do usuário." - }, - "heavySlam": { - "name": "Heavy Slam", - "effect": "O usuário golpeia o alvo com seu corpo pesado. Quanto mais pesado o usuário for comparado ao alvo, maior será o poder do movimento." - }, - "synchronoise": { - "name": "Synchronoise", - "effect": "Usando uma estranha onda de choque, o usuário inflige dano em qualquer Pokémon do mesmo tipo na área ao seu redor." - }, - "electroBall": { - "name": "Electro Ball", - "effect": "O usuário arremessa uma esfera elétrica no alvo. Quanto mais rápido for o usuário comparado ao alvo, maior será o poder do movimento." - }, - "soak": { - "name": "Soak", - "effect": "O usuário atira uma corrente de água no alvo e muda a tipagem do alvo para Água." - }, - "flameCharge": { - "name": "Flame Charge", - "effect": "Ocultando-se nas chamas, o usuário ataca. Então, concentrando mais poder, o usuário aumenta sua Velocidade." - }, - "coil": { - "name": "Coil", - "effect": "O usuário enrola seu corpo e se concentra. Isso aumenta seus atributos de Ataque, Defesa e Precisão." - }, - "lowSweep": { - "name": "Low Sweep", - "effect": "O usuário faz um ataque repentino nas pernas do alvo, diminuindo a Velocidade dele." - }, - "acidSpray": { - "name": "Acid Spray", - "effect": "O usuário cospe um fluido corrosivo no alvo. Isso duramente diminui a Defesa Especial do alvo." - }, - "foulPlay": { - "name": "Foul Play", - "effect": "O usuário vira o poder do alvo contra ele. Quanto maior for o atributo de Ataque do alvo, maior será o poder do movimento." - }, - "simpleBeam": { - "name": "Simple Beam", - "effect": "Essa misteriosa onda psíquica produzida pelo usuário muda a Habilidade do alvo para “Simples”." - }, - "entrainment": { - "name": "Entrainment", - "effect": "O usuário dança em um ritmo estranho que contagia o alvo que o imita, fazendo a Habilidade do alvo tornar-se a mesma que a do usuário." - }, - "afterYou": { - "name": "After You", - "effect": "O usuário auxilia o alvo e o faz usar seu movimento exatamente após o usuário." - }, - "round": { - "name": "Round", - "effect": "O usuário ataca o alvo com uma música. Outros podem entrar na Ronda e fazer o ataque dar um dano ainda maior." - }, - "echoedVoice": { - "name": "Echoed Voice", - "effect": "O usuário ataca o alvo com uma voz ecoante. Se esse movimento for usado um turno após o outro, ele infligirá dano maior." - }, - "chipAway": { - "name": "Chip Away", - "effect": "Procurando por uma brecha, o usuário ataca consistentemente. As mudanças de atributos do alvo não afetam o dano desse movimento." - }, - "clearSmog": { - "name": "Clear Smog", - "effect": "O usuário ataca arremessando um amontoado de lama especial. Todas as mudanças de atributos voltam ao normal." - }, - "storedPower": { - "name": "Stored Power", - "effect": "O usuário ataca o alvo com seu poder armazenado. Quanto mais os atributos do usuário estiverem fortalecidos, maior será o poder do movimento." - }, - "quickGuard": { - "name": "Quick Guard", - "effect": "O usuário protege a si mesmo e seus aliados de golpes de prioridade." - }, - "allySwitch": { - "name": "Ally Switch", - "effect": "O usuário teletransporta usando um estranho poder e troca de lugar com um de seus aliados." - }, - "scald": { - "name": "Scald", - "effect": "O usuário atira água fervente no seu alvo. Isso também pode deixar o alvo com queimadura." - }, - "shellSmash": { - "name": "Shell Smash", - "effect": "O usuário quebra a própria concha, diminuindo sua Defesa e Defesa Especial, mas bruscamente aumentando Ataque, Ataque Especial e Velocidade." - }, - "healPulse": { - "name": "Heal Pulse", - "effect": "O usuário emite um pulso curativo que restaura os PS do alvo pela metade de seus PS máximos." - }, - "hex": { - "name": "Hex", - "effect": "Esse ataque cruel inflige dano massivo a um alvo afetado por condições negativas." - }, - "skyDrop": { - "name": "Sky Drop", - "effect": "O usuário leva o alvo para o céu, então o solta durante o próximo turno. O alvo não pode atacar enquanto estiver no céu." - }, - "shiftGear": { - "name": "Shift Gear", - "effect": "O usuário roda suas engrenagens, aumentando seu Ataque e bruscamente aumentando sua Velocidade." - }, - "circleThrow": { - "name": "Circle Throw", - "effect": "O alvo é arremessado, e um Pokémon diferente é trazido para a batalha. Na natureza, isso termina uma batalha contra um único Pokémon." - }, - "incinerate": { - "name": "Incinerate", - "effect": "O usuário ataca o Pokémon oponente com fogo. Se um Pokémon estiver segurando um certo item, como uma Fruta, o item será queimado e inutilizado." - }, - "quash": { - "name": "Quash", - "effect": "O usuário reprime o alvo e o faz se mover por último." - }, - "acrobatics": { - "name": "Acrobatics", - "effect": "O usuário atinge o alvo rapidamente. Se o usuário não estiver segurando um item, esse ataque causa um dano massivo." - }, - "reflectType": { - "name": "Reflect Type", - "effect": "O usuário reflete o tipo do alvo, fazendo-o ter o mesmo tipo do alvo." - }, - "retaliate": { - "name": "Retaliate", - "effect": "O usuário se vinga por um aliado desmaiado. Se um aliado desmaiou no turno anterior, esse movimento ficará mais poderoso." - }, - "finalGambit": { - "name": "Final Gambit", - "effect": "O usuário arrisca tudo para atacar seu alvo. O usuário desmaia porém inflige dano igual aos seus PS perdidos." - }, - "bestow": { - "name": "Bestow", - "effect": "O usuário passa seu item ao alvo se o alvo não estiver segurando um item." - }, - "inferno": { - "name": "Inferno", - "effect": "O usuário ataca engolindo o alvo em intensas chamas. intense fire. Isso deixa o alvo com uma queimadura." - }, - "waterPledge": { - "name": "Water Pledge", - "effect": "Um pilar de água atinge o alvo. Quando combinado com seu equivalente do tipo fogo, seu dano aumenta e um arco-íris é formado." - }, - "firePledge": { - "name": "Fire Pledge", - "effect": "Um pilar de fogo atinge o alvo. Quando combinado com seu equivalente do tipo Planta, seu dano aumenta e um vasto mar de fogo aparece." - }, - "grassPledge": { - "name": "Grass Pledge", - "effect": "Um pilar de grama acerta o alvo. Quando combinado com seu equivalente do tipo Água, seu dano aumenta e um vasto pântano surge." - }, - "voltSwitch": { - "name": "Volt Switch", - "effect": "Depois de fazer o seu ataque, o usuário corre de volta para trocar de lugar com um Pokémon da própria equipe." - }, - "struggleBug": { - "name": "Struggle Bug", - "effect": "Enquanto resiste, o usuário ataca o Pokémon oponente. Isso diminui o Ataque Especial daqueles atingidos." - }, - "bulldoze": { - "name": "Bulldoze", - "effect": "O usuário atinge a todos ao seu redor pisoteando o chão. Isso diminui a Velocidade daqueles atingidos." - }, - "frostBreath": { - "name": "Frost Breath", - "effect": "O usuário sopra sua respiração gelada no alvo. Esse ataque sempre resulta em um acerto crítico." - }, - "dragonTail": { - "name": "Dragon Tail", - "effect": "O alvo é arremessado e um Pokémon diferente é trazido para o combate. Em batalhas selvagens, isso encerra a batalha contra um único Pokémon." - }, - "workUp": { - "name": "Work Up", - "effect": "O usuário se agita e seus atributos de Ataque e Ataque Especial são fortalecidos." - }, - "electroweb": { - "name": "Electroweb", - "effect": "O usuário ataca e captura os Pokémon adversários usando uma rede elétrica. Isso diminui a Velocidade deles." - }, - "wildCharge": { - "name": "Wild Charge", - "effect": "O usuário se cobre de eletricidade e colide com o seu alvo. Isso também fere um pouco o usuário." - }, - "drillRun": { - "name": "Drill Run", - "effect": "O usuário colide com seu alvo enquanto rotaciona seu corpo como uma broca. Golpes críticos acertam mais facilmente." - }, - "dualChop": { - "name": "Dual Chop", - "effect": "O usuário ataca o seu alvo o acertando com golpes brutais. O alvo é atingido duas vezes seguidas." - }, - "heartStamp": { - "name": "Heart Stamp", - "effect": "O usuário libera sua fúria em um golpe violento após enganar o alvo com sua atuação fofa. Isso também pode fazer o alvo hesitar." - }, - "hornLeech": { - "name": "Horn Leech", - "effect": "O usuário drena a energia do alvo com seus chifres. Os PS do usuário são restaurados pela metade do dano recebido pelo alvo." - }, - "sacredSword": { - "name": "Sacred Sword", - "effect": "O usuário ataca cortando com um longo chifre. As mudanças de atributos do alvo não afetam o dano desse ataque." - }, - "razorShell": { - "name": "Razor Shell", - "effect": "O usuário corta seu alvo com conchas afiadas. Isso pode também diminuir o atributo de Defesa do alvo." - }, - "heatCrash": { - "name": "Heat Crash", - "effect": "O usuário golpeia seu alvo com seu corpo envolto em chamas. Quanto mais pesado o usuário for comparado ao alvo, maior será o poder do movimento." - }, - "leafTornado": { - "name": "Leaf Tornado", - "effect": "O usuário ataca seu alvo cercando-o com folhas afiadas. Isso também pode diminuir a precisão do alvo." - }, - "steamroller": { - "name": "Steamroller", - "effect": "O usuário esmaga seu alvo rolando sobre ele com seu corpo enrolado como uma bola. Isso também pode fazer o alvo hesitar." - }, - "cottonGuard": { - "name": "Cotton Guard", - "effect": "O usuário protege a si mesmo envolvendo seu corpo em algodão macio, o que drasticamente aumenta o atributo de Defesa do usuário." - }, - "nightDaze": { - "name": "Night Daze", - "effect": "O usuário libera uma onda de choque escura como a noite no alvo. Isso também pode reduzir a Precisão do alvo." - }, - "psystrike": { - "name": "Psystrike", - "effect": "O usuário materializa uma estranha onda psíquica para atacar o alvo. Esse ataque inflige dano físico." - }, - "tailSlap": { - "name": "Tail Slap", - "effect": "O usuário ataca golpeando o alvo com sua cauda resistente. Isso acerta o alvo duas a cinco vezes seguidas." - }, - "hurricane": { - "name": "Hurricane", - "effect": "O usuário ataca prendendo seu oponente num violento turbilhão que voa alto no céu. Isso também pode confundir o alvo." - }, - "headCharge": { - "name": "Head Charge", - "effect": "O usuário ataca colidindo sua cabeça no alvo, usando sua pelagem protetora. Isso também fere um pouco o usuário." - }, - "gearGrind": { - "name": "Gear Grind", - "effect": "O usuário ataca arremessando engrenagens de aço no seu alvo duas vezes em sequência." - }, - "searingShot": { - "name": "Searing Shot", - "effect": "O usuário queima tudo ao seu redor com um inferno de chamas escarlate. Isso também pode causar uma queimadura em alvos atingidos." - }, - "technoBlast": { - "name": "Techno Blast", - "effect": "O usuário atira um raio de luz em seu alvo. O tipo do movimento muda dependendo do Disco que o usuário estiver segurando." - }, - "relicSong": { - "name": "Relic Song", - "effect": "O usuário canta uma antiga canção e ataca encantando o coração dos Pokémon adversários. Isso também pode induzir sono." - }, - "secretSword": { - "name": "Secret Sword", - "effect": "O usuário ataca cortando com seu longo chifre. O estranho poder contido no chifre inflige dano físico no alvo." - }, - "glaciate": { - "name": "Glaciate", - "effect": "O usuário ataca soprando ar congelante nos Pokémon oponentes. Isso diminui a Velocidade deles." - }, - "boltStrike": { - "name": "Bolt Strike", - "effect": "O usuário cobre a si mesmo com uma grande quantidade de eletricidade e avança no alvo. Isso também pode paralisar o alvo." - }, - "blueFlare": { - "name": "Blue Flare", - "effect": "O usuário ataca engolindo o alvo numa intensa, porém linda, chama azul. Isso também pode deixar o alvo com uma queimadura." - }, - "fieryDance": { - "name": "Fiery Dance", - "effect": "Coberto por chamas, o usuário dança e bate suas asas. Isso também pode aumentar o Ataque Especial do usuário." - }, - "freezeShock": { - "name": "Freeze Shock", - "effect": "No segundo turno, o usuário acerta o alvo com gelo eletricamente carregado. Isso também pode deixar o alvo paralisado." - }, - "iceBurn": { - "name": "Ice Burn", - "effect": "No segundo turno, um impiedoso vento gélido cerca o alvo. Isso pode deixar o alvo com uma queimadura." - }, - "snarl": { - "name": "Snarl", - "effect": "O usuário grita como se ele estivesse reclamando de algo, diminuindo o Ataque Especial do Pokémon oponente." - }, - "icicleCrash": { - "name": "Icicle Crash", - "effect": "O usuário ataca arremessando estacas de gelo no alvo violentamente. Isso também pode fazer o alvo hesitar." - }, - "vCreate": { - "name": "V-create", - "effect": "Com uma ardente chama em sua testa, o usuário joga seu corpo em direção ao alvo. Isso diminui a Defesa, Defesa Especial, e Velocidade do usuário." - }, - "fusionFlare": { - "name": "Fusion Flare", - "effect": "O usuário invoca uma chama gigante. Esse movimento é mais poderoso quando influenciado por um enorme raio." - }, - "fusionBolt": { - "name": "Fusion Bolt", - "effect": "O usuário conduz um raio gigantesco. Esse movimento é mais poderoso quando influenciado por uma enorme chama." - }, - "flyingPress": { - "name": "Flying Press", - "effect": "O usuário mergulha do céu em direção ao alvo. Esse movimento é simultaneamente do tipo Lutador e Voador." - }, - "matBlock": { - "name": "Mat Block", - "effect": "Usando uma esteira elevada como escudo, o usuário protege a si mesmo e a seus aliados de golpes que causam dano. Isso não previne condições negativas." - }, - "belch": { - "name": "Belch", - "effect": "O usuário expurga um arroto danificante no alvo. O usuário deve comer uma Fruta para usar esse movimento." - }, - "rototiller": { - "name": "Rototiller", - "effect": "O usuário ara o solo, facilitando o crescimento de plantas. Isso aumenta os atributos de Ataque e Ataque Especial dos Pokémon do tipo Planta." - }, - "stickyWeb": { - "name": "Sticky Web", - "effect": "O usuário tece uma teia viscosa ao redor da equipe adversária, o que diminui a Velocidade dos adversários após entrarem em campo." - }, - "fellStinger": { - "name": "Fell Stinger", - "effect": "Quando o usuário nocauteia um alvo com este movimento, o atributo de Ataque do usuário aumenta bruscamente." - }, - "phantomForce": { - "name": "Phantom Force", - "effect": "O usuário desaparece para algum lugar e então ataca o alvo no próximo turno. Esse movimento acerta mesmo se o alvo estiver se protegendo." - }, - "trickOrTreat": { - "name": "Trick-or-Treat", - "effect": "O usuário enche o alvo com o espírito do Halloween para celebrarem juntos. Isso adiciona o tipo Fantasma à tipagem do alvo." - }, - "nobleRoar": { - "name": "Noble Roar", - "effect": "Soltando um nobre rugido, o usuário intimida o alvo e diminui seus atributos de Ataque e Ataque Especial." - }, - "ionDeluge": { - "name": "Ion Deluge", - "effect": "O usuário dispersa partículas eletricamente carregadas, o que muda movimentos do tipo Normal para o tipo Elétrico." - }, - "parabolicCharge": { - "name": "Parabolic Charge", - "effect": "O usuário ataca tudo ao seu redor. Os PS do usuário são restaurados pela metade do dano recebido por aqueles que foram atingidos." - }, - "forestsCurse": { - "name": "Forest's Curse", - "effect": "O usuário conjura uma maldição da floresta no alvo. Isso adiciona o tipo Planta à tipagem do alvo." - }, - "petalBlizzard": { - "name": "Petal Blizzard", - "effect": "O usuário rotaciona uma violenta nevasca composta por pétalas e ataca tudo ao seu redor." - }, - "freezeDry": { - "name": "Freeze-Dry", - "effect": "O usuário rapidamente diminui a temperatura do alvo. Isso pode deixar o alvo congelado. Esse movimento é supereficaz contra tipos Água." - }, - "disarmingVoice": { - "name": "Disarming Voice", - "effect": "Liberando um grito encantador, o usuário inflige dano emocional nos Pokémon oponentes. Esse ataque nunca erra." - }, - "partingShot": { - "name": "Parting Shot", - "effect": "O usuário diminui os atributos de Ataque e Ataque Esp. do alvo com uma ameaça antes de ser trocado por outro Pokémon na equipe." - }, - "topsyTurvy": { - "name": "Topsy-Turvy", - "effect": "Todas as mudanças de atributos afetando o alvo viram de cabeça para baixo e se tornam o oposto do que eram." - }, - "drainingKiss": { - "name": "Draining Kiss", - "effect": "O usuário rouba a energia do alvo com um beijo. Os PS do usuário são restaurados além da metade do dano recebido pelo alvo." - }, - "craftyShield": { - "name": "Crafty Shield", - "effect": "O usuário protege a si mesmo e seus aliados de condições negativas com um misterioso poder. Isso não previne golpes que inflijam dano." - }, - "flowerShield": { - "name": "Flower Shield", - "effect": "Usando um misterioso poder, o usuário aumenta o atributo de Defesa de todos os Pokémon tipo Planta em batalha." - }, - "grassyTerrain": { - "name": "Grassy Terrain", - "effect": "O usuário transforma o campo de batalha em grama por cinco turnos. Isso restaura os PS dos Pokémon no solo um pouco a cada turno e fortalece golpes do tipo Grama." - }, - "mistyTerrain": { - "name": "Misty Terrain", - "effect": "Isto protege os Pokémon no solo de condições de estado e corta pela metade o dano dos movimentos do tipo Dragão por cinco turnos." - }, - "electrify": { - "name": "Electrify", - "effect": "Caso o alvo tenha sido energizado antes de usar um movimento durante aquele turno, o movimento do alvo se tornará do tipo Elétrico." - }, - "playRough": { - "name": "Play Rough", - "effect": "O usuário joga duro com o alvo e o ataca. Isso também pode diminuir o atributo de Ataque do alvo." - }, - "fairyWind": { - "name": "Fairy Wind", - "effect": "O usuário rotaciona um vento de fada e ataca o alvo com ele." - }, - "moonblast": { - "name": "Moonblast", - "effect": "Canalizando o poder da lua, o usuário ataca o alvo. Isso também pode diminuir o atributo de Ataque Especial do alvo." - }, - "boomburst": { - "name": "Boomburst", - "effect": "O usuário ataca tudo ao seu redor com o poder destrutivo de um terrível som explosivo." - }, - "fairyLock": { - "name": "Fairy Lock", - "effect": "Bloqueando o campo de batalha, o usuário previne que todos os Pokémon fujam durante o próximo turno." - }, - "kingsShield": { - "name": "King's Shield", - "effect": "O usuário assume uma posição defensiva enquanto protege a si mesmo de dano. Isto duramente diminui o Ataque de qualquer um que faça contato direto." - }, - "playNice": { - "name": "Play Nice", - "effect": "O usuário e o alvo se tornam amigos, fazendo com que o alvo perca sua vontade de lutar. Isso diminui o atributo de Ataque do alvo." - }, - "confide": { - "name": "Confide", - "effect": "O usuário conta um segredo para o alvo e o alvo perde sua habilidade de se concentrar. Isso diminui o Ataque Especial do alvo." - }, - "diamondStorm": { - "name": "Diamond Storm", - "effect": "O usuário provoca uma tempestade de diamantes para ferir os Pokémon oponentes. Isso também pode aumentar o atributo de Defesa do usuário." - }, - "steamEruption": { - "name": "Steam Eruption", - "effect": "O usuário imerge o alvo em vapor superaquecido. Isso também pode deixar o alvo com uma queimadura." - }, - "hyperspaceHole": { - "name": "Hyperspace Hole", - "effect": "Usando uma fenda espacial, o usuário aparece ao lado do alvo e ataca. Isso também acerta um alvo usando movimentos como Proteger ou Detectar." - }, - "waterShuriken": { - "name": "Water Shuriken", - "effect": "O usuário acerta o alvo jogando estrelas ninja de duas a cinco vezes seguidas. Esse movimento tem prioridade." - }, - "mysticalFire": { - "name": "Mystical Fire", - "effect": "O usuário ataca soprando um fogo ardente especial. Isso também diminui o Ataque Especial do alvo." - }, - "spikyShield": { - "name": "Spiky Shield", - "effect": "Além de proteger o alvo de ataques, este movimento também fere qualquer atacante que fizer contato direto." - }, - "aromaticMist": { - "name": "Aromatic Mist", - "effect": "Usando um misterioso aroma, o usuário aumenta o atributo de Defesa Especial de um Pokémon aliado." - }, - "eerieImpulse": { - "name": "Eerie Impulse", - "effect": "O corpo do usuário gera um impulso misterioso. O alvo exposto ao impulso tem seu Ataque Especial duramente diminuído." - }, - "venomDrench": { - "name": "Venom Drench", - "effect": "Pokémon oponentes são encharcados por um estranho líquido venenoso. Isso diminui o Ataque, Ataque Esp. e Velocidade de um alvo envenenado." - }, - "powder": { - "name": "Powder", - "effect": "O usuário cobre o alvo em pólvora. Se o alvo usar um movimento do tipo Fogo, a pólvora entra em combustão e causa dano ao alvo." - }, - "geomancy": { - "name": "Geomancy", - "effect": "O usuário absorve energia e bruscamente aumenta seus atributos de Ataque Especial, Defesa Especial e Velocidade no próximo turno." - }, - "magneticFlux": { - "name": "Magnetic Flux", - "effect": "O usuário manipula campos magnéticos, o que aumenta os atributos de Defesa e Defesa Especial de Pokémon aliados com as Habilidades “Mais” ou “Menos”." - }, - "happyHour": { - "name": "Happy Hour", - "effect": "Usar Happy Hour dobra a quantidade de prêmio em dinheiro recebido após a batalha." - }, - "electricTerrain": { - "name": "Electric Terrain", - "effect": "O usuário eletrifica o campo de batalha por cinco turnos, fortalecendo movimentos do tipo Elétrico. Pokémon no solo não podem mais cair no sono." - }, - "dazzlingGleam": { - "name": "Dazzling Gleam", - "effect": "O usuário causa dano ao Pokémon oponente emitindo um clarão poderoso." - }, - "celebrate": { - "name": "Celebrate", - "effect": "O Pokémon te dá parabéns pelo seu dia especial!" - }, - "holdHands": { - "name": "Hold Hands", - "effect": "O usuário e um aliado dão as mãos. Isso os deixam muito contentes." - }, - "babyDollEyes": { - "name": "Baby-Doll Eyes", - "effect": "O usuário encara o alvo com seus olhos adoráveis, o que diminui seu atributo de Ataque. Esse movimento tem prioridade." - }, - "nuzzle": { - "name": "Nuzzle", - "effect": "O usuário ataca esfregando suas bochechas eletrizadas contra o alvo. Isso também deixa o alvo paralisado." - }, - "holdBack": { - "name": "Hold Back", - "effect": "O usuário pega leve quando ataca e o alvo é deixado com pelo menos 1 PS." - }, - "infestation": { - "name": "Infestation", - "effect": "O alvo é infestado e atacado de quatro a cinco turnos. O alvo não pode fugir durante esse período." - }, - "powerUpPunch": { - "name": "Power-Up Punch", - "effect": "Golpear oponentes repetidamente faz os punhos do usuário enrijecerem. Acertar um alvo aumenta o Ataque." - }, - "oblivionWing": { - "name": "Oblivion Wing", - "effect": "O usuário absorve os PS de seu alvo. Os PS do usuário são restaurados além da metade do dano recebido pelo usuário." - }, - "thousandArrows": { - "name": "Thousand Arrows", - "effect": "Este movimento também acerta Pokémon adversários que estão no ar. Esses Pokémon são derrubados e caem no chão." - }, - "thousandWaves": { - "name": "Thousand Waves", - "effect": "O usuário ataca com tremores que se dispersam pelo chão. Alvos atingidos não podem fugir da batalha." - }, - "landsWrath": { - "name": "Land's Wrath", - "effect": "O usuário reúne a energia da terra e foca esse poder nos Pokémon oponentes para causar dano." - }, - "lightOfRuin": { - "name": "Light of Ruin", - "effect": "Usufruindo do poder da flor eterna, o usuário atira um poderoso raio de luz. Isso também fere muito o usuário." - }, - "originPulse": { - "name": "Origin Pulse", - "effect": "O usuário ataca o Pokémon adversário com inúmeros raios de luz resplandescente que brilham em uma cor de profundo azul." - }, - "precipiceBlades": { - "name": "Precipice Blades", - "effect": "O usuário ataca o Pokémon adversário manifestando o poder terrestre em espadas de pedra assustadoras." - }, - "dragonAscent": { - "name": "Dragon Ascent", - "effect": "Depois de alcançar grandes alturas, o usuário ataca o alvo mergulhando do céu em alta velocidade, porém isso diminui sua própria Defesa e Defesa Especial." - }, - "hyperspaceFury": { - "name": "Hyperspace Fury", - "effect": "Usando seus diversos braços, o usuário libera golpes furiosos que ignoram efeitos de movimentos como Proteção e Detectar. Diminui a Defesa do usuário." - }, - "breakneckBlitzPhysical": { - "name": "Breakneck Blitz", - "effect": "Utilizando o Poder Z, o usuário intensifica seu ímpeto e atinge o alvo em alta velocidade. Seu poder varia dependendo do movimento original." - }, - "breakneckBlitzSpecial": { - "name": "Breakneck Blitz", - "effect": "Dummy Data" - }, - "allOutPummelingPhysical": { - "name": "All-Out Pummeling", - "effect": "Utilizando o Poder Z, o usuário cria e arremessa uma esfera de energia no alvo com força total. Seu poder varia dependendo do movimento original." - }, - "allOutPummelingSpecial": { - "name": "All-Out Pummeling", - "effect": "Dummy Data" - }, - "supersonicSkystrikePhysical": { - "name": "Supersonic Skystrike", - "effect": "Utilizando o Poder Z, o usuário ascende e mergulha em direção ao alvo em alta velocidade. Seu poder varia dependendo do movimento original." - }, - "supersonicSkystrikeSpecial": { - "name": "Supersonic Skystrike", - "effect": "Dummy Data" - }, - "acidDownpourPhysical": { - "name": "Acid Downpour", - "effect": "Utilizando o Poder Z, o usuário cria um pântano venenoso e afoga o alvo com toda sua força. Seu poder varia dependendo do movimento original." - }, - "acidDownpourSpecial": { - "name": "Acid Downpour", - "effect": "Dummy Data" - }, - "tectonicRagePhysical": { - "name": "Tectonic Rage", - "effect": "Utilizando o Poder Z, o usuário abre uma cratera e mergulha nela com o alvo com força total. Seu poder varia dependendo do movimento original." - }, - "tectonicRageSpecial": { - "name": "Tectonic Rage", - "effect": "Dummy Data" - }, - "continentalCrushPhysical": { - "name": "Continental Crush", - "effect": "Utilizando o Poder Z, o usuário cria um meteoro que cai do céu em direção ao alvo com força total. Seu poder varia dependendo do movimento original." - }, - "continentalCrushSpecial": { - "name": "Continental Crush", - "effect": "Dummy Data" - }, - "savageSpinOutPhysical": { - "name": "Savage Spin-Out", - "effect": "Utilizando o Poder Z, o usuário restringe o alvo em um casulo de seda e ataca ele com força total. Seu poder varia dependendo do movimento original." - }, - "savageSpinOutSpecial": { - "name": "Savage Spin-Out", - "effect": "Dummy Data" - }, - "neverEndingNightmarePhysical": { - "name": "Never-Ending Nightmare", - "effect": "Utilizando o Poder Z, o usuário invoca espectros rancorosos que sufocam o alvo. Seu poder varia dependendo do movimento original." - }, - "neverEndingNightmareSpecial": { - "name": "Never-Ending Nightmare", - "effect": "Dummy Data" - }, - "corkscrewCrashPhysical": { - "name": "Corkscrew Crash", - "effect": "Utilizando o Poder Z, o usuário gira rapidamente e ataca o alvo com força total. Seu poder varia dependendo do movimento original." - }, - "corkscrewCrashSpecial": { - "name": "Corkscrew Crash", - "effect": "Dummy Data" - }, - "infernoOverdrivePhysical": { - "name": "Inferno Overdrive", - "effect": "Utilizando o Poder Z, o usuário cospe uma enorme labareda ardente contra o alvo com força total. Seu poder varia dependendo do movimento original." - }, - "infernoOverdriveSpecial": { - "name": "Inferno Overdrive", - "effect": "Dummy Data" - }, - "hydroVortexPhysical": { - "name": "Hydro Vortex", - "effect": "Utilizando o Poder Z, o usuário cria um intenso turbilhão que engole o alvo com força total. Seu poder varia dependendo do movimento original." - }, - "hydroVortexSpecial": { - "name": "Hydro Vortex", - "effect": "Dummy Data" - }, - "bloomDoomPhysical": { - "name": "Bloom Doom", - "effect": "Utilizando o Poder Z, o usuário absorve a energia vital do ambiente e ataca o alvo com força total. Seu poder varia dependendo do movimento original." - }, - "bloomDoomSpecial": { - "name": "Bloom Doom", - "effect": "Dummy Data" - }, - "gigavoltHavocPhysical": { - "name": "Gigavolt Havoc", - "effect": "Utilizando o Poder Z, o usuário concentra uma corrente elétrica carregada e atinge o alvo. Seu poder varia dependendo do movimento original." - }, - "gigavoltHavocSpecial": { - "name": "Gigavolt Havoc", - "effect": "Dummy Data" - }, - "shatteredPsychePhysical": { - "name": "Shattered Psyche", - "effect": "Utilizando o Poder Z, o usuário manipula a cabeça do alvo e destrói-o mentalmente. Seu poder varia dependendo do movimento original." - }, - "shatteredPsycheSpecial": { - "name": "Shattered Psyche", - "effect": "Dummy Data" - }, - "subzeroSlammerPhysical": { - "name": "Subzero Slammer", - "effect": "Utilizando o Poder Z, o usuário lança um raio de gelo que reduz a temperatura do alvo a zero. Seu poder varia dependendo do movimento original." - }, - "subzeroSlammerSpecial": { - "name": "Subzero Slammer", - "effect": "Dummy Data" - }, - "devastatingDrakePhysical": { - "name": "Devastating Drake", - "effect": "Utilizando o Poder Z, o usuário materializa sua aura, que ataca o alvo com força total. Seu poder varia dependendo do movimento original." - }, - "devastatingDrakeSpecial": { - "name": "Devastating Drake", - "effect": "Dummy Data" - }, - "blackHoleEclipsePhysical": { - "name": "Black Hole Eclipse", - "effect": "Utilizando o Poder Z, o usuário cria um buraco negro que engole o alvo. Seu poder varia dependendo do movimento original." - }, - "blackHoleEclipseSpecial": { - "name": "Black Hole Eclipse", - "effect": "Dummy Data" - }, - "twinkleTacklePhysical": { - "name": "Twinkle Tackle", - "effect": "Utilizando o Poder Z, o usuário cria uma dimensão graciosa que deixa o alvo a sua mercê. Seu poder varia dependendo do movimento original." - }, - "twinkleTackleSpecial": { - "name": "Twinkle Tackle", - "effect": "Dummy Data" - }, - "catastropika": { - "name": "Catastropika", - "effect": "Utilizando seu Poder Z, Pikachu acumula o máximo de eletricidade que seu corpo suporta e pula no alvo com força total." - }, - "shoreUp": { - "name": "Shore Up", - "effect": "Recupera metade dos PS do usuário. Durante uma Tempestade de Areia, recupera um pouco mais." - }, - "firstImpression": { - "name": "First Impression", - "effect": "Embora esse movimento seja poderoso, ele funciona apenas na primeira rodada em que o usuário está em batalha." - }, - "banefulBunker": { - "name": "Baneful Bunker", - "effect": "Além de proteger o usuário de ataques, este movimento também envenena qualquer um que fizer contato direto." - }, - "spiritShackle": { - "name": "Spirit Shackle", - "effect": "O usuário ataca enquanto fisga simultaneamente a sombra do alvo e impede ele de escapar." - }, - "darkestLariat": { - "name": "Darkest Lariat", - "effect": "O usuário balança os dois braços e acerta o alvo. As mudanças de atributos do alvo não afetam o dano deste ataque." - }, - "sparklingAria": { - "name": "Sparkling Aria", - "effect": "Libera borbulhas ao cantar. Se um Pokémon estiver queimado, ele será curado pelo toque das bolhas." - }, - "iceHammer": { - "name": "Ice Hammer", - "effect": "O usuário gira seu corpo e bate com seus fortes e pesados punhos. Isso diminui a Velocidade do usuário." - }, - "floralHealing": { - "name": "Floral Healing", - "effect": "O usuário restaura os PS do alvo até metade a dos seus PS máximo. Ele restaura mais HP quando o terreno é de grama." - }, - "highHorsepower": { - "name": "High Horsepower", - "effect": "O usuário ataca ferozmente o alvo usando todo o seu corpo." - }, - "strengthSap": { - "name": "Strength Sap", - "effect": "O usuário restaura seus PS em uma quantidade igual ao atributo de Ataque do alvo. Também diminui o atributo de Ataque do alvo." - }, - "solarBlade": { - "name": "Solar Blade", - "effect": "O usuário absorve luz e concentra-a em forma de lâmina com a energia absorvida no primeiro turno e atacando o alvo no próximo turno." - }, - "leafage": { - "name": "Leafage", - "effect": "O usuário ataca lançando folhas no alvo." - }, - "spotlight": { - "name": "Spotlight", - "effect": "O usuário direciona o foco no alvo para que apenas ele seja atacado durante o turno." - }, - "toxicThread": { - "name": "Toxic Thread", - "effect": "O usuário dispara fios venenosos para envenenar o alvo e diminuir sua Velocidade." - }, - "laserFocus": { - "name": "Laser Focus", - "effect": "O usuário se concentra intensamente. O ataque no próximo turno sempre resultará em um acerto crítico." - }, - "gearUp": { - "name": "Gear Up", - "effect": "O usuário engata suas engrenagens para aumentar os atributos de Ataque e Ataque Esp. de Pokémon aliados com as Habilidades Mais ou Menos." - }, - "throatChop": { - "name": "Throat Chop", - "effect": "O usuário acerta a garganta do alvo, e a dor resultante impede que o alvo use movimentos que emitam som por dois turnos." - }, - "pollenPuff": { - "name": "Pollen Puff", - "effect": "O usuário ataca o inimigo com uma bola de pólen explosiva. Se o alvo for um aliado, ele recebe uma bola de pólen que restaura seus PS em vez disso." - }, - "anchorShot": { - "name": "Anchor Shot", - "effect": "O usuário revolve o alvo com a corrente de sua âncora enquanto ataca. O alvo se torna incapaz de fugir." - }, - "psychicTerrain": { - "name": "Psychic Terrain", - "effect": "Protege o Pokémon no terreno de movimentos de prioridade e aumenta o poder dos movimentos do tipo Psíquico por cinco turnos." - }, - "lunge": { - "name": "Lunge", - "effect": "O usuário faz uma estocada no alvo, atacando com força total. Isso também diminui o Ataque do alvo." - }, - "fireLash": { - "name": "Fire Lash", - "effect": "O usuário atinge o alvo com um chicote em chamas. Também diminui a Defesa do alvo." - }, - "powerTrip": { - "name": "Power Trip", - "effect": "O usuário ostenta sua força e ataca o alvo. Quanto mais os atributos do usuário forem aumentados, maior será o poder do movimento." - }, - "burnUp": { - "name": "Burn Up", - "effect": "Para infligir um dano massivo, o usuário se exaure. Após usar esse movimento, o usuário não será mais do tipo Fogo." - }, - "speedSwap": { - "name": "Speed Swap", - "effect": "O usuário troca os atributos de Velocidade com o alvo." - }, - "smartStrike": { - "name": "Smart Strike", - "effect": "O usuário perfura o alvo com um chifre afiado. Esse ataque nunca erra." - }, - "purify": { - "name": "Purify", - "effect": "O usuário cura a condição de estado do alvo. Se o movimento for bem-sucedido, também recupera os PS do usuário." - }, - "revelationDance": { - "name": "Revelation Dance", - "effect": "O usuário ataca o alvo dançando intensamente. O tipo do usuário determina o tipo deste movimento." - }, - "coreEnforcer": { - "name": "Core Enforcer", - "effect": "Se os Pokémon nos quais o usuário causou dano já tiverem usado seus movimentos, esse movimento elimina o efeito da Habilidade do alvo." - }, - "tropKick": { - "name": "Trop Kick", - "effect": "O usuário desfere um chute intenso de origens tropicais no alvo. Também diminui o Ataque do alvo." - }, - "instruct": { - "name": "Instruct", - "effect": "O usuário instrui o alvo a usar novamente o seu último movimento usado." - }, - "beakBlast": { - "name": "Beak Blast", - "effect": "O usuário aquece o bico e depois ataca o alvo. Fazer contato direto com o Pokémon enquanto ele aquece o bico resultará em queimadura." - }, - "clangingScales": { - "name": "Clanging Scales", - "effect": "O usuário esfrega as escamas de todo o seu corpo e faz um estrondo para machucar o Pokémon oponente. A Defesa do usuário diminui após o ataque." - }, - "dragonHammer": { - "name": "Dragon Hammer", - "effect": "O usuário usa seu corpo como um martelo para atacar o alvo e causar dano." - }, - "brutalSwing": { - "name": "Brutal Swing", - "effect": "O usuário balança o corpo violentamente para infligir dano a tudo em seu redor." - }, - "auroraVeil": { - "name": "Aurora Veil", - "effect": "Esse movimento reduz o dano de movimentos físicos e especiais por cinco turnos. Só pode ser usado durante uma tempestade de granizo." - }, - "sinisterArrowRaid": { - "name": "Sinister Arrow Raid", - "effect": "Utilizando o Poder Z, Decidueye cria incontáveis flechas e dispara-as contra o alvo com força total." - }, - "maliciousMoonsault": { - "name": "Malicious Moonsault", - "effect": "Utilizando o Poder Z, Incineroar fortalece seu corpo e pula no alvo com força total." - }, - "oceanicOperetta": { - "name": "Oceanic Operetta", - "effect": "Utilizando o Poder Z, Primarina convoca uma quantidade massiva de água e lança contra o alvo com força total." - }, - "guardianOfAlola": { - "name": "Guardian of Alola", - "effect": "Utilizando o Poder Z, o Espírito Nativo canaliza a energia de Alola e ataca o alvo com força total. Reduz muito os PS do alvo." - }, - "soulStealing7StarStrike": { - "name": "Soul-Stealing 7-Star Strike", - "effect": "Quando um Marshadow obtém o Poder Z, ele ataca o alvo consecutivamente com socos e chutes usando força total." - }, - "stokedSparksurfer": { - "name": "Stoked Sparksurfer", - "effect": "Quando um Raichu de Alola obtém o Poder Z, ele lança um ataque contra o alvo com força total. Este movimento deixa o alvo paralisado." - }, - "pulverizingPancake": { - "name": "Pulverizing Pancake", - "effect": "O Poder Z desperta as capacidades máximas de seu Snorlax. O Pokémon movimenta seu enorme corpo velozmente e ataca o alvo com força total." - }, - "extremeEvoboost": { - "name": "Extreme Evoboost", - "effect": "Quando um Eevee obtém o Poder Z, ele absorve energia dos seus amigos evoluídos e aumenta os seus atributos bruscamente." - }, - "genesisSupernova": { - "name": "Genesis Supernova", - "effect": "Quando um Mew obtém o Poder Z, ele ataca o alvo com força total. O terreno será carregado com energia psíquica." - }, - "shellTrap": { - "name": "Shell Trap", - "effect": "O usuário arma uma cilada explosiva. Se o usuário for atingido fisicamente, a cilada irá explodir e causar de dano ao Pokémon oponente." - }, - "fleurCannon": { - "name": "Fleur Cannon", - "effect": "O usuário dispara um raio poderoso. O efeito colateral do ataque prejudica duramente o Ataque Especial do usuário." - }, - "psychicFangs": { - "name": "Psychic Fangs", - "effect": "O usuário morde o alvo com suas capacidades psíquicas. Pode destruir Tela de Luz e Refletir." - }, - "stompingTantrum": { - "name": "Stomping Tantrum", - "effect": "Guiado pela frustração, o usuário ataca o alvo. Se o movimento anterior falhou, o poder do movimento é dobrado." - }, - "shadowBone": { - "name": "Shadow Bone", - "effect": "O usuário ataca o alvo com um osso que contém um espírito. Pode diminuir a Defesa do alvo." - }, - "accelerock": { - "name": "Accelerock", - "effect": "O usuário colide contra o alvo em alta velocidade. Esse movimento sempre ataca primeiro." - }, - "liquidation": { - "name": "Liquidation", - "effect": "O usuário dispara no alvo um jato d'água poderoso. Diminui a Defesa do alvo." - }, - "prismaticLaser": { - "name": "Prismatic Laser", - "effect": "O usuário dispara lasers poderosos usando o poder de um prisma. O usuário não pode se mover no próximo turno." - }, - "spectralThief": { - "name": "Spectral Thief", - "effect": "O usuário se esconde na sombra do alvo, rouba seus aumentos de atributos e então, ataca-o." - }, - "sunsteelStrike": { - "name": "Sunsteel Strike", - "effect": "O usuário atinge o alvo com a força de um meteoro. Esse movimento pode ser usado no alvo independentemente de sua Habilidade." - }, - "moongeistBeam": { - "name": "Moongeist Beam", - "effect": "O usuário emite um raio pavoroso para atacar o alvo. Esse movimento pode ser usado no alvo independentemente de sua Habilidade." - }, - "tearfulLook": { - "name": "Tearful Look", - "effect": "O usuário fica manhoso e o alvo perde a vontade de lutar. Diminui o Ataque e o Ataque Esp. do alvo." - }, - "zingZap": { - "name": "Zing Zap", - "effect": "Uma forte explosão elétrica que cai sobre o alvo, eletrocutando-o e podendo fazê-lo hesitar." - }, - "naturesMadness": { - "name": "Nature's Madness", - "effect": "O usuário atinge o alvo com a força da natureza. Reduz os PS do alvo pela metade." - }, - "multiAttack": { - "name": "Multi-Attack", - "effect": "Se envolvendo em energia concentrada, o usuário acerta o alvo. A memória segurada determina o tipo do movimento." - }, - "tenMillionVoltThunderbolt": { - "name": "10,000,000 Volt Thunderbolt", - "effect": "Usando seu Poder Z, o Pikachu de boné acumula eletricidade e despeja-a. Golpes críticos acertam mais facilmente." - }, - "mindBlown": { - "name": "Mind Blown", - "effect": "O usuário ataca tudo ao seu redor fazendo sua própria cabeça explodir. Isso também causa dano ao usuário." - }, - "plasmaFists": { - "name": "Plasma Fists", - "effect": "O usuário ataca com punhos carregados eletricamente. Este movimento transforma movimentos do tipo Normal em movimentos do tipo Elétrico." - }, - "photonGeyser": { - "name": "Photon Geyser", - "effect": "O usuário ataca o alvo com um pilar de luz. Este movimento causa dano de Ataque ou Ataque Especial—o que for maior para o usuário." - }, - "lightThatBurnsTheSky": { - "name": "Light That Burns the Sky", - "effect": "Este ataque causa dano de Ataque ou Ataque Especial—o que for maior para o usuário, Necrozma. Este movimento ignora a Habilidade do alvo." - }, - "searingSunrazeSmash": { - "name": "Searing Sunraze Smash", - "effect": "Após obter o Z-Power, o usuário, Solgaleo, ataca o alvo com força total. Este movimento pode ignorar o efeito da Habilidade do alvo." - }, - "menacingMoonrazeMaelstrom": { - "name": "Menacing Moonraze Maelstrom", - "effect": "Após obter o Z-Power, o usuário, Lunala, ataca o alvo com força total. Este movimento pode ignorar o efeito da Habilidade do alvo." - }, - "letsSnuggleForever": { - "name": "Let's Snuggle Forever", - "effect": "Após obter o Z-Power, o usuário, Mimikyu, soca o alvo com força total." - }, - "splinteredStormshards": { - "name": "Splintered Stormshards", - "effect": "Após obter o Z-Power, o usuário, Lycanroc, ataca o alvo com força total. Este movimento nega o efeito no campo de batalha." - }, - "clangorousSoulblaze": { - "name": "Clangorous Soulblaze", - "effect": "Após obter o Z-Power, o usuário, Kommo-o, ataca os Pokémon adversários com força total. Este movimento aumenta os atributos do usuário." - }, - "zippyZap": { - "name": "Zippy Zap", - "effect": "O usuário ataca o alvo com rajadas de eletricidade em alta velocidade. Esse movimento sempre vai primeiro e resulta em um golpe crítico." - }, - "splishySplash": { - "name": "Splishy Splash", - "effect": "O usuário carrega uma onda enorme com eletricidade e atinge os Pokémon adversários com a onda. Isso também pode deixar os Pokémon adversários paralisados." - }, - "floatyFall": { - "name": "Floaty Fall", - "effect": "O usuário flutua no ar e então mergulha em um ângulo íngreme para atacar o alvo. Isso também pode fazer o alvo hesitar." - }, - "pikaPapow": { - "name": "Pika Papow", - "effect": "Quanto mais o Pikachu ama seu Treinador, maior o poder do movimento. Nunca erra." - }, - "bouncyBubble": { - "name": "Bouncy Bubble", - "effect": "O usuário ataca atirando bolhas de água no alvo. Em seguida, absorve água e restaura seu HP pelo mesmo valor de dano causado ao alvo." - }, - "buzzyBuzz": { - "name": "Buzzy Buzz", - "effect": "O usuário dispara um choque de eletricidade para atacar o alvo. Isso também deixa o alvo paralisado." - }, - "sizzlySlide": { - "name": "Sizzly Slide", - "effect": "O usuário se envolve em fogo e carrega contra o alvo. Isso também deixa o alvo queimado." - }, - "glitzyGlow": { - "name": "Glitzy Glow", - "effect": "O usuário bombardeia o alvo com força telecinética. Uma parede maravilhosa de luz é erguida para enfraquecer o poder dos movimentos especiais dos Pokémon adversários." - }, - "baddyBad": { - "name": "Baddy Bad", - "effect": "O usuário age mal e ataca o alvo. Uma parede maravilhosa de luz é erguida para enfraquecer o poder dos movimentos físicos dos Pokémon adversários." - }, - "sappySeed": { - "name": "Sappy Seed", - "effect": "O usuário cresce um caule gigantesco que espalha sementes para atacar o alvo. As sementes drenam o HP do alvo a cada turno." - }, - "freezyFrost": { - "name": "Freezy Frost", - "effect": "O usuário ataca com um cristal feito de névoa congelada fria. Isso elimina todas as mudanças de atributo entre todos os Pokémon envolvidos na batalha." - }, - "sparklySwirl": { - "name": "Sparkly Swirl", - "effect": "O usuário ataca o alvo envolvendo-o com um redemoinho de um aroma esmagador. Isso também cura todas as condições de status do grupo do usuário." - }, - "veeveeVolley": { - "name": "Veevee Volley", - "effect": "Quanto mais o Eevee ama seu Treinador, maior o poder do movimento. Nunca erra." - }, - "doubleIronBash": { - "name": "Double Iron Bash", - "effect": "O usuário gira, centrando a porca hexagonal em seu peito e depois ataca com seus braços duas vezes seguidas. Isso também pode fazer o alvo hesitar." - }, - "maxGuard": { - "name": "Max Guard", - "effect": "Este movimento permite ao usuário proteger-se de todos os ataques. Sua chance de falhar aumenta se for usado em sucessão." - }, - "dynamaxCannon": { - "name": "Dynamax Cannon", - "effect": "O usuário libera um forte feixe de seu núcleo. Este movimento causa até o dobro do dano se o alvo estiver com seu nível acima do limite." - }, - "snipeShot": { - "name": "Snipe Shot", - "effect": "O usuário ignora os efeitos dos movimentos e Habilidades dos Pokémon adversários que atraem movimentos, permitindo que este movimento atinja o alvo escolhido." - }, - "jawLock": { - "name": "Jaw Lock", - "effect": "Este movimento impede o usuário e o alvo de trocarem de lugar até que um deles desmaie. O efeito desaparece se qualquer um dos Pokémon deixar o campo." - }, - "stuffCheeks": { - "name": "Stuff Cheeks", - "effect": "O usuário come sua Fruta segurada, depois aumenta muito seu atributo de Defesa." - }, - "noRetreat": { - "name": "No Retreat", - "effect": "Este movimento aumenta todos os atributos do usuário, mas impede o usuário de trocar de lugar ou fugir." - }, - "tarShot": { - "name": "Tar Shot", - "effect": "O usuário derrama alcatrão pegajoso sobre o alvo, diminuindo o atributo de Velocidade do alvo. O alvo se torna mais fraco contra movimentos do tipo Fogo." - }, - "magicPowder": { - "name": "Magic Powder", - "effect": "O usuário espalha uma nuvem de pó mágico que muda o alvo para o tipo Psíquico." - }, - "dragonDarts": { - "name": "Dragon Darts", - "effect": "O usuário ataca duas vezes usando Dreepy. Se houver dois alvos, este movimento atinge cada alvo uma vez." - }, - "teatime": { - "name": "Teatime", - "effect": "O usuário faz hora do chá com todos os Pokémon na batalha. Cada Pokémon come sua Fruta segurada." - }, - "octolock": { - "name": "Octolock", - "effect": "O usuário prende o alvo e impede que ele fuja. Este movimento também diminui os atributos de Defesa e Def. Esp. do alvo a cada turno." - }, - "boltBeak": { - "name": "Bolt Beak", - "effect": "O usuário fere o alvo com seu bico eletrificado. Se o usuário atacar antes do alvo, o poder deste movimento é dobrado." - }, - "fishiousRend": { - "name": "Fishious Rend", - "effect": "O usuário fere o alvo com suas brânquias duras. Se o usuário atacar antes do alvo, o poder deste movimento é dobrado." - }, - "courtChange": { - "name": "Court Change", - "effect": "Com seu poder misterioso, o usuário troca os efeitos de cada lado do campo." - }, - "maxFlare": { - "name": "Max Flare", - "effect": "Este é um ataque do tipo Fogo que Pokémon Dynamax usam. O usuário intensifica o sol por cinco turnos." - }, - "maxFlutterby": { - "name": "Max Flutterby", - "effect": "Este é um ataque do tipo Inseto que Pokémon Dynamax usam. Isso diminui o atributo de Atq. Esp. do alvo." - }, - "maxLightning": { - "name": "Max Lightning", - "effect": "Este é um ataque do tipo Elétrico que Pokémon Dynamax usam. O usuário transforma o chão em Terreno Elétrico por cinco turnos." - }, - "maxStrike": { - "name": "Max Strike", - "effect": "Este é um ataque do tipo Normal que Pokémon Dynamax usam. Isso diminui o atributo de Velocidade do alvo." - }, - "maxKnuckle": { - "name": "Max Knuckle", - "effect": "Este é um ataque do tipo Lutador que Pokémon Dynamax usam. Isso aumenta os atributos de Ataque dos Pokémon aliados." - }, - "maxPhantasm": { - "name": "Max Phantasm", - "effect": "Este é um ataque do tipo Fantasma que Pokémon Dynamax usam. Isso diminui o atributo de Defesa do alvo." - }, - "maxHailstorm": { - "name": "Max Hailstorm", - "effect": "Este é um ataque do tipo Gelo que Pokémon Dynamax usam. O usuário convoca uma tempestade de granizo que dura cinco turnos." - }, - "maxOoze": { - "name": "Max Ooze", - "effect": "Este é um ataque do tipo Veneno que Pokémon Dynamax usam. Isso aumenta os atributos de Atq. Esp. dos Pokémon aliados." - }, - "maxGeyser": { - "name": "Max Geyser", - "effect": "Este é um ataque do tipo Água que Pokémon Dynamax usam. O usuário convoca uma chuva pesada que cai por cinco turnos." - }, - "maxAirstream": { - "name": "Max Airstream", - "effect": "Este é um ataque do tipo Voador que Pokémon Dynamax usam. Isso aumenta os atributos de Velocidade dos Pokémon aliados." - }, - "maxStarfall": { - "name": "Max Starfall", - "effect": "Este é um ataque do tipo Fada que Pokémon Dynamax usam. O usuário transforma o chão em Terreno de Nevoeiro por cinco turnos." - }, - "maxWyrmwind": { - "name": "Max Wyrmwind", - "effect": "Este é um ataque do tipo Dragão que Pokémon Dynamax usam. Isso diminui o atributo de Ataque do alvo." - }, - "maxMindstorm": { - "name": "Max Mindstorm", - "effect": "Este é um ataque do tipo Psíquico que Pokémon Dynamax usam. O usuário transforma o chão em Terreno Psíquico por cinco turnos." - }, - "maxRockfall": { - "name": "Max Rockfall", - "effect": "Este é um ataque do tipo Pedra que Pokémon Dynamax usam. O usuário convoca uma tempestade de areia que dura cinco turnos." - }, - "maxQuake": { - "name": "Max Quake", - "effect": "Este é um ataque do tipo Terra que Pokémon Dynamax usam. Isso aumenta os atributos de Def. Esp. dos Pokémon aliados." - }, - "maxDarkness": { - "name": "Max Darkness", - "effect": "Este é um ataque do tipo Sombrio que Pokémon Dynamax usam. Isso diminui o atributo de Def. Esp. do alvo." - }, - "maxOvergrowth": { - "name": "Max Overgrowth", - "effect": "Este é um ataque do tipo Grama que Pokémon Dynamax usam. O usuário transforma o chão em Terreno de Grama por cinco turnos." - }, - "maxSteelspike": { - "name": "Max Steelspike", - "effect": "Este é um ataque do tipo Aço que Pokémon Dynamax usam. Isso aumenta os atributos de Defesa dos Pokémon aliados." - }, - "clangorousSoul": { - "name": "Clangorous Soul", - "effect": "O usuário aumenta todos os seus atributos usando um pouco de seu HP." - }, - "bodyPress": { - "name": "Body Press", - "effect": "O usuário ataca pressionando seu corpo contra o alvo. Quanto maior a Defesa do usuário, mais dano pode infligir ao alvo." - }, - "decorate": { - "name": "Decorate", - "effect": "O usuário aumenta muito os atributos de Ataque e Atq. Esp. do alvo decorando o alvo." - }, - "drumBeating": { - "name": "Drum Beating", - "effect": "O usuário toca seu tambor, controlando as raízes do tambor para atacar o alvo. Isso também diminui o atributo de Velocidade do alvo." - }, - "snapTrap": { - "name": "Snap Trap", - "effect": "O usuário prende o alvo em uma armadilha rápida por quatro ou cinco turnos." - }, - "pyroBall": { - "name": "Pyro Ball", - "effect": "O usuário ataca acendendo uma pequena pedra e lançando-a como uma bola de fogo no alvo. Isso também pode deixar o alvo queimado." - }, - "behemothBlade": { - "name": "Behemoth Blade", - "effect": "O usuário empunha uma espada grande e poderosa usando todo o seu corpo e corta o alvo em um ataque vigoroso." - }, - "behemothBash": { - "name": "Behemoth Bash", - "effect": "O corpo do usuário se torna um escudo firme e atinge o alvo com força." - }, - "auraWheel": { - "name": "Aura Wheel", - "effect": "Morpeko ataca e aumenta sua Velocidade com a energia armazenada em suas bochechas. O tipo deste movimento muda dependendo da forma do usuário." - }, - "breakingSwipe": { - "name": "Breaking Swipe", - "effect": "O usuário balança sua cauda dura violentamente e ataca os Pokémon adversários. Isso também diminui os atributos de Ataque deles." - }, - "branchPoke": { - "name": "Branch Poke", - "effect": "O usuário ataca o alvo cutucando-o com um galho pontiagudo." - }, - "overdrive": { - "name": "Overdrive", - "effect": "O usuário ataca os Pokémon adversários vibrando uma guitarra ou baixo, causando um eco enorme e uma vibração forte." - }, - "appleAcid": { - "name": "Apple Acid", - "effect": "O usuário ataca o alvo com um líquido ácido criado a partir de maçãs azedas. Isso também diminui o atributo de Def. Esp. do alvo." - }, - "gravApple": { - "name": "Grav Apple", - "effect": "O usuário inflige dano derrubando uma maçã de cima. Isso também diminui o atributo de Defesa do alvo." - }, - "spiritBreak": { - "name": "Spirit Break", - "effect": "O usuário ataca o alvo com tanta força que poderia quebrar o espírito do alvo. Isso também diminui o atributo de Atq. Esp. do alvo." - }, - "strangeSteam": { - "name": "Strange Steam", - "effect": "O usuário ataca o alvo emitindo vapor. Isso também pode deixar o alvo confuso." - }, - "lifeDew": { - "name": "Life Dew", - "effect": "O usuário espalha água misteriosa ao redor e restaura o HP de si mesmo e de seus Pokémon aliados na batalha." - }, - "obstruct": { - "name": "Obstruct", - "effect": "Este movimento permite ao usuário proteger-se de todos os ataques. Sua chance de falhar aumenta se for usado em sucessão. Contato direto reduz severamente o atributo de Defesa do atacante." - }, - "falseSurrender": { - "name": "False Surrender", - "effect": "O usuário finge abaixar a cabeça, mas então esfaqueia o alvo com seus cabelos desgrenhados. Este ataque nunca erra." - }, - "meteorAssault": { - "name": "Meteor Assault", - "effect": "O usuário ataca selvagemente com seu alho-poró grosso. O usuário não pode se mover na próxima rodada, porque a força deste movimento o faz cambalear." - }, - "eternabeam": { - "name": "Eternabeam", - "effect": "Este é o ataque mais poderoso de Eternatus em sua forma original. O usuário não pode se mover na próxima rodada." - }, - "steelBeam": { - "name": "Steel Beam", - "effect": "O usuário dispara um feixe de aço que coletou de todo o seu corpo. Isso também causa dano ao usuário." - }, - "expandingForce": { - "name": "Expanding Force", - "effect": "O usuário ataca o alvo com seu poder psíquico. O poder deste movimento aumenta e danifica todos os Pokémon adversários no Terreno Psíquico." - }, - "steelRoller": { - "name": "Steel Roller", - "effect": "O usuário ataca enquanto destrói o terreno. Este movimento falha quando o chão não foi transformado em um terreno." - }, - "scaleShot": { - "name": "Scale Shot", - "effect": "O usuário ataca atirando escamas de duas a cinco vezes seguidas. Este movimento aumenta o atributo de Velocidade do usuário, mas diminui seu atributo de Defesa." - }, - "meteorBeam": { - "name": "Meteor Beam", - "effect": "Neste ataque de dois turnos, o usuário reúne energia espacial e aumenta seu atributo de Atq. Esp., depois ataca o alvo no próximo turno." - }, - "shellSideArm": { - "name": "Shell Side Arm", - "effect": "Este movimento causa dano físico ou especial, o que for mais eficaz. Isso também pode envenenar o alvo." - }, - "mistyExplosion": { - "name": "Misty Explosion", - "effect": "O usuário ataca tudo ao seu redor e desmaia ao usar este movimento. O poder deste movimento é aumentado no Terreno de Nevoeiro." - }, - "grassyGlide": { - "name": "Grassy Glide", - "effect": "Deslizando no chão, o usuário ataca o alvo. Este movimento sempre ataca primeiro no Terreno de Grama." - }, - "risingVoltage": { - "name": "Rising Voltage", - "effect": "O usuário ataca com a voltagem elétrica que sobe do chão. O poder deste movimento dobra quando o alvo está no Terreno Elétrico." - }, - "terrainPulse": { - "name": "Terrain Pulse", - "effect": "O usuário utiliza o poder do terreno para atacar. O tipo e o poder deste movimento mudam dependendo do terreno em que é usado." - }, - "skitterSmack": { - "name": "Skitter Smack", - "effect": "O usuário corre por trás do alvo para atacar. Isso também diminui o atributo de Atq. Esp. do alvo." - }, - "burningJealousy": { - "name": "Burning Jealousy", - "effect": "O usuário ataca com energia da inveja. Isso deixa todos os Pokémon adversários que tiveram seus atributos aumentados durante o turno com uma queimadura." - }, - "lashOut": { - "name": "Lash Out", - "effect": "O usuário ataca para desabafar sua frustração contra o alvo. Se os atributos do usuário foram diminuídos durante este turno, o poder deste movimento é dobrado." - }, - "poltergeist": { - "name": "Poltergeist", - "effect": "O usuário ataca o alvo controlando o item do alvo. O movimento falha se o alvo não tiver um item." - }, - "corrosiveGas": { - "name": "Corrosive Gas", - "effect": "O usuário envolve tudo ao seu redor com gás altamente ácido e derrete os itens que eles seguram." - }, - "coaching": { - "name": "Coaching", - "effect": "O usuário treina adequadamente seus Pokémon aliados, aumentando seus atributos de Ataque e Defesa." - }, - "flipTurn": { - "name": "Flip Turn", - "effect": "Após fazer seu ataque, o usuário corre para trocar de lugar com um Pokémon do grupo à espera." - }, - "tripleAxel": { - "name": "Triple Axel", - "effect": "Um ataque de três chutes consecutivos que se torna mais poderoso a cada acerto bem-sucedido." - }, - "dualWingbeat": { - "name": "Dual Wingbeat", - "effect": "O usuário atinge o alvo com suas asas. O alvo é atingido duas vezes seguidas." - }, - "scorchingSands": { - "name": "Scorching Sands", - "effect": "O usuário joga areia escaldante no alvo para atacar. Isso também pode deixar o alvo queimado." - }, - "jungleHealing": { - "name": "Jungle Healing", - "effect": "O usuário se torna um com a selva, restaurando HP e curando quaisquer condições de status de si mesmo e de seus Pokémon aliados na batalha." - }, - "wickedBlow": { - "name": "Wicked Blow", - "effect": "O usuário, tendo dominado o estilo Sombrio, atinge o alvo com um golpe feroz. Este ataque sempre resulta em um acerto crítico." - }, - "surgingStrikes": { - "name": "Surging Strikes", - "effect": "O usuário, tendo dominado o estilo Água, atinge o alvo com um movimento fluido três vezes seguidas. Estes ataques sempre resultam em acertos críticos." - }, - "thunderCage": { - "name": "Thunder Cage", - "effect": "O usuário prende o alvo em uma gaiola de eletricidade cintilante por quatro ou cinco turnos." - }, - "dragonEnergy": { - "name": "Dragon Energy", - "effect": "Convertendo sua força vital em poder, o usuário ataca os Pokémon adversários. Quanto menor o HP do usuário, menor o poder do movimento." - }, - "freezingGlare": { - "name": "Freezing Glare", - "effect": "O usuário dispara seu poder psíquico dos olhos para atacar. Isso também pode deixar o alvo congelado." - }, - "fieryWrath": { - "name": "Fiery Wrath", - "effect": "O usuário transforma sua ira em uma aura semelhante ao fogo para atacar. Isso também pode fazer os Pokémon adversários hesitarem." - }, - "thunderousKick": { - "name": "Thunderous Kick", - "effect": "O usuário oprime o alvo com movimento semelhante ao relâmpago antes de entregar um chute. Isso também diminui o atributo de Defesa do alvo." - }, - "glacialLance": { - "name": "Glacial Lance", - "effect": "O usuário ataca lançando uma lança de gelo envolta em nevasca nos Pokémon adversários." - }, - "astralBarrage": { - "name": "Astral Barrage", - "effect": "O usuário ataca enviando uma quantidade assustadora de pequenos fantasmas nos Pokémon adversários." - }, - "eerieSpell": { - "name": "Eerie Spell", - "effect": "O usuário ataca com seu tremendo poder psíquico. Isso também remove 3 PP do último movimento usado pelo alvo." - }, - "direClaw": { - "name": "Dire Claw", - "effect": "O usuário ataca o alvo com garras destruidoras. Isso também pode deixar o alvo envenenado, paralisado ou adormecido." - }, - "psyshieldBash": { - "name": "Psyshield Bash", - "effect": "Envoltando-se em energia psíquica, o usuário se choca contra o alvo. Isso também aumenta o atributo de Defesa do usuário." - }, - "powerShift": { - "name": "Power Shift", - "effect": "O usuário troca seus atributos de Ataque e Defesa." - }, - "stoneAxe": { - "name": "Stone Axe", - "effect": "O usuário balança seus machados de pedra no alvo. Fragmentos de pedra deixados para trás por este ataque flutuam ao redor do alvo." - }, - "springtideStorm": { - "name": "Springtide Storm", - "effect": "O usuário ataca envolvendo os Pokémon adversários em ventos ferozes repletos de amor e ódio. Isso também pode diminuir os atributos de Ataque deles." - }, - "mysticalPower": { - "name": "Mystical Power", - "effect": "O usuário ataca emitindo um poder misterioso. Isso também aumenta o atributo de Atq. Esp. do usuário." - }, - "ragingFury": { - "name": "Raging Fury", - "effect": "O usuário se enfurece espalhando chamas por dois ou três turnos. O usuário então fica confuso." - }, - "waveCrash": { - "name": "Wave Crash", - "effect": "O usuário se envolve em água e atinge o alvo com todo o corpo para infligir dano. Isso também causa muito dano ao usuário." - }, - "chloroblast": { - "name": "Chloroblast", - "effect": "O usuário lança sua clorofila acumulada para infligir dano no alvo. Isso também causa dano ao usuário." - }, - "mountainGale": { - "name": "Mountain Gale", - "effect": "O usuário arremessa pedaços gigantes de gelo no alvo para infligir dano. Isso também pode fazer o alvo hesitar." - }, - "victoryDance": { - "name": "Victory Dance", - "effect": "O usuário realiza uma dança intensa para inaugurar a vitória, aumentando seus atributos de Ataque, Defesa e Velocidade." - }, - "headlongRush": { - "name": "Headlong Rush", - "effect": "O usuário se choca contra o alvo em um ataque de corpo inteiro. Isso também diminui os atributos de Defesa e Def. Esp. do usuário." - }, - "barbBarrage": { - "name": "Barb Barrage", - "effect": "O usuário lança inúmeras barbas tóxicas para infligir dano. O poder deste movimento é dobrado se o alvo já estiver envenenado." - }, - "esperWing": { - "name": "Esper Wing", - "effect": "O usuário corta o alvo com asas enriquecidas com aura. Isso também aumenta o atributo de Velocidade do usuário. Este movimento tem uma chance aumentada de causar um acerto crítico." - }, - "bitterMalice": { - "name": "Bitter Malice", - "effect": "O usuário ataca o alvo com um ressentimento arrepiante. Isso também diminui o atributo de Ataque do alvo." - }, - "shelter": { - "name": "Shelter", - "effect": "O usuário torna sua pele tão dura quanto um escudo de ferro, aumentando muito seu atributo de Defesa." - }, - "tripleArrows": { - "name": "Triple Arrows", - "effect": "O usuário chuta e depois dispara três flechas. Este movimento tem uma chance aumentada de causar um acerto crítico e também pode diminuir o atributo de Defesa do alvo ou fazê-lo hesitar." - }, - "infernalParade": { - "name": "Infernal Parade", - "effect": "O usuário ataca com miríades de bolas de fogo. Isso também pode deixar o alvo queimado. O poder deste movimento é dobrado se o alvo tiver uma condição de status." - }, - "ceaselessEdge": { - "name": "Ceaseless Edge", - "effect": "O usuário corta sua lâmina de concha no alvo. Fragmentos de concha deixados para trás por este ataque permanecem espalhados sob o alvo como espinhos." - }, - "bleakwindStorm": { - "name": "Bleakwind Storm", - "effect": "O usuário ataca com ventos selvagemente frios que fazem tanto o corpo quanto o espírito tremerem. Isso também pode diminuir os atributos de Velocidade dos Pokémon adversários." - }, - "wildboltStorm": { - "name": "Wildbolt Storm", - "effect": "O usuário invoca uma tempestade trovejante e ataca selvagemente com relâmpagos e vento. Isso também pode deixar os Pokémon adversários paralisados." - }, - "sandsearStorm": { - "name": "Sandsear Storm", - "effect": "O usuário ataca envolvendo os Pokémon adversários em ventos ferozes e areia escaldante. Isso também pode deixá-los queimados." - }, - "lunarBlessing": { - "name": "Lunar Blessing", - "effect": "O usuário recebe uma bênção do crescente lunar, restaurando HP e curando condições de status para si mesmo e seus Pokémon aliados atualmente na batalha." - }, - "takeHeart": { - "name": "Take Heart", - "effect": "O usuário levanta o espírito, curando suas próprias condições de status e aumentando seus atributos de Atq. Esp. e Def. Esp." - }, - "gMaxWildfire": { - "name": "G-Max Wildfire", - "effect": "Um ataque do tipo Fogo que o Gigantamax Charizard usa. Este movimento continua causando dano aos oponentes por quatro turnos." - }, - "gMaxBefuddle": { - "name": "G-Max Befuddle", - "effect": "Um ataque do tipo Inseto que o Gigantamax Butterfree usa. Este movimento inflige as condições de envenenado, paralisado ou adormecido nos oponentes." - }, - "gMaxVoltCrash": { - "name": "G-Max Volt Crash", - "effect": "Um ataque do tipo Elétrico que o Gigantamax Pikachu usa. Este movimento paralisa os oponentes." - }, - "gMaxGoldRush": { - "name": "G-Max Gold Rush", - "effect": "Um ataque do tipo Normal que o Gigantamax Meowth usa. Este movimento confunde os oponentes e também ganha dinheiro extra." - }, - "gMaxChiStrike": { - "name": "G-Max Chi Strike", - "effect": "Um ataque do tipo Lutador que Gigantamax Machamp usa. Este movimento aumenta a chance de acertos críticos." - }, - "gMaxTerror": { - "name": "G-Max Terror", - "effect": "Um ataque do tipo Fantasma que Gigantamax Gengar usa. Este Pokémon pisa na sombra do Pokémon adversário para impedi-lo de escapar." - }, - "gMaxResonance": { - "name": "G-Max Resonance", - "effect": "Um ataque do tipo Gelo que Gigantamax Lapras usa. Este movimento reduz o dano recebido por cinco turnos." - }, - "gMaxCuddle": { - "name": "G-Max Cuddle", - "effect": "Um ataque do tipo Normal que Gigantamax Eevee usa. Este movimento apaixona os oponentes." - }, - "gMaxReplenish": { - "name": "G-Max Replenish", - "effect": "Um ataque do tipo Normal que Gigantamax Snorlax usa. Este movimento restaura Frutas que foram comidas." - }, - "gMaxMalodor": { - "name": "G-Max Malodor", - "effect": "Um ataque do tipo Veneno que Gigantamax Garbodor usa. Este movimento envenena os oponentes." - }, - "gMaxStonesurge": { - "name": "G-Max Stonesurge", - "effect": "Um ataque do tipo Água que Gigantamax Drednaw usa. Este movimento espalha pedras afiadas pelo campo." - }, - "gMaxWindRage": { - "name": "G-Max Wind Rage", - "effect": "Um ataque do tipo Voador que Gigantamax Corviknight usa. Este movimento remove os efeitos de movimentos como Reflect e Light Screen." - }, - "gMaxStunShock": { - "name": "G-Max Stun Shock", - "effect": "Um ataque do tipo Elétrico que Gigantamax Toxtricity usa. Este movimento envenena ou paralisa os oponentes." - }, - "gMaxFinale": { - "name": "G-Max Finale", - "effect": "Um ataque do tipo Fada que Gigantamax Alcremie usa. Este movimento cura os PS dos aliados." - }, - "gMaxDepletion": { - "name": "G-Max Depletion", - "effect": "Um ataque do tipo Dragão que Gigantamax Duraludon usa. Reduz o PP do último movimento usado." - }, - "gMaxGravitas": { - "name": "G-Max Gravitas", - "effect": "Um ataque do tipo Psíquico que Gigantamax Orbeetle usa. Este movimento muda a gravidade por cinco turnos." - }, - "gMaxVolcalith": { - "name": "G-Max Volcalith", - "effect": "Um ataque do tipo Pedra que Gigantamax Coalossal usa. Este movimento continua a causar dano aos oponentes por quatro turnos." - }, - "gMaxSandblast": { - "name": "G-Max Sandblast", - "effect": "Um ataque do tipo Terra que Gigantamax Sandaconda usa. Os oponentes ficam presos em uma tempestade de areia furiosa por quatro a cinco turnos." - }, - "gMaxSnooze": { - "name": "G-Max Snooze", - "effect": "Um ataque do tipo Sombrio que Gigantamax Grimmsnarl usa. O usuário solta um grande bocejo que faz com que os alvos adormeçam no próximo turno." - }, - "gMaxTartness": { - "name": "G-Max Tartness", - "effect": "Um ataque do tipo Planta que Gigantamax Flapple usa. Este movimento reduz a Evasão dos oponentes." - }, - "gMaxSweetness": { - "name": "G-Max Sweetness", - "effect": "Um ataque do tipo Planta que Gigantamax Appletun usa. Este movimento cura as condições de status dos aliados." - }, - "gMaxSmite": { - "name": "G-Max Smite", - "effect": "Um ataque do tipo Fada que Gigantamax Hatterene usa. Este movimento confunde os oponentes." - }, - "gMaxSteelsurge": { - "name": "G-Max Steelsurge", - "effect": "Um ataque do tipo Aço que Gigantamax Copperajah usa. Este movimento espalha estacas afiadas pelo campo." - }, - "gMaxMeltdown": { - "name": "G-Max Meltdown", - "effect": "Um ataque do tipo Aço que Gigantamax Melmetal usa. Este movimento impede os oponentes de usar o mesmo movimento duas vezes seguidas." - }, - "gMaxFoamBurst": { - "name": "G-Max Foam Burst", - "effect": "Um ataque do tipo Água que Gigantamax Kingler usa. Este movimento reduz drasticamente a Velocidade dos oponentes." - }, - "gMaxCentiferno": { - "name": "G-Max Centiferno", - "effect": "Um ataque do tipo Fogo que Gigantamax Centiskorch usa. Este movimento prende os oponentes em chamas por quatro a cinco turnos." - }, - "gMaxVineLash": { - "name": "G-Max Vine Lash", - "effect": "Um ataque do tipo Planta que Gigantamax Venusaur usa. Este movimento continua a causar dano aos oponentes por quatro turnos." - }, - "gMaxCannonade": { - "name": "G-Max Cannonade", - "effect": "Um ataque do tipo Água que Gigantamax Blastoise usa. Este movimento continua a causar dano aos oponentes por quatro turnos." - }, - "gMaxDrumSolo": { - "name": "G-Max Drum Solo", - "effect": "Um ataque do tipo Planta que Gigantamax Rillaboom usa. Este movimento pode ser usado no alvo independentemente de suas Habilidades." - }, - "gMaxFireball": { - "name": "G-Max Fireball", - "effect": "Um ataque do tipo Fogo que Gigantamax Cinderace usa. Este movimento pode ser usado no alvo independentemente de suas Habilidades." - }, - "gMaxHydrosnipe": { - "name": "G-Max Hydrosnipe", - "effect": "Um ataque do tipo Água que Gigantamax Inteleon usa. Este movimento pode ser usado no alvo independentemente de suas Habilidades." - }, - "gMaxOneBlow": { - "name": "G-Max One Blow", - "effect": "Um ataque do tipo Sombrio que Gigantamax Urshifu usa. Este movimento único pode ignorar o Max Guard." - }, - "gMaxRapidFlow": { - "name": "G-Max Rapid Flow", - "effect": "Um ataque do tipo Água que Gigantamax Urshifu usa. Este movimento rápido pode ignorar o Max Guard." - }, - "teraBlast": { - "name": "Tera Blast", - "effect": "Se o usuário estiver Terastalizado, ele libera energia de seu Tera Tipo. Este movimento causa dano usando o maior entre o Ataque ou Ataque Esp. do usuário." - }, - "silkTrap": { - "name": "Silk Trap", - "effect": "O usuário tece uma armadilha de seda, protegendo-se de dano enquanto reduz o atributo de Velocidade de qualquer atacante que faça contato direto." - }, - "axeKick": { - "name": "Axe Kick", - "effect": "O usuário ataca chutando para cima e depois abaixando o calcanhar sobre o alvo. Isso também pode confundir o alvo. Se errar, o usuário sofre dano." - }, - "lastRespects": { - "name": "Last Respects", - "effect": "O usuário ataca para vingar seus aliados. Quanto mais aliados derrotados, maior o poder do movimento." - }, - "luminaCrash": { - "name": "Lumina Crash", - "effect": "O usuário ataca liberando uma luz peculiar que afeta até a mente. Isso também reduz muito a Defesa Esp. do alvo." - }, - "orderUp": { - "name": "Order Up", - "effect": "O usuário ataca com elegância. Se o usuário tiver um Tatsugiri na boca, este movimento aumenta uma dos atributos do usuário com base na forma do Tatsugiri." - }, - "jetPunch": { - "name": "Jet Punch", - "effect": "O usuário convoca um turbilhão ao redor de seu punho e ataca com velocidade cegante. Este movimento sempre age primeiro." - }, - "spicyExtract": { - "name": "Spicy Extract", - "effect": "O usuário emite um extrato incrivelmente picante, aumentando muito o Ataque do alvo e reduzindo muito a Defesa do alvo." - }, - "spinOut": { - "name": "Spin Out", - "effect": "O usuário gira furiosamente ao esticar as pernas, causando dano ao alvo. Isso também reduz muito a Velocidade do usuário." - }, - "populationBomb": { - "name": "Population Bomb", - "effect": "Os companheiros do usuário se reúnem em massa para executar um ataque combinado que atinge o alvo de uma a dez vezes seguidas." - }, - "iceSpinner": { - "name": "Ice Spinner", - "effect": "O usuário cobre seus pés com gelo fino e gira ao redor, atingindo o alvo. O movimento giratório deste movimento também destrói o terreno." - }, - "glaiveRush": { - "name": "Glaive Rush", - "effect": "O usuário lança todo o seu corpo em uma carga imprudente. Após o uso deste movimento, ataques contra o usuário não podem errar e infligirão o dobro do dano até a próxima vez que o usuário agir." - }, - "revivalBlessing": { - "name": "Revival Blessing", - "effect": "O usuário concede uma bênção amorosa, reanimando um Pokémon da equipe que tenha desmaiado e restaurando metade do máximo de PS desse Pokémon." - }, - "saltCure": { - "name": "Salt Cure", - "effect": "O usuário cura o alvo com sal, causando dano a cada turno. Tipos de Aço e Água são mais fortemente afetados por este movimento." - }, - "tripleDive": { - "name": "Triple Dive", - "effect": "O usuário executa um mergulho triplo perfeitamente cronometrado, atingindo o alvo com respingos de água três vezes seguidas." - }, - "mortalSpin": { - "name": "Mortal Spin", - "effect": "O usuário realiza um ataque giratório que também pode eliminar os efeitos de movimentos como Bind, Wrap e Leech Seed. Isso também envenena os Pokémon oponentes." - }, - "doodle": { - "name": "Doodle", - "effect": "O usuário captura a essência do alvo em um esboço. Isso muda as Habilidades do usuário e de seus Pokémon aliados para a do alvo." - }, - "filletAway": { - "name": "Fillet Away", - "effect": "O usuário aumenta muito seus atributos de Ataque, Ataque Esp. e Velocidade ao usar seus próprios PS." - }, - "kowtowCleave": { - "name": "Kowtow Cleave", - "effect": "O usuário corta o alvo depois de se curvar para fazer o alvo baixar a guarda. Este ataque nunca erra." - }, - "flowerTrick": { - "name": "Flower Trick", - "effect": "O usuário lança um buquê de flores armado no alvo. Este ataque nunca erra e sempre resulta em um acerto crítico." - }, - "torchSong": { - "name": "Torch Song", - "effect": "O usuário exala chamas furiosas como se estivesse cantando uma canção, queimando o alvo. Isso também aumenta o atributo de Ataque Esp. do usuário." - }, - "aquaStep": { - "name": "Aqua Step", - "effect": "O usuário brinca com o alvo e o ataca usando passos de dança leves e fluidos. Isso também aumenta a Velocidade do usuário." - }, - "ragingBull": { - "name": "Raging Bull", - "effect": "O usuário realiza um ataque de investida como um touro enfurecido. O tipo deste movimento depende da forma do usuário. Ele também pode quebrar barreiras, como Light Screen e Reflect." - }, - "makeItRain": { - "name": "Make It Rain", - "effect": "O usuário ataca lançando uma massa de moedas. Isso também reduz o atributo de Ataque Esp. do usuário. Dinheiro é ganho após a batalha." - }, - "psyblade": { - "name": "Psyblade", - "effect": "O usuário fende o alvo com uma lâmina etérea. O poder deste movimento é aumentado em 50% se o usuário estiver no Electric Terrain." - }, - "hydroSteam": { - "name": "Hydro Steam", - "effect": "O usuário ataca o alvo com água fervente. O poder deste movimento não é reduzido sob sol forte, mas sim aumentado em 50%." - }, - "ruination": { - "name": "Ruination", - "effect": "O usuário invoca um desastre ruinoso. Isso corta os PS do alvo pela metade." - }, - "collisionCourse": { - "name": "Collision Course", - "effect": "O usuário se transforma e cai no chão, causando uma explosão pré-histórica massiva. O poder deste movimento é aumentado mais do que o usual se for um golpe super eficaz." - }, - "electroDrift": { - "name": "Electro Drift", - "effect": "O usuário avança a velocidades ultra-rápidas, perfurando o alvo com eletricidade futurista. O poder deste movimento é aumentado mais do que o usual se for um golpe super eficaz." - }, - "shedTail": { - "name": "Shed Tail", - "effect": "O usuário cria um substituto para si mesmo usando seus próprios PS antes de trocar de lugar com um Pokémon da equipe que está esperando." - }, - "chillyReception": { - "name": "Chilly Reception", - "effect": "O usuário conta uma piada terrivelmente ruim antes de trocar de lugar com um Pokémon da equipe que está esperando. Isso invoca uma nevasca que dura cinco turnos." - }, - "tidyUp": { - "name": "Tidy Up", - "effect": "O usuário arruma e remove os efeitos de Spikes, Stealth Rock, Sticky Web, Toxic Spikes e Substitute. Isso também aumenta os atributos de Ataque e Velocidade do usuário." - }, - "snowscape": { - "name": "Snowscape", - "effect": "O usuário invoca uma tempestade de neve que dura cinco turnos. Isso aumenta os atributos de Defesa dos tipos Gelo." - }, - "pounce": { - "name": "Pounce", - "effect": "O usuário ataca saltando sobre o alvo. Isso também reduz a Velocidade do alvo." - }, - "trailblaze": { - "name": "Trailblaze", - "effect": "O usuário ataca repentinamente como se estivesse saltando de dentro da grama alta. A agilidade do usuário aumenta sua Velocidade." - }, - "chillingWater": { - "name": "Chilling Water", - "effect": "O usuário ataca o alvo derramando sobre ele água tão fria que suga seu poder. Isso também reduz o atributo de Ataque do alvo." - }, - "hyperDrill": { - "name": "Hyper Drill", - "effect": "O usuário gira a parte pontiaguda de seu corpo em alta velocidade para perfurar o alvo. Este ataque pode atingir um alvo que esteja usando um movimento como Protect ou Detect." - }, - "twinBeam": { - "name": "Twin Beam", - "effect": "O usuário dispara feixes místicos de seus olhos para causar dano. O alvo é atingido duas vezes seguidas." - }, - "rageFist": { - "name": "Rage Fist", - "effect": "O usuário converte sua raiva em energia para atacar. Quanto mais vezes o usuário foi atingido por ataques, maior o poder do movimento." - }, - "armorCannon": { - "name": "Armor Cannon", - "effect": "O usuário dispara sua própria armadura como projéteis ardentes. Isso também reduz os atributos de Defesa e Defesa Esp. do usuário." - }, - "bitterBlade": { - "name": "Bitter Blade", - "effect": "O usuário concentra seus sentimentos amargos em relação ao mundo dos vivos em um ataque cortante. Os PS do usuário são restaurados em até metade do dano causado ao alvo." - }, - "doubleShock": { - "name": "Double Shock", - "effect": "O usuário descarrega toda a eletricidade de seu corpo para executar um ataque de alto dano. Após usar este movimento, o usuário não será mais do tipo Elétrico." - }, - "gigatonHammer": { - "name": "Gigaton Hammer", - "effect": "O usuário balança todo o seu corpo para atacar com seu enorme martelo. Este movimento não pode ser usado duas vezes seguidas." - }, - "comeuppance": { - "name": "Comeuppance", - "effect": "O usuário retalia com muito mais força contra o oponente que causou o último dano a ele." - }, - "aquaCutter": { - "name": "Aqua Cutter", - "effect": "O usuário expele água pressurizada para cortar o alvo como uma lâmina. Este movimento tem uma chance aumentada de resultar em um acerto crítico." - }, - "blazingTorque": { - "name": "Blazing Torque", - "effect": "O usuário acelera seu motor ardente no alvo. Isso também pode deixar o alvo queimado." - }, - "wickedTorque": { - "name": "Wicked Torque", - "effect": "O usuário acelera seu motor no alvo com intenção maliciosa. Isso pode fazer o alvo adormecer." - }, - "noxiousTorque": { - "name": "Noxious Torque", - "effect": "O usuário acelera seu motor venenoso no alvo. Isso também pode envenenar o alvo." - }, - "combatTorque": { - "name": "Combat Torque", - "effect": "O usuário acelera seu motor com força no alvo. Isso também pode deixar o alvo paralisado." - }, - "magicalTorque": { - "name": "Magical Torque", - "effect": "O usuário acelera seu motor de fadas no alvo. Isso também pode confundir o alvo." - }, - "bloodMoon": { - "name": "Blood Moon", - "effect": "O usuário libera toda a força de seu espírito de uma lua cheia que brilha tão vermelha quanto o sangue. Este movimento não pode ser usado duas vezes seguidas." - }, - "matchaGotcha": { - "name": "Matcha Gotcha", - "effect": "O usuário dispara um jato de chá que misturou. Os PS do usuário são restaurados em até metade do dano causado ao alvo. Isso também pode deixar o alvo queimado." - }, - "syrupBomb": { - "name": "Syrup Bomb", - "effect": "O usuário detona uma explosão de xarope de doces pegajoso, que reveste o alvo e faz o atributo de Velocidade do alvo cair a cada turno por três turnos." - }, - "ivyCudgel": { - "name": "Ivy Cudgel", - "effect": "O usuário golpeia com um porrete envolto em hera. O tipo deste movimento muda dependendo da máscara usada pelo usuário, e tem uma chance aumentada de resultar em um acerto crítico." - }, - "electroShot": { - "name": "Electro Shot", - "effect": "O usuário acumula eletricidade no primeiro turno, aumentando suo atributo de Ataque Esp., e então dispara um tiro de alta voltagem no próximo turno. O tiro será disparado imediatamente na chuva." - }, - "teraStarstorm": { - "name": "Tera Starstorm", - "effect": "Com o poder de seus cristais, o usuário bombardeia e elimina o alvo. Quando usado por Terapagos em sua Forma Estelar, este movimento causa dano a todos os Pokémon oponentes." - }, - "fickleBeam": { - "name": "Fickle Beam", - "effect": "O usuário dispara um feixe de luz para causar dano. Às vezes, todas as cabeças do usuário disparam feixes ao mesmo tempo, dobrando o poder do movimento." - }, - "burningBulwark": { - "name": "Burning Bulwark", - "effect": "A pele intensamente quente do usuário o protege de ataques e também queima qualquer atacante que faça contato direto." - }, - "thunderclap": { - "name": "Thunderclap", - "effect": "Este movimento permite que o usuário ataque primeiro com um choque de eletricidade. Este movimento falha se o alvo não estiver preparando um ataque." - }, - "mightyCleave": { - "name": "Mighty Cleave", - "effect": "O usuário empunha a luz que se acumulou no topo de sua cabeça para cortar o alvo. Este movimento atinge mesmo se o alvo se proteger." - }, - "tachyonCutter": { - "name": "Tachyon Cutter", - "effect": "O usuário ataca lançando lâminas de partículas no alvo duas vezes seguidas. Este ataque nunca erra." - }, - "hardPress": { - "name": "Hard Press", - "effect": "O alvo é esmagado com um braço, uma garra ou algo do tipo para causar dano. Quanto mais PS o alvo tiver, maior o poder do movimento." - }, - "dragonCheer": { - "name": "Dragon Cheer", - "effect": "O usuário eleva o moral de seus aliados com um grito dracônico, para que seus futuros ataques tenham uma chance aumentada de resultar em golpes críticos. Isso anima mais os tipos Dragão." - }, - "alluringVoice": { - "name": "Alluring Voice", - "effect": "O usuário ataca o alvo usando sua voz angelical. Isso também confunde o alvo se seus atributos tiverem sido aumentadas durante o turno." - }, - "temperFlare": { - "name": "Temper Flare", - "effect": "Impulsionado pelo desespero, o usuário ataca o alvo. O poder deste movimento é dobrado se o movimento anterior do usuário tiver falhado." - }, - "supercellSlam": { - "name": "Supercell Slam", - "effect": "O usuário eletrifica seu corpo e cai sobre o alvo para causar dano. Se este movimento errar, o usuário sofre dano." - }, - "psychicNoise": { - "name": "Psychic Noise", - "effect": "O usuário ataca o alvo com ondas sonoras desagradáveis. Por dois turnos, o alvo é impedido de recuperar PS através de movimentos, Habilidades ou itens mantidos." - }, - "upperHand": { - "name": "Upper Hand", - "effect": "O usuário reage ao movimento do alvo e o ataca com o calcanhar da palma da mão, fazendo o alvo hesitar. Este movimento falha se o alvo não estiver preparando um movimento de prioridade." - }, - "malignantChain": { - "name": "Malignant Chain", - "effect": "O usuário derrama toxinas no alvo envolvendo-o em uma corrente tóxica e corrosiva. Isso também pode deixar o alvo seriamente envenenado." - } -} diff --git a/src/locales/pt_BR/nature.json b/src/locales/pt_BR/nature.json deleted file mode 100644 index 5678c74061c..00000000000 --- a/src/locales/pt_BR/nature.json +++ /dev/null @@ -1,27 +0,0 @@ -{ - "Hardy": "Destemida", - "Lonely": "Solitária", - "Brave": "Valente", - "Adamant": "Adamante", - "Naughty": "Teimosa", - "Bold": "Corajosa", - "Docile": "Dócil", - "Relaxed": "Relaxada", - "Impish": "Inquieta", - "Lax": "Frouxa", - "Timid": "Tímida", - "Hasty": "Apressada", - "Serious": "Séria", - "Jolly": "Alegre", - "Naive": "Ingênua", - "Modest": "Modesta", - "Mild": "Mansa", - "Quiet": "Quieta", - "Bashful": "Atrapalhada", - "Rash": "Ousada", - "Calm": "Calma", - "Gentle": "Gentil", - "Sassy": "Atrevida", - "Careful": "Cuidadosa", - "Quirky": "Peculiar" -} \ No newline at end of file diff --git a/src/locales/pt_BR/party-ui-handler.json b/src/locales/pt_BR/party-ui-handler.json deleted file mode 100644 index 435bc916ac6..00000000000 --- a/src/locales/pt_BR/party-ui-handler.json +++ /dev/null @@ -1,47 +0,0 @@ -{ - "SEND_OUT": "Trocar", - "SUMMARY": "Sumário", - "CANCEL": "Cancelar", - "RELEASE": "Soltar", - "APPLY": "Aplicar", - "TEACH": "Ensinar", - "SPLICE": "Fundir", - "UNSPLICE": "Separar", - "ACTIVATE": "Ativar", - "DEACTIVATE": "Desativar", - "TRANSFER": "Transferir", - "ALL": "Tudo", - "PASS_BATON": "Passar Bastão", - "UNPAUSE_EVOLUTION": "Ativar Evolução", - "REVIVE": "Reanimar", - "RENAME": "Renomear", - "choosePokemon": "Escolha um Pokémon.", - "doWhatWithThisPokemon": "O que você deseja fazer?", - "noEnergy": "{{pokemonName}} não pode\nmais batalhar!", - "hasEnergy": "{{pokemonName}} ainda\npode batalhar!", - "cantBeUsed": "{{pokemonName}} não pode\nser usado neste desafio!", - "tooManyItems": "{{pokemonName}} já tem\nmuitos desse item!", - "anyEffect": "Isso não terá nenhum efeito.", - "unpausedEvolutions": "Evoluções foram despausadas para {{pokemonName}}.", - "unspliceConfirmation": "Você realmente deseja desfazer a fusão de {{fusionName}}\ncom {{pokemonName}}? {{fusionName}} será perdido.", - "wasReverted": "{{fusionName}} foi revertido para {{pokemonName}}.", - "releaseConfirmation": "Você realmente deseja soltar {{pokemonName}}?", - "releaseInBattle": "Você não pode soltar um Pokémon que está em batalha!", - "selectAMove": "Selecione um movimento.", - "changeQuantity": "Selecione um item para transferir.\nUse < e > para mudar a quantidade.", - "selectAnotherPokemonToSplice": "Selecione outro Pokémon para fundir.", - "cancel": "Voltar", - "able": "Capaz", - "notAble": "Incapaz", - "learned": "Aprendido", - "goodbye": "Adeus, {{pokemonName}}!", - "byebye": "Tchau, {{pokemonName}}!", - "farewell": "Até mais, {{pokemonName}}!", - "soLong": "Até logo, {{pokemonName}}!", - "thisIsWhereWePart": "Aqui é onde nos separamos, {{pokemonName}}!", - "illMissYou": "Vou sentir saudades, {{pokemonName}}!", - "illNeverForgetYou": "Nunca vou esquecer de você, {{pokemonName}}!", - "untilWeMeetAgain": "Até nos encontrarmos novamente, {{pokemonName}}!", - "sayonara": "Sayonara, {{pokemonName}}!", - "smellYaLater": "Te vejo depois, {{pokemonName}}!" -} \ No newline at end of file diff --git a/src/locales/pt_BR/pokeball.json b/src/locales/pt_BR/pokeball.json deleted file mode 100644 index 3a059654bb3..00000000000 --- a/src/locales/pt_BR/pokeball.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "pokeBall": "Poké Bola", - "greatBall": "Grande Bola", - "ultraBall": "Ultra Bola", - "rogueBall": "Bola Rogue", - "masterBall": "Bola Mestra", - "luxuryBall": "Bola Luxo" -} \ No newline at end of file diff --git a/src/locales/pt_BR/pokemon-form-battle.json b/src/locales/pt_BR/pokemon-form-battle.json deleted file mode 100644 index 6ea7947fb66..00000000000 --- a/src/locales/pt_BR/pokemon-form-battle.json +++ /dev/null @@ -1,14 +0,0 @@ -{ - "mega": "Mega {{pokemonName}}", - "mega-x": "Mega {{pokemonName}} X", - "mega-y": "Mega {{pokemonName}} Y", - "primal": "{{pokemonName}} Primordial", - "gigantamax": "G-Max {{pokemonName}}", - "eternamax": "E-Max {{pokemonName}}", - "megaChange": "{{preName}} Mega Evoluiu\npara {{pokemonName}}!", - "gigantamaxChange": "{{preName}} Gigantamaxou\npara {{pokemonName}}!", - "eternamaxChange": "{{preName}} Eternamaxou\npara {{pokemonName}}!", - "revertChange": "{{pokemonName}} voltou\npara sua forma original!", - "formChange": "{{preName}} mudou de forma!", - "disguiseChange": "O seu disfarce serviu-lhe de isca!" -} \ No newline at end of file diff --git a/src/locales/pt_BR/pokemon-form.json b/src/locales/pt_BR/pokemon-form.json deleted file mode 100644 index aa8f32a5d36..00000000000 --- a/src/locales/pt_BR/pokemon-form.json +++ /dev/null @@ -1,170 +0,0 @@ -{ - "pikachuCosplay": "Cosplay", - "pikachuCoolCosplay": "Cosplay Legal", - "pikachuBeautyCosplay": "Cosplay Bonito", - "pikachuCuteCosplay": "Cosplay Fofo", - "pikachuSmartCosplay": "Cosplay Inteligente", - "pikachuToughCosplay": "Cosplay Forte", - "pikachuPartner": "Parceiro", - "eeveePartner": "Parceiro", - "pichuSpiky": "Orelha Espetada", - "unownA": "A", - "unownB": "B", - "unownC": "C", - "unownD": "D", - "unownE": "E", - "unownF": "F", - "unownG": "G", - "unownH": "H", - "unownI": "I", - "unownJ": "J", - "unownK": "K", - "unownL": "L", - "unownM": "M", - "unownN": "N", - "unownO": "O", - "unownP": "P", - "unownQ": "Q", - "unownR": "R", - "unownS": "S", - "unownT": "T", - "unownU": "U", - "unownV": "V", - "unownW": "W", - "unownX": "X", - "unownY": "Y", - "unownZ": "Z", - "unownExclamation": "!", - "unownQuestion": "?", - "castformSunny": "Ensolarado", - "castformRainy": "Chuvoso", - "castformSnowy": "Nevado", - "deoxysNormal": "Normal", - "burmyPlant": "Vegetal", - "burmySandy": "Arenoso", - "burmyTrash": "Lixo", - "shellosEast": "Leste", - "shellosWest": "Oeste", - "rotomHeat": "Calor", - "rotomWash": "Lavagem", - "rotomFrost": "Congelante", - "rotomFan": "Ventilador", - "rotomMow": "Corte", - "giratinaAltered": "Alterado", - "shayminLand": "Terrestre", - "basculinRedStriped": "Listras Vermelhas", - "basculinBlueStriped": "Listras Azuis", - "basculinWhiteStriped": "Listras Brancas", - "deerlingSpring": "Primavera", - "deerlingSummer": "Verão", - "deerlingAutumn": "Outono", - "deerlingWinter": "Inverno", - "tornadusIncarnate": "Materializado", - "thundurusIncarnate": "Materializado", - "landorusIncarnate": "Materializado", - "keldeoOrdinary": "Comum", - "meloettaAria": "Ária", - "meloettaPirouette": "Pirueta", - "froakieBattleBond": "Vínculo de Batalha", - "scatterbugMeadow": "Prado", - "scatterbugIcySnow": "Neve Congelada", - "scatterbugPolar": "Polar", - "scatterbugTundra": "Tundra", - "scatterbugContinental": "Continental", - "scatterbugGarden": "Jardim", - "scatterbugElegant": "Elegante", - "scatterbugModern": "Moderno", - "scatterbugMarine": "Marinho", - "scatterbugArchipelago": "Arquipélago", - "scatterbugHighPlains": "Planalto", - "scatterbugSandstorm": "Deserto", - "scatterbugRiver": "Rio", - "scatterbugMonsoon": "Monção", - "scatterbugSavanna": "Savana", - "scatterbugSun": "Solar", - "scatterbugOcean": "Oceano", - "scatterbugJungle": "Selva", - "scatterbugFancy": "Chique", - "scatterbugPokeBall": "Poké Bola", - "flabebeRed": "Vermelha", - "flabebeYellow": "Amarela", - "flabebeOrange": "Laranja", - "flabebeBlue": "Azul", - "flabebeWhite": "Branca", - "furfrouHeart": "Coração", - "furfrouStar": "Estrela", - "furfrouDiamond": "Diamante", - "furfrouDebutante": "Debutante", - "furfrouMatron": "Madame", - "furfrouDandy": "Cavalheiro", - "furfrouLaReine": "Aristocrático", - "furfrouKabuki": "Kabuki", - "furfrouPharaoh": "Faraó", - "pumpkabooSmall": "Pequeno", - "pumpkabooLarge": "Grande", - "pumpkabooSuper": "Extragrande", - "xerneasNeutral": "Relaxado", - "xerneasActive": "Ativo", - "zygarde50": "Forma 50%", - "zygarde10": "Forma 10%", - "zygarde50Pc": "Forma 50% Agrupada", - "zygarde10Pc": "Forma 10% Agrupada", - "zygardeComplete": "Forma Completa", - "oricorioBaile": "Flamenco", - "oricorioPompom": "Pompom", - "oricorioPau": "Hula", - "oricorioSensu": "Leque", - "rockruffOwnTempo": "Próprio Tempo", - "miniorRedMeteor": "Meteoro Vermelho", - "miniorOrangeMeteor": "Meteoro Laranja", - "miniorYellowMeteor": "Meteoro Amarelo", - "miniorGreenMeteor": "Meteoro Verde", - "miniorBlueMeteor": "Meteoro Azul", - "miniorIndigoMeteor": "Meteoro Anil", - "miniorVioletMeteor": "Meteoro Violeta", - "miniorRed": "Vermelho", - "miniorOrange": "Laranja", - "miniorYellow": "Amarelo", - "miniorGreen": "Verde", - "miniorBlue": "Azul", - "miniorIndigo": "Anil", - "miniorViolet": "Violeta", - "mimikyuDisguised": "Disfarçado", - "mimikyuBusted": "Descoberto", - "magearnaOriginal": "Original", - "marshadowZenith": "Zênite", - "sinisteaPhony": "Falsificado", - "sinisteaAntique": "Autêntico", - "eiscueNoIce": "Descongelado", - "indeedeeMale": "Macho", - "indeedeeFemale": "Fêmea", - "morpekoFullBelly": "Saciado", - "zacianHeroOfManyBattles": "Herói Veterano", - "zamazentaHeroOfManyBattles": "Herói Veterano", - "zarudeDada": "Papa", - "enamorusIncarnate": "Materializado", - "squawkabillyGreenPlumage": "Plumas Verdes", - "squawkabillyBluePlumage": "Plumas Azuis", - "squawkabillyYellowPlumage": "Plumas Amarelas", - "squawkabillyWhitePlumage": "Plumas Brancas", - "tatsugiriCurly": "Curvado", - "tatsugiriDroopy": "Caído", - "tatsugiriStretchy": "Reto", - "gimmighoulChest": "Baú", - "gimmighoulRoaming": "Perambulante", - "koraidonApexBuild": "Forma Plena", - "koraidonLimitedBuild": "Forma Limitada", - "koraidonSprintingBuild": "Forma de Corrida", - "koraidonSwimmingBuild": "Forma de Nado", - "koraidonGlidingBuild": "Forma de Voo", - "miraidonUltimateMode": "Modo Pleno", - "miraidonLowPowerMode": "Modo Limitado", - "miraidonDriveMode": "Modo Terrestre", - "miraidonAquaticMode": "Modo Aquático", - "miraidonGlideMode": "Modo Aéreo", - "poltchageistCounterfeit": "Imitação", - "poltchageistArtisan": "Artesão", - "paldeaTaurosCombat": "Combate", - "paldeaTaurosBlaze": "Chamas", - "paldeaTaurosAqua": "Aquático" -} diff --git a/src/locales/pt_BR/pokemon-info-container.json b/src/locales/pt_BR/pokemon-info-container.json deleted file mode 100644 index dcf1fc4e0b5..00000000000 --- a/src/locales/pt_BR/pokemon-info-container.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "moveset": "Movimentos", - "gender": "Gênero:", - "ability": "Habilidade:", - "nature": "Natureza:", - "form": "Forma:" -} \ No newline at end of file diff --git a/src/locales/pt_BR/pokemon-info.json b/src/locales/pt_BR/pokemon-info.json deleted file mode 100644 index a7a46b7a24e..00000000000 --- a/src/locales/pt_BR/pokemon-info.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "Stat": { - "HP": "PS", - "HPshortened": "PS", - "ATK": "Ataque", - "ATKshortened": "Ata", - "DEF": "Defesa", - "DEFshortened": "Def", - "SPATK": "At. Esp.", - "SPATKshortened": "AtEsp", - "SPDEF": "Def. Esp.", - "SPDEFshortened": "DefEsp", - "SPD": "Veloc.", - "SPDshortened": "Veloc.", - "ACC": "Precisão", - "EVA": "Evasão", - "HPStat": "PS" - }, - "Type": { - "UNKNOWN": "Desconhecido", - "NORMAL": "Normal", - "FIGHTING": "Lutador", - "FLYING": "Voador", - "POISON": "Veneno", - "GROUND": "Terra", - "ROCK": "Pedra", - "BUG": "Inseto", - "GHOST": "Fantasma", - "STEEL": "Aço", - "FIRE": "Fogo", - "WATER": "Água", - "GRASS": "Grama", - "ELECTRIC": "Elétrico", - "PSYCHIC": "Psíquico", - "ICE": "Gelo", - "DRAGON": "Dragão", - "DARK": "Sombrio", - "FAIRY": "Fada", - "STELLAR": "Estelar" - } -} diff --git a/src/locales/pt_BR/pokemon-summary.json b/src/locales/pt_BR/pokemon-summary.json deleted file mode 100644 index 14b736a0cf2..00000000000 --- a/src/locales/pt_BR/pokemon-summary.json +++ /dev/null @@ -1,44 +0,0 @@ -{ - "pokemonInfo": "Info. Pokémon", - "status": "Status", - "powerAccuracyCategory": "Poder\nPrecisão\nCategoria", - "type": "Tipo", - "unknownTrainer": "Desconhecido", - "ot": "TO", - "nature": "natureza", - "expPoints": "Pontos EXP.", - "nextLv": "Próx. Nv.", - "cancel": "Cancelar", - "memoString": "Natureza {{natureFragment}},\n{{metFragment}}", - "metFragment": { - "normal": "encontrado no Nv.{{level}},\n{{biome}}, Onda {{wave}}.", - "apparently": "aparentemente encontrado no Nv.{{level}},\n{{biome}}." - }, - "natureFragment": { - "Hardy": "{{nature}}", - "Lonely": "{{nature}}", - "Brave": "{{nature}}", - "Adamant": "{{nature}}", - "Naughty": "{{nature}}", - "Bold": "{{nature}}", - "Docile": "{{nature}}", - "Relaxed": "{{nature}}", - "Impish": "{{nature}}", - "Lax": "{{nature}}", - "Timid": "{{nature}}", - "Hasty": "{{nature}}", - "Serious": "{{nature}}", - "Jolly": "{{nature}}", - "Naive": "{{nature}}", - "Modest": "{{nature}}", - "Mild": "{{nature}}", - "Quiet": "{{nature}}", - "Bashful": "{{nature}}", - "Rash": "{{nature}}", - "Calm": "{{nature}}", - "Gentle": "{{nature}}", - "Sassy": "{{nature}}", - "Careful": "{{nature}}", - "Quirky": "{{nature}}" - } -} diff --git a/src/locales/pt_BR/pokemon.json b/src/locales/pt_BR/pokemon.json deleted file mode 100644 index f780d2accbd..00000000000 --- a/src/locales/pt_BR/pokemon.json +++ /dev/null @@ -1,1084 +0,0 @@ -{ - "bulbasaur": "Bulbasaur", - "ivysaur": "Ivysaur", - "venusaur": "Venusaur", - "charmander": "Charmander", - "charmeleon": "Charmeleon", - "charizard": "Charizard", - "squirtle": "Squirtle", - "wartortle": "Wartortle", - "blastoise": "Blastoise", - "caterpie": "Caterpie", - "metapod": "Metapod", - "butterfree": "Butterfree", - "weedle": "Weedle", - "kakuna": "Kakuna", - "beedrill": "Beedrill", - "pidgey": "Pidgey", - "pidgeotto": "Pidgeotto", - "pidgeot": "Pidgeot", - "rattata": "Rattata", - "raticate": "Raticate", - "spearow": "Spearow", - "fearow": "Fearow", - "ekans": "Ekans", - "arbok": "Arbok", - "pikachu": "Pikachu", - "raichu": "Raichu", - "sandshrew": "Sandshrew", - "sandslash": "Sandslash", - "nidoran_f": "Nidoran♀", - "nidorina": "Nidorina", - "nidoqueen": "Nidoqueen", - "nidoran_m": "Nidoran♂", - "nidorino": "Nidorino", - "nidoking": "Nidoking", - "clefairy": "Clefairy", - "clefable": "Clefable", - "vulpix": "Vulpix", - "ninetales": "Ninetales", - "jigglypuff": "Jigglypuff", - "wigglytuff": "Wigglytuff", - "zubat": "Zubat", - "golbat": "Golbat", - "oddish": "Oddish", - "gloom": "Gloom", - "vileplume": "Vileplume", - "paras": "Paras", - "parasect": "Parasect", - "venonat": "Venonat", - "venomoth": "Venomoth", - "diglett": "Diglett", - "dugtrio": "Dugtrio", - "meowth": "Meowth", - "persian": "Persian", - "psyduck": "Psyduck", - "golduck": "Golduck", - "mankey": "Mankey", - "primeape": "Primeape", - "growlithe": "Growlithe", - "arcanine": "Arcanine", - "poliwag": "Poliwag", - "poliwhirl": "Poliwhirl", - "poliwrath": "Poliwrath", - "abra": "Abra", - "kadabra": "Kadabra", - "alakazam": "Alakazam", - "machop": "Machop", - "machoke": "Machoke", - "machamp": "Machamp", - "bellsprout": "Bellsprout", - "weepinbell": "Weepinbell", - "victreebel": "Victreebel", - "tentacool": "Tentacool", - "tentacruel": "Tentacruel", - "geodude": "Geodude", - "graveler": "Graveler", - "golem": "Golem", - "ponyta": "Ponyta", - "rapidash": "Rapidash", - "slowpoke": "Slowpoke", - "slowbro": "Slowbro", - "magnemite": "Magnemite", - "magneton": "Magneton", - "farfetchd": "Farfetch'd", - "doduo": "Doduo", - "dodrio": "Dodrio", - "seel": "Seel", - "dewgong": "Dewgong", - "grimer": "Grimer", - "muk": "Muk", - "shellder": "Shellder", - "cloyster": "Cloyster", - "gastly": "Gastly", - "haunter": "Haunter", - "gengar": "Gengar", - "onix": "Onix", - "drowzee": "Drowzee", - "hypno": "Hypno", - "krabby": "Krabby", - "kingler": "Kingler", - "voltorb": "Voltorb", - "electrode": "Electrode", - "exeggcute": "Exeggcute", - "exeggutor": "Exeggutor", - "cubone": "Cubone", - "marowak": "Marowak", - "hitmonlee": "Hitmonlee", - "hitmonchan": "Hitmonchan", - "lickitung": "Lickitung", - "koffing": "Koffing", - "weezing": "Weezing", - "rhyhorn": "Rhyhorn", - "rhydon": "Rhydon", - "chansey": "Chansey", - "tangela": "Tangela", - "kangaskhan": "Kangaskhan", - "horsea": "Horsea", - "seadra": "Seadra", - "goldeen": "Goldeen", - "seaking": "Seaking", - "staryu": "Staryu", - "starmie": "Starmie", - "mr_mime": "Mr. Mime", - "scyther": "Scyther", - "jynx": "Jynx", - "electabuzz": "Electabuzz", - "magmar": "Magmar", - "pinsir": "Pinsir", - "tauros": "Tauros", - "magikarp": "Magikarp", - "gyarados": "Gyarados", - "lapras": "Lapras", - "ditto": "Ditto", - "eevee": "Eevee", - "vaporeon": "Vaporeon", - "jolteon": "Jolteon", - "flareon": "Flareon", - "porygon": "Porygon", - "omanyte": "Omanyte", - "omastar": "Omastar", - "kabuto": "Kabuto", - "kabutops": "Kabutops", - "aerodactyl": "Aerodactyl", - "snorlax": "Snorlax", - "articuno": "Articuno", - "zapdos": "Zapdos", - "moltres": "Moltres", - "dratini": "Dratini", - "dragonair": "Dragonair", - "dragonite": "Dragonite", - "mewtwo": "Mewtwo", - "mew": "Mew", - "chikorita": "Chikorita", - "bayleef": "Bayleef", - "meganium": "Meganium", - "cyndaquil": "Cyndaquil", - "quilava": "Quilava", - "typhlosion": "Typhlosion", - "totodile": "Totodile", - "croconaw": "Croconaw", - "feraligatr": "Feraligatr", - "sentret": "Sentret", - "furret": "Furret", - "hoothoot": "Hoothoot", - "noctowl": "Noctowl", - "ledyba": "Ledyba", - "ledian": "Ledian", - "spinarak": "Spinarak", - "ariados": "Ariados", - "crobat": "Crobat", - "chinchou": "Chinchou", - "lanturn": "Lanturn", - "pichu": "Pichu", - "cleffa": "Cleffa", - "igglybuff": "Igglybuff", - "togepi": "Togepi", - "togetic": "Togetic", - "natu": "Natu", - "xatu": "Xatu", - "mareep": "Mareep", - "flaaffy": "Flaaffy", - "ampharos": "Ampharos", - "bellossom": "Bellossom", - "marill": "Marill", - "azumarill": "Azumarill", - "sudowoodo": "Sudowoodo", - "politoed": "Politoed", - "hoppip": "Hoppip", - "skiploom": "Skiploom", - "jumpluff": "Jumpluff", - "aipom": "Aipom", - "sunkern": "Sunkern", - "sunflora": "Sunflora", - "yanma": "Yanma", - "wooper": "Wooper", - "quagsire": "Quagsire", - "espeon": "Espeon", - "umbreon": "Umbreon", - "murkrow": "Murkrow", - "slowking": "Slowking", - "misdreavus": "Misdreavus", - "unown": "Unown", - "wobbuffet": "Wobbuffet", - "girafarig": "Girafarig", - "pineco": "Pineco", - "forretress": "Forretress", - "dunsparce": "Dunsparce", - "gligar": "Gligar", - "steelix": "Steelix", - "snubbull": "Snubbull", - "granbull": "Granbull", - "qwilfish": "Qwilfish", - "scizor": "Scizor", - "shuckle": "Shuckle", - "heracross": "Heracross", - "sneasel": "Sneasel", - "teddiursa": "Teddiursa", - "ursaring": "Ursaring", - "slugma": "Slugma", - "magcargo": "Magcargo", - "swinub": "Swinub", - "piloswine": "Piloswine", - "corsola": "Corsola", - "remoraid": "Remoraid", - "octillery": "Octillery", - "delibird": "Delibird", - "mantine": "Mantine", - "skarmory": "Skarmory", - "houndour": "Houndour", - "houndoom": "Houndoom", - "kingdra": "Kingdra", - "phanpy": "Phanpy", - "donphan": "Donphan", - "porygon2": "Porygon2", - "stantler": "Stantler", - "smeargle": "Smeargle", - "tyrogue": "Tyrogue", - "hitmontop": "Hitmontop", - "smoochum": "Smoochum", - "elekid": "Elekid", - "magby": "Magby", - "miltank": "Miltank", - "blissey": "Blissey", - "raikou": "Raikou", - "entei": "Entei", - "suicune": "Suicune", - "larvitar": "Larvitar", - "pupitar": "Pupitar", - "tyranitar": "Tyranitar", - "lugia": "Lugia", - "ho_oh": "Ho-Oh", - "celebi": "Celebi", - "treecko": "Treecko", - "grovyle": "Grovyle", - "sceptile": "Sceptile", - "torchic": "Torchic", - "combusken": "Combusken", - "blaziken": "Blaziken", - "mudkip": "Mudkip", - "marshtomp": "Marshtomp", - "swampert": "Swampert", - "poochyena": "Poochyena", - "mightyena": "Mightyena", - "zigzagoon": "Zigzagoon", - "linoone": "Linoone", - "wurmple": "Wurmple", - "silcoon": "Silcoon", - "beautifly": "Beautifly", - "cascoon": "Cascoon", - "dustox": "Dustox", - "lotad": "Lotad", - "lombre": "Lombre", - "ludicolo": "Ludicolo", - "seedot": "Seedot", - "nuzleaf": "Nuzleaf", - "shiftry": "Shiftry", - "taillow": "Taillow", - "swellow": "Swellow", - "wingull": "Wingull", - "pelipper": "Pelipper", - "ralts": "Ralts", - "kirlia": "Kirlia", - "gardevoir": "Gardevoir", - "surskit": "Surskit", - "masquerain": "Masquerain", - "shroomish": "Shroomish", - "breloom": "Breloom", - "slakoth": "Slakoth", - "vigoroth": "Vigoroth", - "slaking": "Slaking", - "nincada": "Nincada", - "ninjask": "Ninjask", - "shedinja": "Shedinja", - "whismur": "Whismur", - "loudred": "Loudred", - "exploud": "Exploud", - "makuhita": "Makuhita", - "hariyama": "Hariyama", - "azurill": "Azurill", - "nosepass": "Nosepass", - "skitty": "Skitty", - "delcatty": "Delcatty", - "sableye": "Sableye", - "mawile": "Mawile", - "aron": "Aron", - "lairon": "Lairon", - "aggron": "Aggron", - "meditite": "Meditite", - "medicham": "Medicham", - "electrike": "Electrike", - "manectric": "Manectric", - "plusle": "Plusle", - "minun": "Minun", - "volbeat": "Volbeat", - "illumise": "Illumise", - "roselia": "Roselia", - "gulpin": "Gulpin", - "swalot": "Swalot", - "carvanha": "Carvanha", - "sharpedo": "Sharpedo", - "wailmer": "Wailmer", - "wailord": "Wailord", - "numel": "Numel", - "camerupt": "Camerupt", - "torkoal": "Torkoal", - "spoink": "Spoink", - "grumpig": "Grumpig", - "spinda": "Spinda", - "trapinch": "Trapinch", - "vibrava": "Vibrava", - "flygon": "Flygon", - "cacnea": "Cacnea", - "cacturne": "Cacturne", - "swablu": "Swablu", - "altaria": "Altaria", - "zangoose": "Zangoose", - "seviper": "Seviper", - "lunatone": "Lunatone", - "solrock": "Solrock", - "barboach": "Barboach", - "whiscash": "Whiscash", - "corphish": "Corphish", - "crawdaunt": "Crawdaunt", - "baltoy": "Baltoy", - "claydol": "Claydol", - "lileep": "Lileep", - "cradily": "Cradily", - "anorith": "Anorith", - "armaldo": "Armaldo", - "feebas": "Feebas", - "milotic": "Milotic", - "castform": "Castform", - "kecleon": "Kecleon", - "shuppet": "Shuppet", - "banette": "Banette", - "duskull": "Duskull", - "dusclops": "Dusclops", - "tropius": "Tropius", - "chimecho": "Chimecho", - "absol": "Absol", - "wynaut": "Wynaut", - "snorunt": "Snorunt", - "glalie": "Glalie", - "spheal": "Spheal", - "sealeo": "Sealeo", - "walrein": "Walrein", - "clamperl": "Clamperl", - "huntail": "Huntail", - "gorebyss": "Gorebyss", - "relicanth": "Relicanth", - "luvdisc": "Luvdisc", - "bagon": "Bagon", - "shelgon": "Shelgon", - "salamence": "Salamence", - "beldum": "Beldum", - "metang": "Metang", - "metagross": "Metagross", - "regirock": "Regirock", - "regice": "Regice", - "registeel": "Registeel", - "latias": "Latias", - "latios": "Latios", - "kyogre": "Kyogre", - "groudon": "Groudon", - "rayquaza": "Rayquaza", - "jirachi": "Jirachi", - "deoxys": "Deoxys", - "turtwig": "Turtwig", - "grotle": "Grotle", - "torterra": "Torterra", - "chimchar": "Chimchar", - "monferno": "Monferno", - "infernape": "Infernape", - "piplup": "Piplup", - "prinplup": "Prinplup", - "empoleon": "Empoleon", - "starly": "Starly", - "staravia": "Staravia", - "staraptor": "Staraptor", - "bidoof": "Bidoof", - "bibarel": "Bibarel", - "kricketot": "Kricketot", - "kricketune": "Kricketune", - "shinx": "Shinx", - "luxio": "Luxio", - "luxray": "Luxray", - "budew": "Budew", - "roserade": "Roserade", - "cranidos": "Cranidos", - "rampardos": "Rampardos", - "shieldon": "Shieldon", - "bastiodon": "Bastiodon", - "burmy": "Burmy", - "wormadam": "Wormadam", - "mothim": "Mothim", - "combee": "Combee", - "vespiquen": "Vespiquen", - "pachirisu": "Pachirisu", - "buizel": "Buizel", - "floatzel": "Floatzel", - "cherubi": "Cherubi", - "cherrim": "Cherrim", - "shellos": "Shellos", - "gastrodon": "Gastrodon", - "ambipom": "Ambipom", - "drifloon": "Drifloon", - "drifblim": "Drifblim", - "buneary": "Buneary", - "lopunny": "Lopunny", - "mismagius": "Mismagius", - "honchkrow": "Honchkrow", - "glameow": "Glameow", - "purugly": "Purugly", - "chingling": "Chingling", - "stunky": "Stunky", - "skuntank": "Skuntank", - "bronzor": "Bronzor", - "bronzong": "Bronzong", - "bonsly": "Bonsly", - "mime_jr": "Mime Jr.", - "happiny": "Happiny", - "chatot": "Chatot", - "spiritomb": "Spiritomb", - "gible": "Gible", - "gabite": "Gabite", - "garchomp": "Garchomp", - "munchlax": "Munchlax", - "riolu": "Riolu", - "lucario": "Lucario", - "hippopotas": "Hippopotas", - "hippowdon": "Hippowdon", - "skorupi": "Skorupi", - "drapion": "Drapion", - "croagunk": "Croagunk", - "toxicroak": "Toxicroak", - "carnivine": "Carnivine", - "finneon": "Finneon", - "lumineon": "Lumineon", - "mantyke": "Mantyke", - "snover": "Snover", - "abomasnow": "Abomasnow", - "weavile": "Weavile", - "magnezone": "Magnezone", - "lickilicky": "Lickilicky", - "rhyperior": "Rhyperior", - "tangrowth": "Tangrowth", - "electivire": "Electivire", - "magmortar": "Magmortar", - "togekiss": "Togekiss", - "yanmega": "Yanmega", - "leafeon": "Leafeon", - "glaceon": "Glaceon", - "gliscor": "Gliscor", - "mamoswine": "Mamoswine", - "porygon_z": "Porygon-Z", - "gallade": "Gallade", - "probopass": "Probopass", - "dusknoir": "Dusknoir", - "froslass": "Froslass", - "rotom": "Rotom", - "uxie": "Uxie", - "mesprit": "Mesprit", - "azelf": "Azelf", - "dialga": "Dialga", - "palkia": "Palkia", - "heatran": "Heatran", - "regigigas": "Regigigas", - "giratina": "Giratina", - "cresselia": "Cresselia", - "phione": "Phione", - "manaphy": "Manaphy", - "darkrai": "Darkrai", - "shaymin": "Shaymin", - "arceus": "Arceus", - "victini": "Victini", - "snivy": "Snivy", - "servine": "Servine", - "serperior": "Serperior", - "tepig": "Tepig", - "pignite": "Pignite", - "emboar": "Emboar", - "oshawott": "Oshawott", - "dewott": "Dewott", - "samurott": "Samurott", - "patrat": "Patrat", - "watchog": "Watchog", - "lillipup": "Lillipup", - "herdier": "Herdier", - "stoutland": "Stoutland", - "purrloin": "Purrloin", - "liepard": "Liepard", - "pansage": "Pansage", - "simisage": "Simisage", - "pansear": "Pansear", - "simisear": "Simisear", - "panpour": "Panpour", - "simipour": "Simipour", - "munna": "Munna", - "musharna": "Musharna", - "pidove": "Pidove", - "tranquill": "Tranquill", - "unfezant": "Unfezant", - "blitzle": "Blitzle", - "zebstrika": "Zebstrika", - "roggenrola": "Roggenrola", - "boldore": "Boldore", - "gigalith": "Gigalith", - "woobat": "Woobat", - "swoobat": "Swoobat", - "drilbur": "Drilbur", - "excadrill": "Excadrill", - "audino": "Audino", - "timburr": "Timburr", - "gurdurr": "Gurdurr", - "conkeldurr": "Conkeldurr", - "tympole": "Tympole", - "palpitoad": "Palpitoad", - "seismitoad": "Seismitoad", - "throh": "Throh", - "sawk": "Sawk", - "sewaddle": "Sewaddle", - "swadloon": "Swadloon", - "leavanny": "Leavanny", - "venipede": "Venipede", - "whirlipede": "Whirlipede", - "scolipede": "Scolipede", - "cottonee": "Cottonee", - "whimsicott": "Whimsicott", - "petilil": "Petilil", - "lilligant": "Lilligant", - "basculin": "Basculin", - "sandile": "Sandile", - "krokorok": "Krokorok", - "krookodile": "Krookodile", - "darumaka": "Darumaka", - "darmanitan": "Darmanitan", - "maractus": "Maractus", - "dwebble": "Dwebble", - "crustle": "Crustle", - "scraggy": "Scraggy", - "scrafty": "Scrafty", - "sigilyph": "Sigilyph", - "yamask": "Yamask", - "cofagrigus": "Cofagrigus", - "tirtouga": "Tirtouga", - "carracosta": "Carracosta", - "archen": "Archen", - "archeops": "Archeops", - "trubbish": "Trubbish", - "garbodor": "Garbodor", - "zorua": "Zorua", - "zoroark": "Zoroark", - "minccino": "Minccino", - "cinccino": "Cinccino", - "gothita": "Gothita", - "gothorita": "Gothorita", - "gothitelle": "Gothitelle", - "solosis": "Solosis", - "duosion": "Duosion", - "reuniclus": "Reuniclus", - "ducklett": "Ducklett", - "swanna": "Swanna", - "vanillite": "Vanillite", - "vanillish": "Vanillish", - "vanilluxe": "Vanilluxe", - "deerling": "Deerling", - "sawsbuck": "Sawsbuck", - "emolga": "Emolga", - "karrablast": "Karrablast", - "escavalier": "Escavalier", - "foongus": "Foongus", - "amoonguss": "Amoonguss", - "frillish": "Frillish", - "jellicent": "Jellicent", - "alomomola": "Alomomola", - "joltik": "Joltik", - "galvantula": "Galvantula", - "ferroseed": "Ferroseed", - "ferrothorn": "Ferrothorn", - "klink": "Klink", - "klang": "Klang", - "klinklang": "Klinklang", - "tynamo": "Tynamo", - "eelektrik": "Eelektrik", - "eelektross": "Eelektross", - "elgyem": "Elgyem", - "beheeyem": "Beheeyem", - "litwick": "Litwick", - "lampent": "Lampent", - "chandelure": "Chandelure", - "axew": "Axew", - "fraxure": "Fraxure", - "haxorus": "Haxorus", - "cubchoo": "Cubchoo", - "beartic": "Beartic", - "cryogonal": "Cryogonal", - "shelmet": "Shelmet", - "accelgor": "Accelgor", - "stunfisk": "Stunfisk", - "mienfoo": "Mienfoo", - "mienshao": "Mienshao", - "druddigon": "Druddigon", - "golett": "Golett", - "golurk": "Golurk", - "pawniard": "Pawniard", - "bisharp": "Bisharp", - "bouffalant": "Bouffalant", - "rufflet": "Rufflet", - "braviary": "Braviary", - "vullaby": "Vullaby", - "mandibuzz": "Mandibuzz", - "heatmor": "Heatmor", - "durant": "Durant", - "deino": "Deino", - "zweilous": "Zweilous", - "hydreigon": "Hydreigon", - "larvesta": "Larvesta", - "volcarona": "Volcarona", - "cobalion": "Cobalion", - "terrakion": "Terrakion", - "virizion": "Virizion", - "tornadus": "Tornadus", - "thundurus": "Thundurus", - "reshiram": "Reshiram", - "zekrom": "Zekrom", - "landorus": "Landorus", - "kyurem": "Kyurem", - "keldeo": "Keldeo", - "meloetta": "Meloetta", - "genesect": "Genesect", - "chespin": "Chespin", - "quilladin": "Quilladin", - "chesnaught": "Chesnaught", - "fennekin": "Fennekin", - "braixen": "Braixen", - "delphox": "Delphox", - "froakie": "Froakie", - "frogadier": "Frogadier", - "greninja": "Greninja", - "bunnelby": "Bunnelby", - "diggersby": "Diggersby", - "fletchling": "Fletchling", - "fletchinder": "Fletchinder", - "talonflame": "Talonflame", - "scatterbug": "Scatterbug", - "spewpa": "Spewpa", - "vivillon": "Vivillon", - "litleo": "Litleo", - "pyroar": "Pyroar", - "flabebe": "Flabébé", - "floette": "Floette", - "florges": "Florges", - "skiddo": "Skiddo", - "gogoat": "Gogoat", - "pancham": "Pancham", - "pangoro": "Pangoro", - "furfrou": "Furfrou", - "espurr": "Espurr", - "meowstic": "Meowstic", - "honedge": "Honedge", - "doublade": "Doublade", - "aegislash": "Aegislash", - "spritzee": "Spritzee", - "aromatisse": "Aromatisse", - "swirlix": "Swirlix", - "slurpuff": "Slurpuff", - "inkay": "Inkay", - "malamar": "Malamar", - "binacle": "Binacle", - "barbaracle": "Barbaracle", - "skrelp": "Skrelp", - "dragalge": "Dragalge", - "clauncher": "Clauncher", - "clawitzer": "Clawitzer", - "helioptile": "Helioptile", - "heliolisk": "Heliolisk", - "tyrunt": "Tyrunt", - "tyrantrum": "Tyrantrum", - "amaura": "Amaura", - "aurorus": "Aurorus", - "sylveon": "Sylveon", - "hawlucha": "Hawlucha", - "dedenne": "Dedenne", - "carbink": "Carbink", - "goomy": "Goomy", - "sliggoo": "Sliggoo", - "goodra": "Goodra", - "klefki": "Klefki", - "phantump": "Phantump", - "trevenant": "Trevenant", - "pumpkaboo": "Pumpkaboo", - "gourgeist": "Gourgeist", - "bergmite": "Bergmite", - "avalugg": "Avalugg", - "noibat": "Noibat", - "noivern": "Noivern", - "xerneas": "Xerneas", - "yveltal": "Yveltal", - "zygarde": "Zygarde", - "diancie": "Diancie", - "hoopa": "Hoopa", - "volcanion": "Volcanion", - "rowlet": "Rowlet", - "dartrix": "Dartrix", - "decidueye": "Decidueye", - "litten": "Litten", - "torracat": "Torracat", - "incineroar": "Incineroar", - "popplio": "Popplio", - "brionne": "Brionne", - "primarina": "Primarina", - "pikipek": "Pikipek", - "trumbeak": "Trumbeak", - "toucannon": "Toucannon", - "yungoos": "Yungoos", - "gumshoos": "Gumshoos", - "grubbin": "Grubbin", - "charjabug": "Charjabug", - "vikavolt": "Vikavolt", - "crabrawler": "Crabrawler", - "crabominable": "Crabominable", - "oricorio": "Oricorio", - "cutiefly": "Cutiefly", - "ribombee": "Ribombee", - "rockruff": "Rockruff", - "lycanroc": "Lycanroc", - "wishiwashi": "Wishiwashi", - "mareanie": "Mareanie", - "toxapex": "Toxapex", - "mudbray": "Mudbray", - "mudsdale": "Mudsdale", - "dewpider": "Dewpider", - "araquanid": "Araquanid", - "fomantis": "Fomantis", - "lurantis": "Lurantis", - "morelull": "Morelull", - "shiinotic": "Shiinotic", - "salandit": "Salandit", - "salazzle": "Salazzle", - "stufful": "Stufful", - "bewear": "Bewear", - "bounsweet": "Bounsweet", - "steenee": "Steenee", - "tsareena": "Tsareena", - "comfey": "Comfey", - "oranguru": "Oranguru", - "passimian": "Passimian", - "wimpod": "Wimpod", - "golisopod": "Golisopod", - "sandygast": "Sandygast", - "palossand": "Palossand", - "pyukumuku": "Pyukumuku", - "type_null": "Tipo Nulo", - "silvally": "Silvally", - "minior": "Minior", - "komala": "Komala", - "turtonator": "Turtonator", - "togedemaru": "Togedemaru", - "mimikyu": "Mimikyu", - "bruxish": "Bruxish", - "drampa": "Drampa", - "dhelmise": "Dhelmise", - "jangmo_o": "Jangmo-o", - "hakamo_o": "Hakamo-o", - "kommo_o": "Kommo-o", - "tapu_koko": "Tapu Koko", - "tapu_lele": "Tapu Lele", - "tapu_bulu": "Tapu Bulu", - "tapu_fini": "Tapu Fini", - "cosmog": "Cosmog", - "cosmoem": "Cosmoem", - "solgaleo": "Solgaleo", - "lunala": "Lunala", - "nihilego": "Nihilego", - "buzzwole": "Buzzwole", - "pheromosa": "Pheromosa", - "xurkitree": "Xurkitree", - "celesteela": "Celesteela", - "kartana": "Kartana", - "guzzlord": "Guzzlord", - "necrozma": "Necrozma", - "magearna": "Magearna", - "marshadow": "Marshadow", - "poipole": "Poipole", - "naganadel": "Naganadel", - "stakataka": "Stakataka", - "blacephalon": "Blacephalon", - "zeraora": "Zeraora", - "meltan": "Meltan", - "melmetal": "Melmetal", - "grookey": "Grookey", - "thwackey": "Thwackey", - "rillaboom": "Rillaboom", - "scorbunny": "Scorbunny", - "raboot": "Raboot", - "cinderace": "Cinderace", - "sobble": "Sobble", - "drizzile": "Drizzile", - "inteleon": "Inteleon", - "skwovet": "Skwovet", - "greedent": "Greedent", - "rookidee": "Rookidee", - "corvisquire": "Corvisquire", - "corviknight": "Corviknight", - "blipbug": "Blipbug", - "dottler": "Dottler", - "orbeetle": "Orbeetle", - "nickit": "Nickit", - "thievul": "Thievul", - "gossifleur": "Gossifleur", - "eldegoss": "Eldegoss", - "wooloo": "Wooloo", - "dubwool": "Dubwool", - "chewtle": "Chewtle", - "drednaw": "Drednaw", - "yamper": "Yamper", - "boltund": "Boltund", - "rolycoly": "Rolycoly", - "carkol": "Carkol", - "coalossal": "Coalossal", - "applin": "Applin", - "flapple": "Flapple", - "appletun": "Appletun", - "silicobra": "Silicobra", - "sandaconda": "Sandaconda", - "cramorant": "Cramorant", - "arrokuda": "Arrokuda", - "barraskewda": "Barraskewda", - "toxel": "Toxel", - "toxtricity": "Toxtricity", - "sizzlipede": "Sizzlipede", - "centiskorch": "Centiskorch", - "clobbopus": "Clobbopus", - "grapploct": "Grapploct", - "sinistea": "Sinistea", - "polteageist": "Polteageist", - "hatenna": "Hatenna", - "hattrem": "Hattrem", - "hatterene": "Hatterene", - "impidimp": "Impidimp", - "morgrem": "Morgrem", - "grimmsnarl": "Grimmsnarl", - "obstagoon": "Obstagoon", - "perrserker": "Perrserker", - "cursola": "Cursola", - "sirfetchd": "Sirfetch'd", - "mr_rime": "Mr. Rime", - "runerigus": "Runerigus", - "milcery": "Milcery", - "alcremie": "Alcremie", - "falinks": "Falinks", - "pincurchin": "Pincurchin", - "snom": "Snom", - "frosmoth": "Frosmoth", - "stonjourner": "Stonjourner", - "eiscue": "Eiscue", - "indeedee": "Indeedee", - "morpeko": "Morpeko", - "cufant": "Cufant", - "copperajah": "Copperajah", - "dracozolt": "Dracozolt", - "arctozolt": "Arctozolt", - "dracovish": "Dracovish", - "arctovish": "Arctovish", - "duraludon": "Duraludon", - "dreepy": "Dreepy", - "drakloak": "Drakloak", - "dragapult": "Dragapult", - "zacian": "Zacian", - "zamazenta": "Zamazenta", - "eternatus": "Eternatus", - "kubfu": "Kubfu", - "urshifu": "Urshifu", - "zarude": "Zarude", - "regieleki": "Regieleki", - "regidrago": "Regidrago", - "glastrier": "Glastrier", - "spectrier": "Spectrier", - "calyrex": "Calyrex", - "wyrdeer": "Wyrdeer", - "kleavor": "Kleavor", - "ursaluna": "Ursaluna", - "basculegion": "Basculegion", - "sneasler": "Sneasler", - "overqwil": "Overqwil", - "enamorus": "Enamorus", - "sprigatito": "Sprigatito", - "floragato": "Floragato", - "meowscarada": "Meowscarada", - "fuecoco": "Fuecoco", - "crocalor": "Crocalor", - "skeledirge": "Skeledirge", - "quaxly": "Quaxly", - "quaxwell": "Quaxwell", - "quaquaval": "Quaquaval", - "lechonk": "Lechonk", - "oinkologne": "Oinkologne", - "tarountula": "Tarountula", - "spidops": "Spidops", - "nymble": "Nymble", - "lokix": "Lokix", - "pawmi": "Pawmi", - "pawmo": "Pawmo", - "pawmot": "Pawmot", - "tandemaus": "Tandemaus", - "maushold": "Maushold", - "fidough": "Fidough", - "dachsbun": "Dachsbun", - "smoliv": "Smoliv", - "dolliv": "Dolliv", - "arboliva": "Arboliva", - "squawkabilly": "Squawkabilly", - "nacli": "Nacli", - "naclstack": "Naclstack", - "garganacl": "Garganacl", - "charcadet": "Charcadet", - "armarouge": "Armarouge", - "ceruledge": "Ceruledge", - "tadbulb": "Tadbulb", - "bellibolt": "Bellibolt", - "wattrel": "Wattrel", - "kilowattrel": "Kilowattrel", - "maschiff": "Maschiff", - "mabosstiff": "Mabosstiff", - "shroodle": "Shroodle", - "grafaiai": "Grafaiai", - "bramblin": "Bramblin", - "brambleghast": "Brambleghast", - "toedscool": "Toedscool", - "toedscruel": "Toedscruel", - "klawf": "Klawf", - "capsakid": "Capsakid", - "scovillain": "Scovillain", - "rellor": "Rellor", - "rabsca": "Rabsca", - "flittle": "Flittle", - "espathra": "Espathra", - "tinkatink": "Tinkatink", - "tinkatuff": "Tinkatuff", - "tinkaton": "Tinkaton", - "wiglett": "Wiglett", - "wugtrio": "Wugtrio", - "bombirdier": "Bombirdier", - "finizen": "Finizen", - "palafin": "Palafin", - "varoom": "Varoom", - "revavroom": "Revavroom", - "cyclizar": "Cyclizar", - "orthworm": "Orthworm", - "glimmet": "Glimmet", - "glimmora": "Glimmora", - "greavard": "Greavard", - "houndstone": "Houndstone", - "flamigo": "Flamigo", - "cetoddle": "Cetoddle", - "cetitan": "Cetitan", - "veluza": "Veluza", - "dondozo": "Dondozo", - "tatsugiri": "Tatsugiri", - "annihilape": "Annihilape", - "clodsire": "Clodsire", - "farigiraf": "Farigiraf", - "dudunsparce": "Dudunsparce", - "kingambit": "Kingambit", - "great_tusk": "Presa Grande", - "scream_tail": "Cauda Brado", - "brute_bonnet": "Capuz Bruto", - "flutter_mane": "Juba Sopro", - "slither_wing": "Asa Rasteira", - "sandy_shocks": "Choque Areia", - "iron_treads": "Trilho Férreo", - "iron_bundle": "Pacote Férreo", - "iron_hands": "Mãos Férreas", - "iron_jugulis": "Jugulares Férreas", - "iron_moth": "Mariposa Férrea", - "iron_thorns": "Espinhos Férreos", - "frigibax": "Frigibax", - "arctibax": "Arctibax", - "baxcalibur": "Baxcalibur", - "gimmighoul": "Gimmighoul", - "gholdengo": "Gholdengo", - "wo_chien": "Wo-Chien", - "chien_pao": "Chien-Pao", - "ting_lu": "Ting-Lu", - "chi_yu": "Chi-Yu", - "roaring_moon": "Lua Estrondo", - "iron_valiant": "Valentia Férrea", - "koraidon": "Koraidon", - "miraidon": "Miraidon", - "walking_wake": "Onda Ando", - "iron_leaves": "Folhas Férreas", - "dipplin": "Dipplin", - "poltchageist": "Poltchageist", - "sinistcha": "Sinistcha", - "okidogi": "Okidogi", - "munkidori": "Munkidori", - "fezandipiti": "Fezandipiti", - "ogerpon": "Ogerpon", - "archaludon": "Archaludon", - "hydrapple": "Hydrapple", - "gouging_fire": "Fogo Corrosão", - "raging_bolt": "Raio Fúria", - "iron_boulder": "Rocha Férrea", - "iron_crown": "Chifres Férreos", - "terapagos": "Terapagos", - "pecharunt": "Pecharunt", - "alola_rattata": "Rattata", - "alola_raticate": "Raticate", - "alola_raichu": "Raichu", - "alola_sandshrew": "Sandshrew", - "alola_sandslash": "Sandslash", - "alola_vulpix": "Vulpix", - "alola_ninetales": "Ninetales", - "alola_diglett": "Diglett", - "alola_dugtrio": "Dugtrio", - "alola_meowth": "Meowth", - "alola_persian": "Persian", - "alola_geodude": "Geodude", - "alola_graveler": "Graveler", - "alola_golem": "Golem", - "alola_grimer": "Grimer", - "alola_muk": "Muk", - "alola_exeggutor": "Exeggutor", - "alola_marowak": "Marowak", - "eternal_floette": "Floette", - "galar_meowth": "Meowth", - "galar_ponyta": "Ponyta", - "galar_rapidash": "Rapidash", - "galar_slowpoke": "Slowpoke", - "galar_slowbro": "Slowbro", - "galar_farfetchd": "Farfetch'd", - "galar_weezing": "Weezing", - "galar_mr_mime": "Mr. Mime", - "galar_articuno": "Articuno", - "galar_zapdos": "Zapdos", - "galar_moltres": "Moltres", - "galar_slowking": "Slowking", - "galar_corsola": "Corsola", - "galar_zigzagoon": "Zigzagoon", - "galar_linoone": "Linoone", - "galar_darumaka": "Darumaka", - "galar_darmanitan": "Darmanitan", - "galar_yamask": "Yamask", - "galar_stunfisk": "Stunfisk", - "hisui_growlithe": "Growlithe", - "hisui_arcanine": "Arcanine", - "hisui_voltorb": "Voltorb", - "hisui_electrode": "Electrode", - "hisui_typhlosion": "Typhlosion", - "hisui_qwilfish": "Qwilfish", - "hisui_sneasel": "Sneasel", - "hisui_samurott": "Samurott", - "hisui_lilligant": "Lilligant", - "hisui_zorua": "Zorua", - "hisui_zoroark": "Zoroark", - "hisui_braviary": "Braviary", - "hisui_sliggoo": "Sliggoo", - "hisui_goodra": "Goodra", - "hisui_avalugg": "Avalugg", - "hisui_decidueye": "Decidueye", - "paldea_tauros": "Tauros", - "paldea_wooper": "Wooper", - "bloodmoon_ursaluna": "Ursaluna" -} \ No newline at end of file diff --git a/src/locales/pt_BR/run-history.json b/src/locales/pt_BR/run-history.json deleted file mode 100644 index 74cc2c35d28..00000000000 --- a/src/locales/pt_BR/run-history.json +++ /dev/null @@ -1,37 +0,0 @@ -{ - "victory": "Vitória!", - "defeatedWild": "Derrotado por ", - "defeatedTrainer": "Derrotado por ", - "defeatedTrainerDouble": "Derrotado por Dupla", - "defeatedRival": "Derrotado por Rival", - "defeated": "Derrotado", - "defeatedWild_female": "Derrotada por ", - "defeatedTrainer_female": "Derrotada por ", - "defeatedTrainerDouble_female": "Derrotada por Dupla", - "defeatedRival_female": "Derrotada por Rival", - "defeated_female": "Derrotada", - "luck": "Sorte", - "score": "Pontuação", - "mode": "Modo", - "challengeRules": "Regra(s)", - "challengeMonoGen1": "Ger. 1", - "challengeMonoGen2": "Ger. 2", - "challengeMonoGen3": "Ger. 3", - "challengeMonoGen4": "Ger. 4", - "challengeMonoGen5": "Ger. 5", - "challengeMonoGen6": "Ger. 6", - "challengeMonoGen7": "Ger. 7", - "challengeMonoGen8": "Ger. 8", - "challengeMonoGen9": "Ger. 9", - "playerItems": "Itens do Jogador", - "personalBest": "Recorde Pessoal!", - "SPDshortened": "Vel.", - "runInfo": "Info. do Jogo", - "money": "Dinheiro", - "runLength": "Duração do Jogo", - "viewHeldItems": "Itens Segurados", - "hallofFameText": "Bem-vindo ao Hall da Fama!", - "hallofFameText_female": "Bem-vinda ao Hall da Fama!", - "viewHallOfFame": "Veja o Hall da Fama!", - "viewEndingSplash": "Veja a arte final!" -} \ No newline at end of file diff --git a/src/locales/pt_BR/save-slot-select-ui-handler.json b/src/locales/pt_BR/save-slot-select-ui-handler.json deleted file mode 100644 index 31fe28de691..00000000000 --- a/src/locales/pt_BR/save-slot-select-ui-handler.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "overwriteData": "Substituir os dados desse slot?", - "loading": "Carregando...", - "wave": "Onda", - "lv": "Nv", - "empty": "Vazio" -} \ No newline at end of file diff --git a/src/locales/pt_BR/settings.json b/src/locales/pt_BR/settings.json deleted file mode 100644 index 74f3918bed8..00000000000 --- a/src/locales/pt_BR/settings.json +++ /dev/null @@ -1,107 +0,0 @@ -{ - "boy": "Menino", - "girl": "Menina", - "general": "Geral", - "display": "Exibição", - "audio": "Áudio", - "gamepad": "Controle", - "keyboard": "Teclado", - "gameSpeed": "Velocidade do Jogo", - "hpBarSpeed": "Velocidade da Barra de PS", - "expGainsSpeed": "Velocidade do Ganho de EXP", - "expPartyDisplay": "Exibição de EXP da Equipe", - "skipSeenDialogues": "Pular Diálogos Vistos", - "battleStyle": "Estilo de Batalha", - "enableRetries": "Habilitar Novas Tentativas", - "hideIvs": "Esconder scanner de IV", - "tutorials": "Tutorial", - "touchControls": "Controles de Toque", - "vibrations": "Vibração", - "normal": "Normal", - "fast": "Rápido", - "faster": "Mais Rápido", - "skip": "Pular", - "levelUpNotifications": "Notificação", - "on": "Ligado", - "off": "Desligado", - "switch": "Alternar", - "set": "Definido", - "auto": "Automático", - "disabled": "Desativado", - "language": "Idioma", - "change": "Mudar", - "uiTheme": "Tema da Interface", - "default": "Padrão", - "legacy": "Legado", - "windowType": "Estilo da Janela", - "moneyFormat": "Formatação do Dinheiro", - "damageNumbers": "Números de Dano", - "simple": "Simples", - "fancy": "Detalhado", - "abbreviated": "Abreviado", - "moveAnimations": "Animações de Movimento", - "showStatsOnLevelUp": "Mostrar Atributos ao Subir de Nível", - "candyUpgradeNotification": "Exibir Melhorias com Doce", - "passivesOnly": "Passivas", - "candyUpgradeDisplay": "Modo Melhorias com Doce", - "icon": "Ícone", - "animation": "Animação", - "moveInfo": "Informações de Movimento", - "showMovesetFlyout": "Mostrar Flutuante de Movimentos", - "showArenaFlyout": "Mostrar Flutuante de Bioma", - "showTimeOfDayWidget": "Widget da Hora do Dia", - "timeOfDayAnimation": "Animação da Hora do Dia", - "bounce": "Saltar", - "timeOfDay_back": "Voltar", - "spriteSet": "Conjunto de Sprites", - "consistent": "Consistente", - "mixedAnimated": "Animado", - "fusionPaletteSwaps": "Cores da Paleta de Fusão", - "playerGender": "Gênero do Jogador", - "typeHints": "Dicas de Tipo", - "masterVolume": "Volume Mestre", - "bgmVolume": "Músicas", - "fieldVolume": "Ambiente", - "seVolume": "Ef. Sonoros", - "uiVolume": "Interface", - "musicPreference": "Preferência de Música", - "mixed": "Misto", - "gamepadPleasePlug": "Conecte um controle ou pressione um botão", - "delete": "Deletar", - "keyboardPleasePress": "Pressione uma tecla", - "reset": "Redefinir", - "requireReload": "Requer Reinício", - "action": "Ação", - "back": "Voltar", - "pressToBind": "Pressione para Atribuir", - "pressButton": "Pressione um Botão...", - "buttonUp": "Cima", - "buttonDown": "Baixo", - "buttonLeft": "Esquerda", - "buttonRight": "Direita", - "buttonAction": "Ação", - "buttonMenu": "Menu", - "buttonSubmit": "Confirmar", - "buttonCancel": "Cancelar", - "buttonStats": "Atributos", - "buttonCycleForm": "Próxima Forma", - "buttonCycleShiny": "Próximo Shiny", - "buttonCycleGender": "Próximo Gênero", - "buttonCycleAbility": "Próxima Habilidade", - "buttonCycleNature": "Próxima Natureza", - "buttonCycleVariant": "Próxima Variante", - "buttonSpeedUp": "Acelerar", - "buttonSlowDown": "Desacelerar", - "alt": " (Alt)", - "mute": "Mudo", - "controller": "Controle", - "gamepadSupport": "Suporte para Controle", - "showBgmBar": "Exibir Nomes das Músicas", - "moveTouchControls": "Mover Controles de Toque", - "shopOverlayOpacity": "Opacidade da Loja", - "shopCursorTarget": "Alvo do Cursor da Loja", - "rewards": "Itens", - "reroll": "Atualizar", - "shop": "Loja", - "checkTeam": "Checar Time" -} diff --git a/src/locales/pt_BR/splash-messages.json b/src/locales/pt_BR/splash-messages.json deleted file mode 100644 index 55c0b1b9e74..00000000000 --- a/src/locales/pt_BR/splash-messages.json +++ /dev/null @@ -1,36 +0,0 @@ -{ - "battlesWon": "Batalhas Ganhas!", - "joinTheDiscord": "Junte-se ao Discord!", - "infiniteLevels": "Níveis Infinitos!", - "everythingStacks": "Tudo Acumula!", - "optionalSaveScumming": "Você Pode Dar F5!", - "biomes": "35 Biomas!", - "openSource": "Código Aberto!", - "playWithSpeed": "Jogue na Velocidade 5x!", - "liveBugTesting": "Testamos os Bugs Ao Vivo!", - "heavyInfluence": "Grande Influência de RoR2!", - "pokemonRiskAndPokemonRain": "Pokémon Risk e Pokémon Rain!", - "nowWithMoreSalt": "O Choro é Livre!", - "infiniteFusionAtHome": "Infinite Fusion da Shopee!", - "brokenEggMoves": "Mov. de Ovo Apelões!", - "magnificent": "Magnífico!", - "mubstitute": "Mubstituto!", - "thatsCrazy": "Que Doidera!", - "oranceJuice": "Suco de Laranja!", - "questionableBalancing": "Balanceamento Questionável!", - "coolShaders": "Shader Maneiros!", - "aiFree": "Livre de IA!", - "suddenDifficultySpikes": "Ficou Difícil do Nada!", - "basedOnAnUnfinishedFlashGame": "Baseado num Jogo Online Inacabado!", - "moreAddictiveThanIntended": "Mais Viciante do que Planejado!", - "mostlyConsistentSeeds": "Consistente (na Maioria das Vezes)!", - "achievementPointsDontDoAnything": "Pontos de Conquista Não Fazem Nada!", - "youDoNotStartAtLevel": "Você Não Começa no Nível 2000!", - "dontTalkAboutTheManaphyEggIncident": "Não Fale do Incidente do Ovo de Manaphy!", - "alsoTryPokengine": "Também Jogue Pokéngine!", - "alsoTryEmeraldRogue": "Também Jogue Emerald Rogue!", - "alsoTryRadicalRed": "Também Jogue Radical Red!", - "eeveeExpo": "Eevee Expo!", - "ynoproject": "YNOproject!", - "breedersInSpace": "Criadores Pokémon no Espaço!" -} \ No newline at end of file diff --git a/src/locales/pt_BR/starter-select-ui-handler.json b/src/locales/pt_BR/starter-select-ui-handler.json deleted file mode 100644 index 1d83e43f12c..00000000000 --- a/src/locales/pt_BR/starter-select-ui-handler.json +++ /dev/null @@ -1,45 +0,0 @@ -{ - "confirmStartTeam": "Começar com esses Pokémon?", - "confirmExit": "Deseja sair?", - "invalidParty": "Essa equipe de iniciais não é válida!", - "gen1": "G1", - "gen2": "G2", - "gen3": "G3", - "gen4": "G4", - "gen5": "G5", - "gen6": "G6", - "gen7": "G7", - "gen8": "G8", - "gen9": "G9", - "growthRate": "Crescimento:", - "ability": "Habilidade:", - "passive": "Passiva:", - "nature": "Natureza:", - "eggMoves": "Mov. de Ovo", - "addToParty": "Adicionar à equipe", - "removeFromParty": "Remover da Equipe", - "toggleIVs": "Mostrar IVs", - "manageMoves": "Mudar Movimentos", - "manageNature": "Mudar Natureza", - "addToFavorites": "Adicionar aos Favoritos", - "removeFromFavorites": "Remover dos Favoritos", - "useCandies": "Usar Doces", - "selectNature": "Escolha uma natureza.", - "selectMoveSwapOut": "Escolha um movimento para substituir.", - "selectMoveSwapWith": "Escolha o movimento que substituirá", - "sameSpeciesEgg": "Comprar Ovo", - "unlockPassive": "Aprender Passiva", - "reduceCost": "Reduzir Custo", - "cycleShiny": ": » Shiny", - "cycleForm": ": » Forma", - "cycleGender": ": » Gênero", - "cycleAbility": ": » Habilidade", - "cycleNature": ": » Natureza", - "cycleVariant": ": » Variante", - "goFilter": ": Ir para filtros", - "enablePassive": "Ativar Passiva", - "disablePassive": "Desativar Passiva", - "locked": "Bloqueada", - "disabled": "Desativada", - "uncaught": "Não capturado" -} \ No newline at end of file diff --git a/src/locales/pt_BR/status-effect.json b/src/locales/pt_BR/status-effect.json deleted file mode 100644 index 5a851a0bdeb..00000000000 --- a/src/locales/pt_BR/status-effect.json +++ /dev/null @@ -1,65 +0,0 @@ -{ - "none": { - "name": "Nenhum", - "description": "", - "obtain": "", - "obtainSource": "", - "activation": "", - "overlap": "", - "heal": "" - }, - "poison": { - "name": "Envenenamento", - "description": "envenenamento", - "obtain": "{{pokemonNameWithAffix}}\nfoi envenenado!", - "obtainSource": "{{pokemonNameWithAffix}}\nfoi envenenado por {{sourceText}}!", - "activation": "{{pokemonNameWithAffix}} foi ferido\ncom o veneno!", - "overlap": "{{pokemonNameWithAffix}} já\nestá envenenado!", - "heal": "{{pokemonNameWithAffix}} se\ncurou do envenenamento!" - }, - "toxic": { - "name": "Toxic", - "description": "envenenamento", - "obtain": "{{pokemonNameWithAffix}}\nfoi seriamente envenenado!", - "obtainSource": "{{pokemonNameWithAffix}} foi seriamente\nenvenenado por {{sourceText}}!", - "activation": "{{pokemonNameWithAffix}} foi ferido\ncom o veneno!", - "overlap": "{{pokemonNameWithAffix}} já\nestá envenenado!", - "heal": "{{pokemonNameWithAffix}} se\ncurou do envenenamento!" - }, - "paralysis": { - "name": "Paralisia", - "description": "paralisia", - "obtain": "{{pokemonNameWithAffix}} foi paralisado,\nTalvez ele não consiga se mover!", - "obtainSource": "{{pokemonNameWithAffix}} foi paralisado por {{sourceText}},\nTalvez ele não consiga se mover!", - "activation": "{{pokemonNameWithAffix}} está paralisado!\nEle não consegue se mover!", - "overlap": "{{pokemonNameWithAffix}} já\nestá paralisado!", - "heal": "{{pokemonNameWithAffix}} foi\ncurado da paralisia!" - }, - "sleep": { - "name": "Dormindo", - "description": "dormindo", - "obtain": "{{pokemonNameWithAffix}}\nadormeceu!", - "obtainSource": "{{pokemonNameWithAffix}}\ndormiu devido a {{sourceText}}!", - "activation": "{{pokemonNameWithAffix}} está dormindo profundamente.", - "overlap": "{{pokemonNameWithAffix}} já\nestá dormindo!", - "heal": "{{pokemonNameWithAffix}} acordou!" - }, - "freeze": { - "name": "Congelamento", - "description": "congelando", - "obtain": "{{pokemonNameWithAffix}}\nfoi congelado!", - "obtainSource": "{{pokemonNameWithAffix}}\nfoi congelado por {{sourceText}}!", - "activation": "{{pokemonNameWithAffix}} está\ncongelado!", - "overlap": "{{pokemonNameWithAffix}} já\nestá congelado!", - "heal": "{{pokemonNameWithAffix}} foi\ndescongelado!" - }, - "burn": { - "name": "Queimadura", - "description": "queimadura", - "obtain": "{{pokemonNameWithAffix}}\nfoi queimado!", - "obtainSource": "{{pokemonNameWithAffix}}\nfoi queimado por {{sourceText}}!", - "activation": "{{pokemonNameWithAffix}} foi ferido\npor sua queimadura!", - "overlap": "{{pokemonNameWithAffix}} já\nestá queimado!", - "heal": "{{pokemonNameWithAffix}} foi\ncurado de sua queimadura!" - } -} \ No newline at end of file diff --git a/src/locales/pt_BR/terrain.json b/src/locales/pt_BR/terrain.json deleted file mode 100644 index 73df2b441ac..00000000000 --- a/src/locales/pt_BR/terrain.json +++ /dev/null @@ -1,16 +0,0 @@ -{ - "misty": "Enevoado", - "mistyStartMessage": "Uma névoa se espalhou pelo campo de batalha!", - "mistyClearMessage": "A névou sumiu do campo de batalha.", - "mistyBlockMessage": "{{pokemonNameWithAffix}} se envolveu com uma névoa protetora!", - "electric": "Elétrico", - "electricStartMessage": "Uma corrente elétrica se espalhou pelo campo de batalha!", - "electricClearMessage": "A eletricidade sumiu do campo de batalha.", - "grassy": "de Plantas", - "grassyStartMessage": "Grama cresceu para cobrir o campo de batalha!", - "grassyClearMessage": "A grama sumiu do campo de batalha.", - "psychic": "Psíquico", - "psychicStartMessage": "O campo de batalha ficou esquisito!", - "psychicClearMessage": "A esquisitice sumiu do campo de batalha!", - "defaultBlockMessage": "{{pokemonNameWithAffix}} está protegido pelo Terreno {{terrainName}}!" -} \ No newline at end of file diff --git a/src/locales/pt_BR/trainer-classes.json b/src/locales/pt_BR/trainer-classes.json deleted file mode 100644 index 482265d00c6..00000000000 --- a/src/locales/pt_BR/trainer-classes.json +++ /dev/null @@ -1,131 +0,0 @@ -{ - "ace_trainer": "Treinador Ás", - "ace_trainer_female": "Treinadora Ás", - "ace_duo": "Dupla Ás", - "artist": "Artista", - "artist_female": "Artista", - "backers": "Torcedores", - "backpacker": "Mochileiro", - "backpacker_female": "Mochileira", - "backpackers": "Mochileiros", - "baker": "Padeira", - "battle_girl": "Lutadora", - "beauty": "Modelo", - "beginners": "Iniciantes", - "biker": "Motoqueiro", - "black_belt": "Faixa Preta", - "breeder": "Criador", - "breeder_female": "Criadora", - "breeders": "Criadores", - "clerk": "Funcionário", - "clerk_female": "Funcionária", - "colleagues": "Funcionários", - "crush_kin": "Casal Lutador", - "cyclist": "Ciclista", - "cyclist_female": "Ciclista", - "cyclists": "Ciclistas", - "dancer": "Dançarino", - "dancer_female": "Dançarina", - "depot_agent": "Ferroviário", - "doctor": "Doutor", - "doctor_female": "Doutora", - "firebreather": "Cospe-Fogo", - "fisherman": "Pescador", - "fisherman_female": "Pescadora", - "gentleman": "Cavalheiro", - "guitarist": "Guitarrista", - "guitarist_female": "Guitarrista", - "harlequin": "Arlequim", - "hiker": "Montanhista", - "hooligans": "Bandoleiro", - "hoopster": "Jogador de Basquete", - "infielder": "Jogador de Baseball", - "janitor": "Faxineiro", - "lady": "Dama", - "lass": "Senhorita", - "linebacker": "Zagueiro", - "maid": "Doméstica", - "madame": "Madame", - "medical_team": "Equipe Médica", - "musician": "Músico", - "hex_maniac": "Ocultista", - "nurse": "Enfermeira", - "nursery_aide": "Professora do Berçário", - "officer": "Policial", - "parasol_lady": "Moça de Sombrinha", - "pilot": "Piloto", - "pokéfan": "Pokefã", - "pokéfan_female": "Pokéfã", - "pokéfan_family": "Família Pokefã", - "preschooler": "Menino do Prezinho", - "preschooler_female": "Menina do Prezinho", - "preschoolers": "Alunos do Prezinho", - "psychic": "Médium", - "psychic_female": "Médium", - "psychics": "Médiuns", - "pokémon_ranger": "Guarda Pokémon", - "pokémon_ranger_female": "Guarda Pokémon", - "pokémon_rangers": "Guardas Pokémon", - "ranger": "Guarda", - "restaurant_staff": "Equipe do Restaurante", - "rich": "Burguês", - "rich_female": "Burguesa", - "rich_boy": "Riquinho", - "rich_couple": "Casal Burguês", - "rich_kid": "Garoto Rico", - "rich_kid_female": "Garota Rica", - "rich_kids": "Garotos Ricos", - "roughneck": "Arruaceiro", - "sailor": "Marinheiro", - "scientist": "Cientista", - "scientist_female": "Cientista", - "scientists": "Cientistas", - "smasher": "Tenista", - "snow_worker": "Operário da Neve", - "snow_worker_female": "Operária da Neve", - "striker": "Atacante", - "school_kid": "Estudante", - "school_kid_female": "Estudante", - "school_kids": "Estudantes", - "swimmer": "Nadador", - "swimmer_female": "Nadadora", - "swimmers": "Nadadores", - "twins": "Gêmeos", - "veteran": "Veterano", - "veteran_female": "Veterana", - "veteran_duo": "Dupla Veterana", - "waiter": "Garçom", - "waitress": "Garçonete", - "worker": "Operário", - "worker_female": "Operária", - "workers": "Operários", - "youngster": "Jovem", - "rocket_grunt": "Capanga da Equipe Rocket", - "rocket_grunts": "Capangas da Equipe Rocket", - "rocket_grunt_female": "Capanga da Equipe Rocket", - "magma_grunt": "Capanga da Equipe Magma", - "magma_grunt_female": "Capanga da Equipe Magma", - "magma_grunts": "Capangas da Equipe Magma", - "aqua_grunt": "Capanga da Equipe Aqua", - "aqua_grunt_female": "Capanga da Equipe Aqua", - "aqua_grunts": "Capangas da Equipe Aqua", - "galactic_grunt": "Capanga da Equipe Galáctica", - "galactic_grunt_female": "Capanga da Equipe Galáctica", - "galactic_grunts": "Capangas da Equipe Galáctica", - "plasma_grunt": "Capanga da Equipe Plasma", - "plasma_grunt_female": "Capanga da Equipe Plasma", - "plasma_grunts": "Capangas da Equipe Plasma", - "flare_grunt": "Capanga da Equipe Flare", - "flare_grunt_female": "Capanga da Equipe Flare", - "flare_grunts": "Capangas da Equipe Flare", - "aether_grunt": "Funcionário da Fundação Aether", - "aether_grunt_female": "Funcionária da Fundação Aether", - "aether_grunts": "Funcionários da Fundação Aether", - "skull_grunt": "Capanga da Equipe Skull", - "skull_grunt_female": "Capanga da Equipe Skull", - "skull_grunts": "Capangas da Equipe Skull", - "macro_grunt": "Treinador da Macro Cosmos", - "macro_grunt_female": "Treinadora da Macro Cosmos", - "macro_grunts": "Treinadores da Macro Cosmos" - -} diff --git a/src/locales/pt_BR/trainer-names.json b/src/locales/pt_BR/trainer-names.json deleted file mode 100644 index 5500e2ddb46..00000000000 --- a/src/locales/pt_BR/trainer-names.json +++ /dev/null @@ -1,162 +0,0 @@ -{ - "brock": "Brock", - "misty": "Misty", - "lt_surge": "Ten. Surge", - "erika": "Erika", - "janine": "Janine", - "sabrina": "Sabrina", - "blaine": "Blaine", - "giovanni": "Giovanni", - "falkner": "Falkner", - "bugsy": "Bugsy", - "whitney": "Whitney", - "morty": "Morty", - "chuck": "Chuck", - "jasmine": "Jasmine", - "pryce": "Pryce", - "clair": "Clair", - "roxanne": "Roxanne", - "brawly": "Brawly", - "wattson": "Wattson", - "flannery": "Flannery", - "norman": "Norman", - "winona": "Winona", - "tate": "Tate", - "liza": "Liza", - "juan": "Juan", - "roark": "Roark", - "gardenia": "Gardenia", - "maylene": "Maylene", - "crasher_wake": "Demolidor Wake", - "fantina": "Fantina", - "byron": "Byron", - "candice": "Candice", - "volkner": "Volkner", - "cilan": "Cilan", - "chili": "Chili", - "cress": "Cress", - "cheren": "Cheren", - "lenora": "Lenora", - "roxie": "Roxie", - "burgh": "Burgh", - "elesa": "Elesa", - "clay": "Clay", - "skyla": "Skyla", - "brycen": "Brycen", - "drayden": "Drayden", - "marlon": "Marlon", - "viola": "Viola", - "grant": "Grant", - "korrina": "Korrina", - "ramos": "Ramos", - "clemont": "Clemont", - "valerie": "Valerie", - "olympia": "Olympia", - "wulfric": "Wulfric", - "milo": "Milo", - "nessa": "Nessa", - "kabu": "Kabu", - "bea": "Bea", - "allister": "Allister", - "opal": "Opal", - "bede": "Bede", - "gordie": "Gordie", - "melony": "Melony", - "piers": "Piers", - "marnie": "Marnie", - "raihan": "Raihan", - "katy": "Katy", - "brassius": "Brassius", - "iono": "Iono", - "kofu": "Kofu", - "larry": "Larry", - "ryme": "Ryme", - "tulip": "Tulip", - "grusha": "Grusha", - "lorelei": "Lorelei", - "bruno": "Bruno", - "agatha": "Agatha", - "lance": "Lance", - "will": "Will", - "koga": "Koga", - "karen": "Karen", - "sidney": "Sidney", - "phoebe": "Phoebe", - "glacia": "Glacia", - "drake": "Drake", - "aaron": "Aaron", - "bertha": "Bertha", - "flint": "Flint", - "lucian": "Lucian", - "shauntal": "Shauntal", - "marshal": "Marshal", - "grimsley": "Grimsley", - "caitlin": "Caitlin", - "malva": "Malva", - "siebold": "Siebold", - "wikstrom": "Wikstrom", - "drasna": "Drasna", - "hala": "Hala", - "molayne": "Molayne", - "olivia": "Olivia", - "acerola": "Acerola", - "kahili": "Kahili", - "rika": "Rika", - "poppy": "Poppy", - "hassel": "Hassel", - "crispin": "Crispin", - "amarys": "Amarys", - "lacey": "Lacey", - "drayton": "Drayton", - "blue": "Blue", - "red": "Red", - "steven": "Steven", - "wallace": "Wallace", - "cynthia": "Cynthia", - "alder": "Alder", - "iris": "Iris", - "diantha": "Diantha", - "hau": "Hau", - "geeta": "Geeta", - "nemona": "Nemona", - "kieran": "Kieran", - "leon": "Leon", - "rival": "Finn", - "rival_female": "Ivy", - "archer": "Archer", - "ariana": "Ariana", - "proton": "Proton", - "petrel": "Petrel", - "tabitha": "Tabitha", - "courtney": "Courtney", - "shelly": "Shelly", - "matt": "Matt", - "mars": "Mars", - "jupiter": "Jupiter", - "saturn": "Saturn", - "zinzolin": "Zinzolin", - "rood": "Rood", - "xerosic": "Xerosic", - "bryony": "Bryony", - "faba": "Faba", - "plumeria": "Plumeria", - "oleana": "Oleana", - "maxie": "Maxie", - "archie": "Archie", - "cyrus": "Cyrus", - "ghetsis": "Ghetsis", - "lysandre": "Lysandre", - "lusamine": "Lusamine", - "guzma": "Guzma", - "rose": "Rose", - "blue_red_double": "Blue & Red", - "red_blue_double": "Red & Blue", - "tate_liza_double": "Tate & Liza", - "liza_tate_double": "Liza & Tate", - "steven_wallace_double": "Steven & Wallace", - "wallace_steven_double": "Wallace & Steven", - "alder_iris_double": "Alder & Iris", - "iris_alder_double": "Iris & Alder", - "marnie_piers_double": "Marnie & Piers", - "piers_marnie_double": "Piers & Marnie" -} diff --git a/src/locales/pt_BR/trainer-titles.json b/src/locales/pt_BR/trainer-titles.json deleted file mode 100644 index 701c2e143fa..00000000000 --- a/src/locales/pt_BR/trainer-titles.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "elite_four": "Elite dos Quatro", - "elite_four_female": "Elite dos Quatro", - "gym_leader": "Líder de Ginásio", - "gym_leader_female": "Líder de Ginásio", - "gym_leader_double": "Líderes de Ginásio", - "champion": "Campeão", - "champion_female": "Campeã", - "champion_double": "Dupla Campeã", - "rival": "Rival", - "professor": "Professor", - "frontier_brain": "Cérebro da Fronteira", - "rocket_boss": "Chefe da Equipe Rocket", - "magma_boss": "Chefe da Equipe Magma", - "aqua_boss": "Chefe da Equipe Aqua", - "galactic_boss": "Chefe da Equipe Galáctica", - "plasma_boss": "Chefe da Equipe Plasma", - "flare_boss": "Chefe da Equipe Flare", - "aether_boss": "Presidente Aether", - "skull_boss": "Chefe da Equipe Skull", - "macro_boss": "Presidente da Macro Cosmos", - - "rocket_admin": "Admin da Equipe Rocket", - "rocket_admin_female": "Admin da Equipe Rocket", - "magma_admin": "Admin da Equipe Magma", - "magma_admin_female": "Admin da Equipe Magma", - "aqua_admin": "Admin da Equipe Aqua", - "aqua_admin_female": "Admin da Equipe Aqua", - "galactic_commander": "Comandante da Equipe Galáctica", - "galactic_commander_female": "Comandante da Equipe Galáctica", - "plasma_sage": "Sábio da Equipe Plasma", - "plasma_admin": "Admin da Equipe Plasma", - "flare_admin": "Admin da Equipe Flare", - "flare_admin_female": "Admin da Equipe Flare", - "aether_admin": "Admin da Fundação Aether", - "skull_admin": "Admin da Equipe Skull", - "macro_admin": "Macro Cosmos" -} diff --git a/src/locales/pt_BR/tutorial.json b/src/locales/pt_BR/tutorial.json deleted file mode 100644 index 92ea0dd080f..00000000000 --- a/src/locales/pt_BR/tutorial.json +++ /dev/null @@ -1,10 +0,0 @@ -{ - "intro": "Bem-vindo ao PokéRogue!\n$Este é um fangame Pokémon focado em batalhas com elementos roguelite.\n$Este jogo não é monetizado e não reivindicamos propriedade do Pokémon nem dos ativos protegidos$por direitos autorais usados.\n$O jogo é um trabalho em andamento,\nmas totalmente jogável.\n$Para relatórios de bugs, use a comunidade do Discord.\n$Se o jogo rodar lentamente, certifique-se de que\na 'Aceleração de Hardware' esteja ativada$nas configurações do seu navegador.", - "accessMenu": "Para acessar o menu, pressione M ou Esc.\n$O menu contém configurações e diversas funções.", - "menu": "A partir deste menu, você pode\\nacessar as configurações.\n$A partir das configurações, você\npode alterar a velocidade do jogo,\n$o estilo da janela e outras opções.\n$Há também vários outros recursos aqui.\nCertifique-se de verificar todos eles!", - "starterSelect": "Nesta tela, você pode selecionar seus iniciais\npressionando Z ou a barra de espaço.\n$Esses serão os primeiros membros da sua equipe.\n$Cada inicial tem um custo. Sua equipe pode ter até 6 membros,\ndesde que desde que o custo total não exceda 10.\n$Você pode escolher o gênero, a habilidade\ne até a forma do seu inicial.\n$Essas opções dependem das variantes dessa\nespécie que você já capturou ou chocou.\n$Os IVs de cada inicial são os melhores de todos os Pokémon\ndaquela espécie que você já capturou ou chocou.\n$Sempre capture vários Pokémon de todas as espécies!", - "pokerus": "Todo dia, 3 Pokémon iniciais ficam com uma borda roxa.\n$Caso veja um inicial que você possui com uma dessa, tente\nadicioná-lo a sua equipe. Lembre-se de olhar seu sumário!", - "statChange": "As mudanças de atributos se mantém após a batalha desde que o Pokémon não seja trocado.\n$Seus Pokémon voltam a suas Poké Bolas antes de batalhas contra treinadores e de entrar em um novo bioma.\n$Para ver as mudanças de atributos dos Pokémon em campo, mantena C ou Shift pressionado durante a batalha.", - "selectItem": "Após cada batalha, você pode escolher entre 3 itens aleatórios.\n$Você pode escolher apenas um deles.\n$Esses itens variam entre consumíveis, itens de segurar e itens passivos permanentes.\n$A maioria dos efeitos de itens não consumíveis podem ser acumulados.\n$Alguns itens só aparecerão se puderem ser usados, como os itens de evolução.\n$Você também pode transferir itens de segurar entre os Pokémon utilizando a opção \"Alterar\".\n$A opção de transferir irá aparecer no canto inferior direito assim que você obter um item de segurar.\n$Você pode comprar itens consumíveis com dinheiro, e sua variedade aumentará conforme você for mais longe.\n$Certifique-se de comprá-los antes de escolher seu item aleatório. Ao escolhê-lo, a próxima batalha começará.", - "eggGacha": "Nesta tela, você pode trocar seus vouchers por ovos\nde Pokémon.\n$Ovos ficam mais próximos de chocar após cada batalha.\nOvos mais raros demoram mais tempo para chocar.\n$Pokémon chocados não serão adicionados a sua equipe,\nmas sim aos seus iniciais.\n$Pokémon chocados de ovos geralmente têm IVs melhores\ndo que Pokémon selvagens.\n$Alguns Pokémon só podem ser obtidos através de ovos.\n$Existem 3 máquinas para usar com diferentes bônus, então\nescolha a que mais lhe convém!" -} diff --git a/src/locales/pt_BR/voucher.json b/src/locales/pt_BR/voucher.json deleted file mode 100644 index c33dfa20e0f..00000000000 --- a/src/locales/pt_BR/voucher.json +++ /dev/null @@ -1,9 +0,0 @@ -{ - "vouchers": "Vouchers", - "eggVoucher": "Voucher de Ovo", - "eggVoucherPlus": "Voucher de Ovo Plus", - "eggVoucherPremium": "Voucher de Ovo Premium", - "eggVoucherGold": "Voucher de Ovo Dourado", - "locked": "Bloqueado", - "defeatTrainer": "Derrote {{trainerName}}" -} \ No newline at end of file diff --git a/src/locales/pt_BR/weather.json b/src/locales/pt_BR/weather.json deleted file mode 100644 index 54b929da0b9..00000000000 --- a/src/locales/pt_BR/weather.json +++ /dev/null @@ -1,32 +0,0 @@ -{ - "sunnyStartMessage": "A luz do sol ficou clara!", - "sunnyLapseMessage": "A luz do sol está forte.", - "sunnyClearMessage": "A luz do sol sumiu.", - "rainStartMessage": "Começou a chover!", - "rainLapseMessage": "A chuva continua forte.", - "rainClearMessage": "A chuva parou.", - "sandstormStartMessage": "Uma tempestade de areia se formou!", - "sandstormLapseMessage": "A tempestade de areia é violenta.", - "sandstormClearMessage": "A tempestade de areia diminuiu.", - "sandstormDamageMessage": "{{pokemonNameWithAffix}} é atingido\npela tempestade de areia!", - "hailStartMessage": "Começou a chover granizo!", - "hailLapseMessage": "Granizo cai do céu.", - "hailClearMessage": "O granizo parou.", - "hailDamageMessage": "{{pokemonNameWithAffix}} é atingido\npelo granizo!", - "snowStartMessage": "Começou a nevar!", - "snowLapseMessage": "A neve continua caindo.", - "snowClearMessage": "Parou de nevar.", - "fogStartMessage": "Uma névoa densa se formou!", - "fogLapseMessage": "A névoa continua forte.", - "fogClearMessage": "A névoa sumiu.", - "heavyRainStartMessage": "Um temporal começou!", - "heavyRainLapseMessage": "O temporal continua forte.", - "heavyRainClearMessage": "O temporal parou.", - "harshSunStartMessage": "A luz do sol está escaldante!", - "harshSunLapseMessage": "A luz do sol é intensa.", - "harshSunClearMessage": "A luz do sol enfraqueceu.", - "strongWindsStartMessage": "Ventos fortes apareceram!", - "strongWindsLapseMessage": "Os ventos fortes continuam.", - "strongWindsEffectMessage": "A corrente de ar misteriosa enfraqueceu o ataque!", - "strongWindsClearMessage": "Os ventos fortes diminuíram." -} \ No newline at end of file diff --git a/src/locales/zh_CN/ability-trigger.json b/src/locales/zh_CN/ability-trigger.json deleted file mode 100644 index 0bb9c3a56ef..00000000000 --- a/src/locales/zh_CN/ability-trigger.json +++ /dev/null @@ -1,64 +0,0 @@ -{ - "blockRecoilDamage": "{{pokemonName}}的{{abilityName}}\n抵消了反作用力!", - "badDreams": "{{pokemonName}}被折磨着!", - "costar": "{{pokemonName}}复制了{{allyName}}的能力变化!", - "iceFaceAvoidedDamage": "{{pokemonNameWithAffix}}因为{{abilityName}}\n避免了伤害!", - "perishBody": "因为{{pokemonName}}的{{abilityName}}\n双方将在3回合后灭亡!", - "poisonHeal": "{{pokemonName}}因{{abilityName}}\n回复了少许HP!", - "trace": "{{pokemonName}}复制了{{targetName}}的\n{{abilityName}}!", - "windPowerCharged": "受{{moveName}}的影响,{{pokemonName}}提升了能力!", - "quickDraw": "因为速击效果发动,\n{{pokemonName}}比平常出招更快了!", - "disguiseAvoidedDamage": "{{pokemonNameWithAffix}}的画皮脱落了!", - "blockItemTheft": "{{pokemonNameWithAffix}}的{{abilityName}}\n阻止了对方夺取道具!", - "typeImmunityHeal": "{{pokemonNameWithAffix}}因{{abilityName}}\n回复了少许HP!", - "nonSuperEffectiveImmunity": "{{pokemonNameWithAffix}}因{{abilityName}}\n避免了伤害!", - "fullHpResistType": "{{pokemonNameWithAffix}}\n让甲壳发出光辉,使属性相克发生扭曲!", - "moveImmunity": "对{{pokemonNameWithAffix}}没有效果!", - "reverseDrain": "{{pokemonNameWithAffix}}\n吸到了污泥浆!", - "postDefendTypeChange": "{{pokemonNameWithAffix}}因{{abilityName}}\n变成了{{typeName}}属性!", - "postDefendContactDamage": "{{pokemonNameWithAffix}}的{{abilityName}}\n使对方受到了伤害!", - "postDefendAbilitySwap": "{{pokemonNameWithAffix}}\n互换了各自的特性!", - "postDefendAbilityGive": "因为{{pokemonNameWithAffix}}\n对方的特性变成了{{abilityName}}!", - "postDefendMoveDisable": "封住了{{pokemonNameWithAffix}}的\n{{moveName}}!", - "pokemonTypeChange": "{{pokemonNameWithAffix}}\n变成了{{moveType}}属性!", - "postAttackStealHeldItem": "{{pokemonNameWithAffix}}从{{defenderName}}那里\n夺取了{{stolenItemType}}!", - "postDefendStealHeldItem": "{{pokemonNameWithAffix}}从{{attackerName}}那里\n夺取了{{stolenItemType}}!", - "copyFaintedAllyAbility": "继承了{{pokemonNameWithAffix}}的\n{{abilityName}}!", - "intimidateImmunity": "{{pokemonNameWithAffix}}因{{abilityName}}没有受到威吓!", - "postSummonAllyHeal": "{{pokemonNameWithAffix}}喝光了\n{{pokemonName}}泡的茶!", - "postSummonClearAllyStats": "{{pokemonNameWithAffix}}的\n能力变化消失了!", - "postSummonTransform": "{{pokemonNameWithAffix}}\n变身成了{{targetName}}!", - "protectStat": "因{{pokemonNameWithAffix}}的{{abilityName}}\n{{statName}}不会降低!", - "statusEffectImmunityWithName": "{{pokemonNameWithAffix}}因{{abilityName}}\n{{statusEffectName}}没有效果!", - "statusEffectImmunity": "{{pokemonNameWithAffix}}因{{abilityName}}\n异常状态没有效果!", - "battlerTagImmunity": "{{pokemonNameWithAffix}}因{{abilityName}}\n而不会{{battlerTagName}}!", - "forewarn": "{{pokemonNameWithAffix}}读取了\n{{moveName}}!", - "frisk": "{{pokemonNameWithAffix}}察觉到了\n{{opponentName}}的{{opponentAbilityName}}!", - "postWeatherLapseHeal": "{{pokemonNameWithAffix}}因{{abilityName}}\n回复了少许HP!", - "postWeatherLapseDamage": "{{pokemonNameWithAffix}}\n因{{abilityName}}而受到了伤害!", - "postTurnLootCreateEatenBerry": "{{pokemonNameWithAffix}}\n收获了{{berryName}}!", - "postTurnHeal": "{{pokemonNameWithAffix}}因{{abilityName}}\n回复了少许HP!", - "fetchBall": "{{pokemonNameWithAffix}}\n捡回了{{pokeballName}}!", - "healFromBerryUse": "{{pokemonNameWithAffix}}因{{abilityName}}\n回复了HP!", - "arenaTrap": "因{{pokemonNameWithAffix}}的{{abilityName}}\n而无法进行替换!", - "postBattleLoot": "{{pokemonNameWithAffix}}捡到了\n{{itemName}}!", - "postFaintContactDamage": "{{pokemonNameWithAffix}}的{{abilityName}}\n使对方受到了伤害!", - "postFaintHpDamage": "{{pokemonNameWithAffix}}的{{abilityName}}\n使对方受到了伤害!", - "postSummonPressure": "从{{pokemonNameWithAffix}}的身上\n感到了一种压迫感!", - "weatherEffectDisappeared": "天气的影响消失了!", - "postSummonMoldBreaker": "{{pokemonNameWithAffix}}\n打破了常规!", - "postSummonAnticipation": "{{pokemonNameWithAffix}}\n发抖了!", - "postSummonTurboblaze": "{{pokemonNameWithAffix}}\n正在释放炽焰气场!", - "postSummonTeravolt": "{{pokemonNameWithAffix}}\n正在释放溅射气场!", - "postSummonDarkAura": "{{pokemonNameWithAffix}}\n正在释放暗黑气场!", - "postSummonFairyAura": "{{pokemonNameWithAffix}}\n正在释放妖精气场!", - "postSummonAuraBreak": "{{pokemonNameWithAffix}}\n压制了所有气场!", - "postSummonNeutralizingGas": "周围充满了\n{{pokemonNameWithAffix}}的化学变化气体!", - "postSummonAsOneGlastrier": "{{pokemonNameWithAffix}}\n同时拥有了两种特性!", - "postSummonAsOneSpectrier": "{{pokemonNameWithAffix}}\n同时拥有了两种特性!", - "postSummonVesselOfRuin": "{{pokemonNameWithAffix}}的灾祸之鼎\n令周围的宝可梦的{{statName}}减弱了!", - "postSummonSwordOfRuin": "{{pokemonNameWithAffix}}的灾祸之剑\n令周围的宝可梦的{{statName}}减弱了!", - "postSummonTabletsOfRuin": "{{pokemonNameWithAffix}}的灾祸之简\n令周围的宝可梦的{{statName}}减弱了!", - "postSummonBeadsOfRuin": "{{pokemonNameWithAffix}}的灾祸之玉\n令周围的宝可梦的{{statName}}减弱了!", - "preventBerryUse": "{{pokemonNameWithAffix}}因太紧张\n而无法食用树果!" -} diff --git a/src/locales/zh_CN/ability.json b/src/locales/zh_CN/ability.json deleted file mode 100644 index 31e3c08161d..00000000000 --- a/src/locales/zh_CN/ability.json +++ /dev/null @@ -1,1242 +0,0 @@ -{ - "stench": { - "name": "恶臭", - "description": "通过释放臭臭的气味,在攻击的时\n候,有时会使对手畏缩。" - }, - "drizzle": { - "name": "降雨", - "description": "出场时,会将天气变为下雨。" - }, - "speedBoost": { - "name": "加速", - "description": "每一回合速度会变快。" - }, - "battleArmor": { - "name": "战斗盔甲", - "description": "被坚硬的甲壳守护着,不会被对手\n的攻击击中要害。" - }, - "sturdy": { - "name": "结实", - "description": "在HP全满时,即使受到招式攻击\n,也不会被一击打倒。一击必杀的\n招式也没有效果。" - }, - "damp": { - "name": "湿气", - "description": "通过把周围都弄湿,使谁都无法使\n用自爆等爆炸类的招式。" - }, - "limber": { - "name": "柔软", - "description": "因为身体柔软,不会变为麻痹状态\n。" - }, - "sandVeil": { - "name": "沙隐", - "description": "在沙暴的时候,闪避率会提高。" - }, - "static": { - "name": "静电", - "description": "身上带有静电,有时会让接触到的\n对手麻痹。" - }, - "voltAbsorb": { - "name": "蓄电", - "description": "受到电属性的招式攻击时,不会受\n到伤害,而是会回复。" - }, - "waterAbsorb": { - "name": "储水", - "description": "受到水属性的招式攻击时,不会受\n到伤害,而是会回复。" - }, - "oblivious": { - "name": "迟钝", - "description": "因为感觉迟钝,不会变为着迷和被\n挑衅状态。对威吓也毫不动摇。" - }, - "cloudNine": { - "name": "无关天气", - "description": "任何天气的影响都会消失。" - }, - "compoundEyes": { - "name": "复眼", - "description": "因为拥有复眼,招式的命中率会提\n高。" - }, - "insomnia": { - "name": "不眠", - "description": "因为有着睡不着的体质,所以不会\n陷入睡眠状态。" - }, - "colorChange": { - "name": "变色", - "description": "自己的属性会变为从对手处所受招\n式的属性。" - }, - "immunity": { - "name": "免疫", - "description": "因为体内拥有免疫能力,不会变为\n中毒状态。" - }, - "flashFire": { - "name": "引火", - "description": "受到火属性的招式攻击时,吸收火\n焰,自己使出的火属性招式会变强\n。" - }, - "shieldDust": { - "name": "鳞粉", - "description": "被鳞粉守护着,不会受到招式的追\n加效果影响。" - }, - "ownTempo": { - "name": "我行我素", - "description": "因为我行我素,不会变为混乱状态\n。对威吓也毫不动摇。" - }, - "suctionCups": { - "name": "吸盘", - "description": "用吸盘牢牢贴在地面上,让替换宝\n可梦的招式和道具无效。" - }, - "intimidate": { - "name": "威吓", - "description": "出场时威吓对手,让其退缩,降低\n对手的攻击。" - }, - "shadowTag": { - "name": "踩影", - "description": "踩住对手的影子使其无法逃走或替\n换。" - }, - "roughSkin": { - "name": "粗糙皮肤", - "description": "受到攻击时,用粗糙的皮肤弄伤接\n触到自己的对手。" - }, - "wonderGuard": { - "name": "神奇守护", - "description": "不可思议的力量,只有效果绝佳的\n招式才能击中。" - }, - "levitate": { - "name": "飘浮", - "description": "从地面浮起,从而不会受到地面属\n性招式的攻击。" - }, - "effectSpore": { - "name": "孢子", - "description": "受到攻击时,有时会把接触到自己\n的对手变为中毒、麻痹或睡眠状态\n。" - }, - "synchronize": { - "name": "同步", - "description": "将自己的中毒、麻痹或灼伤状态传\n染给对手。" - }, - "clearBody": { - "name": "恒净之躯", - "description": "不会因为对手的招式或特性而被降\n低能力。" - }, - "naturalCure": { - "name": "自然回复", - "description": "回到同行队伍后,异常状态就会被\n治愈。" - }, - "lightningRod": { - "name": "避雷针", - "description": "将电属性的招式吸引到自己身上,\n不会受到伤害,而是会提高特攻。" - }, - "sereneGrace": { - "name": "天恩", - "description": "托天恩的福,招式的追加效果容易\n出现。" - }, - "swiftSwim": { - "name": "悠游自如", - "description": "下雨天气时,速度会提高。" - }, - "chlorophyll": { - "name": "叶绿素", - "description": "晴朗天气时,速度会提高。" - }, - "illuminate": { - "name": "发光", - "description": "通过让周围变亮来保持命中率不会\n被降低。" - }, - "trace": { - "name": "复制", - "description": "出场时,复制对手的特性,变为与\n之相同的特性。" - }, - "hugePower": { - "name": "大力士", - "description": "物理攻击的威力会变为2倍。" - }, - "poisonPoint": { - "name": "毒刺", - "description": "有时会让接触到自己的对手变为中\n毒状态。" - }, - "innerFocus": { - "name": "精神力", - "description": "拥有经过锻炼的精神,而不会因对\n手的攻击而畏缩。对威吓也毫不动\n摇。" - }, - "magmaArmor": { - "name": "熔岩铠甲", - "description": "将炽热的熔岩覆盖在身上,不会变\n为冰冻状态。" - }, - "waterVeil": { - "name": "水幕", - "description": "将水幕裹在身上,不会变为灼伤状\n态。" - }, - "magnetPull": { - "name": "磁力", - "description": "用磁力吸住钢属性的宝可梦,使其\n无法逃走。" - }, - "soundproof": { - "name": "隔音", - "description": "通过屏蔽声音,不受到声音招式的\n影响。" - }, - "rainDish": { - "name": "雨盘", - "description": "下雨天气时,会缓缓回复HP。" - }, - "sandStream": { - "name": "扬沙", - "description": "出场时,会把天气变为沙暴。" - }, - "pressure": { - "name": "压迫感", - "description": "给予对手压迫感,大量减少其使用\n招式的PP。" - }, - "thickFat": { - "name": "厚脂肪", - "description": "因为被厚厚的脂肪保护着,会让火\n属性和冰属性的招式伤害减半。" - }, - "earlyBird": { - "name": "早起", - "description": "即使变为睡眠状态,也能以2倍的\n速度提早醒来。" - }, - "flameBody": { - "name": "火焰之躯", - "description": "有时会让接触到自己的对手变为灼\n伤状态。" - }, - "runAway": { - "name": "逃跑", - "description": "一定能从野生宝可梦那儿逃走。" - }, - "keenEye": { - "name": "锐利目光", - "description": "多亏了锐利的目光,命中率不会被\n降低。" - }, - "hyperCutter": { - "name": "怪力钳", - "description": "因为拥有以力量自豪的钳子,不会\n被对手降低攻击。" - }, - "pickup": { - "name": "捡拾", - "description": "有时会捡来对手用过的道具,冒险\n过程中也会捡到。" - }, - "truant": { - "name": "懒惰", - "description": "如果使出招式,下一回合就会休息\n。" - }, - "hustle": { - "name": "活力", - "description": "自己的攻击变高,但命中率会降低\n。" - }, - "cuteCharm": { - "name": "迷人之躯", - "description": "有时会让接触到自己的对手着迷。" - }, - "plus": { - "name": "正电", - "description": "出场的伙伴之间如果有正电或负电\n特性的宝可梦,自己的特攻会提高\n。" - }, - "minus": { - "name": "负电", - "description": "出场的伙伴之间如果有正电或负电\n特性的宝可梦,自己的特攻会提高\n。" - }, - "forecast": { - "name": "阴晴不定", - "description": "受天气的影响,会变为水属性、火\n属性或冰属性中的某一个。" - }, - "stickyHold": { - "name": "黏着", - "description": "因为道具是粘在黏性身体上的,所\n以不会被对手夺走。" - }, - "shedSkin": { - "name": "蜕皮", - "description": "通过蜕去身上的皮,有时会治愈异\n常状态。" - }, - "guts": { - "name": "毅力", - "description": "如果变为异常状态,会拿出毅力,\n攻击会提高。" - }, - "marvelScale": { - "name": "神奇鳞片", - "description": "如果变为异常状态,神奇鳞片会发\n生反应,防御会提高。" - }, - "liquidOoze": { - "name": "污泥浆", - "description": "吸收了污泥浆的对手会因强烈的恶\n臭而受到伤害,减少HP。" - }, - "overgrow": { - "name": "茂盛", - "description": "HP减少的时候,草属性的招式威\n力会提高。" - }, - "blaze": { - "name": "猛火", - "description": "HP减少的时候,火属性的招式威\n力会提高。" - }, - "torrent": { - "name": "激流", - "description": "HP减少的时候,水属性的招式威\n力会提高。" - }, - "swarm": { - "name": "虫之预感", - "description": "HP减少的时候,虫属性的招式威\n力会提高。" - }, - "rockHead": { - "name": "坚硬脑袋", - "description": "即使使出会受反作用力伤害的招式\n,HP也不会减少。" - }, - "drought": { - "name": "日照", - "description": "出场时,会将天气变为晴朗。" - }, - "arenaTrap": { - "name": "沙穴", - "description": "在战斗中让对手无法逃走。" - }, - "vitalSpirit": { - "name": "干劲", - "description": "通过激发出干劲,不会变为睡眠状\n态。" - }, - "whiteSmoke": { - "name": "白色烟雾", - "description": "被白色烟雾保护着,不会被对手降\n低能力。" - }, - "purePower": { - "name": "瑜伽之力", - "description": "因瑜伽的力量,物理攻击的威力会\n变为2倍。" - }, - "shellArmor": { - "name": "硬壳盔甲", - "description": "被坚硬的壳保护着,对手的攻击不\n会击中要害。" - }, - "airLock": { - "name": "气闸", - "description": "所有天气的影响都会消失。" - }, - "tangledFeet": { - "name": "蹒跚", - "description": "在混乱状态时,闪避率会提高。" - }, - "motorDrive": { - "name": "电气引擎", - "description": "受到电属性的招式攻击时,不会受\n到伤害,而是速度会提高。" - }, - "rivalry": { - "name": "斗争心", - "description": "面对性别相同的对手,会燃起斗争\n心,变得更强。而面对性别不同的\n,则会变弱。" - }, - "steadfast": { - "name": "不屈之心", - "description": "每次畏缩时,不屈之心就会燃起,\n速度也会提高。" - }, - "snowCloak": { - "name": "雪隐", - "description": "下雪天气时,闪避率会提高。" - }, - "gluttony": { - "name": "贪吃鬼", - "description": "原本HP变得很少时才会吃树果,\n在HP还有一半时就会把它吃掉。" - }, - "angerPoint": { - "name": "愤怒穴位", - "description": "要害被击中时,会大发雷霆,攻击\n力变为最大。" - }, - "unburden": { - "name": "轻装", - "description": "失去所持有的道具时,速度会提高\n。" - }, - "heatproof": { - "name": "耐热", - "description": "耐热的体质会让火属性的招式伤害\n减半。" - }, - "simple": { - "name": "单纯", - "description": "能力变化会变为平时的2倍。" - }, - "drySkin": { - "name": "干燥皮肤", - "description": "下雨天气时和受到水属性的招式时\n,HP会回复。晴朗天气时和受到\n火属性的招式时,HP会减少。" - }, - "download": { - "name": "下载", - "description": "比较对手的防御和特防,根据较低\n的那项能力相应地提高自己的攻击\n或特攻。" - }, - "ironFist": { - "name": "铁拳", - "description": "使用拳类招式的威力会提高。" - }, - "poisonHeal": { - "name": "毒疗", - "description": "变为中毒状态时,HP不会减少,\n反而会增加起来。" - }, - "adaptability": { - "name": "适应力", - "description": "与自身同属性的招式威力会提高。" - }, - "skillLink": { - "name": "连续攻击", - "description": "如果使用连续招式,总是能使出最\n高次数。" - }, - "hydration": { - "name": "湿润之躯", - "description": "下雨天气时,异常状态会治愈。" - }, - "solarPower": { - "name": "太阳之力", - "description": "晴朗天气时,特攻会提高,而每回\n合HP会减少。" - }, - "quickFeet": { - "name": "飞毛腿", - "description": "变为异常状态时,速度会提高。" - }, - "normalize": { - "name": "一般皮肤", - "description": "无论是什么属性的招式,全部会变\n为一般属性。威力会少量提高。" - }, - "sniper": { - "name": "狙击手", - "description": "击中要害时,威力会变得更强。" - }, - "magicGuard": { - "name": "魔法防守", - "description": "不会受到攻击以外的伤害。" - }, - "noGuard": { - "name": "无防守", - "description": "由于无防守战术,双方使出的招式\n都必定会击中。" - }, - "stall": { - "name": "慢出", - "description": "使出招式的顺序必定会变为最后。" - }, - "technician": { - "name": "技术高手", - "description": "攻击时可以将低威力招式的威力提\n高。" - }, - "leafGuard": { - "name": "叶子防守", - "description": "晴朗天气时,不会变为异常状态。" - }, - "klutz": { - "name": "笨拙", - "description": "无法使用持有的道具。" - }, - "moldBreaker": { - "name": "破格", - "description": "可以不受对手特性的干扰,向对手\n使出招式。" - }, - "superLuck": { - "name": "超幸运", - "description": "因为拥有超幸运,攻击容易击中对\n手的要害。" - }, - "aftermath": { - "name": "引爆", - "description": "变为濒死时,会对接触到自己的对\n手造成伤害。" - }, - "anticipation": { - "name": "危险预知", - "description": "可以察觉到对手拥有的危险招式。" - }, - "forewarn": { - "name": "预知梦", - "description": "出场时,只读取1个对手拥有的招\n式。" - }, - "unaware": { - "name": "纯朴", - "description": "可以无视对手能力的变化,进行攻\n击。" - }, - "tintedLens": { - "name": "有色眼镜", - "description": "可以将效果不好的招式以通常的威\n力使出。" - }, - "filter": { - "name": "过滤", - "description": "受到效果绝佳的攻击时,可以减弱\n其威力。" - }, - "slowStart": { - "name": "慢启动", - "description": "在5回合内,攻击和速度减半。" - }, - "scrappy": { - "name": "胆量", - "description": "一般属性和格斗属性的招式可以击\n中幽灵属性的宝可梦。对威吓也毫\n不动摇。" - }, - "stormDrain": { - "name": "引水", - "description": "将水属性的招式引到自己身上,不\n会受到伤害,而是会提高特攻。" - }, - "iceBody": { - "name": "冰冻之躯", - "description": "下雪天气时,会缓缓回复HP。" - }, - "solidRock": { - "name": "坚硬岩石", - "description": "受到效果绝佳的攻击时,可以减弱\n其威力。" - }, - "snowWarning": { - "name": "降雪", - "description": "出场时,会将天气变为下雪。" - }, - "honeyGather": { - "name": "采蜜", - "description": "战斗结束时,有时候会捡来甜甜蜜。\n甜甜蜜会转换成金钱。" - }, - "frisk": { - "name": "察觉", - "description": "出场时,可以察觉对手的特性。" - }, - "reckless": { - "name": "舍身", - "description": "自己会因反作用力受伤的招式,其\n威力会提高。" - }, - "multitype": { - "name": "多属性", - "description": "自己的属性会根据持有的石板而改\n变。" - }, - "flowerGift": { - "name": "花之礼", - "description": "晴朗天气时,自己与同伴的攻击和\n特防能力会提高。" - }, - "badDreams": { - "name": "梦魇", - "description": "给予睡眠状态的对手伤害。" - }, - "pickpocket": { - "name": "顺手牵羊", - "description": "盗取接触到自己的对手的道具。" - }, - "sheerForce": { - "name": "强行", - "description": "招式的追加效果消失,但因此能以\n更高的威力使出招式。" - }, - "contrary": { - "name": "唱反调", - "description": "能力的变化发生逆转,原本提高时\n会降低,而原本降低时会提高。" - }, - "unnerve": { - "name": "紧张感", - "description": "让对手紧张,使其无法食用树果。" - }, - "defiant": { - "name": "不服输", - "description": "被对手降低能力时,攻击会大幅提\n高。" - }, - "defeatist": { - "name": "软弱", - "description": "HP减半时,会变得软弱,攻击和\n特攻会减半。" - }, - "cursedBody": { - "name": "诅咒之躯", - "description": "受到攻击时,有时会把对手的招式\n变为定身法状态。" - }, - "healer": { - "name": "治愈之心", - "description": "有时会治愈异常状态的同伴。" - }, - "friendGuard": { - "name": "友情防守", - "description": "可以减少我方的伤害。" - }, - "weakArmor": { - "name": "碎裂铠甲", - "description": "受到物理招式的伤害时,防御会降\n低,速度会大幅提高。" - }, - "heavyMetal": { - "name": "重金属", - "description": "自身的重量会变为2倍。" - }, - "lightMetal": { - "name": "轻金属", - "description": "自身的重量会减半。" - }, - "multiscale": { - "name": "多重鳞片", - "description": "HP全满时,受到的伤害会变少。" - }, - "toxicBoost": { - "name": "中毒激升", - "description": "变为中毒状态时,物理招式的威力\n会提高。" - }, - "flareBoost": { - "name": "受热激升", - "description": "变为灼伤状态时,特殊招式的威力\n会提高。" - }, - "harvest": { - "name": "收获", - "description": "可以多次制作出已被使用掉的树果\n。" - }, - "telepathy": { - "name": "心灵感应", - "description": "读取我方的攻击,并闪避其招式伤\n害。" - }, - "moody": { - "name": "心情不定", - "description": "每一回合,能力中的某项会大幅提\n高,而某项会降低。" - }, - "overcoat": { - "name": "防尘", - "description": "不会受到沙暴的伤害。也不会受到\n粉末类和孢子类招式的影响。" - }, - "poisonTouch": { - "name": "毒手", - "description": "只通过接触就有可能让对手变为中\n毒状态。" - }, - "regenerator": { - "name": "再生力", - "description": "退回同行队伍后,HP会少量回复\n。" - }, - "bigPecks": { - "name": "健壮胸肌", - "description": "不会受到防御降低的效果。" - }, - "sandRush": { - "name": "拨沙", - "description": "沙暴天气时,速度会提高。" - }, - "wonderSkin": { - "name": "奇迹皮肤", - "description": "成为不易受到变化招式攻击的身体\n。" - }, - "analytic": { - "name": "分析", - "description": "如果在最后使出招式,招式的威力\n会提高。" - }, - "illusion": { - "name": "幻觉", - "description": "假扮成同行队伍中的最后一只宝可\n梦出场,迷惑对手。" - }, - "imposter": { - "name": "变身者", - "description": "变身为当前面对的宝可梦。" - }, - "infiltrator": { - "name": "穿透", - "description": "可以穿透对手的壁障或替身进行攻\n击。" - }, - "mummy": { - "name": "木乃伊", - "description": "被对手接触到后,会将对手变为木\n乃伊。" - }, - "moxie": { - "name": "自信过度", - "description": "如果打倒对手,就会充满自信,攻\n击会提高。" - }, - "justified": { - "name": "正义之心", - "description": "受到恶属性的招式攻击时,因为正\n义感,攻击会提高。" - }, - "rattled": { - "name": "胆怯", - "description": "受到恶属性、幽灵属性和虫属性的\n攻击或威吓时,会因胆怯而速度提\n高。" - }, - "magicBounce": { - "name": "魔法镜", - "description": "可以不受到由对手使出的变化招式\n影响,并将其反弹。" - }, - "sapSipper": { - "name": "食草", - "description": "受到草属性的招式攻击时,不会受\n到伤害,而是攻击会提高。" - }, - "prankster": { - "name": "恶作剧之心", - "description": "可以率先使出变化招式。" - }, - "sandForce": { - "name": "沙之力", - "description": "沙暴天气时,岩石属性、地面属性\n和钢属性的招式威力会提高。" - }, - "ironBarbs": { - "name": "铁刺", - "description": "用铁刺给予接触到自己的对手伤害\n。" - }, - "zenMode": { - "name": "达摩模式", - "description": "HP变为一半以下时,样子会改变\n。" - }, - "victoryStar": { - "name": "胜利之星", - "description": "自己和同伴的命中率会提高。" - }, - "turboblaze": { - "name": "涡轮火焰", - "description": "可以不受对手特性的干扰,向对手\n使出招式。" - }, - "teravolt": { - "name": "兆级电压", - "description": "可以不受对手特性的干扰,向对手\n使出招式。" - }, - "aromaVeil": { - "name": "芳香幕", - "description": "可以防住向自己和同伴发出的心灵\n攻击。" - }, - "flowerVeil": { - "name": "花幕", - "description": "我方的草属性宝可梦能力不会降低\n,也不会变为异常状态。" - }, - "cheekPouch": { - "name": "颊囊", - "description": "无论是哪种树果,食用后,HP都\n会回复。" - }, - "protean": { - "name": "变幻自如", - "description": "变为与自己使出的招式相同的属性\n。每次出场战斗仅生效一次。" - }, - "furCoat": { - "name": "毛皮大衣", - "description": "对手给予的物理招式的伤害会减半\n。" - }, - "magician": { - "name": "魔术师", - "description": "夺走被自己的招式击中的对手的道\n具。" - }, - "bulletproof": { - "name": "防弹", - "description": "可以防住对手的球和弹类招式。" - }, - "competitive": { - "name": "好胜", - "description": "如果被对手降低能力,特攻会大幅\n提高。" - }, - "strongJaw": { - "name": "强壮之颚", - "description": "因为颚部强壮,啃咬类招式的威力\n会提高。" - }, - "refrigerate": { - "name": "冰冻皮肤", - "description": "一般属性的招式会变为冰属性。威\n力会少量提高。" - }, - "sweetVeil": { - "name": "甜幕", - "description": "自己和同伴的宝可梦不会变为睡眠\n状态。" - }, - "stanceChange": { - "name": "战斗切换", - "description": "如果使出攻击招式,会变为刀剑形\n态,如果使出招式“王者盾牌”,\n会变为盾牌形态。" - }, - "galeWings": { - "name": "疾风之翼", - "description": "HP全满时,飞行属性的招式可以\n率先使出。" - }, - "megaLauncher": { - "name": "超级发射器", - "description": "波动和波导类招式的威力会提高。" - }, - "grassPelt": { - "name": "草之毛皮", - "description": "在青草场地时,防御会提高。" - }, - "symbiosis": { - "name": "共生", - "description": "同伴使用道具时,会把自己持有的\n道具传递给同伴。" - }, - "toughClaws": { - "name": "硬爪", - "description": "接触到对手的招式威力会提高。" - }, - "pixilate": { - "name": "妖精皮肤", - "description": "一般属性的招式会变为妖精属性。\n威力会少量提高。" - }, - "gooey": { - "name": "黏滑", - "description": "对于用攻击接触到自己的对手,会\n降低其速度。" - }, - "aerilate": { - "name": "飞行皮肤", - "description": "一般属性的招式会变为飞行属性。\n威力会少量提高。" - }, - "parentalBond": { - "name": "亲子爱", - "description": "亲子俩可以合计攻击2次。" - }, - "darkAura": { - "name": "暗黑气场", - "description": "全体的恶属性招式变强。" - }, - "fairyAura": { - "name": "妖精气场", - "description": "全体的妖精属性招式变强。" - }, - "auraBreak": { - "name": "气场破坏", - "description": "让气场的效果发生逆转,降低威力\n。" - }, - "primordialSea": { - "name": "始源之海", - "description": "变为不会受到火属性攻击的天气。" - }, - "desolateLand": { - "name": "终结之地", - "description": "变为不会受到水属性攻击的天气。" - }, - "deltaStream": { - "name": "德尔塔气流", - "description": "变为令飞行属性的弱点消失的天气\n。" - }, - "stamina": { - "name": "持久力", - "description": "受到攻击时,防御会提高。" - }, - "wimpOut": { - "name": "跃跃欲逃", - "description": "HP变为一半时,会慌慌张张逃走\n,退回同行队伍中。" - }, - "emergencyExit": { - "name": "危险回避", - "description": "HP变为一半时,为了回避危险,\n会退回到同行队伍中。" - }, - "waterCompaction": { - "name": "遇水凝固", - "description": "受到水属性的招式攻击时,防御会\n大幅提高。" - }, - "merciless": { - "name": "不仁不义", - "description": "攻击中毒状态的对手时,必定会击\n中要害。" - }, - "shieldsDown": { - "name": "界限盾壳", - "description": "HP变为一半时,壳会坏掉,变得\n有攻击性。" - }, - "stakeout": { - "name": "蹲守", - "description": "可以对替换出场的对手以2倍的伤\n害进行攻击。" - }, - "waterBubble": { - "name": "水泡", - "description": "降低自己受到的火属性招式的威力\n,不会灼伤。" - }, - "steelworker": { - "name": "钢能力者", - "description": "钢属性的招式威力会提高。" - }, - "berserk": { - "name": "怒火冲天", - "description": "因对手的攻击HP变为一半时,特\n攻会提高。" - }, - "slushRush": { - "name": "拨雪", - "description": "下雪天气时,速度会提高。" - }, - "longReach": { - "name": "远隔", - "description": "可以不接触对手就使出所有的招式\n。" - }, - "liquidVoice": { - "name": "湿润之声", - "description": "所有的声音招式都变为水属性。" - }, - "triage": { - "name": "先行治疗", - "description": "可以率先使出回复招式。" - }, - "galvanize": { - "name": "电气皮肤", - "description": "一般属性的招式会变为电属性。威\n力会少量提高。" - }, - "surgeSurfer": { - "name": "冲浪之尾", - "description": "电气场地时,速度会变为2倍。" - }, - "schooling": { - "name": "鱼群", - "description": "HP多的时候会聚起来变强。HP\n剩余量变少时,群体会分崩离析。" - }, - "disguise": { - "name": "画皮", - "description": "通过画皮覆盖住身体,可以防住1\n次攻击。" - }, - "battleBond": { - "name": "牵绊变身", - "description": "打倒对手时,与训练家的牵绊会增\n强,自己的攻击、特攻、速度会提\n高。" - }, - "powerConstruct": { - "name": "群聚变形", - "description": "HP变为一半时,细胞们会赶来支\n援,变为完全体形态。" - }, - "corrosion": { - "name": "腐蚀", - "description": "可以使钢属性和毒属性的宝可梦也\n陷入中毒状态。" - }, - "comatose": { - "name": "绝对睡眠", - "description": "总是半梦半醒的状态,绝对不会醒\n来。可以就这么睡着进行攻击。" - }, - "queenlyMajesty": { - "name": "女王的威严", - "description": "向对手施加威慑力,使其无法对我\n方使出先制招式。" - }, - "innardsOut": { - "name": "飞出的内在物", - "description": "被对手打倒的时候,会给予对手相\n当于HP剩余量的伤害。" - }, - "dancer": { - "name": "舞者", - "description": "有谁使出跳舞招式时,自己也能就\n这么接着使出跳舞招式。" - }, - "battery": { - "name": "蓄电池", - "description": "会提高我方的特殊招式的威力。" - }, - "fluffy": { - "name": "毛茸茸", - "description": "会将对手所给予的接触类招式的伤\n害减半,但火属性招式的伤害会变\n为2倍。" - }, - "dazzling": { - "name": "鲜艳之躯", - "description": "让对手吓一跳,使其无法对我方使\n出先制招式。" - }, - "soulHeart": { - "name": "魂心", - "description": "宝可梦每次变为濒死状态时,特攻\n会提高。" - }, - "tanglingHair": { - "name": "卷发", - "description": "对于用攻击接触到自己的对手,会\n降低其速度。" - }, - "receiver": { - "name": "接球手", - "description": "继承被打倒的同伴的特性,变为相\n同的特性。" - }, - "powerOfAlchemy": { - "name": "化学之力", - "description": "继承被打倒的同伴的特性,变为相\n同的特性。" - }, - "beastBoost": { - "name": "异兽提升", - "description": "打倒对手的时候,自己最高的那项\n能力会提高。" - }, - "rksSystem": { - "name": "AR系统", - "description": "根据持有的存储碟,自己的属性会\n改变。" - }, - "electricSurge": { - "name": "电气制造者", - "description": "出场时,会布下电气场地。" - }, - "psychicSurge": { - "name": "精神制造者", - "description": "出场时,会布下精神场地。" - }, - "mistySurge": { - "name": "薄雾制造者", - "description": "出场时,会布下薄雾场地。" - }, - "grassySurge": { - "name": "青草制造者", - "description": "出场时,会布下青草场地。" - }, - "fullMetalBody": { - "name": "金属防护", - "description": "不会因为对手的招式或特性而被降\n低能力。" - }, - "shadowShield": { - "name": "幻影防守", - "description": "HP全满时,受到的伤害会变少。" - }, - "prismArmor": { - "name": "棱镜装甲", - "description": "受到效果绝佳的攻击时,可以减弱\n其威力。" - }, - "neuroforce": { - "name": "脑核之力", - "description": "效果绝佳的攻击,威力会变得更强\n。" - }, - "intrepidSword": { - "name": "不挠之剑", - "description": "首次出场时,攻击会提高。" - }, - "dauntlessShield": { - "name": "不屈之盾", - "description": "首次出场时,防御会提高。" - }, - "libero": { - "name": "自由者", - "description": "变为与自己使出的招式相同的属性\n。每次出场战斗仅生效一次。" - }, - "ballFetch": { - "name": "捡球", - "description": "没有携带道具时,会拾取第1个投\n出后捕捉失败的精灵球。" - }, - "cottonDown": { - "name": "棉絮", - "description": "受到攻击后撒下棉絮,降低除自己\n以外的所有宝可梦的速度。" - }, - "propellerTail": { - "name": "螺旋尾鳍", - "description": "能无视具有吸引对手招式效果的特\n性或招式的影响。" - }, - "mirrorArmor": { - "name": "镜甲", - "description": "只反弹自己受到的能力降低效果。" - }, - "gulpMissile": { - "name": "一口导弹", - "description": "冲浪或潜水时会叼来猎物。受到伤\n害时,会吐出猎物进行攻击。" - }, - "stalwart": { - "name": "坚毅", - "description": "能无视具有吸引对手招式效果的特\n性或招式的影响。" - }, - "steamEngine": { - "name": "蒸汽机", - "description": "受到水属性或火属性的招式攻击时\n,速度会巨幅提高。" - }, - "punkRock": { - "name": "庞克摇滚", - "description": "声音招式的威力会提高。受到的声\n音招式伤害会减半。" - }, - "sandSpit": { - "name": "吐沙", - "description": "受到攻击时,会刮起沙暴。" - }, - "iceScales": { - "name": "冰鳞粉", - "description": "由于有冰鳞粉的守护,受到的特殊\n攻击伤害会减半。" - }, - "ripen": { - "name": "熟成", - "description": "使树果成熟,效果变为2倍。" - }, - "iceFace": { - "name": "结冻头", - "description": "头部的冰会代替自己承受物理攻击\n,但是样子会改变。下雪时,冰会\n恢复原状。" - }, - "powerSpot": { - "name": "能量点", - "description": "只要处在相邻位置,招式的威力就\n会提高。" - }, - "mimicry": { - "name": "拟态", - "description": "宝可梦的属性会根据场地的状态而\n变化。" - }, - "screenCleaner": { - "name": "除障", - "description": "出场时,敌方和我方的光墙、反射\n壁和极光幕的效果会消失。" - }, - "steelySpirit": { - "name": "钢之意志", - "description": "我方的钢属性攻击威力会提高。" - }, - "perishBody": { - "name": "灭亡之躯", - "description": "受到接触类招式攻击时,双方都会\n在3回合后变为濒死状态。替换后\n效果消失。" - }, - "wanderingSpirit": { - "name": "游魂", - "description": "与使用接触类招式攻击自己的宝可\n梦互换特性。" - }, - "gorillaTactics": { - "name": "一猩一意", - "description": "虽然攻击会提高,但是只能使出一\n开始所选的招式。" - }, - "neutralizingGas": { - "name": "化学变化气体", - "description": "特性为化学变化气体的宝可梦在场\n时,场上所有宝可梦的特性效果都\n会消失或者无法生效。" - }, - "pastelVeil": { - "name": "粉彩护幕", - "description": "自己和同伴都不会陷入中毒的异常\n状态。" - }, - "hungerSwitch": { - "name": "饱了又饿", - "description": "每回合结束时会在满腹花纹与空腹\n花纹之间交替改变样子。" - }, - "quickDraw": { - "name": "速击", - "description": "有时能比对手先一步行动。" - }, - "unseenFist": { - "name": "无形拳", - "description": "如果使出的是接触到对手的招式,\n就可以无视守护效果进行攻击。" - }, - "curiousMedicine": { - "name": "怪药", - "description": "出场时会从贝壳撒药,将我方的能\n力变化复原。" - }, - "transistor": { - "name": "电晶体", - "description": "电属性的招式威力会提高。" - }, - "dragonsMaw": { - "name": "龙颚", - "description": "龙属性的招式威力会提高。" - }, - "chillingNeigh": { - "name": "苍白嘶鸣", - "description": "打倒对手时会用冰冷的声音嘶鸣并\n提高攻击。" - }, - "grimNeigh": { - "name": "漆黑嘶鸣", - "description": "打倒对手时会用恐怖的声音嘶鸣并\n提高特攻。" - }, - "asOneGlastrier": { - "name": "人马一体", - "description": "兼备蕾冠王的紧张感和雪暴马的苍\n白嘶鸣这两种特性。" - }, - "asOneSpectrier": { - "name": "人马一体", - "description": "兼备蕾冠王的紧张感和灵幽马的漆\n黑嘶鸣这两种特性。" - }, - "lingeringAroma": { - "name": "甩不掉的气味", - "description": "被对手接触到后,甩不掉的气味会\n沾上对手。" - }, - "seedSower": { - "name": "掉出种子", - "description": "受到攻击时,会将脚下变成青草场\n地。" - }, - "thermalExchange": { - "name": "热交换", - "description": "受到火属性的招式攻击时,攻击会\n提高,且不会陷入灼伤状态。" - }, - "angerShell": { - "name": "愤怒甲壳", - "description": "因被对手攻击而HP变为一半时,\n会因愤怒降低防御和特防。但攻击\n、特攻、速度会提高。" - }, - "purifyingSalt": { - "name": "洁净之盐", - "description": "因洁净的盐而不会陷入异常状态。\n会让幽灵属性的招式伤害减半。" - }, - "wellBakedBody": { - "name": "焦香之躯", - "description": "受到火属性的招式攻击时,不会受\n到伤害,而是会大幅提高防御。" - }, - "windRider": { - "name": "乘风", - "description": "吹起了顺风或受到风的招式攻击时\n,不会受到伤害,而是会提高攻击\n。" - }, - "guardDog": { - "name": "看门犬", - "description": "受到威吓时,攻击会提高。让替换\n宝可梦的招式和道具无效。" - }, - "rockyPayload": { - "name": "搬岩", - "description": "岩石属性的招式威力会提高。" - }, - "windPower": { - "name": "风力发电", - "description": "受到风的招式攻击时,会变为充电\n状态。" - }, - "zeroToHero": { - "name": "全能变身", - "description": "回到同行队伍后,会变为全能形态\n。" - }, - "commander": { - "name": "发号施令", - "description": "出场时,若我方当中有吃吼霸,就\n会进入其口中,并从其口中发出指\n令。" - }, - "electromorphosis": { - "name": "电力转换", - "description": "受到伤害时,会变为充电状态。" - }, - "protosynthesis": { - "name": "古代活性", - "description": "携带着驱劲能量或天气为晴朗时,\n数值最高的能力会提高。" - }, - "quarkDrive": { - "name": "夸克充能", - "description": "携带着驱劲能量或在电气场地上时\n,数值最高的能力会提高。" - }, - "goodAsGold": { - "name": "黄金之躯", - "description": "不会氧化的坚固黄金身躯不会受到\n对手的变化招式的影响。" - }, - "vesselOfRuin": { - "name": "灾祸之鼎", - "description": "以能呼唤灾厄的鼎的力量降低除自\n己以外的宝可梦的特攻。" - }, - "swordOfRuin": { - "name": "灾祸之剑", - "description": "以能呼唤灾厄的剑的力量降低除自\n己以外的宝可梦的防御。" - }, - "tabletsOfRuin": { - "name": "灾祸之简", - "description": "以能呼唤灾厄的简的力量降低除自\n己以外的宝可梦的攻击。" - }, - "beadsOfRuin": { - "name": "灾祸之玉", - "description": "以能呼唤灾厄的勾玉的力量降低除\n自己以外的宝可梦的特防。" - }, - "orichalcumPulse": { - "name": "绯红脉动", - "description": "出场时,会将天气变为晴朗。日照\n强烈时,会通过古代的脉动升高攻\n击。" - }, - "hadronEngine": { - "name": "强子引擎", - "description": "出场时,会布下电气场地。处于电\n气场地时,会通过未来的机关升高\n特攻。" - }, - "opportunist": { - "name": "跟风", - "description": "对手的能力提高时,自己也会趁机\n同样地提高能力。" - }, - "cudChew": { - "name": "反刍", - "description": "吃了树果后,会在下一回合结束时\n从胃反刍出来再吃1次。" - }, - "sharpness": { - "name": "锋锐", - "description": "提高切割对手的招式的威力。" - }, - "supremeOverlord": { - "name": "大将", - "description": "出场时,攻击和特攻会按照目前被\n打倒的同伴数量逐渐提升,被打倒\n越多,提升越多。" - }, - "costar": { - "name": "同台共演", - "description": "出场时,复制同伴的能力变化。" - }, - "toxicDebris": { - "name": "毒满地", - "description": "受到物理招式的伤害时,会在对手\n脚下散布毒菱。" - }, - "armorTail": { - "name": "尾甲", - "description": "包裹头部的神秘尾巴使对手无法对\n我方使出先制招式。" - }, - "earthEater": { - "name": "食土", - "description": "受到地面属性的招式攻击时,不会\n受到伤害,而是会得到回复。" - }, - "myceliumMight": { - "name": "菌丝之力", - "description": "使出变化招式时,虽然行动必定会\n变慢,但能不受对手的特性妨碍。" - }, - "mindsEye": { - "name": "心眼", - "description": "一般属性和格斗属性的招式可以击\n中幽灵属性的宝可梦。无视对手的\n闪避率的变化,且命中率不会被降\n低。" - }, - "supersweetSyrup": { - "name": "甘露之蜜", - "description": "首次出场时,会散发出甜腻的蜜的\n香味来降低对手的闪避率。" - }, - "hospitality": { - "name": "款待", - "description": "出场时款待同伴,回复其少量HP\n。" - }, - "toxicChain": { - "name": "毒锁链", - "description": "凭借含有毒素的锁链的力量,有时\n能让被招式击中的对手陷入剧毒状\n态。" - }, - "embodyAspectTeal": { - "name": "面影辉映", - "description": "将回忆映于心中,让碧草面具发出\n光辉,提高自己的速度。" - }, - "embodyAspectWellspring": { - "name": "面影辉映", - "description": "将回忆映于心中,让水井面具发出\n光辉,提高自己的特防。" - }, - "embodyAspectHearthflame": { - "name": "面影辉映", - "description": "将回忆映于心中,让火灶面具发出\n光辉,提高自己的攻击。" - }, - "embodyAspectCornerstone": { - "name": "面影辉映", - "description": "将回忆映于心中,让础石面具发出\n光辉,提高自己的防御。" - }, - "teraShift": { - "name": "太晶变形", - "description": "出场时,会吸收周围的能量,变为\n太晶形态。" - }, - "teraShell": { - "name": "太晶甲壳", - "description": "甲壳蕴藏着全部属性的力量,会将\n自己HP全满时受到的伤害全都变\n为效果不好。" - }, - "teraformZero": { - "name": "归零化境", - "description": "太乐巴戈斯变为星晶形态时,蕴藏\n在它身上的力量会将天气和场地的\n影响全部归零。" - }, - "poisonPuppeteer": { - "name": "毒傀儡", - "description": "因桃歹郎的招式而陷入中毒状态的\n对手同时也会陷入混乱状态。" - } -} diff --git a/src/locales/zh_CN/achv.json b/src/locales/zh_CN/achv.json deleted file mode 100644 index b93345d876b..00000000000 --- a/src/locales/zh_CN/achv.json +++ /dev/null @@ -1,276 +0,0 @@ -{ - "Achievements": { - "name": "成就" - }, - "Locked": { - "name": "未解锁" - }, - - "MoneyAchv": { - "description": "累计获得 ₽{{moneyAmount}}" - }, - "10K_MONEY": { - "name": "小有积蓄" - }, - "100K_MONEY": { - "name": "大户人家" - }, - "1M_MONEY": { - "name": "百万富翁" - }, - "10M_MONEY": { - "name": "暴发户" - }, - - "DamageAchv": { - "description": "在单次攻击中造成\n {{damageAmount}} 点伤害" - }, - "250_DMG": { - "name": "重拳出击" - }, - "1000_DMG": { - "name": "神拳猛击" - }, - "2500_DMG": { - "name": "夺少?" - }, - "10000_DMG": { - "name": "一拳超人" - }, - - "HealAchv": { - "description": "通过技能、能力或携带的道具\n一次性治疗 {{healAmount}} {{HP}}点" - }, - "250_HEAL": { - "name": "新手奶妈" - }, - "1000_HEAL": { - "name": "治疗担当" - }, - "2500_HEAL": { - "name": "牧师" - }, - "10000_HEAL": { - "name": "泉水" - }, - - "LevelAchv": { - "description": "将一只宝可梦提升到 Lv{{level}}" - }, - "LV_100": { - "name": "别急,后面还有" - }, - "LV_250": { - "name": "精英" - }, - "LV_1000": { - "name": "天外有天" - }, - - "RibbonAchv": { - "description": "累计获得 {{ribbonAmount}} 个勋章" - }, - "10_RIBBONS": { - "name": "宝可梦联盟冠军" - }, - "25_RIBBONS": { - "name": "超级球联盟冠军" - }, - "50_RIBBONS": { - "name": "高级球联盟冠军" - }, - "75_RIBBONS": { - "name": "肉鸽球联盟冠军" - }, - "100_RIBBONS": { - "name": "大师球联盟冠军" - }, - - "TRANSFER_MAX_STAT_STAGE": { - "name": "团队协作", - "description": "在一项属性强化至最大时用\n接力棒传递给其他宝可梦" - }, - "MAX_FRIENDSHIP": { - "name": "亲密无间", - "description": "使一只宝可梦的亲密度\n达到最大值" - }, - "MEGA_EVOLVE": { - "name": "大变身", - "description": "超级进化一只宝可梦" - }, - "GIGANTAMAX": { - "name": "这位更是重量级", - "description": "极巨化一只宝可梦" - }, - "TERASTALLIZE": { - "name": "本系爱好者", - "description": "太晶化一只宝可梦" - }, - "STELLAR_TERASTALLIZE": { - "name": "隐藏属性", - "description": "星晶化一只宝可梦" - }, - "SPLICE": { - "name": "无限融合", - "description": "使用基因之楔将两只宝可梦\n融合在一起" - }, - "MINI_BLACK_HOLE": { - "name": "一大洞的道具", - "description": "获得一个迷你黑洞" - }, - "CATCH_MYTHICAL": { - "name": "神秘礼物", - "description": "捕捉一只幻之宝可梦" - }, - "CATCH_SUB_LEGENDARY": { - "name": "二级传说", - "description": "捕捉一只二级传说宝可梦" - }, - "CATCH_LEGENDARY": { - "name": "传说", - "description": "捕捉一只传说宝可梦" - }, - "SEE_SHINY": { - "name": "闪耀夺目", - "description": "在野外找到一只闪光宝可梦" - }, - "SHINY_PARTY": { - "name": "呕心沥血", - "description": "拥有一支由闪光宝可梦组成\n的满员队伍" - }, - "HATCH_MYTHICAL": { - "name": "幻兽蛋", - "description": "从蛋中孵化出一只幻之宝可梦" - }, - "HATCH_SUB_LEGENDARY": { - "name": "二级传说蛋", - "description": "从蛋中孵化出一只二级传说\n宝可梦" - }, - "HATCH_LEGENDARY": { - "name": "传说蛋", - "description": "从蛋中孵化出一只传说宝可梦" - }, - "HATCH_SHINY": { - "name": "金色传说!", - "description": "从蛋中孵化出一只闪光宝可梦" - }, - "HIDDEN_ABILITY": { - "name": "隐藏实力", - "description": "捕捉一只拥有隐藏特性\n的宝可梦" - }, - "PERFECT_IVS": { - "name": "合格证", - "description": "获得一只拥有完美个体值\n的宝可梦" - }, - "CLASSIC_VICTORY": { - "name": "战无不胜", - "description": "在经典模式中通关游戏" - }, - "UNEVOLVED_CLASSIC_VICTORY": { - "name": "带孩上班", - "description": "通关经典模式时队伍中至少有\n一名未进化的宝可梦" - }, - - "MONO_GEN_ONE": { - "name": "最初的劲敌", - "description": "完成仅限第一世代的挑战" - }, - "MONO_GEN_TWO": { - "name": "1.5世代", - "description": "完成仅限第二世代的挑战" - }, - "MONO_GEN_THREE": { - "name": "“水太多了”", - "description": "完成仅限第三世代的挑战" - }, - "MONO_GEN_FOUR": { - "name": "她真是最强冠军吗?", - "description": "完成仅限第四世代的挑战" - }, - "MONO_GEN_FIVE": { - "name": "完全原创", - "description": "完成仅限第五世代的挑战" - }, - "MONO_GEN_SIX": { - "name": "女大公", - "description": "完成仅限第六世代的挑战" - }, - "MONO_GEN_SEVEN": { - "name": "首届冠军", - "description": "完成仅限第七世代的挑战" - }, - "MONO_GEN_EIGHT": { - "name": "冠军时刻!", - "description": "完成仅限第八世代的挑战" - }, - "MONO_GEN_NINE": { - "name": "她又放水了", - "description": "完成仅限第九世代的挑战" - }, - - "MonoType": { - "description": "完成 {{type}} 单属性挑战" - }, - "MONO_NORMAL": { - "name": "异乎寻常的寻常" - }, - "MONO_FIGHTING": { - "name": "我有真功夫" - }, - "MONO_FLYING": { - "name": "愤怒的小鸟" - }, - "MONO_POISON": { - "name": "关都地区特色" - }, - "MONO_GROUND": { - "name": "地震预报" - }, - "MONO_ROCK": { - "name": "坚如磐石" - }, - "MONO_BUG": { - "name": "音箱蟀侠" - }, - "MONO_GHOST": { - "name": "捉鬼敢死队" - }, - "MONO_STEEL": { - "name": "铁巨人" - }, - "MONO_FIRE": { - "name": "搓火球解决一切" - }, - "MONO_WATER": { - "name": "当雨来临,倾盆而下" - }, - "MONO_GRASS": { - "name": "别踏这个青" - }, - "MONO_ELECTRIC": { - "name": "瞄准大岩蛇的角!" - }, - "MONO_PSYCHIC": { - "name": "脑洞大开" - }, - "MONO_ICE": { - "name": "如履薄冰" - }, - "MONO_DRAGON": { - "name": "准神俱乐部" - }, - "MONO_DARK": { - "name": "总有叛逆期" - }, - "MONO_FAIRY": { - "name": "林克,醒醒!" - }, - "FRESH_START": { - "name": "初次尝试!", - "description": "完成初次尝试挑战" - }, - "INVERSE_BATTLE": { - "name": "镜子子镜", - "description": "完成逆转之战挑战\n战挑战之转逆成完" - } -} diff --git a/src/locales/zh_CN/arena-flyout.json b/src/locales/zh_CN/arena-flyout.json deleted file mode 100644 index fbce213c4aa..00000000000 --- a/src/locales/zh_CN/arena-flyout.json +++ /dev/null @@ -1,41 +0,0 @@ -{ - "activeBattleEffects": "当前战斗效果", - "player": "我方", - "neutral": "全局", - "enemy": "敌方", - "sunny": "大晴天", - "rain": "下雨", - "sandstorm": "沙暴", - "hail": "冰雹", - "snow": "下雪", - "fog": "起雾", - "heavyRain": "大雨", - "harshSun": "大日照", - "strongWinds": "乱流", - "misty": "薄雾场地", - "electric": "电气场地", - "grassy": "青草场地", - "psychic": "精神场地", - "mudSport": "玩泥巴", - "waterSport": "玩水", - "spikes": "撒菱", - "toxicSpikes": "毒菱", - "mist": "白雾", - "futureSight": "预知未来", - "doomDesire": "破灭之愿", - "wish": "祈愿", - "stealthRock": "隐形岩", - "stickyWeb": "黏黏网", - "trickRoom": "戏法空间", - "gravity": "重力", - "reflect": "反射壁", - "lightScreen": "光墙", - "auroraVeil": "极光幕", - "quickGuard": "快速防守", - "wideGuard": "广域防守", - "matBlock": "掀榻榻米", - "craftyShield": "戏法防守", - "tailwind": "顺风", - "happyHour": "快乐时光", - "safeguard": "神秘守护" -} diff --git a/src/locales/zh_CN/arena-tag.json b/src/locales/zh_CN/arena-tag.json deleted file mode 100644 index 74ad38ba9bf..00000000000 --- a/src/locales/zh_CN/arena-tag.json +++ /dev/null @@ -1,57 +0,0 @@ -{ - "yourTeam": "我方队伍", - "opposingTeam": "敌方队伍", - "arenaOnRemove": "{{moveName}}的效果消失了!", - "arenaOnRemovePlayer": "{{moveName}}在我方的效果消失了!", - "arenaOnRemoveEnemy": "{{moveName}}在敌方的效果消失了!", - "mistOnAdd": "{{pokemonNameWithAffix}}的一方被\n白雾包围了!", - "mistApply": "正受到白雾的保护\n能力不会被降低!", - "reflectOnAdd": "反射壁使\n物理抗性提高了!", - "reflectOnAddPlayer": "反射壁使我方的\n物理抗性提高了!", - "reflectOnAddEnemy": "反射壁使敌方的\n物理抗性提高了!", - "lightScreenOnAdd": "光墙使\n特殊抗性提高了!", - "lightScreenOnAddPlayer": "光墙使我方的\n特殊抗性提高了!", - "lightScreenOnAddEnemy": "光墙使敌方的\n特殊抗性提高了!", - "auroraVeilOnAdd": "极光幕使\n物理和特殊抗性提高了!", - "auroraVeilOnAddPlayer": "极光幕使我方的\n物理和特殊抗性提高了!", - "auroraVeilOnAddEnemy": "极光幕使敌方的\n物理和特殊抗性提高了!", - "conditionalProtectOnAdd": "{{moveName}}\n保护了!", - "conditionalProtectOnAddPlayer": "{{moveName}}\n保护了我方!", - "conditionalProtectOnAddEnemy": "{{moveName}}\n保护了敌方!", - "conditionalProtectApply": "{{moveName}}\n保护了{{pokemonNameWithAffix}}!", - "matBlockOnAdd": "{{pokemonNameWithAffix}}正在\n伺机使出掀榻榻米!", - "noCritOnAddPlayer": "{{moveName}}保护了你的\n队伍不被击中要害!", - "noCritOnAddEnemy": "{{moveName}}保护了对方的\n队伍不被击中要害!", - "noCritOnRemove": "{{pokemonNameWithAffix}}的{{moveName}}\n效果消失了!", - "wishTagOnAdd": "{{pokemonNameWithAffix}}的\n祈愿实现了!", - "mudSportOnAdd": "电气的威力减弱了!", - "mudSportOnRemove": "玩泥巴的效果消失了!", - "waterSportOnAdd": "火焰的威力减弱了!", - "waterSportOnRemove": "玩水的效果消失了!", - "spikesOnAdd": "{{opponentDesc}}脚下\n散落着{{moveName}}!", - "spikesActivateTrap": "{{pokemonNameWithAffix}}\n受到了撒菱的伤害!", - "toxicSpikesOnAdd": "{{opponentDesc}}脚下\n散落着{{moveName}}!", - "toxicSpikesActivateTrapPoison": "{{pokemonNameWithAffix}}\n吸收了{{moveName}}!", - "stealthRockOnAdd": "{{opponentDesc}}周围\n开始浮现出尖锐的岩石!", - "stealthRockActivateTrap": "尖锐的岩石扎进了\n{{pokemonNameWithAffix}}的体内!", - "stickyWebOnAdd": "对方的脚下\n延伸出了{{moveName}}!", - "stickyWebActivateTrap": "{{pokemonName}}\n被黏黏网粘住了!", - "trickRoomOnAdd": "{{pokemonNameWithAffix}}\n扭曲了时空!", - "trickRoomOnRemove": "扭曲的时空复原了!", - "gravityOnAdd": "重力变强了!", - "gravityOnRemove": "重力复原了!", - "tailwindOnAdd": "从身后\n吹起了顺风!", - "tailwindOnAddPlayer": "从我方身后\n吹起了顺风!", - "tailwindOnAddEnemy": "从敌方身后\n吹起了顺风!", - "tailwindOnRemove": "顺风停止了!", - "tailwindOnRemovePlayer": "我方的顺风停止了!", - "tailwindOnRemoveEnemy": "敌方的顺风停止了!", - "happyHourOnAdd": "大家被欢乐的\n气氛包围了!", - "happyHourOnRemove": "气氛回复到平常了。", - "safeguardOnAdd": "整个场地被\n神秘之幕包围了!", - "safeguardOnAddPlayer": "我方被\n神秘之幕包围了!", - "safeguardOnAddEnemy": "对手被\n神秘之幕包围了!", - "safeguardOnRemove": "包围整个场地的\n神秘之幕消失了!", - "safeguardOnRemovePlayer": "包围我方的\n神秘之幕消失了!", - "safeguardOnRemoveEnemy": "包围对手的\n神秘之幕消失了!" -} \ No newline at end of file diff --git a/src/locales/zh_CN/battle-info.json b/src/locales/zh_CN/battle-info.json deleted file mode 100644 index 884a01eb8a7..00000000000 --- a/src/locales/zh_CN/battle-info.json +++ /dev/null @@ -1,3 +0,0 @@ -{ - "generation": "第{{generation}}世代" -} \ No newline at end of file diff --git a/src/locales/zh_CN/battle-message-ui-handler.json b/src/locales/zh_CN/battle-message-ui-handler.json deleted file mode 100644 index 2aa750a9776..00000000000 --- a/src/locales/zh_CN/battle-message-ui-handler.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "ivBest": "最棒", - "ivFantastic": "了不起", - "ivVeryGood": "非常好", - "ivPrettyGood": "相当好", - "ivDecent": "一般般", - "ivNoGood": "也许不行" -} \ No newline at end of file diff --git a/src/locales/zh_CN/battle-scene.json b/src/locales/zh_CN/battle-scene.json deleted file mode 100644 index a0288475d69..00000000000 --- a/src/locales/zh_CN/battle-scene.json +++ /dev/null @@ -1,3 +0,0 @@ -{ - "moneyOwned": "₽{{formattedMoney}}" -} \ No newline at end of file diff --git a/src/locales/zh_CN/battle.json b/src/locales/zh_CN/battle.json deleted file mode 100644 index ccf0e560805..00000000000 --- a/src/locales/zh_CN/battle.json +++ /dev/null @@ -1,91 +0,0 @@ -{ - "bossAppeared": "{{bossName}} 出现了。", - "trainerAppeared": "{{trainerName}}\n想要和你对战!", - "trainerAppearedDouble": "{{trainerName}}\n想要和你对战!", - "trainerSendOut": "{{trainerName}}派出了\n{{pokemonName}}!", - "singleWildAppeared": "一只野生的{{pokemonName}}出现了!", - "multiWildAppeared": "野生的{{pokemonName1}}\n和{{pokemonName2}}出现了!", - "playerComeBack": "回来吧,{{pokemonName}}!", - "trainerComeBack": "{{trainerName}}收回了{{pokemonName}}!", - "playerGo": "去吧!{{pokemonName}}!", - "trainerGo": "{{trainerName}}派出了\n{{pokemonName}}!", - "switchQuestion": "要更换\n{{pokemonName}}吗?", - "trainerDefeated": "你击败了\n{{trainerName}}!", - "moneyWon": "你赢得了\n₽{{moneyAmount}}!", - "moneyPickedUp": "捡到了₽{{moneyAmount}}!", - "pokemonCaught": "{{pokemonName}}被抓住了!", - "addedAsAStarter": "增加了{{pokemonName}}作为\n一个新的基础宝可梦!", - "partyFull": "你的队伍已满员。是否放生其他宝可梦\n为{{pokemonName}}腾出空间?", - "pokemon": "宝可梦", - "sendOutPokemon": "上吧!\n{{pokemonName}}!", - "hitResultCriticalHit": "击中了要害!", - "hitResultSuperEffective": "效果拔群!", - "hitResultNotVeryEffective": "收效甚微…", - "hitResultNoEffect": "对{{pokemonName}}没有效果!!", - "hitResultImmune": "对于{{pokemonName}},\n完全没有效果!", - "hitResultOneHitKO": "一击必杀!", - "attackFailed": "但是失败了!", - "attackMissed": "没有命中{{pokemonNameWithAffix}}!", - "attackHitsCount": "击中{{count}}次!", - "rewardGain": "你获得了\n{{modifierName}}!", - "expGain": "{{pokemonName}}获得了{{exp}} 点经验值!", - "levelUp": "{{pokemonName}}升级到Lv.{{level}}!", - "learnMove": "{{pokemonName}}学会了{{moveName}}!", - "learnMovePrompt": "{{pokemonName}}想要学习{{moveName}}。", - "learnMoveLimitReached": "但是,{{pokemonName}}已经学会了\n四个技能", - "learnMoveReplaceQuestion": "要忘记一个技能并学习{{moveName}}吗?", - "learnMoveStopTeaching": "不再尝试学习{{moveName}}?", - "learnMoveNotLearned": "{{pokemonName}}没有学会{{moveName}}。", - "learnMoveForgetQuestion": "要忘记哪个技能?", - "learnMoveForgetSuccess": "{{pokemonName}}忘记了\n如何使用{{moveName}}。", - "countdownPoof": "@d{32}1, @d{15}2 @d{15}… @d{15}… @d{15}@s{se/pb_bounce_1}空!", - "learnMoveAnd": "然后……", - "levelCapUp": "等级上限提升到{{levelCap}}!", - "moveNotImplemented": "{{moveName}}尚未实装,无法选择。", - "moveNoPP": "这个技能的PP用完了", - "moveDisabled": "{{moveName}}被禁用!", - "disableInterruptedMove": "{{pokemonNameWithAffix}}的{{moveName}}\n被无效化了!", - "noPokeballForce": "一股无形的力量阻止了你使用精灵球。", - "noPokeballTrainer": "你不能捕捉其他训练家的宝可梦!", - "noPokeballMulti": "只能在剩下一只宝可梦时才能扔出精灵球!", - "noPokeballStrong": "目标宝可梦太强了,无法捕捉!\n你需要先削弱它!", - "noEscapeForce": "一股无形的力量阻止你逃跑。", - "noEscapeTrainer": "你不能从与训练家的战斗中逃跑!", - "noEscapePokemon": "{{pokemonName}}的{{moveName}}\n阻止了你{{escapeVerb}}!", - "runAwaySuccess": "成功逃走了!", - "runAwayCannotEscape": "无法逃走!", - "escapeVerbSwitch": "切换", - "escapeVerbFlee": "逃跑", - "notDisabled": "{{moveName}}不再被禁用!", - "turnEndHpRestore": "{{pokemonName}}的体力恢复了。", - "hpIsFull": "{{pokemonName}}的体力已满!", - "skipItemQuestion": "你确定要跳过拾取道具吗?", - "itemStackFull": "{{fullItemName}}持有数达到上限,\n你获得了{{itemName}}作为替代。", - "eggHatching": "咦?", - "stealEatBerry": "{{pokemonName}}夺取并吃掉了\n{{targetName}}的{{berryName}}!", - "ppHealBerry": "{{pokemonNameWithAffix}}用{{berryName}}\n回复了{{moveName}}的PP!", - "hpHealBerry": "{{pokemonNameWithAffix}}用{{berryName}}\n回复了体力!", - "ivScannerUseQuestion": "对{{pokemonName}}使用个体值扫描仪?", - "wildPokemonWithAffix": "野生的{{pokemonName}}", - "foePokemonWithAffix": "对手的{{pokemonName}}", - "useMove": "{{pokemonNameWithAffix}}使用了\n{{moveName}}!", - "drainMessage": "{{pokemonName}}\n吸取了体力!", - "regainHealth": "{{pokemonName}}\n回复了体力!", - "fainted": "{{pokemonNameWithAffix}}\n倒下了!", - "statsAnd": "和", - "stats": "能力", - "statRose_other": "{{pokemonNameWithAffix}}的{{stats}}提高了!", - "statSharplyRose_other": "{{pokemonNameWithAffix}}的{{stats}}大幅提高了!", - "statRoseDrastically_other": "{{pokemonNameWithAffix}}的{{stats}}极大幅提高了!", - "statWontGoAnyHigher_other": "{{pokemonNameWithAffix}}的{{stats}}已经无法再提高了!", - "statFell_other": "{{pokemonNameWithAffix}}的{{stats}}降低了!", - "statHarshlyFell_other": "{{pokemonNameWithAffix}}的{{stats}}大幅降低了!", - "statSeverelyFell_other": "{{pokemonNameWithAffix}}的{{stats}}极大幅降低了!", - "statWontGoAnyLower_other": "{{pokemonNameWithAffix}}的{{stats}}已经无法再降低了!", - "transformedIntoType": "{{pokemonName}}变成了\n{{type}}属性!", - "ppReduced": "降低了{{targetName}}的\n{{moveName}}的PP{{reduction}}点!", - "retryBattle": "你要从对战开始时重试么?", - "unlockedSomething": "{{unlockedThing}}\n已解锁。", - "congratulations": "恭喜!", - "beatModeFirstTime": "{{speciesName}}首次击败了{{gameMode}}!\n你获得了{{newModifier}}!" -} diff --git a/src/locales/zh_CN/battler-tags.json b/src/locales/zh_CN/battler-tags.json deleted file mode 100644 index a7859380b7a..00000000000 --- a/src/locales/zh_CN/battler-tags.json +++ /dev/null @@ -1,77 +0,0 @@ -{ - "trappedDesc": "束缚", - "flinchedDesc": "畏缩", - "confusedDesc": "混乱", - "infatuatedDesc": "着迷", - "seedDesc": "寄生种子", - "nightmareDesc": "恶梦", - "ingrainDesc": "扎根", - "drowsyDesc": "瞌睡", - "rechargingLapse": "{{pokemonNameWithAffix}}\n因攻击的反作用力而无法动弹!", - "trappedOnAdd": "{{pokemonNameWithAffix}}不能逃跑!", - "trappedOnRemove": "{{pokemonNameWithAffix}}\n摆脱了{{moveName}}!", - "flinchedLapse": "{{pokemonNameWithAffix}}\n畏缩了,无法使出招式!", - "confusedOnAdd": "{{pokemonNameWithAffix}}\n混乱了!", - "confusedOnRemove": "{{pokemonNameWithAffix}}\n的混乱解除了!", - "confusedOnOverlap": "{{pokemonNameWithAffix}}\n已经混乱了。", - "confusedLapse": "{{pokemonNameWithAffix}}\n正在混乱中!", - "confusedLapseHurtItself": "不知所以地攻击了自己!", - "destinyBondLapseIsBoss": "{{pokemonNameWithAffix}}\n不再受到同命的影响", - "destinyBondLapse": "{{pokemonNameWithAffix}}\n和{{pokemonNameWithAffix2}}同归于尽了!", - "infatuatedOnAdd": "{{pokemonNameWithAffix}}\n对{{sourcePokemonName}}着迷了!", - "infatuatedOnOverlap": "{{pokemonNameWithAffix}}\n已经着迷了!", - "infatuatedLapse": "{{pokemonNameWithAffix}}\n对{{sourcePokemonName}}着迷中!", - "infatuatedLapseImmobilize": "{{pokemonNameWithAffix}}\n不会着迷!", - "infatuatedOnRemove": "{{pokemonNameWithAffix}}\n治愈了着迷状态!", - "seededOnAdd": "将种子种植在了\n{{pokemonNameWithAffix}}的身上!", - "seededLapse": "{{pokemonNameWithAffix}}\n被寄生种子吸取了体力!", - "seededLapseShed": "{{pokemonNameWithAffix}}\n吸到了污泥浆!", - "nightmareOnAdd": "{{pokemonNameWithAffix}}\n开始做恶梦了!", - "nightmareOnOverlap": "{{pokemonNameWithAffix}}\n已经被恶梦缠身!", - "nightmareLapse": "{{pokemonNameWithAffix}}\n正被恶梦缠身!", - "encoreOnAdd": "{{pokemonNameWithAffix}}\n接受了再来一次!", - "encoreOnRemove": "{{pokemonNameWithAffix}}\n的再来一次状态解除了!", - "helpingHandOnAdd": "{{pokemonNameWithAffix}}\n摆出了帮助{{pokemonName}}的架势!", - "ingrainLapse": "{{pokemonNameWithAffix}}\n用扎根回复了体力!", - "ingrainOnTrap": "{{pokemonNameWithAffix}}\n扎根了!", - "aquaRingOnAdd": "{{pokemonNameWithAffix}}\n用水流环包裹了自己!", - "aquaRingLapse": "{{moveName}}回复了\n{{pokemonName}}的体力!", - "drowsyOnAdd": "{{pokemonNameWithAffix}}\n产生睡意了!", - "damagingTrapLapse": "{{pokemonNameWithAffix}}受到了\n{{moveName}}的伤害!", - "bindOnTrap": "{{pokemonNameWithAffix}}被\n{{sourcePokemonName}}的{{moveName}}紧紧束缚住了!", - "wrapOnTrap": "{{pokemonNameWithAffix}}被\n{{sourcePokemonName}}绑紧了!", - "vortexOnTrap": "{{pokemonNameWithAffix}}\n被困在了旋涡之中!", - "clampOnTrap": "{{sourcePokemonNameWithAffix}}用贝壳\n夹住了{{pokemonName}}!", - "sandTombOnTrap": "{{pokemonNameWithAffix}}\n被{{moveName}}困住了!", - "magmaStormOnTrap": "{{pokemonNameWithAffix}}\n被困在了熔岩风暴之中!", - "snapTrapOnTrap": "{{pokemonNameWithAffix}}\n被捕兽夹困住了!", - "thunderCageOnTrap": "{{sourcePokemonNameWithAffix}}困住了\n{{pokemonNameWithAffix}}!", - "infestationOnTrap": "{{pokemonNameWithAffix}}受到了\n{{sourcePokemonNameWithAffix}}的死缠烂打!", - "protectedOnAdd": "{{pokemonNameWithAffix}}\n摆出了防守的架势!", - "protectedLapse": "{{pokemonNameWithAffix}}\n在攻击中保护了自己!", - "enduringOnAdd": "{{pokemonNameWithAffix}}\n摆出了挺住攻击的架势!", - "enduringLapse": "{{pokemonNameWithAffix}}\n挺住了攻击!", - "sturdyLapse": "{{pokemonNameWithAffix}}\n挺住了攻击!", - "perishSongLapse": "{{pokemonNameWithAffix}}\n的灭亡计时变成{{turnCount}}了!", - "centerOfAttentionOnAdd": "{{pokemonNameWithAffix}}\n变得万众瞩目了!", - "truantLapse": "{{pokemonNameWithAffix}}\n正在偷懒!", - "slowStartOnAdd": "{{pokemonNameWithAffix}}\n无法拿出平时的水平!", - "slowStartOnRemove": "{{pokemonNameWithAffix}}\n恢复了平时的水平!", - "highestStatBoostOnAdd": "{{pokemonNameWithAffix}}的\n{{statName}}提高了!", - "highestStatBoostOnRemove": "{{pokemonNameWithAffix}}的\n{{abilityName}}效果解除了!", - "magnetRisenOnAdd": "{{pokemonNameWithAffix}}\n因电磁力浮了起来!", - "magnetRisenOnRemove": "{{pokemonNameWithAffix}}的\n电磁力消失了!", - "critBoostOnAdd": "{{pokemonNameWithAffix}}\n现在干劲十足!", - "critBoostOnRemove": "{{pokemonNameWithAffix}}\n如释重负似地放松了下来。", - "saltCuredOnAdd": "{{pokemonNameWithAffix}}\n陷入了盐腌状态!", - "saltCuredLapse": "{{pokemonNameWithAffix}}\n受到了{{moveName}}的伤害!", - "cursedOnAdd": "{{pokemonNameWithAffix}}削减了自己的体力,\n并诅咒了{{pokemonName}}!", - "cursedLapse": "{{pokemonNameWithAffix}}\n正受到诅咒!", - "stockpilingOnAdd": "{{pokemonNameWithAffix}}蓄力了{{stockpiledCount}}次!", - "disabledOnAdd": "封住了{{pokemonNameWithAffix}}的\n{{moveName}}!", - "disabledLapse": "{{pokemonNameWithAffix}}的\n定身法解除了!", - "tarShotOnAdd": "{{pokemonNameWithAffix}}\n变得怕火了!", - "substituteOnAdd": "{{pokemonNameWithAffix}}的\n替身出现了!", - "substituteOnHit": "替身代替{{pokemonNameWithAffix}}\n承受了攻击!", - "substituteOnRemove": "{{pokemonNameWithAffix}}的\n替身消失了……" -} diff --git a/src/locales/zh_CN/berry.json b/src/locales/zh_CN/berry.json deleted file mode 100644 index 4a739343655..00000000000 --- a/src/locales/zh_CN/berry.json +++ /dev/null @@ -1,46 +0,0 @@ -{ - "SITRUS": { - "name": "文柚果", - "effect": "HP低于50%时,回复最大HP的25%" - }, - "LUM": { - "name": "木子果", - "effect": "治愈任何异常状态和混乱状态" - }, - "ENIGMA": { - "name": "谜芝果", - "effect": "受到效果绝佳的招式攻击时,回复25%最大HP" - }, - "LIECHI": { - "name": "枝荔果", - "effect": "HP低于25%时,攻击提升一个等级" - }, - "GANLON": { - "name": "龙睛果", - "effect": "HP低于25%时,防御提升一个等级" - }, - "PETAYA": { - "name": "龙火果", - "effect": "HP低于25%时,特攻提升一个等级" - }, - "APICOT": { - "name": "杏仔果", - "effect": "HP低于25%时,特防提升一个等级" - }, - "SALAC": { - "name": "沙鳞果", - "effect": "HP低于25%时,速度提升一个等级" - }, - "LANSAT": { - "name": "兰萨果", - "effect": "HP低于25%时,击中要害率提升两个等级" - }, - "STARF": { - "name": "星桃果", - "effect": "HP低于25%时,提高随机一项能力两个等级" - }, - "LEPPA": { - "name": "苹野果", - "effect": "有招式的PP降到0时,恢复该招式10PP" - } -} \ No newline at end of file diff --git a/src/locales/zh_CN/bgm-name.json b/src/locales/zh_CN/bgm-name.json deleted file mode 100644 index 065347e3bb6..00000000000 --- a/src/locales/zh_CN/bgm-name.json +++ /dev/null @@ -1,148 +0,0 @@ -{ - "music": "BGM: ", - "missing_entries": "{{name}}", - "battle_kanto_champion": "黑2白2「决战!关都冠军」", - "battle_johto_champion": "黑2白2「决战!城都冠军」", - "battle_hoenn_champion_g5": "黑2白2「决战!丰缘冠军」", - "battle_hoenn_champion_g6": "Ω红宝石α蓝宝石「决战!丰缘冠军」", - "battle_sinnoh_champion": "黑2白2「决战!神奥冠军」", - "battle_champion_alder": "黑白「决战!合众冠军」", - "battle_champion_iris": "黑2白2「决战!合众冠军」", - "battle_kalos_champion": "XY「决战!卡洛斯冠军」", - "battle_alola_champion": "究极日月「顶上决战!」", - "battle_galar_champion": "剑盾「决战!伽勒尔冠军」", - "battle_champion_geeta": "朱紫「决战!帕底亚首席也慈」", - "battle_champion_nemona": "朱紫「决战!帕底亚冠军妮莫」", - "battle_champion_kieran": "朱紫「决战!蓝莓学园冠军乌栗」", - "battle_hoenn_elite": "Ω红宝石α蓝宝石 「战斗!丰缘四天王」", - "battle_unova_elite": "黑白 「战斗!合众四天王」", - "battle_kalos_elite": "XY「战斗!卡洛斯四天王」", - "battle_alola_elite": "日月「战斗!阿罗拉四天王」", - "battle_galar_elite": "剑盾「联盟锦标赛」", - "battle_paldea_elite": "朱紫「战斗!帕底亚四天王」", - "battle_bb_elite": "朱紫「战斗!蓝之圆盘四天王」", - "battle_final_encounter": "探险队DX 「裂空座的领域」", - "battle_final": "黑白「战斗!魁奇思」", - "battle_kanto_gym": "黑2白2「战斗!关都道馆主」", - "battle_johto_gym": "黑2白2「战斗!城都道馆主」", - "battle_hoenn_gym": "黑2白2「战斗!合众道馆主」", - "battle_sinnoh_gym": "黑2白2「战斗!神奥道馆主」", - "battle_unova_gym": "黑白「战斗!合众道馆主」", - "battle_kalos_gym": "XY「战斗!卡洛斯道馆主」", - "battle_galar_gym": "剑盾「战斗!伽勒尔道馆主」", - "battle_paldea_gym": "朱紫「战斗!帕底亚道馆主」", - "battle_legendary_kanto": "XY「战斗!传说宝可梦(关都)」", - "battle_legendary_raikou": "心金魂银「战斗!雷公」", - "battle_legendary_entei": "心金魂银「战斗!炎帝」", - "battle_legendary_suicune": "心金魂银「战斗!水君」", - "battle_legendary_lugia": "心金魂银「战斗!洛奇亚」", - "battle_legendary_ho_oh": "心金魂银「战斗!凤王」", - "battle_legendary_regis_g5": "黑2白2「战斗!传说中的巨人」", - "battle_legendary_regis_g6": "Ω红宝石α蓝宝石「战斗!传说中的巨人」", - "battle_legendary_gro_kyo": "Ω红宝石α蓝宝石「战斗!原始回归」", - "battle_legendary_rayquaza": "Ω红宝石α蓝宝石「战斗!超古代宝可梦」", - "battle_legendary_deoxys": "Ω红宝石α蓝宝石「战斗!代欧奇希斯」", - "battle_legendary_lake_trio": "Ω红宝石α蓝宝石「战斗!由克希・艾姆利多・亚克诺姆」", - "battle_legendary_sinnoh": "Ω红宝石α蓝宝石「战斗!传说的宝可梦」", - "battle_legendary_dia_pal": "Ω红宝石α蓝宝石「战斗!帝牙卢卡・帕路奇亚」", - "battle_legendary_giratina": "Ω红宝石α蓝宝石「战斗!骑拉帝纳」", - "battle_legendary_arceus": "心金魂银「阿尔宙斯」", - "battle_legendary_unova": "黑白「战斗!传说的宝可梦」", - "battle_legendary_kyurem": "黑白「战斗!酋雷姆」", - "battle_legendary_res_zek": "黑白「战斗!莱希拉姆・捷克罗姆」", - "battle_legendary_xern_yvel": "XY「战斗!哲尔尼亚斯・伊裴尔塔尔」", - "battle_legendary_tapu": "日月「战斗!卡璞」", - "battle_legendary_sol_lun": "日月「战斗!露奈雅拉・索尔迦雷欧」", - "battle_legendary_ub": "日月「战斗!究极异兽」", - "battle_legendary_dusk_dawn": "究极日月「战斗!日食・月食 奈克洛兹玛」", - "battle_legendary_ultra_nec": "究极日月「战斗!究极奈克洛兹玛」", - "battle_legendary_zac_zam": "剑盾「战斗!苍响・藏玛然特」", - "battle_legendary_glas_spec": "剑盾「战斗! 雪暴马・灵幽马」", - "battle_legendary_calyrex": "剑盾「战斗!蕾冠王」", - "battle_legendary_birds_galar": "剑盾「战斗!传说的鸟宝可梦」", - "battle_legendary_ruinous": "朱紫「战斗!灾厄宝可梦」", - "battle_legendary_kor_mir": "朱紫「战斗!第零区的宝可梦2」", - "battle_legendary_loyal_three": "朱紫「战斗!宝伴」", - "battle_legendary_ogerpon": "朱紫「战斗!厄鬼椪」", - "battle_legendary_terapagos": "朱紫「战斗!太乐巴戈斯」", - "battle_legendary_pecharunt": "朱紫「战斗!桃歹郎」", - "battle_rival": "黑白「战斗!黑连・贝尔」", - "battle_rival_2": "黑白「战斗!N」", - "battle_rival_3": "黑白「决战!N」", - "battle_trainer": "黑白「战斗!训练师」", - "battle_wild": "黑白「战斗!野生宝可梦」", - "battle_wild_strong": "黑白「战斗!强大野生宝可梦」", - "end_summit": "探险队DX 「天空之柱 顶层」", - "battle_rocket_grunt": "心金魂银「战斗!火箭队」", - "battle_aqua_magma_grunt": "Ω红宝石α蓝宝石「战斗!熔岩队・海洋队」", - "battle_galactic_grunt": "晶灿钻石·明亮珍珠「战斗!银河队」", - "battle_plasma_grunt": "黑白「战斗!等离子团」", - "battle_flare_grunt": "XY「战斗!闪焰队」", - "battle_aether_grunt": "日月「战斗!以太基金会」", - "battle_skull_grunt": "日月「战斗!骷髅队」", - "battle_macro_grunt": "剑盾「战斗!马洛科蒙集团」", - "battle_galactic_admin": "晶灿钻石·明亮珍珠「战斗!银河队干部」", - "battle_skull_admin": "日月「战斗!骷髅队干部」", - "battle_oleana": "剑盾「战斗!奥利薇」", - "battle_rocket_boss": "究极日月「战斗!坂木」", - "battle_aqua_magma_boss": "Ω红宝石α蓝宝石「战斗!水梧桐・赤焰松」", - "battle_galactic_boss": "晶灿钻石·明亮珍珠「战斗!赤日」", - "battle_plasma_boss": "黑2白2「战斗!魁奇思」", - "battle_flare_boss": "XY「战斗!弗拉达利」", - "battle_aether_boss": "日月「战斗!露莎米奈」", - "battle_skull_boss": "日月「战斗!古兹马」", - "battle_macro_boss": "剑盾「战斗!洛兹」", - - "abyss": "空之探险队「黑暗小丘」", - "badlands": "空之探险队「枯竭之谷」", - "beach": "空之探险队「潮湿岩地」", - "cave": "空之探险队「天空顶端(洞窟)」", - "construction_site": "空之探险队「幻影石室」", - "desert": "空之探险队「北方沙漠」", - "dojo": "空之探险队「嘎啦嘎啦道场」", - "end": "探险队DX「天空之柱」", - "factory": "空之探险队「隐藏遗迹」", - "fairy_cave": "空之探险队「星之洞窟」", - "forest": "空之探险队「黑暗森林」", - "grass": "空之探险队「苹果森林」", - "graveyard": "空之探险队「神秘森林」", - "ice_cave": "空之探险队「大冰山」", - "island": "空之探险队「沿岸岩地」", - "jungle": "Lmz - 丛林", - "laboratory": "Firel - 研究所", - "lake": "空之探险队「水晶洞窟」", - "meadow": "空之探险队「天空顶端(森林)」", - "metropolis": "Firel - 城市", - "mountain": "空之探险队「角山」", - "plains": "空之探险队「天空顶端(草原)」", - "power_plant": "空之探险队「电气平原 深处」", - "ruins": "空之探险队「封印岩地 深处」", - "sea": "Andr06 - 海洋之秘", - "seabed": "Firel - 海底", - "slum": "Andr06 - 狡猾的雪吞虫", - "snowy_forest": "空之探险队「天空顶端(雪山)」", - "space": "Firel - 太空", - "swamp": "空之探险队「封闭之海」", - "tall_grass": "空之探险队「浓雾森林」", - "temple": "空之探险队「守护洞穴」", - "town": "空之探险队「随机迷宫3」", - "volcano": "空之探险队「热水洞窟」", - "wasteland": "空之探险队「梦幻高原」", - "encounter_ace_trainer": "黑白 「视线!精英训练师」", - "encounter_backpacker": "黑白 「视线!背包客」", - "encounter_clerk": "黑白 「视线!上班族」", - "encounter_cyclist": "黑白 「视线!自行车手」", - "encounter_lass": "黑白 「视线!迷你裙」", - "encounter_parasol_lady": "黑白 「视线!阳伞姐姐」", - "encounter_pokefan": "黑白 「视线!宝可梦爱好者」", - "encounter_psychic": "黑白 「视线!超能力者」", - "encounter_rich": "黑白 「视线!绅士」", - "encounter_rival": "黑白「黑连」", - "encounter_roughneck": "黑白 「视线!光头」", - "encounter_scientist": "黑白 「视线!科学家」", - "encounter_twins": "黑白 「视线!双胞胎」", - "encounter_youngster": "黑白 「视线!短裤小子」", - "heal": "黑白「宝可梦回复」", - "menu": "空之探险队「欢迎来到宝可梦的世界」", - "title": "空之探险队「主题曲」" -} diff --git a/src/locales/zh_CN/biome.json b/src/locales/zh_CN/biome.json deleted file mode 100644 index 114b0638e0b..00000000000 --- a/src/locales/zh_CN/biome.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "unknownLocation": "未知领域", - "TOWN": "城镇", - "PLAINS": "平原", - "GRASS": "草地", - "TALL_GRASS": "高草丛", - "METROPOLIS": "城市", - "FOREST": "森林", - "SEA": "海洋", - "SWAMP": "沼泽", - "BEACH": "沙滩", - "LAKE": "湖泊", - "SEABED": "海底", - "MOUNTAIN": "山脉", - "BADLANDS": "不毛之地", - "CAVE": "洞窟", - "DESERT": "沙漠", - "ICE_CAVE": "寒冰洞窟", - "MEADOW": "花丛", - "POWER_PLANT": "发电厂", - "VOLCANO": "火山", - "GRAVEYARD": "墓地", - "DOJO": "道场", - "FACTORY": "工厂", - "RUINS": "遗迹", - "WASTELAND": "荒地龙巢", - "ABYSS": "幽谷深渊", - "SPACE": "太空", - "CONSTRUCTION_SITE": "工地", - "JUNGLE": "丛林", - "FAIRY_CAVE": "妖精洞窟", - "TEMPLE": "神殿", - "SLUM": "陋巷", - "SNOWY_FOREST": "冰雪森林", - "ISLAND": "岛屿", - "LABORATORY": "研究所", - "END": "???" -} \ No newline at end of file diff --git a/src/locales/zh_CN/challenges.json b/src/locales/zh_CN/challenges.json deleted file mode 100644 index 9351ec96285..00000000000 --- a/src/locales/zh_CN/challenges.json +++ /dev/null @@ -1,36 +0,0 @@ -{ - "title": "适用挑战条件", - "illegalEvolution": "{{pokemon}}变成了\n不符合此挑战条件的宝可梦!", - "singleGeneration": { - "name": "单一世代", - "desc": "你只能使用第{{gen}}\n世代的宝可梦", - "desc_default": "你只能使用所选\n世代的宝可梦", - "gen_1": "一", - "gen_2": "二", - "gen_3": "三", - "gen_4": "四", - "gen_5": "五", - "gen_6": "六", - "gen_7": "七", - "gen_8": "八", - "gen_9": "九" - }, - "singleType": { - "name": "单属性", - "desc": "你只能使用{{type}}\n属性的宝可梦", - "desc_default": "你只能使用所选\n属性的宝可梦" - }, - "freshStart": { - "name": "初次尝试", - "desc": "你只能使用御三家,就像是你第一次玩宝可梦肉鸽一样。", - "value.0": "关闭", - "value.1": "开启" - }, - "inverseBattle": { - "name": "逆转之战", - "shortName": "逆转之战", - "desc": "属性相克关系被反转,且没有任何属性对其他属性免疫。\n禁用其他挑战的成就。", - "value.0": "关闭", - "value.1": "开启" - } -} \ No newline at end of file diff --git a/src/locales/zh_CN/command-ui-handler.json b/src/locales/zh_CN/command-ui-handler.json deleted file mode 100644 index b65ba643e05..00000000000 --- a/src/locales/zh_CN/command-ui-handler.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "fight": "战斗", - "ball": "精灵球", - "pokemon": "宝可梦", - "run": "逃跑", - "actionMessage": "要让\n{{pokemonName}} 做什么?" -} \ No newline at end of file diff --git a/src/locales/zh_CN/common.json b/src/locales/zh_CN/common.json deleted file mode 100644 index bf639f0875c..00000000000 --- a/src/locales/zh_CN/common.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "start": "开始", - "luckIndicator": "幸运:", - "shinyOnHover": "闪光", - "commonShiny": "常见", - "rareShiny": "稀有", - "epicShiny": "史诗" -} \ No newline at end of file diff --git a/src/locales/zh_CN/config.ts b/src/locales/zh_CN/config.ts deleted file mode 100644 index 44a190d8c11..00000000000 --- a/src/locales/zh_CN/config.ts +++ /dev/null @@ -1,113 +0,0 @@ -import common from "./common.json"; -import settings from "./settings.json"; -import ability from "./ability.json"; -import abilityTriggers from "./ability-trigger.json"; -import arenaFlyout from "./arena-flyout.json"; -import arenaTag from "./arena-tag.json"; -import achv from "./achv.json"; -import battle from "./battle.json"; -import battleScene from "./battle-scene.json"; -import battleInfo from "./battle-info.json"; -import battleMessageUiHandler from "./battle-message-ui-handler.json"; -import battlerTags from "./battler-tags.json"; -import berry from "./berry.json"; -import bgmName from "./bgm-name.json"; -import biome from "./biome.json"; -import challenges from "./challenges.json"; -import commandUiHandler from "./command-ui-handler.json"; -import dialogue from "./dialogue.json"; -import battleSpecDialogue from "./dialogue-final-boss.json"; -import miscDialogue from "./dialogue-misc.json"; -import doubleBattleDialogue from "./dialogue-double-battle.json"; -import egg from "./egg.json"; -import fightUiHandler from "./fight-ui-handler.json"; -import filterBar from "./filter-bar.json"; -import gameMode from "./game-mode.json"; -import gameStatsUiHandler from "./game-stats-ui-handler.json"; -import growth from "./growth.json"; -import menu from "./menu.json"; -import menuUiHandler from "./menu-ui-handler.json"; -import modifier from "./modifier.json"; -import modifierType from "./modifier-type.json"; -import move from "./move.json"; -import nature from "./nature.json"; -import partyUiHandler from "./party-ui-handler.json"; -import pokeball from "./pokeball.json"; -import pokemon from "./pokemon.json"; -import pokemonForm from "./pokemon-form.json"; -import battlePokemonForm from "./pokemon-form-battle.json"; -import pokemonInfo from "./pokemon-info.json"; -import pokemonInfoContainer from "./pokemon-info-container.json"; -import pokemonSummary from "./pokemon-summary.json"; -import saveSlotSelectUiHandler from "./save-slot-select-ui-handler.json"; -import splashMessages from "./splash-messages.json"; -import starterSelectUiHandler from "./starter-select-ui-handler.json"; -import statusEffect from "./status-effect.json"; -import trainerTitles from "./trainer-titles.json"; -import trainerClasses from "./trainer-classes.json"; -import trainerNames from "./trainer-names.json"; -import tutorial from "./tutorial.json"; -import voucher from "./voucher.json"; -import weather from "./weather.json"; -import terrain from "./terrain.json"; -import modifierSelectUiHandler from "./modifier-select-ui-handler.json"; -import moveTriggers from "./move-trigger.json"; -import runHistory from "./run-history.json"; - -export const zhCnConfig = { - ability, - abilityTriggers, - arenaFlyout, - arenaTag, - battle, - battleScene, - battleInfo, - battleMessageUiHandler, - battlePokemonForm, - battlerTags, - berry, - bgmName, - biome, - challenges, - commandUiHandler, - common, - achv, - dialogue, - battleSpecDialogue, - miscDialogue, - doubleBattleDialogue, - egg, - fightUiHandler, - filterBar, - gameMode, - gameStatsUiHandler, - growth, - menu, - menuUiHandler, - modifier, - modifierType, - move, - nature, - pokeball, - pokemon, - pokemonForm, - pokemonInfo, - pokemonInfoContainer, - pokemonSummary, - saveSlotSelectUiHandler, - settings, - splashMessages, - starterSelectUiHandler, - statusEffect, - terrain, - titles: trainerTitles, - trainerClasses, - trainerNames, - tutorial, - voucher, - weather, - partyUiHandler, - modifierSelectUiHandler, - moveTriggers, - runHistory, -}; diff --git a/src/locales/zh_CN/dialogue-double-battle.json b/src/locales/zh_CN/dialogue-double-battle.json deleted file mode 100644 index 629de3aff3e..00000000000 --- a/src/locales/zh_CN/dialogue-double-battle.json +++ /dev/null @@ -1,82 +0,0 @@ -{ - "blue_red_double": { - "encounter": { - "1": "青绿:嘿,赤红,\n让这家伙看看我们是什么来头!$赤红: ...$青绿: 见识下真新镇的实力!" - }, - "victory": { - "1": "青绿:打得真不错$赤红: ..." - } - }, - "red_blue_double": { - "encounter": { - "1": "赤红: ...!$青绿: 他人狠话不多。$青绿: 但别被他耍了,\n毕竟他可是个冠军!" - }, - "victory": { - "1": "赤红: ...!$青绿: 下次我们一定会赢你!" - } - }, - "tate_liza_double": { - "encounter": { - "1": "小枫:嘿嘿嘿……你惊讶吗?$小南: 这里有两个道馆馆主?$小枫: 我们是双胞胎!$小南: 我们无需交谈,因为……$我们可以通晓彼此的想法$小枫: 我们的组合……$小南: 你能打败吗?" - }, - "victory": { - "1": "小枫:什么?我们的组合……$小南:被瓦解了!" - } - }, - "liza_tate_double": { - "encounter": { - "1": "小南:呵呵呵……你惊讶吧?$小枫:这里有两个道馆馆主?$小南:我们可以通晓……$小枫:彼此的想法……$小南:全在我们脑中!$小枫:我们的组合……$小南:你能打败吗?" - }, - "victory": { - "1": "小枫:你和你的宝可梦……$小南:简直像亲兄弟姐妹!" - } - }, - "wallace_steven_double": { - "encounter": { - "1": "大吾:米可利, 展现冠军的实力吧!$米可利:我们将展示丰缘的实力!$大吾:要上了!" - }, - "victory": { - "1": "大吾:打得真不错!$米可利:我们下次会赢的!" - } - }, - "steven_wallace_double": { - "encounter": { - "1": "大吾:你有什么稀有的宝可梦吗?$米可利:大吾……我们是来对战的,\n不是来炫耀宝可梦的。$大吾:哦……知道了… 那么要上了!" - }, - "victory": { - "1": "大吾:战斗结束了,\n来看看我的稀有宝可梦!$米可利:大吾……" - } - }, - "alder_iris_double": { - "encounter": { - "1": "阿戴克:我们俩是合众最强的训练家!$艾莉丝:与最强来一场最激烈的战斗吧!" - }, - "victory": { - "1": "阿戴克:哇哦!你真是超级厉害!$艾莉丝:我们下次会赢的啦!" - } - }, - "iris_alder_double": { - "encounter": { - "1": "艾莉丝:欢迎!挑战者,\n合众地区最强的冠军大驾光临!$阿戴克:艾莉丝,你是不是有点太兴奋了…" - }, - "victory": { - "1": "艾莉丝:这样的失败可不好受啊…$阿戴克:但是只有失败才能让我们变强!" - } - }, - "piers_marnie_double": { - "encounter": { - "1": "玛俐:哥哥,给他们展现尖钉镇的实力!$聂梓:我们带来黑暗!" - }, - "victory": { - "1": "玛俐:你的强光亮瞎我们的黑暗了啦……$聂梓:实在太亮了…" - } - }, - "marnie_piers_double": { - "encounter": { - "1": "聂梓: 台下准备好了吗!$玛俐: 哥哥,我们是来对战的,\n不是来唱歌的……" - }, - "victory": { - "1": "聂梓:这首歌献给大家!$玛俐:哥哥……" - } - } -} diff --git a/src/locales/zh_CN/dialogue-final-boss.json b/src/locales/zh_CN/dialogue-final-boss.json deleted file mode 100644 index edbc302dcd4..00000000000 --- a/src/locales/zh_CN/dialogue-final-boss.json +++ /dev/null @@ -1,5 +0,0 @@ -{ - "encounter": "看来终于又到了那个时候。\n你知道自己为何会来到这里,不是吗?\n$你被吸引到这里,因为你以前就来过这里。\n无数次。\n$尽管,或许可以数一数。\n准确地说,这实际上是你的第{{cycleCount}}次循环。\n$每一次循环,你的思想都会恢复到之前的状态。\n即便如此,不知何故,你之前自我的残留仍然存在。\n$直到现在,你仍未成功,\n但我感觉这次你身上有一种异样的气息。\n$你是这里唯一的人,尽管感觉上还有……另一个人。\n$你最终会成为对我来的一个硬茬吗?\n我渴望了数千年的挑战?\n$我们,开始。", - "firstStageWin": "我明白了。我所感觉到的气息确实是真实的。\n看来我不再需要保留实力了。\n$别让我失望。", - "secondStageWin": "…漂亮。" -} \ No newline at end of file diff --git a/src/locales/zh_CN/dialogue-misc.json b/src/locales/zh_CN/dialogue-misc.json deleted file mode 100644 index b26a3a5f208..00000000000 --- a/src/locales/zh_CN/dialogue-misc.json +++ /dev/null @@ -1,4 +0,0 @@ -{ - "ending": "@c{shock}你回来了?@d{32} 也就是说…@d{96} 你赢了呀!?\n@c{smile_ehalf}我应该早料到了。\n$@c{smile_eclosed}当然…我一直有这种感觉\n@c{smile}一切都结束了,对么? 你打破了循环。\n$@c{smile_ehalf}你也完成了自己的梦想,不是吗?\n你甚至一次都没失败。\n$我是唯一能够记得你所作所为的人\n@c{angry_mopen}我会努力不忘掉哒!\n$@c{smile_wave_wink}开玩笑啦,@d{64} @c{smile}我才不会忘呢。@d{32}\n你的传奇将永远留存于我们心中。\n$@c{smile_wave}不管了,@d{64} 时候不早了@d{96} ,应该吧?\n在这地方还真搞不清楚。\n$一起回家吧。 @c{smile_wave_wink}可能明天,我们再来打一场,为了重温回忆嘛~", - "ending_female": "@c{smile}哦?你赢了?@d{96} @c{smile_eclosed}我应该早猜到了\n你回来了。\n$@c{smile}结束了。@d{64} 你终结了这个循环。\n$@c{serious_smile_fists}你也完成了自己的梦想,不是吗?\n你甚至一次都没失败。\n$@c{neutral}我是唯一能够记得你所作所为的人@d{96}\n我觉得这应该也还行吧?\n$@c{serious_smile_fists}你的传奇将永远留存于我们心中。\n$@c{smile_eclosed}不管了,我真是受够这个地方了,你也一样吗?我们回家吧。\n$@c{serious_smile_fists}可能等我们回家以后,再打一场?\n要是你想的话" -} diff --git a/src/locales/zh_CN/dialogue.json b/src/locales/zh_CN/dialogue.json deleted file mode 100644 index dd0fa3fb3cc..00000000000 --- a/src/locales/zh_CN/dialogue.json +++ /dev/null @@ -1,2691 +0,0 @@ -{ - "youngster": { - "encounter": { - "1": "嘿,想来对战吗?", - "2": "你也是新人训练师吗?", - "3": "嘿,我之前没见过你。我们来对战吧!", - "4": "我刚输了,所以我正在寻找更多的宝可梦。$等等!你看起来很弱!\n来吧,我们对战吧!", - "5": "我们见过面吗?我记不太清了。$嗯,不管怎样,很高兴见到你!", - "6": "好的!我们上吧!", - "7": "好的!我来啦!我会向你展示我的实力!", - "8": "嚯嚯嚯...我会向你展示我的宝可梦有多厉害!", - "9": "不要浪费时间打招呼。你准备好了就放马过来!", - "10": "别掉以轻心,$否则你可能会被小朋友打到哭鼻子哦。", - "11": "我精心培养了我的宝可梦。不许你伤害它们!", - "12": "恭喜你成功了!从这以后可不轻松哦。", - "13": "战斗永无止境!欢迎来到没有尽头的世界!" - }, - "victory": { - "1": "哇!你很强!", - "2": "我根本没机会赢,对吧?", - "3": "我会等长大了再来打败你!", - "4": "呃。我没有更多宝可梦了。", - "5": "不可能…不可能!我怎么可能又输了…", - "6": "不!我输了!", - "7": "哇!你真是太不可思议了!我既惊讶又钦佩!", - "8": "这怎么…怎么可能…$明明我和我的宝可梦是最强大的…", - "9": "下次我不会输了!我们找时间再对战吧!", - "10": "天哪!你看不出我还只是个小孩子吗!$你那样全力以赴太赖了!", - "11": "你的宝可梦更棒啊!和我交换吧!", - "12": "我之前有点上头,我说了什么来着?", - "13": "啊哈哈!就是这样!$对!你已经熟悉这个世界了!" - } - }, - "lass": { - "encounter": { - "1": "我们来对战吧,好吗?", - "2": "你看起来像是个新人训练师。我们来战斗吧!", - "3": "我不认识你。来对战怎么样?", - "4": "让我们来进行一场有趣的宝可梦对战吧!", - "5": "我会向你展示如何真正使用宝可梦!", - "6": "一场认真的对战从始于认真的开场白!$你确定你准备好了吗?", - "7": "花无重开日,人无再少年。$你在对战中只有一次机会。$很快,你就只能活在回忆中了。", - "8": "你最好对我手下留情,好吗?$当然我会认真对战的!", - "9": "学校很无聊,我无事可做。$*哈欠*…我只是来对战打发时间。" - }, - "victory": { - "1": "那真是令人印象深刻!我还有很多要学习。", - "2": "我没想到你会这么轻易地打败我…", - "3": "我希望有一天,我们能再进行一场对战。", - "4": "那真是场非常有趣的对战!$你让我精疲力尽了…", - "5": "你给我上了一课!你真是太棒了!", - "6": "说真的,我输了。$这,怎么说,真的好难过,但你也真的很厉害。", - "7": "我不需要像这样的记忆。删除记忆中…", - "8": "嘿!我告诉过你要对我手下留情!$不过,当你认真的时候,你真的很酷。", - "9": "实际上,我开始厌倦对战了…$一定有新的事情可以做…" - } - }, - "breeder": { - "encounter": { - "1": "听话的宝可梦,自私的宝可梦…$宝可梦有独特的性格呢。", - "2": "尽管我出生贫寒,但我的宝可梦培养的很好。", - "3": "嗯,你有没有管教你的宝可梦?$过度溺爱是不好的。" - }, - "victory": { - "1": "对每个宝可梦因材施教是很重要的。", - "2": "不像一无是处的我…这些宝可梦都很优秀。", - "3": "过度的赞美会宠坏宝可梦和人。" - }, - "defeat": { - "1": "即使输了,也不应该对你的宝可梦发火。", - "2": "相当好的宝可梦,对吧?我很会养东西。", - "3": "无论你多么爱你的宝可梦,$你仍要在它没做好时管教它们。" - } - }, - "breeder_female": { - "encounter": { - "1": "宝可梦永远不会背叛你。$它们会回报你对它们的爱。", - "2": "要我教教你训练优秀宝可梦的技巧吗?", - "3": "特别的宝可梦有特别的培育技巧。" - }, - "victory": { - "1": "呃…事情不应该是这样的。$我是不是用错了能量方块?", - "2": "这怎么会发生在我的宝可梦身上…$你给你的宝可梦喂了什么?", - "3": "如果我输了,我告诉你我只是在消磨时间。$你根本不会伤害到我的自尊心。" - }, - "defeat": { - "1": "这证明了我的宝可梦已经接受了我的爱。", - "2": "训出好宝可梦的真正技巧是捉到好的宝可梦。", - "3": "宝可梦的强弱取决于你的饲养方式。" - } - }, - "fisherman": { - "encounter": { - "1": "啊!你让我错过了一次咬钩!$你打算怎么办?", - "2": "走开!你吓跑了宝可梦!", - "3": "让我看看你能否赢得胜利!" - }, - "victory": { - "1": "算了吧。", - "2": "下一次,我将卷土重来,凯旋而归!", - "3": "我想这次我低估了海流。" - } - }, - "fisherman_female": { - "encounter": { - "1": "哇!我钓到了一条大鱼!", - "2": "线已收好,准备提竿!", - "3": "准备制造波浪!" - }, - "victory": { - "1": "我会带着更强大的鱼钩回来。", - "2": "下次我会赢得胜利。", - "3": "我只是在为回归磨利我的鱼钩!" - } - }, - "swimmer": { - "encounter": { - "1": "是时候潜水了!", - "2": "让我们一起乘风破浪,赢得胜利!", - "3": "该一鸣惊人了!" - }, - "victory": { - "1": "沉浸在失败中!", - "2": "失败的波浪!", - "3": "后浪死在沙滩上,我猜。" - } - }, - "backpacker": { - "encounter": { - "1": "收拾行李,开始游戏!", - "2": "让我看看你是否能跟上!", - "3": "全副武装,挑战者!", - "4": "我花了20年时间试图找到自己……但我在哪里?" - }, - "victory": { - "1": "这次绊倒了!", - "2": "哦,我觉得我迷路了。", - "3": "死路!", - "4": "等一下!嘿!你不知道我是谁吗?" - } - }, - "ace_trainer": { - "encounter": { - "1": "你看起来挺自信的。", - "2": "你的宝可梦…… 让我看看……", - "3": "因为我是王牌训练师,人们认为我很强。", - "4": "你知道成为王牌训练师需要什么吗?" - }, - "victory": { - "1": "是的…… 你的宝可梦很棒……", - "2": "什么?!我是战斗天才啊!", - "3": "理所应当,你才是主角!", - "4": "好好好!你可以成为王牌训练师!" - }, - "defeat": { - "1": "我将把我的身体和灵魂全都奉献给宝可梦对战!", - "2": "一切都在我的预料之中… \n没有什么好惊讶的…", - "3": "我觉得我长大后有点玻璃心,$你太压力我我会跨的……", - "4": "我当然很强大,不会输。$而且重要的是我要优雅地赢。" - } - }, - "parasol_lady": { - "encounter": { - "1": "是时候用优雅和从容来为战斗添彩了!" - }, - "victory": { - "1": "我的优雅依然完好无损!" - } - }, - "twins": { - "encounter": { - "1": "准备好咯,因为我们联手,\n麻烦双倍!", - "2": "两颗心,一条绳$让我们看看你能否跟上我们双胞胎的力量!", - "3": "希望你准备好了面对双倍的麻烦,$因为我们即将燃起来啦!" - }, - "victory": { - "1": "虽然我们在这一轮输了,$但我们的羁绊依然坚不可摧!", - "2": "我们的双胞胎精神,才不会就此熄灭。", - "3": "我们会作为充满活力的二人组,$卷土重来,变得更强!" - }, - "defeat": { - "1": "双胞胎的力量至高无上!", - "2": "两颗心,一起赢!", - "3": "笑容成双,共舞成双!" - } - }, - "cyclist": { - "encounter": { - "1": "准备好在我后面吃土吧!", - "2": "挑战者,准备好!我要把你打的落花流水!", - "3": "全速前进,让我看看你能不能跟的上!" - }, - "victory": { - "1": "轮子可能不转了,但我的决心没有停下。", - "2": "被超越了!", - "3": "通往胜利的道路还有许多曲折等待探索。" - } - }, - "black_belt": { - "encounter": { - "1": "我赞扬你挑战我的勇气!$因为我是踢力最强的人!", - "2": "哦,我明白了。你想被切成碎片吗?$或者你更喜欢当个沙袋?" - }, - "victory": { - "1": "哦。是宝可梦在战斗。$我强大的踢击一点忙都没帮上。", - "2": "嗯…如果我无论如何都会输,我希望能被彻底打败。" - } - }, - "battle_girl": { - "encounter": { - "1": "你不必试图勾引我。你可以输给我。" - }, - "victory": { - "1": "很难说再见,但我们快没时间了……" - } - }, - "hiker": { - "encounter": { - "1": "人到中年后,我的身体和我爬过的山一样强壮!", - "2": "我从父母那里遗传了这副魁梧的身材…$就像一座活生生的山脉…" - }, - "victory": { - "1": "至少在BMI方面我不能输!", - "2": "这还不够……永远不够。$我的坏胆固醇还不够高……" - } - }, - "ranger": { - "encounter": { - "1": "当我身处大自然中,其他事情都不重要了。", - "2": "如果我生活中没有大自然,有时就会突然感到焦虑。" - }, - "victory": { - "1": "无论我是赢是输,\n对广阔的大自然来说并不重要……", - "2": "与城市生活的窒息感相比,\n这种事情微不足道。" - }, - "defeat": { - "1": "我赢了。但与浩瀚的大自然相比,\n胜利算不了什么…", - "2": "与我的焦虑症相比,我觉得你也不会怎样…" - } - }, - "scientist": { - "encounter": { - "1": "我的研究将引导这个世界走向和平与欢乐。" - }, - "victory": { - "1": "我是个天才…我不应该输给你这样的人…" - } - }, - "school_kid": { - "encounter": { - "1": "……嘿嘿。我对计算和分析很有信心。", - "2": "我正在尽可能地积累经验,$因为我希望有一天能成为道馆馆主。" - }, - "victory": { - "1": "哦…计算和分析也许和个例不太匹配呀…", - "2": "我想,即使是艰难困苦的经历,也有存在的意义。" - } - }, - "artist": { - "encounter": { - "1": "我以前很受欢迎,但现在已经彻底过气了。" - }, - "victory": { - "1": "随着时代的变迁,价值观也在变化。$我意识到这一点已经太晚了。" - } - }, - "guitarist": { - "encounter": { - "1": "当我弹奏着走向胜利的旋律时,$准备好感受失败的节奏吧!" - }, - "victory": { - "1": "暂时沉默了,但我不屈的旋律将继续演奏。" - } - }, - "worker": { - "encounter": { - "1": "人们总误解我,这让我很烦。$我比大家想象的要干净得多。" - }, - "victory": { - "1": "我真的不想晒伤皮肤,所以我想在阴凉处工作。" - } - }, - "worker_female": { - "encounter": { - "1": "人们总是误解我,这让我很烦。 $我比大家想象的要干净得多。" - }, - "victory": { - "1": "我真的不想晒伤皮肤,\n所以我想在阴凉处工作。" - }, - "defeat": { - "1": "我的身体和心灵并不总同步。" - } - }, - "worker_double": { - "encounter": { - "1": "你会知道我们怎么击败你的。我们在工地训练过!" - }, - "victory": { - "1": "真奇怪…怎么会这样…我不应该被打败的。" - } - }, - "hex_maniac": { - "encounter": { - "1": "我通常只听古典音乐,但如果我输了,$我想我应该试试新时代的音乐!", - "2": "我的每一滴眼泪都让我变得更加坚强。" - }, - "victory": { - "1": "乐坛新时代的曙光就此出现了吗?", - "2": "现在我变得更强了。我随着他人怨恨而成长。" - }, - "defeat": { - "1": "“新时代”指的是二十世纪的古典作曲家,对吧?", - "2": "不要纠结于悲伤或沮丧。$你可以用悲愤来激励自己。" - } - }, - "psychic": { - "encounter": { - "1": "嘿!集中!" - }, - "victory": { - "1": "呃呃呃!" - } - }, - "officer": { - "encounter": { - "1": "准备好,因为正义即将得到伸张!", - "2": "准备好维护法律,在战场上伸张正义!" - }, - "victory": { - "1": "正义的分量比以往还要沉重……", - "2": "失败的阴影,在警局中徘徊。" - } - }, - "beauty": { - "encounter": { - "1": "我最后的战斗…我就是这么看待这场对战的…" - }, - "victory": { - "1": "很有趣…有时间再来一场最后的战斗…" - } - }, - "baker": { - "encounter": { - "1": "希望你准备好品尝失败的滋味!" - }, - "victory": { - "1": "我会卷土重来的。" - } - }, - "biker": { - "encounter": { - "1": "是时候加速,把你甩在后面了!" - }, - "victory": { - "1": "我会为下一场比赛调整状态。" - } - }, - "firebreather": { - "encounter": { - "1": "我的火焰会吞噬你!", - "2": "我的灵魂在燃烧,我要让你看看它有多滚烫!", - "3": "快来看看吧!" - }, - "victory": { - "1": "我燃成灰了…", - "2": "哟! 好烫!", - "3": "嗷! 我的鼻尖烧焦了!" - } - }, - "sailor": { - "encounter": { - "1": "伙计,如果你输了,你就得挨板子!", - "2": "来吧!这关系到我作为水手的尊严!", - "3": "你好啊!你晕船么?" - }, - "victory": { - "1": "啊,被孩子打败了。", - "2": "你的精神让我沉沦!", - "3": "好像是我晕船了…" - } - }, - "archer": { - "encounter": { - "1": "在你继续前进之前,\n让我看看你要如何和对付火箭队。", - "2": "我收到报告说你的实力与众不同,\n就让我来看看这是否属实吧。", - "3": "我是阿波罗,火箭对的干部。\n我不会对组织的敌人手软。" - }, - "victory": { - "1": "大失误……", - "2": "以我现在的实力,无法胜任我的任务……", - "3": "原……谅我,坂木。\n我竟被一名训练师打败了。" - } - }, - "ariana": { - "encounter": { - "1": "站住!我们可不能放过你!\n$这会损伤火箭对的名誉,明白吗?", - "2": "我不知道也不想知道我的所作所为正确与否…\n$我只要遵从坂木老大的指令就可以了!", - "3": "你的旅途到此为止了,我会把你狠狠扳倒!" - }, - "victory": { - "1": "切,你好强,可恶。\n$如果你加入火箭队,肯定能成为干部。", - "2": "好……好崩溃……", - "3": "嗯啊啊!这不可能!我使出全力还是输了!" - } - }, - "proton": { - "encounter": { - "1": "你想干什么?如果你要妨碍我们的事业,我可不会手下留情。", - "2": "你在这干什么?别人总说我是火箭队里最残忍和恐怖的人…\n$我强烈推荐你别来碍我们的事!", - "3": "我是兰斯,火箭队的干部。就让来扫除你对我们的阻挠。" - }, - "victory": { - "1": "我的防线崩溃了……", - "2": "你虽然这次赢了,但是这只是让火箭队的怒火继续燃烧!", - "3": "我输了…但是我不会忘记的。" - } - }, - "petrel": { - "encounter": { - "1": "哇哈哈哈,我们一直在等你。我?你不知道我是谁?是我,坂木啊。\n$伟大的坂木大人本人!哇哈哈哈!…啊?我听起来不像坂木吗?\n$我连看起来都不像?怎么会呢,我可认真的变装了!", - "2": "我是拉姆达,火箭队的干部。我不会允许你干涉我们的计划!", - "3": "火箭队干部拉姆达来会会这个入侵者!" - }, - "victory": { - "1": "好好好,我会说他在哪的", - "2": "我……我什么也做不了……坂木,请原谅我……", - "3": "不,我不能慌了神,必须通知其他人…" - } - }, - "tabitha": { - "encounter": { - "1": "呵呵呵!原来你都一路来到这里了!但你来晚了!", - "2": "呵呵呵……你终于来了?我们小瞧你了,没不过事! \n$我比你见过的所有队员都要厉害,我可不会拖延时间。\n$我会把你碾碎!", - "3": "我要让你尝尝痛苦的滋味!认命吧!" - }, - "victory": { - "1": "呵呵呵!虽然你打败了我,但你根本没机会打败老大!\n$如果你现在输了,你就不用面对那样严厉的鞭笞了!", - "2": "呵呵呵……所以,我也输了……", - "3": "啊哈!怎么会这样?像我这样的干部\n竟然输给了一个随处可见的训练师……" - } - }, - "courtney": { - "encounter": { - "1": "那个东西……你所拥有的那个东西……\n那就是……那就是我们熔岩队所寻找的东西……", - "2": "……那么……删除记忆……", - "3": "……哈……分析中……啊哈♪" - }, - "victory": { - "1": "……改变……世界。", - "2": "如预期。出乎意料。目标锁定…锁定你……完成。\n$开始……实验。材料是你…永远…啊哈……♪", - "3": "……又来了?出乎意料……我就知道。你……很有趣!……啊哈哈!♪" - } - }, - "shelly": { - "encounter": { - "1": "啊哈哈哈哈!你要插手海洋队的事?\n$你要么是绝对无畏,要么就是无知,或者两者兼有!\n$你太可爱了,太恶心了!我要把你打倒!", - "2": "怎么回事?这个小鬼头是谁?", - "3": "冷静点,耐心点。我很快就会把你击溃。" - }, - "victory": { - "1": "啊哈哈哈哈!我们意外地被人干扰了!我们别无选择。\n$不得不撤退了,但这会不是你最后一次面对海洋队!\n$我们还有其他计划!别忘了!", - "2": "啊?!我是不是对你太温柔了?!", - "3": "呃…难道在对战中你也一刻不停地在变强吗?\n$你真是个前途光明的小鬼……\n我和我的宝可梦已经没有任何力量去战斗了……\n$继续吧……准备去被水梧桐摧毁吧。" - } - }, - "matt": { - "encounter": { - "1": "嚯!哈哈哈!怎么,你是不是脑子不正常了?\n看看你,像个幕下力士!", - "2": "“哦吼!你!你真是个有趣的孩子!", - "3": "你在这里干什么?你跟踪我们了吗?" - }, - "victory": { - "1": "好吧,在老大有时间对付你之前,我来成为你的对手!", - "2": "我能感觉到!我感觉到了,没错!你身上散发出的力量!\n$更多!还想要更多!但看起来我们没时间了……", - "3": "真有趣!我就知道你会让我尽兴的!\n我期待有一天再次面对你!" - } - }, - "mars": { - "encounter": { - "1": "我是伙星,银河队的顶级干部之一。", - "2": "银河队对未来的愿景坚定不移。\n反对者将被无情地粉碎!", - "3": "“紧张吗?你是该感到紧张了!" - }, - "victory": { - "1": "这不可能!我怎么会输?!", - "2": "你很有本事,我承认。", - "3": "输了……犯了一个代价高昂的大错。" - } - }, - "jupiter": { - "encounter": { - "1": "岁星,银河队干部,为您效劳。", - "2": "抵抗是徒劳的。银河队必将获胜!", - "3": "你在发抖啊……已经害怕了吗?" - }, - "victory": { - "1": "不会吧……我输了?!", - "2": "厉害,你胆子真大!", - "3": "输成这样……真丢人。" - } - }, - "saturn": { - "encounter": { - "1": "我是镇星,银河队的干部。", - "2": "我们的使命是绝对的,任何阻碍都将被消灭!", - "3": "我从你的眼中看到的是恐惧吗?" - }, - "victory": { - "1": "不可能……被你打败了?!", - "2": "你证明了自己是一个值得尊敬的对手。", - "3": "失败的苦涩……难以接受……。" - } - }, - "zinzolin": { - "encounter": { - "1": "你可能会对等离子队构成威胁,所以我们现在就消灭你!", - "2": "哦,天哪……我没想到要在这么冷的天气里战斗!", - "3": "能走到今天这一步,你真是个了不起的训练师。\n但一切到此结束。" - }, - "victory": { - "1": "魁奇思大人……我让你失望了……", - "2": "好冷,我不仅发抖,还要遭罪。", - "3": "哼。你比我想象的要聪明,但还不够。" - } - }, - "rood": { - "encounter": { - "1": "你对等离子队是个威胁。我们现在不能让你离开这里!", - "2": "哦,这寒风……我从没想过我必须在这里战斗!", - "3": "能走到今天这一步,你是一位了不起的训练师,但这就是你的结局了。" - }, - "victory": { - "1": "魁奇思大人……我的任务失败了", - "2": "寒风刺骨。我瑟瑟发抖。我痛苦不堪。", - "3": "嗯,你是很有才。但是要打败等离子队还不够……!" - } - }, - "xerosic": { - "encounter": { - "1": "啊哈哈!我很乐意。\n来吧,小训练师!让我们看看你有什么本事!", - "2": "嗯……你比看上去更强大。\n我想知道你体内有多少能量。", - "3": "我一直在等你!我需要对你做一点研究!\n来吧,我们开始吧!" - }, - "victory": { - "1": "啊,你好强大啊……嗯……确实非常强大。", - "2": "叮叮叮!你成功了!\n战利品归胜利者!", - "3": "太棒了!太神奇了!\n你的技巧和勇气都无与伦比!" - } - }, - "bryony": { - "encounter": { - "1": "我是芭菈,能与你一战是我的荣幸。\n让我看看你的实力。", - "2": "令人印象深刻……你比你看上去的还要强大。\n让我们看看你真正的实力。", - "3": "我预料到了你的到来。\n是时候进行一个小实验了,我们开始吧?" - }, - "victory": { - "1": "你很强大。哦,嗯嗯!确实非常强大", - "2": "叮叮叮!你做得很好。胜利属于你。", - "3": "太棒了!了不起!你的技巧和勇气值得称赞。" - } - }, - "rocket_grunt": { - "encounter": { - "1": "你要有麻烦了!", - "2": "我们要干大事了!\n闪一边去,小子!", - "3": "把你的宝可梦交过来,\n不然就尝尝火箭队的厉害!", - "4": "你准备好感受火箭队真正的恐怖了吗!", - "5": "喂,小子!俺可是火箭队滴!" - }, - "victory": { - "1": "好讨厌的感觉啊!", - "2": "哎呀!不小心丢掉电梯钥匙啦!", - "3": "我搞砸了。", - "4": "我的伙计们不会放过你……!", - "5": "你说啥?俺们火箭队要玩完了?" - } - }, - "magma_grunt": { - "encounter": { - "1": "如果你挡在熔岩队路上,那就别指望我们手下留情!", - "2": "你最好别妨碍我们的计划!\n我们会让世界变得更美好!", - "3": "少碍事!熔岩队没时间理你这样的小孩!", - "4": "你有棉花糖没?我来给你好好烤烤!", - "5": "我们会利用火山的力量!\n它马上要…爆发了!懂吗?嘿嘿嘿……" - }, - "victory": { - "1": "哈?我输了?!", - "2": "我怎么会输!我为了训练饭都不吃了!", - "3": "不会吧,不就是一个小孩!", - "4": "呃啊…我得赶快逃回基地…", - "5": "你打败我了…你觉得老大会扣我工资吗?" - } - }, - "aqua_grunt": { - "encounter": { - "1": "即使是小孩,如果要和海洋队作对,也别指望我们手下留情!", - "2": "嚯…你好大的胆子,敢惹我们海洋队!", - "3": "不仅是我的水系宝可梦,整片大海即将淹没你!", - "4": "我们海洋队,是为了大义!", - "5": "准备好被我的…呃…我宝可梦的海流冲走吧!" - }, - "victory": { - "1": "你在开玩笑吧?", - "2": "害,没想到这种小屁孩也要管我的闲事!", - "3": "我输了?看来我得自己游回基地了。", - "4": "不是吧,怎么会,老大要生气了……", - "5": "你打败了我…老大不会要让我上跳板吧……" - } - }, - "galactic_grunt": { - "encounter": { - "1": "别惹银河队!", - "2": "见识下我们的科技,和我们所设想的未来!", - "3": "以银河队之名,我会扫清一切挡路的人!", - "4": "准备输的一败涂地吧!", - "5": "希望你做好被宇宙力量碾压的准备。" - }, - "victory": { - "1": "停机了…", - "2": "从长远来看,这次的挫折不用在意。", - "3": "小失败不会影响我们的宏图伟业!", - "4": "咋回事!?", - "5": "个人记录:提升对战水平,优先级,高……" - } - }, - "plasma_grunt": { - "encounter": { - "1": "异端不共戴天!", - "2": "要是我赢了你!就把你的宝可梦放生!", - "3": "要是敢和等离子队作对,我来好好关照你!", - "4": "等离子队会从你们这种自私的人手里解放宝可梦!", - "5": "我们的发型帅的一批,而我们的战斗水平呢,\n马上让你见识一下。" - }, - "victory": { - "1": "等离子子子子子子!", - "2": "我怎么会输……", - "3": "…没用的家伙!我得去偷个厉害点的宝可梦!", - "4": "伟大的事业总会被人阻挠…", - "5": "烂完了…烂烂烂烂烂!等离子队烂了!\n说短点就是,等烂子队!" - } - }, - "flare_grunt": { - "encounter": { - "1": "你的宝可梦无法与闪焰队的优雅相提并论", - "2": "带个墨镜吧,别被我闪瞎狗眼了!", - "3": "闪焰队将净化这个不完美的世界!", - "4": "准备面对闪焰队的美!", - "5": "时尚对我们来说最重要!" - }, - "victory": { - "1": "我的未来看起来并不明亮…", - "2": "这战斗比我想的更难搞,我得重头训练了。", - "3": "啊啊?我输了?!", - "4": "就算是在失败当中,闪焰队依旧优雅动人!", - "5": "你虽然打败了我,但是我输的也这么潇洒!" - } - }, - "aether_grunt": { - "encounter": { - "1": "我会用尽全力消灭你!", - "2": "我才不管你是不是小孩!\n只要和我们作对,我就把你打飞!", - "3": "上头要我拦下所有训练师,无论是谁!", - "4": "给你展现一下以太乐园的力量!", - "5": "既然你已经触达到了以太基金会的黑暗,\n那我要请你就此消失了。" - }, - "victory": { - "1": "哼!看来你有点实力。", - "2": "这什么情况!什么情况!", - "3": "啊!你怎么这么强!我这下可没法阻止你!", - "4": "嗯……看来我输了……", - "5": "我惊掉大牙了……" - } - }, - "faba": { - "encounter": { - "1": "我,分部长扎奥博, \n给你见识下现实世界的残酷吧!", - "2": "堂堂以太乐园的最后防线,\n我扎奥博竟然要跟个毛头小子对战。", - "3": "我,扎奥博,以太基金会分部长。\n世上唯一,无可替代!" - }, - "victory": { - "1": "哎咿呀!", - "2": "怎……怎么可能!这孩子!", - "3": "这就是……这就是为啥我讨厌小孩子!" - } - }, - "skull_grunt": { - "encounter": { - "1": "我们并不坏,YO,我们是硬汉!", - "2": "YO!咋样!我们就这样打招呼!\n混个脸熟呗,崽子!", - "3": "咱们就是一帮对别人的宝可梦\n比较感兴趣的哥们和姐们!", - "4": "别装B了,你有我们拽吗,老弟?", - "5": "骷髅队在此!没钱住房子!\n天天找乐子!青春混到死!" - }, - "victory": { - "1": "哈?这就完了?", - "2": "该逃跑了YO!闪一边去YO!", - "3": "你这种弱鸡宝可梦反正我们也不要!", - "4": "啥!? 这小屁孩也太牛B了!", - "5": "MAN!我能说什么,\n我的人生比宝可梦还烂。" - } - }, - "plumeria": { - "encounter": { - "1": " …哼嗯,你看起来也没啥特别的。", - "2": "这帮呆子对付你也花了太长时间了吧……", - "3": "要是惹了骷髅队的人!我就不和你开玩笑了!" - }, - "victory": { - "1": "哼嗯!你很强,我承认。", - "2": "哼,你是挺强的。现在我知道\n为啥那帮手下要花那么久对付一个小孩了。", - "3": "哼嗯!看来我得承认我输了。" - } - }, - "macro_grunt": { - "encounter": { - "1": "你的对战生涯到此为止了。", - "2": "你是一名训练师吧\n你没有干涉我们工作的权力!", - "3": "我是马洛科蒙集团的,要买马洛科蒙人寿保险吗。" - }, - "victory": { - "1": "除了礼貌地撤退我似乎别无选择…", - "2": "没法留住我的零花钱了,我又要财政赤字了…", - "3": "没人能比马洛科蒙集团的我们工作更卷!" - } - }, - "oleana": { - "encounter": { - "1": "我不会让你方案洛兹先生的计划!", - "2": "看来你打倒了所有我安排的训练师,本身也没对他们有啥期待…", - "3": "为了总裁!我不会输的!" - }, - "victory": { - "1": "*叹气*我赢不了。\n奥利薇,你真是个没用的女人", - "2": "呃啊!不可饶恕...我在想什么。\n走到这里的训练师果然不会轻易屈服!", - "3": "*叹气*奥利薇累累了……" - } - }, - "rocket_boss_giovanni_1": { - "encounter": { - "1": "我不得不说,能来到这里,你的确很不简单!" - }, - "victory": { - "1": "什么!这不可能!" - }, - "defeat": { - "1": "记住我的话。无法衡量自己的力量,说明你还是个孩子。" - } - }, - "rocket_boss_giovanni_2": { - "encounter": { - "1": "我的老伙计还需要我…你要挡我的路吗?" - }, - "victory": { - "1": "这怎么可能…?\n火箭队的梦想…就这么成为泡影了…" - }, - "defeat": { - "1": "火箭队会重生,而我会统治世界!" - } - }, - "magma_boss_maxie_1": { - "encounter": { - "1": "我会亲手埋葬你,希望你能喜欢!" - }, - "victory": { - "1": "啊!你…很厉害…我落后了…一点…" - }, - "defeat": { - "1": "熔岩队必胜!" - } - }, - "magma_boss_maxie_2": { - "encounter": { - "1": "你是我实现目标最后的障碍。\n准备好迎接我最强的一击吧!哈哈哈哈!" - }, - "victory": { - "1": "这…这不…呃" - }, - "defeat": { - "1": "现在…我要把这个星球变成人类的理想国度!" - } - }, - "aqua_boss_archie_1": { - "encounter": { - "1": "我是海洋队的老大,所以,你的路大概走到头了。" - }, - "victory": { - "1": "下次再见吧。我会记住你的脸的。" - }, - "defeat": { - "1": "天才!我的队伍不会再退缩了!" - } - }, - "aqua_boss_archie_2": { - "encounter": { - "1": "我等这一天很久了。\n这就是我的真实力量!" - }, - "victory": { - "1": "果然很强……啊!" - }, - "defeat": { - "1": "我会让这世界上的一切回归到最初的纯净状态!!" - } - }, - "galactic_boss_cyrus_1": { - "encounter": { - "1": "但在这之前,让我见识见识你那敢向银河队叫板的实力吧。" - }, - "victory": { - "1": "有意思,简直太有意思了。" - }, - "defeat": { - "1": "我要创造我的新世界…" - } - }, - "galactic_boss_cyrus_2": { - "encounter": { - "1": "是啊,我和你还真是有缘呢。\n不过,这段孽缘…就让我在此斩断吧!" - }, - "victory": { - "1": "怎么可能!怎么可能!怎么可能!" - }, - "defeat": { - "1": "永别了。" - } - }, - "plasma_boss_ghetsis_1": { - "encounter": { - "1": "无论是谁做了什么!都无法阻止我!" - }, - "victory": { - "1": "怎么回事?我可是建立了等离子队的完美的人啊!\n是要改变世界的完美的统治者!" - }, - "defeat": { - "1": "我是坐拥世界的完美统治者!哇哈哈哈!" - } - }, - "plasma_boss_ghetsis_2": { - "encounter": { - "1": "来吧!让我看看你彻底绝望时的那张脸!" - }, - "victory": { - "1": "不!我的伟大目标!我要完全支配世界啊!" - }, - "defeat": { - "1": "酋雷姆!融合吧!" - } - }, - "flare_boss_lysandre_1": { - "encounter": { - "1": "你想要阻止我?在对战中展示给我看吧!" - }, - "victory": { - "1": "看来你的确是想要阻止我。但是,先等一下。" - }, - "defeat": { - "1": "宝可梦…不该存在。" - } - }, - "flare_boss_lysandre_2": { - "encounter": { - "1": "你我的未来…究竟哪个才正确,\n就让我们来问问各自的宝可梦吧!" - }, - "victory": { - "1": "哇啊啊啊!" - }, - "defeat": { - "1": "没有远见的蠢货会继续玷污这个美丽的世界。" - } - }, - "aether_boss_lusamine_1": { - "encounter": { - "1": "你吓到我可爱的异兽了!我要让你先闭嘴!" - }, - "victory": { - "1": "你…你怎么这么不听话!" - }, - "defeat": { - "1": "哼嗯…" - } - }, - "aether_boss_lusamine_2": { - "encounter": { - "1": "为什么你要一直妨碍我!\n我受够你了,完完全全受够了! \n$不用说废话了…有了虚吾伊德的力量。\n我会让你明白,你来这里是有多么错误!" - }, - "victory": { - "1": "呃呃啊啊啊啊呜呜呜啊啊!" - }, - "defeat": { - "1": "我只要和我可爱的异兽在一起就好了!你们怎么样都无所谓了!" - } - }, - "skull_boss_guzma_1": { - "encounter": { - "1": "摧毁,摧毁,\n不管摧毁几次也从不手软\n$惹人厌的古兹马大爷在此。" - }, - "victory": { - "1": "切,我一定要找时间干掉你!" - }, - "defeat": { - "1": "大老远跑来就这,昂?" - } - }, - "skull_boss_guzma_2": { - "encounter": { - "1": "不管谁与我作对,我都会干掉他们!\n$这就是大坏蛋古兹马的全部!" - }, - "victory": { - "1": "古兹马!!你在干什么啊!!!" - }, - "defeat": { - "1": "你们真够蠢的!" - } - }, - "macro_boss_rose_1": { - "encounter": { - "1": "我必须为所有人提供无限的能源,实现繁荣。$这是我的目的,我的责任,我的使命!" - }, - "victory": { - "1": "你还是没有明白,训练师\n$我们…不,我要推动历史的进程啊!" - }, - "defeat": { - "1": "你完全不理解!" - } - }, - "macro_boss_rose_2": { - "encounter": { - "1": "我致力于解决伽勒尔的能源问题\n——当然也是全世界的能源问题。\n$我的经验与成果,造就了马洛科蒙集团,证明了我的正确与成功!\n$就算输了,我也不会改变主意的……" - }, - "victory": { - "1": "我都忘记宝可梦对战的魅力了!我太久没有着手对战了…\n$这的确让人很满足,我接受我的失败!" - }, - "defeat": { - "1": "我承认我做的事情非常渗人,我也不指望你能理解。\n$但我必须为伽勒尔地区提供无限的能源,确保永久的繁荣。" - } - }, - "brock": { - "encounter": { - "1": "我对岩石属性宝可梦的专精会击败你!来吧!", - "2": "我磐石般的意志将压倒你!", - "3": "让我展示给你看看,我宝可梦真正的力量!" - }, - "victory": { - "1": "你宝可梦的力量战胜了我坚如磐石的防御!", - "2": "世界很大!很高兴有机会和你战斗。", - "3": "也许我应该回去追寻我成为宝可梦饲养员的梦想……" - }, - "defeat": { - "1": "最好的进攻就是坚固的防守!$那是我做事的方式!", - "2": "下次来和我一起研究岩石属性,$更好地了解如何与它们对战!", - "3": "哈哈,我在各地的旅行有所回报了!" - } - }, - "misty": { - "encounter": { - "1": "我的战策就是使用水属性宝可梦全面进攻!", - "2": "嗨,我会让你见识我的水属性宝可梦的力量!", - "3": "我的梦想是踏上旅程,与强大的训练师战斗……$你能满足我吗?" - }, - "victory": { - "1": "你真的很强……我承认,你有技术的……", - "2": "哼……你知道你只是运气好,对吧?!", - "3": "哇,你太过分了!不敢相信你打败我了!" - }, - "defeat": { - "1": "强大的小霞对你来说,太过分了吗?", - "2": "我希望你看到了我宝可梦优雅的游泳技巧!", - "3": "你的宝可梦无法匹敌我的心腹和骄傲!" - } - }, - "lt_surge": { - "encounter": { - "1": "我的电属性宝可梦在战争中救了我!$我来给你展示一下!", - "2": "立正!我要电到你投降!", - "3": "我会像对待敌军一样,狠狠电你!" - }, - "victory": { - "1": "哇!你的队伍有真家伙,小子!", - "2": "啊啊,你很强!连我的电击技巧都输给了你。", - "3": "这失败真是把我给电麻了!" - }, - "defeat": { - "1": "哦耶!我的电属性宝可梦是世界第一!", - "2": "哈哈哈!真是一场电动人心的战斗,小子!", - "3": "宝可梦对战等于战争,$我向你展示了军队中的格斗技巧!" - } - }, - "erika": { - "encounter": { - "1": "啊,这里天气真好…$哦,对战?那好吧。", - "2": "我在宝可梦对战上的造诣,$可以与我的插花技巧相媲美。", - "3": "哦,希望我宝可梦的宜人香气\n不会再让我睡着…", - "4": "看看花园里的花朵,如此令人心旷神怡。" - }, - "victory": { - "1": "哦!我认输啦~", - "2": "这场比赛非常愉快。", - "3": "啊,看来我输了…", - "4": "哦,我的天哪。" - }, - "defeat": { - "1": "我怕我会打瞌睡…", - "2": "哦,我天。看来我的草属性宝可梦击败了你。", - "3": "那场战斗是如此令人心旷神怡。", - "4": "哦…这就完啦?" - } - }, - "janine": { - "encounter": { - "1": "我正在掌握毒属性攻击的艺术。$今天我来和你过过招!", - "2": "父亲相信我能独当一面。$我来证明他说的对!", - "3": "我的忍术,仅次于我的父亲!$你能跟的上吗?" - }, - "victory": { - "1": "就算现在,我仍然需要继续训练…我明白了。", - "2": "你的战斗技巧,超过了我。", - "3": "我要好好努力提高我的技术。" - }, - "defeat": { - "1": "呵呵…毒液耗尽了你所有的力量。", - "2": "哈!你根本无法抵挡我卓越的忍技!", - "3": "我没有辜负父亲对我的信任。" - } - }, - "sabrina": { - "encounter": { - "1": "我的超能力预见了你的到来!", - "2": "我不喜欢战斗,但如果你想,$我会展示我的实力!", - "3": "我能感觉到你的雄心壮志。$我倒要看看你是不是虚有其表。" - }, - "victory": { - "1": "你的力量……远远超出了我的预知……", - "2": "我没有准确预测到你的实力。", - "3": "即使我强大的超能力也无法感知到你这样强大的人。" - }, - "defeat": { - "1": "这场胜利……和我看到的未来一样啊!", - "2": "也许我预感到有强大实力的人,是另一个……", - "3": "在你奋不顾身投入战斗之前,\n磨练你的能力。$如果你这样做,你才未来可期……" - } - }, - "blaine": { - "encounter": { - "1": "哈!希望你带了烧伤治疗药!", - "2": "我火热的宝可梦将所有挑战者都焚烧殆尽!", - "3": "准备好玩火吧!" - }, - "victory": { - "1": "我已经焚烧殆尽了!甚至连灰烬都没有留下!", - "2": "我没有把火焰煽得足够高吗?", - "3": "我燃尽了……但这让我进步的动力燃烧得更旺了!" - }, - "defeat": { - "1": "我的熊熊烈火无法被扑灭!", - "2": "我的宝可梦因这次胜利而变得更加强大!", - "3": "哈!我的激情燃得比你的更热烈!" - } - }, - "giovanni": { - "encounter": { - "1": "我,火箭队的领袖,\n会让你的世界感受到痛苦!", - "2": "我在这里的训练在我再次面对老朋友之前至关重要。", - "3": "我认为你还没有准备好迎接你即将经历的失败!" - }, - "victory": { - "1": "什么!我输了?! 我没什么可和你说的!", - "2": "哼……你永远无法理解我希望实现的目标。", - "3": "这次失败只是暂时的。$我将找准时机,让火箭队浴火重生。" - }, - "defeat": { - "1": "不知自己几斤几两,\n说明你仍然只是一个孩子。", - "2": "不要再试图干涉我。", - "3": "我希望你明白挑战我是多么愚蠢。" - } - }, - "roxanne": { - "encounter": { - "1": "您能否展示一下您是如何战斗的么?", - "2": "你可以和更多训练师战斗来学到很多东西。", - "3": "哦,被你抓到我正在用功了~$你想战斗吗?" - }, - "victory": { - "1": "哦,看来我输了。$我明白了。", - "2": "看来我在战斗方面还有更多东西要学。", - "3": "我会把今天在这里学到的东西铭记于心。" - }, - "defeat": { - "1": "从我们的对战中,我学到了很多。$希望你也是。", - "2": "我期待再次与你战斗。$希望你能运用在此学到的东西。", - "3": "我凭借我所学到的一切赢得了胜利。" - } - }, - "brawly": { - "encounter": { - "1": "哦,伙计,挑战者!$让我看看你的能耐!", - "2": "你看起来很厉害嘛。$来对战吧!", - "3": "是时候掀起风暴了!$我们上吧!" - }, - "victory": { - "1": "哦哇,你把我冲走了!", - "2": "你驾驭了我的海浪,把我打败了!", - "3": "我觉得我就像是在武斗洞窟里迷路了!" - }, - "defeat": { - "1": "哈哈,我驾驭了大浪!$有时间再挑战我吧。", - "2": "再和我一起冲浪吧!", - "3": "就像潮水的涨落,\n我希望你也能再来挑战我。" - } - }, - "wattson": { - "encounter": { - "1": "是时候被电击了!$哈哈哈!", - "2": "我要让火星子飞蹦!$哈哈哈!", - "3": "我希望你带了麻痹药!$哇哈哈哈!" - }, - "victory": { - "1": "看来我的电量用完了!$哇哈哈哈!", - "2": "你完全接地了是吧!$哇哈哈哈!", - "3": "谢谢你给我电了一下!$哇哈哈哈!" - }, - "defeat": { - "1": "电充充满,有时间再挑战我吧!$哇哈哈哈!", - "2": "我希望你觉得我们的战斗激情似电!$哇哈哈哈!", - "3": "你没想到我赢了吧?$哇哈哈哈!" - } - }, - "flannery": { - "encounter": { - "1": "很高兴见到你!等等,不对……$我要粉碎你!", - "2": "我才当道馆主没多久,\n但我会让你灰飞烟灭!", - "3": "是时候展示爷爷教给我的招式了!来对战吧!" - }, - "victory": { - "1": "你让我想起了我的爷爷……$难怪我输了。", - "2": "我是不是太努力了?$我应该放松,不能太上头了。", - "3": "失败才不会呛到我。$是时候重新点燃训练了!" - }, - "defeat": { - "1": "我希望我让祖父感到骄傲了……$有时间我们再战斗吧。", - "2": "我……我简直不敢相信我赢了!$按照自己的方式做事奏效了!", - "3": "早点用炽热的招式再来交手吧!" - } - }, - "norman": { - "encounter": { - "1": "我没想到你能一路来到这里。$我们来对战吧。", - "2": "作为道馆主,我会尽一切努力赢得胜利。$我们开始吧!", - "3": "你最好全力以赴。$对战的时候到了!" - }, - "victory": { - "1": "我输给了你……?$但规则就是规则。", - "2": "难道我不该从城都搬家吗……?", - "3": "我不敢相信。$这是一场好对战。" - }, - "defeat": { - "1": "我们都尽力了。$希望我们不久之后能再对战。", - "2": "你应该尝试挑战我的孩子。$可能会有一些收获!", - "3": "谢谢你精彩的战斗。$下次好运。" - } - }, - "winona": { - "encounter": { - "1": "我一直在天空中翱翔寻找猎物…$而你就是我的目标!", - "2": "不管战况如何,我都会和我的飞行宝可梦$以优雅的姿态获胜。来战斗吧!", - "3": "我希望你不怕高。$我们一起升上高空吧!" - }, - "victory": { - "1": "你是我见过的第一位比我更有风度的训练师。$打的非常出色。", - "2": "哦,我的飞行系宝可梦都已经坠落了!$好吧。", - "3": "尽管我倒下了,我的宝可梦将继续翱翔!" - }, - "defeat": { - "1": "我与我的飞行系宝可梦,\n将永远优雅地起舞!", - "2": "我希望你喜欢我们的演出。$我们优雅的舞蹈已经落幕。", - "3": "你愿意再来观看我们优雅的编舞吗?" - } - }, - "tate": { - "encounter": { - "1": "嘿嘿嘿…$看到我没和妹妹在一起,很惊讶么?", - "2": "我可以读懂你在想什么…$你想要战斗!", - "3": "你如何击败一个…$读懂你一举一动的人?" - }, - "victory": { - "1": "赢不了啊…$我想小南了…", - "2": "你和宝可梦之间的联系比我们更强。", - "3": "如果我和小南联手,我们会赢的。$我们可以了解彼此的想法!" - }, - "defeat": { - "1": "我和我的宝可梦无与伦比!", - "2": "如果你连我都打不过,\n你肯定也打不过小南。", - "3": "这多亏了我和小南的严格训练。$我可以与宝可梦一心同体。" - } - }, - "liza": { - "encounter": { - "1": "呵呵呵…$看到我没和哥哥一起,很惊讶吗?", - "2": "我可以读懂你渴望什么…$你想战斗,不是吗?", - "3": "你如何击败一个…$与宝可梦们一心同体的人?" - }, - "victory": { - "1": "赢不了啊…$我想小枫了…", - "2": "你和宝可梦之间的联系…$比我强。", - "3": "如果我和小枫在一起,我们会赢的。$我们甚至可以接上彼此的话!" - }, - "defeat": { - "1": "我和我的宝可梦势不可挡。", - "2": "如果你连我都打不过,\n你肯定也打不过小枫。", - "3": "这多亏了我和小枫的严格训练。$我可以与我的宝可梦一心同体。" - } - }, - "juan": { - "encounter": { - "1": "别害羞啊。$我们来战斗吧!", - "2": "啊哈哈哈,敬请期待\n我和水属性宝可梦的盛大演出!", - "3": "我就是正在逼近的风暴!$你能经受住考验吗?", - "4": "请你见证我们的表演。$由我和宝可梦共同创造的宏伟水之幻境!" - }, - "victory": { - "1": "你可能是一个能挑战米可利的天才!", - "2": "我专注于优雅,而你刻苦锻炼。$你能击败我是很正常的。", - "3": "啊哈哈哈!$好吧,这次你赢了。", - "4": "从你身上,我感受到了技巧的光辉,\n它将战胜一切。" - }, - "defeat": { - "1": "宝可梦和我创造的水之幻境,让我取得了胜利。", - "2": "啊哈哈哈,我赢了,你输了。", - "3": "要我把我的服装借给你吗?\n可能能帮到你对战啊!$啊哈哈哈,我开玩笑的!", - "4": "我是赢家!也就是说,你输了。" - } - }, - "crasher_wake": { - "encounter": { - "1": "极限! 极限! 看好了!$极限假面…就此…登场!", - "2": "极限! 极限! 极限假面!", - "3": "我是滔滔巨浪,将你冲走!" - }, - "victory": { - "1": "我真是笑得合不拢嘴啊!$哈哈哈!那真是太有趣了!", - "2": "呼哇!结束收尾了!$我该怎么说呢……$我还想再对战!我还想再继续战斗!", - "3": "啊啊啊啊啊!?" - }, - "defeat": { - "1": "耶!就是这样!", - "2": "我赢了,但我还想要更多!\n我还想再更多地战斗!", - "3": "再见!" - } - }, - "falkner": { - "encounter": { - "1": "我将向你展示华丽的飞行宝可梦真正的力量!", - "2": "风啊,伴我同行!", - "3": "爸爸!我希望你能在空中注视着我的战斗!" - }, - "victory": { - "1": "明白了……我会礼貌地退场。", - "2": "输了就是输了。你确实很强大。", - "3": "…行吧! 嗯, 我输了。" - }, - "defeat": { - "1": "爸爸!我用你珍爱的飞行宝可梦赢了……", - "2": "飞行系宝可梦才是最强的!", - "3": "感觉我正在追赶上我的父亲!" - } - }, - "nessa": { - "encounter": { - "1": "无论你的小脑瓜子在搞什么阴谋诡计,$我和我的搭档都会确保它石沉大海。", - "2": "我来这里可不是为了闲聊,\n而是为了赢!", - "3": "这是我的宝可梦给你的一点小礼物……\n我希望你能接受!" - }, - "victory": { - "1": "你和你的宝可梦太过分了……", - "2": "怎么……?这怎么可能?!", - "3": "我完全被冲走了!" - }, - "defeat": { - "1": "汹涌的海浪再次袭来!", - "2": "是时候乘风破浪,取得胜利了!", - "3": "诶嘿嘿!" - } - }, - "melony": { - "encounter": { - "1": "我不会手下留情!", - "2": "好吧,我想我们应该开始了。", - "3": "我会把你冻得结结实实的!" - }, - "victory": { - "1": "你……你可厉害了,是不是?", - "2": "如果你找到玛瓜,一定要好好教训他,好吗?", - "3": "你的破冰方式有点过于直接了呢……" - }, - "defeat": { - "1": "现在你知道战斗有多残酷了吧?", - "2": "嘿!看来我又赢了!", - "3": "你是在保留实力吗?" - } - }, - "marlon": { - "encounter": { - "1": "你看起来很强!来吧!让我们开始吧!", - "2": "我的强大像大海一样无边无际。$你会被我冲走,绝对的。", - "3": "哦豁,由我来面对你!这可不得了咯!" - }, - "victory": { - "1": "你太厉害了!\n你培养了一些非常强大的宝可梦啊,$你已经掌握了训练师的精髓!", - "2": "你不仅仅是看起来,\n你是真的强,真的!$呃,我也被冲走了!", - "3": "你像凶猛的波浪一样强壮!" - }, - "defeat": { - "1": "你很强,但这还不足以动摇大海,懂?", - "2": "嘻!看来我又赢了!", - "3": "甜蜜的胜利!" - } - }, - "shauntal": { - "encounter": { - "1": "打扰了。你是挑战者,对吗?$我是四天王的幽灵系宝可梦使用者,$婉龙,我将是你的对手。", - "2": "我非常喜欢描写来到这里的训练师,\n以及他们训练的宝可梦。$我可以用你和你的宝可梦作为主题吗?", - "3": "每个与宝可梦相处的人都有故事要讲。$接下来要讲的故事是怎样的呢?" - }, - "victory": { - "1": "哇。我惊呆了!", - "2": "对…对不起!我必须先向我的宝可梦道歉……$都是因为我让你们有了不好的经历,真的很抱歉!", - "3": "你要知道,我仍然是四天王之一!" - }, - "defeat": { - "1": "额呵呵。", - "2": "给了我下一部小说的绝佳素材!", - "3": "就这样,又一篇故事来到尾声……" - } - }, - "marshal": { - "encounter": { - "1": "我的师傅,阿戴克,\n看到了你作为训练师的潜力,$对你很有兴趣。$我要来考验你——挖掘你力量的极限。\n丹田发力!", - "2": "胜利,决定性的胜利,\n正是我所求!挑战者,我来了!", - "3": "在我的心中,我寻求着成为战士的力量,\n克服自身的所有弱点!$以我的信念,取胜!" - }, - "victory": { - "1": "呼!干得好!", - "2": "不要停止战斗,追求更高的目标!", - "3": "你和你宝可梦展现的力量\n给我留下了深刻的印象……" - }, - "defeat": { - "1": "嗯…", - "2": "这真是场好战斗。", - "3": "哈啊!哈啊!嗨呀啊!" - } - }, - "cheren": { - "encounter": { - "1": "你让我想起了一位老朋友。$这让我对这场宝可梦战斗感到兴奋!", - "2": "不考虑清楚这一点,\n宝可梦对战就没有了意义。$这就是失去了和宝可梦一同战斗的意义。", - "3": "我的名字是黑连!我是道馆馆主,\n也是老师!$很高兴认识你。" - }, - "victory": { - "1": "谢谢……我又能发现自己的不足了。", - "2": "谢谢…接近理想的道路…我好像隐约看到了。", - "3": "嗯……这值得思考。" - }, - "defeat": { - "1": "作为道馆馆主,我要成为你要跨越的壁垒!", - "2": "好吧!", - "3": "正因为有宝可梦,我们才能走到这里。$为什么宝可梦会帮助我们,\n这个恐怕不仅是宝可梦与训练家…$而是生命与生命之间的问题。" - } - }, - "chili": { - "encounter": { - "1": "咿呀!是时候玩火了!!我是三兄弟中最强的!", - "2": "嗒哒!如火似焰的伯特——就是我\n——你接下来的对手!", - "3": "我将向你展示,\n我和我炽热的火系宝可梦的能耐!" - }, - "victory": { - "1": "被你干掉了。我……燃尽了……", - "2": "哇吼!你燃起来了!", - "3": "啊!被你干碎了!" - }, - "defeat": { - "1": "我燃起来啦!和我玩儿,你就会被烫伤!", - "2": "你要是玩儿火,就会被烫伤!", - "3": "我说,拜托,\n你的对手是我,没机会赢的!" - } - }, - "cilan": { - "encounter": { - "1": "无关个人情感…也不会有艰难的感受…$我和我的草属性宝可梦会…$呃…不管什么样的对手我们都会应战的。", - "2": "所以,呃,如果你愿意的话,我会,\n呃,尽我所能做好,呃,你知道的,你的对手。", - "3": "好吧……所以,我是天桐,\n我喜欢草属性宝可梦。" - }, - "victory": { - "1": "呃……已经结束了吗?", - "2": "…真是太意外了。你真…强。$看起来就算是伯特或寇恩都赢不了你…", - "3": "…嗯。看起来我来的…不是时候?" - }, - "defeat": { - "1": "哈?我赢了?", - "2": "我想…$我想我赢了,因为我一直在和我的兄弟伯特和寇恩竞争,\n我们都变得更强了。", - "3": "…这…这是一次非常吓人的经历呢…" - } - }, - "roark": { - "encounter": { - "1": "我需要看看你作为训练师的潜力。$还有,我要看看与你并肩作战的宝可梦的坚韧!", - "2": "来吧!这些是我的岩石系宝可梦,我的骄傲!", - "3": "岩石属性宝可梦就是最强的!", - "4": "我要看看你作为训练师的潜力。$还要看看与你并肩作战的宝可梦的坚韧!" - }, - "victory": { - "1": "什么?不可能!我强化的宝可梦们!", - "2": "……我大脑过载了。$下次邀请你参加地下的化石挖掘比赛。", - "3": "有你这种技术,赢得胜利是很正常的。", - "4": "什么?!连这也不够?", - "5": "我搞砸了。" - }, - "defeat": { - "1": "看?我为我的摇滚战斗风格感到骄傲!", - "2": "谢谢!这场战斗给了我自信,$我感觉能够打败我父亲了!", - "3": "我感觉就像我砸穿了一块顽石!" - } - }, - "morty": { - "encounter": { - "1": "只要我再多努力一点,我就能看到我遇到传说中的宝可梦的未来!$你会帮助我达到那个水平!", - "2": "据说,彩虹色的宝可梦会\n出现在真正强大的训练师面前。 $我一直相信着这个美丽的传说,\n所以,从出生开始,\n就在这里进行着秘密的修行。$因为这样,其他人看不到的东西\n我也能够看得到…$我看到的,是那个将传说中的宝可梦\n召唤到这片大地上的人的影子。$我一直相信,那就是我自己!\n希望你也能助我一臂之力!", - "3": "无论你相信还是不相信,神秘的力量确实存在。", - "4": "你可以见证我训练的成果。", - "5": "你必须让你与宝可梦的灵魂合二为一。你能做到吗?", - "6": "嘿,你想成为我训练的一部分吗?" - }, - "victory": { - "1": "我还不够好……", - "2": "我明白了…你的旅程…去了遥远的地方,你见过的比我多得多。$我羡慕你…", - "3": "这怎么可能……", - "4": "我认为我们的潜力没什么不同。$但是,我觉得你并不简单,似乎还有什么……", - "5": "我想我需要更多的训练。", - "6": "那太遗憾了" - }, - "defeat": { - "1": "我又向前迈进了一步。", - "2": "呵呵呵……", - "3": "什…么?!那还不够?", - "4": "我感觉就像我砸穿了一块顽石!", - "5": "哈哈哈啊!", - "6": "我知道我会赢!" - } - }, - "crispin": { - "encounter": { - "1": "我想赢,所以接下来我正要赢!", - "2": "我想对战就对战!懂吗!就应该这样!" - }, - "victory": { - "1": "我想赢……但我还是输了!", - "2": "我输了……因为我赢不了!" - }, - "defeat": { - "1": "嘿,等一下。我是不是赢了?$我觉得我赢了!太满足了!", - "2": "哇哦!那太棒了!" - } - }, - "amarys": { - "encounter": { - "1": "我想帮助某个人。因此,我不能输。$…我们的战斗现在开始。" - }, - "victory": { - "1": "我还不够,我明白了。" - }, - "defeat": { - "1": "胜利属于我。打得好。" - } - }, - "lacey": { - "encounter": { - "1": "我将用我平时的队伍\n作为四天王的一员面对你。" - }, - "victory": { - "1": "打得真好呀~" - }, - "defeat": { - "1": "让我们为你宝可梦的努力给予热烈的掌声!" - } - }, - "drayton": { - "encounter": { - "1": "哥们,我喜欢椅子。\n你喜欢椅子吗?简直是救星。$我不明白为什么大家不一直坐着。\n站着多累人!" - }, - "victory": { - "1": "我早该想到的!" - }, - "defeat": { - "1": "嘿嘿嘿!别介意我,\n我只是在这里小赢一下。$如果你不开心,我懂,\n但别因为我对乌栗发火,OK?" - } - }, - "ramos": { - "encounter": { - "1": "我用那些强壮的植物\n盖出来的游乐场精彩吗?$它们的力量象征着我这个园丁兼道馆馆主的实力,\n你真的确定能够与之抗衡吗?" - }, - "victory": { - "1": "你信任你的宝可梦,\n它们也信任你…不错的战斗,小豆芽。" - }, - "defeat": { - "1": "呵呵呵…确实,\n脆弱的小草甚至能穿透混凝土。" - } - }, - "viola": { - "encounter": { - "1": "败阵时的后悔,胜利的瞬间…$都是最棒的影象!很好呀,很好呀!$那么来吧!", - "2": "我的镜头总会聚焦在胜利上,\n我不会让任何事情破坏这个画面!" - }, - "victory": { - "1": "你和你的宝可梦向我展示了一个全新的镜头机位!\n很好呀,很好呀!", - "2": "你通过镜头看到的世界,\n和你与宝可梦并肩作战时看到的世界…$视角不同,即使是同一个世界看起来也完全不同。" - }, - "defeat": { - "1": "我胜利那一刻的照片,\n将是一个真正的赢家,对吧!", - "2": "是的!我拍了些很棒的照片!" - } - }, - "candice": { - "encounter": { - "1": "向小菘我挑战吗?好啊!\n我就是在等待强者$但是我也气势高昂,很强哦?", - "2": "宝可梦也好,时尚也好,恋爱也好,\n无论做什么都气势高昂!$就说到这儿吧,让你见识一下我的气势,\n要做好觉悟哦!" - }, - "victory": { - "1": "好厉害!我有点尊敬你了。", - "2": "好厉害!我有点尊敬你了!$嗯,感觉是被你的气势给压倒了。" - }, - "defeat": { - "1": "你的气势我看到了,但我还是不会输的!", - "2": "怎么样?小菘我的气势!\n宝可梦们的气势满满哦!" - } - }, - "gardenia": { - "encounter": { - "1": "你身上有一种胜利的气息。\n那么不管怎样,$这应该会是场有趣的战斗。\n让我们对战吧!" - }, - "victory": { - "1": "太棒了!你可擅长对战了,不是吗?" - }, - "defeat": { - "1": "太好了!我的宝可梦和我都很棒!" - } - }, - "aaron": { - "encounter": { - "1": "好的!让我来接受你的挑战!" - }, - "victory": { - "1": "战斗是一件深刻而复杂的事情……" - }, - "defeat": { - "1": "战胜一位四天王并不容易。" - } - }, - "cress": { - "encounter": { - "1": "没!错!你必须面对\n与我和我高贵的水属性的战斗!" - }, - "victory": { - "1": "输了?我?我不敢相信。" - }, - "defeat": { - "1": "当你的对手是我时,这是必然的结果。" - } - }, - "allister": { - "encounter": { - "1": "我是欧尼奥。$我…我来了……" - }, - "victory": { - "1": "我差点被吓得丢了面具…那真是…$哇。我可以看清你真正的实力。" - }, - "defeat": { - "1": "这真是太棒了!" - } - }, - "clay": { - "encounter": { - "1": "咳咳! 让我好等,不是吗,孩子?$好吧,是时候看看你能做到什么了!" - }, - "victory": { - "1": "真是的……我先说好,\n我可没有手下留情。" - }, - "defeat": { - "1": "最重要的是输掉的时候该怎么办。$只要你能在失败中找到教训,\n就能够不断地成长!" - } - }, - "kofu": { - "encounter": { - "1": "我会给你上一整道水系宝可梦大餐!\n但别真吃了它们!" - }, - "victory": { - "1": "吃了吗!你真是活力又新鲜啊,\n不是吗!$就是有点太鲜活了!" - }, - "defeat": { - "1": "你要再来找我,听见了吗?" - } - }, - "tulip": { - "encounter": { - "1": "请让我运用我的化妆技巧,$让你可爱的小宝可梦变得更美丽!" - }, - "victory": { - "1": "你妆点的力量宛如魔法加固,\n完全冲洗不掉啊。" - }, - "defeat": { - "1": "你知道吗,在我这行,\n那些没天赋的人往往会很快消失,$再也不会被提起。" - } - }, - "sidney": { - "encounter": { - "1": "你给我的印象不错,\n我猜这会是一场精彩的对战。$很棒!看起来真的很棒!$你和我,让我们享受一场\n只能在这里上演的战斗吧!" - }, - "victory": { - "1": "嗯,你觉得怎样?我输了!\n嗯,不过这很有趣,所以无所谓啊。" - }, - "defeat": { - "1": "别介意,OK?" - } - }, - "phoebe": { - "encounter": { - "1": "过去我在修行时得到了\n能与幽灵宝可梦亲密交流的能力。$没错,我和宝可梦之间\n有著强烈的羁绊。$那么,来试试看你有没有能力\n伤到我的宝可梦吧!" - }, - "victory": { - "1": "哦,天呀。我输了。" - }, - "defeat": { - "1": "我期待着下次再和你战斗!" - } - }, - "glacia": { - "encounter": { - "1": "我在这儿见到的尽是些\n弱不禁风的训练家和宝可梦。$你又如何呢?如果你能让我不得不用\n上全力的话就再好不过了!" - }, - "victory": { - "1": "你和你的宝可梦…\n你们的灵魂燃烧得多么热烈啊!$这股激烈的热能仿佛能征服一切。\n$难怪我的冰属性技巧也奈何不了你了。" - }, - "defeat": { - "1": "一场充满激情的战斗,确实。" - } - }, - "drake": { - "encounter": { - "1": "对于我们这些将宝可梦视为\n同伴一同战斗的训练家来说,$你知道怎样才能赢得胜利吗?\n你知道获得胜利的条件吗?$如果你不知道,\n那么你永远也无法战胜我!" - }, - "victory": { - "1": "干得漂亮,就是这样。" - }, - "defeat": { - "1": "我在这场战斗中全力以赴了!" - } - }, - "wallace": { - "encounter": { - "1": "你的气质变了,\n我能感觉到这一点。$现在,把你和你的宝可梦\n的力量展现给我看吧。$作为回礼,就由我和我的宝可梦\n演出一场水之幻影吧!" - }, - "victory": { - "1": "精彩。此刻,我能从你身上感觉到\n身为宝可梦训练家的可靠与高贵。$我真荣幸能遇到你和你的宝可梦。" - }, - "defeat": { - "1": "伟大的幻影!" - } - }, - "lorelei": { - "encounter": { - "1": "只要能让我用冰属性宝可梦,\n就绝对没人能赢得过我!\n能冻住对方可是很厉害的哦!$因为如果被冻住,你的宝可梦就无法动弹了!\n啊哈哈!你做好觉悟了吧!" - }, - "victory": { - "1": "你怎么敢!" - }, - "defeat": { - "1": "一旦你被冻结,你就什么都做不了。" - } - }, - "will": { - "encounter": { - "1": "我曾经环游世界,\n日以继夜地做着超能力宝可梦的修行之旅。$我会不断变强!没理由会在这里输掉!" - }, - "victory": { - "1": "……不会吧……" - }, - "defeat": { - "1": "就差一点。\n我想知道你缺少了什么。" - } - }, - "malva": { - "encounter": { - "1": "我的内心可是一直燃烧着呢。$燃烧着对你的怒火!" - }, - "victory": { - "1": "挑战者出色地击败了四天王之一,帕琦拉。" - }, - "defeat": { - "1": "真开心啊,能将你彻底粉碎!" - } - }, - "hala": { - "encounter": { - "1": "老哈拉让你放开嗓子!" - }, - "victory": { - "1": "我能感受到你在旅途中获得的力量。" - }, - "defeat": { - "1": "啊哈哈。多么有趣的战斗。" - } - }, - "rika": { - "encounter": { - "1": "我要对你手下留情,但……骗你的啦!$好好动脑!" - }, - "victory": { - "1": "不错,小子。" - }, - "defeat": { - "1": "啊哈哈哈哈!你真的很特别,小子!" - } - }, - "molayne": { - "encounter": { - "1": "我将队长的位置让给了我的表弟马玛内,\n但我对自己的能力很有信心。 $我的力量就像超新星一样!" - }, - "victory": { - "1": "我发现了一个有趣的训练师对手!" - }, - "defeat": { - "1": "啊哈哈。多么有趣的战斗。" - } - }, - "bruno": { - "encounter": { - "1": "我们将用势不可挡的力量磨灭你!呼哈!" - }, - "victory": { - "1": "为什么?我怎么会输?" - }, - "defeat": { - "1": "你可以随意挑战我,\n但结果永远不会改变!" - } - }, - "bugsy": { - "encounter": { - "1": "我是阿笔!\n对虫系宝可梦的熟悉不会输给任何人的!" - }, - "victory": { - "1": "哇,太棒了!\n你是个宝可梦专家!$我的研究还没有完成。\n好吧,你赢了。" - }, - "defeat": { - "1": "谢谢!多亏了我们的战斗,\n我的研究也取得了进展!" - } - }, - "koga": { - "encounter": { - "1": "哇哈哈哈哈!$宝可梦不仅仅是关于蛮力,拭目以待吧!" - }, - "victory": { - "1": "啊!你证明了自己!" - }, - "defeat": { - "1": "懂不懂要对忍者的技巧心神畏惧?" - } - }, - "bertha": { - "encounter": { - "1": "啊,让老婆婆看看你学到了什么?" - }, - "victory": { - "1": "好吧,亲爱的孩子,\n不得不说,那令人印象深刻。$你的宝可梦相信你并尽最大努力为你赢得胜利。$尽管我输了,\n我也止不住笑呢!" - }, - "defeat": { - "1": "哈哈哈!看来老婆婆我赢了!" - } - }, - "lenora": { - "encounter": { - "1": "那么,挑战者,让我来研究$你与你精心养育的宝可梦要如何战斗!" - }, - "victory": { - "1": "我关于你的理论是正确的。$你不仅仅是有天赋……你很努力!\n我向你致敬!" - }, - "defeat": { - "1": "啊哈哈!如果你输了,\n一定要分析原因,$并在下一场战斗中运用那些知识!" - } - }, - "siebold": { - "encounter": { - "1": "只要我活着,我将不断努力寻求终极美食…$以及和最强的对手战斗!" - }, - "victory": { - "1": "您的事迹,我志米铭记在心。" - }, - "defeat": { - "1": "我们的宝可梦战斗就像我灵魂的养料。\n它将让我继续前进。$这就是我将向你表示敬意的方式,\n感谢你在战斗中全力以赴!" - } - }, - "roxie": { - "encounter": { - "1": "准备好了吗!我要给你上一课!" - }, - "victory": { - "1": "够野的!你的想法比我的还要毒!" - }, - "defeat": { - "1": "嘿,拜托!认真点!\n你要加把劲啊!" - } - }, - "olivia": { - "encounter": { - "1": "没什么开场白。\n是时候和我丽姿,战斗了!" - }, - "victory": { - "1": "真的很可爱……你和你的宝可梦……" - }, - "defeat": { - "1": "嗯哼。" - } - }, - "poppy": { - "encounter": { - "1": "哦!你想和我进行宝可梦对战么?" - }, - "victory": { - "1": "呜哇?!嘛……" - }, - "defeat": { - "1": "耶!我做到了!我击~败~了~你!\n你可以来…打…复仇之战?$只要你想,随时来打复仇之战吧!" - } - }, - "agatha": { - "encounter": { - "1": "宝可梦是为战斗而生的! \n让我来告诉你什么是真正的战斗吧!" - }, - "victory": { - "1": "呵呵!你可真是了不起!" - }, - "defeat": { - "1": "额哈哈哈,真正的战斗就是该这样。" - } - }, - "flint": { - "encounter": { - "1": "希望你已经热身完毕,\n因为这里即将大爆炸!" - }, - "victory": { - "1": "不可思议!$你的动作如此火热,让我看起来温吞吞的!" - }, - "defeat": { - "1": "嗯?就这吗?\n我觉得你得再激情点。" - } - }, - "grimsley": { - "encounter": { - "1": "一无所有,\n或者,赢下所有!" - }, - "victory": { - "1": "一旦失败,\n就意味着失去一切……$下一次我要追寻胜利!" - }, - "defeat": { - "1": "如果有人赢了,\n和他对战的人就会输。" - } - }, - "caitlin": { - "encounter": { - "1": "当花儿绽开时、我便出现。\n成为你在等待的人…$你似乎同时具备实力和善意$我所寻找的是拥有卓越力量的对手…$请用出你的全力吧!" - }, - "victory": { - "1": "我和我的宝可梦学到了很多!非常感谢。" - }, - "defeat": { - "1": "我渴望以优雅的姿态取得胜利。" - } - }, - "diantha": { - "encounter": { - "1": "与你的宝可梦对战\n让你充满了未来的希望…$说真的,这让我更有活力地面对新的一天,确实如此!" - }, - "victory": { - "1": "拥有高尚灵魂的训练家和宝可梦的身姿,\n让我的心激烈地震颤…" - }, - "defeat": { - "1": "哦,太棒了!你觉得怎么样?\n我的队伍很酷吧~对吧?" - } - }, - "wikstrom": { - "encounter": { - "1": "年轻的挑战者,幸会!\n我乃是著名的钢铁之刃,公爵雁铠! $让我们开始战斗吧!预备!" - }, - "victory": { - "1": "辉煌!你与你尊贵的\n宝可梦之间的信任居然胜过了我!" - }, - "defeat": { - "1": "哦哦哦!这是怎么回事,\n我的心止不住地在震颤! $与如此有价值的对手的胜利\n让我的灵魂飞翔——我心翱翔!" - } - }, - "acerola": { - "encounter": { - "1": "对战只是找个乐子!来吧,我来会会你!" - }, - "victory": { - "1": "我……我说不出话!你是怎么做到的?!" - }, - "defeat": { - "1": "哈哈!真是吓人倒怪的胜利呀!" - } - }, - "larry_elite": { - "encounter": { - "1": "……你好,我是青木。$麻烦的是我还要兼任四天王。" - }, - "victory": { - "1": "好吧,我们翅膀下的疾风止于你这了啊…" - }, - "defeat": { - "1": "是时候和老板开会了。" - } - }, - "lance": { - "encounter": { - "1": "我一直在等你。让我来试试你有几斤几两。", - "2": "我知道你能走这么远。让我们开始吧。" - }, - "victory": { - "1": "被你拿下了啊。你太出色了!", - "2": "我从没想到会有另一个训练师打败我……$我很惊讶。" - }, - "defeat": { - "1": "就差一点。想再试一次吗?", - "2": "我没觉得你弱,别因此困扰。" - } - }, - "karen": { - "encounter": { - "1": "我是梨花,你想和我的恶属性宝可梦$来一场对决吗?", - "2": "我和你见过的那些人不一样。", - "3": "你组建了一支迷人的队伍。$我们的战斗应该会是场精彩的比赛。" - }, - "victory": { - "1": "不!我赢不了。你是怎么做到变得这么强的?", - "2": "我不会偏离我所选择的道路。", - "3": "冠军正期待与你见面。" - }, - "defeat": { - "1": "意料之中。", - "2": "嗯,还算有点意思。", - "3": "随时欢迎你来找我。" - } - }, - "milo": { - "encounter": { - "1": "看起来你显然很了解宝可梦。$这会是一场激烈的战斗!$如果我想赢,我得让我的宝可梦极巨化!" - }, - "victory": { - "1": "草的力量凋谢了…多么不可思议的挑战者!" - }, - "defeat": { - "1": "这必将让你大吃一惊。" - } - }, - "lucian": { - "encounter": { - "1": "请稍等,我正在读的书\n正要进入最精彩的部分…$英雄获得了一把神秘之剑,\n即将面临最后的考验…啊,算了。$既然你能走到这一步,\n我就不说这些了,和你战斗吧。$让我看看你是否\n能像我书中的主角一样荣耀!" - }, - "victory": { - "1": "我明白了…看来你把我逼入了绝境。" - }, - "defeat": { - "1": "我得维护我的名誉。" - } - }, - "drasna": { - "encounter": { - "1": "你很厉害吧,\n而且相当相当地厉害呢。$我很高兴,能和这样的对手交手,\n就能更好地培养宝可梦们了。" - }, - "victory": { - "1": "哎呀,就这么结束了,\n不好意思,可以的话欢迎再来。" - }, - "defeat": { - "1": "怎么会这样?" - } - }, - "kahili": { - "encounter": { - "1": "那么,既然来了……\n要不来看看今天的风更青睐谁?$是你……还是我?" - }, - "victory": { - "1": "让我这个四天王都感到沮丧,$看来你的力量货真价实。" - }, - "defeat": { - "1": "那真是一记好球!" - } - }, - "hassel": { - "encounter": { - "1": "让你亲身感受一下什么叫做猛烈的对战气息吧!" - }, - "victory": { - "1": "这次幸运之神对你微笑了,但是……$谁知道你下次还会不会这么幸运。" - }, - "defeat": { - "1": "那挺厉害的吧!" - } - }, - "blue": { - "encounter": { - "1": "能走到这里,你一定非常优秀。" - }, - "victory": { - "1": "我只输给过他,现在又是你……?$你问他是谁?哈哈哈……" - }, - "defeat": { - "1": "看吧?我的实力就是我来到这里的原因。" - } - }, - "piers": { - "encounter": { - "1": "准备好和我的队伍来个大狂欢吧!$尖钉镇,是时候嗨起来了!" - }, - "victory": { - "1": "我和我的队伍已经尽力了。$找个时间再来对战吧……" - }, - "defeat": { - "1": "我的喉咙因为呼喊而变得沙哑……$但这是一场激动人心的战斗!" - } - }, - "red": { - "encounter": { - "1": "…!" - }, - "victory": { - "1": "…?" - }, - "defeat": { - "1": "…!" - } - }, - "jasmine": { - "encounter": { - "1": "哦……你的宝可梦给人印象深刻。$我想我会享受这场战斗的。" - }, - "victory": { - "1": "你真的很强。我也得加把劲了。" - }, - "defeat": { - "1": "我从没想到会赢。" - } - }, - "lance_champion": { - "encounter": { - "1": "我依旧是冠军,所以我不会留情的。" - }, - "victory": { - "1": "这就是新冠军的崛起。" - }, - "defeat": { - "1": "我成功捍卫了冠军的头衔。" - } - }, - "steven": { - "encounter": { - "1": "告诉我…你在和宝可梦的旅途过程中看到了什么?$邂逅了那么多的训练师,\n你都会有什么样的感受呢?$在这丰饶的大地上旅行…\n有没有唤醒你内在的某种东西?$你不如就用一场对战来告诉我你心中的答案吧。$我也会和我的宝可梦用这种方式\n将我们所知道的告诉你的!" - }, - "victory": { - "1": "没想到连我这个联盟冠军\n都败在你的手上了呢…" - }, - "defeat": { - "1": "正如我所期待的。谢谢!" - } - }, - "cynthia": { - "encounter": { - "1": "我,竹兰,接受你的挑战!\n我是不会手软的!" - }, - "victory": { - "1": "无论对战多么有趣,\n它总会有结束的时候……" - }, - "defeat": { - "1": "即使你输了,\n也永远不要失去你对宝可梦的热爱。" - } - }, - "iris": { - "encounter": { - "1": "你知道吗?\n我真的很期待和强大的训练师进行认真的战斗!$我的意思是,来吧!\n到达这里的是那些渴望胜利的训练师,$他们与经历过无数艰难\n战斗的宝可梦一起战斗!$如果我和那样的人战斗,\n不仅我会变得更强,我的宝可梦也会!$我们也会更好地了解彼此!\n好!做好准备吧!$我是艾莉丝,宝可梦联盟冠军,\n我,将打败你!" - }, - "victory": { - "1": "啊……我尽力了,但我们输了……" - }, - "defeat": { - "1": "耶!我们赢了!" - } - }, - "hau": { - "encounter": { - "1": "我想知道,训练师是否会根据他们是\n来自温暖地区还是寒冷地区而以不同的方式战斗。$让我们来测试一下!" - }, - "victory": { - "1": "那太棒了!我觉得我现在有点了解你的感觉了!" - }, - "defeat": { - "1": "老铁,这才叫战斗!" - } - }, - "geeta": { - "encounter": { - "1": "我决定再试一次。$来吧…让我看看你的训练成果。" - }, - "victory": { - "1": "我期待着你的成就!" - }, - "defeat": { - "1": "怎么,这就结束了?" - } - }, - "nemona": { - "encounter": { - "1": "耶!我太兴奋了!让我们稍微放轻松!" - }, - "victory": { - "1": "好吧,太糟了,但我还是玩得很开心!$下次我一定会赢你!" - }, - "defeat": { - "1": "好吧,那是一场很棒的战斗!$肯定是会有收获的啦。" - } - }, - "leon": { - "encounter": { - "1": "来享受一段冠军时刻吧!" - }, - "victory": { - "1": "我的冠军生涯结束了……$但这是多么美好的冠军时刻啊!$谢谢你给了我最精彩的一战!" - }, - "defeat": { - "1": "名副其实的冠军时刻!" - } - }, - "whitney": { - "encounter": { - "1": "嘿!你不认为宝可梦超级可爱吗?" - }, - "victory": { - "1": "哇啊!哇啊!你太坏了!" - }, - "defeat": { - "1": "就是这样!" - } - }, - "chuck": { - "encounter": { - "1": "哈!你想挑战我?你是勇敢还是无知?" - }, - "victory": { - "1": "你很强!能不能收我为徒?" - }, - "defeat": { - "1": "搞定。你明白我比你强得多了吗?" - } - }, - "katy": { - "encounter": { - "1": "不要放松警惕,除非你想被虫丝绊倒哦!" - }, - "victory": { - "1": "我可爱的宝可梦们都像苍蝇一样坠落了!" - }, - "defeat": { - "1": "开饭啦,我可爱的彩粉蝶!" - } - }, - "pryce": { - "encounter": { - "1": "年轻不代表能获得胜利!经验才是关键。" - }, - "victory": { - "1": "无与伦比!赢得完美,试着不要忘记你现在的感受。" - }, - "defeat": { - "1": "正如我所料。" - } - }, - "clair": { - "encounter": { - "1": "你知道我是谁吗?知道还敢挑战我?" - }, - "victory": { - "1": "我想知道以你现在的水平能走多远,有趣。" - }, - "defeat": { - "1": "就是这样。" - } - }, - "maylene": { - "encounter": { - "1": "我现在要挑战你,我不会保留任何实力。$请准备好战斗!" - }, - "victory": { - "1": "是我输了…" - }, - "defeat": { - "1": "太棒了。" - } - }, - "fantina": { - "encounter": { - "1": "你来挑战吧。我会胜利。$这就是家缘市的道馆馆主。" - }, - "victory": { - "1": "你是最强的,我认输了。" - }, - "defeat": { - "1": "我非常,非常高兴!" - } - }, - "byron": { - "encounter": { - "1": "和我儿子瓢太一样的年轻人啊!$我相信培养年轻人\n关系到宝可梦光明的未来!$为此就让我来成为\n年轻人必须跨越的堡垒吧!" - }, - "victory": { - "1": "唔!我千锤百炼的宝可梦!" - }, - "defeat": { - "1": "哈哈哈哈!怎么样!我千锤百炼的宝可梦!" - } - }, - "olympia": { - "encounter": { - "1": "战斗是决定命运的古老传统。让我们开始吧!" - }, - "victory": { - "1": "创造你自己的道路。$不要让任何东西阻挡你的路、你的命运、你的未来。" - }, - "defeat": { - "1": "我们的道路现在已经清晰了。" - } - }, - "volkner": { - "encounter": { - "1": "能留到最后的训练家想必肯定是很强的…$希望你会是能让我回忆起\n宝可梦对战乐趣的训练家!" - }, - "victory": { - "1": "我输了…$你的心意,宝可梦的不顾一切。$战斗的时候就让我热血沸腾。" - }, - "defeat": { - "1": "完全没感觉…$和我希望的完全不一样!" - } - }, - "burgh": { - "encounter": { - "1": "唔…我有预感,\n只要赢了这场战斗就能画出更好的画来…$嗯!战斗充满了幻象!那么,马上开始吧。", - "2": "当然,我对我所有的宝可梦都相当骄傲! $现在…让我们马上开始吧!" - }, - "victory": { - "1": "结束了吗?我的女神抛弃我了吗?", - "2": "啊唔,输了……你还真是很强啊。" - }, - "defeat": { - "1": "唔啊……好……好美啊!", - "2": "偶尔也有一些不是很好看的胜利,$但只要努力了,\n不管怎么样的战斗,都是很美丽的。" - } - }, - "elesa": { - "encounter": { - "1": "最后一击!\n在确信这一点的时候全身会流淌过电流!$为追求这个快感,\n我要用可爱的宝可梦们让你头晕眼花。" - }, - "victory": { - "1": "本想让你头晕的,\n结果我倒反被你电到了。" - }, - "defeat": { - "1": "感觉还不够啊……下次能使出全力来吗?" - } - }, - "skyla": { - "encounter": { - "1": "终于到决战了!\n这是决定顶点的宝可梦对战吧?$我最喜欢顶点了!\n在高的地方能看到很远很远!$好了!就让我和你好好地玩一场吧!" - }, - "victory": { - "1": "和你的战斗让我更强了……谢谢。" - }, - "defeat": { - "1": "不管是赢了还是输了,战斗都能得到一些东西。" - } - }, - "brycen": { - "encounter": { - "1": "有其他的人和宝可梦在一起,$这份支持会让自己更强…\n让我来给你展示一下这样的强大吧!" - }, - "victory": { - "1": "你和你的宝可梦!配合得天衣无缝!\n华丽的友情!" - }, - "defeat": { - "1": "尝试极限!锻炼!" - } - }, - "drayden": { - "encounter": { - "1": "现在我寻求的是\n能让我看到光明未来的年轻训练家。$你有多少实力,就让我用我的经验,\n我对宝可梦倾注的爱来验证吧!" - }, - "victory": { - "1": "失败后涌现的这灼热的意志…\n该怎么说呢…" - }, - "defeat": { - "1": "啊啊啊!你的实力就这种程度吗!" - } - }, - "grant": { - "encounter": { - "1": "我只期待一件事。$通过超越彼此,\n我们找到通往更高境界的道路。" - }, - "victory": { - "1": "你是一堵我无法逾越的墙!" - }, - "defeat": { - "1": "不要放弃。\n这就是人生的真谛。$大道至简。" - } - }, - "korrina": { - "encounter": { - "1": "小女子科尔尼来大显身手啦!" - }, - "victory": { - "1": "正因为有你,\n才能让你的宝可梦进化!" - }, - "defeat": { - "1": "好劲爆的战斗呀!" - } - }, - "clemont": { - "encounter": { - "1": "哦!我很高兴我们能见面!" - }, - "victory": { - "1": "你对战斗的热情激励了我!" - }, - "defeat": { - "1": "看来我的训练师成长强化机-马克2号,\n真的起作用了!" - } - }, - "valerie": { - "encounter": { - "1": "哦,这不是一个年轻的训练师吗……\n能这样遇见你真是太好了。 $我想你已经获得了这场战斗的资格,\n作为对你努力的奖励。 $难以捉摸的妖精可能看起来像微风一样脆弱,\n像花朵一样精致,但很坚强。" - }, - "victory": { - "1": "我希望明天你也能找到一些值得会心微笑的事物……" - }, - "defeat": { - "1": "哦,天哪,这太遗憾了……" - } - }, - "wulfric": { - "encounter": { - "1": "你知道吗?\n我们都说战斗能学到东西,羁绊之类的,$但实际上,我这么做只是因为有趣。 $谁在乎那些华而不实的东西?\n我们来战斗吧!" - }, - "victory": { - "1": "杰出!我像冰山一样坚硬,但你彻底击溃了我!" - }, - "defeat": { - "1": "和我干的结果就是这样!" - } - }, - "kabu": { - "encounter": { - "1": "每个训练师和宝可梦都在努力追求胜利。$但这意味着你的对手也在努力赢得胜利。$最终,比赛是由哪一方\n能够发挥出他们真正的潜力来决定的。" - }, - "victory": { - "1": "我很高兴今天能和你战斗!" - }, - "defeat": { - "1": "这是我感觉自己的成长的好方式!" - } - }, - "bea": { - "encounter": { - "1": "你有没有一种不可动摇的精神,\n受到什么攻击都安如磐石? $就让我来试试吧?" - }, - "victory": { - "1": "我感受到了你的宝可梦\n在战斗中被你指挥时的战斗之魂。" - }, - "defeat": { - "1": "每个人都希望能有一场这样的好比赛。" - } - }, - "opal": { - "encounter": { - "1": "让我看看你和你的宝可梦的表现如何!" - }, - "victory": { - "1": "你不够粉嫩呀,\n但你是一个优秀的训练师,$还拥有着优秀的宝可梦。" - }, - "defeat": { - "1": "对你来说太惨了,我觉得。" - } - }, - "bede": { - "encounter": { - "1": "就让我来证明你有多可怜,我有多强大。" - }, - "victory": { - "1": "我懂了……好吧。其实我还没拿出全力呢。" - }, - "defeat": { - "1": "我觉得我打的不错。" - } - }, - "gordie": { - "encounter": { - "1": "好了,我们来做个了结吧!" - }, - "victory": { - "1": "我只想要挖一个洞爬进去……$好吧,现在更像是掉了进去。" - }, - "defeat": { - "1": "像往常一样战斗,胜利就会随之而来!" - } - }, - "marnie": { - "encounter": { - "1": "事实上,言而总之… \n人家自己也想当冠军呀! $所以别认为我在针对你!" - }, - "victory": { - "1": "好吧,我还是输了……\n但是我看到了很多你和你宝可梦的优点哦" - }, - "defeat": { - "1": "希望你喜欢我们的战斗策略。" - } - }, - "raihan": { - "encounter": { - "1": "我打算击败冠军,赢得锦标赛,\n并向世界证明奇巴纳大人有多强!" - }, - "victory": { - "1": "就算输了我也好帅。$真是罪孽深重啊。$看来得再来张自拍了!" - }, - "defeat": { - "1": "为了纪念此刻,来张自拍吧!" - } - }, - "brassius": { - "encounter": { - "1": "你应该准备好了吧,\n一起完成这美丽的艺术作品吧!" - }, - "victory": { - "1": "啊……前卫!" - }, - "defeat": { - "1": "我将立即开始新的创作!" - } - }, - "iono": { - "encounter": { - "1": "谁在奇述!是我奇树!\n做好准备了吗!$...$直播开始!\n今天的小挑战者有多强?$奇树不知道哦~\n让我们一起来看看吧!" - }, - "victory": { - "1": "你的闪耀如1000万伏特!朋友!" - }, - "defeat": { - "1": "奇树奇树捕获你的眼球!" - } - }, - "larry": { - "encounter": { - "1": "归根结底,普普通通就是最强。" - }, - "victory": { - "1": "哼,给我上了一道“战败”。" - }, - "defeat": { - "1": "下班打卡,走了" - } - }, - "ryme": { - "encounter": { - "1": "宝贝, 一起! \n摇滚摇到骨子里!" - }, - "victory": { - "1": "你好酷!我佩服!\n我的灵魂为你哭!" - }, - "defeat": { - "1": "再会, 宝贝!" - } - }, - "grusha": { - "encounter": { - "1": "我保证我宝可梦的力量\n会让你感到寒冷彻骨!" - }, - "victory": { - "1": "你燃烧的热情……老实说,我有点喜欢。" - }, - "defeat": { - "1": "你没有升温。" - } - }, - "marnie_elite": { - "encounter": { - "1": "你已经走到这一步了?$哼~ 看看你能不能对付我的宝可梦!", - "2": "我将全力以赴, 别觉得我会手下留情哦~" - }, - "victory": { - "1": "不敢相信…我输掉了… $但是你确实赢得好,干得漂亮捏~", - "2": "看来我还要多多学习呀,\n不过你打的很不错哦~" - }, - "defeat": { - "1": "你打得不错,但是我更胜一筹!$祝你下次好运啦~", - "2": "看来我的练习有所回报了。\n感谢一战!" - } - }, - "nessa_elite": { - "encounter": { - "1": "海流正在朝着对我有利的方向转变。$准备好被卷走了吗?", - "2": "让我们在这场战斗中掀起波澜!$我希望你做好准备!" - }, - "victory": { - "1": "你完美地渡过了这片水域......干得好!", - "2": "看来我现在无法与你匹敌。干得好!" - }, - "defeat": { - "1": "水总能找到出路。\n真是爽快的一战!", - "2": "你打得很好,\n但海洋的力量是不可阻挡的!" - } - }, - "bea_elite": { - "encounter": { - "1": "做好准备!我的斗志熊熊燃烧!", - "2": "让我们看看你是否能跟上我永不停歇的节奏!" - }, - "victory": { - "1": "你的实力......令人印象深刻。\n你真的值得这场胜利。", - "2": "我以前从未感受过这种强度。\n太棒了!" - }, - "defeat": { - "1": "我的高强度训练又带来胜利了!\n干得好!", - "2": "你有实力,但我的训练更努力。\n精彩的战斗!" - } - }, - "allister_elite": { - "encounter": { - "1": "黑暗降临...你准备好面对你的恐惧了吗?", - "2": "让我们看看你能否应对我所操控的黑暗。" - }, - "victory": { - "1": "你已经驱散了阴影......\n暂时。干得很好。", - "2": "你的光芒刺穿了我的黑暗。干得好。" - }, - "defeat": { - "1": "黑影在轻语...\n你的力量还不够。", - "2": "黑暗获胜了......\n也许下次你会看到光明。" - } - }, - "raihan_elite": { - "encounter": { - "1": "虽然没法打败丹帝夺冠,\n让我觉得很遗憾……$但是有你这家伙当对手,\b倒是也还不赖啊!", - "2": "准备好面对龙之风暴!" - }, - "victory": { - "1": "你的气势就像暴风一样,\n连我都甘拜下风了!", - "2": "你完美地驾驭了我的风暴……打得好!" - }, - "defeat": { - "1": "又一场龙之风暴袭来,又一场胜利!打得好!", - "2": "你被我的龙之风暴卷入了!祝你下次好运!" - } - }, - "alder": { - "encounter": { - "1": "准备好和合众最强的训练家交手吧!" - }, - "victory": { - "1": "精彩!简直就是天下无双!" - }, - "defeat": { - "1": "战斗结束后,我的心像是吹过了温和的风……\n$真是厉害!" - } - }, - "kieran": { - "encounter": { - "1": "我的努力让我越来越强!\n$所以我不会输。" - }, - "victory": { - "1": "不可能……\n$真是一场有趣又激动人心的战斗啊!" - }, - "defeat": { - "1": "哇塞,好一场战斗!\n$你得多练练了。" - } - }, - "rival": { - "encounter": { - "1": "@c{smile}嘿,我在找你呢!我知道你急着上路,\n但至少说个再见吧…$@c{smile_eclosed}所以你终于要开始追逐梦想了?\n我几乎不敢相信。$@c{serious_smile_fists}来都来了,来一场对战怎么样?\n毕竟,我想看看你是不是准备周全了。$@c{serious_mopen_fists}不要手下留情,我想让你全力以赴!" - }, - "victory": { - "1": "@c{shock}哇…你彻底击败了我。\n你是真初学者吗?$@c{smile}也许是靠点运气,但是…\n谁知道,你可能真的能一路走下去。$顺便说一下,博士让我给你这些东西。它们看起来可牛了。$@c{serious_smile_fists}祝你好运!" - } - }, - "rival_female": { - "encounter": { - "1": "@c{smile_wave}你在这儿啊!我到处找你呢!$@c{angry_mopen}你忘了和你最好的朋友说再见了吗?$@c{smile_ehalf}你要去追逐梦想了,对吧?\n从今天开始,是不是…$@c{smile}不管怎样,忘了我的事就原谅你吧,\n但有个条件。@c{smile_wave_wink}你必须和我对战!$@c{angry_mopen}全力以赴!\n你也不想让你的冒险在开始之前就结束了,对吧?" - }, - "victory": { - "1": "@c{shock}你刚开始就已经这么强了?!@d{96}$@c{angry}你是不是开了?$@c{smile_wave_wink}只是开个玩笑啦!@d{64} @c{smile_eclosed}我输地心服口服了…\n我感觉你出去挺有天赋的。$@c{smile}顺便说一下,博士想让我给你一些东西。\n希望它们能帮上忙!$@c{smile_wave}像往常一样尽力而为!\n我相信你!" - } - }, - "rival_2": { - "encounter": { - "1": "@c{smile}嘿,你也在这里吗?$@c{smile_eclosed}一路过关斩将,是吧?$@c{serious_mopen_fists}我知道看起来好像我尾随着你来到这里,\n怎么可能啦。$@c{serious_smile_fists}说真的,自从你在老家打败我后,\n我就一直很渴望再比一场。$我自己也进行了很多训练,\n所以这次我肯定会好好打一场。$@c{serious_mopen_fists}不要手下留情,就像以前一样!$让我们开始吧!" - }, - "victory": { - "1": "@c{neutral_eclosed}哦。我过于自信了。$@c{smile}不过没关系。我猜到可能会这样。$@c{serious_mopen_fists}这只意味着我下次需要更努力!$$@c{smile}呃,不是特意帮你,我正好有多余的这个,\n我觉得你可能想要。$$@c{serious_smile_fists}不过这次之后别指望再有了!$我不能一直给我的对手优势。$@c{smile}反正,保重!" - } - }, - "rival_2_female": { - "encounter": { - "1": "@c{smile_wave}哦,真巧,在这里遇见你。\n看来你还没输过嘛。@c{angry_mopen}哈……好家伙!$@c{angry_mopen}我知道你在想什么,\n不,我才不会跟踪你什么呢。 @c{smile_eclosed}我只是碰巧在附近。$@c{smile_ehalf}我为你感到高兴,但我只想让你知道\n有时输了是可以接受的。$@c{smile}我们从错误中学到的东西\n往往比我们一直成功时学到的还要多。$@c{angry_mopen}无论如何,我为了我们的复赛已经努力训练了\n所以你最好全力以赴!" - }, - "victory": { - "1": "@c{neutral}我……没打算会输来着……$@c{smile}嗷……好吧。看来我要再更加努力训练了!$@c{smile_wave}我还给你带了个这个$@c{smile_wave_wink}不用谢我哦~.$@c{angry_mopen}不过,这是最后一个啦!\n你可别想再从我这赚小便宜了~$@c{smile_wave}要保重哦!" - }, - "defeat": { - "1": "输了有时候也不要紧的…" - } - }, - "rival_3": { - "encounter": { - "1": "@c{smile}嘿,看看这是谁!好久不见啊。$@c{neutral}你……还是没输过?哈…$@c{neutral_eclosed}这有点……不太对劲。$没有你一起,回家的感觉有很不一样。$@c{serious}虽然我知道这挺别扭的,但我就直说了。$@c{neutral_eclosed}我觉得你有点儿难以理喻。$@c{serious}没有人能够战无不胜。$失败乃成功之母。$@c{neutral_eclosed}你已经赢得了够好的成绩,\n但前面道阻且长,只会愈发艰难。 @c{neutral}你做好准备了没?$@c{serious_mopen_fists}如果做好了,证明给我看吧。" - }, - "victory": { - "1": "@c{angry_mhalf}这太离谱了……我几乎从没停下训练……$我们之间的差距怎么还是这么大?" - } - }, - "rival_3_female": { - "encounter": { - "1": "@c{smile_wave}好久不见!还没输过,对吧。$@c{angry}我觉得你点烦了。@c{smile_wave_wink}开玩笑啦!$@c{smile_ehalf}但说真的,你现在不想家吗?\n不想…我吗?$我……我的意思是,我们真的很想你。$@c{smile_eclosed}我支持你的一切,包括你的梦想。\n但现实就是你早晚会经历失败。$@c{smile}当你失败的时候,我想像往常一样陪在你身边。$@c{angry_mopen}现在,给你看看我变得多强了吧!" - }, - "victory": { - "1": "@c{shock}都这样了……还是不够吗?$这样下去,你就永远不会回来了……" - }, - "defeat": { - "1": "你尽力了,现在让我们回家吧。" - } - }, - "rival_4": { - "encounter": { - "1": "@c{neutral}嘿。$我不会对你说什么拐弯抹角的客套话。$@c{neutral_eclosed}我来,就是为了赢,简单明了。$@c{serious_mhalf_fists}我将所有时间都投入到训练中,\n掌握了如何发挥我的潜力。$@c{smile}当你削减掉不必要的睡眠和社交后,\n你会得到很多额外的时间。$@c{serious_mopen_fists}但在我获胜之前,这些都不重要了。$@c{neutral_eclosed}我甚至已经到达了战无不败的境地。$@c{smile_eclosed}我觉得你的思路倒是也没毛病。$@c{angry_mhalf}失败是属于弱者的,\n我已经不再软弱了。$@c{serious_mopen_fists}准备好吧。" - }, - "victory": { - "1": "@c{neutral}你…@d{64} 你是人吗?" - } - }, - "rival_4_female": { - "encounter": { - "1": "@c{neutral}是我哦!没又把我忘了吧……是吗?$@c{smile}你应该为自己走了这么远感到骄傲。恭喜你!$但看来你的旅程到此为止了。$@c{smile_eclosed}你唤醒了我体内一些我从未有过的东西。\n就像我现在满脑子除了训练还是训练。$@c{smile_ehalf}我几乎已经没空吃饭睡觉了,\n我没日没夜训练我的宝可梦,每次都能变得更强。$@c{neutral}事实上,我……几乎不认识自己了。$现在,我终于达到了巅峰。\n我感觉我已经战无不胜了。$而且你知道吗?这一切都是因为你。$@c{smile_ehalf}我不知道到底是该感谢你还是恨你。$@c{angry_mopen}做好准备…" - }, - "victory": { - "1": "@c{neutral}你…@d{64} 你是人吗?" - }, - "defeat": { - "1": "@c{smile}你应该为自己走了这么远感到骄傲。" - } - }, - "rival_5": { - "encounter": { - "1": "@c{neutral}…" - }, - "victory": { - "1": "@c{neutral}…" - } - }, - "rival_5_female": { - "encounter": { - "1": "@c{neutral}…" - }, - "victory": { - "1": "@c{neutral}…" - }, - "defeat": { - "1": "$@c{smile_ehalf}…" - } - }, - "rival_6": { - "encounter": { - "1": "@c{smile_eclosed}又见面了。$@c{neutral}我花了点时间思考反思\n有理由说明为什么这一切都显得如此奇妙。$@c{neutral_eclosed}你所追逐的梦想,我想击败你的决心…$这都是某种庞大使命的一部分。$@c{serious}这不仅仅是关于我和你… 而是关于这个世界, @c{serious_mhalf_fists}我的使命就是将你推向极限。$@c{neutral_eclosed}我是否达成了那个使命,我说不上来,但我已尽我所能。$@c{neutral}我们最终到达的这个地方看起来很可怕\n 然而不知何故,我心中毫无畏惧,好像我早就来过这里。$@c{serious_mhalf_fists}你也有同样的感觉,对吧?$@c{serious}……这里好像有什么东西在呼唤我。\n这是世界早已记录的一切。$那些我们经历过的时光,那些记忆犹新的过去,\n其实只是遥远的回忆。$@c{neutral_eclosed}谁能保证它们是否真的发生过。$@c{serious_mopen_fists}你必须继续前进,不然的话,这一切将永无止境。\n这件事而只有你能办成。$@c{serious_smile_fists}我不清楚这一切意味着什么,但我知道……$@c{serious_mopen_fists}如果现在你不能就此击败我,\n你将毫无机会可言。" - }, - "victory": { - "1": "@c{smile_eclosed}看来我的使命在这里已经完成了。\n我想让你答应我一件事。$@c{smile}在你拯救世界之后,要回家。" - } - }, - "rival_6_female": { - "encounter": { - "1": "@c{smile_ehalf}又只有我们两个人了。$@c{smile_eclosed}你知道吗,我在心里想啊想,\n想了好久……$@c{smile_ehalf}这一切背后是有什么原因吗,\n为什么一切现在看起来都这么奇怪……$@c{smile}你有你的梦想,而我内心有这个抱负……$我不禁感觉这一切背后有一个更庞大的力量,$掌控者我们所做的一切,你和我之间。$@c{smile_eclosed}我想我注定要推动你……到你的极限。$@c{smile_ehalf}我不清楚我是否一直做得很好,\n但到现在为止,我已经尽力了。$这个奇怪而可怕的地方……\n一切看起来都那么清晰……$这是世界早已记录的一切。$@c{smile_eclosed}我好像记不清我们一起度过的日子了。$@c{smile_ehalf}那些回忆到底是真的吗?\n怎么感觉这么久远……$@c{angry_mopen}你得继续前进,不然的话,这一切将永无止境。\n你是唯一能做到这件事的。$@c{smile_ehalf}我……不知道这一切意味着什么……\n但我明白$@c{neutral}如果你现在不能就此击败我,\n你将毫无机会可言。" - }, - "victory": { - "1": "@c{smile_ehalf}我……\n我想我完成了我的使命……$@c{smile_eclosed}答应我……在你拯救世界之后\n……要……平安到家。$@c{smile_ehalf}……谢谢你。" - } - } -} diff --git a/src/locales/zh_CN/egg.json b/src/locales/zh_CN/egg.json deleted file mode 100644 index 5a299368873..00000000000 --- a/src/locales/zh_CN/egg.json +++ /dev/null @@ -1,26 +0,0 @@ -{ - "egg": "蛋", - "greatTier": "稀有", - "ultraTier": "史诗", - "masterTier": "传说", - "defaultTier": "普通", - "hatchWavesMessageSoon": "里面传来声音!\n似乎快要孵化了!", - "hatchWavesMessageClose": "有时好像会动一下。\n就快孵化了吧?", - "hatchWavesMessageNotClose": "会孵化出什么呢?\n看来还需要很长时\n间才能孵化。", - "hatchWavesMessageLongTime": "这个蛋需要很长时间\n才能孵化。", - "gachaTypeLegendary": "传说概率上升", - "gachaTypeMove": "稀有概率上升", - "gachaTypeShiny": "闪光概率上升", - "selectMachine": "选择一个机器。", - "notEnoughVouchers": "你没有足够的兑换券!", - "tooManyEggs": "你的蛋太多啦!", - "pull": "次", - "pulls": "次", - "sameSpeciesEgg": "{{species}}将会从蛋中孵化!", - "hatchFromTheEgg": "{{pokemonName}} 从蛋中孵化了!", - "eggMoveUnlock": "蛋招式已解锁: {{moveName}}", - "rareEggMoveUnlock": "稀有蛋招式已解锁: {{moveName}}", - "moveUPGacha": "蛋招式UP!", - "shinyUPGacha": "闪光UP!", - "legendaryUPGacha": "UP!" -} \ No newline at end of file diff --git a/src/locales/zh_CN/fight-ui-handler.json b/src/locales/zh_CN/fight-ui-handler.json deleted file mode 100644 index aa8bf4f77c5..00000000000 --- a/src/locales/zh_CN/fight-ui-handler.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "pp": "PP", - "power": "威力", - "accuracy": "命中", - "abilityFlyInText": " {{pokemonName}} 的\n{{passive}}{{abilityName}}", - "passive": "被动 ", - "teraHover": "{{type}} 太晶化" -} diff --git a/src/locales/zh_CN/filter-bar.json b/src/locales/zh_CN/filter-bar.json deleted file mode 100644 index 1726d40d268..00000000000 --- a/src/locales/zh_CN/filter-bar.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "genFilter": "世代", - "typeFilter": "属性", - "caughtFilter": "捕获", - "unlocksFilter": "解锁", - "miscFilter": "混合", - "sortFilter": "排序", - "all": "全部", - "normal": "无闪光", - "uncaught": "未捕获", - "passive": "被动", - "passiveUnlocked": "被动解锁", - "passiveLocked": "被动未解锁", - "passiveUnlockable": "被动可解锁", - "costReduction": "费用降低", - "costReductionUnlocked": "已降费", - "costReductionLocked": "未降费", - "costReductionUnlockable": "可降费", - "favorite": "最爱", - "isFavorite": "包含最爱", - "notFavorite": "不包含最爱", - "ribbon": "缎带", - "hasWon": "有缎带", - "hasNotWon": "无缎带", - "hiddenAbility": "梦特", - "hasHiddenAbility": "有梦特", - "noHiddenAbility": "无梦特", - "egg": "蛋", - "eggPurchasable": "可购买蛋", - "pokerus": "病毒", - "hasPokerus": "有病毒", - "noPokerus": "无病毒", - "sortByNumber": "编号", - "sortByCost": "费用", - "sortByCandies": "糖果", - "sortByIVs": "个体", - "sortByName": "名称" -} \ No newline at end of file diff --git a/src/locales/zh_CN/game-mode.json b/src/locales/zh_CN/game-mode.json deleted file mode 100644 index 810f943b400..00000000000 --- a/src/locales/zh_CN/game-mode.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "classic": "经典模式", - "endless": "无尽模式", - "endlessSpliced": "融合无尽模式", - "dailyRun": "每日挑战", - "unknown": "未知", - "challenge": "挑战模式" -} diff --git a/src/locales/zh_CN/game-stats-ui-handler.json b/src/locales/zh_CN/game-stats-ui-handler.json deleted file mode 100644 index 94f767e14e3..00000000000 --- a/src/locales/zh_CN/game-stats-ui-handler.json +++ /dev/null @@ -1,42 +0,0 @@ -{ - "stats": "统计", - "playTime": "游戏时间", - "totalBattles": "总战斗次数", - "starters": "初始宝可梦", - "shinyStarters": "闪光初始宝可梦", - "speciesSeen": "遇到的种类", - "speciesCaught": "捕捉的种类", - "ribbonsOwned": "拥有缎带数", - "classicRuns": "经典模式次数", - "classicWins": "经典模式通关次数", - "dailyRunAttempts": "每日挑战次数", - "dailyRunWins": "每日挑战通关次数", - "endlessRuns": "无尽模式挑战次数", - "highestWaveEndless": "最高层数(无尽)", - "highestMoney": "最多金钱", - "highestDamage": "最高伤害", - "highestHPHealed": "最多治疗", - "pokemonEncountered": "遇敌数量", - "pokemonDefeated": "打倒数量", - "pokemonCaught": "捕捉数量", - "eggsHatched": "孵蛋数量", - "subLegendsSeen": "遇到的二级神宝可梦", - "subLegendsCaught": "捕捉的二级神宝可梦", - "subLegendsHatched": "孵化的二级神宝可梦", - "legendsSeen": "遇到的传说宝可梦", - "legendsCaught": "捕捉的传说宝可梦", - "legendsHatched": "孵化的传说宝可梦", - "mythicalsSeen": "遇到的幻兽宝可梦", - "mythicalsCaught": "捕捉的幻兽宝可梦", - "mythicalsHatched": "孵化的幻兽宝可梦", - "shiniesSeen": "遇到的闪光宝可梦", - "shiniesCaught": "捕捉的闪光宝可梦", - "shiniesHatched": "孵化的闪光宝可梦", - "pokemonFused": "融合宝可梦次数", - "trainersDefeated": "打败的训练师数", - "eggsPulled": "总扭蛋次数", - "rareEggsPulled": "稀有扭蛋数", - "epicEggsPulled": "史诗扭蛋数", - "legendaryEggsPulled": "传说扭蛋数", - "manaphyEggsPulled": "玛娜霏扭蛋数" -} diff --git a/src/locales/zh_CN/growth.json b/src/locales/zh_CN/growth.json deleted file mode 100644 index 4ae2f5e5743..00000000000 --- a/src/locales/zh_CN/growth.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "Erratic": "非常快", - "Fast": "快", - "Medium_Fast": "较快", - "Medium_Slow": "较慢", - "Slow": "慢", - "Fluctuating": "非常慢" -} \ No newline at end of file diff --git a/src/locales/zh_CN/menu-ui-handler.json b/src/locales/zh_CN/menu-ui-handler.json deleted file mode 100644 index c8ecaa6dd98..00000000000 --- a/src/locales/zh_CN/menu-ui-handler.json +++ /dev/null @@ -1,29 +0,0 @@ -{ - "GAME_SETTINGS": "游戏设置", - "ACHIEVEMENTS": "成就", - "STATS": "数据统计", - "RUN_HISTORY": "历史记录", - "EGG_LIST": "蛋列表", - "EGG_GACHA": "扭蛋机", - "MANAGE_DATA": "管理数据", - "COMMUNITY": "社区", - "SAVE_AND_QUIT": "保存并退出", - "LOG_OUT": "登出", - "slot": "存档位 {{slotNumber}}", - "importSession": "导入存档", - "importSlotSelect": "选择要导入到的存档位。", - "exportSession": "导出存档", - "exportSlotSelect": "选择要导出的存档位。", - "importRunHistory":"导入历史记录", - "exportRunHistory":"导出历史记录", - "importData": "导入数据", - "exportData": "导出数据", - "consentPreferences": "同意偏好", - "linkDiscord": "关联Discord", - "unlinkDiscord": "解除关联Discord", - "linkGoogle": "关联Google", - "unlinkGoogle": "解除关联Google", - "cancel": "取消", - "losingProgressionWarning": "你将失去自战斗开始以来的所有进度。\n是否继续?", - "noEggs": "当前没有任何蛋\n正在孵化中!" -} \ No newline at end of file diff --git a/src/locales/zh_CN/menu.json b/src/locales/zh_CN/menu.json deleted file mode 100644 index 8946b5b8df6..00000000000 --- a/src/locales/zh_CN/menu.json +++ /dev/null @@ -1,57 +0,0 @@ -{ - "cancel": "取消", - "continue": "继续", - "dailyRun": "每日挑战 (Beta)", - "loadGame": "加载游戏", - "newGame": "新游戏", - "settings": "设置", - "selectGameMode": "选择一个游戏模式", - "logInOrCreateAccount": "登录或创建账户以开始游戏。无需邮箱!", - "username": "用户名", - "password": "密码", - "login": "登录", - "Or use": "或使用", - "register": "注册", - "emptyUsername": "用户名不能为空", - "invalidLoginUsername": "输入的用户名无效", - "invalidRegisterUsername": "用户名只能包含字母、数字或下划线", - "invalidLoginPassword": "输入的密码无效", - "invalidRegisterPassword": "密码必须至少包含 6 个字符", - "usernameAlreadyUsed": "输入的用户名已被使用", - "accountNonExistent": "输入的用户不存在", - "unmatchingPassword": "输入的密码不匹配", - "passwordNotMatchingConfirmPassword": "密码必须与确认密码一致", - "confirmPassword": "确认密码", - "registrationAgeWarning": "注册即表示您确认您已年满 13 岁。", - "backToLogin": "返回登录", - "failedToLoadSaveData": "读取存档数据失败。请重新加载页面。如果\n问题仍然存在,请联系管理员。", - "sessionSuccess": "会话加载成功。", - "failedToLoadSession": "无法加载您的会话数据。它可能已损坏。", - "boyOrGirl": "你是男孩还是女孩?", - "evolving": "咦?\n{{pokemonName}} 开始进化了!", - "stoppedEvolving": "{{pokemonName}} 停止了进化。", - "pauseEvolutionsQuestion": "你确定要停止 {{pokemonName}} 的进化吗?\n你可以在队伍界面中重新进化。", - "evolutionsPaused": "{{pokemonName}} 的进化停止了。", - "evolutionDone": "恭喜!\n你的 {{pokemonName}} 进化成了 {{evolvedPokemonName}}!", - "dailyRankings": "每日排名", - "weeklyRankings": "每周排名", - "noRankings": "无排名", - "positionIcon": "#", - "usernameScoreboard": "用户名", - "score": "分数", - "wave": "层数", - "loading": "加载中...", - "loadingAsset": "加载资源: {{assetName}}", - "playersOnline": "在线玩家", - "yes": "是", - "no": "否", - "disclaimer": "免责声明", - "disclaimerDescription": "这个游戏尚未完成; 可能存在游戏性问题(包括潜在的丢档风险)、\n 不经通知的调整、 未来可能会更新或完成更多内容", - "choosePokemon": "选择一只宝可梦。", - "renamePokemon": "给宝可梦起名", - "rename": "起名", - "nickname": "昵称", - "errorServerDown": "糟糕!访问服务器时发生了错误。\n\n你可以保持页面开启,\n游戏会自动重新连接。", - "noSaves": "你没有任何记录文件!", - "tooManySaves": "你的记录文件太多了!" -} diff --git a/src/locales/zh_CN/modifier-select-ui-handler.json b/src/locales/zh_CN/modifier-select-ui-handler.json deleted file mode 100644 index b3475737dfd..00000000000 --- a/src/locales/zh_CN/modifier-select-ui-handler.json +++ /dev/null @@ -1,12 +0,0 @@ -{ - "transfer": "交换道具", - "reroll": "刷新商店", - "lockRarities": "锁定稀有度", - "checkTeam": "查看队伍", - "transferDesc": "将宝可梦携带的道具交换给其他宝可梦", - "rerollDesc": "花钱刷新道具", - "lockRaritiesDesc": "在刷新时锁定道具稀有度(影响刷新费用)", - "checkTeamDesc": "检查队伍或使用形态改变道具", - "rerollCost": "₽{{formattedMoney}}", - "itemCost": "₽{{formattedMoney}}" -} \ No newline at end of file diff --git a/src/locales/zh_CN/modifier-type.json b/src/locales/zh_CN/modifier-type.json deleted file mode 100644 index 981f26a1603..00000000000 --- a/src/locales/zh_CN/modifier-type.json +++ /dev/null @@ -1,607 +0,0 @@ -{ - "ModifierType": { - "AddPokeballModifierType": { - "name": "{{modifierCount}}x {{pokeballName}}", - "description": "获得 {{pokeballName}} x{{modifierCount}} (已有:{{pokeballAmount}}) \n捕捉倍率:{{catchRate}}。" - }, - "AddVoucherModifierType": { - "name": "{{modifierCount}}x {{voucherTypeName}}", - "description": "获得 {{voucherTypeName}} x{{modifierCount}}。" - }, - "PokemonHeldItemModifierType": { - "extra": { - "inoperable": "{{pokemonName}} 无法携带\n这个物品!", - "tooMany": "{{pokemonName}} 已有太多\n这个物品!" - } - }, - "PokemonHpRestoreModifierType": { - "description": "为一只宝可梦回复{{restorePoints}}HP或{{restorePercent}}%HP,取较大值。", - "extra": { - "fully": "为一只宝可梦回复全部HP。", - "fullyWithStatus": "为一只宝可梦回复全部HP并消除所有负面\n状态。" - } - }, - "PokemonReviveModifierType": { - "description": "复活一只宝可梦并回复 {{restorePercent}}% HP。" - }, - "PokemonStatusHealModifierType": { - "description": "为一只宝可梦消除所有负面状态。" - }, - "PokemonPpRestoreModifierType": { - "description": "为一只宝可梦的一个招式回复 {{restorePoints}} PP。", - "extra": { - "fully": "完全回复一只宝可梦一个招式的PP。" - } - }, - "PokemonAllMovePpRestoreModifierType": { - "description": "为一只宝可梦的所有招式回复 {{restorePoints}} PP。", - "extra": { - "fully": "为一只宝可梦的所有招式回复所有PP。" - } - }, - "PokemonPpUpModifierType": { - "description": "选择一只宝可梦的一个招式使用\n使其PP最大值提升基础的20% (最多3次)。" - }, - "PokemonNatureChangeModifierType": { - "name": "{{natureName}}薄荷", - "description": "将一只宝可梦的性格改为{{natureName}}并为\n该宝可梦永久解锁该性格。" - }, - "DoubleBattleChanceBoosterModifierType": { - "description": "遭遇双打概率提升四倍,持续{{battleCount}}场战斗。" - }, - "TempStatStageBoosterModifierType": { - "description": "提升全队的{{stat}}{{amount}}级,持续5场战斗。", - "extra": { - "stage": "1阶", - "percentage": "30%" - } - }, - "AttackTypeBoosterModifierType": { - "description": "一只宝可梦的{{moveType}}系招式威力提升20%。" - }, - "PokemonLevelIncrementModifierType": { - "description": "使一只宝可梦的等级提升{{levels}}级。" - }, - "AllPokemonLevelIncrementModifierType": { - "description": "使一只寶可夢的等級提升{{levels}}級。" - }, - "BaseStatBoosterModifierType": { - "description": "增加10%持有者的{{stat}},\n个体值越高堆叠上限越高。" - }, - "AllPokemonFullHpRestoreModifierType": { - "description": "所有宝可梦完全回复HP。" - }, - "AllPokemonFullReviveModifierType": { - "description": "复活所有濒死的宝可梦,\n并完全回复HP。" - }, - "MoneyRewardModifierType": { - "description": "获得{{moneyMultiplier}}金钱(₽{{moneyAmount}})。", - "extra": { - "small": "少量", - "moderate": "中等", - "large": "大量" - } - }, - "ExpBoosterModifierType": { - "description": "经验值获取量增加{{boostPercent}}%。" - }, - "PokemonExpBoosterModifierType": { - "description": "持有者经验值获取量增加{{boostPercent}}%。" - }, - "PokemonFriendshipBoosterModifierType": { - "description": "每场战斗获得的好感度提升50%。" - }, - "PokemonMoveAccuracyBoosterModifierType": { - "description": "招式命中率增加{{accuracyAmount}}(最大100)。" - }, - "PokemonMultiHitModifierType": { - "description": "攻击以60/75/82.5%的伤害造成2/3/4次伤害。" - }, - "TmModifierType": { - "name": "招式学习器\n{{moveId}} - {{moveName}}", - "description": "教会一只宝可梦{{moveName}}。" - }, - "TmModifierTypeWithInfo": { - "name": "招式学习器\n{{moveId}} - {{moveName}}", - "description": "教会一只宝可梦{{moveName}}\n(按住C或者Shift查看更多信息)。" - }, - "EvolutionItemModifierType": { - "description": "使某些宝可梦进化。" - }, - "FormChangeItemModifierType": { - "description": "使某些宝可梦更改形态。" - }, - "FusePokemonModifierType": { - "description": "融合两只宝可梦 (改变特性, 平分基础点数\n和属性, 共享招式池)。" - }, - "TerastallizeModifierType": { - "name": "{{teraType}}太晶碎块", - "description": "持有者获得{{teraType}}太晶化,\n持续10场战斗。" - }, - "ContactHeldItemTransferChanceModifierType": { - "description": "攻击时{{chancePercent}}%概率\n偷取对手物品。" - }, - "TurnHeldItemTransferModifierType": { - "description": "持有者每回合从对手那里\n获得一个持有的物品。" - }, - "EnemyAttackStatusEffectChanceModifierType": { - "description": "攻击时{{chancePercent}}%概率造成{{statusEffect}}。" - }, - "EnemyEndureChanceModifierType": { - "description": "敌方增加{{chancePercent}}%的概率\n在本回合不会倒下。" - }, - "RARE_CANDY": { - "name": "神奇糖果" - }, - "RARER_CANDY": { - "name": "超神奇糖果" - }, - "MEGA_BRACELET": { - "name": "MEGA手镯", - "description": "能让携带着MEGA石战斗的宝可梦\n进行MEGA进化。" - }, - "DYNAMAX_BAND": { - "name": "极巨腕带", - "description": "能让携带着极巨菇菇战斗的宝可梦\n进行超极巨化。" - }, - "TERA_ORB": { - "name": "太晶珠", - "description": "能让携带着太晶碎块战斗的宝可梦\n进行太晶化。" - }, - "MAP": { - "name": "地图", - "description": "有概率允许你在切换地区时\n选择目的地。" - }, - "POTION": { - "name": "伤药" - }, - "SUPER_POTION": { - "name": "好伤药" - }, - "HYPER_POTION": { - "name": "厉害伤药" - }, - "MAX_POTION": { - "name": "全满药" - }, - "FULL_RESTORE": { - "name": "全复药" - }, - "REVIVE": { - "name": "活力碎片" - }, - "MAX_REVIVE": { - "name": "活力块" - }, - "FULL_HEAL": { - "name": "万灵药" - }, - "SACRED_ASH": { - "name": "圣灰" - }, - "REVIVER_SEED": { - "name": "复活种子", - "description": "受到技能攻击伤害濒死时,\n恢复该宝可梦的HP至1/2。" - }, - "WHITE_HERB": { - "name": "白色香草", - "description": "当携带它的宝可梦能力降低时,\n仅能回到之前的状态1次。" - }, - "ETHER": { - "name": "PP单项小补剂" - }, - "MAX_ETHER": { - "name": "PP单项全补剂" - }, - "ELIXIR": { - "name": "PP多项小补剂" - }, - "MAX_ELIXIR": { - "name": "PP多项全补剂" - }, - "PP_UP": { - "name": "PP提升剂" - }, - "PP_MAX": { - "name": "PP极限提升剂" - }, - "LURE": { - "name": "引虫香水" - }, - "SUPER_LURE": { - "name": "白银香水" - }, - "MAX_LURE": { - "name": "黄金香水" - }, - "MEMORY_MUSHROOM": { - "name": "回忆蘑菇", - "description": "回忆一个宝可梦已经遗忘的招式。" - }, - "EXP_SHARE": { - "name": "学习装置", - "description": "未参加对战的宝可梦获得20%的经验值。" - }, - "EXP_BALANCE": { - "name": "均衡型学习装置", - "description": "经验值会更多分给队伍中等级最低的宝可梦。" - }, - "OVAL_CHARM": { - "name": "圆形护符", - "description": "当多只宝可梦参与战斗,分别获得总经验值\n10%的额外经验值。" - }, - "EXP_CHARM": { - "name": "经验护符" - }, - "SUPER_EXP_CHARM": { - "name": "超级经验护符" - }, - "GOLDEN_EXP_CHARM": { - "name": "黄金经验护符" - }, - "LUCKY_EGG": { - "name": "幸运蛋" - }, - "GOLDEN_EGG": { - "name": "金蛋" - }, - "SOOTHE_BELL": { - "name": "安抚之铃" - }, - "SCOPE_LENS": { - "name": "焦点镜", - "description": "能看见弱点的镜片。携带它的宝可梦的招式\n会变得容易击中要害。" - }, - "DIRE_HIT": { - "name": "要害攻击", - "extra": { - "raises": "会心" - } - }, - "LEEK": { - "name": "大葱", - "description": "非常长且坚硬的茎。让大葱鸭携带后,\n招式会变得容易击中要害。" - }, - "EVIOLITE": { - "name": "进化奇石", - "description": "携带后,还能进化的宝可梦的\n防御和特防就会提高。" - }, - "SOUL_DEW": { - "name": "心之水滴", - "description": "增加10%宝可梦性格对数值的影响 (加算)。" - }, - "NUGGET": { - "name": "金珠" - }, - "BIG_NUGGET": { - "name": "巨大金珠" - }, - "RELIC_GOLD": { - "name": "古代金币" - }, - "AMULET_COIN": { - "name": "护符金币", - "description": "获得的金钱增加20%。" - }, - "GOLDEN_PUNCH": { - "name": "黄金拳头", - "description": "将50%造成的伤害转换为金钱。" - }, - "COIN_CASE": { - "name": "代币盒", - "description": "每10场战斗, 获得自己金钱10%的利息。" - }, - "LOCK_CAPSULE": { - "name": "上锁的容器", - "description": "允许在商店中刷新物品时,\n锁定物品的稀有度。" - }, - "GRIP_CLAW": { - "name": "紧缠钩爪" - }, - "WIDE_LENS": { - "name": "广角镜" - }, - "MULTI_LENS": { - "name": "多重镜" - }, - "HEALING_CHARM": { - "name": "治愈护符", - "description": "HP回复量增加10% (不含复活)。" - }, - "CANDY_JAR": { - "name": "糖果罐", - "description": "神奇糖果提供的升级额外增加1级。" - }, - "BERRY_POUCH": { - "name": "树果袋", - "description": "使用树果时增加30%的几率不会消耗树果。" - }, - "FOCUS_BAND": { - "name": "气势头带", - "description": "携带该道具的宝可梦增加10%几率在受到攻击\n而将陷入濒死状态时,保留1点HP不陷入濒死状态。" - }, - "QUICK_CLAW": { - "name": "先制之爪", - "description": "增加10%的几率无视速度优先使出招式\n(先制技能优先)。" - }, - "KINGS_ROCK": { - "name": "王者之证", - "description": "使用任意原本不会造成畏缩状态的攻击,\n增加10%几率使目标陷入畏缩状态。" - }, - "LEFTOVERS": { - "name": "吃剩的东西", - "description": "携带后,在每个回合结束时恢复\n最大HP的1/16。" - }, - "SHELL_BELL": { - "name": "贝壳之铃", - "description": "携带后,在攻击对方成功造成伤害时,\n携带者的HP会恢复其所造成伤害的1/8。" - }, - "TOXIC_ORB": { - "name": "剧毒宝珠", - "description": "触碰后会放出毒的神奇宝珠。\n携带后,在战斗时会变成剧毒状态。" - }, - "FLAME_ORB": { - "name": "火焰宝珠", - "description": "触碰后会放出热量的神奇宝珠。\n携带后,在战斗时会变成灼伤状态。" - }, - "BATON": { - "name": "接力棒", - "description": "允许在切换宝可梦时保留能力变化, 对陷阱\n同样生效。" - }, - "SHINY_CHARM": { - "name": "闪耀护符", - "description": "显著增加野生宝可梦的闪光概率。" - }, - "ABILITY_CHARM": { - "name": "特性护符", - "description": "显著增加野生宝可梦有隐藏特性的概率。" - }, - "IV_SCANNER": { - "name": "个体值探测器", - "description": "允许扫描野生宝可梦的个体值。每多拥有一个\n多显示两项个体值,优先显示最高项。" - }, - "DNA_SPLICERS": { - "name": "基因之楔" - }, - "MINI_BLACK_HOLE": { - "name": "迷你黑洞" - }, - "GOLDEN_POKEBALL": { - "name": "黄金精灵球", - "description": "在每场战斗结束后,增加一个额外物品选项。" - }, - "ENEMY_DAMAGE_BOOSTER": { - "name": "伤害硬币", - "description": "造成5%额外伤害(乘算)。" - }, - "ENEMY_DAMAGE_REDUCTION": { - "name": "防御硬币", - "description": "受到2.5%更少伤害(乘算)。" - }, - "ENEMY_HEAL": { - "name": "回复硬币", - "description": "每回合回复2%最大HP。" - }, - "ENEMY_ATTACK_POISON_CHANCE": { - "name": "剧毒硬币" - }, - "ENEMY_ATTACK_PARALYZE_CHANCE": { - "name": "麻痹硬币" - }, - "ENEMY_ATTACK_BURN_CHANCE": { - "name": "灼烧硬币" - }, - "ENEMY_STATUS_EFFECT_HEAL_CHANCE": { - "name": "万灵药硬币", - "description": "增加2.5%每回合治愈异常状态的概率。" - }, - "ENEMY_ENDURE_CHANCE": { - "name": "忍受硬币" - }, - "ENEMY_FUSED_CHANCE": { - "name": "融合硬币", - "description": "增加1%野生融合宝可梦出现概率。" - } - }, - "SpeciesBoosterItem": { - "LIGHT_BALL": { - "name": "电气球", - "description": "让皮卡丘携带后,\n攻击和特攻就会提高的神奇之球。" - }, - "THICK_CLUB": { - "name": "粗骨头", - "description": "某种坚硬的骨头。\n让卡拉卡拉或嘎啦嘎啦携带后,攻击就会提高。" - }, - "METAL_POWDER": { - "name": "金属粉", - "description": "让百变怪携带后,防御就会提高的神奇粉末。\n非常细腻坚硬。" - }, - "QUICK_POWDER": { - "name": "速度粉", - "description": "让百变怪携带后,速度就会提高的神奇粉末。\n非常细腻坚硬。" - } - }, - "TempStatStageBoosterItem": { - "x_attack": "力量强化", - "x_defense": "防御强化", - "x_sp_atk": "特攻强化", - "x_sp_def": "特防强化", - "x_speed": "速度强化", - "x_accuracy": "命中强化" - }, - "AttackTypeBoosterItem": { - "silk_scarf": "丝绸围巾", - "black_belt": "黑带", - "sharp_beak": "锐利鸟嘴", - "poison_barb": "毒针", - "soft_sand": "柔软沙子", - "hard_stone": "硬石头", - "silver_powder": "银粉", - "spell_tag": "诅咒之符", - "metal_coat": "金属膜", - "charcoal": "木炭", - "mystic_water": "神秘水滴", - "miracle_seed": "奇迹种子", - "magnet": "磁铁", - "twisted_spoon": "弯曲的汤匙", - "never_melt_ice": "不融冰", - "dragon_fang": "龙之牙", - "black_glasses": "黑色眼镜", - "fairy_feather": "妖精之羽" - }, - "BaseStatBoosterItem": { - "hp_up": "HP增强剂", - "protein": "攻击增强剂", - "iron": "防御增强剂", - "calcium": "特攻增强剂", - "zinc": "特防增强剂", - "carbos": "速度增强剂" - }, - "EvolutionItem": { - "NONE": "无", - "LINKING_CORD": "联系绳", - "SUN_STONE": "日之石", - "MOON_STONE": "月之石", - "LEAF_STONE": "叶之石", - "FIRE_STONE": "火之石", - "WATER_STONE": "水之石", - "THUNDER_STONE": "雷之石", - "ICE_STONE": "冰之石", - "DUSK_STONE": "暗之石", - "DAWN_STONE": "觉醒之石", - "SHINY_STONE": "光之石", - "CRACKED_POT": "破裂的茶壶", - "SWEET_APPLE": "甜甜苹果", - "TART_APPLE": "酸酸苹果", - "STRAWBERRY_SWEET": "草莓糖饰", - "UNREMARKABLE_TEACUP": "凡作茶碗", - "CHIPPED_POT": "缺损的茶壶", - "BLACK_AUGURITE": "黑奇石", - "GALARICA_CUFF": "伽勒豆蔻手环", - "GALARICA_WREATH": "伽勒豆蔻花圈", - "PEAT_BLOCK": "泥炭块", - "AUSPICIOUS_ARMOR": "庆祝之铠", - "MALICIOUS_ARMOR": "咒术之铠", - "MASTERPIECE_TEACUP": "杰作茶碗", - "METAL_ALLOY": "复合金属", - "SCROLL_OF_DARKNESS": "恶之挂轴", - "SCROLL_OF_WATERS": "水之挂轴", - "SYRUPY_APPLE": "蜜汁苹果" - }, - "FormChangeItem": { - "NONE": "无", - "ABOMASITE": "暴雪王进化石", - "ABSOLITE": "阿勃梭鲁进化石", - "AERODACTYLITE": "化石翼龙进化石", - "AGGRONITE": "波士可多拉进化石", - "ALAKAZITE": "胡地进化石", - "ALTARIANITE": "七夕青鸟进化石", - "AMPHAROSITE": "电龙进化石", - "AUDINITE": "差不多娃娃进化石", - "BANETTITE": "诅咒娃娃进化石", - "BEEDRILLITE": "大针蜂进化石", - "BLASTOISINITE": "水箭龟进化石", - "BLAZIKENITE": "火焰鸡进化石", - "CAMERUPTITE": "喷火驼进化石", - "CHARIZARDITE_X": "喷火龙进化石X", - "CHARIZARDITE_Y": "喷火龙进化石Y", - "DIANCITE": "蒂安希进化石", - "GALLADITE": "艾路雷朵进化石", - "GARCHOMPITE": "烈咬陆鲨进化石", - "GARDEVOIRITE": "沙奈朵进化石", - "GENGARITE": "耿鬼进化石", - "GLALITITE": "冰鬼护进化石", - "GYARADOSITE": "暴鲤龙进化石", - "HERACRONITE": "赫拉克罗斯进化石", - "HOUNDOOMINITE": "黑鲁加进化石", - "KANGASKHANITE": "袋兽进化石", - "LATIASITE": "拉帝亚斯进化石", - "LATIOSITE": "拉帝欧斯进化石", - "LOPUNNITE": "长耳兔进化石", - "LUCARIONITE": "路卡利欧进化石", - "MANECTITE": "雷电兽进化石", - "MAWILITE": "大嘴娃进化石", - "MEDICHAMITE": "恰雷姆进化石", - "METAGROSSITE": "巨金怪进化石", - "MEWTWONITE_X": "超梦进化石X", - "MEWTWONITE_Y": "超梦进化石Y", - "PIDGEOTITE": "大比鸟进化石", - "PINSIRITE": "凯罗斯进化石", - "RAYQUAZITE": "烈空坐进化石", - "SABLENITE": "勾魂眼进化石", - "SALAMENCITE": "暴飞龙进化石", - "SCEPTILITE": "蜥蜴王进化石", - "SCIZORITE": "巨钳螳螂进化石", - "SHARPEDONITE": "巨牙鲨进化石", - "SLOWBRONITE": "呆壳兽进化石", - "STEELIXITE": "大钢蛇进化石", - "SWAMPERTITE": "巨沼怪进化石", - "TYRANITARITE": "班基拉斯进化石", - "VENUSAURITE": "妙蛙花进化石", - "BLUE_ORB": "靛蓝色宝珠", - "RED_ORB": "朱红色宝珠", - "SHARP_METEORITE": "锐利陨石", - "HARD_METEORITE": "坚硬陨石", - "SMOOTH_METEORITE": "光滑陨石", - "ADAMANT_CRYSTAL": "大金刚宝玉", - "LUSTROUS_GLOBE": "大白宝玉", - "GRISEOUS_CORE": "大白金宝玉", - "REVEAL_GLASS": "现形镜", - "GRACIDEA": "葛拉西蒂亚花", - "MAX_MUSHROOMS": "极巨菇菇", - "DARK_STONE": "黑暗石", - "LIGHT_STONE": "光明石", - "PRISON_BOTTLE": "惩戒之壶", - "N_LUNARIZER": "奈克洛露奈合体器", - "N_SOLARIZER": "奈克洛索尔合体器", - "RUSTED_SWORD": "腐朽的剑", - "RUSTED_SHIELD": "腐朽的盾", - "ICY_REINS_OF_UNITY": "牵绊缰绳(冰)", - "SHADOW_REINS_OF_UNITY": "牵绊缰绳(幽灵)", - "WELLSPRING_MASK": "水井面具", - "HEARTHFLAME_MASK": "火灶面具", - "CORNERSTONE_MASK": "础石面具", - "SHOCK_DRIVE": "闪电卡带", - "BURN_DRIVE": "火焰卡带", - "CHILL_DRIVE": "冰冻卡带", - "DOUSE_DRIVE": "水流卡带", - "ULTRANECROZIUM_Z": "究极奈克洛Z", - "FIST_PLATE": "拳头石板", - "SKY_PLATE": "蓝天石板", - "TOXIC_PLATE": "剧毒石板", - "EARTH_PLATE": "大地石板", - "STONE_PLATE": "岩石石板", - "INSECT_PLATE": "玉虫石板", - "SPOOKY_PLATE": "妖怪石板", - "IRON_PLATE": "钢铁石板", - "FLAME_PLATE": "火球石板", - "SPLASH_PLATE": "水滴石板", - "MEADOW_PLATE": "碧绿石板", - "ZAP_PLATE": "雷电石板", - "MIND_PLATE": "神奇石板", - "ICICLE_PLATE": "冰柱石板", - "DRACO_PLATE": "龙之石板", - "DREAD_PLATE": "恶颜石板", - "PIXIE_PLATE": "妖精石板", - "BLANK_PLATE": "净空石板", - "LEGEND_PLATE": "传说石板", - "FIGHTING_MEMORY": "战斗存储碟", - "FLYING_MEMORY": "飞翔存储碟", - "POISON_MEMORY": "毒存储碟", - "GROUND_MEMORY": "大地存储碟", - "ROCK_MEMORY": "岩石存储碟", - "BUG_MEMORY": "虫子存储碟", - "GHOST_MEMORY": "幽灵存储碟", - "STEEL_MEMORY": "钢铁存储碟", - "FIRE_MEMORY": "火焰存储碟", - "WATER_MEMORY": "清水存储碟", - "GRASS_MEMORY": "青草存储碟", - "ELECTRIC_MEMORY": "电子存储碟", - "PSYCHIC_MEMORY": "精神存储碟", - "ICE_MEMORY": "冰雪存储碟", - "DRAGON_MEMORY": "龙存储碟", - "DARK_MEMORY": "黑暗存储碟", - "FAIRY_MEMORY": "妖精存储碟", - "NORMAL_MEMORY": "一般存储碟" - } -} diff --git a/src/locales/zh_CN/modifier.json b/src/locales/zh_CN/modifier.json deleted file mode 100644 index a50cdd35bc1..00000000000 --- a/src/locales/zh_CN/modifier.json +++ /dev/null @@ -1,12 +0,0 @@ -{ - "surviveDamageApply": "{{pokemonNameWithAffix}}用{{typeName}}\n撑住了!", - "turnHealApply": "{{pokemonNameWithAffix}}用{{typeName}}\n回复了体力!", - "hitHealApply": "{{pokemonNameWithAffix}}用{{typeName}}\n回复了体力!", - "pokemonInstantReviveApply": "{{pokemonNameWithAffix}}用{{typeName}}\n恢复了活力!", - "resetNegativeStatStageApply": "{{pokemonNameWithAffix}}降低的能力被{{typeName}}\n复原了!", - "moneyInterestApply": "用{{typeName}}\n获得了 ₽{{moneyAmount}} 利息!", - "turnHeldItemTransferApply": "{{pokemonNameWithAffix}}的{{itemName}}被\n{{pokemonName}}的{{typeName}}吸收了!", - "contactHeldItemTransferApply": "{{pokemonNameWithAffix}}的{{itemName}}被\n{{pokemonName}}的{{typeName}}夺取了!", - "enemyTurnHealApply": "{{pokemonNameWithAffix}}\n回复了一些体力!", - "bypassSpeedChanceApply": "{{pokemonName}}用了{{itemName}}后,行动变快了!" -} \ No newline at end of file diff --git a/src/locales/zh_CN/move-trigger.json b/src/locales/zh_CN/move-trigger.json deleted file mode 100644 index 436f1805c4e..00000000000 --- a/src/locales/zh_CN/move-trigger.json +++ /dev/null @@ -1,71 +0,0 @@ -{ - "hitWithRecoil": "{{pokemonName}}\n受到了反作用力造成的伤害!", - "cutHpPowerUpMove": "{{pokemonName}}\n削减了体力并提升了招式威力!", - "absorbedElectricity": "{{pokemonName}}\n吸收了电力!", - "switchedStatChanges": "{{pokemonName}}和对手互换了\n自己的能力变化!", - "switchedTwoStatChanges": "{{pokemonName}} 和对手互换了自己的{{firstStat}}和{{secondStat}}的能力变化!", - "switchedStat": "{{pokemonName}} 互换了各自的{{stat}}!", - "sharedGuard": "{{pokemonName}} 平分了各自的防守!", - "sharedPower": "{{pokemonName}} 平分了各自的力量!", - "goingAllOutForAttack": "{{pokemonName}}拿出全力了!", - "regainedHealth": "{{pokemonName}}的\n体力回复了!", - "keptGoingAndCrashed": "{{pokemonName}}因势头过猛\n而撞到了地面!", - "fled": "{{pokemonName}}\n逃走了!", - "cannotBeSwitchedOut": "{{pokemonName}}\n无法被收回!", - "swappedAbilitiesWithTarget": "{{pokemonName}}\n互换了各自的特性!", - "coinsScatteredEverywhere": "金币散落一地!", - "attackedByItem": "{{pokemonName}}被\n{{itemName}}袭击了!", - "whippedUpAWhirlwind": "{{pokemonName}}周围的\n空气产生了旋涡!", - "flewUpHigh": "{{pokemonName}}\n飞向了高空!", - "tookInSunlight": "{{pokemonName}}\n吸收了光!", - "dugAHole": "{{pokemonName}}\n钻入了地里!", - "loweredItsHead": "{{pokemonName}}\n把头缩了进去!", - "isGlowing": "强光包围了{{pokemonName}}\n!", - "bellChimed": "铃声响彻四周!", - "foresawAnAttack": "{{pokemonName}}\n预知了未来的攻击!", - "isTighteningFocus": "{{pokemonName}}正在集中注意力!", - "hidUnderwater": "{{pokemonName}}\n潜入了水中!", - "soothingAromaWaftedThroughArea": "怡人的香气扩散了开来!", - "sprangUp": "{{pokemonName}}\n高高地跳了起来!", - "choseDoomDesireAsDestiny": "{{pokemonName}}\n将破灭之愿托付给了未来!", - "vanishedInstantly": "{{pokemonName}}的身影\n瞬间消失了!", - "tookTargetIntoSky": "{{pokemonName}}将{{targetName}}\n带上了高空!", - "becameCloakedInFreezingLight": "{{pokemonName}}\n被冷光包围了!", - "becameCloakedInFreezingAir": "{{pokemonName}}\n被冰冻的空气包围了!", - "isChargingPower": "{{pokemonName}}\n正在积蓄力量!", - "burnedItselfOut": "{{pokemonName}}的火焰燃尽了!", - "startedHeatingUpBeak": "{{pokemonName}}\n开始给鸟嘴加热了!", - "setUpShellTrap": "{{pokemonName}}\n设置了陷阱甲壳!", - "isOverflowingWithSpacePower": "{{pokemonName}}身上\n溢出了宇宙之力!", - "usedUpAllElectricity": "{{pokemonName}}\n用尽电力了!", - "stoleItem": "{{pokemonName}}从{{targetName}}那里\n夺取了{{itemName}}!", - "incineratedItem": "{{pokemonName}}烧没了\n{{targetName}}的{{itemName}}!", - "knockedOffItem": "{{pokemonName}}拍落了\n{{targetName}}的{{itemName}}!", - "tookMoveAttack": "{{pokemonName}}\n受到了{{moveName}}的攻击!", - "cutOwnHpAndMaximizedStat": "{{pokemonName}}\n削减了体力并释放了全部{{statName}}!", - "copiedStatChanges": "{{pokemonName}}复制了\n{{targetName}}的能力变化!", - "magnitudeMessage": "震级{{magnitude}}!", - "tookAimAtTarget": "{{pokemonName}}将目标对准了\n{{targetName}}!", - "transformedIntoType": "{{pokemonName}} \n变成了{{typeName}}属性!", - "copiedMove": "{{pokemonName}}\n复制了{{moveName}}!", - "sketchedMove": "{{pokemonName}}\n对{{moveName}}进行了写生!", - "acquiredAbility": "{{pokemonName}}的特性\n变为{{abilityName}}了!", - "copiedTargetAbility": "{{pokemonName}}复制了\n{{targetName}}的{{abilityName}}!", - "transformedIntoTarget": "{{pokemonName}}\n变身成了{{targetName}}!", - "tryingToTakeFoeDown": "{{pokemonName}}\n想和对手同归于尽!", - "addType": "{{pokemonName}}\n增加了{{typeName}}属性!", - "cannotUseMove": "{{pokemonName}}\n无法使用{{moveName}}!", - "healHp": "{{pokemonName}}的\n体力回复了!", - "sacrificialFullRestore": "{{pokemonName}}的\n治愈之愿实现了!", - "invertStats": "{{pokemonName}}的\n能力变化颠倒过来了!", - "resetStats": "{{pokemonName}}的\n能力变化复原了!", - "statEliminated": "所有能力都复原了!", - "faintCountdown": "{{pokemonName}}\n将在{{turnCount}}回合后灭亡!", - "copyType": "{{pokemonName}}\n变成了{{targetPokemonName}}的属性!", - "suppressAbilities": "{{pokemonName}}的特性\n变得无效了!", - "revivalBlessing": "{{pokemonName}}复活了!", - "swapArenaTags": "{{pokemonName}}\n交换了双方的场地效果!", - "exposedMove": "{{pokemonName}}识破了\n{{targetPokemonName}}的原型!", - "safeguard": "{{targetName}}\n正受到神秘之幕的保护!", - "afterYou": "{{pokemonName}}\n接受了对手的好意!" -} diff --git a/src/locales/zh_CN/move.json b/src/locales/zh_CN/move.json deleted file mode 100644 index 5974271abb2..00000000000 --- a/src/locales/zh_CN/move.json +++ /dev/null @@ -1,3810 +0,0 @@ -{ - "pound": { - "name": "拍击", - "effect": "使用长长的尾巴或手等拍打对手进行攻击" - }, - "karateChop": { - "name": "空手劈", - "effect": "用锋利的手刀劈向对手进行攻击。\n容易击中要害" - }, - "doubleSlap": { - "name": "连环巴掌", - "effect": "用连环巴掌拍打对手进行攻击。\n连续攻击2~5次" - }, - "cometPunch": { - "name": "连续拳", - "effect": "用拳头怒涛般的殴打对手进行攻击。\n连续攻击2~5次" - }, - "megaPunch": { - "name": "百万吨重拳", - "effect": "用充满力量的拳头攻击对手" - }, - "payDay": { - "name": "聚宝功", - "effect": "向对手的身体投掷小金币进行攻击。\n战斗后可以拿到钱" - }, - "firePunch": { - "name": "火焰拳", - "effect": "用充满火焰的拳头攻击对手。\n有时会让对手陷入灼伤状态" - }, - "icePunch": { - "name": "冰冻拳", - "effect": "用充满寒气的拳头攻击对手。\n有时会让对手陷入冰冻状态" - }, - "thunderPunch": { - "name": "雷电拳", - "effect": "用充满电流的拳头攻击对手。\n有时会让对手陷入麻痹状态" - }, - "scratch": { - "name": "抓", - "effect": "用坚硬且无比锋利的爪子抓对手进行攻击" - }, - "viseGrip": { - "name": "夹住", - "effect": "将对手从两侧夹住,给予伤害" - }, - "guillotine": { - "name": "极落钳", - "effect": "用大钳子或剪刀等夹断对手进行攻击。\n只要命中就会一击昏厥" - }, - "razorWind": { - "name": "旋风刀", - "effect": "制造风之刃,于第2回合攻击对手。\n容易击中要害" - }, - "swordsDance": { - "name": "剑舞", - "effect": "激烈地跳起战舞提高气势。\n大幅提高自己的攻击" - }, - "cut": { - "name": "居合劈", - "effect": "用镰刀或爪子等切斩对手进行攻击" - }, - "gust": { - "name": "起风", - "effect": "用翅膀将刮起的狂风袭向对手进行攻击" - }, - "wingAttack": { - "name": "翅膀攻击", - "effect": "大大地展开美丽的翅膀,\n将其撞向对手进行攻击" - }, - "whirlwind": { - "name": "吹飞", - "effect": "吹飞对手,强制拉后备宝可梦上场。\n如果对手为野生宝可梦,\n战斗将直接结束" - }, - "fly": { - "name": "飞翔", - "effect": "第1回合飞上天空,第2回合攻击对手" - }, - "bind": { - "name": "绑紧", - "effect": "使用长长的身体或藤蔓等,\n在4~5回合内绑紧对手进行攻击" - }, - "slam": { - "name": "摔打", - "effect": "使用长长的尾巴或藤蔓等摔打对手\n进行攻击" - }, - "vineWhip": { - "name": "藤鞭", - "effect": "用如同鞭子般弯曲而细长的藤蔓摔\n打对手进行攻击" - }, - "stomp": { - "name": "踩踏", - "effect": "用大脚踩踏对手进行攻击。\n有时会使对手畏缩" - }, - "doubleKick": { - "name": "二连踢", - "effect": "用2只脚踢飞对手进行攻击。\n连续2次给予伤害" - }, - "megaKick": { - "name": "百万吨重踢", - "effect": "使出力大无穷的重踢踢飞对手进行攻击" - }, - "jumpKick": { - "name": "飞踢", - "effect": "使出高高的腾空踢攻击对手。\n如果踢偏则自己会受到伤害" - }, - "rollingKick": { - "name": "回旋踢", - "effect": "一边使身体快速旋转,\n一边踢飞对手进行攻击。\n有时会使对手畏缩" - }, - "sandAttack": { - "name": "泼沙", - "effect": "向对手脸上泼沙子,从而降低命中率" - }, - "headbutt": { - "name": "头锤", - "effect": "将头伸出,笔直地扑向对手进行攻击。\n有时会使对手畏缩" - }, - "hornAttack": { - "name": "角撞", - "effect": "用尖锐的角攻击对手" - }, - "furyAttack": { - "name": "乱击", - "effect": "用角或喙刺向对手进行攻击。\n连续攻击2~5次" - }, - "hornDrill": { - "name": "角钻", - "effect": "用旋转的角刺入对手进行攻击。\n只要命中就会一击昏厥" - }, - "tackle": { - "name": "撞击", - "effect": "用整个身体撞向对手进行攻击" - }, - "bodySlam": { - "name": "泰山压顶", - "effect": "用整个身体压住对手进行攻击。\n有时会让对手陷入麻痹状态" - }, - "wrap": { - "name": "紧束", - "effect": "使用长长的身体或藤蔓等,\n在4~5回合内紧束对手进行攻击" - }, - "takeDown": { - "name": "猛撞", - "effect": "以惊人的气势撞向对手进行攻击。\n自己也会受到少许伤害" - }, - "thrash": { - "name": "大闹一番", - "effect": "在2~3回合内,乱打一气地攻击对手。\n大闹一番后自己会陷入混乱" - }, - "doubleEdge": { - "name": "舍身冲撞", - "effect": "拼命地猛撞向对手进行攻击。\n自己也会受到不小的伤害" - }, - "tailWhip": { - "name": "摇尾巴", - "effect": "可爱地左右摇晃尾巴,\n诱使对手疏忽大意。会降低对手的防御" - }, - "poisonSting": { - "name": "毒针", - "effect": "将有毒的针刺入对手进行攻击。\n有时会让对手陷入中毒状态" - }, - "twineedle": { - "name": "双针", - "effect": "将2根针刺入对手,连续2次给予伤害。\n有时会让对手陷入中毒状态" - }, - "pinMissile": { - "name": "飞弹针", - "effect": "向对手发射锐针进行攻击。\n连续攻击2~5次" - }, - "leer": { - "name": "瞪眼", - "effect": "用犀利的眼神使其害怕,\n从而降低对手的防御" - }, - "bite": { - "name": "咬住", - "effect": "用尖锐的牙咬住对手进行攻击。\n有时会使对手畏缩" - }, - "growl": { - "name": "叫声", - "effect": "让对手听可爱的叫声,\n引开注意力使其疏忽,\n从而降低对手的攻击" - }, - "roar": { - "name": "吼叫", - "effect": "放走对手,强制拉后备宝可梦上场。\n如果对手为野生宝可梦,\n战斗将直接结束" - }, - "sing": { - "name": "唱歌", - "effect": "让对手听舒适、美妙的歌声,\n从而陷入睡眠状态" - }, - "supersonic": { - "name": "超音波", - "effect": "从身体发出特殊的音波,\n从而使对手混乱" - }, - "sonicBoom": { - "name": "音爆", - "effect": "将冲击波撞向对手进行攻击。\n必定会给予20的伤害" - }, - "disable": { - "name": "定身法", - "effect": "阻碍对手行动,之前使出的招式将\n在4回合内无法使用" - }, - "acid": { - "name": "溶解液", - "effect": "将强酸泼向对手进行攻击。\n有时会降低对手的特防" - }, - "ember": { - "name": "火花", - "effect": "向对手发射小型火焰进行攻击。\n有时会让对手陷入灼伤状态" - }, - "flamethrower": { - "name": "喷射火焰", - "effect": "向对手发射烈焰进行攻击。\n有时会让对手陷入灼伤状态" - }, - "mist": { - "name": "白雾", - "effect": "用白雾覆盖身体。在5回合内不会\n让对手降低自己的能力" - }, - "waterGun": { - "name": "水枪", - "effect": "向对手猛烈地喷射水流进行攻击" - }, - "hydroPump": { - "name": "水炮", - "effect": "向对手猛烈地喷射大量水流进行攻击" - }, - "surf": { - "name": "冲浪", - "effect": "利用大浪攻击自己周围所有的宝可梦" - }, - "iceBeam": { - "name": "冰冻光束", - "effect": "向对手发射冰冻光束进行攻击。\n有时会让对手陷入冰冻状态" - }, - "blizzard": { - "name": "暴风雪", - "effect": "将猛烈的暴风雪刮向对手进行攻击。\n有时会让对手陷入冰冻状态" - }, - "psybeam": { - "name": "幻象光线", - "effect": "向对手发射神奇的光线进行攻击。\n有时会使对手混乱" - }, - "bubbleBeam": { - "name": "泡沫光线", - "effect": "向对手猛烈地喷射泡沫进行攻击。\n有时会降低对手的速度" - }, - "auroraBeam": { - "name": "极光束", - "effect": "向对手发射虹色光束进行攻击。\n有时会降低对手的攻击" - }, - "hyperBeam": { - "name": "破坏光线", - "effect": "向对手发射强烈的光线进行攻击。\n下一回合自己将无法动弹" - }, - "peck": { - "name": "啄", - "effect": "用尖锐的喙或角刺向对手进行攻击" - }, - "drillPeck": { - "name": "啄钻", - "effect": "一边旋转,一边将尖喙刺入对手进行攻击" - }, - "submission": { - "name": "深渊翻滚", - "effect": "将对手连同自己一起摔向地面进行攻击。\n自己也会受到少许伤害" - }, - "lowKick": { - "name": "踢倒", - "effect": "用力踢对手的脚,使其摔倒进行攻击。\n对手越重,威力越大" - }, - "counter": { - "name": "双倍奉还", - "effect": "从对手那里受到物理攻击的伤害将\n以2倍返还给同一个对手" - }, - "seismicToss": { - "name": "地球上投", - "effect": "利用引力将对手甩飞出去。\n给予对手和自己等级相同的伤害" - }, - "strength": { - "name": "怪力", - "effect": "使出浑身力气殴打对手进行攻击" - }, - "absorb": { - "name": "吸取", - "effect": "吸取对手的养分进行攻击。\n可以回复给予对手伤害的一半HP" - }, - "megaDrain": { - "name": "超级吸取", - "effect": "吸取对手的养分进行攻击。\n可以回复给予对手伤害的一半HP" - }, - "leechSeed": { - "name": "寄生种子", - "effect": "植入寄生种子后,将在每回合一点\n一点吸取对手的HP,\n从而用来回复自己的HP" - }, - "growth": { - "name": "生长", - "effect": "让身体一下子长大,从而提高攻击和特攻" - }, - "razorLeaf": { - "name": "飞叶快刀", - "effect": "飞出叶片,切斩对手进行攻击。\n容易击中要害" - }, - "solarBeam": { - "name": "日光束", - "effect": "第1回合收集满满的日光,\n第2回合发射光束进行攻击" - }, - "poisonPowder": { - "name": "毒粉", - "effect": "撒出毒粉,从而让对手陷入中毒状态" - }, - "stunSpore": { - "name": "麻痹粉", - "effect": "撒出麻痹粉,从而让对手陷入麻痹状态" - }, - "sleepPowder": { - "name": "催眠粉", - "effect": "撒出催眠粉,从而让对手陷入睡眠状态" - }, - "petalDance": { - "name": "花瓣舞", - "effect": "在2~3回合内,散落花瓣攻击对手。\n之后自己会陷入混乱" - }, - "stringShot": { - "name": "吐丝", - "effect": "用口中吐出的丝缠绕对手,\n从而大幅降低对手的速度" - }, - "dragonRage": { - "name": "龙之怒", - "effect": "将愤怒的冲击波撞向对手进行攻击。\n必定会给予40的伤害" - }, - "fireSpin": { - "name": "火焰旋涡", - "effect": "将对手困在激烈的火焰旋涡中,\n在4~5回合内进行攻击" - }, - "thunderShock": { - "name": "电击", - "effect": "发出电流刺激对手进行攻击。\n有时会让对手陷入麻痹状态" - }, - "thunderbolt": { - "name": "十万伏特", - "effect": "向对手发出强力电击进行攻击。\n有时会让对手陷入麻痹状态" - }, - "thunderWave": { - "name": "电磁波", - "effect": "向对手发出微弱的电击,\n从而让对手陷入麻痹状态" - }, - "thunder": { - "name": "打雷", - "effect": "向对手劈下暴雷进行攻击。\n有时会让对手陷入麻痹状态" - }, - "rockThrow": { - "name": "落石", - "effect": "拿起小岩石,投掷对手进行攻击" - }, - "earthquake": { - "name": "地震", - "effect": "利用地震的冲击,攻击自己周围所\n有的宝可梦" - }, - "fissure": { - "name": "地裂", - "effect": "让对手掉落于地裂的裂缝中进行攻击。\n只要命中就会一击昏厥" - }, - "dig": { - "name": "挖洞", - "effect": "第1回合钻入地底,第2回合攻击对手" - }, - "toxic": { - "name": "剧毒", - "effect": "让对手陷入剧毒状态。\n随着回合的推进,中毒伤害会增加" - }, - "confusion": { - "name": "念力", - "effect": "向对手发送微弱的念力进行攻击。\n有时会使对手混乱" - }, - "psychic": { - "name": "精神强念", - "effect": "向对手发送强大的念力进行攻击。\n有时会降低对手的特防" - }, - "hypnosis": { - "name": "催眠术", - "effect": "施以诱导睡意的暗示,\n让对手陷入睡眠状态" - }, - "meditate": { - "name": "瑜伽姿势", - "effect": "唤醒身体深处沉睡的力量,\n从而提高自己的攻击" - }, - "agility": { - "name": "高速移动", - "effect": "让身体放松变得轻盈,\n以便高速移动。大幅提高自己的速度" - }, - "quickAttack": { - "name": "电光一闪", - "effect": "以迅雷不及掩耳之势扑向对手。\n必定能够先制攻击" - }, - "rage": { - "name": "愤怒", - "effect": "如果在使出招式后受到攻击的话,\n会因愤怒的力量而提高攻击" - }, - "teleport": { - "name": "瞬间移动", - "effect": "当有后备宝可梦时使用,\n就可以进行替换。\n野生的宝可梦使用则会逃走" - }, - "nightShade": { - "name": "黑夜魔影", - "effect": "显示恐怖幻影,只给予对手和自己\n等级相同的伤害" - }, - "mimic": { - "name": "模仿", - "effect": "可以将对手最后使用的招式,\n在战斗内变成自己的招式" - }, - "screech": { - "name": "刺耳声", - "effect": "发出不由自主想要捂起耳朵的刺耳声,\n从而大幅降低对手的防御" - }, - "doubleTeam": { - "name": "影子分身", - "effect": "通过快速移动来制造分身,\n扰乱对手,从而提高闪避率" - }, - "recover": { - "name": "自我再生", - "effect": "让细胞再生,从而回复自己最大H\nP的一半" - }, - "harden": { - "name": "变硬", - "effect": "全身使劲,让身体变硬,\n从而提高自己的防御" - }, - "minimize": { - "name": "变小", - "effect": "蜷缩身体显得很小,从而大幅提高\n自己的闪避率" - }, - "smokescreen": { - "name": "烟幕", - "effect": "向对手喷出烟或墨汁等,\n从而降低对手的命中率" - }, - "confuseRay": { - "name": "奇异之光", - "effect": "显示奇怪的光,扰乱对手。\n使对手混乱" - }, - "withdraw": { - "name": "缩入壳中", - "effect": "缩入壳里保护身体,从而提高自己的防御" - }, - "defenseCurl": { - "name": "变圆", - "effect": "将身体蜷曲变圆,从而提高自己的防御" - }, - "barrier": { - "name": "屏障", - "effect": "制造坚固的壁障,从而大幅提高自\n己的防御" - }, - "lightScreen": { - "name": "光墙", - "effect": "利用神奇的墙壁,在5回合内减弱\n从对手那里受到的特殊攻击的伤害" - }, - "haze": { - "name": "黑雾", - "effect": "升起黑雾,将正在场上战斗的全体\n宝可梦的能力变回原点" - }, - "reflect": { - "name": "反射壁", - "effect": "利用神奇的墙壁,在5回合内减弱\n从对手那里受到的物理攻击的伤害" - }, - "focusEnergy": { - "name": "聚气", - "effect": "深深地吸口气,集中精神。\n自己的攻击会变得容易击中要害" - }, - "bide": { - "name": "忍耐", - "effect": "在2回合内忍受攻击,\n受到的伤害会2倍返还给对手" - }, - "metronome": { - "name": "挥指", - "effect": "挥动手指刺激自己的大脑,\n从许多的招式中随机使出1个" - }, - "mirrorMove": { - "name": "鹦鹉学舌", - "effect": "模仿对手使用的招式,\n自己也使用相同招式" - }, - "selfDestruct": { - "name": "玉石俱碎", - "effect": "引发爆炸,攻击自己周围所有的宝可梦。\n使用后陷入昏厥" - }, - "eggBomb": { - "name": "炸蛋", - "effect": "向对手用力投掷大大的蛋进行攻击" - }, - "lick": { - "name": "舌舔", - "effect": "用长长的舌头,舔遍对手进行攻击。\n有时会让对手陷入麻痹状态" - }, - "smog": { - "name": "浊雾", - "effect": "将肮脏的浓雾吹向对手进行攻击。\n有时会让对手陷入中毒状态" - }, - "sludge": { - "name": "污泥攻击", - "effect": "用污泥投掷对手进行攻击。\n有时会让对手陷入中毒状态" - }, - "boneClub": { - "name": "骨棒", - "effect": "用手中的骨头殴打对手进行攻击。\n有时会使对手畏缩" - }, - "fireBlast": { - "name": "大字爆炎", - "effect": "用大字形状的火焰烧尽对手。\n有时会让对手陷入灼伤状态" - }, - "waterfall": { - "name": "攀瀑", - "effect": "以惊人的气势扑向对手。\n有时会使对手畏缩" - }, - "clamp": { - "name": "贝壳夹击", - "effect": "用非常坚固且厚实的贝壳,\n在4~5回合内夹住对手进行攻击" - }, - "swift": { - "name": "高速星星", - "effect": "发射星形的光攻击对手。\n攻击必定会命中" - }, - "skullBash": { - "name": "火箭头锤", - "effect": "第1回合把头缩进去,\n从而提高防御。第2回合攻击对手" - }, - "spikeCannon": { - "name": "尖刺加农炮", - "effect": "向对手发射锐针进行攻击。\n连续攻击2~5次" - }, - "constrict": { - "name": "缠绕", - "effect": "用触手或青藤等缠绕进行攻击。\n有时会降低对手的速度" - }, - "amnesia": { - "name": "瞬间失忆", - "effect": "将头脑清空,瞬间忘记某事,\n从而大幅提高自己的特防" - }, - "kinesis": { - "name": "折弯汤匙", - "effect": "折弯汤匙引开注意,从而降低对手\n的命中率" - }, - "softBoiled": { - "name": "生蛋", - "effect": "回复自己最大HP的一半" - }, - "highJumpKick": { - "name": "飞膝踢", - "effect": "跳起后用膝盖撞对手进行攻击。\n如果撞偏则自己会受到伤害" - }, - "glare": { - "name": "大蛇瞪眼", - "effect": "用腹部的花纹使对手害怕,\n从而让其陷入麻痹状态" - }, - "dreamEater": { - "name": "食梦", - "effect": "吃掉正在睡觉的对手的梦进行攻击。\n回复对手所受到伤害的一半HP" - }, - "poisonGas": { - "name": "毒瓦斯", - "effect": "将毒瓦斯吹到对手的脸上,\n从而让对手陷入中毒状态" - }, - "barrage": { - "name": "投球", - "effect": "向对手投掷圆形物体进行攻击。\n连续攻击2~5次" - }, - "leechLife": { - "name": "吸血", - "effect": "吸取血液攻击对手。可以回复给予\n对手伤害的一半HP" - }, - "lovelyKiss": { - "name": "恶魔之吻", - "effect": "用恐怖的脸强吻对手。\n让对手陷入睡眠状态" - }, - "skyAttack": { - "name": "神鸟猛击", - "effect": "第2回合攻击对手。偶尔使对手畏缩。\n也容易击中要害" - }, - "transform": { - "name": "变身", - "effect": "变身成对手宝可梦的样子,\n能够使用和对手完全相同的招式" - }, - "bubble": { - "name": "泡沫", - "effect": "向对手用力吹起无数泡泡进行攻击。\n有时会降低对手的速度" - }, - "dizzyPunch": { - "name": "迷昏拳", - "effect": "有节奏地出拳攻击对手。\n有时会使对手混乱" - }, - "spore": { - "name": "蘑菇孢子", - "effect": "沙沙沙地撒满具有催眠效果的孢子,\n从而让对手陷入睡眠状态" - }, - "flash": { - "name": "闪光", - "effect": "使出光芒,从而降低对手的命中率。\n也可在阴暗的洞窟里照亮四周" - }, - "psywave": { - "name": "精神波", - "effect": "向对手发射神奇的念波进行攻击。\n每次使用,伤害都会改变" - }, - "splash": { - "name": "跃起", - "effect": "也不攻击只是一蹦一蹦地跳,\n什么都不会发生…" - }, - "acidArmor": { - "name": "溶化", - "effect": "通过细胞的变化进行液化,\n从而大幅提高自己的防御" - }, - "crabhammer": { - "name": "蟹钳锤", - "effect": "用大钳子敲打对手进行攻击。\n容易击中要害" - }, - "explosion": { - "name": "大爆炸", - "effect": "引发大爆炸,\n攻击自己周围所有的宝可梦。\n使用后自己会陷入昏厥" - }, - "furySwipes": { - "name": "乱抓", - "effect": "用爪子或镰刀等抓对手进行攻击。\n连续攻击2~5次" - }, - "bonemerang": { - "name": "骨头回力镖", - "effect": "用手中的骨头投掷对手,\n来回连续2次给予伤害" - }, - "rest": { - "name": "睡觉", - "effect": "连续睡上2回合。回复自己的全部\nHP以及治愈所有异常状态" - }, - "rockSlide": { - "name": "岩崩", - "effect": "将大岩石猛烈地撞向对手进行攻击。\n有时会使对手畏缩" - }, - "hyperFang": { - "name": "终结门牙", - "effect": "用锋利的门牙牢牢地咬住对手进行攻击。\n有时会使对手畏缩" - }, - "sharpen": { - "name": "棱角化", - "effect": "增加身体的角,变得棱棱角角,\n从而提高自己的攻击" - }, - "conversion": { - "name": "纹理", - "effect": "将自己的属性转换成和已学会的招\n式中第一个招式相同的属性" - }, - "triAttack": { - "name": "三重攻击", - "effect": "用3种光线进行攻击。\n有时会让对手陷入麻痹、\n灼伤或冰冻的状态" - }, - "superFang": { - "name": "愤怒门牙", - "effect": "用锋利的门牙猛烈地咬住对手进行攻击。\n对手的HP减半" - }, - "slash": { - "name": "劈开", - "effect": "用爪子或镰刀等劈开对手进行攻击。\n容易击中要害" - }, - "substitute": { - "name": "替身", - "effect": "削减少许自己的HP,\n制造分身。分身将成为自己的替身" - }, - "struggle": { - "name": "挣扎", - "effect": "当自己的PP耗尽时,\n努力挣扎攻击对手。\n自己也会受到少许伤害" - }, - "sketch": { - "name": "写生", - "effect": "将对手使用的招式变成自己的招式。\n使用1次后写生消失" - }, - "tripleKick": { - "name": "三连踢", - "effect": "连续3次踢对手进行攻击。\n每踢中一次,威力就会提高" - }, - "thief": { - "name": "小偷", - "effect": "攻击的同时盗取对手的道具。" - }, - "spiderWeb": { - "name": "蛛网", - "effect": "将黏糊糊的细丝一层一层缠住对手,\n使其不能从战斗中逃走" - }, - "mindReader": { - "name": "心之眼", - "effect": "用心感受对手的行动,\n下次攻击必定会击中对手" - }, - "nightmare": { - "name": "恶梦", - "effect": "让在睡眠状态下的对手做恶梦,\n每回合会缓缓减少HP" - }, - "flameWheel": { - "name": "火焰轮", - "effect": "让火焰覆盖全身,猛撞向对手进行攻击。\n有时会让对手陷入灼伤状态" - }, - "snore": { - "name": "打鼾", - "effect": "在自己睡觉时,发出噪音进行攻击。\n有时会使对手畏缩" - }, - "curse": { - "name": "诅咒", - "effect": "使用该招式的宝可梦,\n其属性是幽灵属性或其他属性时,\n效果会不一样" - }, - "flail": { - "name": "抓狂", - "effect": "抓狂般乱打进行攻击。\n自己的HP越少,招式的威力越大" - }, - "conversion2": { - "name": "纹理2", - "effect": "为了可以抵抗对手最后使用的招式,\n从而使自己的属性发生变化" - }, - "aeroblast": { - "name": "气旋攻击", - "effect": "发射空气旋涡进行攻击。\n容易击中要害" - }, - "cottonSpore": { - "name": "棉孢子", - "effect": "将棉花般柔软的孢子紧贴对手,\n从而大幅降低对手的速度" - }, - "reversal": { - "name": "绝处逢生", - "effect": "竭尽全力进行攻击。自己的HP越少,\n招式的威力越大" - }, - "spite": { - "name": "怨恨", - "effect": "对对手最后使用的招式怀有怨恨,\n减少4PP该招式" - }, - "powderSnow": { - "name": "细雪", - "effect": "将冰冷的细雪吹向对手进行攻击。\n有时会让对手陷入冰冻状态" - }, - "protect": { - "name": "守住", - "effect": "完全抵挡对手的攻击。\n连续使出则容易失败" - }, - "machPunch": { - "name": "音速拳", - "effect": "以迅雷不及掩耳之势出拳。\n必定能够先制攻击" - }, - "scaryFace": { - "name": "可怕面孔", - "effect": "用恐怖的表情瞪着对手,\n使其害怕,从而大幅降低对手的速度" - }, - "feintAttack": { - "name": "出奇一击", - "effect": "悄悄地靠近对手,趁其不备进行殴打。\n攻击必定会命中" - }, - "sweetKiss": { - "name": "天使之吻", - "effect": "像天使般可爱地亲吻对手,\n从而使对手混乱" - }, - "bellyDrum": { - "name": "腹鼓", - "effect": "将自己的HP减少到最大HP的一半,\n从而最大限度提高自己的攻击" - }, - "sludgeBomb": { - "name": "污泥炸弹", - "effect": "用污泥投掷对手进行攻击。\n有时会让对手陷入中毒状态" - }, - "mudSlap": { - "name": "掷泥", - "effect": "向对手的脸等投掷泥块进行攻击。\n会降低对手的命中率" - }, - "octazooka": { - "name": "章鱼桶炮", - "effect": "向对手的脸等喷出墨汁进行攻击。\n有时会降低对手的命中率" - }, - "spikes": { - "name": "撒菱", - "effect": "在对手的脚下扔撒菱。\n对替换出场的对手的宝可梦给予伤害" - }, - "zapCannon": { - "name": "电磁炮", - "effect": "发射大炮一样的电流进行攻击。\n让对手陷入麻痹状态" - }, - "foresight": { - "name": "识破", - "effect": "使出后对幽灵属性宝可梦没有效果\n的招式以及闪避率高的对手,\n变得能够打中" - }, - "destinyBond": { - "name": "同命", - "effect": "使出招式后,当受到对手攻击\n陷入昏厥时,对手也会一同昏厥。\n连续使出则会失败" - }, - "perishSong": { - "name": "终焉之歌", - "effect": "倾听歌声的宝可梦经过3回合陷入昏厥。\n替换后效果消失" - }, - "icyWind": { - "name": "冰冻之风", - "effect": "将结冰的冷气吹向对手进行攻击。\n会降低对手的速度" - }, - "detect": { - "name": "看穿", - "effect": "完全抵挡对手的攻击。\n连续使出则容易失败" - }, - "boneRush": { - "name": "骨棒乱打", - "effect": "用坚硬的骨头殴打对手进行攻击。\n连续攻击2~5次" - }, - "lockOn": { - "name": "锁定", - "effect": "紧紧瞄准对手,下次攻击必定会打中" - }, - "outrage": { - "name": "逆鳞", - "effect": "在2~3回合内,乱打一气地进行攻击。\n大闹一番后自己会陷入混乱" - }, - "sandstorm": { - "name": "沙暴", - "effect": "在5回合内扬起沙暴,\n除岩石、地面和钢属性以外的宝可梦,\n都会受到伤害。岩石属性的特防还会提高" - }, - "gigaDrain": { - "name": "终极吸取", - "effect": "吸取对手的养分进行攻击。\n可以回复给予对手伤害的一半HP" - }, - "endure": { - "name": "挺住", - "effect": "即使受到攻击,也至少会留下1HP。\n连续使出则容易失败" - }, - "charm": { - "name": "撒娇", - "effect": "可爱地凝视,诱使对手疏忽大意,\n从而大幅降低对手的攻击" - }, - "rollout": { - "name": "滚动", - "effect": "在5回合内连续滚动攻击对手。\n招式每次击中,威力就会提高" - }, - "falseSwipe": { - "name": "点到为止", - "effect": "对手的HP至少会留下1HP,\n如此般手下留情地攻击" - }, - "swagger": { - "name": "虚张声势", - "effect": "激怒对手,使其混乱。\n因为愤怒,对手的攻击会大幅提高" - }, - "milkDrink": { - "name": "喝牛奶", - "effect": "回复自己最大HP的一半" - }, - "spark": { - "name": "电光", - "effect": "让电流覆盖全身,猛撞向对手进行攻击。\n有时会让对手陷入麻痹状态" - }, - "furyCutter": { - "name": "连斩", - "effect": "用镰刀或爪子等切斩对手进行攻击。\n连续击中,威力就会提高" - }, - "steelWing": { - "name": "钢翼", - "effect": "用坚硬的翅膀敲打对手进行攻击。\n有时会提高自己的防御" - }, - "meanLook": { - "name": "黑色目光", - "effect": "用好似要勾人心魂的黑色目光一动\n不动地凝视对手,使其不能从战斗中逃走" - }, - "attract": { - "name": "迷人", - "effect": "♂诱惑♀或♀诱惑♂,让对手着迷。\n对手将很难使出招式" - }, - "sleepTalk": { - "name": "梦话", - "effect": "从自己已学会的招式中任意使出1个。\n只能在自己睡觉时使用" - }, - "healBell": { - "name": "治愈铃声", - "effect": "让同伴听舒适的铃音,\n从而治愈我方全员的异常状态" - }, - "return": { - "name": "报恩", - "effect": "为了训练家而全力攻击对手。\n亲密度越高,威力越大" - }, - "present": { - "name": "礼物", - "effect": "递给对手设有圈套的盒子进行攻击。\n也有可能回复对手HP" - }, - "frustration": { - "name": "迁怒", - "effect": "为了发泄不满而全力攻击对手。\n亲密度越低,威力越大" - }, - "safeguard": { - "name": "神秘守护", - "effect": "在5回合内被神奇的力量守护,\n从而不会陷入异常状态" - }, - "painSplit": { - "name": "分担痛楚", - "effect": "将自己的HP和对手的HP相加,\n然后自己和对手友好地平分" - }, - "sacredFire": { - "name": "神圣之火", - "effect": "用神秘的火焰烧尽对手进行攻击。\n有时会让对手陷入灼伤状态" - }, - "magnitude": { - "name": "震级", - "effect": "晃动地面,攻击自己周围所有的宝可梦。\n招式的威力会有各种变化" - }, - "dynamicPunch": { - "name": "爆裂拳", - "effect": "使出浑身力气出拳进行攻击。\n必定会使对手混乱" - }, - "megahorn": { - "name": "超级角击", - "effect": "用坚硬且华丽的角狠狠地刺入对手\n进行攻击" - }, - "dragonBreath": { - "name": "龙息", - "effect": "将强烈的气息吹向对手进行攻击。\n有时会让对手陷入麻痹状态" - }, - "batonPass": { - "name": "接棒", - "effect": "和后备宝可梦进行替换。\n换上的宝可梦能直接继承其能力的变化" - }, - "encore": { - "name": "再来一次", - "effect": "让对手接受再来一次,\n连续3次使出最后使用的招式" - }, - "pursuit": { - "name": "追打", - "effect": "当对手替换宝可梦上场时\n使出此招式的话,\n能够以2倍的威力进行攻击" - }, - "rapidSpin": { - "name": "高速旋转", - "effect": "通过旋转来攻击对手。\n可以摆脱绑紧、紧束、寄生种子等招式。\n还能提高自己的速度" - }, - "sweetScent": { - "name": "甜甜香气", - "effect": "用香气大幅降低对手的闪避率" - }, - "ironTail": { - "name": "铁尾", - "effect": "使用坚硬的尾巴摔打对手进行攻击。\n有时会降低对手的防御" - }, - "metalClaw": { - "name": "金属爪", - "effect": "用钢铁之爪劈开对手进行攻击。\n有时会提高自己的攻击" - }, - "vitalThrow": { - "name": "借力摔", - "effect": "会在对手之后进行攻击。\n但是自己的攻击必定会命中" - }, - "morningSun": { - "name": "晨光", - "effect": "回复自己的HP。根据天气的不同,\n回复量也会有所变化" - }, - "synthesis": { - "name": "光合作用", - "effect": "回复自己的HP。根据天气的不同,\n回复量也会有所变化" - }, - "moonlight": { - "name": "月光", - "effect": "回复自己的HP。根据天气的不同,\n回复量也会有所变化" - }, - "hiddenPower": { - "name": "觉醒力量", - "effect": "招式的属性会随着使用此招式的宝\n可梦而改变" - }, - "crossChop": { - "name": "十字劈", - "effect": "用两手呈十字劈打对手进行攻击。\n容易击中要害" - }, - "twister": { - "name": "龙卷风", - "effect": "兴起龙卷风,将对手卷入进行攻击。\n有时会使对手畏缩" - }, - "rainDance": { - "name": "求雨", - "effect": "在5回合内一直降雨,\n从而提高水属性的招式威力。\n火属性的招式威力则降低" - }, - "sunnyDay": { - "name": "大晴天", - "effect": "在5回合内让日照变得强烈,\n从而提高火属性的招式威力。\n水属性的招式威力则降低" - }, - "crunch": { - "name": "咬碎", - "effect": "用利牙咬碎对手进行攻击。\n有时会降低对手的防御" - }, - "mirrorCoat": { - "name": "镜面反射", - "effect": "从对手那里受到特殊攻击的伤害将\n以2倍返还给同一个对手" - }, - "psychUp": { - "name": "自我暗示", - "effect": "向自己施以自我暗示,\n将能力变化的状态变得和对手一样" - }, - "extremeSpeed": { - "name": "神速", - "effect": "以迅雷不及掩耳之势猛\n撞向对手进行攻击。\n必定能够先制攻击" - }, - "ancientPower": { - "name": "原始之力", - "effect": "用原始之力进行攻击。\n有时会提高自己所有的能力" - }, - "shadowBall": { - "name": "暗影球", - "effect": "投掷一团黑影进行攻击。\n有时会降低对手的特防" - }, - "futureSight": { - "name": "预知未来", - "effect": "在使用招式2回合后,\n向对手发送一团念力进行攻击" - }, - "rockSmash": { - "name": "碎岩", - "effect": "用拳头进行攻击。有时会降低对手的防御" - }, - "whirlpool": { - "name": "潮旋", - "effect": "将对手困在激烈的水流旋涡中,\n在4~5回合内进行攻击" - }, - "beatUp": { - "name": "围攻", - "effect": "我方全员进行攻击。同行的宝可梦越多,\n招式的攻击次数越多" - }, - "fakeOut": { - "name": "击掌奇袭", - "effect": "进行先制攻击,使对手畏缩。\n要在出场后立刻使出才能成功" - }, - "uproar": { - "name": "吵闹", - "effect": "在3回合内大吵大闹攻击对手。\n在此期间谁都不能入眠" - }, - "stockpile": { - "name": "蓄力", - "effect": "积蓄力量,提高自己的防御和特防。\n最多积蓄3次" - }, - "spitUp": { - "name": "喷出", - "effect": "将积蓄的力量撞向对手进行攻击。\n积蓄得越多,威力越大" - }, - "swallow": { - "name": "吞下", - "effect": "将积蓄的力量吞下,\n从而回复自己的HP。\n积蓄得越多,回复越大" - }, - "heatWave": { - "name": "热风", - "effect": "将炎热的气息吹向对手进行攻击。\n有时会让对手陷入灼伤状态" - }, - "hail": { - "name": "冰雹", - "effect": "在5回合内一直降冰雹,\n除冰属性的宝可梦以外,\n给予全体宝可梦伤害" - }, - "torment": { - "name": "无理取闹", - "effect": "向对手无理取闹,令其不能连续2\n次使出相同招式" - }, - "flatter": { - "name": "吹捧", - "effect": "吹捧对手,使其混乱。\n同时还会提高对手的特攻" - }, - "willOWisp": { - "name": "磷火", - "effect": "放出怪异的火焰,从而让对手陷入\n灼伤状态" - }, - "memento": { - "name": "临别礼物", - "effect": "虽然会使自己陷入昏厥,\n但是能够大幅降低对手的攻击和特攻" - }, - "facade": { - "name": "硬撑", - "effect": "当自己处于中毒、麻痹、灼伤状态时,\n向对手使出此招式的话,\n威力会变成2倍" - }, - "focusPunch": { - "name": "真气拳", - "effect": "集中精神出拳。在招式使出前若受\n到攻击则会失败" - }, - "smellingSalts": { - "name": "清醒", - "effect": "对于麻痹状态下的对手,\n威力会变成2倍。\n但相反对手的麻痹也会被治愈" - }, - "followMe": { - "name": "看我嘛", - "effect": "引起对手的注意,将对手的攻击全\n部转移到自己身上" - }, - "naturePower": { - "name": "自然之力", - "effect": "用自然之力进行攻击。\n根据所使用场所的不同,\n使出的招式也会有所变化" - }, - "charge": { - "name": "充电", - "effect": "变为充电状态,提高下次使出的电\n属性的招式威力。自己的特防也会提高" - }, - "taunt": { - "name": "挑衅", - "effect": "使对手愤怒。在3回合内让对手只\n能使出给予伤害的招式" - }, - "helpingHand": { - "name": "帮助", - "effect": "帮助伙伴。被帮助的宝可梦,\n其招式威力变得比平时大" - }, - "trick": { - "name": "戏法", - "effect": "抓住对手的空隙,交换自己和对手\n的持有物" - }, - "rolePlay": { - "name": "扮演", - "effect": "扮演对手,让自己的特性变得和对手相同" - }, - "wish": { - "name": "祈愿", - "effect": "在下一回合回复自己或是替换出场\n的宝可梦最大HP的一半" - }, - "assist": { - "name": "借助", - "effect": "向同伴紧急求助,从我方宝可梦已\n学会的招式中随机使用1个" - }, - "ingrain": { - "name": "扎根", - "effect": "在大地上扎根,每回合回复自己的HP。\n因为扎根了,所以不能替换宝可梦" - }, - "superpower": { - "name": "蛮力", - "effect": "发挥惊人的力量攻击对手。\n自己的攻击和防御会降低" - }, - "magicCoat": { - "name": "魔法反射", - "effect": "当对手使出会变成异常状态的招式\n或寄生种子等时,会将对手的招式\n反射回去" - }, - "recycle": { - "name": "回收利用", - "effect": "使战斗中已经消耗掉的\n自己的持有物再生,\n并可以再次使用" - }, - "revenge": { - "name": "报复", - "effect": "如果受到对手的招式攻击,\n就能给予对手2倍的伤害" - }, - "brickBreak": { - "name": "劈瓦", - "effect": "将手刀猛烈地挥下攻击对手。\n还可以破坏光墙和反射壁等" - }, - "yawn": { - "name": "哈欠", - "effect": "打个大哈欠引起睡意。\n在下一回合让对手陷入睡眠状态" - }, - "knockOff": { - "name": "拍落", - "effect": "拍落对手的持有物,直到战斗结束\n都不能使用。对手携带道具时会增加伤害" - }, - "endeavor": { - "name": "蛮干", - "effect": "给予伤害,使对手的HP变得和自\n己的HP一样" - }, - "eruption": { - "name": "喷火", - "effect": "爆发怒火攻击对手。自己的HP越少,\n招式的威力越小" - }, - "skillSwap": { - "name": "特性互换", - "effect": "利用超能力互换自己和对手的特性" - }, - "imprison": { - "name": "封印", - "effect": "如果对手有和自己相同的招式,\n那么只有对手无法使用该招式" - }, - "refresh": { - "name": "焕然一新", - "effect": "让身体休息,治愈自己身上所中的\n毒、麻痹、灼伤的异常状态" - }, - "grudge": { - "name": "怨念", - "effect": "因对手的招式而陷入昏厥时给对手\n施加怨念,让该招式的PP变成0" - }, - "snatch": { - "name": "抢夺", - "effect": "将对手打算使用的回复招式或能力\n变化招式夺为己用" - }, - "secretPower": { - "name": "秘密之力", - "effect": "根据使用场所不同,该招式的追加\n效果也会有所变化" - }, - "dive": { - "name": "潜水", - "effect": "第1回合潜入水中,第2回合浮上\n来进行攻击" - }, - "armThrust": { - "name": "猛推", - "effect": "用张开着的双手猛推对手进行攻击。\n连续攻击2~5次" - }, - "camouflage": { - "name": "保护色", - "effect": "根据所在场所不同,如水边、草丛\n和洞窟等,可以改变自己的属性" - }, - "tailGlow": { - "name": "萤火", - "effect": "凝视闪烁的光芒,集中自己的精神,\n从而巨幅提高特攻" - }, - "lusterPurge": { - "name": "洁净光芒", - "effect": "释放耀眼的光芒进行攻击。\n有时会降低对手的特防" - }, - "mistBall": { - "name": "薄雾球", - "effect": "用围绕着雾状羽毛的球进行攻击。\n有时会降低对手的特攻" - }, - "featherDance": { - "name": "羽毛舞", - "effect": "撒出羽毛,笼罩在对手的周围。\n大幅降低对手的攻击" - }, - "teeterDance": { - "name": "摇晃舞", - "effect": "摇摇晃晃地跳起舞蹈,\n让自己周围的宝可梦陷入混乱状态" - }, - "blazeKick": { - "name": "火焰踢", - "effect": "攻击对手后,有时会使其陷入灼伤状态。\n也容易击中要害" - }, - "mudSport": { - "name": "玩泥巴", - "effect": "一旦使用此招式,\n周围就会弄得到处是泥。\n在5回合内减弱电属性的招式" - }, - "iceBall": { - "name": "冰球", - "effect": "在5回合内攻击对手。\n招式每次击中,威力就会提高" - }, - "needleArm": { - "name": "尖刺臂", - "effect": "用带刺的手臂猛烈地挥舞进行攻击。\n有时会使对手畏缩" - }, - "slackOff": { - "name": "偷懒", - "effect": "偷懒休息。回复自己最大HP的一半" - }, - "hyperVoice": { - "name": "巨声", - "effect": "给予对手又吵又响的巨大震动进行攻击" - }, - "poisonFang": { - "name": "剧毒牙", - "effect": "用有毒的牙齿咬住对手进行攻击。\n有时会使对手中剧毒" - }, - "crushClaw": { - "name": "撕裂爪", - "effect": "用坚硬的锐爪劈开对手进行攻击。\n有时会降低对手的防御" - }, - "blastBurn": { - "name": "爆炸烈焰", - "effect": "用爆炸的火焰烧尽对手进行攻击。\n下一回合自己将无法动弹" - }, - "hydroCannon": { - "name": "加农水炮", - "effect": "向对手喷射水炮进行攻击。\n下一回合自己将无法动弹" - }, - "meteorMash": { - "name": "彗星拳", - "effect": "使出彗星般的拳头攻击对手。\n有时会提高自己的攻击" - }, - "astonish": { - "name": "惊吓", - "effect": "用尖叫声等突然惊吓对手进行攻击。\n有时会使对手畏缩" - }, - "weatherBall": { - "name": "气象球", - "effect": "根据使用时的天气,招式属性和威\n力会改变" - }, - "aromatherapy": { - "name": "芳香治疗", - "effect": "让同伴闻沁人心脾的香气,\n从而治愈我方全员的异常状态" - }, - "fakeTears": { - "name": "假哭", - "effect": "装哭流泪。使对手不知所措,\n从而大幅降低对手的特防" - }, - "airCutter": { - "name": "空气利刃", - "effect": "用锐利的风切斩对手进行攻击。\n容易击中要害" - }, - "overheat": { - "name": "过热", - "effect": "使出全部力量攻击对手。\n使用之后会因为反作用力,\n自己的特攻大幅降低" - }, - "odorSleuth": { - "name": "气味侦测", - "effect": "使出后对幽灵属性宝可梦没有效果\n的招式以及闪避率高的对手,\n变得能够打中" - }, - "rockTomb": { - "name": "岩石封锁", - "effect": "投掷岩石进行攻击。封住对手的行动,\n从而降低速度" - }, - "silverWind": { - "name": "银色旋风", - "effect": "在风中掺入鳞粉攻击对手。\n有时会提高自己的全部能力" - }, - "metalSound": { - "name": "金属音", - "effect": "让对手听摩擦金属般讨厌的声音。\n大幅降低对手的特防" - }, - "grassWhistle": { - "name": "草笛", - "effect": "让对手听舒适的笛声,\n从而陷入睡眠状态" - }, - "tickle": { - "name": "挠痒", - "effect": "给对手挠痒,使其发笑,\n从而降低对手的攻击和防御" - }, - "cosmicPower": { - "name": "宇宙力量", - "effect": "汲取宇宙中神秘的力量,\n从而提高自己的防御和特防" - }, - "waterSpout": { - "name": "喷水", - "effect": "掀起潮水进行攻击。自己的HP越少,\n招式的威力越小" - }, - "signalBeam": { - "name": "信号光束", - "effect": "发射神奇的光线进行攻击。\n有时会使对手混乱" - }, - "shadowPunch": { - "name": "暗影拳", - "effect": "使出混影之拳。攻击必定会命中" - }, - "extrasensory": { - "name": "神通力", - "effect": "发出看不见的神奇力量进行攻击。\n有时会使对手畏缩" - }, - "skyUppercut": { - "name": "冲天拳", - "effect": "用冲向天空般高高的上勾拳顶起对\n手进行攻击" - }, - "sandTomb": { - "name": "流沙深渊", - "effect": "将对手困在铺天盖地的沙暴中,\n在4~5回合内进行攻击" - }, - "sheerCold": { - "name": "绝对零度", - "effect": "给对手一击昏厥。如果是冰属性以\n外的宝可梦使用,就会难以打中" - }, - "muddyWater": { - "name": "浊流", - "effect": "向对手喷射浑浊的水进行攻击。\n有时会降低对手的命中率" - }, - "bulletSeed": { - "name": "种子机关枪", - "effect": "向对手猛烈地发射种子进行攻击。\n连续攻击2~5次" - }, - "aerialAce": { - "name": "燕返", - "effect": "以敏捷的动作戏弄对手后进行切斩。\n攻击必定会命中" - }, - "icicleSpear": { - "name": "冰锥", - "effect": "向对手发射锋利的冰柱进行攻击。\n连续攻击2~5次" - }, - "ironDefense": { - "name": "铁壁", - "effect": "将皮肤变得坚硬如铁,\n从而大幅提高自己的防御" - }, - "block": { - "name": "挡路", - "effect": "张开双手进行阻挡,封住对手的退路,\n使其不能逃走" - }, - "howl": { - "name": "长嚎", - "effect": "大声吼叫提高气势,从而提高自己\n和同伴的攻击" - }, - "dragonClaw": { - "name": "龙爪", - "effect": "用尖锐的巨爪劈开对手进行攻击" - }, - "frenzyPlant": { - "name": "疯狂植物", - "effect": "用大树摔打对手进行攻击。\n下一回合自己将无法动弹" - }, - "bulkUp": { - "name": "健美", - "effect": "使出全身力气绷紧肌肉,\n从而提高自己的攻击和防御" - }, - "bounce": { - "name": "弹跳", - "effect": "弹跳到高高的空中,第2回合攻击对手。\n有时会让对手陷入麻痹状态" - }, - "mudShot": { - "name": "泥巴射击", - "effect": "向对手投掷泥块进行攻击。\n同时降低对手的速度" - }, - "poisonTail": { - "name": "毒尾", - "effect": "用尾巴拍打。\n有时会让对手陷入中毒状态,\n也容易击中要害" - }, - "covet": { - "name": "渴望", - "effect": "一边可爱地撒娇,\n一边靠近对手进行攻击,\n还能夺取对手携带的道具" - }, - "voltTackle": { - "name": "伏特攻击", - "effect": "让电流覆盖全身猛撞向对手。\n自己也会受到不小的伤害。\n有时会让对手陷入麻痹状态" - }, - "magicalLeaf": { - "name": "魔法叶", - "effect": "散落可以追踪对手的神奇叶片。\n攻击必定会命中" - }, - "waterSport": { - "name": "玩水", - "effect": "用水湿透周围。在5回合内减弱火\n属性的招式" - }, - "calmMind": { - "name": "冥想", - "effect": "静心凝神,从而提高自己的特攻和特防" - }, - "leafBlade": { - "name": "叶刃", - "effect": "像用剑一般操纵叶片切斩对手进行攻击。\n容易击中要害" - }, - "dragonDance": { - "name": "龙之舞", - "effect": "激烈地跳起神秘且强有力的舞蹈。\n从而提高自己的攻击和速度" - }, - "rockBlast": { - "name": "岩石爆击", - "effect": "向对手发射坚硬的岩石进行攻击。\n连续攻击2~5次" - }, - "shockWave": { - "name": "电击波", - "effect": "向对手快速发出电击。\n攻击必定会命中" - }, - "waterPulse": { - "name": "水之波动", - "effect": "用水的震动攻击对手。\n有时会使对手混乱" - }, - "doomDesire": { - "name": "破灭之愿", - "effect": "使用招式2回合后,会用无数道光\n束攻击对手" - }, - "psychoBoost": { - "name": "精神突进", - "effect": "使出全部力量攻击对手。\n使用之后会因为反作用力,\n自己的特攻大幅降低" - }, - "roost": { - "name": "羽栖", - "effect": "降到地面,使身体休息。\n回复自己最大HP的一半" - }, - "gravity": { - "name": "重力", - "effect": "在5回合内,飘浮特性和飞行属性\n的宝可梦会被地面属性的招式击中。\n飞向空中的招式也将无法使用" - }, - "miracleEye": { - "name": "奇迹之眼", - "effect": "使出后对恶属性宝可梦没有效果的\n招式以及闪避率高的对手,\n变得能够打中" - }, - "wakeUpSlap": { - "name": "唤醒巴掌", - "effect": "给予睡眠状态下的对手较大的伤害。\n但相反对手会从睡眠中醒过来" - }, - "hammerArm": { - "name": "臂锤", - "effect": "挥舞强力而沉重的拳头,\n给予对手伤害。自己的速度会降低" - }, - "gyroBall": { - "name": "陀螺球", - "effect": "让身体高速旋转并撞击对手。\n速度比对手越慢,威力越大" - }, - "healingWish": { - "name": "治愈之愿", - "effect": "虽然自己陷入昏厥,但可以治愈后\n备上场的宝可梦的异常状态以及回复HP" - }, - "brine": { - "name": "盐水", - "effect": "当对手的HP负伤到一半左右时,\n招式威力会变成2倍" - }, - "naturalGift": { - "name": "自然之恩", - "effect": "从树果上获得力量进行攻击。\n根据携带的树果,招式属性和威力会改变" - }, - "feint": { - "name": "佯攻", - "effect": "能够攻击正在使用守住或看穿等招\n式的对手。解除其守护效果" - }, - "pluck": { - "name": "啄食", - "effect": "用喙进行攻击。当对手携带树果时,\n可以食用并获得其效果" - }, - "tailwind": { - "name": "顺风", - "effect": "刮起猛烈的旋风,在4回合内提高\n我方全员的速度" - }, - "acupressure": { - "name": "点穴", - "effect": "通过点穴让身体舒筋活络。\n大幅提高某1项能力" - }, - "metalBurst": { - "name": "金属爆炸", - "effect": "使出招式前,将最后受到的招式的\n伤害大力返还给对手" - }, - "uTurn": { - "name": "急速折返", - "effect": "在攻击之后急速返回,\n和后备宝可梦进行替换" - }, - "closeCombat": { - "name": "近身战", - "effect": "放弃守护,向对手的怀里突击。\n自己的防御和特防会降低" - }, - "payback": { - "name": "以牙还牙", - "effect": "蓄力攻击。如果能在对手之后攻击,\n招式的威力会变成2倍" - }, - "assurance": { - "name": "恶意追击", - "effect": "如果此回合内对手已经受到伤害的话,\n招式威力会变成2倍" - }, - "embargo": { - "name": "查封", - "effect": "让对手在5回合内不能使用宝可梦\n携带的道具。训练家也不能给那只\n宝可梦使用道具" - }, - "fling": { - "name": "投掷", - "effect": "快速投掷携带的道具进行攻击。\n根据道具不同,威力和效果会改变" - }, - "psychoShift": { - "name": "精神转移", - "effect": "利用超能力施以暗示,\n从而将自己受到的异常状态转移给对手" - }, - "trumpCard": { - "name": "王牌", - "effect": "王牌招式的剩余PP越少,\n招式的威力越大" - }, - "healBlock": { - "name": "回复封锁", - "effect": "在5回合内无法通过招式、特性或\n携带的道具来回复HP" - }, - "wringOut": { - "name": "绞紧", - "effect": "用力勒紧对手进行攻击。\n对手的HP越多,威力越大" - }, - "powerTrick": { - "name": "力量戏法", - "effect": "利用超能力交换自己的攻击和防御的力量" - }, - "gastroAcid": { - "name": "胃液", - "effect": "将胃液吐向对手的身体。\n沾上的胃液会消除对手的特性效果" - }, - "luckyChant": { - "name": "幸运咒语", - "effect": "向天许愿,从而在5回合内不会被\n对手的攻击打中要害" - }, - "meFirst": { - "name": "抢先一步", - "effect": "提高威力,\n抢先使出对手想要使出的招式。\n如果不先使出则会失败" - }, - "copycat": { - "name": "仿效", - "effect": "模仿对手刚才使出的招式,\n并使出相同招式。\n如果对手还没出招则会失败" - }, - "powerSwap": { - "name": "力量互换", - "effect": "利用超能力互换自己和对手的攻击\n以及特攻的能力变化" - }, - "guardSwap": { - "name": "防守互换", - "effect": "利用超能力互换自己和对手的防御\n以及特防的能力变化" - }, - "punishment": { - "name": "惩罚", - "effect": "根据能力变化,对手提高的力量越大,\n招式的威力越大" - }, - "lastResort": { - "name": "珍藏", - "effect": "当战斗中已学会的招式全部使用过后,\n才能开始使出珍藏的招式" - }, - "worrySeed": { - "name": "烦恼种子", - "effect": "种植心神不宁的种子。\n使对手不能入眠,并将特性变成不眠" - }, - "suckerPunch": { - "name": "突袭", - "effect": "可以比对手先攻击。对手使出的招\n式如果不是攻击招式则会失败" - }, - "toxicSpikes": { - "name": "毒菱", - "effect": "在对手的脚下撒毒菱。\n使对手替换出场的宝可梦中毒" - }, - "heartSwap": { - "name": "心灵互换", - "effect": "利用超能力互换自己和对手之间的\n能力变化" - }, - "aquaRing": { - "name": "水流环", - "effect": "在自己身体的周围覆盖用水制造的幕。\n每回合回复HP" - }, - "magnetRise": { - "name": "电磁飘浮", - "effect": "利用电气产生的磁力浮在空中。\n在5回合内可以飘浮" - }, - "flareBlitz": { - "name": "闪焰冲锋", - "effect": "让火焰覆盖全身猛撞向对手。\n自己也会受到不小的伤害。\n有时会让对手陷入灼伤状态" - }, - "forcePalm": { - "name": "发劲", - "effect": "向对手的身体发出冲击波进行攻击。\n有时会让对手陷入麻痹状态" - }, - "auraSphere": { - "name": "波导弹", - "effect": "从体内产生出波导之力,\n然后向对手发出。攻击必定会命中" - }, - "rockPolish": { - "name": "岩石打磨", - "effect": "打磨自己的身体,减少空气阻力。\n可以大幅提高自己的速度" - }, - "poisonJab": { - "name": "毒击", - "effect": "用带毒的触手或手臂刺入对手。\n有时会让对手陷入中毒状态" - }, - "darkPulse": { - "name": "恶之波动", - "effect": "从体内发出充满恶意的恐怖气场。\n有时会使对手畏缩" - }, - "nightSlash": { - "name": "暗袭要害", - "effect": "抓住瞬间的空隙切斩对手。\n容易击中要害" - }, - "aquaTail": { - "name": "水流尾", - "effect": "如惊涛骇浪般挥动大尾巴攻击对手" - }, - "seedBomb": { - "name": "种子炸弹", - "effect": "将外壳坚硬的大种子,\n从上方砸下攻击对手" - }, - "airSlash": { - "name": "空气之刃", - "effect": "用连天空也能劈开的空气之刃进行攻击。\n有时会使对手畏缩" - }, - "xScissor": { - "name": "十字剪", - "effect": "将镰刀或爪子像剪刀般地交叉,\n顺势劈开对手" - }, - "bugBuzz": { - "name": "虫鸣", - "effect": "利用振动发出音波进行攻击。\n有时会降低对手的特防" - }, - "dragonPulse": { - "name": "龙之波动", - "effect": "从大大的口中掀起冲击波攻击对手" - }, - "dragonRush": { - "name": "龙之俯冲", - "effect": "释放出骇人的杀气,一边威慑一边\n撞击对手。有时会使对手畏缩" - }, - "powerGem": { - "name": "力量宝石", - "effect": "发射如宝石般闪耀的光芒攻击对手" - }, - "drainPunch": { - "name": "吸取拳", - "effect": "用拳头吸取对手的力量。\n可以回复给予对手伤害的一半HP" - }, - "vacuumWave": { - "name": "真空波", - "effect": "挥动拳头,掀起真空波。\n必定能够先制攻击" - }, - "focusBlast": { - "name": "真气弹", - "effect": "提高气势,释放出全部力量。\n有时会降低对手的特防" - }, - "energyBall": { - "name": "能量球", - "effect": "发射从自然收集的生命力量。\n有时会降低对手的特防" - }, - "braveBird": { - "name": "勇鸟猛攻", - "effect": "收拢翅膀,通过低空飞行突击对手。\n自己也会受到不小的伤害" - }, - "earthPower": { - "name": "大地之力", - "effect": "向对手脚下释放出大地之力。\n有时会降低对手的特防" - }, - "switcheroo": { - "name": "掉包", - "effect": "用一闪而过的速度交换自己和对手\n的持有物" - }, - "gigaImpact": { - "name": "终极冲击", - "effect": "使出自己浑身力量突击对手。\n下一回合自己将无法动弹" - }, - "nastyPlot": { - "name": "诡计", - "effect": "谋划诡计,激活头脑。\n大幅提高自己的特攻" - }, - "bulletPunch": { - "name": "子弹拳", - "effect": "向对手使出如子弹般快速而坚硬的拳头。\n必定能够先制攻击" - }, - "avalanche": { - "name": "雪崩", - "effect": "如果受到对手的招式攻击,\n就能给予该对手2倍威力的攻击" - }, - "iceShard": { - "name": "冰砾", - "effect": "瞬间制作冰块,快速地扔向对手。\n必定能够先制攻击" - }, - "shadowClaw": { - "name": "暗影爪", - "effect": "以影子做成的锐爪,劈开对手。\n容易击中要害" - }, - "thunderFang": { - "name": "雷电牙", - "effect": "用蓄满电流的牙齿咬住对手。\n有时会使对手畏缩或陷入麻痹状态" - }, - "iceFang": { - "name": "冰冻牙", - "effect": "用藏有冷气的牙齿咬住对手。\n有时会使对手畏缩或陷入冰冻状态" - }, - "fireFang": { - "name": "火焰牙", - "effect": "用覆盖着火焰的牙齿咬住对手。\n有时会使对手畏缩或陷入灼伤状态" - }, - "shadowSneak": { - "name": "影子偷袭", - "effect": "伸长影子,从对手的背后进行攻击。\n必定能够先制攻击" - }, - "mudBomb": { - "name": "泥巴炸弹", - "effect": "向对手发射坚硬的泥弹进行攻击。\n有时会降低对手的命中率" - }, - "psychoCut": { - "name": "精神利刃", - "effect": "用实体化的心之利刃劈开对手。\n容易击中要害" - }, - "zenHeadbutt": { - "name": "意念头锤", - "effect": "将思念的力量集中在前额进行攻击。\n有时会使对手畏缩" - }, - "mirrorShot": { - "name": "镜光射击", - "effect": "抛光自己的身体,\n向对手释放出闪光之力。\n有时会降低对手的命中率" - }, - "flashCannon": { - "name": "加农光炮", - "effect": "将身体的光芒聚集在一点释放出去。\n有时会降低对手的特防" - }, - "rockClimb": { - "name": "攀岩", - "effect": "发动猛撞攻击,有时会使对手混乱。\n是宝可表的秘传招式之一" - }, - "defog": { - "name": "清除浓雾", - "effect": "用强风吹开对手的反射壁或光墙等。\n也会降低对手的闪避率" - }, - "trickRoom": { - "name": "戏法空间", - "effect": "制造出离奇的空间。在5回合内速\n度慢的宝可梦可以先行动" - }, - "dracoMeteor": { - "name": "流星群", - "effect": "从天空中向对手落下陨石。\n使用之后因为反作用力,\n自己的特攻会大幅降低" - }, - "discharge": { - "name": "放电", - "effect": "用耀眼的电击攻击\n自己周围所有的宝可梦。\n有时会陷入麻痹状态" - }, - "lavaPlume": { - "name": "喷烟", - "effect": "用熊熊烈火攻击自己周围所有的宝可梦。\n有时会陷入灼伤状态" - }, - "leafStorm": { - "name": "飞叶风暴", - "effect": "用尖尖的叶片向对手卷起风暴。\n使用之后因为反作用力自己的特攻会\n大幅降低" - }, - "powerWhip": { - "name": "强力鞭打", - "effect": "激烈地挥舞青藤或触手摔打对手进行攻击" - }, - "rockWrecker": { - "name": "岩石炮", - "effect": "向对手发射巨大的岩石进行攻击。\n下一回合自己将无法动弹" - }, - "crossPoison": { - "name": "十字毒刃", - "effect": "用毒刃劈开对手。有时会让对手陷\n入中毒状态,也容易击中要害" - }, - "gunkShot": { - "name": "垃圾射击", - "effect": "用肮脏的垃圾撞向对手进行攻击。\n有时会让对手陷入中毒状态" - }, - "ironHead": { - "name": "铁头", - "effect": "用钢铁般坚硬的头部进行攻击。\n有时会使对手畏缩" - }, - "magnetBomb": { - "name": "磁铁炸弹", - "effect": "发射吸住对手的钢铁炸弹。\n攻击必定会命中" - }, - "stoneEdge": { - "name": "尖石攻击", - "effect": "用尖尖的岩石刺入对手进行攻击。\n容易击中要害" - }, - "captivate": { - "name": "诱惑", - "effect": "♂诱惑♀或♀诱惑♂,\n从而大幅降低对手的特攻" - }, - "stealthRock": { - "name": "隐形岩", - "effect": "将无数岩石悬浮在对手的周围,\n从而对替换出场的对手的宝可梦给予伤害" - }, - "grassKnot": { - "name": "打草结", - "effect": "用草缠住并绊倒对手。\n对手越重,威力越大" - }, - "chatter": { - "name": "喋喋不休", - "effect": "用非常烦人的,\n喋喋不休的音波攻击对手。\n使对手混乱" - }, - "judgment": { - "name": "制裁光砾", - "effect": "向对手放出无数的光弹。\n属性会根据自己携带的石板不同而改变" - }, - "bugBite": { - "name": "虫咬", - "effect": "咬住进行攻击。当对手携带树果时,\n可以食用并获得其效果" - }, - "chargeBeam": { - "name": "充电光束", - "effect": "向对手发射电击光束。\n由于蓄满电流,有时会提高自己的特攻" - }, - "woodHammer": { - "name": "木槌", - "effect": "用坚硬的躯体撞击对手进行攻击。\n自己也会受到不小的伤害" - }, - "aquaJet": { - "name": "水流喷射", - "effect": "以迅雷不及掩耳之势扑向对手。\n必定能够先制攻击" - }, - "attackOrder": { - "name": "攻击指令", - "effect": "召唤手下,让其朝对手发起攻击。\n容易击中要害" - }, - "defendOrder": { - "name": "防御指令", - "effect": "召唤手下,让其附在自己的身体上。\n可以提高自己的防御和特防" - }, - "healOrder": { - "name": "回复指令", - "effect": "召唤手下疗伤。回复自己最大HP的一半" - }, - "headSmash": { - "name": "双刃头锤", - "effect": "拼命使出浑身力气,\n向对手进行头锤攻击。\n自己也会受到非常大的伤害" - }, - "doubleHit": { - "name": "二连击", - "effect": "使用尾巴等拍打对手进行攻击。\n连续2次给予伤害" - }, - "roarOfTime": { - "name": "时光咆哮", - "effect": "释放出扭曲时间般的强大力量攻击对手。\n下一回合自己将无法动弹" - }, - "spacialRend": { - "name": "亚空裂斩", - "effect": "将对手连同周围的空间一起撕裂并\n给予伤害。容易击中要害" - }, - "lunarDance": { - "name": "新月舞", - "effect": "虽然自己陷入昏厥,但可以治愈后\n备上场的宝可梦的全部状态" - }, - "crushGrip": { - "name": "捏碎", - "effect": "用骇人的力量捏碎对手。\n对手剩余的HP越多,威力越大" - }, - "magmaStorm": { - "name": "熔岩风暴", - "effect": "将对手困在熊熊燃烧的火焰中,\n在4~5回合内进行攻击" - }, - "darkVoid": { - "name": "暗黑洞", - "effect": "将对手强制拖入黑暗的世界,\n从而让对手陷入睡眠状态" - }, - "seedFlare": { - "name": "种子闪光", - "effect": "从身体里产生冲击波。\n有时会大幅降低对手的特防" - }, - "ominousWind": { - "name": "奇异之风", - "effect": "突然刮起毛骨悚然的暴风攻击对手。\n有时会提高自己的全部能力" - }, - "shadowForce": { - "name": "暗影潜袭", - "effect": "第1回合消失踪影,第2回合攻击对手。\n即使对手正受保护,\n也能击中" - }, - "honeClaws": { - "name": "磨爪", - "effect": "将爪子磨得更加锋利。\n提高自己的攻击和命中率" - }, - "wideGuard": { - "name": "广域防守", - "effect": "在1回合内防住击打我方全员的攻击" - }, - "guardSplit": { - "name": "防守平分", - "effect": "利用超能力将自己和对手的防御和\n特防相加,再进行平分" - }, - "powerSplit": { - "name": "力量平分", - "effect": "利用超能力将自己和对手的攻击和\n特攻相加,再进行平分" - }, - "wonderRoom": { - "name": "奇妙空间", - "effect": "制造出离奇的空间。在5回合内互\n换所有宝可梦的防御和特防" - }, - "psyshock": { - "name": "精神冲击", - "effect": "将神奇的念波实体化攻击对手。\n给予物理伤害" - }, - "venoshock": { - "name": "毒液冲击", - "effect": "将特殊的毒液泼向对手。\n对处于中毒状态的对手,威力会变成2倍" - }, - "autotomize": { - "name": "身体轻量化", - "effect": "削掉身体上没用的部分。\n大幅提高自己的速度,同时体重也会变轻" - }, - "ragePowder": { - "name": "愤怒粉", - "effect": "将令人烦躁的粉末撒在自己身上,\n用以吸引对手的注意。\n使对手的攻击全部指向自己" - }, - "telekinesis": { - "name": "意念移物", - "effect": "利用超能力使对手浮起来。\n在3回合内攻击会变得容易打中对手" - }, - "magicRoom": { - "name": "魔法空间", - "effect": "制造出离奇的空间。在5回合内所\n有宝可梦携带道具的效果都会消失" - }, - "smackDown": { - "name": "击落", - "effect": "扔石头或炮弹,攻击飞行的对手。\n对手会被击落,掉到地面" - }, - "stormThrow": { - "name": "山岚摔", - "effect": "向对手使出强烈的一击。\n攻击必定会击中要害" - }, - "flameBurst": { - "name": "烈焰溅射", - "effect": "如果击中,爆裂的火焰会攻击到对手。\n爆裂出的火焰还会飞溅到旁边的对手" - }, - "sludgeWave": { - "name": "污泥波", - "effect": "用污泥波攻击自己周围所有的宝可梦。\n有时会陷入中毒状态" - }, - "quiverDance": { - "name": "蝶舞", - "effect": "轻巧地跳起神秘而又美丽的舞蹈。\n提高自己的特攻、特防和速度" - }, - "heavySlam": { - "name": "重磅冲撞", - "effect": "用沉重的身体撞向对手进行攻击。\n自己比对手越重,威力越大" - }, - "synchronoise": { - "name": "同步干扰", - "effect": "用神奇电波对周围所有和自己属性\n相同的宝可梦给予伤害" - }, - "electroBall": { - "name": "电球", - "effect": "用电气团撞向对手。\n自己比对手速度越快,\n威力越大" - }, - "soak": { - "name": "浸水", - "effect": "将大量的水泼向对手,\n从而使其变成水属性" - }, - "flameCharge": { - "name": "蓄能焰袭", - "effect": "让火焰覆盖全身,攻击对手。\n积蓄力量来提高自己的速度" - }, - "coil": { - "name": "盘蜷", - "effect": "盘蜷着集中精神。提高自己的攻击\n、防御和命中率" - }, - "lowSweep": { - "name": "下盘踢", - "effect": "以敏捷的动作瞄准对手的脚进行攻击。\n会降低对手的速度" - }, - "acidSpray": { - "name": "酸液炸弹", - "effect": "喷出能溶化对手的液体进行攻击。\n会大幅降低对手的特防" - }, - "foulPlay": { - "name": "欺诈", - "effect": "利用对手的力量进行攻击。\n正和自己战斗的对手,其攻击越高,\n伤害越大" - }, - "simpleBeam": { - "name": "单纯光束", - "effect": "向对手发送谜之念波。\n接收到念波的对手,其特性会变为单纯" - }, - "entrainment": { - "name": "找伙伴", - "effect": "用神奇的节奏跳舞。使对手模仿自\n己的动作,从而将特性变成一样" - }, - "afterYou": { - "name": "您先请", - "effect": "支援我方或对手的行动,\n使其紧接着此招式之后行动" - }, - "round": { - "name": "轮唱", - "effect": "用歌声攻击对手。大家一起轮唱便\n可以接连使出,威力也会提高" - }, - "echoedVoice": { - "name": "回声", - "effect": "用回声攻击对手。如果每回合都有\n宝可梦接着使用该招式,\n威力就会提高" - }, - "chipAway": { - "name": "逐步击破", - "effect": "看准机会稳步攻击。\n无视对手的能力变化,\n直接给予伤害" - }, - "clearSmog": { - "name": "清除之烟", - "effect": "向对手投掷特殊的泥块进行攻击。\n使其能力变回原点" - }, - "storedPower": { - "name": "辅助力量", - "effect": "用蓄积起来的力量攻击对手。\n自己的能力提高得越多,威力就越大" - }, - "quickGuard": { - "name": "快速防守", - "effect": "守护自己和同伴,以防对手的先制攻击" - }, - "allySwitch": { - "name": "交换场地", - "effect": "用神奇的力量瞬间移动,\n互换自己和同伴所在的位置。\n连续使出则容易失败" - }, - "scald": { - "name": "热水", - "effect": "向对手喷射煮得翻滚的开水进行攻击。\n有时会让对手陷入灼伤状态" - }, - "shellSmash": { - "name": "破壳", - "effect": "打破外壳,降低自己的防御和特防,\n但大幅提高攻击、特攻和速度" - }, - "healPulse": { - "name": "治愈波动", - "effect": "放出治愈波动,从而回复对手最大\nHP的一半" - }, - "hex": { - "name": "祸不单行", - "effect": "接二连三地进行攻击。\n对处于异常状态的对手给予较大的伤害" - }, - "skyDrop": { - "name": "自由落体", - "effect": "第1回合将对手带到空中,\n第2回合将其摔下进行攻击。\n被带到空中的对手不能动弹" - }, - "shiftGear": { - "name": "换档", - "effect": "转动齿轮,不仅提高自己的攻击,\n还会大幅提高速度" - }, - "circleThrow": { - "name": "巴投", - "effect": "扔飞对手,强制拉后备宝可梦上场。\n如果对手为野生宝可梦,\n战斗将直接结束" - }, - "incinerate": { - "name": "烧净", - "effect": "用火焰攻击对手。对手携带树果等时,\n会烧掉,使其不能使用" - }, - "quash": { - "name": "延后", - "effect": "压制对手,从而将其行动顺序放到最后" - }, - "acrobatics": { - "name": "杂技", - "effect": "轻巧地攻击对手。自己没有携带道具时,\n会给予较大的伤害" - }, - "reflectType": { - "name": "镜面属性", - "effect": "反射对手的属性,让自己也变成一\n样的属性" - }, - "retaliate": { - "name": "报仇", - "effect": "为倒下的同伴报仇。如果上一回合\n有同伴倒下,威力就会提高" - }, - "finalGambit": { - "name": "搏命", - "effect": "拼命攻击对手。虽然自己陷入昏厥,\n但会给予对手和自己目前HP等\n量的伤害" - }, - "bestow": { - "name": "传递礼物", - "effect": "当对手未携带道具时,\n能够将自己携带的道具交给对手" - }, - "inferno": { - "name": "烈火深渊", - "effect": "用烈焰包裹住对手进行攻击。\n让对手陷入灼伤状态" - }, - "waterPledge": { - "name": "水之誓约", - "effect": "用水柱进行攻击。如果和火组合,\n威力就会提高,天空中会挂上彩虹" - }, - "firePledge": { - "name": "火之誓约", - "effect": "用火柱进行攻击。如果和草组合,\n威力就会提高,周围会变成火海" - }, - "grassPledge": { - "name": "草之誓约", - "effect": "用草柱进行攻击。如果和水组合,\n威力就会提高,周围会变成湿地" - }, - "voltSwitch": { - "name": "伏特替换", - "effect": "在攻击之后急速返回,\n和后备宝可梦进行替换" - }, - "struggleBug": { - "name": "虫之抵抗", - "effect": "抵抗并攻击对手。会降低对手的特攻" - }, - "bulldoze": { - "name": "重踏", - "effect": "用力踩踏地面并攻击自己周围所有\n的宝可梦。会降低对方的速度" - }, - "frostBreath": { - "name": "冰息", - "effect": "将冰冷的气息吹向对手进行攻击。\n必定会击中要害" - }, - "dragonTail": { - "name": "龙尾", - "effect": "弹飞对手,强制拉后备宝可梦上场。\n如果对手为野生宝可梦,\n战斗将直接结束" - }, - "workUp": { - "name": "自我激励", - "effect": "激励自己,从而提高攻击和特攻" - }, - "electroweb": { - "name": "电网", - "effect": "用电网捉住对手进行攻击。\n会降低对手的速度" - }, - "wildCharge": { - "name": "疯狂伏特", - "effect": "让电流覆盖全身,撞向对手进行攻击。\n自己也会受到少许伤害" - }, - "drillRun": { - "name": "直冲钻", - "effect": "像钢钻一样,\n一边旋转身体一边撞击对手。\n容易击中要害" - }, - "dualChop": { - "name": "二连劈", - "effect": "用身体坚硬的部分拍打对手进行攻击。\n连续2次给予伤害" - }, - "heartStamp": { - "name": "爱心印章", - "effect": "以可爱的动作使对手疏忽,\n乘机给出强烈的一击。有时会使对手畏缩" - }, - "hornLeech": { - "name": "木角", - "effect": "将角刺入,吸取对手的养分。\n可以回复给予对手伤害的一半HP" - }, - "sacredSword": { - "name": "圣剑", - "effect": "用剑切斩对手进行攻击。\n无视对手的能力变化,直接给予伤害" - }, - "razorShell": { - "name": "贝壳刃", - "effect": "用锋利的贝壳切斩对手进行攻击。\n有时会降低对手的防御" - }, - "heatCrash": { - "name": "高温重压", - "effect": "用燃烧的身体撞向对手进行攻击。\n自己比对手越重,威力越大" - }, - "leafTornado": { - "name": "青草搅拌器", - "effect": "用锋利的叶片包裹住对手进行攻击。\n有时会降低对手的命中率" - }, - "steamroller": { - "name": "疯狂滚压", - "effect": "旋转揉成团的身体压扁对手。\n有时会使对手畏缩" - }, - "cottonGuard": { - "name": "棉花防守", - "effect": "用软绵绵的绒毛包裹住自己的身体\n进行守护。巨幅提高自己的防御" - }, - "nightDaze": { - "name": "暗黑爆破", - "effect": "放出黑暗的冲击波攻击对手。\n有时会降低对手的命中率" - }, - "psystrike": { - "name": "精神击破", - "effect": "将神奇的念波实体化攻击对手。\n给予物理伤害" - }, - "tailSlap": { - "name": "扫尾拍打", - "effect": "用坚硬的尾巴拍打对手进行攻击。\n连续攻击2~5次" - }, - "hurricane": { - "name": "暴风", - "effect": "用强烈的风席卷对手进行攻击。\n有时会使对手混乱" - }, - "headCharge": { - "name": "爆炸头突击", - "effect": "用厉害的爆炸头猛撞向对手进行攻击。\n自己也会受到少许伤害" - }, - "gearGrind": { - "name": "齿轮飞盘", - "effect": "向对手投掷钢铁齿轮进行攻击。\n连续2次给予伤害" - }, - "searingShot": { - "name": "火焰弹", - "effect": "用熊熊烈火攻击自己周围所有的宝可梦。\n有时会陷入灼伤状态" - }, - "technoBlast": { - "name": "高科技光炮", - "effect": "向对手放出光弹。属性会根据自己\n携带的卡带不同而改变" - }, - "relicSong": { - "name": "古老之歌", - "effect": "让对手听古老之歌,打动对手的内\n心进行攻击。有时会让对手陷入睡眠状态" - }, - "secretSword": { - "name": "神秘之剑", - "effect": "用长角切斩对手进行攻击。\n角上拥有的神奇力量将给予物理伤害" - }, - "glaciate": { - "name": "冰封世界", - "effect": "将冰冻的冷气吹向对手进行攻击。\n会降低对手的速度" - }, - "boltStrike": { - "name": "雷击", - "effect": "让强大的电流覆盖全身,\n猛撞向对手进行攻击。\n有时会让对手陷入麻痹状态" - }, - "blueFlare": { - "name": "青焰", - "effect": "用美丽而激烈的青焰\n包裹住对手进行攻击。\n有时会让对手陷入灼伤状态" - }, - "fieryDance": { - "name": "火之舞", - "effect": "让火焰覆盖全身,振翅攻击对手。\n有时会提高自己的特攻" - }, - "freezeShock": { - "name": "冰冻伏特", - "effect": "用覆盖着电流的冰块,\n在第2回合撞向对手。\n有时会让对手陷入麻痹状态" - }, - "iceBurn": { - "name": "极寒冷焰", - "effect": "用能够冻结一切的强烈冷气,\n在第2回合包裹住对手。有时会让对手\n陷入灼伤状态" - }, - "snarl": { - "name": "大声咆哮", - "effect": "没完没了地大声斥责,\n从而降低对手的特攻" - }, - "icicleCrash": { - "name": "冰柱坠击", - "effect": "用大冰柱激烈地撞向对手进行攻击。\n有时会使对手畏缩" - }, - "vCreate": { - "name": "V热焰", - "effect": "从前额产生灼热的火焰,\n舍身撞击对手。防御、特防和速度会降低" - }, - "fusionFlare": { - "name": "交错火焰", - "effect": "释放出巨大的火焰。受到巨大的闪\n电影响时,招式威力会提高" - }, - "fusionBolt": { - "name": "交错闪电", - "effect": "释放出巨大的闪电。受到巨大的火\n焰影响时,招式威力会提高" - }, - "flyingPress": { - "name": "飞身重压", - "effect": "从空中俯冲向对手。此招式同时带\n有格斗属性和飞行属性" - }, - "matBlock": { - "name": "掀榻榻米", - "effect": "将掀起来的榻榻米当作盾牌,\n防住自己和同伴免受招式伤害。\n变化招式无法防住" - }, - "belch": { - "name": "打嗝", - "effect": "朝着对手打嗝,并给予伤害。\n如果不吃树果则无法使出" - }, - "rototiller": { - "name": "耕地", - "effect": "翻耕土地,使草木更容易成长。\n会提高草属性宝可梦的攻击和特攻" - }, - "stickyWeb": { - "name": "黏黏网", - "effect": "在对手周围围上黏黏的网,\n降低替换出场的对手的速度" - }, - "fellStinger": { - "name": "致命针刺", - "effect": "如果使用此招式打倒对手,\n攻击会巨幅提高" - }, - "phantomForce": { - "name": "潜灵奇袭", - "effect": "第1回合消失在某处,\n第2回合攻击对手。\n可以无视守护进行攻击" - }, - "trickOrTreat": { - "name": "万圣夜", - "effect": "邀请对手参加万圣夜。\n使对手被追加幽灵属性" - }, - "nobleRoar": { - "name": "战吼", - "effect": "发出战吼威吓对手,从而降低对手\n的攻击和特攻" - }, - "ionDeluge": { - "name": "等离子浴", - "effect": "将带电粒子扩散开来,\n使一般属性的招式变成电属性" - }, - "parabolicCharge": { - "name": "抛物面充电", - "effect": "给周围全体宝可梦造成伤害。\n可以回复给予伤害的一半HP" - }, - "forestsCurse": { - "name": "森林咒术", - "effect": "向对手施加森林咒术。\n中了咒术的对手会被追加草属性" - }, - "petalBlizzard": { - "name": "落英缤纷", - "effect": "猛烈地刮起飞雪般的落花,\n攻击周围所有的宝可梦,并给予伤害" - }, - "freezeDry": { - "name": "冷冻干燥", - "effect": "急剧冷冻对手,有时会让对手陷入\n冰冻状态。对于水属性宝可梦也是\n效果绝佳" - }, - "disarmingVoice": { - "name": "魅惑之声", - "effect": "发出魅惑的叫声,\n给予对手精神上的伤害。\n攻击必定会命中" - }, - "partingShot": { - "name": "抛下狠话", - "effect": "抛下狠话威吓对手,降低攻击和特攻后,\n和后备宝可梦进行替换" - }, - "topsyTurvy": { - "name": "颠倒", - "effect": "颠倒对手身上的所有能力变化,\n变成和原来相反的状态" - }, - "drainingKiss": { - "name": "吸取之吻", - "effect": "用一个吻吸取对手的HP。\n回复给予对手伤害的一半以上的HP" - }, - "craftyShield": { - "name": "戏法防守", - "effect": "使用神奇的力量防住\n攻击我方的变化招式。\n但无法防住伤害招式的攻击" - }, - "flowerShield": { - "name": "鲜花防守", - "effect": "使用神奇的力量提高在场的所有草\n属性宝可梦的防御" - }, - "grassyTerrain": { - "name": "青草场地", - "effect": "在5回合内变成青草场地。\n地面上的宝可梦每回合都能回复。\n草属性的招式威力还会提高" - }, - "mistyTerrain": { - "name": "薄雾场地", - "effect": "在5回合内,地面上的宝可梦不会\n陷入异常状态。龙属性招式的伤害\n也会减半" - }, - "electrify": { - "name": "输电", - "effect": "对手使出招式前,如果输电,\n则该回合对手的招式变成电属性" - }, - "playRough": { - "name": "嬉闹", - "effect": "与对手嬉闹并攻击。有时会降低对\n手的攻击" - }, - "fairyWind": { - "name": "妖精之风", - "effect": "刮起妖精之风,吹向对手进行攻击" - }, - "moonblast": { - "name": "月亮之力", - "effect": "借用月亮的力量攻击对手。\n有时会降低对手的特攻" - }, - "boomburst": { - "name": "爆音波", - "effect": "通过震耳欲聋的爆炸声产生的破坏力,\n攻击自己周围所有的宝可梦" - }, - "fairyLock": { - "name": "妖精之锁", - "effect": "通过封锁,下一回合所有的宝可梦\n都无法逃走" - }, - "kingsShield": { - "name": "王者盾牌", - "effect": "防住对手攻击的同时,\n自己变为防御姿态。\n能够降低所接触到的对手的攻击" - }, - "playNice": { - "name": "和睦相处", - "effect": "和对手和睦相处,使其失去战斗的气力,\n从而降低对手的攻击" - }, - "confide": { - "name": "密语", - "effect": "和对手进行密语,使其失去集中力,\n从而降低对手的特攻" - }, - "diamondStorm": { - "name": "钻石风暴", - "effect": "掀起钻石风暴给予伤害。\n有时会大幅提高自己的防御" - }, - "steamEruption": { - "name": "蒸汽爆炸", - "effect": "将滚烫的蒸汽喷向对手。\n有时会让对手灼伤" - }, - "hyperspaceHole": { - "name": "异次元洞", - "effect": "通过异次元洞,突然出现在对手的\n侧面进行攻击。还可以无视守住和\n看穿等招式" - }, - "waterShuriken": { - "name": "飞水手里剑", - "effect": "用粘液制成的手里剑,\n连续攻击2~5次。必定能够先制攻击" - }, - "mysticalFire": { - "name": "魔法火焰", - "effect": "从口中喷出特别灼热的火焰进行攻击。\n降低对手的特攻" - }, - "spikyShield": { - "name": "尖刺防守", - "effect": "防住对手攻击的同时,\n削减接触到自己的对手的体力" - }, - "aromaticMist": { - "name": "芳香薄雾", - "effect": "通过神奇的芳香,提高我方宝可梦的特防" - }, - "eerieImpulse": { - "name": "怪异电波", - "effect": "从身体放射出怪异电波,\n让对手沐浴其中,从而大幅降低其特攻" - }, - "venomDrench": { - "name": "毒液陷阱", - "effect": "将特殊的毒液泼向对手。\n对处于中毒状态的对手,其攻击、\n特攻和速度都会降低" - }, - "powder": { - "name": "粉尘", - "effect": "如果被撒到粉尘的对手使用火招式,\n则会爆炸并给予伤害" - }, - "geomancy": { - "name": "大地掌控", - "effect": "第1回合吸收能量,第2回合大幅\n提高特攻、特防和速度" - }, - "magneticFlux": { - "name": "磁场操控", - "effect": "通过操控磁场,会提高特性为正电\n和负电的宝可梦的防御和特防" - }, - "happyHour": { - "name": "欢乐时光", - "effect": "如果使用欢乐时光,战斗后得到的\n钱会翻倍" - }, - "electricTerrain": { - "name": "电气场地", - "effect": "在5回合内变成电气场地。\n地面上的宝可梦将无法入眠。\n电属性的招式威力还会提高" - }, - "dazzlingGleam": { - "name": "魔法闪耀", - "effect": "向对手发射强光,并给予伤害" - }, - "celebrate": { - "name": "庆祝", - "effect": "宝可梦为十分开心的你庆祝" - }, - "holdHands": { - "name": "牵手", - "effect": "我方宝可梦之间牵手。\n能带来非常幸福的心情" - }, - "babyDollEyes": { - "name": "圆瞳", - "effect": "用圆瞳凝视对手,从而降低其攻击。\n必定能够先制攻击" - }, - "nuzzle": { - "name": "蹭蹭脸颊", - "effect": "将带电的脸颊蹭蹭对手进行攻击。\n让对手陷入麻痹状态" - }, - "holdBack": { - "name": "手下留情", - "effect": "在攻击的时候手下留情,\n从而使对手的HP至少会留下1HP" - }, - "infestation": { - "name": "纠缠不休", - "effect": "在4~5回合内死缠烂打地进行攻击。\n在此期间对手将无法逃走" - }, - "powerUpPunch": { - "name": "增强拳", - "effect": "通过反复击打对手,使自己的拳头\n慢慢变硬。打中对手攻击就会提高" - }, - "oblivionWing": { - "name": "归天之翼", - "effect": "从锁定的对手身上吸取HP。\n回复给予对手伤害的一半以上的HP" - }, - "thousandArrows": { - "name": "千箭齐发", - "effect": "可以击中浮在空中的宝可梦。\n空中的对手被击落后,会掉到地面" - }, - "thousandWaves": { - "name": "千波激荡", - "effect": "从地面掀起波浪进行攻击。\n被掀入波浪中的对手,\n将无法从战斗中逃走" - }, - "landsWrath": { - "name": "大地神力", - "effect": "聚集大地的力量,\n将此力量集中攻击对手,\n并给予伤害" - }, - "lightOfRuin": { - "name": "破灭之光", - "effect": "借用永恒之花的力量,\n发射出强力光线。\n自己也会受到非常大的伤害" - }, - "originPulse": { - "name": "根源波动", - "effect": "用无数青白色且闪耀的光线攻击对手" - }, - "precipiceBlades": { - "name": "断崖之剑", - "effect": "将大地的力量变化为利刃攻击对手" - }, - "dragonAscent": { - "name": "画龙点睛", - "effect": "从天空中急速下降攻击对手。\n自己的防御和特防会降低" - }, - "hyperspaceFury": { - "name": "异次元猛攻", - "effect": "用许多手臂,无视对手的守住或看\n穿等招式进行连续攻击,\n自己的防御会降低" - }, - "breakneckBlitzPhysical": { - "name": "一般Z究极无敌大冲撞", - "effect": "通过Z力量气势猛烈地全力撞上对手。\n威力会根据原来的招式而改变" - }, - "breakneckBlitzSpecial": { - "name": "一般Z究极无敌大冲撞", - "effect": "通过Z力量气势猛烈地全力撞上对手。\n威力会根据原来的招式而改变" - }, - "allOutPummelingPhysical": { - "name": "格斗Z全力无双激烈拳", - "effect": "通过Z力量制造出能量弹,\n全力撞向对手。\n威力会根据原来的招式而改变" - }, - "allOutPummelingSpecial": { - "name": "格斗Z全力无双激烈拳", - "effect": "通过Z力量制造出能量弹,\n全力撞向对手。\n威力会根据原来的招式而改变" - }, - "supersonicSkystrikePhysical": { - "name": "飞行Z极速俯冲轰烈撞", - "effect": "通过Z力量猛烈地飞向天空,\n朝对手全力落下。\n威力会根据原来的招式而改变" - }, - "supersonicSkystrikeSpecial": { - "name": "飞行Z极速俯冲轰烈撞", - "effect": "通过Z力量猛烈地飞向天空,\n朝对手全力落下。\n威力会根据原来的招式而改变" - }, - "acidDownpourPhysical": { - "name": "毒Z强酸剧毒灭绝雨", - "effect": "通过Z力量使毒沼涌起,\n全力让对手沉下去。\n威力会根据原来的招式而改变" - }, - "acidDownpourSpecial": { - "name": "毒Z强酸剧毒灭绝雨", - "effect": "通过Z力量使毒沼涌起,\n全力让对手沉下去。\n威力会根据原来的招式而改变" - }, - "tectonicRagePhysical": { - "name": "地面Z地隆啸天大终结", - "effect": "通过Z力量潜入地里最深处,\n全力撞上对手。\n威力会根据原来的招式而改变" - }, - "tectonicRageSpecial": { - "name": "地面Z地隆啸天大终结", - "effect": "通过Z力量潜入地里最深处,\n全力撞上对手。\n威力会根据原来的招式而改变" - }, - "continentalCrushPhysical": { - "name": "岩石Z毁天灭地巨岩坠", - "effect": "通过Z力量召唤大大的岩山,\n全力撞向对手。\n威力会根据原来的招式而改变" - }, - "continentalCrushSpecial": { - "name": "岩石Z毁天灭地巨岩坠", - "effect": "通过Z力量召唤大大的岩山,\n全力撞向对手。\n威力会根据原来的招式而改变" - }, - "savageSpinOutPhysical": { - "name": "虫Z绝对捕食回旋斩", - "effect": "通过Z力量将吐出的丝线全力束缚对手。\n威力会根据原来的招式而改变" - }, - "savageSpinOutSpecial": { - "name": "虫Z绝对捕食回旋斩", - "effect": "通过Z力量将吐出的丝线全力束缚对手。\n威力会根据原来的招式而改变" - }, - "neverEndingNightmarePhysical": { - "name": "幽灵Z无尽暗夜之诱惑", - "effect": "通过Z力量召唤强烈的怨念,\n全力降临到对手身上。\n威力会根据原来的招式而改变" - }, - "neverEndingNightmareSpecial": { - "name": "幽灵Z无尽暗夜之诱惑", - "effect": "通过Z力量召唤强烈的怨念,\n全力降临到对手身上。\n威力会根据原来的招式而改变" - }, - "corkscrewCrashPhysical": { - "name": "钢Z超绝螺旋连击", - "effect": "通过Z力量进行高速旋转,\n全力撞上对手。\n威力会根据原来的招式而改变" - }, - "corkscrewCrashSpecial": { - "name": "钢Z超绝螺旋连击", - "effect": "通过Z力量进行高速旋转,\n全力撞上对手。\n威力会根据原来的招式而改变" - }, - "infernoOverdrivePhysical": { - "name": "火Z超强极限爆焰弹", - "effect": "通过Z力量喷出熊熊烈火,\n全力撞向对手。\n威力会根据原来的招式而改变" - }, - "infernoOverdriveSpecial": { - "name": "火Z超强极限爆焰弹", - "effect": "通过Z力量喷出熊熊烈火,\n全力撞向对手。\n威力会根据原来的招式而改变" - }, - "hydroVortexPhysical": { - "name": "水Z超级水流大漩涡", - "effect": "通过Z力量制造大大的潮旋,\n全力吞没对手。\n威力会根据原来的招式而改变" - }, - "hydroVortexSpecial": { - "name": "水Z超级水流大漩涡", - "effect": "通过Z力量制造大大的潮旋,\n全力吞没对手。\n威力会根据原来的招式而改变" - }, - "bloomDoomPhysical": { - "name": "草Z绚烂缤纷花怒放", - "effect": "通过Z力量借助花草的能量,\n全力攻击对手。\n威力会根据原来的招式而改变" - }, - "bloomDoomSpecial": { - "name": "草Z绚烂缤纷花怒放", - "effect": "通过Z力量借助花草的能量,\n全力攻击对手。\n威力会根据原来的招式而改变" - }, - "gigavoltHavocPhysical": { - "name": "电Z终极伏特狂雷闪", - "effect": "通过Z力量将蓄积的强大电流全力\n撞向对手。威力会根据原来的招式而改变" - }, - "gigavoltHavocSpecial": { - "name": "电Z终极伏特狂雷闪", - "effect": "通过Z力量将蓄积的强大电流全力\n撞向对手。威力会根据原来的招式而改变" - }, - "shatteredPsychePhysical": { - "name": "超能力Z至高精神破坏波", - "effect": "通过Z力量操纵对手,\n全力使其感受到痛苦。\n威力会根据原来的招式而改变" - }, - "shatteredPsycheSpecial": { - "name": "超能力Z至高精神破坏波", - "effect": "通过Z力量操纵对手,\n全力使其感受到痛苦。\n威力会根据原来的招式而改变" - }, - "subzeroSlammerPhysical": { - "name": "冰Z激狂大地万里冰", - "effect": "通过Z力量急剧降低气温,\n全力冰冻对手。\n威力会根据原来的招式而改变" - }, - "subzeroSlammerSpecial": { - "name": "冰Z激狂大地万里冰", - "effect": "通过Z力量急剧降低气温,\n全力冰冻对手。\n威力会根据原来的招式而改变" - }, - "devastatingDrakePhysical": { - "name": "龙Z究极巨龙震天地", - "effect": "通过Z力量将气场实体化,\n向对手全力发动袭击。\n威力会根据原来的招式而改变" - }, - "devastatingDrakeSpecial": { - "name": "龙Z究极巨龙震天地", - "effect": "通过Z力量将气场实体化,\n向对手全力发动袭击。\n威力会根据原来的招式而改变" - }, - "blackHoleEclipsePhysical": { - "name": "恶Z黑洞吞噬万物灭", - "effect": "通过Z力量收集恶能量,\n全力将对手吸入。\n威力会根据原来的招式而改变" - }, - "blackHoleEclipseSpecial": { - "name": "恶Z黑洞吞噬万物灭", - "effect": "通过Z力量收集恶能量,\n全力将对手吸入。\n威力会根据原来的招式而改变" - }, - "twinkleTacklePhysical": { - "name": "妖精Z可爱星星飞天撞", - "effect": "通过Z力量制造魅惑空间,\n全力捉弄对手。\n威力会根据原来的招式而改变" - }, - "twinkleTackleSpecial": { - "name": "妖精Z可爱星星飞天撞", - "effect": "通过Z力量制造魅惑空间,\n全力捉弄对手。\n威力会根据原来的招式而改变" - }, - "catastropika": { - "name": "皮卡丘Z皮卡皮卡必杀击", - "effect": "通过Z力量,皮卡丘全身覆盖最强电力,\n全力猛扑对手" - }, - "shoreUp": { - "name": "集沙", - "effect": "回复自己最大HP的一半。\n在沙暴中回复得更多" - }, - "firstImpression": { - "name": "迎头一击", - "effect": "威力很高的招式,但只有在出场战斗时,\n立刻使出才能成功" - }, - "banefulBunker": { - "name": "碉堡", - "effect": "防住对手攻击的同时,\n让接触到自己的对手中毒" - }, - "spiritShackle": { - "name": "缝影", - "effect": "攻击的同时,缝住对手的影子,\n使其无法逃走" - }, - "darkestLariat": { - "name": "DD金勾臂", - "effect": "旋转双臂打向对手。\n无视对手的能力变化,\n直接给予伤害" - }, - "sparklingAria": { - "name": "泡影的咏叹调", - "effect": "随着唱歌会放出很多气球。\n受到此招式攻击时,灼伤会被治愈" - }, - "iceHammer": { - "name": "冰锤", - "effect": "挥舞强力而沉重的拳头,\n给予对手伤害。自己的速度会降低" - }, - "floralHealing": { - "name": "花疗", - "effect": "回复对手最大HP的一半。\n在青草场地时,效果会提高" - }, - "highHorsepower": { - "name": "十万马力", - "effect": "使出全身力量,猛攻对手" - }, - "strengthSap": { - "name": "吸取力量", - "effect": "给自己回复和对手攻击力\n相同数值的HP,\n然后降低对手的攻击" - }, - "solarBlade": { - "name": "日光刃", - "effect": "第1回合收集满满的日光,\n第2回合将此力量集中在剑上进行攻击" - }, - "leafage": { - "name": "树叶", - "effect": "将叶片打向对手,进行攻击" - }, - "spotlight": { - "name": "聚光灯", - "effect": "给宝可梦打上聚光灯,\n该回合只能瞄准该宝可梦" - }, - "toxicThread": { - "name": "毒丝", - "effect": "将混有毒的丝吐向对手。\n使其中毒,从而降低对手的速度" - }, - "laserFocus": { - "name": "磨砺", - "effect": "集中精神,下次攻击必定会击中要害" - }, - "gearUp": { - "name": "辅助齿轮", - "effect": "启动齿轮,提高特性为正电和负电\n的宝可梦的攻击和特攻" - }, - "throatChop": { - "name": "深渊突刺", - "effect": "受到此招式攻击的对手,\n会因为地狱般的痛苦,在2回合内,\n变得无法使出声音类招式" - }, - "pollenPuff": { - "name": "花粉团", - "effect": "对敌人使用是会爆炸的团子。\n对我方使用则是给予回复的团子" - }, - "anchorShot": { - "name": "掷锚", - "effect": "将锚缠住对手进行攻击。\n使对手无法逃走" - }, - "psychicTerrain": { - "name": "精神场地", - "effect": "在5回合内,地面上的宝可梦不会\n受到先制招式的攻击。\n超能力属性的招式威力会提高" - }, - "lunge": { - "name": "猛扑", - "effect": "全力猛扑对手进行攻击。\n从而降低对手的攻击" - }, - "fireLash": { - "name": "火焰鞭", - "effect": "用燃烧的鞭子抽打对手。\n受到攻击的对手防御会降低" - }, - "powerTrip": { - "name": "嚣张", - "effect": "耀武扬威地攻击对手,\n自己的能力提高得越多,威力就越大" - }, - "burnUp": { - "name": "燃尽", - "effect": "将自己全身燃烧起火焰来,\n给予对手大大的伤害。\n自己的火属性将会消失" - }, - "speedSwap": { - "name": "速度互换", - "effect": "将对手和自己的速度进行互换" - }, - "smartStrike": { - "name": "修长之角", - "effect": "用尖尖的角刺入对手进行攻击。\n攻击必定会命中" - }, - "purify": { - "name": "净化", - "effect": "治愈对手的异常状态。\n治愈后可以回复自己的HP" - }, - "revelationDance": { - "name": "觉醒之舞", - "effect": "全力跳舞进行攻击。此招式的属性\n将变得和自己的属性相同" - }, - "coreEnforcer": { - "name": "核心惩罚者", - "effect": "如果给予过伤害的对手已经结束行动,\n其特性就会被消除" - }, - "tropKick": { - "name": "热带踢", - "effect": "向对手使出来自南国的火热脚踢。\n从而降低对手的攻击" - }, - "instruct": { - "name": "号令", - "effect": "向对手下达指示,让其再次使出刚\n才的招式" - }, - "beakBlast": { - "name": "鸟嘴加农炮", - "effect": "先加热鸟嘴后再进行攻击。\n鸟嘴在加热时对手触碰的话,\n就会使其灼伤" - }, - "clangingScales": { - "name": "鳞片噪音", - "effect": "摩擦全身鳞片,\n发出响亮的声音进行攻击。\n攻击后自己的防御会降低" - }, - "dragonHammer": { - "name": "龙锤", - "effect": "将身体当作锤子,向对手发动袭击,\n给予伤害" - }, - "brutalSwing": { - "name": "狂舞挥打", - "effect": "用自己的身体狂舞挥打,\n给予对手伤害" - }, - "auroraVeil": { - "name": "极光幕", - "effect": "在5回合内减弱物理和特殊的伤害。\n只有下雪时才能使出" - }, - "sinisterArrowRaid": { - "name": "狙射树枭Z遮天蔽日暗影箭", - "effect": "通过Z力量制造出无数箭的狙射树\n枭将全力射穿对手进行攻击" - }, - "maliciousMoonsault": { - "name": "炽焰咆哮虎Z极恶飞跃粉碎击", - "effect": "通过Z力量得到强壮肉体的炽焰咆\n哮虎将全力撞向对手进行攻击" - }, - "oceanicOperetta": { - "name": "西狮海壬Z海神庄严交响乐", - "effect": "通过Z力量召唤大量水的西狮海壬\n将全力攻击对手" - }, - "guardianOfAlola": { - "name": "卡璞Z巨人卫士・阿罗拉", - "effect": "通过Z力量得到阿罗拉之力的土地\n神宝可梦将全力进行攻击。\n对手的剩余HP会减少很多" - }, - "soulStealing7StarStrike": { - "name": "玛夏多Z七星夺魂腿", - "effect": "得到Z力量的玛夏多将全力使出拳\n头和脚踢的连续招式叩打对手" - }, - "stokedSparksurfer": { - "name": "阿罗雷Z驾雷驭电戏冲浪", - "effect": "得到Z力量的阿罗拉地区的雷丘将\n全力进行攻击。从而让对手陷入麻痹状态" - }, - "pulverizingPancake": { - "name": "卡比兽Z认真起来大爆击", - "effect": "通过Z力量使得认真起来的卡比兽\n跃动巨大身躯,全力向对手发动袭击" - }, - "extremeEvoboost": { - "name": "伊布Z九彩昇华齐聚顶", - "effect": "得到Z力量的伊布将借助进化后伙\n伴们的力量,大幅提高能力" - }, - "genesisSupernova": { - "name": "梦幻Z起源超新星大爆炸", - "effect": "得到Z力量的梦幻将全力攻击对手。\n脚下会变成精神场地" - }, - "shellTrap": { - "name": "陷阱甲壳", - "effect": "设下甲壳陷阱。如果对手使出物理招式,\n陷阱就会爆炸并给予对手伤害" - }, - "fleurCannon": { - "name": "花朵加农炮", - "effect": "放出强力光束后,自己的特攻会大幅降低" - }, - "psychicFangs": { - "name": "精神之牙", - "effect": "利用精神力量咬住对手进行攻击。\n还可以破坏光墙和反射壁等" - }, - "stompingTantrum": { - "name": "跺脚", - "effect": "化悔恨为力量进行攻击。\n如果上一回合招式没有打中,\n威力就会翻倍" - }, - "shadowBone": { - "name": "暗影之骨", - "effect": "用附有灵魂的骨头殴打对手进行攻击。\n有时会降低对手的防御" - }, - "accelerock": { - "name": "冲岩", - "effect": "迅速撞向对手进行攻击。\n必定能够先制攻击" - }, - "liquidation": { - "name": "水流裂破", - "effect": "用水之力量撞向对手进行攻击。\n有时会降低对手的防御" - }, - "prismaticLaser": { - "name": "棱镜镭射", - "effect": "用棱镜的力量发射强烈光线。\n下一回合自己将无法动弹" - }, - "spectralThief": { - "name": "暗影偷盗", - "effect": "潜入对手的影子进行攻击。\n会夺取对手的能力提升" - }, - "sunsteelStrike": { - "name": "流星闪冲", - "effect": "以流星般的气势猛撞对手。\n可以无视对手的特性进行攻击" - }, - "moongeistBeam": { - "name": "暗影之光", - "effect": "放出奇怪的光线攻击对手。\n可以无视对手的特性进行攻击" - }, - "tearfulLook": { - "name": "泪眼汪汪", - "effect": "变得泪眼汪汪,让对手丧失斗志。\n从而降低对手的攻击和特攻" - }, - "zingZap": { - "name": "麻麻刺刺", - "effect": "撞向对手,并发出强电,\n使其感到麻麻刺刺的。有时会使对手畏缩" - }, - "naturesMadness": { - "name": "自然之怒", - "effect": "向对手释放自然之怒。\n对手的HP会减半" - }, - "multiAttack": { - "name": "多属性攻击", - "effect": "一边覆盖高能量,\n一边撞向对手进行攻击。\n根据存储碟不同,\n属性会改变" - }, - "tenMillionVoltThunderbolt": { - "name": "智皮卡Z千万伏特", - "effect": "戴着帽子的皮卡丘将通过Z力量增\n强的电击全力释放给对手。\n容易击中要害" - }, - "mindBlown": { - "name": "惊爆大头", - "effect": "让自己的头爆炸,来攻击周围的一切。\n自己也会受到伤害" - }, - "plasmaFists": { - "name": "等离子闪电拳", - "effect": "用覆盖着电流的拳头进行攻击。\n使一般属性的招式变成电属性" - }, - "photonGeyser": { - "name": "光子喷涌", - "effect": "用光柱来进行攻击。比较自己的攻\n击和特攻,用数值相对较高的一项\n给予对方伤害" - }, - "lightThatBurnsTheSky": { - "name": "究极奈克洛Z焚天灭世炽光爆", - "effect": "奈克洛兹玛会无视对手的特性效果,\n在攻击和特攻之间,\n用数值相对较高的一项给予对方伤害" - }, - "searingSunrazeSmash": { - "name": "索尔迦雷欧Z日光回旋下苍穹", - "effect": "得到Z力量的索尔迦雷欧\n将全力进行攻击。\n可以无视对手的特性效果" - }, - "menacingMoonrazeMaelstrom": { - "name": "露奈雅拉Z月华飞溅落灵霄", - "effect": "得到Z力量的露奈雅拉将全力进行攻击。\n可以无视对手的特性效果" - }, - "letsSnuggleForever": { - "name": "谜拟丘Z亲密无间大乱揍", - "effect": "得到Z力量的谜拟Q将全力进行乱揍攻击" - }, - "splinteredStormshards": { - "name": "鬃岩狼人Z狼啸石牙飓风暴", - "effect": "得到Z力量的鬃岩狼人将全力进行攻击。\n而且会消除场地状态" - }, - "clangorousSoulblaze": { - "name": "杖尾鳞甲龙Z炽魂热舞烈音爆", - "effect": "得到Z力量的杖尾鳞甲龙\n将全力攻击对手。\n并且自己的能力会提高" - }, - "zippyZap": { - "name": "电电加速", - "effect": "迅猛无比的电击。必定能够先制攻击,击中对方的要害。" - }, - "splishySplash": { - "name": "滔滔冲浪", - "effect": "往巨浪中注入电能后冲撞对手进行攻击。\n有时会让对手陷入麻痹状态" - }, - "floatyFall": { - "name": "飘飘坠落", - "effect": "轻飘飘地浮起来后,再猛地俯冲下\n去进行攻击。有时会使对手畏缩" - }, - "pikaPapow": { - "name": "闪闪雷光", - "effect": "皮卡丘越喜欢训练家,\n电击的威力就越强。攻击必定会命中" - }, - "bouncyBubble": { - "name": "活活气泡", - "effect": "投掷水球进行攻击。吸水后能回复\n等同于造成的伤害的HP" - }, - "buzzyBuzz": { - "name": "麻麻电击", - "effect": "放出电击攻击对手。让对手陷入麻痹状态" - }, - "sizzlySlide": { - "name": "熊熊火爆", - "effect": "用燃起大火的身体猛烈地冲撞对手。\n让对手陷入灼伤状态" - }, - "glitzyGlow": { - "name": "哗哗气场", - "effect": "利用念力强攻,粉碎对方信心。\n制造一道能减弱对手特殊攻击的神奇墙壁" - }, - "baddyBad": { - "name": "坏坏领域", - "effect": "恶行恶相地进行攻击。\n制造一道能减弱对手物理攻击的神奇墙壁" - }, - "sappySeed": { - "name": "茁茁炸弹", - "effect": "长出巨大的藤蔓,播撒种子进行攻击。\n种子每回合都会吸取对手的HP" - }, - "freezyFrost": { - "name": "冰冰霜冻", - "effect": "利用冰冷的黑雾结晶进行攻击。\n使全体宝可梦的能力变回原点" - }, - "sparklySwirl": { - "name": "亮亮风暴", - "effect": "利用芬芳刺鼻的龙卷风吞噬对方。\n能治愈我方宝可梦的异常状态" - }, - "veeveeVolley": { - "name": "砰砰击破", - "effect": "伊布越喜欢训练家,冲撞的威力就越强。\n攻击必定会命中" - }, - "doubleIronBash": { - "name": "钢拳双击", - "effect": "以胸口的螺帽为中心旋转,\n并连续2次挥动手臂打击对手。\n有时会使对手畏缩" - }, - "maxGuard": { - "name": "极巨防壁", - "effect": "完全抵挡对手的攻击。\n连续使出则容易失败" - }, - "dynamaxCannon": { - "name": "极巨炮", - "effect": "将凝缩在体内的能量从核心放出进行攻击,\n对手等级比当前波次的等级上限越高,造成的伤害越高,最多两倍。" - }, - "snipeShot": { - "name": "狙击", - "effect": "能无视具有吸引对手招式效果的特\n性或招式的影响。可以向选定的对\n手进行攻击" - }, - "jawLock": { - "name": "紧咬不放", - "effect": "使双方直到一方昏厥为止\n无法替换宝可梦。\n其中一方退场则可以解除效果" - }, - "stuffCheeks": { - "name": "大快朵颐", - "effect": "吃掉携带的树果,大幅提高防御" - }, - "noRetreat": { - "name": "背水一战", - "effect": "提高自己的所有能力,\n但无法替换或逃走" - }, - "tarShot": { - "name": "沥青射击", - "effect": "泼洒黏糊糊的沥青,降低对手的速度。\n火属性会变成对手的弱点" - }, - "magicPowder": { - "name": "魔法粉", - "effect": "向对手喷洒魔法粉,使对手变为超\n能力属性" - }, - "dragonDarts": { - "name": "龙箭", - "effect": "让多龙梅西亚进行2次攻击。\n如果对手有2只宝可梦,则对它们各进\n行1次攻击" - }, - "teatime": { - "name": "茶会", - "effect": "举办一场茶会,场上的所有宝可梦\n都会吃掉自己携带的树果" - }, - "octolock": { - "name": "蛸固", - "effect": "让对手无法逃走。对手被固定后,\n每回合都会降低防御和特防" - }, - "boltBeak": { - "name": "电喙", - "effect": "用带电的喙啄刺对手。\n如果比对手先出手攻击,\n招式的威力会变成2倍" - }, - "fishiousRend": { - "name": "鳃咬", - "effect": "用坚硬的腮咬住对手。\n如果比对手先出手攻击,\n招式的威力会变成2倍" - }, - "courtChange": { - "name": "换场", - "effect": "用神奇的力量交换双方的场地效果" - }, - "maxFlare": { - "name": "极巨火爆", - "effect": "极巨化宝可梦使出的火属性攻击。\n可在5回合内让日照变得强烈" - }, - "maxFlutterby": { - "name": "极巨虫蛊", - "effect": "极巨化宝可梦使出的虫属性攻击。\n会降低对手的特攻" - }, - "maxLightning": { - "name": "极巨闪电", - "effect": "极巨化宝可梦使出的电属性攻击。\n可在5回合内将脚下变成电气场地" - }, - "maxStrike": { - "name": "极巨攻击", - "effect": "极巨化宝可梦使出的一般属性攻击。\n会降低对手的速度" - }, - "maxKnuckle": { - "name": "极巨拳斗", - "effect": "极巨化宝可梦使出的格斗属性攻击。\n会提高我方的攻击" - }, - "maxPhantasm": { - "name": "极巨幽魂", - "effect": "极巨化宝可梦使出的幽灵属性攻击。\n会降低对手的防御" - }, - "maxHailstorm": { - "name": "极巨寒冰", - "effect": "极巨化宝可梦使出的冰属性攻击。\n在5回合内会下雪" - }, - "maxOoze": { - "name": "极巨酸毒", - "effect": "极巨化宝可梦使出的毒属性攻击。\n会提高我方的特攻" - }, - "maxGeyser": { - "name": "极巨水流", - "effect": "极巨化宝可梦使出的水属性攻击。\n可在5回合内降下大雨" - }, - "maxAirstream": { - "name": "极巨飞冲", - "effect": "极巨化宝可梦使出的飞行属性攻击。\n会提高我方的速度" - }, - "maxStarfall": { - "name": "极巨妖精", - "effect": "极巨化宝可梦使出的妖精属性攻击。\n可在5回合内将脚下变成薄雾场地" - }, - "maxWyrmwind": { - "name": "极巨龙骑", - "effect": "极巨化宝可梦使出的龙属性攻击。\n会降低对手的攻击" - }, - "maxMindstorm": { - "name": "极巨超能", - "effect": "极巨化宝可梦使出的超能力属性攻击。\n可在5回合内将脚下变成精神场地" - }, - "maxRockfall": { - "name": "极巨岩石", - "effect": "极巨化宝可梦使出的岩石属性攻击。\n可在5回合内卷起沙暴" - }, - "maxQuake": { - "name": "极巨大地", - "effect": "极巨化宝可梦使出的地面属性攻击。\n会提高我方的特防" - }, - "maxDarkness": { - "name": "极巨恶霸", - "effect": "极巨化宝可梦使出的恶属性攻击。\n会降低对手的特防" - }, - "maxOvergrowth": { - "name": "极巨草原", - "effect": "极巨化宝可梦使出的草属性攻击。\n可在5回合内将脚下变成青草场地" - }, - "maxSteelspike": { - "name": "极巨钢铁", - "effect": "极巨化宝可梦使出的钢属性攻击。\n会提高我方的防御" - }, - "clangorousSoul": { - "name": "魂舞烈音爆", - "effect": "削减少许自己的HP,\n使所有能力都提高" - }, - "bodyPress": { - "name": "扑击", - "effect": "用身体撞向对手进行攻击。\n防御越高,给予的伤害就越高" - }, - "decorate": { - "name": "装饰", - "effect": "通过装饰,大幅提高对方的攻击和特攻" - }, - "drumBeating": { - "name": "鼓击", - "effect": "用鼓点来控制鼓的根部进行攻击,\n从而降低对手的速度" - }, - "snapTrap": { - "name": "捕兽夹", - "effect": "使用捕兽夹,在4~5回合内,\n夹住对手进行攻击" - }, - "pyroBall": { - "name": "火焰球", - "effect": "点燃小石子,形成火球攻击对手。\n有时会使对手陷入灼伤状态" - }, - "behemothBlade": { - "name": "巨兽斩", - "effect": "以全身力气举起强大的剑,\n猛烈地劈向对手进行攻击" - }, - "behemothBash": { - "name": "巨兽弹", - "effect": "将全身变化为坚固的盾,\n猛烈地撞向对手进行攻击" - }, - "auraWheel": { - "name": "气场轮", - "effect": "用储存在颊囊里的能量进行攻击,\n并提高自己的速度。其属性会随着\n莫鲁贝可的样子而改变" - }, - "breakingSwipe": { - "name": "广域破坏", - "effect": "用坚韧的尾巴猛扫对手进行攻击,\n从而降低对手的攻击" - }, - "branchPoke": { - "name": "木枝突刺", - "effect": "使用尖锐的树枝刺向对手进行攻击" - }, - "overdrive": { - "name": "破音", - "effect": "奏响吉他和贝斯,释放出发出巨响\n的剧烈震动攻击对手" - }, - "appleAcid": { - "name": "苹果酸", - "effect": "使用从酸苹果中提取出来的酸性液\n体进行攻击。降低对手的特防" - }, - "gravApple": { - "name": "万有引力", - "effect": "从高处落下苹果,给予对手伤害。\n可降低对手的防御" - }, - "spiritBreak": { - "name": "灵魂冲击", - "effect": "用足以让对手一蹶不振的气势进行攻击。\n会降低对手的特攻" - }, - "strangeSteam": { - "name": "神奇蒸汽", - "effect": "喷出烟雾攻击对手。有时会使对手混乱" - }, - "lifeDew": { - "name": "生命水滴", - "effect": "喷洒出神奇的水,回复自己和场上\n同伴的HP" - }, - "obstruct": { - "name": "拦堵", - "effect": "完全抵挡对手的攻击。\n连续使出则容易失败。一旦触碰,\n防御就会大幅降低" - }, - "falseSurrender": { - "name": "假跪真撞", - "effect": "装作低头认错的样子,\n用凌乱的头发进行突刺。攻击必定会命中" - }, - "meteorAssault": { - "name": "流星突击", - "effect": "大力挥舞粗壮的茎进行攻击。\n但同时自己也会被晃晕,下一回合自己\n将无法动弹" - }, - "eternabeam": { - "name": "无极光束", - "effect": "无极汰那变回原来的样子后,\n发动的最强攻击。\n下一回合自己将无法动弹" - }, - "steelBeam": { - "name": "铁蹄光线", - "effect": "将从全身聚集的钢铁化为光束,\n激烈地发射出去。自己也会受到伤害" - }, - "expandingForce": { - "name": "广域战力", - "effect": "利用精神力量攻击对手。\n在精神场地上威力会有所提高,\n能对所有对手造成伤害" - }, - "steelRoller": { - "name": "铁滚轮", - "effect": "在破坏场地的同时攻击对手。\n如果脚下没有任何场地状态存在,\n使出此招式时便会失败" - }, - "scaleShot": { - "name": "鳞射", - "effect": "发射鳞片进行攻击。连续攻击2~5次。\n速度会提高但防御会降低" - }, - "meteorBeam": { - "name": "流星光束", - "effect": "第1回合聚集宇宙之力提高特攻,\n第2回合攻击对手" - }, - "shellSideArm": { - "name": "臂贝武器", - "effect": "从物理攻击和特殊攻击中选择可造\n成较多伤害的方式进行攻击。\n有时会让对手陷入中毒状态" - }, - "mistyExplosion": { - "name": "薄雾炸裂", - "effect": "对自己周围的所有宝可梦进行攻击,\n但使出后,自己会陷入昏厥。\n在薄雾场地上,招式威力会提高" - }, - "grassyGlide": { - "name": "青草滑梯", - "effect": "仿佛在地面上滑行般地攻击对手。\n在青草场地上,必定能够先制攻击" - }, - "risingVoltage": { - "name": "电力上升", - "effect": "用从地面升腾而起的电击进行攻击。\n当对手处于电气场地上时,\n招式威力会变成2倍" - }, - "terrainPulse": { - "name": "大地波动", - "effect": "借助场地的力量进行攻击。\n视使出招式时场地状态不同,\n招式的属性和威力会有所变化" - }, - "skitterSmack": { - "name": "爬击", - "effect": "从对手背后爬近后进行攻击。\n会降低对手的特攻" - }, - "burningJealousy": { - "name": "妒火", - "effect": "用嫉妒的能量攻击对手。\n会让在该回合内能力有所提高\n的宝可梦陷入灼伤状态" - }, - "lashOut": { - "name": "泄愤", - "effect": "攻击对手以发泄对其感到的恼怒情绪。\n如果在该回合内自身能力遭到降低,\n招式的威力会变成2倍" - }, - "poltergeist": { - "name": "灵骚", - "effect": "操纵对手的持有物进行攻击。\n当对手没有携带道具时,使出此招式时\n便会失败" - }, - "corrosiveGas": { - "name": "腐蚀气体", - "effect": "用具有强酸性的气体包裹住自己周\n围所有的宝可梦,并融化其所携带的道具" - }, - "coaching": { - "name": "指导", - "effect": "通过进行正确合理的指导,\n提高我方全员的攻击和防御" - }, - "flipTurn": { - "name": "快速折返", - "effect": "在攻击之后急速返回,\n和后备宝可梦进行替换" - }, - "tripleAxel": { - "name": "三旋击", - "effect": "连续3次踢对手进行攻击。\n每踢中一次,威力就会提高" - }, - "dualWingbeat": { - "name": "双翼", - "effect": "将翅膀撞向对手进行攻击。\n连续2次给予伤害" - }, - "scorchingSands": { - "name": "热沙大地", - "effect": "将滚烫的沙子砸向对手进行攻击。\n有时会让对手陷入灼伤状态" - }, - "jungleHealing": { - "name": "丛林治疗", - "effect": "与丛林融为一体,回复自己和场上\n同伴的HP和状态" - }, - "wickedBlow": { - "name": "暗冥强击", - "effect": "将恶之流派修炼至大成的猛烈一击。\n必定会击中要害" - }, - "surgingStrikes": { - "name": "水流连打", - "effect": "将水之流派修炼至大成的仿若行云\n流水般的3次连击。必定会击中要害" - }, - "thunderCage": { - "name": "雷电囚笼", - "effect": "将对手困在电流四溅的囚笼中,\n在4~5回合内进行攻击" - }, - "dragonEnergy": { - "name": "巨龙威能", - "effect": "把生命力转换为力量攻击对手。\n自己的HP越少,招式的威力越小" - }, - "freezingGlare": { - "name": "冰冷视线", - "effect": "从双眼发射精神力量进行攻击。\n有时会让对手陷入冰冻状态" - }, - "fieryWrath": { - "name": "怒火中烧", - "effect": "将愤怒转化为火焰般的气场进行攻击。\n有时会使对手畏缩" - }, - "thunderousKick": { - "name": "雷鸣蹴击", - "effect": "以雷电般的动作\n戏耍对手的同时使出脚踢。\n可降低对手的防御" - }, - "glacialLance": { - "name": "雪矛", - "effect": "向对手投掷掀起暴风雪的冰矛进行攻击" - }, - "astralBarrage": { - "name": "星碎", - "effect": "用大量的小灵体向对手发起攻击" - }, - "eerieSpell": { - "name": "诡异咒语", - "effect": "用强大的精神力量攻击。\n让对手最后使用的招式减少3PP" - }, - "direClaw": { - "name": "克命爪", - "effect": "以破灭之爪进行攻击。\n有时还会让对手陷入中毒、麻痹、\n睡眠之中的一种状态" - }, - "psyshieldBash": { - "name": "屏障猛攻", - "effect": "让意念的能量覆盖全身,\n撞向对手进行攻击。会提高自己的防御" - }, - "powerShift": { - "name": "力量转换", - "effect": "将自己的攻击与防御互相交换" - }, - "stoneAxe": { - "name": "岩斧", - "effect": "用岩石之斧进行攻击。\n散落的岩石碎片会飘浮在对手周围" - }, - "springtideStorm": { - "name": "阳春风暴", - "effect": "用交织着爱与恨的烈风席卷对手\n进行攻击。有时会降低对手的攻击" - }, - "mysticalPower": { - "name": "神秘之力", - "effect": "放出不可思议的力量攻击。\n会提高自己的特攻" - }, - "ragingFury": { - "name": "大愤慨", - "effect": "在2~3回合内,一边放出火焰,\n一边疯狂乱打。大闹一番后自己会\n陷入混乱" - }, - "waveCrash": { - "name": "波动冲", - "effect": "让水覆盖全身后撞向对手。\n自己也会受到不少伤害" - }, - "chloroblast": { - "name": "叶绿爆震", - "effect": "将自己的叶绿素凝聚起来后放出去\n进行攻击。自己也会受到伤害" - }, - "mountainGale": { - "name": "冰山风", - "effect": "将冰山般巨大的冰块砸向对手进行攻击。\n有时会使对手畏缩" - }, - "victoryDance": { - "name": "胜利之舞", - "effect": "激烈地跳起唤来胜利的舞蹈,\n提高自己的攻击、防御和速度" - }, - "headlongRush": { - "name": "突飞猛扑", - "effect": "向对手使出灌注了全心全力的撞击。\n自己的防御和特防会降低" - }, - "barbBarrage": { - "name": "毒千针", - "effect": "用无数的毒针进行攻击。\n有时还会让对手陷入中毒状态。\n攻击处于中毒状态的对手时,\n威力会变成2倍" - }, - "esperWing": { - "name": "气场之翼", - "effect": "用经过气场强化的翅膀撕裂对手。\n容易击中要害。会提高自己的速度" - }, - "bitterMalice": { - "name": "冤冤相报", - "effect": "用令人毛骨悚然的怨念进行攻击。\n会降低对手的攻击" - }, - "shelter": { - "name": "闭关", - "effect": "将皮肤变得坚硬如铁盾,\n从而大幅提高自己的防御" - }, - "tripleArrows": { - "name": "三连箭", - "effect": "使出一记腿技后同时发射3箭。\n有时会降低对手的防御或使对手畏缩。\n容易击中要害" - }, - "infernalParade": { - "name": "群魔乱舞", - "effect": "用无数的火球进行攻击。有时会让对手陷\n入灼伤状态。攻击处于异常状态\n的对手时,威力会变成2倍" - }, - "ceaselessEdge": { - "name": "秘剑・千重涛", - "effect": "用贝壳之剑进行攻击。\n散落的贝壳碎片会散落\n在对手脚下成为撒菱" - }, - "bleakwindStorm": { - "name": "枯叶风暴", - "effect": "用足以让身心都止不住颤抖的冰冷\n狂风进行攻击。有时会降低对手的速度" - }, - "wildboltStorm": { - "name": "鸣雷风暴", - "effect": "呼唤雷云引起风暴,用雷与风进行\n激烈的攻击。有时会让对手陷入麻痹状态" - }, - "sandsearStorm": { - "name": "热沙风暴", - "effect": "用灼热的沙子和强烈的风席卷对手\n进行攻击。有时会让对手陷入灼伤状态" - }, - "lunarBlessing": { - "name": "新月祈祷", - "effect": "向新月献上祈祷,回复自己和场上\n同伴的HP和状态" - }, - "takeHeart": { - "name": "勇气填充", - "effect": "鼓起冲劲,治愈自己的异常状态,\n同时提高自己的特攻和特防" - }, - "gMaxWildfire": { - "name": "超极巨深渊灭焰", - "effect": "超极巨化的喷火龙使出的火属性攻击。\n可在4回合内给予对手伤害" - }, - "gMaxBefuddle": { - "name": "超极巨蝶影蛊惑", - "effect": "超极巨化的巴大蝶使出的虫属性攻击。\n会让对手陷入中毒、麻痹或睡眠状态" - }, - "gMaxVoltCrash": { - "name": "超极巨万雷轰顶", - "effect": "超极巨化的皮卡丘使出的电属性攻击。\n会让对手陷入麻痹状态" - }, - "gMaxGoldRush": { - "name": "超极巨特大金币", - "effect": "超极巨化的喵喵使出的一般属性攻击。\n会让对手陷入混乱状态,\n并可获得金钱" - }, - "gMaxChiStrike": { - "name": "超极巨会心一击", - "effect": "超极巨化的怪力使出的格斗属性攻击。\n会变得容易击中要害" - }, - "gMaxTerror": { - "name": "超极巨幻影幽魂", - "effect": "超极巨化的耿鬼使出的幽灵属性攻击。\n会踩住对手的影子,\n让其无法被替换" - }, - "gMaxResonance": { - "name": "超极巨极光旋律", - "effect": "超极巨化的拉普拉斯使出的冰属性攻击。\n可在5回合内减弱受到的伤害" - }, - "gMaxCuddle": { - "name": "超极巨热情拥抱", - "effect": "超极巨化的伊布使出的一般属性攻击。\n会让对手陷入着迷状态" - }, - "gMaxReplenish": { - "name": "超极巨资源再生", - "effect": "超极巨化的卡比兽使出的一般属性攻击。\n会让吃掉的树果再生" - }, - "gMaxMalodor": { - "name": "超极巨臭气冲天", - "effect": "超极巨化的灰尘山使出的毒属性攻击。\n会让对手陷入中毒状态" - }, - "gMaxStonesurge": { - "name": "超极巨岩阵以待", - "effect": "超极巨化的暴噬龟使出的水属性攻击。\n会发射无数锐利的岩石" - }, - "gMaxWindRage": { - "name": "超极巨旋风袭卷", - "effect": "超极巨化的钢铠鸦使出的飞行属性攻击。\n可消除反射壁和光墙" - }, - "gMaxStunShock": { - "name": "超极巨异毒电场", - "effect": "超极巨化的颤弦蝾螈使出的电属性攻击。\n会让对手陷入中毒或麻痹状态" - }, - "gMaxFinale": { - "name": "超极巨幸福圆满", - "effect": "超极巨化的霜奶仙使出的妖精属性攻击。\n可回复我方的HP" - }, - "gMaxDepletion": { - "name": "超极巨劣化衰变", - "effect": "超极巨化的铝钢龙使出的龙属性攻击。\n可减少对手最后使用的招式的PP" - }, - "gMaxGravitas": { - "name": "超极巨天道七星", - "effect": "超极巨化的以欧路普使出的超能力\n属性攻击。在5回合内重力会产生变化" - }, - "gMaxVolcalith": { - "name": "超极巨炎石喷发", - "effect": "超极巨化的巨炭山使出的岩石属性攻击。\n可在4回合内给予对手伤害" - }, - "gMaxSandblast": { - "name": "超极巨沙尘漫天", - "effect": "超极巨化的沙螺蟒使出的地面属性攻击。\n在4~5回合内会狂刮沙暴" - }, - "gMaxSnooze": { - "name": "超极巨睡魔降临", - "effect": "超极巨化的长毛巨魔使出的恶属性攻击。\n会通过打大哈欠让对手产生睡意" - }, - "gMaxTartness": { - "name": "超极巨酸不溜丢", - "effect": "超极巨化的苹裹龙使出的草属性攻击。\n会降低对手的闪避率" - }, - "gMaxSweetness": { - "name": "超极巨琼浆玉液", - "effect": "超极巨化的丰蜜龙使出的草属性攻击。\n会治愈我方的异常状态" - }, - "gMaxSmite": { - "name": "超极巨天谴雷诛", - "effect": "超极巨化的布莉姆温使出的\n妖精属性攻击。\n会让对手陷入混乱状态" - }, - "gMaxSteelsurge": { - "name": "超极巨钢铁阵法", - "effect": "超极巨化的大王铜象使出的钢属性攻击。\n会发射无数锐利的刺" - }, - "gMaxMeltdown": { - "name": "超极巨液金熔击", - "effect": "超极巨化的美录梅塔使出的钢属性攻击。\n会让对手无法连续使出相同的招式" - }, - "gMaxFoamBurst": { - "name": "超极巨激漩泡涡", - "effect": "超极巨化的巨钳蟹使出的水属性攻击。\n会大幅降低对手的速度" - }, - "gMaxCentiferno": { - "name": "超极巨百火焚野", - "effect": "超极巨化的焚焰蚣使出的火属性攻击。\n可在4~5回合内将对手困在火焰中" - }, - "gMaxVineLash": { - "name": "超极巨灰飞鞭灭", - "effect": "超极巨化的妙蛙花使出的草属性攻击。\n可在4回合内给予对手伤害" - }, - "gMaxCannonade": { - "name": "超极巨水炮轰灭", - "effect": "超极巨化的水箭龟使出的水属性攻击。\n可在4回合内给予对手伤害" - }, - "gMaxDrumSolo": { - "name": "超极巨狂擂乱打", - "effect": "超极巨化的轰擂金刚猩使出的\n草属性攻击。\n不会受到对手特性的干扰" - }, - "gMaxFireball": { - "name": "超极巨破阵火球", - "effect": "超极巨化的闪焰王牌使出的火属性攻击。\n不会受到对手特性的干扰" - }, - "gMaxHydrosnipe": { - "name": "超极巨狙击神射", - "effect": "超极巨化的千面避役使出的水属性攻击。\n不会受到对手特性的干扰" - }, - "gMaxOneBlow": { - "name": "超极巨夺命一击", - "effect": "超极巨化的武道熊师使出的恶属性攻击。\n是可以无视极巨防壁的一击" - }, - "gMaxRapidFlow": { - "name": "超极巨流水连击", - "effect": "超极巨化的武道熊师使出的水属性攻击。\n是可以无视极巨防壁的连击" - }, - "teraBlast": { - "name": "太晶爆发", - "effect": "太晶化时,会放出太晶属性的能量攻击。\n比较自己的攻击和特攻,\n用数值相对较高的一项给予对方伤害。\n(其他属性)/用攻击和特攻数\n值较高的一项给予伤害。\n对正处于太晶化的对手效果绝佳。\n自己的攻击和特攻会降低。(星晶" - }, - "silkTrap": { - "name": "线阱", - "effect": "用丝设置陷阱。防住对方攻击的同时,\n能够降低所接触到的对手的速度" - }, - "axeKick": { - "name": "下压踢", - "effect": "将踢起的脚跟往下劈向对手进行攻击。\n有时会使对手混乱。\n如果劈偏则自己会受到伤害" - }, - "lastRespects": { - "name": "扫墓", - "effect": "为了化解伙伴的悔恨而进行攻击。\n被打倒的我方宝可梦越多,\n招式的威力越高" - }, - "luminaCrash": { - "name": "琉光冲激", - "effect": "放出连精神都能影响到的奇妙怪光\n进行攻击。会大幅降低对方的特防" - }, - "orderUp": { - "name": "上菜", - "effect": "以潇洒的身手进行攻击。\n若口中有米立龙,会按其样子提高能力" - }, - "jetPunch": { - "name": "喷射拳", - "effect": "将激流覆盖于拳头,以肉眼无法辨\n识的速度打出拳击。必定能够先制攻击" - }, - "spicyExtract": { - "name": "辣椒精华", - "effect": "放出极为辛辣的精华。\n对手的攻击会大幅提高,防御会大幅降低" - }, - "spinOut": { - "name": "疾速转轮", - "effect": "通过往腿上增加负荷,\n以激烈的旋转给予对手伤害。\n自己的速度会大幅降低" - }, - "populationBomb": { - "name": "鼠数儿", - "effect": "伙伴们会纷纷赶来集合,\n以群体行动给予对手攻击。\n连续命中1~10次" - }, - "iceSpinner": { - "name": "冰旋", - "effect": "脚上覆盖薄冰,旋转着撞击对手。\n通过旋转的动作破坏场地" - }, - "glaiveRush": { - "name": "巨剑突击", - "effect": "有勇无谋的舍身突击。使出招式后,\n对手的攻击必定会命中,\n且伤害会变成2倍" - }, - "revivalBlessing": { - "name": "复生祈祷", - "effect": "通过以慈爱之心祈祷,\n让陷入昏厥的后备宝可梦\n以回复一半HP的状态复活" - }, - "saltCure": { - "name": "盐腌", - "effect": "使对手陷入盐腌状态,\n每回合给予对手伤害。\n对手为钢或水属性时会更痛苦" - }, - "tripleDive": { - "name": "三连钻", - "effect": "以默契的跳跃溅起水花击向对手。\n连续3次给予伤害" - }, - "mortalSpin": { - "name": "晶光转转", - "effect": "通过旋转来攻击对手。\n可以摆脱绑紧、紧束、寄生种子等招式。\n还能让对手陷入中毒状态" - }, - "doodle": { - "name": "描绘", - "effect": "把握并映射出对手的本质,\n让自己和同伴宝可梦的特性\n变得和对手相同" - }, - "filletAway": { - "name": "甩肉", - "effect": "削减自己的HP,大幅提高攻击和\n特攻以及速度" - }, - "kowtowCleave": { - "name": "仆刀", - "effect": "下跪让对手大意后发起袭击劈向对手。\n攻击必定会命中" - }, - "flowerTrick": { - "name": "千变万花", - "effect": "将做了手脚的花束扔向对手进行攻击。\n必定会命中,且会击中要害" - }, - "torchSong": { - "name": "闪焰高歌", - "effect": "如唱歌一样喷出熊熊燃烧的火焰\n烧焦对手。会提高自己的特攻" - }, - "aquaStep": { - "name": "流水旋舞", - "effect": "以盈盈欲滴的轻快步伐戏耍对手并\n给予其伤害。会提高自己的速度" - }, - "ragingBull": { - "name": "怒牛", - "effect": "狂怒暴牛的猛烈冲撞。\n招式的属性随形态改变,\n光墙和反射壁等招式也能破坏" - }, - "makeItRain": { - "name": "淘金潮", - "effect": "扔出大量硬币攻击。自己的特攻会降低,\n战斗后还可以拿到钱" - }, - "psyblade": { - "name": "精神剑", - "effect": "用无形的利刃劈开对手。\n处于电气场地时,\n招式威力会变成1.5倍" - }, - "hydroSteam": { - "name": "水蒸气", - "effect": "将煮得翻滚的开水猛烈地喷向对手。\n日照强烈时,招式威力不但不会降低,\n还会变成1.5倍" - }, - "ruination": { - "name": "大灾难", - "effect": "引发毁灭性的灾厄,使对手的HP减半" - }, - "collisionCourse": { - "name": "全开猛撞", - "effect": "边变形边凶暴地落下,\n并引发起古老的大爆炸。若针对到弱点,\n威力会进一步" - }, - "electroDrift": { - "name": "闪电猛冲", - "effect": "边变形边高速奔走,并以未知的电\n击贯穿对手。若针对到弱点,\n威力会进一步" - }, - "shedTail": { - "name": "断尾", - "effect": "削减自己的HP,制造分身后会返回,\n并和后备宝可梦进行替换" - }, - "chillyReception": { - "name": "冷笑话", - "effect": "留下冷场的冷笑话后,\n和后备宝可梦进行替换。\n在5回合内会下雪" - }, - "tidyUp": { - "name": "大扫除", - "effect": "将撒菱、隐形岩、黏黏网、毒菱、\n替身全部扫除掉。自己的攻击和速\n度会提高" - }, - "snowscape": { - "name": "雪景", - "effect": "在5回合内会下雪。冰属性的防御会提高" - }, - "pounce": { - "name": "虫扑", - "effect": "飞扑向对手攻击。会降低对手的速度" - }, - "trailblaze": { - "name": "起草", - "effect": "跳出草丛进行攻击。通过轻快的步\n伐会提高自己的速度" - }, - "chillingWater": { - "name": "泼冷水", - "effect": "泼洒冰冷得足以让对手失去活力的\n水进行攻击。会降低对手的攻击" - }, - "hyperDrill": { - "name": "强力钻", - "effect": "急速旋转尖锐的身体部位贯穿对手。\n可以无视守住和看穿等招式" - }, - "twinBeam": { - "name": "双光束", - "effect": "从两眼发射出神奇的光线攻击。\n连续2次给予伤害" - }, - "rageFist": { - "name": "愤怒之拳", - "effect": "将愤怒化为力量攻击。\n受到攻击的次数越多,招式的威力越高" - }, - "armorCannon": { - "name": "铠农炮", - "effect": "熊熊燃烧自己的铠甲,\n将其做成炮弹射出攻击。\n自己的防御和特防会降低" - }, - "bitterBlade": { - "name": "悔念剑", - "effect": "将对世间的留恋聚集于剑尖,\n并斩击对手。可以回复给予对手伤害的\n一半HP" - }, - "doubleShock": { - "name": "电光双击", - "effect": "将全身所有的电力放出,\n给予对手大大的伤害。\n自己的电属性将会消失" - }, - "gigatonHammer": { - "name": "巨力锤", - "effect": "连同身体转起巨大的锤子进行攻击。\n这个招式无法连续使出2次" - }, - "comeuppance": { - "name": "复仇", - "effect": "使出招式前,将最后受到的招式的\n伤害大力返还给对手" - }, - "aquaCutter": { - "name": "水波刀", - "effect": "如刀刃般喷射出加压的水切开对手。\n容易击中要害" - }, - "blazingTorque": { - "name": "灼热暴冲", - "effect": "攻击目标造成伤害,有30%的几\n率使目标陷入灼伤状态。" - }, - "wickedTorque": { - "name": "黑暗暴冲", - "effect": "攻击目标造成伤害,有30%的几\n率使目标陷入睡眠状态。" - }, - "noxiousTorque": { - "name": "剧毒暴冲", - "effect": "攻击目标造成伤害,有30%的几\n率使目标陷入中毒状态。" - }, - "combatTorque": { - "name": "格斗暴冲", - "effect": "攻击目标造成伤害,有30%的几\n率使目标陷入麻痹状态。\n此招式可以命中幽灵属性的宝可梦。" - }, - "magicalTorque": { - "name": "魔法暴冲", - "effect": "攻击目标造成伤害,有30%的几\n率使目标陷入混乱状态。" - }, - "bloodMoon": { - "name": "血月", - "effect": "从赤红如血的满月发射出全部的气势。\n这个招式无法连续使出2次" - }, - "matchaGotcha": { - "name": "刷刷茶炮", - "effect": "发射经搅拌的茶的大炮,\n可以回复给予对手伤害的一半HP,\n有时会让对手陷入灼伤状态" - }, - "syrupBomb": { - "name": "糖浆炸弹", - "effect": "使粘稠的麦芽糖浆爆炸,\n让对手陷入满身糖状态,\n在3回合内持续降\n低其速度" - }, - "ivyCudgel": { - "name": "棘藤棒", - "effect": "用缠有藤蔓的棍棒殴打。\n属性会随所戴的面具而改变。\n容易击中要害" - }, - "electroShot": { - "name": "电光束", - "effect": "第1回合收集电力提高特攻,\n第2回合将高压的电力发射出去。\n下雨天气时能立刻发射" - }, - "teraStarstorm": { - "name": "晶光星群", - "effect": "照射出结晶的力量来驱逐敌人。\n太乐巴戈斯在星晶形态下使出时,\n能对所有对手造成伤害" - }, - "fickleBeam": { - "name": "随机光", - "effect": "发射光线进行攻击。有时其他的头\n也会合力发射镭射,让招式威力变成2倍" - }, - "burningBulwark": { - "name": "火焰守护", - "effect": "用超高温的体毛防住对手攻击的同时,\n让接触到自己的对手灼伤" - }, - "thunderclap": { - "name": "迅雷", - "effect": "可以比对手先使出电击进行攻击。\n对手使出的招式如果不是攻击招式\n则会失败" - }, - "mightyCleave": { - "name": "强刃攻击", - "effect": "用积蓄在头部的光来斩切对手。\n可以无视守护进行攻击" - }, - "tachyonCutter": { - "name": "迅子利刃", - "effect": "接连发射出粒子的利刃,\n连续2次给予伤害。攻击必定会命中" - }, - "hardPress": { - "name": "硬压", - "effect": "用手臂或钳子压迫对手。\n对手剩余的HP越多,威力越大" - }, - "dragonCheer": { - "name": "龙声鼓舞", - "effect": "以龙之鼓舞提高士气,\n让我方的招式变得容易击中要害。\n对龙属性的鼓舞效果会更强" - }, - "alluringVoice": { - "name": "魅诱之声", - "effect": "用天使般的歌声攻击对手。\n会让此回合内能力有提高的\n宝可梦陷入混乱状态" - }, - "temperFlare": { - "name": "豁出去", - "effect": "以自暴自弃的气势进行攻击。\n如果上一回合招式没有命中,\n威力就会翻倍" - }, - "supercellSlam": { - "name": "闪电强袭", - "effect": "让身体带电后压向对手。\n如果没有命中则自己会受到伤害" - }, - "psychicNoise": { - "name": "精神噪音", - "effect": "用令对手不舒服的音波进行攻击。\n让对手在2回合内无法通过招式、\n特性或携带的道具回复HP" - }, - "upperHand": { - "name": "快手还击", - "effect": "察觉到对手的动作后用掌根攻击,\n让对手畏缩。如果对手使出的招式\n不是先制攻击,则会失败" - }, - "malignantChain": { - "name": "邪毒锁链", - "effect": "用由毒形成的锁链缠住对手注入毒\n素加以侵蚀。有时会让对手陷入剧毒状态" - } -} diff --git a/src/locales/zh_CN/nature.json b/src/locales/zh_CN/nature.json deleted file mode 100644 index 60b34c9363a..00000000000 --- a/src/locales/zh_CN/nature.json +++ /dev/null @@ -1,27 +0,0 @@ -{ - "Hardy": "勤奋", - "Lonely": "怕寂寞", - "Brave": "勇敢", - "Adamant": "固执", - "Naughty": "顽皮", - "Bold": "大胆", - "Docile": "坦率", - "Relaxed": "悠闲", - "Impish": "淘气", - "Lax": "乐天", - "Timid": "胆小", - "Hasty": "急躁", - "Serious": "认真", - "Jolly": "爽朗", - "Naive": "天真", - "Modest": "内敛", - "Mild": "慢吞吞", - "Quiet": "冷静", - "Bashful": "害羞", - "Rash": "马虎", - "Calm": "温和", - "Gentle": "温顺", - "Sassy": "自大", - "Careful": "慎重", - "Quirky": "浮躁" -} \ No newline at end of file diff --git a/src/locales/zh_CN/party-ui-handler.json b/src/locales/zh_CN/party-ui-handler.json deleted file mode 100644 index 8dff1ffb75c..00000000000 --- a/src/locales/zh_CN/party-ui-handler.json +++ /dev/null @@ -1,47 +0,0 @@ -{ - "SEND_OUT": "上场", - "SUMMARY": "概要", - "CANCEL": "取消", - "RELEASE": "放生", - "APPLY": "应用", - "TEACH": "教授", - "SPLICE": "融合", - "UNSPLICE": "分离", - "ACTIVATE": "激活", - "DEACTIVATE": "解除", - "TRANSFER": "交换", - "ALL": "全部道具", - "PASS_BATON": "接棒", - "UNPAUSE_EVOLUTION": "解除进化暂停", - "REVIVE": "复活", - "RENAME": "起名", - "choosePokemon": "选择一只宝可梦。", - "doWhatWithThisPokemon": "要对宝可梦做什么?", - "noEnergy": "{{pokemonName}}没有力气战斗了!", - "hasEnergy": "{{pokemonName}}仍然精神十足!", - "cantBeUsed": "{{pokemonName}}无法在此挑战中使用!", - "tooManyItems": "{{pokemonName}}拥有\n太多这个道具了!", - "anyEffect": "即便使用也无效果哦。", - "unpausedEvolutions": "{{pokemonName}}的进化停止了。", - "unspliceConfirmation": "真的要把{{fusionName}}\n从{{pokemonName}}身上分离吗?{{fusionName}}会就此消失。", - "wasReverted": "{{fusionName}}恢复成了{{pokemonName}}。", - "releaseConfirmation": "你真要放生{{pokemonName}}吗?", - "releaseInBattle": "你无法放生正在战斗中的宝可梦!", - "selectAMove": "选择一个招式。", - "changeQuantity": "选择一件道具来交换。\n使用 ← 和 → 来指定数量。", - "selectAnotherPokemonToSplice": "选择另一只宝可梦来融合。", - "cancel": "取消", - "able": "能学会!", - "notAble": "无法学习", - "learned": "已习得", - "goodbye": "再见,{{pokemonName}}!", - "byebye": "拜拜,{{pokemonName}}!", - "farewell": "再会了,{{pokemonName}}!", - "soLong": "告辞了,{{pokemonName}}!", - "thisIsWhereWePart": "就此分别吧,{{pokemonName}}!", - "illMissYou": "我会想你的,{{pokemonName}}!", - "illNeverForgetYou": "我不会忘记你的,{{pokemonName}}!", - "untilWeMeetAgain": "下次再见了,{{pokemonName}}!", - "sayonara": "撒由那拉,{{pokemonName}}!", - "smellYaLater": "拜拜了您嘞,{{pokemonName}}!" -} diff --git a/src/locales/zh_CN/pokeball.json b/src/locales/zh_CN/pokeball.json deleted file mode 100644 index 4f2a959f904..00000000000 --- a/src/locales/zh_CN/pokeball.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "pokeBall": "精灵球", - "greatBall": "超级球", - "ultraBall": "高级球", - "rogueBall": "肉鸽球", - "masterBall": "大师球", - "luxuryBall": "豪华球" -} \ No newline at end of file diff --git a/src/locales/zh_CN/pokemon-form-battle.json b/src/locales/zh_CN/pokemon-form-battle.json deleted file mode 100644 index 9db2cbc0154..00000000000 --- a/src/locales/zh_CN/pokemon-form-battle.json +++ /dev/null @@ -1,14 +0,0 @@ -{ - "mega": "Mega {{pokemonName}}", - "mega-x": "Mega {{pokemonName}} X", - "mega-y": "Mega {{pokemonName}} Y", - "primal": "原始{{pokemonName}}", - "gigantamax": "超极巨{{pokemonName}}", - "eternamax": "无极巨{{pokemonName}}", - "megaChange": "{{preName}}超级进化成了\n{{pokemonName}}!", - "gigantamaxChange": "{{preName}}超极巨化成了\n{{pokemonName}}!", - "eternamaxChange": "{{preName}}无极巨化成了\n{{pokemonName}}!", - "revertChange": "{{pokemonName}}变回了\n原本的样子!", - "formChange": "{{preName}}变成其他样子了。", - "disguiseChange": "它的画皮被当作诱饵使用了!" -} \ No newline at end of file diff --git a/src/locales/zh_CN/pokemon-form.json b/src/locales/zh_CN/pokemon-form.json deleted file mode 100644 index e77f9bdb9fa..00000000000 --- a/src/locales/zh_CN/pokemon-form.json +++ /dev/null @@ -1,170 +0,0 @@ -{ - "pikachuCosplay": "换装", - "pikachuCoolCosplay": "摇滚巨星", - "pikachuBeautyCosplay": "贵妇", - "pikachuCuteCosplay": "流行偶像", - "pikachuSmartCosplay": "博士", - "pikachuToughCosplay": "面罩摔跤手", - "pikachuPartner": "搭档", - "eeveePartner": "搭档", - "pichuSpiky": "刺刺耳", - "unownA": "A", - "unownB": "B", - "unownC": "C", - "unownD": "D", - "unownE": "E", - "unownF": "F", - "unownG": "G", - "unownH": "H", - "unownI": "I", - "unownJ": "J", - "unownK": "K", - "unownL": "L", - "unownM": "M", - "unownN": "N", - "unownO": "O", - "unownP": "P", - "unownQ": "Q", - "unownR": "R", - "unownS": "S", - "unownT": "T", - "unownU": "U", - "unownV": "V", - "unownW": "W", - "unownX": "X", - "unownY": "Y", - "unownZ": "Z", - "unownExclamation": "!", - "unownQuestion": "?", - "castformSunny": "晴天", - "castformRainy": "雨天", - "castformSnowy": "雪天", - "deoxysNormal": "普通", - "burmyPlant": "草木蓑衣", - "burmySandy": "砂土蓑衣", - "burmyTrash": "垃圾蓑衣", - "shellosEast": "东海", - "shellosWest": "西海", - "rotomHeat": "加热", - "rotomWash": "清洗", - "rotomFrost": "结冰", - "rotomFan": "旋转", - "rotomMow": "切割", - "giratinaAltered": "别种", - "shayminLand": "陆上", - "basculinRedStriped": "红条纹", - "basculinBlueStriped": "蓝条纹", - "basculinWhiteStriped": "白条纹", - "deerlingSpring": "春天", - "deerlingSummer": "夏天", - "deerlingAutumn": "秋天", - "deerlingWinter": "冬天", - "tornadusIncarnate": "化身", - "thundurusIncarnate": "化身", - "landorusIncarnate": "化身", - "keldeoOrdinary": "通常", - "meloettaAria": "歌声", - "meloettaPirouette": "舞步形态", - "froakieBattleBond": "牵绊变身", - "scatterbugMeadow": "花园花纹", - "scatterbugIcySnow": "冰雪花纹", - "scatterbugPolar": "雪国花纹", - "scatterbugTundra": "雪原花纹", - "scatterbugContinental": "大陆花纹", - "scatterbugGarden": "庭园花纹", - "scatterbugElegant": "高雅花纹", - "scatterbugModern": "摩登花纹", - "scatterbugMarine": "大海花纹", - "scatterbugArchipelago": "群岛花纹", - "scatterbugHighPlains": "荒野花纹", - "scatterbugSandstorm": "沙尘花纹", - "scatterbugRiver": "大河花纹", - "scatterbugMonsoon": "骤雨花纹", - "scatterbugSavanna": "热带草原花纹", - "scatterbugSun": "太阳花纹", - "scatterbugOcean": "大洋花纹", - "scatterbugJungle": "热带雨林花纹", - "scatterbugFancy": "幻彩花纹", - "scatterbugPokeBall": "球球花纹", - "flabebeRed": "红花", - "flabebeYellow": "黄花", - "flabebeOrange": "橙花", - "flabebeBlue": "蓝花", - "flabebeWhite": "白花", - "furfrouHeart": "心形造型", - "furfrouStar": "星形造型", - "furfrouDiamond": "菱形造型", - "furfrouDebutante": "淑女造型", - "furfrouMatron": "贵妇造型", - "furfrouDandy": "绅士造型", - "furfrouLaReine": "女王造型", - "furfrouKabuki": "歌舞伎造型", - "furfrouPharaoh": "国王造型", - "pumpkabooSmall": "小尺寸", - "pumpkabooLarge": "大尺寸", - "pumpkabooSuper": "特大尺寸", - "xerneasNeutral": "放松模式", - "xerneasActive": "活跃模式", - "zygarde50": "50%形态", - "zygarde10": "10%形态", - "zygarde50Pc": "50%形态 群聚变形", - "zygarde10Pc": "10%形态 群聚变形", - "zygardeComplete": "完全体形态", - "oricorioBaile": "热辣热辣风格", - "oricorioPompom": "啪滋啪滋风格", - "oricorioPau": "呼拉呼拉风格", - "oricorioSensu": "轻盈轻盈风格", - "rockruffOwnTempo": "特殊岩狗狗", - "miniorRedMeteor": "红色核心", - "miniorOrangeMeteor": "橙色核心", - "miniorYellowMeteor": "黄色核心", - "miniorGreenMeteor": "绿色核心", - "miniorBlueMeteor": "浅蓝色核心", - "miniorIndigoMeteor": "蓝色核心", - "miniorVioletMeteor": "紫色核心", - "miniorRed": "红色", - "miniorOrange": "橙色", - "miniorYellow": "黄色", - "miniorGreen": "绿色", - "miniorBlue": "浅蓝色", - "miniorIndigo": "蓝色", - "miniorViolet": "紫色", - "mimikyuDisguised": "化形", - "mimikyuBusted": "现形", - "magearnaOriginal": "500年前的颜色", - "marshadowZenith": "全力", - "sinisteaPhony": "赝品", - "sinisteaAntique": "真品", - "eiscueNoIce": "解冻头", - "indeedeeMale": "雄性", - "indeedeeFemale": "雌性", - "morpekoFullBelly": "满腹花纹", - "zacianHeroOfManyBattles": "百战勇者", - "zamazentaHeroOfManyBattles": "百战勇者", - "zarudeDada": "老爹", - "enamorusIncarnate": "化身", - "squawkabillyGreenPlumage": "绿羽毛", - "squawkabillyBluePlumage": "蓝羽毛", - "squawkabillyYellowPlumage": "黄羽毛", - "squawkabillyWhitePlumage": "白羽毛", - "tatsugiriCurly": "上弓姿势", - "tatsugiriDroopy": "下垂姿势", - "tatsugiriStretchy": "平挺姿势", - "gimmighoulChest": "宝箱形态", - "gimmighoulRoaming": "徒步形态", - "koraidonApexBuild": "顶尖形态", - "koraidonLimitedBuild": "限制形态", - "koraidonSprintingBuild": "冲刺形态", - "koraidonSwimmingBuild": "游泳形态", - "koraidonGlidingBuild": "滑翔形态", - "miraidonUltimateMode": "极限模式", - "miraidonLowPowerMode": "节能模式", - "miraidonDriveMode": "驾驶模式", - "miraidonAquaticMode": "水上模式", - "miraidonGlideMode": "滑翔模式", - "poltchageistCounterfeit": "冒牌货", - "poltchageistArtisan": "高档货", - "paldeaTaurosCombat": "斗战种", - "paldeaTaurosBlaze": "火炽种", - "paldeaTaurosAqua": "水澜种" -} diff --git a/src/locales/zh_CN/pokemon-info-container.json b/src/locales/zh_CN/pokemon-info-container.json deleted file mode 100644 index 15b5f4a2da5..00000000000 --- a/src/locales/zh_CN/pokemon-info-container.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "moveset": "招式", - "gender": "性别:", - "ability": "特性:", - "nature": "性格:" -} \ No newline at end of file diff --git a/src/locales/zh_CN/pokemon-info.json b/src/locales/zh_CN/pokemon-info.json deleted file mode 100644 index a21a8156e4c..00000000000 --- a/src/locales/zh_CN/pokemon-info.json +++ /dev/null @@ -1,40 +0,0 @@ -{ - "Stat": { - "HP": "最大HP", - "HPshortened": "HP", - "ATK": "攻击", - "ATKshortened": "攻击", - "DEF": "防御", - "DEFshortened": "防御", - "SPATK": "特攻", - "SPATKshortened": "特攻", - "SPDEF": "特防", - "SPDEFshortened": "特防", - "SPD": "速度", - "SPDshortened": "速度", - "ACC": "命中率", - "EVA": "回避率" - }, - "Type": { - "UNKNOWN": "未知", - "NORMAL": "一般", - "FIGHTING": "格斗", - "FLYING": "飞行", - "POISON": "毒", - "GROUND": "地面", - "ROCK": "岩石", - "BUG": "虫", - "GHOST": "幽灵", - "STEEL": "钢", - "FIRE": "火", - "WATER": "水", - "GRASS": "草", - "ELECTRIC": "电", - "PSYCHIC": "超能力", - "ICE": "冰", - "DRAGON": "龙", - "DARK": "恶", - "FAIRY": "妖精", - "STELLAR": "星晶" - } -} diff --git a/src/locales/zh_CN/pokemon-summary.json b/src/locales/zh_CN/pokemon-summary.json deleted file mode 100644 index 159b0a38315..00000000000 --- a/src/locales/zh_CN/pokemon-summary.json +++ /dev/null @@ -1,16 +0,0 @@ -{ - "pokemonInfo": "宝可梦信息", - "status": "状态", - "powerAccuracyCategory": "威力\n命中率\n类别", - "type": "属性", - "unknownTrainer": "未知", - "ot": "训练师", - "nature": "性格", - "expPoints": "经验值", - "nextLv": "下一级", - "cancel": "取消", - "memoString": "{{natureFragment}} 性格,\n{{metFragment}}", - "metFragment": { - "apparently": "命中注定般地相遇于Lv.{{level}},\n{{biome}}。" - } -} \ No newline at end of file diff --git a/src/locales/zh_CN/pokemon.json b/src/locales/zh_CN/pokemon.json deleted file mode 100644 index 1e70dc29e70..00000000000 --- a/src/locales/zh_CN/pokemon.json +++ /dev/null @@ -1,1084 +0,0 @@ -{ - "bulbasaur": "妙蛙种子", - "ivysaur": "妙蛙草", - "venusaur": "妙蛙花", - "charmander": "小火龙", - "charmeleon": "火恐龙", - "charizard": "喷火龙", - "squirtle": "杰尼龟", - "wartortle": "卡咪龟", - "blastoise": "水箭龟", - "caterpie": "绿毛虫", - "metapod": "铁甲蛹", - "butterfree": "巴大蝶", - "weedle": "独角虫", - "kakuna": "铁壳蛹", - "beedrill": "大针蜂", - "pidgey": "波波", - "pidgeotto": "比比鸟", - "pidgeot": "大比鸟", - "rattata": "小拉达", - "raticate": "拉达", - "spearow": "烈雀", - "fearow": "大嘴雀", - "ekans": "阿柏蛇", - "arbok": "阿柏怪", - "pikachu": "皮卡丘", - "raichu": "雷丘", - "sandshrew": "穿山鼠", - "sandslash": "穿山王", - "nidoran_f": "尼多兰", - "nidorina": "尼多娜", - "nidoqueen": "尼多后", - "nidoran_m": "尼多朗", - "nidorino": "尼多力诺", - "nidoking": "尼多王", - "clefairy": "皮皮", - "clefable": "皮可西", - "vulpix": "六尾", - "ninetales": "九尾", - "jigglypuff": "胖丁", - "wigglytuff": "胖可丁", - "zubat": "超音蝠", - "golbat": "大嘴蝠", - "oddish": "走路草", - "gloom": "臭臭花", - "vileplume": "霸王花", - "paras": "派拉斯", - "parasect": "派拉斯特", - "venonat": "毛球", - "venomoth": "摩鲁蛾", - "diglett": "地鼠", - "dugtrio": "三地鼠", - "meowth": "喵喵", - "persian": "猫老大", - "psyduck": "可达鸭", - "golduck": "哥达鸭", - "mankey": "猴怪", - "primeape": "火暴猴", - "growlithe": "卡蒂狗", - "arcanine": "风速狗", - "poliwag": "蚊香蝌蚪", - "poliwhirl": "蚊香君", - "poliwrath": "蚊香泳士", - "abra": "凯西", - "kadabra": "勇基拉", - "alakazam": "胡地", - "machop": "腕力", - "machoke": "豪力", - "machamp": "怪力", - "bellsprout": "喇叭芽", - "weepinbell": "口呆花", - "victreebel": "大食花", - "tentacool": "玛瑙水母", - "tentacruel": "毒刺水母", - "geodude": "小拳石", - "graveler": "隆隆石", - "golem": "隆隆岩", - "ponyta": "小火马", - "rapidash": "烈焰马", - "slowpoke": "呆呆兽", - "slowbro": "呆壳兽", - "magnemite": "小磁怪", - "magneton": "三合一磁怪", - "farfetchd": "大葱鸭", - "doduo": "嘟嘟", - "dodrio": "嘟嘟利", - "seel": "小海狮", - "dewgong": "白海狮", - "grimer": "臭泥", - "muk": "臭臭泥", - "shellder": "大舌贝", - "cloyster": "刺甲贝", - "gastly": "鬼斯", - "haunter": "鬼斯通", - "gengar": "耿鬼", - "onix": "大岩蛇", - "drowzee": "催眠貘", - "hypno": "引梦貘人", - "krabby": "大钳蟹", - "kingler": "巨钳蟹", - "voltorb": "霹雳电球", - "electrode": "顽皮雷弹", - "exeggcute": "蛋蛋", - "exeggutor": "椰蛋树", - "cubone": "卡拉卡拉", - "marowak": "嘎啦嘎啦", - "hitmonlee": "飞腿郎", - "hitmonchan": "快拳郎", - "lickitung": "大舌头", - "koffing": "瓦斯弹", - "weezing": "双弹瓦斯", - "rhyhorn": "独角犀牛", - "rhydon": "钻角犀兽", - "chansey": "吉利蛋", - "tangela": "蔓藤怪", - "kangaskhan": "袋兽", - "horsea": "墨海马", - "seadra": "海刺龙", - "goldeen": "角金鱼", - "seaking": "金鱼王", - "staryu": "海星星", - "starmie": "宝石海星", - "mr_mime": "魔墙人偶", - "scyther": "飞天螳螂", - "jynx": "迷唇姐", - "electabuzz": "电击兽", - "magmar": "鸭嘴火兽", - "pinsir": "凯罗斯", - "tauros": "肯泰罗", - "magikarp": "鲤鱼王", - "gyarados": "暴鲤龙", - "lapras": "拉普拉斯", - "ditto": "百变怪", - "eevee": "伊布", - "vaporeon": "水伊布", - "jolteon": "雷伊布", - "flareon": "火伊布", - "porygon": "多边兽", - "omanyte": "菊石兽", - "omastar": "多刺菊石兽", - "kabuto": "化石盔", - "kabutops": "镰刀盔", - "aerodactyl": "化石翼龙", - "snorlax": "卡比兽", - "articuno": "急冻鸟", - "zapdos": "闪电鸟", - "moltres": "火焰鸟", - "dratini": "迷你龙", - "dragonair": "哈克龙", - "dragonite": "快龙", - "mewtwo": "超梦", - "mew": "梦幻", - "chikorita": "菊草叶", - "bayleef": "月桂叶", - "meganium": "大竺葵", - "cyndaquil": "火球鼠", - "quilava": "火岩鼠", - "typhlosion": "火暴兽", - "totodile": "小锯鳄", - "croconaw": "蓝鳄", - "feraligatr": "大力鳄", - "sentret": "尾立", - "furret": "大尾立", - "hoothoot": "咕咕", - "noctowl": "猫头夜鹰", - "ledyba": "芭瓢虫", - "ledian": "安瓢虫", - "spinarak": "圆丝蛛", - "ariados": "阿利多斯", - "crobat": "叉字蝠", - "chinchou": "灯笼鱼", - "lanturn": "电灯怪", - "pichu": "皮丘", - "cleffa": "皮宝宝", - "igglybuff": "宝宝丁", - "togepi": "波克比", - "togetic": "波克基古", - "natu": "天然雀", - "xatu": "天然鸟", - "mareep": "咩利羊", - "flaaffy": "茸茸羊", - "ampharos": "电龙", - "bellossom": "美丽花", - "marill": "玛力露", - "azumarill": "玛力露丽", - "sudowoodo": "树才怪", - "politoed": "蚊香蛙皇", - "hoppip": "毽子草", - "skiploom": "毽子花", - "jumpluff": "毽子棉", - "aipom": "长尾怪手", - "sunkern": "向日种子", - "sunflora": "向日花怪", - "yanma": "蜻蜻蜓", - "wooper": "乌波", - "quagsire": "沼王", - "espeon": "太阳伊布", - "umbreon": "月亮伊布", - "murkrow": "黑暗鸦", - "slowking": "呆呆王", - "misdreavus": "梦妖", - "unown": "未知图腾", - "wobbuffet": "果然翁", - "girafarig": "麒麟奇", - "pineco": "榛果球", - "forretress": "佛烈托斯", - "dunsparce": "土龙弟弟", - "gligar": "天蝎", - "steelix": "大钢蛇", - "snubbull": "布鲁", - "granbull": "布鲁皇", - "qwilfish": "千针鱼", - "scizor": "巨钳螳螂", - "shuckle": "壶壶", - "heracross": "赫拉克罗斯", - "sneasel": "狃拉", - "teddiursa": "熊宝宝", - "ursaring": "圈圈熊", - "slugma": "熔岩虫", - "magcargo": "熔岩蜗牛", - "swinub": "小山猪", - "piloswine": "长毛猪", - "corsola": "太阳珊瑚", - "remoraid": "铁炮鱼", - "octillery": "章鱼桶", - "delibird": "信使鸟", - "mantine": "巨翅飞鱼", - "skarmory": "盔甲鸟", - "houndour": "戴鲁比", - "houndoom": "黑鲁加", - "kingdra": "刺龙王", - "phanpy": "小小象", - "donphan": "顿甲", - "porygon2": "多边兽2型", - "stantler": "惊角鹿", - "smeargle": "图图犬", - "tyrogue": "无畏小子", - "hitmontop": "战舞郎", - "smoochum": "迷唇娃", - "elekid": "电击怪", - "magby": "鸭嘴宝宝", - "miltank": "大奶罐", - "blissey": "幸福蛋", - "raikou": "雷公", - "entei": "炎帝", - "suicune": "水君", - "larvitar": "幼基拉斯", - "pupitar": "沙基拉斯", - "tyranitar": "班基拉斯", - "lugia": "洛奇亚", - "ho_oh": "凤王", - "celebi": "时拉比", - "treecko": "木守宫", - "grovyle": "森林蜥蜴", - "sceptile": "蜥蜴王", - "torchic": "火稚鸡", - "combusken": "力壮鸡", - "blaziken": "火焰鸡", - "mudkip": "水跃鱼", - "marshtomp": "沼跃鱼", - "swampert": "巨沼怪", - "poochyena": "土狼犬", - "mightyena": "大狼犬", - "zigzagoon": "蛇纹熊", - "linoone": "直冲熊", - "wurmple": "刺尾虫", - "silcoon": "甲壳茧", - "beautifly": "狩猎凤蝶", - "cascoon": "盾甲茧", - "dustox": "毒粉蛾", - "lotad": "莲叶童子", - "lombre": "莲帽小童", - "ludicolo": "乐天河童", - "seedot": "橡实果", - "nuzleaf": "长鼻叶", - "shiftry": "狡猾天狗", - "taillow": "傲骨燕", - "swellow": "大王燕", - "wingull": "长翅鸥", - "pelipper": "大嘴鸥", - "ralts": "拉鲁拉丝", - "kirlia": "奇鲁莉安", - "gardevoir": "沙奈朵", - "surskit": "溜溜糖球", - "masquerain": "雨翅蛾", - "shroomish": "蘑蘑菇", - "breloom": "斗笠菇", - "slakoth": "懒人獭", - "vigoroth": "过动猿", - "slaking": "请假王", - "nincada": "土居忍士", - "ninjask": "铁面忍者", - "shedinja": "脱壳忍者", - "whismur": "咕妞妞", - "loudred": "吼爆弹", - "exploud": "爆音怪", - "makuhita": "幕下力士", - "hariyama": "铁掌力士", - "azurill": "露力丽", - "nosepass": "朝北鼻", - "skitty": "向尾喵", - "delcatty": "优雅猫", - "sableye": "勾魂眼", - "mawile": "大嘴娃", - "aron": "可可多拉", - "lairon": "可多拉", - "aggron": "波士可多拉", - "meditite": "玛沙那", - "medicham": "恰雷姆", - "electrike": "落雷兽", - "manectric": "雷电兽", - "plusle": "正电拍拍", - "minun": "负电拍拍", - "volbeat": "电萤虫", - "illumise": "甜甜萤", - "roselia": "毒蔷薇", - "gulpin": "溶食兽", - "swalot": "吞食兽", - "carvanha": "利牙鱼", - "sharpedo": "巨牙鲨", - "wailmer": "吼吼鲸", - "wailord": "吼鲸王", - "numel": "呆火驼", - "camerupt": "喷火驼", - "torkoal": "煤炭龟", - "spoink": "跳跳猪", - "grumpig": "噗噗猪", - "spinda": "晃晃斑", - "trapinch": "大颚蚁", - "vibrava": "超音波幼虫", - "flygon": "沙漠蜻蜓", - "cacnea": "刺球仙人掌", - "cacturne": "梦歌仙人掌", - "swablu": "青绵鸟", - "altaria": "七夕青鸟", - "zangoose": "猫鼬斩", - "seviper": "饭匙蛇", - "lunatone": "月石", - "solrock": "太阳岩", - "barboach": "泥泥鳅", - "whiscash": "鲶鱼王", - "corphish": "龙虾小兵", - "crawdaunt": "铁螯龙虾", - "baltoy": "天秤偶", - "claydol": "念力土偶", - "lileep": "触手百合", - "cradily": "摇篮百合", - "anorith": "太古羽虫", - "armaldo": "太古盔甲", - "feebas": "丑丑鱼", - "milotic": "美纳斯", - "castform": "飘浮泡泡", - "kecleon": "变隐龙", - "shuppet": "怨影娃娃", - "banette": "诅咒娃娃", - "duskull": "夜巡灵", - "dusclops": "彷徨夜灵", - "tropius": "热带龙", - "chimecho": "风铃铃", - "absol": "阿勃梭鲁", - "wynaut": "小果然", - "snorunt": "雪童子", - "glalie": "冰鬼护", - "spheal": "海豹球", - "sealeo": "海魔狮", - "walrein": "帝牙海狮", - "clamperl": "珍珠贝", - "huntail": "猎斑鱼", - "gorebyss": "樱花鱼", - "relicanth": "古空棘鱼", - "luvdisc": "爱心鱼", - "bagon": "宝贝龙", - "shelgon": "甲壳龙", - "salamence": "暴飞龙", - "beldum": "铁哑铃", - "metang": "金属怪", - "metagross": "巨金怪", - "regirock": "雷吉洛克", - "regice": "雷吉艾斯", - "registeel": "雷吉斯奇鲁", - "latias": "拉帝亚斯", - "latios": "拉帝欧斯", - "kyogre": "盖欧卡", - "groudon": "固拉多", - "rayquaza": "烈空坐", - "jirachi": "基拉祈", - "deoxys": "代欧奇希斯", - "turtwig": "草苗龟", - "grotle": "树林龟", - "torterra": "土台龟", - "chimchar": "小火焰猴", - "monferno": "猛火猴", - "infernape": "烈焰猴", - "piplup": "波加曼", - "prinplup": "波皇子", - "empoleon": "帝王拿波", - "starly": "姆克儿", - "staravia": "姆克鸟", - "staraptor": "姆克鹰", - "bidoof": "大牙狸", - "bibarel": "大尾狸", - "kricketot": "圆法师", - "kricketune": "音箱蟀", - "shinx": "小猫怪", - "luxio": "勒克猫", - "luxray": "伦琴猫", - "budew": "含羞苞", - "roserade": "罗丝雷朵", - "cranidos": "头盖龙", - "rampardos": "战槌龙", - "shieldon": "盾甲龙", - "bastiodon": "护城龙", - "burmy": "结草儿", - "wormadam": "结草贵妇", - "mothim": "绅士蛾", - "combee": "三蜜蜂", - "vespiquen": "蜂女王", - "pachirisu": "帕奇利兹", - "buizel": "泳圈鼬", - "floatzel": "浮潜鼬", - "cherubi": "樱花宝", - "cherrim": "樱花儿", - "shellos": "无壳海兔", - "gastrodon": "海兔兽", - "ambipom": "双尾怪手", - "drifloon": "飘飘球", - "drifblim": "随风球", - "buneary": "卷卷耳", - "lopunny": "长耳兔", - "mismagius": "梦妖魔", - "honchkrow": "乌鸦头头", - "glameow": "魅力喵", - "purugly": "东施喵", - "chingling": "铃铛响", - "stunky": "臭鼬噗", - "skuntank": "坦克臭鼬", - "bronzor": "铜镜怪", - "bronzong": "青铜钟", - "bonsly": "盆才怪", - "mime_jr": "魔尼尼", - "happiny": "小福蛋", - "chatot": "聒噪鸟", - "spiritomb": "花岩怪", - "gible": "圆陆鲨", - "gabite": "尖牙陆鲨", - "garchomp": "烈咬陆鲨", - "munchlax": "小卡比兽", - "riolu": "利欧路", - "lucario": "路卡利欧", - "hippopotas": "沙河马", - "hippowdon": "河马兽", - "skorupi": "钳尾蝎", - "drapion": "龙王蝎", - "croagunk": "不良蛙", - "toxicroak": "毒骷蛙", - "carnivine": "尖牙笼", - "finneon": "荧光鱼", - "lumineon": "霓虹鱼", - "mantyke": "小球飞鱼", - "snover": "雪笠怪", - "abomasnow": "暴雪王", - "weavile": "玛狃拉", - "magnezone": "自爆磁怪", - "lickilicky": "大舌舔", - "rhyperior": "超甲狂犀", - "tangrowth": "巨蔓藤", - "electivire": "电击魔兽", - "magmortar": "鸭嘴炎兽", - "togekiss": "波克基斯", - "yanmega": "远古巨蜓", - "leafeon": "叶伊布", - "glaceon": "冰伊布", - "gliscor": "天蝎王", - "mamoswine": "象牙猪", - "porygon_z": "多边兽乙型", - "gallade": "艾路雷朵", - "probopass": "大朝北鼻", - "dusknoir": "黑夜魔灵", - "froslass": "雪妖女", - "rotom": "洛托姆", - "uxie": "由克希", - "mesprit": "艾姆利多", - "azelf": "亚克诺姆", - "dialga": "帝牙卢卡", - "palkia": "帕路奇亚", - "heatran": "席多蓝恩", - "regigigas": "雷吉奇卡斯", - "giratina": "骑拉帝纳", - "cresselia": "克雷色利亚", - "phione": "霏欧纳", - "manaphy": "玛纳霏", - "darkrai": "达克莱伊", - "shaymin": "谢米", - "arceus": "阿尔宙斯", - "victini": "比克提尼", - "snivy": "藤藤蛇", - "servine": "青藤蛇", - "serperior": "君主蛇", - "tepig": "暖暖猪", - "pignite": "炒炒猪", - "emboar": "炎武王", - "oshawott": "水水獭", - "dewott": "双刃丸", - "samurott": "大剑鬼", - "patrat": "探探鼠", - "watchog": "步哨鼠", - "lillipup": "小约克", - "herdier": "哈约克", - "stoutland": "长毛狗", - "purrloin": "扒手猫", - "liepard": "酷豹", - "pansage": "花椰猴", - "simisage": "花椰猿", - "pansear": "爆香猴", - "simisear": "爆香猿", - "panpour": "冷水猴", - "simipour": "冷水猿", - "munna": "食梦梦", - "musharna": "梦梦蚀", - "pidove": "豆豆鸽", - "tranquill": "咕咕鸽", - "unfezant": "高傲雉鸡", - "blitzle": "斑斑马", - "zebstrika": "雷电斑马", - "roggenrola": "石丸子", - "boldore": "地幔岩", - "gigalith": "庞岩怪", - "woobat": "滚滚蝙蝠", - "swoobat": "心蝙蝠", - "drilbur": "螺钉地鼠", - "excadrill": "龙头地鼠", - "audino": "差不多娃娃", - "timburr": "搬运小匠", - "gurdurr": "铁骨土人", - "conkeldurr": "修建老匠", - "tympole": "圆蝌蚪", - "palpitoad": "蓝蟾蜍", - "seismitoad": "蟾蜍王", - "throh": "投摔鬼", - "sawk": "打击鬼", - "sewaddle": "虫宝包", - "swadloon": "宝包茧", - "leavanny": "保姆虫", - "venipede": "百足蜈蚣", - "whirlipede": "车轮球", - "scolipede": "蜈蚣王", - "cottonee": "木棉球", - "whimsicott": "风妖精", - "petilil": "百合根娃娃", - "lilligant": "裙儿小姐", - "basculin": "野蛮鲈鱼", - "sandile": "黑眼鳄", - "krokorok": "混混鳄", - "krookodile": "流氓鳄", - "darumaka": "火红不倒翁", - "darmanitan": "达摩狒狒", - "maractus": "沙铃仙人掌", - "dwebble": "石居蟹", - "crustle": "岩殿居蟹", - "scraggy": "滑滑小子", - "scrafty": "头巾混混", - "sigilyph": "象征鸟", - "yamask": "哭哭面具", - "cofagrigus": "迭失棺", - "tirtouga": "原盖海龟", - "carracosta": "肋骨海龟", - "archen": "始祖小鸟", - "archeops": "始祖大鸟", - "trubbish": "破破袋", - "garbodor": "灰尘山", - "zorua": "索罗亚", - "zoroark": "索罗亚克", - "minccino": "泡沫栗鼠", - "cinccino": "奇诺栗鼠", - "gothita": "哥德宝宝", - "gothorita": "哥德小童", - "gothitelle": "哥德小姐", - "solosis": "单卵细胞球", - "duosion": "双卵细胞球", - "reuniclus": "人造细胞卵", - "ducklett": "鸭宝宝", - "swanna": "舞天鹅", - "vanillite": "迷你冰", - "vanillish": "多多冰", - "vanilluxe": "双倍多多冰", - "deerling": "四季鹿", - "sawsbuck": "萌芽鹿", - "emolga": "电飞鼠", - "karrablast": "盖盖虫", - "escavalier": "骑士蜗牛", - "foongus": "哎呀球菇", - "amoonguss": "败露球菇", - "frillish": "轻飘飘", - "jellicent": "胖嘟嘟", - "alomomola": "保姆曼波", - "joltik": "电电虫", - "galvantula": "电蜘蛛", - "ferroseed": "种子铁球", - "ferrothorn": "坚果哑铃", - "klink": "齿轮儿", - "klang": "齿轮组", - "klinklang": "齿轮怪", - "tynamo": "麻麻小鱼", - "eelektrik": "麻麻鳗", - "eelektross": "麻麻鳗鱼王", - "elgyem": "小灰怪", - "beheeyem": "大宇怪", - "litwick": "烛光灵", - "lampent": "灯火幽灵", - "chandelure": "水晶灯火灵", - "axew": "牙牙", - "fraxure": "斧牙龙", - "haxorus": "双斧战龙", - "cubchoo": "喷嚏熊", - "beartic": "冻原熊", - "cryogonal": "几何雪花", - "shelmet": "小嘴蜗", - "accelgor": "敏捷虫", - "stunfisk": "泥巴鱼", - "mienfoo": "功夫鼬", - "mienshao": "师父鼬", - "druddigon": "赤面龙", - "golett": "泥偶小人", - "golurk": "泥偶巨人", - "pawniard": "驹刀小兵", - "bisharp": "劈斩司令", - "bouffalant": "爆炸头水牛", - "rufflet": "毛头小鹰", - "braviary": "勇士雄鹰", - "vullaby": "秃鹰丫头", - "mandibuzz": "秃鹰娜", - "heatmor": "熔蚁兽", - "durant": "铁蚁", - "deino": "单首龙", - "zweilous": "双首暴龙", - "hydreigon": "三首恶龙", - "larvesta": "燃烧虫", - "volcarona": "火神蛾", - "cobalion": "勾帕路翁", - "terrakion": "代拉基翁", - "virizion": "毕力吉翁", - "tornadus": "龙卷云", - "thundurus": "雷电云", - "reshiram": "莱希拉姆", - "zekrom": "捷克罗姆", - "landorus": "土地云", - "kyurem": "酋雷姆", - "keldeo": "凯路迪欧", - "meloetta": "美洛耶塔", - "genesect": "盖诺赛克特", - "chespin": "哈力栗", - "quilladin": "胖胖哈力", - "chesnaught": "布里卡隆", - "fennekin": "火狐狸", - "braixen": "长尾火狐", - "delphox": "妖火红狐", - "froakie": "呱呱泡蛙", - "frogadier": "呱头蛙", - "greninja": "甲贺忍蛙", - "bunnelby": "掘掘兔", - "diggersby": "掘地兔", - "fletchling": "小箭雀", - "fletchinder": "火箭雀", - "talonflame": "烈箭鹰", - "scatterbug": "粉蝶虫", - "spewpa": "粉蝶蛹", - "vivillon": "彩粉蝶", - "litleo": "小狮狮", - "pyroar": "火炎狮", - "flabebe": "花蓓蓓", - "floette": "花叶蒂", - "florges": "花洁夫人", - "skiddo": "坐骑小羊", - "gogoat": "坐骑山羊", - "pancham": "顽皮熊猫", - "pangoro": "霸道熊猫", - "furfrou": "多丽米亚", - "espurr": "妙喵", - "meowstic": "超能妙喵", - "honedge": "独剑鞘", - "doublade": "双剑鞘", - "aegislash": "坚盾剑怪", - "spritzee": "粉香香", - "aromatisse": "芳香精", - "swirlix": "绵绵泡芙", - "slurpuff": "胖甜妮", - "inkay": "好啦鱿", - "malamar": "乌贼王", - "binacle": "龟脚脚", - "barbaracle": "龟足巨铠", - "skrelp": "垃垃藻", - "dragalge": "毒藻龙", - "clauncher": "铁臂枪虾", - "clawitzer": "钢炮臂虾", - "helioptile": "伞电蜥", - "heliolisk": "光电伞蜥", - "tyrunt": "宝宝暴龙", - "tyrantrum": "怪颚龙", - "amaura": "冰雪龙", - "aurorus": "冰雪巨龙", - "sylveon": "仙子伊布", - "hawlucha": "摔角鹰人", - "dedenne": "咚咚鼠", - "carbink": "小碎钻", - "goomy": "黏黏宝", - "sliggoo": "黏美儿", - "goodra": "黏美龙", - "klefki": "钥圈儿", - "phantump": "小木灵", - "trevenant": "朽木妖", - "pumpkaboo": "南瓜精", - "gourgeist": "南瓜怪人", - "bergmite": "冰宝", - "avalugg": "冰岩怪", - "noibat": "嗡蝠", - "noivern": "音波龙", - "xerneas": "哲尔尼亚斯", - "yveltal": "伊裴尔塔尔", - "zygarde": "基格尔德", - "diancie": "蒂安希", - "hoopa": "胡帕", - "volcanion": "波尔凯尼恩", - "rowlet": "木木枭", - "dartrix": "投羽枭", - "decidueye": "狙射树枭", - "litten": "火斑喵", - "torracat": "炎热喵", - "incineroar": "炽焰咆哮虎", - "popplio": "球球海狮", - "brionne": "花漾海狮", - "primarina": "西狮海壬", - "pikipek": "小笃儿", - "trumbeak": "喇叭啄鸟", - "toucannon": "铳嘴大鸟", - "yungoos": "猫鼬少", - "gumshoos": "猫鼬探长", - "grubbin": "强颚鸡母虫", - "charjabug": "虫电宝", - "vikavolt": "锹农炮虫", - "crabrawler": "好胜蟹", - "crabominable": "好胜毛蟹", - "oricorio": "花舞鸟", - "cutiefly": "萌虻", - "ribombee": "蝶结萌虻", - "rockruff": "岩狗狗", - "lycanroc": "鬃岩狼人", - "wishiwashi": "弱丁鱼", - "mareanie": "好坏星", - "toxapex": "超坏星", - "mudbray": "泥驴仔", - "mudsdale": "重泥挽马", - "dewpider": "滴蛛", - "araquanid": "滴蛛霸", - "fomantis": "伪螳草", - "lurantis": "兰螳花", - "morelull": "睡睡菇", - "shiinotic": "灯罩夜菇", - "salandit": "夜盗火蜥", - "salazzle": "焰后蜥", - "stufful": "童偶熊", - "bewear": "穿着熊", - "bounsweet": "甜竹竹", - "steenee": "甜舞妮", - "tsareena": "甜冷美后", - "comfey": "花疗环环", - "oranguru": "智挥猩", - "passimian": "投掷猴", - "wimpod": "胆小虫", - "golisopod": "具甲武者", - "sandygast": "沙丘娃", - "palossand": "噬沙堡爷", - "pyukumuku": "拳海参", - "type_null": "属性:空", - "silvally": "银伴战兽", - "minior": "小陨星", - "komala": "树枕尾熊", - "turtonator": "爆焰龟兽", - "togedemaru": "托戈德玛尔", - "mimikyu": "谜拟丘", - "bruxish": "磨牙彩皮鱼", - "drampa": "老翁龙", - "dhelmise": "破破舵轮", - "jangmo_o": "心鳞宝", - "hakamo_o": "鳞甲龙", - "kommo_o": "杖尾鳞甲龙", - "tapu_koko": "卡璞・鸣鸣", - "tapu_lele": "卡璞・蝶蝶", - "tapu_bulu": "卡璞・哞哞", - "tapu_fini": "卡璞・鳍鳍", - "cosmog": "科斯莫古", - "cosmoem": "科斯莫姆", - "solgaleo": "索尔迦雷欧", - "lunala": "露奈雅拉", - "nihilego": "虚吾伊德", - "buzzwole": "爆肌蚊", - "pheromosa": "费洛美螂", - "xurkitree": "电束木", - "celesteela": "铁火辉夜", - "kartana": "纸御剑", - "guzzlord": "恶食大王", - "necrozma": "奈克洛兹玛", - "magearna": "玛机雅娜", - "marshadow": "玛夏多", - "poipole": "毒贝比", - "naganadel": "四颚针龙", - "stakataka": "垒磊石", - "blacephalon": "砰头小丑", - "zeraora": "捷拉奥拉", - "meltan": "美录坦", - "melmetal": "美录梅塔", - "grookey": "敲音猴", - "thwackey": "啪咚猴", - "rillaboom": "轰擂金刚猩", - "scorbunny": "炎兔儿", - "raboot": "腾蹴小将", - "cinderace": "闪焰王牌", - "sobble": "泪眼蜥", - "drizzile": "变涩蜥", - "inteleon": "千面避役", - "skwovet": "贪心栗鼠", - "greedent": "藏饱栗鼠", - "rookidee": "稚山雀", - "corvisquire": "蓝鸦", - "corviknight": "钢铠鸦", - "blipbug": "索侦虫", - "dottler": "天罩虫", - "orbeetle": "以欧路普", - "nickit": "狡小狐", - "thievul": "猾大狐", - "gossifleur": "幼棉棉", - "eldegoss": "白蓬蓬", - "wooloo": "毛辫羊", - "dubwool": "毛毛角羊", - "chewtle": "咬咬龟", - "drednaw": "暴噬龟", - "yamper": "来电汪", - "boltund": "逐电犬", - "rolycoly": "小炭仔", - "carkol": "大炭车", - "coalossal": "巨炭山", - "applin": "啃果虫", - "flapple": "苹裹龙", - "appletun": "丰蜜龙", - "silicobra": "沙包蛇", - "sandaconda": "沙螺蟒", - "cramorant": "古月鸟", - "arrokuda": "刺梭鱼", - "barraskewda": "戽斗尖梭", - "toxel": "电音婴", - "toxtricity": "颤弦蝾螈", - "sizzlipede": "烧火蚣", - "centiskorch": "焚焰蚣", - "clobbopus": "拳拳蛸", - "grapploct": "八爪武师", - "sinistea": "来悲茶", - "polteageist": "怖思壶", - "hatenna": "迷布莉姆", - "hattrem": "提布莉姆", - "hatterene": "布莉姆温", - "impidimp": "捣蛋小妖", - "morgrem": "诈唬魔", - "grimmsnarl": "长毛巨魔", - "obstagoon": "堵拦熊", - "perrserker": "喵头目", - "cursola": "魔灵珊瑚", - "sirfetchd": "葱游兵", - "mr_rime": "踏冰人偶", - "runerigus": "迭失板", - "milcery": "小仙奶", - "alcremie": "霜奶仙", - "falinks": "列阵兵", - "pincurchin": "啪嚓海胆", - "snom": "雪吞虫", - "frosmoth": "雪绒蛾", - "stonjourner": "巨石丁", - "eiscue": "冰砌鹅", - "indeedee": "爱管侍", - "morpeko": "莫鲁贝可", - "cufant": "铜象", - "copperajah": "大王铜象", - "dracozolt": "雷鸟龙", - "arctozolt": "雷鸟海兽", - "dracovish": "鳃鱼龙", - "arctovish": "鳃鱼海兽", - "duraludon": "铝钢龙", - "dreepy": "多龙梅西亚", - "drakloak": "多龙奇", - "dragapult": "多龙巴鲁托", - "zacian": "苍响", - "zamazenta": "藏玛然特", - "eternatus": "无极汰那", - "kubfu": "熊徒弟", - "urshifu": "武道熊师", - "zarude": "萨戮德", - "regieleki": "雷吉艾勒奇", - "regidrago": "雷吉铎拉戈", - "glastrier": "雪暴马", - "spectrier": "灵幽马", - "calyrex": "蕾冠王", - "wyrdeer": "诡角鹿", - "kleavor": "劈斧螳螂", - "ursaluna": "月月熊", - "basculegion": "幽尾玄鱼", - "sneasler": "大狃拉", - "overqwil": "万针鱼", - "enamorus": "眷恋云", - "sprigatito": "新叶喵", - "floragato": "蒂蕾喵", - "meowscarada": "魔幻假面喵", - "fuecoco": "呆火鳄", - "crocalor": "炙烫鳄", - "skeledirge": "骨纹巨声鳄", - "quaxly": "润水鸭", - "quaxwell": "涌跃鸭", - "quaquaval": "狂欢浪舞鸭", - "lechonk": "爱吃豚", - "oinkologne": "飘香豚", - "tarountula": "团珠蛛", - "spidops": "操陷蛛", - "nymble": "豆蟋蟀", - "lokix": "烈腿蝗", - "pawmi": "布拨", - "pawmo": "布土拨", - "pawmot": "巴布土拨", - "tandemaus": "一对鼠", - "maushold": "一家鼠", - "fidough": "狗仔包", - "dachsbun": "麻花犬", - "smoliv": "迷你芙", - "dolliv": "奥利纽", - "arboliva": "奥利瓦", - "squawkabilly": "怒鹦哥", - "nacli": "盐石宝", - "naclstack": "盐石垒", - "garganacl": "盐石巨灵", - "charcadet": "炭小侍", - "armarouge": "红莲铠骑", - "ceruledge": "苍炎刃鬼", - "tadbulb": "光蚪仔", - "bellibolt": "电肚蛙", - "wattrel": "电海燕", - "kilowattrel": "大电海燕", - "maschiff": "偶叫獒", - "mabosstiff": "獒教父", - "shroodle": "滋汁鼹", - "grafaiai": "涂标客", - "bramblin": "纳噬草", - "brambleghast": "怖纳噬草", - "toedscool": "原野水母", - "toedscruel": "陆地水母", - "klawf": "毛崖蟹", - "capsakid": "热辣娃", - "scovillain": "狠辣椒", - "rellor": "虫滚泥", - "rabsca": "虫甲圣", - "flittle": "飘飘雏", - "espathra": "超能艳鸵", - "tinkatink": "小锻匠", - "tinkatuff": "巧锻匠", - "tinkaton": "巨锻匠", - "wiglett": "海地鼠", - "wugtrio": "三海地鼠", - "bombirdier": "下石鸟", - "finizen": "波普海豚", - "palafin": "海豚侠", - "varoom": "噗隆隆", - "revavroom": "普隆隆姆", - "cyclizar": "摩托蜥", - "orthworm": "拖拖蚓", - "glimmet": "晶光芽", - "glimmora": "晶光花", - "greavard": "墓仔狗", - "houndstone": "墓扬犬", - "flamigo": "缠红鹤", - "cetoddle": "走鲸", - "cetitan": "浩大鲸", - "veluza": "轻身鳕", - "dondozo": "吃吼霸", - "tatsugiri": "米立龙", - "annihilape": "弃世猴", - "clodsire": "土王", - "farigiraf": "奇麒麟", - "dudunsparce": "土龙节节", - "kingambit": "仆刀将军", - "great_tusk": "雄伟牙", - "scream_tail": "吼叫尾", - "brute_bonnet": "猛恶菇", - "flutter_mane": "振翼发", - "slither_wing": "爬地翅", - "sandy_shocks": "沙铁皮", - "iron_treads": "铁辙迹", - "iron_bundle": "铁包袱", - "iron_hands": "铁臂膀", - "iron_jugulis": "铁脖颈", - "iron_moth": "铁毒蛾", - "iron_thorns": "铁荆棘", - "frigibax": "凉脊龙", - "arctibax": "冻脊龙", - "baxcalibur": "戟脊龙", - "gimmighoul": "索财灵", - "gholdengo": "赛富豪", - "wo_chien": "古简蜗", - "chien_pao": "古剑豹", - "ting_lu": "古鼎鹿", - "chi_yu": "古玉鱼", - "roaring_moon": "轰鸣月", - "iron_valiant": "铁武者", - "koraidon": "故勒顿", - "miraidon": "密勒顿", - "walking_wake": "波荡水", - "iron_leaves": "铁斑叶", - "dipplin": "裹蜜虫", - "poltchageist": "斯魔茶", - "sinistcha": "来悲粗茶", - "okidogi": "够赞狗", - "munkidori": "愿增猿", - "fezandipiti": "吉雉鸡", - "ogerpon": "厄诡椪", - "archaludon": "铝钢桥龙", - "hydrapple": "蜜集大蛇", - "gouging_fire": "破空焰", - "raging_bolt": "猛雷鼓", - "iron_boulder": "铁磐岩", - "iron_crown": "铁头壳", - "terapagos": "太乐巴戈斯", - "pecharunt": "桃歹郎", - "alola_rattata": "小拉达", - "alola_raticate": "拉达", - "alola_raichu": "雷丘", - "alola_sandshrew": "穿山鼠", - "alola_sandslash": "穿山王", - "alola_vulpix": "六尾", - "alola_ninetales": "九尾", - "alola_diglett": "地鼠", - "alola_dugtrio": "三地鼠", - "alola_meowth": "喵喵", - "alola_persian": "猫老大", - "alola_geodude": "小拳石", - "alola_graveler": "隆隆石", - "alola_golem": "隆隆岩", - "alola_grimer": "臭泥", - "alola_muk": "臭臭泥", - "alola_exeggutor": "椰蛋树", - "alola_marowak": "嘎啦嘎啦", - "eternal_floette": "花叶蒂", - "galar_meowth": "喵喵", - "galar_ponyta": "小火马", - "galar_rapidash": "烈焰马", - "galar_slowpoke": "呆呆兽", - "galar_slowbro": "呆壳兽", - "galar_farfetchd": "大葱鸭", - "galar_weezing": "双弹瓦斯", - "galar_mr_mime": "魔墙人偶", - "galar_articuno": "急冻鸟", - "galar_zapdos": "闪电鸟", - "galar_moltres": "火焰鸟", - "galar_slowking": "呆呆王", - "galar_corsola": "太阳珊瑚", - "galar_zigzagoon": "蛇纹熊", - "galar_linoone": "直冲熊", - "galar_darumaka": "火红不倒翁", - "galar_darmanitan": "达摩狒狒", - "galar_yamask": "哭哭面具", - "galar_stunfisk": "泥巴鱼", - "hisui_growlithe": "卡蒂狗", - "hisui_arcanine": "风速狗", - "hisui_voltorb": "霹雳电球", - "hisui_electrode": "顽皮雷弹", - "hisui_typhlosion": "火暴兽", - "hisui_qwilfish": "千针鱼", - "hisui_sneasel": "狃拉", - "hisui_samurott": "大剑鬼", - "hisui_lilligant": "裙儿小姐", - "hisui_zorua": "索罗亚", - "hisui_zoroark": "索罗亚克", - "hisui_braviary": "勇士雄鹰", - "hisui_sliggoo": "黏美儿", - "hisui_goodra": "黏美龙", - "hisui_avalugg": "冰岩怪", - "hisui_decidueye": "狙射树枭", - "paldea_tauros": "肯泰罗", - "paldea_wooper": "乌波", - "bloodmoon_ursaluna": "月月熊" -} \ No newline at end of file diff --git a/src/locales/zh_CN/run-history.json b/src/locales/zh_CN/run-history.json deleted file mode 100644 index 08f430364fc..00000000000 --- a/src/locales/zh_CN/run-history.json +++ /dev/null @@ -1,37 +0,0 @@ -{ - "victory": "胜利!", - "defeatedWild": "被打败", - "defeatedTrainer": "被打败", - "defeatedTrainerDouble": "被组合打败", - "defeatedRival": "被劲敌打败", - "defeated": "被打败", - "defeatedWild_female": "被打败", - "defeatedTrainer_female": "被打败", - "defeatedTrainerDouble_female": "被组合打败", - "defeatedRival_female": "被劲敌打败", - "defeated_female": "被打败", - "luck": "幸运", - "score": "分数", - "mode": "模式", - "challengeRules": "规则", - "challengeMonoGen1": "一代", - "challengeMonoGen2": "二代", - "challengeMonoGen3": "三代", - "challengeMonoGen4": "四代", - "challengeMonoGen5": "五代", - "challengeMonoGen6": "六代", - "challengeMonoGen7": "七代", - "challengeMonoGen8": "八代", - "challengeMonoGen9": "九代", - "playerItems": "玩家道具", - "personalBest": "个人最佳!", - "SPDshortened": "速率", - "runInfo": "游戏记录", - "money": "金钱", - "runLength": "游戏时长", - "viewHeldItems": "持有道具", - "hallofFameText": "欢迎来到名人堂!", - "hallofFameText_female": "欢迎来到名人堂!", - "viewHallOfFame": "浏览名人堂!", - "viewEndingSplash": "浏览结算画面" -} \ No newline at end of file diff --git a/src/locales/zh_CN/save-slot-select-ui-handler.json b/src/locales/zh_CN/save-slot-select-ui-handler.json deleted file mode 100644 index a6c5348a39c..00000000000 --- a/src/locales/zh_CN/save-slot-select-ui-handler.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "overwriteData": "要覆盖该槽位的存档吗?", - "loading": "正在加载中...", - "wave": "层数", - "lv": "Lv", - "empty": "空" -} \ No newline at end of file diff --git a/src/locales/zh_CN/settings.json b/src/locales/zh_CN/settings.json deleted file mode 100644 index dd001213b9e..00000000000 --- a/src/locales/zh_CN/settings.json +++ /dev/null @@ -1,106 +0,0 @@ -{ - "boy": "男孩", - "girl": "女孩", - "general": "常规", - "display": "显示", - "audio": "音频", - "gamepad": "手柄", - "keyboard": "键盘", - "gameSpeed": "游戏速度", - "hpBarSpeed": "血条速度", - "expGainsSpeed": "经验值获取动画速度", - "expPartyDisplay": "显示队伍经验", - "skipSeenDialogues": "跳过已读对话", - "battleStyle": "对战模式", - "enableRetries": "允许重试", - "hideIvs": "禁用个体值探测器信息", - "tutorials": "教程", - "touchControls": "触摸操作", - "vibrations": "手柄震动", - "normal": "普通", - "fast": "快", - "faster": "更快", - "skip": "跳过", - "levelUpNotifications": "升级提示", - "on": "启用", - "off": "禁用", - "switch": "切换", - "set": "固定", - "auto": "自动", - "disabled": "禁用", - "language": "语言", - "change": "选择", - "uiTheme": "界面风格", - "default": "默认", - "legacy": "经典", - "windowType": "窗口类型", - "moneyFormat": "金钱格式", - "damageNumbers": "伤害数字", - "simple": "简单", - "fancy": "华丽", - "abbreviated": "缩略", - "moveAnimations": "招式动画", - "showStatsOnLevelUp": "升级时显示能力值", - "candyUpgradeNotification": "糖果升级提示", - "passivesOnly": "仅被动", - "candyUpgradeDisplay": "糖果升级显示", - "icon": "图标", - "animation": "动画", - "moveInfo": "招式信息", - "showMovesetFlyout": "显示招式池弹窗", - "showArenaFlyout": "显示战场弹窗", - "showTimeOfDayWidget": "显示时间指示器", - "timeOfDayAnimation": "时间指示器动画", - "bounce": "弹跳", - "timeOfDay_back": "不弹", - "spriteSet": "宝可梦动画", - "consistent": "默认", - "mixedAnimated": "全部动画", - "fusionPaletteSwaps": "融合色调切换", - "playerGender": "玩家性别", - "typeHints": "属性提示", - "masterVolume": "主音量", - "bgmVolume": "音乐", - "fieldVolume": "场景音量", - "seVolume": "音效", - "musicPreference": "音乐偏好", - "mixed": "全曲混合", - "gamepadPleasePlug": "请链接手柄或按任意键", - "delete": "删除", - "keyboardPleasePress": "请点击键盘上的对应按键", - "reset": "重置", - "requireReload": "需要重新加载", - "action": "操作", - "back": "返回", - "pressToBind": "按下以绑定", - "pressButton": "请按键……", - "buttonUp": "上", - "buttonDown": "下", - "buttonLeft": "左", - "buttonRight": "右", - "buttonAction": "确认", - "buttonMenu": "菜单", - "buttonSubmit": "提交", - "buttonCancel": "取消", - "buttonStats": "状态", - "buttonCycleForm": "切换形态", - "buttonCycleShiny": "切换闪光", - "buttonCycleGender": "切换性别", - "buttonCycleAbility": "切换特性", - "buttonCycleNature": "切换性格", - "buttonCycleVariant": "切换变种", - "buttonSpeedUp": "加速", - "buttonSlowDown": "减速", - "alt": " (备用)", - "mute": "静音", - "controller": "控制器", - "gamepadSupport": "手柄支持", - "showBgmBar": "显示音乐名称", - "moveTouchControls": "移动触摸控制", - "shopOverlayOpacity": "商店显示不透明度", - "shopCursorTarget": "商店指针位置", - "rewards": "道具", - "reroll": "刷新", - "shop": "购买", - "checkTeam": "检查队伍" -} diff --git a/src/locales/zh_CN/splash-messages.json b/src/locales/zh_CN/splash-messages.json deleted file mode 100644 index 4d2d208edfd..00000000000 --- a/src/locales/zh_CN/splash-messages.json +++ /dev/null @@ -1,36 +0,0 @@ -{ - "battlesWon": "场胜利!", - "joinTheDiscord": "加入Discord!", - "infiniteLevels": "等级无限!", - "everythingStacks": "道具全部叠加!", - "optionalSaveScumming": "可用SL大法!", - "biomes": "35种地区!", - "openSource": "开源!", - "playWithSpeed": "请五倍速游玩!", - "liveBugTesting": "随时修复BUG!", - "heavyInfluence": "深受雨中冒险2影响!", - "pokemonRiskAndPokemonRain": "雨中宝可梦冒险!", - "nowWithMoreSalt": "增加33%的盐!", - "infiniteFusionAtHome": "无限融合家庭版!", - "brokenEggMoves": "超模的蛋招式!", - "magnificent": "华丽!", - "mubstitute": "替身!", - "thatsCrazy": "疯狂!", - "oranceJuice": "橙汁!", - "questionableBalancing": "游戏平衡性存疑!", - "coolShaders": "炫酷的配色!", - "aiFree": "不含AI!", - "suddenDifficultySpikes": "难度会突然飙升!", - "basedOnAnUnfinishedFlashGame": "基于未完成的Flash游戏!", - "moreAddictiveThanIntended": "比你想象的更上瘾!", - "mostlyConsistentSeeds": "随机数种子基本固定!", - "achievementPointsDontDoAnything": "成就点数没有任何用处!", - "youDoNotStartAtLevel": "你不能第一关就改个2000级!", - "dontTalkAboutTheManaphyEggIncident": "别再提玛纳霏蛋事件了!", - "alsoTryPokengine": "也玩玩看Pokéngine!", - "alsoTryEmeraldRogue": "也玩玩看绿宝石肉鸽!", - "alsoTryRadicalRed": "也玩玩看激进红!", - "eeveeExpo": "伊布博览会!", - "ynoproject": "Yume Nikki 页游项目!", - "breedersInSpace": "饲养员也能上太空?" -} diff --git a/src/locales/zh_CN/starter-select-ui-handler.json b/src/locales/zh_CN/starter-select-ui-handler.json deleted file mode 100644 index 4851468ab7c..00000000000 --- a/src/locales/zh_CN/starter-select-ui-handler.json +++ /dev/null @@ -1,45 +0,0 @@ -{ - "confirmStartTeam": "使用这些宝可梦开始游戏吗?", - "confirmExit": "确定要退出吗?", - "invalidParty": "初始队伍不可用!", - "gen1": "I", - "gen2": "II", - "gen3": "III", - "gen4": "IV", - "gen5": "V", - "gen6": "VI", - "gen7": "VII", - "gen8": "VIII", - "gen9": "IX", - "growthRate": "成长速度:", - "ability": "特性:", - "passive": "被动:", - "nature": "性格:", - "eggMoves": "蛋招式", - "addToParty": "加入队伍", - "removeFromParty": "移出队伍", - "toggleIVs": "显示个体", - "manageMoves": "管理招式", - "manageNature": "管理性格", - "addToFavorites": "添加到最爱", - "removeFromFavorites": "移出最爱", - "useCandies": "使用糖果", - "selectNature": "选择性格", - "selectMoveSwapOut": "选择要替换的招式。", - "selectMoveSwapWith": "选择要替换成的招式", - "sameSpeciesEgg": "兑换一颗蛋", - "unlockPassive": "解锁被动", - "reduceCost": "降低花费", - "cycleShiny": ": 闪光", - "cycleForm": ": 形态", - "cycleGender": ": 性别", - "cycleAbility": ": 特性", - "cycleNature": ": 性格", - "cycleVariant": ": 变种", - "goFilter": ": 转到筛选", - "enablePassive": "启用被动", - "disablePassive": "禁用被动", - "locked": "未解锁", - "disabled": "已禁用", - "uncaught": "未捕获" -} diff --git a/src/locales/zh_CN/status-effect.json b/src/locales/zh_CN/status-effect.json deleted file mode 100644 index f7fb9092107..00000000000 --- a/src/locales/zh_CN/status-effect.json +++ /dev/null @@ -1,65 +0,0 @@ -{ - "none": { - "name": "无", - "description": "", - "obtain": "", - "obtainSource": "", - "activation": "", - "overlap": "", - "heal": "" - }, - "poison": { - "name": "中毒", - "description": "中毒", - "obtain": "{{pokemonNameWithAffix}}中毒了!", - "obtainSource": "{{pokemonNameWithAffix}}因{{sourceText}}中毒了!", - "activation": "{{pokemonNameWithAffix}}受到了毒的伤害!", - "overlap": "{{pokemonNameWithAffix}}已经中毒了!", - "heal": "{{pokemonNameWithAffix}}中的毒彻底清除了!" - }, - "toxic": { - "name": "剧毒", - "description": "中毒", - "obtain": "{{pokemonNameWithAffix}}中了剧毒!", - "obtainSource": "{{pokemonNameWithAffix}}因{{sourceText}}中了剧毒!", - "activation": "{{pokemonNameWithAffix}}受到了毒的伤害!", - "overlap": "{{pokemonNameWithAffix}}已经中毒了!", - "heal": "{{pokemonNameWithAffix}}中的毒彻底清除了!" - }, - "paralysis": { - "name": "麻痹", - "description": "麻痹", - "obtain": "{{pokemonNameWithAffix}}麻痹了,很难使出招式!", - "obtainSource": "{{pokemonNameWithAffix}}被{{sourceText}}麻痹了,很难使出招式!", - "activation": "{{pokemonNameWithAffix}}因身体麻痹而无法行动!", - "overlap": "{{pokemonNameWithAffix}}已经麻痹了!", - "heal": "{{pokemonNameWithAffix}}的麻痹治愈了!" - }, - "sleep": { - "name": "睡眠", - "description": "睡眠", - "obtain": "{{pokemonNameWithAffix}}睡着了!", - "obtainSource": "{{pokemonNameWithAffix}}因{{sourceText}}睡着了!", - "activation": "{{pokemonNameWithAffix}}正在呼呼大睡。", - "overlap": "{{pokemonNameWithAffix}}已经睡着了!", - "heal": "{{pokemonNameWithAffix}}醒了!" - }, - "freeze": { - "name": "冰冻", - "description": "冰冻", - "obtain": "{{pokemonNameWithAffix}}冻住了!", - "obtainSource": "{{pokemonNameWithAffix}}因{{sourceText}}冻住了!", - "activation": "{{pokemonNameWithAffix}}因冻住了而无法行动!", - "overlap": "{{pokemonNameWithAffix}}已经冻住了!", - "heal": "{{pokemonNameWithAffix}}治愈了冰冻状态!" - }, - "burn": { - "name": "灼伤", - "description": "灼伤", - "obtain": "{{pokemonNameWithAffix}}被灼伤了!", - "obtainSource": "{{pokemonNameWithAffix}}因{{sourceText}}被灼伤了!", - "activation": "{{pokemonNameWithAffix}}受到了灼伤的伤害!", - "overlap": "{{pokemonNameWithAffix}}已经被灼伤了!", - "heal": "{{pokemonNameWithAffix}}的灼伤治愈了!" - } -} \ No newline at end of file diff --git a/src/locales/zh_CN/terrain.json b/src/locales/zh_CN/terrain.json deleted file mode 100644 index b56a9ce9ee8..00000000000 --- a/src/locales/zh_CN/terrain.json +++ /dev/null @@ -1,16 +0,0 @@ -{ - "misty": "薄雾", - "mistyStartMessage": "脚下雾气缭绕!", - "mistyClearMessage": "脚下的雾气消失不见了!", - "mistyBlockMessage": "{{pokemonNameWithAffix}}正受到薄雾场地的保护!", - "electric": "电气", - "electricStartMessage": "脚下电光飞闪!", - "electricClearMessage": "脚下的电光消失不见了!", - "grassy": "青草", - "grassyStartMessage": "脚下青草如茵!", - "grassyClearMessage": "脚下的青草消失不见了!", - "psychic": "精神", - "psychicStartMessage": "脚下传来了奇妙的感觉!", - "psychicClearMessage": "脚下的奇妙感觉消失了!", - "defaultBlockMessage": "{{pokemonNameWithAffix}}正受到{{terrainName}}的的保护!" -} \ No newline at end of file diff --git a/src/locales/zh_CN/trainer-classes.json b/src/locales/zh_CN/trainer-classes.json deleted file mode 100644 index 3a50acf5c01..00000000000 --- a/src/locales/zh_CN/trainer-classes.json +++ /dev/null @@ -1,130 +0,0 @@ -{ - "ace_trainer": "精英训练家", - "ace_trainer_female": "精英训练家", - "ace_duo": "精英组合", - "artist": "艺术家", - "artist_female": "艺术家", - "backers": "啦啦队", - "backpacker": "背包客", - "backpacker_female": "背包客", - "backpackers": "背包客组合", - "baker": "面包师", - "battle_girl": "对战少女", - "beauty": "大姐姐", - "beginners": "新人训练家组合", - "biker": "飙车族", - "black_belt": "空手道王", - "breeder": "宝可梦培育家", - "breeder_female": "宝可梦培育家", - "breeders": "宝可梦培育家组合", - "clerk": "商务人士", - "clerk_female": "职场OL", - "colleagues": "商务伙伴", - "crush_kin": "格斗姐弟", - "cyclist": "自行车手", - "cyclist_female": "自行车手", - "cyclists": "自行车手组合", - "dancer": "舞者", - "dancer_female": "舞者", - "depot_agent": "铁路员工", - "doctor": "医生", - "doctor_female": "医生", - "firebreather": "吹火人", - "fisherman": "垂钓者", - "fisherman_female": "垂钓者", - "gentleman": "绅士", - "guitarist": "吉他手", - "guitarist_female": "吉他手", - "harlequin": "滑稽演员", - "hiker": "登山男", - "hooligans": "坏组合", - "hoopster": "篮球选手", - "infielder": "棒球选手", - "janitor": "清洁员", - "lady": "千金小姐", - "lass": "迷你裙", - "linebacker": "美式橄榄球选手", - "maid": "女仆", - "madame": "女士", - "medical_team": "医疗团队", - "musician": "音乐家", - "hex_maniac": "灵异迷", - "nurse": "护士", - "nursery_aide": "幼儿园老师", - "officer": "警察", - "parasol_lady": "阳伞姐姐", - "pilot": "飞行员", - "pokéfan": "发烧友俱乐部", - "pokéfan_female": "发烧友俱乐部", - "pokéfan_family": "同好夫妇", - "preschooler": "幼儿园小朋友", - "preschooler_female": "幼儿园小朋友", - "preschoolers": "幼儿园小朋友组合", - "psychic": "超能力者", - "psychic_female": "超能力者", - "psychics": "超能力者组合", - "pokémon_ranger": "宝可梦巡护员", - "pokémon_ranger_female": "宝可梦巡护员", - "pokémon_rangers": "宝可梦巡护员组合", - "ranger": "巡护员", - "restaurant_staff": "服务生组合", - "rich": "富豪", - "rich_female": "富豪太太", - "rich_boy": "富家少爷", - "rich_couple": "富豪夫妇", - "rich_kid": "富家小孩", - "rich_kid_female": "富家小孩", - "rich_kids": "富家小孩组合", - "roughneck": "光头男", - "sailor": "水手", - "scientist": "研究员", - "scientist_female": "研究员", - "scientists": "研究员组合", - "smasher": "网球选手", - "snow_worker": "雪地工人", - "snow_worker_female": "雪地工人", - "striker": "足球选手", - "school_kid": "补习班学生", - "school_kid_female": "补习班学生", - "school_kids": "补习班学生组合", - "swimmer": "泳裤小伙子", - "swimmer_female": "比基尼大姐姐", - "swimmers": "泳装情侣", - "twins": "双胞胎", - "veteran": "资深训练家", - "veteran_female": "资深训练家", - "veteran_duo": "资深组合", - "waiter": "服务生", - "waitress": "女服务生", - "worker": "工人", - "worker_female": "工人", - "workers": "工人组合", - "youngster": "短裤小子", - "rocket_grunt": "火箭队手下", - "rocket_grunt_female": "火箭队手下", - "rocket_grunts": "火箭队手下们", - "magma_grunt": "熔岩队手下", - "magma_grunt_female": "熔岩队手下", - "magma_grunts": "熔岩队手下们", - "aqua_grunt": "海洋队手下", - "aqua_grunt_female": "海洋队手下", - "aqua_grunts": "海洋队手下们", - "galactic_grunt": "银河队手下", - "galactic_grunt_female": "银河队手下", - "galactic_grunts": "银河队手下们", - "plasma_grunt": "等离子队手下", - "plasma_grunt_female": "等离子队手下", - "plasma_grunts": "等离子队手下们", - "flare_grunt": "闪焰队手下", - "flare_grunt_female": "闪焰队手下", - "flare_grunts": "闪焰队手下们", - "aether_grunt": "以太基金会职员", - "aether_grunt_female": "以太基金会职员", - "aether_grunts": "以太基金会职员", - "skull_grunt": "骷髅队手下", - "skull_grunt_female": "骷髅队手下", - "skull_grunts": "骷髅队手下", - "macro_grunt": "马洛科蒙训练师", - "macro_grunt_female": "马洛科蒙训练师", - "macro_grunts": "马洛科蒙训练师" -} diff --git a/src/locales/zh_CN/trainer-names.json b/src/locales/zh_CN/trainer-names.json deleted file mode 100644 index 9e03a514ff7..00000000000 --- a/src/locales/zh_CN/trainer-names.json +++ /dev/null @@ -1,164 +0,0 @@ -{ - "brock": "小刚", - "misty": "小霞", - "lt_surge": "马志士", - "erika": "莉佳", - "janine": "阿杏", - "sabrina": "娜姿", - "blaine": "夏伯", - "giovanni": "坂木", - "falkner": "阿速", - "bugsy": "阿笔", - "whitney": "小茜", - "morty": "松叶", - "chuck": "阿四", - "jasmine": "阿蜜", - "pryce": "柳伯", - "clair": "小椿", - "roxanne": "杜娟", - "brawly": "藤树", - "wattson": "铁旋", - "flannery": "亚莎", - "norman": "千里", - "winona": "娜琪", - "tate": "小枫", - "liza": "小南", - "juan": "亚当", - "roark": "瓢太", - "gardenia": "菜种", - "maylene": "阿李", - "crasher_wake": "吉宪", - "fantina": "梅丽莎", - "byron": "东瓜", - "faba": "扎奥博", - "plumeria": "布尔美丽", - "oleana": "奥莉薇", - - "candice": "小菘", - "volkner": "电次", - "cilan": "天桐", - "chili": "伯特", - "cress": "寇恩", - "cheren": "黑连", - "lenora": "芦荟", - "roxie": "霍米加", - "burgh": "亚堤", - "elesa": "小菊儿", - "clay": "菊老大", - "skyla": "风露", - "brycen": "哈奇库", - "drayden": "夏卡", - "marlon": "西子伊", - "viola": "紫罗兰", - "grant": "查克洛", - "korrina": "可尔妮", - "ramos": "福爷", - "clemont": "希特隆", - "valerie": "玛绣", - "olympia": "葛吉花", - "wulfric": "得抚", - "milo": "亚洛", - "nessa": "露璃娜", - "kabu": "卡芜", - "bea": "彩豆", - "allister": "欧尼奥", - "opal": "波普菈", - "bede": "彼特", - "gordie": "玛瓜", - "melony": "美蓉", - "piers": "聂梓", - "marnie": "玛俐", - "raihan": "奇巴纳", - "katy": "阿枫", - "brassius": "寇沙", - "iono": "奇树", - "kofu": "海岱", - "larry": "青木", - "ryme": "莱姆", - "tulip": "莉普", - "grusha": "古鲁夏", - "lorelei": "科拿", - "bruno": "希巴", - "agatha": "菊子", - "lance": "阿渡", - "will": "一树", - "koga": "阿桔", - "karen": "梨花", - "sidney": "花月", - "phoebe": "芙蓉", - "glacia": "波妮", - "drake": "源治", - "aaron": "阿柳", - "bertha": "菊野", - "flint": "大叶", - "lucian": "悟松", - "shauntal": "婉龙", - "marshal": "连武", - "grimsley": "越橘", - "caitlin": "嘉德丽雅", - "malva": "帕琦拉", - "siebold": "志米", - "wikstrom": "雁铠", - "drasna": "朵拉塞娜", - "hala": "哈拉", - "molayne": "马睿因", - "olivia": "丽姿", - "acerola": "阿塞萝拉", - "kahili": "卡希丽", - "rika": "辛俐", - "poppy": "波琵", - "hassel": "八朔", - "crispin": "赤松", - "amarys": "纳莉", - "lacey": "紫竽", - "drayton": "杜若", - "blue": "青绿", - "red": "赤红", - "steven": "大吾", - "wallace": "米可利", - "cynthia": "竹兰", - "alder": "阿戴克", - "iris": "艾莉丝", - "diantha": "卡露妮", - "hau": "哈乌", - "leon": "丹帝", - "geeta": "也慈", - "nemona": "妮莫", - "kieran": "乌栗", - "rival": "芬恩", - "rival_female": "艾薇", - "archer": "阿波罗", - "ariana": "雅典娜", - "proton": "兰斯", - "petrel": "拉姆达", - "tabitha": "火村", - "courtney": "火雁", - "shelly": "阿泉", - "matt": "阿潮", - "mars": "伙星", - "jupiter": "碎星", - "saturn": "镇星", - "zinzolin": "维奥", - "rood": "罗德", - "xerosic": "库瑟洛斯奇", - "bryony": "芭菈", - "maxie": "赤焰松", - "archie": "水梧桐", - "cyrus": "赤日", - "ghetsis": "魁奇思", - "lysandre": "弗拉达利", - "lusamine": "露莎米奈", - "guzma": "古兹马", - "rose": "洛兹", - - "blue_red_double": "青绿 & 赤红", - "red_blue_double": "赤红 & 青绿", - "tate_liza_double": "小枫 & 小南", - "liza_tate_double": "小南 & 小枫", - "steven_wallace_double": "大吾 & 米可利", - "wallace_steven_double": "米可利 & 大吾", - "alder_iris_double": "阿戴克 & 艾莉丝", - "iris_alder_double": "艾莉丝 & 阿戴克", - "marnie_piers_double": "玛俐 & 聂梓", - "piers_marnie_double": "聂梓 & 玛俐" -} diff --git a/src/locales/zh_CN/trainer-titles.json b/src/locales/zh_CN/trainer-titles.json deleted file mode 100644 index 07654ec8fc3..00000000000 --- a/src/locales/zh_CN/trainer-titles.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "elite_four": "四天王", - "elite_four_female": "四天王", - "gym_leader": "道馆馆主", - "gym_leader_female": "道馆馆主", - "gym_leader_double": "道馆馆主搭档", - "champion": "冠军", - "champion_female": "冠军", - "champion_double": "冠军搭档", - "rival": "劲敌", - "professor": "博士", - "frontier_brain": "开拓头脑", - "rocket_boss": "火箭队老大", - "magma_boss": "熔岩队老大", - "aqua_boss": "海洋队老大", - "galactic_boss": "银河队老大", - "plasma_boss": "等离子队老大", - "flare_boss": "闪焰队老大", - "aether_boss": "以太基金会理事长", - "skull_boss": "骷髅队老大", - "macro_boss": "马洛科蒙总裁", - - "rocket_admin": "火箭队干部", - "rocket_admin_female": "火箭队干部", - "magma_admin": "熔岩队干部", - "magma_admin_female": "熔岩队干部", - "aqua_admin": "海洋队干部", - "aqua_admin_female": "海洋队干部", - "galactic_commander": "银河队干部", - "galactic_commander_female": "银河队干部", - "plasma_sage": "等离子队贤人", - "plasma_admin": "等离子队干部", - "flare_admin": "闪焰队干部", - "flare_admin_female": "闪焰队干部", - "aether_admin": "以太基金会干部", - "skull_admin": "骷髅队干部", - "macro_admin": "马洛科蒙干部" -} diff --git a/src/locales/zh_CN/tutorial.json b/src/locales/zh_CN/tutorial.json deleted file mode 100644 index 2f76b2ba2b5..00000000000 --- a/src/locales/zh_CN/tutorial.json +++ /dev/null @@ -1,10 +0,0 @@ -{ - "intro": "欢迎来到PokéRogue!这是一款以战斗为核心的\n融合了roguelite元素的宝可梦同人游戏。\n$本游戏未进行商业化,我们没有\nPokémon或Pokémon使用的版\n$权资产的所有权。\n$游戏仍在开发中,但已可完整游玩。如需报\n告错误,请通过 Discord 社区。\n$如果游戏运行缓慢,请确保在浏览器设置中\n打开了“硬件加速”。", - "accessMenu": "在等待输入时,按 M 或 Escape 键可访\n问菜单。菜单包含设置和各种功能。", - "menu": "在此菜单中,您可以访问设置。\n$在设置中,您可以更改游戏速度、窗口样式\n和其他选项。\n$这里还有各种其他功能,请务必全部查看!", - "starterSelect": "在此页面中,您可以通过按Z或空格键选择\n您的初始宝可梦。这些是您最初的队伍成员。\n$每个初始宝可梦都有一个费用值。您的队伍\n最多可以拥有6名成员,只要总费用不超过10。\n$您还可以根据您捕获或孵化的变种选择性别\n、特性和形态。\n$一个物种个体值是您捕获或孵化的所有宝可\n梦中最好的,所以尽量获得更多同种宝可梦!", - "pokerus": "每天随机3个可选的初始宝可梦会有紫色边\n框。\n$如果您看到您拥有的初始宝可梦带有紫色边\n框,请尝试将其添加到您的队伍中。请务必\n$查看其概况!", - "statChange": "只要您的宝可梦没有被召回,属性变化就会\n在战斗中持续存在。\n$在训练家战斗之前和进入新的宝可梦群落之\n前,您的宝可梦会被召回。\n$您还可以通过按住C或Shift键来查看\n场上宝可梦的能力变化。", - "selectItem": "每次战斗后,您都可以从多个随机物品中\n选择其中一个。\n$这些物品包括消耗品、宝可梦携带物品和永\n久被动道具。\n$大多数非消耗品的效果会以各种方式叠加。\n$某些物品只有在可以使用时才会出现,例如\n进化物品。\n$您还可以使用转移选项在宝可梦之间转移携\n带物品。\n$一旦您获得了携带物品,转移选项就会出现\n在右下角。\n$您可以用金钱购买消耗品,并且随着您游戏\n的深入,将会有更多种类的消耗品可供选择。\n$请务必在选择随机物品之前购买这些消耗品\n因为一旦您选择,游戏就会进入下一场战斗。", - "eggGacha": "在此页面中,您可以使用您的兑换券兑换宝\n可梦蛋。\n$蛋需要孵化,并且在每场战斗后都会减少孵\n化周期。稀有蛋需要更长时间才能孵化。\n$孵化的宝可梦不会被添加到您的队伍中,它\n们将被添加到您的初始宝可梦中。\n$从蛋中孵化的宝可梦通常比野生宝可梦具有\n更好的个体值。\n$有些宝可梦只能从蛋中获得。\n$有 3 种不同的扭蛋机可供选择,每种扭蛋机\n都有不同的奖励,请选择最适合您的!" -} \ No newline at end of file diff --git a/src/locales/zh_CN/voucher.json b/src/locales/zh_CN/voucher.json deleted file mode 100644 index c913affda7d..00000000000 --- a/src/locales/zh_CN/voucher.json +++ /dev/null @@ -1,9 +0,0 @@ -{ - "vouchers": "兑换券", - "eggVoucher": "初级扭蛋券", - "eggVoucherPlus": "中级扭蛋券", - "eggVoucherPremium": "高级扭蛋券", - "eggVoucherGold": "黄金扭蛋券", - "locked": "锁定", - "defeatTrainer": "你打败了{{trainerName}}" -} \ No newline at end of file diff --git a/src/locales/zh_CN/weather.json b/src/locales/zh_CN/weather.json deleted file mode 100644 index 65f677044ac..00000000000 --- a/src/locales/zh_CN/weather.json +++ /dev/null @@ -1,31 +0,0 @@ -{ - "sunnyStartMessage": "日照变强了!", - "sunnyLapseMessage": "日照很强。", - "sunnyClearMessage": "日照复原了。", - "rainStartMessage": "开始下雨了!", - "rainLapseMessage": "雨继续下。", - "rainClearMessage": "雨停了。", - "sandstormStartMessage": "开始刮沙暴了!", - "sandstormLapseMessage": "沙暴肆虐。", - "sandstormClearMessage": "沙暴停止了!", - "sandstormDamageMessage": "沙暴袭击了{{pokemonNameWithAffix}}!", - "hailStartMessage": "开始下冰雹了!", - "hailLapseMessage": "冰雹继续肆虐。", - "hailClearMessage": "冰雹不再下了。", - "hailDamageMessage": "冰雹袭击了{{pokemonNameWithAffix}}!", - "snowStartMessage": "开始下雪了!", - "snowLapseMessage": "雪继续下。", - "snowClearMessage": "雪停了。", - "fogStartMessage": "起雾了!", - "fogLapseMessage": "雾很浓。", - "fogClearMessage": "雾散了。", - "heavyRainStartMessage": "开始下起了暴雨!", - "heavyRainLapseMessage": "暴雨势头不减。", - "heavyRainClearMessage": "暴雨停了。", - "harshSunStartMessage": "日照变得非常强了!", - "harshSunLapseMessage": "强日照势头不减。", - "harshSunClearMessage": "日照复原了。", - "strongWindsStartMessage": "吹起了神秘的乱流!", - "strongWindsLapseMessage": "神秘的乱流势头不减。", - "strongWindsClearMessage": "神秘的乱流停止了。" -} \ No newline at end of file diff --git a/src/locales/zh_TW/ability-trigger.json b/src/locales/zh_TW/ability-trigger.json deleted file mode 100644 index c4b53fa5126..00000000000 --- a/src/locales/zh_TW/ability-trigger.json +++ /dev/null @@ -1,64 +0,0 @@ -{ - "blockRecoilDamage": "{{pokemonName}} 的 {{abilityName}}\n抵消了反作用力!", - "badDreams": "{{pokemonName}} 被折磨着!", - "costar": "{{pokemonName}} 複製了 {{allyName}} 的\n能力變化!", - "iceFaceAvoidedDamage": "{{pokemonNameWithAffix}} 因爲 {{abilityName}}\n避免了傷害!", - "perishBody": "因爲{{pokemonName}}的{{abilityName}}\n雙方將在3回合後滅亡!", - "poisonHeal": "{{pokemonName}}因{{abilityName}}\n回複了少許HP!", - "trace": "{{pokemonName}}複制了{{targetName}}的\n{{abilityName}}!", - "windPowerCharged": "受{{moveName}}的影響,{{pokemonName}}提升了能力!", - "quickDraw":"因爲速擊效果發動,\n{{pokemonName}}比平常出招更快了!", - "disguiseAvoidedDamage": "{{pokemonNameWithAffix}}的畫皮脫落了!", - "blockItemTheft": "{{pokemonNameWithAffix}}的{{abilityName}}\n阻止了對方奪取道具!", - "typeImmunityHeal": "{{pokemonNameWithAffix}}因{{abilityName}}\n回複了少許HP!", - "nonSuperEffectiveImmunity": "{{pokemonNameWithAffix}}因{{abilityName}}\n避免了傷害!", - "fullHpResistType": "{{pokemonNameWithAffix}}讓甲殼綻放光輝,扭曲了屬性相剋關係!", - "moveImmunity": "對{{pokemonNameWithAffix}}沒有效果!", - "reverseDrain": "{{pokemonNameWithAffix}}\n吸到了汙泥漿!", - "postDefendTypeChange": "{{pokemonNameWithAffix}}因{{abilityName}}\n變成了{{typeName}}屬性!", - "postDefendContactDamage": "{{pokemonNameWithAffix}}的{{abilityName}}\n使對方受到了傷害!", - "postDefendAbilitySwap": "{{pokemonNameWithAffix}}\n互換了各自的特性!", - "postDefendAbilityGive": "因爲{{pokemonNameWithAffix}}\n對方的特性變成了{{abilityName}}!", - "postDefendMoveDisable": "封住了{{pokemonNameWithAffix}}的\n{{moveName}}!", - "pokemonTypeChange": "{{pokemonNameWithAffix}}\n變成了{{moveType}}屬性!", - "postAttackStealHeldItem": "{{pokemonNameWithAffix}}從{{defenderName}}那裏\n奪取了{{stolenItemType}}!", - "postDefendStealHeldItem": "{{pokemonNameWithAffix}}從{{attackerName}}那裏\n奪取了{{stolenItemType}}!", - "copyFaintedAllyAbility": "繼承了{{pokemonNameWithAffix}}的\n{{abilityName}}!", - "intimidateImmunity": "{{pokemonNameWithAffix}}因{{abilityName}}沒有受到威嚇!", - "postSummonAllyHeal": "{{pokemonNameWithAffix}}喝光了\n{{pokemonName}}泡的茶!", - "postSummonClearAllyStats": "{{pokemonNameWithAffix}}的\n能力變化消失了!", - "postSummonTransform": "{{pokemonNameWithAffix}}\n變身成了{{targetName}}!", - "protectStat": "因{{pokemonNameWithAffix}}的{{abilityName}}\n{{statName}}不會降低!", - "statusEffectImmunityWithName": "{{pokemonNameWithAffix}}因{{abilityName}}\n{{statusEffectName}}沒有效果!", - "statusEffectImmunity": "{{pokemonNameWithAffix}}因{{abilityName}}\n異常狀態沒有效果!", - "battlerTagImmunity": "{{pokemonNameWithAffix}}因{{abilityName}}\n而不會{{battlerTagName}}!", - "forewarn": "{{pokemonNameWithAffix}}讀取了\n{{moveName}}!", - "frisk": "{{pokemonNameWithAffix}}察覺到了\n{{opponentName}}的{{opponentAbilityName}}!", - "postWeatherLapseHeal": "{{pokemonNameWithAffix}}因{{abilityName}}\n回複了少許HP!", - "postWeatherLapseDamage": "{{pokemonNameWithAffix}}\n因{{abilityName}}而受到了傷害!", - "postTurnLootCreateEatenBerry": "{{pokemonNameWithAffix}}\n收獲了{{berryName}}!", - "postTurnHeal": "{{pokemonNameWithAffix}}因{{abilityName}}\n回複了少許HP!", - "fetchBall": "{{pokemonNameWithAffix}}\n撿回了{{pokeballName}}!", - "healFromBerryUse": "{{pokemonNameWithAffix}}因{{abilityName}}\n回複了HP!", - "arenaTrap": "因{{pokemonNameWithAffix}}的{{abilityName}}\n而無法進行替換!", - "postBattleLoot": "{{pokemonNameWithAffix}}撿到了\n{{itemName}}!", - "postFaintContactDamage": "{{pokemonNameWithAffix}}的{{abilityName}}\n使對方受到了傷害!", - "postFaintHpDamage": "{{pokemonNameWithAffix}}的{{abilityName}}\n使對方受到了傷害!", - "postSummonPressure": "從{{pokemonNameWithAffix}}的身上\n感到了一種壓迫感!", - "weatherEffectDisappeared": "天氣的影響消失了!", - "postSummonMoldBreaker": "{{pokemonNameWithAffix}}\n打破了常規!", - "postSummonAnticipation": "{{pokemonNameWithAffix}}\n發抖了!", - "postSummonTurboblaze": "{{pokemonNameWithAffix}}\n正在釋放熾焰氣場!", - "postSummonTeravolt": "{{pokemonNameWithAffix}}\n正在釋放濺射氣場!", - "postSummonDarkAura": "{{pokemonNameWithAffix}}\n正在釋放暗黑氣場!", - "postSummonFairyAura": "{{pokemonNameWithAffix}}\n正在釋放妖精氣場!", - "postSummonAuraBreak": "{{pokemonNameWithAffix}}壓制了所有氣場!", - "postSummonNeutralizingGas": "周圍充滿了\n{{pokemonNameWithAffix}}的化學變化氣體!", - "postSummonAsOneGlastrier": "{{pokemonNameWithAffix}}\n同時擁有了兩種特性!", - "postSummonAsOneSpectrier": "{{pokemonNameWithAffix}}\n同時擁有了兩種特性!", - "postSummonVesselOfRuin": "{{pokemonNameWithAffix}}的災禍之鼎\n令周圍的寶可夢的{{statName}}減弱了!", - "postSummonSwordOfRuin": "{{pokemonNameWithAffix}}的災禍之劍\n令周圍的寶可夢的{{statName}}減弱了!", - "postSummonTabletsOfRuin": "{{pokemonNameWithAffix}}的災禍之簡\n令周圍的寶可夢的{{statName}}減弱了!", - "postSummonBeadsOfRuin": "{{pokemonNameWithAffix}}的災禍之玉\n令周圍的寶可夢的{{statName}}減弱了!", - "preventBerryUse": "{{pokemonNameWithAffix}}因太緊張\n而無法食用樹果!" -} diff --git a/src/locales/zh_TW/ability.json b/src/locales/zh_TW/ability.json deleted file mode 100644 index 21206c5362a..00000000000 --- a/src/locales/zh_TW/ability.json +++ /dev/null @@ -1,1242 +0,0 @@ -{ - "stench": { - "name": "惡臭", - "description": "發出臭氣,在攻擊的時候,\n有時會使對手畏縮。" - }, - "drizzle": { - "name": "降雨", - "description": "出場時,會將天氣變為下雨\n。" - }, - "speedBoost": { - "name": "加速", - "description": "每一回合速度會變快。" - }, - "battleArmor": { - "name": "戰鬥盔甲", - "description": "被堅硬的甲殼守護著,不會\n被對手的攻擊擊中要害。" - }, - "sturdy": { - "name": "結實", - "description": "在HP全滿時受到招式攻擊\n不會被一擊打倒。一擊必殺\n的招式也沒有效果。" - }, - "damp": { - "name": "濕氣", - "description": "透過把周圍都弄溼,使誰都\n無法使用自爆等爆炸類的招\n式。" - }, - "limber": { - "name": "柔軟", - "description": "因為身體柔軟,不會變為麻\n痹狀態。" - }, - "sandVeil": { - "name": "沙隱", - "description": "在沙暴中閃避率會提高。" - }, - "static": { - "name": "靜電", - "description": "身上帶有靜電,有時會令接\n觸到的對手麻痹。" - }, - "voltAbsorb": { - "name": "蓄電", - "description": "受到電屬性的招式攻擊時,\n不會受到傷害,而是會回復。" - }, - "waterAbsorb": { - "name": "儲水", - "description": "受到水屬性的招式攻擊時,\n不會受到傷害,而是會回復。" - }, - "oblivious": { - "name": "遲鈍", - "description": "感覺遲鈍,不會陷入著迷和\n被挑釁狀態。面對威嚇也不\n會動搖。" - }, - "cloudNine": { - "name": "無關天氣", - "description": "任何天氣的影響都會消失。" - }, - "compoundEyes": { - "name": "複眼", - "description": "因為擁有複眼,會提高招式\n的命中率。" - }, - "insomnia": { - "name": "不眠", - "description": "因為有著睡不著的體質,所\n以不會陷入睡眠狀態。" - }, - "colorChange": { - "name": "變色", - "description": "自己的屬性會變為擊中自己\n的對手招式的屬性。" - }, - "immunity": { - "name": "免疫", - "description": "因為體內擁有免疫能力,不\n會變為中毒狀態。" - }, - "flashFire": { - "name": "引火", - "description": "受到火屬性的招式攻擊時,\n吸收火焰,自己使出的火屬\n性招式會變強。" - }, - "shieldDust": { - "name": "鱗粉", - "description": "被鱗粉守護著,不會受到招\n式的追加效果影響。" - }, - "ownTempo": { - "name": "我行我素", - "description": "因為我行我素,不會陷入混\n亂狀態。面對威嚇也不會動\n搖。" - }, - "suctionCups": { - "name": "吸盤", - "description": "用吸盤將自己牢牢吸附在地\n面上,讓替換寶可夢的招式\n和道具失效。" - }, - "intimidate": { - "name": "威嚇", - "description": "出場時威嚇對手,使其退縮\n,從而降低對手的攻擊。" - }, - "shadowTag": { - "name": "踩影", - "description": "踩住對手的影子使其無法逃\n走或替換。" - }, - "roughSkin": { - "name": "粗糙皮膚", - "description": "受到攻擊時,用粗糙的皮膚\n弄傷接觸到自己的對手。" - }, - "wonderGuard": { - "name": "神奇守護", - "description": "不可思議的力量,只有效果\n絕佳的招式才能擊中。" - }, - "levitate": { - "name": "飄浮", - "description": "從地面浮起,從而不會受到\n地面屬性招式的攻擊。" - }, - "effectSpore": { - "name": "孢子", - "description": "受到攻擊時,有時會把接觸\n到自己的對手變為中毒、麻\n痹或睡眠狀態。" - }, - "synchronize": { - "name": "同步", - "description": "將自己的中毒、麻痹或灼傷\n狀態傳染給對手。" - }, - "clearBody": { - "name": "恆淨之軀", - "description": "不會因對手的招式或特性而\n被降低能力。" - }, - "naturalCure": { - "name": "自然回復", - "description": "異常狀態會在離場後治癒。" - }, - "lightningRod": { - "name": "避雷針", - "description": "將電屬性的招式吸引到自己\n身上,不但不會受到傷害,\n反而會提高特攻。" - }, - "sereneGrace": { - "name": "天恩", - "description": "受到上天保佑,容易出現招式的追加效果。" - }, - "swiftSwim": { - "name": "悠遊自如", - "description": "天氣為下雨時,速度會提高。" - }, - "chlorophyll": { - "name": "葉綠素", - "description": "天氣為晴朗時,速度會提高。" - }, - "illuminate": { - "name": "發光", - "description": "透過讓周圍變亮,命中率不\n會被降低。" - }, - "trace": { - "name": "複製", - "description": "出場時,複製對手的特性,\n變為與之相同的特性。" - }, - "hugePower": { - "name": "大力士", - "description": "物理攻擊的威力會變為2倍\n。" - }, - "poisonPoint": { - "name": "毒刺", - "description": "有時會讓接觸到自己的對手\n變為中毒狀態。" - }, - "innerFocus": { - "name": "精神力", - "description": "靠著經過鍛鍊的精神,不會\n因對手的攻擊而畏縮。面對\n威嚇也不會動搖。" - }, - "magmaArmor": { - "name": "熔岩鎧甲", - "description": "將熾熱的熔岩覆蓋在身上,\n不會陷入冰凍狀態。" - }, - "waterVeil": { - "name": "水幕", - "description": "將水幕裹在身上,不會陷入\n灼傷狀態。" - }, - "magnetPull": { - "name": "磁力", - "description": "用磁力吸住鋼屬性的寶可夢\n,使其無法逃走。" - }, - "soundproof": { - "name": "隔音", - "description": "透過遮蔽聲音,不受到聲音\n招式的影響。" - }, - "rainDish": { - "name": "雨盤", - "description": "天氣為下雨時,會緩緩回復\nHP。" - }, - "sandStream": { - "name": "揚沙", - "description": "出場時,會把天氣變為沙暴。" - }, - "pressure": { - "name": "壓迫感", - "description": "給予對手壓迫感,大量減少\n其使用招式的PP。" - }, - "thickFat": { - "name": "厚脂肪", - "description": "被厚厚的脂肪保護著,能夠\n讓火屬性和冰屬性招式的傷\n害減半。" - }, - "earlyBird": { - "name": "早起", - "description": "即使陷入睡眠狀態,也能以\n2倍的速度提早醒來。" - }, - "flameBody": { - "name": "火焰之軀", - "description": "有時會讓接觸到自己的對手\n變為灼傷狀態。" - }, - "runAway": { - "name": "逃跑", - "description": "一定能從野生寶可夢那裡逃\n走。" - }, - "keenEye": { - "name": "銳利目光", - "description": "靠著銳利的目光,命中率不\n會被降低。" - }, - "hyperCutter": { - "name": "怪力鉗", - "description": "因為擁有以力量自豪的鉗子,\n不會被對手降低攻擊。" - }, - "pickup": { - "name": "撿拾", - "description": "有時會撿來對手用過的道具,\n冒險過程中也會撿到。" - }, - "truant": { - "name": "懶惰", - "description": "如果使出招式,下一回合就\n需要休息。" - }, - "hustle": { - "name": "活力", - "description": "自己的攻擊雖會變高,但命\n中率會降低。" - }, - "cuteCharm": { - "name": "迷人之軀", - "description": "有時會讓接觸到自己的對手陷\n入著迷狀態。" - }, - "plus": { - "name": "正電", - "description": "場上的夥伴之中,如果有正\n電或負電特性的寶可夢,自\n己的特攻會提高。" - }, - "minus": { - "name": "負電", - "description": "場上的夥伴之中,如果有正\n電或負電特性的寶可夢,自\n己的特攻會提高。" - }, - "forecast": { - "name": "陰晴不定", - "description": "在天氣的影響下,會變成水\n屬性、火屬性或冰屬性之中\n的一種。" - }, - "stickyHold": { - "name": "黏著", - "description": "道具會黏在具有黏性的身體\n上,不會被對手奪走。" - }, - "shedSkin": { - "name": "蛻皮", - "description": "透過蛻去身上的皮,有時會\n治癒異常狀態。" - }, - "guts": { - "name": "毅力", - "description": "陷入異常狀態時,會拿出毅\n力,攻擊會提高。" - }, - "marvelScale": { - "name": "神奇鱗片", - "description": "陷入異常狀態時,神奇鱗片\n會發生反應,防禦會提高。" - }, - "liquidOoze": { - "name": "污泥漿", - "description": "吸收了污泥漿的對手會因為\n強烈的惡臭而使得HP減少。" - }, - "overgrow": { - "name": "茂盛", - "description": "HP減少的時候,草屬性的\n招式威力會提高。" - }, - "blaze": { - "name": "猛火", - "description": "HP減少的時候,火屬性的\n招式威力會提高。" - }, - "torrent": { - "name": "激流", - "description": "HP減少的時候,水屬性的\n招式威力會提高。" - }, - "swarm": { - "name": "蟲之預感", - "description": "HP減少的時候,蟲屬性的\n招式威力會提高。" - }, - "rockHead": { - "name": "堅硬腦袋", - "description": "即使使出會受反作用力傷害\n的招式,HP也不會減少。" - }, - "drought": { - "name": "日照", - "description": "出場時,會將天氣變為晴朗。" - }, - "arenaTrap": { - "name": "沙穴", - "description": "在戰鬥中讓對手無法逃走。" - }, - "vitalSpirit": { - "name": "幹勁", - "description": "透過激發出幹勁,不會變為\n睡眠狀態。" - }, - "whiteSmoke": { - "name": "白色煙霧", - "description": "被白色煙霧保護著,不會被\n對手降低能力。" - }, - "purePower": { - "name": "瑜伽之力", - "description": "因瑜伽的力量,物理攻擊的\n威力會變為2倍。" - }, - "shellArmor": { - "name": "硬殼盔甲", - "description": "被堅硬的殼保護著,對手的\n攻擊不會擊中要害。" - }, - "airLock": { - "name": "氣閘", - "description": "所有天氣的影響都會消失。" - }, - "tangledFeet": { - "name": "蹣跚", - "description": "陷入混亂狀態時,閃避率會\n提高。" - }, - "motorDrive": { - "name": "電氣引擎", - "description": "受到電屬性的招式攻擊時,\n不但不會受到傷害,反而速\n度會提高。" - }, - "rivalry": { - "name": "鬥爭心", - "description": "面對性別相同的對手,會燃\n起鬥爭心,變得更強。面對\n性別不同的對手時則會變弱。" - }, - "steadfast": { - "name": "不屈之心", - "description": "每次畏縮時,不屈之心就會\n燃起,速度也會提高。" - }, - "snowCloak": { - "name": "雪隱", - "description": "天氣為下雪時,閃避率會提\n高。" - }, - "gluttony": { - "name": "貪吃鬼", - "description": "原本HP變得很少時才會吃\n樹果,在HP還有一半時就\n會把它吃掉。" - }, - "angerPoint": { - "name": "憤怒穴位", - "description": "要害被擊中時會大發雷霆。\n攻擊力會提高到最大。" - }, - "unburden": { - "name": "輕裝", - "description": "失去所持有的道具時,速度\n會提高。" - }, - "heatproof": { - "name": "耐熱", - "description": "靠著耐熱的體質,讓火屬性\n的招式傷害減半。" - }, - "simple": { - "name": "單純", - "description": "能力變化會變為平時的2倍。" - }, - "drySkin": { - "name": "乾燥皮膚", - "description": "下雨天氣時和受到水屬性的\n招式時,HP會回復。晴朗\n天氣時和受到火屬性的招式\n時,HP會減少。" - }, - "download": { - "name": "下載", - "description": "比較對手的防禦和特防,根\n據較低的那項能力相應地提\n高自己的攻擊或特攻。" - }, - "ironFist": { - "name": "鐵拳", - "description": "使用到拳頭的招式威力會\n提高。" - }, - "poisonHeal": { - "name": "毒療", - "description": "陷入中毒狀態時,HP不會\n減少,反而會漸漸增加。" - }, - "adaptability": { - "name": "適應力", - "description": "與自身同屬性的招式威力會\n提高。" - }, - "skillLink": { - "name": "連續攻擊", - "description": "使用連續招式時,每回都能\n以最多次數進行攻擊。" - }, - "hydration": { - "name": "濕潤之軀", - "description": "天氣為下雨時,會治癒異常\n狀態。" - }, - "solarPower": { - "name": "太陽之力", - "description": "天氣為晴朗時特攻會提高,\n但每回合HP會減少。" - }, - "quickFeet": { - "name": "飛毛腿", - "description": "陷入異常狀態時,速度會提\n高。" - }, - "normalize": { - "name": "一般皮膚", - "description": "無論是什麼屬性的招式,全\n部都會變為一般屬性。威力\n會少量提高。" - }, - "sniper": { - "name": "狙擊手", - "description": "擊中要害時,威力會進一步\n提高。" - }, - "magicGuard": { - "name": "魔法防守", - "description": "不會受到攻擊以外的傷害。" - }, - "noGuard": { - "name": "無防守", - "description": "由於無防守戰術,雙方使出\n的招式都必定會擊中。" - }, - "stall": { - "name": "慢出", - "description": "使出招式的順序必定會變為\n最後。" - }, - "technician": { - "name": "技術高手", - "description": "可讓威力低的招式提高威力\n來進行攻擊。" - }, - "leafGuard": { - "name": "葉子防守", - "description": "天氣為晴朗時,不會陷入異\n常狀態。" - }, - "klutz": { - "name": "笨拙", - "description": "無法使用持有的道具。" - }, - "moldBreaker": { - "name": "破格", - "description": "可不受特性影響,向對手使\n出招式。" - }, - "superLuck": { - "name": "超幸運", - "description": "因為非常幸運,容易擊中對\n手的要害。" - }, - "aftermath": { - "name": "引爆", - "description": "瀕死時,會對接觸到自己的\n對手造成傷害。" - }, - "anticipation": { - "name": "危險預知", - "description": "察覺對手持有的危險招式。" - }, - "forewarn": { - "name": "預知夢", - "description": "出場時,預見1個對手持有\n的招式。" - }, - "unaware": { - "name": "純樸", - "description": "可無視對手能力的變化,進\n行攻擊。" - }, - "tintedLens": { - "name": "有色眼鏡", - "description": "可將效果不好的招式以正常\n的威力使出。" - }, - "filter": { - "name": "過濾", - "description": "受到效果絕佳的攻擊時,可\n減弱其威力。" - }, - "slowStart": { - "name": "慢啓動", - "description": "在5回合內,攻擊和速度會\n減半。" - }, - "scrappy": { - "name": "膽量", - "description": "一般屬性和格鬥屬性的招式\n可擊中幽靈屬性的寶可夢。\n面對威嚇也不會動搖。" - }, - "stormDrain": { - "name": "引水", - "description": "將水屬性的招式引到自己身\n上,不但不會受到傷害,反\n而會提高特攻。" - }, - "iceBody": { - "name": "冰凍之軀", - "description": "天氣為下雪時,會漸漸回復\nHP。" - }, - "solidRock": { - "name": "堅硬岩石", - "description": "受到效果絕佳的攻擊時,可\n減弱其威力。" - }, - "snowWarning": { - "name": "降雪", - "description": "出場時,會將天氣變為下雪。" - }, - "honeyGather": { - "name": "採蜜", - "description": "戰鬥結束時,有時候會撿來甜甜蜜。\n甜甜蜜會轉換成金錢。" - }, - "frisk": { - "name": "察覺", - "description": "出場時,可以察覺對手的特\n性。" - }, - "reckless": { - "name": "捨身", - "description": "會讓自己因反作用力而受傷\n的招式威力會提高。" - }, - "multitype": { - "name": "多屬性", - "description": "自己的屬性會依持有的石板\n而改變。" - }, - "flowerGift": { - "name": "花之禮", - "description": "天氣為晴朗時,自己和同伴\n的攻擊和特防能力會提高。" - }, - "badDreams": { - "name": "夢魘", - "description": "給予陷入睡眠狀態的對手傷\n害。" - }, - "pickpocket": { - "name": "順手牽羊", - "description": "盜取接觸到自己的對手的道\n具。" - }, - "sheerForce": { - "name": "強行", - "description": "招式會失去追加效果,但可\n以用更高的威力使出招式。" - }, - "contrary": { - "name": "唱反調", - "description": "能力的變化會逆轉,原本提\n高時會降低,原本降低時會\n提高。" - }, - "unnerve": { - "name": "緊張感", - "description": "讓對手感到緊張,無法吃樹\n果。" - }, - "defiant": { - "name": "不服輸", - "description": "被對手降低能力時,攻擊會\n大幅提高。" - }, - "defeatist": { - "name": "軟弱", - "description": "HP降到一半以下時,會變\n得軟弱而使得攻擊和特攻減\n半。" - }, - "cursedBody": { - "name": "詛咒之軀", - "description": "受到攻擊時,有時會把對手\n的招式變為定身法狀態。" - }, - "healer": { - "name": "治癒之心", - "description": "有時會治癒同伴的異常狀態。" - }, - "friendGuard": { - "name": "友情防守", - "description": "可以減少我方受到的傷害。" - }, - "weakArmor": { - "name": "碎裂鎧甲", - "description": "因物理招式受到傷害時,防\n禦會降低,速度會大幅提高。" - }, - "heavyMetal": { - "name": "重金屬", - "description": "自己的重量會變為2倍。" - }, - "lightMetal": { - "name": "輕金屬", - "description": "自己的重量會減半。" - }, - "multiscale": { - "name": "多重鱗片", - "description": "HP全滿時,受到的傷害會\n變少。" - }, - "toxicBoost": { - "name": "中毒激升", - "description": "陷入中毒狀態時,物理招式\n的威力會提高。" - }, - "flareBoost": { - "name": "受熱激升", - "description": "陷入灼傷狀態時,特殊招式\n的威力會提高。" - }, - "harvest": { - "name": "收穫", - "description": "可多次採收已被使用過的樹果。" - }, - "telepathy": { - "name": "心靈感應", - "description": "讀取我方的攻擊,並閃避其\n招式傷害。" - }, - "moody": { - "name": "心情不定", - "description": "每一回合,能力中的某項會\n大幅提高,而某項會降低。" - }, - "overcoat": { - "name": "防塵", - "description": "不會受到沙暴的傷害。也不\n會受到粉末類和孢子類招式\n的影響。" - }, - "poisonTouch": { - "name": "毒手", - "description": "有時僅是接觸就能讓對手中\n毒。" - }, - "regenerator": { - "name": "再生力", - "description": "退回同行隊伍後,HP會少\n量回復。" - }, - "bigPecks": { - "name": "健壯胸肌", - "description": "不會受到降低防禦的效果影\n響。" - }, - "sandRush": { - "name": "撥沙", - "description": "天氣為沙暴時,速度會提高。" - }, - "wonderSkin": { - "name": "奇蹟皮膚", - "description": "不易受到變化類招式攻擊的\n身體。" - }, - "analytic": { - "name": "分析", - "description": "如果在最後使出招式,招式\n的威力就會變強。" - }, - "illusion": { - "name": "幻覺", - "description": "假扮成同行隊伍中的最後一\n隻寶可夢出場,迷惑對手。" - }, - "imposter": { - "name": "變身者", - "description": "變身為當前面對的寶可夢。" - }, - "infiltrator": { - "name": "穿透", - "description": "可穿透對手的屏障或替身進\n行攻擊。" - }, - "mummy": { - "name": "木乃伊", - "description": "被對手接觸到後,會將對手\n變為木乃伊。" - }, - "moxie": { - "name": "自信過度", - "description": "如果打倒對手,會充滿自信\n並提高攻擊。" - }, - "justified": { - "name": "正義之心", - "description": "受到惡屬性的招式攻擊時,\n因為正義感,攻擊會提高。" - }, - "rattled": { - "name": "膽怯", - "description": "受到惡屬性、幽靈屬性和蟲\n屬性的招式攻擊,或受到威\n嚇時,會因膽怯而使得速度\n提高。" - }, - "magicBounce": { - "name": "魔法鏡", - "description": "可不受到由對手使出的變化\n類招式所影響,並將其反彈。" - }, - "sapSipper": { - "name": "食草", - "description": "受到草屬性的招式攻擊時,\n不但不會受到傷害,反而攻\n擊會提高。" - }, - "prankster": { - "name": "惡作劇之心", - "description": "可以搶先使出變化類招式。" - }, - "sandForce": { - "name": "沙之力", - "description": "天氣為沙暴時,岩石屬性、\n地面屬性和鋼屬性招式的威\n力會提高。" - }, - "ironBarbs": { - "name": "鐵刺", - "description": "用鐵刺給予接觸到自己的對\n手傷害。" - }, - "zenMode": { - "name": "達摩模式", - "description": "HP變為一半以下時,樣子\n會改變。" - }, - "victoryStar": { - "name": "勝利之星", - "description": "自己和同伴的命中率會提高。" - }, - "turboblaze": { - "name": "渦輪火焰", - "description": "可以不受對手特性的干擾,\n向對手使出招式。" - }, - "teravolt": { - "name": "兆級電壓", - "description": "可以不受對手特性的干擾,\n向對手使出招式。" - }, - "aromaVeil": { - "name": "芳香幕", - "description": "可防住向自己和同伴發出的\n心靈攻擊。" - }, - "flowerVeil": { - "name": "花幕", - "description": "我方的草屬性寶可夢能力不\n會降低。也不會陷入異常狀\n態。" - }, - "cheekPouch": { - "name": "頰囊", - "description": "無論是哪種樹果,吃下去後\nHP都會回復。" - }, - "protean": { - "name": "變幻自如", - "description": "每次出場戰鬥時,變為與自\n己使出的招式相同的屬性1\n次。" - }, - "furCoat": { - "name": "毛皮大衣", - "description": "對手的物理招式造成的傷害\n會減半。" - }, - "magician": { - "name": "魔術師", - "description": "奪走被自己的招式擊中的對\n手的道具。" - }, - "bulletproof": { - "name": "防彈", - "description": "可防住對手的球和彈類的招\n式。" - }, - "competitive": { - "name": "好勝", - "description": "被對手降低能力時,特攻會\n大幅提高。" - }, - "strongJaw": { - "name": "強壯之顎", - "description": "顎部強壯,會提高啃咬類招\n式的威力。" - }, - "refrigerate": { - "name": "冰凍皮膚", - "description": "一般屬性的招式會變為冰屬\n性。威力會少量提高。" - }, - "sweetVeil": { - "name": "甜幕", - "description": "自己和我方的寶可夢不會陷\n入睡眠狀態。" - }, - "stanceChange": { - "name": "戰鬥切換", - "description": "若使出攻擊招式,會變為刀\n劍形態,若使出招式「王者\n盾牌」,會變為盾牌形態。" - }, - "galeWings": { - "name": "疾風之翼", - "description": "HP全滿時,可以搶先在對\n手之前使出飛行屬性的招式。" - }, - "megaLauncher": { - "name": "超級發射器", - "description": "波動和波導類招式的威力會\n提高。" - }, - "grassPelt": { - "name": "草之毛皮", - "description": "在青草場地時,防禦會提高。" - }, - "symbiosis": { - "name": "共生", - "description": "同伴使用道具時,會把自己\n持有的道具傳遞給同伴。" - }, - "toughClaws": { - "name": "硬爪", - "description": "接觸到對手的招式威力會提\n高。" - }, - "pixilate": { - "name": "妖精皮膚", - "description": "一般屬性的招式會變為妖精\n屬性。威力會少量提高。" - }, - "gooey": { - "name": "黏滑", - "description": "對手用攻擊接觸到自己時,\n降低此對手的速度。" - }, - "aerilate": { - "name": "飛行皮膚", - "description": "一般屬性的招式會變為飛行\n屬性。威力會少量提高。" - }, - "parentalBond": { - "name": "親子愛", - "description": "親子倆可合計攻擊2次。" - }, - "darkAura": { - "name": "暗黑氣場", - "description": "全體的惡屬性招式變強。" - }, - "fairyAura": { - "name": "妖精氣場", - "description": "全體的妖精屬性招式變強。" - }, - "auraBreak": { - "name": "氣場破壞", - "description": "讓氣場的效果逆轉,並降低\n威力。" - }, - "primordialSea": { - "name": "始源之海", - "description": "變為讓火屬性攻擊失效的天\n氣。" - }, - "desolateLand": { - "name": "終結之地", - "description": "變為讓水屬性攻擊失效的天\n氣。" - }, - "deltaStream": { - "name": "德爾塔氣流", - "description": "變為令飛行屬性的弱點消失\n的天氣。" - }, - "stamina": { - "name": "持久力", - "description": "受到攻擊時,防禦會提高。" - }, - "wimpOut": { - "name": "躍躍欲逃", - "description": "HP變為一半時,會慌慌張\n張逃走,退回同行隊伍中。" - }, - "emergencyExit": { - "name": "危險迴避", - "description": "HP減到一半時,為了避開\n危險,會退回到同行隊伍中。" - }, - "waterCompaction": { - "name": "遇水凝固", - "description": "受到水屬性的招式攻擊時,\n防禦會大幅提高。" - }, - "merciless": { - "name": "不仁不義", - "description": "攻擊中毒狀態的對手時,\n必定會擊中要害。" - }, - "shieldsDown": { - "name": "界限盾殼", - "description": "HP變為一半時,殼會壞掉,\n變得更有攻擊性。" - }, - "stakeout": { - "name": "蹲守", - "description": "可以向替換出場的對手以2\n倍的傷害進行攻擊。" - }, - "waterBubble": { - "name": "水泡", - "description": "降低自己受到的火屬性招式\n的威力,不會灼傷。" - }, - "steelworker": { - "name": "鋼能力者", - "description": "鋼屬性的招式威力會提高。" - }, - "berserk": { - "name": "怒火沖天", - "description": "HP因對手的攻擊降到一半\n時,特攻會提高。" - }, - "slushRush": { - "name": "撥雪", - "description": "天氣為下雪時,速度會提高。" - }, - "longReach": { - "name": "遠隔", - "description": "可以不接觸對手就使出所有\n的招式。" - }, - "liquidVoice": { - "name": "溼潤之聲", - "description": "所有的聲音招式都變為水屬\n性。" - }, - "triage": { - "name": "先行治療", - "description": "可以搶先使出回復招式。" - }, - "galvanize": { - "name": "電氣皮膚", - "description": "一般屬性的招式會變為電屬\n性。威力會少量提高。" - }, - "surgeSurfer": { - "name": "衝浪之尾", - "description": "電氣場地時,速度會變為2\n倍。" - }, - "schooling": { - "name": "魚羣", - "description": "HP多的時候會聚起來變強。\nHP剩餘量變少時,群體\n會分崩離析。" - }, - "disguise": { - "name": "畫皮", - "description": "用畫皮覆蓋住身體,可防住\n1次攻擊。" - }, - "battleBond": { - "name": "牽絆變身", - "description": "打倒對手時,與訓練家的牽\n絆會加深,自己的攻擊、特\n攻和速度會提高。" - }, - "powerConstruct": { - "name": "群聚變形", - "description": "HP變為一半時,細胞們會\n趕來支援,變為完全體形態。" - }, - "corrosion": { - "name": "腐蝕", - "description": "就算對方是鋼屬性或毒屬性\n寶可夢,也可讓對方陷入中\n毒狀態。" - }, - "comatose": { - "name": "絕對睡眠", - "description": "總是半夢半醒的狀態,絕對\n不會醒來。可在睡著的狀況\n下進行攻擊。" - }, - "queenlyMajesty": { - "name": "女王的威嚴", - "description": "向對手施加威懾力,使其無\n法對我方使出先制招式。" - }, - "innardsOut": { - "name": "飛出的內在物", - "description": "被對手打倒的時候,會給予\n對手相當於HP剩餘量的傷\n害。" - }, - "dancer": { - "name": "舞者", - "description": "當有誰使出跳舞招式時,自\n己也能接著使出跳舞招式。" - }, - "battery": { - "name": "蓄電池", - "description": "會提高我方的特殊招式的威\n力。" - }, - "fluffy": { - "name": "毛茸茸", - "description": "會將對手所給予的接觸類招\n式的傷害減半,但火屬性招\n式的傷害會變為2倍。" - }, - "dazzling": { - "name": "鮮豔之軀", - "description": "讓對手嚇一跳,使其無法對\n我方使出先制招式。" - }, - "soulHeart": { - "name": "魂心", - "description": "每當場上有寶可夢陷入瀕死\n狀態時,特攻就會提高。" - }, - "tanglingHair": { - "name": "捲髮", - "description": "對手用攻擊接觸到自己時,\n降低此對手的速度。" - }, - "receiver": { - "name": "接球手", - "description": "繼承被打倒的同伴的特性,\n變為相同的特性。" - }, - "powerOfAlchemy": { - "name": "化學之力", - "description": "繼承被打倒的同伴的特性,\n變為相同的特性。" - }, - "beastBoost": { - "name": "異獸提升", - "description": "打倒對手的時候,會提高自\n己最高的那項能力。" - }, - "rksSystem": { - "name": "AR系統", - "description": "根據持有的記憶碟,自己的\n屬性會改變。" - }, - "electricSurge": { - "name": "電氣製造者", - "description": "出場時,會布下電氣場地。" - }, - "psychicSurge": { - "name": "精神製造者", - "description": "出場時,會布下精神場地。" - }, - "mistySurge": { - "name": "薄霧製造者", - "description": "出場時,會布下薄霧場地。" - }, - "grassySurge": { - "name": "青草製造者", - "description": "出場時,會布下青草場地。" - }, - "fullMetalBody": { - "name": "金屬防護", - "description": "不會因對手的招式或特性而\n被降低能力。" - }, - "shadowShield": { - "name": "幻影防守", - "description": "HP全滿時,受到的傷害會\n變少。" - }, - "prismArmor": { - "name": "棱鏡裝甲", - "description": "受到效果絕佳的攻擊時,可\n減弱其威力。" - }, - "neuroforce": { - "name": "腦核之力", - "description": "可進一步提升效果絕佳招式\n的威力。" - }, - "intrepidSword": { - "name": "不撓之劍", - "description": "在戰鬥中首次出場時,攻擊\n會提高。" - }, - "dauntlessShield": { - "name": "不屈之盾", - "description": "在戰鬥中首次出場時,防禦\n會提高。" - }, - "libero": { - "name": "自由者", - "description": "每次出場戰鬥時,變為與自\n己使出的招式相同的屬性1\n次。" - }, - "ballFetch": { - "name": "撿球", - "description": "當寶可夢沒有攜帶道具時,\n會撿回第1個投出後捕捉失\n敗的精靈球。" - }, - "cottonDown": { - "name": "棉絮", - "description": "受到攻擊時會撒下棉絮,降\n低除自己以外的所有寶可夢\n的速度。" - }, - "propellerTail": { - "name": "螺旋尾鰭", - "description": "能無視具有吸引對手招式效\n果的特性或招式的影響。" - }, - "mirrorArmor": { - "name": "鏡甲", - "description": "只反彈自己受到的能力降低\n效果。" - }, - "gulpMissile": { - "name": "一口導彈", - "description": "衝浪或潛水時會叼來獵物。\n當受到傷害時,會吐出獵物\n攻擊對手。" - }, - "stalwart": { - "name": "堅毅", - "description": "能無視具有吸引對手招式效\n果的特性或招式的影響。" - }, - "steamEngine": { - "name": "蒸汽機", - "description": "受到水屬性或火屬性招式攻\n擊時,速度會極大幅提高。" - }, - "punkRock": { - "name": "龐克搖滾", - "description": "聲音招式的威力會提高。受\n到聲音招式的傷害會減半。" - }, - "sandSpit": { - "name": "吐沙", - "description": "受到攻擊時,會刮起沙暴。" - }, - "iceScales": { - "name": "冰鱗粉", - "description": "得到冰鱗粉的守護,受到的\n特殊攻擊傷害會減半。" - }, - "ripen": { - "name": "熟成", - "description": "讓樹果成熟,使效果變為2\n倍。" - }, - "iceFace": { - "name": "結凍頭", - "description": "頭部的冰會代替自己承受物\n理攻擊,但是樣子會改變。\n下雪時,冰會恢復原狀。" - }, - "powerSpot": { - "name": "能量點", - "description": "只要站在旁邊,招式的威力\n就會提高。" - }, - "mimicry": { - "name": "擬態", - "description": "寶可夢的屬性會根據場地的\n狀態而改變。" - }, - "screenCleaner": { - "name": "除障", - "description": "出場時,敵方和我方的光牆\n、反射壁和極光幕的效果會\n消失。" - }, - "steelySpirit": { - "name": "鋼之意志", - "description": "我方的鋼屬性攻擊威力會提\n高。" - }, - "perishBody": { - "name": "滅亡之軀", - "description": "在受到接觸類招式攻擊時,\n3個回合後雙方都會陷入瀕\n死。替換寶可夢後效果就\n會消失。" - }, - "wanderingSpirit": { - "name": "遊魂", - "description": "與使用接觸類招式攻擊自己\n的寶可夢互換特性。" - }, - "gorillaTactics": { - "name": "一猩一意", - "description": "攻擊雖然會提高,但只能使\n出最初選擇的招式。" - }, - "neutralizingGas": { - "name": "化學變化氣體", - "description": "當場上有特性是化學變化氣\n體的寶可夢時,所有寶可夢\n的特性效果都會消失或無\n法發動。" - }, - "pastelVeil": { - "name": "粉彩護幕", - "description": "自己和我方同伴都不會陷入\n中毒的異常狀態。" - }, - "hungerSwitch": { - "name": "飽了又餓", - "description": "在每個回合結束時,會在滿\n腹花紋和空腹花紋之間交替\n改變樣子。" - }, - "quickDraw": { - "name": "速擊", - "description": "有時能比對手先一步行動。" - }, - "unseenFist": { - "name": "無形拳", - "description": "只要是接觸到對手的招式,\n就可以無視對手的防守效果\n進行攻擊。" - }, - "curiousMedicine": { - "name": "怪藥", - "description": "出場時,會從貝殼撒藥,將\n我方的能力變化復原。" - }, - "transistor": { - "name": "電晶體", - "description": "電屬性的招式威力會提高。" - }, - "dragonsMaw": { - "name": "龍顎", - "description": "龍屬性的招式威力會提高。" - }, - "chillingNeigh": { - "name": "蒼白嘶鳴", - "description": "打倒對手時會用冰冷的聲音\n嘶鳴並提高攻擊。" - }, - "grimNeigh": { - "name": "漆黑嘶鳴", - "description": "打倒對手時會用恐怖的聲音\n嘶鳴並提高特攻。" - }, - "asOneGlastrier": { - "name": "人馬一體", - "description": "兼備蕾冠王的緊張感和雪暴\n馬的蒼白嘶鳴這2種特性。" - }, - "asOneSpectrier": { - "name": "人馬一體", - "description": "兼備蕾冠王的緊張感和靈幽\n馬的漆黑嘶鳴這2種特性。" - }, - "lingeringAroma": { - "name": "甩不掉的氣味", - "description": "被對手接觸到時,甩不掉的\n氣味會沾染給對手。" - }, - "seedSower": { - "name": "掉出種子", - "description": "受到攻擊時,會將腳下變成\n青草場地。" - }, - "thermalExchange": { - "name": "熱交換", - "description": "受到火屬性的招式攻擊時,\n攻擊會提高,不會陷入灼傷\n狀態。" - }, - "angerShell": { - "name": "憤怒甲殼", - "description": "HP因對手的攻擊降到一半\n時,會因憤怒而降低防禦和\n特防,但攻擊、特攻和速度\n會提高。" - }, - "purifyingSalt": { - "name": "潔淨之鹽", - "description": "因潔淨的鹽而不會陷入異常\n狀態。能夠讓幽靈屬性招式\n的傷害減半。" - }, - "wellBakedBody": { - "name": "焦香之軀", - "description": "受到火屬性的招式攻擊時,\n不但不會受到傷害,反而防\n禦會大幅提高" - }, - "windRider": { - "name": "乘風", - "description": "吹起順風或受到風的招式攻\n擊時,不但不會受到傷害,\n反而攻擊會提高。" - }, - "guardDog": { - "name": "看門犬", - "description": "受到威嚇時,攻擊會提高。\n會讓替換寶可夢的招式和道\n具失效。" - }, - "rockyPayload": { - "name": "搬巖", - "description": "岩石屬性的招式威力會提高。" - }, - "windPower": { - "name": "風力發電", - "description": "受到風的招式攻擊時,會變\n成充電狀態。" - }, - "zeroToHero": { - "name": "全能變身", - "description": "離場後會變為全能形態。" - }, - "commander": { - "name": "發號施令", - "description": "出場時,若我方有吃吼霸,\n便會進入吃吼霸的口中,從\n那裡發號施令。" - }, - "electromorphosis": { - "name": "電力轉換", - "description": "受到傷害時,會變成充電狀\n態。" - }, - "protosynthesis": { - "name": "古代活性", - "description": "攜帶著驅勁能量或天氣為晴\n朗時,數值最高的能力會提\n高。" - }, - "quarkDrive": { - "name": "夸克充能", - "description": "攜帶著驅勁能量或在電氣場\n地上時,數值最高的能力會\n提高。" - }, - "goodAsGold": { - "name": "黃金之軀", - "description": "既不氧化又堅韌的黃金之軀\n不會受到對手的變化類招式\n攻擊。" - }, - "vesselOfRuin": { - "name": "災禍之鼎", - "description": "在喚來災厄之鼎的力量下,\n除自己以外的特攻會變弱。" - }, - "swordOfRuin": { - "name": "災禍之劍", - "description": "在喚來災厄之劍的力量下,\n除自己以外的防禦會變弱。" - }, - "tabletsOfRuin": { - "name": "災禍之簡", - "description": "在喚來災厄之木簡的力量下\n,除自己以外的攻擊會變弱。" - }, - "beadsOfRuin": { - "name": "災禍之玉", - "description": "在喚來災厄之木簡的力量下\n,除自己以外的特防會變弱。" - }, - "orichalcumPulse": { - "name": "緋紅脈動", - "description": "出場時,會將天氣變為晴朗\n。日照很強時,會因為古代\n的脈動而使攻擊升高。" - }, - "hadronEngine": { - "name": "強子引擎", - "description": "出場時,會布下電氣場地。\n在電氣場地時,會因為未來\n的機關而使特攻升高。" - }, - "opportunist": { - "name": "跟風", - "description": "對手的能力提高時,自己也\n會跟著提高能力。" - }, - "cudChew": { - "name": "反芻", - "description": "食用樹果後,會在下一回合\n結束時從胃裡取出,以1次\n為限再次食用。" - }, - "sharpness": { - "name": "鋒銳", - "description": "切斬對手的招式威力會提高。" - }, - "supremeOverlord": { - "name": "大將", - "description": "出場時,先前每有1隻同伴\n被打倒,攻擊和特攻就會提\n高少許。" - }, - "costar": { - "name": "同台共演", - "description": "出場時,會複製同伴的能力\n變化。" - }, - "toxicDebris": { - "name": "毒滿地", - "description": "因物理招式受到傷害時,會\n在對手腳下散布毒菱。" - }, - "armorTail": { - "name": "尾甲", - "description": "包覆著頭部的神秘尾巴使對\n手無法對我方使出先制招式。" - }, - "earthEater": { - "name": "食土", - "description": "受到地面屬性的招式攻擊時\n,不會受到傷害,而是會回\n復。" - }, - "myceliumMight": { - "name": "菌絲之力", - "description": "使出變化類招式時,行動一\n定會變緩慢,但不會受到對\n手特性的干擾。" - }, - "mindsEye": { - "name": "心眼", - "description": "一般屬性和格鬥屬性的招式\n可以擊中幽靈屬性的寶可夢。\n無視對手的閃避率的變化,\n且命中率不會被降低。" - }, - "supersweetSyrup": { - "name": "甘露之蜜", - "description": "在對戰中首次出場時,會四\n處散播甜膩的蜜香,降低對\n手的閃避率。" - }, - "hospitality": { - "name": "款待", - "description": "出場時款待同伴,使其回復\n少量HP。" - }, - "toxicChain": { - "name": "毒鎖鏈", - "description": "靠著含有毒素的鎖鏈的力量\n,有時會讓被招式擊中的對\n手陷入劇毒狀態。" - }, - "embodyAspectTeal": { - "name": "面影輝映", - "description": "將回憶映於心中,使碧草面\n具發出光輝,提高自己的速\n度。" - }, - "embodyAspectWellspring": { - "name": "面影輝映", - "description": "將回憶映於心中,使水井面\n具發出光輝,提高自己的特\n防。" - }, - "embodyAspectHearthflame": { - "name": "面影輝映", - "description": "將回憶映於心中,使火灶面\n具發出光輝,提高自己的攻\n擊。" - }, - "embodyAspectCornerstone": { - "name": "面影輝映", - "description": "將回憶映於心中,使礎石面\n具發出光輝,提高自己的防\n御。" - }, - "teraShift": { - "name": "太晶變形", - "description": "出場時,會吸收周圍的能量\n,變為太晶形態。" - }, - "teraShell": { - "name": "太晶甲殼", - "description": "蘊藏著所有屬性力量的甲殼\n會將自身HP全滿時受到的\n傷害全都變為效果不好。" - }, - "teraformZero": { - "name": "歸零化境", - "description": "太樂巴戈斯變為星晶形態時\n,蘊藏其身的力量會將天氣\n和場地的影響全部歸零。" - }, - "poisonPuppeteer": { - "name": "毒傀儡", - "description": "因為桃歹郎的招式而陷入中\n毒狀態的對手同時也會陷入\n混亂狀態。" - } -} diff --git a/src/locales/zh_TW/achv.json b/src/locales/zh_TW/achv.json deleted file mode 100644 index 804ec0c5089..00000000000 --- a/src/locales/zh_TW/achv.json +++ /dev/null @@ -1,268 +0,0 @@ -{ - "Achievements": { - "name": "成就" - }, - "Locked": { - "name": "未解鎖" - }, - "MoneyAchv": { - "description": "累計獲得 ₽{{moneyAmount}}" - }, - "10K_MONEY": { - "name": "小有積蓄" - }, - "100K_MONEY": { - "name": "大戶人家" - }, - "1M_MONEY": { - "name": "百萬富翁" - }, - "10M_MONEY": { - "name": "暴發戶" - }, - "DamageAchv": { - "description": "在單次攻擊中造成\n {{damageAmount}} 點傷害" - }, - "250_DMG": { - "name": "重拳出擊" - }, - "1000_DMG": { - "name": "神拳猛擊" - }, - "2500_DMG": { - "name": "奪少?" - }, - "10000_DMG": { - "name": "一拳超人" - }, - "HealAchv": { - "description": "通過技能、能力或攜帶的道具\n一次性治療 {{healAmount}} {{HP}}點" - }, - "250_HEAL": { - "name": "新手奶媽" - }, - "1000_HEAL": { - "name": "治療擔當" - }, - "2500_HEAL": { - "name": "牧師" - }, - "10000_HEAL": { - "name": "泉水" - }, - "LevelAchv": { - "description": "將一隻寶可夢提升到 Lv{{level}}" - }, - "LV_100": { - "name": "别急,後面還有" - }, - "LV_250": { - "name": "精英" - }, - "LV_1000": { - "name": "天外有天" - }, - "RibbonAchv": { - "description": "累計獲得 {{ribbonAmount}} 個勛章" - }, - "10_RIBBONS": { - "name": "寶可夢聯盟冠軍" - }, - "25_RIBBONS": { - "name": "超級球聯盟冠軍" - }, - "50_RIBBONS": { - "name": "高級球聯盟冠軍" - }, - "75_RIBBONS": { - "name": "肉鴿球聯盟冠軍" - }, - "100_RIBBONS": { - "name": "大師球聯盟冠軍" - }, - "TRANSFER_MAX_STAT_STAGE": { - "name": "團隊協作", - "description": "在一項屬性強化至最大時用\n接力棒傳遞給其他寶可夢" - }, - "MAX_FRIENDSHIP": { - "name": "親密無間", - "description": "使一隻寶可夢的親密度\n達到最大值" - }, - "MEGA_EVOLVE": { - "name": "大變身", - "description": "超級進化一隻寶可夢" - }, - "GIGANTAMAX": { - "name": "這位更是重量級", - "description": "極巨化一隻寶可夢" - }, - "TERASTALLIZE": { - "name": "本系愛好者", - "description": "太晶化一隻寶可夢" - }, - "STELLAR_TERASTALLIZE": { - "name": "隱藏屬性", - "description": "星晶化一隻寶可夢" - }, - "SPLICE": { - "name": "無限融合", - "description": "使用基因之楔將兩隻寶可夢\n融合在一起" - }, - "MINI_BLACK_HOLE": { - "name": "一大洞的道具", - "description": "獲得一個迷你黑洞" - }, - "CATCH_MYTHICAL": { - "name": "神秘禮物", - "description": "捕捉一隻幻之寶可夢" - }, - "CATCH_SUB_LEGENDARY": { - "name": "二級傳說", - "description": "捕捉一隻準傳說寶可夢" - }, - "CATCH_LEGENDARY": { - "name": "傳說", - "description": "捕捉一隻傳說寶可夢" - }, - "SEE_SHINY": { - "name": "閃耀奪目", - "description": "在野外找到一隻閃光寶可夢" - }, - "SHINY_PARTY": { - "name": "嘔心瀝血", - "description": "擁有一支由閃光寶可夢組成\n的滿員隊伍" - }, - "HATCH_MYTHICAL": { - "name": "幻獸蛋", - "description": "從蛋中孵化出一隻幻之寶可夢" - }, - "HATCH_SUB_LEGENDARY": { - "name": "二級傳說蛋", - "description": "從蛋中孵化出一隻準傳說\n寶可夢" - }, - "HATCH_LEGENDARY": { - "name": "傳說蛋", - "description": "從蛋中孵化出一隻傳說寶可夢" - }, - "HATCH_SHINY": { - "name": "金色傳說!", - "description": "從蛋中孵化出一隻閃光寶可夢" - }, - "HIDDEN_ABILITY": { - "name": "隱藏實力", - "description": "捕捉一隻擁有隱藏特性\n的寶可夢" - }, - "PERFECT_IVS": { - "name": "合格證", - "description": "獲得一隻擁有完美個體值\n的寶可夢" - }, - "CLASSIC_VICTORY": { - "name": "戰無不勝", - "description": "在經典模式中通關遊戲" - }, - "UNEVOLVED_CLASSIC_VICTORY": { - "name": "帶孩上班", - "description": "通關經典模式時隊伍中至少有\n一名未進化的寶可夢" - }, - "MONO_GEN_ONE": { - "name": "最初的勁敵", - "description": "完成僅限第一世代的挑戰." - }, - "MONO_GEN_TWO": { - "name": "1.5世代", - "description": "完成僅限第二世代的挑戰." - }, - "MONO_GEN_THREE": { - "name": "“水太多了”", - "description": "完成僅限第三世代的挑戰." - }, - "MONO_GEN_FOUR": { - "name": "她真是最強冠軍嗎?", - "description": "完成僅限第四世代的挑戰." - }, - "MONO_GEN_FIVE": { - "name": "完全原創", - "description": "完成僅限第五世代的挑戰." - }, - "MONO_GEN_SIX": { - "name": "女大公", - "description": "完成僅限第六世代的挑戰." - }, - "MONO_GEN_SEVEN": { - "name": "首屆冠軍", - "description": "完成僅限第七世代的挑戰." - }, - "MONO_GEN_EIGHT": { - "name": "冠軍時刻!", - "description": "完成僅限第八世代的挑戰." - }, - "MONO_GEN_NINE": { - "name": "她又放水了", - "description": "完成僅限第九世代的挑戰." - }, - "MonoType": { - "description": "完成 {{type}} 單屬性挑戰." - }, - "MONO_NORMAL": { - "name": "異乎尋常的尋常" - }, - "MONO_FIGHTING": { - "name": "我有真功夫" - }, - "MONO_FLYING": { - "name": "憤怒的小鳥" - }, - "MONO_POISON": { - "name": "關都地區特色" - }, - "MONO_GROUND": { - "name": "地震預報" - }, - "MONO_ROCK": { - "name": "堅如磐石" - }, - "MONO_BUG": { - "name": "音箱蟀俠" - }, - "MONO_GHOST": { - "name": "捉鬼敢死隊" - }, - "MONO_STEEL": { - "name": "鐵巨人" - }, - "MONO_FIRE": { - "name": "搓火球解決一切" - }, - "MONO_WATER": { - "name": "當雨來臨,傾盆而下" - }, - "MONO_GRASS": { - "name": "別踏這個青" - }, - "MONO_ELECTRIC": { - "name": "瞄準大岩蛇的角!" - }, - "MONO_PSYCHIC": { - "name": "腦洞大開" - }, - "MONO_ICE": { - "name": "如履薄冰" - }, - "MONO_DRAGON": { - "name": "準神俱樂部" - }, - "MONO_DARK": { - "name": "總有叛逆期" - }, - "MONO_FAIRY": { - "name": "林克,醒醒!" - }, - "FRESH_START": { - "name": "初次嘗試!", - "description": "完成初次嘗試挑戰" - }, - "INVERSE_BATTLE": { - "name": "鏡子子鏡", - "description": "完成逆轉之戰挑戰\n戰挑戰之轉逆成完" - } -} diff --git a/src/locales/zh_TW/arena-flyout.json b/src/locales/zh_TW/arena-flyout.json deleted file mode 100644 index e201b683543..00000000000 --- a/src/locales/zh_TW/arena-flyout.json +++ /dev/null @@ -1,43 +0,0 @@ -{ - "activeBattleEffects": "當前戰鬥效果", - "player": "我方", - "neutral": "全局", - "enemy": "敵方", - - "sunny": "大晴天", - "rain": "下雨", - "sandstorm": "沙暴", - "hail": "冰雹", - "snow": "下雪", - "fog": "起霧", - "heavyRain": "大雨", - "harshSun": "大日照", - "strongWinds": "亂流", - - "misty": "薄霧場地", - "electric": "電氣場地", - "grassy": "青草場地", - "psychic": "精神場地", - - "mudSport": "玩泥巴", - "waterSport": "玩水", - "spikes": "撒菱", - "toxicSpikes": "毒菱", - "mist": "白霧", - "futureSight": "預知未來", - "doomDesire": "破滅之願", - "wish": "祈願", - "stealthRock": "隱形岩", - "stickyWeb": "黏黏網", - "trickRoom": "戲法空間", - "gravity": "重力", - "reflect": "反射壁", - "lightScreen": "光牆", - "auroraVeil": "極光幕", - "quickGuard": "快速防守", - "wideGuard": "廣域防守", - "matBlock": "掀榻榻米", - "craftyShield": "戲法防守", - "tailwind": "順風", - "happyHour": "快樂時光" -} diff --git a/src/locales/zh_TW/arena-tag.json b/src/locales/zh_TW/arena-tag.json deleted file mode 100644 index a6224f300a3..00000000000 --- a/src/locales/zh_TW/arena-tag.json +++ /dev/null @@ -1,57 +0,0 @@ -{ - "yourTeam": "我方隊伍", - "opposingTeam": "敵方隊伍", - "arenaOnRemove": "{{moveName}}的效果消失了!", - "arenaOnRemovePlayer": "{{moveName}}在我方的效果消失了!", - "arenaOnRemoveEnemy": "{{moveName}}在敵方的效果消失了!", - "mistOnAdd": "{{pokemonNameWithAffix}}的一方被\n白霧包圍了!", - "mistApply": "正受到白霧的保護\n能力不會被降低!", - "reflectOnAdd": "反射壁使\n物理抗性提高了!", - "reflectOnAddPlayer": "反射壁使我方的\n物理抗性提高了!", - "reflectOnAddEnemy": "反射壁使敵方的\n物理抗性提高了!", - "lightScreenOnAdd": "光牆使\n特殊抗性提高了!", - "lightScreenOnAddPlayer": "光牆使我方的\n特殊抗性提高了!", - "lightScreenOnAddEnemy": "光牆使敵方的\n特殊抗性提高了!", - "auroraVeilOnAdd": "極光幕使\n物理和特殊抗性提高了!", - "auroraVeilOnAddPlayer": "極光幕使我方的\n物理和特殊抗性提高了!", - "auroraVeilOnAddEnemy": "極光幕使敵方的\n物理和特殊抗性提高了!", - "conditionalProtectOnAdd": "{{moveName}}\n保護了!", - "conditionalProtectOnAddPlayer": "{{moveName}}\n保護了我方!", - "conditionalProtectOnAddEnemy": "{{moveName}}\n保護了敵方!", - "conditionalProtectApply": "{{moveName}}\n保護了{{pokemonNameWithAffix}}!", - "matBlockOnAdd": "{{pokemonNameWithAffix}}正在\n伺機使出掀榻榻米!", - "noCritOnAddPlayer": "{{moveName}}保護了你的\n隊伍不被擊中要害!", - "noCritOnAddEnemy": "{{moveName}}保護了對方的\n隊伍不被擊中要害!", - "noCritOnRemove": "{{pokemonNameWithAffix}}的{{moveName}}\n效果消失了!", - "wishTagOnAdd": "{{pokemonNameWithAffix}}的\n祈願實現了!", - "mudSportOnAdd": "電氣的威力減弱了!", - "mudSportOnRemove": "玩泥巴的效果消失了!", - "waterSportOnAdd": "火焰的威力減弱了!", - "waterSportOnRemove": "玩水的效果消失了!", - "spikesOnAdd": "{{opponentDesc}}腳下\n散落著{{moveName}}!", - "spikesActivateTrap": "{{pokemonNameWithAffix}}\n受到了撒菱的傷害!", - "toxicSpikesOnAdd": "{{opponentDesc}}腳下\n散落著{{moveName}}!", - "toxicSpikesActivateTrapPoison": "{{pokemonNameWithAffix}}\n吸收了{{moveName}}!", - "stealthRockOnAdd": "{{opponentDesc}}周圍\n開始浮現出尖銳的岩石!", - "stealthRockActivateTrap": "尖銳的岩石紮進了\n{{pokemonNameWithAffix}}的體內!", - "stickyWebOnAdd": "對方的腳下\n延伸出了{{moveName}}!", - "stickyWebActivateTrap": "{{pokemonName}}\n被黏黏網粘住了!", - "trickRoomOnAdd": "{{pokemonNameWithAffix}}\n扭曲了時空!", - "trickRoomOnRemove": "扭曲的時空複原了!", - "gravityOnAdd": "重力變強了!", - "gravityOnRemove": "重力複原了!", - "tailwindOnAdd": "從身後\n吹起了順風!", - "tailwindOnAddPlayer": "從我方身後\n吹起了順風!", - "tailwindOnAddEnemy": "從敵方身後\n吹起了順風!", - "tailwindOnRemove": "順風停止了!", - "tailwindOnRemovePlayer": "我方的順風停止了!", - "tailwindOnRemoveEnemy": "敵方的順風停止了!", - "happyHourOnAdd": "大家被歡樂的\n氣氛包圍了!", - "happyHourOnRemove": "氣氛回複到平常了。", - "safeguardOnAdd": "整個場地被\n神秘之幕包圍了!", - "safeguardOnAddPlayer": "我方被\n神秘之幕包圍了!", - "safeguardOnAddEnemy": "對手被\n神秘之幕包圍了!", - "safeguardOnRemove": "包圍整個場地的\n神秘之幕消失了!", - "safeguardOnRemovePlayer": "包圍我方的\n神秘之幕消失了!", - "safeguardOnRemoveEnemy": "包圍對手的\n神秘之幕消失了!" -} diff --git a/src/locales/zh_TW/battle-info.json b/src/locales/zh_TW/battle-info.json deleted file mode 100644 index 884a01eb8a7..00000000000 --- a/src/locales/zh_TW/battle-info.json +++ /dev/null @@ -1,3 +0,0 @@ -{ - "generation": "第{{generation}}世代" -} \ No newline at end of file diff --git a/src/locales/zh_TW/battle-message-ui-handler.json b/src/locales/zh_TW/battle-message-ui-handler.json deleted file mode 100644 index 9cfa83e31dd..00000000000 --- a/src/locales/zh_TW/battle-message-ui-handler.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "ivBest": "最棒", - "ivFantastic": "了不起", - "ivVeryGood": "非常好", - "ivPrettyGood": "相當好", - "ivDecent": "一般般", - "ivNoGood": "也許不行" -} \ No newline at end of file diff --git a/src/locales/zh_TW/battle-scene.json b/src/locales/zh_TW/battle-scene.json deleted file mode 100644 index a0288475d69..00000000000 --- a/src/locales/zh_TW/battle-scene.json +++ /dev/null @@ -1,3 +0,0 @@ -{ - "moneyOwned": "₽{{formattedMoney}}" -} \ No newline at end of file diff --git a/src/locales/zh_TW/battle.json b/src/locales/zh_TW/battle.json deleted file mode 100644 index 66da1b7cace..00000000000 --- a/src/locales/zh_TW/battle.json +++ /dev/null @@ -1,98 +0,0 @@ -{ - "bossAppeared": "{{bossName}} 出現了。", - "trainerAppeared": "{{trainerName}}\n想要和你對戰!", - "trainerAppearedDouble": "{{trainerName}}\n想要和你對戰!", - "trainerSendOut": "{{trainerName}}派出了\n{{pokemonName}}!", - "singleWildAppeared": "一只野生的{{pokemonName}}出現了!", - "multiWildAppeared": "野生的{{pokemonName1}}\n和{{pokemonName2}}出現了!", - "playerComeBack": "回來吧,{{pokemonName}}!", - "trainerComeBack": "{{trainerName}}收回了{{pokemonName}}!", - "playerGo": "去吧!{{pokemonName}}!", - "trainerGo": "{{trainerName}}派出了\n{{pokemonName}}!", - "trainerSendOut": "{{trainerName}}派出了\n{{pokemonName}}!", - "singleWildAppeared": "一只野生的{{pokemonName}}出現了!", - "multiWildAppeared": "野生的{{pokemonName1}}\n和{{pokemonName2}}出現了!", - "playerComeBack": "回來吧,{{pokemonName}}!", - "trainerComeBack": "{{trainerName}}收回了{{pokemonName}}!", - "playerGo": "去吧!{{pokemonName}}!", - "trainerGo": "{{trainerName}}派出了\n{{pokemonName}}!", - "switchQuestion": "要更換\n{{pokemonName}}嗎?", - "trainerDefeated": "你擊敗了\n{{trainerName}}!", - "moneyWon": "你贏得了\n₽{{moneyAmount}}!", - "moneyPickedUp": "撿到了₽{{moneyAmount}}!", - "pokemonCaught": "{{pokemonName}}被抓住了!", - "addedAsAStarter": "增加了{{pokemonName}}作爲\n一個新的基礎寶可夢!", - "partyFull": "你的隊伍已滿員。是否放生其他寶可夢\n爲{{pokemonName}}騰出空間?", - "pokemon": "寶可夢", - "sendOutPokemon": "上吧!\n{{pokemonName}}!", - "hitResultCriticalHit": "擊中了要害!", - "hitResultSuperEffective": "效果拔群!", - "hitResultNotVeryEffective": "收效甚微…", - "hitResultNoEffect": "對{{pokemonName}}沒有效果!", - "hitResultImmune": "對于{{pokemonName}},\n完全沒有效果!", - "hitResultOneHitKO": "一擊必殺!", - "attackFailed": "但是失敗了!", - "attackMissed": "沒有命中{{pokemonNameWithAffix}}!", - "attackHitsCount": "擊中{{count}}次!", - "rewardGain": "你獲得了\n{{modifierName}}!", - "expGain": "{{pokemonName}}獲得了{{exp}} 點經驗值!", - "levelUp": "{{pokemonName}}升級到Lv.{{level}}!", - "learnMove": "{{pokemonName}}學會了{{moveName}}!", - "learnMovePrompt": "{{pokemonName}}想要學習{{moveName}}。", - "learnMoveLimitReached": "但是,{{pokemonName}}已經學會了\n四個技能", - "learnMoveReplaceQuestion": "要忘記一個技能並學習{{moveName}}嗎?", - "learnMoveStopTeaching": "不再嘗試學習{{moveName}}?", - "learnMoveNotLearned": "{{pokemonName}}沒有學會{{moveName}}。", - "learnMoveForgetQuestion": "要忘記哪個技能?", - "learnMoveForgetSuccess": "{{pokemonName}}忘記了\n如何使用{{moveName}}。", - "countdownPoof": "@d{32}1, @d{15}2 @d{15}… @d{15}… @d{15}@s{pb_bounce_1}空!", - "learnMoveAnd": "然後……", - "levelCapUp": "等級上限提升到{{levelCap}}!", - "moveNotImplemented": "{{moveName}}尚未實裝,無法選擇。", - "moveNoPP": "這個技能的PP用完了", - "moveDisabled": "{{moveName}}被禁用!", - "disableInterruptedMove": "{{pokemonNameWithAffix}}的{{moveName}}\n被無效化了!", - "noPokeballForce": "一股無形的力量阻止了你使用精靈球。", - "noPokeballTrainer": "你不能捕捉其他訓練家的寶可夢!", - "noPokeballMulti": "只能在剩下一只寶可夢時才能扔出精靈球!", - "noPokeballStrong": "目標寶可夢太強了,無法捕捉!\n你需要先削弱它!", - "noEscapeForce": "一股無形的力量阻止你逃跑。", - "noEscapeTrainer": "你不能從與訓練家的戰鬥中逃跑!", - "noEscapePokemon": "{{pokemonName}}的{{moveName}}\n阻止了你{{escapeVerb}}!", - "runAwaySuccess": "成功逃走了!", - "runAwayCannotEscape": "無法逃走!", - "escapeVerbSwitch": "切換", - "escapeVerbFlee": "逃跑", - "notDisabled": "{{moveName}}不再被禁用!", - "turnEndHpRestore": "{{pokemonName}}的體力恢複了。", - "hpIsFull": "{{pokemonName}}的體力已滿!", - "skipItemQuestion": "你確定要跳過拾取道具嗎?", - "itemStackFull": "{{fullItemName}}持有數達到上限,\n你獲得了{{itemName}}作爲替代。", - "eggHatching": "咦?", - "stealEatBerry": "{{pokemonName}}奪取並吃掉了\n{{targetName}}的{{berryName}}!", - "ppHealBerry": "{{pokemonNameWithAffix}}用{{berryName}}\n回複了{{moveName}}的PP!", - "hpHealBerry": "{{pokemonNameWithAffix}}用{{berryName}}\n回複了體力!", - "ivScannerUseQuestion": "對{{pokemonName}}使用個體值掃描儀?", - "wildPokemonWithAffix": "野生的{{pokemonName}}", - "foePokemonWithAffix": "對手的{{pokemonName}}", - "useMove": "{{pokemonNameWithAffix}}使用了\n{{moveName}}!", - "drainMessage": "{{pokemonName}}\n吸取了體力!", - "regainHealth": "{{pokemonName}}\n回複了體力!", - "fainted": "{{pokemonNameWithAffix}}\n倒下了!", - "statsAnd": "和", - "stats": "能力", - "statRose_other": "{{pokemonNameWithAffix}}的{{stats}}提高了!", - "statSharplyRose_other": "{{pokemonNameWithAffix}}的{{stats}}大幅提高了!", - "statRoseDrastically_other": "{{pokemonNameWithAffix}}的{{stats}}極大幅提高了!", - "statWontGoAnyHigher_other": "{{pokemonNameWithAffix}}的{{stats}}已經無法再提高了!", - "statFell_other": "{{pokemonNameWithAffix}}的{{stats}}降低了!", - "statHarshlyFell_other": "{{pokemonNameWithAffix}}的{{stats}}大幅降低了!", - "statSeverelyFell_other": "{{pokemonNameWithAffix}}的{{stats}}極大幅降低了!", - "statWontGoAnyLower_other": "{{pokemonNameWithAffix}}的{{stats}}已經無法再降低了!", - "transformedIntoType": "{{pokemonName}}變成了\n{{type}}屬性!", - "ppReduced": "降低了{{targetName}}的\n{{moveName}}的PP{{reduction}}點!", - "retryBattle": "你要從對戰開始時重試麽?", - "unlockedSomething": "{{unlockedThing}}\n已解鎖。", - "congratulations": "恭喜!", - "beatModeFirstTime": "{{speciesName}}首次擊敗了{{gameMode}}!\n你獲得了{{newModifier}}!" -} diff --git a/src/locales/zh_TW/battler-tags.json b/src/locales/zh_TW/battler-tags.json deleted file mode 100644 index 49b19f5efdc..00000000000 --- a/src/locales/zh_TW/battler-tags.json +++ /dev/null @@ -1,77 +0,0 @@ -{ - "trappedDesc": "束縛", - "flinchedDesc": "畏縮", - "confusedDesc": "混亂", - "infatuatedDesc": "著迷", - "seedDesc": "寄生種子", - "nightmareDesc": "惡夢", - "ingrainDesc": "扎根", - "drowsyDesc": "瞌睡", - "rechargingLapse": "{{pokemonNameWithAffix}}因攻擊的反作用力而無法動彈!", - "trappedOnAdd": "{{pokemonNameWithAffix}}不能逃跑!", - "trappedOnRemove": "{{pokemonNameWithAffix}}擺脫了{{moveName}}!", - "flinchedLapse": "{{pokemonNameWithAffix}}畏縮了!", - "confusedOnAdd": "{{pokemonNameWithAffix}}混亂了!", - "confusedOnRemove": "{{pokemonNameWithAffix}}的混亂解除了!", - "confusedOnOverlap": "{{pokemonNameWithAffix}}已經混亂了。", - "confusedLapse": "{{pokemonNameWithAffix}}正在混亂中!", - "confusedLapseHurtItself": "不知所以地攻擊了自己!", - "destinyBondLapseIsBoss": "{{pokemonNameWithAffix}}不再受到同命的影響", - "destinyBondLapse": "{{pokemonNameWithAffix}} 和{{pokemonNameWithAffix2}} 同歸於盡了!", - "infatuatedOnAdd": "{{pokemonNameWithAffix}}對{{sourcePokemonName}}著迷了!", - "infatuatedOnOverlap": "{{pokemonNameWithAffix}}已經著迷了!", - "infatuatedLapse": "{{pokemonNameWithAffix}}對{{sourcePokemonName}}著迷中!", - "infatuatedLapseImmobilize": "{{pokemonNameWithAffix}} 不會著迷!", - "infatuatedOnRemove": "{{pokemonNameWithAffix}} 治癒了著迷狀態!", - "seededOnAdd": "將種子種植在了{{pokemonNameWithAffix}}身上!", - "seededLapse": "{{pokemonNameWithAffix}}被寄生種子吸取了體力!", - "seededLapseShed": "{{pokemonNameWithAffix}}吸到了污泥漿!", - "nightmareOnAdd": "{{pokemonNameWithAffix}}開始做惡夢了!", - "nightmareOnOverlap": "{{pokemonNameWithAffix}}已經被惡夢纏身!", - "nightmareLapse": "{{pokemonNameWithAffix}}正被惡夢纏身!", - "encoreOnAdd": "{{pokemonNameWithAffix}}接受了再來一次!", - "encoreOnRemove": "{{pokemonNameWithAffix}}的再來一次狀態解除了!", - "helpingHandOnAdd": "{{pokemonNameWithAffix}}擺出了幫助{{pokemonName}} 的架勢!", - "ingrainLapse": "{{pokemonNameWithAffix}}用扎根回復了體力!", - "ingrainOnTrap": "{{pokemonNameWithAffix}}扎根了!", - "aquaRingOnAdd": "{{pokemonNameWithAffix}}用水流環包裹了自己!", - "aquaRingLapse": "{{moveName}}回復了{{pokemonName}}的體力!", - "drowsyOnAdd": "{{pokemonNameWithAffix}}產生睡意了!", - "damagingTrapLapse": "{{pokemonNameWithAffix}}受到了{{moveName}}的傷害!", - "bindOnTrap": "{{pokemonNameWithAffix}}被{{sourcePokemonName}}的 {{moveName}}緊緊束縛住了!", - "wrapOnTrap": "{{pokemonNameWithAffix}}被{{sourcePokemonName}}綁緊了!", - "vortexOnTrap": "{{pokemonNameWithAffix}}被困在了旋渦之中!", - "clampOnTrap": "{{sourcePokemonNameWithAffix}}用貝殼夾住了{{pokemonName}}!", - "sandTombOnTrap": "{{pokemonNameWithAffix}}被{{moveName}}困住了!", - "magmaStormOnTrap": "{{pokemonNameWithAffix}}被困在了熔岩風暴之中!", - "snapTrapOnTrap": "{{pokemonNameWithAffix}}被捕獸夾困住了!", - "thunderCageOnTrap": "{{sourcePokemonNameWithAffix}}困住了{{pokemonNameWithAffix}}!", - "infestationOnTrap": "{{pokemonNameWithAffix}}受到了{{sourcePokemonNameWithAffix}}的死纏爛打!", - "protectedOnAdd": "{{pokemonNameWithAffix}}擺出了防守的架勢!", - "protectedLapse": "{{pokemonNameWithAffix}}在攻擊中保護了自己!", - "enduringOnAdd": "{{pokemonNameWithAffix}}擺出了挺住攻擊的架勢!", - "enduringLapse": "{{pokemonNameWithAffix}}挺住了攻擊!", - "sturdyLapse": "{{pokemonNameWithAffix}}挺住了攻擊!", - "perishSongLapse": "{{pokemonNameWithAffix}} 的滅亡計時變成{{turnCount}}了!", - "centerOfAttentionOnAdd": "{{pokemonNameWithAffix}}\n變得萬眾矚目了!", - "truantLapse": "{{pokemonNameWithAffix}}正在偷懶!", - "slowStartOnAdd": "{{pokemonNameWithAffix}}無法拿出平時的水平!", - "slowStartOnRemove": "{{pokemonNameWithAffix}}恢復了平時的水平!", - "highestStatBoostOnAdd": "{{pokemonNameWithAffix}}的{{statName}}升高了!", - "highestStatBoostOnRemove": "{{pokemonNameWithAffix}}的{{abilityName}}效果解除了!", - "magnetRisenOnAdd": "{{pokemonNameWithAffix}}\n因電磁力浮了起來!", - "magnetRisenOnRemove": "{{pokemonNameWithAffix}}的\n電磁力消失了!", - "critBoostOnAdd": "{{pokemonNameWithAffix}}現在幹勁十足!", - "critBoostOnRemove": "{{pokemonNameWithAffix}}如釋重負似地放鬆了下來。", - "saltCuredOnAdd": "{{pokemonNameWithAffix}} 陷入了鹽腌狀態!", - "saltCuredLapse": "{{pokemonNameWithAffix}} 受到了{{moveName}}的傷害!", - "cursedOnAdd": "{{pokemonNameWithAffix}}削減了自己的體力,並詛咒了{{pokemonName}}!", - "cursedLapse": "{{pokemonNameWithAffix}}正受到詛咒!", - "stockpilingOnAdd": "{{pokemonNameWithAffix}}蓄力了{{stockpiledCount}}次!", - "disabledOnAdd": "封住了{{pokemonNameWithAffix}}的\n{moveName}}!", - "disabledLapse": "{{pokemonNameWithAffix}}的\n定身法解除了!", - "tarShotOnAdd": "{{pokemonNameWithAffix}}\n變得怕火了!", - "substituteOnAdd": "{{pokemonNameWithAffix}}的\n替身出現了!", - "substituteOnHit": "替身代替{{pokemonNameWithAffix}}承受了攻擊!", - "substituteOnRemove": "{{pokemonNameWithAffix}}的\n替身消失了……" -} diff --git a/src/locales/zh_TW/berry.json b/src/locales/zh_TW/berry.json deleted file mode 100644 index ba16fec0900..00000000000 --- a/src/locales/zh_TW/berry.json +++ /dev/null @@ -1,46 +0,0 @@ -{ - "SITRUS": { - "name": "文柚果", - "effect": "HP低於50%時,恢復最大HP的25%" - }, - "LUM": { - "name": "木子果", - "effect": "治癒任何異常狀態和混亂狀態" - }, - "ENIGMA": { - "name": "謎芝果", - "effect": "受到效果絕佳的招式攻擊時,恢復25%最大HP" - }, - "LIECHI": { - "name": "枝荔果", - "effect": "HP低於25%時,攻擊提升一個等級" - }, - "GANLON": { - "name": "龍睛果", - "effect": "HP低於25%時,防禦提升一個等級" - }, - "PETAYA": { - "name": "龍火果", - "effect": "HP低於25%時,特攻提升一個等級" - }, - "APICOT": { - "name": "杏仔果", - "effect": "HP低於25%時,特防提升一個等級" - }, - "SALAC": { - "name": "沙鱗果", - "effect": "HP低於25%時,速度提升一個等級" - }, - "LANSAT": { - "name": "蘭薩果", - "effect": "HP低於25%時,擊中要害率提升兩個等級" - }, - "STARF": { - "name": "星桃果", - "effect": "HP低於25%時,提高隨機一項能力兩個等級" - }, - "LEPPA": { - "name": "蘋野果", - "effect": "有招式的PP降到0時,恢復該招式10PP" - } -} \ No newline at end of file diff --git a/src/locales/zh_TW/bgm-name.json b/src/locales/zh_TW/bgm-name.json deleted file mode 100644 index e8546750977..00000000000 --- a/src/locales/zh_TW/bgm-name.json +++ /dev/null @@ -1,141 +0,0 @@ -{ - "music": "Music: ", - "missing_entries" : "{{name}}", - "battle_kanto_champion": "黑2白2「決戰!關都冠軍」", - "battle_johto_champion": "黑2白2「決戰!城都冠軍」", - "battle_hoenn_champion_g5": "黑2白2「決戰!豐緣冠軍」", - "battle_hoenn_champion_g6": "Ω紅寶石α藍寶石「決戰!豐緣冠軍」", - "battle_sinnoh_champion": "黑2白2「決戰!神奧冠軍」", - "battle_champion_alder": "黑白「決戰!合衆冠軍」", - "battle_champion_iris": "黑2白2「決戰!合衆冠軍」", - "battle_kalos_champion": "XY「決戰!卡洛斯冠軍」", - "battle_alola_champion": "究極日月「頂上決戰!」", - "battle_galar_champion": "劍盾「決戰!伽勒爾冠軍」", - "battle_champion_geeta": "朱紫「決戰!帕底亞首席也慈」", - "battle_champion_nemona": "朱紫「決戰!帕底亞冠軍妮莫」", - "battle_champion_kieran": "朱紫「決戰!藍莓學園冠軍烏栗」", - "battle_hoenn_elite": "Ω紅寶石α藍寶石 「戰鬥!豐緣四天王」", - "battle_unova_elite": "黑白 「戰鬥!合衆四天王」", - "battle_kalos_elite": "XY「戰鬥!卡洛斯四天王」", - "battle_alola_elite": "日月「戰鬥!阿羅拉四天王」", - "battle_galar_elite": "劍盾「聯盟錦標賽」", - "battle_paldea_elite": "朱紫「戰鬥!帕底亞四天王」", - "battle_bb_elite": "朱紫「戰鬥!藍之圓盤四天王」", - "battle_final_encounter": "探險隊DX 「裂空座的領域」", - "battle_final": "黑白「戰鬥!魁奇思」", - "battle_kanto_gym": "黑2白2「戰鬥!關都道館主」", - "battle_johto_gym": "黑2白2「戰鬥!城都道館主」", - "battle_hoenn_gym": "黑2白2「戰鬥!合衆道館主」", - "battle_sinnoh_gym": "黑2白2「戰鬥!神奧道館主」", - "battle_unova_gym": "黑白「戰鬥!合衆道館主」", - "battle_kalos_gym": "XY「戰鬥!卡洛斯道館主」", - "battle_galar_gym": "劍盾「戰鬥!伽勒爾道館主」", - "battle_paldea_gym": "朱紫「戰鬥!帕底亞道館主」", - "battle_legendary_kanto": "XY「戰鬥!傳說寶可夢(關都)」", - "battle_legendary_raikou": "心金魂銀「戰鬥!雷公」", - "battle_legendary_entei": "心金魂銀「戰鬥!炎帝」", - "battle_legendary_suicune": "心金魂銀「戰鬥!水君」", - "battle_legendary_lugia": "心金魂銀「戰鬥!洛奇亞」", - "battle_legendary_ho_oh": "心金魂銀「戰鬥!鳳王」", - "battle_legendary_regis_g5": "黑2白2「戰鬥!傳說中的巨人」", - "battle_legendary_regis_g6": "Ω紅寶石α藍寶石「戰鬥!傳說中的巨人」", - "battle_legendary_gro_kyo": "Ω紅寶石α藍寶石「戰鬥!原始回歸」", - "battle_legendary_rayquaza": "Ω紅寶石α藍寶石「戰鬥!超古代寶可夢」", - "battle_legendary_deoxys": "Ω紅寶石α藍寶石「戰鬥!代歐奇希斯」", - "battle_legendary_lake_trio": "Ω紅寶石α藍寶石「戰鬥!由克希・艾姆利多・亞克諾姆」", - "battle_legendary_sinnoh": "Ω紅寶石α藍寶石「戰鬥!傳說的寶可夢」", - "battle_legendary_dia_pal": "Ω紅寶石α藍寶石「戰鬥!帝牙盧卡・帕路奇亞」", - "battle_legendary_giratina": "Ω紅寶石α藍寶石「戰鬥!騎拉帝納」", - "battle_legendary_arceus": "心金魂銀「阿爾宙斯」", - "battle_legendary_unova": "黑白「戰鬥!傳說的寶可夢」", - "battle_legendary_kyurem": "黑白「戰鬥!酋雷姆」", - "battle_legendary_res_zek": "黑白「戰鬥!萊希拉姆・捷克羅姆」", - "battle_legendary_xern_yvel": "XY「戰鬥!哲爾尼亞斯・伊裴爾塔爾」", - "battle_legendary_tapu": "日月「戰鬥!卡璞」", - "battle_legendary_sol_lun": "日月「戰鬥!露奈雅拉・索爾迦雷歐」", - "battle_legendary_ub": "日月「戰鬥!究極異獸」", - "battle_legendary_dusk_dawn": "究極日月「戰鬥!日食・月食 奈克洛茲瑪」", - "battle_legendary_ultra_nec": "究極日月「戰鬥!究極奈克洛茲瑪」", - "battle_legendary_zac_zam": "劍盾「戰鬥!蒼響・藏瑪然特」", - "battle_legendary_glas_spec": "劍盾「戰鬥! 雪暴馬・靈幽馬」", - "battle_legendary_calyrex": "劍盾「戰鬥!蕾冠王」", - "battle_legendary_birds_galar": "劍盾「戰鬥!傳說的鳥寶可夢」", - "battle_legendary_ruinous": "朱紫「戰鬥!災厄寶可夢」", - "battle_legendary_kor_mir": "朱紫「戰鬥!第零區的寶可夢2」", - "battle_legendary_loyal_three": "朱紫「戰鬥!寶伴」", - "battle_legendary_ogerpon": "朱紫「戰鬥!厄鬼椪」", - "battle_legendary_terapagos": "朱紫「戰鬥!太樂巴戈斯」", - "battle_legendary_pecharunt": "朱紫「戰鬥!桃歹郎」", - "battle_rival": "黑白「戰鬥!黑連・貝爾」", - "battle_rival_2": "黑白「戰鬥!N」", - "battle_rival_3": "黑白「決戰!N」", - "battle_trainer": "黑白「戰鬥!訓練師」", - "battle_wild": "黑白「戰鬥!野生寶可夢」", - "battle_wild_strong": "黑白「戰鬥!強大野生寶可夢」", - "end_summit": "探險隊DX 「天空之柱 頂層」", - "battle_rocket_grunt": "心金魂銀「戰鬥!火箭隊」", - "battle_aqua_magma_grunt": "Ω紅寶石α藍寶石「戰鬥!熔岩隊・海洋隊」", - "battle_galactic_grunt": "晶燦鑽石·明亮珍珠「戰鬥!銀河隊」", - "battle_plasma_grunt": "黑白「戰鬥!等離子團」", - "battle_flare_grunt": "XY「戰鬥!閃焰隊」", - "battle_rocket_boss": "究極日月「戰鬥!坂木」", - "battle_aqua_magma_boss": "Ω紅寶石α藍寶石「戰鬥!水梧桐・赤焰松」", - "battle_galactic_boss": "晶燦鑽石·明亮珍珠「戰鬥!赤日」", - "battle_plasma_boss": "黑2白2「戰鬥!魁奇思」", - "battle_flare_boss": "XY「戰鬥!弗拉達利」", - - "abyss": "空之探險隊「黑暗小丘」", - "badlands": "空之探險隊「枯竭之谷」", - "beach": "空之探險隊「潮濕岩地」", - "cave": "空之探險隊「天空頂端(洞窟)」", - "construction_site": "空之探險隊「幻影石室」", - "desert": "空之探險隊「北方沙漠」", - "dojo": "空之探險隊「嘎啦嘎啦道場」", - "end": "探險隊DX「天空之柱」", - "factory": "空之探險隊「隱藏遺迹」", - "fairy_cave": "空之探險隊「星之洞窟」", - "forest": "空之探險隊「黑暗森林」", - "grass": "空之探險隊「蘋果森林」", - "graveyard": "空之探險隊「神秘森林」", - "ice_cave": "空之探險隊「大冰山」", - "island": "空之探險隊「沿岸岩地」", - "jungle": "Lmz - 叢林", - "laboratory": "Firel - 研究所", - "lake": "空之探險隊「水晶洞窟」", - "meadow": "空之探險隊「天空頂端(森林)」", - "metropolis": "Firel - 城市", - "mountain": "空之探險隊「角山」", - "plains": "空之探險隊「天空頂端(草原)」", - "power_plant": "空之探險隊「電氣平原 深處」", - "ruins": "空之探險隊「封印岩地 深處」", - "sea": "Andr06 - 海洋之秘", - "seabed": "Firel - 海底", - "slum": "Andr06 - 狡猾的雪吞蟲", - "snowy_forest": "空之探險隊「天空頂端(雪山)」", - "space": "Firel - 太空", - "swamp": "空之探險隊「封閉之海」", - "tall_grass": "空之探險隊「濃霧森林」", - "temple": "空之探險隊「守護洞穴」", - "town": "空之探險隊「隨機迷宮3」", - "volcano": "空之探險隊「熱水洞窟」", - "wasteland": "空之探險隊「夢幻高原」", - - "encounter_ace_trainer": "黑白 「視線!精英訓練師」", - "encounter_backpacker": "黑白 「視線!背包客」", - "encounter_clerk": "黑白 「視線!上班族」", - "encounter_cyclist": "黑白 「視線!自行車手」", - "encounter_lass": "黑白 「視線!迷你裙」", - "encounter_parasol_lady": "黑白 「視線!陽傘姐姐」", - "encounter_pokefan": "黑白 「視線!寶可夢愛好者」", - "encounter_psychic": "黑白 「視線!超能力者」", - "encounter_rich": "黑白 「視線!紳士」", - "encounter_rival": "黑白「黑連」", - "encounter_roughneck": "黑白 「視線!光頭」", - "encounter_scientist": "黑白 「視線!科學家」", - "encounter_twins": "黑白 「視線!雙胞胎」", - "encounter_youngster": "黑白 「視線!短褲小子」", - - "heal": "黑白「寶可夢回複」", - "menu": "空之探險隊「歡迎來到寶可夢的世界」", - "title": "空之探險隊「主題曲」" -} diff --git a/src/locales/zh_TW/biome.json b/src/locales/zh_TW/biome.json deleted file mode 100644 index 5f10d817377..00000000000 --- a/src/locales/zh_TW/biome.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "unknownLocation": "未知領域", - "TOWN": "城鎮", - "PLAINS": "平原", - "GRASS": "草地", - "TALL_GRASS": "高草叢", - "METROPOLIS": "城市", - "FOREST": "森林", - "SEA": "海洋", - "SWAMP": "沼澤", - "BEACH": "沙灘", - "LAKE": "湖泊", - "SEABED": "海底", - "MOUNTAIN": "山脈", - "BADLANDS": "不毛之地", - "CAVE": "洞窟", - "DESERT": "沙漠", - "ICE_CAVE": "寒冰洞窟", - "MEADOW": "花叢", - "POWER_PLANT": "發電廠", - "VOLCANO": "火山", - "GRAVEYARD": "墓地", - "DOJO": "道場", - "FACTORY": "工廠", - "RUINS": "遺跡", - "WASTELAND": "荒地龍巢", - "ABYSS": "幽谷深淵", - "SPACE": "太空", - "CONSTRUCTION_SITE": "工地", - "JUNGLE": "叢林", - "FAIRY_CAVE": "妖精洞窟", - "TEMPLE": "神殿", - "SLUM": "陋巷", - "SNOWY_FOREST": "冰雪森林", - "ISLAND": "島嶼", - "LABORATORY": "研究所", - "END": "???" -} \ No newline at end of file diff --git a/src/locales/zh_TW/challenges.json b/src/locales/zh_TW/challenges.json deleted file mode 100644 index f600cc24a84..00000000000 --- a/src/locales/zh_TW/challenges.json +++ /dev/null @@ -1,36 +0,0 @@ -{ - "title": "適用挑戰條件", - "illegalEvolution": "{{pokemon}} 進化成了不符合\n挑戰條件的寶可夢!", - "singleGeneration": { - "name": "單一世代", - "desc": "你只能使用第{{gen}}\n世代的寶可夢", - "desc_default": "你只能使用所選\n世代的寶可夢", - "gen_1": "一", - "gen_2": "二", - "gen_3": "三", - "gen_4": "四", - "gen_5": "五", - "gen_6": "六", - "gen_7": "七", - "gen_8": "八", - "gen_9": "九" - }, - "singleType": { - "name": "單屬性", - "desc": "你只能使用{{type}}\n屬性的寶可夢", - "desc_default": "你只能使用所選\n屬性的寶可夢" - }, - "freshStart": { - "name": "初次嘗試", - "desc": "你只能使用禦三家,就像是你第一次玩寶可夢肉鴿一樣。", - "value.0": "關閉", - "value.1": "開啓" - }, - "inverseBattle": { - "name": "逆轉之戰", - "shortName": "逆轉之戰", - "desc": "屬性相克關系被反轉,且沒有任何屬性對其他屬性免疫。\n禁用其他挑戰的成就。", - "value.0": "關閉", - "value.1": "開啓" - } -} diff --git a/src/locales/zh_TW/command-ui-handler.json b/src/locales/zh_TW/command-ui-handler.json deleted file mode 100644 index 224835addaf..00000000000 --- a/src/locales/zh_TW/command-ui-handler.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "fight": "戰鬥", - "ball": "精靈球", - "pokemon": "寶可夢", - "run": "逃跑", - "actionMessage": "要讓\n{{pokemonName}} 做甚麼?" -} \ No newline at end of file diff --git a/src/locales/zh_TW/common.json b/src/locales/zh_TW/common.json deleted file mode 100644 index 8b0f91802ee..00000000000 --- a/src/locales/zh_TW/common.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "start": "開始", - "luckIndicator": "幸運:", - "shinyOnHover": "閃光", - "commonShiny": "常見", - "rareShiny": "稀有", - "epicShiny": "史詩" -} diff --git a/src/locales/zh_TW/config.ts b/src/locales/zh_TW/config.ts deleted file mode 100644 index cf505d683a5..00000000000 --- a/src/locales/zh_TW/config.ts +++ /dev/null @@ -1,113 +0,0 @@ -import common from "./common.json"; -import settings from "./settings.json"; -import ability from "./ability.json"; -import abilityTriggers from "./ability-trigger.json"; -import arenaFlyout from "./arena-flyout.json"; -import arenaTag from "./arena-tag.json"; -import achv from "./achv.json"; -import battle from "./battle.json"; -import battleScene from "./battle-scene.json"; -import battleInfo from "./battle-info.json"; -import battleMessageUiHandler from "./battle-message-ui-handler.json"; -import battlerTags from "./battler-tags.json"; -import berry from "./berry.json"; -import bgmName from "./bgm-name.json"; -import biome from "./biome.json"; -import challenges from "./challenges.json"; -import commandUiHandler from "./command-ui-handler.json"; -import dialogue from "./dialogue.json"; -import battleSpecDialogue from "./dialogue-final-boss.json"; -import miscDialogue from "./dialogue-misc.json"; -import doubleBattleDialogue from "./dialogue-double-battle.json"; -import egg from "./egg.json"; -import fightUiHandler from "./fight-ui-handler.json"; -import filterBar from "./filter-bar.json"; -import gameMode from "./game-mode.json"; -import gameStatsUiHandler from "./game-stats-ui-handler.json"; -import growth from "./growth.json"; -import menu from "./menu.json"; -import menuUiHandler from "./menu-ui-handler.json"; -import modifier from "./modifier.json"; -import modifierType from "./modifier-type.json"; -import move from "./move.json"; -import nature from "./nature.json"; -import partyUiHandler from "./party-ui-handler.json"; -import pokeball from "./pokeball.json"; -import pokemon from "./pokemon.json"; -import pokemonForm from "./pokemon-form.json"; -import battlePokemonForm from "./pokemon-form-battle.json"; -import pokemonInfo from "./pokemon-info.json"; -import pokemonInfoContainer from "./pokemon-info-container.json"; -import pokemonSummary from "./pokemon-summary.json"; -import saveSlotSelectUiHandler from "./save-slot-select-ui-handler.json"; -import splashMessages from "./splash-messages.json"; -import starterSelectUiHandler from "./starter-select-ui-handler.json"; -import statusEffect from "./status-effect.json"; -import trainerTitles from "./trainer-titles.json"; -import trainerClasses from "./trainer-classes.json"; -import trainerNames from "./trainer-names.json"; -import tutorial from "./tutorial.json"; -import voucher from "./voucher.json"; -import weather from "./weather.json"; -import terrain from "./terrain.json"; -import modifierSelectUiHandler from "./modifier-select-ui-handler.json"; -import moveTriggers from "./move-trigger.json"; -import runHistory from "./run-history.json"; - -export const zhTwConfig = { - ability, - abilityTriggers, - arenaFlyout, - arenaTag, - battle, - battleScene, - battleInfo, - battleMessageUiHandler, - battlePokemonForm, - battlerTags, - berry, - bgmName, - biome, - challenges, - commandUiHandler, - common, - achv, - dialogue, - battleSpecDialogue, - miscDialogue, - doubleBattleDialogue, - egg, - fightUiHandler, - filterBar, - gameMode, - gameStatsUiHandler, - growth, - menu, - menuUiHandler, - modifier, - modifierType, - move, - nature, - pokeball, - pokemon, - pokemonForm, - pokemonInfo, - pokemonInfoContainer, - pokemonSummary, - saveSlotSelectUiHandler, - settings, - splashMessages, - starterSelectUiHandler, - statusEffect, - terrain, - titles: trainerTitles, - trainerClasses, - trainerNames, - tutorial, - voucher, - weather, - partyUiHandler, - modifierSelectUiHandler, - moveTriggers, - runHistory, -}; diff --git a/src/locales/zh_TW/dialogue-double-battle.json b/src/locales/zh_TW/dialogue-double-battle.json deleted file mode 100644 index 612bf3d4490..00000000000 --- a/src/locales/zh_TW/dialogue-double-battle.json +++ /dev/null @@ -1,82 +0,0 @@ -{ - "blue_red_double": { - "encounter": { - "1": "青綠:嘿,赤紅,\n讓這傢伙看看我們是什麼來頭!$赤紅:...$青綠: 見識下真新鎮的實力!" - }, - "victory": { - "1": "青綠:打得真不錯$赤紅: ..." - } - }, - "red_blue_double": { - "encounter": { - "1": "赤紅: ...!$青綠:他人狠話不多。$青綠: 他人狠話不多。$青綠: 但別被他耍了,\n畢竟他可是個冠軍!" - }, - "victory": { - "1": "赤紅: ...!$青綠: 下次我們一定會贏你!" - } - }, - "tate_liza_double": { - "encounter": { - "1": "小楓:嘿嘿嘿……你驚訝嗎?$小南:這裡有兩個道館館主?$小楓: 我們是雙胞胎!$小南:我們無需交談,因為……我們可以通曉彼此的想法$小楓: 我們的組合……$小南: 你能打敗嗎?" - }, - "victory": { - "1": "小楓:什麼?我們的組合……$小南:被瓦解了!" - } - }, - "liza_tate_double": { - "encounter": { - "1": "小南:呵呵呵……你驚訝吧?$小楓:這裡有兩個道館館主?$小南:我們可以通曉……$小楓:彼此的想法……$小南:全在我們腦中!$小楓:我們的組合……$小南:你能打敗嗎?" - }, - "victory": { - "1": "小楓:你和你的寶可夢……$小南:簡直像親兄弟姐妹!" - } - }, - "wallace_steven_double": { - "encounter": { - "1": "大吾:米可利, 展現冠軍的實力吧!$米可利:我們將展示豐緣的實力!$米可利:我們將展示豐緣的實力!$大吾:要上了!" - }, - "victory": { - "1": "大吾:打得真不錯!$米可利:我們下次會贏的!" - } - }, - "steven_wallace_double": { - "encounter": { - "1": "大吾:你有什麼稀有的寶可夢嗎?$米可利:大吾……我們是來對戰的,\n不是來炫耀寶可夢的。$大吾:哦……知道了… 那麼要上了!" - }, - "victory": { - "1": "大吾:戰鬥結束了,\n來看看我的稀有寶可夢!$米可利:大吾……" - } - }, - "alder_iris_double": { - "encounter": { - "1": "阿戴克:我們倆是合眾最強的訓練家!$艾莉絲:與最強來一場最激烈的戰鬥吧!" - }, - "victory": { - "1": "阿戴克:哇哦!你真是超級厲害!$艾莉絲:我們下次會贏的啦!" - } - }, - "iris_alder_double": { - "encounter": { - "1": "艾莉絲:歡迎!挑戰者,\n合眾地區最強的冠軍大駕光臨!$阿戴克:艾莉絲,你是不是有點太興奮了…" - }, - "victory": { - "1": "艾莉絲:這樣的失敗可不好受啊…$阿戴克:但是只有失敗才能讓我們變強!" - } - }, - "piers_marnie_double": { - "encounter": { - "1": "瑪俐:哥哥,給他們展現尖釘鎮的實力!$聶梓:我們帶來黑暗!" - }, - "victory": { - "1": "瑪俐:你的強光亮瞎我們的黑暗了啦……$聶梓:實在太亮了…" - } - }, - "marnie_piers_double": { - "encounter": { - "1": "聶梓: 台下準備好了嗎!$瑪俐: 哥哥,我們是來對戰的,\n不是來唱歌的……" - }, - "victory": { - "1": "聶梓:這首歌獻給大家!$瑪俐:哥哥……" - } - } -} diff --git a/src/locales/zh_TW/dialogue-final-boss.json b/src/locales/zh_TW/dialogue-final-boss.json deleted file mode 100644 index 13bfee9eb96..00000000000 --- a/src/locales/zh_TW/dialogue-final-boss.json +++ /dev/null @@ -1,5 +0,0 @@ -{ - "encounter": "看來終於又到了那個時候。\n你知道自己為何會來到這裡,不是嗎?\n$你被吸引到這裡,因為你以前就來過這裡。\n無數次。\n$儘管,或許可以數一數。\n準確地說,這實際上是你的第{{cycleCount}}次循環。\n$每一次循環,你的思想都會恢復到之前的狀態。\n即便如此,不知何故,你之前自我的殘留仍然存在。\n$直到現在,你仍未成功,但我感覺這次你身上有一種異樣的氣息。\n$你是這裡唯一的人,儘管感覺上還有……另一個人。\n$你最終會成為對我來的一個硬茬嗎?\n我渴望了數千年的挑戰?\n$我們,開始。", - "firstStageWin": "我明白了。我所感覺到的氣息確實是真實的。\n看來我不再需要保留實力了。\n$別讓我失望。", - "secondStageWin": "…漂亮。" -} \ No newline at end of file diff --git a/src/locales/zh_TW/dialogue-misc.json b/src/locales/zh_TW/dialogue-misc.json deleted file mode 100644 index 73771e96027..00000000000 --- a/src/locales/zh_TW/dialogue-misc.json +++ /dev/null @@ -1,4 +0,0 @@ -{ - "ending": "@c{shock}你回來了?@d{32} 也就是說…@d{96} 你贏了呀!?\n@c{smile_ehalf}我應該早料到了。\n$@c{smile_eclosed}當然…我一直有這種感覺\n@c{smile}一切都結束了,對麼? 你打破了循環。\n$@c{smile_ehalf}你也完成了自己的夢想,不是嗎?\n你甚至一次都沒失敗。\n$我是唯一能夠記得你所作所為的人\n@c{angry_mopen}我會努力不忘掉哒!\n$@c{smile_wave_wink}開玩笑啦,@d{64} @c{smile}我才不會忘呢。@d{32}\n你的傳奇將永遠留存於我們心中。\n$@c{smile_wave}不管了,@d{64} 時候不早了@d{96} ,應該吧?\n在這地方還真搞不清楚。\n$一起回家吧。 @c{smile_wave_wink}可能明天,我們再來打一場,為了重溫回憶嘛~", - "ending_female": "@c{smile}哦?你贏了?@d{96} @c{smile_eclosed}我應該早猜到了\n你回來了。\n$@c{smile}結束了。@d{64} 你終結了這個循環。\n$@c{serious_smile_fists}你也完成了自己的夢想,不是嗎?\n你甚至一次都沒失敗。\n$@c{neutral}我是唯一能夠記得你所作所為的人@d{96}\n我覺得這應該也還行吧?\n$@c{serious_smile_fists}你的傳奇將永遠留存於我們心中。\n$@c{smile_eclosed}不管了,我真是受夠這個地方了,你也一樣嗎?我們回家吧。\n$@c{serious_smile_fists}可能等我們回家以後,再打一場?\n要是你想的話" -} diff --git a/src/locales/zh_TW/dialogue.json b/src/locales/zh_TW/dialogue.json deleted file mode 100644 index 99427ac5f14..00000000000 --- a/src/locales/zh_TW/dialogue.json +++ /dev/null @@ -1,2546 +0,0 @@ -{ - "youngster": { - "encounter": { - "1": "嘿,想來對戰嗎?", - "2": "你也是新人訓練師嗎?", - "3": "嘿,我之前沒見過你。我們來對戰吧!", - "4": "我剛輸了,所以我正在尋找更多的寶可夢。$等等!你看起來很弱!\n來吧,我們對戰吧!", - "5": "我們見過面嗎?我記不太清了。$嗯,不管怎樣,很高興見到你!", - "6": "好的!我們上吧!", - "7": "好的!我來啦!我會向你展示我的實力!", - "8": "嚯嚯嚯...我會向你展示我的寶可夢有多厲害!", - "9": "不要浪費時間打招呼。你準備好了就放馬過來!", - "10": "別掉以輕心,$否則你可能會被小朋友打到哭鼻子哦。", - "11": "我精心培養了我的寶可夢。不許你傷害它們!", - "12": "恭喜你成功了!從這以後可不輕鬆哦。", - "13": "戰鬥永無止境!歡迎來到沒有盡頭的世界!" - }, - "victory": { - "1": "哇!你很強!", - "2": "我根本沒機會贏,對吧?", - "3": "我會等長大了再來打敗你!", - "4": "呃。我沒有更多寶可夢了。", - "5": "不可能…不可能!我怎麼可能又輸了…", - "6": "不!我輸了!", - "7": "哇!你真是太不可思議了!我既驚訝又欽佩!", - "8": "這怎麼…怎麼可能…$明明我和我的寶可夢是最強大的…", - "9": "下次我不會輸了!我們找時間再對戰吧!", - "10": "天哪!你看不出我還只是個小孩子嗎!$你那樣全力以赴太賴了!", - "11": "你的寶可夢更棒啊!和我交換吧!", - "12": "我之前有點上頭,我說了什麼來著?", - "13": "啊哈哈!就是這樣!$對!你已經熟悉這個世界了!" - } - }, - "lass": { - "encounter": { - "1": "我們來對戰吧,好嗎?", - "2": "你看起來像是個新人訓練師。我們來戰鬥吧!", - "3": "我不認識你。來對戰怎麼樣?", - "4": "讓我們來進行一場有趣的寶可夢對戰吧!", - "5": "我會向你展示如何真正使用寶可夢!", - "6": "一場認真的對戰從始於認真的開場白!$你確定你準備好了嗎?", - "7": "花無重開日,人無再少年。$你在對戰中只有一次機會。$很快,你就只能活在回憶中了。", - "8": "你最好對我手下留情,好嗎?$當然我會認真對戰的!", - "9": "學校很無聊,我無事可做。$*哈欠*…我只是來對戰打發時間。" - }, - "victory": { - "1": "那真是令人印象深刻!我還有很多要學習。", - "2": "我沒想到你會這麼輕易地打敗我…", - "3": "我希望有一天,我們能再進行一場對戰。", - "4": "那真是場非常有趣的對戰!$你讓我精疲力盡了…", - "5": "你給我上了一課!你真是太棒了!", - "6": "說真的,我輸了。$這,怎麼說,真的好難過,但你也真的很厲害。", - "7": "我不需要像這樣的記憶。刪除記憶中…", - "8": "嘿!我告訴過你要對我手下留情!$不過,當你認真的時候,你真的很酷。", - "9": "實際上,我開始厭倦對戰了…$一定有新的事情可以做…" - } - }, - "breeder": { - "encounter": { - "1": "聽話的寶可夢,自私的寶可夢…$寶可夢有獨特的性格呢。", - "2": "儘管我出生貧寒,但我的寶可夢培養的很好。", - "3": "嗯,你有沒有管教你的寶可夢?$過度溺愛是不好的。" - }, - "victory": { - "1": "對每個寶可夢因材施教是很重要的。", - "2": "不像一無是處的我…這些寶可夢都很優秀。", - "3": "過度的讚美會寵壞寶可夢和人。" - }, - "defeat": { - "1": "即使輸了,也不應該對你的寶可夢發火。", - "2": "相當好的寶可夢,對吧?我很會養東西。", - "3": "無論你多麼愛你的寶可夢,$你仍要在它沒做好時管教它們。" - } - }, - "breeder_female": { - "encounter": { - "1": "寶可夢永遠不會背叛你。$它們會回報你對它們的愛。", - "2": "要我教教你訓練優秀寶可夢的技巧嗎?", - "3": "特別的寶可夢有特別的培育技巧。" - }, - "victory": { - "1": "呃…事情不應該是這樣的。$我是不是用錯了能量方塊?", - "2": "這怎麼會發生在我的寶可夢身上…$你給你的寶可夢餵了什麼?", - "3": "如果我輸了,我告訴你我只是在消磨時間。$你根本不會傷害到我的自尊心。" - }, - "defeat": { - "1": "這證明了我的寶可夢已經接受了我的愛。", - "2": "訓出好寶可夢的真正技巧是捉到好的寶可夢。", - "3": "寶可夢的強弱取決於你的飼養方式。" - } - }, - "fisherman": { - "encounter": { - "1": "啊!你讓我錯過了一次咬鉤!$你打算怎麼辦?", - "2": "走開!你嚇跑了寶可夢!", - "3": "讓我看看你能否贏得勝利!" - }, - "victory": { - "1": "算了吧。", - "2": "下一次,我將捲土重來,凱旋而歸!", - "3": "我想這次我低估了海流。" - } - }, - "fisherman_female": { - "encounter": { - "1": "哇!我釣到了一條大魚!", - "2": "線已收好,準備提竿!", - "3": "準備製造波浪!" - }, - "victory": { - "1": "我會帶著更強大的魚鉤回來。", - "2": "下次我會贏得勝利。", - "3": "我只是在為回歸磨利我的魚鉤!" - } - }, - "swimmer": { - "encounter": { - "1": "是時候潛水了!", - "2": "讓我們一起乘風破浪,贏得勝利!", - "3": "該一鳴驚人了!" - }, - "victory": { - "1": "沉浸在失敗中!", - "2": "失敗的波浪!", - "3": "後浪死在沙灘上,我猜。" - } - }, - "backpacker": { - "encounter": { - "1": "收拾行李,開始遊戲!", - "2": "讓我看看你是否能跟上!", - "3": "全副武裝,挑戰者!", - "4": "我花了20年時間試圖找到自己……但我在哪裡?" - }, - "victory": { - "1": "這次絆倒了!", - "2": "哦,我覺得我迷路了。", - "3": "死路!", - "4": "等一下!嘿!你不知道我是誰嗎?" - } - }, - "ace_trainer": { - "encounter": { - "1": "你看起來挺自信的。", - "2": "你的寶可夢…… 讓我看看……", - "3": "因為我是王牌訓練師,人們認為我很強。", - "4": "你知道成為王牌訓練師需要什麼嗎?" - }, - "victory": { - "1": "是的…… 你的寶可夢很棒……", - "2": "什麼?!我是戰鬥天才啊!", - "3": "理所應當,你才是主角!", - "4": "好好好!你可以成為王牌訓練師!" - }, - "defeat": { - "1": "我將把我的身體和靈魂全都奉獻給寶可夢對戰!", - "2": "一切都在我的預料之中… \n沒有什麼好驚訝的…", - "3": "我覺得我長大後有點玻璃心,$你太壓力我我會垮的……", - "4": "我當然很強大,不會輸。$而且重要的是我要優雅地贏。" - } - }, - "parasol_lady": { - "encounter": { - "1": "是時候用優雅和從容來為戰鬥添彩了!" - }, - "victory": { - "1": "我的優雅依然完好無損!" - } - }, - "twins": { - "encounter": { - "1": "準備好囉,因為我們聯手,\n麻煩雙倍!", - "2": "兩顆心,一條繩$讓我們看看你能否跟上我們雙胞胎的力量!", - "3": "希望你準備好了面對雙倍的麻煩,$因為我們即將燃起來啦!" - }, - "victory": { - "1": "雖然我們在這一輪輸了,$但我們的羈絆依然堅不可摧!", - "2": "我們的雙胞胎精神,才不會就此熄滅。", - "3": "我們會作為充滿活力的二人組,$捲土重來,變得更強!" - }, - "defeat": { - "1": "雙胞胎的力量至高無上!", - "2": "兩顆心,一起贏!", - "3": "笑容成雙,共舞成雙!" - } - }, - "cyclist": { - "encounter": { - "1": "準備好在我後面吃土吧!", - "2": "挑戰者,準備好!我要把你打得落花流水!", - "3": "全速前進,讓我看看你能不能跟得上!" - }, - "victory": { - "1": "輪子可能不轉了,但我的決心沒有停下。", - "2": "被超越了!", - "3": "通往勝利的道路還有許多曲折等待探索。" - } - }, - "black_belt": { - "encounter": { - "1": "我讚揚你挑戰我的勇氣!$因為我是踢力最強的人!", - "2": "哦,我明白了。你想被切成碎片嗎?$或者你更喜歡當個沙袋?" - }, - "victory": { - "1": "哦。是寶可夢在戰鬥。$我強大的踢擊一點忙都沒幫上。", - "2": "嗯…如果我無論如何都會輸,我希望能被徹底打敗。" - } - }, - "battle_girl": { - "encounter": { - "1": "你不必試圖勾引我。你可以輸給我。" - }, - "victory": { - "1": "很難說再見,但我們快沒時間了……" - } - }, - "hiker": { - "encounter": { - "1": "人到中年後,我的身體和我爬過的山一樣強壯!", - "2": "我從父母那裡遺傳了這副魁梧的身材…$就像一座活生生的山脈…" - }, - "victory": { - "1": "至少在BMI方面我不能輸!", - "2": "這還不夠……永遠不夠。$我的壞膽固醇還不夠高……" - } - }, - "ranger": { - "encounter": { - "1": "當我身處大自然中,其他事情都不重要了。", - "2": "如果我生活中沒有大自然,有時就會突然感到焦慮。" - }, - "victory": { - "1": "無論我是贏是輸,\n對廣闊的大自然來說並不重要……", - "2": "與城市生活的窒息感相比,\n這種事情微不足道。" - }, - "defeat": { - "1": "我贏了。但與浩瀚的大自然相比,\n勝利算不了什麼…", - "2": "與我的焦慮症相比,我覺得你也不會怎樣…" - } - }, - "scientist": { - "encounter": { - "1": "我的研究將引導這個世界走向和平與歡樂。" - }, - "victory": { - "1": "我是個天才…我不應該輸給你這樣的人…" - } - }, - "school_kid": { - "encounter": { - "1": "……嘿嘿。我對計算和分析很有信心。", - "2": "我正在盡可能地積累經驗,$因為我希望有一天能成為道館館主。" - }, - "victory": { - "1": "哦…計算和分析也許和個例不太匹配呀…", - "2": "我想,即使是艱難困苦的經歷,也有存在的意義。" - } - }, - "artist": { - "encounter": { - "1": "我以前很受歡迎,但現在已經徹底過氣了。" - }, - "victory": { - "1": "隨著時代的變遷,價值觀也在變化。$我意識到這一點已經太晚了。" - } - }, - "guitarist": { - "encounter": { - "1": "當我彈奏著走向勝利的旋律時,$準備好感受失敗的節奏吧!" - }, - "victory": { - "1": "暫時沉默了,但我不屈的旋律將繼續演奏。" - } - }, - "worker": { - "encounter": { - "1": "人們總誤解我,這讓我很煩。$我比大家想象的要乾淨得多。" - }, - "victory": { - "1": "我真的不想曬傷皮膚,所以我想在陰涼處工作。" - } - }, - "worker_female": { - "encounter": { - "1": "人們總是誤解我,這讓我很煩。 $我比大家想象的要乾淨得多。" - }, - "victory": { - "1": "我真的不想曬傷皮膚,\n所以我想在陰涼處工作。" - }, - "defeat": { - "1": "我的身體和心靈並不總同步。" - } - }, - "worker_double": { - "encounter": { - "1": "你會知道我們怎麼擊敗你的。我們在工地訓練過!" - }, - "victory": { - "1": "真奇怪…怎麼會這樣…我不應該被打敗的。" - } - }, - "hex_maniac": { - "encounter": { - "1": "我通常只聽古典音樂,但如果我輸了,$我想我應該試試新時代的音樂!", - "2": "我的每一滴眼淚都讓我變得更加堅強。" - }, - "victory": { - "1": "樂壇新時代的曙光就此出現了嗎?", - "2": "現在我變得更強了。我隨著他人怨恨而成長。" - }, - "defeat": { - "1": "“新時代”指的是二十世紀的古典作曲家,對吧?", - "2": "不要糾結於悲傷或沮喪。$你可以用悲憤來激勵自己。" - } - }, - "psychic": { - "encounter": { - "1": "嘿!集中!" - }, - "victory": { - "1": "呃呃呃!" - } - }, - "officer": { - "encounter": { - "1": "準備好,因為正義即將得到伸張!", - "2": "準備好維護法律,在戰場上伸張正義!" - }, - "victory": { - "1": "正義的分量比以往還要沉重……", - "2": "失敗的陰影,在警局中徘徊。" - } - }, - "beauty": { - "encounter": { - "1": "我最後的戰鬥…我就是這麼看待這場對戰的…" - }, - "victory": { - "1": "很有趣…有時間再來一場最後的戰鬥…" - } - }, - "baker": { - "encounter": { - "1": "希望你準備好品嚐失敗的滋味!" - }, - "victory": { - "1": "我會捲土重來的。" - } - }, - "biker": { - "encounter": { - "1": "是時候加速,把你甩在後面了!" - }, - "victory": { - "1": "我會為下一場比賽調整狀態。" - } - }, - "firebreather": { - "encounter": { - "1": "我的火焰會吞噬你!", - "2": "我的靈魂在燃燒,我要讓你看看它有多滾燙!", - "3": "快來看看吧!" - }, - "victory": { - "1": "我燃成灰了…", - "2": "哟! 好燙!", - "3": "嗷! 我的鼻尖燒焦了!" - } - }, - "sailor": { - "encounter": { - "1": "夥計,如果你輸了,你就得挨板子!", - "2": "來吧!這關係到我作為水手的尊嚴!", - "3": "你好啊!你暈船麼?" - }, - "victory": { - "1": "啊,被孩子打敗了。", - "2": "你的精神讓我沉淪!", - "3": "好像是我暈船了…" - } - }, - "archer": { - "encounter": { - "1": "在你繼續前進之前,\n讓我看看你要如何和對付火箭隊。", - "2": "我收到報告說你的實力與衆不同,\n就讓我來看看這是否屬實吧。", - "3": "我是阿波羅,火箭對的幹部。\n我不會對組織的敵人手軟。" - }, - "victory": { - "1": "大失誤……", - "2": "以我現在的實力,無法勝任我的任務……", - "3": "原……諒我,坂木。\n我竟被一名訓練師打敗了。." - } - }, - "ariana": { - "encounter": { - "1": "站住!我們可不能放過你!$這會損傷火箭對的名譽,明白嗎?", - "2": "我不知道也不想知道我的所作所爲正確與否…$我只要遵從坂木老大的指令就可以了!", - "3": "你的旅途到此爲止了,我會把你狠狠扳倒!" - }, - "victory": { - "1": "切,你好強,可惡。$如果你加入火箭隊,肯定能成爲幹部。", - "2": "好……好崩潰……", - "3": "嗯啊啊!這不可能!我使出全力還是輸了!" - } - }, - "proton": { - "encounter": { - "1": "你想幹什麽?如果你要妨礙我們的事業,我可不會手下留情。", - "2": "你在這幹什麽?別人總說我是火箭隊裏最殘忍和恐怖的人…$我強烈推薦你別來礙我們的事!", - "3": "我是蘭斯,火箭隊的幹部。就讓來掃除你對我們的阻撓。" - }, - "victory": { - "1": "我的防線崩潰了……", - "2": "你雖然這次贏了,但是這只是讓火箭隊的怒火繼續燃燒!", - "3": "我輸了…但是我不會忘記的。" - } - }, - - "petrel": { - "encounter": { - "1": "哇哈哈哈,我們一直在等你。我?你不知道我是誰?是我,坂木啊。$偉大的坂木大人本人!哇哈哈哈!…啊?我聽起來不像坂木嗎?$我連看起來都不像?怎麽會呢,我可認真的變裝了!", - "2": "我是拉姆達,火箭隊的幹部。我不會允許你幹涉我們的計劃!", - "3": "火箭隊幹部拉姆達來會會這個入侵者!" - }, - "victory": { - "1": "好好好,我會說他在哪的", - "2": "我……我什麽也做不了……坂木,請原諒我……", - "3": "不,我不能慌了神,必須通知其他人…" - } - }, - "tabitha": { - "encounter": { - "1": "呵呵呵!原來你都一路來到這裏了!但你來晚了!", - "2": "呵呵呵……你終于來了?我們小瞧你了,沒不過事! $我比你見過的所有隊員都要厲害,我可不會拖延時間。$我會把你碾碎!", - "3": "我要讓你嘗嘗痛苦的滋味!認命吧!" - }, - "victory": { - "1": "呵呵呵!雖然你打敗了我,但你根本沒機會打敗老大!$如果你現在輸了,你就不用面對那樣嚴厲的鞭笞了!", - "2": "呵呵呵……所以,我也輸了……", - "3": "啊哈!怎麽會這樣?像我這樣的幹部\n竟然輸給了一個隨處可見的訓練師……" - } - }, - "courtney": { - "encounter": { - "1": "那個東西……你所擁有的那個東西……\n那就是……那就是我們熔岩隊所尋找的東西……", - "2": "……那麽……刪除記憶……", - "3": "……哈……分析中……啊哈♪" - }, - "victory": { - "1": "……改變……世界。", - "2": "如預期。出乎意料。目標鎖定…鎖定你……完成。$開始……實驗。材料是你…永遠…啊哈……♪", - "3": "……又來了?出乎意料……我就知道。你……很有趣!……啊哈哈!♪" - } - }, - "shelly": { - "encounter": { - "1": "啊哈哈哈哈!你要插手海洋隊的事?$你要麽是絕對無畏,要麽就是無知,或者兩者兼有!$你太可愛了,太惡心了!我要把你打倒!", - "2": "怎麽回事?這個小鬼頭是誰?", - "3": "冷靜點,耐心點。我很快就會把你擊潰。" - }, - "victory": { - "1": "啊哈哈哈哈!我們意外地被人幹擾了!我們別無選擇。$不得不撤退了,但這會不是你最後一次面對海洋隊!$我們還有其他計劃!別忘了!", - "2": "啊?!我是不是對你太溫柔了?!", - "3": "唉…難道在對戰中你也一刻不停地在變強嗎?$你真是個前途光明的小鬼……\n我和我的寶可夢已經沒有任何力量去戰鬥了……$繼續吧……准備去被水梧桐摧毀吧。" - } - }, - "matt": { - "encounter": { - "1": "嚯!哈哈哈!怎麽,你是不是腦子不正常了?\n看看你,像個幕下力士!", - "2": "“哦吼!你!你真是個有趣的孩子!", - "3": "你在這裏幹什麽?你跟蹤我們了嗎?" - }, - "victory": { - "1": "好吧,在老大有時間對付你之前,我來成爲你的對手!", - "2": "我能感覺到!我感覺到了,沒錯!你身上散發出的力量!$更多!還想要更多!但看起來我們沒時間了……", - "3": "真有趣!我就知道你會讓我盡興的!\n我期待有一天再次面對你!" - } - }, - "mars": { - "encounter": { - "1": "我是夥星,銀河隊的頂級幹部之一。", - "2": "銀河隊對未來的願景堅定不移。\n反對者將被無情地粉碎!", - "3": "“緊張嗎?你是該感到緊張了!" - }, - "victory": { - "1": "這不可能!我怎麽會輸?!", - "2": "你很有本事,我承認。", - "3": "輸了……犯了一個代價高昂的大錯。" - } - }, - "jupiter": { - "encounter": { - "1": "歲星,銀河隊幹部,爲您效勞。", - "2": "抵抗是徒勞的。銀河隊必將獲勝!", - "3": "你在發抖啊……已經害怕了嗎?" - }, - "victory": { - "1": "不會吧……我輸了?!", - "2": "厲害,你膽子真大!", - "3": "輸成這樣……真丟人。" - } - }, - "saturn": { - "encounter": { - "1": "我是鎮星,銀河隊的幹部。", - "2": "我們的使命是絕對的,任何阻礙都將被消滅!", - "3": "我從你的眼中看到的是恐懼嗎?" - }, - "victory": { - "1": "不可能……被你打敗了?!", - "2": "你證明了自己是一個值得尊敬的對手。", - "3": "失敗的苦澀……難以接受……。" - }}, - "zinzolin": { - "encounter": { - "1": "你可能會對等離子隊構成威脅,所以我們現在就消滅你!", - "2": "哦,天哪……我沒想到要在這麽冷的天氣裏戰鬥!", - "3": "能走到今天這一步,你真是個了不起的訓練師。\n但一切到此結束。" - }, - "victory": { - "1": "魁奇思大人……我讓你失望了……", - "2": "好冷,我不僅發抖,還要遭罪。", - "3": "哼。你比我想象的要聰明,但還不夠。" - } - }, - "rood": { - "encounter": { - "1": "你對等離子隊是個威脅。我們現在不能讓你離開這裏!", - "2": "哦,這寒風……我從沒想過我必須在這裏戰鬥!", - "3": "能走到今天這一步,你是一位了不起的訓練師,但這就是你的結局了。" - }, - "victory": { - "1": "魁奇思大人……我的任務失敗了", - "2": "寒風刺骨。我瑟瑟發抖。我痛苦不堪。", - "3": "嗯,你是很有才。但是要打敗等離子隊還不夠……!" - } - }, - "xerosic": { - "encounter": { - "1": "啊哈哈!我很樂意。\n來吧,小訓練師!讓我們看看你有什麽本事!", - "2": "嗯……你比看上去更強大。\n我想知道你體內有多少能量。", - "3": "我一直在等你!我需要對你做一點研究!\n來吧,我們開始吧!" - }, - "victory": { - "1": "啊,你好強大啊……嗯……確實非常強大。", - "2": "叮叮叮!你成功了!\n戰利品歸勝利者!", - "3": "太棒了!太神奇了!\n你的技巧和勇氣都無與倫比!" - } - }, - "bryony": { - "encounter": { - "1": "我是芭拉,能與你一戰是我的榮幸。\n讓我看看你的實力。", - "2": "令人印象深刻……你比你看上去的還要強大。\n讓我們看看你真正的實力。", - "3": "我預料到了你的到來。\n是時候進行一個小實驗了,我們開始吧?" - }, - "victory": { - "1": "你很強大。哦,嗯嗯!確實非常強大", - "2": "叮叮叮!你做得很好。勝利屬于你。", - "3": "太棒了!了不起!你的技巧和勇氣值得稱贊。" - } - }, - "rocket_grunt": { - "encounter": { - "1": "你要有麻煩了!", - "2": "我們要幹大事了!\n閃一邊去,小子!", - "3": "把你的寶可夢交過來,\n不然就嘗嘗火箭隊的厲害!", - "4": "你准備好感受火箭隊真正的恐怖了嗎!", - "5": "喂,小子!俺可是火箭隊滴!" - }, - "victory": { - "1": "好討厭的感覺啊!", - "2": "哎呀!不小心丟掉電梯鑰匙啦!", - "3": "我搞砸了。", - "4": "我的夥計們不會放過你……!", - "5": "你說啥?俺們火箭隊要玩完了?" - } - }, - "magma_grunt": { - "encounter": { - "1": "如果你擋在熔岩隊路上,那就別指望我們手下留情!", - "2": "你最好別妨礙我們的計劃!\n我們會讓世界變得更美好!", - "3": "少礙事!熔岩隊沒時間理你這樣的小孩!", - "4": "你有棉花糖沒?我來給你好好烤烤!", - "5": "我們會利用火山的力量!\n它馬上要…爆發了!懂嗎?嘿嘿嘿……" - }, - "victory": { - "1": "哈?我輸了?!", - "2": "我怎麽會輸!我爲了訓練飯都不吃了!", - "3": "不會吧,不就是一個小孩!", - "4": "唉啊…我得趕快逃回基地…", - "5": "你打敗我了…你覺得老大會扣我工資嗎?" - } - }, - "aqua_grunt": { - "encounter": { - "1": "即使是小孩,如果要和海洋隊作對,也別指望我們手下留情!", - "2": "嚯…你好大的膽子,敢惹我們海洋隊!", - "3": "不僅是我的水系寶可夢,整片大海即將淹沒你!", - "4": "我們海洋隊,是爲了大義!", - "5": "准備好被我的…唉…我寶可夢的海流沖走吧!" - }, - "victory": { - "1": "你在開玩笑吧?", - "2": "害,沒想到這種小屁孩也要管我的閑事!", - "3": "我輸了?看來我得自己遊回基地了。", - "4": "不是吧,怎麽會,老大要生氣了……", - "5": "你打敗了我…老大不會要讓我上跳板吧……" - } - }, - "galactic_grunt": { - "encounter": { - "1": "別惹銀河隊!", - "2": "見識下我們的科技,和我們所設想的未來!", - "3": "以銀河隊之名,我會掃清一切擋路的人!", - "4": "准備輸的一敗塗地吧!", - "5": "希望你做好被宇宙力量碾壓的准備。" - }, - "victory": { - "1": "停機了…", - "2": "從長遠來看,這次的挫折不用在意。", - "3": "小失敗不會影響我們的宏圖偉業!", - "4": "咋回事!?", - "5": "個人記錄:提升對戰水平,優先級,高……" - } - }, - "plasma_grunt": { - "encounter": { - "1": "異端不共戴天!", - "2": "要是我贏了你!就把你的寶可夢放生!", - "3": "要是敢和等離子隊作對,我來好好關照你!", - "4": "等離子隊會從你們這種自私的人手裏解放寶可夢!", - "5": "我們的發型帥的一批,而我們的戰鬥水平呢,\n馬上讓你見識一下。" - }, - "victory": { - "1": "等離子子子子子子!", - "2": "我怎麽會輸……", - "3": "…沒用的家夥!我得去偷個厲害點的寶可夢!", - "4": "偉大的事業總會被人阻撓…", - "5": "爛完了…爛爛爛爛爛!等離子隊爛了!\n說短點就是,等爛子隊!" - } - }, - "flare_grunt": { - "encounter": { - "1": "你的寶可夢無法與閃焰隊的優雅相提並論", - "2": "帶個墨鏡吧,別被我閃瞎狗眼了!", - "3": "閃焰隊將淨化這個不完美的世界!", - "4": "准備面對閃焰隊的美!", - "5": "時尚對我們來說最重要!" - }, - "victory": { - "1": "我的未來看起來並不明亮…", - "2": "這戰鬥比我想的更難搞,我得重頭訓練了。", - "3": "啊啊?我輸了?!", - "4": "就算是在失敗當中,閃焰隊依舊優雅動人!", - "5": "你雖然打敗了我,但是我輸的也這麽潇灑!" - } - }, - "rocket_boss_giovanni_1": { - "encounter": { - "1": "我不得不說,能來到這裏,你的確很不簡單!" - }, - "victory": { - "1": "什麽!這不可能!" - }, - "defeat": { - "1": "記住我的話。無法衡量自己的力量,說明你還是個孩子。" - } - }, - "rocket_boss_giovanni_2": { - "encounter": { - "1": "我的老夥計還需要我…你要擋我的路嗎?" - }, - "victory": { - "1": "這怎麽可能…?\n火箭隊的夢想…就這麽成爲泡影了…" - }, - "defeat": { - "1": "火箭隊會重生,而我會統治世界!" - } - }, - "magma_boss_maxie_1": { - "encounter": { - "1": "我會親手埋葬你,希望你能喜歡!" - }, - "victory": { - "1": "啊!你…很厲害…我落後了…一點…" - }, - "defeat": { - "1": "熔岩隊必勝!" - } - }, - "magma_boss_maxie_2": { - "encounter": { - "1": "你是我實現目標最後的障礙。\n准備好迎接我最強的一擊吧!哈哈哈哈!" - }, - "victory": { - "1": "這…這不…唉" - }, - "defeat": { - "1": "現在…我要把這個星球變成人類的理想國度!" - } - }, - "aqua_boss_archie_1": { - "encounter": { - "1": "我是海洋隊的老大,所以,你的路大概走到頭了。" - }, - "victory": { - "1": "下次再見吧。我會記住你的臉的。" - }, - "defeat": { - "1": "天才!我的隊伍不會再退縮了!" - } - }, - "aqua_boss_archie_2": { - "encounter": { - "1": "我等這一天很久了。\n這就是我的真實力量!" - }, - "victory": { - "1": "果然很強……啊!" - }, - "defeat": { - "1": "我會讓這世界上的一切回歸到最初的純淨狀態!!" - } - }, - "galactic_boss_cyrus_1": { - "encounter": { - "1": "但在這之前,讓我見識見識你那敢向銀河隊叫板的實力吧。" - }, - "victory": { - "1": "有意思,簡直太有意思了。" - }, - "defeat": { - "1": "我要創造我的新世界…" - } - }, - "galactic_boss_cyrus_2": { - "encounter": { - "1": "是啊,我和你還真是有緣呢。\n不過,這段孽緣…就讓我在此斬斷吧!" - }, - "victory": { - "1": "怎麽可能!怎麽可能!怎麽可能!" - }, - "defeat": { - "1": "永別了。" - } - }, - "plasma_boss_ghetsis_1": { - "encounter": { - "1": "無論是誰做了什麽!都無法阻止我!" - }, - "victory": { - "1": "怎麽回事?我可是建立了等離子隊的完美的人啊!\n是要改變世界的完美的統治者!" - }, - "defeat": { - "1": "我是坐擁世界的完美統治者!哇哈哈哈!" - } - }, - "plasma_boss_ghetsis_2": { - "encounter": { - "1": "來吧!讓我看看你徹底絕望時的那張臉!" - }, - "victory": { - "1": "不!我的偉大目標!我要完全支配世界啊!" - }, - "defeat": { - "1": "酋雷姆!融合吧!" - } - }, - "flare_boss_lysandre_1": { - "encounter": { - "1": "你想要阻止我?在對戰中展示給我看吧!" - }, - "victory": { - "1": "看來你的確是想要阻止我。但是,先等一下。" - }, - "defeat": { - "1": "寶可夢…不該存在。" - } - }, - "flare_boss_lysandre_2": { - "encounter": { - "1": "你我的未來…究竟哪個才正確,\n就讓我們來問問各自的寶可夢吧!" - }, - "victory": { - "1": "哇啊啊啊!" - }, - "defeat": { - "1": "沒有遠見的蠢貨會繼續玷汙這個美麗的世界。" - } - }, - "brock": { - "encounter": { - "1": "我對岩石屬性寶可夢的專精會擊敗你!來吧!", - "2": "我磐石般的意志將壓倒你!", - "3": "讓我展示給你看看,我寶可夢真正的力量!" - }, - "victory": { - "1": "你寶可夢的力量戰勝了我堅如磐石的防禦!", - "2": "世界很大!很高興有機會和你戰鬥。", - "3": "也許我應該回去追尋我成為寶可夢飼養員的夢想……" - }, - "defeat": { - "1": "最好的進攻就是堅固的防守!$那是我做事的方式!", - "2": "下次來和我一起研究岩石屬性,$更好地了解如何與它們對戰!", - "3": "哈哈,我在各地的旅行有所回報了!" - } - }, - "misty": { - "encounter": { - "1": "我的戰策就是使用水屬性寶可夢全面進攻!", - "2": "嗨,我會讓你見識我的水屬性寶可夢的力量!", - "3": "我的夢想是踏上旅程,與強大的訓練師戰鬥……$你能滿足我嗎?" - }, - "victory": { - "1": "你真的很強……我承認,你有技術的……", - "2": "哼……你知道你只是運氣好,對吧?!", - "3": "哇,你太過分了!不敢相信你打敗我了!" - }, - "defeat": { - "1": "強大的小霞對你來說,太過分了嗎?", - "2": "我希望你看到了我寶可夢優雅的游泳技巧!", - "3": "你的寶可夢無法匹敵我的心腹和驕傲!" - } - }, - "lt_surge": { - "encounter": { - "1": "我的電屬性寶可夢在戰爭中救了我!$我來給你展示一下!", - "2": "立正!我要電到你投降!", - "3": "我會像對待敵軍一樣,狠狠電你!" - }, - "victory": { - "1": "哇!你的隊伍有真傢伙,小子!", - "2": "啊啊,你很強!連我的電擊技巧都輸給了你。", - "3": "這失敗真是把我給電麻了!" - }, - "defeat": { - "1": "哦耶!我的電屬性寶可夢是世界第一!", - "2": "哈哈哈!真是一場電動人心的戰鬥,小子!", - "3": "寶可夢對戰等於戰爭,$我向你展示了軍隊中的格鬥技巧!" - } - }, - "erika": { - "encounter": { - "1": "啊,這裡天氣真好…$哦,對戰?那好吧。", - "2": "我在寶可夢對戰上的造詣,$可以與我的插花技巧相媲美。", - "3": "哦,希望我寶可夢的宜人香氣\n不會再讓我睡著…", - "4": "看看花園裡的花朵,如此令人心曠神怡。" - }, - "victory": { - "1": "哦!我認輸啦~", - "2": "這場比賽非常愉快。", - "3": "啊,看來我輸了…", - "4": "哦,我的天哪。" - }, - "defeat": { - "1": "我怕我會打瞌睡…", - "2": "哦,我天。看來我的草屬性寶可夢擊敗了你。", - "3": "那場戰鬥是如此令人心曠神怡。", - "4": "哦…這就完啦?" - } - }, - "janine": { - "encounter": { - "1": "我正在掌握毒屬性攻擊的藝術。$今天我來和你過過招!", - "2": "父親相信我能獨當一面。$我來證明他說的對!", - "3": "我的忍術,僅次於我的父親!$你能跟的上嗎?" - }, - "victory": { - "1": "就算現在,我仍然需要繼續訓練…我明白了。", - "2": "你的戰鬥技巧,超過了我。", - "3": "我要好好努力提高我的技術。" - }, - "defeat": { - "1": "呵呵…毒液耗盡了你所有的力量。", - "2": "哈!你根本無法抵擋我卓越的忍技!", - "3": "我沒有辜負父親對我的信任。" - } - }, - "sabrina": { - "encounter": { - "1": "我的超能力預見了你的到來!", - "2": "我不喜歡戰鬥,但如果你想,$我會展示我的實力!", - "3": "我能感覺到你的雄心壯志。$我倒要看看你是不是虛有其表。" - }, - "victory": { - "1": "你的力量……遠遠超出了我的預知……", - "2": "我沒有準確預測到你的實力。", - "3": "即使我強大的超能力也無法感知到你這樣強大的人。" - }, - "defeat": { - "1": "這場勝利……和我看到的未來一樣啊!", - "2": "也許我預感到有強大實力的人,是另一個……", - "3": "在你奮不顧身投入戰鬥之前,\n磨練你的能力。$如果你這樣做,你才未來可期……" - } - }, - "blaine": { - "encounter": { - "1": "哈!希望你帶了燒傷治療藥!", - "2": "我火熱的寶可夢將所有挑戰者都焚燒殆盡!", - "3": "準備好玩火吧!" - }, - "victory": { - "1": "我已經焚燒殆盡了!甚至連灰燼都沒有留下!", - "2": "我沒有把火焰煽得足夠高嗎?", - "3": "我燃盡了……但這讓我進步的動力燃燒得更旺了!" - }, - "defeat": { - "1": "我的熊熊烈火無法被撲滅!", - "2": "我的寶可夢因這次勝利而變得更加強大!", - "3": "哈!我的激情燃得比你的更熱烈!" - } - }, - "giovanni": { - "encounter": { - "1": "我,火箭隊的領袖,\n會讓你的世界感受到痛苦!", - "2": "我在這裡的訓練在我再次面對老朋友之前至關重要。", - "3": "我認為你還沒有準備好迎接你即將經歷的失敗!" - }, - "victory": { - "1": "什麼!我輸了?! 我沒什麼可和你說的!", - "2": "哼……你永遠無法理解我希望實現的目標。", - "3": "這次失敗只是暫時的。$我將找準時機,讓火箭隊浴火重生。" - }, - "defeat": { - "1": "不知自己幾斤幾兩,\n說明你仍然只是一個孩子。", - "2": "不要再試圖干涉我。", - "3": "我希望你明白挑戰我是多麼愚蠢。" - } - }, - "roxanne": { - "encounter": { - "1": "您能否展示一下您是如何戰鬥的麼?", - "2": "你可以和更多訓練師戰鬥來學到很多東西。", - "3": "哦,被你抓到我正在用功了~$你想戰鬥嗎?" - }, - "victory": { - "1": "哦,看來我輸了。$我明白了。", - "2": "看來我在戰鬥方面還有更多東西要學。", - "3": "我會把今天在這裡學到的東西銘記於心。" - }, - "defeat": { - "1": "從我們的對戰中,我學到了很多。$希望你也是。", - "2": "我期待再次與你戰鬥。$希望你能運用在此學到的東西。", - "3": "我憑借我所學到的一切贏得了勝利。" - } - }, - "brawly": { - "encounter": { - "1": "哦,夥計,挑戰者!$讓我看看你的能耐!", - "2": "你看起來很厲害嘛。$來對戰吧!", - "3": "是時候掀起風暴了!$我們上吧!" - }, - "victory": { - "1": "哦哇,你把我沖走了!", - "2": "你駕馭了我的海浪,把我打敗了!", - "3": "我覺得我就像是在武鬥洞窟裡迷路了!" - }, - "defeat": { - "1": "哈哈,我駕馭了大浪!$有時間再挑戰我吧。", - "2": "再和我一起衝浪吧!", - "3": "就像潮水的漲落,\n我希望你也能再來挑戰我。" - } - }, - "wattson": { - "encounter": { - "1": "是時候被電擊了!$哈哈哈!", - "2": "我要讓火星子飛蹦!$哈哈哈!", - "3": "我希望你帶了麻痺藥!$哇哈哈哈!" - }, - "victory": { - "1": "看來我的電量用完了!$哇哈哈哈!", - "2": "你完全接地了是吧!$哇哈哈哈!", - "3": "謝謝你給我電了一下!$哇哈哈哈!" - }, - "defeat": { - "1": "電充充滿,有時間再挑戰我吧!$哇哈哈哈!", - "2": "我希望你覺得我們的戰鬥激情似電!$哇哈哈哈!", - "3": "你沒想到我贏了吧?$哇哈哈哈!" - } - }, - "flannery": { - "encounter": { - "1": "很高興見到你!等等,不對……$我要粉碎你!", - "2": "我才當道館主沒多久,\n但我會讓你灰飛煙滅!", - "3": "是時候展示爺爺教給我的招式了!來對戰吧!" - }, - "victory": { - "1": "你讓我想起了我的爺爺……$難怪我輸了。", - "2": "我是不是太努力了?$我應該放鬆,不能太上頭了。", - "3": "失敗才不會嗆到我。$是時候重新點燃訓練了!" - }, - "defeat": { - "1": "我希望我讓祖父感到驕傲了……$有時間我們再戰鬥吧。", - "2": "我……我簡直不敢相信我贏了!$按照自己的方式做事奏效了!", - "3": "早點用炙熱的招式再來交手吧!" - } - }, - "norman": { - "encounter": { - "1": "我沒想到你能一路來到這裡。$我們來對戰吧。", - "2": "作為道館主,我會盡一切努力贏得勝利。$我們開始吧!", - "3": "你最好全力以赴。$對戰的時候到了!" - }, - "victory": { - "1": "我輸給了你……?$但規則就是規則。", - "2": "難道我不該從城都搬家嗎……?", - "3": "我不敢相信。$這是一場好對戰。" - }, - "defeat": { - "1": "我們都盡力了。$希望我們不久之後能再對戰。", - "2": "你應該嘗試挑戰我的孩子。$可能會有一些收穫!", - "3": "謝謝你精彩的戰鬥。$下次好運。" - } - }, - "winona": { - "encounter": { - "1": "我一直在天空中翱翔尋找獵物…$而你就是我的目標!", - "2": "不管戰況如何,我都會和我的飛行寶可夢$以優雅的姿態獲勝。來戰鬥吧!", - "3": "我希望你不怕高。$我們一起升上高空吧!" - }, - "victory": { - "1": "你是我見過的第一位比我更有風度的訓練師。$打的非常出色。", - "2": "哦,我的飛行系寶可夢都已經墜落了!$好吧。", - "3": "儘管我倒下了,我的寶可夢將繼續翱翔!" - }, - "defeat": { - "1": "我與我的飛行系寶可夢,\n將永遠優雅地起舞!", - "2": "我希望你喜歡我們的演出。$我們優雅的舞蹈已經落幕。", - "3": "你願意再來觀看我們優雅的編舞嗎?" - } - }, - "tate": { - "encounter": { - "1": "嘿嘿嘿…$看到我沒和妹妹在一起,很驚訝麼?", - "2": "我可以讀懂你在想什麼…$你想要戰鬥!", - "3": "你如何擊敗一個…$讀懂你一舉一動的人?" - }, - "victory": { - "1": "贏不了啊…$我想小南了…", - "2": "你和寶可夢之間的聯繫比我們更強。", - "3": "如果我和小南聯手,我們會贏的。$我們可以了解彼此的想法!" - }, - "defeat": { - "1": "我和我的寶可夢無與倫比!", - "2": "如果你連我都打不過,\n你肯定也打不過小南。", - "3": "這多虧了我和小南的嚴格訓練。$我可以與寶可夢一心同體。" - } - }, - "liza": { - "encounter": { - "1": "呵呵呵…$看到我沒和哥哥一起,很驚訝嗎?", - "2": "我可以讀懂你渴望什麼…$你想戰鬥,不是嗎?", - "3": "你如何擊敗一個…$與寶可夢們一心同體的人?" - }, - "victory": { - "1": "贏不了啊…$我想小楓了…", - "2": "你和寶可夢之間的聯繫…$比我強。", - "3": "如果我和小楓在一起,我們會贏的。$我們甚至可以接上彼此的話!" - }, - "defeat": { - "1": "我和我的寶可夢勢不可擋。", - "2": "如果你連我都打不過,\n你肯定也打不過小楓。", - "3": "這多虧了我和小楓的嚴格訓練。$我可以與我的寶可夢一心同體。" - } - }, - "juan": { - "encounter": { - "1": "別害羞啊。$我們來戰鬥吧!", - "2": "啊哈哈哈,敬請期待\n我和水屬性寶可夢的盛大演出!", - "3": "我就是正在逼近的風暴!$你能經受住考驗嗎?", - "4": "請你見證我們的表演。$由我和寶可夢共同創造的宏偉水之幻境!" - }, - "victory": { - "1": "你可能是一個能挑戰米可利的天才!", - "2": "我專注於優雅,而你刻苦鍛鍊。$你能擊敗我是很正常的。", - "3": "啊哈哈哈!$好吧,這次你贏了。", - "4": "從你身上,我感受到了技巧的光輝,\n它將戰勝一切。" - }, - "defeat": { - "1": "寶可夢和我創造的水之幻境,讓我取得了勝利。", - "2": "啊哈哈哈,我贏了,你輸了。", - "3": "要我把我的服裝借給你嗎?\n可能能幫到你對戰啊!$啊哈哈哈,我開玩笑的!", - "4": "我是贏家!也就是說,你輸了。" - } - }, - "crasher_wake": { - "encounter": { - "1": "極限! 極限! 看好了!$極限假面…就此…登場!", - "2": "極限! 極限! 極限假面!", - "3": "我是滔滔巨浪,將你沖走!" - }, - "victory": { - "1": "我真是笑得合不攏嘴啊!$哈哈哈!那真是太有趣了!", - "2": "呼哇!結束收尾了!$我該怎麼說呢……$我還想再對戰!我還想再繼續戰鬥!", - "3": "啊啊啊啊啊!?" - }, - "defeat": { - "1": "耶!就是這樣!", - "2": "我贏了,但我還想要更多!\n我還想再更多地戰鬥!", - "3": "再見!" - } - }, - "falkner": { - "encounter": { - "1": "我將向你展示華麗的飛行寶可夢真正的力量!", - "2": "風啊,伴我同行!", - "3": "爸爸!我希望你能在空中注視著我的戰鬥!" - }, - "victory": { - "1": "明白了……我會禮貌地退場。", - "2": "輸了就是輸了。你確實很強大。", - "3": "…行吧! 嗯, 我輸了。" - }, - "defeat": { - "1": "爸爸!我用你珍愛的飛行寶可夢贏了……", - "2": "飛行系寶可夢才是最強的!", - "3": "感覺我正在追趕上我的父親!" - } - }, - "nessa": { - "encounter": { - "1": "無論你的小腦瓜子在搞什麼陰謀詭計,$我和我的搭檔都會確保它石沉大海。", - "2": "我來這裡可不是為了閒聊,\n而是為了贏!", - "3": "這是我的寶可夢給你的一點小禮物……\n我希望你能接受!" - }, - "victory": { - "1": "你和你的寶可夢太過分了……", - "2": "怎麼……?這怎麼可能?!", - "3": "我完全被沖走了!" - }, - "defeat": { - "1": "洶湧的海浪再次襲來!", - "2": "是時候乘風破浪,取得勝利了!", - "3": "誒嘿嘿!" - } - }, - "melony": { - "encounter": { - "1": "我不會手下留情!", - "2": "好吧,我想我們應該開始了。", - "3": "我會把你凍得結結實實的!" - }, - "victory": { - "1": "你……你可厲害了,是不是?", - "2": "如果你找到瑪瓜,一定要好好教訓他,好嗎?", - "3": "你的破冰方式有點過於直接了呢……" - }, - "defeat": { - "1": "現在你知道戰鬥有多殘酷了吧?", - "2": "嘿!看來我又贏了!", - "3": "你是在保留實力嗎?" - } - }, - "marlon": { - "encounter": { - "1": "你看起來很強!來吧!讓我們開始吧!", - "2": "我的強大像大海一樣無邊無際。$你會被我沖走,絕對的。", - "3": "哦豁,由我來面對你!這可不得了咯!" - }, - "victory": { - "1": "你太厲害了!\n你培養了一些非常強大的寶可夢啊,$你已經掌握了訓練師的精髓!", - "2": "你不僅僅是看起來,\n你是真的強,真的!$呃,我也被沖走了!", - "3": "你像兇猛的波浪一樣強壯!" - }, - "defeat": { - "1": "你很強,但這還不足以動搖大海,懂?", - "2": "嘻!看來我又贏了!", - "3": "甜蜜的勝利!" - } - }, - "shauntal": { - "encounter": { - "1": "打擾了。你是挑戰者,對嗎?$我是四天王的幽靈系寶可夢使用者,$婉龍,我將是你的對手。", - "2": "我非常喜歡描寫來到這裡的訓練師,\n以及他們訓練的寶可夢。$我可以用你和你的寶可夢作為主題嗎?", - "3": "每個與寶可夢相處的人都有故事要講。$接下來要講的故事是怎樣的呢?" - }, - "victory": { - "1": "哇。我驚呆了!", - "2": "對…對不起!我必須先向我的寶可夢道歉……$都是因為我讓你們有了不好的經歷,真的很抱歉!", - "3": "你要知道,我仍然是四天王之一!" - }, - "defeat": { - "1": "額呵呵。", - "2": "給了我下一部小說的絕佳素材!", - "3": "就這樣,又一篇故事來到尾聲……" - } - }, - "marshal": { - "encounter": { - "1": "我的師傅,阿戴克,\n看到了你作為訓練師的潛力,$對你很有興趣。$我要來考驗你——挖掘你力量的極限。\n丹田發力!", - "2": "勝利,決定性的勝利,\n正是我所求!挑戰者,我來了!", - "3": "在我的心中,我尋求著成為戰士的力量,\n克服自身的所有弱點!$以我的信念,取勝!" - }, - "victory": { - "1": "呼!幹得好!", - "2": "不要停止戰鬥,追求更高的目標!", - "3": "你和你寶可夢展現的力量\n給我留下了深刻的印象……" - }, - "defeat": { - "1": "嗯…", - "2": "這真是場好戰鬥。", - "3": "哈啊!哈啊!嗨呀啊!" - } - }, - "cheren": { - "encounter": { - "1": "你讓我想起了一位老朋友。$這讓我對這場寶可夢戰鬥感到興奮!", - "2": "不考慮清楚這一點,\n寶可夢對戰就沒有了意義。$這就是失去了和寶可夢一同戰鬥的意義。", - "3": "我的名字是黑連!我是道館館主,\n也是老師!$很高興認識你。" - }, - "victory": { - "1": "謝謝……我又能發現自己的不足了。", - "2": "謝謝…接近理想的道路…我好像隱約看到了。", - "3": "嗯……這值得思考。" - }, - "defeat": { - "1": "作為道館館主,我要成為你要跨越的壁壘!", - "2": "好吧!", - "3": "正因為有寶可夢,我們才能走到這裡。$為什麼寶可夢會幫助我們,\n這個恐怕不僅是寶可夢與訓練家…$而是生命與生命之間的問題。" - } - }, - "chili": { - "encounter": { - "1": "咿呀!是時候玩火了!!我是三兄弟中最強的!", - "2": "嗒噠!如火似焰的伯特——就是我\n——你接下來的對手!", - "3": "我將向你展示,\n我和我熾熱的火系寶可夢的能耐!" - }, - "victory": { - "1": "被你幹掉了。我……燃盡了……", - "2": "哇吼!你燃起來了!", - "3": "啊!被你幹碎了!" - }, - "defeat": { - "1": "我燃起來啦!和我玩兒,你就會被燙傷!", - "2": "你要是玩兒火,就會被燙傷!", - "3": "我說,拜託,\n你的對手是我,沒機會贏的!" - } - }, - "cilan": { - "encounter": { - "1": "無關個人情感…也不會有艱難的感受…$我和我的草屬性寶可夢會…$呃…不管什麼樣的對手我們都會應戰的。", - "2": "所以,呃,如果你願意的話,我會,\n呃,盡我所能做好,呃,你知道的,你的對手。", - "3": "好吧……所以,我是天桐,\n我喜歡草屬性寶可夢。" - }, - "victory": { - "1": "呃……已經結束了嗎?", - "2": "…真是太意外了。你真…強。$看起來就算是伯特或寇恩都贏不了你…", - "3": "…嗯。看起來我來的…不是時候?" - }, - "defeat": { - "1": "哈?我贏了?", - "2": "我想…$我想我贏了,因為我一直在和我的兄弟伯特和寇恩競爭,\n我們都變得更強了。", - "3": "…這…這是一次非常嚇人的經歷呢…" - } - }, - "roark": { - "encounter": { - "1": "我需要看看你作為訓練師的潛力。$還有,我要看看與你並肩作戰的寶可夢的堅韌!", - "2": "來吧!這些是我的岩石系寶可夢,我的驕傲!", - "3": "岩石屬性寶可夢就是最強的!", - "4": "我要看看你作為訓練師的潛力。$還要看看與你並肩作戰的寶可夢的堅韌!" - }, - "victory": { - "1": "什麼?不可能!我強化的寶可夢們!", - "2": "……我大腦過載了。$下次邀請你參加地下的化石挖掘比賽。", - "3": "有你這種技術,贏得勝利是很正常的。", - "4": "什麼?!連這也不夠?", - "5": "我搞砸了。" - }, - "defeat": { - "1": "看?我為我的搖滾戰鬥風格感到驕傲!", - "2": "謝謝!這場戰鬥給了我自信,$我感覺能夠打敗我父親了!", - "3": "我感覺就像我砸穿了一塊頑石!" - } - }, - "morty": { - "encounter": { - "1": "只要我再多努力一點,我就能看到我遇到傳說中的寶可夢的未來!$你會幫助我達到那個水平!", - "2": "據說,彩虹色的寶可夢會\n出現在真正強大的訓練師面前。 $我一直相信著這個美麗的傳說,\n所以,從出生開始,\n就在這裡進行著秘密的修行。$因為這樣,其他人看不到的東西\n我也能夠看得到…$我看到的,是那個將傳說中的寶可夢\n召喚到這片大地上的人的影子。$我一直相信,那就是我自己!\n希望你也能助我一臂之力!", - "3": "無論你相信還是不相信,神秘的力量確實存在。", - "4": "你可以見證我訓練的成果。", - "5": "你必須讓你與寶可夢的靈魂合二為一。你能做到嗎?", - "6": "嘿,你想成為我訓練的一部分嗎?" - }, - "victory": { - "1": "我還不夠好……", - "2": "我明白了…你的旅程…去了遙遠的地方,你見過的比我多得多。$我羨慕你…", - "3": "這怎麼可能……", - "4": "我認為我們的潛力沒什麼不同。$但是,我覺得你並不簡單,似乎還有什麼……", - "5": "我想我需要更多的訓練。", - "6": "那太遺憾了" - }, - "defeat": { - "1": "我又向前邁進了一步。", - "2": "呵呵呵……", - "3": "什…麼?!那還不夠?", - "4": "我感覺就像我砸穿了一塊頑石!", - "5": "哈哈哈啊!", - "6": "我知道我會贏!" - } - }, - "crispin": { - "encounter": { - "1": "我想贏,所以接下來我正要贏!", - "2": "我想對戰就對戰!懂嗎!就應該這樣!" - }, - "victory": { - "1": "我想贏……但我還是輸了!", - "2": "我輸了……因為我贏不了!" - }, - "defeat": { - "1": "嘿,等一下。我是不是贏了?$我覺得我贏了!太滿足了!", - "2": "哇哦!那太棒了!" - } - }, - "amarys": { - "encounter": { - "1": "我想幫助某個人。因此,我不能輸。$…我們的戰鬥現在開始。" - }, - "victory": { - "1": "我還不夠,我明白了。" - }, - "defeat": { - "1": "勝利屬於我。打得好。" - } - }, - "lacey": { - "encounter": { - "1": "我將用我平時的隊伍\n作為四天王的一員面對你。" - }, - "victory": { - "1": "打得真好呀~" - }, - "defeat": { - "1": "讓我們為你寶可夢的努力給予熱烈的掌聲!" - } - }, - "drayton": { - "encounter": { - "1": "哥們,我喜歡椅子。\n你喜歡椅子嗎?簡直是救星。$我不明白為什麼大家不一直坐著。\n站著多累人!" - }, - "victory": { - "1": "我早該想到的!" - }, - "defeat": { - "1": "嘿嘿嘿!別介意我,\n我只是在這裡小贏一下。$如果你不開心,我懂,\n但別因為我對烏栗發火,OK?" - } - }, - "ramos": { - "encounter": { - "1": "我用那些強壯的植物\n蓋出來的遊樂場精彩嗎?$它們的力量象徵著我這個園丁兼道館館主的實力,\n你真的確定能夠與之抗衡嗎?" - }, - "victory": { - "1": "你信任你的寶可夢,\n它們也信任你…不錯的戰鬥,小豆芽。" - }, - "defeat": { - "1": "呵呵呵…確實,\n脆弱的小草甚至能穿透混凝土。" - } - }, - "viola": { - "encounter": { - "1": "敗陣時的後悔,勝利的瞬間…$都是最棒的影象!很好呀,很好呀!$那麼來吧!", - "2": "我的鏡頭總會聚焦在勝利上,\n我不會讓任何事情破壞這個畫面!" - }, - "victory": { - "1": "你和你的寶可夢向我展示了一個全新的鏡頭機位!\n很好呀,很好呀!", - "2": "你通過鏡頭看到的世界,\n和你與寶可夢並肩作戰時看到的世界…$視角不同,即使是同一個世界看起來也完全不同。" - }, - "defeat": { - "1": "我勝利那一刻的照片,\n將是一個真正的贏家,對吧!", - "2": "是的!我拍了些很棒的照片!" - } - }, - "candice": { - "encounter": { - "1": "向小菘我挑戰嗎?好啊!\n我就是在等待強者$但是我也氣勢高昂,很強哦?", - "2": "寶可夢也好,時尚也好,戀愛也好,\n無論做什麼都氣勢高昂!$就說到這兒吧,讓你見識一下我的氣勢,\n要做好覺悟哦!" - }, - "victory": { - "1": "好厲害!我有點尊敬你了。", - "2": "好厲害!我有點尊敬你了!$嗯,感覺是被你的氣勢給壓倒了。" - }, - "defeat": { - "1": "你的氣勢我看到了,但我還是不會輸的!", - "2": "怎麼樣?小菘我的氣勢!\n寶可夢們的氣勢滿滿哦!" - } - }, - "gardenia": { - "encounter": { - "1": "你身上有一種勝利的氣息。\n那麼不管怎樣,$這應該會是場有趣的戰鬥。\n讓我們對戰吧!" - }, - "victory": { - "1": "太棒了!你可擅長對戰了,不是嗎?" - }, - "defeat": { - "1": "太好了!我的寶可夢和我都很棒!" - } - }, - "aaron": { - "encounter": { - "1": "好的!讓我來接受你的挑戰!" - }, - "victory": { - "1": "戰鬥是一件深刻而複雜的事情……" - }, - "defeat": { - "1": "戰勝一位四天王並不容易。" - } - }, - "cress": { - "encounter": { - "1": "沒!錯!你必須面對\n與我和我高貴的水屬性的戰鬥!" - }, - "victory": { - "1": "輸了?我?我不敢相信。" - }, - "defeat": { - "1": "當你的對手是我時,這是必然的結果。" - } - }, - "allister": { - "encounter": { - "1": "我是歐尼奧。$我…我來了……" - }, - "victory": { - "1": "我差點被嚇得丟了面具…那真是…$哇。我可以看清你真正的實力。" - }, - "defeat": { - "1": "這真是太棒了!" - } - }, - "clay": { - "encounter": { - "1": "咳咳! 讓我好等,不是嗎,孩子?$好吧,是時候看看你能做到什麼了!" - }, - "victory": { - "1": "真是的……我先說好,\n我可沒有手下留情。" - }, - "defeat": { - "1": "最重要的是輸掉的時候該怎麼辦。$只要你能在失敗中找到教訓,\n就能夠不斷地成長!" - } - }, - "kofu": { - "encounter": { - "1": "我會給你上一整道水系寶可夢大餐!\n但別真吃了它們!" - }, - "victory": { - "1": "吃了嗎!你真是活力又新鮮啊,\n不是嗎!$就是有點太鮮活了!" - }, - "defeat": { - "1": "你要再來找我,聽見了嗎?" - } - }, - "tulip": { - "encounter": { - "1": "請讓我運用我的化妝技巧,$讓你可愛的小寶可夢變得更美麗!" - }, - "victory": { - "1": "你妝點的力量宛如魔法加固,\n完全沖洗不掉啊。" - }, - "defeat": { - "1": "你知道嗎,在我這行,\n那些沒天賦的人往往會很快消失,$再也不會被提起。" - } - }, - "sidney": { - "encounter": { - "1": "你給我的印象不錯,\n我猜這會是一場精彩的對戰。$很棒!看起來真的很棒!$你和我,讓我們享受一場\n只能在這裡上演的戰鬥吧!" - }, - "victory": { - "1": "嗯,你覺得怎樣?我輸了!\n嗯,不過這很有趣,所以無所謂啊。" - }, - "defeat": { - "1": "別介意,OK?" - } - }, - "phoebe": { - "encounter": { - "1": "過去我在修行時得到了\n能與幽靈寶可夢親密交流的能力。$沒錯,我和寶可夢之間\n有著強烈的羈絆。$那麼,來試試看你有沒有能力\n傷到我的寶可夢吧!" - }, - "victory": { - "1": "哦,天呀。我輸了。" - }, - "defeat": { - "1": "我期待著下次再和你戰鬥!" - } - }, - "glacia": { - "encounter": { - "1": "我在這兒見到的盡是些\n弱不禁風的訓練家和寶可夢。$你又如何呢?如果你能讓我不得不用\n上全力的話就再好不過了!" - }, - "victory": { - "1": "你和你的寶可夢…\n你們的靈魂燃燒得多麼熱烈啊!$這股激烈的熱能仿佛能征服一切。\n$難怪我的冰屬性技巧也奈何不了你了。" - }, - "defeat": { - "1": "一場充滿激情的戰鬥,確實。" - } - }, - "drake": { - "encounter": { - "1": "對於我們這些將寶可夢視為\n同伴一同戰鬥的訓練家來說,$你知道怎樣才能贏得勝利嗎?\n你知道獲得勝利的條件嗎?$如果你不知道,\n那麼你永遠也無法戰勝我!" - }, - "victory": { - "1": "幹得漂亮,就是這樣。" - }, - "defeat": { - "1": "我在這場戰鬥中全力以赴了!" - } - }, - "wallace": { - "encounter": { - "1": "你的氣質變了,\n我能感覺到這一點。$現在,把你和你的寶可夢\n的力量展現給我看吧。$作為回禮,就由我和我的寶可夢\n演出一場水之幻影吧!" - }, - "victory": { - "1": "精彩。此刻,我能從你身上感覺到\n身為寶可夢訓練家的可靠與高貴。$我真榮幸能遇到你和你的寶可夢。" - }, - "defeat": { - "1": "偉大的幻影!" - } - }, - "lorelei": { - "encounter": { - "1": "只要能讓我用冰屬性寶可夢,\n就絕對沒人能贏得過我!\n能凍住對方可是很厲害的哦!$因為如果被凍住,你的寶可夢就無法動彈了!\n啊哈哈!你做好覺悟了吧!" - }, - "victory": { - "1": "你怎麼敢!" - }, - "defeat": { - "1": "一旦你被凍結,你就什麼都做不了。" - } - }, - "will": { - "encounter": { - "1": "我曾經環遊世界,\n日以繼夜地做著超能力寶可夢的修行之旅。$我會不斷變強!沒理由會在這裡輸掉!" - }, - "victory": { - "1": "……不會吧……" - }, - "defeat": { - "1": "就差一點。\n我想知道你缺少了什麼。" - } - }, - "malva": { - "encounter": { - "1": "我的內心可是一直燃燒著呢。$燃燒著對你的怒火!" - }, - "victory": { - "1": "挑戰者出色地擊敗了四天王之一,帕琦拉。" - }, - "defeat": { - "1": "真開心啊,能將你徹底粉碎!" - } - }, - "hala": { - "encounter": { - "1": "老哈拉讓你放開嗓子!" - }, - "victory": { - "1": "我能感受到你在旅途中所獲得的力量。" - }, - "defeat": { - "1": "啊哈哈。多麼有趣的戰鬥。" - } - }, - "molayne": { - "encounter": { - "1": "我將隊長的位置讓給了我的表弟馬瑪內,\n但我對自己的能力很有信心。 $我的力量就像超新星一樣!" - }, - "victory": { - "1": "我發現了一個有趣的訓練師對手!" - }, - "defeat": { - "1": "啊哈哈。多麼有趣的戰鬥。" - } - }, - "rika": { - "encounter": { - "1": "我要對你手下留情,但……騙你的啦! $好好動腦!" - }, - "victory": { - "1": "不錯,小子。" - }, - "defeat": { - "1": "啊哈哈哈哈!你真的很特别,小子!" - } - }, - "bruno": { - "encounter": { - "1": "我們將用勢不可擋的力量磨滅你!呼哈!" - }, - "victory": { - "1": "為什麼?我怎麼會輸?" - }, - "defeat": { - "1": "你可以隨意挑戰我,\n但結果永遠不會改變!" - } - }, - "bugsy": { - "encounter": { - "1": "我是阿筆!\n對蟲系寶可夢的熟悉不會輸給任何人的!" - }, - "victory": { - "1": "哇,太棒了!\n你是個寶可夢專家!$我的研究還沒有完成。\n好吧,你贏了。" - }, - "defeat": { - "1": "謝謝!多虧了我們的戰鬥,\n我的研究也取得了進展!" - } - }, - "koga": { - "encounter": { - "1": "哇哈哈哈哈!$寶可夢不僅僅是關於蠻力,拭目以待吧!" - }, - "victory": { - "1": "啊!你證明了自己!" - }, - "defeat": { - "1": "懂不懂要對忍者的技巧心神畏懼?" - } - }, - "bertha": { - "encounter": { - "1": "啊,讓老婆婆看看你學到了什麼?" - }, - "victory": { - "1": "好吧,親愛的孩子,\n不得不說,那令人印象深刻。$你的寶可夢相信你並盡最大努力為你贏得勝利。$儘管我輸了,\n我也止不住笑呢!" - }, - "defeat": { - "1": "哈哈哈!看來老婆婆我贏了!" - } - }, - "lenora": { - "encounter": { - "1": "那麼,挑戰者,讓我來研究$你與你精心養育的寶可夢要如何戰鬥!" - }, - "victory": { - "1": "我關於你的理論是正確的。$你不僅僅是有天賦……你很努力!\n我向你致敬!" - }, - "defeat": { - "1": "啊哈哈!如果你輸了,\n一定要分析原因,$並在下一場戰鬥中運用那些知識!" - } - }, - "siebold": { - "encounter": { - "1": "只要我活著,我將不斷努力尋求終極美食…$以及和最強的對手戰鬥!" - }, - "victory": { - "1": "您的事蹟,我志米銘記在心。" - }, - "defeat": { - "1": "我們的寶可夢戰鬥就像我靈魂的養料。\n它將讓我繼續前進。$這就是我將向你表示敬意的方式,\n感謝你在戰鬥中全力以赴!" - } - }, - "roxie": { - "encounter": { - "1": "準備好了嗎!我要給你上一課!" - }, - "victory": { - "1": "夠野的!你的想法比我的還要毒!" - }, - "defeat": { - "1": "嘿,拜託!認真點!\n你要加把勁啊!" - } - }, - "olivia": { - "encounter": { - "1": "沒什麼開場白。\n是時候和我麗姿,戰鬥了!" - }, - "victory": { - "1": "真的很可愛……你和你的寶可夢……" - }, - "defeat": { - "1": "嗯哼。" - } - }, - "poppy": { - "encounter": { - "1": "哦!你想和我進行寶可夢對戰麼?" - }, - "victory": { - "1": "嗚哇?!嘛……" - }, - "defeat": { - "1": "耶!我做到了!我擊~敗~了~你!\n你可以來…打…復仇之戰?$只要你想,隨時來打復仇之戰吧!" - } - }, - "agatha": { - "encounter": { - "1": "寶可夢是用來戰鬥的!我會讓你看看真正訓練家的戰鬥!" - }, - "victory": { - "1": "哦,我的天!你真是個特別的孩子!" - }, - "defeat": { - "1": "哈哈哈,這才是正確的戰鬥方式!" - } - }, - "flint": { - "encounter": { - "1": "希望你已經熱身完畢,\n因為這裡即將大爆炸!" - }, - "victory": { - "1": "不可思議!$你的動作如此火熱,讓我看起來溫吞吞的!" - }, - "defeat": { - "1": "嗯?就這嗎?\n我覺得你得再激情點。" - } - }, - "grimsley": { - "encounter": { - "1": "一無所有,\n或者,贏下所有!" - }, - "victory": { - "1": "一旦失敗,\n就意味著失去一切……$下一次我要追尋勝利!" - }, - "defeat": { - "1": "如果有人贏了,\n和他對戰的人就會輸。" - } - }, - "caitlin": { - "encounter": { - "1": "當花兒綻開時、我便出現。\n成為你在等待的人…$你似乎同時具備實力和善意$我所尋找的是擁有卓越力量的對手…$請用出你的全力吧!" - }, - "victory": { - "1": "我和我的寶可夢學到了很多!非常感謝。" - }, - "defeat": { - "1": "我渴望以優雅的姿態取得勝利。" - } - }, - "diantha": { - "encounter": { - "1": "與你的寶可夢對戰\n讓你充滿了未來的希望…$說真的,這讓我更有活力地面對新的一天,確實如此!" - }, - "victory": { - "1": "擁有高尚靈魂的訓練家和寶可夢的身姿,\n讓我的心激烈地震顫…" - }, - "defeat": { - "1": "哦,太棒了!你覺得怎麼樣?\n我的隊伍很酷吧~對吧?" - } - }, - "wikstrom": { - "encounter": { - "1": "年輕的挑戰者,幸會!\n我乃是著名的鋼鐵之刃,公爵雁鎧! $讓我們開始戰鬥吧!預備!" - }, - "victory": { - "1": "輝煌!你與你尊貴的\n寶可夢之間的信任居然勝過了我!" - }, - "defeat": { - "1": "哦哦哦!這是怎麼回事,\n我的心止不住地在震顫! $與如此有價值的對手的勝利\n讓我的靈魂飛翔——我心翱翔!" - } - }, - "acerola": { - "encounter": { - "1": "對戰只是找個樂子!來吧,我來會會你!" - }, - "victory": { - "1": "我……我說不出話!你是怎麼做到的?!" - }, - "defeat": { - "1": "哈哈!真是嚇人倒怪的勝利呀!" - } - }, - "larry_elite": { - "encounter": { - "1": "……你好,我是青木。$麻煩的是我還要兼任四天王。" - }, - "victory": { - "1": "好吧,我們翅膀下的疾風止於你這了啊…" - }, - "defeat": { - "1": "是時候和老闆開會了。" - } - }, - "lance": { - "encounter": { - "1": "我一直在等你。讓我來試試你有幾斤幾兩。", - "2": "我知道你能走這麼遠。讓我們開始吧。" - }, - "victory": { - "1": "被你拿下了啊。你太出色了!", - "2": "我從沒想到會有另一個訓練師打敗我……$我很驚訝。" - }, - "defeat": { - "1": "就差一點。想再試一次嗎?", - "2": "我沒覺得你弱,別因此困擾。" - } - }, - "karen": { - "encounter": { - "1": "我是梨花,你想和我的惡屬性寶可夢$來一場對決嗎?", - "2": "我和你見過的那些人不一樣。", - "3": "你組建了一支迷人的隊伍。$我們的戰鬥應該會是場精彩的比賽。" - }, - "victory": { - "1": "不!我贏不了。你是怎麼做到變得這麼強的?", - "2": "我不會偏離我所選擇的道路。", - "3": "冠軍正期待與你見面。" - }, - "defeat": { - "1": "意料之中。", - "2": "嗯,還算有點意思。", - "3": "隨時歡迎你來找我。" - } - }, - "milo": { - "encounter": { - "1": "看起來你顯然很了解寶可夢。$這會是一場激烈的戰鬥!$如果我想贏,我得讓我的寶可夢極巨化!" - }, - "victory": { - "1": "草的力量凋謝了…多麼不可思議的挑戰者!" - }, - "defeat": { - "1": "這必將讓你大吃一驚。" - } - }, - "lucian": { - "encounter": { - "1": "請稍等,我正在讀的書\n正要進入最精彩的部分…$英雄獲得了一把神秘之劍,\n即將面臨最後的考驗…啊,算了。$既然你能走到這一步,\n我就不說這些了,和你戰鬥吧。$讓我看看你是否\n能像我書中的主角一樣榮耀!" - }, - "victory": { - "1": "我明白了…看來你把我逼入了絕境。" - }, - "defeat": { - "1": "我得維護我的名譽。" - } - }, - "drasna": { - "encounter": { - "1": "你很厲害吧,\n而且相當相當地厲害呢。$我很高興,能和這樣的對手交手,\n就能更好地培養寶可夢們了。" - }, - "victory": { - "1": "哎呀,就這麼結束了,\n不好意思,可以的話歡迎再來。" - }, - "defeat": { - "1": "怎麼會這樣?" - } - }, - "kahili": { - "encounter": { - "1": "那麼,既然來了……\n要不來看看今天的風更青睞誰?$是你……還是我?" - }, - "victory": { - "1": "讓我這個四天王都感到沮喪,$看來你的力量貨真價實。" - }, - "defeat": { - "1": "那真是一記好球!" - } - }, - "hassel": { - "encounter": { - "1": "讓你親身感受一下什麼叫做猛烈的對戰氣息吧!" - }, - "victory": { - "1": "這次幸運之神對我微笑了,但是……$誰知道我下次會不會這麼幸運。" - }, - "defeat": { - "1": "那可真厲害!" - } - }, - "blue": { - "encounter": { - "1": "能走到這裡,你一定非常優秀。" - }, - "victory": { - "1": "我只輸給過他,現在又是你……?$你問他是誰?哈哈哈……" - }, - "defeat": { - "1": "看吧?我的實力就是我來到這裡的原因。" - } - }, - "piers": { - "encounter": { - "1": "準備好和我的隊伍來個大狂歡吧!$尖釘鎮,是時候嗨起來了!" - }, - "victory": { - "1": "我和我的隊伍已經盡力了。$找個時間再來對戰吧……" - }, - "defeat": { - "1": "我的喉嚨因為呼喊而變得沙啞……$但這是一場激動人心的戰鬥!" - } - }, - "red": { - "encounter": { - "1": "…!" - }, - "victory": { - "1": "…?" - }, - "defeat": { - "1": "…!" - } - }, - "jasmine": { - "encounter": { - "1": "哦……你的寶可夢給人印象深刻。$我想我會享受這場戰鬥的。" - }, - "victory": { - "1": "你真的很強。我也得加把勁了。" - }, - "defeat": { - "1": "我從沒想到會贏。" - } - }, - "lance_champion": { - "encounter": { - "1": "我依舊是冠軍,所以我不會留情的。" - }, - "victory": { - "1": "這就是新冠軍的崛起。" - }, - "defeat": { - "1": "我成功捍衛了冠軍的頭銜。" - } - }, - "steven": { - "encounter": { - "1": "告訴我…你在和寶可夢的旅途過程中看到了什麼?$邂逅了那麼多的訓練師,\n你都會有什麼樣的感受呢?$在這豐饒的大地上旅行…\n有沒有喚醒你內在的某種東西?$你不如就用一場對戰來告訴我你心中的答案吧。$我也會和我的寶可夢用這種方式\n將我們所知道的告訴你的!" - }, - "victory": { - "1": "沒想到連我這個聯盟冠軍\n都敗在你的手上了呢…" - }, - "defeat": { - "1": "正如我所期待的。謝謝!" - } - }, - "cynthia": { - "encounter": { - "1": "我,竹蘭,接受你的挑戰!\n我是絕不會手軟的!" - }, - "victory": { - "1": "無論對戰多麼有趣,\n它總會有結束的時候……" - }, - "defeat": { - "1": "即使你輸了,\n也永遠不要失去你對寶可夢的熱愛。" - } - }, - "iris": { - "encounter": { - "1": "你知道嗎?\n我真的很期待和強大的訓練師進行認真的戰鬥!$我的意思是,來吧!\n到達這裡的是那些渴望勝利的訓練師,$他們與經歷過無數艱難\n戰鬥的寶可夢一起戰鬥!$如果我和那樣的人戰鬥,\n不僅我會變得更強,我的寶可夢也會!$我們也會更好地了解彼此!\n好!做好準備吧!$我是艾莉絲,寶可夢聯盟冠軍,\n我,將打敗你!" - }, - "victory": { - "1": "啊……我盡力了,但我們輸了……" - }, - "defeat": { - "1": "耶!我們贏了!" - } - }, - "hau": { - "encounter": { - "1": "我想知道,訓練師是否會根據他們是\n來自溫暖地區還是寒冷地區而以不同的方式戰鬥。$讓我們來測試一下!" - }, - "victory": { - "1": "那太棒了!我覺得我現在有點了解你的感覺了!" - }, - "defeat": { - "1": "老鐵,這才叫戰鬥!" - } - }, - "geeta": { - "encounter": { - "1": "我決定再試一次。$來吧…讓我看看你的訓練成果。" - }, - "victory": { - "1": "我期待著你的成就!" - }, - "defeat": { - "1": "怎麼,這就結束了?" - } - }, - "nemona": { - "encounter": { - "1": "耶!我太興奮了!讓我們稍微放輕鬆!" - }, - "victory": { - "1": "好吧,太糟了,但我還是玩得很開心!$下次我一定會贏你!" - }, - "defeat": { - "1": "好吧,那是一場很棒的戰鬥!$肯定是會有收穫的啦。" - } - }, - "leon": { - "encounter": { - "1": "來享受一段冠軍時刻吧!" - }, - "victory": { - "1": "我的冠軍生涯結束了……但這是多麼美好的冠軍時刻啊!但這是多麼美好的冠軍時刻啊!謝謝你給了我最精彩的一戰!" - }, - "defeat": { - "1": "名副其實的冠軍時刻!" - } - }, - "whitney": { - "encounter": { - "1": "嘿!你不認為寶可夢超級可愛嗎?" - }, - "victory": { - "1": "哇啊!哇啊!你太壞了!" - }, - "defeat": { - "1": "就是這樣!" - } - }, - "chuck": { - "encounter": { - "1": "哈!你想挑戰我?你是勇敢還是無知?" - }, - "victory": { - "1": "你很強!能不能收我為徒?" - }, - "defeat": { - "1": "搞定。你明白我比你強得多了嗎?" - } - }, - "katy": { - "encounter": { - "1": "不要放鬆警惕,除非你想被蟲絲絆倒哦!" - }, - "victory": { - "1": "我可愛的寶可夢們都像蒼蠅一樣墜落了!" - }, - "defeat": { - "1": "開飯啦,我可愛的彩粉蝶!" - } - }, - "pryce": { - "encounter": { - "1": "年輕不代表能獲得勝利!經驗才是關鍵。" - }, - "victory": { - "1": "無與倫比!贏得完美,試著不要忘記你現在的感受。" - }, - "defeat": { - "1": "正如我所料。" - } - }, - "clair": { - "encounter": { - "1": "你知道我是誰嗎?知道還敢挑戰我?" - }, - "victory": { - "1": "我想知道以你現在的水平能走多遠,有趣。" - }, - "defeat": { - "1": "就是這樣。" - } - }, - "maylene": { - "encounter": { - "1": "我現在要挑戰你,我不會保留任何實力。$請準備好戰鬥!" - }, - "victory": { - "1": "是我輸了…" - }, - "defeat": { - "1": "太棒了。" - } - }, - "fantina": { - "encounter": { - "1": "你來挑戰吧。我會勝利。$這就是家緣市的道館館主。" - }, - "victory": { - "1": "你是最強的,我認輸了。" - }, - "defeat": { - "1": "我非常,非常高興!" - } - }, - "byron": { - "encounter": { - "1": "和我兒子瓢太一樣的年輕人啊!$我相信培養年輕人\n關係到寶可夢光明的未來!$為此就讓我來成為\n年輕人必須跨越的堡壘吧!" - }, - "victory": { - "1": "唔!我千錘百煉的寶可夢!" - }, - "defeat": { - "1": "哈哈哈哈!怎麼樣!我千錘百煉的寶可夢!" - } - }, - "olympia": { - "encounter": { - "1": "戰鬥是決定命運的古老傳統。讓我們開始吧!" - }, - "victory": { - "1": "創造你自己的道路。$不要讓任何東西阻擋你的路、你的命運、你的未來。" - }, - "defeat": { - "1": "我們的道路現在已經清晰了。" - } - }, - "volkner": { - "encounter": { - "1": "能留到最後的訓練家想必肯定是很強的…$希望你會是能讓我回憶起\n寶可夢對戰樂趣的訓練家!" - }, - "victory": { - "1": "我輸了…$你的心意,寶可夢的不顧一切。$戰鬥的時候就讓我熱血沸騰。" - }, - "defeat": { - "1": "完全沒感覺…$和我希望的完全不一樣!" - } - }, - "burgh": { - "encounter": { - "1": "唔…我有預感,\n只要贏了這場戰鬥就能畫出更好的畫來…$嗯!戰鬥充滿了幻象!那麼,馬上開始吧。", - "2": "當然,我對我所有的寶可夢都相當驕傲! $現在…讓我們馬上開始吧!" - }, - "victory": { - "1": "結束了嗎?我的女神拋棄我了嗎?", - "2": "啊唔,輸了……你還真是很強啊。" - }, - "defeat": { - "1": "唔啊……好……好美啊!", - "2": "偶爾也有一些不是很好看的勝利,$但只要努力了,\n不管怎麼樣的戰鬥,都是很美麗的。" - } - }, - "elesa": { - "encounter": { - "1": "最後一擊!\n在確信這一點的時候全身會流淌過電流!$為追求這個快感,\n我要用可愛的寶可夢們讓你頭暈眼花。" - }, - "victory": { - "1": "本想讓你頭暈的,\n結果我倒反被你電到了。" - }, - "defeat": { - "1": "感覺還不夠啊……下次能使出全力來嗎?" - } - }, - "skyla": { - "encounter": { - "1": "終於到決戰了!\n這是決定頂點的寶可夢對戰吧?$我最喜歡頂點了!\n在高的地方能看到很遠很遠!$好了!就讓我和你好好地玩一場吧!" - }, - "victory": { - "1": "和你的戰鬥讓我更強了……謝謝。" - }, - "defeat": { - "1": "不管是贏了還是輸了,戰鬥都能得到一些東西。" - } - }, - "brycen": { - "encounter": { - "1": "有其他的人和寶可夢在一起,$這份支持會讓自己更強…\n讓我來給你展示一下這樣的強大吧!" - }, - "victory": { - "1": "你和你的寶可夢!配合得天衣無縫!\n華麗的友情!" - }, - "defeat": { - "1": "嘗試極限!鍛鍊!" - } - }, - "drayden": { - "encounter": { - "1": "現在我尋求的是\n能讓我看到光明未來的年輕訓練家。$你有多少實力,就讓我用我的經驗,\n我對寶可夢傾注的愛來驗證吧!" - }, - "victory": { - "1": "失敗後湧現的這灼熱的意志…\n該怎麼說呢…" - }, - "defeat": { - "1": "啊啊啊!你的實力就這種程度嗎!" - } - }, - "grant": { - "encounter": { - "1": "我只期待一件事。. $通過超越彼此,\n我們找到通往更高境界的道路。" - }, - "victory": { - "1": "你是一堵我無法逾越的牆!" - }, - "defeat": { - "1": "不要放棄。\n這就是人生的真諦。$大道至簡。" - } - }, - "korrina": { - "encounter": { - "1": "小女子科爾尼來大顯身手啦!" - }, - "victory": { - "1": "正因為有你,\n才能讓你的寶可夢進化!" - }, - "defeat": { - "1": "好勁爆的戰鬥呀!" - } - }, - "clemont": { - "encounter": { - "1": "哦!我很高興我們能見面!" - }, - "victory": { - "1": "你對戰鬥的熱情激勵了我!" - }, - "defeat": { - "1": "看來我的訓練師成長強化機-馬克2號,\n真的起作用了!" - } - }, - "valerie": { - "encounter": { - "1": "哦,這不是一個年輕的訓練師嗎……\n能這樣遇見你真是太好了。 $我想你已經獲得了這場戰鬥的資格,\n作為對你努力的獎勵。 $難以捉摸的妖精可能看起來像微風一樣脆弱,\n像花朵一樣精緻,但很堅強。" - }, - "victory": { - "1": "我希望明天你也能找到一些值得會心微笑的事物……" - }, - "defeat": { - "1": "哦,天哪,這太遺憾了……" - } - }, - "wulfric": { - "encounter": { - "1": "你知道嗎?\n我們都說戰鬥能學到東西,羈絆之類的,$但實際上,我這麼做只是因為有趣。 $誰在乎那些華而不實的東西?\n我們來戰鬥吧!" - }, - "victory": { - "1": "傑出!我像冰山一樣堅硬,但你徹底擊潰了我!" - }, - "defeat": { - "1": "和我幹的結果就是這樣!" - } - }, - "kabu": { - "encounter": { - "1": "每個訓練師和寶可夢都在努力追求勝利。$但這意味著你的對手也在努力贏得勝利。$最終,比賽是由哪一方\n能夠發揮出他們真正的潛力來決定的。" - }, - "victory": { - "1": "我很高興今天能和你戰鬥!" - }, - "defeat": { - "1": "這是我感覺自己的成長的好方式!" - } - }, - "bea": { - "encounter": { - "1": "你有沒有一種不可動搖的精神,\n受到什麼攻擊都安如磐石? $就讓我來試試吧?" - }, - "victory": { - "1": "我感受到了你的寶可夢\n在戰鬥中被你指揮時的戰鬥之魂。" - }, - "defeat": { - "1": "每個人都希望能有一場這樣的好比賽。" - } - }, - "opal": { - "encounter": { - "1": "讓我看看你和你的寶可夢的表現如何!" - }, - "victory": { - "1": "你不夠粉嫩呀,\n但你是一個優秀的訓練師,$還擁有著優秀的寶可夢。" - }, - "defeat": { - "1": "對你來說太慘了,我覺得。" - } - }, - "bede": { - "encounter": { - "1": "就讓我來證明你有多可憐,我有多強大。" - }, - "victory": { - "1": "我懂了……好吧。其實我還沒拿出全力呢。" - }, - "defeat": { - "1": "我覺得我打得不錯。" - } - }, - "gordie": { - "encounter": { - "1": "好了,我們來做個了結吧!" - }, - "victory": { - "1": "我只想要挖一個洞爬進去……$好吧,現在更像是掉了進去。" - }, - "defeat": { - "1": "像往常一樣戰鬥,勝利就會隨之而來!" - } - }, - "marnie": { - "encounter": { - "1": "事實上,言而總之… \n人家自己也想當冠軍呀! $所以別認為我在針對你!" - }, - "victory": { - "1": "好吧,我還是輸了……\n但是我看到了很多你和你寶可夢的優點哦" - }, - "defeat": { - "1": "希望你喜歡我們的戰鬥策略。" - } - }, - "raihan": { - "encounter": { - "1": "我打算擊敗冠軍,贏得錦標賽,\n並向世界證明奇巴納大人有多強!" - }, - "victory": { - "1": "就算輸了我也好帥。$真是罪孽深重啊。$看來得再來張自拍了!" - }, - "defeat": { - "1": "為了紀念此刻,來張自拍吧!" - } - }, - "brassius": { - "encounter": { - "1": "你應該準備好了吧,\n一起完成這美麗的藝術作品吧!" - }, - "victory": { - "1": "啊……前衛!" - }, - "defeat": { - "1": "我將立即開始新的創作!" - } - }, - "iono": { - "encounter": { - "1": "誰在奇述!是我奇樹!\n做好準備了嗎!$...$直播開始!\n今天的小挑戰者有多強?$奇樹不知道哦~\n讓我們一起來看看吧!" - }, - "victory": { - "1": "你的閃耀如1000萬伏特!朋友!" - }, - "defeat": { - "1": "奇樹奇樹捕獲你的眼球!" - } - }, - "larry": { - "encounter": { - "1": "歸根結底,普普通通就是最強。" - }, - "victory": { - "1": "哼,給我上了一道“戰敗”。" - }, - "defeat": { - "1": "下班打卡,走了" - } - }, - "ryme": { - "encounter": { - "1": "寶貝, 一起! \n搖滾搖到骨子裡!" - }, - "victory": { - "1": "你好酷!我佩服!\n我的靈魂為你哭!" - }, - "defeat": { - "1": "再會, 寶貝!" - } - }, - "grusha": { - "encounter": { - "1": "我保證我寶可夢的力量\n會讓你感到寒冷徹骨!" - }, - "victory": { - "1": "你燃燒的熱情……老實說,我有點喜歡。" - }, - "defeat": { - "1": "你沒有升溫。" - } - }, - "marnie_elite": { - "encounter": { - "1": "你已經走到這一步了?$哼~ 看看你能不能對付我的寶可夢!", - "2": "我將全力以赴, 別覺得我會手下留情哦~" - }, - "victory": { - "1": "不敢相信…我輸掉了… $但是你確實贏得好,幹得漂亮捏~", - "2": "看來我還要多多學習呀,\n不過你打得很不錯哦~" - }, - "defeat": { - "1": "你打得不錯,但是我更勝一籌!$祝你下次好運啦~", - "2": "看來我的練習有所回報了。\n感謝一戰!" - } - }, - "nessa_elite": { - "encounter": { - "1": "海流正在朝著對我有利的方向轉變。$準備好被捲走了嗎?", - "2": "讓我們在這場戰鬥中掀起波瀾!$我希望你做好準備!" - }, - "victory": { - "1": "你完美地渡過了這片水域......幹得好!", - "2": "看來我現在無法與你匹敵。幹得好!" - }, - "defeat": { - "1": "水總能找到出路。\n真是爽快的一戰!", - "2": "你打得很好,\n但海洋的力量是不可阻擋的!" - } - }, - "bea_elite": { - "encounter": { - "1": "做好準備!我的鬥志熊熊燃燒!", - "2": "讓我們看看你是否能跟上我永不停歇的節奏!" - }, - "victory": { - "1": "你的實力......令人印象深刻。\n你真的值得這場勝利。", - "2": "我以前從未感受過這種強度。\n太棒了!" - }, - "defeat": { - "1": "我的高強度訓練又帶來勝利了!\n幹得好!", - "2": "你有實力,但我的訓練更努力。\n精彩的戰鬥!" - } - }, - "allister_elite": { - "encounter": { - "1": "黑暗降臨...你準備好面對你的恐懼了嗎?", - "2": "讓我們看看你能否應對我所操控的黑暗。" - }, - "victory": { - "1": "你已經驅散了陰影......\n暫時。幹得很好。", - "2": "你的光芒刺穿了我的黑暗。幹得好。" - }, - "defeat": { - "1": "黑影在輕語...\n你的力量還不夠。", - "2": "黑暗獲勝了......\n也許下次你會看到光明。" - } - }, - "raihan_elite": { - "encounter": { - "1": "風暴來臨!你能挺過這場戰鬥嗎!", - "2": "準備好面對風暴之眼!" - }, - "victory": { - "1": "你戰勝了風暴...難以置信!", - "2": "你完美地駕馭了風……打得好!" - }, - "defeat": { - "1": "又一場風暴襲來,又一場勝利!打得好!", - "2": "你被我的風暴捲入了!祝你下次好運!" - } - }, - "alder": { - "encounter": { - "1": "準備好和合眾最強的訓練家交手吧!" - }, - "victory": { - "1": "精彩!簡直就是天下無雙!" - }, - "defeat": { - "1": "戰鬥結束後,我的心像是吹過了溫和的風…$真是厲害!" - } - }, - "kieran": { - "encounter": { - "1": "我的努力讓我越來越強!$所以我不會輸。" - }, - "victory": { - "1": "不可能…$真是一場有趣又激動人心的戰鬥啊!" - }, - "defeat": { - "1": "哇塞,好一場戰鬥!$你得多練練了。" - } - }, - "rival": { - "encounter": { - "1": "@c{smile}嘿,我在找你呢!我知道你急著上路,\n但至少說個再見吧…$@c{smile_eclosed}所以你終於要開始追逐夢想了?\n我幾乎不敢相信。$@c{serious_smile_fists}來都來了,來一場對戰怎麼樣?\n畢竟,我想看看你是不是準備周全了。$@c{serious_mopen_fists}不要手下留情,我想讓你全力以赴!" - }, - "victory": { - "1": "@c{shock}哇…你徹底擊敗了我。\n你是真初學者嗎?$@c{smile}也許是靠點運氣,但是…\n誰知道,你可能真的能一路走下去。$順便說一下,博士讓我給你這些東西。它們看起來可牛了。$@c{serious_smile_fists}祝你好运!$@c{smile}哦!我希望你能喜歡這次的活動!" - } - }, - "rival_female": { - "encounter": { - "1": "@c{smile_wave}你在這兒啊!我到處找你呢!$@c{angry_mopen}你忘了和你最好的朋友說再見了嗎?$@c{smile_ehalf}你要去追逐夢想了,對吧?\n從今天開始,是不是…$@c{smile}不管怎樣,忘了我的事就原諒你吧,\n但有個條件。@c{smile_wave_wink}你必須和我對戰!$@c{angry_mopen}全力以赴!\n你也不想讓你的冒險在開始之前就結束了,對吧?" - }, - "victory": { - "1": "@c{shock}你剛開始就已經這麼強了?!@d{96}$@c{angry}你是不是開了?$@c{smile_wave_wink}只是開個玩笑啦!@d{64} @c{smile_eclosed}我輸地心服口服了…\n我感覺你出去挺有天賦的。$@c{smile}順便說一下,博士想讓我給你一些東西。\n希望它們能幫上忙!$@c{smile_wave}像往常一樣盡力而為!\n我相信你!$@c{smile}哦!我希望你能喜歡這次的活動!" - } - }, - "rival_2": { - "encounter": { - "1": "@c{smile}嘿,你也在這裡嗎?$@c{smile_eclosed}一路過關斬將,是吧?$@c{serious_mopen_fists}我知道看起來好像我尾隨著你來到這裡,\n怎麼可能啦。$@c{serious_smile_fists}說真的,自從你在老家打敗我後,\n我就一直很渴望再比一場。$我自己也進行了很多訓練,\n所以這次我肯定會好好打一場。$@c{serious_mopen_fists}不要手下留情,就像以前一樣!$讓我們開始吧!" - }, - "victory": { - "1": "@c{neutral_eclosed}哦。我過於自信了。$@c{smile}不過沒關係。我猜到可能會這樣。$@c{serious_mopen_fists}這只意味著我下次需要更努力!$$@c{smile}呃,不是特意幫你,我正好有多餘的這個,\n我覺得你可能想要。$$@c{serious_smile_fists}不過這次之後別指望再有了!$我不能一直給我的對手優勢。$@c{smile}反正,保重, 要享受活動哦!" - } - }, - "rival_2_female": { - "encounter": { - "1": "@c{smile_wave}哦,真巧,在這裡遇見你。\n看來你還沒輸過嘛。@c{angry_mopen}哈……好傢伙!$@c{angry_mopen}我知道你在想什麼,\n不,我才不會跟蹤你什麼呢。 @c{smile_eclosed}我只是碰巧在附近。$@c{smile_ehalf}我為你感到高興,但我只想讓你知道\n有時輸了是可以接受的。$@c{smile}我們從錯誤中學到的東西\n往往比我們一直成功時學到的還要多。$@c{angry_mopen}無論如何,我為了我們的複賽已經努力訓練了\n所以你最好全力以赴!" - }, - "victory": { - "1": "@c{neutral}我……沒打算會輸來著……$@c{smile}嗷……好吧。看來我要再更加努力訓練了!$@c{smile_wave}我還給你帶了個這個$@c{smile_wave_wink}不用謝我哦~.$@c{angry_mopen}不過,這是最後一個啦!\n 你可別想再從我這賺小便宜了~$@c{smile_wave}要保重哦,要享受活動哦!" - }, - "defeat": { - "1": "輸了有時候也不要緊的…" - } - }, - "rival_3": { - "encounter": { - "1": "@c{smile}嘿,看看這是誰!好久不見啊。$@c{neutral}你……還是沒輸過?哈…$@c{neutral_eclosed}這有點……不太對勁。$沒有你一起,回家的感覺有很不一樣。$@c{serious}雖然我知道這挺別扭的,但我就直說了。$@c{neutral_eclosed}我覺得你有點兒難以理解。$@c{serious}沒有人能夠戰無不勝。$失敗乃成功之母。$@c{neutral_eclosed}你已經贏得了夠好的成績,\n但前面道阻且長,只會愈發艱難。 @c{neutral}你做好準備了沒?$@c{serious_mopen_fists}如果做好了,證明給我看吧。" - }, - "victory": { - "1": "@c{angry_mhalf}這太離譜了……我幾乎從沒停下訓練……$我們之間的差距怎麼還是這麼大?" - } - }, - "rival_3_female": { - "encounter": { - "1": "@c{smile_wave}好久不見!還沒輸過,對吧。$@c{angry}我覺得你點煩了。@c{smile_wave_wink}開玩笑啦!$@c{smile_ehalf}但說真的,你現在不想家嗎?\n 不想…我嗎?$我……我的意思是,我們真的很想你。$@c{smile_eclosed}我支持你的一切,包括你的夢想。\n但現實就是你早晚會經歷失敗。$@c{smile}當你失敗的時候,我想像往常一樣陪在你身邊。$@c{angry_mopen}現在,給你看看我變得多強了吧!" - }, - "victory": { - "1": "@c{shock}都這樣了……還是不夠嗎?$這樣下去,你就永遠不會回來了……" - }, - "defeat": { - "1": "你盡力了,現在讓我們回家吧。" - } - }, - "rival_4": { - "encounter": { - "1": "@c{neutral}嘿。$我不會對你說什麼拐彎抹角的客套話。$@c{neutral_eclosed}我來,就是為了贏,簡單明了。$@c{serious_mhalf_fists}我將所有時間都投入到訓練中,\n掌握了如何發揮我的潛力。$@c{smile}當你削減掉不必要的睡眠和社交後,\n你會得到很多額外的時間。$@c{serious_mopen_fists}但在我獲勝之前,這些都不重要了。$@c{neutral_eclosed}我甚至已經到達了戰無不敗的境地。$@c{smile_eclosed}我覺得你的思路倒是也沒毛病。$@c{angry_mhalf}失敗是屬於弱者的,\n我已經不再軟弱了。$@c{serious_mopen_fists}準備好吧。" - }, - "victory": { - "1": "@c{neutral}你…@d{64} 你是人嗎?" - } - }, - "rival_4_female": { - "encounter": { - "1": "@c{neutral}是我哦!沒又把我忘了吧……是嗎?$@c{smile}你應該為自己走了這麼遠感到驕傲。恭喜你!$但看來你的旅程到此為止了。$@c{smile_eclosed}你喚醒了我體內一些我從未有過的東西。\n就像我現在滿腦子除了訓練還是訓練。$@c{smile_ehalf}我幾乎已經沒空吃飯睡覺了,\n我沒日沒夜訓練我的寶可夢,每次都能變得更強。$@c{neutral}事實上,我……幾乎不認識自己了。$現在,我終於達到了巔峰。\n我感覺我已經戰無不勝了。$而且你知道嗎?這一切都是因為你。$@c{smile_ehalf}我不知道到底是該感謝你還是恨你。$@c{angry_mopen}做好準備…" - }, - "victory": { - "1": "@c{neutral}你…@d{64} 你是人嗎?" - }, - "defeat": { - "1": "@c{smile}你應該為自己走了這麼遠感到驕傲。" - } - }, - "rival_5": { - "encounter": { - "1": "@c{neutral}…" - }, - "victory": { - "1": "@c{neutral}…" - } - }, - "rival_5_female": { - "encounter": { - "1": "@c{neutral}…" - }, - "victory": { - "1": "@c{neutral}…" - - }, - "defeat": { - "1": "$@c{smile_ehalf}…" - } - }, - "rival_6": { - "encounter": { - "1": "@c{smile_eclosed}又見面了。$@c{neutral}我花了點時間思考反思\n有理由說明為什麼這一切都顯得如此奇妙。$@c{neutral_eclosed}你所追逐的夢想,我想擊敗你的決心…$這都是某種龐大使命的一部分。$@c{serious}這不僅僅是關於我和你… 而是關於這個世界, @c{serious_mhalf_fists}我的使命就是將你推向極限。$@c{neutral_eclosed}我是否達成了那個使命,我說不上來,但我已盡我所能。$@c{neutral}我們最終到達的這個地方看起來很可怕\n 然而不知何故,我心中毫無畏懼,好像我早就來過這裡。$@c{serious_mhalf_fists}你也有同樣的感覺,對吧?$@c{serious}……這裡好像有什麼東西在呼喚我。\n這是世界早已記錄的一切。$那些我們經歷過的時光,那些記憶猶新的過去,\n其實只是遙遠的回憶。$@c{neutral_eclosed}誰能保證它們是否真的發生過。$@c{serious_mopen_fists}你必須繼續前進,不然的話,這一切將永無止境。\n這件事而只有你能辦成。$@c{serious_smile_fists}我不清楚這一切意味著什麼,但我知道……$@c{serious_mopen_fists}如果現在你不能就此擊敗我,\n你將毫無機會可言。" - }, - "victory": { - "1": "@c{smile_eclosed}看來我的使命在這裡已經完成了。\n我想讓你答應我一件事。$@c{smile}在你拯救世界之後,要回家。" - } - }, - "rival_6_female": { - "encounter": { - "1": "@c{smile_ehalf}又只有我們兩個人了。$@c{smile_eclosed}你知道嗎,我在心裡想啊想,\n想了好久……$@c{smile_ehalf}這一切背後是有什麼原因嗎,\n為什麼一切現在看起來都這麼奇怪……$@c{smile}你有你的夢想,而我內心有這個抱負……$我不禁感覺這一切背後有一個更龐大的力量,$掌控者我們所做的一切,你和我之間。$@c{smile_eclosed}我想我注定要推動你……到你的極限。$@c{smile_ehalf}我不清楚我是否一直做得很好,\n但到現在為止,我已經盡力了。$這個奇怪而可怕的地方……\n一切看起來都那麼清晰……$這是世界早已記錄的一切。$@c{smile_eclosed}我好像記不清我們一起度過的日子了。$@c{smile_ehalf}那些回憶到底是真的嗎?\n怎麼感覺這麼久遠……$@c{angry_mopen}你得繼續前進,不然的話,這一切將永無止境。\n你是唯一能做到這件事的。$@c{smile_ehalf}我……不知道這一切意味著什麼……\n但我明白$@c{neutral}如果你現在不能就此擊敗我,\n你將毫無機會可言。" - }, - "victory": { - "1": "@c{smile_ehalf}我……\n我想我完成了我的使命……$@c{smile_eclosed}答應我……在你拯救世界之後\n……要……平安到家。$@c{smile_ehalf}……謝謝你。" - } - } -} diff --git a/src/locales/zh_TW/egg.json b/src/locales/zh_TW/egg.json deleted file mode 100644 index 0178848a0d5..00000000000 --- a/src/locales/zh_TW/egg.json +++ /dev/null @@ -1,26 +0,0 @@ -{ - "egg": "蛋", - "greatTier": "稀有", - "ultraTier": "史詩", - "masterTier": "傳說", - "defaultTier": "普通", - "hatchWavesMessageSoon": "裡面傳來聲音!\n似乎快要孵化了!", - "hatchWavesMessageClose": "有時好像會動一下。\n就快要孵化了吧?", - "hatchWavesMessageNotClose": "會孵化出什麼呢?\n看來還需要很長時\n間才能孵化。", - "hatchWavesMessageLongTime": "這個蛋需要很長時間\n才能孵化。", - "gachaTypeLegendary": "傳說概率上升", - "gachaTypeMove": "稀有概率上升", - "gachaTypeShiny": "閃光概率上升", - "selectMachine": "選擇一個機器。", - "notEnoughVouchers": "你沒有足夠的兌換券!", - "tooManyEggs": "你的蛋太多啦!", - "pull": "抽", - "pulls": "抽", - "sameSpeciesEgg": "{{species}} 會從這個蛋裡孵化!", - "hatchFromTheEgg": "{{pokemonName}} 從蛋中孵化了!", - "eggMoveUnlock": "蛋招式已解鎖: {{moveName}}", - "rareEggMoveUnlock": "稀有蛋招式已解鎖: {{moveName}}", - "moveUPGacha": "蛋招式UP!", - "shinyUPGacha": "闪光UP!", - "legendaryUPGacha": "UP!" -} diff --git a/src/locales/zh_TW/fight-ui-handler.json b/src/locales/zh_TW/fight-ui-handler.json deleted file mode 100644 index dda3e443b36..00000000000 --- a/src/locales/zh_TW/fight-ui-handler.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "pp": "PP", - "power": "威力", - "accuracy": "命中率", - "abilityFlyInText": " {{pokemonName}} 的\n{{passive}}{{abilityName}}", - "passive": "被動能力 ", - "teraHover": "{{type}} 太晶化" -} diff --git a/src/locales/zh_TW/filter-bar.json b/src/locales/zh_TW/filter-bar.json deleted file mode 100644 index 80688c19767..00000000000 --- a/src/locales/zh_TW/filter-bar.json +++ /dev/null @@ -1,38 +0,0 @@ -{ - "genFilter": "世代", - "typeFilter": "屬性", - "caughtFilter": "捕獲", - "unlocksFilter": "解鎖", - "miscFilter": "混合", - "sortFilter": "排序", - "all": "全部", - "normal": "通常", - "uncaught": "未捕獲", - "passive": "被動", - "passiveUnlocked": "被動解鎖", - "passiveLocked": "被動未解鎖", - "passiveUnlockable": "被動可解鎖", - "costReduction": "費用降低", - "costReductionUnlocked": "已降費", - "costReductionLocked": "未降費", - "costReductionUnlockable": "可降費", - "favorite": "最愛", - "isFavorite": "包含最愛", - "notFavorite": "不包含最愛", - "ribbon": "緞帶", - "hasWon": "有緞帶", - "hasNotWon": "無緞帶", - "hiddenAbility": "隱藏特性", - "hasHiddenAbility": "有隱藏特性", - "noHiddenAbility": "無隱藏特性", - "egg": "蛋", - "eggPurchasable": "可購買蛋", - "pokerus": "病毒", - "hasPokerus": "有病毒", - "noPokerus": "無病毒", - "sortByNumber": "編號", - "sortByCost": "花費", - "sortByCandies": "糖果", - "sortByIVs": "個體值", - "sortByName": "名稱" -} \ No newline at end of file diff --git a/src/locales/zh_TW/game-mode.json b/src/locales/zh_TW/game-mode.json deleted file mode 100644 index b41dbdcae96..00000000000 --- a/src/locales/zh_TW/game-mode.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "classic": "經典模式", - "endless": "無盡模式", - "endlessSpliced": "融合無盡模式", - "dailyRun": "每日挑戰", - "unknown": "未知", - "challenge": "挑戰模式" -} \ No newline at end of file diff --git a/src/locales/zh_TW/game-stats-ui-handler.json b/src/locales/zh_TW/game-stats-ui-handler.json deleted file mode 100644 index ccd7f481fe1..00000000000 --- a/src/locales/zh_TW/game-stats-ui-handler.json +++ /dev/null @@ -1,42 +0,0 @@ -{ - "stats": "統計", - "playTime": "遊戲時間", - "totalBattles": "總戰鬥次數", - "starters": "初始寶可夢", - "shinyStarters": "閃光初始寶可夢", - "speciesSeen": "遇到的種類", - "speciesCaught": "捕捉的種類", - "ribbonsOwned": "擁有緞帶數", - "classicRuns": "經典模式次數", - "classicWins": "經典模式通關次數", - "dailyRunAttempts": "每日挑戰次數", - "dailyRunWins": "每日挑戰通關次數", - "endlessRuns": "無盡模式挑戰次數", - "highestWaveEndless": "最高層數(無盡)", - "highestMoney": "最多金錢", - "highestDamage": "最高傷害", - "highestHPHealed": "最多治療", - "pokemonEncountered": "遇敵數量", - "pokemonDefeated": "打倒數量", - "pokemonCaught": "捕捉數量", - "eggsHatched": "孵蛋數量", - "subLegendsSeen": "遇到的二級神寶可夢", - "subLegendsCaught": "捕捉的二級神寶可夢", - "subLegendsHatched": "孵化的二級神寶可夢", - "legendsSeen": "遇到的傳說寶可夢", - "legendsCaught": "捕捉的傳說寶可夢", - "legendsHatched": "孵化的傳說寶可夢", - "mythicalsSeen": "遇到的幻獸寶可夢", - "mythicalsCaught": "捕捉的幻獸寶可夢", - "mythicalsHatched": "孵化的幻獸寶可夢", - "shiniesSeen": "遇到的閃光寶可夢", - "shiniesCaught": "捕捉的閃光寶可夢", - "shiniesHatched": "孵化的閃光寶可夢", - "pokemonFused": "融合寶可夢次數", - "trainersDefeated": "打敗的訓練師數", - "eggsPulled": "總扭蛋次數", - "rareEggsPulled": "稀有扭蛋數", - "epicEggsPulled": "史詩扭蛋數", - "legendaryEggsPulled": "傳說扭蛋數", - "manaphyEggsPulled": "瑪娜霏扭蛋數" -} \ No newline at end of file diff --git a/src/locales/zh_TW/growth.json b/src/locales/zh_TW/growth.json deleted file mode 100644 index 6e6d8db4b4a..00000000000 --- a/src/locales/zh_TW/growth.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "Erratic": "最快", - "Fast": "快", - "Medium_Fast": "較快", - "Medium_Slow": "較慢", - "Slow": "慢", - "Fluctuating": "最慢" -} \ No newline at end of file diff --git a/src/locales/zh_TW/menu-ui-handler.json b/src/locales/zh_TW/menu-ui-handler.json deleted file mode 100644 index cbb5b604d33..00000000000 --- a/src/locales/zh_TW/menu-ui-handler.json +++ /dev/null @@ -1,29 +0,0 @@ -{ - "GAME_SETTINGS": "遊戲設置", - "ACHIEVEMENTS": "成就", - "STATS": "數據", - "RUN_HISTORY": "歷史記錄", - "EGG_LIST": "蛋列表", - "EGG_GACHA": "扭蛋機", - "MANAGE_DATA": "管理數據", - "COMMUNITY": "社群", - "RETURN_TO_TITLE": "返回標題畫面", - "LOG_OUT": "登出", - "slot": "存檔位 {{slotNumber}}", - "importSession": "導入存檔", - "importSlotSelect": "選擇要導入到的存檔位。", - "exportSession": "導出存檔", - "exportSlotSelect": "選擇要導出的存檔位。", - "importRunHistory":"導入歷史記錄", - "exportRunHistory":"導出歷史記錄", - "importData": "導入數據", - "exportData": "導出數據", - "consentPreferences": "同意偏好", - "linkDiscord": "關聯Discord", - "unlinkDiscord": "解除關聯Discord", - "linkGoogle": "關聯Google", - "unlinkGoogle": "解除關聯Google", - "cancel": "取消", - "losingProgressionWarning": "你將失去自戰鬥開始以來的所有進度。是否\n繼續?", - "noEggs": "當前沒有任何蛋\n正在孵化中!" -} diff --git a/src/locales/zh_TW/menu.json b/src/locales/zh_TW/menu.json deleted file mode 100644 index fee9b1be85d..00000000000 --- a/src/locales/zh_TW/menu.json +++ /dev/null @@ -1,54 +0,0 @@ -{ - "cancel": "取消", - "continue": "繼續", - "dailyRun": "每日挑戰 (Beta)", - "loadGame": "加載遊戲", - "newGame": "新遊戲", - "settings": "設定", - "selectGameMode": "選擇遊戲模式", - "logInOrCreateAccount": "登入或註冊即可開始遊戲,無需郵箱!", - "username": "用戶名", - "password": "密碼", - "login": "登入", - "orUse": "或使用", - "register": "注冊", - "emptyUsername": "用戶名不能為空", - "invalidLoginUsername": "提供的用戶名無效", - "invalidRegisterUsername": "用戶名只能包含字母,數字或下劃線", - "invalidLoginPassword": "提供的密碼無效", - "invalidRegisterPassword": "密碼必需至少包含6個字符", - "usernameAlreadyUsed": "用戶名稱已被使用", - "accountNonExistent": "用戶不存在", - "unmatchingPassword": "提供的密碼不匹配", - "passwordNotMatchingConfirmPassword": "密碼必需與確認密碼一致", - "confirmPassword": "確認密碼", - "registrationAgeWarning": "注冊表示您確認您已年滿13歲。", - "backToLogin": "返回登錄", - "failedToLoadSaveData": "讀取存檔數據失敗。請重新加載頁面。如果\n問題仍然存在,請聯繫管理員。", - "sessionSuccess": "工作階段加載成功.", - "failedToLoadSession": "無法加載您的工作階段數據。它可能已損壞。", - "boyOrGirl": "你是男孩還是女孩?", - "evolving": "甚麼?\n{{pokemonName}} 要進化了!", - "stoppedEvolving": "{{pokemonName}} 停止了進化。", - "pauseEvolutionsQuestion": "你確定要停止 {{pokemonName}} 的進化嗎?\n你可以在隊伍畫面中重新啟用進化。", - "evolutionsPaused": "{{pokemonName}}的進化已暫停。", - "evolutionDone": "恭喜!\n你的 {{pokemonName}} 進化成了 {{evolvedPokemonName}}!", - "dailyRankings": "每日排名", - "weeklyRankings": "每週排名", - "noRankings": "無排名", - "positionIcon": "#", - "loading": "加載中…", - "loadingAsset": "加載資源: {{assetName}}", - "playersOnline": "在線玩家", - "yes": "是", - "no": "否", - "disclaimer": "免責聲明", - "disclaimerDescription": "這個遊戲尚未完成; 可能存在遊戲性問題(包括潛在的丟檔風險)、\n 不經通知的調整、 未來可能會更新或完成更多內容", - "choosePokemon": "選擇一只寶可夢。", - "renamePokemon": "給寶可夢起名", - "rename": "起名", - "nickname": "昵稱", - "errorServerDown": "糟糕!訪問服務器時發生了錯誤。\n\n你可以保持頁面開啓,\n遊戲會自動重新連接。", - "noSaves": "你沒有任何記錄檔!", - "tooManySaves": "你的記錄檔太多了!" -} diff --git a/src/locales/zh_TW/modifier-select-ui-handler.json b/src/locales/zh_TW/modifier-select-ui-handler.json deleted file mode 100644 index 84ebbbfef6a..00000000000 --- a/src/locales/zh_TW/modifier-select-ui-handler.json +++ /dev/null @@ -1,12 +0,0 @@ -{ - "transfer": "交換道具", - "reroll": "刷新商店", - "lockRarities": "鎖定稀有度", - "checkTeam": "查看隊伍", - "transferDesc": "將寶可夢攜帶的道具交換給其他寶可夢", - "rerollDesc": "花錢刷新道具", - "lockRaritiesDesc": "在刷新時鎖定道具稀有度(影響刷新費用)", - "checkTeamDesc": "檢查隊伍或使用形態改變道具", - "rerollCost": "₽{{formattedMoney}}", - "itemCost": "₽{{formattedMoney}}" -} diff --git a/src/locales/zh_TW/modifier-type.json b/src/locales/zh_TW/modifier-type.json deleted file mode 100644 index 6ff593ddba7..00000000000 --- a/src/locales/zh_TW/modifier-type.json +++ /dev/null @@ -1,607 +0,0 @@ -{ - "ModifierType": { - "AddPokeballModifierType": { - "name": "{{modifierCount}}x {{pokeballName}}", - "description": "獲得 {{pokeballName}} x{{modifierCount}} (已有:{{pokeballAmount}}) \n捕捉倍率:{{catchRate}}。" - }, - "AddVoucherModifierType": { - "name": "{{modifierCount}}x {{voucherTypeName}}", - "description": "獲得 {{voucherTypeName}} x{{modifierCount}}。" - }, - "PokemonHeldItemModifierType": { - "extra": { - "inoperable": "{{pokemonName}} 無法攜帶\n這個物品!", - "tooMany": "{{pokemonName}} 已有太多\n這個物品!" - } - }, - "PokemonHpRestoreModifierType": { - "description": "爲一隻寶可夢恢復 {{restorePoints}} HP 或 {{restorePercent}}% HP,取最大值。", - "extra": { - "fully": "爲一隻寶可夢恢復全部HP。", - "fullyWithStatus": "爲一隻寶可夢恢復全部HP並消除所有負面\n狀態。" - } - }, - "PokemonReviveModifierType": { - "description": "復活一隻寶可夢並恢復 {{restorePercent}}% HP。" - }, - "PokemonStatusHealModifierType": { - "description": "爲一隻寶可夢消除所有負面狀態。" - }, - "PokemonPpRestoreModifierType": { - "description": "爲一隻寶可夢的一個招式恢復 {{restorePoints}} PP。", - "extra": { - "fully": "完全恢復一隻寶可夢一個招式的PP。" - } - }, - "PokemonAllMovePpRestoreModifierType": { - "description": "爲一隻寶可夢的所有招式恢復 {{restorePoints}} PP。", - "extra": { - "fully": "爲一隻寶可夢的所有招式恢復所有PP。" - } - }, - "PokemonPpUpModifierType": { - "description": "永久提升一個招式的PP,每5點最大PP增加{{upPoints}} (最多3點)。" - }, - "PokemonNatureChangeModifierType": { - "name": "{{natureName}}薄荷", - "description": "將一隻寶可夢的性格改爲{{natureName}}併爲該寶可\n夢永久解鎖該性格。" - }, - "DoubleBattleChanceBoosterModifierType": { - "description": "遭遇雙打機率提升四倍,持續{{battleCount}}場戰鬥。" - }, - "TempStatStageBoosterModifierType": { - "description": "提升全隊的{{stat}}{{amount}}級,持續5場戰鬥。", - "extra": { - "stage": "1階", - "percentage": "30%" - } - }, - "AttackTypeBoosterModifierType": { - "description": "一隻寶可夢的{{moveType}}系招式威力提升20%。" - }, - "PokemonLevelIncrementModifierType": { - "description": "使一只寶可夢的等級提升{{levels}}級。" - }, - "AllPokemonLevelIncrementModifierType": { - "description": "使一只寶可夢的等級提升{{levels}}級。" - }, - "BaseStatBoosterModifierType": { - "description": "增加持有者的{{stat}}10%,個體值越高堆疊\n上限越高。" - }, - "AllPokemonFullHpRestoreModifierType": { - "description": "所有寶可夢完全恢復HP。" - }, - "AllPokemonFullReviveModifierType": { - "description": "復活所有瀕死寶可夢,完全恢復HP。" - }, - "MoneyRewardModifierType": { - "description": "獲得{{moneyMultiplier}}金錢 (₽{{moneyAmount}})。", - "extra": { - "small": "少量", - "moderate": "中等", - "large": "大量" - } - }, - "ExpBoosterModifierType": { - "description": "經驗值獲取量增加{{boostPercent}}%。" - }, - "PokemonExpBoosterModifierType": { - "description": "持有者經驗值獲取量增加{{boostPercent}}%。" - }, - "PokemonFriendshipBoosterModifierType": { - "description": "每場戰鬥獲得的好感度提升50%。" - }, - "PokemonMoveAccuracyBoosterModifierType": { - "description": "招式命中率增加{{accuracyAmount}} (最大100)。" - }, - "PokemonMultiHitModifierType": { - "description": "攻擊以60/75/82.5%的傷害造成2/3/4次傷害。" - }, - "TmModifierType": { - "name": "招式學習器 {{moveId}} - {{moveName}}", - "description": "教會一隻寶可夢{{moveName}}。" - }, - "TmModifierTypeWithInfo": { - "name": "招式學習器{{moveId}} - {{moveName}}", - "description": "教會一隻寶可夢{{moveName}}\n(按住C或者Shift查看更多信息)" - }, - "EvolutionItemModifierType": { - "description": "使某些寶可夢進化。" - }, - "FormChangeItemModifierType": { - "description": "使某些寶可夢更改形態。" - }, - "FusePokemonModifierType": { - "description": "融合兩隻寶可夢 (改變特性, 平分基礎點數\n和屬性, 共享招式池)。" - }, - "TerastallizeModifierType": { - "name": "{{teraType}}太晶碎塊", - "description": "持有者獲得{{teraType}}太晶化10場戰鬥。" - }, - "ContactHeldItemTransferChanceModifierType": { - "description": "攻擊時{{chancePercent}}%概率偷取對手物品。" - }, - "TurnHeldItemTransferModifierType": { - "description": "持有者每回合從對手那裏獲得一個持有的物品。" - }, - "EnemyAttackStatusEffectChanceModifierType": { - "description": "攻擊時{{chancePercent}}%概率造成{{statusEffect}}。" - }, - "EnemyEndureChanceModifierType": { - "description": "增加{{chancePercent}}%遭受攻擊的概率。" - }, - "RARE_CANDY": { - "name": "神奇糖果" - }, - "RARER_CANDY": { - "name": "超神奇糖果" - }, - "MEGA_BRACELET": { - "name": "超級手鐲", - "description": "能讓攜帶着超級石戰鬥的寶可夢進行\n超級進化。" - }, - "DYNAMAX_BAND": { - "name": "極巨腕帶", - "description": "能讓攜帶着極巨菇菇戰鬥的寶可夢進行\n極巨化。" - }, - "TERA_ORB": { - "name": "太晶珠", - "description": "能讓攜帶着太晶碎塊戰鬥的寶可夢進行\n太晶化。" - }, - "MAP": { - "name": "地圖", - "description": "允許你在切換寶可夢羣落時選擇目的地。" - }, - "POTION": { - "name": "傷藥" - }, - "SUPER_POTION": { - "name": "好傷藥" - }, - "HYPER_POTION": { - "name": "厲害傷藥" - }, - "MAX_POTION": { - "name": "全滿藥" - }, - "FULL_RESTORE": { - "name": "全復藥" - }, - "REVIVE": { - "name": "活力碎片" - }, - "MAX_REVIVE": { - "name": "活力塊" - }, - "FULL_HEAL": { - "name": "萬靈藥" - }, - "SACRED_ASH": { - "name": "聖灰" - }, - "REVIVER_SEED": { - "name": "復活種子", - "description": "受到技能攻擊傷害瀕死時,\n恢復該瀕死寶可夢的HP至1/2。" - }, - "WHITE_HERB": { - "name": "白色香草", - "description": "當攜帶它的寶可夢能力降低時,\n僅能回到之前的狀態1次。" - }, - "ETHER": { - "name": "PP單項小補劑" - }, - "MAX_ETHER": { - "name": "PP單項全補劑" - }, - "ELIXIR": { - "name": "PP多項小補劑" - }, - "MAX_ELIXIR": { - "name": "PP多項全補劑" - }, - "PP_UP": { - "name": "PP提升劑" - }, - "PP_MAX": { - "name": "PP極限提升劑" - }, - "LURE": { - "name": "引蟲香水" - }, - "SUPER_LURE": { - "name": "白銀香水" - }, - "MAX_LURE": { - "name": "黃金香水" - }, - "MEMORY_MUSHROOM": { - "name": "回憶蘑菇", - "description": "回憶一個寶可夢已經遺忘的招式。" - }, - "EXP_SHARE": { - "name": "學習裝置", - "description": "未參加對戰的寶可夢獲得20%的經驗值。" - }, - "EXP_BALANCE": { - "name": "均衡型學習裝置", - "description": "隊伍中的低級寶可夢獲得更多經驗值。" - }, - "OVAL_CHARM": { - "name": "圓形護符", - "description": "當多隻寶可夢參與戰鬥,分別獲得總經驗值\n10%的額外經驗值。" - }, - "EXP_CHARM": { - "name": "經驗護符" - }, - "SUPER_EXP_CHARM": { - "name": "超級經驗護符" - }, - "GOLDEN_EXP_CHARM": { - "name": "黃金經驗護符" - }, - "LUCKY_EGG": { - "name": "幸運蛋" - }, - "GOLDEN_EGG": { - "name": "金蛋" - }, - "SOOTHE_BELL": { - "name": "安撫之鈴" - }, - "SCOPE_LENS": { - "name": "焦點鏡", - "description": "能看見弱點的鏡片。攜帶它的寶可夢的招式 會變得容易擊中要害。" - }, - "DIRE_HIT": { - "name": "要害攻擊", - "extra": { - "raises": "會心" - } - }, - "LEEK": { - "name": "大蔥", - "description": "非常長且堅硬的莖。讓大蔥鴨攜帶後,招式會 變得容易擊中要害。" - }, - "EVIOLITE": { - "name": "進化奇石", - "description": "進化的神奇石塊。攜帶後,還能進化的寶可夢的 防禦和特防就會提高。" - }, - "SOUL_DEW": { - "name": "心之水滴", - "description": "增加寶可夢性格影響10% (加算)。" - }, - "NUGGET": { - "name": "金珠" - }, - "BIG_NUGGET": { - "name": "巨大金珠" - }, - "RELIC_GOLD": { - "name": "古代金幣" - }, - "AMULET_COIN": { - "name": "護符金幣", - "description": "金錢獎勵增加20%。" - }, - "GOLDEN_PUNCH": { - "name": "黃金拳頭", - "description": "將50%造成的傷害轉換爲金錢。" - }, - "COIN_CASE": { - "name": "代幣盒", - "description": "每十場戰鬥, 獲得自己金錢10%的利息。" - }, - "LOCK_CAPSULE": { - "name": "上鎖的容器", - "description": "允許在刷新物品時鎖定物品稀有度。" - }, - "GRIP_CLAW": { - "name": "緊纏鉤爪" - }, - "WIDE_LENS": { - "name": "廣角鏡" - }, - "MULTI_LENS": { - "name": "多重鏡" - }, - "HEALING_CHARM": { - "name": "治癒護符", - "description": "HP恢復量增加10% (不含復活)。" - }, - "CANDY_JAR": { - "name": "糖果罐", - "description": "神奇糖果提供的升級提升1級。" - }, - "BERRY_POUCH": { - "name": "樹果袋", - "description": "使用樹果時增加30%的幾率不會消耗樹果。" - }, - "FOCUS_BAND": { - "name": "氣勢頭帶", - "description": "攜帶該道具的寶可夢增加10%幾率在受到\n攻擊而將陷入瀕死狀態時,保留1點HP不陷入瀕死狀態。" - }, - "QUICK_CLAW": { - "name": "先制之爪", - "description": "增加10%的幾率無視速度優先使出招式\n(先制技能優先)。" - }, - "KINGS_ROCK": { - "name": "王者之證", - "description": "攜帶該道具的寶可夢使用任意原本不會造成\n畏縮狀態的攻擊招式並造成傷害時,增加\n10%幾率使目標陷入畏縮狀態。" - }, - "LEFTOVERS": { - "name": "喫剩的東西", - "description": "攜帶該道具的寶可夢在每個回合結束時恢復\n最大HP的1/16。" - }, - "SHELL_BELL": { - "name": "貝殼之鈴", - "description": "攜帶該道具的寶可夢在攻擊對方成功造成傷\n害時,攜帶者的HP會恢復其所造成傷害\n的1/8。" - }, - "TOXIC_ORB": { - "name": "劇毒寶珠", - "description": "觸碰後會放出毒的神奇寶珠。\n攜帶後,在戰鬥時會變成劇毒狀態。" - }, - "FLAME_ORB": { - "name": "火焰寶珠", - "description": "觸碰後會放出熱量的神奇寶珠。\n攜帶後,在戰鬥時會變成灼傷狀態。" - }, - "BATON": { - "name": "接力棒", - "description": "允許在切換寶可夢時保留能力變化, 對陷阱\n同樣生效。" - }, - "SHINY_CHARM": { - "name": "閃耀護符", - "description": "顯著增加野生寶可夢的閃光概率。" - }, - "ABILITY_CHARM": { - "name": "特性護符", - "description": "顯著增加野生寶可夢有隱藏特性的概率。" - }, - "IV_SCANNER": { - "name": "個體值探測器", - "description": "允許掃描野生寶可夢的個體值。 每個次顯示\n2個個體值. 最好的個體值優先顯示。" - }, - "DNA_SPLICERS": { - "name": "基因之楔" - }, - "MINI_BLACK_HOLE": { - "name": "迷你黑洞" - }, - "GOLDEN_POKEBALL": { - "name": "黃金精靈球", - "description": "在每場戰鬥結束後增加一個額外物品選項。" - }, - "ENEMY_DAMAGE_BOOSTER": { - "name": "傷害硬幣", - "description": "增加5%造成傷害。" - }, - "ENEMY_DAMAGE_REDUCTION": { - "name": "防禦硬幣", - "description": "減少2.5%承受傷害。" - }, - "ENEMY_HEAL": { - "name": "恢復硬幣", - "description": "每回合恢復2%最大HP。" - }, - "ENEMY_ATTACK_POISON_CHANCE": { - "name": "劇毒硬幣" - }, - "ENEMY_ATTACK_PARALYZE_CHANCE": { - "name": "麻痹硬幣" - }, - "ENEMY_ATTACK_BURN_CHANCE": { - "name": "灼燒硬幣" - }, - "ENEMY_STATUS_EFFECT_HEAL_CHANCE": { - "name": "萬靈藥硬幣", - "description": "增加2.5%每回合治癒異常狀態的概率。" - }, - "ENEMY_ENDURE_CHANCE": { - "name": "忍受硬幣" - }, - "ENEMY_FUSED_CHANCE": { - "name": "融合硬幣", - "description": "增加1%野生融合寶可夢出現概率。" - } - }, - "SpeciesBoosterItem": { - "LIGHT_BALL": { - "name": "電氣球", - "description": "讓皮卡丘攜帶後,攻擊和特攻就會 提高的神奇之球。" - }, - "THICK_CLUB": { - "name": "粗骨頭", - "description": "某種堅硬的骨頭。讓卡拉卡拉或嘎啦嘎啦攜帶後,攻擊就會提高。" - }, - "METAL_POWDER": { - "name": "金屬粉", - "description": "讓百變怪攜帶後,防禦就會提高的神奇粉末。非常細緻堅硬。" - }, - "QUICK_POWDER": { - "name": "速度粉", - "description": "讓百變怪攜帶後,速度就會提高的神奇粉末。非常細緻堅硬。" - } - }, - "TempStatStageBoosterItem": { - "x_attack": "力量強化", - "x_defense": "防禦強化", - "x_sp_atk": "特攻強化", - "x_sp_def": "特防強化", - "x_speed": "速度強化", - "x_accuracy": "命中強化" - }, - "AttackTypeBoosterItem": { - "silk_scarf": "絲綢圍巾", - "black_belt": "黑帶", - "sharp_beak": "銳利鳥嘴", - "poison_barb": "毒針", - "soft_sand": "柔軟沙子", - "hard_stone": "硬石頭", - "silver_powder": "銀粉", - "spell_tag": "詛咒之符", - "metal_coat": "金屬膜", - "charcoal": "木炭", - "mystic_water": "神祕水滴", - "miracle_seed": "奇蹟種子", - "magnet": "磁鐵", - "twisted_spoon": "彎曲的湯匙", - "never_melt_ice": "不融冰", - "dragon_fang": "龍之牙", - "black_glasses": "黑色眼鏡", - "fairy_feather": "妖精之羽" - }, - "BaseStatBoosterItem": { - "hp_up": "HP增強劑", - "protein": "攻擊增強劑", - "iron": "防禦增強劑", - "calcium": "特攻增強劑", - "zinc": "特防增強劑", - "carbos": "速度增強劑" - }, - "EvolutionItem": { - "NONE": "無", - "LINKING_CORD": "聯繫繩", - "SUN_STONE": "日之石", - "MOON_STONE": "月之石", - "LEAF_STONE": "葉之石", - "FIRE_STONE": "火之石", - "WATER_STONE": "水之石", - "THUNDER_STONE": "雷之石", - "ICE_STONE": "冰之石", - "DUSK_STONE": "暗之石", - "DAWN_STONE": "覺醒之石", - "SHINY_STONE": "光之石", - "CRACKED_POT": "破裂的茶壺", - "SWEET_APPLE": "甜甜蘋果", - "TART_APPLE": "酸酸蘋果", - "STRAWBERRY_SWEET": "草莓糖飾", - "UNREMARKABLE_TEACUP": "凡作茶碗", - "CHIPPED_POT": "缺損的茶壺", - "BLACK_AUGURITE": "黑奇石", - "GALARICA_CUFF": "伽勒豆蔻手環", - "GALARICA_WREATH": "伽勒豆蔻花圈", - "PEAT_BLOCK": "泥炭塊", - "AUSPICIOUS_ARMOR": "慶祝之鎧", - "MALICIOUS_ARMOR": "咒術之鎧", - "MASTERPIECE_TEACUP": "傑作茶碗", - "METAL_ALLOY": "複合金屬", - "SCROLL_OF_DARKNESS": "惡之掛軸", - "SCROLL_OF_WATERS": "水之掛軸", - "SYRUPY_APPLE": "蜜汁蘋果" - }, - "FormChangeItem": { - "NONE": "無", - "ABOMASITE": "暴雪王進化石", - "ABSOLITE": "阿勃梭魯進化石", - "AERODACTYLITE": "化石翼龍進化石", - "AGGRONITE": "波士可多拉進化石", - "ALAKAZITE": "胡地進化石", - "ALTARIANITE": "七夕青鳥進化石", - "AMPHAROSITE": "電龍進化石", - "AUDINITE": "差不多娃娃進化石", - "BANETTITE": "詛咒娃娃進化石", - "BEEDRILLITE": "大針蜂進化石", - "BLASTOISINITE": "水箭龜進化石", - "BLAZIKENITE": "火焰雞進化石", - "CAMERUPTITE": "噴火駝進化石", - "CHARIZARDITE_X": "噴火龍進化石X", - "CHARIZARDITE_Y": "噴火龍進化石Y", - "DIANCITE": "蒂安希進化石", - "GALLADITE": "艾路雷朵進化石", - "GARCHOMPITE": "烈咬陸鯊進化石", - "GARDEVOIRITE": "沙奈朵進化石", - "GENGARITE": "耿鬼進化石", - "GLALITITE": "冰鬼護進化石", - "GYARADOSITE": "暴鯉龍進化石", - "HERACRONITE": "赫拉克羅斯進化石", - "HOUNDOOMINITE": "黑魯加進化石", - "KANGASKHANITE": "袋獸進化石", - "LATIASITE": "拉帝亞斯進化石", - "LATIOSITE": "拉帝歐斯進化石", - "LOPUNNITE": "長耳兔進化石", - "LUCARIONITE": "路卡利歐進化石", - "MANECTITE": "雷電獸進化石", - "MAWILITE": "大嘴娃進化石", - "MEDICHAMITE": "恰雷姆進化石", - "METAGROSSITE": "巨金怪進化石", - "MEWTWONITE_X": "超夢進化石X", - "MEWTWONITE_Y": "超夢進化石Y", - "PIDGEOTITE": "大比鳥進化石", - "PINSIRITE": "凱羅斯進化石", - "RAYQUAZITE": "烈空坐進化石", - "SABLENITE": "勾魂眼進化石", - "SALAMENCITE": "暴飛龍進化石", - "SCEPTILITE": "蜥蜴王進化石", - "SCIZORITE": "巨鉗螳螂進化石", - "SHARPEDONITE": "巨牙鯊進化石", - "SLOWBRONITE": "呆殼獸進化石", - "STEELIXITE": "大鋼蛇進化石", - "SWAMPERTITE": "巨沼怪進化石", - "TYRANITARITE": "班基拉斯進化石", - "VENUSAURITE": "妙蛙花進化石", - "BLUE_ORB": "靛藍色寶珠", - "RED_ORB": "硃紅色寶珠", - "SHARP_METEORITE": "銳利隕石", - "HARD_METEORITE": "堅硬隕石", - "SMOOTH_METEORITE": "光滑隕石", - "ADAMANT_CRYSTAL": "大金剛寶玉", - "LUSTROUS_GLOBE": "大白寶玉", - "GRISEOUS_CORE": "大白金寶玉", - "REVEAL_GLASS": "現形鏡", - "GRACIDEA": "葛拉西蒂亞花", - "MAX_MUSHROOMS": "極巨菇菇", - "DARK_STONE": "黑暗石", - "LIGHT_STONE": "光明石", - "PRISON_BOTTLE": "懲戒之壺", - "N_LUNARIZER": "奈克洛露奈合體器", - "N_SOLARIZER": "奈克洛索爾合體器", - "RUSTED_SWORD": "腐朽的劍", - "RUSTED_SHIELD": "腐朽的盾", - "ICY_REINS_OF_UNITY": "牽絆繮繩(冰)", - "SHADOW_REINS_OF_UNITY": "牽絆繮繩(幽靈)", - "WELLSPRING_MASK": "水井面具", - "HEARTHFLAME_MASK": "火竈面具", - "CORNERSTONE_MASK": "礎石面具", - "SHOCK_DRIVE": "閃電卡帶", - "BURN_DRIVE": "火焰卡帶", - "CHILL_DRIVE": "冰凍卡帶", - "DOUSE_DRIVE": "水流卡帶", - "ULTRANECROZIUM_Z": "究極奈克洛Z", - "FIST_PLATE": "拳頭石板", - "SKY_PLATE": "藍天石板", - "TOXIC_PLATE": "劇毒石板", - "EARTH_PLATE": "大地石板", - "STONE_PLATE": "岩石石板", - "INSECT_PLATE": "玉蟲石板", - "SPOOKY_PLATE": "妖怪石板", - "IRON_PLATE": "鋼鐵石板", - "FLAME_PLATE": "火球石板", - "SPLASH_PLATE": "水滴石板", - "MEADOW_PLATE": "碧綠石板", - "ZAP_PLATE": "雷電石板", - "MIND_PLATE": "神奇石板", - "ICICLE_PLATE": "冰柱石板", - "DRACO_PLATE": "龍之石板", - "DREAD_PLATE": "惡顏石板", - "PIXIE_PLATE": "妖精石板", - "BLANK_PLATE": "淨空石板", - "LEGEND_PLATE": "傳說石板", - "FIGHTING_MEMORY": "戰鬥記憶碟", - "FLYING_MEMORY": "飛翔記憶碟", - "POISON_MEMORY": "毒記憶碟", - "GROUND_MEMORY": "大地記憶碟", - "ROCK_MEMORY": "岩石記憶碟", - "BUG_MEMORY": "蟲子記憶碟", - "GHOST_MEMORY": "幽靈記憶碟", - "STEEL_MEMORY": "鋼鐵記憶碟", - "FIRE_MEMORY": "火焰記憶碟", - "WATER_MEMORY": "清水記憶碟", - "GRASS_MEMORY": "青草記憶碟", - "ELECTRIC_MEMORY": "電子記憶碟", - "PSYCHIC_MEMORY": "精神記憶碟", - "ICE_MEMORY": "冰雪記憶碟", - "DRAGON_MEMORY": "龍記憶碟", - "DARK_MEMORY": "黑暗記憶碟", - "FAIRY_MEMORY": "妖精記憶碟", - "NORMAL_MEMORY": "一般記憶碟" - } -} diff --git a/src/locales/zh_TW/modifier.json b/src/locales/zh_TW/modifier.json deleted file mode 100644 index 12c436c1783..00000000000 --- a/src/locales/zh_TW/modifier.json +++ /dev/null @@ -1,12 +0,0 @@ -{ - "surviveDamageApply": "{{pokemonNameWithAffix}}用{{typeName}}\n撐住了!", - "turnHealApply": "{{pokemonNameWithAffix}}用{{typeName}}\n回復了體力!", - "hitHealApply": "{{pokemonNameWithAffix}}用{{typeName}}\n回復了體力!", - "pokemonInstantReviveApply": "{{pokemonNameWithAffix}}用{{typeName}}\n回復了活力!", - "pokemonResetNegativeStatStageApply": "{{pokemonNameWithAffix}}降低的能力被{{typeName}}\n複原了!!", - "moneyInterestApply": "用{{typeName}}\n獲得了 ₽{{moneyAmount}} 利息!", - "turnHeldItemTransferApply": "{{pokemonNameWithAffix}}的{{itemName}}被\n{{pokemonName}}的{{typeName}}吸收了!", - "contactHeldItemTransferApply": "{{pokemonNameWithAffix}}的{{itemName}}被\n{{pokemonName}}的{{typeName}}奪取了!", - "enemyTurnHealApply": "{{pokemonNameWithAffix}}\n回復了一些體力!", - "bypassSpeedChanceApply": "{{pokemonName}}用了{{itemName}}後,行動變快了!" -} diff --git a/src/locales/zh_TW/move-trigger.json b/src/locales/zh_TW/move-trigger.json deleted file mode 100644 index db88f6df57f..00000000000 --- a/src/locales/zh_TW/move-trigger.json +++ /dev/null @@ -1,71 +0,0 @@ -{ - "hitWithRecoil": "{{pokemonName}}\n受到了反作用力造成的傷害!", - "cutHpPowerUpMove": "{{pokemonName}}\n削減體力並提升了招式威力!", - "absorbedElectricity": "{{pokemonName}}\n吸收了电力!", - "switchedStatChanges": "{{pokemonName}}和對手互換了\n自身的能力變化!", - "switchedTwoStatChanges": "{{pokemonName}} 和對手互換了自身的{{firstStat}}和{{secondStat}}的能力變化!", - "switchedStat": "{{pokemonName}} 互換了各自的{{stat}}!", - "sharedGuard": "{{pokemonName}} 平分了各自的防守!", - "sharedPower": "{{pokemonName}} 平分了各自的力量!", - "goingAllOutForAttack": "{{pokemonName}}拿出全力了!", - "regainedHealth": "{{pokemonName}}的\n體力回復了!", - "keptGoingAndCrashed": "{{pokemonName}}因勢頭過猛\n而撞到了地面!", - "fled": "{{pokemonName}}\n逃走了!", - "cannotBeSwitchedOut": "{{pokemonName}}\n無法被收回!", - "swappedAbilitiesWithTarget": "{{pokemonName}}\n互換了各自的特性!", - "coinsScatteredEverywhere": "金幣散落一地!", - "attackedByItem": "{{pokemonName}}被\n{{itemName}}襲擊了!", - "whippedUpAWhirlwind": "{{pokemonName}}周圍的\n空氣產生了旋渦!", - "flewUpHigh": "{{pokemonName}}\n飛向了高空!", - "tookInSunlight": "{{pokemonName}}\n吸收了光線!", - "dugAHole": "{{pokemonName}}\n鑽進了地下!", - "loweredItsHead": "{{pokemonName}}\n把頭縮了進去!", - "isGlowing": "強光包圍了\n{{pokemonName}}!", - "bellChimed": "鈴聲響徹四周!", - "foresawAnAttack": "{{pokemonName}}\n預知了未來的攻擊!", - "isTighteningFocus": "{{pokemonName}}正在集中注意力!", - "hidUnderwater": "{{pokemonName}}\n潛入了水中!", - "soothingAromaWaftedThroughArea": "怡人的香氣擴散了開來!", - "sprangUp": "{{pokemonName}}\n高高地跳了起來!", - "choseDoomDesireAsDestiny": "{{pokemonName}}\n將破滅之願託付給了未來!", - "vanishedInstantly": "{{pokemonName}}的身影\n瞬間消失了!", - "tookTargetIntoSky": "{{pokemonName}}將{{targetName}}\n帶上了高空!", - "becameCloakedInFreezingLight": "{{pokemonName}}\n被冷光包圍了!", - "becameCloakedInFreezingAir": "{{pokemonName}}\n被冰凍的空氣包圍了!", - "isChargingPower": "{{pokemonName}}\n正在積蓄力量!", - "burnedItselfOut": "{{pokemonName}}的火焰燃盡了!", - "startedHeatingUpBeak": "{{pokemonName}}\n開始給鳥嘴加熱了!", - "setUpShellTrap": "{{pokemonName}}\n設下了陷阱甲殼!", - "isOverflowingWithSpacePower": "{{pokemonName}}湧起了宇宙的力量!", - "usedUpAllElectricity": "{{pokemonName}}\n用盡了電力!", - "stoleItem": "{{pokemonName}}从{{targetName}}那裏\n奪取了{{itemName}}!", - "incineratedItem": "{{pokemonName}}燒掉了\n{{targetName}}的{{itemName}}!", - "knockedOffItem": "{{pokemonName}}拍落了\n{{targetName}}的{{itemName}}!", - "tookMoveAttack": "{{pokemonName}}\n受到了{{moveName}}的攻擊!", - "cutOwnHpAndMaximizedStat": "{{pokemonName}}\n削減體力並釋放了全部{{statName}}!", - "copiedStatChanges": "{{pokemonName}}複製了\n{{targetName}}的能力變化!", - "magnitudeMessage": "震級{{magnitude}}!", - "tookAimAtTarget": "{{pokemonName}}將目標對準了\n{{targetName}}!", - "transformedIntoType": "{{pokemonName}} \n變成了{{typeName}}屬性!", - "copiedMove": "{{pokemonName}}\n複製了{{moveName}}!", - "sketchedMove": "{{pokemonName}}\n對{{moveName}}進行了寫生!", - "acquiredAbility": "{{pokemonName}}的特性\n變为{{abilityName}}了!", - "copiedTargetAbility": "{{pokemonName}}複製了\n{{targetName}}的{{abilityName}}!", - "transformedIntoTarget": "{{pokemonName}}\n變身成了{{targetName}}!", - "tryingToTakeFoeDown": "{{pokemonName}}\n想和對手同歸於盡!", - "addType": "{{pokemonName}}\n增加了{{typeName}}屬性!", - "cannotUseMove": "{{pokemonName}}\n無法使用{{moveName}}!", - "healHp": "{{pokemonName}}的\n體力回復了!", - "sacrificialFullRestore": "{{pokemonName}}的\n治癒之願實現了!", - "invertStats": "{{pokemonName}}的\n能力變化顛倒過來了!", - "resetStats": "{{pokemonName}}的\n能力變化復原了!", - "statEliminated": "所有能力都復原了!", - "faintCountdown": "{{pokemonName}}\n將在{{turnCount}}回合後滅亡!", - "copyType": "{{pokemonName}}變成了{{targetPokemonName}}的屬性!", - "suppressAbilities": "{{pokemonName}}的特性\n變得無效了!", - "revivalBlessing": "{{pokemonName}}復活了!", - "swapArenaTags": "{{pokemonName}}\n交換了雙方的場地效果!", - "exposedMove": "{{pokemonName}}識破了\n{{targetPokemonName}}的原形!", - "safeguard": "{{targetName}}\n正受到神秘之幕的保護!", - "afterYou": "{{pokemonName}}\n接受了對手的好意!" -} diff --git a/src/locales/zh_TW/move.json b/src/locales/zh_TW/move.json deleted file mode 100644 index b8c4ec05033..00000000000 --- a/src/locales/zh_TW/move.json +++ /dev/null @@ -1,3810 +0,0 @@ -{ - "pound": { - "name": "拍擊", - "effect": "使用長長的尾巴或手等拍打\n對手進行攻擊" - }, - "karateChop": { - "name": "空手劈", - "effect": "用鋒利的手刀劈向對手進行\n攻擊。容易擊中要害" - }, - "doubleSlap": { - "name": "連環巴掌", - "effect": "用連環巴掌拍打對手進行攻\n擊。連續攻擊2~5次" - }, - "cometPunch": { - "name": "連續拳", - "effect": "用拳頭怒濤般的毆打對手進\n行攻擊。連續攻擊2~5次" - }, - "megaPunch": { - "name": "百萬噸重拳", - "effect": "用充滿力量的拳頭攻擊對手" - }, - "payDay": { - "name": "聚寶功", - "effect": "向對手的身體投擲小金幣進\n行攻擊。戰鬥後可以拿到錢" - }, - "firePunch": { - "name": "火焰拳", - "effect": "用充滿火焰的拳頭攻擊對手。\n有時會讓對手陷入灼傷狀\n態" - }, - "icePunch": { - "name": "冰凍拳", - "effect": "用充滿寒氣的拳頭攻擊對手。\n有時會讓對手陷入冰凍狀\n態" - }, - "thunderPunch": { - "name": "雷電拳", - "effect": "用充滿電流的拳頭攻擊對手。\n有時會讓對手陷入麻痹狀\n態" - }, - "scratch": { - "name": "抓", - "effect": "用堅硬且無比鋒利的爪子抓\n對手進行攻擊" - }, - "viseGrip": { - "name": "夾住", - "effect": "將對手從兩側夾住,給予傷\n害" - }, - "guillotine": { - "name": "斷頭鉗", - "effect": "用大鉗子或剪刀等夾斷對手\n進行攻擊。只要命中就會一\n擊瀕死" - }, - "razorWind": { - "name": "旋風刀", - "effect": "製造風之刃,於第2回合攻\n擊對手。容易擊中要害" - }, - "swordsDance": { - "name": "劍舞", - "effect": "激烈地跳起戰舞提高氣勢。\n大幅提高自己的攻擊" - }, - "cut": { - "name": "居合斬", - "effect": "用鐮刀或爪子等切斬對手進\n行攻擊" - }, - "gust": { - "name": "起風", - "effect": "用翅膀將颳起的狂風襲向對\n手進行攻擊" - }, - "wingAttack": { - "name": "翅膀攻擊", - "effect": "大大地展開美麗的翅膀,將\n其撞向對手進行攻擊" - }, - "whirlwind": { - "name": "吹飛", - "effect": "吹飛對手,強制拉後備寶可\n夢上場。如果對手爲野生寶\n可夢,戰鬥將直接結束" - }, - "fly": { - "name": "飛翔", - "effect": "第1回合飛上天空,第2回\n合攻擊對手" - }, - "bind": { - "name": "綁緊", - "effect": "使用長長的身體或藤蔓等,\n在4~5回合內綁緊對手進\n行攻擊" - }, - "slam": { - "name": "摔打", - "effect": "使用長長的尾巴或藤蔓等摔\n打對手進行攻擊" - }, - "vineWhip": { - "name": "藤鞭", - "effect": "用如同鞭子般彎曲而細長的\n藤蔓摔打對手進行攻擊" - }, - "stomp": { - "name": "踩踏", - "effect": "用大腳踩踏對手進行攻擊。\n有時會使對手畏縮" - }, - "doubleKick": { - "name": "二連踢", - "effect": "用2隻腳踢飛對手進行攻擊。\n連續2次給予傷害" - }, - "megaKick": { - "name": "百萬噸重踢", - "effect": "使出力大無窮的重踢踢飛對\n手進行攻擊" - }, - "jumpKick": { - "name": "飛踢", - "effect": "使出高高的騰空踢攻擊對手。\n如果踢偏則自己會受到傷\n害" - }, - "rollingKick": { - "name": "迴旋踢", - "effect": "一邊使身體快速旋轉,一邊\n踢飛對手進行攻擊。有時會\n使對手畏縮" - }, - "sandAttack": { - "name": "潑沙", - "effect": "向對手臉上潑沙子,從而降\n低命中率" - }, - "headbutt": { - "name": "頭錘", - "effect": "將頭伸出,筆直地撲向對手\n進行攻擊。有時會使對手畏\n縮" - }, - "hornAttack": { - "name": "角撞", - "effect": "用尖銳的角攻擊對手" - }, - "furyAttack": { - "name": "亂擊", - "effect": "用角或喙刺向對手進行攻擊。\n連續攻擊2~5次" - }, - "hornDrill": { - "name": "角鑽", - "effect": "用旋轉的角刺入對手進行攻\n擊。只要命中就會一擊昏厥" - }, - "tackle": { - "name": "撞擊", - "effect": "用整個身體撞向對手進行攻\n擊" - }, - "bodySlam": { - "name": "泰山壓頂", - "effect": "用整個身體壓住對手進行攻\n擊。有時會讓對手陷入麻痹\n狀態" - }, - "wrap": { - "name": "緊束", - "effect": "使用長長的身體或藤蔓等,\n在4~5回合內緊束對手進\n行攻擊" - }, - "takeDown": { - "name": "猛撞", - "effect": "以驚人的氣勢撞向對手進行\n攻擊。自己也會受到少許傷\n害" - }, - "thrash": { - "name": "大鬧一番", - "effect": "在2~3回合內,亂打一氣\n地攻擊對手。大鬧一番後自\n己會陷入混亂" - }, - "doubleEdge": { - "name": "捨身衝撞", - "effect": "拼命地猛撞向對手進行攻擊。\n自己也會受到不小的傷害" - }, - "tailWhip": { - "name": "搖尾巴", - "effect": "可愛地左右搖晃尾巴,誘使\n對手疏忽大意。會降低對手\n的防禦" - }, - "poisonSting": { - "name": "毒針", - "effect": "將有毒的針刺入對手進行攻\n擊。有時會讓對手陷入中毒\n狀態" - }, - "twineedle": { - "name": "雙針", - "effect": "將2根針刺入對手,連續2\n次給予傷害。有時會讓對手\n陷入中毒狀態" - }, - "pinMissile": { - "name": "飛彈針", - "effect": "向對手發射銳針進行攻擊。\n連續攻擊2~5次" - }, - "leer": { - "name": "瞪眼", - "effect": "用犀利的眼神使其害怕,從\n而降低對手的防禦" - }, - "bite": { - "name": "咬住", - "effect": "用尖銳的牙咬住對手進行攻\n擊。有時會使對手畏縮" - }, - "growl": { - "name": "叫聲", - "effect": "讓對手聽可愛的叫聲,引開\n注意力使其疏忽,從而降低\n對手的攻擊" - }, - "roar": { - "name": "吼叫", - "effect": "放走對手,強制拉後備寶可\n夢上場。如果對手爲野生寶\n可夢,戰鬥將直接結束" - }, - "sing": { - "name": "唱歌", - "effect": "讓對手聽舒適、美妙的歌聲,\n從而陷入睡眠狀態" - }, - "supersonic": { - "name": "超音波", - "effect": "從身體發出特殊的音波,從\n而使對手混亂" - }, - "sonicBoom": { - "name": "音爆", - "effect": "將衝擊波撞向對手進行攻擊。\n必定會給予20的傷害" - }, - "disable": { - "name": "定身法", - "effect": "阻礙對手行動,之前使出的\n招式將在4回合內無法使用" - }, - "acid": { - "name": "溶解液", - "effect": "將強酸潑向對手進行攻擊。\n有時會降低對手的特防" - }, - "ember": { - "name": "火花", - "effect": "向對手發射小型火焰進行攻\n擊。有時會讓對手陷入灼傷\n狀態" - }, - "flamethrower": { - "name": "噴射火焰", - "effect": "向對手發射烈焰進行攻擊。\n有時會讓對手陷入灼傷狀態" - }, - "mist": { - "name": "白霧", - "effect": "用白霧覆蓋身體。在5回合\n內不會讓對手降低自己的能\n力" - }, - "waterGun": { - "name": "水槍", - "effect": "向對手猛烈地噴射水流進行\n攻擊" - }, - "hydroPump": { - "name": "水炮", - "effect": "向對手猛烈地噴射大量水流\n進行攻擊" - }, - "surf": { - "name": "衝浪", - "effect": "利用大浪攻擊自己周圍所有\n的寶可夢" - }, - "iceBeam": { - "name": "冰凍光束", - "effect": "向對手發射冰凍光束進行攻\n擊。有時會讓對手陷入冰凍\n狀態" - }, - "blizzard": { - "name": "暴風雪", - "effect": "將猛烈的暴風雪刮向對手進\n行攻擊。有時會讓對手陷入\n冰凍狀態" - }, - "psybeam": { - "name": "幻象光線", - "effect": "向對手發射神奇的光線進行\n攻擊。有時會使對手混亂" - }, - "bubbleBeam": { - "name": "泡沫光線", - "effect": "向對手猛烈地噴射泡沫進行\n攻擊。有時會降低對手的速\n度" - }, - "auroraBeam": { - "name": "極光束", - "effect": "向對手發射虹色光束進行攻\n擊。有時會降低對手的攻擊" - }, - "hyperBeam": { - "name": "破壞光線", - "effect": "向對手發射強烈的光線進行\n攻擊。下一回合自己將無法\n動彈" - }, - "peck": { - "name": "啄", - "effect": "用尖銳的喙或角刺向對手進\n行攻擊" - }, - "drillPeck": { - "name": "啄鑽", - "effect": "一邊旋轉,一邊將尖喙刺入\n對手進行攻擊" - }, - "submission": { - "name": "地獄翻滾", - "effect": "將對手連同自己一起摔向地\n面進行攻擊。自己也會受到\n少許傷害" - }, - "lowKick": { - "name": "踢倒", - "effect": "用力踢對手的腳,使其摔倒\n進行攻擊。對手越重,威力\n越大" - }, - "counter": { - "name": "雙倍奉還", - "effect": "從對手那裏受到物理攻擊的\n傷害將以2倍返還給同一個\n對手" - }, - "seismicToss": { - "name": "地球上投", - "effect": "利用引力將對手甩飛出去。\n給予對手和自己等級相同的\n傷害" - }, - "strength": { - "name": "怪力", - "effect": "使出渾身力氣毆打對手進行\n攻擊" - }, - "absorb": { - "name": "吸取", - "effect": "吸取對手的養分進行攻擊。\n可以回覆給予對手傷害的一\n半HP" - }, - "megaDrain": { - "name": "超級吸取", - "effect": "吸取對手的養分進行攻擊。\n可以回覆給予對手傷害的一\n半HP" - }, - "leechSeed": { - "name": "寄生種子", - "effect": "植入寄生種子後,將在每回\n合一點一點吸取對手的HP,\n從而用來回復自己的HP" - }, - "growth": { - "name": "生長", - "effect": "讓身體一下子長大,從而提\n高攻擊和特攻" - }, - "razorLeaf": { - "name": "飛葉快刀", - "effect": "飛出葉片,切斬對手進行攻\n擊。容易擊中要害" - }, - "solarBeam": { - "name": "日光束", - "effect": "第1回合收集滿滿的日光,\n第2回合發射光束進行攻擊" - }, - "poisonPowder": { - "name": "毒粉", - "effect": "撒出毒粉,從而讓對手陷入\n中毒狀態" - }, - "stunSpore": { - "name": "麻痹粉", - "effect": "撒出麻痹粉,從而讓對手陷\n入麻痹狀態" - }, - "sleepPowder": { - "name": "催眠粉", - "effect": "撒出催眠粉,從而讓對手陷\n入睡眠狀態" - }, - "petalDance": { - "name": "花瓣舞", - "effect": "在2~3回合內,散落花瓣\n攻擊對手。之後自己會陷入\n混亂" - }, - "stringShot": { - "name": "吐絲", - "effect": "用口中吐出的絲纏繞對手,\n從而大幅降低對手的速度" - }, - "dragonRage": { - "name": "龍之怒", - "effect": "將憤怒的衝擊波撞向對手進\n行攻擊。必定會給予40的\n傷害" - }, - "fireSpin": { - "name": "火焰旋渦", - "effect": "將對手困在激烈的火焰旋渦\n中,在4~5回合內進行攻\n擊" - }, - "thunderShock": { - "name": "電擊", - "effect": "發出電流刺激對手進行攻擊。\n有時會讓對手陷入麻痹狀\n態" - }, - "thunderbolt": { - "name": "十萬伏特", - "effect": "向對手發出強力電擊進行攻\n擊。有時會讓對手陷入麻痹\n狀態" - }, - "thunderWave": { - "name": "電磁波", - "effect": "向對手發出微弱的電擊,從\n而讓對手陷入麻痹狀態" - }, - "thunder": { - "name": "打雷", - "effect": "向對手劈下暴雷進行攻擊。\n有時會讓對手陷入麻痹狀態" - }, - "rockThrow": { - "name": "落石", - "effect": "拿起小岩石,投擲對手進行\n攻擊" - }, - "earthquake": { - "name": "地震", - "effect": "利用地震的衝擊,攻擊自己\n周圍所有的寶可夢" - }, - "fissure": { - "name": "地裂", - "effect": "讓對手掉落於地裂的裂縫中\n進行攻擊。只要命中就會一\n擊瀕死" - }, - "dig": { - "name": "挖洞", - "effect": "第1回合鑽入地底,第2回\n合攻擊對手" - }, - "toxic": { - "name": "劇毒", - "effect": "讓對手陷入劇毒狀態。隨着\n回合的推進,中毒傷害會增\n加" - }, - "confusion": { - "name": "念力", - "effect": "向對手發送微弱的念力進行\n攻擊。有時會使對手混亂" - }, - "psychic": { - "name": "精神強念", - "effect": "向對手發送強大的念力進行\n攻擊。有時會降低對手的特\n防" - }, - "hypnosis": { - "name": "催眠術", - "effect": "施以誘導睡意的暗示,讓對\n手陷入睡眠狀態" - }, - "meditate": { - "name": "瑜伽姿勢", - "effect": "喚醒身體深處沉睡的力量,\n從而提高自己的攻擊" - }, - "agility": { - "name": "高速移動", - "effect": "讓身體放鬆變得輕盈,以便\n高速移動。大幅提高自己的\n速度" - }, - "quickAttack": { - "name": "電光一閃", - "effect": "以迅雷不及掩耳之勢撲向對\n手。必定能夠先制攻擊" - }, - "rage": { - "name": "憤怒", - "effect": "如果在使出招式後受到攻擊\n的話,會因憤怒的力量而提\n高攻擊" - }, - "teleport": { - "name": "瞬間移動", - "effect": "當有後備寶可夢時使用,就\n可以進行替換。野生的寶可\n夢使用則會逃走" - }, - "nightShade": { - "name": "黑夜魔影", - "effect": "顯示恐怖幻影,只給予對手\n和自己等級相同的傷害" - }, - "mimic": { - "name": "模仿", - "effect": "可以將對手最後使用的招式,\n在戰鬥內變成自己的招式" - }, - "screech": { - "name": "刺耳聲", - "effect": "發出不由自主想要捂起耳朵\n的刺耳聲,從而大幅降低對\n手的防禦" - }, - "doubleTeam": { - "name": "影子分身", - "effect": "通過快速移動來製造分身,\n擾亂對手,從而提高閃避率" - }, - "recover": { - "name": "自我再生", - "effect": "讓細胞再生,從而回復自己\n最大HP的一半" - }, - "harden": { - "name": "變硬", - "effect": "全身使勁,讓身體變硬,從\n而提高自己的防禦" - }, - "minimize": { - "name": "變小", - "effect": "蜷縮身體顯得很小,從而大\n幅提高自己的閃避率" - }, - "smokescreen": { - "name": "煙幕", - "effect": "向對手噴出煙或墨汁等,從\n而降低對手的命中率" - }, - "confuseRay": { - "name": "奇異之光", - "effect": "顯示奇怪的光,擾亂對手。\n使對手混亂" - }, - "withdraw": { - "name": "縮入殼中", - "effect": "縮入殼裏保護身體,從而提\n高自己的防禦" - }, - "defenseCurl": { - "name": "變圓", - "effect": "將身體蜷曲變圓,從而提高\n自己的防禦" - }, - "barrier": { - "name": "屏障", - "effect": "製造堅固的壁障,從而大幅\n提高自己的防禦" - }, - "lightScreen": { - "name": "光牆", - "effect": "利用神奇的牆壁,在5回合\n內減弱從對手那裏受到的特\n殊攻擊的傷害" - }, - "haze": { - "name": "黑霧", - "effect": "升起黑霧,將正在場上戰鬥\n的全體寶可夢的能力變回原\n點" - }, - "reflect": { - "name": "反射壁", - "effect": "利用神奇的牆壁,在5回合\n內減弱從對手那裏受到的物\n理攻擊的傷害" - }, - "focusEnergy": { - "name": "聚氣", - "effect": "深深地吸口氣,集中精神。\n自己的攻擊會變得容易擊中\n要害" - }, - "bide": { - "name": "忍耐", - "effect": "在2回合內忍受攻擊,受到\n的傷害會2倍返還給對手" - }, - "metronome": { - "name": "揮指", - "effect": "揮動手指刺激自己的大腦,\n從許多的招式中隨機使出1\n個" - }, - "mirrorMove": { - "name": "鸚鵡學舌", - "effect": "模仿對手使用的招式,自己\n也使用相同招式" - }, - "selfDestruct": { - "name": "自爆", - "effect": "引發爆炸,攻擊自己周圍所\n有的寶可夢。使用後陷入瀕\n死" - }, - "eggBomb": { - "name": "炸蛋", - "effect": "向對手用力投擲大大的蛋進\n行攻擊" - }, - "lick": { - "name": "舌舔", - "effect": "用長長的舌頭,舔遍對手進\n行攻擊。有時會讓對手陷入\n麻痹狀態" - }, - "smog": { - "name": "濁霧", - "effect": "將骯髒的濃霧吹向對手進行\n攻擊。有時會讓對手陷入中\n毒狀態" - }, - "sludge": { - "name": "污泥攻擊", - "effect": "用污泥投擲對手進行攻擊。\n有時會讓對手陷入中毒狀態" - }, - "boneClub": { - "name": "骨棒", - "effect": "用手中的骨頭毆打對手進行\n攻擊。有時會使對手畏縮" - }, - "fireBlast": { - "name": "大字爆炎", - "effect": "用大字形狀的火焰燒盡對手。\n有時會讓對手陷入灼傷狀\n態" - }, - "waterfall": { - "name": "攀瀑", - "effect": "以驚人的氣勢撲向對手。有\n時會使對手畏縮" - }, - "clamp": { - "name": "貝殼夾擊", - "effect": "用非常堅固且厚實的貝殼,\n在4~5回合內夾住對手進\n行攻擊" - }, - "swift": { - "name": "高速星星", - "effect": "發射星形的光攻擊對手。攻\n擊必定會命中" - }, - "skullBash": { - "name": "火箭頭錘", - "effect": "第1回合把頭縮進去,從而\n提高防禦。第2回合攻擊對\n手" - }, - "spikeCannon": { - "name": "尖刺加農炮", - "effect": "向對手發射銳針進行攻擊。\n連續攻擊2~5次" - }, - "constrict": { - "name": "纏繞", - "effect": "用觸手或青藤等纏繞進行攻\n擊。有時會降低對手的速度" - }, - "amnesia": { - "name": "瞬間失憶", - "effect": "將頭腦清空,瞬間忘記某事,\n從而大幅提高自己的特防" - }, - "kinesis": { - "name": "折彎湯匙", - "effect": "折彎湯匙引開注意,從而降\n低對手的命中率" - }, - "softBoiled": { - "name": "生蛋", - "effect": "回覆自己最大HP的一半" - }, - "highJumpKick": { - "name": "飛膝踢", - "effect": "跳起後用膝蓋撞對手進行攻\n擊。如果撞偏則自己會受到\n傷害" - }, - "glare": { - "name": "大蛇瞪眼", - "effect": "用腹部的花紋使對手害怕,\n從而讓其陷入麻痹狀態" - }, - "dreamEater": { - "name": "食夢", - "effect": "喫掉正在睡覺的對手的夢進\n行攻擊。回覆對手所受到傷\n害的一半HP" - }, - "poisonGas": { - "name": "毒瓦斯", - "effect": "將毒瓦斯吹到對手的臉上,\n從而讓對手陷入中毒狀態" - }, - "barrage": { - "name": "投球", - "effect": "向對手投擲圓形物體進行攻\n擊。連續攻擊2~5次" - }, - "leechLife": { - "name": "吸血", - "effect": "吸取血液攻擊對手。可以回\n復給予對手傷害的一半HP" - }, - "lovelyKiss": { - "name": "惡魔之吻", - "effect": "用恐怖的臉強吻對手。讓對\n手陷入睡眠狀態" - }, - "skyAttack": { - "name": "神鳥猛擊", - "effect": "第2回合攻擊對手。偶爾使\n對手畏縮。也容易擊中要害" - }, - "transform": { - "name": "變身", - "effect": "變身成對手寶可夢的樣子,\n能夠使用和對手完全相同的\n招式" - }, - "bubble": { - "name": "泡沫", - "effect": "向對手用力吹起無數泡泡進\n行攻擊。有時會降低對手的\n速度" - }, - "dizzyPunch": { - "name": "迷昏拳", - "effect": "有節奏地出拳攻擊對手。有\n時會使對手混亂" - }, - "spore": { - "name": "蘑菇孢子", - "effect": "沙沙沙地撒滿具有催眠效果\n的孢子,從而讓對手陷入睡\n眠狀態" - }, - "flash": { - "name": "閃光", - "effect": "使出光芒,從而降低對手的\n命中率。也可在陰暗的洞窟\n裏照亮四周" - }, - "psywave": { - "name": "精神波", - "effect": "向對手發射神奇的念波進行\n攻擊。每次使用,傷害都會\n改變" - }, - "splash": { - "name": "躍起", - "effect": "也不攻擊只是一蹦一蹦地跳,\n什麼都不會發生…" - }, - "acidArmor": { - "name": "溶化", - "effect": "通過細胞的變化進行液化,\n從而大幅提高自己的防禦" - }, - "crabhammer": { - "name": "蟹鉗錘", - "effect": "用大鉗子敲打對手進行攻擊。\n容易擊中要害" - }, - "explosion": { - "name": "大爆炸", - "effect": "引發大爆炸,攻擊自己周圍\n所有的寶可夢。使用後自己\n會陷入瀕死" - }, - "furySwipes": { - "name": "亂抓", - "effect": "用爪子或鐮刀等抓對手進行\n攻擊。連續攻擊2~5次" - }, - "bonemerang": { - "name": "骨頭回力鏢", - "effect": "用手中的骨頭投擲對手,來\n回連續2次給予傷害" - }, - "rest": { - "name": "睡覺", - "effect": "連續睡上2回合。回覆自己\n的全部HP以及治癒所有異\n常狀態" - }, - "rockSlide": { - "name": "岩崩", - "effect": "將大岩石猛烈地撞向對手進\n行攻擊。有時會使對手畏縮" - }, - "hyperFang": { - "name": "必殺門牙", - "effect": "用鋒利的門牙牢牢地咬住對\n手進行攻擊。有時會使對手\n畏縮" - }, - "sharpen": { - "name": "稜角化", - "effect": "增加身體的角,變得棱棱角\n角,從而提高自己的攻擊" - }, - "conversion": { - "name": "紋理", - "effect": "將自己的屬性轉換成和已學\n會的招式中第一個招式相同\n的屬性" - }, - "triAttack": { - "name": "三重攻擊", - "effect": "用3種光線進行攻擊。有時\n會讓對手陷入麻痹、灼傷或\n冰凍的狀態" - }, - "superFang": { - "name": "憤怒門牙", - "effect": "用鋒利的門牙猛烈地咬住對\n手進行攻擊。對手的HP減\n半" - }, - "slash": { - "name": "劈開", - "effect": "用爪子或鐮刀等劈開對手進\n行攻擊。容易擊中要害" - }, - "substitute": { - "name": "替身", - "effect": "削減少許自己的HP,製造\n分身。分身將成爲自己的替\n身" - }, - "struggle": { - "name": "掙扎", - "effect": "當自己的PP耗盡時,努力\n掙扎攻擊對手。自己也會受\n到少許傷害" - }, - "sketch": { - "name": "寫生", - "effect": "將對手使用的招式變成自己\n的招式。使用1次後寫生消\n失" - }, - "tripleKick": { - "name": "三連踢", - "effect": "連續3次踢對手進行攻擊。\n每踢中一次,威力就會提高" - }, - "thief": { - "name": "小偷", - "effect": "攻擊的同時盜取道具。當自\n己攜帶道具時,不會去盜取" - }, - "spiderWeb": { - "name": "蛛網", - "effect": "將黏糊糊的細絲一層一層纏\n住對手,使其不能從戰鬥中\n逃走" - }, - "mindReader": { - "name": "心之眼", - "effect": "用心感受對手的行動,下次\n攻擊必定會擊中對手" - }, - "nightmare": { - "name": "惡夢", - "effect": "讓在睡眠狀態下的對手做惡\n夢,每回合會緩緩減少HP" - }, - "flameWheel": { - "name": "火焰輪", - "effect": "讓火焰覆蓋全身,猛撞向對\n手進行攻擊。有時會讓對手\n陷入灼傷狀態" - }, - "snore": { - "name": "打鼾", - "effect": "在自己睡覺時,發出噪音進\n行攻擊。有時會使對手畏縮" - }, - "curse": { - "name": "詛咒", - "effect": "使用該招式的寶可夢,其屬\n性是幽靈屬性或其他屬性時,\n效果會不一樣" - }, - "flail": { - "name": "抓狂", - "effect": "抓狂般亂打進行攻擊。自己\n的HP越少,招式的威力越\n大" - }, - "conversion2": { - "name": "紋理2", - "effect": "爲了可以抵抗對手最後使用\n的招式,從而使自己的屬性\n發生變化" - }, - "aeroblast": { - "name": "氣旋攻擊", - "effect": "發射空氣旋渦進行攻擊。容\n易擊中要害" - }, - "cottonSpore": { - "name": "棉孢子", - "effect": "將棉花般柔軟的孢子緊貼對\n手,從而大幅降低對手的速\n度" - }, - "reversal": { - "name": "起死回生", - "effect": "竭盡全力進行攻擊。自己的\nHP越少,招式的威力越大" - }, - "spite": { - "name": "怨恨", - "effect": "對對手最後使用的招式懷有\n怨恨,減少4PP該招式" - }, - "powderSnow": { - "name": "細雪", - "effect": "將冰冷的細雪吹向對手進行\n攻擊。有時會讓對手陷入冰\n凍狀態" - }, - "protect": { - "name": "守住", - "effect": "完全抵擋對手的攻擊。連續\n使出則容易失敗" - }, - "machPunch": { - "name": "音速拳", - "effect": "以迅雷不及掩耳之勢出拳。\n必定能夠先制攻擊" - }, - "scaryFace": { - "name": "鬼面", - "effect": "用恐怖的表情瞪着對手,使\n其害怕,從而大幅降低對手\n的速度" - }, - "feintAttack": { - "name": "出奇一擊", - "effect": "悄悄地靠近對手,趁其不備\n進行毆打。攻擊必定會命中" - }, - "sweetKiss": { - "name": "天使之吻", - "effect": "像天使般可愛地親吻對手,\n從而使對手混亂" - }, - "bellyDrum": { - "name": "腹鼓", - "effect": "將自己的HP減少到最大\nHP的一半,從而最大限度提\n高自己的攻擊" - }, - "sludgeBomb": { - "name": "污泥炸彈", - "effect": "用污泥投擲對手進行攻擊。\n有時會讓對手陷入中毒狀態" - }, - "mudSlap": { - "name": "擲泥", - "effect": "向對手的臉等投擲泥塊進行\n攻擊。會降低對手的命中率" - }, - "octazooka": { - "name": "章魚桶炮", - "effect": "向對手的臉等噴出墨汁進行\n攻擊。有時會降低對手的命\n中率" - }, - "spikes": { - "name": "撒菱", - "effect": "在對手的腳下扔撒菱。對替\n換出場的對手的寶可夢給予\n傷害" - }, - "zapCannon": { - "name": "電磁炮", - "effect": "發射大炮一樣的電流進行攻\n擊。讓對手陷入麻痹狀態" - }, - "foresight": { - "name": "識破", - "effect": "使出後對幽靈屬性寶可夢沒\n有效果的招式以及閃避率高\n的對手,變得能夠打中" - }, - "destinyBond": { - "name": "同命", - "effect": "使出招式後,當受到對手攻\n擊陷入瀕死時,對手也會一\n同瀕死。連續使出則會失敗" - }, - "perishSong": { - "name": "滅亡之歌", - "effect": "傾聽歌聲的寶可夢經過3回\n合陷入瀕死。替換後效果消\n失" - }, - "icyWind": { - "name": "冰凍之風", - "effect": "將結冰的冷氣吹向對手進行\n攻擊。會降低對手的速度" - }, - "detect": { - "name": "看穿", - "effect": "完全抵擋對手的攻擊。連續\n使出則容易失敗" - }, - "boneRush": { - "name": "骨棒亂打", - "effect": "用堅硬的骨頭毆打對手進行\n攻擊。連續攻擊2~5次" - }, - "lockOn": { - "name": "鎖定", - "effect": "緊緊瞄準對手,下次攻擊必\n定會打中" - }, - "outrage": { - "name": "逆鱗", - "effect": "在2~3回合內,亂打一氣\n地進行攻擊。大鬧一番後自\n己會陷入混亂" - }, - "sandstorm": { - "name": "沙暴", - "effect": "在5回合內揚起沙暴,除巖\n石、地面和鋼屬性以外的寶\n可夢,都會受到傷害。岩石\n屬性的特防還會提高" - }, - "gigaDrain": { - "name": "終極吸取", - "effect": "吸取對手的養分進行攻擊。\n可以回覆給予對手傷害的一\n半HP" - }, - "endure": { - "name": "挺住", - "effect": "即使受到攻擊,也至少會留\n下1HP。連續使出則容易\n失敗" - }, - "charm": { - "name": "撒嬌", - "effect": "可愛地凝視,誘使對手疏忽\n大意,從而大幅降低對手的\n攻擊" - }, - "rollout": { - "name": "滾動", - "effect": "在5回合內連續滾動攻擊對\n手。招式每次擊中,威力就\n會提高" - }, - "falseSwipe": { - "name": "點到爲止", - "effect": "對手的HP至少會留下1\nHP,如此般手下留情地攻擊" - }, - "swagger": { - "name": "虛張聲勢", - "effect": "激怒對手,使其混亂。因爲\n憤怒,對手的攻擊會大幅提\n高" - }, - "milkDrink": { - "name": "喝牛奶", - "effect": "回覆自己最大HP的一半" - }, - "spark": { - "name": "電光", - "effect": "讓電流覆蓋全身,猛撞向對\n手進行攻擊。有時會讓對手\n陷入麻痹狀態" - }, - "furyCutter": { - "name": "連斬", - "effect": "用鐮刀或爪子等切斬對手進\n行攻擊。連續擊中,威力就\n會提高" - }, - "steelWing": { - "name": "鋼翼", - "effect": "用堅硬的翅膀敲打對手進行\n攻擊。有時會提高自己的防\n御" - }, - "meanLook": { - "name": "黑色目光", - "effect": "用好似要勾人心魂的黑色目\n光一動不動地凝視對手,使\n其不能從戰鬥中逃走" - }, - "attract": { - "name": "迷人", - "effect": "♂誘惑♀或♀誘惑♂,讓對\n手着迷。對手將很難使出招\n式" - }, - "sleepTalk": { - "name": "夢話", - "effect": "從自己已學會的招式中任意\n使出1個。只能在自己睡覺\n時使用" - }, - "healBell": { - "name": "治癒鈴聲", - "effect": "讓同伴聽舒適的鈴音,從而\n治癒我方全員的異常狀態" - }, - "return": { - "name": "報恩", - "effect": "爲了訓練家而全力攻擊對手。\n親密度越高,威力越大" - }, - "present": { - "name": "禮物", - "effect": "遞給對手設有圈套的盒子進\n行攻擊。也有可能回覆對手\nHP" - }, - "frustration": { - "name": "遷怒", - "effect": "爲了發泄不滿而全力攻擊對\n手。親密度越低,威力越大" - }, - "safeguard": { - "name": "神祕守護", - "effect": "在5回合內被神奇的力量守\n護,從而不會陷入異常狀態" - }, - "painSplit": { - "name": "分擔痛楚", - "effect": "將自己的HP和對手的HP\n相加,然後自己和對手友好\n地平分" - }, - "sacredFire": { - "name": "神聖之火", - "effect": "用神祕的火焰燒盡對手進行\n攻擊。有時會讓對手陷入灼\n傷狀態" - }, - "magnitude": { - "name": "震級", - "effect": "晃動地面,攻擊自己周圍所\n有的寶可夢。招式的威力會\n有各種變化" - }, - "dynamicPunch": { - "name": "爆裂拳", - "effect": "使出渾身力氣出拳進行攻擊。\n必定會使對手混亂" - }, - "megahorn": { - "name": "超級角擊", - "effect": "用堅硬且華麗的角狠狠地刺\n入對手進行攻擊" - }, - "dragonBreath": { - "name": "龍息", - "effect": "將強烈的氣息吹向對手進行\n攻擊。有時會讓對手陷入麻\n痹狀態" - }, - "batonPass": { - "name": "接棒", - "effect": "和後備寶可夢進行替換。換\n上的寶可夢能直接繼承其能\n力的變化" - }, - "encore": { - "name": "再來一次", - "effect": "讓對手接受再來一次,連續\n3次使出最後使用的招式" - }, - "pursuit": { - "name": "追打", - "effect": "當對手替換寶可夢上場時使\n出此招式的話,能夠以2倍\n的威力進行攻擊" - }, - "rapidSpin": { - "name": "高速旋轉", - "effect": "通過旋轉來攻擊對手。可以\n擺脫綁緊、緊束、寄生種子\n等招式。還能提高自己的速\n度" - }, - "sweetScent": { - "name": "甜甜香氣", - "effect": "用香氣大幅降低對手的閃避\n率" - }, - "ironTail": { - "name": "鐵尾", - "effect": "使用堅硬的尾巴摔打對手進\n行攻擊。有時會降低對手的\n防禦" - }, - "metalClaw": { - "name": "金屬爪", - "effect": "用鋼鐵之爪劈開對手進行攻\n擊。有時會提高自己的攻擊" - }, - "vitalThrow": { - "name": "借力摔", - "effect": "會在對手之後進行攻擊。但\n是自己的攻擊必定會命中" - }, - "morningSun": { - "name": "晨光", - "effect": "回覆自己的HP。根據天氣\n的不同,回覆量也會有所變\n化" - }, - "synthesis": { - "name": "光合作用", - "effect": "回覆自己的HP。根據天氣\n的不同,回覆量也會有所變\n化" - }, - "moonlight": { - "name": "月光", - "effect": "回覆自己的HP。根據天氣\n的不同,回覆量也會有所變\n化" - }, - "hiddenPower": { - "name": "覺醒力量", - "effect": "招式的屬性會隨着使用此招\n式的寶可夢而改變" - }, - "crossChop": { - "name": "十字劈", - "effect": "用兩手呈十字劈打對手進行\n攻擊。容易擊中要害" - }, - "twister": { - "name": "龍捲風", - "effect": "興起龍捲風,將對手卷入進\n行攻擊。有時會使對手畏縮" - }, - "rainDance": { - "name": "求雨", - "effect": "在5回合內一直降雨,從而\n提高水屬性的招式威力。火\n屬性的招式威力則降低" - }, - "sunnyDay": { - "name": "大晴天", - "effect": "在5回合內讓日照變得強烈,\n從而提高火屬性的招式威\n力。水屬性的招式威力則降\n低" - }, - "crunch": { - "name": "咬碎", - "effect": "用利牙咬碎對手進行攻擊。\n有時會降低對手的防禦" - }, - "mirrorCoat": { - "name": "鏡面反射", - "effect": "從對手那裏受到特殊攻擊的\n傷害將以2倍返還給同一個\n對手" - }, - "psychUp": { - "name": "自我暗示", - "effect": "向自己施以自我暗示,將能\n力變化的狀態變得和對手一\n樣" - }, - "extremeSpeed": { - "name": "神速", - "effect": "以迅雷不及掩耳之勢猛撞向\n對手進行攻擊。必定能夠先\n制攻擊" - }, - "ancientPower": { - "name": "原始之力", - "effect": "用原始之力進行攻擊。有時\n會提高自己所有的能力" - }, - "shadowBall": { - "name": "暗影球", - "effect": "投擲一團黑影進行攻擊。有\n時會降低對手的特防" - }, - "futureSight": { - "name": "預知未來", - "effect": "在使用招式2回合後,向對\n手發送一團念力進行攻擊" - }, - "rockSmash": { - "name": "碎岩", - "effect": "用拳頭進行攻擊。有時會降\n低對手的防禦" - }, - "whirlpool": { - "name": "潮旋", - "effect": "將對手困在激烈的水流旋渦\n中,在4~5回合內進行攻\n擊" - }, - "beatUp": { - "name": "圍攻", - "effect": "我方全員進行攻擊。同行的\n寶可夢越多,招式的攻擊次\n數越多" - }, - "fakeOut": { - "name": "擊掌奇襲", - "effect": "進行先制攻擊,使對手畏縮。\n要在出場後立刻使出才能\n成功" - }, - "uproar": { - "name": "吵鬧", - "effect": "在3回合內大吵大鬧攻擊對\n手。在此期間誰都不能入眠" - }, - "stockpile": { - "name": "蓄力", - "effect": "積蓄力量,提高自己的防禦\n和特防。最多積蓄3次" - }, - "spitUp": { - "name": "噴出", - "effect": "將積蓄的力量撞向對手進行\n攻擊。積蓄得越多,威力越\n大" - }, - "swallow": { - "name": "吞下", - "effect": "將積蓄的力量吞下,從而回\n復自己的HP。積蓄得越多,\n回覆越大" - }, - "heatWave": { - "name": "熱風", - "effect": "將炎熱的氣息吹向對手進行\n攻擊。有時會讓對手陷入灼\n傷狀態" - }, - "hail": { - "name": "冰雹", - "effect": "在5回合內一直降冰雹,除\n冰屬性的寶可夢以外,給予\n全體寶可夢傷害" - }, - "torment": { - "name": "無理取鬧", - "effect": "向對手無理取鬧,令其不能\n連續2次使出相同招式" - }, - "flatter": { - "name": "吹捧", - "effect": "吹捧對手,使其混亂。同時\n還會提高對手的特攻" - }, - "willOWisp": { - "name": "鬼火", - "effect": "放出怪異的火焰,從而讓對\n手陷入灼傷狀態" - }, - "memento": { - "name": "臨別禮物", - "effect": "雖然會使自己陷入昏厥,但\n是能夠大幅降低對手的攻擊\n和特攻" - }, - "facade": { - "name": "硬撐", - "effect": "當自己處於中毒、麻痹、灼\n傷狀態時,向對手使出此招\n式的話,威力會變成2倍" - }, - "focusPunch": { - "name": "真氣拳", - "effect": "集中精神出拳。在招式使出\n前若受到攻擊則會失敗" - }, - "smellingSalts": { - "name": "清醒", - "effect": "對於麻痹狀態下的對手,威\n力會變成2倍。但相反對手\n的麻痹也會被治癒" - }, - "followMe": { - "name": "看我嘛", - "effect": "引起對手的注意,將對手的\n攻擊全部轉移到自己身上" - }, - "naturePower": { - "name": "自然之力", - "effect": "用自然之力進行攻擊。根據\n所使用場所的不同,使出的\n招式也會有所變化" - }, - "charge": { - "name": "充電", - "effect": "變爲充電狀態,提高下次使\n出的電屬性的招式威力。自\n己的特防也會提高" - }, - "taunt": { - "name": "挑釁", - "effect": "使對手憤怒。在3回合內讓\n對手只能使出給予傷害的招\n式" - }, - "helpingHand": { - "name": "幫助", - "effect": "幫助夥伴。被幫助的寶可夢,\n其招式威力變得比平時大" - }, - "trick": { - "name": "戲法", - "effect": "抓住對手的空隙,交換自己\n和對手的持有物" - }, - "rolePlay": { - "name": "扮演", - "effect": "扮演對手,讓自己的特性變\n得和對手相同" - }, - "wish": { - "name": "祈願", - "effect": "在下一回合回覆自己或是替\n換出場的寶可夢最大HP的\n一半" - }, - "assist": { - "name": "藉助", - "effect": "向同伴緊急求助,從我方寶\n可夢已學會的招式中隨機使\n用1個" - }, - "ingrain": { - "name": "扎根", - "effect": "在大地上扎根,每回合回覆\n自己的HP。因爲扎根了,\n所以不能替換寶可夢" - }, - "superpower": { - "name": "蠻力", - "effect": "發揮驚人的力量攻擊對手。\n自己的攻擊和防禦會降低" - }, - "magicCoat": { - "name": "魔法反射", - "effect": "當對手使出會變成異常狀態\n的招式或寄生種子等時,會\n將對手的招式反射回去" - }, - "recycle": { - "name": "回收利用", - "effect": "使戰鬥中已經消耗掉的自己\n的持有物再生,並可以再次\n使用" - }, - "revenge": { - "name": "報復", - "effect": "如果受到對手的招式攻擊,\n就能給予對手2倍的傷害" - }, - "brickBreak": { - "name": "劈瓦", - "effect": "將手刀猛烈地揮下攻擊對手。\n還可以破壞光牆和反射壁\n等" - }, - "yawn": { - "name": "哈欠", - "effect": "打個大哈欠引起睡意。在下\n一回合讓對手陷入睡眠狀態" - }, - "knockOff": { - "name": "拍落", - "effect": "拍落對手的持有物,直到戰\n鬥結束都不能使用。對手攜\n帶道具時會增加傷害" - }, - "endeavor": { - "name": "蠻幹", - "effect": "給予傷害,使對手的HP變\n得和自己的HP一樣" - }, - "eruption": { - "name": "噴火", - "effect": "爆發怒火攻擊對手。自己的\nHP越少,招式的威力越小" - }, - "skillSwap": { - "name": "特性互換", - "effect": "利用超能力互換自己和對手\n的特性" - }, - "imprison": { - "name": "封印", - "effect": "如果對手有和自己相同的招\n式,那麼只有對手無法使用\n該招式" - }, - "refresh": { - "name": "煥然一新", - "effect": "讓身體休息,治癒自己身上\n所中的毒、麻痹、灼傷的異\n常狀態" - }, - "grudge": { - "name": "怨念", - "effect": "因對手的招式而陷入昏厥時\n給對手施加怨念,讓該招式\n的PP變成0" - }, - "snatch": { - "name": "搶奪", - "effect": "將對手打算使用的回覆招式\n或能力變化招式奪爲己用" - }, - "secretPower": { - "name": "祕密之力", - "effect": "根據使用場所不同,該招式\n的追加效果也會有所變化" - }, - "dive": { - "name": "潛水", - "effect": "第1回合潛入水中,第2回\n合浮上來進行攻擊" - }, - "armThrust": { - "name": "猛推", - "effect": "用張開着的雙手猛推對手進\n行攻擊。連續攻擊2~5次" - }, - "camouflage": { - "name": "保護色", - "effect": "根據所在場所不同,如水邊\n、草叢和洞窟等,可以改變\n自己的屬性" - }, - "tailGlow": { - "name": "螢火", - "effect": "凝視閃爍的光芒,集中自己\n的精神,從而巨幅提高特攻" - }, - "lusterPurge": { - "name": "潔淨光芒", - "effect": "釋放耀眼的光芒進行攻擊。\n有時會降低對手的特防" - }, - "mistBall": { - "name": "薄霧球", - "effect": "用圍繞着霧狀羽毛的球進行\n攻擊。有時會降低對手的特\n攻" - }, - "featherDance": { - "name": "羽毛舞", - "effect": "撒出羽毛,籠罩在對手的周\n圍。大幅降低對手的攻擊" - }, - "teeterDance": { - "name": "搖晃舞", - "effect": "搖搖晃晃地跳起舞蹈,讓自\n己周圍的寶可夢陷入混亂狀\n態" - }, - "blazeKick": { - "name": "火焰踢", - "effect": "攻擊對手後,有時會使其陷\n入灼傷狀態。也容易擊中要\n害" - }, - "mudSport": { - "name": "玩泥巴", - "effect": "一旦使用此招式,周圍就會\n弄得到處是泥。在5回合內\n減弱電屬性的招式" - }, - "iceBall": { - "name": "冰球", - "effect": "在5回合內攻擊對手。招式\n每次擊中,威力就會提高" - }, - "needleArm": { - "name": "尖刺臂", - "effect": "用帶刺的手臂猛烈地揮舞進\n行攻擊。有時會使對手畏縮" - }, - "slackOff": { - "name": "偷懶", - "effect": "偷懶休息。回覆自己最大\nHP的一半" - }, - "hyperVoice": { - "name": "巨聲", - "effect": "給予對手又吵又響的巨大震\n動進行攻擊" - }, - "poisonFang": { - "name": "劇毒牙", - "effect": "用有毒的牙齒咬住對手進行\n攻擊。有時會使對手中劇毒" - }, - "crushClaw": { - "name": "撕裂爪", - "effect": "用堅硬的銳爪劈開對手進行\n攻擊。有時會降低對手的防\n御" - }, - "blastBurn": { - "name": "爆炸烈焰", - "effect": "用爆炸的火焰燒盡對手進行\n攻擊。下一回合自己將無法\n動彈" - }, - "hydroCannon": { - "name": "加農水炮", - "effect": "向對手噴射水炮進行攻擊。\n下一回合自己將無法動彈" - }, - "meteorMash": { - "name": "彗星拳", - "effect": "使出彗星般的拳頭攻擊對手。\n有時會提高自己的攻擊" - }, - "astonish": { - "name": "驚嚇", - "effect": "用尖叫聲等突然驚嚇對手進\n行攻擊。有時會使對手畏縮" - }, - "weatherBall": { - "name": "氣象球", - "effect": "根據使用時的天氣,招式屬\n性和威力會改變" - }, - "aromatherapy": { - "name": "芳香治療", - "effect": "讓同伴聞沁人心脾的香氣,\n從而治癒我方全員的異常狀\n態" - }, - "fakeTears": { - "name": "假哭", - "effect": "裝哭流淚。使對手不知所措,\n從而大幅降低對手的特防" - }, - "airCutter": { - "name": "空氣利刃", - "effect": "用銳利的風切斬對手進行攻\n擊。容易擊中要害" - }, - "overheat": { - "name": "過熱", - "effect": "使出全部力量攻擊對手。使\n用之後會因爲反作用力,自\n己的特攻大幅降低" - }, - "odorSleuth": { - "name": "氣味偵測", - "effect": "使出後對幽靈屬性寶可夢沒\n有效果的招式以及閃避率高\n的對手,變得能夠打中" - }, - "rockTomb": { - "name": "岩石封鎖", - "effect": "投擲岩石進行攻擊。封住對\n手的行動,從而降低速度" - }, - "silverWind": { - "name": "銀色旋風", - "effect": "在風中摻入鱗粉攻擊對手。\n有時會提高自己的全部能力" - }, - "metalSound": { - "name": "金屬音", - "effect": "讓對手聽摩擦金屬般討厭的\n聲音。大幅降低對手的特防" - }, - "grassWhistle": { - "name": "草笛", - "effect": "讓對手聽舒適的笛聲,從而\n陷入睡眠狀態" - }, - "tickle": { - "name": "搔癢", - "effect": "給對手搔癢,使其發笑,從\n而降低對手的攻擊和防禦" - }, - "cosmicPower": { - "name": "宇宙力量", - "effect": "汲取宇宙中神祕的力量,從\n而提高自己的防禦和特防" - }, - "waterSpout": { - "name": "噴水", - "effect": "掀起潮水進行攻擊。自己的\nHP越少,招式的威力越小" - }, - "signalBeam": { - "name": "信號光束", - "effect": "發射神奇的光線進行攻擊。\n有時會使對手混亂" - }, - "shadowPunch": { - "name": "暗影拳", - "effect": "使出混影之拳。攻擊必定會\n命中" - }, - "extrasensory": { - "name": "神通力", - "effect": "發出看不見的神奇力量進行\n攻擊。有時會使對手畏縮" - }, - "skyUppercut": { - "name": "衝天拳", - "effect": "用衝向天空般高高的上勾拳\n頂起對手進行攻擊" - }, - "sandTomb": { - "name": "流沙地獄", - "effect": "將對手困在鋪天蓋地的沙暴\n中,在4~5回合內進行攻\n擊" - }, - "sheerCold": { - "name": "絕對零度", - "effect": "給對手一擊瀕死。如果是冰\n屬性以外的寶可夢使用,就\n會難以打中" - }, - "muddyWater": { - "name": "濁流", - "effect": "向對手噴射渾濁的水進行攻\n擊。有時會降低對手的命中\n率" - }, - "bulletSeed": { - "name": "種子機關槍", - "effect": "向對手猛烈地發射種子進行\n攻擊。連續攻擊2~5次" - }, - "aerialAce": { - "name": "燕返", - "effect": "以敏捷的動作戲弄對手後進\n行切斬。攻擊必定會命中" - }, - "icicleSpear": { - "name": "冰錐", - "effect": "向對手發射鋒利的冰柱進行\n攻擊。連續攻擊2~5次" - }, - "ironDefense": { - "name": "鐵壁", - "effect": "將皮膚變得堅硬如鐵,從而\n大幅提高自己的防禦" - }, - "block": { - "name": "擋路", - "effect": "張開雙手進行阻擋,封住對\n手的退路,使其不能逃走" - }, - "howl": { - "name": "長嚎", - "effect": "大聲吼叫提高氣勢,從而提\n高自己和同伴的攻擊" - }, - "dragonClaw": { - "name": "龍爪", - "effect": "用尖銳的巨爪劈開對手進行\n攻擊" - }, - "frenzyPlant": { - "name": "瘋狂植物", - "effect": "用大樹摔打對手進行攻擊。\n下一回合自己將無法動彈" - }, - "bulkUp": { - "name": "健美", - "effect": "使出全身力氣繃緊肌肉,從\n而提高自己的攻擊和防禦" - }, - "bounce": { - "name": "彈跳", - "effect": "彈跳到高高的空中,第2回\n合攻擊對手。有時會讓對手\n陷入麻痹狀態" - }, - "mudShot": { - "name": "泥巴射擊", - "effect": "向對手投擲泥塊進行攻擊。\n同時降低對手的速度" - }, - "poisonTail": { - "name": "毒尾", - "effect": "用尾巴拍打。有時會讓對手\n陷入中毒狀態,也容易擊中\n要害" - }, - "covet": { - "name": "渴望", - "effect": "一邊可愛地撒嬌,一邊靠近\n對手進行攻擊,還能奪取對\n手攜帶的道具" - }, - "voltTackle": { - "name": "伏特攻擊", - "effect": "讓電流覆蓋全身猛撞向對手。\n自己也會受到不小的傷害。\n有時會讓對手陷入麻痹狀\n態" - }, - "magicalLeaf": { - "name": "魔法葉", - "effect": "散落可以追蹤對手的神奇葉\n片。攻擊必定會命中" - }, - "waterSport": { - "name": "玩水", - "effect": "用水溼透周圍。在5回合內\n減弱火屬性的招式" - }, - "calmMind": { - "name": "冥想", - "effect": "靜心凝神,從而提高自己的\n特攻和特防" - }, - "leafBlade": { - "name": "葉刃", - "effect": "像用劍一般操縱葉片切斬對\n手進行攻擊。容易擊中要害" - }, - "dragonDance": { - "name": "龍之舞", - "effect": "激烈地跳起神祕且強有力的\n舞蹈。從而提高自己的攻擊\n和速度" - }, - "rockBlast": { - "name": "岩石爆擊", - "effect": "向對手發射堅硬的岩石進行\n攻擊。連續攻擊2~5次" - }, - "shockWave": { - "name": "電擊波", - "effect": "向對手快速發出電擊。攻擊\n必定會命中" - }, - "waterPulse": { - "name": "水之波動", - "effect": "用水的震動攻擊對手。有時\n會使對手混亂" - }, - "doomDesire": { - "name": "破滅之願", - "effect": "使用招式2回合後,會用無\n數道光束攻擊對手" - }, - "psychoBoost": { - "name": "精神突進", - "effect": "使出全部力量攻擊對手。使\n用之後會因爲反作用力,自\n己的特攻大幅降低" - }, - "roost": { - "name": "羽棲", - "effect": "降到地面,使身體休息。回\n復自己最大HP的一半" - }, - "gravity": { - "name": "重力", - "effect": "在5回合內,飄浮特性和飛\n行屬性的寶可夢會被地面屬\n性的招式擊中。飛向空中的\n招式也將無法使用" - }, - "miracleEye": { - "name": "奇蹟之眼", - "effect": "使出後對惡屬性寶可夢沒有\n效果的招式以及閃避率高的\n對手,變得能夠打中" - }, - "wakeUpSlap": { - "name": "喚醒巴掌", - "effect": "給予睡眠狀態下的對手較大\n的傷害。但相反對手會從睡\n眠中醒過來" - }, - "hammerArm": { - "name": "臂錘", - "effect": "揮舞強力而沉重的拳頭,給\n予對手傷害。自己的速度會\n降低" - }, - "gyroBall": { - "name": "陀螺球", - "effect": "讓身體高速旋轉並撞擊對手。\n速度比對手越慢,威力越\n大" - }, - "healingWish": { - "name": "治癒之願", - "effect": "雖然自己陷入瀕死,但可以\n治癒後備上場的寶可夢的異\n常狀態以及回覆HP" - }, - "brine": { - "name": "鹽水", - "effect": "當對手的HP負傷到一半左\n右時,招式威力會變成2倍" - }, - "naturalGift": { - "name": "自然之恩", - "effect": "從樹果上獲得力量進行攻擊。\n根據攜帶的樹果,招式屬\n性和威力會改變" - }, - "feint": { - "name": "佯攻", - "effect": "能夠攻擊正在使用守住或看\n穿等招式的對手。解除其守\n護效果" - }, - "pluck": { - "name": "啄食", - "effect": "用喙進行攻擊。當對手攜帶\n樹果時,可以食用並獲得其\n效果" - }, - "tailwind": { - "name": "順風", - "effect": "颳起猛烈的旋風,在4回合\n內提高我方全員的速度" - }, - "acupressure": { - "name": "點穴", - "effect": "通過點穴讓身體舒筋活絡。\n大幅提高某1項能力" - }, - "metalBurst": { - "name": "金屬爆炸", - "effect": "使出招式前,將最後受到的\n招式的傷害大力返還給對手" - }, - "uTurn": { - "name": "急速折返", - "effect": "在攻擊之後急速返回,和後\n備寶可夢進行替換" - }, - "closeCombat": { - "name": "近身戰", - "effect": "放棄守護,向對手的懷裏突\n擊。自己的防禦和特防會降\n低" - }, - "payback": { - "name": "以牙還牙", - "effect": "蓄力攻擊。如果能在對手之\n後攻擊,招式的威力會變成\n2倍" - }, - "assurance": { - "name": "惡意追擊", - "effect": "如果此回合內對手已經受到\n傷害的話,招式威力會變成\n2倍" - }, - "embargo": { - "name": "查封", - "effect": "讓對手在5回合內不能使用\n寶可夢攜帶的道具。訓練家\n也不能給那隻寶可夢使用道\n具" - }, - "fling": { - "name": "投擲", - "effect": "快速投擲攜帶的道具進行攻\n擊。根據道具不同,威力和\n效果會改變" - }, - "psychoShift": { - "name": "精神轉移", - "effect": "利用超能力施以暗示,從而\n將自己受到的異常狀態轉移\n給對手" - }, - "trumpCard": { - "name": "王牌", - "effect": "王牌招式的剩餘PP越少,\n招式的威力越大" - }, - "healBlock": { - "name": "回覆封鎖", - "effect": "在5回合內無法通過招式、\n特性或攜帶的道具來回復H\nP" - }, - "wringOut": { - "name": "絞緊", - "effect": "用力勒緊對手進行攻擊。對\n手的HP越多,威力越大" - }, - "powerTrick": { - "name": "力量戲法", - "effect": "利用超能力交換自己的攻擊\n和防禦的力量" - }, - "gastroAcid": { - "name": "胃液", - "effect": "將胃液吐向對手的身體。沾\n上的胃液會消除對手的特性\n效果" - }, - "luckyChant": { - "name": "幸運咒語", - "effect": "向天許願,從而在5回合內\n不會被對手的攻擊打中要害" - }, - "meFirst": { - "name": "搶先一步", - "effect": "提高威力,搶先使出對手想\n要使出的招式。如果不先使\n出則會失敗" - }, - "copycat": { - "name": "仿效", - "effect": "模仿對手剛纔使出的招式,\n並使出相同招式。如果對手\n還沒出招則會失敗" - }, - "powerSwap": { - "name": "力量互換", - "effect": "利用超能力互換自己和對手\n的攻擊以及特攻的能力變化" - }, - "guardSwap": { - "name": "防守互換", - "effect": "利用超能力互換自己和對手\n的防禦以及特防的能力變化" - }, - "punishment": { - "name": "懲罰", - "effect": "根據能力變化,對手提高的\n力量越大,招式的威力越大" - }, - "lastResort": { - "name": "珍藏", - "effect": "當戰鬥中已學會的招式全部\n使用過後,才能開始使出珍\n藏的招式" - }, - "worrySeed": { - "name": "煩惱種子", - "effect": "種植心神不寧的種子。使對\n手不能入眠,並將特性變成\n不眠" - }, - "suckerPunch": { - "name": "突襲", - "effect": "可以比對手先攻擊。對手使\n出的招式如果不是攻擊招式\n則會失敗" - }, - "toxicSpikes": { - "name": "毒菱", - "effect": "在對手的腳下撒毒菱。使對\n手替換出場的寶可夢中毒" - }, - "heartSwap": { - "name": "心靈互換", - "effect": "利用超能力互換自己和對手\n之間的能力變化" - }, - "aquaRing": { - "name": "水流環", - "effect": "在自己身體的周圍覆蓋用水\n製造的幕。每回合回覆HP" - }, - "magnetRise": { - "name": "電磁飄浮", - "effect": "利用電氣產生的磁力浮在空\n中。在5回合內可以飄浮" - }, - "flareBlitz": { - "name": "閃焰衝鋒", - "effect": "讓火焰覆蓋全身猛撞向對手。\n自己也會受到不小的傷害。\n有時會讓對手陷入灼傷狀\n態" - }, - "forcePalm": { - "name": "發勁", - "effect": "向對手的身體發出衝擊波進\n行攻擊。有時會讓對手陷入\n麻痹狀態" - }, - "auraSphere": { - "name": "波導彈", - "effect": "從體內產生出波導之力,然\n後向對手發出。攻擊必定會\n命中" - }, - "rockPolish": { - "name": "岩石打磨", - "effect": "打磨自己的身體,減少空氣\n阻力。可以大幅提高自己的\n速度" - }, - "poisonJab": { - "name": "毒擊", - "effect": "用帶毒的觸手或手臂刺入對\n手。有時會讓對手陷入中毒\n狀態" - }, - "darkPulse": { - "name": "惡之波動", - "effect": "從體內發出充滿惡意的恐怖\n氣場。有時會使對手畏縮" - }, - "nightSlash": { - "name": "暗襲要害", - "effect": "抓住瞬間的空隙切斬對手。\n容易擊中要害" - }, - "aquaTail": { - "name": "水流尾", - "effect": "如驚濤駭浪般揮動大尾巴攻\n擊對手" - }, - "seedBomb": { - "name": "種子炸彈", - "effect": "將外殼堅硬的大種子,從上\n方砸下攻擊對手" - }, - "airSlash": { - "name": "空氣斬", - "effect": "用連天空也能劈開的空氣之\n刃進行攻擊。有時會使對手\n畏縮" - }, - "xScissor": { - "name": "十字剪", - "effect": "將鐮刀或爪子像剪刀般地交\n叉,順勢劈開對手" - }, - "bugBuzz": { - "name": "蟲鳴", - "effect": "利用振動發出音波進行攻擊。\n有時會降低對手的特防" - }, - "dragonPulse": { - "name": "龍之波動", - "effect": "從大大的口中掀起衝擊波攻\n擊對手" - }, - "dragonRush": { - "name": "龍之俯衝", - "effect": "釋放出駭人的殺氣,一邊威\n懾一邊撞擊對手。有時會使\n對手畏縮" - }, - "powerGem": { - "name": "力量寶石", - "effect": "發射如寶石般閃耀的光芒攻\n擊對手" - }, - "drainPunch": { - "name": "吸取拳", - "effect": "用拳頭吸取對手的力量。可\n以回覆給予對手傷害的一半\nHP" - }, - "vacuumWave": { - "name": "真空波", - "effect": "揮動拳頭,掀起真空波。必\n定能夠先制攻擊" - }, - "focusBlast": { - "name": "真氣彈", - "effect": "提高氣勢,釋放出全部力量。\n有時會降低對手的特防" - }, - "energyBall": { - "name": "能量球", - "effect": "發射從自然收集的生命力量。\n有時會降低對手的特防" - }, - "braveBird": { - "name": "勇鳥猛攻", - "effect": "收攏翅膀,通過低空飛行突\n擊對手。自己也會受到不小\n的傷害" - }, - "earthPower": { - "name": "大地之力", - "effect": "向對手腳下釋放出大地之力。\n有時會降低對手的特防" - }, - "switcheroo": { - "name": "掉包", - "effect": "用一閃而過的速度交換自己\n和對手的持有物" - }, - "gigaImpact": { - "name": "終極衝擊", - "effect": "使出自己渾身力量突擊對手。\n下一回合自己將無法動彈" - }, - "nastyPlot": { - "name": "詭計", - "effect": "謀劃詭計,激活頭腦。大幅\n提高自己的特攻" - }, - "bulletPunch": { - "name": "子彈拳", - "effect": "向對手使出如子彈般快速而\n堅硬的拳頭。必定能夠先制\n攻擊" - }, - "avalanche": { - "name": "雪崩", - "effect": "如果受到對手的招式攻擊,\n就能給予該對手2倍威力的\n攻擊" - }, - "iceShard": { - "name": "冰礫", - "effect": "瞬間製作冰塊,快速地扔向\n對手。必定能夠先制攻擊" - }, - "shadowClaw": { - "name": "暗影爪", - "effect": "以影子做成的銳爪,劈開對\n手。容易擊中要害" - }, - "thunderFang": { - "name": "雷電牙", - "effect": "用蓄滿電流的牙齒咬住對手。\n有時會使對手畏縮或陷入\n麻痹狀態" - }, - "iceFang": { - "name": "冰凍牙", - "effect": "用藏有冷氣的牙齒咬住對手。\n有時會使對手畏縮或陷入\n冰凍狀態" - }, - "fireFang": { - "name": "火焰牙", - "effect": "用覆蓋着火焰的牙齒咬住對\n手。有時會使對手畏縮或陷\n入灼傷狀態" - }, - "shadowSneak": { - "name": "影子偷襲", - "effect": "伸長影子,從對手的背後進\n行攻擊。必定能夠先制攻擊" - }, - "mudBomb": { - "name": "泥巴炸彈", - "effect": "向對手發射堅硬的泥彈進行\n攻擊。有時會降低對手的命\n中率" - }, - "psychoCut": { - "name": "精神利刃", - "effect": "用實體化的心之利刃劈開對\n手。容易擊中要害" - }, - "zenHeadbutt": { - "name": "意念頭錘", - "effect": "將思念的力量集中在前額進\n行攻擊。有時會使對手畏縮" - }, - "mirrorShot": { - "name": "鏡光射擊", - "effect": "拋光自己的身體,向對手釋\n放出閃光之力。有時會降低\n對手的命中率" - }, - "flashCannon": { - "name": "加農光炮", - "effect": "將身體的光芒聚集在一點釋\n放出去。有時會降低對手的\n特防" - }, - "rockClimb": { - "name": "攀岩", - "effect": "發動猛撞攻擊,有時會使對\n手混亂。是寶可表的祕傳招\n式之一" - }, - "defog": { - "name": "清除濃霧", - "effect": "用強風吹開對手的反射壁或\n光牆等。也會降低對手的閃\n避率" - }, - "trickRoom": { - "name": "戲法空間", - "effect": "製造出離奇的空間。在5回\n合內速度慢的寶可夢可以先\n行動" - }, - "dracoMeteor": { - "name": "流星群", - "effect": "從天空中向對手落下隕石。\n使用之後因爲反作用力,自\n己的特攻會大幅降低" - }, - "discharge": { - "name": "放電", - "effect": "用耀眼的電擊攻擊自己周圍\n所有的寶可夢。有時會陷入\n麻痹狀態" - }, - "lavaPlume": { - "name": "噴煙", - "effect": "用熊熊烈火攻擊自己周圍所\n有的寶可夢。有時會陷入灼\n傷狀態" - }, - "leafStorm": { - "name": "飛葉風暴", - "effect": "用尖尖的葉片向對手卷起風\n暴。使用之後因爲反作用力\n自己的特攻會大幅降低" - }, - "powerWhip": { - "name": "強力鞭打", - "effect": "激烈地揮舞青藤或觸手摔打\n對手進行攻擊" - }, - "rockWrecker": { - "name": "岩石炮", - "effect": "向對手發射巨大的岩石進行\n攻擊。下一回合自己將無法\n動彈" - }, - "crossPoison": { - "name": "十字毒刃", - "effect": "用毒刃劈開對手。有時會讓\n對手陷入中毒狀態,也容易\n擊中要害" - }, - "gunkShot": { - "name": "垃圾射擊", - "effect": "用骯髒的垃圾撞向對手進行\n攻擊。有時會讓對手陷入中\n毒狀態" - }, - "ironHead": { - "name": "鐵頭", - "effect": "用鋼鐵般堅硬的頭部進行攻\n擊。有時會使對手畏縮" - }, - "magnetBomb": { - "name": "磁鐵炸彈", - "effect": "發射吸住對手的鋼鐵炸彈。\n攻擊必定會命中" - }, - "stoneEdge": { - "name": "尖石攻擊", - "effect": "用尖尖的岩石刺入對手進行\n攻擊。容易擊中要害" - }, - "captivate": { - "name": "誘惑", - "effect": "♂誘惑♀或♀誘惑♂,從而\n大幅降低對手的特攻" - }, - "stealthRock": { - "name": "隱形岩", - "effect": "將無數岩石懸浮在對手的周\n圍,從而對替換出場的對手\n的寶可夢給予傷害" - }, - "grassKnot": { - "name": "打草結", - "effect": "用草纏住並絆倒對手。對手\n越重,威力越大" - }, - "chatter": { - "name": "喋喋不休", - "effect": "用非常煩人的,喋喋不休的\n音波攻擊對手。使對手混亂" - }, - "judgment": { - "name": "制裁光礫", - "effect": "向對手放出無數的光彈。屬\n性會根據自己攜帶的石板不\n同而改變" - }, - "bugBite": { - "name": "蟲咬", - "effect": "咬住進行攻擊。當對手攜帶\n樹果時,可以食用並獲得其\n效果" - }, - "chargeBeam": { - "name": "充電光束", - "effect": "向對手發射電擊光束。由於\n蓄滿電流,有時會提高自己\n的特攻" - }, - "woodHammer": { - "name": "木槌", - "effect": "用堅硬的軀體撞擊對手進行\n攻擊。自己也會受到不小的\n傷害" - }, - "aquaJet": { - "name": "水流噴射", - "effect": "以迅雷不及掩耳之勢撲向對\n手。必定能夠先制攻擊" - }, - "attackOrder": { - "name": "攻擊指令", - "effect": "召喚手下,讓其朝對手發起\n攻擊。容易擊中要害" - }, - "defendOrder": { - "name": "防禦指令", - "effect": "召喚手下,讓其附在自己的\n身體上。可以提高自己的防\n御和特防" - }, - "healOrder": { - "name": "回覆指令", - "effect": "召喚手下療傷。回覆自己最\n大HP的一半" - }, - "headSmash": { - "name": "雙刃頭錘", - "effect": "拼命使出渾身力氣,向對手\n進行頭錘攻擊。自己也會受\n到非常大的傷害" - }, - "doubleHit": { - "name": "二連擊", - "effect": "使用尾巴等拍打對手進行攻\n擊。連續2次給予傷害" - }, - "roarOfTime": { - "name": "時光咆哮", - "effect": "釋放出扭曲時間般的強大力\n量攻擊對手。下一回合自己\n將無法動彈" - }, - "spacialRend": { - "name": "亞空裂斬", - "effect": "將對手連同周圍的空間一起\n撕裂並給予傷害。容易擊中\n要害" - }, - "lunarDance": { - "name": "新月舞", - "effect": "雖然自己陷入昏厥,但可以\n治癒後備上場的寶可夢的全\n部狀態" - }, - "crushGrip": { - "name": "捏碎", - "effect": "用駭人的力量捏碎對手。對\n手剩餘的HP越多,威力越\n大" - }, - "magmaStorm": { - "name": "熔岩風暴", - "effect": "將對手困在熊熊燃燒的火焰\n中,在4~5回合內進行攻\n擊" - }, - "darkVoid": { - "name": "暗黑洞", - "effect": "將對手強制拖入黑暗的世界,\n從而讓對手陷入睡眠狀態" - }, - "seedFlare": { - "name": "種子閃光", - "effect": "從身體裏產生衝擊波。有時\n會大幅降低對手的特防" - }, - "ominousWind": { - "name": "奇異之風", - "effect": "突然颳起毛骨悚然的暴風攻\n擊對手。有時會提高自己的\n全部能力" - }, - "shadowForce": { - "name": "暗影潛襲", - "effect": "第1回合消失蹤影,第2回\n合攻擊對手。即使對手正受\n保護,也能擊中" - }, - "honeClaws": { - "name": "磨爪", - "effect": "將爪子磨得更加鋒利。提高\n自己的攻擊和命中率" - }, - "wideGuard": { - "name": "廣域防守", - "effect": "在1回合內防住擊打我方全\n員的攻擊" - }, - "guardSplit": { - "name": "防守平分", - "effect": "利用超能力將自己和對手的\n防禦和特防相加,再進行平\n分" - }, - "powerSplit": { - "name": "力量平分", - "effect": "利用超能力將自己和對手的\n攻擊和特攻相加,再進行平\n分" - }, - "wonderRoom": { - "name": "奇妙空間", - "effect": "製造出離奇的空間。在5回\n合內互換所有寶可夢的防禦\n和特防" - }, - "psyshock": { - "name": "精神衝擊", - "effect": "將神奇的念波實體化攻擊對\n手。給予物理傷害" - }, - "venoshock": { - "name": "毒液衝擊", - "effect": "將特殊的毒液潑向對手。對\n處於中毒狀態的對手,威力\n會變成2倍" - }, - "autotomize": { - "name": "身體輕量化", - "effect": "削掉身體上沒用的部分。大\n幅提高自己的速度,同時體\n重也會變輕" - }, - "ragePowder": { - "name": "憤怒粉", - "effect": "將令人煩躁的粉末撒在自己\n身上,用以吸引對手的注意。\n使對手的攻擊全部指向自\n己" - }, - "telekinesis": { - "name": "意念移物", - "effect": "利用超能力使對手浮起來。\n在3回合內攻擊會變得容易\n打中對手" - }, - "magicRoom": { - "name": "魔法空間", - "effect": "製造出離奇的空間。在5回\n合內所有寶可夢攜帶道具的\n效果都會消失" - }, - "smackDown": { - "name": "擊落", - "effect": "扔石頭或炮彈,攻擊飛行的\n對手。對手會被擊落,掉到\n地面" - }, - "stormThrow": { - "name": "山嵐摔", - "effect": "向對手使出強烈的一擊。攻\n擊必定會擊中要害" - }, - "flameBurst": { - "name": "烈焰濺射", - "effect": "如果擊中,爆裂的火焰會攻\n擊到對手。爆裂出的火焰還\n會飛濺到旁邊的對手" - }, - "sludgeWave": { - "name": "污泥波", - "effect": "用污泥波攻擊自己周圍所有\n的寶可夢。有時會陷入中毒\n狀態" - }, - "quiverDance": { - "name": "蝶舞", - "effect": "輕巧地跳起神祕而又美麗的\n舞蹈。提高自己的特攻、特\n防和速度" - }, - "heavySlam": { - "name": "重磅衝撞", - "effect": "用沉重的身體撞向對手進行\n攻擊。自己比對手越重,威\n力越大" - }, - "synchronoise": { - "name": "同步干擾", - "effect": "用神奇電波對周圍所有和自\n己屬性相同的寶可夢給予傷\n害" - }, - "electroBall": { - "name": "電球", - "effect": "用電氣團撞向對手。自己比\n對手速度越快,威力越大" - }, - "soak": { - "name": "浸水", - "effect": "將大量的水潑向對手,從而\n使其變成水屬性" - }, - "flameCharge": { - "name": "蓄能焰襲", - "effect": "讓火焰覆蓋全身,攻擊對手。\n積蓄力量來提高自己的速\n度" - }, - "coil": { - "name": "盤蜷", - "effect": "盤蜷着集中精神。提高自己\n的攻擊、防禦和命中率" - }, - "lowSweep": { - "name": "下盤踢", - "effect": "以敏捷的動作瞄準對手的腳\n進行攻擊。會降低對手的速\n度" - }, - "acidSpray": { - "name": "酸液炸彈", - "effect": "噴出能溶化對手的液體進行\n攻擊。會大幅降低對手的特\n防" - }, - "foulPlay": { - "name": "欺詐", - "effect": "利用對手的力量進行攻擊。\n正和自己戰鬥的對手,其攻\n擊越高,傷害越大" - }, - "simpleBeam": { - "name": "單純光束", - "effect": "向對手發送謎之念波。接收\n到念波的對手,其特性會變\n爲單純" - }, - "entrainment": { - "name": "找夥伴", - "effect": "用神奇的節奏跳舞。使對手\n模仿自己的動作,從而將特\n性變成一樣" - }, - "afterYou": { - "name": "您先請", - "effect": "支援我方或對手的行動,使\n其緊接着此招式之後行動" - }, - "round": { - "name": "輪唱", - "effect": "用歌聲攻擊對手。大家一起\n輪唱便可以接連使出,威力\n也會提高" - }, - "echoedVoice": { - "name": "迴聲", - "effect": "用回聲攻擊對手。如果每回\n合都有寶可夢接着使用該招\n式,威力就會提高" - }, - "chipAway": { - "name": "逐步擊破", - "effect": "看準機會穩步攻擊。無視對\n手的能力變化,直接給予傷\n害" - }, - "clearSmog": { - "name": "清除之煙", - "effect": "向對手投擲特殊的泥塊進行\n攻擊。使其能力變回原點" - }, - "storedPower": { - "name": "輔助力量", - "effect": "用蓄積起來的力量攻擊對手。\n自己的能力提高得越多,\n威力就越大" - }, - "quickGuard": { - "name": "快速防守", - "effect": "守護自己和同伴,以防對手\n的先制攻擊" - }, - "allySwitch": { - "name": "交換場地", - "effect": "用神奇的力量瞬間移動,互\n換自己和同伴所在的位置。\n連續使出則容易失敗" - }, - "scald": { - "name": "熱水", - "effect": "向對手噴射煮得翻滾的開水\n進行攻擊。有時會讓對手陷\n入灼傷狀態" - }, - "shellSmash": { - "name": "破殼", - "effect": "打破外殼,降低自己的防禦\n和特防,但大幅提高攻擊、\n特攻和速度" - }, - "healPulse": { - "name": "治癒波動", - "effect": "放出治癒波動,從而回復對\n手最大HP的一半" - }, - "hex": { - "name": "禍不單行", - "effect": "接二連三地進行攻擊。對處\n於異常狀態的對手給予較大\n的傷害" - }, - "skyDrop": { - "name": "自由落體", - "effect": "第1回合將對手帶到空中,\n第2回合將其摔下進行攻擊。\n被帶到空中的對手不能動\n彈" - }, - "shiftGear": { - "name": "換檔", - "effect": "轉動齒輪,不僅提高自己的\n攻擊,還會大幅提高速度" - }, - "circleThrow": { - "name": "巴投", - "effect": "扔飛對手,強制拉後備寶可\n夢上場。如果對手爲野生寶\n可夢,戰鬥將直接結束" - }, - "incinerate": { - "name": "燒盡", - "effect": "用火焰攻擊對手。對手攜帶\n樹果等時,會燒掉,使其不\n能使用" - }, - "quash": { - "name": "延後", - "effect": "壓制對手,從而將其行動順\n序放到最後" - }, - "acrobatics": { - "name": "雜技", - "effect": "輕巧地攻擊對手。自己沒有\n攜帶道具時,會給予較大的\n傷害" - }, - "reflectType": { - "name": "鏡面屬性", - "effect": "反射對手的屬性,讓自己也\n變成一樣的屬性" - }, - "retaliate": { - "name": "報仇", - "effect": "爲倒下的同伴報仇。如果上\n一回合有同伴倒下,威力就\n會提高" - }, - "finalGambit": { - "name": "搏命", - "effect": "拼命攻擊對手。雖然自己陷\n入昏厥,但會給予對手和自\n己目前HP等量的傷害" - }, - "bestow": { - "name": "傳遞禮物", - "effect": "當對手未攜帶道具時,能夠\n將自己攜帶的道具交給對手" - }, - "inferno": { - "name": "煉獄", - "effect": "用猛烈的火焰包圍對手進行\n攻擊。讓對手陷入灼傷狀態" - }, - "waterPledge": { - "name": "水之誓約", - "effect": "用水柱進行攻擊。如果和火\n組合,威力就會提高,天空\n中會掛上彩虹" - }, - "firePledge": { - "name": "火之誓約", - "effect": "用火柱進行攻擊。如果和草\n組合,威力就會提高,周圍\n會變成火海" - }, - "grassPledge": { - "name": "草之誓約", - "effect": "用草柱進行攻擊。如果和水\n組合,威力就會提高,周圍\n會變成溼地" - }, - "voltSwitch": { - "name": "伏特替換", - "effect": "在攻擊之後急速返回,和後\n備寶可夢進行替換" - }, - "struggleBug": { - "name": "蟲之抵抗", - "effect": "抵抗並攻擊對手。會降低對\n手的特攻" - }, - "bulldoze": { - "name": "重踏", - "effect": "用力踩踏地面並攻擊自己周\n圍所有的寶可夢。會降低對\n方的速度" - }, - "frostBreath": { - "name": "冰息", - "effect": "將冰冷的氣息吹向對手進行\n攻擊。必定會擊中要害" - }, - "dragonTail": { - "name": "龍尾", - "effect": "彈飛對手,強制拉後備寶可\n夢上場。如果對手爲野生寶\n可夢,戰鬥將直接結束" - }, - "workUp": { - "name": "自我激勵", - "effect": "激勵自己,從而提高攻擊和\n特攻" - }, - "electroweb": { - "name": "電網", - "effect": "用電網捉住對手進行攻擊。\n會降低對手的速度" - }, - "wildCharge": { - "name": "瘋狂伏特", - "effect": "讓電流覆蓋全身,撞向對手\n進行攻擊。自己也會受到少\n許傷害" - }, - "drillRun": { - "name": "直衝鑽", - "effect": "像鋼鑽一樣,一邊旋轉身體\n一邊撞擊對手。容易擊中要\n害" - }, - "dualChop": { - "name": "二連劈", - "effect": "用身體堅硬的部分拍打對手\n進行攻擊。連續2次給予傷\n害" - }, - "heartStamp": { - "name": "愛心印章", - "effect": "以可愛的動作使對手疏忽,\n乘機給出強烈的一擊。有時\n會使對手畏縮" - }, - "hornLeech": { - "name": "木角", - "effect": "將角刺入,吸取對手的養分。\n可以回覆給予對手傷害的\n一半HP" - }, - "sacredSword": { - "name": "聖劍", - "effect": "用劍切斬對手進行攻擊。無\n視對手的能力變化,直接給\n予傷害" - }, - "razorShell": { - "name": "貝殼刃", - "effect": "用鋒利的貝殼切斬對手進行\n攻擊。有時會降低對手的防\n御" - }, - "heatCrash": { - "name": "高溫重壓", - "effect": "用燃燒的身體撞向對手進行\n攻擊。自己比對手越重,威\n力越大" - }, - "leafTornado": { - "name": "青草攪拌器", - "effect": "用鋒利的葉片包裹住對手進\n行攻擊。有時會降低對手的\n命中率" - }, - "steamroller": { - "name": "瘋狂滾壓", - "effect": "旋轉揉成團的身體壓扁對手。\n有時會使對手畏縮" - }, - "cottonGuard": { - "name": "棉花防守", - "effect": "用軟綿綿的絨毛包裹住自己\n的身體進行守護。巨幅提高\n自己的防禦" - }, - "nightDaze": { - "name": "暗黑爆破", - "effect": "放出黑暗的衝擊波攻擊對手。\n有時會降低對手的命中率" - }, - "psystrike": { - "name": "精神擊破", - "effect": "將神奇的念波實體化攻擊對\n手。給予物理傷害" - }, - "tailSlap": { - "name": "掃尾拍打", - "effect": "用堅硬的尾巴拍打對手進行\n攻擊。連續攻擊2~5次" - }, - "hurricane": { - "name": "暴風", - "effect": "用強烈的風席捲對手進行攻\n擊。有時會使對手混亂" - }, - "headCharge": { - "name": "爆炸頭突擊", - "effect": "用厲害的爆炸頭猛撞向對手\n進行攻擊。自己也會受到少\n許傷害" - }, - "gearGrind": { - "name": "齒輪飛盤", - "effect": "向對手投擲鋼鐵齒輪進行攻\n擊。連續2次給予傷害" - }, - "searingShot": { - "name": "火焰彈", - "effect": "用熊熊烈火攻擊自己周圍所\n有的寶可夢。有時會陷入灼\n傷狀態" - }, - "technoBlast": { - "name": "高科技光炮", - "effect": "向對手放出光彈。屬性會根\n據自己攜帶的卡帶不同而改\n變" - }, - "relicSong": { - "name": "古老之歌", - "effect": "讓對手聽古老之歌,打動對\n手的內心進行攻擊。有時會\n讓對手陷入睡眠狀態" - }, - "secretSword": { - "name": "神祕之劍", - "effect": "用長角切斬對手進行攻擊。\n角上擁有的神奇力量將給予\n物理傷害" - }, - "glaciate": { - "name": "冰封世界", - "effect": "將冰凍的冷氣吹向對手進行\n攻擊。會降低對手的速度" - }, - "boltStrike": { - "name": "雷擊", - "effect": "讓強大的電流覆蓋全身,猛\n撞向對手進行攻擊。有時會\n讓對手陷入麻痹狀態" - }, - "blueFlare": { - "name": "青焰", - "effect": "用美麗而激烈的青焰包裹住\n對手進行攻擊。有時會讓對\n手陷入灼傷狀態" - }, - "fieryDance": { - "name": "火之舞", - "effect": "讓火焰覆蓋全身,振翅攻擊\n對手。有時會提高自己的特\n攻" - }, - "freezeShock": { - "name": "冰凍伏特", - "effect": "用覆蓋着電流的冰塊,在第\n2回合撞向對手。有時會讓\n對手陷入麻痹狀態" - }, - "iceBurn": { - "name": "極寒冷焰", - "effect": "用能夠凍結一切的強烈冷氣,\n在第2回合包裹住對手。\n有時會讓對手陷入灼傷狀態" - }, - "snarl": { - "name": "大聲咆哮", - "effect": "沒完沒了地大聲斥責,從而\n降低對手的特攻" - }, - "icicleCrash": { - "name": "冰柱墜擊", - "effect": "用大冰柱激烈地撞向對手進\n行攻擊。有時會使對手畏縮" - }, - "vCreate": { - "name": "V熱焰", - "effect": "從前額產生灼熱的火焰,舍\n身撞擊對手。防禦、特防和\n速度會降低" - }, - "fusionFlare": { - "name": "交錯火焰", - "effect": "釋放出巨大的火焰。受到巨\n大的閃電影響時,招式威力\n會提高" - }, - "fusionBolt": { - "name": "交錯閃電", - "effect": "釋放出巨大的閃電。受到巨\n大的火焰影響時,招式威力\n會提高" - }, - "flyingPress": { - "name": "飛身重壓", - "effect": "從空中俯衝向對手。此招式\n同時帶有格鬥屬性和飛行屬\n性" - }, - "matBlock": { - "name": "掀榻榻米", - "effect": "將掀起來的榻榻米當作盾牌,\n防住自己和同伴免受招式\n傷害。變化招式無法防住" - }, - "belch": { - "name": "打嗝", - "effect": "朝着對手打嗝,並給予傷害。\n如果不喫樹果則無法使出" - }, - "rototiller": { - "name": "耕地", - "effect": "翻耕土地,使草木更容易成\n長。會提高草屬性寶可夢的\n攻擊和特攻" - }, - "stickyWeb": { - "name": "黏黏網", - "effect": "在對手周圍圍上黏黏的網,\n降低替換出場的對手的速度" - }, - "fellStinger": { - "name": "致命針刺", - "effect": "如果使用此招式打倒對手,\n攻擊會巨幅提高" - }, - "phantomForce": { - "name": "潛靈奇襲", - "effect": "第1回合消失在某處,第2\n回合攻擊對手。可以無視守\n護進行攻擊" - }, - "trickOrTreat": { - "name": "萬聖夜", - "effect": "邀請對手參加萬聖夜。使對\n手被追加幽靈屬性" - }, - "nobleRoar": { - "name": "戰吼", - "effect": "發出戰吼威嚇對手,從而降\n低對手的攻擊和特攻" - }, - "ionDeluge": { - "name": "等離子浴", - "effect": "將帶電粒子擴散開來,使一\n般屬性的招式變成電屬性" - }, - "parabolicCharge": { - "name": "拋物面充電", - "effect": "給周圍全體寶可夢造成傷害。\n可以回覆給予傷害的一半\nHP" - }, - "forestsCurse": { - "name": "森林咒術", - "effect": "向對手施加森林咒術。中了\n咒術的對手會被追加草屬性" - }, - "petalBlizzard": { - "name": "落英繽紛", - "effect": "猛烈地颳起飛雪般的落花,\n攻擊周圍所有的寶可夢,並\n給予傷害" - }, - "freezeDry": { - "name": "冷凍乾燥", - "effect": "急劇冷凍對手,有時會讓對\n手陷入冰凍狀態。對於水屬\n性寶可夢也是效果絕佳" - }, - "disarmingVoice": { - "name": "魅惑之聲", - "effect": "發出魅惑的叫聲,給予對手\n精神上的傷害。攻擊必定會\n命中" - }, - "partingShot": { - "name": "拋下狠話", - "effect": "拋下狠話威嚇對手,降低攻\n擊和特攻後,和後備寶可夢\n進行替換" - }, - "topsyTurvy": { - "name": "顛倒", - "effect": "顛倒對手身上的所有能力變\n化,變成和原來相反的狀態" - }, - "drainingKiss": { - "name": "吸取之吻", - "effect": "用一個吻吸取對手的HP。\n回覆給予對手傷害的一半以\n上的HP" - }, - "craftyShield": { - "name": "戲法防守", - "effect": "使用神奇的力量防住攻擊我\n方的變化招式。但無法防住\n傷害招式的攻擊" - }, - "flowerShield": { - "name": "鮮花防守", - "effect": "使用神奇的力量提高在場的\n所有草屬性寶可夢的防禦" - }, - "grassyTerrain": { - "name": "青草場地", - "effect": "在5回合內變成青草場地。\n地面上的寶可夢每回合都能\n回覆。草屬性的招式威力還\n會提高" - }, - "mistyTerrain": { - "name": "薄霧場地", - "effect": "在5回合內,地面上的寶可\n夢不會陷入異常狀態。龍屬\n性招式的傷害也會減半" - }, - "electrify": { - "name": "輸電", - "effect": "對手使出招式前,如果輸電,\n則該回合對手的招式變成\n電屬性" - }, - "playRough": { - "name": "嬉鬧", - "effect": "與對手嬉鬧並攻擊。有時會\n降低對手的攻擊" - }, - "fairyWind": { - "name": "妖精之風", - "effect": "颳起妖精之風,吹向對手進\n行攻擊" - }, - "moonblast": { - "name": "月亮之力", - "effect": "借用月亮的力量攻擊對手。\n有時會降低對手的特攻" - }, - "boomburst": { - "name": "爆音波", - "effect": "通過震耳欲聾的爆炸聲產生\n的破壞力,攻擊自己周圍所\n有的寶可夢" - }, - "fairyLock": { - "name": "妖精之鎖", - "effect": "通過封鎖,下一回合所有的\n寶可夢都無法逃走" - }, - "kingsShield": { - "name": "王者盾牌", - "effect": "防住對手攻擊的同時,自己\n變爲防禦姿態。能夠降低所\n接觸到的對手的攻擊" - }, - "playNice": { - "name": "和睦相處", - "effect": "和對手和睦相處,使其失去\n戰鬥的氣力,從而降低對手\n的攻擊" - }, - "confide": { - "name": "密語", - "effect": "和對手進行密語,使其失去\n集中力,從而降低對手的特\n攻" - }, - "diamondStorm": { - "name": "鑽石風暴", - "effect": "掀起鑽石風暴給予傷害。有\n時會大幅提高自己的防禦" - }, - "steamEruption": { - "name": "蒸汽爆炸", - "effect": "將滾燙的蒸汽噴向對手。有\n時會讓對手灼傷" - }, - "hyperspaceHole": { - "name": "異次元洞", - "effect": "通過異次元洞,突然出現在\n對手的側面進行攻擊。還可\n以無視守住和看穿等招式" - }, - "waterShuriken": { - "name": "飛水手裏劍", - "effect": "用粘液製成的手裏劍,連續\n攻擊2~5次。必定能夠先\n制攻擊" - }, - "mysticalFire": { - "name": "魔法火焰", - "effect": "從口中噴出特別灼熱的火焰\n進行攻擊。降低對手的特攻" - }, - "spikyShield": { - "name": "尖刺防守", - "effect": "防住對手攻擊的同時,削減\n接觸到自己的對手的體力" - }, - "aromaticMist": { - "name": "芳香薄霧", - "effect": "通過神奇的芳香,提高我方\n寶可夢的特防" - }, - "eerieImpulse": { - "name": "怪異電波", - "effect": "從身體放射出怪異電波,讓\n對手沐浴其中,從而大幅降\n低其特攻" - }, - "venomDrench": { - "name": "毒液陷阱", - "effect": "將特殊的毒液潑向對手。對\n處於中毒狀態的對手,其攻\n擊、特攻和速度都會降低" - }, - "powder": { - "name": "粉塵", - "effect": "如果被撒到粉塵的對手使用\n火招式,則會爆炸並給予傷\n害" - }, - "geomancy": { - "name": "大地掌控", - "effect": "第1回合吸收能量,第2回\n合大幅提高特攻、特防和速\n度" - }, - "magneticFlux": { - "name": "磁場操控", - "effect": "通過操控磁場,會提高特性\n爲正電和負電的寶可夢的防\n御和特防" - }, - "happyHour": { - "name": "歡樂時光", - "effect": "如果使用歡樂時光,戰鬥後\n得到的錢會翻倍" - }, - "electricTerrain": { - "name": "電氣場地", - "effect": "在5回合內變成電氣場地。\n地面上的寶可夢將無法入眠。\n電屬性的招式威力還會提\n高" - }, - "dazzlingGleam": { - "name": "魔法閃耀", - "effect": "向對手發射強光,並給予傷\n害" - }, - "celebrate": { - "name": "慶祝", - "effect": "寶可夢爲十分開心的你慶祝" - }, - "holdHands": { - "name": "牽手", - "effect": "我方寶可夢之間牽手。能帶\n來非常幸福的心情" - }, - "babyDollEyes": { - "name": "圓瞳", - "effect": "用圓瞳凝視對手,從而降低\n其攻擊。必定能夠先制攻擊" - }, - "nuzzle": { - "name": "蹭蹭臉頰", - "effect": "將帶電的臉頰蹭蹭對手進行\n攻擊。讓對手陷入麻痹狀態" - }, - "holdBack": { - "name": "手下留情", - "effect": "在攻擊的時候手下留情,從\n而使對手的HP至少會留下\n1HP" - }, - "infestation": { - "name": "糾纏不休", - "effect": "在4~5回合內死纏爛打地\n進行攻擊。在此期間對手將\n無法逃走" - }, - "powerUpPunch": { - "name": "增強拳", - "effect": "通過反覆擊打對手,使自己\n的拳頭慢慢變硬。打中對手\n攻擊就會提高" - }, - "oblivionWing": { - "name": "歸天之翼", - "effect": "從鎖定的對手身上吸取HP。\n回覆給予對手傷害的一半\n以上的HP" - }, - "thousandArrows": { - "name": "千箭齊發", - "effect": "可以擊中浮在空中的寶可夢。\n空中的對手被擊落後,會\n掉到地面" - }, - "thousandWaves": { - "name": "千波激盪", - "effect": "從地面掀起波浪進行攻擊。\n被掀入波浪中的對手,將無\n法從戰鬥中逃走" - }, - "landsWrath": { - "name": "大地神力", - "effect": "聚集大地的力量,將此力量\n集中攻擊對手,並給予傷害" - }, - "lightOfRuin": { - "name": "破滅之光", - "effect": "借用永恆之花的力量,發射\n出強力光線。自己也會受到\n非常大的傷害" - }, - "originPulse": { - "name": "根源波動", - "effect": "用無數青白色且閃耀的光線\n攻擊對手" - }, - "precipiceBlades": { - "name": "斷崖之劍", - "effect": "將大地的力量變化爲利刃攻\n擊對手" - }, - "dragonAscent": { - "name": "畫龍點睛", - "effect": "從天空中急速下降攻擊對手。\n自己的防禦和特防會降低" - }, - "hyperspaceFury": { - "name": "異次元猛攻", - "effect": "用許多手臂,無視對手的守\n住或看穿等招式進行連續攻\n擊,自己的防禦會降低" - }, - "breakneckBlitzPhysical": { - "name": "一般Z究極無敵大沖撞", - "effect": "通過Z力量氣勢猛烈地全力\n撞上對手。威力會根據原來\n的招式而改變" - }, - "breakneckBlitzSpecial": { - "name": "一般Z究極無敵大沖撞", - "effect": "通過Z力量氣勢猛烈地全力\n撞上對手。威力會根據原來\n的招式而改變" - }, - "allOutPummelingPhysical": { - "name": "格鬥Z全力無雙激烈拳", - "effect": "通過Z力量製造出能量彈,\n全力撞向對手。威力會根據\n原來的招式而改變" - }, - "allOutPummelingSpecial": { - "name": "格鬥Z全力無雙激烈拳", - "effect": "通過Z力量製造出能量彈,\n全力撞向對手。威力會根據\n原來的招式而改變" - }, - "supersonicSkystrikePhysical": { - "name": "飛行Z極速俯衝轟烈撞", - "effect": "通過Z力量猛烈地飛向天空,\n朝對手全力落下。威力會\n根據原來的招式而改變" - }, - "supersonicSkystrikeSpecial": { - "name": "飛行Z極速俯衝轟烈撞", - "effect": "通過Z力量猛烈地飛向天空,\n朝對手全力落下。威力會\n根據原來的招式而改變" - }, - "acidDownpourPhysical": { - "name": "毒Z強酸劇毒滅絕雨", - "effect": "通過Z力量使毒沼湧起,全\n力讓對手沉下去。威力會根\n據原來的招式而改變" - }, - "acidDownpourSpecial": { - "name": "毒Z強酸劇毒滅絕雨", - "effect": "通過Z力量使毒沼湧起,全\n力讓對手沉下去。威力會根\n據原來的招式而改變" - }, - "tectonicRagePhysical": { - "name": "地面Z地隆嘯天大終結", - "effect": "通過Z力量潛入地裏最深處,\n全力撞上對手。威力會根\n據原來的招式而改變" - }, - "tectonicRageSpecial": { - "name": "地面Z地隆嘯天大終結", - "effect": "通過Z力量潛入地裏最深處,\n全力撞上對手。威力會根\n據原來的招式而改變" - }, - "continentalCrushPhysical": { - "name": "岩石Z毀天滅地巨巖墜", - "effect": "通過Z力量召喚大大的巖山,\n全力撞向對手。威力會根\n據原來的招式而改變" - }, - "continentalCrushSpecial": { - "name": "岩石Z毀天滅地巨巖墜", - "effect": "通過Z力量召喚大大的巖山,\n全力撞向對手。威力會根\n據原來的招式而改變" - }, - "savageSpinOutPhysical": { - "name": "蟲Z絕對捕食迴旋斬", - "effect": "通過Z力量將吐出的絲線全\n力束縛對手。威力會根據原\n來的招式而改變" - }, - "savageSpinOutSpecial": { - "name": "蟲Z絕對捕食迴旋斬", - "effect": "通過Z力量將吐出的絲線全\n力束縛對手。威力會根據原\n來的招式而改變" - }, - "neverEndingNightmarePhysical": { - "name": "幽靈Z無盡暗夜之誘惑", - "effect": "通過Z力量召喚強烈的怨念,\n全力降臨到對手身上。威\n力會根據原來的招式而改變" - }, - "neverEndingNightmareSpecial": { - "name": "幽靈Z無盡暗夜之誘惑", - "effect": "通過Z力量召喚強烈的怨念,\n全力降臨到對手身上。威\n力會根據原來的招式而改變" - }, - "corkscrewCrashPhysical": { - "name": "鋼Z超絕螺旋連擊", - "effect": "通過Z力量進行高速旋轉,\n全力撞上對手。威力會根據\n原來的招式而改變" - }, - "corkscrewCrashSpecial": { - "name": "鋼Z超絕螺旋連擊", - "effect": "通過Z力量進行高速旋轉,\n全力撞上對手。威力會根據\n原來的招式而改變" - }, - "infernoOverdrivePhysical": { - "name": "火Z超強極限爆焰彈", - "effect": "通過Z力量噴出熊熊烈火,\n全力撞向對手。威力會根據\n原來的招式而改變" - }, - "infernoOverdriveSpecial": { - "name": "火Z超強極限爆焰彈", - "effect": "通過Z力量噴出熊熊烈火,\n全力撞向對手。威力會根據\n原來的招式而改變" - }, - "hydroVortexPhysical": { - "name": "水Z超級水流大漩渦", - "effect": "通過Z力量製造大大的潮旋,\n全力吞沒對手。威力會根\n據原來的招式而改變" - }, - "hydroVortexSpecial": { - "name": "水Z超級水流大漩渦", - "effect": "通過Z力量製造大大的潮旋,\n全力吞沒對手。威力會根\n據原來的招式而改變" - }, - "bloomDoomPhysical": { - "name": "草Z絢爛繽紛花怒放", - "effect": "通過Z力量藉助花草的能量,\n全力攻擊對手。威力會根\n據原來的招式而改變" - }, - "bloomDoomSpecial": { - "name": "草Z絢爛繽紛花怒放", - "effect": "通過Z力量藉助花草的能量,\n全力攻擊對手。威力會根\n據原來的招式而改變" - }, - "gigavoltHavocPhysical": { - "name": "電Z終極伏特狂雷閃", - "effect": "通過Z力量將蓄積的強大電\n流全力撞向對手。威力會根\n據原來的招式而改變" - }, - "gigavoltHavocSpecial": { - "name": "電Z終極伏特狂雷閃", - "effect": "通過Z力量將蓄積的強大電\n流全力撞向對手。威力會根\n據原來的招式而改變" - }, - "shatteredPsychePhysical": { - "name": "超能力Z至高精神破壞波", - "effect": "通過Z力量操縱對手,全力\n使其感受到痛苦。威力會根\n據原來的招式而改變" - }, - "shatteredPsycheSpecial": { - "name": "超能力Z至高精神破壞波", - "effect": "通過Z力量操縱對手,全力\n使其感受到痛苦。威力會根\n據原來的招式而改變" - }, - "subzeroSlammerPhysical": { - "name": "冰Z激狂大地萬里冰", - "effect": "通過Z力量急劇降低氣溫,\n全力冰凍對手。威力會根據\n原來的招式而改變" - }, - "subzeroSlammerSpecial": { - "name": "冰Z激狂大地萬里冰", - "effect": "通過Z力量急劇降低氣溫,\n全力冰凍對手。威力會根據\n原來的招式而改變" - }, - "devastatingDrakePhysical": { - "name": "龍Z究極巨龍震天地", - "effect": "通過Z力量將氣場實體化,\n向對手全力發動襲擊。威力\n會根據原來的招式而改變" - }, - "devastatingDrakeSpecial": { - "name": "龍Z究極巨龍震天地", - "effect": "通過Z力量將氣場實體化,\n向對手全力發動襲擊。威力\n會根據原來的招式而改變" - }, - "blackHoleEclipsePhysical": { - "name": "惡Z黑洞吞噬萬物滅", - "effect": "通過Z力量收集惡能量,全\n力將對手吸入。威力會根據\n原來的招式而改變" - }, - "blackHoleEclipseSpecial": { - "name": "惡Z黑洞吞噬萬物滅", - "effect": "通過Z力量收集惡能量,全\n力將對手吸入。威力會根據\n原來的招式而改變" - }, - "twinkleTacklePhysical": { - "name": "妖精Z可愛星星飛天撞", - "effect": "通過Z力量製造魅惑空間,\n全力捉弄對手。威力會根據\n原來的招式而改變" - }, - "twinkleTackleSpecial": { - "name": "妖精Z可愛星星飛天撞", - "effect": "通過Z力量製造魅惑空間,\n全力捉弄對手。威力會根據\n原來的招式而改變" - }, - "catastropika": { - "name": "皮卡丘Z皮卡皮卡必殺擊", - "effect": "通過Z力量,皮卡丘全身覆\n蓋最強電力,全力猛撲對手" - }, - "shoreUp": { - "name": "集沙", - "effect": "回覆自己最大HP的一半。\n在沙暴中回覆得更多" - }, - "firstImpression": { - "name": "迎頭一擊", - "effect": "威力很高的招式,但只有在\n出場戰鬥時,立刻使出才能\n成功" - }, - "banefulBunker": { - "name": "碉堡", - "effect": "防住對手攻擊的同時,讓接\n觸到自己的對手中毒" - }, - "spiritShackle": { - "name": "縫影", - "effect": "攻擊的同時,縫住對手的影\n子,使其無法逃走" - }, - "darkestLariat": { - "name": "DD金勾臂", - "effect": "旋轉雙臂打向對手。無視對\n手的能力變化,直接給予傷\n害" - }, - "sparklingAria": { - "name": "泡影的詠歎調", - "effect": "隨着唱歌會放出很多氣球。\n受到此招式攻擊時,灼傷會\n被治癒" - }, - "iceHammer": { - "name": "冰錘", - "effect": "揮舞強力而沉重的拳頭,給\n予對手傷害。自己的速度會\n降低" - }, - "floralHealing": { - "name": "花療", - "effect": "回覆對手最大HP的一半。\n在青草場地時,效果會提高" - }, - "highHorsepower": { - "name": "十萬馬力", - "effect": "使出全身力量,猛攻對手" - }, - "strengthSap": { - "name": "吸取力量", - "effect": "給自己回覆和對手攻擊力相\n同數值的HP,然後降低對\n手的攻擊" - }, - "solarBlade": { - "name": "日光刃", - "effect": "第1回合收集滿滿的日光,\n第2回合將此力量集中在劍\n上進行攻擊" - }, - "leafage": { - "name": "樹葉", - "effect": "將葉片打向對手,進行攻擊" - }, - "spotlight": { - "name": "聚光燈", - "effect": "給寶可夢打上聚光燈,該回\n合只能瞄準該寶可夢" - }, - "toxicThread": { - "name": "毒絲", - "effect": "將混有毒的絲吐向對手。使\n其中毒,從而降低對手的速\n度" - }, - "laserFocus": { - "name": "磨礪", - "effect": "集中精神,下次攻擊必定會\n擊中要害" - }, - "gearUp": { - "name": "輔助齒輪", - "effect": "啓動齒輪,提高特性爲正電\n和負電的寶可夢的攻擊和特\n攻" - }, - "throatChop": { - "name": "深淵突刺", - "effect": "受到此招式攻擊的對手,會\n因爲地獄般的痛苦,在2回\n合內,變得無法使出聲音類\n招式" - }, - "pollenPuff": { - "name": "花粉團", - "effect": "對敵人使用是會爆炸的糰子。\n對我方使用則是給予回覆\n的糰子" - }, - "anchorShot": { - "name": "擲錨", - "effect": "將錨纏住對手進行攻擊。使\n對手無法逃走" - }, - "psychicTerrain": { - "name": "精神場地", - "effect": "在5回合內,地面上的寶可\n夢不會受到先制招式的攻擊。\n超能力屬性的招式威力會\n提高" - }, - "lunge": { - "name": "猛撲", - "effect": "全力猛撲對手進行攻擊。從\n而降低對手的攻擊" - }, - "fireLash": { - "name": "火焰鞭", - "effect": "用燃燒的鞭子抽打對手。受\n到攻擊的對手防禦會降低" - }, - "powerTrip": { - "name": "囂張", - "effect": "耀武揚威地攻擊對手,自己\n的能力提高得越多,威力就\n越大" - }, - "burnUp": { - "name": "燃盡", - "effect": "將自己全身燃燒起火焰來,\n給予對手大大的傷害。自己\n的火屬性將會消失" - }, - "speedSwap": { - "name": "速度互換", - "effect": "將對手和自己的速度進行互\n換" - }, - "smartStrike": { - "name": "修長之角", - "effect": "用尖尖的角刺入對手進行攻\n擊。攻擊必定會命中" - }, - "purify": { - "name": "淨化", - "effect": "治癒對手的異常狀態。治癒\n後可以回覆自己的HP" - }, - "revelationDance": { - "name": "覺醒之舞", - "effect": "全力跳舞進行攻擊。此招式\n的屬性將變得和自己的屬性\n相同" - }, - "coreEnforcer": { - "name": "核心懲罰者", - "effect": "如果給予過傷害的對手已經\n結束行動,其特性就會被消\n除" - }, - "tropKick": { - "name": "熱帶踢", - "effect": "向對手使出來自南國的火熱\n腳踢。從而降低對手的攻擊" - }, - "instruct": { - "name": "號令", - "effect": "向對手下達指示,讓其再次\n使出剛纔的招式" - }, - "beakBlast": { - "name": "鳥嘴加農炮", - "effect": "先加熱鳥嘴後再進行攻擊。\n鳥嘴在加熱時對手觸碰的話,\n就會使其灼傷" - }, - "clangingScales": { - "name": "鱗片噪音", - "effect": "摩擦全身鱗片,發出響亮的\n聲音進行攻擊。攻擊後自己\n的防禦會降低" - }, - "dragonHammer": { - "name": "龍錘", - "effect": "將身體當作錘子,向對手發\n動襲擊,給予傷害" - }, - "brutalSwing": { - "name": "狂舞揮打", - "effect": "用自己的身體狂舞揮打,給\n予對手傷害" - }, - "auroraVeil": { - "name": "極光幕", - "effect": "在5回合內減弱物理和特殊\n的傷害。只有下雪時才能使\n出" - }, - "sinisterArrowRaid": { - "name": "狙射樹梟Z遮天蔽日暗影箭", - "effect": "通過Z力量製造出無數箭的\n狙射樹梟將全力射穿對手進\n行攻擊" - }, - "maliciousMoonsault": { - "name": "熾焰咆哮虎Z極惡飛躍粉碎擊", - "effect": "通過Z力量得到強壯肉體的\n熾焰咆哮虎將全力撞向對手\n進行攻擊" - }, - "oceanicOperetta": { - "name": "西獅海壬Z海神莊嚴交響樂", - "effect": "通過Z力量召喚大量水的西\n獅海壬將全力攻擊對手" - }, - "guardianOfAlola": { - "name": "卡璞Z巨人衛士・阿羅拉", - "effect": "通過Z力量得到阿羅拉之力\n的土地神寶可夢將全力進行\n攻擊。對手的剩餘HP會減\n少很多" - }, - "soulStealing7StarStrike": { - "name": "瑪夏多Z七星奪魂腿", - "effect": "得到Z力量的瑪夏多將全力\n使出拳頭和腳踢的連續招式\n叩打對手" - }, - "stokedSparksurfer": { - "name": "阿羅雷Z駕雷馭電戲衝浪", - "effect": "得到Z力量的阿羅拉地區的\n雷丘將全力進行攻擊。從而\n讓對手陷入麻痹狀態" - }, - "pulverizingPancake": { - "name": "卡比獸Z認真起來大爆擊", - "effect": "通過Z力量使得認真起來的\n卡比獸躍動巨大身軀,全力\n向對手發動襲擊" - }, - "extremeEvoboost": { - "name": "伊布Z九彩昇華齊聚頂", - "effect": "得到Z力量的伊布將藉助進\n化後夥伴們的力量,大幅提\n高能力" - }, - "genesisSupernova": { - "name": "夢幻Z起源超新星大爆炸", - "effect": "得到Z力量的夢幻將全力攻\n擊對手。腳下會變成精神場\n地" - }, - "shellTrap": { - "name": "陷阱甲殼", - "effect": "設下甲殼陷阱。如果對手使\n出物理招式,陷阱就會爆炸\n並給予對手傷害" - }, - "fleurCannon": { - "name": "花朵加農炮", - "effect": "放出強力光束後,自己的特\n攻會大幅降低" - }, - "psychicFangs": { - "name": "精神之牙", - "effect": "利用精神力量咬住對手進行\n攻擊。還可以破壞光牆和反\n射壁等" - }, - "stompingTantrum": { - "name": "跺腳", - "effect": "化悔恨爲力量進行攻擊。如\n果上一回合招式沒有打中,\n威力就會翻倍" - }, - "shadowBone": { - "name": "暗影之骨", - "effect": "用附有靈魂的骨頭毆打對手\n進行攻擊。有時會降低對手\n的防禦" - }, - "accelerock": { - "name": "衝巖", - "effect": "迅速撞向對手進行攻擊。必\n定能夠先制攻擊" - }, - "liquidation": { - "name": "水流裂破", - "effect": "用水之力量撞向對手進行攻\n擊。有時會降低對手的防禦" - }, - "prismaticLaser": { - "name": "棱鏡鐳射", - "effect": "用棱鏡的力量發射強烈光線。\n下一回合自己將無法動彈" - }, - "spectralThief": { - "name": "暗影偷盜", - "effect": "潛入對手的影子進行攻擊。\n會奪取對手的能力提升" - }, - "sunsteelStrike": { - "name": "流星閃衝", - "effect": "以流星般的氣勢猛撞對手。\n可以無視對手的特性進行攻\n擊" - }, - "moongeistBeam": { - "name": "暗影之光", - "effect": "放出奇怪的光線攻擊對手。\n可以無視對手的特性進行攻\n擊" - }, - "tearfulLook": { - "name": "淚眼汪汪", - "effect": "變得淚眼汪汪,讓對手喪失\n鬥志。從而降低對手的攻擊\n和特攻" - }, - "zingZap": { - "name": "麻麻刺刺", - "effect": "撞向對手,併發出強電,使\n其感到麻麻刺刺的。有時會\n使對手畏縮" - }, - "naturesMadness": { - "name": "自然之怒", - "effect": "向對手釋放自然之怒。對手\n的HP會減半" - }, - "multiAttack": { - "name": "多屬性攻擊", - "effect": "一邊覆蓋高能量,一邊撞向\n對手進行攻擊。根據存儲碟\n不同,屬性會改變" - }, - "tenMillionVoltThunderbolt": { - "name": "智皮卡Z千萬伏特", - "effect": "戴着帽子的皮卡丘將通過Z\n力量增強的電擊全力釋放給\n對手。容易擊中要害" - }, - "mindBlown": { - "name": "驚爆大頭", - "effect": "讓自己的頭爆炸,來攻擊周\n圍的一切。自己也會受到傷\n害" - }, - "plasmaFists": { - "name": "等離子閃電拳", - "effect": "用覆蓋着電流的拳頭進行攻\n擊。使一般屬性的招式變成\n電屬性" - }, - "photonGeyser": { - "name": "光子噴湧", - "effect": "用光柱來進行攻擊。比較自\n己的攻擊和特攻,用數值相\n對較高的一項給予對方傷害" - }, - "lightThatBurnsTheSky": { - "name": "究極奈克洛Z焚天滅世熾光爆", - "effect": "奈克洛茲瑪會無視對手的特\n性效果,在攻擊和特攻之間,\n用數值相對較高的一項給\n予對方傷害" - }, - "searingSunrazeSmash": { - "name": "索爾迦雷歐Z日光迴旋下蒼穹", - "effect": "得到Z力量的索爾迦雷歐將\n全力進行攻擊。可以無視對\n手的特性效果" - }, - "menacingMoonrazeMaelstrom": { - "name": "露奈雅拉Z月華飛濺落靈霄", - "effect": "得到Z力量的露奈雅拉將全\n力進行攻擊。可以無視對手\n的特性效果" - }, - "letsSnuggleForever": { - "name": "謎擬丘Z親密無間大亂揍", - "effect": "得到Z力量的謎擬Q將全力\n進行亂揍攻擊" - }, - "splinteredStormshards": { - "name": "鬃巖狼人Z狼嘯石牙颶風暴", - "effect": "得到Z力量的鬃巖狼人將全\n力進行攻擊。而且會消除場\n地狀態" - }, - "clangorousSoulblaze": { - "name": "杖尾鱗甲龍Z熾魂熱舞烈音爆", - "effect": "得到Z力量的杖尾鱗甲龍將\n全力攻擊對手。並且自己的\n能力會提高" - }, - "zippyZap": { - "name": "電電加速", - "effect": "迅猛無比的電擊。必定能夠先制攻擊,\n並且提高自己的閃避率" - }, - "splishySplash": { - "name": "滔滔衝浪", - "effect": "往巨浪中注入電能後衝撞對\n手進行攻擊。有時會讓對手\n陷入麻痹狀態" - }, - "floatyFall": { - "name": "飄飄墜落", - "effect": "輕飄飄地浮起來後,再猛地\n俯衝下去進行攻擊。有時會\n使對手畏縮" - }, - "pikaPapow": { - "name": "閃閃雷光", - "effect": "皮卡丘越喜歡訓練家,電擊\n的威力就越強。攻擊必定會\n命中" - }, - "bouncyBubble": { - "name": "活活氣泡", - "effect": "投擲水球進行攻擊。吸水後\n能回覆等同於造成的傷害\n的HP" - }, - "buzzyBuzz": { - "name": "麻麻電擊", - "effect": "放出電擊攻擊對手。讓對手\n陷入麻痹狀態" - }, - "sizzlySlide": { - "name": "熊熊火爆", - "effect": "用燃起大火的身體猛烈地衝\n撞對手。讓對手陷入灼傷狀\n態" - }, - "glitzyGlow": { - "name": "嘩嘩氣場", - "effect": "利用念力強攻,粉碎對方信\n心。製造一道能減弱對手特\n殊攻擊的神奇牆壁" - }, - "baddyBad": { - "name": "壞壞領域", - "effect": "惡行惡相地進行攻擊。製造\n一道能減弱對手物理攻擊的\n神奇牆壁" - }, - "sappySeed": { - "name": "茁茁炸彈", - "effect": "長出巨大的藤蔓,播撒種子\n進行攻擊。種子每回合都會\n吸取對手的HP" - }, - "freezyFrost": { - "name": "冰冰霜凍", - "effect": "利用冰冷的黑霧結晶進行攻\n擊。使全體寶可夢的能力變\n回原點" - }, - "sparklySwirl": { - "name": "亮亮風暴", - "effect": "利用芬芳刺鼻的龍捲風吞噬\n對方。能治癒我方寶可夢的\n異常狀態" - }, - "veeveeVolley": { - "name": "砰砰擊破", - "effect": "伊布越喜歡訓練家,衝撞的\n威力就越強。攻擊必定會命\n中" - }, - "doubleIronBash": { - "name": "鋼拳雙擊", - "effect": "以胸口的螺帽爲中心旋轉,\n並連續2次揮動手臂打擊對\n手。有時會使對手畏縮" - }, - "maxGuard": { - "name": "極巨防壁", - "effect": "完全抵擋對手的攻擊。連續\n使出則容易失敗" - }, - "dynamaxCannon": { - "name": "極巨炮", - "effect": "將凝縮在體內的能量從核心放出進行攻擊,\n對手等級比當前波次的等級上限越高,造成的傷害越高,最多兩倍。" - }, - "snipeShot": { - "name": "狙擊", - "effect": "能無視具有吸引對手招式效\n果的特性或招式的影響。可\n以向選定的對手進行攻擊" - }, - "jawLock": { - "name": "緊咬不放", - "effect": "使雙方直到一方昏厥爲止無\n法替換寶可夢。其中一方退\n場則可以解除效果" - }, - "stuffCheeks": { - "name": "大快朵頤", - "effect": "喫掉攜帶的樹果,大幅提高\n防禦" - }, - "noRetreat": { - "name": "背水一戰", - "effect": "提高自己的所有能力,但無\n法替換或逃走" - }, - "tarShot": { - "name": "瀝青射擊", - "effect": "潑灑黏糊糊的瀝青,降低對\n手的速度。火屬性會變成對\n手的弱點" - }, - "magicPowder": { - "name": "魔法粉", - "effect": "向對手噴灑魔法粉,使對手\n變爲超能力屬性" - }, - "dragonDarts": { - "name": "龍箭", - "effect": "讓多龍梅西亞進行2次攻擊。\n如果對手有2隻寶可夢,\n則對它們各進行1次攻擊" - }, - "teatime": { - "name": "茶會", - "effect": "舉辦一場茶會,場上的所有\n寶可夢都會喫掉自己攜帶的\n樹果" - }, - "octolock": { - "name": "蛸固", - "effect": "讓對手無法逃走。對手被固\n定後,每回合都會降低防禦\n和特防" - }, - "boltBeak": { - "name": "電喙", - "effect": "用帶電的喙啄刺對手。如果\n比對手先出手攻擊,招式的\n威力會變成2倍" - }, - "fishiousRend": { - "name": "鰓咬", - "effect": "用堅硬的腮咬住對手。如果\n比對手先出手攻擊,招式的\n威力會變成2倍" - }, - "courtChange": { - "name": "換場", - "effect": "用神奇的力量交換雙方的場\n地效果" - }, - "maxFlare": { - "name": "極巨火爆", - "effect": "極巨化寶可夢使出的火屬性\n攻擊。可在5回合內讓日照\n變得強烈" - }, - "maxFlutterby": { - "name": "極巨蟲蠱", - "effect": "極巨化寶可夢使出的蟲屬性\n攻擊。會降低對手的特攻" - }, - "maxLightning": { - "name": "極巨閃電", - "effect": "極巨化寶可夢使出的電屬性\n攻擊。可在5回合內將腳下\n變成電氣場地" - }, - "maxStrike": { - "name": "極巨攻擊", - "effect": "極巨化寶可夢使出的一般屬\n性攻擊。會降低對手的速度" - }, - "maxKnuckle": { - "name": "極巨拳鬥", - "effect": "極巨化寶可夢使出的格鬥屬\n性攻擊。會提高我方的攻擊" - }, - "maxPhantasm": { - "name": "極巨幽魂", - "effect": "極巨化寶可夢使出的幽靈屬\n性攻擊。會降低對手的防禦" - }, - "maxHailstorm": { - "name": "極巨寒冰", - "effect": "極巨化寶可夢使出的冰屬性\n攻擊。在5回合內會下雪" - }, - "maxOoze": { - "name": "極巨酸毒", - "effect": "極巨化寶可夢使出的毒屬性\n攻擊。會提高我方的特攻" - }, - "maxGeyser": { - "name": "極巨水流", - "effect": "極巨化寶可夢使出的水屬性\n攻擊。可在5回合內降下大\n雨" - }, - "maxAirstream": { - "name": "極巨飛衝", - "effect": "極巨化寶可夢使出的飛行屬\n性攻擊。會提高我方的速度" - }, - "maxStarfall": { - "name": "極巨妖精", - "effect": "極巨化寶可夢使出的妖精屬\n性攻擊。可在5回合內將腳\n下變成薄霧場地" - }, - "maxWyrmwind": { - "name": "極巨龍騎", - "effect": "極巨化寶可夢使出的龍屬性\n攻擊。會降低對手的攻擊" - }, - "maxMindstorm": { - "name": "極巨超能", - "effect": "極巨化寶可夢使出的超能力\n屬性攻擊。可在5回合內將\n腳下變成精神場地" - }, - "maxRockfall": { - "name": "極巨岩石", - "effect": "極巨化寶可夢使出的岩石屬\n性攻擊。可在5回合內捲起\n沙暴" - }, - "maxQuake": { - "name": "極巨大地", - "effect": "極巨化寶可夢使出的地面屬\n性攻擊。會提高我方的特防" - }, - "maxDarkness": { - "name": "極巨惡霸", - "effect": "極巨化寶可夢使出的惡屬性\n攻擊。會降低對手的特防" - }, - "maxOvergrowth": { - "name": "極巨草原", - "effect": "極巨化寶可夢使出的草屬性\n攻擊。可在5回合內將腳下\n變成青草場地" - }, - "maxSteelspike": { - "name": "極巨鋼鐵", - "effect": "極巨化寶可夢使出的鋼屬性\n攻擊。會提高我方的防禦" - }, - "clangorousSoul": { - "name": "魂舞烈音爆", - "effect": "削減少許自己的HP,使所\n有能力都提高" - }, - "bodyPress": { - "name": "撲擊", - "effect": "用身體撞向對手進行攻擊。\n防禦越高,給予的傷害就越\n高" - }, - "decorate": { - "name": "裝飾", - "effect": "通過裝飾,大幅提高對方的\n攻擊和特攻" - }, - "drumBeating": { - "name": "鼓擊", - "effect": "用鼓點來控制鼓的根部進行\n攻擊,從而降低對手的速度" - }, - "snapTrap": { - "name": "捕獸夾", - "effect": "使用捕獸夾,在4~5回合\n內,夾住對手進行攻擊" - }, - "pyroBall": { - "name": "火焰球", - "effect": "點燃小石子,形成火球攻擊\n對手。有時會使對手陷入灼\n傷狀態" - }, - "behemothBlade": { - "name": "巨獸斬", - "effect": "以全身力氣舉起強大的劍,\n猛烈地劈向對手進行攻擊" - }, - "behemothBash": { - "name": "巨獸彈", - "effect": "將全身變化爲堅固的盾,猛\n烈地撞向對手進行攻擊" - }, - "auraWheel": { - "name": "氣場輪", - "effect": "用儲存在頰囊裏的能量進行\n攻擊,並提高自己的速度。\n其屬性會隨着莫魯貝可的樣\n子而改變" - }, - "breakingSwipe": { - "name": "廣域破壞", - "effect": "用堅韌的尾巴猛掃對手進行\n攻擊,從而降低對手的攻擊" - }, - "branchPoke": { - "name": "木枝突刺", - "effect": "使用尖銳的樹枝刺向對手進\n行攻擊" - }, - "overdrive": { - "name": "破音", - "effect": "奏響吉他和貝斯,釋放出發\n出巨響的劇烈震動攻擊對手" - }, - "appleAcid": { - "name": "蘋果酸", - "effect": "使用從酸蘋果中提取出來的\n酸性液體進行攻擊。降低對\n手的特防" - }, - "gravApple": { - "name": "萬有引力", - "effect": "從高處落下蘋果,給予對手\n傷害。可降低對手的防禦" - }, - "spiritBreak": { - "name": "靈魂衝擊", - "effect": "用足以讓對手一蹶不振的氣\n勢進行攻擊。會降低對手的\n特攻" - }, - "strangeSteam": { - "name": "神奇蒸汽", - "effect": "噴出煙霧攻擊對手。有時會\n使對手混亂" - }, - "lifeDew": { - "name": "生命水滴", - "effect": "噴灑出神奇的水,回覆自己\n和場上同伴的HP" - }, - "obstruct": { - "name": "攔堵", - "effect": "完全抵擋對手的攻擊。連續\n使出則容易失敗。一旦觸碰,\n防禦就會大幅降低" - }, - "falseSurrender": { - "name": "假跪真撞", - "effect": "裝作低頭認錯的樣子,用凌\n亂的頭髮進行突刺。攻擊必\n定會命中" - }, - "meteorAssault": { - "name": "流星突擊", - "effect": "大力揮舞粗壯的莖進行攻擊。\n但同時自己也會被晃暈,\n下一回合自己將無法動彈" - }, - "eternabeam": { - "name": "無極光束", - "effect": "無極汰那變回原來的樣子後,\n發動的最強攻擊。下一回\n合自己將無法動彈" - }, - "steelBeam": { - "name": "鐵蹄光線", - "effect": "將從全身聚集的鋼鐵化爲光\n束,激烈地發射出去。自己\n也會受到傷害" - }, - "expandingForce": { - "name": "廣域戰力", - "effect": "利用精神力量攻擊對手。在\n精神場地上威力會有所提高,\n能對所有對手造成傷害" - }, - "steelRoller": { - "name": "鐵滾輪", - "effect": "在破壞場地的同時攻擊對手。\n如果腳下沒有任何場地狀\n態存在,使出此招式時便會\n失敗" - }, - "scaleShot": { - "name": "鱗射", - "effect": "發射鱗片進行攻擊。連續攻\n擊2~5次。速度會提高但\n防禦會降低" - }, - "meteorBeam": { - "name": "流星光束", - "effect": "第1回合聚集宇宙之力提高\n特攻,第2回合攻擊對手" - }, - "shellSideArm": { - "name": "臂貝武器", - "effect": "從物理攻擊和特殊攻擊中選\n擇可造成較多傷害的方式進\n行攻擊。有時會讓對手陷入\n中毒狀態" - }, - "mistyExplosion": { - "name": "薄霧炸裂", - "effect": "對自己周圍的所有寶可夢進\n行攻擊,但使出後,自己會\n陷入昏厥。在薄霧場地上,\n招式威力會提高" - }, - "grassyGlide": { - "name": "青草滑梯", - "effect": "彷彿在地面上滑行般地攻擊\n對手。在青草場地上,必定\n能夠先制攻擊" - }, - "risingVoltage": { - "name": "電力上升", - "effect": "用從地面升騰而起的電擊進\n行攻擊。當對手處於電氣場\n地上時,招式威力會變成2\n倍" - }, - "terrainPulse": { - "name": "大地波動", - "effect": "藉助場地的力量進行攻擊。\n視使出招式時場地狀態不同,\n招式的屬性和威力會有所\n變化" - }, - "skitterSmack": { - "name": "爬擊", - "effect": "從對手背後爬近後進行攻擊。\n會降低對手的特攻" - }, - "burningJealousy": { - "name": "妒火", - "effect": "用嫉妒的能量攻擊對手。會\n讓在該回合內能力有所提高\n的寶可夢陷入灼傷狀態" - }, - "lashOut": { - "name": "泄憤", - "effect": "攻擊對手以發泄對其感到的\n惱怒情緒。如果在該回合內\n自身能力遭到降低,招式的\n威力會變成2倍" - }, - "poltergeist": { - "name": "靈騷", - "effect": "操縱對手的持有物進行攻擊。\n當對手沒有攜帶道具時,\n使出此招式時便會失敗" - }, - "corrosiveGas": { - "name": "腐蝕氣體", - "effect": "用具有強酸性的氣體包裹住\n自己周圍所有的寶可夢,並\n融化其所攜帶的道具" - }, - "coaching": { - "name": "指導", - "effect": "通過進行正確合理的指導,\n提高我方全員的攻擊和防禦" - }, - "flipTurn": { - "name": "快速折返", - "effect": "在攻擊之後急速返回,和後\n備寶可夢進行替換" - }, - "tripleAxel": { - "name": "三旋擊", - "effect": "連續3次踢對手進行攻擊。\n每踢中一次,威力就會提高" - }, - "dualWingbeat": { - "name": "雙翼", - "effect": "將翅膀撞向對手進行攻擊。\n連續2次給予傷害" - }, - "scorchingSands": { - "name": "熱沙大地", - "effect": "將滾燙的沙子砸向對手進行\n攻擊。有時會讓對手陷入灼\n傷狀態" - }, - "jungleHealing": { - "name": "叢林治療", - "effect": "與叢林融爲一體,回覆自己\n和場上同伴的HP和狀態" - }, - "wickedBlow": { - "name": "闇冥強擊", - "effect": "將惡之流派修煉至大成的猛\n烈一擊。必定會擊中要害" - }, - "surgingStrikes": { - "name": "水流連打", - "effect": "將水之流派修煉至大成的仿\n若行雲流水般的3次連擊。\n必定會擊中要害" - }, - "thunderCage": { - "name": "雷電囚籠", - "effect": "將對手困在電流四濺的囚籠\n中,在4~5回合內進行攻\n擊" - }, - "dragonEnergy": { - "name": "巨龍威能", - "effect": "把生命力轉換爲力量攻擊對\n手。自己的HP越少,招式\n的威力越小" - }, - "freezingGlare": { - "name": "冰冷視線", - "effect": "從雙眼發射精神力量進行攻\n擊。有時會讓對手陷入冰凍\n狀態" - }, - "fieryWrath": { - "name": "怒火中燒", - "effect": "將憤怒轉化爲火焰般的氣場\n進行攻擊。有時會使對手畏\n縮" - }, - "thunderousKick": { - "name": "雷鳴蹴擊", - "effect": "以雷電般的動作戲耍對手的\n同時使出腳踢。可降低對手\n的防禦" - }, - "glacialLance": { - "name": "雪矛", - "effect": "向對手投擲掀起暴風雪的冰\n矛進行攻擊" - }, - "astralBarrage": { - "name": "星碎", - "effect": "用大量的小靈體向對手發起\n攻擊" - }, - "eerieSpell": { - "name": "詭異咒語", - "effect": "用強大的精神力量攻擊。讓\n對手最後使用的招式減少3\nPP" - }, - "direClaw": { - "name": "克命爪", - "effect": "以破滅之爪進行攻擊。有時\n還會讓對手陷入中毒、麻痹\n、睡眠之中的一種狀態" - }, - "psyshieldBash": { - "name": "屏障猛攻", - "effect": "讓意念的能量覆蓋全身,撞\n向對手進行攻擊。會提高自\n己的防禦" - }, - "powerShift": { - "name": "力量轉換", - "effect": "將自己的攻擊與防禦互相交\n換" - }, - "stoneAxe": { - "name": "巖斧", - "effect": "用岩石之斧進行攻擊。散落\n的岩石碎片會飄浮在對手周\n圍" - }, - "springtideStorm": { - "name": "陽春風暴", - "effect": "用交織着愛與恨的烈風席捲\n對手進行攻擊。有時會降低\n對手的攻擊" - }, - "mysticalPower": { - "name": "神祕之力", - "effect": "放出不可思議的力量攻擊。\n會提高自己的特攻" - }, - "ragingFury": { - "name": "大憤慨", - "effect": "在2~3回合內,一邊放出\n火焰,一邊瘋狂亂打。大鬧\n一番後自己會陷入混亂" - }, - "waveCrash": { - "name": "波動衝", - "effect": "讓水覆蓋全身後撞向對手。\n自己也會受到不少傷害" - }, - "chloroblast": { - "name": "葉綠爆震", - "effect": "將自己的葉綠素凝聚起來後\n放出去進行攻擊。自己也會\n受到傷害" - }, - "mountainGale": { - "name": "冰山風", - "effect": "將冰山般巨大的冰塊砸向對\n手進行攻擊。有時會使對手\n畏縮" - }, - "victoryDance": { - "name": "勝利之舞", - "effect": "激烈地跳起喚來勝利的舞蹈,\n提高自己的攻擊、防禦和\n速度" - }, - "headlongRush": { - "name": "突飛猛撲", - "effect": "向對手使出灌注了全心全力\n的撞擊。自己的防禦和特防\n會降低" - }, - "barbBarrage": { - "name": "毒千針", - "effect": "用無數的毒針進行攻擊。有\n時還會讓對手陷入中毒狀態。\n攻擊處於中毒狀態的對手\n時,威力會變成2倍" - }, - "esperWing": { - "name": "氣場之翼", - "effect": "用經過氣場強化的翅膀撕裂\n對手。容易擊中要害。會提\n高自己的速度" - }, - "bitterMalice": { - "name": "冤冤相報", - "effect": "用令人毛骨悚然的怨念進行\n攻擊。會降低對手的攻擊" - }, - "shelter": { - "name": "閉關", - "effect": "將皮膚變得堅硬如鐵盾,從\n而大幅提高自己的防禦" - }, - "tripleArrows": { - "name": "三連箭", - "effect": "使出一記腿技後同時發射3\n箭。有時會降低對手的防禦\n或使對手畏縮。容易擊中要\n害" - }, - "infernalParade": { - "name": "羣魔亂舞", - "effect": "用無數的火球進行攻擊。有\n時會讓對手陷入灼傷狀態。\n攻擊處於異常狀態的對手時,\n威力會變成2倍" - }, - "ceaselessEdge": { - "name": "祕劍・千重濤", - "effect": "用貝殼之劍進行攻擊。散落\n的貝殼碎片會散落在對手腳\n下成爲撒菱" - }, - "bleakwindStorm": { - "name": "枯葉風暴", - "effect": "用足以讓身心都止不住顫抖\n的冰冷狂風進行攻擊。有時\n會降低對手的速度" - }, - "wildboltStorm": { - "name": "鳴雷風暴", - "effect": "呼喚雷雲引起風暴,用雷與\n風進行激烈的攻擊。有時會\n讓對手陷入麻痹狀態" - }, - "sandsearStorm": { - "name": "熱沙風暴", - "effect": "用灼熱的沙子和強烈的風席\n卷對手進行攻擊。有時會讓\n對手陷入灼傷狀態" - }, - "lunarBlessing": { - "name": "新月祈禱", - "effect": "向新月獻上祈禱,回覆自己\n和場上同伴的HP和狀態" - }, - "takeHeart": { - "name": "勇氣填充", - "effect": "鼓起衝勁,治癒自己的異常\n狀態,同時提高自己的特攻\n和特防" - }, - "gMaxWildfire": { - "name": "超極巨深淵滅焰", - "effect": "超極巨化的噴火龍使出的火\n屬性攻擊。可在4回合內給\n予對手傷害" - }, - "gMaxBefuddle": { - "name": "超極巨蝶影蠱惑", - "effect": "超極巨化的巴大蝶使出的蟲\n屬性攻擊。會讓對手陷入中\n毒、麻痹或睡眠狀態" - }, - "gMaxVoltCrash": { - "name": "超極鉅萬雷轟頂", - "effect": "超極巨化的皮卡丘使出的電\n屬性攻擊。會讓對手陷入麻\n痹狀態" - }, - "gMaxGoldRush": { - "name": "超極巨特大金幣", - "effect": "超極巨化的喵喵使出的一般\n屬性攻擊。會讓對手陷入混\n亂狀態,並可獲得金錢" - }, - "gMaxChiStrike": { - "name": "超極巨會心一擊", - "effect": "超極巨化的怪力使出的格鬥\n屬性攻擊。會變得容易擊中\n要害" - }, - "gMaxTerror": { - "name": "超極巨幻影幽魂", - "effect": "超極巨化的耿鬼使出的幽靈\n屬性攻擊。會踩住對手的影\n子,讓其無法被替換" - }, - "gMaxResonance": { - "name": "超極巨極光旋律", - "effect": "超極巨化的拉普拉斯使出的\n冰屬性攻擊。可在5回合內\n減弱受到的傷害" - }, - "gMaxCuddle": { - "name": "超極巨熱情擁抱", - "effect": "超極巨化的伊布使出的一般\n屬性攻擊。會讓對手陷入着\n迷狀態" - }, - "gMaxReplenish": { - "name": "超極巨資源再生", - "effect": "超極巨化的卡比獸使出的一\n般屬性攻擊。會讓喫掉的樹\n果再生" - }, - "gMaxMalodor": { - "name": "超極巨臭氣沖天", - "effect": "超極巨化的灰塵山使出的毒\n屬性攻擊。會讓對手陷入中\n毒狀態" - }, - "gMaxStonesurge": { - "name": "超極巨巖陣以待", - "effect": "超極巨化的暴噬龜使出的水\n屬性攻擊。會發射無數銳利\n的岩石" - }, - "gMaxWindRage": { - "name": "超極巨旋風襲捲", - "effect": "超極巨化的鋼鎧鴉使出的飛\n行屬性攻擊。可消除反射壁\n和光牆" - }, - "gMaxStunShock": { - "name": "超極巨異毒電場", - "effect": "超極巨化的顫弦蠑螈使出的\n電屬性攻擊。會讓對手陷入\n中毒或麻痹狀態" - }, - "gMaxFinale": { - "name": "超極巨幸福圓滿", - "effect": "超極巨化的霜奶仙使出的妖\n精屬性攻擊。可回覆我方的\nHP" - }, - "gMaxDepletion": { - "name": "超極巨劣化衰變", - "effect": "超極巨化的鋁鋼龍使出的龍\n屬性攻擊。可減少對手最後\n使用的招式的PP" - }, - "gMaxGravitas": { - "name": "超極巨天道七星", - "effect": "超極巨化的以歐路普使出的\n超能力屬性攻擊。在5回合\n內重力會產生變化" - }, - "gMaxVolcalith": { - "name": "超極巨炎石噴發", - "effect": "超極巨化的巨炭山使出的巖\n石屬性攻擊。可在4回合內\n給予對手傷害" - }, - "gMaxSandblast": { - "name": "超極巨沙塵漫天", - "effect": "超極巨化的沙螺蟒使出的地\n面屬性攻擊。在4~5回合\n內會狂刮沙暴" - }, - "gMaxSnooze": { - "name": "超極巨睡魔降臨", - "effect": "超極巨化的長毛巨魔使出的\n惡屬性攻擊。會通過打大哈\n欠讓對手產生睡意" - }, - "gMaxTartness": { - "name": "超極巨酸不溜丟", - "effect": "超極巨化的蘋裹龍使出的草\n屬性攻擊。會降低對手的閃\n避率" - }, - "gMaxSweetness": { - "name": "超極巨瓊漿玉液", - "effect": "超極巨化的豐蜜龍使出的草\n屬性攻擊。會治癒我方的異\n常狀態" - }, - "gMaxSmite": { - "name": "超極巨天譴雷誅", - "effect": "超極巨化的布莉姆溫使出的\n妖精屬性攻擊。會讓對手陷\n入混亂狀態" - }, - "gMaxSteelsurge": { - "name": "超極巨鋼鐵陣法", - "effect": "超極巨化的大王銅象使出的\n鋼屬性攻擊。會發射無數銳\n利的刺" - }, - "gMaxMeltdown": { - "name": "超極巨液金熔擊", - "effect": "超極巨化的美錄梅塔使出的\n鋼屬性攻擊。會讓對手無法\n連續使出相同的招式" - }, - "gMaxFoamBurst": { - "name": "超極巨激漩泡渦", - "effect": "超極巨化的巨鉗蟹使出的水\n屬性攻擊。會大幅降低對手\n的速度" - }, - "gMaxCentiferno": { - "name": "超極巨百火焚野", - "effect": "超極巨化的焚焰蚣使出的火\n屬性攻擊。可在4~5回合\n內將對手困在火焰中" - }, - "gMaxVineLash": { - "name": "超極巨灰飛鞭滅", - "effect": "超極巨化的妙蛙花使出的草\n屬性攻擊。可在4回合內給\n予對手傷害" - }, - "gMaxCannonade": { - "name": "超極巨水炮轟滅", - "effect": "超極巨化的水箭龜使出的水\n屬性攻擊。可在4回合內給\n予對手傷害" - }, - "gMaxDrumSolo": { - "name": "超極巨狂擂亂打", - "effect": "超極巨化的轟擂金剛猩使出\n的草屬性攻擊。不會受到對\n手特性的干擾" - }, - "gMaxFireball": { - "name": "超極巨破陣火球", - "effect": "超極巨化的閃焰王牌使出的\n火屬性攻擊。不會受到對手\n特性的干擾" - }, - "gMaxHydrosnipe": { - "name": "超極巨狙擊神射", - "effect": "超極巨化的千面避役使出的\n水屬性攻擊。不會受到對手\n特性的干擾" - }, - "gMaxOneBlow": { - "name": "超極巨奪命一擊", - "effect": "超極巨化的武道熊師使出的\n惡屬性攻擊。是可以無視極\n巨防壁的一擊" - }, - "gMaxRapidFlow": { - "name": "超極巨流水連擊", - "effect": "超極巨化的武道熊師使出的\n水屬性攻擊。是可以無視極\n巨防壁的連擊" - }, - "teraBlast": { - "name": "太晶爆發", - "effect": "太晶化時,會放出太晶屬性\n的能量攻擊。比較自己的攻\n擊和特攻,用數值相對較高\n的一項給予對方傷害。(其\n他屬性)/用攻擊和特攻數\n值較高的一項給予傷害。對\n正處於太晶化的對手效果絕\n佳。自己的攻擊和特攻會降\n低。(星晶" - }, - "silkTrap": { - "name": "線阱", - "effect": "用絲設置陷阱。防住對方攻\n擊的同時,能夠降低所接觸\n到的對手的速度" - }, - "axeKick": { - "name": "下壓踢", - "effect": "將踢起的腳跟往下劈向對手\n進行攻擊。有時會使對手混\n亂。如果劈偏則自己會受到\n傷害" - }, - "lastRespects": { - "name": "掃墓", - "effect": "爲了化解夥伴的悔恨而進行\n攻擊。被打倒的我方寶可夢\n越多,招式的威力越高" - }, - "luminaCrash": { - "name": "琉光衝激", - "effect": "放出連精神都能影響到的奇\n妙怪光進行攻擊。會大幅降\n低對方的特防" - }, - "orderUp": { - "name": "上菜", - "effect": "以瀟灑的身手進行攻擊。若\n口中有米立龍,會按其樣子\n提高能力" - }, - "jetPunch": { - "name": "噴射拳", - "effect": "將激流覆蓋於拳頭,以肉眼\n無法辨識的速度打出拳擊。\n必定能夠先制攻擊" - }, - "spicyExtract": { - "name": "辣椒精華", - "effect": "放出極爲辛辣的精華。對手\n的攻擊會大幅提高,防禦會\n大幅降低" - }, - "spinOut": { - "name": "疾速轉輪", - "effect": "通過往腿上增加負荷,以激\n烈的旋轉給予對手傷害。自\n己的速度會大幅降低" - }, - "populationBomb": { - "name": "鼠數兒", - "effect": "夥伴們會紛紛趕來集合,以\n羣體行動給予對手攻擊。連\n續命中1~10次" - }, - "iceSpinner": { - "name": "冰旋", - "effect": "腳上覆蓋薄冰,旋轉着撞擊\n對手。通過旋轉的動作破壞\n場地" - }, - "glaiveRush": { - "name": "巨劍突擊", - "effect": "有勇無謀的捨身突擊。使出\n招式後,對手的攻擊必定會\n命中,且傷害會變成2倍" - }, - "revivalBlessing": { - "name": "復生祈禱", - "effect": "通過以慈愛之心祈禱,讓陷\n入昏厥的後備寶可夢以回覆\n一半HP的狀態復活" - }, - "saltCure": { - "name": "鹽醃", - "effect": "使對手陷入鹽醃狀態,每回\n合給予對手傷害。對手爲鋼\n或水屬性時會更痛苦" - }, - "tripleDive": { - "name": "三連鑽", - "effect": "以默契的跳躍濺起水花擊向\n對手。連續3次給予傷害" - }, - "mortalSpin": { - "name": "晶光轉轉", - "effect": "通過旋轉來攻擊對手。可以\n擺脫綁緊、緊束、寄生種子\n等招式。還能讓對手陷入中\n毒狀態" - }, - "doodle": { - "name": "描繪", - "effect": "把握並映射出對手的本質,\n讓自己和同伴寶可夢的特性\n變得和對手相同" - }, - "filletAway": { - "name": "甩肉", - "effect": "削減自己的HP,大幅提高\n攻擊和特攻以及速度" - }, - "kowtowCleave": { - "name": "僕刀", - "effect": "下跪讓對手大意後發起襲擊\n劈向對手。攻擊必定會命中" - }, - "flowerTrick": { - "name": "千變萬花", - "effect": "將做了手腳的花束扔向對手\n進行攻擊。必定會命中,且\n會擊中要害" - }, - "torchSong": { - "name": "閃焰高歌", - "effect": "如唱歌一樣噴出熊熊燃燒的\n火焰燒焦對手。會提高自己\n的特攻" - }, - "aquaStep": { - "name": "流水旋舞", - "effect": "以盈盈欲滴的輕快步伐戲耍\n對手並給予其傷害。會提高\n自己的速度" - }, - "ragingBull": { - "name": "怒牛", - "effect": "狂怒暴牛的猛烈衝撞。招式\n的屬性隨形態改變,光牆和\n反射壁等招式也能破壞" - }, - "makeItRain": { - "name": "淘金潮", - "effect": "扔出大量硬幣攻擊。自己的\n特攻會降低,戰鬥後還可以\n拿到錢" - }, - "psyblade": { - "name": "精神劍", - "effect": "用無形的利刃劈開對手。處\n於電氣場地時,招式威力會\n變成1.5倍" - }, - "hydroSteam": { - "name": "水蒸氣", - "effect": "將煮得翻滾的開水猛烈地噴\n向對手。日照強烈時,招式\n威力不但不會降低,還會變\n成1.5倍" - }, - "ruination": { - "name": "大災難", - "effect": "引發毀滅性的災厄,使對手\n的HP減半" - }, - "collisionCourse": { - "name": "全開猛撞", - "effect": "邊變形邊兇暴地落下,並引\n發起古老的大爆炸。若針對\n到弱點,威力會進一步" - }, - "electroDrift": { - "name": "閃電猛衝", - "effect": "邊變形邊高速奔走,並以未\n知的電擊貫穿對手。若針對\n到弱點,威力會進一步" - }, - "shedTail": { - "name": "斷尾", - "effect": "削減自己的HP,製造分身\n後會返回,並和後備寶可夢\n進行替換" - }, - "chillyReception": { - "name": "冷笑話", - "effect": "留下冷場的冷笑話後,和後\n備寶可夢進行替換。在5回\n合內會下雪" - }, - "tidyUp": { - "name": "大掃除", - "effect": "將撒菱、隱形巖、黏黏網、\n毒菱、替身全部掃除掉。自\n己的攻擊和速度會提高" - }, - "snowscape": { - "name": "雪景", - "effect": "在5回合內會下雪。冰屬性\n的防禦會提高" - }, - "pounce": { - "name": "蟲撲", - "effect": "飛撲向對手攻擊。會降低對\n手的速度" - }, - "trailblaze": { - "name": "起草", - "effect": "跳出草叢進行攻擊。通過輕\n快的步伐會提高自己的速度" - }, - "chillingWater": { - "name": "潑冷水", - "effect": "潑灑冰冷得足以讓對手失去\n活力的水進行攻擊。會降低\n對手的攻擊" - }, - "hyperDrill": { - "name": "強力鑽", - "effect": "急速旋轉尖銳的身體部位貫\n穿對手。可以無視守住和看\n穿等招式" - }, - "twinBeam": { - "name": "雙光束", - "effect": "從兩眼發射出神奇的光線攻\n擊。連續2次給予傷害" - }, - "rageFist": { - "name": "憤怒之拳", - "effect": "將憤怒化爲力量攻擊。受到\n攻擊的次數越多,招式的威\n力越高" - }, - "armorCannon": { - "name": "鎧農炮", - "effect": "熊熊燃燒自己的鎧甲,將其\n做成炮彈射出攻擊。自己的\n防禦和特防會降低" - }, - "bitterBlade": { - "name": "悔念劍", - "effect": "將對世間的留戀聚集於劍尖,\n並斬擊對手。可以回覆給\n予對手傷害的一半HP" - }, - "doubleShock": { - "name": "電光雙擊", - "effect": "將全身所有的電力放出,給\n予對手大大的傷害。自己的\n電屬性將會消失" - }, - "gigatonHammer": { - "name": "巨力錘", - "effect": "連同身體轉起巨大的錘子進\n行攻擊。這個招式無法連續\n使出2次" - }, - "comeuppance": { - "name": "復仇", - "effect": "使出招式前,將最後受到的\n招式的傷害大力返還給對手" - }, - "aquaCutter": { - "name": "水波刀", - "effect": "如刀刃般噴射出加壓的水切\n開對手。容易擊中要害" - }, - "blazingTorque": { - "name": "灼熱暴衝", - "effect": "攻擊目標造成傷害,\n有30%的幾率使目標陷入\n灼傷狀態。" - }, - "wickedTorque": { - "name": "黑暗暴衝", - "effect": "攻擊目標造成傷害,\n有30%的幾率使目標陷入\n睡眠狀態。" - }, - "noxiousTorque": { - "name": "劇毒暴衝", - "effect": "攻擊目標造成傷害,\n有30%的幾率使目標陷入\n中毒狀態。" - }, - "combatTorque": { - "name": "格鬥暴衝", - "effect": "攻擊目標造成傷害,\n有30%的幾率使目標陷入\n麻痹狀態。此招式可以命中\n幽靈屬性的寶可夢。" - }, - "magicalTorque": { - "name": "魔法暴衝", - "effect": "攻擊目標造成傷害,\n有30%的幾率使目標陷入\n混亂狀態。" - }, - "bloodMoon": { - "name": "血月", - "effect": "從赤紅如血的滿月發射出全\n部的氣勢。這個招式無法連\n續使出2次" - }, - "matchaGotcha": { - "name": "刷刷茶炮", - "effect": "發射經攪拌的茶的大炮,可\n以回覆給予對手傷害的一半\nHP,有時會讓對手陷入灼\n傷狀態" - }, - "syrupBomb": { - "name": "糖漿炸彈", - "effect": "使粘稠的麥芽糖漿爆炸,讓\n對手陷入滿身糖狀態,在3\n回合內持續降低其速度" - }, - "ivyCudgel": { - "name": "棘藤棒", - "effect": "用纏有藤蔓的棍棒毆打。屬\n性會隨所戴的面具而改變。\n容易擊中要害" - }, - "electroShot": { - "name": "電光束", - "effect": "第1回合收集電力提高特攻,\n第2回合將高壓的電力發\n射出去。下雨天氣時能立刻\n發射" - }, - "teraStarstorm": { - "name": "晶光星羣", - "effect": "照射出結晶的力量來驅逐敵\n人。太樂巴戈斯在星晶形態\n下使出時,能對所有對手造\n成傷害" - }, - "fickleBeam": { - "name": "隨機光", - "effect": "發射光線進行攻擊。有時其\n他的頭也會合力發射鐳射,\n讓招式威力變成2倍" - }, - "burningBulwark": { - "name": "火焰守護", - "effect": "用超高溫的體毛防住對手攻\n擊的同時,讓接觸到自己的\n對手灼傷" - }, - "thunderclap": { - "name": "迅雷", - "effect": "可以比對手先使出電擊進行\n攻擊。對手使出的招式如果\n不是攻擊招式則會失敗" - }, - "mightyCleave": { - "name": "強刃攻擊", - "effect": "用積蓄在頭部的光來斬切對\n手。可以無視守護進行攻擊" - }, - "tachyonCutter": { - "name": "迅子利刃", - "effect": "接連發射出粒子的利刃,連\n續2次給予傷害。攻擊必定\n會命中" - }, - "hardPress": { - "name": "硬壓", - "effect": "用手臂或鉗子壓迫對手。對\n手剩餘的HP越多,威力越\n大" - }, - "dragonCheer": { - "name": "龍聲鼓舞", - "effect": "以龍之鼓舞提高士氣,讓我\n方的招式變得容易擊中要害。\n對龍屬性的鼓舞效果會更\n強" - }, - "alluringVoice": { - "name": "魅誘之聲", - "effect": "用天使般的歌聲攻擊對手。\n會讓此回合內能力有提高的\n寶可夢陷入混亂狀態" - }, - "temperFlare": { - "name": "豁出去", - "effect": "以自暴自棄的氣勢進行攻擊。\n如果上一回合招式沒有命\n中,威力就會翻倍" - }, - "supercellSlam": { - "name": "閃電強襲", - "effect": "讓身體帶電後壓向對手。如\n果沒有命中則自己會受到傷\n害" - }, - "psychicNoise": { - "name": "精神噪音", - "effect": "用令對手不舒服的音波進行\n攻擊。讓對手在2回合內無\n法通過招式、特性或攜帶的\n道具回覆HP" - }, - "upperHand": { - "name": "快手還擊", - "effect": "察覺到對手的動作後用掌根\n攻擊,讓對手畏縮。如果對\n手使出的招式不是先制攻擊,\n則會失敗" - }, - "malignantChain": { - "name": "邪毒鎖鏈", - "effect": "用由毒形成的鎖鏈纏住對手\n注入毒素加以侵蝕。有時會\n讓對手陷入劇毒狀態" - } -} diff --git a/src/locales/zh_TW/nature.json b/src/locales/zh_TW/nature.json deleted file mode 100644 index bde8d938c06..00000000000 --- a/src/locales/zh_TW/nature.json +++ /dev/null @@ -1,27 +0,0 @@ -{ - "Hardy": "勤奮", - "Lonely": "怕寂寞", - "Brave": "勇敢", - "Adamant": "固執", - "Naughty": "頑皮", - "Bold": "大膽", - "Docile": "坦率", - "Relaxed": "悠閒", - "Impish": "淘氣", - "Lax": "樂天", - "Timid": "膽小", - "Hasty": "急躁", - "Serious": "認真", - "Jolly": "爽朗", - "Naive": "天真", - "Modest": "內斂", - "Mild": "慢吞吞", - "Quiet": "冷靜", - "Bashful": "害羞", - "Rash": "馬虎", - "Calm": "溫和", - "Gentle": "溫順", - "Sassy": "自大", - "Careful": "慎重", - "Quirky": "浮躁" -} \ No newline at end of file diff --git a/src/locales/zh_TW/party-ui-handler.json b/src/locales/zh_TW/party-ui-handler.json deleted file mode 100644 index ef82d1a3ddc..00000000000 --- a/src/locales/zh_TW/party-ui-handler.json +++ /dev/null @@ -1,47 +0,0 @@ -{ - "SEND_OUT": "上場", - "SUMMARY": "概要", - "CANCEL": "取消", - "RELEASE": "放生", - "APPLY": "應用", - "TEACH": "教授", - "SPLICE": "融合", - "UNSPLICE": "分離", - "ACTIVATE": "激活", - "DEACTIVATE": "解除", - "TRANSFER": "交換", - "ALL": "全部道具", - "PASS_BATON": "接棒", - "UNPAUSE_EVOLUTION": "解除進化暫停", - "REVIVE": "複活", - "RENAME": "起名", - "choosePokemon": "選擇一只寶可夢。", - "doWhatWithThisPokemon": "要對寶可夢做什麽?", - "noEnergy": "{{pokemonName}}沒有力氣戰鬥了!", - "hasEnergy": "{{pokemonName}}仍然精神十足!", - "cantBeUsed": "{{pokemonName}}無法在此挑戰中使用!", - "tooManyItems": "{{pokemonName}}擁有\n太多這個道具了!", - "anyEffect": "即便使用也無效果哦。", - "unpausedEvolutions": "{{pokemonName}}的進化停止了。", - "unspliceConfirmation": "真的要把{{fusionName}}\n從{{pokemonName}}身上分離嗎?{{fusionName}}會就此消失。", - "wasReverted": "{{fusionName}}恢複成了{{pokemonName}}。", - "releaseConfirmation": "你真要放生{{pokemonName}}嗎?", - "releaseInBattle": "你無法放生正在戰鬥中的寶可夢!", - "selectAMove": "選擇一個招式。", - "changeQuantity": "選擇一件道具來交換。\n使用 ← 和 → 來指定數量。", - "selectAnotherPokemonToSplice": "選擇另一只寶可夢來融合。", - "cancel": "取消", - "able": "能學會!", - "notAble": "無法學習", - "learned": "已習得", - "goodbye": "再見,{{pokemonName}}!", - "byebye": "拜拜,{{pokemonName}}!", - "farewell": "再會了,{{pokemonName}}!", - "soLong": "告辭了,{{pokemonName}}!", - "thisIsWhereWePart": "就此分別吧,{{pokemonName}}!", - "illMissYou": "我會想你的,{{pokemonName}}!", - "illNeverForgetYou": "我不會忘記你的,{{pokemonName}}!", - "untilWeMeetAgain": "下次再見了,{{pokemonName}}!", - "sayonara": "撒由那拉,{{pokemonName}}!", - "smellYaLater": "拜拜了您勒,{{pokemonName}}!" -} diff --git a/src/locales/zh_TW/pokeball.json b/src/locales/zh_TW/pokeball.json deleted file mode 100644 index 48492edf311..00000000000 --- a/src/locales/zh_TW/pokeball.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "pokeBall": "精靈球", - "greatBall": "超級球", - "ultraBall": "高級球", - "rogueBall": "肉鴿球", - "masterBall": "大師球", - "luxuryBall": "豪華球" -} \ No newline at end of file diff --git a/src/locales/zh_TW/pokemon-form-battle.json b/src/locales/zh_TW/pokemon-form-battle.json deleted file mode 100644 index 93a9e65f1f8..00000000000 --- a/src/locales/zh_TW/pokemon-form-battle.json +++ /dev/null @@ -1,14 +0,0 @@ -{ - "mega": "Mega {{pokemonName}}", - "mega-x": "Mega {{pokemonName}} X", - "mega-y": "Mega {{pokemonName}} Y", - "primal": "原始{{pokemonName}}", - "gigantamax": "超極巨{{pokemonName}}", - "eternamax": "無極巨{{pokemonName}}", - "megaChange": "{{preName}}超級進化成了\n{{pokemonName}}!", - "gigantamaxChange": "{{preName}}超極巨化成了\n{{pokemonName}}!", - "eternamaxChange": "{{preName}}無極巨化成了\n{{pokemonName}}!", - "revertChange": "{{pokemonName}}變回了\n原本的樣子!", - "formChange": "{{preName}}變為其他樣子了。", - "disguiseChange": "它的畫皮被當作誘餌使用了!" -} diff --git a/src/locales/zh_TW/pokemon-form.json b/src/locales/zh_TW/pokemon-form.json deleted file mode 100644 index f1fb4dff599..00000000000 --- a/src/locales/zh_TW/pokemon-form.json +++ /dev/null @@ -1,170 +0,0 @@ -{ - "pikachuCosplay": "換裝", - "pikachuCoolCosplay": "搖滾巨星", - "pikachuBeautyCosplay": "貴婦", - "pikachuCuteCosplay": "流行偶像", - "pikachuSmartCosplay": "博士", - "pikachuToughCosplay": "面罩摔跤手", - "pikachuPartner": "搭檔", - "eeveePartner": "搭檔", - "pichuSpiky": "刺刺耳", - "unownA": "A", - "unownB": "B", - "unownC": "C", - "unownD": "D", - "unownE": "E", - "unownF": "F", - "unownG": "G", - "unownH": "H", - "unownI": "I", - "unownJ": "J", - "unownK": "K", - "unownL": "L", - "unownM": "M", - "unownN": "N", - "unownO": "O", - "unownP": "P", - "unownQ": "Q", - "unownR": "R", - "unownS": "S", - "unownT": "T", - "unownU": "U", - "unownV": "V", - "unownW": "W", - "unownX": "X", - "unownY": "Y", - "unownZ": "Z", - "unownExclamation": "!", - "unownQuestion": "?", - "castformSunny": "晴天", - "castformRainy": "雨天", - "castformSnowy": "雪天", - "deoxysNormal": "普通", - "burmyPlant": "草木蓑衣", - "burmySandy": "砂土蓑衣", - "burmyTrash": "垃圾蓑衣", - "shellosEast": "東海", - "shellosWest": "西海", - "rotomHeat": "加熱", - "rotomWash": "清洗", - "rotomFrost": "結冰", - "rotomFan": "旋轉", - "rotomMow": "切割", - "giratinaAltered": "別種", - "shayminLand": "陸上", - "basculinRedStriped": "紅條紋", - "basculinBlueStriped": "藍條紋", - "basculinWhiteStriped": "白條紋", - "deerlingSpring": "春天", - "deerlingSummer": "夏天", - "deerlingAutumn": "秋天", - "deerlingWinter": "冬天", - "tornadusIncarnate": "化身", - "thundurusIncarnate": "化身", - "landorusIncarnate": "化身", - "keldeoOrdinary": "通常", - "meloettaAria": "歌聲", - "meloettaPirouette": "舞步形態", - "froakieBattleBond": "牽絆變身", - "scatterbugMeadow": "花園花紋", - "scatterbugIcySnow": "冰雪花紋", - "scatterbugPolar": "雪國花紋", - "scatterbugTundra": "雪原花紋", - "scatterbugContinental": "大陸花紋", - "scatterbugGarden": "庭園花紋", - "scatterbugElegant": "高雅花紋", - "scatterbugModern": "摩登花紋", - "scatterbugMarine": "大海花紋", - "scatterbugArchipelago": "群島花紋", - "scatterbugHighPlains": "荒野花紋", - "scatterbugSandstorm": "沙塵花紋", - "scatterbugRiver": "大河花紋", - "scatterbugMonsoon": "驟雨花紋", - "scatterbugSavanna": "熱帶草原花紋", - "scatterbugSun": "太陽花紋", - "scatterbugOcean": "大洋花紋", - "scatterbugJungle": "熱帶雨林花紋", - "scatterbugFancy": "幻彩花紋", - "scatterbugPokeBall": "球球花紋", - "flabebeRed": "紅花", - "flabebeYellow": "黃花", - "flabebeOrange": "橙花", - "flabebeBlue": "藍花", - "flabebeWhite": "白花", - "furfrouHeart": "心形造型", - "furfrouStar": "星形造型", - "furfrouDiamond": "菱形造型", - "furfrouDebutante": "淑女造型", - "furfrouMatron": "貴婦造型", - "furfrouDandy": "紳士造型", - "furfrouLaReine": "女王造型", - "furfrouKabuki": "歌舞伎造型", - "furfrouPharaoh": "國王造型", - "pumpkabooSmall": "小尺寸", - "pumpkabooLarge": "大尺寸", - "pumpkabooSuper": "特大尺寸", - "xerneasNeutral": "放松模式", - "xerneasActive": "活躍模式", - "zygarde50": "50%形態", - "zygarde10": "10%形態", - "zygarde50Pc": "50%形態 群聚變形", - "zygarde10Pc": "10%形態 群聚變形", - "zygardeComplete": "完全體形態", - "oricorioBaile": "熱辣熱辣風格", - "oricorioPompom": "啪滋啪滋風格", - "oricorioPau": "呼拉呼拉風格", - "oricorioSensu": "輕盈輕盈風格", - "rockruffOwnTempo": "特殊岩狗狗", - "miniorRedMeteor": "紅色核心", - "miniorOrangeMeteor": "橙色核心", - "miniorYellowMeteor": "黃色核心", - "miniorGreenMeteor": "綠色核心", - "miniorBlueMeteor": "淺藍色核心", - "miniorIndigoMeteor": "藍色核心", - "miniorVioletMeteor": "紫色核心", - "miniorRed": "紅色", - "miniorOrange": "橙色", - "miniorYellow": "黃色", - "miniorGreen": "綠色", - "miniorBlue": "淺藍色", - "miniorIndigo": "藍色", - "miniorViolet": "紫色", - "mimikyuDisguised": "化形", - "mimikyuBusted": "現形", - "magearnaOriginal": "500年前的顔色", - "marshadowZenith": "全力", - "sinisteaPhony": "赝品", - "sinisteaAntique": "真品", - "eiscueNoIce": "解凍頭", - "indeedeeMale": "雄性", - "indeedeeFemale": "雌性", - "morpekoFullBelly": "滿腹花紋", - "zacianHeroOfManyBattles": "百戰勇者", - "zamazentaHeroOfManyBattles": "百戰勇者", - "zarudeDada": "老爹", - "enamorusIncarnate": "化身", - "squawkabillyGreenPlumage": "綠羽毛", - "squawkabillyBluePlumage": "藍羽毛", - "squawkabillyYellowPlumage": "黃羽毛", - "squawkabillyWhitePlumage": "白羽毛", - "tatsugiriCurly": "上弓姿勢", - "tatsugiriDroopy": "下垂姿勢", - "tatsugiriStretchy": "平挺姿勢", - "gimmighoulChest": "寶箱形態", - "gimmighoulRoaming": "徒步形態", - "koraidonApexBuild": "頂尖形態", - "koraidonLimitedBuild":"限制形態", - "koraidonSprintingBuild":"沖刺形態", - "koraidonSwimmingBuild":"遊泳形態", - "koraidonGlidingBuild":"滑翔形態", - "miraidonUltimateMode":"極限模式", - "miraidonLowPowerMode":"節能模式", - "miraidonDriveMode":"駕駛模式", - "miraidonAquaticMode":"水上模式", - "miraidonGlideMode":"滑翔模式", - "poltchageistCounterfeit": "冒牌貨", - "poltchageistArtisan": "高檔貨", - "paldeaTaurosCombat": "鬥戰種", - "paldeaTaurosBlaze": "火熾種", - "paldeaTaurosAqua": "水瀾種" -} diff --git a/src/locales/zh_TW/pokemon-info-container.json b/src/locales/zh_TW/pokemon-info-container.json deleted file mode 100644 index 15b5f4a2da5..00000000000 --- a/src/locales/zh_TW/pokemon-info-container.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "moveset": "招式", - "gender": "性别:", - "ability": "特性:", - "nature": "性格:" -} \ No newline at end of file diff --git a/src/locales/zh_TW/pokemon-info.json b/src/locales/zh_TW/pokemon-info.json deleted file mode 100644 index f2e29875e75..00000000000 --- a/src/locales/zh_TW/pokemon-info.json +++ /dev/null @@ -1,40 +0,0 @@ -{ - "Stat": { - "HP": "最大生命", - "HPshortened": "生命", - "ATK": "物理攻擊", - "ATKshortened": "物攻", - "DEF": "物理防禦", - "DEFshortened": "物防", - "SPATK": "特殊攻擊", - "SPATKshortened": "特攻", - "SPDEF": "特殊防禦", - "SPDEFshortened": "特防", - "SPD": "速度", - "SPDshortened": "速度", - "ACC": "命中率", - "EVA": "回避率" - }, - "Type": { - "UNKNOWN": "未知", - "NORMAL": "一般", - "FIGHTING": "格鬥", - "FLYING": "飛行", - "POISON": "毒", - "GROUND": "地面", - "ROCK": "岩石", - "BUG": "蟲", - "GHOST": "幽靈", - "STEEL": "鋼", - "FIRE": "火", - "WATER": "水", - "GRASS": "草", - "ELECTRIC": "電", - "PSYCHIC": "超能力", - "ICE": "冰", - "DRAGON": "龍", - "DARK": "惡", - "FAIRY": "妖精", - "STELLAR": "星晶" - } -} diff --git a/src/locales/zh_TW/pokemon-summary.json b/src/locales/zh_TW/pokemon-summary.json deleted file mode 100644 index 331330f5bdd..00000000000 --- a/src/locales/zh_TW/pokemon-summary.json +++ /dev/null @@ -1,45 +0,0 @@ -{ - "pokemonInfo": "寶可夢信息", - "status": "狀態", - "powerAccuracyCategory": "威力\n命中率\n類別", - "type": "屬性", - "unknownTrainer": "未知", - "ot": "訓練師", - "nature": "性格", - "expPoints": "經驗值", - "nextLv": "下一級", - "cancel": "取消", - - "memoString": "{{natureFragment}} 性格,\n{{metFragment}}", - "metFragment": { - "normal": "met at Lv{{level}},\n{{biome}}, Wave {{wave}}.", - "apparently": "命中注定般地相遇于Lv.{{level}},\n{{biome}}。" - }, - "natureFragment": { - "Hardy": "{{nature}}", - "Lonely": "{{nature}}", - "Brave": "{{nature}}", - "Adamant": "{{nature}}", - "Naughty": "{{nature}}", - "Bold": "{{nature}}", - "Docile": "{{nature}}", - "Relaxed": "{{nature}}", - "Impish": "{{nature}}", - "Lax": "{{nature}}", - "Timid": "{{nature}}", - "Hasty": "{{nature}}", - "Serious": "{{nature}}", - "Jolly": "{{nature}}", - "Naive": "{{nature}}", - "Modest": "{{nature}}", - "Mild": "{{nature}}", - "Quiet": "{{nature}}", - "Bashful": "{{nature}}", - "Rash": "{{nature}}", - "Calm": "{{nature}}", - "Gentle": "{{nature}}", - "Sassy": "{{nature}}", - "Careful": "{{nature}}", - "Quirky": "{{nature}}" - } -} diff --git a/src/locales/zh_TW/pokemon.json b/src/locales/zh_TW/pokemon.json deleted file mode 100644 index 4acd4a21fd5..00000000000 --- a/src/locales/zh_TW/pokemon.json +++ /dev/null @@ -1,1084 +0,0 @@ -{ - "bulbasaur": "妙蛙種子", - "ivysaur": "妙蛙草", - "venusaur": "妙蛙花", - "charmander": "小火龍", - "charmeleon": "火恐龍", - "charizard": "噴火龍", - "squirtle": "傑尼龜", - "wartortle": "卡咪龜", - "blastoise": "水箭龜", - "caterpie": "綠毛蟲", - "metapod": "鐵甲蛹", - "butterfree": "巴大蝶", - "weedle": "獨角蟲", - "kakuna": "鐵殼蛹", - "beedrill": "大針蜂", - "pidgey": "波波", - "pidgeotto": "比比鳥", - "pidgeot": "大比鳥", - "rattata": "小拉達", - "raticate": "拉達", - "spearow": "烈雀", - "fearow": "大嘴雀", - "ekans": "阿柏蛇", - "arbok": "阿柏怪", - "pikachu": "皮卡丘", - "raichu": "雷丘", - "sandshrew": "穿山鼠", - "sandslash": "穿山王", - "nidoran_f": "尼多蘭", - "nidorina": "尼多娜", - "nidoqueen": "尼多后", - "nidoran_m": "尼多朗", - "nidorino": "尼多力諾", - "nidoking": "尼多王", - "clefairy": "皮皮", - "clefable": "皮可西", - "vulpix": "六尾", - "ninetales": "九尾", - "jigglypuff": "胖丁", - "wigglytuff": "胖可丁", - "zubat": "超音蝠", - "golbat": "大嘴蝠", - "oddish": "走路草", - "gloom": "臭臭花", - "vileplume": "霸王花", - "paras": "派拉斯", - "parasect": "派拉斯特", - "venonat": "毛球", - "venomoth": "摩魯蛾", - "diglett": "地鼠", - "dugtrio": "三地鼠", - "meowth": "喵喵", - "persian": "貓老大", - "psyduck": "可達鴨", - "golduck": "哥達鴨", - "mankey": "猴怪", - "primeape": "火爆猴", - "growlithe": "卡蒂狗", - "arcanine": "風速狗", - "poliwag": "蚊香蝌蚪", - "poliwhirl": "蚊香君", - "poliwrath": "蚊香泳士", - "abra": "凱西", - "kadabra": "勇基拉", - "alakazam": "胡地", - "machop": "腕力", - "machoke": "豪力", - "machamp": "怪力", - "bellsprout": "喇叭芽", - "weepinbell": "口呆花", - "victreebel": "大食花", - "tentacool": "瑪瑙水母", - "tentacruel": "毒刺水母", - "geodude": "小拳石", - "graveler": "隆隆石", - "golem": "隆隆岩", - "ponyta": "小火馬", - "rapidash": "烈焰馬", - "slowpoke": "呆呆獸", - "slowbro": "呆殼獸", - "magnemite": "小磁怪", - "magneton": "三合一磁怪", - "farfetchd": "大蔥鴨", - "doduo": "嘟嘟", - "dodrio": "嘟嘟利", - "seel": "小海獅", - "dewgong": "白海獅", - "grimer": "臭泥", - "muk": "臭臭泥", - "shellder": "大舌貝", - "cloyster": "刺甲貝", - "gastly": "鬼斯", - "haunter": "鬼斯通", - "gengar": "耿鬼", - "onix": "大岩蛇", - "drowzee": "催眠貘", - "hypno": "引夢貘人", - "krabby": "大鉗蟹", - "kingler": "巨鉗蟹", - "voltorb": "霹靂電球", - "electrode": "頑皮雷彈", - "exeggcute": "蛋蛋", - "exeggutor": "椰蛋樹", - "cubone": "卡拉卡拉", - "marowak": "嘎啦嘎啦", - "hitmonlee": "飛腿郎", - "hitmonchan": "快拳郎", - "lickitung": "大舌頭", - "koffing": "瓦斯彈", - "weezing": "雙彈瓦斯", - "rhyhorn": "獨角犀牛", - "rhydon": "鑽角犀獸", - "chansey": "吉利蛋", - "tangela": "蔓藤怪", - "kangaskhan": "袋獸", - "horsea": "墨海馬", - "seadra": "海刺龍", - "goldeen": "角金魚", - "seaking": "金魚王", - "staryu": "海星星", - "starmie": "寶石海星", - "mr_mime": "魔牆人偶", - "scyther": "飛天螳螂", - "jynx": "迷脣姐", - "electabuzz": "電擊獸", - "magmar": "鴨嘴火獸", - "pinsir": "凱羅斯", - "tauros": "肯泰羅", - "magikarp": "鯉魚王", - "gyarados": "暴鯉龍", - "lapras": "拉普拉斯", - "ditto": "百變怪", - "eevee": "伊布", - "vaporeon": "水伊布", - "jolteon": "雷伊布", - "flareon": "火伊布", - "porygon": "多邊獸", - "omanyte": "菊石獸", - "omastar": "多刺菊石獸", - "kabuto": "化石盔", - "kabutops": "鐮刀盔", - "aerodactyl": "化石翼龍", - "snorlax": "卡比獸", - "articuno": "急凍鳥", - "zapdos": "閃電鳥", - "moltres": "火焰鳥", - "dratini": "迷你龍", - "dragonair": "哈克龍", - "dragonite": "快龍", - "mewtwo": "超夢", - "mew": "夢幻", - "chikorita": "菊草葉", - "bayleef": "月桂葉", - "meganium": "大竺葵", - "cyndaquil": "火球鼠", - "quilava": "火岩鼠", - "typhlosion": "火暴獸", - "totodile": "小鋸鱷", - "croconaw": "藍鱷", - "feraligatr": "大力鱷", - "sentret": "尾立", - "furret": "大尾立", - "hoothoot": "咕咕", - "noctowl": "貓頭夜鷹", - "ledyba": "芭瓢蟲", - "ledian": "安瓢蟲", - "spinarak": "圓絲蛛", - "ariados": "阿利多斯", - "crobat": "叉字蝠", - "chinchou": "燈籠魚", - "lanturn": "電燈怪", - "pichu": "皮丘", - "cleffa": "皮寶寶", - "igglybuff": "寶寶丁", - "togepi": "波克比", - "togetic": "波克基古", - "natu": "天然雀", - "xatu": "天然鳥", - "mareep": "咩利羊", - "flaaffy": "茸茸羊", - "ampharos": "電龍", - "bellossom": "美麗花", - "marill": "瑪力露", - "azumarill": "瑪力露麗", - "sudowoodo": "樹才怪", - "politoed": "蚊香蛙皇", - "hoppip": "毽子草", - "skiploom": "毽子花", - "jumpluff": "毽子棉", - "aipom": "長尾怪手", - "sunkern": "向日種子", - "sunflora": "向日花怪", - "yanma": "蜻蜻蜓", - "wooper": "烏波", - "quagsire": "沼王", - "espeon": "太陽伊布", - "umbreon": "月亮伊布", - "murkrow": "黑暗鴉", - "slowking": "呆呆王", - "misdreavus": "夢妖", - "unown": "未知圖騰", - "wobbuffet": "果然翁", - "girafarig": "麒麟奇", - "pineco": "榛果球", - "forretress": "佛烈託斯", - "dunsparce": "土龍弟弟", - "gligar": "天蠍", - "steelix": "大鋼蛇", - "snubbull": "布魯", - "granbull": "布魯皇", - "qwilfish": "千針魚", - "scizor": "巨鉗螳螂", - "shuckle": "壺壺", - "heracross": "赫拉克羅斯", - "sneasel": "狃拉", - "teddiursa": "熊寶寶", - "ursaring": "圈圈熊", - "slugma": "熔岩蟲", - "magcargo": "熔岩蝸牛", - "swinub": "小山豬", - "piloswine": "長毛豬", - "corsola": "太陽珊瑚", - "remoraid": "鐵炮魚", - "octillery": "章魚桶", - "delibird": "信使鳥", - "mantine": "巨翅飛魚", - "skarmory": "盔甲鳥", - "houndour": "戴魯比", - "houndoom": "黑魯加", - "kingdra": "刺龍王", - "phanpy": "小小象", - "donphan": "頓甲", - "porygon2": "多邊獸Ⅱ", - "stantler": "驚角鹿", - "smeargle": "圖圖犬", - "tyrogue": "無畏小子", - "hitmontop": "戰舞郎", - "smoochum": "迷脣娃", - "elekid": "電擊怪", - "magby": "鴨嘴寶寶", - "miltank": "大奶罐", - "blissey": "幸福蛋", - "raikou": "雷公", - "entei": "炎帝", - "suicune": "水君", - "larvitar": "幼基拉斯", - "pupitar": "沙基拉斯", - "tyranitar": "班基拉斯", - "lugia": "洛奇亞", - "ho_oh": "鳳王", - "celebi": "時拉比", - "treecko": "木守宮", - "grovyle": "森林蜥蜴", - "sceptile": "蜥蜴王", - "torchic": "火稚雞", - "combusken": "力壯雞", - "blaziken": "火焰雞", - "mudkip": "水躍魚", - "marshtomp": "沼躍魚", - "swampert": "巨沼怪", - "poochyena": "土狼犬", - "mightyena": "大狼犬", - "zigzagoon": "蛇紋熊", - "linoone": "直衝熊", - "wurmple": "刺尾蟲", - "silcoon": "甲殼繭", - "beautifly": "狩獵鳳蝶", - "cascoon": "盾甲繭", - "dustox": "毒粉蛾", - "lotad": "蓮葉童子", - "lombre": "蓮帽小童", - "ludicolo": "樂天河童", - "seedot": "橡實果", - "nuzleaf": "長鼻葉", - "shiftry": "狡猾天狗", - "taillow": "傲骨燕", - "swellow": "大王燕", - "wingull": "長翅鷗", - "pelipper": "大嘴鷗", - "ralts": "拉魯拉絲", - "kirlia": "奇魯莉安", - "gardevoir": "沙奈朵", - "surskit": "溜溜糖球", - "masquerain": "雨翅蛾", - "shroomish": "蘑蘑菇", - "breloom": "斗笠菇", - "slakoth": "懶人獺", - "vigoroth": "過動猿", - "slaking": "請假王", - "nincada": "土居忍士", - "ninjask": "鐵面忍者", - "shedinja": "脫殼忍者", - "whismur": "咕妞妞", - "loudred": "吼爆彈", - "exploud": "爆音怪", - "makuhita": "幕下力士", - "hariyama": "鐵掌力士", - "azurill": "露力麗", - "nosepass": "朝北鼻", - "skitty": "向尾喵", - "delcatty": "優雅貓", - "sableye": "勾魂眼", - "mawile": "大嘴娃", - "aron": "可可多拉", - "lairon": "可多拉", - "aggron": "波士可多拉", - "meditite": "瑪沙那", - "medicham": "恰雷姆", - "electrike": "落雷獸", - "manectric": "雷電獸", - "plusle": "正電拍拍", - "minun": "負電拍拍", - "volbeat": "電螢蟲", - "illumise": "甜甜螢", - "roselia": "毒薔薇", - "gulpin": "溶食獸", - "swalot": "吞食獸", - "carvanha": "利牙魚", - "sharpedo": "巨牙鯊", - "wailmer": "吼吼鯨", - "wailord": "吼鯨王", - "numel": "呆火駝", - "camerupt": "噴火駝", - "torkoal": "煤炭龜", - "spoink": "跳跳豬", - "grumpig": "噗噗豬", - "spinda": "晃晃斑", - "trapinch": "大顎蟻", - "vibrava": "超音波幼蟲", - "flygon": "沙漠蜻蜓", - "cacnea": "刺球仙人掌", - "cacturne": "夢歌仙人掌", - "swablu": "青綿鳥", - "altaria": "七夕青鳥", - "zangoose": "貓鼬斬", - "seviper": "飯匙蛇", - "lunatone": "月石", - "solrock": "太陽岩", - "barboach": "泥泥鰍", - "whiscash": "鯰魚王", - "corphish": "龍蝦小兵", - "crawdaunt": "鐵螯龍蝦", - "baltoy": "天秤偶", - "claydol": "念力土偶", - "lileep": "觸手百合", - "cradily": "搖籃百合", - "anorith": "太古羽蟲", - "armaldo": "太古盔甲", - "feebas": "醜醜魚", - "milotic": "美納斯", - "castform": "飄浮泡泡", - "kecleon": "變隱龍", - "shuppet": "怨影娃娃", - "banette": "詛咒娃娃", - "duskull": "夜巡靈", - "dusclops": "彷徨夜靈", - "tropius": "熱帶龍", - "chimecho": "風鈴鈴", - "absol": "阿勃梭魯", - "wynaut": "小果然", - "snorunt": "雪童子", - "glalie": "冰鬼護", - "spheal": "海豹球", - "sealeo": "海魔獅", - "walrein": "帝牙海獅", - "clamperl": "珍珠貝", - "huntail": "獵斑魚", - "gorebyss": "櫻花魚", - "relicanth": "古空棘魚", - "luvdisc": "愛心魚", - "bagon": "寶貝龍", - "shelgon": "甲殼龍", - "salamence": "暴飛龍", - "beldum": "鐵啞鈴", - "metang": "金屬怪", - "metagross": "巨金怪", - "regirock": "雷吉洛克", - "regice": "雷吉艾斯", - "registeel": "雷吉斯奇魯", - "latias": "拉帝亞斯", - "latios": "拉帝歐斯", - "kyogre": "蓋歐卡", - "groudon": "固拉多", - "rayquaza": "烈空坐", - "jirachi": "基拉祈", - "deoxys": "代歐奇希斯", - "turtwig": "草苗龜", - "grotle": "樹林龜", - "torterra": "土臺龜", - "chimchar": "小火焰猴", - "monferno": "猛火猴", - "infernape": "烈焰猴", - "piplup": "波加曼", - "prinplup": "波皇子", - "empoleon": "帝王拿波", - "starly": "姆克兒", - "staravia": "姆克鳥", - "staraptor": "姆克鷹", - "bidoof": "大牙狸", - "bibarel": "大尾狸", - "kricketot": "圓法師", - "kricketune": "音箱蟀", - "shinx": "小貓怪", - "luxio": "勒克貓", - "luxray": "倫琴貓", - "budew": "含羞苞", - "roserade": "羅絲雷朵", - "cranidos": "頭蓋龍", - "rampardos": "戰槌龍", - "shieldon": "盾甲龍", - "bastiodon": "護城龍", - "burmy": "結草兒", - "wormadam": "結草貴婦", - "mothim": "紳士蛾", - "combee": "三蜜蜂", - "vespiquen": "蜂女王", - "pachirisu": "帕奇利茲", - "buizel": "泳圈鼬", - "floatzel": "浮潛鼬", - "cherubi": "櫻花寶", - "cherrim": "櫻花兒", - "shellos": "無殼海兔", - "gastrodon": "海兔獸", - "ambipom": "雙尾怪手", - "drifloon": "飄飄球", - "drifblim": "隨風球", - "buneary": "卷卷耳", - "lopunny": "長耳兔", - "mismagius": "夢妖魔", - "honchkrow": "烏鴉頭頭", - "glameow": "魅力喵", - "purugly": "東施喵", - "chingling": "鈴鐺響", - "stunky": "臭鼬噗", - "skuntank": "坦克臭鼬", - "bronzor": "銅鏡怪", - "bronzong": "青銅鐘", - "bonsly": "盆才怪", - "mime_jr": "魔尼尼", - "happiny": "小福蛋", - "chatot": "聒噪鳥", - "spiritomb": "花岩怪", - "gible": "圓陸鯊", - "gabite": "尖牙陸鯊", - "garchomp": "烈咬陸鯊", - "munchlax": "小卡比獸", - "riolu": "利歐路", - "lucario": "路卡利歐", - "hippopotas": "沙河馬", - "hippowdon": "河馬獸", - "skorupi": "鉗尾蠍", - "drapion": "龍王蠍", - "croagunk": "不良蛙", - "toxicroak": "毒骷蛙", - "carnivine": "尖牙籠", - "finneon": "熒光魚", - "lumineon": "霓虹魚", - "mantyke": "小球飛魚", - "snover": "雪笠怪", - "abomasnow": "暴雪王", - "weavile": "瑪狃拉", - "magnezone": "自爆磁怪", - "lickilicky": "大舌舔", - "rhyperior": "超甲狂犀", - "tangrowth": "巨蔓藤", - "electivire": "電擊魔獸", - "magmortar": "鴨嘴炎獸", - "togekiss": "波克基斯", - "yanmega": "遠古巨蜓", - "leafeon": "葉伊布", - "glaceon": "冰伊布", - "gliscor": "天蠍王", - "mamoswine": "象牙豬", - "porygon_z": "多邊獸Z", - "gallade": "艾路雷朵", - "probopass": "大朝北鼻", - "dusknoir": "黑夜魔靈", - "froslass": "雪妖女", - "rotom": "洛托姆", - "uxie": "由克希", - "mesprit": "艾姆利多", - "azelf": "亞克諾姆", - "dialga": "帝牙盧卡", - "palkia": "帕路奇亞", - "heatran": "席多藍恩", - "regigigas": "雷吉奇卡斯", - "giratina": "騎拉帝納", - "cresselia": "克雷色利亞", - "phione": "霏歐納", - "manaphy": "瑪納霏", - "darkrai": "達克萊伊", - "shaymin": "謝米", - "arceus": "阿爾宙斯", - "victini": "比克提尼", - "snivy": "藤藤蛇", - "servine": "青藤蛇", - "serperior": "君主蛇", - "tepig": "暖暖豬", - "pignite": "炒炒豬", - "emboar": "炎武王", - "oshawott": "水水獺", - "dewott": "雙刃丸", - "samurott": "大劍鬼", - "patrat": "探探鼠", - "watchog": "步哨鼠", - "lillipup": "小約克", - "herdier": "哈約克", - "stoutland": "長毛狗", - "purrloin": "扒手貓", - "liepard": "酷豹", - "pansage": "花椰猴", - "simisage": "花椰猿", - "pansear": "爆香猴", - "simisear": "爆香猿", - "panpour": "冷水猴", - "simipour": "冷水猿", - "munna": "食夢夢", - "musharna": "夢夢蝕", - "pidove": "豆豆鴿", - "tranquill": "咕咕鴿", - "unfezant": "高傲雉雞", - "blitzle": "斑斑馬", - "zebstrika": "雷電斑馬", - "roggenrola": "石丸子", - "boldore": "地幔岩", - "gigalith": "龐岩怪", - "woobat": "滾滾蝙蝠", - "swoobat": "心蝙蝠", - "drilbur": "螺釘地鼠", - "excadrill": "龍頭地鼠", - "audino": "差不多娃娃", - "timburr": "搬運小匠", - "gurdurr": "鐵骨土人", - "conkeldurr": "修建老匠", - "tympole": "圓蝌蚪", - "palpitoad": "藍蟾蜍", - "seismitoad": "蟾蜍王", - "throh": "投摔鬼", - "sawk": "打擊鬼", - "sewaddle": "蟲寶包", - "swadloon": "寶包繭", - "leavanny": "保姆蟲", - "venipede": "百足蜈蚣", - "whirlipede": "車輪毬", - "scolipede": "蜈蚣王", - "cottonee": "木棉球", - "whimsicott": "風妖精", - "petilil": "百合根娃娃", - "lilligant": "裙兒小姐", - "basculin": "野蠻鱸魚", - "sandile": "黑眼鱷", - "krokorok": "混混鱷", - "krookodile": "流氓鱷", - "darumaka": "火紅不倒翁", - "darmanitan": "達摩狒狒", - "maractus": "沙鈴仙人掌", - "dwebble": "石居蟹", - "crustle": "岩殿居蟹", - "scraggy": "滑滑小子", - "scrafty": "頭巾混混", - "sigilyph": "象徵鳥", - "yamask": "哭哭面具", - "cofagrigus": "死神棺", - "tirtouga": "原蓋海龜", - "carracosta": "肋骨海龜", - "archen": "始祖小鳥", - "archeops": "始祖大鳥", - "trubbish": "破破袋", - "garbodor": "灰塵山", - "zorua": "索羅亞", - "zoroark": "索羅亞克", - "minccino": "泡沫栗鼠", - "cinccino": "奇諾栗鼠", - "gothita": "哥德寶寶", - "gothorita": "哥德小童", - "gothitelle": "哥德小姐", - "solosis": "單卵細胞球", - "duosion": "雙卵細胞球", - "reuniclus": "人造細胞卵", - "ducklett": "鴨寶寶", - "swanna": "舞天鵝", - "vanillite": "迷你冰", - "vanillish": "多多冰", - "vanilluxe": "雙倍多多冰", - "deerling": "四季鹿", - "sawsbuck": "萌芽鹿", - "emolga": "電飛鼠", - "karrablast": "蓋蓋蟲", - "escavalier": "騎士蝸牛", - "foongus": "哎呀球菇", - "amoonguss": "敗露球菇", - "frillish": "輕飄飄", - "jellicent": "胖嘟嘟", - "alomomola": "保姆曼波", - "joltik": "電電蟲", - "galvantula": "電蜘蛛", - "ferroseed": "種子鐵球", - "ferrothorn": "堅果啞鈴", - "klink": "齒輪兒", - "klang": "齒輪組", - "klinklang": "齒輪怪", - "tynamo": "麻麻小魚", - "eelektrik": "麻麻鰻", - "eelektross": "麻麻鰻魚王", - "elgyem": "小灰怪", - "beheeyem": "大宇怪", - "litwick": "燭光靈", - "lampent": "燈火幽靈", - "chandelure": "水晶燈火靈", - "axew": "牙牙", - "fraxure": "斧牙龍", - "haxorus": "雙斧戰龍", - "cubchoo": "噴嚏熊", - "beartic": "凍原熊", - "cryogonal": "幾何雪花", - "shelmet": "小嘴蝸", - "accelgor": "敏捷蟲", - "stunfisk": "泥巴魚", - "mienfoo": "功夫鼬", - "mienshao": "師父鼬", - "druddigon": "赤面龍", - "golett": "泥偶小人", - "golurk": "泥偶巨人", - "pawniard": "駒刀小兵", - "bisharp": "劈斬司令", - "bouffalant": "爆炸頭水牛", - "rufflet": "毛頭小鷹", - "braviary": "勇士雄鷹", - "vullaby": "禿鷹丫頭", - "mandibuzz": "禿鷹娜", - "heatmor": "熔蟻獸", - "durant": "鐵蟻", - "deino": "單首龍", - "zweilous": "雙首暴龍", - "hydreigon": "三首惡龍", - "larvesta": "燃燒蟲", - "volcarona": "火神蛾", - "cobalion": "勾帕路翁", - "terrakion": "代拉基翁", - "virizion": "畢力吉翁", - "tornadus": "龍捲雲", - "thundurus": "雷電雲", - "reshiram": "萊希拉姆", - "zekrom": "捷克羅姆", - "landorus": "土地雲", - "kyurem": "酋雷姆", - "keldeo": "凱路迪歐", - "meloetta": "美洛耶塔", - "genesect": "蓋諾賽克特", - "chespin": "哈力栗", - "quilladin": "胖胖哈力", - "chesnaught": "布里卡隆", - "fennekin": "火狐狸", - "braixen": "長尾火狐", - "delphox": "妖火紅狐", - "froakie": "呱呱泡蛙", - "frogadier": "呱頭蛙", - "greninja": "甲賀忍蛙", - "bunnelby": "掘掘兔", - "diggersby": "掘地兔", - "fletchling": "小箭雀", - "fletchinder": "火箭雀", - "talonflame": "烈箭鷹", - "scatterbug": "粉蝶蟲", - "spewpa": "粉蝶蛹", - "vivillon": "彩粉蝶", - "litleo": "小獅獅", - "pyroar": "火炎獅", - "flabebe": "花蓓蓓", - "floette": "花葉蒂", - "florges": "花潔夫人", - "skiddo": "坐騎小羊", - "gogoat": "坐騎山羊", - "pancham": "頑皮熊貓", - "pangoro": "霸道熊貓", - "furfrou": "多麗米亞", - "espurr": "妙喵", - "meowstic": "超能妙喵", - "honedge": "獨劍鞘", - "doublade": "雙劍鞘", - "aegislash": "堅盾劍怪", - "spritzee": "粉香香", - "aromatisse": "芳香精", - "swirlix": "綿綿泡芙", - "slurpuff": "胖甜妮", - "inkay": "好啦魷", - "malamar": "烏賊王", - "binacle": "龜腳腳", - "barbaracle": "龜足巨鎧", - "skrelp": "垃垃藻", - "dragalge": "毒藻龍", - "clauncher": "鐵臂槍蝦", - "clawitzer": "鋼炮臂蝦", - "helioptile": "傘電蜥", - "heliolisk": "光電傘蜥", - "tyrunt": "寶寶暴龍", - "tyrantrum": "怪顎龍", - "amaura": "冰雪龍", - "aurorus": "冰雪巨龍", - "sylveon": "仙子伊布", - "hawlucha": "摔角鷹人", - "dedenne": "咚咚鼠", - "carbink": "小碎鑽", - "goomy": "黏黏寶", - "sliggoo": "黏美兒", - "goodra": "黏美龍", - "klefki": "鑰圈兒", - "phantump": "小木靈", - "trevenant": "朽木妖", - "pumpkaboo": "南瓜精", - "gourgeist": "南瓜怪人", - "bergmite": "冰寶", - "avalugg": "冰岩怪", - "noibat": "嗡蝠", - "noivern": "音波龍", - "xerneas": "哲爾尼亞斯", - "yveltal": "伊裴爾塔爾", - "zygarde": "基格爾德", - "diancie": "蒂安希", - "hoopa": "胡帕", - "volcanion": "波爾凱尼恩", - "rowlet": "木木梟", - "dartrix": "投羽梟", - "decidueye": "狙射樹梟", - "litten": "火斑喵", - "torracat": "炎熱喵", - "incineroar": "熾焰咆哮虎", - "popplio": "球球海獅", - "brionne": "花漾海獅", - "primarina": "西獅海壬", - "pikipek": "小篤兒", - "trumbeak": "喇叭啄鳥", - "toucannon": "銃嘴大鳥", - "yungoos": "貓鼬少", - "gumshoos": "貓鼬探長", - "grubbin": "強顎雞母蟲", - "charjabug": "蟲電寶", - "vikavolt": "鍬農炮蟲", - "crabrawler": "好勝蟹", - "crabominable": "好勝毛蟹", - "oricorio": "花舞鳥", - "cutiefly": "萌虻", - "ribombee": "蝶結萌虻", - "rockruff": "岩狗狗", - "lycanroc": "鬃岩狼人", - "wishiwashi": "弱丁魚", - "mareanie": "好壞星", - "toxapex": "超壞星", - "mudbray": "泥驢仔", - "mudsdale": "重泥挽馬", - "dewpider": "滴蛛", - "araquanid": "滴蛛霸", - "fomantis": "僞螳草", - "lurantis": "蘭螳花", - "morelull": "睡睡菇", - "shiinotic": "燈罩夜菇", - "salandit": "夜盜火蜥", - "salazzle": "焰后蜥", - "stufful": "童偶熊", - "bewear": "穿着熊", - "bounsweet": "甜竹竹", - "steenee": "甜舞妮", - "tsareena": "甜冷美后", - "comfey": "花療環環", - "oranguru": "智揮猩", - "passimian": "投擲猴", - "wimpod": "膽小蟲", - "golisopod": "具甲武者", - "sandygast": "沙丘娃", - "palossand": "噬沙堡爺", - "pyukumuku": "拳海蔘", - "type_null": "屬性:空", - "silvally": "銀伴戰獸", - "minior": "小隕星", - "komala": "樹枕尾熊", - "turtonator": "爆焰龜獸", - "togedemaru": "託戈德瑪爾", - "mimikyu": "謎擬Q", - "bruxish": "磨牙彩皮魚", - "drampa": "老翁龍", - "dhelmise": "破破舵輪", - "jangmo_o": "心鱗寶", - "hakamo_o": "鱗甲龍", - "kommo_o": "杖尾鱗甲龍", - "tapu_koko": "卡璞・鳴鳴", - "tapu_lele": "卡璞・蝶蝶", - "tapu_bulu": "卡璞・哞哞", - "tapu_fini": "卡璞・鰭鰭", - "cosmog": "科斯莫古", - "cosmoem": "科斯莫姆", - "solgaleo": "索爾迦雷歐", - "lunala": "露奈雅拉", - "nihilego": "虛吾伊德", - "buzzwole": "爆肌蚊", - "pheromosa": "費洛美螂", - "xurkitree": "電束木", - "celesteela": "鐵火輝夜", - "kartana": "紙御劍", - "guzzlord": "惡食大王", - "necrozma": "奈克洛茲瑪", - "magearna": "瑪機雅娜", - "marshadow": "瑪夏多", - "poipole": "毒貝比", - "naganadel": "四顎針龍", - "stakataka": "壘磊石", - "blacephalon": "砰頭小丑", - "zeraora": "捷拉奧拉", - "meltan": "美錄坦", - "melmetal": "美錄梅塔", - "grookey": "敲音猴", - "thwackey": "啪咚猴", - "rillaboom": "轟擂金剛猩", - "scorbunny": "炎兔兒", - "raboot": "騰蹴小將", - "cinderace": "閃焰王牌", - "sobble": "淚眼蜥", - "drizzile": "變澀蜥", - "inteleon": "千面避役", - "skwovet": "貪心栗鼠", - "greedent": "藏飽栗鼠", - "rookidee": "稚山雀", - "corvisquire": "藍鴉", - "corviknight": "鋼鎧鴉", - "blipbug": "索偵蟲", - "dottler": "天罩蟲", - "orbeetle": "以歐路普", - "nickit": "偷兒狐", - "thievul": "狐大盜", - "gossifleur": "幼棉棉", - "eldegoss": "白蓬蓬", - "wooloo": "毛辮羊", - "dubwool": "毛毛角羊", - "chewtle": "咬咬龜", - "drednaw": "暴噬龜", - "yamper": "來電汪", - "boltund": "逐電犬", - "rolycoly": "小炭仔", - "carkol": "大炭車", - "coalossal": "巨炭山", - "applin": "啃果蟲", - "flapple": "蘋裹龍", - "appletun": "豐蜜龍", - "silicobra": "沙包蛇", - "sandaconda": "沙螺蟒", - "cramorant": "古月鳥", - "arrokuda": "刺梭魚", - "barraskewda": "戽斗尖梭", - "toxel": "毒電嬰", - "toxtricity": "顫弦蠑螈", - "sizzlipede": "燒火蚣", - "centiskorch": "焚焰蚣", - "clobbopus": "拳拳蛸", - "grapploct": "八爪武師", - "sinistea": "來悲茶", - "polteageist": "怖思壺", - "hatenna": "迷布莉姆", - "hattrem": "提布莉姆", - "hatterene": "布莉姆溫", - "impidimp": "搗蛋小妖", - "morgrem": "詐唬魔", - "grimmsnarl": "長毛巨魔", - "obstagoon": "堵攔熊", - "perrserker": "喵頭目", - "cursola": "魔靈珊瑚", - "sirfetchd": "蔥遊兵", - "mr_rime": "踏冰人偶", - "runerigus": "死神板", - "milcery": "小仙奶", - "alcremie": "霜奶仙", - "falinks": "列陣兵", - "pincurchin": "啪嚓海膽", - "snom": "雪吞蟲", - "frosmoth": "雪絨蛾", - "stonjourner": "巨石丁", - "eiscue": "冰砌鵝", - "indeedee": "愛管侍", - "morpeko": "莫魯貝可", - "cufant": "銅象", - "copperajah": "大王銅象", - "dracozolt": "雷鳥龍", - "arctozolt": "雷鳥海獸", - "dracovish": "鰓魚龍", - "arctovish": "鰓魚海獸", - "duraludon": "鋁鋼龍", - "dreepy": "多龍梅西亞", - "drakloak": "多龍奇", - "dragapult": "多龍巴魯託", - "zacian": "蒼響", - "zamazenta": "藏瑪然特", - "eternatus": "無極汰那", - "kubfu": "熊徒弟", - "urshifu": "武道熊師", - "zarude": "薩戮德", - "regieleki": "雷吉艾勒奇", - "regidrago": "雷吉鐸拉戈", - "glastrier": "雪暴馬", - "spectrier": "靈幽馬", - "calyrex": "蕾冠王", - "wyrdeer": "詭角鹿", - "kleavor": "劈斧螳螂", - "ursaluna": "月月熊", - "basculegion": "幽尾玄魚", - "sneasler": "大狃拉", - "overqwil": "萬針魚", - "enamorus": "眷戀雲", - "sprigatito": "新葉喵", - "floragato": "蒂蕾喵", - "meowscarada": "魔幻假面喵", - "fuecoco": "呆火鱷", - "crocalor": "炙燙鱷", - "skeledirge": "骨紋巨聲鱷", - "quaxly": "潤水鴨", - "quaxwell": "湧躍鴨", - "quaquaval": "狂歡浪舞鴨", - "lechonk": "愛吃豚", - "oinkologne": "飄香豚", - "tarountula": "團珠蛛", - "spidops": "操陷蛛", - "nymble": "豆蟋蟀", - "lokix": "烈腿蝗", - "pawmi": "布撥", - "pawmo": "布土撥", - "pawmot": "巴布土撥", - "tandemaus": "一對鼠", - "maushold": "一家鼠", - "fidough": "狗仔包", - "dachsbun": "麻花犬", - "smoliv": "迷你芙", - "dolliv": "奧利紐", - "arboliva": "奧利瓦", - "squawkabilly": "怒鸚哥", - "nacli": "鹽石寶", - "naclstack": "鹽石壘", - "garganacl": "鹽石巨靈", - "charcadet": "炭小侍", - "armarouge": "紅蓮鎧騎", - "ceruledge": "蒼炎刃鬼", - "tadbulb": "光蚪仔", - "bellibolt": "電肚蛙", - "wattrel": "電海燕", - "kilowattrel": "大電海燕", - "maschiff": "偶叫獒", - "mabosstiff": "獒教父", - "shroodle": "滋汁鼴", - "grafaiai": "塗標客", - "bramblin": "納噬草", - "brambleghast": "怖納噬草", - "toedscool": "原野水母", - "toedscruel": "陸地水母", - "klawf": "毛崖蟹", - "capsakid": "熱辣娃", - "scovillain": "狠辣椒", - "rellor": "蟲滾泥", - "rabsca": "蟲甲聖", - "flittle": "飄飄雛", - "espathra": "超能豔鴕", - "tinkatink": "小鍛匠", - "tinkatuff": "巧鍛匠", - "tinkaton": "巨鍛匠", - "wiglett": "海地鼠", - "wugtrio": "三海地鼠", - "bombirdier": "下石鳥", - "finizen": "波普海豚", - "palafin": "海豚俠", - "varoom": "噗隆隆", - "revavroom": "普隆隆姆", - "cyclizar": "摩托蜥", - "orthworm": "拖拖蚓", - "glimmet": "晶光芽", - "glimmora": "晶光花", - "greavard": "墓仔狗", - "houndstone": "墓揚犬", - "flamigo": "纏紅鶴", - "cetoddle": "走鯨", - "cetitan": "浩大鯨", - "veluza": "輕身鱈", - "dondozo": "喫吼霸", - "tatsugiri": "米立龍", - "annihilape": "棄世猴", - "clodsire": "土王", - "farigiraf": "奇麒麟", - "dudunsparce": "土龍節節", - "kingambit": "僕刀將軍", - "great_tusk": "雄偉牙", - "scream_tail": "吼叫尾", - "brute_bonnet": "猛惡菇", - "flutter_mane": "振翼髮", - "slither_wing": "爬地翅", - "sandy_shocks": "沙鐵皮", - "iron_treads": "鐵轍跡", - "iron_bundle": "鐵包袱", - "iron_hands": "鐵臂膀", - "iron_jugulis": "鐵脖頸", - "iron_moth": "鐵毒蛾", - "iron_thorns": "鐵荊棘", - "frigibax": "涼脊龍", - "arctibax": "凍脊龍", - "baxcalibur": "戟脊龍", - "gimmighoul": "索財靈", - "gholdengo": "賽富豪", - "wo_chien": "古簡蝸", - "chien_pao": "古劍豹", - "ting_lu": "古鼎鹿", - "chi_yu": "古玉魚", - "roaring_moon": "轟鳴月", - "iron_valiant": "鐵武者", - "koraidon": "故勒頓", - "miraidon": "密勒頓", - "walking_wake": "波盪水", - "iron_leaves": "鐵斑葉", - "dipplin": "裹蜜蟲", - "poltchageist": "斯魔茶", - "sinistcha": "來悲粗茶", - "okidogi": "夠贊狗", - "munkidori": "願增猿", - "fezandipiti": "吉雉雞", - "ogerpon": "厄詭椪", - "archaludon": "鋁鋼橋龍", - "hydrapple": "蜜集大蛇", - "gouging_fire": "破空焰", - "raging_bolt": "猛雷鼓", - "iron_boulder": "鐵磐巖", - "iron_crown": "鐵頭殼", - "terapagos": "太樂巴戈斯", - "pecharunt": "桃歹郎", - "alola_rattata": "小拉達", - "alola_raticate": "拉達", - "alola_raichu": "雷丘", - "alola_sandshrew": "穿山鼠", - "alola_sandslash": "穿山王", - "alola_vulpix": "六尾", - "alola_ninetales": "九尾", - "alola_diglett": "地鼠", - "alola_dugtrio": "三地鼠", - "alola_meowth": "喵喵", - "alola_persian": "貓老大", - "alola_geodude": "小拳石", - "alola_graveler": "隆隆石", - "alola_golem": "隆隆岩", - "alola_grimer": "臭泥", - "alola_muk": "臭臭泥", - "alola_exeggutor": "椰蛋樹", - "alola_marowak": "嘎啦嘎啦", - "eternal_floette": "花葉蒂", - "galar_meowth": "喵喵", - "galar_ponyta": "小火馬", - "galar_rapidash": "烈焰馬", - "galar_slowpoke": "呆呆獸", - "galar_slowbro": "呆殼獸", - "galar_farfetchd": "大蔥鴨", - "galar_weezing": "雙彈瓦斯", - "galar_mr_mime": "魔牆人偶", - "galar_articuno": "急凍鳥", - "galar_zapdos": "閃電鳥", - "galar_moltres": "火焰鳥", - "galar_slowking": "呆呆王", - "galar_corsola": "太陽珊瑚", - "galar_zigzagoon": "蛇紋熊", - "galar_linoone": "直衝熊", - "galar_darumaka": "火紅不倒翁", - "galar_darmanitan": "達摩狒狒", - "galar_yamask": "哭哭面具", - "galar_stunfisk": "泥巴魚", - "hisui_growlithe": "卡蒂狗", - "hisui_arcanine": "風速狗", - "hisui_voltorb": "霹靂電球", - "hisui_electrode": "頑皮雷彈", - "hisui_typhlosion": "火暴獸", - "hisui_qwilfish": "千針魚", - "hisui_sneasel": "狃拉", - "hisui_samurott": "大劍鬼", - "hisui_lilligant": "裙兒小姐", - "hisui_zorua": "索羅亞", - "hisui_zoroark": "索羅亞克", - "hisui_braviary": "勇士雄鷹", - "hisui_sliggoo": "黏美兒", - "hisui_goodra": "黏美龍", - "hisui_avalugg": "冰岩怪", - "hisui_decidueye": "狙射樹梟", - "paldea_tauros": "肯泰羅", - "paldea_wooper": "烏波", - "bloodmoon_ursaluna": "月月熊" -} \ No newline at end of file diff --git a/src/locales/zh_TW/run-history.json b/src/locales/zh_TW/run-history.json deleted file mode 100644 index 76cb2592ce2..00000000000 --- a/src/locales/zh_TW/run-history.json +++ /dev/null @@ -1,37 +0,0 @@ -{ - "victory": "勝利!", - "defeatedWild": "被打敗", - "defeatedTrainer": "被打敗", - "defeatedTrainerDouble": "被組合打敗", - "defeatedRival": "被勁敵打敗", - "defeated": "被打敗", - "defeatedWild_female": "被打敗", - "defeatedTrainer_female": "被打敗", - "defeatedTrainerDouble_female": "被組合打敗", - "defeatedRival_female": "被勁敵打敗", - "defeated_female": "被打敗", - "luck": "幸運", - "score": "分數", - "mode": "模式", - "challengeRules": "規則", - "challengeMonoGen1": "一代", - "challengeMonoGen2": "二代", - "challengeMonoGen3": "三代", - "challengeMonoGen4": "四代", - "challengeMonoGen5": "五代", - "challengeMonoGen6": "六代", - "challengeMonoGen7": "七代", - "challengeMonoGen8": "八代", - "challengeMonoGen9": "九代", - "playerItems": "玩家道具", - "personalBest": "個人最佳!", - "SPDshortened": "速率", - "runInfo": "遊戲記錄", - "money": "金錢", - "runLength": "遊戲時長", - "viewHeldItems": "持有道具", - "hallofFameText": "歡迎來到名人堂!", - "hallofFameText_female": "歡迎來到名人堂!", - "viewHallOfFame": "浏覽名人堂!", - "viewEndingSplash": "浏覽結算畫面" -} \ No newline at end of file diff --git a/src/locales/zh_TW/save-slot-select-ui-handler.json b/src/locales/zh_TW/save-slot-select-ui-handler.json deleted file mode 100644 index 94fd6b0971f..00000000000 --- a/src/locales/zh_TW/save-slot-select-ui-handler.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "overwriteData": "要覆蓋該槽位的存檔嗎?", - "loading": "正在加載...", - "wave": "層數", - "lv": "Lv", - "empty": "空" -} \ No newline at end of file diff --git a/src/locales/zh_TW/settings.json b/src/locales/zh_TW/settings.json deleted file mode 100644 index d9c71df3a0d..00000000000 --- a/src/locales/zh_TW/settings.json +++ /dev/null @@ -1,101 +0,0 @@ -{ - "boy": "男孩", - "girl": "女孩", - "general": "常規", - "display": "顯示", - "audio": "音頻", - "gamepad": "手柄", - "keyboard": "鍵盤", - "gameSpeed": "遊戲速度", - "hpBarSpeed": "血條速度", - "expGainsSpeed": "經驗值獲取動畫速度", - "expPartyDisplay": "顯示隊伍經驗", - "skipSeenDialogues": "跳過已讀對話", - "battleStyle": "對戰模式", - "enableRetries": "允許重試", - "hideIvs": "禁用個體值探測器信息", - "tutorials": "教程", - "touchControls": "觸摸操作", - "vibrations": "手柄震動", - "normal": "普通", - "fast": "快", - "faster": "更快", - "skip": "跳過", - "levelUpNotifications": "升級提示", - "on": "啟用", - "off": "禁用", - "switch": "切換", - "set": "固定", - "auto": "自動", - "disabled": "禁用", - "language": "語言", - "change": "選擇", - "uiTheme": "界面風格", - "default": "默認", - "legacy": "經典", - "windowType": "窗口類型", - "moneyFormat": "金錢格式", - "damageNumbers": "傷害數字", - "simple": "簡單", - "fancy": "華麗", - "abbreviated": "縮寫", - "moveAnimations": "招式動畫", - "showStatsOnLevelUp": "升級時顯示能力值", - "candyUpgradeNotification": "糖果升級提示", - "passivesOnly": "僅被動", - "candyUpgradeDisplay": "糖果升級顯示", - "icon": "圖標", - "animation": "動畫", - "moveInfo": "招式信息", - "showMovesetFlyout": "顯示招式池彈窗", - "showArenaFlyout": "顯示戰場彈窗", - "showTimeOfDayWidget": "顯示時間指示器", - "timeOfDayAnimation": "時間指示器動畫", - "bounce": "彈一下", - "timeOfDay_back": "不彈", - "spriteSet": "寶可夢動畫", - "consistent": "默認", - "mixedAnimated": "全部動畫", - "fusionPaletteSwaps": "融合色調切換", - "playerGender": "玩家性別", - "typeHints": "屬性提示", - "masterVolume": "主音量", - "bgmVolume": "音樂", - "fieldVolume": "場景音量", - "seVolume": "音效", - "musicPreference": "音樂偏好", - "mixed": "全曲混合", - "gamepadPleasePlug": "請連接手柄或按任意鍵", - "delete": "刪除", - "keyboardPleasePress": "請點擊鍵盤上的對應按鍵", - "reset": "重置", - "requireReload": "需要重新加載", - "action": "操作", - "back": "返回", - "pressToBind": "按下以綁定", - "pressButton": "請按鍵……", - "buttonUp": "上", - "buttonDown": "下", - "buttonLeft": "左", - "buttonRight": "右", - "buttonAction": "確認", - "buttonMenu": "菜單", - "buttonSubmit": "提交", - "buttonCancel": "取消", - "buttonStats": "狀態", - "buttonCycleForm": "切換形態", - "buttonCycleShiny": "切換閃光", - "buttonCycleGender": "切換性別", - "buttonCycleAbility": "切換特性", - "buttonCycleNature": "切換性格", - "buttonCycleVariant": "切換變種", - "buttonSpeedUp": "加速", - "buttonSlowDown": "減速", - "alt": " (備用)", - "mute": "靜音", - "controller": "控制器", - "gamepadSupport": "手柄支持", - "showBgmBar": "顯示音樂名稱", - "moveTouchControls": "移動觸控控制", - "shopOverlayOpacity": "商店顯示不透明度" -} diff --git a/src/locales/zh_TW/splash-messages.json b/src/locales/zh_TW/splash-messages.json deleted file mode 100644 index a25e7dab97b..00000000000 --- a/src/locales/zh_TW/splash-messages.json +++ /dev/null @@ -1,36 +0,0 @@ -{ - "battlesWon": "勝利場數!", - "joinTheDiscord": "加入Discord!", - "infiniteLevels": "無限等級!", - "everythingStacks": "所有效果都能疊加!", - "optionalSaveScumming": "可選的存檔重刷!", - "biomes": "35種生態區!", - "openSource": "開源!", - "playWithSpeed": "以5倍速度遊玩!", - "liveBugTesting": "即時漏洞測試!", - "heavyInfluence": "深受RoR2影響!", - "pokemonRiskAndPokemonRain": "寶可夢風險與寶可夢雨!", - "nowWithMoreSalt": "現在多33%的鹽分!", - "infiniteFusionAtHome": "在家無限融合!", - "brokenEggMoves": "破損的蛋招式!", - "magnificent": "壯麗!", - "mubstitute": "替補!", - "thatsCrazy": "真是瘋狂!", - "oranceJuice": "橙汁!", - "questionableBalancing": "值得質疑的平衡性!", - "coolShaders": "酷炫的著色器!", - "aiFree": "無AI!", - "suddenDifficultySpikes": "突然的難度提升!", - "basedOnAnUnfinishedFlashGame": "基於未完成的Flash遊戲!", - "moreAddictiveThanIntended": "比預期更上癮!", - "mostlyConsistentSeeds": "大多數情況下一致的種子!", - "achievementPointsDontDoAnything": "成就點數沒有任何用處!", - "youDoNotStartAtLevel": "你不會從2000級開始!", - "dontTalkAboutTheManaphyEggIncident": "別提那個瑪納霏蛋事件!", - "alsoTryPokengine": "也試試Pokéngine!", - "alsoTryEmeraldRogue": "也試試翡翠流氓!", - "alsoTryRadicalRed": "也試試激進紅!", - "eeveeExpo": "伊布博覽會!", - "ynoproject": "YNO專案!", - "breedersInSpace": "飼養員也能上太空?" -} diff --git a/src/locales/zh_TW/starter-select-ui-handler.json b/src/locales/zh_TW/starter-select-ui-handler.json deleted file mode 100644 index ad64a8d9743..00000000000 --- a/src/locales/zh_TW/starter-select-ui-handler.json +++ /dev/null @@ -1,46 +0,0 @@ -{ - "confirmStartTeam": "使用這些寶可夢開始嗎?", - "confirmExit": "確定要退出嗎?", - "invalidParty": "此為無效隊伍!", - "gen1": "I", - "gen2": "II", - "gen3": "III", - "gen4": "IV", - "gen5": "V", - "gen6": "VI", - "gen7": "VII", - "gen8": "VIII", - "gen9": "IX", - "growthRate": "成長速度:", - "ability": "特性:", - "passive": "被動:", - "nature": "性格:", - "eggMoves": "孵化招式", - "start": "開始", - "addToParty": "加入隊伍", - "removeFromParty": "移出隊伍", - "toggleIVs": "查看個體值", - "manageMoves": "管理技能", - "manageNature": "管理性格", - "addToFavorites": "添加到最愛", - "removeFromFavorites": "移出最愛", - "useCandies": "使用糖果", - "selectNature": "選擇性格", - "selectMoveSwapOut": "選擇想要替換走的招式", - "selectMoveSwapWith": "選擇想要替換成的招式", - "sameSpeciesEgg": "買蛋", - "unlockPassive": "解鎖被動", - "reduceCost": "降低花費", - "cycleShiny": ": 閃光", - "cycleForm": ": 形態", - "cycleGender": ": 性別", - "cycleAbility": ": 特性", - "cycleNature": ": 性格", - "cycleVariant": ": 變種", - "goFilter": ": 轉到篩選", - "enablePassive": "啟用被動", - "disablePassive": "禁用被動", - "locked": "未解鎖", - "disabled": "已禁用", - "uncaught": "未捕獲" -} diff --git a/src/locales/zh_TW/status-effect.json b/src/locales/zh_TW/status-effect.json deleted file mode 100644 index 5f634a0bddf..00000000000 --- a/src/locales/zh_TW/status-effect.json +++ /dev/null @@ -1,65 +0,0 @@ -{ - "none": { - "name": "無", - "description": "", - "obtain": "", - "obtainSource": "", - "activation": "", - "overlap": "", - "heal": "" - }, - "poison": { - "name": "中毒", - "description": "中毒", - "obtain": "{{pokemonNameWithAffix}}中毒了!", - "obtainSource": "{{pokemonNameWithAffix}}因{{sourceText}}中毒了!", - "activation": "{{pokemonNameWithAffix}}受到了毒的傷害!", - "overlap": "{{pokemonNameWithAffix}}已經中毒了!", - "heal": "{{pokemonNameWithAffix}}中的毒徹底清除了!" - }, - "toxic": { - "name": "劇毒", - "description": "中毒", - "obtain": "{{pokemonNameWithAffix}}中了劇毒!", - "obtainSource": "{{pokemonNameWithAffix}}因{{sourceText}}中了劇毒!", - "activation": "{{pokemonNameWithAffix}}受到了毒的傷害!", - "overlap": "{{pokemonNameWithAffix}}已經中毒了!", - "heal": "{{pokemonNameWithAffix}}中的毒徹底清除了!" - }, - "paralysis": { - "name": "麻痹", - "description": "麻痹", - "obtain": "{{pokemonNameWithAffix}}麻痹了,很難使出招式!", - "obtainSource": "{{pokemonNameWithAffix}}被{{sourceText}}麻痹了,很難使出招式!", - "activation": "{{pokemonNameWithAffix}}因身體麻痹而無法行動!", - "overlap": "{{pokemonNameWithAffix}}已經麻痹了!", - "heal": "{{pokemonNameWithAffix}}的麻痹治愈了!" - }, - "sleep": { - "name": "睡眠", - "description": "睡眠", - "obtain": "{{pokemonNameWithAffix}}睡著了!", - "obtainSource": "{{pokemonNameWithAffix}}因{{sourceText}}睡著了!", - "activation": "{{pokemonNameWithAffix}}正在呼呼大睡。", - "overlap": "{{pokemonNameWithAffix}}已經睡著了!", - "heal": "{{pokemonNameWithAffix}}醒了!" - }, - "freeze": { - "name": "冰凍", - "description": "冰凍", - "obtain": "{{pokemonNameWithAffix}}凍住了!", - "obtainSource": "{{pokemonNameWithAffix}}因{{sourceText}}凍住了!", - "activation": "{{pokemonNameWithAffix}}因凍住了而無法行動!", - "overlap": "{{pokemonNameWithAffix}}已經凍住了!", - "heal": "{{pokemonNameWithAffix}}治愈了冰凍狀態!" - }, - "burn": { - "name": "灼傷", - "description": "灼傷", - "obtain": "{{pokemonNameWithAffix}}被灼傷了!", - "obtainSource": "{{pokemonNameWithAffix}}因{{sourceText}}被灼傷了!", - "activation": "{{pokemonNameWithAffix}}受到了灼傷的傷害!", - "overlap": "{{pokemonNameWithAffix}}已經被灼傷了!", - "heal": "{{pokemonNameWithAffix}}的灼傷治愈了!" - } -} diff --git a/src/locales/zh_TW/terrain.json b/src/locales/zh_TW/terrain.json deleted file mode 100644 index 37b74a1e352..00000000000 --- a/src/locales/zh_TW/terrain.json +++ /dev/null @@ -1,16 +0,0 @@ -{ - "misty": "薄霧", - "mistyStartMessage": "腳下霧氣繚繞!", - "mistyClearMessage": "腳下的霧氣消失不見了!", - "mistyBlockMessage": "{{pokemonNameWithAffix}}正受到薄霧場地的保護!", - "electric": "電氣", - "electricStartMessage": "腳下電流飛閃!", - "electricClearMessage": "腳下的電流消失了!", - "grassy": "青草", - "grassyStartMessage": "腳下青草如茵!", - "grassyClearMessage": "腳下的青草消失不見了!", - "psychic": "精神", - "psychicStartMessage": "腳下傳來了奇妙的感覺!", - "psychicClearMessage": "腳下的奇妙感覺消失了!", - "defaultBlockMessage": "{{pokemonNameWithAffix}}正受到{{terrainName}}的保護!" -} \ No newline at end of file diff --git a/src/locales/zh_TW/trainer-classes.json b/src/locales/zh_TW/trainer-classes.json deleted file mode 100644 index d0b0fed7e5d..00000000000 --- a/src/locales/zh_TW/trainer-classes.json +++ /dev/null @@ -1,121 +0,0 @@ -{ - "ace_trainer": "精英訓練家", - "ace_trainer_female": "精英訓練家", - "ace_duo": "精英組合", - "artist": "藝術家", - "artist_female": "藝術家", - "backers": "啦啦隊", - "backpacker": "背包客", - "backpacker_female": "背包客", - "backpackers": "背包客組合", - "baker": "麵包師", - "battle_girl": "對戰少女", - "beauty": "大姐姐", - "beginners": "新人訓練家組合", - "biker": "飆車族", - "black_belt": "空手道王", - "breeder": "寶可夢培育家", - "breeder_female": "寶可夢培育家", - "breeders": "寶可夢培育家組合", - "clerk": "商務人士", - "clerk_female": "職場OL", - "colleagues": "商務夥伴", - "crush_kin": "格鬥姐弟", - "cyclist": "自行車手", - "cyclist_female": "自行車手", - "cyclists": "自行車手組合", - "dancer": "舞者", - "dancer_female": "舞者", - "depot_agent": "鐵路員工", - "doctor": "醫生", - "doctor_female": "醫生", - "firebreather": "吹火人", - "fisherman": "垂釣者", - "fisherman_female": "垂釣者", - "gentleman": "紳士", - "guitarist": "吉他手", - "guitarist_female": "吉他手", - "harlequin": "滑稽演員", - "hiker": "登山男", - "hooligans": "壞組合", - "hoopster": "籃球選手", - "infielder": "棒球選手", - "janitor": "清潔員", - "lady": "千金小姐", - "lass": "迷你裙", - "linebacker": "美式橄欖球選手", - "maid": "女僕", - "madame": "女士", - "medical_team": "醫療團隊", - "musician": "音樂家", - "hex_maniac": "靈異迷", - "nurse": "護士", - "nursery_aide": "幼兒園老師", - "officer": "警察", - "parasol_lady": "陽傘姐姐", - "pilot": "飛行員", - "pokéfan": "發燒友俱樂部", - "pokéfan_female": "發燒友俱樂部", - "pokéfan_family": "同好夫婦", - "preschooler": "幼兒園小朋友", - "preschooler_female": "幼兒園小朋友", - "preschoolers": "幼兒園小朋友組合", - "psychic": "超能力者", - "psychic_female": "超能力者", - "psychics": "超能力者組合", - "pokémon_ranger": "寶可夢巡護員", - "pokémon_ranger_female": "寶可夢巡護員", - "pokémon_rangers": "寶可夢巡護員組合", - "ranger": "巡護員", - "restaurant_staff": "服務生組合", - "rich": "富有", - "rich_female": "富有", - "rich_boy": "富家少爺", - "rich_couple": "富豪夫婦", - "rich_kid": "富家孩子", - "rich_kid_female": "富家孩子", - "rich_kids": "富二代組合", - "roughneck": "光頭男", - "sailor": "水手", - "scientist": "研究員", - "scientist_female": "研究員", - "scientists": "研究員組合", - "smasher": "網球選手", - "snow_worker": "雪地工人", - "snow_worker_female": "雪地工人", - "striker": "足球選手", - "school_kid": "補習班學生", - "school_kid_female": "補習班學生", - "school_kids": "補習班學生組合", - "swimmer": "泳褲小伙子", - "swimmer_female": "比基尼大姐姐", - "swimmers": "泳裝情侶", - "twins": "雙胞胎", - "veteran": "資深訓練家", - "veteran_female": "資深訓練家", - "veteran_duo": "資深組合", - "waiter": "服務生", - "waitress": "女服務生", - "worker": "工人", - "worker_female": "工人", - "workers": "工人組合", - "youngster": "短褲小子", - "rocket_grunt": "火箭队手下", - "rocket_grunt_female": "火箭队手下", - "rocket_grunts": "火箭队手下們", - "magma_grunt": "熔岩队手下", - "magma_grunt_female": "熔岩队手下", - "magma_grunts": "熔岩队手下們", - "aqua_grunt": "海洋队手下", - "aqua_grunt_female": "海洋队手下", - "aqua_grunts": "海洋队手下們", - "galactic_grunt": "银河队手下", - "galactic_grunt_female": "银河队手下", - "galactic_grunts": "银河队手下們", - "plasma_grunt": "等离子队手下", - "plasma_grunt_female": "等离子队手下", - "plasma_grunts": "等离子队手下們", - "flare_grunt": "闪焰队手下", - "flare_grunt_female": "闪焰队手下", - "flare_grunts": "闪焰队手下們" -} diff --git a/src/locales/zh_TW/trainer-names.json b/src/locales/zh_TW/trainer-names.json deleted file mode 100644 index 04399cf19af..00000000000 --- a/src/locales/zh_TW/trainer-names.json +++ /dev/null @@ -1,164 +0,0 @@ -{ - "brock": "小剛", - "misty": "小霞", - "lt_surge": "馬志士", - "erika": "莉佳", - "janine": "阿杏", - "sabrina": "娜姿", - "blaine": "夏伯", - "giovanni": "坂木", - "falkner": "阿速", - "bugsy": "阿筆", - "whitney": "小茜", - "morty": "松葉", - "chuck": "阿四", - "jasmine": "阿蜜", - "pryce": "柳伯", - "clair": "小椿", - "roxanne": "杜鵑", - "brawly": "藤樹", - "wattson": "鐵旋", - "flannery": "亞莎", - "norman": "千里", - "winona": "娜琪", - "tate": "小楓", - "liza": "小南", - "juan": "亞當", - "roark": "瓢太", - "gardenia": "菜種", - "maylene": "阿李", - "crasher_wake": "吉憲", - "fantina": "梅麗莎", - "byron": "東瓜", - "candice": "小菘", - "volkner": "電次", - "cilan": "天桐", - "chili": "伯特", - "cress": "寇恩", - "cheren": "黑連", - "lenora": "蘆薈", - "roxie": "霍米加", - "burgh": "亞堤", - "elesa": "小菊兒", - "clay": "菊老大", - "skyla": "風露", - "brycen": "哈奇庫", - "drayden": "夏卡", - "marlon": "西子伊", - "viola": "紫羅蘭", - "grant": "查克洛", - "korrina": "可爾妮", - "ramos": "福爺", - "clemont": "希特隆", - "valerie": "瑪綉", - "olympia": "葛吉花", - "wulfric": "得撫", - "milo": "亞洛", - "nessa": "露璃娜", - "kabu": "卡芜", - "bea": "彩豆", - "allister": "歐尼奧", - "opal": "波普菈", - "bede": "彼特", - "gordie": "瑪瓜", - "melony": "美蓉", - "piers": "聶梓", - "marnie": "瑪俐", - "raihan": "奇巴納", - "katy": "阿楓", - "brassius": "寇沙", - "iono": "奇樹", - "kofu": "海岱", - "larry": "青木", - "ryme": "萊姆", - "tulip": "莉普", - "grusha": "古魯夏", - "lorelei": "科拿", - "bruno": "希巴", - "agatha": "菊子", - "lance": "阿渡", - "will": "一樹", - "koga": "阿桔", - "karen": "梨花", - "sidney": "花月", - "phoebe": "芙蓉", - "glacia": "波妮", - "drake": "源治", - "aaron": "阿柳", - "bertha": "菊野", - "flint": "大葉", - "lucian": "悟松", - "shauntal": "婉龍", - "marshal": "連武", - "grimsley": "越橘", - "caitlin": "嘉德麗雅", - "malva": "帕琦拉", - "siebold": "志米", - "wikstrom": "雁鎧", - "drasna": "朵拉塞娜", - "hala": "哈拉", - "molayne": "馬睿因", - "olivia": "麗姿", - "acerola": "阿塞蘿拉", - "kahili": "卡希麗", - "rika": "辛俐", - "poppy": "波琵", - "hassel": "八朔", - "crispin": "赤松", - "amarys": "納莉", - "lacey": "紫竽", - "drayton": "杜若", - "blue": "青綠", - "red": "赤紅", - "steven": "大吾", - "wallace": "米可利", - "cynthia": "竹蘭", - "alder": "阿戴克", - "iris": "艾莉絲", - "diantha": "卡露妮", - "hau": "哈烏", - "leon": "丹帝", - "geeta": "也慈", - "nemona": "妮莫", - "kieran": "烏栗", - "rival": "芬恩", - "rival_female": "艾薇", - "archer": "阿波羅", - "ariana": "雅典娜", - "proton": "蘭斯", - "petrel": "拉姆達", - "tabitha": "火村", - "courtney": "火雁", - "shelly": "阿泉", - "matt": "阿潮", - "mars": "夥星", - "jupiter": "碎星", - "saturn": "鎮星", - "zinzolin": "維奧", - "rood": "羅德", - "xerosic": "庫瑟洛斯奇", - "bryony": "芭拉", - "faba": "扎奧博", - "plumeria": "布爾美麗", - "oleana": "奧利薇", - - "maxie": "赤焰松", - "archie": "水梧桐", - "cyrus": "赤日", - "ghetsis": "魁奇思", - "lysandre": "弗拉達利", - "lusamine": "露莎米奈", - "guzma": "古茲馬", - "rose": "洛茲", - - "blue_red_double": "青綠 & 赤紅", - "red_blue_double": "赤紅 & 青綠", - "tate_liza_double": "小楓 & 小南", - "liza_tate_double": "小南 & 小楓", - "steven_wallace_double": "大吾 & 米可利", - "wallace_steven_double": "米可利 & 大吾", - "alder_iris_double": "阿戴克 & 艾莉絲", - "iris_alder_double": "艾莉絲 & 阿戴克", - "marnie_piers_double": "瑪俐 & 聶梓", - "piers_marnie_double": "聶梓 & 瑪俐" -} diff --git a/src/locales/zh_TW/trainer-titles.json b/src/locales/zh_TW/trainer-titles.json deleted file mode 100644 index 80b2807e7b5..00000000000 --- a/src/locales/zh_TW/trainer-titles.json +++ /dev/null @@ -1,32 +0,0 @@ -{ - "elite_four": "四天王", - "elite_four_female": "四天王", - "gym_leader": "道館館主", - "gym_leader_female": "道館館主", - "gym_leader_double": "道館館主", - "champion": "冠軍", - "champion_female": "冠軍", - "champion_double": "冠軍搭檔", - "rival": "勁敵", - "professor": "博士", - "frontier_brain": "開拓頭腦", - "rocket_boss": "火箭隊老大", - "magma_boss": "熔岩隊老大", - "aqua_boss": "海洋隊老大", - "galactic_boss": "銀河隊老大", - "plasma_boss": "等離子隊老大", - "flare_boss": "閃焰隊老大", - - "rocket_admin": "火箭隊幹部", - "rocket_admin_female": "火箭隊幹部", - "magma_admin": "熔岩隊幹部", - "magma_admin_female": "熔岩隊幹部", - "aqua_admin": "海洋隊幹部", - "aqua_admin_female": "海洋隊幹部", - "galactic_commander": "銀河隊幹部", - "galactic_commander_female": "銀河隊幹部", - "plasma_sage": "等離子隊賢人", - "plasma_admin": "等離子隊幹部", - "flare_admin": "閃焰隊幹部", - "flare_admin_female": "閃焰隊幹部" -} diff --git a/src/locales/zh_TW/tutorial.json b/src/locales/zh_TW/tutorial.json deleted file mode 100644 index 5e6e3d0ba9c..00000000000 --- a/src/locales/zh_TW/tutorial.json +++ /dev/null @@ -1,10 +0,0 @@ -{ - "intro": "歡迎來到PokéRogue!這是一款以戰鬥爲核心的融合了roguelite元素的寶可夢同人遊戲。 \n$本遊戲未進行商業化,我們沒有\nPokémon或Pokémon使用的版 \n$權資產的所有權。 \n$遊戲仍在開發中,但已可完整遊玩。如需報\n告錯誤,請使用 Discord 社區。 \n$如果遊戲運行緩慢,請確保在瀏覽器設置中\n打開了“硬件加速”。", - "accessMenu": "在等待輸入時,按 M 或 Escape 鍵可訪\n問菜單。菜單包含設置和各種功能。", - "menu": "在此菜單中,您可以訪問設置。 \n$在設置中,您可以更改遊戲速度、窗口樣式\n和其他選項。 \n$這裏還有各種其他功能,請務必全部查看!", - "starterSelect": "在此頁面中,您可以選擇您的初始寶可夢。\n這些是您最初的隊伍成員。 \n$每個初始寶可夢都有一個費用值。您的隊伍\n最多可以擁有6名成員,只要總費用不超過10。 \n$您還可以根據您捕獲或孵化的變種選擇性別\n、特性和形態。 \n$一個物種個體值是您捕獲或孵化的所有寶可\n夢中最好的,所以儘量獲得更多同種寶可夢!", - "pokerus": "每天隨機3個可選的初始寶可夢會有紫色邊\n框。 \n$如果您看到您擁有的初始寶可夢帶有紫色邊\n框,請嘗試將其添加到您的隊伍中。請務必 \n$查看其概況!", - "statChange": "只要您的寶可夢沒有被召回,屬性變化就會\n在戰鬥中持續存在。 \n$在訓練家戰鬥之前和進入新的寶可夢羣落之\n前,您的寶可夢會被召回。 \n$您還可以通過按住C或Shift鍵來查看\n場上寶可夢的能力變化。", - "selectItem": "每次戰鬥後,您都可以選擇 3 個隨機物品。\n您只能選擇其中一個。 \n$這些物品包括消耗品、寶可夢攜帶物品和永\n久被動道具。 \n$大多數非消耗品的效果會以各種方式疊加。 \n$某些物品只有在可以使用時纔會出現,例如\n進化物品。 \n$您還可以使用轉移選項在寶可夢之間轉移攜\n帶物品。 \n$一旦您獲得了攜帶物品,轉移選項就會出現\n在右下角。 \n$您可以用金錢購買消耗品,並且隨着您遊戲\n的深入,將會有更多種類的消耗品可供選擇。 \n$請務必在選擇隨機物品之前購買這些消耗品\n因爲一旦您選擇,遊戲就會進入下一場戰鬥。", - "eggGacha": "在此頁面中,您可以使用您的兌換券兌換寶\n可夢蛋。 \n$蛋需要孵化,並且在每場戰鬥後都會減少孵\n化週期。稀有蛋需要更長時間才能孵化。 \n$孵化的寶可夢不會被添加到您的隊伍中,它\n們將被添加到您的初始寶可夢中。 \n$從蛋中孵化的寶可夢通常比野生寶可夢具有\n更好的個體值。 \n$有些寶可夢只能從蛋中獲得。 \n$有 3 種不同的扭蛋機可供選擇,每種扭蛋機\n都有不同的獎勵,請選擇最適合您的!" -} \ No newline at end of file diff --git a/src/locales/zh_TW/voucher.json b/src/locales/zh_TW/voucher.json deleted file mode 100644 index fcff16ba6fc..00000000000 --- a/src/locales/zh_TW/voucher.json +++ /dev/null @@ -1,9 +0,0 @@ -{ - "vouchers": "兌換券", - "eggVoucher": "初級扭蛋券", - "eggVoucherPlus": "中級扭蛋券", - "eggVoucherPremium": "高級扭蛋券", - "eggVoucherGold": "黃金扭蛋券", - "locked": "鎖定", - "defeatTrainer": "你打敗了{{trainerName}}" -} \ No newline at end of file diff --git a/src/locales/zh_TW/weather.json b/src/locales/zh_TW/weather.json deleted file mode 100644 index b315d27625d..00000000000 --- a/src/locales/zh_TW/weather.json +++ /dev/null @@ -1,32 +0,0 @@ -{ - "sunnyStartMessage": "日照變強了!", - "sunnyLapseMessage": "日照很強。", - "sunnyClearMessage": "日照復原了。", - "rainStartMessage": "下大雨了!", - "rainLapseMessage": "雨繼續下。", - "rainClearMessage": "雨停了。", - "sandstormStartMessage": "開始刮沙暴了!", - "sandstormLapseMessage": "沙暴肆虐。", - "sandstormClearMessage": "沙暴停止了。", - "sandstormDamageMessage": "沙暴襲擊了{{pokemonNameWithAffix}}!", - "hailStartMessage": "開始下冰雹了!", - "hailLapseMessage": "冰雹繼續肆虐。", - "hailClearMessage": "冰雹不再下了。", - "hailDamageMessage": "冰雹襲擊了{{pokemonNameWithAffix}}!", - "snowStartMessage": "開始下雪了!", - "snowLapseMessage": "雪繼續下。", - "snowClearMessage": "雪停了。", - "fogStartMessage": "起霧了!", - "fogLapseMessage": "霧很濃。", - "fogClearMessage": "霧散了。", - "heavyRainStartMessage": "開始下起了暴雨!", - "heavyRainLapseMessage": "暴雨勢頭不減。", - "heavyRainClearMessage": "暴雨停了。", - "harshSunStartMessage": "日照變得非常強了!", - "harshSunLapseMessage": "強日照勢頭不減。", - "harshSunClearMessage": "日照復原了。", - "strongWindsStartMessage": "吹起了神秘的亂流!", - "strongWindsLapseMessage": "神秘的亂流勢頭不減。", - "strongWindsEffectMessage": "神秘的亂流減弱了攻擊!", - "strongWindsClearMessage": "神秘的亂流停止了。" -} diff --git a/src/main.ts b/src/main.ts index b5f813bdf2f..993bd1018ae 100644 --- a/src/main.ts +++ b/src/main.ts @@ -1,12 +1,11 @@ import Phaser from "phaser"; -import BattleScene from "./battle-scene"; import InvertPostFX from "./pipelines/invert"; import { version } from "../package.json"; import UIPlugin from "phaser3-rex-plugins/templates/ui/ui-plugin"; import BBCodeTextPlugin from "phaser3-rex-plugins/plugins/bbcodetext-plugin"; import InputTextPlugin from "phaser3-rex-plugins/plugins/inputtext-plugin"; import TransitionImagePackPlugin from "phaser3-rex-plugins/templates/transitionimagepack/transitionimagepack-plugin"; -import { LoadingScene } from "./loading-scene"; +import { initI18n } from "./plugins/i18n"; // Catch global errors and display them in an alert so users can report the issue. @@ -25,52 +24,6 @@ window.addEventListener("unhandledrejection", (event) => { //alert(errorString); }); -const config: Phaser.Types.Core.GameConfig = { - type: Phaser.WEBGL, - parent: "app", - scale: { - width: 1920, - height: 1080, - mode: Phaser.Scale.FIT - }, - plugins: { - global: [{ - key: "rexInputTextPlugin", - plugin: InputTextPlugin, - start: true - }, { - key: "rexBBCodeTextPlugin", - plugin: BBCodeTextPlugin, - start: true - }, { - key: "rexTransitionImagePackPlugin", - plugin: TransitionImagePackPlugin, - start: true - }], - scene: [{ - key: "rexUI", - plugin: UIPlugin, - mapping: "rexUI" - }] - }, - input: { - mouse: { - target: "app" - }, - touch: { - target: "app" - }, - gamepad: true - }, - dom: { - createContainer: true - }, - pixelArt: true, - pipeline: [ InvertPostFX ] as unknown as Phaser.Types.Core.PipelineConfig, - scene: [ LoadingScene, BattleScene ], - version: version -}; - /** * Sets this object's position relative to another object with a given offset */ @@ -91,16 +44,65 @@ document.fonts.load("16px emerald").then(() => document.fonts.load("10px pkmnems let game; -const startGame = () => { - game = new Phaser.Game(config); +const startGame = async (manifest?: any) => { + await initI18n(); + const LoadingScene = (await import("./loading-scene")).LoadingScene; + const BattleScene = (await import("./battle-scene")).default; + game = new Phaser.Game({ + type: Phaser.WEBGL, + parent: "app", + scale: { + width: 1920, + height: 1080, + mode: Phaser.Scale.FIT + }, + plugins: { + global: [{ + key: "rexInputTextPlugin", + plugin: InputTextPlugin, + start: true + }, { + key: "rexBBCodeTextPlugin", + plugin: BBCodeTextPlugin, + start: true + }, { + key: "rexTransitionImagePackPlugin", + plugin: TransitionImagePackPlugin, + start: true + }], + scene: [{ + key: "rexUI", + plugin: UIPlugin, + mapping: "rexUI" + }] + }, + input: { + mouse: { + target: "app" + }, + touch: { + target: "app" + }, + gamepad: true + }, + dom: { + createContainer: true + }, + pixelArt: true, + pipeline: [ InvertPostFX ] as unknown as Phaser.Types.Core.PipelineConfig, + scene: [ LoadingScene, BattleScene ], + version: version + }); game.sound.pauseOnBlur = false; + if (manifest) { + game["manifest"] = manifest; + } }; fetch("/manifest.json") .then(res => res.json()) .then(jsonResponse => { - startGame(); - game["manifest"] = jsonResponse.manifest; + startGame(jsonResponse.manifest); }).catch(() => { // Manifest not found (likely local build) startGame(); diff --git a/src/messages.ts b/src/messages.ts index 1cd6a5966b6..91f550918e5 100644 --- a/src/messages.ts +++ b/src/messages.ts @@ -13,21 +13,21 @@ export function getPokemonNameWithAffix(pokemon: Pokemon | undefined): string { } switch (pokemon.scene.currentBattle.battleSpec) { - case BattleSpec.DEFAULT: - return !pokemon.isPlayer() - ? pokemon.hasTrainer() - ? i18next.t("battle:foePokemonWithAffix", { - pokemonName: pokemon.getNameToRender(), - }) - : i18next.t("battle:wildPokemonWithAffix", { - pokemonName: pokemon.getNameToRender(), - }) - : pokemon.getNameToRender(); - case BattleSpec.FINAL_BOSS: - return !pokemon.isPlayer() - ? i18next.t("battle:foePokemonWithAffix", { pokemonName: pokemon.getNameToRender() }) - : pokemon.getNameToRender(); - default: - return pokemon.getNameToRender(); + case BattleSpec.DEFAULT: + return !pokemon.isPlayer() + ? pokemon.hasTrainer() + ? i18next.t("battle:foePokemonWithAffix", { + pokemonName: pokemon.getNameToRender(), + }) + : i18next.t("battle:wildPokemonWithAffix", { + pokemonName: pokemon.getNameToRender(), + }) + : pokemon.getNameToRender(); + case BattleSpec.FINAL_BOSS: + return !pokemon.isPlayer() + ? i18next.t("battle:foePokemonWithAffix", { pokemonName: pokemon.getNameToRender() }) + : pokemon.getNameToRender(); + default: + return pokemon.getNameToRender(); } } diff --git a/src/modifier/modifier-type.ts b/src/modifier/modifier-type.ts index a23a9c5ece2..4986c1feab1 100644 --- a/src/modifier/modifier-type.ts +++ b/src/modifier/modifier-type.ts @@ -1,38 +1,38 @@ -import * as Modifiers from "./modifier"; -import { MoneyMultiplierModifier } from "./modifier"; -import { allMoves, AttackMove, selfStatLowerMoves } from "../data/move"; -import { getPokeballCatchMultiplier, getPokeballName, MAX_PER_TYPE_POKEBALLS, PokeballType } from "../data/pokeball"; -import Pokemon, { EnemyPokemon, PlayerPokemon, PokemonMove } from "../field/pokemon"; -import { EvolutionItem, pokemonEvolutions } from "../data/pokemon-evolutions"; -import { tmPoolTiers, tmSpecies } from "../data/tms"; -import { Type } from "../data/type"; -import PartyUiHandler, { PokemonMoveSelectFilter, PokemonSelectFilter } from "../ui/party-ui-handler"; -import * as Utils from "../utils"; -import { getBerryEffectDescription, getBerryName } from "../data/berry"; -import { Unlockables } from "../system/unlockables"; -import { getStatusEffectDescriptor, StatusEffect } from "../data/status-effect"; -import { SpeciesFormKey } from "../data/pokemon-species"; -import BattleScene from "../battle-scene"; -import { getVoucherTypeIcon, getVoucherTypeName, VoucherType } from "../system/voucher"; -import { FormChangeItem, pokemonFormChanges, SpeciesFormChangeCondition, SpeciesFormChangeItemTrigger } from "../data/pokemon-forms"; -import { ModifierTier } from "./modifier-tier"; -import { getNatureName, getNatureStatMultiplier, Nature } from "#app/data/nature"; -import i18next from "i18next"; -import { getModifierTierTextTint } from "#app/ui/text"; +import BattleScene from "#app/battle-scene"; +import { EvolutionItem, pokemonEvolutions } from "#app/data/balance/pokemon-evolutions"; +import { tmPoolTiers, tmSpecies } from "#app/data/balance/tms"; +import { getBerryEffectDescription, getBerryName } from "#app/data/berry"; +import { allMoves, AttackMove, selfStatLowerMoves } from "#app/data/move"; +import { getNatureName, getNatureStatMultiplier } from "#app/data/nature"; +import { getPokeballCatchMultiplier, getPokeballName, MAX_PER_TYPE_POKEBALLS } from "#app/data/pokeball"; +import { FormChangeItem, pokemonFormChanges, SpeciesFormChangeCondition, SpeciesFormChangeItemTrigger } from "#app/data/pokemon-forms"; +import { getStatusEffectDescriptor } from "#app/data/status-effect"; +import { Type } from "#enums/type"; +import Pokemon, { EnemyPokemon, PlayerPokemon, PokemonMove } from "#app/field/pokemon"; +import { getPokemonNameWithAffix } from "#app/messages"; +import { AddPokeballModifier, AddVoucherModifier, AttackTypeBoosterModifier, BaseStatModifier, BerryModifier, BoostBugSpawnModifier, BypassSpeedChanceModifier, ContactHeldItemTransferChanceModifier, CritBoosterModifier, DamageMoneyRewardModifier, DoubleBattleChanceBoosterModifier, EnemyAttackStatusEffectChanceModifier, EnemyDamageBoosterModifier, EnemyDamageReducerModifier, EnemyEndureChanceModifier, EnemyFusionChanceModifier, EnemyStatusEffectHealChanceModifier, EnemyTurnHealModifier, EvolutionItemModifier, EvolutionStatBoosterModifier, EvoTrackerModifier, ExpBalanceModifier, ExpBoosterModifier, ExpShareModifier, ExtraModifierModifier, FlinchChanceModifier, FusePokemonModifier, GigantamaxAccessModifier, HealingBoosterModifier, HealShopCostModifier, HiddenAbilityRateBoosterModifier, HitHealModifier, IvScannerModifier, LevelIncrementBoosterModifier, LockModifierTiersModifier, MapModifier, MegaEvolutionAccessModifier, MoneyInterestModifier, MoneyMultiplierModifier, MoneyRewardModifier, MultipleParticipantExpBonusModifier, PokemonAllMovePpRestoreModifier, PokemonBaseStatFlatModifier, PokemonBaseStatTotalModifier, PokemonExpBoosterModifier, PokemonFormChangeItemModifier, PokemonFriendshipBoosterModifier, PokemonHeldItemModifier, PokemonHpRestoreModifier, PokemonIncrementingStatModifier, PokemonInstantReviveModifier, PokemonLevelIncrementModifier, PokemonMoveAccuracyBoosterModifier, PokemonMultiHitModifier, PokemonNatureChangeModifier, PokemonNatureWeightModifier, PokemonPpRestoreModifier, PokemonPpUpModifier, PokemonStatusHealModifier, PreserveBerryModifier, RememberMoveModifier, ResetNegativeStatStageModifier, ShinyRateBoosterModifier, SpeciesCritBoosterModifier, SpeciesStatBoosterModifier, SurviveDamageModifier, SwitchEffectTransferModifier, TempCritBoosterModifier, TempStatStageBoosterModifier, TerastallizeAccessModifier, TerastallizeModifier, TmModifier, TurnHealModifier, TurnHeldItemTransferModifier, TurnStatusEffectModifier, type EnemyPersistentModifier, type Modifier, type PersistentModifier, TempExtraModifierModifier, CriticalCatchChanceBoosterModifier } from "#app/modifier/modifier"; +import { ModifierTier } from "#app/modifier/modifier-tier"; import Overrides from "#app/overrides"; +import { Unlockables } from "#app/system/unlockables"; +import { getVoucherTypeIcon, getVoucherTypeName, VoucherType } from "#app/system/voucher"; +import PartyUiHandler, { PokemonMoveSelectFilter, PokemonSelectFilter } from "#app/ui/party-ui-handler"; +import { getModifierTierTextTint } from "#app/ui/text"; +import { formatMoney, getEnumKeys, getEnumValues, isNullOrUndefined, NumberHolder, padInt, randSeedInt, randSeedItem } from "#app/utils"; import { Abilities } from "#enums/abilities"; import { BattlerTagType } from "#enums/battler-tag-type"; import { BerryType } from "#enums/berry-type"; import { Moves } from "#enums/moves"; +import { Nature } from "#enums/nature"; +import { PokeballType } from "#enums/pokeball"; import { Species } from "#enums/species"; -import { getPokemonNameWithAffix } from "#app/messages"; -import { PermanentStat, TEMP_BATTLE_STATS, TempBattleStat, Stat, getStatKey } from "#app/enums/stat"; +import { SpeciesFormKey } from "#enums/species-form-key"; +import { getStatKey, PermanentStat, Stat, TEMP_BATTLE_STATS, TempBattleStat } from "#enums/stat"; +import { StatusEffect } from "#enums/status-effect"; +import i18next from "i18next"; const outputModifierData = false; const useMaxWeightForOutput = false; -type Modifier = Modifiers.Modifier; - export enum ModifierPoolType { PLAYER, WILD, @@ -81,23 +81,23 @@ export class ModifierType { } let poolTypes: ModifierPoolType[]; switch (poolType) { - case ModifierPoolType.PLAYER: - poolTypes = [ poolType, ModifierPoolType.TRAINER, ModifierPoolType.WILD ]; - break; - case ModifierPoolType.WILD: - poolTypes = [ poolType, ModifierPoolType.PLAYER, ModifierPoolType.TRAINER ]; - break; - case ModifierPoolType.TRAINER: - poolTypes = [ poolType, ModifierPoolType.PLAYER, ModifierPoolType.WILD ]; - break; - default: - poolTypes = [ poolType ]; - break; + case ModifierPoolType.PLAYER: + poolTypes = [ poolType, ModifierPoolType.TRAINER, ModifierPoolType.WILD ]; + break; + case ModifierPoolType.WILD: + poolTypes = [ poolType, ModifierPoolType.PLAYER, ModifierPoolType.TRAINER ]; + break; + case ModifierPoolType.TRAINER: + poolTypes = [ poolType, ModifierPoolType.PLAYER, ModifierPoolType.WILD ]; + break; + default: + poolTypes = [ poolType ]; + break; } // Try multiple pool types in case of stolen items for (const type of poolTypes) { const pool = getModifierPoolForType(type); - for (const tier of Utils.getEnumValues(ModifierTier)) { + for (const tier of getEnumValues(ModifierTier)) { if (!pool.hasOwnProperty(tier)) { continue; } @@ -122,18 +122,41 @@ export class ModifierType { * Populates item tier for ModifierType instance * Tier is a necessary field for items that appear in player shop (determines the Pokeball visual they use) * To find the tier, this function performs a reverse lookup of the item type in modifier pools + * It checks the weight of the item and will use the first tier for which the weight is greater than 0 + * This is to allow items to be in multiple item pools depending on the conditions, for example for events + * If all tiers have a weight of 0 for the item, the first tier where the item was found is used * @param poolType Default 'ModifierPoolType.PLAYER'. Which pool to lookup item tier from + * @param party optional. Needed to check the weight of modifiers with conditional weight (see {@linkcode WeightedModifierTypeWeightFunc}) + * if not provided or empty, the weight check will be ignored + * @param rerollCount Default `0`. Used to check the weight of modifiers with conditional weight (see {@linkcode WeightedModifierTypeWeightFunc}) */ - withTierFromPool(poolType: ModifierPoolType = ModifierPoolType.PLAYER): ModifierType { + withTierFromPool(poolType: ModifierPoolType = ModifierPoolType.PLAYER, party?: PlayerPokemon[], rerollCount: number = 0): ModifierType { + let defaultTier: undefined | ModifierTier; for (const tier of Object.values(getModifierPoolForType(poolType))) { for (const modifier of tier) { if (this.id === modifier.modifierType.id) { - this.tier = modifier.modifierType.tier; - return this; + let weight: number; + if (modifier.weight instanceof Function) { + weight = party ? modifier.weight(party, rerollCount) : 0; + } else { + weight = modifier.weight; + } + if (weight > 0) { + this.tier = modifier.modifierType.tier; + return this; + } else if (isNullOrUndefined(defaultTier)) { + // If weight is 0, keep track of the first tier where the item was found + defaultTier = modifier.modifierType.tier; + } } } } + // Didn't find a pool with weight > 0, fallback to first tier where the item was found, if any + if (defaultTier) { + this.tier = defaultTier; + } + return this; } @@ -171,7 +194,7 @@ class AddPokeballModifierType extends ModifierType { private count: integer; constructor(iconImage: string, pokeballType: PokeballType, count: integer) { - super("", iconImage, (_type, _args) => new Modifiers.AddPokeballModifier(this, pokeballType, count), "pb", "se/pb_bounce_1"); + super("", iconImage, (_type, _args) => new AddPokeballModifier(this, pokeballType, count), "pb", "se/pb_bounce_1"); this.pokeballType = pokeballType; this.count = count; } @@ -198,7 +221,7 @@ class AddVoucherModifierType extends ModifierType { private count: integer; constructor(voucherType: VoucherType, count: integer) { - super("", getVoucherTypeIcon(voucherType), (_type, _args) => new Modifiers.AddVoucherModifier(this, voucherType, count), "voucher"); + super("", getVoucherTypeIcon(voucherType), (_type, _args) => new AddVoucherModifier(this, voucherType, count), "voucher"); this.count = count; this.voucherType = voucherType; } @@ -232,7 +255,7 @@ export class PokemonHeldItemModifierType extends PokemonModifierType { constructor(localeKey: string, iconImage: string, newModifierFunc: NewModifierFunc, group?: string, soundName?: string) { super(localeKey, iconImage, newModifierFunc, (pokemon: PlayerPokemon) => { const dummyModifier = this.newModifier(pokemon); - const matchingModifier = pokemon.scene.findModifier(m => m instanceof Modifiers.PokemonHeldItemModifier && m.pokemonId === pokemon.id && m.matchType(dummyModifier)) as Modifiers.PokemonHeldItemModifier; + const matchingModifier = pokemon.scene.findModifier(m => m instanceof PokemonHeldItemModifier && m.pokemonId === pokemon.id && m.matchType(dummyModifier)) as PokemonHeldItemModifier; const maxStackCount = dummyModifier.getMaxStackCount(pokemon.scene); if (!maxStackCount) { return i18next.t("modifierType:ModifierType.PokemonHeldItemModifierType.extra.inoperable", { "pokemonName": getPokemonNameWithAffix(pokemon) }); @@ -244,8 +267,8 @@ export class PokemonHeldItemModifierType extends PokemonModifierType { }, group, soundName); } - newModifier(...args: any[]): Modifiers.PokemonHeldItemModifier { - return super.newModifier(...args) as Modifiers.PokemonHeldItemModifier; + newModifier(...args: any[]): PokemonHeldItemModifier { + return super.newModifier(...args) as PokemonHeldItemModifier; } } @@ -255,7 +278,7 @@ export class PokemonHpRestoreModifierType extends PokemonModifierType { protected healStatus: boolean; constructor(localeKey: string, iconImage: string, restorePoints: integer, restorePercent: integer, healStatus: boolean = false, newModifierFunc?: NewModifierFunc, selectFilter?: PokemonSelectFilter, group?: string) { - super(localeKey, iconImage, newModifierFunc || ((_type, args) => new Modifiers.PokemonHpRestoreModifier(this, (args[0] as PlayerPokemon).id, this.restorePoints, this.restorePercent, this.healStatus, false)), + super(localeKey, iconImage, newModifierFunc || ((_type, args) => new PokemonHpRestoreModifier(this, (args[0] as PlayerPokemon).id, this.restorePoints, this.restorePercent, this.healStatus, false)), selectFilter || ((pokemon: PlayerPokemon) => { if (!pokemon.hp || (pokemon.isFullHp() && (!this.healStatus || (!pokemon.status && !pokemon.getTag(BattlerTagType.CONFUSED))))) { return PartyUiHandler.NoEffectMessage; @@ -282,7 +305,7 @@ export class PokemonHpRestoreModifierType extends PokemonModifierType { export class PokemonReviveModifierType extends PokemonHpRestoreModifierType { constructor(localeKey: string, iconImage: string, restorePercent: integer) { - super(localeKey, iconImage, 0, restorePercent, false, (_type, args) => new Modifiers.PokemonHpRestoreModifier(this, (args[0] as PlayerPokemon).id, 0, this.restorePercent, false, true), + super(localeKey, iconImage, 0, restorePercent, false, (_type, args) => new PokemonHpRestoreModifier(this, (args[0] as PlayerPokemon).id, 0, this.restorePercent, false, true), ((pokemon: PlayerPokemon) => { if (!pokemon.isFainted()) { return PartyUiHandler.NoEffectMessage; @@ -305,7 +328,7 @@ export class PokemonReviveModifierType extends PokemonHpRestoreModifierType { export class PokemonStatusHealModifierType extends PokemonModifierType { constructor(localeKey: string, iconImage: string) { - super(localeKey, iconImage, ((_type, args) => new Modifiers.PokemonStatusHealModifier(this, (args[0] as PlayerPokemon).id)), + super(localeKey, iconImage, ((_type, args) => new PokemonStatusHealModifier(this, (args[0] as PlayerPokemon).id)), ((pokemon: PlayerPokemon) => { if (!pokemon.hp || (!pokemon.status && !pokemon.getTag(BattlerTagType.CONFUSED))) { return PartyUiHandler.NoEffectMessage; @@ -333,7 +356,7 @@ export class PokemonPpRestoreModifierType extends PokemonMoveModifierType { protected restorePoints: integer; constructor(localeKey: string, iconImage: string, restorePoints: integer) { - super(localeKey, iconImage, (_type, args) => new Modifiers.PokemonPpRestoreModifier(this, (args[0] as PlayerPokemon).id, (args[1] as integer), this.restorePoints), + super(localeKey, iconImage, (_type, args) => new PokemonPpRestoreModifier(this, (args[0] as PlayerPokemon).id, (args[1] as integer), this.restorePoints), (_pokemon: PlayerPokemon) => { return null; }, (pokemonMove: PokemonMove) => { @@ -358,7 +381,7 @@ export class PokemonAllMovePpRestoreModifierType extends PokemonModifierType { protected restorePoints: integer; constructor(localeKey: string, iconImage: string, restorePoints: integer) { - super(localeKey, iconImage, (_type, args) => new Modifiers.PokemonAllMovePpRestoreModifier(this, (args[0] as PlayerPokemon).id, this.restorePoints), + super(localeKey, iconImage, (_type, args) => new PokemonAllMovePpRestoreModifier(this, (args[0] as PlayerPokemon).id, this.restorePoints), (pokemon: PlayerPokemon) => { if (!pokemon.getMoveset().filter(m => m?.ppUsed).length) { return PartyUiHandler.NoEffectMessage; @@ -381,11 +404,11 @@ export class PokemonPpUpModifierType extends PokemonMoveModifierType { protected upPoints: integer; constructor(localeKey: string, iconImage: string, upPoints: integer) { - super(localeKey, iconImage, (_type, args) => new Modifiers.PokemonPpUpModifier(this, (args[0] as PlayerPokemon).id, (args[1] as integer), this.upPoints), + super(localeKey, iconImage, (_type, args) => new PokemonPpUpModifier(this, (args[0] as PlayerPokemon).id, (args[1] as integer), this.upPoints), (_pokemon: PlayerPokemon) => { return null; }, (pokemonMove: PokemonMove) => { - if (pokemonMove.getMove().pp < 5 || pokemonMove.ppUp >= 3) { + if (pokemonMove.getMove().pp < 5 || pokemonMove.ppUp >= 3 || pokemonMove.maxPpOverride) { return PartyUiHandler.NoEffectMessage; } return null; @@ -403,7 +426,7 @@ export class PokemonNatureChangeModifierType extends PokemonModifierType { protected nature: Nature; constructor(nature: Nature) { - super("", `mint_${Utils.getEnumKeys(Stat).find(s => getNatureStatMultiplier(nature, Stat[s]) > 1)?.toLowerCase() || "neutral" }`, ((_type, args) => new Modifiers.PokemonNatureChangeModifier(this, (args[0] as PlayerPokemon).id, this.nature)), + super("", `mint_${getEnumKeys(Stat).find(s => getNatureStatMultiplier(nature, Stat[s]) > 1)?.toLowerCase() || "neutral" }`, ((_type, args) => new PokemonNatureChangeModifier(this, (args[0] as PlayerPokemon).id, this.nature)), ((pokemon: PlayerPokemon) => { if (pokemon.getNature() === this.nature) { return PartyUiHandler.NoEffectMessage; @@ -425,7 +448,7 @@ export class PokemonNatureChangeModifierType extends PokemonModifierType { export class RememberMoveModifierType extends PokemonModifierType { constructor(localeKey: string, iconImage: string, group?: string) { - super(localeKey, iconImage, (type, args) => new Modifiers.RememberMoveModifier(type, (args[0] as PlayerPokemon).id, (args[1] as integer)), + super(localeKey, iconImage, (type, args) => new RememberMoveModifier(type, (args[0] as PlayerPokemon).id, (args[1] as integer)), (pokemon: PlayerPokemon) => { if (!pokemon.getLearnableLevelMoves().length) { return PartyUiHandler.NoEffectMessage; @@ -439,7 +462,7 @@ export class DoubleBattleChanceBoosterModifierType extends ModifierType { private maxBattles: number; constructor(localeKey: string, iconImage: string, maxBattles: number) { - super(localeKey, iconImage, (_type, _args) => new Modifiers.DoubleBattleChanceBoosterModifier(this, maxBattles), "lure"); + super(localeKey, iconImage, (_type, _args) => new DoubleBattleChanceBoosterModifier(this, maxBattles), "lure"); this.maxBattles = maxBattles; } @@ -458,7 +481,7 @@ export class TempStatStageBoosterModifierType extends ModifierType implements Ge constructor(stat: TempBattleStat) { const nameKey = TempStatStageBoosterModifierTypeGenerator.items[stat]; - super("", nameKey, (_type, _args) => new Modifiers.TempStatStageBoosterModifier(this, this.stat, 5)); + super("", nameKey, (_type, _args) => new TempStatStageBoosterModifier(this, this.stat, 5)); this.stat = stat; this.nameKey = nameKey; @@ -485,7 +508,7 @@ export class BerryModifierType extends PokemonHeldItemModifierType implements Ge private berryType: BerryType; constructor(berryType: BerryType) { - super("", `${BerryType[berryType].toLowerCase()}_berry`, (type, args) => new Modifiers.BerryModifier(type, (args[0] as Pokemon).id, berryType), "berry"); + super("", `${BerryType[berryType].toLowerCase()}_berry`, (type, args) => new BerryModifier(type, (args[0] as Pokemon).id, berryType), "berry"); this.berryType = berryType; } @@ -503,45 +526,25 @@ export class BerryModifierType extends PokemonHeldItemModifierType implements Ge } } -function getAttackTypeBoosterItemName(type: Type) { - switch (type) { - case Type.NORMAL: - return "Silk Scarf"; - case Type.FIGHTING: - return "Black Belt"; - case Type.FLYING: - return "Sharp Beak"; - case Type.POISON: - return "Poison Barb"; - case Type.GROUND: - return "Soft Sand"; - case Type.ROCK: - return "Hard Stone"; - case Type.BUG: - return "Silver Powder"; - case Type.GHOST: - return "Spell Tag"; - case Type.STEEL: - return "Metal Coat"; - case Type.FIRE: - return "Charcoal"; - case Type.WATER: - return "Mystic Water"; - case Type.GRASS: - return "Miracle Seed"; - case Type.ELECTRIC: - return "Magnet"; - case Type.PSYCHIC: - return "Twisted Spoon"; - case Type.ICE: - return "Never-Melt Ice"; - case Type.DRAGON: - return "Dragon Fang"; - case Type.DARK: - return "Black Glasses"; - case Type.FAIRY: - return "Fairy Feather"; - } +enum AttackTypeBoosterItem { + SILK_SCARF, + BLACK_BELT, + SHARP_BEAK, + POISON_BARB, + SOFT_SAND, + HARD_STONE, + SILVER_POWDER, + SPELL_TAG, + METAL_COAT, + CHARCOAL, + MYSTIC_WATER, + MIRACLE_SEED, + MAGNET, + TWISTED_SPOON, + NEVER_MELT_ICE, + DRAGON_FANG, + BLACK_GLASSES, + FAIRY_FEATHER } export class AttackTypeBoosterModifierType extends PokemonHeldItemModifierType implements GeneratedPersistentModifierType { @@ -549,15 +552,15 @@ export class AttackTypeBoosterModifierType extends PokemonHeldItemModifierType i public boostPercent: integer; constructor(moveType: Type, boostPercent: integer) { - super("", `${getAttackTypeBoosterItemName(moveType)?.replace(/[ \-]/g, "_").toLowerCase()}`, - (_type, args) => new Modifiers.AttackTypeBoosterModifier(this, (args[0] as Pokemon).id, moveType, boostPercent)); + super("", `${AttackTypeBoosterItem[moveType]?.toLowerCase()}`, + (_type, args) => new AttackTypeBoosterModifier(this, (args[0] as Pokemon).id, moveType, boostPercent)); this.moveType = moveType; this.boostPercent = boostPercent; } get name(): string { - return i18next.t(`modifierType:AttackTypeBoosterItem.${getAttackTypeBoosterItemName(this.moveType)?.replace(/[ \-]/g, "_").toLowerCase()}`); + return i18next.t(`modifierType:AttackTypeBoosterItem.${AttackTypeBoosterItem[this.moveType]?.toLowerCase()}`); } getDescription(scene: BattleScene): string { @@ -573,7 +576,7 @@ export class AttackTypeBoosterModifierType extends PokemonHeldItemModifierType i export type SpeciesStatBoosterItem = keyof typeof SpeciesStatBoosterModifierTypeGenerator.items; /** - * Modifier type for {@linkcode Modifiers.SpeciesStatBoosterModifier} + * Modifier type for {@linkcode SpeciesStatBoosterModifier} * @extends PokemonHeldItemModifierType * @implements GeneratedPersistentModifierType */ @@ -582,7 +585,7 @@ export class SpeciesStatBoosterModifierType extends PokemonHeldItemModifierType constructor(key: SpeciesStatBoosterItem) { const item = SpeciesStatBoosterModifierTypeGenerator.items[key]; - super(`modifierType:SpeciesBoosterItem.${key}`, key.toLowerCase(), (type, args) => new Modifiers.SpeciesStatBoosterModifier(type, (args[0] as Pokemon).id, item.stats, item.multiplier, item.species)); + super(`modifierType:SpeciesBoosterItem.${key}`, key.toLowerCase(), (type, args) => new SpeciesStatBoosterModifier(type, (args[0] as Pokemon).id, item.stats, item.multiplier, item.species)); this.key = key; } @@ -594,12 +597,12 @@ export class SpeciesStatBoosterModifierType extends PokemonHeldItemModifierType export class PokemonLevelIncrementModifierType extends PokemonModifierType { constructor(localeKey: string, iconImage: string) { - super(localeKey, iconImage, (_type, args) => new Modifiers.PokemonLevelIncrementModifier(this, (args[0] as PlayerPokemon).id), (_pokemon: PlayerPokemon) => null); + super(localeKey, iconImage, (_type, args) => new PokemonLevelIncrementModifier(this, (args[0] as PlayerPokemon).id), (_pokemon: PlayerPokemon) => null); } getDescription(scene: BattleScene): string { let levels = 1; - const hasCandyJar = scene.modifiers.find(modifier => modifier instanceof Modifiers.LevelIncrementBoosterModifier); + const hasCandyJar = scene.modifiers.find(modifier => modifier instanceof LevelIncrementBoosterModifier); if (hasCandyJar) { levels += hasCandyJar.stackCount; } @@ -609,12 +612,12 @@ export class PokemonLevelIncrementModifierType extends PokemonModifierType { export class AllPokemonLevelIncrementModifierType extends ModifierType { constructor(localeKey: string, iconImage: string) { - super(localeKey, iconImage, (_type, _args) => new Modifiers.PokemonLevelIncrementModifier(this, -1)); + super(localeKey, iconImage, (_type, _args) => new PokemonLevelIncrementModifier(this, -1)); } getDescription(scene: BattleScene): string { let levels = 1; - const hasCandyJar = scene.modifiers.find(modifier => modifier instanceof Modifiers.LevelIncrementBoosterModifier); + const hasCandyJar = scene.modifiers.find(modifier => modifier instanceof LevelIncrementBoosterModifier); if (hasCandyJar) { levels += hasCandyJar.stackCount; } @@ -628,7 +631,7 @@ export class BaseStatBoosterModifierType extends PokemonHeldItemModifierType imp constructor(stat: PermanentStat) { const key = BaseStatBoosterModifierTypeGenerator.items[stat]; - super("", key, (_type, args) => new Modifiers.BaseStatModifier(this, (args[0] as Pokemon).id, this.stat)); + super("", key, (_type, args) => new BaseStatModifier(this, (args[0] as Pokemon).id, this.stat)); this.stat = stat; this.key = key; @@ -654,7 +657,7 @@ export class PokemonBaseStatTotalModifierType extends PokemonHeldItemModifierTyp private readonly statModifier: integer; constructor(statModifier: integer) { - super("modifierType:ModifierType.MYSTERY_ENCOUNTER_SHUCKLE_JUICE", "berry_juice", (_type, args) => new Modifiers.PokemonBaseStatTotalModifier(this, (args[0] as Pokemon).id, this.statModifier)); + super("modifierType:ModifierType.MYSTERY_ENCOUNTER_SHUCKLE_JUICE", "berry_juice", (_type, args) => new PokemonBaseStatTotalModifier(this, (args[0] as Pokemon).id, this.statModifier)); this.statModifier = statModifier; } @@ -679,7 +682,7 @@ export class PokemonBaseStatFlatModifierType extends PokemonHeldItemModifierType private readonly stats: Stat[]; constructor(statModifier: integer, stats: Stat[]) { - super("modifierType:ModifierType.MYSTERY_ENCOUNTER_OLD_GATEAU", "old_gateau", (_type, args) => new Modifiers.PokemonBaseStatFlatModifier(this, (args[0] as Pokemon).id, this.statModifier, this.stats)); + super("modifierType:ModifierType.MYSTERY_ENCOUNTER_OLD_GATEAU", "old_gateau", (_type, args) => new PokemonBaseStatFlatModifier(this, (args[0] as Pokemon).id, this.statModifier, this.stats)); this.statModifier = statModifier; this.stats = stats; } @@ -700,7 +703,7 @@ class AllPokemonFullHpRestoreModifierType extends ModifierType { private descriptionKey: string; constructor(localeKey: string, iconImage: string, descriptionKey?: string, newModifierFunc?: NewModifierFunc) { - super(localeKey, iconImage, newModifierFunc || ((_type, _args) => new Modifiers.PokemonHpRestoreModifier(this, -1, 0, 100, false))); + super(localeKey, iconImage, newModifierFunc || ((_type, _args) => new PokemonHpRestoreModifier(this, -1, 0, 100, false))); this.descriptionKey = descriptionKey!; // TODO: is this bang correct? } @@ -712,7 +715,7 @@ class AllPokemonFullHpRestoreModifierType extends ModifierType { class AllPokemonFullReviveModifierType extends AllPokemonFullHpRestoreModifierType { constructor(localeKey: string, iconImage: string) { - super(localeKey, iconImage, "modifierType:ModifierType.AllPokemonFullReviveModifierType", (_type, _args) => new Modifiers.PokemonHpRestoreModifier(this, -1, 0, 100, false, true)); + super(localeKey, iconImage, "modifierType:ModifierType.AllPokemonFullReviveModifierType", (_type, _args) => new PokemonHpRestoreModifier(this, -1, 0, 100, false, true)); } } @@ -721,16 +724,16 @@ export class MoneyRewardModifierType extends ModifierType { private moneyMultiplierDescriptorKey: string; constructor(localeKey: string, iconImage: string, moneyMultiplier: number, moneyMultiplierDescriptorKey: string) { - super(localeKey, iconImage, (_type, _args) => new Modifiers.MoneyRewardModifier(this, moneyMultiplier), "money", "se/buy"); + super(localeKey, iconImage, (_type, _args) => new MoneyRewardModifier(this, moneyMultiplier), "money", "se/buy"); this.moneyMultiplier = moneyMultiplier; this.moneyMultiplierDescriptorKey = moneyMultiplierDescriptorKey; } getDescription(scene: BattleScene): string { - const moneyAmount = new Utils.IntegerHolder(scene.getWaveMoneyAmount(this.moneyMultiplier)); + const moneyAmount = new NumberHolder(scene.getWaveMoneyAmount(this.moneyMultiplier)); scene.applyModifiers(MoneyMultiplierModifier, true, moneyAmount); - const formattedMoney = Utils.formatMoney(scene.moneyFormat, moneyAmount.value); + const formattedMoney = formatMoney(scene.moneyFormat, moneyAmount.value); return i18next.t("modifierType:ModifierType.MoneyRewardModifierType.description", { moneyMultiplier: i18next.t(this.moneyMultiplierDescriptorKey as any), @@ -743,7 +746,7 @@ export class ExpBoosterModifierType extends ModifierType { private boostPercent: integer; constructor(localeKey: string, iconImage: string, boostPercent: integer) { - super(localeKey, iconImage, () => new Modifiers.ExpBoosterModifier(this, boostPercent)); + super(localeKey, iconImage, () => new ExpBoosterModifier(this, boostPercent)); this.boostPercent = boostPercent; } @@ -757,7 +760,7 @@ export class PokemonExpBoosterModifierType extends PokemonHeldItemModifierType { private boostPercent: integer; constructor(localeKey: string, iconImage: string, boostPercent: integer) { - super(localeKey, iconImage, (_type, args) => new Modifiers.PokemonExpBoosterModifier(this, (args[0] as Pokemon).id, boostPercent)); + super(localeKey, iconImage, (_type, args) => new PokemonExpBoosterModifier(this, (args[0] as Pokemon).id, boostPercent)); this.boostPercent = boostPercent; } @@ -769,7 +772,7 @@ export class PokemonExpBoosterModifierType extends PokemonHeldItemModifierType { export class PokemonFriendshipBoosterModifierType extends PokemonHeldItemModifierType { constructor(localeKey: string, iconImage: string) { - super(localeKey, iconImage, (_type, args) => new Modifiers.PokemonFriendshipBoosterModifier(this, (args[0] as Pokemon).id)); + super(localeKey, iconImage, (_type, args) => new PokemonFriendshipBoosterModifier(this, (args[0] as Pokemon).id)); } getDescription(scene: BattleScene): string { @@ -781,7 +784,7 @@ export class PokemonMoveAccuracyBoosterModifierType extends PokemonHeldItemModif private amount: integer; constructor(localeKey: string, iconImage: string, amount: integer, group?: string, soundName?: string) { - super(localeKey, iconImage, (_type, args) => new Modifiers.PokemonMoveAccuracyBoosterModifier(this, (args[0] as Pokemon).id, amount), group, soundName); + super(localeKey, iconImage, (_type, args) => new PokemonMoveAccuracyBoosterModifier(this, (args[0] as Pokemon).id, amount), group, soundName); this.amount = amount; } @@ -793,7 +796,7 @@ export class PokemonMoveAccuracyBoosterModifierType extends PokemonHeldItemModif export class PokemonMultiHitModifierType extends PokemonHeldItemModifierType { constructor(localeKey: string, iconImage: string) { - super(localeKey, iconImage, (type, args) => new Modifiers.PokemonMultiHitModifier(type as PokemonMultiHitModifierType, (args[0] as Pokemon).id)); + super(localeKey, iconImage, (type, args) => new PokemonMultiHitModifier(type as PokemonMultiHitModifierType, (args[0] as Pokemon).id)); } getDescription(scene: BattleScene): string { @@ -805,7 +808,7 @@ export class TmModifierType extends PokemonModifierType { public moveId: Moves; constructor(moveId: Moves) { - super("", `tm_${Type[allMoves[moveId].type].toLowerCase()}`, (_type, args) => new Modifiers.TmModifier(this, (args[0] as PlayerPokemon).id), + super("", `tm_${Type[allMoves[moveId].type].toLowerCase()}`, (_type, args) => new TmModifier(this, (args[0] as PlayerPokemon).id), (pokemon: PlayerPokemon) => { if (pokemon.compatibleTms.indexOf(moveId) === -1 || pokemon.getMoveset().filter(m => m?.moveId === moveId).length) { return PartyUiHandler.NoEffectMessage; @@ -818,7 +821,7 @@ export class TmModifierType extends PokemonModifierType { get name(): string { return i18next.t("modifierType:ModifierType.TmModifierType.name", { - moveId: Utils.padInt(Object.keys(tmSpecies).indexOf(this.moveId.toString()) + 1, 3), + moveId: padInt(Object.keys(tmSpecies).indexOf(this.moveId.toString()) + 1, 3), moveName: allMoves[this.moveId].name, }); } @@ -832,7 +835,7 @@ export class EvolutionItemModifierType extends PokemonModifierType implements Ge public evolutionItem: EvolutionItem; constructor(evolutionItem: EvolutionItem) { - super("", EvolutionItem[evolutionItem].toLowerCase(), (_type, args) => new Modifiers.EvolutionItemModifier(this, (args[0] as PlayerPokemon).id), + super("", EvolutionItem[evolutionItem].toLowerCase(), (_type, args) => new EvolutionItemModifier(this, (args[0] as PlayerPokemon).id), (pokemon: PlayerPokemon) => { if (pokemonEvolutions.hasOwnProperty(pokemon.species.speciesId) && pokemonEvolutions[pokemon.species.speciesId].filter(e => e.item === this.evolutionItem && (!e.condition || e.condition.predicate(pokemon)) && (e.preFormKey === null || e.preFormKey === pokemon.getFormKey())).length && (pokemon.getFormKey() !== SpeciesFormKey.GIGANTAMAX)) { @@ -868,7 +871,7 @@ export class FormChangeItemModifierType extends PokemonModifierType implements G public formChangeItem: FormChangeItem; constructor(formChangeItem: FormChangeItem) { - super("", FormChangeItem[formChangeItem].toLowerCase(), (_type, args) => new Modifiers.PokemonFormChangeItemModifier(this, (args[0] as PlayerPokemon).id, formChangeItem, true), + super("", FormChangeItem[formChangeItem].toLowerCase(), (_type, args) => new PokemonFormChangeItemModifier(this, (args[0] as PlayerPokemon).id, formChangeItem, true), (pokemon: PlayerPokemon) => { // Make sure the Pokemon has alternate forms if (pokemonFormChanges.hasOwnProperty(pokemon.species.speciesId) @@ -902,7 +905,7 @@ export class FormChangeItemModifierType extends PokemonModifierType implements G export class FusePokemonModifierType extends PokemonModifierType { constructor(localeKey: string, iconImage: string) { - super(localeKey, iconImage, (_type, args) => new Modifiers.FusePokemonModifier(this, (args[0] as PlayerPokemon).id, (args[1] as PlayerPokemon).id), + super(localeKey, iconImage, (_type, args) => new FusePokemonModifier(this, (args[0] as PlayerPokemon).id, (args[1] as PlayerPokemon).id), (pokemon: PlayerPokemon) => { if (pokemon.isFusion()) { return PartyUiHandler.NoEffectMessage; @@ -949,7 +952,7 @@ class AttackTypeBoosterModifierTypeGenerator extends ModifierTypeGenerator { let type: Type; - const randInt = Utils.randSeedInt(totalWeight); + const randInt = randSeedInt(totalWeight); let weight = 0; for (const t of attackMoveTypeWeights.keys()) { @@ -981,7 +984,7 @@ class BaseStatBoosterModifierTypeGenerator extends ModifierTypeGenerator { if (pregenArgs) { return new BaseStatBoosterModifierType(pregenArgs[0]); } - const randStat: PermanentStat = Utils.randSeedInt(Stat.SPD + 1); + const randStat: PermanentStat = randSeedInt(Stat.SPD + 1); return new BaseStatBoosterModifierType(randStat); }); } @@ -1002,7 +1005,7 @@ class TempStatStageBoosterModifierTypeGenerator extends ModifierTypeGenerator { if (pregenArgs && (pregenArgs.length === 1) && TEMP_BATTLE_STATS.includes(pregenArgs[0])) { return new TempStatStageBoosterModifierType(pregenArgs[0]); } - const randStat: TempBattleStat = Utils.randSeedInt(Stat.ACC, Stat.ATK); + const randStat: TempBattleStat = randSeedInt(Stat.ACC, Stat.ATK); return new TempStatStageBoosterModifierType(randStat); }); } @@ -1017,10 +1020,10 @@ class TempStatStageBoosterModifierTypeGenerator extends ModifierTypeGenerator { class SpeciesStatBoosterModifierTypeGenerator extends ModifierTypeGenerator { /** Object comprised of the currently available species-based stat boosting held items */ public static readonly items = { - LIGHT_BALL: { stats: [Stat.ATK, Stat.SPATK], multiplier: 2, species: [Species.PIKACHU] }, - THICK_CLUB: { stats: [Stat.ATK], multiplier: 2, species: [Species.CUBONE, Species.MAROWAK, Species.ALOLA_MAROWAK] }, - METAL_POWDER: { stats: [Stat.DEF], multiplier: 2, species: [Species.DITTO] }, - QUICK_POWDER: { stats: [Stat.SPD], multiplier: 2, species: [Species.DITTO] }, + LIGHT_BALL: { stats: [ Stat.ATK, Stat.SPATK ], multiplier: 2, species: [ Species.PIKACHU ]}, + THICK_CLUB: { stats: [ Stat.ATK ], multiplier: 2, species: [ Species.CUBONE, Species.MAROWAK, Species.ALOLA_MAROWAK ]}, + METAL_POWDER: { stats: [ Stat.DEF ], multiplier: 2, species: [ Species.DITTO ]}, + QUICK_POWDER: { stats: [ Stat.SPD ], multiplier: 2, species: [ Species.DITTO ]}, }; constructor() { @@ -1044,8 +1047,8 @@ class SpeciesStatBoosterModifierTypeGenerator extends ModifierTypeGenerator { const checkedStats = values[i].stats; // If party member already has the item being weighted currently, skip to the next item - const hasItem = p.getHeldItems().some(m => m instanceof Modifiers.SpeciesStatBoosterModifier - && (m as Modifiers.SpeciesStatBoosterModifier).contains(checkedSpecies[0], checkedStats[0])); + const hasItem = p.getHeldItems().some(m => m instanceof SpeciesStatBoosterModifier + && (m as SpeciesStatBoosterModifier).contains(checkedSpecies[0], checkedStats[0])); if (!hasItem) { if (checkedSpecies.includes(speciesId) || (!!fusionSpeciesId && checkedSpecies.includes(fusionSpeciesId))) { @@ -1065,7 +1068,7 @@ class SpeciesStatBoosterModifierTypeGenerator extends ModifierTypeGenerator { } if (totalWeight !== 0) { - const randInt = Utils.randSeedInt(totalWeight, 1); + const randInt = randSeedInt(totalWeight, 1); let weight = 0; for (const i in weights) { @@ -1095,7 +1098,7 @@ class TmModifierTypeGenerator extends ModifierTypeGenerator { if (!tierUniqueCompatibleTms.length) { return null; } - const randTmIndex = Utils.randSeedInt(tierUniqueCompatibleTms.length); + const randTmIndex = randSeedInt(tierUniqueCompatibleTms.length); return new TmModifierType(tierUniqueCompatibleTms[randTmIndex]); }); } @@ -1123,26 +1126,26 @@ class EvolutionItemModifierTypeGenerator extends ModifierTypeGenerator { return null; } - return new EvolutionItemModifierType(evolutionItemPool[Utils.randSeedInt(evolutionItemPool.length)]!); // TODO: is the bang correct? + return new EvolutionItemModifierType(evolutionItemPool[randSeedInt(evolutionItemPool.length)]!); // TODO: is the bang correct? }); } } class FormChangeItemModifierTypeGenerator extends ModifierTypeGenerator { - constructor(rare: boolean) { + constructor(isRareFormChangeItem: boolean) { super((party: Pokemon[], pregenArgs?: any[]) => { if (pregenArgs && (pregenArgs.length === 1) && (pregenArgs[0] in FormChangeItem)) { return new FormChangeItemModifierType(pregenArgs[0] as FormChangeItem); } - const formChangeItemPool = [...new Set(party.filter(p => pokemonFormChanges.hasOwnProperty(p.species.speciesId)).map(p => { + const formChangeItemPool = [ ...new Set(party.filter(p => pokemonFormChanges.hasOwnProperty(p.species.speciesId)).map(p => { const formChanges = pokemonFormChanges[p.species.speciesId]; - let formChangeItemTriggers = formChanges.filter(fc => ((fc.formKey.indexOf(SpeciesFormKey.MEGA) === -1 && fc.formKey.indexOf(SpeciesFormKey.PRIMAL) === -1) || party[0].scene.getModifiers(Modifiers.MegaEvolutionAccessModifier).length) - && ((fc.formKey.indexOf(SpeciesFormKey.GIGANTAMAX) === -1 && fc.formKey.indexOf(SpeciesFormKey.ETERNAMAX) === -1) || party[0].scene.getModifiers(Modifiers.GigantamaxAccessModifier).length) + let formChangeItemTriggers = formChanges.filter(fc => ((fc.formKey.indexOf(SpeciesFormKey.MEGA) === -1 && fc.formKey.indexOf(SpeciesFormKey.PRIMAL) === -1) || party[0].scene.getModifiers(MegaEvolutionAccessModifier).length) + && ((fc.formKey.indexOf(SpeciesFormKey.GIGANTAMAX) === -1 && fc.formKey.indexOf(SpeciesFormKey.ETERNAMAX) === -1) || party[0].scene.getModifiers(GigantamaxAccessModifier).length) && (!fc.conditions.length || fc.conditions.filter(cond => cond instanceof SpeciesFormChangeCondition && cond.predicate(p)).length) && (fc.preFormKey === p.getFormKey())) .map(fc => fc.findTrigger(SpeciesFormChangeItemTrigger) as SpeciesFormChangeItemTrigger) - .filter(t => t && t.active && !p.scene.findModifier(m => m instanceof Modifiers.PokemonFormChangeItemModifier && m.pokemonId === p.id && m.formChangeItem === t.item)); + .filter(t => t && t.active && !p.scene.findModifier(m => m instanceof PokemonFormChangeItemModifier && m.pokemonId === p.id && m.formChangeItem === t.item)); if (p.species.speciesId === Species.NECROZMA) { // technically we could use a simplified version and check for formChanges.length > 3, but in case any code changes later, this might break... @@ -1152,15 +1155,15 @@ class FormChangeItemModifierTypeGenerator extends ModifierTypeGenerator { foundN_SOLAR = false; formChangeItemTriggers.forEach((fc, i) => { switch (fc.item) { - case FormChangeItem.ULTRANECROZIUM_Z: - foundULTRA_Z = true; - break; - case FormChangeItem.N_LUNARIZER: - foundN_LUNA = true; - break; - case FormChangeItem.N_SOLARIZER: - foundN_SOLAR = true; - break; + case FormChangeItem.ULTRANECROZIUM_Z: + foundULTRA_Z = true; + break; + case FormChangeItem.N_LUNARIZER: + foundN_LUNA = true; + break; + case FormChangeItem.N_SOLARIZER: + foundN_SOLAR = true; + break; } }); if (foundULTRA_Z && foundN_LUNA && foundN_SOLAR) { @@ -1170,14 +1173,14 @@ class FormChangeItemModifierTypeGenerator extends ModifierTypeGenerator { } return formChangeItemTriggers; }).flat()) - ].flat().flatMap(fc => fc.item).filter(i => (i && i < 100) === rare); + ].flat().flatMap(fc => fc.item).filter(i => (i && i < 100) === isRareFormChangeItem); // convert it into a set to remove duplicate values, which can appear when the same species with a potential form change is in the party. if (!formChangeItemPool.length) { return null; } - return new FormChangeItemModifierType(formChangeItemPool[Utils.randSeedInt(formChangeItemPool.length)]); + return new FormChangeItemModifierType(formChangeItemPool[randSeedInt(formChangeItemPool.length)]); }); } } @@ -1186,7 +1189,7 @@ export class TerastallizeModifierType extends PokemonHeldItemModifierType implem private teraType: Type; constructor(teraType: Type) { - super("", `${Type[teraType].toLowerCase()}_tera_shard`, (type, args) => new Modifiers.TerastallizeModifier(type as TerastallizeModifierType, (args[0] as Pokemon).id, teraType), "tera_shard"); + super("", `${Type[teraType].toLowerCase()}_tera_shard`, (type, args) => new TerastallizeModifier(type as TerastallizeModifierType, (args[0] as Pokemon).id, teraType), "tera_shard"); this.teraType = teraType; } @@ -1208,7 +1211,7 @@ export class ContactHeldItemTransferChanceModifierType extends PokemonHeldItemMo private chancePercent: integer; constructor(localeKey: string, iconImage: string, chancePercent: integer, group?: string, soundName?: string) { - super(localeKey, iconImage, (type, args) => new Modifiers.ContactHeldItemTransferChanceModifier(type, (args[0] as Pokemon).id, chancePercent), group, soundName); + super(localeKey, iconImage, (type, args) => new ContactHeldItemTransferChanceModifier(type, (args[0] as Pokemon).id, chancePercent), group, soundName); this.chancePercent = chancePercent; } @@ -1220,7 +1223,7 @@ export class ContactHeldItemTransferChanceModifierType extends PokemonHeldItemMo export class TurnHeldItemTransferModifierType extends PokemonHeldItemModifierType { constructor(localeKey: string, iconImage: string, group?: string, soundName?: string) { - super(localeKey, iconImage, (type, args) => new Modifiers.TurnHeldItemTransferModifier(type, (args[0] as Pokemon).id), group, soundName); + super(localeKey, iconImage, (type, args) => new TurnHeldItemTransferModifier(type, (args[0] as Pokemon).id), group, soundName); } getDescription(scene: BattleScene): string { @@ -1233,7 +1236,7 @@ export class EnemyAttackStatusEffectChanceModifierType extends ModifierType { private effect: StatusEffect; constructor(localeKey: string, iconImage: string, chancePercent: integer, effect: StatusEffect, stackCount?: integer) { - super(localeKey, iconImage, (type, args) => new Modifiers.EnemyAttackStatusEffectChanceModifier(type, effect, chancePercent, stackCount), "enemy_status_chance"); + super(localeKey, iconImage, (type, args) => new EnemyAttackStatusEffectChanceModifier(type, effect, chancePercent, stackCount), "enemy_status_chance"); this.chancePercent = chancePercent; this.effect = effect; @@ -1251,7 +1254,7 @@ export class EnemyEndureChanceModifierType extends ModifierType { private chancePercent: number; constructor(localeKey: string, iconImage: string, chancePercent: number) { - super(localeKey, iconImage, (type, _args) => new Modifiers.EnemyEndureChanceModifier(type, chancePercent), "enemy_endure"); + super(localeKey, iconImage, (type, _args) => new EnemyEndureChanceModifier(type, chancePercent), "enemy_endure"); this.chancePercent = chancePercent; } @@ -1288,12 +1291,26 @@ function skipInClassicAfterWave(wave: integer, defaultWeight: integer): Weighted function skipInLastClassicWaveOrDefault(defaultWeight: integer) : WeightedModifierTypeWeightFunc { return skipInClassicAfterWave(199, defaultWeight); } + +/** + * High order function that returns a WeightedModifierTypeWeightFunc to ensure Lures don't spawn on Classic 199 + * or if the lure still has over 60% of its duration left + * @param maxBattles The max battles the lure type in question lasts. 10 for green, 15 for Super, 30 for Max + * @param weight The desired weight for the lure when it does spawn + * @returns A WeightedModifierTypeWeightFunc + */ +function lureWeightFunc(maxBattles: number, weight: number): WeightedModifierTypeWeightFunc { + return (party: Pokemon[]) => { + const lures = party[0].scene.getModifiers(DoubleBattleChanceBoosterModifier); + return !(party[0].scene.gameMode.isClassic && party[0].scene.currentBattle.waveIndex === 199) && (lures.length === 0 || lures.filter(m => m.getMaxBattles() === maxBattles && m.getBattleCount() >= maxBattles * 0.6).length === 0) ? weight : 0; + }; +} class WeightedModifierType { public modifierType: ModifierType; public weight: integer | WeightedModifierTypeWeightFunc; - public maxWeight: integer; + public maxWeight: integer | WeightedModifierTypeWeightFunc; - constructor(modifierTypeFunc: ModifierTypeFunc, weight: integer | WeightedModifierTypeWeightFunc, maxWeight?: integer) { + constructor(modifierTypeFunc: ModifierTypeFunc, weight: integer | WeightedModifierTypeWeightFunc, maxWeight?: integer | WeightedModifierTypeWeightFunc) { this.modifierType = modifierTypeFunc(); this.modifierType.id = Object.keys(modifierTypes).find(k => modifierTypes[k] === modifierTypeFunc)!; // TODO: is this bang correct? this.weight = weight; @@ -1372,13 +1389,14 @@ export const modifierTypes = { FORM_CHANGE_ITEM: () => new FormChangeItemModifierTypeGenerator(false), RARE_FORM_CHANGE_ITEM: () => new FormChangeItemModifierTypeGenerator(true), - EVOLUTION_TRACKER_GIMMIGHOUL: () => new PokemonHeldItemModifierType("modifierType:ModifierType.EVOLUTION_TRACKER_GIMMIGHOUL", "relic_gold", (type, _args) => new Modifiers.EvoTrackerModifier(type, (_args[0] as Pokemon).id, Species.GIMMIGHOUL, 10)), + EVOLUTION_TRACKER_GIMMIGHOUL: () => new PokemonHeldItemModifierType("modifierType:ModifierType.EVOLUTION_TRACKER_GIMMIGHOUL", "relic_gold", + (type, args) => new EvoTrackerModifier(type, (args[0] as Pokemon).id, Species.GIMMIGHOUL, 10)), - MEGA_BRACELET: () => new ModifierType("modifierType:ModifierType.MEGA_BRACELET", "mega_bracelet", (type, _args) => new Modifiers.MegaEvolutionAccessModifier(type)), - DYNAMAX_BAND: () => new ModifierType("modifierType:ModifierType.DYNAMAX_BAND", "dynamax_band", (type, _args) => new Modifiers.GigantamaxAccessModifier(type)), - TERA_ORB: () => new ModifierType("modifierType:ModifierType.TERA_ORB", "tera_orb", (type, _args) => new Modifiers.TerastallizeAccessModifier(type)), + MEGA_BRACELET: () => new ModifierType("modifierType:ModifierType.MEGA_BRACELET", "mega_bracelet", (type, _args) => new MegaEvolutionAccessModifier(type)), + DYNAMAX_BAND: () => new ModifierType("modifierType:ModifierType.DYNAMAX_BAND", "dynamax_band", (type, _args) => new GigantamaxAccessModifier(type)), + TERA_ORB: () => new ModifierType("modifierType:ModifierType.TERA_ORB", "tera_orb", (type, _args) => new TerastallizeAccessModifier(type)), - MAP: () => new ModifierType("modifierType:ModifierType.MAP", "map", (type, _args) => new Modifiers.MapModifier(type)), + MAP: () => new ModifierType("modifierType:ModifierType.MAP", "map", (type, _args) => new MapModifier(type)), POTION: () => new PokemonHpRestoreModifierType("modifierType:ModifierType.POTION", "potion", 20, 10), SUPER_POTION: () => new PokemonHpRestoreModifierType("modifierType:ModifierType.SUPER_POTION", "super_potion", 50, 25), @@ -1393,8 +1411,8 @@ export const modifierTypes = { SACRED_ASH: () => new AllPokemonFullReviveModifierType("modifierType:ModifierType.SACRED_ASH", "sacred_ash"), - REVIVER_SEED: () => new PokemonHeldItemModifierType("modifierType:ModifierType.REVIVER_SEED", "reviver_seed", (type, args) => new Modifiers.PokemonInstantReviveModifier(type, (args[0] as Pokemon).id)), - WHITE_HERB: () => new PokemonHeldItemModifierType("modifierType:ModifierType.WHITE_HERB", "white_herb", (type, args) => new Modifiers.ResetNegativeStatStageModifier(type, (args[0] as Pokemon).id)), + REVIVER_SEED: () => new PokemonHeldItemModifierType("modifierType:ModifierType.REVIVER_SEED", "reviver_seed", (type, args) => new PokemonInstantReviveModifier(type, (args[0] as Pokemon).id)), + WHITE_HERB: () => new PokemonHeldItemModifierType("modifierType:ModifierType.WHITE_HERB", "white_herb", (type, args) => new ResetNegativeStatStageModifier(type, (args[0] as Pokemon).id)), ETHER: () => new PokemonPpRestoreModifierType("modifierType:ModifierType.ETHER", "ether", 10), MAX_ETHER: () => new PokemonPpRestoreModifierType("modifierType:ModifierType.MAX_ETHER", "max_ether", -1), @@ -1424,7 +1442,7 @@ export const modifierTypes = { amount: i18next.t("modifierType:ModifierType.TempStatStageBoosterModifierType.extra.stage") }); } - }("modifierType:ModifierType.DIRE_HIT", "dire_hit", (type, _args) => new Modifiers.TempCritBoosterModifier(type, 5)), + }("modifierType:ModifierType.DIRE_HIT", "dire_hit", (type, _args) => new TempCritBoosterModifier(type, 5)), BASE_STAT_BOOSTER: () => new BaseStatBoosterModifierTypeGenerator(), @@ -1434,22 +1452,22 @@ export const modifierTypes = { if (pregenArgs && (pregenArgs.length === 1) && (pregenArgs[0] in Nature)) { return new PokemonNatureChangeModifierType(pregenArgs[0] as Nature); } - return new PokemonNatureChangeModifierType(Utils.randSeedInt(Utils.getEnumValues(Nature).length) as Nature); + return new PokemonNatureChangeModifierType(randSeedInt(getEnumValues(Nature).length) as Nature); }), TERA_SHARD: () => new ModifierTypeGenerator((party: Pokemon[], pregenArgs?: any[]) => { if (pregenArgs && (pregenArgs.length === 1) && (pregenArgs[0] in Type)) { return new TerastallizeModifierType(pregenArgs[0] as Type); } - if (!party[0].scene.getModifiers(Modifiers.TerastallizeAccessModifier).length) { + if (!party[0].scene.getModifiers(TerastallizeAccessModifier).length) { return null; } let type: Type; - if (!Utils.randSeedInt(3)) { + if (!randSeedInt(3)) { const partyMemberTypes = party.map(p => p.getTypes(false, false, true)).flat(); - type = Utils.randSeedItem(partyMemberTypes); + type = randSeedItem(partyMemberTypes); } else { - type = Utils.randSeedInt(64) ? Utils.randSeedInt(18) as Type : Type.STELLAR; + type = randSeedInt(64) ? randSeedInt(18) as Type : Type.STELLAR; } return new TerastallizeModifierType(type); }), @@ -1458,9 +1476,9 @@ export const modifierTypes = { if (pregenArgs && (pregenArgs.length === 1) && (pregenArgs[0] in BerryType)) { return new BerryModifierType(pregenArgs[0] as BerryType); } - const berryTypes = Utils.getEnumValues(BerryType); + const berryTypes = getEnumValues(BerryType); let randBerryType: BerryType; - const rand = Utils.randSeedInt(12); + const rand = randSeedInt(12); if (rand < 2) { randBerryType = BerryType.SITRUS; } else if (rand < 4) { @@ -1468,7 +1486,7 @@ export const modifierTypes = { } else if (rand < 6) { randBerryType = BerryType.LEPPA; } else { - randBerryType = berryTypes[Utils.randSeedInt(berryTypes.length - 3) + 2]; + randBerryType = berryTypes[randSeedInt(berryTypes.length - 3) + 2]; } return new BerryModifierType(randBerryType); }), @@ -1479,10 +1497,10 @@ export const modifierTypes = { MEMORY_MUSHROOM: () => new RememberMoveModifierType("modifierType:ModifierType.MEMORY_MUSHROOM", "big_mushroom"), - EXP_SHARE: () => new ModifierType("modifierType:ModifierType.EXP_SHARE", "exp_share", (type, _args) => new Modifiers.ExpShareModifier(type)), - EXP_BALANCE: () => new ModifierType("modifierType:ModifierType.EXP_BALANCE", "exp_balance", (type, _args) => new Modifiers.ExpBalanceModifier(type)), + EXP_SHARE: () => new ModifierType("modifierType:ModifierType.EXP_SHARE", "exp_share", (type, _args) => new ExpShareModifier(type)), + EXP_BALANCE: () => new ModifierType("modifierType:ModifierType.EXP_BALANCE", "exp_balance", (type, _args) => new ExpBalanceModifier(type)), - OVAL_CHARM: () => new ModifierType("modifierType:ModifierType.OVAL_CHARM", "oval_charm", (type, _args) => new Modifiers.MultipleParticipantExpBonusModifier(type)), + OVAL_CHARM: () => new ModifierType("modifierType:ModifierType.OVAL_CHARM", "oval_charm", (type, _args) => new MultipleParticipantExpBonusModifier(type)), EXP_CHARM: () => new ExpBoosterModifierType("modifierType:ModifierType.EXP_CHARM", "exp_charm", 25), SUPER_EXP_CHARM: () => new ExpBoosterModifierType("modifierType:ModifierType.SUPER_EXP_CHARM", "super_exp_charm", 60), @@ -1493,51 +1511,52 @@ export const modifierTypes = { SOOTHE_BELL: () => new PokemonFriendshipBoosterModifierType("modifierType:ModifierType.SOOTHE_BELL", "soothe_bell"), - SCOPE_LENS: () => new PokemonHeldItemModifierType("modifierType:ModifierType.SCOPE_LENS", "scope_lens", (type, args) => new Modifiers.CritBoosterModifier(type, (args[0] as Pokemon).id, 1)), - LEEK: () => new PokemonHeldItemModifierType("modifierType:ModifierType.LEEK", "leek", (type, args) => new Modifiers.SpeciesCritBoosterModifier(type, (args[0] as Pokemon).id, 2, [Species.FARFETCHD, Species.GALAR_FARFETCHD, Species.SIRFETCHD])), + SCOPE_LENS: () => new PokemonHeldItemModifierType("modifierType:ModifierType.SCOPE_LENS", "scope_lens", (type, args) => new CritBoosterModifier(type, (args[0] as Pokemon).id, 1)), + LEEK: () => new PokemonHeldItemModifierType("modifierType:ModifierType.LEEK", "leek", (type, args) => new SpeciesCritBoosterModifier(type, (args[0] as Pokemon).id, 2, [ Species.FARFETCHD, Species.GALAR_FARFETCHD, Species.SIRFETCHD ])), - EVIOLITE: () => new PokemonHeldItemModifierType("modifierType:ModifierType.EVIOLITE", "eviolite", (type, args) => new Modifiers.EvolutionStatBoosterModifier(type, (args[0] as Pokemon).id, [Stat.DEF, Stat.SPDEF], 1.5)), + EVIOLITE: () => new PokemonHeldItemModifierType("modifierType:ModifierType.EVIOLITE", "eviolite", (type, args) => new EvolutionStatBoosterModifier(type, (args[0] as Pokemon).id, [ Stat.DEF, Stat.SPDEF ], 1.5)), - SOUL_DEW: () => new PokemonHeldItemModifierType("modifierType:ModifierType.SOUL_DEW", "soul_dew", (type, args) => new Modifiers.PokemonNatureWeightModifier(type, (args[0] as Pokemon).id)), + SOUL_DEW: () => new PokemonHeldItemModifierType("modifierType:ModifierType.SOUL_DEW", "soul_dew", (type, args) => new PokemonNatureWeightModifier(type, (args[0] as Pokemon).id)), NUGGET: () => new MoneyRewardModifierType("modifierType:ModifierType.NUGGET", "nugget", 1, "modifierType:ModifierType.MoneyRewardModifierType.extra.small"), BIG_NUGGET: () => new MoneyRewardModifierType("modifierType:ModifierType.BIG_NUGGET", "big_nugget", 2.5, "modifierType:ModifierType.MoneyRewardModifierType.extra.moderate"), RELIC_GOLD: () => new MoneyRewardModifierType("modifierType:ModifierType.RELIC_GOLD", "relic_gold", 10, "modifierType:ModifierType.MoneyRewardModifierType.extra.large"), - AMULET_COIN: () => new ModifierType("modifierType:ModifierType.AMULET_COIN", "amulet_coin", (type, _args) => new Modifiers.MoneyMultiplierModifier(type)), - GOLDEN_PUNCH: () => new PokemonHeldItemModifierType("modifierType:ModifierType.GOLDEN_PUNCH", "golden_punch", (type, args) => new Modifiers.DamageMoneyRewardModifier(type, (args[0] as Pokemon).id)), - COIN_CASE: () => new ModifierType("modifierType:ModifierType.COIN_CASE", "coin_case", (type, _args) => new Modifiers.MoneyInterestModifier(type)), + AMULET_COIN: () => new ModifierType("modifierType:ModifierType.AMULET_COIN", "amulet_coin", (type, _args) => new MoneyMultiplierModifier(type)), + GOLDEN_PUNCH: () => new PokemonHeldItemModifierType("modifierType:ModifierType.GOLDEN_PUNCH", "golden_punch", (type, args) => new DamageMoneyRewardModifier(type, (args[0] as Pokemon).id)), + COIN_CASE: () => new ModifierType("modifierType:ModifierType.COIN_CASE", "coin_case", (type, _args) => new MoneyInterestModifier(type)), - LOCK_CAPSULE: () => new ModifierType("modifierType:ModifierType.LOCK_CAPSULE", "lock_capsule", (type, _args) => new Modifiers.LockModifierTiersModifier(type)), + LOCK_CAPSULE: () => new ModifierType("modifierType:ModifierType.LOCK_CAPSULE", "lock_capsule", (type, _args) => new LockModifierTiersModifier(type)), GRIP_CLAW: () => new ContactHeldItemTransferChanceModifierType("modifierType:ModifierType.GRIP_CLAW", "grip_claw", 10), WIDE_LENS: () => new PokemonMoveAccuracyBoosterModifierType("modifierType:ModifierType.WIDE_LENS", "wide_lens", 5), MULTI_LENS: () => new PokemonMultiHitModifierType("modifierType:ModifierType.MULTI_LENS", "zoom_lens"), - HEALING_CHARM: () => new ModifierType("modifierType:ModifierType.HEALING_CHARM", "healing_charm", (type, _args) => new Modifiers.HealingBoosterModifier(type, 1.1)), - CANDY_JAR: () => new ModifierType("modifierType:ModifierType.CANDY_JAR", "candy_jar", (type, _args) => new Modifiers.LevelIncrementBoosterModifier(type)), + HEALING_CHARM: () => new ModifierType("modifierType:ModifierType.HEALING_CHARM", "healing_charm", (type, _args) => new HealingBoosterModifier(type, 1.1)), + CANDY_JAR: () => new ModifierType("modifierType:ModifierType.CANDY_JAR", "candy_jar", (type, _args) => new LevelIncrementBoosterModifier(type)), - BERRY_POUCH: () => new ModifierType("modifierType:ModifierType.BERRY_POUCH", "berry_pouch", (type, _args) => new Modifiers.PreserveBerryModifier(type)), + BERRY_POUCH: () => new ModifierType("modifierType:ModifierType.BERRY_POUCH", "berry_pouch", (type, _args) => new PreserveBerryModifier(type)), - FOCUS_BAND: () => new PokemonHeldItemModifierType("modifierType:ModifierType.FOCUS_BAND", "focus_band", (type, args) => new Modifiers.SurviveDamageModifier(type, (args[0] as Pokemon).id)), + FOCUS_BAND: () => new PokemonHeldItemModifierType("modifierType:ModifierType.FOCUS_BAND", "focus_band", (type, args) => new SurviveDamageModifier(type, (args[0] as Pokemon).id)), - QUICK_CLAW: () => new PokemonHeldItemModifierType("modifierType:ModifierType.QUICK_CLAW", "quick_claw", (type, args) => new Modifiers.BypassSpeedChanceModifier(type, (args[0] as Pokemon).id)), + QUICK_CLAW: () => new PokemonHeldItemModifierType("modifierType:ModifierType.QUICK_CLAW", "quick_claw", (type, args) => new BypassSpeedChanceModifier(type, (args[0] as Pokemon).id)), - KINGS_ROCK: () => new PokemonHeldItemModifierType("modifierType:ModifierType.KINGS_ROCK", "kings_rock", (type, args) => new Modifiers.FlinchChanceModifier(type, (args[0] as Pokemon).id)), + KINGS_ROCK: () => new PokemonHeldItemModifierType("modifierType:ModifierType.KINGS_ROCK", "kings_rock", (type, args) => new FlinchChanceModifier(type, (args[0] as Pokemon).id)), - LEFTOVERS: () => new PokemonHeldItemModifierType("modifierType:ModifierType.LEFTOVERS", "leftovers", (type, args) => new Modifiers.TurnHealModifier(type, (args[0] as Pokemon).id)), - SHELL_BELL: () => new PokemonHeldItemModifierType("modifierType:ModifierType.SHELL_BELL", "shell_bell", (type, args) => new Modifiers.HitHealModifier(type, (args[0] as Pokemon).id)), + LEFTOVERS: () => new PokemonHeldItemModifierType("modifierType:ModifierType.LEFTOVERS", "leftovers", (type, args) => new TurnHealModifier(type, (args[0] as Pokemon).id)), + SHELL_BELL: () => new PokemonHeldItemModifierType("modifierType:ModifierType.SHELL_BELL", "shell_bell", (type, args) => new HitHealModifier(type, (args[0] as Pokemon).id)), - TOXIC_ORB: () => new PokemonHeldItemModifierType("modifierType:ModifierType.TOXIC_ORB", "toxic_orb", (type, args) => new Modifiers.TurnStatusEffectModifier(type, (args[0] as Pokemon).id)), - FLAME_ORB: () => new PokemonHeldItemModifierType("modifierType:ModifierType.FLAME_ORB", "flame_orb", (type, args) => new Modifiers.TurnStatusEffectModifier(type, (args[0] as Pokemon).id)), + TOXIC_ORB: () => new PokemonHeldItemModifierType("modifierType:ModifierType.TOXIC_ORB", "toxic_orb", (type, args) => new TurnStatusEffectModifier(type, (args[0] as Pokemon).id)), + FLAME_ORB: () => new PokemonHeldItemModifierType("modifierType:ModifierType.FLAME_ORB", "flame_orb", (type, args) => new TurnStatusEffectModifier(type, (args[0] as Pokemon).id)), - BATON: () => new PokemonHeldItemModifierType("modifierType:ModifierType.BATON", "baton", (type, args) => new Modifiers.SwitchEffectTransferModifier(type, (args[0] as Pokemon).id)), + BATON: () => new PokemonHeldItemModifierType("modifierType:ModifierType.BATON", "baton", (type, args) => new SwitchEffectTransferModifier(type, (args[0] as Pokemon).id)), - SHINY_CHARM: () => new ModifierType("modifierType:ModifierType.SHINY_CHARM", "shiny_charm", (type, _args) => new Modifiers.ShinyRateBoosterModifier(type)), - ABILITY_CHARM: () => new ModifierType("modifierType:ModifierType.ABILITY_CHARM", "ability_charm", (type, _args) => new Modifiers.HiddenAbilityRateBoosterModifier(type)), + SHINY_CHARM: () => new ModifierType("modifierType:ModifierType.SHINY_CHARM", "shiny_charm", (type, _args) => new ShinyRateBoosterModifier(type)), + ABILITY_CHARM: () => new ModifierType("modifierType:ModifierType.ABILITY_CHARM", "ability_charm", (type, _args) => new HiddenAbilityRateBoosterModifier(type)), + CATCHING_CHARM: () => new ModifierType("modifierType:ModifierType.CATCHING_CHARM", "catching_charm", (type, _args) => new CriticalCatchChanceBoosterModifier(type)), - IV_SCANNER: () => new ModifierType("modifierType:ModifierType.IV_SCANNER", "scanner", (type, _args) => new Modifiers.IvScannerModifier(type)), + IV_SCANNER: () => new ModifierType("modifierType:ModifierType.IV_SCANNER", "scanner", (type, _args) => new IvScannerModifier(type)), DNA_SPLICERS: () => new FusePokemonModifierType("modifierType:ModifierType.DNA_SPLICERS", "dna_splicers"), @@ -1547,34 +1566,40 @@ export const modifierTypes = { VOUCHER_PLUS: () => new AddVoucherModifierType(VoucherType.PLUS, 1), VOUCHER_PREMIUM: () => new AddVoucherModifierType(VoucherType.PREMIUM, 1), - GOLDEN_POKEBALL: () => new ModifierType("modifierType:ModifierType.GOLDEN_POKEBALL", "pb_gold", (type, _args) => new Modifiers.ExtraModifierModifier(type), undefined, "se/pb_bounce_1"), + GOLDEN_POKEBALL: () => new ModifierType("modifierType:ModifierType.GOLDEN_POKEBALL", "pb_gold", (type, _args) => new ExtraModifierModifier(type), undefined, "se/pb_bounce_1"), + SILVER_POKEBALL: () => new ModifierType("modifierType:ModifierType.SILVER_POKEBALL", "pb_silver", (type, _args) => new TempExtraModifierModifier(type, 100), undefined, "se/pb_bounce_1"), - ENEMY_DAMAGE_BOOSTER: () => new ModifierType("modifierType:ModifierType.ENEMY_DAMAGE_BOOSTER", "wl_item_drop", (type, _args) => new Modifiers.EnemyDamageBoosterModifier(type, 5)), - ENEMY_DAMAGE_REDUCTION: () => new ModifierType("modifierType:ModifierType.ENEMY_DAMAGE_REDUCTION", "wl_guard_spec", (type, _args) => new Modifiers.EnemyDamageReducerModifier(type, 2.5)), - //ENEMY_SUPER_EFFECT_BOOSTER: () => new ModifierType('Type Advantage Token', 'Increases damage of super effective attacks by 30%', (type, _args) => new Modifiers.EnemySuperEffectiveDamageBoosterModifier(type, 30), 'wl_custom_super_effective'), - ENEMY_HEAL: () => new ModifierType("modifierType:ModifierType.ENEMY_HEAL", "wl_potion", (type, _args) => new Modifiers.EnemyTurnHealModifier(type, 2, 10)), + ENEMY_DAMAGE_BOOSTER: () => new ModifierType("modifierType:ModifierType.ENEMY_DAMAGE_BOOSTER", "wl_item_drop", (type, _args) => new EnemyDamageBoosterModifier(type, 5)), + ENEMY_DAMAGE_REDUCTION: () => new ModifierType("modifierType:ModifierType.ENEMY_DAMAGE_REDUCTION", "wl_guard_spec", (type, _args) => new EnemyDamageReducerModifier(type, 2.5)), + //ENEMY_SUPER_EFFECT_BOOSTER: () => new ModifierType('Type Advantage Token', 'Increases damage of super effective attacks by 30%', (type, _args) => new EnemySuperEffectiveDamageBoosterModifier(type, 30), 'wl_custom_super_effective'), + ENEMY_HEAL: () => new ModifierType("modifierType:ModifierType.ENEMY_HEAL", "wl_potion", (type, _args) => new EnemyTurnHealModifier(type, 2, 10)), ENEMY_ATTACK_POISON_CHANCE: () => new EnemyAttackStatusEffectChanceModifierType("modifierType:ModifierType.ENEMY_ATTACK_POISON_CHANCE", "wl_antidote", 5, StatusEffect.POISON, 10), ENEMY_ATTACK_PARALYZE_CHANCE: () => new EnemyAttackStatusEffectChanceModifierType("modifierType:ModifierType.ENEMY_ATTACK_PARALYZE_CHANCE", "wl_paralyze_heal", 2.5, StatusEffect.PARALYSIS, 10), ENEMY_ATTACK_BURN_CHANCE: () => new EnemyAttackStatusEffectChanceModifierType("modifierType:ModifierType.ENEMY_ATTACK_BURN_CHANCE", "wl_burn_heal", 5, StatusEffect.BURN, 10), - ENEMY_STATUS_EFFECT_HEAL_CHANCE: () => new ModifierType("modifierType:ModifierType.ENEMY_STATUS_EFFECT_HEAL_CHANCE", "wl_full_heal", (type, _args) => new Modifiers.EnemyStatusEffectHealChanceModifier(type, 2.5, 10)), + ENEMY_STATUS_EFFECT_HEAL_CHANCE: () => new ModifierType("modifierType:ModifierType.ENEMY_STATUS_EFFECT_HEAL_CHANCE", "wl_full_heal", (type, _args) => new EnemyStatusEffectHealChanceModifier(type, 2.5, 10)), ENEMY_ENDURE_CHANCE: () => new EnemyEndureChanceModifierType("modifierType:ModifierType.ENEMY_ENDURE_CHANCE", "wl_reset_urge", 2), - ENEMY_FUSED_CHANCE: () => new ModifierType("modifierType:ModifierType.ENEMY_FUSED_CHANCE", "wl_custom_spliced", (type, _args) => new Modifiers.EnemyFusionChanceModifier(type, 1)), + ENEMY_FUSED_CHANCE: () => new ModifierType("modifierType:ModifierType.ENEMY_FUSED_CHANCE", "wl_custom_spliced", (type, _args) => new EnemyFusionChanceModifier(type, 1)), MYSTERY_ENCOUNTER_SHUCKLE_JUICE: () => new ModifierTypeGenerator((party: Pokemon[], pregenArgs?: any[]) => { if (pregenArgs) { - return new PokemonBaseStatTotalModifierType(pregenArgs[0] as integer); + return new PokemonBaseStatTotalModifierType(pregenArgs[0] as number); } - return new PokemonBaseStatTotalModifierType(Utils.randSeedInt(20)); + return new PokemonBaseStatTotalModifierType(randSeedInt(20, 1)); }), MYSTERY_ENCOUNTER_OLD_GATEAU: () => new ModifierTypeGenerator((party: Pokemon[], pregenArgs?: any[]) => { if (pregenArgs) { - return new PokemonBaseStatFlatModifierType(pregenArgs[0] as integer, pregenArgs[1] as Stat[]); + return new PokemonBaseStatFlatModifierType(pregenArgs[0] as number, pregenArgs[1] as Stat[]); } - return new PokemonBaseStatFlatModifierType(Utils.randSeedInt(20), [Stat.HP, Stat.ATK, Stat.DEF]); + return new PokemonBaseStatFlatModifierType(randSeedInt(20, 1), [ Stat.HP, Stat.ATK, Stat.DEF ]); }), - MYSTERY_ENCOUNTER_BLACK_SLUDGE: () => new ModifierType("modifierType:ModifierType.MYSTERY_ENCOUNTER_BLACK_SLUDGE", "black_sludge", (type, _args) => new Modifiers.HealShopCostModifier(type)), - MYSTERY_ENCOUNTER_MACHO_BRACE: () => new PokemonHeldItemModifierType("modifierType:ModifierType.MYSTERY_ENCOUNTER_MACHO_BRACE", "macho_brace", (type, args) => new Modifiers.PokemonIncrementingStatModifier(type, (args[0] as Pokemon).id)), - MYSTERY_ENCOUNTER_GOLDEN_BUG_NET: () => new ModifierType("modifierType:ModifierType.MYSTERY_ENCOUNTER_GOLDEN_BUG_NET", "golden_net", (type, _args) => new Modifiers.BoostBugSpawnModifier(type)), + MYSTERY_ENCOUNTER_BLACK_SLUDGE: () => new ModifierTypeGenerator((party: Pokemon[], pregenArgs?: any[]) => { + if (pregenArgs) { + return new ModifierType("modifierType:ModifierType.MYSTERY_ENCOUNTER_BLACK_SLUDGE", "black_sludge", (type, _args) => new HealShopCostModifier(type, pregenArgs[0] as number)); + } + return new ModifierType("modifierType:ModifierType.MYSTERY_ENCOUNTER_BLACK_SLUDGE", "black_sludge", (type, _args) => new HealShopCostModifier(type, 2.5)); + }), + MYSTERY_ENCOUNTER_MACHO_BRACE: () => new PokemonHeldItemModifierType("modifierType:ModifierType.MYSTERY_ENCOUNTER_MACHO_BRACE", "macho_brace", (type, args) => new PokemonIncrementingStatModifier(type, (args[0] as Pokemon).id)), + MYSTERY_ENCOUNTER_GOLDEN_BUG_NET: () => new ModifierType("modifierType:ModifierType.MYSTERY_ENCOUNTER_GOLDEN_BUG_NET", "golden_net", (type, _args) => new BoostBugSpawnModifier(type)), }; interface ModifierPool { @@ -1596,22 +1621,24 @@ const modifierPool: ModifierPool = { new WeightedModifierType(modifierTypes.POKEBALL, (party: Pokemon[]) => (hasMaximumBalls(party, PokeballType.POKEBALL)) ? 0 : 6, 6), new WeightedModifierType(modifierTypes.RARE_CANDY, 2), new WeightedModifierType(modifierTypes.POTION, (party: Pokemon[]) => { - const thresholdPartyMemberCount = Math.min(party.filter(p => (p.getInverseHp() >= 10 || p.getHpRatio() <= 0.875) && !p.isFainted()).length, 3); + const thresholdPartyMemberCount = Math.min(party.filter(p => (p.getInverseHp() >= 10 && p.getHpRatio() <= 0.875) && !p.isFainted()).length, 3); return thresholdPartyMemberCount * 3; }, 9), new WeightedModifierType(modifierTypes.SUPER_POTION, (party: Pokemon[]) => { - const thresholdPartyMemberCount = Math.min(party.filter(p => (p.getInverseHp() >= 25 || p.getHpRatio() <= 0.75) && !p.isFainted()).length, 3); + const thresholdPartyMemberCount = Math.min(party.filter(p => (p.getInverseHp() >= 25 && p.getHpRatio() <= 0.75) && !p.isFainted()).length, 3); return thresholdPartyMemberCount; }, 3), new WeightedModifierType(modifierTypes.ETHER, (party: Pokemon[]) => { - const thresholdPartyMemberCount = Math.min(party.filter(p => p.hp && p.getMoveset().filter(m => m?.ppUsed && (m.getMovePp() - m.ppUsed) <= 5 && m.ppUsed >= Math.floor(m.getMovePp() / 2)).length).length, 3); + const thresholdPartyMemberCount = Math.min(party.filter(p => p.hp && !p.getHeldItems().some(m => m instanceof BerryModifier && m.berryType === BerryType.LEPPA) + && p.getMoveset().filter(m => m?.ppUsed && (m.getMovePp() - m.ppUsed) <= 5 && m.ppUsed > Math.floor(m.getMovePp() / 2)).length).length, 3); return thresholdPartyMemberCount * 3; }, 9), new WeightedModifierType(modifierTypes.MAX_ETHER, (party: Pokemon[]) => { - const thresholdPartyMemberCount = Math.min(party.filter(p => p.hp && p.getMoveset().filter(m => m?.ppUsed && (m.getMovePp() - m.ppUsed) <= 5 && m.ppUsed >= Math.floor(m.getMovePp() / 2)).length).length, 3); + const thresholdPartyMemberCount = Math.min(party.filter(p => p.hp && !p.getHeldItems().some(m => m instanceof BerryModifier && m.berryType === BerryType.LEPPA) + && p.getMoveset().filter(m => m?.ppUsed && (m.getMovePp() - m.ppUsed) <= 5 && m.ppUsed > Math.floor(m.getMovePp() / 2)).length).length, 3); return thresholdPartyMemberCount; }, 3), - new WeightedModifierType(modifierTypes.LURE, skipInLastClassicWaveOrDefault(2)), + new WeightedModifierType(modifierTypes.LURE, lureWeightFunc(10, 2)), new WeightedModifierType(modifierTypes.TEMP_STAT_STAGE_BOOSTER, 4), new WeightedModifierType(modifierTypes.BERRY, 2), new WeightedModifierType(modifierTypes.TM_COMMON, 2), @@ -1623,8 +1650,8 @@ const modifierPool: ModifierPool = { new WeightedModifierType(modifierTypes.PP_UP, 2), new WeightedModifierType(modifierTypes.FULL_HEAL, (party: Pokemon[]) => { const statusEffectPartyMemberCount = Math.min(party.filter(p => p.hp && !!p.status && !p.getHeldItems().some(i => { - if (i instanceof Modifiers.TurnStatusEffectModifier) { - return (i as Modifiers.TurnStatusEffectModifier).getStatusEffect() === p.status?.effect; + if (i instanceof TurnStatusEffectModifier) { + return (i as TurnStatusEffectModifier).getStatusEffect() === p.status?.effect; } return false; })).length, 3); @@ -1642,33 +1669,35 @@ const modifierPool: ModifierPool = { return party.filter(p => p.isFainted()).length >= Math.ceil(party.length / 2) ? 1 : 0; }, 1), new WeightedModifierType(modifierTypes.HYPER_POTION, (party: Pokemon[]) => { - const thresholdPartyMemberCount = Math.min(party.filter(p => (p.getInverseHp() >= 100 || p.getHpRatio() <= 0.625) && !p.isFainted()).length, 3); + const thresholdPartyMemberCount = Math.min(party.filter(p => (p.getInverseHp() >= 100 && p.getHpRatio() <= 0.625) && !p.isFainted()).length, 3); return thresholdPartyMemberCount * 3; }, 9), new WeightedModifierType(modifierTypes.MAX_POTION, (party: Pokemon[]) => { - const thresholdPartyMemberCount = Math.min(party.filter(p => (p.getInverseHp() >= 150 || p.getHpRatio() <= 0.5) && !p.isFainted()).length, 3); + const thresholdPartyMemberCount = Math.min(party.filter(p => (p.getInverseHp() >= 100 && p.getHpRatio() <= 0.5) && !p.isFainted()).length, 3); return thresholdPartyMemberCount; }, 3), new WeightedModifierType(modifierTypes.FULL_RESTORE, (party: Pokemon[]) => { const statusEffectPartyMemberCount = Math.min(party.filter(p => p.hp && !!p.status && !p.getHeldItems().some(i => { - if (i instanceof Modifiers.TurnStatusEffectModifier) { - return (i as Modifiers.TurnStatusEffectModifier).getStatusEffect() === p.status?.effect; + if (i instanceof TurnStatusEffectModifier) { + return (i as TurnStatusEffectModifier).getStatusEffect() === p.status?.effect; } return false; })).length, 3); - const thresholdPartyMemberCount = Math.floor((Math.min(party.filter(p => (p.getInverseHp() >= 150 || p.getHpRatio() <= 0.5) && !p.isFainted()).length, 3) + statusEffectPartyMemberCount) / 2); + const thresholdPartyMemberCount = Math.floor((Math.min(party.filter(p => (p.getInverseHp() >= 100 && p.getHpRatio() <= 0.5) && !p.isFainted()).length, 3) + statusEffectPartyMemberCount) / 2); return thresholdPartyMemberCount; }, 3), new WeightedModifierType(modifierTypes.ELIXIR, (party: Pokemon[]) => { - const thresholdPartyMemberCount = Math.min(party.filter(p => p.hp && p.getMoveset().filter(m => m?.ppUsed && (m.getMovePp() - m.ppUsed) <= 5 && m.ppUsed >= Math.floor(m.getMovePp() / 2)).length).length, 3); + const thresholdPartyMemberCount = Math.min(party.filter(p => p.hp && !p.getHeldItems().some(m => m instanceof BerryModifier && m.berryType === BerryType.LEPPA) + && p.getMoveset().filter(m => m?.ppUsed && (m.getMovePp() - m.ppUsed) <= 5 && m.ppUsed > Math.floor(m.getMovePp() / 2)).length).length, 3); return thresholdPartyMemberCount * 3; }, 9), new WeightedModifierType(modifierTypes.MAX_ELIXIR, (party: Pokemon[]) => { - const thresholdPartyMemberCount = Math.min(party.filter(p => p.hp && p.getMoveset().filter(m => m?.ppUsed && (m.getMovePp() - m.ppUsed) <= 5 && m.ppUsed >= Math.floor(m.getMovePp() / 2)).length).length, 3); + const thresholdPartyMemberCount = Math.min(party.filter(p => p.hp && !p.getHeldItems().some(m => m instanceof BerryModifier && m.berryType === BerryType.LEPPA) + && p.getMoveset().filter(m => m?.ppUsed && (m.getMovePp() - m.ppUsed) <= 5 && m.ppUsed > Math.floor(m.getMovePp() / 2)).length).length, 3); return thresholdPartyMemberCount; }, 3), new WeightedModifierType(modifierTypes.DIRE_HIT, 4), - new WeightedModifierType(modifierTypes.SUPER_LURE, skipInLastClassicWaveOrDefault(4)), + new WeightedModifierType(modifierTypes.SUPER_LURE, lureWeightFunc(15, 4)), new WeightedModifierType(modifierTypes.NUGGET, skipInLastClassicWaveOrDefault(5)), new WeightedModifierType(modifierTypes.EVOLUTION_ITEM, (party: Pokemon[]) => { return Math.min(Math.ceil(party[0].scene.currentBattle.waveIndex / 15), 8); @@ -1691,7 +1720,7 @@ const modifierPool: ModifierPool = { }), [ModifierTier.ULTRA]: [ new WeightedModifierType(modifierTypes.ULTRA_BALL, (party: Pokemon[]) => (hasMaximumBalls(party, PokeballType.ULTRA_BALL)) ? 0 : 15, 15), - new WeightedModifierType(modifierTypes.MAX_LURE, skipInLastClassicWaveOrDefault(4)), + new WeightedModifierType(modifierTypes.MAX_LURE, lureWeightFunc(30, 4)), new WeightedModifierType(modifierTypes.BIG_NUGGET, skipInLastClassicWaveOrDefault(12)), new WeightedModifierType(modifierTypes.PP_MAX, 3), new WeightedModifierType(modifierTypes.MINT, 4), @@ -1699,8 +1728,10 @@ const modifierPool: ModifierPool = { new WeightedModifierType(modifierTypes.FORM_CHANGE_ITEM, (party: Pokemon[]) => Math.min(Math.ceil(party[0].scene.currentBattle.waveIndex / 50), 4) * 6, 24), new WeightedModifierType(modifierTypes.AMULET_COIN, skipInLastClassicWaveOrDefault(3)), new WeightedModifierType(modifierTypes.EVIOLITE, (party: Pokemon[]) => { - if (!party[0].scene.gameMode.isFreshStartChallenge() && party[0].scene.gameData.unlocks[Unlockables.EVIOLITE]) { - return party.some(p => ((p.getSpeciesForm(true).speciesId in pokemonEvolutions) || (p.isFusion() && (p.getFusionSpeciesForm(true).speciesId in pokemonEvolutions))) && !p.getHeldItems().some(i => i instanceof Modifiers.EvolutionStatBoosterModifier)) ? 10 : 0; + const { gameMode, gameData } = party[0].scene; + if (gameMode.isDaily || (!gameMode.isFreshStartChallenge() && gameData.isUnlocked(Unlockables.EVIOLITE))) { + return party.some(p => ((p.getSpeciesForm(true).speciesId in pokemonEvolutions) || (p.isFusion() && (p.getFusionSpeciesForm(true).speciesId in pokemonEvolutions))) + && !p.getHeldItems().some(i => i instanceof EvolutionStatBoosterModifier) && !p.isMax()) ? 10 : 0; } return 0; }), @@ -1708,24 +1739,29 @@ const modifierPool: ModifierPool = { new WeightedModifierType(modifierTypes.LEEK, (party: Pokemon[]) => { const checkedSpecies = [ Species.FARFETCHD, Species.GALAR_FARFETCHD, Species.SIRFETCHD ]; // If a party member doesn't already have a Leek and is one of the relevant species, Leek can appear - return party.some(p => !p.getHeldItems().some(i => i instanceof Modifiers.SpeciesCritBoosterModifier) && (checkedSpecies.includes(p.getSpeciesForm(true).speciesId) || (p.isFusion() && checkedSpecies.includes(p.getFusionSpeciesForm(true).speciesId)))) ? 12 : 0; + return party.some(p => !p.getHeldItems().some(i => i instanceof SpeciesCritBoosterModifier) + && (checkedSpecies.includes(p.getSpeciesForm(true).speciesId) + || (p.isFusion() && checkedSpecies.includes(p.getFusionSpeciesForm(true).speciesId)))) ? 12 : 0; }, 12), new WeightedModifierType(modifierTypes.TOXIC_ORB, (party: Pokemon[]) => { - const checkedAbilities = [Abilities.QUICK_FEET, Abilities.GUTS, Abilities.MARVEL_SCALE, Abilities.TOXIC_BOOST, Abilities.POISON_HEAL, Abilities.MAGIC_GUARD]; - const checkedMoves = [Moves.FACADE, Moves.TRICK, Moves.FLING, Moves.SWITCHEROO, Moves.PSYCHO_SHIFT]; + const checkedAbilities = [ Abilities.QUICK_FEET, Abilities.GUTS, Abilities.MARVEL_SCALE, Abilities.TOXIC_BOOST, Abilities.POISON_HEAL, Abilities.MAGIC_GUARD ]; + const checkedMoves = [ Moves.FACADE, Moves.TRICK, Moves.FLING, Moves.SWITCHEROO, Moves.PSYCHO_SHIFT ]; // If a party member doesn't already have one of these two orbs and has one of the above moves or abilities, the orb can appear - return party.some(p => !p.getHeldItems().some(i => i instanceof Modifiers.TurnStatusEffectModifier) && (checkedAbilities.some(a => p.hasAbility(a, false, true)) || p.getMoveset(true).some(m => m && checkedMoves.includes(m.moveId)))) ? 10 : 0; + return party.some(p => !p.getHeldItems().some(i => i instanceof TurnStatusEffectModifier) + && (checkedAbilities.some(a => p.hasAbility(a, false, true)) + || p.getMoveset(true).some(m => m && checkedMoves.includes(m.moveId)))) ? 10 : 0; }, 10), new WeightedModifierType(modifierTypes.FLAME_ORB, (party: Pokemon[]) => { - const checkedAbilities = [Abilities.QUICK_FEET, Abilities.GUTS, Abilities.MARVEL_SCALE, Abilities.FLARE_BOOST, Abilities.MAGIC_GUARD]; - const checkedMoves = [Moves.FACADE, Moves.TRICK, Moves.FLING, Moves.SWITCHEROO, Moves.PSYCHO_SHIFT]; + const checkedAbilities = [ Abilities.QUICK_FEET, Abilities.GUTS, Abilities.MARVEL_SCALE, Abilities.FLARE_BOOST, Abilities.MAGIC_GUARD ]; + const checkedMoves = [ Moves.FACADE, Moves.TRICK, Moves.FLING, Moves.SWITCHEROO, Moves.PSYCHO_SHIFT ]; // If a party member doesn't already have one of these two orbs and has one of the above moves or abilities, the orb can appear - return party.some(p => !p.getHeldItems().some(i => i instanceof Modifiers.TurnStatusEffectModifier) && (checkedAbilities.some(a => p.hasAbility(a, false, true)) || p.getMoveset(true).some(m => m && checkedMoves.includes(m.moveId)))) ? 10 : 0; + return party.some(p => !p.getHeldItems().some(i => i instanceof TurnStatusEffectModifier) + && (checkedAbilities.some(a => p.hasAbility(a, false, true)) || p.getMoveset(true).some(m => m && checkedMoves.includes(m.moveId)))) ? 10 : 0; }, 10), new WeightedModifierType(modifierTypes.WHITE_HERB, (party: Pokemon[]) => { - const checkedAbilities = [Abilities.WEAK_ARMOR, Abilities.CONTRARY, Abilities.MOODY, Abilities.ANGER_SHELL, Abilities.COMPETITIVE, Abilities.DEFIANT]; + const checkedAbilities = [ Abilities.WEAK_ARMOR, Abilities.CONTRARY, Abilities.MOODY, Abilities.ANGER_SHELL, Abilities.COMPETITIVE, Abilities.DEFIANT ]; const weightMultiplier = party.filter( - p => !p.getHeldItems().some(i => i instanceof Modifiers.ResetNegativeStatStageModifier && i.stackCount >= i.getMaxHeldItemCount(p)) && + p => !p.getHeldItems().some(i => i instanceof ResetNegativeStatStageModifier && i.stackCount >= i.getMaxHeldItemCount(p)) && (checkedAbilities.some(a => p.hasAbility(a, false, true)) || p.getMoveset(true).some(m => m && selfStatLowerMoves.includes(m.moveId)))).length; // If a party member has one of the above moves or abilities and doesn't have max herbs, the herb will appear more frequently return 0 * (weightMultiplier ? 2 : 1) + (weightMultiplier ? weightMultiplier * 0 : 0); @@ -1757,11 +1793,12 @@ const modifierPool: ModifierPool = { new WeightedModifierType(modifierTypes.BATON, 2), new WeightedModifierType(modifierTypes.SOUL_DEW, 7), //new WeightedModifierType(modifierTypes.OVAL_CHARM, 6), + new WeightedModifierType(modifierTypes.CATCHING_CHARM, (party: Pokemon[]) => !party[0].scene.gameMode.isFreshStartChallenge() && party[0].scene.gameData.getSpeciesCount(d => !!d.caughtAttr) > 100 ? 4 : 0, 4), new WeightedModifierType(modifierTypes.SOOTHE_BELL, 4), new WeightedModifierType(modifierTypes.ABILITY_CHARM, skipInClassicAfterWave(189, 6)), new WeightedModifierType(modifierTypes.FOCUS_BAND, 5), new WeightedModifierType(modifierTypes.KINGS_ROCK, 3), - new WeightedModifierType(modifierTypes.LOCK_CAPSULE, skipInLastClassicWaveOrDefault(3)), + new WeightedModifierType(modifierTypes.LOCK_CAPSULE, (party: Pokemon[]) => party[0].scene.gameMode.isClassic ? 0 : 3), new WeightedModifierType(modifierTypes.SUPER_EXP_CHARM, skipInLastClassicWaveOrDefault(8)), new WeightedModifierType(modifierTypes.RARE_FORM_CHANGE_ITEM, (party: Pokemon[]) => Math.min(Math.ceil(party[0].scene.currentBattle.waveIndex / 50), 4) * 6, 24), new WeightedModifierType(modifierTypes.MEGA_BRACELET, (party: Pokemon[]) => Math.min(Math.ceil(party[0].scene.currentBattle.waveIndex / 50), 4) * 9, 36), @@ -1775,9 +1812,10 @@ const modifierPool: ModifierPool = { new WeightedModifierType(modifierTypes.SHINY_CHARM, 14), new WeightedModifierType(modifierTypes.HEALING_CHARM, 18), new WeightedModifierType(modifierTypes.MULTI_LENS, 18), - new WeightedModifierType(modifierTypes.VOUCHER_PREMIUM, (party: Pokemon[], rerollCount: integer) => !party[0].scene.gameMode.isDaily && !party[0].scene.gameMode.isEndless && !party[0].scene.gameMode.isSplicedOnly ? Math.max(5 - rerollCount * 2, 0) : 0, 5), + new WeightedModifierType(modifierTypes.VOUCHER_PREMIUM, (party: Pokemon[], rerollCount: integer) => + !party[0].scene.gameMode.isDaily && !party[0].scene.gameMode.isEndless && !party[0].scene.gameMode.isSplicedOnly ? Math.max(5 - rerollCount * 2, 0) : 0, 5), new WeightedModifierType(modifierTypes.DNA_SPLICERS, (party: Pokemon[]) => !party[0].scene.gameMode.isSplicedOnly && party.filter(p => !p.fusionSpecies).length > 1 ? 24 : 0, 24), - new WeightedModifierType(modifierTypes.MINI_BLACK_HOLE, (party: Pokemon[]) => (!party[0].scene.gameMode.isFreshStartChallenge() && party[0].scene.gameData.unlocks[Unlockables.MINI_BLACK_HOLE]) ? 1 : 0, 1), + new WeightedModifierType(modifierTypes.MINI_BLACK_HOLE, (party: Pokemon[]) => (party[0].scene.gameMode.isDaily || (!party[0].scene.gameMode.isFreshStartChallenge() && party[0].scene.gameData.isUnlocked(Unlockables.MINI_BLACK_HOLE))) ? 1 : 0, 1), ].map(m => { m.setTier(ModifierTier.MASTER); return m; }) @@ -1949,29 +1987,36 @@ let enemyBuffIgnoredPoolIndexes = {}; // eslint-disable-line @typescript-eslint/ export function getModifierPoolForType(poolType: ModifierPoolType): ModifierPool { let pool: ModifierPool; switch (poolType) { - case ModifierPoolType.PLAYER: - pool = modifierPool; - break; - case ModifierPoolType.WILD: - pool = wildModifierPool; - break; - case ModifierPoolType.TRAINER: - pool = trainerModifierPool; - break; - case ModifierPoolType.ENEMY_BUFF: - pool = enemyBuffModifierPool; - break; - case ModifierPoolType.DAILY_STARTER: - pool = dailyStarterModifierPool; - break; + case ModifierPoolType.PLAYER: + pool = modifierPool; + break; + case ModifierPoolType.WILD: + pool = wildModifierPool; + break; + case ModifierPoolType.TRAINER: + pool = trainerModifierPool; + break; + case ModifierPoolType.ENEMY_BUFF: + pool = enemyBuffModifierPool; + break; + case ModifierPoolType.DAILY_STARTER: + pool = dailyStarterModifierPool; + break; } return pool; } const tierWeights = [ 768 / 1024, 195 / 1024, 48 / 1024, 12 / 1024, 1 / 1024 ]; +/** + * Allows a unit test to check if an item exists in the Modifier Pool. Checks the pool directly, rather than attempting to reroll for the item. + */ +export const itemPoolChecks: Map = new Map(); export function regenerateModifierPoolThresholds(party: Pokemon[], poolType: ModifierPoolType, rerollCount: integer = 0) { const pool = getModifierPoolForType(poolType); + itemPoolChecks.forEach((v, k) => { + itemPoolChecks.set(k, false); + }); const ignoredIndexes = {}; const modifierTableData = {}; @@ -2008,6 +2053,9 @@ export function regenerateModifierPoolThresholds(party: Pokemon[], poolType: Mod ignoredIndexes[t].push(i++); return total; } + if (itemPoolChecks.has(modifierType.modifierType.id as ModifierTypeKeys)) { + itemPoolChecks.set(modifierType.modifierType.id as ModifierTypeKeys, true); + } thresholds.set(total, i++); return total; }, 0); @@ -2024,23 +2072,23 @@ export function regenerateModifierPoolThresholds(party: Pokemon[], poolType: Mod console.table(modifierTableData); } switch (poolType) { - case ModifierPoolType.PLAYER: - modifierPoolThresholds = thresholds; - ignoredPoolIndexes = ignoredIndexes; - break; - case ModifierPoolType.WILD: - case ModifierPoolType.TRAINER: - enemyModifierPoolThresholds = thresholds; - enemyIgnoredPoolIndexes = ignoredIndexes; - break; - case ModifierPoolType.ENEMY_BUFF: - enemyBuffModifierPoolThresholds = thresholds; - enemyBuffIgnoredPoolIndexes = ignoredIndexes; - break; - case ModifierPoolType.DAILY_STARTER: - dailyStarterModifierPoolThresholds = thresholds; - ignoredDailyStarterPoolIndexes = ignoredIndexes; - break; + case ModifierPoolType.PLAYER: + modifierPoolThresholds = thresholds; + ignoredPoolIndexes = ignoredIndexes; + break; + case ModifierPoolType.WILD: + case ModifierPoolType.TRAINER: + enemyModifierPoolThresholds = thresholds; + enemyIgnoredPoolIndexes = ignoredIndexes; + break; + case ModifierPoolType.ENEMY_BUFF: + enemyBuffModifierPoolThresholds = thresholds; + enemyBuffIgnoredPoolIndexes = ignoredIndexes; + break; + case ModifierPoolType.DAILY_STARTER: + dailyStarterModifierPoolThresholds = thresholds; + ignoredDailyStarterPoolIndexes = ignoredIndexes; + break; } } @@ -2096,7 +2144,7 @@ export function getPlayerModifierTypeOptions(count: integer, party: PlayerPokemo // Populates item id and tier guaranteedMod = guaranteedMod .withIdFromFunc(modifierTypes[modifierId]) - .withTierFromPool(); + .withTierFromPool(ModifierPoolType.PLAYER, party); const modType = guaranteedMod instanceof ModifierTypeGenerator ? guaranteedMod.generateType(party) : guaranteedMod; if (modType) { @@ -2160,12 +2208,12 @@ export function overridePlayerModifierTypeOptions(options: ModifierTypeOption[], let modifierType: ModifierType | null = modifierFunc(); if (modifierType instanceof ModifierTypeGenerator) { - const pregenArgs = ("type" in override) && (override.type !== null) ? [override.type] : undefined; + const pregenArgs = ("type" in override) && (override.type !== null) ? [ override.type ] : undefined; modifierType = modifierType.generateType(party, pregenArgs); } if (modifierType) { - options[i].type = modifierType.withIdFromFunc(modifierFunc).withTierFromPool(); + options[i].type = modifierType.withIdFromFunc(modifierFunc).withTierFromPool(ModifierPoolType.PLAYER, party); } } } @@ -2191,7 +2239,8 @@ export function getPlayerShopModifierTypeOptionsForWave(waveIndex: integer, base ], [ new ModifierTypeOption(modifierTypes.HYPER_POTION(), 0, baseCost * 0.8), - new ModifierTypeOption(modifierTypes.MAX_REVIVE(), 0, baseCost * 2.75) + new ModifierTypeOption(modifierTypes.MAX_REVIVE(), 0, baseCost * 2.75), + new ModifierTypeOption(modifierTypes.MEMORY_MUSHROOM(), 0, baseCost * 4) ], [ new ModifierTypeOption(modifierTypes.MAX_POTION(), 0, baseCost * 1.5), @@ -2207,47 +2256,47 @@ export function getPlayerShopModifierTypeOptionsForWave(waveIndex: integer, base return options.slice(0, Math.ceil(Math.max(waveIndex + 10, 0) / 30)).flat(); } -export function getEnemyBuffModifierForWave(tier: ModifierTier, enemyModifiers: Modifiers.PersistentModifier[], scene: BattleScene): Modifiers.EnemyPersistentModifier { +export function getEnemyBuffModifierForWave(tier: ModifierTier, enemyModifiers: PersistentModifier[], scene: BattleScene): EnemyPersistentModifier { let tierStackCount: number; switch (tier) { - case ModifierTier.ULTRA: - tierStackCount = 5; - break; - case ModifierTier.GREAT: - tierStackCount = 3; - break; - default: - tierStackCount = 1; - break; + case ModifierTier.ULTRA: + tierStackCount = 5; + break; + case ModifierTier.GREAT: + tierStackCount = 3; + break; + default: + tierStackCount = 1; + break; } const retryCount = 50; let candidate = getNewModifierTypeOption([], ModifierPoolType.ENEMY_BUFF, tier); let r = 0; - let matchingModifier: Modifiers.PersistentModifier | undefined; + let matchingModifier: PersistentModifier | undefined; while (++r < retryCount && (matchingModifier = enemyModifiers.find(m => m.type.id === candidate?.type?.id)) && matchingModifier.getMaxStackCount(scene) < matchingModifier.stackCount + (r < 10 ? tierStackCount : 1)) { candidate = getNewModifierTypeOption([], ModifierPoolType.ENEMY_BUFF, tier); } - const modifier = candidate?.type?.newModifier() as Modifiers.EnemyPersistentModifier; + const modifier = candidate?.type?.newModifier() as EnemyPersistentModifier; modifier.stackCount = tierStackCount; return modifier; } export function getEnemyModifierTypesForWave(waveIndex: integer, count: integer, party: EnemyPokemon[], poolType: ModifierPoolType.WILD | ModifierPoolType.TRAINER, upgradeChance: integer = 0): PokemonHeldItemModifierType[] { - const ret = new Array(count).fill(0).map(() => getNewModifierTypeOption(party, poolType, undefined, upgradeChance && !Utils.randSeedInt(upgradeChance) ? 1 : 0)?.type as PokemonHeldItemModifierType); + const ret = new Array(count).fill(0).map(() => getNewModifierTypeOption(party, poolType, undefined, upgradeChance && !randSeedInt(upgradeChance) ? 1 : 0)?.type as PokemonHeldItemModifierType); if (!(waveIndex % 1000)) { ret.push(getModifierType(modifierTypes.MINI_BLACK_HOLE) as PokemonHeldItemModifierType); } return ret; } -export function getDailyRunStarterModifiers(party: PlayerPokemon[]): Modifiers.PokemonHeldItemModifier[] { - const ret: Modifiers.PokemonHeldItemModifier[] = []; +export function getDailyRunStarterModifiers(party: PlayerPokemon[]): PokemonHeldItemModifier[] { + const ret: PokemonHeldItemModifier[] = []; for (const p of party) { for (let m = 0; m < 3; m++) { - const tierValue = Utils.randSeedInt(64); + const tierValue = randSeedInt(64); let tier: ModifierTier; if (tierValue > 25) { @@ -2262,7 +2311,7 @@ export function getDailyRunStarterModifiers(party: PlayerPokemon[]): Modifiers.P tier = ModifierTier.MASTER; } - const modifier = getNewModifierTypeOption(party, ModifierPoolType.DAILY_STARTER, tier)?.type?.newModifier(p) as Modifiers.PokemonHeldItemModifier; + const modifier = getNewModifierTypeOption(party, ModifierPoolType.DAILY_STARTER, tier)?.type?.newModifier(p) as PokemonHeldItemModifier; ret.push(modifier); } } @@ -2284,24 +2333,24 @@ function getNewModifierTypeOption(party: Pokemon[], poolType: ModifierPoolType, const pool = getModifierPoolForType(poolType); let thresholds: object; switch (poolType) { - case ModifierPoolType.PLAYER: - thresholds = modifierPoolThresholds; - break; - case ModifierPoolType.WILD: - thresholds = enemyModifierPoolThresholds; - break; - case ModifierPoolType.TRAINER: - thresholds = enemyModifierPoolThresholds; - break; - case ModifierPoolType.ENEMY_BUFF: - thresholds = enemyBuffModifierPoolThresholds; - break; - case ModifierPoolType.DAILY_STARTER: - thresholds = dailyStarterModifierPoolThresholds; - break; + case ModifierPoolType.PLAYER: + thresholds = modifierPoolThresholds; + break; + case ModifierPoolType.WILD: + thresholds = enemyModifierPoolThresholds; + break; + case ModifierPoolType.TRAINER: + thresholds = enemyModifierPoolThresholds; + break; + case ModifierPoolType.ENEMY_BUFF: + thresholds = enemyBuffModifierPoolThresholds; + break; + case ModifierPoolType.DAILY_STARTER: + thresholds = dailyStarterModifierPoolThresholds; + break; } if (tier === undefined) { - const tierValue = Utils.randSeedInt(1024); + const tierValue = randSeedInt(1024); if (!upgradeCount) { upgradeCount = 0; } @@ -2310,7 +2359,7 @@ function getNewModifierTypeOption(party: Pokemon[], poolType: ModifierPoolType, const upgradeOdds = Math.floor(128 / ((partyLuckValue + 4) / 4)); let upgraded = false; do { - upgraded = Utils.randSeedInt(upgradeOdds) < 4; + upgraded = randSeedInt(upgradeOdds) < 4; if (upgraded) { upgradeCount++; } @@ -2342,7 +2391,7 @@ function getNewModifierTypeOption(party: Pokemon[], poolType: ModifierPoolType, const partyShinyCount = party.filter(p => p.isShiny() && !p.isFainted()).length; const upgradeOdds = Math.floor(32 / ((partyShinyCount + 2) / 2)); while (modifierPool.hasOwnProperty(tier + upgradeCount + 1) && modifierPool[tier + upgradeCount + 1].length) { - if (!Utils.randSeedInt(upgradeOdds)) { + if (!randSeedInt(upgradeOdds)) { upgradeCount++; } else { break; @@ -2357,7 +2406,7 @@ function getNewModifierTypeOption(party: Pokemon[], poolType: ModifierPoolType, const tierThresholds = Object.keys(thresholds[tier]); const totalWeight = parseInt(tierThresholds[tierThresholds.length - 1]); - const value = Utils.randSeedInt(totalWeight); + const value = randSeedInt(totalWeight); let index: integer | undefined; for (const t of tierThresholds) { const threshold = parseInt(t); @@ -2410,10 +2459,22 @@ export class ModifierTypeOption { } } +/** + * Calculates the team's luck value. + * @param party The player's party. + * @returns A number between 0 and 14 based on the party's total luck value, or a random number between 0 and 14 if the player is in Daily Run mode. + */ export function getPartyLuckValue(party: Pokemon[]): integer { + if (party[0].scene.gameMode.isDaily) { + const DailyLuck = new NumberHolder(0); + party[0].scene.executeWithSeedOffset(() => { + DailyLuck.value = randSeedInt(15); // Random number between 0 and 14 + }, 0, party[0].scene.seed); + return DailyLuck.value; + } const luck = Phaser.Math.Clamp(party.map(p => p.isAllowedInBattle() ? p.getLuck() : 0) .reduce((total: integer, value: integer) => total += value, 0), 0, 14); - return luck || 0; + return luck ?? 0; } export function getLuckString(luckValue: integer): string { diff --git a/src/modifier/modifier.ts b/src/modifier/modifier.ts index 0c4d2a63802..5e5246269a3 100644 --- a/src/modifier/modifier.ts +++ b/src/modifier/modifier.ts @@ -1,34 +1,38 @@ -import * as ModifierTypes from "./modifier-type"; -import BattleScene from "../battle-scene"; -import { getLevelTotalExp } from "../data/exp"; -import { MAX_PER_TYPE_POKEBALLS, PokeballType } from "../data/pokeball"; -import Pokemon, { PlayerPokemon } from "../field/pokemon"; -import { addTextObject, TextStyle } from "../ui/text"; -import { Type } from "../data/type"; -import { EvolutionPhase } from "../phases/evolution-phase"; -import { FusionSpeciesFormEvolution, pokemonEvolutions, pokemonPrevolutions } from "../data/pokemon-evolutions"; -import { getPokemonNameWithAffix } from "../messages"; -import * as Utils from "../utils"; -import { getBerryEffectFunc, getBerryPredicate } from "../data/berry"; -import { BattlerTagType } from "#enums/battler-tag-type"; -import { BerryType } from "#enums/berry-type"; -import { StatusEffect, getStatusEffectHealText } from "../data/status-effect"; -import { achvs } from "../system/achv"; -import { VoucherType } from "../system/voucher"; -import { FormChangeItem, SpeciesFormChangeItemTrigger, SpeciesFormChangeLapseTeraTrigger, SpeciesFormChangeTeraTrigger } from "../data/pokemon-forms"; -import { Nature } from "#app/data/nature"; -import Overrides from "#app/overrides"; -import { ModifierType, modifierTypes } from "./modifier-type"; -import { Command } from "#app/ui/command-ui-handler"; -import { Species } from "#enums/species"; -import { Stat, type PermanentStat, type TempBattleStat, BATTLE_STATS, TEMP_BATTLE_STATS } from "#app/enums/stat"; -import i18next from "i18next"; - +import type BattleScene from "#app/battle-scene"; +import { FusionSpeciesFormEvolution, pokemonEvolutions } from "#app/data/balance/pokemon-evolutions"; +import { getBerryEffectFunc, getBerryPredicate } from "#app/data/berry"; +import { getLevelTotalExp } from "#app/data/exp"; import { allMoves } from "#app/data/move"; -import { Abilities } from "#app/enums/abilities"; -import { LearnMovePhase } from "#app/phases/learn-move-phase"; +import { MAX_PER_TYPE_POKEBALLS } from "#app/data/pokeball"; +import { type FormChangeItem, SpeciesFormChangeItemTrigger, SpeciesFormChangeLapseTeraTrigger, SpeciesFormChangeTeraTrigger } from "#app/data/pokemon-forms"; +import { getStatusEffectHealText } from "#app/data/status-effect"; +import Pokemon, { type PlayerPokemon } from "#app/field/pokemon"; +import { getPokemonNameWithAffix } from "#app/messages"; +import Overrides from "#app/overrides"; +import { EvolutionPhase } from "#app/phases/evolution-phase"; +import { LearnMovePhase, LearnMoveType } from "#app/phases/learn-move-phase"; import { LevelUpPhase } from "#app/phases/level-up-phase"; import { PokemonHealPhase } from "#app/phases/pokemon-heal-phase"; +import { achvs } from "#app/system/achv"; +import type { VoucherType } from "#app/system/voucher"; +import { Command } from "#app/ui/command-ui-handler"; +import { addTextObject, TextStyle } from "#app/ui/text"; +import { BooleanHolder, hslToHex, isNullOrUndefined, NumberHolder, toDmgValue } from "#app/utils"; +import { Abilities } from "#enums/abilities"; +import { BattlerTagType } from "#enums/battler-tag-type"; +import { BerryType } from "#enums/berry-type"; +import { Moves } from "#enums/moves"; +import type { Nature } from "#enums/nature"; +import type { PokeballType } from "#enums/pokeball"; +import { Species } from "#enums/species"; +import { type PermanentStat, type TempBattleStat, BATTLE_STATS, Stat, TEMP_BATTLE_STATS } from "#enums/stat"; +import { StatusEffect } from "#enums/status-effect"; +import { Type } from "#enums/type"; +import i18next from "i18next"; +import { type DoubleBattleChanceBoosterModifierType, type EvolutionItemModifierType, type FormChangeItemModifierType, type ModifierOverride, type ModifierType, type PokemonBaseStatTotalModifierType, type PokemonExpBoosterModifierType, type PokemonFriendshipBoosterModifierType, type PokemonMoveAccuracyBoosterModifierType, type PokemonMultiHitModifierType, type TerastallizeModifierType, type TmModifierType, getModifierType, ModifierPoolType, ModifierTypeGenerator, modifierTypes, PokemonHeldItemModifierType } from "./modifier-type"; +import { Color, ShadowColor } from "#enums/color"; +import { FRIENDSHIP_GAIN_FROM_RARE_CANDY } from "#app/data/balance/starters"; +import { applyAbAttrs, CommanderAbAttr } from "#app/data/ability"; export type ModifierPredicate = (modifier: Modifier) => boolean; @@ -85,7 +89,7 @@ export class ModifierBar extends Phaser.GameObjects.Container { const thisArg = this; - sortedVisibleIconModifiers.forEach((modifier: PersistentModifier, i: integer) => { + sortedVisibleIconModifiers.forEach((modifier: PersistentModifier, i: number) => { const icon = modifier.getIcon(this.scene as BattleScene); if (i >= iconOverflowIndex) { icon.setVisible(false); @@ -121,8 +125,8 @@ export class ModifierBar extends Phaser.GameObjects.Container { } } - setModifierIconPosition(icon: Phaser.GameObjects.Container, modifierCount: integer) { - const rowIcons: integer = 12 + 6 * Math.max((Math.ceil(Math.min(modifierCount, 24) / 12) - 2), 0); + setModifierIconPosition(icon: Phaser.GameObjects.Container, modifierCount: number) { + const rowIcons: number = 12 + 6 * Math.max((Math.ceil(Math.min(modifierCount, 24) / 12) - 2), 0); const x = (this.getIndex(icon) % rowIcons) * 26 / (rowIcons / 12); const y = Math.floor(this.getIndex(icon) / rowIcons) * 20; @@ -142,18 +146,27 @@ export abstract class Modifier { return false; } - shouldApply(_args: any[]): boolean { + /** + * Checks if {@linkcode Modifier} should be applied + * @param _args parameters passed to {@linkcode Modifier.apply} + * @returns always `true` by default + */ + shouldApply(..._args: Parameters): boolean { return true; } - abstract apply(args: any[]): boolean | Promise; + /** + * Handles applying of {@linkcode Modifier} + * @param args collection of all passed parameters + */ + abstract apply(...args: unknown[]): boolean | Promise; } export abstract class PersistentModifier extends Modifier { - public stackCount: integer; - public virtualStackCount: integer; + public stackCount: number; + public virtualStackCount: number; - constructor(type: ModifierType, stackCount?: integer) { + constructor(type: ModifierType, stackCount?: number) { super(type); this.stackCount = stackCount === undefined ? 1 : stackCount; this.virtualStackCount = 0; @@ -180,7 +193,7 @@ export abstract class PersistentModifier extends Modifier { return []; } - incrementStack(scene: BattleScene, amount: integer, virtual: boolean): boolean { + incrementStack(scene: BattleScene, amount: number, virtual: boolean): boolean { if (this.getStackCount() + amount <= this.getMaxStackCount(scene)) { if (!virtual) { this.stackCount += amount; @@ -193,11 +206,11 @@ export abstract class PersistentModifier extends Modifier { return false; } - getStackCount(): integer { + getStackCount(): number { return this.stackCount + this.virtualStackCount; } - abstract getMaxStackCount(scene: BattleScene, forThreshold?: boolean): integer; + abstract getMaxStackCount(scene: BattleScene, forThreshold?: boolean): number; isIconVisible(scene: BattleScene): boolean { return true; @@ -248,25 +261,26 @@ export abstract class ConsumableModifier extends Modifier { add(_modifiers: Modifier[]): boolean { return true; } - - shouldApply(args: any[]): boolean { - return super.shouldApply(args) && args.length === 1 && args[0] instanceof BattleScene; - } } export class AddPokeballModifier extends ConsumableModifier { private pokeballType: PokeballType; - private count: integer; + private count: number; - constructor(type: ModifierType, pokeballType: PokeballType, count: integer) { + constructor(type: ModifierType, pokeballType: PokeballType, count: number) { super(type); this.pokeballType = pokeballType; this.count = count; } - apply(args: any[]): boolean { - const pokeballCounts = (args[0] as BattleScene).pokeballCounts; + /** + * Applies {@linkcode AddPokeballModifier} + * @param battleScene {@linkcode BattleScene} + * @returns always `true` + */ + override apply(battleScene: BattleScene): boolean { + const pokeballCounts = battleScene.pokeballCounts; pokeballCounts[this.pokeballType] = Math.min(pokeballCounts[this.pokeballType] + this.count, MAX_PER_TYPE_POKEBALLS); return true; @@ -275,17 +289,22 @@ export class AddPokeballModifier extends ConsumableModifier { export class AddVoucherModifier extends ConsumableModifier { private voucherType: VoucherType; - private count: integer; + private count: number; - constructor(type: ModifierType, voucherType: VoucherType, count: integer) { + constructor(type: ModifierType, voucherType: VoucherType, count: number) { super(type); this.voucherType = voucherType; this.count = count; } - apply(args: any[]): boolean { - const voucherCounts = (args[0] as BattleScene).gameData.voucherCounts; + /** + * Applies {@linkcode AddVoucherModifier} + * @param battleScene {@linkcode BattleScene} + * @returns always `true` + */ + override apply(battleScene: BattleScene): boolean { + const voucherCounts = battleScene.gameData.voucherCounts; voucherCounts[this.voucherType] += this.count; return true; @@ -309,7 +328,7 @@ export abstract class LapsingPersistentModifier extends PersistentModifier { /** The current amount of battles the modifier will exist for */ private battleCount: number; - constructor(type: ModifierTypes.ModifierType, maxBattles: number, battleCount?: number, stackCount?: integer) { + constructor(type: ModifierType, maxBattles: number, battleCount?: number, stackCount?: number) { super(type, stackCount); this.maxBattles = maxBattles; @@ -323,7 +342,7 @@ export abstract class LapsingPersistentModifier extends PersistentModifier { * @param modifiers {@linkcode PersistentModifier} array of the player's modifiers * @param _virtual N/A * @param _scene N/A - * @returns true if the modifier was successfully added or applied, false otherwise + * @returns `true` if the modifier was successfully added or applied, false otherwise */ add(modifiers: PersistentModifier[], _virtual: boolean, scene: BattleScene): boolean { for (const modifier of modifiers) { @@ -343,7 +362,12 @@ export abstract class LapsingPersistentModifier extends PersistentModifier { return true; } - lapse(_args: any[]): boolean { + /** + * Lapses the {@linkcode battleCount} by 1. + * @param _args passed arguments (not in use here) + * @returns `true` if the {@linkcode battleCount} is greater than 0 + */ + public lapse(..._args: unknown[]): boolean { this.battleCount--; return this.battleCount > 0; } @@ -355,10 +379,13 @@ export abstract class LapsingPersistentModifier extends PersistentModifier { const hue = Math.floor(120 * (this.battleCount / this.maxBattles) + 5); // Generates the color hex code with a constant saturation and lightness but varying hue - const typeHex = Utils.hslToHex(hue, 0.50, 0.90); - const strokeHex = Utils.hslToHex(hue, 0.70, 0.30); + const typeHex = hslToHex(hue, 0.5, 0.9); + const strokeHex = hslToHex(hue, 0.7, 0.3); - const battleCountText = addTextObject(scene, 27, 0, this.battleCount.toString(), TextStyle.PARTY, { fontSize: "66px", color: typeHex }); + const battleCountText = addTextObject(scene, 27, 0, this.battleCount.toString(), TextStyle.PARTY, { + fontSize: "66px", + color: typeHex, + }); battleCountText.setShadow(0, 0); battleCountText.setStroke(strokeHex, 16); battleCountText.setOrigin(1, 0); @@ -379,6 +406,14 @@ export abstract class LapsingPersistentModifier extends PersistentModifier { this.battleCount = this.maxBattles; } + /** + * Updates an existing modifier with a new `maxBattles` and `battleCount`. + */ + setNewBattleCount(count: number): void { + this.maxBattles = count; + this.battleCount = count; + } + getMaxBattles(): number { return this.maxBattles; } @@ -400,7 +435,9 @@ export abstract class LapsingPersistentModifier extends PersistentModifier { * @see {@linkcode apply} */ export class DoubleBattleChanceBoosterModifier extends LapsingPersistentModifier { - constructor(type: ModifierType, maxBattles:number, battleCount?: number, stackCount?: integer) { + public override type: DoubleBattleChanceBoosterModifierType; + + constructor(type: ModifierType, maxBattles:number, battleCount?: number, stackCount?: number) { super(type, maxBattles, battleCount, stackCount); } @@ -409,19 +446,18 @@ export class DoubleBattleChanceBoosterModifier extends LapsingPersistentModifier } clone(): DoubleBattleChanceBoosterModifier { - return new DoubleBattleChanceBoosterModifier(this.type as ModifierTypes.DoubleBattleChanceBoosterModifierType, this.getMaxBattles(), this.getBattleCount(), this.stackCount); + return new DoubleBattleChanceBoosterModifier(this.type, this.getMaxBattles(), this.getBattleCount(), this.stackCount); } /** - * Modifies the chance of a double battle occurring - * @param args [0] {@linkcode Utils.NumberHolder} for double battle chance - * @returns true if the modifier was applied + * Increases the chance of a double battle occurring + * @param doubleBattleChance {@linkcode NumberHolder} for double battle chance + * @returns true */ - apply(args: any[]): boolean { - const doubleBattleChance = args[0] as Utils.NumberHolder; - // This is divided because the chance is generated as a number from 0 to doubleBattleChance.value using Utils.randSeedInt + override apply(doubleBattleChance: NumberHolder): boolean { + // This is divided because the chance is generated as a number from 0 to doubleBattleChance.value using randSeedInt // A double battle will initiate if the generated number is 0 - doubleBattleChance.value = Math.ceil(doubleBattleChance.value / 4); + doubleBattleChance.value = doubleBattleChance.value / 4; return true; } @@ -468,21 +504,21 @@ export class TempStatStageBoosterModifier extends LapsingPersistentModifier { /** * Checks if {@linkcode args} contains the necessary elements and if the * incoming stat is matches {@linkcode stat}. - * @param args [0] {@linkcode TempBattleStat} being checked at the time - * [1] {@linkcode Utils.NumberHolder} N/A - * @returns true if the modifier can be applied, false otherwise + * @param tempBattleStat {@linkcode TempBattleStat} being affected + * @param statLevel {@linkcode NumberHolder} that holds the resulting value of the stat stage multiplier + * @returns `true` if the modifier can be applied, false otherwise */ - shouldApply(args: any[]): boolean { - return args && (args.length === 2) && TEMP_BATTLE_STATS.includes(args[0]) && (args[0] === this.stat) && (args[1] instanceof Utils.NumberHolder); + override shouldApply(tempBattleStat?: TempBattleStat, statLevel?: NumberHolder): boolean { + return !!tempBattleStat && !!statLevel && TEMP_BATTLE_STATS.includes(tempBattleStat) && (tempBattleStat === this.stat); } /** * Increases the incoming stat stage matching {@linkcode stat} by {@linkcode boost}. - * @param args [0] {@linkcode TempBattleStat} N/A - * [1] {@linkcode Utils.NumberHolder} that holds the resulting value of the stat stage multiplier + * @param _tempBattleStat {@linkcode TempBattleStat} N/A + * @param statLevel {@linkcode NumberHolder} that holds the resulting value of the stat stage multiplier */ - apply(args: any[]): boolean { - (args[1] as Utils.NumberHolder).value += this.boost; + override apply(_tempBattleStat: TempBattleStat, statLevel: NumberHolder): boolean { + statLevel.value += this.boost; return true; } } @@ -508,26 +544,26 @@ export class TempCritBoosterModifier extends LapsingPersistentModifier { /** * Checks if {@linkcode args} contains the necessary elements. - * @param args [1] {@linkcode Utils.NumberHolder} N/A - * @returns true if the critical-hit stage boost applies successfully + * @param critLevel {@linkcode NumberHolder} that holds the resulting critical-hit level + * @returns `true` if the critical-hit stage boost applies successfully */ - shouldApply(args: any[]): boolean { - return args && (args.length === 1) && (args[0] instanceof Utils.NumberHolder); + override shouldApply(critLevel?: NumberHolder): boolean { + return !!critLevel; } /** * Increases the current critical-hit stage value by 1. - * @param args [0] {@linkcode Utils.IntegerHolder} that holds the resulting critical-hit level - * @returns true if the critical-hit stage boost applies successfully + * @param critLevel {@linkcode NumberHolder} that holds the resulting critical-hit level + * @returns `true` if the critical-hit stage boost applies successfully */ - apply(args: any[]): boolean { - (args[0] as Utils.NumberHolder).value++; + override apply(critLevel: NumberHolder): boolean { + critLevel.value++; return true; } } export class MapModifier extends PersistentModifier { - constructor(type: ModifierType, stackCount?: integer) { + constructor(type: ModifierType, stackCount?: number) { super(type, stackCount); } @@ -535,17 +571,17 @@ export class MapModifier extends PersistentModifier { return new MapModifier(this.type, this.stackCount); } - apply(args: any[]): boolean { + override apply(..._args: unknown[]): boolean { return true; } - getMaxStackCount(scene: BattleScene): integer { + getMaxStackCount(scene: BattleScene): number { return 1; } } export class MegaEvolutionAccessModifier extends PersistentModifier { - constructor(type: ModifierType, stackCount?: integer) { + constructor(type: ModifierType, stackCount?: number) { super(type, stackCount); } @@ -553,17 +589,17 @@ export class MegaEvolutionAccessModifier extends PersistentModifier { return new MegaEvolutionAccessModifier(this.type, this.stackCount); } - apply(args: any[]): boolean { + override apply(..._args: unknown[]): boolean { return true; } - getMaxStackCount(scene: BattleScene): integer { + getMaxStackCount(scene: BattleScene): number { return 1; } } export class GigantamaxAccessModifier extends PersistentModifier { - constructor(type: ModifierType, stackCount?: integer) { + constructor(type: ModifierType, stackCount?: number) { super(type, stackCount); } @@ -571,17 +607,22 @@ export class GigantamaxAccessModifier extends PersistentModifier { return new GigantamaxAccessModifier(this.type, this.stackCount); } - apply(args: any[]): boolean { + /** + * Applies {@linkcode GigantamaxAccessModifier} + * @param _args N/A + * @returns always `true` + */ + apply(..._args: unknown[]): boolean { return true; } - getMaxStackCount(scene: BattleScene): integer { + getMaxStackCount(scene: BattleScene): number { return 1; } } export class TerastallizeAccessModifier extends PersistentModifier { - constructor(type: ModifierType, stackCount?: integer) { + constructor(type: ModifierType, stackCount?: number) { super(type, stackCount); } @@ -589,20 +630,25 @@ export class TerastallizeAccessModifier extends PersistentModifier { return new TerastallizeAccessModifier(this.type, this.stackCount); } - apply(args: any[]): boolean { + /** + * Applies {@linkcode TerastallizeAccessModifier} + * @param _args N/A + * @returns always `true` + */ + override apply(..._args: unknown[]): boolean { return true; } - getMaxStackCount(scene: BattleScene): integer { + getMaxStackCount(scene: BattleScene): number { return 1; } } export abstract class PokemonHeldItemModifier extends PersistentModifier { - public pokemonId: integer; - readonly isTransferrable: boolean = true; + public pokemonId: number; + public isTransferable: boolean = true; - constructor(type: ModifierType, pokemonId: integer, stackCount?: integer) { + constructor(type: ModifierType, pokemonId: number, stackCount?: number) { super(type, stackCount); this.pokemonId = pokemonId; @@ -618,8 +664,21 @@ export abstract class PokemonHeldItemModifier extends PersistentModifier { return [ this.pokemonId ]; } - shouldApply(args: any[]): boolean { - return super.shouldApply(args) && args.length !== 0 && args[0] instanceof Pokemon && (this.pokemonId === -1 || (args[0] as Pokemon).id === this.pokemonId); + /** + * Applies the {@linkcode PokemonHeldItemModifier} to the given {@linkcode Pokemon}. + * @param pokemon The {@linkcode Pokemon} that holds the held item + * @param args additional parameters + */ + abstract override apply(pokemon: Pokemon, ...args: unknown[]): boolean; + + /** + * Checks if {@linkcode PokemonHeldItemModifier} should be applied. + * @param pokemon The {@linkcode Pokemon} that holds the item + * @param _args N/A + * @returns if {@linkcode PokemonHeldItemModifier} should be applied + */ + override shouldApply(pokemon?: Pokemon, ..._args: unknown[]): boolean { + return !!pokemon && (this.pokemonId === -1 || pokemon.id === this.pokemonId); } isIconVisible(scene: BattleScene): boolean { @@ -668,12 +727,12 @@ export abstract class PokemonHeldItemModifier extends PersistentModifier { } //Applies to items with chance of activating secondary effects ie Kings Rock - getSecondaryChanceMultiplier(pokemon: Pokemon): integer { + getSecondaryChanceMultiplier(pokemon: Pokemon): number { // Temporary quickfix to stop game from freezing when the opponet uses u-turn while holding on to king's rock - if (!pokemon.getLastXMoves(0)[0]) { + if (!pokemon.getLastXMoves()[0]) { return 1; } - const sheerForceAffected = allMoves[pokemon.getLastXMoves(0)[0].move].chance >= 0 && pokemon.hasAbility(Abilities.SHEER_FORCE); + const sheerForceAffected = allMoves[pokemon.getLastXMoves()[0].move].chance >= 0 && pokemon.hasAbility(Abilities.SHEER_FORCE); if (sheerForceAffected) { return 0; @@ -683,41 +742,52 @@ export abstract class PokemonHeldItemModifier extends PersistentModifier { return 1; } - getMaxStackCount(scene: BattleScene, forThreshold?: boolean): integer { + getMaxStackCount(scene: BattleScene, forThreshold?: boolean): number { const pokemon = this.getPokemon(scene); if (!pokemon) { return 0; } if (pokemon.isPlayer() && forThreshold) { - return scene.getParty().map(p => this.getMaxHeldItemCount(p)).reduce((stackCount: integer, maxStackCount: integer) => Math.max(stackCount, maxStackCount), 0); + return scene.getPlayerParty().map(p => this.getMaxHeldItemCount(p)).reduce((stackCount: number, maxStackCount: number) => Math.max(stackCount, maxStackCount), 0); } return this.getMaxHeldItemCount(pokemon); } - abstract getMaxHeldItemCount(pokemon?: Pokemon): integer; + abstract getMaxHeldItemCount(pokemon?: Pokemon): number; } export abstract class LapsingPokemonHeldItemModifier extends PokemonHeldItemModifier { - protected battlesLeft: integer; - readonly isTransferrable: boolean = false; + protected battlesLeft: number; + public isTransferable: boolean = false; - constructor(type: ModifierTypes.ModifierType, pokemonId: integer, battlesLeft?: integer, stackCount?: integer) { + constructor(type: ModifierType, pokemonId: number, battlesLeft?: number, stackCount?: number) { super(type, pokemonId, stackCount); this.battlesLeft = battlesLeft!; // TODO: is this bang correct? } - lapse(args: any[]): boolean { + /** + * Lapse the {@linkcode battlesLeft} counter (reduce it by 1) + * @param _args arguments passed (not used here) + * @returns `true` if {@linkcode battlesLeft} is not null + */ + public lapse(..._args: unknown[]): boolean { return !!--this.battlesLeft; } - getIcon(scene: BattleScene, forSummary?: boolean): Phaser.GameObjects.Container { + /** + * Retrieve the {@linkcode Modifier | Modifiers} icon as a {@linkcode Phaser.GameObjects.Container | Container} + * @param scene The {@linkcode BattleScene} + * @param forSummary `true` if the icon is for the summary screen + * @returns the icon as a {@linkcode Phaser.GameObjects.Container | Container} + */ + public getIcon(scene: BattleScene, forSummary?: boolean): Phaser.GameObjects.Container { const container = super.getIcon(scene, forSummary); if (this.getPokemon(scene)?.isPlayer()) { - const battleCountText = addTextObject(scene, 27, 0, this.battlesLeft.toString(), TextStyle.PARTY, { fontSize: "66px", color: "#f89890" }); + const battleCountText = addTextObject(scene, 27, 0, this.battlesLeft.toString(), TextStyle.PARTY, { fontSize: "66px", color: Color.PINK }); battleCountText.setShadow(0, 0); - battleCountText.setStroke("#984038", 16); + battleCountText.setStroke(ShadowColor.RED, 16); battleCountText.setOrigin(1, 0); container.add(battleCountText); } @@ -725,7 +795,7 @@ export abstract class LapsingPokemonHeldItemModifier extends PokemonHeldItemModi return container; } - getBattlesLeft(): integer { + getBattlesLeft(): number { return this.battlesLeft; } @@ -735,10 +805,11 @@ export abstract class LapsingPokemonHeldItemModifier extends PokemonHeldItemModi } export class TerastallizeModifier extends LapsingPokemonHeldItemModifier { + public override type: TerastallizeModifierType; public teraType: Type; - readonly isTransferrable: boolean = false; + public isTransferable: boolean = false; - constructor(type: ModifierTypes.TerastallizeModifierType, pokemonId: integer, teraType: Type, battlesLeft?: integer, stackCount?: integer) { + constructor(type: TerastallizeModifierType, pokemonId: number, teraType: Type, battlesLeft?: number, stackCount?: number) { super(type, pokemonId, battlesLeft || 10, stackCount); this.teraType = teraType; @@ -752,15 +823,19 @@ export class TerastallizeModifier extends LapsingPokemonHeldItemModifier { } clone(): TerastallizeModifier { - return new TerastallizeModifier(this.type as ModifierTypes.TerastallizeModifierType, this.pokemonId, this.teraType, this.battlesLeft, this.stackCount); + return new TerastallizeModifier(this.type, this.pokemonId, this.teraType, this.battlesLeft, this.stackCount); } getArgs(): any[] { return [ this.pokemonId, this.teraType, this.battlesLeft ]; } - apply(args: any[]): boolean { - const pokemon = args[0] as Pokemon; + /** + * Applies the {@linkcode TerastallizeModifier} to the specified {@linkcode Pokemon}. + * @param pokemon the {@linkcode Pokemon} to be terastallized + * @returns always `true` + */ + override apply(pokemon: Pokemon): boolean { if (pokemon.isPlayer()) { pokemon.scene.triggerPokemonFormChange(pokemon, SpeciesFormChangeTeraTrigger); pokemon.scene.validateAchv(achvs.TERASTALLIZE); @@ -772,10 +847,14 @@ export class TerastallizeModifier extends LapsingPokemonHeldItemModifier { return true; } - lapse(args: any[]): boolean { - const ret = super.lapse(args); + /** + * Triggers {@linkcode LapsingPokemonHeldItemModifier.lapse} and if it returns `0` a form change is triggered. + * @param pokemon THe {@linkcode Pokemon} to be terastallized + * @returns the result of {@linkcode LapsingPokemonHeldItemModifier.lapse} + */ + public override lapse(pokemon: Pokemon): boolean { + const ret = super.lapse(pokemon); if (!ret) { - const pokemon = args[0] as Pokemon; pokemon.scene.triggerPokemonFormChange(pokemon, SpeciesFormChangeLapseTeraTrigger); pokemon.updateSpritePipelineData(); } @@ -786,7 +865,7 @@ export class TerastallizeModifier extends LapsingPokemonHeldItemModifier { return 1.25; } - getMaxHeldItemCount(pokemon: Pokemon): integer { + getMaxHeldItemCount(pokemon: Pokemon): number { return 1; } } @@ -799,9 +878,9 @@ export class TerastallizeModifier extends LapsingPokemonHeldItemModifier { */ export class BaseStatModifier extends PokemonHeldItemModifier { protected stat: PermanentStat; - readonly isTransferrable: boolean = false; + public isTransferable: boolean = false; - constructor(type: ModifierType, pokemonId: integer, stat: PermanentStat, stackCount?: integer) { + constructor(type: ModifierType, pokemonId: number, stat: PermanentStat, stackCount?: number) { super(type, pokemonId, stackCount); this.stat = stat; } @@ -821,12 +900,23 @@ export class BaseStatModifier extends PokemonHeldItemModifier { return super.getArgs().concat(this.stat); } - shouldApply(args: any[]): boolean { - return super.shouldApply(args) && args.length === 2 && Array.isArray(args[1]); + /** + * Checks if {@linkcode BaseStatModifier} should be applied to the specified {@linkcode Pokemon}. + * @param _pokemon the {@linkcode Pokemon} to be modified + * @param baseStats the base stats of the {@linkcode Pokemon} + * @returns `true` if the {@linkcode Pokemon} should be modified + */ + override shouldApply(_pokemon?: Pokemon, baseStats?: number[]): boolean { + return super.shouldApply(_pokemon, baseStats) && Array.isArray(baseStats); } - apply(args: any[]): boolean { - const baseStats = args[1] as number[]; + /** + * Applies the {@linkcode BaseStatModifier} to the specified {@linkcode Pokemon}. + * @param _pokemon the {@linkcode Pokemon} to be modified + * @param baseStats the base stats of the {@linkcode Pokemon} + * @returns always `true` + */ + override apply(_pokemon: Pokemon, baseStats: number[]): boolean { baseStats[this.stat] = Math.floor(baseStats[this.stat] * (1 + this.getStackCount() * 0.1)); return true; } @@ -835,43 +925,68 @@ export class BaseStatModifier extends PokemonHeldItemModifier { return 1.1; } - getMaxHeldItemCount(pokemon: Pokemon): integer { + getMaxHeldItemCount(pokemon: Pokemon): number { return pokemon.ivs[this.stat]; } } export class EvoTrackerModifier extends PokemonHeldItemModifier { protected species: Species; - protected required: integer; - readonly isTransferrable: boolean = false; + protected required: number; + public isTransferable: boolean = false; - constructor(type: ModifierType, pokemonId: integer, species: Species, required: integer, stackCount?: integer) { + constructor(type: ModifierType, pokemonId: number, species: Species, required: number, stackCount?: number) { super(type, pokemonId, stackCount); this.species = species; this.required = required; } matchType(modifier: Modifier): boolean { - if (modifier instanceof EvoTrackerModifier) { - return (modifier as EvoTrackerModifier).species === this.species; - } - return false; + return modifier instanceof EvoTrackerModifier && modifier.species === this.species && modifier.required === this.required; } clone(): PersistentModifier { - return new EvoTrackerModifier(this.type, this.pokemonId, this.species, this.stackCount); + return new EvoTrackerModifier(this.type, this.pokemonId, this.species, this.required, this.stackCount); } getArgs(): any[] { - return super.getArgs().concat(this.species); + return super.getArgs().concat([ this.species, this.required ]); } - apply(args: any[]): boolean { + /** + * Applies the {@linkcode EvoTrackerModifier} + * @returns always `true` + */ + override apply(): boolean { return true; } - getMaxHeldItemCount(_pokemon: Pokemon): integer { - return this.required; + getIconStackText(scene: BattleScene, virtual?: boolean): Phaser.GameObjects.BitmapText | null { + if (this.getMaxStackCount(scene) === 1 || (virtual && !this.virtualStackCount)) { + return null; + } + + const pokemon = scene.getPokemonById(this.pokemonId); + + this.stackCount = pokemon + ? pokemon.evoCounter + pokemon.getHeldItems().filter(m => m instanceof DamageMoneyRewardModifier).length + + pokemon.scene.findModifiers(m => m instanceof MoneyMultiplierModifier || m instanceof ExtraModifierModifier || m instanceof TempExtraModifierModifier).length + : this.stackCount; + + const text = scene.add.bitmapText(10, 15, "item-count", this.stackCount.toString(), 11); + text.letterSpacing = -0.5; + if (this.getStackCount() >= this.required) { + text.setTint(0xf89890); + } + text.setOrigin(0, 0); + + return text; + } + + getMaxHeldItemCount(pokemon: Pokemon): number { + this.stackCount = pokemon.evoCounter + pokemon.getHeldItems().filter(m => m instanceof DamageMoneyRewardModifier).length + + pokemon.scene.findModifiers(m => m instanceof MoneyMultiplierModifier || m instanceof ExtraModifierModifier || m instanceof TempExtraModifierModifier).length; + return 999; } } @@ -879,36 +994,50 @@ export class EvoTrackerModifier extends PokemonHeldItemModifier { * Currently used by Shuckle Juice item */ export class PokemonBaseStatTotalModifier extends PokemonHeldItemModifier { - private statModifier: integer; - readonly isTransferrable: boolean = false; + public override type: PokemonBaseStatTotalModifierType; + public isTransferable: boolean = false; - constructor(type: ModifierTypes.PokemonBaseStatTotalModifierType, pokemonId: integer, statModifier: integer, stackCount?: integer) { + private statModifier: number; + + constructor(type: PokemonBaseStatTotalModifierType, pokemonId: number, statModifier: number, stackCount?: number) { super(type, pokemonId, stackCount); this.statModifier = statModifier; } override matchType(modifier: Modifier): boolean { - return modifier instanceof PokemonBaseStatTotalModifier; + return modifier instanceof PokemonBaseStatTotalModifier && this.statModifier === modifier.statModifier; } override clone(): PersistentModifier { - return new PokemonBaseStatTotalModifier(this.type as ModifierTypes.PokemonBaseStatTotalModifierType, this.pokemonId, this.statModifier, this.stackCount); + return new PokemonBaseStatTotalModifier(this.type, this.pokemonId, this.statModifier, this.stackCount); } override getArgs(): any[] { return super.getArgs().concat(this.statModifier); } - override shouldApply(args: any[]): boolean { - return super.shouldApply(args) && args.length === 2 && args[1] instanceof Array; + /** + * Checks if {@linkcode PokemonBaseStatTotalModifier} should be applied to the specified {@linkcode Pokemon}. + * @param pokemon the {@linkcode Pokemon} to be modified + * @param baseStats the base stats of the {@linkcode Pokemon} + * @returns `true` if the {@linkcode Pokemon} should be modified + */ + override shouldApply(pokemon?: Pokemon, baseStats?: number[]): boolean { + return super.shouldApply(pokemon, baseStats) && Array.isArray(baseStats); } - override apply(args: any[]): boolean { + /** + * Applies the {@linkcode PokemonBaseStatTotalModifier} + * @param _pokemon the {@linkcode Pokemon} to be modified + * @param baseStats the base stats of the {@linkcode Pokemon} + * @returns always `true` + */ + override apply(_pokemon: Pokemon, baseStats: number[]): boolean { // Modifies the passed in baseStats[] array - args[1].forEach((v, i) => { + baseStats.forEach((v, i) => { // HP is affected by half as much as other stats const newVal = i === 0 ? Math.floor(v + this.statModifier / 2) : Math.floor(v + this.statModifier); - args[1][i] = Math.min(Math.max(newVal, 1), 999999); + baseStats[i] = Math.min(Math.max(newVal, 1), 999999); }); return true; @@ -918,7 +1047,7 @@ export class PokemonBaseStatTotalModifier extends PokemonHeldItemModifier { return 1.2; } - override getMaxHeldItemCount(pokemon: Pokemon): integer { + override getMaxHeldItemCount(pokemon: Pokemon): number { return 2; } } @@ -927,11 +1056,11 @@ export class PokemonBaseStatTotalModifier extends PokemonHeldItemModifier { * Currently used by Old Gateau item */ export class PokemonBaseStatFlatModifier extends PokemonHeldItemModifier { - private statModifier: integer; + private statModifier: number; private stats: Stat[]; - readonly isTransferrable: boolean = false; + public isTransferable: boolean = false; - constructor (type: ModifierType, pokemonId: integer, statModifier: integer, stats: Stat[], stackCount?: integer) { + constructor (type: ModifierType, pokemonId: number, statModifier: number, stats: Stat[], stackCount?: number) { super(type, pokemonId, stackCount); this.statModifier = statModifier; @@ -939,7 +1068,7 @@ export class PokemonBaseStatFlatModifier extends PokemonHeldItemModifier { } override matchType(modifier: Modifier): boolean { - return modifier instanceof PokemonBaseStatFlatModifier; + return modifier instanceof PokemonBaseStatFlatModifier && modifier.statModifier === this.statModifier && this.stats.every(s => modifier.stats.some(stat => s === stat)); } override clone(): PersistentModifier { @@ -947,19 +1076,31 @@ export class PokemonBaseStatFlatModifier extends PokemonHeldItemModifier { } override getArgs(): any[] { - return super.getArgs().concat(this.statModifier, this.stats); + return [ ...super.getArgs(), this.statModifier, this.stats ]; } - override shouldApply(args: any[]): boolean { - return super.shouldApply(args) && args.length === 2 && args[1] instanceof Array; + /** + * Checks if the {@linkcode PokemonBaseStatFlatModifier} should be applied to the {@linkcode Pokemon}. + * @param pokemon The {@linkcode Pokemon} that holds the item + * @param baseStats The base stats of the {@linkcode Pokemon} + * @returns `true` if the {@linkcode PokemonBaseStatFlatModifier} should be applied + */ + override shouldApply(pokemon?: Pokemon, baseStats?: number[]): boolean { + return super.shouldApply(pokemon, baseStats) && Array.isArray(baseStats); } - override apply(args: any[]): boolean { + /** + * Applies the {@linkcode PokemonBaseStatFlatModifier} + * @param _pokemon The {@linkcode Pokemon} that holds the item + * @param baseStats The base stats of the {@linkcode Pokemon} + * @returns always `true` + */ + override apply(_pokemon: Pokemon, baseStats: number[]): boolean { // Modifies the passed in baseStats[] array by a flat value, only if the stat is specified in this.stats - args[1].forEach((v, i) => { + baseStats.forEach((v, i) => { if (this.stats.includes(i)) { const newVal = Math.floor(v + this.statModifier); - args[1][i] = Math.min(Math.max(newVal, 1), 999999); + baseStats[i] = Math.min(Math.max(newVal, 1), 999999); } }); @@ -970,7 +1111,7 @@ export class PokemonBaseStatFlatModifier extends PokemonHeldItemModifier { return 1.1; } - override getMaxHeldItemCount(pokemon: Pokemon): integer { + override getMaxHeldItemCount(pokemon: Pokemon): number { return 1; } } @@ -979,9 +1120,9 @@ export class PokemonBaseStatFlatModifier extends PokemonHeldItemModifier { * Currently used by Macho Brace item */ export class PokemonIncrementingStatModifier extends PokemonHeldItemModifier { - readonly isTransferrable: boolean = false; + public isTransferable: boolean = false; - constructor (type: ModifierType, pokemonId: integer, stackCount?: integer) { + constructor (type: ModifierType, pokemonId: number, stackCount?: number) { super(type, pokemonId, stackCount); } @@ -989,30 +1130,48 @@ export class PokemonIncrementingStatModifier extends PokemonHeldItemModifier { return modifier instanceof PokemonIncrementingStatModifier; } - clone(): PersistentModifier { - return new PokemonIncrementingStatModifier(this.type, this.pokemonId); + clone(): PokemonIncrementingStatModifier { + return new PokemonIncrementingStatModifier(this.type, this.pokemonId, this.stackCount); } getArgs(): any[] { return super.getArgs(); } - shouldApply(args: any[]): boolean { - return super.shouldApply(args) && args.length === 2 && args[1] instanceof Array; + /** + * Checks if the {@linkcode PokemonIncrementingStatModifier} should be applied to the {@linkcode Pokemon}. + * @param pokemon The {@linkcode Pokemon} that holds the item + * @param stat The affected {@linkcode Stat} + * @param statHolder The {@linkcode NumberHolder} that holds the stat + * @returns `true` if the {@linkcode PokemonBaseStatFlatModifier} should be applied + */ + override shouldApply(pokemon?: Pokemon, stat?: Stat, statHolder?: NumberHolder): boolean { + return super.shouldApply(pokemon, stat, statHolder) && !!statHolder; } - apply(args: any[]): boolean { - // Modifies the passed in stats[] array by +1 per stack for HP, +2 per stack for other stats + /** + * Applies the {@linkcode PokemonIncrementingStatModifier} + * @param _pokemon The {@linkcode Pokemon} that holds the item + * @param stat The affected {@linkcode Stat} + * @param statHolder The {@linkcode NumberHolder} that holds the stat + * @returns always `true` + */ + override apply(_pokemon: Pokemon, stat: Stat, statHolder: NumberHolder): boolean { + // Modifies the passed in stat number holder by +1 per stack for HP, +2 per stack for other stats // If the Macho Brace is at max stacks (50), adds additional 5% to total HP and 10% to other stats - args[1].forEach((v, i) => { - const isHp = i === 0; - let mult = 1; + const isHp = stat === Stat.HP; + + if (isHp) { + statHolder.value += this.stackCount; if (this.stackCount === this.getMaxHeldItemCount()) { - mult = isHp ? 1.05 : 1.1; + statHolder.value = Math.floor(statHolder.value * 1.05); } - const newVal = Math.floor((v + this.stackCount * (isHp ? 1 : 2)) * mult); - args[1][i] = Math.min(Math.max(newVal, 1), 999999); - }); + } else { + statHolder.value += 2 * this.stackCount; + if (this.stackCount === this.getMaxHeldItemCount()) { + statHolder.value = Math.floor(statHolder.value * 1.1); + } + } return true; } @@ -1021,13 +1180,13 @@ export class PokemonIncrementingStatModifier extends PokemonHeldItemModifier { return 1.2; } - getMaxHeldItemCount(pokemon?: Pokemon): integer { + getMaxHeldItemCount(pokemon?: Pokemon): number { return 50; } } /** - * Modifier used for held items that apply {@linkcode Stat} boost(s) + * Modifier used for held items that Applies {@linkcode Stat} boost(s) * using a multiplier. * @extends PokemonHeldItemModifier * @see {@linkcode apply} @@ -1038,7 +1197,7 @@ export class StatBoosterModifier extends PokemonHeldItemModifier { /** The multiplier used to increase the relevant stat(s) */ protected multiplier: number; - constructor(type: ModifierType, pokemonId: integer, stats: Stat[], multiplier: number, stackCount?: integer) { + constructor(type: ModifierType, pokemonId: number, stats: Stat[], multiplier: number, stackCount?: number) { super(type, pokemonId, stackCount); this.stats = stats; @@ -1066,27 +1225,25 @@ export class StatBoosterModifier extends PokemonHeldItemModifier { /** * Checks if the incoming stat is listed in {@linkcode stats} - * @param args [0] {@linkcode Pokemon} N/A - * [1] {@linkcode Stat} being checked at the time - * [2] {@linkcode Utils.NumberHolder} N/A - * @returns true if the stat could be boosted, false otherwise + * @param _pokemon the {@linkcode Pokemon} that holds the item + * @param _stat the {@linkcode Stat} to be boosted + * @param statValue {@linkcode NumberHolder} that holds the resulting value of the stat + * @returns `true` if the stat could be boosted, false otherwise */ - shouldApply(args: any[]): boolean { - return super.shouldApply(args) && this.stats.includes(args[1] as Stat); + override shouldApply(pokemon: Pokemon, stat: Stat, statValue: NumberHolder): boolean { + return super.shouldApply(pokemon, stat, statValue) && this.stats.includes(stat); } /** * Boosts the incoming stat by a {@linkcode multiplier} if the stat is listed * in {@linkcode stats}. - * @param args [0] {@linkcode Pokemon} N/A - * [1] {@linkcode Stat} N/A - * [2] {@linkcode Utils.NumberHolder} that holds the resulting value of the stat - * @returns true if the stat boost applies successfully, false otherwise + * @param _pokemon the {@linkcode Pokemon} that holds the item + * @param _stat the {@linkcode Stat} to be boosted + * @param statValue {@linkcode NumberHolder} that holds the resulting value of the stat + * @returns `true` if the stat boost applies successfully, false otherwise * @see shouldApply */ - apply(args: any[]): boolean { - const statValue = args[2] as Utils.NumberHolder; - + override apply(_pokemon: Pokemon, _stat: Stat, statValue: NumberHolder): boolean { statValue.value *= this.multiplier; return true; } @@ -1114,39 +1271,37 @@ export class EvolutionStatBoosterModifier extends StatBoosterModifier { /** * Checks if the stat boosts can apply and if the holder is not currently * Gigantamax'd. - * @param args [0] {@linkcode Pokemon} that holds the held item - * [1] {@linkcode Stat} N/A - * [2] {@linkcode Utils.NumberHolder} N/A - * @returns true if the stat boosts can be applied, false otherwise + * @param pokemon {@linkcode Pokemon} that holds the held item + * @param stat {@linkcode Stat} The {@linkcode Stat} to be boosted + * @param statValue {@linkcode NumberHolder} that holds the resulting value of the stat + * @returns `true` if the stat boosts can be applied, false otherwise */ - shouldApply(args: any[]): boolean { - return super.shouldApply(args) && !(args[0] as Pokemon).isMax(); + override shouldApply(pokemon: Pokemon, stat: Stat, statValue: NumberHolder): boolean { + return super.shouldApply(pokemon, stat, statValue) && !pokemon.isMax(); } /** - * Boosts the incoming stat value by a {@linkcode multiplier} if the holder + * Boosts the incoming stat value by a {@linkcode EvolutionStatBoosterModifier.multiplier} if the holder * can evolve. Note that, if the holder is a fusion, they will receive * only half of the boost if either of the fused members are fully * evolved. However, if they are both unevolved, the full boost * will apply. - * @param args [0] {@linkcode Pokemon} that holds the held item - * [1] {@linkcode Stat} N/A - * [2] {@linkcode Utils.NumberHolder} that holds the resulting value of the stat - * @returns true if the stat boost applies successfully, false otherwise + * @param pokemon {@linkcode Pokemon} that holds the item + * @param _stat {@linkcode Stat} The {@linkcode Stat} to be boosted + * @param statValue{@linkcode NumberHolder} that holds the resulting value of the stat + * @returns `true` if the stat boost applies successfully, false otherwise * @see shouldApply */ - apply(args: any[]): boolean { - const holder = args[0] as Pokemon; - const statValue = args[2] as Utils.NumberHolder; - const isUnevolved = holder.getSpeciesForm(true).speciesId in pokemonEvolutions; + override apply(pokemon: Pokemon, stat: Stat, statValue: NumberHolder): boolean { + const isUnevolved = pokemon.getSpeciesForm(true).speciesId in pokemonEvolutions; - if (holder.isFusion() && (holder.getFusionSpeciesForm(true).speciesId in pokemonEvolutions) !== isUnevolved) { - // Half boost applied if holder is fused and either part of fusion is fully evolved + if (pokemon.isFusion() && (pokemon.getFusionSpeciesForm(true).speciesId in pokemonEvolutions) !== isUnevolved) { + // Half boost applied if pokemon is fused and either part of fusion is fully evolved statValue.value *= 1 + (this.multiplier - 1) / 2; return true; } else if (isUnevolved) { // Full boost applied if holder is unfused and unevolved or, if fused, both parts of fusion are unevolved - return super.apply(args); + return super.apply(pokemon, stat, statValue); } return false; @@ -1154,7 +1309,7 @@ export class EvolutionStatBoosterModifier extends StatBoosterModifier { } /** - * Modifier used for held items that apply {@linkcode Stat} boost(s) using a + * Modifier used for held items that Applies {@linkcode Stat} boost(s) using a * multiplier if the holder is of a specific {@linkcode Species}. * @extends StatBoosterModifier * @see {@linkcode apply} @@ -1163,7 +1318,7 @@ export class SpeciesStatBoosterModifier extends StatBoosterModifier { /** The species that the held item's stat boost(s) apply to */ private species: Species[]; - constructor(type: ModifierType, pokemonId: integer, stats: Stat[], multiplier: number, species: Species[], stackCount?: integer) { + constructor(type: ModifierType, pokemonId: number, stats: Stat[], multiplier: number, species: Species[], stackCount?: number) { super(type, pokemonId, stats, multiplier, stackCount); this.species = species; @@ -1191,21 +1346,20 @@ export class SpeciesStatBoosterModifier extends StatBoosterModifier { /** * Checks if the incoming stat is listed in {@linkcode stats} and if the holder's {@linkcode Species} * (or its fused species) is listed in {@linkcode species}. - * @param args [0] {@linkcode Pokemon} that holds the held item - * [1] {@linkcode Stat} being checked at the time - * [2] {@linkcode Utils.NumberHolder} N/A - * @returns true if the stat could be boosted, false otherwise + * @param pokemon {@linkcode Pokemon} that holds the item + * @param stat {@linkcode Stat} being checked at the time + * @param statValue {@linkcode NumberHolder} that holds the resulting value of the stat + * @returns `true` if the stat could be boosted, false otherwise */ - shouldApply(args: any[]): boolean { - const holder = args[0] as Pokemon; - return super.shouldApply(args) && (this.species.includes(holder.getSpeciesForm(true).speciesId) || (holder.isFusion() && this.species.includes(holder.getFusionSpeciesForm(true).speciesId))); + override shouldApply(pokemon: Pokemon, stat: Stat, statValue: NumberHolder): boolean { + return super.shouldApply(pokemon, stat, statValue) && (this.species.includes(pokemon.getSpeciesForm(true).speciesId) || (pokemon.isFusion() && this.species.includes(pokemon.getFusionSpeciesForm(true).speciesId))); } /** * Checks if either parameter is included in the corresponding lists * @param speciesId {@linkcode Species} being checked * @param stat {@linkcode Stat} being checked - * @returns true if both parameters are in {@linkcode species} and {@linkcode stats} respectively, false otherwise + * @returns `true` if both parameters are in {@linkcode species} and {@linkcode stats} respectively, false otherwise */ contains(speciesId: Species, stat: Stat): boolean { return this.species.includes(speciesId) && this.stats.includes(stat); @@ -1221,7 +1375,7 @@ export class CritBoosterModifier extends PokemonHeldItemModifier { /** The amount of stages by which the held item increases the current critical-hit stage value */ protected stageIncrement: number; - constructor(type: ModifierType, pokemonId: integer, stageIncrement: number, stackCount?: integer) { + constructor(type: ModifierType, pokemonId: number, stageIncrement: number, stackCount?: number) { super(type, pokemonId, stackCount); this.stageIncrement = stageIncrement; @@ -1245,13 +1399,11 @@ export class CritBoosterModifier extends PokemonHeldItemModifier { /** * Increases the current critical-hit stage value by {@linkcode stageIncrement}. - * @param args [0] {@linkcode Pokemon} N/A - * [1] {@linkcode Utils.IntegerHolder} that holds the resulting critical-hit level - * @returns true if the critical-hit stage boost applies successfully, false otherwise + * @param _pokemon {@linkcode Pokemon} N/A + * @param critStage {@linkcode NumberHolder} that holds the resulting critical-hit level + * @returns always `true` */ - apply(args: any[]): boolean { - const critStage = args[1] as Utils.NumberHolder; - + override apply(_pokemon: Pokemon, critStage: NumberHolder): boolean { critStage.value += this.stageIncrement; return true; } @@ -1271,7 +1423,7 @@ export class SpeciesCritBoosterModifier extends CritBoosterModifier { /** The species that the held item's critical-hit stage boost applies to */ private species: Species[]; - constructor(type: ModifierType, pokemonId: integer, stageIncrement: number, species: Species[], stackCount?: integer) { + constructor(type: ModifierType, pokemonId: number, stageIncrement: number, species: Species[], stackCount?: number) { super(type, pokemonId, stageIncrement, stackCount); this.species = species; @@ -1292,14 +1444,12 @@ export class SpeciesCritBoosterModifier extends CritBoosterModifier { /** * Checks if the holder's {@linkcode Species} (or its fused species) is listed * in {@linkcode species}. - * @param args [0] {@linkcode Pokemon} that holds the held item - * [1] {@linkcode Utils.IntegerHolder} N/A - * @returns true if the critical-hit level can be incremented, false otherwise + * @param pokemon {@linkcode Pokemon} that holds the held item + * @param critStage {@linkcode NumberHolder} that holds the resulting critical-hit level + * @returns `true` if the critical-hit level can be incremented, false otherwise */ - shouldApply(args: any[]) { - const holder = args[0] as Pokemon; - - return super.shouldApply(args) && (this.species.includes(holder.getSpeciesForm(true).speciesId) || (holder.isFusion() && this.species.includes(holder.getFusionSpeciesForm(true).speciesId))); + override shouldApply(pokemon: Pokemon, critStage: NumberHolder): boolean { + return super.shouldApply(pokemon, critStage) && (this.species.includes(pokemon.getSpeciesForm(true).speciesId) || (pokemon.isFusion() && this.species.includes(pokemon.getFusionSpeciesForm(true).speciesId))); } } @@ -1310,7 +1460,7 @@ export class AttackTypeBoosterModifier extends PokemonHeldItemModifier { public moveType: Type; private boostMultiplier: number; - constructor(type: ModifierType, pokemonId: integer, moveType: Type, boostPercent: number, stackCount?: integer) { + constructor(type: ModifierType, pokemonId: number, moveType: Type, boostPercent: number, stackCount?: number) { super(type, pokemonId, stackCount); this.moveType = moveType; @@ -1334,20 +1484,27 @@ export class AttackTypeBoosterModifier extends PokemonHeldItemModifier { return super.getArgs().concat([ this.moveType, this.boostMultiplier * 100 ]); } - shouldApply(args: any[]): boolean { - return super.shouldApply(args) && args.length === 3 && typeof args[1] === "number" && args[2] instanceof Utils.NumberHolder; + /** + * Checks if {@linkcode AttackTypeBoosterModifier} should be applied + * @param pokemon the {@linkcode Pokemon} that holds the held item + * @param moveType the {@linkcode Type} of the move being used + * @param movePower the {@linkcode NumberHolder} that holds the power of the move + * @returns `true` if boosts should be applied to the move. + */ + override shouldApply(pokemon?: Pokemon, moveType?: Type, movePower?: NumberHolder): boolean { + return super.shouldApply(pokemon, moveType, movePower) && typeof moveType === "number" && movePower instanceof NumberHolder; } /** - * @param {Array} args Array - * - Index 0: {Pokemon} Pokemon - * - Index 1: {number} Move type - * - Index 2: {Utils.NumberHolder} Move power - * @returns {boolean} Returns true if boosts have been applied to the move. - */ - apply(args: any[]): boolean { - if (args[1] === this.moveType && (args[2] as Utils.NumberHolder).value >= 1) { - (args[2] as Utils.NumberHolder).value = Math.floor((args[2] as Utils.NumberHolder).value * (1 + (this.getStackCount() * this.boostMultiplier))); + * Applies {@linkcode AttackTypeBoosterModifier} + * @param pokemon {@linkcode Pokemon} that holds the held item + * @param moveType {@linkcode Type} of the move being used + * @param movePower {@linkcode NumberHolder} that holds the power of the move + * @returns `true` if boosts have been applied to the move. + */ + override apply(_pokemon: Pokemon, moveType: Type, movePower: NumberHolder): boolean { + if (moveType === this.moveType && movePower.value >= 1) { + (movePower as NumberHolder).value = Math.floor((movePower as NumberHolder).value * (1 + (this.getStackCount() * this.boostMultiplier))); return true; } @@ -1358,13 +1515,13 @@ export class AttackTypeBoosterModifier extends PokemonHeldItemModifier { return 1.2; } - getMaxHeldItemCount(pokemon: Pokemon): integer { + getMaxHeldItemCount(pokemon: Pokemon): number { return 99; } } export class SurviveDamageModifier extends PokemonHeldItemModifier { - constructor(type: ModifierType, pokemonId: integer, stackCount?: integer) { + constructor(type: ModifierType, pokemonId: number, stackCount?: number) { super(type, pokemonId, stackCount); } @@ -1376,14 +1533,23 @@ export class SurviveDamageModifier extends PokemonHeldItemModifier { return new SurviveDamageModifier(this.type, this.pokemonId, this.stackCount); } - shouldApply(args: any[]): boolean { - return super.shouldApply(args) && args.length === 2 && args[1] instanceof Utils.BooleanHolder; + /** + * Checks if the {@linkcode SurviveDamageModifier} should be applied + * @param pokemon the {@linkcode Pokemon} that holds the item + * @param surviveDamage {@linkcode BooleanHolder} that holds the survive damage + * @returns `true` if the {@linkcode SurviveDamageModifier} should be applied + */ + override shouldApply(pokemon?: Pokemon, surviveDamage?: BooleanHolder): boolean { + return super.shouldApply(pokemon, surviveDamage) && !!surviveDamage; } - apply(args: any[]): boolean { - const pokemon = args[0] as Pokemon; - const surviveDamage = args[1] as Utils.BooleanHolder; - + /** + * Applies {@linkcode SurviveDamageModifier} + * @param pokemon the {@linkcode Pokemon} that holds the item + * @param surviveDamage {@linkcode BooleanHolder} that holds the survive damage + * @returns `true` if the survive damage has been applied + */ + override apply(pokemon: Pokemon, surviveDamage: BooleanHolder): boolean { if (!surviveDamage.value && pokemon.randSeedInt(10) < this.getStackCount()) { surviveDamage.value = true; @@ -1394,13 +1560,13 @@ export class SurviveDamageModifier extends PokemonHeldItemModifier { return false; } - getMaxHeldItemCount(pokemon: Pokemon): integer { + getMaxHeldItemCount(pokemon: Pokemon): number { return 5; } } export class BypassSpeedChanceModifier extends PokemonHeldItemModifier { - constructor(type: ModifierType, pokemonId: integer, stackCount?: integer) { + constructor(type: ModifierType, pokemonId: number, stackCount?: number) { super(type, pokemonId, stackCount); } @@ -1412,18 +1578,27 @@ export class BypassSpeedChanceModifier extends PokemonHeldItemModifier { return new BypassSpeedChanceModifier(this.type, this.pokemonId, this.stackCount); } - shouldApply(args: any[]): boolean { - return super.shouldApply(args) && args.length === 2 && args[1] instanceof Utils.BooleanHolder; + /** + * Checks if {@linkcode BypassSpeedChanceModifier} should be applied + * @param pokemon the {@linkcode Pokemon} that holds the item + * @param doBypassSpeed {@linkcode BooleanHolder} that is `true` if speed should be bypassed + * @returns `true` if {@linkcode BypassSpeedChanceModifier} should be applied + */ + override shouldApply(pokemon?: Pokemon, doBypassSpeed?: BooleanHolder): boolean { + return super.shouldApply(pokemon, doBypassSpeed) && !!doBypassSpeed; } - apply(args: any[]): boolean { - const pokemon = args[0] as Pokemon; - const bypassSpeed = args[1] as Utils.BooleanHolder; - - if (!bypassSpeed.value && pokemon.randSeedInt(10) < this.getStackCount()) { - bypassSpeed.value = true; + /** + * Applies {@linkcode BypassSpeedChanceModifier} + * @param pokemon the {@linkcode Pokemon} that holds the item + * @param doBypassSpeed {@linkcode BooleanHolder} that is `true` if speed should be bypassed + * @returns `true` if {@linkcode BypassSpeedChanceModifier} has been applied + */ + override apply(pokemon: Pokemon, doBypassSpeed: BooleanHolder): boolean { + if (!doBypassSpeed.value && pokemon.randSeedInt(10) < this.getStackCount()) { + doBypassSpeed.value = true; const isCommandFight = pokemon.scene.currentBattle.turnCommands[pokemon.getBattlerIndex()]?.command === Command.FIGHT; - const hasQuickClaw = this.type instanceof ModifierTypes.PokemonHeldItemModifierType && this.type.id === "QUICK_CLAW"; + const hasQuickClaw = this.type instanceof PokemonHeldItemModifierType && this.type.id === "QUICK_CLAW"; if (isCommandFight && hasQuickClaw) { pokemon.scene.queueMessage(i18next.t("modifier:bypassSpeedChanceApply", { pokemonName: getPokemonNameWithAffix(pokemon), itemName: i18next.t("modifierType:ModifierType.QUICK_CLAW.name") })); @@ -1434,13 +1609,13 @@ export class BypassSpeedChanceModifier extends PokemonHeldItemModifier { return false; } - getMaxHeldItemCount(pokemon: Pokemon): integer { + getMaxHeldItemCount(pokemon: Pokemon): number { return 3; } } export class FlinchChanceModifier extends PokemonHeldItemModifier { - constructor(type: ModifierType, pokemonId: integer, stackCount?: integer) { + constructor(type: ModifierType, pokemonId: number, stackCount?: number) { super(type, pokemonId, stackCount); } @@ -1452,14 +1627,23 @@ export class FlinchChanceModifier extends PokemonHeldItemModifier { return new FlinchChanceModifier(this.type, this.pokemonId, this.stackCount); } - shouldApply(args: any[]): boolean { - return super.shouldApply(args) && args.length === 2 && args[1] instanceof Utils.BooleanHolder; + /** + * Checks if {@linkcode FlinchChanceModifier} should be applied + * @param pokemon the {@linkcode Pokemon} that holds the item + * @param flinched {@linkcode BooleanHolder} that is `true` if the pokemon flinched + * @returns `true` if {@linkcode FlinchChanceModifier} should be applied + */ + override shouldApply(pokemon?: Pokemon, flinched?: BooleanHolder): boolean { + return super.shouldApply(pokemon, flinched) && !!flinched; } - apply(args: any[]): boolean { - const pokemon = args[0] as Pokemon; - const flinched = args[1] as Utils.BooleanHolder; - + /** + * Applies {@linkcode FlinchChanceModifier} + * @param pokemon the {@linkcode Pokemon} that holds the item + * @param flinched {@linkcode BooleanHolder} that is `true` if the pokemon flinched + * @returns `true` if {@linkcode FlinchChanceModifier} has been applied + */ + override apply(pokemon: Pokemon, flinched: BooleanHolder): boolean { if (!flinched.value && pokemon.randSeedInt(10) < (this.getStackCount() * this.getSecondaryChanceMultiplier(pokemon))) { flinched.value = true; return true; @@ -1468,13 +1652,13 @@ export class FlinchChanceModifier extends PokemonHeldItemModifier { return false; } - getMaxHeldItemCount(pokemon: Pokemon): integer { + getMaxHeldItemCount(pokemon: Pokemon): number { return 3; } } export class TurnHealModifier extends PokemonHeldItemModifier { - constructor(type: ModifierType, pokemonId: integer, stackCount?: integer) { + constructor(type: ModifierType, pokemonId: number, stackCount?: number) { super(type, pokemonId, stackCount); } @@ -1486,20 +1670,23 @@ export class TurnHealModifier extends PokemonHeldItemModifier { return new TurnHealModifier(this.type, this.pokemonId, this.stackCount); } - apply(args: any[]): boolean { - const pokemon = args[0] as Pokemon; - + /** + * Applies {@linkcode TurnHealModifier} + * @param pokemon The {@linkcode Pokemon} that holds the item + * @returns `true` if the {@linkcode Pokemon} was healed + */ + override apply(pokemon: Pokemon): boolean { if (!pokemon.isFullHp()) { const scene = pokemon.scene; scene.unshiftPhase(new PokemonHealPhase(scene, pokemon.getBattlerIndex(), - Utils.toDmgValue(pokemon.getMaxHp() / 16) * this.stackCount, i18next.t("modifier:turnHealApply", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon), typeName: this.type.name }), true)); + toDmgValue(pokemon.getMaxHp() / 16) * this.stackCount, i18next.t("modifier:turnHealApply", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon), typeName: this.type.name }), true)); return true; } return false; } - getMaxHeldItemCount(pokemon: Pokemon): integer { + getMaxHeldItemCount(pokemon: Pokemon): number { return 4; } } @@ -1514,16 +1701,16 @@ export class TurnStatusEffectModifier extends PokemonHeldItemModifier { /** The status effect to be applied by the held item */ private effect: StatusEffect; - constructor (type: ModifierType, pokemonId: integer, stackCount?: integer) { + constructor (type: ModifierType, pokemonId: number, stackCount?: number) { super(type, pokemonId, stackCount); switch (type.id) { - case "TOXIC_ORB": - this.effect = StatusEffect.TOXIC; - break; - case "FLAME_ORB": - this.effect = StatusEffect.BURN; - break; + case "TOXIC_ORB": + this.effect = StatusEffect.TOXIC; + break; + case "FLAME_ORB": + this.effect = StatusEffect.BURN; + break; } } @@ -1534,7 +1721,7 @@ export class TurnStatusEffectModifier extends PokemonHeldItemModifier { * would be the only item able to {@linkcode apply} successfully. * @override * @param modifier {@linkcode Modifier} being type tested - * @return true if {@linkcode modifier} is an instance of + * @return `true` if {@linkcode modifier} is an instance of * TurnStatusEffectModifier, false otherwise */ matchType(modifier: Modifier): boolean { @@ -1547,15 +1734,14 @@ export class TurnStatusEffectModifier extends PokemonHeldItemModifier { /** * Tries to inflicts the holder with the associated {@linkcode StatusEffect}. - * @param args [0] {@linkcode Pokemon} that holds the held item - * @returns true if the status effect was applied successfully, false if - * otherwise + * @param pokemon {@linkcode Pokemon} that holds the held item + * @returns `true` if the status effect was applied successfully */ - apply(args: any[]): boolean { - return (args[0] as Pokemon).trySetStatus(this.effect, true, undefined, undefined, this.type.name); + override apply(pokemon: Pokemon): boolean { + return pokemon.trySetStatus(this.effect, true, undefined, undefined, this.type.name); } - getMaxHeldItemCount(pokemon: Pokemon): integer { + getMaxHeldItemCount(pokemon: Pokemon): number { return 1; } @@ -1565,7 +1751,7 @@ export class TurnStatusEffectModifier extends PokemonHeldItemModifier { } export class HitHealModifier extends PokemonHeldItemModifier { - constructor(type: ModifierType, pokemonId: integer, stackCount?: integer) { + constructor(type: ModifierType, pokemonId: number, stackCount?: number) { super(type, pokemonId, stackCount); } @@ -1577,25 +1763,28 @@ export class HitHealModifier extends PokemonHeldItemModifier { return new HitHealModifier(this.type, this.pokemonId, this.stackCount); } - apply(args: any[]): boolean { - const pokemon = args[0] as Pokemon; - - if (pokemon.turnData.damageDealt && !pokemon.isFullHp()) { + /** + * Applies {@linkcode HitHealModifier} + * @param pokemon The {@linkcode Pokemon} that holds the item + * @returns `true` if the {@linkcode Pokemon} was healed + */ + override apply(pokemon: Pokemon): boolean { + if (pokemon.turnData.totalDamageDealt && !pokemon.isFullHp()) { const scene = pokemon.scene; scene.unshiftPhase(new PokemonHealPhase(scene, pokemon.getBattlerIndex(), - Utils.toDmgValue(pokemon.turnData.damageDealt / 8) * this.stackCount, i18next.t("modifier:hitHealApply", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon), typeName: this.type.name }), true)); + toDmgValue(pokemon.turnData.totalDamageDealt / 8) * this.stackCount, i18next.t("modifier:hitHealApply", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon), typeName: this.type.name }), true)); } return true; } - getMaxHeldItemCount(pokemon: Pokemon): integer { + getMaxHeldItemCount(pokemon: Pokemon): number { return 4; } } export class LevelIncrementBoosterModifier extends PersistentModifier { - constructor(type: ModifierType, stackCount?: integer) { + constructor(type: ModifierType, stackCount?: number) { super(type, stackCount); } @@ -1607,12 +1796,22 @@ export class LevelIncrementBoosterModifier extends PersistentModifier { return new LevelIncrementBoosterModifier(this.type, this.stackCount); } - shouldApply(args: any[]): boolean { - return super.shouldApply(args) && args[0] instanceof Utils.IntegerHolder; + /** + * Checks if {@linkcode LevelIncrementBoosterModifier} should be applied + * @param count {@linkcode NumberHolder} holding the level increment count + * @returns `true` if {@linkcode LevelIncrementBoosterModifier} should be applied + */ + override shouldApply(count: NumberHolder): boolean { + return !!count; } - apply(args: any[]): boolean { - (args[0] as Utils.IntegerHolder).value += this.getStackCount(); + /** + * Applies {@linkcode LevelIncrementBoosterModifier} + * @param count {@linkcode NumberHolder} holding the level increment count + * @returns always `true` + */ + override apply(count: NumberHolder): boolean { + count.value += this.getStackCount(); return true; } @@ -1626,7 +1825,7 @@ export class BerryModifier extends PokemonHeldItemModifier { public berryType: BerryType; public consumed: boolean; - constructor(type: ModifierType, pokemonId: integer, berryType: BerryType, stackCount?: integer) { + constructor(type: ModifierType, pokemonId: number, berryType: BerryType, stackCount?: number) { super(type, pokemonId, stackCount); this.berryType = berryType; @@ -1645,14 +1844,22 @@ export class BerryModifier extends PokemonHeldItemModifier { return super.getArgs().concat(this.berryType); } - shouldApply(args: any[]): boolean { - return !this.consumed && super.shouldApply(args) && getBerryPredicate(this.berryType)(args[0] as Pokemon); + /** + * Checks if {@linkcode BerryModifier} should be applied + * @param pokemon The {@linkcode Pokemon} that holds the berry + * @returns `true` if {@linkcode BerryModifier} should be applied + */ + override shouldApply(pokemon: Pokemon): boolean { + return !this.consumed && super.shouldApply(pokemon) && getBerryPredicate(this.berryType)(pokemon); } - apply(args: any[]): boolean { - const pokemon = args[0] as Pokemon; - - const preserve = new Utils.BooleanHolder(false); + /** + * Applies {@linkcode BerryModifier} + * @param pokemon The {@linkcode Pokemon} that holds the berry + * @returns always `true` + */ + override apply(pokemon: Pokemon): boolean { + const preserve = new BooleanHolder(false); pokemon.scene.applyModifiers(PreserveBerryModifier, pokemon.isPlayer(), pokemon, preserve); getBerryEffectFunc(this.berryType)(pokemon); @@ -1663,8 +1870,8 @@ export class BerryModifier extends PokemonHeldItemModifier { return true; } - getMaxHeldItemCount(pokemon: Pokemon): integer { - if ([BerryType.LUM, BerryType.LEPPA, BerryType.SITRUS, BerryType.ENIGMA].includes(this.berryType)) { + getMaxHeldItemCount(pokemon: Pokemon): number { + if ([ BerryType.LUM, BerryType.LEPPA, BerryType.SITRUS, BerryType.ENIGMA ].includes(this.berryType)) { return 2; } return 3; @@ -1672,7 +1879,7 @@ export class BerryModifier extends PokemonHeldItemModifier { } export class PreserveBerryModifier extends PersistentModifier { - constructor(type: ModifierType, stackCount?: integer) { + constructor(type: ModifierType, stackCount?: number) { super(type, stackCount); } @@ -1684,25 +1891,37 @@ export class PreserveBerryModifier extends PersistentModifier { return new PreserveBerryModifier(this.type, this.stackCount); } - shouldApply(args: any[]): boolean { - return super.shouldApply(args) && args[0] instanceof Pokemon && args[1] instanceof Utils.BooleanHolder; + /** + * Checks if all prequired conditions are met to apply {@linkcode PreserveBerryModifier} + * @param pokemon {@linkcode Pokemon} that holds the berry + * @param doPreserve {@linkcode BooleanHolder} that is `true` if the berry should be preserved + * @returns `true` if {@linkcode PreserveBerryModifier} should be applied + */ + override shouldApply(pokemon?: Pokemon, doPreserve?: BooleanHolder): boolean { + return !!pokemon && !!doPreserve; } - apply(args: any[]): boolean { - if (!(args[1] as Utils.BooleanHolder).value) { - (args[1] as Utils.BooleanHolder).value = (args[0] as Pokemon).randSeedInt(10) < this.getStackCount() * 3; + /** + * Applies {@linkcode PreserveBerryModifier} + * @param pokemon The {@linkcode Pokemon} that holds the berry + * @param doPreserve {@linkcode BooleanHolder} that is `true` if the berry should be preserved + * @returns always `true` + */ + override apply(pokemon: Pokemon, doPreserve: BooleanHolder): boolean { + if (!doPreserve.value) { + doPreserve.value = pokemon.randSeedInt(10) < this.getStackCount() * 3; } return true; } - getMaxStackCount(scene: BattleScene): integer { + getMaxStackCount(scene: BattleScene): number { return 3; } } export class PokemonInstantReviveModifier extends PokemonHeldItemModifier { - constructor(type: ModifierType, pokemonId: integer, stackCount?: integer) { + constructor(type: ModifierType, pokemonId: number, stackCount?: number) { super(type, pokemonId, stackCount); } @@ -1714,17 +1933,26 @@ export class PokemonInstantReviveModifier extends PokemonHeldItemModifier { return new PokemonInstantReviveModifier(this.type, this.pokemonId, this.stackCount); } - apply(args: any[]): boolean { - const pokemon = args[0] as Pokemon; - + /** + * Applies {@linkcode PokemonInstantReviveModifier} + * @param pokemon The {@linkcode Pokemon} that holds the item + * @returns always `true` + */ + override apply(pokemon: Pokemon): boolean { + // Restore the Pokemon to half HP pokemon.scene.unshiftPhase(new PokemonHealPhase(pokemon.scene, pokemon.getBattlerIndex(), - Utils.toDmgValue(pokemon.getMaxHp() / 2), i18next.t("modifier:pokemonInstantReviveApply", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon), typeName: this.type.name }), false, false, true)); + toDmgValue(pokemon.getMaxHp() / 2), i18next.t("modifier:pokemonInstantReviveApply", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon), typeName: this.type.name }), false, false, true)); + // Remove the Pokemon's FAINT status pokemon.resetStatus(true, false, true); + + // Reapply Commander on the Pokemon's side of the field, if applicable + const field = pokemon.isPlayer() ? pokemon.scene.getPlayerField() : pokemon.scene.getEnemyField(); + field.forEach((p) => applyAbAttrs(CommanderAbAttr, p, null, false)); return true; } - getMaxHeldItemCount(pokemon: Pokemon): integer { + getMaxHeldItemCount(pokemon: Pokemon): number { return 1; } } @@ -1736,7 +1964,7 @@ export class PokemonInstantReviveModifier extends PokemonHeldItemModifier { * @see {@linkcode apply} */ export class ResetNegativeStatStageModifier extends PokemonHeldItemModifier { - constructor(type: ModifierType, pokemonId: integer, stackCount?: integer) { + constructor(type: ModifierType, pokemonId: number, stackCount?: number) { super(type, pokemonId, stackCount); } @@ -1751,11 +1979,10 @@ export class ResetNegativeStatStageModifier extends PokemonHeldItemModifier { /** * Goes through the holder's stat stages and, if any are negative, resets that * stat stage back to 0. - * @param args [0] {@linkcode Pokemon} that holds the held item - * @returns true if any stat stages were reset, false otherwise + * @param pokemon {@linkcode Pokemon} that holds the item + * @returns `true` if any stat stages were reset, false otherwise */ - apply(args: any[]): boolean { - const pokemon = args[0] as Pokemon; + override apply(pokemon: Pokemon): boolean { let statRestored = false; for (const s of BATTLE_STATS) { @@ -1771,36 +1998,49 @@ export class ResetNegativeStatStageModifier extends PokemonHeldItemModifier { return statRestored; } - getMaxHeldItemCount(_pokemon: Pokemon): integer { + getMaxHeldItemCount(_pokemon: Pokemon): number { return 2; } } export abstract class ConsumablePokemonModifier extends ConsumableModifier { - public pokemonId: integer; + public pokemonId: number; - constructor(type: ModifierType, pokemonId: integer) { + constructor(type: ModifierType, pokemonId: number) { super(type); this.pokemonId = pokemonId; } - shouldApply(args: any[]): boolean { - return args.length !== 0 && args[0] instanceof PlayerPokemon && (this.pokemonId === -1 || (args[0] as PlayerPokemon).id === this.pokemonId); + /** + * Checks if {@linkcode ConsumablePokemonModifier} should be applied + * @param playerPokemon The {@linkcode PlayerPokemon} that consumes the item + * @param _args N/A + * @returns `true` if {@linkcode ConsumablePokemonModifier} should be applied + */ + override shouldApply(playerPokemon?: PlayerPokemon, ..._args: unknown[]): boolean { + return !!playerPokemon && (this.pokemonId === -1 || playerPokemon.id === this.pokemonId); } + /** + * Applies {@linkcode ConsumablePokemonModifier} + * @param playerPokemon The {@linkcode PlayerPokemon} that consumes the item + * @param args Additional arguments passed to {@linkcode ConsumablePokemonModifier.apply} + */ + abstract override apply(playerPokemon: PlayerPokemon, ...args: unknown[]): boolean | Promise; + getPokemon(scene: BattleScene) { - return scene.getParty().find(p => p.id === this.pokemonId); + return scene.getPlayerParty().find(p => p.id === this.pokemonId); } } export class PokemonHpRestoreModifier extends ConsumablePokemonModifier { - private restorePoints: integer; + private restorePoints: number; private restorePercent: number; private healStatus: boolean; public fainted: boolean; - constructor(type: ModifierType, pokemonId: integer, restorePoints: integer, restorePercent: number, healStatus: boolean, fainted?: boolean) { + constructor(type: ModifierType, pokemonId: number, restorePoints: number, restorePercent: number, healStatus: boolean, fainted?: boolean) { super(type, pokemonId); this.restorePoints = restorePoints; @@ -1809,16 +2049,27 @@ export class PokemonHpRestoreModifier extends ConsumablePokemonModifier { this.fainted = !!fainted; } - shouldApply(args: any[]): boolean { - return super.shouldApply(args) && (this.fainted || (args.length > 1 && typeof(args[1]) === "number")); + /** + * Checks if {@linkcode PokemonHpRestoreModifier} should be applied + * @param playerPokemon The {@linkcode PlayerPokemon} that consumes the item + * @param multiplier The multiplier of the hp restore + * @returns `true` if the {@linkcode PokemonHpRestoreModifier} should be applied + */ + override shouldApply(playerPokemon?: PlayerPokemon, multiplier?: number): boolean { + return super.shouldApply(playerPokemon) && (this.fainted || (!isNullOrUndefined(multiplier) && typeof(multiplier) === "number")); } - apply(args: any[]): boolean { - const pokemon = args[0] as Pokemon; + /** + * Applies {@linkcode PokemonHpRestoreModifier} + * @param pokemon The {@linkcode PlayerPokemon} that consumes the item + * @param multiplier The multiplier of the hp restore + * @returns `true` if hp was restored + */ + override apply(pokemon: Pokemon, multiplier: number): boolean { if (!pokemon.hp === this.fainted) { let restorePoints = this.restorePoints; if (!this.fainted) { - restorePoints = Math.floor(restorePoints * (args[1] as number)); + restorePoints = Math.floor(restorePoints * multiplier); } if (this.fainted || this.healStatus) { pokemon.resetStatus(true, true); @@ -1831,21 +2082,25 @@ export class PokemonHpRestoreModifier extends ConsumablePokemonModifier { } export class PokemonStatusHealModifier extends ConsumablePokemonModifier { - constructor(type: ModifierType, pokemonId: integer) { + constructor(type: ModifierType, pokemonId: number) { super(type, pokemonId); } - apply(args: any[]): boolean { - const pokemon = args[0] as Pokemon; - pokemon.resetStatus(true, true); + /** + * Applies {@linkcode PokemonStatusHealModifier} + * @param playerPokemon The {@linkcode PlayerPokemon} that gets healed from the status + * @returns always `true` + */ + override apply(playerPokemon: PlayerPokemon): boolean { + playerPokemon.resetStatus(true, true); return true; } } export abstract class ConsumablePokemonMoveModifier extends ConsumablePokemonModifier { - public moveIndex: integer; + public moveIndex: number; - constructor(type: ModifierType, pokemonId: integer, moveIndex: integer) { + constructor(type: ModifierType, pokemonId: number, moveIndex: number) { super(type, pokemonId); this.moveIndex = moveIndex; @@ -1853,36 +2108,49 @@ export abstract class ConsumablePokemonMoveModifier extends ConsumablePokemonMod } export class PokemonPpRestoreModifier extends ConsumablePokemonMoveModifier { - private restorePoints: integer; + private restorePoints: number; - constructor(type: ModifierType, pokemonId: integer, moveIndex: integer, restorePoints: integer) { + constructor(type: ModifierType, pokemonId: number, moveIndex: number, restorePoints: number) { super(type, pokemonId, moveIndex); this.restorePoints = restorePoints; } - apply(args: any[]): boolean { - const pokemon = args[0] as Pokemon; - const move = pokemon.getMoveset()[this.moveIndex]!; //TODO: is the bang correct? - move.ppUsed = this.restorePoints > -1 ? Math.max(move.ppUsed - this.restorePoints, 0) : 0; + /** + * Applies {@linkcode PokemonPpRestoreModifier} + * @param playerPokemon The {@linkcode PlayerPokemon} that should get move pp restored + * @returns always `true` + */ + override apply(playerPokemon: PlayerPokemon): boolean { + const move = playerPokemon.getMoveset()[this.moveIndex]; + + if (move) { + move.ppUsed = this.restorePoints > -1 ? Math.max(move.ppUsed - this.restorePoints, 0) : 0; + } return true; } } export class PokemonAllMovePpRestoreModifier extends ConsumablePokemonModifier { - private restorePoints: integer; + private restorePoints: number; - constructor(type: ModifierType, pokemonId: integer, restorePoints: integer) { + constructor(type: ModifierType, pokemonId: number, restorePoints: number) { super(type, pokemonId); this.restorePoints = restorePoints; } - apply(args: any[]): boolean { - const pokemon = args[0] as Pokemon; - for (const move of pokemon.getMoveset()) { - move!.ppUsed = this.restorePoints > -1 ? Math.max(move!.ppUsed - this.restorePoints, 0) : 0; // TODO: are those bangs correct? + /** + * Applies {@linkcode PokemonAllMovePpRestoreModifier} + * @param playerPokemon The {@linkcode PlayerPokemon} that should get all move pp restored + * @returns always `true` + */ + override apply(playerPokemon: PlayerPokemon): boolean { + for (const move of playerPokemon.getMoveset()) { + if (move) { + move.ppUsed = this.restorePoints > -1 ? Math.max(move.ppUsed - this.restorePoints, 0) : 0; + } } return true; @@ -1890,18 +2158,25 @@ export class PokemonAllMovePpRestoreModifier extends ConsumablePokemonModifier { } export class PokemonPpUpModifier extends ConsumablePokemonMoveModifier { - private upPoints: integer; + private upPoints: number; - constructor(type: ModifierType, pokemonId: integer, moveIndex: integer, upPoints: integer) { + constructor(type: ModifierType, pokemonId: number, moveIndex: number, upPoints: number) { super(type, pokemonId, moveIndex); this.upPoints = upPoints; } - apply(args: any[]): boolean { - const pokemon = args[0] as Pokemon; - const move = pokemon.getMoveset()[this.moveIndex]!; // TODO: is the bang correct? - move.ppUp = Math.min(move.ppUp + this.upPoints, 3); + /** + * Applies {@linkcode PokemonPpUpModifier} + * @param playerPokemon The {@linkcode PlayerPokemon} that gets a pp up on move-slot {@linkcode moveIndex} + * @returns + */ + override apply(playerPokemon: PlayerPokemon): boolean { + const move = playerPokemon.getMoveset()[this.moveIndex]; + + if (move && !move.maxPpOverride) { + move.ppUp = Math.min(move.ppUp + this.upPoints, 3); + } return true; } @@ -1910,108 +2185,125 @@ export class PokemonPpUpModifier extends ConsumablePokemonMoveModifier { export class PokemonNatureChangeModifier extends ConsumablePokemonModifier { public nature: Nature; - constructor(type: ModifierType, pokemonId: integer, nature: Nature) { + constructor(type: ModifierType, pokemonId: number, nature: Nature) { super(type, pokemonId); this.nature = nature; } - apply(args: any[]): boolean { - const pokemon = args[0] as Pokemon; - pokemon.natureOverride = this.nature; - let speciesId = pokemon.species.speciesId; - pokemon.scene.gameData.dexData[speciesId].natureAttr |= 1 << (this.nature + 1); - - while (pokemonPrevolutions.hasOwnProperty(speciesId)) { - speciesId = pokemonPrevolutions[speciesId]; - pokemon.scene.gameData.dexData[speciesId].natureAttr |= 1 << (this.nature + 1); - } + /** + * Applies {@linkcode PokemonNatureChangeModifier} + * @param playerPokemon {@linkcode PlayerPokemon} to apply the {@linkcode Nature} change to + * @returns + */ + override apply(playerPokemon: PlayerPokemon): boolean { + playerPokemon.setCustomNature(this.nature); + playerPokemon.scene.gameData.unlockSpeciesNature(playerPokemon.species, this.nature); return true; } } export class PokemonLevelIncrementModifier extends ConsumablePokemonModifier { - constructor(type: ModifierType, pokemonId: integer) { + constructor(type: ModifierType, pokemonId: number) { super(type, pokemonId); } - apply(args: any[]): boolean { - const pokemon = args[0] as PlayerPokemon; - const levelCount = new Utils.IntegerHolder(1); - pokemon.scene.applyModifiers(LevelIncrementBoosterModifier, true, levelCount); + /** + * Applies {@linkcode PokemonLevelIncrementModifier} + * @param playerPokemon The {@linkcode PlayerPokemon} that should get levels incremented + * @param levelCount The amount of levels to increment + * @returns always `true` + */ + override apply(playerPokemon: PlayerPokemon, levelCount: NumberHolder = new NumberHolder(1)): boolean { + playerPokemon.scene.applyModifiers(LevelIncrementBoosterModifier, true, levelCount); - pokemon.level += levelCount.value; - if (pokemon.level <= pokemon.scene.getMaxExpLevel(true)) { - pokemon.exp = getLevelTotalExp(pokemon.level, pokemon.species.growthRate); - pokemon.levelExp = 0; + playerPokemon.level += levelCount.value; + if (playerPokemon.level <= playerPokemon.scene.getMaxExpLevel(true)) { + playerPokemon.exp = getLevelTotalExp(playerPokemon.level, playerPokemon.species.growthRate); + playerPokemon.levelExp = 0; } - pokemon.addFriendship(5); + playerPokemon.addFriendship(FRIENDSHIP_GAIN_FROM_RARE_CANDY); - pokemon.scene.unshiftPhase(new LevelUpPhase(pokemon.scene, pokemon.scene.getParty().indexOf(pokemon), pokemon.level - levelCount.value, pokemon.level)); + playerPokemon.scene.unshiftPhase(new LevelUpPhase(playerPokemon.scene, playerPokemon.scene.getPlayerParty().indexOf(playerPokemon), playerPokemon.level - levelCount.value, playerPokemon.level)); return true; } } export class TmModifier extends ConsumablePokemonModifier { - constructor(type: ModifierTypes.TmModifierType, pokemonId: integer) { + public override type: TmModifierType; + + constructor(type: TmModifierType, pokemonId: number) { super(type, pokemonId); } - apply(args: any[]): boolean { - const pokemon = args[0] as PlayerPokemon; + /** + * Applies {@linkcode TmModifier} + * @param playerPokemon The {@linkcode PlayerPokemon} that should learn the TM + * @returns always `true` + */ + override apply(playerPokemon: PlayerPokemon): boolean { - pokemon.scene.unshiftPhase(new LearnMovePhase(pokemon.scene, pokemon.scene.getParty().indexOf(pokemon), (this.type as ModifierTypes.TmModifierType).moveId, true)); + playerPokemon.scene.unshiftPhase(new LearnMovePhase(playerPokemon.scene, playerPokemon.scene.getPlayerParty().indexOf(playerPokemon), this.type.moveId, LearnMoveType.TM)); return true; } } export class RememberMoveModifier extends ConsumablePokemonModifier { - public levelMoveIndex: integer; + public levelMoveIndex: number; - constructor(type: ModifierTypes.ModifierType, pokemonId: integer, levelMoveIndex: integer) { + constructor(type: ModifierType, pokemonId: number, levelMoveIndex: number) { super(type, pokemonId); this.levelMoveIndex = levelMoveIndex; } - apply(args: any[]): boolean { - const pokemon = args[0] as PlayerPokemon; + /** + * Applies {@linkcode RememberMoveModifier} + * @param playerPokemon The {@linkcode PlayerPokemon} that should remember the move + * @returns always `true` + */ + override apply(playerPokemon: PlayerPokemon, cost?: number): boolean { - pokemon.scene.unshiftPhase(new LearnMovePhase(pokemon.scene, pokemon.scene.getParty().indexOf(pokemon), pokemon.getLearnableLevelMoves()[this.levelMoveIndex])); + playerPokemon.scene.unshiftPhase(new LearnMovePhase(playerPokemon.scene, playerPokemon.scene.getPlayerParty().indexOf(playerPokemon), playerPokemon.getLearnableLevelMoves()[this.levelMoveIndex], LearnMoveType.MEMORY, cost)); return true; } } export class EvolutionItemModifier extends ConsumablePokemonModifier { - constructor(type: ModifierTypes.EvolutionItemModifierType, pokemonId: integer) { + public override type: EvolutionItemModifierType; + + constructor(type: EvolutionItemModifierType, pokemonId: number) { super(type, pokemonId); } - apply(args: any[]): boolean { - const pokemon = args[0] as PlayerPokemon; - - let matchingEvolution = pokemonEvolutions.hasOwnProperty(pokemon.species.speciesId) - ? pokemonEvolutions[pokemon.species.speciesId].find(e => e.item === (this.type as ModifierTypes.EvolutionItemModifierType).evolutionItem - && (e.evoFormKey === null || (e.preFormKey || "") === pokemon.getFormKey()) - && (!e.condition || e.condition.predicate(pokemon))) + /** + * Applies {@linkcode EvolutionItemModifier} + * @param playerPokemon The {@linkcode PlayerPokemon} that should evolve via item + * @returns `true` if the evolution was successful + */ + override apply(playerPokemon: PlayerPokemon): boolean { + let matchingEvolution = pokemonEvolutions.hasOwnProperty(playerPokemon.species.speciesId) + ? pokemonEvolutions[playerPokemon.species.speciesId].find(e => e.item === this.type.evolutionItem + && (e.evoFormKey === null || (e.preFormKey || "") === playerPokemon.getFormKey()) + && (!e.condition || e.condition.predicate(playerPokemon))) : null; - if (!matchingEvolution && pokemon.isFusion()) { - matchingEvolution = pokemonEvolutions[pokemon.fusionSpecies!.speciesId].find(e => e.item === (this.type as ModifierTypes.EvolutionItemModifierType).evolutionItem // TODO: is the bang correct? - && (e.evoFormKey === null || (e.preFormKey || "") === pokemon.getFusionFormKey()) - && (!e.condition || e.condition.predicate(pokemon))); + if (!matchingEvolution && playerPokemon.isFusion()) { + matchingEvolution = pokemonEvolutions[playerPokemon.fusionSpecies!.speciesId].find(e => e.item === this.type.evolutionItem // TODO: is the bang correct? + && (e.evoFormKey === null || (e.preFormKey || "") === playerPokemon.getFusionFormKey()) + && (!e.condition || e.condition.predicate(playerPokemon))); if (matchingEvolution) { - matchingEvolution = new FusionSpeciesFormEvolution(pokemon.species.speciesId, matchingEvolution); + matchingEvolution = new FusionSpeciesFormEvolution(playerPokemon.species.speciesId, matchingEvolution); } } if (matchingEvolution) { - pokemon.scene.unshiftPhase(new EvolutionPhase(pokemon.scene, pokemon, matchingEvolution, pokemon.level - 1)); + playerPokemon.scene.unshiftPhase(new EvolutionPhase(playerPokemon.scene, playerPokemon, matchingEvolution, playerPokemon.level - 1)); return true; } @@ -2020,27 +2312,38 @@ export class EvolutionItemModifier extends ConsumablePokemonModifier { } export class FusePokemonModifier extends ConsumablePokemonModifier { - public fusePokemonId: integer; + public fusePokemonId: number; - constructor(type: ModifierType, pokemonId: integer, fusePokemonId: integer) { + constructor(type: ModifierType, pokemonId: number, fusePokemonId: number) { super(type, pokemonId); this.fusePokemonId = fusePokemonId; } - shouldApply(args: any[]): boolean { - return super.shouldApply(args) && args[1] instanceof PlayerPokemon && this.fusePokemonId === (args[1] as PlayerPokemon).id; + /** + * Checks if {@linkcode FusePokemonModifier} should be applied + * @param playerPokemon {@linkcode PlayerPokemon} that should be fused + * @param playerPokemon2 {@linkcode PlayerPokemon} that should be fused with {@linkcode playerPokemon} + * @returns `true` if {@linkcode FusePokemonModifier} should be applied + */ + override shouldApply(playerPokemon?: PlayerPokemon, playerPokemon2?: PlayerPokemon): boolean { + return super.shouldApply(playerPokemon, playerPokemon2) && !!playerPokemon2 && this.fusePokemonId === playerPokemon2.id; } - apply(args: any[]): Promise { - return new Promise(resolve => { - (args[0] as PlayerPokemon).fuse(args[1] as PlayerPokemon).then(() => resolve(true)); - }); + /** + * Applies {@linkcode FusePokemonModifier} + * @param playerPokemon {@linkcode PlayerPokemon} that should be fused + * @param playerPokemon2 {@linkcode PlayerPokemon} that should be fused with {@linkcode playerPokemon} + * @returns always Promise + */ + override async apply(playerPokemon: PlayerPokemon, playerPokemon2: PlayerPokemon): Promise { + await playerPokemon.fuse(playerPokemon2); + return true; } } export class MultipleParticipantExpBonusModifier extends PersistentModifier { - constructor(type: ModifierType, stackCount?: integer) { + constructor(type: ModifierType, stackCount?: number) { super(type, stackCount); } @@ -2048,7 +2351,11 @@ export class MultipleParticipantExpBonusModifier extends PersistentModifier { return modifier instanceof MultipleParticipantExpBonusModifier; } - apply(_args: any[]): boolean { + /** + * Applies {@linkcode MultipleParticipantExpBonusModifier} + * @returns always `true` + */ + apply(): boolean { return true; } @@ -2056,7 +2363,7 @@ export class MultipleParticipantExpBonusModifier extends PersistentModifier { return new MultipleParticipantExpBonusModifier(this.type, this.stackCount); } - getMaxStackCount(scene: BattleScene): integer { + getMaxStackCount(scene: BattleScene): number { return 5; } } @@ -2064,7 +2371,7 @@ export class MultipleParticipantExpBonusModifier extends PersistentModifier { export class HealingBoosterModifier extends PersistentModifier { private multiplier: number; - constructor(type: ModifierType, multiplier: number, stackCount?: integer) { + constructor(type: ModifierType, multiplier: number, stackCount?: number) { super(type, stackCount); this.multiplier = multiplier; @@ -2082,22 +2389,26 @@ export class HealingBoosterModifier extends PersistentModifier { return [ this.multiplier ]; } - apply(args: any[]): boolean { - const healingMultiplier = args[0] as Utils.IntegerHolder; + /** + * Applies {@linkcode HealingBoosterModifier} + * @param healingMultiplier the multiplier to apply to the healing + * @returns always `true` + */ + override apply(healingMultiplier: NumberHolder): boolean { healingMultiplier.value *= 1 + ((this.multiplier - 1) * this.getStackCount()); return true; } - getMaxStackCount(scene: BattleScene): integer { + getMaxStackCount(scene: BattleScene): number { return 5; } } export class ExpBoosterModifier extends PersistentModifier { - private boostMultiplier: integer; + private boostMultiplier: number; - constructor(type: ModifierType, boostPercent: number, stackCount?: integer) { + constructor(type: ModifierType, boostPercent: number, stackCount?: number) { super(type, stackCount); this.boostMultiplier = boostPercent * 0.01; @@ -2119,21 +2430,28 @@ export class ExpBoosterModifier extends PersistentModifier { return [ this.boostMultiplier * 100 ]; } - apply(args: any[]): boolean { - (args[0] as Utils.NumberHolder).value = Math.floor((args[0] as Utils.NumberHolder).value * (1 + (this.getStackCount() * this.boostMultiplier))); + /** + * Applies {@linkcode ExpBoosterModifier} + * @param boost {@linkcode NumberHolder} holding the boost value + * @returns always `true` + */ + override apply(boost: NumberHolder): boolean { + boost.value = Math.floor(boost.value * (1 + (this.getStackCount() * this.boostMultiplier))); return true; } - getMaxStackCount(scene: BattleScene, forThreshold?: boolean): integer { + getMaxStackCount(scene: BattleScene, forThreshold?: boolean): number { return this.boostMultiplier < 1 ? this.boostMultiplier < 0.6 ? 99 : 30 : 10; } } export class PokemonExpBoosterModifier extends PokemonHeldItemModifier { - private boostMultiplier: integer; + public override type: PokemonExpBoosterModifierType; - constructor(type: ModifierTypes.PokemonExpBoosterModifierType, pokemonId: integer, boostPercent: number, stackCount?: integer) { + private boostMultiplier: number; + + constructor(type: PokemonExpBoosterModifierType, pokemonId: number, boostPercent: number, stackCount?: number) { super(type, pokemonId, stackCount); this.boostMultiplier = boostPercent * 0.01; } @@ -2147,30 +2465,42 @@ export class PokemonExpBoosterModifier extends PokemonHeldItemModifier { } clone(): PersistentModifier { - return new PokemonExpBoosterModifier(this.type as ModifierTypes.PokemonExpBoosterModifierType, this.pokemonId, this.boostMultiplier * 100, this.stackCount); + return new PokemonExpBoosterModifier(this.type, this.pokemonId, this.boostMultiplier * 100, this.stackCount); } getArgs(): any[] { return super.getArgs().concat(this.boostMultiplier * 100); } - shouldApply(args: any[]): boolean { - return super.shouldApply(args) && args.length === 2 && args[1] instanceof Utils.NumberHolder; + /** + * Checks if {@linkcode PokemonExpBoosterModifier} should be applied + * @param pokemon The {@linkcode Pokemon} to apply the exp boost to + * @param boost {@linkcode NumberHolder} holding the exp boost value + * @returns `true` if {@linkcode PokemonExpBoosterModifier} should be applied + */ + override shouldApply(pokemon: Pokemon, boost: NumberHolder): boolean { + return super.shouldApply(pokemon, boost) && !!boost; } - apply(args: any[]): boolean { - (args[1] as Utils.NumberHolder).value = Math.floor((args[1] as Utils.NumberHolder).value * (1 + (this.getStackCount() * this.boostMultiplier))); + /** + * Applies {@linkcode PokemonExpBoosterModifier} + * @param _pokemon The {@linkcode Pokemon} to apply the exp boost to + * @param boost {@linkcode NumberHolder} holding the exp boost value + * @returns always `true` + */ + override apply(_pokemon: Pokemon, boost: NumberHolder): boolean { + boost.value = Math.floor(boost.value * (1 + (this.getStackCount() * this.boostMultiplier))); return true; } - getMaxHeldItemCount(pokemon: Pokemon): integer { + getMaxHeldItemCount(pokemon: Pokemon): number { return 99; } } export class ExpShareModifier extends PersistentModifier { - constructor(type: ModifierType, stackCount?: integer) { + constructor(type: ModifierType, stackCount?: number) { super(type, stackCount); } @@ -2182,17 +2512,21 @@ export class ExpShareModifier extends PersistentModifier { return new ExpShareModifier(this.type, this.stackCount); } - apply(_args: any[]): boolean { + /** + * Applies {@linkcode ExpShareModifier} + * @returns always `true` + */ + override apply(): boolean { return true; } - getMaxStackCount(scene: BattleScene): integer { + getMaxStackCount(scene: BattleScene): number { return 5; } } export class ExpBalanceModifier extends PersistentModifier { - constructor(type: ModifierType, stackCount?: integer) { + constructor(type: ModifierType, stackCount?: number) { super(type, stackCount); } @@ -2204,17 +2538,23 @@ export class ExpBalanceModifier extends PersistentModifier { return new ExpBalanceModifier(this.type, this.stackCount); } - apply(_args: any[]): boolean { + /** + * Applies {@linkcode ExpBalanceModifier} + * @returns always `true` + */ + override apply(): boolean { return true; } - getMaxStackCount(scene: BattleScene): integer { + getMaxStackCount(scene: BattleScene): number { return 4; } } export class PokemonFriendshipBoosterModifier extends PokemonHeldItemModifier { - constructor(type: ModifierTypes.PokemonFriendshipBoosterModifierType, pokemonId: integer, stackCount?: integer) { + public override type: PokemonFriendshipBoosterModifierType; + + constructor(type: PokemonFriendshipBoosterModifierType, pokemonId: number, stackCount?: number) { super(type, pokemonId, stackCount); } @@ -2223,23 +2563,28 @@ export class PokemonFriendshipBoosterModifier extends PokemonHeldItemModifier { } clone(): PersistentModifier { - return new PokemonFriendshipBoosterModifier(this.type as ModifierTypes.PokemonFriendshipBoosterModifierType, this.pokemonId, this.stackCount); + return new PokemonFriendshipBoosterModifier(this.type, this.pokemonId, this.stackCount); } - apply(args: any[]): boolean { - const friendship = args[1] as Utils.IntegerHolder; + /** + * Applies {@linkcode PokemonFriendshipBoosterModifier} + * @param _pokemon The {@linkcode Pokemon} to apply the friendship boost to + * @param friendship {@linkcode NumberHolder} holding the friendship boost value + * @returns always `true` + */ + override apply(_pokemon: Pokemon, friendship: NumberHolder): boolean { friendship.value = Math.floor(friendship.value * (1 + 0.5 * this.getStackCount())); return true; } - getMaxHeldItemCount(pokemon: Pokemon): integer { + getMaxHeldItemCount(pokemon: Pokemon): number { return 3; } } export class PokemonNatureWeightModifier extends PokemonHeldItemModifier { - constructor(type: ModifierTypes.ModifierType, pokemonId: integer, stackCount?: integer) { + constructor(type: ModifierType, pokemonId: number, stackCount?: number) { super(type, pokemonId, stackCount); } @@ -2251,8 +2596,13 @@ export class PokemonNatureWeightModifier extends PokemonHeldItemModifier { return new PokemonNatureWeightModifier(this.type, this.pokemonId, this.stackCount); } - apply(args: any[]): boolean { - const multiplier = args[1] as Utils.IntegerHolder; + /** + * Applies {@linkcode PokemonNatureWeightModifier} + * @param _pokemon The {@linkcode Pokemon} to apply the nature weight to + * @param multiplier {@linkcode NumberHolder} holding the nature weight + * @returns `true` if multiplier was applied + */ + override apply(_pokemon: Pokemon, multiplier: NumberHolder): boolean { if (multiplier.value !== 1) { multiplier.value += 0.1 * this.getStackCount() * (multiplier.value > 1 ? 1 : -1); return true; @@ -2261,15 +2611,16 @@ export class PokemonNatureWeightModifier extends PokemonHeldItemModifier { return false; } - getMaxHeldItemCount(pokemon: Pokemon): integer { + getMaxHeldItemCount(pokemon: Pokemon): number { return 10; } } export class PokemonMoveAccuracyBoosterModifier extends PokemonHeldItemModifier { - private accuracyAmount: integer; + public override type: PokemonMoveAccuracyBoosterModifierType; + private accuracyAmount: number; - constructor(type: ModifierTypes.PokemonMoveAccuracyBoosterModifierType, pokemonId: integer, accuracy: integer, stackCount?: integer) { + constructor(type: PokemonMoveAccuracyBoosterModifierType, pokemonId: number, accuracy: number, stackCount?: number) { super(type, pokemonId, stackCount); this.accuracyAmount = accuracy; } @@ -2283,31 +2634,44 @@ export class PokemonMoveAccuracyBoosterModifier extends PokemonHeldItemModifier } clone(): PersistentModifier { - return new PokemonMoveAccuracyBoosterModifier(this.type as ModifierTypes.PokemonMoveAccuracyBoosterModifierType, this.pokemonId, this.accuracyAmount, this.stackCount); + return new PokemonMoveAccuracyBoosterModifier(this.type, this.pokemonId, this.accuracyAmount, this.stackCount); } getArgs(): any[] { return super.getArgs().concat(this.accuracyAmount); } - shouldApply(args: any[]): boolean { - return super.shouldApply(args) && args.length === 2 && args[1] instanceof Utils.NumberHolder; + /** + * Checks if {@linkcode PokemonMoveAccuracyBoosterModifier} should be applied + * @param pokemon The {@linkcode Pokemon} to apply the move accuracy boost to + * @param moveAccuracy {@linkcode NumberHolder} holding the move accuracy boost + * @returns `true` if {@linkcode PokemonMoveAccuracyBoosterModifier} should be applied + */ + override shouldApply(pokemon?: Pokemon, moveAccuracy?: NumberHolder): boolean { + return super.shouldApply(pokemon, moveAccuracy) && !!moveAccuracy; } - apply(args: any[]): boolean { - const moveAccuracy = (args[1] as Utils.IntegerHolder); + /** + * Applies {@linkcode PokemonMoveAccuracyBoosterModifier} + * @param _pokemon The {@linkcode Pokemon} to apply the move accuracy boost to + * @param moveAccuracy {@linkcode NumberHolder} holding the move accuracy boost + * @returns always `true` + */ + override apply(_pokemon: Pokemon, moveAccuracy: NumberHolder): boolean { moveAccuracy.value = Math.min(moveAccuracy.value + this.accuracyAmount * this.getStackCount(), 100); return true; } - getMaxHeldItemCount(pokemon: Pokemon): integer { + getMaxHeldItemCount(pokemon: Pokemon): number { return 3; } } export class PokemonMultiHitModifier extends PokemonHeldItemModifier { - constructor(type: ModifierTypes.PokemonMultiHitModifierType, pokemonId: integer, stackCount?: integer) { + public override type: PokemonMultiHitModifierType; + + constructor(type: PokemonMultiHitModifierType, pokemonId: number, stackCount?: number) { super(type, pokemonId, stackCount); } @@ -2316,39 +2680,79 @@ export class PokemonMultiHitModifier extends PokemonHeldItemModifier { } clone(): PersistentModifier { - return new PokemonMultiHitModifier(this.type as ModifierTypes.PokemonMultiHitModifierType, this.pokemonId, this.stackCount); + return new PokemonMultiHitModifier(this.type, this.pokemonId, this.stackCount); } - apply(args: any[]): boolean { - (args[1] as Utils.IntegerHolder).value *= (this.getStackCount() + 1); - - const power = args[2] as Utils.NumberHolder; - switch (this.getStackCount()) { - case 1: - power.value *= 0.4; - break; - case 2: - power.value *= 0.25; - break; - case 3: - power.value *= 0.175; - break; + /** + * For each stack, converts 25 percent of attack damage into an additional strike. + * @param pokemon The {@linkcode Pokemon} using the move + * @param moveId The {@linkcode Moves | identifier} for the move being used + * @param count {@linkcode NumberHolder} holding the move's hit count for this turn + * @param damageMultiplier {@linkcode NumberHolder} holding a damage multiplier applied to a strike of this move + * @returns always `true` + */ + override apply(pokemon: Pokemon, moveId: Moves, count: NumberHolder | null = null, damageMultiplier: NumberHolder | null = null): boolean { + const move = allMoves[moveId]; + /** + * The move must meet Parental Bond's restrictions for this item + * to apply. This means + * - Only attacks are boosted + * - Multi-strike moves, charge moves, and self-sacrificial moves are not boosted + * (though Multi-Lens can still affect moves boosted by Parental Bond) + * - Multi-target moves are not boosted *unless* they can only hit a single Pokemon + * - Fling, Uproar, Rollout, Ice Ball, and Endeavor are not boosted + */ + if (!move.canBeMultiStrikeEnhanced(pokemon)) { + return false; } + if (!isNullOrUndefined(count)) { + return this.applyHitCountBoost(count); + } else if (!isNullOrUndefined(damageMultiplier)) { + return this.applyDamageModifier(pokemon, damageMultiplier); + } + + return false; + } + + /** Adds strikes to a move equal to the number of stacked Multi-Lenses */ + private applyHitCountBoost(count: NumberHolder): boolean { + count.value += this.getStackCount(); return true; } - getMaxHeldItemCount(pokemon: Pokemon): integer { - return 3; + /** + * If applied to the first hit of a move, sets the damage multiplier + * equal to (1 - the number of stacked Multi-Lenses). + * Additional strikes beyond that are given a 0.25x damage multiplier + */ + private applyDamageModifier(pokemon: Pokemon, damageMultiplier: NumberHolder): boolean { + if (pokemon.turnData.hitsLeft === pokemon.turnData.hitCount) { + // Reduce first hit by 25% for each stack count + damageMultiplier.value *= 1 - 0.25 * this.getStackCount(); + return true; + } else if (pokemon.turnData.hitCount - pokemon.turnData.hitsLeft !== this.getStackCount() + 1) { + // Deal 25% damage for each remaining Multi Lens hit + damageMultiplier.value *= 0.25; + return true; + } else { + // An extra hit not caused by Multi Lens -- assume it is Parental Bond + return false; + } + } + + getMaxHeldItemCount(pokemon: Pokemon): number { + return 2; } } export class PokemonFormChangeItemModifier extends PokemonHeldItemModifier { + public override type: FormChangeItemModifierType; public formChangeItem: FormChangeItem; public active: boolean; - readonly isTransferrable: boolean = false; + public isTransferable: boolean = false; - constructor(type: ModifierTypes.FormChangeItemModifierType, pokemonId: integer, formChangeItem: FormChangeItem, active: boolean, stackCount?: integer) { + constructor(type: FormChangeItemModifierType, pokemonId: number, formChangeItem: FormChangeItem, active: boolean, stackCount?: number) { super(type, pokemonId, stackCount); this.formChangeItem = formChangeItem; this.active = active; @@ -2359,17 +2763,20 @@ export class PokemonFormChangeItemModifier extends PokemonHeldItemModifier { } clone(): PersistentModifier { - return new PokemonFormChangeItemModifier(this.type as ModifierTypes.FormChangeItemModifierType, this.pokemonId, this.formChangeItem, this.active, this.stackCount); + return new PokemonFormChangeItemModifier(this.type, this.pokemonId, this.formChangeItem, this.active, this.stackCount); } getArgs(): any[] { return super.getArgs().concat(this.formChangeItem, this.active); } - apply(args: any[]): boolean { - const pokemon = args[0] as Pokemon; - const active = args[1] as boolean; - + /** + * Applies {@linkcode PokemonFormChangeItemModifier} + * @param pokemon The {@linkcode Pokemon} to apply the form change item to + * @param active `true` if the form change item is active + * @returns `true` if the form change item was applied + */ + override apply(pokemon: Pokemon, active: boolean): boolean { const switchActive = this.active && !active; if (switchActive) { @@ -2385,7 +2792,7 @@ export class PokemonFormChangeItemModifier extends PokemonHeldItemModifier { return ret; } - getMaxHeldItemCount(pokemon: Pokemon): integer { + getMaxHeldItemCount(pokemon: Pokemon): number { return 1; } } @@ -2399,20 +2806,23 @@ export class MoneyRewardModifier extends ConsumableModifier { this.moneyMultiplier = moneyMultiplier; } - apply(args: any[]): boolean { - const scene = args[0] as BattleScene; - const moneyAmount = new Utils.IntegerHolder(scene.getWaveMoneyAmount(this.moneyMultiplier)); + /** + * Applies {@linkcode MoneyRewardModifier} + * @param battleScene The current {@linkcode BattleScene} + * @returns always `true` + */ + override apply(battleScene: BattleScene): boolean { + const moneyAmount = new NumberHolder(battleScene.getWaveMoneyAmount(this.moneyMultiplier)); - scene.applyModifiers(MoneyMultiplierModifier, true, moneyAmount); + battleScene.applyModifiers(MoneyMultiplierModifier, true, moneyAmount); - scene.addMoney(moneyAmount.value); + battleScene.addMoney(moneyAmount.value); - scene.getParty().map(p => { + battleScene.getPlayerParty().map(p => { if (p.species?.speciesId === Species.GIMMIGHOUL || p.fusionSpecies?.speciesId === Species.GIMMIGHOUL) { - p.evoCounter++; - const modifierType: ModifierType = modifierTypes.EVOLUTION_TRACKER_GIMMIGHOUL(); - const modifier = modifierType!.newModifier(p); - scene.addModifier(modifier); + p.evoCounter ? p.evoCounter += Math.min(Math.floor(this.moneyMultiplier), 3) : p.evoCounter = Math.min(Math.floor(this.moneyMultiplier), 3); + const modifier = getModifierType(modifierTypes.EVOLUTION_TRACKER_GIMMIGHOUL).newModifier(p) as EvoTrackerModifier; + battleScene.addModifier(modifier); } }); @@ -2421,7 +2831,7 @@ export class MoneyRewardModifier extends ConsumableModifier { } export class MoneyMultiplierModifier extends PersistentModifier { - constructor(type: ModifierType, stackCount?: integer) { + constructor(type: ModifierType, stackCount?: number) { super(type, stackCount); } @@ -2433,19 +2843,24 @@ export class MoneyMultiplierModifier extends PersistentModifier { return new MoneyMultiplierModifier(this.type, this.stackCount); } - apply(args: any[]): boolean { - (args[0] as Utils.IntegerHolder).value += Math.floor((args[0] as Utils.IntegerHolder).value * 0.2 * this.getStackCount()); + /** + * Applies {@linkcode MoneyMultiplierModifier} + * @param multiplier {@linkcode NumberHolder} holding the money multiplier value + * @returns always `true` + */ + override apply(multiplier: NumberHolder): boolean { + multiplier.value += Math.floor(multiplier.value * 0.2 * this.getStackCount()); return true; } - getMaxStackCount(scene: BattleScene): integer { + getMaxStackCount(scene: BattleScene): number { return 5; } } export class DamageMoneyRewardModifier extends PokemonHeldItemModifier { - constructor(type: ModifierType, pokemonId: integer, stackCount?: integer) { + constructor(type: ModifierType, pokemonId: number, stackCount?: number) { super(type, pokemonId, stackCount); } @@ -2457,22 +2872,28 @@ export class DamageMoneyRewardModifier extends PokemonHeldItemModifier { return new DamageMoneyRewardModifier(this.type, this.pokemonId, this.stackCount); } - apply(args: any[]): boolean { - const scene = (args[0] as Pokemon).scene; - const moneyAmount = new Utils.IntegerHolder(Math.floor((args[1] as Utils.IntegerHolder).value * (0.5 * this.getStackCount()))); - scene.applyModifiers(MoneyMultiplierModifier, true, moneyAmount); - scene.addMoney(moneyAmount.value); + /** + * Applies {@linkcode DamageMoneyRewardModifier} + * @param pokemon The {@linkcode Pokemon} attacking + * @param multiplier {@linkcode NumberHolder} holding the multiplier value + * @returns always `true` + */ + override apply(pokemon: Pokemon, multiplier: NumberHolder): boolean { + const battleScene = pokemon.scene; + const moneyAmount = new NumberHolder(Math.floor(multiplier.value * (0.5 * this.getStackCount()))); + battleScene.applyModifiers(MoneyMultiplierModifier, true, moneyAmount); + battleScene.addMoney(moneyAmount.value); return true; } - getMaxHeldItemCount(pokemon: Pokemon): integer { + getMaxHeldItemCount(pokemon: Pokemon): number { return 5; } } export class MoneyInterestModifier extends PersistentModifier { - constructor(type: ModifierType, stackCount?: integer) { + constructor(type: ModifierType, stackCount?: number) { super(type, stackCount); } @@ -2480,15 +2901,19 @@ export class MoneyInterestModifier extends PersistentModifier { return modifier instanceof MoneyInterestModifier; } - apply(args: any[]): boolean { - const scene = args[0] as BattleScene; - const interestAmount = Math.floor(scene.money * 0.1 * this.getStackCount()); - scene.addMoney(interestAmount); + /** + * Applies {@linkcode MoneyInterestModifier} + * @param battleScene The current {@linkcode BattleScene} + * @returns always `true` + */ + override apply(battleScene: BattleScene): boolean { + const interestAmount = Math.floor(battleScene.money * 0.1 * this.getStackCount()); + battleScene.addMoney(interestAmount); const userLocale = navigator.language || "en-US"; const formattedMoneyAmount = interestAmount.toLocaleString(userLocale); const message = i18next.t("modifier:moneyInterestApply", { moneyAmount: formattedMoneyAmount, typeName: this.type.name }); - scene.queueMessage(message, undefined, true); + battleScene.queueMessage(message, undefined, true); return true; } @@ -2497,13 +2922,13 @@ export class MoneyInterestModifier extends PersistentModifier { return new MoneyInterestModifier(this.type, this.stackCount); } - getMaxStackCount(scene: BattleScene): integer { + getMaxStackCount(scene: BattleScene): number { return 5; } } export class HiddenAbilityRateBoosterModifier extends PersistentModifier { - constructor(type: ModifierType, stackCount?: integer) { + constructor(type: ModifierType, stackCount?: number) { super(type, stackCount); } @@ -2515,19 +2940,24 @@ export class HiddenAbilityRateBoosterModifier extends PersistentModifier { return new HiddenAbilityRateBoosterModifier(this.type, this.stackCount); } - apply(args: any[]): boolean { - (args[0] as Utils.IntegerHolder).value *= Math.pow(2, -1 - this.getStackCount()); + /** + * Applies {@linkcode HiddenAbilityRateBoosterModifier} + * @param boost {@linkcode NumberHolder} holding the boost value + * @returns always `true` + */ + override apply(boost: NumberHolder): boolean { + boost.value *= Math.pow(2, -1 - this.getStackCount()); return true; } - getMaxStackCount(scene: BattleScene): integer { + getMaxStackCount(scene: BattleScene): number { return 4; } } export class ShinyRateBoosterModifier extends PersistentModifier { - constructor(type: ModifierType, stackCount?: integer) { + constructor(type: ModifierType, stackCount?: number) { super(type, stackCount); } @@ -2539,19 +2969,56 @@ export class ShinyRateBoosterModifier extends PersistentModifier { return new ShinyRateBoosterModifier(this.type, this.stackCount); } - apply(args: any[]): boolean { - (args[0] as Utils.IntegerHolder).value *= Math.pow(2, 1 + this.getStackCount()); + /** + * Applies {@linkcode ShinyRateBoosterModifier} + * @param boost {@linkcode NumberHolder} holding the boost value + * @returns always `true` + */ + override apply(boost: NumberHolder): boolean { + boost.value *= Math.pow(2, 1 + this.getStackCount()); return true; } - getMaxStackCount(scene: BattleScene): integer { + getMaxStackCount(scene: BattleScene): number { return 4; } } +export class CriticalCatchChanceBoosterModifier extends PersistentModifier { + constructor(type: ModifierType, stackCount?: number) { + super(type, stackCount); + } + + match(modifier: Modifier): boolean { + return modifier instanceof CriticalCatchChanceBoosterModifier; + } + + clone(): CriticalCatchChanceBoosterModifier { + return new CriticalCatchChanceBoosterModifier(this.type, this.stackCount); + } + + /** + * Applies {@linkcode CriticalCatchChanceBoosterModifier} + * @param boost {@linkcode NumberHolder} holding the boost value + * @returns always `true` + */ + override apply(boost: NumberHolder): boolean { + // 1 stack: 2x + // 2 stack: 2.5x + // 3 stack: 3x + boost.value *= 1.5 + this.getStackCount() / 2; + + return true; + } + + getMaxStackCount(scene: BattleScene): number { + return 3; + } +} + export class LockModifierTiersModifier extends PersistentModifier { - constructor(type: ModifierType, stackCount?: integer) { + constructor(type: ModifierType, stackCount?: number) { super(type, stackCount); } @@ -2559,7 +3026,11 @@ export class LockModifierTiersModifier extends PersistentModifier { return modifier instanceof LockModifierTiersModifier; } - apply(args: any[]): boolean { + /** + * Applies {@linkcode LockModifierTiersModifier} + * @returns always `true` + */ + override apply(): boolean { return true; } @@ -2567,7 +3038,7 @@ export class LockModifierTiersModifier extends PersistentModifier { return new LockModifierTiersModifier(this.type, this.stackCount); } - getMaxStackCount(scene: BattleScene): integer { + getMaxStackCount(scene: BattleScene): number { return 1; } } @@ -2576,8 +3047,12 @@ export class LockModifierTiersModifier extends PersistentModifier { * Black Sludge item */ export class HealShopCostModifier extends PersistentModifier { - constructor(type: ModifierType, stackCount?: integer) { + public readonly shopMultiplier: number; + + constructor(type: ModifierType, shopMultiplier: number, stackCount?: number) { super(type, stackCount); + + this.shopMultiplier = shopMultiplier ?? 2.5; } match(modifier: Modifier): boolean { @@ -2585,22 +3060,31 @@ export class HealShopCostModifier extends PersistentModifier { } clone(): HealShopCostModifier { - return new HealShopCostModifier(this.type, this.stackCount); + return new HealShopCostModifier(this.type, this.shopMultiplier, this.stackCount); } - apply(args: any[]): boolean { - (args[0] as Utils.IntegerHolder).value *= Math.pow(3, this.getStackCount()); + /** + * Applies {@linkcode HealShopCostModifier} + * @param cost {@linkcode NumberHolder} holding the heal shop cost + * @returns always `true` + */ + apply(moneyCost: NumberHolder): boolean { + moneyCost.value = Math.floor(moneyCost.value * this.shopMultiplier); return true; } - getMaxStackCount(scene: BattleScene): integer { + getArgs(): any[] { + return super.getArgs().concat(this.shopMultiplier); + } + + getMaxStackCount(scene: BattleScene): number { return 1; } } export class BoostBugSpawnModifier extends PersistentModifier { - constructor(type: ModifierType, stackCount?: integer) { + constructor(type: ModifierType, stackCount?: number) { super(type, stackCount); } @@ -2608,21 +3092,25 @@ export class BoostBugSpawnModifier extends PersistentModifier { return modifier instanceof BoostBugSpawnModifier; } - clone(): HealShopCostModifier { + clone(): BoostBugSpawnModifier { return new BoostBugSpawnModifier(this.type, this.stackCount); } - apply(args: any[]): boolean { + /** + * Applies {@linkcode BoostBugSpawnModifier} + * @returns always `true` + */ + override apply(): boolean { return true; } - getMaxStackCount(scene: BattleScene): integer { + getMaxStackCount(scene: BattleScene): number { return 1; } } export class SwitchEffectTransferModifier extends PokemonHeldItemModifier { - constructor(type: ModifierType, pokemonId: integer, stackCount?: integer) { + constructor(type: ModifierType, pokemonId: number, stackCount?: number) { super(type, pokemonId, stackCount); } @@ -2634,11 +3122,15 @@ export class SwitchEffectTransferModifier extends PokemonHeldItemModifier { return new SwitchEffectTransferModifier(this.type, this.pokemonId, this.stackCount); } - apply(args: any[]): boolean { + /** + * Applies {@linkcode SwitchEffectTransferModifier} + * @returns always `true` + */ + override apply(): boolean { return true; } - getMaxHeldItemCount(pokemon: Pokemon): integer { + getMaxHeldItemCount(pokemon: Pokemon): number { return 1; } } @@ -2649,18 +3141,17 @@ export class SwitchEffectTransferModifier extends PokemonHeldItemModifier { * @see {@linkcode ContactHeldItemTransferChanceModifier} */ export abstract class HeldItemTransferModifier extends PokemonHeldItemModifier { - constructor(type: ModifierType, pokemonId: integer, stackCount?: integer) { + constructor(type: ModifierType, pokemonId: number, stackCount?: number) { super(type, pokemonId, stackCount); } /** * Determines the targets to transfer items from when this applies. - * @param args\[0\] the {@linkcode Pokemon} holding this item + * @param pokemon the {@linkcode Pokemon} holding this item + * @param _args N/A * @returns the opponents of the source {@linkcode Pokemon} */ - getTargets(args: any[]): Pokemon[] { - const pokemon = args[0]; - + getTargets(pokemon?: Pokemon, ..._args: unknown[]): Pokemon[] { return pokemon instanceof Pokemon ? pokemon.getOpponents() : []; @@ -2669,12 +3160,13 @@ export abstract class HeldItemTransferModifier extends PokemonHeldItemModifier { /** * Steals an item from a set of target Pokemon. * This prioritizes high-tier held items when selecting the item to steal. - * @param args \[0\] The {@linkcode Pokemon} holding this item - * @returns true if an item was stolen; false otherwise. + * @param pokemon The {@linkcode Pokemon} holding this item + * @param target The {@linkcode Pokemon} to steal from (optional) + * @param _args N/A + * @returns `true` if an item was stolen; false otherwise. */ - apply(args: any[]): boolean { - const pokemon = args[0] as Pokemon; - const opponents = this.getTargets(args); + override apply(pokemon: Pokemon, target?: Pokemon, ..._args: unknown[]): boolean { + const opponents = this.getTargets(pokemon, target); if (!opponents.length) { return false; @@ -2687,11 +3179,11 @@ export abstract class HeldItemTransferModifier extends PokemonHeldItemModifier { return false; } - const poolType = pokemon.isPlayer() ? ModifierTypes.ModifierPoolType.PLAYER : pokemon.hasTrainer() ? ModifierTypes.ModifierPoolType.TRAINER : ModifierTypes.ModifierPoolType.WILD; + const poolType = pokemon.isPlayer() ? ModifierPoolType.PLAYER : pokemon.hasTrainer() ? ModifierPoolType.TRAINER : ModifierPoolType.WILD; - const transferredModifierTypes: ModifierTypes.ModifierType[] = []; + const transferredModifierTypes: ModifierType[] = []; const itemModifiers = pokemon.scene.findModifiers(m => m instanceof PokemonHeldItemModifier - && m.pokemonId === targetPokemon.id && m.isTransferrable, targetPokemon.isPlayer()) as PokemonHeldItemModifier[]; + && m.pokemonId === targetPokemon.id && m.isTransferable, targetPokemon.isPlayer()) as PokemonHeldItemModifier[]; let highestItemTier = itemModifiers.map(m => m.type.getOrInferTier(poolType)).reduce((highestTier, tier) => Math.max(tier!, highestTier), 0); // TODO: is this bang correct? let tierItemModifiers = itemModifiers.filter(m => m.type.getOrInferTier(poolType) === highestItemTier); @@ -2725,9 +3217,9 @@ export abstract class HeldItemTransferModifier extends PokemonHeldItemModifier { return !!transferredModifierTypes.length; } - abstract getTransferredItemCount(): integer; + abstract getTransferredItemCount(): number; - abstract getTransferMessage(pokemon: Pokemon, targetPokemon: Pokemon, item: ModifierTypes.ModifierType): string; + abstract getTransferMessage(pokemon: Pokemon, targetPokemon: Pokemon, item: ModifierType): string; } /** @@ -2736,8 +3228,8 @@ export abstract class HeldItemTransferModifier extends PokemonHeldItemModifier { * @see {@linkcode modifierTypes[MINI_BLACK_HOLE]} */ export class TurnHeldItemTransferModifier extends HeldItemTransferModifier { - isTransferrable: boolean = true; - constructor(type: ModifierType, pokemonId: integer, stackCount?: integer) { + isTransferable: boolean = true; + constructor(type: ModifierType, pokemonId: number, stackCount?: number) { super(type, pokemonId, stackCount); } @@ -2749,20 +3241,20 @@ export class TurnHeldItemTransferModifier extends HeldItemTransferModifier { return new TurnHeldItemTransferModifier(this.type, this.pokemonId, this.stackCount); } - getTransferredItemCount(): integer { + getTransferredItemCount(): number { return this.getStackCount(); } - getTransferMessage(pokemon: Pokemon, targetPokemon: Pokemon, item: ModifierTypes.ModifierType): string { + getTransferMessage(pokemon: Pokemon, targetPokemon: Pokemon, item: ModifierType): string { return i18next.t("modifier:turnHeldItemTransferApply", { pokemonNameWithAffix: getPokemonNameWithAffix(targetPokemon), itemName: item.name, pokemonName: pokemon.getNameToRender(), typeName: this.type.name }); } - getMaxHeldItemCount(pokemon: Pokemon): integer { + getMaxHeldItemCount(pokemon: Pokemon): number { return 1; } setTransferrableFalse(): void { - this.isTransferrable = false; + this.isTransferable = false; } } @@ -2773,9 +3265,9 @@ export class TurnHeldItemTransferModifier extends HeldItemTransferModifier { * @see {@linkcode HeldItemTransferModifier} */ export class ContactHeldItemTransferChanceModifier extends HeldItemTransferModifier { - private chance: number; + public readonly chance: number; - constructor(type: ModifierType, pokemonId: integer, chancePercent: number, stackCount?: integer) { + constructor(type: ModifierType, pokemonId: number, chancePercent: number, stackCount?: number) { super(type, pokemonId, stackCount); this.chance = chancePercent / 100; @@ -2783,16 +3275,12 @@ export class ContactHeldItemTransferChanceModifier extends HeldItemTransferModif /** * Determines the target to steal items from when this applies. - * @param args\[0\] The {@linkcode Pokemon} holding this item - * @param args\[1\] The {@linkcode Pokemon} the holder is targeting with an attack - * @returns The target (args[1]) stored in array format for use in {@linkcode HeldItemTransferModifier.apply} + * @param _holderPokemon The {@linkcode Pokemon} holding this item + * @param targetPokemon The {@linkcode Pokemon} the holder is targeting with an attack + * @returns The target {@linkcode Pokemon} as array for further use in `apply` implementations */ - getTargets(args: any[]): Pokemon[] { - const target = args[1]; - - return target instanceof Pokemon - ? [ target ] - : []; + override getTargets(_holderPokemon: Pokemon, targetPokemon: Pokemon): Pokemon[] { + return !!targetPokemon ? [ targetPokemon ] : []; } matchType(modifier: Modifier): boolean { @@ -2807,21 +3295,21 @@ export class ContactHeldItemTransferChanceModifier extends HeldItemTransferModif return super.getArgs().concat(this.chance * 100); } - getTransferredItemCount(): integer { + getTransferredItemCount(): number { return Phaser.Math.RND.realInRange(0, 1) < (this.chance * this.getStackCount()) ? 1 : 0; } - getTransferMessage(pokemon: Pokemon, targetPokemon: Pokemon, item: ModifierTypes.ModifierType): string { + getTransferMessage(pokemon: Pokemon, targetPokemon: Pokemon, item: ModifierType): string { return i18next.t("modifier:contactHeldItemTransferApply", { pokemonNameWithAffix: getPokemonNameWithAffix(targetPokemon), itemName: item.name, pokemonName: getPokemonNameWithAffix(pokemon), typeName: this.type.name }); } - getMaxHeldItemCount(pokemon: Pokemon): integer { + getMaxHeldItemCount(pokemon: Pokemon): number { return 5; } } export class IvScannerModifier extends PersistentModifier { - constructor(type: ModifierType, stackCount?: integer) { + constructor(type: ModifierType, stackCount?: number) { super(type, stackCount); } @@ -2833,17 +3321,21 @@ export class IvScannerModifier extends PersistentModifier { return new IvScannerModifier(this.type, this.stackCount); } - apply(args: any[]): boolean { + /** + * Applies {@linkcode IvScannerModifier} + * @returns always `true` + */ + override apply(): boolean { return true; } - getMaxStackCount(scene: BattleScene): integer { + getMaxStackCount(scene: BattleScene): number { return 3; } } export class ExtraModifierModifier extends PersistentModifier { - constructor(type: ModifierType, stackCount?: integer) { + constructor(type: ModifierType, stackCount?: number) { super(type, stackCount); } @@ -2855,23 +3347,82 @@ export class ExtraModifierModifier extends PersistentModifier { return new ExtraModifierModifier(this.type, this.stackCount); } - apply(args: any[]): boolean { - (args[0] as Utils.IntegerHolder).value += this.getStackCount(); + /** + * Applies {@linkcode ExtraModifierModifier} + * @param count {NumberHolder} holding the count value + * @returns always `true` + */ + override apply(count: NumberHolder): boolean { + count.value += this.getStackCount(); return true; } - getMaxStackCount(scene: BattleScene): integer { + getMaxStackCount(scene: BattleScene): number { return 3; } } +/** + * Modifier used for timed boosts to the player's shop item rewards. + * @extends LapsingPersistentModifier + * @see {@linkcode apply} + */ +export class TempExtraModifierModifier extends LapsingPersistentModifier { + constructor(type: ModifierType, maxBattles: number, battleCount?: number, stackCount?: number) { + super(type, maxBattles, battleCount, stackCount); + } + + /** + * Goes through existing modifiers for any that match Silver Pokeball, + * which will then add the max count of the new item to the existing count of the current item. + * If no existing Silver Pokeballs are found, will add a new one. + * @param modifiers {@linkcode PersistentModifier} array of the player's modifiers + * @param _virtual N/A + * @param scene + * @returns true if the modifier was successfully added or applied, false otherwise + */ + add(modifiers: PersistentModifier[], _virtual: boolean, scene: BattleScene): boolean { + for (const modifier of modifiers) { + if (this.match(modifier)) { + const modifierInstance = modifier as TempExtraModifierModifier; + const newBattleCount = this.getMaxBattles() + modifierInstance.getBattleCount(); + + modifierInstance.setNewBattleCount(newBattleCount); + scene.playSound("se/restore"); + return true; + } + } + + modifiers.push(this); + return true; + } + + clone() { + return new TempExtraModifierModifier(this.type, this.getMaxBattles(), this.getBattleCount(), this.stackCount); + } + + match(modifier: Modifier): boolean { + return (modifier instanceof TempExtraModifierModifier); + } + + /** + * Increases the current rewards in the battle by the `stackCount`. + * @returns `true` if the shop reward number modifier applies successfully + * @param count {@linkcode NumberHolder} that holds the resulting shop item reward count + */ + apply(count: NumberHolder): boolean { + count.value += this.getStackCount(); + return true; + } +} + export abstract class EnemyPersistentModifier extends PersistentModifier { - constructor(type: ModifierType, stackCount?: integer) { + constructor(type: ModifierType, stackCount?: number) { super(type, stackCount); } - getMaxStackCount(scene: BattleScene): integer { + getMaxStackCount(scene: BattleScene): number { return 5; } } @@ -2879,25 +3430,30 @@ export abstract class EnemyPersistentModifier extends PersistentModifier { abstract class EnemyDamageMultiplierModifier extends EnemyPersistentModifier { protected damageMultiplier: number; - constructor(type: ModifierType, damageMultiplier: number, stackCount?: integer) { + constructor(type: ModifierType, damageMultiplier: number, stackCount?: number) { super(type, stackCount); this.damageMultiplier = damageMultiplier; } - apply(args: any[]): boolean { - (args[0] as Utils.NumberHolder).value = Math.floor((args[0] as Utils.NumberHolder).value * Math.pow(this.damageMultiplier, this.getStackCount())); + /** + * Applies {@linkcode EnemyDamageMultiplierModifier} + * @param multiplier {NumberHolder} holding the multiplier value + * @returns always `true` + */ + override apply(multiplier: NumberHolder): boolean { + multiplier.value = Math.floor(multiplier.value * Math.pow(this.damageMultiplier, this.getStackCount())); return true; } - getMaxStackCount(scene: BattleScene): integer { + getMaxStackCount(scene: BattleScene): number { return 99; } } export class EnemyDamageBoosterModifier extends EnemyDamageMultiplierModifier { - constructor(type: ModifierType, boostPercent: number, stackCount?: integer) { + constructor(type: ModifierType, boostPercent: number, stackCount?: number) { //super(type, 1 + ((boostPercent || 10) * 0.01), stackCount); super(type, 1.05, stackCount); // Hardcode multiplier temporarily } @@ -2914,13 +3470,13 @@ export class EnemyDamageBoosterModifier extends EnemyDamageMultiplierModifier { return [ (this.damageMultiplier - 1) * 100 ]; } - getMaxStackCount(scene: BattleScene): integer { + getMaxStackCount(scene: BattleScene): number { return 999; } } export class EnemyDamageReducerModifier extends EnemyDamageMultiplierModifier { - constructor(type: ModifierType, reductionPercent: number, stackCount?: integer) { + constructor(type: ModifierType, reductionPercent: number, stackCount?: number) { //super(type, 1 - ((reductionPercent || 5) * 0.01), stackCount); super(type, 0.975, stackCount); // Hardcode multiplier temporarily } @@ -2937,7 +3493,7 @@ export class EnemyDamageReducerModifier extends EnemyDamageMultiplierModifier { return [ (1 - this.damageMultiplier) * 100 ]; } - getMaxStackCount(scene: BattleScene): integer { + getMaxStackCount(scene: BattleScene): number { return scene.currentBattle.waveIndex < 2000 ? super.getMaxStackCount(scene) : 999; } } @@ -2945,7 +3501,7 @@ export class EnemyDamageReducerModifier extends EnemyDamageMultiplierModifier { export class EnemyTurnHealModifier extends EnemyPersistentModifier { public healPercent: number; - constructor(type: ModifierType, healPercent: number, stackCount?: integer) { + constructor(type: ModifierType, healPercent: number, stackCount?: number) { super(type, stackCount); // Hardcode temporarily @@ -2964,20 +3520,23 @@ export class EnemyTurnHealModifier extends EnemyPersistentModifier { return [ this.healPercent ]; } - apply(args: any[]): boolean { - const pokemon = args[0] as Pokemon; - - if (!pokemon.isFullHp()) { - const scene = pokemon.scene; - scene.unshiftPhase(new PokemonHealPhase(scene, pokemon.getBattlerIndex(), - Math.max(Math.floor(pokemon.getMaxHp() / (100 / this.healPercent)) * this.stackCount, 1), i18next.t("modifier:enemyTurnHealApply", { pokemonNameWithAffix: getPokemonNameWithAffix(pokemon) }), true, false, false, false, true)); + /** + * Applies {@linkcode EnemyTurnHealModifier} + * @param enemyPokemon The {@linkcode Pokemon} to heal + * @returns `true` if the {@linkcode Pokemon} was healed + */ + override apply(enemyPokemon: Pokemon): boolean { + if (!enemyPokemon.isFullHp()) { + const scene = enemyPokemon.scene; + scene.unshiftPhase(new PokemonHealPhase(scene, enemyPokemon.getBattlerIndex(), + Math.max(Math.floor(enemyPokemon.getMaxHp() / (100 / this.healPercent)) * this.stackCount, 1), i18next.t("modifier:enemyTurnHealApply", { pokemonNameWithAffix: getPokemonNameWithAffix(enemyPokemon) }), true, false, false, false, true)); return true; } return false; } - getMaxStackCount(scene: BattleScene): integer { + getMaxStackCount(scene: BattleScene): number { return 10; } } @@ -2986,7 +3545,7 @@ export class EnemyAttackStatusEffectChanceModifier extends EnemyPersistentModifi public effect: StatusEffect; public chance: number; - constructor(type: ModifierType, effect: StatusEffect, chancePercent: number, stackCount?: integer) { + constructor(type: ModifierType, effect: StatusEffect, chancePercent: number, stackCount?: number) { super(type, stackCount); this.effect = effect; @@ -3006,16 +3565,20 @@ export class EnemyAttackStatusEffectChanceModifier extends EnemyPersistentModifi return [ this.effect, this.chance * 100 ]; } - apply(args: any[]): boolean { - const target = (args[0] as Pokemon); + /** + * Applies {@linkcode EnemyAttackStatusEffectChanceModifier} + * @param enemyPokemon {@linkcode Pokemon} to apply the status effect to + * @returns `true` if the {@linkcode Pokemon} was affected + */ + override apply(enemyPokemon: Pokemon): boolean { if (Phaser.Math.RND.realInRange(0, 1) < (this.chance * this.getStackCount())) { - return target.trySetStatus(this.effect, true); + return enemyPokemon.trySetStatus(this.effect, true); } return false; } - getMaxStackCount(scene: BattleScene): integer { + getMaxStackCount(scene: BattleScene): number { return 10; } } @@ -3023,7 +3586,7 @@ export class EnemyAttackStatusEffectChanceModifier extends EnemyPersistentModifi export class EnemyStatusEffectHealChanceModifier extends EnemyPersistentModifier { public chance: number; - constructor(type: ModifierType, chancePercent: number, stackCount?: integer) { + constructor(type: ModifierType, chancePercent: number, stackCount?: number) { super(type, stackCount); //Hardcode temporarily @@ -3042,19 +3605,23 @@ export class EnemyStatusEffectHealChanceModifier extends EnemyPersistentModifier return [ this.chance * 100 ]; } - apply(args: any[]): boolean { - const target = (args[0] as Pokemon); - if (target.status && Phaser.Math.RND.realInRange(0, 1) < (this.chance * this.getStackCount())) { - target.scene.queueMessage(getStatusEffectHealText(target.status.effect, getPokemonNameWithAffix(target))); - target.resetStatus(); - target.updateInfo(); + /** + * Applies {@linkcode EnemyStatusEffectHealChanceModifier} + * @param enemyPokemon The {@linkcode Pokemon} to heal + * @returns `true` if the {@linkcode Pokemon} was healed + */ + override apply(enemyPokemon: Pokemon): boolean { + if (enemyPokemon.status && Phaser.Math.RND.realInRange(0, 1) < (this.chance * this.getStackCount())) { + enemyPokemon.scene.queueMessage(getStatusEffectHealText(enemyPokemon.status.effect, getPokemonNameWithAffix(enemyPokemon))); + enemyPokemon.resetStatus(); + enemyPokemon.updateInfo(); return true; } return false; } - getMaxStackCount(scene: BattleScene): integer { + getMaxStackCount(scene: BattleScene): number { return 10; } } @@ -3062,11 +3629,11 @@ export class EnemyStatusEffectHealChanceModifier extends EnemyPersistentModifier export class EnemyEndureChanceModifier extends EnemyPersistentModifier { public chance: number; - constructor(type: ModifierType, chancePercent?: number, stackCount?: integer) { + constructor(type: ModifierType, chancePercent?: number, stackCount?: number) { super(type, stackCount || 10); //Hardcode temporarily - this.chance = .02; + this.chance = 2; } match(modifier: Modifier) { @@ -3074,28 +3641,31 @@ export class EnemyEndureChanceModifier extends EnemyPersistentModifier { } clone() { - return new EnemyEndureChanceModifier(this.type, this.chance * 100, this.stackCount); + return new EnemyEndureChanceModifier(this.type, this.chance, this.stackCount); } getArgs(): any[] { - return [ this.chance * 100 ]; + return [ this.chance ]; } - apply(args: any[]): boolean { - const target = (args[0] as Pokemon); - - if (target.battleData.endured || Phaser.Math.RND.realInRange(0, 1) >= (this.chance * this.getStackCount())) { + /** + * Applies a chance of enduring a lethal hit of an attack + * @param target the {@linkcode Pokemon} to apply the {@linkcode BattlerTagType.ENDURING} chance to + * @returns `true` if {@linkcode Pokemon} endured + */ + override apply(target: Pokemon): boolean { + if (target.battleData.endured || target.randSeedInt(100) >= (this.chance * this.getStackCount())) { return false; } - target.addTag(BattlerTagType.ENDURING, 1); + target.addTag(BattlerTagType.ENDURE_TOKEN, 1); target.battleData.endured = true; return true; } - getMaxStackCount(scene: BattleScene): integer { + getMaxStackCount(scene: BattleScene): number { return 10; } } @@ -3103,7 +3673,7 @@ export class EnemyEndureChanceModifier extends EnemyPersistentModifier { export class EnemyFusionChanceModifier extends EnemyPersistentModifier { private chance: number; - constructor(type: ModifierType, chancePercent: number, stackCount?: integer) { + constructor(type: ModifierType, chancePercent: number, stackCount?: number) { super(type, stackCount); this.chance = chancePercent / 100; @@ -3121,17 +3691,22 @@ export class EnemyFusionChanceModifier extends EnemyPersistentModifier { return [ this.chance * 100 ]; } - apply(args: any[]): boolean { + /** + * Applies {@linkcode EnemyFusionChanceModifier} + * @param isFusion {@linkcode BooleanHolder} that will be set to `true` if the {@linkcode EnemyPokemon} is a fusion + * @returns `true` if the {@linkcode EnemyPokemon} is a fusion + */ + override apply(isFusion: BooleanHolder): boolean { if (Phaser.Math.RND.realInRange(0, 1) >= (this.chance * this.getStackCount())) { return false; } - (args[0] as Utils.BooleanHolder).value = true; + isFusion.value = true; return true; } - getMaxStackCount(scene: BattleScene): integer { + getMaxStackCount(scene: BattleScene): number { return 10; } } @@ -3144,7 +3719,7 @@ export class EnemyFusionChanceModifier extends EnemyPersistentModifier { * @param isPlayer {@linkcode boolean} for whether the player (`true`) or enemy (`false`) is being overridden */ export function overrideModifiers(scene: BattleScene, isPlayer: boolean = true): void { - const modifiersOverride: ModifierTypes.ModifierOverride[] = isPlayer ? Overrides.STARTING_MODIFIER_OVERRIDE : Overrides.OPP_MODIFIER_OVERRIDE; + const modifiersOverride: ModifierOverride[] = isPlayer ? Overrides.STARTING_MODIFIER_OVERRIDE : Overrides.OPP_MODIFIER_OVERRIDE; if (!modifiersOverride || modifiersOverride.length === 0 || !scene) { return; } @@ -3158,8 +3733,8 @@ export function overrideModifiers(scene: BattleScene, isPlayer: boolean = true): const modifierFunc = modifierTypes[item.name]; let modifierType: ModifierType | null = modifierFunc(); - if (modifierType instanceof ModifierTypes.ModifierTypeGenerator) { - const pregenArgs = ("type" in item) && (item.type !== null) ? [item.type] : undefined; + if (modifierType instanceof ModifierTypeGenerator) { + const pregenArgs = ("type" in item) && (item.type !== null) ? [ item.type ] : undefined; modifierType = modifierType.generateType([], pregenArgs); } @@ -3185,13 +3760,13 @@ export function overrideModifiers(scene: BattleScene, isPlayer: boolean = true): * @param isPlayer {@linkcode boolean} for whether the {@linkcode pokemon} is the player's (`true`) or an enemy (`false`) */ export function overrideHeldItems(scene: BattleScene, pokemon: Pokemon, isPlayer: boolean = true): void { - const heldItemsOverride: ModifierTypes.ModifierOverride[] = isPlayer ? Overrides.STARTING_HELD_ITEMS_OVERRIDE : Overrides.OPP_HELD_ITEMS_OVERRIDE; + const heldItemsOverride: ModifierOverride[] = isPlayer ? Overrides.STARTING_HELD_ITEMS_OVERRIDE : Overrides.OPP_HELD_ITEMS_OVERRIDE; if (!heldItemsOverride || heldItemsOverride.length === 0 || !scene) { return; } if (!isPlayer) { - scene.clearEnemyHeldItemModifiers(); + scene.clearEnemyHeldItemModifiers(pokemon); } heldItemsOverride.forEach(item => { @@ -3199,8 +3774,8 @@ export function overrideHeldItems(scene: BattleScene, pokemon: Pokemon, isPlayer let modifierType: ModifierType | null = modifierFunc(); const qty = item.count || 1; - if (modifierType instanceof ModifierTypes.ModifierTypeGenerator) { - const pregenArgs = ("type" in item) && (item.type !== null) ? [item.type] : undefined; + if (modifierType instanceof ModifierTypeGenerator) { + const pregenArgs = ("type" in item) && (item.type !== null) ? [ item.type ] : undefined; modifierType = modifierType.generateType([], pregenArgs); } diff --git a/src/overrides.ts b/src/overrides.ts index ec0577ceb3d..7b73cd47b03 100644 --- a/src/overrides.ts +++ b/src/overrides.ts @@ -1,19 +1,20 @@ +import { type PokeballCounts } from "#app/battle-scene"; +import { Gender } from "#app/data/gender"; +import { Variant } from "#app/data/variant"; +import { type ModifierOverride } from "#app/modifier/modifier-type"; +import { Unlockables } from "#app/system/unlockables"; import { Abilities } from "#enums/abilities"; import { Biome } from "#enums/biome"; import { EggTier } from "#enums/egg-type"; import { Moves } from "#enums/moves"; +import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; +import { MysteryEncounterType } from "#enums/mystery-encounter-type"; import { PokeballType } from "#enums/pokeball"; import { Species } from "#enums/species"; import { StatusEffect } from "#enums/status-effect"; import { TimeOfDay } from "#enums/time-of-day"; -import { VariantTier } from "#enums/variant-tiers"; +import { VariantTier } from "#enums/variant-tier"; import { WeatherType } from "#enums/weather-type"; -import { type PokeballCounts } from "./battle-scene"; -import { Gender } from "./data/gender"; -import { Variant } from "./data/variant"; -import { type ModifierOverride } from "./modifier/modifier-type"; -import { MysteryEncounterType } from "#enums/mystery-encounter-type"; -import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; /** * Overrides that are using when testing different in game situations @@ -46,7 +47,18 @@ class DefaultOverrides { /** a specific seed (default: a random string of 24 characters) */ readonly SEED_OVERRIDE: string = ""; readonly WEATHER_OVERRIDE: WeatherType = WeatherType.NONE; - readonly BATTLE_TYPE_OVERRIDE: "double" | "single" | null = null; + /** + * If `null`, ignore this override. + * + * If `"single"`, set every non-trainer battle to be a single battle. + * + * If `"double"`, set every battle (including trainer battles) to be a double battle. + * + * If `"even-doubles"`, follow the `"double"` rule on even wave numbers, and follow the `"single"` rule on odd wave numbers. + * + * If `"odd-doubles"`, follow the `"double"` rule on odd wave numbers, and follow the `"single"` rule on even wave numbers. + */ + readonly BATTLE_TYPE_OVERRIDE: BattleStyle | null = null; readonly STARTING_WAVE_OVERRIDE: number = 0; readonly STARTING_BIOME_OVERRIDE: Biome = Biome.TOWN; readonly ARENA_TINT_OVERRIDE: TimeOfDay | null = null; @@ -70,8 +82,12 @@ class DefaultOverrides { [PokeballType.MASTER_BALL]: 0, }, }; + /** Forces an item to be UNLOCKED */ + readonly ITEM_UNLOCK_OVERRIDE: Unlockables[] = []; /** Set to `true` to show all tutorials */ - readonly BYPASS_TUTORIAL_SKIP: boolean = false; + readonly BYPASS_TUTORIAL_SKIP_OVERRIDE: boolean = false; + /** Set to `true` to force Paralysis and Freeze to always activate, or `false` to force them to not activate */ + readonly STATUS_ACTIVATION_OVERRIDE: boolean | null = null; // ---------------- // PLAYER OVERRIDES @@ -97,26 +113,42 @@ class DefaultOverrides { * @example SPECIES_OVERRIDE = Species.Bulbasaur; */ readonly STARTER_SPECIES_OVERRIDE: Species | number = 0; + /** + * This will force your starter to be a random fusion + */ + readonly STARTER_FUSION_OVERRIDE: boolean = false; + /** + * This will override the species of the fusion + */ + readonly STARTER_FUSION_SPECIES_OVERRIDE: Species | integer = 0; readonly ABILITY_OVERRIDE: Abilities = Abilities.NONE; readonly PASSIVE_ABILITY_OVERRIDE: Abilities = Abilities.NONE; readonly STATUS_OVERRIDE: StatusEffect = StatusEffect.NONE; readonly GENDER_OVERRIDE: Gender | null = null; readonly MOVESET_OVERRIDE: Moves | Array = []; - readonly SHINY_OVERRIDE: boolean = false; - readonly VARIANT_OVERRIDE: Variant = 0; + readonly SHINY_OVERRIDE: boolean | null = null; + readonly VARIANT_OVERRIDE: Variant | null = null; // -------------------------- // OPPONENT / ENEMY OVERRIDES // -------------------------- readonly OPP_SPECIES_OVERRIDE: Species | number = 0; + /** + * This will make all opponents fused Pokemon + */ + readonly OPP_FUSION_OVERRIDE: boolean = false; + /** + * This will override the species of the fusion only when the opponent is already a fusion + */ + readonly OPP_FUSION_SPECIES_OVERRIDE: Species | integer = 0; readonly OPP_LEVEL_OVERRIDE: number = 0; readonly OPP_ABILITY_OVERRIDE: Abilities = Abilities.NONE; readonly OPP_PASSIVE_ABILITY_OVERRIDE: Abilities = Abilities.NONE; readonly OPP_STATUS_OVERRIDE: StatusEffect = StatusEffect.NONE; readonly OPP_GENDER_OVERRIDE: Gender | null = null; readonly OPP_MOVESET_OVERRIDE: Moves | Array = []; - readonly OPP_SHINY_OVERRIDE: boolean = false; - readonly OPP_VARIANT_OVERRIDE: Variant = 0; + readonly OPP_SHINY_OVERRIDE: boolean | null = null; + readonly OPP_VARIANT_OVERRIDE: Variant | null = null; readonly OPP_IVS_OVERRIDE: number | number[] = []; readonly OPP_FORM_OVERRIDES: Partial> = {}; /** @@ -137,6 +169,7 @@ class DefaultOverrides { readonly EGG_VARIANT_OVERRIDE: VariantTier | null = null; readonly EGG_FREE_GACHA_PULLS_OVERRIDE: boolean = false; readonly EGG_GACHA_PULL_COUNT_OVERRIDE: number = 0; + readonly UNLIMITED_EGG_COUNT_OVERRIDE: boolean = false; // ------------------------- // MYSTERY ENCOUNTER OVERRIDES @@ -207,3 +240,5 @@ export default { ...defaultOverrides, ...overrides } satisfies InstanceType; + +export type BattleStyle = "double" | "single" | "even-doubles" | "odd-doubles"; diff --git a/src/phase.ts b/src/phase.ts index 02939757112..5cf91f2c478 100644 --- a/src/phase.ts +++ b/src/phase.ts @@ -8,7 +8,6 @@ export class Phase { } start() { - console.log(`%cStart Phase ${this.constructor.name}`, "color:green;"); if (this.scene.abilityBar.shown) { this.scene.abilityBar.resetAutoHideTimer(); } diff --git a/src/phases/attempt-capture-phase.ts b/src/phases/attempt-capture-phase.ts index 53723526c14..de10d1eca45 100644 --- a/src/phases/attempt-capture-phase.ts +++ b/src/phases/attempt-capture-phase.ts @@ -1,21 +1,22 @@ -import BattleScene from "#app/battle-scene"; import { BattlerIndex } from "#app/battle"; -import { getPokeballCatchMultiplier, getPokeballAtlasKey, getPokeballTintColor, doPokeballBounceAnim } from "#app/data/pokeball"; +import BattleScene from "#app/battle-scene"; +import { PLAYER_PARTY_MAX_SIZE } from "#app/constants"; +import { SubstituteTag } from "#app/data/battler-tags"; +import { doPokeballBounceAnim, getPokeballAtlasKey, getPokeballCatchMultiplier, getPokeballTintColor, getCriticalCaptureChance } from "#app/data/pokeball"; import { getStatusEffectCatchRateMultiplier } from "#app/data/status-effect"; -import { PokeballType } from "#app/enums/pokeball"; -import { StatusEffect } from "#app/enums/status-effect"; -import { addPokeballOpenParticles, addPokeballCaptureStars } from "#app/field/anims"; +import { addPokeballCaptureStars, addPokeballOpenParticles } from "#app/field/anims"; import { EnemyPokemon } from "#app/field/pokemon"; import { getPokemonNameWithAffix } from "#app/messages"; import { PokemonHeldItemModifier } from "#app/modifier/modifier"; +import { PokemonPhase } from "#app/phases/pokemon-phase"; +import { VictoryPhase } from "#app/phases/victory-phase"; import { achvs } from "#app/system/achv"; -import { PartyUiMode, PartyOption } from "#app/ui/party-ui-handler"; +import { PartyOption, PartyUiMode } from "#app/ui/party-ui-handler"; import { SummaryUiMode } from "#app/ui/summary-ui-handler"; import { Mode } from "#app/ui/ui"; +import { PokeballType } from "#enums/pokeball"; +import { StatusEffect } from "#enums/status-effect"; import i18next from "i18next"; -import { PokemonPhase } from "./pokemon-phase"; -import { VictoryPhase } from "./victory-phase"; -import { SubstituteTag } from "#app/data/battler-tags"; export class AttemptCapturePhase extends PokemonPhase { private pokeballType: PokeballType; @@ -51,8 +52,10 @@ export class AttemptCapturePhase extends PokemonPhase { const catchRate = pokemon.species.catchRate; const pokeballMultiplier = getPokeballCatchMultiplier(this.pokeballType); const statusMultiplier = pokemon.status ? getStatusEffectCatchRateMultiplier(pokemon.status.effect) : 1; - const x = Math.round((((_3m - _2h) * catchRate * pokeballMultiplier) / _3m) * statusMultiplier); - const y = Math.round(65536 / Math.sqrt(Math.sqrt(255 / x))); + const modifiedCatchRate = Math.round((((_3m - _2h) * catchRate * pokeballMultiplier) / _3m) * statusMultiplier); + const shakeProbability = Math.round(65536 / Math.pow((255 / modifiedCatchRate), 0.1875)); // Formula taken from gen 6 + const criticalCaptureChance = getCriticalCaptureChance(this.scene, modifiedCatchRate); + const isCritical = pokemon.randSeedInt(256) < criticalCaptureChance; const fpOffset = pokemon.getFieldPositionOffset(); const pokeballAtlasKey = getPokeballAtlasKey(this.pokeballType); @@ -60,17 +63,19 @@ export class AttemptCapturePhase extends PokemonPhase { this.pokeball.setOrigin(0.5, 0.625); this.scene.field.add(this.pokeball); - this.scene.playSound("se/pb_throw"); + this.scene.playSound("se/pb_throw", isCritical ? { rate: 0.2 } : undefined); // Crit catch throws are higher pitched this.scene.time.delayedCall(300, () => { this.scene.field.moveBelow(this.pokeball as Phaser.GameObjects.GameObject, pokemon); }); this.scene.tweens.add({ + // Throw animation targets: this.pokeball, x: { value: 236 + fpOffset[0], ease: "Linear" }, y: { value: 16 + fpOffset[1], ease: "Cubic.easeOut" }, duration: 500, onComplete: () => { + // Ball opens this.pokeball.setTexture("pb", `${pokeballAtlasKey}_opening`); this.scene.time.delayedCall(17, () => this.pokeball.setTexture("pb", `${pokeballAtlasKey}_open`)); this.scene.playSound("se/pb_rel"); @@ -79,30 +84,33 @@ export class AttemptCapturePhase extends PokemonPhase { addPokeballOpenParticles(this.scene, this.pokeball.x, this.pokeball.y, this.pokeballType); this.scene.tweens.add({ + // Mon enters ball targets: pokemon, duration: 500, ease: "Sine.easeIn", scale: 0.25, y: 20, onComplete: () => { + // Ball closes this.pokeball.setTexture("pb", `${pokeballAtlasKey}_opening`); pokemon.setVisible(false); this.scene.playSound("se/pb_catch"); this.scene.time.delayedCall(17, () => this.pokeball.setTexture("pb", `${pokeballAtlasKey}`)); const doShake = () => { + // After the overall catch rate check, the game does 3 shake checks before confirming the catch. let shakeCount = 0; const pbX = this.pokeball.x; const shakeCounter = this.scene.tweens.addCounter({ from: 0, to: 1, - repeat: 4, + repeat: isCritical ? 2 : 4, // Critical captures only perform 1 shake check yoyo: true, ease: "Cubic.easeOut", duration: 250, repeatDelay: 500, onUpdate: t => { - if (shakeCount && shakeCount < 4) { + if (shakeCount && shakeCount < (isCritical ? 2 : 4)) { const value = t.getValue(); const directionMultiplier = shakeCount % 2 === 1 ? 1 : -1; this.pokeball.setX(pbX + value * 4 * directionMultiplier); @@ -113,13 +121,18 @@ export class AttemptCapturePhase extends PokemonPhase { if (!pokemon.species.isObtainable()) { shakeCounter.stop(); this.failCatch(shakeCount); - } else if (shakeCount++ < 3) { - if (pokeballMultiplier === -1 || pokemon.randSeedInt(65536) < y) { + } else if (shakeCount++ < (isCritical ? 1 : 3)) { + // Shake check (skip check for critical or guaranteed captures, but still play the sound) + if (pokeballMultiplier === -1 || isCritical || modifiedCatchRate >= 255 || pokemon.randSeedInt(65536) < shakeProbability) { this.scene.playSound("se/pb_move"); } else { shakeCounter.stop(); this.failCatch(shakeCount); } + } else if (isCritical && pokemon.randSeedInt(65536) >= shakeProbability) { + // Above, perform the one shake check for critical captures after the ball shakes once + shakeCounter.stop(); + this.failCatch(shakeCount); } else { this.scene.playSound("se/pb_lock"); addPokeballCaptureStars(this.scene, this.pokeball); @@ -152,7 +165,8 @@ export class AttemptCapturePhase extends PokemonPhase { }); }; - this.scene.time.delayedCall(250, () => doPokeballBounceAnim(this.scene, this.pokeball, 16, 72, 350, doShake)); + // Ball bounces (handled in pokemon.ts) + this.scene.time.delayedCall(250, () => doPokeballBounceAnim(this.scene, this.pokeball, 16, 72, 350, doShake, isCritical)); } }); } @@ -235,7 +249,7 @@ export class AttemptCapturePhase extends PokemonPhase { const addToParty = (slotIndex?: number) => { const newPokemon = pokemon.addToParty(this.pokeballType, slotIndex); const modifiers = this.scene.findModifiers(m => m instanceof PokemonHeldItemModifier, false); - if (this.scene.getParty().filter(p => p.isShiny()).length === 6) { + if (this.scene.getPlayerParty().filter(p => p.isShiny()).length === PLAYER_PARTY_MAX_SIZE) { this.scene.validateAchv(achvs.SHINY_PARTY); } Promise.all(modifiers.map(m => this.scene.addModifier(m, true))).then(() => { @@ -248,8 +262,8 @@ export class AttemptCapturePhase extends PokemonPhase { } }); }; - Promise.all([pokemon.hideInfo(), this.scene.gameData.setPokemonCaught(pokemon)]).then(() => { - if (this.scene.getParty().length === 6) { + Promise.all([ pokemon.hideInfo(), this.scene.gameData.setPokemonCaught(pokemon) ]).then(() => { + if (this.scene.getPlayerParty().length === PLAYER_PARTY_MAX_SIZE) { const promptRelease = () => { this.scene.ui.showText(i18next.t("battle:partyFull", { pokemonName: pokemon.getNameToRender() }), null, () => { this.scene.pokemonInfoContainer.makeRoomForConfirmUi(1, true); diff --git a/src/phases/attempt-run-phase.ts b/src/phases/attempt-run-phase.ts index 46d68f6005a..b4768dc9a26 100644 --- a/src/phases/attempt-run-phase.ts +++ b/src/phases/attempt-run-phase.ts @@ -10,6 +10,10 @@ import { NewBattlePhase } from "./new-battle-phase"; import { PokemonPhase } from "./pokemon-phase"; export class AttemptRunPhase extends PokemonPhase { + + /** For testing purposes: this is to force the pokemon to fail and escape */ + public forceFailEscape = false; + constructor(scene: BattleScene, fieldIndex: number) { super(scene, fieldIndex); } @@ -28,12 +32,12 @@ export class AttemptRunPhase extends PokemonPhase { applyAbAttrs(RunSuccessAbAttr, playerPokemon, null, false, escapeChance); - if (playerPokemon.randSeedInt(100) < escapeChance.value) { + if (playerPokemon.randSeedInt(100) < escapeChance.value && !this.forceFailEscape) { this.scene.playSound("se/flee"); this.scene.queueMessage(i18next.t("battle:runAwaySuccess"), null, true, 500); this.scene.tweens.add({ - targets: [this.scene.arenaEnemy, enemyField].flat(), + targets: [ this.scene.arenaEnemy, enemyField ].flat(), alpha: 0, duration: 250, ease: "Sine.easeIn", @@ -51,6 +55,7 @@ export class AttemptRunPhase extends PokemonPhase { this.scene.pushPhase(new BattleEndPhase(this.scene)); this.scene.pushPhase(new NewBattlePhase(this.scene)); } else { + playerPokemon.turnData.failedRunAway = true; this.scene.queueMessage(i18next.t("battle:runAwayCannotEscape"), null, true, 500); } diff --git a/src/phases/battle-end-phase.ts b/src/phases/battle-end-phase.ts index f08e04b443a..3b9ca012ef7 100644 --- a/src/phases/battle-end-phase.ts +++ b/src/phases/battle-end-phase.ts @@ -1,20 +1,32 @@ +import BattleScene from "#app/battle-scene"; import { applyPostBattleAbAttrs, PostBattleAbAttr } from "#app/data/ability"; import { LapsingPersistentModifier, LapsingPokemonHeldItemModifier } from "#app/modifier/modifier"; import { BattlePhase } from "./battle-phase"; import { GameOverPhase } from "./game-over-phase"; export class BattleEndPhase extends BattlePhase { + /** If true, will increment battles won */ + isVictory: boolean; + + constructor(scene: BattleScene, isVictory: boolean = true) { + super(scene); + + this.isVictory = isVictory; + } + start() { super.start(); - this.scene.currentBattle.addBattleScore(this.scene); + if (this.isVictory) { + this.scene.currentBattle.addBattleScore(this.scene); - this.scene.gameData.gameStats.battles++; - if (this.scene.currentBattle.trainer) { - this.scene.gameData.gameStats.trainersDefeated++; - } - if (this.scene.gameMode.isEndless && this.scene.currentBattle.waveIndex + 1 > this.scene.gameData.gameStats.highestEndlessWave) { - this.scene.gameData.gameStats.highestEndlessWave = this.scene.currentBattle.waveIndex + 1; + this.scene.gameData.gameStats.battles++; + if (this.scene.currentBattle.trainer) { + this.scene.gameData.gameStats.trainersDefeated++; + } + if (this.scene.gameMode.isEndless && this.scene.currentBattle.waveIndex + 1 > this.scene.gameData.gameStats.highestEndlessWave) { + this.scene.gameData.gameStats.highestEndlessWave = this.scene.currentBattle.waveIndex + 1; + } } // Endless graceful end @@ -23,7 +35,13 @@ export class BattleEndPhase extends BattlePhase { this.scene.unshiftPhase(new GameOverPhase(this.scene, true)); } - for (const pokemon of this.scene.getParty().filter(p => p.isAllowedInBattle())) { + for (const pokemon of this.scene.getField()) { + if (pokemon && pokemon.battleSummonData) { + pokemon.battleSummonData.waveTurnCount = 1; + } + } + + for (const pokemon of this.scene.getPokemonAllowedInBattle()) { applyPostBattleAbAttrs(PostBattleAbAttr, pokemon); } @@ -39,7 +57,7 @@ export class BattleEndPhase extends BattlePhase { if (m instanceof LapsingPokemonHeldItemModifier) { args.push(this.scene.getPokemonById(m.pokemonId)); } - if (!m.lapse(args)) { + if (!m.lapse(...args)) { this.scene.removeModifier(m); } } diff --git a/src/phases/battle-phase.ts b/src/phases/battle-phase.ts index b51e19bdf0e..11807fdc714 100644 --- a/src/phases/battle-phase.ts +++ b/src/phases/battle-phase.ts @@ -12,7 +12,7 @@ export class BattlePhase extends Phase { const tintSprites = this.scene.currentBattle.trainer?.getTintSprites()!; // TODO: is this bang correct? for (let i = 0; i < sprites.length; i++) { const visible = !trainerSlot || !i === (trainerSlot === TrainerSlot.TRAINER) || sprites.length < 2; - [sprites[i], tintSprites[i]].map(sprite => { + [ sprites[i], tintSprites[i] ].map(sprite => { if (visible) { sprite.x = trainerSlot || sprites.length < 2 ? 0 : i ? 16 : -16; } diff --git a/src/phases/berry-phase.ts b/src/phases/berry-phase.ts index 66ecaa6c7f8..5c33ae4b343 100644 --- a/src/phases/berry-phase.ts +++ b/src/phases/berry-phase.ts @@ -15,7 +15,7 @@ export class BerryPhase extends FieldPhase { this.executeForAll((pokemon) => { const hasUsableBerry = !!this.scene.findModifier((m) => { - return m instanceof BerryModifier && m.shouldApply([pokemon]); + return m instanceof BerryModifier && m.shouldApply(pokemon); }, pokemon.isPlayer()); if (hasUsableBerry) { @@ -29,13 +29,10 @@ export class BerryPhase extends FieldPhase { new CommonAnimPhase(this.scene, pokemon.getBattlerIndex(), pokemon.getBattlerIndex(), CommonAnim.USE_ITEM) ); - for (const berryModifier of this.scene.applyModifiers(BerryModifier, pokemon.isPlayer(), pokemon) as BerryModifier[]) { + for (const berryModifier of this.scene.applyModifiers(BerryModifier, pokemon.isPlayer(), pokemon)) { if (berryModifier.consumed) { - if (!--berryModifier.stackCount) { - this.scene.removeModifier(berryModifier); - } else { - berryModifier.consumed = false; - } + berryModifier.consumed = false; + pokemon.loseHeldItem(berryModifier); } this.scene.eventTarget.dispatchEvent(new BerryUsedEvent(berryModifier)); // Announce a berry was used } diff --git a/src/phases/check-status-effect-phase.ts b/src/phases/check-status-effect-phase.ts new file mode 100644 index 00000000000..44918b54966 --- /dev/null +++ b/src/phases/check-status-effect-phase.ts @@ -0,0 +1,23 @@ +import { PostTurnStatusEffectPhase } from "#app/phases/post-turn-status-effect-phase"; +import { Phase } from "#app/phase"; +import { BattlerIndex } from "#app/battle"; +import BattleScene from "#app/battle-scene"; + +export class CheckStatusEffectPhase extends Phase { + private order : BattlerIndex[]; + constructor(scene : BattleScene, order : BattlerIndex[]) { + super(scene); + this.scene = scene; + this.order = order; + } + + start() { + const field = this.scene.getField(); + for (const o of this.order) { + if (field[o].status && field[o].status.isPostTurn()) { + this.scene.unshiftPhase(new PostTurnStatusEffectPhase(this.scene, o)); + } + } + this.end(); + } +} diff --git a/src/phases/check-switch-phase.ts b/src/phases/check-switch-phase.ts index a069ba224a2..acf17c75668 100644 --- a/src/phases/check-switch-phase.ts +++ b/src/phases/check-switch-phase.ts @@ -8,6 +8,7 @@ import { BattlePhase } from "./battle-phase"; import { PostSummonPhase } from "./post-summon-phase"; import { SummonMissingPhase } from "./summon-missing-phase"; import { SwitchPhase } from "./switch-phase"; +import { SwitchType } from "#enums/switch-type"; export class CheckSwitchPhase extends BattlePhase { protected fieldIndex: integer; @@ -25,32 +26,36 @@ export class CheckSwitchPhase extends BattlePhase { const pokemon = this.scene.getPlayerField()[this.fieldIndex]; + // End this phase early... + + // ...if the user is playing in Set Mode if (this.scene.battleStyle === BattleStyle.SET) { - super.end(); - return; + return super.end(); } + // ...if the checked Pokemon is somehow not on the field if (this.scene.field.getAll().indexOf(pokemon) === -1) { this.scene.unshiftPhase(new SummonMissingPhase(this.scene, this.fieldIndex)); - super.end(); - return; + return super.end(); } - if (!this.scene.getParty().slice(1).filter(p => p.isActive()).length) { - super.end(); - return; + // ...if there are no other allowed Pokemon in the player's party to switch with + if (!this.scene.getPlayerParty().slice(1).filter(p => p.isActive()).length) { + return super.end(); } - if (pokemon.getTag(BattlerTagType.FRENZY)) { - super.end(); - return; + // ...or if any player Pokemon has an effect that prevents the checked Pokemon from switching + if (pokemon.getTag(BattlerTagType.FRENZY) + || pokemon.isTrapped() + || this.scene.getPlayerField().some(p => p.getTag(BattlerTagType.COMMANDED))) { + return super.end(); } this.scene.ui.showText(i18next.t("battle:switchQuestion", { pokemonName: this.useName ? getPokemonNameWithAffix(pokemon) : i18next.t("battle:pokemon") }), null, () => { this.scene.ui.setMode(Mode.CONFIRM, () => { this.scene.ui.setMode(Mode.MESSAGE); this.scene.tryRemovePhase(p => p instanceof PostSummonPhase && p.player && p.fieldIndex === this.fieldIndex); - this.scene.unshiftPhase(new SwitchPhase(this.scene, this.fieldIndex, false, true)); + this.scene.unshiftPhase(new SwitchPhase(this.scene, SwitchType.INITIAL_SWITCH, this.fieldIndex, false, true)); this.end(); }, () => { this.scene.ui.setMode(Mode.MESSAGE); diff --git a/src/phases/command-phase.ts b/src/phases/command-phase.ts index 86e42acb26b..eab76282908 100644 --- a/src/phases/command-phase.ts +++ b/src/phases/command-phase.ts @@ -2,12 +2,12 @@ import BattleScene from "#app/battle-scene"; import { TurnCommand, BattleType } from "#app/battle"; import { TrappedTag, EncoreTag } from "#app/data/battler-tags"; import { MoveTargetSet, getMoveTargets } from "#app/data/move"; -import { speciesStarters } from "#app/data/pokemon-species"; +import { speciesStarterCosts } from "#app/data/balance/starters"; import { Abilities } from "#app/enums/abilities"; import { BattlerTagType } from "#app/enums/battler-tag-type"; import { Biome } from "#app/enums/biome"; import { Moves } from "#app/enums/moves"; -import { PokeballType } from "#app/enums/pokeball"; +import { PokeballType } from "#enums/pokeball"; import { FieldPosition, PlayerPokemon } from "#app/field/pokemon"; import { getPokemonNameWithAffix } from "#app/messages"; import { Command } from "#app/ui/command-ui-handler"; @@ -16,6 +16,9 @@ import i18next from "i18next"; import { FieldPhase } from "./field-phase"; import { SelectTargetPhase } from "./select-target-phase"; import { MysteryEncounterMode } from "#enums/mystery-encounter-mode"; +import { isNullOrUndefined } from "#app/utils"; +import { ArenaTagSide } from "#app/data/arena-tag"; +import { ArenaTagType } from "#app/enums/arena-tag-type"; export class CommandPhase extends FieldPhase { protected fieldIndex: integer; @@ -29,6 +32,17 @@ export class CommandPhase extends FieldPhase { start() { super.start(); + this.scene.updateGameInfo(); + + const commandUiHandler = this.scene.ui.handlers[Mode.COMMAND]; + if (commandUiHandler) { + if (this.scene.currentBattle.turn === 1 || commandUiHandler.getCursor() === Command.POKEMON) { + commandUiHandler.setCursor(Command.FIGHT); + } else { + commandUiHandler.setCursor(commandUiHandler.getCursor()); + } + } + if (this.fieldIndex) { // If we somehow are attempting to check the right pokemon but there's only one pokemon out // Switch back to the center pokemon. This can happen rarely in double battles with mid turn switching @@ -42,6 +56,17 @@ export class CommandPhase extends FieldPhase { } } + // If the Pokemon has applied Commander's effects to its ally, skip this command + if (this.scene.currentBattle?.double && this.getPokemon().getAlly()?.getTag(BattlerTagType.COMMANDED)?.getSourcePokemon(this.scene) === this.getPokemon()) { + this.scene.currentBattle.turnCommands[this.fieldIndex] = { command: Command.FIGHT, move: { move: Moves.NONE, targets: []}, skip: true }; + } + + // Checks if the Pokemon is under the effects of Encore. If so, Encore can end early if the encored move has no more PP. + const encoreTag = this.getPokemon().getTag(BattlerTagType.ENCORE) as EncoreTag; + if (encoreTag) { + this.getPokemon().lapseTag(BattlerTagType.ENCORE); + } + if (this.scene.currentBattle.turnCommands[this.fieldIndex]?.skip) { return this.end(); } @@ -69,7 +94,7 @@ export class CommandPhase extends FieldPhase { } } } else { - if (this.scene.currentBattle.battleType === BattleType.MYSTERY_ENCOUNTER && this.scene.currentBattle.mysteryEncounter?.skipToFightInput) { + if (this.scene.currentBattle.isBattleMysteryEncounter() && this.scene.currentBattle.mysteryEncounter?.skipToFightInput) { this.scene.ui.clearText(); this.scene.ui.setMode(Mode.FIGHT, this.fieldIndex); } else { @@ -80,178 +105,188 @@ export class CommandPhase extends FieldPhase { handleCommand(command: Command, cursor: integer, ...args: any[]): boolean { const playerPokemon = this.scene.getPlayerField()[this.fieldIndex]; - let success: boolean; + let success: boolean = false; switch (command) { - case Command.FIGHT: - let useStruggle = false; - if (cursor === -1 || + case Command.FIGHT: + let useStruggle = false; + if (cursor === -1 || playerPokemon.trySelectMove(cursor, args[0] as boolean) || (useStruggle = cursor > -1 && !playerPokemon.getMoveset().filter(m => m?.isUsable(playerPokemon)).length)) { - const moveId = !useStruggle ? cursor > -1 ? playerPokemon.getMoveset()[cursor]!.moveId : Moves.NONE : Moves.STRUGGLE; // TODO: is the bang correct? - const turnCommand: TurnCommand = { command: Command.FIGHT, cursor: cursor, move: { move: moveId, targets: [], ignorePP: args[0] }, args: args }; - const moveTargets: MoveTargetSet = args.length < 3 ? getMoveTargets(playerPokemon, moveId) : args[2]; - if (!moveId) { - turnCommand.targets = [this.fieldIndex]; - } - console.log(moveTargets, getPokemonNameWithAffix(playerPokemon)); - if (moveTargets.targets.length > 1 && moveTargets.multiple) { - this.scene.unshiftPhase(new SelectTargetPhase(this.scene, this.fieldIndex)); - } - if (moveTargets.targets.length <= 1 || moveTargets.multiple) { + const moveId = !useStruggle ? cursor > -1 ? playerPokemon.getMoveset()[cursor]!.moveId : Moves.NONE : Moves.STRUGGLE; // TODO: is the bang correct? + const turnCommand: TurnCommand = { command: Command.FIGHT, cursor: cursor, move: { move: moveId, targets: [], ignorePP: args[0] }, args: args }; + const moveTargets: MoveTargetSet = args.length < 3 ? getMoveTargets(playerPokemon, moveId) : args[2]; + if (!moveId) { + turnCommand.targets = [ this.fieldIndex ]; + } + console.log(moveTargets, getPokemonNameWithAffix(playerPokemon)); + if (moveTargets.targets.length > 1 && moveTargets.multiple) { + this.scene.unshiftPhase(new SelectTargetPhase(this.scene, this.fieldIndex)); + } + if (moveTargets.targets.length <= 1 || moveTargets.multiple) { turnCommand.move!.targets = moveTargets.targets; //TODO: is the bang correct here? - } else if (playerPokemon.getTag(BattlerTagType.CHARGING) && playerPokemon.getMoveQueue().length >= 1) { + } else if (playerPokemon.getTag(BattlerTagType.CHARGING) && playerPokemon.getMoveQueue().length >= 1) { turnCommand.move!.targets = playerPokemon.getMoveQueue()[0].targets; //TODO: is the bang correct here? - } else { - this.scene.unshiftPhase(new SelectTargetPhase(this.scene, this.fieldIndex)); - } - this.scene.currentBattle.turnCommands[this.fieldIndex] = turnCommand; - success = true; - } else if (cursor < playerPokemon.getMoveset().length) { - const move = playerPokemon.getMoveset()[cursor]!; //TODO: is this bang correct? - this.scene.ui.setMode(Mode.MESSAGE); + } else { + this.scene.unshiftPhase(new SelectTargetPhase(this.scene, this.fieldIndex)); + } + this.scene.currentBattle.turnCommands[this.fieldIndex] = turnCommand; + success = true; + } else if (cursor < playerPokemon.getMoveset().length) { + const move = playerPokemon.getMoveset()[cursor]!; //TODO: is this bang correct? + this.scene.ui.setMode(Mode.MESSAGE); - // Decides between a Disabled, Not Implemented, or No PP translation message - const errorMessage = - playerPokemon.isMoveRestricted(move.moveId) - ? playerPokemon.getRestrictingTag(move.moveId)!.selectionDeniedText(playerPokemon, move.moveId) + // Decides between a Disabled, Not Implemented, or No PP translation message + const errorMessage = + playerPokemon.isMoveRestricted(move.moveId, playerPokemon) + ? playerPokemon.getRestrictingTag(move.moveId, playerPokemon)!.selectionDeniedText(playerPokemon, move.moveId) : move.getName().endsWith(" (N)") ? "battle:moveNotImplemented" : "battle:moveNoPP"; - const moveName = move.getName().replace(" (N)", ""); // Trims off the indicator + const moveName = move.getName().replace(" (N)", ""); // Trims off the indicator - this.scene.ui.showText(i18next.t(errorMessage, { moveName: moveName }), null, () => { - this.scene.ui.clearText(); - this.scene.ui.setMode(Mode.FIGHT, this.fieldIndex); - }, null, true); - } - break; - case Command.BALL: - const notInDex = (this.scene.getEnemyField().filter(p => p.isActive(true)).some(p => !p.scene.gameData.dexData[p.species.speciesId].caughtAttr) && this.scene.gameData.getStarterCount(d => !!d.caughtAttr) < Object.keys(speciesStarters).length - 1); - if (this.scene.arena.biomeType === Biome.END && (!this.scene.gameMode.isClassic || this.scene.gameMode.isFreshStartChallenge() || notInDex )) { - this.scene.ui.setMode(Mode.COMMAND, this.fieldIndex); - this.scene.ui.setMode(Mode.MESSAGE); - this.scene.ui.showText(i18next.t("battle:noPokeballForce"), null, () => { - this.scene.ui.showText("", 0); - this.scene.ui.setMode(Mode.COMMAND, this.fieldIndex); - }, null, true); - } else if (this.scene.currentBattle.battleType === BattleType.TRAINER) { - this.scene.ui.setMode(Mode.COMMAND, this.fieldIndex); - this.scene.ui.setMode(Mode.MESSAGE); - this.scene.ui.showText(i18next.t("battle:noPokeballTrainer"), null, () => { - this.scene.ui.showText("", 0); - this.scene.ui.setMode(Mode.COMMAND, this.fieldIndex); - }, null, true); - } else if (this.scene.currentBattle.battleType === BattleType.MYSTERY_ENCOUNTER && !this.scene.currentBattle.mysteryEncounter!.catchAllowed) { - this.scene.ui.setMode(Mode.COMMAND, this.fieldIndex); - this.scene.ui.setMode(Mode.MESSAGE); - this.scene.ui.showText(i18next.t("battle:noPokeballMysteryEncounter"), null, () => { - this.scene.ui.showText("", 0); - this.scene.ui.setMode(Mode.COMMAND, this.fieldIndex); - }, null, true); - } else { - const targets = this.scene.getEnemyField().filter(p => p.isActive(true)).map(p => p.getBattlerIndex()); - if (targets.length > 1) { + this.scene.ui.showText(i18next.t(errorMessage, { moveName: moveName }), null, () => { + this.scene.ui.clearText(); + this.scene.ui.setMode(Mode.FIGHT, this.fieldIndex); + }, null, true); + } + break; + case Command.BALL: + const notInDex = (this.scene.getEnemyField().filter(p => p.isActive(true)).some(p => !p.scene.gameData.dexData[p.species.speciesId].caughtAttr) && this.scene.gameData.getStarterCount(d => !!d.caughtAttr) < Object.keys(speciesStarterCosts).length - 1); + if (this.scene.arena.biomeType === Biome.END && (!this.scene.gameMode.isClassic || this.scene.gameMode.isFreshStartChallenge() || notInDex )) { this.scene.ui.setMode(Mode.COMMAND, this.fieldIndex); this.scene.ui.setMode(Mode.MESSAGE); - this.scene.ui.showText(i18next.t("battle:noPokeballMulti"), null, () => { + this.scene.ui.showText(i18next.t("battle:noPokeballForce"), null, () => { this.scene.ui.showText("", 0); this.scene.ui.setMode(Mode.COMMAND, this.fieldIndex); }, null, true); - } else if (cursor < 5) { - const targetPokemon = this.scene.getEnemyField().find(p => p.isActive(true)); - if (targetPokemon?.isBoss() && targetPokemon?.bossSegmentIndex >= 1 && !targetPokemon?.hasAbility(Abilities.WONDER_GUARD, false, true) && cursor < PokeballType.MASTER_BALL) { + } else if (this.scene.currentBattle.battleType === BattleType.TRAINER) { + this.scene.ui.setMode(Mode.COMMAND, this.fieldIndex); + this.scene.ui.setMode(Mode.MESSAGE); + this.scene.ui.showText(i18next.t("battle:noPokeballTrainer"), null, () => { + this.scene.ui.showText("", 0); + this.scene.ui.setMode(Mode.COMMAND, this.fieldIndex); + }, null, true); + } else if (this.scene.currentBattle.isBattleMysteryEncounter() && !this.scene.currentBattle.mysteryEncounter!.catchAllowed) { + this.scene.ui.setMode(Mode.COMMAND, this.fieldIndex); + this.scene.ui.setMode(Mode.MESSAGE); + this.scene.ui.showText(i18next.t("battle:noPokeballMysteryEncounter"), null, () => { + this.scene.ui.showText("", 0); + this.scene.ui.setMode(Mode.COMMAND, this.fieldIndex); + }, null, true); + } else { + const targets = this.scene.getEnemyField().filter(p => p.isActive(true)).map(p => p.getBattlerIndex()); + if (targets.length > 1) { this.scene.ui.setMode(Mode.COMMAND, this.fieldIndex); this.scene.ui.setMode(Mode.MESSAGE); - this.scene.ui.showText(i18next.t("battle:noPokeballStrong"), null, () => { + this.scene.ui.showText(i18next.t("battle:noPokeballMulti"), null, () => { this.scene.ui.showText("", 0); this.scene.ui.setMode(Mode.COMMAND, this.fieldIndex); }, null, true); - } else { - this.scene.currentBattle.turnCommands[this.fieldIndex] = { command: Command.BALL, cursor: cursor }; + } else if (cursor < 5) { + const targetPokemon = this.scene.getEnemyField().find(p => p.isActive(true)); + if (targetPokemon?.isBoss() && targetPokemon?.bossSegmentIndex >= 1 && !targetPokemon?.hasAbility(Abilities.WONDER_GUARD, false, true) && cursor < PokeballType.MASTER_BALL) { + this.scene.ui.setMode(Mode.COMMAND, this.fieldIndex); + this.scene.ui.setMode(Mode.MESSAGE); + this.scene.ui.showText(i18next.t("battle:noPokeballStrong"), null, () => { + this.scene.ui.showText("", 0); + this.scene.ui.setMode(Mode.COMMAND, this.fieldIndex); + }, null, true); + } else { + this.scene.currentBattle.turnCommands[this.fieldIndex] = { command: Command.BALL, cursor: cursor }; this.scene.currentBattle.turnCommands[this.fieldIndex]!.targets = targets; if (this.fieldIndex) { this.scene.currentBattle.turnCommands[this.fieldIndex - 1]!.skip = true; } success = true; + } } } - } - break; - case Command.POKEMON: - case Command.RUN: - const isSwitch = command === Command.POKEMON; - if (!isSwitch && this.scene.arena.biomeType === Biome.END) { - this.scene.ui.setMode(Mode.COMMAND, this.fieldIndex); - this.scene.ui.setMode(Mode.MESSAGE); - this.scene.ui.showText(i18next.t("battle:noEscapeForce"), null, () => { - this.scene.ui.showText("", 0); + break; + case Command.POKEMON: + case Command.RUN: + const isSwitch = command === Command.POKEMON; + const { currentBattle, arena } = this.scene; + const mysteryEncounterFleeAllowed = currentBattle.mysteryEncounter?.fleeAllowed; + if (!isSwitch && (arena.biomeType === Biome.END || (!isNullOrUndefined(mysteryEncounterFleeAllowed) && !mysteryEncounterFleeAllowed))) { this.scene.ui.setMode(Mode.COMMAND, this.fieldIndex); - }, null, true); - } else if (!isSwitch && (this.scene.currentBattle.battleType === BattleType.TRAINER || this.scene.currentBattle.mysteryEncounter?.encounterMode === MysteryEncounterMode.TRAINER_BATTLE)) { - this.scene.ui.setMode(Mode.COMMAND, this.fieldIndex); - this.scene.ui.setMode(Mode.MESSAGE); - this.scene.ui.showText(i18next.t("battle:noEscapeTrainer"), null, () => { - this.scene.ui.showText("", 0); - this.scene.ui.setMode(Mode.COMMAND, this.fieldIndex); - }, null, true); - } else { - const batonPass = isSwitch && args[0] as boolean; - const trappedAbMessages: string[] = []; - if (batonPass || !playerPokemon.isTrapped(trappedAbMessages)) { - this.scene.currentBattle.turnCommands[this.fieldIndex] = isSwitch - ? { command: Command.POKEMON, cursor: cursor, args: args } - : { command: Command.RUN }; - success = true; - if (!isSwitch && this.fieldIndex) { - this.scene.currentBattle.turnCommands[this.fieldIndex - 1]!.skip = true; - } - } else if (trappedAbMessages.length > 0) { - if (!isSwitch) { - this.scene.ui.setMode(Mode.MESSAGE); - } - this.scene.ui.showText(trappedAbMessages[0], null, () => { + this.scene.ui.setMode(Mode.MESSAGE); + this.scene.ui.showText(i18next.t("battle:noEscapeForce"), null, () => { this.scene.ui.showText("", 0); - if (!isSwitch) { - this.scene.ui.setMode(Mode.COMMAND, this.fieldIndex); - } + this.scene.ui.setMode(Mode.COMMAND, this.fieldIndex); + }, null, true); + } else if (!isSwitch && (currentBattle.battleType === BattleType.TRAINER || currentBattle.mysteryEncounter?.encounterMode === MysteryEncounterMode.TRAINER_BATTLE)) { + this.scene.ui.setMode(Mode.COMMAND, this.fieldIndex); + this.scene.ui.setMode(Mode.MESSAGE); + this.scene.ui.showText(i18next.t("battle:noEscapeTrainer"), null, () => { + this.scene.ui.showText("", 0); + this.scene.ui.setMode(Mode.COMMAND, this.fieldIndex); }, null, true); } else { - const trapTag = playerPokemon.getTag(TrappedTag); - - // trapTag should be defined at this point, but just in case... - if (!trapTag) { - this.scene.currentBattle.turnCommands[this.fieldIndex] = isSwitch + const batonPass = isSwitch && args[0] as boolean; + const trappedAbMessages: string[] = []; + if (batonPass || !playerPokemon.isTrapped(trappedAbMessages)) { + currentBattle.turnCommands[this.fieldIndex] = isSwitch ? { command: Command.POKEMON, cursor: cursor, args: args } : { command: Command.RUN }; - break; - } - - if (!isSwitch) { - this.scene.ui.setMode(Mode.COMMAND, this.fieldIndex); - this.scene.ui.setMode(Mode.MESSAGE); - } - this.scene.ui.showText( - i18next.t("battle:noEscapePokemon", { - pokemonName: trapTag.sourceId && this.scene.getPokemonById(trapTag.sourceId) ? getPokemonNameWithAffix(this.scene.getPokemonById(trapTag.sourceId)!) : "", - moveName: trapTag.getMoveName(), - escapeVerb: isSwitch ? i18next.t("battle:escapeVerbSwitch") : i18next.t("battle:escapeVerbFlee") - }), - null, - () => { + success = true; + if (!isSwitch && this.fieldIndex) { + currentBattle.turnCommands[this.fieldIndex - 1]!.skip = true; + } + } else if (trappedAbMessages.length > 0) { + if (!isSwitch) { + this.scene.ui.setMode(Mode.MESSAGE); + } + this.scene.ui.showText(trappedAbMessages[0], null, () => { this.scene.ui.showText("", 0); if (!isSwitch) { this.scene.ui.setMode(Mode.COMMAND, this.fieldIndex); } }, null, true); + } else { + const trapTag = playerPokemon.getTag(TrappedTag); + const fairyLockTag = playerPokemon.scene.arena.getTagOnSide(ArenaTagType.FAIRY_LOCK, ArenaTagSide.PLAYER); + + if (!trapTag && !fairyLockTag) { + i18next.t(`battle:noEscape${isSwitch ? "Switch" : "Flee"}`); + break; + } + if (!isSwitch) { + this.scene.ui.setMode(Mode.COMMAND, this.fieldIndex); + this.scene.ui.setMode(Mode.MESSAGE); + } + const showNoEscapeText = (tag: any) => { + this.scene.ui.showText( + i18next.t("battle:noEscapePokemon", { + pokemonName: tag.sourceId && this.scene.getPokemonById(tag.sourceId) ? getPokemonNameWithAffix(this.scene.getPokemonById(tag.sourceId)!) : "", + moveName: tag.getMoveName(), + escapeVerb: isSwitch ? i18next.t("battle:escapeVerbSwitch") : i18next.t("battle:escapeVerbFlee") + }), + null, + () => { + this.scene.ui.showText("", 0); + if (!isSwitch) { + this.scene.ui.setMode(Mode.COMMAND, this.fieldIndex); + } + }, + null, + true + ); + }; + + if (trapTag) { + showNoEscapeText(trapTag); + } else if (fairyLockTag) { + showNoEscapeText(fairyLockTag); + } + } } - } - break; + break; } - if (success!) { // TODO: is the bang correct? + if (success) { this.end(); } - return success!; // TODO: is the bang correct? + return success; } cancel() { @@ -262,26 +297,6 @@ export class CommandPhase extends FieldPhase { } } - checkFightOverride(): boolean { - const pokemon = this.getPokemon(); - - const encoreTag = pokemon.getTag(EncoreTag) as EncoreTag; - - if (!encoreTag) { - return false; - } - - const moveIndex = pokemon.getMoveset().findIndex(m => m?.moveId === encoreTag.moveId); - - if (moveIndex === -1 || !pokemon.getMoveset()[moveIndex]!.isUsable(pokemon)) { // TODO: is this bang correct? - return false; - } - - this.handleCommand(Command.FIGHT, moveIndex, false); - - return true; - } - getFieldIndex(): integer { return this.fieldIndex; } diff --git a/src/phases/damage-phase.ts b/src/phases/damage-phase.ts index 66b11512729..44e3dfd4182 100644 --- a/src/phases/damage-phase.ts +++ b/src/phases/damage-phase.ts @@ -41,16 +41,16 @@ export class DamagePhase extends PokemonPhase { applyDamage() { switch (this.damageResult) { - case HitResult.EFFECTIVE: - this.scene.playSound("se/hit"); - break; - case HitResult.SUPER_EFFECTIVE: - case HitResult.ONE_HIT_KO: - this.scene.playSound("se/hit_strong"); - break; - case HitResult.NOT_VERY_EFFECTIVE: - this.scene.playSound("se/hit_weak"); - break; + case HitResult.EFFECTIVE: + this.scene.playSound("se/hit"); + break; + case HitResult.SUPER_EFFECTIVE: + case HitResult.ONE_HIT_KO: + this.scene.playSound("se/hit_strong"); + break; + case HitResult.NOT_VERY_EFFECTIVE: + this.scene.playSound("se/hit_weak"); + break; } if (this.amount) { diff --git a/src/phases/egg-lapse-phase.ts b/src/phases/egg-lapse-phase.ts index 65426846bb3..4c57be09b79 100644 --- a/src/phases/egg-lapse-phase.ts +++ b/src/phases/egg-lapse-phase.ts @@ -28,20 +28,21 @@ export class EggLapsePhase extends Phase { return Overrides.EGG_IMMEDIATE_HATCH_OVERRIDE ? true : --egg.hatchWaves < 1; }); const eggsToHatchCount: number = eggsToHatch.length; - this.eggHatchData= []; + this.eggHatchData = []; if (eggsToHatchCount > 0) { if (eggsToHatchCount >= this.minEggsToSkip && this.scene.eggSkipPreference === 1) { this.scene.ui.showText(i18next.t("battle:eggHatching"), 0, () => { - // show prompt for skip + // show prompt for skip, blocking inputs for 1 second this.scene.ui.showText(i18next.t("battle:eggSkipPrompt"), 0); this.scene.ui.setModeWithoutClear(Mode.CONFIRM, () => { this.hatchEggsSkipped(eggsToHatch); this.showSummary(); }, () => { this.hatchEggsRegular(eggsToHatch); - this.showSummary(); - } + this.end(); + }, + null, null, null, 1000, true ); }, 100, true); } else if (eggsToHatchCount >= this.minEggsToSkip && this.scene.eggSkipPreference === 2) { diff --git a/src/phases/egg-summary-phase.ts b/src/phases/egg-summary-phase.ts index 75c6939daf1..b673eb4887b 100644 --- a/src/phases/egg-summary-phase.ts +++ b/src/phases/egg-summary-phase.ts @@ -1,7 +1,6 @@ import BattleScene from "#app/battle-scene"; import { Phase } from "#app/phase"; import { Mode } from "#app/ui/ui"; -import EggHatchSceneHandler from "#app/ui/egg-hatch-scene-handler"; import { EggHatchData } from "#app/data/egg-hatch-data"; /** @@ -11,7 +10,6 @@ import { EggHatchData } from "#app/data/egg-hatch-data"; */ export class EggSummaryPhase extends Phase { private eggHatchData: EggHatchData[]; - private eggHatchHandler: EggHatchSceneHandler; constructor(scene: BattleScene, eggHatchData: EggHatchData[]) { super(scene); @@ -26,7 +24,6 @@ export class EggSummaryPhase extends Phase { if (i >= this.eggHatchData.length) { this.scene.ui.setModeForceTransition(Mode.EGG_HATCH_SUMMARY, this.eggHatchData).then(() => { this.scene.fadeOutBgm(undefined, false); - this.eggHatchHandler = this.scene.ui.getHandler() as EggHatchSceneHandler; }); } else { diff --git a/src/phases/encounter-phase.ts b/src/phases/encounter-phase.ts index 012738df9ab..03126ba81bb 100644 --- a/src/phases/encounter-phase.ts +++ b/src/phases/encounter-phase.ts @@ -1,39 +1,41 @@ -import BattleScene from "#app/battle-scene"; import { BattlerIndex, BattleType } from "#app/battle"; +import BattleScene from "#app/battle-scene"; +import { PLAYER_PARTY_MAX_SIZE } from "#app/constants"; import { applyAbAttrs, SyncEncounterNatureAbAttr } from "#app/data/ability"; +import { initEncounterAnims, loadEncounterAnimAssets } from "#app/data/battle-anims"; import { getCharVariantFromDialogue } from "#app/data/dialogue"; +import { getEncounterText } from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; +import { doTrainerExclamation } from "#app/data/mystery-encounters/utils/encounter-phase-utils"; +import { getGoldenBugNetSpecies } from "#app/data/mystery-encounters/utils/encounter-pokemon-utils"; import { TrainerSlot } from "#app/data/trainer-config"; import { getRandomWeatherType } from "#app/data/weather"; -import { BattleSpec } from "#app/enums/battle-spec"; -import { PlayerGender } from "#app/enums/player-gender"; -import { Species } from "#app/enums/species"; import { EncounterPhaseEvent } from "#app/events/battle-scene"; import Pokemon, { FieldPosition } from "#app/field/pokemon"; import { getPokemonNameWithAffix } from "#app/messages"; -import { ModifierPoolType, regenerateModifierPoolThresholds } from "#app/modifier/modifier-type"; import { BoostBugSpawnModifier, IvScannerModifier, TurnHeldItemTransferModifier } from "#app/modifier/modifier"; +import { ModifierPoolType, regenerateModifierPoolThresholds } from "#app/modifier/modifier-type"; +import Overrides from "#app/overrides"; +import { BattlePhase } from "#app/phases/battle-phase"; +import { CheckSwitchPhase } from "#app/phases/check-switch-phase"; +import { GameOverPhase } from "#app/phases/game-over-phase"; +import { MysteryEncounterPhase } from "#app/phases/mystery-encounter-phases"; +import { PostSummonPhase } from "#app/phases/post-summon-phase"; +import { ReturnPhase } from "#app/phases/return-phase"; +import { ScanIvsPhase } from "#app/phases/scan-ivs-phase"; +import { ShinySparklePhase } from "#app/phases/shiny-sparkle-phase"; +import { SummonPhase } from "#app/phases/summon-phase"; +import { ToggleDoublePositionPhase } from "#app/phases/toggle-double-position-phase"; import { achvs } from "#app/system/achv"; import { handleTutorial, Tutorial } from "#app/tutorial"; import { Mode } from "#app/ui/ui"; -import i18next from "i18next"; -import { BattlePhase } from "./battle-phase"; -import * as Utils from "#app/utils"; -import { randSeedInt } from "#app/utils"; -import { CheckSwitchPhase } from "./check-switch-phase"; -import { GameOverPhase } from "./game-over-phase"; -import { PostSummonPhase } from "./post-summon-phase"; -import { ReturnPhase } from "./return-phase"; -import { ScanIvsPhase } from "./scan-ivs-phase"; -import { ShinySparklePhase } from "./shiny-sparkle-phase"; -import { SummonPhase } from "./summon-phase"; -import { ToggleDoublePositionPhase } from "./toggle-double-position-phase"; -import Overrides from "#app/overrides"; -import { initEncounterAnims, loadEncounterAnimAssets } from "#app/data/battle-anims"; +import { randSeedInt, randSeedItem } from "#app/utils"; +import { BattleSpec } from "#enums/battle-spec"; +import { Biome } from "#enums/biome"; import { MysteryEncounterMode } from "#enums/mystery-encounter-mode"; -import { doTrainerExclamation } from "#app/data/mystery-encounters/utils/encounter-phase-utils"; -import { getEncounterText } from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; -import { MysteryEncounterPhase } from "#app/phases/mystery-encounter-phases"; -import { getGoldenBugNetSpecies } from "#app/data/mystery-encounters/utils/encounter-pokemon-utils"; +import { PlayerGender } from "#enums/player-gender"; +import { Species } from "#enums/species"; +import i18next from "i18next"; +import { WEIGHT_INCREMENT_ON_SPAWN_MISS } from "#app/data/mystery-encounters/mystery-encounters"; export class EncounterPhase extends BattlePhase { private loaded: boolean; @@ -62,7 +64,13 @@ export class EncounterPhase extends BattlePhase { const battle = this.scene.currentBattle; - // Init Mystery Encounter if there is one + // Generate and Init Mystery Encounter + if (battle.isBattleMysteryEncounter() && !battle.mysteryEncounter) { + this.scene.executeWithSeedOffset(() => { + const currentSessionEncounterType = battle.mysteryEncounterType; + battle.mysteryEncounter = this.scene.getMysteryEncounter(currentSessionEncounterType); + }, battle.waveIndex * 16); + } const mysteryEncounter = battle.mysteryEncounter; if (mysteryEncounter) { // If ME has an onInit() function, call it @@ -73,7 +81,7 @@ export class EncounterPhase extends BattlePhase { mysteryEncounter.onInit(this.scene); } mysteryEncounter.populateDialogueTokensFromRequirements(this.scene); - }, this.scene.currentBattle.waveIndex); + }, battle.waveIndex); // Add any special encounter animations to load if (mysteryEncounter.encounterAnimations && mysteryEncounter.encounterAnimations.length > 0) { @@ -88,7 +96,7 @@ export class EncounterPhase extends BattlePhase { let totalBst = 0; battle.enemyLevels?.every((level, e) => { - if (battle.battleType === BattleType.MYSTERY_ENCOUNTER) { + if (battle.isBattleMysteryEncounter()) { // Skip enemy loading for MEs, those are loaded elsewhere return false; } @@ -97,15 +105,18 @@ export class EncounterPhase extends BattlePhase { battle.enemyParty[e] = battle.trainer?.genPartyMember(e)!; // TODO:: is the bang correct here? } else { let enemySpecies = this.scene.randomSpecies(battle.waveIndex, level, true); - // If player has golden bug net, rolls 10% chance to replace with species from the golden bug net bug pool - if (this.scene.findModifier(m => m instanceof BoostBugSpawnModifier) && randSeedInt(10) === 0) { - enemySpecies = getGoldenBugNetSpecies(); + // If player has golden bug net, rolls 10% chance to replace non-boss wave wild species from the golden bug net bug pool + if (this.scene.findModifier(m => m instanceof BoostBugSpawnModifier) + && !this.scene.gameMode.isBoss(battle.waveIndex) + && this.scene.arena.biomeType !== Biome.END + && randSeedInt(10) === 0) { + enemySpecies = getGoldenBugNetSpecies(level); } battle.enemyParty[e] = this.scene.addEnemyPokemon(enemySpecies, level, TrainerSlot.NONE, !!this.scene.getEncounterBossSegments(battle.waveIndex, level, enemySpecies)); if (this.scene.currentBattle.battleSpec === BattleSpec.FINAL_BOSS) { battle.enemyParty[e].ivs = new Array(6).fill(31); } - this.scene.getParty().slice(0, !battle.double ? 1 : 2).reverse().forEach(playerPokemon => { + this.scene.getPlayerParty().slice(0, !battle.double ? 1 : 2).reverse().forEach(playerPokemon => { applyAbAttrs(SyncEncounterNatureAbAttr, playerPokemon, null, false, battle.enemyParty[e]); }); } @@ -130,10 +141,6 @@ export class EncounterPhase extends BattlePhase { } else if (!(battle.waveIndex % 1000)) { enemyPokemon.formIndex = 1; enemyPokemon.updateScale(); - const bossMBH = this.scene.findModifier(m => m instanceof TurnHeldItemTransferModifier && m.pokemonId === enemyPokemon.id, false) as TurnHeldItemTransferModifier; - this.scene.removeModifier(bossMBH!); - bossMBH?.setTransferrableFalse(); - this.scene.addEnemyModifier(bossMBH!); } } @@ -141,30 +148,27 @@ export class EncounterPhase extends BattlePhase { loadEnemyAssets.push(enemyPokemon.loadAssets()); - console.log(getPokemonNameWithAffix(enemyPokemon), enemyPokemon.species.speciesId, enemyPokemon.stats); + console.log(`Pokemon: ${getPokemonNameWithAffix(enemyPokemon)}`, `Species ID: ${enemyPokemon.species.speciesId}`, `Stats: ${enemyPokemon.stats}`, `Ability: ${enemyPokemon.getAbility().name}`, `Passive Ability: ${enemyPokemon.getPassiveAbility().name}`); return true; }); - if (this.scene.getParty().filter(p => p.isShiny()).length === 6) { + if (this.scene.getPlayerParty().filter(p => p.isShiny()).length === PLAYER_PARTY_MAX_SIZE) { this.scene.validateAchv(achvs.SHINY_PARTY); } if (battle.battleType === BattleType.TRAINER) { loadEnemyAssets.push(battle.trainer?.loadAssets().then(() => battle.trainer?.initSprite())!); // TODO: is this bang correct? - } else if (battle.battleType === BattleType.MYSTERY_ENCOUNTER) { - if (!battle.mysteryEncounter) { - battle.mysteryEncounter = this.scene.getMysteryEncounter(mysteryEncounter?.encounterType); - } - if (battle.mysteryEncounter.introVisuals) { + } else if (battle.isBattleMysteryEncounter()) { + if (battle.mysteryEncounter?.introVisuals) { loadEnemyAssets.push(battle.mysteryEncounter.introVisuals.loadAssets().then(() => battle.mysteryEncounter!.introVisuals!.initSprite())); } - if (battle.mysteryEncounter.loadAssets.length > 0) { + if (battle.mysteryEncounter?.loadAssets && battle.mysteryEncounter.loadAssets.length > 0) { loadEnemyAssets.push(...battle.mysteryEncounter.loadAssets); } // Load Mystery Encounter Exclamation bubble and sfx loadEnemyAssets.push(new Promise(resolve => { this.scene.loadSe("GEN8- Exclaim", "battle_anims", "GEN8- Exclaim.wav"); - this.scene.loadImage("exclaim", "mystery-encounters"); + this.scene.loadImage("encounter_exclaim", "mystery-encounters"); this.scene.load.once(Phaser.Loader.Events.COMPLETE, () => resolve()); if (!this.scene.load.isLoading()) { this.scene.load.start(); @@ -186,7 +190,7 @@ export class EncounterPhase extends BattlePhase { Promise.all(loadEnemyAssets).then(() => { battle.enemyParty.every((enemyPokemon, e) => { - if (battle.battleType === BattleType.MYSTERY_ENCOUNTER) { + if (battle.isBattleMysteryEncounter()) { return false; } if (e < (battle.double ? 2 : 1)) { @@ -194,7 +198,7 @@ export class EncounterPhase extends BattlePhase { this.scene.field.add(enemyPokemon); battle.seenEnemyPartyMemberIds.add(enemyPokemon.id); const playerPokemon = this.scene.getPlayerPokemon(); - if (playerPokemon?.visible) { + if (playerPokemon?.isOnField()) { this.scene.field.moveBelow(enemyPokemon as Pokemon, playerPokemon); } enemyPokemon.tint(0, 0.5); @@ -217,7 +221,8 @@ export class EncounterPhase extends BattlePhase { this.scene.ui.setMode(Mode.MESSAGE).then(() => { if (!this.loaded) { this.trySetWeatherIfNewBiome(); // Set weather before session gets saved - this.scene.gameData.saveAll(this.scene, true, battle.waveIndex % 10 === 1 || (this.scene.lastSavePlayTime ?? 0) >= 300).then(success => { + // Game syncs to server on waves X1 and X6 (As of 1.2.0) + this.scene.gameData.saveAll(this.scene, true, battle.waveIndex % 5 === 1 || (this.scene.lastSavePlayTime ?? 0) >= 300).then(success => { this.scene.disableMenu = false; if (!success) { return this.scene.reset(true); @@ -240,11 +245,18 @@ export class EncounterPhase extends BattlePhase { /*if (startingWave > 10) { for (let m = 0; m < Math.min(Math.floor(startingWave / 10), 99); m++) - this.scene.addModifier(getPlayerModifierTypeOptionsForWave((m + 1) * 10, 1, this.scene.getParty())[0].type.newModifier(), true); + this.scene.addModifier(getPlayerModifierTypeOptionsForWave((m + 1) * 10, 1, this.scene.getPlayerParty())[0].type.newModifier(), true); this.scene.updateModifiers(true); }*/ - for (const pokemon of this.scene.getParty()) { + const { battleType, waveIndex } = this.scene.currentBattle; + if (this.scene.isMysteryEncounterValidForWave(battleType, waveIndex) && !this.scene.currentBattle.isBattleMysteryEncounter()) { + // Increment ME spawn chance if an ME could have spawned but did not + // Only do this AFTER session has been saved to avoid duplicating increments + this.scene.mysteryEncounterSaveData.encounterSpawnChance += WEIGHT_INCREMENT_ON_SPAWN_MISS; + } + + for (const pokemon of this.scene.getPlayerParty()) { if (pokemon) { pokemon.resetBattleData(); } @@ -252,7 +264,7 @@ export class EncounterPhase extends BattlePhase { const enemyField = this.scene.getEnemyField(); this.scene.tweens.add({ - targets: [this.scene.arenaEnemy, this.scene.currentBattle.trainer, enemyField, this.scene.arenaPlayer, this.scene.trainer].flat(), + targets: [ this.scene.arenaEnemy, this.scene.currentBattle.trainer, enemyField, this.scene.arenaPlayer, this.scene.trainer ].flat(), x: (_target, _key, value, fieldIndex: integer) => fieldIndex < 2 + (enemyField.length) ? value + 300 : value - 300, duration: 2000, onComplete: () => { @@ -280,7 +292,7 @@ export class EncounterPhase extends BattlePhase { const enemyField = this.scene.getEnemyField(); if (this.scene.currentBattle.battleSpec === BattleSpec.FINAL_BOSS) { - return i18next.t("battle:bossAppeared", { bossName: getPokemonNameWithAffix(enemyField[0])}); + return i18next.t("battle:bossAppeared", { bossName: getPokemonNameWithAffix(enemyField[0]) }); } if (this.scene.currentBattle.battleType === BattleType.TRAINER) { @@ -323,7 +335,7 @@ export class EncounterPhase extends BattlePhase { const doSummon = () => { this.scene.currentBattle.started = true; this.scene.playBgm(undefined); - this.scene.pbTray.showPbTray(this.scene.getParty()); + this.scene.pbTray.showPbTray(this.scene.getPlayerParty()); this.scene.pbTrayEnemy.showPbTray(this.scene.getEnemyParty()); const doTrainerSummon = () => { this.hideEnemyTrainer(); @@ -347,7 +359,7 @@ export class EncounterPhase extends BattlePhase { doSummon(); } else { let message: string; - this.scene.executeWithSeedOffset(() => message = Utils.randSeedItem(encounterMessages), this.scene.currentBattle.waveIndex); + this.scene.executeWithSeedOffset(() => message = randSeedItem(encounterMessages), this.scene.currentBattle.waveIndex); message = message!; // tell TS compiler it's defined now const showDialogueAndSummon = () => { this.scene.ui.showDialogue(message, trainer?.getName(TrainerSlot.NONE, true), null, () => { @@ -360,7 +372,7 @@ export class EncounterPhase extends BattlePhase { showDialogueAndSummon(); } } - } else if (this.scene.currentBattle.battleType === BattleType.MYSTERY_ENCOUNTER && this.scene.currentBattle.mysteryEncounter) { + } else if (this.scene.currentBattle.isBattleMysteryEncounter() && this.scene.currentBattle.mysteryEncounter) { const encounter = this.scene.currentBattle.mysteryEncounter; const introVisuals = encounter.introVisuals; introVisuals?.playAnim(); @@ -427,18 +439,27 @@ export class EncounterPhase extends BattlePhase { if (enemyPokemon.isShiny()) { this.scene.unshiftPhase(new ShinySparklePhase(this.scene, BattlerIndex.ENEMY + e)); } + /** This sets Eternatus' held item to be untransferrable, preventing it from being stolen */ + if (enemyPokemon.species.speciesId === Species.ETERNATUS && (this.scene.gameMode.isBattleClassicFinalBoss(this.scene.currentBattle.waveIndex) || this.scene.gameMode.isEndlessMajorBoss(this.scene.currentBattle.waveIndex))) { + const enemyMBH = this.scene.findModifier(m => m instanceof TurnHeldItemTransferModifier, false) as TurnHeldItemTransferModifier; + if (enemyMBH) { + this.scene.removeModifier(enemyMBH, true); + enemyMBH.setTransferrableFalse(); + this.scene.addEnemyModifier(enemyMBH); + } + } }); - if (![BattleType.TRAINER, BattleType.MYSTERY_ENCOUNTER].includes(this.scene.currentBattle.battleType)) { + if (![ BattleType.TRAINER, BattleType.MYSTERY_ENCOUNTER ].includes(this.scene.currentBattle.battleType)) { enemyField.map(p => this.scene.pushConditionalPhase(new PostSummonPhase(this.scene, p.getBattlerIndex()), () => { // if there is not a player party, we can't continue - if (!this.scene.getParty()?.length) { + if (!this.scene.getPlayerParty().length) { return false; } // how many player pokemon are on the field ? - const pokemonsOnFieldCount = this.scene.getParty().filter(p => p.isOnField()).length; + const pokemonsOnFieldCount = this.scene.getPlayerParty().filter(p => p.isOnField()).length; // if it's a 2vs1, there will never be a 2nd pokemon on our field even - const requiredPokemonsOnField = Math.min(this.scene.getParty().filter((p) => !p.isFainted()).length, 2); + const requiredPokemonsOnField = Math.min(this.scene.getPlayerParty().filter((p) => !p.isFainted()).length, 2); // if it's a double, there should be 2, otherwise 1 if (this.scene.currentBattle.double) { return pokemonsOnFieldCount === requiredPokemonsOnField; @@ -452,7 +473,7 @@ export class EncounterPhase extends BattlePhase { } if (!this.loaded) { - const availablePartyMembers = this.scene.getParty().filter(p => p.isAllowedInBattle()); + const availablePartyMembers = this.scene.getPokemonAllowedInBattle(); if (!availablePartyMembers[0].isOnField()) { this.scene.pushPhase(new SummonPhase(this.scene, 0)); @@ -487,31 +508,31 @@ export class EncounterPhase extends BattlePhase { tryOverrideForBattleSpec(): boolean { switch (this.scene.currentBattle.battleSpec) { - case BattleSpec.FINAL_BOSS: - const enemy = this.scene.getEnemyPokemon(); - this.scene.ui.showText(this.getEncounterMessage(), null, () => { - const localizationKey = "battleSpecDialogue:encounter"; - if (this.scene.ui.shouldSkipDialogue(localizationKey)) { + case BattleSpec.FINAL_BOSS: + const enemy = this.scene.getEnemyPokemon(); + this.scene.ui.showText(this.getEncounterMessage(), null, () => { + const localizationKey = "battleSpecDialogue:encounter"; + if (this.scene.ui.shouldSkipDialogue(localizationKey)) { // Logging mirrors logging found in dialogue-ui-handler - console.log(`Dialogue ${localizationKey} skipped`); - this.doEncounterCommon(false); - } else { - const count = 5643853 + this.scene.gameData.gameStats.classicSessionsPlayed; - // The line below checks if an English ordinal is necessary or not based on whether an entry for encounterLocalizationKey exists in the language or not. - const ordinalUsed = !i18next.exists(localizationKey, {fallbackLng: []}) || i18next.resolvedLanguage === "en" ? i18next.t("battleSpecDialogue:key", { count: count, ordinal: true }) : ""; - const cycleCount = count.toLocaleString() + ordinalUsed; - const genderIndex = this.scene.gameData.gender ?? PlayerGender.UNSET; - const genderStr = PlayerGender[genderIndex].toLowerCase(); - const encounterDialogue = i18next.t(localizationKey, { context: genderStr, cycleCount: cycleCount }); - if (!this.scene.gameData.getSeenDialogues()[localizationKey]) { - this.scene.gameData.saveSeenDialogue(localizationKey); - } - this.scene.ui.showDialogue(encounterDialogue, enemy?.species.name, null, () => { + console.log(`Dialogue ${localizationKey} skipped`); this.doEncounterCommon(false); - }); - } - }, 1500, true); - return true; + } else { + const count = 5643853 + this.scene.gameData.gameStats.classicSessionsPlayed; + // The line below checks if an English ordinal is necessary or not based on whether an entry for encounterLocalizationKey exists in the language or not. + const ordinalUsed = !i18next.exists(localizationKey, { fallbackLng: []}) || i18next.resolvedLanguage === "en" ? i18next.t("battleSpecDialogue:key", { count: count, ordinal: true }) : ""; + const cycleCount = count.toLocaleString() + ordinalUsed; + const genderIndex = this.scene.gameData.gender ?? PlayerGender.UNSET; + const genderStr = PlayerGender[genderIndex].toLowerCase(); + const encounterDialogue = i18next.t(localizationKey, { context: genderStr, cycleCount: cycleCount }); + if (!this.scene.gameData.getSeenDialogues()[localizationKey]) { + this.scene.gameData.saveSeenDialogue(localizationKey); + } + this.scene.ui.showDialogue(encounterDialogue, enemy?.species.name, null, () => { + this.doEncounterCommon(false); + }); + } + }, 1500, true); + return true; } return false; } diff --git a/src/phases/enemy-command-phase.ts b/src/phases/enemy-command-phase.ts index b4503a7b059..83a85009ae0 100644 --- a/src/phases/enemy-command-phase.ts +++ b/src/phases/enemy-command-phase.ts @@ -2,6 +2,8 @@ import BattleScene from "#app/battle-scene"; import { BattlerIndex } from "#app/battle"; import { Command } from "#app/ui/command-ui-handler"; import { FieldPhase } from "./field-phase"; +import { Abilities } from "#enums/abilities"; +import { BattlerTagType } from "#enums/battler-tag-type"; /** * Phase for determining an enemy AI's action for the next turn. @@ -34,6 +36,11 @@ export class EnemyCommandPhase extends FieldPhase { const trainer = battle.trainer; + if (battle.double && enemyPokemon.hasAbility(Abilities.COMMANDER) + && enemyPokemon.getAlly().getTag(BattlerTagType.COMMANDED)) { + this.skipTurn = true; + } + /** * If the enemy has a trainer, decide whether or not the enemy should switch * to another member in its party. @@ -61,7 +68,7 @@ export class EnemyCommandPhase extends FieldPhase { const index = trainer.getNextSummonIndex(enemyPokemon.trainerSlot, partyMemberScores); battle.turnCommands[this.fieldIndex + BattlerIndex.ENEMY] = - { command: Command.POKEMON, cursor: index, args: [false], skip: this.skipTurn }; + { command: Command.POKEMON, cursor: index, args: [ false ], skip: this.skipTurn }; battle.enemySwitchCounter++; diff --git a/src/phases/evolution-phase.ts b/src/phases/evolution-phase.ts index 0c3c2fa5bcf..01994263688 100644 --- a/src/phases/evolution-phase.ts +++ b/src/phases/evolution-phase.ts @@ -1,23 +1,27 @@ import SoundFade from "phaser3-rex-plugins/plugins/soundfade"; -import { Phase } from "../phase"; -import BattleScene from "../battle-scene"; -import { SpeciesFormEvolution } from "../data/pokemon-evolutions"; -import EvolutionSceneHandler from "../ui/evolution-scene-handler"; -import * as Utils from "../utils"; -import { Mode } from "../ui/ui"; -import { cos, sin } from "../field/anims"; -import { PlayerPokemon } from "../field/pokemon"; -import { getTypeRgb } from "../data/type"; +import { Phase } from "#app/phase"; +import BattleScene, { AnySound } from "#app/battle-scene"; +import { SpeciesFormEvolution } from "#app/data/balance/pokemon-evolutions"; +import EvolutionSceneHandler from "#app/ui/evolution-scene-handler"; +import * as Utils from "#app/utils"; +import { Mode } from "#app/ui/ui"; +import { cos, sin } from "#app/field/anims"; +import Pokemon, { PlayerPokemon } from "#app/field/pokemon"; +import { getTypeRgb } from "#app/data/type"; import i18next from "i18next"; -import { getPokemonNameWithAffix } from "../messages"; -import { LearnMovePhase } from "./learn-move-phase"; -import { EndEvolutionPhase } from "./end-evolution-phase"; +import { getPokemonNameWithAffix } from "#app/messages"; +import { LearnMovePhase } from "#app/phases/learn-move-phase"; +import { EndEvolutionPhase } from "#app/phases/end-evolution-phase"; export class EvolutionPhase extends Phase { protected pokemon: PlayerPokemon; protected lastLevel: integer; + private preEvolvedPokemonName: string; + private evolution: SpeciesFormEvolution | null; + private evolutionBgm: AnySound; + private evolutionHandler: EvolutionSceneHandler; protected evolutionContainer: Phaser.GameObjects.Container; protected evolutionBaseBg: Phaser.GameObjects.Image; @@ -56,9 +60,9 @@ export class EvolutionPhase extends Phase { this.scene.fadeOutBgm(undefined, false); - const evolutionHandler = this.scene.ui.getHandler() as EvolutionSceneHandler; + this.evolutionHandler = this.scene.ui.getHandler() as EvolutionSceneHandler; - this.evolutionContainer = evolutionHandler.evolutionContainer; + this.evolutionContainer = this.evolutionHandler.evolutionContainer; this.evolutionBaseBg = this.scene.add.image(0, 0, "default_bg"); this.evolutionBaseBg.setOrigin(0, 0); @@ -111,16 +115,13 @@ export class EvolutionPhase extends Phase { sprite.pipelineData[k] = this.pokemon.getSprite().pipelineData[k]; }); }); - + this.preEvolvedPokemonName = getPokemonNameWithAffix(this.pokemon); this.doEvolution(); }); } doEvolution(): void { - const evolutionHandler = this.scene.ui.getHandler() as EvolutionSceneHandler; - const preName = getPokemonNameWithAffix(this.pokemon); - - this.scene.ui.showText(i18next.t("menu:evolving", { pokemonName: preName }), null, () => { + this.scene.ui.showText(i18next.t("menu:evolving", { pokemonName: this.preEvolvedPokemonName }), null, () => { this.pokemon.cry(); this.pokemon.getPossibleEvolution(this.evolution).then(evolvedPokemon => { @@ -140,7 +141,7 @@ export class EvolutionPhase extends Phase { }); this.scene.time.delayedCall(1000, () => { - const evolutionBgm = this.scene.playSoundWithoutBgm("evolution"); + this.evolutionBgm = this.scene.playSoundWithoutBgm("evolution"); this.scene.tweens.add({ targets: this.evolutionBgOverlay, alpha: 1, @@ -174,100 +175,13 @@ export class EvolutionPhase extends Phase { this.scene.time.delayedCall(1500, () => { this.pokemonEvoTintSprite.setScale(0.25); this.pokemonEvoTintSprite.setVisible(true); - evolutionHandler.canCancel = true; + this.evolutionHandler.canCancel = true; this.doCycle(1).then(success => { - if (!success) { - - this.pokemonSprite.setVisible(true); - this.pokemonTintSprite.setScale(1); - this.scene.tweens.add({ - targets: [ this.evolutionBg, this.pokemonTintSprite, this.pokemonEvoSprite, this.pokemonEvoTintSprite ], - alpha: 0, - duration: 250, - onComplete: () => { - this.evolutionBg.setVisible(false); - } - }); - - SoundFade.fadeOut(this.scene, evolutionBgm, 100); - - this.scene.unshiftPhase(new EndEvolutionPhase(this.scene)); - - this.scene.ui.showText(i18next.t("menu:stoppedEvolving", { pokemonName: preName }), null, () => { - this.scene.ui.showText(i18next.t("menu:pauseEvolutionsQuestion", { pokemonName: preName }), null, () => { - const end = () => { - this.scene.ui.showText("", 0); - this.scene.playBgm(); - evolvedPokemon.destroy(); - this.end(); - }; - this.scene.ui.setOverlayMode(Mode.CONFIRM, () => { - this.scene.ui.revertMode(); - this.pokemon.pauseEvolutions = true; - this.scene.ui.showText(i18next.t("menu:evolutionsPaused", { pokemonName: preName }), null, end, 3000); - }, () => { - this.scene.ui.revertMode(); - this.scene.time.delayedCall(3000, end); - }); - }); - }, null, true); - return; + if (success) { + this.handleSuccessEvolution(evolvedPokemon); + } else { + this.handleFailedEvolution(evolvedPokemon); } - - this.scene.playSound("se/sparkle"); - this.pokemonEvoSprite.setVisible(true); - this.doCircleInward(); - this.scene.time.delayedCall(900, () => { - evolutionHandler.canCancel = false; - - this.pokemon.evolve(this.evolution, this.pokemon.species).then(() => { - const levelMoves = this.pokemon.getLevelMoves(this.lastLevel + 1, true); - for (const lm of levelMoves) { - this.scene.unshiftPhase(new LearnMovePhase(this.scene, this.scene.getParty().indexOf(this.pokemon), lm[1])); - } - this.scene.unshiftPhase(new EndEvolutionPhase(this.scene)); - - this.scene.playSound("se/shine"); - this.doSpray(); - this.scene.tweens.add({ - targets: this.evolutionOverlay, - alpha: 1, - duration: 250, - easing: "Sine.easeIn", - onComplete: () => { - this.evolutionBgOverlay.setAlpha(1); - this.evolutionBg.setVisible(false); - this.scene.tweens.add({ - targets: [ this.evolutionOverlay, this.pokemonEvoTintSprite ], - alpha: 0, - duration: 2000, - delay: 150, - easing: "Sine.easeIn", - onComplete: () => { - this.scene.tweens.add({ - targets: this.evolutionBgOverlay, - alpha: 0, - duration: 250, - onComplete: () => { - SoundFade.fadeOut(this.scene, evolutionBgm, 100); - this.scene.time.delayedCall(250, () => { - this.pokemon.cry(); - this.scene.time.delayedCall(1250, () => { - this.scene.playSoundWithoutBgm("evolution_fanfare"); - - evolvedPokemon.destroy(); - this.scene.ui.showText(i18next.t("menu:evolutionDone", { pokemonName: preName, evolvedPokemonName: this.pokemon.name }), null, () => this.end(), null, true, Utils.fixedInt(4000)); - this.scene.time.delayedCall(Utils.fixedInt(4250), () => this.scene.playBgm()); - }); - }); - } - }); - } - }); - } - }); - }); - }); }); }); }); @@ -280,6 +194,110 @@ export class EvolutionPhase extends Phase { }, 1000); } + /** + * Handles a failed/stopped evolution + * @param evolvedPokemon - The evolved Pokemon + */ + private handleFailedEvolution(evolvedPokemon: Pokemon): void { + this.pokemonSprite.setVisible(true); + this.pokemonTintSprite.setScale(1); + this.scene.tweens.add({ + targets: [ this.evolutionBg, this.pokemonTintSprite, this.pokemonEvoSprite, this.pokemonEvoTintSprite ], + alpha: 0, + duration: 250, + onComplete: () => { + this.evolutionBg.setVisible(false); + } + }); + + SoundFade.fadeOut(this.scene, this.evolutionBgm, 100); + + this.scene.unshiftPhase(new EndEvolutionPhase(this.scene)); + + this.scene.ui.showText(i18next.t("menu:stoppedEvolving", { pokemonName: this.preEvolvedPokemonName }), null, () => { + this.scene.ui.showText(i18next.t("menu:pauseEvolutionsQuestion", { pokemonName: this.preEvolvedPokemonName }), null, () => { + const end = () => { + this.scene.ui.showText("", 0); + this.scene.playBgm(); + evolvedPokemon.destroy(); + this.end(); + }; + this.scene.ui.setOverlayMode(Mode.CONFIRM, () => { + this.scene.ui.revertMode(); + this.pokemon.pauseEvolutions = true; + this.scene.ui.showText(i18next.t("menu:evolutionsPaused", { pokemonName: this.preEvolvedPokemonName }), null, end, 3000); + }, () => { + this.scene.ui.revertMode(); + this.scene.time.delayedCall(3000, end); + }); + }); + }, null, true); + } + + /** + * Handles a successful evolution + * @param evolvedPokemon - The evolved Pokemon + */ + private handleSuccessEvolution(evolvedPokemon: Pokemon): void { + this.scene.playSound("se/sparkle"); + this.pokemonEvoSprite.setVisible(true); + this.doCircleInward(); + + const onEvolutionComplete = () => { + SoundFade.fadeOut(this.scene, this.evolutionBgm, 100); + this.scene.time.delayedCall(250, () => { + this.pokemon.cry(); + this.scene.time.delayedCall(1250, () => { + this.scene.playSoundWithoutBgm("evolution_fanfare"); + + evolvedPokemon.destroy(); + this.scene.ui.showText(i18next.t("menu:evolutionDone", { pokemonName: this.preEvolvedPokemonName, evolvedPokemonName: this.pokemon.name }), null, () => this.end(), null, true, Utils.fixedInt(4000)); + this.scene.time.delayedCall(Utils.fixedInt(4250), () => this.scene.playBgm()); + }); + }); + }; + + this.scene.time.delayedCall(900, () => { + this.evolutionHandler.canCancel = false; + + this.pokemon.evolve(this.evolution, this.pokemon.species).then(() => { + const levelMoves = this.pokemon.getLevelMoves(this.lastLevel + 1, true); + for (const lm of levelMoves) { + this.scene.unshiftPhase(new LearnMovePhase(this.scene, this.scene.getPlayerParty().indexOf(this.pokemon), lm[1])); + } + this.scene.unshiftPhase(new EndEvolutionPhase(this.scene)); + + this.scene.playSound("se/shine"); + this.doSpray(); + this.scene.tweens.add({ + targets: this.evolutionOverlay, + alpha: 1, + duration: 250, + easing: "Sine.easeIn", + onComplete: () => { + this.evolutionBgOverlay.setAlpha(1); + this.evolutionBg.setVisible(false); + this.scene.tweens.add({ + targets: [ this.evolutionOverlay, this.pokemonEvoTintSprite ], + alpha: 0, + duration: 2000, + delay: 150, + easing: "Sine.easeIn", + onComplete: () => { + this.scene.tweens.add({ + targets: this.evolutionBgOverlay, + alpha: 0, + duration: 250, + onComplete: onEvolutionComplete + }); + } + }); + } + }); + }); + }); + } + doSpiralUpward() { let f = 0; @@ -320,7 +338,6 @@ export class EvolutionPhase extends Phase { doCycle(l: number, lastCycle: integer = 15): Promise { return new Promise(resolve => { - const evolutionHandler = this.scene.ui.getHandler() as EvolutionSceneHandler; const isLastCycle = l === lastCycle; this.scene.tweens.add({ targets: this.pokemonTintSprite, @@ -336,7 +353,7 @@ export class EvolutionPhase extends Phase { duration: 500 / l, yoyo: !isLastCycle, onComplete: () => { - if (evolutionHandler.cancelled) { + if (this.evolutionHandler.cancelled) { return resolve(false); } if (l < lastCycle) { diff --git a/src/phases/faint-phase.ts b/src/phases/faint-phase.ts index 41384e5e491..1c48bdfb37a 100644 --- a/src/phases/faint-phase.ts +++ b/src/phases/faint-phase.ts @@ -1,48 +1,89 @@ -import BattleScene from "#app/battle-scene"; import { BattlerIndex, BattleType } from "#app/battle"; -import { applyPostFaintAbAttrs, PostFaintAbAttr, applyPostKnockOutAbAttrs, PostKnockOutAbAttr, applyPostVictoryAbAttrs, PostVictoryAbAttr } from "#app/data/ability"; -import { BattlerTagLapseType } from "#app/data/battler-tags"; +import BattleScene from "#app/battle-scene"; +import { applyPostFaintAbAttrs, applyPostKnockOutAbAttrs, applyPostVictoryAbAttrs, PostFaintAbAttr, PostKnockOutAbAttr, PostVictoryAbAttr } from "#app/data/ability"; +import { BattlerTagLapseType, DestinyBondTag, GrudgeTag } from "#app/data/battler-tags"; import { battleSpecDialogue } from "#app/data/dialogue"; import { allMoves, PostVictoryStatStageChangeAttr } from "#app/data/move"; +import { SpeciesFormChangeActiveTrigger } from "#app/data/pokemon-forms"; import { BattleSpec } from "#app/enums/battle-spec"; import { StatusEffect } from "#app/enums/status-effect"; -import { PokemonMove, EnemyPokemon, PlayerPokemon, HitResult } from "#app/field/pokemon"; +import Pokemon, { EnemyPokemon, HitResult, PlayerPokemon, PokemonMove } from "#app/field/pokemon"; import { getPokemonNameWithAffix } from "#app/messages"; import { PokemonInstantReviveModifier } from "#app/modifier/modifier"; +import { SwitchType } from "#enums/switch-type"; import i18next from "i18next"; import { DamagePhase } from "./damage-phase"; +import { GameOverPhase } from "./game-over-phase"; import { PokemonPhase } from "./pokemon-phase"; +import { SwitchPhase } from "./switch-phase"; import { SwitchSummonPhase } from "./switch-summon-phase"; import { ToggleDoublePositionPhase } from "./toggle-double-position-phase"; -import { GameOverPhase } from "./game-over-phase"; -import { SwitchPhase } from "./switch-phase"; import { VictoryPhase } from "./victory-phase"; -import { SpeciesFormChangeActiveTrigger } from "#app/data/pokemon-forms"; +import { isNullOrUndefined } from "#app/utils"; +import { FRIENDSHIP_LOSS_FROM_FAINT } from "#app/data/balance/starters"; export class FaintPhase extends PokemonPhase { + /** + * Whether or not enduring (for this phase's purposes, Reviver Seed) should be prevented + */ private preventEndure: boolean; - constructor(scene: BattleScene, battlerIndex: BattlerIndex, preventEndure?: boolean) { + /** + * Destiny Bond tag belonging to the currently fainting Pokemon, if applicable + */ + private destinyTag?: DestinyBondTag | null; + + /** + * Grudge tag belonging to the currently fainting Pokemon, if applicable + */ + private grudgeTag?: GrudgeTag | null; + + /** + * The source Pokemon that dealt fatal damage + */ + private source?: Pokemon; + + constructor(scene: BattleScene, battlerIndex: BattlerIndex, preventEndure: boolean = false, destinyTag?: DestinyBondTag | null, grudgeTag?: GrudgeTag | null, source?: Pokemon) { super(scene, battlerIndex); - this.preventEndure = preventEndure!; // TODO: is this bang correct? + this.preventEndure = preventEndure; + this.destinyTag = destinyTag; + this.grudgeTag = grudgeTag; + this.source = source; } start() { super.start(); + const faintPokemon = this.getPokemon(); + + if (!isNullOrUndefined(this.destinyTag) && !isNullOrUndefined(this.source)) { + this.destinyTag.lapse(this.source, BattlerTagLapseType.CUSTOM); + } + + if (!isNullOrUndefined(this.grudgeTag) && !isNullOrUndefined(this.source)) { + this.grudgeTag.lapse(faintPokemon, BattlerTagLapseType.CUSTOM, this.source); + } + if (!this.preventEndure) { - const instantReviveModifier = this.scene.applyModifier(PokemonInstantReviveModifier, this.player, this.getPokemon()) as PokemonInstantReviveModifier; + const instantReviveModifier = this.scene.applyModifier(PokemonInstantReviveModifier, this.player, faintPokemon) as PokemonInstantReviveModifier; if (instantReviveModifier) { - if (!--instantReviveModifier.stackCount) { - this.scene.removeModifier(instantReviveModifier); - } + faintPokemon.loseHeldItem(instantReviveModifier); this.scene.updateModifiers(this.player); return this.end(); } } + /** In case the current pokemon was just switched in, make sure it is counted as participating in the combat */ + this.scene.getPlayerField().forEach((pokemon, i) => { + if (pokemon?.isActive(true)) { + if (pokemon.isPlayer()) { + this.scene.currentBattle.addParticipant(pokemon as PlayerPokemon); + } + } + }); + if (!this.tryOverrideForBattleSpec()) { this.doFaint(); } @@ -89,7 +130,7 @@ export class FaintPhase extends PokemonPhase { if (this.player) { /** The total number of Pokemon in the player's party that can legally fight */ - const legalPlayerPokemon = this.scene.getParty().filter(p => p.isAllowedInBattle()); + const legalPlayerPokemon = this.scene.getPokemonAllowedInBattle(); /** The total number of legal player Pokemon that aren't currently on the field */ const legalPlayerPartyPokemon = legalPlayerPokemon.filter(p => !p.isActive(true)); if (!legalPlayerPokemon.length) { @@ -106,14 +147,14 @@ export class FaintPhase extends PokemonPhase { * If previous conditions weren't met, and the player has at least 1 legal Pokemon off the field, * push a phase that prompts the player to summon a Pokemon from their party. */ - this.scene.pushPhase(new SwitchPhase(this.scene, this.fieldIndex, true, false)); + this.scene.pushPhase(new SwitchPhase(this.scene, SwitchType.SWITCH, this.fieldIndex, true, false)); } } else { this.scene.unshiftPhase(new VictoryPhase(this.scene, this.battlerIndex)); - if ([BattleType.TRAINER, BattleType.MYSTERY_ENCOUNTER].includes(this.scene.currentBattle.battleType)) { + if ([ BattleType.TRAINER, BattleType.MYSTERY_ENCOUNTER ].includes(this.scene.currentBattle.battleType)) { const hasReservePartyMember = !!this.scene.getEnemyParty().filter(p => p.isActive() && !p.isOnField() && p.trainerSlot === (pokemon as EnemyPokemon).trainerSlot).length; if (hasReservePartyMember) { - this.scene.pushPhase(new SwitchSummonPhase(this.scene, this.fieldIndex, -1, false, false, false)); + this.scene.pushPhase(new SwitchSummonPhase(this.scene, SwitchType.SWITCH, this.fieldIndex, -1, false, false)); } } } @@ -126,7 +167,7 @@ export class FaintPhase extends PokemonPhase { pokemon.faintCry(() => { if (pokemon instanceof PlayerPokemon) { - pokemon.addFriendship(-10); + pokemon.addFriendship(-FRIENDSHIP_LOSS_FROM_FAINT); } pokemon.hideInfo(); this.scene.playSound("se/faint"); @@ -157,19 +198,19 @@ export class FaintPhase extends PokemonPhase { tryOverrideForBattleSpec(): boolean { switch (this.scene.currentBattle.battleSpec) { - case BattleSpec.FINAL_BOSS: - if (!this.player) { - const enemy = this.getPokemon(); - if (enemy.formIndex) { - this.scene.ui.showDialogue(battleSpecDialogue[BattleSpec.FINAL_BOSS].secondStageWin, enemy.species.name, null, () => this.doFaint()); - } else { + case BattleSpec.FINAL_BOSS: + if (!this.player) { + const enemy = this.getPokemon(); + if (enemy.formIndex) { + this.scene.ui.showDialogue(battleSpecDialogue[BattleSpec.FINAL_BOSS].secondStageWin, enemy.species.name, null, () => this.doFaint()); + } else { // Final boss' HP threshold has been bypassed; cancel faint and force check for 2nd phase - enemy.hp++; - this.scene.unshiftPhase(new DamagePhase(this.scene, enemy.getBattlerIndex(), 0, HitResult.OTHER)); - this.end(); + enemy.hp++; + this.scene.unshiftPhase(new DamagePhase(this.scene, enemy.getBattlerIndex(), 0, HitResult.OTHER)); + this.end(); + } + return true; } - return true; - } } return false; diff --git a/src/phases/form-change-phase.ts b/src/phases/form-change-phase.ts index 33c1f8e8cef..410163a70e4 100644 --- a/src/phases/form-change-phase.ts +++ b/src/phases/form-change-phase.ts @@ -1,6 +1,5 @@ import BattleScene from "../battle-scene"; import * as Utils from "../utils"; -import { SpeciesFormKey } from "../data/pokemon-species"; import { achvs } from "../system/achv"; import { SpeciesFormChange, getSpeciesFormChangeMessage } from "../data/pokemon-forms"; import { PlayerPokemon } from "../field/pokemon"; @@ -9,6 +8,8 @@ import PartyUiHandler from "../ui/party-ui-handler"; import { getPokemonNameWithAffix } from "../messages"; import { EndEvolutionPhase } from "./end-evolution-phase"; import { EvolutionPhase } from "./evolution-phase"; +import { BattlerTagType } from "#app/enums/battler-tag-type"; +import { SpeciesFormKey } from "#enums/species-form-key"; export class FormChangePhase extends EvolutionPhase { private formChange: SpeciesFormChange; @@ -157,6 +158,7 @@ export class FormChangePhase extends EvolutionPhase { } end(): void { + this.pokemon.findAndRemoveTags(t => t.tagType === BattlerTagType.AUTOTOMIZED); if (this.modal) { this.scene.ui.revertMode().then(() => { if (this.scene.ui.getMode() === Mode.PARTY) { diff --git a/src/phases/game-over-phase.ts b/src/phases/game-over-phase.ts index 8ab191324c6..84a4a4e8ef9 100644 --- a/src/phases/game-over-phase.ts +++ b/src/phases/game-over-phase.ts @@ -1,43 +1,38 @@ import { clientSessionId } from "#app/account"; -import BattleScene from "#app/battle-scene"; import { BattleType } from "#app/battle"; +import BattleScene from "#app/battle-scene"; +import { pokemonEvolutions } from "#app/data/balance/pokemon-evolutions"; import { getCharVariantFromDialogue } from "#app/data/dialogue"; -import { pokemonEvolutions } from "#app/data/pokemon-evolutions"; import PokemonSpecies, { getPokemonSpecies } from "#app/data/pokemon-species"; import { trainerConfigs } from "#app/data/trainer-config"; -import { PlayerGender } from "#app/enums/player-gender"; -import { TrainerType } from "#app/enums/trainer-type"; import Pokemon from "#app/field/pokemon"; import { modifierTypes } from "#app/modifier/modifier-type"; +import { BattlePhase } from "#app/phases/battle-phase"; +import { CheckSwitchPhase } from "#app/phases/check-switch-phase"; +import { EncounterPhase } from "#app/phases/encounter-phase"; +import { EndCardPhase } from "#app/phases/end-card-phase"; +import { GameOverModifierRewardPhase } from "#app/phases/game-over-modifier-reward-phase"; +import { PostGameOverPhase } from "#app/phases/post-game-over-phase"; +import { RibbonModifierRewardPhase } from "#app/phases/ribbon-modifier-reward-phase"; +import { SummonPhase } from "#app/phases/summon-phase"; +import { UnlockPhase } from "#app/phases/unlock-phase"; import { achvs, ChallengeAchv } from "#app/system/achv"; import { Unlockables } from "#app/system/unlockables"; import { Mode } from "#app/ui/ui"; -import i18next from "i18next"; import * as Utils from "#app/utils"; -import { BattlePhase } from "./battle-phase"; -import { CheckSwitchPhase } from "./check-switch-phase"; -import { EncounterPhase } from "./encounter-phase"; -import { GameOverModifierRewardPhase } from "./game-over-modifier-reward-phase"; -import { RibbonModifierRewardPhase } from "./ribbon-modifier-reward-phase"; -import { SummonPhase } from "./summon-phase"; -import { EndCardPhase } from "./end-card-phase"; -import { PostGameOverPhase } from "./post-game-over-phase"; -import { UnlockPhase } from "./unlock-phase"; -import { SessionSaveData } from "../system/game-data"; -import TrainerData from "../system/trainer-data"; -import PokemonData from "../system/pokemon-data"; -import PersistentModifierData from "../system/modifier-data"; -import ChallengeData from "../system/challenge-data"; -import ArenaData from "../system/arena-data"; +import { PlayerGender } from "#enums/player-gender"; +import { TrainerType } from "#enums/trainer-type"; +import i18next from "i18next"; +import { pokerogueApi } from "#app/plugins/api/pokerogue-api"; export class GameOverPhase extends BattlePhase { - private victory: boolean; + private isVictory: boolean; private firstRibbons: PokemonSpecies[] = []; - constructor(scene: BattleScene, victory?: boolean) { + constructor(scene: BattleScene, isVictory: boolean = false) { super(scene); - this.victory = !!victory; + this.isVictory = isVictory; } start() { @@ -45,14 +40,22 @@ export class GameOverPhase extends BattlePhase { // Failsafe if players somehow skip floor 200 in classic mode if (this.scene.gameMode.isClassic && this.scene.currentBattle.waveIndex > 200) { - this.victory = true; + this.isVictory = true; } - if (this.victory && this.scene.gameMode.isEndless) { + // Handle Mystery Encounter special Game Over cases + // Situations such as when player lost a battle, but it isn't treated as full Game Over + if (!this.isVictory && this.scene.currentBattle.mysteryEncounter?.onGameOver && !this.scene.currentBattle.mysteryEncounter.onGameOver(this.scene)) { + // Do not end the game + return this.end(); + } + // Otherwise, continue standard Game Over logic + + if (this.isVictory && this.scene.gameMode.isEndless) { const genderIndex = this.scene.gameData.gender ?? PlayerGender.UNSET; const genderStr = PlayerGender[genderIndex].toLowerCase(); this.scene.ui.showDialogue(i18next.t("miscDialogue:ending_endless", { context: genderStr }), i18next.t("miscDialogue:ending_name"), 0, () => this.handleGameOver()); - } else if (this.victory || !this.scene.enableRetries) { + } else if (this.isVictory || !this.scene.enableRetries) { this.handleGameOver(); } else { this.scene.ui.showText(i18next.t("battle:retryBattle"), null, () => { @@ -63,7 +66,7 @@ export class GameOverPhase extends BattlePhase { this.scene.gameData.loadSession(this.scene, this.scene.sessionSlotId).then(() => { this.scene.pushPhase(new EncounterPhase(this.scene, true)); - const availablePartyMembers = this.scene.getParty().filter(p => p.isAllowedInBattle()).length; + const availablePartyMembers = this.scene.getPokemonAllowedInBattle().length; this.scene.pushPhase(new SummonPhase(this.scene, 0)); if (this.scene.currentBattle.double && availablePartyMembers > 1) { @@ -90,12 +93,12 @@ export class GameOverPhase extends BattlePhase { this.scene.disableMenu = true; this.scene.time.delayedCall(1000, () => { let firstClear = false; - if (this.victory && newClear) { + if (this.isVictory && newClear) { if (this.scene.gameMode.isClassic) { firstClear = this.scene.validateAchv(achvs.CLASSIC_VICTORY); this.scene.validateAchv(achvs.UNEVOLVED_CLASSIC_VICTORY); this.scene.gameData.gameStats.sessionsWon++; - for (const pokemon of this.scene.getParty()) { + for (const pokemon of this.scene.getPlayerParty()) { this.awardRibbon(pokemon); if (pokemon.species.getRootSpeciesId() !== pokemon.species.getRootSpeciesId(true)) { @@ -106,8 +109,8 @@ export class GameOverPhase extends BattlePhase { this.scene.gameData.gameStats.dailyRunSessionsWon++; } } - this.scene.gameData.saveRunHistory(this.scene, this.getFinalSessionData(), this.victory); - const fadeDuration = this.victory ? 10000 : 5000; + this.scene.gameData.saveRunHistory(this.scene, this.scene.gameData.getSessionSaveData(this.scene), this.isVictory); + const fadeDuration = this.isVictory ? 10000 : 5000; this.scene.fadeOutBgm(fadeDuration, true); const activeBattlers = this.scene.getField().filter(p => p?.isActive(true)); activeBattlers.map(p => p.hideInfo()); @@ -117,15 +120,14 @@ export class GameOverPhase extends BattlePhase { this.scene.clearPhaseQueue(); this.scene.ui.clearText(); - if (this.victory && this.scene.gameMode.isChallenge) { + if (this.isVictory && this.scene.gameMode.isChallenge) { this.scene.gameMode.challenges.forEach(c => this.scene.validateAchvs(ChallengeAchv, c)); } const clear = (endCardPhase?: EndCardPhase) => { - if (newClear) { + if (this.isVictory && newClear) { this.handleUnlocks(); - } - if (this.victory && newClear) { + for (const species of this.firstRibbons) { this.scene.unshiftPhase(new RibbonModifierRewardPhase(this.scene, modifierTypes.VOUCHER_PLUS, species)); } @@ -137,7 +139,7 @@ export class GameOverPhase extends BattlePhase { this.end(); }; - if (this.victory && this.scene.gameMode.isClassic) { + if (this.isVictory && this.scene.gameMode.isClassic) { const dialogueKey = "miscDialogue:ending"; if (!this.scene.ui.shouldSkipDialogue(dialogueKey)) { @@ -170,36 +172,33 @@ export class GameOverPhase extends BattlePhase { }); }; - /* Added a local check to see if the game is running offline on victory + /* Added a local check to see if the game is running offline If Online, execute apiFetch as intended - If Offline, execute offlineNewClear(), a localStorage implementation of newClear daily run checks */ - if (this.victory) { - if (!Utils.isLocal) { - Utils.apiFetch(`savedata/session/newclear?slot=${this.scene.sessionSlotId}&clientSessionId=${clientSessionId}`, true) - .then(response => response.json()) - .then(newClear => doGameOver(newClear)); - } else { - this.scene.gameData.offlineNewClear(this.scene).then(result => { - doGameOver(result); - }); - } + If Offline, execute offlineNewClear() only for victory, a localStorage implementation of newClear daily run checks */ + if (!Utils.isLocal || Utils.isLocalServerConnected) { + pokerogueApi.savedata.session.newclear({ slot: this.scene.sessionSlotId, isVictory: this.isVictory, clientSessionId: clientSessionId }) + .then((success) => doGameOver(!!success)); + } else if (this.isVictory) { + this.scene.gameData.offlineNewClear(this.scene).then(result => { + doGameOver(result); + }); } else { doGameOver(false); } } handleUnlocks(): void { - if (this.victory && this.scene.gameMode.isClassic) { + if (this.isVictory && this.scene.gameMode.isClassic) { if (!this.scene.gameData.unlocks[Unlockables.ENDLESS_MODE]) { this.scene.unshiftPhase(new UnlockPhase(this.scene, Unlockables.ENDLESS_MODE)); } - if (this.scene.getParty().filter(p => p.fusionSpecies).length && !this.scene.gameData.unlocks[Unlockables.SPLICED_ENDLESS_MODE]) { + if (this.scene.getPlayerParty().filter(p => p.fusionSpecies).length && !this.scene.gameData.unlocks[Unlockables.SPLICED_ENDLESS_MODE]) { this.scene.unshiftPhase(new UnlockPhase(this.scene, Unlockables.SPLICED_ENDLESS_MODE)); } if (!this.scene.gameData.unlocks[Unlockables.MINI_BLACK_HOLE]) { this.scene.unshiftPhase(new UnlockPhase(this.scene, Unlockables.MINI_BLACK_HOLE)); } - if (!this.scene.gameData.unlocks[Unlockables.EVIOLITE] && this.scene.getParty().some(p => p.getSpeciesForm(true).speciesId in pokemonEvolutions)) { + if (!this.scene.gameData.unlocks[Unlockables.EVIOLITE] && this.scene.getPlayerParty().some(p => p.getSpeciesForm(true).speciesId in pokemonEvolutions)) { this.scene.unshiftPhase(new UnlockPhase(this.scene, Unlockables.EVIOLITE)); } } @@ -213,34 +212,5 @@ export class GameOverPhase extends BattlePhase { this.firstRibbons.push(getPokemonSpecies(pokemon.species.getRootSpeciesId(forStarter))); } } - - /** - * This function mirrors game-data.ts' getSessionSaveData() to update the session data to reflect any changes that occurred within the last wave - * This means that level ups, item usage, evolutions, etc. will all be accurately reflected. - * @returns {@linkCode SessionSaveData} an updated version of the wave's SessionSaveData that accurately reflects the events of the wave - */ - private getFinalSessionData(): SessionSaveData { - return { - seed: this.scene.seed, - playTime: this.scene.sessionPlayTime, - gameMode: this.scene.gameMode.modeId, - party: this.scene.getParty().map(p => new PokemonData(p)), - enemyParty: this.scene.getEnemyParty().map(p => new PokemonData(p)), - modifiers: this.scene.findModifiers(() => true).map(m => new PersistentModifierData(m, true)), - enemyModifiers: this.scene.findModifiers(() => true, false).map(m => new PersistentModifierData(m, false)), - arena: new ArenaData(this.scene.arena), - pokeballCounts: this.scene.pokeballCounts, - money: this.scene.money, - score: this.scene.score, - waveIndex: this.scene.currentBattle.waveIndex, - battleType: this.scene.currentBattle.battleType, - trainer: this.scene.currentBattle.battleType === BattleType.TRAINER ? new TrainerData(this.scene.currentBattle.trainer) : null, - gameVersion: this.scene.game.config.gameVersion, - timestamp: new Date().getTime(), - challenges: this.scene.gameMode.challenges.map(c => new ChallengeData(c)), - mysteryEncounterType: this.scene.currentBattle.mysteryEncounter?.encounterType, - mysteryEncounterSaveData: this.scene.mysteryEncounterSaveData - } as SessionSaveData; - } } diff --git a/src/phases/learn-move-phase.ts b/src/phases/learn-move-phase.ts index 5b4b16f3785..fefda384092 100644 --- a/src/phases/learn-move-phase.ts +++ b/src/phases/learn-move-phase.ts @@ -2,24 +2,37 @@ import BattleScene from "#app/battle-scene"; import { initMoveAnim, loadMoveAnimAssets } from "#app/data/battle-anims"; import Move, { allMoves } from "#app/data/move"; import { SpeciesFormChangeMoveLearnedTrigger } from "#app/data/pokemon-forms"; -import { Moves } from "#app/enums/moves"; +import { Moves } from "#enums/moves"; import { getPokemonNameWithAffix } from "#app/messages"; +import Overrides from "#app/overrides"; import EvolutionSceneHandler from "#app/ui/evolution-scene-handler"; import { SummaryUiMode } from "#app/ui/summary-ui-handler"; import { Mode } from "#app/ui/ui"; import i18next from "i18next"; -import { PlayerPartyMemberPokemonPhase } from "./player-party-member-pokemon-phase"; +import { PlayerPartyMemberPokemonPhase } from "#app/phases/player-party-member-pokemon-phase"; import Pokemon from "#app/field/pokemon"; +import { SelectModifierPhase } from "#app/phases/select-modifier-phase"; + +export enum LearnMoveType { + /** For learning a move via level-up, evolution, or other non-item-based event */ + LEARN_MOVE, + /** For learning a move via Memory Mushroom */ + MEMORY, + /** For learning a move via TM */ + TM +} export class LearnMovePhase extends PlayerPartyMemberPokemonPhase { private moveId: Moves; private messageMode: Mode; - private fromTM: boolean; + private learnMoveType; + private cost: number; - constructor(scene: BattleScene, partyMemberIndex: integer, moveId: Moves, fromTM?: boolean) { + constructor(scene: BattleScene, partyMemberIndex: integer, moveId: Moves, learnMoveType: LearnMoveType = LearnMoveType.LEARN_MOVE, cost: number = -1) { super(scene, partyMemberIndex); this.moveId = moveId; - this.fromTM = fromTM ?? false; + this.learnMoveType = learnMoveType; + this.cost = cost; } start() { @@ -59,7 +72,7 @@ export class LearnMovePhase extends PlayerPartyMemberPokemonPhase { const learnMovePrompt = i18next.t("battle:learnMovePrompt", { pokemonName: getPokemonNameWithAffix(pokemon), moveName: move.name }); const moveLimitReached = i18next.t("battle:learnMoveLimitReached", { pokemonName: getPokemonNameWithAffix(pokemon) }); const shouldReplaceQ = i18next.t("battle:learnMoveReplaceQuestion", { moveName: move.name }); - const preQText = [learnMovePrompt, moveLimitReached].join("$"); + const preQText = [ learnMovePrompt, moveLimitReached ].join("$"); await this.scene.ui.showTextPromise(preQText); await this.scene.ui.showTextPromise(shouldReplaceQ, undefined, false); await this.scene.ui.setModeWithoutClear(Mode.CONFIRM, @@ -91,7 +104,7 @@ export class LearnMovePhase extends PlayerPartyMemberPokemonPhase { return; } const forgetSuccessText = i18next.t("battle:learnMoveForgetSuccess", { pokemonName: getPokemonNameWithAffix(pokemon), moveName: pokemon.moveset[moveIndex]!.getName() }); - const fullText = [i18next.t("battle:countdownPoof"), forgetSuccessText, i18next.t("battle:learnMoveAnd")].join("$"); + const fullText = [ i18next.t("battle:countdownPoof"), forgetSuccessText, i18next.t("battle:learnMoveAnd") ].join("$"); this.scene.ui.setMode(this.messageMode).then(() => this.learnMove(moveIndex, move, pokemon, fullText)); }); } @@ -136,22 +149,37 @@ export class LearnMovePhase extends PlayerPartyMemberPokemonPhase { * @param Pokemon The Pokemon learning the move */ async learnMove(index: number, move: Move, pokemon: Pokemon, textMessage?: string) { - if (this.fromTM) { + if (this.learnMoveType === LearnMoveType.TM) { if (!pokemon.usedTMs) { pokemon.usedTMs = []; } pokemon.usedTMs.push(this.moveId); + this.scene.tryRemovePhase((phase) => phase instanceof SelectModifierPhase); + } else if (this.learnMoveType === LearnMoveType.MEMORY) { + if (this.cost !== -1) { + if (!Overrides.WAIVE_ROLL_FEE_OVERRIDE) { + this.scene.money -= this.cost; + this.scene.updateMoneyText(); + this.scene.animateMoneyChanged(false); + } + this.scene.playSound("se/buy"); + } else { + this.scene.tryRemovePhase((phase) => phase instanceof SelectModifierPhase); + } } pokemon.setMove(index, this.moveId); initMoveAnim(this.scene, this.moveId).then(() => { - loadMoveAnimAssets(this.scene, [this.moveId], true); - this.scene.playSound("level_up_fanfare"); // Sound loaded into game as is + loadMoveAnimAssets(this.scene, [ this.moveId ], true); }); this.scene.ui.setMode(this.messageMode); const learnMoveText = i18next.t("battle:learnMove", { pokemonName: getPokemonNameWithAffix(pokemon), moveName: move.name }); - textMessage = textMessage ? textMessage+"$"+learnMoveText : learnMoveText; - await this.scene.ui.showTextPromise(textMessage, this.messageMode === Mode.EVOLUTION_SCENE ? 1000 : undefined, true); - this.scene.triggerPokemonFormChange(pokemon, SpeciesFormChangeMoveLearnedTrigger, true); - this.end(); + if (textMessage) { + await this.scene.ui.showTextPromise(textMessage); + } + this.scene.playSound("level_up_fanfare"); // Sound loaded into game as is + this.scene.ui.showText(learnMoveText, null, () => { + this.scene.triggerPokemonFormChange(pokemon, SpeciesFormChangeMoveLearnedTrigger, true); + this.end(); + }, this.messageMode === Mode.EVOLUTION_SCENE ? 1000 : undefined, true); } } diff --git a/src/phases/level-up-phase.ts b/src/phases/level-up-phase.ts index a99e038acba..4f26abc5af3 100644 --- a/src/phases/level-up-phase.ts +++ b/src/phases/level-up-phase.ts @@ -1,59 +1,66 @@ -import BattleScene from "#app/battle-scene"; +import type BattleScene from "#app/battle-scene"; import { ExpNotification } from "#app/enums/exp-notification"; -import { EvolutionPhase } from "#app/phases/evolution-phase"; -import { PlayerPokemon } from "#app/field/pokemon"; +import type { PlayerPokemon } from "#app/field/pokemon"; import { getPokemonNameWithAffix } from "#app/messages"; +import { EvolutionPhase } from "#app/phases/evolution-phase"; +import { LearnMovePhase } from "#app/phases/learn-move-phase"; +import { PlayerPartyMemberPokemonPhase } from "#app/phases/player-party-member-pokemon-phase"; import { LevelAchv } from "#app/system/achv"; +import { NumberHolder } from "#app/utils"; import i18next from "i18next"; -import * as Utils from "#app/utils"; -import { PlayerPartyMemberPokemonPhase } from "./player-party-member-pokemon-phase"; -import { LearnMovePhase } from "./learn-move-phase"; export class LevelUpPhase extends PlayerPartyMemberPokemonPhase { - private lastLevel: integer; - private level: integer; + protected lastLevel: number; + protected level: number; + protected pokemon: PlayerPokemon = this.getPlayerPokemon(); - constructor(scene: BattleScene, partyMemberIndex: integer, lastLevel: integer, level: integer) { + constructor(scene: BattleScene, partyMemberIndex: number, lastLevel: number, level: number) { super(scene, partyMemberIndex); this.lastLevel = lastLevel; this.level = level; - this.scene = scene; } - start() { + public override start() { super.start(); if (this.level > this.scene.gameData.gameStats.highestLevel) { this.scene.gameData.gameStats.highestLevel = this.level; } - this.scene.validateAchvs(LevelAchv, new Utils.IntegerHolder(this.level)); + this.scene.validateAchvs(LevelAchv, new NumberHolder(this.level)); - const pokemon = this.getPokemon(); - const prevStats = pokemon.stats.slice(0); - pokemon.calculateStats(); - pokemon.updateInfo(); + const prevStats = this.pokemon.stats.slice(0); + this.pokemon.calculateStats(); + this.pokemon.updateInfo(); if (this.scene.expParty === ExpNotification.DEFAULT) { this.scene.playSound("level_up_fanfare"); - this.scene.ui.showText(i18next.t("battle:levelUp", { pokemonName: getPokemonNameWithAffix(this.getPokemon()), level: this.level }), null, () => this.scene.ui.getMessageHandler().promptLevelUpStats(this.partyMemberIndex, prevStats, false).then(() => this.end()), null, true); + this.scene.ui.showText( + i18next.t("battle:levelUp", { pokemonName: getPokemonNameWithAffix(this.pokemon), level: this.level }), + null, + () => this.scene.ui.getMessageHandler().promptLevelUpStats(this.partyMemberIndex, prevStats, false) + .then(() => this.end()), null, true); } else if (this.scene.expParty === ExpNotification.SKIP) { this.end(); } else { // we still want to display the stats if activated this.scene.ui.getMessageHandler().promptLevelUpStats(this.partyMemberIndex, prevStats, false).then(() => this.end()); } + } + + public override end() { if (this.lastLevel < 100) { // this feels like an unnecessary optimization const levelMoves = this.getPokemon().getLevelMoves(this.lastLevel + 1); for (const lm of levelMoves) { this.scene.unshiftPhase(new LearnMovePhase(this.scene, this.partyMemberIndex, lm[1])); } } - if (!pokemon.pauseEvolutions) { - const evolution = pokemon.getEvolution(); + if (!this.pokemon.pauseEvolutions) { + const evolution = this.pokemon.getEvolution(); if (evolution) { - this.scene.unshiftPhase(new EvolutionPhase(this.scene, pokemon as PlayerPokemon, evolution, this.lastLevel)); + this.scene.unshiftPhase(new EvolutionPhase(this.scene, this.pokemon, evolution, this.lastLevel)); } } + return super.end(); } } diff --git a/src/phases/login-phase.ts b/src/phases/login-phase.ts index 89ced201e9e..ac1e68d1b0e 100644 --- a/src/phases/login-phase.ts +++ b/src/phases/login-phase.ts @@ -22,7 +22,7 @@ export class LoginPhase extends Phase { const hasSession = !!Utils.getCookie(Utils.sessionIdKey); - this.scene.ui.setMode(Mode.LOADING, { buttonActions: [] }); + this.scene.ui.setMode(Mode.LOADING, { buttonActions: []}); Utils.executeIf(bypassLogin || hasSession, updateUserInfo).then(response => { const success = response ? response[0] : false; const statusCode = response ? response[1] : null; diff --git a/src/phases/message-phase.ts b/src/phases/message-phase.ts index 2244980c899..1d953801178 100644 --- a/src/phases/message-phase.ts +++ b/src/phases/message-phase.ts @@ -6,14 +6,16 @@ export class MessagePhase extends Phase { private callbackDelay: integer | null; private prompt: boolean | null; private promptDelay: integer | null; + private speaker?: string; - constructor(scene: BattleScene, text: string, callbackDelay?: integer | null, prompt?: boolean | null, promptDelay?: integer | null) { + constructor(scene: BattleScene, text: string, callbackDelay?: integer | null, prompt?: boolean | null, promptDelay?: integer | null, speaker?: string) { super(scene); this.text = text; this.callbackDelay = callbackDelay!; // TODO: is this bang correct? this.prompt = prompt!; // TODO: is this bang correct? this.promptDelay = promptDelay!; // TODO: is this bang correct? + this.speaker = speaker; } start() { @@ -21,11 +23,15 @@ export class MessagePhase extends Phase { if (this.text.indexOf("$") > -1) { const pageIndex = this.text.indexOf("$"); - this.scene.unshiftPhase(new MessagePhase(this.scene, this.text.slice(pageIndex + 1), this.callbackDelay, this.prompt, this.promptDelay)); + this.scene.unshiftPhase(new MessagePhase(this.scene, this.text.slice(pageIndex + 1), this.callbackDelay, this.prompt, this.promptDelay, this.speaker)); this.text = this.text.slice(0, pageIndex).trim(); } - this.scene.ui.showText(this.text, null, () => this.end(), this.callbackDelay || (this.prompt ? 0 : 1500), this.prompt, this.promptDelay); + if (this.speaker) { + this.scene.ui.showDialogue(this.text, this.speaker, null, () => this.end(), this.callbackDelay || (this.prompt ? 0 : 1500), this.promptDelay ?? 0); + } else { + this.scene.ui.showText(this.text, null, () => this.end(), this.callbackDelay || (this.prompt ? 0 : 1500), this.prompt, this.promptDelay); + } } end() { diff --git a/src/phases/move-anim-test-phase.ts b/src/phases/move-anim-test-phase.ts index a6ab90464b8..e4b04ce5de6 100644 --- a/src/phases/move-anim-test-phase.ts +++ b/src/phases/move-anim-test-phase.ts @@ -29,7 +29,7 @@ export class MoveAnimTestPhase extends BattlePhase { } initMoveAnim(this.scene, moveId).then(() => { - loadMoveAnimAssets(this.scene, [moveId], true) + loadMoveAnimAssets(this.scene, [ moveId ], true) .then(() => { const user = player ? this.scene.getPlayerPokemon()! : this.scene.getEnemyPokemon()!; const target = (player !== (allMoves[moveId] instanceof SelfStatusMove)) ? this.scene.getEnemyPokemon()! : this.scene.getPlayerPokemon()!; diff --git a/src/phases/move-charge-phase.ts b/src/phases/move-charge-phase.ts new file mode 100644 index 00000000000..d1dc340b81b --- /dev/null +++ b/src/phases/move-charge-phase.ts @@ -0,0 +1,84 @@ +import BattleScene from "#app/battle-scene"; +import { BattlerIndex } from "#app/battle"; +import { MoveChargeAnim } from "#app/data/battle-anims"; +import { applyMoveChargeAttrs, MoveEffectAttr, InstantChargeAttr } from "#app/data/move"; +import Pokemon, { MoveResult, PokemonMove } from "#app/field/pokemon"; +import { BooleanHolder } from "#app/utils"; +import { MovePhase } from "#app/phases/move-phase"; +import { PokemonPhase } from "#app/phases/pokemon-phase"; +import { BattlerTagType } from "#enums/battler-tag-type"; +import { MoveEndPhase } from "#app/phases/move-end-phase"; + +/** + * Phase for the "charging turn" of two-turn moves (e.g. Dig). + * @extends {@linkcode PokemonPhase} + */ +export class MoveChargePhase extends PokemonPhase { + /** The move instance that this phase applies */ + public move: PokemonMove; + /** The field index targeted by the move (Charging moves assume single target) */ + public targetIndex: BattlerIndex; + + constructor(scene: BattleScene, battlerIndex: BattlerIndex, targetIndex: BattlerIndex, move: PokemonMove) { + super(scene, battlerIndex); + this.move = move; + this.targetIndex = targetIndex; + } + + public override start() { + super.start(); + + const user = this.getUserPokemon(); + const target = this.getTargetPokemon(); + const move = this.move.getMove(); + + // If the target is somehow not defined, or the move is somehow not a ChargingMove, + // immediately end this phase. + if (!target || !(move.isChargingMove())) { + console.warn("Invalid parameters for MoveChargePhase"); + return super.end(); + } + + new MoveChargeAnim(move.chargeAnim, move.id, user).play(this.scene, false, () => { + move.showChargeText(user, target); + + applyMoveChargeAttrs(MoveEffectAttr, user, target, move).then(() => { + user.addTag(BattlerTagType.CHARGING, 1, move.id, user.id); + this.end(); + }); + }); + } + + /** Checks the move's instant charge conditions, then ends this phase. */ + public override end() { + const user = this.getUserPokemon(); + const move = this.move.getMove(); + + if (move.isChargingMove()) { + const instantCharge = new BooleanHolder(false); + + applyMoveChargeAttrs(InstantChargeAttr, user, null, move, instantCharge); + + if (instantCharge.value) { + // this MoveEndPhase will be duplicated by the queued MovePhase if not removed + this.scene.tryRemovePhase((phase) => phase instanceof MoveEndPhase && phase.getPokemon() === user); + // queue a new MovePhase for this move's attack phase + this.scene.unshiftPhase(new MovePhase(this.scene, user, [ this.targetIndex ], this.move, false)); + } else { + user.getMoveQueue().push({ move: move.id, targets: [ this.targetIndex ]}); + } + + // Add this move's charging phase to the user's move history + user.pushMoveHistory({ move: this.move.moveId, targets: [ this.targetIndex ], result: MoveResult.OTHER }); + } + super.end(); + } + + public getUserPokemon(): Pokemon { + return (this.player ? this.scene.getPlayerField() : this.scene.getEnemyField())[this.fieldIndex]; + } + + public getTargetPokemon(): Pokemon | undefined { + return this.scene.getField(true).find((p) => this.targetIndex === p.getBattlerIndex()); + } +} diff --git a/src/phases/move-effect-phase.ts b/src/phases/move-effect-phase.ts index e2fca951b2f..afc8dd0475d 100644 --- a/src/phases/move-effect-phase.ts +++ b/src/phases/move-effect-phase.ts @@ -1,19 +1,63 @@ -import BattleScene from "#app/battle-scene"; import { BattlerIndex } from "#app/battle"; -import { applyPreAttackAbAttrs, AddSecondStrikeAbAttr, IgnoreMoveEffectsAbAttr, applyPostDefendAbAttrs, PostDefendAbAttr, applyPostAttackAbAttrs, PostAttackAbAttr, MaxMultiHitAbAttr, AlwaysHitAbAttr } from "#app/data/ability"; +import BattleScene from "#app/battle-scene"; +import { + AddSecondStrikeAbAttr, + AlwaysHitAbAttr, + applyPostAttackAbAttrs, + applyPostDefendAbAttrs, + applyPreAttackAbAttrs, + IgnoreMoveEffectsAbAttr, + MaxMultiHitAbAttr, + PostAttackAbAttr, + PostDefendAbAttr, + TypeImmunityAbAttr, +} from "#app/data/ability"; import { ArenaTagSide, ConditionalProtectTag } from "#app/data/arena-tag"; import { MoveAnim } from "#app/data/battle-anims"; -import { BattlerTagLapseType, DamageProtectedTag, ProtectedTag, SemiInvulnerableTag, SubstituteTag } from "#app/data/battler-tags"; -import { MoveTarget, applyMoveAttrs, OverrideMoveEffectAttr, MultiHitAttr, AttackMove, FixedDamageAttr, VariableTargetAttr, MissEffectAttr, MoveFlags, applyFilteredMoveAttrs, MoveAttr, MoveEffectAttr, MoveEffectTrigger, ChargeAttr, MoveCategory, NoEffectAttr, DealsDoubleDamageToTagAttr } from "#app/data/move"; +import { + BattlerTagLapseType, + DamageProtectedTag, + ProtectedTag, + SemiInvulnerableTag, + SubstituteTag, +} from "#app/data/battler-tags"; +import { + applyFilteredMoveAttrs, + applyMoveAttrs, + AttackMove, + DelayedAttackAttr, + FlinchAttr, + HitsTagAttr, + MissEffectAttr, + MoveAttr, + MoveCategory, + MoveEffectAttr, + MoveEffectTrigger, + MoveFlags, + MoveTarget, + MultiHitAttr, + NoEffectAttr, + OneHitKOAttr, + OverrideMoveEffectAttr, + ToxicAccuracyAttr, + VariableTargetAttr, +} from "#app/data/move"; import { SpeciesFormChangePostMoveTrigger } from "#app/data/pokemon-forms"; -import { BattlerTagType } from "#app/enums/battler-tag-type"; -import { Moves } from "#app/enums/moves"; -import Pokemon, { PokemonMove, MoveResult, HitResult } from "#app/field/pokemon"; +import { Type } from "#enums/type"; +import Pokemon, { HitResult, MoveResult, PokemonMove } from "#app/field/pokemon"; import { getPokemonNameWithAffix } from "#app/messages"; -import { PokemonMultiHitModifier, FlinchChanceModifier, EnemyAttackStatusEffectChanceModifier, ContactHeldItemTransferChanceModifier, HitHealModifier } from "#app/modifier/modifier"; +import { + ContactHeldItemTransferChanceModifier, + EnemyAttackStatusEffectChanceModifier, + FlinchChanceModifier, + HitHealModifier, + PokemonMultiHitModifier, +} from "#app/modifier/modifier"; +import { PokemonPhase } from "#app/phases/pokemon-phase"; +import { BooleanHolder, executeIf, NumberHolder } from "#app/utils"; +import { BattlerTagType } from "#enums/battler-tag-type"; +import { Moves } from "#enums/moves"; import i18next from "i18next"; -import * as Utils from "#app/utils"; -import { PokemonPhase } from "./pokemon-phase"; export class MoveEffectPhase extends PokemonPhase { public move: PokemonMove; @@ -23,10 +67,10 @@ export class MoveEffectPhase extends PokemonPhase { super(scene, battlerIndex); this.move = move; /** - * In double battles, if the right Pokemon selects a spread move and the left Pokemon dies - * with no party members available to switch in, then the right Pokemon takes the index - * of the left Pokemon and gets hit unless this is checked. - */ + * In double battles, if the right Pokemon selects a spread move and the left Pokemon dies + * with no party members available to switch in, then the right Pokemon takes the index + * of the left Pokemon and gets hit unless this is checked. + */ if (targets.includes(battlerIndex) && this.move.getMove().moveTarget === MoveTarget.ALL_NEAR_OTHERS) { const i = targets.indexOf(battlerIndex); targets.splice(i, i + 1); @@ -34,7 +78,7 @@ export class MoveEffectPhase extends PokemonPhase { this.targets = targets; } - start() { + public override start(): void { super.start(); /** The Pokemon using this phase's invoked move */ @@ -42,21 +86,26 @@ export class MoveEffectPhase extends PokemonPhase { /** All Pokemon targeted by this phase's invoked move */ const targets = this.getTargets(); - /** If the user was somehow removed from the field, end this phase */ - if (!user?.isOnField()) { + if (!user) { + return super.end(); + } + + const isDelayedAttack = this.move.getMove().hasAttr(DelayedAttackAttr); + /** If the user was somehow removed from the field and it's not a delayed attack, end this phase */ + if (!user.isOnField() && !isDelayedAttack) { return super.end(); } /** - * Does an effect from this move override other effects on this turn? - * e.g. Charging moves (Fly, etc.) on their first turn of use. - */ - const overridden = new Utils.BooleanHolder(false); + * Does an effect from this move override other effects on this turn? + * e.g. Charging moves (Fly, etc.) on their first turn of use. + */ + const overridden = new BooleanHolder(false); /** The {@linkcode Move} object from {@linkcode allMoves} invoked by this phase */ const move = this.move.getMove(); // Assume single target for override - applyMoveAttrs(OverrideMoveEffectAttr, user, this.getTarget() ?? null, move, overridden, this.move.virtual).then(() => { + applyMoveAttrs(OverrideMoveEffectAttr, user, this.getFirstTarget() ?? null, move, overridden, this.move.virtual).then(() => { // If other effects were overriden, stop this phase before they can be applied if (overridden.value) { return this.end(); @@ -65,49 +114,53 @@ export class MoveEffectPhase extends PokemonPhase { user.lapseTags(BattlerTagLapseType.MOVE_EFFECT); /** - * If this phase is for the first hit of the invoked move, - * resolve the move's total hit count. This block combines the - * effects of the move itself, Parental Bond, and Multi-Lens to do so. - */ - if (user.turnData.hitsLeft === undefined) { - const hitCount = new Utils.IntegerHolder(1); + * If this phase is for the first hit of the invoked move, + * resolve the move's total hit count. This block combines the + * effects of the move itself, Parental Bond, and Multi-Lens to do so. + */ + if (user.turnData.hitsLeft === -1) { + const hitCount = new NumberHolder(1); // Assume single target for multi hit - applyMoveAttrs(MultiHitAttr, user, this.getTarget() ?? null, move, hitCount); - // If Parental Bond is applicable, double the hit count - applyPreAttackAbAttrs(AddSecondStrikeAbAttr, user, null, move, false, targets.length, hitCount, new Utils.IntegerHolder(0)); - // If Multi-Lens is applicable, multiply the hit count by 1 + the number of Multi-Lenses held by the user - if (move instanceof AttackMove && !move.hasAttr(FixedDamageAttr)) { - this.scene.applyModifiers(PokemonMultiHitModifier, user.isPlayer(), user, hitCount, new Utils.IntegerHolder(0)); - } + applyMoveAttrs(MultiHitAttr, user, this.getFirstTarget() ?? null, move, hitCount); + // If Parental Bond is applicable, add another hit + applyPreAttackAbAttrs(AddSecondStrikeAbAttr, user, null, move, false, hitCount, null); + // If Multi-Lens is applicable, add hits equal to the number of held Multi-Lenses + this.scene.applyModifiers(PokemonMultiHitModifier, user.isPlayer(), user, move.id, hitCount); // Set the user's relevant turnData fields to reflect the final hit count user.turnData.hitCount = hitCount.value; user.turnData.hitsLeft = hitCount.value; } /** - * Log to be entered into the user's move history once the move result is resolved. - * Note that `result` (a {@linkcode MoveResult}) logs whether the move was successfully - * used in the sense of "Does it have an effect on the user?". - */ + * Log to be entered into the user's move history once the move result is resolved. + * Note that `result` (a {@linkcode MoveResult}) logs whether the move was successfully + * used in the sense of "Does it have an effect on the user?". + */ const moveHistoryEntry = { move: this.move.moveId, targets: this.targets, result: MoveResult.PENDING, virtual: this.move.virtual }; /** - * Stores results of hit checks of the invoked move against all targets, organized by battler index. - * @see {@linkcode hitCheck} - */ - const targetHitChecks = Object.fromEntries(targets.map(p => [p.getBattlerIndex(), this.hitCheck(p)])); + * Stores results of hit checks of the invoked move against all targets, organized by battler index. + * @see {@linkcode hitCheck} + */ + const targetHitChecks = Object.fromEntries(targets.map(p => [ p.getBattlerIndex(), this.hitCheck(p) ])); const hasActiveTargets = targets.some(t => t.isActive(true)); + + /** Check if the target is immune via ability to the attacking move, and NOT in semi invulnerable state */ + const isImmune = targets[0]?.hasAbilityWithAttr(TypeImmunityAbAttr) + && (targets[0]?.getAbility()?.getAttrs(TypeImmunityAbAttr)?.[0]?.getImmuneType() === user.getMoveType(move)) + && !targets[0]?.getTag(SemiInvulnerableTag); + /** - * If no targets are left for the move to hit (FAIL), or the invoked move is single-target - * (and not random target) and failed the hit check against its target (MISS), log the move - * as FAILed or MISSed (depending on the conditions above) and end this phase. - */ - if (!hasActiveTargets || (!move.hasAttr(VariableTargetAttr) && !move.isMultiTarget() && !targetHitChecks[this.targets[0]] && !targets[0].getTag(ProtectedTag))) { + * If no targets are left for the move to hit (FAIL), or the invoked move is single-target + * (and not random target) and failed the hit check against its target (MISS), log the move + * as FAILed or MISSed (depending on the conditions above) and end this phase. + */ + if (!hasActiveTargets || (!move.hasAttr(VariableTargetAttr) && !move.isMultiTarget() && !targetHitChecks[this.targets[0]] && !targets[0].getTag(ProtectedTag) && !isImmune)) { this.stopMultiHit(); if (hasActiveTargets) { - this.scene.queueMessage(i18next.t("battle:attackMissed", { pokemonNameWithAffix: this.getTarget()? getPokemonNameWithAffix(this.getTarget()!) : "" })); + this.scene.queueMessage(i18next.t("battle:attackMissed", { pokemonNameWithAffix: this.getFirstTarget() ? getPokemonNameWithAffix(this.getFirstTarget()!) : "" })); moveHistoryEntry.result = MoveResult.MISS; - applyMoveAttrs(MissEffectAttr, user, null, move); + applyMoveAttrs(MissEffectAttr, user, null, this.move.getMove()); } else { this.scene.queueMessage(i18next.t("battle:attackFailed")); moveHistoryEntry.result = MoveResult.FAIL; @@ -121,32 +174,49 @@ export class MoveEffectPhase extends PokemonPhase { const playOnEmptyField = this.scene.currentBattle?.mysteryEncounter?.hasBattleAnimationsWithoutTargets ?? false; // Move animation only needs one target - new MoveAnim(move.id as Moves, user, this.getTarget()!.getBattlerIndex()!, playOnEmptyField).play(this.scene, move.hitsSubstitute(user, this.getTarget()!), () => { + new MoveAnim(move.id as Moves, user, this.getFirstTarget()!.getBattlerIndex()!, playOnEmptyField).play(this.scene, move.hitsSubstitute(user, this.getFirstTarget()!), () => { /** Has the move successfully hit a target (for damage) yet? */ let hasHit: boolean = false; for (const target of targets) { + // Prevent ENEMY_SIDE targeted moves from occurring twice in double battles + if (move.moveTarget === MoveTarget.ENEMY_SIDE && target !== targets[targets.length - 1]) { + continue; + } /** The {@linkcode ArenaTagSide} to which the target belongs */ const targetSide = target.isPlayer() ? ArenaTagSide.PLAYER : ArenaTagSide.ENEMY; /** Has the invoked move been cancelled by conditional protection (e.g Quick Guard)? */ - const hasConditionalProtectApplied = new Utils.BooleanHolder(false); + const hasConditionalProtectApplied = new BooleanHolder(false); /** Does the applied conditional protection bypass Protect-ignoring effects? */ - const bypassIgnoreProtect = new Utils.BooleanHolder(false); - // If the move is not targeting a Pokemon on the user's side, try to apply conditional protection effects + const bypassIgnoreProtect = new BooleanHolder(false); + /** If the move is not targeting a Pokemon on the user's side, try to apply conditional protection effects */ if (!this.move.getMove().isAllyTarget()) { - this.scene.arena.applyTagsForSide(ConditionalProtectTag, targetSide, hasConditionalProtectApplied, user, target, move.id, bypassIgnoreProtect); + this.scene.arena.applyTagsForSide(ConditionalProtectTag, targetSide, false, hasConditionalProtectApplied, user, target, move.id, bypassIgnoreProtect); } /** Is the target protected by Protect, etc. or a relevant conditional protection effect? */ - const isProtected = (bypassIgnoreProtect.value || !this.move.getMove().checkFlag(MoveFlags.IGNORE_PROTECT, user, target)) - && (hasConditionalProtectApplied.value || (!target.findTags(t => t instanceof DamageProtectedTag).length && target.findTags(t => t instanceof ProtectedTag).find(t => target.lapseTag(t.tagType))) - || (this.move.getMove().category !== MoveCategory.STATUS && target.findTags(t => t instanceof DamageProtectedTag).find(t => target.lapseTag(t.tagType)))); + const isProtected = ( + bypassIgnoreProtect.value + || !this.move.getMove().checkFlag(MoveFlags.IGNORE_PROTECT, user, target)) + && (hasConditionalProtectApplied.value + || (!target.findTags(t => t instanceof DamageProtectedTag).length + && target.findTags(t => t instanceof ProtectedTag).find(t => target.lapseTag(t.tagType))) + || (this.move.getMove().category !== MoveCategory.STATUS + && target.findTags(t => t instanceof DamageProtectedTag).find(t => target.lapseTag(t.tagType)))); + + /** Is the pokemon immune due to an ablility, and also not in a semi invulnerable state? */ + const isImmune = target.hasAbilityWithAttr(TypeImmunityAbAttr) + && (target.getAbility()?.getAttrs(TypeImmunityAbAttr)?.[0]?.getImmuneType() === user.getMoveType(move)) + && !target.getTag(SemiInvulnerableTag); + + /** Is the target hidden by the effects of its Commander ability? */ + const isCommanding = this.scene.currentBattle.double && target.getAlly()?.getTag(BattlerTagType.COMMANDED)?.getSourcePokemon(this.scene) === target; /** - * If the move missed a target, stop all future hits against that target - * and move on to the next target (if there is one). - */ - if (!isProtected && !targetHitChecks[target.getBattlerIndex()]) { + * If the move missed a target, stop all future hits against that target + * and move on to the next target (if there is one). + */ + if (isCommanding || (!isImmune && !isProtected && !targetHitChecks[target.getBattlerIndex()])) { this.stopMultiHit(target); this.scene.queueMessage(i18next.t("battle:attackMissed", { pokemonNameWithAffix: getPokemonNameWithAffix(target) })); if (moveHistoryEntry.result === MoveResult.PENDING) { @@ -166,23 +236,23 @@ export class MoveEffectPhase extends PokemonPhase { } /** - * Since all fail/miss checks have applied, the move is considered successfully applied. - * It's worth noting that if the move has no effect or is protected against, this assignment - * is overwritten and the move is logged as a FAIL. - */ + * Since all fail/miss checks have applied, the move is considered successfully applied. + * It's worth noting that if the move has no effect or is protected against, this assignment + * is overwritten and the move is logged as a FAIL. + */ moveHistoryEntry.result = MoveResult.SUCCESS; /** - * Stores the result of applying the invoked move to the target. - * If the target is protected, the result is always `NO_EFFECT`. - * Otherwise, the hit result is based on type effectiveness, immunities, - * and other factors that may negate the attack or status application. - * - * Internally, the call to {@linkcode Pokemon.apply} is where damage is calculated - * (for attack moves) and the target's HP is updated. However, this isn't - * made visible to the user until the resulting {@linkcode DamagePhase} - * is invoked. - */ + * Stores the result of applying the invoked move to the target. + * If the target is protected, the result is always `NO_EFFECT`. + * Otherwise, the hit result is based on type effectiveness, immunities, + * and other factors that may negate the attack or status application. + * + * Internally, the call to {@linkcode Pokemon.apply} is where damage is calculated + * (for attack moves) and the target's HP is updated. However, this isn't + * made visible to the user until the resulting {@linkcode DamagePhase} + * is invoked. + */ const hitResult = !isProtected ? target.apply(user, move) : HitResult.NO_EFFECT; /** Does {@linkcode hitResult} indicate that damage was dealt to the target? */ @@ -200,113 +270,72 @@ export class MoveEffectPhase extends PokemonPhase { } /** - * If the move has no effect on the target (i.e. the target is protected or immune), - * change the logged move result to FAIL. - */ + * If the move has no effect on the target (i.e. the target is protected or immune), + * change the logged move result to FAIL. + */ if (hitResult === HitResult.NO_EFFECT) { moveHistoryEntry.result = MoveResult.FAIL; } /** Does this phase represent the invoked move's last strike? */ - const lastHit = (user.turnData.hitsLeft === 1 || !this.getTarget()?.isActive()); + const lastHit = (user.turnData.hitsLeft === 1 || !this.getFirstTarget()?.isActive()); /** - * If the user can change forms by using the invoked move, - * it only changes forms after the move's last hit - * (see Relic Song's interaction with Parental Bond when used by Meloetta). - */ + * If the user can change forms by using the invoked move, + * it only changes forms after the move's last hit + * (see Relic Song's interaction with Parental Bond when used by Meloetta). + */ if (lastHit) { this.scene.triggerPokemonFormChange(user, SpeciesFormChangePostMoveTrigger); } /** - * Create a Promise that applys *all* effects from the invoked move's MoveEffectAttrs. - * These are ordered by trigger type (see {@linkcode MoveEffectTrigger}), and each trigger - * type requires different conditions to be met with respect to the move's hit result. - */ - applyAttrs.push(new Promise(resolve => { - // Apply all effects with PRE_MOVE triggers (if the target isn't immune to the move) - applyFilteredMoveAttrs((attr: MoveAttr) => attr instanceof MoveEffectAttr && attr.trigger === MoveEffectTrigger.PRE_APPLY && (!attr.firstHitOnly || firstHit) && (!attr.lastHitOnly || lastHit) && hitResult !== HitResult.NO_EFFECT, - user, target, move).then(() => { - // All other effects require the move to not have failed or have been cancelled to trigger - if (hitResult !== HitResult.FAIL) { - /** Are the move's effects tied to the first turn of a charge move? */ - const chargeEffect = !!move.getAttrs(ChargeAttr).find(ca => ca.usedChargeEffect(user, this.getTarget() ?? null, move)); - /** - * If the invoked move's effects are meant to trigger during the move's "charge turn," - * ignore all effects after this point. - * Otherwise, apply all self-targeted POST_APPLY effects. - */ - Utils.executeIf(!chargeEffect, () => applyFilteredMoveAttrs((attr: MoveAttr) => attr instanceof MoveEffectAttr && attr.trigger === MoveEffectTrigger.POST_APPLY - && attr.selfTarget && (!attr.firstHitOnly || firstHit) && (!attr.lastHitOnly || lastHit), user, target, move)).then(() => { - // All effects past this point require the move to have hit the target - if (hitResult !== HitResult.NO_EFFECT) { - // Apply all non-self-targeted POST_APPLY effects - applyFilteredMoveAttrs((attr: MoveAttr) => attr instanceof MoveEffectAttr && (attr as MoveEffectAttr).trigger === MoveEffectTrigger.POST_APPLY - && !(attr as MoveEffectAttr).selfTarget && (!attr.firstHitOnly || firstHit) && (!attr.lastHitOnly || lastHit), user, target, this.move.getMove()).then(() => { - /** - * If the move hit, and the target doesn't have Shield Dust, - * apply the chance to flinch the target gained from King's Rock - */ - if (dealsDamage && !target.hasAbilityWithAttr(IgnoreMoveEffectsAbAttr) && !move.hitsSubstitute(user, target)) { - const flinched = new Utils.BooleanHolder(false); - user.scene.applyModifiers(FlinchChanceModifier, user.isPlayer(), user, flinched); - if (flinched.value) { - target.addTag(BattlerTagType.FLINCHED, undefined, this.move.moveId, user.id); - } - } - // If the move was not protected against, apply all HIT effects - Utils.executeIf(!isProtected && !chargeEffect, () => applyFilteredMoveAttrs((attr: MoveAttr) => attr instanceof MoveEffectAttr && (attr as MoveEffectAttr).trigger === MoveEffectTrigger.HIT - && (!attr.firstHitOnly || firstHit) && (!attr.lastHitOnly || lastHit) && (!attr.firstTargetOnly || firstTarget), user, target, this.move.getMove()).then(() => { - // Apply the target's post-defend ability effects (as long as the target is active or can otherwise apply them) - return Utils.executeIf(!target.isFainted() || target.canApplyAbility(), () => applyPostDefendAbAttrs(PostDefendAbAttr, target, user, this.move.getMove(), hitResult).then(() => { - // Only apply the following effects if the move was not deflected by a substitute - if (move.hitsSubstitute(user, target)) { - return resolve(); - } + * Create a Promise that applys *all* effects from the invoked move's MoveEffectAttrs. + * These are ordered by trigger type (see {@linkcode MoveEffectTrigger}), and each trigger + * type requires different conditions to be met with respect to the move's hit result. + */ + const k = new Promise((resolve) => { + //Start promise chain and apply PRE_APPLY move attributes + let promiseChain: Promise = applyFilteredMoveAttrs((attr: MoveAttr) => + attr instanceof MoveEffectAttr + && attr.trigger === MoveEffectTrigger.PRE_APPLY + && (!attr.firstHitOnly || firstHit) + && (!attr.lastHitOnly || lastHit) + && hitResult !== HitResult.NO_EFFECT, user, target, move); - // If the invoked move is an enemy attack, apply the enemy's status effect-inflicting tokens - if (!user.isPlayer() && this.move.getMove() instanceof AttackMove) { - user.scene.applyShuffledModifiers(this.scene, EnemyAttackStatusEffectChanceModifier, false, target); - } - target.lapseTag(BattlerTagType.BEAK_BLAST_CHARGING); - if (move.category === MoveCategory.PHYSICAL && user.isPlayer() !== target.isPlayer()) { - target.lapseTag(BattlerTagType.SHELL_TRAP); - } - })).then(() => { - // Apply the user's post-attack ability effects - applyPostAttackAbAttrs(PostAttackAbAttr, user, target, this.move.getMove(), hitResult).then(() => { - /** - * If the invoked move is an attack, apply the user's chance to - * steal an item from the target granted by Grip Claw - */ - if (this.move.getMove() instanceof AttackMove) { - this.scene.applyModifiers(ContactHeldItemTransferChanceModifier, this.player, user, target); - } - resolve(); - }); - }); - }) - ).then(() => resolve()); - }); - } else { - applyMoveAttrs(NoEffectAttr, user, null, move).then(() => resolve()); - } - }); - } else { - resolve(); - } - }); - })); + /** Don't complete if the move failed */ + if (hitResult === HitResult.FAIL) { + return resolve(); + } + + /** Apply Move/Ability Effects in correct order */ + promiseChain = promiseChain + .then(this.applySelfTargetEffects(user, target, firstHit, lastHit)); + + if (hitResult !== HitResult.NO_EFFECT) { + promiseChain + .then(this.applyPostApplyEffects(user, target, firstHit, lastHit)) + .then(this.applyHeldItemFlinchCheck(user, target, dealsDamage)) + .then(this.applySuccessfulAttackEffects(user, target, firstHit, lastHit, !!isProtected, hitResult, firstTarget)) + .then(() => resolve()); + } else { + promiseChain + .then(() => applyMoveAttrs(NoEffectAttr, user, null, move)) + .then(resolve); + } + }); + + applyAttrs.push(k); } + // Apply the move's POST_TARGET effects on the move's last hit, after all targeted effects have resolved - const postTarget = (user.turnData.hitsLeft === 1 || !this.getTarget()?.isActive()) ? + const postTarget = (user.turnData.hitsLeft === 1 || !this.getFirstTarget()?.isActive()) ? applyFilteredMoveAttrs((attr: MoveAttr) => attr instanceof MoveEffectAttr && attr.trigger === MoveEffectTrigger.POST_TARGET, user, null, move) : null; - if (!!postTarget) { + if (postTarget) { if (applyAttrs.length) { // If there is a pending asynchronous move effect, do this after - applyAttrs[applyAttrs.length - 1]?.then(() => postTarget); + applyAttrs[applyAttrs.length - 1].then(() => postTarget); } else { // Otherwise, push a new asynchronous move effect applyAttrs.push(postTarget); } @@ -321,7 +350,7 @@ export class MoveEffectPhase extends PokemonPhase { */ targets.forEach(target => { const substitute = target.getTag(SubstituteTag); - if (!!substitute && substitute.hp <= 0) { + if (substitute && substitute.hp <= 0) { target.lapseTag(BattlerTagType.SUBSTITUTE); } }); @@ -331,27 +360,29 @@ export class MoveEffectPhase extends PokemonPhase { }); } - end() { + public override end(): void { const user = this.getUserPokemon(); /** - * If this phase isn't for the invoked move's last strike, - * unshift another MoveEffectPhase for the next strike. - * Otherwise, queue a message indicating the number of times the move has struck - * (if the move has struck more than once), then apply the heal from Shell Bell - * to the user. - */ + * If this phase isn't for the invoked move's last strike, + * unshift another MoveEffectPhase for the next strike. + * Otherwise, queue a message indicating the number of times the move has struck + * (if the move has struck more than once), then apply the heal from Shell Bell + * to the user. + */ if (user) { - if (user.turnData.hitsLeft && --user.turnData.hitsLeft >= 1 && this.getTarget()?.isActive()) { + if (user.turnData.hitsLeft && --user.turnData.hitsLeft >= 1 && this.getFirstTarget()?.isActive()) { this.scene.unshiftPhase(this.getNewHitPhase()); } else { // Queue message for number of hits made by multi-move // If multi-hit attack only hits once, still want to render a message - const hitsTotal = user.turnData.hitCount! - Math.max(user.turnData.hitsLeft!, 0); // TODO: are those bangs correct? + const hitsTotal = user.turnData.hitCount - Math.max(user.turnData.hitsLeft, 0); if (hitsTotal > 1 || (user.turnData.hitsLeft && user.turnData.hitsLeft > 0)) { // If there are multiple hits, or if there are hits of the multi-hit move left this.scene.queueMessage(i18next.t("battle:attackHitsCount", { count: hitsTotal })); } this.scene.applyModifiers(HitHealModifier, this.player, user); + // Clear all cached move effectiveness values among targets + this.getTargets().forEach((target) => target.turnData.moveEffectiveness = null); } } @@ -359,17 +390,149 @@ export class MoveEffectPhase extends PokemonPhase { } /** - * Resolves whether this phase's invoked move hits or misses the given target - * @param target {@linkcode Pokemon} the Pokemon targeted by the invoked move - * @returns `true` if the move does not miss the target; `false` otherwise - */ - hitCheck(target: Pokemon): boolean { + * Apply self-targeted effects that trigger `POST_APPLY` + * + * @param user - The {@linkcode Pokemon} using this phase's invoked move + * @param target - {@linkcode Pokemon} the current target of this phase's invoked move + * @param firstHit - `true` if this is the first hit in a multi-hit attack + * @param lastHit - `true` if this is the last hit in a multi-hit attack + * @returns a function intended to be passed into a `then()` call. + */ + protected applySelfTargetEffects(user: Pokemon, target: Pokemon, firstHit: boolean, lastHit: boolean): () => Promise { + return () => applyFilteredMoveAttrs((attr: MoveAttr) => + attr instanceof MoveEffectAttr + && attr.trigger === MoveEffectTrigger.POST_APPLY + && attr.selfTarget + && (!attr.firstHitOnly || firstHit) + && (!attr.lastHitOnly || lastHit), user, target, this.move.getMove()); + } + + /** + * Applies non-self-targeted effects that trigger `POST_APPLY` + * (i.e. Smelling Salts curing Paralysis, and the forced switch from U-Turn, Dragon Tail, etc) + * @param user - The {@linkcode Pokemon} using this phase's invoked move + * @param target - {@linkcode Pokemon} the current target of this phase's invoked move + * @param firstHit - `true` if this is the first hit in a multi-hit attack + * @param lastHit - `true` if this is the last hit in a multi-hit attack + * @returns a function intended to be passed into a `then()` call. + */ + protected applyPostApplyEffects(user: Pokemon, target: Pokemon, firstHit: boolean, lastHit: boolean): () => Promise { + return () => applyFilteredMoveAttrs((attr: MoveAttr) => + attr instanceof MoveEffectAttr + && attr.trigger === MoveEffectTrigger.POST_APPLY + && !attr.selfTarget + && (!attr.firstHitOnly || firstHit) + && (!attr.lastHitOnly || lastHit), user, target, this.move.getMove()); + } + + /** + * Applies effects that trigger on HIT + * (i.e. Final Gambit, Power-Up Punch, Drain Punch) + * @param user - The {@linkcode Pokemon} using this phase's invoked move + * @param target - {@linkcode Pokemon} the current target of this phase's invoked move + * @param firstHit - `true` if this is the first hit in a multi-hit attack + * @param lastHit - `true` if this is the last hit in a multi-hit attack + * @param firstTarget - `true` if {@linkcode target} is the first target hit by this strike of {@linkcode move} + * @returns a function intended to be passed into a `then()` call. + */ + protected applyOnHitEffects(user: Pokemon, target: Pokemon, firstHit : boolean, lastHit: boolean, firstTarget: boolean): Promise { + return applyFilteredMoveAttrs((attr: MoveAttr) => + attr instanceof MoveEffectAttr + && attr.trigger === MoveEffectTrigger.HIT + && (!attr.firstHitOnly || firstHit) + && (!attr.lastHitOnly || lastHit) + && (!attr.firstTargetOnly || firstTarget), user, target, this.move.getMove()); + } + + /** + * Applies reactive effects that occur when a Pokémon is hit. + * (i.e. Effect Spore, Disguise, Liquid Ooze, Beak Blast) + * @param user - The {@linkcode Pokemon} using this phase's invoked move + * @param target - {@linkcode Pokemon} the current target of this phase's invoked move + * @param hitResult - The {@linkcode HitResult} of the attempted move + * @returns a `Promise` intended to be passed into a `then()` call. + */ + protected applyOnGetHitAbEffects(user: Pokemon, target: Pokemon, hitResult: HitResult): Promise { + return executeIf(!target.isFainted() || target.canApplyAbility(), () => + applyPostDefendAbAttrs(PostDefendAbAttr, target, user, this.move.getMove(), hitResult) + .then(() => { + + if (!this.move.getMove().hitsSubstitute(user, target)) { + if (!user.isPlayer() && this.move.getMove() instanceof AttackMove) { + user.scene.applyShuffledModifiers(this.scene, EnemyAttackStatusEffectChanceModifier, false, target); + } + + target.lapseTags(BattlerTagLapseType.AFTER_HIT); + } + + }) + ); + } + + /** + * Applies all effects and attributes that require a move to connect with a target, + * namely reactive effects like Weak Armor, on-hit effects like that of Power-Up Punch, and item stealing effects + * @param user - The {@linkcode Pokemon} using this phase's invoked move + * @param target - {@linkcode Pokemon} the current target of this phase's invoked move + * @param firstHit - `true` if this is the first hit in a multi-hit attack + * @param lastHit - `true` if this is the last hit in a multi-hit attack + * @param isProtected - `true` if the target is protected by effects such as Protect + * @param hitResult - The {@linkcode HitResult} of the attempted move + * @param firstTarget - `true` if {@linkcode target} is the first target hit by this strike of {@linkcode move} + * @returns a function intended to be passed into a `then()` call. + */ + protected applySuccessfulAttackEffects(user: Pokemon, target: Pokemon, firstHit : boolean, lastHit: boolean, isProtected : boolean, hitResult: HitResult, firstTarget: boolean) : () => Promise { + return () => executeIf(!isProtected, () => + this.applyOnHitEffects(user, target, firstHit, lastHit, firstTarget).then(() => + this.applyOnGetHitAbEffects(user, target, hitResult)).then(() => + applyPostAttackAbAttrs(PostAttackAbAttr, user, target, this.move.getMove(), hitResult)).then(() => { // Item Stealing Effects + + if (this.move.getMove() instanceof AttackMove) { + this.scene.applyModifiers(ContactHeldItemTransferChanceModifier, this.player, user, target); + } + }) + ); + } + + /** + * Handles checking for and applying Flinches + * @param user - The {@linkcode Pokemon} using this phase's invoked move + * @param target - {@linkcode Pokemon} the current target of this phase's invoked move + * @param dealsDamage - `true` if the attempted move successfully dealt damage + * @returns a function intended to be passed into a `then()` call. + */ + protected applyHeldItemFlinchCheck(user: Pokemon, target: Pokemon, dealsDamage: boolean) : () => void { + return () => { + if (this.move.getMove().hasAttr(FlinchAttr)) { + return; + } + + if (dealsDamage && !target.hasAbilityWithAttr(IgnoreMoveEffectsAbAttr) && !this.move.getMove().hitsSubstitute(user, target)) { + const flinched = new BooleanHolder(false); + user.scene.applyModifiers(FlinchChanceModifier, user.isPlayer(), user, flinched); + if (flinched.value) { + target.addTag(BattlerTagType.FLINCHED, undefined, this.move.moveId, user.id); + } + } + }; + } + + /** + * Resolves whether this phase's invoked move hits the given target + * @param target - The {@linkcode Pokemon} targeted by the invoked move + * @returns `true` if the move hits the target + */ + public hitCheck(target: Pokemon): boolean { // Moves targeting the user and entry hazards can't miss - if ([MoveTarget.USER, MoveTarget.ENEMY_SIDE].includes(this.move.getMove().moveTarget)) { + if ([ MoveTarget.USER, MoveTarget.ENEMY_SIDE ].includes(this.move.getMove().moveTarget)) { return true; } - const user = this.getUserPokemon()!; // TODO: is this bang correct? + const user = this.getUserPokemon(); + + if (!user) { + return false; + } // Hit check only calculated on first hit for multi-hit moves unless flag is set to check all hits. // However, if an ability with the MaxMultiHitAbAttr, namely Skill Link, is present, act as a normal @@ -393,8 +556,15 @@ export class MoveEffectPhase extends PokemonPhase { return true; } + if (target.getTag(BattlerTagType.TELEKINESIS) && !target.getTag(SemiInvulnerableTag) && !this.move.getMove().hasAttr(OneHitKOAttr)) { + return true; + } + const semiInvulnerableTag = target.getTag(SemiInvulnerableTag); - if (semiInvulnerableTag && !this.move.getMove().getAttrs(DealsDoubleDamageToTagAttr).some(hta => hta.tagType === semiInvulnerableTag.tagType)) { + if (semiInvulnerableTag + && !this.move.getMove().getAttrs(HitsTagAttr).some(hta => hta.tagType === semiInvulnerableTag.tagType) + && !(this.move.getMove().hasAttr(ToxicAccuracyAttr) && user.isOfType(Type.POISON)) + ) { return false; } @@ -410,29 +580,29 @@ export class MoveEffectPhase extends PokemonPhase { return rand < (moveAccuracy * accuracyMultiplier); } - /** Returns the {@linkcode Pokemon} using this phase's invoked move */ - getUserPokemon(): Pokemon | undefined { + /** @returns The {@linkcode Pokemon} using this phase's invoked move */ + public getUserPokemon(): Pokemon | null { if (this.battlerIndex > BattlerIndex.ENEMY_2) { - return this.scene.getPokemonById(this.battlerIndex) ?? undefined; + return this.scene.getPokemonById(this.battlerIndex); } return (this.player ? this.scene.getPlayerField() : this.scene.getEnemyField())[this.fieldIndex]; } - /** Returns an array of all {@linkcode Pokemon} targeted by this phase's invoked move */ - getTargets(): Pokemon[] { + /** @returns An array of all {@linkcode Pokemon} targeted by this phase's invoked move */ + public getTargets(): Pokemon[] { return this.scene.getField(true).filter(p => this.targets.indexOf(p.getBattlerIndex()) > -1); } - /** Returns the first target of this phase's invoked move */ - getTarget(): Pokemon | undefined { + /** @returns The first target of this phase's invoked move */ + public getFirstTarget(): Pokemon | undefined { return this.getTargets()[0]; } /** - * Removes the given {@linkcode Pokemon} from this phase's target list - * @param target {@linkcode Pokemon} the Pokemon to be removed - */ - removeTarget(target: Pokemon): void { + * Removes the given {@linkcode Pokemon} from this phase's target list + * @param target - The {@linkcode Pokemon} to be removed + */ + protected removeTarget(target: Pokemon): void { const targetIndex = this.targets.findIndex(ind => ind === target.getBattlerIndex()); if (targetIndex !== -1) { this.targets.splice(this.targets.findIndex(ind => ind === target.getBattlerIndex()), 1); @@ -440,27 +610,28 @@ export class MoveEffectPhase extends PokemonPhase { } /** - * Prevents subsequent strikes of this phase's invoked move from occurring - * @param target {@linkcode Pokemon} if defined, only stop subsequent - * strikes against this Pokemon - */ - stopMultiHit(target?: Pokemon): void { - /** If given a specific target, remove the target from subsequent strikes */ + * Prevents subsequent strikes of this phase's invoked move from occurring + * @param target - If defined, only stop subsequent strikes against this {@linkcode Pokemon} + */ + public stopMultiHit(target?: Pokemon): void { + // If given a specific target, remove the target from subsequent strikes if (target) { this.removeTarget(target); } - /** - * If no target specified, or the specified target was the last of this move's - * targets, completely cancel all subsequent strikes. - */ + const user = this.getUserPokemon(); + if (!user) { + return; + } + // If no target specified, or the specified target was the last of this move's + // targets, completely cancel all subsequent strikes. if (!target || this.targets.length === 0 ) { - this.getUserPokemon()!.turnData.hitCount = 1; // TODO: is the bang correct here? - this.getUserPokemon()!.turnData.hitsLeft = 1; // TODO: is the bang correct here? + user.turnData.hitCount = 1; + user.turnData.hitsLeft = 1; } } - /** Returns a new MoveEffectPhase with the same properties as this phase */ - getNewHitPhase() { + /** @returns A new `MoveEffectPhase` with the same properties as this phase */ + protected getNewHitPhase(): MoveEffectPhase { return new MoveEffectPhase(this.scene, this.battlerIndex, this.targets, this.move); } } diff --git a/src/phases/move-phase.ts b/src/phases/move-phase.ts index e63096360dd..005cdbe1716 100644 --- a/src/phases/move-phase.ts +++ b/src/phases/move-phase.ts @@ -1,70 +1,127 @@ -import BattleScene from "#app/battle-scene"; import { BattlerIndex } from "#app/battle"; -import { applyAbAttrs, applyPostMoveUsedAbAttrs, applyPreAttackAbAttrs, BlockRedirectAbAttr, IncreasePpAbAttr, PokemonTypeChangeAbAttr, PostMoveUsedAbAttr, RedirectMoveAbAttr } from "#app/data/ability"; +import BattleScene from "#app/battle-scene"; +import { + applyAbAttrs, + applyPostMoveUsedAbAttrs, + applyPreAttackAbAttrs, + BlockRedirectAbAttr, + IncreasePpAbAttr, + PokemonTypeChangeAbAttr, + PostMoveUsedAbAttr, + RedirectMoveAbAttr, + ReduceStatusEffectDurationAbAttr +} from "#app/data/ability"; +import { DelayedAttackTag } from "#app/data/arena-tag"; import { CommonAnim } from "#app/data/battle-anims"; import { BattlerTagLapseType, CenterOfAttentionTag } from "#app/data/battler-tags"; -import { allMoves, applyMoveAttrs, BypassRedirectAttr, BypassSleepAttr, ChargeAttr, CopyMoveAttr, HealStatusEffectAttr, MoveFlags, PreMoveMessageAttr } from "#app/data/move"; +import { + allMoves, + applyMoveAttrs, + BypassRedirectAttr, + BypassSleepAttr, + CopyMoveAttr, + DelayedAttackAttr, + frenzyMissFunc, + HealStatusEffectAttr, + MoveFlags, + PreMoveMessageAttr +} from "#app/data/move"; import { SpeciesFormChangePreMoveTrigger } from "#app/data/pokemon-forms"; import { getStatusEffectActivationText, getStatusEffectHealText } from "#app/data/status-effect"; -import { Type } from "#app/data/type"; +import { Type } from "#enums/type"; import { getTerrainBlockMessage } from "#app/data/weather"; -import { Abilities } from "#app/enums/abilities"; -import { BattlerTagType } from "#app/enums/battler-tag-type"; -import { Moves } from "#app/enums/moves"; -import { StatusEffect } from "#app/enums/status-effect"; import { MoveUsedEvent } from "#app/events/battle-scene"; -import Pokemon, { MoveResult, PokemonMove, TurnMove } from "#app/field/pokemon"; +import Pokemon, { MoveResult, PokemonMove } from "#app/field/pokemon"; import { getPokemonNameWithAffix } from "#app/messages"; -import * as Utils from "#app/utils"; +import Overrides from "#app/overrides"; +import { BattlePhase } from "#app/phases/battle-phase"; +import { CommonAnimPhase } from "#app/phases/common-anim-phase"; +import { MoveChargePhase } from "#app/phases/move-charge-phase"; +import { MoveEffectPhase } from "#app/phases/move-effect-phase"; +import { MoveEndPhase } from "#app/phases/move-end-phase"; +import { ShowAbilityPhase } from "#app/phases/show-ability-phase"; +import { BooleanHolder, NumberHolder } from "#app/utils"; +import { Abilities } from "#enums/abilities"; +import { ArenaTagType } from "#enums/arena-tag-type"; +import { BattlerTagType } from "#enums/battler-tag-type"; +import { Moves } from "#enums/moves"; +import { StatusEffect } from "#enums/status-effect"; import i18next from "i18next"; -import { BattlePhase } from "./battle-phase"; -import { CommonAnimPhase } from "./common-anim-phase"; -import { MoveEffectPhase } from "./move-effect-phase"; -import { MoveEndPhase } from "./move-end-phase"; -import { ShowAbilityPhase } from "./show-ability-phase"; export class MovePhase extends BattlePhase { - public pokemon: Pokemon; - public move: PokemonMove; - public targets: BattlerIndex[]; + protected _pokemon: Pokemon; + protected _move: PokemonMove; + protected _targets: BattlerIndex[]; protected followUp: boolean; protected ignorePp: boolean; - protected failed: boolean; - protected cancelled: boolean; + protected failed: boolean = false; + protected cancelled: boolean = false; - constructor(scene: BattleScene, pokemon: Pokemon, targets: BattlerIndex[], move: PokemonMove, followUp?: boolean, ignorePp?: boolean) { + public get pokemon(): Pokemon { + return this._pokemon; + } + + protected set pokemon(pokemon: Pokemon) { + this._pokemon = pokemon; + } + + public get move(): PokemonMove { + return this._move; + } + + protected set move(move: PokemonMove) { + this._move = move; + } + + public get targets(): BattlerIndex[] { + return this._targets; + } + + protected set targets(targets: BattlerIndex[]) { + this._targets = targets; + } + + /** + * @param followUp Indicates that the move being uses is a "follow-up" - for example, a move being used by Metronome or Dancer. + * Follow-ups bypass a few failure conditions, including flinches, sleep/paralysis/freeze and volatile status checks, etc. + */ + constructor(scene: BattleScene, pokemon: Pokemon, targets: BattlerIndex[], move: PokemonMove, followUp: boolean = false, ignorePp: boolean = false) { super(scene); this.pokemon = pokemon; this.targets = targets; this.move = move; - this.followUp = followUp ?? false; - this.ignorePp = ignorePp ?? false; - this.failed = false; - this.cancelled = false; + this.followUp = followUp; + this.ignorePp = ignorePp; } - canMove(ignoreDisableTags?: boolean): boolean { + /** + * Checks if the pokemon is active, if the move is usable, and that the move is targetting something. + * @param ignoreDisableTags `true` to not check if the move is disabled + * @returns `true` if all the checks pass + */ + public canMove(ignoreDisableTags: boolean = false): boolean { return this.pokemon.isActive(true) && this.move.isUsable(this.pokemon, this.ignorePp, ignoreDisableTags) && !!this.targets.length; } /**Signifies the current move should fail but still use PP */ - fail(): void { + public fail(): void { this.failed = true; } /**Signifies the current move should cancel and retain PP */ - cancel(): void { + public cancel(): void { this.cancelled = true; } - start() { + public start(): void { super.start(); console.log(Moves[this.move.moveId]); + // Check if move is unusable (e.g. because it's out of PP due to a mid-turn Spite). if (!this.canMove(true)) { - if (this.pokemon.isActive(true) && this.move.ppUsed >= this.move.getMovePp()) { // if the move PP was reduced from Spite or otherwise, the move fails + if (this.pokemon.isActive(true)) { this.fail(); this.showMoveText(); this.showFailedText(); @@ -72,238 +129,412 @@ export class MovePhase extends BattlePhase { return this.end(); } + this.pokemon.turnData.acted = true; + + // Reset hit-related turn data when starting follow-up moves (e.g. Metronomed moves, Dancer repeats) + if (this.followUp) { + this.pokemon.turnData.hitsLeft = -1; + this.pokemon.turnData.hitCount = 0; + } + + // Check move to see if arena.ignoreAbilities should be true. if (!this.followUp) { if (this.move.getMove().checkFlag(MoveFlags.IGNORE_ABILITIES, this.pokemon, null)) { - this.scene.arena.setIgnoreAbilities(); + this.scene.arena.setIgnoreAbilities(true, this.pokemon.getBattlerIndex()); } + } + + this.resolveRedirectTarget(); + + this.resolveCounterAttackTarget(); + + this.resolvePreMoveStatusEffects(); + + this.lapsePreMoveAndMoveTags(); + + if (!(this.failed || this.cancelled)) { + this.resolveFinalPreMoveCancellationChecks(); + } + + if (this.cancelled || this.failed) { + this.handlePreMoveFailures(); + } else if (this.move.getMove().isChargingMove() && !this.pokemon.getTag(BattlerTagType.CHARGING)) { + this.chargeMove(); } else { - this.pokemon.turnData.hitsLeft = 0; // TODO: is `0` correct? - this.pokemon.turnData.hitCount = 0; // TODO: is `0` correct? + this.useMove(); } - // Move redirection abilities (ie. Storm Drain) only support single target moves - const moveTarget = this.targets.length === 1 - ? new Utils.IntegerHolder(this.targets[0]) - : null; - if (moveTarget) { - const oldTarget = moveTarget.value; - this.scene.getField(true).filter(p => p !== this.pokemon).forEach(p => applyAbAttrs(RedirectMoveAbAttr, p, null, false, this.move.moveId, moveTarget)); - this.pokemon.getOpponents().forEach(p => { - const redirectTag = p.getTag(CenterOfAttentionTag) as CenterOfAttentionTag; - if (redirectTag && (!redirectTag.powder || (!this.pokemon.isOfType(Type.GRASS) && !this.pokemon.hasAbility(Abilities.OVERCOAT)))) { - moveTarget.value = p.getBattlerIndex(); - } - }); - //Check if this move is immune to being redirected, and restore its target to the intended target if it is. - if ((this.pokemon.hasAbilityWithAttr(BlockRedirectAbAttr) || this.move.getMove().hasAttr(BypassRedirectAttr))) { - //If an ability prevented this move from being redirected, display its ability pop up. - if ((this.pokemon.hasAbilityWithAttr(BlockRedirectAbAttr) && !this.move.getMove().hasAttr(BypassRedirectAttr)) && oldTarget !== moveTarget.value) { - this.scene.unshiftPhase(new ShowAbilityPhase(this.scene, this.pokemon.getBattlerIndex(), this.pokemon.getPassiveAbility().hasAttr(BlockRedirectAbAttr))); - } - moveTarget.value = oldTarget; - } - this.targets[0] = moveTarget.value; + this.end(); + } + + /** Check for cancellation edge cases - no targets remaining, or {@linkcode Moves.NONE} is in the queue */ + protected resolveFinalPreMoveCancellationChecks(): void { + const targets = this.getActiveTargetPokemon(); + const moveQueue = this.pokemon.getMoveQueue(); + + if (targets.length === 0 || (moveQueue.length && moveQueue[0].move === Moves.NONE)) { + this.showMoveText(); + this.showFailedText(); + this.cancel(); } + } - // Check for counterattack moves to switch target - if (this.targets.length === 1 && this.targets[0] === BattlerIndex.ATTACKER) { - if (this.pokemon.turnData.attacksReceived.length) { - const attack = this.pokemon.turnData.attacksReceived[0]; - this.targets[0] = attack.sourceBattlerIndex; - - // account for metal burst and comeuppance hitting remaining targets in double battles - // counterattack will redirect to remaining ally if original attacker faints - if (this.scene.currentBattle.double && this.move.getMove().hasFlag(MoveFlags.REDIRECT_COUNTER)) { - if (this.scene.getField()[this.targets[0]].hp === 0) { - const opposingField = this.pokemon.isPlayer() ? this.scene.getEnemyField() : this.scene.getPlayerField(); - //@ts-ignore - this.targets[0] = opposingField.find(p => p.hp > 0)?.getBattlerIndex(); //TODO: fix ts-ignore - } - } - } - if (this.targets[0] === BattlerIndex.ATTACKER) { - this.fail(); // Marks the move as failed for later in doMove - this.showMoveText(); - this.showFailedText(); - } - } - - const targets = this.scene.getField(true).filter(p => { - if (this.targets.indexOf(p.getBattlerIndex()) > -1) { - return true; - } - return false; - }); - - const doMove = () => { - this.pokemon.turnData.acted = true; // Record that the move was attempted, even if it fails - - this.pokemon.lapseTags(BattlerTagLapseType.PRE_MOVE); - - let ppUsed = 1; - // Filter all opponents to include only those this move is targeting - const targetedOpponents = this.pokemon.getOpponents().filter(o => this.targets.includes(o.getBattlerIndex())); - for (const opponent of targetedOpponents) { - if (this.move.ppUsed + ppUsed >= this.move.getMovePp()) { // If we're already at max PP usage, stop checking - break; - } - if (opponent.hasAbilityWithAttr(IncreasePpAbAttr)) { // Accounting for abilities like Pressure - ppUsed++; - } - } - - if (!this.followUp && this.canMove() && !this.cancelled) { - this.pokemon.lapseTags(BattlerTagLapseType.MOVE); - } - - const moveQueue = this.pokemon.getMoveQueue(); - if (this.cancelled || this.failed) { - if (this.failed) { - this.move.usePp(ppUsed); // Only use PP if the move failed - this.scene.eventTarget.dispatchEvent(new MoveUsedEvent(this.pokemon?.id, this.move.getMove(), this.move.ppUsed)); - } - - // Record a failed move so Abilities like Truant don't trigger next turn and soft-lock - this.pokemon.pushMoveHistory({ move: Moves.NONE, result: MoveResult.FAIL }); - - this.pokemon.lapseTags(BattlerTagLapseType.MOVE_EFFECT); // Remove any tags from moves like Fly/Dive/etc. - this.pokemon.lapseTags(BattlerTagLapseType.AFTER_MOVE); - moveQueue.shift(); // Remove the second turn of charge moves - return this.end(); - } - - this.scene.triggerPokemonFormChange(this.pokemon, SpeciesFormChangePreMoveTrigger); - - if (this.move.moveId) { - this.showMoveText(); - } - - // This should only happen when there are no valid targets left on the field - if ((moveQueue.length && moveQueue[0].move === Moves.NONE) || !targets.length) { - this.showFailedText(); - this.cancel(); - - // Record a failed move so Abilities like Truant don't trigger next turn and soft-lock - this.pokemon.pushMoveHistory({ move: Moves.NONE, result: MoveResult.FAIL }); - - this.pokemon.lapseTags(BattlerTagLapseType.MOVE_EFFECT); // Remove any tags from moves like Fly/Dive/etc. - this.pokemon.lapseTags(BattlerTagLapseType.AFTER_MOVE); - - moveQueue.shift(); - return this.end(); - } - - if ((!moveQueue.length || !moveQueue.shift()?.ignorePP) && !this.ignorePp) { // using .shift here clears out two turn moves once they've been used - this.move.usePp(ppUsed); - this.scene.eventTarget.dispatchEvent(new MoveUsedEvent(this.pokemon?.id, this.move.getMove(), this.move.ppUsed)); - } - - if (!allMoves[this.move.moveId].hasAttr(CopyMoveAttr)) { - this.scene.currentBattle.lastMove = this.move.moveId; - } - - // Assume conditions affecting targets only apply to moves with a single target - let success = this.move.getMove().applyConditions(this.pokemon, targets[0], this.move.getMove()); - const cancelled = new Utils.BooleanHolder(false); - let failedText = this.move.getMove().getFailedText(this.pokemon, targets[0], this.move.getMove(), cancelled); - if (success && this.scene.arena.isMoveWeatherCancelled(this.pokemon, this.move.getMove())) { - success = false; - } else if (success && this.scene.arena.isMoveTerrainCancelled(this.pokemon, this.targets, this.move.getMove())) { - success = false; - if (failedText === null) { - failedText = getTerrainBlockMessage(targets[0], this.scene.arena.terrain?.terrainType!); // TODO: is this bang correct? - } - } - - /** - * Trigger pokemon type change before playing the move animation - * Will still change the user's type when using Roar, Whirlwind, Trick-or-Treat, and Forest's Curse, - * regardless of whether the move successfully executes or not. - */ - if (success || [Moves.ROAR, Moves.WHIRLWIND, Moves.TRICK_OR_TREAT, Moves.FORESTS_CURSE].includes(this.move.moveId)) { - applyPreAttackAbAttrs(PokemonTypeChangeAbAttr, this.pokemon, null, this.move.getMove()); - } - - if (success) { - this.scene.unshiftPhase(this.getEffectPhase()); - } else { - this.pokemon.pushMoveHistory({ move: this.move.moveId, targets: this.targets, result: MoveResult.FAIL, virtual: this.move.virtual }); - if (!cancelled.value) { - this.showFailedText(failedText); - } - } - // Checks if Dancer ability is triggered - if (this.move.getMove().hasFlag(MoveFlags.DANCE_MOVE) && !this.followUp) { - // Pokemon with Dancer can be on either side of the battle so we check in both cases - this.scene.getPlayerField().forEach(pokemon => { - applyPostMoveUsedAbAttrs(PostMoveUsedAbAttr, pokemon, this.move, this.pokemon, this.targets); - }); - this.scene.getEnemyField().forEach(pokemon => { - applyPostMoveUsedAbAttrs(PostMoveUsedAbAttr, pokemon, this.move, this.pokemon, this.targets); - }); - } - this.end(); - }; + public getActiveTargetPokemon(): Pokemon[] { + return this.scene.getField(true).filter(p => this.targets.includes(p.getBattlerIndex())); + } + /** + * Handles {@link StatusEffect.SLEEP Sleep}/{@link StatusEffect.PARALYSIS Paralysis}/{@link StatusEffect.FREEZE Freeze} rolls and side effects. + */ + protected resolvePreMoveStatusEffects(): void { if (!this.followUp && this.pokemon.status && !this.pokemon.status.isPostTurn()) { this.pokemon.status.incrementTurn(); let activated = false; let healed = false; switch (this.pokemon.status.effect) { - case StatusEffect.PARALYSIS: - if (!this.pokemon.randSeedInt(4)) { - activated = true; - this.cancelled = true; - } - break; - case StatusEffect.SLEEP: - applyMoveAttrs(BypassSleepAttr, this.pokemon, null, this.move.getMove()); - healed = this.pokemon.status.turnCount === this.pokemon.status.cureTurn; - activated = !healed && !this.pokemon.getTag(BattlerTagType.BYPASS_SLEEP); - this.cancelled = activated; - break; - case StatusEffect.FREEZE: - healed = !!this.move.getMove().findAttr(attr => attr instanceof HealStatusEffectAttr && attr.selfTarget && attr.isOfEffect(StatusEffect.FREEZE)) || !this.pokemon.randSeedInt(5); - activated = !healed; - this.cancelled = activated; - break; + case StatusEffect.PARALYSIS: + activated = (!this.pokemon.randSeedInt(4) || Overrides.STATUS_ACTIVATION_OVERRIDE === true) && Overrides.STATUS_ACTIVATION_OVERRIDE !== false; + break; + case StatusEffect.SLEEP: + applyMoveAttrs(BypassSleepAttr, this.pokemon, null, this.move.getMove()); + const turnsRemaining = new NumberHolder(this.pokemon.status.sleepTurnsRemaining ?? 0); + applyAbAttrs(ReduceStatusEffectDurationAbAttr, this.pokemon, null, false, this.pokemon.status.effect, turnsRemaining); + this.pokemon.status.sleepTurnsRemaining = turnsRemaining.value; + healed = this.pokemon.status.sleepTurnsRemaining <= 0; + activated = !healed && !this.pokemon.getTag(BattlerTagType.BYPASS_SLEEP); + break; + case StatusEffect.FREEZE: + healed = + !!this.move.getMove().findAttr((attr) => + attr instanceof HealStatusEffectAttr + && attr.selfTarget + && attr.isOfEffect(StatusEffect.FREEZE)) + || (!this.pokemon.randSeedInt(5) && Overrides.STATUS_ACTIVATION_OVERRIDE !== true) + || Overrides.STATUS_ACTIVATION_OVERRIDE === false; + + activated = !healed; + break; } if (activated) { + this.cancel(); this.scene.queueMessage(getStatusEffectActivationText(this.pokemon.status.effect, getPokemonNameWithAffix(this.pokemon))); this.scene.unshiftPhase(new CommonAnimPhase(this.scene, this.pokemon.getBattlerIndex(), undefined, CommonAnim.POISON + (this.pokemon.status.effect - 1))); - doMove(); - } else { - if (healed) { - this.scene.queueMessage(getStatusEffectHealText(this.pokemon.status.effect, getPokemonNameWithAffix(this.pokemon))); - this.pokemon.resetStatus(); - this.pokemon.updateInfo(); + } else if (healed) { + this.scene.queueMessage(getStatusEffectHealText(this.pokemon.status.effect, getPokemonNameWithAffix(this.pokemon))); + this.pokemon.resetStatus(); + this.pokemon.updateInfo(); + } + } + } + + /** + * Lapse {@linkcode BattlerTagLapseType.PRE_MOVE PRE_MOVE} tags that trigger before a move is used, regardless of whether or not it failed. + * Also lapse {@linkcode BattlerTagLapseType.MOVE MOVE} tags if the move should be successful. + */ + protected lapsePreMoveAndMoveTags(): void { + this.pokemon.lapseTags(BattlerTagLapseType.PRE_MOVE); + + // TODO: does this intentionally happen before the no targets/Moves.NONE on queue cancellation case is checked? + if (!this.followUp && this.canMove() && !this.cancelled) { + this.pokemon.lapseTags(BattlerTagLapseType.MOVE); + } + } + + protected useMove(): void { + const targets = this.getActiveTargetPokemon(); + const moveQueue = this.pokemon.getMoveQueue(); + + // form changes happen even before we know that the move wll execute. + this.scene.triggerPokemonFormChange(this.pokemon, SpeciesFormChangePreMoveTrigger); + + const isDelayedAttack = this.move.getMove().hasAttr(DelayedAttackAttr); + if (isDelayedAttack) { + // Check the player side arena if future sight is active + const futureSightTags = this.scene.arena.findTags(t => t.tagType === ArenaTagType.FUTURE_SIGHT); + const doomDesireTags = this.scene.arena.findTags(t => t.tagType === ArenaTagType.DOOM_DESIRE); + let fail = false; + const currentTargetIndex = targets[0].getBattlerIndex(); + for (const tag of futureSightTags) { + if ((tag as DelayedAttackTag).targetIndex === currentTargetIndex) { + fail = true; + break; } - doMove(); } + for (const tag of doomDesireTags) { + if ((tag as DelayedAttackTag).targetIndex === currentTargetIndex) { + fail = true; + break; + } + } + if (fail) { + this.showMoveText(); + this.showFailedText(); + return this.end(); + } + } + + this.showMoveText(); + + if (moveQueue.length > 0) { + // Using .shift here clears out two turn moves once they've been used + this.ignorePp = moveQueue.shift()?.ignorePP ?? false; + } + + if (this.pokemon.getTag(BattlerTagType.CHARGING)?.sourceMove === this.move.moveId) { + this.pokemon.lapseTag(BattlerTagType.CHARGING); + } + + // "commit" to using the move, deducting PP. + if (!this.ignorePp) { + const ppUsed = 1 + this.getPpIncreaseFromPressure(targets); + + this.move.usePp(ppUsed); + this.scene.eventTarget.dispatchEvent(new MoveUsedEvent(this.pokemon?.id, this.move.getMove(), this.move.ppUsed)); + } + + // Update the battle's "last move" pointer, unless we're currently mimicking a move. + if (!allMoves[this.move.moveId].hasAttr(CopyMoveAttr)) { + this.scene.currentBattle.lastMove = this.move.moveId; + } + + /** + * Determine if the move is successful (meaning that its damage/effects can be attempted) + * by checking that all of the following are true: + * - Conditional attributes of the move are all met + * - The target's `ForceSwitchOutImmunityAbAttr` is not triggered (see {@linkcode Move.prototype.applyConditions}) + * - Weather does not block the move + * - Terrain does not block the move + * + * TODO: These steps are straightforward, but the implementation below is extremely convoluted. + */ + + const move = this.move.getMove(); + + /** + * Move conditions assume the move has a single target + * TODO: is this sustainable? + */ + const passesConditions = move.applyConditions(this.pokemon, targets[0], move); + const failedDueToWeather: boolean = this.scene.arena.isMoveWeatherCancelled(this.pokemon, move); + const failedDueToTerrain: boolean = this.scene.arena.isMoveTerrainCancelled(this.pokemon, this.targets, move); + + const success = passesConditions && !failedDueToWeather && !failedDueToTerrain; + + /** + * If the move has not failed, trigger ability-based user type changes and then execute it. + * + * Notably, Roar, Whirlwind, Trick-or-Treat, and Forest's Curse will trigger these type changes even + * if the move fails. + */ + if (success) { + applyPreAttackAbAttrs(PokemonTypeChangeAbAttr, this.pokemon, null, this.move.getMove()); + this.scene.unshiftPhase(new MoveEffectPhase(this.scene, this.pokemon.getBattlerIndex(), this.targets, this.move)); + } else { - doMove(); + if ([ Moves.ROAR, Moves.WHIRLWIND, Moves.TRICK_OR_TREAT, Moves.FORESTS_CURSE ].includes(this.move.moveId)) { + applyPreAttackAbAttrs(PokemonTypeChangeAbAttr, this.pokemon, null, this.move.getMove()); + } + + this.pokemon.pushMoveHistory({ move: this.move.moveId, targets: this.targets, result: MoveResult.FAIL, virtual: this.move.virtual }); + + let failedText: string | undefined; + const failureMessage = move.getFailedText(this.pokemon, targets[0], move, new BooleanHolder(false)); + + if (failureMessage) { + failedText = failureMessage; + } else if (failedDueToTerrain) { + failedText = getTerrainBlockMessage(this.pokemon, this.scene.arena.getTerrainType()); + } + + this.showFailedText(failedText); + + // Remove the user from its semi-invulnerable state (if applicable) + this.pokemon.lapseTags(BattlerTagLapseType.MOVE_EFFECT); + } + + // Handle Dancer, which triggers immediately after a move is used (rather than waiting on `this.end()`). + // Note that the `!this.followUp` check here prevents an infinite Dancer loop. + if (this.move.getMove().hasFlag(MoveFlags.DANCE_MOVE) && !this.followUp) { + this.scene.getField(true).forEach(pokemon => { + applyPostMoveUsedAbAttrs(PostMoveUsedAbAttr, pokemon, this.move, this.pokemon, this.targets); + }); } } - getEffectPhase(): MoveEffectPhase { - return new MoveEffectPhase(this.scene, this.pokemon.getBattlerIndex(), this.targets, this.move); + /** Queues a {@linkcode MoveChargePhase} for this phase's invoked move. */ + protected chargeMove() { + const move = this.move.getMove(); + const targets = this.getActiveTargetPokemon(); + + if (move.applyConditions(this.pokemon, targets[0], move)) { + // Protean and Libero apply on the charging turn of charge moves + applyPreAttackAbAttrs(PokemonTypeChangeAbAttr, this.pokemon, null, this.move.getMove()); + + this.showMoveText(); + this.scene.unshiftPhase(new MoveChargePhase(this.scene, this.pokemon.getBattlerIndex(), this.targets[0], this.move)); + } else { + this.pokemon.pushMoveHistory({ move: this.move.moveId, targets: this.targets, result: MoveResult.FAIL, virtual: this.move.virtual }); + + const failureMessage = move.getFailedText(this.pokemon, targets[0], move, new BooleanHolder(false)); + this.showMoveText(); + this.showFailedText(failureMessage ?? undefined); + + // Remove the user from its semi-invulnerable state (if applicable) + this.pokemon.lapseTags(BattlerTagLapseType.MOVE_EFFECT); + } } - showMoveText(): void { - if (this.move.getMove().hasAttr(ChargeAttr)) { - const lastMove = this.pokemon.getLastXMoves() as TurnMove[]; - if (!lastMove.length || lastMove[0].move !== this.move.getMove().id || lastMove[0].result !== MoveResult.OTHER) { - this.scene.queueMessage(i18next.t("battle:useMove", { - pokemonNameWithAffix: getPokemonNameWithAffix(this.pokemon), - moveName: this.move.getName() - }), 500); - return; + /** + * Queues a {@linkcode MoveEndPhase} if the move wasn't a {@linkcode followUp} and {@linkcode canMove()} returns `true`, + * then ends the phase. + */ + public end(): void { + if (!this.followUp && this.canMove()) { + this.scene.unshiftPhase(new MoveEndPhase(this.scene, this.pokemon.getBattlerIndex())); + } + + super.end(); + } + + /** + * Applies PP increasing abilities (currently only {@link Abilities.PRESSURE Pressure}) if they exist on the target pokemon. + * Note that targets must include only active pokemon. + * + * TODO: This hardcodes the PP increase at 1 per opponent, rather than deferring to the ability. + */ + public getPpIncreaseFromPressure(targets: Pokemon[]): number { + const foesWithPressure = this.pokemon.getOpponents().filter(o => targets.includes(o) && o.isActive(true) && o.hasAbilityWithAttr(IncreasePpAbAttr)); + return foesWithPressure.length; + } + + /** + * Modifies `this.targets` in place, based upon: + * - Move redirection abilities, effects, etc. + * - Counterattacks, which pass a special value into the `targets` constructor param (`[`{@linkcode BattlerIndex.ATTACKER}`]`). + */ + protected resolveRedirectTarget(): void { + if (this.targets.length === 1) { + const currentTarget = this.targets[0]; + const redirectTarget = new NumberHolder(currentTarget); + + // check move redirection abilities of every pokemon *except* the user. + this.scene.getField(true).filter(p => p !== this.pokemon).forEach(p => applyAbAttrs(RedirectMoveAbAttr, p, null, false, this.move.moveId, redirectTarget)); + + /** `true` if an Ability is responsible for redirecting the move to another target; `false` otherwise */ + let redirectedByAbility = (currentTarget !== redirectTarget.value); + + // check for center-of-attention tags (note that this will override redirect abilities) + this.pokemon.getOpponents().forEach(p => { + const redirectTag = p.getTag(CenterOfAttentionTag); + + // TODO: don't hardcode this interaction. + // Handle interaction between the rage powder center-of-attention tag and moves used by grass types/overcoat-havers (which are immune to RP's redirect) + if (redirectTag && (!redirectTag.powder || (!this.pokemon.isOfType(Type.GRASS) && !this.pokemon.hasAbility(Abilities.OVERCOAT)))) { + redirectTarget.value = p.getBattlerIndex(); + redirectedByAbility = false; + } + }); + + if (currentTarget !== redirectTarget.value) { + const bypassRedirectAttrs = this.move.getMove().getAttrs(BypassRedirectAttr); + bypassRedirectAttrs.forEach((attr) => { + if (!attr.abilitiesOnly || redirectedByAbility) { + redirectTarget.value = currentTarget; + } + }); + + if (this.pokemon.hasAbilityWithAttr(BlockRedirectAbAttr)) { + redirectTarget.value = currentTarget; + this.scene.unshiftPhase(new ShowAbilityPhase(this.scene, this.pokemon.getBattlerIndex(), this.pokemon.getPassiveAbility().hasAttr(BlockRedirectAbAttr))); + } + + this.targets[0] = redirectTarget.value; } } + } - if (this.pokemon.getTag(BattlerTagType.RECHARGING || BattlerTagType.INTERRUPTED)) { + /** + * Counter-attacking moves pass in `[`{@linkcode BattlerIndex.ATTACKER}`]` into the constructor's `targets` param. + * This function modifies `this.targets` to reflect the actual battler index of the user's last + * attacker. + * + * If there is no last attacker, or they are no longer on the field, a message is displayed and the + * move is marked for failure. + */ + protected resolveCounterAttackTarget(): void { + if (this.targets.length === 1 && this.targets[0] === BattlerIndex.ATTACKER) { + if (this.pokemon.turnData.attacksReceived.length) { + this.targets[0] = this.pokemon.turnData.attacksReceived[0].sourceBattlerIndex; + + // account for metal burst and comeuppance hitting remaining targets in double battles + // counterattack will redirect to remaining ally if original attacker faints + if (this.scene.currentBattle.double && this.move.getMove().hasFlag(MoveFlags.REDIRECT_COUNTER)) { + if (this.scene.getField()[this.targets[0]].hp === 0) { + const opposingField = this.pokemon.isPlayer() ? this.scene.getEnemyField() : this.scene.getPlayerField(); + this.targets[0] = opposingField.find(p => p.hp > 0)?.getBattlerIndex() ?? BattlerIndex.ATTACKER; + } + } + } + + if (this.targets[0] === BattlerIndex.ATTACKER) { + this.fail(); + this.showMoveText(); + this.showFailedText(); + } + } + } + + /** + * Handles the case where the move was cancelled or failed: + * - Uses PP if the move failed (not cancelled) and should use PP (failed moves are not affected by {@link Abilities.PRESSURE Pressure}) + * - Records a cancelled OR failed move in move history, so abilities like {@link Abilities.TRUANT Truant} don't trigger on the + * next turn and soft-lock. + * - Lapses `MOVE_EFFECT` tags: + * - Semi-invulnerable battler tags (Fly/Dive/etc.) are intended to lapse on move effects, but also need + * to lapse on move failure/cancellation. + * + * TODO: ...this seems weird. + * - Lapses `AFTER_MOVE` tags: + * - This handles the effects of {@link Moves.SUBSTITUTE Substitute} + * - Removes the second turn of charge moves + */ + protected handlePreMoveFailures(): void { + if (this.cancelled || this.failed) { + if (this.failed) { + const ppUsed = this.ignorePp ? 0 : 1; + + if (ppUsed) { + this.move.usePp(); + } + + this.scene.eventTarget.dispatchEvent(new MoveUsedEvent(this.pokemon?.id, this.move.getMove(), ppUsed)); + } + + if (this.cancelled && this.pokemon.summonData?.tags?.find(t => t.tagType === BattlerTagType.FRENZY)) { + frenzyMissFunc(this.pokemon, this.move.getMove()); + } + + this.pokemon.pushMoveHistory({ move: Moves.NONE, result: MoveResult.FAIL }); + + this.pokemon.lapseTags(BattlerTagLapseType.MOVE_EFFECT); + this.pokemon.lapseTags(BattlerTagLapseType.AFTER_MOVE); + + this.pokemon.getMoveQueue().shift(); + } + } + + /** + * Displays the move's usage text to the player, unless it's a charge turn (ie: {@link Moves.SOLAR_BEAM Solar Beam}), + * the pokemon is on a recharge turn (ie: {@link Moves.HYPER_BEAM Hyper Beam}), or a 2-turn move was interrupted (ie: {@link Moves.FLY Fly}). + */ + protected showMoveText(): void { + if (this.move.moveId === Moves.NONE) { + return; + } + + if (this.pokemon.getTag(BattlerTagType.RECHARGING) || this.pokemon.getTag(BattlerTagType.INTERRUPTED)) { return; } @@ -311,18 +542,10 @@ export class MovePhase extends BattlePhase { pokemonNameWithAffix: getPokemonNameWithAffix(this.pokemon), moveName: this.move.getName() }), 500); - applyMoveAttrs(PreMoveMessageAttr, this.pokemon, this.pokemon.getOpponents().find(() => true)!, this.move.getMove()); //TODO: is the bang correct here? + applyMoveAttrs(PreMoveMessageAttr, this.pokemon, this.pokemon.getOpponents()[0], this.move.getMove()); } - showFailedText(failedText: string | null = null): void { - this.scene.queueMessage(failedText || i18next.t("battle:attackFailed")); - } - - end() { - if (!this.followUp && this.canMove()) { - this.scene.unshiftPhase(new MoveEndPhase(this.scene, this.pokemon.getBattlerIndex())); - } - - super.end(); + protected showFailedText(failedText?: string): void { + this.scene.queueMessage(failedText ?? i18next.t("battle:attackFailed")); } } diff --git a/src/phases/mystery-encounter-phases.ts b/src/phases/mystery-encounter-phases.ts index 6c9d3fd8c1d..2d1c3c4ae31 100644 --- a/src/phases/mystery-encounter-phases.ts +++ b/src/phases/mystery-encounter-phases.ts @@ -1,29 +1,31 @@ +import { BattlerTagLapseType } from "#app/data/battler-tags"; +import MysteryEncounterOption, { OptionPhaseCallback } from "#app/data/mystery-encounters/mystery-encounter-option"; +import { SeenEncounterData } from "#app/data/mystery-encounters/mystery-encounter-save-data"; +import { getEncounterText } from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; +import { CheckSwitchPhase } from "#app/phases/check-switch-phase"; +import { GameOverPhase } from "#app/phases/game-over-phase"; +import { NewBattlePhase } from "#app/phases/new-battle-phase"; +import { PostTurnStatusEffectPhase } from "#app/phases/post-turn-status-effect-phase"; +import { ReturnPhase } from "#app/phases/return-phase"; +import { ScanIvsPhase } from "#app/phases/scan-ivs-phase"; +import { SelectModifierPhase } from "#app/phases/select-modifier-phase"; +import { SummonPhase } from "#app/phases/summon-phase"; +import { SwitchPhase } from "#app/phases/switch-phase"; +import { ToggleDoublePositionPhase } from "#app/phases/toggle-double-position-phase"; +import { BattleSpec } from "#enums/battle-spec"; +import { BattlerTagType } from "#enums/battler-tag-type"; +import { MysteryEncounterMode } from "#enums/mystery-encounter-mode"; +import { SwitchType } from "#enums/switch-type"; import i18next from "i18next"; import BattleScene from "../battle-scene"; +import { getCharVariantFromDialogue } from "../data/dialogue"; +import { OptionSelectSettings, transitionMysteryEncounterIntroVisuals } from "../data/mystery-encounters/utils/encounter-phase-utils"; +import { TrainerSlot } from "../data/trainer-config"; +import { IvScannerModifier } from "../modifier/modifier"; import { Phase } from "../phase"; import { Mode } from "../ui/ui"; -import { transitionMysteryEncounterIntroVisuals, OptionSelectSettings } from "../data/mystery-encounters/utils/encounter-phase-utils"; -import MysteryEncounterOption, { OptionPhaseCallback } from "../data/mystery-encounters/mystery-encounter-option"; -import { getCharVariantFromDialogue } from "../data/dialogue"; -import { TrainerSlot } from "../data/trainer-config"; -import { BattleSpec } from "#enums/battle-spec"; -import { IvScannerModifier } from "../modifier/modifier"; import * as Utils from "../utils"; import { isNullOrUndefined } from "../utils"; -import { getEncounterText } from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; -import { BattlerTagLapseType } from "#app/data/battler-tags"; -import { MysteryEncounterMode } from "#enums/mystery-encounter-mode"; -import { PostTurnStatusEffectPhase } from "#app/phases/post-turn-status-effect-phase"; -import { SummonPhase } from "#app/phases/summon-phase"; -import { ScanIvsPhase } from "#app/phases/scan-ivs-phase"; -import { ToggleDoublePositionPhase } from "#app/phases/toggle-double-position-phase"; -import { ReturnPhase } from "#app/phases/return-phase"; -import { CheckSwitchPhase } from "#app/phases/check-switch-phase"; -import { SelectModifierPhase } from "#app/phases/select-modifier-phase"; -import { NewBattlePhase } from "#app/phases/new-battle-phase"; -import { GameOverPhase } from "#app/phases/game-over-phase"; -import { SwitchPhase } from "#app/phases/switch-phase"; -import { SeenEncounterData } from "#app/data/mystery-encounters/mystery-encounter-save-data"; /** * Will handle (in order): @@ -217,9 +219,17 @@ export class MysteryEncounterBattleStartCleanupPhase extends Phase { start() { super.start(); + // Lapse any residual flinches/endures but ignore all other turn-end battle tags + const includedLapseTags = [ BattlerTagType.FLINCHED, BattlerTagType.ENDURING ]; const field = this.scene.getField(true).filter(p => p.summonData); field.forEach(pokemon => { - pokemon.lapseTags(BattlerTagLapseType.TURN_END); + const tags = pokemon.summonData.tags; + tags.filter(t => includedLapseTags.includes(t.tagType) + && t.lapseTypes.includes(BattlerTagLapseType.TURN_END) + && !(t.lapse(pokemon, BattlerTagLapseType.TURN_END))).forEach(t => { + t.onRemove(pokemon); + tags.splice(tags.indexOf(t), 1); + }); }); // Remove any status tick phases @@ -228,7 +238,7 @@ export class MysteryEncounterBattleStartCleanupPhase extends Phase { } // The total number of Pokemon in the player's party that can legally fight - const legalPlayerPokemon = this.scene.getParty().filter(p => p.isAllowedInBattle()); + const legalPlayerPokemon = this.scene.getPokemonAllowedInBattle(); // The total number of legal player Pokemon that aren't currently on the field const legalPlayerPartyPokemon = legalPlayerPokemon.filter(p => !p.isActive(true)); if (!legalPlayerPokemon.length) { @@ -241,7 +251,7 @@ export class MysteryEncounterBattleStartCleanupPhase extends Phase { const playerField = this.scene.getPlayerField(); playerField.forEach((pokemon, i) => { if (!pokemon.isAllowedInBattle() && legalPlayerPartyPokemon.length > i) { - this.scene.unshiftPhase(new SwitchPhase(this.scene, i, true, false)); + this.scene.unshiftPhase(new SwitchPhase(this.scene, SwitchType.SWITCH, i, true, false)); } }); @@ -333,7 +343,7 @@ export class MysteryEncounterBattlePhase extends Phase { const doSummon = () => { scene.currentBattle.started = true; scene.playBgm(undefined); - scene.pbTray.showPbTray(scene.getParty()); + scene.pbTray.showPbTray(scene.getPlayerParty()); scene.pbTrayEnemy.showPbTray(scene.getEnemyParty()); const doTrainerSummon = () => { this.hideEnemyTrainer(); @@ -392,7 +402,7 @@ export class MysteryEncounterBattlePhase extends Phase { } } - const availablePartyMembers = scene.getParty().filter(p => !p.isFainted()); + const availablePartyMembers = scene.getPlayerParty().filter(p => p.isAllowedInBattle()); if (!availablePartyMembers[0].isOnField()) { scene.pushPhase(new SummonPhase(scene, 0)); @@ -407,6 +417,7 @@ export class MysteryEncounterBattlePhase extends Phase { } } else { if (availablePartyMembers.length > 1 && availablePartyMembers[1].isOnField()) { + scene.getPlayerField().forEach((pokemon) => pokemon.lapseTag(BattlerTagType.COMMANDED)); scene.pushPhase(new ReturnPhase(scene, 1)); } scene.pushPhase(new ToggleDoublePositionPhase(scene, false)); diff --git a/src/phases/new-biome-encounter-phase.ts b/src/phases/new-biome-encounter-phase.ts index 2a526a22ee2..910306b76ad 100644 --- a/src/phases/new-biome-encounter-phase.ts +++ b/src/phases/new-biome-encounter-phase.ts @@ -11,18 +11,18 @@ export class NewBiomeEncounterPhase extends NextEncounterPhase { doEncounter(): void { this.scene.playBgm(undefined, true); - for (const pokemon of this.scene.getParty()) { + for (const pokemon of this.scene.getPlayerParty()) { if (pokemon) { pokemon.resetBattleData(); } } - for (const pokemon of this.scene.getParty().filter(p => p.isOnField())) { + for (const pokemon of this.scene.getPlayerParty().filter(p => p.isOnField())) { applyAbAttrs(PostBiomeChangeAbAttr, pokemon, null); } const enemyField = this.scene.getEnemyField(); - const moveTargets: any[] = [this.scene.arenaEnemy, enemyField]; + const moveTargets: any[] = [ this.scene.arenaEnemy, enemyField ]; const mysteryEncounter = this.scene.currentBattle?.mysteryEncounter?.introVisuals; if (mysteryEncounter) { moveTargets.push(mysteryEncounter); diff --git a/src/phases/next-encounter-phase.ts b/src/phases/next-encounter-phase.ts index d63823e4167..e086ed4fe3e 100644 --- a/src/phases/next-encounter-phase.ts +++ b/src/phases/next-encounter-phase.ts @@ -13,7 +13,7 @@ export class NextEncounterPhase extends EncounterPhase { doEncounter(): void { this.scene.playBgm(undefined, true); - for (const pokemon of this.scene.getParty()) { + for (const pokemon of this.scene.getPlayerParty()) { if (pokemon) { pokemon.resetBattleData(); } @@ -23,7 +23,7 @@ export class NextEncounterPhase extends EncounterPhase { this.scene.arenaNextEnemy.setVisible(true); const enemyField = this.scene.getEnemyField(); - const moveTargets: any[] = [this.scene.arenaEnemy, this.scene.arenaNextEnemy, this.scene.currentBattle.trainer, enemyField, this.scene.lastEnemyTrainer]; + const moveTargets: any[] = [ this.scene.arenaEnemy, this.scene.arenaNextEnemy, this.scene.currentBattle.trainer, enemyField, this.scene.lastEnemyTrainer ]; const lastEncounterVisuals = this.scene.lastMysteryEncounter?.introVisuals; if (lastEncounterVisuals) { moveTargets.push(lastEncounterVisuals); diff --git a/src/phases/obtain-status-effect-phase.ts b/src/phases/obtain-status-effect-phase.ts index 93bf4cd41d5..01384b932cb 100644 --- a/src/phases/obtain-status-effect-phase.ts +++ b/src/phases/obtain-status-effect-phase.ts @@ -6,42 +6,38 @@ import { StatusEffect } from "#app/enums/status-effect"; import Pokemon from "#app/field/pokemon"; import { getPokemonNameWithAffix } from "#app/messages"; import { PokemonPhase } from "./pokemon-phase"; -import { PostTurnStatusEffectPhase } from "./post-turn-status-effect-phase"; export class ObtainStatusEffectPhase extends PokemonPhase { - private statusEffect: StatusEffect | undefined; - private cureTurn: integer | null; - private sourceText: string | null; - private sourcePokemon: Pokemon | null; + private statusEffect?: StatusEffect; + private turnsRemaining?: number; + private sourceText?: string | null; + private sourcePokemon?: Pokemon | null; - constructor(scene: BattleScene, battlerIndex: BattlerIndex, statusEffect?: StatusEffect, cureTurn?: integer | null, sourceText?: string, sourcePokemon?: Pokemon) { + constructor(scene: BattleScene, battlerIndex: BattlerIndex, statusEffect?: StatusEffect, turnsRemaining?: number, sourceText?: string | null, sourcePokemon?: Pokemon | null) { super(scene, battlerIndex); this.statusEffect = statusEffect; - this.cureTurn = cureTurn!; // TODO: is this bang correct? - this.sourceText = sourceText!; // TODO: is this bang correct? - this.sourcePokemon = sourcePokemon!; // For tracking which Pokemon caused the status effect // TODO: is this bang correct? + this.turnsRemaining = turnsRemaining; + this.sourceText = sourceText; + this.sourcePokemon = sourcePokemon; } start() { const pokemon = this.getPokemon(); - if (!pokemon?.status) { - if (pokemon?.trySetStatus(this.statusEffect, false, this.sourcePokemon)) { - if (this.cureTurn) { - pokemon.status!.cureTurn = this.cureTurn; // TODO: is this bang correct? + if (pokemon && !pokemon.status) { + if (pokemon.trySetStatus(this.statusEffect, false, this.sourcePokemon)) { + if (this.turnsRemaining) { + pokemon.status!.sleepTurnsRemaining = this.turnsRemaining; } pokemon.updateInfo(true); new CommonBattleAnim(CommonAnim.POISON + (this.statusEffect! - 1), pokemon).play(this.scene, false, () => { this.scene.queueMessage(getStatusEffectObtainText(this.statusEffect, getPokemonNameWithAffix(pokemon), this.sourceText ?? undefined)); - if (pokemon.status?.isPostTurn()) { - this.scene.pushPhase(new PostTurnStatusEffectPhase(this.scene, this.battlerIndex)); - } this.end(); }); return; } - } else if (pokemon.status.effect === this.statusEffect) { - this.scene.queueMessage(getStatusEffectOverlapText(this.statusEffect, getPokemonNameWithAffix(pokemon))); + } else if (pokemon.status?.effect === this.statusEffect) { + this.scene.queueMessage(getStatusEffectOverlapText(this.statusEffect ?? StatusEffect.NONE, getPokemonNameWithAffix(pokemon))); } this.end(); } diff --git a/src/phases/outdated-phase.ts b/src/phases/outdated-phase.ts deleted file mode 100644 index 4baf16d2f56..00000000000 --- a/src/phases/outdated-phase.ts +++ /dev/null @@ -1,13 +0,0 @@ -import BattleScene from "#app/battle-scene"; -import { Phase } from "#app/phase"; -import { Mode } from "#app/ui/ui"; - -export class OutdatedPhase extends Phase { - constructor(scene: BattleScene) { - super(scene); - } - - start(): void { - this.scene.ui.setMode(Mode.OUTDATED); - } -} diff --git a/src/phases/party-heal-phase.ts b/src/phases/party-heal-phase.ts index e6ee11202df..4841bf9a5b4 100644 --- a/src/phases/party-heal-phase.ts +++ b/src/phases/party-heal-phase.ts @@ -19,7 +19,7 @@ export class PartyHealPhase extends BattlePhase { this.scene.fadeOutBgm(1000, false); } this.scene.ui.fadeOut(1000).then(() => { - for (const pokemon of this.scene.getParty()) { + for (const pokemon of this.scene.getPlayerParty()) { pokemon.hp = pokemon.getMaxHp(); pokemon.resetStatus(); for (const move of pokemon.moveset) { diff --git a/src/phases/party-member-pokemon-phase.ts b/src/phases/party-member-pokemon-phase.ts index 2b6ca01261d..f2e2b23bfb2 100644 --- a/src/phases/party-member-pokemon-phase.ts +++ b/src/phases/party-member-pokemon-phase.ts @@ -18,7 +18,7 @@ export abstract class PartyMemberPokemonPhase extends FieldPhase { } getParty(): Pokemon[] { - return this.player ? this.scene.getParty() : this.scene.getEnemyParty(); + return this.player ? this.scene.getPlayerParty() : this.scene.getEnemyParty(); } getPokemon(): Pokemon { diff --git a/src/phases/party-status-cure-phase.ts b/src/phases/party-status-cure-phase.ts deleted file mode 100644 index e4903c7fc1f..00000000000 --- a/src/phases/party-status-cure-phase.ts +++ /dev/null @@ -1,48 +0,0 @@ -import BattleScene from "#app/battle-scene"; -import { Abilities } from "#app/enums/abilities"; -import Pokemon from "#app/field/pokemon"; -import { BattlePhase } from "./battle-phase"; -import { ShowAbilityPhase } from "./show-ability-phase"; - -/** - * Cures the party of all non-volatile status conditions, shows a message - * @param {BattleScene} scene The current scene - * @param {Pokemon} user The user of the move that cures the party - * @param {string} message The message that should be displayed - * @param {Abilities} abilityCondition Pokemon with this ability will not be affected ie. Soundproof - */ -export class PartyStatusCurePhase extends BattlePhase { - private user: Pokemon; - private message: string; - private abilityCondition: Abilities; - - constructor(scene: BattleScene, user: Pokemon, message: string, abilityCondition: Abilities) { - super(scene); - - this.user = user; - this.message = message; - this.abilityCondition = abilityCondition; - } - - start() { - super.start(); - for (const pokemon of this.scene.getParty()) { - if (!pokemon.isOnField() || pokemon === this.user) { - pokemon.resetStatus(false); - pokemon.updateInfo(true); - } else { - if (!pokemon.hasAbility(this.abilityCondition)) { - pokemon.resetStatus(); - pokemon.updateInfo(true); - } else { - // Manually show ability bar, since we're not hooked into the targeting system - pokemon.scene.unshiftPhase(new ShowAbilityPhase(pokemon.scene, pokemon.id, pokemon.getPassiveAbility()?.id === this.abilityCondition)); - } - } - } - if (this.message) { - this.scene.queueMessage(this.message); - } - this.end(); - } -} diff --git a/src/phases/pokemon-anim-phase.ts b/src/phases/pokemon-anim-phase.ts index 50a62837f9c..eb5431cbc56 100644 --- a/src/phases/pokemon-anim-phase.ts +++ b/src/phases/pokemon-anim-phase.ts @@ -1,9 +1,10 @@ import BattleScene from "#app/battle-scene"; import { SubstituteTag } from "#app/data/battler-tags"; -import { PokemonAnimType } from "#enums/pokemon-anim-type"; import Pokemon from "#app/field/pokemon"; import { BattlePhase } from "#app/phases/battle-phase"; - +import { isNullOrUndefined } from "#app/utils"; +import { PokemonAnimType } from "#enums/pokemon-anim-type"; +import { Species } from "#enums/species"; export class PokemonAnimPhase extends BattlePhase { @@ -26,26 +27,32 @@ export class PokemonAnimPhase extends BattlePhase { super.start(); switch (this.key) { - case PokemonAnimType.SUBSTITUTE_ADD: - this.doSubstituteAddAnim(); - break; - case PokemonAnimType.SUBSTITUTE_PRE_MOVE: - this.doSubstitutePreMoveAnim(); - break; - case PokemonAnimType.SUBSTITUTE_POST_MOVE: - this.doSubstitutePostMoveAnim(); - break; - case PokemonAnimType.SUBSTITUTE_REMOVE: - this.doSubstituteRemoveAnim(); - break; - default: - this.end(); + case PokemonAnimType.SUBSTITUTE_ADD: + this.doSubstituteAddAnim(); + break; + case PokemonAnimType.SUBSTITUTE_PRE_MOVE: + this.doSubstitutePreMoveAnim(); + break; + case PokemonAnimType.SUBSTITUTE_POST_MOVE: + this.doSubstitutePostMoveAnim(); + break; + case PokemonAnimType.SUBSTITUTE_REMOVE: + this.doSubstituteRemoveAnim(); + break; + case PokemonAnimType.COMMANDER_APPLY: + this.doCommanderApplyAnim(); + break; + case PokemonAnimType.COMMANDER_REMOVE: + this.doCommanderRemoveAnim(); + break; + default: + this.end(); } } - doSubstituteAddAnim(): void { + private doSubstituteAddAnim(): void { const substitute = this.pokemon.getTag(SubstituteTag); - if (substitute === null) { + if (isNullOrUndefined(substitute)) { return this.end(); } @@ -53,7 +60,7 @@ export class PokemonAnimPhase extends BattlePhase { const sprite = this.scene.addFieldSprite( this.pokemon.x + this.pokemon.getSprite().x, this.pokemon.y + this.pokemon.getSprite().y, - `pkmn${this.pokemon.isPlayer() ? "__back": ""}__sub` + `pkmn${this.pokemon.isPlayer() ? "__back" : ""}__sub` ); sprite.setOrigin(0.5, 1); this.scene.field.add(sprite); @@ -107,7 +114,7 @@ export class PokemonAnimPhase extends BattlePhase { }); } - doSubstitutePreMoveAnim(): void { + private doSubstitutePreMoveAnim(): void { if (this.fieldAssets.length !== 1) { return this.end(); } @@ -136,7 +143,7 @@ export class PokemonAnimPhase extends BattlePhase { }); } - doSubstitutePostMoveAnim(): void { + private doSubstitutePostMoveAnim(): void { if (this.fieldAssets.length !== 1) { return this.end(); } @@ -165,7 +172,7 @@ export class PokemonAnimPhase extends BattlePhase { }); } - doSubstituteRemoveAnim(): void { + private doSubstituteRemoveAnim(): void { if (this.fieldAssets.length !== 1) { return this.end(); } @@ -179,7 +186,7 @@ export class PokemonAnimPhase extends BattlePhase { const sprite = this.scene.addFieldSprite( subSprite.x, subSprite.y, - `pkmn${this.pokemon.isPlayer() ? "__back": ""}__sub` + `pkmn${this.pokemon.isPlayer() ? "__back" : ""}__sub` ); sprite.setOrigin(0.5, 1); this.scene.field.add(sprite); @@ -234,4 +241,125 @@ export class PokemonAnimPhase extends BattlePhase { } }); } + + private doCommanderApplyAnim(): void { + if (!this.scene.currentBattle?.double) { + return this.end(); + } + const dondozo = this.pokemon.getAlly(); + + if (dondozo?.species?.speciesId !== Species.DONDOZO) { + return this.end(); + } + + const tatsugiriX = this.pokemon.x + this.pokemon.getSprite().x; + const tatsugiriY = this.pokemon.y + this.pokemon.getSprite().y; + + const getSourceSprite = () => { + const sprite = this.scene.addPokemonSprite(this.pokemon, tatsugiriX, tatsugiriY, this.pokemon.getSprite().texture, this.pokemon.getSprite()!.frame.name, true); + [ "spriteColors", "fusionSpriteColors" ].map(k => sprite.pipelineData[k] = this.pokemon.getSprite().pipelineData[k]); + sprite.setPipelineData("spriteKey", this.pokemon.getBattleSpriteKey()); + sprite.setPipelineData("shiny", this.pokemon.shiny); + sprite.setPipelineData("variant", this.pokemon.variant); + sprite.setPipelineData("ignoreFieldPos", true); + sprite.setOrigin(0.5, 1); + this.pokemon.getSprite().on("animationupdate", (_anim, frame) => sprite.setFrame(frame.textureFrame)); + this.scene.field.add(sprite); + return sprite; + }; + + const sourceSprite = getSourceSprite(); + + this.pokemon.setVisible(false); + + const sourceFpOffset = this.pokemon.getFieldPositionOffset(); + const dondozoFpOffset = dondozo.getFieldPositionOffset(); + + this.scene.playSound("se/pb_throw"); + + this.scene.tweens.add({ + targets: sourceSprite, + duration: 375, + scale: 0.5, + x: { value: tatsugiriX + (dondozoFpOffset[0] - sourceFpOffset[0]) / 2, ease: "Linear" }, + y: { value: (this.pokemon.isPlayer() ? 100 : 65) + sourceFpOffset[1], ease: "Sine.easeOut" }, + onComplete: () => { + this.scene.field.bringToTop(dondozo); + this.scene.tweens.add({ + targets: sourceSprite, + duration: 375, + scale: 0.01, + x: { value: dondozo.x, ease: "Linear" }, + y: { value: dondozo.y + dondozo.height / 2, ease: "Sine.easeIn" }, + onComplete: () => { + sourceSprite.destroy(); + this.scene.playSound("battle_anims/PRSFX- Liquidation1.wav"); + this.scene.tweens.add({ + targets: dondozo, + duration: 250, + ease: "Sine.easeInOut", + scale: 0.85, + yoyo: true, + onComplete: () => this.end() + }); + } + }); + } + }); + } + + private doCommanderRemoveAnim(): void { + // Note: unlike the other Commander animation, this is played through the + // Dondozo instead of the Tatsugiri. + const tatsugiri = this.pokemon.getAlly(); + if (isNullOrUndefined(tatsugiri)) { + console.warn("Aborting COMMANDER_REMOVE anim: Tatsugiri is undefined"); + return this.end(); + } + + const tatsuSprite = this.scene.addPokemonSprite( + tatsugiri, + this.pokemon.x + this.pokemon.getSprite().x, + this.pokemon.y + this.pokemon.getSprite().y + this.pokemon.height / 2, + tatsugiri.getSprite().texture, + tatsugiri.getSprite()!.frame.name, + true + ); + [ "spriteColors", "fusionSpriteColors" ].map(k => tatsuSprite.pipelineData[k] = tatsugiri.getSprite().pipelineData[k]); + tatsuSprite.setPipelineData("spriteKey", tatsugiri.getBattleSpriteKey()); + tatsuSprite.setPipelineData("shiny", tatsugiri.shiny); + tatsuSprite.setPipelineData("variant", tatsugiri.variant); + tatsuSprite.setPipelineData("ignoreFieldPos", true); + this.pokemon.getSprite().on("animationupdate", (_anim, frame) => tatsuSprite.setFrame(frame.textureFrame)); + + tatsuSprite.setOrigin(0.5, 1); + tatsuSprite.setScale(0.01); + + this.scene.field.add(tatsuSprite); + this.scene.field.bringToTop(this.pokemon); + tatsuSprite.setVisible(true); + + this.scene.tweens.add({ + targets: this.pokemon, + duration: 250, + ease: "Sine.easeInOut", + scale: 1.15, + yoyo: true, + onComplete: () => { + this.scene.playSound("battle_anims/PRSFX- Liquidation4.wav"); + this.scene.tweens.add({ + targets: tatsuSprite, + duration: 500, + scale: 1, + x: { value: tatsugiri.x + tatsugiri.getSprite().x, ease: "Linear" }, + y: { value: tatsugiri.y + tatsugiri.getSprite().y, ease: "Sine.easeIn" }, + onComplete: () => { + tatsugiri.setVisible(true); + tatsuSprite.destroy(); + this.end(); + } + }); + } + }); + } } diff --git a/src/phases/pokemon-heal-phase.ts b/src/phases/pokemon-heal-phase.ts index 49db2641e98..dc0bd235bb5 100644 --- a/src/phases/pokemon-heal-phase.ts +++ b/src/phases/pokemon-heal-phase.ts @@ -10,6 +10,8 @@ import { HealAchv } from "#app/system/achv"; import i18next from "i18next"; import * as Utils from "#app/utils"; import { CommonAnimPhase } from "./common-anim-phase"; +import { BattlerTagType } from "#app/enums/battler-tag-type"; +import { HealBlockTag } from "#app/data/battler-tags"; export class PokemonHealPhase extends CommonAnimPhase { private hpHealed: integer; @@ -44,15 +46,19 @@ export class PokemonHealPhase extends CommonAnimPhase { const pokemon = this.getPokemon(); if (!pokemon.isOnField() || (!this.revive && !pokemon.isActive())) { - super.end(); - return; + return super.end(); } const hasMessage = !!this.message; const healOrDamage = (!pokemon.isFullHp() || this.hpHealed < 0); + const healBlock = pokemon.getTag(BattlerTagType.HEAL_BLOCK) as HealBlockTag; let lastStatusEffect = StatusEffect.NONE; - if (healOrDamage) { + if (healBlock && this.hpHealed > 0) { + this.scene.queueMessage(healBlock.onActivation(pokemon)); + this.message = null; + return super.end(); + } else if (healOrDamage) { const hpRestoreMultiplier = new Utils.IntegerHolder(1); if (!this.revive) { this.scene.applyModifiers(HealingBoosterModifier, this.player, hpRestoreMultiplier); diff --git a/src/phases/post-summon-phase.ts b/src/phases/post-summon-phase.ts index e7f6c6ea3db..644a6235a42 100644 --- a/src/phases/post-summon-phase.ts +++ b/src/phases/post-summon-phase.ts @@ -1,12 +1,11 @@ import BattleScene from "#app/battle-scene"; import { BattlerIndex } from "#app/battle"; -import { applyPostSummonAbAttrs, PostSummonAbAttr } from "#app/data/ability"; +import { applyAbAttrs, applyPostSummonAbAttrs, CommanderAbAttr, PostSummonAbAttr } from "#app/data/ability"; import { ArenaTrapTag } from "#app/data/arena-tag"; import { StatusEffect } from "#app/enums/status-effect"; import { PokemonPhase } from "./pokemon-phase"; import { MysteryEncounterPostSummonTag } from "#app/data/battler-tags"; import { BattlerTagType } from "#enums/battler-tag-type"; -import { BattleType } from "#app/battle"; export class PostSummonPhase extends PokemonPhase { constructor(scene: BattleScene, battlerIndex: BattlerIndex) { @@ -19,15 +18,18 @@ export class PostSummonPhase extends PokemonPhase { const pokemon = this.getPokemon(); if (pokemon.status?.effect === StatusEffect.TOXIC) { - pokemon.status.turnCount = 0; + pokemon.status.toxicTurnCount = 0; } - this.scene.arena.applyTags(ArenaTrapTag, pokemon); + this.scene.arena.applyTags(ArenaTrapTag, false, pokemon); // If this is mystery encounter and has post summon phase tag, apply post summon effects - if (this.scene.currentBattle.battleType === BattleType.MYSTERY_ENCOUNTER && pokemon.findTags(t => t instanceof MysteryEncounterPostSummonTag).length > 0) { + if (this.scene.currentBattle.isBattleMysteryEncounter() && pokemon.findTags(t => t instanceof MysteryEncounterPostSummonTag).length > 0) { pokemon.lapseTag(BattlerTagType.MYSTERY_ENCOUNTER_POST_SUMMON); } applyPostSummonAbAttrs(PostSummonAbAttr, pokemon).then(() => this.end()); + + const field = pokemon.isPlayer() ? this.scene.getPlayerField() : this.scene.getEnemyField(); + field.forEach((p) => applyAbAttrs(CommanderAbAttr, p, null, false)); } } diff --git a/src/phases/post-turn-status-effect-phase.ts b/src/phases/post-turn-status-effect-phase.ts index 285bbddde88..08e4d7cb952 100644 --- a/src/phases/post-turn-status-effect-phase.ts +++ b/src/phases/post-turn-status-effect-phase.ts @@ -1,6 +1,6 @@ import BattleScene from "#app/battle-scene"; import { BattlerIndex } from "#app/battle"; -import { applyAbAttrs, BlockNonDirectDamageAbAttr, BlockStatusDamageAbAttr, ReduceBurnDamageAbAttr } from "#app/data/ability"; +import { applyAbAttrs, applyPostDamageAbAttrs, BlockNonDirectDamageAbAttr, BlockStatusDamageAbAttr, PostDamageAbAttr, ReduceBurnDamageAbAttr } from "#app/data/ability"; import { CommonBattleAnim, CommonAnim } from "#app/data/battle-anims"; import { getStatusEffectActivationText } from "#app/data/status-effect"; import { BattleSpec } from "#app/enums/battle-spec"; @@ -26,21 +26,22 @@ export class PostTurnStatusEffectPhase extends PokemonPhase { this.scene.queueMessage(getStatusEffectActivationText(pokemon.status.effect, getPokemonNameWithAffix(pokemon))); const damage = new Utils.NumberHolder(0); switch (pokemon.status.effect) { - case StatusEffect.POISON: - damage.value = Math.max(pokemon.getMaxHp() >> 3, 1); - break; - case StatusEffect.TOXIC: - damage.value = Math.max(Math.floor((pokemon.getMaxHp() / 16) * pokemon.status.turnCount), 1); - break; - case StatusEffect.BURN: - damage.value = Math.max(pokemon.getMaxHp() >> 4, 1); - applyAbAttrs(ReduceBurnDamageAbAttr, pokemon, null, false, damage); - break; + case StatusEffect.POISON: + damage.value = Math.max(pokemon.getMaxHp() >> 3, 1); + break; + case StatusEffect.TOXIC: + damage.value = Math.max(Math.floor((pokemon.getMaxHp() / 16) * pokemon.status.toxicTurnCount), 1); + break; + case StatusEffect.BURN: + damage.value = Math.max(pokemon.getMaxHp() >> 4, 1); + applyAbAttrs(ReduceBurnDamageAbAttr, pokemon, null, false, damage); + break; } if (damage.value) { // Set preventEndure flag to avoid pokemon surviving thanks to focus band, sturdy, endure ... this.scene.damageNumberHandler.add(this.getPokemon(), pokemon.damage(damage.value, false, true)); pokemon.updateInfo(); + applyPostDamageAbAttrs(PostDamageAbAttr, pokemon, damage.value, pokemon.hasPassive(), false, []); } new CommonBattleAnim(CommonAnim.POISON + (pokemon.status.effect - 1), pokemon).play(this.scene, false, () => this.end()); } else { diff --git a/src/phases/quiet-form-change-phase.ts b/src/phases/quiet-form-change-phase.ts index dde500e156a..6c84c0d1a8a 100644 --- a/src/phases/quiet-form-change-phase.ts +++ b/src/phases/quiet-form-change-phase.ts @@ -3,6 +3,7 @@ import { SemiInvulnerableTag } from "#app/data/battler-tags"; import { SpeciesFormChange, getSpeciesFormChangeMessage } from "#app/data/pokemon-forms"; import { getTypeRgb } from "#app/data/type"; import { BattleSpec } from "#app/enums/battle-spec"; +import { BattlerTagType } from "#app/enums/battler-tag-type"; import Pokemon, { EnemyPokemon } from "#app/field/pokemon"; import { getPokemonNameWithAffix } from "#app/messages"; import { BattlePhase } from "./battle-phase"; @@ -28,10 +29,14 @@ export class QuietFormChangePhase extends BattlePhase { const preName = getPokemonNameWithAffix(this.pokemon); - if (!this.pokemon.isOnField() || this.pokemon.getTag(SemiInvulnerableTag)) { - this.pokemon.changeForm(this.formChange).then(() => { - this.scene.ui.showText(getSpeciesFormChangeMessage(this.pokemon, this.formChange, preName), null, () => this.end(), 1500); - }); + if (!this.pokemon.isOnField() || this.pokemon.getTag(SemiInvulnerableTag) || this.pokemon.isFainted()) { + if (this.pokemon.isPlayer() || this.pokemon.isActive()) { + this.pokemon.changeForm(this.formChange).then(() => { + this.scene.ui.showText(getSpeciesFormChangeMessage(this.pokemon, this.formChange, preName), null, () => this.end(), 1500); + }); + } else { + this.end(); + } return; } @@ -113,6 +118,7 @@ export class QuietFormChangePhase extends BattlePhase { } end(): void { + this.pokemon.findAndRemoveTags(t => t.tagType === BattlerTagType.AUTOTOMIZED); if (this.pokemon.scene?.currentBattle.battleSpec === BattleSpec.FINAL_BOSS && this.pokemon instanceof EnemyPokemon) { this.scene.playBgm(); this.scene.unshiftPhase(new PokemonHealPhase(this.scene, this.pokemon.getBattlerIndex(), this.pokemon.getMaxHp(), null, false, false, false, true)); diff --git a/src/phases/return-phase.ts b/src/phases/return-phase.ts index 19c73816b36..eb587201585 100644 --- a/src/phases/return-phase.ts +++ b/src/phases/return-phase.ts @@ -1,10 +1,11 @@ import BattleScene from "#app/battle-scene"; import { SpeciesFormChangeActiveTrigger } from "#app/data/pokemon-forms"; +import { SwitchType } from "#enums/switch-type"; import { SwitchSummonPhase } from "./switch-summon-phase"; export class ReturnPhase extends SwitchSummonPhase { constructor(scene: BattleScene, fieldIndex: integer) { - super(scene, fieldIndex, -1, true, false); + super(scene, SwitchType.SWITCH, fieldIndex, -1, true); } switchAndSummon(): void { diff --git a/src/phases/select-biome-phase.ts b/src/phases/select-biome-phase.ts index fe9b5b3996b..817cd7bcd3d 100644 --- a/src/phases/select-biome-phase.ts +++ b/src/phases/select-biome-phase.ts @@ -1,5 +1,5 @@ import BattleScene from "#app/battle-scene"; -import { biomeLinks, getBiomeName } from "#app/data/biomes"; +import { biomeLinks, getBiomeName } from "#app/data/balance/biomes"; import { Biome } from "#app/enums/biome"; import { MoneyInterestModifier, MapModifier } from "#app/modifier/modifier"; import { OptionSelectItem } from "#app/ui/abstact-option-select-ui-handler"; @@ -45,7 +45,7 @@ export class SelectBiomePhase extends BattlePhase { let biomeChoices: Biome[] = []; this.scene.executeWithSeedOffset(() => { biomeChoices = (!Array.isArray(biomeLinks[currentBiome]) - ? [biomeLinks[currentBiome] as Biome] + ? [ biomeLinks[currentBiome] as Biome ] : biomeLinks[currentBiome] as (Biome | [Biome, integer])[]) .filter((b, i) => !Array.isArray(b) || !Utils.randSeedInt(b[1])) .map(b => Array.isArray(b) ? b[0] : b); diff --git a/src/phases/select-modifier-phase.ts b/src/phases/select-modifier-phase.ts index 39a0da1167f..19e1ccc12ae 100644 --- a/src/phases/select-modifier-phase.ts +++ b/src/phases/select-modifier-phase.ts @@ -1,7 +1,7 @@ import BattleScene from "#app/battle-scene"; import { ModifierTier } from "#app/modifier/modifier-tier"; import { regenerateModifierPoolThresholds, ModifierTypeOption, ModifierType, getPlayerShopModifierTypeOptionsForWave, PokemonModifierType, FusePokemonModifierType, PokemonMoveModifierType, TmModifierType, RememberMoveModifierType, PokemonPpRestoreModifierType, PokemonPpUpModifierType, ModifierPoolType, getPlayerModifierTypeOptions } from "#app/modifier/modifier-type"; -import { ExtraModifierModifier, Modifier, PokemonHeldItemModifier } from "#app/modifier/modifier"; +import { ExtraModifierModifier, HealShopCostModifier, Modifier, PokemonHeldItemModifier, TempExtraModifierModifier } from "#app/modifier/modifier"; import ModifierSelectUiHandler, { SHOP_OPTIONS_ROW_LIMIT } from "#app/ui/modifier-select-ui-handler"; import PartyUiHandler, { PartyUiMode, PartyOption } from "#app/ui/party-ui-handler"; import { Mode } from "#app/ui/ui"; @@ -10,35 +10,42 @@ import * as Utils from "#app/utils"; import { BattlePhase } from "./battle-phase"; import Overrides from "#app/overrides"; import { CustomModifierSettings } from "#app/modifier/modifier-type"; -import { isNullOrUndefined } from "#app/utils"; +import { isNullOrUndefined, NumberHolder } from "#app/utils"; export class SelectModifierPhase extends BattlePhase { private rerollCount: integer; private modifierTiers?: ModifierTier[]; private customModifierSettings?: CustomModifierSettings; + private isCopy: boolean; - constructor(scene: BattleScene, rerollCount: integer = 0, modifierTiers?: ModifierTier[], customModifierSettings?: CustomModifierSettings) { + private typeOptions: ModifierTypeOption[]; + + constructor(scene: BattleScene, rerollCount: integer = 0, modifierTiers?: ModifierTier[], customModifierSettings?: CustomModifierSettings, isCopy: boolean = false) { super(scene); this.rerollCount = rerollCount; this.modifierTiers = modifierTiers; this.customModifierSettings = customModifierSettings; + this.isCopy = isCopy; } start() { super.start(); - if (!this.rerollCount) { + if (!this.rerollCount && !this.isCopy) { this.updateSeed(); - } else { + } else if (this.rerollCount) { this.scene.reroll = false; } - const party = this.scene.getParty(); - regenerateModifierPoolThresholds(party, this.getPoolType(), this.rerollCount); + const party = this.scene.getPlayerParty(); + if (!this.isCopy) { + regenerateModifierPoolThresholds(party, this.getPoolType(), this.rerollCount); + } const modifierCount = new Utils.IntegerHolder(3); if (this.isPlayer()) { this.scene.applyModifiers(ExtraModifierModifier, true, modifierCount); + this.scene.applyModifiers(TempExtraModifierModifier, true, modifierCount); } // If custom modifiers are specified, overrides default item count @@ -54,7 +61,7 @@ export class SelectModifierPhase extends BattlePhase { } } - const typeOptions: ModifierTypeOption[] = this.getModifierTypeOptions(modifierCount.value); + this.typeOptions = this.getModifierTypeOptions(modifierCount.value); const modifierSelectCallback = (rowCursor: integer, cursor: integer) => { if (rowCursor < 0 || cursor < 0) { @@ -63,78 +70,86 @@ export class SelectModifierPhase extends BattlePhase { this.scene.ui.revertMode(); this.scene.ui.setMode(Mode.MESSAGE); super.end(); - }, () => this.scene.ui.setMode(Mode.MODIFIER_SELECT, this.isPlayer(), typeOptions, modifierSelectCallback, this.getRerollCost(typeOptions, this.scene.lockModifierTiers))); + }, () => this.scene.ui.setMode(Mode.MODIFIER_SELECT, this.isPlayer(), this.typeOptions, modifierSelectCallback, this.getRerollCost(this.scene.lockModifierTiers))); }); return false; } let modifierType: ModifierType; let cost: integer; + const rerollCost = this.getRerollCost(this.scene.lockModifierTiers); switch (rowCursor) { - case 0: - switch (cursor) { case 0: - const rerollCost = this.getRerollCost(typeOptions, this.scene.lockModifierTiers); - if (rerollCost < 0 || this.scene.money < rerollCost) { - this.scene.ui.playError(); - return false; - } else { - this.scene.reroll = true; - this.scene.unshiftPhase(new SelectModifierPhase(this.scene, this.rerollCount + 1, typeOptions.map(o => o.type?.tier).filter(t => t !== undefined) as ModifierTier[])); + switch (cursor) { + case 0: + if (rerollCost < 0 || this.scene.money < rerollCost) { + this.scene.ui.playError(); + return false; + } else { + this.scene.reroll = true; + this.scene.unshiftPhase(new SelectModifierPhase(this.scene, this.rerollCount + 1, this.typeOptions.map(o => o.type?.tier).filter(t => t !== undefined) as ModifierTier[])); + this.scene.ui.clearText(); + this.scene.ui.setMode(Mode.MESSAGE).then(() => super.end()); + if (!Overrides.WAIVE_ROLL_FEE_OVERRIDE) { + this.scene.money -= rerollCost; + this.scene.updateMoneyText(); + this.scene.animateMoneyChanged(false); + } + this.scene.playSound("se/buy"); + } + break; + case 1: + this.scene.ui.setModeWithoutClear(Mode.PARTY, PartyUiMode.MODIFIER_TRANSFER, -1, (fromSlotIndex: integer, itemIndex: integer, itemQuantity: integer, toSlotIndex: integer) => { + if (toSlotIndex !== undefined && fromSlotIndex < 6 && toSlotIndex < 6 && fromSlotIndex !== toSlotIndex && itemIndex > -1) { + const itemModifiers = this.scene.findModifiers(m => m instanceof PokemonHeldItemModifier + && m.isTransferable && m.pokemonId === party[fromSlotIndex].id) as PokemonHeldItemModifier[]; + const itemModifier = itemModifiers[itemIndex]; + this.scene.tryTransferHeldItemModifier(itemModifier, party[toSlotIndex], true, itemQuantity, undefined, undefined, false); + } else { + this.scene.ui.setMode(Mode.MODIFIER_SELECT, this.isPlayer(), this.typeOptions, modifierSelectCallback, this.getRerollCost(this.scene.lockModifierTiers)); + } + }, PartyUiHandler.FilterItemMaxStacks); + break; + case 2: + this.scene.ui.setModeWithoutClear(Mode.PARTY, PartyUiMode.CHECK, -1, () => { + this.scene.ui.setMode(Mode.MODIFIER_SELECT, this.isPlayer(), this.typeOptions, modifierSelectCallback, this.getRerollCost(this.scene.lockModifierTiers)); + }); + break; + case 3: + if (rerollCost < 0) { + // Reroll lock button is also disabled when reroll is disabled + this.scene.ui.playError(); + return false; + } + this.scene.lockModifierTiers = !this.scene.lockModifierTiers; + const uiHandler = this.scene.ui.getHandler() as ModifierSelectUiHandler; + uiHandler.setRerollCost(this.getRerollCost(this.scene.lockModifierTiers)); + uiHandler.updateLockRaritiesText(); + uiHandler.updateRerollCostText(); + return false; + } + return true; + case 1: + if (this.typeOptions.length === 0) { this.scene.ui.clearText(); - this.scene.ui.setMode(Mode.MESSAGE).then(() => super.end()); - if (!Overrides.WAIVE_ROLL_FEE_OVERRIDE) { - this.scene.money -= rerollCost; - this.scene.updateMoneyText(); - this.scene.animateMoneyChanged(false); - } - this.scene.playSound("se/buy"); + this.scene.ui.setMode(Mode.MESSAGE); + super.end(); + return true; + } + if (this.typeOptions[cursor].type) { + modifierType = this.typeOptions[cursor].type; } break; - case 1: - this.scene.ui.setModeWithoutClear(Mode.PARTY, PartyUiMode.MODIFIER_TRANSFER, -1, (fromSlotIndex: integer, itemIndex: integer, itemQuantity: integer, toSlotIndex: integer) => { - if (toSlotIndex !== undefined && fromSlotIndex < 6 && toSlotIndex < 6 && fromSlotIndex !== toSlotIndex && itemIndex > -1) { - const itemModifiers = this.scene.findModifiers(m => m instanceof PokemonHeldItemModifier - && m.isTransferrable && m.pokemonId === party[fromSlotIndex].id) as PokemonHeldItemModifier[]; - const itemModifier = itemModifiers[itemIndex]; - this.scene.tryTransferHeldItemModifier(itemModifier, party[toSlotIndex], true, itemQuantity); - } else { - this.scene.ui.setMode(Mode.MODIFIER_SELECT, this.isPlayer(), typeOptions, modifierSelectCallback, this.getRerollCost(typeOptions, this.scene.lockModifierTiers)); - } - }, PartyUiHandler.FilterItemMaxStacks); + default: + const shopOptions = getPlayerShopModifierTypeOptionsForWave(this.scene.currentBattle.waveIndex, this.scene.getWaveMoneyAmount(1)); + const shopOption = shopOptions[rowCursor > 2 || shopOptions.length <= SHOP_OPTIONS_ROW_LIMIT ? cursor : cursor + SHOP_OPTIONS_ROW_LIMIT]; + if (shopOption.type) { + modifierType = shopOption.type; + } + // Apply Black Sludge to healing item cost + const healingItemCost = new NumberHolder(shopOption.cost); + this.scene.applyModifier(HealShopCostModifier, true, healingItemCost); + cost = healingItemCost.value; break; - case 2: - this.scene.ui.setModeWithoutClear(Mode.PARTY, PartyUiMode.CHECK, -1, () => { - this.scene.ui.setMode(Mode.MODIFIER_SELECT, this.isPlayer(), typeOptions, modifierSelectCallback, this.getRerollCost(typeOptions, this.scene.lockModifierTiers)); - }); - break; - case 3: - this.scene.lockModifierTiers = !this.scene.lockModifierTiers; - const uiHandler = this.scene.ui.getHandler() as ModifierSelectUiHandler; - uiHandler.setRerollCost(this.getRerollCost(typeOptions, this.scene.lockModifierTiers)); - uiHandler.updateLockRaritiesText(); - uiHandler.updateRerollCostText(); - return false; - } - return true; - case 1: - if (typeOptions.length === 0) { - this.scene.ui.clearText(); - this.scene.ui.setMode(Mode.MESSAGE); - super.end(); - return true; - } - if (typeOptions[cursor].type) { - modifierType = typeOptions[cursor].type; - } - break; - default: - const shopOptions = getPlayerShopModifierTypeOptionsForWave(this.scene.currentBattle.waveIndex, this.scene.getWaveMoneyAmount(1)); - const shopOption = shopOptions[rowCursor > 2 || shopOptions.length <= SHOP_OPTIONS_ROW_LIMIT ? cursor : cursor + SHOP_OPTIONS_ROW_LIMIT]; - if (shopOption.type) { - modifierType = shopOption.type; - } - cost = shopOption.cost; - break; } if (cost! && (this.scene.money < cost) && !Overrides.WAIVE_ROLL_FEE_OVERRIDE) { // TODO: is the bang on cost correct? @@ -143,8 +158,16 @@ export class SelectModifierPhase extends BattlePhase { } const applyModifier = (modifier: Modifier, playSound: boolean = false) => { - const result = this.scene.addModifier(modifier, false, playSound); - if (cost) { + const result = this.scene.addModifier(modifier, false, playSound, undefined, undefined, cost); + // Queue a copy of this phase when applying a TM or Memory Mushroom. + // If the player selects either of these, then escapes out of consuming them, + // they are returned to a shop in the same state. + if (modifier.type instanceof RememberMoveModifierType || + modifier.type instanceof TmModifierType) { + this.scene.unshiftPhase(this.copy()); + } + + if (cost && !(modifier.type instanceof RememberMoveModifierType)) { result.then(success => { if (success) { if (!Overrides.WAIVE_ROLL_FEE_OVERRIDE) { @@ -181,7 +204,7 @@ export class SelectModifierPhase extends BattlePhase { applyModifier(modifier, true); }); } else { - this.scene.ui.setMode(Mode.MODIFIER_SELECT, this.isPlayer(), typeOptions, modifierSelectCallback, this.getRerollCost(typeOptions, this.scene.lockModifierTiers)); + this.scene.ui.setMode(Mode.MODIFIER_SELECT, this.isPlayer(), this.typeOptions, modifierSelectCallback, this.getRerollCost(this.scene.lockModifierTiers)); } }, modifierType.selectFilter); } else { @@ -208,7 +231,7 @@ export class SelectModifierPhase extends BattlePhase { applyModifier(modifier!, true); // TODO: is the bang correct? }); } else { - this.scene.ui.setMode(Mode.MODIFIER_SELECT, this.isPlayer(), typeOptions, modifierSelectCallback, this.getRerollCost(typeOptions, this.scene.lockModifierTiers)); + this.scene.ui.setMode(Mode.MODIFIER_SELECT, this.isPlayer(), this.typeOptions, modifierSelectCallback, this.getRerollCost(this.scene.lockModifierTiers)); } }, pokemonModifierType.selectFilter, modifierType instanceof PokemonMoveModifierType ? (modifierType as PokemonMoveModifierType).moveSelectFilter : undefined, tmMoveId, isPpRestoreModifier); } @@ -218,7 +241,7 @@ export class SelectModifierPhase extends BattlePhase { return !cost!;// TODO: is the bang correct? }; - this.scene.ui.setMode(Mode.MODIFIER_SELECT, this.isPlayer(), typeOptions, modifierSelectCallback, this.getRerollCost(typeOptions, this.scene.lockModifierTiers)); + this.scene.ui.setMode(Mode.MODIFIER_SELECT, this.isPlayer(), this.typeOptions, modifierSelectCallback, this.getRerollCost(this.scene.lockModifierTiers)); } updateSeed(): void { @@ -229,13 +252,13 @@ export class SelectModifierPhase extends BattlePhase { return true; } - getRerollCost(typeOptions: ModifierTypeOption[], lockRarities: boolean): number { + getRerollCost(lockRarities: boolean): number { let baseValue = 0; if (Overrides.WAIVE_ROLL_FEE_OVERRIDE) { return baseValue; } else if (lockRarities) { - const tierValues = [50, 125, 300, 750, 2000]; - for (const opt of typeOptions) { + const tierValues = [ 50, 125, 300, 750, 2000 ]; + for (const opt of this.typeOptions) { baseValue += tierValues[opt.type.tier ?? 0]; } } else { @@ -244,15 +267,21 @@ export class SelectModifierPhase extends BattlePhase { let multiplier = 1; if (!isNullOrUndefined(this.customModifierSettings?.rerollMultiplier)) { - if (this.customModifierSettings!.rerollMultiplier! < 0) { + if (this.customModifierSettings.rerollMultiplier < 0) { // Completely overrides reroll cost to -1 and early exits return -1; } // Otherwise, continue with custom multiplier - multiplier = this.customModifierSettings!.rerollMultiplier!; + multiplier = this.customModifierSettings.rerollMultiplier; } - return Math.min(Math.ceil(this.scene.currentBattle.waveIndex / 10) * baseValue * Math.pow(2, this.rerollCount) * multiplier, Number.MAX_SAFE_INTEGER); + + const baseMultiplier = Math.min(Math.ceil(this.scene.currentBattle.waveIndex / 10) * baseValue * (2 ** this.rerollCount) * multiplier, Number.MAX_SAFE_INTEGER); + + // Apply Black Sludge to reroll cost + const modifiedRerollCost = new NumberHolder(baseMultiplier); + this.scene.applyModifier(HealShopCostModifier, true, modifiedRerollCost); + return modifiedRerollCost.value; } getPoolType(): ModifierPoolType { @@ -260,7 +289,17 @@ export class SelectModifierPhase extends BattlePhase { } getModifierTypeOptions(modifierCount: integer): ModifierTypeOption[] { - return getPlayerModifierTypeOptions(modifierCount, this.scene.getParty(), this.scene.lockModifierTiers ? this.modifierTiers : undefined, this.customModifierSettings); + return getPlayerModifierTypeOptions(modifierCount, this.scene.getPlayerParty(), this.scene.lockModifierTiers ? this.modifierTiers : undefined, this.customModifierSettings); + } + + copy(): SelectModifierPhase { + return new SelectModifierPhase( + this.scene, + this.rerollCount, + this.modifierTiers, + { guaranteedModifierTypeOptions: this.typeOptions, rerollMultiplier: this.customModifierSettings?.rerollMultiplier, allowLuckUpgrades: false }, + true + ); } addModifier(modifier: Modifier): Promise { diff --git a/src/phases/select-starter-phase.ts b/src/phases/select-starter-phase.ts index cd3c112549c..2273ab1cd3c 100644 --- a/src/phases/select-starter-phase.ts +++ b/src/phases/select-starter-phase.ts @@ -3,16 +3,15 @@ import { applyChallenges, ChallengeType } from "#app/data/challenge"; import { Gender } from "#app/data/gender"; import { SpeciesFormChangeMoveLearnedTrigger } from "#app/data/pokemon-forms"; import { getPokemonSpecies } from "#app/data/pokemon-species"; -import { Species } from "#app/enums/species"; -import { PlayerPokemon } from "#app/field/pokemon"; -import { overrideModifiers, overrideHeldItems } from "#app/modifier/modifier"; +import { overrideHeldItems, overrideModifiers } from "#app/modifier/modifier"; +import Overrides from "#app/overrides"; import { Phase } from "#app/phase"; +import { TitlePhase } from "#app/phases/title-phase"; import { SaveSlotUiMode } from "#app/ui/save-slot-select-ui-handler"; import { Starter } from "#app/ui/starter-select-ui-handler"; import { Mode } from "#app/ui/ui"; +import { Species } from "#enums/species"; import SoundFade from "phaser3-rex-plugins/plugins/soundfade"; -import { TitlePhase } from "./title-phase"; -import Overrides from "#app/overrides"; export class SelectStarterPhase extends Phase { @@ -44,7 +43,7 @@ export class SelectStarterPhase extends Phase { * @param starters {@linkcode Pokemon} with which to start the first battle */ initBattle(starters: Starter[]) { - const party = this.scene.getParty(); + const party = this.scene.getPlayerParty(); const loadPokemonAssets: Promise[] = []; starters.forEach((starter: Starter, i: integer) => { if (!i && Overrides.STARTER_SPECIES_OVERRIDE) { @@ -80,7 +79,7 @@ export class SelectStarterPhase extends Phase { starterPokemon.nickname = starter.nickname; } - if (this.scene.gameMode.isSplicedOnly) { + if (this.scene.gameMode.isSplicedOnly || Overrides.STARTER_FUSION_OVERRIDE) { starterPokemon.generateFusionSpecies(true); } starterPokemon.setVisible(false); @@ -103,7 +102,7 @@ export class SelectStarterPhase extends Phase { this.scene.sessionPlayTime = 0; this.scene.lastSavePlayTime = 0; // Ensures Keldeo (or any future Pokemon that have this type of form change) starts in the correct form - this.scene.getParty().forEach((p: PlayerPokemon) => { + this.scene.getPlayerParty().forEach((p) => { this.scene.triggerPokemonFormChange(p, SpeciesFormChangeMoveLearnedTrigger); }); this.end(); diff --git a/src/phases/select-target-phase.ts b/src/phases/select-target-phase.ts index 716d2737a6c..6f11f984c4b 100644 --- a/src/phases/select-target-phase.ts +++ b/src/phases/select-target-phase.ts @@ -4,6 +4,8 @@ import { Command } from "#app/ui/command-ui-handler"; import { Mode } from "#app/ui/ui"; import { CommandPhase } from "./command-phase"; import { PokemonPhase } from "./pokemon-phase"; +import i18next from "#app/plugins/i18n"; +import { allMoves } from "#app/data/move"; export class SelectTargetPhase extends PokemonPhase { constructor(scene: BattleScene, fieldIndex: integer) { @@ -17,6 +19,14 @@ export class SelectTargetPhase extends PokemonPhase { const move = turnCommand?.move?.move; this.scene.ui.setMode(Mode.TARGET_SELECT, this.fieldIndex, move, (targets: BattlerIndex[]) => { this.scene.ui.setMode(Mode.MESSAGE); + const fieldSide = this.scene.getField(); + const user = fieldSide[this.fieldIndex]; + const moveObject = allMoves[move!]; + if (moveObject && user.isMoveTargetRestricted(moveObject.id, user, fieldSide[targets[0]])) { + const errorMessage = user.getRestrictingTag(move!, user, fieldSide[targets[0]])!.selectionDeniedText(user, moveObject.id); + user.scene.queueMessage(i18next.t(errorMessage, { moveName: moveObject.name }), 0, true); + targets = []; + } if (targets.length < 1) { this.scene.currentBattle.turnCommands[this.fieldIndex] = null; this.scene.unshiftPhase(new CommandPhase(this.scene, this.fieldIndex)); diff --git a/src/phases/stat-stage-change-phase.ts b/src/phases/stat-stage-change-phase.ts index 4418c38c849..44144f9d047 100644 --- a/src/phases/stat-stage-change-phase.ts +++ b/src/phases/stat-stage-change-phase.ts @@ -36,6 +36,16 @@ export class StatStageChangePhase extends PokemonPhase { } start() { + + // Check if multiple stats are being changed at the same time, then run SSCPhase for each of them + if (this.stats.length > 1) { + for (let i = 0; i < this.stats.length; i++) { + const stat = [ this.stats[i] ]; + this.scene.unshiftPhase(new StatStageChangePhase(this.scene, this.battlerIndex, this.selfTarget, stat, this.stages, this.showMessage, this.ignoreAbilities, this.canBeCopied, this.onChange)); + } + return this.end(); + } + const pokemon = this.getPokemon(); if (!pokemon.isActive(true)) { @@ -54,8 +64,8 @@ export class StatStageChangePhase extends PokemonPhase { const cancelled = new BooleanHolder(false); if (!this.selfTarget && stages.value < 0) { - // TODO: Include simulate boolean when tag applications can be simulated - this.scene.arena.applyTagsForSide(MistTag, pokemon.isPlayer() ? ArenaTagSide.PLAYER : ArenaTagSide.ENEMY, cancelled); + // TODO: add a reference to the source of the stat change to fix Infiltrator interaction + this.scene.arena.applyTagsForSide(MistTag, pokemon.isPlayer() ? ArenaTagSide.PLAYER : ArenaTagSide.ENEMY, false, null, cancelled); } if (!cancelled.value && !this.selfTarget && stages.value < 0) { @@ -115,10 +125,7 @@ export class StatStageChangePhase extends PokemonPhase { const whiteHerb = this.scene.applyModifier(ResetNegativeStatStageModifier, this.player, pokemon) as ResetNegativeStatStageModifier; // If the White Herb was applied, consume it if (whiteHerb) { - whiteHerb.stackCount--; - if (whiteHerb.stackCount <= 0) { - this.scene.removeModifier(whiteHerb); - } + pokemon.loseHeldItem(whiteHerb); this.scene.updateModifiers(this.player); } } diff --git a/src/phases/summon-phase.ts b/src/phases/summon-phase.ts index d909c5c3501..177e09c4527 100644 --- a/src/phases/summon-phase.ts +++ b/src/phases/summon-phase.ts @@ -57,7 +57,7 @@ export class SummonPhase extends PartyMemberPokemonPhase { } // Swaps the fainted Pokemon and the first non-fainted legal Pokemon in the party - [party[this.partyMemberIndex], party[legalIndex]] = [party[legalIndex], party[this.partyMemberIndex]]; + [ party[this.partyMemberIndex], party[legalIndex] ] = [ party[legalIndex], party[this.partyMemberIndex] ]; console.warn("Swapped %s %O with %s %O", getPokemonNameWithAffix(partyMember), partyMember, getPokemonNameWithAffix(party[0]), party[0]); } @@ -87,7 +87,7 @@ export class SummonPhase extends PartyMemberPokemonPhase { this.scene.pbTrayEnemy.hide(); this.scene.ui.showText(message, null, () => this.summon()); - } else if (this.scene.currentBattle.battleType === BattleType.MYSTERY_ENCOUNTER) { + } else if (this.scene.currentBattle.isBattleMysteryEncounter()) { this.scene.pbTrayEnemy.hide(); this.summonWild(); } @@ -140,7 +140,7 @@ export class SummonPhase extends PartyMemberPokemonPhase { this.scene.field.add(pokemon); if (!this.player) { const playerPokemon = this.scene.getPlayerPokemon() as Pokemon; - if (playerPokemon?.visible) { + if (playerPokemon?.isOnField()) { this.scene.field.moveBelow(pokemon, playerPokemon); } this.scene.currentBattle.seenEnemyPartyMemberIds.add(pokemon.id); @@ -193,7 +193,7 @@ export class SummonPhase extends PartyMemberPokemonPhase { this.scene.field.add(pokemon); if (!this.player) { const playerPokemon = this.scene.getPlayerPokemon() as Pokemon; - if (playerPokemon?.visible) { + if (playerPokemon?.isOnField()) { this.scene.field.moveBelow(pokemon, playerPokemon); } this.scene.currentBattle.seenEnemyPartyMemberIds.add(pokemon.id); @@ -240,7 +240,7 @@ export class SummonPhase extends PartyMemberPokemonPhase { pokemon.resetTurnData(); - if (!this.loaded || [BattleType.TRAINER, BattleType.MYSTERY_ENCOUNTER].includes(this.scene.currentBattle.battleType) || (this.scene.currentBattle.waveIndex % 10) === 1) { + if (!this.loaded || [ BattleType.TRAINER, BattleType.MYSTERY_ENCOUNTER ].includes(this.scene.currentBattle.battleType) || (this.scene.currentBattle.waveIndex % 10) === 1) { this.scene.triggerPokemonFormChange(pokemon, SpeciesFormChangeActiveTrigger, true); this.queuePostSummon(); } diff --git a/src/phases/switch-biome-phase.ts b/src/phases/switch-biome-phase.ts index 9cf5635a39f..80a31794209 100644 --- a/src/phases/switch-biome-phase.ts +++ b/src/phases/switch-biome-phase.ts @@ -20,7 +20,7 @@ export class SwitchBiomePhase extends BattlePhase { } this.scene.tweens.add({ - targets: [this.scene.arenaEnemy, this.scene.lastEnemyTrainer], + targets: [ this.scene.arenaEnemy, this.scene.lastEnemyTrainer ], x: "+=300", duration: 2000, onComplete: () => { @@ -38,7 +38,7 @@ export class SwitchBiomePhase extends BattlePhase { this.scene.arenaPlayerTransition.setVisible(true); this.scene.tweens.add({ - targets: [this.scene.arenaPlayer, this.scene.arenaBgTransition, this.scene.arenaPlayerTransition], + targets: [ this.scene.arenaPlayer, this.scene.arenaBgTransition, this.scene.arenaPlayerTransition ], duration: 1000, delay: 1000, ease: "Sine.easeInOut", diff --git a/src/phases/switch-phase.ts b/src/phases/switch-phase.ts index b1a2e991ed8..2abb109a529 100644 --- a/src/phases/switch-phase.ts +++ b/src/phases/switch-phase.ts @@ -1,6 +1,7 @@ import BattleScene from "#app/battle-scene"; -import PartyUiHandler, { PartyUiMode, PartyOption } from "#app/ui/party-ui-handler"; +import PartyUiHandler, { PartyOption, PartyUiMode } from "#app/ui/party-ui-handler"; import { Mode } from "#app/ui/ui"; +import { SwitchType } from "#enums/switch-type"; import { BattlePhase } from "./battle-phase"; import { SwitchSummonPhase } from "./switch-summon-phase"; @@ -9,22 +10,25 @@ import { SwitchSummonPhase } from "./switch-summon-phase"; * for the player (if a switch would be valid for the current battle state). */ export class SwitchPhase extends BattlePhase { - protected fieldIndex: integer; - private isModal: boolean; - private doReturn: boolean; + protected readonly fieldIndex: integer; + private readonly switchType: SwitchType; + private readonly isModal: boolean; + private readonly doReturn: boolean; /** * Creates a new SwitchPhase * @param scene {@linkcode BattleScene} Current battle scene + * @param switchType {@linkcode SwitchType} The type of switch logic this phase implements * @param fieldIndex Field index to switch out * @param isModal Indicates if the switch should be forced (true) or is * optional (false). * @param doReturn Indicates if the party member on the field should be * recalled to ball or has already left the field. Passed to {@linkcode SwitchSummonPhase}. */ - constructor(scene: BattleScene, fieldIndex: integer, isModal: boolean, doReturn: boolean) { + constructor(scene: BattleScene, switchType: SwitchType, fieldIndex: integer, isModal: boolean, doReturn: boolean) { super(scene); + this.switchType = switchType; this.fieldIndex = fieldIndex; this.isModal = isModal; this.doReturn = doReturn; @@ -34,16 +38,18 @@ export class SwitchPhase extends BattlePhase { super.start(); // Skip modal switch if impossible (no remaining party members that aren't in battle) - if (this.isModal && !this.scene.getParty().filter(p => p.isAllowedInBattle() && !p.isActive(true)).length) { + if (this.isModal && !this.scene.getPlayerParty().filter(p => p.isAllowedInBattle() && !p.isActive(true)).length) { return super.end(); } - // Skip if the fainted party member has been revived already. doReturn is - // only passed as `false` from FaintPhase (as opposed to other usages such - // as ForceSwitchOutAttr or CheckSwitchPhase), so we only want to check this - // if the mon should have already been returned but is still alive and well - // on the field. see also; battle.test.ts - if (this.isModal && !this.doReturn && !this.scene.getParty()[this.fieldIndex].isFainted()) { + /** + * Skip if the fainted party member has been revived already. doReturn is + * only passed as `false` from FaintPhase (as opposed to other usages such + * as ForceSwitchOutAttr or CheckSwitchPhase), so we only want to check this + * if the mon should have already been returned but is still alive and well + * on the field. see also; battle.test.ts + */ + if (this.isModal && !this.doReturn && !this.scene.getPlayerParty()[this.fieldIndex].isFainted()) { return super.end(); } @@ -53,11 +59,12 @@ export class SwitchPhase extends BattlePhase { } // Override field index to 0 in case of double battle where 2/3 remaining legal party members fainted at once - const fieldIndex = this.scene.currentBattle.getBattlerCount() === 1 || this.scene.getParty().filter(p => p.isAllowedInBattle()).length > 1 ? this.fieldIndex : 0; + const fieldIndex = this.scene.currentBattle.getBattlerCount() === 1 || this.scene.getPokemonAllowedInBattle().length > 1 ? this.fieldIndex : 0; this.scene.ui.setMode(Mode.PARTY, this.isModal ? PartyUiMode.FAINT_SWITCH : PartyUiMode.POST_BATTLE_SWITCH, fieldIndex, (slotIndex: integer, option: PartyOption) => { if (slotIndex >= this.scene.currentBattle.getBattlerCount() && slotIndex < 6) { - this.scene.unshiftPhase(new SwitchSummonPhase(this.scene, fieldIndex, slotIndex, this.doReturn, option === PartyOption.PASS_BATON)); + const switchType = (option === PartyOption.PASS_BATON) ? SwitchType.BATON_PASS : this.switchType; + this.scene.unshiftPhase(new SwitchSummonPhase(this.scene, switchType, fieldIndex, slotIndex, this.doReturn)); } this.scene.ui.setMode(Mode.MESSAGE).then(() => super.end()); }, PartyUiHandler.FilterNonFainted); diff --git a/src/phases/switch-summon-phase.ts b/src/phases/switch-summon-phase.ts index 525f74e896f..a667e17edf1 100644 --- a/src/phases/switch-summon-phase.ts +++ b/src/phases/switch-summon-phase.ts @@ -12,29 +12,30 @@ import i18next from "i18next"; import { PostSummonPhase } from "./post-summon-phase"; import { SummonPhase } from "./summon-phase"; import { SubstituteTag } from "#app/data/battler-tags"; +import { SwitchType } from "#enums/switch-type"; export class SwitchSummonPhase extends SummonPhase { - private slotIndex: integer; - private doReturn: boolean; - private batonPass: boolean; + private readonly switchType: SwitchType; + private readonly slotIndex: integer; + private readonly doReturn: boolean; private lastPokemon: Pokemon; /** * Constructor for creating a new SwitchSummonPhase * @param scene {@linkcode BattleScene} the scene the phase is associated with + * @param switchType the type of switch behavior * @param fieldIndex integer representing position on the battle field * @param slotIndex integer for the index of pokemon (in party of 6) to switch into * @param doReturn boolean whether to render "comeback" dialogue - * @param batonPass boolean if the switch is from baton pass * @param player boolean if the switch is from the player */ - constructor(scene: BattleScene, fieldIndex: integer, slotIndex: integer, doReturn: boolean, batonPass: boolean, player?: boolean) { + constructor(scene: BattleScene, switchType: SwitchType, fieldIndex: integer, slotIndex: integer, doReturn: boolean, player?: boolean) { super(scene, fieldIndex, player !== undefined ? player : true); + this.switchType = switchType; this.slotIndex = slotIndex; this.doReturn = doReturn; - this.batonPass = batonPass; } start(): void { @@ -53,7 +54,7 @@ export class SwitchSummonPhase extends SummonPhase { } } - if (!this.doReturn || (this.slotIndex !== -1 && !(this.player ? this.scene.getParty() : this.scene.getEnemyParty())[this.slotIndex])) { + if (!this.doReturn || (this.slotIndex !== -1 && !(this.player ? this.scene.getPlayerParty() : this.scene.getEnemyParty())[this.slotIndex])) { if (this.player) { return this.switchAndSummon(); } else { @@ -63,9 +64,8 @@ export class SwitchSummonPhase extends SummonPhase { } const pokemon = this.getPokemon(); - - if (!this.batonPass) { - (this.player ? this.scene.getEnemyField() : this.scene.getPlayerField()).forEach(enemyPokemon => enemyPokemon.removeTagsBySourceId(pokemon.id)); + (this.player ? this.scene.getEnemyField() : this.scene.getPlayerField()).forEach(enemyPokemon => enemyPokemon.removeTagsBySourceId(pokemon.id)); + if (this.switchType === SwitchType.SWITCH || this.switchType === SwitchType.INITIAL_SWITCH) { const substitute = pokemon.getTag(SubstituteTag); if (substitute) { this.scene.tweens.add({ @@ -94,7 +94,7 @@ export class SwitchSummonPhase extends SummonPhase { ease: "Sine.easeIn", scale: 0.5, onComplete: () => { - pokemon.leaveField(!this.batonPass, false); + pokemon.leaveField(this.switchType === SwitchType.SWITCH, false); this.scene.time.delayedCall(750, () => this.switchAndSummon()); } }); @@ -105,13 +105,13 @@ export class SwitchSummonPhase extends SummonPhase { const switchedInPokemon = party[this.slotIndex]; this.lastPokemon = this.getPokemon(); applyPreSwitchOutAbAttrs(PreSwitchOutAbAttr, this.lastPokemon); - if (this.batonPass && switchedInPokemon) { + if (this.switchType === SwitchType.BATON_PASS && switchedInPokemon) { (this.player ? this.scene.getEnemyField() : this.scene.getPlayerField()).forEach(enemyPokemon => enemyPokemon.transferTagsBySourceId(this.lastPokemon.id, switchedInPokemon.id)); if (!this.scene.findModifier(m => m instanceof SwitchEffectTransferModifier && (m as SwitchEffectTransferModifier).pokemonId === switchedInPokemon.id)) { const batonPassModifier = this.scene.findModifier(m => m instanceof SwitchEffectTransferModifier && (m as SwitchEffectTransferModifier).pokemonId === this.lastPokemon.id) as SwitchEffectTransferModifier; if (batonPassModifier && !this.scene.findModifier(m => m instanceof SwitchEffectTransferModifier && (m as SwitchEffectTransferModifier).pokemonId === switchedInPokemon.id)) { - this.scene.tryTransferHeldItemModifier(batonPassModifier, switchedInPokemon, false); + this.scene.tryTransferHeldItemModifier(batonPassModifier, switchedInPokemon, false, undefined, undefined, undefined, false); } } } @@ -130,7 +130,7 @@ export class SwitchSummonPhase extends SummonPhase { * If this switch is passing a Substitute, make the switched Pokemon match the returned Pokemon's state as it left. * Otherwise, clear any persisting tags on the returned Pokemon. */ - if (this.batonPass) { + if (this.switchType === SwitchType.BATON_PASS || this.switchType === SwitchType.SHED_TAIL) { const substitute = this.lastPokemon.getTag(SubstituteTag); if (substitute) { switchedInPokemon.x += this.lastPokemon.getSubstituteOffset()[0]; @@ -138,7 +138,6 @@ export class SwitchSummonPhase extends SummonPhase { switchedInPokemon.setAlpha(0.5); } } else { - switchedInPokemon.resetBattleData(); switchedInPokemon.resetSummonData(); } this.summon(); @@ -172,10 +171,21 @@ export class SwitchSummonPhase extends SummonPhase { // Or compensate for force switch move if switched out pokemon is not fainted if (currentCommand === Command.POKEMON || lastPokemonIsForceSwitchedAndNotFainted) { pokemon.battleSummonData.turnCount--; + pokemon.battleSummonData.waveTurnCount--; } - if (this.batonPass && pokemon) { + if (this.switchType === SwitchType.BATON_PASS && pokemon) { pokemon.transferSummon(this.lastPokemon); + } else if (this.switchType === SwitchType.SHED_TAIL && pokemon) { + const subTag = this.lastPokemon.getTag(SubstituteTag); + if (subTag) { + pokemon.summonData.tags.push(subTag); + } + } + + if (this.switchType !== SwitchType.INITIAL_SWITCH) { + pokemon.resetTurnData(); + pokemon.turnData.switchedInThisTurn = true; } this.lastPokemon?.resetSummonData(); diff --git a/src/phases/title-phase.ts b/src/phases/title-phase.ts index 52503501837..88793617776 100644 --- a/src/phases/title-phase.ts +++ b/src/phases/title-phase.ts @@ -1,21 +1,21 @@ import { loggedInUser } from "#app/account"; -import BattleScene from "#app/battle-scene"; import { BattleType } from "#app/battle"; -import { getDailyRunStarters, fetchDailyRunSeed } from "#app/data/daily-run"; +import BattleScene from "#app/battle-scene"; +import { fetchDailyRunSeed, getDailyRunStarters } from "#app/data/daily-run"; import { Gender } from "#app/data/gender"; import { getBiomeKey } from "#app/field/arena"; -import { GameModes, GameMode, getGameMode } from "#app/game-mode"; -import { regenerateModifierPoolThresholds, ModifierPoolType, modifierTypes, getDailyRunStarterModifiers } from "#app/modifier/modifier-type"; +import { GameMode, GameModes, getGameMode } from "#app/game-mode"; +import { Modifier } from "#app/modifier/modifier"; +import { getDailyRunStarterModifiers, ModifierPoolType, modifierTypes, regenerateModifierPoolThresholds } from "#app/modifier/modifier-type"; import { Phase } from "#app/phase"; import { SessionSaveData } from "#app/system/game-data"; import { Unlockables } from "#app/system/unlockables"; import { vouchers } from "#app/system/voucher"; -import { OptionSelectItem, OptionSelectConfig } from "#app/ui/abstact-option-select-ui-handler"; +import { OptionSelectConfig, OptionSelectItem } from "#app/ui/abstact-option-select-ui-handler"; import { SaveSlotUiMode } from "#app/ui/save-slot-select-ui-handler"; import { Mode } from "#app/ui/ui"; -import i18next from "i18next"; import * as Utils from "#app/utils"; -import { Modifier } from "#app/modifier/modifier"; +import i18next from "i18next"; import { CheckSwitchPhase } from "./check-switch-phase"; import { EncounterPhase } from "./encounter-phase"; import { SelectChallengePhase } from "./select-challenge-phase"; @@ -60,7 +60,7 @@ export class TitlePhase extends Phase { const options: OptionSelectItem[] = []; if (loggedInUser && loggedInUser.lastSessionSlot > -1) { options.push({ - label: i18next.t("continue", {ns: "menu"}), + label: i18next.t("continue", { ns: "menu" }), handler: () => { this.loadSaveSlot(this.lastSessionData || !loggedInUser ? -1 : loggedInUser.lastSessionSlot); return true; @@ -76,7 +76,8 @@ export class TitlePhase extends Phase { this.scene.ui.clearText(); this.end(); }; - if (this.scene.gameData.unlocks[Unlockables.ENDLESS_MODE]) { + const { gameData } = this.scene; + if (gameData.isUnlocked(Unlockables.ENDLESS_MODE)) { const options: OptionSelectItem[] = [ { label: GameMode.getModeName(GameModes.CLASSIC), @@ -100,7 +101,7 @@ export class TitlePhase extends Phase { } } ]; - if (this.scene.gameData.unlocks[Unlockables.SPLICED_ENDLESS_MODE]) { + if (gameData.isUnlocked(Unlockables.SPLICED_ENDLESS_MODE)) { options.push({ label: GameMode.getModeName(GameModes.SPLICED_ENDLESS), handler: () => { @@ -195,14 +196,14 @@ export class TitlePhase extends Phase { this.scene.gameMode = getGameMode(GameModes.DAILY); this.scene.setSeed(seed); - this.scene.resetSeed(1); + this.scene.resetSeed(0); this.scene.money = this.scene.gameMode.getStartingMoney(); const starters = getDailyRunStarters(this.scene, seed); const startingLevel = this.scene.gameMode.getStartingLevel(); - const party = this.scene.getParty(); + const party = this.scene.getPlayerParty(); const loadPokemonAssets: Promise[] = []; for (const starter of starters) { const starterProps = this.scene.gameData.getSpeciesDexAttrProps(starter.species, starter.dexAttr); @@ -220,6 +221,7 @@ export class TitlePhase extends Phase { const modifiers: Modifier[] = Array(3).fill(null).map(() => modifierTypes.EXP_SHARE().withIdFromFunc(modifierTypes.EXP_SHARE).newModifier()) .concat(Array(3).fill(null).map(() => modifierTypes.GOLDEN_EXP_CHARM().withIdFromFunc(modifierTypes.GOLDEN_EXP_CHARM).newModifier())) + .concat([ modifierTypes.MAP().withIdFromFunc(modifierTypes.MAP).newModifier() ]) .concat(getDailyRunStarterModifiers(party)) .filter((m) => m !== null); @@ -241,7 +243,7 @@ export class TitlePhase extends Phase { }; // If Online, calls seed fetch from db to generate daily run. If Offline, generates a daily run based on current date. - if (!Utils.isLocal) { + if (!Utils.isLocal || Utils.isLocalServerConnected) { fetchDailyRunSeed().then(seed => { if (seed) { generateDaily(seed); @@ -274,7 +276,7 @@ export class TitlePhase extends Phase { this.scene.pushPhase(new EncounterPhase(this.scene, this.loaded)); if (this.loaded) { - const availablePartyMembers = this.scene.getParty().filter(p => p.isAllowedInBattle()).length; + const availablePartyMembers = this.scene.getPokemonAllowedInBattle().length; this.scene.pushPhase(new SummonPhase(this.scene, 0, true, true)); if (this.scene.currentBattle.double && availablePartyMembers > 1) { diff --git a/src/phases/toggle-double-position-phase.ts b/src/phases/toggle-double-position-phase.ts index 563af8575d7..eff92bc6acd 100644 --- a/src/phases/toggle-double-position-phase.ts +++ b/src/phases/toggle-double-position-phase.ts @@ -16,9 +16,9 @@ export class ToggleDoublePositionPhase extends BattlePhase { const playerPokemon = this.scene.getPlayerField().find(p => p.isActive(true)); if (playerPokemon) { - playerPokemon.setFieldPosition(this.double && this.scene.getParty().filter(p => p.isAllowedInBattle()).length > 1 ? FieldPosition.LEFT : FieldPosition.CENTER, 500).then(() => { + playerPokemon.setFieldPosition(this.double && this.scene.getPokemonAllowedInBattle().length > 1 ? FieldPosition.LEFT : FieldPosition.CENTER, 500).then(() => { if (playerPokemon.getFieldIndex() === 1) { - const party = this.scene.getParty(); + const party = this.scene.getPlayerParty(); party[1] = party[0]; party[0] = playerPokemon; } diff --git a/src/phases/trainer-message-test-phase.ts b/src/phases/trainer-message-test-phase.ts index 8075dd761e2..d9e58473bd5 100644 --- a/src/phases/trainer-message-test-phase.ts +++ b/src/phases/trainer-message-test-phase.ts @@ -24,7 +24,7 @@ export class TrainerMessageTestPhase extends BattlePhase { continue; } const config = trainerConfigs[type]; - [config.encounterMessages, config.femaleEncounterMessages, config.victoryMessages, config.femaleVictoryMessages, config.defeatMessages, config.femaleDefeatMessages] + [ config.encounterMessages, config.femaleEncounterMessages, config.victoryMessages, config.femaleVictoryMessages, config.defeatMessages, config.femaleDefeatMessages ] .map(messages => { if (messages?.length) { testMessages.push(...messages); diff --git a/src/phases/trainer-victory-phase.ts b/src/phases/trainer-victory-phase.ts index e925f0c47d4..dc1b962f47e 100644 --- a/src/phases/trainer-victory-phase.ts +++ b/src/phases/trainer-victory-phase.ts @@ -27,10 +27,16 @@ export class TrainerVictoryPhase extends BattlePhase { this.scene.unshiftPhase(new ModifierRewardPhase(this.scene, modifierRewardFunc)); } + if (this.scene.eventManager.isEventActive()) { + for (const rewardFunc of this.scene.currentBattle.trainer?.config.eventRewardFuncs!) { + this.scene.unshiftPhase(new ModifierRewardPhase(this.scene, rewardFunc)); + } + } + const trainerType = this.scene.currentBattle.trainer?.config.trainerType!; // TODO: is this bang correct? if (vouchers.hasOwnProperty(TrainerType[trainerType])) { if (!this.scene.validateVoucher(vouchers[TrainerType[trainerType]]) && this.scene.currentBattle.trainer?.config.isBoss) { - this.scene.unshiftPhase(new ModifierRewardPhase(this.scene, [modifierTypes.VOUCHER, modifierTypes.VOUCHER, modifierTypes.VOUCHER_PLUS, modifierTypes.VOUCHER_PREMIUM][vouchers[TrainerType[trainerType]].voucherType])); + this.scene.unshiftPhase(new ModifierRewardPhase(this.scene, [ modifierTypes.VOUCHER, modifierTypes.VOUCHER, modifierTypes.VOUCHER_PLUS, modifierTypes.VOUCHER_PREMIUM ][vouchers[TrainerType[trainerType]].voucherType])); } } diff --git a/src/phases/turn-end-phase.ts b/src/phases/turn-end-phase.ts index 724a5206d74..60a2e6600db 100644 --- a/src/phases/turn-end-phase.ts +++ b/src/phases/turn-end-phase.ts @@ -44,6 +44,7 @@ export class TurnEndPhase extends FieldPhase { this.scene.applyModifiers(TurnHeldItemTransferModifier, pokemon.isPlayer(), pokemon); pokemon.battleSummonData.turnCount++; + pokemon.battleSummonData.waveTurnCount++; }; this.executeForAll(handlePokemon); diff --git a/src/phases/turn-init-phase.ts b/src/phases/turn-init-phase.ts index 92547878f12..baff6c7d73f 100644 --- a/src/phases/turn-init-phase.ts +++ b/src/phases/turn-init-phase.ts @@ -1,15 +1,15 @@ -import BattleScene from "#app/battle-scene"; import { BattlerIndex } from "#app/battle"; +import BattleScene from "#app/battle-scene"; +import { handleMysteryEncounterBattleStartEffects, handleMysteryEncounterTurnStartEffects } from "#app/data/mystery-encounters/utils/encounter-phase-utils"; import { TurnInitEvent } from "#app/events/battle-scene"; import { PlayerPokemon } from "#app/field/pokemon"; import i18next from "i18next"; -import { FieldPhase } from "./field-phase"; -import { ToggleDoublePositionPhase } from "./toggle-double-position-phase"; import { CommandPhase } from "./command-phase"; import { EnemyCommandPhase } from "./enemy-command-phase"; +import { FieldPhase } from "./field-phase"; import { GameOverPhase } from "./game-over-phase"; +import { ToggleDoublePositionPhase } from "./toggle-double-position-phase"; import { TurnStartPhase } from "./turn-start-phase"; -import { handleMysteryEncounterBattleStartEffects, handleMysteryEncounterTurnStartEffects } from "#app/data/mystery-encounters/utils/encounter-phase-utils"; export class TurnInitPhase extends FieldPhase { constructor(scene: BattleScene) { @@ -24,7 +24,7 @@ export class TurnInitPhase extends FieldPhase { if (p.isOnField() && !p.isAllowedInBattle()) { this.scene.queueMessage(i18next.t("challenges:illegalEvolution", { "pokemon": p.name }), null, true); - const allowedPokemon = this.scene.getParty().filter(p => p.isAllowedInBattle()); + const allowedPokemon = this.scene.getPokemonAllowedInBattle(); if (!allowedPokemon.length) { // If there are no longer any legal pokemon in the party, game over. @@ -32,7 +32,7 @@ export class TurnInitPhase extends FieldPhase { this.scene.unshiftPhase(new GameOverPhase(this.scene)); } else if (allowedPokemon.length >= this.scene.currentBattle.getBattlerCount() || (this.scene.currentBattle.double && !allowedPokemon[0].isActive(true))) { // If there is at least one pokemon in the back that is legal to switch in, force a switch. - p.switchOut(false); + p.switchOut(); } else { // If there are no pokemon in the back but we're not game overing, just hide the pokemon. // This should only happen in double battles. diff --git a/src/phases/turn-start-phase.ts b/src/phases/turn-start-phase.ts index 5c1af4228c6..b48b018a046 100644 --- a/src/phases/turn-start-phase.ts +++ b/src/phases/turn-start-phase.ts @@ -1,6 +1,6 @@ import BattleScene from "#app/battle-scene"; -import { applyAbAttrs, BypassSpeedChanceAbAttr, PreventBypassSpeedChanceAbAttr, ChangeMovePriorityAbAttr } from "#app/data/ability"; -import { allMoves, applyMoveAttrs, IncrementMovePriorityAttr, MoveHeaderAttr } from "#app/data/move"; +import { applyAbAttrs, BypassSpeedChanceAbAttr, PreventBypassSpeedChanceAbAttr } from "#app/data/ability"; +import { allMoves, MoveHeaderAttr } from "#app/data/move"; import { Abilities } from "#app/enums/abilities"; import { Stat } from "#app/enums/stat"; import Pokemon, { PokemonMove } from "#app/field/pokemon"; @@ -13,12 +13,13 @@ import { BerryPhase } from "./berry-phase"; import { FieldPhase } from "./field-phase"; import { MoveHeaderPhase } from "./move-header-phase"; import { MovePhase } from "./move-phase"; -import { PostTurnStatusEffectPhase } from "./post-turn-status-effect-phase"; import { SwitchSummonPhase } from "./switch-summon-phase"; import { TurnEndPhase } from "./turn-end-phase"; import { WeatherEffectPhase } from "./weather-effect-phase"; +import { CheckStatusEffectPhase } from "#app/phases/check-status-effect-phase"; import { BattlerIndex } from "#app/battle"; import { TrickRoomTag } from "#app/data/arena-tag"; +import { SwitchType } from "#enums/switch-type"; export class TurnStartPhase extends FieldPhase { constructor(scene: BattleScene) { @@ -42,20 +43,17 @@ export class TurnStartPhase extends FieldPhase { orderedTargets = Utils.randSeedShuffle(orderedTargets); }, this.scene.currentBattle.turn, this.scene.waveSeed); - orderedTargets.sort((a: Pokemon, b: Pokemon) => { - const aSpeed = a?.getEffectiveStat(Stat.SPD) || 0; - const bSpeed = b?.getEffectiveStat(Stat.SPD) || 0; - - return bSpeed - aSpeed; - }); - - // Next, a check for Trick Room is applied. If Trick Room is present, the order is reversed. + // Next, a check for Trick Room is applied to determine sort order. const speedReversed = new Utils.BooleanHolder(false); - this.scene.arena.applyTags(TrickRoomTag, speedReversed); + this.scene.arena.applyTags(TrickRoomTag, false, speedReversed); - if (speedReversed.value) { - orderedTargets = orderedTargets.reverse(); - } + // Adjust the sort function based on whether Trick Room is active. + orderedTargets.sort((a: Pokemon, b: Pokemon) => { + const aSpeed = a?.getEffectiveStat(Stat.SPD) ?? 0; + const bSpeed = b?.getEffectiveStat(Stat.SPD) ?? 0; + + return speedReversed.value ? aSpeed - bSpeed : bSpeed - aSpeed; + }); return orderedTargets.map(t => t.getFieldIndex() + (!t.isPlayer() ? BattlerIndex.ENEMY : BattlerIndex.PLAYER)); } @@ -100,26 +98,22 @@ export class TurnStartPhase extends FieldPhase { const aMove = allMoves[aCommand.move!.move]; const bMove = allMoves[bCommand!.move!.move]; - // The game now considers priority and applies the relevant move and ability attributes - const aPriority = new Utils.IntegerHolder(aMove.priority); - const bPriority = new Utils.IntegerHolder(bMove.priority); + const aUser = this.scene.getField(true).find(p => p.getBattlerIndex() === a)!; + const bUser = this.scene.getField(true).find(p => p.getBattlerIndex() === b)!; - applyMoveAttrs(IncrementMovePriorityAttr, this.scene.getField().find(p => p?.isActive() && p.getBattlerIndex() === a)!, null, aMove, aPriority); - applyMoveAttrs(IncrementMovePriorityAttr, this.scene.getField().find(p => p?.isActive() && p.getBattlerIndex() === b)!, null, bMove, bPriority); - - applyAbAttrs(ChangeMovePriorityAbAttr, this.scene.getField().find(p => p?.isActive() && p.getBattlerIndex() === a)!, null, false, aMove, aPriority); - applyAbAttrs(ChangeMovePriorityAbAttr, this.scene.getField().find(p => p?.isActive() && p.getBattlerIndex() === b)!, null, false, bMove, bPriority); + const aPriority = aMove.getPriority(aUser, false); + const bPriority = bMove.getPriority(bUser, false); // The game now checks for differences in priority levels. // If the moves share the same original priority bracket, it can check for differences in battlerBypassSpeed and return the result. // This conditional is used to ensure that Quick Claw can still activate with abilities like Stall and Mycelium Might (attack moves only) // Otherwise, the game returns the user of the move with the highest priority. - const isSameBracket = Math.ceil(aPriority.value) - Math.ceil(bPriority.value) === 0; - if (aPriority.value !== bPriority.value) { + const isSameBracket = Math.ceil(aPriority) - Math.ceil(bPriority) === 0; + if (aPriority !== bPriority) { if (isSameBracket && battlerBypassSpeed[a].value !== battlerBypassSpeed[b].value) { return battlerBypassSpeed[a].value ? -1 : 1; } - return aPriority.value < bPriority.value ? 1 : -1; + return (aPriority < bPriority) ? 1 : -1; } } @@ -154,66 +148,64 @@ export class TurnStartPhase extends FieldPhase { } switch (turnCommand?.command) { - case Command.FIGHT: - const queuedMove = turnCommand.move; - pokemon.turnData.order = orderIndex++; - if (!queuedMove) { - continue; - } - const move = pokemon.getMoveset().find(m => m?.moveId === queuedMove.move) || new PokemonMove(queuedMove.move); - if (move.getMove().hasAttr(MoveHeaderAttr)) { - this.scene.unshiftPhase(new MoveHeaderPhase(this.scene, pokemon, move)); - } - if (pokemon.isPlayer()) { - if (turnCommand.cursor === -1) { - this.scene.pushPhase(new MovePhase(this.scene, pokemon, turnCommand.targets || turnCommand.move!.targets, move));//TODO: is the bang correct here? - } else { - const playerPhase = new MovePhase(this.scene, pokemon, turnCommand.targets || turnCommand.move!.targets, move, false, queuedMove.ignorePP);//TODO: is the bang correct here? - this.scene.pushPhase(playerPhase); + case Command.FIGHT: + const queuedMove = turnCommand.move; + pokemon.turnData.order = orderIndex++; + if (!queuedMove) { + continue; } - } else { - this.scene.pushPhase(new MovePhase(this.scene, pokemon, turnCommand.targets || turnCommand.move!.targets, move, false, queuedMove.ignorePP));//TODO: is the bang correct here? - } - break; - case Command.BALL: - this.scene.unshiftPhase(new AttemptCapturePhase(this.scene, turnCommand.targets![0] % 2, turnCommand.cursor!));//TODO: is the bang correct here? - break; - case Command.POKEMON: - this.scene.unshiftPhase(new SwitchSummonPhase(this.scene, pokemon.getFieldIndex(), turnCommand.cursor!, true, turnCommand.args![0] as boolean, pokemon.isPlayer()));//TODO: is the bang correct here? - break; - case Command.RUN: - let runningPokemon = pokemon; - if (this.scene.currentBattle.double) { - const playerActivePokemon = field.filter(pokemon => { - if (!!pokemon) { - return pokemon.isPlayer() && pokemon.isActive(); + const move = pokemon.getMoveset().find(m => m?.moveId === queuedMove.move && m?.ppUsed < m?.getMovePp()) || new PokemonMove(queuedMove.move); + if (move.getMove().hasAttr(MoveHeaderAttr)) { + this.scene.unshiftPhase(new MoveHeaderPhase(this.scene, pokemon, move)); + } + if (pokemon.isPlayer()) { + if (turnCommand.cursor === -1) { + this.scene.pushPhase(new MovePhase(this.scene, pokemon, turnCommand.targets || turnCommand.move!.targets, move));//TODO: is the bang correct here? } else { - return; + const playerPhase = new MovePhase(this.scene, pokemon, turnCommand.targets || turnCommand.move!.targets, move, false, queuedMove.ignorePP);//TODO: is the bang correct here? + this.scene.pushPhase(playerPhase); } - }); - // if only one pokemon is alive, use that one - if (playerActivePokemon.length > 1) { - // find which active pokemon has faster speed - const fasterPokemon = playerActivePokemon[0].getStat(Stat.SPD) > playerActivePokemon[1].getStat(Stat.SPD) ? playerActivePokemon[0] : playerActivePokemon[1]; - // check if either active pokemon has the ability "Run Away" - const hasRunAway = playerActivePokemon.find(p => p.hasAbility(Abilities.RUN_AWAY)); - runningPokemon = hasRunAway !== undefined ? hasRunAway : fasterPokemon; + } else { + this.scene.pushPhase(new MovePhase(this.scene, pokemon, turnCommand.targets || turnCommand.move!.targets, move, false, queuedMove.ignorePP));//TODO: is the bang correct here? } - } - this.scene.unshiftPhase(new AttemptRunPhase(this.scene, runningPokemon.getFieldIndex())); - break; + break; + case Command.BALL: + this.scene.unshiftPhase(new AttemptCapturePhase(this.scene, turnCommand.targets![0] % 2, turnCommand.cursor!));//TODO: is the bang correct here? + break; + case Command.POKEMON: + const switchType = turnCommand.args?.[0] ? SwitchType.BATON_PASS : SwitchType.SWITCH; + this.scene.unshiftPhase(new SwitchSummonPhase(this.scene, switchType, pokemon.getFieldIndex(), turnCommand.cursor!, true, pokemon.isPlayer())); + break; + case Command.RUN: + let runningPokemon = pokemon; + if (this.scene.currentBattle.double) { + const playerActivePokemon = field.filter(pokemon => { + if (!!pokemon) { + return pokemon.isPlayer() && pokemon.isActive(); + } else { + return; + } + }); + // if only one pokemon is alive, use that one + if (playerActivePokemon.length > 1) { + // find which active pokemon has faster speed + const fasterPokemon = playerActivePokemon[0].getStat(Stat.SPD) > playerActivePokemon[1].getStat(Stat.SPD) ? playerActivePokemon[0] : playerActivePokemon[1]; + // check if either active pokemon has the ability "Run Away" + const hasRunAway = playerActivePokemon.find(p => p.hasAbility(Abilities.RUN_AWAY)); + runningPokemon = hasRunAway !== undefined ? hasRunAway : fasterPokemon; + } + } + this.scene.unshiftPhase(new AttemptRunPhase(this.scene, runningPokemon.getFieldIndex())); + break; } } this.scene.pushPhase(new WeatherEffectPhase(this.scene)); - - for (const o of moveOrder) { - if (field[o].status && field[o].status.isPostTurn()) { - this.scene.pushPhase(new PostTurnStatusEffectPhase(this.scene, o)); - } - } - this.scene.pushPhase(new BerryPhase(this.scene)); + + /** Add a new phase to check who should be taking status damage */ + this.scene.pushPhase(new CheckStatusEffectPhase(this.scene, moveOrder)); + this.scene.pushPhase(new TurnEndPhase(this.scene)); /** diff --git a/src/phases/victory-phase.ts b/src/phases/victory-phase.ts index c11dd80b3aa..1faa31655df 100644 --- a/src/phases/victory-phase.ts +++ b/src/phases/victory-phase.ts @@ -1,6 +1,6 @@ import BattleScene from "#app/battle-scene"; -import { BattlerIndex, BattleType } from "#app/battle"; -import { modifierTypes } from "#app/modifier/modifier-type"; +import { BattlerIndex, BattleType, ClassicFixedBossWaves } from "#app/battle"; +import { CustomModifierSettings, modifierTypes } from "#app/modifier/modifier-type"; import { BattleEndPhase } from "./battle-end-phase"; import { NewBattlePhase } from "./new-battle-phase"; import { PokemonPhase } from "./pokemon-phase"; @@ -25,12 +25,17 @@ export class VictoryPhase extends PokemonPhase { start() { super.start(); - this.scene.gameData.gameStats.pokemonDefeated++; + const isMysteryEncounter = this.scene.currentBattle.isBattleMysteryEncounter(); + + // update Pokemon defeated count except for MEs that disable it + if (!isMysteryEncounter || !this.scene.currentBattle.mysteryEncounter?.preventGameStatsUpdates) { + this.scene.gameData.gameStats.pokemonDefeated++; + } const expValue = this.getPokemon().getExpValue(); this.scene.applyPartyExp(expValue, true); - if (this.scene.currentBattle.battleType === BattleType.MYSTERY_ENCOUNTER) { + if (isMysteryEncounter) { handleMysteryEncounterVictory(this.scene, false, this.isExpOnly); return this.end(); } @@ -42,8 +47,12 @@ export class VictoryPhase extends PokemonPhase { } if (this.scene.gameMode.isEndless || !this.scene.gameMode.isWaveFinal(this.scene.currentBattle.waveIndex)) { this.scene.pushPhase(new EggLapsePhase(this.scene)); + if (this.scene.gameMode.isClassic && this.scene.currentBattle.waveIndex === ClassicFixedBossWaves.EVIL_BOSS_2) { + // Should get Lock Capsule on 165 before shop phase so it can be used in the rewards shop + this.scene.pushPhase(new ModifierRewardPhase(this.scene, modifierTypes.LOCK_CAPSULE)); + } if (this.scene.currentBattle.waveIndex % 10) { - this.scene.pushPhase(new SelectModifierPhase(this.scene)); + this.scene.pushPhase(new SelectModifierPhase(this.scene, undefined, undefined, this.getFixedBattleCustomModifiers())); } else if (this.scene.gameMode.isDaily) { this.scene.pushPhase(new ModifierRewardPhase(this.scene, modifierTypes.EXP_CHARM)); if (this.scene.currentBattle.waveIndex > 10 && !this.scene.gameMode.isWaveFinal(this.scene.currentBattle.waveIndex)) { @@ -76,4 +85,18 @@ export class VictoryPhase extends PokemonPhase { this.end(); } + + /** + * If this wave is a fixed battle with special custom modifier rewards, + * will pass those settings to the upcoming {@linkcode SelectModifierPhase}`. + */ + getFixedBattleCustomModifiers(): CustomModifierSettings | undefined { + const gameMode = this.scene.gameMode; + const waveIndex = this.scene.currentBattle.waveIndex; + if (gameMode.isFixedBattle(waveIndex)) { + return gameMode.getFixedBattle(waveIndex).customModifierRewardSettings; + } + + return undefined; + } } diff --git a/src/phases/weather-effect-phase.ts b/src/phases/weather-effect-phase.ts index 73de44389d0..b48ee342780 100644 --- a/src/phases/weather-effect-phase.ts +++ b/src/phases/weather-effect-phase.ts @@ -44,7 +44,7 @@ export class WeatherEffectPhase extends CommonAnimPhase { return; } - const damage = Math.ceil(pokemon.getMaxHp() / 16); + const damage = Utils.toDmgValue(pokemon.getMaxHp() / 16); this.scene.queueMessage(getWeatherDamageMessage(this.weather?.weatherType!, pokemon)!); // TODO: are those bangs correct? pokemon.damageAndUpdate(damage, HitResult.EFFECTIVE, false, false, true); diff --git a/src/plugins/api/api-base.ts b/src/plugins/api/api-base.ts new file mode 100644 index 00000000000..5c1a30ff3ab --- /dev/null +++ b/src/plugins/api/api-base.ts @@ -0,0 +1,93 @@ +import { SESSION_ID_COOKIE_NAME } from "#app/constants"; +import { getCookie } from "#app/utils"; + +type DataType = "json" | "form-urlencoded"; + +export abstract class ApiBase { + //#region Fields + + public readonly ERR_GENERIC: string = "There was an error"; + + protected readonly base: string; + + //#region Public + + constructor(base: string) { + this.base = base; + } + + //#region Protected + + /** + * Send a GET request. + * @param path The path to send the request to. + */ + protected async doGet(path: string) { + return this.doFetch(path, { method: "GET" }); + } + + /** + * Send a POST request. + * @param path THe path to send the request to. + * @param bodyData The body-data to send. + * @param dataType The data-type of the {@linkcode bodyData}. + */ + protected async doPost(path: string, bodyData?: D, dataType: DataType = "json") { + let body: string | undefined = undefined; + const headers: HeadersInit = {}; + + if (bodyData) { + if (dataType === "json") { + body = typeof bodyData === "string" ? bodyData : JSON.stringify(bodyData); + headers["Content-Type"] = "application/json"; + } else if (dataType === "form-urlencoded") { + if (bodyData instanceof Object) { + body = this.toUrlSearchParams(bodyData).toString(); + } else { + console.warn("Could not add body data to form-urlencoded!", bodyData); + } + headers["Content-Type"] = "application/x-www-form-urlencoded"; + } else { + console.warn(`Unsupported data type: ${dataType}`); + body = String(bodyData); + headers["Content-Type"] = "text/plain"; + } + } + + return await this.doFetch(path, { method: "POST", body, headers }); + } + + /** + * A generic request helper. + * @param path The path to send the request to. + * @param config The request {@linkcode RequestInit | Configuration}. + */ + protected async doFetch(path: string, config: RequestInit): Promise { + config.headers = { + ...config.headers, + Authorization: getCookie(SESSION_ID_COOKIE_NAME), + "Content-Type": config.headers?.["Content-Type"] ?? "application/json", + }; + + if (import.meta.env.DEV) { + console.log(`Sending ${config.method ?? "GET"} request to: `, this.base + path, config); + } + + return await fetch(this.base + path, config); + } + + /** + * Helper to transform data to {@linkcode URLSearchParams} + * Any key with a value of `undefined` will be ignored. + * Any key with a value of `null` will be included. + * @param data the data to transform to {@linkcode URLSearchParams} + * @returns a {@linkcode URLSearchParams} representaton of {@linkcode data} + */ + protected toUrlSearchParams>(data: D) { + const arr = Object.entries(data) + .map(([ key, value ]) => (value !== undefined ? [ key, String(value) ] : [ key, "" ])) + .filter(([ , value ]) => value !== ""); + + return new URLSearchParams(arr); + } +} diff --git a/src/plugins/api/pokerogue-account-api.ts b/src/plugins/api/pokerogue-account-api.ts new file mode 100644 index 00000000000..66ab8d67520 --- /dev/null +++ b/src/plugins/api/pokerogue-account-api.ts @@ -0,0 +1,101 @@ +import type { + AccountInfoResponse, + AccountLoginRequest, + AccountLoginResponse, + AccountRegisterRequest, +} from "#app/@types/PokerogueAccountApi"; +import { SESSION_ID_COOKIE_NAME } from "#app/constants"; +import { ApiBase } from "#app/plugins/api/api-base"; +import { removeCookie, setCookie } from "#app/utils"; + +/** + * A wrapper for PokéRogue account API requests. + */ +export class PokerogueAccountApi extends ApiBase { + //#region Public + + /** + * Request the {@linkcode AccountInfoResponse | UserInfo} of the logged in user. + * The user is identified by the {@linkcode SESSION_ID_COOKIE_NAME | session cookie}. + */ + public async getInfo(): Promise<[data: AccountInfoResponse | null, status: number]> { + try { + const response = await this.doGet("/account/info"); + + if (response.ok) { + const resData = (await response.json()) as AccountInfoResponse; + return [ resData, response.status ]; + } else { + console.warn("Could not get account info!", response.status, response.statusText); + return [ null, response.status ]; + } + } catch (err) { + console.warn("Could not get account info!", err); + return [ null, 500 ]; + } + } + + /** + * Register a new account. + * @param registerData The {@linkcode AccountRegisterRequest} to send + * @returns An error message if something went wrong + */ + public async register(registerData: AccountRegisterRequest) { + try { + const response = await this.doPost("/account/register", registerData, "form-urlencoded"); + + if (response.ok) { + return null; + } else { + return response.text(); + } + } catch (err) { + console.warn("Register failed!", err); + } + + return "Unknown error!"; + } + + /** + * Send a login request. + * Sets the session cookie on success. + * @param loginData The {@linkcode AccountLoginRequest} to send + * @returns An error message if something went wrong + */ + public async login(loginData: AccountLoginRequest) { + try { + const response = await this.doPost("/account/login", loginData, "form-urlencoded"); + + if (response.ok) { + const loginResponse = (await response.json()) as AccountLoginResponse; + setCookie(SESSION_ID_COOKIE_NAME, loginResponse.token); + return null; + } else { + console.warn("Login failed!", response.status, response.statusText); + return response.text(); + } + } catch (err) { + console.warn("Login failed!", err); + } + + return "Unknown error!"; + } + + /** + * Send a logout request. + * **Always** (no matter if failed or not) removes the session cookie. + */ + public async logout() { + try { + const response = await this.doGet("/account/logout"); + + if (!response.ok) { + throw new Error(`${response.status}: ${response.statusText}`); + } + } catch (err) { + console.warn("Log out failed!", err); + } + + removeCookie(SESSION_ID_COOKIE_NAME); // we are always clearing the cookie. + } +} diff --git a/src/plugins/api/pokerogue-admin-api.ts b/src/plugins/api/pokerogue-admin-api.ts new file mode 100644 index 00000000000..eeba5319adc --- /dev/null +++ b/src/plugins/api/pokerogue-admin-api.ts @@ -0,0 +1,140 @@ +import type { + LinkAccountToDiscordIdRequest, + LinkAccountToGoogledIdRequest, + SearchAccountRequest, + SearchAccountResponse, + UnlinkAccountFromDiscordIdRequest, + UnlinkAccountFromGoogledIdRequest, +} from "#app/@types/PokerogueAdminApi"; +import { ApiBase } from "#app/plugins/api/api-base"; + +export class PokerogueAdminApi extends ApiBase { + public readonly ERR_USERNAME_NOT_FOUND: string = "Username not found!"; + + /** + * Links an account to a discord id. + * @param params The {@linkcode LinkAccountToDiscordIdRequest} to send + * @returns `null` if successful, error message if not + */ + public async linkAccountToDiscord(params: LinkAccountToDiscordIdRequest) { + try { + const response = await this.doPost("/admin/account/discordLink", params, "form-urlencoded"); + + if (response.ok) { + return null; + } else { + console.warn("Could not link account with discord!", response.status, response.statusText); + + if (response.status === 404) { + return this.ERR_USERNAME_NOT_FOUND; + } + } + } catch (err) { + console.warn("Could not link account with discord!", err); + } + + return this.ERR_GENERIC; + } + + /** + * Unlinks an account from a discord id. + * @param params The {@linkcode UnlinkAccountFromDiscordIdRequest} to send + * @returns `null` if successful, error message if not + */ + public async unlinkAccountFromDiscord(params: UnlinkAccountFromDiscordIdRequest) { + try { + const response = await this.doPost("/admin/account/discordUnlink", params, "form-urlencoded"); + + if (response.ok) { + return null; + } else { + console.warn("Could not unlink account from discord!", response.status, response.statusText); + + if (response.status === 404) { + return this.ERR_USERNAME_NOT_FOUND; + } + } + } catch (err) { + console.warn("Could not unlink account from discord!", err); + } + + return this.ERR_GENERIC; + } + + /** + * Links an account to a google id. + * @param params The {@linkcode LinkAccountToGoogledIdRequest} to send + * @returns `null` if successful, error message if not + */ + public async linkAccountToGoogleId(params: LinkAccountToGoogledIdRequest) { + try { + const response = await this.doPost("/admin/account/googleLink", params, "form-urlencoded"); + + if (response.ok) { + return null; + } else { + console.warn("Could not link account with google!", response.status, response.statusText); + + if (response.status === 404) { + return this.ERR_USERNAME_NOT_FOUND; + } + } + } catch (err) { + console.warn("Could not link account with google!", err); + } + + return this.ERR_GENERIC; + } + + /** + * Unlinks an account from a google id. + * @param params The {@linkcode UnlinkAccountFromGoogledIdRequest} to send + * @returns `null` if successful, error message if not + */ + public async unlinkAccountFromGoogleId(params: UnlinkAccountFromGoogledIdRequest) { + try { + const response = await this.doPost("/admin/account/googleUnlink", params, "form-urlencoded"); + + if (response.ok) { + return null; + } else { + console.warn("Could not unlink account from google!", response.status, response.statusText); + + if (response.status === 404) { + return this.ERR_USERNAME_NOT_FOUND; + } + } + } catch (err) { + console.warn("Could not unlink account from google!", err); + } + + return this.ERR_GENERIC; + } + + /** + * Search an account. + * @param params The {@linkcode SearchAccountRequest} to send + * @returns an array of {@linkcode SearchAccountResponse} and error. Both can be `undefined` + */ + public async searchAccount(params: SearchAccountRequest): Promise<[data?: SearchAccountResponse, error?: string]> { + try { + const urlSearchParams = this.toUrlSearchParams(params); + const response = await this.doGet(`/admin/account/adminSearch?${urlSearchParams}`); + + if (response.ok) { + const resData: SearchAccountResponse = await response.json(); + return [ resData, undefined ]; + } else { + console.warn("Could not find account!", response.status, response.statusText); + + if (response.status === 404) { + return [ undefined, this.ERR_USERNAME_NOT_FOUND ]; + } + } + } catch (err) { + console.warn("Could not find account!", err); + } + + return [ undefined, this.ERR_GENERIC ]; + } +} diff --git a/src/plugins/api/pokerogue-api.ts b/src/plugins/api/pokerogue-api.ts new file mode 100644 index 00000000000..92d0ff1bbbb --- /dev/null +++ b/src/plugins/api/pokerogue-api.ts @@ -0,0 +1,83 @@ +import type { TitleStatsResponse } from "#app/@types/PokerogueApi"; +import { ApiBase } from "#app/plugins/api/api-base"; +import { PokerogueAccountApi } from "#app/plugins/api/pokerogue-account-api"; +import { PokerogueAdminApi } from "#app/plugins/api/pokerogue-admin-api"; +import { PokerogueDailyApi } from "#app/plugins/api/pokerogue-daily-api"; +import { PokerogueSavedataApi } from "#app/plugins/api/pokerogue-savedata-api"; + +/** + * A wrapper for PokéRogue API requests. + */ +export class PokerogueApi extends ApiBase { + //#region Fields∏ + + public readonly account: PokerogueAccountApi; + public readonly daily: PokerogueDailyApi; + public readonly admin: PokerogueAdminApi; + public readonly savedata: PokerogueSavedataApi; + + //#region Public + + constructor(base: string) { + super(base); + this.account = new PokerogueAccountApi(base); + this.daily = new PokerogueDailyApi(base); + this.admin = new PokerogueAdminApi(base); + this.savedata = new PokerogueSavedataApi(base); + } + + /** + * Request game title-stats. + */ + public async getGameTitleStats() { + try { + const response = await this.doGet("/game/titlestats"); + return (await response.json()) as TitleStatsResponse; + } catch (err) { + console.warn("Could not get game title stats!", err); + return null; + } + } + + /** + * Unlink the currently logged in user from Discord. + * @returns `true` if unlinking was successful, `false` if not + */ + public async unlinkDiscord() { + try { + const response = await this.doPost("/auth/discord/logout"); + if (response.ok) { + return true; + } else { + console.warn(`Discord unlink failed (${response.status}: ${response.statusText})`); + } + } catch (err) { + console.warn("Could not unlink Discord!", err); + } + + return false; + } + + /** + * Unlink the currently logged in user from Google. + * @returns `true` if unlinking was successful, `false` if not + */ + public async unlinkGoogle() { + try { + const response = await this.doPost("/auth/google/logout"); + if (response.ok) { + return true; + } else { + console.warn(`Google unlink failed (${response.status}: ${response.statusText})`); + } + } catch (err) { + console.warn("Could not unlink Google!", err); + } + + return false; + } + + //#endregion +} + +export const pokerogueApi = new PokerogueApi(import.meta.env.VITE_SERVER_URL ?? "http://localhost:8001"); diff --git a/src/plugins/api/pokerogue-daily-api.ts b/src/plugins/api/pokerogue-daily-api.ts new file mode 100644 index 00000000000..c9319ae7fdc --- /dev/null +++ b/src/plugins/api/pokerogue-daily-api.ts @@ -0,0 +1,57 @@ +import type { GetDailyRankingsPageCountRequest, GetDailyRankingsRequest } from "#app/@types/PokerogueDailyApi"; +import { ApiBase } from "#app/plugins/api/api-base"; +import type { RankingEntry } from "#app/ui/daily-run-scoreboard"; + +/** + * A wrapper for daily-run PokéRogue API requests. + */ +export class PokerogueDailyApi extends ApiBase { + //#region Public + + /** + * Request the daily-run seed. + * @returns The active daily-run seed as `string`. + */ + public async getSeed() { + try { + const response = await this.doGet("/daily/seed"); + return response.text(); + } catch (err) { + console.warn("Could not get daily-run seed!", err); + return null; + } + } + + /** + * Get the daily rankings for a {@linkcode ScoreboardCategory}. + * @param params The {@linkcode GetDailyRankingsRequest} to send + */ + public async getRankings(params: GetDailyRankingsRequest) { + try { + const urlSearchParams = this.toUrlSearchParams(params); + const response = await this.doGet(`/daily/rankings?${urlSearchParams}`); + + return (await response.json()) as RankingEntry[]; + } catch (err) { + console.warn("Could not get daily rankings!", err); + return null; + } + } + + /** + * Get the page count of the daily rankings for a {@linkcode ScoreboardCategory}. + * @param params The {@linkcode GetDailyRankingsPageCountRequest} to send. + */ + public async getRankingsPageCount(params: GetDailyRankingsPageCountRequest) { + try { + const urlSearchParams = this.toUrlSearchParams(params); + const response = await this.doGet(`/daily/rankingpagecount?${urlSearchParams}`); + const json = await response.json(); + + return Number(json); + } catch (err) { + console.warn("Could not get daily rankings page count!", err); + return 1; + } + } +} diff --git a/src/plugins/api/pokerogue-savedata-api.ts b/src/plugins/api/pokerogue-savedata-api.ts new file mode 100644 index 00000000000..184bfbb4bdb --- /dev/null +++ b/src/plugins/api/pokerogue-savedata-api.ts @@ -0,0 +1,41 @@ +import type { UpdateAllSavedataRequest } from "#app/@types/PokerogueSavedataApi"; +import { MAX_INT_ATTR_VALUE } from "#app/constants"; +import { ApiBase } from "#app/plugins/api/api-base"; +import { PokerogueSessionSavedataApi } from "#app/plugins/api/pokerogue-session-savedata-api"; +import { PokerogueSystemSavedataApi } from "#app/plugins/api/pokerogue-system-savedata-api"; + +/** + * A wrapper for PokéRogue savedata API requests. + */ +export class PokerogueSavedataApi extends ApiBase { + //#region Fields + + public readonly system: PokerogueSystemSavedataApi; + public readonly session: PokerogueSessionSavedataApi; + + //#region Public + + constructor(base: string) { + super(base); + this.system = new PokerogueSystemSavedataApi(base); + this.session = new PokerogueSessionSavedataApi(base); + } + + /** + * Update all savedata + * @param bodyData The {@linkcode UpdateAllSavedataRequest | request data} to send + * @returns An error message if something went wrong + */ + public async updateAll(bodyData: UpdateAllSavedataRequest) { + try { + const rawBodyData = JSON.stringify(bodyData, (_k: any, v: any) => + typeof v === "bigint" ? (v <= MAX_INT_ATTR_VALUE ? Number(v) : v.toString()) : v + ); + const response = await this.doPost("/savedata/updateall", rawBodyData); + return await response.text(); + } catch (err) { + console.warn("Could not update all savedata!", err); + return "Unknown error"; + } + } +} diff --git a/src/plugins/api/pokerogue-session-savedata-api.ts b/src/plugins/api/pokerogue-session-savedata-api.ts new file mode 100644 index 00000000000..44a7b463849 --- /dev/null +++ b/src/plugins/api/pokerogue-session-savedata-api.ts @@ -0,0 +1,115 @@ +import type { + ClearSessionSavedataRequest, + ClearSessionSavedataResponse, + DeleteSessionSavedataRequest, + GetSessionSavedataRequest, + NewClearSessionSavedataRequest, + UpdateSessionSavedataRequest, +} from "#app/@types/PokerogueSessionSavedataApi"; +import { ApiBase } from "#app/plugins/api/api-base"; +import type { SessionSaveData } from "#app/system/game-data"; + +/** + * A wrapper for PokéRogue session savedata API requests. + */ +export class PokerogueSessionSavedataApi extends ApiBase { + //#region Public + + /** + * Mark a session as cleared aka "newclear".\ + * *This is **NOT** the same as {@linkcode clear | clear()}.* + * @param params The {@linkcode NewClearSessionSavedataRequest} to send + * @returns The raw savedata as `string`. + */ + public async newclear(params: NewClearSessionSavedataRequest) { + try { + const urlSearchParams = this.toUrlSearchParams(params); + const response = await this.doGet(`/savedata/session/newclear?${urlSearchParams}`); + const json = await response.json(); + + return Boolean(json); + } catch (err) { + console.warn("Could not newclear session!", err); + return false; + } + } + + /** + * Get a session savedata. + * @param params The {@linkcode GetSessionSavedataRequest} to send + * @returns The session as `string` + */ + public async get(params: GetSessionSavedataRequest) { + try { + const urlSearchParams = this.toUrlSearchParams(params); + const response = await this.doGet(`/savedata/session/get?${urlSearchParams}`); + + return await response.text(); + } catch (err) { + console.warn("Could not get session savedata!", err); + return null; + } + } + + /** + * Update a session savedata. + * @param params The {@linkcode UpdateSessionSavedataRequest} to send + * @param rawSavedata The raw savedata (as `string`) + * @returns An error message if something went wrong + */ + public async update(params: UpdateSessionSavedataRequest, rawSavedata: string) { + try { + const urlSearchParams = this.toUrlSearchParams(params); + const response = await this.doPost(`/savedata/session/update?${urlSearchParams}`, rawSavedata); + + return await response.text(); + } catch (err) { + console.warn("Could not update session savedata!", err); + } + + return "Unknown Error!"; + } + + /** + * Delete a session savedata slot. + * @param params The {@linkcode DeleteSessionSavedataRequest} to send + * @returns An error message if something went wrong + */ + public async delete(params: DeleteSessionSavedataRequest) { + try { + const urlSearchParams = this.toUrlSearchParams(params); + const response = await this.doGet(`/savedata/session/delete?${urlSearchParams}`); + + if (response.ok) { + return null; + } else { + return await response.text(); + } + } catch (err) { + console.warn("Could not delete session savedata!", err); + return "Unknown error"; + } + } + + /** + * Clears the session savedata of the given slot.\ + * *This is **NOT** the same as {@linkcode newclear | newclear()}.* + * @param params The {@linkcode ClearSessionSavedataRequest} to send + * @param sessionData The {@linkcode SessionSaveData} object + */ + public async clear(params: ClearSessionSavedataRequest, sessionData: SessionSaveData) { + try { + const urlSearchParams = this.toUrlSearchParams(params); + const response = await this.doPost(`/savedata/session/clear?${urlSearchParams}`, sessionData); + + return (await response.json()) as ClearSessionSavedataResponse; + } catch (err) { + console.warn("Could not clear session savedata!", err); + } + + return { + error: "Unknown error", + success: false, + } as ClearSessionSavedataResponse; + } +} diff --git a/src/plugins/api/pokerogue-system-savedata-api.ts b/src/plugins/api/pokerogue-system-savedata-api.ts new file mode 100644 index 00000000000..659584776c4 --- /dev/null +++ b/src/plugins/api/pokerogue-system-savedata-api.ts @@ -0,0 +1,77 @@ +import type { + GetSystemSavedataRequest, + UpdateSystemSavedataRequest, + VerifySystemSavedataRequest, + VerifySystemSavedataResponse, +} from "#app/@types/PokerogueSystemSavedataApi"; +import { ApiBase } from "#app/plugins/api/api-base"; + +/** + * A wrapper for PokéRogue system savedata API requests. + */ +export class PokerogueSystemSavedataApi extends ApiBase { + //#region Public + + /** + * Get a system savedata. + * @param params The {@linkcode GetSystemSavedataRequest} to send + * @returns The system savedata as `string` or `null` on error + */ + public async get(params: GetSystemSavedataRequest) { + try { + const urlSearchParams = this.toUrlSearchParams(params); + const response = await this.doGet(`/savedata/system/get?${urlSearchParams}`); + const rawSavedata = await response.text(); + + return rawSavedata; + } catch (err) { + console.warn("Could not get system savedata!", err); + return null; + } + } + + /** + * Verify if the session is valid. + * If not the {@linkcode SystemSaveData} is returned. + * @param params The {@linkcode VerifySystemSavedataRequest} to send + * @returns A {@linkcode SystemSaveData} if **NOT** valid, otherwise `null`. + * + * TODO: add handling for errors + */ + public async verify(params: VerifySystemSavedataRequest) { + const urlSearchParams = this.toUrlSearchParams(params); + const response = await this.doGet(`/savedata/system/verify?${urlSearchParams}`); + + if (response.ok) { + const verifySavedata = (await response.json()) as VerifySystemSavedataResponse; + + if (!verifySavedata.valid) { + console.warn("Invalid system savedata!"); + return verifySavedata.systemData; + } + } else { + console.warn("System savedata verification failed!", response.status, response.statusText); + } + + return null; + } + + /** + * Update a system savedata. + * @param params The {@linkcode UpdateSystemSavedataRequest} to send + * @param rawSystemData The raw {@linkcode SystemSaveData} + * @returns An error message if something went wrong + */ + public async update(params: UpdateSystemSavedataRequest, rawSystemData: string) { + try { + const urSearchParams = this.toUrlSearchParams(params); + const response = await this.doPost(`/savedata/system/update?${urSearchParams}`, rawSystemData); + + return await response.text(); + } catch (err) { + console.warn("Could not update system savedata!", err); + } + + return "Unknown Error"; + } +} diff --git a/src/plugins/cache-busted-loader-plugin.ts b/src/plugins/cache-busted-loader-plugin.ts index 3ed939c49dd..344da3eaa66 100644 --- a/src/plugins/cache-busted-loader-plugin.ts +++ b/src/plugins/cache-busted-loader-plugin.ts @@ -20,7 +20,7 @@ export default class CacheBustedLoaderPlugin extends Phaser.Loader.LoaderPlugin file.forEach(item => { if (manifest) { - const timestamp = manifest[`/${item.url.replace(/\/\//g, "/")}` ]; + const timestamp = manifest[`/${item.url.replace(/\/\//g, "/")}`]; if (timestamp) { item.url += `?t=${timestamp}`; } diff --git a/src/plugins/i18n.ts b/src/plugins/i18n.ts index ec3fe93c765..845739dfcac 100644 --- a/src/plugins/i18n.ts +++ b/src/plugins/i18n.ts @@ -1,18 +1,11 @@ +import { camelCaseToKebabCase, } from "#app/utils"; import i18next from "i18next"; import LanguageDetector from "i18next-browser-languagedetector"; +import HttpBackend from "i18next-http-backend"; import processor, { KoreanPostpositionProcessor } from "i18next-korean-postposition-processor"; +import pkg from "../../package.json"; -import { caEsConfig} from "#app/locales/ca_ES/config"; -import { deConfig } from "#app/locales/de/config"; -import { enConfig } from "#app/locales/en/config"; -import { esConfig } from "#app/locales/es/config"; -import { frConfig } from "#app/locales/fr/config"; -import { itConfig } from "#app/locales/it/config"; -import { koConfig } from "#app/locales/ko/config"; -import { jaConfig } from "#app/locales/ja/config"; -import { ptBrConfig } from "#app/locales/pt_BR/config"; -import { zhCnConfig } from "#app/locales/zh_CN/config"; -import { zhTwConfig } from "#app/locales/zh_TW/config"; +//#region Interfaces/Types interface LoadingFontFaceProperty { face: FontFace, @@ -20,6 +13,10 @@ interface LoadingFontFaceProperty { only?: Array } +//#region Constants + +let isInitialized = false; + const unicodeRanges = { fullwidth: "U+FF00-FFEF", hangul: "U+1100-11FF,U+3130-318F,U+A960-A97F,U+AC00-D7AF,U+D7B0-D7FF", @@ -28,10 +25,11 @@ const unicodeRanges = { CJKIdeograph: "U+4E00-9FFF", specialCharacters: "U+266A,U+2605,U+2665,U+2663" //♪.★,♥,♣ }; + const rangesByLanguage = { - korean: [unicodeRanges.CJKCommon, unicodeRanges.hangul].join(","), - chinese: [unicodeRanges.CJKCommon, unicodeRanges.fullwidth, unicodeRanges.CJKIdeograph].join(","), - japanese: [unicodeRanges.CJKCommon, unicodeRanges.fullwidth, unicodeRanges.kana, unicodeRanges.CJKIdeograph].join(",") + korean: [ unicodeRanges.CJKCommon, unicodeRanges.hangul ].join(","), + chinese: [ unicodeRanges.CJKCommon, unicodeRanges.fullwidth, unicodeRanges.CJKIdeograph ].join(","), + japanese: [ unicodeRanges.CJKCommon, unicodeRanges.fullwidth, unicodeRanges.kana, unicodeRanges.CJKIdeograph ].join(",") }; const fonts: Array = [ @@ -74,6 +72,21 @@ const fonts: Array = [ }, ]; +/** maps namespaces that deviate from the file-name */ +const namespaceMap = { + titles: "trainer-titles", + moveTriggers: "move-trigger", + abilityTriggers: "ability-trigger", + battlePokemonForm: "pokemon-form-battle", + miscDialogue: "dialogue-misc", + battleSpecDialogue: "dialogue-final-boss", + doubleBattleDialogue: "dialogue-double-battle", + splashMessages: "splash-texts", + mysteryEncounterMessages: "mystery-encounter-texts", +}; + +//#region Functions + async function initFonts(language: string | undefined) { const results = await Promise.allSettled( fonts @@ -89,6 +102,27 @@ async function initFonts(language: string | undefined) { } } +/** + * I18n money formatter with. (useful for BBCode coloring of text)\ + * *If you don't want the BBCode tag applied, just use 'number' formatter* + * @example Input: `{{myMoneyValue, money}}` + * Output: `@[MONEY]{₽100,000,000}` + * @param amount the money amount + * @returns a money formatted string + */ +function i18nMoneyFormatter(amount: any): string { + if (isNaN(Number(amount))) { + console.warn(`i18nMoneyFormatter: value "${amount}" is not a number!`); + } + + return `@[MONEY]{${i18next.t("common:money", { amount })}}`; +} + +//#region Exports + +/** + * Initialize i18n with fonts + */ export async function initI18n(): Promise { // Prevent reinitialization if (isInitialized) { @@ -113,15 +147,116 @@ export async function initI18n(): Promise { * A: In src/system/settings.ts, add a new case to the Setting.Language switch statement. */ + i18next.use(HttpBackend); i18next.use(LanguageDetector); i18next.use(processor); i18next.use(new KoreanPostpositionProcessor()); await i18next.init({ - nonExplicitSupportedLngs: true, fallbackLng: "en", - supportedLngs: ["en", "es", "fr", "it", "de", "zh", "pt", "ko", "ja", "ca"], + supportedLngs: [ "en", "es-ES", "fr", "it", "de", "zh-CN", "zh-TW", "pt-BR", "ko", "ja", "ca-ES" ], + backend: { + loadPath(lng: string, [ ns ]: string[]) { + let fileName: string; + if (namespaceMap[ns]) { + fileName = namespaceMap[ns]; + } else if (ns.startsWith("mysteryEncounters/")) { + fileName = camelCaseToKebabCase(ns + "Dialogue"); + } else { + fileName = camelCaseToKebabCase(ns); + } + return `./locales/${lng}/${fileName}.json?v=${pkg.version}`; + }, + }, defaultNS: "menu", - ns: Object.keys(enConfig), + ns: [ + "ability", + "abilityTriggers", + "arenaFlyout", + "arenaTag", + "battle", + "battleScene", + "battleInfo", + "battleMessageUiHandler", + "battlePokemonForm", + "battlerTags", + "berry", + "bgmName", + "biome", + "challenges", + "commandUiHandler", + "common", + "achv", + "dialogue", + "battleSpecDialogue", + "miscDialogue", + "doubleBattleDialogue", + "egg", + "fightUiHandler", + "filterBar", + "gameMode", + "gameStatsUiHandler", + "growth", + "menu", + "menuUiHandler", + "modifier", + "modifierType", + "move", + "nature", + "pokeball", + "pokemon", + "pokemonForm", + "pokemonInfo", + "pokemonInfoContainer", + "pokemonSummary", + "saveSlotSelectUiHandler", + "settings", + "splashMessages", + "starterSelectUiHandler", + "statusEffect", + "terrain", + "titles", + "trainerClasses", + "trainerNames", + "tutorial", + "voucher", + "weather", + "partyUiHandler", + "modifierSelectUiHandler", + "moveTriggers", + "runHistory", + "mysteryEncounters/mysteriousChallengers", + "mysteryEncounters/mysteriousChest", + "mysteryEncounters/darkDeal", + "mysteryEncounters/fightOrFlight", + "mysteryEncounters/slumberingSnorlax", + "mysteryEncounters/trainingSession", + "mysteryEncounters/departmentStoreSale", + "mysteryEncounters/shadyVitaminDealer", + "mysteryEncounters/fieldTrip", + "mysteryEncounters/safariZone", + "mysteryEncounters/lostAtSea", + "mysteryEncounters/fieryFallout", + "mysteryEncounters/theStrongStuff", + "mysteryEncounters/thePokemonSalesman", + "mysteryEncounters/anOfferYouCantRefuse", + "mysteryEncounters/delibirdy", + "mysteryEncounters/absoluteAvarice", + "mysteryEncounters/aTrainersTest", + "mysteryEncounters/trashToTreasure", + "mysteryEncounters/berriesAbound", + "mysteryEncounters/clowningAround", + "mysteryEncounters/partTimer", + "mysteryEncounters/dancingLessons", + "mysteryEncounters/weirdDream", + "mysteryEncounters/theWinstrateChallenge", + "mysteryEncounters/teleportingHijinks", + "mysteryEncounters/bugTypeSuperfan", + "mysteryEncounters/funAndGames", + "mysteryEncounters/uncommonBreed", + "mysteryEncounters/globalTradeSystem", + "mysteryEncounters/theExpertPokemonBreeder", + "mysteryEncounterMessages", + ], detection: { lookupLocalStorage: "prLang" }, @@ -129,71 +264,21 @@ export async function initI18n(): Promise { interpolation: { escapeValue: false, }, - resources: { - en: { - ...enConfig - }, - es: { - ...esConfig - }, - fr: { - ...frConfig - }, - it: { - ...itConfig - }, - de: { - ...deConfig - }, - "pt-BR": { - ...ptBrConfig - }, - "zh-CN": { - ...zhCnConfig - }, - "zh-TW": { - ...zhTwConfig - }, - ko: { - ...koConfig - }, - ja: { - ...jaConfig - }, - "ca-ES": { - ...caEsConfig - } - }, - postProcess: ["korean-postposition"], + postProcess: [ "korean-postposition" ], }); - // Input: {{myMoneyValue, money}} - // Output: @[MONEY]{₽100,000,000} (useful for BBCode coloring of text) - // If you don't want the BBCode tag applied, just use 'number' formatter - i18next.services.formatter?.add("money", (value, lng, options) => { - const numberFormattedString = Intl.NumberFormat(lng, options).format(value); - switch (lng) { - case "ja": - return `@[MONEY]{${numberFormattedString}}円`; - case "de": - case "es": - case "fr": - case "it": - return `@[MONEY]{${numberFormattedString} ₽}`; - default: - // English and other languages that use same format - return `@[MONEY]{₽${numberFormattedString}}`; - } - }); + + if (i18next.services.formatter) { + i18next.services.formatter.add("money", i18nMoneyFormatter); + } await initFonts(localStorage.getItem("prLang") ?? undefined); } -export default i18next; - export function getIsInitialized(): boolean { return isInitialized; } -let isInitialized = false; +export default i18next; +//#endregion diff --git a/src/plugins/vite/vite-minify-json-plugin.ts b/src/plugins/vite/vite-minify-json-plugin.ts index 57130669075..a638271562f 100644 --- a/src/plugins/vite/vite-minify-json-plugin.ts +++ b/src/plugins/vite/vite-minify-json-plugin.ts @@ -41,7 +41,7 @@ export function minifyJsonPlugin(basePath: string | string[], recursive?: boolea }, async closeBundle() { console.log("Minifying JSON files..."); - const basePathes = Array.isArray(basePath) ? basePath : [basePath]; + const basePathes = Array.isArray(basePath) ? basePath : [ basePath ]; basePathes.forEach((basePath) => { const baseDir = path.resolve(buildDir, basePath); diff --git a/src/scene-base.ts b/src/scene-base.ts index 298b8096e54..9af97b8e6d4 100644 --- a/src/scene-base.ts +++ b/src/scene-base.ts @@ -81,7 +81,7 @@ export class SceneBase extends Phaser.Scene { filenames = [ filenames ]; } for (const f of filenames as string[]) { - this.load.audio(folder+key, this.getCachedUrl(`audio/${folder}${f}`)); + this.load.audio(folder + key, this.getCachedUrl(`audio/${folder}${f}`)); } } diff --git a/src/system/achv.ts b/src/system/achv.ts index 6170fe23e1d..d94fcba48f2 100644 --- a/src/system/achv.ts +++ b/src/system/achv.ts @@ -1,7 +1,7 @@ import { Modifier } from "typescript"; import BattleScene from "../battle-scene"; import { TurnHeldItemTransferModifier } from "../modifier/modifier"; -import { pokemonEvolutions } from "#app/data/pokemon-evolutions"; +import { pokemonEvolutions } from "#app/data/balance/pokemon-evolutions"; import i18next from "i18next"; import * as Utils from "../utils"; import { PlayerGender } from "#enums/player-gender"; @@ -109,7 +109,7 @@ export class DamageAchv extends Achv { damageAmount: integer; constructor(localizationKey: string, name: string, damageAmount: integer, iconImage: string, score: integer) { - super(localizationKey, name, "", iconImage, score, (_scene: BattleScene, args: any[]) => (args[0] as Utils.NumberHolder).value >= this.damageAmount); + super(localizationKey, name, "", iconImage, score, (_scene: BattleScene, args: any[]) => (args[0] instanceof Utils.NumberHolder ? args[0].value : args[0]) >= this.damageAmount); this.damageAmount = damageAmount; } } @@ -118,7 +118,7 @@ export class HealAchv extends Achv { healAmount: integer; constructor(localizationKey: string, name: string, healAmount: integer, iconImage: string, score: integer) { - super(localizationKey, name, "", iconImage, score, (_scene: BattleScene, args: any[]) => (args[0] as Utils.NumberHolder).value >= this.healAmount); + super(localizationKey, name, "", iconImage, score, (_scene: BattleScene, args: any[]) => (args[0] instanceof Utils.NumberHolder ? args[0].value : args[0]) >= this.healAmount); this.healAmount = healAmount; } } @@ -127,7 +127,7 @@ export class LevelAchv extends Achv { level: integer; constructor(localizationKey: string, name: string, level: integer, iconImage: string, score: integer) { - super(localizationKey, name, "", iconImage, score, (scene: BattleScene, args: any[]) => (args[0] as Utils.IntegerHolder).value >= this.level); + super(localizationKey, name, "", iconImage, score, (scene: BattleScene, args: any[]) => (args[0] instanceof Utils.NumberHolder ? args[0].value : args[0]) >= this.level); this.level = level; } } @@ -156,131 +156,133 @@ export function getAchievementDescription(localizationKey: string): string { const genderStr = PlayerGender[genderIndex].toLowerCase(); switch (localizationKey) { - case "10K_MONEY": - return i18next.t("achv:MoneyAchv.description", {context: genderStr, "moneyAmount": achvs._10K_MONEY.moneyAmount.toLocaleString("en-US")}); - case "100K_MONEY": - return i18next.t("achv:MoneyAchv.description", {context: genderStr, "moneyAmount": achvs._100K_MONEY.moneyAmount.toLocaleString("en-US")}); - case "1M_MONEY": - return i18next.t("achv:MoneyAchv.description", {context: genderStr, "moneyAmount": achvs._1M_MONEY.moneyAmount.toLocaleString("en-US")}); - case "10M_MONEY": - return i18next.t("achv:MoneyAchv.description", {context: genderStr, "moneyAmount": achvs._10M_MONEY.moneyAmount.toLocaleString("en-US")}); - case "250_DMG": - return i18next.t("achv:DamageAchv.description", {context: genderStr, "damageAmount": achvs._250_DMG.damageAmount.toLocaleString("en-US")}); - case "1000_DMG": - return i18next.t("achv:DamageAchv.description", {context: genderStr, "damageAmount": achvs._1000_DMG.damageAmount.toLocaleString("en-US")}); - case "2500_DMG": - return i18next.t("achv:DamageAchv.description", {context: genderStr, "damageAmount": achvs._2500_DMG.damageAmount.toLocaleString("en-US")}); - case "10000_DMG": - return i18next.t("achv:DamageAchv.description", {context: genderStr, "damageAmount": achvs._10000_DMG.damageAmount.toLocaleString("en-US")}); - case "250_HEAL": - return i18next.t("achv:HealAchv.description", {context: genderStr, "healAmount": achvs._250_HEAL.healAmount.toLocaleString("en-US"), "HP": i18next.t(getShortenedStatKey(Stat.HP))}); - case "1000_HEAL": - return i18next.t("achv:HealAchv.description", {context: genderStr, "healAmount": achvs._1000_HEAL.healAmount.toLocaleString("en-US"), "HP": i18next.t(getShortenedStatKey(Stat.HP))}); - case "2500_HEAL": - return i18next.t("achv:HealAchv.description", {context: genderStr, "healAmount": achvs._2500_HEAL.healAmount.toLocaleString("en-US"), "HP": i18next.t(getShortenedStatKey(Stat.HP))}); - case "10000_HEAL": - return i18next.t("achv:HealAchv.description", {context: genderStr, "healAmount": achvs._10000_HEAL.healAmount.toLocaleString("en-US"), "HP": i18next.t(getShortenedStatKey(Stat.HP))}); - case "LV_100": - return i18next.t("achv:LevelAchv.description", {context: genderStr, "level": achvs.LV_100.level}); - case "LV_250": - return i18next.t("achv:LevelAchv.description", {context: genderStr, "level": achvs.LV_250.level}); - case "LV_1000": - return i18next.t("achv:LevelAchv.description", {context: genderStr, "level": achvs.LV_1000.level}); - case "10_RIBBONS": - return i18next.t("achv:RibbonAchv.description", {context: genderStr, "ribbonAmount": achvs._10_RIBBONS.ribbonAmount.toLocaleString("en-US")}); - case "25_RIBBONS": - return i18next.t("achv:RibbonAchv.description", {context: genderStr, "ribbonAmount": achvs._25_RIBBONS.ribbonAmount.toLocaleString("en-US")}); - case "50_RIBBONS": - return i18next.t("achv:RibbonAchv.description", {context: genderStr, "ribbonAmount": achvs._50_RIBBONS.ribbonAmount.toLocaleString("en-US")}); - case "75_RIBBONS": - return i18next.t("achv:RibbonAchv.description", {context: genderStr, "ribbonAmount": achvs._75_RIBBONS.ribbonAmount.toLocaleString("en-US")}); - case "100_RIBBONS": - return i18next.t("achv:RibbonAchv.description", {context: genderStr, "ribbonAmount": achvs._100_RIBBONS.ribbonAmount.toLocaleString("en-US")}); - case "TRANSFER_MAX_STAT_STAGE": - return i18next.t("achv:TRANSFER_MAX_STAT_STAGE.description", { context: genderStr }); - case "MAX_FRIENDSHIP": - return i18next.t("achv:MAX_FRIENDSHIP.description", { context: genderStr }); - case "MEGA_EVOLVE": - return i18next.t("achv:MEGA_EVOLVE.description", { context: genderStr }); - case "GIGANTAMAX": - return i18next.t("achv:GIGANTAMAX.description", { context: genderStr }); - case "TERASTALLIZE": - return i18next.t("achv:TERASTALLIZE.description", { context: genderStr }); - case "STELLAR_TERASTALLIZE": - return i18next.t("achv:STELLAR_TERASTALLIZE.description", { context: genderStr }); - case "SPLICE": - return i18next.t("achv:SPLICE.description", { context: genderStr }); - case "MINI_BLACK_HOLE": - return i18next.t("achv:MINI_BLACK_HOLE.description", { context: genderStr }); - case "CATCH_MYTHICAL": - return i18next.t("achv:CATCH_MYTHICAL.description", { context: genderStr }); - case "CATCH_SUB_LEGENDARY": - return i18next.t("achv:CATCH_SUB_LEGENDARY.description", { context: genderStr }); - case "CATCH_LEGENDARY": - return i18next.t("achv:CATCH_LEGENDARY.description", { context: genderStr }); - case "SEE_SHINY": - return i18next.t("achv:SEE_SHINY.description", { context: genderStr }); - case "SHINY_PARTY": - return i18next.t("achv:SHINY_PARTY.description", { context: genderStr }); - case "HATCH_MYTHICAL": - return i18next.t("achv:HATCH_MYTHICAL.description", { context: genderStr }); - case "HATCH_SUB_LEGENDARY": - return i18next.t("achv:HATCH_SUB_LEGENDARY.description", { context: genderStr }); - case "HATCH_LEGENDARY": - return i18next.t("achv:HATCH_LEGENDARY.description", { context: genderStr }); - case "HATCH_SHINY": - return i18next.t("achv:HATCH_SHINY.description", { context: genderStr }); - case "HIDDEN_ABILITY": - return i18next.t("achv:HIDDEN_ABILITY.description", { context: genderStr }); - case "PERFECT_IVS": - return i18next.t("achv:PERFECT_IVS.description", { context: genderStr }); - case "CLASSIC_VICTORY": - return i18next.t("achv:CLASSIC_VICTORY.description", { context: genderStr }); - case "UNEVOLVED_CLASSIC_VICTORY": - return i18next.t("achv:UNEVOLVED_CLASSIC_VICTORY.description", { context: genderStr }); - case "MONO_GEN_ONE": - return i18next.t("achv:MONO_GEN_ONE.description", { context: genderStr }); - case "MONO_GEN_TWO": - return i18next.t("achv:MONO_GEN_TWO.description", { context: genderStr }); - case "MONO_GEN_THREE": - return i18next.t("achv:MONO_GEN_THREE.description", { context: genderStr }); - case "MONO_GEN_FOUR": - return i18next.t("achv:MONO_GEN_FOUR.description", { context: genderStr }); - case "MONO_GEN_FIVE": - return i18next.t("achv:MONO_GEN_FIVE.description", { context: genderStr }); - case "MONO_GEN_SIX": - return i18next.t("achv:MONO_GEN_SIX.description", { context: genderStr }); - case "MONO_GEN_SEVEN": - return i18next.t("achv:MONO_GEN_SEVEN.description", { context: genderStr }); - case "MONO_GEN_EIGHT": - return i18next.t("achv:MONO_GEN_EIGHT.description", { context: genderStr }); - case "MONO_GEN_NINE": - return i18next.t("achv:MONO_GEN_NINE.description", { context: genderStr }); - case "MONO_NORMAL": - case "MONO_FIGHTING": - case "MONO_FLYING": - case "MONO_POISON": - case "MONO_GROUND": - case "MONO_ROCK": - case "MONO_BUG": - case "MONO_GHOST": - case "MONO_STEEL": - case "MONO_FIRE": - case "MONO_WATER": - case "MONO_GRASS": - case "MONO_ELECTRIC": - case "MONO_PSYCHIC": - case "MONO_ICE": - case "MONO_DRAGON": - case "MONO_DARK": - case "MONO_FAIRY": - return i18next.t("achv:MonoType.description", { context: genderStr, "type": i18next.t(`pokemonInfo:Type.${localizationKey.slice(5)}`) }); - case "FRESH_START": - return i18next.t("achv:FRESH_START.description", { context: genderStr }); - case "INVERSE_BATTLE": - return i18next.t("achv:INVERSE_BATTLE.description", { context: genderStr }); - default: - return ""; + case "10K_MONEY": + return i18next.t("achv:MoneyAchv.description", { context: genderStr, "moneyAmount": achvs._10K_MONEY.moneyAmount.toLocaleString("en-US") }); + case "100K_MONEY": + return i18next.t("achv:MoneyAchv.description", { context: genderStr, "moneyAmount": achvs._100K_MONEY.moneyAmount.toLocaleString("en-US") }); + case "1M_MONEY": + return i18next.t("achv:MoneyAchv.description", { context: genderStr, "moneyAmount": achvs._1M_MONEY.moneyAmount.toLocaleString("en-US") }); + case "10M_MONEY": + return i18next.t("achv:MoneyAchv.description", { context: genderStr, "moneyAmount": achvs._10M_MONEY.moneyAmount.toLocaleString("en-US") }); + case "250_DMG": + return i18next.t("achv:DamageAchv.description", { context: genderStr, "damageAmount": achvs._250_DMG.damageAmount.toLocaleString("en-US") }); + case "1000_DMG": + return i18next.t("achv:DamageAchv.description", { context: genderStr, "damageAmount": achvs._1000_DMG.damageAmount.toLocaleString("en-US") }); + case "2500_DMG": + return i18next.t("achv:DamageAchv.description", { context: genderStr, "damageAmount": achvs._2500_DMG.damageAmount.toLocaleString("en-US") }); + case "10000_DMG": + return i18next.t("achv:DamageAchv.description", { context: genderStr, "damageAmount": achvs._10000_DMG.damageAmount.toLocaleString("en-US") }); + case "250_HEAL": + return i18next.t("achv:HealAchv.description", { context: genderStr, "healAmount": achvs._250_HEAL.healAmount.toLocaleString("en-US"), "HP": i18next.t(getShortenedStatKey(Stat.HP)) }); + case "1000_HEAL": + return i18next.t("achv:HealAchv.description", { context: genderStr, "healAmount": achvs._1000_HEAL.healAmount.toLocaleString("en-US"), "HP": i18next.t(getShortenedStatKey(Stat.HP)) }); + case "2500_HEAL": + return i18next.t("achv:HealAchv.description", { context: genderStr, "healAmount": achvs._2500_HEAL.healAmount.toLocaleString("en-US"), "HP": i18next.t(getShortenedStatKey(Stat.HP)) }); + case "10000_HEAL": + return i18next.t("achv:HealAchv.description", { context: genderStr, "healAmount": achvs._10000_HEAL.healAmount.toLocaleString("en-US"), "HP": i18next.t(getShortenedStatKey(Stat.HP)) }); + case "LV_100": + return i18next.t("achv:LevelAchv.description", { context: genderStr, "level": achvs.LV_100.level }); + case "LV_250": + return i18next.t("achv:LevelAchv.description", { context: genderStr, "level": achvs.LV_250.level }); + case "LV_1000": + return i18next.t("achv:LevelAchv.description", { context: genderStr, "level": achvs.LV_1000.level }); + case "10_RIBBONS": + return i18next.t("achv:RibbonAchv.description", { context: genderStr, "ribbonAmount": achvs._10_RIBBONS.ribbonAmount.toLocaleString("en-US") }); + case "25_RIBBONS": + return i18next.t("achv:RibbonAchv.description", { context: genderStr, "ribbonAmount": achvs._25_RIBBONS.ribbonAmount.toLocaleString("en-US") }); + case "50_RIBBONS": + return i18next.t("achv:RibbonAchv.description", { context: genderStr, "ribbonAmount": achvs._50_RIBBONS.ribbonAmount.toLocaleString("en-US") }); + case "75_RIBBONS": + return i18next.t("achv:RibbonAchv.description", { context: genderStr, "ribbonAmount": achvs._75_RIBBONS.ribbonAmount.toLocaleString("en-US") }); + case "100_RIBBONS": + return i18next.t("achv:RibbonAchv.description", { context: genderStr, "ribbonAmount": achvs._100_RIBBONS.ribbonAmount.toLocaleString("en-US") }); + case "TRANSFER_MAX_STAT_STAGE": + return i18next.t("achv:TRANSFER_MAX_STAT_STAGE.description", { context: genderStr }); + case "MAX_FRIENDSHIP": + return i18next.t("achv:MAX_FRIENDSHIP.description", { context: genderStr }); + case "MEGA_EVOLVE": + return i18next.t("achv:MEGA_EVOLVE.description", { context: genderStr }); + case "GIGANTAMAX": + return i18next.t("achv:GIGANTAMAX.description", { context: genderStr }); + case "TERASTALLIZE": + return i18next.t("achv:TERASTALLIZE.description", { context: genderStr }); + case "STELLAR_TERASTALLIZE": + return i18next.t("achv:STELLAR_TERASTALLIZE.description", { context: genderStr }); + case "SPLICE": + return i18next.t("achv:SPLICE.description", { context: genderStr }); + case "MINI_BLACK_HOLE": + return i18next.t("achv:MINI_BLACK_HOLE.description", { context: genderStr }); + case "CATCH_MYTHICAL": + return i18next.t("achv:CATCH_MYTHICAL.description", { context: genderStr }); + case "CATCH_SUB_LEGENDARY": + return i18next.t("achv:CATCH_SUB_LEGENDARY.description", { context: genderStr }); + case "CATCH_LEGENDARY": + return i18next.t("achv:CATCH_LEGENDARY.description", { context: genderStr }); + case "SEE_SHINY": + return i18next.t("achv:SEE_SHINY.description", { context: genderStr }); + case "SHINY_PARTY": + return i18next.t("achv:SHINY_PARTY.description", { context: genderStr }); + case "HATCH_MYTHICAL": + return i18next.t("achv:HATCH_MYTHICAL.description", { context: genderStr }); + case "HATCH_SUB_LEGENDARY": + return i18next.t("achv:HATCH_SUB_LEGENDARY.description", { context: genderStr }); + case "HATCH_LEGENDARY": + return i18next.t("achv:HATCH_LEGENDARY.description", { context: genderStr }); + case "HATCH_SHINY": + return i18next.t("achv:HATCH_SHINY.description", { context: genderStr }); + case "HIDDEN_ABILITY": + return i18next.t("achv:HIDDEN_ABILITY.description", { context: genderStr }); + case "PERFECT_IVS": + return i18next.t("achv:PERFECT_IVS.description", { context: genderStr }); + case "CLASSIC_VICTORY": + return i18next.t("achv:CLASSIC_VICTORY.description", { context: genderStr }); + case "UNEVOLVED_CLASSIC_VICTORY": + return i18next.t("achv:UNEVOLVED_CLASSIC_VICTORY.description", { context: genderStr }); + case "MONO_GEN_ONE": + return i18next.t("achv:MONO_GEN_ONE.description", { context: genderStr }); + case "MONO_GEN_TWO": + return i18next.t("achv:MONO_GEN_TWO.description", { context: genderStr }); + case "MONO_GEN_THREE": + return i18next.t("achv:MONO_GEN_THREE.description", { context: genderStr }); + case "MONO_GEN_FOUR": + return i18next.t("achv:MONO_GEN_FOUR.description", { context: genderStr }); + case "MONO_GEN_FIVE": + return i18next.t("achv:MONO_GEN_FIVE.description", { context: genderStr }); + case "MONO_GEN_SIX": + return i18next.t("achv:MONO_GEN_SIX.description", { context: genderStr }); + case "MONO_GEN_SEVEN": + return i18next.t("achv:MONO_GEN_SEVEN.description", { context: genderStr }); + case "MONO_GEN_EIGHT": + return i18next.t("achv:MONO_GEN_EIGHT.description", { context: genderStr }); + case "MONO_GEN_NINE": + return i18next.t("achv:MONO_GEN_NINE.description", { context: genderStr }); + case "MONO_NORMAL": + case "MONO_FIGHTING": + case "MONO_FLYING": + case "MONO_POISON": + case "MONO_GROUND": + case "MONO_ROCK": + case "MONO_BUG": + case "MONO_GHOST": + case "MONO_STEEL": + case "MONO_FIRE": + case "MONO_WATER": + case "MONO_GRASS": + case "MONO_ELECTRIC": + case "MONO_PSYCHIC": + case "MONO_ICE": + case "MONO_DRAGON": + case "MONO_DARK": + case "MONO_FAIRY": + return i18next.t("achv:MonoType.description", { context: genderStr, "type": i18next.t(`pokemonInfo:Type.${localizationKey.slice(5)}`) }); + case "FRESH_START": + return i18next.t("achv:FRESH_START.description", { context: genderStr }); + case "INVERSE_BATTLE": + return i18next.t("achv:INVERSE_BATTLE.description", { context: genderStr }); + case "BREEDERS_IN_SPACE": + return i18next.t("achv:BREEDERS_IN_SPACE.description", { context: genderStr }); + default: + return ""; } } @@ -326,7 +328,7 @@ export const achvs = { HIDDEN_ABILITY: new Achv("HIDDEN_ABILITY", "", "HIDDEN_ABILITY.description", "ability_charm", 75), PERFECT_IVS: new Achv("PERFECT_IVS", "", "PERFECT_IVS.description", "blunder_policy", 100), CLASSIC_VICTORY: new Achv("CLASSIC_VICTORY", "", "CLASSIC_VICTORY.description", "relic_crown", 150, c => c.gameData.gameStats.sessionsWon === 0), - UNEVOLVED_CLASSIC_VICTORY: new Achv("UNEVOLVED_CLASSIC_VICTORY", "", "UNEVOLVED_CLASSIC_VICTORY.description", "eviolite", 175, c => c.getParty().some(p => p.getSpeciesForm(true).speciesId in pokemonEvolutions)), + UNEVOLVED_CLASSIC_VICTORY: new Achv("UNEVOLVED_CLASSIC_VICTORY", "", "UNEVOLVED_CLASSIC_VICTORY.description", "eviolite", 175, c => c.getPlayerParty().some(p => p.getSpeciesForm(true).speciesId in pokemonEvolutions)), MONO_GEN_ONE_VICTORY: new ChallengeAchv("MONO_GEN_ONE", "", "MONO_GEN_ONE.description", "ribbon_gen1", 100, (c, scene) => c instanceof SingleGenerationChallenge && c.value === 1 && !scene.gameMode.challenges.some(c => c.id === Challenges.INVERSE_BATTLE && c.value > 0)), MONO_GEN_TWO_VICTORY: new ChallengeAchv("MONO_GEN_TWO", "", "MONO_GEN_TWO.description", "ribbon_gen2", 100, (c, scene) => c instanceof SingleGenerationChallenge && c.value === 2 && !scene.gameMode.challenges.some(c => c.id === Challenges.INVERSE_BATTLE && c.value > 0)), MONO_GEN_THREE_VICTORY: new ChallengeAchv("MONO_GEN_THREE", "", "MONO_GEN_THREE.description", "ribbon_gen3", 100, (c, scene) => c instanceof SingleGenerationChallenge && c.value === 3 && !scene.gameMode.challenges.some(c => c.id === Challenges.INVERSE_BATTLE && c.value > 0)), @@ -356,6 +358,7 @@ export const achvs = { MONO_FAIRY: new ChallengeAchv("MONO_FAIRY", "", "MONO_FAIRY.description", "fairy_feather", 100, (c, scene) => c instanceof SingleTypeChallenge && c.value === 18 && !scene.gameMode.challenges.some(c => c.id === Challenges.INVERSE_BATTLE && c.value > 0)), FRESH_START: new ChallengeAchv("FRESH_START", "", "FRESH_START.description", "reviver_seed", 100, (c, scene) => c instanceof FreshStartChallenge && c.value > 0 && !scene.gameMode.challenges.some(c => c.id === Challenges.INVERSE_BATTLE && c.value > 0)), INVERSE_BATTLE: new ChallengeAchv("INVERSE_BATTLE", "", "INVERSE_BATTLE.description", "inverse", 100, c => c instanceof InverseBattleChallenge && c.value > 0), + BREEDERS_IN_SPACE: new Achv("BREEDERS_IN_SPACE", "", "BREEDERS_IN_SPACE.description", "moon_stone", 100).setSecret(), }; export function initAchievements() { diff --git a/src/system/arena-data.ts b/src/system/arena-data.ts index 5b907805372..ba37de0ed0e 100644 --- a/src/system/arena-data.ts +++ b/src/system/arena-data.ts @@ -1,5 +1,5 @@ import { Arena } from "../field/arena"; -import { ArenaTag } from "../data/arena-tag"; +import { ArenaTag, loadArenaTag } from "../data/arena-tag"; import { Biome } from "#enums/biome"; import { Weather } from "../data/weather"; import { Terrain } from "#app/data/terrain"; @@ -15,6 +15,10 @@ export default class ArenaData { this.biome = sourceArena ? sourceArena.biomeType : source.biome; this.weather = sourceArena ? sourceArena.weather : source.weather ? new Weather(source.weather.weatherType, source.weather.turnsLeft) : null; this.terrain = sourceArena ? sourceArena.terrain : source.terrain ? new Terrain(source.terrain.terrainType, source.terrain.turnsLeft) : null; - this.tags = sourceArena ? sourceArena.tags : []; + this.tags = []; + + if (source.tags) { + this.tags = source.tags.map(t => loadArenaTag(t)); + } } } diff --git a/src/system/egg-data.ts b/src/system/egg-data.ts index 785ae364efe..aa06316a61f 100644 --- a/src/system/egg-data.ts +++ b/src/system/egg-data.ts @@ -1,6 +1,6 @@ import { EggTier } from "#enums/egg-type"; import { Species } from "#enums/species"; -import { VariantTier } from "#enums/variant-tiers"; +import { VariantTier } from "#enums/variant-tier"; import { EGG_SEED, Egg } from "../data/egg"; import { EggSourceType } from "#app/enums/egg-source-types"; @@ -41,7 +41,7 @@ export default class EggData { if (!this.species) { return new Egg({ id: this.id, hatchWaves: this.hatchWaves, sourceType: this.sourceType, timestamp: this.timestamp, tier: Math.floor(this.id / EGG_SEED) }); } else { - return new Egg({id: this.id, tier: this.tier, sourceType: this.sourceType, hatchWaves: this.hatchWaves, + return new Egg({ id: this.id, tier: this.tier, sourceType: this.sourceType, hatchWaves: this.hatchWaves, timestamp: this.timestamp, variantTier: this.variantTier, isShiny: this.isShiny, species: this.species, eggMoveIndex: this.eggMoveIndex, overrideHiddenAbility: this.overrideHiddenAbility }); } diff --git a/src/system/game-data.ts b/src/system/game-data.ts index 04fef4a81da..3e3a6ce8f8b 100644 --- a/src/system/game-data.ts +++ b/src/system/game-data.ts @@ -1,53 +1,55 @@ import i18next from "i18next"; -import BattleScene, { PokeballCounts, bypassLogin } from "../battle-scene"; -import Pokemon, { EnemyPokemon, PlayerPokemon } from "../field/pokemon"; -import { pokemonPrevolutions } from "../data/pokemon-evolutions"; -import PokemonSpecies, { allSpecies, getPokemonSpecies, noStarterFormKeys, speciesStarters } from "../data/pokemon-species"; -import * as Utils from "../utils"; +import BattleScene, { bypassLogin, PokeballCounts } from "#app/battle-scene"; +import Pokemon, { EnemyPokemon, PlayerPokemon } from "#app/field/pokemon"; +import { pokemonPrevolutions } from "#app/data/balance/pokemon-evolutions"; +import PokemonSpecies, { allSpecies, getPokemonSpecies, noStarterFormKeys } from "#app/data/pokemon-species"; +import { speciesStarterCosts } from "#app/data/balance/starters"; +import * as Utils from "#app/utils"; import Overrides from "#app/overrides"; -import PokemonData from "./pokemon-data"; -import PersistentModifierData from "./modifier-data"; -import ArenaData from "./arena-data"; -import { Unlockables } from "./unlockables"; -import { GameModes, getGameMode } from "../game-mode"; -import { BattleType } from "../battle"; -import TrainerData from "./trainer-data"; -import { trainerConfigs } from "../data/trainer-config"; -import { SettingKeys, resetSettings, setSetting } from "./settings/settings"; -import { achvs } from "./achv"; -import EggData from "./egg-data"; -import { Egg } from "../data/egg"; -import { VoucherType, vouchers } from "./voucher"; +import PokemonData from "#app/system/pokemon-data"; +import PersistentModifierData from "#app/system/modifier-data"; +import ArenaData from "#app/system/arena-data"; +import { Unlockables } from "#app/system/unlockables"; +import { GameModes, getGameMode } from "#app/game-mode"; +import { BattleType } from "#app/battle"; +import TrainerData from "#app/system/trainer-data"; +import { trainerConfigs } from "#app/data/trainer-config"; +import { resetSettings, setSetting, SettingKeys } from "#app/system/settings/settings"; +import { achvs } from "#app/system/achv"; +import EggData from "#app/system/egg-data"; +import { Egg } from "#app/data/egg"; +import { vouchers, VoucherType } from "#app/system/voucher"; import { AES, enc } from "crypto-js"; -import { Mode } from "../ui/ui"; -import { clientSessionId, loggedInUser, updateUserInfo } from "../account"; -import { Nature } from "../data/nature"; -import { GameStats } from "./game-stats"; -import { Tutorial } from "../tutorial"; -import { speciesEggMoves } from "../data/egg-moves"; -import { allMoves } from "../data/move"; -import { TrainerVariant } from "../field/trainer"; +import { Mode } from "#app/ui/ui"; +import { clientSessionId, loggedInUser, updateUserInfo } from "#app/account"; +import { Nature } from "#enums/nature"; +import { GameStats } from "#app/system/game-stats"; +import { Tutorial } from "#app/tutorial"; +import { speciesEggMoves } from "#app/data/balance/egg-moves"; +import { allMoves } from "#app/data/move"; +import { TrainerVariant } from "#app/field/trainer"; import { Variant } from "#app/data/variant"; -import {setSettingGamepad, SettingGamepad, settingGamepadDefaults} from "./settings/settings-gamepad"; -import {setSettingKeyboard, SettingKeyboard} from "#app/system/settings/settings-keyboard"; -import { TerrainChangedEvent, WeatherChangedEvent } from "#app/events/arena"; -import * as Modifier from "../modifier/modifier"; -import { StatusEffect } from "#app/data/status-effect"; -import ChallengeData from "./challenge-data"; +import { setSettingGamepad, SettingGamepad, settingGamepadDefaults } from "#app/system/settings/settings-gamepad"; +import { setSettingKeyboard, SettingKeyboard } from "#app/system/settings/settings-keyboard"; +import { TagAddedEvent, TerrainChangedEvent, WeatherChangedEvent } from "#app/events/arena"; +import * as Modifier from "#app/modifier/modifier"; +import { StatusEffect } from "#enums/status-effect"; +import ChallengeData from "#app/system/challenge-data"; import { Device } from "#enums/devices"; import { GameDataType } from "#enums/game-data-type"; import { Moves } from "#enums/moves"; import { PlayerGender } from "#enums/player-gender"; import { Species } from "#enums/species"; import { applyChallenges, ChallengeType } from "#app/data/challenge"; -import { WeatherType } from "#app/enums/weather-type"; +import { WeatherType } from "#enums/weather-type"; import { TerrainType } from "#app/data/terrain"; -import { OutdatedPhase } from "#app/phases/outdated-phase"; import { ReloadSessionPhase } from "#app/phases/reload-session-phase"; import { RUN_HISTORY_LIMIT } from "#app/ui/run-history-ui-handler"; -import { applySessionDataPatches, applySettingsDataPatches, applySystemDataPatches } from "./version-converter"; -import { MysteryEncounterSaveData } from "../data/mystery-encounters/mystery-encounter-save-data"; +import { applySessionVersionMigration, applySystemVersionMigration, applySettingsVersionMigration } from "./version_migration/version_converter"; +import { MysteryEncounterSaveData } from "#app/data/mystery-encounters/mystery-encounter-save-data"; import { MysteryEncounterType } from "#enums/mystery-encounter-type"; +import { pokerogueApi } from "#app/plugins/api/pokerogue-api"; +import { ArenaTrapTag } from "#app/data/arena-tag"; export const defaultStarterSpecies: Species[] = [ Species.BULBASAUR, Species.CHARMANDER, Species.SQUIRTLE, @@ -65,22 +67,22 @@ const saveKey = "x0i2O7WRiANTqPmZ"; // Temporary; secure encryption is not yet n export function getDataTypeKey(dataType: GameDataType, slotId: integer = 0): string { switch (dataType) { - case GameDataType.SYSTEM: - return "data"; - case GameDataType.SESSION: - let ret = "sessionData"; - if (slotId) { - ret += slotId; - } - return ret; - case GameDataType.SETTINGS: - return "settings"; - case GameDataType.TUTORIALS: - return "tutorials"; - case GameDataType.SEEN_DIALOGUES: - return "seenDialogues"; - case GameDataType.RUN_HISTORY: - return "runHistoryData"; + case GameDataType.SYSTEM: + return "data"; + case GameDataType.SESSION: + let ret = "sessionData"; + if (slotId) { + ret += slotId; + } + return ret; + case GameDataType.SETTINGS: + return "settings"; + case GameDataType.TUTORIALS: + return "tutorials"; + case GameDataType.SEEN_DIALOGUES: + return "seenDialogues"; + case GameDataType.RUN_HISTORY: + return "runHistoryData"; } } @@ -346,8 +348,8 @@ export class GameData { [VoucherType.GOLDEN]: 0 }; this.eggs = []; - this.eggPity = [0, 0, 0, 0]; - this.unlockPity = [0, 0, 0, 0]; + this.eggPity = [ 0, 0, 0, 0 ]; + this.unlockPity = [ 0, 0, 0, 0 ]; this.initDexData(); this.initStarterData(); } @@ -372,6 +374,18 @@ export class GameData { }; } + /** + * Checks if an `Unlockable` has been unlocked. + * @param unlockable The Unlockable to check + * @returns `true` if the player has unlocked this `Unlockable` or an override has enabled it + */ + public isUnlocked(unlockable: Unlockables): boolean { + if (Overrides.ITEM_UNLOCK_OVERRIDE.includes(unlockable)) { + return true; + } + return this.unlocks[unlockable]; + } + public saveSystem(): Promise { return new Promise(resolve => { this.scene.ui.savingIcon.show(); @@ -383,15 +397,11 @@ export class GameData { localStorage.setItem(`data_${loggedInUser?.username}`, encrypt(systemData, bypassLogin)); if (!bypassLogin) { - Utils.apiPost(`savedata/system/update?clientSessionId=${clientSessionId}`, systemData, undefined, true) - .then(response => response.text()) + pokerogueApi.savedata.system.update({ clientSessionId }, systemData) .then(error => { this.scene.ui.savingIcon.hide(); if (error) { - if (error.startsWith("client version out of date")) { - this.scene.clearPhaseQueue(); - this.scene.unshiftPhase(new OutdatedPhase(this.scene)); - } else if (error.startsWith("session out of date")) { + if (error.startsWith("session out of date")) { this.scene.clearPhaseQueue(); this.scene.unshiftPhase(new ReloadSessionPhase(this.scene)); } @@ -417,23 +427,22 @@ export class GameData { } if (!bypassLogin) { - Utils.apiFetch(`savedata/system/get?clientSessionId=${clientSessionId}`, true) - .then(response => response.text()) - .then(response => { - if (!response.length || response[0] !== "{") { - if (response.startsWith("sql: no rows in result set")) { + pokerogueApi.savedata.system.get({ clientSessionId }) + .then(saveDataOrErr => { + if (!saveDataOrErr || saveDataOrErr.length === 0 || saveDataOrErr[0] !== "{") { + if (saveDataOrErr?.startsWith("sql: no rows in result set")) { this.scene.queueMessage("Save data could not be found. If this is a new account, you can safely ignore this message.", null, true); return resolve(true); - } else if (response.indexOf("Too many connections") > -1) { + } else if (saveDataOrErr?.includes("Too many connections")) { this.scene.queueMessage("Too many people are trying to connect and the server is overloaded. Please try again later.", null, true); return resolve(false); } - console.error(response); + console.error(saveDataOrErr); return resolve(false); } const cachedSystem = localStorage.getItem(`data_${loggedInUser?.username}`); - this.initSystem(response, cachedSystem ? AES.decrypt(cachedSystem, saveKey).toString(enc.Utf8) : undefined).then(resolve); + this.initSystem(saveDataOrErr, cachedSystem ? AES.decrypt(cachedSystem, saveKey).toString(enc.Utf8) : undefined).then(resolve); }); } else { this.initSystem(decrypt(localStorage.getItem(`data_${loggedInUser?.username}`)!, bypassLogin)).then(resolve); // TODO: is this bang correct? @@ -467,7 +476,7 @@ export class GameData { localStorage.setItem(lsItemKey, ""); } - applySystemDataPatches(systemData); + applySystemVersionMigration(systemData); this.trainerId = systemData.trainerId; this.secretId = systemData.secretId; @@ -497,9 +506,9 @@ export class GameData { const starterIds = Object.keys(this.starterData).map(s => parseInt(s) as Species); for (const s of starterIds) { - this.starterData[s].candyCount += this.dexData[s].caughtCount; - this.starterData[s].candyCount += this.dexData[s].hatchedCount * 2; - if (this.dexData[s].caughtAttr & DexAttr.SHINY) { + this.starterData[s].candyCount += systemData.dexData[s].caughtCount; + this.starterData[s].candyCount += systemData.dexData[s].hatchedCount * 2; + if (systemData.dexData[s].caughtAttr & DexAttr.SHINY) { this.starterData[s].candyCount += 4; } } @@ -546,8 +555,8 @@ export class GameData { ? systemData.eggs.map(e => e.toEgg()) : []; - this.eggPity = systemData.eggPity ? systemData.eggPity.slice(0) : [0, 0, 0, 0]; - this.unlockPity = systemData.unlockPity ? systemData.unlockPity.slice(0) : [0, 0, 0, 0]; + this.eggPity = systemData.eggPity ? systemData.eggPity.slice(0) : [ 0, 0, 0, 0 ]; + this.unlockPity = systemData.unlockPity ? systemData.unlockPity.slice(0) : [ 0, 0, 0, 0 ]; this.dexData = Object.assign(this.dexData, systemData.dexData); this.consolidateDexData(this.dexData); @@ -569,6 +578,7 @@ export class GameData { if (!Utils.isLocal) { /** * Networking Code DO NOT DELETE! + * Note: Might have to be migrated to `pokerogue-api.ts` * const response = await Utils.apiFetch("savedata/runHistory", true); const data = await response.json(); @@ -649,6 +659,7 @@ export class GameData { return false; } } + NOTE: should be adopted to `pokerogue-api.ts` */ return true; } @@ -668,7 +679,7 @@ export class GameData { return ret; } - return k.endsWith("Attr") && ![ "natureAttr", "abilityAttr", "passiveAttr" ].includes(k) ? BigInt(v) : v; + return k.endsWith("Attr") && ![ "natureAttr", "abilityAttr", "passiveAttr" ].includes(k) ? BigInt(v ?? 0) : v; }) as SystemSaveData; } @@ -693,12 +704,11 @@ export class GameData { return true; } - const response = await Utils.apiFetch(`savedata/system/verify?clientSessionId=${clientSessionId}`, true) - .then(response => response.json()); + const systemData = await pokerogueApi.savedata.system.verify({ clientSessionId }); - if (!response.valid) { + if (systemData) { this.scene.clearPhaseQueue(); - this.scene.unshiftPhase(new ReloadSessionPhase(this.scene, JSON.stringify(response.systemData))); + this.scene.unshiftPhase(new ReloadSessionPhase(this.scene, JSON.stringify(systemData))); this.clearLocalData(); return false; } @@ -842,7 +852,7 @@ export class GameData { const settings = JSON.parse(localStorage.getItem("settings")!); // TODO: is this bang correct? - applySettingsDataPatches(settings); + applySettingsVersionMigration(settings); for (const setting of Object.keys(settings)) { setSetting(this.scene, setting, settings[setting]); @@ -938,13 +948,13 @@ export class GameData { seed: scene.seed, playTime: scene.sessionPlayTime, gameMode: scene.gameMode.modeId, - party: scene.getParty().map(p => new PokemonData(p)), + party: scene.getPlayerParty().map(p => new PokemonData(p)), enemyParty: scene.getEnemyParty().map(p => new PokemonData(p)), modifiers: scene.findModifiers(() => true).map(m => new PersistentModifierData(m, true)), enemyModifiers: scene.findModifiers(() => true, false).map(m => new PersistentModifierData(m, false)), arena: new ArenaData(scene.arena), pokeballCounts: scene.pokeballCounts, - money: scene.money, + money: Math.floor(scene.money), score: scene.score, waveIndex: scene.currentBattle.waveIndex, battleType: scene.currentBattle.battleType, @@ -973,10 +983,9 @@ export class GameData { }; if (!bypassLogin && !localStorage.getItem(`sessionData${slotId ? slotId : ""}_${loggedInUser?.username}`)) { - Utils.apiFetch(`savedata/session/get?slot=${slotId}&clientSessionId=${clientSessionId}`, true) - .then(response => response.text()) + pokerogueApi.savedata.session.get({ slot: slotId, clientSessionId }) .then(async response => { - if (!response.length || response[0] !== "{") { + if (!response || response?.length === 0 || response?.[0] !== "{") { console.error(response); return resolve(null); } @@ -1017,7 +1026,7 @@ export class GameData { const loadPokemonAssets: Promise[] = []; - const party = scene.getParty(); + const party = scene.getPlayerParty(); party.splice(0, party.length); for (const p of sessionData.party) { @@ -1034,7 +1043,7 @@ export class GameData { scene.pokeballCounts = Overrides.POKEBALL_OVERRIDE.pokeballs; } - scene.money = sessionData.money || 0; + scene.money = Math.floor(sessionData.money || 0); scene.updateMoneyText(); if (scene.money > this.gameStats.highestMoney) { @@ -1071,8 +1080,18 @@ export class GameData { scene.arena.terrain = sessionData.arena.terrain; scene.arena.eventTarget.dispatchEvent(new TerrainChangedEvent(TerrainType.NONE, scene.arena.terrain?.terrainType!, scene.arena.terrain?.turnsLeft!)); // TODO: is this bang correct? - // TODO - //scene.arena.tags = sessionData.arena.tags; + + scene.arena.tags = sessionData.arena.tags; + if (scene.arena.tags) { + for (const tag of scene.arena.tags) { + if (tag instanceof ArenaTrapTag) { + const { tagType, side, turnCount, layers, maxLayers } = tag as ArenaTrapTag; + scene.arena.eventTarget.dispatchEvent(new TagAddedEvent(tagType, side, turnCount, layers, maxLayers)); + } else { + scene.arena.eventTarget.dispatchEvent(new TagAddedEvent(tag.tagType, tag.side, tag.turnCount)); + } + } + } for (const modifierData of sessionData.modifiers) { const modifier = modifierData.toModifier(scene, Modifier[modifierData.className]); @@ -1111,10 +1130,16 @@ export class GameData { }); } + /** + * Delete the session data at the given slot when overwriting a save file + * For deleting the session of a finished run, use {@linkcode tryClearSession} + * @param slotId the slot to clear + * @returns Promise with result `true` if the session was deleted successfully, `false` otherwise + */ deleteSession(slotId: integer): Promise { return new Promise(resolve => { if (bypassLogin) { - localStorage.removeItem(`sessionData${this.scene.sessionSlotId ? this.scene.sessionSlotId : ""}_${loggedInUser?.username}`); + localStorage.removeItem(`sessionData${slotId ? slotId : ""}_${loggedInUser?.username}`); return resolve(true); } @@ -1122,14 +1147,7 @@ export class GameData { if (success !== null && !success) { return resolve(false); } - Utils.apiFetch(`savedata/session/delete?slot=${slotId}&clientSessionId=${clientSessionId}`, true).then(response => { - if (response.ok) { - loggedInUser!.lastSessionSlot = -1; // TODO: is the bang correct? - localStorage.removeItem(`sessionData${this.scene.sessionSlotId ? this.scene.sessionSlotId : ""}_${loggedInUser?.username}`); - resolve(true); - } - return response.text(); - }).then(error => { + pokerogueApi.savedata.session.delete({ slot: slotId, clientSessionId }).then(error => { if (error) { if (error.startsWith("session out of date")) { this.scene.clearPhaseQueue(); @@ -1137,8 +1155,15 @@ export class GameData { } console.error(error); resolve(false); + } else { + if (loggedInUser) { + loggedInUser.lastSessionSlot = -1; + } + + localStorage.removeItem(`sessionData${slotId ? slotId : ""}_${loggedInUser?.username}`); + resolve(true); + } - resolve(true); }); }); }); @@ -1174,37 +1199,43 @@ export class GameData { }); } - tryClearSession(scene: BattleScene, slotId: integer): Promise<[success: boolean, newClear: boolean]> { - return new Promise<[boolean, boolean]>(resolve => { - if (bypassLogin) { - localStorage.removeItem(`sessionData${slotId ? slotId : ""}_${loggedInUser?.username}`); - return resolve([true, true]); - } - updateUserInfo().then(success => { - if (success !== null && !success) { - return resolve([false, false]); + /** + * Attempt to clear session data after the end of a run + * After session data is removed, attempt to update user info so the menu updates + * To delete an unfinished run instead, use {@linkcode deleteSession} + */ + async tryClearSession(scene: BattleScene, slotId: integer): Promise<[success: boolean, newClear: boolean]> { + let result: [boolean, boolean] = [ false, false ]; + + if (bypassLogin) { + localStorage.removeItem(`sessionData${slotId ? slotId : ""}_${loggedInUser?.username}`); + result = [ true, true ]; + } else { + const sessionData = this.getSessionSaveData(scene); + const { trainerId } = this; + const jsonResponse = await pokerogueApi.savedata.session.clear({ slot: slotId, trainerId, clientSessionId }, sessionData); + + if (!jsonResponse?.error) { + result = [ true, jsonResponse?.success ?? false ]; + if (loggedInUser) { + loggedInUser!.lastSessionSlot = -1; } - const sessionData = this.getSessionSaveData(scene); - Utils.apiPost(`savedata/session/clear?slot=${slotId}&trainerId=${this.trainerId}&secretId=${this.secretId}&clientSessionId=${clientSessionId}`, JSON.stringify(sessionData), undefined, true).then(response => { - if (response.ok) { - loggedInUser!.lastSessionSlot = -1; // TODO: is the bang correct? - localStorage.removeItem(`sessionData${this.scene.sessionSlotId ? this.scene.sessionSlotId : ""}_${loggedInUser?.username}`); - } - return response.json(); - }).then(jsonResponse => { - if (!jsonResponse.error) { - return resolve([true, jsonResponse.success as boolean]); - } - if (jsonResponse && jsonResponse.error.startsWith("session out of date")) { - this.scene.clearPhaseQueue(); - this.scene.unshiftPhase(new ReloadSessionPhase(this.scene)); - } - console.error(jsonResponse); - resolve([false, false]); - }); - }); - }); + localStorage.removeItem(`sessionData${slotId ? slotId : ""}_${loggedInUser?.username}`); + } else { + if (jsonResponse && jsonResponse.error?.startsWith("session out of date")) { + this.scene.clearPhaseQueue(); + this.scene.unshiftPhase(new ReloadSessionPhase(this.scene)); + } + + console.error(jsonResponse); + result = [ false, false ]; + } + } + + await updateUserInfo(); + + return result; } parseSessionData(dataStr: string): SessionSaveData { @@ -1274,7 +1305,7 @@ export class GameData { return v; }) as SessionSaveData; - applySessionDataPatches(sessionData); + applySessionVersionMigration(sessionData); return sessionData; } @@ -1307,18 +1338,14 @@ export class GameData { console.debug("Session data saved"); if (!bypassLogin && sync) { - Utils.apiPost("savedata/updateall", JSON.stringify(request, (k: any, v: any) => typeof v === "bigint" ? v <= maxIntAttrValue ? Number(v) : v.toString() : v), undefined, true) - .then(response => response.text()) + pokerogueApi.savedata.updateAll(request) .then(error => { if (sync) { this.scene.lastSavePlayTime = 0; this.scene.ui.savingIcon.hide(); } if (error) { - if (error.startsWith("client version out of date")) { - this.scene.clearPhaseQueue(); - this.scene.unshiftPhase(new OutdatedPhase(this.scene)); - } else if (error.startsWith("session out of date")) { + if (error.startsWith("session out of date")) { this.scene.clearPhaseQueue(); this.scene.unshiftPhase(new ReloadSessionPhase(this.scene)); } @@ -1342,12 +1369,12 @@ export class GameData { const dataKey: string = `${getDataTypeKey(dataType, slotId)}_${loggedInUser?.username}`; const handleData = (dataStr: string) => { switch (dataType) { - case GameDataType.SYSTEM: - dataStr = this.convertSystemDataStr(dataStr, true); - break; + case GameDataType.SYSTEM: + dataStr = this.convertSystemDataStr(dataStr, true); + break; } const encryptedData = AES.encrypt(dataStr, saveKey); - const blob = new Blob([ encryptedData.toString() ], {type: "text/json"}); + const blob = new Blob([ encryptedData.toString() ], { type: "text/json" }); const link = document.createElement("a"); link.href = window.URL.createObjectURL(blob); link.download = `${dataKey}.prsv`; @@ -1355,18 +1382,24 @@ export class GameData { link.remove(); }; if (!bypassLogin && dataType < GameDataType.SETTINGS) { - Utils.apiFetch(`savedata/${dataType === GameDataType.SYSTEM ? "system" : "session"}/get?clientSessionId=${clientSessionId}${dataType === GameDataType.SESSION ? `&slot=${slotId}` : ""}`, true) - .then(response => response.text()) - .then(response => { - if (!response.length || response[0] !== "{") { - console.error(response); - resolve(false); - return; - } + let promise: Promise = Promise.resolve(null); - handleData(response); - resolve(true); - }); + if (dataType === GameDataType.SYSTEM) { + promise = pokerogueApi.savedata.system.get({ clientSessionId }); + } else if (dataType === GameDataType.SESSION) { + promise = pokerogueApi.savedata.session.get({ slot: slotId, clientSessionId }); + } + + promise.then(response => { + if (!response?.length || response[0] !== "{") { + console.error(response); + resolve(false); + return; + } + + handleData(response); + resolve(true); + }); } else { const data = localStorage.getItem(dataKey); if (data) { @@ -1402,28 +1435,28 @@ export class GameData { try { dataName = GameDataType[dataType].toLowerCase(); switch (dataType) { - case GameDataType.SYSTEM: - dataStr = this.convertSystemDataStr(dataStr); - const systemData = this.parseSystemData(dataStr); - valid = !!systemData.dexData && !!systemData.timestamp; - break; - case GameDataType.SESSION: - const sessionData = this.parseSessionData(dataStr); - valid = !!sessionData.party && !!sessionData.enemyParty && !!sessionData.timestamp; - break; - case GameDataType.RUN_HISTORY: - const data = JSON.parse(dataStr); - const keys = Object.keys(data); - dataName = i18next.t("menuUiHandler:RUN_HISTORY").toLowerCase(); - keys.forEach((key) => { - const entryKeys = Object.keys(data[key]); - valid = ["isFavorite", "isVictory", "entry"].every(v => entryKeys.includes(v)) && entryKeys.length === 3; - }); - break; - case GameDataType.SETTINGS: - case GameDataType.TUTORIALS: - valid = true; - break; + case GameDataType.SYSTEM: + dataStr = this.convertSystemDataStr(dataStr); + const systemData = this.parseSystemData(dataStr); + valid = !!systemData.dexData && !!systemData.timestamp; + break; + case GameDataType.SESSION: + const sessionData = this.parseSessionData(dataStr); + valid = !!sessionData.party && !!sessionData.enemyParty && !!sessionData.timestamp; + break; + case GameDataType.RUN_HISTORY: + const data = JSON.parse(dataStr); + const keys = Object.keys(data); + dataName = i18next.t("menuUiHandler:RUN_HISTORY").toLowerCase(); + keys.forEach((key) => { + const entryKeys = Object.keys(data[key]); + valid = [ "isFavorite", "isVictory", "entry" ].every(v => entryKeys.includes(v)) && entryKeys.length === 3; + }); + break; + case GameDataType.SETTINGS: + case GameDataType.TUTORIALS: + valid = true; + break; } } catch (ex) { console.error(ex); @@ -1445,14 +1478,14 @@ export class GameData { if (!success[0]) { return displayError(`Could not contact the server. Your ${dataName} data could not be imported.`); } - let url: string; + const { trainerId, secretId } = this; + let updatePromise: Promise; if (dataType === GameDataType.SESSION) { - url = `savedata/session/update?slot=${slotId}&trainerId=${this.trainerId}&secretId=${this.secretId}&clientSessionId=${clientSessionId}`; + updatePromise = pokerogueApi.savedata.session.update({ slot: slotId, trainerId, secretId, clientSessionId }, dataStr); } else { - url = `savedata/system/update?trainerId=${this.trainerId}&secretId=${this.secretId}&clientSessionId=${clientSessionId}`; + updatePromise = pokerogueApi.savedata.system.update({ trainerId, secretId, clientSessionId }, dataStr); } - Utils.apiPost(url, dataStr, undefined, true) - .then(response => response.text()) + updatePromise .then(error => { if (error) { console.error(error); @@ -1507,7 +1540,7 @@ export class GameData { entry.caughtAttr = defaultStarterAttr; entry.natureAttr = 1 << (defaultStarterNatures[ds] + 1); for (const i in entry.ivs) { - entry.ivs[i] = 10; + entry.ivs[i] = 15; } } @@ -1518,7 +1551,7 @@ export class GameData { private initStarterData(): void { const starterData: StarterData = {}; - const starterSpeciesIds = Object.keys(speciesStarters).map(k => parseInt(k) as Species); + const starterSpeciesIds = Object.keys(speciesStarterCosts).map(k => parseInt(k) as Species); for (const speciesId of starterSpeciesIds) { starterData[speciesId] = { @@ -1537,6 +1570,10 @@ export class GameData { } setPokemonSeen(pokemon: Pokemon, incrementCount: boolean = true, trainer: boolean = false): void { + // Some Mystery Encounters block updates to these stats + if (this.scene.currentBattle?.isBattleMysteryEncounter() && this.scene.currentBattle.mysteryEncounter?.preventGameStatsUpdates) { + return; + } const dexEntry = this.dexData[pokemon.species.speciesId]; dexEntry.seenAttr |= pokemon.getDexAttr(); if (incrementCount) { @@ -1564,12 +1601,20 @@ export class GameData { * @returns `true` if Pokemon catch unlocked a new starter, `false` if Pokemon catch did not unlock a starter */ setPokemonCaught(pokemon: Pokemon, incrementCount: boolean = true, fromEgg: boolean = false, showMessage: boolean = true): Promise { - return this.setPokemonSpeciesCaught(pokemon, pokemon.species, incrementCount, fromEgg, showMessage); + // If incrementCount === false (not a catch scenario), only update the pokemon's dex data if the Pokemon has already been marked as caught in dex + // Prevents form changes, nature changes, etc. from unintentionally updating the dex data of a "rental" pokemon + const speciesRootForm = pokemon.species.getRootSpeciesId(); + if (!incrementCount && !this.scene.gameData.dexData[speciesRootForm].caughtAttr) { + return Promise.resolve(false); + } else { + return this.setPokemonSpeciesCaught(pokemon, pokemon.species, incrementCount, fromEgg, showMessage); + } } /** * * @param pokemon + * @param species * @param incrementCount * @param fromEgg * @param showMessage @@ -1585,12 +1630,18 @@ export class GameData { } const dexAttr = pokemon.getDexAttr(); pokemon.formIndex = formIndex; + + // Mark as caught dexEntry.caughtAttr |= dexAttr; - if (speciesStarters.hasOwnProperty(species.speciesId)) { + + // Unlock ability + if (speciesStarterCosts.hasOwnProperty(species.speciesId)) { this.starterData[species.speciesId].abilityAttr |= pokemon.abilityIndex !== 1 || pokemon.species.ability2 ? 1 << pokemon.abilityIndex : AbilityAttr.ABILITY_HIDDEN; } + + // Unlock nature dexEntry.natureAttr |= 1 << (pokemon.nature + 1); const hasPrevolution = pokemonPrevolutions.hasOwnProperty(species.speciesId); @@ -1640,7 +1691,7 @@ export class GameData { } }; - if (newCatch && speciesStarters.hasOwnProperty(species.speciesId)) { + if (newCatch && speciesStarterCosts.hasOwnProperty(species.speciesId)) { if (!showMessage) { resolve(true); return; @@ -1685,9 +1736,19 @@ export class GameData { return ++this.starterData[speciesIdToIncrement].classicWinCount; } + /** + * Adds a candy to the player's game data for a given {@linkcode PokemonSpecies}. + * Will do nothing if the player does not have the Pokemon owned in their system save data. + * @param species + * @param count + */ addStarterCandy(species: PokemonSpecies, count: integer): void { - this.scene.candyBar.showStarterSpeciesCandy(species.speciesId, count); - this.starterData[species.speciesId].candyCount += count; + // Only gain candies if the Pokemon has already been marked as caught in dex (ignore "rental" pokemon) + const speciesRootForm = species.getRootSpeciesId(); + if (this.scene.gameData.dexData[speciesRootForm].caughtAttr) { + this.scene.candyBar.showStarterSpeciesCandy(species.speciesId, count); + this.starterData[species.speciesId].candyCount += count; + } } /** @@ -1730,6 +1791,32 @@ export class GameData { }); } + /** + * Checks whether the root species of a given {@PokemonSpecies} has been unlocked in the dex + */ + isRootSpeciesUnlocked(species: PokemonSpecies): boolean { + return !!this.dexData[species.getRootSpeciesId()]?.caughtAttr; + } + + /** + * Unlocks the given {@linkcode Nature} for a {@linkcode PokemonSpecies} and its prevolutions. + * Will fail silently if root species has not been unlocked + */ + unlockSpeciesNature(species: PokemonSpecies, nature: Nature): void { + if (!this.isRootSpeciesUnlocked(species)) { + return; + } + + //recursively unlock nature for species and prevolutions + const _unlockSpeciesNature = (speciesId: Species) => { + this.dexData[speciesId].natureAttr |= 1 << (nature + 1); + if (pokemonPrevolutions.hasOwnProperty(speciesId)) { + _unlockSpeciesNature(pokemonPrevolutions[speciesId]); + } + }; + _unlockSpeciesNature(species.speciesId); + } + updateSpeciesDexIvs(speciesId: Species, ivs: integer[]): void { let dexEntry: DexEntry; do { @@ -1758,7 +1845,7 @@ export class GameData { } getStarterCount(dexEntryPredicate: (entry: DexEntry) => boolean): integer { - const starterKeys = Object.keys(speciesStarters); + const starterKeys = Object.keys(speciesStarterCosts); let starterCount = 0; for (const s of starterKeys) { const starterDexEntry = this.dexData[s]; @@ -1769,17 +1856,40 @@ export class GameData { return starterCount; } - getSpeciesDefaultDexAttr(species: PokemonSpecies, forSeen: boolean = false, optimistic: boolean = false): bigint { + getSpeciesDefaultDexAttr(species: PokemonSpecies, _forSeen: boolean = false, optimistic: boolean = false): bigint { let ret = 0n; const dexEntry = this.dexData[species.speciesId]; const attr = dexEntry.caughtAttr; - ret |= optimistic - ? attr & DexAttr.SHINY ? DexAttr.SHINY : DexAttr.NON_SHINY - : attr & DexAttr.NON_SHINY || !(attr & DexAttr.SHINY) ? DexAttr.NON_SHINY : DexAttr.SHINY; + if (optimistic) { + if (attr & DexAttr.SHINY) { + ret |= DexAttr.SHINY; + + if (attr & DexAttr.VARIANT_3) { + ret |= DexAttr.VARIANT_3; + } else if (attr & DexAttr.VARIANT_2) { + ret |= DexAttr.VARIANT_2; + } else { + ret |= DexAttr.DEFAULT_VARIANT; + } + } else { + ret |= DexAttr.NON_SHINY; + ret |= DexAttr.DEFAULT_VARIANT; + } + } else { + // Default to non shiny. Fallback to shiny if it's the only thing that's unlocked + ret |= (attr & DexAttr.NON_SHINY || !(attr & DexAttr.SHINY)) ? DexAttr.NON_SHINY : DexAttr.SHINY; + + if (attr & DexAttr.DEFAULT_VARIANT) { + ret |= DexAttr.DEFAULT_VARIANT; + } else if (attr & DexAttr.VARIANT_2) { + ret |= DexAttr.VARIANT_2; + } else if (attr & DexAttr.VARIANT_3) { + ret |= DexAttr.VARIANT_3; + } else { + ret |= DexAttr.DEFAULT_VARIANT; + } + } ret |= attr & DexAttr.MALE || !(attr & DexAttr.FEMALE) ? DexAttr.MALE : DexAttr.FEMALE; - ret |= optimistic - ? attr & DexAttr.SHINY ? attr & DexAttr.VARIANT_3 ? DexAttr.VARIANT_3 : attr & DexAttr.VARIANT_2 ? DexAttr.VARIANT_2 : DexAttr.DEFAULT_VARIANT : DexAttr.DEFAULT_VARIANT - : attr & DexAttr.DEFAULT_VARIANT ? DexAttr.DEFAULT_VARIANT : attr & DexAttr.VARIANT_2 ? DexAttr.VARIANT_2 : attr & DexAttr.VARIANT_3 ? DexAttr.VARIANT_3 : DexAttr.DEFAULT_VARIANT; ret |= this.getFormAttr(this.getFormIndex(attr)); return ret; } @@ -1787,7 +1897,14 @@ export class GameData { getSpeciesDexAttrProps(species: PokemonSpecies, dexAttr: bigint): DexAttrProps { const shiny = !(dexAttr & DexAttr.NON_SHINY); const female = !(dexAttr & DexAttr.MALE); - const variant = dexAttr & DexAttr.DEFAULT_VARIANT ? 0 : dexAttr & DexAttr.VARIANT_2 ? 1 : dexAttr & DexAttr.VARIANT_3 ? 2 : 0; + let variant: Variant = 0; + if (dexAttr & DexAttr.DEFAULT_VARIANT) { + variant = 0; + } else if (dexAttr & DexAttr.VARIANT_2) { + variant = 1; + } else if (dexAttr & DexAttr.VARIANT_3) { + variant = 2; + } const formIndex = this.getFormIndex(dexAttr); return { @@ -1832,7 +1949,7 @@ export class GameData { } getSpeciesStarterValue(speciesId: Species): number { - const baseValue = speciesStarters[speciesId]; + const baseValue = speciesStarterCosts[speciesId]; let value = baseValue; const decrementValue = (value: number) => { diff --git a/src/system/modifier-data.ts b/src/system/modifier-data.ts index 1514f7e3fb3..c68f9ccb47d 100644 --- a/src/system/modifier-data.ts +++ b/src/system/modifier-data.ts @@ -38,7 +38,7 @@ export default class ModifierData { type.id = this.typeId; if (type instanceof ModifierTypeGenerator) { - type = (type as ModifierTypeGenerator).generateType(this.player ? scene.getParty() : scene.getEnemyField(), this.typePregenArgs); + type = (type as ModifierTypeGenerator).generateType(this.player ? scene.getPlayerParty() : scene.getEnemyField(), this.typePregenArgs); } const ret = Reflect.construct(constructor, ([ type ] as any[]).concat(this.args).concat(this.stackCount)) as PersistentModifier; diff --git a/src/system/pokemon-data.ts b/src/system/pokemon-data.ts index 0fd90e448a1..443382186c7 100644 --- a/src/system/pokemon-data.ts +++ b/src/system/pokemon-data.ts @@ -1,8 +1,8 @@ import { BattleType } from "../battle"; import BattleScene from "../battle-scene"; import { Gender } from "../data/gender"; -import { Nature } from "../data/nature"; -import { PokeballType } from "../data/pokeball"; +import { Nature } from "#enums/nature"; +import { PokeballType } from "#enums/pokeball"; import { getPokemonSpecies } from "../data/pokemon-species"; import { Status } from "../data/status-effect"; import Pokemon, { EnemyPokemon, PokemonMove, PokemonSummonData } from "../field/pokemon"; @@ -12,7 +12,7 @@ import { loadBattlerTag } from "../data/battler-tags"; import { Biome } from "#enums/biome"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; -import { MysteryEncounterPokemonData } from "#app/data/mystery-encounters/mystery-encounter-pokemon-data"; +import { CustomPokemonData } from "#app/data/custom-pokemon-data"; export default class PokemonData { public id: integer; @@ -33,7 +33,6 @@ export default class PokemonData { public stats: integer[]; public ivs: integer[]; public nature: Nature; - public natureOverride: Nature | -1; public moveset: (PokemonMove | null)[]; public status: Status | null; public friendship: integer; @@ -59,8 +58,15 @@ export default class PokemonData { public bossSegments?: integer; public summonData: PokemonSummonData; + /** Data that can customize a Pokemon in non-standard ways from its Species */ - public mysteryEncounterPokemonData: MysteryEncounterPokemonData; + public customPokemonData: CustomPokemonData; + public fusionCustomPokemonData: CustomPokemonData; + + // Deprecated attributes, needed for now to allow SessionData migration (see PR#4619 comments) + public natureOverride: Nature | -1; + public mysteryEncounterPokemonData: CustomPokemonData | null; + public fusionMysteryEncounterPokemonData: CustomPokemonData | null; constructor(source: Pokemon | any, forHistory: boolean = false) { const sourcePokemon = source instanceof Pokemon ? source : null; @@ -86,7 +92,6 @@ export default class PokemonData { this.stats = source.stats; this.ivs = source.ivs; this.nature = source.nature !== undefined ? source.nature : 0 as Nature; - this.natureOverride = source.natureOverride !== undefined ? source.natureOverride : -1; this.friendship = source.friendship !== undefined ? source.friendship : getPokemonSpecies(this.species).baseFriendship; this.metLevel = source.metLevel || 5; this.metBiome = source.metBiome !== undefined ? source.metBiome : -1; @@ -106,9 +111,15 @@ export default class PokemonData { this.fusionVariant = source.fusionVariant; this.fusionGender = source.fusionGender; this.fusionLuck = source.fusionLuck !== undefined ? source.fusionLuck : (source.fusionShiny ? source.fusionVariant + 1 : 0); + this.fusionCustomPokemonData = new CustomPokemonData(source.fusionCustomPokemonData); this.usedTMs = source.usedTMs ?? []; - this.mysteryEncounterPokemonData = new MysteryEncounterPokemonData(source.mysteryEncounterPokemonData); + this.customPokemonData = new CustomPokemonData(source.customPokemonData); + + // Deprecated, but needed for session data migration + this.natureOverride = source.natureOverride; + this.mysteryEncounterPokemonData = source.mysteryEncounterPokemonData ? new CustomPokemonData(source.mysteryEncounterPokemonData) : null; + this.fusionMysteryEncounterPokemonData = source.fusionMysteryEncounterPokemonData ? new CustomPokemonData(source.fusionMysteryEncounterPokemonData) : null; if (!forHistory) { this.boss = (source instanceof EnemyPokemon && !!source.bossSegments) || (!this.player && !!source.boss); @@ -124,10 +135,10 @@ export default class PokemonData { } } } else { - this.moveset = (source.moveset || [ new PokemonMove(Moves.TACKLE), new PokemonMove(Moves.GROWL) ]).filter(m => m).map((m: any) => new PokemonMove(m.moveId, m.ppUsed, m.ppUp)); + this.moveset = (source.moveset || [ new PokemonMove(Moves.TACKLE), new PokemonMove(Moves.GROWL) ]).filter(m => m).map((m: any) => new PokemonMove(m.moveId, m.ppUsed, m.ppUp, m.virtual, m.maxPpOverride)); if (!forHistory) { this.status = source.status - ? new Status(source.status.effect, source.status.turnCount, source.status.cureTurn) + ? new Status(source.status.effect, source.status.toxicTurnCount, source.status.sleepTurnsRemaining) : null; } diff --git a/src/system/settings/settings-gamepad.ts b/src/system/settings/settings-gamepad.ts index 5dd94b780a0..322b2baac9e 100644 --- a/src/system/settings/settings-gamepad.ts +++ b/src/system/settings/settings-gamepad.ts @@ -1,9 +1,9 @@ import BattleScene from "../../battle-scene"; import SettingsGamepadUiHandler from "../../ui/settings/settings-gamepad-ui-handler"; -import {Mode} from "../../ui/ui"; -import {truncateString} from "../../utils"; -import {Button} from "#enums/buttons"; -import {SettingKeyboard} from "#app/system/settings/settings-keyboard"; +import { Mode } from "../../ui/ui"; +import { truncateString } from "../../utils"; +import { Button } from "#enums/buttons"; +import { SettingKeyboard } from "#app/system/settings/settings-keyboard"; export enum SettingGamepad { Controller = "CONTROLLER", @@ -30,25 +30,25 @@ export enum SettingGamepad { const pressAction = "Press action to assign"; export const settingGamepadOptions = { - [SettingGamepad.Controller]: ["Default", "Change"], - [SettingGamepad.Gamepad_Support]: ["Auto", "Disabled"], - [SettingGamepad.Button_Up]: [`KEY ${Button.UP.toString()}`, pressAction], - [SettingGamepad.Button_Down]: [`KEY ${Button.DOWN.toString()}`, pressAction], - [SettingGamepad.Button_Left]: [`KEY ${Button.LEFT.toString()}`, pressAction], - [SettingGamepad.Button_Right]: [`KEY ${Button.RIGHT.toString()}`, pressAction], - [SettingGamepad.Button_Action]: [`KEY ${Button.ACTION.toString()}`, pressAction], - [SettingGamepad.Button_Cancel]: [`KEY ${Button.CANCEL.toString()}`, pressAction], - [SettingGamepad.Button_Menu]: [`KEY ${Button.MENU.toString()}`, pressAction], - [SettingGamepad.Button_Stats]: [`KEY ${Button.STATS.toString()}`, pressAction], - [SettingGamepad.Button_Cycle_Form]: [`KEY ${Button.CYCLE_FORM.toString()}`, pressAction], - [SettingGamepad.Button_Cycle_Shiny]: [`KEY ${Button.CYCLE_SHINY.toString()}`, pressAction], - [SettingGamepad.Button_Cycle_Gender]: [`KEY ${Button.CYCLE_GENDER.toString()}`, pressAction], - [SettingGamepad.Button_Cycle_Ability]: [`KEY ${Button.CYCLE_ABILITY.toString()}`, pressAction], - [SettingGamepad.Button_Cycle_Nature]: [`KEY ${Button.CYCLE_NATURE.toString()}`, pressAction], - [SettingGamepad.Button_Cycle_Variant]: [`KEY ${Button.V.toString()}`, pressAction], - [SettingGamepad.Button_Speed_Up]: [`KEY ${Button.SPEED_UP.toString()}`, pressAction], - [SettingGamepad.Button_Slow_Down]: [`KEY ${Button.SLOW_DOWN.toString()}`, pressAction], - [SettingGamepad.Button_Submit]: [`KEY ${Button.SUBMIT.toString()}`, pressAction], + [SettingGamepad.Controller]: [ "Default", "Change" ], + [SettingGamepad.Gamepad_Support]: [ "Auto", "Disabled" ], + [SettingGamepad.Button_Up]: [ `KEY ${Button.UP.toString()}`, pressAction ], + [SettingGamepad.Button_Down]: [ `KEY ${Button.DOWN.toString()}`, pressAction ], + [SettingGamepad.Button_Left]: [ `KEY ${Button.LEFT.toString()}`, pressAction ], + [SettingGamepad.Button_Right]: [ `KEY ${Button.RIGHT.toString()}`, pressAction ], + [SettingGamepad.Button_Action]: [ `KEY ${Button.ACTION.toString()}`, pressAction ], + [SettingGamepad.Button_Cancel]: [ `KEY ${Button.CANCEL.toString()}`, pressAction ], + [SettingGamepad.Button_Menu]: [ `KEY ${Button.MENU.toString()}`, pressAction ], + [SettingGamepad.Button_Stats]: [ `KEY ${Button.STATS.toString()}`, pressAction ], + [SettingGamepad.Button_Cycle_Form]: [ `KEY ${Button.CYCLE_FORM.toString()}`, pressAction ], + [SettingGamepad.Button_Cycle_Shiny]: [ `KEY ${Button.CYCLE_SHINY.toString()}`, pressAction ], + [SettingGamepad.Button_Cycle_Gender]: [ `KEY ${Button.CYCLE_GENDER.toString()}`, pressAction ], + [SettingGamepad.Button_Cycle_Ability]: [ `KEY ${Button.CYCLE_ABILITY.toString()}`, pressAction ], + [SettingGamepad.Button_Cycle_Nature]: [ `KEY ${Button.CYCLE_NATURE.toString()}`, pressAction ], + [SettingGamepad.Button_Cycle_Variant]: [ `KEY ${Button.V.toString()}`, pressAction ], + [SettingGamepad.Button_Speed_Up]: [ `KEY ${Button.SPEED_UP.toString()}`, pressAction ], + [SettingGamepad.Button_Slow_Down]: [ `KEY ${Button.SLOW_DOWN.toString()}`, pressAction ], + [SettingGamepad.Button_Submit]: [ `KEY ${Button.SUBMIT.toString()}`, pressAction ], }; export const settingGamepadDefaults = { @@ -82,66 +82,66 @@ export const settingGamepadBlackList = [ export function setSettingGamepad(scene: BattleScene, setting: SettingGamepad, value: integer): boolean { switch (setting) { - case SettingGamepad.Gamepad_Support: + case SettingGamepad.Gamepad_Support: // if we change the value of the gamepad support, we call a method in the inputController to // activate or deactivate the controller listener - scene.inputController.setGamepadSupport(settingGamepadOptions[setting][value] !== "Disabled"); - break; - case SettingGamepad.Button_Action: - case SettingGamepad.Button_Cancel: - case SettingGamepad.Button_Menu: - case SettingGamepad.Button_Stats: - case SettingGamepad.Button_Cycle_Shiny: - case SettingGamepad.Button_Cycle_Form: - case SettingGamepad.Button_Cycle_Gender: - case SettingGamepad.Button_Cycle_Ability: - case SettingGamepad.Button_Cycle_Nature: - case SettingGamepad.Button_Cycle_Variant: - case SettingGamepad.Button_Speed_Up: - case SettingGamepad.Button_Slow_Down: - case SettingGamepad.Button_Submit: - if (value) { - if (scene.ui) { - const cancelHandler = (success: boolean = false) : boolean => { - scene.ui.revertMode(); - (scene.ui.getHandler() as SettingsGamepadUiHandler).updateBindings(); - return success; - }; - scene.ui.setOverlayMode(Mode.GAMEPAD_BINDING, { - target: setting, - cancelHandler: cancelHandler, - }); + scene.inputController.setGamepadSupport(settingGamepadOptions[setting][value] !== "Disabled"); + break; + case SettingGamepad.Button_Action: + case SettingGamepad.Button_Cancel: + case SettingGamepad.Button_Menu: + case SettingGamepad.Button_Stats: + case SettingGamepad.Button_Cycle_Shiny: + case SettingGamepad.Button_Cycle_Form: + case SettingGamepad.Button_Cycle_Gender: + case SettingGamepad.Button_Cycle_Ability: + case SettingGamepad.Button_Cycle_Nature: + case SettingGamepad.Button_Cycle_Variant: + case SettingGamepad.Button_Speed_Up: + case SettingGamepad.Button_Slow_Down: + case SettingGamepad.Button_Submit: + if (value) { + if (scene.ui) { + const cancelHandler = (success: boolean = false) : boolean => { + scene.ui.revertMode(); + (scene.ui.getHandler() as SettingsGamepadUiHandler).updateBindings(); + return success; + }; + scene.ui.setOverlayMode(Mode.GAMEPAD_BINDING, { + target: setting, + cancelHandler: cancelHandler, + }); + } } - } - break; - case SettingGamepad.Controller: - if (value) { - const gp = scene.inputController.getGamepadsName(); - if (scene.ui && gp) { - const cancelHandler = () => { - scene.ui.revertMode(); - (scene.ui.getHandler() as SettingsGamepadUiHandler).setOptionCursor(Object.values(SettingGamepad).indexOf(SettingGamepad.Controller), 0, true); - (scene.ui.getHandler() as SettingsGamepadUiHandler).updateBindings(); + break; + case SettingGamepad.Controller: + if (value) { + const gp = scene.inputController.getGamepadsName(); + if (scene.ui && gp) { + const cancelHandler = () => { + scene.ui.revertMode(); + (scene.ui.getHandler() as SettingsGamepadUiHandler).setOptionCursor(Object.values(SettingGamepad).indexOf(SettingGamepad.Controller), 0, true); + (scene.ui.getHandler() as SettingsGamepadUiHandler).updateBindings(); + return false; + }; + const changeGamepadHandler = (gamepad: string) => { + scene.inputController.setChosenGamepad(gamepad); + cancelHandler(); + return true; + }; + scene.ui.setOverlayMode(Mode.OPTION_SELECT, { + options: [ ...gp.map((g: string) => ({ + label: truncateString(g, 30), // Truncate the gamepad name for display + handler: () => changeGamepadHandler(g) + })), { + label: "Cancel", + handler: cancelHandler, + }] + }); return false; - }; - const changeGamepadHandler = (gamepad: string) => { - scene.inputController.setChosenGamepad(gamepad); - cancelHandler(); - return true; - }; - scene.ui.setOverlayMode(Mode.OPTION_SELECT, { - options: [...gp.map((g: string) => ({ - label: truncateString(g, 30), // Truncate the gamepad name for display - handler: () => changeGamepadHandler(g) - })), { - label: "Cancel", - handler: cancelHandler, - }] - }); - return false; + } } - } - break; + break; } return true; diff --git a/src/system/settings/settings-keyboard.ts b/src/system/settings/settings-keyboard.ts index d60af06e12b..97990f61c86 100644 --- a/src/system/settings/settings-keyboard.ts +++ b/src/system/settings/settings-keyboard.ts @@ -1,6 +1,6 @@ -import {Button} from "#enums/buttons"; +import { Button } from "#enums/buttons"; import BattleScene from "#app/battle-scene"; -import {Mode} from "#app/ui/ui"; +import { Mode } from "#app/ui/ui"; import SettingsKeyboardUiHandler from "#app/ui/settings/settings-keyboard-ui-handler"; import i18next from "i18next"; @@ -46,40 +46,40 @@ const pressAction = i18next.t("settings:pressToBind"); export const settingKeyboardOptions = { // [SettingKeyboard.Default_Layout]: ['Default'], - [SettingKeyboard.Button_Up]: [`KEY ${Button.UP.toString()}`, pressAction], - [SettingKeyboard.Button_Down]: [`KEY ${Button.DOWN.toString()}`, pressAction], - [SettingKeyboard.Alt_Button_Up]: [`KEY ${Button.UP.toString()}`, pressAction], - [SettingKeyboard.Button_Left]: [`KEY ${Button.LEFT.toString()}`, pressAction], - [SettingKeyboard.Button_Right]: [`KEY ${Button.RIGHT.toString()}`, pressAction], - [SettingKeyboard.Button_Action]: [`KEY ${Button.ACTION.toString()}`, pressAction], - [SettingKeyboard.Button_Menu]: [`KEY ${Button.MENU.toString()}`, pressAction], - [SettingKeyboard.Button_Submit]: [`KEY ${Button.SUBMIT.toString()}`, pressAction], - [SettingKeyboard.Alt_Button_Down]: [`KEY ${Button.DOWN.toString()}`, pressAction], - [SettingKeyboard.Alt_Button_Left]: [`KEY ${Button.LEFT.toString()}`, pressAction], - [SettingKeyboard.Alt_Button_Right]: [`KEY ${Button.RIGHT.toString()}`, pressAction], - [SettingKeyboard.Alt_Button_Action]: [`KEY ${Button.ACTION.toString()}`, pressAction], - [SettingKeyboard.Button_Cancel]: [`KEY ${Button.CANCEL.toString()}`, pressAction], - [SettingKeyboard.Alt_Button_Cancel]: [`KEY ${Button.CANCEL.toString()}`, pressAction], - [SettingKeyboard.Alt_Button_Menu]: [`KEY ${Button.MENU.toString()}`, pressAction], - [SettingKeyboard.Button_Stats]: [`KEY ${Button.STATS.toString()}`, pressAction], - [SettingKeyboard.Alt_Button_Stats]: [`KEY ${Button.STATS.toString()}`, pressAction], - [SettingKeyboard.Button_Cycle_Form]: [`KEY ${Button.CYCLE_FORM.toString()}`, pressAction], - [SettingKeyboard.Alt_Button_Cycle_Form]: [`KEY ${Button.CYCLE_FORM.toString()}`, pressAction], - [SettingKeyboard.Button_Cycle_Shiny]: [`KEY ${Button.CYCLE_SHINY.toString()}`, pressAction], - [SettingKeyboard.Alt_Button_Cycle_Shiny]: [`KEY ${Button.CYCLE_SHINY.toString()}`, pressAction], - [SettingKeyboard.Button_Cycle_Gender]: [`KEY ${Button.CYCLE_GENDER.toString()}`, pressAction], - [SettingKeyboard.Alt_Button_Cycle_Gender]: [`KEY ${Button.CYCLE_GENDER.toString()}`, pressAction], - [SettingKeyboard.Button_Cycle_Ability]: [`KEY ${Button.CYCLE_ABILITY.toString()}`, pressAction], - [SettingKeyboard.Alt_Button_Cycle_Ability]: [`KEY ${Button.CYCLE_ABILITY.toString()}`, pressAction], - [SettingKeyboard.Button_Cycle_Nature]: [`KEY ${Button.CYCLE_NATURE.toString()}`, pressAction], - [SettingKeyboard.Alt_Button_Cycle_Nature]: [`KEY ${Button.CYCLE_NATURE.toString()}`, pressAction], - [SettingKeyboard.Button_Cycle_Variant]: [`KEY ${Button.V.toString()}`, pressAction], - [SettingKeyboard.Alt_Button_Cycle_Variant]: [`KEY ${Button.V.toString()}`, pressAction], - [SettingKeyboard.Button_Speed_Up]: [`KEY ${Button.SPEED_UP.toString()}`, pressAction], - [SettingKeyboard.Alt_Button_Speed_Up]: [`KEY ${Button.SPEED_UP.toString()}`, pressAction], - [SettingKeyboard.Button_Slow_Down]: [`KEY ${Button.SLOW_DOWN.toString()}`, pressAction], - [SettingKeyboard.Alt_Button_Slow_Down]: [`KEY ${Button.SLOW_DOWN.toString()}`, pressAction], - [SettingKeyboard.Alt_Button_Submit]: [`KEY ${Button.SUBMIT.toString()}`, pressAction], + [SettingKeyboard.Button_Up]: [ `KEY ${Button.UP.toString()}`, pressAction ], + [SettingKeyboard.Button_Down]: [ `KEY ${Button.DOWN.toString()}`, pressAction ], + [SettingKeyboard.Alt_Button_Up]: [ `KEY ${Button.UP.toString()}`, pressAction ], + [SettingKeyboard.Button_Left]: [ `KEY ${Button.LEFT.toString()}`, pressAction ], + [SettingKeyboard.Button_Right]: [ `KEY ${Button.RIGHT.toString()}`, pressAction ], + [SettingKeyboard.Button_Action]: [ `KEY ${Button.ACTION.toString()}`, pressAction ], + [SettingKeyboard.Button_Menu]: [ `KEY ${Button.MENU.toString()}`, pressAction ], + [SettingKeyboard.Button_Submit]: [ `KEY ${Button.SUBMIT.toString()}`, pressAction ], + [SettingKeyboard.Alt_Button_Down]: [ `KEY ${Button.DOWN.toString()}`, pressAction ], + [SettingKeyboard.Alt_Button_Left]: [ `KEY ${Button.LEFT.toString()}`, pressAction ], + [SettingKeyboard.Alt_Button_Right]: [ `KEY ${Button.RIGHT.toString()}`, pressAction ], + [SettingKeyboard.Alt_Button_Action]: [ `KEY ${Button.ACTION.toString()}`, pressAction ], + [SettingKeyboard.Button_Cancel]: [ `KEY ${Button.CANCEL.toString()}`, pressAction ], + [SettingKeyboard.Alt_Button_Cancel]: [ `KEY ${Button.CANCEL.toString()}`, pressAction ], + [SettingKeyboard.Alt_Button_Menu]: [ `KEY ${Button.MENU.toString()}`, pressAction ], + [SettingKeyboard.Button_Stats]: [ `KEY ${Button.STATS.toString()}`, pressAction ], + [SettingKeyboard.Alt_Button_Stats]: [ `KEY ${Button.STATS.toString()}`, pressAction ], + [SettingKeyboard.Button_Cycle_Form]: [ `KEY ${Button.CYCLE_FORM.toString()}`, pressAction ], + [SettingKeyboard.Alt_Button_Cycle_Form]: [ `KEY ${Button.CYCLE_FORM.toString()}`, pressAction ], + [SettingKeyboard.Button_Cycle_Shiny]: [ `KEY ${Button.CYCLE_SHINY.toString()}`, pressAction ], + [SettingKeyboard.Alt_Button_Cycle_Shiny]: [ `KEY ${Button.CYCLE_SHINY.toString()}`, pressAction ], + [SettingKeyboard.Button_Cycle_Gender]: [ `KEY ${Button.CYCLE_GENDER.toString()}`, pressAction ], + [SettingKeyboard.Alt_Button_Cycle_Gender]: [ `KEY ${Button.CYCLE_GENDER.toString()}`, pressAction ], + [SettingKeyboard.Button_Cycle_Ability]: [ `KEY ${Button.CYCLE_ABILITY.toString()}`, pressAction ], + [SettingKeyboard.Alt_Button_Cycle_Ability]: [ `KEY ${Button.CYCLE_ABILITY.toString()}`, pressAction ], + [SettingKeyboard.Button_Cycle_Nature]: [ `KEY ${Button.CYCLE_NATURE.toString()}`, pressAction ], + [SettingKeyboard.Alt_Button_Cycle_Nature]: [ `KEY ${Button.CYCLE_NATURE.toString()}`, pressAction ], + [SettingKeyboard.Button_Cycle_Variant]: [ `KEY ${Button.V.toString()}`, pressAction ], + [SettingKeyboard.Alt_Button_Cycle_Variant]: [ `KEY ${Button.V.toString()}`, pressAction ], + [SettingKeyboard.Button_Speed_Up]: [ `KEY ${Button.SPEED_UP.toString()}`, pressAction ], + [SettingKeyboard.Alt_Button_Speed_Up]: [ `KEY ${Button.SPEED_UP.toString()}`, pressAction ], + [SettingKeyboard.Button_Slow_Down]: [ `KEY ${Button.SLOW_DOWN.toString()}`, pressAction ], + [SettingKeyboard.Alt_Button_Slow_Down]: [ `KEY ${Button.SLOW_DOWN.toString()}`, pressAction ], + [SettingKeyboard.Alt_Button_Submit]: [ `KEY ${Button.SUBMIT.toString()}`, pressAction ], }; export const settingKeyboardDefaults = { @@ -135,53 +135,53 @@ export const settingKeyboardBlackList = [ export function setSettingKeyboard(scene: BattleScene, setting: SettingKeyboard, value: integer): boolean { switch (setting) { - case SettingKeyboard.Button_Up: - case SettingKeyboard.Button_Down: - case SettingKeyboard.Button_Left: - case SettingKeyboard.Button_Right: - case SettingKeyboard.Button_Action: - case SettingKeyboard.Button_Cancel: - case SettingKeyboard.Button_Menu: - case SettingKeyboard.Button_Stats: - case SettingKeyboard.Button_Cycle_Shiny: - case SettingKeyboard.Button_Cycle_Form: - case SettingKeyboard.Button_Cycle_Gender: - case SettingKeyboard.Button_Cycle_Ability: - case SettingKeyboard.Button_Cycle_Nature: - case SettingKeyboard.Button_Cycle_Variant: - case SettingKeyboard.Button_Speed_Up: - case SettingKeyboard.Button_Slow_Down: - case SettingKeyboard.Alt_Button_Up: - case SettingKeyboard.Alt_Button_Down: - case SettingKeyboard.Alt_Button_Left: - case SettingKeyboard.Alt_Button_Right: - case SettingKeyboard.Alt_Button_Action: - case SettingKeyboard.Alt_Button_Cancel: - case SettingKeyboard.Alt_Button_Menu: - case SettingKeyboard.Alt_Button_Stats: - case SettingKeyboard.Alt_Button_Cycle_Shiny: - case SettingKeyboard.Alt_Button_Cycle_Form: - case SettingKeyboard.Alt_Button_Cycle_Gender: - case SettingKeyboard.Alt_Button_Cycle_Ability: - case SettingKeyboard.Alt_Button_Cycle_Nature: - case SettingKeyboard.Alt_Button_Cycle_Variant: - case SettingKeyboard.Alt_Button_Speed_Up: - case SettingKeyboard.Alt_Button_Slow_Down: - case SettingKeyboard.Alt_Button_Submit: - if (value) { - if (scene.ui) { - const cancelHandler = (success: boolean = false) : boolean => { - scene.ui.revertMode(); - (scene.ui.getHandler() as SettingsKeyboardUiHandler).updateBindings(); - return success; - }; - scene.ui.setOverlayMode(Mode.KEYBOARD_BINDING, { - target: setting, - cancelHandler: cancelHandler, - }); + case SettingKeyboard.Button_Up: + case SettingKeyboard.Button_Down: + case SettingKeyboard.Button_Left: + case SettingKeyboard.Button_Right: + case SettingKeyboard.Button_Action: + case SettingKeyboard.Button_Cancel: + case SettingKeyboard.Button_Menu: + case SettingKeyboard.Button_Stats: + case SettingKeyboard.Button_Cycle_Shiny: + case SettingKeyboard.Button_Cycle_Form: + case SettingKeyboard.Button_Cycle_Gender: + case SettingKeyboard.Button_Cycle_Ability: + case SettingKeyboard.Button_Cycle_Nature: + case SettingKeyboard.Button_Cycle_Variant: + case SettingKeyboard.Button_Speed_Up: + case SettingKeyboard.Button_Slow_Down: + case SettingKeyboard.Alt_Button_Up: + case SettingKeyboard.Alt_Button_Down: + case SettingKeyboard.Alt_Button_Left: + case SettingKeyboard.Alt_Button_Right: + case SettingKeyboard.Alt_Button_Action: + case SettingKeyboard.Alt_Button_Cancel: + case SettingKeyboard.Alt_Button_Menu: + case SettingKeyboard.Alt_Button_Stats: + case SettingKeyboard.Alt_Button_Cycle_Shiny: + case SettingKeyboard.Alt_Button_Cycle_Form: + case SettingKeyboard.Alt_Button_Cycle_Gender: + case SettingKeyboard.Alt_Button_Cycle_Ability: + case SettingKeyboard.Alt_Button_Cycle_Nature: + case SettingKeyboard.Alt_Button_Cycle_Variant: + case SettingKeyboard.Alt_Button_Speed_Up: + case SettingKeyboard.Alt_Button_Slow_Down: + case SettingKeyboard.Alt_Button_Submit: + if (value) { + if (scene.ui) { + const cancelHandler = (success: boolean = false) : boolean => { + scene.ui.revertMode(); + (scene.ui.getHandler() as SettingsKeyboardUiHandler).updateBindings(); + return success; + }; + scene.ui.setOverlayMode(Mode.KEYBOARD_BINDING, { + target: setting, + cancelHandler: cancelHandler, + }); + } } - } - break; + break; // case SettingKeyboard.Default_Layout: // if (value && scene.ui) { // const cancelHandler = () => { diff --git a/src/system/settings/settings.ts b/src/system/settings/settings.ts index 66021845c29..d71edf603dd 100644 --- a/src/system/settings/settings.ts +++ b/src/system/settings/settings.ts @@ -76,16 +76,16 @@ const SHOP_CURSOR_TARGET_OPTIONS: SettingOption[] = [ const shopCursorTargetIndexMap = SHOP_CURSOR_TARGET_OPTIONS.map(option => { switch (option.value) { - case "Rewards": - return ShopCursorTarget.REWARDS; - case "Shop": - return ShopCursorTarget.SHOP; - case "Reroll": - return ShopCursorTarget.REROLL; - case "Check Team": - return ShopCursorTarget.CHECK_TEAM; - default: - throw new Error(`Unknown value: ${option.value}`); + case "Rewards": + return ShopCursorTarget.REWARDS; + case "Shop": + return ShopCursorTarget.SHOP; + case "Reroll": + return ShopCursorTarget.REROLL; + case "Check Team": + return ShopCursorTarget.CHECK_TEAM; + default: + throw new Error(`Unknown value: ${option.value}`); } }); @@ -163,6 +163,11 @@ export const SettingKeys = { Shop_Overlay_Opacity: "SHOP_OVERLAY_OPACITY" }; +export enum MusicPreference { + CONSISTENT, + MIXED +} + /** * All Settings not related to controls */ @@ -634,7 +639,7 @@ export const Setting: Array = [ label: i18next.t("settings:mixed") } ], - default: 0, + default: MusicPreference.MIXED, type: SettingType.AUDIO, requireReload: true }, @@ -699,226 +704,226 @@ export function setSetting(scene: BattleScene, setting: string, value: integer): return false; } switch (Setting[index].key) { - case SettingKeys.Game_Speed: - scene.gameSpeed = parseFloat(Setting[index].options[value].value.replace("x", "")); - break; - case SettingKeys.Master_Volume: - scene.masterVolume = value ? parseInt(Setting[index].options[value].value) * 0.01 : 0; - scene.updateSoundVolume(); - break; - case SettingKeys.BGM_Volume: - scene.bgmVolume = value ? parseInt(Setting[index].options[value].value) * 0.01 : 0; - scene.updateSoundVolume(); - break; - case SettingKeys.Field_Volume: - scene.fieldVolume = value ? parseInt(Setting[index].options[value].value) * 0.01 : 0; - scene.updateSoundVolume(); - break; - case SettingKeys.SE_Volume: - scene.seVolume = value ? parseInt(Setting[index].options[value].value) * 0.01 : 0; - scene.updateSoundVolume(); - break; - case SettingKeys.UI_Volume: - scene.uiVolume = value ? parseInt(Setting[index].options[value].value) * 0.01 : 0; - break; - case SettingKeys.Music_Preference: - scene.musicPreference = value; - break; - case SettingKeys.Damage_Numbers: - scene.damageNumbersMode = value; - break; - case SettingKeys.UI_Theme: - scene.uiTheme = value; - break; - case SettingKeys.Window_Type: - updateWindowType(scene, parseInt(Setting[index].options[value].value)); - break; - case SettingKeys.Tutorials: - scene.enableTutorials = Setting[index].options[value].value === "On"; - break; - case SettingKeys.Move_Info: - scene.enableMoveInfo = Setting[index].options[value].value === "On"; - break; - case SettingKeys.Enable_Retries: - scene.enableRetries = Setting[index].options[value].value === "On"; - break; - case SettingKeys.Hide_IVs: - scene.hideIvs = Setting[index].options[value].value === "On"; - break; - case SettingKeys.Skip_Seen_Dialogues: - scene.skipSeenDialogues = Setting[index].options[value].value === "On"; - break; - case SettingKeys.Egg_Skip: - scene.eggSkipPreference = value; - break; - case SettingKeys.Battle_Style: - scene.battleStyle = value; - break; - case SettingKeys.Show_BGM_Bar: - scene.showBgmBar = Setting[index].options[value].value === "On"; - break; - case SettingKeys.Candy_Upgrade_Notification: - if (scene.candyUpgradeNotification === value) { + case SettingKeys.Game_Speed: + scene.gameSpeed = parseFloat(Setting[index].options[value].value.replace("x", "")); break; - } - scene.candyUpgradeNotification = value; - scene.eventTarget.dispatchEvent(new CandyUpgradeNotificationChangedEvent(value)); - break; - case SettingKeys.Candy_Upgrade_Display: - scene.candyUpgradeDisplay = value; - case SettingKeys.Money_Format: - switch (Setting[index].options[value].value) { - case "Normal": - scene.moneyFormat = MoneyFormat.NORMAL; + case SettingKeys.Master_Volume: + scene.masterVolume = value ? parseInt(Setting[index].options[value].value) * 0.01 : 0; + scene.updateSoundVolume(); break; - case "Abbreviated": - scene.moneyFormat = MoneyFormat.ABBREVIATED; + case SettingKeys.BGM_Volume: + scene.bgmVolume = value ? parseInt(Setting[index].options[value].value) * 0.01 : 0; + scene.updateSoundVolume(); break; - } - scene.updateMoneyText(false); - break; - case SettingKeys.Sprite_Set: - scene.experimentalSprites = !!value; - if (value) { - scene.initExpSprites(); - } - break; - case SettingKeys.Move_Animations: - scene.moveAnimations = Setting[index].options[value].value === "On"; - break; - case SettingKeys.Show_Moveset_Flyout: - scene.showMovesetFlyout = Setting[index].options[value].value === "On"; - break; - case SettingKeys.Show_Arena_Flyout: - scene.showArenaFlyout = Setting[index].options[value].value === "On"; - break; - case SettingKeys.Show_Time_Of_Day_Widget: - scene.showTimeOfDayWidget = Setting[index].options[value].value === "On"; - break; - case SettingKeys.Time_Of_Day_Animation: - scene.timeOfDayAnimation = Setting[index].options[value].value === "Bounce" ? EaseType.BOUNCE : EaseType.BACK; - break; - case SettingKeys.Show_Stats_on_Level_Up: - scene.showLevelUpStats = Setting[index].options[value].value === "On"; - break; - case SettingKeys.Shop_Cursor_Target: - const selectedValue = shopCursorTargetIndexMap[value]; - scene.shopCursorTarget = selectedValue; - break; - case SettingKeys.EXP_Gains_Speed: - scene.expGainsSpeed = value; - break; - case SettingKeys.EXP_Party_Display: - scene.expParty = value; - break; - case SettingKeys.HP_Bar_Speed: - scene.hpBarSpeed = value; - break; - case SettingKeys.Fusion_Palette_Swaps: - scene.fusionPaletteSwaps = !!value; - break; - case SettingKeys.Player_Gender: - if (scene.gameData) { - const female = Setting[index].options[value].value === "Girl"; - scene.gameData.gender = female ? PlayerGender.FEMALE : PlayerGender.MALE; - scene.trainer.setTexture(scene.trainer.texture.key.replace(female ? "m" : "f", female ? "f" : "m")); - } else { - return false; - } - break; - case SettingKeys.Touch_Controls: - scene.enableTouchControls = Setting[index].options[value].value !== "Disabled" && hasTouchscreen(); - const touchControls = document.getElementById("touchControls"); - if (touchControls) { - touchControls.classList.toggle("visible", scene.enableTouchControls); - } - break; - case SettingKeys.Vibration: - scene.enableVibration = Setting[index].options[value].value !== "Disabled" && hasTouchscreen(); - break; - case SettingKeys.Type_Hints: - scene.typeHints = Setting[index].options[value].value === "On"; - break; - case SettingKeys.Language: - if (value) { - if (scene.ui) { - const cancelHandler = () => { - scene.ui.revertMode(); - (scene.ui.getHandler() as SettingsUiHandler).setOptionCursor(0, 0, true); - }; - const changeLocaleHandler = (locale: string): boolean => { - try { - i18next.changeLanguage(locale); - localStorage.setItem("prLang", locale); - cancelHandler(); - // Reload the whole game to apply the new locale since also some constants are translated - window.location.reload(); - return true; - } catch (error) { - console.error("Error changing locale:", error); - return false; - } - }; - scene.ui.setOverlayMode(Mode.OPTION_SELECT, { - options: [ - { - label: "English", - handler: () => changeLocaleHandler("en") - }, - { - label: "Español", - handler: () => changeLocaleHandler("es") - }, - { - label: "Italiano", - handler: () => changeLocaleHandler("it") - }, - { - label: "Français", - handler: () => changeLocaleHandler("fr") - }, - { - label: "Deutsch", - handler: () => changeLocaleHandler("de") - }, - { - label: "Português (BR)", - handler: () => changeLocaleHandler("pt-BR") - }, - { - label: "简体中文", - handler: () => changeLocaleHandler("zh-CN") - }, - { - label: "繁體中文", - handler: () => changeLocaleHandler("zh-TW") - }, - { - label: "한국어", - handler: () => changeLocaleHandler("ko") - }, - { - label: "日本語", - handler: () => changeLocaleHandler("ja") - }, - // { - // label: "Català", - // handler: () => changeLocaleHandler("ca-ES") - // }, - { - label: i18next.t("settings:back"), - handler: () => cancelHandler() - } - ], - maxOptions: 7 - }); + case SettingKeys.Field_Volume: + scene.fieldVolume = value ? parseInt(Setting[index].options[value].value) * 0.01 : 0; + scene.updateSoundVolume(); + break; + case SettingKeys.SE_Volume: + scene.seVolume = value ? parseInt(Setting[index].options[value].value) * 0.01 : 0; + scene.updateSoundVolume(); + break; + case SettingKeys.UI_Volume: + scene.uiVolume = value ? parseInt(Setting[index].options[value].value) * 0.01 : 0; + break; + case SettingKeys.Music_Preference: + scene.musicPreference = value; + break; + case SettingKeys.Damage_Numbers: + scene.damageNumbersMode = value; + break; + case SettingKeys.UI_Theme: + scene.uiTheme = value; + break; + case SettingKeys.Window_Type: + updateWindowType(scene, parseInt(Setting[index].options[value].value)); + break; + case SettingKeys.Tutorials: + scene.enableTutorials = Setting[index].options[value].value === "On"; + break; + case SettingKeys.Move_Info: + scene.enableMoveInfo = Setting[index].options[value].value === "On"; + break; + case SettingKeys.Enable_Retries: + scene.enableRetries = Setting[index].options[value].value === "On"; + break; + case SettingKeys.Hide_IVs: + scene.hideIvs = Setting[index].options[value].value === "On"; + break; + case SettingKeys.Skip_Seen_Dialogues: + scene.skipSeenDialogues = Setting[index].options[value].value === "On"; + break; + case SettingKeys.Egg_Skip: + scene.eggSkipPreference = value; + break; + case SettingKeys.Battle_Style: + scene.battleStyle = value; + break; + case SettingKeys.Show_BGM_Bar: + scene.showBgmBar = Setting[index].options[value].value === "On"; + break; + case SettingKeys.Candy_Upgrade_Notification: + if (scene.candyUpgradeNotification === value) { + break; + } + scene.candyUpgradeNotification = value; + scene.eventTarget.dispatchEvent(new CandyUpgradeNotificationChangedEvent(value)); + break; + case SettingKeys.Candy_Upgrade_Display: + scene.candyUpgradeDisplay = value; + case SettingKeys.Money_Format: + switch (Setting[index].options[value].value) { + case "Normal": + scene.moneyFormat = MoneyFormat.NORMAL; + break; + case "Abbreviated": + scene.moneyFormat = MoneyFormat.ABBREVIATED; + break; + } + scene.updateMoneyText(false); + break; + case SettingKeys.Sprite_Set: + scene.experimentalSprites = !!value; + if (value) { + scene.initExpSprites(); + } + break; + case SettingKeys.Move_Animations: + scene.moveAnimations = Setting[index].options[value].value === "On"; + break; + case SettingKeys.Show_Moveset_Flyout: + scene.showMovesetFlyout = Setting[index].options[value].value === "On"; + break; + case SettingKeys.Show_Arena_Flyout: + scene.showArenaFlyout = Setting[index].options[value].value === "On"; + break; + case SettingKeys.Show_Time_Of_Day_Widget: + scene.showTimeOfDayWidget = Setting[index].options[value].value === "On"; + break; + case SettingKeys.Time_Of_Day_Animation: + scene.timeOfDayAnimation = Setting[index].options[value].value === "Bounce" ? EaseType.BOUNCE : EaseType.BACK; + break; + case SettingKeys.Show_Stats_on_Level_Up: + scene.showLevelUpStats = Setting[index].options[value].value === "On"; + break; + case SettingKeys.Shop_Cursor_Target: + const selectedValue = shopCursorTargetIndexMap[value]; + scene.shopCursorTarget = selectedValue; + break; + case SettingKeys.EXP_Gains_Speed: + scene.expGainsSpeed = value; + break; + case SettingKeys.EXP_Party_Display: + scene.expParty = value; + break; + case SettingKeys.HP_Bar_Speed: + scene.hpBarSpeed = value; + break; + case SettingKeys.Fusion_Palette_Swaps: + scene.fusionPaletteSwaps = !!value; + break; + case SettingKeys.Player_Gender: + if (scene.gameData) { + const female = Setting[index].options[value].value === "Girl"; + scene.gameData.gender = female ? PlayerGender.FEMALE : PlayerGender.MALE; + scene.trainer.setTexture(scene.trainer.texture.key.replace(female ? "m" : "f", female ? "f" : "m")); + } else { return false; } - } - break; - case SettingKeys.Shop_Overlay_Opacity: - scene.updateShopOverlayOpacity(parseInt(Setting[index].options[value].value) * .01); - break; + break; + case SettingKeys.Touch_Controls: + scene.enableTouchControls = Setting[index].options[value].value !== "Disabled" && hasTouchscreen(); + const touchControls = document.getElementById("touchControls"); + if (touchControls) { + touchControls.classList.toggle("visible", scene.enableTouchControls); + } + break; + case SettingKeys.Vibration: + scene.enableVibration = Setting[index].options[value].value !== "Disabled" && hasTouchscreen(); + break; + case SettingKeys.Type_Hints: + scene.typeHints = Setting[index].options[value].value === "On"; + break; + case SettingKeys.Language: + if (value) { + if (scene.ui) { + const cancelHandler = () => { + scene.ui.revertMode(); + (scene.ui.getHandler() as SettingsUiHandler).setOptionCursor(0, 0, true); + }; + const changeLocaleHandler = (locale: string): boolean => { + try { + i18next.changeLanguage(locale); + localStorage.setItem("prLang", locale); + cancelHandler(); + // Reload the whole game to apply the new locale since also some constants are translated + window.location.reload(); + return true; + } catch (error) { + console.error("Error changing locale:", error); + return false; + } + }; + scene.ui.setOverlayMode(Mode.OPTION_SELECT, { + options: [ + { + label: "English", + handler: () => changeLocaleHandler("en") + }, + { + label: "Español (ES)", + handler: () => changeLocaleHandler("es-ES") + }, + { + label: "Italiano", + handler: () => changeLocaleHandler("it") + }, + { + label: "Français", + handler: () => changeLocaleHandler("fr") + }, + { + label: "Deutsch", + handler: () => changeLocaleHandler("de") + }, + { + label: "Português (BR)", + handler: () => changeLocaleHandler("pt-BR") + }, + { + label: "简体中文", + handler: () => changeLocaleHandler("zh-CN") + }, + { + label: "繁體中文", + handler: () => changeLocaleHandler("zh-TW") + }, + { + label: "한국어", + handler: () => changeLocaleHandler("ko") + }, + { + label: "日本語", + handler: () => changeLocaleHandler("ja") + }, + // { + // label: "Català", + // handler: () => changeLocaleHandler("ca-ES") + // }, + { + label: i18next.t("settings:back"), + handler: () => cancelHandler() + } + ], + maxOptions: 7 + }); + return false; + } + } + break; + case SettingKeys.Shop_Overlay_Opacity: + scene.updateShopOverlayOpacity(parseInt(Setting[index].options[value].value) * .01); + break; } return true; diff --git a/src/system/unlockables.ts b/src/system/unlockables.ts index 983909373fd..0a666e2c755 100644 --- a/src/system/unlockables.ts +++ b/src/system/unlockables.ts @@ -10,13 +10,13 @@ export enum Unlockables { export function getUnlockableName(unlockable: Unlockables) { switch (unlockable) { - case Unlockables.ENDLESS_MODE: - return `${GameMode.getModeName(GameModes.ENDLESS)} Mode`; - case Unlockables.MINI_BLACK_HOLE: - return i18next.t("modifierType:ModifierType.MINI_BLACK_HOLE.name"); - case Unlockables.SPLICED_ENDLESS_MODE: - return `${GameMode.getModeName(GameModes.SPLICED_ENDLESS)} Mode`; - case Unlockables.EVIOLITE: - return i18next.t("modifierType:ModifierType.EVIOLITE.name"); + case Unlockables.ENDLESS_MODE: + return `${GameMode.getModeName(GameModes.ENDLESS)} Mode`; + case Unlockables.MINI_BLACK_HOLE: + return i18next.t("modifierType:ModifierType.MINI_BLACK_HOLE.name"); + case Unlockables.SPLICED_ENDLESS_MODE: + return `${GameMode.getModeName(GameModes.SPLICED_ENDLESS)} Mode`; + case Unlockables.EVIOLITE: + return i18next.t("modifierType:ModifierType.EVIOLITE.name"); } } diff --git a/src/system/version-converter.ts b/src/system/version-converter.ts deleted file mode 100644 index c297782ba66..00000000000 --- a/src/system/version-converter.ts +++ /dev/null @@ -1,141 +0,0 @@ -import { allSpecies } from "#app/data/pokemon-species"; -import { AbilityAttr, defaultStarterSpecies, DexAttr, SessionSaveData, SystemSaveData } from "./game-data"; -import { SettingKeys } from "./settings/settings"; - -const LATEST_VERSION = "1.0.5"; - -export function applySessionDataPatches(data: SessionSaveData) { - const curVersion = data.gameVersion; - if (curVersion !== LATEST_VERSION) { - switch (curVersion) { - case "1.0.0": - case "1.0.1": - case "1.0.2": - case "1.0.3": - case "1.0.4": - // --- PATCHES --- - - // Fix Battle Items, Vitamins, and Lures - data.modifiers.forEach((m) => { - if (m.className === "PokemonBaseStatModifier") { - m.className = "BaseStatModifier"; - } else if (m.className === "PokemonResetNegativeStatStageModifier") { - m.className = "ResetNegativeStatStageModifier"; - } else if (m.className === "TempBattleStatBoosterModifier") { - m.className = "TempStatStageBoosterModifier"; - m.typeId = "TEMP_STAT_STAGE_BOOSTER"; - - // Migration from TempBattleStat to Stat - const newStat = m.typePregenArgs[0] + 1; - m.typePregenArgs[0] = newStat; - - // From [ stat, battlesLeft ] to [ stat, maxBattles, battleCount ] - m.args = [ newStat, 5, m.args[1] ]; - } else if (m.className === "DoubleBattleChanceBoosterModifier" && m.args.length === 1) { - let maxBattles: number; - switch (m.typeId) { - case "MAX_LURE": - maxBattles = 30; - break; - case "SUPER_LURE": - maxBattles = 15; - break; - default: - maxBattles = 10; - break; - } - - // From [ battlesLeft ] to [ maxBattles, battleCount ] - m.args = [ maxBattles, m.args[0] ]; - } - }); - - data.enemyModifiers.forEach((m) => { - if (m.className === "PokemonBaseStatModifier") { - m.className = "BaseStatModifier"; - } else if (m.className === "PokemonResetNegativeStatStageModifier") { - m.className = "ResetNegativeStatStageModifier"; - } - }); - } - - data.gameVersion = LATEST_VERSION; - } -} - -export function applySystemDataPatches(data: SystemSaveData) { - const curVersion = data.gameVersion; - if (curVersion !== LATEST_VERSION) { - switch (curVersion) { - case "1.0.0": - case "1.0.1": - case "1.0.2": - case "1.0.3": - case "1.0.4": - // --- LEGACY PATCHES --- - if (data.starterData) { - // Migrate ability starter data if empty for caught species - Object.keys(data.starterData).forEach(sd => { - if (data.dexData[sd]?.caughtAttr && (data.starterData[sd] && !data.starterData[sd].abilityAttr)) { - data.starterData[sd].abilityAttr = 1; - } - }); - } - - // Fix Legendary Stats - if (data.gameStats && (data.gameStats.legendaryPokemonCaught !== undefined && data.gameStats.subLegendaryPokemonCaught === undefined)) { - data.gameStats.subLegendaryPokemonSeen = 0; - data.gameStats.subLegendaryPokemonCaught = 0; - data.gameStats.subLegendaryPokemonHatched = 0; - allSpecies.filter(s => s.subLegendary).forEach(s => { - const dexEntry = data.dexData[s.speciesId]; - data.gameStats.subLegendaryPokemonSeen += dexEntry.seenCount; - data.gameStats.legendaryPokemonSeen = Math.max(data.gameStats.legendaryPokemonSeen - dexEntry.seenCount, 0); - data.gameStats.subLegendaryPokemonCaught += dexEntry.caughtCount; - data.gameStats.legendaryPokemonCaught = Math.max(data.gameStats.legendaryPokemonCaught - dexEntry.caughtCount, 0); - data.gameStats.subLegendaryPokemonHatched += dexEntry.hatchedCount; - data.gameStats.legendaryPokemonHatched = Math.max(data.gameStats.legendaryPokemonHatched - dexEntry.hatchedCount, 0); - }); - data.gameStats.subLegendaryPokemonSeen = Math.max(data.gameStats.subLegendaryPokemonSeen, data.gameStats.subLegendaryPokemonCaught); - data.gameStats.legendaryPokemonSeen = Math.max(data.gameStats.legendaryPokemonSeen, data.gameStats.legendaryPokemonCaught); - data.gameStats.mythicalPokemonSeen = Math.max(data.gameStats.mythicalPokemonSeen, data.gameStats.mythicalPokemonCaught); - } - - // --- PATCHES --- - - // Fix Starter Data - for (const starterId of defaultStarterSpecies) { - if (data.starterData[starterId]?.abilityAttr) { - data.starterData[starterId].abilityAttr |= AbilityAttr.ABILITY_1; - } - if (data.dexData[starterId]?.caughtAttr) { - data.dexData[starterId].caughtAttr |= DexAttr.FEMALE; - } - } - } - - data.gameVersion = LATEST_VERSION; - } -} - -export function applySettingsDataPatches(settings: Object) { - const curVersion = settings.hasOwnProperty("gameVersion") ? settings["gameVersion"] : "1.0.0"; - if (curVersion !== LATEST_VERSION) { - switch (curVersion) { - case "1.0.0": - case "1.0.1": - case "1.0.2": - case "1.0.3": - case "1.0.4": - // --- PATCHES --- - - // Fix Reward Cursor Target - if (settings.hasOwnProperty("REROLL_TARGET") && !settings.hasOwnProperty(SettingKeys.Shop_Cursor_Target)) { - settings[SettingKeys.Shop_Cursor_Target] = settings["REROLL_TARGET"]; - delete settings["REROLL_TARGET"]; - localStorage.setItem("settings", JSON.stringify(settings)); - } - } - // Note that the current game version will be written at `saveSettings` - } -} diff --git a/src/system/version_migration/version_converter.ts b/src/system/version_migration/version_converter.ts new file mode 100644 index 00000000000..d0c69dc3213 --- /dev/null +++ b/src/system/version_migration/version_converter.ts @@ -0,0 +1,197 @@ +import { SessionSaveData, SystemSaveData } from "../game-data"; +import { version } from "../../../package.json"; + +// --- v1.0.4 (and below) PATCHES --- // +import * as v1_0_4 from "./versions/v1_0_4"; + +// --- v1.1.0 PATCHES --- // +import * as v1_1_0 from "./versions/v1_1_0"; + +const LATEST_VERSION = version.split(".").map(value => parseInt(value)); + +/** + * Converts incoming {@linkcode SystemSaveData} that has a version below the + * current version number listed in `package.json`. + * + * Note that no transforms act on the {@linkcode data} if its version matches + * the current version or if there are no migrations made between its version up + * to the current version. + * @param data {@linkcode SystemSaveData} + * @see {@link SystemVersionConverter} + */ +export function applySystemVersionMigration(data: SystemSaveData) { + const curVersion = data.gameVersion.split(".").map(value => parseInt(value)); + + if (!curVersion.every((value, index) => value === LATEST_VERSION[index])) { + const converter = new SystemVersionConverter(); + converter.applyStaticPreprocessors(data); + converter.applyMigration(data, curVersion); + } +} + +/** + * Converts incoming {@linkcode SessionSavaData} that has a version below the + * current version number listed in `package.json`. + * + * Note that no transforms act on the {@linkcode data} if its version matches + * the current version or if there are no migrations made between its version up + * to the current version. + * @param data {@linkcode SessionSaveData} + * @see {@link SessionVersionConverter} + */ +export function applySessionVersionMigration(data: SessionSaveData) { + const curVersion = data.gameVersion.split(".").map(value => parseInt(value)); + + if (!curVersion.every((value, index) => value === LATEST_VERSION[index])) { + const converter = new SessionVersionConverter(); + converter.applyStaticPreprocessors(data); + converter.applyMigration(data, curVersion); + } +} + +/** + * Converts incoming settings data that has a version below the + * current version number listed in `package.json`. + * + * Note that no transforms act on the {@linkcode data} if its version matches + * the current version or if there are no migrations made between its version up + * to the current version. + * @param data Settings data object + * @see {@link SettingsVersionConverter} + */ +export function applySettingsVersionMigration(data: Object) { + const gameVersion: string = data.hasOwnProperty("gameVersion") ? data["gameVersion"] : "1.0.0"; + const curVersion = gameVersion.split(".").map(value => parseInt(value)); + + if (!curVersion.every((value, index) => value === LATEST_VERSION[index])) { + const converter = new SettingsVersionConverter(); + converter.applyStaticPreprocessors(data); + converter.applyMigration(data, curVersion); + } +} + +/** + * Abstract class encapsulating the logic for migrating data from a given version up to + * the current version listed in `package.json`. + * + * Note that, for any version converter, the corresponding `applyMigration` + * function would only need to be changed once when the first migration for a + * given version is introduced. Similarly, a version file (within the `versions` + * folder) would only need to be created for a version once with the appropriate + * array nomenclature. + */ +abstract class VersionConverter { + /** + * Iterates through an array of designated migration functions that are each + * called one by one to transform the data. + * @param data The data to be operated on + * @param migrationArr An array of functions that will transform the incoming data + */ + callMigrators(data: any, migrationArr: readonly any[]) { + for (const migrate of migrationArr) { + migrate(data); + } + } + + /** + * Applies any version-agnostic data sanitation as defined within the function + * body. + * @param data The data to be operated on + */ + applyStaticPreprocessors(_data: any): void { + } + + /** + * Uses the current version the incoming data to determine the starting point + * of the migration which will cascade up to the latest version, calling the + * necessary migration functions in the process. + * @param data The data to be operated on + * @param curVersion [0] Current major version + * [1] Current minor version + * [2] Current patch version + */ + abstract applyMigration(data: any, curVersion: number[]): void; +} + +/** + * Class encapsulating the logic for migrating {@linkcode SessionSaveData} from + * a given version up to the current version listed in `package.json`. + * @extends VersionConverter + */ +class SessionVersionConverter extends VersionConverter { + override applyStaticPreprocessors(data: SessionSaveData): void { + // Always sanitize money as a safeguard + data.money = Math.floor(data.money); + } + + override applyMigration(data: SessionSaveData, curVersion: number[]): void { + const [ curMajor, curMinor, curPatch ] = curVersion; + + if (curMajor === 1) { + if (curMinor === 0) { + if (curPatch <= 5) { + console.log("Applying v1.0.4 session data migration!"); + this.callMigrators(data, v1_0_4.sessionMigrators); + } + } + if (curMinor <= 1) { + console.log("Applying v1.1.0 session data migration!"); + this.callMigrators(data, v1_1_0.sessionMigrators); + } + } + + console.log(`Session data successfully migrated to v${version}!`); + } +} + +/** + * Class encapsulating the logic for migrating {@linkcode SystemSaveData} from + * a given version up to the current version listed in `package.json`. + * @extends VersionConverter + */ +class SystemVersionConverter extends VersionConverter { + override applyMigration(data: SystemSaveData, curVersion: number[]): void { + const [ curMajor, curMinor, curPatch ] = curVersion; + + if (curMajor === 1) { + if (curMinor === 0) { + if (curPatch <= 4) { + console.log("Applying v1.0.4 system data migraton!"); + this.callMigrators(data, v1_0_4.systemMigrators); + } + } + if (curMinor <= 1) { + console.log("Applying v1.1.0 system data migraton!"); + this.callMigrators(data, v1_1_0.systemMigrators); + } + } + + console.log(`System data successfully migrated to v${version}!`); + } +} + +/** + * Class encapsulating the logic for migrating settings data from + * a given version up to the current version listed in `package.json`. + * @extends VersionConverter + */ +class SettingsVersionConverter extends VersionConverter { + override applyMigration(data: Object, curVersion: number[]): void { + const [ curMajor, curMinor, curPatch ] = curVersion; + + if (curMajor === 1) { + if (curMinor === 0) { + if (curPatch <= 4) { + console.log("Applying v1.0.4 settings data migraton!"); + this.callMigrators(data, v1_0_4.settingsMigrators); + } + } + if (curMinor <= 1) { + console.log("Applying v1.1.0 settings data migraton!"); + this.callMigrators(data, v1_1_0.settingsMigrators); + } + } + + console.log(`System data successfully migrated to v${version}!`); + } +} diff --git a/src/system/version_migration/versions/v1_0_4.ts b/src/system/version_migration/versions/v1_0_4.ts new file mode 100644 index 00000000000..95f0337ecdd --- /dev/null +++ b/src/system/version_migration/versions/v1_0_4.ts @@ -0,0 +1,162 @@ +import { SettingKeys } from "#app/system/settings/settings"; +import { AbilityAttr, defaultStarterSpecies, DexAttr, SystemSaveData, SessionSaveData } from "#app/system/game-data"; +import { allSpecies } from "#app/data/pokemon-species"; +import { CustomPokemonData } from "#app/data/custom-pokemon-data"; +import { isNullOrUndefined } from "#app/utils"; + +export const systemMigrators = [ + /** + * Migrate ability starter data if empty for caught species. + * @param data {@linkcode SystemSaveData} + */ + function migrateAbilityData(data: SystemSaveData) { + if (data.starterData && data.dexData) { + Object.keys(data.starterData).forEach(sd => { + if (data.dexData[sd]?.caughtAttr && (data.starterData[sd] && !data.starterData[sd].abilityAttr)) { + data.starterData[sd].abilityAttr = 1; + } + }); + } + }, + + /** + * Populate legendary Pokémon statistics if they are missing. + * @param data {@linkcode SystemSaveData} + */ + function fixLegendaryStats(data: SystemSaveData) { + if (data.gameStats && (data.gameStats.legendaryPokemonCaught !== undefined && data.gameStats.subLegendaryPokemonCaught === undefined)) { + data.gameStats.subLegendaryPokemonSeen = 0; + data.gameStats.subLegendaryPokemonCaught = 0; + data.gameStats.subLegendaryPokemonHatched = 0; + allSpecies.filter(s => s.subLegendary).forEach(s => { + const dexEntry = data.dexData[s.speciesId]; + data.gameStats.subLegendaryPokemonSeen += dexEntry.seenCount; + data.gameStats.legendaryPokemonSeen = Math.max(data.gameStats.legendaryPokemonSeen - dexEntry.seenCount, 0); + data.gameStats.subLegendaryPokemonCaught += dexEntry.caughtCount; + data.gameStats.legendaryPokemonCaught = Math.max(data.gameStats.legendaryPokemonCaught - dexEntry.caughtCount, 0); + data.gameStats.subLegendaryPokemonHatched += dexEntry.hatchedCount; + data.gameStats.legendaryPokemonHatched = Math.max(data.gameStats.legendaryPokemonHatched - dexEntry.hatchedCount, 0); + }); + data.gameStats.subLegendaryPokemonSeen = Math.max(data.gameStats.subLegendaryPokemonSeen, data.gameStats.subLegendaryPokemonCaught); + data.gameStats.legendaryPokemonSeen = Math.max(data.gameStats.legendaryPokemonSeen, data.gameStats.legendaryPokemonCaught); + data.gameStats.mythicalPokemonSeen = Math.max(data.gameStats.mythicalPokemonSeen, data.gameStats.mythicalPokemonCaught); + } + }, + + /** + * Unlock all starters' first ability and female gender option. + * @param data {@linkcode SystemSaveData} + */ + function fixStarterData(data: SystemSaveData) { + if (!isNullOrUndefined(data.starterData)) { + for (const starterId of defaultStarterSpecies) { + if (data.starterData[starterId]?.abilityAttr) { + data.starterData[starterId].abilityAttr |= AbilityAttr.ABILITY_1; + } + if (data.dexData[starterId]?.caughtAttr) { + data.dexData[starterId].caughtAttr |= DexAttr.FEMALE; + } + } + } + } +] as const; + +export const settingsMigrators = [ + /** + * Migrate from "REROLL_TARGET" property to {@linkcode + * SettingKeys.Shop_Cursor_Target}. + * @param data the `settings` object + */ + function fixRerollTarget(data: Object) { + if (data.hasOwnProperty("REROLL_TARGET") && !data.hasOwnProperty(SettingKeys.Shop_Cursor_Target)) { + data[SettingKeys.Shop_Cursor_Target] = data["REROLL_TARGET"]; + delete data["REROLL_TARGET"]; + localStorage.setItem("settings", JSON.stringify(data)); + } + } +] as const; + +export const sessionMigrators = [ + /** + * Converts old lapsing modifiers (battle items, lures, and Dire Hit) and + * other miscellaneous modifiers (vitamins, White Herb) to any new class + * names and/or change in reload arguments. + * @param data {@linkcode SessionSaveData} + */ + function migrateModifiers(data: SessionSaveData) { + data.modifiers.forEach((m) => { + if (m.className === "PokemonBaseStatModifier") { + m.className = "BaseStatModifier"; + } else if (m.className === "PokemonResetNegativeStatStageModifier") { + m.className = "ResetNegativeStatStageModifier"; + } else if (m.className === "TempBattleStatBoosterModifier") { + const maxBattles = 5; + // Dire Hit no longer a part of the TempBattleStatBoosterModifierTypeGenerator + if (m.typeId !== "DIRE_HIT") { + m.className = "TempStatStageBoosterModifier"; + m.typeId = "TEMP_STAT_STAGE_BOOSTER"; + + // Migration from TempBattleStat to Stat + const newStat = m.typePregenArgs[0] + 1; + m.typePregenArgs[0] = newStat; + + // From [ stat, battlesLeft ] to [ stat, maxBattles, battleCount ] + m.args = [ newStat, maxBattles, Math.min(m.args[1], maxBattles) ]; + } else { + m.className = "TempCritBoosterModifier"; + m.typePregenArgs = []; + + // From [ stat, battlesLeft ] to [ maxBattles, battleCount ] + m.args = [ maxBattles, Math.min(m.args[1], maxBattles) ]; + } + } else if (m.className === "DoubleBattleChanceBoosterModifier" && m.args.length === 1) { + let maxBattles: number; + switch (m.typeId) { + case "MAX_LURE": + maxBattles = 30; + break; + case "SUPER_LURE": + maxBattles = 15; + break; + default: + maxBattles = 10; + break; + } + + // From [ battlesLeft ] to [ maxBattles, battleCount ] + m.args = [ maxBattles, Math.min(m.args[0], maxBattles) ]; + } + }); + + data.enemyModifiers.forEach((m) => { + if (m.className === "PokemonBaseStatModifier") { + m.className = "BaseStatModifier"; + } else if (m.className === "PokemonResetNegativeStatStageModifier") { + m.className = "ResetNegativeStatStageModifier"; + } + }); + }, + /** + * Converts old Pokemon natureOverride and mysteryEncounterData + * to use the new conjoined {@linkcode Pokemon.customPokemonData} structure instead. + * @param data {@linkcode SessionSaveData} + */ + function migrateCustomPokemonDataAndNatureOverrides(data: SessionSaveData) { + // Fix Pokemon nature overrides and custom data migration + data.party.forEach(pokemon => { + if (pokemon["mysteryEncounterPokemonData"]) { + pokemon.customPokemonData = new CustomPokemonData(pokemon["mysteryEncounterPokemonData"]); + pokemon["mysteryEncounterPokemonData"] = null; + } + if (pokemon["fusionMysteryEncounterPokemonData"]) { + pokemon.fusionCustomPokemonData = new CustomPokemonData(pokemon["fusionMysteryEncounterPokemonData"]); + pokemon["fusionMysteryEncounterPokemonData"] = null; + } + pokemon.customPokemonData = pokemon.customPokemonData ?? new CustomPokemonData(); + if (!isNullOrUndefined(pokemon["natureOverride"]) && pokemon["natureOverride"] >= 0) { + pokemon.customPokemonData.nature = pokemon["natureOverride"]; + pokemon["natureOverride"] = -1; + } + }); + } +] as const; diff --git a/src/system/version_migration/versions/v1_1_0.ts b/src/system/version_migration/versions/v1_1_0.ts new file mode 100644 index 00000000000..5d6247aeaa2 --- /dev/null +++ b/src/system/version_migration/versions/v1_1_0.ts @@ -0,0 +1,5 @@ +export const systemMigrators = [] as const; + +export const settingsMigrators = [] as const; + +export const sessionMigrators = [] as const; diff --git a/src/system/voucher.ts b/src/system/voucher.ts index 06edfe5c6a6..b38fd528c9f 100644 --- a/src/system/voucher.ts +++ b/src/system/voucher.ts @@ -45,41 +45,41 @@ export class Voucher { getTier(): AchvTier { switch (this.voucherType) { - case VoucherType.REGULAR: - return AchvTier.COMMON; - case VoucherType.PLUS: - return AchvTier.GREAT; - case VoucherType.PREMIUM: - return AchvTier.ULTRA; - case VoucherType.GOLDEN: - return AchvTier.ROGUE; + case VoucherType.REGULAR: + return AchvTier.COMMON; + case VoucherType.PLUS: + return AchvTier.GREAT; + case VoucherType.PREMIUM: + return AchvTier.ULTRA; + case VoucherType.GOLDEN: + return AchvTier.ROGUE; } } } export function getVoucherTypeName(voucherType: VoucherType): string { switch (voucherType) { - case VoucherType.REGULAR: - return i18next.t("voucher:eggVoucher"); - case VoucherType.PLUS: - return i18next.t("voucher:eggVoucherPlus"); - case VoucherType.PREMIUM: - return i18next.t("voucher:eggVoucherPremium"); - case VoucherType.GOLDEN: - return i18next.t("voucher:eggVoucherGold"); + case VoucherType.REGULAR: + return i18next.t("voucher:eggVoucher"); + case VoucherType.PLUS: + return i18next.t("voucher:eggVoucherPlus"); + case VoucherType.PREMIUM: + return i18next.t("voucher:eggVoucherPremium"); + case VoucherType.GOLDEN: + return i18next.t("voucher:eggVoucherGold"); } } export function getVoucherTypeIcon(voucherType: VoucherType): string { switch (voucherType) { - case VoucherType.REGULAR: - return "coupon"; - case VoucherType.PLUS: - return "pair_of_tickets"; - case VoucherType.PREMIUM: - return "mystic_ticket"; - case VoucherType.GOLDEN: - return "golden_mystic_ticket"; + case VoucherType.REGULAR: + return "coupon"; + case VoucherType.PLUS: + return "pair_of_tickets"; + case VoucherType.PREMIUM: + return "mystic_ticket"; + case VoucherType.GOLDEN: + return "golden_mystic_ticket"; } } @@ -90,7 +90,7 @@ export interface Vouchers { export const vouchers: Vouchers = {}; export function initVouchers() { - for (const achv of [achvs.CLASSIC_VICTORY]) { + for (const achv of [ achvs.CLASSIC_VICTORY ]) { const voucherType = achv.score >= 150 ? VoucherType.GOLDEN : achv.score >= 100 diff --git a/src/test/abilities/ability_duplication.test.ts b/src/test/abilities/ability_duplication.test.ts new file mode 100644 index 00000000000..f9122b3259c --- /dev/null +++ b/src/test/abilities/ability_duplication.test.ts @@ -0,0 +1,58 @@ +import { Stat } from "#app/enums/stat"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, it, expect } from "vitest"; + +describe("Ability Duplication", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.SPLASH ]) + .battleType("single") + .ability(Abilities.HUGE_POWER) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.SPLASH); + }); + + it("huge power should only be applied once if both normal and passive", async () => { + game.override.passiveAbility(Abilities.HUGE_POWER); + + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const [ magikarp ] = game.scene.getPlayerField(); + const magikarpAttack = magikarp.getEffectiveStat(Stat.ATK); + + magikarp.summonData.abilitySuppressed = true; + + expect(magikarp.getEffectiveStat(Stat.ATK)).toBe(magikarpAttack / 2); + }); + + it("huge power should stack with pure power", async () => { + game.override.passiveAbility(Abilities.PURE_POWER); + + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const [ magikarp ] = game.scene.getPlayerField(); + const magikarpAttack = magikarp.getEffectiveStat(Stat.ATK); + + magikarp.summonData.abilitySuppressed = true; + + expect(magikarp.getEffectiveStat(Stat.ATK)).toBe(magikarpAttack / 4); + }); +}); diff --git a/src/test/abilities/ability_timing.test.ts b/src/test/abilities/ability_timing.test.ts index fb3d3af1a6b..e3264c2c1a8 100644 --- a/src/test/abilities/ability_timing.test.ts +++ b/src/test/abilities/ability_timing.test.ts @@ -1,13 +1,13 @@ import { BattleStyle } from "#app/enums/battle-style"; import { CommandPhase } from "#app/phases/command-phase"; import { TurnInitPhase } from "#app/phases/turn-init-phase"; -import i18next, { initI18n } from "#app/plugins/i18n"; +import i18next from "#app/plugins/i18n"; import { Mode } from "#app/ui/ui"; import { Abilities } from "#enums/abilities"; import { Species } from "#enums/species"; import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; -import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; +import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; describe("Ability Timing", () => { @@ -32,13 +32,12 @@ describe("Ability Timing", () => { .enemySpecies(Species.MAGIKARP) .enemyAbility(Abilities.INTIMIDATE) .ability(Abilities.BALL_FETCH); + vi.spyOn(i18next, "t"); }); it("should trigger after switch check", async () => { - initI18n(); - i18next.changeLanguage("en"); game.settings.battleStyle = BattleStyle.SWITCH; - await game.classicMode.runToSummon([Species.EEVEE, Species.FEEBAS]); + await game.classicMode.runToSummon([ Species.EEVEE, Species.FEEBAS ]); game.onNextPrompt("CheckSwitchPhase", Mode.CONFIRM, () => { game.setMode(Mode.MESSAGE); @@ -46,7 +45,6 @@ describe("Ability Timing", () => { }, () => game.isCurrentPhase(CommandPhase) || game.isCurrentPhase(TurnInitPhase)); await game.phaseInterceptor.to("MessagePhase"); - const message = game.textInterceptor.getLatestMessage(); - expect(message).toContain("Attack fell"); + expect(i18next.t).toHaveBeenCalledWith("battle:statFell", expect.objectContaining({ count: 1 })); }, 5000); }); diff --git a/src/test/abilities/arena_trap.test.ts b/src/test/abilities/arena_trap.test.ts new file mode 100644 index 00000000000..5068fed6b77 --- /dev/null +++ b/src/test/abilities/arena_trap.test.ts @@ -0,0 +1,58 @@ +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, it, expect } from "vitest"; + +describe("Abilities - Arena Trap", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset(Moves.SPLASH) + .ability(Abilities.ARENA_TRAP) + .enemySpecies(Species.RALTS) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.TELEPORT); + }); + + // TODO: Enable test when Issue #935 is addressed + it.todo("should not allow grounded Pokémon to flee", async () => { + game.override.battleType("single"); + + await game.classicMode.startBattle(); + + const enemy = game.scene.getEnemyPokemon(); + + game.move.select(Moves.SPLASH); + + await game.toNextTurn(); + + expect(enemy).toBe(game.scene.getEnemyPokemon()); + }); + + it("should guarantee double battle with any one LURE", async () => { + game.override + .startingModifier([ + { name: "LURE" }, + ]) + .startingWave(2); + + await game.classicMode.startBattle(); + + expect(game.scene.getEnemyField().length).toBe(2); + }); +}); diff --git a/src/test/abilities/aroma_veil.test.ts b/src/test/abilities/aroma_veil.test.ts new file mode 100644 index 00000000000..e74d0ff5a39 --- /dev/null +++ b/src/test/abilities/aroma_veil.test.ts @@ -0,0 +1,65 @@ +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import { Abilities } from "#enums/abilities"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; +import { BattlerTagType } from "#enums/battler-tag-type"; +import { ArenaTagType } from "#enums/arena-tag-type"; +import { BattlerIndex } from "#app/battle"; +import { PlayerPokemon } from "#app/field/pokemon"; + +describe("Moves - Aroma Veil", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .battleType("double") + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset([ Moves.HEAL_BLOCK, Moves.IMPRISON, Moves.SPLASH ]) + .enemySpecies(Species.SHUCKLE) + .ability(Abilities.AROMA_VEIL) + .moveset([ Moves.GROWL ]); + }); + + it("Aroma Veil protects the Pokemon's side against most Move Restriction Battler Tags", async () => { + await game.classicMode.startBattle([ Species.REGIELEKI, Species.BULBASAUR ]); + + const party = game.scene.getPlayerParty()! as PlayerPokemon[]; + + game.move.select(Moves.GROWL); + game.move.select(Moves.GROWL); + await game.forceEnemyMove(Moves.HEAL_BLOCK); + await game.toNextTurn(); + party.forEach(p => { + expect(p.getTag(BattlerTagType.HEAL_BLOCK)).toBeUndefined(); + }); + }); + + it("Aroma Veil does not protect against Imprison", async () => { + await game.classicMode.startBattle([ Species.REGIELEKI, Species.BULBASAUR ]); + + const party = game.scene.getPlayerParty()! as PlayerPokemon[]; + + game.move.select(Moves.GROWL); + game.move.select(Moves.GROWL, 1); + await game.forceEnemyMove(Moves.IMPRISON, BattlerIndex.PLAYER); + await game.forceEnemyMove(Moves.SPLASH); + await game.toNextTurn(); + expect(game.scene.arena.getTag(ArenaTagType.IMPRISON)).toBeDefined(); + party.forEach(p => { + expect(p.getTag(BattlerTagType.IMPRISON)).toBeDefined(); + }); + }); +}); diff --git a/src/test/abilities/aura_break.test.ts b/src/test/abilities/aura_break.test.ts index 422ac5178c1..137688d1f22 100644 --- a/src/test/abilities/aura_break.test.ts +++ b/src/test/abilities/aura_break.test.ts @@ -25,7 +25,7 @@ describe("Abilities - Aura Break", () => { beforeEach(() => { game = new GameManager(phaserGame); game.override.battleType("single"); - game.override.moveset([Moves.MOONBLAST, Moves.DARK_PULSE, Moves.MOONBLAST, Moves.DARK_PULSE]); + game.override.moveset([ Moves.MOONBLAST, Moves.DARK_PULSE, Moves.MOONBLAST, Moves.DARK_PULSE ]); game.override.enemyMoveset(Moves.SPLASH); game.override.enemyAbility(Abilities.AURA_BREAK); game.override.enemySpecies(Species.SHUCKLE); @@ -38,7 +38,7 @@ describe("Abilities - Aura Break", () => { game.override.ability(Abilities.FAIRY_AURA); vi.spyOn(moveToCheck, "calculateBattlePower"); - await game.classicMode.startBattle([Species.PIKACHU]); + await game.classicMode.startBattle([ Species.PIKACHU ]); game.move.select(Moves.MOONBLAST); await game.phaseInterceptor.to("MoveEffectPhase"); @@ -52,7 +52,7 @@ describe("Abilities - Aura Break", () => { game.override.ability(Abilities.DARK_AURA); vi.spyOn(moveToCheck, "calculateBattlePower"); - await game.classicMode.startBattle([Species.PIKACHU]); + await game.classicMode.startBattle([ Species.PIKACHU ]); game.move.select(Moves.DARK_PULSE); await game.phaseInterceptor.to("MoveEffectPhase"); @@ -66,7 +66,7 @@ describe("Abilities - Aura Break", () => { game.override.ability(Abilities.BALL_FETCH); vi.spyOn(moveToCheck, "calculateBattlePower"); - await game.classicMode.startBattle([Species.PIKACHU]); + await game.classicMode.startBattle([ Species.PIKACHU ]); game.move.select(Moves.MOONBLAST); await game.phaseInterceptor.to("MoveEffectPhase"); diff --git a/src/test/abilities/battery.test.ts b/src/test/abilities/battery.test.ts index cd02ed0c4eb..8abeca287f7 100644 --- a/src/test/abilities/battery.test.ts +++ b/src/test/abilities/battery.test.ts @@ -29,7 +29,7 @@ describe("Abilities - Battery", () => { game.override.battleType("double"); game.override.enemySpecies(Species.SHUCKLE); game.override.enemyAbility(Abilities.BALL_FETCH); - game.override.moveset([Moves.TACKLE, Moves.BREAKING_SWIPE, Moves.SPLASH, Moves.DAZZLING_GLEAM]); + game.override.moveset([ Moves.TACKLE, Moves.BREAKING_SWIPE, Moves.SPLASH, Moves.DAZZLING_GLEAM ]); game.override.enemyMoveset(Moves.SPLASH); }); @@ -39,7 +39,7 @@ describe("Abilities - Battery", () => { vi.spyOn(moveToCheck, "calculateBattlePower"); - await game.startBattle([Species.PIKACHU, Species.CHARJABUG]); + await game.startBattle([ Species.PIKACHU, Species.CHARJABUG ]); game.move.select(Moves.DAZZLING_GLEAM); game.move.select(Moves.SPLASH, 1); @@ -54,7 +54,7 @@ describe("Abilities - Battery", () => { vi.spyOn(moveToCheck, "calculateBattlePower"); - await game.startBattle([Species.PIKACHU, Species.CHARJABUG]); + await game.startBattle([ Species.PIKACHU, Species.CHARJABUG ]); game.move.select(Moves.BREAKING_SWIPE); game.move.select(Moves.SPLASH, 1); @@ -69,7 +69,7 @@ describe("Abilities - Battery", () => { vi.spyOn(moveToCheck, "calculateBattlePower"); - await game.startBattle([Species.CHARJABUG, Species.PIKACHU]); + await game.startBattle([ Species.CHARJABUG, Species.PIKACHU ]); game.move.select(Moves.DAZZLING_GLEAM); game.move.select(Moves.SPLASH, 1); diff --git a/src/test/abilities/battle_bond.test.ts b/src/test/abilities/battle_bond.test.ts index 71e9438db8f..db7ed01e7d9 100644 --- a/src/test/abilities/battle_bond.test.ts +++ b/src/test/abilities/battle_bond.test.ts @@ -1,18 +1,20 @@ -import { Status, StatusEffect } from "#app/data/status-effect"; -import { QuietFormChangePhase } from "#app/phases/quiet-form-change-phase"; -import { TurnEndPhase } from "#app/phases/turn-end-phase"; +import { allMoves, MultiHitAttr, MultiHitType } from "#app/data/move"; +import { Status } from "#app/data/status-effect"; import { Abilities } from "#enums/abilities"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; +import { StatusEffect } from "#enums/status-effect"; import GameManager from "#test/utils/gameManager"; -import { afterEach, beforeAll, beforeEach, describe, expect, test } from "vitest"; +import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Abilities - BATTLE BOND", () => { let phaserGame: Phaser.Game; let game: GameManager; + const baseForm = 1; + const ashForm = 2; + beforeAll(() => { phaserGame = new Phaser.Game({ type: Phaser.HEADLESS, @@ -25,41 +27,68 @@ describe("Abilities - BATTLE BOND", () => { beforeEach(() => { game = new GameManager(phaserGame); - const moveToUse = Moves.SPLASH; - game.override.battleType("single"); - game.override.ability(Abilities.BATTLE_BOND); - game.override.moveset([moveToUse]); - game.override.enemyMoveset([Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE]); + game.override.battleType("single") + .startingWave(4) // Leads to arena reset on Wave 5 trainer battle + .ability(Abilities.BATTLE_BOND) + .starterForms({ [Species.GRENINJA]: ashForm, }) + .moveset([ Moves.SPLASH, Moves.WATER_SHURIKEN ]) + .enemySpecies(Species.BULBASAUR) + .enemyMoveset(Moves.SPLASH) + .startingLevel(100) // Avoid levelling up + .enemyLevel(1000); // Avoid opponent dying before `doKillOpponents()` }); - test( - "check if fainted pokemon switches to base form on arena reset", - async () => { - const baseForm = 1; - const ashForm = 2; - game.override.startingWave(4); - game.override.starterForms({ - [Species.GRENINJA]: ashForm, - }); + it("check if fainted pokemon switches to base form on arena reset", async () => { + await game.classicMode.startBattle([ Species.MAGIKARP, Species.GRENINJA ]); - await game.startBattle([Species.MAGIKARP, Species.GRENINJA]); + const greninja = game.scene.getPlayerParty()[1]; + expect(greninja.formIndex).toBe(ashForm); - const greninja = game.scene.getParty().find((p) => p.species.speciesId === Species.GRENINJA); - expect(greninja).toBeDefined(); - expect(greninja!.formIndex).toBe(ashForm); + greninja.hp = 0; + greninja.status = new Status(StatusEffect.FAINT); + expect(greninja.isFainted()).toBe(true); - greninja!.hp = 0; - greninja!.status = new Status(StatusEffect.FAINT); - expect(greninja!.isFainted()).toBe(true); + game.move.select(Moves.SPLASH); + await game.doKillOpponents(); + await game.phaseInterceptor.to("TurnEndPhase"); + game.doSelectModifier(); + await game.phaseInterceptor.to("QuietFormChangePhase"); - game.move.select(Moves.SPLASH); - await game.doKillOpponents(); - await game.phaseInterceptor.to(TurnEndPhase); - game.doSelectModifier(); - await game.phaseInterceptor.to(QuietFormChangePhase); + expect(greninja.formIndex).toBe(baseForm); + }); - expect(greninja!.formIndex).toBe(baseForm); - }, - TIMEOUT - ); + it("should not keep buffing Water Shuriken after Greninja switches to base form", async () => { + await game.classicMode.startBattle([ Species.GRENINJA ]); + + const waterShuriken = allMoves[Moves.WATER_SHURIKEN]; + vi.spyOn(waterShuriken, "calculateBattlePower"); + + let actualMultiHitType: MultiHitType | null = null; + const multiHitAttr = waterShuriken.getAttrs(MultiHitAttr)[0]; + vi.spyOn(multiHitAttr, "getHitCount").mockImplementation(() => { + actualMultiHitType = multiHitAttr.getMultiHitType(); + return 3; + }); + + // Wave 4: Use Water Shuriken in Ash form + let expectedBattlePower = 20; + let expectedMultiHitType = MultiHitType._3; + + game.move.select(Moves.WATER_SHURIKEN); + await game.phaseInterceptor.to("BerryPhase", false); + expect(waterShuriken.calculateBattlePower).toHaveLastReturnedWith(expectedBattlePower); + expect(actualMultiHitType).toBe(expectedMultiHitType); + + await game.doKillOpponents(); + await game.toNextWave(); + + // Wave 5: Use Water Shuriken in base form + expectedBattlePower = 15; + expectedMultiHitType = MultiHitType._2_TO_5; + + game.move.select(Moves.WATER_SHURIKEN); + await game.phaseInterceptor.to("BerryPhase", false); + expect(waterShuriken.calculateBattlePower).toHaveLastReturnedWith(expectedBattlePower); + expect(actualMultiHitType).toBe(expectedMultiHitType); + }); }); diff --git a/src/test/abilities/beast_boost.test.ts b/src/test/abilities/beast_boost.test.ts index 26bae7b8838..de31b979e32 100644 --- a/src/test/abilities/beast_boost.test.ts +++ b/src/test/abilities/beast_boost.test.ts @@ -34,7 +34,7 @@ describe("Abilities - Beast Boost", () => { }); it("should prefer highest stat to boost its corresponding stat stage by 1 when winning a battle", async() => { - await game.classicMode.startBattle([Species.SLOWBRO]); + await game.classicMode.startBattle([ Species.SLOWBRO ]); const playerPokemon = game.scene.getPlayerPokemon()!; // Set the pokemon's highest stat to DEF, so it should be picked by Beast Boost @@ -50,9 +50,9 @@ describe("Abilities - Beast Boost", () => { }, 20000); it("should use in-battle overriden stats when determining the stat stage to raise by 1", async() => { - game.override.enemyMoveset([Moves.GUARD_SPLIT]); + game.override.enemyMoveset([ Moves.GUARD_SPLIT ]); - await game.classicMode.startBattle([Species.SLOWBRO]); + await game.classicMode.startBattle([ Species.SLOWBRO ]); const playerPokemon = game.scene.getPlayerPokemon()!; // If the opponent uses Guard Split, the pokemon's second highest stat (SPATK) should be chosen @@ -70,7 +70,7 @@ describe("Abilities - Beast Boost", () => { it("should have order preference in case of stat ties", async() => { // Order preference follows the order of EFFECTIVE_STAT - await game.classicMode.startBattle([Species.SLOWBRO]); + await game.classicMode.startBattle([ Species.SLOWBRO ]); const playerPokemon = game.scene.getPlayerPokemon()!; diff --git a/src/test/abilities/commander.test.ts b/src/test/abilities/commander.test.ts new file mode 100644 index 00000000000..99b3d50797c --- /dev/null +++ b/src/test/abilities/commander.test.ts @@ -0,0 +1,224 @@ +import { BattlerIndex } from "#app/battle"; +import { BattlerTagType } from "#enums/battler-tag-type"; +import { PokemonAnimType } from "#enums/pokemon-anim-type"; +import { EffectiveStat, Stat } from "#enums/stat"; +import { StatusEffect } from "#enums/status-effect"; +import { WeatherType } from "#enums/weather-type"; +import { MoveResult } from "#app/field/pokemon"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; + +describe("Abilities - Commander", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .startingLevel(100) + .enemyLevel(100) + .moveset([ Moves.LIQUIDATION, Moves.MEMENTO, Moves.SPLASH, Moves.FLIP_TURN ]) + .ability(Abilities.COMMANDER) + .battleType("double") + .disableCrits() + .enemySpecies(Species.SNORLAX) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.TACKLE); + + vi.spyOn(game.scene, "triggerPokemonBattleAnim").mockReturnValue(true); + }); + + it("causes the source to jump into Dondozo's mouth, granting a stat boost and hiding the source", async () => { + await game.classicMode.startBattle([ Species.TATSUGIRI, Species.DONDOZO ]); + + const [ tatsugiri, dondozo ] = game.scene.getPlayerField(); + + const affectedStats: EffectiveStat[] = [ Stat.ATK, Stat.DEF, Stat.SPATK, Stat.SPDEF, Stat.SPD ]; + + expect(game.scene.triggerPokemonBattleAnim).toHaveBeenLastCalledWith(tatsugiri, PokemonAnimType.COMMANDER_APPLY); + expect(dondozo.getTag(BattlerTagType.COMMANDED)).toBeDefined(); + affectedStats.forEach((stat) => expect(dondozo.getStatStage(stat)).toBe(2)); + + game.move.select(Moves.SPLASH, 1); + + expect(game.scene.currentBattle.turnCommands[0]?.skip).toBeTruthy(); + + // Force both enemies to target the Tatsugiri + await game.forceEnemyMove(Moves.TACKLE, BattlerIndex.PLAYER); + await game.forceEnemyMove(Moves.TACKLE, BattlerIndex.PLAYER); + + await game.phaseInterceptor.to("BerryPhase", false); + game.scene.getEnemyField().forEach(enemy => expect(enemy.getLastXMoves(1)[0].result).toBe(MoveResult.MISS)); + expect(tatsugiri.isFullHp()).toBeTruthy(); + }); + + it("should activate when a Dondozo switches in and cancel the source's move", async () => { + game.override.enemyMoveset(Moves.SPLASH); + + await game.classicMode.startBattle([ Species.TATSUGIRI, Species.MAGIKARP, Species.DONDOZO ]); + + const tatsugiri = game.scene.getPlayerField()[0]; + + game.move.select(Moves.LIQUIDATION, 0, BattlerIndex.ENEMY); + game.doSwitchPokemon(2); + + await game.phaseInterceptor.to("MovePhase", false); + expect(game.scene.triggerPokemonBattleAnim).toHaveBeenCalledWith(tatsugiri, PokemonAnimType.COMMANDER_APPLY); + + const dondozo = game.scene.getPlayerField()[1]; + expect(dondozo.getTag(BattlerTagType.COMMANDED)).toBeDefined(); + + await game.phaseInterceptor.to("BerryPhase", false); + expect(tatsugiri.getMoveHistory()).toHaveLength(0); + expect(game.scene.getEnemyField()[0].isFullHp()).toBeTruthy(); + }); + + it("source should reenter the field when Dondozo faints", async () => { + await game.classicMode.startBattle([ Species.TATSUGIRI, Species.DONDOZO ]); + + const [ tatsugiri, dondozo ] = game.scene.getPlayerField(); + + expect(game.scene.triggerPokemonBattleAnim).toHaveBeenLastCalledWith(tatsugiri, PokemonAnimType.COMMANDER_APPLY); + expect(dondozo.getTag(BattlerTagType.COMMANDED)).toBeDefined(); + + game.move.select(Moves.MEMENTO, 1, BattlerIndex.ENEMY); + + expect(game.scene.currentBattle.turnCommands[0]?.skip).toBeTruthy(); + + await game.forceEnemyMove(Moves.TACKLE, BattlerIndex.PLAYER); + await game.forceEnemyMove(Moves.TACKLE, BattlerIndex.PLAYER); + + await game.setTurnOrder([ BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2, BattlerIndex.PLAYER ]); + + await game.phaseInterceptor.to("FaintPhase", false); + expect(dondozo.getTag(BattlerTagType.COMMANDED)).toBeUndefined(); + expect(game.scene.triggerPokemonBattleAnim).toHaveBeenLastCalledWith(dondozo, PokemonAnimType.COMMANDER_REMOVE); + + await game.phaseInterceptor.to("BerryPhase", false); + expect(tatsugiri.isFullHp()).toBeFalsy(); + }); + + it("source should still take damage from Poison while hidden", async () => { + game.override + .statusEffect(StatusEffect.POISON) + .enemyMoveset(Moves.SPLASH); + + await game.classicMode.startBattle([ Species.TATSUGIRI, Species.DONDOZO ]); + + const [ tatsugiri, dondozo ] = game.scene.getPlayerField(); + + expect(game.scene.triggerPokemonBattleAnim).toHaveBeenLastCalledWith(tatsugiri, PokemonAnimType.COMMANDER_APPLY); + expect(dondozo.getTag(BattlerTagType.COMMANDED)).toBeDefined(); + + game.move.select(Moves.SPLASH, 1); + + expect(game.scene.currentBattle.turnCommands[0]?.skip).toBeTruthy(); + + await game.phaseInterceptor.to("TurnEndPhase"); + expect(tatsugiri.isFullHp()).toBeFalsy(); + }); + + it("source should still take damage from Salt Cure while hidden", async () => { + game.override.enemyMoveset(Moves.SPLASH); + + await game.classicMode.startBattle([ Species.TATSUGIRI, Species.DONDOZO ]); + + const [ tatsugiri, dondozo ] = game.scene.getPlayerField(); + + expect(game.scene.triggerPokemonBattleAnim).toHaveBeenLastCalledWith(tatsugiri, PokemonAnimType.COMMANDER_APPLY); + expect(dondozo.getTag(BattlerTagType.COMMANDED)).toBeDefined(); + + tatsugiri.addTag(BattlerTagType.SALT_CURED, 0, Moves.NONE, game.scene.getField()[BattlerIndex.ENEMY].id); + + game.move.select(Moves.SPLASH, 1); + + expect(game.scene.currentBattle.turnCommands[0]?.skip).toBeTruthy(); + + await game.phaseInterceptor.to("TurnEndPhase"); + expect(tatsugiri.isFullHp()).toBeFalsy(); + }); + + it("source should still take damage from Sandstorm while hidden", async () => { + game.override + .weather(WeatherType.SANDSTORM) + .enemyMoveset(Moves.SPLASH); + + await game.classicMode.startBattle([ Species.TATSUGIRI, Species.DONDOZO ]); + + const [ tatsugiri, dondozo ] = game.scene.getPlayerField(); + + expect(game.scene.triggerPokemonBattleAnim).toHaveBeenLastCalledWith(tatsugiri, PokemonAnimType.COMMANDER_APPLY); + expect(dondozo.getTag(BattlerTagType.COMMANDED)).toBeDefined(); + + game.move.select(Moves.SPLASH, 1); + + expect(game.scene.currentBattle.turnCommands[0]?.skip).toBeTruthy(); + + await game.phaseInterceptor.to("TurnEndPhase"); + expect(tatsugiri.isFullHp()).toBeFalsy(); + }); + + it("should make Dondozo immune to being forced out", async () => { + game.override.enemyMoveset([ Moves.SPLASH, Moves.WHIRLWIND ]); + + await game.classicMode.startBattle([ Species.TATSUGIRI, Species.DONDOZO ]); + + const [ tatsugiri, dondozo ] = game.scene.getPlayerField(); + + expect(game.scene.triggerPokemonBattleAnim).toHaveBeenLastCalledWith(tatsugiri, PokemonAnimType.COMMANDER_APPLY); + expect(dondozo.getTag(BattlerTagType.COMMANDED)).toBeDefined(); + + game.move.select(Moves.SPLASH, 1); + + expect(game.scene.currentBattle.turnCommands[0]?.skip).toBeTruthy(); + + await game.forceEnemyMove(Moves.WHIRLWIND, BattlerIndex.PLAYER_2); + await game.forceEnemyMove(Moves.SPLASH); + + // Test may time out here if Whirlwind forced out a Pokemon + await game.phaseInterceptor.to("TurnEndPhase"); + expect(dondozo.isActive(true)).toBeTruthy(); + }); + + it("should interrupt the source's semi-invulnerability", async () => { + game.override + .moveset([ Moves.SPLASH, Moves.DIVE ]) + .enemyMoveset(Moves.SPLASH); + + await game.classicMode.startBattle([ Species.TATSUGIRI, Species.MAGIKARP, Species.DONDOZO ]); + + const tatsugiri = game.scene.getPlayerField()[0]; + + game.move.select(Moves.DIVE, 0, BattlerIndex.ENEMY); + game.move.select(Moves.SPLASH, 1); + + await game.phaseInterceptor.to("CommandPhase"); + await game.toNextTurn(); + + expect(tatsugiri.getTag(BattlerTagType.UNDERWATER)).toBeDefined(); + game.doSwitchPokemon(2); + + await game.phaseInterceptor.to("MovePhase", false); + const dondozo = game.scene.getPlayerField()[1]; + expect(tatsugiri.getTag(BattlerTagType.UNDERWATER)).toBeUndefined(); + expect(dondozo.getTag(BattlerTagType.COMMANDED)).toBeDefined(); + + await game.toNextTurn(); + const enemy = game.scene.getEnemyField()[0]; + expect(enemy.isFullHp()).toBeTruthy(); + }); +}); diff --git a/src/test/abilities/competitive.test.ts b/src/test/abilities/competitive.test.ts new file mode 100644 index 00000000000..ecb276a1b8d --- /dev/null +++ b/src/test/abilities/competitive.test.ts @@ -0,0 +1,72 @@ +import { Stat } from "#enums/stat"; +import { TurnInitPhase } from "#app/phases/turn-init-phase"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; + +describe("Abilities - Competitive", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + + game.override.battleType("single") + .enemySpecies(Species.BEEDRILL) + .enemyMoveset(Moves.TICKLE) + .startingLevel(1) + .moveset([ Moves.SPLASH, Moves.CLOSE_COMBAT ]) + .ability(Abilities.COMPETITIVE); + }); + + it("lower atk and def by 1 via tickle, then increase spatk by 4 via competitive", async () => { + await game.classicMode.startBattle([ Species.FLYGON ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + game.move.select(Moves.SPLASH); + await game.phaseInterceptor.to(TurnInitPhase); + + expect(playerPokemon.getStatStage(Stat.ATK)).toBe(-1); + expect(playerPokemon.getStatStage(Stat.DEF)).toBe(-1); + expect(playerPokemon.getStatStage(Stat.SPATK)).toBe(4); + }); + + it("lowering your own stats should not trigger competitive", async () => { + game.override.enemyMoveset(Moves.SPLASH); + await game.classicMode.startBattle([ Species.FLYGON ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + game.move.select(Moves.CLOSE_COMBAT); + await game.phaseInterceptor.to(TurnInitPhase); + + expect(playerPokemon.getStatStage(Stat.SPDEF)).toBe(-1); + expect(playerPokemon.getStatStage(Stat.DEF)).toBe(-1); + expect(playerPokemon.getStatStage(Stat.SPATK)).toBe(0); + }); + + it("white herb should remove only the negative effects", async () => { + game.override.startingHeldItems([{ name: "WHITE_HERB" }]); + await game.classicMode.startBattle([ Species.FLYGON ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + game.move.select(Moves.SPLASH); + await game.phaseInterceptor.to(TurnInitPhase); + + expect(playerPokemon.getStatStage(Stat.ATK)).toBe(0); + expect(playerPokemon.getStatStage(Stat.DEF)).toBe(0); + expect(playerPokemon.getStatStage(Stat.SPATK)).toBe(4); + }); +}); diff --git a/src/test/abilities/contrary.test.ts b/src/test/abilities/contrary.test.ts index 5221e821e70..c838a5a098e 100644 --- a/src/test/abilities/contrary.test.ts +++ b/src/test/abilities/contrary.test.ts @@ -44,8 +44,8 @@ describe("Abilities - Contrary", () => { it("should apply positive effects", async () => { game.override .enemyPassiveAbility(Abilities.CLEAR_BODY) - .moveset([Moves.TAIL_WHIP]); - await game.classicMode.startBattle([Species.SLOWBRO]); + .moveset([ Moves.TAIL_WHIP ]); + await game.classicMode.startBattle([ Species.SLOWBRO ]); const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -60,9 +60,9 @@ describe("Abilities - Contrary", () => { it("should block negative effects", async () => { game.override .enemyPassiveAbility(Abilities.CLEAR_BODY) - .enemyMoveset([Moves.HOWL, Moves.HOWL, Moves.HOWL, Moves.HOWL]) - .moveset([Moves.SPLASH]); - await game.classicMode.startBattle([Species.SLOWBRO]); + .enemyMoveset([ Moves.HOWL, Moves.HOWL, Moves.HOWL, Moves.HOWL ]) + .moveset([ Moves.SPLASH ]); + await game.classicMode.startBattle([ Species.SLOWBRO ]); const enemyPokemon = game.scene.getEnemyPokemon()!; diff --git a/src/test/abilities/corrosion.test.ts b/src/test/abilities/corrosion.test.ts new file mode 100644 index 00000000000..e607e85defb --- /dev/null +++ b/src/test/abilities/corrosion.test.ts @@ -0,0 +1,46 @@ +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; + +describe("Abilities - Corrosion", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.SPLASH ]) + .battleType("single") + .disableCrits() + .enemySpecies(Species.GRIMER) + .enemyAbility(Abilities.CORROSION) + .enemyMoveset(Moves.TOXIC); + }); + + it("If a Poison- or Steel-type Pokémon with this Ability poisons a target with Synchronize, Synchronize does not gain the ability to poison Poison- or Steel-type Pokémon.", async () => { + game.override.ability(Abilities.SYNCHRONIZE); + await game.classicMode.startBattle([ Species.FEEBAS ]); + + const playerPokemon = game.scene.getPlayerPokemon(); + const enemyPokemon = game.scene.getEnemyPokemon(); + expect(playerPokemon!.status).toBeUndefined(); + + game.move.select(Moves.SPLASH); + await game.phaseInterceptor.to("BerryPhase"); + expect(playerPokemon!.status).toBeDefined(); + expect(enemyPokemon!.status).toBeUndefined(); + }); +}); diff --git a/src/test/abilities/costar.test.ts b/src/test/abilities/costar.test.ts index 794bed0d3cf..3be29ea2dcf 100644 --- a/src/test/abilities/costar.test.ts +++ b/src/test/abilities/costar.test.ts @@ -8,7 +8,6 @@ import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, test } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Abilities - COSTAR", () => { let phaserGame: Phaser.Game; @@ -28,7 +27,7 @@ describe("Abilities - COSTAR", () => { game = new GameManager(phaserGame); game.override.battleType("double"); game.override.ability(Abilities.COSTAR); - game.override.moveset([Moves.SPLASH, Moves.NASTY_PLOT]); + game.override.moveset([ Moves.SPLASH, Moves.NASTY_PLOT ]); game.override.enemyMoveset(Moves.SPLASH); }); @@ -38,9 +37,9 @@ describe("Abilities - COSTAR", () => { async () => { game.override.enemyAbility(Abilities.BALL_FETCH); - await game.startBattle([Species.MAGIKARP, Species.MAGIKARP, Species.FLAMIGO]); + await game.startBattle([ Species.MAGIKARP, Species.MAGIKARP, Species.FLAMIGO ]); - let [leftPokemon, rightPokemon] = game.scene.getPlayerField(); + let [ leftPokemon, rightPokemon ] = game.scene.getPlayerField(); game.move.select(Moves.NASTY_PLOT); await game.phaseInterceptor.to(CommandPhase); @@ -55,11 +54,10 @@ describe("Abilities - COSTAR", () => { game.doSwitchPokemon(2); await game.phaseInterceptor.to(MessagePhase); - [leftPokemon, rightPokemon] = game.scene.getPlayerField(); + [ leftPokemon, rightPokemon ] = game.scene.getPlayerField(); expect(leftPokemon.getStatStage(Stat.SPATK)).toBe(2); expect(rightPokemon.getStatStage(Stat.SPATK)).toBe(2); }, - TIMEOUT, ); test( @@ -67,9 +65,9 @@ describe("Abilities - COSTAR", () => { async () => { game.override.enemyAbility(Abilities.INTIMIDATE); - await game.startBattle([Species.MAGIKARP, Species.MAGIKARP, Species.FLAMIGO]); + await game.startBattle([ Species.MAGIKARP, Species.MAGIKARP, Species.FLAMIGO ]); - let [leftPokemon, rightPokemon] = game.scene.getPlayerField(); + let [ leftPokemon, rightPokemon ] = game.scene.getPlayerField(); expect(leftPokemon.getStatStage(Stat.ATK)).toBe(-2); expect(leftPokemon.getStatStage(Stat.ATK)).toBe(-2); @@ -79,10 +77,9 @@ describe("Abilities - COSTAR", () => { game.doSwitchPokemon(2); await game.phaseInterceptor.to(MessagePhase); - [leftPokemon, rightPokemon] = game.scene.getPlayerField(); + [ leftPokemon, rightPokemon ] = game.scene.getPlayerField(); expect(leftPokemon.getStatStage(Stat.ATK)).toBe(-2); expect(rightPokemon.getStatStage(Stat.ATK)).toBe(-2); }, - TIMEOUT, ); }); diff --git a/src/test/abilities/dancer.test.ts b/src/test/abilities/dancer.test.ts index ec5ce53f4c3..8fa3d444f37 100644 --- a/src/test/abilities/dancer.test.ts +++ b/src/test/abilities/dancer.test.ts @@ -7,7 +7,6 @@ import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Abilities - Dancer", () => { let phaserGame: Phaser.Game; @@ -27,22 +26,22 @@ describe("Abilities - Dancer", () => { game = new GameManager(phaserGame); game.override .battleType("double") - .moveset([Moves.SWORDS_DANCE, Moves.SPLASH]) + .moveset([ Moves.SWORDS_DANCE, Moves.SPLASH ]) .enemySpecies(Species.MAGIKARP) .enemyAbility(Abilities.DANCER) - .enemyMoveset([Moves.VICTORY_DANCE]); + .enemyMoveset([ Moves.VICTORY_DANCE ]); }); // Reference Link: https://bulbapedia.bulbagarden.net/wiki/Dancer_(Ability) it("triggers when dance moves are used, doesn't consume extra PP", async () => { - await game.classicMode.startBattle([Species.ORICORIO, Species.FEEBAS]); + await game.classicMode.startBattle([ Species.ORICORIO, Species.FEEBAS ]); - const [oricorio] = game.scene.getPlayerField(); + const [ oricorio ] = game.scene.getPlayerField(); game.move.select(Moves.SPLASH); game.move.select(Moves.SWORDS_DANCE, 1); - await game.setTurnOrder([BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.PLAYER, BattlerIndex.ENEMY_2]); + await game.setTurnOrder([ BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.PLAYER, BattlerIndex.ENEMY_2 ]); await game.phaseInterceptor.to("MovePhase"); // immediately copies ally move await game.phaseInterceptor.to("MovePhase", false); @@ -60,5 +59,5 @@ describe("Abilities - Dancer", () => { // doesn't use PP if copied move is also in moveset expect(oricorio.moveset[0]?.ppUsed).toBe(0); - }, TIMEOUT); + }); }); diff --git a/src/test/abilities/defiant.test.ts b/src/test/abilities/defiant.test.ts new file mode 100644 index 00000000000..aa8d250dad7 --- /dev/null +++ b/src/test/abilities/defiant.test.ts @@ -0,0 +1,70 @@ +import { Stat } from "#enums/stat"; +import { TurnInitPhase } from "#app/phases/turn-init-phase"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; + +describe("Abilities - Defiant", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + + game.override.battleType("single") + .enemySpecies(Species.BEEDRILL) + .enemyMoveset(Moves.TICKLE) + .startingLevel(1) + .moveset([ Moves.SPLASH, Moves.CLOSE_COMBAT ]) + .ability(Abilities.DEFIANT); + }); + + it("lower atk and def by 1 via tickle, then increase atk by 4 via defiant", async () => { + await game.classicMode.startBattle([ Species.FLYGON ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + game.move.select(Moves.SPLASH); + await game.phaseInterceptor.to(TurnInitPhase); + + expect(playerPokemon.getStatStage(Stat.ATK)).toBe(3); + expect(playerPokemon.getStatStage(Stat.DEF)).toBe(-1); + }); + + it("lowering your own stats should not trigger defiant", async () => { + game.override.enemyMoveset(Moves.SPLASH); + await game.classicMode.startBattle([ Species.FLYGON ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + game.move.select(Moves.CLOSE_COMBAT); + await game.phaseInterceptor.to(TurnInitPhase); + + expect(playerPokemon.getStatStage(Stat.SPDEF)).toBe(-1); + expect(playerPokemon.getStatStage(Stat.DEF)).toBe(-1); + expect(playerPokemon.getStatStage(Stat.ATK)).toBe(0); + }); + + it("white herb should remove only the negative effects", async () => { + game.override.startingHeldItems([{ name: "WHITE_HERB" }]); + await game.classicMode.startBattle([ Species.FLYGON ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + game.move.select(Moves.SPLASH); + await game.phaseInterceptor.to(TurnInitPhase); + + expect(playerPokemon.getStatStage(Stat.DEF)).toBe(0); + expect(playerPokemon.getStatStage(Stat.ATK)).toBe(3); + }); +}); diff --git a/src/test/abilities/disguise.test.ts b/src/test/abilities/disguise.test.ts index fa7f26d2716..07a84bd7a5a 100644 --- a/src/test/abilities/disguise.test.ts +++ b/src/test/abilities/disguise.test.ts @@ -1,13 +1,13 @@ +import { BattlerIndex } from "#app/battle"; import { toDmgValue } from "#app/utils"; import { Abilities } from "#enums/abilities"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; -import { StatusEffect } from "#app/data/status-effect"; import { Stat } from "#enums/stat"; +import { StatusEffect } from "#enums/status-effect"; import GameManager from "#test/utils/gameManager"; import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Abilities - Disguise", () => { let phaserGame: Phaser.Game; @@ -32,8 +32,8 @@ describe("Abilities - Disguise", () => { .enemySpecies(Species.MIMIKYU) .enemyMoveset(Moves.SPLASH) .starterSpecies(Species.REGIELEKI) - .moveset([Moves.SHADOW_SNEAK, Moves.VACUUM_WAVE, Moves.TOXIC_THREAD, Moves.SPLASH]); - }, TIMEOUT); + .moveset([ Moves.SHADOW_SNEAK, Moves.VACUUM_WAVE, Moves.TOXIC_THREAD, Moves.SPLASH ]); + }); it("takes no damage from attacking move and transforms to Busted form, takes 1/8 max HP damage from the disguise breaking", async () => { await game.classicMode.startBattle(); @@ -50,7 +50,7 @@ describe("Abilities - Disguise", () => { expect(mimikyu.hp).equals(maxHp - disguiseDamage); expect(mimikyu.formIndex).toBe(bustedForm); - }, TIMEOUT); + }); it("doesn't break disguise when attacked with ineffective move", async () => { await game.classicMode.startBattle(); @@ -64,7 +64,7 @@ describe("Abilities - Disguise", () => { await game.phaseInterceptor.to("MoveEndPhase"); expect(mimikyu.formIndex).toBe(disguisedForm); - }, TIMEOUT); + }); it("takes no damage from the first hit of a multihit move and transforms to Busted form, then takes damage from the second hit", async () => { game.override.moveset([ Moves.SURGING_STRIKES ]); @@ -88,7 +88,7 @@ describe("Abilities - Disguise", () => { await game.phaseInterceptor.to("MoveEffectPhase"); expect(mimikyu.hp).lessThan(maxHp - disguiseDamage); expect(mimikyu.formIndex).toBe(bustedForm); - }, TIMEOUT); + }); it("takes effects from status moves and damage from status effects", async () => { await game.classicMode.startBattle(); @@ -104,10 +104,10 @@ describe("Abilities - Disguise", () => { expect(mimikyu.status?.effect).toBe(StatusEffect.POISON); expect(mimikyu.getStatStage(Stat.SPD)).toBe(-1); expect(mimikyu.hp).toBeLessThan(mimikyu.getMaxHp()); - }, TIMEOUT); + }); it("persists form change when switched out", async () => { - game.override.enemyMoveset([Moves.SHADOW_SNEAK]); + game.override.enemyMoveset([ Moves.SHADOW_SNEAK ]); game.override.starterSpecies(0); await game.classicMode.startBattle([ Species.MIMIKYU, Species.FURRET ]); @@ -129,7 +129,7 @@ describe("Abilities - Disguise", () => { await game.phaseInterceptor.to("TurnEndPhase"); expect(mimikyu.formIndex).toBe(bustedForm); - }, TIMEOUT); + }); it("persists form change when wave changes with no arena reset", async () => { game.override.starterSpecies(0); @@ -138,7 +138,7 @@ describe("Abilities - Disguise", () => { }); await game.classicMode.startBattle([ Species.FURRET, Species.MIMIKYU ]); - const mimikyu = game.scene.getParty()[1]!; + const mimikyu = game.scene.getPlayerParty()[1]!; expect(mimikyu.formIndex).toBe(bustedForm); game.move.select(Moves.SPLASH); @@ -146,7 +146,7 @@ describe("Abilities - Disguise", () => { await game.toNextWave(); expect(mimikyu.formIndex).toBe(bustedForm); - }, TIMEOUT); + }); it("reverts to Disguised form on arena reset", async () => { game.override.startingWave(4); @@ -166,7 +166,7 @@ describe("Abilities - Disguise", () => { await game.toNextWave(); expect(mimikyu.formIndex).toBe(disguisedForm); - }, TIMEOUT); + }); it("reverts to Disguised form on biome change when fainted", async () => { game.override.startingWave(10); @@ -190,10 +190,10 @@ describe("Abilities - Disguise", () => { await game.phaseInterceptor.to("PartyHealPhase"); expect(mimikyu1.formIndex).toBe(disguisedForm); - }, TIMEOUT); + }); it("doesn't faint twice when fainting due to Disguise break damage, nor prevent faint from Disguise break damage if using Endure", async () => { - game.override.enemyMoveset([Moves.ENDURE]); + game.override.enemyMoveset([ Moves.ENDURE ]); await game.classicMode.startBattle(); const mimikyu = game.scene.getEnemyPokemon()!; @@ -204,11 +204,11 @@ describe("Abilities - Disguise", () => { expect(game.scene.getCurrentPhase()?.constructor.name).toBe("CommandPhase"); expect(game.scene.currentBattle.waveIndex).toBe(2); - }, TIMEOUT); + }); it("activates when Aerilate circumvents immunity to the move's base type", async () => { game.override.ability(Abilities.AERILATE); - game.override.moveset([Moves.TACKLE]); + game.override.moveset([ Moves.TACKLE ]); await game.classicMode.startBattle(); @@ -222,5 +222,18 @@ describe("Abilities - Disguise", () => { expect(mimikyu.formIndex).toBe(bustedForm); expect(mimikyu.hp).toBe(maxHp - disguiseDamage); - }, TIMEOUT); + }); + + it("doesn't trigger if user is behind a substitute", async () => { + game.override + .enemyMoveset(Moves.SUBSTITUTE) + .moveset(Moves.POWER_TRIP); + await game.classicMode.startBattle(); + + game.move.select(Moves.POWER_TRIP); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); + await game.toNextTurn(); + + expect(game.scene.getEnemyPokemon()!.formIndex).toBe(disguisedForm); + }); }); diff --git a/src/test/abilities/dry_skin.test.ts b/src/test/abilities/dry_skin.test.ts index 1af8831f25b..314564df15c 100644 --- a/src/test/abilities/dry_skin.test.ts +++ b/src/test/abilities/dry_skin.test.ts @@ -28,7 +28,7 @@ describe("Abilities - Dry Skin", () => { .enemyMoveset(Moves.SPLASH) .enemySpecies(Species.CHARMANDER) .ability(Abilities.BALL_FETCH) - .moveset([Moves.SUNNY_DAY, Moves.RAIN_DANCE, Moves.SPLASH, Moves.WATER_GUN]) + .moveset([ Moves.SUNNY_DAY, Moves.RAIN_DANCE, Moves.SPLASH, Moves.WATER_GUN ]) .starterSpecies(Species.CHANDELURE); }); @@ -69,7 +69,7 @@ describe("Abilities - Dry Skin", () => { }); it("opposing fire attacks do 25% more damage", async () => { - game.override.moveset([Moves.FLAMETHROWER]); + game.override.moveset([ Moves.FLAMETHROWER ]); await game.classicMode.startBattle(); const enemy = game.scene.getEnemyPokemon()!; @@ -105,7 +105,7 @@ describe("Abilities - Dry Skin", () => { }); it("opposing water attacks do not heal if they were protected from", async () => { - game.override.enemyMoveset([Moves.PROTECT]); + game.override.enemyMoveset([ Moves.PROTECT ]); await game.classicMode.startBattle(); @@ -119,7 +119,7 @@ describe("Abilities - Dry Skin", () => { }); it("multi-strike water attacks only heal once", async () => { - game.override.moveset([Moves.WATER_GUN, Moves.WATER_SHURIKEN]); + game.override.moveset([ Moves.WATER_GUN, Moves.WATER_SHURIKEN ]); await game.classicMode.startBattle(); @@ -141,4 +141,18 @@ describe("Abilities - Dry Skin", () => { expect(healthGainedFromWaterShuriken).toBe(healthGainedFromWaterGun); }); + + it("opposing water moves still heal regardless of accuracy check", async () => { + await game.classicMode.startBattle(); + + const enemy = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.WATER_GUN); + enemy.hp = enemy.hp - 1; + await game.phaseInterceptor.to("MoveEffectPhase"); + + await game.move.forceMiss(); + await game.phaseInterceptor.to("BerryPhase", false); + expect(enemy.hp).toBe(enemy.getMaxHp()); + }); }); diff --git a/src/test/abilities/early_bird.test.ts b/src/test/abilities/early_bird.test.ts new file mode 100644 index 00000000000..a69290fa1e4 --- /dev/null +++ b/src/test/abilities/early_bird.test.ts @@ -0,0 +1,93 @@ +import { Status } from "#app/data/status-effect"; +import { MoveResult } from "#app/field/pokemon"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import { StatusEffect } from "#enums/status-effect"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; + +describe("Abilities - Early Bird", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.REST, Moves.BELLY_DRUM, Moves.SPLASH ]) + .ability(Abilities.EARLY_BIRD) + .battleType("single") + .disableCrits() + .enemySpecies(Species.MAGIKARP) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.SPLASH); + }); + + it("reduces Rest's sleep time to 1 turn", async () => { + await game.classicMode.startBattle([ Species.FEEBAS ]); + + const player = game.scene.getPlayerPokemon()!; + + game.move.select(Moves.BELLY_DRUM); + await game.toNextTurn(); + game.move.select(Moves.REST); + await game.toNextTurn(); + + expect(player.status?.effect).toBe(StatusEffect.SLEEP); + + game.move.select(Moves.SPLASH); + await game.toNextTurn(); + + expect(player.status?.effect).toBe(StatusEffect.SLEEP); + expect(player.getLastXMoves(1)[0].result).toBe(MoveResult.FAIL); + + game.move.select(Moves.SPLASH); + await game.toNextTurn(); + + expect(player.status?.effect).toBeUndefined(); + expect(player.getLastXMoves(1)[0].result).toBe(MoveResult.SUCCESS); + }); + + it("reduces 3-turn sleep to 1 turn", async () => { + await game.classicMode.startBattle([ Species.FEEBAS ]); + + const player = game.scene.getPlayerPokemon()!; + player.status = new Status(StatusEffect.SLEEP, 0, 4); + + game.move.select(Moves.SPLASH); + await game.toNextTurn(); + + expect(player.status?.effect).toBe(StatusEffect.SLEEP); + expect(player.getLastXMoves(1)[0].result).toBe(MoveResult.FAIL); + + game.move.select(Moves.SPLASH); + await game.toNextTurn(); + + expect(player.status?.effect).toBeUndefined(); + expect(player.getLastXMoves(1)[0].result).toBe(MoveResult.SUCCESS); + }); + + it("reduces 1-turn sleep to 0 turns", async () => { + await game.classicMode.startBattle([ Species.FEEBAS ]); + + const player = game.scene.getPlayerPokemon()!; + player.status = new Status(StatusEffect.SLEEP, 0, 2); + + game.move.select(Moves.SPLASH); + await game.toNextTurn(); + + expect(player.status?.effect).toBeUndefined(); + expect(player.getLastXMoves(1)[0].result).toBe(MoveResult.SUCCESS); + }); +}); diff --git a/src/test/abilities/flash_fire.test.ts b/src/test/abilities/flash_fire.test.ts index c3cf31496ea..0ca55227ea4 100644 --- a/src/test/abilities/flash_fire.test.ts +++ b/src/test/abilities/flash_fire.test.ts @@ -1,11 +1,11 @@ import { BattlerIndex } from "#app/battle"; -import { StatusEffect } from "#app/data/status-effect"; import { BattlerTagType } from "#app/enums/battler-tag-type"; import { Species } from "#app/enums/species"; import { MovePhase } from "#app/phases/move-phase"; import { TurnEndPhase } from "#app/phases/turn-end-phase"; import { Abilities } from "#enums/abilities"; import { Moves } from "#enums/moves"; +import { StatusEffect } from "#enums/status-effect"; import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; @@ -37,8 +37,8 @@ describe("Abilities - Flash Fire", () => { it("immune to Fire-type moves", async () => { - game.override.enemyMoveset([Moves.EMBER]).moveset(Moves.SPLASH); - await game.startBattle([Species.BLISSEY]); + game.override.enemyMoveset([ Moves.EMBER ]).moveset(Moves.SPLASH); + await game.classicMode.startBattle([ Species.BLISSEY ]); const blissey = game.scene.getPlayerPokemon()!; @@ -48,8 +48,8 @@ describe("Abilities - Flash Fire", () => { }, 20000); it("not activate if the Pokémon is protected from the Fire-type move", async () => { - game.override.enemyMoveset([Moves.EMBER]).moveset([Moves.PROTECT]); - await game.startBattle([Species.BLISSEY]); + game.override.enemyMoveset([ Moves.EMBER ]).moveset([ Moves.PROTECT ]); + await game.classicMode.startBattle([ Species.BLISSEY ]); const blissey = game.scene.getPlayerPokemon()!; @@ -59,8 +59,8 @@ describe("Abilities - Flash Fire", () => { }, 20000); it("activated by Will-O-Wisp", async () => { - game.override.enemyMoveset([Moves.WILL_O_WISP]).moveset(Moves.SPLASH); - await game.startBattle([Species.BLISSEY]); + game.override.enemyMoveset([ Moves.WILL_O_WISP ]).moveset(Moves.SPLASH); + await game.classicMode.startBattle([ Species.BLISSEY ]); const blissey = game.scene.getPlayerPokemon()!; @@ -74,9 +74,9 @@ describe("Abilities - Flash Fire", () => { }, 20000); it("activated after being frozen", async () => { - game.override.enemyMoveset([Moves.EMBER]).moveset(Moves.SPLASH); + game.override.enemyMoveset([ Moves.EMBER ]).moveset(Moves.SPLASH); game.override.statusEffect(StatusEffect.FREEZE); - await game.startBattle([Species.BLISSEY]); + await game.classicMode.startBattle([ Species.BLISSEY ]); const blissey = game.scene.getPlayerPokemon()!; @@ -87,12 +87,12 @@ describe("Abilities - Flash Fire", () => { }, 20000); it("not passing with baton pass", async () => { - game.override.enemyMoveset([Moves.EMBER]).moveset([Moves.BATON_PASS]); - await game.startBattle([Species.BLISSEY, Species.CHANSEY]); + game.override.enemyMoveset([ Moves.EMBER ]).moveset([ Moves.BATON_PASS ]); + await game.classicMode.startBattle([ Species.BLISSEY, Species.CHANSEY ]); // ensure use baton pass after enemy moved game.move.select(Moves.BATON_PASS); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); game.doSelectPartyPokemon(1); @@ -103,16 +103,16 @@ describe("Abilities - Flash Fire", () => { }, 20000); it("boosts Fire-type move when the ability is activated", async () => { - game.override.enemyMoveset([Moves.FIRE_PLEDGE]).moveset([Moves.EMBER, Moves.SPLASH]); + game.override.enemyMoveset([ Moves.FIRE_PLEDGE ]).moveset([ Moves.EMBER, Moves.SPLASH ]); game.override.enemyAbility(Abilities.FLASH_FIRE).ability(Abilities.NONE); - await game.startBattle([Species.BLISSEY]); + await game.classicMode.startBattle([ Species.BLISSEY ]); const blissey = game.scene.getPlayerPokemon()!; const initialHP = 1000; blissey.hp = initialHP; // first turn game.move.select(Moves.EMBER); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); await game.phaseInterceptor.to(TurnEndPhase); const originalDmg = initialHP - blissey.hp; @@ -126,4 +126,33 @@ describe("Abilities - Flash Fire", () => { expect(flashFireDmg).toBeGreaterThan(originalDmg); }, 20000); + + it("still activates regardless of accuracy check", async () => { + game.override.moveset(Moves.FIRE_PLEDGE).enemyMoveset(Moves.EMBER); + game.override.enemyAbility(Abilities.NONE).ability(Abilities.FLASH_FIRE); + game.override.enemySpecies(Species.BLISSEY); + await game.classicMode.startBattle([ Species.RATTATA ]); + + const blissey = game.scene.getEnemyPokemon()!; + const initialHP = 1000; + blissey.hp = initialHP; + + // first turn + game.move.select(Moves.FIRE_PLEDGE); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + await game.phaseInterceptor.to("MoveEffectPhase"); + await game.move.forceMiss(); + await game.phaseInterceptor.to(TurnEndPhase); + const originalDmg = initialHP - blissey.hp; + + expect(blissey.hp > 0); + blissey.hp = initialHP; + + // second turn + game.move.select(Moves.FIRE_PLEDGE); + await game.phaseInterceptor.to(TurnEndPhase); + const flashFireDmg = initialHP - blissey.hp; + + expect(flashFireDmg).toBeGreaterThan(originalDmg); + }, 20000); }); diff --git a/src/test/abilities/flower_gift.test.ts b/src/test/abilities/flower_gift.test.ts index 256b61c6fea..04ada598f22 100644 --- a/src/test/abilities/flower_gift.test.ts +++ b/src/test/abilities/flower_gift.test.ts @@ -21,7 +21,7 @@ describe("Abilities - Flower Gift", () => { */ const testRevertFormAgainstAbility = async (game: GameManager, ability: Abilities) => { game.override.starterForms({ [Species.CASTFORM]: SUNSHINE_FORM }).enemyAbility(ability); - await game.classicMode.startBattle([Species.CASTFORM]); + await game.classicMode.startBattle([ Species.CASTFORM ]); game.move.select(Moves.SPLASH); @@ -41,7 +41,7 @@ describe("Abilities - Flower Gift", () => { beforeEach(() => { game = new GameManager(phaserGame); game.override - .moveset([Moves.SPLASH, Moves.RAIN_DANCE, Moves.SUNNY_DAY, Moves.SKILL_SWAP]) + .moveset([ Moves.SPLASH, Moves.RAIN_DANCE, Moves.SUNNY_DAY, Moves.SKILL_SWAP ]) .enemySpecies(Species.MAGIKARP) .enemyMoveset(Moves.SPLASH) .enemyAbility(Abilities.BALL_FETCH); @@ -50,7 +50,7 @@ describe("Abilities - Flower Gift", () => { // TODO: Uncomment expect statements when the ability is implemented - currently does not increase stats of allies it("increases the ATK and SPDEF stat stages of the Pokémon with this Ability and its allies by 1.5× during Harsh Sunlight", async () => { game.override.battleType("double"); - await game.classicMode.startBattle([Species.CHERRIM, Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.CHERRIM, Species.MAGIKARP ]); const [ cherrim ] = game.scene.getPlayerField(); const cherrimAtkStat = cherrim.getEffectiveStat(Stat.ATK); @@ -62,7 +62,7 @@ describe("Abilities - Flower Gift", () => { game.move.select(Moves.SUNNY_DAY, 0); game.move.select(Moves.SPLASH, 1); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2 ]); await game.phaseInterceptor.to("TurnEndPhase"); expect(cherrim.formIndex).toBe(SUNSHINE_FORM); @@ -74,7 +74,7 @@ describe("Abilities - Flower Gift", () => { it("changes the Pokemon's form during Harsh Sunlight", async () => { game.override.weather(WeatherType.HARSH_SUN); - await game.classicMode.startBattle([Species.CHERRIM]); + await game.classicMode.startBattle([ Species.CHERRIM ]); const cherrim = game.scene.getPlayerPokemon()!; expect(cherrim.formIndex).toBe(SUNSHINE_FORM); @@ -91,9 +91,9 @@ describe("Abilities - Flower Gift", () => { }); it("reverts to Overcast Form when the Pokémon loses Flower Gift, changes form under Harsh Sunlight/Sunny when it regains it", async () => { - game.override.enemyMoveset([Moves.SKILL_SWAP]).weather(WeatherType.HARSH_SUN); + game.override.enemyMoveset([ Moves.SKILL_SWAP ]).weather(WeatherType.HARSH_SUN); - await game.classicMode.startBattle([Species.CHERRIM]); + await game.classicMode.startBattle([ Species.CHERRIM ]); const cherrim = game.scene.getPlayerPokemon()!; @@ -110,16 +110,16 @@ describe("Abilities - Flower Gift", () => { }); it("reverts to Overcast Form when the Flower Gift is suppressed, changes form under Harsh Sunlight/Sunny when it regains it", async () => { - game.override.enemyMoveset([Moves.GASTRO_ACID]).weather(WeatherType.HARSH_SUN); + game.override.enemyMoveset([ Moves.GASTRO_ACID ]).weather(WeatherType.HARSH_SUN); - await game.classicMode.startBattle([Species.CHERRIM, Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.CHERRIM, Species.MAGIKARP ]); const cherrim = game.scene.getPlayerPokemon()!; expect(cherrim.formIndex).toBe(SUNSHINE_FORM); game.move.select(Moves.SPLASH); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); await game.phaseInterceptor.to("TurnEndPhase"); expect(cherrim.summonData.abilitySuppressed).toBe(true); @@ -140,7 +140,7 @@ describe("Abilities - Flower Gift", () => { it("should be in Overcast Form after the user is switched out", async () => { game.override.weather(WeatherType.SUNNY); - await game.classicMode.startBattle([Species.CASTFORM, Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.CASTFORM, Species.MAGIKARP ]); const cherrim = game.scene.getPlayerPokemon()!; expect(cherrim.formIndex).toBe(SUNSHINE_FORM); diff --git a/src/test/abilities/forecast.test.ts b/src/test/abilities/forecast.test.ts index c1eb3600b8b..18d43a67a9d 100644 --- a/src/test/abilities/forecast.test.ts +++ b/src/test/abilities/forecast.test.ts @@ -30,7 +30,7 @@ describe("Abilities - Forecast", () => { */ const testWeatherFormChange = async (game: GameManager, weather: WeatherType, form: number, initialForm?: number) => { game.override.weather(weather).starterForms({ [Species.CASTFORM]: initialForm }); - await game.startBattle([Species.CASTFORM]); + await game.startBattle([ Species.CASTFORM ]); game.move.select(Moves.SPLASH); @@ -44,7 +44,7 @@ describe("Abilities - Forecast", () => { */ const testRevertFormAgainstAbility = async (game: GameManager, ability: Abilities) => { game.override.starterForms({ [Species.CASTFORM]: SUNNY_FORM }).enemyAbility(ability); - await game.startBattle([Species.CASTFORM]); + await game.startBattle([ Species.CASTFORM ]); game.move.select(Moves.SPLASH); @@ -64,7 +64,7 @@ describe("Abilities - Forecast", () => { beforeEach(() => { game = new GameManager(phaserGame); game.override - .moveset([Moves.SPLASH, Moves.RAIN_DANCE, Moves.SUNNY_DAY, Moves.TACKLE]) + .moveset([ Moves.SPLASH, Moves.RAIN_DANCE, Moves.SUNNY_DAY, Moves.TACKLE ]) .enemySpecies(Species.MAGIKARP) .enemyMoveset(Moves.SPLASH) .enemyAbility(Abilities.BALL_FETCH); @@ -72,16 +72,16 @@ describe("Abilities - Forecast", () => { it("changes form based on weather", async () => { game.override - .moveset([Moves.RAIN_DANCE, Moves.SUNNY_DAY, Moves.SNOWSCAPE, Moves.SPLASH]) + .moveset([ Moves.RAIN_DANCE, Moves.SUNNY_DAY, Moves.SNOWSCAPE, Moves.SPLASH ]) .battleType("double") .starterForms({ [Species.KYOGRE]: 1, [Species.GROUDON]: 1, [Species.RAYQUAZA]: 1 }); - await game.startBattle([Species.CASTFORM, Species.FEEBAS, Species.KYOGRE, Species.GROUDON, Species.RAYQUAZA, Species.ALTARIA]); + await game.startBattle([ Species.CASTFORM, Species.FEEBAS, Species.KYOGRE, Species.GROUDON, Species.RAYQUAZA, Species.ALTARIA ]); - vi.spyOn(game.scene.getParty()[5], "getAbility").mockReturnValue(allAbilities[Abilities.CLOUD_NINE]); + vi.spyOn(game.scene.getPlayerParty()[5], "getAbility").mockReturnValue(allAbilities[Abilities.CLOUD_NINE]); const castform = game.scene.getPlayerField()[0]; expect(castform.formIndex).toBe(NORMAL_FORM); @@ -107,7 +107,7 @@ describe("Abilities - Forecast", () => { expect(castform.formIndex).toBe(SNOWY_FORM); - game.override.moveset([Moves.HAIL, Moves.SANDSTORM, Moves.SNOWSCAPE, Moves.SPLASH]); + game.override.moveset([ Moves.HAIL, Moves.SANDSTORM, Moves.SNOWSCAPE, Moves.SPLASH ]); game.move.select(Moves.SANDSTORM); game.move.select(Moves.SPLASH, 1); @@ -190,7 +190,7 @@ describe("Abilities - Forecast", () => { it("has no effect on Pokémon other than Castform", async () => { game.override.enemyAbility(Abilities.FORECAST).enemySpecies(Species.SHUCKLE); - await game.startBattle([Species.CASTFORM]); + await game.startBattle([ Species.CASTFORM ]); game.move.select(Moves.RAIN_DANCE); await game.phaseInterceptor.to(TurnEndPhase); @@ -200,8 +200,8 @@ describe("Abilities - Forecast", () => { }); it("reverts to Normal Form when Castform loses Forecast, changes form to match the weather when it regains it", async () => { - game.override.moveset([Moves.SKILL_SWAP, Moves.WORRY_SEED, Moves.SPLASH]).weather(WeatherType.RAIN).battleType("double"); - await game.startBattle([Species.CASTFORM, Species.FEEBAS]); + game.override.moveset([ Moves.SKILL_SWAP, Moves.WORRY_SEED, Moves.SPLASH ]).weather(WeatherType.RAIN).battleType("double"); + await game.startBattle([ Species.CASTFORM, Species.FEEBAS ]); const castform = game.scene.getPlayerField()[0]; @@ -209,7 +209,7 @@ describe("Abilities - Forecast", () => { game.move.select(Moves.SKILL_SWAP, 0, BattlerIndex.PLAYER_2); game.move.select(Moves.SKILL_SWAP, 1, BattlerIndex.PLAYER); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2 ]); await game.phaseInterceptor.to("MoveEndPhase"); expect(castform.formIndex).toBe(NORMAL_FORM); @@ -221,22 +221,22 @@ describe("Abilities - Forecast", () => { game.move.select(Moves.SPLASH); game.move.select(Moves.WORRY_SEED, 1, BattlerIndex.PLAYER); - await game.setTurnOrder([BattlerIndex.PLAYER_2, BattlerIndex.PLAYER, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2]); + await game.setTurnOrder([ BattlerIndex.PLAYER_2, BattlerIndex.PLAYER, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2 ]); await game.phaseInterceptor.to("MoveEndPhase"); expect(castform.formIndex).toBe(NORMAL_FORM); }); it("reverts to Normal Form when Forecast is suppressed, changes form to match the weather when it regains it", async () => { - game.override.enemyMoveset([Moves.GASTRO_ACID]).weather(WeatherType.RAIN); - await game.startBattle([Species.CASTFORM, Species.PIKACHU]); + game.override.enemyMoveset([ Moves.GASTRO_ACID ]).weather(WeatherType.RAIN); + await game.startBattle([ Species.CASTFORM, Species.PIKACHU ]); const castform = game.scene.getPlayerPokemon()!; expect(castform.formIndex).toBe(RAINY_FORM); // First turn - Forecast is suppressed game.move.select(Moves.SPLASH); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); await game.move.forceHit(); await game.phaseInterceptor.to(TurnEndPhase); @@ -259,8 +259,8 @@ describe("Abilities - Forecast", () => { }); it("does not change Castform's form until after Stealth Rock deals damage", async () => { - game.override.weather(WeatherType.RAIN).enemyMoveset([Moves.STEALTH_ROCK]); - await game.startBattle([Species.PIKACHU, Species.CASTFORM]); + game.override.weather(WeatherType.RAIN).enemyMoveset([ Moves.STEALTH_ROCK ]); + await game.startBattle([ Species.PIKACHU, Species.CASTFORM ]); // First turn - set up stealth rock game.move.select(Moves.SPLASH); @@ -284,7 +284,7 @@ describe("Abilities - Forecast", () => { it("should be in Normal Form after the user is switched out", async () => { game.override.weather(WeatherType.RAIN); - await game.startBattle([Species.CASTFORM, Species.MAGIKARP]); + await game.startBattle([ Species.CASTFORM, Species.MAGIKARP ]); const castform = game.scene.getPlayerPokemon()!; expect(castform.formIndex).toBe(RAINY_FORM); diff --git a/src/test/abilities/friend_guard.test.ts b/src/test/abilities/friend_guard.test.ts new file mode 100644 index 00000000000..4ce64468c43 --- /dev/null +++ b/src/test/abilities/friend_guard.test.ts @@ -0,0 +1,120 @@ +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import { Abilities } from "#enums/abilities"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; +import { BattlerIndex } from "#app/battle"; +import { allAbilities } from "#app/data/ability"; +import { allMoves, MoveCategory } from "#app/data/move"; + +describe("Moves - Friend Guard", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .battleType("double") + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset([ Moves.TACKLE, Moves.SPLASH, Moves.DRAGON_RAGE ]) + .enemySpecies(Species.SHUCKLE) + .moveset([ Moves.SPLASH ]) + .startingLevel(100); + }); + + it("should reduce damage that other allied Pokémon receive from attacks (from any Pokémon) by 25%", async () => { + await game.classicMode.startBattle([ Species.BULBASAUR, Species.CHARMANDER ]); + const [ player1, player2 ] = game.scene.getPlayerField(); + const spy = vi.spyOn(player1, "getAttackDamage"); + + const enemy1 = game.scene.getEnemyField()[0]; + + game.move.select(Moves.SPLASH); + game.move.select(Moves.SPLASH, 1); + await game.forceEnemyMove(Moves.TACKLE, BattlerIndex.PLAYER); + await game.forceEnemyMove(Moves.SPLASH); + await game.toNextTurn(); + + // Get the last return value from `getAttackDamage` + const turn1Damage = spy.mock.results[spy.mock.results.length - 1].value.damage; + // Making sure the test is controlled; turn 1 damage is equal to base damage (after rounding) + expect(turn1Damage).toBe(Math.floor(player1.getBaseDamage(enemy1, allMoves[Moves.TACKLE], MoveCategory.PHYSICAL))); + + vi.spyOn(player2, "getAbility").mockReturnValue(allAbilities[Abilities.FRIEND_GUARD]); + + game.move.select(Moves.SPLASH); + game.move.select(Moves.SPLASH, 1); + await game.forceEnemyMove(Moves.TACKLE, BattlerIndex.PLAYER); + await game.forceEnemyMove(Moves.SPLASH); + await game.toNextTurn(); + + // Get the last return value from `getAttackDamage` + const turn2Damage = spy.mock.results[spy.mock.results.length - 1].value.damage; + // With the ally's Friend Guard, damage should have been reduced from base damage by 25% + expect(turn2Damage).toBe(Math.floor(player1.getBaseDamage(enemy1, allMoves[Moves.TACKLE], MoveCategory.PHYSICAL) * 0.75)); + }); + + it("should NOT reduce damage to pokemon with friend guard", async () => { + await game.classicMode.startBattle([ Species.BULBASAUR, Species.CHARMANDER ]); + + const player2 = game.scene.getPlayerField()[1]; + const spy = vi.spyOn(player2, "getAttackDamage"); + + game.move.select(Moves.SPLASH); + game.move.select(Moves.SPLASH, 1); + await game.forceEnemyMove(Moves.TACKLE, BattlerIndex.PLAYER_2); + await game.forceEnemyMove(Moves.SPLASH); + await game.toNextTurn(); + + const turn1Damage = spy.mock.results[spy.mock.results.length - 1].value.damage; + + vi.spyOn(player2, "getAbility").mockReturnValue(allAbilities[Abilities.FRIEND_GUARD]); + + game.move.select(Moves.SPLASH); + game.move.select(Moves.SPLASH, 1); + await game.forceEnemyMove(Moves.TACKLE, BattlerIndex.PLAYER_2); + await game.forceEnemyMove(Moves.SPLASH); + await game.toNextTurn(); + + const turn2Damage = spy.mock.results[spy.mock.results.length - 1].value.damage; + expect(turn2Damage).toBe(turn1Damage); + }); + + it("should NOT reduce damage from fixed damage attacks", async () => { + await game.classicMode.startBattle([ Species.BULBASAUR, Species.CHARMANDER ]); + + const [ player1, player2 ] = game.scene.getPlayerField(); + const spy = vi.spyOn(player1, "getAttackDamage"); + + game.move.select(Moves.SPLASH); + game.move.select(Moves.SPLASH, 1); + await game.forceEnemyMove(Moves.DRAGON_RAGE, BattlerIndex.PLAYER); + await game.forceEnemyMove(Moves.SPLASH); + await game.toNextTurn(); + + const turn1Damage = spy.mock.results[spy.mock.results.length - 1].value.damage; + expect(turn1Damage).toBe(40); + + vi.spyOn(player2, "getAbility").mockReturnValue(allAbilities[Abilities.FRIEND_GUARD]); + + game.move.select(Moves.SPLASH); + game.move.select(Moves.SPLASH, 1); + await game.forceEnemyMove(Moves.DRAGON_RAGE, BattlerIndex.PLAYER); + await game.forceEnemyMove(Moves.SPLASH); + await game.toNextTurn(); + + const turn2Damage = spy.mock.results[spy.mock.results.length - 1].value.damage; + expect(turn2Damage).toBe(40); + }); +}); diff --git a/src/test/abilities/galvanize.test.ts b/src/test/abilities/galvanize.test.ts index f81b854180a..80e767866ea 100644 --- a/src/test/abilities/galvanize.test.ts +++ b/src/test/abilities/galvanize.test.ts @@ -1,6 +1,6 @@ import { BattlerIndex } from "#app/battle"; import { allMoves } from "#app/data/move"; -import { Type } from "#app/data/type"; +import { Type } from "#enums/type"; import { Abilities } from "#app/enums/abilities"; import { Moves } from "#app/enums/moves"; import { Species } from "#app/enums/species"; @@ -9,7 +9,6 @@ import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Abilities - Galvanize", () => { let phaserGame: Phaser.Game; @@ -32,7 +31,7 @@ describe("Abilities - Galvanize", () => { .battleType("single") .startingLevel(100) .ability(Abilities.GALVANIZE) - .moveset([Moves.TACKLE, Moves.REVELATION_DANCE, Moves.FURY_SWIPES]) + .moveset([ Moves.TACKLE, Moves.REVELATION_DANCE, Moves.FURY_SWIPES ]) .enemySpecies(Species.DUSCLOPS) .enemyAbility(Abilities.BALL_FETCH) .enemyMoveset(Moves.SPLASH) @@ -59,7 +58,7 @@ describe("Abilities - Galvanize", () => { expect(enemyPokemon.apply).toHaveReturnedWith(HitResult.EFFECTIVE); expect(move.calculateBattlePower).toHaveReturnedWith(48); expect(enemyPokemon.hp).toBeLessThan(enemyPokemon.getMaxHp()); - }, TIMEOUT); + }); it("should cause Normal-type attacks to activate Volt Absorb", async () => { game.override.enemyAbility(Abilities.VOLT_ABSORB); @@ -81,12 +80,12 @@ describe("Abilities - Galvanize", () => { expect(playerPokemon.getMoveType).toHaveLastReturnedWith(Type.ELECTRIC); expect(enemyPokemon.apply).toHaveReturnedWith(HitResult.NO_EFFECT); expect(enemyPokemon.hp).toBe(enemyPokemon.getMaxHp()); - }, TIMEOUT); + }); it("should not change the type of variable-type moves", async () => { game.override.enemySpecies(Species.MIGHTYENA); - await game.startBattle([Species.ESPEON]); + await game.startBattle([ Species.ESPEON ]); const playerPokemon = game.scene.getPlayerPokemon()!; vi.spyOn(playerPokemon, "getMoveType"); @@ -100,7 +99,7 @@ describe("Abilities - Galvanize", () => { expect(playerPokemon.getMoveType).not.toHaveLastReturnedWith(Type.ELECTRIC); expect(enemyPokemon.apply).toHaveReturnedWith(HitResult.NO_EFFECT); expect(enemyPokemon.hp).toBe(enemyPokemon.getMaxHp()); - }, TIMEOUT); + }); it("should affect all hits of a Normal-type multi-hit move", async () => { await game.startBattle(); @@ -112,7 +111,7 @@ describe("Abilities - Galvanize", () => { vi.spyOn(enemyPokemon, "apply"); game.move.select(Moves.FURY_SWIPES); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.move.forceHit(); await game.phaseInterceptor.to("MoveEffectPhase"); @@ -128,5 +127,5 @@ describe("Abilities - Galvanize", () => { } expect(enemyPokemon.apply).not.toHaveReturnedWith(HitResult.NO_EFFECT); - }, TIMEOUT); + }); }); diff --git a/src/test/abilities/gorilla_tactics.test.ts b/src/test/abilities/gorilla_tactics.test.ts index df698194323..8aee365eb8f 100644 --- a/src/test/abilities/gorilla_tactics.test.ts +++ b/src/test/abilities/gorilla_tactics.test.ts @@ -10,8 +10,6 @@ import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; describe("Abilities - Gorilla Tactics", () => { let phaserGame: Phaser.Game; let game: GameManager; - const TIMEOUT = 20 * 1000; - beforeAll(() => { phaserGame = new Phaser.Game({ type: Phaser.HEADLESS, @@ -27,15 +25,15 @@ describe("Abilities - Gorilla Tactics", () => { game.override .battleType("single") .enemyAbility(Abilities.BALL_FETCH) - .enemyMoveset([Moves.SPLASH, Moves.DISABLE]) + .enemyMoveset([ Moves.SPLASH, Moves.DISABLE ]) .enemySpecies(Species.MAGIKARP) .enemyLevel(30) - .moveset([Moves.SPLASH, Moves.TACKLE, Moves.GROWL]) + .moveset([ Moves.SPLASH, Moves.TACKLE, Moves.GROWL ]) .ability(Abilities.GORILLA_TACTICS); }); it("boosts the Pokémon's Attack by 50%, but limits the Pokémon to using only one move", async () => { - await game.classicMode.startBattle([Species.GALAR_DARMANITAN]); + await game.classicMode.startBattle([ Species.GALAR_DARMANITAN ]); const darmanitan = game.scene.getPlayerPokemon()!; const initialAtkStat = darmanitan.getStat(Stat.ATK); @@ -49,10 +47,10 @@ describe("Abilities - Gorilla Tactics", () => { // Other moves should be restricted expect(darmanitan.isMoveRestricted(Moves.TACKLE)).toBe(true); expect(darmanitan.isMoveRestricted(Moves.SPLASH)).toBe(false); - }, TIMEOUT); + }); it("should struggle if the only usable move is disabled", async () => { - await game.classicMode.startBattle([Species.GALAR_DARMANITAN]); + await game.classicMode.startBattle([ Species.GALAR_DARMANITAN ]); const darmanitan = game.scene.getPlayerPokemon()!; const enemy = game.scene.getEnemyPokemon()!; @@ -66,7 +64,7 @@ describe("Abilities - Gorilla Tactics", () => { game.move.select(Moves.GROWL); await game.forceEnemyMove(Moves.DISABLE); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); await game.phaseInterceptor.to("TurnEndPhase"); expect(enemy.getStatStage(Stat.ATK)).toBe(-1); // Only the effect of the first Growl should be applied @@ -75,9 +73,9 @@ describe("Abilities - Gorilla Tactics", () => { await game.toNextTurn(); game.move.select(Moves.TACKLE); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to("MoveEndPhase"); expect(darmanitan.hp).toBeLessThan(darmanitan.getMaxHp()); - }, TIMEOUT); + }); }); diff --git a/src/test/abilities/gulp_missile.test.ts b/src/test/abilities/gulp_missile.test.ts index ac0efd8e8d1..01b68d0c89d 100644 --- a/src/test/abilities/gulp_missile.test.ts +++ b/src/test/abilities/gulp_missile.test.ts @@ -1,17 +1,14 @@ -import { BattlerTagType } from "#app/enums/battler-tag-type"; -import { StatusEffect } from "#app/enums/status-effect"; +import { BattlerIndex } from "#app/battle"; import Pokemon from "#app/field/pokemon"; -import { BerryPhase } from "#app/phases/berry-phase"; -import { MoveEndPhase } from "#app/phases/move-end-phase"; -import { TurnEndPhase } from "#app/phases/turn-end-phase"; -import { TurnStartPhase } from "#app/phases/turn-start-phase"; -import GameManager from "#app/test/utils/gameManager"; import { Abilities } from "#enums/abilities"; +import { BattlerTagType } from "#enums/battler-tag-type"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; +import { Stat } from "#enums/stat"; +import { StatusEffect } from "#enums/status-effect"; +import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; -import { Stat } from "#enums/stat"; describe("Abilities - Gulp Missile", () => { let phaserGame: Phaser.Game; @@ -44,8 +41,9 @@ describe("Abilities - Gulp Missile", () => { beforeEach(() => { game = new GameManager(phaserGame); game.override + .disableCrits() .battleType("single") - .moveset([Moves.SURF, Moves.DIVE, Moves.SPLASH]) + .moveset([ Moves.SURF, Moves.DIVE, Moves.SPLASH, Moves.SUBSTITUTE ]) .enemySpecies(Species.SNORLAX) .enemyAbility(Abilities.BALL_FETCH) .enemyMoveset(Moves.SPLASH) @@ -53,13 +51,13 @@ describe("Abilities - Gulp Missile", () => { }); it("changes to Gulping Form if HP is over half when Surf or Dive is used", async () => { - await game.startBattle([Species.CRAMORANT]); + await game.classicMode.startBattle([ Species.CRAMORANT ]); const cramorant = game.scene.getPlayerPokemon()!; game.move.select(Moves.DIVE); await game.toNextTurn(); game.move.select(Moves.DIVE); - await game.phaseInterceptor.to(MoveEndPhase); + await game.phaseInterceptor.to("MoveEndPhase"); expect(cramorant.getHpRatio()).toBeGreaterThanOrEqual(.5); expect(cramorant.getTag(BattlerTagType.GULP_MISSILE_ARROKUDA)).toBeDefined(); @@ -67,21 +65,21 @@ describe("Abilities - Gulp Missile", () => { }); it("changes to Gorging Form if HP is under half when Surf or Dive is used", async () => { - await game.startBattle([Species.CRAMORANT]); + await game.classicMode.startBattle([ Species.CRAMORANT ]); const cramorant = game.scene.getPlayerPokemon()!; vi.spyOn(cramorant, "getHpRatio").mockReturnValue(.49); expect(cramorant.getHpRatio()).toBe(.49); game.move.select(Moves.SURF); - await game.phaseInterceptor.to(MoveEndPhase); + await game.phaseInterceptor.to("MoveEndPhase"); expect(cramorant.getTag(BattlerTagType.GULP_MISSILE_PIKACHU)).toBeDefined(); expect(cramorant.formIndex).toBe(GORGING_FORM); }); it("changes to base form when switched out after Surf or Dive is used", async () => { - await game.startBattle([Species.CRAMORANT, Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.CRAMORANT, Species.MAGIKARP ]); const cramorant = game.scene.getPlayerPokemon()!; game.move.select(Moves.SURF); @@ -96,51 +94,51 @@ describe("Abilities - Gulp Missile", () => { }); it("changes form during Dive's charge turn", async () => { - await game.startBattle([Species.CRAMORANT]); + await game.classicMode.startBattle([ Species.CRAMORANT ]); const cramorant = game.scene.getPlayerPokemon()!; game.move.select(Moves.DIVE); - await game.phaseInterceptor.to(MoveEndPhase); + await game.phaseInterceptor.to("MoveEndPhase"); expect(cramorant.getTag(BattlerTagType.GULP_MISSILE_ARROKUDA)).toBeDefined(); expect(cramorant.formIndex).toBe(GULPING_FORM); }); it("deals 1/4 of the attacker's maximum HP when hit by a damaging attack", async () => { - game.override.enemyMoveset([Moves.TACKLE]); - await game.startBattle([Species.CRAMORANT]); + game.override.enemyMoveset(Moves.TACKLE); + await game.classicMode.startBattle([ Species.CRAMORANT ]); const enemy = game.scene.getEnemyPokemon()!; vi.spyOn(enemy, "damageAndUpdate"); game.move.select(Moves.SURF); - await game.phaseInterceptor.to(TurnEndPhase); + await game.phaseInterceptor.to("TurnEndPhase"); expect(enemy.damageAndUpdate).toHaveReturnedWith(getEffectDamage(enemy)); }); it("does not have any effect when hit by non-damaging attack", async () => { - game.override.enemyMoveset([Moves.TAIL_WHIP]); - await game.startBattle([Species.CRAMORANT]); + game.override.enemyMoveset(Moves.TAIL_WHIP); + await game.classicMode.startBattle([ Species.CRAMORANT ]); const cramorant = game.scene.getPlayerPokemon()!; vi.spyOn(cramorant, "getHpRatio").mockReturnValue(.55); game.move.select(Moves.SURF); - await game.phaseInterceptor.to(MoveEndPhase); + await game.phaseInterceptor.to("MoveEndPhase"); expect(cramorant.getTag(BattlerTagType.GULP_MISSILE_ARROKUDA)).toBeDefined(); expect(cramorant.formIndex).toBe(GULPING_FORM); - await game.phaseInterceptor.to(TurnEndPhase); + await game.phaseInterceptor.to("TurnEndPhase"); expect(cramorant.getTag(BattlerTagType.GULP_MISSILE_ARROKUDA)).toBeDefined(); expect(cramorant.formIndex).toBe(GULPING_FORM); }); it("lowers attacker's DEF stat stage by 1 when hit in Gulping form", async () => { - game.override.enemyMoveset([Moves.TACKLE]); - await game.startBattle([Species.CRAMORANT]); + game.override.enemyMoveset(Moves.TACKLE); + await game.classicMode.startBattle([ Species.CRAMORANT ]); const cramorant = game.scene.getPlayerPokemon()!; const enemy = game.scene.getEnemyPokemon()!; @@ -149,12 +147,12 @@ describe("Abilities - Gulp Missile", () => { vi.spyOn(cramorant, "getHpRatio").mockReturnValue(.55); game.move.select(Moves.SURF); - await game.phaseInterceptor.to(MoveEndPhase); + await game.phaseInterceptor.to("MoveEndPhase"); expect(cramorant.getTag(BattlerTagType.GULP_MISSILE_ARROKUDA)).toBeDefined(); expect(cramorant.formIndex).toBe(GULPING_FORM); - await game.phaseInterceptor.to(TurnEndPhase); + await game.phaseInterceptor.to("TurnEndPhase"); expect(enemy.damageAndUpdate).toHaveReturnedWith(getEffectDamage(enemy)); expect(enemy.getStatStage(Stat.DEF)).toBe(-1); @@ -163,8 +161,8 @@ describe("Abilities - Gulp Missile", () => { }); it("paralyzes the enemy when hit in Gorging form", async () => { - game.override.enemyMoveset([Moves.TACKLE]); - await game.startBattle([Species.CRAMORANT]); + game.override.enemyMoveset(Moves.TACKLE); + await game.classicMode.startBattle([ Species.CRAMORANT ]); const cramorant = game.scene.getPlayerPokemon()!; const enemy = game.scene.getEnemyPokemon()!; @@ -173,12 +171,12 @@ describe("Abilities - Gulp Missile", () => { vi.spyOn(cramorant, "getHpRatio").mockReturnValue(.45); game.move.select(Moves.SURF); - await game.phaseInterceptor.to(MoveEndPhase); + await game.phaseInterceptor.to("MoveEndPhase"); expect(cramorant.getTag(BattlerTagType.GULP_MISSILE_PIKACHU)).toBeDefined(); expect(cramorant.formIndex).toBe(GORGING_FORM); - await game.phaseInterceptor.to(TurnEndPhase); + await game.phaseInterceptor.to("TurnEndPhase"); expect(enemy.damageAndUpdate).toHaveReturnedWith(getEffectDamage(enemy)); expect(enemy.status?.effect).toBe(StatusEffect.PARALYSIS); @@ -187,21 +185,21 @@ describe("Abilities - Gulp Missile", () => { }); it("does not activate the ability when underwater", async () => { - game.override.enemyMoveset([Moves.SURF]); - await game.startBattle([Species.CRAMORANT]); + game.override.enemyMoveset(Moves.SURF); + await game.classicMode.startBattle([ Species.CRAMORANT ]); const cramorant = game.scene.getPlayerPokemon()!; game.move.select(Moves.DIVE); - await game.phaseInterceptor.to(BerryPhase, false); + await game.phaseInterceptor.to("BerryPhase", false); expect(cramorant.getTag(BattlerTagType.GULP_MISSILE_ARROKUDA)).toBeDefined(); expect(cramorant.formIndex).toBe(GULPING_FORM); }); it("prevents effect damage but inflicts secondary effect on attacker with Magic Guard", async () => { - game.override.enemyMoveset([Moves.TACKLE]).enemyAbility(Abilities.MAGIC_GUARD); - await game.startBattle([Species.CRAMORANT]); + game.override.enemyMoveset(Moves.TACKLE).enemyAbility(Abilities.MAGIC_GUARD); + await game.classicMode.startBattle([ Species.CRAMORANT ]); const cramorant = game.scene.getPlayerPokemon()!; const enemy = game.scene.getEnemyPokemon()!; @@ -209,13 +207,13 @@ describe("Abilities - Gulp Missile", () => { vi.spyOn(cramorant, "getHpRatio").mockReturnValue(.55); game.move.select(Moves.SURF); - await game.phaseInterceptor.to(MoveEndPhase); + await game.phaseInterceptor.to("MoveEndPhase"); const enemyHpPreEffect = enemy.hp; expect(cramorant.getTag(BattlerTagType.GULP_MISSILE_ARROKUDA)).toBeDefined(); expect(cramorant.formIndex).toBe(GULPING_FORM); - await game.phaseInterceptor.to(TurnEndPhase); + await game.phaseInterceptor.to("TurnEndPhase"); expect(enemy.hp).toBe(enemyHpPreEffect); expect(enemy.getStatStage(Stat.DEF)).toBe(-1); @@ -223,20 +221,55 @@ describe("Abilities - Gulp Missile", () => { expect(cramorant.formIndex).toBe(NORMAL_FORM); }); + it("activates on faint", async () => { + game.override.enemyMoveset(Moves.THUNDERBOLT); + await game.classicMode.startBattle([ Species.CRAMORANT ]); + + const cramorant = game.scene.getPlayerPokemon()!; + + game.move.select(Moves.SURF); + await game.phaseInterceptor.to("FaintPhase"); + + expect(cramorant.hp).toBe(0); + expect(cramorant.getTag(BattlerTagType.GULP_MISSILE_ARROKUDA)).toBeUndefined(); + expect(cramorant.formIndex).toBe(NORMAL_FORM); + expect(game.scene.getEnemyPokemon()!.getStatStage(Stat.DEF)).toBe(-1); + }); + + it("doesn't trigger if user is behind a substitute", async () => { + game.override + .enemyAbility(Abilities.STURDY) + .enemyMoveset([ Moves.SPLASH, Moves.POWER_TRIP ]); + await game.classicMode.startBattle([ Species.CRAMORANT ]); + + game.move.select(Moves.SURF); + await game.forceEnemyMove(Moves.SPLASH); + await game.toNextTurn(); + + expect(game.scene.getPlayerPokemon()!.formIndex).toBe(GULPING_FORM); + + game.move.select(Moves.SUBSTITUTE); + await game.forceEnemyMove(Moves.POWER_TRIP); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + await game.toNextTurn(); + + expect(game.scene.getPlayerPokemon()!.formIndex).toBe(GULPING_FORM); + }); + it("cannot be suppressed", async () => { - game.override.enemyMoveset([Moves.GASTRO_ACID]); - await game.startBattle([Species.CRAMORANT]); + game.override.enemyMoveset(Moves.GASTRO_ACID); + await game.classicMode.startBattle([ Species.CRAMORANT ]); const cramorant = game.scene.getPlayerPokemon()!; vi.spyOn(cramorant, "getHpRatio").mockReturnValue(.55); game.move.select(Moves.SURF); - await game.phaseInterceptor.to(MoveEndPhase); + await game.phaseInterceptor.to("MoveEndPhase"); expect(cramorant.getTag(BattlerTagType.GULP_MISSILE_ARROKUDA)).toBeDefined(); expect(cramorant.formIndex).toBe(GULPING_FORM); - await game.phaseInterceptor.to(TurnEndPhase); + await game.phaseInterceptor.to("TurnEndPhase"); expect(cramorant.hasAbility(Abilities.GULP_MISSILE)).toBe(true); expect(cramorant.getTag(BattlerTagType.GULP_MISSILE_ARROKUDA)).toBeDefined(); @@ -244,19 +277,19 @@ describe("Abilities - Gulp Missile", () => { }); it("cannot be swapped with another ability", async () => { - game.override.enemyMoveset([Moves.SKILL_SWAP]); - await game.startBattle([Species.CRAMORANT]); + game.override.enemyMoveset(Moves.SKILL_SWAP); + await game.classicMode.startBattle([ Species.CRAMORANT ]); const cramorant = game.scene.getPlayerPokemon()!; vi.spyOn(cramorant, "getHpRatio").mockReturnValue(.55); game.move.select(Moves.SURF); - await game.phaseInterceptor.to(MoveEndPhase); + await game.phaseInterceptor.to("MoveEndPhase"); expect(cramorant.getTag(BattlerTagType.GULP_MISSILE_ARROKUDA)).toBeDefined(); expect(cramorant.formIndex).toBe(GULPING_FORM); - await game.phaseInterceptor.to(TurnEndPhase); + await game.phaseInterceptor.to("TurnEndPhase"); expect(cramorant.hasAbility(Abilities.GULP_MISSILE)).toBe(true); expect(cramorant.getTag(BattlerTagType.GULP_MISSILE_ARROKUDA)).toBeDefined(); @@ -266,9 +299,9 @@ describe("Abilities - Gulp Missile", () => { it("cannot be copied", async () => { game.override.enemyAbility(Abilities.TRACE); - await game.startBattle([Species.CRAMORANT]); + await game.classicMode.startBattle([ Species.CRAMORANT ]); game.move.select(Moves.SPLASH); - await game.phaseInterceptor.to(TurnStartPhase); + await game.phaseInterceptor.to("TurnStartPhase"); expect(game.scene.getEnemyPokemon()?.hasAbility(Abilities.GULP_MISSILE)).toBe(false); }); diff --git a/src/test/abilities/heatproof.test.ts b/src/test/abilities/heatproof.test.ts index 61c406201bd..bf4e99ce467 100644 --- a/src/test/abilities/heatproof.test.ts +++ b/src/test/abilities/heatproof.test.ts @@ -33,7 +33,7 @@ describe("Abilities - Heatproof", () => { .enemyLevel(100) .starterSpecies(Species.CHANDELURE) .ability(Abilities.BALL_FETCH) - .moveset([Moves.FLAMETHROWER, Moves.SPLASH]) + .moveset([ Moves.FLAMETHROWER, Moves.SPLASH ]) .startingLevel(100); }); diff --git a/src/test/abilities/hustle.test.ts b/src/test/abilities/hustle.test.ts index 29cbfdc1a5d..c4c4818040d 100644 --- a/src/test/abilities/hustle.test.ts +++ b/src/test/abilities/hustle.test.ts @@ -34,7 +34,7 @@ describe("Abilities - Hustle", () => { }); it("increases the user's Attack stat by 50%", async () => { - await game.classicMode.startBattle([Species.PIKACHU]); + await game.classicMode.startBattle([ Species.PIKACHU ]); const pikachu = game.scene.getPlayerPokemon()!; const atk = pikachu.stats[Stat.ATK]; @@ -48,7 +48,7 @@ describe("Abilities - Hustle", () => { }); it("lowers the accuracy of the user's physical moves by 20%", async () => { - await game.classicMode.startBattle([Species.PIKACHU]); + await game.classicMode.startBattle([ Species.PIKACHU ]); const pikachu = game.scene.getPlayerPokemon()!; vi.spyOn(pikachu, "getAccuracyMultiplier"); @@ -60,7 +60,7 @@ describe("Abilities - Hustle", () => { }); it("does not affect non-physical moves", async () => { - await game.classicMode.startBattle([Species.PIKACHU]); + await game.classicMode.startBattle([ Species.PIKACHU ]); const pikachu = game.scene.getPlayerPokemon()!; const spatk = pikachu.stats[Stat.SPATK]; @@ -78,7 +78,7 @@ describe("Abilities - Hustle", () => { game.override.startingLevel(100); game.override.enemyLevel(30); - await game.classicMode.startBattle([Species.PIKACHU]); + await game.classicMode.startBattle([ Species.PIKACHU ]); const pikachu = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; diff --git a/src/test/abilities/hyper_cutter.test.ts b/src/test/abilities/hyper_cutter.test.ts index ec947add939..e51fef6bd49 100644 --- a/src/test/abilities/hyper_cutter.test.ts +++ b/src/test/abilities/hyper_cutter.test.ts @@ -24,7 +24,7 @@ describe("Abilities - Hyper Cutter", () => { game = new GameManager(phaserGame); game.override .battleType("single") - .moveset([Moves.SAND_ATTACK, Moves.NOBLE_ROAR, Moves.DEFOG, Moves.OCTOLOCK]) + .moveset([ Moves.SAND_ATTACK, Moves.NOBLE_ROAR, Moves.DEFOG, Moves.OCTOLOCK ]) .ability(Abilities.BALL_FETCH) .enemySpecies(Species.SHUCKLE) .enemyAbility(Abilities.HYPER_CUTTER) @@ -46,11 +46,11 @@ describe("Abilities - Hyper Cutter", () => { await game.toNextTurn(); game.move.select(Moves.SAND_ATTACK); await game.toNextTurn(); - game.override.moveset([Moves.STRING_SHOT]); + game.override.moveset([ Moves.STRING_SHOT ]); game.move.select(Moves.STRING_SHOT); await game.toNextTurn(); expect(enemy.getStatStage(Stat.ATK)).toEqual(0); - [Stat.ACC, Stat.DEF, Stat.EVA, Stat.SPATK, Stat.SPDEF, Stat.SPD].forEach((stat: number) => expect(enemy.getStatStage(stat)).toBeLessThan(0)); + [ Stat.ACC, Stat.DEF, Stat.EVA, Stat.SPATK, Stat.SPDEF, Stat.SPD ].forEach((stat: number) => expect(enemy.getStatStage(stat)).toBeLessThan(0)); }); }); diff --git a/src/test/abilities/ice_face.test.ts b/src/test/abilities/ice_face.test.ts index fbc660c27c2..e31bee1c721 100644 --- a/src/test/abilities/ice_face.test.ts +++ b/src/test/abilities/ice_face.test.ts @@ -1,3 +1,4 @@ +import { BattlerIndex } from "#app/battle"; import { MoveEffectPhase } from "#app/phases/move-effect-phase"; import { MoveEndPhase } from "#app/phases/move-end-phase"; import { QuietFormChangePhase } from "#app/phases/quiet-form-change-phase"; @@ -32,11 +33,11 @@ describe("Abilities - Ice Face", () => { game.override.battleType("single"); game.override.enemySpecies(Species.EISCUE); game.override.enemyAbility(Abilities.ICE_FACE); - game.override.moveset([Moves.TACKLE, Moves.ICE_BEAM, Moves.TOXIC_THREAD, Moves.HAIL]); + game.override.moveset([ Moves.TACKLE, Moves.ICE_BEAM, Moves.TOXIC_THREAD, Moves.HAIL ]); }); it("takes no damage from physical move and transforms to Noice", async () => { - await game.startBattle([Species.HITMONLEE]); + await game.classicMode.startBattle([ Species.HITMONLEE ]); game.move.select(Moves.TACKLE); @@ -50,9 +51,9 @@ describe("Abilities - Ice Face", () => { }); it("takes no damage from the first hit of multihit physical move and transforms to Noice", async () => { - game.override.moveset([Moves.SURGING_STRIKES]); + game.override.moveset([ Moves.SURGING_STRIKES ]); game.override.enemyLevel(1); - await game.startBattle([Species.HITMONLEE]); + await game.classicMode.startBattle([ Species.HITMONLEE ]); game.move.select(Moves.SURGING_STRIKES); @@ -78,7 +79,7 @@ describe("Abilities - Ice Face", () => { }); it("takes damage from special moves", async () => { - await game.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); game.move.select(Moves.ICE_BEAM); @@ -92,7 +93,7 @@ describe("Abilities - Ice Face", () => { }); it("takes effects from status moves", async () => { - await game.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); game.move.select(Moves.TOXIC_THREAD); @@ -105,10 +106,10 @@ describe("Abilities - Ice Face", () => { }); it("transforms to Ice Face when Hail or Snow starts", async () => { - game.override.moveset([Moves.QUICK_ATTACK]); - game.override.enemyMoveset([Moves.HAIL, Moves.HAIL, Moves.HAIL, Moves.HAIL]); + game.override.moveset([ Moves.QUICK_ATTACK ]); + game.override.enemyMoveset([ Moves.HAIL, Moves.HAIL, Moves.HAIL, Moves.HAIL ]); - await game.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); game.move.select(Moves.QUICK_ATTACK); @@ -127,10 +128,10 @@ describe("Abilities - Ice Face", () => { }); it("transforms to Ice Face when summoned on arena with active Snow or Hail", async () => { - game.override.enemyMoveset([Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE]); - game.override.moveset([Moves.SNOWSCAPE]); + game.override.enemyMoveset([ Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE ]); + game.override.moveset([ Moves.SNOWSCAPE ]); - await game.startBattle([Species.EISCUE, Species.NINJASK]); + await game.classicMode.startBattle([ Species.EISCUE, Species.NINJASK ]); game.move.select(Moves.SNOWSCAPE); @@ -155,9 +156,9 @@ describe("Abilities - Ice Face", () => { it("will not revert to its Ice Face if there is already Hail when it changes into Noice", async () => { game.override.enemySpecies(Species.SHUCKLE); - game.override.enemyMoveset([Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE]); + game.override.enemyMoveset([ Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE ]); - await game.startBattle([Species.EISCUE]); + await game.classicMode.startBattle([ Species.EISCUE ]); game.move.select(Moves.HAIL); const eiscue = game.scene.getPlayerPokemon()!; @@ -174,9 +175,9 @@ describe("Abilities - Ice Face", () => { }); it("persists form change when switched out", async () => { - game.override.enemyMoveset([Moves.QUICK_ATTACK, Moves.QUICK_ATTACK, Moves.QUICK_ATTACK, Moves.QUICK_ATTACK]); + game.override.enemyMoveset([ Moves.QUICK_ATTACK, Moves.QUICK_ATTACK, Moves.QUICK_ATTACK, Moves.QUICK_ATTACK ]); - await game.startBattle([Species.EISCUE, Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.EISCUE, Species.MAGIKARP ]); game.move.select(Moves.ICE_BEAM); @@ -191,7 +192,7 @@ describe("Abilities - Ice Face", () => { game.doSwitchPokemon(1); await game.phaseInterceptor.to(TurnEndPhase); - eiscue = game.scene.getParty()[1]; + eiscue = game.scene.getPlayerParty()[1]; expect(eiscue.formIndex).toBe(noiceForm); expect(eiscue.getTag(BattlerTagType.ICE_FACE)).toBeUndefined(); @@ -205,7 +206,7 @@ describe("Abilities - Ice Face", () => { [Species.EISCUE]: noiceForm, }); - await game.startBattle([Species.EISCUE]); + await game.classicMode.startBattle([ Species.EISCUE ]); const eiscue = game.scene.getPlayerPokemon()!; @@ -222,10 +223,23 @@ describe("Abilities - Ice Face", () => { expect(eiscue.getTag(BattlerTagType.ICE_FACE)).not.toBe(undefined); }); - it("cannot be suppressed", async () => { - game.override.moveset([Moves.GASTRO_ACID]); + it("doesn't trigger if user is behind a substitute", async () => { + game.override + .enemyMoveset(Moves.SUBSTITUTE) + .moveset(Moves.POWER_TRIP); + await game.classicMode.startBattle(); - await game.startBattle([Species.MAGIKARP]); + game.move.select(Moves.POWER_TRIP); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); + await game.toNextTurn(); + + expect(game.scene.getEnemyPokemon()!.formIndex).toBe(icefaceForm); + }); + + it("cannot be suppressed", async () => { + game.override.moveset([ Moves.GASTRO_ACID ]); + + await game.classicMode.startBattle([ Species.MAGIKARP ]); game.move.select(Moves.GASTRO_ACID); @@ -239,9 +253,9 @@ describe("Abilities - Ice Face", () => { }); it("cannot be swapped with another ability", async () => { - game.override.moveset([Moves.SKILL_SWAP]); + game.override.moveset([ Moves.SKILL_SWAP ]); - await game.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); game.move.select(Moves.SKILL_SWAP); @@ -257,7 +271,7 @@ describe("Abilities - Ice Face", () => { it("cannot be copied", async () => { game.override.ability(Abilities.TRACE); - await game.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); game.move.select(Moves.SIMPLE_BEAM); diff --git a/src/test/abilities/illuminate.test.ts b/src/test/abilities/illuminate.test.ts new file mode 100644 index 00000000000..4f7d3d83b51 --- /dev/null +++ b/src/test/abilities/illuminate.test.ts @@ -0,0 +1,58 @@ +import { Stat } from "#app/enums/stat"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, it, expect } from "vitest"; + +describe("Abilities - Illuminate", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset(Moves.SPLASH) + .ability(Abilities.ILLUMINATE) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.SAND_ATTACK); + }); + + it("should prevent ACC stat stage from being lowered", async () => { + game.override.battleType("single"); + + await game.classicMode.startBattle(); + + const player = game.scene.getPlayerPokemon()!; + + expect(player.getStatStage(Stat.ACC)).toBe(0); + + game.move.select(Moves.SPLASH); + + await game.toNextTurn(); + + expect(player.getStatStage(Stat.ACC)).toBe(0); + }); + + it("should guarantee double battle with any one LURE", async () => { + game.override + .startingModifier([ + { name: "LURE" }, + ]) + .startingWave(2); + + await game.classicMode.startBattle(); + + expect(game.scene.getEnemyField().length).toBe(2); + }); +}); diff --git a/src/test/abilities/imposter.test.ts b/src/test/abilities/imposter.test.ts index 27673564aaa..3445b3b322c 100644 --- a/src/test/abilities/imposter.test.ts +++ b/src/test/abilities/imposter.test.ts @@ -36,9 +36,7 @@ describe("Abilities - Imposter", () => { }); it("should copy species, ability, gender, all stats except HP, all stat stages, moveset, and types of target", async () => { - await game.startBattle([ - Species.DITTO - ]); + await game.classicMode.startBattle([ Species.DITTO ]); game.move.select(Moves.SPLASH); await game.phaseInterceptor.to(TurnEndPhase); @@ -62,25 +60,24 @@ describe("Abilities - Imposter", () => { const playerMoveset = player.getMoveset(); const enemyMoveset = player.getMoveset(); + expect(playerMoveset.length).toBe(enemyMoveset.length); for (let i = 0; i < playerMoveset.length && i < enemyMoveset.length; i++) { - // TODO: Checks for 5 PP should be done here when that gets addressed expect(playerMoveset[i]?.moveId).toBe(enemyMoveset[i]?.moveId); } const playerTypes = player.getTypes(); const enemyTypes = enemy.getTypes(); + expect(playerTypes.length).toBe(enemyTypes.length); for (let i = 0; i < playerTypes.length && i < enemyTypes.length; i++) { expect(playerTypes[i]).toBe(enemyTypes[i]); } - }, 20000); + }); it("should copy in-battle overridden stats", async () => { - game.override.enemyMoveset([Moves.POWER_SPLIT]); + game.override.enemyMoveset([ Moves.POWER_SPLIT ]); - await game.startBattle([ - Species.DITTO - ]); + await game.classicMode.startBattle([ Species.DITTO ]); const player = game.scene.getPlayerPokemon()!; const enemy = game.scene.getEnemyPokemon()!; @@ -97,4 +94,26 @@ describe("Abilities - Imposter", () => { expect(player.getStat(Stat.SPATK, false)).toBe(avgSpAtk); expect(enemy.getStat(Stat.SPATK, false)).toBe(avgSpAtk); }); + + it("should set each move's pp to a maximum of 5", async () => { + game.override.enemyMoveset([ Moves.SWORDS_DANCE, Moves.GROWL, Moves.SKETCH, Moves.RECOVER ]); + + await game.classicMode.startBattle([ Species.DITTO ]); + const player = game.scene.getPlayerPokemon()!; + + game.move.select(Moves.TACKLE); + await game.phaseInterceptor.to(TurnEndPhase); + + player.getMoveset().forEach(move => { + // Should set correct maximum PP without touching `ppUp` + if (move) { + if (move.moveId === Moves.SKETCH) { + expect(move.getMovePp()).toBe(1); + } else { + expect(move.getMovePp()).toBe(5); + } + expect(move.ppUp).toBe(0); + } + }); + }); }); diff --git a/src/test/abilities/infiltrator.test.ts b/src/test/abilities/infiltrator.test.ts new file mode 100644 index 00000000000..01c5cef7796 --- /dev/null +++ b/src/test/abilities/infiltrator.test.ts @@ -0,0 +1,107 @@ +import { ArenaTagSide } from "#app/data/arena-tag"; +import { allMoves } from "#app/data/move"; +import { ArenaTagType } from "#enums/arena-tag-type"; +import { BattlerTagType } from "#enums/battler-tag-type"; +import { Stat } from "#enums/stat"; +import { StatusEffect } from "#enums/status-effect"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; + +describe("Abilities - Infiltrator", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.TACKLE, Moves.WATER_GUN, Moves.SPORE, Moves.BABY_DOLL_EYES ]) + .ability(Abilities.INFILTRATOR) + .battleType("single") + .disableCrits() + .enemySpecies(Species.SNORLAX) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.SPLASH) + .startingLevel(100) + .enemyLevel(100); + }); + + it.each([ + { effectName: "Light Screen", tagType: ArenaTagType.LIGHT_SCREEN, move: Moves.WATER_GUN }, + { effectName: "Reflect", tagType: ArenaTagType.REFLECT, move: Moves.TACKLE }, + { effectName: "Aurora Veil", tagType: ArenaTagType.AURORA_VEIL, move: Moves.TACKLE } + ])("should bypass the target's $effectName", async ({ tagType, move }) => { + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const player = game.scene.getPlayerPokemon()!; + const enemy = game.scene.getEnemyPokemon()!; + + const preScreenDmg = enemy.getAttackDamage(player, allMoves[move]).damage; + + game.scene.arena.addTag(tagType, 1, Moves.NONE, enemy.id, ArenaTagSide.ENEMY, true); + + const postScreenDmg = enemy.getAttackDamage(player, allMoves[move]).damage; + + expect(postScreenDmg).toBe(preScreenDmg); + expect(player.battleData.abilitiesApplied[0]).toBe(Abilities.INFILTRATOR); + }); + + it("should bypass the target's Safeguard", async () => { + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const player = game.scene.getPlayerPokemon()!; + const enemy = game.scene.getEnemyPokemon()!; + + game.scene.arena.addTag(ArenaTagType.SAFEGUARD, 1, Moves.NONE, enemy.id, ArenaTagSide.ENEMY, true); + + game.move.select(Moves.SPORE); + + await game.phaseInterceptor.to("BerryPhase", false); + expect(enemy.status?.effect).toBe(StatusEffect.SLEEP); + expect(player.battleData.abilitiesApplied[0]).toBe(Abilities.INFILTRATOR); + }); + + // TODO: fix this interaction to pass this test + it.skip("should bypass the target's Mist", async () => { + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const player = game.scene.getPlayerPokemon()!; + const enemy = game.scene.getEnemyPokemon()!; + + game.scene.arena.addTag(ArenaTagType.MIST, 1, Moves.NONE, enemy.id, ArenaTagSide.ENEMY, true); + + game.move.select(Moves.BABY_DOLL_EYES); + + await game.phaseInterceptor.to("MoveEndPhase"); + expect(enemy.getStatStage(Stat.ATK)).toBe(-1); + expect(player.battleData.abilitiesApplied[0]).toBe(Abilities.INFILTRATOR); + }); + + it("should bypass the target's Substitute", async () => { + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const player = game.scene.getPlayerPokemon()!; + const enemy = game.scene.getEnemyPokemon()!; + + enemy.addTag(BattlerTagType.SUBSTITUTE, 1, Moves.NONE, enemy.id); + + game.move.select(Moves.BABY_DOLL_EYES); + + await game.phaseInterceptor.to("MoveEndPhase"); + expect(enemy.getStatStage(Stat.ATK)).toBe(-1); + expect(player.battleData.abilitiesApplied[0]).toBe(Abilities.INFILTRATOR); + }); +}); diff --git a/src/test/abilities/intimidate.test.ts b/src/test/abilities/intimidate.test.ts index d4c097022df..d5a37d06593 100644 --- a/src/test/abilities/intimidate.test.ts +++ b/src/test/abilities/intimidate.test.ts @@ -34,7 +34,7 @@ describe("Abilities - Intimidate", () => { }); it("should lower ATK stat stage by 1 of enemy Pokemon on entry and player switch", async () => { - await game.classicMode.runToSummon([Species.MIGHTYENA, Species.POOCHYENA]); + await game.classicMode.runToSummon([ Species.MIGHTYENA, Species.POOCHYENA ]); game.onNextPrompt( "CheckSwitchPhase", Mode.CONFIRM, @@ -66,7 +66,7 @@ describe("Abilities - Intimidate", () => { it("should lower ATK stat stage by 1 for every enemy Pokemon in a double battle on entry", async () => { game.override.battleType("double") .startingWave(3); - await game.classicMode.runToSummon([Species.MIGHTYENA, Species.POOCHYENA]); + await game.classicMode.runToSummon([ Species.MIGHTYENA, Species.POOCHYENA ]); game.onNextPrompt( "CheckSwitchPhase", Mode.CONFIRM, @@ -89,7 +89,7 @@ describe("Abilities - Intimidate", () => { it("should not activate again if there is no switch or new entry", async () => { game.override.startingWave(2); - game.override.moveset([Moves.SPLASH]); + game.override.moveset([ Moves.SPLASH ]); await game.classicMode.startBattle([ Species.MIGHTYENA, Species.POOCHYENA ]); const playerPokemon = game.scene.getPlayerPokemon()!; @@ -106,8 +106,8 @@ describe("Abilities - Intimidate", () => { }, 20000); it("should lower ATK stat stage by 1 for every switch", async () => { - game.override.moveset([Moves.SPLASH]) - .enemyMoveset([Moves.VOLT_SWITCH]) + game.override.moveset([ Moves.SPLASH ]) + .enemyMoveset([ Moves.VOLT_SWITCH ]) .startingWave(5); await game.classicMode.startBattle([ Species.MIGHTYENA, Species.POOCHYENA ]); diff --git a/src/test/abilities/libero.test.ts b/src/test/abilities/libero.test.ts index 51f182d5401..e7bc9eeeb63 100644 --- a/src/test/abilities/libero.test.ts +++ b/src/test/abilities/libero.test.ts @@ -1,6 +1,6 @@ import { allMoves } from "#app/data/move"; -import { Type } from "#app/data/type"; -import { Weather, WeatherType } from "#app/data/weather"; +import { Type } from "#enums/type"; +import { Weather } from "#app/data/weather"; import { PlayerPokemon } from "#app/field/pokemon"; import { TurnEndPhase } from "#app/phases/turn-end-phase"; import { Abilities } from "#enums/abilities"; @@ -8,11 +8,11 @@ import { BattlerTagType } from "#enums/battler-tag-type"; import { Biome } from "#enums/biome"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; +import { WeatherType } from "#enums/weather-type"; import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, test, vi } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Abilities - Libero", () => { let phaserGame: Phaser.Game; @@ -34,15 +34,15 @@ describe("Abilities - Libero", () => { game.override.ability(Abilities.LIBERO); game.override.startingLevel(100); game.override.enemySpecies(Species.RATTATA); - game.override.enemyMoveset([Moves.ENDURE, Moves.ENDURE, Moves.ENDURE, Moves.ENDURE]); + game.override.enemyMoveset([ Moves.ENDURE, Moves.ENDURE, Moves.ENDURE, Moves.ENDURE ]); }); test( "ability applies and changes a pokemon's type", async () => { - game.override.moveset([Moves.SPLASH]); + game.override.moveset([ Moves.SPLASH ]); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; expect(leadPokemon).not.toBe(undefined); @@ -52,15 +52,14 @@ describe("Abilities - Libero", () => { testPokemonTypeMatchesDefaultMoveType(leadPokemon, Moves.SPLASH); }, - TIMEOUT, ); test.skip( "ability applies only once per switch in", async () => { - game.override.moveset([Moves.SPLASH, Moves.AGILITY]); + game.override.moveset([ Moves.SPLASH, Moves.AGILITY ]); - await game.startBattle([Species.MAGIKARP, Species.BULBASAUR]); + await game.startBattle([ Species.MAGIKARP, Species.BULBASAUR ]); let leadPokemon = game.scene.getPlayerPokemon()!; expect(leadPokemon).not.toBe(undefined); @@ -92,15 +91,14 @@ describe("Abilities - Libero", () => { testPokemonTypeMatchesDefaultMoveType(leadPokemon, Moves.SPLASH); }, - TIMEOUT, ); test( "ability applies correctly even if the pokemon's move has a variable type", async () => { - game.override.moveset([Moves.WEATHER_BALL]); + game.override.moveset([ Moves.WEATHER_BALL ]); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; expect(leadPokemon).not.toBe(undefined); @@ -115,16 +113,15 @@ describe("Abilities - Libero", () => { moveType = Type[Type.FIRE]; expect(leadPokemonType).toBe(moveType); }, - TIMEOUT, ); test( "ability applies correctly even if the type has changed by another ability", async () => { - game.override.moveset([Moves.TACKLE]); + game.override.moveset([ Moves.TACKLE ]); game.override.passiveAbility(Abilities.REFRIGERATE); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; expect(leadPokemon).not.toBe(undefined); @@ -138,15 +135,14 @@ describe("Abilities - Libero", () => { moveType = Type[Type.ICE]; expect(leadPokemonType).toBe(moveType); }, - TIMEOUT, ); test( "ability applies correctly even if the pokemon's move calls another move", async () => { - game.override.moveset([Moves.NATURE_POWER]); + game.override.moveset([ Moves.NATURE_POWER ]); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; expect(leadPokemon).not.toBe(undefined); @@ -157,15 +153,14 @@ describe("Abilities - Libero", () => { testPokemonTypeMatchesDefaultMoveType(leadPokemon, Moves.AIR_SLASH); }, - TIMEOUT, ); test( "ability applies correctly even if the pokemon's move is delayed / charging", async () => { - game.override.moveset([Moves.DIG]); + game.override.moveset([ Moves.DIG ]); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; expect(leadPokemon).not.toBe(undefined); @@ -175,16 +170,15 @@ describe("Abilities - Libero", () => { testPokemonTypeMatchesDefaultMoveType(leadPokemon, Moves.DIG); }, - TIMEOUT, ); test( "ability applies correctly even if the pokemon's move misses", async () => { - game.override.moveset([Moves.TACKLE]); + game.override.moveset([ Moves.TACKLE ]); game.override.enemyMoveset(Moves.SPLASH); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; expect(leadPokemon).not.toBe(undefined); @@ -197,16 +191,15 @@ describe("Abilities - Libero", () => { expect(enemyPokemon.isFullHp()).toBe(true); testPokemonTypeMatchesDefaultMoveType(leadPokemon, Moves.TACKLE); }, - TIMEOUT, ); test( "ability applies correctly even if the pokemon's move is protected against", async () => { - game.override.moveset([Moves.TACKLE]); - game.override.enemyMoveset([Moves.PROTECT, Moves.PROTECT, Moves.PROTECT, Moves.PROTECT]); + game.override.moveset([ Moves.TACKLE ]); + game.override.enemyMoveset([ Moves.PROTECT, Moves.PROTECT, Moves.PROTECT, Moves.PROTECT ]); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; expect(leadPokemon).not.toBe(undefined); @@ -216,16 +209,15 @@ describe("Abilities - Libero", () => { testPokemonTypeMatchesDefaultMoveType(leadPokemon, Moves.TACKLE); }, - TIMEOUT, ); test( "ability applies correctly even if the pokemon's move fails because of type immunity", async () => { - game.override.moveset([Moves.TACKLE]); + game.override.moveset([ Moves.TACKLE ]); game.override.enemySpecies(Species.GASTLY); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; expect(leadPokemon).not.toBe(undefined); @@ -235,34 +227,32 @@ describe("Abilities - Libero", () => { testPokemonTypeMatchesDefaultMoveType(leadPokemon, Moves.TACKLE); }, - TIMEOUT, ); test( "ability is not applied if pokemon's type is the same as the move's type", async () => { - game.override.moveset([Moves.SPLASH]); + game.override.moveset([ Moves.SPLASH ]); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; expect(leadPokemon).not.toBe(undefined); - leadPokemon.summonData.types = [allMoves[Moves.SPLASH].type]; + leadPokemon.summonData.types = [ allMoves[Moves.SPLASH].type ]; game.move.select(Moves.SPLASH); await game.phaseInterceptor.to(TurnEndPhase); expect(leadPokemon.summonData.abilitiesApplied).not.toContain(Abilities.LIBERO); }, - TIMEOUT, ); test( "ability is not applied if pokemon is terastallized", async () => { - game.override.moveset([Moves.SPLASH]); + game.override.moveset([ Moves.SPLASH ]); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; expect(leadPokemon).not.toBe(undefined); @@ -274,15 +264,14 @@ describe("Abilities - Libero", () => { expect(leadPokemon.summonData.abilitiesApplied).not.toContain(Abilities.LIBERO); }, - TIMEOUT, ); test( "ability is not applied if pokemon uses struggle", async () => { - game.override.moveset([Moves.STRUGGLE]); + game.override.moveset([ Moves.STRUGGLE ]); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; expect(leadPokemon).not.toBe(undefined); @@ -292,15 +281,14 @@ describe("Abilities - Libero", () => { expect(leadPokemon.summonData.abilitiesApplied).not.toContain(Abilities.LIBERO); }, - TIMEOUT, ); test( "ability is not applied if the pokemon's move fails", async () => { - game.override.moveset([Moves.BURN_UP]); + game.override.moveset([ Moves.BURN_UP ]); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; expect(leadPokemon).not.toBe(undefined); @@ -310,16 +298,15 @@ describe("Abilities - Libero", () => { expect(leadPokemon.summonData.abilitiesApplied).not.toContain(Abilities.LIBERO); }, - TIMEOUT, ); test( "ability applies correctly even if the pokemon's Trick-or-Treat fails", async () => { - game.override.moveset([Moves.TRICK_OR_TREAT]); + game.override.moveset([ Moves.TRICK_OR_TREAT ]); game.override.enemySpecies(Species.GASTLY); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; expect(leadPokemon).not.toBe(undefined); @@ -329,15 +316,14 @@ describe("Abilities - Libero", () => { testPokemonTypeMatchesDefaultMoveType(leadPokemon, Moves.TRICK_OR_TREAT); }, - TIMEOUT, ); test( "ability applies correctly and the pokemon curses itself", async () => { - game.override.moveset([Moves.CURSE]); + game.override.moveset([ Moves.CURSE ]); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; expect(leadPokemon).not.toBe(undefined); @@ -348,7 +334,6 @@ describe("Abilities - Libero", () => { testPokemonTypeMatchesDefaultMoveType(leadPokemon, Moves.CURSE); expect(leadPokemon.getTag(BattlerTagType.CURSED)).not.toBe(undefined); }, - TIMEOUT, ); }); diff --git a/src/test/abilities/magic_guard.test.ts b/src/test/abilities/magic_guard.test.ts index 4b3fb0ba985..7c038354748 100644 --- a/src/test/abilities/magic_guard.test.ts +++ b/src/test/abilities/magic_guard.test.ts @@ -1,18 +1,17 @@ import { ArenaTagSide, getArenaTag } from "#app/data/arena-tag"; -import { StatusEffect, getStatusEffectCatchRateMultiplier } from "#app/data/status-effect"; -import { WeatherType } from "#app/data/weather"; +import { getStatusEffectCatchRateMultiplier } from "#app/data/status-effect"; import { TurnEndPhase } from "#app/phases/turn-end-phase"; import { Abilities } from "#enums/abilities"; import { ArenaTagType } from "#enums/arena-tag-type"; import { BattlerTagType } from "#enums/battler-tag-type"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; +import { StatusEffect } from "#enums/status-effect"; +import { WeatherType } from "#enums/weather-type"; import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; -const TIMEOUT = 20 * 1000; // 20 sec timeout - describe("Abilities - Magic Guard", () => { let phaserGame: Phaser.Game; let game: GameManager; @@ -32,7 +31,7 @@ describe("Abilities - Magic Guard", () => { /** Player Pokemon overrides */ game.override.ability(Abilities.MAGIC_GUARD); - game.override.moveset([Moves.SPLASH]); + game.override.moveset([ Moves.SPLASH ]); game.override.startingLevel(100); /** Enemy Pokemon overrides */ @@ -49,7 +48,7 @@ describe("Abilities - Magic Guard", () => { async () => { game.override.weather(WeatherType.SANDSTORM); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -67,7 +66,7 @@ describe("Abilities - Magic Guard", () => { */ expect(leadPokemon.hp).toBe(leadPokemon.getMaxHp()); expect(enemyPokemon.hp).toBeLessThan(enemyPokemon.getMaxHp()); - }, TIMEOUT + } ); it( @@ -76,7 +75,7 @@ describe("Abilities - Magic Guard", () => { //Toxic keeps track of the turn counters -> important that Magic Guard keeps track of post-Toxic turns game.override.statusEffect(StatusEffect.POISON); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -91,16 +90,16 @@ describe("Abilities - Magic Guard", () => { */ expect(leadPokemon.hp).toBe(leadPokemon.getMaxHp()); expect(getStatusEffectCatchRateMultiplier(leadPokemon.status!.effect)).toBe(1.5); - }, TIMEOUT + } ); it( "ability effect should not persist when the ability is replaced", async () => { - game.override.enemyMoveset([Moves.WORRY_SEED, Moves.WORRY_SEED, Moves.WORRY_SEED, Moves.WORRY_SEED]); + game.override.enemyMoveset([ Moves.WORRY_SEED, Moves.WORRY_SEED, Moves.WORRY_SEED, Moves.WORRY_SEED ]); game.override.statusEffect(StatusEffect.POISON); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -113,7 +112,7 @@ describe("Abilities - Magic Guard", () => { * - The player Pokemon (that just lost its Magic Guard ability) has taken damage from poison */ expect(leadPokemon.hp).toBeLessThan(leadPokemon.getMaxHp()); - }, TIMEOUT + } ); @@ -122,7 +121,7 @@ describe("Abilities - Magic Guard", () => { game.override.enemyStatusEffect(StatusEffect.BURN); game.override.enemyAbility(Abilities.MAGIC_GUARD); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); game.move.select(Moves.SPLASH); @@ -138,7 +137,7 @@ describe("Abilities - Magic Guard", () => { */ expect(enemyPokemon.hp).toBe(enemyPokemon.getMaxHp()); expect(getStatusEffectCatchRateMultiplier(enemyPokemon.status!.effect)).toBe(1.5); - }, TIMEOUT + } ); it("Magic Guard prevents damage caused by toxic but other non-damaging effects are still applied", @@ -146,13 +145,13 @@ describe("Abilities - Magic Guard", () => { game.override.enemyStatusEffect(StatusEffect.TOXIC); game.override.enemyAbility(Abilities.MAGIC_GUARD); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); game.move.select(Moves.SPLASH); const enemyPokemon = game.scene.getEnemyPokemon()!; - const toxicStartCounter = enemyPokemon.status!.turnCount; + const toxicStartCounter = enemyPokemon.status!.toxicTurnCount; //should be 0 await game.phaseInterceptor.to(TurnEndPhase); @@ -164,9 +163,9 @@ describe("Abilities - Magic Guard", () => { * - The enemy Pokemon's hypothetical CatchRateMultiplier should be 1.5 */ expect(enemyPokemon.hp).toBe(enemyPokemon.getMaxHp()); - expect(enemyPokemon.status!.turnCount).toBeGreaterThan(toxicStartCounter); + expect(enemyPokemon.status!.toxicTurnCount).toBeGreaterThan(toxicStartCounter); expect(getStatusEffectCatchRateMultiplier(enemyPokemon.status!.effect)).toBe(1.5); - }, TIMEOUT + } ); @@ -175,7 +174,7 @@ describe("Abilities - Magic Guard", () => { const newTag = getArenaTag(ArenaTagType.SPIKES, 5, Moves.SPIKES, 0, 0, ArenaTagSide.BOTH)!; game.scene.arena.tags.push(newTag); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; game.move.select(Moves.SPLASH); @@ -191,7 +190,7 @@ describe("Abilities - Magic Guard", () => { */ expect(leadPokemon.hp).toBe(leadPokemon.getMaxHp()); expect(enemyPokemon.hp).toBeLessThan(enemyPokemon.getMaxHp()); - }, TIMEOUT + } ); it("Magic Guard does not prevent poison from Toxic Spikes", async () => { @@ -201,7 +200,7 @@ describe("Abilities - Magic Guard", () => { game.scene.arena.tags.push(playerTag); game.scene.arena.tags.push(enemyTag); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; game.move.select(Moves.SPLASH); @@ -220,13 +219,13 @@ describe("Abilities - Magic Guard", () => { expect(enemyPokemon.status!.effect).toBe(StatusEffect.POISON); expect(leadPokemon.hp).toBe(leadPokemon.getMaxHp()); expect(enemyPokemon.hp).toBeLessThan(enemyPokemon.getMaxHp()); - }, TIMEOUT + } ); it("Magic Guard prevents against damage from volatile status effects", async () => { - await game.startBattle([Species.DUSKULL]); - game.override.moveset([Moves.CURSE]); + await game.startBattle([ Species.DUSKULL ]); + game.override.moveset([ Moves.CURSE ]); game.override.enemyAbility(Abilities.MAGIC_GUARD); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -246,12 +245,12 @@ describe("Abilities - Magic Guard", () => { expect(leadPokemon.hp).toBeLessThan(leadPokemon.getMaxHp()); expect(enemyPokemon.getTag(BattlerTagType.CURSED)).not.toBe(undefined); expect(enemyPokemon.hp).toBe(enemyPokemon.getMaxHp()); - }, TIMEOUT + } ); it("Magic Guard prevents crash damage", async () => { - game.override.moveset([Moves.HIGH_JUMP_KICK]); - await game.startBattle([Species.MAGIKARP]); + game.override.moveset([ Moves.HIGH_JUMP_KICK ]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -265,12 +264,12 @@ describe("Abilities - Magic Guard", () => { * - The player Pokemon (with Magic Guard) misses High Jump Kick but does not lose HP as a result */ expect(leadPokemon.hp).toBe(leadPokemon.getMaxHp()); - }, TIMEOUT + } ); it("Magic Guard prevents damage from recoil", async () => { - game.override.moveset([Moves.TAKE_DOWN]); - await game.startBattle([Species.MAGIKARP]); + game.override.moveset([ Moves.TAKE_DOWN ]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -283,12 +282,12 @@ describe("Abilities - Magic Guard", () => { * - The player Pokemon (with Magic Guard) uses a recoil move but does not lose HP from recoil */ expect(leadPokemon.hp).toBe(leadPokemon.getMaxHp()); - }, TIMEOUT + } ); it("Magic Guard does not prevent damage from Struggle's recoil", async () => { - game.override.moveset([Moves.STRUGGLE]); - await game.startBattle([Species.MAGIKARP]); + game.override.moveset([ Moves.STRUGGLE ]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -301,13 +300,13 @@ describe("Abilities - Magic Guard", () => { * - The player Pokemon (with Magic Guard) uses Struggle but does lose HP from Struggle's recoil */ expect(leadPokemon.hp).toBeLessThan(leadPokemon.getMaxHp()); - }, TIMEOUT + } ); //This tests different move attributes than the recoil tests above it("Magic Guard prevents self-damage from attacking moves", async () => { - game.override.moveset([Moves.STEEL_BEAM]); - await game.startBattle([Species.MAGIKARP]); + game.override.moveset([ Moves.STEEL_BEAM ]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -320,7 +319,7 @@ describe("Abilities - Magic Guard", () => { * - The player Pokemon (with Magic Guard) uses a move with an HP cost but does not lose HP from using it */ expect(leadPokemon.hp).toBe(leadPokemon.getMaxHp()); - }, TIMEOUT + } ); /* @@ -334,8 +333,8 @@ describe("Abilities - Magic Guard", () => { */ it("Magic Guard does not prevent self-damage from non-attacking moves", async () => { - game.override.moveset([Moves.BELLY_DRUM]); - await game.startBattle([Species.MAGIKARP]); + game.override.moveset([ Moves.BELLY_DRUM ]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -348,17 +347,17 @@ describe("Abilities - Magic Guard", () => { * - The player Pokemon (with Magic Guard) uses a non-attacking move with an HP cost and thus loses HP from using it */ expect(leadPokemon.hp).toBeLessThan(leadPokemon.getMaxHp()); - }, TIMEOUT + } ); it("Magic Guard prevents damage from abilities with PostTurnHurtIfSleepingAbAttr", async () => { //Tests the ability Bad Dreams game.override.statusEffect(StatusEffect.SLEEP); //enemy pokemon is given Spore just in case player pokemon somehow awakens during test - game.override.enemyMoveset([Moves.SPORE, Moves.SPORE, Moves.SPORE, Moves.SPORE]); + game.override.enemyMoveset([ Moves.SPORE, Moves.SPORE, Moves.SPORE, Moves.SPORE ]); game.override.enemyAbility(Abilities.BAD_DREAMS); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -373,15 +372,15 @@ describe("Abilities - Magic Guard", () => { */ expect(leadPokemon.hp).toBe(leadPokemon.getMaxHp()); expect(leadPokemon.status!.effect).toBe(StatusEffect.SLEEP); - }, TIMEOUT + } ); it("Magic Guard prevents damage from abilities with PostFaintContactDamageAbAttr", async () => { //Tests the abilities Innards Out/Aftermath - game.override.moveset([Moves.TACKLE]); + game.override.moveset([ Moves.TACKLE ]); game.override.enemyAbility(Abilities.AFTERMATH); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -398,15 +397,15 @@ describe("Abilities - Magic Guard", () => { */ expect(enemyPokemon.hp).toBe(0); expect(leadPokemon.hp).toBe(leadPokemon.getMaxHp()); - }, TIMEOUT + } ); it("Magic Guard prevents damage from abilities with PostDefendContactDamageAbAttr", async () => { //Tests the abilities Iron Barbs/Rough Skin - game.override.moveset([Moves.TACKLE]); + game.override.moveset([ Moves.TACKLE ]); game.override.enemyAbility(Abilities.IRON_BARBS); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -422,15 +421,15 @@ describe("Abilities - Magic Guard", () => { */ expect(enemyPokemon.hp).toBeLessThan(enemyPokemon.getMaxHp()); expect(leadPokemon.hp).toBe(leadPokemon.getMaxHp()); - }, TIMEOUT + } ); it("Magic Guard prevents damage from abilities with ReverseDrainAbAttr", async () => { //Tests the ability Liquid Ooze - game.override.moveset([Moves.ABSORB]); + game.override.moveset([ Moves.ABSORB ]); game.override.enemyAbility(Abilities.LIQUID_OOZE); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -446,7 +445,7 @@ describe("Abilities - Magic Guard", () => { */ expect(enemyPokemon.hp).toBeLessThan(enemyPokemon.getMaxHp()); expect(leadPokemon.hp).toBe(leadPokemon.getMaxHp()); - }, TIMEOUT + } ); it("Magic Guard prevents HP loss from abilities with PostWeatherLapseDamageAbAttr", async () => { @@ -454,7 +453,7 @@ describe("Abilities - Magic Guard", () => { game.override.passiveAbility(Abilities.SOLAR_POWER); game.override.weather(WeatherType.SUNNY); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; game.move.select(Moves.SPLASH); await game.phaseInterceptor.to(TurnEndPhase); @@ -464,6 +463,6 @@ describe("Abilities - Magic Guard", () => { * - The player Pokemon (with Magic Guard) should not lose HP due to this ability attribute */ expect(leadPokemon.hp).toBe(leadPokemon.getMaxHp()); - }, TIMEOUT + } ); }); diff --git a/src/test/abilities/mimicry.test.ts b/src/test/abilities/mimicry.test.ts new file mode 100644 index 00000000000..29aa1d649d3 --- /dev/null +++ b/src/test/abilities/mimicry.test.ts @@ -0,0 +1,91 @@ +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import { Type } from "#enums/type"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; + +describe("Abilities - Mimicry", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.SPLASH ]) + .ability(Abilities.MIMICRY) + .battleType("single") + .disableCrits() + .enemySpecies(Species.MAGIKARP) + .enemyMoveset(Moves.SPLASH); + }); + + it("Mimicry activates after the Pokémon with Mimicry is switched in while terrain is present, or whenever there is a change in terrain", async () => { + game.override.enemyAbility(Abilities.MISTY_SURGE); + await game.classicMode.startBattle([ Species.FEEBAS, Species.ABRA ]); + + const [ playerPokemon1, playerPokemon2 ] = game.scene.getPlayerParty(); + game.move.select(Moves.SPLASH); + await game.toNextTurn(); + expect(playerPokemon1.getTypes().includes(Type.FAIRY)).toBe(true); + + game.doSwitchPokemon(1); + await game.toNextTurn(); + + expect(playerPokemon2.getTypes().includes(Type.FAIRY)).toBe(true); + }); + + it("Pokemon should revert back to its original, root type once terrain ends", async () => { + game.override + .moveset([ Moves.SPLASH, Moves.TRANSFORM ]) + .enemyAbility(Abilities.MIMICRY) + .enemyMoveset([ Moves.SPLASH, Moves.PSYCHIC_TERRAIN ]); + await game.classicMode.startBattle([ Species.REGIELEKI ]); + + const playerPokemon = game.scene.getPlayerPokemon(); + game.move.select(Moves.TRANSFORM); + await game.forceEnemyMove(Moves.PSYCHIC_TERRAIN); + await game.toNextTurn(); + expect(playerPokemon?.getTypes().includes(Type.PSYCHIC)).toBe(true); + + if (game.scene.arena.terrain) { + game.scene.arena.terrain.turnsLeft = 1; + } + + game.move.select(Moves.SPLASH); + await game.forceEnemyMove(Moves.SPLASH); + await game.toNextTurn(); + expect(playerPokemon?.getTypes().includes(Type.ELECTRIC)).toBe(true); + }); + + it("If the Pokemon is under the effect of a type-adding move and an equivalent terrain activates, the move's effect disappears", async () => { + game.override + .enemyMoveset([ Moves.FORESTS_CURSE, Moves.GRASSY_TERRAIN ]); + await game.classicMode.startBattle([ Species.FEEBAS ]); + + const playerPokemon = game.scene.getPlayerPokemon(); + game.move.select(Moves.SPLASH); + await game.forceEnemyMove(Moves.FORESTS_CURSE); + await game.toNextTurn(); + + expect(playerPokemon?.summonData.addedType).toBe(Type.GRASS); + + game.move.select(Moves.SPLASH); + await game.forceEnemyMove(Moves.GRASSY_TERRAIN); + await game.phaseInterceptor.to("TurnEndPhase"); + + expect(playerPokemon?.summonData.addedType).toBeNull(); + expect(playerPokemon?.getTypes().includes(Type.GRASS)).toBe(true); + }); +}); diff --git a/src/test/abilities/mycelium_might.test.ts b/src/test/abilities/mycelium_might.test.ts index d8947935880..0c8e7b5a703 100644 --- a/src/test/abilities/mycelium_might.test.ts +++ b/src/test/abilities/mycelium_might.test.ts @@ -28,9 +28,9 @@ describe("Abilities - Mycelium Might", () => { game.override.disableCrits(); game.override.enemySpecies(Species.SHUCKLE); game.override.enemyAbility(Abilities.CLEAR_BODY); - game.override.enemyMoveset([Moves.QUICK_ATTACK, Moves.QUICK_ATTACK, Moves.QUICK_ATTACK, Moves.QUICK_ATTACK]); + game.override.enemyMoveset([ Moves.QUICK_ATTACK, Moves.QUICK_ATTACK, Moves.QUICK_ATTACK, Moves.QUICK_ATTACK ]); game.override.ability(Abilities.MYCELIUM_MIGHT); - game.override.moveset([Moves.QUICK_ATTACK, Moves.BABY_DOLL_EYES]); + game.override.moveset([ Moves.QUICK_ATTACK, Moves.BABY_DOLL_EYES ]); }); /** @@ -41,7 +41,7 @@ describe("Abilities - Mycelium Might", () => { **/ it("will move last in its priority bracket and ignore protective abilities", async () => { - await game.startBattle([Species.REGIELEKI]); + await game.startBattle([ Species.REGIELEKI ]); const enemyPokemon = game.scene.getEnemyPokemon(); const playerIndex = game.scene.getPlayerPokemon()?.getBattlerIndex(); @@ -55,8 +55,8 @@ describe("Abilities - Mycelium Might", () => { const commandOrder = phase.getCommandOrder(); // The opponent Pokemon (without Mycelium Might) goes first despite having lower speed than the player Pokemon. // The player Pokemon (with Mycelium Might) goes last despite having higher speed than the opponent. - expect(speedOrder).toEqual([playerIndex, enemyIndex]); - expect(commandOrder).toEqual([enemyIndex, playerIndex]); + expect(speedOrder).toEqual([ playerIndex, enemyIndex ]); + expect(commandOrder).toEqual([ enemyIndex, playerIndex ]); await game.phaseInterceptor.to(TurnEndPhase); // Despite the opponent's ability (Clear Body), its ATK stat stage is still reduced. @@ -64,8 +64,8 @@ describe("Abilities - Mycelium Might", () => { }, 20000); it("will still go first if a status move that is in a higher priority bracket than the opponent's move is used", async () => { - game.override.enemyMoveset([Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE]); - await game.startBattle([Species.REGIELEKI]); + game.override.enemyMoveset([ Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE ]); + await game.startBattle([ Species.REGIELEKI ]); const enemyPokemon = game.scene.getEnemyPokemon(); const playerIndex = game.scene.getPlayerPokemon()?.getBattlerIndex(); @@ -79,15 +79,15 @@ describe("Abilities - Mycelium Might", () => { const commandOrder = phase.getCommandOrder(); // The player Pokemon (with M.M.) goes first because its move is still within a higher priority bracket than its opponent. // The enemy Pokemon goes second because its move is in a lower priority bracket. - expect(speedOrder).toEqual([playerIndex, enemyIndex]); - expect(commandOrder).toEqual([playerIndex, enemyIndex]); + expect(speedOrder).toEqual([ playerIndex, enemyIndex ]); + expect(commandOrder).toEqual([ playerIndex, enemyIndex ]); await game.phaseInterceptor.to(TurnEndPhase); // Despite the opponent's ability (Clear Body), its ATK stat stage is still reduced. expect(enemyPokemon?.getStatStage(Stat.ATK)).toBe(-1); }, 20000); it("will not affect non-status moves", async () => { - await game.startBattle([Species.REGIELEKI]); + await game.startBattle([ Species.REGIELEKI ]); const playerIndex = game.scene.getPlayerPokemon()!.getBattlerIndex(); const enemyIndex = game.scene.getEnemyPokemon()!.getBattlerIndex(); @@ -101,7 +101,7 @@ describe("Abilities - Mycelium Might", () => { // The player Pokemon (with M.M.) goes first because it has a higher speed and did not use a status move. // The enemy Pokemon (without M.M.) goes second because its speed is lower. // This means that the commandOrder should be identical to the speedOrder - expect(speedOrder).toEqual([playerIndex, enemyIndex]); - expect(commandOrder).toEqual([playerIndex, enemyIndex]); + expect(speedOrder).toEqual([ playerIndex, enemyIndex ]); + expect(commandOrder).toEqual([ playerIndex, enemyIndex ]); }, 20000); }); diff --git a/src/test/abilities/no_guard.test.ts b/src/test/abilities/no_guard.test.ts new file mode 100644 index 00000000000..b0b454dd560 --- /dev/null +++ b/src/test/abilities/no_guard.test.ts @@ -0,0 +1,67 @@ +import { BattlerIndex } from "#app/battle"; +import { MoveEffectPhase } from "#app/phases/move-effect-phase"; +import { MoveEndPhase } from "#app/phases/move-end-phase"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, it, expect, vi } from "vitest"; + +describe("Abilities - No Guard", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset(Moves.ZAP_CANNON) + .ability(Abilities.NO_GUARD) + .enemyLevel(200) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.SPLASH); + }); + + it("should make moves always hit regardless of move accuracy", async () => { + game.override.battleType("single"); + + await game.classicMode.startBattle([ + Species.REGIELEKI + ]); + + game.move.select(Moves.ZAP_CANNON); + + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + + await game.phaseInterceptor.to(MoveEffectPhase, false); + + const moveEffectPhase = game.scene.getCurrentPhase() as MoveEffectPhase; + vi.spyOn(moveEffectPhase, "hitCheck"); + + await game.phaseInterceptor.to(MoveEndPhase); + + expect(moveEffectPhase.hitCheck).toHaveReturnedWith(true); + }); + + it("should guarantee double battle with any one LURE", async () => { + game.override + .startingModifier([ + { name: "LURE" }, + ]) + .startingWave(2); + + await game.classicMode.startBattle(); + + expect(game.scene.getEnemyField().length).toBe(2); + }); +}); diff --git a/src/test/abilities/parental_bond.test.ts b/src/test/abilities/parental_bond.test.ts index 2ad3f9e3f5c..10048a774cd 100644 --- a/src/test/abilities/parental_bond.test.ts +++ b/src/test/abilities/parental_bond.test.ts @@ -1,16 +1,15 @@ -import { Stat } from "#enums/stat"; -import { StatusEffect } from "#app/data/status-effect"; -import { Type } from "#app/data/type"; +import { Type } from "#enums/type"; import { BattlerTagType } from "#app/enums/battler-tag-type"; import { toDmgValue } from "#app/utils"; import { Abilities } from "#enums/abilities"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; +import { Stat } from "#enums/stat"; +import { StatusEffect } from "#enums/status-effect"; import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Abilities - Parental Bond", () => { let phaserGame: Phaser.Game; @@ -41,9 +40,9 @@ describe("Abilities - Parental Bond", () => { it( "should add second strike to attack move", async () => { - game.override.moveset([Moves.TACKLE]); + game.override.moveset([ Moves.TACKLE ]); - await game.classicMode.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -62,16 +61,16 @@ describe("Abilities - Parental Bond", () => { expect(leadPokemon.turnData.hitCount).toBe(2); expect(secondStrikeDamage).toBe(toDmgValue(0.25 * firstStrikeDamage)); - }, TIMEOUT + } ); it( "should apply secondary effects to both strikes", async () => { - game.override.moveset([Moves.POWER_UP_PUNCH]); + game.override.moveset([ Moves.POWER_UP_PUNCH ]); game.override.enemySpecies(Species.AMOONGUSS); - await game.classicMode.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -81,15 +80,15 @@ describe("Abilities - Parental Bond", () => { expect(leadPokemon.turnData.hitCount).toBe(2); expect(leadPokemon.getStatStage(Stat.ATK)).toBe(2); - }, TIMEOUT + } ); it( "should not apply to Status moves", async () => { - game.override.moveset([Moves.BABY_DOLL_EYES]); + game.override.moveset([ Moves.BABY_DOLL_EYES ]); - await game.classicMode.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -98,15 +97,15 @@ describe("Abilities - Parental Bond", () => { await game.phaseInterceptor.to("BerryPhase", false); expect(enemyPokemon.getStatStage(Stat.ATK)).toBe(-1); - }, TIMEOUT + } ); it( "should not apply to multi-hit moves", async () => { - game.override.moveset([Moves.DOUBLE_HIT]); + game.override.moveset([ Moves.DOUBLE_HIT ]); - await game.classicMode.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -116,15 +115,15 @@ describe("Abilities - Parental Bond", () => { await game.phaseInterceptor.to("BerryPhase", false); expect(leadPokemon.turnData.hitCount).toBe(2); - }, TIMEOUT + } ); it( "should not apply to self-sacrifice moves", async () => { - game.override.moveset([Moves.SELF_DESTRUCT]); + game.override.moveset([ Moves.SELF_DESTRUCT ]); - await game.classicMode.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -133,15 +132,15 @@ describe("Abilities - Parental Bond", () => { await game.phaseInterceptor.to("DamagePhase", false); expect(leadPokemon.turnData.hitCount).toBe(1); - }, TIMEOUT + } ); it( "should not apply to Rollout", async () => { - game.override.moveset([Moves.ROLLOUT]); + game.override.moveset([ Moves.ROLLOUT ]); - await game.classicMode.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -151,15 +150,15 @@ describe("Abilities - Parental Bond", () => { await game.phaseInterceptor.to("DamagePhase", false); expect(leadPokemon.turnData.hitCount).toBe(1); - }, TIMEOUT + } ); it( "should not apply multiplier to fixed-damage moves", async () => { - game.override.moveset([Moves.DRAGON_RAGE]); + game.override.moveset([ Moves.DRAGON_RAGE ]); - await game.classicMode.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -167,16 +166,16 @@ describe("Abilities - Parental Bond", () => { await game.phaseInterceptor.to("BerryPhase", false); expect(enemyPokemon.hp).toBe(enemyPokemon.getMaxHp() - 80); - }, TIMEOUT + } ); it( "should not apply multiplier to counter moves", async () => { - game.override.moveset([Moves.COUNTER]); - game.override.enemyMoveset([Moves.TACKLE]); + game.override.moveset([ Moves.COUNTER ]); + game.override.enemyMoveset([ Moves.TACKLE ]); - await game.classicMode.startBattle([Species.SHUCKLE]); + await game.classicMode.startBattle([ Species.SHUCKLE ]); const leadPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -189,17 +188,17 @@ describe("Abilities - Parental Bond", () => { await game.phaseInterceptor.to("BerryPhase", false); expect(enemyPokemon.hp).toBe(enemyPokemon.getMaxHp() - 4 * playerDamage); - }, TIMEOUT + } ); it( "should not apply to multi-target moves", async () => { game.override.battleType("double"); - game.override.moveset([Moves.EARTHQUAKE]); + game.override.moveset([ Moves.EARTHQUAKE ]); game.override.passiveAbility(Abilities.LEVITATE); - await game.classicMode.startBattle([Species.MAGIKARP, Species.FEEBAS]); + await game.classicMode.startBattle([ Species.MAGIKARP, Species.FEEBAS ]); const playerPokemon = game.scene.getPlayerField(); @@ -209,15 +208,15 @@ describe("Abilities - Parental Bond", () => { await game.phaseInterceptor.to("BerryPhase", false); playerPokemon.forEach(p => expect(p.turnData.hitCount).toBe(1)); - }, TIMEOUT + } ); it( "should apply to multi-target moves when hitting only one target", async () => { - game.override.moveset([Moves.EARTHQUAKE]); + game.override.moveset([ Moves.EARTHQUAKE ]); - await game.classicMode.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -225,15 +224,15 @@ describe("Abilities - Parental Bond", () => { await game.phaseInterceptor.to("DamagePhase", false); expect(leadPokemon.turnData.hitCount).toBe(2); - }, TIMEOUT + } ); it( "should only trigger post-target move effects once", async () => { - game.override.moveset([Moves.MIND_BLOWN]); + game.override.moveset([ Moves.MIND_BLOWN ]); - await game.classicMode.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -247,15 +246,15 @@ describe("Abilities - Parental Bond", () => { await game.phaseInterceptor.to("BerryPhase", false); expect(leadPokemon.hp).toBe(Math.ceil(leadPokemon.getMaxHp() / 2)); - }, TIMEOUT + } ); it( "Burn Up only removes type after the second strike", async () => { - game.override.moveset([Moves.BURN_UP]); + game.override.moveset([ Moves.BURN_UP ]); - await game.classicMode.startBattle([Species.CHARIZARD]); + await game.classicMode.startBattle([ Species.CHARIZARD ]); const leadPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -271,16 +270,16 @@ describe("Abilities - Parental Bond", () => { await game.phaseInterceptor.to("BerryPhase", false); expect(leadPokemon.isOfType(Type.FIRE)).toBe(false); - }, TIMEOUT + } ); it( - "Moves boosted by this ability and Multi-Lens should strike 4 times", + "Moves boosted by this ability and Multi-Lens should strike 3 times", async () => { - game.override.moveset([Moves.TACKLE]); + game.override.moveset([ Moves.TACKLE ]); game.override.startingHeldItems([{ name: "MULTI_LENS", count: 1 }]); - await game.classicMode.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -288,41 +287,17 @@ describe("Abilities - Parental Bond", () => { await game.phaseInterceptor.to("DamagePhase"); - expect(leadPokemon.turnData.hitCount).toBe(4); - }, TIMEOUT + expect(leadPokemon.turnData.hitCount).toBe(3); + } ); it( - "Super Fang boosted by this ability and Multi-Lens should strike twice", + "Seismic Toss boosted by this ability and Multi-Lens should strike 3 times", async () => { - game.override.moveset([Moves.SUPER_FANG]); + game.override.moveset([ Moves.SEISMIC_TOSS ]); game.override.startingHeldItems([{ name: "MULTI_LENS", count: 1 }]); - await game.classicMode.startBattle([Species.MAGIKARP]); - - const leadPokemon = game.scene.getPlayerPokemon()!; - const enemyPokemon = game.scene.getEnemyPokemon()!; - - game.move.select(Moves.SUPER_FANG); - await game.move.forceHit(); - - await game.phaseInterceptor.to("DamagePhase"); - - expect(leadPokemon.turnData.hitCount).toBe(2); - - await game.phaseInterceptor.to("MoveEndPhase", false); - - expect(enemyPokemon.hp).toBe(Math.ceil(enemyPokemon.getMaxHp() * 0.25)); - }, TIMEOUT - ); - - it( - "Seismic Toss boosted by this ability and Multi-Lens should strike twice", - async () => { - game.override.moveset([Moves.SEISMIC_TOSS]); - game.override.startingHeldItems([{ name: "MULTI_LENS", count: 1 }]); - - await game.classicMode.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -334,20 +309,20 @@ describe("Abilities - Parental Bond", () => { await game.phaseInterceptor.to("DamagePhase"); - expect(leadPokemon.turnData.hitCount).toBe(2); + expect(leadPokemon.turnData.hitCount).toBe(3); await game.phaseInterceptor.to("MoveEndPhase", false); expect(enemyPokemon.hp).toBe(enemyStartingHp - 200); - }, TIMEOUT + } ); it( "Hyper Beam boosted by this ability should strike twice, then recharge", async () => { - game.override.moveset([Moves.HYPER_BEAM]); + game.override.moveset([ Moves.HYPER_BEAM ]); - await game.classicMode.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -362,15 +337,15 @@ describe("Abilities - Parental Bond", () => { await game.phaseInterceptor.to("TurnEndPhase"); expect(leadPokemon.getTag(BattlerTagType.RECHARGING)).toBeDefined(); - }, TIMEOUT + } ); it( "Anchor Shot boosted by this ability should only trap the target after the second hit", async () => { - game.override.moveset([Moves.ANCHOR_SHOT]); + game.override.moveset([ Moves.ANCHOR_SHOT ]); - await game.classicMode.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -389,15 +364,15 @@ describe("Abilities - Parental Bond", () => { await game.phaseInterceptor.to("TurnEndPhase"); expect(enemyPokemon.getTag(BattlerTagType.TRAPPED)).toBeDefined(); - }, TIMEOUT + } ); it( "Smack Down boosted by this ability should only ground the target after the second hit", async () => { - game.override.moveset([Moves.SMACK_DOWN]); + game.override.moveset([ Moves.SMACK_DOWN ]); - await game.classicMode.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -413,15 +388,15 @@ describe("Abilities - Parental Bond", () => { await game.phaseInterceptor.to("TurnEndPhase"); expect(enemyPokemon.getTag(BattlerTagType.IGNORE_FLYING)).toBeDefined(); - }, TIMEOUT + } ); it( "U-turn boosted by this ability should strike twice before forcing a switch", async () => { - game.override.moveset([Moves.U_TURN]); + game.override.moveset([ Moves.U_TURN ]); - await game.classicMode.startBattle([Species.MAGIKARP, Species.BLASTOISE]); + await game.classicMode.startBattle([ Species.MAGIKARP, Species.BLASTOISE ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -433,15 +408,15 @@ describe("Abilities - Parental Bond", () => { // This will cause this test to time out if the switch was forced on the first hit. await game.phaseInterceptor.to("MoveEffectPhase", false); - }, TIMEOUT + } ); it( "Wake-Up Slap boosted by this ability should only wake up the target after the second hit", async () => { - game.override.moveset([Moves.WAKE_UP_SLAP]).enemyStatusEffect(StatusEffect.SLEEP); + game.override.moveset([ Moves.WAKE_UP_SLAP ]).enemyStatusEffect(StatusEffect.SLEEP); - await game.classicMode.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -457,16 +432,16 @@ describe("Abilities - Parental Bond", () => { await game.phaseInterceptor.to("BerryPhase", false); expect(enemyPokemon.status?.effect).toBeUndefined(); - }, TIMEOUT + } ); it( "should not cause user to hit into King's Shield more than once", async () => { - game.override.moveset([Moves.TACKLE]); - game.override.enemyMoveset([Moves.KINGS_SHIELD]); + game.override.moveset([ Moves.TACKLE ]); + game.override.enemyMoveset([ Moves.KINGS_SHIELD ]); - await game.classicMode.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -475,16 +450,16 @@ describe("Abilities - Parental Bond", () => { await game.phaseInterceptor.to("BerryPhase", false); expect(leadPokemon.getStatStage(Stat.ATK)).toBe(-1); - }, TIMEOUT + } ); it( "should not cause user to hit into Storm Drain more than once", async () => { - game.override.moveset([Moves.WATER_GUN]); + game.override.moveset([ Moves.WATER_GUN ]); game.override.enemyAbility(Abilities.STORM_DRAIN); - await game.classicMode.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -493,32 +468,6 @@ describe("Abilities - Parental Bond", () => { await game.phaseInterceptor.to("BerryPhase", false); expect(enemyPokemon.getStatStage(Stat.SPATK)).toBe(1); - }, TIMEOUT - ); - - it( - "should not apply to multi-target moves with Multi-Lens", - async () => { - game.override.battleType("double"); - game.override.moveset([Moves.EARTHQUAKE, Moves.SPLASH]); - game.override.passiveAbility(Abilities.LEVITATE); - game.override.startingHeldItems([{ name: "MULTI_LENS", count: 1 }]); - - await game.classicMode.startBattle([Species.MAGIKARP, Species.FEEBAS]); - - const enemyPokemon = game.scene.getEnemyField(); - - const enemyStartingHp = enemyPokemon.map(p => p.hp); - - game.move.select(Moves.EARTHQUAKE); - game.move.select(Moves.SPLASH, 1); - - await game.phaseInterceptor.to("DamagePhase"); - const enemyFirstHitDamage = enemyStartingHp.map((hp, i) => hp - enemyPokemon[i].hp); - - await game.phaseInterceptor.to("BerryPhase", false); - - enemyPokemon.forEach((p, i) => expect(enemyStartingHp[i] - p.hp).toBe(2 * enemyFirstHitDamage[i])); - }, TIMEOUT + } ); }); diff --git a/src/test/abilities/pastel_veil.test.ts b/src/test/abilities/pastel_veil.test.ts index 31490aab143..dd8360493a1 100644 --- a/src/test/abilities/pastel_veil.test.ts +++ b/src/test/abilities/pastel_veil.test.ts @@ -1,10 +1,10 @@ import { BattlerIndex } from "#app/battle"; -import { StatusEffect } from "#app/data/status-effect"; import { Abilities } from "#app/enums/abilities"; import { CommandPhase } from "#app/phases/command-phase"; import { TurnEndPhase } from "#app/phases/turn-end-phase"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; +import { StatusEffect } from "#enums/status-effect"; import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; @@ -27,14 +27,14 @@ describe("Abilities - Pastel Veil", () => { game = new GameManager(phaserGame); game.override .battleType("double") - .moveset([Moves.TOXIC_THREAD, Moves.SPLASH]) + .moveset([ Moves.TOXIC_THREAD, Moves.SPLASH ]) .enemyAbility(Abilities.BALL_FETCH) .enemySpecies(Species.SUNKERN) .enemyMoveset(Moves.SPLASH); }); it("prevents the user and its allies from being afflicted by poison", async () => { - await game.startBattle([Species.MAGIKARP, Species.GALAR_PONYTA]); + await game.startBattle([ Species.MAGIKARP, Species.GALAR_PONYTA ]); const ponyta = game.scene.getPlayerField()[1]; const magikarp = game.scene.getPlayerField()[0]; ponyta.abilityIndex = 1; @@ -50,8 +50,8 @@ describe("Abilities - Pastel Veil", () => { }); it("it heals the poisoned status condition of allies if user is sent out into battle", async () => { - await game.startBattle([Species.MAGIKARP, Species.FEEBAS, Species.GALAR_PONYTA]); - const ponyta = game.scene.getParty()[2]; + await game.startBattle([ Species.MAGIKARP, Species.FEEBAS, Species.GALAR_PONYTA ]); + const ponyta = game.scene.getPlayerParty()[2]; const magikarp = game.scene.getPlayerField()[0]; ponyta.abilityIndex = 1; diff --git a/src/test/abilities/power_construct.test.ts b/src/test/abilities/power_construct.test.ts index ec37bc96c2f..aaab5ddb5c4 100644 --- a/src/test/abilities/power_construct.test.ts +++ b/src/test/abilities/power_construct.test.ts @@ -1,13 +1,13 @@ -import { Status, StatusEffect } from "#app/data/status-effect"; +import { Status } from "#app/data/status-effect"; import { QuietFormChangePhase } from "#app/phases/quiet-form-change-phase"; import { TurnEndPhase } from "#app/phases/turn-end-phase"; import { Abilities } from "#enums/abilities"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; +import { StatusEffect } from "#enums/status-effect"; import GameManager from "#test/utils/gameManager"; import { afterEach, beforeAll, beforeEach, describe, expect, test } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Abilities - POWER CONSTRUCT", () => { let phaserGame: Phaser.Game; @@ -28,12 +28,12 @@ describe("Abilities - POWER CONSTRUCT", () => { const moveToUse = Moves.SPLASH; game.override.battleType("single"); game.override.ability(Abilities.POWER_CONSTRUCT); - game.override.moveset([moveToUse]); - game.override.enemyMoveset([Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE]); + game.override.moveset([ moveToUse ]); + game.override.enemyMoveset([ Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE ]); }); test( - "check if fainted pokemon switches to base form on arena reset", + "check if fainted 50% Power Construct Pokemon switches to base form on arena reset", async () => { const baseForm = 2, completeForm = 4; @@ -42,9 +42,39 @@ describe("Abilities - POWER CONSTRUCT", () => { [Species.ZYGARDE]: completeForm, }); - await game.startBattle([Species.MAGIKARP, Species.ZYGARDE]); + await game.classicMode.startBattle([ Species.MAGIKARP, Species.ZYGARDE ]); - const zygarde = game.scene.getParty().find((p) => p.species.speciesId === Species.ZYGARDE); + const zygarde = game.scene.getPlayerParty().find((p) => p.species.speciesId === Species.ZYGARDE); + expect(zygarde).not.toBe(undefined); + expect(zygarde!.formIndex).toBe(completeForm); + + zygarde!.hp = 0; + zygarde!.status = new Status(StatusEffect.FAINT); + expect(zygarde!.isFainted()).toBe(true); + + game.move.select(Moves.SPLASH); + await game.doKillOpponents(); + await game.phaseInterceptor.to(TurnEndPhase); + game.doSelectModifier(); + await game.phaseInterceptor.to(QuietFormChangePhase); + + expect(zygarde!.formIndex).toBe(baseForm); + }, + ); + + test( + "check if fainted 10% Power Construct Pokemon switches to base form on arena reset", + async () => { + const baseForm = 3, + completeForm = 5; + game.override.startingWave(4); + game.override.starterForms({ + [Species.ZYGARDE]: completeForm, + }); + + await game.classicMode.startBattle([ Species.MAGIKARP, Species.ZYGARDE ]); + + const zygarde = game.scene.getPlayerParty().find((p) => p.species.speciesId === Species.ZYGARDE); expect(zygarde).not.toBe(undefined); expect(zygarde!.formIndex).toBe(completeForm); @@ -60,6 +90,5 @@ describe("Abilities - POWER CONSTRUCT", () => { expect(zygarde!.formIndex).toBe(baseForm); }, - TIMEOUT ); }); diff --git a/src/test/abilities/power_spot.test.ts b/src/test/abilities/power_spot.test.ts index 6d349a1a3f9..a566c2277c3 100644 --- a/src/test/abilities/power_spot.test.ts +++ b/src/test/abilities/power_spot.test.ts @@ -27,7 +27,7 @@ describe("Abilities - Power Spot", () => { beforeEach(() => { game = new GameManager(phaserGame); game.override.battleType("double"); - game.override.moveset([Moves.TACKLE, Moves.BREAKING_SWIPE, Moves.SPLASH, Moves.DAZZLING_GLEAM]); + game.override.moveset([ Moves.TACKLE, Moves.BREAKING_SWIPE, Moves.SPLASH, Moves.DAZZLING_GLEAM ]); game.override.enemyMoveset(Moves.SPLASH); game.override.enemySpecies(Species.SHUCKLE); game.override.enemyAbility(Abilities.BALL_FETCH); @@ -39,7 +39,7 @@ describe("Abilities - Power Spot", () => { vi.spyOn(moveToCheck, "calculateBattlePower"); - await game.startBattle([Species.REGIELEKI, Species.STONJOURNER]); + await game.startBattle([ Species.REGIELEKI, Species.STONJOURNER ]); game.move.select(Moves.DAZZLING_GLEAM); game.move.select(Moves.SPLASH, 1); await game.phaseInterceptor.to(MoveEffectPhase); @@ -53,7 +53,7 @@ describe("Abilities - Power Spot", () => { vi.spyOn(moveToCheck, "calculateBattlePower"); - await game.startBattle([Species.REGIELEKI, Species.STONJOURNER]); + await game.startBattle([ Species.REGIELEKI, Species.STONJOURNER ]); game.move.select(Moves.BREAKING_SWIPE); game.move.select(Moves.SPLASH, 1); await game.phaseInterceptor.to(MoveEffectPhase); @@ -67,7 +67,7 @@ describe("Abilities - Power Spot", () => { vi.spyOn(moveToCheck, "calculateBattlePower"); - await game.startBattle([Species.STONJOURNER, Species.REGIELEKI]); + await game.startBattle([ Species.STONJOURNER, Species.REGIELEKI ]); game.move.select(Moves.BREAKING_SWIPE); game.move.select(Moves.SPLASH, 1); await game.phaseInterceptor.to(TurnEndPhase); diff --git a/src/test/abilities/protean.test.ts b/src/test/abilities/protean.test.ts index 4be58a677a6..0d7202e3f6d 100644 --- a/src/test/abilities/protean.test.ts +++ b/src/test/abilities/protean.test.ts @@ -1,6 +1,6 @@ import { allMoves } from "#app/data/move"; -import { Type } from "#app/data/type"; -import { Weather, WeatherType } from "#app/data/weather"; +import { Type } from "#enums/type"; +import { Weather } from "#app/data/weather"; import { PlayerPokemon } from "#app/field/pokemon"; import { TurnEndPhase } from "#app/phases/turn-end-phase"; import { Abilities } from "#enums/abilities"; @@ -8,11 +8,11 @@ import { BattlerTagType } from "#enums/battler-tag-type"; import { Biome } from "#enums/biome"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; +import { WeatherType } from "#enums/weather-type"; import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, test, vi } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Abilities - Protean", () => { let phaserGame: Phaser.Game; @@ -34,15 +34,15 @@ describe("Abilities - Protean", () => { game.override.ability(Abilities.PROTEAN); game.override.startingLevel(100); game.override.enemySpecies(Species.RATTATA); - game.override.enemyMoveset([Moves.ENDURE, Moves.ENDURE, Moves.ENDURE, Moves.ENDURE]); + game.override.enemyMoveset([ Moves.ENDURE, Moves.ENDURE, Moves.ENDURE, Moves.ENDURE ]); }); test( "ability applies and changes a pokemon's type", async () => { - game.override.moveset([Moves.SPLASH]); + game.override.moveset([ Moves.SPLASH ]); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; expect(leadPokemon).not.toBe(undefined); @@ -52,15 +52,14 @@ describe("Abilities - Protean", () => { testPokemonTypeMatchesDefaultMoveType(leadPokemon, Moves.SPLASH); }, - TIMEOUT, ); test.skip( "ability applies only once per switch in", async () => { - game.override.moveset([Moves.SPLASH, Moves.AGILITY]); + game.override.moveset([ Moves.SPLASH, Moves.AGILITY ]); - await game.startBattle([Species.MAGIKARP, Species.BULBASAUR]); + await game.startBattle([ Species.MAGIKARP, Species.BULBASAUR ]); let leadPokemon = game.scene.getPlayerPokemon()!; expect(leadPokemon).not.toBe(undefined); @@ -92,15 +91,14 @@ describe("Abilities - Protean", () => { testPokemonTypeMatchesDefaultMoveType(leadPokemon, Moves.SPLASH); }, - TIMEOUT, ); test( "ability applies correctly even if the pokemon's move has a variable type", async () => { - game.override.moveset([Moves.WEATHER_BALL]); + game.override.moveset([ Moves.WEATHER_BALL ]); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; expect(leadPokemon).not.toBe(undefined); @@ -115,16 +113,15 @@ describe("Abilities - Protean", () => { moveType = Type[Type.FIRE]; expect(leadPokemonType).toBe(moveType); }, - TIMEOUT, ); test( "ability applies correctly even if the type has changed by another ability", async () => { - game.override.moveset([Moves.TACKLE]); + game.override.moveset([ Moves.TACKLE ]); game.override.passiveAbility(Abilities.REFRIGERATE); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; expect(leadPokemon).not.toBe(undefined); @@ -138,15 +135,14 @@ describe("Abilities - Protean", () => { moveType = Type[Type.ICE]; expect(leadPokemonType).toBe(moveType); }, - TIMEOUT, ); test( "ability applies correctly even if the pokemon's move calls another move", async () => { - game.override.moveset([Moves.NATURE_POWER]); + game.override.moveset([ Moves.NATURE_POWER ]); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; expect(leadPokemon).not.toBe(undefined); @@ -157,15 +153,14 @@ describe("Abilities - Protean", () => { testPokemonTypeMatchesDefaultMoveType(leadPokemon, Moves.AIR_SLASH); }, - TIMEOUT, ); test( "ability applies correctly even if the pokemon's move is delayed / charging", async () => { - game.override.moveset([Moves.DIG]); + game.override.moveset([ Moves.DIG ]); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; expect(leadPokemon).not.toBe(undefined); @@ -175,16 +170,15 @@ describe("Abilities - Protean", () => { testPokemonTypeMatchesDefaultMoveType(leadPokemon, Moves.DIG); }, - TIMEOUT, ); test( "ability applies correctly even if the pokemon's move misses", async () => { - game.override.moveset([Moves.TACKLE]); + game.override.moveset([ Moves.TACKLE ]); game.override.enemyMoveset(Moves.SPLASH); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; expect(leadPokemon).not.toBe(undefined); @@ -197,16 +191,15 @@ describe("Abilities - Protean", () => { expect(enemyPokemon.isFullHp()).toBe(true); testPokemonTypeMatchesDefaultMoveType(leadPokemon, Moves.TACKLE); }, - TIMEOUT, ); test( "ability applies correctly even if the pokemon's move is protected against", async () => { - game.override.moveset([Moves.TACKLE]); - game.override.enemyMoveset([Moves.PROTECT, Moves.PROTECT, Moves.PROTECT, Moves.PROTECT]); + game.override.moveset([ Moves.TACKLE ]); + game.override.enemyMoveset([ Moves.PROTECT, Moves.PROTECT, Moves.PROTECT, Moves.PROTECT ]); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; expect(leadPokemon).not.toBe(undefined); @@ -216,16 +209,15 @@ describe("Abilities - Protean", () => { testPokemonTypeMatchesDefaultMoveType(leadPokemon, Moves.TACKLE); }, - TIMEOUT, ); test( "ability applies correctly even if the pokemon's move fails because of type immunity", async () => { - game.override.moveset([Moves.TACKLE]); + game.override.moveset([ Moves.TACKLE ]); game.override.enemySpecies(Species.GASTLY); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; expect(leadPokemon).not.toBe(undefined); @@ -235,34 +227,32 @@ describe("Abilities - Protean", () => { testPokemonTypeMatchesDefaultMoveType(leadPokemon, Moves.TACKLE); }, - TIMEOUT, ); test( "ability is not applied if pokemon's type is the same as the move's type", async () => { - game.override.moveset([Moves.SPLASH]); + game.override.moveset([ Moves.SPLASH ]); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; expect(leadPokemon).not.toBe(undefined); - leadPokemon.summonData.types = [allMoves[Moves.SPLASH].type]; + leadPokemon.summonData.types = [ allMoves[Moves.SPLASH].type ]; game.move.select(Moves.SPLASH); await game.phaseInterceptor.to(TurnEndPhase); expect(leadPokemon.summonData.abilitiesApplied).not.toContain(Abilities.PROTEAN); }, - TIMEOUT, ); test( "ability is not applied if pokemon is terastallized", async () => { - game.override.moveset([Moves.SPLASH]); + game.override.moveset([ Moves.SPLASH ]); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; expect(leadPokemon).not.toBe(undefined); @@ -274,15 +264,14 @@ describe("Abilities - Protean", () => { expect(leadPokemon.summonData.abilitiesApplied).not.toContain(Abilities.PROTEAN); }, - TIMEOUT, ); test( "ability is not applied if pokemon uses struggle", async () => { - game.override.moveset([Moves.STRUGGLE]); + game.override.moveset([ Moves.STRUGGLE ]); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; expect(leadPokemon).not.toBe(undefined); @@ -292,15 +281,14 @@ describe("Abilities - Protean", () => { expect(leadPokemon.summonData.abilitiesApplied).not.toContain(Abilities.PROTEAN); }, - TIMEOUT, ); test( "ability is not applied if the pokemon's move fails", async () => { - game.override.moveset([Moves.BURN_UP]); + game.override.moveset([ Moves.BURN_UP ]); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; expect(leadPokemon).not.toBe(undefined); @@ -310,16 +298,15 @@ describe("Abilities - Protean", () => { expect(leadPokemon.summonData.abilitiesApplied).not.toContain(Abilities.PROTEAN); }, - TIMEOUT, ); test( "ability applies correctly even if the pokemon's Trick-or-Treat fails", async () => { - game.override.moveset([Moves.TRICK_OR_TREAT]); + game.override.moveset([ Moves.TRICK_OR_TREAT ]); game.override.enemySpecies(Species.GASTLY); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; expect(leadPokemon).not.toBe(undefined); @@ -329,15 +316,14 @@ describe("Abilities - Protean", () => { testPokemonTypeMatchesDefaultMoveType(leadPokemon, Moves.TRICK_OR_TREAT); }, - TIMEOUT, ); test( "ability applies correctly and the pokemon curses itself", async () => { - game.override.moveset([Moves.CURSE]); + game.override.moveset([ Moves.CURSE ]); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; expect(leadPokemon).not.toBe(undefined); @@ -348,7 +334,6 @@ describe("Abilities - Protean", () => { testPokemonTypeMatchesDefaultMoveType(leadPokemon, Moves.CURSE); expect(leadPokemon.getTag(BattlerTagType.CURSED)).not.toBe(undefined); }, - TIMEOUT, ); }); diff --git a/src/test/abilities/quick_draw.test.ts b/src/test/abilities/quick_draw.test.ts index a02ee5cf56a..4979152f4d6 100644 --- a/src/test/abilities/quick_draw.test.ts +++ b/src/test/abilities/quick_draw.test.ts @@ -27,12 +27,12 @@ describe("Abilities - Quick Draw", () => { game.override.starterSpecies(Species.MAGIKARP); game.override.ability(Abilities.QUICK_DRAW); - game.override.moveset([Moves.TACKLE, Moves.TAIL_WHIP]); + game.override.moveset([ Moves.TACKLE, Moves.TAIL_WHIP ]); game.override.enemyLevel(100); game.override.enemySpecies(Species.MAGIKARP); game.override.enemyAbility(Abilities.BALL_FETCH); - game.override.enemyMoveset([Moves.TACKLE]); + game.override.enemyMoveset([ Moves.TACKLE ]); vi.spyOn(allAbilities[Abilities.QUICK_DRAW].getAttrs(BypassSpeedChanceAbAttr)[0], "chance", "get").mockReturnValue(100); }); @@ -55,7 +55,6 @@ describe("Abilities - Quick Draw", () => { }, 20000); test("does not triggered by non damage moves", { - timeout: 20000, retry: 5 }, async () => { await game.startBattle(); @@ -76,7 +75,7 @@ describe("Abilities - Quick Draw", () => { ); test("does not increase priority", async () => { - game.override.enemyMoveset([Moves.EXTREME_SPEED]); + game.override.enemyMoveset([ Moves.EXTREME_SPEED ]); await game.startBattle(); diff --git a/src/test/abilities/sand_spit.test.ts b/src/test/abilities/sand_spit.test.ts index add13ede296..1c21cff3c14 100644 --- a/src/test/abilities/sand_spit.test.ts +++ b/src/test/abilities/sand_spit.test.ts @@ -31,11 +31,11 @@ describe("Abilities - Sand Spit", () => { game.override.starterSpecies(Species.SILICOBRA); game.override.ability(Abilities.SAND_SPIT); - game.override.moveset([Moves.SPLASH, Moves.COIL]); + game.override.moveset([ Moves.SPLASH, Moves.COIL ]); }); it("should trigger when hit with damaging move", async () => { - game.override.enemyMoveset([Moves.TACKLE]); + game.override.enemyMoveset([ Moves.TACKLE ]); await game.startBattle(); game.move.select(Moves.SPLASH); @@ -45,7 +45,7 @@ describe("Abilities - Sand Spit", () => { }, 20000); it("should not trigger when targetted with status moves", async () => { - game.override.enemyMoveset([Moves.GROWL]); + game.override.enemyMoveset([ Moves.GROWL ]); await game.startBattle(); game.move.select(Moves.COIL); diff --git a/src/test/abilities/sand_veil.test.ts b/src/test/abilities/sand_veil.test.ts index da9fdcc01ab..ee8ca450df9 100644 --- a/src/test/abilities/sand_veil.test.ts +++ b/src/test/abilities/sand_veil.test.ts @@ -1,17 +1,16 @@ import { StatMultiplierAbAttr, allAbilities } from "#app/data/ability"; -import { Stat } from "#enums/stat"; -import { WeatherType } from "#app/data/weather"; import { CommandPhase } from "#app/phases/command-phase"; import { MoveEffectPhase } from "#app/phases/move-effect-phase"; import { MoveEndPhase } from "#app/phases/move-end-phase"; import { Abilities } from "#enums/abilities"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; +import { Stat } from "#enums/stat"; +import { WeatherType } from "#enums/weather-type"; import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, test, vi } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Abilities - Sand Veil", () => { let phaserGame: Phaser.Game; @@ -29,10 +28,10 @@ describe("Abilities - Sand Veil", () => { beforeEach(() => { game = new GameManager(phaserGame); - game.override.moveset([Moves.SPLASH]); + game.override.moveset([ Moves.SPLASH ]); game.override.enemySpecies(Species.MEOWSCARADA); game.override.enemyAbility(Abilities.INSOMNIA); - game.override.enemyMoveset([Moves.TWISTER, Moves.TWISTER, Moves.TWISTER, Moves.TWISTER]); + game.override.enemyMoveset([ Moves.TWISTER, Moves.TWISTER, Moves.TWISTER, Moves.TWISTER ]); game.override.startingLevel(100); game.override.enemyLevel(100); game.override @@ -43,7 +42,7 @@ describe("Abilities - Sand Veil", () => { test( "ability should increase the evasiveness of the source", async () => { - await game.startBattle([Species.SNORLAX, Species.BLISSEY]); + await game.startBattle([ Species.SNORLAX, Species.BLISSEY ]); const leadPokemon = game.scene.getPlayerField(); @@ -75,6 +74,6 @@ describe("Abilities - Sand Veil", () => { expect(leadPokemon[0].isFullHp()).toBe(true); expect(leadPokemon[1].hp).toBeLessThan(leadPokemon[1].getMaxHp()); - }, TIMEOUT + } ); }); diff --git a/src/test/abilities/sap_sipper.test.ts b/src/test/abilities/sap_sipper.test.ts index 5e8cac74c95..dc254a54b54 100644 --- a/src/test/abilities/sap_sipper.test.ts +++ b/src/test/abilities/sap_sipper.test.ts @@ -8,7 +8,8 @@ import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; -import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; +import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; +import { allMoves, RandomMoveAttr } from "#app/data/move"; // See also: TypeImmunityAbAttr describe("Abilities - Sap Sipper", () => { @@ -27,20 +28,20 @@ describe("Abilities - Sap Sipper", () => { beforeEach(() => { game = new GameManager(phaserGame); - game.override.battleType("single"); - game.override.disableCrits(); + game.override.battleType("single") + .disableCrits() + .ability(Abilities.SAP_SIPPER) + .enemySpecies(Species.RATTATA) + .enemyAbility(Abilities.SAP_SIPPER) + .enemyMoveset(Moves.SPLASH); }); it("raises ATK stat stage by 1 and block effects when activated against a grass attack", async() => { const moveToUse = Moves.LEAFAGE; - const enemyAbility = Abilities.SAP_SIPPER; - game.override.moveset([ moveToUse ]); - game.override.enemyMoveset(Moves.SPLASH); - game.override.enemySpecies(Species.DUSKULL); - game.override.enemyAbility(enemyAbility); + game.override.moveset(moveToUse); - await game.startBattle(); + await game.classicMode.startBattle([ Species.BULBASAUR ]); const enemyPokemon = game.scene.getEnemyPokemon()!; const initialEnemyHp = enemyPokemon.hp; @@ -55,14 +56,10 @@ describe("Abilities - Sap Sipper", () => { it("raises ATK stat stage by 1 and block effects when activated against a grass status move", async() => { const moveToUse = Moves.SPORE; - const enemyAbility = Abilities.SAP_SIPPER; - game.override.moveset([ moveToUse ]); - game.override.enemyMoveset(Moves.SPLASH); - game.override.enemySpecies(Species.RATTATA); - game.override.enemyAbility(enemyAbility); + game.override.moveset(moveToUse); - await game.startBattle(); + await game.classicMode.startBattle([ Species.BULBASAUR ]); const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -76,14 +73,10 @@ describe("Abilities - Sap Sipper", () => { it("do not activate against status moves that target the field", async () => { const moveToUse = Moves.GRASSY_TERRAIN; - const enemyAbility = Abilities.SAP_SIPPER; - game.override.moveset([ moveToUse ]); - game.override.enemyMoveset(Moves.SPLASH); - game.override.enemySpecies(Species.RATTATA); - game.override.enemyAbility(enemyAbility); + game.override.moveset(moveToUse); - await game.startBattle(); + await game.classicMode.startBattle([ Species.BULBASAUR ]); game.move.select(moveToUse); @@ -96,14 +89,10 @@ describe("Abilities - Sap Sipper", () => { it("activate once against multi-hit grass attacks", async () => { const moveToUse = Moves.BULLET_SEED; - const enemyAbility = Abilities.SAP_SIPPER; - game.override.moveset([ moveToUse ]); - game.override.enemyMoveset(Moves.SPLASH); - game.override.enemySpecies(Species.RATTATA); - game.override.enemyAbility(enemyAbility); + game.override.moveset(moveToUse); - await game.startBattle(); + await game.classicMode.startBattle([ Species.BULBASAUR ]); const enemyPokemon = game.scene.getEnemyPokemon()!; const initialEnemyHp = enemyPokemon.hp; @@ -118,15 +107,10 @@ describe("Abilities - Sap Sipper", () => { it("do not activate against status moves that target the user", async () => { const moveToUse = Moves.SPIKY_SHIELD; - const ability = Abilities.SAP_SIPPER; - game.override.moveset([ moveToUse ]); - game.override.ability(ability); - game.override.enemyMoveset(Moves.SPLASH); - game.override.enemySpecies(Species.RATTATA); - game.override.enemyAbility(Abilities.NONE); + game.override.moveset(moveToUse); - await game.startBattle(); + await game.classicMode.startBattle([ Species.BULBASAUR ]); const playerPokemon = game.scene.getPlayerPokemon()!; @@ -142,18 +126,15 @@ describe("Abilities - Sap Sipper", () => { expect(game.phaseInterceptor.log).not.toContain("ShowAbilityPhase"); }); - // TODO Add METRONOME outcome override - // To run this testcase, manually modify the METRONOME move to always give SAP_SIPPER, then uncomment - it.todo("activate once against multi-hit grass attacks (metronome)", async () => { + it("activate once against multi-hit grass attacks (metronome)", async () => { const moveToUse = Moves.METRONOME; - const enemyAbility = Abilities.SAP_SIPPER; - game.override.moveset([moveToUse]); - game.override.enemyMoveset([Moves.SPLASH, Moves.NONE, Moves.NONE, Moves.NONE]); - game.override.enemySpecies(Species.RATTATA); - game.override.enemyAbility(enemyAbility); + const randomMoveAttr = allMoves[Moves.METRONOME].findAttr(attr => attr instanceof RandomMoveAttr) as RandomMoveAttr; + vi.spyOn(randomMoveAttr, "getMoveOverride").mockReturnValue(Moves.BULLET_SEED); - await game.startBattle(); + game.override.moveset(moveToUse); + + await game.classicMode.startBattle([ Species.BULBASAUR ]); const enemyPokemon = game.scene.getEnemyPokemon()!; const initialEnemyHp = enemyPokemon.hp; @@ -165,4 +146,19 @@ describe("Abilities - Sap Sipper", () => { expect(initialEnemyHp - enemyPokemon.hp).toBe(0); expect(enemyPokemon.getStatStage(Stat.ATK)).toBe(1); }); + + it("still activates regardless of accuracy check", async () => { + game.override.moveset(Moves.LEAF_BLADE); + + await game.classicMode.startBattle([ Species.BULBASAUR ]); + + const enemyPokemon = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.LEAF_BLADE); + await game.phaseInterceptor.to("MoveEffectPhase"); + + await game.move.forceMiss(); + await game.phaseInterceptor.to("BerryPhase", false); + expect(enemyPokemon.getStatStage(Stat.ATK)).toBe(1); + }); }); diff --git a/src/test/abilities/schooling.test.ts b/src/test/abilities/schooling.test.ts index ad9663bf8e5..e1ec58f517e 100644 --- a/src/test/abilities/schooling.test.ts +++ b/src/test/abilities/schooling.test.ts @@ -1,13 +1,13 @@ -import { Status, StatusEffect } from "#app/data/status-effect"; +import { Status } from "#app/data/status-effect"; import { QuietFormChangePhase } from "#app/phases/quiet-form-change-phase"; import { TurnEndPhase } from "#app/phases/turn-end-phase"; import { Abilities } from "#enums/abilities"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; +import { StatusEffect } from "#enums/status-effect"; import GameManager from "#test/utils/gameManager"; import { afterEach, beforeAll, beforeEach, describe, expect, test } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Abilities - SCHOOLING", () => { let phaserGame: Phaser.Game; @@ -28,8 +28,8 @@ describe("Abilities - SCHOOLING", () => { const moveToUse = Moves.SPLASH; game.override.battleType("single"); game.override.ability(Abilities.SCHOOLING); - game.override.moveset([moveToUse]); - game.override.enemyMoveset([Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE]); + game.override.moveset([ moveToUse ]); + game.override.enemyMoveset([ Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE ]); }); test( @@ -42,9 +42,9 @@ describe("Abilities - SCHOOLING", () => { [Species.WISHIWASHI]: schoolForm, }); - await game.startBattle([Species.MAGIKARP, Species.WISHIWASHI]); + await game.startBattle([ Species.MAGIKARP, Species.WISHIWASHI ]); - const wishiwashi = game.scene.getParty().find((p) => p.species.speciesId === Species.WISHIWASHI)!; + const wishiwashi = game.scene.getPlayerParty().find((p) => p.species.speciesId === Species.WISHIWASHI)!; expect(wishiwashi).not.toBe(undefined); expect(wishiwashi.formIndex).toBe(schoolForm); @@ -60,6 +60,5 @@ describe("Abilities - SCHOOLING", () => { expect(wishiwashi.formIndex).toBe(soloForm); }, - TIMEOUT ); }); diff --git a/src/test/abilities/screen_cleaner.test.ts b/src/test/abilities/screen_cleaner.test.ts index 3c0d12a06ea..c036aa90a77 100644 --- a/src/test/abilities/screen_cleaner.test.ts +++ b/src/test/abilities/screen_cleaner.test.ts @@ -30,10 +30,10 @@ describe("Abilities - Screen Cleaner", () => { }); it("removes Aurora Veil", async () => { - game.override.moveset([Moves.HAIL]); - game.override.enemyMoveset([Moves.AURORA_VEIL, Moves.AURORA_VEIL, Moves.AURORA_VEIL, Moves.AURORA_VEIL]); + game.override.moveset([ Moves.HAIL ]); + game.override.enemyMoveset([ Moves.AURORA_VEIL, Moves.AURORA_VEIL, Moves.AURORA_VEIL, Moves.AURORA_VEIL ]); - await game.startBattle([Species.MAGIKARP, Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP, Species.MAGIKARP ]); game.move.select(Moves.HAIL); await game.phaseInterceptor.to(TurnEndPhase); @@ -48,9 +48,9 @@ describe("Abilities - Screen Cleaner", () => { }); it("removes Light Screen", async () => { - game.override.enemyMoveset([Moves.LIGHT_SCREEN, Moves.LIGHT_SCREEN, Moves.LIGHT_SCREEN, Moves.LIGHT_SCREEN]); + game.override.enemyMoveset([ Moves.LIGHT_SCREEN, Moves.LIGHT_SCREEN, Moves.LIGHT_SCREEN, Moves.LIGHT_SCREEN ]); - await game.startBattle([Species.MAGIKARP, Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP, Species.MAGIKARP ]); game.move.select(Moves.SPLASH); await game.phaseInterceptor.to(TurnEndPhase); @@ -65,9 +65,9 @@ describe("Abilities - Screen Cleaner", () => { }); it("removes Reflect", async () => { - game.override.enemyMoveset([Moves.REFLECT, Moves.REFLECT, Moves.REFLECT, Moves.REFLECT]); + game.override.enemyMoveset([ Moves.REFLECT, Moves.REFLECT, Moves.REFLECT, Moves.REFLECT ]); - await game.startBattle([Species.MAGIKARP, Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP, Species.MAGIKARP ]); game.move.select(Moves.SPLASH); await game.phaseInterceptor.to(TurnEndPhase); diff --git a/src/test/abilities/serene_grace.test.ts b/src/test/abilities/serene_grace.test.ts index e06288b9de9..3318c7fc27a 100644 --- a/src/test/abilities/serene_grace.test.ts +++ b/src/test/abilities/serene_grace.test.ts @@ -27,12 +27,12 @@ describe("Abilities - Serene Grace", () => { beforeEach(() => { game = new GameManager(phaserGame); - const movesToUse = [Moves.AIR_SLASH, Moves.TACKLE]; + const movesToUse = [ Moves.AIR_SLASH, Moves.TACKLE ]; game.override.battleType("single"); game.override.enemySpecies(Species.ONIX); game.override.startingLevel(100); game.override.moveset(movesToUse); - game.override.enemyMoveset([Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE]); + game.override.enemyMoveset([ Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE ]); }); it("Move chance without Serene Grace", async () => { @@ -43,11 +43,11 @@ describe("Abilities - Serene Grace", () => { game.scene.getEnemyParty()[0].stats[Stat.SPDEF] = 10000; - expect(game.scene.getParty()[0].formIndex).toBe(0); + expect(game.scene.getPlayerParty()[0].formIndex).toBe(0); game.move.select(moveToUse); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to(MoveEffectPhase, false); // Check chance of Air Slash without Serene Grace @@ -57,7 +57,7 @@ describe("Abilities - Serene Grace", () => { const chance = new Utils.IntegerHolder(move.chance); console.log(move.chance + " Their ability is " + phase.getUserPokemon()!.getAbility().name); - applyAbAttrs(MoveEffectChanceMultiplierAbAttr, phase.getUserPokemon()!, null, false, chance, move, phase.getTarget(), false); + applyAbAttrs(MoveEffectChanceMultiplierAbAttr, phase.getUserPokemon()!, null, false, chance, move, phase.getFirstTarget(), false); expect(chance.value).toBe(30); }, 20000); @@ -70,11 +70,11 @@ describe("Abilities - Serene Grace", () => { ]); game.scene.getEnemyParty()[0].stats[Stat.SPDEF] = 10000; - expect(game.scene.getParty()[0].formIndex).toBe(0); + expect(game.scene.getPlayerParty()[0].formIndex).toBe(0); game.move.select(moveToUse); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to(MoveEffectPhase, false); // Check chance of Air Slash with Serene Grace @@ -83,7 +83,7 @@ describe("Abilities - Serene Grace", () => { expect(move.id).toBe(Moves.AIR_SLASH); const chance = new Utils.IntegerHolder(move.chance); - applyAbAttrs(MoveEffectChanceMultiplierAbAttr, phase.getUserPokemon()!, null, false, chance, move, phase.getTarget(), false); + applyAbAttrs(MoveEffectChanceMultiplierAbAttr, phase.getUserPokemon()!, null, false, chance, move, phase.getFirstTarget(), false); expect(chance.value).toBe(60); }, 20000); diff --git a/src/test/abilities/sheer_force.test.ts b/src/test/abilities/sheer_force.test.ts index 69b47e1eaae..826694752b7 100644 --- a/src/test/abilities/sheer_force.test.ts +++ b/src/test/abilities/sheer_force.test.ts @@ -1,15 +1,15 @@ import { BattlerIndex } from "#app/battle"; import { applyAbAttrs, applyPostDefendAbAttrs, applyPreAttackAbAttrs, MoveEffectChanceMultiplierAbAttr, MovePowerBoostAbAttr, PostDefendTypeChangeAbAttr } from "#app/data/ability"; -import { Stat } from "#enums/stat"; import { MoveEffectPhase } from "#app/phases/move-effect-phase"; -import * as Utils from "#app/utils"; +import { NumberHolder } from "#app/utils"; import { Abilities } from "#enums/abilities"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; +import { Stat } from "#enums/stat"; import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; - +import { allMoves } from "#app/data/move"; describe("Abilities - Sheer Force", () => { let phaserGame: Phaser.Game; @@ -27,28 +27,25 @@ describe("Abilities - Sheer Force", () => { beforeEach(() => { game = new GameManager(phaserGame); - const movesToUse = [Moves.AIR_SLASH, Moves.BIND, Moves.CRUSH_CLAW, Moves.TACKLE]; + const movesToUse = [ Moves.AIR_SLASH, Moves.BIND, Moves.CRUSH_CLAW, Moves.TACKLE ]; game.override.battleType("single"); game.override.enemySpecies(Species.ONIX); game.override.startingLevel(100); game.override.moveset(movesToUse); - game.override.enemyMoveset([Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE]); + game.override.enemyMoveset([ Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE ]); }); it("Sheer Force", async () => { const moveToUse = Moves.AIR_SLASH; game.override.ability(Abilities.SHEER_FORCE); - await game.startBattle([ - Species.PIDGEOT - ]); + await game.classicMode.startBattle([ Species.PIDGEOT ]); - - game.scene.getEnemyParty()[0].stats[Stat.SPDEF] = 10000; - expect(game.scene.getParty()[0].formIndex).toBe(0); + game.scene.getEnemyPokemon()!.stats[Stat.SPDEF] = 10000; + expect(game.scene.getPlayerPokemon()!.formIndex).toBe(0); game.move.select(moveToUse); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to(MoveEffectPhase, false); const phase = game.scene.getCurrentPhase() as MoveEffectPhase; @@ -56,11 +53,11 @@ describe("Abilities - Sheer Force", () => { expect(move.id).toBe(Moves.AIR_SLASH); //Verify the move is boosted and has no chance of secondary effects - const power = new Utils.IntegerHolder(move.power); - const chance = new Utils.IntegerHolder(move.chance); + const power = new NumberHolder(move.power); + const chance = new NumberHolder(move.chance); - applyAbAttrs(MoveEffectChanceMultiplierAbAttr, phase.getUserPokemon()!, null, false, chance, move, phase.getTarget(), false); - applyPreAttackAbAttrs(MovePowerBoostAbAttr, phase.getUserPokemon()!, phase.getTarget()!, move, false, power); + applyAbAttrs(MoveEffectChanceMultiplierAbAttr, phase.getUserPokemon()!, null, false, chance, move, phase.getFirstTarget(), false); + applyPreAttackAbAttrs(MovePowerBoostAbAttr, phase.getUserPokemon()!, phase.getFirstTarget()!, move, false, power); expect(chance.value).toBe(0); expect(power.value).toBe(move.power * 5461 / 4096); @@ -71,17 +68,15 @@ describe("Abilities - Sheer Force", () => { it("Sheer Force with exceptions including binding moves", async () => { const moveToUse = Moves.BIND; game.override.ability(Abilities.SHEER_FORCE); - await game.startBattle([ - Species.PIDGEOT - ]); + await game.classicMode.startBattle([ Species.PIDGEOT ]); - game.scene.getEnemyParty()[0].stats[Stat.DEF] = 10000; - expect(game.scene.getParty()[0].formIndex).toBe(0); + game.scene.getEnemyPokemon()!.stats[Stat.DEF] = 10000; + expect(game.scene.getPlayerPokemon()!.formIndex).toBe(0); game.move.select(moveToUse); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to(MoveEffectPhase, false); const phase = game.scene.getCurrentPhase() as MoveEffectPhase; @@ -89,11 +84,11 @@ describe("Abilities - Sheer Force", () => { expect(move.id).toBe(Moves.BIND); //Binding moves and other exceptions are not affected by Sheer Force and have a chance.value of -1 - const power = new Utils.IntegerHolder(move.power); - const chance = new Utils.IntegerHolder(move.chance); + const power = new NumberHolder(move.power); + const chance = new NumberHolder(move.chance); - applyAbAttrs(MoveEffectChanceMultiplierAbAttr, phase.getUserPokemon()!, null, false, chance, move, phase.getTarget(), false); - applyPreAttackAbAttrs(MovePowerBoostAbAttr, phase.getUserPokemon()!, phase.getTarget()!, move, false, power); + applyAbAttrs(MoveEffectChanceMultiplierAbAttr, phase.getUserPokemon()!, null, false, chance, move, phase.getFirstTarget(), false); + applyPreAttackAbAttrs(MovePowerBoostAbAttr, phase.getUserPokemon()!, phase.getFirstTarget()!, move, false, power); expect(chance.value).toBe(-1); expect(power.value).toBe(move.power); @@ -104,17 +99,15 @@ describe("Abilities - Sheer Force", () => { it("Sheer Force with moves with no secondary effect", async () => { const moveToUse = Moves.TACKLE; game.override.ability(Abilities.SHEER_FORCE); - await game.startBattle([ - Species.PIDGEOT - ]); + await game.classicMode.startBattle([ Species.PIDGEOT ]); - game.scene.getEnemyParty()[0].stats[Stat.DEF] = 10000; - expect(game.scene.getParty()[0].formIndex).toBe(0); + game.scene.getEnemyPokemon()!.stats[Stat.DEF] = 10000; + expect(game.scene.getPlayerPokemon()!.formIndex).toBe(0); game.move.select(moveToUse); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to(MoveEffectPhase, false); const phase = game.scene.getCurrentPhase() as MoveEffectPhase; @@ -122,11 +115,11 @@ describe("Abilities - Sheer Force", () => { expect(move.id).toBe(Moves.TACKLE); //Binding moves and other exceptions are not affected by Sheer Force and have a chance.value of -1 - const power = new Utils.IntegerHolder(move.power); - const chance = new Utils.IntegerHolder(move.chance); + const power = new NumberHolder(move.power); + const chance = new NumberHolder(move.chance); - applyAbAttrs(MoveEffectChanceMultiplierAbAttr, phase.getUserPokemon()!, null, false, chance, move, phase.getTarget(), false); - applyPreAttackAbAttrs(MovePowerBoostAbAttr, phase.getUserPokemon()!, phase.getTarget()!, move, false, power); + applyAbAttrs(MoveEffectChanceMultiplierAbAttr, phase.getUserPokemon()!, null, false, chance, move, phase.getFirstTarget(), false); + applyPreAttackAbAttrs(MovePowerBoostAbAttr, phase.getUserPokemon()!, phase.getFirstTarget()!, move, false, power); expect(chance.value).toBe(-1); expect(power.value).toBe(move.power); @@ -139,17 +132,15 @@ describe("Abilities - Sheer Force", () => { game.override.enemyAbility(Abilities.COLOR_CHANGE); game.override.startingHeldItems([{ name: "KINGS_ROCK", count: 1 }]); game.override.ability(Abilities.SHEER_FORCE); - await game.startBattle([ - Species.PIDGEOT - ]); + await game.startBattle([ Species.PIDGEOT ]); - game.scene.getEnemyParty()[0].stats[Stat.DEF] = 10000; - expect(game.scene.getParty()[0].formIndex).toBe(0); + game.scene.getEnemyPokemon()!.stats[Stat.DEF] = 10000; + expect(game.scene.getPlayerPokemon()!.formIndex).toBe(0); game.move.select(moveToUse); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to(MoveEffectPhase, false); const phase = game.scene.getCurrentPhase() as MoveEffectPhase; @@ -157,10 +148,10 @@ describe("Abilities - Sheer Force", () => { expect(move.id).toBe(Moves.CRUSH_CLAW); //Disable color change due to being hit by Sheer Force - const power = new Utils.IntegerHolder(move.power); - const chance = new Utils.IntegerHolder(move.chance); + const power = new NumberHolder(move.power); + const chance = new NumberHolder(move.chance); const user = phase.getUserPokemon()!; - const target = phase.getTarget()!; + const target = phase.getFirstTarget()!; const opponentType = target.getTypes()[0]; applyAbAttrs(MoveEffectChanceMultiplierAbAttr, user, null, false, chance, move, target, false); @@ -174,5 +165,31 @@ describe("Abilities - Sheer Force", () => { }, 20000); + it("Two Pokemon with abilities disabled by Sheer Force hitting each other should not cause a crash", async () => { + const moveToUse = Moves.CRUNCH; + game.override.enemyAbility(Abilities.COLOR_CHANGE) + .ability(Abilities.COLOR_CHANGE) + .moveset(moveToUse) + .enemyMoveset(moveToUse); + + await game.classicMode.startBattle([ + Species.PIDGEOT + ]); + + const pidgeot = game.scene.getPlayerParty()[0]; + const onix = game.scene.getEnemyParty()[0]; + + pidgeot.stats[Stat.DEF] = 10000; + onix.stats[Stat.DEF] = 10000; + + game.move.select(moveToUse); + await game.toNextTurn(); + + // Check that both Pokemon's Color Change activated + const expectedTypes = [ allMoves[moveToUse].type ]; + expect(pidgeot.getTypes()).toStrictEqual(expectedTypes); + expect(onix.getTypes()).toStrictEqual(expectedTypes); + }); + //TODO King's Rock Interaction Unit Test }); diff --git a/src/test/abilities/shield_dust.test.ts b/src/test/abilities/shield_dust.test.ts index 8a0b769827d..9f1e6aeb11d 100644 --- a/src/test/abilities/shield_dust.test.ts +++ b/src/test/abilities/shield_dust.test.ts @@ -1,11 +1,11 @@ import { BattlerIndex } from "#app/battle"; import { applyAbAttrs, applyPreDefendAbAttrs, IgnoreMoveEffectsAbAttr, MoveEffectChanceMultiplierAbAttr } from "#app/data/ability"; -import { Stat } from "#enums/stat"; import { MoveEffectPhase } from "#app/phases/move-effect-phase"; -import * as Utils from "#app/utils"; +import { NumberHolder } from "#app/utils"; import { Abilities } from "#enums/abilities"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; +import { Stat } from "#enums/stat"; import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; @@ -27,28 +27,24 @@ describe("Abilities - Shield Dust", () => { beforeEach(() => { game = new GameManager(phaserGame); - const movesToUse = [Moves.AIR_SLASH]; game.override.battleType("single"); game.override.enemySpecies(Species.ONIX); game.override.enemyAbility(Abilities.SHIELD_DUST); game.override.startingLevel(100); - game.override.moveset(movesToUse); - game.override.enemyMoveset([Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE]); + game.override.moveset(Moves.AIR_SLASH); + game.override.enemyMoveset(Moves.TACKLE); }); it("Shield Dust", async () => { - const moveToUse = Moves.AIR_SLASH; - await game.startBattle([ - Species.PIDGEOT - ]); + await game.classicMode.startBattle([ Species.PIDGEOT ]); - game.scene.getEnemyParty()[0].stats[Stat.SPDEF] = 10000; - expect(game.scene.getParty()[0].formIndex).toBe(0); + game.scene.getEnemyPokemon()!.stats[Stat.SPDEF] = 10000; + expect(game.scene.getPlayerPokemon()!.formIndex).toBe(0); - game.move.select(moveToUse); + game.move.select(Moves.AIR_SLASH); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to(MoveEffectPhase, false); // Shield Dust negates secondary effect @@ -56,9 +52,9 @@ describe("Abilities - Shield Dust", () => { const move = phase.move.getMove(); expect(move.id).toBe(Moves.AIR_SLASH); - const chance = new Utils.IntegerHolder(move.chance); - applyAbAttrs(MoveEffectChanceMultiplierAbAttr, phase.getUserPokemon()!, null, false, chance, move, phase.getTarget(), false); - applyPreDefendAbAttrs(IgnoreMoveEffectsAbAttr, phase.getTarget()!, phase.getUserPokemon()!, null, null, false, chance); + const chance = new NumberHolder(move.chance); + applyAbAttrs(MoveEffectChanceMultiplierAbAttr, phase.getUserPokemon()!, null, false, chance, move, phase.getFirstTarget(), false); + applyPreDefendAbAttrs(IgnoreMoveEffectsAbAttr, phase.getFirstTarget()!, phase.getUserPokemon()!, null, null, false, chance); expect(chance.value).toBe(0); }, 20000); diff --git a/src/test/abilities/shields_down.test.ts b/src/test/abilities/shields_down.test.ts index 9bfec23ddf1..6100d3e04d9 100644 --- a/src/test/abilities/shields_down.test.ts +++ b/src/test/abilities/shields_down.test.ts @@ -1,13 +1,13 @@ -import { Status, StatusEffect } from "#app/data/status-effect"; +import { Status } from "#app/data/status-effect"; import { QuietFormChangePhase } from "#app/phases/quiet-form-change-phase"; import { TurnEndPhase } from "#app/phases/turn-end-phase"; import { Abilities } from "#enums/abilities"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; +import { StatusEffect } from "#enums/status-effect"; import GameManager from "#test/utils/gameManager"; import { afterEach, beforeAll, beforeEach, describe, expect, test } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Abilities - SHIELDS DOWN", () => { let phaserGame: Phaser.Game; @@ -28,8 +28,8 @@ describe("Abilities - SHIELDS DOWN", () => { const moveToUse = Moves.SPLASH; game.override.battleType("single"); game.override.ability(Abilities.SHIELDS_DOWN); - game.override.moveset([moveToUse]); - game.override.enemyMoveset([Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE]); + game.override.moveset([ moveToUse ]); + game.override.enemyMoveset([ Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE ]); }); test( @@ -42,9 +42,9 @@ describe("Abilities - SHIELDS DOWN", () => { [Species.MINIOR]: coreForm, }); - await game.startBattle([Species.MAGIKARP, Species.MINIOR]); + await game.startBattle([ Species.MAGIKARP, Species.MINIOR ]); - const minior = game.scene.getParty().find((p) => p.species.speciesId === Species.MINIOR)!; + const minior = game.scene.getPlayerParty().find((p) => p.species.speciesId === Species.MINIOR)!; expect(minior).not.toBe(undefined); expect(minior.formIndex).toBe(coreForm); @@ -60,6 +60,5 @@ describe("Abilities - SHIELDS DOWN", () => { expect(minior.formIndex).toBe(meteorForm); }, - TIMEOUT ); }); diff --git a/src/test/abilities/speed_boost.test.ts b/src/test/abilities/speed_boost.test.ts new file mode 100644 index 00000000000..dd2e83aaa88 --- /dev/null +++ b/src/test/abilities/speed_boost.test.ts @@ -0,0 +1,125 @@ +import { Stat } from "#enums/stat"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; +import { CommandPhase } from "#app/phases/command-phase"; +import { Command } from "#app/ui/command-ui-handler"; +import { AttemptRunPhase } from "#app/phases/attempt-run-phase"; + +describe("Abilities - Speed Boost", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + + game.override + .battleType("single") + .enemySpecies(Species.DRAGAPULT) + .ability(Abilities.SPEED_BOOST) + .enemyMoveset(Moves.SPLASH) + .moveset([ Moves.SPLASH, Moves.U_TURN ]); + }); + + it("should increase speed by 1 stage at end of turn", + async () => { + await game.classicMode.startBattle(); + + const playerPokemon = game.scene.getPlayerPokemon()!; + game.move.select(Moves.SPLASH); + await game.toNextTurn(); + + expect(playerPokemon.getStatStage(Stat.SPD)).toBe(1); + }); + + it("should not trigger this turn if pokemon was switched into combat via attack, but the turn after", + async () => { + await game.classicMode.startBattle([ + Species.SHUCKLE, + Species.NINJASK + ]); + + game.move.select(Moves.U_TURN); + game.doSelectPartyPokemon(1); + await game.toNextTurn(); + const playerPokemon = game.scene.getPlayerPokemon()!; + expect(playerPokemon.getStatStage(Stat.SPD)).toBe(0); + + game.move.select(Moves.SPLASH); + await game.toNextTurn(); + expect(playerPokemon.getStatStage(Stat.SPD)).toBe(1); + }); + + it("checking back to back swtiches", + async () => { + await game.classicMode.startBattle([ + Species.SHUCKLE, + Species.NINJASK + ]); + + game.move.select(Moves.U_TURN); + game.doSelectPartyPokemon(1); + await game.toNextTurn(); + let playerPokemon = game.scene.getPlayerPokemon()!; + expect(playerPokemon.getStatStage(Stat.SPD)).toBe(0); + + game.move.select(Moves.U_TURN); + game.doSelectPartyPokemon(1); + await game.toNextTurn(); + playerPokemon = game.scene.getPlayerPokemon()!; + expect(playerPokemon.getStatStage(Stat.SPD)).toBe(0); + + game.move.select(Moves.SPLASH); + await game.toNextTurn(); + expect(playerPokemon.getStatStage(Stat.SPD)).toBe(1); + }); + + it("should not trigger this turn if pokemon was switched into combat via normal switch, but the turn after", + async () => { + await game.classicMode.startBattle([ + Species.SHUCKLE, + Species.NINJASK + ]); + + game.doSwitchPokemon(1); + await game.toNextTurn(); + const playerPokemon = game.scene.getPlayerPokemon()!; + expect(playerPokemon.getStatStage(Stat.SPD)).toBe(0); + + game.move.select(Moves.SPLASH); + await game.toNextTurn(); + expect(playerPokemon.getStatStage(Stat.SPD)).toBe(1); + }); + + it("should not trigger if pokemon fails to escape", + async () => { + await game.classicMode.startBattle([ Species.SHUCKLE ]); + + const commandPhase = game.scene.getCurrentPhase() as CommandPhase; + commandPhase.handleCommand(Command.RUN, 0); + const runPhase = game.scene.getCurrentPhase() as AttemptRunPhase; + runPhase.forceFailEscape = true; + await game.phaseInterceptor.to(AttemptRunPhase); + await game.toNextTurn(); + + const playerPokemon = game.scene.getPlayerPokemon()!; + expect(playerPokemon.getStatStage(Stat.SPD)).toBe(0); + + game.move.select(Moves.SPLASH); + await game.toNextTurn(); + expect(playerPokemon.getStatStage(Stat.SPD)).toBe(1); + }); +}); diff --git a/src/test/abilities/stall.test.ts b/src/test/abilities/stall.test.ts index 7baf7c846f0..b51c56dbe1f 100644 --- a/src/test/abilities/stall.test.ts +++ b/src/test/abilities/stall.test.ts @@ -26,8 +26,8 @@ describe("Abilities - Stall", () => { game.override.disableCrits(); game.override.enemySpecies(Species.REGIELEKI); game.override.enemyAbility(Abilities.STALL); - game.override.enemyMoveset([Moves.QUICK_ATTACK, Moves.QUICK_ATTACK, Moves.QUICK_ATTACK, Moves.QUICK_ATTACK]); - game.override.moveset([Moves.QUICK_ATTACK, Moves.TACKLE]); + game.override.enemyMoveset([ Moves.QUICK_ATTACK, Moves.QUICK_ATTACK, Moves.QUICK_ATTACK, Moves.QUICK_ATTACK ]); + game.override.moveset([ Moves.QUICK_ATTACK, Moves.TACKLE ]); }); /** @@ -37,7 +37,7 @@ describe("Abilities - Stall", () => { **/ it("Pokemon with Stall should move last in its priority bracket regardless of speed", async () => { - await game.startBattle([Species.SHUCKLE]); + await game.startBattle([ Species.SHUCKLE ]); const playerIndex = game.scene.getPlayerPokemon()!.getBattlerIndex(); const enemyIndex = game.scene.getEnemyPokemon()!.getBattlerIndex(); @@ -50,12 +50,12 @@ describe("Abilities - Stall", () => { const commandOrder = phase.getCommandOrder(); // The player Pokemon (without Stall) goes first despite having lower speed than the opponent. // The opponent Pokemon (with Stall) goes last despite having higher speed than the player Pokemon. - expect(speedOrder).toEqual([enemyIndex, playerIndex]); - expect(commandOrder).toEqual([playerIndex, enemyIndex]); + expect(speedOrder).toEqual([ enemyIndex, playerIndex ]); + expect(commandOrder).toEqual([ playerIndex, enemyIndex ]); }, 20000); it("Pokemon with Stall will go first if a move that is in a higher priority bracket than the opponent's move is used", async () => { - await game.startBattle([Species.SHUCKLE]); + await game.startBattle([ Species.SHUCKLE ]); const playerIndex = game.scene.getPlayerPokemon()!.getBattlerIndex(); const enemyIndex = game.scene.getEnemyPokemon()!.getBattlerIndex(); @@ -68,13 +68,13 @@ describe("Abilities - Stall", () => { const commandOrder = phase.getCommandOrder(); // The opponent Pokemon (with Stall) goes first because its move is still within a higher priority bracket than its opponent. // The player Pokemon goes second because its move is in a lower priority bracket. - expect(speedOrder).toEqual([enemyIndex, playerIndex]); - expect(commandOrder).toEqual([enemyIndex, playerIndex]); + expect(speedOrder).toEqual([ enemyIndex, playerIndex ]); + expect(commandOrder).toEqual([ enemyIndex, playerIndex ]); }, 20000); it("If both Pokemon have stall and use the same move, speed is used to determine who goes first.", async () => { game.override.ability(Abilities.STALL); - await game.startBattle([Species.SHUCKLE]); + await game.startBattle([ Species.SHUCKLE ]); const playerIndex = game.scene.getPlayerPokemon()!.getBattlerIndex(); const enemyIndex = game.scene.getEnemyPokemon()!.getBattlerIndex(); @@ -88,7 +88,7 @@ describe("Abilities - Stall", () => { // The opponent Pokemon (with Stall) goes first because it has a higher speed. // The player Pokemon (with Stall) goes second because its speed is lower. - expect(speedOrder).toEqual([enemyIndex, playerIndex]); - expect(commandOrder).toEqual([enemyIndex, playerIndex]); + expect(speedOrder).toEqual([ enemyIndex, playerIndex ]); + expect(commandOrder).toEqual([ enemyIndex, playerIndex ]); }, 20000); }); diff --git a/src/test/abilities/steely_spirit.test.ts b/src/test/abilities/steely_spirit.test.ts index 7b5879555be..61e76989060 100644 --- a/src/test/abilities/steely_spirit.test.ts +++ b/src/test/abilities/steely_spirit.test.ts @@ -29,13 +29,13 @@ describe("Abilities - Steely Spirit", () => { game.override.battleType("double"); game.override.enemySpecies(Species.SHUCKLE); game.override.enemyAbility(Abilities.BALL_FETCH); - game.override.moveset([Moves.IRON_HEAD, Moves.SPLASH]); + game.override.moveset([ Moves.IRON_HEAD, Moves.SPLASH ]); game.override.enemyMoveset(Moves.SPLASH); vi.spyOn(allMoves[moveToCheck], "calculateBattlePower"); }); it("increases Steel-type moves' power used by the user and its allies by 50%", async () => { - await game.classicMode.startBattle([Species.PIKACHU, Species.SHUCKLE]); + await game.classicMode.startBattle([ Species.PIKACHU, Species.SHUCKLE ]); const boostSource = game.scene.getPlayerField()[1]; const enemyToCheck = game.scene.getEnemyPokemon()!; @@ -51,7 +51,7 @@ describe("Abilities - Steely Spirit", () => { }); it("stacks if multiple users with this ability are on the field.", async () => { - await game.classicMode.startBattle([Species.PIKACHU, Species.PIKACHU]); + await game.classicMode.startBattle([ Species.PIKACHU, Species.PIKACHU ]); const enemyToCheck = game.scene.getEnemyPokemon()!; game.scene.getPlayerField().forEach(p => { @@ -68,7 +68,7 @@ describe("Abilities - Steely Spirit", () => { }); it("does not take effect when suppressed", async () => { - await game.classicMode.startBattle([Species.PIKACHU, Species.SHUCKLE]); + await game.classicMode.startBattle([ Species.PIKACHU, Species.SHUCKLE ]); const boostSource = game.scene.getPlayerField()[1]; const enemyToCheck = game.scene.getEnemyPokemon()!; @@ -90,12 +90,12 @@ describe("Abilities - Steely Spirit", () => { it("affects variable-type moves if their resolved type is Steel", async () => { game.override .ability(Abilities.STEELY_SPIRIT) - .moveset([Moves.REVELATION_DANCE]); + .moveset([ Moves.REVELATION_DANCE ]); const revelationDance = allMoves[Moves.REVELATION_DANCE]; vi.spyOn(revelationDance, "calculateBattlePower"); - await game.classicMode.startBattle([Species.KLINKLANG]); + await game.classicMode.startBattle([ Species.KLINKLANG ]); game.move.select(Moves.REVELATION_DANCE); diff --git a/src/test/abilities/sturdy.test.ts b/src/test/abilities/sturdy.test.ts index dc9f774cc5b..49384e69f83 100644 --- a/src/test/abilities/sturdy.test.ts +++ b/src/test/abilities/sturdy.test.ts @@ -8,7 +8,6 @@ import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, test } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Abilities - Sturdy", () => { let phaserGame: Phaser.Game; @@ -30,7 +29,7 @@ describe("Abilities - Sturdy", () => { game.override.starterSpecies(Species.LUCARIO); game.override.startingLevel(100); - game.override.moveset([Moves.CLOSE_COMBAT, Moves.FISSURE]); + game.override.moveset([ Moves.CLOSE_COMBAT, Moves.FISSURE ]); game.override.enemySpecies(Species.ARON); game.override.enemyLevel(5); @@ -45,7 +44,6 @@ describe("Abilities - Sturdy", () => { await game.phaseInterceptor.to(MoveEndPhase); expect(game.scene.getEnemyParty()[0].hp).toBe(1); }, - TIMEOUT ); test( @@ -62,7 +60,6 @@ describe("Abilities - Sturdy", () => { expect(enemyPokemon.hp).toBe(0); expect(enemyPokemon.isFainted()).toBe(true); }, - TIMEOUT ); test( @@ -75,7 +72,6 @@ describe("Abilities - Sturdy", () => { const enemyPokemon: EnemyPokemon = game.scene.getEnemyParty()[0]; expect(enemyPokemon.isFullHp()).toBe(true); }, - TIMEOUT ); test( @@ -91,7 +87,6 @@ describe("Abilities - Sturdy", () => { expect(enemyPokemon.hp).toBe(0); expect(enemyPokemon.isFainted()).toBe(true); }, - TIMEOUT ); }); diff --git a/src/test/abilities/sweet_veil.test.ts b/src/test/abilities/sweet_veil.test.ts index c2946443245..ef66cb1c68a 100644 --- a/src/test/abilities/sweet_veil.test.ts +++ b/src/test/abilities/sweet_veil.test.ts @@ -26,14 +26,14 @@ describe("Abilities - Sweet Veil", () => { beforeEach(() => { game = new GameManager(phaserGame); game.override.battleType("double"); - game.override.moveset([Moves.SPLASH, Moves.REST, Moves.YAWN]); + game.override.moveset([ Moves.SPLASH, Moves.REST, Moves.YAWN ]); game.override.enemySpecies(Species.MAGIKARP); game.override.enemyAbility(Abilities.BALL_FETCH); - game.override.enemyMoveset([Moves.POWDER, Moves.POWDER, Moves.POWDER, Moves.POWDER]); + game.override.enemyMoveset([ Moves.POWDER, Moves.POWDER, Moves.POWDER, Moves.POWDER ]); }); it("prevents the user and its allies from falling asleep", async () => { - await game.startBattle([Species.SWIRLIX, Species.MAGIKARP]); + await game.startBattle([ Species.SWIRLIX, Species.MAGIKARP ]); game.move.select(Moves.SPLASH); game.move.select(Moves.SPLASH, 1); @@ -45,7 +45,7 @@ describe("Abilities - Sweet Veil", () => { it("causes Rest to fail when used by the user or its allies", async () => { game.override.enemyMoveset(Moves.SPLASH); - await game.startBattle([Species.SWIRLIX, Species.MAGIKARP]); + await game.startBattle([ Species.SWIRLIX, Species.MAGIKARP ]); game.move.select(Moves.SPLASH); game.move.select(Moves.REST, 1); @@ -56,8 +56,8 @@ describe("Abilities - Sweet Veil", () => { }); it("causes Yawn to fail if used on the user or its allies", async () => { - game.override.enemyMoveset([Moves.YAWN, Moves.YAWN, Moves.YAWN, Moves.YAWN]); - await game.startBattle([Species.SWIRLIX, Species.MAGIKARP]); + game.override.enemyMoveset([ Moves.YAWN, Moves.YAWN, Moves.YAWN, Moves.YAWN ]); + await game.startBattle([ Species.SWIRLIX, Species.MAGIKARP ]); game.move.select(Moves.SPLASH); game.move.select(Moves.SPLASH, 1); @@ -73,7 +73,7 @@ describe("Abilities - Sweet Veil", () => { game.override.startingLevel(5); game.override.enemyMoveset(Moves.SPLASH); - await game.startBattle([Species.SHUCKLE, Species.SHUCKLE, Species.SWIRLIX]); + await game.startBattle([ Species.SHUCKLE, Species.SHUCKLE, Species.SWIRLIX ]); game.move.select(Moves.SPLASH); game.move.select(Moves.YAWN, 1, BattlerIndex.PLAYER); diff --git a/src/test/abilities/synchronize.test.ts b/src/test/abilities/synchronize.test.ts new file mode 100644 index 00000000000..2ae80ae9c7a --- /dev/null +++ b/src/test/abilities/synchronize.test.ts @@ -0,0 +1,97 @@ +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import { StatusEffect } from "#enums/status-effect"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; + +describe("Abilities - Synchronize", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + + game.override + .battleType("single") + .startingLevel(100) + .enemySpecies(Species.MAGIKARP) + .enemyAbility(Abilities.SYNCHRONIZE) + .moveset([ Moves.SPLASH, Moves.THUNDER_WAVE, Moves.SPORE, Moves.PSYCHO_SHIFT ]) + .ability(Abilities.NO_GUARD); + }); + + it("does not trigger when no status is applied by opponent Pokemon", async () => { + await game.classicMode.startBattle([ Species.FEEBAS ]); + + game.move.select(Moves.SPLASH); + await game.phaseInterceptor.to("BerryPhase"); + + expect(game.scene.getPlayerPokemon()!.status).toBeUndefined(); + expect(game.phaseInterceptor.log).not.toContain("ShowAbilityPhase"); + }); + + it("sets the status of the source pokemon to Paralysis when paralyzed by it", async () => { + await game.classicMode.startBattle([ Species.FEEBAS ]); + + game.move.select(Moves.THUNDER_WAVE); + await game.phaseInterceptor.to("BerryPhase"); + + expect(game.scene.getPlayerPokemon()!.status?.effect).toBe(StatusEffect.PARALYSIS); + expect(game.scene.getEnemyPokemon()!.status?.effect).toBe(StatusEffect.PARALYSIS); + expect(game.phaseInterceptor.log).toContain("ShowAbilityPhase"); + }); + + it("does not trigger on Sleep", async () => { + await game.classicMode.startBattle(); + + game.move.select(Moves.SPORE); + + await game.phaseInterceptor.to("BerryPhase"); + + expect(game.scene.getPlayerPokemon()!.status?.effect).toBeUndefined(); + expect(game.scene.getEnemyPokemon()!.status?.effect).toBe(StatusEffect.SLEEP); + expect(game.phaseInterceptor.log).not.toContain("ShowAbilityPhase"); + }); + + it("does not trigger when Pokemon is statused by Toxic Spikes", async () => { + game.override + .ability(Abilities.SYNCHRONIZE) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Array(4).fill(Moves.TOXIC_SPIKES)); + + await game.classicMode.startBattle([ Species.FEEBAS, Species.MILOTIC ]); + + game.move.select(Moves.SPLASH); + await game.toNextTurn(); + + game.doSwitchPokemon(1); + await game.phaseInterceptor.to("BerryPhase"); + + expect(game.scene.getPlayerPokemon()!.status?.effect).toBe(StatusEffect.POISON); + expect(game.scene.getEnemyPokemon()!.status?.effect).toBeUndefined(); + expect(game.phaseInterceptor.log).not.toContain("ShowAbilityPhase"); + }); + + it("shows ability even if it fails to set the status of the opponent Pokemon", async () => { + await game.classicMode.startBattle([ Species.PIKACHU ]); + + game.move.select(Moves.THUNDER_WAVE); + await game.phaseInterceptor.to("BerryPhase"); + + expect(game.scene.getPlayerPokemon()!.status?.effect).toBeUndefined(); + expect(game.scene.getEnemyPokemon()!.status?.effect).toBe(StatusEffect.PARALYSIS); + expect(game.phaseInterceptor.log).toContain("ShowAbilityPhase"); + }); +}); diff --git a/src/test/abilities/tera_shell.test.ts b/src/test/abilities/tera_shell.test.ts index 2826469f3bf..01382d0fd9a 100644 --- a/src/test/abilities/tera_shell.test.ts +++ b/src/test/abilities/tera_shell.test.ts @@ -1,3 +1,4 @@ +import { BattlerIndex } from "#app/battle"; import { Abilities } from "#app/enums/abilities"; import { Moves } from "#app/enums/moves"; import { Species } from "#app/enums/species"; @@ -6,8 +7,6 @@ import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; -const TIMEOUT = 10 * 1000; // 10 second timeout - describe("Abilities - Tera Shell", () => { let phaserGame: Phaser.Game; let game: GameManager; @@ -27,10 +26,10 @@ describe("Abilities - Tera Shell", () => { game.override .battleType("single") .ability(Abilities.TERA_SHELL) - .moveset([Moves.SPLASH]) + .moveset([ Moves.SPLASH ]) .enemySpecies(Species.SNORLAX) .enemyAbility(Abilities.INSOMNIA) - .enemyMoveset([Moves.MACH_PUNCH]) + .enemyMoveset([ Moves.MACH_PUNCH ]) .startingLevel(100) .enemyLevel(100); }); @@ -38,7 +37,7 @@ describe("Abilities - Tera Shell", () => { it( "should change the effectiveness of non-resisted attacks when the source is at full HP", async () => { - await game.classicMode.startBattle([Species.SNORLAX]); + await game.classicMode.startBattle([ Species.SNORLAX ]); const playerPokemon = game.scene.getPlayerPokemon()!; vi.spyOn(playerPokemon, "getMoveEffectiveness"); @@ -54,15 +53,15 @@ describe("Abilities - Tera Shell", () => { await game.phaseInterceptor.to("MoveEndPhase"); expect(playerPokemon.getMoveEffectiveness).toHaveLastReturnedWith(2); - }, TIMEOUT + } ); it( "should not override type immunities", async () => { - game.override.enemyMoveset([Moves.SHADOW_SNEAK]); + game.override.enemyMoveset([ Moves.SHADOW_SNEAK ]); - await game.classicMode.startBattle([Species.SNORLAX]); + await game.classicMode.startBattle([ Species.SNORLAX ]); const playerPokemon = game.scene.getPlayerPokemon()!; vi.spyOn(playerPokemon, "getMoveEffectiveness"); @@ -71,15 +70,15 @@ describe("Abilities - Tera Shell", () => { await game.phaseInterceptor.to("MoveEndPhase"); expect(playerPokemon.getMoveEffectiveness).toHaveLastReturnedWith(0); - }, TIMEOUT + } ); it( "should not override type multipliers less than 0.5x", async () => { - game.override.enemyMoveset([Moves.QUICK_ATTACK]); + game.override.enemyMoveset([ Moves.QUICK_ATTACK ]); - await game.classicMode.startBattle([Species.AGGRON]); + await game.classicMode.startBattle([ Species.AGGRON ]); const playerPokemon = game.scene.getPlayerPokemon()!; vi.spyOn(playerPokemon, "getMoveEffectiveness"); @@ -88,15 +87,15 @@ describe("Abilities - Tera Shell", () => { await game.phaseInterceptor.to("MoveEndPhase"); expect(playerPokemon.getMoveEffectiveness).toHaveLastReturnedWith(0.25); - }, TIMEOUT + } ); it( "should not affect the effectiveness of fixed-damage moves", async () => { - game.override.enemyMoveset([Moves.DRAGON_RAGE]); + game.override.enemyMoveset([ Moves.DRAGON_RAGE ]); - await game.classicMode.startBattle([Species.CHARIZARD]); + await game.classicMode.startBattle([ Species.CHARIZARD ]); const playerPokemon = game.scene.getPlayerPokemon()!; vi.spyOn(playerPokemon, "apply"); @@ -106,6 +105,28 @@ describe("Abilities - Tera Shell", () => { await game.phaseInterceptor.to("BerryPhase", false); expect(playerPokemon.apply).toHaveLastReturnedWith(HitResult.EFFECTIVE); expect(playerPokemon.hp).toBe(playerPokemon.getMaxHp() - 40); - }, TIMEOUT + } + ); + + it( + "should change the effectiveness of all strikes of a multi-strike move", + async () => { + game.override.enemyMoveset([ Moves.DOUBLE_HIT ]); + + await game.classicMode.startBattle([ Species.SNORLAX ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + vi.spyOn(playerPokemon, "apply"); + + game.move.select(Moves.SPLASH); + + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); + await game.move.forceHit(); + for (let i = 0; i < 2; i++) { + await game.phaseInterceptor.to("MoveEffectPhase"); + expect(playerPokemon.apply).toHaveLastReturnedWith(HitResult.NOT_VERY_EFFECTIVE); + } + expect(playerPokemon.apply).toHaveReturnedTimes(2); + } ); }); diff --git a/src/test/abilities/unburden.test.ts b/src/test/abilities/unburden.test.ts new file mode 100644 index 00000000000..ba14c7fdcd0 --- /dev/null +++ b/src/test/abilities/unburden.test.ts @@ -0,0 +1,401 @@ +import { BattlerIndex } from "#app/battle"; +import { PostItemLostAbAttr } from "#app/data/ability"; +import { allMoves, StealHeldItemChanceAttr } from "#app/data/move"; +import Pokemon from "#app/field/pokemon"; +import type { ContactHeldItemTransferChanceModifier } from "#app/modifier/modifier"; +import { Abilities } from "#enums/abilities"; +import { BattlerTagType } from "#enums/battler-tag-type"; +import { BerryType } from "#enums/berry-type"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import { Stat } from "#enums/stat"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; + + +describe("Abilities - Unburden", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + /** + * Count the number of held items a Pokemon has, accounting for stacks of multiple items. + */ + function getHeldItemCount(pokemon: Pokemon): number { + const stackCounts = pokemon.getHeldItems().map(m => m.getStackCount()); + if (stackCounts.length) { + return stackCounts.reduce((a, b) => a + b); + } else { + return 0; + } + } + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .battleType("single") + .startingLevel(1) + .ability(Abilities.UNBURDEN) + .moveset([ Moves.SPLASH, Moves.KNOCK_OFF, Moves.PLUCK, Moves.FALSE_SWIPE ]) + .startingHeldItems([ + { name: "BERRY", count: 1, type: BerryType.SITRUS }, + { name: "BERRY", count: 2, type: BerryType.APICOT }, + { name: "BERRY", count: 2, type: BerryType.LUM }, + ]) + .enemySpecies(Species.NINJASK) + .enemyLevel(100) + .enemyMoveset(Moves.SPLASH) + .enemyAbility(Abilities.UNBURDEN) + .enemyPassiveAbility(Abilities.NO_GUARD) + .enemyHeldItems([ + { name: "BERRY", type: BerryType.SITRUS, count: 1 }, + { name: "BERRY", type: BerryType.LUM, count: 1 }, + ]); + // For the various tests that use Thief, give it a 100% steal rate + vi.spyOn(allMoves[Moves.THIEF], "attrs", "get").mockReturnValue([ new StealHeldItemChanceAttr(1.0) ]); + }); + + it("should activate when a berry is eaten", async () => { + game.override.enemyMoveset(Moves.FALSE_SWIPE); + await game.classicMode.startBattle([ Species.TREECKO ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const playerHeldItems = getHeldItemCount(playerPokemon); + const initialPlayerSpeed = playerPokemon.getStat(Stat.SPD); + + // Player gets hit by False Swipe and eats its own Sitrus Berry + game.move.select(Moves.SPLASH); + await game.toNextTurn(); + + expect(getHeldItemCount(playerPokemon)).toBeLessThan(playerHeldItems); + expect(playerPokemon.getEffectiveStat(Stat.SPD)).toBe(initialPlayerSpeed * 2); + }); + + it("should activate when a berry is eaten, even if Berry Pouch preserves the berry", async () => { + game.override.enemyMoveset(Moves.FALSE_SWIPE) + .startingModifier([{ name: "BERRY_POUCH", count: 5850 }]); + await game.classicMode.startBattle([ Species.TREECKO ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const playerHeldItems = getHeldItemCount(playerPokemon); + const initialPlayerSpeed = playerPokemon.getStat(Stat.SPD); + + // Player gets hit by False Swipe and eats its own Sitrus Berry + game.move.select(Moves.SPLASH); + await game.toNextTurn(); + + expect(getHeldItemCount(playerPokemon)).toBe(playerHeldItems); + expect(playerPokemon.getEffectiveStat(Stat.SPD)).toBe(initialPlayerSpeed * 2); + }); + + it("should activate for the target, and not the stealer, when a berry is stolen", async () => { + await game.classicMode.startBattle([ Species.TREECKO ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const initialPlayerSpeed = playerPokemon.getStat(Stat.SPD); + const enemyPokemon = game.scene.getEnemyPokemon()!; + const enemyHeldItemCt = getHeldItemCount(enemyPokemon); + const initialEnemySpeed = enemyPokemon.getStat(Stat.SPD); + + // Player uses Pluck and eats the opponent's berry + game.move.select(Moves.PLUCK); + await game.toNextTurn(); + + expect(getHeldItemCount(enemyPokemon)).toBeLessThan(enemyHeldItemCt); + expect(enemyPokemon.getEffectiveStat(Stat.SPD)).toBe(initialEnemySpeed * 2); + expect(playerPokemon.getEffectiveStat(Stat.SPD)).toBe(initialPlayerSpeed); + }); + + it("should activate when an item is knocked off", async () => { + await game.classicMode.startBattle([ Species.TREECKO ]); + + const enemyPokemon = game.scene.getEnemyPokemon()!; + const enemyHeldItemCt = getHeldItemCount(enemyPokemon); + const initialEnemySpeed = enemyPokemon.getStat(Stat.SPD); + + // Player uses Knock Off and removes the opponent's item + game.move.select(Moves.KNOCK_OFF); + await game.toNextTurn(); + + expect(getHeldItemCount(enemyPokemon)).toBeLessThan(enemyHeldItemCt); + expect(enemyPokemon.getEffectiveStat(Stat.SPD)).toBe(initialEnemySpeed * 2); + }); + + it("should activate when an item is stolen via attacking ability", async () => { + game.override + .ability(Abilities.MAGICIAN) + .startingHeldItems([]); // Remove player's full stacks of held items so it can steal opponent's held items + await game.classicMode.startBattle([ Species.TREECKO ]); + + const enemyPokemon = game.scene.getEnemyPokemon()!; + const enemyHeldItemCt = getHeldItemCount(enemyPokemon); + const initialEnemySpeed = enemyPokemon.getStat(Stat.SPD); + + // Player steals the opponent's item via ability Magician + game.move.select(Moves.FALSE_SWIPE); + await game.toNextTurn(); + + expect(getHeldItemCount(enemyPokemon)).toBeLessThan(enemyHeldItemCt); + expect(enemyPokemon.getEffectiveStat(Stat.SPD)).toBe(initialEnemySpeed * 2); + }); + + it("should activate when an item is stolen via defending ability", async () => { + game.override + .enemyAbility(Abilities.PICKPOCKET) + .enemyHeldItems([]); // Remove opponent's full stacks of held items so it can steal player's held items + await game.classicMode.startBattle([ Species.TREECKO ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const playerHeldItems = getHeldItemCount(playerPokemon); + const initialPlayerSpeed = playerPokemon.getStat(Stat.SPD); + + // Player's item gets stolen via ability Pickpocket + game.move.select(Moves.FALSE_SWIPE); + await game.toNextTurn(); + + expect(getHeldItemCount(playerPokemon)).toBeLessThan(playerHeldItems); + expect(playerPokemon.getEffectiveStat(Stat.SPD)).toBe(initialPlayerSpeed * 2); + }); + + it("should activate when an item is stolen via move", async () => { + game.override.moveset(Moves.THIEF) + .startingHeldItems([]); // Remove player's full stacks of held items so it can steal opponent's held items + await game.classicMode.startBattle([ Species.TREECKO ]); + + const enemyPokemon = game.scene.getEnemyPokemon()!; + const enemyHeldItemCt = getHeldItemCount(enemyPokemon); + const initialEnemySpeed = enemyPokemon.getStat(Stat.SPD); + + // Player uses Thief and steals the opponent's item + game.move.select(Moves.THIEF); + await game.toNextTurn(); + + expect(getHeldItemCount(enemyPokemon)).toBeLessThan(enemyHeldItemCt); + expect(enemyPokemon.getEffectiveStat(Stat.SPD)).toBe(initialEnemySpeed * 2); + }); + + it("should activate when an item is stolen via grip claw", async () => { + game.override + .startingHeldItems([ + { name: "GRIP_CLAW", count: 1 }, + ]); + await game.classicMode.startBattle([ Species.TREECKO ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const gripClaw = playerPokemon.getHeldItems()[0] as ContactHeldItemTransferChanceModifier; + vi.spyOn(gripClaw, "chance", "get").mockReturnValue(100); + + const enemyPokemon = game.scene.getEnemyPokemon()!; + const enemyHeldItemCt = getHeldItemCount(enemyPokemon); + const initialEnemySpeed = enemyPokemon.getStat(Stat.SPD); + + // Player steals the opponent's item using Grip Claw + game.move.select(Moves.FALSE_SWIPE); + await game.toNextTurn(); + + expect(getHeldItemCount(enemyPokemon)).toBeLessThan(enemyHeldItemCt); + expect(enemyPokemon.getEffectiveStat(Stat.SPD)).toBe(initialEnemySpeed * 2); + }); + + it("should not activate when a neutralizing ability is present", async () => { + game.override.enemyAbility(Abilities.NEUTRALIZING_GAS) + .enemyMoveset(Moves.FALSE_SWIPE); + await game.classicMode.startBattle([ Species.TREECKO ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const playerHeldItems = getHeldItemCount(playerPokemon); + const initialPlayerSpeed = playerPokemon.getStat(Stat.SPD); + + // Player gets hit by False Swipe and eats Sitrus Berry, which should not trigger Unburden + game.move.select(Moves.SPLASH); + await game.toNextTurn(); + + expect(getHeldItemCount(playerPokemon)).toBeLessThan(playerHeldItems); + expect(playerPokemon.getEffectiveStat(Stat.SPD)).toBe(initialPlayerSpeed); + expect(playerPokemon.getTag(BattlerTagType.UNBURDEN)).toBeUndefined(); + }); + + it("should activate when a move that consumes a berry is used", async () => { + game.override.moveset(Moves.STUFF_CHEEKS); + await game.classicMode.startBattle([ Species.TREECKO ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const playerHeldItemCt = getHeldItemCount(playerPokemon); + const initialPlayerSpeed = playerPokemon.getStat(Stat.SPD); + + // Player uses Stuff Cheeks and eats its own berry + // Caution: Do not test this using opponent, there is a known issue where opponent can randomly generate with Salac Berry + game.move.select(Moves.STUFF_CHEEKS); + await game.toNextTurn(); + + expect(getHeldItemCount(playerPokemon)).toBeLessThan(playerHeldItemCt); + expect(playerPokemon.getEffectiveStat(Stat.SPD)).toBe(initialPlayerSpeed * 2); + }); + + it("should deactivate temporarily when a neutralizing gas user is on the field", async () => { + game.override + .battleType("double") + .ability(Abilities.NONE); // Disable ability override so that we can properly set abilities below + await game.classicMode.startBattle([ Species.TREECKO, Species.MEOWTH, Species.WEEZING ]); + + // eslint-disable-next-line @typescript-eslint/no-unused-vars + const [ treecko, _meowth, weezing ] = game.scene.getPlayerParty(); + treecko.abilityIndex = 2; // Treecko has Unburden + weezing.abilityIndex = 1; // Weezing has Neutralizing Gas + const playerHeldItems = getHeldItemCount(treecko); + const initialPlayerSpeed = treecko.getStat(Stat.SPD); + + // Turn 1: Treecko gets hit by False Swipe and eats Sitrus Berry, activating Unburden + game.move.select(Moves.SPLASH); + game.move.select(Moves.SPLASH, 1); + await game.forceEnemyMove(Moves.FALSE_SWIPE, 0); + await game.forceEnemyMove(Moves.FALSE_SWIPE, 0); + await game.phaseInterceptor.to("TurnEndPhase"); + + expect(getHeldItemCount(treecko)).toBeLessThan(playerHeldItems); + expect(treecko.getEffectiveStat(Stat.SPD)).toBe(initialPlayerSpeed * 2); + + // Turn 2: Switch Meowth to Weezing, activating Neutralizing Gas + await game.toNextTurn(); + game.move.select(Moves.SPLASH); + game.doSwitchPokemon(2); + await game.phaseInterceptor.to("TurnEndPhase"); + + expect(getHeldItemCount(treecko)).toBeLessThan(playerHeldItems); + expect(treecko.getEffectiveStat(Stat.SPD)).toBe(initialPlayerSpeed); + + // Turn 3: Switch Weezing to Meowth, deactivating Neutralizing Gas + await game.toNextTurn(); + game.move.select(Moves.SPLASH); + game.doSwitchPokemon(2); + await game.phaseInterceptor.to("TurnEndPhase"); + + expect(getHeldItemCount(treecko)).toBeLessThan(playerHeldItems); + expect(treecko.getEffectiveStat(Stat.SPD)).toBe(initialPlayerSpeed * 2); + }); + + it("should not activate when passing a baton to a teammate switching in", async () => { + game.override.startingHeldItems([{ name: "BATON" }]) + .moveset(Moves.BATON_PASS); + await game.classicMode.startBattle([ Species.TREECKO, Species.PURRLOIN ]); + + const [ treecko, purrloin ] = game.scene.getPlayerParty(); + const initialTreeckoSpeed = treecko.getStat(Stat.SPD); + const initialPurrloinSpeed = purrloin.getStat(Stat.SPD); + const unburdenAttr = treecko.getAbilityAttrs(PostItemLostAbAttr)[0]; + vi.spyOn(unburdenAttr, "applyPostItemLost"); + + // Player uses Baton Pass, which also passes the Baton item + game.move.select(Moves.BATON_PASS); + game.doSelectPartyPokemon(1); + await game.toNextTurn(); + + expect(getHeldItemCount(treecko)).toBe(0); + expect(getHeldItemCount(purrloin)).toBe(1); + expect(treecko.getEffectiveStat(Stat.SPD)).toBe(initialTreeckoSpeed); + expect(purrloin.getEffectiveStat(Stat.SPD)).toBe(initialPurrloinSpeed); + expect(unburdenAttr.applyPostItemLost).not.toHaveBeenCalled(); + }); + + it("should not speed up a Pokemon after it loses the ability Unburden", async () => { + game.override.enemyMoveset([ Moves.FALSE_SWIPE, Moves.WORRY_SEED ]); + await game.classicMode.startBattle([ Species.PURRLOIN ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const playerHeldItems = getHeldItemCount(playerPokemon); + const initialPlayerSpeed = playerPokemon.getStat(Stat.SPD); + + // Turn 1: Get hit by False Swipe and eat Sitrus Berry, activating Unburden + game.move.select(Moves.SPLASH); + await game.forceEnemyMove(Moves.FALSE_SWIPE); + await game.toNextTurn(); + + expect(getHeldItemCount(playerPokemon)).toBeLessThan(playerHeldItems); + expect(playerPokemon.getEffectiveStat(Stat.SPD)).toBe(initialPlayerSpeed * 2); + + // Turn 2: Get hit by Worry Seed, deactivating Unburden + game.move.select(Moves.SPLASH); + await game.forceEnemyMove(Moves.WORRY_SEED); + await game.toNextTurn(); + + expect(getHeldItemCount(playerPokemon)).toBeLessThan(playerHeldItems); + expect(playerPokemon.getEffectiveStat(Stat.SPD)).toBe(initialPlayerSpeed); + }); + + it("should activate when a reviver seed is used", async () => { + game.override.startingHeldItems([{ name: "REVIVER_SEED" }]) + .enemyMoveset([ Moves.WING_ATTACK ]); + await game.classicMode.startBattle([ Species.TREECKO ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const playerHeldItems = getHeldItemCount(playerPokemon); + const initialPlayerSpeed = playerPokemon.getStat(Stat.SPD); + + // Turn 1: Get hit by Wing Attack and faint, activating Reviver Seed + game.move.select(Moves.SPLASH); + await game.toNextTurn(); + + expect(getHeldItemCount(playerPokemon)).toBeLessThan(playerHeldItems); + expect(playerPokemon.getEffectiveStat(Stat.SPD)).toBe(initialPlayerSpeed * 2); + }); + + // test for `.bypassFaint()` - singles + it("shouldn't persist when revived normally if activated while fainting", async () => { + game.override.enemyMoveset([ Moves.SPLASH, Moves.THIEF ]); + await game.classicMode.startBattle([ Species.TREECKO, Species.FEEBAS ]); + + const treecko = game.scene.getPlayerPokemon()!; + const treeckoInitialHeldItems = getHeldItemCount(treecko); + const initialSpeed = treecko.getStat(Stat.SPD); + + game.move.select(Moves.SPLASH); + await game.forceEnemyMove(Moves.THIEF); + game.doSelectPartyPokemon(1); + await game.toNextTurn(); + + game.doRevivePokemon(1); + game.doSwitchPokemon(1); + await game.forceEnemyMove(Moves.SPLASH); + await game.toNextTurn(); + + expect(game.scene.getPlayerPokemon()!).toBe(treecko); + expect(getHeldItemCount(treecko)).toBeLessThan(treeckoInitialHeldItems); + expect(treecko.getEffectiveStat(Stat.SPD)).toBe(initialSpeed); + }); + + // test for `.bypassFaint()` - doubles + it("shouldn't persist when revived by revival blessing if activated while fainting", async () => { + game.override + .battleType("double") + .enemyMoveset([ Moves.SPLASH, Moves.THIEF ]) + .moveset([ Moves.SPLASH, Moves.REVIVAL_BLESSING ]) + .startingHeldItems([{ name: "WIDE_LENS" }]); + await game.classicMode.startBattle([ Species.TREECKO, Species.FEEBAS, Species.MILOTIC ]); + + const treecko = game.scene.getPlayerField()[0]; + const treeckoInitialHeldItems = getHeldItemCount(treecko); + const initialSpeed = treecko.getStat(Stat.SPD); + + game.move.select(Moves.SPLASH); + game.move.select(Moves.REVIVAL_BLESSING, 1); + await game.forceEnemyMove(Moves.THIEF, BattlerIndex.PLAYER); + await game.forceEnemyMove(Moves.SPLASH); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2, BattlerIndex.PLAYER_2 ]); + game.doSelectPartyPokemon(0, "MoveEffectPhase"); + await game.toNextTurn(); + + expect(game.scene.getPlayerField()[0]).toBe(treecko); + expect(getHeldItemCount(treecko)).toBeLessThan(treeckoInitialHeldItems); + expect(treecko.getEffectiveStat(Stat.SPD)).toBe(initialSpeed); + }); +}); diff --git a/src/test/abilities/unseen_fist.test.ts b/src/test/abilities/unseen_fist.test.ts index 813880c7326..f8fa8a723fe 100644 --- a/src/test/abilities/unseen_fist.test.ts +++ b/src/test/abilities/unseen_fist.test.ts @@ -8,7 +8,6 @@ import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; import { BattlerTagType } from "#app/enums/battler-tag-type"; import { BerryPhase } from "#app/phases/berry-phase"; -const TIMEOUT = 20 * 1000; describe("Abilities - Unseen Fist", () => { let phaserGame: Phaser.Game; @@ -29,7 +28,7 @@ describe("Abilities - Unseen Fist", () => { game.override.battleType("single"); game.override.starterSpecies(Species.URSHIFU); game.override.enemySpecies(Species.SNORLAX); - game.override.enemyMoveset([Moves.PROTECT, Moves.PROTECT, Moves.PROTECT, Moves.PROTECT]); + game.override.enemyMoveset([ Moves.PROTECT, Moves.PROTECT, Moves.PROTECT, Moves.PROTECT ]); game.override.startingLevel(100); game.override.enemyLevel(100); }); @@ -37,13 +36,11 @@ describe("Abilities - Unseen Fist", () => { it( "should cause a contact move to ignore Protect", () => testUnseenFistHitResult(game, Moves.QUICK_ATTACK, Moves.PROTECT, true), - TIMEOUT ); it( "should not cause a non-contact move to ignore Protect", () => testUnseenFistHitResult(game, Moves.ABSORB, Moves.PROTECT, false), - TIMEOUT ); it( @@ -51,26 +48,24 @@ describe("Abilities - Unseen Fist", () => { () => { game.override.passiveAbility(Abilities.LONG_REACH); testUnseenFistHitResult(game, Moves.QUICK_ATTACK, Moves.PROTECT, false); - }, TIMEOUT + } ); it( "should cause a contact move to ignore Wide Guard", () => testUnseenFistHitResult(game, Moves.BREAKING_SWIPE, Moves.WIDE_GUARD, true), - TIMEOUT ); it( "should not cause a non-contact move to ignore Wide Guard", () => testUnseenFistHitResult(game, Moves.BULLDOZE, Moves.WIDE_GUARD, false), - TIMEOUT ); it( "should cause a contact move to ignore Protect, but not Substitute", async () => { game.override.enemyLevel(1); - game.override.moveset([Moves.TACKLE]); + game.override.moveset([ Moves.TACKLE ]); await game.startBattle(); @@ -83,13 +78,13 @@ describe("Abilities - Unseen Fist", () => { expect(enemyPokemon.getTag(BattlerTagType.SUBSTITUTE)).toBeUndefined(); expect(enemyPokemon.hp).toBe(enemyPokemon.getMaxHp()); - }, TIMEOUT + } ); }); async function testUnseenFistHitResult(game: GameManager, attackMove: Moves, protectMove: Moves, shouldSucceed: boolean = true): Promise { - game.override.moveset([attackMove]); - game.override.enemyMoveset([protectMove, protectMove, protectMove, protectMove]); + game.override.moveset([ attackMove ]); + game.override.enemyMoveset([ protectMove, protectMove, protectMove, protectMove ]); await game.startBattle(); diff --git a/src/test/abilities/volt_absorb.test.ts b/src/test/abilities/volt_absorb.test.ts index 7f3e160c7d0..4fee7653b99 100644 --- a/src/test/abilities/volt_absorb.test.ts +++ b/src/test/abilities/volt_absorb.test.ts @@ -7,6 +7,7 @@ import { Species } from "#enums/species"; import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; +import { BattlerIndex } from "#app/battle"; // See also: TypeImmunityAbAttr describe("Abilities - Volt Absorb", () => { @@ -33,13 +34,13 @@ describe("Abilities - Volt Absorb", () => { const moveToUse = Moves.CHARGE; const ability = Abilities.VOLT_ABSORB; - game.override.moveset([moveToUse]); + game.override.moveset([ moveToUse ]); game.override.ability(ability); - game.override.enemyMoveset([Moves.SPLASH, Moves.NONE, Moves.NONE, Moves.NONE]); + game.override.enemyMoveset([ Moves.SPLASH, Moves.NONE, Moves.NONE, Moves.NONE ]); game.override.enemySpecies(Species.DUSKULL); game.override.enemyAbility(Abilities.BALL_FETCH); - await game.startBattle(); + await game.classicMode.startBattle(); const playerPokemon = game.scene.getPlayerPokemon()!; @@ -51,4 +52,42 @@ describe("Abilities - Volt Absorb", () => { expect(playerPokemon.getTag(BattlerTagType.CHARGED)).toBeDefined(); expect(game.phaseInterceptor.log).not.toContain("ShowAbilityPhase"); }); + + it("should activate regardless of accuracy checks", async () => { + game.override.moveset(Moves.THUNDERBOLT); + game.override.enemyMoveset(Moves.SPLASH); + game.override.enemySpecies(Species.MAGIKARP); + game.override.enemyAbility(Abilities.VOLT_ABSORB); + + await game.classicMode.startBattle(); + + const enemyPokemon = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.THUNDERBOLT); + enemyPokemon.hp = enemyPokemon.hp - 1; + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); + await game.phaseInterceptor.to("MoveEffectPhase"); + + await game.move.forceMiss(); + await game.phaseInterceptor.to("BerryPhase", false); + expect(enemyPokemon.hp).toBe(enemyPokemon.getMaxHp()); + }); + + it("regardless of accuracy should not trigger on pokemon in semi invulnerable state", async () => { + game.override.moveset(Moves.THUNDERBOLT); + game.override.enemyMoveset(Moves.DIVE); + game.override.enemySpecies(Species.MAGIKARP); + game.override.enemyAbility(Abilities.VOLT_ABSORB); + + await game.classicMode.startBattle(); + + const enemyPokemon = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.THUNDERBOLT); + enemyPokemon.hp = enemyPokemon.hp - 1; + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); + + await game.phaseInterceptor.to("BerryPhase", false); + expect(enemyPokemon.hp).toBeLessThan(enemyPokemon.getMaxHp()); + }); }); diff --git a/src/test/abilities/wimp_out.test.ts b/src/test/abilities/wimp_out.test.ts new file mode 100644 index 00000000000..4283386b248 --- /dev/null +++ b/src/test/abilities/wimp_out.test.ts @@ -0,0 +1,635 @@ +import { BattlerIndex } from "#app/battle"; +import { ArenaTagSide } from "#app/data/arena-tag"; +import { allMoves } from "#app/data/move"; +import GameManager from "#app/test/utils/gameManager"; +import { Abilities } from "#enums/abilities"; +import { ArenaTagType } from "#enums/arena-tag-type"; +import { BattlerTagType } from "#enums/battler-tag-type"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import { Stat } from "#enums/stat"; +import { StatusEffect } from "#enums/status-effect"; +import { WeatherType } from "#enums/weather-type"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; + +describe("Abilities - Wimp Out", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .battleType("single") + .ability(Abilities.WIMP_OUT) + .enemySpecies(Species.NINJASK) + .enemyPassiveAbility(Abilities.NO_GUARD) + .startingLevel(90) + .enemyLevel(70) + .moveset([ Moves.SPLASH, Moves.FALSE_SWIPE, Moves.ENDURE ]) + .enemyMoveset(Moves.FALSE_SWIPE) + .disableCrits(); + }); + + function confirmSwitch(): void { + const [ pokemon1, pokemon2 ] = game.scene.getPlayerParty(); + + expect(game.phaseInterceptor.log).toContain("SwitchSummonPhase"); + + expect(pokemon1.species.speciesId).not.toBe(Species.WIMPOD); + + expect(pokemon2.species.speciesId).toBe(Species.WIMPOD); + expect(pokemon2.isFainted()).toBe(false); + expect(pokemon2.getHpRatio()).toBeLessThan(0.5); + } + + function confirmNoSwitch(): void { + const [ pokemon1, pokemon2 ] = game.scene.getPlayerParty(); + + expect(game.phaseInterceptor.log).not.toContain("SwitchSummonPhase"); + + expect(pokemon2.species.speciesId).not.toBe(Species.WIMPOD); + + expect(pokemon1.species.speciesId).toBe(Species.WIMPOD); + expect(pokemon1.isFainted()).toBe(false); + expect(pokemon1.getHpRatio()).toBeLessThan(0.5); + } + + it("triggers regenerator passive single time when switching out with wimp out", async () => { + game.override + .passiveAbility(Abilities.REGENERATOR) + .startingLevel(5) + .enemyLevel(100); + await game.classicMode.startBattle([ + Species.WIMPOD, + Species.TYRUNT + ]); + + const wimpod = game.scene.getPlayerPokemon()!; + + game.move.select(Moves.SPLASH); + game.doSelectPartyPokemon(1); + await game.phaseInterceptor.to("TurnEndPhase"); + + expect(wimpod.hp).toEqual(Math.floor(wimpod.getMaxHp() * 0.33 + 1)); + confirmSwitch(); + }); + + it("It makes wild pokemon flee if triggered", async () => { + game.override.enemyAbility(Abilities.WIMP_OUT); + await game.classicMode.startBattle([ + Species.GOLISOPOD, + Species.TYRUNT + ]); + + const enemyPokemon = game.scene.getEnemyPokemon()!; + enemyPokemon.hp *= 0.52; + + game.move.select(Moves.FALSE_SWIPE); + await game.phaseInterceptor.to("BerryPhase"); + + const isVisible = enemyPokemon.visible; + const hasFled = enemyPokemon.switchOutStatus; + expect(!isVisible && hasFled).toBe(true); + }); + + it("Does not trigger when HP already below half", async () => { + await game.classicMode.startBattle([ + Species.WIMPOD, + Species.TYRUNT + ]); + const wimpod = game.scene.getPlayerPokemon()!; + wimpod.hp = 5; + + game.move.select(Moves.SPLASH); + await game.phaseInterceptor.to("TurnEndPhase"); + + expect(wimpod.hp).toEqual(1); + confirmNoSwitch(); + }); + + it("Trapping moves do not prevent Wimp Out from activating.", async () => { + game.override + .enemyMoveset([ Moves.SPIRIT_SHACKLE ]) + .startingLevel(53) + .enemyLevel(45); + await game.classicMode.startBattle([ + Species.WIMPOD, + Species.TYRUNT + ]); + + game.move.select(Moves.SPLASH); + game.doSelectPartyPokemon(1); + + await game.phaseInterceptor.to("TurnEndPhase"); + + expect(game.phaseInterceptor.log).toContain("SwitchSummonPhase"); + expect(game.scene.getPlayerPokemon()!.getTag(BattlerTagType.TRAPPED)).toBeUndefined(); + expect(game.scene.getPlayerParty()[1].getTag(BattlerTagType.TRAPPED)).toBeUndefined(); + confirmSwitch(); + }); + + it("If this Ability activates due to being hit by U-turn or Volt Switch, the user of that move will not be switched out.", async () => { + game.override + .startingLevel(95) + .enemyMoveset([ Moves.U_TURN ]); + await game.classicMode.startBattle([ + Species.WIMPOD, + Species.TYRUNT + ]); + + game.move.select(Moves.SPLASH); + game.doSelectPartyPokemon(1); + await game.phaseInterceptor.to("TurnEndPhase"); + + const enemyPokemon = game.scene.getEnemyPokemon()!; + const hasFled = enemyPokemon.switchOutStatus; + expect(hasFled).toBe(false); + confirmSwitch(); + }); + + it("If this Ability does not activate due to being hit by U-turn or Volt Switch, the user of that move will be switched out.", async () => { + game.override + .startingLevel(190) + .startingWave(8) + .enemyMoveset([ Moves.U_TURN ]); + await game.classicMode.startBattle([ + Species.GOLISOPOD, + Species.TYRUNT + ]); + const RIVAL_NINJASK1 = game.scene.getEnemyPokemon()?.id; + game.move.select(Moves.SPLASH); + await game.phaseInterceptor.to("BerryPhase", false); + expect(game.scene.getEnemyPokemon()?.id !== RIVAL_NINJASK1); + }); + + it("Dragon Tail and Circle Throw switch out Pokémon before the Ability activates.", async () => { + game.override + .startingLevel(69) + .enemyMoveset([ Moves.DRAGON_TAIL ]); + await game.classicMode.startBattle([ + Species.WIMPOD, + Species.TYRUNT + ]); + + const wimpod = game.scene.getPlayerPokemon()!; + + game.move.select(Moves.SPLASH); + game.doSelectPartyPokemon(1); + await game.phaseInterceptor.to("SwitchSummonPhase", false); + + expect(wimpod.summonData.abilitiesApplied).not.toContain(Abilities.WIMP_OUT); + + await game.phaseInterceptor.to("TurnEndPhase"); + + expect(game.scene.getPlayerPokemon()!.species.speciesId).not.toBe(Species.WIMPOD); + }); + + it("triggers when recoil damage is taken", async () => { + game.override + .moveset([ Moves.HEAD_SMASH ]) + .enemyMoveset([ Moves.SPLASH ]); + await game.classicMode.startBattle([ + Species.WIMPOD, + Species.TYRUNT + ]); + + game.move.select(Moves.HEAD_SMASH); + game.doSelectPartyPokemon(1); + await game.phaseInterceptor.to("TurnEndPhase"); + + confirmSwitch(); + }); + + it("It does not activate when the Pokémon cuts its own HP", async () => { + game.override + .moveset([ Moves.SUBSTITUTE ]) + .enemyMoveset([ Moves.SPLASH ]); + await game.classicMode.startBattle([ + Species.WIMPOD, + Species.TYRUNT + ]); + + const wimpod = game.scene.getPlayerPokemon()!; + wimpod.hp *= 0.52; + + game.move.select(Moves.SUBSTITUTE); + await game.phaseInterceptor.to("TurnEndPhase"); + + confirmNoSwitch(); + }); + + it("Does not trigger when neutralized", async () => { + game.override + .enemyAbility(Abilities.NEUTRALIZING_GAS) + .startingLevel(5); + await game.classicMode.startBattle([ + Species.WIMPOD, + Species.TYRUNT + ]); + + game.move.select(Moves.SPLASH); + await game.phaseInterceptor.to("TurnEndPhase"); + + confirmNoSwitch(); + }); + + it("If it falls below half and recovers back above half from a Shell Bell, Wimp Out will activate even after the Shell Bell recovery", async () => { + game.override + .moveset([ Moves.DOUBLE_EDGE ]) + .enemyMoveset([ Moves.SPLASH ]) + .startingHeldItems([ + { name: "SHELL_BELL", count: 3 }, + { name: "HEALING_CHARM", count: 5 }, + ]); + await game.classicMode.startBattle([ + Species.WIMPOD, + Species.TYRUNT + ]); + + game.scene.getPlayerPokemon()!.hp *= 0.75; + + game.move.select(Moves.DOUBLE_EDGE); + game.doSelectPartyPokemon(1); + await game.phaseInterceptor.to("TurnEndPhase"); + + expect(game.scene.getPlayerParty()[1].getHpRatio()).toBeGreaterThan(0.5); + expect(game.phaseInterceptor.log).toContain("SwitchSummonPhase"); + expect(game.scene.getPlayerPokemon()!.species.speciesId).toBe(Species.TYRUNT); + }); + + it("Wimp Out will activate due to weather damage", async () => { + game.override + .weather(WeatherType.HAIL) + .enemyMoveset([ Moves.SPLASH ]); + await game.classicMode.startBattle([ + Species.WIMPOD, + Species.TYRUNT + ]); + + game.scene.getPlayerPokemon()!.hp *= 0.51; + + game.move.select(Moves.SPLASH); + game.doSelectPartyPokemon(1); + await game.phaseInterceptor.to("TurnEndPhase"); + + confirmSwitch(); + }); + + it("Does not trigger when enemy has sheer force", async () => { + game.override + .enemyAbility(Abilities.SHEER_FORCE) + .enemyMoveset(Moves.SLUDGE_BOMB) + .startingLevel(95); + await game.classicMode.startBattle([ + Species.WIMPOD, + Species.TYRUNT + ]); + + game.scene.getPlayerPokemon()!.hp *= 0.51; + + game.move.select(Moves.ENDURE); + await game.phaseInterceptor.to("TurnEndPhase"); + + confirmNoSwitch(); + }); + + it("Wimp Out will activate due to post turn status damage", async () => { + game.override + .statusEffect(StatusEffect.POISON) + .enemyMoveset([ Moves.SPLASH ]); + await game.classicMode.startBattle([ + Species.WIMPOD, + Species.TYRUNT + ]); + + game.scene.getPlayerPokemon()!.hp *= 0.51; + + game.move.select(Moves.SPLASH); + game.doSelectPartyPokemon(1); + await game.toNextTurn(); + + confirmSwitch(); + }); + + it("Wimp Out will activate due to bad dreams", async () => { + game.override + .statusEffect(StatusEffect.SLEEP) + .enemyAbility(Abilities.BAD_DREAMS); + await game.classicMode.startBattle([ + Species.WIMPOD, + Species.TYRUNT + ]); + + game.scene.getPlayerPokemon()!.hp *= 0.52; + + game.move.select(Moves.SPLASH); + game.doSelectPartyPokemon(1); + await game.toNextTurn(); + + confirmSwitch(); + }); + + it("Wimp Out will activate due to leech seed", async () => { + game.override + .enemyMoveset([ Moves.LEECH_SEED ]); + await game.classicMode.startBattle([ + Species.WIMPOD, + Species.TYRUNT + ]); + game.scene.getPlayerPokemon()!.hp *= 0.52; + + game.move.select(Moves.SPLASH); + game.doSelectPartyPokemon(1); + await game.toNextTurn(); + + confirmSwitch(); + }); + + it("Wimp Out will activate due to curse damage", async () => { + game.override + .enemySpecies(Species.DUSKNOIR) + .enemyMoveset([ Moves.CURSE ]); + await game.classicMode.startBattle([ + Species.WIMPOD, + Species.TYRUNT + ]); + game.scene.getPlayerPokemon()!.hp *= 0.52; + + game.move.select(Moves.SPLASH); + game.doSelectPartyPokemon(1); + await game.toNextTurn(); + + confirmSwitch(); + }); + + it("Wimp Out will activate due to salt cure damage", async () => { + game.override + .enemySpecies(Species.NACLI) + .enemyMoveset([ Moves.SALT_CURE ]) + .enemyLevel(1); + await game.classicMode.startBattle([ + Species.WIMPOD, + Species.TYRUNT + ]); + game.scene.getPlayerPokemon()!.hp *= 0.70; + + game.move.select(Moves.SPLASH); + game.doSelectPartyPokemon(1); + await game.toNextTurn(); + + confirmSwitch(); + }); + + it("Wimp Out will activate due to damaging trap damage", async () => { + game.override + .enemySpecies(Species.MAGIKARP) + .enemyMoveset([ Moves.WHIRLPOOL ]) + .enemyLevel(1); + await game.classicMode.startBattle([ + Species.WIMPOD, + Species.TYRUNT + ]); + game.scene.getPlayerPokemon()!.hp *= 0.55; + + game.move.select(Moves.SPLASH); + game.doSelectPartyPokemon(1); + await game.toNextTurn(); + + confirmSwitch(); + }); + + it("Magic Guard passive should not allow indirect damage to trigger Wimp Out", async () => { + game.scene.arena.addTag(ArenaTagType.STEALTH_ROCK, 1, Moves.STEALTH_ROCK, 0, ArenaTagSide.ENEMY); + game.scene.arena.addTag(ArenaTagType.SPIKES, 1, Moves.SPIKES, 0, ArenaTagSide.ENEMY); + game.override + .passiveAbility(Abilities.MAGIC_GUARD) + .enemyMoveset([ Moves.LEECH_SEED ]) + .weather(WeatherType.HAIL) + .statusEffect(StatusEffect.POISON); + await game.classicMode.startBattle([ + Species.WIMPOD, + Species.TYRUNT + ]); + game.scene.getPlayerPokemon()!.hp *= 0.51; + + game.move.select(Moves.SPLASH); + await game.phaseInterceptor.to("TurnEndPhase"); + + expect(game.scene.getPlayerParty()[0].getHpRatio()).toEqual(0.51); + expect(game.phaseInterceptor.log).not.toContain("SwitchSummonPhase"); + expect(game.scene.getPlayerPokemon()!.species.speciesId).toBe(Species.WIMPOD); + }); + + it("Wimp Out activating should not cancel a double battle", async () => { + game.override + .battleType("double") + .enemyAbility(Abilities.WIMP_OUT) + .enemyMoveset([ Moves.SPLASH ]) + .enemyLevel(1); + await game.classicMode.startBattle([ + Species.WIMPOD, + Species.TYRUNT + ]); + const enemyLeadPokemon = game.scene.getEnemyParty()[0]; + const enemySecPokemon = game.scene.getEnemyParty()[1]; + + game.move.select(Moves.FALSE_SWIPE, 0, BattlerIndex.ENEMY); + game.move.select(Moves.SPLASH, 1); + + await game.phaseInterceptor.to("BerryPhase"); + + const isVisibleLead = enemyLeadPokemon.visible; + const hasFledLead = enemyLeadPokemon.switchOutStatus; + const isVisibleSec = enemySecPokemon.visible; + const hasFledSec = enemySecPokemon.switchOutStatus; + expect(!isVisibleLead && hasFledLead && isVisibleSec && !hasFledSec).toBe(true); + expect(enemyLeadPokemon.hp).toBeLessThan(enemyLeadPokemon.getMaxHp()); + expect(enemySecPokemon.hp).toEqual(enemySecPokemon.getMaxHp()); + }); + + it("Wimp Out will activate due to aftermath", async () => { + game.override + .moveset([ Moves.THUNDER_PUNCH ]) + .enemySpecies(Species.MAGIKARP) + .enemyAbility(Abilities.AFTERMATH) + .enemyMoveset([ Moves.SPLASH ]) + .enemyLevel(1); + await game.classicMode.startBattle([ + Species.WIMPOD, + Species.TYRUNT + ]); + game.scene.getPlayerPokemon()!.hp *= 0.51; + + game.move.select(Moves.THUNDER_PUNCH); + game.doSelectPartyPokemon(1); + await game.phaseInterceptor.to("TurnEndPhase"); + + confirmSwitch(); + }); + + it("Activates due to entry hazards", async () => { + game.scene.arena.addTag(ArenaTagType.STEALTH_ROCK, 1, Moves.STEALTH_ROCK, 0, ArenaTagSide.ENEMY); + game.scene.arena.addTag(ArenaTagType.SPIKES, 1, Moves.SPIKES, 0, ArenaTagSide.ENEMY); + game.override + .enemySpecies(Species.CENTISKORCH) + .enemyAbility(Abilities.WIMP_OUT) + .startingWave(4); + await game.classicMode.startBattle([ + Species.TYRUNT + ]); + + expect(game.phaseInterceptor.log).not.toContain("MovePhase"); + expect(game.phaseInterceptor.log).toContain("BattleEndPhase"); + }); + + it("Wimp Out will activate due to Nightmare", async () => { + game.override + .enemyMoveset([ Moves.NIGHTMARE ]) + .statusEffect(StatusEffect.SLEEP); + await game.classicMode.startBattle([ + Species.WIMPOD, + Species.TYRUNT + ]); + game.scene.getPlayerPokemon()!.hp *= 0.65; + + game.move.select(Moves.SPLASH); + game.doSelectPartyPokemon(1); + await game.toNextTurn(); + + confirmSwitch(); + }); + + it("triggers status on the wimp out user before a new pokemon is switched in", async () => { + game.override + .enemyMoveset(Moves.SLUDGE_BOMB) + .startingLevel(80); + await game.classicMode.startBattle([ + Species.WIMPOD, + Species.TYRUNT + ]); + vi.spyOn(allMoves[Moves.SLUDGE_BOMB], "chance", "get").mockReturnValue(100); + + game.move.select(Moves.SPLASH); + game.doSelectPartyPokemon(1); + await game.phaseInterceptor.to("TurnEndPhase"); + + expect(game.scene.getPlayerParty()[1].status?.effect).toEqual(StatusEffect.POISON); + confirmSwitch(); + }); + + it("triggers after last hit of multi hit move", async () => { + game.override + .enemyMoveset(Moves.BULLET_SEED) + .enemyAbility(Abilities.SKILL_LINK); + await game.classicMode.startBattle([ + Species.WIMPOD, + Species.TYRUNT + ]); + + game.scene.getPlayerPokemon()!.hp *= 0.51; + + game.move.select(Moves.ENDURE); + game.doSelectPartyPokemon(1); + await game.phaseInterceptor.to("TurnEndPhase"); + + const enemyPokemon = game.scene.getEnemyPokemon()!; + expect(enemyPokemon.turnData.hitsLeft).toBe(0); + expect(enemyPokemon.turnData.hitCount).toBe(5); + confirmSwitch(); + }); + + it("triggers after last hit of multi hit move (multi lens)", async () => { + game.override + .enemyMoveset(Moves.TACKLE) + .enemyHeldItems([{ name: "MULTI_LENS", count: 1 }]); + await game.classicMode.startBattle([ + Species.WIMPOD, + Species.TYRUNT + ]); + + game.scene.getPlayerPokemon()!.hp *= 0.51; + + game.move.select(Moves.ENDURE); + game.doSelectPartyPokemon(1); + await game.phaseInterceptor.to("TurnEndPhase"); + + const enemyPokemon = game.scene.getEnemyPokemon()!; + expect(enemyPokemon.turnData.hitsLeft).toBe(0); + expect(enemyPokemon.turnData.hitCount).toBe(2); + confirmSwitch(); + }); + it("triggers after last hit of Parental Bond", async () => { + game.override + .enemyMoveset(Moves.TACKLE) + .enemyAbility(Abilities.PARENTAL_BOND); + await game.classicMode.startBattle([ + Species.WIMPOD, + Species.TYRUNT + ]); + + game.scene.getPlayerPokemon()!.hp *= 0.51; + + game.move.select(Moves.ENDURE); + game.doSelectPartyPokemon(1); + await game.phaseInterceptor.to("TurnEndPhase"); + + const enemyPokemon = game.scene.getEnemyPokemon()!; + expect(enemyPokemon.turnData.hitsLeft).toBe(0); + expect(enemyPokemon.turnData.hitCount).toBe(2); + confirmSwitch(); + }); + + // TODO: This interaction is not implemented yet + it.todo("Wimp Out will not activate if the Pokémon's HP falls below half due to hurting itself in confusion", async () => { + game.override + .moveset([ Moves.SWORDS_DANCE ]) + .enemyMoveset([ Moves.SWAGGER ]); + await game.classicMode.startBattle([ + Species.WIMPOD, + Species.TYRUNT + ]); + const playerPokemon = game.scene.getPlayerPokemon()!; + playerPokemon.hp *= 0.51; + playerPokemon.setStatStage(Stat.ATK, 6); + playerPokemon.addTag(BattlerTagType.CONFUSED); + + // TODO: add helper function to force confusion self-hits + + while (playerPokemon.getHpRatio() > 0.49) { + game.move.select(Moves.SWORDS_DANCE); + await game.phaseInterceptor.to("TurnEndPhase"); + } + + confirmNoSwitch(); + }); + + it("should not activate on wave X0 bosses", async () => { + game.override.enemyAbility(Abilities.WIMP_OUT) + .startingLevel(5850) + .startingWave(10); + await game.classicMode.startBattle([ Species.GOLISOPOD ]); + + const enemyPokemon = game.scene.getEnemyPokemon()!; + + // Use 2 turns of False Swipe due to opponent's health bar shield + game.move.select(Moves.FALSE_SWIPE); + await game.toNextTurn(); + game.move.select(Moves.FALSE_SWIPE); + await game.toNextTurn(); + + const isVisible = enemyPokemon.visible; + const hasFled = enemyPokemon.switchOutStatus; + expect(isVisible && !hasFled).toBe(true); + }); +}); diff --git a/src/test/abilities/wind_power.test.ts b/src/test/abilities/wind_power.test.ts index 12b8d2f2299..538b65f898b 100644 --- a/src/test/abilities/wind_power.test.ts +++ b/src/test/abilities/wind_power.test.ts @@ -26,12 +26,12 @@ describe("Abilities - Wind Power", () => { game.override.battleType("single"); game.override.enemySpecies(Species.SHIFTRY); game.override.enemyAbility(Abilities.WIND_POWER); - game.override.moveset([Moves.TAILWIND, Moves.SPLASH, Moves.PETAL_BLIZZARD, Moves.SANDSTORM]); + game.override.moveset([ Moves.TAILWIND, Moves.SPLASH, Moves.PETAL_BLIZZARD, Moves.SANDSTORM ]); game.override.enemyMoveset(Moves.SPLASH); }); it("it becomes charged when hit by wind moves", async () => { - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const shiftry = game.scene.getEnemyPokemon()!; expect(shiftry.getTag(BattlerTagType.CHARGED)).toBeUndefined(); @@ -46,7 +46,7 @@ describe("Abilities - Wind Power", () => { game.override.ability(Abilities.WIND_POWER); game.override.enemySpecies(Species.MAGIKARP); - await game.startBattle([Species.SHIFTRY]); + await game.startBattle([ Species.SHIFTRY ]); const shiftry = game.scene.getPlayerPokemon()!; expect(shiftry.getTag(BattlerTagType.CHARGED)).toBeUndefined(); @@ -61,7 +61,7 @@ describe("Abilities - Wind Power", () => { game.override.enemySpecies(Species.MAGIKARP); game.override.ability(Abilities.WIND_POWER); - await game.startBattle([Species.SHIFTRY]); + await game.startBattle([ Species.SHIFTRY ]); const magikarp = game.scene.getEnemyPokemon()!; const shiftry = game.scene.getPlayerPokemon()!; @@ -79,7 +79,7 @@ describe("Abilities - Wind Power", () => { it("does not interact with Sandstorm", async () => { game.override.enemySpecies(Species.MAGIKARP); - await game.startBattle([Species.SHIFTRY]); + await game.startBattle([ Species.SHIFTRY ]); const shiftry = game.scene.getPlayerPokemon()!; expect(shiftry.getTag(BattlerTagType.CHARGED)).toBeUndefined(); diff --git a/src/test/abilities/wind_rider.test.ts b/src/test/abilities/wind_rider.test.ts index c917f56e101..cd7094fb0a9 100644 --- a/src/test/abilities/wind_rider.test.ts +++ b/src/test/abilities/wind_rider.test.ts @@ -26,7 +26,7 @@ describe("Abilities - Wind Rider", () => { .battleType("single") .enemySpecies(Species.SHIFTRY) .enemyAbility(Abilities.WIND_RIDER) - .moveset([Moves.TAILWIND, Moves.SPLASH, Moves.PETAL_BLIZZARD, Moves.SANDSTORM]) + .moveset([ Moves.TAILWIND, Moves.SPLASH, Moves.PETAL_BLIZZARD, Moves.SANDSTORM ]) .enemyMoveset(Moves.SPLASH); }); @@ -49,7 +49,7 @@ describe("Abilities - Wind Rider", () => { .enemySpecies(Species.MAGIKARP) .ability(Abilities.WIND_RIDER); - await game.classicMode.startBattle([Species.SHIFTRY]); + await game.classicMode.startBattle([ Species.SHIFTRY ]); const shiftry = game.scene.getPlayerPokemon()!; expect(shiftry.getStatStage(Stat.ATK)).toBe(0); @@ -66,7 +66,7 @@ describe("Abilities - Wind Rider", () => { .enemySpecies(Species.MAGIKARP) .ability(Abilities.WIND_RIDER); - await game.classicMode.startBattle([Species.SHIFTRY]); + await game.classicMode.startBattle([ Species.SHIFTRY ]); const magikarp = game.scene.getEnemyPokemon()!; const shiftry = game.scene.getPlayerPokemon()!; @@ -86,7 +86,7 @@ describe("Abilities - Wind Rider", () => { .enemySpecies(Species.MAGIKARP) .ability(Abilities.WIND_RIDER); - await game.classicMode.startBattle([Species.SHIFTRY]); + await game.classicMode.startBattle([ Species.SHIFTRY ]); const magikarp = game.scene.getEnemyPokemon()!; const shiftry = game.scene.getPlayerPokemon()!; @@ -104,7 +104,7 @@ describe("Abilities - Wind Rider", () => { it("does not interact with Sandstorm", async () => { game.override.enemySpecies(Species.MAGIKARP); - await game.classicMode.startBattle([Species.SHIFTRY]); + await game.classicMode.startBattle([ Species.SHIFTRY ]); const shiftry = game.scene.getPlayerPokemon()!; expect(shiftry.getStatStage(Stat.ATK)).toBe(0); diff --git a/src/test/abilities/wonder_skin.test.ts b/src/test/abilities/wonder_skin.test.ts index 6ef985fbd42..6b25701e36a 100644 --- a/src/test/abilities/wonder_skin.test.ts +++ b/src/test/abilities/wonder_skin.test.ts @@ -25,7 +25,7 @@ describe("Abilities - Wonder Skin", () => { beforeEach(() => { game = new GameManager(phaserGame); game.override.battleType("single"); - game.override.moveset([Moves.TACKLE, Moves.CHARM]); + game.override.moveset([ Moves.TACKLE, Moves.CHARM ]); game.override.ability(Abilities.BALL_FETCH); game.override.enemySpecies(Species.SHUCKLE); game.override.enemyAbility(Abilities.WONDER_SKIN); @@ -37,7 +37,7 @@ describe("Abilities - Wonder Skin", () => { vi.spyOn(moveToCheck, "calculateBattleAccuracy"); - await game.startBattle([Species.PIKACHU]); + await game.startBattle([ Species.PIKACHU ]); game.move.select(Moves.CHARM); await game.phaseInterceptor.to(MoveEffectPhase); @@ -49,14 +49,14 @@ describe("Abilities - Wonder Skin", () => { vi.spyOn(moveToCheck, "calculateBattleAccuracy"); - await game.startBattle([Species.PIKACHU]); + await game.startBattle([ Species.PIKACHU ]); game.move.select(Moves.TACKLE); await game.phaseInterceptor.to(MoveEffectPhase); expect(moveToCheck.calculateBattleAccuracy).toHaveReturnedWith(100); }); - const bypassAbilities = [Abilities.MOLD_BREAKER, Abilities.TERAVOLT, Abilities.TURBOBLAZE]; + const bypassAbilities = [ Abilities.MOLD_BREAKER, Abilities.TERAVOLT, Abilities.TURBOBLAZE ]; bypassAbilities.forEach(ability => { it(`does not affect pokemon with ${allAbilities[ability].name}`, async () => { @@ -65,7 +65,7 @@ describe("Abilities - Wonder Skin", () => { game.override.ability(ability); vi.spyOn(moveToCheck, "calculateBattleAccuracy"); - await game.startBattle([Species.PIKACHU]); + await game.startBattle([ Species.PIKACHU ]); game.move.select(Moves.CHARM); await game.phaseInterceptor.to(MoveEffectPhase); diff --git a/src/test/abilities/zen_mode.test.ts b/src/test/abilities/zen_mode.test.ts index fd378647184..e0cc457c4d5 100644 --- a/src/test/abilities/zen_mode.test.ts +++ b/src/test/abilities/zen_mode.test.ts @@ -1,29 +1,18 @@ -import { Stat } from "#enums/stat"; -import { BattlerIndex } from "#app/battle"; -import { DamagePhase } from "#app/phases/damage-phase"; -import { EnemyCommandPhase } from "#app/phases/enemy-command-phase"; -import { MessagePhase } from "#app/phases/message-phase"; -import { PostSummonPhase } from "#app/phases/post-summon-phase"; -import { QuietFormChangePhase } from "#app/phases/quiet-form-change-phase"; -import { SwitchPhase } from "#app/phases/switch-phase"; -import { SwitchSummonPhase } from "#app/phases/switch-summon-phase"; -import { TurnEndPhase } from "#app/phases/turn-end-phase"; -import { TurnInitPhase } from "#app/phases/turn-init-phase"; -import { TurnStartPhase } from "#app/phases/turn-start-phase"; -import { Mode } from "#app/ui/ui"; +import { Status } from "#app/data/status-effect"; import { Abilities } from "#enums/abilities"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; +import { StatusEffect } from "#enums/status-effect"; import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; -import { afterEach, beforeAll, beforeEach, describe, expect, test } from "vitest"; -import { Status, StatusEffect } from "#app/data/status-effect"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Abilities - ZEN MODE", () => { let phaserGame: Phaser.Game; let game: GameManager; + const baseForm = 0; + const zenForm = 1; beforeAll(() => { phaserGame = new Phaser.Game({ @@ -37,125 +26,85 @@ describe("Abilities - ZEN MODE", () => { beforeEach(() => { game = new GameManager(phaserGame); - const moveToUse = Moves.SPLASH; - game.override.battleType("single"); - game.override.enemySpecies(Species.RATTATA); - game.override.enemyAbility(Abilities.HYDRATION); - game.override.ability(Abilities.ZEN_MODE); - game.override.startingLevel(100); - game.override.moveset([moveToUse]); - game.override.enemyMoveset([Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE]); + game.override + .battleType("single") + .disableCrits() + .enemySpecies(Species.MAGIKARP) + .enemyAbility(Abilities.BALL_FETCH) + .enemyLevel(5) + .ability(Abilities.ZEN_MODE) + .moveset(Moves.SPLASH) + .enemyMoveset(Moves.SEISMIC_TOSS); }); - test( - "not enough damage to change form", - async () => { - const moveToUse = Moves.SPLASH; - await game.startBattle([Species.DARMANITAN]); - game.scene.getParty()[0].stats[Stat.HP] = 100; - game.scene.getParty()[0].hp = 100; - expect(game.scene.getParty()[0].formIndex).toBe(0); + it("shouldn't change form when taking damage if not dropping below 50% HP", async () => { + await game.classicMode.startBattle([ Species.DARMANITAN ]); + const darmanitan = game.scene.getPlayerPokemon()!; + expect(darmanitan.formIndex).toBe(baseForm); - game.move.select(moveToUse); + game.move.select(Moves.SPLASH); + await game.toNextTurn(); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); - await game.phaseInterceptor.to(DamagePhase, false); - // await game.phaseInterceptor.runFrom(DamagePhase).to(DamagePhase, false); - const damagePhase = game.scene.getCurrentPhase() as DamagePhase; - damagePhase.updateAmount(40); - await game.phaseInterceptor.runFrom(DamagePhase).to(TurnEndPhase, false); - expect(game.scene.getParty()[0].hp).toBeLessThan(100); - expect(game.scene.getParty()[0].formIndex).toBe(0); - }, - TIMEOUT - ); + expect(darmanitan.getHpRatio()).toBeLessThan(1); + expect(darmanitan.getHpRatio()).toBeGreaterThan(0.5); + expect(darmanitan.formIndex).toBe(baseForm); + }); - test( - "enough damage to change form", - async () => { - const moveToUse = Moves.SPLASH; - await game.startBattle([Species.DARMANITAN]); - game.scene.getParty()[0].stats[Stat.HP] = 1000; - game.scene.getParty()[0].hp = 100; - expect(game.scene.getParty()[0].formIndex).toBe(0); + it("should change form when falling below 50% HP", async () => { + await game.classicMode.startBattle([ Species.DARMANITAN ]); - game.move.select(moveToUse); + const darmanitan = game.scene.getPlayerPokemon()!; + darmanitan.hp = (darmanitan.getMaxHp() / 2) + 1; + expect(darmanitan.formIndex).toBe(baseForm); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); - await game.phaseInterceptor.to(QuietFormChangePhase); - await game.phaseInterceptor.to(TurnInitPhase, false); - expect(game.scene.getParty()[0].hp).not.toBe(100); - expect(game.scene.getParty()[0].formIndex).not.toBe(0); - }, - TIMEOUT - ); + game.move.select(Moves.SPLASH); + await game.toNextTurn(); - test( - "kill pokemon while on zen mode", - async () => { - const moveToUse = Moves.SPLASH; - await game.startBattle([Species.DARMANITAN, Species.CHARIZARD]); - game.scene.getParty()[0].stats[Stat.HP] = 1000; - game.scene.getParty()[0].hp = 100; - expect(game.scene.getParty()[0].formIndex).toBe(0); + expect(darmanitan.getHpRatio()).toBeLessThan(0.5); + expect(darmanitan.formIndex).toBe(zenForm); + }); - game.move.select(moveToUse); + it("should stay zen mode when fainted", async () => { + await game.classicMode.startBattle([ Species.DARMANITAN, Species.CHARIZARD ]); + const darmanitan = game.scene.getPlayerPokemon()!; + darmanitan.hp = (darmanitan.getMaxHp() / 2) + 1; + expect(darmanitan.formIndex).toBe(baseForm); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); - await game.phaseInterceptor.to(DamagePhase, false); - // await game.phaseInterceptor.runFrom(DamagePhase).to(DamagePhase, false); - const damagePhase = game.scene.getCurrentPhase() as DamagePhase; - damagePhase.updateAmount(80); - await game.phaseInterceptor.runFrom(DamagePhase).to(QuietFormChangePhase); - expect(game.scene.getParty()[0].hp).not.toBe(100); - expect(game.scene.getParty()[0].formIndex).not.toBe(0); - await game.killPokemon(game.scene.getParty()[0]); - expect(game.scene.getParty()[0].isFainted()).toBe(true); - await game.phaseInterceptor.run(MessagePhase); - await game.phaseInterceptor.run(EnemyCommandPhase); - await game.phaseInterceptor.run(TurnStartPhase); - game.onNextPrompt("SwitchPhase", Mode.PARTY, () => { - game.scene.unshiftPhase(new SwitchSummonPhase(game.scene, 0, 1, false, false)); - game.scene.ui.setMode(Mode.MESSAGE); - }); - game.onNextPrompt("SwitchPhase", Mode.MESSAGE, () => { - game.endPhase(); - }); - await game.phaseInterceptor.run(SwitchPhase); - await game.phaseInterceptor.to(PostSummonPhase); - expect(game.scene.getParty()[1].formIndex).toBe(1); - }, - TIMEOUT - ); + game.move.select(Moves.SPLASH); + await game.toNextTurn(); - test( - "check if fainted pokemon switches to base form on arena reset", - async () => { - const baseForm = 0, - zenForm = 1; - game.override.startingWave(4); - game.override.starterForms({ - [Species.DARMANITAN]: zenForm, - }); + expect(darmanitan.getHpRatio()).toBeLessThan(0.5); + expect(darmanitan.formIndex).toBe(zenForm); - await game.startBattle([Species.MAGIKARP, Species.DARMANITAN]); + game.move.select(Moves.SPLASH); + await game.killPokemon(darmanitan); + game.doSelectPartyPokemon(1); + await game.toNextTurn(); - const darmanitan = game.scene.getParty().find((p) => p.species.speciesId === Species.DARMANITAN)!; - expect(darmanitan).not.toBe(undefined); - expect(darmanitan.formIndex).toBe(zenForm); + expect(darmanitan.isFainted()).toBe(true); + expect(game.scene.getPlayerParty()[1].formIndex).toBe(zenForm); + }); - darmanitan.hp = 0; - darmanitan.status = new Status(StatusEffect.FAINT); - expect(darmanitan.isFainted()).toBe(true); + it("should switch to base form on arena reset", async () => { + game.override.startingWave(4); + game.override.starterForms({ + [Species.DARMANITAN]: zenForm, + }); - game.move.select(Moves.SPLASH); - await game.doKillOpponents(); - await game.phaseInterceptor.to(TurnEndPhase); - game.doSelectModifier(); - await game.phaseInterceptor.to(QuietFormChangePhase); + await game.classicMode.startBattle([ Species.MAGIKARP, Species.DARMANITAN ]); - expect(darmanitan.formIndex).toBe(baseForm); - }, - TIMEOUT - ); + const darmanitan = game.scene.getPlayerParty()[1]; + darmanitan.hp = 1; + expect(darmanitan.formIndex).toBe(zenForm); + + darmanitan.hp = 0; + darmanitan.status = new Status(StatusEffect.FAINT); + expect(darmanitan.isFainted()).toBe(true); + + game.move.select(Moves.SPLASH); + await game.doKillOpponents(); + await game.toNextWave(); + + expect(darmanitan.formIndex).toBe(baseForm); + }); }); diff --git a/src/test/abilities/zero_to_hero.test.ts b/src/test/abilities/zero_to_hero.test.ts index eafc32b4c79..5702f73e6c4 100644 --- a/src/test/abilities/zero_to_hero.test.ts +++ b/src/test/abilities/zero_to_hero.test.ts @@ -1,13 +1,13 @@ -import { Status, StatusEffect } from "#app/data/status-effect"; +import { Status } from "#app/data/status-effect"; import { QuietFormChangePhase } from "#app/phases/quiet-form-change-phase"; import { TurnEndPhase } from "#app/phases/turn-end-phase"; import { Abilities } from "#enums/abilities"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; +import { StatusEffect } from "#enums/status-effect"; import GameManager from "#test/utils/gameManager"; import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Abilities - ZERO TO HERO", () => { let phaserGame: Phaser.Game; @@ -40,10 +40,10 @@ describe("Abilities - ZERO TO HERO", () => { [Species.PALAFIN]: heroForm, }); - await game.startBattle([Species.FEEBAS, Species.PALAFIN, Species.PALAFIN]); + await game.startBattle([ Species.FEEBAS, Species.PALAFIN, Species.PALAFIN ]); - const palafin1 = game.scene.getParty()[1]; - const palafin2 = game.scene.getParty()[2]; + const palafin1 = game.scene.getPlayerParty()[1]; + const palafin2 = game.scene.getPlayerParty()[2]; expect(palafin1.formIndex).toBe(heroForm); expect(palafin2.formIndex).toBe(heroForm); palafin2.hp = 0; @@ -59,10 +59,10 @@ describe("Abilities - ZERO TO HERO", () => { expect(palafin1.formIndex).toBe(baseForm); expect(palafin2.formIndex).toBe(baseForm); - }, TIMEOUT); + }); it("should swap to Hero form when switching out during a battle", async () => { - await game.startBattle([Species.PALAFIN, Species.FEEBAS]); + await game.startBattle([ Species.PALAFIN, Species.FEEBAS ]); const palafin = game.scene.getPlayerPokemon()!; expect(palafin.formIndex).toBe(baseForm); @@ -70,10 +70,10 @@ describe("Abilities - ZERO TO HERO", () => { game.doSwitchPokemon(1); await game.phaseInterceptor.to(QuietFormChangePhase); expect(palafin.formIndex).toBe(heroForm); - }, TIMEOUT); + }); it("should not swap to Hero form if switching due to faint", async () => { - await game.startBattle([Species.PALAFIN, Species.FEEBAS]); + await game.startBattle([ Species.PALAFIN, Species.FEEBAS ]); const palafin = game.scene.getPlayerPokemon()!; expect(palafin.formIndex).toBe(baseForm); @@ -83,14 +83,14 @@ describe("Abilities - ZERO TO HERO", () => { game.doSelectPartyPokemon(1); await game.toNextTurn(); expect(palafin.formIndex).toBe(baseForm); - }, TIMEOUT); + }); it("should stay hero form if fainted and then revived", async () => { game.override.starterForms({ [Species.PALAFIN]: heroForm, }); - await game.startBattle([Species.PALAFIN, Species.FEEBAS]); + await game.startBattle([ Species.PALAFIN, Species.FEEBAS ]); const palafin = game.scene.getPlayerPokemon()!; expect(palafin.formIndex).toBe(heroForm); @@ -105,5 +105,5 @@ describe("Abilities - ZERO TO HERO", () => { await game.toNextTurn(); expect(palafin.formIndex).toBe(heroForm); - }, TIMEOUT); + }); }); diff --git a/src/test/account.test.ts b/src/test/account.test.ts index eb6002f3cf2..0f49014c377 100644 --- a/src/test/account.test.ts +++ b/src/test/account.test.ts @@ -1,7 +1,7 @@ import * as battleScene from "#app/battle-scene"; +import { pokerogueApi } from "#app/plugins/api/pokerogue-api"; import { describe, expect, it, vi } from "vitest"; import { initLoggedInUser, loggedInUser, updateUserInfo } from "../account"; -import * as utils from "../utils"; describe("account", () => { describe("initLoggedInUser", () => { @@ -17,7 +17,7 @@ describe("account", () => { it("should set loggedInUser! to Guest if bypassLogin is true", async () => { vi.spyOn(battleScene, "bypassLogin", "get").mockReturnValue(true); - const [success, status] = await updateUserInfo(); + const [ success, status ] = await updateUserInfo(); expect(success).toBe(true); expect(status).toBe(200); @@ -27,19 +27,18 @@ describe("account", () => { it("should fetch user info from the API if bypassLogin is false", async () => { vi.spyOn(battleScene, "bypassLogin", "get").mockReturnValue(false); - vi.spyOn(utils, "apiFetch").mockResolvedValue( - new Response( - JSON.stringify({ - username: "test", - lastSessionSlot: 99, - }), - { - status: 200, - } - ) - ); + vi.spyOn(pokerogueApi.account, "getInfo").mockResolvedValue([ + { + username: "test", + lastSessionSlot: 99, + discordId: "", + googleId: "", + hasAdminRole: false, + }, + 200, + ]); - const [success, status] = await updateUserInfo(); + const [ success, status ] = await updateUserInfo(); expect(success).toBe(true); expect(status).toBe(200); @@ -49,26 +48,22 @@ describe("account", () => { it("should handle resolved API errors", async () => { vi.spyOn(battleScene, "bypassLogin", "get").mockReturnValue(false); - vi.spyOn(utils, "apiFetch").mockResolvedValue( - new Response(null, { status: 401 }) - ); + vi.spyOn(pokerogueApi.account, "getInfo").mockResolvedValue([ null, 401 ]); - const [success, status] = await updateUserInfo(); + const [ success, status ] = await updateUserInfo(); expect(success).toBe(false); expect(status).toBe(401); }); - it("should handle rejected API errors", async () => { - const consoleErrorSpy = vi.spyOn(console, "error"); + it("should handle 500 API errors", async () => { vi.spyOn(battleScene, "bypassLogin", "get").mockReturnValue(false); - vi.spyOn(utils, "apiFetch").mockRejectedValue(new Error("Api failed!")); + vi.spyOn(pokerogueApi.account, "getInfo").mockResolvedValue([ null, 500 ]); - const [success, status] = await updateUserInfo(); + const [ success, status ] = await updateUserInfo(); expect(success).toBe(false); expect(status).toBe(500); - expect(consoleErrorSpy).toHaveBeenCalled(); }); }); }); diff --git a/src/test/achievements/achievement.test.ts b/src/test/achievements/achievement.test.ts index 24d00a3e77b..a3669c60463 100644 --- a/src/test/achievements/achievement.test.ts +++ b/src/test/achievements/achievement.test.ts @@ -61,8 +61,8 @@ describe("Achv", () => { const conditionFunc = vi.fn((scene: BattleScene, args: any[]) => args[0] === 10); const achv = new Achv("", "Test Achievement", "Test Description", "test_icon", 10, conditionFunc); - expect(achv.validate(new BattleScene(), [5])).toBe(false); - expect(achv.validate(new BattleScene(), [10])).toBe(true); + expect(achv.validate(new BattleScene(), [ 5 ])).toBe(false); + expect(achv.validate(new BattleScene(), [ 10 ])).toBe(true); expect(conditionFunc).toHaveBeenCalledTimes(2); }); }); @@ -141,10 +141,10 @@ describe("DamageAchv", () => { const scene = new BattleScene(); const numberHolder = new NumberHolder(200); - expect(damageAchv.validate(scene, [numberHolder])).toBe(false); + expect(damageAchv.validate(scene, [ numberHolder ])).toBe(false); numberHolder.value = 300; - expect(damageAchv.validate(scene, [numberHolder])).toBe(true); + expect(damageAchv.validate(scene, [ numberHolder ])).toBe(true); }); }); @@ -160,10 +160,10 @@ describe("HealAchv", () => { const scene = new BattleScene(); const numberHolder = new NumberHolder(200); - expect(healAchv.validate(scene, [numberHolder])).toBe(false); + expect(healAchv.validate(scene, [ numberHolder ])).toBe(false); numberHolder.value = 300; - expect(healAchv.validate(scene, [numberHolder])).toBe(true); + expect(healAchv.validate(scene, [ numberHolder ])).toBe(true); }); }); @@ -179,10 +179,10 @@ describe("LevelAchv", () => { const scene = new BattleScene(); const integerHolder = new IntegerHolder(50); - expect(levelAchv.validate(scene, [integerHolder])).toBe(false); + expect(levelAchv.validate(scene, [ integerHolder ])).toBe(false); integerHolder.value = 150; - expect(levelAchv.validate(scene, [integerHolder])).toBe(true); + expect(levelAchv.validate(scene, [ integerHolder ])).toBe(true); }); }); @@ -198,7 +198,7 @@ describe("ModifierAchv", () => { const scene = new BattleScene(); const modifier = new TurnHeldItemTransferModifier(null!, 3, 1); - expect(modifierAchv.validate(scene, [modifier])).toBe(true); + expect(modifierAchv.validate(scene, [ modifier ])).toBe(true); }); }); diff --git a/src/test/arena/arena_gravity.test.ts b/src/test/arena/arena_gravity.test.ts index 47b8bf4cf70..13e9c23a35c 100644 --- a/src/test/arena/arena_gravity.test.ts +++ b/src/test/arena/arena_gravity.test.ts @@ -1,8 +1,8 @@ +import { BattlerIndex } from "#app/battle"; import { allMoves } from "#app/data/move"; -import { Abilities } from "#app/enums/abilities"; -import { ArenaTagType } from "#app/enums/arena-tag-type"; -import { MoveEffectPhase } from "#app/phases/move-effect-phase"; -import { TurnEndPhase } from "#app/phases/turn-end-phase"; +import { Abilities } from "#enums/abilities"; +import { ArenaTagType } from "#enums/arena-tag-type"; +import { BattlerTagType } from "#enums/battler-tag-type"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; import GameManager from "#test/utils/gameManager"; @@ -27,11 +27,12 @@ describe("Arena - Gravity", () => { game = new GameManager(phaserGame); game.override .battleType("single") - .moveset([Moves.TACKLE, Moves.GRAVITY, Moves.FISSURE]) + .moveset([ Moves.TACKLE, Moves.GRAVITY, Moves.FISSURE ]) .ability(Abilities.UNNERVE) .enemyAbility(Abilities.BALL_FETCH) .enemySpecies(Species.SHUCKLE) - .enemyMoveset(Moves.SPLASH); + .enemyMoveset(Moves.SPLASH) + .enemyLevel(5); }); // Reference: https://bulbapedia.bulbagarden.net/wiki/Gravity_(move) @@ -42,102 +43,121 @@ describe("Arena - Gravity", () => { vi.spyOn(moveToCheck, "calculateBattleAccuracy"); // Setup Gravity on first turn - await game.startBattle([Species.PIKACHU]); + await game.classicMode.startBattle([ Species.PIKACHU ]); game.move.select(Moves.GRAVITY); - await game.phaseInterceptor.to(TurnEndPhase); + await game.phaseInterceptor.to("TurnEndPhase"); expect(game.scene.arena.getTag(ArenaTagType.GRAVITY)).toBeDefined(); // Use non-OHKO move on second turn await game.toNextTurn(); game.move.select(Moves.TACKLE); - await game.phaseInterceptor.to(MoveEffectPhase); + await game.phaseInterceptor.to("MoveEffectPhase"); - expect(moveToCheck.calculateBattleAccuracy).toHaveReturnedWith(100 * 1.67); + expect(moveToCheck.calculateBattleAccuracy).toHaveLastReturnedWith(100 * 1.67); }); it("OHKO move accuracy is not affected", async () => { - game.override.startingLevel(5); - game.override.enemyLevel(5); - /** See Fissure {@link https://bulbapedia.bulbagarden.net/wiki/Fissure_(move)} */ const moveToCheck = allMoves[Moves.FISSURE]; vi.spyOn(moveToCheck, "calculateBattleAccuracy"); // Setup Gravity on first turn - await game.startBattle([Species.PIKACHU]); + await game.classicMode.startBattle([ Species.PIKACHU ]); game.move.select(Moves.GRAVITY); - await game.phaseInterceptor.to(TurnEndPhase); + await game.phaseInterceptor.to("TurnEndPhase"); expect(game.scene.arena.getTag(ArenaTagType.GRAVITY)).toBeDefined(); // Use OHKO move on second turn await game.toNextTurn(); game.move.select(Moves.FISSURE); - await game.phaseInterceptor.to(MoveEffectPhase); + await game.phaseInterceptor.to("MoveEffectPhase"); - expect(moveToCheck.calculateBattleAccuracy).toHaveReturnedWith(30); + expect(moveToCheck.calculateBattleAccuracy).toHaveLastReturnedWith(30); }); describe("Against flying types", () => { it("can be hit by ground-type moves now", async () => { game.override - .startingLevel(5) - .enemyLevel(5) .enemySpecies(Species.PIDGEOT) - .moveset([Moves.GRAVITY, Moves.EARTHQUAKE]); + .moveset([ Moves.GRAVITY, Moves.EARTHQUAKE ]); - await game.startBattle([Species.PIKACHU]); + await game.classicMode.startBattle([ Species.PIKACHU ]); const pidgeot = game.scene.getEnemyPokemon()!; vi.spyOn(pidgeot, "getAttackTypeEffectiveness"); // Try earthquake on 1st turn (fails!); game.move.select(Moves.EARTHQUAKE); - await game.phaseInterceptor.to(TurnEndPhase); + await game.phaseInterceptor.to("TurnEndPhase"); - expect(pidgeot.getAttackTypeEffectiveness).toHaveReturnedWith(0); + expect(pidgeot.getAttackTypeEffectiveness).toHaveLastReturnedWith(0); // Setup Gravity on 2nd turn await game.toNextTurn(); game.move.select(Moves.GRAVITY); - await game.phaseInterceptor.to(TurnEndPhase); + await game.phaseInterceptor.to("TurnEndPhase"); expect(game.scene.arena.getTag(ArenaTagType.GRAVITY)).toBeDefined(); // Use ground move on 3rd turn await game.toNextTurn(); game.move.select(Moves.EARTHQUAKE); - await game.phaseInterceptor.to(TurnEndPhase); + await game.phaseInterceptor.to("TurnEndPhase"); - expect(pidgeot.getAttackTypeEffectiveness).toHaveReturnedWith(1); + expect(pidgeot.getAttackTypeEffectiveness).toHaveLastReturnedWith(1); }); it("keeps super-effective moves super-effective after using gravity", async () => { game.override - .startingLevel(5) - .enemyLevel(5) .enemySpecies(Species.PIDGEOT) - .moveset([Moves.GRAVITY, Moves.THUNDERBOLT]); + .moveset([ Moves.GRAVITY, Moves.THUNDERBOLT ]); - await game.startBattle([Species.PIKACHU]); + await game.classicMode.startBattle([ Species.PIKACHU ]); const pidgeot = game.scene.getEnemyPokemon()!; vi.spyOn(pidgeot, "getAttackTypeEffectiveness"); // Setup Gravity on 1st turn game.move.select(Moves.GRAVITY); - await game.phaseInterceptor.to(TurnEndPhase); + await game.phaseInterceptor.to("TurnEndPhase"); expect(game.scene.arena.getTag(ArenaTagType.GRAVITY)).toBeDefined(); // Use electric move on 2nd turn await game.toNextTurn(); game.move.select(Moves.THUNDERBOLT); - await game.phaseInterceptor.to(TurnEndPhase); + await game.phaseInterceptor.to("TurnEndPhase"); - expect(pidgeot.getAttackTypeEffectiveness).toHaveReturnedWith(2); + expect(pidgeot.getAttackTypeEffectiveness).toHaveLastReturnedWith(2); }); }); + + it("cancels Fly if its user is semi-invulnerable", async () => { + game.override + .enemySpecies(Species.SNORLAX) + .enemyMoveset(Moves.FLY) + .moveset([ Moves.GRAVITY, Moves.SPLASH ]); + + await game.classicMode.startBattle([ Species.CHARIZARD ]); + + const charizard = game.scene.getPlayerPokemon()!; + const snorlax = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.SPLASH); + + await game.toNextTurn(); + expect(snorlax.getTag(BattlerTagType.FLYING)).toBeDefined(); + + game.move.select(Moves.GRAVITY); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + + await game.phaseInterceptor.to("MoveEffectPhase"); + expect(snorlax.getTag(BattlerTagType.INTERRUPTED)).toBeDefined(); + + await game.phaseInterceptor.to("TurnEndPhase"); + expect(charizard.hp).toBe(charizard.getMaxHp()); + }); }); diff --git a/src/test/arena/grassy_terrain.test.ts b/src/test/arena/grassy_terrain.test.ts index efb2539885d..ead4467925b 100644 --- a/src/test/arena/grassy_terrain.test.ts +++ b/src/test/arena/grassy_terrain.test.ts @@ -9,8 +9,6 @@ import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vite describe("Arena - Grassy Terrain", () => { let phaserGame: Phaser.Game; let game: GameManager; - const TIMEOUT = 20 * 1000; - beforeAll(() => { phaserGame = new Phaser.Game({ type: Phaser.HEADLESS, @@ -30,12 +28,12 @@ describe("Arena - Grassy Terrain", () => { .enemySpecies(Species.SHUCKLE) .enemyAbility(Abilities.STURDY) .enemyMoveset(Moves.FLY) - .moveset([Moves.GRASSY_TERRAIN, Moves.EARTHQUAKE]) + .moveset([ Moves.GRASSY_TERRAIN, Moves.EARTHQUAKE ]) .ability(Abilities.NO_GUARD); }); it("halves the damage of Earthquake", async () => { - await game.classicMode.startBattle([Species.TAUROS]); + await game.classicMode.startBattle([ Species.TAUROS ]); const eq = allMoves[Moves.EARTHQUAKE]; vi.spyOn(eq, "calculateBattlePower"); @@ -52,10 +50,10 @@ describe("Arena - Grassy Terrain", () => { await game.phaseInterceptor.to("BerryPhase"); expect(eq.calculateBattlePower).toHaveReturnedWith(50); - }, TIMEOUT); + }); it("Does not halve the damage of Earthquake if opponent is not grounded", async () => { - await game.classicMode.startBattle([Species.NINJASK]); + await game.classicMode.startBattle([ Species.NINJASK ]); const eq = allMoves[Moves.EARTHQUAKE]; vi.spyOn(eq, "calculateBattlePower"); @@ -67,5 +65,5 @@ describe("Arena - Grassy Terrain", () => { await game.phaseInterceptor.to("BerryPhase"); expect(eq.calculateBattlePower).toHaveReturnedWith(100); - }, TIMEOUT); + }); }); diff --git a/src/test/arena/weather_fog.test.ts b/src/test/arena/weather_fog.test.ts index b47145e8dd0..8c1fcb1e3a4 100644 --- a/src/test/arena/weather_fog.test.ts +++ b/src/test/arena/weather_fog.test.ts @@ -1,9 +1,9 @@ import { allMoves } from "#app/data/move"; -import { WeatherType } from "#app/data/weather"; import { Abilities } from "#app/enums/abilities"; import { MoveEffectPhase } from "#app/phases/move-effect-phase"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; +import { WeatherType } from "#enums/weather-type"; import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; @@ -27,11 +27,11 @@ describe("Weather - Fog", () => { game.override .weather(WeatherType.FOG) .battleType("single"); - game.override.moveset([Moves.TACKLE]); + game.override.moveset([ Moves.TACKLE ]); game.override.ability(Abilities.BALL_FETCH); game.override.enemyAbility(Abilities.BALL_FETCH); game.override.enemySpecies(Species.MAGIKARP); - game.override.enemyMoveset([Moves.SPLASH]); + game.override.enemyMoveset([ Moves.SPLASH ]); }); it("move accuracy is multiplied by 90%", async () => { @@ -39,7 +39,7 @@ describe("Weather - Fog", () => { vi.spyOn(moveToCheck, "calculateBattleAccuracy"); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); game.move.select(Moves.TACKLE); await game.phaseInterceptor.to(MoveEffectPhase); diff --git a/src/test/arena/weather_hail.test.ts b/src/test/arena/weather_hail.test.ts index 31d20be2ded..0b267550d75 100644 --- a/src/test/arena/weather_hail.test.ts +++ b/src/test/arena/weather_hail.test.ts @@ -1,10 +1,10 @@ -import { WeatherType } from "#app/data/weather"; +import { BattlerIndex } from "#app/battle"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; +import { WeatherType } from "#enums/weather-type"; import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; -import { BattlerIndex } from "#app/battle"; describe("Weather - Hail", () => { let phaserGame: Phaser.Game; @@ -31,24 +31,24 @@ describe("Weather - Hail", () => { }); it("inflicts damage equal to 1/16 of Pokemon's max HP at turn end", async () => { - await game.classicMode.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); game.move.select(Moves.SPLASH); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); await game.phaseInterceptor.to("TurnEndPhase"); game.scene.getField(true).forEach(pokemon => { - expect(pokemon.hp).toBeLessThan(pokemon.getMaxHp() - Math.floor(pokemon.getMaxHp() / 16)); + expect(pokemon.hp).toBe(pokemon.getMaxHp() - Math.max(Math.floor(pokemon.getMaxHp() / 16), 1)); }); }); it("does not inflict damage to a Pokemon that is underwater (Dive) or underground (Dig)", async () => { - game.override.moveset([Moves.DIG]); - await game.classicMode.startBattle([Species.MAGIKARP]); + game.override.moveset([ Moves.DIG ]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); game.move.select(Moves.DIG); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); await game.phaseInterceptor.to("TurnEndPhase"); @@ -56,6 +56,20 @@ describe("Weather - Hail", () => { const enemyPokemon = game.scene.getEnemyPokemon()!; expect(playerPokemon.hp).toBe(playerPokemon.getMaxHp()); - expect(enemyPokemon.hp).toBeLessThan(enemyPokemon.getMaxHp() - Math.floor(enemyPokemon.getMaxHp() / 16)); + expect(enemyPokemon.hp).toBe(enemyPokemon.getMaxHp() - Math.max(Math.floor(enemyPokemon.getMaxHp() / 16), 1)); + }); + + it("does not inflict damage to Ice type Pokemon", async () => { + await game.classicMode.startBattle([ Species.CLOYSTER ]); + + game.move.select(Moves.SPLASH); + + await game.phaseInterceptor.to("TurnEndPhase"); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const enemyPokemon = game.scene.getEnemyPokemon()!; + + expect(playerPokemon.hp).toBe(playerPokemon.getMaxHp()); + expect(enemyPokemon.hp).toBe(enemyPokemon.getMaxHp() - Math.max(Math.floor(enemyPokemon.getMaxHp() / 16), 1)); }); }); diff --git a/src/test/arena/weather_sandstorm.test.ts b/src/test/arena/weather_sandstorm.test.ts index 91188de6985..17ccfdee94b 100644 --- a/src/test/arena/weather_sandstorm.test.ts +++ b/src/test/arena/weather_sandstorm.test.ts @@ -1,6 +1,8 @@ -import { WeatherType } from "#app/data/weather"; +import { Abilities } from "#app/enums/abilities"; +import { Stat } from "#app/enums/stat"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; +import { WeatherType } from "#enums/weather-type"; import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; @@ -30,20 +32,20 @@ describe("Weather - Sandstorm", () => { }); it("inflicts damage equal to 1/16 of Pokemon's max HP at turn end", async () => { - await game.classicMode.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); game.move.select(Moves.SPLASH); await game.phaseInterceptor.to("TurnEndPhase"); game.scene.getField(true).forEach(pokemon => { - expect(pokemon.hp).toBeLessThan(pokemon.getMaxHp() - Math.floor(pokemon.getMaxHp() / 16)); + expect(pokemon.hp).toBe(pokemon.getMaxHp() - Math.max(Math.floor(pokemon.getMaxHp() / 16), 1)); }); }); it("does not inflict damage to a Pokemon that is underwater (Dive) or underground (Dig)", async () => { - game.override.moveset([Moves.DIVE]); - await game.classicMode.startBattle([Species.MAGIKARP]); + game.override.moveset([ Moves.DIVE ]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); game.move.select(Moves.DIVE); @@ -53,6 +55,37 @@ describe("Weather - Sandstorm", () => { const enemyPokemon = game.scene.getEnemyPokemon()!; expect(playerPokemon.hp).toBe(playerPokemon.getMaxHp()); - expect(enemyPokemon.hp).toBeLessThan(enemyPokemon.getMaxHp() - Math.floor(enemyPokemon.getMaxHp() / 16)); + expect(enemyPokemon.hp).toBe(enemyPokemon.getMaxHp() - Math.max(Math.floor(enemyPokemon.getMaxHp() / 16), 1)); + }); + + it("does not inflict damage to Rock, Ground and Steel type Pokemon", async () => { + game.override + .battleType("double") + .enemySpecies(Species.SANDSHREW) + .ability(Abilities.BALL_FETCH) + .enemyAbility(Abilities.BALL_FETCH); + + await game.classicMode.startBattle([ Species.ROCKRUFF, Species.KLINK ]); + + game.move.select(Moves.SPLASH, 0); + game.move.select(Moves.SPLASH, 1); + + await game.phaseInterceptor.to("TurnEndPhase"); + + game.scene.getField(true).forEach(pokemon => { + expect(pokemon.hp).toBe(pokemon.getMaxHp()); + }); + }); + + it("increases Rock type Pokemon Sp.Def by 50%", async () => { + await game.classicMode.startBattle([ Species.ROCKRUFF ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const playerSpdef = playerPokemon.getStat(Stat.SPDEF); + expect(playerPokemon.getEffectiveStat(Stat.SPDEF)).toBe(Math.floor(playerSpdef * 1.5)); + + const enemyPokemon = game.scene.getEnemyPokemon()!; + const enemySpdef = enemyPokemon.getStat(Stat.SPDEF); + expect(enemyPokemon.getEffectiveStat(Stat.SPDEF)).toBe(enemySpdef); }); }); diff --git a/src/test/arena/weather_strong_winds.test.ts b/src/test/arena/weather_strong_winds.test.ts index 5ce0e61e647..557de93d644 100644 --- a/src/test/arena/weather_strong_winds.test.ts +++ b/src/test/arena/weather_strong_winds.test.ts @@ -28,13 +28,13 @@ describe("Weather - Strong Winds", () => { game.override.startingLevel(10); game.override.enemySpecies(Species.TAILLOW); game.override.enemyAbility(Abilities.DELTA_STREAM); - game.override.moveset([Moves.THUNDERBOLT, Moves.ICE_BEAM, Moves.ROCK_SLIDE]); + game.override.moveset([ Moves.THUNDERBOLT, Moves.ICE_BEAM, Moves.ROCK_SLIDE ]); }); it("electric type move is not very effective on Rayquaza", async () => { game.override.enemySpecies(Species.RAYQUAZA); - await game.classicMode.startBattle([Species.PIKACHU]); + await game.classicMode.startBattle([ Species.PIKACHU ]); const pikachu = game.scene.getPlayerPokemon()!; const enemy = game.scene.getEnemyPokemon()!; @@ -45,7 +45,7 @@ describe("Weather - Strong Winds", () => { }); it("electric type move is neutral for flying type pokemon", async () => { - await game.classicMode.startBattle([Species.PIKACHU]); + await game.classicMode.startBattle([ Species.PIKACHU ]); const pikachu = game.scene.getPlayerPokemon()!; const enemy = game.scene.getEnemyPokemon()!; @@ -56,7 +56,7 @@ describe("Weather - Strong Winds", () => { }); it("ice type move is neutral for flying type pokemon", async () => { - await game.classicMode.startBattle([Species.PIKACHU]); + await game.classicMode.startBattle([ Species.PIKACHU ]); const pikachu = game.scene.getPlayerPokemon()!; const enemy = game.scene.getEnemyPokemon()!; @@ -67,7 +67,7 @@ describe("Weather - Strong Winds", () => { }); it("rock type move is neutral for flying type pokemon", async () => { - await game.classicMode.startBattle([Species.PIKACHU]); + await game.classicMode.startBattle([ Species.PIKACHU ]); const pikachu = game.scene.getPlayerPokemon()!; const enemy = game.scene.getEnemyPokemon()!; @@ -80,7 +80,7 @@ describe("Weather - Strong Winds", () => { it("weather goes away when last trainer pokemon dies to indirect damage", async () => { game.override.enemyStatusEffect(StatusEffect.POISON); - await game.classicMode.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); const enemy = game.scene.getEnemyPokemon()!; enemy.hp = 1; diff --git a/src/test/battle/battle-order.test.ts b/src/test/battle/battle-order.test.ts index e19168962dc..d4e9950dec9 100644 --- a/src/test/battle/battle-order.test.ts +++ b/src/test/battle/battle-order.test.ts @@ -28,7 +28,7 @@ describe("Battle order", () => { game.override.enemySpecies(Species.MEWTWO); game.override.enemyAbility(Abilities.INSOMNIA); game.override.ability(Abilities.INSOMNIA); - game.override.moveset([Moves.TACKLE]); + game.override.moveset([ Moves.TACKLE ]); }); it("opponent faster than player 50 vs 150", async () => { @@ -38,8 +38,8 @@ describe("Battle order", () => { const playerPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; - vi.spyOn(playerPokemon, "stats", "get").mockReturnValue([20, 20, 20, 20, 20, 50]); // set playerPokemon's speed to 50 - vi.spyOn(enemyPokemon, "stats", "get").mockReturnValue([20, 20, 20, 20, 20, 150]); // set enemyPokemon's speed to 150 + vi.spyOn(playerPokemon, "stats", "get").mockReturnValue([ 20, 20, 20, 20, 20, 50 ]); // set playerPokemon's speed to 50 + vi.spyOn(enemyPokemon, "stats", "get").mockReturnValue([ 20, 20, 20, 20, 20, 150 ]); // set enemyPokemon's speed to 150 game.move.select(Moves.TACKLE); await game.phaseInterceptor.run(EnemyCommandPhase); @@ -59,8 +59,8 @@ describe("Battle order", () => { const playerPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; - vi.spyOn(playerPokemon, "stats", "get").mockReturnValue([20, 20, 20, 20, 20, 150]); // set playerPokemon's speed to 150 - vi.spyOn(enemyPokemon, "stats", "get").mockReturnValue([20, 20, 20, 20, 20, 50]); // set enemyPokemon's speed to 50 + vi.spyOn(playerPokemon, "stats", "get").mockReturnValue([ 20, 20, 20, 20, 20, 150 ]); // set playerPokemon's speed to 150 + vi.spyOn(enemyPokemon, "stats", "get").mockReturnValue([ 20, 20, 20, 20, 20, 50 ]); // set enemyPokemon's speed to 50 game.move.select(Moves.TACKLE); await game.phaseInterceptor.run(EnemyCommandPhase); @@ -83,8 +83,8 @@ describe("Battle order", () => { const playerPokemon = game.scene.getPlayerField(); const enemyPokemon = game.scene.getEnemyField(); - playerPokemon.forEach(p => vi.spyOn(p, "stats", "get").mockReturnValue([20, 20, 20, 20, 20, 50])); // set both playerPokemons' speed to 50 - enemyPokemon.forEach(p => vi.spyOn(p, "stats", "get").mockReturnValue([20, 20, 20, 20, 20, 150])); // set both enemyPokemons' speed to 150 + playerPokemon.forEach(p => vi.spyOn(p, "stats", "get").mockReturnValue([ 20, 20, 20, 20, 20, 50 ])); // set both playerPokemons' speed to 50 + enemyPokemon.forEach(p => vi.spyOn(p, "stats", "get").mockReturnValue([ 20, 20, 20, 20, 20, 150 ])); // set both enemyPokemons' speed to 150 const playerIndices = playerPokemon.map(p => p?.getBattlerIndex()); const enemyIndices = enemyPokemon.map(p => p?.getBattlerIndex()); @@ -109,9 +109,9 @@ describe("Battle order", () => { const playerPokemon = game.scene.getPlayerField(); const enemyPokemon = game.scene.getEnemyField(); - playerPokemon.forEach(p => vi.spyOn(p, "stats", "get").mockReturnValue([20, 20, 20, 20, 20, 100])); //set both playerPokemons' speed to 100 - vi.spyOn(enemyPokemon[0], "stats", "get").mockReturnValue([20, 20, 20, 20, 20, 100]); // set enemyPokemon's speed to 100 - vi.spyOn(enemyPokemon[1], "stats", "get").mockReturnValue([20, 20, 20, 20, 20, 150]); // set enemyPokemon's speed to 150 + playerPokemon.forEach(p => vi.spyOn(p, "stats", "get").mockReturnValue([ 20, 20, 20, 20, 20, 100 ])); //set both playerPokemons' speed to 100 + vi.spyOn(enemyPokemon[0], "stats", "get").mockReturnValue([ 20, 20, 20, 20, 20, 100 ]); // set enemyPokemon's speed to 100 + vi.spyOn(enemyPokemon[1], "stats", "get").mockReturnValue([ 20, 20, 20, 20, 20, 150 ]); // set enemyPokemon's speed to 150 const playerIndices = playerPokemon.map(p => p?.getBattlerIndex()); const enemyIndices = enemyPokemon.map(p => p?.getBattlerIndex()); @@ -136,10 +136,10 @@ describe("Battle order", () => { const playerPokemon = game.scene.getPlayerField(); const enemyPokemon = game.scene.getEnemyField(); - vi.spyOn(playerPokemon[0], "stats", "get").mockReturnValue([20, 20, 20, 20, 20, 100]); // set one playerPokemon's speed to 100 - vi.spyOn(playerPokemon[1], "stats", "get").mockReturnValue([20, 20, 20, 20, 20, 150]); // set other playerPokemon's speed to 150 - vi.spyOn(enemyPokemon[0], "stats", "get").mockReturnValue([20, 20, 20, 20, 20, 100]); // set one enemyPokemon's speed to 100 - vi.spyOn(enemyPokemon[1], "stats", "get").mockReturnValue([20, 20, 20, 20, 20, 150]); // set other enemyPokemon's speed to 150 + vi.spyOn(playerPokemon[0], "stats", "get").mockReturnValue([ 20, 20, 20, 20, 20, 100 ]); // set one playerPokemon's speed to 100 + vi.spyOn(playerPokemon[1], "stats", "get").mockReturnValue([ 20, 20, 20, 20, 20, 150 ]); // set other playerPokemon's speed to 150 + vi.spyOn(enemyPokemon[0], "stats", "get").mockReturnValue([ 20, 20, 20, 20, 20, 100 ]); // set one enemyPokemon's speed to 100 + vi.spyOn(enemyPokemon[1], "stats", "get").mockReturnValue([ 20, 20, 20, 20, 20, 150 ]); // set other enemyPokemon's speed to 150 const playerIndices = playerPokemon.map(p => p?.getBattlerIndex()); const enemyIndices = enemyPokemon.map(p => p?.getBattlerIndex()); diff --git a/src/test/battle/battle.test.ts b/src/test/battle/battle.test.ts index 554692374d2..656cc62ac59 100644 --- a/src/test/battle/battle.test.ts +++ b/src/test/battle/battle.test.ts @@ -99,9 +99,9 @@ describe("Test Battle Phase", () => { game.override .startingWave(3) .battleType("single"); - game.override.moveset([Moves.TACKLE]); + game.override.moveset([ Moves.TACKLE ]); game.override.enemyAbility(Abilities.HYDRATION); - game.override.enemyMoveset([Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE]); + game.override.enemyMoveset([ Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE ]); await game.startBattle(); game.move.select(Moves.TACKLE); await game.phaseInterceptor.runFrom(EnemyCommandPhase).to(SelectModifierPhase, false); @@ -112,9 +112,9 @@ describe("Test Battle Phase", () => { game.override.enemySpecies(Species.RATTATA); game.override.startingLevel(5); game.override.startingWave(3); - game.override.moveset([Moves.TACKLE]); + game.override.moveset([ Moves.TACKLE ]); game.override.enemyAbility(Abilities.HYDRATION); - game.override.enemyMoveset([Moves.TAIL_WHIP, Moves.TAIL_WHIP, Moves.TAIL_WHIP, Moves.TAIL_WHIP]); + game.override.enemyMoveset([ Moves.TAIL_WHIP, Moves.TAIL_WHIP, Moves.TAIL_WHIP, Moves.TAIL_WHIP ]); game.override.battleType("single"); await game.startBattle(); game.move.select(Moves.TACKLE); @@ -136,9 +136,9 @@ describe("Test Battle Phase", () => { Species.CHANSEY, Species.MEW ]); - expect(game.scene.getParty()[0].species.speciesId).toBe(Species.CHARIZARD); - expect(game.scene.getParty()[1].species.speciesId).toBe(Species.CHANSEY); - expect(game.scene.getParty()[2].species.speciesId).toBe(Species.MEW); + expect(game.scene.getPlayerParty()[0].species.speciesId).toBe(Species.CHARIZARD); + expect(game.scene.getPlayerParty()[1].species.speciesId).toBe(Species.CHANSEY); + expect(game.scene.getPlayerParty()[2].species.speciesId).toBe(Species.MEW); }, 20000); it("test remove random battle seed int", async () => { @@ -259,8 +259,8 @@ describe("Test Battle Phase", () => { game.override.ability(Abilities.ZEN_MODE); game.override.startingLevel(2000); game.override.startingWave(3); - game.override.moveset([moveToUse]); - game.override.enemyMoveset([Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE]); + game.override.moveset([ moveToUse ]); + game.override.enemyMoveset([ Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE ]); await game.startBattle([ Species.DARMANITAN, Species.CHARIZARD, @@ -282,8 +282,8 @@ describe("Test Battle Phase", () => { game.override.ability(Abilities.ZEN_MODE); game.override.startingLevel(2000); game.override.startingWave(3); - game.override.moveset([moveToUse]); - game.override.enemyMoveset([Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE]); + game.override.moveset([ moveToUse ]); + game.override.enemyMoveset([ Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE ]); await game.startBattle(); const turn = game.scene.currentBattle.turn; game.move.select(moveToUse); @@ -302,8 +302,8 @@ describe("Test Battle Phase", () => { .startingLevel(2000) .startingWave(3) .startingBiome(Biome.LAKE) - .moveset([moveToUse]); - game.override.enemyMoveset([Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE]); + .moveset([ moveToUse ]); + game.override.enemyMoveset([ Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE ]); await game.classicMode.startBattle(); const waveIndex = game.scene.currentBattle.waveIndex; game.move.select(moveToUse); @@ -323,7 +323,7 @@ describe("Test Battle Phase", () => { .enemySpecies(Species.RATTATA) .startingWave(1) .startingLevel(100) - .moveset([moveToUse]) + .moveset([ moveToUse ]) .enemyMoveset(Moves.SPLASH) .startingHeldItems([{ name: "TEMP_STAT_STAGE_BOOSTER", type: Stat.ACC }]); diff --git a/src/test/battle/damage_calculation.test.ts b/src/test/battle/damage_calculation.test.ts index a348df6c085..e6ecbe4646f 100644 --- a/src/test/battle/damage_calculation.test.ts +++ b/src/test/battle/damage_calculation.test.ts @@ -31,11 +31,11 @@ describe("Battle Mechanics - Damage Calculation", () => { .startingLevel(100) .enemyLevel(100) .disableCrits() - .moveset([Moves.TACKLE, Moves.DRAGON_RAGE, Moves.FISSURE, Moves.JUMP_KICK]); + .moveset([ Moves.TACKLE, Moves.DRAGON_RAGE, Moves.FISSURE, Moves.JUMP_KICK ]); }); it("Tackle deals expected base damage", async () => { - await game.classicMode.startBattle([Species.CHARIZARD]); + await game.classicMode.startBattle([ Species.CHARIZARD ]); const playerPokemon = game.scene.getPlayerPokemon()!; vi.spyOn(playerPokemon, "getEffectiveStat").mockReturnValue(80); @@ -53,7 +53,7 @@ describe("Battle Mechanics - Damage Calculation", () => { .startingLevel(1) .enemySpecies(Species.AGGRON); - await game.classicMode.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); const aggron = game.scene.getEnemyPokemon()!; @@ -70,7 +70,7 @@ describe("Battle Mechanics - Damage Calculation", () => { .enemySpecies(Species.DRAGONITE) .enemyAbility(Abilities.MULTISCALE); - await game.classicMode.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); const magikarp = game.scene.getPlayerPokemon()!; const dragonite = game.scene.getEnemyPokemon()!; @@ -83,7 +83,7 @@ describe("Battle Mechanics - Damage Calculation", () => { .enemySpecies(Species.AGGRON) .enemyAbility(Abilities.MULTISCALE); - await game.classicMode.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); const magikarp = game.scene.getPlayerPokemon()!; const aggron = game.scene.getEnemyPokemon()!; @@ -96,7 +96,7 @@ describe("Battle Mechanics - Damage Calculation", () => { .enemySpecies(Species.GASTLY) .ability(Abilities.WONDER_GUARD); - await game.classicMode.startBattle([Species.SHEDINJA]); + await game.classicMode.startBattle([ Species.SHEDINJA ]); const shedinja = game.scene.getPlayerPokemon()!; @@ -115,7 +115,7 @@ describe("Battle Mechanics - Damage Calculation", () => { .enemySpecies(Species.CHARIZARD) .enemyAbility(Abilities.BLAZE); - await game.classicMode.startBattle([Species.PIKACHU]); + await game.classicMode.startBattle([ Species.PIKACHU ]); const charizard = game.scene.getEnemyPokemon()!; diff --git a/src/test/battle/double_battle.test.ts b/src/test/battle/double_battle.test.ts index b7a5616d642..b48f2a96a5b 100644 --- a/src/test/battle/double_battle.test.ts +++ b/src/test/battle/double_battle.test.ts @@ -1,13 +1,18 @@ -import { Status, StatusEffect } from "#app/data/status-effect"; +import { Status } from "#app/data/status-effect"; +import { Abilities } from "#enums/abilities"; +import { GameModes, getGameMode } from "#app/game-mode"; import { BattleEndPhase } from "#app/phases/battle-end-phase"; import { TurnInitPhase } from "#app/phases/turn-init-phase"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; +import { StatusEffect } from "#enums/status-effect"; import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; -import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; +import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; describe("Double Battles", () => { + const DOUBLE_CHANCE = 8; // Normal chance of double battle is 1/8 + let phaserGame: Phaser.Game; let game: GameManager; @@ -49,10 +54,46 @@ describe("Double Battles", () => { await game.phaseInterceptor.to(BattleEndPhase); game.doSelectModifier(); - const charizard = game.scene.getParty().findIndex(p => p.species.speciesId === Species.CHARIZARD); + const charizard = game.scene.getPlayerParty().findIndex(p => p.species.speciesId === Species.CHARIZARD); game.doRevivePokemon(charizard); await game.phaseInterceptor.to(TurnInitPhase); expect(game.scene.getPlayerField().filter(p => !p.isFainted())).toHaveLength(2); }, 20000); + + it("randomly chooses between single and double battles if there is no battle type override", async () => { + let rngSweepProgress = 0; // Will simulate RNG rolls by slowly increasing from 0 to 1 + let doubleCount = 0; + let singleCount = 0; + + vi.spyOn(Phaser.Math.RND, "realInRange").mockImplementation((min: number, max: number) => { + return rngSweepProgress * (max - min) + min; + }); + + game.override.enemyMoveset(Moves.SPLASH) + .moveset(Moves.SPLASH) + .enemyAbility(Abilities.BALL_FETCH) + .ability(Abilities.BALL_FETCH); + + // Play through endless, waves 1 to 9, counting number of double battles from waves 2 to 9 + await game.classicMode.startBattle([ Species.BULBASAUR ]); + game.scene.gameMode = getGameMode(GameModes.ENDLESS); + + for (let i = 0; i < DOUBLE_CHANCE; i++) { + rngSweepProgress = (i + 0.5) / DOUBLE_CHANCE; + + game.move.select(Moves.SPLASH); + await game.doKillOpponents(); + await game.toNextWave(); + + if (game.scene.getEnemyParty().length === 1) { + singleCount++; + } else if (game.scene.getEnemyParty().length === 2) { + doubleCount++; + } + } + + expect(doubleCount).toBe(1); + expect(singleCount).toBe(DOUBLE_CHANCE - 1); + }); }); diff --git a/src/test/battle/error-handling.test.ts b/src/test/battle/error-handling.test.ts index da5cc4d1969..208463e7064 100644 --- a/src/test/battle/error-handling.test.ts +++ b/src/test/battle/error-handling.test.ts @@ -30,8 +30,8 @@ describe("Error Handling", () => { game.override.enemyAbility(Abilities.HYDRATION); game.override.ability(Abilities.ZEN_MODE); game.override.startingLevel(2000); - game.override.moveset([moveToUse]); - game.override.enemyMoveset([Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE]); + game.override.moveset([ moveToUse ]); + game.override.enemyMoveset([ Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE ]); }); it.skip("to next turn", async () => { diff --git a/src/test/battle/inverse_battle.test.ts b/src/test/battle/inverse_battle.test.ts index d808f71addb..0bda678bbd3 100644 --- a/src/test/battle/inverse_battle.test.ts +++ b/src/test/battle/inverse_battle.test.ts @@ -1,5 +1,5 @@ import { BattlerIndex } from "#app/battle"; -import { Type } from "#app/data/type"; +import { Type } from "#enums/type"; import { Abilities } from "#enums/abilities"; import { ArenaTagType } from "#enums/arena-tag-type"; import { Challenges } from "#enums/challenges"; @@ -10,7 +10,6 @@ import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Inverse Battle", () => { let phaserGame: Phaser.Game; @@ -42,7 +41,7 @@ describe("Inverse Battle", () => { it("Immune types are 2x effective - Thunderbolt against Ground Type", async () => { game.override - .moveset([Moves.THUNDERBOLT]) + .moveset([ Moves.THUNDERBOLT ]) .enemySpecies(Species.SANDSHREW); @@ -52,15 +51,15 @@ describe("Inverse Battle", () => { vi.spyOn(enemy, "getMoveEffectiveness"); game.move.select(Moves.THUNDERBOLT); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to("MoveEffectPhase"); expect(enemy.getMoveEffectiveness).toHaveLastReturnedWith(2); - }, TIMEOUT); + }); it("2x effective types are 0.5x effective - Thunderbolt against Flying Type", async () => { game.override - .moveset([Moves.THUNDERBOLT]) + .moveset([ Moves.THUNDERBOLT ]) .enemySpecies(Species.PIDGEY); await game.challengeMode.startBattle(); @@ -69,15 +68,15 @@ describe("Inverse Battle", () => { vi.spyOn(enemy, "getMoveEffectiveness"); game.move.select(Moves.THUNDERBOLT); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to("MoveEffectPhase"); expect(enemy.getMoveEffectiveness).toHaveLastReturnedWith(0.5); - }, TIMEOUT); + }); it("0.5x effective types are 2x effective - Thunderbolt against Electric Type", async () => { game.override - .moveset([Moves.THUNDERBOLT]) + .moveset([ Moves.THUNDERBOLT ]) .enemySpecies(Species.CHIKORITA); await game.challengeMode.startBattle(); @@ -86,11 +85,11 @@ describe("Inverse Battle", () => { vi.spyOn(enemy, "getMoveEffectiveness"); game.move.select(Moves.THUNDERBOLT); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to("MoveEffectPhase"); expect(enemy.getMoveEffectiveness).toHaveLastReturnedWith(2); - }, TIMEOUT); + }); it("Stealth Rock follows the inverse matchups - Stealth Rock against Charizard deals 1/32 of max HP", async () => { game.scene.arena.addTag(ArenaTagType.STEALTH_ROCK, 1, Moves.STEALTH_ROCK, 0); @@ -110,11 +109,11 @@ describe("Inverse Battle", () => { console.log("Charizard's max HP: " + maxHp, "Damage: " + damage_prediction, "Current HP: " + currentHp, "Expected HP: " + expectedHP); expect(currentHp).toBeGreaterThan(maxHp * 31 / 32 - 1); - }, TIMEOUT); + }); it("Freeze Dry is 2x effective against Water Type like other Ice type Move - Freeze Dry against Squirtle", async () => { game.override - .moveset([Moves.FREEZE_DRY]) + .moveset([ Moves.FREEZE_DRY ]) .enemySpecies(Species.SQUIRTLE); await game.challengeMode.startBattle(); @@ -123,15 +122,15 @@ describe("Inverse Battle", () => { vi.spyOn(enemy, "getMoveEffectiveness"); game.move.select(Moves.FREEZE_DRY); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to("MoveEffectPhase"); expect(enemy.getMoveEffectiveness).toHaveLastReturnedWith(2); - }, TIMEOUT); + }); it("Water Absorb should heal against water moves - Water Absorb against Water gun", async () => { game.override - .moveset([Moves.WATER_GUN]) + .moveset([ Moves.WATER_GUN ]) .enemyAbility(Abilities.WATER_ABSORB); await game.challengeMode.startBattle(); @@ -139,15 +138,15 @@ describe("Inverse Battle", () => { const enemy = game.scene.getEnemyPokemon()!; enemy.hp = enemy.getMaxHp() - 1; game.move.select(Moves.WATER_GUN); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to("MoveEndPhase"); expect(enemy.hp).toBe(enemy.getMaxHp()); - }, TIMEOUT); + }); it("Fire type does not get burned - Will-O-Wisp against Charmander", async () => { game.override - .moveset([Moves.WILL_O_WISP]) + .moveset([ Moves.WILL_O_WISP ]) .enemySpecies(Species.CHARMANDER); await game.challengeMode.startBattle(); @@ -155,16 +154,16 @@ describe("Inverse Battle", () => { const enemy = game.scene.getEnemyPokemon()!; game.move.select(Moves.WILL_O_WISP); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.move.forceHit(); await game.phaseInterceptor.to("MoveEndPhase"); expect(enemy.status?.effect).not.toBe(StatusEffect.BURN); - }, TIMEOUT); + }); it("Electric type does not get paralyzed - Nuzzle against Pikachu", async () => { game.override - .moveset([Moves.NUZZLE]) + .moveset([ Moves.NUZZLE ]) .enemySpecies(Species.PIKACHU) .enemyLevel(50); @@ -173,15 +172,15 @@ describe("Inverse Battle", () => { const enemy = game.scene.getEnemyPokemon()!; game.move.select(Moves.NUZZLE); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to("MoveEndPhase"); expect(enemy.status?.effect).not.toBe(StatusEffect.PARALYSIS); - }, TIMEOUT); + }); it("Ground type is not immune to Thunder Wave - Thunder Wave against Sandshrew", async () => { game.override - .moveset([Moves.THUNDER_WAVE]) + .moveset([ Moves.THUNDER_WAVE ]) .enemySpecies(Species.SANDSHREW); await game.challengeMode.startBattle(); @@ -189,45 +188,45 @@ describe("Inverse Battle", () => { const enemy = game.scene.getEnemyPokemon()!; game.move.select(Moves.THUNDER_WAVE); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.move.forceHit(); await game.phaseInterceptor.to("MoveEndPhase"); expect(enemy.status?.effect).toBe(StatusEffect.PARALYSIS); - }, TIMEOUT); + }); it("Anticipation should trigger on 2x effective moves - Anticipation against Thunderbolt", async () => { game.override - .moveset([Moves.THUNDERBOLT]) + .moveset([ Moves.THUNDERBOLT ]) .enemySpecies(Species.SANDSHREW) .enemyAbility(Abilities.ANTICIPATION); await game.challengeMode.startBattle(); expect(game.scene.getEnemyPokemon()?.summonData.abilitiesApplied[0]).toBe(Abilities.ANTICIPATION); - }, TIMEOUT); + }); it("Conversion 2 should change the type to the resistive type - Conversion 2 against Dragonite", async () => { game.override - .moveset([Moves.CONVERSION_2]) - .enemyMoveset([Moves.DRAGON_CLAW, Moves.DRAGON_CLAW, Moves.DRAGON_CLAW, Moves.DRAGON_CLAW]); + .moveset([ Moves.CONVERSION_2 ]) + .enemyMoveset([ Moves.DRAGON_CLAW, Moves.DRAGON_CLAW, Moves.DRAGON_CLAW, Moves.DRAGON_CLAW ]); await game.challengeMode.startBattle(); const player = game.scene.getPlayerPokemon()!; game.move.select(Moves.CONVERSION_2); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); await game.phaseInterceptor.to("TurnEndPhase"); expect(player.getTypes()[0]).toBe(Type.DRAGON); - }, TIMEOUT); + }); it("Flying Press should be 0.25x effective against Grass + Dark Type - Flying Press against Meowscarada", async () => { game.override - .moveset([Moves.FLYING_PRESS]) + .moveset([ Moves.FLYING_PRESS ]) .enemySpecies(Species.MEOWSCARADA); await game.challengeMode.startBattle(); @@ -236,15 +235,15 @@ describe("Inverse Battle", () => { vi.spyOn(enemy, "getMoveEffectiveness"); game.move.select(Moves.FLYING_PRESS); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to("MoveEffectPhase"); expect(enemy.getMoveEffectiveness).toHaveLastReturnedWith(0.25); - }, TIMEOUT); + }); it("Scrappy ability has no effect - Tackle against Ghost Type still 2x effective with Scrappy", async () => { game.override - .moveset([Moves.TACKLE]) + .moveset([ Moves.TACKLE ]) .ability(Abilities.SCRAPPY) .enemySpecies(Species.GASTLY); @@ -254,15 +253,15 @@ describe("Inverse Battle", () => { vi.spyOn(enemy, "getMoveEffectiveness"); game.move.select(Moves.TACKLE); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to("MoveEffectPhase"); expect(enemy.getMoveEffectiveness).toHaveLastReturnedWith(2); - }, TIMEOUT); + }); it("FORESIGHT has no effect - Tackle against Ghost Type still 2x effective with Foresight", async () => { game.override - .moveset([Moves.FORESIGHT, Moves.TACKLE]) + .moveset([ Moves.FORESIGHT, Moves.TACKLE ]) .enemySpecies(Species.GASTLY); await game.challengeMode.startBattle(); @@ -271,13 +270,13 @@ describe("Inverse Battle", () => { vi.spyOn(enemy, "getMoveEffectiveness"); game.move.select(Moves.FORESIGHT); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); await game.phaseInterceptor.to("TurnEndPhase"); game.move.select(Moves.TACKLE); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to("MoveEffectPhase"); expect(enemy.getMoveEffectiveness).toHaveLastReturnedWith(2); - }, TIMEOUT); + }); }); diff --git a/src/test/battle/special_battle.test.ts b/src/test/battle/special_battle.test.ts index 1d319bea372..af9e3dddbec 100644 --- a/src/test/battle/special_battle.test.ts +++ b/src/test/battle/special_battle.test.ts @@ -25,10 +25,10 @@ describe("Test Battle Phase", () => { game = new GameManager(phaserGame); game.override.enemySpecies(Species.RATTATA); game.override.startingLevel(2000); - game.override.moveset([Moves.TACKLE]); + game.override.moveset([ Moves.TACKLE ]); game.override.enemyAbility(Abilities.HYDRATION); game.override.ability(Abilities.HYDRATION); - game.override.enemyMoveset([Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE]); + game.override.enemyMoveset([ Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE ]); }); it("startBattle 2vs1 boss", async() => { diff --git a/src/test/battlerTags/octolock.test.ts b/src/test/battlerTags/octolock.test.ts index 7b1f9264370..ebd92dc6401 100644 --- a/src/test/battlerTags/octolock.test.ts +++ b/src/test/battlerTags/octolock.test.ts @@ -10,7 +10,7 @@ vi.mock("#app/battle-scene.js"); describe("BattlerTag - OctolockTag", () => { describe("lapse behavior", () => { - it("unshifts a StatStageChangePhase with expected stat stage changes", { timeout: 10000 }, async () => { + it("unshifts a StatStageChangePhase with expected stat stage changes", async () => { const mockPokemon = { scene: new BattleScene(), getBattlerIndex: () => 0, @@ -30,11 +30,11 @@ describe("BattlerTag - OctolockTag", () => { }); }); - it ("traps its target (extends TrappedTag)", { timeout: 2000 }, async () => { + it ("traps its target (extends TrappedTag)", async () => { expect(new OctolockTag(1)).toBeInstanceOf(TrappedTag); }); - it("can be added to pokemon who are not octolocked", { timeout: 2000 }, async => { + it("can be added to pokemon who are not octolocked", async => { const mockPokemon = { getTag: vi.fn().mockReturnValue(undefined) as Pokemon["getTag"], } as Pokemon; @@ -47,7 +47,7 @@ describe("BattlerTag - OctolockTag", () => { expect(mockPokemon.getTag).toHaveBeenCalledWith(BattlerTagType.OCTOLOCK); }); - it("cannot be added to pokemon who are octolocked", { timeout: 2000 }, async => { + it("cannot be added to pokemon who are octolocked", async => { const mockPokemon = { getTag: vi.fn().mockReturnValue(new BattlerTag(null!, null!, null!, null!)) as Pokemon["getTag"], } as Pokemon; diff --git a/src/test/battlerTags/stockpiling.test.ts b/src/test/battlerTags/stockpiling.test.ts index e568016dfef..dab189853c5 100644 --- a/src/test/battlerTags/stockpiling.test.ts +++ b/src/test/battlerTags/stockpiling.test.ts @@ -12,7 +12,7 @@ beforeEach(() => { describe("BattlerTag - StockpilingTag", () => { describe("onAdd", () => { - it("unshifts a StatStageChangePhase with expected stat stage changes on add", { timeout: 10000 }, async () => { + it("unshifts a StatStageChangePhase with expected stat stage changes on add", async () => { const mockPokemon = { scene: vi.mocked(new BattleScene()) as BattleScene, getBattlerIndex: () => 0, @@ -27,7 +27,7 @@ describe("BattlerTag - StockpilingTag", () => { expect((phase as StatStageChangePhase)["stages"]).toEqual(1); expect((phase as StatStageChangePhase)["stats"]).toEqual(expect.arrayContaining([ Stat.DEF, Stat.SPDEF ])); - (phase as StatStageChangePhase)["onChange"]!(mockPokemon, [Stat.DEF, Stat.SPDEF], [1, 1]); + (phase as StatStageChangePhase)["onChange"]!(mockPokemon, [ Stat.DEF, Stat.SPDEF ], [ 1, 1 ]); }); subject.onAdd(mockPokemon); @@ -35,7 +35,7 @@ describe("BattlerTag - StockpilingTag", () => { expect(mockPokemon.scene.unshiftPhase).toBeCalledTimes(1); }); - it("unshifts a StatStageChangePhase with expected stat changes on add (one stat maxed)", { timeout: 10000 }, async () => { + it("unshifts a StatStageChangePhase with expected stat changes on add (one stat maxed)", async () => { const mockPokemon = { scene: new BattleScene(), summonData: new PokemonSummonData(), @@ -52,9 +52,9 @@ describe("BattlerTag - StockpilingTag", () => { vi.spyOn(mockPokemon.scene, "unshiftPhase").mockImplementation(phase => { expect(phase).toBeInstanceOf(StatStageChangePhase); expect((phase as StatStageChangePhase)["stages"]).toEqual(1); - expect((phase as StatStageChangePhase)["stats"]).toEqual(expect.arrayContaining([Stat.DEF, Stat.SPDEF])); + expect((phase as StatStageChangePhase)["stats"]).toEqual(expect.arrayContaining([ Stat.DEF, Stat.SPDEF ])); - (phase as StatStageChangePhase)["onChange"]!(mockPokemon, [ Stat.DEF, Stat.SPDEF ], [1, 1]); + (phase as StatStageChangePhase)["onChange"]!(mockPokemon, [ Stat.DEF, Stat.SPDEF ], [ 1, 1 ]); }); subject.onAdd(mockPokemon); @@ -64,7 +64,7 @@ describe("BattlerTag - StockpilingTag", () => { }); describe("onOverlap", () => { - it("unshifts a StatStageChangePhase with expected stat changes on overlap", { timeout: 10000 }, async () => { + it("unshifts a StatStageChangePhase with expected stat changes on overlap", async () => { const mockPokemon = { scene: new BattleScene(), getBattlerIndex: () => 0, @@ -79,7 +79,7 @@ describe("BattlerTag - StockpilingTag", () => { expect((phase as StatStageChangePhase)["stages"]).toEqual(1); expect((phase as StatStageChangePhase)["stats"]).toEqual(expect.arrayContaining([ Stat.DEF, Stat.SPDEF ])); - (phase as StatStageChangePhase)["onChange"]!(mockPokemon, [ Stat.DEF, Stat.SPDEF ], [1, 1]); + (phase as StatStageChangePhase)["onChange"]!(mockPokemon, [ Stat.DEF, Stat.SPDEF ], [ 1, 1 ]); }); subject.onOverlap(mockPokemon); @@ -89,7 +89,7 @@ describe("BattlerTag - StockpilingTag", () => { }); describe("stack limit, stat tracking, and removal", () => { - it("can be added up to three times, even when one stat does not change", { timeout: 10000 }, async () => { + it("can be added up to three times, even when one stat does not change", async () => { const mockPokemon = { scene: new BattleScene(), summonData: new PokemonSummonData(), @@ -109,7 +109,7 @@ describe("BattlerTag - StockpilingTag", () => { expect((phase as StatStageChangePhase)["stats"]).toEqual(expect.arrayContaining([ Stat.DEF, Stat.SPDEF ])); // def doesn't change - (phase as StatStageChangePhase)["onChange"]!(mockPokemon, [ Stat.SPDEF ], [1]); + (phase as StatStageChangePhase)["onChange"]!(mockPokemon, [ Stat.SPDEF ], [ 1 ]); }); subject.onAdd(mockPokemon); @@ -121,7 +121,7 @@ describe("BattlerTag - StockpilingTag", () => { expect((phase as StatStageChangePhase)["stats"]).toEqual(expect.arrayContaining([ Stat.DEF, Stat.SPDEF ])); // def doesn't change - (phase as StatStageChangePhase)["onChange"]!(mockPokemon, [ Stat.SPDEF ], [1]); + (phase as StatStageChangePhase)["onChange"]!(mockPokemon, [ Stat.SPDEF ], [ 1 ]); }); subject.onOverlap(mockPokemon); @@ -145,13 +145,13 @@ describe("BattlerTag - StockpilingTag", () => { // fourth stack should not be applied subject.onOverlap(mockPokemon); expect(subject.stockpiledCount).toBe(3); - expect(subject.statChangeCounts).toMatchObject({ [ Stat.DEF ]: 0, [Stat.SPDEF]: 2 }); + expect(subject.statChangeCounts).toMatchObject({ [Stat.DEF]: 0, [Stat.SPDEF]: 2 }); // removing tag should reverse stat changes vi.spyOn(mockPokemon.scene, "unshiftPhase").mockImplementationOnce(phase => { expect(phase).toBeInstanceOf(StatStageChangePhase); expect((phase as StatStageChangePhase)["stages"]).toEqual(-2); - expect((phase as StatStageChangePhase)["stats"]).toEqual(expect.arrayContaining([Stat.SPDEF])); + expect((phase as StatStageChangePhase)["stats"]).toEqual(expect.arrayContaining([ Stat.SPDEF ])); }); subject.onRemove(mockPokemon); diff --git a/src/test/battlerTags/substitute.test.ts b/src/test/battlerTags/substitute.test.ts index 12888daca50..af0aa63af89 100644 --- a/src/test/battlerTags/substitute.test.ts +++ b/src/test/battlerTags/substitute.test.ts @@ -10,8 +10,6 @@ import { MoveEffectPhase } from "#app/phases/move-effect-phase"; vi.mock("#app/battle-scene.js"); -const TIMEOUT = 5 * 1000; // 5 sec timeout - describe("BattlerTag - SubstituteTag", () => { let mockPokemon: Pokemon; @@ -45,7 +43,7 @@ describe("BattlerTag - SubstituteTag", () => { subject.onAdd(mockPokemon); expect(subject.hp).toBe(25); - }, TIMEOUT + } ); it( @@ -67,7 +65,7 @@ describe("BattlerTag - SubstituteTag", () => { expect(subject.sourceInFocus).toBeFalsy(); expect(mockPokemon.scene.triggerPokemonBattleAnim).toHaveBeenCalledTimes(1); expect(mockPokemon.scene.queueMessage).toHaveBeenCalledTimes(1); - }, TIMEOUT + } ); it( @@ -79,7 +77,7 @@ describe("BattlerTag - SubstituteTag", () => { subject.onAdd(mockPokemon); expect(mockPokemon.findAndRemoveTags).toHaveBeenCalledTimes(1); - }, TIMEOUT + } ); }); @@ -114,7 +112,7 @@ describe("BattlerTag - SubstituteTag", () => { expect(mockPokemon.scene.triggerPokemonBattleAnim).toHaveBeenCalledTimes(1); expect(mockPokemon.scene.queueMessage).toHaveBeenCalledTimes(1); - }, TIMEOUT + } ); }); @@ -124,8 +122,8 @@ describe("BattlerTag - SubstituteTag", () => { scene: new BattleScene(), hp: 101, id: 0, - turnData: {acted: true} as PokemonTurnData, - getLastXMoves: vi.fn().mockReturnValue([{move: Moves.TACKLE, result: MoveResult.SUCCESS} as TurnMove]) as Pokemon["getLastXMoves"], + turnData: { acted: true } as PokemonTurnData, + getLastXMoves: vi.fn().mockReturnValue([ { move: Moves.TACKLE, result: MoveResult.SUCCESS } as TurnMove ]) as Pokemon["getLastXMoves"], } as Pokemon; vi.spyOn(messages, "getPokemonNameWithAffix").mockReturnValue(""); @@ -150,7 +148,7 @@ describe("BattlerTag - SubstituteTag", () => { expect(subject.sourceInFocus).toBeTruthy(); expect(mockPokemon.scene.triggerPokemonBattleAnim).toHaveBeenCalledTimes(1); expect(mockPokemon.scene.queueMessage).not.toHaveBeenCalled(); - }, TIMEOUT + } ); it( @@ -172,7 +170,7 @@ describe("BattlerTag - SubstituteTag", () => { expect(subject.sourceInFocus).toBeFalsy(); expect(mockPokemon.scene.triggerPokemonBattleAnim).toHaveBeenCalledTimes(1); expect(mockPokemon.scene.queueMessage).not.toHaveBeenCalled(); - }, TIMEOUT + } ); /** TODO: Figure out how to mock a MoveEffectPhase correctly for this test */ @@ -200,7 +198,7 @@ describe("BattlerTag - SubstituteTag", () => { expect(mockPokemon.scene.triggerPokemonBattleAnim).not.toHaveBeenCalled(); expect(mockPokemon.scene.queueMessage).toHaveBeenCalledTimes(1); - }, TIMEOUT + } ); it( @@ -212,7 +210,7 @@ describe("BattlerTag - SubstituteTag", () => { vi.spyOn(mockPokemon.scene, "queueMessage").mockReturnValue(); expect(subject.lapse(mockPokemon, BattlerTagLapseType.CUSTOM)).toBeFalsy(); - }, TIMEOUT + } ); it( diff --git a/src/test/boss-pokemon.test.ts b/src/test/boss-pokemon.test.ts index 8a0a0e01617..840b65f3cc6 100644 --- a/src/test/boss-pokemon.test.ts +++ b/src/test/boss-pokemon.test.ts @@ -9,8 +9,6 @@ import { EnemyPokemon } from "#app/field/pokemon"; import { toDmgValue } from "#app/utils"; describe("Boss Pokemon / Shields", () => { - const TIMEOUT = 20 * 1000; - let phaserGame: Phaser.Game; let game: GameManager; @@ -35,7 +33,7 @@ describe("Boss Pokemon / Shields", () => { .enemyMoveset(Moves.SPLASH) .enemyHeldItems([]) .startingLevel(1000) - .moveset([Moves.FALSE_SWIPE, Moves.SUPER_FANG, Moves.SPLASH]) + .moveset([ Moves.FALSE_SWIPE, Moves.SUPER_FANG, Moves.SPLASH, Moves.PSYCHIC ]) .ability(Abilities.NO_GUARD); }); @@ -62,7 +60,7 @@ describe("Boss Pokemon / Shields", () => { // Pokemon above level 100 get an extra shield level = 100; expect(game.scene.getEncounterBossSegments(wave, level, getPokemonSpecies(Species.RATTATA))).toBe(7); - }, TIMEOUT); + }); it("should reduce the number of shields if we are in a double battle", async () => { game.override @@ -77,7 +75,7 @@ describe("Boss Pokemon / Shields", () => { expect(boss1.bossSegments).toBe(2); expect(boss2.isBoss()).toBe(true); expect(boss2.bossSegments).toBe(2); - }, TIMEOUT); + }); it("shields should stop overflow damage and give stat stage boosts when broken", async () => { game.override.startingWave(150); // Floor 150 > 2 shields / 3 health segments @@ -107,7 +105,7 @@ describe("Boss Pokemon / Shields", () => { // Breaking the last shield gives a +2 boost to ATK, DEF, SP ATK, SP DEF or SPD expect(getTotalStatStageBoosts(enemyPokemon)).toBe(3); - }, TIMEOUT); + }); it("breaking multiple shields at once requires extra damage", async () => { game.override @@ -143,7 +141,7 @@ describe("Boss Pokemon / Shields", () => { expect(boss2.bossSegmentIndex).toBe(0); expect(boss2.hp).toBe(boss2.getMaxHp() - toDmgValue(boss2SegmentHp * 4)); - }, TIMEOUT); + }); it("the number of stat stage boosts is consistent when several shields are broken at once", async () => { const shieldsToBreak = 4; @@ -174,7 +172,7 @@ describe("Boss Pokemon / Shields", () => { game.move.select(Moves.SPLASH); await game.toNextTurn(); // All broken shields give +1 stat boost, except the last two that gives +2 - totalStatStages += i >= shieldsToBreak -1? 2 : 1; + totalStatStages += i >= shieldsToBreak - 1 ? 2 : 1; expect(getTotalStatStageBoosts(boss1)).toBe(totalStatStages); } @@ -196,7 +194,29 @@ describe("Boss Pokemon / Shields", () => { await game.toNextTurn(); expect(getTotalStatStageBoosts(boss2)).toBe(totalStatStages); - }, TIMEOUT); + }); + + it("the boss enduring does not proc an extra stat boost", async () => { + game.override + .enemyHealthSegments(2) + .enemyAbility(Abilities.STURDY); + + await game.classicMode.startBattle([ Species.MEWTWO ]); + + const enemyPokemon = game.scene.getEnemyPokemon()!; + expect(enemyPokemon.isBoss()).toBe(true); + expect(enemyPokemon.bossSegments).toBe(2); + expect(getTotalStatStageBoosts(enemyPokemon)).toBe(0); + + game.move.select(Moves.PSYCHIC); + await game.toNextTurn(); + + // Enemy survived with Sturdy + expect(enemyPokemon.bossSegmentIndex).toBe(0); + expect(enemyPokemon.hp).toBe(1); + expect(getTotalStatStageBoosts(enemyPokemon)).toBe(1); + + }); /** * Gets the sum of the effective stat stage boosts for the given Pokemon diff --git a/src/test/daily_mode.test.ts b/src/test/daily_mode.test.ts index 5cc61a62874..3e70cc2d8a7 100644 --- a/src/test/daily_mode.test.ts +++ b/src/test/daily_mode.test.ts @@ -1,5 +1,14 @@ -import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; -import GameManager from "./utils/gameManager"; +import { Biome } from "#app/enums/biome"; +import { Moves } from "#app/enums/moves"; +import { MapModifier } from "#app/modifier/modifier"; +import { pokerogueApi } from "#app/plugins/api/pokerogue-api"; +import ModifierSelectUiHandler from "#app/ui/modifier-select-ui-handler"; +import { Species } from "#enums/species"; +import { Mode } from "#app/ui/ui"; +import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; +import GameManager from "#app/test/utils/gameManager"; + +//const TIMEOUT = 20 * 1000; describe("Daily Mode", () => { let phaserGame: Phaser.Game; @@ -13,6 +22,7 @@ describe("Daily Mode", () => { beforeEach(() => { game = new GameManager(phaserGame); + vi.spyOn(pokerogueApi.daily, "getSeed").mockResolvedValue("test-seed"); }); afterEach(() => { @@ -22,11 +32,70 @@ describe("Daily Mode", () => { it("should initialize properly", async () => { await game.dailyMode.runToSummon(); - const party = game.scene.getParty(); + const party = game.scene.getPlayerParty(); expect(party).toHaveLength(3); - party.forEach(pkm => { + party.forEach((pkm) => { expect(pkm.level).toBe(20); expect(pkm.moveset.length).toBeGreaterThan(0); }); + expect(game.scene.getModifiers(MapModifier).length).toBeGreaterThan(0); + }); +}); + +describe("Shop modifications", async () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + beforeEach(() => { + game = new GameManager(phaserGame); + + game.override + .startingWave(9) + .startingBiome(Biome.ICE_CAVE) + .battleType("single") + .startingLevel(100) // Avoid levelling up + .disableTrainerWaves() + .moveset([ Moves.SPLASH ]) + .enemyMoveset(Moves.SPLASH); + game.modifiers + .addCheck("EVIOLITE") + .addCheck("MINI_BLACK_HOLE"); + vi.spyOn(pokerogueApi.daily, "getSeed").mockResolvedValue("test-seed"); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + game.modifiers.clearChecks(); + }); + + it("should not have Eviolite and Mini Black Hole available in Classic if not unlocked", async () => { + await game.classicMode.startBattle([ Species.BULBASAUR ]); + game.move.select(Moves.SPLASH); + await game.doKillOpponents(); + await game.phaseInterceptor.to("BattleEndPhase"); + game.onNextPrompt("SelectModifierPhase", Mode.MODIFIER_SELECT, () => { + expect(game.scene.ui.getHandler()).toBeInstanceOf(ModifierSelectUiHandler); + game.modifiers + .testCheck("EVIOLITE", false) + .testCheck("MINI_BLACK_HOLE", false); + }); + }); + + it("should have Eviolite and Mini Black Hole available in Daily", async () => { + await game.dailyMode.startBattle(); + game.move.select(Moves.SPLASH); + await game.doKillOpponents(); + await game.phaseInterceptor.to("BattleEndPhase"); + game.onNextPrompt("SelectModifierPhase", Mode.MODIFIER_SELECT, () => { + expect(game.scene.ui.getHandler()).toBeInstanceOf(ModifierSelectUiHandler); + game.modifiers + .testCheck("EVIOLITE", true) + .testCheck("MINI_BLACK_HOLE", true); + }); }); }); diff --git a/src/test/data/splash_messages.test.ts b/src/test/data/splash_messages.test.ts new file mode 100644 index 00000000000..b9ed5b9d365 --- /dev/null +++ b/src/test/data/splash_messages.test.ts @@ -0,0 +1,66 @@ +import { getSplashMessages } from "#app/data/splash-messages"; +import { describe, expect, it, vi, afterEach, beforeEach } from "vitest"; +import * as Constants from "#app/constants"; + +describe("Data - Splash Messages", () => { + it("should contain at least 15 splash messages", () => { + expect(getSplashMessages().length).toBeGreaterThanOrEqual(15); + }); + + // make sure to adjust this test if the weight it changed! + it("should add contain 10 `battlesWon` splash messages", () => { + const battlesWonMessages = getSplashMessages().filter((message) => message === "splashMessages:battlesWon"); + expect(battlesWonMessages).toHaveLength(10); + }); + + describe("Seasonal", () => { + beforeEach(() => { + vi.spyOn(Constants, "USE_SEASONAL_SPLASH_MESSAGES", "get").mockReturnValue(true); + }); + + afterEach(() => { + vi.useRealTimers(); // reset system time + }); + + it("should contain halloween messages from Sep 15 to Oct 31", () => { + testSeason(new Date("2024-09-15"), new Date("2024-10-31"), "halloween"); + }); + + it("should contain xmas messages from Dec 1 to Dec 26", () => { + testSeason(new Date("2024-12-01"), new Date("2024-12-26"), "xmas"); + }); + + it("should contain new years messages frm Jan 1 to Jan 31", () => { + testSeason(new Date("2024-01-01"), new Date("2024-01-31"), "newYears"); + }); + }); +}); + +/** + * Helpoer method to test seasonal messages + * @param startDate The seasons start date + * @param endDate The seasons end date + * @param prefix the splash message prefix (e.g. `newYears` or `xmas`) + */ +function testSeason(startDate: Date, endDate: Date, prefix: string) { + const filterFn = (message: string) => message.startsWith(`splashMessages:${prefix}.`); + + const beforeDate = new Date(startDate); + beforeDate.setDate(startDate.getDate() - 1); + + const afterDate = new Date(endDate); + afterDate.setDate(endDate.getDate() + 1); + + const dates: Date[] = [ beforeDate, startDate, endDate, afterDate ]; + const [ before, start, end, after ] = dates.map((date) => { + vi.setSystemTime(date); + console.log("System time set to", date); + const count = getSplashMessages().filter(filterFn).length; + return count; + }); + + expect(before).toBe(0); + expect(start).toBeGreaterThanOrEqual(10); // make sure to adjust if weight is changed! + expect(end).toBeGreaterThanOrEqual(10); // make sure to adjust if weight is changed! + expect(after).toBe(0); +} diff --git a/src/test/localization/status-effect.test.ts b/src/test/data/status-effect.test.ts similarity index 71% rename from src/test/localization/status-effect.test.ts rename to src/test/data/status-effect.test.ts index 9dcab5aeb5f..4831e8de5de 100644 --- a/src/test/localization/status-effect.test.ts +++ b/src/test/data/status-effect.test.ts @@ -1,12 +1,25 @@ -import { StatusEffect, getStatusEffectActivationText, getStatusEffectDescriptor, getStatusEffectHealText, getStatusEffectObtainText, getStatusEffectOverlapText } from "#app/data/status-effect"; +import { + Status, + getStatusEffectActivationText, + getStatusEffectDescriptor, + getStatusEffectHealText, + getStatusEffectObtainText, + getStatusEffectOverlapText, +} from "#app/data/status-effect"; +import { MoveResult } from "#app/field/pokemon"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import { StatusEffect } from "#enums/status-effect"; +import GameManager from "#test/utils/gameManager"; import { mockI18next } from "#test/utils/testUtils"; import i18next from "i18next"; -import { afterEach, beforeAll, describe, expect, it, vi } from "vitest"; +import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; const pokemonName = "PKM"; const sourceText = "SOURCE"; -describe("status-effect", () => { +describe("Status Effect Messages", () => { beforeAll(() => { i18next.init(); }); @@ -18,44 +31,45 @@ describe("status-effect", () => { mockI18next(); const text = getStatusEffectObtainText(statusEffect, pokemonName); - expect(text).toBe("statusEffect:none.obtain"); + console.log("text:", text); + expect(text).toBe(""); const emptySourceText = getStatusEffectObtainText(statusEffect, pokemonName, ""); - expect(emptySourceText).toBe("statusEffect:none.obtain"); + expect(emptySourceText).toBe(""); }); it("should return the source-obtain text", () => { mockI18next(); const text = getStatusEffectObtainText(statusEffect, pokemonName, sourceText); - expect(text).toBe("statusEffect:none.obtainSource"); + expect(text).toBe(""); const emptySourceText = getStatusEffectObtainText(statusEffect, pokemonName, ""); - expect(emptySourceText).not.toBe("statusEffect:none.obtainSource"); + expect(emptySourceText).toBe(""); }); it("should return the activation text", () => { mockI18next(); const text = getStatusEffectActivationText(statusEffect, pokemonName); - expect(text).toBe("statusEffect:none.activation"); + expect(text).toBe(""); }); it("should return the overlap text", () => { mockI18next(); const text = getStatusEffectOverlapText(statusEffect, pokemonName); - expect(text).toBe("statusEffect:none.overlap"); + expect(text).toBe(""); }); it("should return the heal text", () => { mockI18next(); const text = getStatusEffectHealText(statusEffect, pokemonName); - expect(text).toBe("statusEffect:none.heal"); + expect(text).toBe(""); }); it("should return the descriptor", () => { mockI18next(); const text = getStatusEffectDescriptor(statusEffect); - expect(text).toBe("statusEffect:none.description"); + expect(text).toBe(""); }); }); @@ -291,3 +305,99 @@ describe("status-effect", () => { vi.resetAllMocks(); }); }); + +describe("Status Effects", () => { + describe("Paralysis", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + + game.override + .enemySpecies(Species.MAGIKARP) + .enemyMoveset(Moves.SPLASH) + .enemyAbility(Abilities.BALL_FETCH) + .moveset([ Moves.QUICK_ATTACK ]) + .ability(Abilities.BALL_FETCH) + .statusEffect(StatusEffect.PARALYSIS); + }); + + it("causes the pokemon's move to fail when activated", async () => { + await game.classicMode.startBattle([ Species.FEEBAS ]); + + game.move.select(Moves.QUICK_ATTACK); + await game.move.forceStatusActivation(true); + await game.toNextTurn(); + + expect(game.scene.getEnemyPokemon()!.isFullHp()).toBe(true); + expect(game.scene.getPlayerPokemon()!.getLastXMoves(1)[0].result).toBe(MoveResult.FAIL); + }); + }); + + describe("Sleep", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.SPLASH ]) + .ability(Abilities.BALL_FETCH) + .battleType("single") + .disableCrits() + .enemySpecies(Species.MAGIKARP) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.SPLASH); + }); + + it("should last the appropriate number of turns", async () => { + await game.classicMode.startBattle([ Species.FEEBAS ]); + + const player = game.scene.getPlayerPokemon()!; + player.status = new Status(StatusEffect.SLEEP, 0, 4); + + game.move.select(Moves.SPLASH); + await game.toNextTurn(); + + expect(player.status.effect).toBe(StatusEffect.SLEEP); + + game.move.select(Moves.SPLASH); + await game.toNextTurn(); + + expect(player.status.effect).toBe(StatusEffect.SLEEP); + + game.move.select(Moves.SPLASH); + await game.toNextTurn(); + + expect(player.status.effect).toBe(StatusEffect.SLEEP); + expect(player.getLastXMoves(1)[0].result).toBe(MoveResult.FAIL); + + game.move.select(Moves.SPLASH); + await game.toNextTurn(); + + expect(player.status?.effect).toBeUndefined(); + expect(player.getLastXMoves(1)[0].result).toBe(MoveResult.SUCCESS); + }); + }); +}); diff --git a/src/test/eggs/egg.test.ts b/src/test/eggs/egg.test.ts index 4f00e843b47..aebb196ff5e 100644 --- a/src/test/eggs/egg.test.ts +++ b/src/test/eggs/egg.test.ts @@ -1,7 +1,10 @@ -import { Egg, getLegendaryGachaSpeciesForTimestamp } from "#app/data/egg"; +import { speciesEggTiers } from "#app/data/balance/species-egg-tiers"; +import { speciesStarterCosts } from "#app/data/balance/starters"; +import { Egg, getLegendaryGachaSpeciesForTimestamp, getValidLegendaryGachaSpecies } from "#app/data/egg"; +import { allSpecies } from "#app/data/pokemon-species"; import { EggSourceType } from "#app/enums/egg-source-types"; import { EggTier } from "#app/enums/egg-type"; -import { VariantTier } from "#app/enums/variant-tiers"; +import { VariantTier } from "#app/enums/variant-tier"; import EggData from "#app/system/egg-data"; import * as Utils from "#app/utils"; import { Species } from "#enums/species"; @@ -55,7 +58,7 @@ describe("Egg Generation Tests", () => { let gachaSpeciesCount = 0; for (let i = 0; i < EGG_HATCH_COUNT; i++) { - const result = new Egg({ scene, timestamp, sourceType: EggSourceType.GACHA_LEGENDARY, tier: EggTier.MASTER }).generatePlayerPokemon(scene).species.speciesId; + const result = new Egg({ scene, timestamp, sourceType: EggSourceType.GACHA_LEGENDARY, tier: EggTier.LEGENDARY }).generatePlayerPokemon(scene).species.speciesId; if (result === expectedSpecies) { gachaSpeciesCount++; } @@ -64,6 +67,12 @@ describe("Egg Generation Tests", () => { expect(gachaSpeciesCount).toBeGreaterThan(0.4 * EGG_HATCH_COUNT); expect(gachaSpeciesCount).toBeLessThan(0.6 * EGG_HATCH_COUNT); }); + it("should never be allowed to generate Eternatus via the legendary gacha", () => { + const validLegendaryGachaSpecies = getValidLegendaryGachaSpecies(); + expect(validLegendaryGachaSpecies.every(s => speciesEggTiers[s] === EggTier.LEGENDARY)).toBe(true); + expect(validLegendaryGachaSpecies.every(s => allSpecies[s].isObtainable())).toBe(true); + expect(validLegendaryGachaSpecies.includes(Species.ETERNATUS)).toBe(false); + }); it("should hatch an Arceus. Set from species", () => { const scene = game.scene; const expectedSpecies = Species.ARCEUS; @@ -82,7 +91,7 @@ describe("Egg Generation Tests", () => { }); it("should return an rare tier egg", () => { const scene = game.scene; - const expectedTier = EggTier.GREAT; + const expectedTier = EggTier.RARE; const result = new Egg({ scene, tier: expectedTier }).tier; @@ -90,7 +99,7 @@ describe("Egg Generation Tests", () => { }); it("should return an epic tier egg", () => { const scene = game.scene; - const expectedTier = EggTier.ULTRA; + const expectedTier = EggTier.EPIC; const result = new Egg({ scene, tier: expectedTier }).tier; @@ -98,7 +107,7 @@ describe("Egg Generation Tests", () => { }); it("should return an legendary tier egg", () => { const scene = game.scene; - const expectedTier = EggTier.MASTER; + const expectedTier = EggTier.LEGENDARY; const result = new Egg({ scene, tier: expectedTier }).tier; @@ -136,9 +145,9 @@ describe("Egg Generation Tests", () => { expect(result).toBe(expectedResult); }); - it("should return a shiny common variant", () => { + it("should return a shiny standard variant", () => { const scene = game.scene; - const expectedVariantTier = VariantTier.COMMON; + const expectedVariantTier = VariantTier.STANDARD; const result = new Egg({ scene, isShiny: true, variantTier: expectedVariantTier, species: Species.BULBASAUR }).generatePlayerPokemon(scene).variant; @@ -200,7 +209,7 @@ describe("Egg Generation Tests", () => { const scene = game.scene; const expectedEggTier = EggTier.COMMON; - const result = new Egg({ scene, tier: EggTier.MASTER, species: Species.BULBASAUR }).tier; + const result = new Egg({ scene, tier: EggTier.LEGENDARY, species: Species.BULBASAUR }).tier; expect(result).toBe(expectedEggTier); }); @@ -208,7 +217,7 @@ describe("Egg Generation Tests", () => { const scene = game.scene; const expectedHatchWaves = 10; - const result = new Egg({ scene, tier: EggTier.MASTER, species: Species.BULBASAUR }).hatchWaves; + const result = new Egg({ scene, tier: EggTier.LEGENDARY, species: Species.BULBASAUR }).hatchWaves; expect(result).toBe(expectedHatchWaves); }); @@ -229,7 +238,7 @@ describe("Egg Generation Tests", () => { const result = new EggData(legacyEgg).toEgg(); - expect(result.tier).toBe(EggTier.GREAT); + expect(result.tier).toBe(EggTier.RARE); expect(result.id).toBe(legacyEgg.id); expect(result.timestamp).toBe(legacyEgg.timestamp); expect(result.hatchWaves).toBe(legacyEgg.hatchWaves); @@ -237,23 +246,23 @@ describe("Egg Generation Tests", () => { }); it("should increase egg pity", () => { const scene = game.scene; - const startPityValues = [...scene.gameData.eggPity]; + const startPityValues = [ ...scene.gameData.eggPity ]; new Egg({ scene, sourceType: EggSourceType.GACHA_MOVE, pulled: true, tier: EggTier.COMMON }); - expect(scene.gameData.eggPity[EggTier.GREAT]).toBe(startPityValues[EggTier.GREAT] + 1); - expect(scene.gameData.eggPity[EggTier.ULTRA]).toBe(startPityValues[EggTier.ULTRA] + 1); - expect(scene.gameData.eggPity[EggTier.MASTER]).toBe(startPityValues[EggTier.MASTER] + 1); + expect(scene.gameData.eggPity[EggTier.RARE]).toBe(startPityValues[EggTier.RARE] + 1); + expect(scene.gameData.eggPity[EggTier.EPIC]).toBe(startPityValues[EggTier.EPIC] + 1); + expect(scene.gameData.eggPity[EggTier.LEGENDARY]).toBe(startPityValues[EggTier.LEGENDARY] + 1); }); it("should increase legendary egg pity by two", () => { const scene = game.scene; - const startPityValues = [...scene.gameData.eggPity]; + const startPityValues = [ ...scene.gameData.eggPity ]; new Egg({ scene, sourceType: EggSourceType.GACHA_LEGENDARY, pulled: true, tier: EggTier.COMMON }); - expect(scene.gameData.eggPity[EggTier.GREAT]).toBe(startPityValues[EggTier.GREAT] + 1); - expect(scene.gameData.eggPity[EggTier.ULTRA]).toBe(startPityValues[EggTier.ULTRA] + 1); - expect(scene.gameData.eggPity[EggTier.MASTER]).toBe(startPityValues[EggTier.MASTER] + 2); + expect(scene.gameData.eggPity[EggTier.RARE]).toBe(startPityValues[EggTier.RARE] + 1); + expect(scene.gameData.eggPity[EggTier.EPIC]).toBe(startPityValues[EggTier.EPIC] + 1); + expect(scene.gameData.eggPity[EggTier.LEGENDARY]).toBe(startPityValues[EggTier.LEGENDARY] + 2); }); it("should not increase manaphy egg count if bulbasaurs are pulled", () => { const scene = game.scene; @@ -277,7 +286,7 @@ describe("Egg Generation Tests", () => { const scene = game.scene; const startingRareEggsPulled = scene.gameData.gameStats.rareEggsPulled; - new Egg({ scene, sourceType: EggSourceType.GACHA_MOVE, pulled: true, tier: EggTier.GREAT }); + new Egg({ scene, sourceType: EggSourceType.GACHA_MOVE, pulled: true, tier: EggTier.RARE }); expect(scene.gameData.gameStats.rareEggsPulled).toBe(startingRareEggsPulled + 1); }); @@ -285,7 +294,7 @@ describe("Egg Generation Tests", () => { const scene = game.scene; const startingEpicEggsPulled = scene.gameData.gameStats.epicEggsPulled; - new Egg({ scene, sourceType: EggSourceType.GACHA_MOVE, pulled: true, tier: EggTier.ULTRA }); + new Egg({ scene, sourceType: EggSourceType.GACHA_MOVE, pulled: true, tier: EggTier.EPIC }); expect(scene.gameData.gameStats.epicEggsPulled).toBe(startingEpicEggsPulled + 1); }); @@ -293,7 +302,7 @@ describe("Egg Generation Tests", () => { const scene = game.scene; const startingLegendaryEggsPulled = scene.gameData.gameStats.legendaryEggsPulled; - new Egg({ scene, sourceType: EggSourceType.GACHA_MOVE, pulled: true, tier: EggTier.MASTER }); + new Egg({ scene, sourceType: EggSourceType.GACHA_MOVE, pulled: true, tier: EggTier.LEGENDARY }); expect(scene.gameData.gameStats.legendaryEggsPulled).toBe(startingLegendaryEggsPulled + 1); }); @@ -301,8 +310,8 @@ describe("Egg Generation Tests", () => { vi.spyOn(Utils, "randInt").mockReturnValue(1); const scene = game.scene; - const expectedTier1 = EggTier.MASTER; - const expectedTier2 = EggTier.ULTRA; + const expectedTier1 = EggTier.LEGENDARY; + const expectedTier2 = EggTier.EPIC; const result1 = new Egg({ scene, sourceType: EggSourceType.GACHA_LEGENDARY, pulled: true }).tier; const result2 = new Egg({ scene, sourceType: EggSourceType.GACHA_MOVE, pulled: true }).tier; @@ -323,7 +332,7 @@ describe("Egg Generation Tests", () => { scene.setSeed("ABCDEFGHIJKLMNOPQRSTUVWXYZ"); scene.resetSeed(); - const firstEgg = new Egg({scene, sourceType: EggSourceType.GACHA_SHINY, tier: EggTier.COMMON}); + const firstEgg = new Egg({ scene, sourceType: EggSourceType.GACHA_SHINY, tier: EggTier.COMMON }); const firstHatch = firstEgg.generatePlayerPokemon(scene); let diffEggMove = false; let diffSpecies = false; @@ -334,7 +343,7 @@ describe("Egg Generation Tests", () => { scene.setSeed("ABCDEFGHIJKLMNOPQRSTUVWXYZ"); scene.resetSeed(); // Make sure that eggs are unpredictable even if using same seed - const newEgg = new Egg({scene, sourceType: EggSourceType.GACHA_SHINY, tier: EggTier.COMMON}); + const newEgg = new Egg({ scene, sourceType: EggSourceType.GACHA_SHINY, tier: EggTier.COMMON }); const newHatch = newEgg.generatePlayerPokemon(scene); diffEggMove = diffEggMove || (newEgg.eggMoveIndex !== firstEgg.eggMoveIndex); diffSpecies = diffSpecies || (newHatch.species.speciesId !== firstHatch.species.speciesId); @@ -353,7 +362,7 @@ describe("Egg Generation Tests", () => { scene.setSeed("ABCDEFGHIJKLMNOPQRSTUVWXYZ"); scene.resetSeed(); - const firstEgg = new Egg({scene, species: Species.BULBASAUR}); + const firstEgg = new Egg({ scene, species: Species.BULBASAUR }); const firstHatch = firstEgg.generatePlayerPokemon(scene); let diffEggMove = false; let diffSpecies = false; @@ -363,7 +372,7 @@ describe("Egg Generation Tests", () => { scene.setSeed("ABCDEFGHIJKLMNOPQRSTUVWXYZ"); scene.resetSeed(); // Make sure that eggs are unpredictable even if using same seed - const newEgg = new Egg({scene, species: Species.BULBASAUR}); + const newEgg = new Egg({ scene, species: Species.BULBASAUR }); const newHatch = newEgg.generatePlayerPokemon(scene); diffEggMove = diffEggMove || (newEgg.eggMoveIndex !== firstEgg.eggMoveIndex); diffSpecies = diffSpecies || (newHatch.species.speciesId !== firstHatch.species.speciesId); @@ -376,4 +385,23 @@ describe("Egg Generation Tests", () => { expect(diffShiny).toBe(true); expect(diffAbility).toBe(true); }); + + // For now, we are using this test to detect oversights in egg tiers. + // Delete this test if the balance team rebalances species costs independently of egg tiers. + it("should have correct egg tiers based on species costs", () => { + const getExpectedEggTier = (starterCost) => + starterCost <= 3 ? EggTier.COMMON + : starterCost <= 5 ? EggTier.RARE + : starterCost <= 7 ? EggTier.EPIC + : EggTier.LEGENDARY; + + allSpecies.forEach(pokemonSpecies => { + const rootSpecies = pokemonSpecies.getRootSpeciesId(); + const speciesCost = speciesStarterCosts[rootSpecies]; + const expectedEggTier = getExpectedEggTier(speciesCost); + const actualEggTier = speciesEggTiers[rootSpecies]; + + expect(actualEggTier).toBe(expectedEggTier); + }); + }); }); diff --git a/src/test/eggs/manaphy-egg.test.ts b/src/test/eggs/manaphy-egg.test.ts index 257bf330bb8..3b2c40ae84a 100644 --- a/src/test/eggs/manaphy-egg.test.ts +++ b/src/test/eggs/manaphy-egg.test.ts @@ -60,8 +60,8 @@ describe("Manaphy Eggs", () => { } expect(manaphyCount + phioneCount).toBe(EGG_HATCH_COUNT); - expect(manaphyCount).toBe(1/8 * EGG_HATCH_COUNT); - expect(rareEggMoveCount).toBe(1/12 * EGG_HATCH_COUNT); + expect(manaphyCount).toBe(1 / 8 * EGG_HATCH_COUNT); + expect(rareEggMoveCount).toBe(1 / 12 * EGG_HATCH_COUNT); }); it("should have correct Manaphy rates and Rare Egg Move rates, from Phione species eggs", () => { @@ -86,8 +86,8 @@ describe("Manaphy Eggs", () => { } expect(manaphyCount + phioneCount).toBe(EGG_HATCH_COUNT); - expect(manaphyCount).toBe(1/8 * EGG_HATCH_COUNT); - expect(rareEggMoveCount).toBe(1/6 * EGG_HATCH_COUNT); + expect(manaphyCount).toBe(1 / 8 * EGG_HATCH_COUNT); + expect(rareEggMoveCount).toBe(1 / 6 * EGG_HATCH_COUNT); }); it("should have correct Manaphy rates and Rare Egg Move rates, from Manaphy species eggs", () => { @@ -113,6 +113,6 @@ describe("Manaphy Eggs", () => { expect(phioneCount).toBe(0); expect(manaphyCount).toBe(EGG_HATCH_COUNT); - expect(rareEggMoveCount).toBe(1/6 * EGG_HATCH_COUNT); + expect(rareEggMoveCount).toBe(1 / 6 * EGG_HATCH_COUNT); }); }); diff --git a/src/test/endless_boss.test.ts b/src/test/endless_boss.test.ts index 8a564695e42..c9f3afc3936 100644 --- a/src/test/endless_boss.test.ts +++ b/src/test/endless_boss.test.ts @@ -32,7 +32,7 @@ describe("Endless Boss", () => { it(`should spawn a minor boss every ${EndlessBossWave.Minor} waves in END biome in Endless`, async () => { game.override.startingWave(EndlessBossWave.Minor); - await game.runToFinalBossEncounter([Species.BIDOOF], GameModes.ENDLESS); + await game.runToFinalBossEncounter([ Species.BIDOOF ], GameModes.ENDLESS); expect(game.scene.currentBattle.waveIndex).toBe(EndlessBossWave.Minor); expect(game.scene.arena.biomeType).toBe(Biome.END); @@ -44,7 +44,7 @@ describe("Endless Boss", () => { it(`should spawn a major boss every ${EndlessBossWave.Major} waves in END biome in Endless`, async () => { game.override.startingWave(EndlessBossWave.Major); - await game.runToFinalBossEncounter([Species.BIDOOF], GameModes.ENDLESS); + await game.runToFinalBossEncounter([ Species.BIDOOF ], GameModes.ENDLESS); expect(game.scene.currentBattle.waveIndex).toBe(EndlessBossWave.Major); expect(game.scene.arena.biomeType).toBe(Biome.END); @@ -56,7 +56,7 @@ describe("Endless Boss", () => { it(`should spawn a minor boss every ${EndlessBossWave.Minor} waves in END biome in Spliced Endless`, async () => { game.override.startingWave(EndlessBossWave.Minor); - await game.runToFinalBossEncounter([Species.BIDOOF], GameModes.SPLICED_ENDLESS); + await game.runToFinalBossEncounter([ Species.BIDOOF ], GameModes.SPLICED_ENDLESS); expect(game.scene.currentBattle.waveIndex).toBe(EndlessBossWave.Minor); expect(game.scene.arena.biomeType).toBe(Biome.END); @@ -68,7 +68,7 @@ describe("Endless Boss", () => { it(`should spawn a major boss every ${EndlessBossWave.Major} waves in END biome in Spliced Endless`, async () => { game.override.startingWave(EndlessBossWave.Major); - await game.runToFinalBossEncounter([Species.BIDOOF], GameModes.SPLICED_ENDLESS); + await game.runToFinalBossEncounter([ Species.BIDOOF ], GameModes.SPLICED_ENDLESS); expect(game.scene.currentBattle.waveIndex).toBe(EndlessBossWave.Major); expect(game.scene.arena.biomeType).toBe(Biome.END); @@ -80,7 +80,7 @@ describe("Endless Boss", () => { it(`should NOT spawn major or minor boss outside wave ${EndlessBossWave.Minor}s in END biome`, async () => { game.override.startingWave(EndlessBossWave.Minor - 1); - await game.runToFinalBossEncounter([Species.BIDOOF], GameModes.ENDLESS); + await game.runToFinalBossEncounter([ Species.BIDOOF ], GameModes.ENDLESS); expect(game.scene.currentBattle.waveIndex).not.toBe(EndlessBossWave.Minor); expect(game.scene.getEnemyPokemon()!.species.speciesId).not.toBe(Species.ETERNATUS); diff --git a/src/test/enemy_command.test.ts b/src/test/enemy_command.test.ts index 9a2caa56dfc..49419f5b34d 100644 --- a/src/test/enemy_command.test.ts +++ b/src/test/enemy_command.test.ts @@ -8,7 +8,7 @@ import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; -const TIMEOUT = 20 * 1000; + const NUM_TRIALS = 300; type MoveChoiceSet = { [key: number]: number }; @@ -23,7 +23,7 @@ function getEnemyMoveChoices(pokemon: EnemyPokemon, moveChoices: MoveChoiceSet): moveChoices[queuedMove.move]++; } - for (const [moveId, count] of Object.entries(moveChoices)) { + for (const [ moveId, count ] of Object.entries(moveChoices)) { console.log(`Move: ${allMoves[moveId].name} Count: ${count} (${count / NUM_TRIALS * 100}%)`); } } @@ -55,11 +55,11 @@ describe("Enemy Commands - Move Selection", () => { async () => { game.override .enemySpecies(Species.ETERNATUS) - .enemyMoveset([Moves.ETERNABEAM, Moves.SLUDGE_BOMB, Moves.DRAGON_DANCE, Moves.COSMIC_POWER]) + .enemyMoveset([ Moves.ETERNABEAM, Moves.SLUDGE_BOMB, Moves.DRAGON_DANCE, Moves.COSMIC_POWER ]) .startingLevel(1) .enemyLevel(100); - await game.classicMode.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); const enemyPokemon = game.scene.getEnemyPokemon()!; enemyPokemon.aiType = AiType.SMART_RANDOM; @@ -74,7 +74,7 @@ describe("Enemy Commands - Move Selection", () => { expect(moveChoices[mv.moveId]).toBe(0); } }); - }, TIMEOUT + } ); it( @@ -82,11 +82,11 @@ describe("Enemy Commands - Move Selection", () => { async () => { game.override .enemySpecies(Species.KANGASKHAN) - .enemyMoveset([Moves.LAST_RESORT, Moves.GIGA_IMPACT, Moves.SPLASH, Moves.SWORDS_DANCE]) + .enemyMoveset([ Moves.LAST_RESORT, Moves.GIGA_IMPACT, Moves.SPLASH, Moves.SWORDS_DANCE ]) .startingLevel(1) .enemyLevel(100); - await game.classicMode.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); const enemyPokemon = game.scene.getEnemyPokemon()!; enemyPokemon.aiType = AiType.SMART_RANDOM; @@ -101,6 +101,6 @@ describe("Enemy Commands - Move Selection", () => { expect(moveChoices[mv.moveId]).toBe(0); } }); - }, TIMEOUT + } ); }); diff --git a/src/test/escape-calculations.test.ts b/src/test/escape-calculations.test.ts index ecf22fc74aa..cc18fd78066 100644 --- a/src/test/escape-calculations.test.ts +++ b/src/test/escape-calculations.test.ts @@ -32,13 +32,13 @@ describe("Escape chance calculations", () => { }); it("single non-boss opponent", async () => { - await game.classicMode.startBattle([Species.BULBASAUR]); + await game.classicMode.startBattle([ Species.BULBASAUR ]); const playerPokemon = game.scene.getPlayerField(); const enemyField = game.scene.getEnemyField(); const enemySpeed = 100; // set enemyPokemon's speed to 100 - vi.spyOn(enemyField[0], "stats", "get").mockReturnValue([20, 20, 20, 20, 20, enemySpeed]); + vi.spyOn(enemyField[0], "stats", "get").mockReturnValue([ 20, 20, 20, 20, 20, enemySpeed ]); const commandPhase = game.scene.getCurrentPhase() as CommandPhase; commandPhase.handleCommand(Command.RUN, 0); @@ -79,7 +79,7 @@ describe("Escape chance calculations", () => { // sets the number of escape attempts to the required amount game.scene.currentBattle.escapeAttempts = escapeChances[i].escapeAttempts; // set playerPokemon's speed to a multiple of the enemySpeed - vi.spyOn(playerPokemon[0], "stats", "get").mockReturnValue([20, 20, 20, 20, 20, escapeChances[i].pokemonSpeedRatio * enemySpeed]); + vi.spyOn(playerPokemon[0], "stats", "get").mockReturnValue([ 20, 20, 20, 20, 20, escapeChances[i].pokemonSpeedRatio * enemySpeed ]); phase.attemptRunAway(playerPokemon, enemyField, escapePercentage); expect(escapePercentage.value).toBe(escapeChances[i].expectedEscapeChance); } @@ -87,7 +87,7 @@ describe("Escape chance calculations", () => { it("double non-boss opponent", async () => { game.override.battleType("double"); - await game.classicMode.startBattle([Species.BULBASAUR, Species.ABOMASNOW]); + await game.classicMode.startBattle([ Species.BULBASAUR, Species.ABOMASNOW ]); const playerPokemon = game.scene.getPlayerField(); const enemyField = game.scene.getEnemyField(); @@ -98,9 +98,9 @@ describe("Escape chance calculations", () => { // this is used to find the ratio of the player's first pokemon const playerASpeedPercentage = 0.4; // set enemyAPokemon's speed to 70 - vi.spyOn(enemyField[0], "stats", "get").mockReturnValue([20, 20, 20, 20, 20, enemyASpeed]); + vi.spyOn(enemyField[0], "stats", "get").mockReturnValue([ 20, 20, 20, 20, 20, enemyASpeed ]); // set enemyBPokemon's speed to 30 - vi.spyOn(enemyField[1], "stats", "get").mockReturnValue([20, 20, 20, 20, 20, enemyBSpeed]); + vi.spyOn(enemyField[1], "stats", "get").mockReturnValue([ 20, 20, 20, 20, 20, enemyBSpeed ]); const commandPhase = game.scene.getCurrentPhase() as CommandPhase; commandPhase.handleCommand(Command.RUN, 0); @@ -141,9 +141,9 @@ describe("Escape chance calculations", () => { // sets the number of escape attempts to the required amount game.scene.currentBattle.escapeAttempts = escapeChances[i].escapeAttempts; // set the first playerPokemon's speed to a multiple of the enemySpeed - vi.spyOn(playerPokemon[0], "stats", "get").mockReturnValue([20, 20, 20, 20, 20, Math.floor(escapeChances[i].pokemonSpeedRatio * totalEnemySpeed * playerASpeedPercentage)]); + vi.spyOn(playerPokemon[0], "stats", "get").mockReturnValue([ 20, 20, 20, 20, 20, Math.floor(escapeChances[i].pokemonSpeedRatio * totalEnemySpeed * playerASpeedPercentage) ]); // set the second playerPokemon's speed to the remaining value of speed - vi.spyOn(playerPokemon[1], "stats", "get").mockReturnValue([20, 20, 20, 20, 20, escapeChances[i].pokemonSpeedRatio * totalEnemySpeed - playerPokemon[0].stats[5]]); + vi.spyOn(playerPokemon[1], "stats", "get").mockReturnValue([ 20, 20, 20, 20, 20, escapeChances[i].pokemonSpeedRatio * totalEnemySpeed - playerPokemon[0].stats[5] ]); phase.attemptRunAway(playerPokemon, enemyField, escapePercentage); // checks to make sure the escape values are the same expect(escapePercentage.value).toBe(escapeChances[i].expectedEscapeChance); @@ -154,13 +154,13 @@ describe("Escape chance calculations", () => { it("single boss opponent", async () => { game.override.startingWave(10); - await game.classicMode.startBattle([Species.BULBASAUR]); + await game.classicMode.startBattle([ Species.BULBASAUR ]); const playerPokemon = game.scene.getPlayerField()!; const enemyField = game.scene.getEnemyField()!; const enemySpeed = 100; // set enemyPokemon's speed to 100 - vi.spyOn(enemyField[0], "stats", "get").mockReturnValue([20, 20, 20, 20, 20, enemySpeed]); + vi.spyOn(enemyField[0], "stats", "get").mockReturnValue([ 20, 20, 20, 20, 20, enemySpeed ]); const commandPhase = game.scene.getCurrentPhase() as CommandPhase; commandPhase.handleCommand(Command.RUN, 0); @@ -215,7 +215,7 @@ describe("Escape chance calculations", () => { // sets the number of escape attempts to the required amount game.scene.currentBattle.escapeAttempts = escapeChances[i].escapeAttempts; // set playerPokemon's speed to a multiple of the enemySpeed - vi.spyOn(playerPokemon[0], "stats", "get").mockReturnValue([20, 20, 20, 20, 20, escapeChances[i].pokemonSpeedRatio * enemySpeed]); + vi.spyOn(playerPokemon[0], "stats", "get").mockReturnValue([ 20, 20, 20, 20, 20, escapeChances[i].pokemonSpeedRatio * enemySpeed ]); phase.attemptRunAway(playerPokemon, enemyField, escapePercentage); expect(escapePercentage.value).toBe(escapeChances[i].expectedEscapeChance); } @@ -224,7 +224,7 @@ describe("Escape chance calculations", () => { it("double boss opponent", async () => { game.override.battleType("double"); game.override.startingWave(10); - await game.classicMode.startBattle([Species.BULBASAUR, Species.ABOMASNOW]); + await game.classicMode.startBattle([ Species.BULBASAUR, Species.ABOMASNOW ]); const playerPokemon = game.scene.getPlayerField(); const enemyField = game.scene.getEnemyField(); @@ -235,9 +235,9 @@ describe("Escape chance calculations", () => { // this is used to find the ratio of the player's first pokemon const playerASpeedPercentage = 0.8; // set enemyAPokemon's speed to 70 - vi.spyOn(enemyField[0], "stats", "get").mockReturnValue([20, 20, 20, 20, 20, enemyASpeed]); + vi.spyOn(enemyField[0], "stats", "get").mockReturnValue([ 20, 20, 20, 20, 20, enemyASpeed ]); // set enemyBPokemon's speed to 30 - vi.spyOn(enemyField[1], "stats", "get").mockReturnValue([20, 20, 20, 20, 20, enemyBSpeed]); + vi.spyOn(enemyField[1], "stats", "get").mockReturnValue([ 20, 20, 20, 20, 20, enemyBSpeed ]); const commandPhase = game.scene.getCurrentPhase() as CommandPhase; commandPhase.handleCommand(Command.RUN, 0); @@ -290,9 +290,9 @@ describe("Escape chance calculations", () => { // sets the number of escape attempts to the required amount game.scene.currentBattle.escapeAttempts = escapeChances[i].escapeAttempts; // set the first playerPokemon's speed to a multiple of the enemySpeed - vi.spyOn(playerPokemon[0], "stats", "get").mockReturnValue([20, 20, 20, 20, 20, Math.floor(escapeChances[i].pokemonSpeedRatio * totalEnemySpeed * playerASpeedPercentage)]); + vi.spyOn(playerPokemon[0], "stats", "get").mockReturnValue([ 20, 20, 20, 20, 20, Math.floor(escapeChances[i].pokemonSpeedRatio * totalEnemySpeed * playerASpeedPercentage) ]); // set the second playerPokemon's speed to the remaining value of speed - vi.spyOn(playerPokemon[1], "stats", "get").mockReturnValue([20, 20, 20, 20, 20, escapeChances[i].pokemonSpeedRatio * totalEnemySpeed - playerPokemon[0].stats[5]]); + vi.spyOn(playerPokemon[1], "stats", "get").mockReturnValue([ 20, 20, 20, 20, 20, escapeChances[i].pokemonSpeedRatio * totalEnemySpeed - playerPokemon[0].stats[5] ]); phase.attemptRunAway(playerPokemon, enemyField, escapePercentage); // checks to make sure the escape values are the same expect(escapePercentage.value).toBe(escapeChances[i].expectedEscapeChance); diff --git a/src/test/evolution.test.ts b/src/test/evolution.test.ts index 16922babd7c..3046d103cbc 100644 --- a/src/test/evolution.test.ts +++ b/src/test/evolution.test.ts @@ -1,4 +1,4 @@ -import { pokemonEvolutions, SpeciesFormEvolution, SpeciesWildEvolutionDelay } from "#app/data/pokemon-evolutions"; +import { pokemonEvolutions, SpeciesFormEvolution, SpeciesWildEvolutionDelay } from "#app/data/balance/pokemon-evolutions"; import { Abilities } from "#app/enums/abilities"; import { Moves } from "#app/enums/moves"; import { Species } from "#app/enums/species"; @@ -10,7 +10,6 @@ import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vite describe("Evolution", () => { let phaserGame: Phaser.Game; let game: GameManager; - const TIMEOUT = 1000 * 20; beforeAll(() => { phaserGame = new Phaser.Game({ @@ -34,10 +33,10 @@ describe("Evolution", () => { }); it("should keep hidden ability after evolving", async () => { - await game.classicMode.runToSummon([Species.EEVEE, Species.TRAPINCH]); + await game.classicMode.runToSummon([ Species.EEVEE, Species.TRAPINCH ]); - const eevee = game.scene.getParty()[0]; - const trapinch = game.scene.getParty()[1]; + const eevee = game.scene.getPlayerParty()[0]; + const trapinch = game.scene.getPlayerParty()[1]; eevee.abilityIndex = 2; trapinch.abilityIndex = 2; @@ -46,13 +45,13 @@ describe("Evolution", () => { trapinch.evolve(pokemonEvolutions[Species.TRAPINCH][0], trapinch.getSpeciesForm()); expect(trapinch.abilityIndex).toBe(1); - }, TIMEOUT); + }); it("should keep same ability slot after evolving", async () => { - await game.classicMode.runToSummon([Species.BULBASAUR, Species.CHARMANDER]); + await game.classicMode.runToSummon([ Species.BULBASAUR, Species.CHARMANDER ]); - const bulbasaur = game.scene.getParty()[0]; - const charmander = game.scene.getParty()[1]; + const bulbasaur = game.scene.getPlayerParty()[0]; + const charmander = game.scene.getPlayerParty()[1]; bulbasaur.abilityIndex = 0; charmander.abilityIndex = 1; @@ -61,33 +60,33 @@ describe("Evolution", () => { charmander.evolve(pokemonEvolutions[Species.CHARMANDER][0], charmander.getSpeciesForm()); expect(charmander.abilityIndex).toBe(1); - }, TIMEOUT); + }); it("should handle illegal abilityIndex values", async () => { - await game.classicMode.runToSummon([Species.SQUIRTLE]); + await game.classicMode.runToSummon([ Species.SQUIRTLE ]); const squirtle = game.scene.getPlayerPokemon()!; squirtle.abilityIndex = 5; squirtle.evolve(pokemonEvolutions[Species.SQUIRTLE][0], squirtle.getSpeciesForm()); expect(squirtle.abilityIndex).toBe(0); - }, TIMEOUT); + }); it("should handle nincada's unique evolution", async () => { - await game.classicMode.runToSummon([Species.NINCADA]); + await game.classicMode.runToSummon([ Species.NINCADA ]); const nincada = game.scene.getPlayerPokemon()!; nincada.abilityIndex = 2; nincada.metBiome = -1; nincada.evolve(pokemonEvolutions[Species.NINCADA][0], nincada.getSpeciesForm()); - const ninjask = game.scene.getParty()[0]; - const shedinja = game.scene.getParty()[1]; + const ninjask = game.scene.getPlayerParty()[0]; + const shedinja = game.scene.getPlayerParty()[1]; expect(ninjask.abilityIndex).toBe(2); expect(shedinja.abilityIndex).toBe(1); // Regression test for https://github.com/pagefaultgames/pokerogue/issues/3842 expect(shedinja.metBiome).toBe(-1); - }, TIMEOUT); + }); it("should set wild delay to NONE by default", () => { const speciesFormEvo = new SpeciesFormEvolution(Species.ABRA, null, null, 1000, null, null); @@ -96,14 +95,14 @@ describe("Evolution", () => { }); it("should increase both HP and max HP when evolving", async () => { - game.override.moveset([Moves.SURF]) + game.override.moveset([ Moves.SURF ]) .enemySpecies(Species.GOLEM) .enemyMoveset(Moves.SPLASH) .startingWave(21) .startingLevel(16) .enemyLevel(50); - await game.startBattle([Species.TOTODILE]); + await game.startBattle([ Species.TOTODILE ]); const totodile = game.scene.getPlayerPokemon()!; const hpBefore = totodile.hp; @@ -120,17 +119,17 @@ describe("Evolution", () => { expect(totodile.hp).toBe(totodile.getMaxHp()); expect(totodile.hp).toBeGreaterThan(hpBefore); - }, TIMEOUT); + }); it("should not fully heal HP when evolving", async () => { - game.override.moveset([Moves.SURF]) + game.override.moveset([ Moves.SURF ]) .enemySpecies(Species.GOLEM) .enemyMoveset(Moves.SPLASH) .startingWave(21) .startingLevel(13) .enemyLevel(30); - await game.startBattle([Species.CYNDAQUIL]); + await game.startBattle([ Species.CYNDAQUIL ]); const cyndaquil = game.scene.getPlayerPokemon()!; cyndaquil.hp = Math.floor(cyndaquil.getMaxHp() / 2); @@ -150,7 +149,7 @@ describe("Evolution", () => { expect(cyndaquil.getMaxHp()).toBeGreaterThan(maxHpBefore); expect(cyndaquil.hp).toBeGreaterThan(hpBefore); expect(cyndaquil.hp).toBeLessThan(cyndaquil.getMaxHp()); - }, TIMEOUT); + }); it("should handle rng-based split evolution", async () => { /* this test checks to make sure that tandemaus will @@ -163,7 +162,7 @@ describe("Evolution", () => { * If the value is 0, it's a 3 family maushold, whereas if the value is * 1, 2 or 3, it's a 4 family maushold */ - await game.startBattle([Species.TANDEMAUS]); // starts us off with a tandemaus + await game.startBattle([ Species.TANDEMAUS ]); // starts us off with a tandemaus const playerPokemon = game.scene.getPlayerPokemon()!; playerPokemon.level = 25; // tandemaus evolves at level 25 vi.spyOn(Utils, "randSeedInt").mockReturnValue(0); // setting the random generator to be 0 to force a three family maushold @@ -174,5 +173,5 @@ describe("Evolution", () => { const fourForm = playerPokemon.getEvolution()!; expect(fourForm.evoFormKey).toBe(null); // meanwhile, according to the pokemon-forms, the evoFormKey for a 4 family maushold is null } - }, TIMEOUT); + }); }); diff --git a/src/test/field/pokemon.test.ts b/src/test/field/pokemon.test.ts index f7c1cf8bc3d..0bfbd03e9d9 100644 --- a/src/test/field/pokemon.test.ts +++ b/src/test/field/pokemon.test.ts @@ -1,8 +1,9 @@ import { Species } from "#app/enums/species"; import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; import GameManager from "../utils/gameManager"; -import { PokeballType } from "#app/enums/pokeball"; +import { PokeballType } from "#enums/pokeball"; import BattleScene from "#app/battle-scene"; +import { Moves } from "#app/enums/moves"; describe("Spec - Pokemon", () => { let phaserGame: Phaser.Game; @@ -23,7 +24,7 @@ describe("Spec - Pokemon", () => { }); it("should not crash when trying to set status of undefined", async () => { - await game.classicMode.runToSummon([Species.ABRA]); + await game.classicMode.runToSummon([ Species.ABRA ]); const pkm = game.scene.getPlayerPokemon()!; expect(pkm).toBeDefined(); @@ -36,7 +37,7 @@ describe("Spec - Pokemon", () => { beforeEach(async () => { game.override.enemySpecies(Species.ZUBAT); - await game.classicMode.runToSummon([Species.ABRA, Species.ABRA, Species.ABRA, Species.ABRA, Species.ABRA]); // 5 Abra, only 1 slot left + await game.classicMode.runToSummon([ Species.ABRA, Species.ABRA, Species.ABRA, Species.ABRA, Species.ABRA ]); // 5 Abra, only 1 slot left scene = game.scene; }); @@ -44,7 +45,7 @@ describe("Spec - Pokemon", () => { const zubat = scene.getEnemyPokemon()!; zubat.addToParty(PokeballType.LUXURY_BALL); - const party = scene.getParty(); + const party = scene.getPlayerParty(); expect(party).toHaveLength(6); party.forEach((pkm, index) =>{ expect(pkm.species.speciesId).toBe(index === 5 ? Species.ZUBAT : Species.ABRA); @@ -56,11 +57,22 @@ describe("Spec - Pokemon", () => { const zubat = scene.getEnemyPokemon()!; zubat.addToParty(PokeballType.LUXURY_BALL, slotIndex); - const party = scene.getParty(); + const party = scene.getPlayerParty(); expect(party).toHaveLength(6); party.forEach((pkm, index) =>{ expect(pkm.species.speciesId).toBe(index === slotIndex ? Species.ZUBAT : Species.ABRA); }); }); }); + + it("should not share tms between different forms", async () => { + game.override.starterForms({ [Species.ROTOM]: 4 }); + + await game.classicMode.startBattle([ Species.ROTOM ]); + + const fanRotom = game.scene.getPlayerPokemon()!; + + expect(fanRotom.compatibleTms).not.toContain(Moves.BLIZZARD); + expect(fanRotom.compatibleTms).toContain(Moves.AIR_SLASH); + }); }); diff --git a/src/test/final_boss.test.ts b/src/test/final_boss.test.ts index fee4dc6c8f6..5540d9511e4 100644 --- a/src/test/final_boss.test.ts +++ b/src/test/final_boss.test.ts @@ -1,12 +1,12 @@ -import { StatusEffect } from "#app/data/status-effect"; -import { Abilities } from "#app/enums/abilities"; -import { Biome } from "#app/enums/biome"; -import { Moves } from "#app/enums/moves"; -import { Species } from "#app/enums/species"; import { GameModes } from "#app/game-mode"; import { TurnHeldItemTransferModifier } from "#app/modifier/modifier"; +import { Abilities } from "#enums/abilities"; +import { Biome } from "#enums/biome"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import { StatusEffect } from "#enums/status-effect"; +import GameManager from "#test/utils/gameManager"; import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; -import GameManager from "./utils/gameManager"; const FinalWave = { Classic: 200, @@ -38,7 +38,7 @@ describe("Final Boss", () => { }); it("should spawn Eternatus on wave 200 in END biome", async () => { - await game.runToFinalBossEncounter([Species.BIDOOF], GameModes.CLASSIC); + await game.runToFinalBossEncounter([ Species.BIDOOF ], GameModes.CLASSIC); expect(game.scene.currentBattle.waveIndex).toBe(FinalWave.Classic); expect(game.scene.arena.biomeType).toBe(Biome.END); @@ -47,7 +47,7 @@ describe("Final Boss", () => { it("should NOT spawn Eternatus before wave 200 in END biome", async () => { game.override.startingWave(FinalWave.Classic - 1); - await game.runToFinalBossEncounter([Species.BIDOOF], GameModes.CLASSIC); + await game.runToFinalBossEncounter([ Species.BIDOOF ], GameModes.CLASSIC); expect(game.scene.currentBattle.waveIndex).not.toBe(FinalWave.Classic); expect(game.scene.arena.biomeType).toBe(Biome.END); @@ -56,7 +56,7 @@ describe("Final Boss", () => { it("should NOT spawn Eternatus outside of END biome", async () => { game.override.startingBiome(Biome.FOREST); - await game.runToFinalBossEncounter([Species.BIDOOF], GameModes.CLASSIC); + await game.runToFinalBossEncounter([ Species.BIDOOF ], GameModes.CLASSIC); expect(game.scene.currentBattle.waveIndex).toBe(FinalWave.Classic); expect(game.scene.arena.biomeType).not.toBe(Biome.END); @@ -64,7 +64,7 @@ describe("Final Boss", () => { }); it("should not have passive enabled on Eternatus", async () => { - await game.runToFinalBossEncounter([Species.BIDOOF], GameModes.CLASSIC); + await game.runToFinalBossEncounter([ Species.BIDOOF ], GameModes.CLASSIC); const eternatus = game.scene.getEnemyPokemon()!; expect(eternatus.species.speciesId).toBe(Species.ETERNATUS); @@ -72,7 +72,7 @@ describe("Final Boss", () => { }); it("should change form on direct hit down to last boss fragment", async () => { - await game.runToFinalBossEncounter([Species.KYUREM], GameModes.CLASSIC); + await game.runToFinalBossEncounter([ Species.KYUREM ], GameModes.CLASSIC); await game.phaseInterceptor.to("CommandPhase"); // Eternatus phase 1 @@ -101,7 +101,7 @@ describe("Final Boss", () => { it("should change form on status damage down to last boss fragment", async () => { game.override.ability(Abilities.NO_GUARD); - await game.runToFinalBossEncounter([Species.BIDOOF], GameModes.CLASSIC); + await game.runToFinalBossEncounter([ Species.BIDOOF ], GameModes.CLASSIC); await game.phaseInterceptor.to("CommandPhase"); // Eternatus phase 1 diff --git a/src/test/game-mode.test.ts b/src/test/game-mode.test.ts index ccec3a3aa16..11994a102af 100644 --- a/src/test/game-mode.test.ts +++ b/src/test/game-mode.test.ts @@ -2,6 +2,7 @@ import { GameMode, GameModes, getGameMode } from "#app/game-mode"; import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; import * as Utils from "../utils"; import GameManager from "./utils/gameManager"; + describe("game-mode", () => { let phaserGame: Phaser.Game; let game: GameManager; @@ -12,6 +13,7 @@ describe("game-mode", () => { }); afterEach(() => { game.phaseInterceptor.restoreOg(); + vi.clearAllMocks(); vi.resetAllMocks(); }); beforeEach(() => { diff --git a/src/test/internals.test.ts b/src/test/internals.test.ts index 3c76b40e901..ce2cd55dbc6 100644 --- a/src/test/internals.test.ts +++ b/src/test/internals.test.ts @@ -23,7 +23,7 @@ describe("Internals", () => { }); it("should provide Eevee with 3 defined abilities", async () => { - await game.classicMode.runToSummon([Species.EEVEE]); + await game.classicMode.runToSummon([ Species.EEVEE ]); const eevee = game.scene.getPlayerPokemon()!; expect(eevee.getSpeciesForm().getAbilityCount()).toBe(3); @@ -34,7 +34,7 @@ describe("Internals", () => { }); it("should set Eeeve abilityIndex between 0-2", async () => { - await game.classicMode.runToSummon([Species.EEVEE]); + await game.classicMode.runToSummon([ Species.EEVEE ]); const eevee = game.scene.getPlayerPokemon()!; expect(eevee.abilityIndex).toBeGreaterThanOrEqual(0); diff --git a/src/test/items/double_battle_chance_booster.test.ts b/src/test/items/double_battle_chance_booster.test.ts index 1d5051fa9e9..8d2bd7c9179 100644 --- a/src/test/items/double_battle_chance_booster.test.ts +++ b/src/test/items/double_battle_chance_booster.test.ts @@ -12,8 +12,6 @@ import { Button } from "#app/enums/buttons"; describe("Items - Double Battle Chance Boosters", () => { let phaserGame: Phaser.Game; let game: GameManager; - const TIMEOUT = 20 * 1000; - beforeAll(() => { phaserGame = new Phaser.Game({ type: Phaser.HEADLESS, @@ -39,7 +37,7 @@ describe("Items - Double Battle Chance Boosters", () => { await game.classicMode.startBattle(); expect(game.scene.getEnemyField().length).toBe(2); - }, TIMEOUT); + }); it("should guarantee double boss battle with 3 unique tiers", async () => { game.override @@ -57,7 +55,7 @@ describe("Items - Double Battle Chance Boosters", () => { expect(enemyField.length).toBe(2); expect(enemyField[0].isBoss()).toBe(true); expect(enemyField[1].isBoss()).toBe(true); - }, TIMEOUT); + }); it("should renew how many battles are left of existing booster when picking up new booster of same tier", async() => { game.override @@ -100,5 +98,5 @@ describe("Items - Double Battle Chance Boosters", () => { } } expect(count).toBe(1); - }, TIMEOUT); + }); }); diff --git a/src/test/items/eviolite.test.ts b/src/test/items/eviolite.test.ts index d9991d47a89..a97c287da29 100644 --- a/src/test/items/eviolite.test.ts +++ b/src/test/items/eviolite.test.ts @@ -1,16 +1,14 @@ -import { Stat } from "#enums/stat"; +import { StatBoosterModifier } from "#app/modifier/modifier"; +import { NumberHolder, randItem } from "#app/utils"; import { Species } from "#enums/species"; +import { Stat } from "#enums/stat"; import GameManager from "#test/utils/gameManager"; import Phase from "phaser"; -import * as Utils from "#app/utils"; import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; -import { StatBoosterModifier } from "#app/modifier/modifier"; describe("Items - Eviolite", () => { let phaserGame: Phaser.Game; let game: GameManager; - const TIMEOUT = 20 * 1000; - beforeAll(() => { phaserGame = new Phase.Game({ type: Phaser.HEADLESS, @@ -30,14 +28,12 @@ describe("Items - Eviolite", () => { }); it("should provide 50% boost to DEF and SPDEF for unevolved, unfused pokemon", async() => { - await game.classicMode.startBattle([ - Species.PICHU - ]); + await game.classicMode.startBattle([ Species.PICHU ]); const partyMember = game.scene.getPlayerPokemon()!; vi.spyOn(partyMember, "getEffectiveStat").mockImplementation((stat, _opponent?, _move?, _isCritical?) => { - const statValue = new Utils.NumberHolder(partyMember.getStat(stat, false)); + const statValue = new NumberHolder(partyMember.getStat(stat, false)); game.scene.applyModifiers(StatBoosterModifier, partyMember.isPlayer(), partyMember, stat, statValue); // Ignore other calculations for simplicity @@ -50,17 +46,15 @@ describe("Items - Eviolite", () => { expect(partyMember.getEffectiveStat(Stat.DEF)).toBe(Math.floor(defStat * 1.5)); expect(partyMember.getEffectiveStat(Stat.SPDEF)).toBe(Math.floor(spDefStat * 1.5)); - }, TIMEOUT); + }); it("should not provide a boost for fully evolved, unfused pokemon", async() => { - await game.classicMode.startBattle([ - Species.RAICHU, - ]); + await game.classicMode.startBattle([ Species.RAICHU ]); - const partyMember = game.scene.getParty()[0]; + const partyMember = game.scene.getPlayerPokemon()!; vi.spyOn(partyMember, "getEffectiveStat").mockImplementation((stat, _opponent?, _move?, _isCritical?) => { - const statValue = new Utils.NumberHolder(partyMember.getStat(stat, false)); + const statValue = new NumberHolder(partyMember.getStat(stat, false)); game.scene.applyModifiers(StatBoosterModifier, partyMember.isPlayer(), partyMember, stat, statValue); // Ignore other calculations for simplicity @@ -74,15 +68,12 @@ describe("Items - Eviolite", () => { expect(partyMember.getEffectiveStat(Stat.DEF)).toBe(defStat); expect(partyMember.getEffectiveStat(Stat.SPDEF)).toBe(spDefStat); - }, TIMEOUT); + }); it("should provide 50% boost to DEF and SPDEF for completely unevolved, fused pokemon", async() => { - await game.classicMode.startBattle([ - Species.PICHU, - Species.CLEFFA - ]); + await game.classicMode.startBattle([ Species.PICHU, Species.CLEFFA ]); - const [ partyMember, ally ] = game.scene.getParty(); + const [ partyMember, ally ] = game.scene.getPlayerParty(); // Fuse party members (taken from PlayerPokemon.fuse(...) function) partyMember.fusionSpecies = ally.species; @@ -94,7 +85,7 @@ describe("Items - Eviolite", () => { partyMember.fusionLuck = ally.luck; vi.spyOn(partyMember, "getEffectiveStat").mockImplementation((stat, _opponent?, _move?, _isCritical?) => { - const statValue = new Utils.NumberHolder(partyMember.getStat(stat, false)); + const statValue = new NumberHolder(partyMember.getStat(stat, false)); game.scene.applyModifiers(StatBoosterModifier, partyMember.isPlayer(), partyMember, stat, statValue); // Ignore other calculations for simplicity @@ -107,15 +98,12 @@ describe("Items - Eviolite", () => { expect(partyMember.getEffectiveStat(Stat.DEF)).toBe(Math.floor(defStat * 1.5)); expect(partyMember.getEffectiveStat(Stat.SPDEF)).toBe(Math.floor(spDefStat * 1.5)); - }, TIMEOUT); + }); it("should provide 25% boost to DEF and SPDEF for partially unevolved (base), fused pokemon", async() => { - await game.classicMode.startBattle([ - Species.PICHU, - Species.CLEFABLE - ]); + await game.classicMode.startBattle([ Species.PICHU, Species.CLEFABLE ]); - const [ partyMember, ally ] = game.scene.getParty(); + const [ partyMember, ally ] = game.scene.getPlayerParty(); // Fuse party members (taken from PlayerPokemon.fuse(...) function) partyMember.fusionSpecies = ally.species; @@ -127,7 +115,7 @@ describe("Items - Eviolite", () => { partyMember.fusionLuck = ally.luck; vi.spyOn(partyMember, "getEffectiveStat").mockImplementation((stat, _opponent?, _move?, _isCritical?) => { - const statValue = new Utils.NumberHolder(partyMember.getStat(stat, false)); + const statValue = new NumberHolder(partyMember.getStat(stat, false)); game.scene.applyModifiers(StatBoosterModifier, partyMember.isPlayer(), partyMember, stat, statValue); // Ignore other calculations for simplicity @@ -140,15 +128,12 @@ describe("Items - Eviolite", () => { expect(partyMember.getEffectiveStat(Stat.DEF)).toBe(Math.floor(defStat * 1.25)); expect(partyMember.getEffectiveStat(Stat.SPDEF)).toBe(Math.floor(spDefStat * 1.25)); - }, TIMEOUT); + }); it("should provide 25% boost to DEF and SPDEF for partially unevolved (fusion), fused pokemon", async() => { - await game.classicMode.startBattle([ - Species.RAICHU, - Species.CLEFFA - ]); + await game.classicMode.startBattle([ Species.RAICHU, Species.CLEFFA ]); - const [ partyMember, ally ] = game.scene.getParty(); + const [ partyMember, ally ] = game.scene.getPlayerParty(); // Fuse party members (taken from PlayerPokemon.fuse(...) function) partyMember.fusionSpecies = ally.species; @@ -160,7 +145,7 @@ describe("Items - Eviolite", () => { partyMember.fusionLuck = ally.luck; vi.spyOn(partyMember, "getEffectiveStat").mockImplementation((stat, _opponent?, _move?, _isCritical?) => { - const statValue = new Utils.NumberHolder(partyMember.getStat(stat, false)); + const statValue = new NumberHolder(partyMember.getStat(stat, false)); game.scene.applyModifiers(StatBoosterModifier, partyMember.isPlayer(), partyMember, stat, statValue); // Ignore other calculations for simplicity @@ -173,15 +158,12 @@ describe("Items - Eviolite", () => { expect(partyMember.getEffectiveStat(Stat.DEF)).toBe(Math.floor(defStat * 1.25)); expect(partyMember.getEffectiveStat(Stat.SPDEF)).toBe(Math.floor(spDefStat * 1.25)); - }, TIMEOUT); + }); it("should not provide a boost for fully evolved, fused pokemon", async() => { - await game.classicMode.startBattle([ - Species.RAICHU, - Species.CLEFABLE - ]); + await game.classicMode.startBattle([ Species.RAICHU, Species.CLEFABLE ]); - const [ partyMember, ally ] = game.scene.getParty(); + const [ partyMember, ally ] = game.scene.getPlayerParty(); // Fuse party members (taken from PlayerPokemon.fuse(...) function) partyMember.fusionSpecies = ally.species; @@ -193,7 +175,7 @@ describe("Items - Eviolite", () => { partyMember.fusionLuck = ally.luck; vi.spyOn(partyMember, "getEffectiveStat").mockImplementation((stat, _opponent?, _move?, _isCritical?) => { - const statValue = new Utils.NumberHolder(partyMember.getStat(stat, false)); + const statValue = new NumberHolder(partyMember.getStat(stat, false)); game.scene.applyModifiers(StatBoosterModifier, partyMember.isPlayer(), partyMember, stat, statValue); // Ignore other calculations for simplicity @@ -206,7 +188,7 @@ describe("Items - Eviolite", () => { expect(partyMember.getEffectiveStat(Stat.DEF)).toBe(defStat); expect(partyMember.getEffectiveStat(Stat.SPDEF)).toBe(spDefStat); - }, TIMEOUT); + }); it("should not provide a boost for Gigantamax Pokémon", async() => { game.override.starterForms({ @@ -218,14 +200,12 @@ describe("Items - Eviolite", () => { const gMaxablePokemon = [ Species.PIKACHU, Species.EEVEE, Species.DURALUDON, Species.MEOWTH ]; - await game.classicMode.startBattle([ - Utils.randItem(gMaxablePokemon) - ]); + await game.classicMode.startBattle([ randItem(gMaxablePokemon) ]); const partyMember = game.scene.getPlayerPokemon()!; vi.spyOn(partyMember, "getEffectiveStat").mockImplementation((stat, _opponent?, _move?, _isCritical?) => { - const statValue = new Utils.NumberHolder(partyMember.getStat(stat, false)); + const statValue = new NumberHolder(partyMember.getStat(stat, false)); game.scene.applyModifiers(StatBoosterModifier, partyMember.isPlayer(), partyMember, stat, statValue); // Ignore other calculations for simplicity @@ -238,5 +218,5 @@ describe("Items - Eviolite", () => { expect(partyMember.getEffectiveStat(Stat.DEF)).toBe(defStat); expect(partyMember.getEffectiveStat(Stat.SPDEF)).toBe(spDefStat); - }, TIMEOUT); + }); }); diff --git a/src/test/items/exp_booster.test.ts b/src/test/items/exp_booster.test.ts index 9a7464e4866..36107329706 100644 --- a/src/test/items/exp_booster.test.ts +++ b/src/test/items/exp_booster.test.ts @@ -28,7 +28,7 @@ describe("EXP Modifier Items", () => { }); it("EXP booster items stack multiplicatively", async() => { - game.override.startingHeldItems([{name: "LUCKY_EGG", count: 3}, {name: "GOLDEN_EGG"}]); + game.override.startingHeldItems([{ name: "LUCKY_EGG", count: 3 }, { name: "GOLDEN_EGG" }]); await game.startBattle(); const partyMember = game.scene.getPlayerPokemon()!; diff --git a/src/test/items/grip_claw.test.ts b/src/test/items/grip_claw.test.ts index d9871616449..2909549af87 100644 --- a/src/test/items/grip_claw.test.ts +++ b/src/test/items/grip_claw.test.ts @@ -1,16 +1,14 @@ import { BattlerIndex } from "#app/battle"; -import { allMoves } from "#app/data/move"; -import { Abilities } from "#app/enums/abilities"; -import { BerryType } from "#app/enums/berry-type"; -import { Moves } from "#app/enums/moves"; -import { Species } from "#app/enums/species"; -import { MoveEndPhase } from "#app/phases/move-end-phase"; +import Pokemon from "#app/field/pokemon"; +import { ContactHeldItemTransferChanceModifier } from "#app/modifier/modifier"; +import { Abilities } from "#enums/abilities"; +import { BerryType } from "#enums/berry-type"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; import GameManager from "#test/utils/gameManager"; import Phase from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; -const TIMEOUT = 20 * 1000; // 20 seconds - describe("Items - Grip Claw", () => { let phaserGame: Phaser.Game; let game: GameManager; @@ -30,39 +28,85 @@ describe("Items - Grip Claw", () => { game.override .battleType("double") - .moveset([Moves.POPULATION_BOMB, Moves.SPLASH]) + .moveset([ Moves.TACKLE, Moves.SPLASH, Moves.ATTRACT ]) .startingHeldItems([ - { name: "GRIP_CLAW", count: 5 }, // TODO: Find a way to mock the steal chance of grip claw - { name: "MULTI_LENS", count: 3 }, + { name: "GRIP_CLAW", count: 1 }, ]) .enemySpecies(Species.SNORLAX) - .ability(Abilities.KLUTZ) + .enemyAbility(Abilities.UNNERVE) + .ability(Abilities.UNNERVE) .enemyMoveset(Moves.SPLASH) .enemyHeldItems([ { name: "BERRY", type: BerryType.SITRUS, count: 2 }, { name: "BERRY", type: BerryType.LUM, count: 2 }, ]) - .startingLevel(100) .enemyLevel(100); - vi.spyOn(allMoves[Moves.POPULATION_BOMB], "accuracy", "get").mockReturnValue(100); }); - it( - "should only steal items from the attack target", - async () => { - await game.startBattle([Species.PANSEAR, Species.ROWLET]); + it("should steal items on contact and only from the attack target", async () => { + await game.classicMode.startBattle([ Species.FEEBAS, Species.MILOTIC ]); - const enemyPokemon = game.scene.getEnemyField(); + const [ playerPokemon, ] = game.scene.getPlayerField(); - const enemyHeldItemCt = enemyPokemon.map(p => p.getHeldItems.length); + const gripClaw = playerPokemon.getHeldItems()[0] as ContactHeldItemTransferChanceModifier; + vi.spyOn(gripClaw, "chance", "get").mockReturnValue(100); - game.move.select(Moves.POPULATION_BOMB, 0, BattlerIndex.ENEMY); - game.move.select(Moves.SPLASH, 1); + const enemyPokemon = game.scene.getEnemyField(); - await game.phaseInterceptor.to(MoveEndPhase, false); + const playerHeldItemCount = getHeldItemCount(playerPokemon); + const enemy1HeldItemCount = getHeldItemCount(enemyPokemon[0]); + const enemy2HeldItemCount = getHeldItemCount(enemyPokemon[1]); + expect(enemy2HeldItemCount).toBeGreaterThan(0); - expect(enemyPokemon[1].getHeldItems.length).toBe(enemyHeldItemCt[1]); - }, TIMEOUT - ); + game.move.select(Moves.TACKLE, 0, BattlerIndex.ENEMY_2); + game.move.select(Moves.SPLASH, 1); + + await game.phaseInterceptor.to("BerryPhase", false); + + const playerHeldItemCountAfter = getHeldItemCount(playerPokemon); + const enemy1HeldItemCountsAfter = getHeldItemCount(enemyPokemon[0]); + const enemy2HeldItemCountsAfter = getHeldItemCount(enemyPokemon[1]); + + expect(playerHeldItemCountAfter).toBe(playerHeldItemCount + 1); + expect(enemy1HeldItemCountsAfter).toBe(enemy1HeldItemCount); + expect(enemy2HeldItemCountsAfter).toBe(enemy2HeldItemCount - 1); + }); + + it("should not steal items when using a targetted, non attack move", async () => { + await game.classicMode.startBattle([ Species.FEEBAS, Species.MILOTIC ]); + + const [ playerPokemon, ] = game.scene.getPlayerField(); + + const gripClaw = playerPokemon.getHeldItems()[0] as ContactHeldItemTransferChanceModifier; + vi.spyOn(gripClaw, "chance", "get").mockReturnValue(100); + + const enemyPokemon = game.scene.getEnemyField(); + + const playerHeldItemCount = getHeldItemCount(playerPokemon); + const enemy1HeldItemCount = getHeldItemCount(enemyPokemon[0]); + const enemy2HeldItemCount = getHeldItemCount(enemyPokemon[1]); + expect(enemy2HeldItemCount).toBeGreaterThan(0); + + game.move.select(Moves.ATTRACT, 0, BattlerIndex.ENEMY_2); + game.move.select(Moves.SPLASH, 1); + + await game.phaseInterceptor.to("BerryPhase", false); + + const playerHeldItemCountAfter = getHeldItemCount(playerPokemon); + const enemy1HeldItemCountsAfter = getHeldItemCount(enemyPokemon[0]); + const enemy2HeldItemCountsAfter = getHeldItemCount(enemyPokemon[1]); + + expect(playerHeldItemCountAfter).toBe(playerHeldItemCount); + expect(enemy1HeldItemCountsAfter).toBe(enemy1HeldItemCount); + expect(enemy2HeldItemCountsAfter).toBe(enemy2HeldItemCount); + }); }); + +/* + * Gets the total number of items a Pokemon holds + */ +function getHeldItemCount(pokemon: Pokemon) { + return pokemon.getHeldItems().reduce((currentTotal, item) => currentTotal + item.getStackCount(), 0); +} + diff --git a/src/test/items/leek.test.ts b/src/test/items/leek.test.ts index af20516ef83..901b353b3d3 100644 --- a/src/test/items/leek.test.ts +++ b/src/test/items/leek.test.ts @@ -25,7 +25,7 @@ describe("Items - Leek", () => { game.override .enemySpecies(Species.MAGIKARP) - .enemyMoveset([Moves.SPLASH, Moves.SPLASH, Moves.SPLASH, Moves.SPLASH]) + .enemyMoveset([ Moves.SPLASH, Moves.SPLASH, Moves.SPLASH, Moves.SPLASH ]) .startingHeldItems([{ name: "LEEK" }]) .moveset([ Moves.TACKLE ]) .disableCrits() @@ -82,14 +82,14 @@ describe("Items - Leek", () => { it("should raise CRIT stage by 2 when held by FARFETCHD line fused with Pokemon", async () => { // Randomly choose from the Farfetch'd line - const species = [Species.FARFETCHD, Species.GALAR_FARFETCHD, Species.SIRFETCHD]; + const species = [ Species.FARFETCHD, Species.GALAR_FARFETCHD, Species.SIRFETCHD ]; await game.startBattle([ species[Utils.randInt(species.length)], Species.PIKACHU, ]); - const [ partyMember, ally ] = game.scene.getParty(); + const [ partyMember, ally ] = game.scene.getPlayerParty(); // Fuse party members (taken from PlayerPokemon.fuse(...) function) partyMember.fusionSpecies = ally.species; @@ -113,14 +113,14 @@ describe("Items - Leek", () => { it("should raise CRIT stage by 2 when held by Pokemon fused with FARFETCHD line", async () => { // Randomly choose from the Farfetch'd line - const species = [Species.FARFETCHD, Species.GALAR_FARFETCHD, Species.SIRFETCHD]; + const species = [ Species.FARFETCHD, Species.GALAR_FARFETCHD, Species.SIRFETCHD ]; await game.startBattle([ Species.PIKACHU, species[Utils.randInt(species.length)] ]); - const [ partyMember, ally ] = game.scene.getParty(); + const [ partyMember, ally ] = game.scene.getPlayerParty(); // Fuse party members (taken from PlayerPokemon.fuse(...) function) partyMember.fusionSpecies = ally.species; diff --git a/src/test/items/leftovers.test.ts b/src/test/items/leftovers.test.ts index 8e548542436..cfbf7c2f734 100644 --- a/src/test/items/leftovers.test.ts +++ b/src/test/items/leftovers.test.ts @@ -27,15 +27,15 @@ describe("Items - Leftovers", () => { game.override.battleType("single"); game.override.startingLevel(2000); game.override.ability(Abilities.UNNERVE); - game.override.moveset([Moves.SPLASH]); + game.override.moveset([ Moves.SPLASH ]); game.override.enemySpecies(Species.SHUCKLE); game.override.enemyAbility(Abilities.UNNERVE); - game.override.enemyMoveset([Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE]); + game.override.enemyMoveset([ Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE ]); game.override.startingHeldItems([{ name: "LEFTOVERS", count: 1 }]); }); it("leftovers works", async () => { - await game.startBattle([Species.ARCANINE]); + await game.startBattle([ Species.ARCANINE ]); // Make sure leftovers are there expect(game.scene.modifiers[0].type.id).toBe("LEFTOVERS"); diff --git a/src/test/items/light_ball.test.ts b/src/test/items/light_ball.test.ts index 673348e7b7a..fe79b6a2045 100644 --- a/src/test/items/light_ball.test.ts +++ b/src/test/items/light_ball.test.ts @@ -35,7 +35,7 @@ describe("Items - Light Ball", () => { Species.PIKACHU ]); - const partyMember = game.scene.getParty()[0]; + const partyMember = game.scene.getPlayerParty()[0]; // Checking console log to make sure Light Ball is applied when getEffectiveStat (with the appropriate stat) is called partyMember.getEffectiveStat(Stat.DEF); @@ -68,7 +68,7 @@ describe("Items - Light Ball", () => { Species.PIKACHU ]); - const partyMember = game.scene.getParty()[0]; + const partyMember = game.scene.getPlayerParty()[0]; const atkStat = partyMember.getStat(Stat.ATK); const spAtkStat = partyMember.getStat(Stat.SPATK); @@ -83,7 +83,7 @@ describe("Items - Light Ball", () => { expect(spAtkValue.value / spAtkStat).toBe(1); // Giving Eviolite to party member and testing if it applies - partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], ["LIGHT_BALL"])!.newModifier(partyMember), true); + partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], [ "LIGHT_BALL" ])!.newModifier(partyMember), true); partyMember.scene.applyModifiers(SpeciesStatBoosterModifier, true, partyMember, Stat.ATK, atkValue); partyMember.scene.applyModifiers(SpeciesStatBoosterModifier, true, partyMember, Stat.SPATK, spAtkValue); @@ -97,8 +97,8 @@ describe("Items - Light Ball", () => { Species.MAROWAK ]); - const partyMember = game.scene.getParty()[0]; - const ally = game.scene.getParty()[1]; + const partyMember = game.scene.getPlayerParty()[0]; + const ally = game.scene.getPlayerParty()[1]; // Fuse party members (taken from PlayerPokemon.fuse(...) function) partyMember.fusionSpecies = ally.species; @@ -122,7 +122,7 @@ describe("Items - Light Ball", () => { expect(spAtkValue.value / spAtkStat).toBe(1); // Giving Eviolite to party member and testing if it applies - partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], ["LIGHT_BALL"])!.newModifier(partyMember), true); + partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], [ "LIGHT_BALL" ])!.newModifier(partyMember), true); partyMember.scene.applyModifiers(SpeciesStatBoosterModifier, true, partyMember, Stat.ATK, atkValue); partyMember.scene.applyModifiers(SpeciesStatBoosterModifier, true, partyMember, Stat.SPATK, spAtkValue); @@ -136,8 +136,8 @@ describe("Items - Light Ball", () => { Species.PIKACHU ]); - const partyMember = game.scene.getParty()[0]; - const ally = game.scene.getParty()[1]; + const partyMember = game.scene.getPlayerParty()[0]; + const ally = game.scene.getPlayerParty()[1]; // Fuse party members (taken from PlayerPokemon.fuse(...) function) partyMember.fusionSpecies = ally.species; @@ -161,7 +161,7 @@ describe("Items - Light Ball", () => { expect(spAtkValue.value / spAtkStat).toBe(1); // Giving Eviolite to party member and testing if it applies - partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], ["LIGHT_BALL"])!.newModifier(partyMember), true); + partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], [ "LIGHT_BALL" ])!.newModifier(partyMember), true); partyMember.scene.applyModifiers(SpeciesStatBoosterModifier, true, partyMember, Stat.ATK, atkValue); partyMember.scene.applyModifiers(SpeciesStatBoosterModifier, true, partyMember, Stat.SPATK, spAtkValue); @@ -174,7 +174,7 @@ describe("Items - Light Ball", () => { Species.MAROWAK ]); - const partyMember = game.scene.getParty()[0]; + const partyMember = game.scene.getPlayerParty()[0]; const atkStat = partyMember.getStat(Stat.ATK); const spAtkStat = partyMember.getStat(Stat.SPATK); @@ -189,7 +189,7 @@ describe("Items - Light Ball", () => { expect(spAtkValue.value / spAtkStat).toBe(1); // Giving Eviolite to party member and testing if it applies - partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], ["LIGHT_BALL"])!.newModifier(partyMember), true); + partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], [ "LIGHT_BALL" ])!.newModifier(partyMember), true); partyMember.scene.applyModifiers(SpeciesStatBoosterModifier, true, partyMember, Stat.ATK, atkValue); partyMember.scene.applyModifiers(SpeciesStatBoosterModifier, true, partyMember, Stat.SPATK, spAtkValue); diff --git a/src/test/items/lock_capsule.test.ts b/src/test/items/lock_capsule.test.ts index bc4ca1cb014..0b6534b5eaf 100644 --- a/src/test/items/lock_capsule.test.ts +++ b/src/test/items/lock_capsule.test.ts @@ -1,7 +1,8 @@ import { Abilities } from "#app/enums/abilities"; import { Moves } from "#app/enums/moves"; -import { ModifierTypeOption, modifierTypes } from "#app/modifier/modifier-type"; +import { ModifierTier } from "#app/modifier/modifier-tier"; import { SelectModifierPhase } from "#app/phases/select-modifier-phase"; +import { Mode } from "#app/ui/ui"; import GameManager from "#test/utils/gameManager"; import Phase from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; @@ -26,21 +27,22 @@ describe("Items - Lock Capsule", () => { game.override .battleType("single") .startingLevel(200) - .moveset([Moves.SURF]) + .moveset([ Moves.SURF ]) .enemyAbility(Abilities.BALL_FETCH) .startingModifier([{ name: "LOCK_CAPSULE" }]); }); it("doesn't set the cost of common tier items to 0", async () => { - await game.startBattle(); + await game.classicMode.startBattle(); + game.scene.overridePhase(new SelectModifierPhase(game.scene, 0, undefined, { guaranteedModifierTiers: [ ModifierTier.COMMON, ModifierTier.COMMON, ModifierTier.COMMON ], fillRemaining: false })); - game.move.select(Moves.SURF); - await game.phaseInterceptor.to(SelectModifierPhase, false); + game.onNextPrompt("SelectModifierPhase", Mode.MODIFIER_SELECT, () => { + const selectModifierPhase = game.scene.getCurrentPhase() as SelectModifierPhase; + const rerollCost = selectModifierPhase.getRerollCost(true); + expect(rerollCost).toBe(150); + }); - const rewards = game.scene.getCurrentPhase() as SelectModifierPhase; - const potion = new ModifierTypeOption(modifierTypes.POTION(), 0, 40); // Common tier item - const rerollCost = rewards.getRerollCost([potion, potion, potion], true); - - expect(rerollCost).toBe(150); + game.doSelectModifier(); + await game.phaseInterceptor.to("SelectModifierPhase"); }, 20000); }); diff --git a/src/test/items/metal_powder.test.ts b/src/test/items/metal_powder.test.ts index 0206fd1f471..86e7d329ecb 100644 --- a/src/test/items/metal_powder.test.ts +++ b/src/test/items/metal_powder.test.ts @@ -35,7 +35,7 @@ describe("Items - Metal Powder", () => { Species.DITTO ]); - const partyMember = game.scene.getParty()[0]; + const partyMember = game.scene.getPlayerParty()[0]; // Checking console log to make sure Metal Powder is applied when getEffectiveStat (with the appropriate stat) is called partyMember.getEffectiveStat(Stat.DEF); @@ -68,7 +68,7 @@ describe("Items - Metal Powder", () => { Species.DITTO ]); - const partyMember = game.scene.getParty()[0]; + const partyMember = game.scene.getPlayerParty()[0]; const defStat = partyMember.getStat(Stat.DEF); @@ -79,7 +79,7 @@ describe("Items - Metal Powder", () => { expect(defValue.value / defStat).toBe(1); // Giving Eviolite to party member and testing if it applies - partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], ["METAL_POWDER"])!.newModifier(partyMember), true); + partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], [ "METAL_POWDER" ])!.newModifier(partyMember), true); partyMember.scene.applyModifiers(SpeciesStatBoosterModifier, true, partyMember, Stat.DEF, defValue); expect(defValue.value / defStat).toBe(2); @@ -91,8 +91,8 @@ describe("Items - Metal Powder", () => { Species.MAROWAK ]); - const partyMember = game.scene.getParty()[0]; - const ally = game.scene.getParty()[1]; + const partyMember = game.scene.getPlayerParty()[0]; + const ally = game.scene.getPlayerParty()[1]; // Fuse party members (taken from PlayerPokemon.fuse(...) function) partyMember.fusionSpecies = ally.species; @@ -112,7 +112,7 @@ describe("Items - Metal Powder", () => { expect(defValue.value / defStat).toBe(1); // Giving Eviolite to party member and testing if it applies - partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], ["METAL_POWDER"])!.newModifier(partyMember), true); + partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], [ "METAL_POWDER" ])!.newModifier(partyMember), true); partyMember.scene.applyModifiers(SpeciesStatBoosterModifier, true, partyMember, Stat.DEF, defValue); expect(defValue.value / defStat).toBe(2); @@ -124,8 +124,8 @@ describe("Items - Metal Powder", () => { Species.DITTO ]); - const partyMember = game.scene.getParty()[0]; - const ally = game.scene.getParty()[1]; + const partyMember = game.scene.getPlayerParty()[0]; + const ally = game.scene.getPlayerParty()[1]; // Fuse party members (taken from PlayerPokemon.fuse(...) function) partyMember.fusionSpecies = ally.species; @@ -145,7 +145,7 @@ describe("Items - Metal Powder", () => { expect(defValue.value / defStat).toBe(1); // Giving Eviolite to party member and testing if it applies - partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], ["METAL_POWDER"])!.newModifier(partyMember), true); + partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], [ "METAL_POWDER" ])!.newModifier(partyMember), true); partyMember.scene.applyModifiers(SpeciesStatBoosterModifier, true, partyMember, Stat.DEF, defValue); expect(defValue.value / defStat).toBe(2); @@ -156,7 +156,7 @@ describe("Items - Metal Powder", () => { Species.MAROWAK ]); - const partyMember = game.scene.getParty()[0]; + const partyMember = game.scene.getPlayerParty()[0]; const defStat = partyMember.getStat(Stat.DEF); @@ -167,7 +167,7 @@ describe("Items - Metal Powder", () => { expect(defValue.value / defStat).toBe(1); // Giving Eviolite to party member and testing if it applies - partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], ["METAL_POWDER"])!.newModifier(partyMember), true); + partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], [ "METAL_POWDER" ])!.newModifier(partyMember), true); partyMember.scene.applyModifiers(SpeciesStatBoosterModifier, true, partyMember, Stat.DEF, defValue); expect(defValue.value / defStat).toBe(1); diff --git a/src/test/items/multi_lens.test.ts b/src/test/items/multi_lens.test.ts new file mode 100644 index 00000000000..c5e60c9f9e5 --- /dev/null +++ b/src/test/items/multi_lens.test.ts @@ -0,0 +1,138 @@ +import { BattlerIndex } from "#app/battle"; +import { Stat } from "#enums/stat"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; + +describe("Items - Multi Lens", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.TACKLE, Moves.TRAILBLAZE, Moves.TACHYON_CUTTER ]) + .ability(Abilities.BALL_FETCH) + .startingHeldItems([{ name: "MULTI_LENS" }]) + .battleType("single") + .disableCrits() + .enemySpecies(Species.SNORLAX) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.SPLASH) + .startingLevel(99) // Check for proper rounding on Seismic Toss damage reduction + .enemyLevel(99); + }); + + it.each([ + { stackCount: 1, firstHitDamage: 0.75 }, + { stackCount: 2, firstHitDamage: 0.50 } + ])("$stackCount count: should deal {$firstHitDamage}x damage on the first hit, then hit $stackCount times for 0.25x", + async ({ stackCount, firstHitDamage }) => { + game.override.startingHeldItems([{ name: "MULTI_LENS", count: stackCount }]); + + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const enemyPokemon = game.scene.getEnemyPokemon()!; + const spy = vi.spyOn(enemyPokemon, "getAttackDamage"); + vi.spyOn(enemyPokemon, "getBaseDamage").mockReturnValue(100); + + game.move.select(Moves.TACKLE); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + + await game.phaseInterceptor.to("MoveEndPhase"); + const damageResults = spy.mock.results.map(result => result.value?.damage); + + expect(damageResults).toHaveLength(1 + stackCount); + expect(damageResults[0]).toBe(firstHitDamage * 100); + damageResults.slice(1).forEach(dmg => expect(dmg).toBe(25)); + }); + + it("should stack additively with Parental Bond", async () => { + game.override.ability(Abilities.PARENTAL_BOND); + + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + + game.move.select(Moves.TACKLE); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + + await game.phaseInterceptor.to("MoveEndPhase"); + expect(playerPokemon.turnData.hitCount).toBe(3); + }); + + it("should apply secondary effects on each hit", async () => { + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + + game.move.select(Moves.TRAILBLAZE); + + await game.phaseInterceptor.to("BerryPhase", false); + expect(playerPokemon.getStatStage(Stat.SPD)).toBe(2); + }); + + it("should not enhance multi-hit moves", async () => { + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + + game.move.select(Moves.TACHYON_CUTTER); + + await game.phaseInterceptor.to("BerryPhase", false); + expect(playerPokemon.turnData.hitCount).toBe(2); + }); + + it("should enhance multi-target moves", async () => { + game.override + .battleType("double") + .moveset([ Moves.SWIFT, Moves.SPLASH ]); + + await game.classicMode.startBattle([ Species.MAGIKARP, Species.FEEBAS ]); + + const [ magikarp, ] = game.scene.getPlayerField(); + + game.move.select(Moves.SWIFT, 0); + game.move.select(Moves.SPLASH, 1); + + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2 ]); + + await game.phaseInterceptor.to("MoveEndPhase"); + + expect(magikarp.turnData.hitCount).toBe(2); + }); + + it("should enhance fixed-damage moves while also applying damage reduction", async () => { + game.override.startingHeldItems([{ name: "MULTI_LENS", count: 1 }]) + .moveset(Moves.SEISMIC_TOSS); + + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const enemyPokemon = game.scene.getEnemyPokemon()!; + const spy = vi.spyOn(enemyPokemon, "getAttackDamage"); + + game.move.select(Moves.SEISMIC_TOSS); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + + await game.phaseInterceptor.to("MoveEndPhase"); + const damageResults = spy.mock.results.map(result => result.value?.damage); + + expect(damageResults).toHaveLength(2); + expect(damageResults[0]).toBe(Math.floor(playerPokemon.level * 0.75)); + expect(damageResults[1]).toBe(Math.floor(playerPokemon.level * 0.25)); + }); +}); diff --git a/src/test/items/quick_powder.test.ts b/src/test/items/quick_powder.test.ts index 344b772feb4..905d023ad8b 100644 --- a/src/test/items/quick_powder.test.ts +++ b/src/test/items/quick_powder.test.ts @@ -35,7 +35,7 @@ describe("Items - Quick Powder", () => { Species.DITTO ]); - const partyMember = game.scene.getParty()[0]; + const partyMember = game.scene.getPlayerParty()[0]; // Checking console log to make sure Quick Powder is applied when getEffectiveStat (with the appropriate stat) is called partyMember.getEffectiveStat(Stat.DEF); @@ -68,7 +68,7 @@ describe("Items - Quick Powder", () => { Species.DITTO ]); - const partyMember = game.scene.getParty()[0]; + const partyMember = game.scene.getPlayerParty()[0]; const spdStat = partyMember.getStat(Stat.SPD); @@ -79,7 +79,7 @@ describe("Items - Quick Powder", () => { expect(spdValue.value / spdStat).toBe(1); // Giving Eviolite to party member and testing if it applies - partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], ["QUICK_POWDER"])!.newModifier(partyMember), true); + partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], [ "QUICK_POWDER" ])!.newModifier(partyMember), true); partyMember.scene.applyModifiers(SpeciesStatBoosterModifier, true, partyMember, Stat.SPD, spdValue); expect(spdValue.value / spdStat).toBe(2); @@ -91,8 +91,8 @@ describe("Items - Quick Powder", () => { Species.MAROWAK ]); - const partyMember = game.scene.getParty()[0]; - const ally = game.scene.getParty()[1]; + const partyMember = game.scene.getPlayerParty()[0]; + const ally = game.scene.getPlayerParty()[1]; // Fuse party members (taken from PlayerPokemon.fuse(...) function) partyMember.fusionSpecies = ally.species; @@ -112,7 +112,7 @@ describe("Items - Quick Powder", () => { expect(spdValue.value / spdStat).toBe(1); // Giving Eviolite to party member and testing if it applies - partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], ["QUICK_POWDER"])!.newModifier(partyMember), true); + partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], [ "QUICK_POWDER" ])!.newModifier(partyMember), true); partyMember.scene.applyModifiers(SpeciesStatBoosterModifier, true, partyMember, Stat.SPD, spdValue); expect(spdValue.value / spdStat).toBe(2); @@ -124,8 +124,8 @@ describe("Items - Quick Powder", () => { Species.DITTO ]); - const partyMember = game.scene.getParty()[0]; - const ally = game.scene.getParty()[1]; + const partyMember = game.scene.getPlayerParty()[0]; + const ally = game.scene.getPlayerParty()[1]; // Fuse party members (taken from PlayerPokemon.fuse(...) function) partyMember.fusionSpecies = ally.species; @@ -145,7 +145,7 @@ describe("Items - Quick Powder", () => { expect(spdValue.value / spdStat).toBe(1); // Giving Eviolite to party member and testing if it applies - partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], ["QUICK_POWDER"])!.newModifier(partyMember), true); + partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], [ "QUICK_POWDER" ])!.newModifier(partyMember), true); partyMember.scene.applyModifiers(SpeciesStatBoosterModifier, true, partyMember, Stat.SPD, spdValue); expect(spdValue.value / spdStat).toBe(2); @@ -156,7 +156,7 @@ describe("Items - Quick Powder", () => { Species.MAROWAK ]); - const partyMember = game.scene.getParty()[0]; + const partyMember = game.scene.getPlayerParty()[0]; const spdStat = partyMember.getStat(Stat.SPD); @@ -167,7 +167,7 @@ describe("Items - Quick Powder", () => { expect(spdValue.value / spdStat).toBe(1); // Giving Eviolite to party member and testing if it applies - partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], ["QUICK_POWDER"])!.newModifier(partyMember), true); + partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], [ "QUICK_POWDER" ])!.newModifier(partyMember), true); partyMember.scene.applyModifiers(SpeciesStatBoosterModifier, true, partyMember, Stat.SPD, spdValue); expect(spdValue.value / spdStat).toBe(1); diff --git a/src/test/items/thick_club.test.ts b/src/test/items/thick_club.test.ts index bcb6b371264..d349a1ad7b9 100644 --- a/src/test/items/thick_club.test.ts +++ b/src/test/items/thick_club.test.ts @@ -35,7 +35,7 @@ describe("Items - Thick Club", () => { Species.CUBONE ]); - const partyMember = game.scene.getParty()[0]; + const partyMember = game.scene.getPlayerParty()[0]; // Checking console log to make sure Thick Club is applied when getEffectiveStat (with the appropriate stat) is called partyMember.getEffectiveStat(Stat.DEF); @@ -68,7 +68,7 @@ describe("Items - Thick Club", () => { Species.CUBONE ]); - const partyMember = game.scene.getParty()[0]; + const partyMember = game.scene.getPlayerParty()[0]; const atkStat = partyMember.getStat(Stat.ATK); @@ -79,7 +79,7 @@ describe("Items - Thick Club", () => { expect(atkValue.value / atkStat).toBe(1); // Giving Eviolite to party member and testing if it applies - partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], ["THICK_CLUB"])!.newModifier(partyMember), true); + partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], [ "THICK_CLUB" ])!.newModifier(partyMember), true); partyMember.scene.applyModifiers(SpeciesStatBoosterModifier, true, partyMember, Stat.ATK, atkValue); expect(atkValue.value / atkStat).toBe(2); @@ -90,7 +90,7 @@ describe("Items - Thick Club", () => { Species.MAROWAK ]); - const partyMember = game.scene.getParty()[0]; + const partyMember = game.scene.getPlayerParty()[0]; const atkStat = partyMember.getStat(Stat.ATK); @@ -101,7 +101,7 @@ describe("Items - Thick Club", () => { expect(atkValue.value / atkStat).toBe(1); // Giving Eviolite to party member and testing if it applies - partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], ["THICK_CLUB"])!.newModifier(partyMember), true); + partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], [ "THICK_CLUB" ])!.newModifier(partyMember), true); partyMember.scene.applyModifiers(SpeciesStatBoosterModifier, true, partyMember, Stat.ATK, atkValue); expect(atkValue.value / atkStat).toBe(2); @@ -112,7 +112,7 @@ describe("Items - Thick Club", () => { Species.ALOLA_MAROWAK ]); - const partyMember = game.scene.getParty()[0]; + const partyMember = game.scene.getPlayerParty()[0]; const atkStat = partyMember.getStat(Stat.ATK); @@ -123,7 +123,7 @@ describe("Items - Thick Club", () => { expect(atkValue.value / atkStat).toBe(1); // Giving Eviolite to party member and testing if it applies - partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], ["THICK_CLUB"])!.newModifier(partyMember), true); + partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], [ "THICK_CLUB" ])!.newModifier(partyMember), true); partyMember.scene.applyModifiers(SpeciesStatBoosterModifier, true, partyMember, Stat.ATK, atkValue); expect(atkValue.value / atkStat).toBe(2); @@ -139,8 +139,8 @@ describe("Items - Thick Club", () => { Species.PIKACHU ]); - const partyMember = game.scene.getParty()[0]; - const ally = game.scene.getParty()[1]; + const partyMember = game.scene.getPlayerParty()[0]; + const ally = game.scene.getPlayerParty()[1]; // Fuse party members (taken from PlayerPokemon.fuse(...) function) partyMember.fusionSpecies = ally.species; @@ -160,7 +160,7 @@ describe("Items - Thick Club", () => { expect(atkValue.value / atkStat).toBe(1); // Giving Eviolite to party member and testing if it applies - partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], ["THICK_CLUB"])!.newModifier(partyMember), true); + partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], [ "THICK_CLUB" ])!.newModifier(partyMember), true); partyMember.scene.applyModifiers(SpeciesStatBoosterModifier, true, partyMember, Stat.ATK, atkValue); expect(atkValue.value / atkStat).toBe(2); @@ -176,8 +176,8 @@ describe("Items - Thick Club", () => { species[randSpecies] ]); - const partyMember = game.scene.getParty()[0]; - const ally = game.scene.getParty()[1]; + const partyMember = game.scene.getPlayerParty()[0]; + const ally = game.scene.getPlayerParty()[1]; // Fuse party members (taken from PlayerPokemon.fuse(...) function) partyMember.fusionSpecies = ally.species; @@ -197,7 +197,7 @@ describe("Items - Thick Club", () => { expect(atkValue.value / atkStat).toBe(1); // Giving Eviolite to party member and testing if it applies - partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], ["THICK_CLUB"])!.newModifier(partyMember), true); + partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], [ "THICK_CLUB" ])!.newModifier(partyMember), true); partyMember.scene.applyModifiers(SpeciesStatBoosterModifier, true, partyMember, Stat.ATK, atkValue); expect(atkValue.value / atkStat).toBe(2); @@ -208,7 +208,7 @@ describe("Items - Thick Club", () => { Species.PIKACHU ]); - const partyMember = game.scene.getParty()[0]; + const partyMember = game.scene.getPlayerParty()[0]; const atkStat = partyMember.getStat(Stat.ATK); @@ -219,7 +219,7 @@ describe("Items - Thick Club", () => { expect(atkValue.value / atkStat).toBe(1); // Giving Eviolite to party member and testing if it applies - partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], ["THICK_CLUB"])!.newModifier(partyMember), true); + partyMember.scene.addModifier(modifierTypes.SPECIES_STAT_BOOSTER().generateType([], [ "THICK_CLUB" ])!.newModifier(partyMember), true); partyMember.scene.applyModifiers(SpeciesStatBoosterModifier, true, partyMember, Stat.ATK, atkValue); expect(atkValue.value / atkStat).toBe(1); diff --git a/src/test/items/toxic_orb.test.ts b/src/test/items/toxic_orb.test.ts index 95336c0793e..6918d7f34f0 100644 --- a/src/test/items/toxic_orb.test.ts +++ b/src/test/items/toxic_orb.test.ts @@ -1,15 +1,11 @@ -import { StatusEffect } from "#app/data/status-effect"; -import { EnemyCommandPhase } from "#app/phases/enemy-command-phase"; -import { MessagePhase } from "#app/phases/message-phase"; -import { TurnEndPhase } from "#app/phases/turn-end-phase"; -import i18next, { initI18n } from "#app/plugins/i18n"; +import i18next from "#app/plugins/i18n"; import { Abilities } from "#enums/abilities"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; +import { StatusEffect } from "#enums/status-effect"; import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; -import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; - +import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; describe("Items - Toxic orb", () => { let phaserGame: Phaser.Game; @@ -27,42 +23,33 @@ describe("Items - Toxic orb", () => { beforeEach(() => { game = new GameManager(phaserGame); - const moveToUse = Moves.GROWTH; - const oppMoveToUse = Moves.TACKLE; - game.override.battleType("single"); - game.override.enemySpecies(Species.RATTATA); - game.override.ability(Abilities.INSOMNIA); - game.override.enemyAbility(Abilities.INSOMNIA); - game.override.startingLevel(2000); - game.override.moveset([moveToUse]); - game.override.enemyMoveset([oppMoveToUse, oppMoveToUse, oppMoveToUse, oppMoveToUse]); - game.override.startingHeldItems([{ - name: "TOXIC_ORB", - }]); + game.override + .battleType("single") + .enemySpecies(Species.MAGIKARP) + .ability(Abilities.BALL_FETCH) + .enemyAbility(Abilities.BALL_FETCH) + .moveset(Moves.SPLASH) + .enemyMoveset(Moves.SPLASH) + .startingHeldItems([{ + name: "TOXIC_ORB", + }]); + + vi.spyOn(i18next, "t"); }); - it("TOXIC ORB", async () => { - initI18n(); - i18next.changeLanguage("en"); - const moveToUse = Moves.GROWTH; - await game.startBattle([ - Species.MIGHTYENA, - Species.MIGHTYENA, - ]); - expect(game.scene.modifiers[0].type.id).toBe("TOXIC_ORB"); + it("should badly poison the holder", async () => { + await game.classicMode.startBattle([ Species.FEEBAS ]); - game.move.select(moveToUse); + const player = game.scene.getPlayerPokemon()!; + expect(player.getHeldItems()[0].type.id).toBe("TOXIC_ORB"); - // will run the 13 phase from enemyCommandPhase to TurnEndPhase - await game.phaseInterceptor.runFrom(EnemyCommandPhase).to(TurnEndPhase); - // Toxic orb should trigger here - await game.phaseInterceptor.run(MessagePhase); - const message = game.textInterceptor.getLatestMessage(); - expect(message).toContain("was badly poisoned by the Toxic Orb"); - await game.phaseInterceptor.run(MessagePhase); - const message2 = game.textInterceptor.getLatestMessage(); - expect(message2).toContain("is hurt"); - expect(message2).toContain("by poison"); - expect(game.scene.getParty()[0].status!.effect).toBe(StatusEffect.TOXIC); - }, 20000); + game.move.select(Moves.SPLASH); + + await game.phaseInterceptor.to("TurnEndPhase"); + await game.phaseInterceptor.to("MessagePhase"); + expect(i18next.t).toHaveBeenCalledWith("statusEffect:toxic.obtainSource", expect.anything()); + + expect(player.status?.effect).toBe(StatusEffect.TOXIC); + expect(player.status?.toxicTurnCount).toBe(0); + }); }); diff --git a/src/test/localization/french.test.ts b/src/test/localization/french.test.ts deleted file mode 100644 index 92b4c82d7cb..00000000000 --- a/src/test/localization/french.test.ts +++ /dev/null @@ -1,42 +0,0 @@ -import { initI18n } from "#app/plugins/i18n"; -import { Species } from "#enums/species"; -import GameManager from "#test/utils/gameManager"; -import i18next from "i18next"; -import Phaser from "phaser"; -import { afterEach, beforeAll, describe, expect, it } from "vitest"; - -describe("Lokalization - french", () => { - let phaserGame: Phaser.Game; - let game: GameManager; - - beforeAll(() => { - initI18n(); - phaserGame = new Phaser.Game({ - type: Phaser.HEADLESS, - }); - }); - - afterEach(() => { - game.phaseInterceptor.restoreOg(); - }); - - it("test bulbasaur name english", async () => { - game = new GameManager(phaserGame); - await game.startBattle([ - Species.BULBASAUR, - ]); - expect(game.scene.getParty()[0].name).toBe("Bulbasaur"); - }, 20000); - - it("test bulbasaure name french", async () => { - const locale = "fr"; - i18next.changeLanguage(locale); - localStorage.setItem("prLang", locale); - game = new GameManager(phaserGame); - - await game.startBattle([ - Species.BULBASAUR, - ]); - expect(game.scene.getParty()[0].name).toBe("Bulbizarre"); - }, 20000); -}); diff --git a/src/test/localization/terrain.test.ts b/src/test/localization/terrain.test.ts deleted file mode 100644 index ed280177a06..00000000000 --- a/src/test/localization/terrain.test.ts +++ /dev/null @@ -1,191 +0,0 @@ -import { TerrainType, getTerrainName } from "#app/data/terrain"; -import { getTerrainBlockMessage, getTerrainClearMessage, getTerrainStartMessage } from "#app/data/weather"; -import { Species } from "#enums/species"; -import GameManager from "#test/utils/gameManager"; -import { mockI18next } from "#test/utils/testUtils"; -import i18next from "i18next"; -import Phaser from "phaser"; -import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; - -describe("terrain", () => { - let phaserGame: Phaser.Game; - let game: GameManager; - - beforeAll(() => { - phaserGame = new Phaser.Game({ - type: Phaser.HEADLESS, - }); - i18next.init(); - }); - - beforeEach(() => { - game = new GameManager(phaserGame); - game.override.battleType("single"); - }); - - describe("NONE", () => { - const terrainType = TerrainType.NONE; - - it("should return the obtain text", () => { - mockI18next(); - - const text = getTerrainName(terrainType); - expect(text).toBe(""); - }); - - it("should return the start text", () => { - mockI18next(); - - const text = getTerrainStartMessage(terrainType); - expect(text).toBeNull(); - }); - - it("should return the clear text", () => { - mockI18next(); - const text = getTerrainClearMessage(terrainType); - expect(text).toBeNull(); - }); - - it("should return the block text", async () => { - await game.startBattle([Species.MAGIKARP]); - const pokemon = game.scene.getPlayerPokemon()!; - mockI18next(); - const text = getTerrainBlockMessage(pokemon, terrainType); - expect(text).toBe("terrain:defaultBlockMessage"); - }); - }); - - describe("MISTY", () => { - const terrainType = TerrainType.MISTY; - - it("should return the obtain text", () => { - mockI18next(); - - const text = getTerrainName(terrainType); - expect(text).toBe("terrain:misty"); - }); - - it("should return the start text", () => { - mockI18next(); - - const text = getTerrainStartMessage(terrainType); - expect(text).toBe("terrain:mistyStartMessage"); - }); - - it("should return the clear text", () => { - mockI18next(); - const text = getTerrainClearMessage(terrainType); - expect(text).toBe("terrain:mistyClearMessage"); - }); - - it("should return the block text", async () => { - await game.startBattle([Species.MAGIKARP]); - const pokemon = game.scene.getPlayerPokemon()!; - mockI18next(); - const text = getTerrainBlockMessage(pokemon, terrainType); - expect(text).toBe("terrain:mistyBlockMessage"); - }); - }); - - describe("ELECTRIC", () => { - const terrainType = TerrainType.ELECTRIC; - - it("should return the obtain text", () => { - mockI18next(); - - const text = getTerrainName(terrainType); - expect(text).toBe("terrain:electric"); - }); - - it("should return the start text", () => { - mockI18next(); - - const text = getTerrainStartMessage(terrainType); - expect(text).toBe("terrain:electricStartMessage"); - }); - - it("should return the clear text", () => { - mockI18next(); - const text = getTerrainClearMessage(terrainType); - expect(text).toBe("terrain:electricClearMessage"); - }); - - it("should return the block text", async () => { - await game.startBattle([Species.MAGIKARP]); - const pokemon = game.scene.getPlayerPokemon()!; - mockI18next(); - const text = getTerrainBlockMessage(pokemon, terrainType); - expect(text).toBe("terrain:defaultBlockMessage"); - }); - }); - - describe("GRASSY", () => { - const terrainType = TerrainType.GRASSY; - - it("should return the obtain text", () => { - mockI18next(); - - const text = getTerrainName(terrainType); - expect(text).toBe("terrain:grassy"); - }); - - it("should return the start text", () => { - mockI18next(); - - const text = getTerrainStartMessage(terrainType); - expect(text).toBe("terrain:grassyStartMessage"); - }); - - it("should return the clear text", () => { - mockI18next(); - const text = getTerrainClearMessage(terrainType); - expect(text).toBe("terrain:grassyClearMessage"); - }); - - it("should return the block text", async () => { - await game.startBattle([Species.MAGIKARP]); - const pokemon = game.scene.getPlayerPokemon()!; - mockI18next(); - const text = getTerrainBlockMessage(pokemon, terrainType); - expect(text).toBe("terrain:defaultBlockMessage"); - }); - }); - - describe("PSYCHIC", () => { - const terrainType = TerrainType.PSYCHIC; - - it("should return the obtain text", () => { - mockI18next(); - - const text = getTerrainName(terrainType); - expect(text).toBe("terrain:psychic"); - }); - - it("should return the start text", () => { - mockI18next(); - - const text = getTerrainStartMessage(terrainType); - expect(text).toBe("terrain:psychicStartMessage"); - }); - - it("should return the clear text", () => { - mockI18next(); - const text = getTerrainClearMessage(terrainType); - expect(text).toBe("terrain:psychicClearMessage"); - }); - - it("should return the block text", async () => { - await game.startBattle([Species.MAGIKARP]); - const pokemon = game.scene.getPlayerPokemon()!; - mockI18next(); - const text = getTerrainBlockMessage(pokemon, terrainType); - expect(text).toBe("terrain:defaultBlockMessage"); - }); - }); - - - afterEach(() => { - game.phaseInterceptor.restoreOg(); - vi.resetAllMocks(); - }); -}); diff --git a/src/test/misc.test.ts b/src/test/misc.test.ts index 1052a282a64..ae91a5014d9 100644 --- a/src/test/misc.test.ts +++ b/src/test/misc.test.ts @@ -1,4 +1,4 @@ -import { apiFetch } from "#app/utils"; +// import { apiFetch } from "#app/utils"; import GameManager from "#test/utils/gameManager"; import { waitUntil } from "#test/utils/gameManagerUtils"; import Phaser from "phaser"; @@ -35,18 +35,18 @@ describe("Test misc", () => { expect(spy).toHaveBeenCalled(); }); - it("test apifetch mock async", async () => { - const spy = vi.fn(); - await apiFetch("https://localhost:8080/account/info").then(response => { - expect(response.status).toBe(200); - expect(response.ok).toBe(true); - return response.json(); - }).then(data => { - spy(); // Call the spy function - expect(data).toEqual({ "username": "greenlamp", "lastSessionSlot": 0 }); - }); - expect(spy).toHaveBeenCalled(); - }); + // it.skip("test apifetch mock async", async () => { + // const spy = vi.fn(); + // await apiFetch("https://localhost:8080/account/info").then(response => { + // expect(response.status).toBe(200); + // expect(response.ok).toBe(true); + // return response.json(); + // }).then(data => { + // spy(); // Call the spy function + // expect(data).toEqual({ "username": "greenlamp", "lastSessionSlot": 0 }); + // }); + // expect(spy).toHaveBeenCalled(); + // }); it("test fetch mock sync", async () => { const response = await fetch("https://localhost:8080/account/info"); @@ -64,7 +64,7 @@ describe("Test misc", () => { it("testing wait phase queue", async () => { const fakeScene = { - phaseQueue: [1, 2, 3] // Initially not empty + phaseQueue: [ 1, 2, 3 ] // Initially not empty }; setTimeout(() => { fakeScene.phaseQueue = []; diff --git a/src/test/moves/after_you.test.ts b/src/test/moves/after_you.test.ts index efce1b28a17..99f383194aa 100644 --- a/src/test/moves/after_you.test.ts +++ b/src/test/moves/after_you.test.ts @@ -8,7 +8,6 @@ import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Moves - After You", () => { let phaserGame: Phaser.Game; @@ -33,11 +32,11 @@ describe("Moves - After You", () => { .enemyAbility(Abilities.BALL_FETCH) .enemyMoveset(Moves.SPLASH) .ability(Abilities.BALL_FETCH) - .moveset([Moves.AFTER_YOU, Moves.SPLASH]); + .moveset([ Moves.AFTER_YOU, Moves.SPLASH ]); }); it("makes the target move immediately after the user", async () => { - await game.classicMode.startBattle([Species.REGIELEKI, Species.SHUCKLE]); + await game.classicMode.startBattle([ Species.REGIELEKI, Species.SHUCKLE ]); game.move.select(Moves.AFTER_YOU, 0, BattlerIndex.PLAYER_2); game.move.select(Moves.SPLASH, 1); @@ -47,11 +46,11 @@ describe("Moves - After You", () => { const phase = game.scene.getCurrentPhase() as MovePhase; expect(phase.pokemon).toBe(game.scene.getPlayerField()[1]); await game.phaseInterceptor.to("MoveEndPhase"); - }, TIMEOUT); + }); it("fails if target already moved", async () => { game.override.enemySpecies(Species.SHUCKLE); - await game.classicMode.startBattle([Species.REGIELEKI, Species.PIKACHU]); + await game.classicMode.startBattle([ Species.REGIELEKI, Species.PIKACHU ]); game.move.select(Moves.SPLASH); game.move.select(Moves.AFTER_YOU, 1, BattlerIndex.PLAYER); @@ -61,5 +60,5 @@ describe("Moves - After You", () => { await game.phaseInterceptor.to(MovePhase); expect(game.scene.getPlayerField()[1].getLastXMoves(1)[0].result).toBe(MoveResult.FAIL); - }, TIMEOUT); + }); }); diff --git a/src/test/moves/alluring_voice.test.ts b/src/test/moves/alluring_voice.test.ts index b438d0f736a..2980f102735 100644 --- a/src/test/moves/alluring_voice.test.ts +++ b/src/test/moves/alluring_voice.test.ts @@ -8,7 +8,6 @@ import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Moves - Alluring Voice", () => { let phaserGame: Phaser.Game; @@ -31,12 +30,12 @@ describe("Moves - Alluring Voice", () => { .disableCrits() .enemySpecies(Species.MAGIKARP) .enemyAbility(Abilities.ICE_SCALES) - .enemyMoveset([Moves.HOWL]) + .enemyMoveset([ Moves.HOWL ]) .startingLevel(10) .enemyLevel(10) .starterSpecies(Species.FEEBAS) .ability(Abilities.BALL_FETCH) - .moveset([Moves.ALLURING_VOICE]); + .moveset([ Moves.ALLURING_VOICE ]); }); @@ -46,9 +45,9 @@ describe("Moves - Alluring Voice", () => { const enemy = game.scene.getEnemyPokemon()!; game.move.select(Moves.ALLURING_VOICE); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); await game.phaseInterceptor.to(BerryPhase); expect(enemy.getTag(BattlerTagType.CONFUSED)?.tagType).toBe("CONFUSED"); - }, TIMEOUT); + }); }); diff --git a/src/test/moves/aromatherapy.test.ts b/src/test/moves/aromatherapy.test.ts new file mode 100644 index 00000000000..874dadc0a1f --- /dev/null +++ b/src/test/moves/aromatherapy.test.ts @@ -0,0 +1,101 @@ +import { StatusEffect } from "#app/enums/status-effect"; +import { CommandPhase } from "#app/phases/command-phase"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, it, expect, vi } from "vitest"; + +describe("Moves - Aromatherapy", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.AROMATHERAPY, Moves.SPLASH ]) + .statusEffect(StatusEffect.BURN) + .battleType("double") + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.SPLASH); + }); + + it("should cure status effect of the user, its ally, and all party pokemon", async () => { + await game.classicMode.startBattle([ Species.RATTATA, Species.RATTATA, Species.RATTATA ]); + const [ leftPlayer, rightPlayer, partyPokemon ] = game.scene.getPlayerParty(); + + vi.spyOn(leftPlayer, "resetStatus"); + vi.spyOn(rightPlayer, "resetStatus"); + vi.spyOn(partyPokemon, "resetStatus"); + + game.move.select(Moves.AROMATHERAPY, 0); + await game.phaseInterceptor.to(CommandPhase); + game.move.select(Moves.SPLASH, 1); + await game.toNextTurn(); + + expect(leftPlayer.resetStatus).toHaveBeenCalledOnce(); + expect(rightPlayer.resetStatus).toHaveBeenCalledOnce(); + expect(partyPokemon.resetStatus).toHaveBeenCalledOnce(); + + expect(leftPlayer.status?.effect).toBeUndefined(); + expect(rightPlayer.status?.effect).toBeUndefined(); + expect(partyPokemon.status?.effect).toBeUndefined(); + }); + + it("should not cure status effect of the target/target's allies", async () => { + game.override.enemyStatusEffect(StatusEffect.BURN); + await game.classicMode.startBattle([ Species.RATTATA, Species.RATTATA ]); + const [ leftOpp, rightOpp ] = game.scene.getEnemyField(); + + vi.spyOn(leftOpp, "resetStatus"); + vi.spyOn(rightOpp, "resetStatus"); + + game.move.select(Moves.AROMATHERAPY, 0); + await game.phaseInterceptor.to(CommandPhase); + game.move.select(Moves.SPLASH, 1); + await game.toNextTurn(); + + expect(leftOpp.resetStatus).toHaveBeenCalledTimes(0); + expect(rightOpp.resetStatus).toHaveBeenCalledTimes(0); + + expect(leftOpp.status?.effect).toBeTruthy(); + expect(rightOpp.status?.effect).toBeTruthy(); + + expect(leftOpp.status?.effect).toBe(StatusEffect.BURN); + expect(rightOpp.status?.effect).toBe(StatusEffect.BURN); + }); + + it("should not cure status effect of allies ON FIELD with Sap Sipper, should still cure allies in party", async () => { + game.override.ability(Abilities.SAP_SIPPER); + await game.classicMode.startBattle([ Species.RATTATA, Species.RATTATA, Species.RATTATA ]); + const [ leftPlayer, rightPlayer, partyPokemon ] = game.scene.getPlayerParty(); + + vi.spyOn(leftPlayer, "resetStatus"); + vi.spyOn(rightPlayer, "resetStatus"); + vi.spyOn(partyPokemon, "resetStatus"); + + game.move.select(Moves.AROMATHERAPY, 0); + await game.phaseInterceptor.to(CommandPhase); + game.move.select(Moves.SPLASH, 1); + await game.toNextTurn(); + + expect(leftPlayer.resetStatus).toHaveBeenCalledOnce(); + expect(rightPlayer.resetStatus).toHaveBeenCalledTimes(0); + expect(partyPokemon.resetStatus).toHaveBeenCalledOnce(); + + expect(leftPlayer.status?.effect).toBeUndefined(); + expect(rightPlayer.status?.effect).toBe(StatusEffect.BURN); + expect(partyPokemon.status?.effect).toBeUndefined(); + }); +}); diff --git a/src/test/moves/astonish.test.ts b/src/test/moves/astonish.test.ts index b21e2a06051..d94e50fc9f9 100644 --- a/src/test/moves/astonish.test.ts +++ b/src/test/moves/astonish.test.ts @@ -11,7 +11,6 @@ import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, test, vi } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Moves - Astonish", () => { let phaserGame: Phaser.Game; @@ -30,10 +29,10 @@ describe("Moves - Astonish", () => { beforeEach(() => { game = new GameManager(phaserGame); game.override.battleType("single"); - game.override.moveset([Moves.ASTONISH, Moves.SPLASH]); + game.override.moveset([ Moves.ASTONISH, Moves.SPLASH ]); game.override.enemySpecies(Species.BLASTOISE); game.override.enemyAbility(Abilities.INSOMNIA); - game.override.enemyMoveset([Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE]); + game.override.enemyMoveset([ Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE ]); game.override.startingLevel(100); game.override.enemyLevel(100); @@ -43,7 +42,7 @@ describe("Moves - Astonish", () => { test( "move effect should cancel the target's move on the turn it applies", async () => { - await game.startBattle([Species.MEOWSCARADA]); + await game.startBattle([ Species.MEOWSCARADA ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -67,6 +66,6 @@ describe("Moves - Astonish", () => { await game.phaseInterceptor.to(BerryPhase, false); expect(leadPokemon.hp).toBeLessThan(leadPokemon.getMaxHp()); - }, TIMEOUT + } ); }); diff --git a/src/test/moves/aurora_veil.test.ts b/src/test/moves/aurora_veil.test.ts index fec280debf4..2d7484b4eb5 100644 --- a/src/test/moves/aurora_veil.test.ts +++ b/src/test/moves/aurora_veil.test.ts @@ -1,13 +1,13 @@ import { ArenaTagSide } from "#app/data/arena-tag"; import Move, { allMoves } from "#app/data/move"; -import { WeatherType } from "#app/data/weather"; -import { Abilities } from "#app/enums/abilities"; import { ArenaTagType } from "#app/enums/arena-tag-type"; import Pokemon from "#app/field/pokemon"; import { TurnEndPhase } from "#app/phases/turn-end-phase"; import { NumberHolder } from "#app/utils"; +import { Abilities } from "#enums/abilities"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; +import { WeatherType } from "#enums/weather-type"; import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; @@ -33,17 +33,17 @@ describe("Moves - Aurora Veil", () => { game = new GameManager(phaserGame); game.override.battleType("single"); game.override.ability(Abilities.NONE); - game.override.moveset([Moves.ABSORB, Moves.ROCK_SLIDE, Moves.TACKLE]); + game.override.moveset([ Moves.ABSORB, Moves.ROCK_SLIDE, Moves.TACKLE ]); game.override.enemyLevel(100); game.override.enemySpecies(Species.MAGIKARP); - game.override.enemyMoveset([Moves.AURORA_VEIL, Moves.AURORA_VEIL, Moves.AURORA_VEIL, Moves.AURORA_VEIL]); + game.override.enemyMoveset([ Moves.AURORA_VEIL, Moves.AURORA_VEIL, Moves.AURORA_VEIL, Moves.AURORA_VEIL ]); game.override.disableCrits(); game.override.weather(WeatherType.HAIL); }); it("reduces damage of physical attacks by half in a single battle", async () => { const moveToUse = Moves.TACKLE; - await game.startBattle([Species.SHUCKLE]); + await game.startBattle([ Species.SHUCKLE ]); game.move.select(moveToUse); @@ -57,7 +57,7 @@ describe("Moves - Aurora Veil", () => { game.override.battleType("double"); const moveToUse = Moves.ROCK_SLIDE; - await game.startBattle([Species.SHUCKLE, Species.SHUCKLE]); + await game.startBattle([ Species.SHUCKLE, Species.SHUCKLE ]); game.move.select(moveToUse); game.move.select(moveToUse, 1); @@ -70,7 +70,7 @@ describe("Moves - Aurora Veil", () => { it("reduces damage of special attacks by half in a single battle", async () => { const moveToUse = Moves.ABSORB; - await game.startBattle([Species.SHUCKLE]); + await game.startBattle([ Species.SHUCKLE ]); game.move.select(moveToUse); @@ -85,7 +85,7 @@ describe("Moves - Aurora Veil", () => { game.override.battleType("double"); const moveToUse = Moves.DAZZLING_GLEAM; - await game.startBattle([Species.SHUCKLE, Species.SHUCKLE]); + await game.startBattle([ Species.SHUCKLE, Species.SHUCKLE ]); game.move.select(moveToUse); game.move.select(moveToUse, 1); @@ -111,7 +111,7 @@ const getMockedMoveDamage = (defender: Pokemon, attacker: Pokemon, move: Move) = const side = defender.isPlayer() ? ArenaTagSide.PLAYER : ArenaTagSide.ENEMY; if (defender.scene.arena.getTagOnSide(ArenaTagType.AURORA_VEIL, side)) { - defender.scene.arena.applyTagsForSide(ArenaTagType.AURORA_VEIL, side, move.category, defender.scene.currentBattle.double, multiplierHolder); + defender.scene.arena.applyTagsForSide(ArenaTagType.AURORA_VEIL, side, false, attacker, move.category, multiplierHolder); } return move.power * multiplierHolder.value; diff --git a/src/test/moves/autotomize.test.ts b/src/test/moves/autotomize.test.ts new file mode 100644 index 00000000000..e15642b7ce5 --- /dev/null +++ b/src/test/moves/autotomize.test.ts @@ -0,0 +1,98 @@ +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, it, expect } from "vitest"; + +describe("Moves - Autotomize", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + const TIMEOUT = 20 * 1000; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.AUTOTOMIZE, Moves.KINGS_SHIELD, Moves.FALSE_SWIPE ]) + .battleType("single") + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.SPLASH); + }); + + it("Autotomize should reduce weight", async () => { + const baseDracozoltWeight = 190; + const oneAutotomizeDracozoltWeight = 90; + const twoAutotomizeDracozoltWeight = 0.1; + const threeAutotomizeDracozoltWeight = 0.1; + + await game.classicMode.startBattle([ Species.DRACOZOLT ]); + const playerPokemon = game.scene.getPlayerPokemon()!; + expect(playerPokemon.getWeight()).toBe(baseDracozoltWeight); + game.move.select(Moves.AUTOTOMIZE); + await game.toNextTurn(); + expect(playerPokemon.getWeight()).toBe(oneAutotomizeDracozoltWeight); + + game.move.select(Moves.AUTOTOMIZE); + await game.toNextTurn(); + expect(playerPokemon.getWeight()).toBe(twoAutotomizeDracozoltWeight); + + + game.move.select(Moves.AUTOTOMIZE); + await game.toNextTurn(); + expect(playerPokemon.getWeight()).toBe(threeAutotomizeDracozoltWeight); + }, TIMEOUT); + + it("Changing forms should revert weight", async () => { + const baseAegislashWeight = 53; + const autotomizeAegislashWeight = 0.1; + + await game.classicMode.startBattle([ Species.AEGISLASH ]); + const playerPokemon = game.scene.getPlayerPokemon()!; + + expect(playerPokemon.getWeight()).toBe(baseAegislashWeight); + + game.move.select(Moves.AUTOTOMIZE); + await game.toNextTurn(); + expect(playerPokemon.getWeight()).toBe(autotomizeAegislashWeight); + + // Transform to sword form + game.move.select(Moves.FALSE_SWIPE); + await game.toNextTurn(); + expect(playerPokemon.getWeight()).toBe(baseAegislashWeight); + + game.move.select(Moves.AUTOTOMIZE); + await game.toNextTurn(); + expect(playerPokemon.getWeight()).toBe(autotomizeAegislashWeight); + + // Transform to shield form + game.move.select(Moves.KINGS_SHIELD); + await game.toNextTurn(); + expect(playerPokemon.getWeight()).toBe(baseAegislashWeight); + + game.move.select(Moves.AUTOTOMIZE); + await game.toNextTurn(); + expect(playerPokemon.getWeight()).toBe(autotomizeAegislashWeight); + }, TIMEOUT); + + it("Autotomize should interact with light metal correctly", async () => { + const baseLightGroudonWeight = 475; + const autotomizeLightGroudonWeight = 425; + game.override.ability(Abilities.LIGHT_METAL); + await game.classicMode.startBattle([ Species.GROUDON ]); + const playerPokemon = game.scene.getPlayerPokemon()!; + expect(playerPokemon.getWeight()).toBe(baseLightGroudonWeight); + game.move.select(Moves.AUTOTOMIZE); + await game.toNextTurn(); + expect(playerPokemon.getWeight()).toBe(autotomizeLightGroudonWeight); + }, TIMEOUT); +}); diff --git a/src/test/moves/baddy_bad.test.ts b/src/test/moves/baddy_bad.test.ts index d1a221453a6..1be25704393 100644 --- a/src/test/moves/baddy_bad.test.ts +++ b/src/test/moves/baddy_bad.test.ts @@ -8,8 +8,6 @@ import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; describe("Moves - Baddy Bad", () => { let phaserGame: Phaser.Game; let game: GameManager; - const TIMEOUT = 20 * 1000; - beforeAll(() => { phaserGame = new Phaser.Game({ type: Phaser.HEADLESS, @@ -23,7 +21,7 @@ describe("Moves - Baddy Bad", () => { beforeEach(() => { game = new GameManager(phaserGame); game.override - .moveset([Moves.SPLASH]) + .moveset([ Moves.SPLASH ]) .battleType("single") .enemySpecies(Species.MAGIKARP) .enemyAbility(Abilities.BALL_FETCH) @@ -33,11 +31,11 @@ describe("Moves - Baddy Bad", () => { it("should not activate Reflect if the move fails due to Protect", async () => { game.override.enemyMoveset(Moves.PROTECT); - await game.classicMode.startBattle([Species.FEEBAS]); + await game.classicMode.startBattle([ Species.FEEBAS ]); game.move.select(Moves.BADDY_BAD); await game.phaseInterceptor.to("BerryPhase"); expect(game.scene.arena.tags.length).toBe(0); - }, TIMEOUT); + }); }); diff --git a/src/test/moves/baneful_bunker.test.ts b/src/test/moves/baneful_bunker.test.ts index c4a3036565c..a0fc0f21ee2 100644 --- a/src/test/moves/baneful_bunker.test.ts +++ b/src/test/moves/baneful_bunker.test.ts @@ -7,7 +7,6 @@ import { Moves } from "#enums/moves"; import { BattlerIndex } from "#app/battle"; import { StatusEffect } from "#app/enums/status-effect"; -const TIMEOUT = 20 * 1000; describe("Moves - Baneful Bunker", () => { let phaserGame: Phaser.Game; @@ -40,54 +39,54 @@ describe("Moves - Baneful Bunker", () => { test( "should protect the user and poison attackers that make contact", async () => { - await game.classicMode.startBattle([Species.CHARIZARD]); + await game.classicMode.startBattle([ Species.CHARIZARD ]); const leadPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; game.move.select(Moves.SLASH); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); await game.phaseInterceptor.to("BerryPhase", false); expect(enemyPokemon.hp).toBe(enemyPokemon.getMaxHp()); expect(leadPokemon.status?.effect === StatusEffect.POISON).toBeTruthy(); - }, TIMEOUT + } ); test( "should protect the user and poison attackers that make contact, regardless of accuracy checks", async () => { - await game.classicMode.startBattle([Species.CHARIZARD]); + await game.classicMode.startBattle([ Species.CHARIZARD ]); const leadPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; game.move.select(Moves.SLASH); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); await game.phaseInterceptor.to("MoveEffectPhase"); await game.move.forceMiss(); await game.phaseInterceptor.to("BerryPhase", false); expect(enemyPokemon.hp).toBe(enemyPokemon.getMaxHp()); expect(leadPokemon.status?.effect === StatusEffect.POISON).toBeTruthy(); - }, TIMEOUT + } ); test( "should not poison attackers that don't make contact", async () => { game.override.moveset(Moves.FLASH_CANNON); - await game.classicMode.startBattle([Species.CHARIZARD]); + await game.classicMode.startBattle([ Species.CHARIZARD ]); const leadPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; game.move.select(Moves.FLASH_CANNON); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); await game.phaseInterceptor.to("MoveEffectPhase"); await game.move.forceMiss(); await game.phaseInterceptor.to("BerryPhase", false); expect(enemyPokemon.hp).toBe(enemyPokemon.getMaxHp()); expect(leadPokemon.status?.effect === StatusEffect.POISON).toBeFalsy(); - }, TIMEOUT + } ); }); diff --git a/src/test/moves/baton_pass.test.ts b/src/test/moves/baton_pass.test.ts index 5643efceae2..52e4c3ec016 100644 --- a/src/test/moves/baton_pass.test.ts +++ b/src/test/moves/baton_pass.test.ts @@ -28,15 +28,15 @@ describe("Moves - Baton Pass", () => { .battleType("single") .enemySpecies(Species.MAGIKARP) .enemyAbility(Abilities.BALL_FETCH) - .moveset([Moves.BATON_PASS, Moves.NASTY_PLOT, Moves.SPLASH]) + .moveset([ Moves.BATON_PASS, Moves.NASTY_PLOT, Moves.SPLASH ]) .ability(Abilities.BALL_FETCH) .enemyMoveset(Moves.SPLASH) .disableCrits(); }); - it("transfers all stat stages when player uses it", async() => { + it("transfers all stat stages when player uses it", async () => { // arrange - await game.classicMode.startBattle([Species.RAICHU, Species.SHUCKLE]); + await game.classicMode.startBattle([ Species.RAICHU, Species.SHUCKLE ]); // round 1 - buff game.move.select(Moves.NASTY_PLOT); @@ -61,8 +61,8 @@ describe("Moves - Baton Pass", () => { // arrange game.override .startingWave(5) - .enemyMoveset(new Array(4).fill([Moves.NASTY_PLOT])); - await game.classicMode.startBattle([Species.RAICHU, Species.SHUCKLE]); + .enemyMoveset(new Array(4).fill([ Moves.NASTY_PLOT ])); + await game.classicMode.startBattle([ Species.RAICHU, Species.SHUCKLE ]); // round 1 - ai buffs game.move.select(Moves.SPLASH); @@ -70,7 +70,7 @@ describe("Moves - Baton Pass", () => { // round 2 - baton pass game.scene.getEnemyPokemon()!.hp = 100; - game.override.enemyMoveset([Moves.BATON_PASS]); + game.override.enemyMoveset([ Moves.BATON_PASS ]); // Force moveset to update mid-battle // TODO: replace with enemy ai control function when it's added game.scene.getEnemyParty()[0].getMoveset(); @@ -91,14 +91,14 @@ describe("Moves - Baton Pass", () => { ]); }, 20000); - it("doesn't transfer effects that aren't transferrable", async() => { - game.override.enemyMoveset([Moves.SALT_CURE]); - await game.classicMode.startBattle([Species.PIKACHU, Species.FEEBAS]); + it("doesn't transfer effects that aren't transferrable", async () => { + game.override.enemyMoveset([ Moves.SALT_CURE ]); + await game.classicMode.startBattle([ Species.PIKACHU, Species.FEEBAS ]); - const [player1, player2] = game.scene.getParty(); + const [ player1, player2 ] = game.scene.getPlayerParty(); game.move.select(Moves.BATON_PASS); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); await game.phaseInterceptor.to("MoveEndPhase"); expect(player1.findTag((t) => t.tagType === BattlerTagType.SALT_CURED)).toBeTruthy(); game.doSelectPartyPokemon(1); @@ -106,4 +106,28 @@ describe("Moves - Baton Pass", () => { expect(player2.findTag((t) => t.tagType === BattlerTagType.SALT_CURED)).toBeUndefined(); }, 20000); + + it("doesn't allow binding effects from the user to persist", async () => { + game.override.moveset([ Moves.FIRE_SPIN, Moves.BATON_PASS ]); + + await game.classicMode.startBattle([ Species.MAGIKARP, Species.FEEBAS ]); + + const enemy = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.FIRE_SPIN); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + await game.move.forceHit(); + + await game.toNextTurn(); + + expect(enemy.getTag(BattlerTagType.FIRE_SPIN)).toBeDefined(); + + game.move.select(Moves.BATON_PASS); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + + game.doSelectPartyPokemon(1); + await game.toNextTurn(); + + expect(enemy.getTag(BattlerTagType.FIRE_SPIN)).toBeUndefined(); + }); }); diff --git a/src/test/moves/beak_blast.test.ts b/src/test/moves/beak_blast.test.ts index fe748c87826..0c1e7bbeed9 100644 --- a/src/test/moves/beak_blast.test.ts +++ b/src/test/moves/beak_blast.test.ts @@ -10,7 +10,6 @@ import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Moves - Beak Blast", () => { let phaserGame: Phaser.Game; @@ -31,10 +30,10 @@ describe("Moves - Beak Blast", () => { game.override .battleType("single") .ability(Abilities.UNNERVE) - .moveset([Moves.BEAK_BLAST]) + .moveset([ Moves.BEAK_BLAST ]) .enemySpecies(Species.SNORLAX) .enemyAbility(Abilities.INSOMNIA) - .enemyMoveset([Moves.TACKLE]) + .enemyMoveset([ Moves.TACKLE ]) .startingLevel(100) .enemyLevel(100); }); @@ -42,7 +41,7 @@ describe("Moves - Beak Blast", () => { it( "should add a charge effect that burns attackers on contact", async () => { - await game.startBattle([Species.BLASTOISE]); + await game.startBattle([ Species.BLASTOISE ]); const leadPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -54,7 +53,7 @@ describe("Moves - Beak Blast", () => { await game.phaseInterceptor.to(BerryPhase, false); expect(enemyPokemon.status?.effect).toBe(StatusEffect.BURN); - }, TIMEOUT + } ); it( @@ -62,7 +61,7 @@ describe("Moves - Beak Blast", () => { async () => { game.override.statusEffect(StatusEffect.SLEEP); - await game.startBattle([Species.BLASTOISE]); + await game.startBattle([ Species.BLASTOISE ]); const leadPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -74,15 +73,15 @@ describe("Moves - Beak Blast", () => { await game.phaseInterceptor.to(BerryPhase, false); expect(enemyPokemon.status?.effect).toBe(StatusEffect.BURN); - }, TIMEOUT + } ); it( "should not burn attackers that don't make contact", async () => { - game.override.enemyMoveset([Moves.WATER_GUN]); + game.override.enemyMoveset([ Moves.WATER_GUN ]); - await game.startBattle([Species.BLASTOISE]); + await game.startBattle([ Species.BLASTOISE ]); const leadPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -94,7 +93,7 @@ describe("Moves - Beak Blast", () => { await game.phaseInterceptor.to(BerryPhase, false); expect(enemyPokemon.status?.effect).not.toBe(StatusEffect.BURN); - }, TIMEOUT + } ); it( @@ -102,7 +101,7 @@ describe("Moves - Beak Blast", () => { async () => { game.override.startingHeldItems([{ name: "MULTI_LENS", count: 1 }]); - await game.startBattle([Species.BLASTOISE]); + await game.startBattle([ Species.BLASTOISE ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -110,15 +109,15 @@ describe("Moves - Beak Blast", () => { await game.phaseInterceptor.to(BerryPhase, false); expect(leadPokemon.turnData.hitCount).toBe(2); - }, TIMEOUT + } ); it( "should be blocked by Protect", async () => { - game.override.enemyMoveset([Moves.PROTECT]); + game.override.enemyMoveset([ Moves.PROTECT ]); - await game.startBattle([Species.BLASTOISE]); + await game.startBattle([ Species.BLASTOISE ]); const leadPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -131,6 +130,6 @@ describe("Moves - Beak Blast", () => { await game.phaseInterceptor.to(TurnEndPhase); expect(enemyPokemon.hp).toBe(enemyPokemon.getMaxHp()); expect(leadPokemon.getTag(BattlerTagType.BEAK_BLAST_CHARGING)).toBeUndefined(); - }, TIMEOUT + } ); }); diff --git a/src/test/moves/beat_up.test.ts b/src/test/moves/beat_up.test.ts index 70b33f56583..41e5b63471f 100644 --- a/src/test/moves/beat_up.test.ts +++ b/src/test/moves/beat_up.test.ts @@ -7,8 +7,6 @@ import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; -const TIMEOUT = 20 * 1000; // 20 sec timeout - describe("Moves - Beat Up", () => { let phaserGame: Phaser.Game; let game: GameManager; @@ -29,17 +27,17 @@ describe("Moves - Beat Up", () => { game.override.enemySpecies(Species.SNORLAX); game.override.enemyLevel(100); - game.override.enemyMoveset([Moves.SPLASH]); + game.override.enemyMoveset([ Moves.SPLASH ]); game.override.enemyAbility(Abilities.INSOMNIA); game.override.startingLevel(100); - game.override.moveset([Moves.BEAT_UP]); + game.override.moveset([ Moves.BEAT_UP ]); }); it( "should hit once for each healthy player Pokemon", async () => { - await game.startBattle([Species.MAGIKARP, Species.BULBASAUR, Species.CHARMANDER, Species.SQUIRTLE, Species.PIKACHU, Species.EEVEE]); + await game.startBattle([ Species.MAGIKARP, Species.BULBASAUR, Species.CHARMANDER, Species.SQUIRTLE, Species.PIKACHU, Species.EEVEE ]); const playerPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -57,48 +55,23 @@ describe("Moves - Beat Up", () => { await game.phaseInterceptor.to(MoveEffectPhase); expect(enemyPokemon.hp).toBeLessThan(enemyStartingHp); } - }, TIMEOUT + } ); it( "should not count player Pokemon with status effects towards hit count", async () => { - await game.startBattle([Species.MAGIKARP, Species.BULBASAUR, Species.CHARMANDER, Species.SQUIRTLE, Species.PIKACHU, Species.EEVEE]); + await game.startBattle([ Species.MAGIKARP, Species.BULBASAUR, Species.CHARMANDER, Species.SQUIRTLE, Species.PIKACHU, Species.EEVEE ]); const playerPokemon = game.scene.getPlayerPokemon()!; - game.scene.getParty()[1].trySetStatus(StatusEffect.BURN); + game.scene.getPlayerParty()[1].trySetStatus(StatusEffect.BURN); game.move.select(Moves.BEAT_UP); await game.phaseInterceptor.to(MoveEffectPhase); expect(playerPokemon.turnData.hitCount).toBe(5); - }, TIMEOUT - ); - - it( - "should hit twice for each player Pokemon if the user has Multi-Lens", - async () => { - game.override.startingHeldItems([{ name: "MULTI_LENS", count: 1 }]); - await game.startBattle([Species.MAGIKARP, Species.BULBASAUR, Species.CHARMANDER, Species.SQUIRTLE, Species.PIKACHU, Species.EEVEE]); - - const playerPokemon = game.scene.getPlayerPokemon()!; - const enemyPokemon = game.scene.getEnemyPokemon()!; - let enemyStartingHp = enemyPokemon.hp; - - game.move.select(Moves.BEAT_UP); - - await game.phaseInterceptor.to(MoveEffectPhase); - - expect(playerPokemon.turnData.hitCount).toBe(12); - expect(enemyPokemon.hp).toBeLessThan(enemyStartingHp); - - while (playerPokemon.turnData.hitsLeft > 0) { - enemyStartingHp = enemyPokemon.hp; - await game.phaseInterceptor.to(MoveEffectPhase); - expect(enemyPokemon.hp).toBeLessThan(enemyStartingHp); - } - }, TIMEOUT + } ); }); diff --git a/src/test/moves/belly_drum.test.ts b/src/test/moves/belly_drum.test.ts index 3d85c59a2a5..0bed1248e7e 100644 --- a/src/test/moves/belly_drum.test.ts +++ b/src/test/moves/belly_drum.test.ts @@ -8,7 +8,7 @@ import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, test } from "vitest"; import { Abilities } from "#app/enums/abilities"; -const TIMEOUT = 20 * 1000; + // RATIO : HP Cost of Move const RATIO = 2; // PREDAMAGE : Amount of extra HP lost @@ -35,7 +35,7 @@ describe("Moves - BELLY DRUM", () => { .enemySpecies(Species.SNORLAX) .startingLevel(100) .enemyLevel(100) - .moveset([Moves.BELLY_DRUM]) + .moveset([ Moves.BELLY_DRUM ]) .enemyMoveset(Moves.SPLASH) .enemyAbility(Abilities.BALL_FETCH); }); @@ -44,7 +44,7 @@ describe("Moves - BELLY DRUM", () => { test("raises the user's ATK stat stage to its max, at the cost of 1/2 of its maximum HP", async() => { - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; const hpLost = toDmgValue(leadPokemon.getMaxHp() / RATIO); @@ -54,12 +54,12 @@ describe("Moves - BELLY DRUM", () => { expect(leadPokemon.hp).toBe(leadPokemon.getMaxHp() - hpLost); expect(leadPokemon.getStatStage(Stat.ATK)).toBe(6); - }, TIMEOUT + } ); test("will still take effect if an uninvolved stat stage is at max", async() => { - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; const hpLost = toDmgValue(leadPokemon.getMaxHp() / RATIO); @@ -74,12 +74,12 @@ describe("Moves - BELLY DRUM", () => { expect(leadPokemon.hp).toBe(leadPokemon.getMaxHp() - hpLost); expect(leadPokemon.getStatStage(Stat.ATK)).toBe(6); expect(leadPokemon.getStatStage(Stat.SPATK)).toBe(6); - }, TIMEOUT + } ); test("fails if the pokemon's ATK stat stage is at its maximum", async() => { - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -90,12 +90,12 @@ describe("Moves - BELLY DRUM", () => { expect(leadPokemon.hp).toBe(leadPokemon.getMaxHp()); expect(leadPokemon.getStatStage(Stat.ATK)).toBe(6); - }, TIMEOUT + } ); test("fails if the user's health is less than 1/2", async() => { - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; const hpLost = toDmgValue(leadPokemon.getMaxHp() / RATIO); @@ -106,6 +106,6 @@ describe("Moves - BELLY DRUM", () => { expect(leadPokemon.hp).toBe(hpLost - PREDAMAGE); expect(leadPokemon.getStatStage(Stat.ATK)).toBe(0); - }, TIMEOUT + } ); }); diff --git a/src/test/moves/burning_jealousy.test.ts b/src/test/moves/burning_jealousy.test.ts index 3f2bf453684..fe2735cfa96 100644 --- a/src/test/moves/burning_jealousy.test.ts +++ b/src/test/moves/burning_jealousy.test.ts @@ -8,7 +8,6 @@ import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Moves - Burning Jealousy", () => { let phaserGame: Phaser.Game; @@ -31,12 +30,12 @@ describe("Moves - Burning Jealousy", () => { .disableCrits() .enemySpecies(Species.MAGIKARP) .enemyAbility(Abilities.ICE_SCALES) - .enemyMoveset([Moves.HOWL]) + .enemyMoveset([ Moves.HOWL ]) .startingLevel(10) .enemyLevel(10) .starterSpecies(Species.FEEBAS) .ability(Abilities.BALL_FETCH) - .moveset([Moves.BURNING_JEALOUSY, Moves.GROWL]); + .moveset([ Moves.BURNING_JEALOUSY, Moves.GROWL ]); }); @@ -46,27 +45,27 @@ describe("Moves - Burning Jealousy", () => { const enemy = game.scene.getEnemyPokemon()!; game.move.select(Moves.BURNING_JEALOUSY); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); await game.phaseInterceptor.to("BerryPhase"); expect(enemy.status?.effect).toBe(StatusEffect.BURN); - }, TIMEOUT); + }); it("should still burn the opponent if their stat stages were both raised and lowered in the same turn", async () => { game.override .starterSpecies(0) .battleType("double"); - await game.classicMode.startBattle([Species.FEEBAS, Species.ABRA]); + await game.classicMode.startBattle([ Species.FEEBAS, Species.ABRA ]); const enemy = game.scene.getEnemyPokemon()!; game.move.select(Moves.BURNING_JEALOUSY); game.move.select(Moves.GROWL, 1); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER_2, BattlerIndex.PLAYER, BattlerIndex.ENEMY_2]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER_2, BattlerIndex.PLAYER, BattlerIndex.ENEMY_2 ]); await game.phaseInterceptor.to("BerryPhase"); expect(enemy.status?.effect).toBe(StatusEffect.BURN); - }, TIMEOUT); + }); it("should ignore stat stages raised by IMPOSTER", async () => { game.override @@ -81,11 +80,11 @@ describe("Moves - Burning Jealousy", () => { await game.phaseInterceptor.to("BerryPhase"); expect(enemy.status?.effect).toBeUndefined(); - }, TIMEOUT); + }); it.skip("should ignore weakness policy", async () => { // TODO: Make this test if WP is implemented await game.classicMode.startBattle(); - }, TIMEOUT); + }); it("should be boosted by Sheer Force even if opponent didn't raise stat stages", async () => { game.override @@ -98,5 +97,5 @@ describe("Moves - Burning Jealousy", () => { await game.phaseInterceptor.to("BerryPhase"); expect(allMoves[Moves.BURNING_JEALOUSY].calculateBattlePower).toHaveReturnedWith(allMoves[Moves.BURNING_JEALOUSY].power * 5461 / 4096); - }, TIMEOUT); + }); }); diff --git a/src/test/moves/camouflage.test.ts b/src/test/moves/camouflage.test.ts new file mode 100644 index 00000000000..5773afffcc3 --- /dev/null +++ b/src/test/moves/camouflage.test.ts @@ -0,0 +1,49 @@ +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import { TerrainType } from "#app/data/terrain"; +import { Type } from "#enums/type"; +import { BattlerIndex } from "#app/battle"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; + +describe("Moves - Camouflage", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.CAMOUFLAGE ]) + .ability(Abilities.BALL_FETCH) + .battleType("single") + .disableCrits() + .enemySpecies(Species.REGIELEKI) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.PSYCHIC_TERRAIN); + }); + + it("Camouflage should look at terrain first when selecting a type to change into", async () => { + await game.classicMode.startBattle([ Species.SHUCKLE ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + + game.move.select(Moves.CAMOUFLAGE); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); + await game.phaseInterceptor.to("BerryPhase"); + expect(game.scene.arena.getTerrainType()).toBe(TerrainType.PSYCHIC); + const pokemonType = playerPokemon.getTypes()[0]; + expect(pokemonType).toBe(Type.PSYCHIC); + }); +}); diff --git a/src/test/moves/ceaseless_edge.test.ts b/src/test/moves/ceaseless_edge.test.ts index 8511b3179c6..3fbbb7b0aaf 100644 --- a/src/test/moves/ceaseless_edge.test.ts +++ b/src/test/moves/ceaseless_edge.test.ts @@ -10,7 +10,6 @@ import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, test, vi } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Moves - Ceaseless Edge", () => { let phaserGame: Phaser.Game; @@ -34,8 +33,8 @@ describe("Moves - Ceaseless Edge", () => { game.override.enemyPassiveAbility(Abilities.RUN_AWAY); game.override.startingLevel(100); game.override.enemyLevel(100); - game.override.moveset([Moves.CEASELESS_EDGE, Moves.SPLASH, Moves.ROAR]); - game.override.enemyMoveset([Moves.SPLASH, Moves.SPLASH, Moves.SPLASH, Moves.SPLASH]); + game.override.moveset([ Moves.CEASELESS_EDGE, Moves.SPLASH, Moves.ROAR ]); + game.override.enemyMoveset(Moves.SPLASH); vi.spyOn(allMoves[Moves.CEASELESS_EDGE], "accuracy", "get").mockReturnValue(100); }); @@ -43,7 +42,7 @@ describe("Moves - Ceaseless Edge", () => { test( "move should hit and apply spikes", async () => { - await game.startBattle([Species.ILLUMISE]); + await game.classicMode.startBattle([ Species.ILLUMISE ]); const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -61,14 +60,14 @@ describe("Moves - Ceaseless Edge", () => { expect(tagAfter instanceof ArenaTrapTag).toBeTruthy(); expect(tagAfter.layers).toBe(1); expect(enemyPokemon.hp).toBeLessThan(enemyStartingHp); - }, TIMEOUT + } ); test( "move should hit twice with multi lens and apply two layers of spikes", async () => { game.override.startingHeldItems([{ name: "MULTI_LENS" }]); - await game.startBattle([Species.ILLUMISE]); + await game.classicMode.startBattle([ Species.ILLUMISE ]); const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -86,16 +85,16 @@ describe("Moves - Ceaseless Edge", () => { expect(tagAfter instanceof ArenaTrapTag).toBeTruthy(); expect(tagAfter.layers).toBe(2); expect(enemyPokemon.hp).toBeLessThan(enemyStartingHp); - }, TIMEOUT + } ); test( "trainer - move should hit twice, apply two layers of spikes, force switch opponent - opponent takes damage", async () => { game.override.startingHeldItems([{ name: "MULTI_LENS" }]); - game.override.startingWave(5); + game.override.startingWave(25); - await game.startBattle([Species.ILLUMISE]); + await game.classicMode.startBattle([ Species.ILLUMISE ]); game.move.select(Moves.CEASELESS_EDGE); await game.phaseInterceptor.to(MoveEffectPhase, false); @@ -103,7 +102,7 @@ describe("Moves - Ceaseless Edge", () => { const tagBefore = game.scene.arena.getTagOnSide(ArenaTagType.SPIKES, ArenaTagSide.ENEMY) as ArenaTrapTag; expect(tagBefore instanceof ArenaTrapTag).toBeFalsy(); - await game.phaseInterceptor.to(TurnEndPhase, false); + await game.toNextTurn(); const tagAfter = game.scene.arena.getTagOnSide(ArenaTagType.SPIKES, ArenaTagSide.ENEMY) as ArenaTrapTag; expect(tagAfter instanceof ArenaTrapTag).toBeTruthy(); expect(tagAfter.layers).toBe(2); @@ -114,6 +113,6 @@ describe("Moves - Ceaseless Edge", () => { game.move.select(Moves.SPLASH); await game.phaseInterceptor.to(TurnEndPhase, false); expect(game.scene.currentBattle.enemyParty[0].hp).toBeLessThan(hpBeforeSpikes); - }, TIMEOUT + } ); }); diff --git a/src/test/moves/chilly_reception.test.ts b/src/test/moves/chilly_reception.test.ts new file mode 100644 index 00000000000..664ca242b20 --- /dev/null +++ b/src/test/moves/chilly_reception.test.ts @@ -0,0 +1,124 @@ +import { Abilities } from "#app/enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import { WeatherType } from "#enums/weather-type"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +//import { TurnInitPhase } from "#app/phases/turn-init-phase"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; + +describe("Moves - Chilly Reception", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override.battleType("single") + .moveset([ Moves.CHILLY_RECEPTION, Moves.SNOWSCAPE ]) + .enemyMoveset(Array(4).fill(Moves.SPLASH)) + .enemyAbility(Abilities.NONE) + .ability(Abilities.NONE); + + }); + + it("should still change the weather if user can't switch out", async () => { + await game.classicMode.startBattle([ Species.SLOWKING ]); + + game.move.select(Moves.CHILLY_RECEPTION); + + await game.phaseInterceptor.to("BerryPhase", false); + expect(game.scene.arena.weather?.weatherType).toBe(WeatherType.SNOW); + }); + + it("should switch out even if it's snowing", async () => { + await game.classicMode.startBattle([ Species.SLOWKING, Species.MEOWTH ]); + // first turn set up snow with snowscape, try chilly reception on second turn + game.move.select(Moves.SNOWSCAPE); + await game.phaseInterceptor.to("BerryPhase", false); + expect(game.scene.arena.weather?.weatherType).toBe(WeatherType.SNOW); + + await game.phaseInterceptor.to("TurnInitPhase", false); + game.move.select(Moves.CHILLY_RECEPTION); + game.doSelectPartyPokemon(1); + + await game.phaseInterceptor.to("BerryPhase", false); + expect(game.scene.arena.weather?.weatherType).toBe(WeatherType.SNOW); + expect(game.scene.getPlayerField()[0].species.speciesId).toBe(Species.MEOWTH); + }); + + it("happy case - switch out and weather changes", async () => { + + await game.classicMode.startBattle([ Species.SLOWKING, Species.MEOWTH ]); + + game.move.select(Moves.CHILLY_RECEPTION); + game.doSelectPartyPokemon(1); + + await game.phaseInterceptor.to("BerryPhase", false); + expect(game.scene.arena.weather?.weatherType).toBe(WeatherType.SNOW); + expect(game.scene.getPlayerField()[0].species.speciesId).toBe(Species.MEOWTH); + }); + + // enemy uses another move and weather doesn't change + it("check case - enemy not selecting chilly reception doesn't change weather ", async () => { + game.override.battleType("single") + .enemyMoveset([ Moves.CHILLY_RECEPTION, Moves.TACKLE ]) + .enemyAbility(Abilities.NONE) + .moveset(Array(4).fill(Moves.SPLASH)); + + await game.classicMode.startBattle([ Species.SLOWKING, Species.MEOWTH ]); + + game.move.select(Moves.SPLASH); + await game.forceEnemyMove(Moves.TACKLE); + + await game.phaseInterceptor.to("BerryPhase", false); + expect(game.scene.arena.weather?.weatherType).toBe(undefined); + }); + + it("enemy trainer - expected behavior ", async () => { + game.override.battleType("single") + .startingWave(8) + .enemyMoveset(Array(4).fill(Moves.CHILLY_RECEPTION)) + .enemyAbility(Abilities.NONE) + .enemySpecies(Species.MAGIKARP) + .moveset([ Moves.SPLASH, Moves.THUNDERBOLT ]); + + await game.classicMode.startBattle([ Species.JOLTEON ]); + const RIVAL_MAGIKARP1 = game.scene.getEnemyPokemon()?.id; + + game.move.select(Moves.SPLASH); + await game.phaseInterceptor.to("BerryPhase", false); + expect(game.scene.arena.weather?.weatherType).toBe(WeatherType.SNOW); + expect(game.scene.getEnemyPokemon()?.id !== RIVAL_MAGIKARP1); + + await game.phaseInterceptor.to("TurnInitPhase", false); + game.move.select(Moves.SPLASH); + + // second chilly reception should still switch out + await game.phaseInterceptor.to("BerryPhase", false); + expect(game.scene.arena.weather?.weatherType).toBe(WeatherType.SNOW); + await game.phaseInterceptor.to("TurnInitPhase", false); + expect(game.scene.getEnemyPokemon()?.id === RIVAL_MAGIKARP1); + game.move.select(Moves.THUNDERBOLT); + + // enemy chilly recep move should fail: it's snowing and no option to switch out + // no crashing + await game.phaseInterceptor.to("BerryPhase", false); + expect(game.scene.arena.weather?.weatherType).toBe(WeatherType.SNOW); + await game.phaseInterceptor.to("TurnInitPhase", false); + expect(game.scene.arena.weather?.weatherType).toBe(WeatherType.SNOW); + game.move.select(Moves.SPLASH); + await game.phaseInterceptor.to("BerryPhase", false); + expect(game.scene.arena.weather?.weatherType).toBe(WeatherType.SNOW); + + }); +}); diff --git a/src/test/moves/chloroblast.test.ts b/src/test/moves/chloroblast.test.ts new file mode 100644 index 00000000000..5e55bf46958 --- /dev/null +++ b/src/test/moves/chloroblast.test.ts @@ -0,0 +1,42 @@ +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; + +describe("Moves - Chloroblast", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.CHLOROBLAST ]) + .ability(Abilities.BALL_FETCH) + .battleType("single") + .disableCrits() + .enemySpecies(Species.MAGIKARP) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.PROTECT); + }); + + it("should not deal recoil damage if the opponent uses protect", async () => { + await game.classicMode.startBattle([ Species.FEEBAS ]); + + game.move.select(Moves.CHLOROBLAST); + await game.phaseInterceptor.to("BerryPhase"); + + expect(game.scene.getPlayerPokemon()!.isFullHp()).toBe(true); + }); +}); diff --git a/src/test/moves/clangorous_soul.test.ts b/src/test/moves/clangorous_soul.test.ts index 015b73b4dab..52e980cc4fa 100644 --- a/src/test/moves/clangorous_soul.test.ts +++ b/src/test/moves/clangorous_soul.test.ts @@ -6,7 +6,7 @@ import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; import { Stat } from "#enums/stat"; -const TIMEOUT = 20 * 1000; + /** HP Cost of Move */ const RATIO = 3; /** Amount of extra HP lost */ @@ -32,7 +32,7 @@ describe("Moves - Clangorous Soul", () => { game.override.enemySpecies(Species.SNORLAX); game.override.startingLevel(100); game.override.enemyLevel(100); - game.override.moveset([Moves.CLANGOROUS_SOUL]); + game.override.moveset([ Moves.CLANGOROUS_SOUL ]); game.override.enemyMoveset(Moves.SPLASH); }); @@ -40,7 +40,7 @@ describe("Moves - Clangorous Soul", () => { it("raises the user's ATK, DEF, SPATK, SPDEF, and SPD stat stages by 1 each at the cost of 1/3 of its maximum HP", async() => { - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; const hpLost = Math.floor(leadPokemon.getMaxHp() / RATIO); @@ -54,12 +54,12 @@ describe("Moves - Clangorous Soul", () => { expect(leadPokemon.getStatStage(Stat.SPATK)).toBe(1); expect(leadPokemon.getStatStage(Stat.SPDEF)).toBe(1); expect(leadPokemon.getStatStage(Stat.SPD)).toBe(1); - }, TIMEOUT + } ); it("will still take effect if one or more of the involved stat stages are not at max", async() => { - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; const hpLost = Math.floor(leadPokemon.getMaxHp() / RATIO); @@ -79,12 +79,12 @@ describe("Moves - Clangorous Soul", () => { expect(leadPokemon.getStatStage(Stat.SPATK)).toBe(6); expect(leadPokemon.getStatStage(Stat.SPDEF)).toBe(5); expect(leadPokemon.getStatStage(Stat.SPD)).toBe(1); - }, TIMEOUT + } ); it("fails if all stat stages involved are at max", async() => { - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -103,12 +103,12 @@ describe("Moves - Clangorous Soul", () => { expect(leadPokemon.getStatStage(Stat.SPATK)).toBe(6); expect(leadPokemon.getStatStage(Stat.SPDEF)).toBe(6); expect(leadPokemon.getStatStage(Stat.SPD)).toBe(6); - }, TIMEOUT + } ); it("fails if the user's health is less than 1/3", async() => { - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; const hpLost = Math.floor(leadPokemon.getMaxHp() / RATIO); @@ -123,6 +123,6 @@ describe("Moves - Clangorous Soul", () => { expect(leadPokemon.getStatStage(Stat.SPATK)).toBe(0); expect(leadPokemon.getStatStage(Stat.SPDEF)).toBe(0); expect(leadPokemon.getStatStage(Stat.SPD)).toBe(0); - }, TIMEOUT + } ); }); diff --git a/src/test/moves/crafty_shield.test.ts b/src/test/moves/crafty_shield.test.ts index 7b962518944..93dd4a02538 100644 --- a/src/test/moves/crafty_shield.test.ts +++ b/src/test/moves/crafty_shield.test.ts @@ -9,7 +9,6 @@ import { BattlerTagType } from "#app/enums/battler-tag-type"; import { BerryPhase } from "#app/phases/berry-phase"; import { CommandPhase } from "#app/phases/command-phase"; -const TIMEOUT = 20 * 1000; describe("Moves - Crafty Shield", () => { let phaserGame: Phaser.Game; @@ -30,10 +29,10 @@ describe("Moves - Crafty Shield", () => { game.override.battleType("double"); - game.override.moveset([Moves.CRAFTY_SHIELD, Moves.SPLASH, Moves.SWORDS_DANCE]); + game.override.moveset([ Moves.CRAFTY_SHIELD, Moves.SPLASH, Moves.SWORDS_DANCE ]); game.override.enemySpecies(Species.SNORLAX); - game.override.enemyMoveset([Moves.GROWL]); + game.override.enemyMoveset([ Moves.GROWL ]); game.override.enemyAbility(Abilities.INSOMNIA); game.override.startingLevel(100); @@ -43,7 +42,7 @@ describe("Moves - Crafty Shield", () => { test( "should protect the user and allies from status moves", async () => { - await game.startBattle([Species.CHARIZARD, Species.BLASTOISE]); + await game.startBattle([ Species.CHARIZARD, Species.BLASTOISE ]); const leadPokemon = game.scene.getPlayerField(); @@ -56,15 +55,15 @@ describe("Moves - Crafty Shield", () => { await game.phaseInterceptor.to(BerryPhase, false); leadPokemon.forEach(p => expect(p.getStatStage(Stat.ATK)).toBe(0)); - }, TIMEOUT + } ); test( "should not protect the user and allies from attack moves", async () => { - game.override.enemyMoveset([Moves.TACKLE]); + game.override.enemyMoveset([ Moves.TACKLE ]); - await game.startBattle([Species.CHARIZARD, Species.BLASTOISE]); + await game.startBattle([ Species.CHARIZARD, Species.BLASTOISE ]); const leadPokemon = game.scene.getPlayerField(); @@ -77,16 +76,16 @@ describe("Moves - Crafty Shield", () => { await game.phaseInterceptor.to(BerryPhase, false); expect(leadPokemon.some(p => p.hp < p.getMaxHp())).toBeTruthy(); - }, TIMEOUT + } ); test( "should protect the user and allies from moves that ignore other protection", async () => { game.override.enemySpecies(Species.DUSCLOPS); - game.override.enemyMoveset([Moves.CURSE]); + game.override.enemyMoveset([ Moves.CURSE ]); - await game.startBattle([Species.CHARIZARD, Species.BLASTOISE]); + await game.startBattle([ Species.CHARIZARD, Species.BLASTOISE ]); const leadPokemon = game.scene.getPlayerField(); @@ -99,13 +98,13 @@ describe("Moves - Crafty Shield", () => { await game.phaseInterceptor.to(BerryPhase, false); leadPokemon.forEach(p => expect(p.getTag(BattlerTagType.CURSED)).toBeUndefined()); - }, TIMEOUT + } ); test( "should not block allies' self-targeted moves", async () => { - await game.startBattle([Species.CHARIZARD, Species.BLASTOISE]); + await game.startBattle([ Species.CHARIZARD, Species.BLASTOISE ]); const leadPokemon = game.scene.getPlayerField(); diff --git a/src/test/moves/destiny_bond.test.ts b/src/test/moves/destiny_bond.test.ts new file mode 100644 index 00000000000..4b4c8782862 --- /dev/null +++ b/src/test/moves/destiny_bond.test.ts @@ -0,0 +1,255 @@ +import { ArenaTagSide, ArenaTrapTag } from "#app/data/arena-tag"; +import { allMoves } from "#app/data/move"; +import { Abilities } from "#enums/abilities"; +import { ArenaTagType } from "#enums/arena-tag-type"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; +import { BattlerIndex } from "#app/battle"; +import { StatusEffect } from "#enums/status-effect"; +import { PokemonInstantReviveModifier } from "#app/modifier/modifier"; + + +describe("Moves - Destiny Bond", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + const defaultParty = [ Species.BULBASAUR, Species.SQUIRTLE ]; + const enemyFirst = [ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]; + const playerFirst = [ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override.battleType("single") + .ability(Abilities.UNNERVE) // Pre-emptively prevent flakiness from opponent berries + .enemySpecies(Species.RATTATA) + .enemyAbility(Abilities.RUN_AWAY) + .startingLevel(100) // Make sure tested moves KO + .enemyLevel(5) + .enemyMoveset(Moves.DESTINY_BOND); + }); + + it("should KO the opponent on the same turn", async () => { + const moveToUse = Moves.TACKLE; + + game.override.moveset(moveToUse); + await game.classicMode.startBattle(defaultParty); + + const enemyPokemon = game.scene.getEnemyPokemon(); + const playerPokemon = game.scene.getPlayerPokemon(); + + game.move.select(moveToUse); + await game.setTurnOrder(enemyFirst); + await game.phaseInterceptor.to("BerryPhase"); + + expect(enemyPokemon?.isFainted()).toBe(true); + expect(playerPokemon?.isFainted()).toBe(true); + }); + + it("should KO the opponent on the next turn", async () => { + const moveToUse = Moves.TACKLE; + + game.override.moveset([ Moves.SPLASH, moveToUse ]); + await game.classicMode.startBattle(defaultParty); + + const enemyPokemon = game.scene.getEnemyPokemon(); + const playerPokemon = game.scene.getPlayerPokemon(); + + // Turn 1: Enemy uses Destiny Bond and doesn't faint + game.move.select(Moves.SPLASH); + await game.setTurnOrder(playerFirst); + await game.toNextTurn(); + + expect(enemyPokemon?.isFainted()).toBe(false); + expect(playerPokemon?.isFainted()).toBe(false); + + // Turn 2: Player KO's the enemy before the enemy's turn + game.move.select(moveToUse); + await game.setTurnOrder(playerFirst); + await game.phaseInterceptor.to("BerryPhase"); + + expect(enemyPokemon?.isFainted()).toBe(true); + expect(playerPokemon?.isFainted()).toBe(true); + }); + + it("should fail if used twice in a row", async () => { + const moveToUse = Moves.TACKLE; + + game.override.moveset([ Moves.SPLASH, moveToUse ]); + await game.classicMode.startBattle(defaultParty); + + const enemyPokemon = game.scene.getEnemyPokemon(); + const playerPokemon = game.scene.getPlayerPokemon(); + + // Turn 1: Enemy uses Destiny Bond and doesn't faint + game.move.select(Moves.SPLASH); + await game.setTurnOrder(enemyFirst); + await game.toNextTurn(); + + expect(enemyPokemon?.isFainted()).toBe(false); + expect(playerPokemon?.isFainted()).toBe(false); + + // Turn 2: Enemy should fail Destiny Bond then get KO'd + game.move.select(moveToUse); + await game.setTurnOrder(enemyFirst); + await game.phaseInterceptor.to("BerryPhase"); + + expect(enemyPokemon?.isFainted()).toBe(true); + expect(playerPokemon?.isFainted()).toBe(false); + }); + + it("should not KO the opponent if the user dies to weather", async () => { + // Opponent will be reduced to 1 HP by False Swipe, then faint to Sandstorm + const moveToUse = Moves.FALSE_SWIPE; + + game.override.moveset(moveToUse) + .ability(Abilities.SAND_STREAM); + await game.classicMode.startBattle(defaultParty); + + const enemyPokemon = game.scene.getEnemyPokemon(); + const playerPokemon = game.scene.getPlayerPokemon(); + + game.move.select(moveToUse); + await game.setTurnOrder(enemyFirst); + await game.phaseInterceptor.to("BerryPhase"); + + expect(enemyPokemon?.isFainted()).toBe(true); + expect(playerPokemon?.isFainted()).toBe(false); + }); + + it("should not KO the opponent if the user had another turn", async () => { + const moveToUse = Moves.TACKLE; + + game.override.moveset([ Moves.SPORE, moveToUse ]); + await game.classicMode.startBattle(defaultParty); + + const enemyPokemon = game.scene.getEnemyPokemon(); + const playerPokemon = game.scene.getPlayerPokemon(); + + // Turn 1: Enemy uses Destiny Bond and doesn't faint + game.move.select(Moves.SPORE); + await game.setTurnOrder(enemyFirst); + await game.toNextTurn(); + + expect(enemyPokemon?.isFainted()).toBe(false); + expect(playerPokemon?.isFainted()).toBe(false); + expect(enemyPokemon?.status?.effect).toBe(StatusEffect.SLEEP); + + // Turn 2: Enemy should skip a turn due to sleep, then get KO'd + game.move.select(moveToUse); + await game.setTurnOrder(enemyFirst); + await game.phaseInterceptor.to("BerryPhase"); + + expect(enemyPokemon?.isFainted()).toBe(true); + expect(playerPokemon?.isFainted()).toBe(false); + }); + + it("should not KO an ally", async () => { + game.override.moveset([ Moves.DESTINY_BOND, Moves.CRUNCH ]) + .battleType("double"); + await game.classicMode.startBattle([ Species.SHEDINJA, Species.BULBASAUR, Species.SQUIRTLE ]); + + const enemyPokemon0 = game.scene.getEnemyField()[0]; + const enemyPokemon1 = game.scene.getEnemyField()[1]; + const playerPokemon0 = game.scene.getPlayerField()[0]; + const playerPokemon1 = game.scene.getPlayerField()[1]; + + // Shedinja uses Destiny Bond, then ally Bulbasaur KO's Shedinja with Crunch + game.move.select(Moves.DESTINY_BOND, 0); + game.move.select(Moves.CRUNCH, 1, BattlerIndex.PLAYER); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2 ]); + await game.phaseInterceptor.to("BerryPhase"); + + expect(enemyPokemon0?.isFainted()).toBe(false); + expect(enemyPokemon1?.isFainted()).toBe(false); + expect(playerPokemon0?.isFainted()).toBe(true); + expect(playerPokemon1?.isFainted()).toBe(false); + }); + + it("should not cause a crash if the user is KO'd by Ceaseless Edge", async () => { + const moveToUse = Moves.CEASELESS_EDGE; + vi.spyOn(allMoves[moveToUse], "accuracy", "get").mockReturnValue(100); + + game.override.moveset(moveToUse); + await game.classicMode.startBattle(defaultParty); + + const enemyPokemon = game.scene.getEnemyPokemon(); + const playerPokemon = game.scene.getPlayerPokemon(); + + game.move.select(moveToUse); + await game.setTurnOrder(enemyFirst); + await game.phaseInterceptor.to("BerryPhase"); + + expect(enemyPokemon?.isFainted()).toBe(true); + expect(playerPokemon?.isFainted()).toBe(true); + + // Ceaseless Edge spikes effect should still activate + const tagAfter = game.scene.arena.getTagOnSide(ArenaTagType.SPIKES, ArenaTagSide.ENEMY) as ArenaTrapTag; + expect(tagAfter.tagType).toBe(ArenaTagType.SPIKES); + expect(tagAfter.layers).toBe(1); + }); + + it("should not cause a crash if the user is KO'd by Pledge moves", async () => { + game.override.moveset([ Moves.GRASS_PLEDGE, Moves.WATER_PLEDGE ]) + .battleType("double"); + await game.classicMode.startBattle(defaultParty); + + const enemyPokemon0 = game.scene.getEnemyField()[0]; + const enemyPokemon1 = game.scene.getEnemyField()[1]; + const playerPokemon0 = game.scene.getPlayerField()[0]; + const playerPokemon1 = game.scene.getPlayerField()[1]; + + game.move.select(Moves.GRASS_PLEDGE, 0, BattlerIndex.ENEMY); + game.move.select(Moves.WATER_PLEDGE, 1, BattlerIndex.ENEMY); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.ENEMY_2, BattlerIndex.PLAYER, BattlerIndex.PLAYER_2 ]); + await game.phaseInterceptor.to("BerryPhase"); + + expect(enemyPokemon0?.isFainted()).toBe(true); + expect(enemyPokemon1?.isFainted()).toBe(false); + expect(playerPokemon0?.isFainted()).toBe(false); + expect(playerPokemon1?.isFainted()).toBe(true); + + // Pledge secondary effect should still activate + const tagAfter = game.scene.arena.getTagOnSide(ArenaTagType.GRASS_WATER_PLEDGE, ArenaTagSide.ENEMY) as ArenaTrapTag; + expect(tagAfter.tagType).toBe(ArenaTagType.GRASS_WATER_PLEDGE); + }); + + /** + * In particular, this should prevent something like + * {@link https://github.com/pagefaultgames/pokerogue/issues/4219} + * from occurring with fainting by KO'ing a Destiny Bond user with U-Turn. + */ + it("should not allow the opponent to revive via Reviver Seed", async () => { + const moveToUse = Moves.TACKLE; + + game.override.moveset(moveToUse) + .startingHeldItems([{ name: "REVIVER_SEED" }]); + await game.classicMode.startBattle(defaultParty); + + const enemyPokemon = game.scene.getEnemyPokemon(); + const playerPokemon = game.scene.getPlayerPokemon(); + + game.move.select(moveToUse); + await game.setTurnOrder(enemyFirst); + await game.phaseInterceptor.to("BerryPhase"); + + expect(enemyPokemon?.isFainted()).toBe(true); + expect(playerPokemon?.isFainted()).toBe(true); + + // Check that the Tackle user's Reviver Seed did not activate + const revSeeds = game.scene.getModifiers(PokemonInstantReviveModifier).filter(m => m.pokemonId === playerPokemon?.id); + expect(revSeeds.length).toBe(1); + }); +}); diff --git a/src/test/moves/diamond_storm.test.ts b/src/test/moves/diamond_storm.test.ts new file mode 100644 index 00000000000..6e5be2a790d --- /dev/null +++ b/src/test/moves/diamond_storm.test.ts @@ -0,0 +1,46 @@ +import { allMoves } from "#app/data/move"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import { Stat } from "#enums/stat"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; + +describe("Moves - Diamond Storm", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.DIAMOND_STORM ]) + .battleType("single") + .enemySpecies(Species.MAGIKARP) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.SPLASH); + }); + + it("should only increase defense once even if hitting 2 pokemon", async () => { + game.override.battleType("double"); + const diamondStorm = allMoves[Moves.DIAMOND_STORM]; + vi.spyOn(diamondStorm, "chance", "get").mockReturnValue(100); + vi.spyOn(diamondStorm, "accuracy", "get").mockReturnValue(100); + await game.classicMode.startBattle([ Species.FEEBAS ]); + + game.move.select(Moves.DIAMOND_STORM); + await game.phaseInterceptor.to("BerryPhase"); + + expect(game.scene.getPlayerPokemon()!.getStatStage(Stat.DEF)).toBe(2); + }); +}); diff --git a/src/test/moves/dig.test.ts b/src/test/moves/dig.test.ts new file mode 100644 index 00000000000..4c6b5d3b75d --- /dev/null +++ b/src/test/moves/dig.test.ts @@ -0,0 +1,114 @@ +import { BattlerIndex } from "#app/battle"; +import { allMoves } from "#app/data/move"; +import { Abilities } from "#enums/abilities"; +import { BattlerTagType } from "#enums/battler-tag-type"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import { StatusEffect } from "#enums/status-effect"; +import { MoveResult } from "#app/field/pokemon"; +import { describe, beforeAll, afterEach, beforeEach, it, expect } from "vitest"; +import GameManager from "#test/utils/gameManager"; + +describe("Moves - Dig", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset(Moves.DIG) + .battleType("single") + .startingLevel(100) + .enemySpecies(Species.SNORLAX) + .enemyLevel(100) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.TACKLE); + }); + + it("should make the user semi-invulnerable, then attack over 2 turns", async () => { + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const enemyPokemon = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.DIG); + + await game.phaseInterceptor.to("TurnEndPhase"); + expect(playerPokemon.getTag(BattlerTagType.UNDERGROUND)).toBeDefined(); + expect(enemyPokemon.getLastXMoves(1)[0].result).toBe(MoveResult.MISS); + expect(playerPokemon.hp).toBe(playerPokemon.getMaxHp()); + expect(enemyPokemon.hp).toBe(enemyPokemon.getMaxHp()); + expect(playerPokemon.getMoveQueue()[0].move).toBe(Moves.DIG); + + await game.phaseInterceptor.to("TurnEndPhase"); + expect(playerPokemon.getTag(BattlerTagType.UNDERGROUND)).toBeUndefined(); + expect(enemyPokemon.hp).toBeLessThan(enemyPokemon.getMaxHp()); + expect(playerPokemon.getMoveHistory()).toHaveLength(2); + + const playerDig = playerPokemon.getMoveset().find(mv => mv && mv.moveId === Moves.DIG); + expect(playerDig?.ppUsed).toBe(1); + }); + + it("should not allow the user to evade attacks from Pokemon with No Guard", async () => { + game.override.enemyAbility(Abilities.NO_GUARD); + + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const enemyPokemon = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.DIG); + + await game.phaseInterceptor.to("TurnEndPhase"); + expect(playerPokemon.hp).toBeLessThan(playerPokemon.getMaxHp()); + expect(enemyPokemon.getLastXMoves(1)[0].result).toBe(MoveResult.SUCCESS); + }); + + it("should not expend PP when the attack phase is cancelled", async () => { + game.override + .enemyAbility(Abilities.NO_GUARD) + .enemyMoveset(Moves.SPORE); + + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + + game.move.select(Moves.DIG); + + await game.phaseInterceptor.to("TurnEndPhase"); + expect(playerPokemon.getTag(BattlerTagType.UNDERGROUND)).toBeUndefined(); + expect(playerPokemon.status?.effect).toBe(StatusEffect.SLEEP); + + const playerDig = playerPokemon.getMoveset().find(mv => mv && mv.moveId === Moves.DIG); + expect(playerDig?.ppUsed).toBe(0); + }); + + it("should cause the user to take double damage from Earthquake", async () => { + await game.classicMode.startBattle([ Species.DONDOZO ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const enemyPokemon = game.scene.getEnemyPokemon()!; + + const preDigEarthquakeDmg = playerPokemon.getAttackDamage(enemyPokemon, allMoves[Moves.EARTHQUAKE]).damage; + + game.move.select(Moves.DIG); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + + await game.phaseInterceptor.to("MoveEffectPhase"); + + const postDigEarthquakeDmg = playerPokemon.getAttackDamage(enemyPokemon, allMoves[Moves.EARTHQUAKE]).damage; + // these hopefully get avoid rounding errors :shrug: + expect(postDigEarthquakeDmg).toBeGreaterThanOrEqual(2 * preDigEarthquakeDmg); + expect(postDigEarthquakeDmg).toBeLessThan(2 * (preDigEarthquakeDmg + 1)); + }); +}); diff --git a/src/test/moves/disable.test.ts b/src/test/moves/disable.test.ts index a35d294e91f..3748598fa90 100644 --- a/src/test/moves/disable.test.ts +++ b/src/test/moves/disable.test.ts @@ -26,7 +26,7 @@ describe("Moves - Disable", () => { .battleType("single") .ability(Abilities.BALL_FETCH) .enemyAbility(Abilities.BALL_FETCH) - .moveset([Moves.DISABLE, Moves.SPLASH]) + .moveset([ Moves.DISABLE, Moves.SPLASH ]) .enemyMoveset(Moves.SPLASH) .starterSpecies(Species.PIKACHU) .enemySpecies(Species.SHUCKLE); @@ -38,7 +38,7 @@ describe("Moves - Disable", () => { const enemyMon = game.scene.getEnemyPokemon()!; game.move.select(Moves.DISABLE); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); await game.toNextTurn(); expect(enemyMon.getMoveHistory()).toHaveLength(1); @@ -52,7 +52,7 @@ describe("Moves - Disable", () => { const enemyMon = game.scene.getEnemyPokemon()!; game.move.select(Moves.DISABLE); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.toNextTurn(); expect(playerMon.getMoveHistory()[0]).toMatchObject({ move: Moves.DISABLE, result: MoveResult.FAIL }); @@ -65,7 +65,7 @@ describe("Moves - Disable", () => { const enemyMon = game.scene.getEnemyPokemon()!; game.move.select(Moves.DISABLE); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); await game.toNextTurn(); game.move.select(Moves.SPLASH); @@ -78,14 +78,14 @@ describe("Moves - Disable", () => { }, 20000); it("cannot disable STRUGGLE", async() => { - game.override.enemyMoveset([Moves.STRUGGLE]); + game.override.enemyMoveset([ Moves.STRUGGLE ]); await game.classicMode.startBattle(); const playerMon = game.scene.getPlayerPokemon()!; const enemyMon = game.scene.getEnemyPokemon()!; game.move.select(Moves.DISABLE); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); await game.toNextTurn(); expect(playerMon.getLastXMoves()[0].result).toBe(MoveResult.FAIL); @@ -103,7 +103,7 @@ describe("Moves - Disable", () => { // Both mons just used Splash last turn; now have player use Disable. game.move.select(Moves.DISABLE); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.toNextTurn(); const enemyHistory = enemyMon.getMoveHistory(); @@ -113,13 +113,13 @@ describe("Moves - Disable", () => { }, 20000); it("disables NATURE POWER, not the move invoked by it", async() => { - game.override.enemyMoveset([Moves.NATURE_POWER]); + game.override.enemyMoveset([ Moves.NATURE_POWER ]); await game.classicMode.startBattle(); const enemyMon = game.scene.getEnemyPokemon()!; game.move.select(Moves.DISABLE); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); await game.toNextTurn(); expect(enemyMon.isMoveRestricted(Moves.NATURE_POWER)).toBe(true); diff --git a/src/test/moves/dive.test.ts b/src/test/moves/dive.test.ts new file mode 100644 index 00000000000..b60416d7740 --- /dev/null +++ b/src/test/moves/dive.test.ts @@ -0,0 +1,137 @@ +import { BattlerTagType } from "#enums/battler-tag-type"; +import { StatusEffect } from "#enums/status-effect"; +import { MoveResult } from "#app/field/pokemon"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, it, expect } from "vitest"; +import { WeatherType } from "#enums/weather-type"; + +describe("Moves - Dive", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset(Moves.DIVE) + .battleType("single") + .startingLevel(100) + .enemySpecies(Species.SNORLAX) + .enemyLevel(100) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.TACKLE); + }); + + it("should make the user semi-invulnerable, then attack over 2 turns", async () => { + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const enemyPokemon = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.DIVE); + + await game.phaseInterceptor.to("TurnEndPhase"); + expect(playerPokemon.getTag(BattlerTagType.UNDERWATER)).toBeDefined(); + expect(enemyPokemon.getLastXMoves(1)[0].result).toBe(MoveResult.MISS); + expect(playerPokemon.hp).toBe(playerPokemon.getMaxHp()); + expect(enemyPokemon.hp).toBe(enemyPokemon.getMaxHp()); + expect(playerPokemon.getMoveQueue()[0].move).toBe(Moves.DIVE); + + await game.phaseInterceptor.to("TurnEndPhase"); + expect(playerPokemon.getTag(BattlerTagType.UNDERWATER)).toBeUndefined(); + expect(enemyPokemon.hp).toBeLessThan(enemyPokemon.getMaxHp()); + expect(playerPokemon.getMoveHistory()).toHaveLength(2); + + const playerDive = playerPokemon.getMoveset().find(mv => mv && mv.moveId === Moves.DIVE); + expect(playerDive?.ppUsed).toBe(1); + }); + + it("should not allow the user to evade attacks from Pokemon with No Guard", async () => { + game.override.enemyAbility(Abilities.NO_GUARD); + + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const enemyPokemon = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.DIVE); + + await game.phaseInterceptor.to("TurnEndPhase"); + expect(playerPokemon.hp).toBeLessThan(playerPokemon.getMaxHp()); + expect(enemyPokemon.getLastXMoves(1)[0].result).toBe(MoveResult.SUCCESS); + }); + + it("should not expend PP when the attack phase is cancelled", async () => { + game.override + .enemyAbility(Abilities.NO_GUARD) + .enemyMoveset(Moves.SPORE); + + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + + game.move.select(Moves.DIVE); + + await game.phaseInterceptor.to("TurnEndPhase"); + expect(playerPokemon.getTag(BattlerTagType.UNDERWATER)).toBeUndefined(); + expect(playerPokemon.status?.effect).toBe(StatusEffect.SLEEP); + + const playerDive = playerPokemon.getMoveset().find(mv => mv && mv.moveId === Moves.DIVE); + expect(playerDive?.ppUsed).toBe(0); + }); + + it("should trigger on-contact post-defend ability effects", async () => { + game.override + .enemyAbility(Abilities.ROUGH_SKIN) + .enemyMoveset(Moves.SPLASH); + + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const enemyPokemon = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.DIVE); + + await game.phaseInterceptor.to("TurnEndPhase"); + + await game.phaseInterceptor.to("MoveEndPhase"); + expect(playerPokemon.hp).toBeLessThan(playerPokemon.getMaxHp()); + expect(enemyPokemon.battleData.abilitiesApplied[0]).toBe(Abilities.ROUGH_SKIN); + }); + + it("should cancel attack after Harsh Sunlight is set", async () => { + game.override.enemyMoveset(Moves.SPLASH); + + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const enemyPokemon = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.DIVE); + + await game.phaseInterceptor.to("TurnEndPhase"); + await game.phaseInterceptor.to("TurnStartPhase", false); + game.scene.arena.trySetWeather(WeatherType.HARSH_SUN, false); + + await game.phaseInterceptor.to("MoveEndPhase"); + expect(playerPokemon.getLastXMoves(1)[0].result).toBe(MoveResult.FAIL); + expect(enemyPokemon.hp).toBe(enemyPokemon.getMaxHp()); + expect(playerPokemon.getTag(BattlerTagType.UNDERWATER)).toBeUndefined(); + + const playerDive = playerPokemon.getMoveset().find(mv => mv && mv.moveId === Moves.DIVE); + expect(playerDive?.ppUsed).toBe(1); + }); +}); diff --git a/src/test/moves/double_team.test.ts b/src/test/moves/double_team.test.ts index fa224c8df9e..62848553e06 100644 --- a/src/test/moves/double_team.test.ts +++ b/src/test/moves/double_team.test.ts @@ -24,16 +24,16 @@ describe("Moves - Double Team", () => { beforeEach(() => { game = new GameManager(phaserGame); game.override.battleType("single"); - game.override.moveset([Moves.DOUBLE_TEAM]); + game.override.moveset([ Moves.DOUBLE_TEAM ]); game.override.disableCrits(); game.override.ability(Abilities.BALL_FETCH); game.override.enemySpecies(Species.SHUCKLE); game.override.enemyAbility(Abilities.BALL_FETCH); - game.override.enemyMoveset([Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE]); + game.override.enemyMoveset([ Moves.TACKLE, Moves.TACKLE, Moves.TACKLE, Moves.TACKLE ]); }); it("raises the user's EVA stat stage by 1", async () => { - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const ally = game.scene.getPlayerPokemon()!; const enemy = game.scene.getEnemyPokemon()!; diff --git a/src/test/moves/dragon_cheer.test.ts b/src/test/moves/dragon_cheer.test.ts index 0fc389ccfb6..750f09214ca 100644 --- a/src/test/moves/dragon_cheer.test.ts +++ b/src/test/moves/dragon_cheer.test.ts @@ -1,5 +1,5 @@ import { BattlerIndex } from "#app/battle"; -import { Type } from "#app/data/type"; +import { Type } from "#enums/type"; import { Moves } from "#app/enums/moves"; import { Species } from "#app/enums/species"; import { Abilities } from "#enums/abilities"; @@ -10,8 +10,6 @@ import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vite describe("Moves - Dragon Cheer", () => { let phaserGame: Phaser.Game; let game: GameManager; - const TIMEOUT = 20 * 1000; - beforeAll(() => { phaserGame = new Phaser.Game({ type: Phaser.HEADLESS, @@ -29,11 +27,11 @@ describe("Moves - Dragon Cheer", () => { .enemyAbility(Abilities.BALL_FETCH) .enemyMoveset(Moves.SPLASH) .enemyLevel(20) - .moveset([Moves.DRAGON_CHEER, Moves.TACKLE, Moves.SPLASH]); + .moveset([ Moves.DRAGON_CHEER, Moves.TACKLE, Moves.SPLASH ]); }); it("increases the user's allies' critical hit ratio by one stage", async () => { - await game.classicMode.startBattle([Species.DRAGONAIR, Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.DRAGONAIR, Species.MAGIKARP ]); const enemy = game.scene.getEnemyField()[0]; @@ -42,15 +40,15 @@ describe("Moves - Dragon Cheer", () => { game.move.select(Moves.DRAGON_CHEER, 0); game.move.select(Moves.TACKLE, 1, BattlerIndex.ENEMY); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2 ]); // After Tackle await game.phaseInterceptor.to("TurnEndPhase"); expect(enemy.getCritStage).toHaveReturnedWith(1); // getCritStage is called on defender - }, TIMEOUT); + }); it("increases the user's Dragon-type allies' critical hit ratio by two stages", async () => { - await game.classicMode.startBattle([Species.MAGIKARP, Species.DRAGONAIR]); + await game.classicMode.startBattle([ Species.MAGIKARP, Species.DRAGONAIR ]); const enemy = game.scene.getEnemyField()[0]; @@ -59,15 +57,15 @@ describe("Moves - Dragon Cheer", () => { game.move.select(Moves.DRAGON_CHEER, 0); game.move.select(Moves.TACKLE, 1, BattlerIndex.ENEMY); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2 ]); // After Tackle await game.phaseInterceptor.to("TurnEndPhase"); expect(enemy.getCritStage).toHaveReturnedWith(2); // getCritStage is called on defender - }, TIMEOUT); + }); it("applies the effect based on the allies' type upon use of the move, and do not change if the allies' type changes later in battle", async () => { - await game.classicMode.startBattle([Species.DRAGONAIR, Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.DRAGONAIR, Species.MAGIKARP ]); const magikarp = game.scene.getPlayerField()[1]; const enemy = game.scene.getEnemyField()[0]; @@ -77,7 +75,7 @@ describe("Moves - Dragon Cheer", () => { game.move.select(Moves.DRAGON_CHEER, 0); game.move.select(Moves.TACKLE, 1, BattlerIndex.ENEMY); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2 ]); // After Tackle await game.phaseInterceptor.to("TurnEndPhase"); @@ -86,15 +84,15 @@ describe("Moves - Dragon Cheer", () => { await game.toNextTurn(); // Change Magikarp's type to Dragon - vi.spyOn(magikarp, "getTypes").mockReturnValue([Type.DRAGON]); - expect(magikarp.getTypes()).toEqual([Type.DRAGON]); + vi.spyOn(magikarp, "getTypes").mockReturnValue([ Type.DRAGON ]); + expect(magikarp.getTypes()).toEqual([ Type.DRAGON ]); game.move.select(Moves.SPLASH, 0); game.move.select(Moves.TACKLE, 1, BattlerIndex.ENEMY); - await game.setTurnOrder([BattlerIndex.PLAYER_2, BattlerIndex.PLAYER, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2]); + await game.setTurnOrder([ BattlerIndex.PLAYER_2, BattlerIndex.PLAYER, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2 ]); await game.phaseInterceptor.to("MoveEndPhase"); expect(enemy.getCritStage).toHaveReturnedWith(1); // getCritStage is called on defender - }, TIMEOUT); + }); }); diff --git a/src/test/moves/dragon_rage.test.ts b/src/test/moves/dragon_rage.test.ts index cab8c3f808b..d5536ff9d2f 100644 --- a/src/test/moves/dragon_rage.test.ts +++ b/src/test/moves/dragon_rage.test.ts @@ -1,8 +1,7 @@ import { Stat } from "#enums/stat"; -import { Type } from "#app/data/type"; +import { Type } from "#enums/type"; import { Species } from "#app/enums/species"; import { EnemyPokemon, PlayerPokemon } from "#app/field/pokemon"; -import { modifierTypes } from "#app/modifier/modifier-type"; import { TurnEndPhase } from "#app/phases/turn-end-phase"; import { Abilities } from "#enums/abilities"; import { BattlerTagType } from "#enums/battler-tag-type"; @@ -35,7 +34,7 @@ describe("Moves - Dragon Rage", () => { game.override.battleType("single"); game.override.starterSpecies(Species.SNORLAX); - game.override.moveset([Moves.DRAGON_RAGE]); + game.override.moveset([ Moves.DRAGON_RAGE ]); game.override.ability(Abilities.BALL_FETCH); game.override.passiveAbility(Abilities.BALL_FETCH); game.override.startingLevel(100); @@ -48,7 +47,7 @@ describe("Moves - Dragon Rage", () => { await game.startBattle(); - partyPokemon = game.scene.getParty()[0]; + partyPokemon = game.scene.getPlayerParty()[0]; enemyPokemon = game.scene.getEnemyPokemon()!; // remove berries @@ -58,7 +57,7 @@ describe("Moves - Dragon Rage", () => { it("ignores weaknesses", async () => { game.override.disableCrits(); - vi.spyOn(enemyPokemon, "getTypes").mockReturnValue([Type.DRAGON]); + vi.spyOn(enemyPokemon, "getTypes").mockReturnValue([ Type.DRAGON ]); game.move.select(Moves.DRAGON_RAGE); await game.phaseInterceptor.to(TurnEndPhase); @@ -68,7 +67,7 @@ describe("Moves - Dragon Rage", () => { it("ignores resistances", async () => { game.override.disableCrits(); - vi.spyOn(enemyPokemon, "getTypes").mockReturnValue([Type.STEEL]); + vi.spyOn(enemyPokemon, "getTypes").mockReturnValue([ Type.STEEL ]); game.move.select(Moves.DRAGON_RAGE); await game.phaseInterceptor.to(TurnEndPhase); @@ -88,7 +87,7 @@ describe("Moves - Dragon Rage", () => { it("ignores stab", async () => { game.override.disableCrits(); - vi.spyOn(partyPokemon, "getTypes").mockReturnValue([Type.DRAGON]); + vi.spyOn(partyPokemon, "getTypes").mockReturnValue([ Type.DRAGON ]); game.move.select(Moves.DRAGON_RAGE); await game.phaseInterceptor.to(TurnEndPhase); @@ -114,14 +113,4 @@ describe("Moves - Dragon Rage", () => { expect(enemyPokemon.getInverseHp()).toBe(dragonRageDamage); }); - - it("ignores multi hit", async () => { - game.override.disableCrits(); - game.scene.addModifier(modifierTypes.MULTI_LENS().newModifier(partyPokemon), false); - - game.move.select(Moves.DRAGON_RAGE); - await game.phaseInterceptor.to(TurnEndPhase); - - expect(enemyPokemon.getInverseHp()).toBe(dragonRageDamage); - }); }); diff --git a/src/test/moves/dragon_tail.test.ts b/src/test/moves/dragon_tail.test.ts index e1af29b2db1..6b3e669f770 100644 --- a/src/test/moves/dragon_tail.test.ts +++ b/src/test/moves/dragon_tail.test.ts @@ -1,16 +1,11 @@ import { BattlerIndex } from "#app/battle"; import { allMoves } from "#app/data/move"; -import { BattleEndPhase } from "#app/phases/battle-end-phase"; -import { BerryPhase } from "#app/phases/berry-phase"; -import { TurnEndPhase } from "#app/phases/turn-end-phase"; import { Abilities } from "#enums/abilities"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; -import { afterEach, beforeAll, beforeEach, describe, expect, test, vi } from "vitest"; -import GameManager from "../utils/gameManager"; - -const TIMEOUT = 20 * 1000; +import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; describe("Moves - Dragon Tail", () => { let phaserGame: Phaser.Game; @@ -29,7 +24,7 @@ describe("Moves - Dragon Tail", () => { beforeEach(() => { game = new GameManager(phaserGame); game.override.battleType("single") - .moveset([Moves.DRAGON_TAIL, Moves.SPLASH]) + .moveset([ Moves.DRAGON_TAIL, Moves.SPLASH, Moves.FLAMETHROWER ]) .enemySpecies(Species.WAILORD) .enemyMoveset(Moves.SPLASH) .startingLevel(5) @@ -38,109 +33,164 @@ describe("Moves - Dragon Tail", () => { vi.spyOn(allMoves[Moves.DRAGON_TAIL], "accuracy", "get").mockReturnValue(100); }); - test( - "Single battle should cause opponent to flee, and not crash", - async () => { - await game.startBattle([Species.DRATINI]); + it("should cause opponent to flee, and not crash", async () => { + await game.classicMode.startBattle([ Species.DRATINI ]); - const enemyPokemon = game.scene.getEnemyPokemon()!; + const enemyPokemon = game.scene.getEnemyPokemon()!; - game.move.select(Moves.DRAGON_TAIL); + game.move.select(Moves.DRAGON_TAIL); - await game.phaseInterceptor.to(BerryPhase); + await game.phaseInterceptor.to("BerryPhase"); - const isVisible = enemyPokemon.visible; - const hasFled = enemyPokemon.wildFlee; - expect(!isVisible && hasFled).toBe(true); + const isVisible = enemyPokemon.visible; + const hasFled = enemyPokemon.switchOutStatus; + expect(!isVisible && hasFled).toBe(true); - // simply want to test that the game makes it this far without crashing - await game.phaseInterceptor.to(BattleEndPhase); - }, TIMEOUT - ); + // simply want to test that the game makes it this far without crashing + await game.phaseInterceptor.to("BattleEndPhase"); + }); - test( - "Single battle should cause opponent to flee, display ability, and not crash", - async () => { - game.override.enemyAbility(Abilities.ROUGH_SKIN); - await game.startBattle([Species.DRATINI]); + it("should cause opponent to flee, display ability, and not crash", async () => { + game.override.enemyAbility(Abilities.ROUGH_SKIN); + await game.classicMode.startBattle([ Species.DRATINI ]); - const leadPokemon = game.scene.getPlayerPokemon()!; - const enemyPokemon = game.scene.getEnemyPokemon()!; + const leadPokemon = game.scene.getPlayerPokemon()!; + const enemyPokemon = game.scene.getEnemyPokemon()!; - game.move.select(Moves.DRAGON_TAIL); + game.move.select(Moves.DRAGON_TAIL); - await game.phaseInterceptor.to(BerryPhase); + await game.phaseInterceptor.to("BerryPhase"); - const isVisible = enemyPokemon.visible; - const hasFled = enemyPokemon.wildFlee; - expect(!isVisible && hasFled).toBe(true); - expect(leadPokemon.hp).toBeLessThan(leadPokemon.getMaxHp()); - }, TIMEOUT - ); + const isVisible = enemyPokemon.visible; + const hasFled = enemyPokemon.switchOutStatus; + expect(!isVisible && hasFled).toBe(true); + expect(leadPokemon.hp).toBeLessThan(leadPokemon.getMaxHp()); + }); - test( - "Double battles should proceed without crashing", - async () => { - game.override.battleType("double").enemyMoveset(Moves.SPLASH); - game.override.moveset([Moves.DRAGON_TAIL, Moves.SPLASH, Moves.FLAMETHROWER]) - .enemyAbility(Abilities.ROUGH_SKIN); - await game.startBattle([Species.DRATINI, Species.DRATINI, Species.WAILORD, Species.WAILORD]); + it("should proceed without crashing in a double battle", async () => { + game.override + .battleType("double").enemyMoveset(Moves.SPLASH) + .enemyAbility(Abilities.ROUGH_SKIN); + await game.classicMode.startBattle([ Species.DRATINI, Species.DRATINI, Species.WAILORD, Species.WAILORD ]); - const leadPokemon = game.scene.getParty()[0]!; + const leadPokemon = game.scene.getPlayerParty()[0]!; - const enemyLeadPokemon = game.scene.getEnemyParty()[0]!; - const enemySecPokemon = game.scene.getEnemyParty()[1]!; + const enemyLeadPokemon = game.scene.getEnemyParty()[0]!; + const enemySecPokemon = game.scene.getEnemyParty()[1]!; - game.move.select(Moves.DRAGON_TAIL, 0, BattlerIndex.ENEMY); - game.move.select(Moves.SPLASH, 1); + game.move.select(Moves.DRAGON_TAIL, 0, BattlerIndex.ENEMY); + game.move.select(Moves.SPLASH, 1); - await game.phaseInterceptor.to(TurnEndPhase); + await game.phaseInterceptor.to("TurnEndPhase"); - const isVisibleLead = enemyLeadPokemon.visible; - const hasFledLead = enemyLeadPokemon.wildFlee; - const isVisibleSec = enemySecPokemon.visible; - const hasFledSec = enemySecPokemon.wildFlee; - expect(!isVisibleLead && hasFledLead && isVisibleSec && !hasFledSec).toBe(true); - expect(leadPokemon.hp).toBeLessThan(leadPokemon.getMaxHp()); + const isVisibleLead = enemyLeadPokemon.visible; + const hasFledLead = enemyLeadPokemon.switchOutStatus; + const isVisibleSec = enemySecPokemon.visible; + const hasFledSec = enemySecPokemon.switchOutStatus; + expect(!isVisibleLead && hasFledLead && isVisibleSec && !hasFledSec).toBe(true); + expect(leadPokemon.hp).toBeLessThan(leadPokemon.getMaxHp()); - // second turn - game.move.select(Moves.FLAMETHROWER, 0, BattlerIndex.ENEMY_2); - game.move.select(Moves.SPLASH, 1); + // second turn + game.move.select(Moves.FLAMETHROWER, 0, BattlerIndex.ENEMY_2); + game.move.select(Moves.SPLASH, 1); - await game.phaseInterceptor.to(BerryPhase); - expect(enemySecPokemon.hp).toBeLessThan(enemySecPokemon.getMaxHp()); - }, TIMEOUT - ); + await game.phaseInterceptor.to("BerryPhase"); + expect(enemySecPokemon.hp).toBeLessThan(enemySecPokemon.getMaxHp()); + }); - test( - "Flee move redirection works", - async () => { - game.override.battleType("double").enemyMoveset(Moves.SPLASH); - game.override.moveset([Moves.DRAGON_TAIL, Moves.SPLASH, Moves.FLAMETHROWER]); - game.override.enemyAbility(Abilities.ROUGH_SKIN); - await game.startBattle([Species.DRATINI, Species.DRATINI, Species.WAILORD, Species.WAILORD]); + it("should redirect targets upon opponent flee", async () => { + game.override + .battleType("double") + .enemyMoveset(Moves.SPLASH) + .enemyAbility(Abilities.ROUGH_SKIN); + await game.classicMode.startBattle([ Species.DRATINI, Species.DRATINI, Species.WAILORD, Species.WAILORD ]); - const leadPokemon = game.scene.getParty()[0]!; - const secPokemon = game.scene.getParty()[1]!; + const leadPokemon = game.scene.getPlayerParty()[0]!; + const secPokemon = game.scene.getPlayerParty()[1]!; - const enemyLeadPokemon = game.scene.getEnemyParty()[0]!; - const enemySecPokemon = game.scene.getEnemyParty()[1]!; + const enemyLeadPokemon = game.scene.getEnemyParty()[0]!; + const enemySecPokemon = game.scene.getEnemyParty()[1]!; - game.move.select(Moves.DRAGON_TAIL, 0, BattlerIndex.ENEMY); - // target the same pokemon, second move should be redirected after first flees - game.move.select(Moves.DRAGON_TAIL, 1, BattlerIndex.ENEMY); + game.move.select(Moves.DRAGON_TAIL, 0, BattlerIndex.ENEMY); + // target the same pokemon, second move should be redirected after first flees + game.move.select(Moves.DRAGON_TAIL, 1, BattlerIndex.ENEMY); - await game.phaseInterceptor.to(BerryPhase); + await game.phaseInterceptor.to("BerryPhase"); - const isVisibleLead = enemyLeadPokemon.visible; - const hasFledLead = enemyLeadPokemon.wildFlee; - const isVisibleSec = enemySecPokemon.visible; - const hasFledSec = enemySecPokemon.wildFlee; - expect(!isVisibleLead && hasFledLead && !isVisibleSec && hasFledSec).toBe(true); - expect(leadPokemon.hp).toBeLessThan(leadPokemon.getMaxHp()); - expect(secPokemon.hp).toBeLessThan(secPokemon.getMaxHp()); - expect(enemyLeadPokemon.hp).toBeLessThan(enemyLeadPokemon.getMaxHp()); - expect(enemySecPokemon.hp).toBeLessThan(enemySecPokemon.getMaxHp()); - }, TIMEOUT - ); + const isVisibleLead = enemyLeadPokemon.visible; + const hasFledLead = enemyLeadPokemon.switchOutStatus; + const isVisibleSec = enemySecPokemon.visible; + const hasFledSec = enemySecPokemon.switchOutStatus; + expect(!isVisibleLead && hasFledLead && !isVisibleSec && hasFledSec).toBe(true); + expect(leadPokemon.hp).toBeLessThan(leadPokemon.getMaxHp()); + expect(secPokemon.hp).toBeLessThan(secPokemon.getMaxHp()); + expect(enemyLeadPokemon.hp).toBeLessThan(enemyLeadPokemon.getMaxHp()); + expect(enemySecPokemon.hp).toBeLessThan(enemySecPokemon.getMaxHp()); + }); + + it("doesn't switch out if the target has suction cups", async () => { + game.override.enemyAbility(Abilities.SUCTION_CUPS); + await game.classicMode.startBattle([ Species.REGIELEKI ]); + + const enemy = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.DRAGON_TAIL); + await game.phaseInterceptor.to("TurnEndPhase"); + + expect(enemy.isFullHp()).toBe(false); + }); + + it("should force a switch upon fainting an opponent normally", async () => { + game.override.startingWave(5) + .startingLevel(1000); // To make sure Dragon Tail KO's the opponent + await game.classicMode.startBattle([ Species.DRATINI ]); + + game.move.select(Moves.DRAGON_TAIL); + + await game.toNextTurn(); + + // Make sure the enemy switched to a healthy Pokemon + const enemy = game.scene.getEnemyPokemon()!; + expect(enemy).toBeDefined(); + expect(enemy.isFullHp()).toBe(true); + + // Make sure the enemy has a fainted Pokemon in their party and not on the field + const faintedEnemy = game.scene.getEnemyParty().find(p => !p.isAllowedInBattle()); + expect(faintedEnemy).toBeDefined(); + expect(game.scene.getEnemyField().length).toBe(1); + }); + + it("should not cause a softlock when activating an opponent trainer's reviver seed", async () => { + game.override.startingWave(5) + .enemyHeldItems([{ name: "REVIVER_SEED" }]) + .startingLevel(1000); // To make sure Dragon Tail KO's the opponent + await game.classicMode.startBattle([ Species.DRATINI ]); + + game.move.select(Moves.DRAGON_TAIL); + + await game.toNextTurn(); + + // Make sure the enemy field is not empty and has a revived Pokemon + const enemy = game.scene.getEnemyPokemon()!; + expect(enemy).toBeDefined(); + expect(enemy.hp).toBe(Math.floor(enemy.getMaxHp() / 2)); + expect(game.scene.getEnemyField().length).toBe(1); + }); + + it("should not cause a softlock when activating a player's reviver seed", async () => { + game.override.startingHeldItems([{ name: "REVIVER_SEED" }]) + .enemyMoveset(Moves.DRAGON_TAIL) + .enemyLevel(1000); // To make sure Dragon Tail KO's the player + await game.classicMode.startBattle([ Species.DRATINI, Species.BULBASAUR ]); + + game.move.select(Moves.SPLASH); + + await game.toNextTurn(); + + // Make sure the player's field is not empty and has a revived Pokemon + const dratini = game.scene.getPlayerPokemon()!; + expect(dratini).toBeDefined(); + expect(dratini.hp).toBe(Math.floor(dratini.getMaxHp() / 2)); + expect(game.scene.getPlayerField().length).toBe(1); + }); }); diff --git a/src/test/moves/dynamax_cannon.test.ts b/src/test/moves/dynamax_cannon.test.ts index 6ac0befdb36..001f986bd52 100644 --- a/src/test/moves/dynamax_cannon.test.ts +++ b/src/test/moves/dynamax_cannon.test.ts @@ -27,7 +27,7 @@ describe("Moves - Dynamax Cannon", () => { beforeEach(() => { game = new GameManager(phaserGame); - game.override.moveset([dynamaxCannon.id]); + game.override.moveset([ dynamaxCannon.id ]); game.override.startingLevel(200); // Note that, for Waves 1-10, the level cap is 10 @@ -36,7 +36,7 @@ describe("Moves - Dynamax Cannon", () => { game.override.disableCrits(); game.override.enemySpecies(Species.MAGIKARP); - game.override.enemyMoveset([Moves.SPLASH, Moves.SPLASH, Moves.SPLASH, Moves.SPLASH]); + game.override.enemyMoveset([ Moves.SPLASH, Moves.SPLASH, Moves.SPLASH, Moves.SPLASH ]); vi.spyOn(dynamaxCannon, "calculateBattlePower"); }); @@ -81,7 +81,7 @@ describe("Moves - Dynamax Cannon", () => { const phase = game.scene.getCurrentPhase() as MoveEffectPhase; expect(phase.move.moveId).toBe(dynamaxCannon.id); // Force level cap to be 100 - vi.spyOn(phase.getTarget()!.scene, "getMaxExpLevel").mockReturnValue(100); + vi.spyOn(phase.getFirstTarget()!.scene, "getMaxExpLevel").mockReturnValue(100); await game.phaseInterceptor.to(DamagePhase, false); expect(dynamaxCannon.calculateBattlePower).toHaveLastReturnedWith(120); }, 20000); @@ -98,7 +98,7 @@ describe("Moves - Dynamax Cannon", () => { const phase = game.scene.getCurrentPhase() as MoveEffectPhase; expect(phase.move.moveId).toBe(dynamaxCannon.id); // Force level cap to be 100 - vi.spyOn(phase.getTarget()!.scene, "getMaxExpLevel").mockReturnValue(100); + vi.spyOn(phase.getFirstTarget()!.scene, "getMaxExpLevel").mockReturnValue(100); await game.phaseInterceptor.to(DamagePhase, false); expect(dynamaxCannon.calculateBattlePower).toHaveLastReturnedWith(140); }, 20000); @@ -115,7 +115,7 @@ describe("Moves - Dynamax Cannon", () => { const phase = game.scene.getCurrentPhase() as MoveEffectPhase; expect(phase.move.moveId).toBe(dynamaxCannon.id); // Force level cap to be 100 - vi.spyOn(phase.getTarget()!.scene, "getMaxExpLevel").mockReturnValue(100); + vi.spyOn(phase.getFirstTarget()!.scene, "getMaxExpLevel").mockReturnValue(100); await game.phaseInterceptor.to(DamagePhase, false); expect(dynamaxCannon.calculateBattlePower).toHaveLastReturnedWith(160); }, 20000); @@ -132,7 +132,7 @@ describe("Moves - Dynamax Cannon", () => { const phase = game.scene.getCurrentPhase() as MoveEffectPhase; expect(phase.move.moveId).toBe(dynamaxCannon.id); // Force level cap to be 100 - vi.spyOn(phase.getTarget()!.scene, "getMaxExpLevel").mockReturnValue(100); + vi.spyOn(phase.getFirstTarget()!.scene, "getMaxExpLevel").mockReturnValue(100); await game.phaseInterceptor.to(DamagePhase, false); expect(dynamaxCannon.calculateBattlePower).toHaveLastReturnedWith(180); }, 20000); @@ -149,7 +149,7 @@ describe("Moves - Dynamax Cannon", () => { const phase = game.scene.getCurrentPhase() as MoveEffectPhase; expect(phase.move.moveId).toBe(dynamaxCannon.id); // Force level cap to be 100 - vi.spyOn(phase.getTarget()!.scene, "getMaxExpLevel").mockReturnValue(100); + vi.spyOn(phase.getFirstTarget()!.scene, "getMaxExpLevel").mockReturnValue(100); await game.phaseInterceptor.to(DamagePhase, false); expect(dynamaxCannon.calculateBattlePower).toHaveLastReturnedWith(200); }, 20000); @@ -161,7 +161,7 @@ describe("Moves - Dynamax Cannon", () => { ]); game.move.select(dynamaxCannon.id); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to(MoveEffectPhase, false); expect((game.scene.getCurrentPhase() as MoveEffectPhase).move.moveId).toBe(dynamaxCannon.id); diff --git a/src/test/moves/effectiveness.test.ts b/src/test/moves/effectiveness.test.ts index d1903c79844..829d4533f9b 100644 --- a/src/test/moves/effectiveness.test.ts +++ b/src/test/moves/effectiveness.test.ts @@ -1,7 +1,7 @@ import { allMoves } from "#app/data/move"; import { getPokemonSpecies } from "#app/data/pokemon-species"; import { TrainerSlot } from "#app/data/trainer-config"; -import { Type } from "#app/data/type"; +import { Type } from "#enums/type"; import { Abilities } from "#app/enums/abilities"; import { Moves } from "#app/enums/moves"; import { Species } from "#app/enums/species"; diff --git a/src/test/moves/electrify.test.ts b/src/test/moves/electrify.test.ts new file mode 100644 index 00000000000..8015dd0a74d --- /dev/null +++ b/src/test/moves/electrify.test.ts @@ -0,0 +1,69 @@ +import { BattlerIndex } from "#app/battle"; +import { Type } from "#enums/type"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, it, expect, vi } from "vitest"; + +describe("Moves - Electrify", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset(Moves.ELECTRIFY) + .battleType("single") + .startingLevel(100) + .enemySpecies(Species.SNORLAX) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.TACKLE) + .enemyLevel(100); + }); + + it("should convert attacks to Electric type", async () => { + await game.classicMode.startBattle([ Species.EXCADRILL ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const enemyPokemon = game.scene.getEnemyPokemon()!; + vi.spyOn(enemyPokemon, "getMoveType"); + + game.move.select(Moves.ELECTRIFY); + + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + + await game.phaseInterceptor.to("BerryPhase", false); + expect(enemyPokemon.getMoveType).toHaveLastReturnedWith(Type.ELECTRIC); + expect(playerPokemon.hp).toBe(playerPokemon.getMaxHp()); + }); + + it("should override type changes from abilities", async () => { + game.override.enemyAbility(Abilities.PIXILATE); + + await game.classicMode.startBattle([ Species.EXCADRILL ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const enemyPokemon = game.scene.getPlayerPokemon()!; + vi.spyOn(enemyPokemon, "getMoveType"); + + game.move.select(Moves.ELECTRIFY); + + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + + await game.phaseInterceptor.to("BerryPhase", false); + expect(enemyPokemon.getMoveType).toHaveLastReturnedWith(Type.ELECTRIC); + expect(playerPokemon.hp).toBe(playerPokemon.getMaxHp()); + }); +}); diff --git a/src/test/moves/electro_shot.test.ts b/src/test/moves/electro_shot.test.ts new file mode 100644 index 00000000000..283154b3408 --- /dev/null +++ b/src/test/moves/electro_shot.test.ts @@ -0,0 +1,104 @@ +import { BattlerTagType } from "#enums/battler-tag-type"; +import { Stat } from "#enums/stat"; +import { WeatherType } from "#enums/weather-type"; +import { MoveResult } from "#app/field/pokemon"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, it, expect } from "vitest"; + +describe("Moves - Electro Shot", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset(Moves.ELECTRO_SHOT) + .battleType("single") + .startingLevel(100) + .enemySpecies(Species.SNORLAX) + .enemyLevel(100) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.SPLASH); + }); + + it("should increase the user's Sp. Atk on the first turn, then attack on the second turn", async () => { + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const enemyPokemon = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.ELECTRO_SHOT); + + await game.phaseInterceptor.to("TurnEndPhase"); + expect(playerPokemon.getTag(BattlerTagType.CHARGING)).toBeDefined(); + expect(enemyPokemon.hp).toBe(enemyPokemon.getMaxHp()); + expect(playerPokemon.getLastXMoves(1)[0].result).toBe(MoveResult.OTHER); + expect(playerPokemon.getStatStage(Stat.SPATK)).toBe(1); + + await game.phaseInterceptor.to("TurnEndPhase"); + expect(playerPokemon.getTag(BattlerTagType.CHARGING)).toBeUndefined(); + expect(enemyPokemon.hp).toBeLessThan(enemyPokemon.getMaxHp()); + expect(playerPokemon.getMoveHistory()).toHaveLength(2); + expect(playerPokemon.getStatStage(Stat.SPATK)).toBe(1); + expect(playerPokemon.getLastXMoves(1)[0].result).toBe(MoveResult.SUCCESS); + + const playerElectroShot = playerPokemon.getMoveset().find(mv => mv && mv.moveId === Moves.ELECTRO_SHOT); + expect(playerElectroShot?.ppUsed).toBe(1); + }); + + it.each([ + { weatherType: WeatherType.RAIN, name: "Rain" }, + { weatherType: WeatherType.HEAVY_RAIN, name: "Heavy Rain" } + ])("should fully resolve in one turn if $name is active", async ({ weatherType }) => { + game.override.weather(weatherType); + + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const enemyPokemon = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.ELECTRO_SHOT); + + await game.phaseInterceptor.to("MoveEffectPhase", false); + expect(playerPokemon.getStatStage(Stat.SPATK)).toBe(1); + + await game.phaseInterceptor.to("MoveEndPhase"); + expect(playerPokemon.getTag(BattlerTagType.CHARGING)).toBeUndefined(); + expect(enemyPokemon.hp).toBeLessThan(enemyPokemon.getMaxHp()); + expect(playerPokemon.getMoveHistory()).toHaveLength(2); + expect(playerPokemon.getLastXMoves(1)[0].result).toBe(MoveResult.SUCCESS); + + const playerElectroShot = playerPokemon.getMoveset().find(mv => mv && mv.moveId === Moves.ELECTRO_SHOT); + expect(playerElectroShot?.ppUsed).toBe(1); + }); + + it("should only increase Sp. Atk once with Multi-Lens", async () => { + game.override + .weather(WeatherType.RAIN) + .startingHeldItems([{ name: "MULTI_LENS", count: 1 }]); + + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + + game.move.select(Moves.ELECTRO_SHOT); + + await game.phaseInterceptor.to("MoveEndPhase"); + expect(playerPokemon.turnData.hitCount).toBe(1); + expect(playerPokemon.getStatStage(Stat.SPATK)).toBe(1); + }); +}); diff --git a/src/test/moves/encore.test.ts b/src/test/moves/encore.test.ts new file mode 100644 index 00000000000..7d8dc9658bf --- /dev/null +++ b/src/test/moves/encore.test.ts @@ -0,0 +1,116 @@ +import { BattlerTagType } from "#enums/battler-tag-type"; +import { BattlerIndex } from "#app/battle"; +import { MoveResult } from "#app/field/pokemon"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; + +describe("Moves - Encore", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.SPLASH, Moves.ENCORE ]) + .ability(Abilities.BALL_FETCH) + .battleType("single") + .disableCrits() + .enemySpecies(Species.MAGIKARP) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset([ Moves.SPLASH, Moves.TACKLE ]) + .startingLevel(100) + .enemyLevel(100); + }); + + it("should prevent the target from using any move except the last used move", async () => { + await game.classicMode.startBattle([ Species.SNORLAX ]); + + const enemyPokemon = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.ENCORE); + await game.forceEnemyMove(Moves.SPLASH); + + await game.toNextTurn(); + expect(enemyPokemon.getTag(BattlerTagType.ENCORE)).toBeDefined(); + + game.move.select(Moves.SPLASH); + // The enemy AI would normally be inclined to use Tackle, but should be + // forced into using Splash. + await game.phaseInterceptor.to("BerryPhase", false); + + expect(enemyPokemon.getLastXMoves().every(turnMove => turnMove.move === Moves.SPLASH)).toBeTruthy(); + }); + + describe("should fail against the following moves:", () => { + it.each([ + { moveId: Moves.TRANSFORM, name: "Transform", delay: false }, + { moveId: Moves.MIMIC, name: "Mimic", delay: true }, + { moveId: Moves.SKETCH, name: "Sketch", delay: true }, + { moveId: Moves.ENCORE, name: "Encore", delay: false }, + { moveId: Moves.STRUGGLE, name: "Struggle", delay: false } + ])("$name", async ({ moveId, delay }) => { + game.override.enemyMoveset(moveId); + + await game.classicMode.startBattle([ Species.SNORLAX ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const enemyPokemon = game.scene.getEnemyPokemon()!; + + if (delay) { + game.move.select(Moves.SPLASH); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + await game.toNextTurn(); + } + + game.move.select(Moves.ENCORE); + + const turnOrder = delay + ? [ BattlerIndex.PLAYER, BattlerIndex.ENEMY ] + : [ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]; + await game.setTurnOrder(turnOrder); + + await game.phaseInterceptor.to("BerryPhase", false); + expect(playerPokemon.getLastXMoves(1)[0].result).toBe(MoveResult.FAIL); + expect(enemyPokemon.getTag(BattlerTagType.ENCORE)).toBeUndefined(); + }); + }); + + it("Pokemon under both Encore and Torment should alternate between Struggle and restricted move", async () => { + const turnOrder = [ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]; + game.override.moveset([ Moves.ENCORE, Moves.TORMENT, Moves.SPLASH ]); + await game.classicMode.startBattle([ Species.FEEBAS ]); + + const enemyPokemon = game.scene.getEnemyPokemon(); + game.move.select(Moves.ENCORE); + await game.setTurnOrder(turnOrder); + await game.phaseInterceptor.to("BerryPhase"); + expect(enemyPokemon?.getTag(BattlerTagType.ENCORE)).toBeDefined(); + + await game.toNextTurn(); + game.move.select(Moves.TORMENT); + await game.setTurnOrder(turnOrder); + await game.phaseInterceptor.to("BerryPhase"); + expect(enemyPokemon?.getTag(BattlerTagType.TORMENT)).toBeDefined(); + + await game.toNextTurn(); + game.move.select(Moves.SPLASH); + await game.setTurnOrder(turnOrder); + await game.phaseInterceptor.to("BerryPhase"); + const lastMove = enemyPokemon?.getLastXMoves()[0]; + expect(lastMove?.move).toBe(Moves.STRUGGLE); + }); +}); diff --git a/src/test/moves/endure.test.ts b/src/test/moves/endure.test.ts new file mode 100644 index 00000000000..bde5a26f68e --- /dev/null +++ b/src/test/moves/endure.test.ts @@ -0,0 +1,65 @@ +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; + +describe("Moves - Endure", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.THUNDER, Moves.BULLET_SEED, Moves.TOXIC ]) + .ability(Abilities.SKILL_LINK) + .startingLevel(100) + .battleType("single") + .disableCrits() + .enemySpecies(Species.MAGIKARP) + .enemyAbility(Abilities.NO_GUARD) + .enemyMoveset(Moves.ENDURE); + }); + + it("should let the pokemon survive with 1 HP", async () => { + await game.classicMode.startBattle([ Species.ARCEUS ]); + + game.move.select(Moves.THUNDER); + await game.phaseInterceptor.to("BerryPhase"); + + expect(game.scene.getEnemyPokemon()!.hp).toBe(1); + }); + + it("should let the pokemon survive with 1 HP when hit with a multihit move", async () => { + await game.classicMode.startBattle([ Species.ARCEUS ]); + + game.move.select(Moves.BULLET_SEED); + await game.phaseInterceptor.to("BerryPhase"); + + expect(game.scene.getEnemyPokemon()!.hp).toBe(1); + }); + + it("shouldn't prevent fainting from indirect damage", async () => { + game.override.enemyLevel(100); + await game.classicMode.startBattle([ Species.ARCEUS ]); + + const enemy = game.scene.getEnemyPokemon()!; + enemy.hp = 2; + + game.move.select(Moves.TOXIC); + await game.phaseInterceptor.to("VictoryPhase"); + + expect(enemy.isFainted()).toBe(true); + }); +}); diff --git a/src/test/moves/fairy_lock.test.ts b/src/test/moves/fairy_lock.test.ts new file mode 100644 index 00000000000..ceb298ed0fe --- /dev/null +++ b/src/test/moves/fairy_lock.test.ts @@ -0,0 +1,152 @@ +import { ArenaTagSide } from "#app/data/arena-tag"; +import { ArenaTagType } from "#app/enums/arena-tag-type"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; + +describe("Moves - Fairy Lock", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.FAIRY_LOCK, Moves.SPLASH ]) + .ability(Abilities.BALL_FETCH) + .battleType("double") + .disableCrits() + .enemySpecies(Species.MAGIKARP) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset([ Moves.SPLASH, Moves.U_TURN ]); + }); + + it("Applies Fairy Lock tag for two turns", async () => { + await game.classicMode.startBattle([ Species.KLEFKI, Species.TYRUNT ]); + const playerPokemon = game.scene.getPlayerField(); + const enemyField = game.scene.getEnemyField(); + + game.move.select(Moves.FAIRY_LOCK); + game.move.select(Moves.SPLASH, 1); + await game.forceEnemyMove(Moves.SPLASH, 1); + await game.forceEnemyMove(Moves.SPLASH, 1); + await game.phaseInterceptor.to("BerryPhase"); + expect(game.scene.arena.getTagOnSide(ArenaTagType.FAIRY_LOCK, ArenaTagSide.PLAYER)).toBeDefined(); + expect(game.scene.arena.getTagOnSide(ArenaTagType.FAIRY_LOCK, ArenaTagSide.ENEMY)).toBeDefined(); + + await game.toNextTurn(); + + game.move.select(Moves.SPLASH); + game.move.select(Moves.SPLASH); + await game.forceEnemyMove(Moves.SPLASH, 1); + await game.forceEnemyMove(Moves.SPLASH, 1); + await game.phaseInterceptor.to("BerryPhase"); + expect(playerPokemon[0].isTrapped()).toEqual(true); + expect(playerPokemon[1].isTrapped()).toEqual(true); + expect(enemyField[0].isTrapped()).toEqual(true); + expect(enemyField[1].isTrapped()).toEqual(true); + + await game.toNextTurn(); + expect(playerPokemon[0].isTrapped()).toEqual(false); + expect(playerPokemon[1].isTrapped()).toEqual(false); + expect(enemyField[0].isTrapped()).toEqual(false); + expect(enemyField[1].isTrapped()).toEqual(false); + }); + + it("Ghost types can escape Fairy Lock", async () => { + await game.classicMode.startBattle([ Species.DUSKNOIR, Species.GENGAR, Species.TYRUNT ]); + + game.move.select(Moves.FAIRY_LOCK); + game.move.select(Moves.SPLASH, 1); + await game.forceEnemyMove(Moves.SPLASH, 1); + await game.forceEnemyMove(Moves.SPLASH, 1); + await game.phaseInterceptor.to("BerryPhase"); + + expect(game.scene.arena.getTagOnSide(ArenaTagType.FAIRY_LOCK, ArenaTagSide.PLAYER)).toBeDefined(); + expect(game.scene.arena.getTagOnSide(ArenaTagType.FAIRY_LOCK, ArenaTagSide.ENEMY)).toBeDefined(); + + await game.toNextTurn(); + + expect(game.scene.getPlayerField()[0].isTrapped()).toEqual(false); + expect(game.scene.getPlayerField()[1].isTrapped()).toEqual(false); + + game.move.select(Moves.SPLASH); + game.doSwitchPokemon(2); + await game.forceEnemyMove(Moves.SPLASH, 1); + await game.forceEnemyMove(Moves.SPLASH, 1); + await game.phaseInterceptor.to("BerryPhase"); + await game.toNextTurn(); + + expect(game.scene.getPlayerField()[1].species.speciesId).not.toBe(Species.GENGAR); + }); + + it("Phasing moves will still switch out", async () => { + game.override.enemyMoveset([ Moves.SPLASH, Moves.WHIRLWIND ]); + await game.classicMode.startBattle([ Species.KLEFKI, Species.TYRUNT, Species.ZYGARDE ]); + + game.move.select(Moves.FAIRY_LOCK); + game.move.select(Moves.SPLASH, 1); + await game.forceEnemyMove(Moves.SPLASH, 1); + await game.forceEnemyMove(Moves.SPLASH, 1); + await game.phaseInterceptor.to("BerryPhase"); + + expect(game.scene.arena.getTagOnSide(ArenaTagType.FAIRY_LOCK, ArenaTagSide.PLAYER)).toBeDefined(); + expect(game.scene.arena.getTagOnSide(ArenaTagType.FAIRY_LOCK, ArenaTagSide.ENEMY)).toBeDefined(); + + await game.toNextTurn(); + game.move.select(Moves.SPLASH); + game.move.select(Moves.SPLASH); + await game.forceEnemyMove(Moves.WHIRLWIND, 0); + game.doSelectPartyPokemon(2); + await game.forceEnemyMove(Moves.WHIRLWIND, 1); + game.doSelectPartyPokemon(2); + await game.phaseInterceptor.to("BerryPhase"); + await game.toNextTurn(); + + expect(game.scene.getPlayerField()[0].species.speciesId).not.toBe(Species.KLEFKI); + expect(game.scene.getPlayerField()[1].species.speciesId).not.toBe(Species.TYRUNT); + }); + + it("If a Pokemon faints and is replaced the replacement is also trapped", async () => { + game.override.moveset([ Moves.FAIRY_LOCK, Moves.SPLASH, Moves.MEMENTO ]); + await game.classicMode.startBattle([ Species.KLEFKI, Species.GUZZLORD, Species.TYRUNT, Species.ZYGARDE ]); + + game.move.select(Moves.FAIRY_LOCK); + game.move.select(Moves.MEMENTO, 1); + game.doSelectPartyPokemon(2); + await game.forceEnemyMove(Moves.SPLASH, 1); + await game.forceEnemyMove(Moves.SPLASH, 1); + await game.phaseInterceptor.to("BerryPhase"); + expect(game.scene.arena.getTagOnSide(ArenaTagType.FAIRY_LOCK, ArenaTagSide.PLAYER)).toBeDefined(); + expect(game.scene.arena.getTagOnSide(ArenaTagType.FAIRY_LOCK, ArenaTagSide.ENEMY)).toBeDefined(); + + await game.toNextTurn(); + game.move.select(Moves.SPLASH); + game.move.select(Moves.SPLASH); + await game.forceEnemyMove(Moves.SPLASH, 1); + await game.forceEnemyMove(Moves.SPLASH, 1); + await game.phaseInterceptor.to("BerryPhase"); + expect(game.scene.getPlayerField()[0].isTrapped()).toEqual(true); + expect(game.scene.getPlayerField()[1].isTrapped()).toEqual(true); + expect(game.scene.getEnemyField()[0].isTrapped()).toEqual(true); + expect(game.scene.getEnemyField()[1].isTrapped()).toEqual(true); + + await game.toNextTurn(); + expect(game.scene.getPlayerField()[0].isTrapped()).toEqual(false); + expect(game.scene.getPlayerField()[1].isTrapped()).toEqual(false); + expect(game.scene.getEnemyField()[0].isTrapped()).toEqual(false); + expect(game.scene.getEnemyField()[1].isTrapped()).toEqual(false); + }); +}); diff --git a/src/test/moves/fake_out.test.ts b/src/test/moves/fake_out.test.ts index 04d6216b952..f20b6db3a13 100644 --- a/src/test/moves/fake_out.test.ts +++ b/src/test/moves/fake_out.test.ts @@ -23,14 +23,15 @@ describe("Moves - Fake Out", () => { game.override .battleType("single") .enemySpecies(Species.CORVIKNIGHT) - .starterSpecies(Species.FEEBAS) - .moveset([Moves.FAKE_OUT, Moves.SPLASH]) + .moveset([ Moves.FAKE_OUT, Moves.SPLASH ]) .enemyMoveset(Moves.SPLASH) + .enemyLevel(10) + .startingLevel(10) // prevent LevelUpPhase from happening .disableCrits(); }); - it("can only be used on the first turn a pokemon is sent out", async() => { - await game.classicMode.startBattle(); + it("can only be used on the first turn a pokemon is sent out in a battle", async() => { + await game.classicMode.startBattle([ Species.FEEBAS ]); const enemy = game.scene.getEnemyPokemon()!; @@ -44,22 +45,27 @@ describe("Moves - Fake Out", () => { await game.toNextTurn(); expect(enemy.hp).toBe(postTurnOneHp); + }, 20000); - game.move.select(Moves.SPLASH); - await game.doKillOpponents(); + // This is a PokeRogue buff to Fake Out + it("can be used at the start of every wave even if the pokemon wasn't recalled", async() => { + await game.classicMode.startBattle([ Species.FEEBAS ]); + + const enemy = game.scene.getEnemyPokemon()!; + enemy.damageAndUpdate(enemy.getMaxHp() - 1); + + game.move.select(Moves.FAKE_OUT); await game.toNextWave(); - const newEnemy = game.scene.getEnemyPokemon()!; - game.move.select(Moves.FAKE_OUT); await game.toNextTurn(); - expect(newEnemy.hp).toBe(newEnemy.getMaxHp()); + expect(game.scene.getEnemyPokemon()!.isFullHp()).toBe(false); }, 20000); it("can be used again if recalled and sent back out", async() => { game.override.startingWave(4); - await game.classicMode.startBattle(); + await game.classicMode.startBattle([ Species.FEEBAS, Species.MAGIKARP ]); const enemy1 = game.scene.getEnemyPokemon()!; @@ -76,6 +82,18 @@ describe("Moves - Fake Out", () => { const enemy2 = game.scene.getEnemyPokemon()!; + expect(enemy2.hp).toBeLessThan(enemy2.getMaxHp()); + enemy2.hp = enemy2.getMaxHp(); + + game.doSwitchPokemon(1); + await game.toNextTurn(); + + game.doSwitchPokemon(1); + await game.toNextTurn(); + + game.move.select(Moves.FAKE_OUT); + await game.toNextTurn(); + expect(enemy2.hp).toBeLessThan(enemy2.getMaxHp()); }, 20000); }); diff --git a/src/test/moves/fillet_away.test.ts b/src/test/moves/fillet_away.test.ts index 68ace42c2ec..aa3243270cb 100644 --- a/src/test/moves/fillet_away.test.ts +++ b/src/test/moves/fillet_away.test.ts @@ -7,7 +7,7 @@ import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, test } from "vitest"; -const TIMEOUT = 20 * 1000; + /** HP Cost of Move */ const RATIO = 2; /** Amount of extra HP lost */ @@ -33,7 +33,7 @@ describe("Moves - FILLET AWAY", () => { game.override.enemySpecies(Species.SNORLAX); game.override.startingLevel(100); game.override.enemyLevel(100); - game.override.moveset([Moves.FILLET_AWAY]); + game.override.moveset([ Moves.FILLET_AWAY ]); game.override.enemyMoveset(Moves.SPLASH); }); @@ -41,7 +41,7 @@ describe("Moves - FILLET AWAY", () => { test("raises the user's ATK, SPATK, and SPD stat stages by 2 each, at the cost of 1/2 of its maximum HP", async() => { - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; const hpLost = toDmgValue(leadPokemon.getMaxHp() / RATIO); @@ -53,12 +53,12 @@ describe("Moves - FILLET AWAY", () => { expect(leadPokemon.getStatStage(Stat.ATK)).toBe(2); expect(leadPokemon.getStatStage(Stat.SPATK)).toBe(2); expect(leadPokemon.getStatStage(Stat.SPD)).toBe(2); - }, TIMEOUT + } ); test("still takes effect if one or more of the involved stat stages are not at max", async() => { - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; const hpLost = toDmgValue(leadPokemon.getMaxHp() / RATIO); @@ -74,12 +74,12 @@ describe("Moves - FILLET AWAY", () => { expect(leadPokemon.getStatStage(Stat.ATK)).toBe(6); expect(leadPokemon.getStatStage(Stat.SPATK)).toBe(5); expect(leadPokemon.getStatStage(Stat.SPD)).toBe(2); - }, TIMEOUT + } ); test("fails if all stat stages involved are at max", async() => { - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -94,12 +94,12 @@ describe("Moves - FILLET AWAY", () => { expect(leadPokemon.getStatStage(Stat.ATK)).toBe(6); expect(leadPokemon.getStatStage(Stat.SPATK)).toBe(6); expect(leadPokemon.getStatStage(Stat.SPD)).toBe(6); - }, TIMEOUT + } ); test("fails if the user's health is less than 1/2", async() => { - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; const hpLost = toDmgValue(leadPokemon.getMaxHp() / RATIO); @@ -112,6 +112,6 @@ describe("Moves - FILLET AWAY", () => { expect(leadPokemon.getStatStage(Stat.ATK)).toBe(0); expect(leadPokemon.getStatStage(Stat.SPATK)).toBe(0); expect(leadPokemon.getStatStage(Stat.SPD)).toBe(0); - }, TIMEOUT + } ); }); diff --git a/src/test/moves/fissure.test.ts b/src/test/moves/fissure.test.ts index 8689ce4079e..12f075f1b55 100644 --- a/src/test/moves/fissure.test.ts +++ b/src/test/moves/fissure.test.ts @@ -32,7 +32,7 @@ describe("Moves - Fissure", () => { game.override.disableCrits(); game.override.starterSpecies(Species.SNORLAX); - game.override.moveset([Moves.FISSURE]); + game.override.moveset([ Moves.FISSURE ]); game.override.passiveAbility(Abilities.BALL_FETCH); game.override.startingLevel(100); @@ -43,7 +43,7 @@ describe("Moves - Fissure", () => { await game.startBattle(); - partyPokemon = game.scene.getParty()[0]; + partyPokemon = game.scene.getPlayerParty()[0]; enemyPokemon = game.scene.getEnemyPokemon()!; // remove berries diff --git a/src/test/moves/flame_burst.test.ts b/src/test/moves/flame_burst.test.ts index b2858af2b24..feedee3b7bc 100644 --- a/src/test/moves/flame_burst.test.ts +++ b/src/test/moves/flame_burst.test.ts @@ -36,18 +36,18 @@ describe("Moves - Flame Burst", () => { beforeEach(() => { game = new GameManager(phaserGame); game.override.battleType("double"); - game.override.moveset([Moves.FLAME_BURST, Moves.SPLASH]); + game.override.moveset([ Moves.FLAME_BURST, Moves.SPLASH ]); game.override.disableCrits(); game.override.ability(Abilities.UNNERVE); game.override.startingWave(4); game.override.enemySpecies(Species.SHUCKLE); game.override.enemyAbility(Abilities.BALL_FETCH); - game.override.enemyMoveset([Moves.SPLASH]); + game.override.enemyMoveset([ Moves.SPLASH ]); }); it("inflicts damage to the target's ally equal to 1/16 of its max HP", async () => { - await game.startBattle([Species.PIKACHU, Species.PIKACHU]); - const [leftEnemy, rightEnemy] = game.scene.getEnemyField(); + await game.startBattle([ Species.PIKACHU, Species.PIKACHU ]); + const [ leftEnemy, rightEnemy ] = game.scene.getEnemyField(); game.move.select(Moves.FLAME_BURST, 0, leftEnemy.getBattlerIndex()); game.move.select(Moves.SPLASH, 1); @@ -60,8 +60,8 @@ describe("Moves - Flame Burst", () => { it("does not inflict damage to the target's ally if the target was not affected by Flame Burst", async () => { game.override.enemyAbility(Abilities.FLASH_FIRE); - await game.startBattle([Species.PIKACHU, Species.PIKACHU]); - const [leftEnemy, rightEnemy] = game.scene.getEnemyField(); + await game.startBattle([ Species.PIKACHU, Species.PIKACHU ]); + const [ leftEnemy, rightEnemy ] = game.scene.getEnemyField(); game.move.select(Moves.FLAME_BURST, 0, leftEnemy.getBattlerIndex()); game.move.select(Moves.SPLASH, 1); @@ -72,8 +72,8 @@ describe("Moves - Flame Burst", () => { }); it("does not interact with the target ally's abilities", async () => { - await game.startBattle([Species.PIKACHU, Species.PIKACHU]); - const [leftEnemy, rightEnemy] = game.scene.getEnemyField(); + await game.startBattle([ Species.PIKACHU, Species.PIKACHU ]); + const [ leftEnemy, rightEnemy ] = game.scene.getEnemyField(); vi.spyOn(rightEnemy, "getAbility").mockReturnValue(allAbilities[Abilities.FLASH_FIRE]); @@ -86,8 +86,8 @@ describe("Moves - Flame Burst", () => { }); it("effect damage is prevented by Magic Guard", async () => { - await game.startBattle([Species.PIKACHU, Species.PIKACHU]); - const [leftEnemy, rightEnemy] = game.scene.getEnemyField(); + await game.startBattle([ Species.PIKACHU, Species.PIKACHU ]); + const [ leftEnemy, rightEnemy ] = game.scene.getEnemyField(); vi.spyOn(rightEnemy, "getAbility").mockReturnValue(allAbilities[Abilities.MAGIC_GUARD]); diff --git a/src/test/moves/flower_shield.test.ts b/src/test/moves/flower_shield.test.ts index f5fe8d532cc..4c03df5212b 100644 --- a/src/test/moves/flower_shield.test.ts +++ b/src/test/moves/flower_shield.test.ts @@ -1,6 +1,6 @@ import { Stat } from "#enums/stat"; import { SemiInvulnerableTag } from "#app/data/battler-tags"; -import { Type } from "#app/data/type"; +import { Type } from "#enums/type"; import { Biome } from "#app/enums/biome"; import { TurnEndPhase } from "#app/phases/turn-end-phase"; import { Abilities } from "#enums/abilities"; @@ -29,14 +29,14 @@ describe("Moves - Flower Shield", () => { game.override.ability(Abilities.NONE); game.override.enemyAbility(Abilities.NONE); game.override.battleType("single"); - game.override.moveset([Moves.FLOWER_SHIELD, Moves.SPLASH]); + game.override.moveset([ Moves.FLOWER_SHIELD, Moves.SPLASH ]); game.override.enemyMoveset(Moves.SPLASH); }); it("raises DEF stat stage by 1 for all Grass-type Pokemon on the field by one stage - single battle", async () => { game.override.enemySpecies(Species.CHERRIM); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const cherrim = game.scene.getEnemyPokemon()!; const magikarp = game.scene.getPlayerPokemon()!; @@ -53,7 +53,7 @@ describe("Moves - Flower Shield", () => { it("raises DEF stat stage by 1 for all Grass-type Pokemon on the field by one stage - double battle", async () => { game.override.enemySpecies(Species.MAGIKARP).startingBiome(Biome.GRASS).battleType("double"); - await game.startBattle([Species.CHERRIM, Species.MAGIKARP]); + await game.startBattle([ Species.CHERRIM, Species.MAGIKARP ]); const field = game.scene.getField(true); const grassPokemons = field.filter(p => p.getTypes().includes(Type.GRASS)); @@ -75,10 +75,10 @@ describe("Moves - Flower Shield", () => { */ it("does not raise DEF stat stage for a Pokemon in semi-vulnerable state", async () => { game.override.enemySpecies(Species.PARAS); - game.override.enemyMoveset([Moves.DIG, Moves.DIG, Moves.DIG, Moves.DIG]); + game.override.enemyMoveset([ Moves.DIG, Moves.DIG, Moves.DIG, Moves.DIG ]); game.override.enemyLevel(50); - await game.startBattle([Species.CHERRIM]); + await game.startBattle([ Species.CHERRIM ]); const paras = game.scene.getEnemyPokemon()!; const cherrim = game.scene.getPlayerPokemon()!; @@ -97,7 +97,7 @@ describe("Moves - Flower Shield", () => { it("does nothing if there are no Grass-type Pokemon on the field", async () => { game.override.enemySpecies(Species.MAGIKARP); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const enemy = game.scene.getEnemyPokemon()!; const ally = game.scene.getPlayerPokemon()!; diff --git a/src/test/moves/fly.test.ts b/src/test/moves/fly.test.ts new file mode 100644 index 00000000000..6ae758fe3dc --- /dev/null +++ b/src/test/moves/fly.test.ts @@ -0,0 +1,122 @@ +import { BattlerTagType } from "#enums/battler-tag-type"; +import { StatusEffect } from "#enums/status-effect"; +import { MoveResult } from "#app/field/pokemon"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, it, expect, vi } from "vitest"; +import { BattlerIndex } from "#app/battle"; +import { allMoves } from "#app/data/move"; + +describe("Moves - Fly", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset(Moves.FLY) + .battleType("single") + .startingLevel(100) + .enemySpecies(Species.SNORLAX) + .enemyLevel(100) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.TACKLE); + + vi.spyOn(allMoves[Moves.FLY], "accuracy", "get").mockReturnValue(100); + }); + + it("should make the user semi-invulnerable, then attack over 2 turns", async () => { + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const enemyPokemon = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.FLY); + + await game.phaseInterceptor.to("TurnEndPhase"); + expect(playerPokemon.getTag(BattlerTagType.FLYING)).toBeDefined(); + expect(enemyPokemon.getLastXMoves(1)[0].result).toBe(MoveResult.MISS); + expect(playerPokemon.hp).toBe(playerPokemon.getMaxHp()); + expect(enemyPokemon.hp).toBe(enemyPokemon.getMaxHp()); + expect(playerPokemon.getMoveQueue()[0].move).toBe(Moves.FLY); + + await game.phaseInterceptor.to("TurnEndPhase"); + expect(playerPokemon.getTag(BattlerTagType.FLYING)).toBeUndefined(); + expect(enemyPokemon.hp).toBeLessThan(enemyPokemon.getMaxHp()); + expect(playerPokemon.getMoveHistory()).toHaveLength(2); + + const playerFly = playerPokemon.getMoveset().find(mv => mv && mv.moveId === Moves.FLY); + expect(playerFly?.ppUsed).toBe(1); + }); + + it("should not allow the user to evade attacks from Pokemon with No Guard", async () => { + game.override.enemyAbility(Abilities.NO_GUARD); + + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const enemyPokemon = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.FLY); + + await game.phaseInterceptor.to("TurnEndPhase"); + expect(playerPokemon.hp).toBeLessThan(playerPokemon.getMaxHp()); + expect(enemyPokemon.getLastXMoves(1)[0].result).toBe(MoveResult.SUCCESS); + }); + + it("should not expend PP when the attack phase is cancelled", async () => { + game.override + .enemyAbility(Abilities.NO_GUARD) + .enemyMoveset(Moves.SPORE); + + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + + game.move.select(Moves.FLY); + + await game.phaseInterceptor.to("TurnEndPhase"); + expect(playerPokemon.getTag(BattlerTagType.FLYING)).toBeUndefined(); + expect(playerPokemon.status?.effect).toBe(StatusEffect.SLEEP); + + const playerFly = playerPokemon.getMoveset().find(mv => mv && mv.moveId === Moves.FLY); + expect(playerFly?.ppUsed).toBe(0); + }); + + it("should be cancelled when another Pokemon uses Gravity", async () => { + game.override.enemyMoveset([ Moves.SPLASH, Moves.GRAVITY ]); + + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const enemyPokemon = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.FLY); + + await game.forceEnemyMove(Moves.SPLASH); + + await game.toNextTurn(); + await game.forceEnemyMove(Moves.GRAVITY); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); + + await game.phaseInterceptor.to("TurnEndPhase"); + expect(playerPokemon.getLastXMoves(1)[0].result).toBe(MoveResult.FAIL); + expect(enemyPokemon.hp).toBe(enemyPokemon.getMaxHp()); + + const playerFly = playerPokemon.getMoveset().find(mv => mv && mv.moveId === Moves.FLY); + expect(playerFly?.ppUsed).toBe(0); + }); +}); diff --git a/src/test/moves/focus_punch.test.ts b/src/test/moves/focus_punch.test.ts index ca80c688169..352e3b60aa4 100644 --- a/src/test/moves/focus_punch.test.ts +++ b/src/test/moves/focus_punch.test.ts @@ -10,7 +10,6 @@ import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Moves - Focus Punch", () => { let phaserGame: Phaser.Game; @@ -31,7 +30,7 @@ describe("Moves - Focus Punch", () => { game.override .battleType("single") .ability(Abilities.UNNERVE) - .moveset([Moves.FOCUS_PUNCH]) + .moveset([ Moves.FOCUS_PUNCH ]) .enemySpecies(Species.GROUDON) .enemyAbility(Abilities.INSOMNIA) .enemyMoveset(Moves.SPLASH) @@ -42,7 +41,7 @@ describe("Moves - Focus Punch", () => { it( "should deal damage at the end of turn if uninterrupted", async () => { - await game.startBattle([Species.CHARIZARD]); + await game.startBattle([ Species.CHARIZARD ]); const leadPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -60,16 +59,16 @@ describe("Moves - Focus Punch", () => { expect(enemyPokemon.hp).toBeLessThan(enemyStartingHp); expect(leadPokemon.getMoveHistory().length).toBe(1); - expect(leadPokemon.turnData.damageDealt).toBe(enemyStartingHp - enemyPokemon.hp); - }, TIMEOUT + expect(leadPokemon.turnData.totalDamageDealt).toBe(enemyStartingHp - enemyPokemon.hp); + } ); it( "should fail if the user is hit", async () => { - game.override.enemyMoveset([Moves.TACKLE]); + game.override.enemyMoveset([ Moves.TACKLE ]); - await game.startBattle([Species.CHARIZARD]); + await game.startBattle([ Species.CHARIZARD ]); const leadPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -87,16 +86,16 @@ describe("Moves - Focus Punch", () => { expect(enemyPokemon.hp).toBe(enemyStartingHp); expect(leadPokemon.getMoveHistory().length).toBe(1); - expect(leadPokemon.turnData.damageDealt).toBe(0); - }, TIMEOUT + expect(leadPokemon.turnData.totalDamageDealt).toBe(0); + } ); it( "should be cancelled if the user falls asleep mid-turn", async () => { - game.override.enemyMoveset([Moves.SPORE]); + game.override.enemyMoveset([ Moves.SPORE ]); - await game.startBattle([Species.CHARIZARD]); + await game.startBattle([ Species.CHARIZARD ]); const leadPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -111,7 +110,7 @@ describe("Moves - Focus Punch", () => { expect(leadPokemon.getMoveHistory().length).toBe(1); expect(enemyPokemon.hp).toBe(enemyPokemon.getMaxHp()); - }, TIMEOUT + } ); it( @@ -120,7 +119,7 @@ describe("Moves - Focus Punch", () => { /** Guarantee a Trainer battle with multiple enemy Pokemon */ game.override.startingWave(25); - await game.startBattle([Species.CHARIZARD]); + await game.startBattle([ Species.CHARIZARD ]); game.forceEnemyToSwitch(); game.move.select(Moves.FOCUS_PUNCH); @@ -129,6 +128,6 @@ describe("Moves - Focus Punch", () => { expect(game.scene.getCurrentPhase() instanceof SwitchSummonPhase).toBeTruthy(); expect(game.scene.phaseQueue.find(phase => phase instanceof MoveHeaderPhase)).toBeDefined(); - }, TIMEOUT + } ); }); diff --git a/src/test/moves/follow_me.test.ts b/src/test/moves/follow_me.test.ts index 7d0c4fdb546..fba7937f812 100644 --- a/src/test/moves/follow_me.test.ts +++ b/src/test/moves/follow_me.test.ts @@ -8,7 +8,6 @@ import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, test } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Moves - Follow Me", () => { let phaserGame: Phaser.Game; @@ -32,14 +31,14 @@ describe("Moves - Follow Me", () => { game.override.enemySpecies(Species.SNORLAX); game.override.startingLevel(100); game.override.enemyLevel(100); - game.override.moveset([Moves.FOLLOW_ME, Moves.RAGE_POWDER, Moves.SPOTLIGHT, Moves.QUICK_ATTACK]); - game.override.enemyMoveset([Moves.TACKLE, Moves.FOLLOW_ME, Moves.SPLASH]); + game.override.moveset([ Moves.FOLLOW_ME, Moves.RAGE_POWDER, Moves.SPOTLIGHT, Moves.QUICK_ATTACK ]); + game.override.enemyMoveset([ Moves.TACKLE, Moves.FOLLOW_ME, Moves.SPLASH ]); }); test( "move should redirect enemy attacks to the user", async () => { - await game.classicMode.startBattle([Species.AMOONGUSS, Species.CHARIZARD]); + await game.classicMode.startBattle([ Species.AMOONGUSS, Species.CHARIZARD ]); const playerPokemon = game.scene.getPlayerField(); @@ -54,13 +53,13 @@ describe("Moves - Follow Me", () => { expect(playerPokemon[0].hp).toBeLessThan(playerPokemon[0].getMaxHp()); expect(playerPokemon[1].hp).toBe(playerPokemon[1].getMaxHp()); - }, TIMEOUT + } ); test( "move should redirect enemy attacks to the first ally that uses it", async () => { - await game.classicMode.startBattle([Species.AMOONGUSS, Species.CHARIZARD]); + await game.classicMode.startBattle([ Species.AMOONGUSS, Species.CHARIZARD ]); const playerPokemon = game.scene.getPlayerField(); @@ -77,16 +76,16 @@ describe("Moves - Follow Me", () => { expect(playerPokemon[1].hp).toBeLessThan(playerPokemon[1].getMaxHp()); expect(playerPokemon[0].hp).toBe(playerPokemon[0].getMaxHp()); - }, TIMEOUT + } ); test( "move effect should be bypassed by Stalwart", async () => { game.override.ability(Abilities.STALWART); - game.override.moveset([Moves.QUICK_ATTACK]); + game.override.moveset([ Moves.QUICK_ATTACK ]); - await game.classicMode.startBattle([Species.AMOONGUSS, Species.CHARIZARD]); + await game.classicMode.startBattle([ Species.AMOONGUSS, Species.CHARIZARD ]); const enemyPokemon = game.scene.getEnemyField(); @@ -102,15 +101,15 @@ describe("Moves - Follow Me", () => { // If redirection was bypassed, both enemies should be damaged expect(enemyPokemon[0].hp).toBeLessThan(enemyPokemon[0].getMaxHp()); expect(enemyPokemon[1].hp).toBeLessThan(enemyPokemon[1].getMaxHp()); - }, TIMEOUT + } ); test( "move effect should be bypassed by Snipe Shot", async () => { - game.override.moveset([Moves.SNIPE_SHOT]); + game.override.moveset([ Moves.SNIPE_SHOT ]); - await game.classicMode.startBattle([Species.AMOONGUSS, Species.CHARIZARD]); + await game.classicMode.startBattle([ Species.AMOONGUSS, Species.CHARIZARD ]); const enemyPokemon = game.scene.getEnemyField(); @@ -125,6 +124,6 @@ describe("Moves - Follow Me", () => { // If redirection was bypassed, both enemies should be damaged expect(enemyPokemon[0].hp).toBeLessThan(enemyPokemon[0].getMaxHp()); expect(enemyPokemon[1].hp).toBeLessThan(enemyPokemon[1].getMaxHp()); - }, TIMEOUT + } ); }); diff --git a/src/test/moves/foresight.test.ts b/src/test/moves/foresight.test.ts index d58097691fd..1195cd0b71b 100644 --- a/src/test/moves/foresight.test.ts +++ b/src/test/moves/foresight.test.ts @@ -27,7 +27,7 @@ describe("Moves - Foresight", () => { .enemyMoveset(Moves.SPLASH) .enemyLevel(5) .starterSpecies(Species.MAGIKARP) - .moveset([Moves.FORESIGHT, Moves.QUICK_ATTACK, Moves.MACH_PUNCH]); + .moveset([ Moves.FORESIGHT, Moves.QUICK_ATTACK, Moves.MACH_PUNCH ]); }); it("should allow Normal and Fighting moves to hit Ghost types", async () => { @@ -54,7 +54,7 @@ describe("Moves - Foresight", () => { }); it("should ignore target's evasiveness boosts", async () => { - game.override.enemyMoveset([Moves.MINIMIZE]); + game.override.enemyMoveset([ Moves.MINIMIZE ]); await game.startBattle(); const pokemon = game.scene.getPlayerPokemon()!; diff --git a/src/test/moves/forests_curse.test.ts b/src/test/moves/forests_curse.test.ts new file mode 100644 index 00000000000..010b00599a5 --- /dev/null +++ b/src/test/moves/forests_curse.test.ts @@ -0,0 +1,47 @@ +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import { Type } from "#enums/type"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; + +describe("Moves - Forest's Curse", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.FORESTS_CURSE, Moves.TRICK_OR_TREAT ]) + .ability(Abilities.BALL_FETCH) + .battleType("single") + .disableCrits() + .enemySpecies(Species.MAGIKARP) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.SPLASH); + }); + + it("will replace the added type from Trick Or Treat", async () => { + await game.classicMode.startBattle([ Species.FEEBAS ]); + + const enemyPokemon = game.scene.getEnemyPokemon(); + game.move.select(Moves.TRICK_OR_TREAT); + await game.phaseInterceptor.to("TurnEndPhase"); + expect(enemyPokemon!.summonData.addedType).toBe(Type.GHOST); + + game.move.select(Moves.FORESTS_CURSE); + await game.phaseInterceptor.to("TurnEndPhase"); + expect(enemyPokemon?.summonData.addedType).toBe(Type.GRASS); + }); +}); diff --git a/src/test/moves/freeze_dry.test.ts b/src/test/moves/freeze_dry.test.ts index ff9e2f07162..9206a103a35 100644 --- a/src/test/moves/freeze_dry.test.ts +++ b/src/test/moves/freeze_dry.test.ts @@ -2,6 +2,8 @@ import { BattlerIndex } from "#app/battle"; import { Abilities } from "#app/enums/abilities"; import { Moves } from "#app/enums/moves"; import { Species } from "#app/enums/species"; +import { Type } from "#enums/type"; +import { Challenges } from "#enums/challenges"; import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; @@ -9,8 +11,6 @@ import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vite describe("Moves - Freeze-Dry", () => { let phaserGame: Phaser.Game; let game: GameManager; - const TIMEOUT = 20 * 1000; - beforeAll(() => { phaserGame = new Phaser.Game({ type: Phaser.HEADLESS, @@ -30,7 +30,7 @@ describe("Moves - Freeze-Dry", () => { .enemyMoveset(Moves.SPLASH) .starterSpecies(Species.FEEBAS) .ability(Abilities.BALL_FETCH) - .moveset([Moves.FREEZE_DRY]); + .moveset([ Moves.FREEZE_DRY, Moves.FORESTS_CURSE, Moves.SOAK ]); }); it("should deal 2x damage to pure water types", async () => { @@ -40,11 +40,11 @@ describe("Moves - Freeze-Dry", () => { vi.spyOn(enemy, "getMoveEffectiveness"); game.move.select(Moves.FREEZE_DRY); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to("MoveEffectPhase"); expect(enemy.getMoveEffectiveness).toHaveReturnedWith(2); - }, TIMEOUT); + }); it("should deal 4x damage to water/flying types", async () => { game.override.enemySpecies(Species.WINGULL); @@ -54,11 +54,11 @@ describe("Moves - Freeze-Dry", () => { vi.spyOn(enemy, "getMoveEffectiveness"); game.move.select(Moves.FREEZE_DRY); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to("MoveEffectPhase"); expect(enemy.getMoveEffectiveness).toHaveReturnedWith(4); - }, TIMEOUT); + }); it("should deal 1x damage to water/fire types", async () => { game.override.enemySpecies(Species.VOLCANION); @@ -68,14 +68,103 @@ describe("Moves - Freeze-Dry", () => { vi.spyOn(enemy, "getMoveEffectiveness"); game.move.select(Moves.FREEZE_DRY); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to("MoveEffectPhase"); expect(enemy.getMoveEffectiveness).toHaveReturnedWith(1); - }, TIMEOUT); + }); - // enable if this is ever fixed (lol) - it.todo("should deal 2x damage to water types under Normalize", async () => { + /** + * Freeze drys forced super effectiveness should overwrite wonder guard + */ + it("should deal 2x dmg against soaked wonder guard target", async () => { + game.override + .enemySpecies(Species.SHEDINJA) + .enemyMoveset(Moves.SPLASH) + .starterSpecies(Species.MAGIKARP) + .moveset([ Moves.SOAK, Moves.FREEZE_DRY ]); + await game.classicMode.startBattle(); + + const enemy = game.scene.getEnemyPokemon()!; + vi.spyOn(enemy, "getMoveEffectiveness"); + + game.move.select(Moves.SOAK); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + await game.toNextTurn(); + + game.move.select(Moves.FREEZE_DRY); + await game.phaseInterceptor.to("MoveEffectPhase"); + + expect(enemy.getMoveEffectiveness).toHaveReturnedWith(2); + expect(enemy.hp).toBeLessThan(enemy.getMaxHp()); + }); + + it("should deal 8x damage to water/ground/grass type under Forest's Curse", async () => { + game.override.enemySpecies(Species.QUAGSIRE); + await game.classicMode.startBattle(); + + const enemy = game.scene.getEnemyPokemon()!; + vi.spyOn(enemy, "getMoveEffectiveness"); + + game.move.select(Moves.FORESTS_CURSE); + await game.toNextTurn(); + + game.move.select(Moves.FREEZE_DRY); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + await game.phaseInterceptor.to("MoveEffectPhase"); + + expect(enemy.getMoveEffectiveness).toHaveReturnedWith(8); + }); + + it("should deal 2x damage to steel type terastallized into water", async () => { + game.override.enemySpecies(Species.SKARMORY) + .enemyHeldItems([{ name: "TERA_SHARD", type: Type.WATER }]); + await game.classicMode.startBattle(); + + const enemy = game.scene.getEnemyPokemon()!; + vi.spyOn(enemy, "getMoveEffectiveness"); + + game.move.select(Moves.FREEZE_DRY); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + await game.phaseInterceptor.to("MoveEffectPhase"); + + expect(enemy.getMoveEffectiveness).toHaveReturnedWith(2); + }); + + it("should deal 0.5x damage to water type terastallized into fire", async () => { + game.override.enemySpecies(Species.PELIPPER) + .enemyHeldItems([{ name: "TERA_SHARD", type: Type.FIRE }]); + await game.classicMode.startBattle(); + + const enemy = game.scene.getEnemyPokemon()!; + vi.spyOn(enemy, "getMoveEffectiveness"); + + game.move.select(Moves.FREEZE_DRY); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + await game.phaseInterceptor.to("MoveEffectPhase"); + + expect(enemy.getMoveEffectiveness).toHaveReturnedWith(0.5); + }); + + it("should deal 0.5x damage to water type Terapagos with Tera Shell", async () => { + game.override.enemySpecies(Species.TERAPAGOS) + .enemyAbility(Abilities.TERA_SHELL); + await game.classicMode.startBattle(); + + const enemy = game.scene.getEnemyPokemon()!; + vi.spyOn(enemy, "getMoveEffectiveness"); + + game.move.select(Moves.SOAK); + await game.toNextTurn(); + + game.move.select(Moves.FREEZE_DRY); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + await game.phaseInterceptor.to("MoveEffectPhase"); + + expect(enemy.getMoveEffectiveness).toHaveReturnedWith(0.5); + }); + + it("should deal 2x damage to water type under Normalize", async () => { game.override.ability(Abilities.NORMALIZE); await game.classicMode.startBattle(); @@ -83,24 +172,179 @@ describe("Moves - Freeze-Dry", () => { vi.spyOn(enemy, "getMoveEffectiveness"); game.move.select(Moves.FREEZE_DRY); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to("MoveEffectPhase"); expect(enemy.getMoveEffectiveness).toHaveReturnedWith(2); - }, TIMEOUT); + }); - // enable once Electrify is implemented (and the interaction is fixed, as above) - it.todo("should deal 2x damage to water types under Electrify", async () => { - game.override.enemyMoveset([Moves.ELECTRIFY]); + it("should deal 0.25x damage to rock/steel type under Normalize", async () => { + game.override + .ability(Abilities.NORMALIZE) + .enemySpecies(Species.SHIELDON); await game.classicMode.startBattle(); const enemy = game.scene.getEnemyPokemon()!; vi.spyOn(enemy, "getMoveEffectiveness"); game.move.select(Moves.FREEZE_DRY); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + await game.phaseInterceptor.to("MoveEffectPhase"); + + expect(enemy.getMoveEffectiveness).toHaveReturnedWith(0.25); + }); + + it("should deal 0x damage to water/ghost type under Normalize", async () => { + game.override + .ability(Abilities.NORMALIZE) + .enemySpecies(Species.JELLICENT); + await game.classicMode.startBattle(); + + const enemy = game.scene.getEnemyPokemon()!; + vi.spyOn(enemy, "getMoveEffectiveness"); + + game.move.select(Moves.FREEZE_DRY); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + await game.phaseInterceptor.to("BerryPhase"); + + expect(enemy.getMoveEffectiveness).toHaveReturnedWith(0); + }); + + it("should deal 2x damage to water type under Electrify", async () => { + game.override.enemyMoveset([ Moves.ELECTRIFY ]); + await game.classicMode.startBattle(); + + const enemy = game.scene.getEnemyPokemon()!; + vi.spyOn(enemy, "getMoveEffectiveness"); + + game.move.select(Moves.FREEZE_DRY); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); await game.phaseInterceptor.to("BerryPhase"); expect(enemy.getMoveEffectiveness).toHaveReturnedWith(2); - }, TIMEOUT); + }); + + it("should deal 4x damage to water/flying type under Electrify", async () => { + game.override + .enemyMoveset([ Moves.ELECTRIFY ]) + .enemySpecies(Species.GYARADOS); + await game.classicMode.startBattle(); + + const enemy = game.scene.getEnemyPokemon()!; + vi.spyOn(enemy, "getMoveEffectiveness"); + + game.move.select(Moves.FREEZE_DRY); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); + await game.phaseInterceptor.to("BerryPhase"); + + expect(enemy.getMoveEffectiveness).toHaveReturnedWith(4); + }); + + it("should deal 0x damage to water/ground type under Electrify", async () => { + game.override + .enemyMoveset([ Moves.ELECTRIFY ]) + .enemySpecies(Species.BARBOACH); + await game.classicMode.startBattle(); + + const enemy = game.scene.getEnemyPokemon()!; + vi.spyOn(enemy, "getMoveEffectiveness"); + + game.move.select(Moves.FREEZE_DRY); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); + await game.phaseInterceptor.to("BerryPhase"); + + expect(enemy.getMoveEffectiveness).toHaveReturnedWith(0); + }); + + it("should deal 0.25x damage to Grass/Dragon type under Electrify", async () => { + game.override + .enemyMoveset([ Moves.ELECTRIFY ]) + .enemySpecies(Species.FLAPPLE); + await game.classicMode.startBattle(); + + const enemy = game.scene.getEnemyPokemon()!; + vi.spyOn(enemy, "getMoveEffectiveness"); + + game.move.select(Moves.FREEZE_DRY); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); + await game.phaseInterceptor.to("BerryPhase"); + + expect(enemy.getMoveEffectiveness).toHaveReturnedWith(0.25); + }); + + it("should deal 2x damage to Water type during inverse battle", async () => { + game.override + .moveset([ Moves.FREEZE_DRY ]) + .enemySpecies(Species.MAGIKARP); + game.challengeMode.addChallenge(Challenges.INVERSE_BATTLE, 1, 1); + + + await game.challengeMode.startBattle(); + + const enemy = game.scene.getEnemyPokemon()!; + vi.spyOn(enemy, "getMoveEffectiveness"); + + game.move.select(Moves.FREEZE_DRY); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + await game.phaseInterceptor.to("MoveEffectPhase"); + + expect(enemy.getMoveEffectiveness).toHaveLastReturnedWith(2); + }); + + it("should deal 2x damage to Water type during inverse battle under Normalize", async () => { + game.override + .moveset([ Moves.FREEZE_DRY ]) + .ability(Abilities.NORMALIZE) + .enemySpecies(Species.MAGIKARP); + game.challengeMode.addChallenge(Challenges.INVERSE_BATTLE, 1, 1); + + await game.challengeMode.startBattle(); + + const enemy = game.scene.getEnemyPokemon()!; + vi.spyOn(enemy, "getMoveEffectiveness"); + + game.move.select(Moves.FREEZE_DRY); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + await game.phaseInterceptor.to("MoveEffectPhase"); + + expect(enemy.getMoveEffectiveness).toHaveLastReturnedWith(2); + }); + + it("should deal 2x damage to Water type during inverse battle under Electrify", async () => { + game.override + .moveset([ Moves.FREEZE_DRY ]) + .enemySpecies(Species.MAGIKARP) + .enemyMoveset([ Moves.ELECTRIFY ]); + game.challengeMode.addChallenge(Challenges.INVERSE_BATTLE, 1, 1); + + await game.challengeMode.startBattle(); + + const enemy = game.scene.getEnemyPokemon()!; + vi.spyOn(enemy, "getMoveEffectiveness"); + + game.move.select(Moves.FREEZE_DRY); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); + await game.phaseInterceptor.to("MoveEffectPhase"); + + expect(enemy.getMoveEffectiveness).toHaveLastReturnedWith(2); + }); + + it("should deal 1x damage to water/flying type during inverse battle under Electrify", async () => { + game.override + .enemyMoveset([ Moves.ELECTRIFY ]) + .enemySpecies(Species.GYARADOS); + + game.challengeMode.addChallenge(Challenges.INVERSE_BATTLE, 1, 1); + + await game.challengeMode.startBattle(); + + const enemy = game.scene.getEnemyPokemon()!; + vi.spyOn(enemy, "getMoveEffectiveness"); + + game.move.select(Moves.FREEZE_DRY); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); + await game.phaseInterceptor.to("BerryPhase"); + + expect(enemy.getMoveEffectiveness).toHaveReturnedWith(1); + }); }); diff --git a/src/test/moves/freezy_frost.test.ts b/src/test/moves/freezy_frost.test.ts index ad5163dae48..09d7779474f 100644 --- a/src/test/moves/freezy_frost.test.ts +++ b/src/test/moves/freezy_frost.test.ts @@ -33,7 +33,7 @@ describe("Moves - Freezy Frost", () => { .moveset([ Moves.FREEZY_FROST, Moves.HOWL, Moves.SPLASH ]) .ability(Abilities.BALL_FETCH); - vi.spyOn(allMoves[ Moves.FREEZY_FROST ], "accuracy", "get").mockReturnValue(100); + vi.spyOn(allMoves[Moves.FREEZY_FROST], "accuracy", "get").mockReturnValue(100); }); it( diff --git a/src/test/moves/fusion_bolt.test.ts b/src/test/moves/fusion_bolt.test.ts index db31863ad03..4e35b939abf 100644 --- a/src/test/moves/fusion_bolt.test.ts +++ b/src/test/moves/fusion_bolt.test.ts @@ -23,12 +23,12 @@ describe("Moves - Fusion Bolt", () => { beforeEach(() => { game = new GameManager(phaserGame); - game.override.moveset([fusionBolt]); + game.override.moveset([ fusionBolt ]); game.override.startingLevel(1); game.override.enemySpecies(Species.RESHIRAM); game.override.enemyAbility(Abilities.ROUGH_SKIN); - game.override.enemyMoveset([Moves.SPLASH, Moves.SPLASH, Moves.SPLASH, Moves.SPLASH]); + game.override.enemyMoveset([ Moves.SPLASH, Moves.SPLASH, Moves.SPLASH, Moves.SPLASH ]); game.override.battleType("single"); game.override.startingWave(97); diff --git a/src/test/moves/fusion_flare.test.ts b/src/test/moves/fusion_flare.test.ts index 0a8f6f9115d..75641c04d02 100644 --- a/src/test/moves/fusion_flare.test.ts +++ b/src/test/moves/fusion_flare.test.ts @@ -1,7 +1,7 @@ -import { StatusEffect } from "#app/data/status-effect"; import { TurnStartPhase } from "#app/phases/turn-start-phase"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; +import { StatusEffect } from "#enums/status-effect"; import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; @@ -24,11 +24,11 @@ describe("Moves - Fusion Flare", () => { beforeEach(() => { game = new GameManager(phaserGame); - game.override.moveset([fusionFlare]); + game.override.moveset([ fusionFlare ]); game.override.startingLevel(1); game.override.enemySpecies(Species.RATTATA); - game.override.enemyMoveset([Moves.REST, Moves.REST, Moves.REST, Moves.REST]); + game.override.enemyMoveset([ Moves.REST, Moves.REST, Moves.REST, Moves.REST ]); game.override.battleType("single"); game.override.startingWave(97); diff --git a/src/test/moves/fusion_flare_bolt.test.ts b/src/test/moves/fusion_flare_bolt.test.ts index a8372fcaaab..1bcd0514357 100644 --- a/src/test/moves/fusion_flare_bolt.test.ts +++ b/src/test/moves/fusion_flare_bolt.test.ts @@ -30,11 +30,11 @@ describe("Moves - Fusion Flare and Fusion Bolt", () => { beforeEach(() => { game = new GameManager(phaserGame); - game.override.moveset([fusionFlare.id, fusionBolt.id]); + game.override.moveset([ fusionFlare.id, fusionBolt.id ]); game.override.startingLevel(1); game.override.enemySpecies(Species.RESHIRAM); - game.override.enemyMoveset([Moves.REST, Moves.REST, Moves.REST, Moves.REST]); + game.override.enemyMoveset([ Moves.REST, Moves.REST, Moves.REST, Moves.REST ]); game.override.battleType("double"); game.override.startingWave(97); @@ -54,7 +54,7 @@ describe("Moves - Fusion Flare and Fusion Bolt", () => { game.move.select(fusionBolt.id, 1, BattlerIndex.ENEMY); // Force user party to act before enemy party - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2 ]); await game.phaseInterceptor.to(MoveEffectPhase, false); expect((game.scene.getCurrentPhase() as MoveEffectPhase).move.moveId).toBe(fusionFlare.id); @@ -77,7 +77,7 @@ describe("Moves - Fusion Flare and Fusion Bolt", () => { game.move.select(fusionFlare.id, 1, BattlerIndex.ENEMY); // Force user party to act before enemy party - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2 ]); await game.phaseInterceptor.to(MoveEffectPhase, false); expect((game.scene.getCurrentPhase() as MoveEffectPhase).move.moveId).toBe(fusionBolt.id); @@ -100,7 +100,7 @@ describe("Moves - Fusion Flare and Fusion Bolt", () => { game.move.select(fusionBolt.id, 1, BattlerIndex.PLAYER); // Force first enemy to act (and fail) in between party - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY_2, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY_2, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to(MoveEffectPhase, false); expect((game.scene.getCurrentPhase() as MoveEffectPhase).move.moveId).toBe(fusionFlare.id); @@ -119,7 +119,7 @@ describe("Moves - Fusion Flare and Fusion Bolt", () => { }, 20000); it("FUSION_FLARE should not double power of subsequent FUSION_BOLT if a move succeeded in between", async () => { - game.override.enemyMoveset([Moves.SPLASH, Moves.SPLASH, Moves.SPLASH, Moves.SPLASH]); + game.override.enemyMoveset([ Moves.SPLASH, Moves.SPLASH, Moves.SPLASH, Moves.SPLASH ]); await game.startBattle([ Species.ZEKROM, Species.ZEKROM @@ -129,7 +129,7 @@ describe("Moves - Fusion Flare and Fusion Bolt", () => { game.move.select(fusionBolt.id, 1, BattlerIndex.ENEMY); // Force first enemy to act in between party - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY_2, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY_2, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to(MoveEffectPhase, false); expect((game.scene.getCurrentPhase() as MoveEffectPhase).move.moveId).toBe(fusionFlare.id); @@ -156,7 +156,7 @@ describe("Moves - Fusion Flare and Fusion Bolt", () => { game.move.select(fusionFlare.id, 1, BattlerIndex.PLAYER); // Force user party to act before enemy party - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2 ]); await game.phaseInterceptor.to(MoveEffectPhase, false); expect((game.scene.getCurrentPhase() as MoveEffectPhase).move.moveId).toBe(fusionBolt.id); @@ -170,13 +170,13 @@ describe("Moves - Fusion Flare and Fusion Bolt", () => { }, 20000); it("FUSION_FLARE and FUSION_BOLT alternating throughout turn should double power of subsequent moves", async () => { - game.override.enemyMoveset([fusionFlare.id, fusionFlare.id, fusionFlare.id, fusionFlare.id]); + game.override.enemyMoveset([ fusionFlare.id, fusionFlare.id, fusionFlare.id, fusionFlare.id ]); await game.startBattle([ Species.ZEKROM, Species.ZEKROM ]); - const party = game.scene.getParty(); + const party = game.scene.getPlayerParty(); const enemyParty = game.scene.getEnemyParty(); // Get rid of any modifiers that may alter power @@ -186,12 +186,12 @@ describe("Moves - Fusion Flare and Fusion Bolt", () => { // Mock stats by replacing entries in copy with desired values for specific stats const stats = { enemy: [ - [...enemyParty[0].stats], - [...enemyParty[1].stats], + [ ...enemyParty[0].stats ], + [ ...enemyParty[1].stats ], ], player: [ - [...party[0].stats], - [...party[1].stats], + [ ...party[0].stats ], + [ ...party[1].stats ], ] }; @@ -205,7 +205,7 @@ describe("Moves - Fusion Flare and Fusion Bolt", () => { game.move.select(fusionBolt.id, 1, BattlerIndex.ENEMY); // Force first enemy to act in between party - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY_2, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY_2, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to(MoveEffectPhase, false); expect((game.scene.getCurrentPhase() as MoveEffectPhase).move.moveId).toBe(fusionBolt.id); @@ -229,13 +229,13 @@ describe("Moves - Fusion Flare and Fusion Bolt", () => { }, 20000); it("FUSION_FLARE and FUSION_BOLT alternating throughout turn should double power of subsequent moves if moves are aimed at allies", async () => { - game.override.enemyMoveset([fusionFlare.id, fusionFlare.id, fusionFlare.id, fusionFlare.id]); + game.override.enemyMoveset([ fusionFlare.id, fusionFlare.id, fusionFlare.id, fusionFlare.id ]); await game.startBattle([ Species.ZEKROM, Species.ZEKROM ]); - const party = game.scene.getParty(); + const party = game.scene.getPlayerParty(); const enemyParty = game.scene.getEnemyParty(); // Get rid of any modifiers that may alter power @@ -245,12 +245,12 @@ describe("Moves - Fusion Flare and Fusion Bolt", () => { // Mock stats by replacing entries in copy with desired values for specific stats const stats = { enemy: [ - [...enemyParty[0].stats], - [...enemyParty[1].stats], + [ ...enemyParty[0].stats ], + [ ...enemyParty[1].stats ], ], player: [ - [...party[0].stats], - [...party[1].stats], + [ ...party[0].stats ], + [ ...party[1].stats ], ] }; @@ -264,7 +264,7 @@ describe("Moves - Fusion Flare and Fusion Bolt", () => { game.move.select(fusionBolt.id, 1, BattlerIndex.PLAYER); // Force first enemy to act in between party - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY_2, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY_2, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to(MoveEffectPhase, false); expect((game.scene.getCurrentPhase() as MoveEffectPhase).move.moveId).toBe(fusionBolt.id); diff --git a/src/test/moves/future_sight.test.ts b/src/test/moves/future_sight.test.ts new file mode 100644 index 00000000000..d0110a87202 --- /dev/null +++ b/src/test/moves/future_sight.test.ts @@ -0,0 +1,45 @@ +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; + +describe("Moves - Future Sight", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .startingLevel(50) + .moveset([ Moves.FUTURE_SIGHT, Moves.SPLASH ]) + .battleType("single") + .enemySpecies(Species.MAGIKARP) + .enemyAbility(Abilities.STURDY) + .enemyMoveset(Moves.SPLASH); + }); + + it("hits 2 turns after use, ignores user switch out", async () => { + await game.classicMode.startBattle([ Species.FEEBAS, Species.MILOTIC ]); + + game.move.select(Moves.FUTURE_SIGHT); + await game.toNextTurn(); + game.doSwitchPokemon(1); + await game.toNextTurn(); + game.move.select(Moves.SPLASH); + await game.toNextTurn(); + + expect(game.scene.getEnemyPokemon()!.isFullHp()).toBe(false); + }); +}); diff --git a/src/test/moves/gastro_acid.test.ts b/src/test/moves/gastro_acid.test.ts index cfc458a908f..ec9246c855c 100644 --- a/src/test/moves/gastro_acid.test.ts +++ b/src/test/moves/gastro_acid.test.ts @@ -6,7 +6,6 @@ import { MoveResult } from "#app/field/pokemon"; import GameManager from "#test/utils/gameManager"; import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Moves - Gastro Acid", () => { let phaserGame: Phaser.Game; @@ -28,7 +27,7 @@ describe("Moves - Gastro Acid", () => { game.override.startingLevel(1); game.override.enemyLevel(100); game.override.ability(Abilities.NONE); - game.override.moveset([Moves.GASTRO_ACID, Moves.WATER_GUN, Moves.SPLASH, Moves.CORE_ENFORCER]); + game.override.moveset([ Moves.GASTRO_ACID, Moves.WATER_GUN, Moves.SPLASH, Moves.CORE_ENFORCER ]); game.override.enemySpecies(Species.BIDOOF); game.override.enemyMoveset(Moves.SPLASH); game.override.enemyAbility(Abilities.WATER_ABSORB); @@ -60,16 +59,16 @@ describe("Moves - Gastro Acid", () => { expect(enemyField[0].hp).toBeLessThan(enemyField[0].getMaxHp()); expect(enemyField[1].isFullHp()).toBe(true); - }, TIMEOUT); + }); it("fails if used on an enemy with an already-suppressed ability", async () => { - game.override.battleType(null); + game.override.battleType("single"); await game.startBattle(); game.move.select(Moves.CORE_ENFORCER); // Force player to be slower to enable Core Enforcer to proc its suppression effect - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); await game.phaseInterceptor.to("TurnInitPhase"); @@ -78,5 +77,5 @@ describe("Moves - Gastro Acid", () => { await game.phaseInterceptor.to("TurnInitPhase"); expect(game.scene.getPlayerPokemon()!.getLastXMoves()[0].result).toBe(MoveResult.FAIL); - }, TIMEOUT); + }); }); diff --git a/src/test/moves/geomancy.test.ts b/src/test/moves/geomancy.test.ts new file mode 100644 index 00000000000..6e2f40b9144 --- /dev/null +++ b/src/test/moves/geomancy.test.ts @@ -0,0 +1,78 @@ +import { EffectiveStat, Stat } from "#enums/stat"; +import { MoveResult } from "#app/field/pokemon"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, it, expect } from "vitest"; + +describe("Moves - Geomancy", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset(Moves.GEOMANCY) + .battleType("single") + .startingLevel(100) + .enemySpecies(Species.SNORLAX) + .enemyLevel(100) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.SPLASH); + }); + + it("should boost the user's stats on the second turn of use", async () => { + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const player = game.scene.getPlayerPokemon()!; + const affectedStats: EffectiveStat[] = [ Stat.SPATK, Stat.SPDEF, Stat.SPD ]; + + game.move.select(Moves.GEOMANCY); + + await game.phaseInterceptor.to("TurnEndPhase"); + affectedStats.forEach((stat) => expect(player.getStatStage(stat)).toBe(0)); + expect(player.getLastXMoves(1)[0].result).toBe(MoveResult.OTHER); + + await game.phaseInterceptor.to("TurnEndPhase"); + affectedStats.forEach((stat) => expect(player.getStatStage(stat)).toBe(2)); + expect(player.getMoveHistory()).toHaveLength(2); + expect(player.getLastXMoves(1)[0].result).toBe(MoveResult.SUCCESS); + + const playerGeomancy = player.getMoveset().find((mv) => mv && mv.moveId === Moves.GEOMANCY); + expect(playerGeomancy?.ppUsed).toBe(1); + }); + + it("should execute over 2 turns between waves", async () => { + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const player = game.scene.getPlayerPokemon()!; + const affectedStats: EffectiveStat[] = [ Stat.SPATK, Stat.SPDEF, Stat.SPD ]; + + game.move.select(Moves.GEOMANCY); + + await game.phaseInterceptor.to("MoveEndPhase", false); + await game.doKillOpponents(); + + await game.toNextWave(); + + await game.phaseInterceptor.to("TurnEndPhase"); + affectedStats.forEach((stat) => expect(player.getStatStage(stat)).toBe(2)); + expect(player.getMoveHistory()).toHaveLength(2); + expect(player.getLastXMoves(1)[0].result).toBe(MoveResult.SUCCESS); + + const playerGeomancy = player.getMoveset().find((mv) => mv && mv.moveId === Moves.GEOMANCY); + expect(playerGeomancy?.ppUsed).toBe(1); + }); +}); diff --git a/src/test/moves/gigaton_hammer.test.ts b/src/test/moves/gigaton_hammer.test.ts index b0ab06fdeb5..f54700fe660 100644 --- a/src/test/moves/gigaton_hammer.test.ts +++ b/src/test/moves/gigaton_hammer.test.ts @@ -25,7 +25,7 @@ describe("Moves - Gigaton Hammer", () => { .battleType("single") .enemySpecies(Species.MAGIKARP) .starterSpecies(Species.FEEBAS) - .moveset([Moves.GIGATON_HAMMER]) + .moveset([ Moves.GIGATON_HAMMER ]) .startingLevel(10) .enemyLevel(100) .enemyMoveset(Moves.SPLASH) @@ -38,7 +38,7 @@ describe("Moves - Gigaton Hammer", () => { const enemy1 = game.scene.getEnemyPokemon()!; game.move.select(Moves.GIGATON_HAMMER); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to("MoveEndPhase"); expect(enemy1.hp).toBeLessThan(enemy1.getMaxHp()); @@ -61,7 +61,7 @@ describe("Moves - Gigaton Hammer", () => { const enemy1 = game.scene.getEnemyPokemon()!; game.move.select(Moves.GIGATON_HAMMER); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to("MoveEndPhase"); expect(enemy1.hp).toBeLessThan(enemy1.getMaxHp()); diff --git a/src/test/moves/glaive_rush.test.ts b/src/test/moves/glaive_rush.test.ts index 9eed6868432..b36c3e20c7a 100644 --- a/src/test/moves/glaive_rush.test.ts +++ b/src/test/moves/glaive_rush.test.ts @@ -6,7 +6,6 @@ import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Moves - Glaive Rush", () => { let phaserGame: Phaser.Game; @@ -29,10 +28,10 @@ describe("Moves - Glaive Rush", () => { .disableCrits() .enemySpecies(Species.MAGIKARP) .enemyAbility(Abilities.BALL_FETCH) - .enemyMoveset([Moves.GLAIVE_RUSH]) + .enemyMoveset([ Moves.GLAIVE_RUSH ]) .starterSpecies(Species.KLINK) .ability(Abilities.BALL_FETCH) - .moveset([Moves.SHADOW_SNEAK, Moves.AVALANCHE, Moves.SPLASH, Moves.GLAIVE_RUSH]); + .moveset([ Moves.SHADOW_SNEAK, Moves.AVALANCHE, Moves.SPLASH, Moves.GLAIVE_RUSH ]); }); it("takes double damage from attacks", async () => { @@ -49,7 +48,7 @@ describe("Moves - Glaive Rush", () => { await game.phaseInterceptor.to("DamagePhase"); expect(enemy.hp).toBeLessThanOrEqual(1001 - (damageDealt * 3)); - }, TIMEOUT); + }); it("always gets hit by attacks", async () => { await game.classicMode.startBattle(); @@ -62,12 +61,12 @@ describe("Moves - Glaive Rush", () => { await game.phaseInterceptor.to("TurnEndPhase"); expect(enemy.hp).toBeLessThan(1000); - }, TIMEOUT); + }); it("interacts properly with multi-lens", async () => { game.override .startingHeldItems([{ name: "MULTI_LENS", count: 2 }]) - .enemyMoveset([Moves.AVALANCHE]); + .enemyMoveset([ Moves.AVALANCHE ]); await game.classicMode.startBattle(); const player = game.scene.getPlayerPokemon()!; @@ -85,10 +84,10 @@ describe("Moves - Glaive Rush", () => { await game.phaseInterceptor.to("TurnEndPhase"); expect(player.hp).toBe(1000); - }, TIMEOUT); + }); it("secondary effects only last until next move", async () => { - game.override.enemyMoveset([Moves.SHADOW_SNEAK]); + game.override.enemyMoveset([ Moves.SHADOW_SNEAK ]); await game.classicMode.startBattle(); const player = game.scene.getPlayerPokemon()!; @@ -111,13 +110,13 @@ describe("Moves - Glaive Rush", () => { await game.phaseInterceptor.to("TurnEndPhase"); expect(player.hp).toBe(damagedHp); - }, TIMEOUT); + }); it("secondary effects are removed upon switching", async () => { game.override - .enemyMoveset([Moves.SHADOW_SNEAK]) + .enemyMoveset([ Moves.SHADOW_SNEAK ]) .starterSpecies(0); - await game.classicMode.startBattle([Species.KLINK, Species.FEEBAS]); + await game.classicMode.startBattle([ Species.KLINK, Species.FEEBAS ]); const player = game.scene.getPlayerPokemon()!; const enemy = game.scene.getEnemyPokemon()!; @@ -135,10 +134,10 @@ describe("Moves - Glaive Rush", () => { await game.phaseInterceptor.to("TurnEndPhase"); expect(player.hp).toBe(player.getMaxHp()); - }, TIMEOUT); + }); it("secondary effects don't activate if move fails", async () => { - game.override.moveset([Moves.SHADOW_SNEAK, Moves.PROTECT, Moves.SPLASH, Moves.GLAIVE_RUSH]); + game.override.moveset([ Moves.SHADOW_SNEAK, Moves.PROTECT, Moves.SPLASH, Moves.GLAIVE_RUSH ]); await game.classicMode.startBattle(); const player = game.scene.getPlayerPokemon()!; @@ -152,7 +151,7 @@ describe("Moves - Glaive Rush", () => { game.move.select(Moves.SHADOW_SNEAK); await game.phaseInterceptor.to("TurnEndPhase"); - game.override.enemyMoveset([Moves.SPLASH]); + game.override.enemyMoveset([ Moves.SPLASH ]); const damagedHP1 = 1000 - enemy.hp; enemy.hp = 1000; @@ -161,5 +160,5 @@ describe("Moves - Glaive Rush", () => { const damagedHP2 = 1000 - enemy.hp; expect(damagedHP2).toBeGreaterThanOrEqual((damagedHP1 * 2) - 1); - }, TIMEOUT); + }); }); diff --git a/src/test/moves/grudge.test.ts b/src/test/moves/grudge.test.ts new file mode 100644 index 00000000000..340808929ab --- /dev/null +++ b/src/test/moves/grudge.test.ts @@ -0,0 +1,90 @@ +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import { BattlerIndex } from "#app/battle"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; + +describe("Moves - Grudge", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.EMBER, Moves.SPLASH ]) + .ability(Abilities.BALL_FETCH) + .battleType("single") + .disableCrits() + .enemySpecies(Species.SHEDINJA) + .enemyAbility(Abilities.WONDER_GUARD) + .enemyMoveset([ Moves.GRUDGE, Moves.SPLASH ]); + }); + + it("should reduce the PP of the Pokemon's move to 0 when the user has fainted", async () => { + await game.classicMode.startBattle([ Species.FEEBAS ]); + + const playerPokemon = game.scene.getPlayerPokemon(); + game.move.select(Moves.EMBER); + await game.forceEnemyMove(Moves.GRUDGE); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); + await game.phaseInterceptor.to("BerryPhase"); + + const playerMove = playerPokemon?.getMoveset().find(m => m?.moveId === Moves.EMBER); + + expect(playerMove?.getPpRatio()).toBe(0); + }); + + it("should remain in effect until the user's next move", async () => { + await game.classicMode.startBattle([ Species.FEEBAS ]); + + const playerPokemon = game.scene.getPlayerPokemon(); + game.move.select(Moves.SPLASH); + await game.forceEnemyMove(Moves.GRUDGE); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + await game.toNextTurn(); + + game.move.select(Moves.EMBER); + await game.forceEnemyMove(Moves.SPLASH); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + await game.phaseInterceptor.to("BerryPhase"); + + const playerMove = playerPokemon?.getMoveset().find(m => m?.moveId === Moves.EMBER); + + expect(playerMove?.getPpRatio()).toBe(0); + }); + + it("should not reduce the opponent's PP if the user dies to weather/indirect damage", async () => { + // Opponent will be reduced to 1 HP by False Swipe, then faint to Sandstorm + game.override + .moveset([ Moves.FALSE_SWIPE ]) + .startingLevel(100) + .ability(Abilities.SAND_STREAM) + .enemySpecies(Species.RATTATA); + await game.classicMode.startBattle([ Species.GEODUDE ]); + + const enemyPokemon = game.scene.getEnemyPokemon(); + const playerPokemon = game.scene.getPlayerPokemon(); + + game.move.select(Moves.FALSE_SWIPE); + await game.forceEnemyMove(Moves.GRUDGE); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); + await game.phaseInterceptor.to("BerryPhase"); + + expect(enemyPokemon?.isFainted()).toBe(true); + + const playerMove = playerPokemon?.getMoveset().find(m => m?.moveId === Moves.FALSE_SWIPE); + expect(playerMove?.getPpRatio()).toBeGreaterThan(0); + }); +}); diff --git a/src/test/moves/guard_split.test.ts b/src/test/moves/guard_split.test.ts index 36be82ba5e4..519f347b920 100644 --- a/src/test/moves/guard_split.test.ts +++ b/src/test/moves/guard_split.test.ts @@ -55,7 +55,7 @@ describe("Moves - Guard Split", () => { }, 20000); it("should be idempotent", async () => { - game.override.enemyMoveset([Moves.GUARD_SPLIT]); + game.override.enemyMoveset([ Moves.GUARD_SPLIT ]); await game.startBattle([ Species.INDEEDEE ]); diff --git a/src/test/moves/guard_swap.test.ts b/src/test/moves/guard_swap.test.ts index 0c24f69c32c..99769b32899 100644 --- a/src/test/moves/guard_swap.test.ts +++ b/src/test/moves/guard_swap.test.ts @@ -11,8 +11,6 @@ import { MoveEndPhase } from "#app/phases/move-end-phase"; describe("Moves - Guard Swap", () => { let phaserGame: Phaser.Game; let game: GameManager; - const TIMEOUT = 20 * 1000; - beforeAll(() => { phaserGame = new Phaser.Game({ type: Phaser.HEADLESS, @@ -65,5 +63,5 @@ describe("Moves - Guard Swap", () => { expect(enemy.getStatStage(s)).toBe(1); } } - }, TIMEOUT); + }); }); diff --git a/src/test/moves/hard_press.test.ts b/src/test/moves/hard_press.test.ts index 5d2e4e5b145..0fa4181491c 100644 --- a/src/test/moves/hard_press.test.ts +++ b/src/test/moves/hard_press.test.ts @@ -30,12 +30,12 @@ describe("Moves - Hard Press", () => { game.override.enemySpecies(Species.MUNCHLAX); game.override.enemyAbility(Abilities.BALL_FETCH); game.override.enemyMoveset(Moves.SPLASH); - game.override.moveset([Moves.HARD_PRESS]); + game.override.moveset([ Moves.HARD_PRESS ]); vi.spyOn(moveToCheck, "calculateBattlePower"); }); it("should return 100 power if target HP ratio is at 100%", async () => { - await game.startBattle([Species.PIKACHU]); + await game.startBattle([ Species.PIKACHU ]); game.move.select(Moves.HARD_PRESS); await game.phaseInterceptor.to(MoveEffectPhase); @@ -44,7 +44,7 @@ describe("Moves - Hard Press", () => { }); it("should return 50 power if target HP ratio is at 50%", async () => { - await game.startBattle([Species.PIKACHU]); + await game.startBattle([ Species.PIKACHU ]); const targetHpRatio = .5; const enemy = game.scene.getEnemyPokemon()!; @@ -57,7 +57,7 @@ describe("Moves - Hard Press", () => { }); it("should return 1 power if target HP ratio is at 1%", async () => { - await game.startBattle([Species.PIKACHU]); + await game.startBattle([ Species.PIKACHU ]); const targetHpRatio = .01; const enemy = game.scene.getEnemyPokemon()!; @@ -70,7 +70,7 @@ describe("Moves - Hard Press", () => { }); it("should return 1 power if target HP ratio is less than 1%", async () => { - await game.startBattle([Species.PIKACHU]); + await game.startBattle([ Species.PIKACHU ]); const targetHpRatio = .005; const enemy = game.scene.getEnemyPokemon()!; diff --git a/src/test/moves/haze.test.ts b/src/test/moves/haze.test.ts index 211c1a41409..30aab8bd98c 100644 --- a/src/test/moves/haze.test.ts +++ b/src/test/moves/haze.test.ts @@ -31,12 +31,12 @@ describe("Moves - Haze", () => { game.override.enemyAbility(Abilities.NONE); game.override.startingLevel(100); - game.override.moveset([Moves.HAZE, Moves.SWORDS_DANCE, Moves.CHARM, Moves.SPLASH]); + game.override.moveset([ Moves.HAZE, Moves.SWORDS_DANCE, Moves.CHARM, Moves.SPLASH ]); game.override.ability(Abilities.NONE); }); - it("should reset all stat changes of all Pokemon on field", { timeout: 10000 }, async () => { - await game.startBattle([Species.RATTATA]); + it("should reset all stat changes of all Pokemon on field", async () => { + await game.startBattle([ Species.RATTATA ]); const user = game.scene.getPlayerPokemon()!; const enemy = game.scene.getEnemyPokemon()!; diff --git a/src/test/moves/heal_bell.test.ts b/src/test/moves/heal_bell.test.ts new file mode 100644 index 00000000000..b180588d3a3 --- /dev/null +++ b/src/test/moves/heal_bell.test.ts @@ -0,0 +1,101 @@ +import { StatusEffect } from "#app/enums/status-effect"; +import { CommandPhase } from "#app/phases/command-phase"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, it, expect, vi } from "vitest"; + +describe("Moves - Heal Bell", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.HEAL_BELL, Moves.SPLASH ]) + .statusEffect(StatusEffect.BURN) + .battleType("double") + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.SPLASH); + }); + + it("should cure status effect of the user, its ally, and all party pokemon", async () => { + await game.classicMode.startBattle([ Species.RATTATA, Species.RATTATA, Species.RATTATA ]); + const [ leftPlayer, rightPlayer, partyPokemon ] = game.scene.getPlayerParty(); + + vi.spyOn(leftPlayer, "resetStatus"); + vi.spyOn(rightPlayer, "resetStatus"); + vi.spyOn(partyPokemon, "resetStatus"); + + game.move.select(Moves.HEAL_BELL, 0); + await game.phaseInterceptor.to(CommandPhase); + game.move.select(Moves.SPLASH, 1); + await game.toNextTurn(); + + expect(leftPlayer.resetStatus).toHaveBeenCalledOnce(); + expect(rightPlayer.resetStatus).toHaveBeenCalledOnce(); + expect(partyPokemon.resetStatus).toHaveBeenCalledOnce(); + + expect(leftPlayer.status?.effect).toBeUndefined(); + expect(rightPlayer.status?.effect).toBeUndefined(); + expect(partyPokemon.status?.effect).toBeUndefined(); + }); + + it("should not cure status effect of the target/target's allies", async () => { + game.override.enemyStatusEffect(StatusEffect.BURN); + await game.classicMode.startBattle([ Species.RATTATA, Species.RATTATA ]); + const [ leftOpp, rightOpp ] = game.scene.getEnemyField(); + + vi.spyOn(leftOpp, "resetStatus"); + vi.spyOn(rightOpp, "resetStatus"); + + game.move.select(Moves.HEAL_BELL, 0); + await game.phaseInterceptor.to(CommandPhase); + game.move.select(Moves.SPLASH, 1); + await game.toNextTurn(); + + expect(leftOpp.resetStatus).toHaveBeenCalledTimes(0); + expect(rightOpp.resetStatus).toHaveBeenCalledTimes(0); + + expect(leftOpp.status?.effect).toBeTruthy(); + expect(rightOpp.status?.effect).toBeTruthy(); + + expect(leftOpp.status?.effect).toBe(StatusEffect.BURN); + expect(rightOpp.status?.effect).toBe(StatusEffect.BURN); + }); + + it("should not cure status effect of allies ON FIELD with Soundproof, should still cure allies in party", async () => { + game.override.ability(Abilities.SOUNDPROOF); + await game.classicMode.startBattle([ Species.RATTATA, Species.RATTATA, Species.RATTATA ]); + const [ leftPlayer, rightPlayer, partyPokemon ] = game.scene.getPlayerParty(); + + vi.spyOn(leftPlayer, "resetStatus"); + vi.spyOn(rightPlayer, "resetStatus"); + vi.spyOn(partyPokemon, "resetStatus"); + + game.move.select(Moves.HEAL_BELL, 0); + await game.phaseInterceptor.to(CommandPhase); + game.move.select(Moves.SPLASH, 1); + await game.toNextTurn(); + + expect(leftPlayer.resetStatus).toHaveBeenCalledOnce(); + expect(rightPlayer.resetStatus).toHaveBeenCalledTimes(0); + expect(partyPokemon.resetStatus).toHaveBeenCalledOnce(); + + expect(leftPlayer.status?.effect).toBeUndefined(); + expect(rightPlayer.status?.effect).toBe(StatusEffect.BURN); + expect(partyPokemon.status?.effect).toBeUndefined(); + }); +}); diff --git a/src/test/moves/heal_block.test.ts b/src/test/moves/heal_block.test.ts new file mode 100644 index 00000000000..25f2076ff3e --- /dev/null +++ b/src/test/moves/heal_block.test.ts @@ -0,0 +1,150 @@ +import { BattlerIndex } from "#app/battle"; +import { ArenaTagSide } from "#app/data/arena-tag"; +import GameManager from "#app/test/utils/gameManager"; +import { Abilities } from "#enums/abilities"; +import { ArenaTagType } from "#enums/arena-tag-type"; +import { BattlerTagType } from "#enums/battler-tag-type"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import { WeatherType } from "#enums/weather-type"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; + +// Bulbapedia Reference: https://bulbapedia.bulbagarden.net/wiki/Heal_Block_(move) +describe("Moves - Heal Block", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.ABSORB, Moves.WISH, Moves.SPLASH, Moves.AQUA_RING ]) + .enemyMoveset(Moves.HEAL_BLOCK) + .ability(Abilities.NO_GUARD) + .enemyAbility(Abilities.BALL_FETCH) + .enemySpecies(Species.BLISSEY) + .disableCrits(); + }); + + it("shouldn't stop damage from HP-drain attacks, just HP restoration", async() => { + + await game.classicMode.startBattle([ Species.CHARIZARD ]); + + const player = game.scene.getPlayerPokemon()!; + const enemy = game.scene.getEnemyPokemon()!; + + player.damageAndUpdate(enemy.getMaxHp() - 1); + + game.move.select(Moves.ABSORB); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); + await game.phaseInterceptor.to("TurnEndPhase"); + + expect(player.hp).toBe(1); + expect(enemy.hp).toBeLessThan(enemy.getMaxHp()); + }); + + it("shouldn't stop Liquid Ooze from dealing damage", async() => { + game.override.enemyAbility(Abilities.LIQUID_OOZE); + + await game.classicMode.startBattle([ Species.CHARIZARD ]); + + const player = game.scene.getPlayerPokemon()!; + const enemy = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.ABSORB); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); + await game.phaseInterceptor.to("TurnEndPhase"); + + expect(player.isFullHp()).toBe(false); + expect(enemy.isFullHp()).toBe(false); + }); + + it("should stop delayed heals, such as from Wish", async() => { + await game.classicMode.startBattle([ Species.CHARIZARD ]); + + const player = game.scene.getPlayerPokemon()!; + + player.damageAndUpdate(player.getMaxHp() - 1); + + game.move.select(Moves.WISH); + await game.phaseInterceptor.to("TurnEndPhase"); + + expect(game.scene.arena.getTagOnSide(ArenaTagType.WISH, ArenaTagSide.PLAYER)).toBeDefined(); + while (game.scene.arena.getTagOnSide(ArenaTagType.WISH, ArenaTagSide.PLAYER)) { + game.move.select(Moves.SPLASH); + await game.phaseInterceptor.to("TurnEndPhase"); + } + + expect(player.hp).toBe(1); + }); + + it("should prevent Grassy Terrain from restoring HP", async() => { + game.override.enemyAbility(Abilities.GRASSY_SURGE); + + await game.classicMode.startBattle([ Species.CHARIZARD ]); + + const player = game.scene.getPlayerPokemon()!; + + player.damageAndUpdate(player.getMaxHp() - 1); + + game.move.select(Moves.SPLASH); + await game.phaseInterceptor.to("TurnEndPhase"); + + expect(player.hp).toBe(1); + }); + + it("should prevent healing from heal-over-time moves", async() => { + await game.classicMode.startBattle([ Species.CHARIZARD ]); + + const player = game.scene.getPlayerPokemon()!; + + player.damageAndUpdate(player.getMaxHp() - 1); + + game.move.select(Moves.AQUA_RING); + await game.phaseInterceptor.to("TurnEndPhase"); + + expect(player.getTag(BattlerTagType.AQUA_RING)).toBeDefined(); + expect(player.hp).toBe(1); + }); + + it("should prevent abilities from restoring HP", async() => { + game.override + .weather(WeatherType.RAIN) + .ability(Abilities.RAIN_DISH); + + await game.classicMode.startBattle([ Species.CHARIZARD ]); + + const player = game.scene.getPlayerPokemon()!; + + player.damageAndUpdate(player.getMaxHp() - 1); + + game.move.select(Moves.SPLASH); + await game.phaseInterceptor.to("TurnEndPhase"); + + expect(player.hp).toBe(1); + }); + + it("should stop healing from items", async() => { + game.override.startingHeldItems([{ name: "LEFTOVERS" }]); + + await game.classicMode.startBattle([ Species.CHARIZARD ]); + + const player = game.scene.getPlayerPokemon()!; + player.damageAndUpdate(player.getMaxHp() - 1); + + game.move.select(Moves.SPLASH); + await game.phaseInterceptor.to("TurnEndPhase"); + + expect(player.hp).toBe(1); + }); +}); diff --git a/src/test/moves/heart_swap.test.ts b/src/test/moves/heart_swap.test.ts index f658641d46f..a128549c459 100644 --- a/src/test/moves/heart_swap.test.ts +++ b/src/test/moves/heart_swap.test.ts @@ -11,8 +11,6 @@ import { MoveEndPhase } from "#app/phases/move-end-phase"; describe("Moves - Heart Swap", () => { let phaserGame: Phaser.Game; let game: GameManager; - const TIMEOUT = 20 * 1000; - beforeAll(() => { phaserGame = new Phaser.Game({ type: Phaser.HEADLESS, @@ -60,5 +58,5 @@ describe("Moves - Heart Swap", () => { expect(enemy.getStatStage(s)).toBe(0); expect(player.getStatStage(s)).toBe(1); } - }, TIMEOUT); + }); }); diff --git a/src/test/moves/hyper_beam.test.ts b/src/test/moves/hyper_beam.test.ts index 7aa2dbfec2b..af8440a0911 100644 --- a/src/test/moves/hyper_beam.test.ts +++ b/src/test/moves/hyper_beam.test.ts @@ -9,8 +9,6 @@ import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; -const TIMEOUT = 20 * 1000; // 20 sec timeout for all tests - describe("Moves - Hyper Beam", () => { let phaserGame: Phaser.Game; let game: GameManager; @@ -32,17 +30,17 @@ describe("Moves - Hyper Beam", () => { game.override.ability(Abilities.BALL_FETCH); game.override.enemySpecies(Species.SNORLAX); game.override.enemyAbility(Abilities.BALL_FETCH); - game.override.enemyMoveset([Moves.SPLASH]); + game.override.enemyMoveset([ Moves.SPLASH ]); game.override.enemyLevel(100); - game.override.moveset([Moves.HYPER_BEAM, Moves.TACKLE]); + game.override.moveset([ Moves.HYPER_BEAM, Moves.TACKLE ]); vi.spyOn(allMoves[Moves.HYPER_BEAM], "accuracy", "get").mockReturnValue(100); }); it( "should force the user to recharge on the next turn (and only that turn)", async () => { - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -67,6 +65,6 @@ describe("Moves - Hyper Beam", () => { await game.phaseInterceptor.to(BerryPhase, false); expect(enemyPokemon.hp).toBeLessThan(enemyPostAttackHp); - }, TIMEOUT + } ); }); diff --git a/src/test/moves/imprison.test.ts b/src/test/moves/imprison.test.ts new file mode 100644 index 00000000000..f10e20dab63 --- /dev/null +++ b/src/test/moves/imprison.test.ts @@ -0,0 +1,98 @@ +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import { Abilities } from "#enums/abilities"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; +import { BattlerTagType } from "#enums/battler-tag-type"; +import { ArenaTagType } from "#enums/arena-tag-type"; + +describe("Moves - Imprison", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .battleType("single") + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset([ Moves.IMPRISON, Moves.SPLASH, Moves.GROWL ]) + .enemySpecies(Species.SHUCKLE) + .moveset([ Moves.TRANSFORM, Moves.SPLASH ]); + }); + + it("Pokemon under Imprison cannot use shared moves", async () => { + await game.classicMode.startBattle([ Species.REGIELEKI ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + + game.move.select(Moves.TRANSFORM); + await game.forceEnemyMove(Moves.IMPRISON); + await game.toNextTurn(); + const playerMoveset = playerPokemon.getMoveset().map(x => x?.moveId); + const enemyMoveset = game.scene.getEnemyPokemon()!.getMoveset().map(x => x?.moveId); + expect(enemyMoveset.includes(playerMoveset[0])).toBeTruthy(); + const imprisonArenaTag = game.scene.arena.getTag(ArenaTagType.IMPRISON); + const imprisonBattlerTag = playerPokemon.getTag(BattlerTagType.IMPRISON); + expect(imprisonArenaTag).toBeDefined(); + expect(imprisonBattlerTag).toBeDefined(); + + // Second turn, Imprison forces Struggle to occur + game.move.select(Moves.SPLASH); + await game.forceEnemyMove(Moves.SPLASH); + await game.toNextTurn(); + const move1 = playerPokemon.getLastXMoves(1)[0]!; + expect(move1.move).toBe(Moves.STRUGGLE); + }); + + it("Imprison applies to Pokemon switched into Battle", async () => { + await game.classicMode.startBattle([ Species.REGIELEKI, Species.BULBASAUR ]); + + const playerPokemon1 = game.scene.getPlayerPokemon()!; + + game.move.select(Moves.SPLASH); + await game.forceEnemyMove(Moves.IMPRISON); + await game.toNextTurn(); + const imprisonArenaTag = game.scene.arena.getTag(ArenaTagType.IMPRISON); + const imprisonBattlerTag1 = playerPokemon1.getTag(BattlerTagType.IMPRISON); + expect(imprisonArenaTag).toBeDefined(); + expect(imprisonBattlerTag1).toBeDefined(); + + // Second turn, Imprison forces Struggle to occur + game.doSwitchPokemon(1); + await game.forceEnemyMove(Moves.SPLASH); + await game.toNextTurn(); + const playerPokemon2 = game.scene.getPlayerPokemon()!; + const imprisonBattlerTag2 = playerPokemon2.getTag(BattlerTagType.IMPRISON); + expect(playerPokemon1).not.toEqual(playerPokemon2); + expect(imprisonBattlerTag2).toBeDefined(); + }); + + it("The effects of Imprison only end when the source is no longer active", async () => { + game.override.moveset([ Moves.SPLASH, Moves.IMPRISON ]); + await game.classicMode.startBattle([ Species.REGIELEKI, Species.BULBASAUR ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const enemyPokemon = game.scene.getEnemyPokemon()!; + game.move.select(Moves.IMPRISON); + await game.forceEnemyMove(Moves.GROWL); + await game.toNextTurn(); + expect(game.scene.arena.getTag(ArenaTagType.IMPRISON)).toBeDefined(); + expect(enemyPokemon.getTag(BattlerTagType.IMPRISON)).toBeDefined(); + game.doSwitchPokemon(1); + await game.forceEnemyMove(Moves.SPLASH); + await game.toNextTurn(); + expect(playerPokemon.isActive(true)).toBeFalsy(); + expect(game.scene.arena.getTag(ArenaTagType.IMPRISON)).toBeUndefined(); + expect(enemyPokemon.getTag(BattlerTagType.IMPRISON)).toBeUndefined(); + }); +}); diff --git a/src/test/moves/jaw_lock.test.ts b/src/test/moves/jaw_lock.test.ts index 75fd6f0ff32..30dbcac64a8 100644 --- a/src/test/moves/jaw_lock.test.ts +++ b/src/test/moves/jaw_lock.test.ts @@ -11,7 +11,6 @@ import { Species } from "#enums/species"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Moves - Jaw Lock", () => { let phaserGame: Phaser.Game; @@ -35,7 +34,7 @@ describe("Moves - Jaw Lock", () => { .enemySpecies(Species.SNORLAX) .enemyAbility(Abilities.INSOMNIA) .enemyMoveset(Moves.SPLASH) - .moveset([Moves.JAW_LOCK, Moves.SPLASH]) + .moveset([ Moves.JAW_LOCK, Moves.SPLASH ]) .startingLevel(100) .enemyLevel(100) .disableCrits(); @@ -44,13 +43,13 @@ describe("Moves - Jaw Lock", () => { it( "should trap the move's user and target", async () => { - await game.startBattle([Species.BULBASAUR]); + await game.startBattle([ Species.BULBASAUR ]); const leadPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; game.move.select(Moves.JAW_LOCK); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to(MoveEffectPhase, false); @@ -61,20 +60,20 @@ describe("Moves - Jaw Lock", () => { expect(leadPokemon.getTag(BattlerTagType.TRAPPED)).toBeDefined(); expect(enemyPokemon.getTag(BattlerTagType.TRAPPED)).toBeDefined(); - }, TIMEOUT + } ); it( "should not trap either pokemon if the target faints", async () => { game.override.enemyLevel(1); - await game.startBattle([Species.BULBASAUR]); + await game.startBattle([ Species.BULBASAUR ]); const leadPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; game.move.select(Moves.JAW_LOCK); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to(MoveEffectPhase, false); @@ -90,19 +89,19 @@ describe("Moves - Jaw Lock", () => { expect(leadPokemon.getTag(BattlerTagType.TRAPPED)).toBeUndefined(); expect(enemyPokemon.getTag(BattlerTagType.TRAPPED)).toBeUndefined(); - }, TIMEOUT + } ); it( "should only trap the user until the target faints", async () => { - await game.startBattle([Species.BULBASAUR]); + await game.startBattle([ Species.BULBASAUR ]); const leadPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; game.move.select(Moves.JAW_LOCK); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to(MoveEffectPhase); @@ -114,7 +113,7 @@ describe("Moves - Jaw Lock", () => { await game.doKillOpponents(); expect(leadPokemon.getTag(BattlerTagType.TRAPPED)).toBeUndefined(); - }, TIMEOUT + } ); it( @@ -122,14 +121,14 @@ describe("Moves - Jaw Lock", () => { async () => { game.override.battleType("double"); - await game.startBattle([Species.CHARMANDER, Species.BULBASAUR]); + await game.startBattle([ Species.CHARMANDER, Species.BULBASAUR ]); const playerPokemon = game.scene.getPlayerField(); const enemyPokemon = game.scene.getEnemyField(); game.move.select(Moves.JAW_LOCK, 0, BattlerIndex.ENEMY); game.move.select(Moves.SPLASH, 1); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2 ]); await game.phaseInterceptor.to(MoveEffectPhase); @@ -146,15 +145,15 @@ describe("Moves - Jaw Lock", () => { expect(enemyPokemon[1].getTag(BattlerTagType.TRAPPED)).toBeUndefined(); expect(playerPokemon[0].getTag(BattlerTagType.TRAPPED)).toBeDefined(); expect(playerPokemon[0].getTag(BattlerTagType.TRAPPED)?.sourceId).toBe(enemyPokemon[0].id); - }, TIMEOUT + } ); it( "should not trap either pokemon if the target is protected", async () => { - game.override.enemyMoveset([Moves.PROTECT]); + game.override.enemyMoveset([ Moves.PROTECT ]); - await game.startBattle([Species.BULBASAUR]); + await game.startBattle([ Species.BULBASAUR ]); const playerPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -165,6 +164,6 @@ describe("Moves - Jaw Lock", () => { expect(playerPokemon.getTag(BattlerTagType.TRAPPED)).toBeUndefined(); expect(enemyPokemon.getTag(BattlerTagType.TRAPPED)).toBeUndefined(); - }, TIMEOUT + } ); }); diff --git a/src/test/moves/lash_out.test.ts b/src/test/moves/lash_out.test.ts index 8c414832f36..014c0ae8fe5 100644 --- a/src/test/moves/lash_out.test.ts +++ b/src/test/moves/lash_out.test.ts @@ -7,7 +7,6 @@ import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Moves - Lash Out", () => { let phaserGame: Phaser.Game; @@ -30,12 +29,12 @@ describe("Moves - Lash Out", () => { .disableCrits() .enemySpecies(Species.MAGIKARP) .enemyAbility(Abilities.FUR_COAT) - .enemyMoveset([Moves.GROWL]) + .enemyMoveset([ Moves.GROWL ]) .startingLevel(10) .enemyLevel(10) .starterSpecies(Species.FEEBAS) .ability(Abilities.BALL_FETCH) - .moveset([Moves.LASH_OUT]); + .moveset([ Moves.LASH_OUT ]); }); @@ -44,9 +43,9 @@ describe("Moves - Lash Out", () => { await game.classicMode.startBattle(); game.move.select(Moves.LASH_OUT); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); await game.phaseInterceptor.to("BerryPhase"); expect(allMoves[Moves.LASH_OUT].calculateBattlePower).toHaveReturnedWith(150); - }, TIMEOUT); + }); }); diff --git a/src/test/moves/light_screen.test.ts b/src/test/moves/light_screen.test.ts index e94dc4a299e..af14d9273e6 100644 --- a/src/test/moves/light_screen.test.ts +++ b/src/test/moves/light_screen.test.ts @@ -32,16 +32,16 @@ describe("Moves - Light Screen", () => { game = new GameManager(phaserGame); game.override.battleType("single"); game.override.ability(Abilities.NONE); - game.override.moveset([Moves.ABSORB, Moves.DAZZLING_GLEAM, Moves.TACKLE]); + game.override.moveset([ Moves.ABSORB, Moves.DAZZLING_GLEAM, Moves.TACKLE ]); game.override.enemyLevel(100); game.override.enemySpecies(Species.MAGIKARP); - game.override.enemyMoveset([Moves.LIGHT_SCREEN, Moves.LIGHT_SCREEN, Moves.LIGHT_SCREEN, Moves.LIGHT_SCREEN]); + game.override.enemyMoveset([ Moves.LIGHT_SCREEN, Moves.LIGHT_SCREEN, Moves.LIGHT_SCREEN, Moves.LIGHT_SCREEN ]); game.override.disableCrits(); }); it("reduces damage of special attacks by half in a single battle", async () => { const moveToUse = Moves.ABSORB; - await game.startBattle([Species.SHUCKLE]); + await game.startBattle([ Species.SHUCKLE ]); game.move.select(moveToUse); @@ -56,7 +56,7 @@ describe("Moves - Light Screen", () => { game.override.battleType("double"); const moveToUse = Moves.DAZZLING_GLEAM; - await game.startBattle([Species.SHUCKLE, Species.SHUCKLE]); + await game.startBattle([ Species.SHUCKLE, Species.SHUCKLE ]); game.move.select(moveToUse); game.move.select(moveToUse, 1); @@ -69,7 +69,7 @@ describe("Moves - Light Screen", () => { it("does not affect physical attacks", async () => { const moveToUse = Moves.TACKLE; - await game.startBattle([Species.SHUCKLE]); + await game.startBattle([ Species.SHUCKLE ]); game.move.select(moveToUse); @@ -94,7 +94,7 @@ const getMockedMoveDamage = (defender: Pokemon, attacker: Pokemon, move: Move) = const side = defender.isPlayer() ? ArenaTagSide.PLAYER : ArenaTagSide.ENEMY; if (defender.scene.arena.getTagOnSide(ArenaTagType.LIGHT_SCREEN, side)) { - defender.scene.arena.applyTagsForSide(ArenaTagType.LIGHT_SCREEN, side, move.category, defender.scene.currentBattle.double, multiplierHolder); + defender.scene.arena.applyTagsForSide(ArenaTagType.LIGHT_SCREEN, side, false, attacker, move.category, multiplierHolder); } return move.power * multiplierHolder.value; diff --git a/src/test/moves/lucky_chant.test.ts b/src/test/moves/lucky_chant.test.ts index 57e5ff80f1d..02e9dd24465 100644 --- a/src/test/moves/lucky_chant.test.ts +++ b/src/test/moves/lucky_chant.test.ts @@ -7,7 +7,6 @@ import { TurnEndPhase } from "#app/phases/turn-end-phase"; import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; import GameManager from "../utils/gameManager"; -const TIMEOUT = 20 * 1000; describe("Moves - Lucky Chant", () => { let phaserGame: Phaser.Game; @@ -28,10 +27,10 @@ describe("Moves - Lucky Chant", () => { game.override .battleType("single") - .moveset([Moves.LUCKY_CHANT, Moves.SPLASH, Moves.FOLLOW_ME]) + .moveset([ Moves.LUCKY_CHANT, Moves.SPLASH, Moves.FOLLOW_ME ]) .enemySpecies(Species.SNORLAX) .enemyAbility(Abilities.INSOMNIA) - .enemyMoveset([Moves.FLOWER_TRICK]) + .enemyMoveset([ Moves.FLOWER_TRICK ]) .startingLevel(100) .enemyLevel(100); }); @@ -39,7 +38,7 @@ describe("Moves - Lucky Chant", () => { it( "should prevent critical hits from moves", async () => { - await game.startBattle([Species.CHARIZARD]); + await game.startBattle([ Species.CHARIZARD ]); const playerPokemon = game.scene.getPlayerPokemon()!; @@ -55,7 +54,7 @@ describe("Moves - Lucky Chant", () => { const secondTurnDamage = playerPokemon.getMaxHp() - playerPokemon.hp - firstTurnDamage; expect(secondTurnDamage).toBeLessThan(firstTurnDamage); - }, TIMEOUT + } ); it( @@ -63,7 +62,7 @@ describe("Moves - Lucky Chant", () => { async () => { game.override.battleType("double"); - await game.startBattle([Species.CHARIZARD, Species.BLASTOISE]); + await game.startBattle([ Species.CHARIZARD, Species.BLASTOISE ]); const playerPokemon = game.scene.getPlayerField(); @@ -81,15 +80,15 @@ describe("Moves - Lucky Chant", () => { const secondTurnDamage = playerPokemon[0].getMaxHp() - playerPokemon[0].hp - firstTurnDamage; expect(secondTurnDamage).toBeLessThan(firstTurnDamage); - }, TIMEOUT + } ); it( "should prevent critical hits from field effects", async () => { - game.override.enemyMoveset([Moves.TACKLE]); + game.override.enemyMoveset([ Moves.TACKLE ]); - await game.startBattle([Species.CHARIZARD]); + await game.startBattle([ Species.CHARIZARD ]); const playerPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -108,6 +107,6 @@ describe("Moves - Lucky Chant", () => { const secondTurnDamage = playerPokemon.getMaxHp() - playerPokemon.hp - firstTurnDamage; expect(secondTurnDamage).toBeLessThan(firstTurnDamage); - }, TIMEOUT + } ); }); diff --git a/src/test/moves/lunar_blessing.test.ts b/src/test/moves/lunar_blessing.test.ts index 6a104762f4d..52c41a30e11 100644 --- a/src/test/moves/lunar_blessing.test.ts +++ b/src/test/moves/lunar_blessing.test.ts @@ -28,13 +28,13 @@ describe("Moves - Lunar Blessing", () => { game.override.enemyMoveset(Moves.SPLASH); game.override.enemyAbility(Abilities.BALL_FETCH); - game.override.moveset([Moves.LUNAR_BLESSING, Moves.SPLASH]); + game.override.moveset([ Moves.LUNAR_BLESSING, Moves.SPLASH ]); game.override.ability(Abilities.BALL_FETCH); }); it("should restore 25% HP of the user and its ally", async () => { - await game.startBattle([Species.RATTATA, Species.RATTATA]); - const [leftPlayer, rightPlayer] = game.scene.getPlayerField(); + await game.startBattle([ Species.RATTATA, Species.RATTATA ]); + const [ leftPlayer, rightPlayer ] = game.scene.getPlayerField(); vi.spyOn(leftPlayer, "getMaxHp").mockReturnValue(100); vi.spyOn(rightPlayer, "getMaxHp").mockReturnValue(100); @@ -62,8 +62,8 @@ describe("Moves - Lunar Blessing", () => { it("should cure status effect of the user and its ally", async () => { game.override.statusEffect(StatusEffect.BURN); - await game.startBattle([Species.RATTATA, Species.RATTATA]); - const [leftPlayer, rightPlayer] = game.scene.getPlayerField(); + await game.startBattle([ Species.RATTATA, Species.RATTATA ]); + const [ leftPlayer, rightPlayer ] = game.scene.getPlayerField(); vi.spyOn(leftPlayer, "resetStatus"); vi.spyOn(rightPlayer, "resetStatus"); diff --git a/src/test/moves/magnet_rise.test.ts b/src/test/moves/magnet_rise.test.ts index 9037e377090..b26bbf42ed0 100644 --- a/src/test/moves/magnet_rise.test.ts +++ b/src/test/moves/magnet_rise.test.ts @@ -26,19 +26,19 @@ describe("Moves - Magnet Rise", () => { game.override.battleType("single"); game.override.starterSpecies(Species.MAGNEZONE); game.override.enemySpecies(Species.RATTATA); - game.override.enemyMoveset([Moves.DRILL_RUN, Moves.DRILL_RUN, Moves.DRILL_RUN, Moves.DRILL_RUN]); + game.override.enemyMoveset([ Moves.DRILL_RUN, Moves.DRILL_RUN, Moves.DRILL_RUN, Moves.DRILL_RUN ]); game.override.disableCrits(); game.override.enemyLevel(1); - game.override.moveset([moveToUse, Moves.SPLASH, Moves.GRAVITY, Moves.BATON_PASS]); + game.override.moveset([ moveToUse, Moves.SPLASH, Moves.GRAVITY, Moves.BATON_PASS ]); }); it("MAGNET RISE", async () => { await game.startBattle(); - const startingHp = game.scene.getParty()[0].hp; + const startingHp = game.scene.getPlayerParty()[0].hp; game.move.select(moveToUse); await game.phaseInterceptor.to(TurnEndPhase); - const finalHp = game.scene.getParty()[0].hp; + const finalHp = game.scene.getPlayerParty()[0].hp; const hpLost = finalHp - startingHp; expect(hpLost).toBe(0); }, 20000); @@ -46,15 +46,15 @@ describe("Moves - Magnet Rise", () => { it("MAGNET RISE - Gravity", async () => { await game.startBattle(); - const startingHp = game.scene.getParty()[0].hp; + const startingHp = game.scene.getPlayerParty()[0].hp; game.move.select(moveToUse); await game.phaseInterceptor.to(CommandPhase); - let finalHp = game.scene.getParty()[0].hp; + let finalHp = game.scene.getPlayerParty()[0].hp; let hpLost = finalHp - startingHp; expect(hpLost).toBe(0); game.move.select(Moves.GRAVITY); await game.phaseInterceptor.to(TurnEndPhase); - finalHp = game.scene.getParty()[0].hp; + finalHp = game.scene.getPlayerParty()[0].hp; hpLost = finalHp - startingHp; expect(hpLost).not.toBe(0); }, 20000); diff --git a/src/test/moves/make_it_rain.test.ts b/src/test/moves/make_it_rain.test.ts index 5ac35168f92..08021227e9c 100644 --- a/src/test/moves/make_it_rain.test.ts +++ b/src/test/moves/make_it_rain.test.ts @@ -8,7 +8,6 @@ import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; import { MoveEndPhase } from "#app/phases/move-end-phase"; import { StatStageChangePhase } from "#app/phases/stat-stage-change-phase"; -const TIMEOUT = 20 * 1000; describe("Moves - Make It Rain", () => { let phaserGame: Phaser.Game; @@ -27,7 +26,7 @@ describe("Moves - Make It Rain", () => { beforeEach(() => { game = new GameManager(phaserGame); game.override.battleType("double"); - game.override.moveset([Moves.MAKE_IT_RAIN, Moves.SPLASH]); + game.override.moveset([ Moves.MAKE_IT_RAIN, Moves.SPLASH ]); game.override.enemySpecies(Species.SNORLAX); game.override.enemyAbility(Abilities.INSOMNIA); game.override.enemyMoveset(Moves.SPLASH); @@ -36,7 +35,7 @@ describe("Moves - Make It Rain", () => { }); it("should only lower SPATK stat stage by 1 once in a double battle", async () => { - await game.startBattle([Species.CHARIZARD, Species.BLASTOISE]); + await game.startBattle([ Species.CHARIZARD, Species.BLASTOISE ]); const playerPokemon = game.scene.getPlayerPokemon()!; @@ -46,13 +45,13 @@ describe("Moves - Make It Rain", () => { await game.phaseInterceptor.to(MoveEndPhase); expect(playerPokemon.getStatStage(Stat.SPATK)).toBe(-1); - }, TIMEOUT); + }); it("should apply effects even if the target faints", async () => { game.override.enemyLevel(1); // ensures the enemy will faint game.override.battleType("single"); - await game.startBattle([Species.CHARIZARD]); + await game.startBattle([ Species.CHARIZARD ]); const playerPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -63,12 +62,12 @@ describe("Moves - Make It Rain", () => { expect(enemyPokemon.isFainted()).toBe(true); expect(playerPokemon.getStatStage(Stat.SPATK)).toBe(-1); - }, TIMEOUT); + }); it("should reduce Sp. Atk. once after KOing two enemies", async () => { game.override.enemyLevel(1); // ensures the enemy will faint - await game.startBattle([Species.CHARIZARD, Species.BLASTOISE]); + await game.startBattle([ Species.CHARIZARD, Species.BLASTOISE ]); const playerPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyField(); @@ -80,10 +79,10 @@ describe("Moves - Make It Rain", () => { enemyPokemon.forEach(p => expect(p.isFainted()).toBe(true)); expect(playerPokemon.getStatStage(Stat.SPATK)).toBe(-1); - }, TIMEOUT); + }); it("should lower SPATK stat stage by 1 if it only hits the second target", async () => { - await game.startBattle([Species.CHARIZARD, Species.BLASTOISE]); + await game.startBattle([ Species.CHARIZARD, Species.BLASTOISE ]); const playerPokemon = game.scene.getPlayerPokemon()!; @@ -96,5 +95,5 @@ describe("Moves - Make It Rain", () => { await game.phaseInterceptor.to(MoveEndPhase); expect(playerPokemon.getStatStage(Stat.SPATK)).toBe(-1); - }, TIMEOUT); + }); }); diff --git a/src/test/moves/mat_block.test.ts b/src/test/moves/mat_block.test.ts index b759f49bf98..a4d9177cbdc 100644 --- a/src/test/moves/mat_block.test.ts +++ b/src/test/moves/mat_block.test.ts @@ -9,7 +9,6 @@ import { BerryPhase } from "#app/phases/berry-phase"; import { CommandPhase } from "#app/phases/command-phase"; import { TurnEndPhase } from "#app/phases/turn-end-phase"; -const TIMEOUT = 20 * 1000; describe("Moves - Mat Block", () => { let phaserGame: Phaser.Game; @@ -30,10 +29,10 @@ describe("Moves - Mat Block", () => { game.override.battleType("double"); - game.override.moveset([Moves.MAT_BLOCK, Moves.SPLASH]); + game.override.moveset([ Moves.MAT_BLOCK, Moves.SPLASH ]); game.override.enemySpecies(Species.SNORLAX); - game.override.enemyMoveset([Moves.TACKLE]); + game.override.enemyMoveset([ Moves.TACKLE ]); game.override.enemyAbility(Abilities.INSOMNIA); game.override.startingLevel(100); @@ -43,7 +42,7 @@ describe("Moves - Mat Block", () => { test( "should protect the user and allies from attack moves", async () => { - await game.startBattle([Species.CHARIZARD, Species.BLASTOISE]); + await game.startBattle([ Species.CHARIZARD, Species.BLASTOISE ]); const leadPokemon = game.scene.getPlayerField(); @@ -56,15 +55,15 @@ describe("Moves - Mat Block", () => { await game.phaseInterceptor.to(BerryPhase, false); leadPokemon.forEach(p => expect(p.hp).toBe(p.getMaxHp())); - }, TIMEOUT + } ); test( "should not protect the user and allies from status moves", async () => { - game.override.enemyMoveset([Moves.GROWL]); + game.override.enemyMoveset([ Moves.GROWL ]); - await game.startBattle([Species.CHARIZARD, Species.BLASTOISE]); + await game.startBattle([ Species.CHARIZARD, Species.BLASTOISE ]); const leadPokemon = game.scene.getPlayerField(); @@ -77,13 +76,13 @@ describe("Moves - Mat Block", () => { await game.phaseInterceptor.to(BerryPhase, false); leadPokemon.forEach(p => expect(p.getStatStage(Stat.ATK)).toBe(-2)); - }, TIMEOUT + } ); test( "should fail when used after the first turn", async () => { - await game.startBattle([Species.BLASTOISE, Species.CHARIZARD]); + await game.startBattle([ Species.BLASTOISE, Species.CHARIZARD ]); const leadPokemon = game.scene.getPlayerField(); @@ -103,6 +102,6 @@ describe("Moves - Mat Block", () => { await game.phaseInterceptor.to(BerryPhase, false); expect(leadPokemon.some((p, i) => p.hp < leadStartingHp[i])).toBeTruthy(); - }, TIMEOUT + } ); }); diff --git a/src/test/moves/metal_burst.test.ts b/src/test/moves/metal_burst.test.ts new file mode 100644 index 00000000000..3b32dd322a3 --- /dev/null +++ b/src/test/moves/metal_burst.test.ts @@ -0,0 +1,80 @@ +import { BattlerIndex } from "#app/battle"; +import { MoveResult } from "#app/field/pokemon"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; + +describe("Moves - Metal Burst", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.METAL_BURST, Moves.FISSURE, Moves.PRECIPICE_BLADES ]) + .ability(Abilities.PURE_POWER) + .startingLevel(10) + .battleType("double") + .disableCrits() + .enemySpecies(Species.PICHU) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.TACKLE); + }); + + it("should redirect target if intended target faints", async () => { + await game.classicMode.startBattle([ Species.FEEBAS, Species.FEEBAS ]); + + const [ , enemy2 ] = game.scene.getEnemyField(); + + game.move.select(Moves.METAL_BURST); + game.move.select(Moves.FISSURE, 1, BattlerIndex.ENEMY); + + await game.forceEnemyMove(Moves.TACKLE, BattlerIndex.PLAYER); + await game.forceEnemyMove(Moves.TACKLE, BattlerIndex.PLAYER_2); + + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER_2, BattlerIndex.PLAYER, BattlerIndex.ENEMY_2 ]); + + await game.phaseInterceptor.to("MoveEndPhase"); + await game.move.forceHit(); + await game.phaseInterceptor.to("MoveEndPhase"); + await game.phaseInterceptor.to("MoveEndPhase"); + + expect(enemy2.isFullHp()).toBe(false); + }); + + it("should not crash if both opponents faint before the move is used", async () => { + await game.classicMode.startBattle([ Species.FEEBAS, Species.ARCEUS ]); + + const [ enemy1, enemy2 ] = game.scene.getEnemyField(); + + game.move.select(Moves.METAL_BURST); + game.move.select(Moves.PRECIPICE_BLADES, 1); + + await game.forceEnemyMove(Moves.TACKLE, BattlerIndex.PLAYER); + await game.forceEnemyMove(Moves.TACKLE, BattlerIndex.PLAYER_2); + + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER_2, BattlerIndex.PLAYER, BattlerIndex.ENEMY_2 ]); + + await game.phaseInterceptor.to("MoveEndPhase"); + await game.move.forceHit(); + await game.phaseInterceptor.to("MoveEndPhase"); + await game.phaseInterceptor.to("BerryPhase"); + + expect(enemy1.isFainted()).toBe(true); + expect(enemy2.isFainted()).toBe(true); + expect(game.scene.getPlayerField()[0].getLastXMoves(1)[0].result).toBe(MoveResult.FAIL); + }); +}); diff --git a/src/test/moves/miracle_eye.test.ts b/src/test/moves/miracle_eye.test.ts index 0528b509c82..70f487de942 100644 --- a/src/test/moves/miracle_eye.test.ts +++ b/src/test/moves/miracle_eye.test.ts @@ -28,7 +28,7 @@ describe("Moves - Miracle Eye", () => { .enemyMoveset(Moves.SPLASH) .enemyLevel(5) .starterSpecies(Species.MAGIKARP) - .moveset([Moves.MIRACLE_EYE, Moves.CONFUSION]); + .moveset([ Moves.MIRACLE_EYE, Moves.CONFUSION ]); }); it("should allow Psychic moves to hit Dark types", async () => { @@ -43,7 +43,7 @@ describe("Moves - Miracle Eye", () => { game.move.select(Moves.MIRACLE_EYE); await game.toNextTurn(); game.move.select(Moves.CONFUSION); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to(MoveEffectPhase); expect(enemy.hp).toBeLessThan(enemy.getMaxHp()); diff --git a/src/test/moves/mist.test.ts b/src/test/moves/mist.test.ts new file mode 100644 index 00000000000..cd338f79412 --- /dev/null +++ b/src/test/moves/mist.test.ts @@ -0,0 +1,49 @@ +import { Stat } from "#enums/stat"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; + +describe("Moves - Mist", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.MIST, Moves.SPLASH ]) + .ability(Abilities.BALL_FETCH) + .battleType("double") + .disableCrits() + .enemySpecies(Species.SNORLAX) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.GROWL); + }); + + it("should prevent the user's side from having stats lowered", async () => { + await game.classicMode.startBattle([ Species.MAGIKARP, Species.FEEBAS ]); + + const playerPokemon = game.scene.getPlayerField(); + + game.move.select(Moves.MIST, 0); + game.move.select(Moves.SPLASH, 1); + + await game.phaseInterceptor.to("BerryPhase"); + + playerPokemon.forEach(p => expect(p.getStatStage(Stat.ATK)).toBe(0)); + }); + + it.todo("should be ignored by opponents with Infiltrator"); +}); diff --git a/src/test/moves/moongeist_beam.test.ts b/src/test/moves/moongeist_beam.test.ts new file mode 100644 index 00000000000..216eee482fb --- /dev/null +++ b/src/test/moves/moongeist_beam.test.ts @@ -0,0 +1,59 @@ +import { allMoves, RandomMoveAttr } from "#app/data/move"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; + +describe("Moves - Moongeist Beam", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.MOONGEIST_BEAM, Moves.METRONOME ]) + .ability(Abilities.BALL_FETCH) + .startingLevel(200) + .battleType("single") + .disableCrits() + .enemySpecies(Species.MAGIKARP) + .enemyAbility(Abilities.STURDY) + .enemyMoveset(Moves.SPLASH); + }); + + // Also covers Photon Geyser and Sunsteel Strike + it("should ignore enemy abilities", async () => { + await game.classicMode.startBattle([ Species.MILOTIC ]); + + const enemy = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.MOONGEIST_BEAM); + await game.phaseInterceptor.to("BerryPhase"); + + expect(enemy.isFainted()).toBe(true); + }); + + // Also covers Photon Geyser and Sunsteel Strike + it("should not ignore enemy abilities when called by another move, such as metronome", async () => { + await game.classicMode.startBattle([ Species.MILOTIC ]); + vi.spyOn(allMoves[Moves.METRONOME].getAttrs(RandomMoveAttr)[0], "getMoveOverride").mockReturnValue(Moves.MOONGEIST_BEAM); + + game.move.select(Moves.METRONOME); + await game.phaseInterceptor.to("BerryPhase"); + + expect(game.scene.getEnemyPokemon()!.isFainted()).toBe(false); + expect(game.scene.getPlayerPokemon()!.getLastXMoves()[0].move).toBe(Moves.MOONGEIST_BEAM); + }); +}); diff --git a/src/test/moves/multi_target.test.ts b/src/test/moves/multi_target.test.ts index 5e830f23fc7..965876d3445 100644 --- a/src/test/moves/multi_target.test.ts +++ b/src/test/moves/multi_target.test.ts @@ -7,7 +7,6 @@ import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Multi-target damage reduction", () => { let phaserGame: Phaser.Game; @@ -33,18 +32,18 @@ describe("Multi-target damage reduction", () => { .enemySpecies(Species.POLIWAG) .enemyMoveset(Moves.SPLASH) .enemyAbility(Abilities.BALL_FETCH) - .moveset([Moves.TACKLE, Moves.DAZZLING_GLEAM, Moves.EARTHQUAKE, Moves.SPLASH]) + .moveset([ Moves.TACKLE, Moves.DAZZLING_GLEAM, Moves.EARTHQUAKE, Moves.SPLASH ]) .ability(Abilities.BALL_FETCH); }); it("should reduce d.gleam damage when multiple enemies but not tackle", async () => { - await game.startBattle([Species.MAGIKARP, Species.FEEBAS]); + await game.startBattle([ Species.MAGIKARP, Species.FEEBAS ]); - const [enemy1, enemy2] = game.scene.getEnemyField(); + const [ enemy1, enemy2 ] = game.scene.getEnemyField(); game.move.select(Moves.DAZZLING_GLEAM); game.move.select(Moves.TACKLE, 1, BattlerIndex.ENEMY); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2 ]); await game.phaseInterceptor.to("MoveEndPhase"); const gleam1 = enemy1.getMaxHp() - enemy1.hp; @@ -60,7 +59,7 @@ describe("Multi-target damage reduction", () => { game.move.select(Moves.DAZZLING_GLEAM); game.move.select(Moves.TACKLE, 1, BattlerIndex.ENEMY); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to("MoveEndPhase"); @@ -75,17 +74,17 @@ describe("Multi-target damage reduction", () => { // Moves that target all enemies get reduced if there's more than one enemy expect(gleam1).toBeLessThanOrEqual(Utils.toDmgValue(gleam2 * 0.75) + 1); expect(gleam1).toBeGreaterThanOrEqual(Utils.toDmgValue(gleam2 * 0.75) - 1); - }, TIMEOUT); + }); it("should reduce earthquake when more than one pokemon other than user is not fainted", async () => { - await game.startBattle([Species.MAGIKARP, Species.FEEBAS]); + await game.startBattle([ Species.MAGIKARP, Species.FEEBAS ]); - const player2 = game.scene.getParty()[1]; - const [enemy1, enemy2] = game.scene.getEnemyField(); + const player2 = game.scene.getPlayerParty()[1]; + const [ enemy1, enemy2 ] = game.scene.getEnemyField(); game.move.select(Moves.EARTHQUAKE); game.move.select(Moves.SPLASH, 1); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2 ]); await game.phaseInterceptor.to("MoveEndPhase"); @@ -100,7 +99,7 @@ describe("Multi-target damage reduction", () => { game.move.select(Moves.EARTHQUAKE); game.move.select(Moves.SPLASH, 1); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to("MoveEndPhase"); @@ -118,7 +117,7 @@ describe("Multi-target damage reduction", () => { await game.toNextTurn(); game.move.select(Moves.EARTHQUAKE); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to("MoveEndPhase"); @@ -126,5 +125,5 @@ describe("Multi-target damage reduction", () => { // Turn 3: 1 target, should be no damage reduction expect(damageEnemy1Turn1).toBeLessThanOrEqual(Utils.toDmgValue(damageEnemy1Turn3 * 0.75) + 1); expect(damageEnemy1Turn1).toBeGreaterThanOrEqual(Utils.toDmgValue(damageEnemy1Turn3 * 0.75) - 1); - }, TIMEOUT); + }); }); diff --git a/src/test/moves/nightmare.test.ts b/src/test/moves/nightmare.test.ts new file mode 100644 index 00000000000..850b0793b1e --- /dev/null +++ b/src/test/moves/nightmare.test.ts @@ -0,0 +1,52 @@ +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import { StatusEffect } from "#enums/status-effect"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; + +describe("Moves - Nightmare", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + + game.override.battleType("single") + .enemySpecies(Species.RATTATA) + .enemyMoveset(Moves.SPLASH) + .enemyAbility(Abilities.BALL_FETCH) + .enemyStatusEffect(StatusEffect.SLEEP) + .startingLevel(5) + .moveset([ Moves.NIGHTMARE, Moves.SPLASH ]); + }); + + it("lowers enemy hp by 1/4 each turn while asleep", async () => { + await game.classicMode.startBattle([ Species.HYPNO ]); + + const enemyPokemon = game.scene.getEnemyPokemon()!; + const enemyMaxHP = enemyPokemon.hp; + + game.move.select(Moves.NIGHTMARE); + await game.toNextTurn(); + + expect(enemyPokemon.hp).toBe(enemyMaxHP - Math.floor(enemyMaxHP / 4)); + + // take a second turn to make sure damage occurs again + game.move.select(Moves.SPLASH); + await game.toNextTurn(); + + expect(enemyPokemon.hp).toBe(enemyMaxHP - Math.floor(enemyMaxHP / 4) - Math.floor(enemyMaxHP / 4)); + }); +}); diff --git a/src/test/moves/obstruct.test.ts b/src/test/moves/obstruct.test.ts index eb12daa785d..1649c199e32 100644 --- a/src/test/moves/obstruct.test.ts +++ b/src/test/moves/obstruct.test.ts @@ -1,6 +1,7 @@ -import { Moves } from "#app/enums/moves"; -import { Stat } from "#app/enums/stat"; import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import { Stat } from "#enums/stat"; import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; @@ -8,8 +9,6 @@ import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; describe("Moves - Obstruct", () => { let phaserGame: Phaser.Game; let game: GameManager; - const TIMEOUT = 20 * 1000; - beforeAll(() => { phaserGame = new Phaser.Game({ type: Phaser.HEADLESS, @@ -24,13 +23,15 @@ describe("Moves - Obstruct", () => { game = new GameManager(phaserGame); game.override .battleType("single") + .enemySpecies(Species.MAGIKARP) + .enemyMoveset(Moves.TACKLE) .enemyAbility(Abilities.BALL_FETCH) .ability(Abilities.BALL_FETCH) - .moveset([Moves.OBSTRUCT]); + .moveset([ Moves.OBSTRUCT ]) + .starterSpecies(Species.FEEBAS); }); it("protects from contact damaging moves and lowers the opponent's defense by 2 stages", async () => { - game.override.enemyMoveset(Array(4).fill(Moves.ICE_PUNCH)); await game.classicMode.startBattle(); game.move.select(Moves.OBSTRUCT); @@ -41,10 +42,9 @@ describe("Moves - Obstruct", () => { expect(player.isFullHp()).toBe(true); expect(enemy.getStatStage(Stat.DEF)).toBe(-2); - }, TIMEOUT); + }); it("bypasses accuracy checks when applying protection and defense reduction", async () => { - game.override.enemyMoveset(Array(4).fill(Moves.ICE_PUNCH)); await game.classicMode.startBattle(); game.move.select(Moves.OBSTRUCT); @@ -57,11 +57,11 @@ describe("Moves - Obstruct", () => { await game.phaseInterceptor.to("TurnEndPhase"); expect(player.isFullHp()).toBe(true); expect(enemy.getStatStage(Stat.DEF)).toBe(-2); - }, TIMEOUT + } ); it("protects from non-contact damaging moves and doesn't lower the opponent's defense by 2 stages", async () => { - game.override.enemyMoveset(Array(4).fill(Moves.WATER_GUN)); + game.override.enemyMoveset(Moves.WATER_GUN); await game.classicMode.startBattle(); game.move.select(Moves.OBSTRUCT); @@ -72,10 +72,10 @@ describe("Moves - Obstruct", () => { expect(player.isFullHp()).toBe(true); expect(enemy.getStatStage(Stat.DEF)).toBe(0); - }, TIMEOUT); + }); it("doesn't protect from status moves", async () => { - game.override.enemyMoveset(Array(4).fill(Moves.GROWL)); + game.override.enemyMoveset(Moves.GROWL); await game.classicMode.startBattle(); game.move.select(Moves.OBSTRUCT); @@ -84,5 +84,15 @@ describe("Moves - Obstruct", () => { const player = game.scene.getPlayerPokemon()!; expect(player.getStatStage(Stat.ATK)).toBe(-1); - }, TIMEOUT); + }); + + it("doesn't reduce the stats of an opponent with Clear Body/etc", async () => { + game.override.enemyAbility(Abilities.CLEAR_BODY); + await game.classicMode.startBattle(); + + game.move.select(Moves.OBSTRUCT); + await game.phaseInterceptor.to("BerryPhase"); + + expect(game.scene.getEnemyPokemon()!.getStatStage(Stat.DEF)).toBe(0); + }); }); diff --git a/src/test/moves/octolock.test.ts b/src/test/moves/octolock.test.ts index 7618b08e9fc..d80b71a51e1 100644 --- a/src/test/moves/octolock.test.ts +++ b/src/test/moves/octolock.test.ts @@ -36,7 +36,7 @@ describe("Moves - Octolock", () => { .ability(Abilities.BALL_FETCH); }); - it("lowers DEF and SPDEF stat stages of the target Pokemon by 1 each turn", { timeout: 10000 }, async () => { + it("lowers DEF and SPDEF stat stages of the target Pokemon by 1 each turn", async () => { await game.classicMode.startBattle([ Species.GRAPPLOCT ]); const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -57,7 +57,7 @@ describe("Moves - Octolock", () => { expect(enemyPokemon.getStatStage(Stat.SPDEF)).toBe(-2); }); - it("if target pokemon has BIG_PECKS, should only lower SPDEF stat stage by 1", { timeout: 10000 }, async () => { + it("if target pokemon has BIG_PECKS, should only lower SPDEF stat stage by 1", async () => { game.override.enemyAbility(Abilities.BIG_PECKS); await game.classicMode.startBattle([ Species.GRAPPLOCT ]); @@ -71,7 +71,7 @@ describe("Moves - Octolock", () => { expect(enemyPokemon.getStatStage(Stat.SPDEF)).toBe(-1); }); - it("if target pokemon has WHITE_SMOKE, should not reduce any stat stages", { timeout: 10000 }, async () => { + it("if target pokemon has WHITE_SMOKE, should not reduce any stat stages", async () => { game.override.enemyAbility(Abilities.WHITE_SMOKE); await game.classicMode.startBattle([ Species.GRAPPLOCT ]); @@ -85,7 +85,7 @@ describe("Moves - Octolock", () => { expect(enemyPokemon.getStatStage(Stat.SPDEF)).toBe(0); }); - it("if target pokemon has CLEAR_BODY, should not reduce any stat stages", { timeout: 10000 }, async () => { + it("if target pokemon has CLEAR_BODY, should not reduce any stat stages", async () => { game.override.enemyAbility(Abilities.CLEAR_BODY); await game.classicMode.startBattle([ Species.GRAPPLOCT ]); @@ -99,7 +99,7 @@ describe("Moves - Octolock", () => { expect(enemyPokemon.getStatStage(Stat.SPDEF)).toBe(0); }); - it("traps the target pokemon", { timeout: 10000 }, async () => { + it("traps the target pokemon", async () => { await game.classicMode.startBattle([ Species.GRAPPLOCT ]); const enemyPokemon = game.scene.getEnemyPokemon()!; diff --git a/src/test/moves/order_up.test.ts b/src/test/moves/order_up.test.ts new file mode 100644 index 00000000000..d0b52dc1a9d --- /dev/null +++ b/src/test/moves/order_up.test.ts @@ -0,0 +1,85 @@ +import { BattlerIndex } from "#app/battle"; +import { BattlerTagType } from "#enums/battler-tag-type"; +import { PokemonAnimType } from "#enums/pokemon-anim-type"; +import { EffectiveStat, Stat } from "#enums/stat"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; + +describe("Moves - Order Up", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset(Moves.ORDER_UP) + .ability(Abilities.COMMANDER) + .battleType("double") + .disableCrits() + .enemySpecies(Species.SNORLAX) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.SPLASH) + .startingLevel(100) + .enemyLevel(100); + + vi.spyOn(game.scene, "triggerPokemonBattleAnim").mockReturnValue(true); + }); + + it.each([ + { formIndex: 0, formName: "Curly", stat: Stat.ATK, statName: "Attack" }, + { formIndex: 1, formName: "Droopy", stat: Stat.DEF, statName: "Defense" }, + { formIndex: 2, formName: "Stretchy", stat: Stat.SPD, statName: "Speed" } + ])("should raise the user's $statName when the user is commanded by a $formName Tatsugiri", async ({ formIndex, stat }) => { + game.override.starterForms({ [Species.TATSUGIRI]: formIndex }); + + await game.classicMode.startBattle([ Species.TATSUGIRI, Species.DONDOZO ]); + + const [ tatsugiri, dondozo ] = game.scene.getPlayerField(); + + expect(game.scene.triggerPokemonBattleAnim).toHaveBeenLastCalledWith(tatsugiri, PokemonAnimType.COMMANDER_APPLY); + expect(dondozo.getTag(BattlerTagType.COMMANDED)).toBeDefined(); + + game.move.select(Moves.ORDER_UP, 1, BattlerIndex.ENEMY); + expect(game.scene.currentBattle.turnCommands[0]?.skip).toBeTruthy(); + + await game.phaseInterceptor.to("BerryPhase", false); + + const affectedStats: EffectiveStat[] = [ Stat.ATK, Stat.DEF, Stat.SPATK, Stat.SPDEF, Stat.SPD ]; + affectedStats.forEach(st => expect(dondozo.getStatStage(st)).toBe(st === stat ? 3 : 2)); + }); + + it("should be boosted by Sheer Force while still applying a stat boost", async () => { + game.override + .passiveAbility(Abilities.SHEER_FORCE) + .starterForms({ [Species.TATSUGIRI]: 0 }); + + await game.classicMode.startBattle([ Species.TATSUGIRI, Species.DONDOZO ]); + + const [ tatsugiri, dondozo ] = game.scene.getPlayerField(); + + expect(game.scene.triggerPokemonBattleAnim).toHaveBeenLastCalledWith(tatsugiri, PokemonAnimType.COMMANDER_APPLY); + expect(dondozo.getTag(BattlerTagType.COMMANDED)).toBeDefined(); + + game.move.select(Moves.ORDER_UP, 1, BattlerIndex.ENEMY); + expect(game.scene.currentBattle.turnCommands[0]?.skip).toBeTruthy(); + + await game.phaseInterceptor.to("BerryPhase", false); + + expect(dondozo.battleData.abilitiesApplied.includes(Abilities.SHEER_FORCE)).toBeTruthy(); + expect(dondozo.getStatStage(Stat.ATK)).toBe(3); + }); +}); diff --git a/src/test/moves/parting_shot.test.ts b/src/test/moves/parting_shot.test.ts index 52cfaf98111..cfdf6c15966 100644 --- a/src/test/moves/parting_shot.test.ts +++ b/src/test/moves/parting_shot.test.ts @@ -10,7 +10,6 @@ import { FaintPhase } from "#app/phases/faint-phase"; import { MessagePhase } from "#app/phases/message-phase"; import { TurnInitPhase } from "#app/phases/turn-init-phase"; -const TIMEOUT = 20 * 1000; describe("Moves - Parting Shot", () => { let phaserGame: Phaser.Game; @@ -29,7 +28,7 @@ describe("Moves - Parting Shot", () => { beforeEach(() => { game = new GameManager(phaserGame); game.override.battleType("single"); - game.override.moveset([Moves.PARTING_SHOT, Moves.SPLASH]); + game.override.moveset([ Moves.PARTING_SHOT, Moves.SPLASH ]); game.override.enemyMoveset(Moves.SPLASH); game.override.startingLevel(5); game.override.enemyLevel(5); @@ -42,7 +41,7 @@ describe("Moves - Parting Shot", () => { game.override .enemySpecies(Species.POOCHYENA) .ability(Abilities.PRANKSTER); - await game.startBattle([Species.MURKROW, Species.MEOWTH]); + await game.startBattle([ Species.MURKROW, Species.MEOWTH ]); const enemyPokemon = game.scene.getEnemyPokemon()!; expect(enemyPokemon).toBeDefined(); @@ -53,7 +52,7 @@ describe("Moves - Parting Shot", () => { expect(enemyPokemon.getStatStage(Stat.ATK)).toBe(0); expect(enemyPokemon.getStatStage(Stat.SPATK)).toBe(0); expect(game.scene.getPlayerField()[0].species.speciesId).toBe(Species.MURKROW); - }, TIMEOUT + } ); test( @@ -62,7 +61,7 @@ describe("Moves - Parting Shot", () => { game.override .enemySpecies(Species.GHOLDENGO) .enemyAbility(Abilities.GOOD_AS_GOLD); - await game.startBattle([Species.MURKROW, Species.MEOWTH]); + await game.startBattle([ Species.MURKROW, Species.MEOWTH ]); const enemyPokemon = game.scene.getEnemyPokemon()!; expect(enemyPokemon).toBeDefined(); @@ -73,31 +72,31 @@ describe("Moves - Parting Shot", () => { expect(enemyPokemon.getStatStage(Stat.ATK)).toBe(0); expect(enemyPokemon.getStatStage(Stat.SPATK)).toBe(0); expect(game.scene.getPlayerField()[0].species.speciesId).toBe(Species.MURKROW); - }, TIMEOUT + } ); it.skip( // TODO: fix this bug to pass the test! "Parting shot should fail if target is -6/-6 de-buffed", async () => { - game.override.moveset([Moves.PARTING_SHOT, Moves.MEMENTO, Moves.SPLASH]); - await game.startBattle([Species.MEOWTH, Species.MEOWTH, Species.MEOWTH, Species.MURKROW, Species.ABRA]); + game.override.moveset([ Moves.PARTING_SHOT, Moves.MEMENTO, Moves.SPLASH ]); + await game.startBattle([ Species.MEOWTH, Species.MEOWTH, Species.MEOWTH, Species.MURKROW, Species.ABRA ]); // use Memento 3 times to debuff enemy game.move.select(Moves.MEMENTO); await game.phaseInterceptor.to(FaintPhase); - expect(game.scene.getParty()[0].isFainted()).toBe(true); + expect(game.scene.getPlayerParty()[0].isFainted()).toBe(true); game.doSelectPartyPokemon(1); await game.phaseInterceptor.to(TurnInitPhase, false); game.move.select(Moves.MEMENTO); await game.phaseInterceptor.to(FaintPhase); - expect(game.scene.getParty()[0].isFainted()).toBe(true); + expect(game.scene.getPlayerParty()[0].isFainted()).toBe(true); game.doSelectPartyPokemon(2); await game.phaseInterceptor.to(TurnInitPhase, false); game.move.select(Moves.MEMENTO); await game.phaseInterceptor.to(FaintPhase); - expect(game.scene.getParty()[0].isFainted()).toBe(true); + expect(game.scene.getPlayerParty()[0].isFainted()).toBe(true); game.doSelectPartyPokemon(3); // set up done @@ -115,7 +114,7 @@ describe("Moves - Parting Shot", () => { expect(enemyPokemon.getStatStage(Stat.ATK)).toBe(-6); expect(enemyPokemon.getStatStage(Stat.SPATK)).toBe(-6); expect(game.scene.getPlayerField()[0].species.speciesId).toBe(Species.MURKROW); - }, TIMEOUT + } ); it.skip( // TODO: fix this bug to pass the test! @@ -124,8 +123,8 @@ describe("Moves - Parting Shot", () => { game.override .enemySpecies(Species.ALTARIA) .enemyAbility(Abilities.NONE) - .enemyMoveset([Moves.MIST]); - await game.startBattle([Species.SNORLAX, Species.MEOWTH]); + .enemyMoveset([ Moves.MIST ]); + await game.startBattle([ Species.SNORLAX, Species.MEOWTH ]); const enemyPokemon = game.scene.getEnemyPokemon()!; expect(enemyPokemon).toBeDefined(); @@ -136,7 +135,7 @@ describe("Moves - Parting Shot", () => { expect(enemyPokemon.getStatStage(Stat.ATK)).toBe(0); expect(enemyPokemon.getStatStage(Stat.SPATK)).toBe(0); expect(game.scene.getPlayerField()[0].species.speciesId).toBe(Species.MURKROW); - }, TIMEOUT + } ); it.skip( // TODO: fix this bug to pass the test! @@ -145,7 +144,7 @@ describe("Moves - Parting Shot", () => { game.override .enemySpecies(Species.TENTACOOL) .enemyAbility(Abilities.CLEAR_BODY); - await game.startBattle([Species.SNORLAX, Species.MEOWTH]); + await game.startBattle([ Species.SNORLAX, Species.MEOWTH ]); const enemyPokemon = game.scene.getEnemyPokemon()!; expect(enemyPokemon).toBeDefined(); @@ -156,13 +155,13 @@ describe("Moves - Parting Shot", () => { expect(enemyPokemon.getStatStage(Stat.ATK)).toBe(0); expect(enemyPokemon.getStatStage(Stat.SPATK)).toBe(0); expect(game.scene.getPlayerField()[0].species.speciesId).toBe(Species.MURKROW); - }, TIMEOUT + } ); it.skip( // TODO: fix this bug to pass the test! "Parting shot should de-buff and not fail if no party available to switch - party size 1", async () => { - await game.startBattle([Species.MURKROW]); + await game.startBattle([ Species.MURKROW ]); const enemyPokemon = game.scene.getEnemyPokemon()!; expect(enemyPokemon).toBeDefined(); @@ -173,18 +172,18 @@ describe("Moves - Parting Shot", () => { expect(enemyPokemon.getStatStage(Stat.ATK)).toBe(-1); expect(enemyPokemon.getStatStage(Stat.SPATK)).toBe(-1); expect(game.scene.getPlayerField()[0].species.speciesId).toBe(Species.MURKROW); - }, TIMEOUT + } ); it.skip( // TODO: fix this bug to pass the test! "Parting shot regularly not fail if no party available to switch - party fainted", async () => { - await game.startBattle([Species.MURKROW, Species.MEOWTH]); + await game.startBattle([ Species.MURKROW, Species.MEOWTH ]); game.move.select(Moves.SPLASH); // intentionally kill party pokemon, switch to second slot (now 1 party mon is fainted) - await game.killPokemon(game.scene.getParty()[0]); - expect(game.scene.getParty()[0].isFainted()).toBe(true); + await game.killPokemon(game.scene.getPlayerParty()[0]); + expect(game.scene.getPlayerParty()[0].isFainted()).toBe(true); await game.phaseInterceptor.run(MessagePhase); game.doSelectPartyPokemon(1); @@ -196,6 +195,6 @@ describe("Moves - Parting Shot", () => { expect(enemyPokemon.getStatStage(Stat.ATK)).toBe(0); expect(enemyPokemon.getStatStage(Stat.SPATK)).toBe(0); expect(game.scene.getPlayerField()[0].species.speciesId).toBe(Species.MEOWTH); - }, TIMEOUT + } ); }); diff --git a/src/test/moves/plasma_fists.test.ts b/src/test/moves/plasma_fists.test.ts new file mode 100644 index 00000000000..4075c1ab988 --- /dev/null +++ b/src/test/moves/plasma_fists.test.ts @@ -0,0 +1,98 @@ +import { BattlerIndex } from "#app/battle"; +import { Type } from "#enums/type"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, it, expect, vi } from "vitest"; + +describe("Moves - Plasma Fists", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.PLASMA_FISTS, Moves.TACKLE ]) + .battleType("double") + .startingLevel(100) + .enemySpecies(Species.DUSCLOPS) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.TACKLE) + .enemyLevel(100); + }); + + it("should convert all subsequent Normal-type attacks to Electric-type", async () => { + await game.classicMode.startBattle([ Species.DUSCLOPS, Species.BLASTOISE ]); + + const field = game.scene.getField(true); + field.forEach(p => vi.spyOn(p, "getMoveType")); + + game.move.select(Moves.PLASMA_FISTS, 0, BattlerIndex.ENEMY); + game.move.select(Moves.TACKLE, 1, BattlerIndex.ENEMY_2); + + await game.forceEnemyMove(Moves.TACKLE, BattlerIndex.PLAYER); + await game.forceEnemyMove(Moves.TACKLE, BattlerIndex.PLAYER_2); + + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2 ]); + + await game.phaseInterceptor.to("BerryPhase", false); + + field.forEach(p => { + expect(p.getMoveType).toHaveLastReturnedWith(Type.ELECTRIC); + expect(p.hp).toBeLessThan(p.getMaxHp()); + }); + }); + + it("should not affect Normal-type attacks boosted by Pixilate", async () => { + game.override + .battleType("single") + .enemyAbility(Abilities.PIXILATE); + + await game.classicMode.startBattle([ Species.ONIX ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const enemyPokemon = game.scene.getEnemyPokemon()!; + vi.spyOn(enemyPokemon, "getMoveType"); + + game.move.select(Moves.PLASMA_FISTS); + + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + await game.phaseInterceptor.to("BerryPhase", false); + + expect(enemyPokemon.getMoveType).toHaveLastReturnedWith(Type.FAIRY); + expect(playerPokemon.hp).toBeLessThan(playerPokemon.getMaxHp()); + }); + + it("should affect moves that become Normal type due to Normalize", async () => { + game.override + .battleType("single") + .enemyAbility(Abilities.NORMALIZE) + .enemyMoveset(Moves.WATER_GUN); + + await game.classicMode.startBattle([ Species.DUSCLOPS ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const enemyPokemon = game.scene.getEnemyPokemon()!; + vi.spyOn(enemyPokemon, "getMoveType"); + + game.move.select(Moves.PLASMA_FISTS); + + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + await game.phaseInterceptor.to("BerryPhase", false); + + expect(enemyPokemon.getMoveType).toHaveLastReturnedWith(Type.ELECTRIC); + expect(playerPokemon.hp).toBeLessThan(playerPokemon.getMaxHp()); + }); +}); diff --git a/src/test/moves/pledge_moves.test.ts b/src/test/moves/pledge_moves.test.ts new file mode 100644 index 00000000000..64d586e7ba4 --- /dev/null +++ b/src/test/moves/pledge_moves.test.ts @@ -0,0 +1,337 @@ +import { BattlerIndex } from "#app/battle"; +import { allAbilities } from "#app/data/ability"; +import { ArenaTagSide } from "#app/data/arena-tag"; +import { allMoves, FlinchAttr } from "#app/data/move"; +import { Type } from "#enums/type"; +import { ArenaTagType } from "#enums/arena-tag-type"; +import { Stat } from "#enums/stat"; +import { toDmgValue } from "#app/utils"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, it, expect, vi } from "vitest"; + +describe("Moves - Pledge Moves", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .battleType("double") + .startingLevel(100) + .moveset([ Moves.FIRE_PLEDGE, Moves.GRASS_PLEDGE, Moves.WATER_PLEDGE, Moves.SPLASH ]) + .enemySpecies(Species.SNORLAX) + .enemyLevel(100) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.SPLASH); + }); + + it( + "Fire Pledge - should be an 80-power Fire-type attack outside of combination", + async () => { + await game.classicMode.startBattle([ Species.BLASTOISE, Species.CHARIZARD ]); + + const firePledge = allMoves[Moves.FIRE_PLEDGE]; + vi.spyOn(firePledge, "calculateBattlePower"); + + const playerPokemon = game.scene.getPlayerField(); + vi.spyOn(playerPokemon[0], "getMoveType"); + + game.move.select(Moves.FIRE_PLEDGE, 0, BattlerIndex.ENEMY); + game.move.select(Moves.SPLASH, 1); + + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2 ]); + await game.phaseInterceptor.to("MoveEndPhase", false); + + expect(firePledge.calculateBattlePower).toHaveLastReturnedWith(80); + expect(playerPokemon[0].getMoveType).toHaveLastReturnedWith(Type.FIRE); + } + ); + + it( + "Fire Pledge - should not combine with an ally using Fire Pledge", + async () => { + await game.classicMode.startBattle([ Species.BLASTOISE, Species.CHARIZARD ]); + + const firePledge = allMoves[Moves.FIRE_PLEDGE]; + vi.spyOn(firePledge, "calculateBattlePower"); + + const playerPokemon = game.scene.getPlayerField(); + playerPokemon.forEach(p => vi.spyOn(p, "getMoveType")); + + const enemyPokemon = game.scene.getEnemyField(); + + game.move.select(Moves.FIRE_PLEDGE, 0, BattlerIndex.ENEMY); + game.move.select(Moves.FIRE_PLEDGE, 0, BattlerIndex.ENEMY_2); + + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2 ]); + + await game.phaseInterceptor.to("MoveEndPhase"); + expect(firePledge.calculateBattlePower).toHaveLastReturnedWith(80); + expect(playerPokemon[0].getMoveType).toHaveLastReturnedWith(Type.FIRE); + + await game.phaseInterceptor.to("BerryPhase", false); + expect(firePledge.calculateBattlePower).toHaveLastReturnedWith(80); + expect(playerPokemon[1].getMoveType).toHaveLastReturnedWith(Type.FIRE); + + enemyPokemon.forEach(p => expect(p.hp).toBeLessThan(p.getMaxHp())); + } + ); + + it( + "Fire Pledge - should not combine with an enemy's Pledge move", + async () => { + game.override + .battleType("single") + .enemyMoveset(Moves.GRASS_PLEDGE); + + await game.classicMode.startBattle([ Species.CHARIZARD ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const enemyPokemon = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.FIRE_PLEDGE); + + await game.toNextTurn(); + + // Neither Pokemon should defer their move's effects as they would + // if they combined moves, so both should be damaged. + expect(playerPokemon.hp).toBeLessThan(playerPokemon.getMaxHp()); + expect(enemyPokemon.hp).toBeLessThan(enemyPokemon.getMaxHp()); + expect(game.scene.arena.getTag(ArenaTagType.FIRE_GRASS_PLEDGE)).toBeUndefined(); + } + ); + + it( + "Grass Pledge - should combine with Fire Pledge to form a 150-power Fire-type attack that creates a 'sea of fire'", + async () => { + await game.classicMode.startBattle([ Species.CHARIZARD, Species.BLASTOISE ]); + + const grassPledge = allMoves[Moves.GRASS_PLEDGE]; + vi.spyOn(grassPledge, "calculateBattlePower"); + + const playerPokemon = game.scene.getPlayerField(); + const enemyPokemon = game.scene.getEnemyField(); + + vi.spyOn(playerPokemon[1], "getMoveType"); + const baseDmgMock = vi.spyOn(enemyPokemon[0], "getBaseDamage"); + + game.move.select(Moves.FIRE_PLEDGE, 0, BattlerIndex.ENEMY_2); + game.move.select(Moves.GRASS_PLEDGE, 1, BattlerIndex.ENEMY); + + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2 ]); + // advance to the end of PLAYER_2's move this turn + for (let i = 0; i < 2; i++) { + await game.phaseInterceptor.to("MoveEndPhase"); + } + expect(playerPokemon[1].getMoveType).toHaveLastReturnedWith(Type.FIRE); + expect(grassPledge.calculateBattlePower).toHaveLastReturnedWith(150); + + const baseDmg = baseDmgMock.mock.results[baseDmgMock.mock.results.length - 1].value; + expect(enemyPokemon[0].getMaxHp() - enemyPokemon[0].hp).toBe(toDmgValue(baseDmg * 1.5)); + expect(enemyPokemon[1].hp).toBe(enemyPokemon[1].getMaxHp()); // PLAYER should not have attacked + expect(game.scene.arena.getTagOnSide(ArenaTagType.FIRE_GRASS_PLEDGE, ArenaTagSide.ENEMY)).toBeDefined(); + + const enemyStartingHp = enemyPokemon.map(p => p.hp); + await game.toNextTurn(); + enemyPokemon.forEach((p, i) => expect(enemyStartingHp[i] - p.hp).toBe(toDmgValue(p.getMaxHp() / 8))); + } + ); + + it( + "Fire Pledge - should combine with Water Pledge to form a 150-power Water-type attack that creates a 'rainbow'", + async () => { + game.override.moveset([ Moves.FIRE_PLEDGE, Moves.WATER_PLEDGE, Moves.FIERY_DANCE, Moves.SPLASH ]); + + await game.classicMode.startBattle([ Species.BLASTOISE, Species.VENUSAUR ]); + + const firePledge = allMoves[Moves.FIRE_PLEDGE]; + vi.spyOn(firePledge, "calculateBattlePower"); + + const playerPokemon = game.scene.getPlayerField(); + const enemyPokemon = game.scene.getEnemyField(); + + vi.spyOn(playerPokemon[1], "getMoveType"); + + game.move.select(Moves.WATER_PLEDGE, 0, BattlerIndex.ENEMY_2); + game.move.select(Moves.FIRE_PLEDGE, 1, BattlerIndex.ENEMY); + + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2 ]); + // advance to the end of PLAYER_2's move this turn + for (let i = 0; i < 2; i++) { + await game.phaseInterceptor.to("MoveEndPhase"); + } + expect(playerPokemon[1].getMoveType).toHaveLastReturnedWith(Type.WATER); + expect(firePledge.calculateBattlePower).toHaveLastReturnedWith(150); + expect(enemyPokemon[1].hp).toBe(enemyPokemon[1].getMaxHp()); // PLAYER should not have attacked + expect(game.scene.arena.getTagOnSide(ArenaTagType.WATER_FIRE_PLEDGE, ArenaTagSide.PLAYER)).toBeDefined(); + + await game.toNextTurn(); + + game.move.select(Moves.FIERY_DANCE, 0, BattlerIndex.ENEMY_2); + game.move.select(Moves.SPLASH, 1); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2 ]); + await game.phaseInterceptor.to("MoveEndPhase"); + + // Rainbow effect should increase Fiery Dance's chance of raising Sp. Atk to 100% + expect(playerPokemon[0].getStatStage(Stat.SPATK)).toBe(1); + } + ); + + it( + "Water Pledge - should combine with Grass Pledge to form a 150-power Grass-type attack that creates a 'swamp'", + async () => { + await game.classicMode.startBattle([ Species.BLASTOISE, Species.CHARIZARD ]); + + const waterPledge = allMoves[Moves.WATER_PLEDGE]; + vi.spyOn(waterPledge, "calculateBattlePower"); + + const playerPokemon = game.scene.getPlayerField(); + const enemyPokemon = game.scene.getEnemyField(); + const enemyStartingSpd = enemyPokemon.map(p => p.getEffectiveStat(Stat.SPD)); + + vi.spyOn(playerPokemon[1], "getMoveType"); + + game.move.select(Moves.GRASS_PLEDGE, 0, BattlerIndex.ENEMY_2); + game.move.select(Moves.WATER_PLEDGE, 1, BattlerIndex.ENEMY); + + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2 ]); + // advance to the end of PLAYER_2's move this turn + for (let i = 0; i < 2; i++) { + await game.phaseInterceptor.to("MoveEndPhase"); + } + + expect(playerPokemon[1].getMoveType).toHaveLastReturnedWith(Type.GRASS); + expect(waterPledge.calculateBattlePower).toHaveLastReturnedWith(150); + expect(enemyPokemon[1].hp).toBe(enemyPokemon[1].getMaxHp()); + + expect(game.scene.arena.getTagOnSide(ArenaTagType.GRASS_WATER_PLEDGE, ArenaTagSide.ENEMY)).toBeDefined(); + enemyPokemon.forEach((p, i) => expect(p.getEffectiveStat(Stat.SPD)).toBe(Math.floor(enemyStartingSpd[i] / 4))); + } + ); + + it( + "Pledge Moves - should alter turn order when used in combination", + async () => { + await game.classicMode.startBattle([ Species.CHARIZARD, Species.BLASTOISE ]); + + const enemyPokemon = game.scene.getEnemyField(); + + game.move.select(Moves.WATER_PLEDGE, 0, BattlerIndex.ENEMY); + game.move.select(Moves.FIRE_PLEDGE, 1, BattlerIndex.ENEMY_2); + + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2, BattlerIndex.PLAYER_2 ]); + // PLAYER_2 should act with a combined move immediately after PLAYER as the second move in the turn + for (let i = 0; i < 2; i++) { + await game.phaseInterceptor.to("MoveEndPhase"); + } + expect(enemyPokemon[0].hp).toBe(enemyPokemon[0].getMaxHp()); + expect(enemyPokemon[1].hp).toBeLessThan(enemyPokemon[1].getMaxHp()); + } + ); + + it( + "Pledge Moves - 'rainbow' effect should not stack with Serene Grace when applied to flinching moves", + async () => { + game.override + .ability(Abilities.SERENE_GRACE) + .moveset([ Moves.FIRE_PLEDGE, Moves.WATER_PLEDGE, Moves.IRON_HEAD, Moves.SPLASH ]); + + await game.classicMode.startBattle([ Species.BLASTOISE, Species.CHARIZARD ]); + + const ironHeadFlinchAttr = allMoves[Moves.IRON_HEAD].getAttrs(FlinchAttr)[0]; + vi.spyOn(ironHeadFlinchAttr, "getMoveChance"); + + game.move.select(Moves.WATER_PLEDGE, 0, BattlerIndex.ENEMY); + game.move.select(Moves.FIRE_PLEDGE, 1, BattlerIndex.ENEMY_2); + + await game.phaseInterceptor.to("TurnEndPhase"); + + expect(game.scene.arena.getTagOnSide(ArenaTagType.WATER_FIRE_PLEDGE, ArenaTagSide.PLAYER)).toBeDefined(); + + game.move.select(Moves.IRON_HEAD, 0, BattlerIndex.ENEMY); + game.move.select(Moves.SPLASH, 1); + + await game.phaseInterceptor.to("BerryPhase", false); + + expect(ironHeadFlinchAttr.getMoveChance).toHaveLastReturnedWith(60); + } + ); + + it( + "Pledge Moves - should have no effect when the second ally's move is cancelled", + async () => { + game.override + .enemyMoveset([ Moves.SPLASH, Moves.SPORE ]); + + await game.classicMode.startBattle([ Species.BLASTOISE, Species.CHARIZARD ]); + + const enemyPokemon = game.scene.getEnemyField(); + + game.move.select(Moves.FIRE_PLEDGE, 0, BattlerIndex.ENEMY); + game.move.select(Moves.GRASS_PLEDGE, 1, BattlerIndex.ENEMY_2); + + await game.forceEnemyMove(Moves.SPORE, BattlerIndex.PLAYER_2); + await game.forceEnemyMove(Moves.SPLASH); + + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY_2 ]); + + await game.phaseInterceptor.to("BerryPhase", false); + + enemyPokemon.forEach((p) => expect(p.hp).toBe(p.getMaxHp())); + } + ); + + it( + "Pledge Moves - should ignore redirection from another Pokemon's Storm Drain", + async () => { + await game.classicMode.startBattle([ Species.BLASTOISE, Species.CHARIZARD ]); + + const enemyPokemon = game.scene.getEnemyField(); + vi.spyOn(enemyPokemon[1], "getAbility").mockReturnValue(allAbilities[Abilities.STORM_DRAIN]); + + game.move.select(Moves.WATER_PLEDGE, 0, BattlerIndex.ENEMY); + game.move.select(Moves.SPLASH, 1); + + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2 ]); + + await game.phaseInterceptor.to("MoveEndPhase", false); + + expect(enemyPokemon[0].hp).toBeLessThan(enemyPokemon[0].getMaxHp()); + expect(enemyPokemon[1].getStatStage(Stat.SPATK)).toBe(0); + } + ); + + it( + "Pledge Moves - should not ignore redirection from another Pokemon's Follow Me", + async () => { + game.override.enemyMoveset([ Moves.FOLLOW_ME, Moves.SPLASH ]); + await game.classicMode.startBattle([ Species.BLASTOISE, Species.CHARIZARD ]); + + game.move.select(Moves.WATER_PLEDGE, 0, BattlerIndex.ENEMY); + game.move.select(Moves.SPLASH, 1); + + await game.forceEnemyMove(Moves.SPLASH); + await game.forceEnemyMove(Moves.FOLLOW_ME); + + await game.phaseInterceptor.to("BerryPhase", false); + + const enemyPokemon = game.scene.getEnemyField(); + expect(enemyPokemon[0].hp).toBe(enemyPokemon[0].getMaxHp()); + expect(enemyPokemon[1].hp).toBeLessThan(enemyPokemon[1].getMaxHp()); + } + ); +}); diff --git a/src/test/moves/power_shift.test.ts b/src/test/moves/power_shift.test.ts index 3fda315193e..e389f77bedf 100644 --- a/src/test/moves/power_shift.test.ts +++ b/src/test/moves/power_shift.test.ts @@ -9,8 +9,6 @@ import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; describe("Moves - Power Shift", () => { let phaserGame: Phaser.Game; let game: GameManager; - const TIMEOUT = 20 * 1000; - beforeAll(() => { phaserGame = new Phaser.Game({ type: Phaser.HEADLESS, @@ -24,7 +22,7 @@ describe("Moves - Power Shift", () => { beforeEach(() => { game = new GameManager(phaserGame); game.override - .moveset([Moves.POWER_SHIFT, Moves.BULK_UP]) + .moveset([ Moves.POWER_SHIFT, Moves.BULK_UP ]) .battleType("single") .ability(Abilities.BALL_FETCH) .enemyAbility(Abilities.BALL_FETCH) @@ -32,7 +30,7 @@ describe("Moves - Power Shift", () => { }); it("switches the user's raw Attack stat with its raw Defense stat", async () => { - await game.classicMode.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); const playerPokemon = game.scene.getPlayerPokemon()!; @@ -59,5 +57,5 @@ describe("Moves - Power Shift", () => { // Raw stats are swapped expect(playerPokemon.getStat(Stat.ATK, false)).toBe(20); expect(playerPokemon.getStat(Stat.DEF, false)).toBe(10); - }, TIMEOUT); + }); }); diff --git a/src/test/moves/power_split.test.ts b/src/test/moves/power_split.test.ts index aaf34541567..914fa86e491 100644 --- a/src/test/moves/power_split.test.ts +++ b/src/test/moves/power_split.test.ts @@ -55,7 +55,7 @@ describe("Moves - Power Split", () => { }, 20000); it("should be idempotent", async () => { - game.override.enemyMoveset([Moves.POWER_SPLIT]); + game.override.enemyMoveset([ Moves.POWER_SPLIT ]); await game.startBattle([ Species.INDEEDEE ]); diff --git a/src/test/moves/power_swap.test.ts b/src/test/moves/power_swap.test.ts index 92cd786c050..e9a4b569c92 100644 --- a/src/test/moves/power_swap.test.ts +++ b/src/test/moves/power_swap.test.ts @@ -11,8 +11,6 @@ import { MoveEndPhase } from "#app/phases/move-end-phase"; describe("Moves - Power Swap", () => { let phaserGame: Phaser.Game; let game: GameManager; - const TIMEOUT = 20 * 1000; - beforeAll(() => { phaserGame = new Phaser.Game({ type: Phaser.HEADLESS, @@ -65,5 +63,5 @@ describe("Moves - Power Swap", () => { expect(enemy.getStatStage(s)).toBe(1); } } - }, TIMEOUT); + }); }); diff --git a/src/test/moves/power_trick.test.ts b/src/test/moves/power_trick.test.ts new file mode 100644 index 00000000000..a064a43dec4 --- /dev/null +++ b/src/test/moves/power_trick.test.ts @@ -0,0 +1,113 @@ +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; +import Phaser from "phaser"; +import GameManager from "#app/test/utils/gameManager"; +import { Moves } from "#enums/moves"; +import { Stat } from "#enums/stat"; +import { Species } from "#enums/species"; +import { TurnEndPhase } from "#app/phases/turn-end-phase"; +import { Abilities } from "#enums/abilities"; +import { BattlerTagType } from "#enums/battler-tag-type"; + +describe("Moves - Power Trick", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .battleType("single") + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.SPLASH) + .enemySpecies(Species.MEW) + .enemyLevel(200) + .moveset([ Moves.POWER_TRICK ]) + .ability(Abilities.BALL_FETCH); + }); + + it("swaps the user's ATK and DEF stats", async () => { + await game.classicMode.startBattle([ Species.SHUCKLE ]); + + const player = game.scene.getPlayerPokemon()!; + const baseATK = player.getStat(Stat.ATK, false); + const baseDEF = player.getStat(Stat.DEF, false); + + game.move.select(Moves.POWER_TRICK); + + await game.phaseInterceptor.to(TurnEndPhase); + + expect(player.getStat(Stat.ATK, false)).toBe(baseDEF); + expect(player.getStat(Stat.DEF, false)).toBe(baseATK); + expect(player.getTag(BattlerTagType.POWER_TRICK)).toBeDefined(); + }); + + it("resets initial ATK and DEF stat swap when used consecutively", async () => { + await game.classicMode.startBattle([ Species.SHUCKLE ]); + + const player = game.scene.getPlayerPokemon()!; + const baseATK = player.getStat(Stat.ATK, false); + const baseDEF = player.getStat(Stat.DEF, false); + + game.move.select(Moves.POWER_TRICK); + + await game.phaseInterceptor.to(TurnEndPhase); + + game.move.select(Moves.POWER_TRICK); + + await game.phaseInterceptor.to(TurnEndPhase); + + expect(player.getStat(Stat.ATK, false)).toBe(baseATK); + expect(player.getStat(Stat.DEF, false)).toBe(baseDEF); + expect(player.getTag(BattlerTagType.POWER_TRICK)).toBeUndefined(); + }); + + it("should pass effect when using BATON_PASS", async () => { + await game.classicMode.startBattle([ Species.SHUCKLE, Species.SHUCKLE ]); + await game.override.moveset([ Moves.POWER_TRICK, Moves.BATON_PASS ]); + + const player = game.scene.getPlayerPokemon()!; + player.addTag(BattlerTagType.POWER_TRICK); + + game.move.select(Moves.BATON_PASS); + game.doSelectPartyPokemon(1); + + await game.phaseInterceptor.to(TurnEndPhase); + + const switchedPlayer = game.scene.getPlayerPokemon()!; + const baseATK = switchedPlayer.getStat(Stat.ATK); + const baseDEF = switchedPlayer.getStat(Stat.DEF); + + expect(switchedPlayer.getStat(Stat.ATK, false)).toBe(baseDEF); + expect(switchedPlayer.getStat(Stat.DEF, false)).toBe(baseATK); + expect(switchedPlayer.getTag(BattlerTagType.POWER_TRICK)).toBeDefined(); + }); + + it("should remove effect after using Transform", async () => { + await game.classicMode.startBattle([ Species.SHUCKLE, Species.SHUCKLE ]); + await game.override.moveset([ Moves.POWER_TRICK, Moves.TRANSFORM ]); + + const player = game.scene.getPlayerPokemon()!; + player.addTag(BattlerTagType.POWER_TRICK); + + game.move.select(Moves.TRANSFORM); + + await game.phaseInterceptor.to(TurnEndPhase); + + const enemy = game.scene.getEnemyPokemon()!; + const baseATK = enemy.getStat(Stat.ATK); + const baseDEF = enemy.getStat(Stat.DEF); + + expect(player.getStat(Stat.ATK, false)).toBe(baseATK); + expect(player.getStat(Stat.DEF, false)).toBe(baseDEF); + expect(player.getTag(BattlerTagType.POWER_TRICK)).toBeUndefined(); + }); +}); diff --git a/src/test/moves/protect.test.ts b/src/test/moves/protect.test.ts index 24bbcbb9d34..e639969ddf0 100644 --- a/src/test/moves/protect.test.ts +++ b/src/test/moves/protect.test.ts @@ -10,7 +10,6 @@ import { ArenaTagSide, ArenaTrapTag } from "#app/data/arena-tag"; import { BattlerIndex } from "#app/battle"; import { MoveResult } from "#app/field/pokemon"; -const TIMEOUT = 20 * 1000; describe("Moves - Protect", () => { let phaserGame: Phaser.Game; @@ -31,11 +30,11 @@ describe("Moves - Protect", () => { game.override.battleType("single"); - game.override.moveset([Moves.PROTECT]); + game.override.moveset([ Moves.PROTECT ]); game.override.enemySpecies(Species.SNORLAX); game.override.enemyAbility(Abilities.INSOMNIA); - game.override.enemyMoveset([Moves.TACKLE]); + game.override.enemyMoveset([ Moves.TACKLE ]); game.override.startingLevel(100); game.override.enemyLevel(100); @@ -44,7 +43,7 @@ describe("Moves - Protect", () => { test( "should protect the user from attacks", async () => { - await game.classicMode.startBattle([Species.CHARIZARD]); + await game.classicMode.startBattle([ Species.CHARIZARD ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -53,16 +52,16 @@ describe("Moves - Protect", () => { await game.phaseInterceptor.to("BerryPhase", false); expect(leadPokemon.hp).toBe(leadPokemon.getMaxHp()); - }, TIMEOUT + } ); test( "should prevent secondary effects from the opponent's attack", async () => { - game.override.enemyMoveset([Moves.CEASELESS_EDGE]); + game.override.enemyMoveset([ Moves.CEASELESS_EDGE ]); vi.spyOn(allMoves[Moves.CEASELESS_EDGE], "accuracy", "get").mockReturnValue(100); - await game.classicMode.startBattle([Species.CHARIZARD]); + await game.classicMode.startBattle([ Species.CHARIZARD ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -72,15 +71,15 @@ describe("Moves - Protect", () => { expect(leadPokemon.hp).toBe(leadPokemon.getMaxHp()); expect(game.scene.arena.getTagOnSide(ArenaTrapTag, ArenaTagSide.ENEMY)).toBeUndefined(); - }, TIMEOUT + } ); test( "should protect the user from status moves", async () => { - game.override.enemyMoveset([Moves.CHARM]); + game.override.enemyMoveset([ Moves.CHARM ]); - await game.classicMode.startBattle([Species.CHARIZARD]); + await game.classicMode.startBattle([ Species.CHARIZARD ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -89,15 +88,15 @@ describe("Moves - Protect", () => { await game.phaseInterceptor.to("BerryPhase", false); expect(leadPokemon.getStatStage(Stat.ATK)).toBe(0); - }, TIMEOUT + } ); test( "should stop subsequent hits of a multi-hit move", async () => { - game.override.enemyMoveset([Moves.TACHYON_CUTTER]); + game.override.enemyMoveset([ Moves.TACHYON_CUTTER ]); - await game.classicMode.startBattle([Species.CHARIZARD]); + await game.classicMode.startBattle([ Species.CHARIZARD ]); const leadPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -108,27 +107,27 @@ describe("Moves - Protect", () => { expect(leadPokemon.hp).toBe(leadPokemon.getMaxHp()); expect(enemyPokemon.turnData.hitCount).toBe(1); - }, TIMEOUT + } ); test( "should fail if the user is the last to move in the turn", async () => { - game.override.enemyMoveset([Moves.PROTECT]); + game.override.enemyMoveset([ Moves.PROTECT ]); - await game.classicMode.startBattle([Species.CHARIZARD]); + await game.classicMode.startBattle([ Species.CHARIZARD ]); const leadPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; game.move.select(Moves.PROTECT); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); await game.phaseInterceptor.to("BerryPhase", false); expect(enemyPokemon.getLastXMoves()[0].result).toBe(MoveResult.SUCCESS); expect(leadPokemon.getLastXMoves()[0].result).toBe(MoveResult.FAIL); - }, TIMEOUT + } ); }); diff --git a/src/test/moves/psycho_shift.test.ts b/src/test/moves/psycho_shift.test.ts new file mode 100644 index 00000000000..448a8c99ef0 --- /dev/null +++ b/src/test/moves/psycho_shift.test.ts @@ -0,0 +1,49 @@ +import { StatusEffect } from "#app/enums/status-effect"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; + +describe("Moves - Psycho Shift", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.PSYCHO_SHIFT ]) + .ability(Abilities.BALL_FETCH) + .statusEffect(StatusEffect.POISON) + .battleType("single") + .disableCrits() + .enemySpecies(Species.MAGIKARP) + .enemyLevel(20) + .enemyAbility(Abilities.SYNCHRONIZE) + .enemyMoveset(Moves.SPLASH); + }); + + it("If Psycho Shift is used on a Pokémon with Synchronize, the user of Psycho Shift will already be afflicted with a status condition when Synchronize activates", async () => { + await game.classicMode.startBattle([ Species.FEEBAS ]); + + const playerPokemon = game.scene.getPlayerPokemon(); + const enemyPokemon = game.scene.getEnemyPokemon(); + expect(enemyPokemon?.status).toBeUndefined(); + + game.move.select(Moves.PSYCHO_SHIFT); + await game.phaseInterceptor.to("TurnEndPhase"); + expect(playerPokemon?.status).toBeNull(); + expect(enemyPokemon?.status).toBeDefined(); + }); +}); diff --git a/src/test/moves/purify.test.ts b/src/test/moves/purify.test.ts index 15d684b2d60..171f94a611a 100644 --- a/src/test/moves/purify.test.ts +++ b/src/test/moves/purify.test.ts @@ -1,14 +1,14 @@ import { BattlerIndex } from "#app/battle"; -import { Status, StatusEffect } from "#app/data/status-effect"; +import { Status } from "#app/data/status-effect"; import { EnemyPokemon, PlayerPokemon } from "#app/field/pokemon"; import { MoveEndPhase } from "#app/phases/move-end-phase"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; +import { StatusEffect } from "#enums/status-effect"; import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, test } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Moves - Purify", () => { let phaserGame: Phaser.Game; @@ -30,11 +30,11 @@ describe("Moves - Purify", () => { game.override.starterSpecies(Species.PYUKUMUKU); game.override.startingLevel(10); - game.override.moveset([Moves.PURIFY, Moves.SIZZLY_SLIDE]); + game.override.moveset([ Moves.PURIFY, Moves.SIZZLY_SLIDE ]); game.override.enemySpecies(Species.MAGIKARP); game.override.enemyLevel(10); - game.override.enemyMoveset([Moves.SPLASH, Moves.NONE, Moves.NONE, Moves.NONE]); + game.override.enemyMoveset([ Moves.SPLASH, Moves.NONE, Moves.NONE, Moves.NONE ]); }); test( @@ -49,13 +49,12 @@ describe("Moves - Purify", () => { enemyPokemon.status = new Status(StatusEffect.BURN); game.move.select(Moves.PURIFY); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to(MoveEndPhase); expect(enemyPokemon.status).toBeNull(); expect(playerPokemon.isFullHp()).toBe(true); }, - TIMEOUT ); test( @@ -69,12 +68,11 @@ describe("Moves - Purify", () => { const playerInitialHp = playerPokemon.hp; game.move.select(Moves.PURIFY); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to(MoveEndPhase); expect(playerPokemon.hp).toBe(playerInitialHp); }, - TIMEOUT ); }); diff --git a/src/test/moves/quick_guard.test.ts b/src/test/moves/quick_guard.test.ts index 9ab0fe1509c..7bda71782aa 100644 --- a/src/test/moves/quick_guard.test.ts +++ b/src/test/moves/quick_guard.test.ts @@ -8,7 +8,6 @@ import { Stat } from "#enums/stat"; import { BattlerIndex } from "#app/battle"; import { MoveResult } from "#app/field/pokemon"; -const TIMEOUT = 20 * 1000; describe("Moves - Quick Guard", () => { let phaserGame: Phaser.Game; @@ -29,10 +28,10 @@ describe("Moves - Quick Guard", () => { game.override.battleType("double"); - game.override.moveset([Moves.QUICK_GUARD, Moves.SPLASH, Moves.FOLLOW_ME]); + game.override.moveset([ Moves.QUICK_GUARD, Moves.SPLASH, Moves.FOLLOW_ME ]); game.override.enemySpecies(Species.SNORLAX); - game.override.enemyMoveset([Moves.QUICK_ATTACK]); + game.override.enemyMoveset([ Moves.QUICK_ATTACK ]); game.override.enemyAbility(Abilities.INSOMNIA); game.override.startingLevel(100); @@ -42,7 +41,7 @@ describe("Moves - Quick Guard", () => { test( "should protect the user and allies from priority moves", async () => { - await game.classicMode.startBattle([Species.CHARIZARD, Species.BLASTOISE]); + await game.classicMode.startBattle([ Species.CHARIZARD, Species.BLASTOISE ]); const playerPokemon = game.scene.getPlayerField(); @@ -52,16 +51,16 @@ describe("Moves - Quick Guard", () => { await game.phaseInterceptor.to("BerryPhase", false); playerPokemon.forEach(p => expect(p.hp).toBe(p.getMaxHp())); - }, TIMEOUT + } ); test( "should protect the user and allies from Prankster-boosted moves", async () => { game.override.enemyAbility(Abilities.PRANKSTER); - game.override.enemyMoveset([Moves.GROWL]); + game.override.enemyMoveset([ Moves.GROWL ]); - await game.classicMode.startBattle([Species.CHARIZARD, Species.BLASTOISE]); + await game.classicMode.startBattle([ Species.CHARIZARD, Species.BLASTOISE ]); const playerPokemon = game.scene.getPlayerField(); @@ -71,15 +70,15 @@ describe("Moves - Quick Guard", () => { await game.phaseInterceptor.to("BerryPhase", false); playerPokemon.forEach(p => expect(p.getStatStage(Stat.ATK)).toBe(0)); - }, TIMEOUT + } ); test( "should stop subsequent hits of a multi-hit priority move", async () => { - game.override.enemyMoveset([Moves.WATER_SHURIKEN]); + game.override.enemyMoveset([ Moves.WATER_SHURIKEN ]); - await game.classicMode.startBattle([Species.CHARIZARD, Species.BLASTOISE]); + await game.classicMode.startBattle([ Species.CHARIZARD, Species.BLASTOISE ]); const playerPokemon = game.scene.getPlayerField(); const enemyPokemon = game.scene.getEnemyField(); @@ -98,21 +97,21 @@ describe("Moves - Quick Guard", () => { "should fail if the user is the last to move in the turn", async () => { game.override.battleType("single"); - game.override.enemyMoveset([Moves.QUICK_GUARD]); + game.override.enemyMoveset([ Moves.QUICK_GUARD ]); - await game.classicMode.startBattle([Species.CHARIZARD]); + await game.classicMode.startBattle([ Species.CHARIZARD ]); const playerPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; game.move.select(Moves.QUICK_GUARD); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); await game.phaseInterceptor.to("BerryPhase", false); expect(enemyPokemon.getLastXMoves()[0].result).toBe(MoveResult.SUCCESS); expect(playerPokemon.getLastXMoves()[0].result).toBe(MoveResult.FAIL); - }, TIMEOUT + } ); }); diff --git a/src/test/moves/rage_powder.test.ts b/src/test/moves/rage_powder.test.ts index 86bc48ef882..1b73a7f0f5f 100644 --- a/src/test/moves/rage_powder.test.ts +++ b/src/test/moves/rage_powder.test.ts @@ -6,7 +6,6 @@ import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, test } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Moves - Rage Powder", () => { let phaserGame: Phaser.Game; @@ -28,14 +27,14 @@ describe("Moves - Rage Powder", () => { game.override.enemySpecies(Species.SNORLAX); game.override.startingLevel(100); game.override.enemyLevel(100); - game.override.moveset([Moves.FOLLOW_ME, Moves.RAGE_POWDER, Moves.SPOTLIGHT, Moves.QUICK_ATTACK]); - game.override.enemyMoveset([Moves.RAGE_POWDER, Moves.TACKLE, Moves.SPLASH]); + game.override.moveset([ Moves.FOLLOW_ME, Moves.RAGE_POWDER, Moves.SPOTLIGHT, Moves.QUICK_ATTACK ]); + game.override.enemyMoveset([ Moves.RAGE_POWDER, Moves.TACKLE, Moves.SPLASH ]); }); test( "move effect should be bypassed by Grass type", async () => { - await game.classicMode.startBattle([Species.AMOONGUSS, Species.VENUSAUR]); + await game.classicMode.startBattle([ Species.AMOONGUSS, Species.VENUSAUR ]); const enemyPokemon = game.scene.getEnemyField(); @@ -50,7 +49,7 @@ describe("Moves - Rage Powder", () => { // If redirection was bypassed, both enemies should be damaged expect(enemyPokemon[0].hp).toBeLessThan(enemyPokemon[0].getMaxHp()); expect(enemyPokemon[1].hp).toBeLessThan(enemyPokemon[0].getMaxHp()); - }, TIMEOUT + } ); test( @@ -59,7 +58,7 @@ describe("Moves - Rage Powder", () => { game.override.ability(Abilities.OVERCOAT); // Test with two non-Grass type player Pokemon - await game.classicMode.startBattle([Species.BLASTOISE, Species.CHARIZARD]); + await game.classicMode.startBattle([ Species.BLASTOISE, Species.CHARIZARD ]); const enemyPokemon = game.scene.getEnemyField(); @@ -76,6 +75,6 @@ describe("Moves - Rage Powder", () => { // If redirection was bypassed, both enemies should be damaged expect(enemyPokemon[0].hp).toBeLessThan(enemyStartingHp[0]); expect(enemyPokemon[1].hp).toBeLessThan(enemyStartingHp[1]); - }, TIMEOUT + } ); }); diff --git a/src/test/moves/reflect.test.ts b/src/test/moves/reflect.test.ts index 9780ede3c55..3bf415ea75c 100644 --- a/src/test/moves/reflect.test.ts +++ b/src/test/moves/reflect.test.ts @@ -32,16 +32,16 @@ describe("Moves - Reflect", () => { game = new GameManager(phaserGame); game.override.battleType("single"); game.override.ability(Abilities.NONE); - game.override.moveset([Moves.ABSORB, Moves.ROCK_SLIDE, Moves.TACKLE]); + game.override.moveset([ Moves.ABSORB, Moves.ROCK_SLIDE, Moves.TACKLE ]); game.override.enemyLevel(100); game.override.enemySpecies(Species.MAGIKARP); - game.override.enemyMoveset([Moves.REFLECT, Moves.REFLECT, Moves.REFLECT, Moves.REFLECT]); + game.override.enemyMoveset([ Moves.REFLECT, Moves.REFLECT, Moves.REFLECT, Moves.REFLECT ]); game.override.disableCrits(); }); it("reduces damage of physical attacks by half in a single battle", async () => { const moveToUse = Moves.TACKLE; - await game.startBattle([Species.SHUCKLE]); + await game.startBattle([ Species.SHUCKLE ]); game.move.select(moveToUse); @@ -55,7 +55,7 @@ describe("Moves - Reflect", () => { game.override.battleType("double"); const moveToUse = Moves.ROCK_SLIDE; - await game.startBattle([Species.SHUCKLE, Species.SHUCKLE]); + await game.startBattle([ Species.SHUCKLE, Species.SHUCKLE ]); game.move.select(moveToUse); game.move.select(moveToUse, 1); @@ -68,7 +68,7 @@ describe("Moves - Reflect", () => { it("does not affect special attacks", async () => { const moveToUse = Moves.ABSORB; - await game.startBattle([Species.SHUCKLE]); + await game.startBattle([ Species.SHUCKLE ]); game.move.select(moveToUse); @@ -94,7 +94,7 @@ const getMockedMoveDamage = (defender: Pokemon, attacker: Pokemon, move: Move) = const side = defender.isPlayer() ? ArenaTagSide.PLAYER : ArenaTagSide.ENEMY; if (defender.scene.arena.getTagOnSide(ArenaTagType.REFLECT, side)) { - defender.scene.arena.applyTagsForSide(ArenaTagType.REFLECT, side, move.category, defender.scene.currentBattle.double, multiplierHolder); + defender.scene.arena.applyTagsForSide(ArenaTagType.REFLECT, side, false, attacker, move.category, multiplierHolder); } return move.power * multiplierHolder.value; diff --git a/src/test/moves/reflect_type.test.ts b/src/test/moves/reflect_type.test.ts new file mode 100644 index 00000000000..50e0fc2fbe6 --- /dev/null +++ b/src/test/moves/reflect_type.test.ts @@ -0,0 +1,59 @@ +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import { Type } from "#enums/type"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; + +describe("Moves - Reflect Type", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .ability(Abilities.BALL_FETCH) + .battleType("single") + .disableCrits() + .enemyAbility(Abilities.BALL_FETCH); + }); + + it("will make the user Normal/Grass if targetting a typeless Pokemon affected by Forest's Curse", async () => { + game.override + .moveset([ Moves.FORESTS_CURSE, Moves.REFLECT_TYPE ]) + .startingLevel(60) + .enemySpecies(Species.CHARMANDER) + .enemyMoveset([ Moves.BURN_UP, Moves.SPLASH ]); + await game.classicMode.startBattle([ Species.FEEBAS ]); + + const playerPokemon = game.scene.getPlayerPokemon(); + const enemyPokemon = game.scene.getEnemyPokemon(); + + game.move.select(Moves.SPLASH); + await game.forceEnemyMove(Moves.BURN_UP); + await game.toNextTurn(); + + game.move.select(Moves.FORESTS_CURSE); + await game.forceEnemyMove(Moves.SPLASH); + await game.toNextTurn(); + expect(enemyPokemon?.getTypes().includes(Type.UNKNOWN)).toBe(true); + expect(enemyPokemon?.getTypes().includes(Type.GRASS)).toBe(true); + + game.move.select(Moves.REFLECT_TYPE); + await game.forceEnemyMove(Moves.SPLASH); + await game.phaseInterceptor.to("TurnEndPhase"); + expect(playerPokemon?.getTypes()[0]).toBe(Type.NORMAL); + expect(playerPokemon?.getTypes().includes(Type.GRASS)).toBe(true); + }); +}); diff --git a/src/test/moves/relic_song.test.ts b/src/test/moves/relic_song.test.ts index 373d88f0434..c09514850eb 100644 --- a/src/test/moves/relic_song.test.ts +++ b/src/test/moves/relic_song.test.ts @@ -1,4 +1,4 @@ -import { Type } from "#app/data/type"; +import { Type } from "#enums/type"; import { Challenges } from "#app/enums/challenges"; import { Abilities } from "#enums/abilities"; import { Moves } from "#enums/moves"; @@ -10,8 +10,6 @@ import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; describe("Moves - Relic Song", () => { let phaserGame: Phaser.Game; let game: GameManager; - const TIMEOUT = 20 * 1000; - beforeAll(() => { phaserGame = new Phaser.Game({ type: Phaser.HEADLESS, @@ -25,7 +23,7 @@ describe("Moves - Relic Song", () => { beforeEach(() => { game = new GameManager(phaserGame); game.override - .moveset([Moves.RELIC_SONG, Moves.SPLASH]) + .moveset([ Moves.RELIC_SONG, Moves.SPLASH ]) .battleType("single") .enemyAbility(Abilities.BALL_FETCH) .enemyMoveset(Moves.SPLASH) @@ -34,7 +32,7 @@ describe("Moves - Relic Song", () => { }); it("swaps Meloetta's form between Aria and Pirouette", async () => { - await game.classicMode.startBattle([Species.MELOETTA]); + await game.classicMode.startBattle([ Species.MELOETTA ]); const meloetta = game.scene.getPlayerPokemon()!; @@ -47,11 +45,11 @@ describe("Moves - Relic Song", () => { await game.phaseInterceptor.to("BerryPhase"); expect(meloetta.formIndex).toBe(0); - }, TIMEOUT); + }); it("doesn't swap Meloetta's form during a mono-type challenge", async () => { game.challengeMode.addChallenge(Challenges.SINGLE_TYPE, Type.PSYCHIC + 1, 0); - await game.challengeMode.startBattle([Species.MELOETTA]); + await game.challengeMode.startBattle([ Species.MELOETTA ]); const meloetta = game.scene.getPlayerPokemon()!; @@ -62,13 +60,13 @@ describe("Moves - Relic Song", () => { await game.toNextTurn(); expect(meloetta.formIndex).toBe(0); - }, TIMEOUT); + }); it("doesn't swap Meloetta's form during biome change (arena reset)", async () => { game.override - .starterForms({[Species.MELOETTA]: 1}) + .starterForms({ [Species.MELOETTA]: 1 }) .startingWave(10); - await game.classicMode.startBattle([Species.MELOETTA]); + await game.classicMode.startBattle([ Species.MELOETTA ]); const meloetta = game.scene.getPlayerPokemon()!; @@ -77,5 +75,5 @@ describe("Moves - Relic Song", () => { await game.toNextWave(); expect(meloetta.formIndex).toBe(1); - }, TIMEOUT); + }); }); diff --git a/src/test/moves/retaliate.test.ts b/src/test/moves/retaliate.test.ts index 62965fffba6..e00b9da6010 100644 --- a/src/test/moves/retaliate.test.ts +++ b/src/test/moves/retaliate.test.ts @@ -26,16 +26,16 @@ describe("Moves - Retaliate", () => { game.override .battleType("single") .enemySpecies(Species.SNORLAX) - .enemyMoveset([Moves.RETALIATE, Moves.RETALIATE, Moves.RETALIATE, Moves.RETALIATE]) + .enemyMoveset([ Moves.RETALIATE, Moves.RETALIATE, Moves.RETALIATE, Moves.RETALIATE ]) .enemyLevel(100) - .moveset([Moves.RETALIATE, Moves.SPLASH]) + .moveset([ Moves.RETALIATE, Moves.SPLASH ]) .startingLevel(80) .disableCrits(); }); it("increases power if ally died previous turn", async () => { vi.spyOn(retaliate, "calculateBattlePower"); - await game.startBattle([Species.ABRA, Species.COBALION]); + await game.startBattle([ Species.ABRA, Species.COBALION ]); game.move.select(Moves.RETALIATE); await game.phaseInterceptor.to("TurnEndPhase"); expect(retaliate.calculateBattlePower).toHaveLastReturnedWith(70); diff --git a/src/test/moves/rollout.test.ts b/src/test/moves/rollout.test.ts index c08535a61df..199f4e1dcf2 100644 --- a/src/test/moves/rollout.test.ts +++ b/src/test/moves/rollout.test.ts @@ -35,7 +35,7 @@ describe("Moves - Rollout", () => { }); it("should double it's dmg on sequential uses but reset after 5", async () => { - game.override.moveset([Moves.ROLLOUT]); + game.override.moveset([ Moves.ROLLOUT ]); vi.spyOn(allMoves[Moves.ROLLOUT], "accuracy", "get").mockReturnValue(100); //always hit const variance = 5; @@ -44,11 +44,11 @@ describe("Moves - Rollout", () => { await game.startBattle(); - const playerPkm = game.scene.getParty()[0]; - vi.spyOn(playerPkm, "stats", "get").mockReturnValue([500000, 1, 1, 1, 1, 1]); // HP, ATK, DEF, SPATK, SPDEF, SPD + const playerPkm = game.scene.getPlayerParty()[0]; + vi.spyOn(playerPkm, "stats", "get").mockReturnValue([ 500000, 1, 1, 1, 1, 1 ]); // HP, ATK, DEF, SPATK, SPDEF, SPD const enemyPkm = game.scene.getEnemyParty()[0]; - vi.spyOn(enemyPkm, "stats", "get").mockReturnValue([500000, 1, 1, 1, 1, 1]); // HP, ATK, DEF, SPATK, SPDEF, SPD + vi.spyOn(enemyPkm, "stats", "get").mockReturnValue([ 500000, 1, 1, 1, 1, 1 ]); // HP, ATK, DEF, SPATK, SPDEF, SPD vi.spyOn(enemyPkm, "getHeldItems").mockReturnValue([]); //no berries enemyPkm.hp = enemyPkm.getMaxHp(); @@ -62,7 +62,7 @@ describe("Moves - Rollout", () => { previousHp = enemyPkm.hp; } - const [turn1Dmg, turn2Dmg, turn3Dmg, turn4Dmg, turn5Dmg, turn6Dmg] = dmgHistory; + const [ turn1Dmg, turn2Dmg, turn3Dmg, turn4Dmg, turn5Dmg, turn6Dmg ] = dmgHistory; expect(turn2Dmg).toBeGreaterThanOrEqual(turn1Dmg * 2 - variance); expect(turn2Dmg).toBeLessThanOrEqual(turn1Dmg * 2 + variance); diff --git a/src/test/moves/roost.test.ts b/src/test/moves/roost.test.ts index c1fc962e876..69301dc86cf 100644 --- a/src/test/moves/roost.test.ts +++ b/src/test/moves/roost.test.ts @@ -1,5 +1,5 @@ import { BattlerIndex } from "#app/battle"; -import { Type } from "#app/data/type"; +import { Type } from "#enums/type"; import { BattlerTagType } from "#app/enums/battler-tag-type"; import { Moves } from "#app/enums/moves"; import { Species } from "#app/enums/species"; @@ -9,7 +9,6 @@ import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, test } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Moves - Roost", () => { let phaserGame: Phaser.Game; @@ -32,7 +31,7 @@ describe("Moves - Roost", () => { game.override.startingLevel(100); game.override.enemyLevel(100); game.override.enemyMoveset(Moves.EARTHQUAKE); - game.override.moveset([Moves.ROOST, Moves.BURN_UP, Moves.DOUBLE_SHOCK]); + game.override.moveset([ Moves.ROOST, Moves.BURN_UP, Moves.DOUBLE_SHOCK ]); }); /** @@ -51,11 +50,11 @@ describe("Moves - Roost", () => { test( "Non flying type uses roost -> no type change, took damage", async () => { - await game.classicMode.startBattle([Species.DUNSPARCE]); + await game.classicMode.startBattle([ Species.DUNSPARCE ]); const playerPokemon = game.scene.getPlayerPokemon()!; const playerPokemonStartingHP = playerPokemon.hp; game.move.select(Moves.ROOST); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to(MoveEffectPhase); // Should only be normal type, and NOT flying type @@ -72,17 +71,17 @@ describe("Moves - Roost", () => { expect(playerPokemonTypes[0] === Type.NORMAL).toBeTruthy(); expect(playerPokemonTypes.length === 1).toBeTruthy(); expect(playerPokemon.isGrounded()).toBeTruthy(); - }, TIMEOUT + } ); test( "Pure flying type -> becomes normal after roost and takes damage from ground moves -> regains flying", async () => { - await game.classicMode.startBattle([Species.TORNADUS]); + await game.classicMode.startBattle([ Species.TORNADUS ]); const playerPokemon = game.scene.getPlayerPokemon()!; const playerPokemonStartingHP = playerPokemon.hp; game.move.select(Moves.ROOST); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to(MoveEffectPhase); // Should only be normal type, and NOT flying type @@ -100,17 +99,17 @@ describe("Moves - Roost", () => { expect(playerPokemonTypes[0] === Type.FLYING).toBeTruthy(); expect(playerPokemon.isGrounded()).toBeFalsy(); - }, TIMEOUT + } ); test( "Dual X/flying type -> becomes type X after roost and takes damage from ground moves -> regains flying", async () => { - await game.classicMode.startBattle([Species.HAWLUCHA]); + await game.classicMode.startBattle([ Species.HAWLUCHA ]); const playerPokemon = game.scene.getPlayerPokemon()!; const playerPokemonStartingHP = playerPokemon.hp; game.move.select(Moves.ROOST); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to(MoveEffectPhase); // Should only be pure fighting type and grounded @@ -128,18 +127,18 @@ describe("Moves - Roost", () => { expect(playerPokemonTypes[1] === Type.FLYING).toBeTruthy(); expect(playerPokemon.isGrounded()).toBeFalsy(); - }, TIMEOUT + } ); test( "Pokemon with levitate after using roost should lose flying type but still be unaffected by ground moves", async () => { game.override.starterForms({ [Species.ROTOM]: 4 }); - await game.classicMode.startBattle([Species.ROTOM]); + await game.classicMode.startBattle([ Species.ROTOM ]); const playerPokemon = game.scene.getPlayerPokemon()!; const playerPokemonStartingHP = playerPokemon.hp; game.move.select(Moves.ROOST); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to(MoveEffectPhase); // Should only be pure eletric type and grounded @@ -157,17 +156,17 @@ describe("Moves - Roost", () => { expect(playerPokemonTypes[1] === Type.FLYING).toBeTruthy(); expect(playerPokemon.isGrounded()).toBeFalsy(); - }, TIMEOUT + } ); test( "A fire/flying type that uses burn up, then roost should be typeless until end of turn", async () => { - await game.classicMode.startBattle([Species.MOLTRES]); + await game.classicMode.startBattle([ Species.MOLTRES ]); const playerPokemon = game.scene.getPlayerPokemon()!; const playerPokemonStartingHP = playerPokemon.hp; game.move.select(Moves.BURN_UP); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to(MoveEffectPhase); // Should only be pure flying type after burn up @@ -177,7 +176,7 @@ describe("Moves - Roost", () => { await game.phaseInterceptor.to(TurnEndPhase); game.move.select(Moves.ROOST); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to(MoveEffectPhase); // Should only be typeless type after roost and is grounded @@ -196,18 +195,18 @@ describe("Moves - Roost", () => { expect(playerPokemonTypes.length === 1).toBeTruthy(); expect(playerPokemon.isGrounded()).toBeFalsy(); - }, TIMEOUT + } ); test( "An electric/flying type that uses double shock, then roost should be typeless until end of turn", async () => { game.override.enemySpecies(Species.ZEKROM); - await game.classicMode.startBattle([Species.ZAPDOS]); + await game.classicMode.startBattle([ Species.ZAPDOS ]); const playerPokemon = game.scene.getPlayerPokemon()!; const playerPokemonStartingHP = playerPokemon.hp; game.move.select(Moves.DOUBLE_SHOCK); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to(MoveEffectPhase); // Should only be pure flying type after burn up @@ -217,7 +216,7 @@ describe("Moves - Roost", () => { await game.phaseInterceptor.to(TurnEndPhase); game.move.select(Moves.ROOST); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to(MoveEffectPhase); // Should only be typeless type after roost and is grounded @@ -236,14 +235,14 @@ describe("Moves - Roost", () => { expect(playerPokemonTypes.length === 1).toBeTruthy(); expect(playerPokemon.isGrounded()).toBeFalsy(); - }, TIMEOUT + } ); test( "Dual Type Pokemon afflicted with Forests Curse/Trick or Treat and post roost will become dual type and then become 3 type at end of turn", async () => { - game.override.enemyMoveset([Moves.TRICK_OR_TREAT, Moves.TRICK_OR_TREAT, Moves.TRICK_OR_TREAT, Moves.TRICK_OR_TREAT]); - await game.classicMode.startBattle([Species.MOLTRES]); + game.override.enemyMoveset([ Moves.TRICK_OR_TREAT, Moves.TRICK_OR_TREAT, Moves.TRICK_OR_TREAT, Moves.TRICK_OR_TREAT ]); + await game.classicMode.startBattle([ Species.MOLTRES ]); const playerPokemon = game.scene.getPlayerPokemon()!; game.move.select(Moves.ROOST); await game.phaseInterceptor.to(MoveEffectPhase); @@ -263,7 +262,7 @@ describe("Moves - Roost", () => { expect(playerPokemonTypes.length === 3).toBeTruthy(); expect(playerPokemon.isGrounded()).toBeFalsy(); - }, TIMEOUT + } ); }); diff --git a/src/test/moves/round.test.ts b/src/test/moves/round.test.ts new file mode 100644 index 00000000000..fd318d30c1e --- /dev/null +++ b/src/test/moves/round.test.ts @@ -0,0 +1,65 @@ +import { BattlerIndex } from "#app/battle"; +import { allMoves } from "#app/data/move"; +import { MoveEffectPhase } from "#app/phases/move-effect-phase"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; + +describe("Moves - Round", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.SPLASH, Moves.ROUND ]) + .ability(Abilities.BALL_FETCH) + .battleType("double") + .disableCrits() + .enemySpecies(Species.MAGIKARP) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset([ Moves.SPLASH, Moves.ROUND ]) + .startingLevel(100) + .enemyLevel(100); + }); + + it("should cue other instances of Round together in Speed order", async () => { + await game.classicMode.startBattle([ Species.MAGIKARP, Species.FEEBAS ]); + + const round = allMoves[Moves.ROUND]; + const spy = vi.spyOn(round, "calculateBattlePower"); + + game.move.select(Moves.ROUND, 0, BattlerIndex.ENEMY); + game.move.select(Moves.ROUND, 1, BattlerIndex.ENEMY_2); + + await game.forceEnemyMove(Moves.ROUND, BattlerIndex.PLAYER); + await game.forceEnemyMove(Moves.SPLASH); + + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY_2, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY ]); + + const actualTurnOrder: BattlerIndex[] = []; + + for (let i = 0; i < 4; i++) { + await game.phaseInterceptor.to("MoveEffectPhase", false); + actualTurnOrder.push((game.scene.getCurrentPhase() as MoveEffectPhase).getUserPokemon()!.getBattlerIndex()); + await game.phaseInterceptor.to("MoveEndPhase"); + } + + expect(actualTurnOrder).toEqual([ BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2 ]); + const powerResults = spy.mock.results.map(result => result.value); + expect(powerResults).toEqual( [ 60, 120, 120 ]); + }); +}); diff --git a/src/test/moves/safeguard.test.ts b/src/test/moves/safeguard.test.ts index 2caf698a73a..6505162fd04 100644 --- a/src/test/moves/safeguard.test.ts +++ b/src/test/moves/safeguard.test.ts @@ -8,7 +8,6 @@ import { Species } from "#enums/species"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Moves - Safeguard", () => { let phaserGame: Phaser.Game; @@ -29,12 +28,12 @@ describe("Moves - Safeguard", () => { game.override .battleType("single") .enemySpecies(Species.DRATINI) - .enemyMoveset([Moves.SAFEGUARD]) + .enemyMoveset([ Moves.SAFEGUARD ]) .enemyAbility(Abilities.BALL_FETCH) .enemyLevel(5) .starterSpecies(Species.DRATINI) - .moveset([Moves.NUZZLE, Moves.SPORE, Moves.YAWN, Moves.SPLASH]) - .ability(Abilities.BALL_FETCH); + .moveset([ Moves.NUZZLE, Moves.SPORE, Moves.YAWN, Moves.SPLASH ]) + .ability(Abilities.UNNERVE); // Stop wild Pokemon from potentially eating Lum Berry }); it("protects from damaging moves with additional effects", async () => { @@ -42,34 +41,34 @@ describe("Moves - Safeguard", () => { const enemy = game.scene.getEnemyPokemon()!; game.move.select(Moves.NUZZLE); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); await game.toNextTurn(); expect(enemy.status).toBeUndefined(); - }, TIMEOUT); + }); it("protects from status moves", async () => { await game.classicMode.startBattle(); const enemyPokemon = game.scene.getEnemyPokemon()!; game.move.select(Moves.SPORE); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); await game.toNextTurn(); expect(enemyPokemon.status).toBeUndefined(); - }, TIMEOUT); + }); it("protects from confusion", async () => { - game.override.moveset([Moves.CONFUSE_RAY]); + game.override.moveset([ Moves.CONFUSE_RAY ]); await game.classicMode.startBattle(); const enemyPokemon = game.scene.getEnemyPokemon()!; game.move.select(Moves.CONFUSE_RAY); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); await game.toNextTurn(); expect(enemyPokemon.summonData.tags).toEqual([]); - }, TIMEOUT); + }); it("protects ally from status", async () => { game.override.battleType("double"); @@ -79,7 +78,7 @@ describe("Moves - Safeguard", () => { game.move.select(Moves.SPORE, 0, BattlerIndex.ENEMY_2); game.move.select(Moves.NUZZLE, 1, BattlerIndex.ENEMY_2); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY_2]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY_2 ]); await game.phaseInterceptor.to("BerryPhase"); @@ -87,46 +86,46 @@ describe("Moves - Safeguard", () => { expect(enemyPokemon[0].status).toBeUndefined(); expect(enemyPokemon[1].status).toBeUndefined(); - }, TIMEOUT); + }); it("protects from Yawn", async () => { await game.classicMode.startBattle(); const enemyPokemon = game.scene.getEnemyPokemon()!; game.move.select(Moves.YAWN); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); await game.toNextTurn(); expect(enemyPokemon.summonData.tags).toEqual([]); - }, TIMEOUT); + }); it("doesn't protect from already existing Yawn", async () => { await game.classicMode.startBattle(); const enemyPokemon = game.scene.getEnemyPokemon()!; game.move.select(Moves.YAWN); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.toNextTurn(); game.move.select(Moves.SPLASH); await game.toNextTurn(); expect(enemyPokemon.status?.effect).toEqual(StatusEffect.SLEEP); - }, TIMEOUT); + }); it("doesn't protect from self-inflicted via Rest or Flame Orb", async () => { - game.override.enemyHeldItems([{name: "FLAME_ORB"}]); + game.override.enemyHeldItems([{ name: "FLAME_ORB" }]); await game.classicMode.startBattle(); const enemyPokemon = game.scene.getEnemyPokemon()!; game.move.select(Moves.SPLASH); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); await game.toNextTurn(); enemyPokemon.damageAndUpdate(1); expect(enemyPokemon.status?.effect).toEqual(StatusEffect.BURN); - game.override.enemyMoveset([Moves.REST]); + game.override.enemyMoveset([ Moves.REST ]); // Force the moveset to update mid-battle // TODO: Remove after enemy AI rework is in enemyPokemon.getMoveset(); @@ -135,7 +134,7 @@ describe("Moves - Safeguard", () => { await game.toNextTurn(); expect(enemyPokemon.status?.effect).toEqual(StatusEffect.SLEEP); - }, TIMEOUT); + }); it("protects from ability-inflicted status", async () => { game.override.ability(Abilities.STATIC); @@ -144,12 +143,12 @@ describe("Moves - Safeguard", () => { const enemyPokemon = game.scene.getEnemyPokemon()!; game.move.select(Moves.SPLASH); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); await game.toNextTurn(); - game.override.enemyMoveset([Moves.TACKLE]); + game.override.enemyMoveset([ Moves.TACKLE ]); game.move.select(Moves.SPLASH); await game.toNextTurn(); expect(enemyPokemon.status).toBeUndefined(); - }, TIMEOUT); + }); }); diff --git a/src/test/moves/scale_shot.test.ts b/src/test/moves/scale_shot.test.ts new file mode 100644 index 00000000000..e4d768fa13a --- /dev/null +++ b/src/test/moves/scale_shot.test.ts @@ -0,0 +1,85 @@ +import { BattlerIndex } from "#app/battle"; +import { allMoves } from "#app/data/move"; +import { DamagePhase } from "#app/phases/damage-phase"; +import { MoveEffectPhase } from "#app/phases/move-effect-phase"; +import { MoveEndPhase } from "#app/phases/move-end-phase"; +import { TurnEndPhase } from "#app/phases/turn-end-phase"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import { Stat } from "#enums/stat"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, it, expect, vi } from "vitest"; + +describe("Moves - Scale Shot", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.SCALE_SHOT ]) + .battleType("single") + .disableCrits() + .ability(Abilities.NO_GUARD) + .passiveAbility(Abilities.SKILL_LINK) + .enemyMoveset(Moves.SPLASH) + .enemyLevel(3); + }); + + it("applies stat changes after last hit", async () => { + game.override.enemySpecies(Species.FORRETRESS); + + await game.classicMode.startBattle([ Species.MINCCINO ]); + const minccino = game.scene.getPlayerPokemon()!; + game.move.select(Moves.SCALE_SHOT); + + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + + await game.phaseInterceptor.to(MoveEffectPhase); + await game.phaseInterceptor.to(DamagePhase); + + //check that stats haven't changed after one or two hits have occurred + await game.phaseInterceptor.to(MoveEffectPhase); + expect(minccino.getStatStage(Stat.DEF)).toBe(0); + expect(minccino.getStatStage(Stat.SPD)).toBe(0); + + //check that stats changed on last hit + await game.phaseInterceptor.to(MoveEndPhase); + expect(minccino.getStatStage(Stat.DEF)).toBe(-1); + expect(minccino.getStatStage(Stat.SPD)).toBe(1); + }); + + it("unaffected by sheer force", async () => { + const moveToCheck = allMoves[Moves.SCALE_SHOT]; + const basePower = moveToCheck.power; + + game.override.enemySpecies(Species.WOBBUFFET); + + vi.spyOn(moveToCheck, "calculateBattlePower"); + + await game.classicMode.startBattle([ Species.MINCCINO ]); + const minccino = game.scene.getPlayerPokemon()!; + + game.move.select(Moves.SCALE_SHOT); + await game.phaseInterceptor.to(TurnEndPhase); + + //effect not nullified by sheer force + expect(minccino.getStatStage(Stat.DEF)).toBe(-1); + expect(minccino.getStatStage(Stat.SPD)).toBe(1); + + //power not boosted by sheer force + expect(moveToCheck.calculateBattlePower).toHaveReturnedWith(basePower); + }); +}); diff --git a/src/test/moves/secret_power.test.ts b/src/test/moves/secret_power.test.ts new file mode 100644 index 00000000000..09fe5faa50b --- /dev/null +++ b/src/test/moves/secret_power.test.ts @@ -0,0 +1,98 @@ +import { Abilities } from "#enums/abilities"; +import { Biome } from "#enums/biome"; +import { Moves } from "#enums/moves"; +import { Stat } from "#enums/stat"; +import { allMoves } from "#app/data/move"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; +import { StatusEffect } from "#enums/status-effect"; +import { BattlerIndex } from "#app/battle"; +import { ArenaTagType } from "#enums/arena-tag-type"; +import { ArenaTagSide } from "#app/data/arena-tag"; +import { allAbilities, MoveEffectChanceMultiplierAbAttr } from "#app/data/ability"; + +describe("Moves - Secret Power", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.SECRET_POWER ]) + .ability(Abilities.BALL_FETCH) + .battleType("single") + .disableCrits() + .enemySpecies(Species.MAGIKARP) + .enemyLevel(60) + .enemyAbility(Abilities.BALL_FETCH); + }); + + it("Secret Power checks for an active terrain first then looks at the biome for its secondary effect", async () => { + game.override + .startingBiome(Biome.VOLCANO) + .enemyMoveset([ Moves.SPLASH, Moves.MISTY_TERRAIN ]); + vi.spyOn(allMoves[Moves.SECRET_POWER], "chance", "get").mockReturnValue(100); + await game.classicMode.startBattle([ Species.FEEBAS ]); + + const enemyPokemon = game.scene.getEnemyPokemon()!; + + // No Terrain + Biome.VOLCANO --> Burn + game.move.select(Moves.SECRET_POWER); + await game.forceEnemyMove(Moves.SPLASH); + await game.phaseInterceptor.to("TurnEndPhase"); + expect(enemyPokemon.status?.effect).toBe(StatusEffect.BURN); + + // Misty Terrain --> SpAtk -1 + game.move.select(Moves.SECRET_POWER); + await game.forceEnemyMove(Moves.MISTY_TERRAIN); + await game.phaseInterceptor.to("TurnEndPhase"); + expect(enemyPokemon.getStatStage(Stat.SPATK)).toBe(-1); + }); + + it("Secret Power's effect chance is doubled by Serene Grace, but not by the 'rainbow' effect from Fire/Water Pledge", + async () => { + game.override + .moveset([ Moves.FIRE_PLEDGE, Moves.WATER_PLEDGE, Moves.SECRET_POWER, Moves.SPLASH ]) + .ability(Abilities.SERENE_GRACE) + .enemyMoveset([ Moves.SPLASH ]) + .battleType("double"); + await game.classicMode.startBattle([ Species.BLASTOISE, Species.CHARIZARD ]); + + const sereneGraceAttr = allAbilities[Abilities.SERENE_GRACE].getAttrs(MoveEffectChanceMultiplierAbAttr)[0]; + vi.spyOn(sereneGraceAttr, "apply"); + + game.move.select(Moves.WATER_PLEDGE, 0, BattlerIndex.ENEMY); + game.move.select(Moves.FIRE_PLEDGE, 1, BattlerIndex.ENEMY_2); + + await game.phaseInterceptor.to("TurnEndPhase"); + + let rainbowEffect = game.scene.arena.getTagOnSide(ArenaTagType.WATER_FIRE_PLEDGE, ArenaTagSide.PLAYER); + expect(rainbowEffect).toBeDefined(); + + rainbowEffect = rainbowEffect!; + vi.spyOn(rainbowEffect, "apply"); + + game.move.select(Moves.SECRET_POWER, 0, BattlerIndex.ENEMY); + game.move.select(Moves.SPLASH, 1); + + await game.phaseInterceptor.to("BerryPhase", false); + + expect(sereneGraceAttr.apply).toHaveBeenCalledOnce(); + expect(sereneGraceAttr.apply).toHaveLastReturnedWith(true); + + expect(rainbowEffect.apply).toHaveBeenCalledTimes(0); + } + ); +}); diff --git a/src/test/moves/shed_tail.test.ts b/src/test/moves/shed_tail.test.ts new file mode 100644 index 00000000000..33a7d81e460 --- /dev/null +++ b/src/test/moves/shed_tail.test.ts @@ -0,0 +1,71 @@ +import { SubstituteTag } from "#app/data/battler-tags"; +import { MoveResult } from "#app/field/pokemon"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, it, expect } from "vitest"; + +describe("Moves - Shed Tail", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.SHED_TAIL ]) + .battleType("single") + .enemySpecies(Species.SNORLAX) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.SPLASH); + }); + + it("transfers a Substitute doll to the switched in Pokemon", async () => { + await game.classicMode.startBattle([ Species.MAGIKARP, Species.FEEBAS ]); + + const magikarp = game.scene.getPlayerPokemon()!; + + game.move.select(Moves.SHED_TAIL); + game.doSelectPartyPokemon(1); + + await game.phaseInterceptor.to("TurnEndPhase", false); + + const feebas = game.scene.getPlayerPokemon()!; + const substituteTag = feebas.getTag(SubstituteTag); + + expect(feebas).not.toBe(magikarp); + expect(feebas.hp).toBe(feebas.getMaxHp()); + // Note: Shed Tail's HP cost is currently not accurate to mainline, as it + // should cost ceil(maxHP / 2) instead of max(floor(maxHp / 2), 1). The current + // implementation is consistent with Substitute's HP cost logic, but that's not + // the case in mainline for some reason :regiDespair:. + expect(magikarp.hp).toBe(Math.ceil(magikarp.getMaxHp() / 2)); + expect(substituteTag).toBeDefined(); + expect(substituteTag?.hp).toBe(Math.floor(magikarp.getMaxHp() / 4)); + }); + + it("should fail if no ally is available to switch in", async () => { + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const magikarp = game.scene.getPlayerPokemon()!; + expect(game.scene.getPlayerParty().length).toBe(1); + + game.move.select(Moves.SHED_TAIL); + + await game.phaseInterceptor.to("TurnEndPhase", false); + + expect(magikarp.isOnField()).toBeTruthy(); + expect(magikarp.getLastXMoves()[0].result).toBe(MoveResult.FAIL); + }); +}); diff --git a/src/test/moves/shell_side_arm.test.ts b/src/test/moves/shell_side_arm.test.ts new file mode 100644 index 00000000000..9646d27f17e --- /dev/null +++ b/src/test/moves/shell_side_arm.test.ts @@ -0,0 +1,78 @@ +import { BattlerIndex } from "#app/battle"; +import { allMoves, ShellSideArmCategoryAttr } from "#app/data/move"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; + +describe("Moves - Shell Side Arm", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + const shellSideArm = allMoves[Moves.SHELL_SIDE_ARM]; + const shellSideArmAttr = shellSideArm.getAttrs(ShellSideArmCategoryAttr)[0]; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.SHELL_SIDE_ARM ]) + .battleType("single") + .startingLevel(100) + .enemyLevel(100) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.SPLASH); + }); + + it("becomes a physical attack if forecasted to deal more damage as physical", async () => { + game.override.enemySpecies(Species.SNORLAX); + + await game.classicMode.startBattle([ Species.RAMPARDOS ]); + + vi.spyOn(shellSideArmAttr, "apply"); + + game.move.select(Moves.SHELL_SIDE_ARM); + await game.phaseInterceptor.to("MoveEffectPhase"); + + expect(shellSideArmAttr.apply).toHaveLastReturnedWith(true); + }); + + it("remains a special attack if forecasted to deal more damage as special", async () => { + game.override.enemySpecies(Species.SLOWBRO); + + await game.classicMode.startBattle([ Species.XURKITREE ]); + + vi.spyOn(shellSideArmAttr, "apply"); + + game.move.select(Moves.SHELL_SIDE_ARM); + await game.phaseInterceptor.to("MoveEffectPhase"); + + expect(shellSideArmAttr.apply).toHaveLastReturnedWith(false); + }); + + it("respects stat stage changes when forecasting base damage", async () => { + game.override + .enemySpecies(Species.SNORLAX) + .enemyMoveset(Moves.COTTON_GUARD); + + await game.classicMode.startBattle([ Species.MANAPHY ]); + + vi.spyOn(shellSideArmAttr, "apply"); + + game.move.select(Moves.SHELL_SIDE_ARM); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); + await game.phaseInterceptor.to("BerryPhase", false); + + expect(shellSideArmAttr.apply).toHaveLastReturnedWith(false); + }); +}); diff --git a/src/test/moves/shell_trap.test.ts b/src/test/moves/shell_trap.test.ts index 213b9c3fd0a..04d3cf998b1 100644 --- a/src/test/moves/shell_trap.test.ts +++ b/src/test/moves/shell_trap.test.ts @@ -10,7 +10,6 @@ import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Moves - Shell Trap", () => { let phaserGame: Phaser.Game; @@ -30,9 +29,9 @@ describe("Moves - Shell Trap", () => { game = new GameManager(phaserGame); game.override .battleType("double") - .moveset([Moves.SHELL_TRAP, Moves.SPLASH, Moves.BULLDOZE]) + .moveset([ Moves.SHELL_TRAP, Moves.SPLASH, Moves.BULLDOZE ]) .enemySpecies(Species.SNORLAX) - .enemyMoveset([Moves.RAZOR_LEAF]) + .enemyMoveset([ Moves.RAZOR_LEAF ]) .startingLevel(100) .enemyLevel(100); @@ -42,7 +41,7 @@ describe("Moves - Shell Trap", () => { it( "should activate after the user is hit by a physical attack", async () => { - await game.startBattle([Species.CHARIZARD, Species.TURTONATOR]); + await game.startBattle([ Species.CHARIZARD, Species.TURTONATOR ]); const playerPokemon = game.scene.getPlayerField(); const enemyPokemon = game.scene.getEnemyField(); @@ -50,7 +49,7 @@ describe("Moves - Shell Trap", () => { game.move.select(Moves.SPLASH); game.move.select(Moves.SHELL_TRAP, 1); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.ENEMY_2, BattlerIndex.PLAYER, BattlerIndex.PLAYER_2]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.ENEMY_2, BattlerIndex.PLAYER, BattlerIndex.PLAYER_2 ]); await game.phaseInterceptor.to(MoveEndPhase); @@ -60,15 +59,15 @@ describe("Moves - Shell Trap", () => { await game.phaseInterceptor.to(MoveEndPhase); enemyPokemon.forEach(p => expect(p.hp).toBeLessThan(p.getMaxHp())); - }, TIMEOUT + } ); it( "should fail if the user is only hit by special attacks", async () => { - game.override.enemyMoveset([Moves.SWIFT]); + game.override.enemyMoveset([ Moves.SWIFT ]); - await game.startBattle([Species.CHARIZARD, Species.TURTONATOR]); + await game.startBattle([ Species.CHARIZARD, Species.TURTONATOR ]); const playerPokemon = game.scene.getPlayerField(); const enemyPokemon = game.scene.getEnemyField(); @@ -76,7 +75,7 @@ describe("Moves - Shell Trap", () => { game.move.select(Moves.SPLASH); game.move.select(Moves.SHELL_TRAP, 1); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.ENEMY_2, BattlerIndex.PLAYER, BattlerIndex.PLAYER_2]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.ENEMY_2, BattlerIndex.PLAYER, BattlerIndex.PLAYER_2 ]); await game.phaseInterceptor.to(MoveEndPhase); @@ -86,7 +85,7 @@ describe("Moves - Shell Trap", () => { await game.phaseInterceptor.to(BerryPhase, false); enemyPokemon.forEach(p => expect(p.hp).toBe(p.getMaxHp())); - }, TIMEOUT + } ); it( @@ -94,7 +93,7 @@ describe("Moves - Shell Trap", () => { async () => { game.override.enemyMoveset(Moves.SPLASH); - await game.startBattle([Species.CHARIZARD, Species.TURTONATOR]); + await game.startBattle([ Species.CHARIZARD, Species.TURTONATOR ]); const playerPokemon = game.scene.getPlayerField(); const enemyPokemon = game.scene.getEnemyField(); @@ -102,7 +101,7 @@ describe("Moves - Shell Trap", () => { game.move.select(Moves.SPLASH); game.move.select(Moves.SHELL_TRAP, 1); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.ENEMY_2, BattlerIndex.PLAYER, BattlerIndex.PLAYER_2]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.ENEMY_2, BattlerIndex.PLAYER, BattlerIndex.PLAYER_2 ]); await game.phaseInterceptor.to(MoveEndPhase); @@ -112,7 +111,7 @@ describe("Moves - Shell Trap", () => { await game.phaseInterceptor.to(BerryPhase, false); enemyPokemon.forEach(p => expect(p.hp).toBe(p.getMaxHp())); - }, TIMEOUT + } ); it( @@ -120,7 +119,7 @@ describe("Moves - Shell Trap", () => { async () => { game.override.enemyMoveset(Moves.SPLASH); - await game.startBattle([Species.BLASTOISE, Species.CHARIZARD]); + await game.startBattle([ Species.BLASTOISE, Species.CHARIZARD ]); const playerPokemon = game.scene.getPlayerField(); const enemyPokemon = game.scene.getEnemyField(); @@ -138,7 +137,7 @@ describe("Moves - Shell Trap", () => { await game.phaseInterceptor.to(BerryPhase, false); enemyPokemon.forEach((p, i) => expect(p.hp).toBe(enemyStartingHp[i])); - }, TIMEOUT + } ); it( @@ -147,7 +146,7 @@ describe("Moves - Shell Trap", () => { game.override.battleType("single"); vi.spyOn(allMoves[Moves.RAZOR_LEAF], "priority", "get").mockReturnValue(-4); - await game.startBattle([Species.CHARIZARD]); + await game.startBattle([ Species.CHARIZARD ]); const playerPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -158,6 +157,6 @@ describe("Moves - Shell Trap", () => { expect(playerPokemon.getLastXMoves()[0].result).toBe(MoveResult.FAIL); expect(enemyPokemon.hp).toBe(enemyPokemon.getMaxHp()); - }, TIMEOUT + } ); }); diff --git a/src/test/moves/sketch.test.ts b/src/test/moves/sketch.test.ts new file mode 100644 index 00000000000..f531f44ef0c --- /dev/null +++ b/src/test/moves/sketch.test.ts @@ -0,0 +1,98 @@ +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import { MoveResult, PokemonMove } from "#app/field/pokemon"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; +import { StatusEffect } from "#app/enums/status-effect"; +import { BattlerIndex } from "#app/battle"; +import { allMoves, RandomMoveAttr } from "#app/data/move"; + +describe("Moves - Sketch", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .ability(Abilities.BALL_FETCH) + .battleType("single") + .disableCrits() + .enemySpecies(Species.SHUCKLE) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.SPLASH); + }); + + it("Sketch should not fail even if a previous Sketch failed to retrieve a valid move and ran out of PP", async () => { + await game.classicMode.startBattle([ Species.REGIELEKI ]); + const playerPokemon = game.scene.getPlayerPokemon()!; + // can't use normal moveset override because we need to check moveset changes + playerPokemon.moveset = [ new PokemonMove(Moves.SKETCH), new PokemonMove(Moves.SKETCH) ]; + + game.move.select(Moves.SKETCH); + await game.phaseInterceptor.to("TurnEndPhase"); + expect(playerPokemon.getLastXMoves()[0].result).toBe(MoveResult.FAIL); + const moveSlot0 = playerPokemon.getMoveset()[0]!; + expect(moveSlot0.moveId).toBe(Moves.SKETCH); + expect(moveSlot0.getPpRatio()).toBe(0); + + await game.toNextTurn(); + game.move.select(Moves.SKETCH); + await game.phaseInterceptor.to("TurnEndPhase"); + expect(playerPokemon.getLastXMoves()[0].result).toBe(MoveResult.SUCCESS); + expect(playerPokemon.moveset[0]?.moveId).toBe(Moves.SPLASH); + expect(playerPokemon.moveset[1]?.moveId).toBe(Moves.SKETCH); + }); + + it("Sketch should retrieve the most recent valid move from its target history", async () => { + game.override.enemyStatusEffect(StatusEffect.PARALYSIS); + await game.classicMode.startBattle([ Species.REGIELEKI ]); + const playerPokemon = game.scene.getPlayerPokemon()!; + const enemyPokemon = game.scene.getEnemyPokemon()!; + playerPokemon.moveset = [ new PokemonMove(Moves.SKETCH), new PokemonMove(Moves.GROWL) ]; + + game.move.select(Moves.GROWL); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); + await game.move.forceStatusActivation(false); + await game.phaseInterceptor.to("TurnEndPhase"); + expect(enemyPokemon.getLastXMoves()[0].result).toBe(MoveResult.SUCCESS); + + await game.toNextTurn(); + game.move.select(Moves.SKETCH); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); + await game.move.forceStatusActivation(true); + await game.phaseInterceptor.to("TurnEndPhase"); + expect(playerPokemon.getLastXMoves()[0].result).toBe(MoveResult.SUCCESS); + expect(playerPokemon.moveset[0]?.moveId).toBe(Moves.SPLASH); + expect(playerPokemon.moveset[1]?.moveId).toBe(Moves.GROWL); + }); + + it("should sketch moves that call other moves", async () => { + const randomMoveAttr = allMoves[Moves.METRONOME].findAttr(attr => attr instanceof RandomMoveAttr) as RandomMoveAttr; + vi.spyOn(randomMoveAttr, "getMoveOverride").mockReturnValue(Moves.FALSE_SWIPE); + + game.override.enemyMoveset([ Moves.METRONOME ]); + await game.classicMode.startBattle([ Species.REGIELEKI ]); + const playerPokemon = game.scene.getPlayerPokemon()!; + playerPokemon.moveset = [ new PokemonMove(Moves.SKETCH) ]; + + // Opponent uses Metronome -> False Swipe, then player uses Sketch, which should sketch Metronome + game.move.select(Moves.SKETCH); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); + await game.phaseInterceptor.to("TurnEndPhase"); + expect(playerPokemon.getLastXMoves()[0].result).toBe(MoveResult.SUCCESS); + expect(playerPokemon.moveset[0]?.moveId).toBe(Moves.METRONOME); + expect(playerPokemon.hp).toBeLessThan(playerPokemon.getMaxHp()); // Make sure opponent actually used False Swipe + }); +}); diff --git a/src/test/moves/solar_beam.test.ts b/src/test/moves/solar_beam.test.ts new file mode 100644 index 00000000000..ebec338932a --- /dev/null +++ b/src/test/moves/solar_beam.test.ts @@ -0,0 +1,102 @@ +import { allMoves } from "#app/data/move"; +import { BattlerTagType } from "#enums/battler-tag-type"; +import { WeatherType } from "#enums/weather-type"; +import { MoveResult } from "#app/field/pokemon"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, it, expect, vi } from "vitest"; + +describe("Moves - Solar Beam", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset(Moves.SOLAR_BEAM) + .battleType("single") + .startingLevel(100) + .enemySpecies(Species.SNORLAX) + .enemyLevel(100) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.SPLASH); + }); + + it("should deal damage in two turns if no weather is active", async () => { + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const enemyPokemon = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.SOLAR_BEAM); + + await game.phaseInterceptor.to("TurnEndPhase"); + expect(playerPokemon.getTag(BattlerTagType.CHARGING)).toBeDefined(); + expect(enemyPokemon.hp).toBe(enemyPokemon.getMaxHp()); + expect(playerPokemon.getLastXMoves(1)[0].result).toBe(MoveResult.OTHER); + + await game.phaseInterceptor.to("TurnEndPhase"); + expect(playerPokemon.getTag(BattlerTagType.CHARGING)).toBeUndefined(); + expect(enemyPokemon.hp).toBeLessThan(enemyPokemon.getMaxHp()); + expect(playerPokemon.getMoveHistory()).toHaveLength(2); + expect(playerPokemon.getLastXMoves(1)[0].result).toBe(MoveResult.SUCCESS); + + const playerSolarBeam = playerPokemon.getMoveset().find(mv => mv && mv.moveId === Moves.SOLAR_BEAM); + expect(playerSolarBeam?.ppUsed).toBe(1); + }); + + it.each([ + { weatherType: WeatherType.SUNNY, name: "Sun" }, + { weatherType: WeatherType.HARSH_SUN, name: "Harsh Sun" } + ])("should deal damage in one turn if $name is active", async ({ weatherType }) => { + game.override.weather(weatherType); + + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const enemyPokemon = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.SOLAR_BEAM); + + await game.phaseInterceptor.to("TurnEndPhase"); + expect(playerPokemon.getTag(BattlerTagType.CHARGING)).toBeUndefined(); + expect(enemyPokemon.hp).toBeLessThan(enemyPokemon.getMaxHp()); + expect(playerPokemon.getMoveHistory()).toHaveLength(2); + expect(playerPokemon.getLastXMoves(1)[0].result).toBe(MoveResult.SUCCESS); + + const playerSolarBeam = playerPokemon.getMoveset().find(mv => mv && mv.moveId === Moves.SOLAR_BEAM); + expect(playerSolarBeam?.ppUsed).toBe(1); + }); + + it.each([ + { weatherType: WeatherType.RAIN, name: "Rain" }, + { weatherType: WeatherType.HEAVY_RAIN, name: "Heavy Rain" } + ])("should have its power halved in $name", async ({ weatherType }) => { + game.override.weather(weatherType); + + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const solarBeam = allMoves[Moves.SOLAR_BEAM]; + + vi.spyOn(solarBeam, "calculateBattlePower"); + + game.move.select(Moves.SOLAR_BEAM); + + await game.phaseInterceptor.to("TurnEndPhase"); + await game.phaseInterceptor.to("TurnEndPhase"); + expect(solarBeam.calculateBattlePower).toHaveLastReturnedWith(60); + }); +}); diff --git a/src/test/moves/sparkly_swirl.test.ts b/src/test/moves/sparkly_swirl.test.ts new file mode 100644 index 00000000000..a83f1c3a437 --- /dev/null +++ b/src/test/moves/sparkly_swirl.test.ts @@ -0,0 +1,86 @@ +import { allMoves } from "#app/data/move"; +import { StatusEffect } from "#app/enums/status-effect"; +import { CommandPhase } from "#app/phases/command-phase"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; + +describe("Moves - Sparkly Swirl", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ type: Phaser.HEADLESS }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .enemySpecies(Species.SHUCKLE) + .enemyLevel(100) + .enemyMoveset(Moves.SPLASH) + .enemyAbility(Abilities.BALL_FETCH) + .moveset([ Moves.SPARKLY_SWIRL, Moves.SPLASH ]) + .ability(Abilities.BALL_FETCH); + + vi.spyOn(allMoves[Moves.SPARKLY_SWIRL], "accuracy", "get").mockReturnValue(100); + }); + + it("should cure status effect of the user, its ally, and all party pokemon", async () => { + game.override + .battleType("double") + .statusEffect(StatusEffect.BURN); + await game.classicMode.startBattle([ Species.RATTATA, Species.RATTATA, Species.RATTATA ]); + const [ leftPlayer, rightPlayer, partyPokemon ] = game.scene.getPlayerParty(); + const leftOpp = game.scene.getEnemyPokemon()!; + + vi.spyOn(leftPlayer, "resetStatus"); + vi.spyOn(rightPlayer, "resetStatus"); + vi.spyOn(partyPokemon, "resetStatus"); + + game.move.select(Moves.SPARKLY_SWIRL, 0, leftOpp.getBattlerIndex()); + await game.phaseInterceptor.to(CommandPhase); + game.move.select(Moves.SPLASH, 1); + await game.toNextTurn(); + + expect(leftPlayer.resetStatus).toHaveBeenCalledOnce(); + expect(rightPlayer.resetStatus).toHaveBeenCalledOnce(); + expect(partyPokemon.resetStatus).toHaveBeenCalledOnce(); + + expect(leftPlayer.status?.effect).toBeUndefined(); + expect(rightPlayer.status?.effect).toBeUndefined(); + expect(partyPokemon.status?.effect).toBeUndefined(); + }); + + it("should not cure status effect of the target/target's allies", async () => { + game.override + .battleType("double") + .enemyStatusEffect(StatusEffect.BURN); + await game.classicMode.startBattle([ Species.RATTATA, Species.RATTATA ]); + const [ leftOpp, rightOpp ] = game.scene.getEnemyField(); + + vi.spyOn(leftOpp, "resetStatus"); + vi.spyOn(rightOpp, "resetStatus"); + + game.move.select(Moves.SPARKLY_SWIRL, 0, leftOpp.getBattlerIndex()); + await game.phaseInterceptor.to(CommandPhase); + game.move.select(Moves.SPLASH, 1); + await game.toNextTurn(); + + expect(leftOpp.resetStatus).toHaveBeenCalledTimes(0); + expect(rightOpp.resetStatus).toHaveBeenCalledTimes(0); + + expect(leftOpp.status?.effect).toBeTruthy(); + expect(rightOpp.status?.effect).toBeTruthy(); + + expect(leftOpp.status?.effect).toBe(StatusEffect.BURN); + expect(rightOpp.status?.effect).toBe(StatusEffect.BURN); + }); +}); diff --git a/src/test/moves/spikes.test.ts b/src/test/moves/spikes.test.ts index aa59912d802..35e89c8caf7 100644 --- a/src/test/moves/spikes.test.ts +++ b/src/test/moves/spikes.test.ts @@ -28,11 +28,11 @@ describe("Moves - Spikes", () => { .enemyAbility(Abilities.BALL_FETCH) .ability(Abilities.BALL_FETCH) .enemyMoveset(Moves.SPLASH) - .moveset([Moves.SPIKES, Moves.SPLASH, Moves.ROAR]); + .moveset([ Moves.SPIKES, Moves.SPLASH, Moves.ROAR ]); }); it("should not damage the team that set them", async () => { - await game.startBattle([Species.MIGHTYENA, Species.POOCHYENA]); + await game.startBattle([ Species.MIGHTYENA, Species.POOCHYENA ]); game.move.select(Moves.SPIKES); await game.toNextTurn(); @@ -46,13 +46,13 @@ describe("Moves - Spikes", () => { game.doSwitchPokemon(1); await game.toNextTurn(); - const player = game.scene.getParty()[0]; + const player = game.scene.getPlayerParty()[0]; expect(player.hp).toBe(player.getMaxHp()); }, 20000); it("should damage opposing pokemon that are forced to switch in", async () => { game.override.startingWave(5); - await game.startBattle([Species.MIGHTYENA, Species.POOCHYENA]); + await game.startBattle([ Species.MIGHTYENA, Species.POOCHYENA ]); game.move.select(Moves.SPIKES); await game.toNextTurn(); @@ -66,7 +66,7 @@ describe("Moves - Spikes", () => { it("should damage opposing pokemon that choose to switch in", async () => { game.override.startingWave(5); - await game.startBattle([Species.MIGHTYENA, Species.POOCHYENA]); + await game.startBattle([ Species.MIGHTYENA, Species.POOCHYENA ]); game.move.select(Moves.SPIKES); await game.toNextTurn(); diff --git a/src/test/moves/spit_up.test.ts b/src/test/moves/spit_up.test.ts index acf7f01d991..8e418858e8d 100644 --- a/src/test/moves/spit_up.test.ts +++ b/src/test/moves/spit_up.test.ts @@ -43,11 +43,11 @@ describe("Moves - Spit Up", () => { }); describe("consumes all stockpile stacks to deal damage (scaling with stacks)", () => { - it("1 stack -> 100 power", { timeout: 10000 }, async () => { + it("1 stack -> 100 power", async () => { const stacksToSetup = 1; const expectedPower = 100; - await game.startBattle([Species.ABOMASNOW]); + await game.startBattle([ Species.ABOMASNOW ]); const pokemon = game.scene.getPlayerPokemon()!; pokemon.addTag(BattlerTagType.STOCKPILING); @@ -65,11 +65,11 @@ describe("Moves - Spit Up", () => { expect(pokemon.getTag(StockpilingTag)).toBeUndefined(); }); - it("2 stacks -> 200 power", { timeout: 10000 }, async () => { + it("2 stacks -> 200 power", async () => { const stacksToSetup = 2; const expectedPower = 200; - await game.startBattle([Species.ABOMASNOW]); + await game.startBattle([ Species.ABOMASNOW ]); const pokemon = game.scene.getPlayerPokemon()!; pokemon.addTag(BattlerTagType.STOCKPILING); @@ -88,11 +88,11 @@ describe("Moves - Spit Up", () => { expect(pokemon.getTag(StockpilingTag)).toBeUndefined(); }); - it("3 stacks -> 300 power", { timeout: 10000 }, async () => { + it("3 stacks -> 300 power", async () => { const stacksToSetup = 3; const expectedPower = 300; - await game.startBattle([Species.ABOMASNOW]); + await game.startBattle([ Species.ABOMASNOW ]); const pokemon = game.scene.getPlayerPokemon()!; pokemon.addTag(BattlerTagType.STOCKPILING); @@ -113,8 +113,8 @@ describe("Moves - Spit Up", () => { }); }); - it("fails without stacks", { timeout: 10000 }, async () => { - await game.startBattle([Species.ABOMASNOW]); + it("fails without stacks", async () => { + await game.startBattle([ Species.ABOMASNOW ]); const pokemon = game.scene.getPlayerPokemon()!; @@ -130,8 +130,8 @@ describe("Moves - Spit Up", () => { }); describe("restores stat boosts granted by stacks", () => { - it("decreases stats based on stored values (both boosts equal)", { timeout: 10000 }, async () => { - await game.startBattle([Species.ABOMASNOW]); + it("decreases stats based on stored values (both boosts equal)", async () => { + await game.startBattle([ Species.ABOMASNOW ]); const pokemon = game.scene.getPlayerPokemon()!; pokemon.addTag(BattlerTagType.STOCKPILING); @@ -157,8 +157,8 @@ describe("Moves - Spit Up", () => { expect(pokemon.getTag(StockpilingTag)).toBeUndefined(); }); - it("decreases stats based on stored values (different boosts)", { timeout: 10000 }, async () => { - await game.startBattle([Species.ABOMASNOW]); + it("decreases stats based on stored values (different boosts)", async () => { + await game.startBattle([ Species.ABOMASNOW ]); const pokemon = game.scene.getPlayerPokemon()!; pokemon.addTag(BattlerTagType.STOCKPILING); diff --git a/src/test/moves/spotlight.test.ts b/src/test/moves/spotlight.test.ts index aef44369642..095f7d80bfe 100644 --- a/src/test/moves/spotlight.test.ts +++ b/src/test/moves/spotlight.test.ts @@ -6,7 +6,6 @@ import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, test } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Moves - Spotlight", () => { let phaserGame: Phaser.Game; @@ -29,14 +28,14 @@ describe("Moves - Spotlight", () => { game.override.enemySpecies(Species.SNORLAX); game.override.startingLevel(100); game.override.enemyLevel(100); - game.override.moveset([Moves.FOLLOW_ME, Moves.RAGE_POWDER, Moves.SPOTLIGHT, Moves.QUICK_ATTACK]); - game.override.enemyMoveset([Moves.FOLLOW_ME, Moves.SPLASH]); + game.override.moveset([ Moves.FOLLOW_ME, Moves.RAGE_POWDER, Moves.SPOTLIGHT, Moves.QUICK_ATTACK ]); + game.override.enemyMoveset([ Moves.FOLLOW_ME, Moves.SPLASH ]); }); test( "move should redirect attacks to the target", async () => { - await game.classicMode.startBattle([Species.AMOONGUSS, Species.CHARIZARD]); + await game.classicMode.startBattle([ Species.AMOONGUSS, Species.CHARIZARD ]); const enemyPokemon = game.scene.getEnemyField(); @@ -50,13 +49,13 @@ describe("Moves - Spotlight", () => { expect(enemyPokemon[0].hp).toBeLessThan(enemyPokemon[0].getMaxHp()); expect(enemyPokemon[1].hp).toBe(enemyPokemon[1].getMaxHp()); - }, TIMEOUT + } ); test( "move should cause other redirection moves to fail", async () => { - await game.classicMode.startBattle([Species.AMOONGUSS, Species.CHARIZARD]); + await game.classicMode.startBattle([ Species.AMOONGUSS, Species.CHARIZARD ]); const enemyPokemon = game.scene.getEnemyField(); @@ -70,6 +69,6 @@ describe("Moves - Spotlight", () => { expect(enemyPokemon[0].hp).toBeLessThan(enemyPokemon[0].getMaxHp()); expect(enemyPokemon[1].hp).toBe(enemyPokemon[1].getMaxHp()); - }, TIMEOUT + } ); }); diff --git a/src/test/moves/steamroller.test.ts b/src/test/moves/steamroller.test.ts index cbbb3a22593..9d16643ec5d 100644 --- a/src/test/moves/steamroller.test.ts +++ b/src/test/moves/steamroller.test.ts @@ -25,12 +25,12 @@ describe("Moves - Steamroller", () => { beforeEach(() => { game = new GameManager(phaserGame); - game.override.moveset([Moves.STEAMROLLER]).battleType("single").enemyAbility(Abilities.BALL_FETCH); + game.override.moveset([ Moves.STEAMROLLER ]).battleType("single").enemyAbility(Abilities.BALL_FETCH); }); it("should always hit a minimzed target with double damage", async () => { game.override.enemySpecies(Species.DITTO).enemyMoveset(Moves.MINIMIZE); - await game.classicMode.startBattle([Species.IRON_BOULDER]); + await game.classicMode.startBattle([ Species.IRON_BOULDER ]); const ditto = game.scene.getEnemyPokemon()!; vi.spyOn(ditto, "getAttackDamage"); @@ -41,13 +41,13 @@ describe("Moves - Steamroller", () => { vi.spyOn(ironBoulder, "getAccuracyMultiplier"); // Turn 1 game.move.select(Moves.STEAMROLLER); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.toNextTurn(); // Turn 2 game.move.select(Moves.STEAMROLLER); await game.toNextTurn(); - const [dmgCalcTurn1, dmgCalcTurn2]: DamageCalculationResult[] = vi + const [ dmgCalcTurn1, dmgCalcTurn2 ]: DamageCalculationResult[] = vi .mocked(ditto.getAttackDamage) .mock.results.map((r) => r.value); diff --git a/src/test/moves/stockpile.test.ts b/src/test/moves/stockpile.test.ts index 8e7a44d053b..d3239856ed7 100644 --- a/src/test/moves/stockpile.test.ts +++ b/src/test/moves/stockpile.test.ts @@ -33,12 +33,12 @@ describe("Moves - Stockpile", () => { game.override.enemyAbility(Abilities.NONE); game.override.startingLevel(2000); - game.override.moveset([Moves.STOCKPILE, Moves.SPLASH]); + game.override.moveset([ Moves.STOCKPILE, Moves.SPLASH ]); game.override.ability(Abilities.NONE); }); - it("gains a stockpile stack and raises user's DEF and SPDEF stat stages by 1 on each use, fails at max stacks (3)", { timeout: 10000 }, async () => { - await game.startBattle([Species.ABOMASNOW]); + it("gains a stockpile stack and raises user's DEF and SPDEF stat stages by 1 on each use, fails at max stacks (3)", async () => { + await game.startBattle([ Species.ABOMASNOW ]); const user = game.scene.getPlayerPokemon()!; @@ -76,8 +76,8 @@ describe("Moves - Stockpile", () => { } }); - it("gains a stockpile stack even if user's DEF and SPDEF stat stages are at +6", { timeout: 10000 }, async () => { - await game.startBattle([Species.ABOMASNOW]); + it("gains a stockpile stack even if user's DEF and SPDEF stat stages are at +6", async () => { + await game.startBattle([ Species.ABOMASNOW ]); const user = game.scene.getPlayerPokemon()!; diff --git a/src/test/moves/substitute.test.ts b/src/test/moves/substitute.test.ts index 3976247d489..14ab4ab5054 100644 --- a/src/test/moves/substitute.test.ts +++ b/src/test/moves/substitute.test.ts @@ -1,23 +1,24 @@ +import { BattlerIndex } from "#app/battle"; +import { ArenaTagSide } from "#app/data/arena-tag"; import { SubstituteTag, TrappedTag } from "#app/data/battler-tags"; import { allMoves, StealHeldItemChanceAttr } from "#app/data/move"; -import { StatusEffect } from "#app/data/status-effect"; -import { Abilities } from "#app/enums/abilities"; -import { BattlerTagType } from "#app/enums/battler-tag-type"; -import { BerryType } from "#app/enums/berry-type"; -import { Moves } from "#app/enums/moves"; -import { Species } from "#app/enums/species"; -import { Stat } from "#app/enums/stat"; import { MoveResult } from "#app/field/pokemon"; import { CommandPhase } from "#app/phases/command-phase"; import GameManager from "#app/test/utils/gameManager"; import { Command } from "#app/ui/command-ui-handler"; import { Mode } from "#app/ui/ui"; +import { Abilities } from "#enums/abilities"; +import { ArenaTagType } from "#enums/arena-tag-type"; +import { BattlerTagType } from "#enums/battler-tag-type"; +import { BerryType } from "#enums/berry-type"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import { Stat } from "#enums/stat"; +import { StatusEffect } from "#enums/status-effect"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; -const TIMEOUT = 20 * 1000; // 20 sec timeout - describe("Moves - Substitute", () => { let phaserGame: Phaser.Game; let game: GameManager; @@ -37,7 +38,7 @@ describe("Moves - Substitute", () => { game.override .battleType("single") - .moveset([Moves.SUBSTITUTE, Moves.SWORDS_DANCE, Moves.TACKLE, Moves.SPLASH]) + .moveset([ Moves.SUBSTITUTE, Moves.SWORDS_DANCE, Moves.TACKLE, Moves.SPLASH ]) .enemySpecies(Species.SNORLAX) .enemyAbility(Abilities.INSOMNIA) .enemyMoveset(Moves.SPLASH) @@ -48,7 +49,7 @@ describe("Moves - Substitute", () => { it( "should cause the user to take damage", async () => { - await game.classicMode.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -56,16 +57,16 @@ describe("Moves - Substitute", () => { await game.phaseInterceptor.to("MoveEndPhase", false); - expect(leadPokemon.hp).toBe(Math.ceil(leadPokemon.getMaxHp() * 3/4)); - }, TIMEOUT + expect(leadPokemon.hp).toBe(Math.ceil(leadPokemon.getMaxHp() * 3 / 4)); + } ); it( "should redirect enemy attack damage to the Substitute doll", async () => { - game.override.enemyMoveset(Array(4).fill(Moves.TACKLE)); + game.override.enemyMoveset(Moves.TACKLE); - await game.classicMode.startBattle([Species.SKARMORY]); + await game.classicMode.startBattle([ Species.SKARMORY ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -73,7 +74,7 @@ describe("Moves - Substitute", () => { await game.phaseInterceptor.to("MoveEndPhase", false); - expect(leadPokemon.hp).toBe(Math.ceil(leadPokemon.getMaxHp() * 3/4)); + expect(leadPokemon.hp).toBe(Math.ceil(leadPokemon.getMaxHp() * 3 / 4)); expect(leadPokemon.getTag(BattlerTagType.SUBSTITUTE)).toBeDefined(); const postSubHp = leadPokemon.hp; @@ -81,17 +82,17 @@ describe("Moves - Substitute", () => { expect(leadPokemon.hp).toBe(postSubHp); expect(leadPokemon.getTag(BattlerTagType.SUBSTITUTE)).toBeDefined(); - }, TIMEOUT + } ); it( "should fade after redirecting more damage than its remaining HP", async () => { // Giga Impact OHKOs Magikarp if substitute isn't up - game.override.enemyMoveset(Array(4).fill(Moves.GIGA_IMPACT)); + game.override.enemyMoveset(Moves.GIGA_IMPACT); vi.spyOn(allMoves[Moves.GIGA_IMPACT], "accuracy", "get").mockReturnValue(100); - await game.classicMode.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -99,7 +100,7 @@ describe("Moves - Substitute", () => { await game.phaseInterceptor.to("MoveEndPhase", false); - expect(leadPokemon.hp).toBe(Math.ceil(leadPokemon.getMaxHp() * 3/4)); + expect(leadPokemon.hp).toBe(Math.ceil(leadPokemon.getMaxHp() * 3 / 4)); expect(leadPokemon.getTag(BattlerTagType.SUBSTITUTE)).toBeDefined(); const postSubHp = leadPokemon.hp; @@ -107,15 +108,15 @@ describe("Moves - Substitute", () => { expect(leadPokemon.hp).toBe(postSubHp); expect(leadPokemon.getTag(BattlerTagType.SUBSTITUTE)).toBeUndefined(); - }, TIMEOUT + } ); it( "should block stat changes from status moves", async () => { - game.override.enemyMoveset(Array(4).fill(Moves.CHARM)); + game.override.enemyMoveset(Moves.CHARM); - await game.classicMode.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -131,9 +132,9 @@ describe("Moves - Substitute", () => { it( "should be bypassed by sound-based moves", async () => { - game.override.enemyMoveset(Array(4).fill(Moves.ECHOED_VOICE)); + game.override.enemyMoveset(Moves.ECHOED_VOICE); - await game.classicMode.startBattle([Species.BLASTOISE]); + await game.classicMode.startBattle([ Species.BLASTOISE ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -148,16 +149,16 @@ describe("Moves - Substitute", () => { expect(leadPokemon.getTag(BattlerTagType.SUBSTITUTE)).toBeDefined(); expect(leadPokemon.hp).toBeLessThan(postSubHp); - }, TIMEOUT + } ); it( "should be bypassed by attackers with Infiltrator", async () => { - game.override.enemyMoveset(Array(4).fill(Moves.TACKLE)); + game.override.enemyMoveset(Moves.TACKLE); game.override.enemyAbility(Abilities.INFILTRATOR); - await game.classicMode.startBattle([Species.BLASTOISE]); + await game.classicMode.startBattle([ Species.BLASTOISE ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -172,13 +173,13 @@ describe("Moves - Substitute", () => { expect(leadPokemon.getTag(BattlerTagType.SUBSTITUTE)).toBeDefined(); expect(leadPokemon.hp).toBeLessThan(postSubHp); - }, TIMEOUT + } ); it( "shouldn't block the user's own status moves", async () => { - await game.classicMode.startBattle([Species.BLASTOISE]); + await game.classicMode.startBattle([ Species.BLASTOISE ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -192,16 +193,81 @@ describe("Moves - Substitute", () => { await game.phaseInterceptor.to("MoveEndPhase", false); expect(leadPokemon.getStatStage(Stat.ATK)).toBe(2); - }, TIMEOUT + } + ); + + it( + "shouldn't block moves that target the user's side of the field", + async () => { + game.override.moveset(Moves.LIGHT_SCREEN); + + await game.classicMode.startBattle([ Species.BLASTOISE ]); + + const leadPokemon = game.scene.getPlayerPokemon()!; + vi.spyOn(leadPokemon, "getMoveEffectiveness"); + + leadPokemon.addTag(BattlerTagType.SUBSTITUTE, 0, Moves.NONE, leadPokemon.id); + + game.move.select(Moves.LIGHT_SCREEN); + + await game.toNextTurn(); + + expect(leadPokemon.getMoveEffectiveness).not.toHaveReturnedWith(0); + expect(game.scene.arena.getTagOnSide(ArenaTagType.LIGHT_SCREEN, ArenaTagSide.PLAYER)).toBeDefined(); + } + ); + + it( + "shouldn't block the opponent from setting hazards", + async () => { + game.override.enemyMoveset(Moves.STEALTH_ROCK); + + await game.classicMode.startBattle([ Species.BLASTOISE ]); + + const leadPokemon = game.scene.getPlayerPokemon()!; + vi.spyOn(leadPokemon, "getMoveEffectiveness"); + + game.move.select(Moves.SUBSTITUTE); + + await game.toNextTurn(); + + expect(leadPokemon.getMoveEffectiveness).not.toHaveReturnedWith(0); + expect(game.scene.arena.getTagOnSide(ArenaTagType.STEALTH_ROCK, ArenaTagSide.PLAYER)).toBeDefined(); + } + ); + + it( + "shouldn't block moves that target both sides of the field", + async () => { + game.override + .moveset(Moves.TRICK_ROOM) + .enemyMoveset(Moves.GRAVITY); + + await game.classicMode.startBattle([ Species.BLASTOISE ]); + + const pokemon = game.scene.getField(true); + pokemon.forEach(p => { + vi.spyOn(p, "getMoveEffectiveness"); + p.addTag(BattlerTagType.SUBSTITUTE, 0, Moves.NONE, p.id); + }); + + game.move.select(Moves.TRICK_ROOM); + + await game.toNextTurn(); + + pokemon.forEach(p => expect(p.getMoveEffectiveness).not.toHaveReturnedWith(0)); + expect(game.scene.arena.getTag(ArenaTagType.TRICK_ROOM)).toBeDefined(); + expect(game.scene.arena.getTag(ArenaTagType.GRAVITY)).toBeDefined(); + } ); it( "should protect the user from flinching", async () => { - game.override.enemyMoveset(Array(4).fill(Moves.FAKE_OUT)); + game.override.enemyMoveset(Moves.FAKE_OUT); game.override.startingLevel(1); // Ensures the Substitute will break - await game.classicMode.startBattle([Species.BLASTOISE]); + await game.classicMode.startBattle([ Species.BLASTOISE ]); const leadPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -213,16 +279,16 @@ describe("Moves - Substitute", () => { await game.phaseInterceptor.to("BerryPhase", false); expect(enemyPokemon.hp).toBeLessThan(enemyPokemon.getMaxHp()); - }, TIMEOUT + } ); it( "should protect the user from being trapped", async () => { vi.spyOn(allMoves[Moves.SAND_TOMB], "accuracy", "get").mockReturnValue(100); - game.override.enemyMoveset(Array(4).fill(Moves.SAND_TOMB)); + game.override.enemyMoveset(Moves.SAND_TOMB); - await game.classicMode.startBattle([Species.BLASTOISE]); + await game.classicMode.startBattle([ Species.BLASTOISE ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -233,16 +299,16 @@ describe("Moves - Substitute", () => { await game.phaseInterceptor.to("BerryPhase", false); expect(leadPokemon.getTag(TrappedTag)).toBeUndefined(); - }, TIMEOUT + } ); it( "should prevent the user's stats from being lowered", async () => { vi.spyOn(allMoves[Moves.LIQUIDATION], "chance", "get").mockReturnValue(100); - game.override.enemyMoveset(Array(4).fill(Moves.LIQUIDATION)); + game.override.enemyMoveset(Moves.LIQUIDATION); - await game.classicMode.startBattle([Species.BLASTOISE]); + await game.classicMode.startBattle([ Species.BLASTOISE ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -253,15 +319,15 @@ describe("Moves - Substitute", () => { await game.phaseInterceptor.to("BerryPhase", false); expect(leadPokemon.getStatStage(Stat.DEF)).toBe(0); - }, TIMEOUT + } ); it( "should protect the user from being afflicted with status effects", async () => { - game.override.enemyMoveset(Array(4).fill(Moves.NUZZLE)); + game.override.enemyMoveset(Moves.NUZZLE); - await game.classicMode.startBattle([Species.BLASTOISE]); + await game.classicMode.startBattle([ Species.BLASTOISE ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -272,17 +338,17 @@ describe("Moves - Substitute", () => { await game.phaseInterceptor.to("BerryPhase", false); expect(leadPokemon.status?.effect).not.toBe(StatusEffect.PARALYSIS); - }, TIMEOUT + } ); it( "should prevent the user's items from being stolen", async () => { - game.override.enemyMoveset(Array(4).fill(Moves.THIEF)); - vi.spyOn(allMoves[Moves.THIEF], "attrs", "get").mockReturnValue([new StealHeldItemChanceAttr(1.0)]); // give Thief 100% steal rate - game.override.startingHeldItems([{name: "BERRY", type: BerryType.SITRUS}]); + game.override.enemyMoveset(Moves.THIEF); + vi.spyOn(allMoves[Moves.THIEF], "attrs", "get").mockReturnValue([ new StealHeldItemChanceAttr(1.0) ]); // give Thief 100% steal rate + game.override.startingHeldItems([{ name: "BERRY", type: BerryType.SITRUS }]); - await game.classicMode.startBattle([Species.BLASTOISE]); + await game.classicMode.startBattle([ Species.BLASTOISE ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -293,16 +359,16 @@ describe("Moves - Substitute", () => { await game.phaseInterceptor.to("BerryPhase", false); expect(leadPokemon.getHeldItems().length).toBe(1); - }, TIMEOUT + } ); it( "should prevent the user's items from being removed", async () => { - game.override.moveset([Moves.KNOCK_OFF]); - game.override.enemyHeldItems([{name: "BERRY", type: BerryType.SITRUS}]); + game.override.moveset([ Moves.KNOCK_OFF ]); + game.override.enemyHeldItems([{ name: "BERRY", type: BerryType.SITRUS }]); - await game.classicMode.startBattle([Species.BLASTOISE]); + await game.classicMode.startBattle([ Species.BLASTOISE ]); const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -314,16 +380,16 @@ describe("Moves - Substitute", () => { await game.phaseInterceptor.to("MoveEndPhase", false); expect(enemyPokemon.getHeldItems().length).toBe(enemyNumItems); - }, TIMEOUT + } ); it( "move effect should prevent the user's berries from being stolen and eaten", async () => { - game.override.enemyMoveset(Array(4).fill(Moves.BUG_BITE)); - game.override.startingHeldItems([{name: "BERRY", type: BerryType.SITRUS}]); + game.override.enemyMoveset(Moves.BUG_BITE); + game.override.startingHeldItems([{ name: "BERRY", type: BerryType.SITRUS }]); - await game.classicMode.startBattle([Species.BLASTOISE]); + await game.classicMode.startBattle([ Species.BLASTOISE ]); const leadPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -339,15 +405,15 @@ describe("Moves - Substitute", () => { expect(leadPokemon.getHeldItems().length).toBe(1); expect(enemyPokemon.hp).toBe(enemyPostAttackHp); - }, TIMEOUT + } ); it( "should prevent the user's stats from being reset by Clear Smog", async () => { - game.override.enemyMoveset(Array(4).fill(Moves.CLEAR_SMOG)); + game.override.enemyMoveset(Moves.CLEAR_SMOG); - await game.classicMode.startBattle([Species.BLASTOISE]); + await game.classicMode.startBattle([ Species.BLASTOISE ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -358,16 +424,16 @@ describe("Moves - Substitute", () => { await game.phaseInterceptor.to("BerryPhase", false); expect(leadPokemon.getStatStage(Stat.ATK)).toBe(2); - }, TIMEOUT + } ); it( "should prevent the user from becoming confused", async () => { - game.override.enemyMoveset(Array(4).fill(Moves.MAGICAL_TORQUE)); + game.override.enemyMoveset(Moves.MAGICAL_TORQUE); vi.spyOn(allMoves[Moves.MAGICAL_TORQUE], "chance", "get").mockReturnValue(100); - await game.classicMode.startBattle([Species.BLASTOISE]); + await game.classicMode.startBattle([ Species.BLASTOISE ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -385,9 +451,9 @@ describe("Moves - Substitute", () => { it( "should transfer to the switched in Pokemon when the source uses Baton Pass", async () => { - game.override.moveset([Moves.SUBSTITUTE, Moves.BATON_PASS]); + game.override.moveset([ Moves.SUBSTITUTE, Moves.BATON_PASS ]); - await game.classicMode.startBattle([Species.BLASTOISE, Species.CHARIZARD]); + await game.classicMode.startBattle([ Species.BLASTOISE, Species.CHARIZARD ]); const leadPokemon = game.scene.getPlayerPokemon()!; @@ -403,17 +469,17 @@ describe("Moves - Substitute", () => { const switchedPokemon = game.scene.getPlayerPokemon()!; const subTag = switchedPokemon.getTag(SubstituteTag)!; expect(subTag).toBeDefined(); - expect(subTag.hp).toBe(Math.floor(leadPokemon.getMaxHp() * 1/4)); - }, TIMEOUT + expect(subTag.hp).toBe(Math.floor(leadPokemon.getMaxHp() * 1 / 4)); + } ); it( "should prevent the source's Rough Skin from activating when hit", async () => { - game.override.enemyMoveset(Array(4).fill(Moves.TACKLE)); + game.override.enemyMoveset(Moves.TACKLE); game.override.ability(Abilities.ROUGH_SKIN); - await game.classicMode.startBattle([Species.BLASTOISE]); + await game.classicMode.startBattle([ Species.BLASTOISE ]); const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -422,19 +488,19 @@ describe("Moves - Substitute", () => { await game.phaseInterceptor.to("BerryPhase", false); expect(enemyPokemon.hp).toBe(enemyPokemon.getMaxHp()); - }, TIMEOUT + } ); it( "should prevent the source's Focus Punch from failing when hit", async () => { - game.override.enemyMoveset(Array(4).fill(Moves.TACKLE)); - game.override.moveset([Moves.FOCUS_PUNCH]); + game.override.enemyMoveset(Moves.TACKLE); + game.override.moveset([ Moves.FOCUS_PUNCH ]); // Make Focus Punch 40 power to avoid a KO vi.spyOn(allMoves[Moves.FOCUS_PUNCH], "calculateBattlePower").mockReturnValue(40); - await game.classicMode.startBattle([Species.BLASTOISE]); + await game.classicMode.startBattle([ Species.BLASTOISE ]); const playerPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -447,16 +513,16 @@ describe("Moves - Substitute", () => { expect(playerPokemon.getLastXMoves()[0].result).toBe(MoveResult.SUCCESS); expect(enemyPokemon.hp).toBeLessThan(enemyPokemon.getMaxHp()); - }, TIMEOUT + } ); it( "should not allow Shell Trap to activate when attacked", async () => { - game.override.enemyMoveset(Array(4).fill(Moves.TACKLE)); - game.override.moveset([Moves.SHELL_TRAP]); + game.override.enemyMoveset(Moves.TACKLE); + game.override.moveset([ Moves.SHELL_TRAP ]); - await game.classicMode.startBattle([Species.BLASTOISE]); + await game.classicMode.startBattle([ Species.BLASTOISE ]); const playerPokemon = game.scene.getPlayerPokemon()!; @@ -467,16 +533,16 @@ describe("Moves - Substitute", () => { await game.phaseInterceptor.to("BerryPhase", false); expect(playerPokemon.getLastXMoves()[0].result).toBe(MoveResult.FAIL); - }, TIMEOUT + } ); it( "should not allow Beak Blast to burn opponents when hit", async () => { - game.override.enemyMoveset(Array(4).fill(Moves.TACKLE)); - game.override.moveset([Moves.BEAK_BLAST]); + game.override.enemyMoveset(Moves.TACKLE); + game.override.moveset([ Moves.BEAK_BLAST ]); - await game.classicMode.startBattle([Species.BLASTOISE]); + await game.classicMode.startBattle([ Species.BLASTOISE ]); const playerPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -488,16 +554,16 @@ describe("Moves - Substitute", () => { await game.phaseInterceptor.to("MoveEndPhase"); expect(enemyPokemon.status?.effect).not.toBe(StatusEffect.BURN); - }, TIMEOUT + } ); it( "should cause incoming attacks to not activate Counter", - async() => { - game.override.enemyMoveset(Array(4).fill(Moves.TACKLE)); - game.override.moveset([Moves.COUNTER]); + async () => { + game.override.enemyMoveset(Moves.TACKLE); + game.override.moveset([ Moves.COUNTER ]); - await game.classicMode.startBattle([Species.BLASTOISE]); + await game.classicMode.startBattle([ Species.BLASTOISE ]); const playerPokemon = game.scene.getPlayerPokemon()!; const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -512,4 +578,25 @@ describe("Moves - Substitute", () => { expect(enemyPokemon.hp).toBe(enemyPokemon.getMaxHp()); } ); + + it( + "should prevent Sappy Seed from applying its Leech Seed effect to the user", + async () => { + game.override.enemyMoveset(Moves.SAPPY_SEED); + + await game.classicMode.startBattle([ Species.CHARIZARD ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + + playerPokemon.addTag(BattlerTagType.SUBSTITUTE, 0, Moves.NONE, playerPokemon.id); + + game.move.select(Moves.SPLASH); + + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); // enemy uses Sappy Seed first + await game.move.forceHit(); // forces Sappy Seed to hit + await game.phaseInterceptor.to("MoveEndPhase"); + + expect(playerPokemon.getTag(BattlerTagType.SEEDED)).toBeUndefined(); + } + ); }); diff --git a/src/test/moves/swallow.test.ts b/src/test/moves/swallow.test.ts index 5a0e63e6e78..2aee4d2604a 100644 --- a/src/test/moves/swallow.test.ts +++ b/src/test/moves/swallow.test.ts @@ -33,16 +33,16 @@ describe("Moves - Swallow", () => { game.override.enemyAbility(Abilities.NONE); game.override.enemyLevel(2000); - game.override.moveset([Moves.SWALLOW, Moves.SWALLOW, Moves.SWALLOW, Moves.SWALLOW]); + game.override.moveset([ Moves.SWALLOW, Moves.SWALLOW, Moves.SWALLOW, Moves.SWALLOW ]); game.override.ability(Abilities.NONE); }); describe("consumes all stockpile stacks to heal (scaling with stacks)", () => { - it("1 stack -> 25% heal", { timeout: 10000 }, async () => { + it("1 stack -> 25% heal", async () => { const stacksToSetup = 1; const expectedHeal = 25; - await game.startBattle([Species.ABOMASNOW]); + await game.startBattle([ Species.ABOMASNOW ]); const pokemon = game.scene.getPlayerPokemon()!; vi.spyOn(pokemon, "getMaxHp").mockReturnValue(100); @@ -65,11 +65,11 @@ describe("Moves - Swallow", () => { expect(pokemon.getTag(StockpilingTag)).toBeUndefined(); }); - it("2 stacks -> 50% heal", { timeout: 10000 }, async () => { + it("2 stacks -> 50% heal", async () => { const stacksToSetup = 2; const expectedHeal = 50; - await game.startBattle([Species.ABOMASNOW]); + await game.startBattle([ Species.ABOMASNOW ]); const pokemon = game.scene.getPlayerPokemon()!; vi.spyOn(pokemon, "getMaxHp").mockReturnValue(100); @@ -93,11 +93,11 @@ describe("Moves - Swallow", () => { expect(pokemon.getTag(StockpilingTag)).toBeUndefined(); }); - it("3 stacks -> 100% heal", { timeout: 10000 }, async () => { + it("3 stacks -> 100% heal", async () => { const stacksToSetup = 3; const expectedHeal = 100; - await game.startBattle([Species.ABOMASNOW]); + await game.startBattle([ Species.ABOMASNOW ]); const pokemon = game.scene.getPlayerPokemon()!; vi.spyOn(pokemon, "getMaxHp").mockReturnValue(100); @@ -123,8 +123,8 @@ describe("Moves - Swallow", () => { }); }); - it("fails without stacks", { timeout: 10000 }, async () => { - await game.startBattle([Species.ABOMASNOW]); + it("fails without stacks", async () => { + await game.startBattle([ Species.ABOMASNOW ]); const pokemon = game.scene.getPlayerPokemon()!; @@ -138,8 +138,8 @@ describe("Moves - Swallow", () => { }); describe("restores stat stage boosts granted by stacks", () => { - it("decreases stats based on stored values (both boosts equal)", { timeout: 10000 }, async () => { - await game.startBattle([Species.ABOMASNOW]); + it("decreases stats based on stored values (both boosts equal)", async () => { + await game.startBattle([ Species.ABOMASNOW ]); const pokemon = game.scene.getPlayerPokemon()!; pokemon.addTag(BattlerTagType.STOCKPILING); @@ -163,8 +163,8 @@ describe("Moves - Swallow", () => { expect(pokemon.getTag(StockpilingTag)).toBeUndefined(); }); - it("lower stat stages based on stored values (different boosts)", { timeout: 10000 }, async () => { - await game.startBattle([Species.ABOMASNOW]); + it("lower stat stages based on stored values (different boosts)", async () => { + await game.startBattle([ Species.ABOMASNOW ]); const pokemon = game.scene.getPlayerPokemon()!; pokemon.addTag(BattlerTagType.STOCKPILING); diff --git a/src/test/moves/syrup_bomb.test.ts b/src/test/moves/syrup_bomb.test.ts new file mode 100644 index 00000000000..ea2f8b6bab3 --- /dev/null +++ b/src/test/moves/syrup_bomb.test.ts @@ -0,0 +1,96 @@ +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import { Abilities } from "#enums/abilities"; +import { BattlerTagType } from "#enums/battler-tag-type"; +import { Stat } from "#enums/stat"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { BattlerIndex } from "#app/battle"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; + +describe("Moves - SYRUP BOMB", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .battleType("single") + .enemySpecies(Species.SNORLAX) + .enemyAbility(Abilities.BALL_FETCH) + .ability(Abilities.BALL_FETCH) + .startingLevel(30) + .enemyLevel(100) + .moveset([ Moves.SYRUP_BOMB, Moves.SPLASH ]) + .enemyMoveset(Moves.SPLASH); + }); + + //Bulbapedia Reference: https://bulbapedia.bulbagarden.net/wiki/syrup_bomb_(move) + + it("decreases the target Pokemon's speed stat once per turn for 3 turns", + async () => { + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const targetPokemon = game.scene.getEnemyPokemon()!; + expect(targetPokemon.getStatStage(Stat.SPD)).toBe(0); + + game.move.select(Moves.SYRUP_BOMB); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + await game.move.forceHit(); + await game.toNextTurn(); + expect(targetPokemon.getTag(BattlerTagType.SYRUP_BOMB)).toBeDefined(); + expect(targetPokemon.getStatStage(Stat.SPD)).toBe(-1); + + game.move.select(Moves.SPLASH); + await game.toNextTurn(); + expect(targetPokemon.getTag(BattlerTagType.SYRUP_BOMB)).toBeDefined(); + expect(targetPokemon.getStatStage(Stat.SPD)).toBe(-2); + + game.move.select(Moves.SPLASH); + await game.toNextTurn(); + expect(targetPokemon.getTag(BattlerTagType.SYRUP_BOMB)).toBeUndefined(); + expect(targetPokemon.getStatStage(Stat.SPD)).toBe(-3); + } + ); + + it("does not affect Pokemon with the ability Bulletproof", + async () => { + game.override.enemyAbility(Abilities.BULLETPROOF); + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const targetPokemon = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.SYRUP_BOMB); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + await game.move.forceHit(); + await game.toNextTurn(); + expect(targetPokemon.isFullHp()).toBe(true); + expect(targetPokemon.getTag(BattlerTagType.SYRUP_BOMB)).toBeUndefined(); + expect(targetPokemon.getStatStage(Stat.SPD)).toBe(0); + } + ); + + it("stops lowering the target's speed if the user leaves the field", async () => { + await game.classicMode.startBattle([ Species.FEEBAS, Species.MILOTIC ]); + + game.move.select(Moves.SYRUP_BOMB); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + await game.move.forceHit(); + await game.toNextTurn(); + + game.doSwitchPokemon(1); + await game.toNextTurn(); + + expect(game.scene.getEnemyPokemon()!.getStatStage(Stat.SPD)).toBe(-1); + }); +}); diff --git a/src/test/moves/tackle.test.ts b/src/test/moves/tackle.test.ts index b25c7524a1a..ff50f027f87 100644 --- a/src/test/moves/tackle.test.ts +++ b/src/test/moves/tackle.test.ts @@ -29,8 +29,8 @@ describe("Moves - Tackle", () => { game.override.enemySpecies(Species.MAGIKARP); game.override.startingLevel(1); game.override.startingWave(97); - game.override.moveset([moveToUse]); - game.override.enemyMoveset([Moves.GROWTH, Moves.GROWTH, Moves.GROWTH, Moves.GROWTH]); + game.override.moveset([ moveToUse ]); + game.override.enemyMoveset([ Moves.GROWTH, Moves.GROWTH, Moves.GROWTH, Moves.GROWTH ]); game.override.disableCrits(); }); @@ -53,7 +53,7 @@ describe("Moves - Tackle", () => { Species.MIGHTYENA, ]); game.scene.currentBattle.enemyParty[0].stats[Stat.DEF] = 50; - game.scene.getParty()[0].stats[Stat.ATK] = 50; + game.scene.getPlayerParty()[0].stats[Stat.ATK] = 50; const hpOpponent = game.scene.currentBattle.enemyParty[0].hp; diff --git a/src/test/moves/tailwind.test.ts b/src/test/moves/tailwind.test.ts index 6a08cfe802f..a26dde82824 100644 --- a/src/test/moves/tailwind.test.ts +++ b/src/test/moves/tailwind.test.ts @@ -25,12 +25,12 @@ describe("Moves - Tailwind", () => { beforeEach(() => { game = new GameManager(phaserGame); game.override.battleType("double"); - game.override.moveset([Moves.TAILWIND, Moves.SPLASH, Moves.PETAL_BLIZZARD, Moves.SANDSTORM]); + game.override.moveset([ Moves.TAILWIND, Moves.SPLASH, Moves.PETAL_BLIZZARD, Moves.SANDSTORM ]); game.override.enemyMoveset(Moves.SPLASH); }); it("doubles the Speed stat of the Pokemons on its side", async () => { - await game.startBattle([Species.MAGIKARP, Species.MEOWTH]); + await game.startBattle([ Species.MAGIKARP, Species.MEOWTH ]); const magikarp = game.scene.getPlayerField()[0]; const meowth = game.scene.getPlayerField()[1]; @@ -53,7 +53,7 @@ describe("Moves - Tailwind", () => { it("lasts for 4 turns", async () => { game.override.battleType("single"); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); game.move.select(Moves.TAILWIND); await game.toNextTurn(); @@ -76,7 +76,7 @@ describe("Moves - Tailwind", () => { it("does not affect the opposing side", async () => { game.override.battleType("single"); - await game.startBattle([Species.MAGIKARP]); + await game.startBattle([ Species.MAGIKARP ]); const ally = game.scene.getPlayerPokemon()!; const enemy = game.scene.getEnemyPokemon()!; diff --git a/src/test/moves/tar_shot.test.ts b/src/test/moves/tar_shot.test.ts index 2963f061fc6..5fb70abc19c 100644 --- a/src/test/moves/tar_shot.test.ts +++ b/src/test/moves/tar_shot.test.ts @@ -1,5 +1,5 @@ import { BattlerIndex } from "#app/battle"; -import { Type } from "#app/data/type"; +import { Type } from "#enums/type"; import { Moves } from "#app/enums/moves"; import { Species } from "#app/enums/species"; import { Stat } from "#app/enums/stat"; @@ -11,8 +11,6 @@ import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vite describe("Moves - Tar Shot", () => { let phaserGame: Phaser.Game; let game: GameManager; - const TIMEOUT = 20 * 1000; - beforeAll(() => { phaserGame = new Phaser.Game({ type: Phaser.HEADLESS, @@ -31,12 +29,12 @@ describe("Moves - Tar Shot", () => { .enemyMoveset(Moves.SPLASH) .enemySpecies(Species.TANGELA) .enemyLevel(1000) - .moveset([Moves.TAR_SHOT, Moves.FIRE_PUNCH]) + .moveset([ Moves.TAR_SHOT, Moves.FIRE_PUNCH ]) .disableCrits(); }); it("lowers the target's Speed stat by one stage and doubles the effectiveness of Fire-type moves used on the target", async () => { - await game.classicMode.startBattle([Species.PIKACHU]); + await game.classicMode.startBattle([ Species.PIKACHU ]); const enemy = game.scene.getEnemyPokemon()!; @@ -50,14 +48,14 @@ describe("Moves - Tar Shot", () => { await game.toNextTurn(); game.move.select(Moves.FIRE_PUNCH); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to("MoveEndPhase"); expect(enemy.getMoveEffectiveness).toHaveReturnedWith(4); - }, TIMEOUT); + }); it("will not double the effectiveness of Fire-type moves used on a target that is already under the effect of Tar Shot (but may still lower its Speed)", async () => { - await game.classicMode.startBattle([Species.PIKACHU]); + await game.classicMode.startBattle([ Species.PIKACHU ]); const enemy = game.scene.getEnemyPokemon()!; @@ -78,15 +76,15 @@ describe("Moves - Tar Shot", () => { await game.toNextTurn(); game.move.select(Moves.FIRE_PUNCH); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to("MoveEndPhase"); expect(enemy.getMoveEffectiveness).toHaveReturnedWith(4); - }, TIMEOUT); + }); it("does not double the effectiveness of Fire-type moves against a Pokémon that is Terastallized", async () => { game.override.enemyHeldItems([{ name: "TERA_SHARD", type: Type.GRASS }]).enemySpecies(Species.SPRIGATITO); - await game.classicMode.startBattle([Species.PIKACHU]); + await game.classicMode.startBattle([ Species.PIKACHU ]); const enemy = game.scene.getEnemyPokemon()!; @@ -100,15 +98,15 @@ describe("Moves - Tar Shot", () => { await game.toNextTurn(); game.move.select(Moves.FIRE_PUNCH); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to("MoveEndPhase"); expect(enemy.getMoveEffectiveness).toHaveReturnedWith(2); - }, TIMEOUT); + }); it("doubles the effectiveness of Fire-type moves against a Pokémon that is already under the effects of Tar Shot before it Terastallized", async () => { game.override.enemySpecies(Species.SPRIGATITO); - await game.classicMode.startBattle([Species.PIKACHU]); + await game.classicMode.startBattle([ Species.PIKACHU ]); const enemy = game.scene.getEnemyPokemon()!; @@ -124,9 +122,9 @@ describe("Moves - Tar Shot", () => { game.override.enemyHeldItems([{ name: "TERA_SHARD", type: Type.GRASS }]); game.move.select(Moves.FIRE_PUNCH); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to("MoveEndPhase"); expect(enemy.getMoveEffectiveness).toHaveReturnedWith(4); - }, TIMEOUT); + }); }); diff --git a/src/test/moves/taunt.test.ts b/src/test/moves/taunt.test.ts new file mode 100644 index 00000000000..a425a048a2c --- /dev/null +++ b/src/test/moves/taunt.test.ts @@ -0,0 +1,54 @@ +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import { Abilities } from "#enums/abilities"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; +import { MoveResult } from "#app/field/pokemon"; +import { BattlerTagType } from "#enums/battler-tag-type"; + +describe("Moves - Taunt", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .battleType("single") + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset([ Moves.TAUNT, Moves.SPLASH ]) + .enemySpecies(Species.SHUCKLE) + .moveset([ Moves.GROWL ]); + }); + + it("Pokemon should not be able to use Status Moves", async () => { + await game.classicMode.startBattle([ Species.REGIELEKI ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + + // First turn, Player Pokemon succeeds using Growl without Taunt + game.move.select(Moves.GROWL); + await game.forceEnemyMove(Moves.TAUNT); + await game.toNextTurn(); + const move1 = playerPokemon.getLastXMoves(1)[0]!; + expect(move1.move).toBe(Moves.GROWL); + expect(move1.result).toBe(MoveResult.SUCCESS); + expect(playerPokemon?.getTag(BattlerTagType.TAUNT)).toBeDefined(); + + // Second turn, Taunt forces Struggle to occur + game.move.select(Moves.GROWL); + await game.forceEnemyMove(Moves.SPLASH); + await game.toNextTurn(); + const move2 = playerPokemon.getLastXMoves(1)[0]!; + expect(move2.move).toBe(Moves.STRUGGLE); + }); +}); diff --git a/src/test/moves/telekinesis.test.ts b/src/test/moves/telekinesis.test.ts new file mode 100644 index 00000000000..76c0d001f00 --- /dev/null +++ b/src/test/moves/telekinesis.test.ts @@ -0,0 +1,124 @@ +import { BattlerTagType } from "#enums/battler-tag-type"; +import { allMoves } from "#app/data/move"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import { MoveResult } from "#app/field/pokemon"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, it, expect, vi } from "vitest"; + +describe("Moves - Telekinesis", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.TELEKINESIS, Moves.TACKLE, Moves.MUD_SHOT, Moves.SMACK_DOWN ]) + .battleType("single") + .enemySpecies(Species.SNORLAX) + .enemyLevel(60) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset([ Moves.SPLASH ]); + }); + + it("Telekinesis makes the affected vulnerable to most attacking moves regardless of accuracy", async () => { + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const enemyOpponent = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.TELEKINESIS); + await game.phaseInterceptor.to("TurnEndPhase"); + expect(enemyOpponent.getTag(BattlerTagType.TELEKINESIS)).toBeDefined(); + expect(enemyOpponent.getTag(BattlerTagType.FLOATING)).toBeDefined(); + + await game.toNextTurn(); + vi.spyOn(allMoves[Moves.TACKLE], "accuracy", "get").mockReturnValue(0); + game.move.select(Moves.TACKLE); + await game.phaseInterceptor.to("TurnEndPhase"); + expect(enemyOpponent.isFullHp()).toBe(false); + }); + + it("Telekinesis makes the affected airborne and immune to most Ground-moves", async () => { + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const enemyOpponent = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.TELEKINESIS); + await game.phaseInterceptor.to("TurnEndPhase"); + expect(enemyOpponent.getTag(BattlerTagType.TELEKINESIS)).toBeDefined(); + expect(enemyOpponent.getTag(BattlerTagType.FLOATING)).toBeDefined(); + + await game.toNextTurn(); + vi.spyOn(allMoves[Moves.MUD_SHOT], "accuracy", "get").mockReturnValue(100); + game.move.select(Moves.MUD_SHOT); + await game.phaseInterceptor.to("TurnEndPhase"); + expect(enemyOpponent.isFullHp()).toBe(true); + }); + + it("Telekinesis can still affect Pokemon that have been transformed into invalid Pokemon", async () => { + game.override.enemyMoveset(Moves.TRANSFORM); + await game.classicMode.startBattle([ Species.DIGLETT ]); + + const enemyOpponent = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.TELEKINESIS); + await game.phaseInterceptor.to("TurnEndPhase"); + expect(enemyOpponent.getTag(BattlerTagType.TELEKINESIS)).toBeDefined(); + expect(enemyOpponent.getTag(BattlerTagType.FLOATING)).toBeDefined(); + expect(enemyOpponent.summonData.speciesForm?.speciesId).toBe(Species.DIGLETT); + }); + + it("Moves like Smack Down and 1000 Arrows remove all effects of Telekinesis from the target Pokemon", async () => { + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const enemyOpponent = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.TELEKINESIS); + await game.phaseInterceptor.to("TurnEndPhase"); + expect(enemyOpponent.getTag(BattlerTagType.TELEKINESIS)).toBeDefined(); + expect(enemyOpponent.getTag(BattlerTagType.FLOATING)).toBeDefined(); + + await game.toNextTurn(); + game.move.select(Moves.SMACK_DOWN); + await game.phaseInterceptor.to("TurnEndPhase"); + expect(enemyOpponent.getTag(BattlerTagType.TELEKINESIS)).toBeUndefined(); + expect(enemyOpponent.getTag(BattlerTagType.FLOATING)).toBeUndefined(); + }); + + it("Ingrain will remove the floating effect of Telekinesis, but not the 100% hit", async () => { + game.override.enemyMoveset([ Moves.SPLASH, Moves.INGRAIN ]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + const enemyOpponent = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.TELEKINESIS); + await game.forceEnemyMove(Moves.SPLASH); + await game.phaseInterceptor.to("TurnEndPhase"); + expect(enemyOpponent.getTag(BattlerTagType.TELEKINESIS)).toBeDefined(); + expect(enemyOpponent.getTag(BattlerTagType.FLOATING)).toBeDefined(); + + await game.toNextTurn(); + vi.spyOn(allMoves[Moves.MUD_SHOT], "accuracy", "get").mockReturnValue(0); + game.move.select(Moves.MUD_SHOT); + await game.forceEnemyMove(Moves.INGRAIN); + await game.phaseInterceptor.to("TurnEndPhase"); + expect(enemyOpponent.getTag(BattlerTagType.TELEKINESIS)).toBeDefined(); + expect(enemyOpponent.getTag(BattlerTagType.INGRAIN)).toBeDefined(); + expect(enemyOpponent.getTag(BattlerTagType.IGNORE_FLYING)).toBeDefined(); + expect(enemyOpponent.getTag(BattlerTagType.FLOATING)).toBeUndefined(); + expect(playerPokemon.getLastXMoves()[0].result).toBe(MoveResult.SUCCESS); + }); +}); diff --git a/src/test/moves/tera_blast.test.ts b/src/test/moves/tera_blast.test.ts index 55d61496297..311ac0f0d0e 100644 --- a/src/test/moves/tera_blast.test.ts +++ b/src/test/moves/tera_blast.test.ts @@ -1,7 +1,7 @@ import { BattlerIndex } from "#app/battle"; import { Stat } from "#enums/stat"; import { allMoves } from "#app/data/move"; -import { Type } from "#app/data/type"; +import { Type } from "#enums/type"; import { Abilities } from "#app/enums/abilities"; import { HitResult } from "#app/field/pokemon"; import { Moves } from "#enums/moves"; @@ -32,7 +32,7 @@ describe("Moves - Tera Blast", () => { .battleType("single") .disableCrits() .starterSpecies(Species.FEEBAS) - .moveset([Moves.TERA_BLAST]) + .moveset([ Moves.TERA_BLAST ]) .ability(Abilities.BALL_FETCH) .startingHeldItems([{ name: "TERA_SHARD", type: Type.FIRE }]) .enemySpecies(Species.MAGIKARP) @@ -52,7 +52,7 @@ describe("Moves - Tera Blast", () => { vi.spyOn(enemyPokemon, "apply"); game.move.select(Moves.TERA_BLAST); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to("MoveEffectPhase"); expect(enemyPokemon.apply).toHaveReturnedWith(HitResult.SUPER_EFFECTIVE); @@ -64,7 +64,7 @@ describe("Moves - Tera Blast", () => { await game.startBattle(); game.move.select(Moves.TERA_BLAST); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to("MoveEffectPhase"); expect(moveToCheck.calculateBattlePower).toHaveReturnedWith(100); @@ -80,7 +80,7 @@ describe("Moves - Tera Blast", () => { vi.spyOn(enemyPokemon, "isTerastallized").mockReturnValue(true); game.move.select(Moves.TERA_BLAST); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to("MoveEffectPhase"); expect(enemyPokemon.apply).toHaveReturnedWith(HitResult.SUPER_EFFECTIVE); @@ -107,7 +107,7 @@ describe("Moves - Tera Blast", () => { const playerPokemon = game.scene.getPlayerPokemon()!; game.move.select(Moves.TERA_BLAST); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to("MoveEndPhase"); expect(playerPokemon.getStatStage(Stat.SPATK)).toBe(-1); diff --git a/src/test/moves/tera_starstorm.test.ts b/src/test/moves/tera_starstorm.test.ts new file mode 100644 index 00000000000..22dd5b3c4d1 --- /dev/null +++ b/src/test/moves/tera_starstorm.test.ts @@ -0,0 +1,98 @@ +import { BattlerIndex } from "#app/battle"; +import { Type } from "#enums/type"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, it, expect, vi } from "vitest"; + +describe("Moves - Tera Starstorm", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.TERA_STARSTORM, Moves.SPLASH ]) + .battleType("double") + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.SPLASH) + .enemyLevel(30) + .enemySpecies(Species.MAGIKARP) + .startingHeldItems([{ name: "TERA_SHARD", type: Type.FIRE }]); + }); + + it("changes type to Stellar when used by Terapagos in its Stellar Form", async () => { + game.override.battleType("single"); + await game.classicMode.startBattle([ Species.TERAPAGOS ]); + + const terapagos = game.scene.getPlayerPokemon()!; + + vi.spyOn(terapagos, "getMoveType"); + + game.move.select(Moves.TERA_STARSTORM); + await game.phaseInterceptor.to("TurnEndPhase"); + + expect(terapagos.isTerastallized()).toBe(true); + expect(terapagos.getMoveType).toHaveReturnedWith(Type.STELLAR); + }); + + it("targets both opponents in a double battle when used by Terapagos in its Stellar Form", async () => { + await game.classicMode.startBattle([ Species.MAGIKARP, Species.TERAPAGOS ]); + + game.move.select(Moves.TERA_STARSTORM, 0, BattlerIndex.ENEMY); + game.move.select(Moves.TERA_STARSTORM, 1); + + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.PLAYER_2, BattlerIndex.ENEMY, BattlerIndex.ENEMY_2 ]); + + const enemyField = game.scene.getEnemyField(); + + // Pokemon other than Terapagos should not be affected - only hits one target + await game.phaseInterceptor.to("MoveEndPhase"); + expect(enemyField.some(pokemon => pokemon.isFullHp())).toBe(true); + + // Terapagos in Stellar Form should hit both targets + await game.phaseInterceptor.to("MoveEndPhase"); + expect(enemyField.every(pokemon => pokemon.isFullHp())).toBe(false); + }); + + it("applies the effects when Terapagos in Stellar Form is fused with another Pokemon", async () => { + await game.classicMode.startBattle([ Species.TERAPAGOS, Species.CHARMANDER, Species.MAGIKARP ]); + + const fusionedMon = game.scene.getPlayerParty()[0]; + const magikarp = game.scene.getPlayerParty()[2]; + + // Fuse party members (taken from PlayerPokemon.fuse(...) function) + fusionedMon.fusionSpecies = magikarp.species; + fusionedMon.fusionFormIndex = magikarp.formIndex; + fusionedMon.fusionAbilityIndex = magikarp.abilityIndex; + fusionedMon.fusionShiny = magikarp.shiny; + fusionedMon.fusionVariant = magikarp.variant; + fusionedMon.fusionGender = magikarp.gender; + fusionedMon.fusionLuck = magikarp.luck; + + vi.spyOn(fusionedMon, "getMoveType"); + + game.move.select(Moves.TERA_STARSTORM, 0); + game.move.select(Moves.SPLASH, 1); + await game.phaseInterceptor.to("TurnEndPhase"); + + // Fusion and terastallized + expect(fusionedMon.isFusion()).toBe(true); + expect(fusionedMon.isTerastallized()).toBe(true); + // Move effects should be applied + expect(fusionedMon.getMoveType).toHaveReturnedWith(Type.STELLAR); + expect(game.scene.getEnemyField().every(pokemon => pokemon.isFullHp())).toBe(false); + }); +}); diff --git a/src/test/moves/thousand_arrows.test.ts b/src/test/moves/thousand_arrows.test.ts index 8d1d6ee5f4a..976b4352ee4 100644 --- a/src/test/moves/thousand_arrows.test.ts +++ b/src/test/moves/thousand_arrows.test.ts @@ -8,7 +8,6 @@ import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Moves - Thousand Arrows", () => { let phaserGame: Phaser.Game; @@ -30,14 +29,14 @@ describe("Moves - Thousand Arrows", () => { game.override.enemySpecies(Species.TOGETIC); game.override.startingLevel(100); game.override.enemyLevel(100); - game.override.moveset([Moves.THOUSAND_ARROWS]); - game.override.enemyMoveset([Moves.SPLASH, Moves.SPLASH, Moves.SPLASH, Moves.SPLASH]); + game.override.moveset([ Moves.THOUSAND_ARROWS ]); + game.override.enemyMoveset([ Moves.SPLASH, Moves.SPLASH, Moves.SPLASH, Moves.SPLASH ]); }); it( "move should hit and ground Flying-type targets", async () => { - await game.startBattle([Species.ILLUMISE]); + await game.startBattle([ Species.ILLUMISE ]); const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -51,7 +50,7 @@ describe("Moves - Thousand Arrows", () => { expect(enemyPokemon.getTag(BattlerTagType.IGNORE_FLYING)).toBeDefined(); expect(enemyPokemon.hp).toBeLessThan(enemyPokemon.getMaxHp()); - }, TIMEOUT + } ); it( @@ -60,7 +59,7 @@ describe("Moves - Thousand Arrows", () => { game.override.enemySpecies(Species.SNORLAX); game.override.enemyAbility(Abilities.LEVITATE); - await game.startBattle([Species.ILLUMISE]); + await game.startBattle([ Species.ILLUMISE ]); const enemyPokemon = game.scene.getEnemyPokemon()!; @@ -74,7 +73,7 @@ describe("Moves - Thousand Arrows", () => { expect(enemyPokemon.getTag(BattlerTagType.IGNORE_FLYING)).toBeDefined(); expect(enemyPokemon.hp).toBeLessThan(enemyPokemon.getMaxHp()); - }, TIMEOUT + } ); it( @@ -82,17 +81,17 @@ describe("Moves - Thousand Arrows", () => { async () => { game.override.enemySpecies(Species.SNORLAX); - await game.startBattle([Species.ILLUMISE]); + await game.startBattle([ Species.ILLUMISE ]); const enemyPokemon = game.scene.getEnemyPokemon()!; - enemyPokemon.addTag(BattlerTagType.MAGNET_RISEN, undefined, Moves.MAGNET_RISE); + enemyPokemon.addTag(BattlerTagType.FLOATING, undefined, Moves.MAGNET_RISE); game.move.select(Moves.THOUSAND_ARROWS); await game.phaseInterceptor.to(BerryPhase, false); - expect(enemyPokemon.getTag(BattlerTagType.MAGNET_RISEN)).toBeUndefined(); + expect(enemyPokemon.getTag(BattlerTagType.FLOATING)).toBeUndefined(); expect(enemyPokemon.getTag(BattlerTagType.IGNORE_FLYING)).toBeDefined(); expect(enemyPokemon.hp).toBeLessThan(enemyPokemon.getMaxHp()); } diff --git a/src/test/moves/throat_chop.test.ts b/src/test/moves/throat_chop.test.ts index cb34b4bafff..24293f8d086 100644 --- a/src/test/moves/throat_chop.test.ts +++ b/src/test/moves/throat_chop.test.ts @@ -10,8 +10,6 @@ import { afterEach, beforeAll, beforeEach, describe, it, expect } from "vitest"; describe("Moves - Throat Chop", () => { let phaserGame: Phaser.Game; let game: GameManager; - const TIMEOUT = 20 * 1000; - beforeAll(() => { phaserGame = new Phaser.Game({ type: Phaser.HEADLESS, @@ -34,12 +32,12 @@ describe("Moves - Throat Chop", () => { }); it("prevents the target from using sound-based moves for two turns", async () => { - await game.classicMode.startBattle([Species.MAGIKARP]); + await game.classicMode.startBattle([ Species.MAGIKARP ]); const enemy = game.scene.getEnemyPokemon()!; game.move.select(Moves.GROWL); - await game.setTurnOrder([BattlerIndex.ENEMY, BattlerIndex.PLAYER]); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); // First turn, move is interrupted await game.phaseInterceptor.to("TurnEndPhase"); @@ -49,9 +47,9 @@ describe("Moves - Throat Chop", () => { await game.toNextTurn(); game.move.select(Moves.GROWL); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); await game.phaseInterceptor.to("MoveEndPhase"); expect(enemy.isFullHp()).toBe(false); - }, TIMEOUT); + }); }); diff --git a/src/test/moves/thunder_wave.test.ts b/src/test/moves/thunder_wave.test.ts index 7ad59518013..5551451e59b 100644 --- a/src/test/moves/thunder_wave.test.ts +++ b/src/test/moves/thunder_wave.test.ts @@ -1,13 +1,12 @@ -import { StatusEffect } from "#app/data/status-effect"; -import { Abilities } from "#app/enums/abilities"; import { EnemyPokemon } from "#app/field/pokemon"; +import { Abilities } from "#enums/abilities"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; +import { StatusEffect } from "#enums/status-effect"; import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; -const TIMEOUT = 20 * 1000; describe("Moves - Thunder Wave", () => { let phaserGame: Phaser.Game; @@ -28,7 +27,7 @@ describe("Moves - Thunder Wave", () => { game.override .battleType("single") .starterSpecies(Species.PIKACHU) - .moveset([Moves.THUNDER_WAVE]) + .moveset([ Moves.THUNDER_WAVE ]) .enemyMoveset(Moves.SPLASH); }); @@ -45,7 +44,7 @@ describe("Moves - Thunder Wave", () => { await game.phaseInterceptor.to("BerryPhase", false); expect(enemyPokemon.status?.effect).toBe(StatusEffect.PARALYSIS); - }, TIMEOUT); + }); it("does not paralyze if the Pokemon is a Ground-type", async () => { game.override.enemySpecies(Species.DIGLETT); @@ -58,7 +57,7 @@ describe("Moves - Thunder Wave", () => { await game.phaseInterceptor.to("BerryPhase", false); expect(enemyPokemon.status).toBeUndefined(); - }, TIMEOUT); + }); it("does not paralyze if the Pokemon already has a status effect", async () => { game.override.enemySpecies(Species.MAGIKARP).enemyStatusEffect(StatusEffect.BURN); @@ -71,7 +70,7 @@ describe("Moves - Thunder Wave", () => { await game.phaseInterceptor.to("BerryPhase", false); expect(enemyPokemon.status?.effect).not.toBe(StatusEffect.PARALYSIS); - }, TIMEOUT); + }); it("affects Ground types if the user has Normalize", async () => { game.override.ability(Abilities.NORMALIZE).enemySpecies(Species.DIGLETT); @@ -84,7 +83,7 @@ describe("Moves - Thunder Wave", () => { await game.phaseInterceptor.to("BerryPhase", false); expect(enemyPokemon.status?.effect).toBe(StatusEffect.PARALYSIS); - }, TIMEOUT); + }); it("does not affect Ghost types if the user has Normalize", async () => { game.override.ability(Abilities.NORMALIZE).enemySpecies(Species.HAUNTER); @@ -97,5 +96,5 @@ describe("Moves - Thunder Wave", () => { await game.phaseInterceptor.to("BerryPhase", false); expect(enemyPokemon.status).toBeUndefined(); - }, TIMEOUT); + }); }); diff --git a/src/test/moves/tidy_up.test.ts b/src/test/moves/tidy_up.test.ts index 8a3a0f3be76..255967b40ac 100644 --- a/src/test/moves/tidy_up.test.ts +++ b/src/test/moves/tidy_up.test.ts @@ -33,13 +33,13 @@ describe("Moves - Tidy Up", () => { game.override.enemyMoveset(Moves.SPLASH); game.override.starterSpecies(Species.FEEBAS); game.override.ability(Abilities.BALL_FETCH); - game.override.moveset([Moves.TIDY_UP]); + game.override.moveset([ Moves.TIDY_UP ]); game.override.startingLevel(50); }); it("spikes are cleared", async () => { - game.override.moveset([Moves.SPIKES, Moves.TIDY_UP]); - game.override.enemyMoveset([Moves.SPIKES, Moves.SPIKES, Moves.SPIKES, Moves.SPIKES]); + game.override.moveset([ Moves.SPIKES, Moves.TIDY_UP ]); + game.override.enemyMoveset([ Moves.SPIKES, Moves.SPIKES, Moves.SPIKES, Moves.SPIKES ]); await game.classicMode.startBattle(); game.move.select(Moves.SPIKES); @@ -51,8 +51,8 @@ describe("Moves - Tidy Up", () => { }, 20000); it("stealth rocks are cleared", async () => { - game.override.moveset([Moves.STEALTH_ROCK, Moves.TIDY_UP]); - game.override.enemyMoveset([Moves.STEALTH_ROCK, Moves.STEALTH_ROCK, Moves.STEALTH_ROCK, Moves.STEALTH_ROCK]); + game.override.moveset([ Moves.STEALTH_ROCK, Moves.TIDY_UP ]); + game.override.enemyMoveset([ Moves.STEALTH_ROCK, Moves.STEALTH_ROCK, Moves.STEALTH_ROCK, Moves.STEALTH_ROCK ]); await game.classicMode.startBattle(); game.move.select(Moves.STEALTH_ROCK); @@ -63,8 +63,8 @@ describe("Moves - Tidy Up", () => { }, 20000); it("toxic spikes are cleared", async () => { - game.override.moveset([Moves.TOXIC_SPIKES, Moves.TIDY_UP]); - game.override.enemyMoveset([Moves.TOXIC_SPIKES, Moves.TOXIC_SPIKES, Moves.TOXIC_SPIKES, Moves.TOXIC_SPIKES]); + game.override.moveset([ Moves.TOXIC_SPIKES, Moves.TIDY_UP ]); + game.override.enemyMoveset([ Moves.TOXIC_SPIKES, Moves.TOXIC_SPIKES, Moves.TOXIC_SPIKES, Moves.TOXIC_SPIKES ]); await game.classicMode.startBattle(); game.move.select(Moves.TOXIC_SPIKES); @@ -75,8 +75,8 @@ describe("Moves - Tidy Up", () => { }, 20000); it("sticky webs are cleared", async () => { - game.override.moveset([Moves.STICKY_WEB, Moves.TIDY_UP]); - game.override.enemyMoveset([Moves.STICKY_WEB, Moves.STICKY_WEB, Moves.STICKY_WEB, Moves.STICKY_WEB]); + game.override.moveset([ Moves.STICKY_WEB, Moves.TIDY_UP ]); + game.override.enemyMoveset([ Moves.STICKY_WEB, Moves.STICKY_WEB, Moves.STICKY_WEB, Moves.STICKY_WEB ]); await game.classicMode.startBattle(); @@ -88,8 +88,8 @@ describe("Moves - Tidy Up", () => { }, 20000); it("substitutes are cleared", async () => { - game.override.moveset([Moves.SUBSTITUTE, Moves.TIDY_UP]); - game.override.enemyMoveset([Moves.SUBSTITUTE, Moves.SUBSTITUTE, Moves.SUBSTITUTE, Moves.SUBSTITUTE]); + game.override.moveset([ Moves.SUBSTITUTE, Moves.TIDY_UP ]); + game.override.enemyMoveset([ Moves.SUBSTITUTE, Moves.SUBSTITUTE, Moves.SUBSTITUTE, Moves.SUBSTITUTE ]); await game.classicMode.startBattle(); diff --git a/src/test/moves/torment.test.ts b/src/test/moves/torment.test.ts new file mode 100644 index 00000000000..b4c9a059db1 --- /dev/null +++ b/src/test/moves/torment.test.ts @@ -0,0 +1,64 @@ +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import { Abilities } from "#enums/abilities"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; +import { MoveResult } from "#app/field/pokemon"; +import { BattlerTagType } from "#enums/battler-tag-type"; +import { TurnEndPhase } from "#app/phases/turn-end-phase"; + +describe("Moves - Torment", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .battleType("single") + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset([ Moves.TORMENT, Moves.SPLASH ]) + .enemySpecies(Species.SHUCKLE) + .enemyLevel(30) + .moveset([ Moves.TACKLE ]) + .ability(Abilities.BALL_FETCH); + }); + + it("Pokemon should not be able to use the same move consecutively", async () => { + await game.classicMode.startBattle([ Species.CHANSEY ]); + + const playerPokemon = game.scene.getPlayerPokemon()!; + + // First turn, Player Pokemon uses Tackle successfully + game.move.select(Moves.TACKLE); + await game.forceEnemyMove(Moves.TORMENT); + await game.toNextTurn(); + const move1 = playerPokemon.getLastXMoves(1)[0]!; + expect(move1.move).toBe(Moves.TACKLE); + expect(move1.result).toBe(MoveResult.SUCCESS); + expect(playerPokemon?.getTag(BattlerTagType.TORMENT)).toBeDefined(); + + // Second turn, Torment forces Struggle to occur + game.move.select(Moves.TACKLE); + await game.forceEnemyMove(Moves.SPLASH); + await game.toNextTurn(); + const move2 = playerPokemon.getLastXMoves(1)[0]!; + expect(move2.move).toBe(Moves.STRUGGLE); + + // Third turn, Tackle can be used. + game.move.select(Moves.TACKLE); + await game.forceEnemyMove(Moves.SPLASH); + await game.phaseInterceptor.to(TurnEndPhase); + const move3 = playerPokemon.getLastXMoves(1)[0]!; + expect(move3.move).toBe(Moves.TACKLE); + }); +}); diff --git a/src/test/moves/toxic.test.ts b/src/test/moves/toxic.test.ts new file mode 100644 index 00000000000..b146134ae51 --- /dev/null +++ b/src/test/moves/toxic.test.ts @@ -0,0 +1,89 @@ +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; +import { StatusEffect } from "#enums/status-effect"; +import { BattlerIndex } from "#app/battle"; +import { allMoves } from "#app/data/move"; + +describe("Moves - Toxic", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .battleType("single") + .moveset(Moves.TOXIC) + .enemySpecies(Species.MAGIKARP) + .enemyMoveset(Moves.SPLASH); + }); + + it("should be guaranteed to hit if user is Poison-type", async () => { + vi.spyOn(allMoves[Moves.TOXIC], "accuracy", "get").mockReturnValue(0); + await game.classicMode.startBattle([ Species.TOXAPEX ]); + + game.move.select(Moves.TOXIC); + await game.phaseInterceptor.to("BerryPhase", false); + + expect(game.scene.getEnemyPokemon()!.status?.effect).toBe(StatusEffect.TOXIC); + }); + + it("may miss if user is not Poison-type", async () => { + vi.spyOn(allMoves[Moves.TOXIC], "accuracy", "get").mockReturnValue(0); + await game.classicMode.startBattle([ Species.UMBREON ]); + + game.move.select(Moves.TOXIC); + await game.phaseInterceptor.to("BerryPhase", false); + + expect(game.scene.getEnemyPokemon()!.status).toBeUndefined(); + }); + + it("should hit semi-invulnerable targets if user is Poison-type", async () => { + vi.spyOn(allMoves[Moves.TOXIC], "accuracy", "get").mockReturnValue(0); + game.override.enemyMoveset(Moves.FLY); + await game.classicMode.startBattle([ Species.TOXAPEX ]); + + game.move.select(Moves.TOXIC); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); + await game.phaseInterceptor.to("BerryPhase", false); + + expect(game.scene.getEnemyPokemon()!.status?.effect).toBe(StatusEffect.TOXIC); + }); + + it("should miss semi-invulnerable targets if user is not Poison-type", async () => { + vi.spyOn(allMoves[Moves.TOXIC], "accuracy", "get").mockReturnValue(-1); + game.override.enemyMoveset(Moves.FLY); + await game.classicMode.startBattle([ Species.UMBREON ]); + + game.move.select(Moves.TOXIC); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); + await game.phaseInterceptor.to("BerryPhase", false); + + expect(game.scene.getEnemyPokemon()!.status).toBeUndefined(); + }); + + it("moves other than Toxic should not hit semi-invulnerable targets even if user is Poison-type", async () => { + game.override.moveset(Moves.SWIFT); + game.override.enemyMoveset(Moves.FLY); + await game.classicMode.startBattle([ Species.TOXAPEX ]); + + game.move.select(Moves.SWIFT); + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); + await game.phaseInterceptor.to("BerryPhase", false); + + const enemyPokemon = game.scene.getEnemyPokemon()!; + expect(enemyPokemon.hp).toBe(enemyPokemon.getMaxHp()); + }); +}); diff --git a/src/test/moves/toxic_spikes.test.ts b/src/test/moves/toxic_spikes.test.ts new file mode 100644 index 00000000000..bdd59ed0ac8 --- /dev/null +++ b/src/test/moves/toxic_spikes.test.ts @@ -0,0 +1,139 @@ +import { ArenaTagSide, ArenaTrapTag } from "#app/data/arena-tag"; +import { decrypt, encrypt, GameData, SessionSaveData } from "#app/system/game-data"; +import { Abilities } from "#enums/abilities"; +import { ArenaTagType } from "#enums/arena-tag-type"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import { StatusEffect } from "#enums/status-effect"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; + +describe("Moves - Toxic Spikes", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .battleType("single") + .startingWave(5) + .enemySpecies(Species.RATTATA) + .enemyAbility(Abilities.BALL_FETCH) + .ability(Abilities.BALL_FETCH) + .enemyMoveset(Moves.SPLASH) + .moveset([ Moves.TOXIC_SPIKES, Moves.SPLASH, Moves.ROAR, Moves.COURT_CHANGE ]); + }); + + it("should not affect the opponent if they do not switch", async () => { + await game.classicMode.runToSummon([ Species.MIGHTYENA, Species.POOCHYENA ]); + + const enemy = game.scene.getEnemyField()[0]; + + game.move.select(Moves.TOXIC_SPIKES); + await game.phaseInterceptor.to("TurnEndPhase"); + game.move.select(Moves.SPLASH); + await game.phaseInterceptor.to("TurnEndPhase"); + game.doSwitchPokemon(1); + await game.phaseInterceptor.to("TurnEndPhase"); + + expect(enemy.hp).toBe(enemy.getMaxHp()); + expect(enemy.status?.effect).toBeUndefined(); + }); + + it("should poison the opponent if they switch into 1 layer", async () => { + await game.classicMode.runToSummon([ Species.MIGHTYENA ]); + + game.move.select(Moves.TOXIC_SPIKES); + await game.phaseInterceptor.to("TurnEndPhase"); + game.move.select(Moves.ROAR); + await game.phaseInterceptor.to("TurnEndPhase"); + + const enemy = game.scene.getEnemyField()[0]; + + expect(enemy.hp).toBeLessThan(enemy.getMaxHp()); + expect(enemy.status?.effect).toBe(StatusEffect.POISON); + }); + + it("should badly poison the opponent if they switch into 2 layers", async () => { + await game.classicMode.runToSummon([ Species.MIGHTYENA ]); + + game.move.select(Moves.TOXIC_SPIKES); + await game.phaseInterceptor.to("TurnEndPhase"); + game.move.select(Moves.TOXIC_SPIKES); + await game.phaseInterceptor.to("TurnEndPhase"); + game.move.select(Moves.ROAR); + await game.phaseInterceptor.to("TurnEndPhase"); + + const enemy = game.scene.getEnemyField()[0]; + expect(enemy.hp).toBeLessThan(enemy.getMaxHp()); + expect(enemy.status?.effect).toBe(StatusEffect.TOXIC); + }); + + it("should be removed if a grounded poison pokemon switches in", async () => { + await game.classicMode.runToSummon([ Species.MUK, Species.PIDGEY ]); + + const muk = game.scene.getPlayerPokemon()!; + + game.move.select(Moves.TOXIC_SPIKES); + await game.toNextTurn(); + // also make sure the toxic spikes are removed even if the pokemon + // that set them up is the one switching in (https://github.com/pagefaultgames/pokerogue/issues/935) + game.move.select(Moves.COURT_CHANGE); + await game.toNextTurn(); + game.doSwitchPokemon(1); + await game.toNextTurn(); + game.doSwitchPokemon(1); + await game.toNextTurn(); + game.move.select(Moves.SPLASH); + await game.toNextTurn(); + + expect(muk.isFullHp()).toBe(true); + expect(muk.status?.effect).toBeUndefined(); + expect(game.scene.arena.tags.length).toBe(0); + }); + + it("shouldn't create multiple layers per use in doubles", async () => { + await game.classicMode.runToSummon([ Species.MIGHTYENA, Species.POOCHYENA ]); + + game.move.select(Moves.TOXIC_SPIKES); + await game.phaseInterceptor.to("TurnEndPhase"); + + const arenaTags = (game.scene.arena.getTagOnSide(ArenaTagType.TOXIC_SPIKES, ArenaTagSide.ENEMY) as ArenaTrapTag); + expect(arenaTags.tagType).toBe(ArenaTagType.TOXIC_SPIKES); + expect(arenaTags.layers).toBe(1); + }); + + it("should persist through reload", async () => { + game.override.startingWave(1); + const scene = game.scene; + const gameData = new GameData(scene); + + await game.classicMode.runToSummon([ Species.MIGHTYENA ]); + + game.move.select(Moves.TOXIC_SPIKES); + await game.phaseInterceptor.to("TurnEndPhase"); + game.move.select(Moves.SPLASH); + await game.doKillOpponents(); + await game.phaseInterceptor.to("BattleEndPhase"); + await game.toNextWave(); + + const sessionData : SessionSaveData = gameData["getSessionSaveData"](game.scene); + localStorage.setItem("sessionTestData", encrypt(JSON.stringify(sessionData), true)); + const recoveredData : SessionSaveData = gameData.parseSessionData(decrypt(localStorage.getItem("sessionTestData")!, true)); + gameData.loadSession(game.scene, 0, recoveredData); + + expect(sessionData.arena.tags).toEqual(recoveredData.arena.tags); + localStorage.removeItem("sessionTestData"); + }); +}); diff --git a/src/test/moves/transform.test.ts b/src/test/moves/transform.test.ts index 6686f1fc73b..adb97b42af7 100644 --- a/src/test/moves/transform.test.ts +++ b/src/test/moves/transform.test.ts @@ -36,9 +36,7 @@ describe("Moves - Transform", () => { }); it("should copy species, ability, gender, all stats except HP, all stat stages, moveset, and types of target", async () => { - await game.startBattle([ - Species.DITTO - ]); + await game.classicMode.startBattle([ Species.DITTO ]); game.move.select(Moves.TRANSFORM); await game.phaseInterceptor.to(TurnEndPhase); @@ -62,25 +60,24 @@ describe("Moves - Transform", () => { const playerMoveset = player.getMoveset(); const enemyMoveset = player.getMoveset(); + expect(playerMoveset.length).toBe(enemyMoveset.length); for (let i = 0; i < playerMoveset.length && i < enemyMoveset.length; i++) { - // TODO: Checks for 5 PP should be done here when that gets addressed expect(playerMoveset[i]?.moveId).toBe(enemyMoveset[i]?.moveId); } const playerTypes = player.getTypes(); const enemyTypes = enemy.getTypes(); + expect(playerTypes.length).toBe(enemyTypes.length); for (let i = 0; i < playerTypes.length && i < enemyTypes.length; i++) { expect(playerTypes[i]).toBe(enemyTypes[i]); } - }, 20000); + }); it("should copy in-battle overridden stats", async () => { - game.override.enemyMoveset([Moves.POWER_SPLIT]); + game.override.enemyMoveset([ Moves.POWER_SPLIT ]); - await game.startBattle([ - Species.DITTO - ]); + await game.classicMode.startBattle([ Species.DITTO ]); const player = game.scene.getPlayerPokemon()!; const enemy = game.scene.getEnemyPokemon()!; @@ -97,4 +94,26 @@ describe("Moves - Transform", () => { expect(player.getStat(Stat.SPATK, false)).toBe(avgSpAtk); expect(enemy.getStat(Stat.SPATK, false)).toBe(avgSpAtk); }); + + it("should set each move's pp to a maximum of 5", async () => { + game.override.enemyMoveset([ Moves.SWORDS_DANCE, Moves.GROWL, Moves.SKETCH, Moves.RECOVER ]); + + await game.classicMode.startBattle([ Species.DITTO ]); + const player = game.scene.getPlayerPokemon()!; + + game.move.select(Moves.TRANSFORM); + await game.phaseInterceptor.to(TurnEndPhase); + + player.getMoveset().forEach(move => { + // Should set correct maximum PP without touching `ppUp` + if (move) { + if (move.moveId === Moves.SKETCH) { + expect(move.getMovePp()).toBe(1); + } else { + expect(move.getMovePp()).toBe(5); + } + expect(move.ppUp).toBe(0); + } + }); + }); }); diff --git a/src/test/moves/trick_or_treat.test.ts b/src/test/moves/trick_or_treat.test.ts new file mode 100644 index 00000000000..5c85cac05e2 --- /dev/null +++ b/src/test/moves/trick_or_treat.test.ts @@ -0,0 +1,47 @@ +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import { Type } from "#enums/type"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; + +describe("Moves - Trick Or Treat", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.FORESTS_CURSE, Moves.TRICK_OR_TREAT ]) + .ability(Abilities.BALL_FETCH) + .battleType("single") + .disableCrits() + .enemySpecies(Species.MAGIKARP) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.SPLASH); + }); + + it("will replace added type from Forest's Curse", async () => { + await game.classicMode.startBattle([ Species.FEEBAS ]); + + const enemyPokemon = game.scene.getEnemyPokemon(); + game.move.select(Moves.FORESTS_CURSE); + await game.phaseInterceptor.to("TurnEndPhase"); + expect(enemyPokemon!.summonData.addedType).toBe(Type.GRASS); + + game.move.select(Moves.TRICK_OR_TREAT); + await game.phaseInterceptor.to("TurnEndPhase"); + expect(enemyPokemon?.summonData.addedType).toBe(Type.GHOST); + }); +}); diff --git a/src/test/moves/triple_arrows.test.ts b/src/test/moves/triple_arrows.test.ts new file mode 100644 index 00000000000..98ad29997df --- /dev/null +++ b/src/test/moves/triple_arrows.test.ts @@ -0,0 +1,60 @@ +import { allMoves, FlinchAttr, StatStageChangeAttr } from "#app/data/move"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; + +describe("Moves - Triple Arrows", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + const tripleArrows = allMoves[Moves.TRIPLE_ARROWS]; + const flinchAttr = tripleArrows.getAttrs(FlinchAttr)[0]; + const defDropAttr = tripleArrows.getAttrs(StatStageChangeAttr)[0]; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .ability(Abilities.BALL_FETCH) + .moveset([ Moves.TRIPLE_ARROWS ]) + .battleType("single") + .enemySpecies(Species.MAGIKARP) + .enemyAbility(Abilities.STURDY) + .enemyMoveset(Moves.SPLASH); + + vi.spyOn(flinchAttr, "getMoveChance"); + vi.spyOn(defDropAttr, "getMoveChance"); + }); + + it("has a 30% flinch chance and 50% defense drop chance", async () => { + await game.classicMode.startBattle([ Species.FEEBAS ]); + + game.move.select(Moves.TRIPLE_ARROWS); + await game.phaseInterceptor.to("BerryPhase"); + + expect(flinchAttr.getMoveChance).toHaveReturnedWith(30); + expect(defDropAttr.getMoveChance).toHaveReturnedWith(50); + }); + + it("is affected normally by Serene Grace", async () => { + game.override.ability(Abilities.SERENE_GRACE); + await game.classicMode.startBattle([ Species.FEEBAS ]); + + game.move.select(Moves.TRIPLE_ARROWS); + await game.phaseInterceptor.to("BerryPhase"); + + expect(flinchAttr.getMoveChance).toHaveReturnedWith(60); + expect(defDropAttr.getMoveChance).toHaveReturnedWith(100); + }); +}); diff --git a/src/test/moves/u_turn.test.ts b/src/test/moves/u_turn.test.ts index c4b6ae2497f..c6e255e01b2 100644 --- a/src/test/moves/u_turn.test.ts +++ b/src/test/moves/u_turn.test.ts @@ -1,10 +1,8 @@ -import { Abilities } from "#app/enums/abilities"; -import { StatusEffect } from "#app/enums/status-effect"; -import { SwitchPhase } from "#app/phases/switch-phase"; -import { TurnEndPhase } from "#app/phases/turn-end-phase"; -import GameManager from "#app/test/utils/gameManager"; +import { Abilities } from "#enums/abilities"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; +import { StatusEffect } from "#enums/status-effect"; +import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; @@ -29,7 +27,7 @@ describe("Moves - U-turn", () => { .enemySpecies(Species.GENGAR) .startingLevel(90) .startingWave(97) - .moveset([Moves.U_TURN]) + .moveset([ Moves.U_TURN ]) .enemyMoveset(Moves.SPLASH) .disableCrits(); }); @@ -38,19 +36,16 @@ describe("Moves - U-turn", () => { // arrange const playerHp = 1; game.override.ability(Abilities.REGENERATOR); - await game.startBattle([ - Species.RAICHU, - Species.SHUCKLE - ]); + await game.classicMode.startBattle([ Species.RAICHU, Species.SHUCKLE ]); game.scene.getPlayerPokemon()!.hp = playerHp; // act game.move.select(Moves.U_TURN); game.doSelectPartyPokemon(1); - await game.phaseInterceptor.to(TurnEndPhase); + await game.phaseInterceptor.to("TurnEndPhase"); // assert - expect(game.scene.getParty()[1].hp).toEqual(Math.floor(game.scene.getParty()[1].getMaxHp() * 0.33 + playerHp)); + expect(game.scene.getPlayerParty()[1].hp).toEqual(Math.floor(game.scene.getPlayerParty()[1].getMaxHp() * 0.33 + playerHp)); expect(game.phaseInterceptor.log).toContain("SwitchSummonPhase"); expect(game.scene.getPlayerPokemon()!.species.speciesId).toBe(Species.SHUCKLE); }, 20000); @@ -58,15 +53,12 @@ describe("Moves - U-turn", () => { it("triggers rough skin on the u-turn user before a new pokemon is switched in", async () => { // arrange game.override.enemyAbility(Abilities.ROUGH_SKIN); - await game.startBattle([ - Species.RAICHU, - Species.SHUCKLE - ]); + await game.classicMode.startBattle([ Species.RAICHU, Species.SHUCKLE ]); // act game.move.select(Moves.U_TURN); game.doSelectPartyPokemon(1); - await game.phaseInterceptor.to(SwitchPhase, false); + await game.phaseInterceptor.to("SwitchPhase", false); // assert const playerPkm = game.scene.getPlayerPokemon()!; @@ -79,15 +71,12 @@ describe("Moves - U-turn", () => { it("triggers contact abilities on the u-turn user (eg poison point) before a new pokemon is switched in", async () => { // arrange game.override.enemyAbility(Abilities.POISON_POINT); - await game.startBattle([ - Species.RAICHU, - Species.SHUCKLE - ]); + await game.classicMode.startBattle([ Species.RAICHU, Species.SHUCKLE ]); vi.spyOn(game.scene.getEnemyPokemon()!, "randSeedInt").mockReturnValue(0); // act game.move.select(Moves.U_TURN); - await game.phaseInterceptor.to(SwitchPhase, false); + await game.phaseInterceptor.to("SwitchPhase", false); // assert const playerPkm = game.scene.getPlayerPokemon()!; @@ -96,4 +85,23 @@ describe("Moves - U-turn", () => { expect(game.scene.getEnemyPokemon()!.battleData.abilityRevealed).toBe(true); // proxy for asserting ability activated expect(game.phaseInterceptor.log).not.toContain("SwitchSummonPhase"); }, 20000); + + it("still forces a switch if u-turn KO's the opponent", async () => { + game.override.startingLevel(1000); // Ensure that U-Turn KO's the opponent + await game.classicMode.startBattle([ + Species.RAICHU, + Species.SHUCKLE + ]); + const enemy = game.scene.getEnemyPokemon()!; + + // KO the opponent with U-Turn + game.move.select(Moves.U_TURN); + game.doSelectPartyPokemon(1); + await game.phaseInterceptor.to("TurnEndPhase"); + expect(enemy.isFainted()).toBe(true); + + // Check that U-Turn forced a switch + expect(game.phaseInterceptor.log).toContain("SwitchSummonPhase"); + expect(game.scene.getPlayerPokemon()!.species.speciesId).toBe(Species.SHUCKLE); + }); }); diff --git a/src/test/moves/upper_hand.test.ts b/src/test/moves/upper_hand.test.ts new file mode 100644 index 00000000000..f94197d3fbd --- /dev/null +++ b/src/test/moves/upper_hand.test.ts @@ -0,0 +1,103 @@ +import { BattlerIndex } from "#app/battle"; +import { MoveResult } from "#app/field/pokemon"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; + +describe("Moves - Upper Hand", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset(Moves.UPPER_HAND) + .ability(Abilities.BALL_FETCH) + .battleType("single") + .disableCrits() + .enemySpecies(Species.MAGIKARP) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.QUICK_ATTACK) + .startingLevel(100) + .enemyLevel(100); + }); + + it("should flinch the opponent before they use a priority attack", async () => { + await game.classicMode.startBattle([ Species.FEEBAS ]); + + const feebas = game.scene.getPlayerPokemon()!; + const magikarp = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.UPPER_HAND); + await game.phaseInterceptor.to("BerryPhase"); + + expect(feebas.getLastXMoves()[0].result).toBe(MoveResult.SUCCESS); + expect(magikarp.isFullHp()).toBeFalsy(); + expect(feebas.isFullHp()).toBeTruthy(); + }); + + it.each([ + { descriptor: "non-priority attack", move: Moves.TACKLE }, + { descriptor: "status move", move: Moves.BABY_DOLL_EYES } + ])("should fail when the opponent selects a $descriptor", async ({ move }) => { + game.override.enemyMoveset(move); + + await game.classicMode.startBattle([ Species.FEEBAS ]); + + const feebas = game.scene.getPlayerPokemon()!; + + game.move.select(Moves.UPPER_HAND); + await game.phaseInterceptor.to("BerryPhase"); + + expect(feebas.getLastXMoves()[0].result).toBe(MoveResult.FAIL); + }); + + it("should flinch the opponent before they use an attack boosted by Gale Wings", async () => { + game.override + .enemyAbility(Abilities.GALE_WINGS) + .enemyMoveset(Moves.GUST); + + await game.classicMode.startBattle([ Species.FEEBAS ]); + + const feebas = game.scene.getPlayerPokemon()!; + const magikarp = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.UPPER_HAND); + await game.phaseInterceptor.to("BerryPhase"); + + expect(feebas.getLastXMoves()[0].result).toBe(MoveResult.SUCCESS); + expect(magikarp.isFullHp()).toBeFalsy(); + expect(feebas.isFullHp()).toBeTruthy(); + }); + + it("should fail if the target has already moved", async () => { + game.override + .enemyMoveset(Moves.FAKE_OUT) + .enemyAbility(Abilities.SHEER_FORCE); + + await game.classicMode.startBattle([ Species.FEEBAS ]); + + const feebas = game.scene.getPlayerPokemon()!; + + game.move.select(Moves.UPPER_HAND); + + await game.setTurnOrder([ BattlerIndex.ENEMY, BattlerIndex.PLAYER ]); + await game.phaseInterceptor.to("BerryPhase"); + + expect(feebas.getLastXMoves()[0].result).toBe(MoveResult.FAIL); + expect(feebas.isFullHp()).toBeFalsy(); + }); +}); diff --git a/src/test/moves/whirlwind.test.ts b/src/test/moves/whirlwind.test.ts index a591a3cd6c5..c16f38111f2 100644 --- a/src/test/moves/whirlwind.test.ts +++ b/src/test/moves/whirlwind.test.ts @@ -1,12 +1,11 @@ -import { BattlerIndex } from "#app/battle"; -import { allMoves } from "#app/data/move"; import { BattlerTagType } from "#app/enums/battler-tag-type"; +import { MoveResult } from "#app/field/pokemon"; import { Abilities } from "#enums/abilities"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; -import { afterEach, beforeAll, beforeEach, describe, it, expect, vi } from "vitest"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; describe("Moves - Whirlwind", () => { let phaserGame: Phaser.Game; @@ -36,18 +35,16 @@ describe("Moves - Whirlwind", () => { { move: Moves.BOUNCE, name: "Bounce" }, { move: Moves.SKY_DROP, name: "Sky Drop" }, ])("should not hit a flying target: $name (=$move)", async ({ move }) => { - game.override.moveset([move]); - await game.classicMode.startBattle([Species.STARAPTOR]); + game.override.moveset([ move ]); + await game.classicMode.startBattle([ Species.STARAPTOR ]); const staraptor = game.scene.getPlayerPokemon()!; - const whirlwind = allMoves[Moves.WHIRLWIND]; - vi.spyOn(whirlwind, "getFailedText"); game.move.select(move); - await game.setTurnOrder([BattlerIndex.PLAYER, BattlerIndex.ENEMY]); - await game.toNextTurn(); + + await game.phaseInterceptor.to("BerryPhase", false); expect(staraptor.findTag((t) => t.tagType === BattlerTagType.FLYING)).toBeDefined(); - expect(whirlwind.getFailedText).toHaveBeenCalledOnce(); + expect(game.scene.getEnemyPokemon()!.getLastXMoves(1)[0].result).toBe(MoveResult.MISS); }); }); diff --git a/src/test/moves/wide_guard.test.ts b/src/test/moves/wide_guard.test.ts index b4e6e305539..c25a700c981 100644 --- a/src/test/moves/wide_guard.test.ts +++ b/src/test/moves/wide_guard.test.ts @@ -8,7 +8,6 @@ import { Stat } from "#enums/stat"; import { BerryPhase } from "#app/phases/berry-phase"; import { CommandPhase } from "#app/phases/command-phase"; -const TIMEOUT = 20 * 1000; describe("Moves - Wide Guard", () => { let phaserGame: Phaser.Game; @@ -29,10 +28,10 @@ describe("Moves - Wide Guard", () => { game.override.battleType("double"); - game.override.moveset([Moves.WIDE_GUARD, Moves.SPLASH, Moves.SURF]); + game.override.moveset([ Moves.WIDE_GUARD, Moves.SPLASH, Moves.SURF ]); game.override.enemySpecies(Species.SNORLAX); - game.override.enemyMoveset([Moves.SWIFT]); + game.override.enemyMoveset([ Moves.SWIFT ]); game.override.enemyAbility(Abilities.INSOMNIA); game.override.startingLevel(100); @@ -42,7 +41,7 @@ describe("Moves - Wide Guard", () => { test( "should protect the user and allies from multi-target attack moves", async () => { - await game.startBattle([Species.CHARIZARD, Species.BLASTOISE]); + await game.startBattle([ Species.CHARIZARD, Species.BLASTOISE ]); const leadPokemon = game.scene.getPlayerField(); @@ -55,15 +54,15 @@ describe("Moves - Wide Guard", () => { await game.phaseInterceptor.to(BerryPhase, false); leadPokemon.forEach(p => expect(p.hp).toBe(p.getMaxHp())); - }, TIMEOUT + } ); test( "should protect the user and allies from multi-target status moves", async () => { - game.override.enemyMoveset([Moves.GROWL]); + game.override.enemyMoveset([ Moves.GROWL ]); - await game.startBattle([Species.CHARIZARD, Species.BLASTOISE]); + await game.startBattle([ Species.CHARIZARD, Species.BLASTOISE ]); const leadPokemon = game.scene.getPlayerField(); @@ -76,15 +75,15 @@ describe("Moves - Wide Guard", () => { await game.phaseInterceptor.to(BerryPhase, false); leadPokemon.forEach(p => expect(p.getStatStage(Stat.ATK)).toBe(0)); - }, TIMEOUT + } ); test( "should not protect the user and allies from single-target moves", async () => { - game.override.enemyMoveset([Moves.TACKLE]); + game.override.enemyMoveset([ Moves.TACKLE ]); - await game.startBattle([Species.CHARIZARD, Species.BLASTOISE]); + await game.startBattle([ Species.CHARIZARD, Species.BLASTOISE ]); const leadPokemon = game.scene.getPlayerField(); @@ -97,15 +96,15 @@ describe("Moves - Wide Guard", () => { await game.phaseInterceptor.to(BerryPhase, false); expect(leadPokemon.some(p => p.hp < p.getMaxHp())).toBeTruthy(); - }, TIMEOUT + } ); test( "should protect the user from its ally's multi-target move", async () => { - game.override.enemyMoveset([Moves.SPLASH]); + game.override.enemyMoveset([ Moves.SPLASH ]); - await game.startBattle([Species.CHARIZARD, Species.BLASTOISE]); + await game.startBattle([ Species.CHARIZARD, Species.BLASTOISE ]); const leadPokemon = game.scene.getPlayerField(); const enemyPokemon = game.scene.getEnemyField(); @@ -120,6 +119,6 @@ describe("Moves - Wide Guard", () => { expect(leadPokemon[0].hp).toBe(leadPokemon[0].getMaxHp()); enemyPokemon.forEach(p => expect(p.hp).toBeLessThan(p.getMaxHp())); - }, TIMEOUT + } ); }); diff --git a/src/test/moves/will_o_wisp.test.ts b/src/test/moves/will_o_wisp.test.ts new file mode 100644 index 00000000000..39729d331ad --- /dev/null +++ b/src/test/moves/will_o_wisp.test.ts @@ -0,0 +1,53 @@ +import { BattlerIndex } from "#app/battle"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import { StatusEffect } from "#enums/status-effect"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; + +describe("Moves - Will-O-Wisp", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.WILL_O_WISP, Moves.SPLASH ]) + .ability(Abilities.BALL_FETCH) + .battleType("single") + .disableCrits() + .enemySpecies(Species.MAGIKARP) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.SPLASH); + }); + + it("should burn the opponent", async () => { + await game.classicMode.startBattle([ Species.FEEBAS ]); + + const enemy = game.scene.getEnemyPokemon()!; + + game.move.select(Moves.WILL_O_WISP); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + await game.move.forceHit(); + await game.toNextTurn(); + + expect(enemy.status?.effect).toBe(StatusEffect.BURN); + + game.move.select(Moves.SPLASH); + await game.toNextTurn(); + + expect(enemy.status?.effect).toBe(StatusEffect.BURN); + }); +}); diff --git a/src/test/mystery-encounter/encounter-test-utils.ts b/src/test/mystery-encounter/encounter-test-utils.ts index a31ee150bfd..cd2fd2db042 100644 --- a/src/test/mystery-encounter/encounter-test-utils.ts +++ b/src/test/mystery-encounter/encounter-test-utils.ts @@ -1,18 +1,19 @@ -import { Button } from "#app/enums/buttons"; -import { MysteryEncounterBattlePhase, MysteryEncounterOptionSelectedPhase, MysteryEncounterPhase, MysteryEncounterRewardsPhase } from "#app/phases/mystery-encounter-phases"; -import MysteryEncounterUiHandler from "#app/ui/mystery-encounter-ui-handler"; -import { Mode } from "#app/ui/ui"; -import GameManager from "../utils/gameManager"; -import MessageUiHandler from "#app/ui/message-ui-handler"; -import { Status, StatusEffect } from "#app/data/status-effect"; -import { expect, vi } from "vitest"; import * as EncounterPhaseUtils from "#app/data/mystery-encounters/utils/encounter-phase-utils"; +import { Status } from "#app/data/status-effect"; +import { CommandPhase } from "#app/phases/command-phase"; +import { MessagePhase } from "#app/phases/message-phase"; +import { MysteryEncounterBattlePhase, MysteryEncounterOptionSelectedPhase, MysteryEncounterPhase, MysteryEncounterRewardsPhase } from "#app/phases/mystery-encounter-phases"; +import { VictoryPhase } from "#app/phases/victory-phase"; +import MessageUiHandler from "#app/ui/message-ui-handler"; +import MysteryEncounterUiHandler from "#app/ui/mystery-encounter-ui-handler"; import PartyUiHandler from "#app/ui/party-ui-handler"; import OptionSelectUiHandler from "#app/ui/settings/option-select-ui-handler"; +import { Mode } from "#app/ui/ui"; import { isNullOrUndefined } from "#app/utils"; -import { CommandPhase } from "#app/phases/command-phase"; -import { VictoryPhase } from "#app/phases/victory-phase"; -import { MessagePhase } from "#app/phases/message-phase"; +import { Button } from "#enums/buttons"; +import { StatusEffect } from "#enums/status-effect"; +import GameManager from "#test/utils/gameManager"; +import { expect, vi } from "vitest"; /** * Runs a {@linkcode MysteryEncounter} to either the start of a battle, or to the {@linkcode MysteryEncounterRewardsPhase}, depending on the option selected @@ -97,24 +98,24 @@ export async function runSelectMysteryEncounterOption(game: GameManager, optionN uiHandler.unblockInput(); // input are blocked by 1s to prevent accidental input. Tests need to handle that switch (optionNo) { - default: - case 1: + default: + case 1: // no movement needed. Default cursor position - break; - case 2: - uiHandler.processInput(Button.RIGHT); - break; - case 3: - uiHandler.processInput(Button.DOWN); - break; - case 4: - uiHandler.processInput(Button.RIGHT); - uiHandler.processInput(Button.DOWN); - break; + break; + case 2: + uiHandler.processInput(Button.RIGHT); + break; + case 3: + uiHandler.processInput(Button.DOWN); + break; + case 4: + uiHandler.processInput(Button.RIGHT); + uiHandler.processInput(Button.DOWN); + break; } if (!isNullOrUndefined(secondaryOptionSelect?.pokemonNo)) { - await handleSecondaryOptionSelect(game, secondaryOptionSelect!.pokemonNo, secondaryOptionSelect!.optionNo); + await handleSecondaryOptionSelect(game, secondaryOptionSelect.pokemonNo, secondaryOptionSelect.optionNo); } else { uiHandler.processInput(Button.ACTION); } diff --git a/src/test/mystery-encounter/encounters/a-trainers-test-encounter.test.ts b/src/test/mystery-encounter/encounters/a-trainers-test-encounter.test.ts index b4cc186864c..7d783958422 100644 --- a/src/test/mystery-encounter/encounters/a-trainers-test-encounter.test.ts +++ b/src/test/mystery-encounter/encounters/a-trainers-test-encounter.test.ts @@ -16,9 +16,10 @@ import { EggTier } from "#enums/egg-type"; import { CommandPhase } from "#app/phases/command-phase"; import { SelectModifierPhase } from "#app/phases/select-modifier-phase"; import { PartyHealPhase } from "#app/phases/party-heal-phase"; +import i18next from "i18next"; -const namespace = "mysteryEncounter:aTrainersTest"; -const defaultParty = [Species.LAPRAS, Species.GENGAR, Species.ABRA]; +const namespace = "mysteryEncounters/aTrainersTest"; +const defaultParty = [ Species.LAPRAS, Species.GENGAR, Species.ABRA ]; const defaultBiome = Biome.CAVE; const defaultWave = 45; @@ -40,10 +41,10 @@ describe("A Trainer's Test - Mystery Encounter", () => { game.override.disableTrainerWaves(); const biomeMap = new Map([ - [Biome.VOLCANO, [MysteryEncounterType.MYSTERIOUS_CHALLENGERS]], + [ Biome.VOLCANO, [ MysteryEncounterType.MYSTERIOUS_CHALLENGERS ]], ]); HUMAN_TRANSITABLE_BIOMES.forEach(biome => { - biomeMap.set(biome, [MysteryEncounterType.A_TRAINERS_TEST]); + biomeMap.set(biome, [ MysteryEncounterType.A_TRAINERS_TEST ]); }); vi.spyOn(MysteryEncounters, "mysteryEncountersByBiome", "get").mockReturnValue(biomeMap); }); @@ -63,28 +64,12 @@ describe("A Trainer's Test - Mystery Encounter", () => { expect(ATrainersTestEncounter.dialogue.intro).toBeDefined(); expect(ATrainersTestEncounter.dialogue.intro?.[0].speaker).toBeDefined(); expect(ATrainersTestEncounter.dialogue.intro?.[0].text).toBeDefined(); - expect(ATrainersTestEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}.title`); - expect(ATrainersTestEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}.description`); - expect(ATrainersTestEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}.query`); + expect(ATrainersTestEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}:title`); + expect(ATrainersTestEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}:description`); + expect(ATrainersTestEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}:query`); expect(ATrainersTestEncounter.options.length).toBe(2); }); - it("should not run below wave 10", async () => { - game.override.startingWave(9); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.A_TRAINERS_TEST); - }); - - it("should not run above wave 179", async () => { - game.override.startingWave(181); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle.mysteryEncounter).toBeUndefined(); - }); - it("should initialize fully ", async () => { initSceneWithoutEncounterPhase(scene, defaultParty); scene.currentBattle.mysteryEncounter = ATrainersTestEncounter; @@ -110,8 +95,8 @@ describe("A Trainer's Test - Mystery Encounter", () => { const option = ATrainersTestEncounter.options[0]; expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); - expect(option.dialogue!.buttonLabel).toStrictEqual(`${namespace}.option.1.label`); - expect(option.dialogue!.buttonTooltip).toStrictEqual(`${namespace}.option.1.tooltip`); + expect(option.dialogue!.buttonLabel).toStrictEqual(`${namespace}:option.1.label`); + expect(option.dialogue!.buttonTooltip).toStrictEqual(`${namespace}:option.1.tooltip`); }); it("Should start battle against the trainer", async () => { @@ -122,7 +107,8 @@ describe("A Trainer's Test - Mystery Encounter", () => { expect(scene.getCurrentPhase()?.constructor.name).toBe(CommandPhase.name); expect(enemyField.length).toBe(1); expect(scene.currentBattle.trainer).toBeDefined(); - expect(["buck", "cheryl", "marley", "mira", "riley"].includes(scene.currentBattle.trainer!.config.name.toLowerCase())).toBeTruthy(); + expect([ i18next.t("trainerNames:buck"), i18next.t("trainerNames:cheryl"), i18next.t("trainerNames:marley"), i18next.t("trainerNames:mira"), i18next.t("trainerNames:riley") ] + .map(name => name.toLowerCase()).includes(scene.currentBattle.trainer!.config.name)).toBeTruthy(); expect(enemyField[0]).toBeDefined(); }); @@ -142,7 +128,7 @@ describe("A Trainer's Test - Mystery Encounter", () => { expect(eggsAfter).toBeDefined(); expect(eggsBeforeLength + 1).toBe(eggsAfter.length); const eggTier = eggsAfter[eggsAfter.length - 1].tier; - expect(eggTier === EggTier.ULTRA || eggTier === EggTier.MASTER).toBeTruthy(); + expect(eggTier === EggTier.EPIC || eggTier === EggTier.LEGENDARY).toBeTruthy(); }); }); @@ -161,8 +147,8 @@ describe("A Trainer's Test - Mystery Encounter", () => { const option = ATrainersTestEncounter.options[1]; expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); - expect(option.dialogue?.buttonLabel).toStrictEqual(`${namespace}.option.2.label`); - expect(option.dialogue?.buttonTooltip).toStrictEqual(`${namespace}.option.2.tooltip`); + expect(option.dialogue?.buttonLabel).toStrictEqual(`${namespace}:option.2.label`); + expect(option.dialogue?.buttonTooltip).toStrictEqual(`${namespace}:option.2.tooltip`); }); it("Should fully heal the party", async () => { @@ -190,7 +176,7 @@ describe("A Trainer's Test - Mystery Encounter", () => { expect(eggsAfter).toBeDefined(); expect(eggsBeforeLength + 1).toBe(eggsAfter.length); const eggTier = eggsAfter[eggsAfter.length - 1].tier; - expect(eggTier).toBe(EggTier.GREAT); + expect(eggTier).toBe(EggTier.RARE); }); it("should leave encounter without battle", async () => { diff --git a/src/test/mystery-encounter/encounters/absolute-avarice-encounter.test.ts b/src/test/mystery-encounter/encounters/absolute-avarice-encounter.test.ts index 7cca7abba27..61d8aaa9f5a 100644 --- a/src/test/mystery-encounter/encounters/absolute-avarice-encounter.test.ts +++ b/src/test/mystery-encounter/encounters/absolute-avarice-encounter.test.ts @@ -16,9 +16,10 @@ import { Moves } from "#enums/moves"; import { CommandPhase } from "#app/phases/command-phase"; import { MovePhase } from "#app/phases/move-phase"; import { SelectModifierPhase } from "#app/phases/select-modifier-phase"; +import i18next from "i18next"; -const namespace = "mysteryEncounter:absoluteAvarice"; -const defaultParty = [Species.LAPRAS, Species.GENGAR, Species.ABRA]; +const namespace = "mysteryEncounters/absoluteAvarice"; +const defaultParty = [ Species.LAPRAS, Species.GENGAR, Species.ABRA ]; const defaultBiome = Biome.PLAINS; const defaultWave = 45; @@ -41,8 +42,8 @@ describe("Absolute Avarice - Mystery Encounter", () => { vi.spyOn(MysteryEncounters, "mysteryEncountersByBiome", "get").mockReturnValue( new Map([ - [Biome.PLAINS, [MysteryEncounterType.ABSOLUTE_AVARICE]], - [Biome.VOLCANO, [MysteryEncounterType.MYSTERIOUS_CHALLENGERS]], + [ Biome.PLAINS, [ MysteryEncounterType.ABSOLUTE_AVARICE ]], + [ Biome.VOLCANO, [ MysteryEncounterType.MYSTERIOUS_CHALLENGERS ]], ]) ); }); @@ -59,29 +60,13 @@ describe("Absolute Avarice - Mystery Encounter", () => { expect(AbsoluteAvariceEncounter.encounterType).toBe(MysteryEncounterType.ABSOLUTE_AVARICE); expect(AbsoluteAvariceEncounter.encounterTier).toBe(MysteryEncounterTier.GREAT); expect(AbsoluteAvariceEncounter.dialogue).toBeDefined(); - expect(AbsoluteAvariceEncounter.dialogue.intro).toStrictEqual([{ text: `${namespace}.intro` }]); - expect(AbsoluteAvariceEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}.title`); - expect(AbsoluteAvariceEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}.description`); - expect(AbsoluteAvariceEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}.query`); + expect(AbsoluteAvariceEncounter.dialogue.intro).toStrictEqual([{ text: `${namespace}:intro` }]); + expect(AbsoluteAvariceEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}:title`); + expect(AbsoluteAvariceEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}:description`); + expect(AbsoluteAvariceEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}:query`); expect(AbsoluteAvariceEncounter.options.length).toBe(3); }); - it("should not run below wave 10", async () => { - game.override.startingWave(9); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.ABSOLUTE_AVARICE); - }); - - it("should not run above wave 179", async () => { - game.override.startingWave(181); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle.mysteryEncounter).toBeUndefined(); - }); - it("should not spawn outside of proper biomes", async () => { game.override.mysteryEncounterTier(MysteryEncounterTier.GREAT); game.override.startingBiome(Biome.VOLCANO); @@ -100,7 +85,7 @@ describe("Absolute Avarice - Mystery Encounter", () => { it("should spawn if player has enough berries", async () => { game.override.mysteryEncounterTier(MysteryEncounterTier.GREAT); - game.override.startingHeldItems([{name: "BERRY", count: 2, type: BerryType.SITRUS}, {name: "BERRY", count: 3, type: BerryType.GANLON}]); + game.override.startingHeldItems([{ name: "BERRY", count: 2, type: BerryType.SITRUS }, { name: "BERRY", count: 3, type: BerryType.GANLON }]); await game.runToMysteryEncounter(); @@ -108,7 +93,7 @@ describe("Absolute Avarice - Mystery Encounter", () => { }); it("should remove all player's berries at the start of the encounter", async () => { - game.override.startingHeldItems([{name: "BERRY", count: 2, type: BerryType.SITRUS}, {name: "BERRY", count: 3, type: BerryType.GANLON}]); + game.override.startingHeldItems([{ name: "BERRY", count: 2, type: BerryType.SITRUS }, { name: "BERRY", count: 3, type: BerryType.GANLON }]); await game.runToMysteryEncounter(MysteryEncounterType.ABSOLUTE_AVARICE, defaultParty); @@ -122,11 +107,11 @@ describe("Absolute Avarice - Mystery Encounter", () => { expect(option1.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option1.dialogue).toBeDefined(); expect(option1.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.1.selected`, + text: `${namespace}:option.1.selected`, }, ], }); @@ -144,7 +129,7 @@ describe("Absolute Avarice - Mystery Encounter", () => { expect(enemyField[0].species.speciesId).toBe(Species.GREEDENT); const moveset = enemyField[0].moveset.map(m => m?.moveId); expect(moveset?.length).toBe(4); - expect(moveset).toEqual([Moves.THRASH, Moves.BODY_PRESS, Moves.STUFF_CHEEKS, Moves.SLACK_OFF]); + expect(moveset).toEqual([ Moves.THRASH, Moves.BODY_PRESS, Moves.STUFF_CHEEKS, Moves.CRUNCH ]); const movePhases = phaseSpy.mock.calls.filter(p => p[0] instanceof MovePhase).map(p => p[0]); expect(movePhases.length).toBe(1); @@ -158,11 +143,11 @@ describe("Absolute Avarice - Mystery Encounter", () => { await game.phaseInterceptor.to(SelectModifierPhase, false); expect(scene.getCurrentPhase()?.constructor.name).toBe(SelectModifierPhase.name); - for (const partyPokemon of scene.getParty()) { + for (const partyPokemon of scene.getPlayerParty()) { const pokemonId = partyPokemon.id; const pokemonItems = scene.findModifiers(m => m instanceof PokemonHeldItemModifier && (m as PokemonHeldItemModifier).pokemonId === pokemonId, true) as PokemonHeldItemModifier[]; - const revSeed = pokemonItems.find(i => i.type.name === "Reviver Seed"); + const revSeed = pokemonItems.find(i => i.type.name === i18next.t("modifierType:ModifierType.REVIVER_SEED.name")); expect(revSeed).toBeDefined; expect(revSeed?.stackCount).toBe(1); } @@ -175,18 +160,18 @@ describe("Absolute Avarice - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, selected: [ { - text: `${namespace}.option.2.selected`, + text: `${namespace}:option.2.selected`, }, ], }); }); - it("Should return 3 (2/5ths floored) berries if 8 were stolen", {retry: 5}, async () => { - game.override.startingHeldItems([{name: "BERRY", count: 2, type: BerryType.SITRUS}, {name: "BERRY", count: 3, type: BerryType.GANLON}, {name: "BERRY", count: 3, type: BerryType.APICOT}]); + it("Should return 3 (2/5ths floored) berries if 8 were stolen", { retry: 5 }, async () => { + game.override.startingHeldItems([{ name: "BERRY", count: 2, type: BerryType.SITRUS }, { name: "BERRY", count: 3, type: BerryType.GANLON }, { name: "BERRY", count: 3, type: BerryType.APICOT }]); await game.runToMysteryEncounter(MysteryEncounterType.ABSOLUTE_AVARICE, defaultParty); @@ -201,8 +186,8 @@ describe("Absolute Avarice - Mystery Encounter", () => { expect(berryCountAfter).toBe(3); }); - it("Should return 2 (2/5ths floored) berries if 7 were stolen", {retry: 5}, async () => { - game.override.startingHeldItems([{name: "BERRY", count: 2, type: BerryType.SITRUS}, {name: "BERRY", count: 3, type: BerryType.GANLON}, {name: "BERRY", count: 2, type: BerryType.APICOT}]); + it("Should return 2 (2/5ths floored) berries if 7 were stolen", { retry: 5 }, async () => { + game.override.startingHeldItems([{ name: "BERRY", count: 2, type: BerryType.SITRUS }, { name: "BERRY", count: 3, type: BerryType.GANLON }, { name: "BERRY", count: 2, type: BerryType.APICOT }]); await game.runToMysteryEncounter(MysteryEncounterType.ABSOLUTE_AVARICE, defaultParty); @@ -233,11 +218,11 @@ describe("Absolute Avarice - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, selected: [ { - text: `${namespace}.option.3.selected`, + text: `${namespace}:option.3.selected`, }, ], }); @@ -245,17 +230,17 @@ describe("Absolute Avarice - Mystery Encounter", () => { it("should add Greedent to the party", async () => { await game.runToMysteryEncounter(MysteryEncounterType.ABSOLUTE_AVARICE, defaultParty); - const partyCountBefore = scene.getParty().length; + const partyCountBefore = scene.getPlayerParty().length; await runMysteryEncounterToEnd(game, 3); - const partyCountAfter = scene.getParty().length; + const partyCountAfter = scene.getPlayerParty().length; expect(partyCountBefore + 1).toBe(partyCountAfter); - const greedent = scene.getParty()[scene.getParty().length - 1]; + const greedent = scene.getPlayerParty()[scene.getPlayerParty().length - 1]; expect(greedent.species.speciesId).toBe(Species.GREEDENT); const moveset = greedent.moveset.map(m => m?.moveId); expect(moveset?.length).toBe(4); - expect(moveset).toEqual([Moves.THRASH, Moves.BODY_PRESS, Moves.STUFF_CHEEKS, Moves.SLACK_OFF]); + expect(moveset).toEqual([ Moves.THRASH, Moves.BODY_PRESS, Moves.STUFF_CHEEKS, Moves.SLACK_OFF ]); }); it("should leave encounter without battle", async () => { diff --git a/src/test/mystery-encounter/encounters/an-offer-you-cant-refuse-encounter.test.ts b/src/test/mystery-encounter/encounters/an-offer-you-cant-refuse-encounter.test.ts index 1c68852a63d..727a3993d9b 100644 --- a/src/test/mystery-encounter/encounters/an-offer-you-cant-refuse-encounter.test.ts +++ b/src/test/mystery-encounter/encounters/an-offer-you-cant-refuse-encounter.test.ts @@ -17,10 +17,12 @@ import { getPokemonSpecies } from "#app/data/pokemon-species"; import { Moves } from "#enums/moves"; import { ShinyRateBoosterModifier } from "#app/modifier/modifier"; import { SelectModifierPhase } from "#app/phases/select-modifier-phase"; +import i18next from "i18next"; +import { Abilities } from "#enums/abilities"; -const namespace = "mysteryEncounter:offerYouCantRefuse"; +const namespace = "mysteryEncounters/anOfferYouCantRefuse"; /** Gyarados for Indimidate */ -const defaultParty = [Species.GYARADOS, Species.GENGAR, Species.ABRA]; +const defaultParty = [ Species.GYARADOS, Species.GENGAR, Species.ABRA ]; const defaultBiome = Biome.CAVE; const defaultWave = 45; @@ -36,16 +38,17 @@ describe("An Offer You Can't Refuse - Mystery Encounter", () => { beforeEach(async () => { game = new GameManager(phaserGame); scene = game.scene; - game.override.mysteryEncounterChance(100); - game.override.startingWave(defaultWave); - game.override.startingBiome(defaultBiome); - game.override.disableTrainerWaves(); + game.override.mysteryEncounterChance(100) + .startingWave(defaultWave) + .startingBiome(defaultBiome) + .disableTrainerWaves() + .ability(Abilities.INTIMIDATE); // Extortion ability const biomeMap = new Map([ - [Biome.VOLCANO, [MysteryEncounterType.MYSTERIOUS_CHALLENGERS]], + [ Biome.VOLCANO, [ MysteryEncounterType.MYSTERIOUS_CHALLENGERS ]], ]); HUMAN_TRANSITABLE_BIOMES.forEach(biome => { - biomeMap.set(biome, [MysteryEncounterType.AN_OFFER_YOU_CANT_REFUSE]); + biomeMap.set(biome, [ MysteryEncounterType.AN_OFFER_YOU_CANT_REFUSE ]); }); vi.spyOn(MysteryEncounters, "mysteryEncountersByBiome", "get").mockReturnValue(biomeMap); }); @@ -63,12 +66,12 @@ describe("An Offer You Can't Refuse - Mystery Encounter", () => { expect(AnOfferYouCantRefuseEncounter.encounterTier).toBe(MysteryEncounterTier.GREAT); expect(AnOfferYouCantRefuseEncounter.dialogue).toBeDefined(); expect(AnOfferYouCantRefuseEncounter.dialogue.intro).toStrictEqual([ - { text: `${namespace}.intro` }, - { speaker: `${namespace}.speaker`, text: `${namespace}.intro_dialogue` } + { text: `${namespace}:intro` }, + { speaker: `${namespace}:speaker`, text: `${namespace}:intro_dialogue` } ]); - expect(AnOfferYouCantRefuseEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}.title`); - expect(AnOfferYouCantRefuseEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}.description`); - expect(AnOfferYouCantRefuseEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}.query`); + expect(AnOfferYouCantRefuseEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}:title`); + expect(AnOfferYouCantRefuseEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}:description`); + expect(AnOfferYouCantRefuseEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}:query`); expect(AnOfferYouCantRefuseEncounter.options.length).toBe(3); }); @@ -80,22 +83,6 @@ describe("An Offer You Can't Refuse - Mystery Encounter", () => { expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.AN_OFFER_YOU_CANT_REFUSE); }); - it("should not run below wave 10", async () => { - game.override.startingWave(9); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.AN_OFFER_YOU_CANT_REFUSE); - }); - - it("should not run above wave 179", async () => { - game.override.startingWave(181); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle.mysteryEncounter).toBeUndefined(); - }); - it("should initialize fully ", async () => { initSceneWithoutEncounterPhase(scene, defaultParty); scene.currentBattle.mysteryEncounter = AnOfferYouCantRefuseEncounter; @@ -109,8 +96,8 @@ describe("An Offer You Can't Refuse - Mystery Encounter", () => { expect(AnOfferYouCantRefuseEncounter.dialogueTokens?.strongestPokemon).toBeDefined(); expect(AnOfferYouCantRefuseEncounter.dialogueTokens?.price).toBeDefined(); - expect(AnOfferYouCantRefuseEncounter.dialogueTokens?.option2PrimaryAbility).toBe("Intimidate"); - expect(AnOfferYouCantRefuseEncounter.dialogueTokens?.moveOrAbility).toBe("Intimidate"); + expect(AnOfferYouCantRefuseEncounter.dialogueTokens?.option2PrimaryAbility).toBe(i18next.t("ability:intimidate.name")); + expect(AnOfferYouCantRefuseEncounter.dialogueTokens?.moveOrAbility).toBe(i18next.t("ability:intimidate.name")); expect(AnOfferYouCantRefuseEncounter.misc.pokemon instanceof PlayerPokemon).toBeTruthy(); expect(AnOfferYouCantRefuseEncounter.misc?.price?.toString()).toBe(AnOfferYouCantRefuseEncounter.dialogueTokens?.price); expect(onInitResult).toBe(true); @@ -122,12 +109,12 @@ describe("An Offer You Can't Refuse - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - speaker: `${namespace}.speaker`, - text: `${namespace}.option.1.selected`, + speaker: `${namespace}:speaker`, + text: `${namespace}:option.1.selected`, }, ], }); @@ -160,13 +147,13 @@ describe("An Offer You Can't Refuse - Mystery Encounter", () => { it("Should remove the Pokemon from the party", async () => { await game.runToMysteryEncounter(MysteryEncounterType.AN_OFFER_YOU_CANT_REFUSE, defaultParty); - const initialPartySize = scene.getParty().length; + const initialPartySize = scene.getPlayerParty().length; const pokemonName = scene.currentBattle.mysteryEncounter!.misc.pokemon.name; await runMysteryEncounterToEnd(game, 1); - expect(scene.getParty().length).toBe(initialPartySize - 1); - expect(scene.getParty().find(p => p.name === pokemonName)).toBeUndefined(); + expect(scene.getPlayerParty().length).toBe(initialPartySize - 1); + expect(scene.getPlayerParty().find(p => p.name === pokemonName)).toBeUndefined(); }); it("should leave encounter without battle", async () => { @@ -185,13 +172,13 @@ describe("An Offer You Can't Refuse - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DISABLED_OR_SPECIAL); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, - disabledButtonTooltip: `${namespace}.option.2.tooltip_disabled`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, + disabledButtonTooltip: `${namespace}:option.2.tooltip_disabled`, selected: [ { - speaker: `${namespace}.speaker`, - text: `${namespace}.option.2.selected`, + speaker: `${namespace}:speaker`, + text: `${namespace}:option.2.selected`, }, ], }); @@ -199,7 +186,7 @@ describe("An Offer You Can't Refuse - Mystery Encounter", () => { it("should award EXP to a pokemon with an ability in EXTORTION_ABILITIES", async () => { await game.runToMysteryEncounter(MysteryEncounterType.AN_OFFER_YOU_CANT_REFUSE, defaultParty); - const party = scene.getParty(); + const party = scene.getPlayerParty(); const gyarados = party.find((pkm) => pkm.species.speciesId === Species.GYARADOS)!; const expBefore = gyarados.exp; @@ -210,10 +197,11 @@ describe("An Offer You Can't Refuse - Mystery Encounter", () => { }); it("should award EXP to a pokemon with a move in EXTORTION_MOVES", async () => { - await game.runToMysteryEncounter(MysteryEncounterType.AN_OFFER_YOU_CANT_REFUSE, [Species.ABRA]); - const party = scene.getParty(); + game.override.ability(Abilities.SYNCHRONIZE); // Not an extortion ability, so we can test extortion move + await game.runToMysteryEncounter(MysteryEncounterType.AN_OFFER_YOU_CANT_REFUSE, [ Species.ABRA ]); + const party = scene.getPlayerParty(); const abra = party.find((pkm) => pkm.species.speciesId === Species.ABRA)!; - abra.moveset = [new PokemonMove(Moves.BEAT_UP)]; + abra.moveset = [ new PokemonMove(Moves.BEAT_UP) ]; const expBefore = abra.exp; await runMysteryEncounterToEnd(game, 2); diff --git a/src/test/mystery-encounter/encounters/berries-abound-encounter.test.ts b/src/test/mystery-encounter/encounters/berries-abound-encounter.test.ts index 73ffad36258..2507b94e5ae 100644 --- a/src/test/mystery-encounter/encounters/berries-abound-encounter.test.ts +++ b/src/test/mystery-encounter/encounters/berries-abound-encounter.test.ts @@ -17,9 +17,10 @@ import * as EncounterPhaseUtils from "#app/data/mystery-encounters/utils/encount import * as EncounterDialogueUtils from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; import { CommandPhase } from "#app/phases/command-phase"; import { SelectModifierPhase } from "#app/phases/select-modifier-phase"; +import { Abilities } from "#enums/abilities"; -const namespace = "mysteryEncounter:berriesAbound"; -const defaultParty = [Species.PYUKUMUKU]; +const namespace = "mysteryEncounters/berriesAbound"; +const defaultParty = [ Species.PYUKUMUKU, Species.MAGIKARP, Species.PIKACHU ]; const defaultBiome = Biome.CAVE; const defaultWave = 45; @@ -35,17 +36,19 @@ describe("Berries Abound - Mystery Encounter", () => { beforeEach(async () => { game = new GameManager(phaserGame); scene = game.scene; - game.override.mysteryEncounterChance(100); - game.override.mysteryEncounterTier(MysteryEncounterTier.COMMON); - game.override.startingWave(defaultWave); - game.override.startingBiome(defaultBiome); - game.override.disableTrainerWaves(); - game.override.startingModifier([]); - game.override.startingHeldItems([]); + game.override.mysteryEncounterChance(100) + .mysteryEncounterTier(MysteryEncounterTier.COMMON) + .startingWave(defaultWave) + .startingBiome(defaultBiome) + .disableTrainerWaves() + .startingModifier([]) + .startingHeldItems([]) + .enemyAbility(Abilities.BALL_FETCH) + .enemyPassiveAbility(Abilities.BALL_FETCH); vi.spyOn(MysteryEncounters, "mysteryEncountersByBiome", "get").mockReturnValue( new Map([ - [Biome.CAVE, [MysteryEncounterType.BERRIES_ABOUND]], + [ Biome.CAVE, [ MysteryEncounterType.BERRIES_ABOUND ]], ]) ); }); @@ -62,29 +65,13 @@ describe("Berries Abound - Mystery Encounter", () => { expect(BerriesAboundEncounter.encounterType).toBe(MysteryEncounterType.BERRIES_ABOUND); expect(BerriesAboundEncounter.encounterTier).toBe(MysteryEncounterTier.COMMON); expect(BerriesAboundEncounter.dialogue).toBeDefined(); - expect(BerriesAboundEncounter.dialogue.intro).toStrictEqual([{ text: `${namespace}.intro` }]); - expect(BerriesAboundEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}.title`); - expect(BerriesAboundEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}.description`); - expect(BerriesAboundEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}.query`); + expect(BerriesAboundEncounter.dialogue.intro).toStrictEqual([{ text: `${namespace}:intro` }]); + expect(BerriesAboundEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}:title`); + expect(BerriesAboundEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}:description`); + expect(BerriesAboundEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}:query`); expect(BerriesAboundEncounter.options.length).toBe(3); }); - it("should not run below wave 10", async () => { - game.override.startingWave(9); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.BERRIES_ABOUND); - }); - - it("should not run above wave 179", async () => { - game.override.startingWave(181); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle.mysteryEncounter).toBeUndefined(); - }); - it("should initialize fully", async () => { initSceneWithoutEncounterPhase(scene, defaultParty); scene.currentBattle.mysteryEncounter = BerriesAboundEncounter; @@ -98,7 +85,6 @@ describe("Berries Abound - Mystery Encounter", () => { const config = BerriesAboundEncounter.enemyPartyConfigs[0]; expect(config).toBeDefined(); - expect(config.levelAdditiveMultiplier).toBe(1); expect(config.pokemonConfigs?.[0].isBoss).toBe(true); expect(onInitResult).toBe(true); }); @@ -109,11 +95,11 @@ describe("Berries Abound - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.1.selected`, + text: `${namespace}:option.1.selected`, }, ], }); @@ -133,8 +119,10 @@ describe("Berries Abound - Mystery Encounter", () => { expect(enemyField[0].species.speciesId).toBe(speciesToSpawn); }); - // TODO: there is some severe test flakiness occurring for this file, needs to be looked at/addressed in separate issue - it.skip("should reward the player with X berries based on wave", async () => { + /** + * Related issue-comment: {@link https://github.com/pagefaultgames/pokerogue/issues/4300#issuecomment-2362849444} + */ + it("should reward the player with X berries based on wave", async () => { await game.runToMysteryEncounter(MysteryEncounterType.BERRIES_ABOUND, defaultParty); const numBerries = game.scene.currentBattle.mysteryEncounter!.misc.numBerries; @@ -178,19 +166,22 @@ describe("Berries Abound - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, }); }); - it("should start battle if fastest pokemon is slower than boss", async () => { + it("should start battle if fastest pokemon is slower than boss below wave 50", async () => { + game.override.startingWave(41); const encounterTextSpy = vi.spyOn(EncounterDialogueUtils, "showEncounterText"); await game.runToMysteryEncounter(MysteryEncounterType.BERRIES_ABOUND, defaultParty); + scene.getPlayerParty().forEach(pkm => { + vi.spyOn(pkm, "getStat").mockReturnValue(1); // for ease return for every stat + }); + const config = game.scene.currentBattle.mysteryEncounter!.enemyPartyConfigs[0]; const speciesToSpawn = config.pokemonConfigs?.[0].species.speciesId; - // Setting enemy's level arbitrarily high to outspeed - config.pokemonConfigs![0].dataSource!.level = 1000; await runMysteryEncounterToEnd(game, 2, undefined, true); @@ -200,20 +191,43 @@ describe("Berries Abound - Mystery Encounter", () => { expect(enemyField[0].species.speciesId).toBe(speciesToSpawn); // Should be enraged - expect(enemyField[0].summonData.statStages).toEqual([1, 1, 1, 1, 1, 0, 0]); - expect(encounterTextSpy).toHaveBeenCalledWith(expect.any(BattleScene), `${namespace}.option.2.selected_bad`); + expect(enemyField[0].summonData.statStages).toEqual([ 0, 1, 0, 1, 1, 0, 0 ]); + expect(encounterTextSpy).toHaveBeenCalledWith(expect.any(BattleScene), `${namespace}:option.2.selected_bad`); + }); + + it("should start battle if fastest pokemon is slower than boss above wave 50", async () => { + game.override.startingWave(57); + const encounterTextSpy = vi.spyOn(EncounterDialogueUtils, "showEncounterText"); + await game.runToMysteryEncounter(MysteryEncounterType.BERRIES_ABOUND, defaultParty); + + scene.getPlayerParty().forEach(pkm => { + vi.spyOn(pkm, "getStat").mockReturnValue(1); // for ease return for every stat + }); + + const config = game.scene.currentBattle.mysteryEncounter!.enemyPartyConfigs[0]; + const speciesToSpawn = config.pokemonConfigs?.[0].species.speciesId; + + await runMysteryEncounterToEnd(game, 2, undefined, true); + + const enemyField = scene.getEnemyField(); + expect(scene.getCurrentPhase()?.constructor.name).toBe(CommandPhase.name); + expect(enemyField.length).toBe(1); + expect(enemyField[0].species.speciesId).toBe(speciesToSpawn); + + // Should be enraged + expect(enemyField[0].summonData.statStages).toEqual([ 1, 1, 1, 1, 1, 0, 0 ]); + expect(encounterTextSpy).toHaveBeenCalledWith(expect.any(BattleScene), `${namespace}:option.2.selected_bad`); }); it("Should skip battle when fastest pokemon is faster than boss", async () => { - const leaveEncounterWithoutBattleSpy = vi.spyOn(EncounterPhaseUtils, "leaveEncounterWithoutBattle"); - const encounterTextSpy = vi.spyOn(EncounterDialogueUtils, "showEncounterText"); + vi.spyOn(EncounterPhaseUtils, "leaveEncounterWithoutBattle"); + vi.spyOn(EncounterDialogueUtils, "showEncounterText"); await game.runToMysteryEncounter(MysteryEncounterType.BERRIES_ABOUND, defaultParty); - // Setting party pokemon's level arbitrarily high to outspeed - const fastestPokemon = scene.getParty()[0]; - fastestPokemon.level = 1000; - fastestPokemon.calculateStats(); + scene.getPlayerParty().forEach(pkm => { + vi.spyOn(pkm, "getStat").mockReturnValue(9999); // for ease return for every stat + }); await runMysteryEncounterToEnd(game, 2); await game.phaseInterceptor.to(SelectModifierPhase, false); @@ -227,8 +241,8 @@ describe("Berries Abound - Mystery Encounter", () => { expect(option.modifierTypeOption.type.id).toContain("BERRY"); } - expect(encounterTextSpy).toHaveBeenCalledWith(expect.any(BattleScene), `${namespace}.option.2.selected`); - expect(leaveEncounterWithoutBattleSpy).toBeCalled(); + expect(EncounterDialogueUtils.showEncounterText).toHaveBeenCalledWith(expect.any(BattleScene), `${namespace}:option.2.selected`); + expect(EncounterPhaseUtils.leaveEncounterWithoutBattle).toBeCalled(); }); }); diff --git a/src/test/mystery-encounter/encounters/bug-type-superfan-encounter.test.ts b/src/test/mystery-encounter/encounters/bug-type-superfan-encounter.test.ts index 70adf93d502..e0f37c7e045 100644 --- a/src/test/mystery-encounter/encounters/bug-type-superfan-encounter.test.ts +++ b/src/test/mystery-encounter/encounters/bug-type-superfan-encounter.test.ts @@ -21,8 +21,8 @@ import * as encounterPhaseUtils from "#app/data/mystery-encounters/utils/encount import { SelectModifierPhase } from "#app/phases/select-modifier-phase"; import ModifierSelectUiHandler from "#app/ui/modifier-select-ui-handler"; -const namespace = "mysteryEncounter:bugTypeSuperfan"; -const defaultParty = [Species.LAPRAS, Species.GENGAR, Species.WEEDLE]; +const namespace = "mysteryEncounters/bugTypeSuperfan"; +const defaultParty = [ Species.LAPRAS, Species.GENGAR, Species.WEEDLE ]; const defaultBiome = Biome.CAVE; const defaultWave = 24; @@ -169,7 +169,7 @@ describe("Bug-Type Superfan - Mystery Encounter", () => { vi.spyOn(MysteryEncounters, "mysteryEncountersByBiome", "get").mockReturnValue( new Map([ - [Biome.CAVE, [MysteryEncounterType.BUG_TYPE_SUPERFAN]], + [ Biome.CAVE, [ MysteryEncounterType.BUG_TYPE_SUPERFAN ]], ]) ); }); @@ -188,35 +188,19 @@ describe("Bug-Type Superfan - Mystery Encounter", () => { expect(BugTypeSuperfanEncounter.dialogue).toBeDefined(); expect(BugTypeSuperfanEncounter.dialogue.intro).toStrictEqual([ { - text: `${namespace}.intro`, + text: `${namespace}:intro`, }, { - speaker: `${namespace}.speaker`, - text: `${namespace}.intro_dialogue`, + speaker: `${namespace}:speaker`, + text: `${namespace}:intro_dialogue`, }, ]); - expect(BugTypeSuperfanEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}.title`); - expect(BugTypeSuperfanEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}.description`); - expect(BugTypeSuperfanEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}.query`); + expect(BugTypeSuperfanEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}:title`); + expect(BugTypeSuperfanEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}:description`); + expect(BugTypeSuperfanEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}:query`); expect(BugTypeSuperfanEncounter.options.length).toBe(3); }); - it("should not run below wave 10", async () => { - game.override.startingWave(9); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.BUG_TYPE_SUPERFAN); - }); - - it("should not run above wave 179", async () => { - game.override.startingWave(181); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle.mysteryEncounter).toBeUndefined(); - }); - it("should initialize fully", async () => { initSceneWithoutEncounterPhase(scene, defaultParty); scene.currentBattle.mysteryEncounter = BugTypeSuperfanEncounter; @@ -242,12 +226,12 @@ describe("Bug-Type Superfan - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - speaker: `${namespace}.speaker`, - text: `${namespace}.option.1.selected`, + speaker: `${namespace}:speaker`, + text: `${namespace}:option.1.selected`, }, ], }); @@ -414,14 +398,14 @@ describe("Bug-Type Superfan - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DISABLED_OR_DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, - disabledButtonTooltip: `${namespace}.option.2.disabled_tooltip` + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, + disabledButtonTooltip: `${namespace}:option.2.disabled_tooltip` }); }); it("should NOT be selectable if the player doesn't have any Bug types", async () => { - await game.runToMysteryEncounter(MysteryEncounterType.BUG_TYPE_SUPERFAN, [Species.ABRA]); + await game.runToMysteryEncounter(MysteryEncounterType.BUG_TYPE_SUPERFAN, [ Species.ABRA ]); await game.phaseInterceptor.to(MysteryEncounterPhase, false); const encounterPhase = scene.getCurrentPhase(); @@ -454,7 +438,7 @@ describe("Bug-Type Superfan - Mystery Encounter", () => { }); it("should proceed to rewards screen with 2-3 Bug Types reward options", async () => { - await game.runToMysteryEncounter(MysteryEncounterType.BUG_TYPE_SUPERFAN, [Species.BUTTERFREE, Species.BEEDRILL]); + await game.runToMysteryEncounter(MysteryEncounterType.BUG_TYPE_SUPERFAN, [ Species.BUTTERFREE, Species.BEEDRILL ]); await runMysteryEncounterToEnd(game, 2); expect(scene.getCurrentPhase()?.constructor.name).toBe(SelectModifierPhase.name); @@ -469,7 +453,7 @@ describe("Bug-Type Superfan - Mystery Encounter", () => { }); it("should proceed to rewards screen with 4-5 Bug Types reward options", async () => { - await game.runToMysteryEncounter(MysteryEncounterType.BUG_TYPE_SUPERFAN, [Species.BUTTERFREE, Species.BEEDRILL, Species.GALVANTULA, Species.VOLCARONA]); + await game.runToMysteryEncounter(MysteryEncounterType.BUG_TYPE_SUPERFAN, [ Species.BUTTERFREE, Species.BEEDRILL, Species.GALVANTULA, Species.VOLCARONA ]); await runMysteryEncounterToEnd(game, 2); expect(scene.getCurrentPhase()?.constructor.name).toBe(SelectModifierPhase.name); @@ -484,7 +468,7 @@ describe("Bug-Type Superfan - Mystery Encounter", () => { }); it("should proceed to rewards screen with 6 Bug Types reward options (including form change item)", async () => { - await game.runToMysteryEncounter(MysteryEncounterType.BUG_TYPE_SUPERFAN, [Species.BUTTERFREE, Species.BEEDRILL, Species.GALVANTULA, Species.VOLCARONA, Species.ANORITH, Species.GENESECT]); + await game.runToMysteryEncounter(MysteryEncounterType.BUG_TYPE_SUPERFAN, [ Species.BUTTERFREE, Species.BEEDRILL, Species.GALVANTULA, Species.VOLCARONA, Species.ANORITH, Species.GENESECT ]); await runMysteryEncounterToEnd(game, 2); expect(scene.getCurrentPhase()?.constructor.name).toBe(SelectModifierPhase.name); @@ -492,10 +476,11 @@ describe("Bug-Type Superfan - Mystery Encounter", () => { expect(scene.ui.getMode()).to.equal(Mode.MODIFIER_SELECT); const modifierSelectHandler = scene.ui.handlers.find(h => h instanceof ModifierSelectUiHandler) as ModifierSelectUiHandler; - expect(modifierSelectHandler.options.length).toEqual(3); + expect(modifierSelectHandler.options.length).toEqual(4); expect(modifierSelectHandler.options[0].modifierTypeOption.type.id).toBe("MASTER_BALL"); - expect(modifierSelectHandler.options[1].modifierTypeOption.type.id).toBe("MAX_LURE"); - expect(modifierSelectHandler.options[2].modifierTypeOption.type.id).toBe("FORM_CHANGE_ITEM"); + expect(modifierSelectHandler.options[1].modifierTypeOption.type.id).toBe("MEGA_BRACELET"); + expect(modifierSelectHandler.options[2].modifierTypeOption.type.id).toBe("DYNAMAX_BAND"); + expect(modifierSelectHandler.options[3].modifierTypeOption.type.id).toBe("FORM_CHANGE_ITEM"); }); it("should leave encounter without battle", async () => { @@ -514,19 +499,19 @@ describe("Bug-Type Superfan - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DISABLED_OR_DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, - disabledButtonTooltip: `${namespace}.option.3.disabled_tooltip`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, + disabledButtonTooltip: `${namespace}:option.3.disabled_tooltip`, selected: [ { - text: `${namespace}.option.3.selected`, + text: `${namespace}:option.3.selected`, }, { - speaker: `${namespace}.speaker`, - text: `${namespace}.option.3.selected_dialogue`, + speaker: `${namespace}:speaker`, + text: `${namespace}:option.3.selected_dialogue`, }, ], - secondOptionPrompt: `${namespace}.option.3.select_prompt`, + secondOptionPrompt: `${namespace}:option.3.select_prompt`, }); }); @@ -552,8 +537,8 @@ describe("Bug-Type Superfan - Mystery Encounter", () => { }); it("should remove the gifted item and proceed to rewards screen", async () => { - game.override.startingHeldItems([{name: "GRIP_CLAW", count: 1}]); - await game.runToMysteryEncounter(MysteryEncounterType.BUG_TYPE_SUPERFAN, [Species.BUTTERFREE]); + game.override.startingHeldItems([{ name: "GRIP_CLAW", count: 1 }]); + await game.runToMysteryEncounter(MysteryEncounterType.BUG_TYPE_SUPERFAN, [ Species.BUTTERFREE ]); const gripClawCountBefore = scene.findModifier(m => m instanceof ContactHeldItemTransferChanceModifier)?.stackCount ?? 0; @@ -573,10 +558,10 @@ describe("Bug-Type Superfan - Mystery Encounter", () => { }); it("should leave encounter without battle", async () => { - game.override.startingHeldItems([{name: "GRIP_CLAW", count: 1}]); + game.override.startingHeldItems([{ name: "GRIP_CLAW", count: 1 }]); const leaveEncounterWithoutBattleSpy = vi.spyOn(encounterPhaseUtils, "leaveEncounterWithoutBattle"); - await game.runToMysteryEncounter(MysteryEncounterType.BUG_TYPE_SUPERFAN, [Species.BUTTERFREE]); + await game.runToMysteryEncounter(MysteryEncounterType.BUG_TYPE_SUPERFAN, [ Species.BUTTERFREE ]); await runMysteryEncounterToEnd(game, 3, { pokemonNo: 1, optionNo: 1 }); expect(leaveEncounterWithoutBattleSpy).toBeCalled(); diff --git a/src/test/mystery-encounter/encounters/clowning-around-encounter.test.ts b/src/test/mystery-encounter/encounters/clowning-around-encounter.test.ts index 383e3bd3564..a403a306b3d 100644 --- a/src/test/mystery-encounter/encounters/clowning-around-encounter.test.ts +++ b/src/test/mystery-encounter/encounters/clowning-around-encounter.test.ts @@ -27,14 +27,14 @@ import OptionSelectUiHandler from "#app/ui/settings/option-select-ui-handler"; import { modifierTypes, PokemonHeldItemModifierType } from "#app/modifier/modifier-type"; import { BerryType } from "#enums/berry-type"; import { PokemonHeldItemModifier } from "#app/modifier/modifier"; -import { Type } from "#app/data/type"; +import { Type } from "#enums/type"; import { CommandPhase } from "#app/phases/command-phase"; import { MovePhase } from "#app/phases/move-phase"; import { SelectModifierPhase } from "#app/phases/select-modifier-phase"; import { NewBattlePhase } from "#app/phases/new-battle-phase"; -const namespace = "mysteryEncounter:clowningAround"; -const defaultParty = [Species.LAPRAS, Species.GENGAR, Species.ABRA]; +const namespace = "mysteryEncounters/clowningAround"; +const defaultParty = [ Species.LAPRAS, Species.GENGAR, Species.ABRA ]; const defaultBiome = Biome.CAVE; const defaultWave = 45; @@ -57,7 +57,7 @@ describe("Clowning Around - Mystery Encounter", () => { vi.spyOn(MysteryEncounters, "mysteryEncountersByBiome", "get").mockReturnValue( new Map([ - [Biome.CAVE, [MysteryEncounterType.CLOWNING_AROUND]], + [ Biome.CAVE, [ MysteryEncounterType.CLOWNING_AROUND ]], ]) ); }); @@ -75,15 +75,15 @@ describe("Clowning Around - Mystery Encounter", () => { expect(ClowningAroundEncounter.encounterTier).toBe(MysteryEncounterTier.ULTRA); expect(ClowningAroundEncounter.dialogue).toBeDefined(); expect(ClowningAroundEncounter.dialogue.intro).toStrictEqual([ - { text: `${namespace}.intro` }, + { text: `${namespace}:intro` }, { - speaker: `${namespace}.speaker`, - text: `${namespace}.intro_dialogue`, + speaker: `${namespace}:speaker`, + text: `${namespace}:intro_dialogue`, }, ]); - expect(ClowningAroundEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}.title`); - expect(ClowningAroundEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}.description`); - expect(ClowningAroundEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}.query`); + expect(ClowningAroundEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}:title`); + expect(ClowningAroundEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}:description`); + expect(ClowningAroundEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}:query`); expect(ClowningAroundEncounter.options.length).toBe(3); }); @@ -95,14 +95,6 @@ describe("Clowning Around - Mystery Encounter", () => { expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.CLOWNING_AROUND); }); - it("should not run above wave 179", async () => { - game.override.startingWave(181); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle.mysteryEncounter).toBeUndefined(); - }); - it("should initialize fully", async () => { initSceneWithoutEncounterPhase(scene, defaultParty); scene.currentBattle.mysteryEncounter = ClowningAroundEncounter; @@ -122,15 +114,15 @@ describe("Clowning Around - Mystery Encounter", () => { expect(config.pokemonConfigs?.[0]).toEqual({ species: getPokemonSpecies(Species.MR_MIME), isBoss: true, - moveSet: [Moves.TEETER_DANCE, Moves.ALLY_SWITCH, Moves.DAZZLING_GLEAM, Moves.PSYCHIC] + moveSet: [ Moves.TEETER_DANCE, Moves.ALLY_SWITCH, Moves.DAZZLING_GLEAM, Moves.PSYCHIC ] }); expect(config.pokemonConfigs?.[1]).toEqual({ species: getPokemonSpecies(Species.BLACEPHALON), - mysteryEncounterPokemonData: expect.anything(), + customPokemonData: expect.anything(), isBoss: true, - moveSet: [Moves.TRICK, Moves.HYPNOSIS, Moves.SHADOW_BALL, Moves.MIND_BLOWN] + moveSet: [ Moves.TRICK, Moves.HYPNOSIS, Moves.SHADOW_BALL, Moves.MIND_BLOWN ] }); - expect(config.pokemonConfigs?.[1].mysteryEncounterPokemonData?.types.length).toBe(2); + expect(config.pokemonConfigs?.[1].customPokemonData?.types.length).toBe(2); expect([ Abilities.STURDY, Abilities.PICKUP, @@ -147,8 +139,8 @@ describe("Clowning Around - Mystery Encounter", () => { Abilities.MAGICIAN, Abilities.SHEER_FORCE, Abilities.PRANKSTER - ]).toContain(config.pokemonConfigs?.[1].mysteryEncounterPokemonData?.ability); - expect(ClowningAroundEncounter.misc.ability).toBe(config.pokemonConfigs?.[1].mysteryEncounterPokemonData?.ability); + ]).toContain(config.pokemonConfigs?.[1].customPokemonData?.ability); + expect(ClowningAroundEncounter.misc.ability).toBe(config.pokemonConfigs?.[1].customPokemonData?.ability); await vi.waitFor(() => expect(moveInitSpy).toHaveBeenCalled()); await vi.waitFor(() => expect(moveLoadSpy).toHaveBeenCalled()); expect(onInitResult).toBe(true); @@ -160,12 +152,12 @@ describe("Clowning Around - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - speaker: `${namespace}.speaker`, - text: `${namespace}.option.1.selected`, + speaker: `${namespace}:speaker`, + text: `${namespace}:option.1.selected`, }, ], }); @@ -181,9 +173,9 @@ describe("Clowning Around - Mystery Encounter", () => { expect(scene.getCurrentPhase()?.constructor.name).toBe(CommandPhase.name); expect(enemyField.length).toBe(2); expect(enemyField[0].species.speciesId).toBe(Species.MR_MIME); - expect(enemyField[0].moveset).toEqual([new PokemonMove(Moves.TEETER_DANCE), new PokemonMove(Moves.ALLY_SWITCH), new PokemonMove(Moves.DAZZLING_GLEAM), new PokemonMove(Moves.PSYCHIC)]); + expect(enemyField[0].moveset).toEqual([ new PokemonMove(Moves.TEETER_DANCE), new PokemonMove(Moves.ALLY_SWITCH), new PokemonMove(Moves.DAZZLING_GLEAM), new PokemonMove(Moves.PSYCHIC) ]); expect(enemyField[1].species.speciesId).toBe(Species.BLACEPHALON); - expect(enemyField[1].moveset).toEqual([new PokemonMove(Moves.TRICK), new PokemonMove(Moves.HYPNOSIS), new PokemonMove(Moves.SHADOW_BALL), new PokemonMove(Moves.MIND_BLOWN)]); + expect(enemyField[1].moveset).toEqual([ new PokemonMove(Moves.TRICK), new PokemonMove(Moves.HYPNOSIS), new PokemonMove(Moves.SHADOW_BALL), new PokemonMove(Moves.MIND_BLOWN) ]); // Should have used moves pre-battle const movePhases = phaseSpy.mock.calls.filter(p => p[0] instanceof MovePhase).map(p => p[0]); @@ -226,8 +218,8 @@ describe("Clowning Around - Mystery Encounter", () => { // Stop next battle before it runs await game.phaseInterceptor.to(NewBattlePhase, false); - const leadPokemon = scene.getParty()[0]; - expect(leadPokemon.mysteryEncounterPokemonData?.ability).toBe(abilityToTrain); + const leadPokemon = scene.getPlayerParty()[0]; + expect(leadPokemon.customPokemonData?.ability).toBe(abilityToTrain); }); }); @@ -237,19 +229,19 @@ describe("Clowning Around - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, selected: [ { - speaker: `${namespace}.speaker`, - text: `${namespace}.option.2.selected`, + speaker: `${namespace}:speaker`, + text: `${namespace}:option.2.selected`, }, { - text: `${namespace}.option.2.selected_2`, + text: `${namespace}:option.2.selected_2`, }, { - speaker: `${namespace}.speaker`, - text: `${namespace}.option.2.selected_3`, + speaker: `${namespace}:speaker`, + text: `${namespace}:option.2.selected_3`, }, ], }); @@ -259,35 +251,35 @@ describe("Clowning Around - Mystery Encounter", () => { await game.runToMysteryEncounter(MysteryEncounterType.CLOWNING_AROUND, defaultParty); // Set some moves on party for attack type booster generation - scene.getParty()[0].moveset = [new PokemonMove(Moves.TACKLE), new PokemonMove(Moves.THIEF)]; + scene.getPlayerParty()[0].moveset = [ new PokemonMove(Moves.TACKLE), new PokemonMove(Moves.THIEF) ]; // 2 Sitrus Berries on lead scene.modifiers = []; - let itemType = generateModifierType(scene, modifierTypes.BERRY, [BerryType.SITRUS]) as PokemonHeldItemModifierType; - await addItemToPokemon(scene, scene.getParty()[0], 2, itemType); + let itemType = generateModifierType(scene, modifierTypes.BERRY, [ BerryType.SITRUS ]) as PokemonHeldItemModifierType; + await addItemToPokemon(scene, scene.getPlayerParty()[0], 2, itemType); // 2 Ganlon Berries on lead - itemType = generateModifierType(scene, modifierTypes.BERRY, [BerryType.GANLON]) as PokemonHeldItemModifierType; - await addItemToPokemon(scene, scene.getParty()[0], 2, itemType); + itemType = generateModifierType(scene, modifierTypes.BERRY, [ BerryType.GANLON ]) as PokemonHeldItemModifierType; + await addItemToPokemon(scene, scene.getPlayerParty()[0], 2, itemType); // 5 Golden Punch on lead (ultra) itemType = generateModifierType(scene, modifierTypes.GOLDEN_PUNCH) as PokemonHeldItemModifierType; - await addItemToPokemon(scene, scene.getParty()[0], 5, itemType); + await addItemToPokemon(scene, scene.getPlayerParty()[0], 5, itemType); // 5 Lucky Egg on lead (ultra) itemType = generateModifierType(scene, modifierTypes.LUCKY_EGG) as PokemonHeldItemModifierType; - await addItemToPokemon(scene, scene.getParty()[0], 5, itemType); + await addItemToPokemon(scene, scene.getPlayerParty()[0], 5, itemType); // 5 Soul Dew on lead (rogue) itemType = generateModifierType(scene, modifierTypes.SOUL_DEW) as PokemonHeldItemModifierType; - await addItemToPokemon(scene, scene.getParty()[0], 5, itemType); + await addItemToPokemon(scene, scene.getPlayerParty()[0], 5, itemType); // 2 Golden Egg on lead (rogue) itemType = generateModifierType(scene, modifierTypes.GOLDEN_EGG) as PokemonHeldItemModifierType; - await addItemToPokemon(scene, scene.getParty()[0], 2, itemType); + await addItemToPokemon(scene, scene.getPlayerParty()[0], 2, itemType); // 5 Soul Dew on second party pokemon (these should not change) itemType = generateModifierType(scene, modifierTypes.SOUL_DEW) as PokemonHeldItemModifierType; - await addItemToPokemon(scene, scene.getParty()[1], 5, itemType); + await addItemToPokemon(scene, scene.getPlayerParty()[1], 5, itemType); await runMysteryEncounterToEnd(game, 2); - const leadItemsAfter = scene.getParty()[0].getHeldItems(); + const leadItemsAfter = scene.getPlayerParty()[0].getHeldItems(); const ultraCountAfter = leadItemsAfter .filter(m => m.type.tier === ModifierTier.ULTRA) .reduce((a, b) => a + b.stackCount, 0); @@ -297,7 +289,7 @@ describe("Clowning Around - Mystery Encounter", () => { expect(ultraCountAfter).toBe(10); expect(rogueCountAfter).toBe(7); - const secondItemsAfter = scene.getParty()[1].getHeldItems(); + const secondItemsAfter = scene.getPlayerParty()[1].getHeldItems(); expect(secondItemsAfter.length).toBe(1); expect(secondItemsAfter[0].type.id).toBe("SOUL_DEW"); expect(secondItemsAfter[0]?.stackCount).toBe(5); @@ -319,19 +311,19 @@ describe("Clowning Around - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, selected: [ { - speaker: `${namespace}.speaker`, - text: `${namespace}.option.3.selected`, + speaker: `${namespace}:speaker`, + text: `${namespace}:option.3.selected`, }, { - text: `${namespace}.option.3.selected_2`, + text: `${namespace}:option.3.selected_2`, }, { - speaker: `${namespace}.speaker`, - text: `${namespace}.option.3.selected_3`, + speaker: `${namespace}:speaker`, + text: `${namespace}:option.3.selected_3`, }, ], }); @@ -341,24 +333,24 @@ describe("Clowning Around - Mystery Encounter", () => { await game.runToMysteryEncounter(MysteryEncounterType.CLOWNING_AROUND, defaultParty); // Same type moves on lead - scene.getParty()[0].moveset = [new PokemonMove(Moves.ICE_BEAM), new PokemonMove(Moves.SURF)]; + scene.getPlayerParty()[0].moveset = [ new PokemonMove(Moves.ICE_BEAM), new PokemonMove(Moves.SURF) ]; // Different type moves on second - scene.getParty()[1].moveset = [new PokemonMove(Moves.GRASS_KNOT), new PokemonMove(Moves.ELECTRO_BALL)]; + scene.getPlayerParty()[1].moveset = [ new PokemonMove(Moves.GRASS_KNOT), new PokemonMove(Moves.ELECTRO_BALL) ]; // No moves on third - scene.getParty()[2].moveset = []; + scene.getPlayerParty()[2].moveset = []; await runMysteryEncounterToEnd(game, 3); - const leadTypesAfter = scene.getParty()[0].mysteryEncounterPokemonData?.types; - const secondaryTypesAfter = scene.getParty()[1].mysteryEncounterPokemonData?.types; - const thirdTypesAfter = scene.getParty()[2].mysteryEncounterPokemonData?.types; + const leadTypesAfter = scene.getPlayerParty()[0].customPokemonData?.types; + const secondaryTypesAfter = scene.getPlayerParty()[1].customPokemonData?.types; + const thirdTypesAfter = scene.getPlayerParty()[2].customPokemonData?.types; expect(leadTypesAfter.length).toBe(2); expect(leadTypesAfter[0]).toBe(Type.WATER); - expect([Type.WATER, Type.ICE].includes(leadTypesAfter[1])).toBeFalsy(); + expect([ Type.WATER, Type.ICE ].includes(leadTypesAfter[1])).toBeFalsy(); expect(secondaryTypesAfter.length).toBe(2); expect(secondaryTypesAfter[0]).toBe(Type.GHOST); - expect([Type.GHOST, Type.POISON].includes(secondaryTypesAfter[1])).toBeFalsy(); - expect([Type.GRASS, Type.ELECTRIC].includes(secondaryTypesAfter[1])).toBeTruthy(); + expect([ Type.GHOST, Type.POISON ].includes(secondaryTypesAfter[1])).toBeFalsy(); + expect([ Type.GRASS, Type.ELECTRIC ].includes(secondaryTypesAfter[1])).toBeTruthy(); expect(thirdTypesAfter.length).toBe(2); expect(thirdTypesAfter[0]).toBe(Type.PSYCHIC); expect(secondaryTypesAfter[1]).not.toBe(Type.PSYCHIC); diff --git a/src/test/mystery-encounter/encounters/dancing-lessons-encounter.test.ts b/src/test/mystery-encounter/encounters/dancing-lessons-encounter.test.ts index 5a2512ddaf6..147930f05d1 100644 --- a/src/test/mystery-encounter/encounters/dancing-lessons-encounter.test.ts +++ b/src/test/mystery-encounter/encounters/dancing-lessons-encounter.test.ts @@ -20,8 +20,8 @@ import { MovePhase } from "#app/phases/move-phase"; import { SelectModifierPhase } from "#app/phases/select-modifier-phase"; import { LearnMovePhase } from "#app/phases/learn-move-phase"; -const namespace = "mysteryEncounter:dancingLessons"; -const defaultParty = [Species.LAPRAS, Species.GENGAR, Species.ABRA]; +const namespace = "mysteryEncounters/dancingLessons"; +const defaultParty = [ Species.LAPRAS, Species.GENGAR, Species.ABRA ]; const defaultBiome = Biome.PLAINS; const defaultWave = 45; @@ -44,8 +44,8 @@ describe("Dancing Lessons - Mystery Encounter", () => { vi.spyOn(MysteryEncounters, "mysteryEncountersByBiome", "get").mockReturnValue( new Map([ - [Biome.PLAINS, [MysteryEncounterType.DANCING_LESSONS]], - [Biome.SPACE, [MysteryEncounterType.MYSTERIOUS_CHALLENGERS]], + [ Biome.PLAINS, [ MysteryEncounterType.DANCING_LESSONS ]], + [ Biome.SPACE, [ MysteryEncounterType.MYSTERIOUS_CHALLENGERS ]], ]) ); }); @@ -62,29 +62,13 @@ describe("Dancing Lessons - Mystery Encounter", () => { expect(DancingLessonsEncounter.encounterType).toBe(MysteryEncounterType.DANCING_LESSONS); expect(DancingLessonsEncounter.encounterTier).toBe(MysteryEncounterTier.GREAT); expect(DancingLessonsEncounter.dialogue).toBeDefined(); - expect(DancingLessonsEncounter.dialogue.intro).toStrictEqual([{ text: `${namespace}.intro` }]); - expect(DancingLessonsEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}.title`); - expect(DancingLessonsEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}.description`); - expect(DancingLessonsEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}.query`); + expect(DancingLessonsEncounter.dialogue.intro).toStrictEqual([{ text: `${namespace}:intro` }]); + expect(DancingLessonsEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}:title`); + expect(DancingLessonsEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}:description`); + expect(DancingLessonsEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}:query`); expect(DancingLessonsEncounter.options.length).toBe(3); }); - it("should not run below wave 10", async () => { - game.override.startingWave(9); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.DANCING_LESSONS); - }); - - it("should not run above wave 179", async () => { - game.override.startingWave(181); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle.mysteryEncounter).toBeUndefined(); - }); - it("should not spawn outside of proper biomes", async () => { game.override.mysteryEncounterTier(MysteryEncounterTier.GREAT); game.override.startingBiome(Biome.SPACE); @@ -99,11 +83,11 @@ describe("Dancing Lessons - Mystery Encounter", () => { expect(option1.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option1.dialogue).toBeDefined(); expect(option1.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.1.selected`, + text: `${namespace}:option.1.selected`, }, ], }); @@ -114,7 +98,7 @@ describe("Dancing Lessons - Mystery Encounter", () => { await game.runToMysteryEncounter(MysteryEncounterType.DANCING_LESSONS, defaultParty); // Make party lead's level arbitrarily high to not get KOed by move - const partyLead = scene.getParty()[0]; + const partyLead = scene.getPlayerParty()[0]; partyLead.level = 1000; partyLead.calculateStats(); await runMysteryEncounterToEnd(game, 1, undefined, true); @@ -123,7 +107,7 @@ describe("Dancing Lessons - Mystery Encounter", () => { expect(scene.getCurrentPhase()?.constructor.name).toBe(CommandPhase.name); expect(enemyField.length).toBe(1); expect(enemyField[0].species.speciesId).toBe(Species.ORICORIO); - expect(enemyField[0].summonData.statStages).toEqual([1, 1, 1, 1, 0, 0, 0]); + expect(enemyField[0].summonData.statStages).toEqual([ 1, 1, 1, 1, 0, 0, 0 ]); const moveset = enemyField[0].moveset.map(m => m?.moveId); expect(moveset.some(m => m === Moves.REVELATION_DANCE)).toBeTruthy(); @@ -135,7 +119,7 @@ describe("Dancing Lessons - Mystery Encounter", () => { it("should have a Baton in the rewards after battle", async () => { await game.runToMysteryEncounter(MysteryEncounterType.DANCING_LESSONS, defaultParty); // Make party lead's level arbitrarily high to not get KOed by move - const partyLead = scene.getParty()[0]; + const partyLead = scene.getPlayerParty()[0]; partyLead.level = 1000; partyLead.calculateStats(); await runMysteryEncounterToEnd(game, 1, undefined, true); @@ -159,11 +143,11 @@ describe("Dancing Lessons - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, selected: [ { - text: `${namespace}.option.2.selected`, + text: `${namespace}:option.2.selected`, }, ], }); @@ -173,7 +157,7 @@ describe("Dancing Lessons - Mystery Encounter", () => { const phaseSpy = vi.spyOn(scene, "unshiftPhase"); await game.runToMysteryEncounter(MysteryEncounterType.DANCING_LESSONS, defaultParty); - scene.getParty()[0].moveset = []; + scene.getPlayerParty()[0].moveset = []; await runMysteryEncounterToEnd(game, 2, { pokemonNo: 1 }); const movePhases = phaseSpy.mock.calls.filter(p => p[0] instanceof LearnMovePhase).map(p => p[0]); @@ -185,7 +169,7 @@ describe("Dancing Lessons - Mystery Encounter", () => { const leaveEncounterWithoutBattleSpy = vi.spyOn(EncounterPhaseUtils, "leaveEncounterWithoutBattle"); await game.runToMysteryEncounter(MysteryEncounterType.DANCING_LESSONS, defaultParty); - scene.getParty()[0].moveset = []; + scene.getPlayerParty()[0].moveset = []; await runMysteryEncounterToEnd(game, 2, { pokemonNo: 1 }); expect(leaveEncounterWithoutBattleSpy).toBeCalled(); @@ -198,13 +182,13 @@ describe("Dancing Lessons - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DISABLED_OR_SPECIAL); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, - disabledButtonTooltip: `${namespace}.option.3.disabled_tooltip`, - secondOptionPrompt: `${namespace}.option.3.select_prompt`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, + disabledButtonTooltip: `${namespace}:option.3.disabled_tooltip`, + secondOptionPrompt: `${namespace}:option.3.select_prompt`, selected: [ { - text: `${namespace}.option.3.selected`, + text: `${namespace}:option.3.selected`, }, ], }); @@ -212,13 +196,13 @@ describe("Dancing Lessons - Mystery Encounter", () => { it("should add Oricorio to the party", async () => { await game.runToMysteryEncounter(MysteryEncounterType.DANCING_LESSONS, defaultParty); - const partyCountBefore = scene.getParty().length; - scene.getParty()[0].moveset = [new PokemonMove(Moves.DRAGON_DANCE)]; - await runMysteryEncounterToEnd(game, 3, {pokemonNo: 1, optionNo: 1}); - const partyCountAfter = scene.getParty().length; + const partyCountBefore = scene.getPlayerParty().length; + scene.getPlayerParty()[0].moveset = [ new PokemonMove(Moves.DRAGON_DANCE) ]; + await runMysteryEncounterToEnd(game, 3, { pokemonNo: 1, optionNo: 1 }); + const partyCountAfter = scene.getPlayerParty().length; expect(partyCountBefore + 1).toBe(partyCountAfter); - const oricorio = scene.getParty()[scene.getParty().length - 1]; + const oricorio = scene.getPlayerParty()[scene.getPlayerParty().length - 1]; expect(oricorio.species.speciesId).toBe(Species.ORICORIO); const moveset = oricorio.moveset.map(m => m?.moveId); expect(moveset?.some(m => m === Moves.REVELATION_DANCE)).toBeTruthy(); @@ -227,8 +211,8 @@ describe("Dancing Lessons - Mystery Encounter", () => { it("should NOT be selectable if the player doesn't have a Dance type move", async () => { await game.runToMysteryEncounter(MysteryEncounterType.DANCING_LESSONS, defaultParty); - const partyCountBefore = scene.getParty().length; - scene.getParty().forEach(p => p.moveset = []); + const partyCountBefore = scene.getPlayerParty().length; + scene.getPlayerParty().forEach(p => p.moveset = []); await game.phaseInterceptor.to(MysteryEncounterPhase, false); const encounterPhase = scene.getCurrentPhase(); @@ -239,7 +223,7 @@ describe("Dancing Lessons - Mystery Encounter", () => { vi.spyOn(scene.ui, "playError"); await runSelectMysteryEncounterOption(game, 3); - const partyCountAfter = scene.getParty().length; + const partyCountAfter = scene.getPlayerParty().length; expect(scene.getCurrentPhase()?.constructor.name).toBe(MysteryEncounterPhase.name); expect(scene.ui.playError).not.toHaveBeenCalled(); // No error sfx, option is disabled @@ -252,8 +236,8 @@ describe("Dancing Lessons - Mystery Encounter", () => { const leaveEncounterWithoutBattleSpy = vi.spyOn(EncounterPhaseUtils, "leaveEncounterWithoutBattle"); await game.runToMysteryEncounter(MysteryEncounterType.DANCING_LESSONS, defaultParty); - scene.getParty()[0].moveset = [new PokemonMove(Moves.DRAGON_DANCE)]; - await runMysteryEncounterToEnd(game, 3, {pokemonNo: 1, optionNo: 1}); + scene.getPlayerParty()[0].moveset = [ new PokemonMove(Moves.DRAGON_DANCE) ]; + await runMysteryEncounterToEnd(game, 3, { pokemonNo: 1, optionNo: 1 }); expect(leaveEncounterWithoutBattleSpy).toBeCalled(); }); diff --git a/src/test/mystery-encounter/encounters/delibirdy-encounter.test.ts b/src/test/mystery-encounter/encounters/delibirdy-encounter.test.ts index 969188dca06..c226d60a9b4 100644 --- a/src/test/mystery-encounter/encounters/delibirdy-encounter.test.ts +++ b/src/test/mystery-encounter/encounters/delibirdy-encounter.test.ts @@ -11,14 +11,14 @@ import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; import { DelibirdyEncounter } from "#app/data/mystery-encounters/encounters/delibirdy-encounter"; import * as MysteryEncounters from "#app/data/mystery-encounters/mystery-encounters"; import { MoneyRequirement } from "#app/data/mystery-encounters/mystery-encounter-requirements"; -import { BerryModifier, HealingBoosterModifier, HiddenAbilityRateBoosterModifier, HitHealModifier, LevelIncrementBoosterModifier, PokemonInstantReviveModifier, PokemonNatureWeightModifier, PreserveBerryModifier } from "#app/modifier/modifier"; +import { BerryModifier, HealingBoosterModifier, HitHealModifier, LevelIncrementBoosterModifier, MoneyMultiplierModifier, PokemonInstantReviveModifier, PokemonNatureWeightModifier, PreserveBerryModifier } from "#app/modifier/modifier"; import { MysteryEncounterPhase } from "#app/phases/mystery-encounter-phases"; import { generateModifierType } from "#app/data/mystery-encounters/utils/encounter-phase-utils"; import { modifierTypes } from "#app/modifier/modifier-type"; import { BerryType } from "#enums/berry-type"; -const namespace = "mysteryEncounter:delibirdy"; -const defaultParty = [Species.LAPRAS, Species.GENGAR, Species.ABRA]; +const namespace = "mysteryEncounters/delibirdy"; +const defaultParty = [ Species.LAPRAS, Species.GENGAR, Species.ABRA ]; const defaultBiome = Biome.CAVE; const defaultWave = 45; @@ -41,7 +41,7 @@ describe("Delibird-y - Mystery Encounter", () => { vi.spyOn(MysteryEncounters, "mysteryEncountersByBiome", "get").mockReturnValue( new Map([ - [Biome.CAVE, [MysteryEncounterType.DELIBIRDY]], + [ Biome.CAVE, [ MysteryEncounterType.DELIBIRDY ]], ]) ); }); @@ -58,30 +58,14 @@ describe("Delibird-y - Mystery Encounter", () => { expect(DelibirdyEncounter.encounterType).toBe(MysteryEncounterType.DELIBIRDY); expect(DelibirdyEncounter.encounterTier).toBe(MysteryEncounterTier.GREAT); expect(DelibirdyEncounter.dialogue).toBeDefined(); - expect(DelibirdyEncounter.dialogue.intro).toStrictEqual([{ text: `${namespace}.intro` }]); - expect(DelibirdyEncounter.dialogue.outro).toStrictEqual([{ text: `${namespace}.outro` }]); - expect(DelibirdyEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}.title`); - expect(DelibirdyEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}.description`); - expect(DelibirdyEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}.query`); + expect(DelibirdyEncounter.dialogue.intro).toStrictEqual([{ text: `${namespace}:intro` }]); + expect(DelibirdyEncounter.dialogue.outro).toStrictEqual([{ text: `${namespace}:outro` }]); + expect(DelibirdyEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}:title`); + expect(DelibirdyEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}:description`); + expect(DelibirdyEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}:query`); expect(DelibirdyEncounter.options.length).toBe(3); }); - it("should not run below wave 10", async () => { - game.override.startingWave(9); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.DELIBIRDY); - }); - - it("should not run above wave 179", async () => { - game.override.startingWave(181); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle.mysteryEncounter).toBeUndefined(); - }); - it("should not spawn if player does not have enough money", async () => { scene.money = 0; @@ -96,11 +80,11 @@ describe("Delibird-y - Mystery Encounter", () => { expect(option1.optionMode).toBe(MysteryEncounterOptionMode.DISABLED_OR_DEFAULT); expect(option1.dialogue).toBeDefined(); expect(option1.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.1.selected`, + text: `${namespace}:option.1.selected`, }, ], }); @@ -120,35 +104,35 @@ describe("Delibird-y - Mystery Encounter", () => { expect(scene.money).toBe(initialMoney - price); }); - it("Should give the player a Hidden Ability Charm", async () => { + it("Should give the player an Amulet Coin", async () => { scene.money = 200000; await game.runToMysteryEncounter(MysteryEncounterType.DELIBIRDY, defaultParty); await runMysteryEncounterToEnd(game, 1); - const itemModifier = scene.findModifier(m => m instanceof HiddenAbilityRateBoosterModifier) as HiddenAbilityRateBoosterModifier; + const itemModifier = scene.findModifier(m => m instanceof MoneyMultiplierModifier) as MoneyMultiplierModifier; expect(itemModifier).toBeDefined(); expect(itemModifier?.stackCount).toBe(1); }); - it("Should give the player a Shell Bell if they have max stacks of Berry Pouches", async () => { + it("Should give the player a Shell Bell if they have max stacks of Amulet Coins", async () => { scene.money = 200000; await game.runToMysteryEncounter(MysteryEncounterType.DELIBIRDY, defaultParty); - // 5 Healing Charms + // Max Amulet Coins scene.modifiers = []; - const abilityCharm = generateModifierType(scene, modifierTypes.ABILITY_CHARM)!.newModifier() as HiddenAbilityRateBoosterModifier; - abilityCharm.stackCount = 4; - await scene.addModifier(abilityCharm, true, false, false, true); + const amuletCoin = generateModifierType(scene, modifierTypes.AMULET_COIN)!.newModifier() as MoneyMultiplierModifier; + amuletCoin.stackCount = 5; + await scene.addModifier(amuletCoin, true, false, false, true); await scene.updateModifiers(true); await runMysteryEncounterToEnd(game, 1); - const abilityCharmAfter = scene.findModifier(m => m instanceof HiddenAbilityRateBoosterModifier); + const amuletCoinAfter = scene.findModifier(m => m instanceof MoneyMultiplierModifier); const shellBellAfter = scene.findModifier(m => m instanceof HitHealModifier); - expect(abilityCharmAfter).toBeDefined(); - expect(abilityCharmAfter?.stackCount).toBe(4); + expect(amuletCoinAfter).toBeDefined(); + expect(amuletCoinAfter?.stackCount).toBe(5); expect(shellBellAfter).toBeDefined(); expect(shellBellAfter?.stackCount).toBe(1); }); @@ -190,12 +174,12 @@ describe("Delibird-y - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DISABLED_OR_DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, - secondOptionPrompt: `${namespace}.option.2.select_prompt`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, + secondOptionPrompt: `${namespace}:option.2.select_prompt`, selected: [ { - text: `${namespace}.option.2.selected`, + text: `${namespace}:option.2.selected`, }, ], }); @@ -206,13 +190,13 @@ describe("Delibird-y - Mystery Encounter", () => { // Set 2 Sitrus berries on party lead scene.modifiers = []; - const sitrus = generateModifierType(scene, modifierTypes.BERRY, [BerryType.SITRUS])!; - const sitrusMod = sitrus.newModifier(scene.getParty()[0]) as BerryModifier; + const sitrus = generateModifierType(scene, modifierTypes.BERRY, [ BerryType.SITRUS ])!; + const sitrusMod = sitrus.newModifier(scene.getPlayerParty()[0]) as BerryModifier; sitrusMod.stackCount = 2; await scene.addModifier(sitrusMod, true, false, false, true); await scene.updateModifiers(true); - await runMysteryEncounterToEnd(game, 2, { pokemonNo: 1, optionNo: 1}); + await runMysteryEncounterToEnd(game, 2, { pokemonNo: 1, optionNo: 1 }); const sitrusAfter = scene.findModifier(m => m instanceof BerryModifier); const candyJarAfter = scene.findModifier(m => m instanceof LevelIncrementBoosterModifier); @@ -222,25 +206,25 @@ describe("Delibird-y - Mystery Encounter", () => { expect(candyJarAfter?.stackCount).toBe(1); }); - it("Should remove Reviver Seed and give the player a Healing Charm", async () => { + it("Should remove Reviver Seed and give the player a Berry Pouch", async () => { await game.runToMysteryEncounter(MysteryEncounterType.DELIBIRDY, defaultParty); // Set 1 Reviver Seed on party lead scene.modifiers = []; const revSeed = generateModifierType(scene, modifierTypes.REVIVER_SEED)!; - const modifier = revSeed.newModifier(scene.getParty()[0]) as PokemonInstantReviveModifier; + const modifier = revSeed.newModifier(scene.getPlayerParty()[0]) as PokemonInstantReviveModifier; modifier.stackCount = 1; await scene.addModifier(modifier, true, false, false, true); await scene.updateModifiers(true); - await runMysteryEncounterToEnd(game, 2, { pokemonNo: 1, optionNo: 1}); + await runMysteryEncounterToEnd(game, 2, { pokemonNo: 1, optionNo: 1 }); const reviverSeedAfter = scene.findModifier(m => m instanceof PokemonInstantReviveModifier); - const healingCharmAfter = scene.findModifier(m => m instanceof HealingBoosterModifier); + const berryPouchAfter = scene.findModifier(m => m instanceof PreserveBerryModifier); expect(reviverSeedAfter).toBeUndefined(); - expect(healingCharmAfter).toBeDefined(); - expect(healingCharmAfter?.stackCount).toBe(1); + expect(berryPouchAfter).toBeDefined(); + expect(berryPouchAfter?.stackCount).toBe(1); }); it("Should give the player a Shell Bell if they have max stacks of Candy Jars", async () => { @@ -251,15 +235,15 @@ describe("Delibird-y - Mystery Encounter", () => { const candyJar = generateModifierType(scene, modifierTypes.CANDY_JAR)!.newModifier() as LevelIncrementBoosterModifier; candyJar.stackCount = 99; await scene.addModifier(candyJar, true, false, false, true); - const sitrus = generateModifierType(scene, modifierTypes.BERRY, [BerryType.SITRUS])!; + const sitrus = generateModifierType(scene, modifierTypes.BERRY, [ BerryType.SITRUS ])!; // Sitrus berries on party - const sitrusMod = sitrus.newModifier(scene.getParty()[0]) as BerryModifier; + const sitrusMod = sitrus.newModifier(scene.getPlayerParty()[0]) as BerryModifier; sitrusMod.stackCount = 2; await scene.addModifier(sitrusMod, true, false, false, true); await scene.updateModifiers(true); - await runMysteryEncounterToEnd(game, 2, { pokemonNo: 1, optionNo: 1}); + await runMysteryEncounterToEnd(game, 2, { pokemonNo: 1, optionNo: 1 }); const sitrusAfter = scene.findModifier(m => m instanceof BerryModifier); const candyJarAfter = scene.findModifier(m => m instanceof LevelIncrementBoosterModifier); @@ -272,31 +256,31 @@ describe("Delibird-y - Mystery Encounter", () => { expect(shellBellAfter?.stackCount).toBe(1); }); - it("Should give the player a Shell Bell if they have max stacks of Healing Charms", async () => { + it("Should give the player a Shell Bell if they have max stacks of Berry Pouches", async () => { await game.runToMysteryEncounter(MysteryEncounterType.DELIBIRDY, defaultParty); - // 5 Healing Charms + // 3 Berry Pouches scene.modifiers = []; - const healingCharm = generateModifierType(scene, modifierTypes.HEALING_CHARM)!.newModifier() as HealingBoosterModifier; - healingCharm.stackCount = 5; + const healingCharm = generateModifierType(scene, modifierTypes.BERRY_POUCH)!.newModifier() as PreserveBerryModifier; + healingCharm.stackCount = 3; await scene.addModifier(healingCharm, true, false, false, true); // Set 1 Reviver Seed on party lead const revSeed = generateModifierType(scene, modifierTypes.REVIVER_SEED)!; - const modifier = revSeed.newModifier(scene.getParty()[0]) as PokemonInstantReviveModifier; + const modifier = revSeed.newModifier(scene.getPlayerParty()[0]) as PokemonInstantReviveModifier; modifier.stackCount = 1; await scene.addModifier(modifier, true, false, false, true); await scene.updateModifiers(true); - await runMysteryEncounterToEnd(game, 2, { pokemonNo: 1, optionNo: 1}); + await runMysteryEncounterToEnd(game, 2, { pokemonNo: 1, optionNo: 1 }); const reviverSeedAfter = scene.findModifier(m => m instanceof PokemonInstantReviveModifier); - const healingCharmAfter = scene.findModifier(m => m instanceof HealingBoosterModifier); + const healingCharmAfter = scene.findModifier(m => m instanceof PreserveBerryModifier); const shellBellAfter = scene.findModifier(m => m instanceof HitHealModifier); expect(reviverSeedAfter).toBeUndefined(); expect(healingCharmAfter).toBeDefined(); - expect(healingCharmAfter?.stackCount).toBe(5); + expect(healingCharmAfter?.stackCount).toBe(3); expect(shellBellAfter).toBeDefined(); expect(shellBellAfter?.stackCount).toBe(1); }); @@ -307,7 +291,7 @@ describe("Delibird-y - Mystery Encounter", () => { // Set 1 Soul Dew on party lead scene.modifiers = []; const soulDew = generateModifierType(scene, modifierTypes.SOUL_DEW)!; - const modifier = soulDew.newModifier(scene.getParty()[0]); + const modifier = soulDew.newModifier(scene.getPlayerParty()[0]); await scene.addModifier(modifier, true, false, false, true); await scene.updateModifiers(true); @@ -335,12 +319,12 @@ describe("Delibird-y - Mystery Encounter", () => { // Set 1 Reviver Seed on party lead const revSeed = generateModifierType(scene, modifierTypes.REVIVER_SEED)!; - const modifier = revSeed.newModifier(scene.getParty()[0]) as PokemonInstantReviveModifier; + const modifier = revSeed.newModifier(scene.getPlayerParty()[0]) as PokemonInstantReviveModifier; modifier.stackCount = 1; await scene.addModifier(modifier, true, false, false, true); await scene.updateModifiers(true); - await runMysteryEncounterToEnd(game, 2, { pokemonNo: 1, optionNo: 1}); + await runMysteryEncounterToEnd(game, 2, { pokemonNo: 1, optionNo: 1 }); expect(leaveEncounterWithoutBattleSpy).toBeCalled(); }); @@ -352,84 +336,84 @@ describe("Delibird-y - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DISABLED_OR_DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, - secondOptionPrompt: `${namespace}.option.3.select_prompt`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, + secondOptionPrompt: `${namespace}:option.3.select_prompt`, selected: [ { - text: `${namespace}.option.3.selected`, + text: `${namespace}:option.3.selected`, }, ], }); }); - it("Should decrease held item stacks and give the player a Berry Pouch", async () => { + it("Should decrease held item stacks and give the player a Healing Charm", async () => { await game.runToMysteryEncounter(MysteryEncounterType.DELIBIRDY, defaultParty); // Set 2 Soul Dew on party lead scene.modifiers = []; const soulDew = generateModifierType(scene, modifierTypes.SOUL_DEW)!; - const modifier = soulDew.newModifier(scene.getParty()[0]) as PokemonNatureWeightModifier; + const modifier = soulDew.newModifier(scene.getPlayerParty()[0]) as PokemonNatureWeightModifier; modifier.stackCount = 2; await scene.addModifier(modifier, true, false, false, true); await scene.updateModifiers(true); - await runMysteryEncounterToEnd(game, 3, { pokemonNo: 1, optionNo: 1}); + await runMysteryEncounterToEnd(game, 3, { pokemonNo: 1, optionNo: 1 }); const soulDewAfter = scene.findModifier(m => m instanceof PokemonNatureWeightModifier); - const berryPouchAfter = scene.findModifier(m => m instanceof PreserveBerryModifier); + const healingCharmAfter = scene.findModifier(m => m instanceof HealingBoosterModifier); expect(soulDewAfter?.stackCount).toBe(1); - expect(berryPouchAfter).toBeDefined(); - expect(berryPouchAfter?.stackCount).toBe(1); + expect(healingCharmAfter).toBeDefined(); + expect(healingCharmAfter?.stackCount).toBe(1); }); - it("Should remove held item and give the player a Berry Pouch", async () => { + it("Should remove held item and give the player a Healing Charm", async () => { await game.runToMysteryEncounter(MysteryEncounterType.DELIBIRDY, defaultParty); // Set 1 Soul Dew on party lead scene.modifiers = []; const soulDew = generateModifierType(scene, modifierTypes.SOUL_DEW)!; - const modifier = soulDew.newModifier(scene.getParty()[0]) as PokemonNatureWeightModifier; + const modifier = soulDew.newModifier(scene.getPlayerParty()[0]) as PokemonNatureWeightModifier; modifier.stackCount = 1; await scene.addModifier(modifier, true, false, false, true); await scene.updateModifiers(true); - await runMysteryEncounterToEnd(game, 3, { pokemonNo: 1, optionNo: 1}); + await runMysteryEncounterToEnd(game, 3, { pokemonNo: 1, optionNo: 1 }); const soulDewAfter = scene.findModifier(m => m instanceof PokemonNatureWeightModifier); - const berryPouchAfter = scene.findModifier(m => m instanceof PreserveBerryModifier); + const healingCharmAfter = scene.findModifier(m => m instanceof HealingBoosterModifier); expect(soulDewAfter).toBeUndefined(); - expect(berryPouchAfter).toBeDefined(); - expect(berryPouchAfter?.stackCount).toBe(1); + expect(healingCharmAfter).toBeDefined(); + expect(healingCharmAfter?.stackCount).toBe(1); }); - it("Should give the player a Shell Bell if they have max stacks of Berry Pouches", async () => { + it("Should give the player a Shell Bell if they have max stacks of Healing Charms", async () => { await game.runToMysteryEncounter(MysteryEncounterType.DELIBIRDY, defaultParty); // 5 Healing Charms scene.modifiers = []; - const healingCharm = generateModifierType(scene, modifierTypes.BERRY_POUCH)!.newModifier() as PreserveBerryModifier; - healingCharm.stackCount = 3; + const healingCharm = generateModifierType(scene, modifierTypes.HEALING_CHARM)!.newModifier() as HealingBoosterModifier; + healingCharm.stackCount = 5; await scene.addModifier(healingCharm, true, false, false, true); // Set 1 Soul Dew on party lead const soulDew = generateModifierType(scene, modifierTypes.SOUL_DEW)!; - const modifier = soulDew.newModifier(scene.getParty()[0]) as PokemonNatureWeightModifier; + const modifier = soulDew.newModifier(scene.getPlayerParty()[0]) as PokemonNatureWeightModifier; modifier.stackCount = 1; await scene.addModifier(modifier, true, false, false, true); await scene.updateModifiers(true); - await runMysteryEncounterToEnd(game, 3, { pokemonNo: 1, optionNo: 1}); + await runMysteryEncounterToEnd(game, 3, { pokemonNo: 1, optionNo: 1 }); const soulDewAfter = scene.findModifier(m => m instanceof PokemonNatureWeightModifier); - const berryPouchAfter = scene.findModifier(m => m instanceof PreserveBerryModifier); + const healingCharmAfter = scene.findModifier(m => m instanceof HealingBoosterModifier); const shellBellAfter = scene.findModifier(m => m instanceof HitHealModifier); expect(soulDewAfter).toBeUndefined(); - expect(berryPouchAfter).toBeDefined(); - expect(berryPouchAfter?.stackCount).toBe(3); + expect(healingCharmAfter).toBeDefined(); + expect(healingCharmAfter?.stackCount).toBe(5); expect(shellBellAfter).toBeDefined(); expect(shellBellAfter?.stackCount).toBe(1); }); @@ -440,7 +424,7 @@ describe("Delibird-y - Mystery Encounter", () => { // Set 1 Reviver Seed on party lead scene.modifiers = []; const revSeed = generateModifierType(scene, modifierTypes.REVIVER_SEED)!; - const modifier = revSeed.newModifier(scene.getParty()[0]); + const modifier = revSeed.newModifier(scene.getPlayerParty()[0]); await scene.addModifier(modifier, true, false, false, true); await scene.updateModifiers(true); @@ -469,12 +453,12 @@ describe("Delibird-y - Mystery Encounter", () => { // Set 1 Soul Dew on party lead scene.modifiers = []; const soulDew = generateModifierType(scene, modifierTypes.SOUL_DEW)!; - const modifier = soulDew.newModifier(scene.getParty()[0]) as PokemonNatureWeightModifier; + const modifier = soulDew.newModifier(scene.getPlayerParty()[0]) as PokemonNatureWeightModifier; modifier.stackCount = 1; await scene.addModifier(modifier, true, false, false, true); await scene.updateModifiers(true); - await runMysteryEncounterToEnd(game, 3, { pokemonNo: 1, optionNo: 1}); + await runMysteryEncounterToEnd(game, 3, { pokemonNo: 1, optionNo: 1 }); expect(leaveEncounterWithoutBattleSpy).toBeCalled(); }); diff --git a/src/test/mystery-encounter/encounters/department-store-sale-encounter.test.ts b/src/test/mystery-encounter/encounters/department-store-sale-encounter.test.ts index f22bd832964..1869a4d3c3c 100644 --- a/src/test/mystery-encounter/encounters/department-store-sale-encounter.test.ts +++ b/src/test/mystery-encounter/encounters/department-store-sale-encounter.test.ts @@ -15,8 +15,8 @@ import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; import { SelectModifierPhase } from "#app/phases/select-modifier-phase"; -const namespace = "mysteryEncounter:departmentStoreSale"; -const defaultParty = [Species.LAPRAS, Species.GENGAR, Species.ABRA]; +const namespace = "mysteryEncounters/departmentStoreSale"; +const defaultParty = [ Species.LAPRAS, Species.GENGAR, Species.ABRA ]; const defaultBiome = Biome.PLAINS; const defaultWave = 37; @@ -38,10 +38,10 @@ describe("Department Store Sale - Mystery Encounter", () => { game.override.disableTrainerWaves(); const biomeMap = new Map([ - [Biome.VOLCANO, [MysteryEncounterType.MYSTERIOUS_CHALLENGERS]], + [ Biome.VOLCANO, [ MysteryEncounterType.MYSTERIOUS_CHALLENGERS ]], ]); CIVILIZATION_ENCOUNTER_BIOMES.forEach(biome => { - biomeMap.set(biome, [MysteryEncounterType.DEPARTMENT_STORE_SALE]); + biomeMap.set(biome, [ MysteryEncounterType.DEPARTMENT_STORE_SALE ]); }); vi.spyOn(MysteryEncounters, "mysteryEncountersByBiome", "get").mockReturnValue(biomeMap); }); @@ -59,15 +59,15 @@ describe("Department Store Sale - Mystery Encounter", () => { expect(DepartmentStoreSaleEncounter.encounterTier).toBe(MysteryEncounterTier.COMMON); expect(DepartmentStoreSaleEncounter.dialogue).toBeDefined(); expect(DepartmentStoreSaleEncounter.dialogue.intro).toStrictEqual([ - { text: `${namespace}.intro` }, + { text: `${namespace}:intro` }, { - speaker: `${namespace}.speaker`, - text: `${namespace}.intro_dialogue`, + speaker: `${namespace}:speaker`, + text: `${namespace}:intro_dialogue`, } ]); - expect(DepartmentStoreSaleEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}.title`); - expect(DepartmentStoreSaleEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}.description`); - expect(DepartmentStoreSaleEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}.query`); + expect(DepartmentStoreSaleEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}:title`); + expect(DepartmentStoreSaleEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}:description`); + expect(DepartmentStoreSaleEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}:query`); expect(DepartmentStoreSaleEncounter.options.length).toBe(4); }); @@ -79,30 +79,14 @@ describe("Department Store Sale - Mystery Encounter", () => { expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.DEPARTMENT_STORE_SALE); }); - it("should not run below wave 10", async () => { - game.override.startingWave(9); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.DEPARTMENT_STORE_SALE); - }); - - it("should not run above wave 179", async () => { - game.override.startingWave(181); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle.mysteryEncounter).toBeUndefined(); - }); - describe("Option 1 - TM Shop", () => { it("should have the correct properties", () => { const option = DepartmentStoreSaleEncounter.options[0]; expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, }); }); @@ -114,7 +98,7 @@ describe("Department Store Sale - Mystery Encounter", () => { expect(scene.ui.getMode()).to.equal(Mode.MODIFIER_SELECT); const modifierSelectHandler = scene.ui.handlers.find(h => h instanceof ModifierSelectUiHandler) as ModifierSelectUiHandler; - expect(modifierSelectHandler.options.length).toEqual(4); + expect(modifierSelectHandler.options.length).toEqual(5); for (const option of modifierSelectHandler.options) { expect(option.modifierTypeOption.type.id).toContain("TM_"); } @@ -136,8 +120,8 @@ describe("Department Store Sale - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, }); }); @@ -172,8 +156,8 @@ describe("Department Store Sale - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, }); }); @@ -208,8 +192,8 @@ describe("Department Store Sale - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.4.label`, - buttonTooltip: `${namespace}.option.4.tooltip`, + buttonLabel: `${namespace}:option.4.label`, + buttonTooltip: `${namespace}:option.4.tooltip`, }); }); diff --git a/src/test/mystery-encounter/encounters/field-trip-encounter.test.ts b/src/test/mystery-encounter/encounters/field-trip-encounter.test.ts index 7a8d951c5da..a6f925274c3 100644 --- a/src/test/mystery-encounter/encounters/field-trip-encounter.test.ts +++ b/src/test/mystery-encounter/encounters/field-trip-encounter.test.ts @@ -14,9 +14,10 @@ import { Moves } from "#enums/moves"; import { SelectModifierPhase } from "#app/phases/select-modifier-phase"; import { Mode } from "#app/ui/ui"; import ModifierSelectUiHandler from "#app/ui/modifier-select-ui-handler"; +import i18next from "i18next"; -const namespace = "mysteryEncounter:fieldTrip"; -const defaultParty = [Species.LAPRAS, Species.GENGAR, Species.ABRA]; +const namespace = "mysteryEncounters/fieldTrip"; +const defaultParty = [ Species.LAPRAS, Species.GENGAR, Species.ABRA ]; const defaultBiome = Biome.CAVE; const defaultWave = 45; @@ -36,11 +37,11 @@ describe("Field Trip - Mystery Encounter", () => { game.override.startingWave(defaultWave); game.override.startingBiome(defaultBiome); game.override.disableTrainerWaves(); - game.override.moveset([Moves.TACKLE, Moves.UPROAR, Moves.SWORDS_DANCE]); + game.override.moveset([ Moves.TACKLE, Moves.UPROAR, Moves.SWORDS_DANCE ]); vi.spyOn(MysteryEncounters, "mysteryEncountersByBiome", "get").mockReturnValue( new Map([ - [Biome.CAVE, [MysteryEncounterType.FIELD_TRIP]], + [ Biome.CAVE, [ MysteryEncounterType.FIELD_TRIP ]], ]) ); }); @@ -59,44 +60,28 @@ describe("Field Trip - Mystery Encounter", () => { expect(FieldTripEncounter.dialogue).toBeDefined(); expect(FieldTripEncounter.dialogue.intro).toStrictEqual([ { - text: `${namespace}.intro` + text: `${namespace}:intro` }, { - speaker: `${namespace}.speaker`, - text: `${namespace}.intro_dialogue` + speaker: `${namespace}:speaker`, + text: `${namespace}:intro_dialogue` } ]); - expect(FieldTripEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}.title`); - expect(FieldTripEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}.description`); - expect(FieldTripEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}.query`); + expect(FieldTripEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}:title`); + expect(FieldTripEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}:description`); + expect(FieldTripEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}:query`); expect(FieldTripEncounter.options.length).toBe(3); }); - it("should not run below wave 10", async () => { - game.override.startingWave(9); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.FIELD_TRIP); - }); - - it("should not run above wave 179", async () => { - game.override.startingWave(181); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle.mysteryEncounter).toBeUndefined(); - }); - describe("Option 1 - Show off a physical move", () => { it("should have the correct properties", () => { const option = FieldTripEncounter.options[0]; expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, - secondOptionPrompt: `${namespace}.second_option_prompt`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, + secondOptionPrompt: `${namespace}:second_option_prompt`, }); }); @@ -118,11 +103,11 @@ describe("Field Trip - Mystery Encounter", () => { expect(scene.ui.getMode()).to.equal(Mode.MODIFIER_SELECT); const modifierSelectHandler = scene.ui.handlers.find(h => h instanceof ModifierSelectUiHandler) as ModifierSelectUiHandler; expect(modifierSelectHandler.options.length).toEqual(5); - expect(modifierSelectHandler.options[0].modifierTypeOption.type.name).toBe("X Attack"); - expect(modifierSelectHandler.options[1].modifierTypeOption.type.name).toBe("X Defense"); - expect(modifierSelectHandler.options[2].modifierTypeOption.type.name).toBe("X Speed"); - expect(modifierSelectHandler.options[3].modifierTypeOption.type.name).toBe("Dire Hit"); - expect(modifierSelectHandler.options[4].modifierTypeOption.type.name).toBe("Rarer Candy"); + expect(modifierSelectHandler.options[0].modifierTypeOption.type.name).toBe(i18next.t("modifierType:TempStatStageBoosterItem.x_attack")); + expect(modifierSelectHandler.options[1].modifierTypeOption.type.name).toBe(i18next.t("modifierType:TempStatStageBoosterItem.x_defense")); + expect(modifierSelectHandler.options[2].modifierTypeOption.type.name).toBe(i18next.t("modifierType:TempStatStageBoosterItem.x_speed")); + expect(modifierSelectHandler.options[3].modifierTypeOption.type.name).toBe(i18next.t("modifierType:ModifierType.DIRE_HIT.name")); + expect(modifierSelectHandler.options[4].modifierTypeOption.type.name).toBe(i18next.t("modifierType:ModifierType.RARER_CANDY.name")); }); it("should leave encounter without battle", async () => { @@ -141,9 +126,9 @@ describe("Field Trip - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, - secondOptionPrompt: `${namespace}.second_option_prompt`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, + secondOptionPrompt: `${namespace}:second_option_prompt`, }); }); @@ -165,11 +150,11 @@ describe("Field Trip - Mystery Encounter", () => { expect(scene.ui.getMode()).to.equal(Mode.MODIFIER_SELECT); const modifierSelectHandler = scene.ui.handlers.find(h => h instanceof ModifierSelectUiHandler) as ModifierSelectUiHandler; expect(modifierSelectHandler.options.length).toEqual(5); - expect(modifierSelectHandler.options[0].modifierTypeOption.type.name).toBe("X Sp. Atk"); - expect(modifierSelectHandler.options[1].modifierTypeOption.type.name).toBe("X Sp. Def"); - expect(modifierSelectHandler.options[2].modifierTypeOption.type.name).toBe("X Speed"); - expect(modifierSelectHandler.options[3].modifierTypeOption.type.name).toBe("Dire Hit"); - expect(modifierSelectHandler.options[4].modifierTypeOption.type.name).toBe("Rarer Candy"); + expect(modifierSelectHandler.options[0].modifierTypeOption.type.name).toBe(i18next.t("modifierType:TempStatStageBoosterItem.x_sp_atk")); + expect(modifierSelectHandler.options[1].modifierTypeOption.type.name).toBe(i18next.t("modifierType:TempStatStageBoosterItem.x_sp_def")); + expect(modifierSelectHandler.options[2].modifierTypeOption.type.name).toBe(i18next.t("modifierType:TempStatStageBoosterItem.x_speed")); + expect(modifierSelectHandler.options[3].modifierTypeOption.type.name).toBe(i18next.t("modifierType:ModifierType.DIRE_HIT.name")); + expect(modifierSelectHandler.options[4].modifierTypeOption.type.name).toBe(i18next.t("modifierType:ModifierType.RARER_CANDY.name")); }); it("should leave encounter without battle", async () => { @@ -188,9 +173,9 @@ describe("Field Trip - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, - secondOptionPrompt: `${namespace}.second_option_prompt`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, + secondOptionPrompt: `${namespace}:second_option_prompt`, }); }); @@ -205,6 +190,7 @@ describe("Field Trip - Mystery Encounter", () => { }); it("Should give proper rewards on correct Special move option", async () => { + vi.spyOn(i18next, "t"); await game.runToMysteryEncounter(MysteryEncounterType.FIELD_TRIP, defaultParty); await runMysteryEncounterToEnd(game, 3, { pokemonNo: 1, optionNo: 3 }); await game.phaseInterceptor.to(SelectModifierPhase); @@ -212,11 +198,12 @@ describe("Field Trip - Mystery Encounter", () => { expect(scene.ui.getMode()).to.equal(Mode.MODIFIER_SELECT); const modifierSelectHandler = scene.ui.handlers.find(h => h instanceof ModifierSelectUiHandler) as ModifierSelectUiHandler; expect(modifierSelectHandler.options.length).toEqual(5); - expect(modifierSelectHandler.options[0].modifierTypeOption.type.name).toBe("X Accuracy"); - expect(modifierSelectHandler.options[1].modifierTypeOption.type.name).toBe("X Speed"); - expect(modifierSelectHandler.options[2].modifierTypeOption.type.name).toBe("5x Great Ball"); - expect(modifierSelectHandler.options[3].modifierTypeOption.type.name).toBe("IV Scanner"); - expect(modifierSelectHandler.options[4].modifierTypeOption.type.name).toBe("Rarer Candy"); + expect(modifierSelectHandler.options[0].modifierTypeOption.type.name).toBe(i18next.t("modifierType:TempStatStageBoosterItem.x_accuracy")); + expect(modifierSelectHandler.options[1].modifierTypeOption.type.name).toBe(i18next.t("modifierType:TempStatStageBoosterItem.x_speed")); + expect(modifierSelectHandler.options[2].modifierTypeOption.type.name).toBe(i18next.t("modifierType:ModifierType.AddPokeballModifierType.name", { modifierCount: 5, pokeballName: i18next.t("pokeball:greatBall") })); + expect(i18next.t).toHaveBeenCalledWith(("modifierType:ModifierType.AddPokeballModifierType.name"), expect.objectContaining({ modifierCount: 5 })); + expect(modifierSelectHandler.options[3].modifierTypeOption.type.name).toBe(i18next.t("modifierType:ModifierType.IV_SCANNER.name")); + expect(modifierSelectHandler.options[4].modifierTypeOption.type.name).toBe(i18next.t("modifierType:ModifierType.RARER_CANDY.name")); }); it("should leave encounter without battle", async () => { diff --git a/src/test/mystery-encounter/encounters/fiery-fallout-encounter.test.ts b/src/test/mystery-encounter/encounters/fiery-fallout-encounter.test.ts index 445ab4491a4..215cab5c65a 100644 --- a/src/test/mystery-encounter/encounters/fiery-fallout-encounter.test.ts +++ b/src/test/mystery-encounter/encounters/fiery-fallout-encounter.test.ts @@ -1,8 +1,8 @@ import * as MysteryEncounters from "#app/data/mystery-encounters/mystery-encounters"; -import { Biome } from "#app/enums/biome"; -import { MysteryEncounterType } from "#app/enums/mystery-encounter-type"; -import { Species } from "#app/enums/species"; -import GameManager from "#app/test/utils/gameManager"; +import { Biome } from "#enums/biome"; +import { MysteryEncounterType } from "#enums/mystery-encounter-type"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; import { FieryFalloutEncounter } from "#app/data/mystery-encounters/encounters/fiery-fallout-encounter"; import { Gender } from "#app/data/gender"; @@ -12,9 +12,9 @@ import * as EncounterPhaseUtils from "#app/data/mystery-encounters/utils/encount import { runMysteryEncounterToEnd, runSelectMysteryEncounterOption, skipBattleRunMysteryEncounterRewardsPhase } from "#test/mystery-encounter/encounter-test-utils"; import { Moves } from "#enums/moves"; import BattleScene from "#app/battle-scene"; -import { PokemonHeldItemModifier } from "#app/modifier/modifier"; -import { Type } from "#app/data/type"; -import { Status, StatusEffect } from "#app/data/status-effect"; +import { AttackTypeBoosterModifier, PokemonHeldItemModifier } from "#app/modifier/modifier"; +import { Type } from "#enums/type"; +import { Status } from "#app/data/status-effect"; import { MysteryEncounterPhase } from "#app/phases/mystery-encounter-phases"; import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode"; import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; @@ -22,10 +22,14 @@ import { initSceneWithoutEncounterPhase } from "#test/utils/gameManagerUtils"; import { CommandPhase } from "#app/phases/command-phase"; import { MovePhase } from "#app/phases/move-phase"; import { SelectModifierPhase } from "#app/phases/select-modifier-phase"; +import { BattlerTagType } from "#enums/battler-tag-type"; +import { Abilities } from "#enums/abilities"; +import i18next from "i18next"; +import { StatusEffect } from "#enums/status-effect"; -const namespace = "mysteryEncounter:fieryFallout"; +const namespace = "mysteryEncounters/fieryFallout"; /** Arcanine and Ninetails for 2 Fire types. Lapras, Gengar, Abra for burnable mon. */ -const defaultParty = [Species.ARCANINE, Species.NINETALES, Species.LAPRAS, Species.GENGAR, Species.ABRA]; +const defaultParty = [ Species.ARCANINE, Species.NINETALES, Species.LAPRAS, Species.GENGAR, Species.ABRA ]; const defaultBiome = Biome.VOLCANO; const defaultWave = 56; @@ -41,15 +45,16 @@ describe("Fiery Fallout - Mystery Encounter", () => { beforeEach(async () => { game = new GameManager(phaserGame); scene = game.scene; - game.override.mysteryEncounterChance(100); - game.override.startingWave(defaultWave); - game.override.startingBiome(defaultBiome); - game.override.disableTrainerWaves(); + game.override.mysteryEncounterChance(100) + .startingWave(defaultWave) + .startingBiome(defaultBiome) + .disableTrainerWaves() + .moveset([ Moves.PAYBACK, Moves.THUNDERBOLT ]); // Required for attack type booster item generation vi.spyOn(MysteryEncounters, "mysteryEncountersByBiome", "get").mockReturnValue( new Map([ - [Biome.VOLCANO, [MysteryEncounterType.FIERY_FALLOUT]], - [Biome.MOUNTAIN, [MysteryEncounterType.MYSTERIOUS_CHALLENGERS]], + [ Biome.VOLCANO, [ MysteryEncounterType.FIERY_FALLOUT ]], + [ Biome.MOUNTAIN, [ MysteryEncounterType.MYSTERIOUS_CHALLENGERS ]], ]) ); }); @@ -66,10 +71,10 @@ describe("Fiery Fallout - Mystery Encounter", () => { expect(FieryFalloutEncounter.encounterType).toBe(MysteryEncounterType.FIERY_FALLOUT); expect(FieryFalloutEncounter.encounterTier).toBe(MysteryEncounterTier.COMMON); expect(FieryFalloutEncounter.dialogue).toBeDefined(); - expect(FieryFalloutEncounter.dialogue.intro).toStrictEqual([{ text: `${namespace}.intro` }]); - expect(FieryFalloutEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}.title`); - expect(FieryFalloutEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}.description`); - expect(FieryFalloutEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}.query`); + expect(FieryFalloutEncounter.dialogue.intro).toStrictEqual([{ text: `${namespace}:intro` }]); + expect(FieryFalloutEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}:title`); + expect(FieryFalloutEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}:description`); + expect(FieryFalloutEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}:query`); expect(FieryFalloutEncounter.options.length).toBe(3); }); @@ -88,14 +93,6 @@ describe("Fiery Fallout - Mystery Encounter", () => { expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.FIERY_FALLOUT); }); - it("should not run above wave 179", async () => { - game.override.startingWave(181); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle.mysteryEncounter).toBeUndefined(); - }); - it("should initialize fully ", async () => { initSceneWithoutEncounterPhase(scene, defaultParty); scene.currentBattle.mysteryEncounter = FieryFalloutEncounter; @@ -116,12 +113,16 @@ describe("Fiery Fallout - Mystery Encounter", () => { { species: getPokemonSpecies(Species.VOLCARONA), isBoss: false, - gender: Gender.MALE + gender: Gender.MALE, + tags: [ BattlerTagType.MYSTERY_ENCOUNTER_POST_SUMMON ], + mysteryEncounterBattleEffects: expect.any(Function) }, { species: getPokemonSpecies(Species.VOLCARONA), isBoss: false, - gender: Gender.FEMALE + gender: Gender.FEMALE, + tags: [ BattlerTagType.MYSTERY_ENCOUNTER_POST_SUMMON ], + mysteryEncounterBattleEffects: expect.any(Function) } ], doubleBattle: true, @@ -140,11 +141,11 @@ describe("Fiery Fallout - Mystery Encounter", () => { expect(option1.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option1.dialogue).toBeDefined(); expect(option1.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.1.selected`, + text: `${namespace}:option.1.selected`, }, ], }); @@ -164,23 +165,22 @@ describe("Fiery Fallout - Mystery Encounter", () => { expect(enemyField[0].gender).not.toEqual(enemyField[1].gender); // Should be opposite gender const movePhases = phaseSpy.mock.calls.filter(p => p[0] instanceof MovePhase).map(p => p[0]); - expect(movePhases.length).toBe(4); + expect(movePhases.length).toBe(2); expect(movePhases.filter(p => (p as MovePhase).move.moveId === Moves.FIRE_SPIN).length).toBe(2); // Fire spin used twice before battle - expect(movePhases.filter(p => (p as MovePhase).move.moveId === Moves.QUIVER_DANCE).length).toBe(2); // Quiver Dance used twice before battle }); - it("should give charcoal to lead pokemon", async () => { + it("should give attack type boosting item to lead pokemon", async () => { await game.runToMysteryEncounter(MysteryEncounterType.FIERY_FALLOUT, defaultParty); await runMysteryEncounterToEnd(game, 1, undefined, true); await skipBattleRunMysteryEncounterRewardsPhase(game); await game.phaseInterceptor.to(SelectModifierPhase, false); expect(scene.getCurrentPhase()?.constructor.name).toBe(SelectModifierPhase.name); - const leadPokemonId = scene.getParty()?.[0].id; + const leadPokemonId = scene.getPlayerParty()?.[0].id; const leadPokemonItems = scene.findModifiers(m => m instanceof PokemonHeldItemModifier && (m as PokemonHeldItemModifier).pokemonId === leadPokemonId, true) as PokemonHeldItemModifier[]; - const charcoal = leadPokemonItems.find(i => i.type.name === "Charcoal"); - expect(charcoal).toBeDefined; + const item = leadPokemonItems.find(i => i instanceof AttackTypeBoosterModifier); + expect(item).toBeDefined; }); }); @@ -190,20 +190,20 @@ describe("Fiery Fallout - Mystery Encounter", () => { expect(option1.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option1.dialogue).toBeDefined(); expect(option1.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, selected: [ { - text: `${namespace}.option.2.selected`, + text: `${namespace}:option.2.selected`, }, ], }); }); - it("should damage all non-fire party PKM by 20% and randomly burn 1", async () => { + it("should damage all non-fire party PKM by 20%, and burn + give Heatproof to a random Pokemon", async () => { await game.runToMysteryEncounter(MysteryEncounterType.FIERY_FALLOUT, defaultParty); - const party = scene.getParty(); + const party = scene.getPlayerParty(); const lapras = party.find((pkm) => pkm.species.speciesId === Species.LAPRAS)!; lapras.status = new Status(StatusEffect.POISON); const abra = party.find((pkm) => pkm.species.speciesId === Species.ABRA)!; @@ -213,11 +213,12 @@ describe("Fiery Fallout - Mystery Encounter", () => { const burnablePokemon = party.filter((pkm) => pkm.isAllowedInBattle() && !pkm.getTypes().includes(Type.FIRE)); const notBurnablePokemon = party.filter((pkm) => !pkm.isAllowedInBattle() || pkm.getTypes().includes(Type.FIRE)); - expect(scene.currentBattle.mysteryEncounter?.dialogueTokens["burnedPokemon"]).toBe("Gengar"); + expect(scene.currentBattle.mysteryEncounter?.dialogueTokens["burnedPokemon"]).toBe(i18next.t("pokemon:gengar")); burnablePokemon.forEach((pkm) => { expect(pkm.hp, `${pkm.name} should have received 20% damage: ${pkm.hp} / ${pkm.getMaxHp()} HP`).toBe(pkm.getMaxHp() - Math.floor(pkm.getMaxHp() * 0.2)); }); - expect(burnablePokemon.some(pkm => pkm?.status?.effect === StatusEffect.BURN)).toBeTruthy(); + expect(burnablePokemon.some(pkm => pkm.status?.effect === StatusEffect.BURN)).toBeTruthy(); + expect(burnablePokemon.some(pkm => pkm.customPokemonData.ability === Abilities.HEATPROOF)); notBurnablePokemon.forEach((pkm) => expect(pkm.hp, `${pkm.name} should be full hp: ${pkm.hp} / ${pkm.getMaxHp()} HP`).toBe(pkm.getMaxHp())); }); @@ -237,28 +238,26 @@ describe("Fiery Fallout - Mystery Encounter", () => { expect(option1.optionMode).toBe(MysteryEncounterOptionMode.DISABLED_OR_SPECIAL); expect(option1.dialogue).toBeDefined(); expect(option1.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, - disabledButtonTooltip: `${namespace}.option.3.disabled_tooltip`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, + disabledButtonTooltip: `${namespace}:option.3.disabled_tooltip`, selected: [ { - text: `${namespace}.option.3.selected`, + text: `${namespace}:option.3.selected`, }, ], }); }); - it("should give charcoal to lead pokemon", async () => { + it("should give attack type boosting item to lead pokemon", async () => { await game.runToMysteryEncounter(MysteryEncounterType.FIERY_FALLOUT, defaultParty); await runMysteryEncounterToEnd(game, 3); await game.phaseInterceptor.to(SelectModifierPhase, false); expect(scene.getCurrentPhase()?.constructor.name).toBe(SelectModifierPhase.name); - const leadPokemonId = scene.getParty()?.[0].id; - const leadPokemonItems = scene.findModifiers(m => m instanceof PokemonHeldItemModifier - && (m as PokemonHeldItemModifier).pokemonId === leadPokemonId, true) as PokemonHeldItemModifier[]; - const charcoal = leadPokemonItems.find(i => i.type.name === "Charcoal"); - expect(charcoal).toBeDefined; + const leadPokemonItems = scene.getPlayerParty()?.[0].getHeldItems() as PokemonHeldItemModifier[]; + const item = leadPokemonItems.find(i => i instanceof AttackTypeBoosterModifier); + expect(item).toBeDefined; }); it("should leave encounter without battle", async () => { @@ -271,7 +270,7 @@ describe("Fiery Fallout - Mystery Encounter", () => { }); it("should be disabled if not enough FIRE types are in party", async () => { - await game.runToMysteryEncounter(MysteryEncounterType.FIERY_FALLOUT, [Species.MAGIKARP, Species.ARCANINE]); + await game.runToMysteryEncounter(MysteryEncounterType.FIERY_FALLOUT, [ Species.MAGIKARP ]); await game.phaseInterceptor.to(MysteryEncounterPhase, false); const encounterPhase = scene.getCurrentPhase(); diff --git a/src/test/mystery-encounter/encounters/fight-or-flight-encounter.test.ts b/src/test/mystery-encounter/encounters/fight-or-flight-encounter.test.ts index 735dcc709bf..a5098f682eb 100644 --- a/src/test/mystery-encounter/encounters/fight-or-flight-encounter.test.ts +++ b/src/test/mystery-encounter/encounters/fight-or-flight-encounter.test.ts @@ -19,8 +19,8 @@ import { MysteryEncounterPhase } from "#app/phases/mystery-encounter-phases"; import { CommandPhase } from "#app/phases/command-phase"; import { SelectModifierPhase } from "#app/phases/select-modifier-phase"; -const namespace = "mysteryEncounter:fightOrFlight"; -const defaultParty = [Species.LAPRAS, Species.GENGAR, Species.ABRA]; +const namespace = "mysteryEncounters/fightOrFlight"; +const defaultParty = [ Species.LAPRAS, Species.GENGAR, Species.ABRA ]; const defaultBiome = Biome.CAVE; const defaultWave = 45; @@ -43,7 +43,7 @@ describe("Fight or Flight - Mystery Encounter", () => { vi.spyOn(MysteryEncounters, "mysteryEncountersByBiome", "get").mockReturnValue( new Map([ - [Biome.CAVE, [MysteryEncounterType.FIGHT_OR_FLIGHT]], + [ Biome.CAVE, [ MysteryEncounterType.FIGHT_OR_FLIGHT ]], ]) ); }); @@ -60,29 +60,13 @@ describe("Fight or Flight - Mystery Encounter", () => { expect(FightOrFlightEncounter.encounterType).toBe(MysteryEncounterType.FIGHT_OR_FLIGHT); expect(FightOrFlightEncounter.encounterTier).toBe(MysteryEncounterTier.COMMON); expect(FightOrFlightEncounter.dialogue).toBeDefined(); - expect(FightOrFlightEncounter.dialogue.intro).toStrictEqual([{ text: `${namespace}.intro` }]); - expect(FightOrFlightEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}.title`); - expect(FightOrFlightEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}.description`); - expect(FightOrFlightEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}.query`); + expect(FightOrFlightEncounter.dialogue.intro).toStrictEqual([{ text: `${namespace}:intro` }]); + expect(FightOrFlightEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}:title`); + expect(FightOrFlightEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}:description`); + expect(FightOrFlightEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}:query`); expect(FightOrFlightEncounter.options.length).toBe(3); }); - it("should not run below wave 10", async () => { - game.override.startingWave(9); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.FIGHT_OR_FLIGHT); - }); - - it("should not run above wave 179", async () => { - game.override.startingWave(181); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle.mysteryEncounter).toBeUndefined(); - }); - it("should initialize fully", async () => { initSceneWithoutEncounterPhase(scene, defaultParty); scene.currentBattle.mysteryEncounter = FightOrFlightEncounter; @@ -96,7 +80,6 @@ describe("Fight or Flight - Mystery Encounter", () => { const config = FightOrFlightEncounter.enemyPartyConfigs[0]; expect(config).toBeDefined(); - expect(config.levelAdditiveMultiplier).toBe(1); expect(config.pokemonConfigs?.[0].isBoss).toBe(true); expect(onInitResult).toBe(true); }); @@ -107,11 +90,11 @@ describe("Fight or Flight - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.1.selected`, + text: `${namespace}:option.1.selected`, }, ], }); @@ -155,12 +138,12 @@ describe("Fight or Flight - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DISABLED_OR_SPECIAL); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, - disabledButtonTooltip: `${namespace}.option.2.disabled_tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, + disabledButtonTooltip: `${namespace}:option.2.disabled_tooltip`, selected: [ { - text: `${namespace}.option.2.selected`, + text: `${namespace}:option.2.selected`, } ], }); @@ -168,7 +151,7 @@ describe("Fight or Flight - Mystery Encounter", () => { it("should NOT be selectable if the player doesn't have a Stealing move", async () => { await game.runToMysteryEncounter(MysteryEncounterType.FIGHT_OR_FLIGHT, defaultParty); - scene.getParty().forEach(p => p.moveset = []); + scene.getPlayerParty().forEach(p => p.moveset = []); await game.phaseInterceptor.to(MysteryEncounterPhase, false); const encounterPhase = scene.getCurrentPhase(); @@ -192,7 +175,7 @@ describe("Fight or Flight - Mystery Encounter", () => { await game.runToMysteryEncounter(MysteryEncounterType.FIGHT_OR_FLIGHT, defaultParty); // Mock moveset - scene.getParty()[0].moveset = [new PokemonMove(Moves.KNOCK_OFF)]; + scene.getPlayerParty()[0].moveset = [ new PokemonMove(Moves.KNOCK_OFF) ]; const item = game.scene.currentBattle.mysteryEncounter!.misc; await runMysteryEncounterToEnd(game, 2); diff --git a/src/test/mystery-encounter/encounters/fun-and-games-encounter.test.ts b/src/test/mystery-encounter/encounters/fun-and-games-encounter.test.ts index 70250350af4..2f4f6bed288 100644 --- a/src/test/mystery-encounter/encounters/fun-and-games-encounter.test.ts +++ b/src/test/mystery-encounter/encounters/fun-and-games-encounter.test.ts @@ -22,8 +22,8 @@ import { Moves } from "#enums/moves"; import { Command } from "#app/ui/command-ui-handler"; import * as EncounterPhaseUtils from "#app/data/mystery-encounters/utils/encounter-phase-utils"; -const namespace = "mysteryEncounter:funAndGames"; -const defaultParty = [Species.LAPRAS, Species.GENGAR, Species.ABRA]; +const namespace = "mysteryEncounters/funAndGames"; +const defaultParty = [ Species.LAPRAS, Species.GENGAR, Species.ABRA ]; const defaultBiome = Biome.CAVE; const defaultWave = 45; @@ -45,10 +45,10 @@ describe("Fun And Games! - Mystery Encounter", () => { game.override.disableTrainerWaves(); const biomeMap = new Map([ - [Biome.VOLCANO, [MysteryEncounterType.FIGHT_OR_FLIGHT]], + [ Biome.VOLCANO, [ MysteryEncounterType.FIGHT_OR_FLIGHT ]], ]); HUMAN_TRANSITABLE_BIOMES.forEach(biome => { - biomeMap.set(biome, [MysteryEncounterType.FUN_AND_GAMES]); + biomeMap.set(biome, [ MysteryEncounterType.FUN_AND_GAMES ]); }); vi.spyOn(MysteryEncounters, "mysteryEncountersByBiome", "get").mockReturnValue(biomeMap); }); @@ -67,13 +67,13 @@ describe("Fun And Games! - Mystery Encounter", () => { expect(FunAndGamesEncounter.dialogue).toBeDefined(); expect(FunAndGamesEncounter.dialogue.intro).toStrictEqual([ { - speaker: `${namespace}.speaker`, - text: `${namespace}.intro_dialogue`, + speaker: `${namespace}:speaker`, + text: `${namespace}:intro_dialogue`, } ]); - expect(FunAndGamesEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}.title`); - expect(FunAndGamesEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}.description`); - expect(FunAndGamesEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}.query`); + expect(FunAndGamesEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}:title`); + expect(FunAndGamesEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}:description`); + expect(FunAndGamesEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}:query`); expect(FunAndGamesEncounter.options.length).toBe(2); }); @@ -85,22 +85,6 @@ describe("Fun And Games! - Mystery Encounter", () => { expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.FUN_AND_GAMES); }); - it("should not run below wave 10", async () => { - game.override.startingWave(9); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.FUN_AND_GAMES); - }); - - it("should not run above wave 179", async () => { - game.override.startingWave(181); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle.mysteryEncounter).toBeUndefined(); - }); - it("should initialize fully", async () => { initSceneWithoutEncounterPhase(scene, defaultParty); scene.currentBattle.mysteryEncounter = new MysteryEncounter(FunAndGamesEncounter); @@ -121,11 +105,11 @@ describe("Fun And Games! - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DISABLED_OR_DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.1.selected`, + text: `${namespace}:option.1.selected`, }, ], }); @@ -153,13 +137,13 @@ describe("Fun And Games! - Mystery Encounter", () => { it("should get 3 turns to attack the Wobbuffet for a reward", async () => { scene.money = 20000; - game.override.moveset([Moves.TACKLE]); + game.override.moveset([ Moves.TACKLE ]); await game.runToMysteryEncounter(MysteryEncounterType.FUN_AND_GAMES, defaultParty); await runMysteryEncounterToEnd(game, 1, { pokemonNo: 1 }, true); expect(scene.getCurrentPhase()?.constructor.name).toBe(CommandPhase.name); expect(scene.getEnemyPokemon()?.species.speciesId).toBe(Species.WOBBUFFET); - expect(scene.getEnemyPokemon()?.ivs).toEqual([0, 0, 0, 0, 0, 0]); + expect(scene.getEnemyPokemon()?.ivs).toEqual([ 0, 0, 0, 0, 0, 0 ]); expect(scene.getEnemyPokemon()?.nature).toBe(Nature.MILD); game.onNextPrompt("MessagePhase", Mode.MESSAGE, () => { @@ -208,7 +192,7 @@ describe("Fun And Games! - Mystery Encounter", () => { it("should have Wide Lens item in rewards if Wubboffet is at 15-33% HP remaining", async () => { scene.money = 20000; - game.override.moveset([Moves.SPLASH]); + game.override.moveset([ Moves.SPLASH ]); await game.runToMysteryEncounter(MysteryEncounterType.FUN_AND_GAMES, defaultParty); await runMysteryEncounterToEnd(game, 1, { pokemonNo: 1 }, true); @@ -236,7 +220,7 @@ describe("Fun And Games! - Mystery Encounter", () => { it("should have Scope Lens item in rewards if Wubboffet is at 3-15% HP remaining", async () => { scene.money = 20000; - game.override.moveset([Moves.SPLASH]); + game.override.moveset([ Moves.SPLASH ]); await game.runToMysteryEncounter(MysteryEncounterType.FUN_AND_GAMES, defaultParty); await runMysteryEncounterToEnd(game, 1, { pokemonNo: 1 }, true); @@ -264,7 +248,7 @@ describe("Fun And Games! - Mystery Encounter", () => { it("should have Multi Lens item in rewards if Wubboffet is at <3% HP remaining", async () => { scene.money = 20000; - game.override.moveset([Moves.SPLASH]); + game.override.moveset([ Moves.SPLASH ]); await game.runToMysteryEncounter(MysteryEncounterType.FUN_AND_GAMES, defaultParty); await runMysteryEncounterToEnd(game, 1, { pokemonNo: 1 }, true); diff --git a/src/test/mystery-encounter/encounters/global-trade-system-encounter.test.ts b/src/test/mystery-encounter/encounters/global-trade-system-encounter.test.ts index e91b936cb9d..e8d19ff50b9 100644 --- a/src/test/mystery-encounter/encounters/global-trade-system-encounter.test.ts +++ b/src/test/mystery-encounter/encounters/global-trade-system-encounter.test.ts @@ -19,8 +19,8 @@ import { Mode } from "#app/ui/ui"; import ModifierSelectUiHandler from "#app/ui/modifier-select-ui-handler"; import { ModifierTier } from "#app/modifier/modifier-tier"; -const namespace = "mysteryEncounter:globalTradeSystem"; -const defaultParty = [Species.LAPRAS, Species.GENGAR, Species.ABRA]; +const namespace = "mysteryEncounters/globalTradeSystem"; +const defaultParty = [ Species.LAPRAS, Species.GENGAR, Species.ABRA ]; const defaultBiome = Biome.CAVE; const defaultWave = 45; @@ -42,10 +42,10 @@ describe("Global Trade System - Mystery Encounter", () => { game.override.disableTrainerWaves(); const biomeMap = new Map([ - [Biome.VOLCANO, [MysteryEncounterType.MYSTERIOUS_CHALLENGERS]], + [ Biome.VOLCANO, [ MysteryEncounterType.MYSTERIOUS_CHALLENGERS ]], ]); CIVILIZATION_ENCOUNTER_BIOMES.forEach(biome => { - biomeMap.set(biome, [MysteryEncounterType.GLOBAL_TRADE_SYSTEM]); + biomeMap.set(biome, [ MysteryEncounterType.GLOBAL_TRADE_SYSTEM ]); }); vi.spyOn(MysteryEncounters, "mysteryEncountersByBiome", "get").mockReturnValue(biomeMap); }); @@ -62,27 +62,25 @@ describe("Global Trade System - Mystery Encounter", () => { expect(GlobalTradeSystemEncounter.encounterType).toBe(MysteryEncounterType.GLOBAL_TRADE_SYSTEM); expect(GlobalTradeSystemEncounter.encounterTier).toBe(MysteryEncounterTier.COMMON); expect(GlobalTradeSystemEncounter.dialogue).toBeDefined(); - expect(GlobalTradeSystemEncounter.dialogue.intro).toStrictEqual([{ text: `${namespace}.intro` }]); - expect(GlobalTradeSystemEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}.title`); - expect(GlobalTradeSystemEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}.description`); - expect(GlobalTradeSystemEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}.query`); + expect(GlobalTradeSystemEncounter.dialogue.intro).toStrictEqual([{ text: `${namespace}:intro` }]); + expect(GlobalTradeSystemEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}:title`); + expect(GlobalTradeSystemEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}:description`); + expect(GlobalTradeSystemEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}:query`); expect(GlobalTradeSystemEncounter.options.length).toBe(4); }); - it("should not run below wave 10", async () => { - game.override.startingWave(9); + it("should not loop infinitely when generating trade options for extreme BST non-legendaries", async () => { + const extremeBstTeam = [ Species.SLAKING, Species.WISHIWASHI, Species.SUNKERN ]; + await game.runToMysteryEncounter(MysteryEncounterType.GLOBAL_TRADE_SYSTEM, extremeBstTeam); - await game.runToMysteryEncounter(); - - expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.GLOBAL_TRADE_SYSTEM); - }); - - it("should not run above wave 179", async () => { - game.override.startingWave(181); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle.mysteryEncounter).toBeUndefined(); + expect(GlobalTradeSystemEncounter.encounterType).toBe(MysteryEncounterType.GLOBAL_TRADE_SYSTEM); + expect(GlobalTradeSystemEncounter.encounterTier).toBe(MysteryEncounterTier.COMMON); + expect(GlobalTradeSystemEncounter.dialogue).toBeDefined(); + expect(GlobalTradeSystemEncounter.dialogue.intro).toStrictEqual([{ text: `${namespace}:intro` }]); + expect(GlobalTradeSystemEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}:title`); + expect(GlobalTradeSystemEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}:description`); + expect(GlobalTradeSystemEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}:query`); + expect(GlobalTradeSystemEncounter.options.length).toBe(4); }); it("should not spawn outside of CIVILIZATION_ENCOUNTER_BIOMES", async () => { @@ -99,19 +97,19 @@ describe("Global Trade System - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, - secondOptionPrompt: `${namespace}.option.1.trade_options_prompt`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, + secondOptionPrompt: `${namespace}:option.1.trade_options_prompt`, }); }); it("Should trade a Pokemon from the player's party for the first of 3 Pokemon options", async () => { await game.runToMysteryEncounter(MysteryEncounterType.GLOBAL_TRADE_SYSTEM, defaultParty); - const speciesBefore = scene.getParty()[0].species.speciesId; + const speciesBefore = scene.getPlayerParty()[0].species.speciesId; await runMysteryEncounterToEnd(game, 1, { pokemonNo: 1, optionNo: 1 }); - const speciesAfter = scene.getParty().at(-1)?.species.speciesId; + const speciesAfter = scene.getPlayerParty().at(-1)?.species.speciesId; expect(speciesAfter).toBeDefined(); expect(speciesBefore).not.toBe(speciesAfter); @@ -121,10 +119,10 @@ describe("Global Trade System - Mystery Encounter", () => { it("Should trade a Pokemon from the player's party for the second of 3 Pokemon options", async () => { await game.runToMysteryEncounter(MysteryEncounterType.GLOBAL_TRADE_SYSTEM, defaultParty); - const speciesBefore = scene.getParty()[1].species.speciesId; + const speciesBefore = scene.getPlayerParty()[1].species.speciesId; await runMysteryEncounterToEnd(game, 1, { pokemonNo: 2, optionNo: 2 }); - const speciesAfter = scene.getParty().at(-1)?.species.speciesId; + const speciesAfter = scene.getPlayerParty().at(-1)?.species.speciesId; expect(speciesAfter).toBeDefined(); expect(speciesBefore).not.toBe(speciesAfter); @@ -134,10 +132,10 @@ describe("Global Trade System - Mystery Encounter", () => { it("Should trade a Pokemon from the player's party for the third of 3 Pokemon options", async () => { await game.runToMysteryEncounter(MysteryEncounterType.GLOBAL_TRADE_SYSTEM, defaultParty); - const speciesBefore = scene.getParty()[2].species.speciesId; + const speciesBefore = scene.getPlayerParty()[2].species.speciesId; await runMysteryEncounterToEnd(game, 1, { pokemonNo: 3, optionNo: 3 }); - const speciesAfter = scene.getParty().at(-1)?.species.speciesId; + const speciesAfter = scene.getPlayerParty().at(-1)?.species.speciesId; expect(speciesAfter).toBeDefined(); expect(speciesBefore).not.toBe(speciesAfter); @@ -160,18 +158,18 @@ describe("Global Trade System - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip` + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip` }); }); it("Should trade a Pokemon from the player's party for a random wonder trade Pokemon", async () => { await game.runToMysteryEncounter(MysteryEncounterType.GLOBAL_TRADE_SYSTEM, defaultParty); - const speciesBefore = scene.getParty()[2].species.speciesId; + const speciesBefore = scene.getPlayerParty()[2].species.speciesId; await runMysteryEncounterToEnd(game, 2, { pokemonNo: 1 }); - const speciesAfter = scene.getParty().at(-1)?.species.speciesId; + const speciesAfter = scene.getPlayerParty().at(-1)?.species.speciesId; expect(speciesAfter).toBeDefined(); expect(speciesBefore).not.toBe(speciesAfter); @@ -194,9 +192,9 @@ describe("Global Trade System - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, - secondOptionPrompt: `${namespace}.option.3.trade_options_prompt`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, + secondOptionPrompt: `${namespace}:option.3.trade_options_prompt`, }); }); @@ -206,12 +204,12 @@ describe("Global Trade System - Mystery Encounter", () => { // Set 2 Soul Dew on party lead scene.modifiers = []; const soulDew = generateModifierType(scene, modifierTypes.SOUL_DEW)!; - const modifier = soulDew.newModifier(scene.getParty()[0]) as PokemonNatureWeightModifier; + const modifier = soulDew.newModifier(scene.getPlayerParty()[0]) as PokemonNatureWeightModifier; modifier.stackCount = 2; await scene.addModifier(modifier, true, false, false, true); await scene.updateModifiers(true); - await runMysteryEncounterToEnd(game, 3, { pokemonNo: 1, optionNo: 1}); + await runMysteryEncounterToEnd(game, 3, { pokemonNo: 1, optionNo: 1 }); expect(scene.getCurrentPhase()?.constructor.name).toBe(SelectModifierPhase.name); await game.phaseInterceptor.run(SelectModifierPhase); @@ -231,12 +229,12 @@ describe("Global Trade System - Mystery Encounter", () => { // Set 1 Soul Dew on party lead scene.modifiers = []; const soulDew = generateModifierType(scene, modifierTypes.SOUL_DEW)!; - const modifier = soulDew.newModifier(scene.getParty()[0]) as PokemonNatureWeightModifier; + const modifier = soulDew.newModifier(scene.getPlayerParty()[0]) as PokemonNatureWeightModifier; modifier.stackCount = 1; await scene.addModifier(modifier, true, false, false, true); await scene.updateModifiers(true); - await runMysteryEncounterToEnd(game, 3, { pokemonNo: 1, optionNo: 1}); + await runMysteryEncounterToEnd(game, 3, { pokemonNo: 1, optionNo: 1 }); expect(leaveEncounterWithoutBattleSpy).toBeCalled(); }); @@ -248,11 +246,11 @@ describe("Global Trade System - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.4.label`, - buttonTooltip: `${namespace}.option.4.tooltip`, + buttonLabel: `${namespace}:option.4.label`, + buttonTooltip: `${namespace}:option.4.tooltip`, selected: [ { - text: `${namespace}.option.4.selected`, + text: `${namespace}:option.4.selected`, }, ], }); diff --git a/src/test/mystery-encounter/encounters/lost-at-sea-encounter.test.ts b/src/test/mystery-encounter/encounters/lost-at-sea-encounter.test.ts index 82670e32daa..51f759c9268 100644 --- a/src/test/mystery-encounter/encounters/lost-at-sea-encounter.test.ts +++ b/src/test/mystery-encounter/encounters/lost-at-sea-encounter.test.ts @@ -14,11 +14,12 @@ import { initSceneWithoutEncounterPhase } from "#test/utils/gameManagerUtils"; import BattleScene from "#app/battle-scene"; import { MysteryEncounterPhase } from "#app/phases/mystery-encounter-phases"; import { PartyExpPhase } from "#app/phases/party-exp-phase"; +import i18next from "i18next"; -const namespace = "mysteryEncounter:lostAtSea"; +const namespace = "mysteryEncounters/lostAtSea"; /** Blastoise for surf. Pidgeot for fly. Abra for none. */ -const defaultParty = [Species.BLASTOISE, Species.PIDGEOT, Species.ABRA]; +const defaultParty = [ Species.BLASTOISE, Species.PIDGEOT, Species.ABRA ]; const defaultBiome = Biome.SEA; const defaultWave = 33; @@ -41,8 +42,8 @@ describe("Lost at Sea - Mystery Encounter", () => { vi.spyOn(MysteryEncounters, "mysteryEncountersByBiome", "get").mockReturnValue( new Map([ - [Biome.SEA, [MysteryEncounterType.LOST_AT_SEA]], - [Biome.MOUNTAIN, [MysteryEncounterType.MYSTERIOUS_CHALLENGERS]], + [ Biome.SEA, [ MysteryEncounterType.LOST_AT_SEA ]], + [ Biome.MOUNTAIN, [ MysteryEncounterType.MYSTERIOUS_CHALLENGERS ]], ]) ); }); @@ -59,10 +60,10 @@ describe("Lost at Sea - Mystery Encounter", () => { expect(LostAtSeaEncounter.encounterType).toBe(MysteryEncounterType.LOST_AT_SEA); expect(LostAtSeaEncounter.encounterTier).toBe(MysteryEncounterTier.COMMON); expect(LostAtSeaEncounter.dialogue).toBeDefined(); - expect(LostAtSeaEncounter.dialogue.intro).toStrictEqual([{ text: `${namespace}.intro` }]); - expect(LostAtSeaEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}.title`); - expect(LostAtSeaEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}.description`); - expect(LostAtSeaEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}.query`); + expect(LostAtSeaEncounter.dialogue.intro).toStrictEqual([{ text: `${namespace}:intro` }]); + expect(LostAtSeaEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}:title`); + expect(LostAtSeaEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}:description`); + expect(LostAtSeaEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}:query`); expect(LostAtSeaEncounter.options.length).toBe(3); }); @@ -74,22 +75,6 @@ describe("Lost at Sea - Mystery Encounter", () => { expect(game.scene.currentBattle.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.LOST_AT_SEA); }); - it("should not run below wave 11", async () => { - game.override.startingWave(9); - - await game.runToMysteryEncounter(); - - expect(game.scene.currentBattle.mysteryEncounter).toBeUndefined(); - }); - - it("should not run above wave 179", async () => { - game.override.startingWave(181); - - await game.runToMysteryEncounter(); - - expect(game.scene.currentBattle.mysteryEncounter).toBeUndefined(); - }); - it("should initialize fully", () => { initSceneWithoutEncounterPhase(scene, defaultParty); scene.currentBattle.mysteryEncounter = LostAtSeaEncounter; @@ -102,8 +87,8 @@ describe("Lost at Sea - Mystery Encounter", () => { const onInitResult = onInit!(scene); expect(LostAtSeaEncounter.dialogueTokens?.damagePercentage).toBe("25"); - expect(LostAtSeaEncounter.dialogueTokens?.option1RequiredMove).toBe("Surf"); - expect(LostAtSeaEncounter.dialogueTokens?.option2RequiredMove).toBe("Fly"); + expect(LostAtSeaEncounter.dialogueTokens?.option1RequiredMove).toBe(i18next.t("move:surf.name")); + expect(LostAtSeaEncounter.dialogueTokens?.option2RequiredMove).toBe(i18next.t("move:fly.name")); expect(onInitResult).toBe(true); }); @@ -113,13 +98,13 @@ describe("Lost at Sea - Mystery Encounter", () => { expect(option1.optionMode).toBe(MysteryEncounterOptionMode.DISABLED_OR_DEFAULT); expect(option1.dialogue).toBeDefined(); expect(option1.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.1.label`, - disabledButtonLabel: `${namespace}.option.1.label_disabled`, - buttonTooltip: `${namespace}.option.1.tooltip`, - disabledButtonTooltip: `${namespace}.option.1.tooltip_disabled`, + buttonLabel: `${namespace}:option.1.label`, + disabledButtonLabel: `${namespace}:option.1.label_disabled`, + buttonTooltip: `${namespace}:option.1.tooltip`, + disabledButtonTooltip: `${namespace}:option.1.tooltip_disabled`, selected: [ { - text: `${namespace}.option.1.selected`, + text: `${namespace}:option.1.selected`, }, ], }); @@ -129,7 +114,7 @@ describe("Lost at Sea - Mystery Encounter", () => { const laprasSpecies = getPokemonSpecies(Species.LAPRAS); await game.runToMysteryEncounter(MysteryEncounterType.LOST_AT_SEA, defaultParty); - const party = game.scene.getParty(); + const party = game.scene.getPlayerParty(); const blastoise = party.find((pkm) => pkm.species.speciesId === Species.BLASTOISE); const expBefore = blastoise!.exp; @@ -150,7 +135,7 @@ describe("Lost at Sea - Mystery Encounter", () => { }); it("should be disabled if no surfable PKM is in party", async () => { - await game.runToMysteryEncounter(MysteryEncounterType.LOST_AT_SEA, [Species.ARCANINE]); + await game.runToMysteryEncounter(MysteryEncounterType.LOST_AT_SEA, [ Species.ARCANINE ]); await game.phaseInterceptor.to(MysteryEncounterPhase, false); const encounterPhase = scene.getCurrentPhase(); @@ -176,13 +161,13 @@ describe("Lost at Sea - Mystery Encounter", () => { expect(option2.optionMode).toBe(MysteryEncounterOptionMode.DISABLED_OR_DEFAULT); expect(option2.dialogue).toBeDefined(); expect(option2.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.2.label`, - disabledButtonLabel: `${namespace}.option.2.label_disabled`, - buttonTooltip: `${namespace}.option.2.tooltip`, - disabledButtonTooltip: `${namespace}.option.2.tooltip_disabled`, + buttonLabel: `${namespace}:option.2.label`, + disabledButtonLabel: `${namespace}:option.2.label_disabled`, + buttonTooltip: `${namespace}:option.2.tooltip`, + disabledButtonTooltip: `${namespace}:option.2.tooltip_disabled`, selected: [ { - text: `${namespace}.option.2.selected`, + text: `${namespace}:option.2.selected`, }, ], }); @@ -194,7 +179,7 @@ describe("Lost at Sea - Mystery Encounter", () => { game.override.startingWave(wave); await game.runToMysteryEncounter(MysteryEncounterType.LOST_AT_SEA, defaultParty); - const party = game.scene.getParty(); + const party = game.scene.getPlayerParty(); const pidgeot = party.find((pkm) => pkm.species.speciesId === Species.PIDGEOT); const expBefore = pidgeot!.exp; @@ -215,7 +200,7 @@ describe("Lost at Sea - Mystery Encounter", () => { }); it("should be disabled if no flyable PKM is in party", async () => { - await game.runToMysteryEncounter(MysteryEncounterType.LOST_AT_SEA, [Species.ARCANINE]); + await game.runToMysteryEncounter(MysteryEncounterType.LOST_AT_SEA, [ Species.ARCANINE ]); await game.phaseInterceptor.to(MysteryEncounterPhase, false); const encounterPhase = scene.getCurrentPhase(); @@ -241,11 +226,11 @@ describe("Lost at Sea - Mystery Encounter", () => { expect(option3.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option3.dialogue).toBeDefined(); expect(option3.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, selected: [ { - text: `${namespace}.option.3.selected`, + text: `${namespace}:option.3.selected`, }, ], }); @@ -256,7 +241,7 @@ describe("Lost at Sea - Mystery Encounter", () => { await game.runToMysteryEncounter(MysteryEncounterType.LOST_AT_SEA, defaultParty); - const party = game.scene.getParty(); + const party = game.scene.getPlayerParty(); const abra = party.find((pkm) => pkm.species.speciesId === Species.ABRA)!; vi.spyOn(abra, "isAllowedInBattle").mockReturnValue(false); diff --git a/src/test/mystery-encounter/encounters/mysterious-challengers-encounter.test.ts b/src/test/mystery-encounter/encounters/mysterious-challengers-encounter.test.ts index de527538711..7bbc505dd8e 100644 --- a/src/test/mystery-encounter/encounters/mysterious-challengers-encounter.test.ts +++ b/src/test/mystery-encounter/encounters/mysterious-challengers-encounter.test.ts @@ -21,8 +21,8 @@ import MysteryEncounter from "#app/data/mystery-encounters/mystery-encounter"; import { CommandPhase } from "#app/phases/command-phase"; import { SelectModifierPhase } from "#app/phases/select-modifier-phase"; -const namespace = "mysteryEncounter:mysteriousChallengers"; -const defaultParty = [Species.LAPRAS, Species.GENGAR, Species.ABRA]; +const namespace = "mysteryEncounters/mysteriousChallengers"; +const defaultParty = [ Species.LAPRAS, Species.GENGAR, Species.ABRA ]; const defaultBiome = Biome.CAVE; const defaultWave = 45; @@ -44,10 +44,10 @@ describe("Mysterious Challengers - Mystery Encounter", () => { game.override.disableTrainerWaves(); const biomeMap = new Map([ - [Biome.VOLCANO, [MysteryEncounterType.FIGHT_OR_FLIGHT]], + [ Biome.VOLCANO, [ MysteryEncounterType.FIGHT_OR_FLIGHT ]], ]); HUMAN_TRANSITABLE_BIOMES.forEach(biome => { - biomeMap.set(biome, [MysteryEncounterType.MYSTERIOUS_CHALLENGERS]); + biomeMap.set(biome, [ MysteryEncounterType.MYSTERIOUS_CHALLENGERS ]); }); vi.spyOn(MysteryEncounters, "mysteryEncountersByBiome", "get").mockReturnValue(biomeMap); }); @@ -64,10 +64,10 @@ describe("Mysterious Challengers - Mystery Encounter", () => { expect(MysteriousChallengersEncounter.encounterType).toBe(MysteryEncounterType.MYSTERIOUS_CHALLENGERS); expect(MysteriousChallengersEncounter.encounterTier).toBe(MysteryEncounterTier.GREAT); expect(MysteriousChallengersEncounter.dialogue).toBeDefined(); - expect(MysteriousChallengersEncounter.dialogue.intro).toStrictEqual([{ text: `${namespace}.intro` }]); - expect(MysteriousChallengersEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}.title`); - expect(MysteriousChallengersEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}.description`); - expect(MysteriousChallengersEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}.query`); + expect(MysteriousChallengersEncounter.dialogue.intro).toStrictEqual([{ text: `${namespace}:intro` }]); + expect(MysteriousChallengersEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}:title`); + expect(MysteriousChallengersEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}:description`); + expect(MysteriousChallengersEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}:query`); expect(MysteriousChallengersEncounter.options.length).toBe(3); }); @@ -79,22 +79,6 @@ describe("Mysterious Challengers - Mystery Encounter", () => { expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.MYSTERIOUS_CHALLENGERS); }); - it("should not run below wave 10", async () => { - game.override.startingWave(9); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.MYSTERIOUS_CHALLENGERS); - }); - - it("should not run above wave 179", async () => { - game.override.startingWave(181); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle.mysteryEncounter).toBeUndefined(); - }); - it("should initialize fully", async () => { initSceneWithoutEncounterPhase(scene, defaultParty); scene.currentBattle.mysteryEncounter = new MysteryEncounter(MysteriousChallengersEncounter); @@ -117,12 +101,12 @@ describe("Mysterious Challengers - Mystery Encounter", () => { }, { trainerConfig: expect.any(TrainerConfig), - levelAdditiveMultiplier: 1, + levelAdditiveModifier: 1, female: expect.any(Boolean), }, { trainerConfig: expect.any(TrainerConfig), - levelAdditiveMultiplier: 1.5, + levelAdditiveModifier: 1.5, female: expect.any(Boolean), } ]); @@ -146,11 +130,11 @@ describe("Mysterious Challengers - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.selected`, + text: `${namespace}:option.selected`, }, ], }); @@ -188,11 +172,11 @@ describe("Mysterious Challengers - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, selected: [ { - text: `${namespace}.option.selected`, + text: `${namespace}:option.selected`, }, ], }); @@ -231,11 +215,11 @@ describe("Mysterious Challengers - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, selected: [ { - text: `${namespace}.option.selected`, + text: `${namespace}:option.selected`, }, ], }); diff --git a/src/test/mystery-encounter/encounters/part-timer-encounter.test.ts b/src/test/mystery-encounter/encounters/part-timer-encounter.test.ts index f73c1f437d0..e063a4f3349 100644 --- a/src/test/mystery-encounter/encounters/part-timer-encounter.test.ts +++ b/src/test/mystery-encounter/encounters/part-timer-encounter.test.ts @@ -15,9 +15,9 @@ import { PokemonMove } from "#app/field/pokemon"; import { Moves } from "#enums/moves"; import { MysteryEncounterPhase } from "#app/phases/mystery-encounter-phases"; -const namespace = "mysteryEncounter:partTimer"; +const namespace = "mysteryEncounters/partTimer"; // Pyukumuku for lowest speed, Regieleki for highest speed, Feebas for lowest "bulk", Melmetal for highest "bulk" -const defaultParty = [Species.PYUKUMUKU, Species.REGIELEKI, Species.FEEBAS, Species.MELMETAL]; +const defaultParty = [ Species.PYUKUMUKU, Species.REGIELEKI, Species.FEEBAS, Species.MELMETAL ]; const defaultBiome = Biome.PLAINS; const defaultWave = 37; @@ -39,10 +39,10 @@ describe("Part-Timer - Mystery Encounter", () => { game.override.disableTrainerWaves(); const biomeMap = new Map([ - [Biome.VOLCANO, [MysteryEncounterType.MYSTERIOUS_CHALLENGERS]], + [ Biome.VOLCANO, [ MysteryEncounterType.MYSTERIOUS_CHALLENGERS ]], ]); CIVILIZATION_ENCOUNTER_BIOMES.forEach(biome => { - biomeMap.set(biome, [MysteryEncounterType.PART_TIMER]); + biomeMap.set(biome, [ MysteryEncounterType.PART_TIMER ]); }); vi.spyOn(MysteryEncounters, "mysteryEncountersByBiome", "get").mockReturnValue(biomeMap); }); @@ -60,15 +60,15 @@ describe("Part-Timer - Mystery Encounter", () => { expect(PartTimerEncounter.encounterTier).toBe(MysteryEncounterTier.COMMON); expect(PartTimerEncounter.dialogue).toBeDefined(); expect(PartTimerEncounter.dialogue.intro).toStrictEqual([ - { text: `${namespace}.intro` }, + { text: `${namespace}:intro` }, { - speaker: `${namespace}.speaker`, - text: `${namespace}.intro_dialogue`, + speaker: `${namespace}:speaker`, + text: `${namespace}:intro_dialogue`, } ]); - expect(PartTimerEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}.title`); - expect(PartTimerEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}.description`); - expect(PartTimerEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}.query`); + expect(PartTimerEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}:title`); + expect(PartTimerEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}:description`); + expect(PartTimerEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}:query`); expect(PartTimerEncounter.options.length).toBe(3); }); @@ -80,33 +80,17 @@ describe("Part-Timer - Mystery Encounter", () => { expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.PART_TIMER); }); - it("should not run below wave 10", async () => { - game.override.startingWave(9); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.PART_TIMER); - }); - - it("should not run above wave 179", async () => { - game.override.startingWave(181); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle.mysteryEncounter).toBeUndefined(); - }); - describe("Option 1 - Make Deliveries", () => { it("should have the correct properties", () => { const option = PartTimerEncounter.options[0]; expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.1.selected` + text: `${namespace}:option.1.selected` } ] }); @@ -117,7 +101,7 @@ describe("Part-Timer - Mystery Encounter", () => { await game.runToMysteryEncounter(MysteryEncounterType.PART_TIMER, defaultParty); // Override party levels to 50 so stats can be fully reflective - scene.getParty().forEach(p => { + scene.getPlayerParty().forEach(p => { p.level = 50; p.calculateStats(); }); @@ -125,7 +109,7 @@ describe("Part-Timer - Mystery Encounter", () => { expect(EncounterPhaseUtils.updatePlayerMoney).toHaveBeenCalledWith(scene, scene.getWaveMoneyAmount(1), true, false); // Expect PP of mon's moves to have been reduced to 2 - const moves = scene.getParty()[0].moveset; + const moves = scene.getPlayerParty()[0].moveset; for (const move of moves) { expect((move?.getMovePp() ?? 0) - (move?.ppUsed ?? 0)).toBe(2); } @@ -136,16 +120,16 @@ describe("Part-Timer - Mystery Encounter", () => { await game.runToMysteryEncounter(MysteryEncounterType.PART_TIMER, defaultParty); // Override party levels to 50 so stats can be fully reflective - scene.getParty().forEach(p => { + scene.getPlayerParty().forEach(p => { p.level = 50; - p.ivs = [20, 20, 20, 20, 20, 20]; + p.ivs = [ 20, 20, 20, 20, 20, 20 ]; p.calculateStats(); }); await runMysteryEncounterToEnd(game, 1, { pokemonNo: 2 }); expect(EncounterPhaseUtils.updatePlayerMoney).toHaveBeenCalledWith(scene, scene.getWaveMoneyAmount(4), true, false); // Expect PP of mon's moves to have been reduced to 2 - const moves = scene.getParty()[1].moveset; + const moves = scene.getPlayerParty()[1].moveset; for (const move of moves) { expect((move?.getMovePp() ?? 0) - (move?.ppUsed ?? 0)).toBe(2); } @@ -167,11 +151,11 @@ describe("Part-Timer - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, selected: [ { - text: `${namespace}.option.2.selected` + text: `${namespace}:option.2.selected` } ] }); @@ -182,7 +166,7 @@ describe("Part-Timer - Mystery Encounter", () => { await game.runToMysteryEncounter(MysteryEncounterType.PART_TIMER, defaultParty); // Override party levels to 50 so stats can be fully reflective - scene.getParty().forEach(p => { + scene.getPlayerParty().forEach(p => { p.level = 50; p.calculateStats(); }); @@ -190,7 +174,7 @@ describe("Part-Timer - Mystery Encounter", () => { expect(EncounterPhaseUtils.updatePlayerMoney).toHaveBeenCalledWith(scene, scene.getWaveMoneyAmount(1), true, false); // Expect PP of mon's moves to have been reduced to 2 - const moves = scene.getParty()[2].moveset; + const moves = scene.getPlayerParty()[2].moveset; for (const move of moves) { expect((move?.getMovePp() ?? 0) - (move?.ppUsed ?? 0)).toBe(2); } @@ -201,16 +185,16 @@ describe("Part-Timer - Mystery Encounter", () => { await game.runToMysteryEncounter(MysteryEncounterType.PART_TIMER, defaultParty); // Override party levels to 50 so stats can be fully reflective - scene.getParty().forEach(p => { + scene.getPlayerParty().forEach(p => { p.level = 50; - p.ivs = [20, 20, 20, 20, 20, 20]; + p.ivs = [ 20, 20, 20, 20, 20, 20 ]; p.calculateStats(); }); await runMysteryEncounterToEnd(game, 2, { pokemonNo: 4 }); expect(EncounterPhaseUtils.updatePlayerMoney).toHaveBeenCalledWith(scene, scene.getWaveMoneyAmount(4), true, false); // Expect PP of mon's moves to have been reduced to 2 - const moves = scene.getParty()[3].moveset; + const moves = scene.getPlayerParty()[3].moveset; for (const move of moves) { expect((move?.getMovePp() ?? 0) - (move?.ppUsed ?? 0)).toBe(2); } @@ -232,12 +216,12 @@ describe("Part-Timer - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DISABLED_OR_SPECIAL); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, - disabledButtonTooltip: `${namespace}.option.3.disabled_tooltip`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, + disabledButtonTooltip: `${namespace}:option.3.disabled_tooltip`, selected: [ { - text: `${namespace}.option.3.selected` + text: `${namespace}:option.3.selected` } ] }); @@ -248,7 +232,7 @@ describe("Part-Timer - Mystery Encounter", () => { await game.runToMysteryEncounter(MysteryEncounterType.PART_TIMER, defaultParty); // Mock movesets - scene.getParty().forEach(p => p.moveset = []); + scene.getPlayerParty().forEach(p => p.moveset = []); await game.phaseInterceptor.to(MysteryEncounterPhase, false); const encounterPhase = scene.getCurrentPhase(); @@ -272,12 +256,12 @@ describe("Part-Timer - Mystery Encounter", () => { await game.runToMysteryEncounter(MysteryEncounterType.PART_TIMER, defaultParty); // Mock moveset - scene.getParty()[0].moveset = [new PokemonMove(Moves.ATTRACT)]; + scene.getPlayerParty()[0].moveset = [ new PokemonMove(Moves.ATTRACT) ]; await runMysteryEncounterToEnd(game, 3); expect(EncounterPhaseUtils.updatePlayerMoney).toHaveBeenCalledWith(scene, scene.getWaveMoneyAmount(2.5), true, false); // Expect PP of mon's moves to have been reduced to 2 - const moves = scene.getParty()[0].moveset; + const moves = scene.getPlayerParty()[0].moveset; for (const move of moves) { expect((move?.getMovePp() ?? 0) - (move?.ppUsed ?? 0)).toBe(2); } diff --git a/src/test/mystery-encounter/encounters/teleporting-hijinks-encounter.test.ts b/src/test/mystery-encounter/encounters/teleporting-hijinks-encounter.test.ts index 13860e83baa..02375d83b98 100644 --- a/src/test/mystery-encounter/encounters/teleporting-hijinks-encounter.test.ts +++ b/src/test/mystery-encounter/encounters/teleporting-hijinks-encounter.test.ts @@ -1,26 +1,30 @@ -import * as MysteryEncounters from "#app/data/mystery-encounters/mystery-encounters"; -import { Biome } from "#app/enums/biome"; -import { MysteryEncounterType } from "#app/enums/mystery-encounter-type"; -import { Species } from "#app/enums/species"; -import GameManager from "#app/test/utils/gameManager"; -import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; -import { runMysteryEncounterToEnd, runSelectMysteryEncounterOption, skipBattleRunMysteryEncounterRewardsPhase } from "#test/mystery-encounter/encounter-test-utils"; import BattleScene from "#app/battle-scene"; +import { TeleportingHijinksEncounter } from "#app/data/mystery-encounters/encounters/teleporting-hijinks-encounter"; +import * as MysteryEncounters from "#app/data/mystery-encounters/mystery-encounters"; +import { Abilities } from "#enums/abilities"; +import { Biome } from "#enums/biome"; +import { MysteryEncounterType } from "#enums/mystery-encounter-type"; +import { Species } from "#enums/species"; +import { CommandPhase } from "#app/phases/command-phase"; +import { MysteryEncounterPhase } from "#app/phases/mystery-encounter-phases"; +import { SelectModifierPhase } from "#app/phases/select-modifier-phase"; +import GameManager from "#test/utils/gameManager"; +import ModifierSelectUiHandler from "#app/ui/modifier-select-ui-handler"; +import { Mode } from "#app/ui/ui"; import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode"; import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; +import { runMysteryEncounterToEnd, runSelectMysteryEncounterOption, skipBattleRunMysteryEncounterRewardsPhase } from "#test/mystery-encounter/encounter-test-utils"; import { initSceneWithoutEncounterPhase } from "#test/utils/gameManagerUtils"; -import { MysteryEncounterPhase } from "#app/phases/mystery-encounter-phases"; -import { CommandPhase } from "#app/phases/command-phase"; -import { TeleportingHijinksEncounter } from "#app/data/mystery-encounters/encounters/teleporting-hijinks-encounter"; -import { SelectModifierPhase } from "#app/phases/select-modifier-phase"; -import { Mode } from "#app/ui/ui"; -import ModifierSelectUiHandler from "#app/ui/modifier-select-ui-handler"; +import i18next from "i18next"; +import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; -const namespace = "mysteryEncounter:teleportingHijinks"; -const defaultParty = [Species.LAPRAS, Species.GENGAR, Species.ABRA]; +const namespace = "mysteryEncounters/teleportingHijinks"; +const defaultParty = [ Species.LAPRAS, Species.GENGAR, Species.ABRA ]; const defaultBiome = Biome.CAVE; const defaultWave = 45; +const TRANSPORT_BIOMES = [ Biome.SPACE, Biome.ISLAND, Biome.LABORATORY, Biome.FAIRY_CAVE, Biome.WASTELAND, Biome.DOJO ]; + describe("Teleporting Hijinks - Mystery Encounter", () => { let phaserGame: Phaser.Game; let game: GameManager; @@ -34,14 +38,17 @@ describe("Teleporting Hijinks - Mystery Encounter", () => { game = new GameManager(phaserGame); scene = game.scene; scene.money = 20000; - game.override.mysteryEncounterChance(100); - game.override.startingWave(defaultWave); - game.override.startingBiome(defaultBiome); - game.override.disableTrainerWaves(); + game.override + .mysteryEncounterChance(100) + .startingWave(defaultWave) + .startingBiome(defaultBiome) + .disableTrainerWaves() + .enemyAbility(Abilities.BALL_FETCH) + .enemyPassiveAbility(Abilities.BALL_FETCH); vi.spyOn(MysteryEncounters, "mysteryEncountersByBiome", "get").mockReturnValue( new Map([ - [Biome.CAVE, [MysteryEncounterType.TELEPORTING_HIJINKS]], + [ Biome.CAVE, [ MysteryEncounterType.TELEPORTING_HIJINKS ]], ]) ); }); @@ -58,29 +65,13 @@ describe("Teleporting Hijinks - Mystery Encounter", () => { expect(TeleportingHijinksEncounter.encounterType).toBe(MysteryEncounterType.TELEPORTING_HIJINKS); expect(TeleportingHijinksEncounter.encounterTier).toBe(MysteryEncounterTier.COMMON); expect(TeleportingHijinksEncounter.dialogue).toBeDefined(); - expect(TeleportingHijinksEncounter.dialogue.intro).toStrictEqual([{ text: `${namespace}.intro` }]); - expect(TeleportingHijinksEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}.title`); - expect(TeleportingHijinksEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}.description`); - expect(TeleportingHijinksEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}.query`); + expect(TeleportingHijinksEncounter.dialogue.intro).toStrictEqual([{ text: `${namespace}:intro` }]); + expect(TeleportingHijinksEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}:title`); + expect(TeleportingHijinksEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}:description`); + expect(TeleportingHijinksEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}:query`); expect(TeleportingHijinksEncounter.options.length).toBe(3); }); - it("should not run below wave 10", async () => { - game.override.startingWave(9); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.TELEPORTING_HIJINKS); - }); - - it("should not run above wave 179", async () => { - game.override.startingWave(181); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle.mysteryEncounter).toBeUndefined(); - }); - it("should run in waves that are X1", async () => { game.override.startingWave(11); game.override.mysteryEncounterTier(MysteryEncounterTier.COMMON); @@ -138,11 +129,11 @@ describe("Teleporting Hijinks - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DISABLED_OR_DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.1.selected`, + text: `${namespace}:option.1.selected`, }, ], }); @@ -183,14 +174,23 @@ describe("Teleporting Hijinks - Mystery Encounter", () => { await runMysteryEncounterToEnd(game, 1, undefined, true); expect(previousBiome).not.toBe(scene.arena.biomeType); - expect([Biome.SPACE, Biome.ISLAND, Biome.LABORATORY, Biome.FAIRY_CAVE]).toContain(scene.arena.biomeType); + expect(TRANSPORT_BIOMES).toContain(scene.arena.biomeType); }); - it("should start a battle against an enraged boss", { retry: 5 }, async () => { + it("should start a battle against an enraged boss below wave 50", { retry: 5 }, async () => { await game.runToMysteryEncounter(MysteryEncounterType.TELEPORTING_HIJINKS, defaultParty); await runMysteryEncounterToEnd(game, 1, undefined, true); const enemyField = scene.getEnemyField(); - expect(enemyField[0].summonData.statStages).toEqual([1, 1, 1, 1, 1, 0, 0]); + expect(enemyField[0].summonData.statStages).toEqual([ 0, 1, 0, 1, 1, 0, 0 ]); + expect(enemyField[0].isBoss()).toBe(true); + }); + + it("should start a battle against an extra enraged boss above wave 50", { retry: 5 }, async () => { + game.override.startingWave(56); + await game.runToMysteryEncounter(MysteryEncounterType.TELEPORTING_HIJINKS, defaultParty); + await runMysteryEncounterToEnd(game, 1, undefined, true); + const enemyField = scene.getEnemyField(); + expect(enemyField[0].summonData.statStages).toEqual([ 1, 1, 1, 1, 1, 0, 0 ]); expect(enemyField[0].isBoss()).toBe(true); }); }); @@ -201,19 +201,19 @@ describe("Teleporting Hijinks - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DISABLED_OR_SPECIAL); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, - disabledButtonTooltip: `${namespace}.option.2.disabled_tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, + disabledButtonTooltip: `${namespace}:option.2.disabled_tooltip`, selected: [ { - text: `${namespace}.option.2.selected`, + text: `${namespace}:option.2.selected`, } ], }); }); it("should NOT be selectable if the player doesn't the right type pokemon", async () => { - await game.runToMysteryEncounter(MysteryEncounterType.TELEPORTING_HIJINKS, [Species.BLASTOISE]); + await game.runToMysteryEncounter(MysteryEncounterType.TELEPORTING_HIJINKS, [ Species.BLASTOISE ]); await game.phaseInterceptor.to(MysteryEncounterPhase, false); const encounterPhase = scene.getCurrentPhase(); @@ -232,28 +232,37 @@ describe("Teleporting Hijinks - Mystery Encounter", () => { }); it("should be selectable if the player has the right type pokemon", async () => { - await game.runToMysteryEncounter(MysteryEncounterType.TELEPORTING_HIJINKS, [Species.METAGROSS]); + await game.runToMysteryEncounter(MysteryEncounterType.TELEPORTING_HIJINKS, [ Species.METAGROSS ]); await runMysteryEncounterToEnd(game, 2, undefined, true); expect(scene.getCurrentPhase()?.constructor.name).toBe(CommandPhase.name); }); it("should transport to a new area", async () => { - await game.runToMysteryEncounter(MysteryEncounterType.TELEPORTING_HIJINKS, [Species.PIKACHU]); + await game.runToMysteryEncounter(MysteryEncounterType.TELEPORTING_HIJINKS, [ Species.PIKACHU ]); const previousBiome = scene.arena.biomeType; await runMysteryEncounterToEnd(game, 2, undefined, true); expect(previousBiome).not.toBe(scene.arena.biomeType); - expect([Biome.SPACE, Biome.ISLAND, Biome.LABORATORY, Biome.FAIRY_CAVE]).toContain(scene.arena.biomeType); + expect(TRANSPORT_BIOMES).toContain(scene.arena.biomeType); }); - it("should start a battle against an enraged boss", async () => { - await game.runToMysteryEncounter(MysteryEncounterType.TELEPORTING_HIJINKS, [Species.PIKACHU]); + it("should start a battle against an enraged boss below wave 50", async () => { + await game.runToMysteryEncounter(MysteryEncounterType.TELEPORTING_HIJINKS, [ Species.PIKACHU ]); await runMysteryEncounterToEnd(game, 2, undefined, true); const enemyField = scene.getEnemyField(); - expect(enemyField[0].summonData.statStages).toEqual([1, 1, 1, 1, 1, 0, 0]); + expect(enemyField[0].summonData.statStages).toEqual([ 0, 1, 0, 1, 1, 0, 0 ]); + expect(enemyField[0].isBoss()).toBe(true); + }); + + it("should start a battle against an extra enraged boss above wave 50", { retry: 5 }, async () => { + game.override.startingWave(56); + await game.runToMysteryEncounter(MysteryEncounterType.TELEPORTING_HIJINKS, [ Species.PIKACHU ]); + await runMysteryEncounterToEnd(game, 2, undefined, true); + const enemyField = scene.getEnemyField(); + expect(enemyField[0].summonData.statStages).toEqual([ 1, 1, 1, 1, 1, 0, 0 ]); expect(enemyField[0].isBoss()).toBe(true); }); }); @@ -264,11 +273,11 @@ describe("Teleporting Hijinks - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, selected: [ { - text: `${namespace}.option.3.selected`, + text: `${namespace}:option.3.selected`, }, ], }); @@ -278,7 +287,7 @@ describe("Teleporting Hijinks - Mystery Encounter", () => { await game.runToMysteryEncounter(MysteryEncounterType.TELEPORTING_HIJINKS, defaultParty); await runMysteryEncounterToEnd(game, 3, undefined, true); const enemyField = scene.getEnemyField(); - expect(enemyField[0].summonData.statStages).toEqual([0, 0, 0, 0, 0, 0, 0]); + expect(enemyField[0].summonData.statStages).toEqual([ 0, 0, 0, 0, 0, 0, 0 ]); expect(enemyField[0].isBoss()).toBe(true); }); @@ -292,8 +301,8 @@ describe("Teleporting Hijinks - Mystery Encounter", () => { expect(scene.ui.getMode()).to.equal(Mode.MODIFIER_SELECT); const modifierSelectHandler = scene.ui.handlers.find(h => h instanceof ModifierSelectUiHandler) as ModifierSelectUiHandler; - expect(modifierSelectHandler.options.some(opt => opt.modifierTypeOption.type.name === "Metal Coat")).toBe(true); - expect(modifierSelectHandler.options.some(opt => opt.modifierTypeOption.type.name === "Magnet")).toBe(true); + expect(modifierSelectHandler.options.some(opt => opt.modifierTypeOption.type.name === i18next.t("modifierType:AttackTypeBoosterItem.metal_coat"))).toBe(true); + expect(modifierSelectHandler.options.some(opt => opt.modifierTypeOption.type.name === i18next.t("modifierType:AttackTypeBoosterItem.magnet"))).toBe(true); }); }); }); diff --git a/src/test/mystery-encounter/encounters/the-expert-breeder-encounter.test.ts b/src/test/mystery-encounter/encounters/the-expert-breeder-encounter.test.ts new file mode 100644 index 00000000000..7fc2490fcc9 --- /dev/null +++ b/src/test/mystery-encounter/encounters/the-expert-breeder-encounter.test.ts @@ -0,0 +1,346 @@ +import * as MysteryEncounters from "#app/data/mystery-encounters/mystery-encounters"; +import { HUMAN_TRANSITABLE_BIOMES } from "#app/data/mystery-encounters/mystery-encounters"; +import { Biome } from "#app/enums/biome"; +import { MysteryEncounterType } from "#app/enums/mystery-encounter-type"; +import { Species } from "#app/enums/species"; +import GameManager from "#app/test/utils/gameManager"; +import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; +import { runMysteryEncounterToEnd, skipBattleRunMysteryEncounterRewardsPhase } from "#test/mystery-encounter/encounter-test-utils"; +import BattleScene from "#app/battle-scene"; +import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode"; +import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; +import { initSceneWithoutEncounterPhase } from "#test/utils/gameManagerUtils"; +import { MysteryEncounterMode } from "#enums/mystery-encounter-mode"; +import MysteryEncounter from "#app/data/mystery-encounters/mystery-encounter"; +import { CommandPhase } from "#app/phases/command-phase"; +import { SelectModifierPhase } from "#app/phases/select-modifier-phase"; +import { TheExpertPokemonBreederEncounter } from "#app/data/mystery-encounters/encounters/the-expert-pokemon-breeder-encounter"; +import { TrainerType } from "#enums/trainer-type"; +import { EggTier } from "#enums/egg-type"; +import { PostMysteryEncounterPhase } from "#app/phases/mystery-encounter-phases"; + +const namespace = "mysteryEncounters/theExpertPokemonBreeder"; +const defaultParty = [ Species.LAPRAS, Species.GENGAR, Species.ABRA ]; +const defaultBiome = Biome.CAVE; +const defaultWave = 45; + +describe("The Expert Pokémon Breeder - Mystery Encounter", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + let scene: BattleScene; + + beforeAll(() => { + phaserGame = new Phaser.Game({ type: Phaser.HEADLESS }); + }); + + beforeEach(async () => { + game = new GameManager(phaserGame); + scene = game.scene; + game.override.mysteryEncounterChance(100); + game.override.startingWave(defaultWave); + game.override.startingBiome(defaultBiome); + game.override.disableTrainerWaves(); + + const biomeMap = new Map([ + [ Biome.VOLCANO, [ MysteryEncounterType.FIGHT_OR_FLIGHT ]], + ]); + HUMAN_TRANSITABLE_BIOMES.forEach(biome => { + biomeMap.set(biome, [ MysteryEncounterType.THE_EXPERT_POKEMON_BREEDER ]); + }); + vi.spyOn(MysteryEncounters, "mysteryEncountersByBiome", "get").mockReturnValue(biomeMap); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + vi.clearAllMocks(); + vi.resetAllMocks(); + }); + + it("should have the correct properties", async () => { + await game.runToMysteryEncounter(MysteryEncounterType.THE_EXPERT_POKEMON_BREEDER, defaultParty); + + expect(TheExpertPokemonBreederEncounter.encounterType).toBe(MysteryEncounterType.THE_EXPERT_POKEMON_BREEDER); + expect(TheExpertPokemonBreederEncounter.encounterTier).toBe(MysteryEncounterTier.ULTRA); + expect(TheExpertPokemonBreederEncounter.dialogue).toBeDefined(); + expect(TheExpertPokemonBreederEncounter.dialogue.intro).toStrictEqual([ + { + text: `${namespace}:intro` + }, + { + speaker: "trainerNames:expert_pokemon_breeder", + text: `${namespace}:intro_dialogue` + }, + ]); + expect(TheExpertPokemonBreederEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}:title`); + expect(TheExpertPokemonBreederEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}:description`); + expect(TheExpertPokemonBreederEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}:query`); + expect(TheExpertPokemonBreederEncounter.options.length).toBe(3); + }); + + it("should not spawn outside of HUMAN_TRANSITABLE_BIOMES", async () => { + game.override.mysteryEncounterTier(MysteryEncounterTier.GREAT); + game.override.startingBiome(Biome.VOLCANO); + await game.runToMysteryEncounter(); + + expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.THE_EXPERT_POKEMON_BREEDER); + }); + + it("should initialize fully", async () => { + initSceneWithoutEncounterPhase(scene, defaultParty); + scene.currentBattle.mysteryEncounter = new MysteryEncounter(TheExpertPokemonBreederEncounter); + const encounter = scene.currentBattle.mysteryEncounter!; + scene.currentBattle.waveIndex = defaultWave; + + const { onInit } = encounter; + + expect(encounter.onInit).toBeDefined(); + + encounter.populateDialogueTokensFromRequirements(scene); + const onInitResult = onInit!(scene); + + expect(encounter.enemyPartyConfigs).toBeDefined(); + expect(encounter.enemyPartyConfigs.length).toBe(1); + expect(encounter.enemyPartyConfigs[0].trainerType).toBe(TrainerType.EXPERT_POKEMON_BREEDER); + expect(encounter.enemyPartyConfigs[0].pokemonConfigs?.length).toBe(3); + expect(encounter.spriteConfigs).toBeDefined(); + expect(encounter.spriteConfigs.length).toBe(2); + expect(onInitResult).toBe(true); + }); + + describe("Option 1 - Battle with Pokemon 1", () => { + it("should have the correct properties", () => { + const option = TheExpertPokemonBreederEncounter.options[0]; + expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); + expect(option.dialogue).toBeDefined(); + expect(option.dialogue).toStrictEqual({ + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: expect.any(String), // Varies based on pokemon + selected: [ + { + speaker: "trainerNames:expert_pokemon_breeder", + text: `${namespace}:option.selected`, + }, + ], + }); + }); + + it("should start battle against the trainer with correctly loaded assets", async () => { + await game.runToMysteryEncounter(MysteryEncounterType.THE_EXPERT_POKEMON_BREEDER, defaultParty); + + let successfullyLoaded = false; + vi.spyOn(scene, "getEnemyParty").mockImplementation(() => { + const ace = scene.currentBattle?.enemyParty[0]; + if (ace) { + // Pretend that loading assets takes an extra 500ms + vi.spyOn(ace, "loadAssets").mockImplementation(() => new Promise(resolve => { + setTimeout(() => { + successfullyLoaded = true; + resolve(); + }, 500); + })); + } + + return scene.currentBattle?.enemyParty ?? []; + }); + + await runMysteryEncounterToEnd(game, 1, undefined, true); + + // Check that assets are successfully loaded + expect(successfullyLoaded).toBe(true); + + // Check usual battle stuff + expect(scene.getCurrentPhase()?.constructor.name).toBe(CommandPhase.name); + expect(scene.currentBattle.trainer).toBeDefined(); + expect(scene.currentBattle.mysteryEncounter?.encounterMode).toBe(MysteryEncounterMode.TRAINER_BATTLE); + expect(scene.getPlayerParty().length).toBe(1); + }); + + it("Should reward the player with friendship and eggs based on pokemon selected", async () => { + await game.runToMysteryEncounter(MysteryEncounterType.THE_EXPERT_POKEMON_BREEDER, defaultParty); + + const friendshipBefore = scene.currentBattle.mysteryEncounter!.misc.pokemon1.friendship; + + scene.gameData.eggs = []; + const eggsBefore = scene.gameData.eggs; + expect(eggsBefore).toBeDefined(); + const eggsBeforeLength = eggsBefore.length; + + await runMysteryEncounterToEnd(game, 1, undefined, true); + await skipBattleRunMysteryEncounterRewardsPhase(game); + await game.phaseInterceptor.to(SelectModifierPhase, false); + expect(scene.getCurrentPhase()?.constructor.name).toBe(SelectModifierPhase.name); + + const eggsAfter = scene.gameData.eggs; + const commonEggs = scene.currentBattle.mysteryEncounter!.misc.pokemon1CommonEggs; + const rareEggs = scene.currentBattle.mysteryEncounter!.misc.pokemon1RareEggs; + expect(eggsAfter).toBeDefined(); + expect(eggsBeforeLength + commonEggs + rareEggs).toBe(eggsAfter.length); + expect(eggsAfter.filter(egg => egg.tier === EggTier.COMMON).length).toBe(commonEggs); + expect(eggsAfter.filter(egg => egg.tier === EggTier.RARE).length).toBe(rareEggs); + + game.phaseInterceptor.superEndPhase(); + await game.phaseInterceptor.to(PostMysteryEncounterPhase); + + const friendshipAfter = scene.currentBattle.mysteryEncounter!.misc.pokemon1.friendship; + expect(friendshipAfter).toBe(friendshipBefore + 20 + 2); // +2 extra for friendship gained from winning battle + }); + }); + + describe("Option 2 - Battle with Pokemon 2", () => { + it("should have the correct properties", () => { + const option = TheExpertPokemonBreederEncounter.options[1]; + expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); + expect(option.dialogue).toBeDefined(); + expect(option.dialogue).toStrictEqual({ + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: expect.any(String), // Varies based on pokemon + selected: [ + { + speaker: "trainerNames:expert_pokemon_breeder", + text: `${namespace}:option.selected`, + }, + ], + }); + }); + + it("should start battle against the trainer with correctly loaded assets", async () => { + await game.runToMysteryEncounter(MysteryEncounterType.THE_EXPERT_POKEMON_BREEDER, defaultParty); + + let successfullyLoaded = false; + vi.spyOn(scene, "getEnemyParty").mockImplementation(() => { + const ace = scene.currentBattle?.enemyParty[0]; + if (ace) { + // Pretend that loading assets takes an extra 500ms + vi.spyOn(ace, "loadAssets").mockImplementation(() => new Promise(resolve => { + setTimeout(() => { + successfullyLoaded = true; + resolve(); + }, 500); + })); + } + + return scene.currentBattle?.enemyParty ?? []; + }); + + await runMysteryEncounterToEnd(game, 2, undefined, true); + + // Check that assets are successfully loaded + expect(successfullyLoaded).toBe(true); + + // Check usual battle stuff + expect(scene.getCurrentPhase()?.constructor.name).toBe(CommandPhase.name); + expect(scene.currentBattle.trainer).toBeDefined(); + expect(scene.currentBattle.mysteryEncounter?.encounterMode).toBe(MysteryEncounterMode.TRAINER_BATTLE); + expect(scene.getPlayerParty().length).toBe(1); + }); + + it("Should reward the player with friendship and eggs based on pokemon selected", async () => { + await game.runToMysteryEncounter(MysteryEncounterType.THE_EXPERT_POKEMON_BREEDER, defaultParty); + + const friendshipBefore = scene.currentBattle.mysteryEncounter!.misc.pokemon2.friendship; + + scene.gameData.eggs = []; + const eggsBefore = scene.gameData.eggs; + expect(eggsBefore).toBeDefined(); + const eggsBeforeLength = eggsBefore.length; + + await runMysteryEncounterToEnd(game, 2, undefined, true); + await skipBattleRunMysteryEncounterRewardsPhase(game); + await game.phaseInterceptor.to(SelectModifierPhase, false); + expect(scene.getCurrentPhase()?.constructor.name).toBe(SelectModifierPhase.name); + + const eggsAfter = scene.gameData.eggs; + const commonEggs = scene.currentBattle.mysteryEncounter!.misc.pokemon2CommonEggs; + const rareEggs = scene.currentBattle.mysteryEncounter!.misc.pokemon2RareEggs; + expect(eggsAfter).toBeDefined(); + expect(eggsBeforeLength + commonEggs + rareEggs).toBe(eggsAfter.length); + expect(eggsAfter.filter(egg => egg.tier === EggTier.COMMON).length).toBe(commonEggs); + expect(eggsAfter.filter(egg => egg.tier === EggTier.RARE).length).toBe(rareEggs); + + game.phaseInterceptor.superEndPhase(); + await game.phaseInterceptor.to(PostMysteryEncounterPhase); + + const friendshipAfter = scene.currentBattle.mysteryEncounter!.misc.pokemon2.friendship; + expect(friendshipAfter).toBe(friendshipBefore + 20 + 2); // +2 extra for friendship gained from winning battle + }); + }); + + describe("Option 3 - Battle with Pokemon 3", () => { + it("should have the correct properties", () => { + const option = TheExpertPokemonBreederEncounter.options[2]; + expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); + expect(option.dialogue).toBeDefined(); + expect(option.dialogue).toStrictEqual({ + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: expect.any(String), // Varies based on pokemon + selected: [ + { + speaker: "trainerNames:expert_pokemon_breeder", + text: `${namespace}:option.selected`, + }, + ], + }); + }); + + it("should start battle against the trainer with correctly loaded assets", async () => { + await game.runToMysteryEncounter(MysteryEncounterType.THE_EXPERT_POKEMON_BREEDER, defaultParty); + + let successfullyLoaded = false; + vi.spyOn(scene, "getEnemyParty").mockImplementation(() => { + const ace = scene.currentBattle?.enemyParty[0]; + if (ace) { + // Pretend that loading assets takes an extra 500ms + vi.spyOn(ace, "loadAssets").mockImplementation(() => new Promise(resolve => { + setTimeout(() => { + successfullyLoaded = true; + resolve(); + }, 500); + })); + } + + return scene.currentBattle?.enemyParty ?? []; + }); + + await runMysteryEncounterToEnd(game, 3, undefined, true); + + // Check that assets are successfully loaded + expect(successfullyLoaded).toBe(true); + + // Check usual battle stuff + expect(scene.getCurrentPhase()?.constructor.name).toBe(CommandPhase.name); + expect(scene.currentBattle.trainer).toBeDefined(); + expect(scene.currentBattle.mysteryEncounter?.encounterMode).toBe(MysteryEncounterMode.TRAINER_BATTLE); + expect(scene.getPlayerParty().length).toBe(1); + }); + + it("Should reward the player with friendship and eggs based on pokemon selected", async () => { + await game.runToMysteryEncounter(MysteryEncounterType.THE_EXPERT_POKEMON_BREEDER, defaultParty); + + const friendshipBefore = scene.currentBattle.mysteryEncounter!.misc.pokemon3.friendship; + + scene.gameData.eggs = []; + const eggsBefore = scene.gameData.eggs; + expect(eggsBefore).toBeDefined(); + const eggsBeforeLength = eggsBefore.length; + + await runMysteryEncounterToEnd(game, 3, undefined, true); + await skipBattleRunMysteryEncounterRewardsPhase(game); + await game.phaseInterceptor.to(SelectModifierPhase, false); + expect(scene.getCurrentPhase()?.constructor.name).toBe(SelectModifierPhase.name); + + const eggsAfter = scene.gameData.eggs; + const commonEggs = scene.currentBattle.mysteryEncounter!.misc.pokemon3CommonEggs; + const rareEggs = scene.currentBattle.mysteryEncounter!.misc.pokemon3RareEggs; + expect(eggsAfter).toBeDefined(); + expect(eggsBeforeLength + commonEggs + rareEggs).toBe(eggsAfter.length); + expect(eggsAfter.filter(egg => egg.tier === EggTier.COMMON).length).toBe(commonEggs); + expect(eggsAfter.filter(egg => egg.tier === EggTier.RARE).length).toBe(rareEggs); + + game.phaseInterceptor.superEndPhase(); + await game.phaseInterceptor.to(PostMysteryEncounterPhase); + + const friendshipAfter = scene.currentBattle.mysteryEncounter!.misc.pokemon3.friendship; + expect(friendshipAfter).toBe(friendshipBefore + 20 + 2); // +2 extra for friendship gained from winning battle + }); + }); +}); diff --git a/src/test/mystery-encounter/encounters/the-pokemon-salesman-encounter.test.ts b/src/test/mystery-encounter/encounters/the-pokemon-salesman-encounter.test.ts index c43577337da..a50c0cf4c9e 100644 --- a/src/test/mystery-encounter/encounters/the-pokemon-salesman-encounter.test.ts +++ b/src/test/mystery-encounter/encounters/the-pokemon-salesman-encounter.test.ts @@ -15,8 +15,8 @@ import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; import { initSceneWithoutEncounterPhase } from "#test/utils/gameManagerUtils"; import { MysteryEncounterPhase } from "#app/phases/mystery-encounter-phases"; -const namespace = "mysteryEncounter:pokemonSalesman"; -const defaultParty = [Species.LAPRAS, Species.GENGAR, Species.ABRA]; +const namespace = "mysteryEncounters/thePokemonSalesman"; +const defaultParty = [ Species.LAPRAS, Species.GENGAR, Species.ABRA ]; const defaultBiome = Biome.CAVE; const defaultWave = 45; @@ -38,10 +38,10 @@ describe("The Pokemon Salesman - Mystery Encounter", () => { game.override.disableTrainerWaves(); const biomeMap = new Map([ - [Biome.VOLCANO, [MysteryEncounterType.MYSTERIOUS_CHALLENGERS]], + [ Biome.VOLCANO, [ MysteryEncounterType.MYSTERIOUS_CHALLENGERS ]], ]); HUMAN_TRANSITABLE_BIOMES.forEach(biome => { - biomeMap.set(biome, [MysteryEncounterType.THE_POKEMON_SALESMAN]); + biomeMap.set(biome, [ MysteryEncounterType.THE_POKEMON_SALESMAN ]); }); vi.spyOn(MysteryEncounters, "mysteryEncountersByBiome", "get").mockReturnValue(biomeMap); }); @@ -53,19 +53,22 @@ describe("The Pokemon Salesman - Mystery Encounter", () => { }); it("should have the correct properties", async () => { + const { encounterType, encounterTier, dialogue, options } = ThePokemonSalesmanEncounter; + await game.runToMysteryEncounter(MysteryEncounterType.THE_POKEMON_SALESMAN, defaultParty); - expect(ThePokemonSalesmanEncounter.encounterType).toBe(MysteryEncounterType.THE_POKEMON_SALESMAN); - expect(ThePokemonSalesmanEncounter.encounterTier).toBe(MysteryEncounterTier.ULTRA); - expect(ThePokemonSalesmanEncounter.dialogue).toBeDefined(); - expect(ThePokemonSalesmanEncounter.dialogue.intro).toStrictEqual([ - { text: `${namespace}.intro` }, - { speaker: `${namespace}.speaker`, text: `${namespace}.intro_dialogue` } + expect(encounterType).toBe(MysteryEncounterType.THE_POKEMON_SALESMAN); + expect(encounterTier).toBe(MysteryEncounterTier.ULTRA); + expect(dialogue).toBeDefined(); + expect(dialogue.intro).toStrictEqual([ + { text: `${namespace}:intro` }, + { speaker: `${namespace}:speaker`, text: `${namespace}:intro_dialogue` } ]); - expect(ThePokemonSalesmanEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}.title`); - expect(ThePokemonSalesmanEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}.description`); - expect(ThePokemonSalesmanEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}.query`); - expect(ThePokemonSalesmanEncounter.options.length).toBe(2); + const { title, description, query } = dialogue.encounterOptionsDialogue!; + expect(title).toBe(`${namespace}:title`); + expect(description).toMatch(new RegExp(`^${namespace}\\:description(_shiny)?$`)); + expect(query).toBe(`${namespace}:query`); + expect(options.length).toBe(2); }); it("should not spawn outside of HUMAN_TRANSITABLE_BIOMES", async () => { @@ -76,22 +79,6 @@ describe("The Pokemon Salesman - Mystery Encounter", () => { expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.THE_POKEMON_SALESMAN); }); - it("should not run below wave 10", async () => { - game.override.startingWave(9); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.THE_POKEMON_SALESMAN); - }); - - it("should not run above wave 179", async () => { - game.override.startingWave(181); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle.mysteryEncounter).toBeUndefined(); - }); - it("should initialize fully ", async () => { initSceneWithoutEncounterPhase(scene, defaultParty); scene.currentBattle.mysteryEncounter = ThePokemonSalesmanEncounter; @@ -120,15 +107,16 @@ describe("The Pokemon Salesman - Mystery Encounter", () => { describe("Option 1 - Purchase the pokemon", () => { it("should have the correct properties", () => { - const option = ThePokemonSalesmanEncounter.options[0]; - expect(option.optionMode).toBe(MysteryEncounterOptionMode.DISABLED_OR_DEFAULT); - expect(option.dialogue).toBeDefined(); - expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + const { optionMode, dialogue } = ThePokemonSalesmanEncounter.options[0]; + + expect(optionMode).toBe(MysteryEncounterOptionMode.DISABLED_OR_DEFAULT); + expect(dialogue).toBeDefined(); + expect(dialogue).toStrictEqual({ + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: expect.stringMatching(new RegExp(`^${namespace}\\:option\\.1\\.tooltip(_shiny)?$`)), selected: [ { - text: `${namespace}.option.1.selected_message`, + text: `${namespace}:option.1.selected_message`, }, ], }); @@ -152,15 +140,15 @@ describe("The Pokemon Salesman - Mystery Encounter", () => { scene.money = 20000; await game.runToMysteryEncounter(MysteryEncounterType.THE_POKEMON_SALESMAN, defaultParty); - const initialPartySize = scene.getParty().length; + const initialPartySize = scene.getPlayerParty().length; const pokemonName = scene.currentBattle.mysteryEncounter!.misc.pokemon.name; await runMysteryEncounterToEnd(game, 1); - expect(scene.getParty().length).toBe(initialPartySize + 1); + expect(scene.getPlayerParty().length).toBe(initialPartySize + 1); - const newlyPurchasedPokemon = scene.getParty().find(p => p.name === pokemonName); - expect(newlyPurchasedPokemon).toBeDefined(); + const newlyPurchasedPokemon = scene.getPlayerParty()[scene.getPlayerParty().length - 1]; + expect(newlyPurchasedPokemon.name).toBe(pokemonName); expect(newlyPurchasedPokemon!.moveset.length > 0).toBeTruthy(); }); diff --git a/src/test/mystery-encounter/encounters/the-strong-stuff-encounter.test.ts b/src/test/mystery-encounter/encounters/the-strong-stuff-encounter.test.ts index be35ec31784..ae725f3480a 100644 --- a/src/test/mystery-encounter/encounters/the-strong-stuff-encounter.test.ts +++ b/src/test/mystery-encounter/encounters/the-strong-stuff-encounter.test.ts @@ -1,8 +1,8 @@ import * as MysteryEncounters from "#app/data/mystery-encounters/mystery-encounters"; -import { Biome } from "#app/enums/biome"; -import { MysteryEncounterType } from "#app/enums/mystery-encounter-type"; -import { Species } from "#app/enums/species"; -import GameManager from "#app/test/utils/gameManager"; +import { Biome } from "#enums/biome"; +import { MysteryEncounterType } from "#enums/mystery-encounter-type"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; import { getPokemonSpecies } from "#app/data/pokemon-species"; import * as BattleAnims from "#app/data/battle-anims"; @@ -11,7 +11,7 @@ import { runMysteryEncounterToEnd, skipBattleRunMysteryEncounterRewardsPhase } f import { Moves } from "#enums/moves"; import BattleScene from "#app/battle-scene"; import { TheStrongStuffEncounter } from "#app/data/mystery-encounters/encounters/the-strong-stuff-encounter"; -import { Nature } from "#app/data/nature"; +import { Nature } from "#enums/nature"; import { BerryType } from "#enums/berry-type"; import { BattlerTagType } from "#enums/battler-tag-type"; import { PokemonMove } from "#app/field/pokemon"; @@ -21,13 +21,14 @@ import { BerryModifier, PokemonBaseStatTotalModifier } from "#app/modifier/modif import { MysteryEncounterOptionMode } from "#enums/mystery-encounter-option-mode"; import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; import { initSceneWithoutEncounterPhase } from "#test/utils/gameManagerUtils"; -import { MysteryEncounterPokemonData } from "#app/data/mystery-encounters/mystery-encounter-pokemon-data"; +import { CustomPokemonData } from "#app/data/custom-pokemon-data"; import { CommandPhase } from "#app/phases/command-phase"; import { MovePhase } from "#app/phases/move-phase"; import { SelectModifierPhase } from "#app/phases/select-modifier-phase"; +import { Abilities } from "#enums/abilities"; -const namespace = "mysteryEncounter:theStrongStuff"; -const defaultParty = [Species.LAPRAS, Species.GENGAR, Species.ABRA]; +const namespace = "mysteryEncounters/theStrongStuff"; +const defaultParty = [ Species.LAPRAS, Species.GENGAR, Species.ABRA ]; const defaultBiome = Biome.CAVE; const defaultWave = 45; @@ -43,15 +44,18 @@ describe("The Strong Stuff - Mystery Encounter", () => { beforeEach(async () => { game = new GameManager(phaserGame); scene = game.scene; - game.override.mysteryEncounterChance(100); - game.override.startingWave(defaultWave); - game.override.startingBiome(defaultBiome); - game.override.disableTrainerWaves(); + game.override + .mysteryEncounterChance(100) + .startingWave(defaultWave) + .startingBiome(defaultBiome) + .disableTrainerWaves() + .enemyAbility(Abilities.BALL_FETCH) + .enemyPassiveAbility(Abilities.BALL_FETCH); vi.spyOn(MysteryEncounters, "mysteryEncountersByBiome", "get").mockReturnValue( new Map([ - [Biome.CAVE, [MysteryEncounterType.THE_STRONG_STUFF]], - [Biome.MOUNTAIN, [MysteryEncounterType.MYSTERIOUS_CHALLENGERS]], + [ Biome.CAVE, [ MysteryEncounterType.THE_STRONG_STUFF ]], + [ Biome.MOUNTAIN, [ MysteryEncounterType.MYSTERIOUS_CHALLENGERS ]], ]) ); }); @@ -66,12 +70,12 @@ describe("The Strong Stuff - Mystery Encounter", () => { await game.runToMysteryEncounter(MysteryEncounterType.THE_STRONG_STUFF, defaultParty); expect(TheStrongStuffEncounter.encounterType).toBe(MysteryEncounterType.THE_STRONG_STUFF); - expect(TheStrongStuffEncounter.encounterTier).toBe(MysteryEncounterTier.GREAT); + expect(TheStrongStuffEncounter.encounterTier).toBe(MysteryEncounterTier.COMMON); expect(TheStrongStuffEncounter.dialogue).toBeDefined(); - expect(TheStrongStuffEncounter.dialogue.intro).toStrictEqual([{ text: `${namespace}.intro` }]); - expect(TheStrongStuffEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}.title`); - expect(TheStrongStuffEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}.description`); - expect(TheStrongStuffEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}.query`); + expect(TheStrongStuffEncounter.dialogue.intro).toStrictEqual([{ text: `${namespace}:intro` }]); + expect(TheStrongStuffEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}:title`); + expect(TheStrongStuffEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}:description`); + expect(TheStrongStuffEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}:query`); expect(TheStrongStuffEncounter.options.length).toBe(2); }); @@ -83,22 +87,6 @@ describe("The Strong Stuff - Mystery Encounter", () => { expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.THE_STRONG_STUFF); }); - it("should not run below wave 10", async () => { - game.override.startingWave(9); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.THE_STRONG_STUFF); - }); - - it("should not run above wave 179", async () => { - game.override.startingWave(181); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle.mysteryEncounter).toBeUndefined(); - }); - it("should initialize fully ", async () => { initSceneWithoutEncounterPhase(scene, defaultParty); scene.currentBattle.mysteryEncounter = TheStrongStuffEncounter; @@ -114,18 +102,18 @@ describe("The Strong Stuff - Mystery Encounter", () => { expect(TheStrongStuffEncounter.enemyPartyConfigs).toEqual([ { - levelAdditiveMultiplier: 1, + levelAdditiveModifier: 1, disableSwitch: true, pokemonConfigs: [ { species: getPokemonSpecies(Species.SHUCKLE), isBoss: true, bossSegments: 5, - mysteryEncounterPokemonData: new MysteryEncounterPokemonData({ spriteScale: 1.25 }), + customPokemonData: new CustomPokemonData({ spriteScale: 1.25 }), nature: Nature.BOLD, - moveSet: [Moves.INFESTATION, Moves.SALT_CURE, Moves.GASTRO_ACID, Moves.HEAL_ORDER], + moveSet: [ Moves.INFESTATION, Moves.SALT_CURE, Moves.GASTRO_ACID, Moves.HEAL_ORDER ], modifierConfigs: expect.any(Array), - tags: [BattlerTagType.MYSTERY_ENCOUNTER_POST_SUMMON], + tags: [ BattlerTagType.MYSTERY_ENCOUNTER_POST_SUMMON ], mysteryEncounterBattleEffects: expect.any(Function) } ], @@ -142,11 +130,11 @@ describe("The Strong Stuff - Mystery Encounter", () => { expect(option1.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option1.dialogue).toBeDefined(); expect(option1.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.1.selected`, + text: `${namespace}:option.1.selected`, }, ], }); @@ -155,10 +143,10 @@ describe("The Strong Stuff - Mystery Encounter", () => { it("should lower stats of 2 highest BST and raise stats for rest of party", async () => { await game.runToMysteryEncounter(MysteryEncounterType.THE_STRONG_STUFF, defaultParty); - const bstsPrior = scene.getParty().map(p => p.getSpeciesForm().getBaseStatTotal()); + const bstsPrior = scene.getPlayerParty().map(p => p.getSpeciesForm().getBaseStatTotal()); await runMysteryEncounterToEnd(game, 1); - const bstsAfter = scene.getParty().map(p => { + const bstsAfter = scene.getPlayerParty().map(p => { const baseStats = p.getSpeciesForm().baseStats.slice(0); scene.applyModifiers(PokemonBaseStatTotalModifier, true, p, baseStats); return baseStats.reduce((a, b) => a + b); @@ -186,11 +174,11 @@ describe("The Strong Stuff - Mystery Encounter", () => { expect(option1.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option1.dialogue).toBeDefined(); expect(option1.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, selected: [ { - text: `${namespace}.option.2.selected`, + text: `${namespace}:option.2.selected`, }, ], }); @@ -206,7 +194,7 @@ describe("The Strong Stuff - Mystery Encounter", () => { expect(scene.getCurrentPhase()?.constructor.name).toBe(CommandPhase.name); expect(enemyField.length).toBe(1); expect(enemyField[0].species.speciesId).toBe(Species.SHUCKLE); - expect(enemyField[0].summonData.statStages).toEqual([0, 2, 0, 2, 0, 0, 0]); + expect(enemyField[0].summonData.statStages).toEqual([ 0, 2, 0, 2, 0, 0, 0 ]); const shuckleItems = enemyField[0].getHeldItems(); expect(shuckleItems.length).toBe(5); expect(shuckleItems.find(m => m instanceof BerryModifier && m.berryType === BerryType.SITRUS)?.stackCount).toBe(1); @@ -214,7 +202,7 @@ describe("The Strong Stuff - Mystery Encounter", () => { expect(shuckleItems.find(m => m instanceof BerryModifier && m.berryType === BerryType.GANLON)?.stackCount).toBe(1); expect(shuckleItems.find(m => m instanceof BerryModifier && m.berryType === BerryType.APICOT)?.stackCount).toBe(1); expect(shuckleItems.find(m => m instanceof BerryModifier && m.berryType === BerryType.LUM)?.stackCount).toBe(2); - expect(enemyField[0].moveset).toEqual([new PokemonMove(Moves.INFESTATION), new PokemonMove(Moves.SALT_CURE), new PokemonMove(Moves.GASTRO_ACID), new PokemonMove(Moves.HEAL_ORDER)]); + expect(enemyField[0].moveset).toEqual([ new PokemonMove(Moves.INFESTATION), new PokemonMove(Moves.SALT_CURE), new PokemonMove(Moves.GASTRO_ACID), new PokemonMove(Moves.HEAL_ORDER) ]); // Should have used moves pre-battle const movePhases = phaseSpy.mock.calls.filter(p => p[0] instanceof MovePhase).map(p => p[0]); diff --git a/src/test/mystery-encounter/encounters/the-winstrate-challenge-encounter.test.ts b/src/test/mystery-encounter/encounters/the-winstrate-challenge-encounter.test.ts index 0c642225031..701a3c94add 100644 --- a/src/test/mystery-encounter/encounters/the-winstrate-challenge-encounter.test.ts +++ b/src/test/mystery-encounter/encounters/the-winstrate-challenge-encounter.test.ts @@ -1,9 +1,9 @@ import * as MysteryEncounters from "#app/data/mystery-encounters/mystery-encounters"; import { HUMAN_TRANSITABLE_BIOMES } from "#app/data/mystery-encounters/mystery-encounters"; -import { Biome } from "#app/enums/biome"; -import { MysteryEncounterType } from "#app/enums/mystery-encounter-type"; -import { Species } from "#app/enums/species"; -import GameManager from "#app/test/utils/gameManager"; +import { Biome } from "#enums/biome"; +import { MysteryEncounterType } from "#enums/mystery-encounter-type"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; import { runMysteryEncounterToEnd } from "#test/mystery-encounter/encounter-test-utils"; import BattleScene from "#app/battle-scene"; @@ -19,15 +19,16 @@ import { Nature } from "#enums/nature"; import { Moves } from "#enums/moves"; import { getPokemonSpecies } from "#app/data/pokemon-species"; import { TheWinstrateChallengeEncounter } from "#app/data/mystery-encounters/encounters/the-winstrate-challenge-encounter"; -import { Status, StatusEffect } from "#app/data/status-effect"; +import { Status } from "#app/data/status-effect"; import { MysteryEncounterRewardsPhase } from "#app/phases/mystery-encounter-phases"; import { CommandPhase } from "#app/phases/command-phase"; import { SelectModifierPhase } from "#app/phases/select-modifier-phase"; import { PartyHealPhase } from "#app/phases/party-heal-phase"; import { VictoryPhase } from "#app/phases/victory-phase"; +import { StatusEffect } from "#enums/status-effect"; -const namespace = "mysteryEncounter:theWinstrateChallenge"; -const defaultParty = [Species.LAPRAS, Species.GENGAR, Species.ABRA]; +const namespace = "mysteryEncounters/theWinstrateChallenge"; +const defaultParty = [ Species.LAPRAS, Species.GENGAR, Species.ABRA ]; const defaultBiome = Biome.CAVE; const defaultWave = 45; @@ -49,10 +50,10 @@ describe("The Winstrate Challenge - Mystery Encounter", () => { game.override.disableTrainerWaves(); const biomeMap = new Map([ - [Biome.VOLCANO, [MysteryEncounterType.FIGHT_OR_FLIGHT]], + [ Biome.VOLCANO, [ MysteryEncounterType.FIGHT_OR_FLIGHT ]], ]); HUMAN_TRANSITABLE_BIOMES.forEach(biome => { - biomeMap.set(biome, [MysteryEncounterType.THE_WINSTRATE_CHALLENGE]); + biomeMap.set(biome, [ MysteryEncounterType.THE_WINSTRATE_CHALLENGE ]); }); vi.spyOn(MysteryEncounters, "mysteryEncountersByBiome", "get").mockReturnValue(biomeMap); }); @@ -70,15 +71,15 @@ describe("The Winstrate Challenge - Mystery Encounter", () => { expect(TheWinstrateChallengeEncounter.encounterTier).toBe(MysteryEncounterTier.ROGUE); expect(TheWinstrateChallengeEncounter.dialogue).toBeDefined(); expect(TheWinstrateChallengeEncounter.dialogue.intro).toStrictEqual([ - { text: `${namespace}.intro` }, + { text: `${namespace}:intro` }, { - speaker: `${namespace}.speaker`, - text: `${namespace}.intro_dialogue`, + speaker: `${namespace}:speaker`, + text: `${namespace}:intro_dialogue`, } ]); - expect(TheWinstrateChallengeEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}.title`); - expect(TheWinstrateChallengeEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}.description`); - expect(TheWinstrateChallengeEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}.query`); + expect(TheWinstrateChallengeEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}:title`); + expect(TheWinstrateChallengeEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}:description`); + expect(TheWinstrateChallengeEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}:query`); expect(TheWinstrateChallengeEncounter.options.length).toBe(2); }); @@ -90,22 +91,6 @@ describe("The Winstrate Challenge - Mystery Encounter", () => { expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.THE_WINSTRATE_CHALLENGE); }); - it("should not run below wave 10", async () => { - game.override.startingWave(9); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.THE_WINSTRATE_CHALLENGE); - }); - - it("should not run above wave 179", async () => { - game.override.startingWave(181); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle.mysteryEncounter).toBeUndefined(); - }); - it("should initialize fully", async () => { initSceneWithoutEncounterPhase(scene, defaultParty); scene.currentBattle.mysteryEncounter = new MysteryEncounter(TheWinstrateChallengeEncounter); @@ -130,7 +115,7 @@ describe("The Winstrate Challenge - Mystery Encounter", () => { isBoss: false, abilityIndex: 0, // Soundproof nature: Nature.MODEST, - moveSet: [Moves.THUNDERBOLT, Moves.GIGA_DRAIN, Moves.FOUL_PLAY, Moves.THUNDER_WAVE], + moveSet: [ Moves.THUNDERBOLT, Moves.GIGA_DRAIN, Moves.FOUL_PLAY, Moves.THUNDER_WAVE ], modifierConfigs: expect.any(Array) }, { @@ -138,7 +123,7 @@ describe("The Winstrate Challenge - Mystery Encounter", () => { isBoss: false, abilityIndex: 2, // Gluttony nature: Nature.QUIET, - moveSet: [Moves.SLUDGE_BOMB, Moves.GIGA_DRAIN, Moves.ICE_BEAM, Moves.EARTHQUAKE], + moveSet: [ Moves.SLUDGE_BOMB, Moves.GIGA_DRAIN, Moves.ICE_BEAM, Moves.EARTHQUAKE ], modifierConfigs: expect.any(Array) }, { @@ -146,7 +131,7 @@ describe("The Winstrate Challenge - Mystery Encounter", () => { isBoss: false, abilityIndex: 2, // Tangled Feet nature: Nature.JOLLY, - moveSet: [Moves.DRILL_PECK, Moves.QUICK_ATTACK, Moves.THRASH, Moves.KNOCK_OFF], + moveSet: [ Moves.DRILL_PECK, Moves.QUICK_ATTACK, Moves.THRASH, Moves.KNOCK_OFF ], modifierConfigs: expect.any(Array) }, { @@ -154,7 +139,7 @@ describe("The Winstrate Challenge - Mystery Encounter", () => { isBoss: false, formIndex: 1, nature: Nature.BOLD, - moveSet: [Moves.PSYCHIC, Moves.SHADOW_BALL, Moves.FOCUS_BLAST, Moves.THUNDERBOLT], + moveSet: [ Moves.PSYCHIC, Moves.SHADOW_BALL, Moves.FOCUS_BLAST, Moves.THUNDERBOLT ], modifierConfigs: expect.any(Array) }, { @@ -162,7 +147,7 @@ describe("The Winstrate Challenge - Mystery Encounter", () => { isBoss: false, abilityIndex: 0, // Sheer Force nature: Nature.IMPISH, - moveSet: [Moves.EARTHQUAKE, Moves.U_TURN, Moves.FLARE_BLITZ, Moves.ROCK_SLIDE], + moveSet: [ Moves.EARTHQUAKE, Moves.U_TURN, Moves.FLARE_BLITZ, Moves.ROCK_SLIDE ], modifierConfigs: expect.any(Array) } ] @@ -175,7 +160,7 @@ describe("The Winstrate Challenge - Mystery Encounter", () => { isBoss: false, formIndex: 1, nature: Nature.IMPISH, - moveSet: [Moves.AXE_KICK, Moves.ICE_PUNCH, Moves.ZEN_HEADBUTT, Moves.BULLET_PUNCH], + moveSet: [ Moves.AXE_KICK, Moves.ICE_PUNCH, Moves.ZEN_HEADBUTT, Moves.BULLET_PUNCH ], modifierConfigs: expect.any(Array) } ] @@ -188,7 +173,7 @@ describe("The Winstrate Challenge - Mystery Encounter", () => { isBoss: false, abilityIndex: 3, // Lightning Rod nature: Nature.ADAMANT, - moveSet: [Moves.WATERFALL, Moves.MEGAHORN, Moves.KNOCK_OFF, Moves.REST], + moveSet: [ Moves.WATERFALL, Moves.MEGAHORN, Moves.KNOCK_OFF, Moves.REST ], modifierConfigs: expect.any(Array) }, { @@ -196,7 +181,7 @@ describe("The Winstrate Challenge - Mystery Encounter", () => { isBoss: false, abilityIndex: 1, // Poison Heal nature: Nature.JOLLY, - moveSet: [Moves.SPORE, Moves.SWORDS_DANCE, Moves.SEED_BOMB, Moves.DRAIN_PUNCH], + moveSet: [ Moves.SPORE, Moves.SWORDS_DANCE, Moves.SEED_BOMB, Moves.DRAIN_PUNCH ], modifierConfigs: expect.any(Array) }, { @@ -204,7 +189,7 @@ describe("The Winstrate Challenge - Mystery Encounter", () => { isBoss: false, formIndex: 1, nature: Nature.CALM, - moveSet: [Moves.EARTH_POWER, Moves.FIRE_BLAST, Moves.YAWN, Moves.PROTECT], + moveSet: [ Moves.EARTH_POWER, Moves.FIRE_BLAST, Moves.YAWN, Moves.PROTECT ], modifierConfigs: expect.any(Array) } ] @@ -217,7 +202,7 @@ describe("The Winstrate Challenge - Mystery Encounter", () => { isBoss: false, abilityIndex: 0, // Natural Cure nature: Nature.CALM, - moveSet: [Moves.SYNTHESIS, Moves.SLUDGE_BOMB, Moves.GIGA_DRAIN, Moves.SLEEP_POWDER], + moveSet: [ Moves.SYNTHESIS, Moves.SLUDGE_BOMB, Moves.GIGA_DRAIN, Moves.SLEEP_POWDER ], modifierConfigs: expect.any(Array) }, { @@ -225,7 +210,7 @@ describe("The Winstrate Challenge - Mystery Encounter", () => { isBoss: false, formIndex: 1, nature: Nature.TIMID, - moveSet: [Moves.PSYSHOCK, Moves.MOONBLAST, Moves.SHADOW_BALL, Moves.WILL_O_WISP], + moveSet: [ Moves.PSYSHOCK, Moves.MOONBLAST, Moves.SHADOW_BALL, Moves.WILL_O_WISP ], modifierConfigs: expect.any(Array) } ] @@ -238,7 +223,7 @@ describe("The Winstrate Challenge - Mystery Encounter", () => { isBoss: false, abilityIndex: 0, // Guts nature: Nature.ADAMANT, - moveSet: [Moves.FACADE, Moves.BRAVE_BIRD, Moves.PROTECT, Moves.QUICK_ATTACK], + moveSet: [ Moves.FACADE, Moves.BRAVE_BIRD, Moves.PROTECT, Moves.QUICK_ATTACK ], modifierConfigs: expect.any(Array) }, { @@ -246,7 +231,7 @@ describe("The Winstrate Challenge - Mystery Encounter", () => { isBoss: false, abilityIndex: 1, // Guts nature: Nature.ADAMANT, - moveSet: [Moves.FACADE, Moves.OBSTRUCT, Moves.NIGHT_SLASH, Moves.FIRE_PUNCH], + moveSet: [ Moves.FACADE, Moves.OBSTRUCT, Moves.NIGHT_SLASH, Moves.FIRE_PUNCH ], modifierConfigs: expect.any(Array) } ] @@ -263,12 +248,12 @@ describe("The Winstrate Challenge - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - speaker: `${namespace}.speaker`, - text: `${namespace}.option.1.selected`, + speaker: `${namespace}:speaker`, + text: `${namespace}:option.1.selected`, }, ], }); @@ -327,12 +312,12 @@ describe("The Winstrate Challenge - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, selected: [ { - speaker: `${namespace}.speaker`, - text: `${namespace}.option.2.selected`, + speaker: `${namespace}:speaker`, + text: `${namespace}:option.2.selected`, }, ], }); diff --git a/src/test/mystery-encounter/encounters/trash-to-treasure-encounter.test.ts b/src/test/mystery-encounter/encounters/trash-to-treasure-encounter.test.ts index a4bfaea659a..8286c6a694b 100644 --- a/src/test/mystery-encounter/encounters/trash-to-treasure-encounter.test.ts +++ b/src/test/mystery-encounter/encounters/trash-to-treasure-encounter.test.ts @@ -23,8 +23,8 @@ import { SelectModifierPhase } from "#app/phases/select-modifier-phase"; import { CommandPhase } from "#app/phases/command-phase"; import { MovePhase } from "#app/phases/move-phase"; -const namespace = "mysteryEncounter:trashToTreasure"; -const defaultParty = [Species.LAPRAS, Species.GENGAR, Species.ABRA]; +const namespace = "mysteryEncounters/trashToTreasure"; +const defaultParty = [ Species.LAPRAS, Species.GENGAR, Species.ABRA ]; const defaultBiome = Biome.CAVE; const defaultWave = 45; @@ -47,7 +47,7 @@ describe("Trash to Treasure - Mystery Encounter", () => { vi.spyOn(MysteryEncounters, "mysteryEncountersByBiome", "get").mockReturnValue( new Map([ - [Biome.CAVE, [MysteryEncounterType.TRASH_TO_TREASURE]], + [ Biome.CAVE, [ MysteryEncounterType.TRASH_TO_TREASURE ]], ]) ); }); @@ -64,29 +64,13 @@ describe("Trash to Treasure - Mystery Encounter", () => { expect(TrashToTreasureEncounter.encounterType).toBe(MysteryEncounterType.TRASH_TO_TREASURE); expect(TrashToTreasureEncounter.encounterTier).toBe(MysteryEncounterTier.ULTRA); expect(TrashToTreasureEncounter.dialogue).toBeDefined(); - expect(TrashToTreasureEncounter.dialogue.intro).toStrictEqual([{ text: `${namespace}.intro` }]); - expect(TrashToTreasureEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}.title`); - expect(TrashToTreasureEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}.description`); - expect(TrashToTreasureEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}.query`); + expect(TrashToTreasureEncounter.dialogue.intro).toStrictEqual([{ text: `${namespace}:intro` }]); + expect(TrashToTreasureEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}:title`); + expect(TrashToTreasureEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}:description`); + expect(TrashToTreasureEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}:query`); expect(TrashToTreasureEncounter.options.length).toBe(2); }); - it("should not run below wave 10", async () => { - game.override.startingWave(9); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.TRASH_TO_TREASURE); - }); - - it("should not run above wave 179", async () => { - game.override.startingWave(181); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle.mysteryEncounter).toBeUndefined(); - }); - it("should initialize fully", async () => { initSceneWithoutEncounterPhase(scene, defaultParty); scene.currentBattle.mysteryEncounter = TrashToTreasureEncounter; @@ -102,7 +86,7 @@ describe("Trash to Treasure - Mystery Encounter", () => { expect(TrashToTreasureEncounter.enemyPartyConfigs).toEqual([ { - levelAdditiveMultiplier: 1, + levelAdditiveModifier: 0.5, disableSwitch: true, pokemonConfigs: [ { @@ -110,7 +94,7 @@ describe("Trash to Treasure - Mystery Encounter", () => { isBoss: true, formIndex: 1, bossSegmentModifier: 1, - moveSet: [Moves.PAYBACK, Moves.GUNK_SHOT, Moves.STOMPING_TANTRUM, Moves.DRAIN_PUNCH], + moveSet: [ Moves.PAYBACK, Moves.GUNK_SHOT, Moves.STOMPING_TANTRUM, Moves.DRAIN_PUNCH ], } ], } @@ -126,11 +110,11 @@ describe("Trash to Treasure - Mystery Encounter", () => { expect(option1.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option1.dialogue).toBeDefined(); expect(option1.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.1.selected`, + text: `${namespace}:option.1.selected`, }, ], }); @@ -171,11 +155,11 @@ describe("Trash to Treasure - Mystery Encounter", () => { expect(option1.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option1.dialogue).toBeDefined(); expect(option1.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, selected: [ { - text: `${namespace}.option.2.selected`, + text: `${namespace}:option.2.selected`, }, ], }); @@ -191,7 +175,7 @@ describe("Trash to Treasure - Mystery Encounter", () => { expect(scene.getCurrentPhase()?.constructor.name).toBe(CommandPhase.name); expect(enemyField.length).toBe(1); expect(enemyField[0].species.speciesId).toBe(Species.GARBODOR); - expect(enemyField[0].moveset).toEqual([new PokemonMove(Moves.PAYBACK), new PokemonMove(Moves.GUNK_SHOT), new PokemonMove(Moves.STOMPING_TANTRUM), new PokemonMove(Moves.DRAIN_PUNCH)]); + expect(enemyField[0].moveset).toEqual([ new PokemonMove(Moves.PAYBACK), new PokemonMove(Moves.GUNK_SHOT), new PokemonMove(Moves.STOMPING_TANTRUM), new PokemonMove(Moves.DRAIN_PUNCH) ]); // Should have used moves pre-battle const movePhases = phaseSpy.mock.calls.filter(p => p[0] instanceof MovePhase).map(p => p[0]); diff --git a/src/test/mystery-encounter/encounters/uncommon-breed-encounter.test.ts b/src/test/mystery-encounter/encounters/uncommon-breed-encounter.test.ts index f235609ee08..c811bda673d 100644 --- a/src/test/mystery-encounter/encounters/uncommon-breed-encounter.test.ts +++ b/src/test/mystery-encounter/encounters/uncommon-breed-encounter.test.ts @@ -17,16 +17,17 @@ import { MysteryEncounterPhase } from "#app/phases/mystery-encounter-phases"; import { CommandPhase } from "#app/phases/command-phase"; import { UncommonBreedEncounter } from "#app/data/mystery-encounters/encounters/uncommon-breed-encounter"; import { MovePhase } from "#app/phases/move-phase"; -import { speciesEggMoves } from "#app/data/egg-moves"; +import { speciesEggMoves } from "#app/data/balance/egg-moves"; import { getPokemonSpecies } from "#app/data/pokemon-species"; import { BerryType } from "#enums/berry-type"; import { StatStageChangePhase } from "#app/phases/stat-stage-change-phase"; import { Stat } from "#enums/stat"; import { BerryModifier } from "#app/modifier/modifier"; import { modifierTypes } from "#app/modifier/modifier-type"; +import { Abilities } from "#enums/abilities"; -const namespace = "mysteryEncounter:uncommonBreed"; -const defaultParty = [Species.LAPRAS, Species.GENGAR, Species.ABRA]; +const namespace = "mysteryEncounters/uncommonBreed"; +const defaultParty = [ Species.LAPRAS, Species.GENGAR, Species.ABRA ]; const defaultBiome = Biome.CAVE; const defaultWave = 45; @@ -42,15 +43,17 @@ describe("Uncommon Breed - Mystery Encounter", () => { beforeEach(async () => { game = new GameManager(phaserGame); scene = game.scene; - game.override.mysteryEncounterChance(100); - game.override.mysteryEncounterTier(MysteryEncounterTier.COMMON); - game.override.startingWave(defaultWave); - game.override.startingBiome(defaultBiome); - game.override.disableTrainerWaves(); + game.override.mysteryEncounterChance(100) + .mysteryEncounterTier(MysteryEncounterTier.COMMON) + .startingWave(defaultWave) + .startingBiome(defaultBiome) + .disableTrainerWaves() + .enemyAbility(Abilities.BALL_FETCH) + .enemyPassiveAbility(Abilities.BALL_FETCH); vi.spyOn(MysteryEncounters, "mysteryEncountersByBiome", "get").mockReturnValue( new Map([ - [Biome.CAVE, [MysteryEncounterType.UNCOMMON_BREED]], + [ Biome.CAVE, [ MysteryEncounterType.UNCOMMON_BREED ]], ]) ); }); @@ -67,29 +70,13 @@ describe("Uncommon Breed - Mystery Encounter", () => { expect(UncommonBreedEncounter.encounterType).toBe(MysteryEncounterType.UNCOMMON_BREED); expect(UncommonBreedEncounter.encounterTier).toBe(MysteryEncounterTier.COMMON); expect(UncommonBreedEncounter.dialogue).toBeDefined(); - expect(UncommonBreedEncounter.dialogue.intro).toStrictEqual([{ text: `${namespace}.intro` }]); - expect(UncommonBreedEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}.title`); - expect(UncommonBreedEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}.description`); - expect(UncommonBreedEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}.query`); + expect(UncommonBreedEncounter.dialogue.intro).toStrictEqual([{ text: `${namespace}:intro` }]); + expect(UncommonBreedEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}:title`); + expect(UncommonBreedEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}:description`); + expect(UncommonBreedEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}:query`); expect(UncommonBreedEncounter.options.length).toBe(3); }); - it("should not run below wave 10", async () => { - game.override.startingWave(9); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.UNCOMMON_BREED); - }); - - it("should not run above wave 179", async () => { - game.override.startingWave(181); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle.mysteryEncounter).toBeUndefined(); - }); - it("should initialize fully", async () => { initSceneWithoutEncounterPhase(scene, defaultParty); scene.currentBattle.mysteryEncounter = UncommonBreedEncounter; @@ -107,23 +94,23 @@ describe("Uncommon Breed - Mystery Encounter", () => { expect(onInitResult).toBe(true); }); - describe.skip("Option 1 - Fight", () => { + describe("Option 1 - Fight", () => { it("should have the correct properties", () => { const option = UncommonBreedEncounter.options[0]; expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.1.selected`, + text: `${namespace}:option.1.selected`, }, ], }); }); - it("should start a fight against the boss", async () => { + it.skip("should start a fight against the boss below wave 50", async () => { const phaseSpy = vi.spyOn(scene, "pushPhase"); const unshiftPhaseSpy = vi.spyOn(scene, "unshiftPhase"); await game.runToMysteryEncounter(MysteryEncounterType.UNCOMMON_BREED, defaultParty); @@ -139,7 +126,34 @@ describe("Uncommon Breed - Mystery Encounter", () => { expect(enemyField[0].species.speciesId).toBe(speciesToSpawn); const statStagePhases = unshiftPhaseSpy.mock.calls.filter(p => p[0] instanceof StatStageChangePhase)[0][0] as any; - expect(statStagePhases.stats).toEqual([Stat.ATK, Stat.DEF, Stat.SPATK, Stat.SPDEF, Stat.SPD]); + expect(statStagePhases.stats).toEqual([ Stat.ATK, Stat.DEF, Stat.SPATK, Stat.SPDEF, Stat.SPD ]); + + // Should have used its egg move pre-battle + const movePhases = phaseSpy.mock.calls.filter(p => p[0] instanceof MovePhase).map(p => p[0]); + expect(movePhases.length).toBe(1); + const eggMoves: Moves[] = speciesEggMoves[getPokemonSpecies(speciesToSpawn).getRootSpeciesId()]; + const usedMove = (movePhases[0] as MovePhase).move.moveId; + expect(eggMoves.includes(usedMove)).toBe(true); + }); + + it.skip("should start a fight against the boss above wave 50", async () => { + game.override.startingWave(57); + const phaseSpy = vi.spyOn(scene, "pushPhase"); + const unshiftPhaseSpy = vi.spyOn(scene, "unshiftPhase"); + await game.runToMysteryEncounter(MysteryEncounterType.UNCOMMON_BREED, defaultParty); + + const config = game.scene.currentBattle.mysteryEncounter!.enemyPartyConfigs[0]; + const speciesToSpawn = config.pokemonConfigs?.[0].species.speciesId; + + await runMysteryEncounterToEnd(game, 1, undefined, true); + + const enemyField = scene.getEnemyField(); + expect(scene.getCurrentPhase()?.constructor.name).toBe(CommandPhase.name); + expect(enemyField.length).toBe(1); + expect(enemyField[0].species.speciesId).toBe(speciesToSpawn); + + const statStagePhases = unshiftPhaseSpy.mock.calls.filter(p => p[0] instanceof StatStageChangePhase)[0][0] as any; + expect(statStagePhases.stats).toEqual([ Stat.ATK, Stat.DEF, Stat.SPATK, Stat.SPDEF, Stat.SPD ]); // Should have used its egg move pre-battle const movePhases = phaseSpy.mock.calls.filter(p => p[0] instanceof MovePhase).map(p => p[0]); @@ -156,12 +170,12 @@ describe("Uncommon Breed - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DISABLED_OR_SPECIAL); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, - disabledButtonTooltip: `${namespace}.option.2.disabled_tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, + disabledButtonTooltip: `${namespace}:option.2.disabled_tooltip`, selected: [ { - text: `${namespace}.option.2.selected`, + text: `${namespace}:option.2.selected`, } ], }); @@ -199,12 +213,12 @@ describe("Uncommon Breed - Mystery Encounter", () => { await game.runToMysteryEncounter(MysteryEncounterType.UNCOMMON_BREED, defaultParty); // Berries on party lead - const sitrus = generateModifierType(scene, modifierTypes.BERRY, [BerryType.SITRUS])!; - const sitrusMod = sitrus.newModifier(scene.getParty()[0]) as BerryModifier; + const sitrus = generateModifierType(scene, modifierTypes.BERRY, [ BerryType.SITRUS ])!; + const sitrusMod = sitrus.newModifier(scene.getPlayerParty()[0]) as BerryModifier; sitrusMod.stackCount = 2; await scene.addModifier(sitrusMod, true, false, false, true); - const ganlon = generateModifierType(scene, modifierTypes.BERRY, [BerryType.GANLON])!; - const ganlonMod = ganlon.newModifier(scene.getParty()[0]) as BerryModifier; + const ganlon = generateModifierType(scene, modifierTypes.BERRY, [ BerryType.GANLON ])!; + const ganlonMod = ganlon.newModifier(scene.getPlayerParty()[0]) as BerryModifier; ganlonMod.stackCount = 3; await scene.addModifier(ganlonMod, true, false, false, true); await scene.updateModifiers(true); @@ -221,12 +235,12 @@ describe("Uncommon Breed - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DISABLED_OR_SPECIAL); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.3.label`, - buttonTooltip: `${namespace}.option.3.tooltip`, - disabledButtonTooltip: `${namespace}.option.3.disabled_tooltip`, + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, + disabledButtonTooltip: `${namespace}:option.3.disabled_tooltip`, selected: [ { - text: `${namespace}.option.3.selected`, + text: `${namespace}:option.3.selected`, } ], }); @@ -234,7 +248,7 @@ describe("Uncommon Breed - Mystery Encounter", () => { it("should NOT be selectable if the player doesn't have an Attracting move", async () => { await game.runToMysteryEncounter(MysteryEncounterType.UNCOMMON_BREED, defaultParty); - scene.getParty().forEach(p => p.moveset = []); + scene.getPlayerParty().forEach(p => p.moveset = []); await game.phaseInterceptor.to(MysteryEncounterPhase, false); const encounterPhase = scene.getCurrentPhase(); @@ -256,7 +270,7 @@ describe("Uncommon Breed - Mystery Encounter", () => { const leaveEncounterWithoutBattleSpy = vi.spyOn(EncounterPhaseUtils, "leaveEncounterWithoutBattle"); await game.runToMysteryEncounter(MysteryEncounterType.UNCOMMON_BREED, defaultParty); // Mock moveset - scene.getParty()[0].moveset = [new PokemonMove(Moves.CHARM)]; + scene.getPlayerParty()[0].moveset = [ new PokemonMove(Moves.CHARM) ]; await runMysteryEncounterToEnd(game, 3); expect(leaveEncounterWithoutBattleSpy).toBeCalled(); diff --git a/src/test/mystery-encounter/encounters/weird-dream-encounter.test.ts b/src/test/mystery-encounter/encounters/weird-dream-encounter.test.ts index ef014c6949b..ec9cf1509b1 100644 --- a/src/test/mystery-encounter/encounters/weird-dream-encounter.test.ts +++ b/src/test/mystery-encounter/encounters/weird-dream-encounter.test.ts @@ -5,7 +5,7 @@ import { Species } from "#app/enums/species"; import GameManager from "#app/test/utils/gameManager"; import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; import * as EncounterPhaseUtils from "#app/data/mystery-encounters/utils/encounter-phase-utils"; -import { runMysteryEncounterToEnd } from "#test/mystery-encounter/encounter-test-utils"; +import { runMysteryEncounterToEnd, skipBattleRunMysteryEncounterRewardsPhase } from "#test/mystery-encounter/encounter-test-utils"; import BattleScene from "#app/battle-scene"; import { Mode } from "#app/ui/ui"; import ModifierSelectUiHandler from "#app/ui/modifier-select-ui-handler"; @@ -15,9 +15,11 @@ import { initSceneWithoutEncounterPhase } from "#test/utils/gameManagerUtils"; import { WeirdDreamEncounter } from "#app/data/mystery-encounters/encounters/weird-dream-encounter"; import * as EncounterTransformationSequence from "#app/data/mystery-encounters/utils/encounter-transformation-sequence"; import { SelectModifierPhase } from "#app/phases/select-modifier-phase"; +import { CommandPhase } from "#app/phases/command-phase"; +import { ModifierTier } from "#app/modifier/modifier-tier"; -const namespace = "mysteryEncounter:weirdDream"; -const defaultParty = [Species.MAGBY, Species.HAUNTER, Species.ABRA]; +const namespace = "mysteryEncounters/weirdDream"; +const defaultParty = [ Species.MAGBY, Species.HAUNTER, Species.ABRA ]; const defaultBiome = Biome.CAVE; const defaultWave = 45; @@ -41,7 +43,7 @@ describe("Weird Dream - Mystery Encounter", () => { vi.spyOn(MysteryEncounters, "mysteryEncountersByBiome", "get").mockReturnValue( new Map([ - [Biome.CAVE, [MysteryEncounterType.WEIRD_DREAM]], + [ Biome.CAVE, [ MysteryEncounterType.WEIRD_DREAM ]], ]) ); }); @@ -60,33 +62,17 @@ describe("Weird Dream - Mystery Encounter", () => { expect(WeirdDreamEncounter.dialogue).toBeDefined(); expect(WeirdDreamEncounter.dialogue.intro).toStrictEqual([ { - text: `${namespace}.intro` + text: `${namespace}:intro` }, { - speaker: `${namespace}.speaker`, - text: `${namespace}.intro_dialogue`, + speaker: `${namespace}:speaker`, + text: `${namespace}:intro_dialogue`, }, ]); - expect(WeirdDreamEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}.title`); - expect(WeirdDreamEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}.description`); - expect(WeirdDreamEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}.query`); - expect(WeirdDreamEncounter.options.length).toBe(2); - }); - - it("should not run below wave 10", async () => { - game.override.startingWave(9); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.WEIRD_DREAM); - }); - - it("should not run above wave 179", async () => { - game.override.startingWave(181); - - await game.runToMysteryEncounter(); - - expect(scene.currentBattle.mysteryEncounter).toBeUndefined(); + expect(WeirdDreamEncounter.dialogue.encounterOptionsDialogue?.title).toBe(`${namespace}:title`); + expect(WeirdDreamEncounter.dialogue.encounterOptionsDialogue?.description).toBe(`${namespace}:description`); + expect(WeirdDreamEncounter.dialogue.encounterOptionsDialogue?.query).toBe(`${namespace}:query`); + expect(WeirdDreamEncounter.options.length).toBe(3); }); it("should initialize fully", async () => { @@ -111,11 +97,11 @@ describe("Weird Dream - Mystery Encounter", () => { expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.1.label`, - buttonTooltip: `${namespace}.option.1.tooltip`, + buttonLabel: `${namespace}:option.1.label`, + buttonTooltip: `${namespace}:option.1.tooltip`, selected: [ { - text: `${namespace}.option.1.selected`, + text: `${namespace}:option.1.selected`, }, ], }); @@ -124,21 +110,21 @@ describe("Weird Dream - Mystery Encounter", () => { it("should transform the new party into new species, 2 at +90/+110, the rest at +40/50 BST", async () => { await game.runToMysteryEncounter(MysteryEncounterType.WEIRD_DREAM, defaultParty); - const pokemonPrior = scene.getParty().map(pokemon => pokemon); + const pokemonPrior = scene.getPlayerParty().map(pokemon => pokemon); const bstsPrior = pokemonPrior.map(species => species.getSpeciesForm().getBaseStatTotal()); await runMysteryEncounterToEnd(game, 1); await game.phaseInterceptor.to(SelectModifierPhase, false); expect(scene.getCurrentPhase()?.constructor.name).toBe(SelectModifierPhase.name); - const pokemonAfter = scene.getParty(); + const pokemonAfter = scene.getPlayerParty(); const bstsAfter = pokemonAfter.map(pokemon => pokemon.getSpeciesForm().getBaseStatTotal()); const bstDiff = bstsAfter.map((bst, index) => bst - bstsPrior[index]); for (let i = 0; i < pokemonAfter.length; i++) { const newPokemon = pokemonAfter[i]; expect(newPokemon.getSpeciesForm().speciesId).not.toBe(pokemonPrior[i].getSpeciesForm().speciesId); - expect(newPokemon.mysteryEncounterPokemonData?.types.length).toBe(2); + expect(newPokemon.customPokemonData?.types.length).toBe(2); } const plus90To110 = bstDiff.filter(bst => bst > 80); @@ -148,7 +134,7 @@ describe("Weird Dream - Mystery Encounter", () => { expect(plus40To50.length).toBe(1); }); - it("should have 1 Memory Mushroom, 5 Rogue Balls, and 2 Mints in rewards", async () => { + it("should have 1 Memory Mushroom, 5 Rogue Balls, and 3 Mints in rewards", async () => { await game.runToMysteryEncounter(MysteryEncounterType.WEIRD_DREAM, defaultParty); await runMysteryEncounterToEnd(game, 1); await game.phaseInterceptor.to(SelectModifierPhase, false); @@ -157,11 +143,12 @@ describe("Weird Dream - Mystery Encounter", () => { expect(scene.ui.getMode()).to.equal(Mode.MODIFIER_SELECT); const modifierSelectHandler = scene.ui.handlers.find(h => h instanceof ModifierSelectUiHandler) as ModifierSelectUiHandler; - expect(modifierSelectHandler.options.length).toEqual(4); + expect(modifierSelectHandler.options.length).toEqual(5); expect(modifierSelectHandler.options[0].modifierTypeOption.type.id).toEqual("MEMORY_MUSHROOM"); expect(modifierSelectHandler.options[1].modifierTypeOption.type.id).toEqual("ROGUE_BALL"); expect(modifierSelectHandler.options[2].modifierTypeOption.type.id).toEqual("MINT"); expect(modifierSelectHandler.options[3].modifierTypeOption.type.id).toEqual("MINT"); + expect(modifierSelectHandler.options[3].modifierTypeOption.type.id).toEqual("MINT"); }); it("should leave encounter without battle", async () => { @@ -174,34 +161,80 @@ describe("Weird Dream - Mystery Encounter", () => { }); }); - describe("Option 2 - Leave", () => { + describe("Option 2 - Battle Future Self", () => { it("should have the correct properties", () => { const option = WeirdDreamEncounter.options[1]; expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); expect(option.dialogue).toBeDefined(); expect(option.dialogue).toStrictEqual({ - buttonLabel: `${namespace}.option.2.label`, - buttonTooltip: `${namespace}.option.2.tooltip`, + buttonLabel: `${namespace}:option.2.label`, + buttonTooltip: `${namespace}:option.2.tooltip`, selected: [ { - text: `${namespace}.option.2.selected`, + text: `${namespace}:option.2.selected`, }, ], }); }); - it("should reduce party levels by 20%", async () => { + it("should start a battle against the player's transformation team", async () => { + await game.runToMysteryEncounter(MysteryEncounterType.WEIRD_DREAM, defaultParty); + await runMysteryEncounterToEnd(game, 2, undefined, true); + + const enemyField = scene.getEnemyField(); + expect(scene.getCurrentPhase()?.constructor.name).toBe(CommandPhase.name); + expect(enemyField.length).toBe(1); + expect(scene.getEnemyParty().length).toBe(scene.getPlayerParty().length); + }); + + it("should have 2 Rogue/2 Ultra/2 Great items in rewards", async () => { + await game.runToMysteryEncounter(MysteryEncounterType.WEIRD_DREAM, defaultParty); + await runMysteryEncounterToEnd(game, 2, undefined, true); + await skipBattleRunMysteryEncounterRewardsPhase(game); + await game.phaseInterceptor.to(SelectModifierPhase, false); + expect(scene.getCurrentPhase()?.constructor.name).toBe(SelectModifierPhase.name); + await game.phaseInterceptor.run(SelectModifierPhase); + + expect(scene.ui.getMode()).to.equal(Mode.MODIFIER_SELECT); + const modifierSelectHandler = scene.ui.handlers.find(h => h instanceof ModifierSelectUiHandler) as ModifierSelectUiHandler; + expect(modifierSelectHandler.options.length).toEqual(6); + expect(modifierSelectHandler.options[0].modifierTypeOption.type.tier - modifierSelectHandler.options[0].modifierTypeOption.upgradeCount).toEqual(ModifierTier.ROGUE); + expect(modifierSelectHandler.options[1].modifierTypeOption.type.tier - modifierSelectHandler.options[1].modifierTypeOption.upgradeCount).toEqual(ModifierTier.ROGUE); + expect(modifierSelectHandler.options[2].modifierTypeOption.type.tier - modifierSelectHandler.options[2].modifierTypeOption.upgradeCount).toEqual(ModifierTier.ULTRA); + expect(modifierSelectHandler.options[3].modifierTypeOption.type.tier - modifierSelectHandler.options[3].modifierTypeOption.upgradeCount).toEqual(ModifierTier.ULTRA); + expect(modifierSelectHandler.options[4].modifierTypeOption.type.tier - modifierSelectHandler.options[4].modifierTypeOption.upgradeCount).toEqual(ModifierTier.GREAT); + expect(modifierSelectHandler.options[5].modifierTypeOption.type.tier - modifierSelectHandler.options[5].modifierTypeOption.upgradeCount).toEqual(ModifierTier.GREAT); + }); + }); + + describe("Option 3 - Leave", () => { + it("should have the correct properties", () => { + const option = WeirdDreamEncounter.options[2]; + expect(option.optionMode).toBe(MysteryEncounterOptionMode.DEFAULT); + expect(option.dialogue).toBeDefined(); + expect(option.dialogue).toStrictEqual({ + buttonLabel: `${namespace}:option.3.label`, + buttonTooltip: `${namespace}:option.3.tooltip`, + selected: [ + { + text: `${namespace}:option.3.selected`, + }, + ], + }); + }); + + it("should reduce party levels by 10%", async () => { const leaveEncounterWithoutBattleSpy = vi.spyOn(EncounterPhaseUtils, "leaveEncounterWithoutBattle"); await game.runToMysteryEncounter(MysteryEncounterType.WEIRD_DREAM, defaultParty); - const levelsPrior = scene.getParty().map(p => p.level); - await runMysteryEncounterToEnd(game, 2); + const levelsPrior = scene.getPlayerParty().map(p => p.level); + await runMysteryEncounterToEnd(game, 3); - const levelsAfter = scene.getParty().map(p => p.level); + const levelsAfter = scene.getPlayerParty().map(p => p.level); for (let i = 0; i < levelsPrior.length; i++) { - expect(Math.max(Math.ceil(0.8 * levelsPrior[i]), 1)).toBe(levelsAfter[i]); - expect(scene.getParty()[i].levelExp).toBe(0); + expect(Math.max(Math.ceil(0.9 * levelsPrior[i]), 1)).toBe(levelsAfter[i]); + expect(scene.getPlayerParty()[i].levelExp).toBe(0); } expect(leaveEncounterWithoutBattleSpy).toBeCalled(); @@ -211,7 +244,7 @@ describe("Weird Dream - Mystery Encounter", () => { const leaveEncounterWithoutBattleSpy = vi.spyOn(EncounterPhaseUtils, "leaveEncounterWithoutBattle"); await game.runToMysteryEncounter(MysteryEncounterType.WEIRD_DREAM, defaultParty); - await runMysteryEncounterToEnd(game, 2); + await runMysteryEncounterToEnd(game, 3); expect(leaveEncounterWithoutBattleSpy).toBeCalled(); }); diff --git a/src/test/mystery-encounter/mystery-encounter-utils.test.ts b/src/test/mystery-encounter/mystery-encounter-utils.test.ts index 61eb1eaffd1..ab2d5f052c0 100644 --- a/src/test/mystery-encounter/mystery-encounter-utils.test.ts +++ b/src/test/mystery-encounter/mystery-encounter-utils.test.ts @@ -1,16 +1,17 @@ -import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; -import GameManager from "#app/test/utils/gameManager"; -import Phaser from "phaser"; -import { initSceneWithoutEncounterPhase } from "#test/utils/gameManagerUtils"; -import { Species } from "#enums/species"; import BattleScene from "#app/battle-scene"; -import { StatusEffect } from "#app/data/status-effect"; +import { speciesStarterCosts } from "#app/data/balance/starters"; import MysteryEncounter from "#app/data/mystery-encounters/mystery-encounter"; -import { getPokemonSpecies, speciesStarters } from "#app/data/pokemon-species"; -import { Type } from "#app/data/type"; -import { getHighestLevelPlayerPokemon, getLowestLevelPlayerPokemon, getRandomPlayerPokemon, getRandomSpeciesByStarterTier, koPlayerPokemon } from "#app/data/mystery-encounters/utils/encounter-pokemon-utils"; import { getEncounterText, queueEncounterMessage, showEncounterDialogue, showEncounterText } from "#app/data/mystery-encounters/utils/encounter-dialogue-utils"; +import { getHighestLevelPlayerPokemon, getLowestLevelPlayerPokemon, getRandomPlayerPokemon, getRandomSpeciesByStarterTier, koPlayerPokemon } from "#app/data/mystery-encounters/utils/encounter-pokemon-utils"; +import { getPokemonSpecies } from "#app/data/pokemon-species"; +import { Type } from "#enums/type"; import { MessagePhase } from "#app/phases/message-phase"; +import GameManager from "#app/test/utils/gameManager"; +import { Species } from "#enums/species"; +import { StatusEffect } from "#enums/status-effect"; +import { initSceneWithoutEncounterPhase } from "#test/utils/gameManagerUtils"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; describe("Mystery Encounter Utils", () => { let phaserGame: Phaser.Game; @@ -30,7 +31,7 @@ describe("Mystery Encounter Utils", () => { beforeEach(() => { game = new GameManager(phaserGame); scene = game.scene; - initSceneWithoutEncounterPhase(game.scene, [Species.ARCEUS, Species.MANAPHY]); + initSceneWithoutEncounterPhase(game.scene, [ Species.ARCEUS, Species.MANAPHY ]); }); describe("getRandomPlayerPokemon", () => { @@ -49,7 +50,7 @@ describe("Mystery Encounter Utils", () => { it("gets a fainted pokemon from player party if isAllowedInBattle is false", () => { // Both pokemon fainted - scene.getParty().forEach(p => { + scene.getPlayerParty().forEach(p => { p.hp = 0; p.trySetStatus(StatusEffect.FAINT); p.updateInfo(); @@ -67,9 +68,9 @@ describe("Mystery Encounter Utils", () => { expect(result.species.speciesId).toBe(Species.ARCEUS); }); - it("gets an unfainted pokemon from player party if isAllowedInBattle is true", () => { + it("gets an unfainted legal pokemon from player party if isAllowed is true and isFainted is false", () => { // Only faint 1st pokemon - const party = scene.getParty(); + const party = scene.getPlayerParty(); party[0].hp = 0; party[0].trySetStatus(StatusEffect.FAINT); party[0].updateInfo(); @@ -88,7 +89,7 @@ describe("Mystery Encounter Utils", () => { it("returns last unfainted pokemon if doNotReturnLastAbleMon is false", () => { // Only faint 1st pokemon - const party = scene.getParty(); + const party = scene.getPlayerParty(); party[0].hp = 0; party[0].trySetStatus(StatusEffect.FAINT); party[0].updateInfo(); @@ -107,7 +108,7 @@ describe("Mystery Encounter Utils", () => { it("never returns last unfainted pokemon if doNotReturnLastAbleMon is true", () => { // Only faint 1st pokemon - const party = scene.getParty(); + const party = scene.getPlayerParty(); party[0].hp = 0; party[0].trySetStatus(StatusEffect.FAINT); party[0].updateInfo(); @@ -115,19 +116,19 @@ describe("Mystery Encounter Utils", () => { // Seeds are calculated to return index 0 first, 1 second (if both pokemon are legal) game.override.seed("random"); - let result = getRandomPlayerPokemon(scene, true, true); + let result = getRandomPlayerPokemon(scene, true, false, true); expect(result.species.speciesId).toBe(Species.ARCEUS); game.override.seed("random2"); - result = getRandomPlayerPokemon(scene, true, true); + result = getRandomPlayerPokemon(scene, true, false, true); expect(result.species.speciesId).toBe(Species.ARCEUS); }); }); describe("getHighestLevelPlayerPokemon", () => { it("gets highest level pokemon", () => { - const party = scene.getParty(); + const party = scene.getPlayerParty(); party[0].level = 100; const result = getHighestLevelPlayerPokemon(scene); @@ -135,7 +136,7 @@ describe("Mystery Encounter Utils", () => { }); it("gets highest level pokemon at different index", () => { - const party = scene.getParty(); + const party = scene.getPlayerParty(); party[1].level = 100; const result = getHighestLevelPlayerPokemon(scene); @@ -143,7 +144,7 @@ describe("Mystery Encounter Utils", () => { }); it("breaks ties by getting returning lower index", () => { - const party = scene.getParty(); + const party = scene.getPlayerParty(); party[0].level = 100; party[1].level = 100; @@ -152,7 +153,7 @@ describe("Mystery Encounter Utils", () => { }); it("returns highest level unfainted if unfainted is true", () => { - const party = scene.getParty(); + const party = scene.getPlayerParty(); party[0].level = 100; party[0].hp = 0; party[0].trySetStatus(StatusEffect.FAINT); @@ -166,7 +167,7 @@ describe("Mystery Encounter Utils", () => { describe("getLowestLevelPokemon", () => { it("gets lowest level pokemon", () => { - const party = scene.getParty(); + const party = scene.getPlayerParty(); party[0].level = 100; const result = getLowestLevelPlayerPokemon(scene); @@ -174,7 +175,7 @@ describe("Mystery Encounter Utils", () => { }); it("gets lowest level pokemon at different index", () => { - const party = scene.getParty(); + const party = scene.getPlayerParty(); party[1].level = 100; const result = getLowestLevelPlayerPokemon(scene); @@ -182,7 +183,7 @@ describe("Mystery Encounter Utils", () => { }); it("breaks ties by getting returning lower index", () => { - const party = scene.getParty(); + const party = scene.getPlayerParty(); party[0].level = 100; party[1].level = 100; @@ -191,7 +192,7 @@ describe("Mystery Encounter Utils", () => { }); it("returns lowest level unfainted if unfainted is true", () => { - const party = scene.getParty(); + const party = scene.getPlayerParty(); party[0].level = 10; party[0].hp = 0; party[0].trySetStatus(StatusEffect.FAINT); @@ -209,28 +210,28 @@ describe("Mystery Encounter Utils", () => { const pokeSpecies = getPokemonSpecies(result); expect(pokeSpecies.speciesId).toBe(result); - expect(speciesStarters[result]).toBe(5); + expect(speciesStarterCosts[result]).toBe(5); }); it("gets species for a starter tier range", () => { - const result = getRandomSpeciesByStarterTier([5, 8]); + const result = getRandomSpeciesByStarterTier([ 5, 8 ]); const pokeSpecies = getPokemonSpecies(result); expect(pokeSpecies.speciesId).toBe(result); - expect(speciesStarters[result]).toBeGreaterThanOrEqual(5); - expect(speciesStarters[result]).toBeLessThanOrEqual(8); + expect(speciesStarterCosts[result]).toBeGreaterThanOrEqual(5); + expect(speciesStarterCosts[result]).toBeLessThanOrEqual(8); }); it("excludes species from search", () => { // Only 9 tiers are: Koraidon, Miraidon, Arceus, Rayquaza, Kyogre, Groudon, Zacian - const result = getRandomSpeciesByStarterTier(9, [Species.KORAIDON, Species.MIRAIDON, Species.ARCEUS, Species.RAYQUAZA, Species.KYOGRE, Species.GROUDON]); + const result = getRandomSpeciesByStarterTier(9, [ Species.KORAIDON, Species.MIRAIDON, Species.ARCEUS, Species.RAYQUAZA, Species.KYOGRE, Species.GROUDON ]); const pokeSpecies = getPokemonSpecies(result); expect(pokeSpecies.speciesId).toBe(Species.ZACIAN); }); it("gets species of specified types", () => { // Only 9 tiers are: Koraidon, Miraidon, Arceus, Rayquaza, Kyogre, Groudon, Zacian - const result = getRandomSpeciesByStarterTier(9, undefined, [Type.GROUND]); + const result = getRandomSpeciesByStarterTier(9, undefined, [ Type.GROUND ]); const pokeSpecies = getPokemonSpecies(result); expect(pokeSpecies.speciesId).toBe(Species.GROUDON); }); @@ -238,7 +239,7 @@ describe("Mystery Encounter Utils", () => { describe("koPlayerPokemon", () => { it("KOs a pokemon", () => { - const party = scene.getParty(); + const party = scene.getPlayerParty(); const arceus = party[0]; arceus.hp = 100; expect(arceus.isAllowedInBattle()).toBe(true); @@ -254,7 +255,7 @@ describe("Mystery Encounter Utils", () => { scene.currentBattle.mysteryEncounter.setDialogueToken("test", "value"); const result = getEncounterText(scene, "mysteryEncounter:unit_test_dialogue"); - expect(result).toEqual("valuevalue {{testvalue}} {{test1}} {{test}} {{test\\}} {{test\\}} {test}}"); + expect(result).toEqual("mysteryEncounter:unit_test_dialogue"); }); it("can perform nested dialogue token injection", () => { @@ -263,7 +264,7 @@ describe("Mystery Encounter Utils", () => { scene.currentBattle.mysteryEncounter.setDialogueToken("testvalue", "new"); const result = getEncounterText(scene, "mysteryEncounter:unit_test_dialogue"); - expect(result).toEqual("valuevalue {{testvalue}} {{test1}} {{test}} {{test\\}} {{test\\}} {test}}"); + expect(result).toEqual("mysteryEncounter:unit_test_dialogue"); }); }); @@ -275,7 +276,7 @@ describe("Mystery Encounter Utils", () => { const phaseSpy = vi.spyOn(game.scene, "unshiftPhase"); queueEncounterMessage(scene, "mysteryEncounter:unit_test_dialogue"); - expect(spy).toHaveBeenCalledWith("valuevalue {{testvalue}} {{test1}} {{test}} {{test\\}} {{test\\}} {test}}", null, true); + expect(spy).toHaveBeenCalledWith("mysteryEncounter:unit_test_dialogue", null, true); expect(phaseSpy).toHaveBeenCalledWith(expect.any(MessagePhase)); }); }); @@ -287,7 +288,7 @@ describe("Mystery Encounter Utils", () => { const spy = vi.spyOn(game.scene.ui, "showText"); await showEncounterText(scene, "mysteryEncounter:unit_test_dialogue"); - expect(spy).toHaveBeenCalledWith("valuevalue {{testvalue}} {{test1}} {{test}} {{test\\}} {{test\\}} {test}}", null, expect.any(Function), 0, true, null); + expect(spy).toHaveBeenCalledWith("mysteryEncounter:unit_test_dialogue", null, expect.any(Function), 0, true, null); }); }); @@ -298,43 +299,7 @@ describe("Mystery Encounter Utils", () => { const spy = vi.spyOn(game.scene.ui, "showDialogue"); await showEncounterDialogue(scene, "mysteryEncounter:unit_test_dialogue", "mysteryEncounter:unit_test_dialogue"); - expect(spy).toHaveBeenCalledWith("valuevalue {{testvalue}} {{test1}} {{test}} {{test\\}} {{test\\}} {test}}", "valuevalue {{testvalue}} {{test1}} {{test}} {{test\\}} {{test\\}} {test}}", null, expect.any(Function), 0); - }); - }); - - describe("initBattleWithEnemyConfig", () => { - it("", () => { - - }); - }); - - describe("setCustomEncounterRewards", () => { - it("", () => { - - }); - }); - - describe("selectPokemonForOption", () => { - it("", () => { - - }); - }); - - describe("setEncounterExp", () => { - it("", () => { - - }); - }); - - describe("leaveEncounterWithoutBattle", () => { - it("", () => { - - }); - }); - - describe("handleMysteryEncounterVictory", () => { - it("", () => { - + expect(spy).toHaveBeenCalledWith("mysteryEncounter:unit_test_dialogue", "mysteryEncounter:unit_test_dialogue", null, expect.any(Function), 0); }); }); }); diff --git a/src/test/mystery-encounter/mystery-encounter.test.ts b/src/test/mystery-encounter/mystery-encounter.test.ts index d2a2e7f9d92..eaf6e04a639 100644 --- a/src/test/mystery-encounter/mystery-encounter.test.ts +++ b/src/test/mystery-encounter/mystery-encounter.test.ts @@ -4,10 +4,12 @@ import Phaser from "phaser"; import { Species } from "#enums/species"; import { MysteryEncounterPhase } from "#app/phases/mystery-encounter-phases"; import { MysteryEncounterType } from "#enums/mystery-encounter-type"; +import BattleScene from "#app/battle-scene"; describe("Mystery Encounters", () => { let phaserGame: Phaser.Game; let game: GameManager; + let scene: BattleScene; beforeAll(() => { phaserGame = new Phaser.Game({ @@ -21,34 +23,32 @@ describe("Mystery Encounters", () => { beforeEach(() => { game = new GameManager(phaserGame); + scene = game.scene; game.override.startingWave(11); game.override.mysteryEncounterChance(100); }); it("Spawns a mystery encounter", async () => { - await game.runToMysteryEncounter(MysteryEncounterType.MYSTERIOUS_CHALLENGERS, [Species.CHARIZARD, Species.VOLCARONA]); + await game.runToMysteryEncounter(MysteryEncounterType.MYSTERIOUS_CHALLENGERS, [ Species.CHARIZARD, Species.VOLCARONA ]); await game.phaseInterceptor.to(MysteryEncounterPhase, false); expect(game.scene.getCurrentPhase()!.constructor.name).toBe(MysteryEncounterPhase.name); }); - it("", async () => { - await game.runToMysteryEncounter(MysteryEncounterType.MYSTERIOUS_CHALLENGERS, [Species.CHARIZARD, Species.VOLCARONA]); + it("Encounters should not run below wave 10", async () => { + game.override.startingWave(9); - await game.phaseInterceptor.to(MysteryEncounterPhase, false); - expect(game.scene.getCurrentPhase()!.constructor.name).toBe(MysteryEncounterPhase.name); + await game.runToMysteryEncounter(); + + expect(scene.currentBattle?.mysteryEncounter?.encounterType).not.toBe(MysteryEncounterType.MYSTERIOUS_CHALLENGERS); }); - it("spawns mysterious challengers encounter", async () => { - }); + it("Encounters should not run above wave 180", async () => { + game.override.startingWave(181); - it("spawns mysterious chest encounter", async () => { - }); + await game.runToMysteryEncounter(); - it("spawns dark deal encounter", async () => { - }); - - it("spawns fight or flight encounter", async () => { + expect(scene.currentBattle.mysteryEncounter).toBeUndefined(); }); }); diff --git a/src/test/phases/form-change-phase.test.ts b/src/test/phases/form-change-phase.test.ts new file mode 100644 index 00000000000..3c0016260a3 --- /dev/null +++ b/src/test/phases/form-change-phase.test.ts @@ -0,0 +1,60 @@ +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; +import { Type } from "#enums/type"; +import { generateModifierType } from "#app/data/mystery-encounters/utils/encounter-phase-utils"; +import { modifierTypes } from "#app/modifier/modifier-type"; + +describe("Form Change Phase", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.SPLASH ]) + .ability(Abilities.BALL_FETCH) + .battleType("single") + .disableCrits() + .enemySpecies(Species.MAGIKARP) + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.SPLASH); + }); + + it("Zacian should successfully change into Crowned form", async () => { + await game.classicMode.startBattle([ Species.ZACIAN ]); + + // Before the form change: Should be Hero form + const zacian = game.scene.getPlayerParty()[0]; + expect(zacian.getFormKey()).toBe("hero-of-many-battles"); + expect(zacian.getTypes()).toStrictEqual([ Type.FAIRY ]); + expect(zacian.calculateBaseStats()).toStrictEqual([ 92, 120, 115, 80, 115, 138 ]); + + // Give Zacian a Rusted Sword + const rustedSwordType = generateModifierType(game.scene, modifierTypes.RARE_FORM_CHANGE_ITEM)!; + const rustedSword = rustedSwordType.newModifier(zacian); + await game.scene.addModifier(rustedSword); + + game.move.select(Moves.SPLASH); + await game.toNextTurn(); + + // After the form change: Should be Crowned form + expect(game.phaseInterceptor.log.includes("FormChangePhase")).toBe(true); + expect(zacian.getFormKey()).toBe("crowned"); + expect(zacian.getTypes()).toStrictEqual([ Type.FAIRY, Type.STEEL ]); + expect(zacian.calculateBaseStats()).toStrictEqual([ 92, 150, 115, 80, 115, 148 ]); + }); +}); diff --git a/src/test/phases/frenzy-move-reset.test.ts b/src/test/phases/frenzy-move-reset.test.ts new file mode 100644 index 00000000000..db9ec2bfe66 --- /dev/null +++ b/src/test/phases/frenzy-move-reset.test.ts @@ -0,0 +1,72 @@ +import { BattlerIndex } from "#app/battle"; +import { Abilities } from "#enums/abilities"; +import { BattlerTagType } from "#enums/battler-tag-type"; +import { StatusEffect } from "#enums/status-effect"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, it, expect } from "vitest"; + +describe("Frenzy Move Reset", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .battleType("single") + .disableCrits() + .starterSpecies(Species.MAGIKARP) + .moveset(Moves.THRASH) + .statusEffect(StatusEffect.PARALYSIS) + .enemyMoveset(Moves.SPLASH) + .enemyLevel(100) + .enemySpecies(Species.SHUCKLE) + .enemyAbility(Abilities.BALL_FETCH); + }); + + /* + * Thrash (or frenzy moves in general) should not continue to run if attack fails due to paralysis + * + * This is a 3-turn Thrash test: + * 1. Thrash is selected and succeeds to hit the enemy -> Enemy Faints + * + * 2. Thrash is automatically selected but misses due to paralysis + * Note: After missing the Pokemon should stop automatically attacking + * + * 3. At the start of the 3rd turn the Player should be able to select a move/switch Pokemon/etc. + * Note: This means that BattlerTag.FRENZY is not anymore in pokemon.summonData.tags and pokemon.summonData.moveQueue is empty + * + */ + it("should cancel frenzy move if move fails turn 2", async () => { + await game.classicMode.startBattle(); + + const playerPokemon = game.scene.getPlayerPokemon()!; + + game.move.select(Moves.THRASH); + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + await game.move.forceStatusActivation(false); + await game.toNextTurn(); + + expect(playerPokemon.summonData.moveQueue.length).toBe(2); + expect(playerPokemon.summonData.tags.some(tag => tag.tagType === BattlerTagType.FRENZY)).toBe(true); + + await game.setTurnOrder([ BattlerIndex.PLAYER, BattlerIndex.ENEMY ]); + await game.move.forceStatusActivation(true); + await game.toNextTurn(); + + expect(playerPokemon.summonData.moveQueue.length).toBe(0); + expect(playerPokemon.summonData.tags.some(tag => tag.tagType === BattlerTagType.FRENZY)).toBe(false); + }); +}); diff --git a/src/test/phases/game-over-phase.test.ts b/src/test/phases/game-over-phase.test.ts new file mode 100644 index 00000000000..2e19d5fe954 --- /dev/null +++ b/src/test/phases/game-over-phase.test.ts @@ -0,0 +1,77 @@ +import { Biome } from "#enums/biome"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; +import { achvs } from "#app/system/achv"; +import { Unlockables } from "#app/system/unlockables"; + +describe("Game Over Phase", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.MEMENTO, Moves.ICE_BEAM, Moves.SPLASH ]) + .ability(Abilities.BALL_FETCH) + .battleType("single") + .disableCrits() + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.SPLASH) + .startingWave(200) + .startingBiome(Biome.END) + .startingLevel(10000); + }); + + it("winning a run should give rewards", async () => { + await game.classicMode.startBattle([ Species.BULBASAUR ]); + vi.spyOn(game.scene, "validateAchv"); + + // Note: `game.doKillOpponents()` does not properly handle final boss + // Final boss phase 1 + game.move.select(Moves.ICE_BEAM); + await game.toNextTurn(); + + // Final boss phase 2 + game.move.select(Moves.ICE_BEAM); + await game.phaseInterceptor.to("PostGameOverPhase", false); + + // The game refused to actually give the vouchers during tests, + // so the best we can do is to check that their reward phases occurred. + expect(game.phaseInterceptor.log.includes("GameOverPhase")).toBe(true); + expect(game.phaseInterceptor.log.includes("UnlockPhase")).toBe(true); + expect(game.phaseInterceptor.log.includes("RibbonModifierRewardPhase")).toBe(true); + expect(game.scene.gameData.unlocks[Unlockables.ENDLESS_MODE]).toBe(true); + expect(game.scene.validateAchv).toHaveBeenCalledWith(achvs.CLASSIC_VICTORY); + expect(game.scene.gameData.achvUnlocks[achvs.CLASSIC_VICTORY.id]).toBeTruthy(); + }); + + it("losing a run should not give rewards", async () => { + await game.classicMode.startBattle([ Species.BULBASAUR ]); + vi.spyOn(game.scene, "validateAchv"); + + game.move.select(Moves.MEMENTO); + await game.phaseInterceptor.to("PostGameOverPhase", false); + + expect(game.phaseInterceptor.log.includes("GameOverPhase")).toBe(true); + expect(game.phaseInterceptor.log.includes("UnlockPhase")).toBe(false); + expect(game.phaseInterceptor.log.includes("RibbonModifierRewardPhase")).toBe(false); + expect(game.phaseInterceptor.log.includes("GameOverModifierRewardPhase")).toBe(false); + expect(game.scene.gameData.unlocks[Unlockables.ENDLESS_MODE]).toBe(false); + expect(game.scene.validateAchv).not.toHaveBeenCalledWith(achvs.CLASSIC_VICTORY); + expect(game.scene.gameData.achvUnlocks[achvs.CLASSIC_VICTORY.id]).toBeFalsy(); + }); +}); diff --git a/src/test/phases/learn-move-phase.test.ts b/src/test/phases/learn-move-phase.test.ts index 60cdbee8570..c4fa0e8bf45 100644 --- a/src/test/phases/learn-move-phase.test.ts +++ b/src/test/phases/learn-move-phase.test.ts @@ -25,8 +25,8 @@ describe("Learn Move Phase", () => { }); it("If Pokemon has less than 4 moves, its newest move will be added to the lowest empty index", async () => { - game.override.moveset([Moves.SPLASH]); - await game.startBattle([Species.BULBASAUR]); + game.override.moveset([ Moves.SPLASH ]); + await game.startBattle([ Species.BULBASAUR ]); const pokemon = game.scene.getPlayerPokemon()!; const newMovePos = pokemon?.getMoveset().length; game.move.select(Moves.SPLASH); diff --git a/src/test/phases/mystery-encounter-phase.test.ts b/src/test/phases/mystery-encounter-phase.test.ts index 0a99cd00db3..32e31ce1c94 100644 --- a/src/test/phases/mystery-encounter-phase.test.ts +++ b/src/test/phases/mystery-encounter-phase.test.ts @@ -1,14 +1,15 @@ -import {afterEach, beforeAll, beforeEach, expect, describe, it, vi } from "vitest"; +import { afterEach, beforeAll, beforeEach, expect, describe, it, vi } from "vitest"; import GameManager from "#app/test/utils/gameManager"; import Phaser from "phaser"; -import {Species} from "#enums/species"; +import { Species } from "#enums/species"; import { MysteryEncounterOptionSelectedPhase, MysteryEncounterPhase } from "#app/phases/mystery-encounter-phases"; -import {Mode} from "#app/ui/ui"; -import {Button} from "#enums/buttons"; +import { Mode } from "#app/ui/ui"; +import { Button } from "#enums/buttons"; import MysteryEncounterUiHandler from "#app/ui/mystery-encounter-ui-handler"; -import {MysteryEncounterType} from "#enums/mystery-encounter-type"; +import { MysteryEncounterType } from "#enums/mystery-encounter-type"; import MessageUiHandler from "#app/ui/message-ui-handler"; import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; +import i18next from "i18next"; describe("Mystery Encounter Phases", () => { let phaserGame: Phaser.Game; @@ -34,14 +35,14 @@ describe("Mystery Encounter Phases", () => { describe("MysteryEncounterPhase", () => { it("Runs to MysteryEncounterPhase", async() => { - await game.runToMysteryEncounter(MysteryEncounterType.MYSTERIOUS_CHALLENGERS, [Species.CHARIZARD, Species.VOLCARONA]); + await game.runToMysteryEncounter(MysteryEncounterType.MYSTERIOUS_CHALLENGERS, [ Species.CHARIZARD, Species.VOLCARONA ]); await game.phaseInterceptor.to(MysteryEncounterPhase, false); expect(game.scene.getCurrentPhase()?.constructor.name).toBe(MysteryEncounterPhase.name); }); it("Runs MysteryEncounterPhase", async() => { - await game.runToMysteryEncounter(MysteryEncounterType.MYSTERIOUS_CHALLENGERS, [Species.CHARIZARD, Species.VOLCARONA]); + await game.runToMysteryEncounter(MysteryEncounterType.MYSTERIOUS_CHALLENGERS, [ Species.CHARIZARD, Species.VOLCARONA ]); game.onNextPrompt("MysteryEncounterPhase", Mode.MYSTERY_ENCOUNTER, () => { // End phase early for test @@ -56,9 +57,10 @@ describe("Mystery Encounter Phases", () => { }); it("Selects an option for MysteryEncounterPhase", async() => { - const dialogueSpy = vi.spyOn(game.scene.ui, "showDialogue"); - const messageSpy = vi.spyOn(game.scene.ui, "showText"); - await game.runToMysteryEncounter(MysteryEncounterType.MYSTERIOUS_CHALLENGERS, [Species.CHARIZARD, Species.VOLCARONA]); + const { ui } = game.scene; + vi.spyOn(ui, "showDialogue"); + vi.spyOn(ui, "showText"); + await game.runToMysteryEncounter(MysteryEncounterType.MYSTERIOUS_CHALLENGERS, [ Species.CHARIZARD, Species.VOLCARONA ]); game.onNextPrompt("MysteryEncounterPhase", Mode.MESSAGE, () => { const handler = game.scene.ui.getHandler() as MessageUiHandler; @@ -74,12 +76,12 @@ describe("Mystery Encounter Phases", () => { // Waitfor required so that option select messages and preOptionPhase logic are handled await vi.waitFor(() => expect(game.scene.getCurrentPhase()?.constructor.name).toBe(MysteryEncounterOptionSelectedPhase.name)); - expect(game.scene.ui.getMode()).toBe(Mode.MESSAGE); - expect(dialogueSpy).toHaveBeenCalledTimes(1); - expect(messageSpy).toHaveBeenCalledTimes(2); - expect(dialogueSpy).toHaveBeenCalledWith("What's this?", "???", null, expect.any(Function)); - expect(messageSpy).toHaveBeenCalledWith("Mysterious challengers have appeared!", null, expect.any(Function), 750, true); - expect(messageSpy).toHaveBeenCalledWith("The trainer steps forward...", null, expect.any(Function), 300, true); + expect(ui.getMode()).toBe(Mode.MESSAGE); + expect(ui.showDialogue).toHaveBeenCalledTimes(1); + expect(ui.showText).toHaveBeenCalledTimes(2); + expect(ui.showDialogue).toHaveBeenCalledWith(i18next.t("battle:mysteryEncounterAppeared"), "???", null, expect.any(Function)); + expect(ui.showText).toHaveBeenCalledWith(i18next.t("mysteryEncounters/mysteriousChallengers:intro"), null, expect.any(Function), 750, true); + expect(ui.showText).toHaveBeenCalledWith(i18next.t("mysteryEncounters/mysteriousChallengers:option.selected"), null, expect.any(Function), 300, true); }); }); diff --git a/src/test/phases/select-modifier-phase.test.ts b/src/test/phases/select-modifier-phase.test.ts index d946c850ae3..60f81f3ad54 100644 --- a/src/test/phases/select-modifier-phase.test.ts +++ b/src/test/phases/select-modifier-phase.test.ts @@ -28,7 +28,7 @@ describe("SelectModifierPhase", () => { game = new GameManager(phaserGame); scene = game.scene; - initSceneWithoutEncounterPhase(scene, [Species.ABRA, Species.VOLCARONA]); + initSceneWithoutEncounterPhase(scene, [ Species.ABRA, Species.VOLCARONA ]); }); afterEach(() => { @@ -63,11 +63,11 @@ describe("SelectModifierPhase", () => { new ModifierTypeOption(modifierTypes.REVIVE(), 0, 1000) ]; - const selectModifierPhase1 = new SelectModifierPhase(scene); - const selectModifierPhase2 = new SelectModifierPhase(scene, 0, undefined, { rerollMultiplier: 2 }); + const selectModifierPhase1 = new SelectModifierPhase(scene, 0, undefined, { guaranteedModifierTypeOptions: options }); + const selectModifierPhase2 = new SelectModifierPhase(scene, 0, undefined, { guaranteedModifierTypeOptions: options, rerollMultiplier: 2 }); - const cost1 = selectModifierPhase1.getRerollCost(options, false); - const cost2 = selectModifierPhase2.getRerollCost(options, false); + const cost1 = selectModifierPhase1.getRerollCost(false); + const cost2 = selectModifierPhase2.getRerollCost(false); expect(cost2).toEqual(cost1 * 2); }); @@ -81,7 +81,7 @@ describe("SelectModifierPhase", () => { expect(modifierSelectHandler.options.length).toEqual(3); // Simulate selecting reroll - selectModifierPhase = new SelectModifierPhase(scene, 1, [ModifierTier.COMMON, ModifierTier.COMMON, ModifierTier.COMMON]); + selectModifierPhase = new SelectModifierPhase(scene, 1, [ ModifierTier.COMMON, ModifierTier.COMMON, ModifierTier.COMMON ]); scene.unshiftPhase(selectModifierPhase); scene.ui.setMode(Mode.MESSAGE).then(() => game.endPhase()); await game.phaseInterceptor.run(SelectModifierPhase); @@ -94,7 +94,7 @@ describe("SelectModifierPhase", () => { // Just use fully random seed for this test vi.spyOn(scene, "resetSeed").mockImplementation(() => { scene.waveSeed = Utils.shiftCharCodes(scene.seed, 5); - Phaser.Math.RND.sow([scene.waveSeed]); + Phaser.Math.RND.sow([ scene.waveSeed ]); console.log("Wave Seed:", scene.waveSeed, 5); scene.rngCounter = 0; }); @@ -126,7 +126,7 @@ describe("SelectModifierPhase", () => { it("should generate custom modifiers", async () => { const customModifiers: CustomModifierSettings = { - guaranteedModifierTypeFuncs: [modifierTypes.MEMORY_MUSHROOM, modifierTypes.TM_ULTRA, modifierTypes.LEFTOVERS, modifierTypes.AMULET_COIN, modifierTypes.GOLDEN_PUNCH] + guaranteedModifierTypeFuncs: [ modifierTypes.MEMORY_MUSHROOM, modifierTypes.TM_ULTRA, modifierTypes.LEFTOVERS, modifierTypes.AMULET_COIN, modifierTypes.GOLDEN_PUNCH ] }; const selectModifierPhase = new SelectModifierPhase(scene, 0, undefined, customModifiers); scene.pushPhase(selectModifierPhase); @@ -145,15 +145,15 @@ describe("SelectModifierPhase", () => { it("should generate custom modifier tiers that can upgrade from luck", async () => { const customModifiers: CustomModifierSettings = { - guaranteedModifierTiers: [ModifierTier.COMMON, ModifierTier.GREAT, ModifierTier.ULTRA, ModifierTier.ROGUE, ModifierTier.MASTER] + guaranteedModifierTiers: [ ModifierTier.COMMON, ModifierTier.GREAT, ModifierTier.ULTRA, ModifierTier.ROGUE, ModifierTier.MASTER ] }; const pokemon = new PlayerPokemon(scene, getPokemonSpecies(Species.BULBASAUR), 10, undefined, 0, undefined, true, 2, undefined, undefined, undefined); // Fill party with max shinies - while (scene.getParty().length > 0) { - scene.getParty().pop(); + while (scene.getPlayerParty().length > 0) { + scene.getPlayerParty().pop(); } - scene.getParty().push(pokemon, pokemon, pokemon, pokemon, pokemon, pokemon); + scene.getPlayerParty().push(pokemon, pokemon, pokemon, pokemon, pokemon, pokemon); const selectModifierPhase = new SelectModifierPhase(scene, 0, undefined, customModifiers); scene.pushPhase(selectModifierPhase); @@ -172,8 +172,8 @@ describe("SelectModifierPhase", () => { it("should generate custom modifiers and modifier tiers together", async () => { const customModifiers: CustomModifierSettings = { - guaranteedModifierTypeFuncs: [modifierTypes.MEMORY_MUSHROOM, modifierTypes.TM_COMMON], - guaranteedModifierTiers: [ModifierTier.MASTER, ModifierTier.MASTER] + guaranteedModifierTypeFuncs: [ modifierTypes.MEMORY_MUSHROOM, modifierTypes.TM_COMMON ], + guaranteedModifierTiers: [ ModifierTier.MASTER, ModifierTier.MASTER ] }; const selectModifierPhase = new SelectModifierPhase(scene, 0, undefined, customModifiers); scene.pushPhase(selectModifierPhase); @@ -191,8 +191,8 @@ describe("SelectModifierPhase", () => { it("should fill remaining modifiers if fillRemaining is true with custom modifiers", async () => { const customModifiers: CustomModifierSettings = { - guaranteedModifierTypeFuncs: [modifierTypes.MEMORY_MUSHROOM], - guaranteedModifierTiers: [ModifierTier.MASTER], + guaranteedModifierTypeFuncs: [ modifierTypes.MEMORY_MUSHROOM ], + guaranteedModifierTiers: [ ModifierTier.MASTER ], fillRemaining: true }; const selectModifierPhase = new SelectModifierPhase(scene, 0, undefined, customModifiers); diff --git a/src/test/plugins/api/pokerogue-account-api.test.ts b/src/test/plugins/api/pokerogue-account-api.test.ts new file mode 100644 index 00000000000..90a7d3639ad --- /dev/null +++ b/src/test/plugins/api/pokerogue-account-api.test.ts @@ -0,0 +1,157 @@ +import type { AccountInfoResponse } from "#app/@types/PokerogueAccountApi"; +import { SESSION_ID_COOKIE_NAME } from "#app/constants"; +import { PokerogueAccountApi } from "#app/plugins/api/pokerogue-account-api"; +import { getApiBaseUrl } from "#app/test/utils/testUtils"; +import * as Utils from "#app/utils"; +import { http, HttpResponse } from "msw"; +import { afterEach, beforeEach, describe, expect, it, vi } from "vitest"; + +const apiBase = getApiBaseUrl(); +const accountApi = new PokerogueAccountApi(apiBase); +const { server } = global; + +afterEach(() => { + server.resetHandlers(); +}); + +describe("Pokerogue Account API", () => { + beforeEach(() => { + vi.spyOn(console, "warn"); + }); + + describe("Get Info", () => { + it("should return account-info & 200 on SUCCESS", async () => { + const expectedAccountInfo: AccountInfoResponse = { + username: "test", + lastSessionSlot: -1, + discordId: "23235353543535", + googleId: "1ed1d1d11d1d1d1d1d1", + hasAdminRole: false, + }; + server.use(http.get(`${apiBase}/account/info`, () => HttpResponse.json(expectedAccountInfo))); + + const [ accountInfo, status ] = await accountApi.getInfo(); + + expect(accountInfo).toEqual(expectedAccountInfo); + expect(status).toBe(200); + }); + + it("should return null + status-code anad report a warning on FAILURE", async () => { + server.use(http.get(`${apiBase}/account/info`, () => new HttpResponse("", { status: 401 }))); + + const [ accountInfo, status ] = await accountApi.getInfo(); + + expect(accountInfo).toBeNull(); + expect(status).toBe(401); + expect(console.warn).toHaveBeenCalledWith("Could not get account info!", 401, "Unauthorized"); + }); + + it("should return null + 500 anad report a warning on ERROR", async () => { + server.use(http.get(`${apiBase}/account/info`, () => HttpResponse.error())); + + const [ accountInfo, status ] = await accountApi.getInfo(); + + expect(accountInfo).toBeNull(); + expect(status).toBe(500); + expect(console.warn).toHaveBeenCalledWith("Could not get account info!", expect.any(Error)); + }); + }); + + describe("Register", () => { + const registerParams = { username: "test", password: "test" }; + + it("should return null on SUCCESS", async () => { + server.use(http.post(`${apiBase}/account/register`, () => HttpResponse.text())); + + const error = await accountApi.register(registerParams); + + expect(error).toBeNull(); + }); + + it("should return error message on FAILURE", async () => { + server.use( + http.post(`${apiBase}/account/register`, () => new HttpResponse("Username is already taken", { status: 400 })) + ); + + const error = await accountApi.register(registerParams); + + expect(error).toBe("Username is already taken"); + }); + + it("should return \"Unknown error\" and report a warning on ERROR", async () => { + server.use(http.post(`${apiBase}/account/register`, () => HttpResponse.error())); + + const error = await accountApi.register(registerParams); + + expect(error).toBe("Unknown error!"); + expect(console.warn).toHaveBeenCalledWith("Register failed!", expect.any(Error)); + }); + }); + + describe("Login", () => { + const loginParams = { username: "test", password: "test" }; + + it("should return null and set the cookie on SUCCESS", async () => { + vi.spyOn(Utils, "setCookie"); + server.use(http.post(`${apiBase}/account/login`, () => HttpResponse.json({ token: "abctest" }))); + + const error = await accountApi.login(loginParams); + + expect(error).toBeNull(); + expect(Utils.setCookie).toHaveBeenCalledWith(SESSION_ID_COOKIE_NAME, "abctest"); + }); + + it("should return error message and report a warning on FAILURE", async () => { + server.use( + http.post(`${apiBase}/account/login`, () => new HttpResponse("Password is incorrect", { status: 401 })) + ); + + const error = await accountApi.login(loginParams); + + expect(error).toBe("Password is incorrect"); + expect(console.warn).toHaveBeenCalledWith("Login failed!", 401, "Unauthorized"); + }); + + it("should return \"Unknown error\" and report a warning on ERROR", async () => { + server.use(http.post(`${apiBase}/account/login`, () => HttpResponse.error())); + + const error = await accountApi.login(loginParams); + + expect(error).toBe("Unknown error!"); + expect(console.warn).toHaveBeenCalledWith("Login failed!", expect.any(Error)); + }); + }); + + describe("Logout", () => { + beforeEach(() => { + vi.spyOn(Utils, "removeCookie"); + }); + + it("should remove cookie on success", async () => { + vi.spyOn(Utils, "setCookie"); + server.use(http.get(`${apiBase}/account/logout`, () => new HttpResponse("", { status: 200 }))); + + await accountApi.logout(); + + expect(Utils.removeCookie).toHaveBeenCalledWith(SESSION_ID_COOKIE_NAME); + }); + + it("should report a warning on and remove cookie on FAILURE", async () => { + server.use(http.get(`${apiBase}/account/logout`, () => new HttpResponse("", { status: 401 }))); + + await accountApi.logout(); + + expect(Utils.removeCookie).toHaveBeenCalledWith(SESSION_ID_COOKIE_NAME); + expect(console.warn).toHaveBeenCalledWith("Log out failed!", expect.any(Error)); + }); + + it("should report a warning on and remove cookie on ERROR", async () => { + server.use(http.get(`${apiBase}/account/logout`, () => HttpResponse.error())); + + await accountApi.logout(); + + expect(Utils.removeCookie).toHaveBeenCalledWith(SESSION_ID_COOKIE_NAME); + expect(console.warn).toHaveBeenCalledWith("Log out failed!", expect.any(Error)); + }); + }); +}); diff --git a/src/test/plugins/api/pokerogue-admin-api.test.ts b/src/test/plugins/api/pokerogue-admin-api.test.ts new file mode 100644 index 00000000000..5ae46abfcc8 --- /dev/null +++ b/src/test/plugins/api/pokerogue-admin-api.test.ts @@ -0,0 +1,232 @@ +import type { + LinkAccountToDiscordIdRequest, + LinkAccountToGoogledIdRequest, + SearchAccountRequest, + SearchAccountResponse, + UnlinkAccountFromDiscordIdRequest, + UnlinkAccountFromGoogledIdRequest, +} from "#app/@types/PokerogueAdminApi"; +import { PokerogueAdminApi } from "#app/plugins/api/pokerogue-admin-api"; +import { getApiBaseUrl } from "#app/test/utils/testUtils"; +import { http, HttpResponse } from "msw"; +import { afterEach, beforeEach, describe, expect, it, vi } from "vitest"; + +const apiBase = getApiBaseUrl(); +const adminApi = new PokerogueAdminApi(apiBase); +const { server } = global; + +afterEach(() => { + server.resetHandlers(); +}); + +describe("Pokerogue Admin API", () => { + beforeEach(() => { + vi.spyOn(console, "warn"); + }); + + describe("Link Account to Discord", () => { + const params: LinkAccountToDiscordIdRequest = { username: "test", discordId: "test-12575756" }; + + it("should return null on SUCCESS", async () => { + server.use(http.post(`${apiBase}/admin/account/discordLink`, () => HttpResponse.json(true))); + + const success = await adminApi.linkAccountToDiscord(params); + + expect(success).toBeNull(); + }); + + it("should return a ERR_GENERIC and report a warning on FAILURE", async () => { + server.use(http.post(`${apiBase}/admin/account/discordLink`, () => new HttpResponse("", { status: 400 }))); + + const success = await adminApi.linkAccountToDiscord(params); + + expect(success).toBe(adminApi.ERR_GENERIC); + expect(console.warn).toHaveBeenCalledWith("Could not link account with discord!", 400, "Bad Request"); + }); + + it("should return a ERR_USERNAME_NOT_FOUND and report a warning on 404", async () => { + server.use(http.post(`${apiBase}/admin/account/discordLink`, () => new HttpResponse("", { status: 404 }))); + + const success = await adminApi.linkAccountToDiscord(params); + + expect(success).toBe(adminApi.ERR_USERNAME_NOT_FOUND); + expect(console.warn).toHaveBeenCalledWith("Could not link account with discord!", 404, "Not Found"); + }); + + it("should return a ERR_GENERIC and report a warning on ERROR", async () => { + server.use(http.post(`${apiBase}/admin/account/discordLink`, () => HttpResponse.error())); + + const success = await adminApi.linkAccountToDiscord(params); + + expect(success).toBe(adminApi.ERR_GENERIC); + expect(console.warn).toHaveBeenCalledWith("Could not link account with discord!", expect.any(Error)); + }); + }); + + describe("Unlink Account from Discord", () => { + const params: UnlinkAccountFromDiscordIdRequest = { username: "test", discordId: "test-12575756" }; + + it("should return null on SUCCESS", async () => { + server.use(http.post(`${apiBase}/admin/account/discordUnlink`, () => HttpResponse.json(true))); + + const success = await adminApi.unlinkAccountFromDiscord(params); + + expect(success).toBeNull(); + }); + + it("should return a ERR_GENERIC and report a warning on FAILURE", async () => { + server.use(http.post(`${apiBase}/admin/account/discordUnlink`, () => new HttpResponse("", { status: 400 }))); + + const success = await adminApi.unlinkAccountFromDiscord(params); + + expect(success).toBe(adminApi.ERR_GENERIC); + expect(console.warn).toHaveBeenCalledWith("Could not unlink account from discord!", 400, "Bad Request"); + }); + + it("should return a ERR_USERNAME_NOT_FOUND and report a warning on 404", async () => { + server.use(http.post(`${apiBase}/admin/account/discordUnlink`, () => new HttpResponse("", { status: 404 }))); + + const success = await adminApi.unlinkAccountFromDiscord(params); + + expect(success).toBe(adminApi.ERR_USERNAME_NOT_FOUND); + expect(console.warn).toHaveBeenCalledWith("Could not unlink account from discord!", 404, "Not Found"); + }); + + it("should return a ERR_GENERIC and report a warning on ERROR", async () => { + server.use(http.post(`${apiBase}/admin/account/discordUnlink`, () => HttpResponse.error())); + + const success = await adminApi.unlinkAccountFromDiscord(params); + + expect(success).toBe(adminApi.ERR_GENERIC); + expect(console.warn).toHaveBeenCalledWith("Could not unlink account from discord!", expect.any(Error)); + }); + }); + + describe("Link Account to Google", () => { + const params: LinkAccountToGoogledIdRequest = { username: "test", googleId: "test-12575756" }; + + it("should return null on SUCCESS", async () => { + server.use(http.post(`${apiBase}/admin/account/googleLink`, () => HttpResponse.json(true))); + + const success = await adminApi.linkAccountToGoogleId(params); + + expect(success).toBeNull(); + }); + + it("should return a ERR_GENERIC and report a warning on FAILURE", async () => { + server.use(http.post(`${apiBase}/admin/account/googleLink`, () => new HttpResponse("", { status: 400 }))); + + const success = await adminApi.linkAccountToGoogleId(params); + + expect(success).toBe(adminApi.ERR_GENERIC); + expect(console.warn).toHaveBeenCalledWith("Could not link account with google!", 400, "Bad Request"); + }); + + it("should return a ERR_USERNAME_NOT_FOUND and report a warning on 404", async () => { + server.use(http.post(`${apiBase}/admin/account/googleLink`, () => new HttpResponse("", { status: 404 }))); + + const success = await adminApi.linkAccountToGoogleId(params); + + expect(success).toBe(adminApi.ERR_USERNAME_NOT_FOUND); + expect(console.warn).toHaveBeenCalledWith("Could not link account with google!", 404, "Not Found"); + }); + + it("should return a ERR_GENERIC and report a warning on ERROR", async () => { + server.use(http.post(`${apiBase}/admin/account/googleLink`, () => HttpResponse.error())); + + const success = await adminApi.linkAccountToGoogleId(params); + + expect(success).toBe(adminApi.ERR_GENERIC); + expect(console.warn).toHaveBeenCalledWith("Could not link account with google!", expect.any(Error)); + }); + }); + + describe("Unlink Account from Google", () => { + const params: UnlinkAccountFromGoogledIdRequest = { username: "test", googleId: "test-12575756" }; + + it("should return null on SUCCESS", async () => { + server.use(http.post(`${apiBase}/admin/account/googleUnlink`, () => HttpResponse.json(true))); + + const success = await adminApi.unlinkAccountFromGoogleId(params); + + expect(success).toBeNull(); + }); + + it("should return a ERR_GENERIC and report a warning on FAILURE", async () => { + server.use(http.post(`${apiBase}/admin/account/googleUnlink`, () => new HttpResponse("", { status: 400 }))); + + const success = await adminApi.unlinkAccountFromGoogleId(params); + + expect(success).toBe(adminApi.ERR_GENERIC); + expect(console.warn).toHaveBeenCalledWith("Could not unlink account from google!", 400, "Bad Request"); + }); + + it("should return a ERR_USERNAME_NOT_FOUND and report a warning on 404", async () => { + server.use(http.post(`${apiBase}/admin/account/googleUnlink`, () => new HttpResponse("", { status: 404 }))); + + const success = await adminApi.unlinkAccountFromGoogleId(params); + + expect(success).toBe(adminApi.ERR_USERNAME_NOT_FOUND); + expect(console.warn).toHaveBeenCalledWith("Could not unlink account from google!", 404, "Not Found"); + }); + + it("should return a ERR_GENERIC and report a warning on ERROR", async () => { + server.use(http.post(`${apiBase}/admin/account/googleUnlink`, () => HttpResponse.error())); + + const success = await adminApi.unlinkAccountFromGoogleId(params); + + expect(success).toBe(adminApi.ERR_GENERIC); + expect(console.warn).toHaveBeenCalledWith("Could not unlink account from google!", expect.any(Error)); + }); + }); + + describe("Search Account", () => { + const params: SearchAccountRequest = { username: "test" }; + + it("should return [data, undefined] on SUCCESS", async () => { + const responseData: SearchAccountResponse = { + username: "test", + discordId: "discord-test-123", + googleId: "google-test-123", + lastLoggedIn: "2022-01-01", + registered: "2022-01-01", + }; + server.use(http.get(`${apiBase}/admin/account/adminSearch`, () => HttpResponse.json(responseData))); + + const [ data, err ] = await adminApi.searchAccount(params); + + expect(data).toStrictEqual(responseData); + expect(err).toBeUndefined(); + }); + + it("should return [undefined, ERR_GENERIC] and report a warning on on FAILURE", async () => { + server.use(http.get(`${apiBase}/admin/account/adminSearch`, () => new HttpResponse("", { status: 400 }))); + + const [ data, err ] = await adminApi.searchAccount(params); + + expect(data).toBeUndefined(); + expect(err).toBe(adminApi.ERR_GENERIC); + expect(console.warn).toHaveBeenCalledWith("Could not find account!", 400, "Bad Request"); + }); + + it("should return [undefined, ERR_USERNAME_NOT_FOUND] and report a warning on on 404", async () => { + server.use(http.get(`${apiBase}/admin/account/adminSearch`, () => new HttpResponse("", { status: 404 }))); + + const [ data, err ] = await adminApi.searchAccount(params); + + expect(data).toBeUndefined(); + expect(err).toBe(adminApi.ERR_USERNAME_NOT_FOUND); + expect(console.warn).toHaveBeenCalledWith("Could not find account!", 404, "Not Found"); + }); + + it("should return [undefined, ERR_GENERIC] and report a warning on on ERROR", async () => { + server.use(http.get(`${apiBase}/admin/account/adminSearch`, () => HttpResponse.error())); + + const [ data, err ] = await adminApi.searchAccount(params); + + expect(data).toBeUndefined(); + expect(err).toBe(adminApi.ERR_GENERIC); + expect(console.warn).toHaveBeenCalledWith("Could not find account!", expect.any(Error)); + }); + }); +}); diff --git a/src/test/plugins/api/pokerogue-api.test.ts b/src/test/plugins/api/pokerogue-api.test.ts new file mode 100644 index 00000000000..a62174c226d --- /dev/null +++ b/src/test/plugins/api/pokerogue-api.test.ts @@ -0,0 +1,97 @@ +import type { TitleStatsResponse } from "#app/@types/PokerogueApi"; +import { pokerogueApi } from "#app/plugins/api/pokerogue-api"; +import { getApiBaseUrl } from "#app/test/utils/testUtils"; +import { http, HttpResponse } from "msw"; +import { afterEach, beforeEach, describe, expect, it, vi } from "vitest"; + +const apiBase = getApiBaseUrl(); +const { server } = global; + +afterEach(() => { + server.resetHandlers(); +}); + +describe("Pokerogue API", () => { + beforeEach(() => { + vi.spyOn(console, "warn"); + }); + + describe("Game Title Stats", () => { + const expectedTitleStats: TitleStatsResponse = { + playerCount: 9999999, + battleCount: 9999999, + }; + + it("should return the stats on SUCCESS", async () => { + server.use(http.get(`${apiBase}/game/titlestats`, () => HttpResponse.json(expectedTitleStats))); + + const titleStats = await pokerogueApi.getGameTitleStats(); + + expect(titleStats).toEqual(expectedTitleStats); + }); + + it("should return null and report a warning on ERROR", async () => { + server.use(http.get(`${apiBase}/game/titlestats`, () => HttpResponse.error())); + const titleStats = await pokerogueApi.getGameTitleStats(); + + expect(titleStats).toBeNull(); + expect(console.warn).toHaveBeenCalledWith("Could not get game title stats!", expect.any(Error)); + }); + }); + + describe("Unlink Discord", () => { + it("should return true on SUCCESS", async () => { + server.use(http.post(`${apiBase}/auth/discord/logout`, () => new HttpResponse("", { status: 200 }))); + + const success = await pokerogueApi.unlinkDiscord(); + + expect(success).toBe(true); + }); + + it("should return false and report a warning on FAILURE", async () => { + server.use(http.post(`${apiBase}/auth/discord/logout`, () => new HttpResponse("", { status: 401 }))); + + const success = await pokerogueApi.unlinkDiscord(); + + expect(success).toBe(false); + expect(console.warn).toHaveBeenCalledWith("Discord unlink failed (401: Unauthorized)"); + }); + + it("should return false and report a warning on ERROR", async () => { + server.use(http.post(`${apiBase}/auth/discord/logout`, () => HttpResponse.error())); + + const success = await pokerogueApi.unlinkDiscord(); + + expect(success).toBe(false); + expect(console.warn).toHaveBeenCalledWith("Could not unlink Discord!", expect.any(Error)); + }); + }); + + describe("Unlink Google", () => { + it("should return true on SUCCESS", async () => { + server.use(http.post(`${apiBase}/auth/google/logout`, () => new HttpResponse("", { status: 200 }))); + + const success = await pokerogueApi.unlinkGoogle(); + + expect(success).toBe(true); + }); + + it("should return false and report a warning on FAILURE", async () => { + server.use(http.post(`${apiBase}/auth/google/logout`, () => new HttpResponse("", { status: 401 }))); + + const success = await pokerogueApi.unlinkGoogle(); + + expect(success).toBe(false); + expect(console.warn).toHaveBeenCalledWith("Google unlink failed (401: Unauthorized)"); + }); + + it("should return false and report a warning on ERROR", async () => { + server.use(http.post(`${apiBase}/auth/google/logout`, () => HttpResponse.error())); + + const success = await pokerogueApi.unlinkGoogle(); + + expect(success).toBe(false); + expect(console.warn).toHaveBeenCalledWith("Could not unlink Google!", expect.any(Error)); + }); + }); +}); diff --git a/src/test/plugins/api/pokerogue-daily-api.test.ts b/src/test/plugins/api/pokerogue-daily-api.test.ts new file mode 100644 index 00000000000..569e7cbb15d --- /dev/null +++ b/src/test/plugins/api/pokerogue-daily-api.test.ts @@ -0,0 +1,89 @@ +import type { GetDailyRankingsPageCountRequest, GetDailyRankingsRequest } from "#app/@types/PokerogueDailyApi"; +import { PokerogueDailyApi } from "#app/plugins/api/pokerogue-daily-api"; +import { getApiBaseUrl } from "#app/test/utils/testUtils"; +import { ScoreboardCategory, type RankingEntry } from "#app/ui/daily-run-scoreboard"; +import { http, HttpResponse } from "msw"; +import { afterEach, beforeEach, describe, expect, it, vi } from "vitest"; + +const apiBase = getApiBaseUrl(); +const dailyApi = new PokerogueDailyApi(apiBase); +const { server } = global; + +afterEach(() => { + server.resetHandlers(); +}); + +describe("Pokerogue Daily API", () => { + beforeEach(() => { + vi.spyOn(console, "warn"); + }); + + describe("Get Seed", () => { + it("should return seed string on SUCCESS", async () => { + server.use(http.get(`${apiBase}/daily/seed`, () => HttpResponse.text("this-is-a-test-seed"))); + + const seed = await dailyApi.getSeed(); + + expect(seed).toBe("this-is-a-test-seed"); + }); + + it("should return null and report a warning on ERROR", async () => { + server.use(http.get(`${apiBase}/daily/seed`, () => HttpResponse.error())); + + const seed = await dailyApi.getSeed(); + + expect(seed).toBeNull(); + expect(console.warn).toHaveBeenCalledWith("Could not get daily-run seed!", expect.any(Error)); + }); + }); + + describe("Get Rankings", () => { + const params: GetDailyRankingsRequest = { + category: ScoreboardCategory.DAILY, + }; + + it("should return ranking entries on SUCCESS", async () => { + const expectedRankings: RankingEntry[] = [ + { rank: 1, score: 999, username: "Player 1", wave: 200 }, + { rank: 2, score: 10, username: "Player 2", wave: 1 }, + ]; + server.use(http.get(`${apiBase}/daily/rankings`, () => HttpResponse.json(expectedRankings))); + + const rankings = await dailyApi.getRankings(params); + + expect(rankings).toStrictEqual(expectedRankings); + }); + + it("should return null and report a warning on ERROR", async () => { + server.use(http.get(`${apiBase}/daily/rankings`, () => HttpResponse.error())); + + const rankings = await dailyApi.getRankings(params); + + expect(rankings).toBeNull(); + expect(console.warn).toHaveBeenCalledWith("Could not get daily rankings!", expect.any(Error)); + }); + }); + + describe("Get Rankings Page Count", () => { + const params: GetDailyRankingsPageCountRequest = { + category: ScoreboardCategory.DAILY, + }; + + it("should return a number on SUCCESS", async () => { + server.use(http.get(`${apiBase}/daily/rankingpagecount`, () => HttpResponse.json(5))); + + const pageCount = await dailyApi.getRankingsPageCount(params); + + expect(pageCount).toBe(5); + }); + + it("should return 1 and report a warning on ERROR", async () => { + server.use(http.get(`${apiBase}/daily/rankingpagecount`, () => HttpResponse.error())); + + const pageCount = await dailyApi.getRankingsPageCount(params); + + expect(pageCount).toBe(1); + expect(console.warn).toHaveBeenCalledWith("Could not get daily rankings page count!", expect.any(Error)); + }); + }); +}); diff --git a/src/test/plugins/api/pokerogue-savedata-api.test.ts b/src/test/plugins/api/pokerogue-savedata-api.test.ts new file mode 100644 index 00000000000..6dd402206e5 --- /dev/null +++ b/src/test/plugins/api/pokerogue-savedata-api.test.ts @@ -0,0 +1,46 @@ +import type { UpdateAllSavedataRequest } from "#app/@types/PokerogueSavedataApi"; +import { PokerogueSavedataApi } from "#app/plugins/api/pokerogue-savedata-api"; +import { getApiBaseUrl } from "#app/test/utils/testUtils"; +import { http, HttpResponse } from "msw"; +import { afterEach, beforeEach, describe, expect, it, vi } from "vitest"; + +const apiBase = getApiBaseUrl(); +const savedataApi = new PokerogueSavedataApi(apiBase); +const { server } = global; + +afterEach(() => { + server.resetHandlers(); +}); + +describe("Pokerogue Savedata API", () => { + beforeEach(() => { + vi.spyOn(console, "warn"); + }); + + describe("Update All", () => { + it("should return an empty string on SUCCESS", async () => { + server.use(http.post(`${apiBase}/savedata/updateall`, () => HttpResponse.text(null))); + + const error = await savedataApi.updateAll({} as UpdateAllSavedataRequest); + + expect(error).toBe(""); + }); + + it("should return an error message on FAILURE", async () => { + server.use(http.post(`${apiBase}/savedata/updateall`, () => HttpResponse.text("Failed to update all!"))); + + const error = await savedataApi.updateAll({} as UpdateAllSavedataRequest); + + expect(error).toBe("Failed to update all!"); + }); + + it("should return 'Unknown error' and report a warning on ERROR", async () => { + server.use(http.post(`${apiBase}/savedata/updateall`, () => HttpResponse.error())); + + const error = await savedataApi.updateAll({} as UpdateAllSavedataRequest); + + expect(error).toBe("Unknown error"); + expect(console.warn).toHaveBeenCalledWith("Could not update all savedata!", expect.any(Error)); + }); + }); +}); diff --git a/src/test/plugins/api/pokerogue-session-savedata-api.test.ts b/src/test/plugins/api/pokerogue-session-savedata-api.test.ts new file mode 100644 index 00000000000..f453c5edd88 --- /dev/null +++ b/src/test/plugins/api/pokerogue-session-savedata-api.test.ts @@ -0,0 +1,200 @@ +import type { + ClearSessionSavedataRequest, + ClearSessionSavedataResponse, + DeleteSessionSavedataRequest, + GetSessionSavedataRequest, + NewClearSessionSavedataRequest, + UpdateSessionSavedataRequest, +} from "#app/@types/PokerogueSessionSavedataApi"; +import { PokerogueSessionSavedataApi } from "#app/plugins/api/pokerogue-session-savedata-api"; +import type { SessionSaveData } from "#app/system/game-data"; +import { getApiBaseUrl } from "#app/test/utils/testUtils"; +import { http, HttpResponse } from "msw"; +import { afterEach, beforeEach, describe, expect, it, vi } from "vitest"; + +const apiBase = getApiBaseUrl(); +const sessionSavedataApi = new PokerogueSessionSavedataApi(apiBase); +const { server } = global; + +afterEach(() => { + server.resetHandlers(); +}); + +describe("Pokerogue Session Savedata API", () => { + beforeEach(() => { + vi.spyOn(console, "warn"); + }); + + describe("Newclear", () => { + const params: NewClearSessionSavedataRequest = { + clientSessionId: "test-session-id", + isVictory: true, + slot: 3 + }; + + it("should return true on SUCCESS", async () => { + server.use(http.get(`${apiBase}/savedata/session/newclear`, () => HttpResponse.json(true))); + + const success = await sessionSavedataApi.newclear(params); + + expect(success).toBe(true); + }); + + it("should return false on FAILURE", async () => { + server.use(http.get(`${apiBase}/savedata/session/newclear`, () => HttpResponse.json(false))); + + const success = await sessionSavedataApi.newclear(params); + + expect(success).toBe(false); + }); + + it("should return false and report a warning on ERROR", async () => { + server.use(http.get(`${apiBase}/savedata/session/newclear`, () => HttpResponse.error())); + + const success = await sessionSavedataApi.newclear(params); + + expect(success).toBe(false); + expect(console.warn).toHaveBeenCalledWith("Could not newclear session!", expect.any(Error)); + }); + }); + + describe("Get ", () => { + const params: GetSessionSavedataRequest = { + clientSessionId: "test-session-id", + slot: 3, + }; + + it("should return session-savedata string on SUCCESS", async () => { + server.use(http.get(`${apiBase}/savedata/session/get`, () => HttpResponse.text("TEST SESSION SAVEDATA"))); + + const savedata = await sessionSavedataApi.get(params); + + expect(savedata).toBe("TEST SESSION SAVEDATA"); + }); + + it("should return null and report a warning on ERROR", async () => { + server.use(http.get(`${apiBase}/savedata/session/get`, () => HttpResponse.error())); + + const savedata = await sessionSavedataApi.get(params); + + expect(savedata).toBeNull(); + expect(console.warn).toHaveBeenCalledWith("Could not get session savedata!", expect.any(Error)); + }); + }); + + describe("Update", () => { + const params: UpdateSessionSavedataRequest = { + clientSessionId: "test-session-id", + slot: 3, + secretId: 9876543321, + trainerId: 123456789, + }; + + it("should return an empty string on SUCCESS", async () => { + server.use(http.post(`${apiBase}/savedata/session/update`, () => HttpResponse.text(null))); + + const error = await sessionSavedataApi.update(params, "UPDATED SESSION SAVEDATA"); + + expect(error).toBe(""); + }); + + it("should return an error string on FAILURE", async () => { + server.use(http.post(`${apiBase}/savedata/session/update`, () => HttpResponse.text("Failed to update!"))); + + const error = await sessionSavedataApi.update(params, "UPDATED SESSION SAVEDATA"); + + expect(error).toBe("Failed to update!"); + }); + + it("should return 'Unknown Error!' and report a warning on ERROR", async () => { + server.use(http.post(`${apiBase}/savedata/session/update`, () => HttpResponse.error())); + + const error = await sessionSavedataApi.update(params, "UPDATED SESSION SAVEDATA"); + + expect(error).toBe("Unknown Error!"); + expect(console.warn).toHaveBeenCalledWith("Could not update session savedata!", expect.any(Error)); + }); + }); + + describe("Delete", () => { + const params: DeleteSessionSavedataRequest = { + clientSessionId: "test-session-id", + slot: 3, + }; + + it("should return null on SUCCESS", async () => { + server.use(http.get(`${apiBase}/savedata/session/delete`, () => HttpResponse.text(null))); + + const error = await sessionSavedataApi.delete(params); + + expect(error).toBeNull(); + }); + + it("should return an error string on FAILURE", async () => { + server.use( + http.get(`${apiBase}/savedata/session/delete`, () => new HttpResponse("Failed to delete!", { status: 400 })) + ); + + const error = await sessionSavedataApi.delete(params); + + expect(error).toBe("Failed to delete!"); + }); + + it("should return 'Unknown error' and report a warning on ERROR", async () => { + server.use(http.get(`${apiBase}/savedata/session/delete`, () => HttpResponse.error())); + + const error = await sessionSavedataApi.delete(params); + + expect(error).toBe("Unknown error"); + expect(console.warn).toHaveBeenCalledWith("Could not delete session savedata!", expect.any(Error)); + }); + }); + + describe("Clear", () => { + const params: ClearSessionSavedataRequest = { + clientSessionId: "test-session-id", + slot: 3, + trainerId: 123456789, + }; + + it("should return sucess=true on SUCCESS", async () => { + server.use( + http.post(`${apiBase}/savedata/session/clear`, () => + HttpResponse.json({ + success: true, + }) + ) + ); + + const { success, error } = await sessionSavedataApi.clear(params, {} as SessionSaveData); + + expect(success).toBe(true); + expect(error).toBeUndefined(); + }); + + it("should return sucess=false & an error string on FAILURE", async () => { + server.use( + http.post(`${apiBase}/savedata/session/clear`, () => + HttpResponse.json({ + success: false, + error: "Failed to clear!", + }) + ) + ); + + const { success, error } = await sessionSavedataApi.clear(params, {} as SessionSaveData); + + expect(error).toBe("Failed to clear!"); + expect(success).toBe(false); + }); + + it("should return success=false & error='Unknown error' and report a warning on ERROR", async () => { + server.use(http.post(`${apiBase}/savedata/session/clear`, () => HttpResponse.error())); + + const { success, error } = await sessionSavedataApi.clear(params, {} as SessionSaveData); + + expect(error).toBe("Unknown error"); + expect(success).toBe(false); + }); + }); +}); diff --git a/src/test/plugins/api/pokerogue-system-savedata-api.test.ts b/src/test/plugins/api/pokerogue-system-savedata-api.test.ts new file mode 100644 index 00000000000..af377762b77 --- /dev/null +++ b/src/test/plugins/api/pokerogue-system-savedata-api.test.ts @@ -0,0 +1,122 @@ +import type { + GetSystemSavedataRequest, + UpdateSystemSavedataRequest, + VerifySystemSavedataRequest, + VerifySystemSavedataResponse, +} from "#app/@types/PokerogueSystemSavedataApi"; +import { PokerogueSystemSavedataApi } from "#app/plugins/api/pokerogue-system-savedata-api"; +import type { SystemSaveData } from "#app/system/game-data"; +import { getApiBaseUrl } from "#app/test/utils/testUtils"; +import { http, HttpResponse } from "msw"; +import { afterEach, beforeEach, describe, expect, it, vi } from "vitest"; + +const apiBase = getApiBaseUrl(); +const systemSavedataApi = new PokerogueSystemSavedataApi(getApiBaseUrl()); +const { server } = global; + +afterEach(() => { + server.resetHandlers(); +}); + +describe("Pokerogue System Savedata API", () => { + beforeEach(() => { + vi.spyOn(console, "warn"); + }); + + describe("Get", () => { + const params: GetSystemSavedataRequest = { + clientSessionId: "test-session-id", + }; + + it("should return system-savedata string on SUCCESS", async () => { + server.use(http.get(`${apiBase}/savedata/system/get`, () => HttpResponse.text("TEST SYSTEM SAVEDATA"))); + + const savedata = await systemSavedataApi.get(params); + + expect(savedata).toBe("TEST SYSTEM SAVEDATA"); + }); + + it("should return null and report a warning on ERROR", async () => { + server.use(http.get(`${apiBase}/savedata/system/get`, () => HttpResponse.error())); + + const savedata = await systemSavedataApi.get(params); + + expect(savedata).toBeNull(); + expect(console.warn).toHaveBeenCalledWith("Could not get system savedata!", expect.any(Error)); + }); + }); + + describe("Verify", () => { + const params: VerifySystemSavedataRequest = { + clientSessionId: "test-session-id", + }; + + it("should return null on SUCCESS", async () => { + server.use( + http.get(`${apiBase}/savedata/system/verify`, () => + HttpResponse.json({ + systemData: { + trainerId: 123456789, + } as SystemSaveData, + valid: true, + }) + ) + ); + + const savedata = await systemSavedataApi.verify(params); + + expect(savedata).toBeNull(); + }); + + it("should return system-savedata and report a warning on FAILURE", async () => { + server.use( + http.get(`${apiBase}/savedata/system/verify`, () => + HttpResponse.json({ + systemData: { + trainerId: 123456789, + } as SystemSaveData, + valid: false, + }) + ) + ); + + const savedata = await systemSavedataApi.verify(params); + + expect(savedata?.trainerId).toBe(123456789); + expect(console.warn).toHaveBeenCalledWith("Invalid system savedata!"); + }); + }); + + describe("Update", () => { + const params: UpdateSystemSavedataRequest = { + clientSessionId: "test-session-id", + secretId: 9876543321, + trainerId: 123456789, + }; + + it("should return an empty string on SUCCESS", async () => { + server.use(http.post(`${apiBase}/savedata/system/update`, () => HttpResponse.text(null))); + + const error = await systemSavedataApi.update(params, "UPDATED SYSTEM SAVEDATA"); + + expect(error).toBe(""); + }); + + it("should return an error string on FAILURE", async () => { + server.use(http.post(`${apiBase}/savedata/system/update`, () => HttpResponse.text("Failed to update!"))); + + const error = await systemSavedataApi.update(params, "UPDATED SYSTEM SAVEDATA"); + + expect(error).toBe("Failed to update!"); + }); + + it("should return 'Unknown Error' and report a warning on ERROR", async () => { + server.use(http.post(`${apiBase}/savedata/system/update`, () => HttpResponse.error())); + + const error = await systemSavedataApi.update(params, "UPDATED SYSTEM SAVEDATA"); + + expect(error).toBe("Unknown Error"); + expect(console.warn).toHaveBeenCalledWith("Could not update system savedata!", expect.any(Error)); + }); + }); +}); diff --git a/src/test/reload.test.ts b/src/test/reload.test.ts index 7c4523dd9ef..3b29cadf8e7 100644 --- a/src/test/reload.test.ts +++ b/src/test/reload.test.ts @@ -1,9 +1,14 @@ -import { Species } from "#app/enums/species"; import { GameModes } from "#app/game-mode"; +import { pokerogueApi } from "#app/plugins/api/pokerogue-api"; +import OptionSelectUiHandler from "#app/ui/settings/option-select-ui-handler"; +import { Mode } from "#app/ui/ui"; +import { Biome } from "#enums/biome"; +import { Button } from "#enums/buttons"; +import { Moves } from "#enums/moves"; +import { Species } from "#enums/species"; import GameManager from "#test/utils/gameManager"; -import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; -import { Moves } from "#app/enums/moves"; -import { Biome } from "#app/enums/biome"; +import { MockClock } from "#test/utils/mocks/mockClock"; +import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; describe("Reload", () => { let phaserGame: Phaser.Game; @@ -21,6 +26,8 @@ describe("Reload", () => { beforeEach(() => { game = new GameManager(phaserGame); + vi.spyOn(pokerogueApi, "getGameTitleStats").mockResolvedValue({ battleCount: -1, playerCount: -1 }); + vi.spyOn(pokerogueApi.daily, "getSeed").mockResolvedValue("test-seed"); }); it("should not have RNG inconsistencies in a Classic run", async () => { @@ -40,16 +47,21 @@ describe("Reload", () => { .startingWave(10) .battleType("single") .startingLevel(100) // Avoid levelling up - .enemyLevel(1000) // Avoid opponent dying before game.doKillOpponents() .disableTrainerWaves() - .moveset([Moves.KOWTOW_CLEAVE]) + .moveset([ Moves.SPLASH ]) .enemyMoveset(Moves.SPLASH); await game.dailyMode.startBattle(); // Transition from Wave 10 to Wave 11 in order to trigger biome switch - game.move.select(Moves.KOWTOW_CLEAVE); - await game.phaseInterceptor.to("DamagePhase"); + game.move.select(Moves.SPLASH); await game.doKillOpponents(); + game.onNextPrompt("SelectBiomePhase", Mode.OPTION_SELECT, () => { + (game.scene.time as MockClock).overrideDelay = null; + const optionSelectUiHandler = game.scene.ui.getHandler() as OptionSelectUiHandler; + game.scene.time.delayedCall(1010, () => optionSelectUiHandler.processInput(Button.ACTION)); + game.endPhase(); + (game.scene.time as MockClock).overrideDelay = 1; + }); await game.toNextWave(); expect(game.phaseInterceptor.log).toContain("NewBiomeEncounterPhase"); @@ -68,15 +80,13 @@ describe("Reload", () => { .startingBiome(Biome.ICE_CAVE) // Will lead to Snowy Forest with randomly generated weather .battleType("single") .startingLevel(100) // Avoid levelling up - .enemyLevel(1000) // Avoid opponent dying before game.doKillOpponents() .disableTrainerWaves() - .moveset([Moves.KOWTOW_CLEAVE]) + .moveset([ Moves.SPLASH ]) .enemyMoveset(Moves.SPLASH); await game.classicMode.startBattle(); // Apparently daily mode would override the biome // Transition from Wave 10 to Wave 11 in order to trigger biome switch - game.move.select(Moves.KOWTOW_CLEAVE); - await game.phaseInterceptor.to("DamagePhase"); + game.move.select(Moves.SPLASH); await game.doKillOpponents(); await game.toNextWave(); expect(game.phaseInterceptor.log).toContain("NewBiomeEncounterPhase"); @@ -103,8 +113,7 @@ describe("Reload", () => { }, 20000); it("should not have RNG inconsistencies at a Daily run double battle", async () => { - game.override - .battleType("double"); + game.override.battleType("double"); await game.dailyMode.startBattle(); const preReloadRngState = Phaser.Math.RND.state(); @@ -117,9 +126,7 @@ describe("Reload", () => { }, 20000); it("should not have RNG inconsistencies at a Daily run Gym Leader fight", async () => { - game.override - .battleType("single") - .startingWave(40); + game.override.battleType("single").startingWave(40); await game.dailyMode.startBattle(); const preReloadRngState = Phaser.Math.RND.state(); @@ -132,9 +139,7 @@ describe("Reload", () => { }, 20000); it("should not have RNG inconsistencies at a Daily run regular trainer fight", async () => { - game.override - .battleType("single") - .startingWave(45); + game.override.battleType("single").startingWave(45); await game.dailyMode.startBattle(); const preReloadRngState = Phaser.Math.RND.state(); @@ -147,10 +152,8 @@ describe("Reload", () => { }, 20000); it("should not have RNG inconsistencies at a Daily run wave 50 Boss fight", async () => { - game.override - .battleType("single") - .startingWave(50); - await game.runToFinalBossEncounter([Species.BULBASAUR], GameModes.DAILY); + game.override.battleType("single").startingWave(50); + await game.runToFinalBossEncounter([ Species.BULBASAUR ], GameModes.DAILY); const preReloadRngState = Phaser.Math.RND.state(); diff --git a/src/test/settingMenu/helpers/menuManip.ts b/src/test/settingMenu/helpers/menuManip.ts index 90b3f1e96e6..0b1f48525f1 100644 --- a/src/test/settingMenu/helpers/menuManip.ts +++ b/src/test/settingMenu/helpers/menuManip.ts @@ -72,7 +72,7 @@ export class MenuManip { const icon = getIconWithKeycode(this.config, this.keycode); const key = getKeyWithKeycode(this.config, this.keycode)!; // TODO: is this bang correct? const _keys = key.toLowerCase().split("_"); - const iconIdentifier = _keys[_keys.length-1]; + const iconIdentifier = _keys[_keys.length - 1]; expect(icon.toLowerCase().includes(iconIdentifier)).toEqual(true); return this; } diff --git a/src/test/settingMenu/rebinding_setting.test.ts b/src/test/settingMenu/rebinding_setting.test.ts index ec2343cfb41..37cf8032897 100644 --- a/src/test/settingMenu/rebinding_setting.test.ts +++ b/src/test/settingMenu/rebinding_setting.test.ts @@ -22,7 +22,7 @@ describe("Test Rebinding", () => { beforeEach(() => { config = deepCopy(cfg_keyboard_qwerty); - config.custom = {...config.default}; + config.custom = { ...config.default }; configs["default"] = config; inGame = new InGameManip(configs, config, selectedDevice); inTheSettingMenu = new MenuManip(config); diff --git a/src/test/sprites/pokemonSprite.test.ts b/src/test/sprites/pokemonSprite.test.ts index faf0626b365..c29f88d3143 100644 --- a/src/test/sprites/pokemonSprite.test.ts +++ b/src/test/sprites/pokemonSprite.test.ts @@ -70,7 +70,7 @@ describe("check if every variant's sprite are correctly set", () => { errors.push(`[${id}] missing key ${id} in masterlist for ${trimmedFilePath}`); } if (mlist[id][index] === 1 && jsonFileExists) { - const raw = fs.readFileSync(urlJsonFile, {encoding: "utf8", flag: "r"}); + const raw = fs.readFileSync(urlJsonFile, { encoding: "utf8", flag: "r" }); const data = JSON.parse(raw); const keys = Object.keys(data); if (!keys.includes(`${index}`)) { @@ -87,7 +87,7 @@ describe("check if every variant's sprite are correctly set", () => { } else if (!mlist.hasOwnProperty(name)) { errors.push(`[${name}] - missing key ${name} in masterlist for ${trimmedFilePath}`); } else { - const raw = fs.readFileSync(filePath, {encoding: "utf8", flag: "r"}); + const raw = fs.readFileSync(filePath, { encoding: "utf8", flag: "r" }); const data = JSON.parse(raw); for (const key of Object.keys(data)) { if (mlist[name][key] !== 1) { @@ -109,14 +109,14 @@ describe("check if every variant's sprite are correctly set", () => { const errors: string[] = []; for (const key of Object.keys(keys)) { const row = keys[key]; - for (const [index, elm] of row.entries()) { + for (const [ index, elm ] of row.entries()) { let url: string; if (elm === 0) { continue; } else if (elm === 1) { url = `${key}.json`; const filePath = `${dirPath}${url}`; - const raw = fs.readFileSync(filePath, {encoding: "utf8", flag: "r"}); + const raw = fs.readFileSync(filePath, { encoding: "utf8", flag: "r" }); const data = JSON.parse(raw); if (!data.hasOwnProperty(index)) { errors.push(`index: ${index} - ${filePath}`); @@ -232,7 +232,7 @@ describe("check if every variant's sprite are correctly set", () => { it("look over every file in variant back male and check if present in masterlist", () => { const dirPath = `${rootDir}back${path.sep}`; const backMaleVariant = deepCopy(backVariant); - const errors = getMissingMasterlist(backMaleVariant, dirPath, ["female"]); + const errors = getMissingMasterlist(backMaleVariant, dirPath, [ "female" ]); if (errors.length) { console.log("errors for ", dirPath, errors); } @@ -259,7 +259,7 @@ describe("check if every variant's sprite are correctly set", () => { it("look over every file in variant exp male and check if present in masterlist", () => { const dirPath = `${rootDir}exp${path.sep}`; - const errors = getMissingMasterlist(expVariant, dirPath, ["back", "female"]); + const errors = getMissingMasterlist(expVariant, dirPath, [ "back", "female" ]); if (errors.length) { console.log("errors for ", dirPath, errors); } @@ -268,7 +268,7 @@ describe("check if every variant's sprite are correctly set", () => { it("look over every file in variant root and check if present in masterlist", () => { const dirPath = `${rootDir}`; - const errors = getMissingMasterlist(masterlist, dirPath, ["back", "female", "exp", "icons"]); + const errors = getMissingMasterlist(masterlist, dirPath, [ "back", "female", "exp", "icons" ]); if (errors.length) { console.log("errors for ", dirPath, errors); } diff --git a/src/test/system/game_data.test.ts b/src/test/system/game_data.test.ts new file mode 100644 index 00000000000..1e349470302 --- /dev/null +++ b/src/test/system/game_data.test.ts @@ -0,0 +1,76 @@ +import * as BattleScene from "#app/battle-scene"; +import { pokerogueApi } from "#app/plugins/api/pokerogue-api"; +import { SessionSaveData } from "#app/system/game-data"; +import { Abilities } from "#enums/abilities"; +import { Moves } from "#enums/moves"; +import GameManager from "#test/utils/gameManager"; +import Phaser from "phaser"; +import { afterEach, beforeAll, beforeEach, describe, expect, it, vi } from "vitest"; +import * as account from "../../account"; + +describe("System - Game Data", () => { + let phaserGame: Phaser.Game; + let game: GameManager; + + beforeAll(() => { + phaserGame = new Phaser.Game({ + type: Phaser.HEADLESS, + }); + }); + + beforeEach(() => { + game = new GameManager(phaserGame); + game.override + .moveset([ Moves.SPLASH ]) + .battleType("single") + .enemyAbility(Abilities.BALL_FETCH) + .enemyMoveset(Moves.SPLASH); + }); + + afterEach(() => { + game.phaseInterceptor.restoreOg(); + }); + + describe("tryClearSession", () => { + beforeEach(() => { + vi.spyOn(BattleScene, "bypassLogin", "get").mockReturnValue(false); + vi.spyOn(game.scene.gameData, "getSessionSaveData").mockReturnValue({} as SessionSaveData); + vi.spyOn(account, "updateUserInfo").mockImplementation(async () => [ true, 1 ]); + }); + + it("should return [true, true] if bypassLogin is true", async () => { + vi.spyOn(BattleScene, "bypassLogin", "get").mockReturnValue(true); + + const result = await game.scene.gameData.tryClearSession(game.scene, 0); + + expect(result).toEqual([ true, true ]); + }); + + it("should return [true, true] if successful", async () => { + vi.spyOn(pokerogueApi.savedata.session, "clear").mockResolvedValue({ success: true }); + + const result = await game.scene.gameData.tryClearSession(game.scene, 0); + + expect(result).toEqual([ true, true ]); + expect(account.updateUserInfo).toHaveBeenCalled(); + }); + + it("should return [true, false] if not successful", async () => { + vi.spyOn(pokerogueApi.savedata.session, "clear").mockResolvedValue({ success: false }); + + const result = await game.scene.gameData.tryClearSession(game.scene, 0); + + expect(result).toEqual([ true, false ]); + expect(account.updateUserInfo).toHaveBeenCalled(); + }); + + it("should return [false, false] session is out of date", async () => { + vi.spyOn(pokerogueApi.savedata.session, "clear").mockResolvedValue({ error: "session out of date" }); + + const result = await game.scene.gameData.tryClearSession(game.scene, 0); + + expect(result).toEqual([ false, false ]); + expect(account.updateUserInfo).toHaveBeenCalled(); + }); + }); +}); diff --git a/src/test/ui/battle_info.test.ts b/src/test/ui/battle_info.test.ts index 4d511b75e6f..3100372f091 100644 --- a/src/test/ui/battle_info.test.ts +++ b/src/test/ui/battle_info.test.ts @@ -30,20 +30,20 @@ describe("UI - Battle Info", () => { beforeEach(() => { game = new GameManager(phaserGame); game.override - .moveset([Moves.GUILLOTINE, Moves.SPLASH]) + .moveset([ Moves.GUILLOTINE, Moves.SPLASH ]) .battleType("single") .enemyAbility(Abilities.BALL_FETCH) .enemyMoveset(Moves.SPLASH) .enemySpecies(Species.CATERPIE); }); - it.each([ExpGainsSpeed.FAST, ExpGainsSpeed.FASTER, ExpGainsSpeed.SKIP])( + it.each([ ExpGainsSpeed.FAST, ExpGainsSpeed.FASTER, ExpGainsSpeed.SKIP ])( "should increase exp gains animation by 2^%i", async (expGainsSpeed) => { game.settings.expGainsSpeed(expGainsSpeed); vi.spyOn(Math, "pow"); - await game.classicMode.startBattle([Species.CHARIZARD]); + await game.classicMode.startBattle([ Species.CHARIZARD ]); game.move.select(Moves.SPLASH); await game.doKillOpponents(); diff --git a/src/test/ui/starter-select.test.ts b/src/test/ui/starter-select.test.ts index 6d26ebfd6b3..15af3619ed3 100644 --- a/src/test/ui/starter-select.test.ts +++ b/src/test/ui/starter-select.test.ts @@ -1,5 +1,5 @@ import { Gender } from "#app/data/gender"; -import { Nature } from "#app/data/nature"; +import { Nature } from "#enums/nature"; import { allSpecies } from "#app/data/pokemon-species"; import { GameModes } from "#app/game-mode"; import { EncounterPhase } from "#app/phases/encounter-phase"; @@ -14,6 +14,7 @@ import { Abilities } from "#enums/abilities"; import { Button } from "#enums/buttons"; import { Species } from "#enums/species"; import GameManager from "#test/utils/gameManager"; +import i18next from "i18next"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; @@ -66,11 +67,11 @@ describe("UI - Starter select", () => { resolve(); }); }); - expect(options.some(option => option.label === "Add to Party")).toBe(true); - expect(options.some(option => option.label === "Toggle IVs")).toBe(true); - expect(options.some(option => option.label === "Manage Moves")).toBe(true); - expect(options.some(option => option.label === "Use Candies")).toBe(true); - expect(options.some(option => option.label === "Cancel")).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:addToParty"))).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:toggleIVs"))).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:manageMoves"))).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:useCandies"))).toBe(true); + expect(options.some(option => option.label === i18next.t("menu:cancel"))).toBe(true); optionSelectUiHandler?.processInput(Button.ACTION); await new Promise((resolve) => { @@ -90,10 +91,10 @@ describe("UI - Starter select", () => { }); await game.phaseInterceptor.whenAboutToRun(EncounterPhase); - expect(game.scene.getParty()[0].species.speciesId).toBe(Species.BULBASAUR); - expect(game.scene.getParty()[0].shiny).toBe(true); - expect(game.scene.getParty()[0].variant).toBe(2); - expect(game.scene.getParty()[0].gender).toBe(Gender.MALE); + expect(game.scene.getPlayerParty()[0].species.speciesId).toBe(Species.BULBASAUR); + expect(game.scene.getPlayerParty()[0].shiny).toBe(true); + expect(game.scene.getPlayerParty()[0].variant).toBe(2); + expect(game.scene.getPlayerParty()[0].gender).toBe(Gender.MALE); }, 20000); it("Bulbasaur - shiny - variant 2 female hardy overgrow", async() => { @@ -127,11 +128,11 @@ describe("UI - Starter select", () => { resolve(); }); }); - expect(options.some(option => option.label === "Add to Party")).toBe(true); - expect(options.some(option => option.label === "Toggle IVs")).toBe(true); - expect(options.some(option => option.label === "Manage Moves")).toBe(true); - expect(options.some(option => option.label === "Use Candies")).toBe(true); - expect(options.some(option => option.label === "Cancel")).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:addToParty"))).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:toggleIVs"))).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:manageMoves"))).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:useCandies"))).toBe(true); + expect(options.some(option => option.label === i18next.t("menu:cancel"))).toBe(true); optionSelectUiHandler?.processInput(Button.ACTION); await new Promise((resolve) => { @@ -151,11 +152,11 @@ describe("UI - Starter select", () => { }); await game.phaseInterceptor.whenAboutToRun(EncounterPhase); - expect(game.scene.getParty()[0].species.speciesId).toBe(Species.BULBASAUR); - expect(game.scene.getParty()[0].shiny).toBe(true); - expect(game.scene.getParty()[0].variant).toBe(2); - expect(game.scene.getParty()[0].nature).toBe(Nature.HARDY); - expect(game.scene.getParty()[0].getAbility().id).toBe(Abilities.OVERGROW); + expect(game.scene.getPlayerParty()[0].species.speciesId).toBe(Species.BULBASAUR); + expect(game.scene.getPlayerParty()[0].shiny).toBe(true); + expect(game.scene.getPlayerParty()[0].variant).toBe(2); + expect(game.scene.getPlayerParty()[0].nature).toBe(Nature.HARDY); + expect(game.scene.getPlayerParty()[0].getAbility().id).toBe(Abilities.OVERGROW); }, 20000); it("Bulbasaur - shiny - variant 2 female lonely chlorophyl", async() => { @@ -191,11 +192,11 @@ describe("UI - Starter select", () => { resolve(); }); }); - expect(options.some(option => option.label === "Add to Party")).toBe(true); - expect(options.some(option => option.label === "Toggle IVs")).toBe(true); - expect(options.some(option => option.label === "Manage Moves")).toBe(true); - expect(options.some(option => option.label === "Use Candies")).toBe(true); - expect(options.some(option => option.label === "Cancel")).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:addToParty"))).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:toggleIVs"))).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:manageMoves"))).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:useCandies"))).toBe(true); + expect(options.some(option => option.label === i18next.t("menu:cancel"))).toBe(true); optionSelectUiHandler?.processInput(Button.ACTION); await new Promise((resolve) => { @@ -215,12 +216,12 @@ describe("UI - Starter select", () => { }); await game.phaseInterceptor.whenAboutToRun(EncounterPhase); - expect(game.scene.getParty()[0].species.speciesId).toBe(Species.BULBASAUR); - expect(game.scene.getParty()[0].shiny).toBe(true); - expect(game.scene.getParty()[0].variant).toBe(2); - expect(game.scene.getParty()[0].gender).toBe(Gender.FEMALE); - expect(game.scene.getParty()[0].nature).toBe(Nature.LONELY); - expect(game.scene.getParty()[0].getAbility().id).toBe(Abilities.CHLOROPHYLL); + expect(game.scene.getPlayerParty()[0].species.speciesId).toBe(Species.BULBASAUR); + expect(game.scene.getPlayerParty()[0].shiny).toBe(true); + expect(game.scene.getPlayerParty()[0].variant).toBe(2); + expect(game.scene.getPlayerParty()[0].gender).toBe(Gender.FEMALE); + expect(game.scene.getPlayerParty()[0].nature).toBe(Nature.LONELY); + expect(game.scene.getPlayerParty()[0].getAbility().id).toBe(Abilities.CHLOROPHYLL); }, 20000); it("Bulbasaur - shiny - variant 2 female", async() => { @@ -254,11 +255,11 @@ describe("UI - Starter select", () => { resolve(); }); }); - expect(options.some(option => option.label === "Add to Party")).toBe(true); - expect(options.some(option => option.label === "Toggle IVs")).toBe(true); - expect(options.some(option => option.label === "Manage Moves")).toBe(true); - expect(options.some(option => option.label === "Use Candies")).toBe(true); - expect(options.some(option => option.label === "Cancel")).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:addToParty"))).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:toggleIVs"))).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:manageMoves"))).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:useCandies"))).toBe(true); + expect(options.some(option => option.label === i18next.t("menu:cancel"))).toBe(true); optionSelectUiHandler?.processInput(Button.ACTION); await new Promise((resolve) => { @@ -278,10 +279,10 @@ describe("UI - Starter select", () => { }); await game.phaseInterceptor.whenAboutToRun(EncounterPhase); - expect(game.scene.getParty()[0].species.speciesId).toBe(Species.BULBASAUR); - expect(game.scene.getParty()[0].shiny).toBe(true); - expect(game.scene.getParty()[0].variant).toBe(2); - expect(game.scene.getParty()[0].gender).toBe(Gender.FEMALE); + expect(game.scene.getPlayerParty()[0].species.speciesId).toBe(Species.BULBASAUR); + expect(game.scene.getPlayerParty()[0].shiny).toBe(true); + expect(game.scene.getPlayerParty()[0].variant).toBe(2); + expect(game.scene.getPlayerParty()[0].gender).toBe(Gender.FEMALE); }, 20000); it("Bulbasaur - not shiny", async() => { @@ -315,11 +316,11 @@ describe("UI - Starter select", () => { resolve(); }); }); - expect(options.some(option => option.label === "Add to Party")).toBe(true); - expect(options.some(option => option.label === "Toggle IVs")).toBe(true); - expect(options.some(option => option.label === "Manage Moves")).toBe(true); - expect(options.some(option => option.label === "Use Candies")).toBe(true); - expect(options.some(option => option.label === "Cancel")).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:addToParty"))).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:toggleIVs"))).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:manageMoves"))).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:useCandies"))).toBe(true); + expect(options.some(option => option.label === i18next.t("menu:cancel"))).toBe(true); optionSelectUiHandler?.processInput(Button.ACTION); await new Promise((resolve) => { @@ -339,9 +340,9 @@ describe("UI - Starter select", () => { }); await game.phaseInterceptor.whenAboutToRun(EncounterPhase); - expect(game.scene.getParty()[0].species.speciesId).toBe(Species.BULBASAUR); - expect(game.scene.getParty()[0].shiny).toBe(false); - expect(game.scene.getParty()[0].variant).toBe(0); + expect(game.scene.getPlayerParty()[0].species.speciesId).toBe(Species.BULBASAUR); + expect(game.scene.getPlayerParty()[0].shiny).toBe(false); + expect(game.scene.getPlayerParty()[0].variant).toBe(0); }, 20000); it("Bulbasaur - shiny - variant 1", async() => { @@ -376,11 +377,11 @@ describe("UI - Starter select", () => { resolve(); }); }); - expect(options.some(option => option.label === "Add to Party")).toBe(true); - expect(options.some(option => option.label === "Toggle IVs")).toBe(true); - expect(options.some(option => option.label === "Manage Moves")).toBe(true); - expect(options.some(option => option.label === "Use Candies")).toBe(true); - expect(options.some(option => option.label === "Cancel")).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:addToParty"))).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:toggleIVs"))).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:manageMoves"))).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:useCandies"))).toBe(true); + expect(options.some(option => option.label === i18next.t("menu:cancel"))).toBe(true); optionSelectUiHandler?.processInput(Button.ACTION); await new Promise((resolve) => { @@ -400,9 +401,9 @@ describe("UI - Starter select", () => { }); await game.phaseInterceptor.whenAboutToRun(EncounterPhase); - expect(game.scene.getParty()[0].species.speciesId).toBe(Species.BULBASAUR); - expect(game.scene.getParty()[0].shiny).toBe(true); - expect(game.scene.getParty()[0].variant).toBe(1); + expect(game.scene.getPlayerParty()[0].species.speciesId).toBe(Species.BULBASAUR); + expect(game.scene.getPlayerParty()[0].shiny).toBe(true); + expect(game.scene.getPlayerParty()[0].variant).toBe(1); }, 20000); it("Bulbasaur - shiny - variant 0", async() => { @@ -436,11 +437,11 @@ describe("UI - Starter select", () => { resolve(); }); }); - expect(options.some(option => option.label === "Add to Party")).toBe(true); - expect(options.some(option => option.label === "Toggle IVs")).toBe(true); - expect(options.some(option => option.label === "Manage Moves")).toBe(true); - expect(options.some(option => option.label === "Use Candies")).toBe(true); - expect(options.some(option => option.label === "Cancel")).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:addToParty"))).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:toggleIVs"))).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:manageMoves"))).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:useCandies"))).toBe(true); + expect(options.some(option => option.label === i18next.t("menu:cancel"))).toBe(true); optionSelectUiHandler?.processInput(Button.ACTION); await new Promise((resolve) => { @@ -460,9 +461,9 @@ describe("UI - Starter select", () => { }); await game.phaseInterceptor.whenAboutToRun(EncounterPhase); - expect(game.scene.getParty()[0].species.speciesId).toBe(Species.BULBASAUR); - expect(game.scene.getParty()[0].shiny).toBe(true); - expect(game.scene.getParty()[0].variant).toBe(0); + expect(game.scene.getPlayerParty()[0].species.speciesId).toBe(Species.BULBASAUR); + expect(game.scene.getPlayerParty()[0].shiny).toBe(true); + expect(game.scene.getPlayerParty()[0].variant).toBe(0); }, 20000); it("Check if first pokemon in party is caterpie from gen 1 and 1rd row, 3rd column", async() => { @@ -496,11 +497,11 @@ describe("UI - Starter select", () => { resolve(); }); }); - expect(options.some(option => option.label === "Add to Party")).toBe(true); - expect(options.some(option => option.label === "Toggle IVs")).toBe(true); - expect(options.some(option => option.label === "Manage Moves")).toBe(true); - expect(options.some(option => option.label === "Use Candies")).toBe(true); - expect(options.some(option => option.label === "Cancel")).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:addToParty"))).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:toggleIVs"))).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:manageMoves"))).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:useCandies"))).toBe(true); + expect(options.some(option => option.label === i18next.t("menu:cancel"))).toBe(true); optionSelectUiHandler?.processInput(Button.ACTION); let starterSelectUiHandler: StarterSelectUiHandler; @@ -526,7 +527,7 @@ describe("UI - Starter select", () => { saveSlotSelectUiHandler.processInput(Button.ACTION); }); await game.phaseInterceptor.whenAboutToRun(EncounterPhase); - expect(game.scene.getParty()[0].species.speciesId).toBe(Species.CATERPIE); + expect(game.scene.getPlayerParty()[0].species.speciesId).toBe(Species.CATERPIE); }, 20000); it("Check if first pokemon in party is nidoran_m from gen 1 and 2nd row, 4th column (cursor (9+4)-1)", async() => { @@ -561,11 +562,11 @@ describe("UI - Starter select", () => { resolve(); }); }); - expect(options.some(option => option.label === "Add to Party")).toBe(true); - expect(options.some(option => option.label === "Toggle IVs")).toBe(true); - expect(options.some(option => option.label === "Manage Moves")).toBe(true); - expect(options.some(option => option.label === "Use Candies")).toBe(true); - expect(options.some(option => option.label === "Cancel")).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:addToParty"))).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:toggleIVs"))).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:manageMoves"))).toBe(true); + expect(options.some(option => option.label === i18next.t("starterSelectUiHandler:useCandies"))).toBe(true); + expect(options.some(option => option.label === i18next.t("menu:cancel"))).toBe(true); optionSelectUiHandler?.processInput(Button.ACTION); let starterSelectUiHandler: StarterSelectUiHandler | undefined; @@ -592,6 +593,6 @@ describe("UI - Starter select", () => { saveSlotSelectUiHandler.processInput(Button.ACTION); }); await game.phaseInterceptor.whenAboutToRun(EncounterPhase); - expect(game.scene.getParty()[0].species.speciesId).toBe(Species.NIDORAN_M); + expect(game.scene.getPlayerParty()[0].species.speciesId).toBe(Species.NIDORAN_M); }, 20000); }); diff --git a/src/test/ui/transfer-item.test.ts b/src/test/ui/transfer-item.test.ts index f7dea463574..0fbd4a52c61 100644 --- a/src/test/ui/transfer-item.test.ts +++ b/src/test/ui/transfer-item.test.ts @@ -37,11 +37,11 @@ describe("UI - Transfer Items", () => { { name: "BERRY", count: 2, type: BerryType.APICOT }, { name: "BERRY", count: 2, type: BerryType.LUM }, ]); - game.override.moveset([Moves.DRAGON_CLAW]); + game.override.moveset([ Moves.DRAGON_CLAW ]); game.override.enemySpecies(Species.MAGIKARP); - game.override.enemyMoveset([Moves.SPLASH]); + game.override.enemyMoveset([ Moves.SPLASH ]); - await game.startBattle([Species.RAYQUAZA, Species.RAYQUAZA, Species.RAYQUAZA]); + await game.startBattle([ Species.RAYQUAZA, Species.RAYQUAZA, Species.RAYQUAZA ]); game.move.select(Moves.DRAGON_CLAW); diff --git a/src/test/ui/type-hints.test.ts b/src/test/ui/type-hints.test.ts index 726094b258a..2977262dda7 100644 --- a/src/test/ui/type-hints.test.ts +++ b/src/test/ui/type-hints.test.ts @@ -7,7 +7,8 @@ import { Mode } from "#app/ui/ui"; import GameManager from "#test/utils/gameManager"; import Phaser from "phaser"; import { afterEach, beforeAll, beforeEach, describe, expect, it } from "vitest"; -import MockText from "../utils/mocks/mocksContainer/mockText"; +import MockText from "#test/utils/mocks/mocksContainer/mockText"; +import i18next from "i18next"; describe("UI - Type Hints", () => { let phaserGame: Phaser.Game; @@ -36,10 +37,10 @@ describe("UI - Type Hints", () => { .startingWave(1) .enemySpecies(Species.FLORGES) .enemyMoveset(Moves.SPLASH) - .moveset([Moves.DRAGON_CLAW]); + .moveset([ Moves.DRAGON_CLAW ]); game.settings.typeHints(true); //activate type hints - await game.startBattle([Species.RAYQUAZA]); + await game.startBattle([ Species.RAYQUAZA ]); game.onNextPrompt("CommandPhase", Mode.COMMAND, () => { const { ui } = game.scene; @@ -53,7 +54,7 @@ describe("UI - Type Hints", () => { const movesContainer = ui.getByName(FightUiHandler.MOVES_CONTAINER_NAME); const dragonClawText = movesContainer .getAll() - .find((text) => text.text === "Dragon Claw")! as unknown as MockText; + .find((text) => text.text === i18next.t("move:dragonClaw.name"))! as unknown as MockText; expect.soft(dragonClawText.color).toBe("#929292"); ui.getHandler().processInput(Button.ACTION); @@ -62,9 +63,9 @@ describe("UI - Type Hints", () => { }); it("check status move color", async () => { - game.override.enemySpecies(Species.FLORGES).moveset([Moves.GROWL]); + game.override.enemySpecies(Species.FLORGES).moveset([ Moves.GROWL ]); - await game.startBattle([Species.RAYQUAZA]); + await game.startBattle([ Species.RAYQUAZA ]); game.onNextPrompt("CommandPhase", Mode.COMMAND, () => { const { ui } = game.scene; @@ -78,7 +79,7 @@ describe("UI - Type Hints", () => { const movesContainer = ui.getByName(FightUiHandler.MOVES_CONTAINER_NAME); const growlText = movesContainer .getAll() - .find((text) => text.text === "Growl")! as unknown as MockText; + .find((text) => text.text === i18next.t("move:growl.name"))! as unknown as MockText; expect.soft(growlText.color).toBe(undefined); ui.getHandler().processInput(Button.ACTION); diff --git a/src/test/utils/gameManager.ts b/src/test/utils/gameManager.ts index 36423c5e18f..fe8d06c2c3b 100644 --- a/src/test/utils/gameManager.ts +++ b/src/test/utils/gameManager.ts @@ -1,20 +1,20 @@ import { updateUserInfo } from "#app/account"; import { BattlerIndex } from "#app/battle"; import BattleScene from "#app/battle-scene"; -import { BattleStyle } from "#app/enums/battle-style"; -import { Moves } from "#app/enums/moves"; import { getMoveTargets } from "#app/data/move"; import { EnemyPokemon, PlayerPokemon } from "#app/field/pokemon"; import Trainer from "#app/field/trainer"; import { GameModes, getGameMode } from "#app/game-mode"; import { ModifierTypeOption, modifierTypes } from "#app/modifier/modifier-type"; import overrides from "#app/overrides"; +import { CheckSwitchPhase } from "#app/phases/check-switch-phase"; import { CommandPhase } from "#app/phases/command-phase"; import { EncounterPhase } from "#app/phases/encounter-phase"; import { EnemyCommandPhase } from "#app/phases/enemy-command-phase"; import { FaintPhase } from "#app/phases/faint-phase"; import { LoginPhase } from "#app/phases/login-phase"; import { MovePhase } from "#app/phases/move-phase"; +import { MysteryEncounterPhase } from "#app/phases/mystery-encounter-phases"; import { NewBattlePhase } from "#app/phases/new-battle-phase"; import { SelectStarterPhase } from "#app/phases/select-starter-phase"; import { SelectTargetPhase } from "#app/phases/select-target-phase"; @@ -24,36 +24,36 @@ import { TurnInitPhase } from "#app/phases/turn-init-phase"; import { TurnStartPhase } from "#app/phases/turn-start-phase"; import ErrorInterceptor from "#app/test/utils/errorInterceptor"; import InputsHandler from "#app/test/utils/inputsHandler"; +import BattleMessageUiHandler from "#app/ui/battle-message-ui-handler"; import CommandUiHandler from "#app/ui/command-ui-handler"; import ModifierSelectUiHandler from "#app/ui/modifier-select-ui-handler"; import PartyUiHandler from "#app/ui/party-ui-handler"; import TargetSelectUiHandler from "#app/ui/target-select-ui-handler"; import { Mode } from "#app/ui/ui"; +import { isNullOrUndefined } from "#app/utils"; +import { BattleStyle } from "#enums/battle-style"; import { Button } from "#enums/buttons"; +import { ExpGainsSpeed } from "#enums/exp-gains-speed"; import { ExpNotification } from "#enums/exp-notification"; +import { Moves } from "#enums/moves"; +import { MysteryEncounterType } from "#enums/mystery-encounter-type"; import { PlayerGender } from "#enums/player-gender"; import { Species } from "#enums/species"; import { generateStarter, waitUntil } from "#test/utils/gameManagerUtils"; import GameWrapper from "#test/utils/gameWrapper"; +import { ChallengeModeHelper } from "#test/utils/helpers/challengeModeHelper"; +import { ClassicModeHelper } from "#test/utils/helpers/classicModeHelper"; +import { DailyModeHelper } from "#test/utils/helpers/dailyModeHelper"; +import { ModifierHelper } from "#test/utils/helpers/modifiersHelper"; +import { MoveHelper } from "#test/utils/helpers/moveHelper"; +import { OverridesHelper } from "#test/utils/helpers/overridesHelper"; +import { ReloadHelper } from "#test/utils/helpers/reloadHelper"; +import { SettingsHelper } from "#test/utils/helpers/settingsHelper"; import PhaseInterceptor from "#test/utils/phaseInterceptor"; import TextInterceptor from "#test/utils/TextInterceptor"; import { AES, enc } from "crypto-js"; import fs from "fs"; -import { vi } from "vitest"; -import { ClassicModeHelper } from "./helpers/classicModeHelper"; -import { DailyModeHelper } from "./helpers/dailyModeHelper"; -import { ChallengeModeHelper } from "./helpers/challengeModeHelper"; -import { MoveHelper } from "./helpers/moveHelper"; -import { OverridesHelper } from "./helpers/overridesHelper"; -import { SettingsHelper } from "./helpers/settingsHelper"; -import { ReloadHelper } from "./helpers/reloadHelper"; -import { CheckSwitchPhase } from "#app/phases/check-switch-phase"; -import BattleMessageUiHandler from "#app/ui/battle-message-ui-handler"; -import { MysteryEncounterPhase } from "#app/phases/mystery-encounter-phases"; -import { expect } from "vitest"; -import { MysteryEncounterType } from "#enums/mystery-encounter-type"; -import { isNullOrUndefined } from "#app/utils"; -import { ExpGainsSpeed } from "#app/enums/exp-gains-speed"; +import { expect, vi } from "vitest"; /** * Class to manage the game state and transitions between phases. @@ -71,6 +71,7 @@ export default class GameManager { public readonly challengeMode: ChallengeModeHelper; public readonly settings: SettingsHelper; public readonly reload: ReloadHelper; + public readonly modifiers: ModifierHelper; /** * Creates an instance of GameManager. @@ -93,6 +94,7 @@ export default class GameManager { this.challengeMode = new ChallengeModeHelper(this); this.settings = new SettingsHelper(this); this.reload = new ReloadHelper(this); + this.modifiers = new ModifierHelper(this); // Disables Mystery Encounters on all tests (can be overridden at test level) this.override.mysteryEncounterChance(0); @@ -154,6 +156,7 @@ export default class GameManager { this.scene.enableTutorials = false; this.scene.gameData.gender = PlayerGender.MALE; // set initial player gender this.scene.battleStyle = this.settings.battleStyle; + this.scene.fieldVolume = 0; } /** @@ -195,7 +198,7 @@ export default class GameManager { async runToMysteryEncounter(encounterType?: MysteryEncounterType, species?: Species[]) { if (!isNullOrUndefined(encounterType)) { this.override.disableTrainerWaves(); - this.override.mysteryEncounter(encounterType!); + this.override.mysteryEncounter(encounterType); } await this.runToTitle(); @@ -300,8 +303,8 @@ export default class GameManager { vi.spyOn(enemy, "getNextMove").mockReturnValueOnce({ move: moveId, - targets: (target && !legalTargets.multiple && legalTargets.targets.includes(target)) - ? [target] + targets: (target !== undefined && !legalTargets.multiple && legalTargets.targets.includes(target)) + ? [ target ] : enemy.getNextTargets(moveId) }); @@ -317,7 +320,7 @@ export default class GameManager { const originalMatchupScore = Trainer.prototype.getPartyMemberMatchupScores; Trainer.prototype.getPartyMemberMatchupScores = () => { Trainer.prototype.getPartyMemberMatchupScores = originalMatchupScore; - return [[1, 100], [1, 100]]; + return [[ 1, 100 ], [ 1, 100 ]]; }; } @@ -424,7 +427,7 @@ export default class GameManager { * @param pokemonIndex the index of the pokemon in your party to revive */ doRevivePokemon(pokemonIndex: number) { - const party = this.scene.getParty(); + const party = this.scene.getPlayerParty(); const candidate = new ModifierTypeOption(modifierTypes.MAX_REVIVE(), 0); const modifier = candidate.type!.newModifier(party[pokemonIndex]); this.scene.addModifier(modifier, false); diff --git a/src/test/utils/gameManagerUtils.ts b/src/test/utils/gameManagerUtils.ts index 700d93082d8..0c70bcf7f18 100644 --- a/src/test/utils/gameManagerUtils.ts +++ b/src/test/utils/gameManagerUtils.ts @@ -86,7 +86,7 @@ export function waitUntil(truth) { export function getMovePosition(scene: BattleScene, pokemonIndex: 0 | 1, move: Moves) { const playerPokemon = scene.getPlayerField()[pokemonIndex]; const moveSet = playerPokemon.getMoveset(); - const index = moveSet.findIndex((m) => m?.moveId === move); + const index = moveSet.findIndex((m) => m?.moveId === move && m?.ppUsed < m?.getMovePp()); console.log(`Move position for ${Moves[move]} (=${move}):`, index); return index; } @@ -105,7 +105,7 @@ export function initSceneWithoutEncounterPhase(scene: BattleScene, species?: Spe const starterIvs = scene.gameData.dexData[starter.species.speciesId].ivs.slice(0); const starterPokemon = scene.addPlayerPokemon(starter.species, scene.gameMode.getStartingLevel(), starter.abilityIndex, starterFormIndex, starterGender, starterProps.shiny, starterProps.variant, starterIvs, starter.nature); starter.moveset && starterPokemon.tryPopulateMoveset(starter.moveset); - scene.getParty().push(starterPokemon); + scene.getPlayerParty().push(starterPokemon); }); scene.currentBattle = new Battle(getGameMode(GameModes.CLASSIC), 5, BattleType.WILD, undefined, false); diff --git a/src/test/utils/gameWrapper.ts b/src/test/utils/gameWrapper.ts index 0ef5c4d4611..ca5a67f901a 100644 --- a/src/test/utils/gameWrapper.ts +++ b/src/test/utils/gameWrapper.ts @@ -23,6 +23,8 @@ import KeyboardPlugin = Phaser.Input.Keyboard.KeyboardPlugin; import GamepadPlugin = Phaser.Input.Gamepad.GamepadPlugin; import EventEmitter = Phaser.Events.EventEmitter; import UpdateList = Phaser.GameObjects.UpdateList; +import { version } from "../../../package.json"; +import { MockTimedEventManager } from "./mocks/mockTimedEventManager"; Object.defineProperty(window, "localStorage", { value: mockLocalStorage(), @@ -77,7 +79,7 @@ export default class GameWrapper { constructor(phaserGame: Phaser.Game, bypassLogin: boolean) { Phaser.Math.RND.sow([ 'test' ]); - vi.spyOn(Utils, "apiFetch", "get").mockReturnValue(fetch); + // vi.spyOn(Utils, "apiFetch", "get").mockReturnValue(fetch); if (bypassLogin) { vi.spyOn(battleScene, "bypassLogin", "get").mockReturnValue(true); } @@ -101,6 +103,7 @@ export default class GameWrapper { injectMandatory() { this.game.config = { seed: ["test"], + gameVersion: version }; this.scene.game = this.game; this.game.renderer = { @@ -230,6 +233,7 @@ export default class GameWrapper { this.scene.make = new MockGameObjectCreator(mockTextureManager); this.scene.time = new MockClock(this.scene); this.scene.remove = vi.fn(); // TODO: this should be stubbed differently + this.scene.eventManager = new MockTimedEventManager(); // Disable Timed Events } } diff --git a/src/test/utils/helpers/challengeModeHelper.ts b/src/test/utils/helpers/challengeModeHelper.ts index 184f11f505c..5210d942d5a 100644 --- a/src/test/utils/helpers/challengeModeHelper.ts +++ b/src/test/utils/helpers/challengeModeHelper.ts @@ -38,6 +38,10 @@ export class ChallengeModeHelper extends GameManagerHelper { async runToSummon(species?: Species[]) { await this.game.runToTitle(); + if (this.game.override.disableShinies) { + this.game.override.shiny(false).enemyShiny(false); + } + this.game.onNextPrompt("TitlePhase", Mode.TITLE, () => { this.game.scene.gameMode.challenges = this.challenges; const starters = generateStarter(this.game.scene, species); @@ -47,7 +51,7 @@ export class ChallengeModeHelper extends GameManagerHelper { }); await this.game.phaseInterceptor.run(EncounterPhase); - if (overrides.OPP_HELD_ITEMS_OVERRIDE.length === 0) { + if (overrides.OPP_HELD_ITEMS_OVERRIDE.length === 0 && this.game.override.removeEnemyStartingItems) { this.game.removeEnemyHeldItems(); } } diff --git a/src/test/utils/helpers/classicModeHelper.ts b/src/test/utils/helpers/classicModeHelper.ts index 55e995fc9dc..41a21a52b72 100644 --- a/src/test/utils/helpers/classicModeHelper.ts +++ b/src/test/utils/helpers/classicModeHelper.ts @@ -20,9 +20,13 @@ export class ClassicModeHelper extends GameManagerHelper { * @param species - Optional array of species to summon. * @returns A promise that resolves when the summon phase is reached. */ - async runToSummon(species?: Species[]) { + async runToSummon(species?: Species[]): Promise { await this.game.runToTitle(); + if (this.game.override.disableShinies) { + this.game.override.shiny(false).enemyShiny(false); + } + this.game.onNextPrompt("TitlePhase", Mode.TITLE, () => { this.game.scene.gameMode = getGameMode(GameModes.CLASSIC); const starters = generateStarter(this.game.scene, species); @@ -31,8 +35,8 @@ export class ClassicModeHelper extends GameManagerHelper { selectStarterPhase.initBattle(starters); }); - await this.game.phaseInterceptor.run(EncounterPhase); - if (overrides.OPP_HELD_ITEMS_OVERRIDE.length === 0) { + await this.game.phaseInterceptor.to(EncounterPhase); + if (overrides.OPP_HELD_ITEMS_OVERRIDE.length === 0 && this.game.override.removeEnemyStartingItems) { this.game.removeEnemyHeldItems(); } } @@ -42,7 +46,7 @@ export class ClassicModeHelper extends GameManagerHelper { * @param species - Optional array of species to start the battle with. * @returns A promise that resolves when the battle is started. */ - async startBattle(species?: Species[]) { + async startBattle(species?: Species[]): Promise { await this.runToSummon(species); if (this.game.scene.battleStyle === BattleStyle.SWITCH) { diff --git a/src/test/utils/helpers/dailyModeHelper.ts b/src/test/utils/helpers/dailyModeHelper.ts index e40fada8ac7..813544f85df 100644 --- a/src/test/utils/helpers/dailyModeHelper.ts +++ b/src/test/utils/helpers/dailyModeHelper.ts @@ -21,6 +21,10 @@ export class DailyModeHelper extends GameManagerHelper { async runToSummon() { await this.game.runToTitle(); + if (this.game.override.disableShinies) { + this.game.override.shiny(false).enemyShiny(false); + } + this.game.onNextPrompt("TitlePhase", Mode.TITLE, () => { const titlePhase = new TitlePhase(this.game.scene); titlePhase.initDailyRun(); @@ -33,7 +37,7 @@ export class DailyModeHelper extends GameManagerHelper { await this.game.phaseInterceptor.to(EncounterPhase); - if (overrides.OPP_HELD_ITEMS_OVERRIDE.length === 0) { + if (overrides.OPP_HELD_ITEMS_OVERRIDE.length === 0 && this.game.override.removeEnemyStartingItems) { this.game.removeEnemyHeldItems(); } } diff --git a/src/test/utils/helpers/modifiersHelper.ts b/src/test/utils/helpers/modifiersHelper.ts new file mode 100644 index 00000000000..c38bf5770a8 --- /dev/null +++ b/src/test/utils/helpers/modifiersHelper.ts @@ -0,0 +1,58 @@ +import { expect } from "vitest"; +import { GameManagerHelper } from "./gameManagerHelper"; +import { itemPoolChecks, ModifierTypeKeys } from "#app/modifier/modifier-type"; + +export class ModifierHelper extends GameManagerHelper { + /** + * Adds a Modifier to the list of modifiers to check for. + * + * Note that all modifiers are updated during the start of `SelectModifierPhase`. + * @param modifier The Modifier to add. + * @returns `this` + */ + addCheck(modifier: ModifierTypeKeys): this { + itemPoolChecks.set(modifier, undefined); + return this; + } + + /** + * `get`s a value from the `itemPoolChecks` map. + * + * If the item is in the Modifier Pool, and the player can get it, will return `true`. + * + * If the item is *not* in the Modifier Pool, will return `false`. + * + * If a `SelectModifierPhase` has not occurred, and we do not know if the item is in the Modifier Pool or not, will return `undefined`. + * @param modifier + * @returns + */ + getCheck(modifier: ModifierTypeKeys): boolean | undefined { + return itemPoolChecks.get(modifier); + } + + /** + * `expect`s a Modifier `toBeTruthy` (in the Modifier Pool) or `Falsy` (unobtainable on this floor). Use during a test. + * + * Note that if a `SelectModifierPhase` has not been run yet, these values will be `undefined`, and the check will fail. + * @param modifier The modifier to check. + * @param expectToBePreset Whether the Modifier should be in the Modifier Pool. Set to `false` to expect it to be absent instead. + * @returns `this` + */ + testCheck(modifier: ModifierTypeKeys, expectToBePreset: boolean): this { + if (expectToBePreset) { + expect(itemPoolChecks.get(modifier)).toBeTruthy(); + } + expect(itemPoolChecks.get(modifier)).toBeFalsy(); + return this; + } + + /** Removes all modifier checks. @returns `this` */ + clearChecks() { + itemPoolChecks.clear(); + return this; + } + + private log(...params: any[]) { + console.log("Modifiers:", ...params); + } +} diff --git a/src/test/utils/helpers/moveHelper.ts b/src/test/utils/helpers/moveHelper.ts index a53fa521785..73fe63395fd 100644 --- a/src/test/utils/helpers/moveHelper.ts +++ b/src/test/utils/helpers/moveHelper.ts @@ -1,34 +1,35 @@ import { BattlerIndex } from "#app/battle"; -import { Moves } from "#app/enums/moves"; +import Overrides from "#app/overrides"; import { CommandPhase } from "#app/phases/command-phase"; import { MoveEffectPhase } from "#app/phases/move-effect-phase"; import { Command } from "#app/ui/command-ui-handler"; import { Mode } from "#app/ui/ui"; +import { Moves } from "#enums/moves"; +import { getMovePosition } from "#test/utils/gameManagerUtils"; +import { GameManagerHelper } from "#test/utils/helpers/gameManagerHelper"; import { vi } from "vitest"; -import { getMovePosition } from "../gameManagerUtils"; -import { GameManagerHelper } from "./gameManagerHelper"; /** * Helper to handle a Pokemon's move */ export class MoveHelper extends GameManagerHelper { /** - * Intercepts `MoveEffectPhase` and mocks the hitCheck's - * return value to `true` {@linkcode MoveEffectPhase.hitCheck}. + * Intercepts {@linkcode MoveEffectPhase} and mocks the + * {@linkcode MoveEffectPhase.hitCheck | hitCheck}'s return value to `true`. * Used to force a move to hit. */ - async forceHit(): Promise { + public async forceHit(): Promise { await this.game.phaseInterceptor.to(MoveEffectPhase, false); vi.spyOn(this.game.scene.getCurrentPhase() as MoveEffectPhase, "hitCheck").mockReturnValue(true); } /** - * Intercepts `MoveEffectPhase` and mocks the hitCheck's - * return value to `false` {@linkcode MoveEffectPhase.hitCheck}. + * Intercepts {@linkcode MoveEffectPhase} and mocks the + * {@linkcode MoveEffectPhase.hitCheck | hitCheck}'s return value to `false`. * Used to force a move to miss. - * @param firstTargetOnly Whether the move should force miss on the first target only, in the case of multi-target moves. + * @param firstTargetOnly - Whether the move should force miss on the first target only, in the case of multi-target moves. */ - async forceMiss(firstTargetOnly: boolean = false): Promise { + public async forceMiss(firstTargetOnly: boolean = false): Promise { await this.game.phaseInterceptor.to(MoveEffectPhase, false); const hitCheck = vi.spyOn(this.game.scene.getCurrentPhase() as MoveEffectPhase, "hitCheck"); @@ -40,12 +41,12 @@ export class MoveHelper extends GameManagerHelper { } /** - * Select the move to be used by the given Pokemon(-index). Triggers during the next {@linkcode CommandPhase} - * @param move the move to use - * @param pkmIndex the pokemon index. Relevant for double-battles only (defaults to 0) - * @param targetIndex The {@linkcode BattlerIndex} of the Pokemon to target for single-target moves, or `null` if a manual call to `selectTarget()` is required - */ - select(move: Moves, pkmIndex: 0 | 1 = 0, targetIndex?: BattlerIndex | null) { + * Select the move to be used by the given Pokemon(-index). Triggers during the next {@linkcode CommandPhase} + * @param move - the move to use + * @param pkmIndex - the pokemon index. Relevant for double-battles only (defaults to 0) + * @param targetIndex - The {@linkcode BattlerIndex} of the Pokemon to target for single-target moves, or `null` if a manual call to `selectTarget()` is required + */ + public select(move: Moves, pkmIndex: 0 | 1 = 0, targetIndex?: BattlerIndex | null) { const movePosition = getMovePosition(this.game.scene, pkmIndex, move); this.game.onNextPrompt("CommandPhase", Mode.COMMAND, () => { @@ -59,4 +60,15 @@ export class MoveHelper extends GameManagerHelper { this.game.selectTarget(movePosition, targetIndex); } } + + /** + * Forces the Paralysis or Freeze status to activate on the next move by temporarily mocking {@linkcode Overrides.STATUS_ACTIVATION_OVERRIDE}, + * advancing to the next `MovePhase`, and then resetting the override to `null` + * @param activated - `true` to force the status to activate, `false` to force the status to not activate (will cause Freeze to heal) + */ + public async forceStatusActivation(activated: boolean): Promise { + vi.spyOn(Overrides, "STATUS_ACTIVATION_OVERRIDE", "get").mockReturnValue(activated); + await this.game.phaseInterceptor.to("MovePhase"); + vi.spyOn(Overrides, "STATUS_ACTIVATION_OVERRIDE", "get").mockReturnValue(null); + } } diff --git a/src/test/utils/helpers/overridesHelper.ts b/src/test/utils/helpers/overridesHelper.ts index 686de58e874..1c05f92a334 100644 --- a/src/test/utils/helpers/overridesHelper.ts +++ b/src/test/utils/helpers/overridesHelper.ts @@ -1,28 +1,36 @@ -import { StatusEffect } from "#app/data/status-effect"; -import { Weather, WeatherType } from "#app/data/weather"; +import { Variant } from "#app/data/variant"; +import { Weather } from "#app/data/weather"; import { Abilities } from "#app/enums/abilities"; -import { Biome } from "#app/enums/biome"; -import { Moves } from "#app/enums/moves"; -import { Species } from "#app/enums/species"; import * as GameMode from "#app/game-mode"; import { GameModes, getGameMode } from "#app/game-mode"; import { ModifierOverride } from "#app/modifier/modifier-type"; -import Overrides from "#app/overrides"; +import Overrides, { BattleStyle } from "#app/overrides"; +import { Unlockables } from "#app/system/unlockables"; +import { Biome } from "#enums/biome"; +import { Moves } from "#enums/moves"; +import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; +import { MysteryEncounterType } from "#enums/mystery-encounter-type"; +import { Species } from "#enums/species"; +import { StatusEffect } from "#enums/status-effect"; +import type { WeatherType } from "#enums/weather-type"; import { vi } from "vitest"; import { GameManagerHelper } from "./gameManagerHelper"; -import { MysteryEncounterType } from "#enums/mystery-encounter-type"; -import { MysteryEncounterTier } from "#enums/mystery-encounter-tier"; /** * Helper to handle overrides in tests */ export class OverridesHelper extends GameManagerHelper { + /** If `true`, removes the starting items from enemies at the start of each test; default `true` */ + public removeEnemyStartingItems: boolean = true; + /** If `true`, sets the shiny overrides to disable shinies at the start of each test; default `true` */ + public disableShinies: boolean = true; + /** * Override the starting biome * @warning Any event listeners that are attached to [NewArenaEvent](events\battle-scene.ts) may need to be handled down the line * @param biome the biome to set */ - startingBiome(biome: Biome): this { + public startingBiome(biome: Biome): this { this.game.scene.newArena(biome); this.log(`Starting biome set to ${Biome[biome]} (=${biome})!`); return this; @@ -31,9 +39,9 @@ export class OverridesHelper extends GameManagerHelper { /** * Override the starting wave (index) * @param wave the wave (index) to set. Classic: `1`-`200` - * @returns this + * @returns `this` */ - startingWave(wave: number): this { + public startingWave(wave: number): this { vi.spyOn(Overrides, "STARTING_WAVE_OVERRIDE", "get").mockReturnValue(wave); this.log(`Starting wave set to ${wave}!`); return this; @@ -42,9 +50,9 @@ export class OverridesHelper extends GameManagerHelper { /** * Override the player (pokemon) starting level * @param level the (pokemon) level to set - * @returns this + * @returns `this` */ - startingLevel(level: Species | number): this { + public startingLevel(level: Species | number): this { vi.spyOn(Overrides, "STARTING_LEVEL_OVERRIDE", "get").mockReturnValue(level); this.log(`Player Pokemon starting level set to ${level}!`); return this; @@ -55,7 +63,7 @@ export class OverridesHelper extends GameManagerHelper { * @param value the XP multiplier to set * @returns `this` */ - xpMultiplier(value: number): this { + public xpMultiplier(value: number): this { vi.spyOn(Overrides, "XP_MULTIPLIER_OVERRIDE", "get").mockReturnValue(value); this.log(`XP Multiplier set to ${value}!`); return this; @@ -64,9 +72,9 @@ export class OverridesHelper extends GameManagerHelper { /** * Override the player (pokemon) starting held items * @param items the items to hold - * @returns this + * @returns `this` */ - startingHeldItems(items: ModifierOverride[]) { + public startingHeldItems(items: ModifierOverride[]): this { vi.spyOn(Overrides, "STARTING_HELD_ITEMS_OVERRIDE", "get").mockReturnValue(items); this.log("Player Pokemon starting held items set to:", items); return this; @@ -75,23 +83,44 @@ export class OverridesHelper extends GameManagerHelper { /** * Override the player (pokemon) {@linkcode Species | species} * @param species the (pokemon) {@linkcode Species | species} to set - * @returns this + * @returns `this` */ - starterSpecies(species: Species | number): this { + public starterSpecies(species: Species | number): this { vi.spyOn(Overrides, "STARTER_SPECIES_OVERRIDE", "get").mockReturnValue(species); this.log(`Player Pokemon species set to ${Species[species]} (=${species})!`); return this; } + /** + * Override the player (pokemon) to be a random fusion + * @returns `this` + */ + public enableStarterFusion(): this { + vi.spyOn(Overrides, "STARTER_FUSION_OVERRIDE", "get").mockReturnValue(true); + this.log("Player Pokemon is a random fusion!"); + return this; + } + + /** + * Override the player (pokemon) fusion species + * @param species the fusion species to set + * @returns `this` + */ + public starterFusionSpecies(species: Species | number): this { + vi.spyOn(Overrides, "STARTER_FUSION_SPECIES_OVERRIDE", "get").mockReturnValue(species); + this.log(`Player Pokemon fusion species set to ${Species[species]} (=${species})!`); + return this; + } + /** * Override the player (pokemons) forms * @param forms the (pokemon) forms to set - * @returns this + * @returns `this` */ - starterForms(forms: Partial>): this { + public starterForms(forms: Partial>): this { vi.spyOn(Overrides, "STARTER_FORM_OVERRIDES", "get").mockReturnValue(forms); const formsStr = Object.entries(forms) - .map(([speciesId, formIndex]) => `${Species[speciesId]}=${formIndex}`) + .map(([ speciesId, formIndex ]) => `${Species[speciesId]}=${formIndex}`) .join(", "); this.log(`Player Pokemon form set to: ${formsStr}!`); return this; @@ -100,9 +129,9 @@ export class OverridesHelper extends GameManagerHelper { /** * Override the player's starting modifiers * @param modifiers the modifiers to set - * @returns this + * @returns `this` */ - startingModifier(modifiers: ModifierOverride[]): this { + public startingModifier(modifiers: ModifierOverride[]): this { vi.spyOn(Overrides, "STARTING_MODIFIER_OVERRIDE", "get").mockReturnValue(modifiers); this.log(`Player starting modifiers set to: ${modifiers}`); return this; @@ -111,9 +140,9 @@ export class OverridesHelper extends GameManagerHelper { /** * Override the player (pokemon) {@linkcode Abilities | ability} * @param ability the (pokemon) {@linkcode Abilities | ability} to set - * @returns this + * @returns `this` */ - ability(ability: Abilities): this { + public ability(ability: Abilities): this { vi.spyOn(Overrides, "ABILITY_OVERRIDE", "get").mockReturnValue(ability); this.log(`Player Pokemon ability set to ${Abilities[ability]} (=${ability})!`); return this; @@ -122,9 +151,9 @@ export class OverridesHelper extends GameManagerHelper { /** * Override the player (pokemon) **passive** {@linkcode Abilities | ability} * @param passiveAbility the (pokemon) **passive** {@linkcode Abilities | ability} to set - * @returns this + * @returns `this` */ - passiveAbility(passiveAbility: Abilities): this { + public passiveAbility(passiveAbility: Abilities): this { vi.spyOn(Overrides, "PASSIVE_ABILITY_OVERRIDE", "get").mockReturnValue(passiveAbility); this.log(`Player Pokemon PASSIVE ability set to ${Abilities[passiveAbility]} (=${passiveAbility})!`); return this; @@ -133,12 +162,12 @@ export class OverridesHelper extends GameManagerHelper { /** * Override the player (pokemon) {@linkcode Moves | moves}set * @param moveset the {@linkcode Moves | moves}set to set - * @returns this + * @returns `this` */ - moveset(moveset: Moves | Moves[]): this { + public moveset(moveset: Moves | Moves[]): this { vi.spyOn(Overrides, "MOVESET_OVERRIDE", "get").mockReturnValue(moveset); if (!Array.isArray(moveset)) { - moveset = [moveset]; + moveset = [ moveset ]; } const movesetStr = moveset.map((moveId) => Moves[moveId]).join(", "); this.log(`Player Pokemon moveset set to ${movesetStr} (=[${moveset.join(", ")}])!`); @@ -150,7 +179,7 @@ export class OverridesHelper extends GameManagerHelper { * @param statusEffect the {@linkcode StatusEffect | status-effect} to set * @returns */ - statusEffect(statusEffect: StatusEffect): this { + public statusEffect(statusEffect: StatusEffect): this { vi.spyOn(Overrides, "STATUS_OVERRIDE", "get").mockReturnValue(statusEffect); this.log(`Player Pokemon status-effect set to ${StatusEffect[statusEffect]} (=${statusEffect})!`); return this; @@ -158,9 +187,9 @@ export class OverridesHelper extends GameManagerHelper { /** * Override each wave to not have standard trainer battles - * @returns this + * @returns `this` */ - disableTrainerWaves(): this { + public disableTrainerWaves(): this { const realFn = getGameMode; vi.spyOn(GameMode, "getGameMode").mockImplementation((gameMode: GameModes) => { const mode = realFn(gameMode); @@ -173,9 +202,9 @@ export class OverridesHelper extends GameManagerHelper { /** * Override each wave to not have critical hits - * @returns this + * @returns `this` */ - disableCrits() { + public disableCrits(): this { vi.spyOn(Overrides, "NEVER_CRIT_OVERRIDE", "get").mockReturnValue(true); this.log("Critical hits are disabled!"); return this; @@ -184,9 +213,9 @@ export class OverridesHelper extends GameManagerHelper { /** * Override the {@linkcode WeatherType | weather (type)} * @param type {@linkcode WeatherType | weather type} to set - * @returns this + * @returns `this` */ - weather(type: WeatherType): this { + public weather(type: WeatherType): this { vi.spyOn(Overrides, "WEATHER_OVERRIDE", "get").mockReturnValue(type); this.log(`Weather set to ${Weather[type]} (=${type})!`); return this; @@ -195,12 +224,12 @@ export class OverridesHelper extends GameManagerHelper { /** * Override the seed * @param seed the seed to set - * @returns this + * @returns `this` */ - seed(seed: string): this { + public seed(seed: string): this { vi.spyOn(this.game.scene, "resetSeed").mockImplementation(() => { this.game.scene.waveSeed = seed; - Phaser.Math.RND.sow([seed]); + Phaser.Math.RND.sow([ seed ]); this.game.scene.rngCounter = 0; }); this.game.scene.resetSeed(); @@ -209,33 +238,55 @@ export class OverridesHelper extends GameManagerHelper { } /** - * Override the battle type (single or double) + * Override the battle type (e.g., single or double). + * @see {@linkcode Overrides.BATTLE_TYPE_OVERRIDE} * @param battleType battle type to set - * @returns this + * @returns `this` */ - battleType(battleType: "single" | "double" | null): this { + public battleType(battleType: BattleStyle | null): this { vi.spyOn(Overrides, "BATTLE_TYPE_OVERRIDE", "get").mockReturnValue(battleType); - this.log(`Battle type set to ${battleType} only!`); + this.log(battleType === null ? "Battle type override disabled!" : `Battle type set to ${battleType}!`); return this; } /** * Override the enemy (pokemon) {@linkcode Species | species} * @param species the (pokemon) {@linkcode Species | species} to set - * @returns this + * @returns `this` */ - enemySpecies(species: Species | number): this { + public enemySpecies(species: Species | number): this { vi.spyOn(Overrides, "OPP_SPECIES_OVERRIDE", "get").mockReturnValue(species); this.log(`Enemy Pokemon species set to ${Species[species]} (=${species})!`); return this; } + /** + * Override the enemy (pokemon) to be a random fusion + * @returns `this` + */ + public enableEnemyFusion(): this { + vi.spyOn(Overrides, "OPP_FUSION_OVERRIDE", "get").mockReturnValue(true); + this.log("Enemy Pokemon is a random fusion!"); + return this; + } + + /** + * Override the enemy (pokemon) fusion species + * @param species the fusion species to set + * @returns `this` + */ + public enemyFusionSpecies(species: Species | number): this { + vi.spyOn(Overrides, "OPP_FUSION_SPECIES_OVERRIDE", "get").mockReturnValue(species); + this.log(`Enemy Pokemon fusion species set to ${Species[species]} (=${species})!`); + return this; + } + /** * Override the enemy (pokemon) {@linkcode Abilities | ability} * @param ability the (pokemon) {@linkcode Abilities | ability} to set - * @returns this + * @returns `this` */ - enemyAbility(ability: Abilities): this { + public enemyAbility(ability: Abilities): this { vi.spyOn(Overrides, "OPP_ABILITY_OVERRIDE", "get").mockReturnValue(ability); this.log(`Enemy Pokemon ability set to ${Abilities[ability]} (=${ability})!`); return this; @@ -244,9 +295,9 @@ export class OverridesHelper extends GameManagerHelper { /** * Override the enemy (pokemon) **passive** {@linkcode Abilities | ability} * @param passiveAbility the (pokemon) **passive** {@linkcode Abilities | ability} to set - * @returns this + * @returns `this` */ - enemyPassiveAbility(passiveAbility: Abilities): this { + public enemyPassiveAbility(passiveAbility: Abilities): this { vi.spyOn(Overrides, "OPP_PASSIVE_ABILITY_OVERRIDE", "get").mockReturnValue(passiveAbility); this.log(`Enemy Pokemon PASSIVE ability set to ${Abilities[passiveAbility]} (=${passiveAbility})!`); return this; @@ -255,12 +306,12 @@ export class OverridesHelper extends GameManagerHelper { /** * Override the enemy (pokemon) {@linkcode Moves | moves}set * @param moveset the {@linkcode Moves | moves}set to set - * @returns this + * @returns `this` */ - enemyMoveset(moveset: Moves | Moves[]): this { + public enemyMoveset(moveset: Moves | Moves[]): this { vi.spyOn(Overrides, "OPP_MOVESET_OVERRIDE", "get").mockReturnValue(moveset); if (!Array.isArray(moveset)) { - moveset = [moveset]; + moveset = [ moveset ]; } const movesetStr = moveset.map((moveId) => Moves[moveId]).join(", "); this.log(`Enemy Pokemon moveset set to ${movesetStr} (=[${moveset.join(", ")}])!`); @@ -270,9 +321,9 @@ export class OverridesHelper extends GameManagerHelper { /** * Override the enemy (pokemon) level * @param level the level to set - * @returns this + * @returns `this` */ - enemyLevel(level: number): this { + public enemyLevel(level: number): this { vi.spyOn(Overrides, "OPP_LEVEL_OVERRIDE", "get").mockReturnValue(level); this.log(`Enemy Pokemon level set to ${level}!`); return this; @@ -283,7 +334,7 @@ export class OverridesHelper extends GameManagerHelper { * @param statusEffect the {@linkcode StatusEffect | status-effect} to set * @returns */ - enemyStatusEffect(statusEffect: StatusEffect): this { + public enemyStatusEffect(statusEffect: StatusEffect): this { vi.spyOn(Overrides, "OPP_STATUS_OVERRIDE", "get").mockReturnValue(statusEffect); this.log(`Enemy Pokemon status-effect set to ${StatusEffect[statusEffect]} (=${statusEffect})!`); return this; @@ -292,45 +343,119 @@ export class OverridesHelper extends GameManagerHelper { /** * Override the enemy (pokemon) held items * @param items the items to hold - * @returns this + * @returns `this` */ - enemyHeldItems(items: ModifierOverride[]) { + public enemyHeldItems(items: ModifierOverride[]): this { vi.spyOn(Overrides, "OPP_HELD_ITEMS_OVERRIDE", "get").mockReturnValue(items); this.log("Enemy Pokemon held items set to:", items); return this; } + /** + * Gives the player access to an Unlockable. + * @param unlockable The Unlockable(s) to enable. + * @returns `this` + */ + public enableUnlockable(unlockable: Unlockables[]): this { + vi.spyOn(Overrides, "ITEM_UNLOCK_OVERRIDE", "get").mockReturnValue(unlockable); + this.log("Temporarily unlocked the following content: ", unlockable); + return this; + } + /** * Override the items rolled at the end of a battle * @param items the items to be rolled - * @returns this + * @returns `this` */ - itemRewards(items: ModifierOverride[]) { + public itemRewards(items: ModifierOverride[]): this { vi.spyOn(Overrides, "ITEM_REWARD_OVERRIDE", "get").mockReturnValue(items); this.log("Item rewards set to:", items); return this; } + /** + * Override player shininess + * @param shininess - `true` or `false` to force the player's pokemon to be shiny or not shiny, + * `null` to disable the override and re-enable RNG shinies. + * @returns `this` + */ + public shiny(shininess: boolean | null): this { + vi.spyOn(Overrides, "SHINY_OVERRIDE", "get").mockReturnValue(shininess); + if (shininess === null) { + this.log("Disabled player Pokemon shiny override!"); + } else { + this.log(`Set player Pokemon to be ${shininess ? "" : "not "}shiny!`); + } + return this; + } + + /** + * Override player shiny variant + * @param variant - The player's shiny variant. + * @returns `this` + */ + public shinyVariant(variant: Variant): this { + vi.spyOn(Overrides, "VARIANT_OVERRIDE", "get").mockReturnValue(variant); + this.log(`Set player Pokemon's shiny variant to ${variant}!`); + return this; + } + + /** + * Override enemy shininess + * @param shininess - `true` or `false` to force the enemy's pokemon to be shiny or not shiny, + * `null` to disable the override and re-enable RNG shinies. + * @param variant - (Optional) The enemy's shiny {@linkcode Variant}. + */ + enemyShiny(shininess: boolean | null, variant?: Variant): this { + vi.spyOn(Overrides, "OPP_SHINY_OVERRIDE", "get").mockReturnValue(shininess); + if (shininess === null) { + this.log("Disabled enemy Pokemon shiny override!"); + } else { + this.log(`Set enemy Pokemon to be ${shininess ? "" : "not "}shiny!`); + } + + if (variant !== undefined) { + vi.spyOn(Overrides, "OPP_VARIANT_OVERRIDE", "get").mockReturnValue(variant); + this.log(`Set enemy shiny variant to be ${variant}!`); + } + return this; + } + /** * Override the enemy (Pokemon) to have the given amount of health segments * @param healthSegments the number of segments to give - * default: 0, the health segments will be handled like in the game based on wave, level and species - * 1: the Pokemon will not be a boss - * 2+: the Pokemon will be a boss with the given number of health segments - * @returns this + * - `0` (default): the health segments will be handled like in the game based on wave, level and species + * - `1`: the Pokemon will not be a boss + * - `2`+: the Pokemon will be a boss with the given number of health segments + * @returns `this` */ - enemyHealthSegments(healthSegments: number) { + public enemyHealthSegments(healthSegments: number): this { vi.spyOn(Overrides, "OPP_HEALTH_SEGMENTS_OVERRIDE", "get").mockReturnValue(healthSegments); this.log("Enemy Pokemon health segments set to:", healthSegments); return this; } + /** + * Override statuses (Paralysis and Freeze) to always or never activate + * @param activate - `true` to force activation, `false` to force no activation, `null` to disable the override + * @returns `this` + */ + public statusActivation(activate: boolean | null): this { + vi.spyOn(Overrides, "STATUS_ACTIVATION_OVERRIDE", "get").mockReturnValue(activate); + if (activate !== null) { + this.log(`Paralysis and Freeze forced to ${activate ? "always" : "never"} activate!`); + } else { + this.log("Status activation override disabled!"); + } + return this; + } + /** * Override the encounter chance for a mystery encounter. * @param percentage the encounter chance in % - * @returns spy instance + * @returns `this` */ - mysteryEncounterChance(percentage: number) { + public mysteryEncounterChance(percentage: number): this { const maxRate: number = 256; // 100% const rate = maxRate * (percentage / 100); vi.spyOn(Overrides, "MYSTERY_ENCOUNTER_RATE_OVERRIDE", "get").mockReturnValue(rate); @@ -340,10 +465,10 @@ export class OverridesHelper extends GameManagerHelper { /** * Override the encounter chance for a mystery encounter. - * @returns spy instance - * @param tier + * @param tier - The {@linkcode MysteryEncounterTier} to encounter + * @returns `this` */ - mysteryEncounterTier(tier: MysteryEncounterTier) { + public mysteryEncounterTier(tier: MysteryEncounterTier): this { vi.spyOn(Overrides, "MYSTERY_ENCOUNTER_TIER_OVERRIDE", "get").mockReturnValue(tier); this.log(`Mystery encounter tier set to ${tier}!`); return this; @@ -351,10 +476,10 @@ export class OverridesHelper extends GameManagerHelper { /** * Override the encounter that spawns for the scene - * @param encounterType - * @returns spy instance + * @param encounterType - The {@linkcode MysteryEncounterType} of the encounter + * @returns `this` */ - mysteryEncounter(encounterType: MysteryEncounterType) { + public mysteryEncounter(encounterType: MysteryEncounterType): this { vi.spyOn(Overrides, "MYSTERY_ENCOUNTER_OVERRIDE", "get").mockReturnValue(encounterType); this.log(`Mystery encounter override set to ${encounterType}!`); return this; diff --git a/src/test/utils/helpers/settingsHelper.ts b/src/test/utils/helpers/settingsHelper.ts index c611a705107..83baa329cec 100644 --- a/src/test/utils/helpers/settingsHelper.ts +++ b/src/test/utils/helpers/settingsHelper.ts @@ -27,7 +27,7 @@ export class SettingsHelper extends GameManagerHelper { */ typeHints(enable: boolean): void { this.game.scene.typeHints = enable; - this.log(`Type Hints ${enable? "enabled" : "disabled"}` ); + this.log(`Type Hints ${enable ? "enabled" : "disabled"}` ); } /** diff --git a/src/test/utils/inputsHandler.ts b/src/test/utils/inputsHandler.ts index 30dd101f43d..bf690d5d74c 100644 --- a/src/test/utils/inputsHandler.ts +++ b/src/test/utils/inputsHandler.ts @@ -41,18 +41,18 @@ export default class InputsHandler { pressGamepadButton(button: integer, duration: integer): Promise { return new Promise(async (resolve) => { - this.scene.input.gamepad?.emit("down", this.fakePad, {index: button}); + this.scene.input.gamepad?.emit("down", this.fakePad, { index: button }); await holdOn(duration); - this.scene.input.gamepad?.emit("up", this.fakePad, {index: button}); + this.scene.input.gamepad?.emit("up", this.fakePad, { index: button }); resolve(); }); } pressKeyboardKey(key: integer, duration: integer): Promise { return new Promise(async (resolve) => { - this.scene.input.keyboard?.emit("keydown", {keyCode: key}); + this.scene.input.keyboard?.emit("keydown", { keyCode: key }); await holdOn(duration); - this.scene.input.keyboard?.emit("keyup", {keyCode: key}); + this.scene.input.keyboard?.emit("keyup", { keyCode: key }); resolve(); }); } @@ -67,11 +67,11 @@ export default class InputsHandler { listenInputs(): void { this.events.on("input_down", (event) => { - this.log.push({type: "input_down", button: event.button}); + this.log.push({ type: "input_down", button: event.button }); }, this); this.events.on("input_up", (event) => { - this.logUp.push({type: "input_up", button: event.button}); + this.logUp.push({ type: "input_up", button: event.button }); }, this); } } @@ -82,7 +82,7 @@ class Fakepad extends Phaser.Input.Gamepad.Gamepad { constructor(pad) { //@ts-ignore - super(undefined, {...pad, buttons: pad.deviceMapping, axes: []}); //TODO: resolve ts-ignore + super(undefined, { ...pad, buttons: pad.deviceMapping, axes: []}); //TODO: resolve ts-ignore this.id = "xbox_360_fakepad"; this.index = 0; } @@ -90,7 +90,7 @@ class Fakepad extends Phaser.Input.Gamepad.Gamepad { class FakeMobile { constructor() { - const fakeMobilePage = fs.readFileSync("./src/test/utils/fakeMobile.html", {encoding: "utf8", flag: "r"}); + const fakeMobilePage = fs.readFileSync("./src/test/utils/fakeMobile.html", { encoding: "utf8", flag: "r" }); const dom = new JSDOM(fakeMobilePage); Object.defineProperty(window, "document", { value: dom.window.document, diff --git a/src/test/utils/mocks/mockClock.ts b/src/test/utils/mocks/mockClock.ts index e7501a7c99d..7fad3651010 100644 --- a/src/test/utils/mocks/mockClock.ts +++ b/src/test/utils/mocks/mockClock.ts @@ -17,7 +17,7 @@ export class MockClock extends Clock { } addEvent(config: Phaser.Time.TimerEvent | Phaser.Types.Time.TimerEventConfig): Phaser.Time.TimerEvent { - const cfg = { ...config, delay: this.overrideDelay ?? config.delay}; + const cfg = { ...config, delay: this.overrideDelay ?? config.delay }; return super.addEvent(cfg); } } diff --git a/src/test/utils/mocks/mockConsoleLog.ts b/src/test/utils/mocks/mockConsoleLog.ts index f44a0c7d6cd..9c3cbca6bb6 100644 --- a/src/test/utils/mocks/mockConsoleLog.ts +++ b/src/test/utils/mocks/mockConsoleLog.ts @@ -1,4 +1,4 @@ -const MockConsoleLog = (_logDisabled= false, _phaseText=false) => { +const MockConsoleLog = (_logDisabled = false, _phaseText = false) => { let logs: any[] = []; const logDisabled: boolean = _logDisabled; const phaseText: boolean = _phaseText; @@ -8,8 +8,8 @@ const MockConsoleLog = (_logDisabled= false, _phaseText=false) => { const originalWarn = console.warn; const notified: any[] = []; - const blacklist = ["Phaser", "variant icon does not exist", "Texture \"%s\" not found"]; - const whitelist = ["Phase"]; + const blacklist = [ "Phaser", "variant icon does not exist", "Texture \"%s\" not found" ]; + const whitelist = [ "Phase" ]; return ({ log(...args) { diff --git a/src/test/utils/mocks/mockFetch.ts b/src/test/utils/mocks/mockFetch.ts index ad3758775d1..2fa7cd198ce 100644 --- a/src/test/utils/mocks/mockFetch.ts +++ b/src/test/utils/mocks/mockFetch.ts @@ -5,12 +5,12 @@ export const MockFetch = (input, init) => { let responseText; const handlers = { - "account/info": {"username":"greenlamp", "lastSessionSlot":0}, + "account/info": { "username":"greenlamp", "lastSessionSlot":0 }, "savedata/session": {}, "savedata/system": {}, "savedata/updateall": "", "daily/rankingpagecount": { data: 0 }, - "game/titlestats": {"playerCount":0, "battleCount":5}, + "game/titlestats": { "playerCount":0, "battleCount":5 }, "daily/rankings": [], }; diff --git a/src/test/utils/mocks/mockTimedEventManager.ts b/src/test/utils/mocks/mockTimedEventManager.ts new file mode 100644 index 00000000000..b44729996a7 --- /dev/null +++ b/src/test/utils/mocks/mockTimedEventManager.ts @@ -0,0 +1,17 @@ +import { TimedEventManager } from "#app/timed-event-manager"; + +/** Mock TimedEventManager so that ongoing events don't impact tests */ +export class MockTimedEventManager extends TimedEventManager { + override activeEvent() { + return undefined; + } + override isEventActive(): boolean { + return false; + } + override getFriendshipMultiplier(): number { + return 1; + } + override getShinyMultiplier(): number { + return 1; + } +} diff --git a/src/test/utils/mocks/mocksContainer/mockSprite.ts b/src/test/utils/mocks/mocksContainer/mockSprite.ts index a55b218d0c2..e726fec454d 100644 --- a/src/test/utils/mocks/mocksContainer/mockSprite.ts +++ b/src/test/utils/mocks/mocksContainer/mockSprite.ts @@ -212,5 +212,4 @@ export default class MockSprite implements MockGameObject { } - } diff --git a/src/test/utils/mocks/mocksContainer/mockText.ts b/src/test/utils/mocks/mocksContainer/mockText.ts index f0854fcd90a..faa32ff8a06 100644 --- a/src/test/utils/mocks/mocksContainer/mockText.ts +++ b/src/test/utils/mocks/mocksContainer/mockText.ts @@ -79,7 +79,14 @@ export default class MockText implements MockGameObject { return result; } - showText(text: string, delay?: integer | null, callback?: Function | null, callbackDelay?: integer | null, prompt?: boolean | null, promptDelay?: integer | null) { + showText( + text: string, + delay?: integer | null, + callback?: Function | null, + callbackDelay?: integer | null, + prompt?: boolean | null, + promptDelay?: integer | null + ) { this.scene.messageWrapper.showText(text, delay, callback, callbackDelay, prompt, promptDelay); if (callback) { callback(); @@ -115,16 +122,11 @@ export default class MockText implements MockGameObject { // return this.phaserText.once(event, callback, source); } - off(event, callback, obj) { - } + off(event, callback, obj) {} - removedFromScene() { + removedFromScene() {} - } - - addToDisplayList() { - - } + addToDisplayList() {} setStroke(color, thickness) { // Sets the stroke color and thickness. @@ -160,7 +162,7 @@ export default class MockText implements MockGameObject { * @param z The z position of this Game Object. Default 0. * @param w The w position of this Game Object. Default 0. */ - setPosition(x?: number, y?: number, z?: number, w?: number) { } + setPosition(x?: number, y?: number, z?: number, w?: number) {} setText(text) { // Sets the text this Game Object will display. @@ -298,4 +300,6 @@ export default class MockText implements MockGameObject { getAll() { return this.list; } + + on(_event: string | symbol, _fn: Function, _context?: any) {} } diff --git a/src/test/utils/phaseInterceptor.ts b/src/test/utils/phaseInterceptor.ts index 46bb757c867..4029e5e168c 100644 --- a/src/test/utils/phaseInterceptor.ts +++ b/src/test/utils/phaseInterceptor.ts @@ -12,6 +12,7 @@ import { EndEvolutionPhase } from "#app/phases/end-evolution-phase"; import { EnemyCommandPhase } from "#app/phases/enemy-command-phase"; import { EvolutionPhase } from "#app/phases/evolution-phase"; import { FaintPhase } from "#app/phases/faint-phase"; +import { FormChangePhase } from "#app/phases/form-change-phase"; import { LearnMovePhase } from "#app/phases/learn-move-phase"; import { LevelCapPhase } from "#app/phases/level-cap-phase"; import { LoginPhase } from "#app/phases/login-phase"; @@ -43,6 +44,7 @@ import { UnavailablePhase } from "#app/phases/unavailable-phase"; import { VictoryPhase } from "#app/phases/victory-phase"; import { PartyHealPhase } from "#app/phases/party-heal-phase"; import UI, { Mode } from "#app/ui/ui"; +import { SelectBiomePhase } from "#app/phases/select-biome-phase"; import { MysteryEncounterBattlePhase, MysteryEncounterOptionSelectedPhase, @@ -52,6 +54,12 @@ import { } from "#app/phases/mystery-encounter-phases"; import { ModifierRewardPhase } from "#app/phases/modifier-reward-phase"; import { PartyExpPhase } from "#app/phases/party-exp-phase"; +import { ExpPhase } from "#app/phases/exp-phase"; +import { GameOverPhase } from "#app/phases/game-over-phase"; +import { RibbonModifierRewardPhase } from "#app/phases/ribbon-modifier-reward-phase"; +import { GameOverModifierRewardPhase } from "#app/phases/game-over-modifier-reward-phase"; +import { UnlockPhase } from "#app/phases/unlock-phase"; +import { PostGameOverPhase } from "#app/phases/post-game-over-phase"; export interface PromptHandler { phaseTarget?: string; @@ -60,7 +68,126 @@ export interface PromptHandler { expireFn?: () => void; awaitingActionInput?: boolean; } -import { ExpPhase } from "#app/phases/exp-phase"; + +type PhaseClass = + | typeof LoginPhase + | typeof TitlePhase + | typeof SelectGenderPhase + | typeof NewBiomeEncounterPhase + | typeof SelectStarterPhase + | typeof PostSummonPhase + | typeof SummonPhase + | typeof ToggleDoublePositionPhase + | typeof CheckSwitchPhase + | typeof ShowAbilityPhase + | typeof MessagePhase + | typeof TurnInitPhase + | typeof CommandPhase + | typeof EnemyCommandPhase + | typeof TurnStartPhase + | typeof MovePhase + | typeof MoveEffectPhase + | typeof DamagePhase + | typeof FaintPhase + | typeof BerryPhase + | typeof TurnEndPhase + | typeof BattleEndPhase + | typeof EggLapsePhase + | typeof SelectModifierPhase + | typeof NextEncounterPhase + | typeof NewBattlePhase + | typeof VictoryPhase + | typeof LearnMovePhase + | typeof MoveEndPhase + | typeof StatStageChangePhase + | typeof ShinySparklePhase + | typeof SelectTargetPhase + | typeof UnavailablePhase + | typeof QuietFormChangePhase + | typeof SwitchPhase + | typeof SwitchSummonPhase + | typeof PartyHealPhase + | typeof FormChangePhase + | typeof EvolutionPhase + | typeof EndEvolutionPhase + | typeof LevelCapPhase + | typeof AttemptRunPhase + | typeof SelectBiomePhase + | typeof MysteryEncounterPhase + | typeof MysteryEncounterOptionSelectedPhase + | typeof MysteryEncounterBattlePhase + | typeof MysteryEncounterRewardsPhase + | typeof PostMysteryEncounterPhase + | typeof RibbonModifierRewardPhase + | typeof GameOverModifierRewardPhase + | typeof ModifierRewardPhase + | typeof PartyExpPhase + | typeof ExpPhase + | typeof EncounterPhase + | typeof GameOverPhase + | typeof UnlockPhase + | typeof PostGameOverPhase; + +type PhaseString = + | "LoginPhase" + | "TitlePhase" + | "SelectGenderPhase" + | "NewBiomeEncounterPhase" + | "SelectStarterPhase" + | "PostSummonPhase" + | "SummonPhase" + | "ToggleDoublePositionPhase" + | "CheckSwitchPhase" + | "ShowAbilityPhase" + | "MessagePhase" + | "TurnInitPhase" + | "CommandPhase" + | "EnemyCommandPhase" + | "TurnStartPhase" + | "MovePhase" + | "MoveEffectPhase" + | "DamagePhase" + | "FaintPhase" + | "BerryPhase" + | "TurnEndPhase" + | "BattleEndPhase" + | "EggLapsePhase" + | "SelectModifierPhase" + | "NextEncounterPhase" + | "NewBattlePhase" + | "VictoryPhase" + | "LearnMovePhase" + | "MoveEndPhase" + | "StatStageChangePhase" + | "ShinySparklePhase" + | "SelectTargetPhase" + | "UnavailablePhase" + | "QuietFormChangePhase" + | "SwitchPhase" + | "SwitchSummonPhase" + | "PartyHealPhase" + | "FormChangePhase" + | "EvolutionPhase" + | "EndEvolutionPhase" + | "LevelCapPhase" + | "AttemptRunPhase" + | "SelectBiomePhase" + | "MysteryEncounterPhase" + | "MysteryEncounterOptionSelectedPhase" + | "MysteryEncounterBattlePhase" + | "MysteryEncounterRewardsPhase" + | "PostMysteryEncounterPhase" + | "RibbonModifierRewardPhase" + | "GameOverModifierRewardPhase" + | "ModifierRewardPhase" + | "PartyExpPhase" + | "ExpPhase" + | "EncounterPhase" + | "GameOverPhase" + | "UnlockPhase" + | "PostGameOverPhase"; + +type PhaseInterceptorPhase = PhaseClass | PhaseString; export default class PhaseInterceptor { public scene; @@ -78,58 +205,70 @@ export default class PhaseInterceptor { /** * List of phases with their corresponding start methods. + * + * CAUTION: If a phase and its subclasses (if any) both appear in this list, + * make sure that this list contains said phase AFTER all of its subclasses. + * This way, the phase's `prototype.start` is properly preserved during + * `initPhases()` so that its subclasses can use `super.start()` properly. */ private PHASES = [ - [LoginPhase, this.startPhase], - [TitlePhase, this.startPhase], - [SelectGenderPhase, this.startPhase], - [EncounterPhase, this.startPhase], - [NewBiomeEncounterPhase, this.startPhase], - [SelectStarterPhase, this.startPhase], - [PostSummonPhase, this.startPhase], - [SummonPhase, this.startPhase], - [ToggleDoublePositionPhase, this.startPhase], - [CheckSwitchPhase, this.startPhase], - [ShowAbilityPhase, this.startPhase], - [MessagePhase, this.startPhase], - [TurnInitPhase, this.startPhase], - [CommandPhase, this.startPhase], - [EnemyCommandPhase, this.startPhase], - [TurnStartPhase, this.startPhase], - [MovePhase, this.startPhase], - [MoveEffectPhase, this.startPhase], - [DamagePhase, this.startPhase], - [FaintPhase, this.startPhase], - [BerryPhase, this.startPhase], - [TurnEndPhase, this.startPhase], - [BattleEndPhase, this.startPhase], - [EggLapsePhase, this.startPhase], - [SelectModifierPhase, this.startPhase], - [NextEncounterPhase, this.startPhase], - [NewBattlePhase, this.startPhase], - [VictoryPhase, this.startPhase], - [LearnMovePhase, this.startPhase], - [MoveEndPhase, this.startPhase], - [StatStageChangePhase, this.startPhase], - [ShinySparklePhase, this.startPhase], - [SelectTargetPhase, this.startPhase], - [UnavailablePhase, this.startPhase], - [QuietFormChangePhase, this.startPhase], - [SwitchPhase, this.startPhase], - [SwitchSummonPhase, this.startPhase], - [PartyHealPhase, this.startPhase], - [EvolutionPhase, this.startPhase], - [EndEvolutionPhase, this.startPhase], - [LevelCapPhase, this.startPhase], - [AttemptRunPhase, this.startPhase], - [MysteryEncounterPhase, this.startPhase], - [MysteryEncounterOptionSelectedPhase, this.startPhase], - [MysteryEncounterBattlePhase, this.startPhase], - [MysteryEncounterRewardsPhase, this.startPhase], - [PostMysteryEncounterPhase, this.startPhase], - [ModifierRewardPhase, this.startPhase], - [PartyExpPhase, this.startPhase], - [ExpPhase, this.startPhase], + [ LoginPhase, this.startPhase ], + [ TitlePhase, this.startPhase ], + [ SelectGenderPhase, this.startPhase ], + [ NewBiomeEncounterPhase, this.startPhase ], + [ SelectStarterPhase, this.startPhase ], + [ PostSummonPhase, this.startPhase ], + [ SummonPhase, this.startPhase ], + [ ToggleDoublePositionPhase, this.startPhase ], + [ CheckSwitchPhase, this.startPhase ], + [ ShowAbilityPhase, this.startPhase ], + [ MessagePhase, this.startPhase ], + [ TurnInitPhase, this.startPhase ], + [ CommandPhase, this.startPhase ], + [ EnemyCommandPhase, this.startPhase ], + [ TurnStartPhase, this.startPhase ], + [ MovePhase, this.startPhase ], + [ MoveEffectPhase, this.startPhase ], + [ DamagePhase, this.startPhase ], + [ FaintPhase, this.startPhase ], + [ BerryPhase, this.startPhase ], + [ TurnEndPhase, this.startPhase ], + [ BattleEndPhase, this.startPhase ], + [ EggLapsePhase, this.startPhase ], + [ SelectModifierPhase, this.startPhase ], + [ NextEncounterPhase, this.startPhase ], + [ NewBattlePhase, this.startPhase ], + [ VictoryPhase, this.startPhase ], + [ LearnMovePhase, this.startPhase ], + [ MoveEndPhase, this.startPhase ], + [ StatStageChangePhase, this.startPhase ], + [ ShinySparklePhase, this.startPhase ], + [ SelectTargetPhase, this.startPhase ], + [ UnavailablePhase, this.startPhase ], + [ QuietFormChangePhase, this.startPhase ], + [ SwitchPhase, this.startPhase ], + [ SwitchSummonPhase, this.startPhase ], + [ PartyHealPhase, this.startPhase ], + [ FormChangePhase, this.startPhase ], + [ EvolutionPhase, this.startPhase ], + [ EndEvolutionPhase, this.startPhase ], + [ LevelCapPhase, this.startPhase ], + [ AttemptRunPhase, this.startPhase ], + [ SelectBiomePhase, this.startPhase ], + [ MysteryEncounterPhase, this.startPhase ], + [ MysteryEncounterOptionSelectedPhase, this.startPhase ], + [ MysteryEncounterBattlePhase, this.startPhase ], + [ MysteryEncounterRewardsPhase, this.startPhase ], + [ PostMysteryEncounterPhase, this.startPhase ], + [ RibbonModifierRewardPhase, this.startPhase ], + [ GameOverModifierRewardPhase, this.startPhase ], + [ ModifierRewardPhase, this.startPhase ], + [ PartyExpPhase, this.startPhase ], + [ ExpPhase, this.startPhase ], + [ EncounterPhase, this.startPhase ], + [ GameOverPhase, this.startPhase ], + [ UnlockPhase, this.startPhase ], + [ PostGameOverPhase, this.startPhase ], ]; private endBySetMode = [ @@ -170,7 +309,7 @@ export default class PhaseInterceptor { * @param phaseFrom - The phase to start from. * @returns The instance of the PhaseInterceptor. */ - runFrom(phaseFrom) { + runFrom(phaseFrom: PhaseInterceptorPhase): PhaseInterceptor { this.phaseFrom = phaseFrom; return this; } @@ -178,9 +317,10 @@ export default class PhaseInterceptor { /** * Method to transition to a target phase. * @param phaseTo - The phase to transition to. + * @param runTarget - Whether or not to run the target phase. * @returns A promise that resolves when the transition is complete. */ - async to(phaseTo, runTarget: boolean = true): Promise { + async to(phaseTo: PhaseInterceptorPhase, runTarget: boolean = true): Promise { return new Promise(async (resolve, reject) => { ErrorInterceptor.getInstance().add(this); if (this.phaseFrom) { @@ -217,7 +357,7 @@ export default class PhaseInterceptor { * @param skipFn - Optional skip function. * @returns A promise that resolves when the phase is run. */ - run(phaseTarget, skipFn?): Promise { + run(phaseTarget: PhaseInterceptorPhase, skipFn?: (className: PhaseClass) => boolean): Promise { const targetName = typeof phaseTarget === "string" ? phaseTarget : phaseTarget.name; this.scene.moveAnimations = null; // Mandatory to avoid crash return new Promise(async (resolve, reject) => { @@ -251,7 +391,7 @@ export default class PhaseInterceptor { }); } - whenAboutToRun(phaseTarget, skipFn?): Promise { + whenAboutToRun(phaseTarget: PhaseInterceptorPhase, skipFn?: (className: PhaseClass) => boolean): Promise { const targetName = typeof phaseTarget === "string" ? phaseTarget : phaseTarget.name; this.scene.moveAnimations = null; // Mandatory to avoid crash return new Promise(async (resolve, reject) => { @@ -295,7 +435,7 @@ export default class PhaseInterceptor { this.originalSuperEnd = Phase.prototype.end; UI.prototype.setMode = (mode, ...args) => this.setMode.call(this, mode, ...args); Phase.prototype.end = () => this.superEndPhase.call(this); - for (const [phase, methodStart] of this.PHASES) { + for (const [ phase, methodStart ] of this.PHASES) { const originalStart = phase.prototype.start; this.phases[phase.name] = { start: originalStart, @@ -309,7 +449,7 @@ export default class PhaseInterceptor { * Method to start a phase and log it. * @param phase - The phase to start. */ - startPhase(phase) { + startPhase(phase: PhaseClass) { this.log.push(phase.name); const instance = this.scene.getCurrentPhase(); this.onHold.push({ @@ -338,15 +478,17 @@ export default class PhaseInterceptor { /** * m2m to set mode. - * @param phase - The phase to start. + * @param mode - The {@linkcode Mode} to set. + * @param args - Additional arguments to pass to the original method. */ - setMode(mode: Mode, ...args: any[]): Promise { + setMode(mode: Mode, ...args: unknown[]): Promise { const currentPhase = this.scene.getCurrentPhase(); const instance = this.scene.ui; console.log("setMode", `${Mode[mode]} (=${mode})`, args); - const ret = this.originalSetMode.apply(instance, [mode, ...args]); + const ret = this.originalSetMode.apply(instance, [ mode, ...args ]); if (!this.phases[currentPhase.constructor.name]) { - throw new Error(`missing ${currentPhase.constructor.name} in phaseInterceptor PHASES list`); + throw new Error(`missing ${currentPhase.constructor.name} in phaseInterceptor PHASES list --- Add it to PHASES inside of /test/utils/phaseInterceptor.ts`); + } if (this.phases[currentPhase.constructor.name].endBySetMode) { this.inProgress?.callback(); @@ -403,7 +545,7 @@ export default class PhaseInterceptor { * function stored in `this.phases`. Additionally, it clears the `promptInterval` and `interval`. */ restoreOg() { - for (const [phase] of this.PHASES) { + for (const [ phase ] of this.PHASES) { phase.prototype.start = this.phases[phase.name].start; } UI.prototype.setMode = this.originalSetMode; diff --git a/src/test/utils/saves/everything.prsv b/src/test/utils/saves/everything.prsv index 1985a6649ca..f9106ce0e35 100644 --- a/src/test/utils/saves/everything.prsv +++ b/src/test/utils/saves/everything.prsv @@ -1 +1 @@ -U2FsdGVkX1/4DTixhxQcAYS2/Di/pqeu/nRpupkjBuWMNPyi+EU5+XagpDb3U95TieqHIklaFb+j7Pd6A/hz87xqpTZlaELG7sPTaVHcghitW2NbqKQn30ghp1jZ4YclXiBLaust5iT9CfGZ2Nd9XSNxgUPg/j+H0hWMgkpx4T28rB/RipRUgwwoPB2018E48E5b9Or55aZ2Ddh/zXXnOPFOghOn2+0XaLhyXKWHf/8/VPgGTzyvAdzwIC0C8dPCEuSgPoELY7nigHpX+9N3P5DHv1K3RlG4QfAF9tmgkXwuddsSCT1/4yQxhXSPTXG8dQ4HWa9aLFLCjVbqsnHFnLmd5TQt1PdzDo5uPlSS8OXVyRcs1ghtLfdhoVOJNYQIEW/vyfRuitHmvnZiQQiV10meueTUnmtsvBIdKOkbf9c/DB4muwQVuV/X5Y4Fhat6GrsqVsYT9NhKgKZdk6ohTb8RJz3CmjiNxYzKMF9q32DazDWIlaKEy4Z/aoHJshuxG/v9mHHs6K3Yx6hhMjUMAC+0BP+M+SVc5CpfJWP46cBtXeFLRHSC+XOyq/Rawe36QTF84pfZFMTd3H3ZqYDMMs55Ldsky51AyKLs9u5Onw6uzFKX8DmbSlO3ak0o65EBBe1TXadQHbzT/0wlWMt9pj2kcA+4AAl9wgqtXOLWR9dfSq7tZEz5U4iTd8kOi4OgeLHZqueH9rXF0YdTOgqJtsnbXKz91+EwkMfaTE8GrtpgaWYorN72j3DryFx2zMK/L2zUDV6XJEhRXb5udHxcrg+0l5EQgLfWjT92GGuomj2E20E0lUN02JRZHYQjH89w464cAy4kvFdJtmydYYNWp3olBwIb8tRGXifXgkFacFCXwOmtGIrUkwN6Gm1MOh0l0bS3suaQklqaTyzBAkAQMKNYKlenmXwgs23e3PNfe9SRKXmTDaH8ZikoWT10ur/G17O+p+73ufkYh8VbLUcSbDUtSuSCCipAyxxaJ5alhAXlFprEkkVNJb9jES/403KRcLVxk/8i9Yym7ftBxDNQc3j0q3bEz5FMm8GFWcTBOctBJjXQ32wCitF6MGOM7pefhFeuZo9j6SatV8Wm9++/QYYp9WykY7K3zGwvQ6jCrSCKZWnNK7+ESrNhgzUQKcaU2xp2cdv30Z5Yy5HYPwSE61bVJsdXYeeNIewsT0V0n7P7FgVvJ2f9jF2RN4avD1uH1xmWAZVckJ08D2i0JYz9PeygJhpN8MrlLQQCu2AmWkXx5GTDf4WsYhDfkTxW4YQn6Ba1Jr1kUdApT0KZzlJxtQTcTxpB720WQ08E1ZNHhk/pEsG3/uDe3tbOyhCHT6o4xhLMKfkdJYOyWwYht/SMkqTJGwNMGJVADZbSDFT5t0gRibCZTErXoGgTEmPWUDevRQhWPeAEgy73GmmvFWJgAMzwwmCxhFqhAzyWUR/dv6LC/t0acBqrW1EjoYKqlxDMBQH5vbcCE6pI0jfei8N4EIA7qOqI2Fd/GvM3pdX2d5yO5MRzxq7y5nxzRNfaxPh+aW9WGDeK/jm4UOwchWIrLrYDQsh6PED3B3stBpftJcx6RigmhsKhdF79/si2/ifh3X6gutsK95693bR6rdUYSymYUxo4dF8HFhtxIBFf6OZnIIROr8uiOe+goeQ0fp+JQjQ2wFWVs5p3oDbwhvNgViDDZ4eJlxQTyMXgKOq3sn3EQ3/WMknHykSZy1n7nP1sPIUmG8+dh275xbFBCkLbhm4gh+FmAzAmXrnb+7UupqqZiINR8O+WKJCYEWeknDBCDOOYgzEESzzN5J/54bbKrbQVvrwmIxXVeI7/VE9MrLVdH6F+vwFrAWzRlUic7xu8/BK0dfvbIaArImgUFCdQZFL8JwVpyhDSAm6IkzGQ9A97b+9cdydYr8zjggNm+L5nIAxsOXfg+fEhDnMnBLqvoQkd7jwHgsjHTygpMIYdkTTOSsDnpr78c9LXRXN0h9YYrTMIdniUHsPf58nLGNhKdyopGCm7MYllFdZgt4IDSZwslDsgWAqg7/zZ+35tU44XlRi0g/c72192Zsv7z5SM1m/jqkB4aN5a1yT/NSLF4dST34DWGFBptCkbhLWT0C6e7K7r2TQ2GC90C8jyznwJhvUqJzDExokYrIhhDhHu0ae6x+yFLAWR08RrsKpBFqVCDhT4dV2lwMYx1CsS71a/9OPn+WIEZT/MuKKHjDsNRZF+nKUaUc3MpW37Qcb+8s5c9O5dFuaokPSkklRioWOeoi+DGg34ZIqcoBZhp4FQHIDpEZrF2yigXbRKuJeoy6uXQOK5zREkgcdnUfzMlScuOYNg4FfnMg5406paWoj15GrIhaM2w+EZTcDxawlbMdSkFg4uud6Fhywkvj1vnFdyksLia0IE9ysnfbNQQOxfC82Z56/qC/HOgTzjflWyomgbd51RDQVnT5k1Hss1L2dA4JG6OLBJozMrG3TuPmTfnUvoen3dzbJJrIyKHKIeg69YozG/uL23bHX/6M0RnfkwXkAenzyaepbKqRxrYKvfbRT0E3W9V3tZeI7NwSiYO7Jfs7XkIRLrtdquChnYLd1MfjdS7Vj1cY/uoUeN9ZIHgJxtp9Q83GOmtqaoGOtngn4QvRuTkim6xVYG8SkDefHE9Ey7csA0kVccR4y709uk5tYjdGQqOt/9dIYhQxEHRyXjQ03k5U59hlAw6C+R7LoTZ1xEBDb/+ctJffqMh4kZsIC5Uue/KqLPfQomjPO+Q9ZrDkXLwe0ylCILxVeqWB96TSrQF5m5AQbF1ukYLGcjLZUPJW41OzJfeuMmh5jqjXdjOnD+C0Kte0SiDyFro50ij7DrdZTDXbw+Umfq6MkLlzXy8Xe4Bpbr+GFGuOKXhjWu9wlhlkkuFzxHc+2Vk7uvtCct6wIwlXqi6HoBFSzubsjyeAZPzKXxhOgxYandoubsoLTmQ4R8dJ+tIVjv/cF754I5OZNz9YPVQQSpSr87SQPGRktSpxUypSAeA3TMhnDuaFMaxsUcsxsGhEZi9FPM1BCCC94OI9Q8wdwM0jPwYuJBOtcS4M4aheEEn9v2SHTns+mBckVZxLxIAbhqpQ0UkyJPwCL94/lqIC7kJXxgLTS93p2BWuMBsjb2kew5AbcTgTdSqK/f5GA10yV9D2V3mhX6htHEqpe73qw/cn3jkhzILscJVMDeLV0KLUq7TkbagKS2zLX84XEjAsZWFahN6WZFmdPBpmYlC7obOo+mdgOZwgDc2JYEWTyVcuHY9xf+uU7sToDikqGs35NiatCm7IH6gZslAqw5pMpwlHHgzgeM8TDposfs1iVbdVnjoB3YLeS0mVlkLgYNIOz0Wi8L37CW8Y73yVMx3yFiZTE41VNU1FzmuBLzxDjF9h7XyEGYGyVKP6I7kxPGIq3JBNCQKDdg8lpqx7j+2Yt3OdpPRbZ4XAYL3JDohWRjKLV7HHyRtYmuqUmBAdS2U591JdlNfyq0hO2/qwowtpex6miBgZW9B2AGcZxRLlSKRdmVyhd0WNk4sp5hkKJQLX5Ny10YbDi0KOo2iw9bQJ42T/UfFqODC+dIA2l+4OCNqDAZ9r4pPHHaxeVys0zJfvsMMfJ69wH3sVTMXWRN1HkyDD/dZtaqSD/4vXifuGFhQ2pDB4UskA1NiUFmUX2mgLicB2IUHeW7CIXFdBTUj+NGcVFFzdTGvZ9tT0dYqyRO00QQQrjmEEyhlWJaju3nNcVmgiDWD4Tiz40Huf3kZ4Ssp0ppZJcFnFuMfo8nagmGKwhiAw4TbmCOI+ME0rLWkaGyS7YNGgAlzr+rbY+n9vhBDTddTIv5qhQ/ORzWxV5VO+Z4ItwEPGuLZCiZ4JKIxVnK4N1JrDI5FG17yvbBFWtgDgz5s2GsnLCHnyf/OzSOkbOjHZ3HLYDFZwqtt8D9lSWvZQo9yq5qqZcSI25oSiNkuf5JcSiSwfCmFkLlvxyMjWXTgpG5lxK+17E5RZljY9ONbGXYAArzZ0d7cFOqcym6zil73PUHDudc6dIaUsis0X27SSBq4WbNDbCVqJEEPYKZBVPNCavpcj29y/JeefFHM3+dUwubqUyIdePLDpsNKXJ/VWq3b5HdJz0sZCJ74GMYeRw9J5OSWcXIAxJxEub4K0tfpdQd9WGSIb5tBBj78uNeK4/hh/POq1Wu5nMq1VQUHoHlysVFNYssgBKEIvkIoiJwbCDsJm1NUxLkKaQbQjIEPeixX46USVs4hB2tv74OxqOgAaQikErsJQ899TEu5puZ4uYiE4KfyG6X3Xcxy/A+aXpRNNf/USneVIjbo4Lj8VMxrHHt46p43Jn18McfIjhH7CxTCSvByqG1tYtn1hyk0UEQWOGT+ZHkDER2Kxpuqg2QKJoNh6Z4n9TyPmtqGCm5Xd/AccHJSKWXWsckSaazlpHelz83ANhbxZNAyPeHw4QLUpWkn5zrPGo9qeYBdxmBxHYB1mq60luC9qJObE8irLP17p/PJ3PNpiX4GNeX8tCsiaLsB1rhVC/4/s6pBRJRoPu2uyt+vsljBRlpmNM9F3na0E92Mk6Hclo1XDNYi38hmP9olpsQoRORlXbzTyKyVijbQX1MOBLvxQQPRT83scwLyVvKM64prRfepfwgU+DPJjcOUke1FsQdA1FHneuWTxJO9QxrXOkAPyq18L2l56n9MCe6we+7znfGusrWDuxJanSyI+mR1v3OendDgMGEQ4KPsCCYkXBtcVawyJl31xJRSknXXmLVR40BLkzPAsxXcmK1f/nCxvRZtnxDQltplZb1Wp5OPP/bkkhMoikULuOR9QBWExwXmZALoJv6HCjmUfcKsYaKH311NlFyOWQJLeNGscGde4z2hot4pNauoqpeOFdksT7i/G4ihsvG/GSYpU5USMSMFVcryEmIJIuxzP66W9YgDvvDhl0uSHWatUTK6FjS5vqVqiZE+M4V38zngs8uc0lFSQ9l7VIzgcLuFQhtHX17HT1RNmjhcoqoDBG3u1Y9vHr+GMqOYpqOxtzAEDGx+JPmSmZNRbP/SdC+iu2Y5c5nbW99aAP9E8ZNUVDSLdz9QniQNKshYWI6a6j7LCBFK36uL1aUBhog30cdBCMT/IZ09NPR+E6mGy4RNkevgbUhTbVT5sf9OIeFv9djLL+ywZ1iRDbA5/smI95cSwVhuEvWRoRmXlekHruiJ/HKjsusGHXJ2LV8gg31pxVWNpBochUlJJiPd1wk6ETC6UVwKAqFMNIwtyN2SvH6SRj7AztD7xlXAC099hCAMokCHpmlCrLoMQEdpNmv19VSmTpX9B2882G6TgxZQzgJj4wbxmudZYkXPJ3Gpusi8PMzKcFvApDiNO9+rTNsEEFR4a6Akb055HYyGfFVWh68TOv3KTA/MlvIQZjLCLqIX9FdYFQYwL1xki9ccocKP6fmSM09OofSfabmFjtyHHPbFAPzUB4xC/qikSjQPCo7uDLyuO1Yxzj3cBhzQpwUKT8Qvek59xfuqmZF+DNvXWm6M5OG9RQT2/3vqje4MZCf5Q65hyuc5m19ABCl/XUBiUiFLNGODoVCECcgtOIidNYMIxLAMlYs9pnbxFADgZs5yB1hAe7XTvd4Y4ZAR7t5AvzccCanGX70cYiJcJJ6hhLqmomta58hhAzQkkDam/G+M3z8luFZxnKMW7u90ZoGzfNhtTSclpFFxSoWVJT2P2Qrgi8WH42ySJKoBBQ7rZZRj3/rUOn+UnzdN3fISQY5sjgeRuzcta3YCL2QB9x+OixeU5gVtWJX2B0OBDUHs2CcZEwcQ8BaOYs0CsqtTPhWVG+ndjnCuGD1sSBnerNEN4g4CNKvsA1WtwDImpoqlKNGOPhkP5ZKdXlsliMksMt67xKau69bgC1lYwIcVGAnLZbmvbyB7S8ycfAWIY+6xYfbVA15d3JbU2brh0773KEJDD19CanO328rYluXSc/TeX5vrqDWZ97tT5w1377spi7n3GjJovITot5I6UgrTF/w3/XT0+ZTbgWNPjDoc+veJyhJF/q51FoThrIL87HEIxPU6jMFE5qgd3ugU49veY8V2wHzKcwxl4LfFOiEVh2eS92Fr2xy3RVvsyJoncblwDA4SGUbaQpFs/0vodfSmxbObrADqoDo4hweTSDs9eJE+3GdckgRrgvcoV0kmPRbUUnDmY2QCCdNa0yQRQ5D2zBVjujpKDTtCxEZecybePXMAIQkG93DHCq1wJuFfKPKaP7M82g24KXTWcSS72t3a+S0Be+1pD1mDwZx7ePvyULziaqUHLg6R0JOQJKTqI1SzcIMAh+ISipKFIfCf1Oe0DBuoT/GsmmpRlcxnx8cuz9e5po8u1l9DzHUR3GSQpxc+5aINgHlctRymgqq4A04Rwie6r5IUga8o5MD2w4VJTKH9kwRSarPnyzZ7ruMeJGn4JoScUlH3DB9uJbJaYrB9lrwIBixdxU1ZlONoD9aDGIWnwytsft4vKtTBYtRE7S4cPwhik6L60yJq6PxanUIUDLB6o4NHP9ozc6T/nI/7Z+rJZkwoldaPTms+lCvR5pWluMwk1zp5kbhfciJBCOLKwiXjfm0HcNGHKkIY/SXJqjlMj16cLppuLtRPeqE2szbn+A40jBIckTjnbnKAE4P+xuZHzYFej6AoocVFoDAuI2LomImN8Yk1ZmqOC5WPbaL9VZGaMSeQ3DJkYaIViPFq41wEKmtBb0U0VCcRVkdpr3yqa2u+ikT4Lz4tkjtofl6hqlJ3ii94Nl7esEGMxzcjvduCiNuJEQ13ftsSkRnfsMBN7ZZW2MdK39zdtWTGdiHcKx/mPCIE5Essph7Il5pc/V7UcXdlR+221KOz6UA8EkNDZxBd5Ut2LuiZ4b4P1n4QC0szlulnVbsMqG3TY1Tl0kflK8v3dlbeVboljZ/k7wYx2/IzqgJTnFWKvTkYsJHZcpIqnpUHyQCEeyn5vjgZNfk//EmbkY/AH6c96xMjkx+d4c3FnS9FLeDeSRsTEqSAvGvkn9BwGxfalHQr6BSIiDI9W250UB1efUFBvgrJ2lTWgFqC7BCIuiEFitjugFNlsaSz7RDxtmPiCXXHWnxigd5MoJgX8WRDsgYec1mMeFphAsw4bzc66mVXC0uqsnRg5twyTyLe6cyCe8gTfmKvPspoQnq/hz2ret3a8B0u6tAOBlh7wAeH+5LfEzHss9/gAwaoUzJE5r8b9i4blMmy01biRhXHOE04k1BZsYzhiaW+Nl0XRM4QHuF4LPe3Ec0kTwwZI4/CBKNfrjiv5jr0VQxJbrQM8RVwVDPj9RcX9d/0RTOtyMan/BbbvzjKNK8MaNSoEcUvtnBv0+88madMo3EG2DTxwEnE8MnzxdMjc0gYcaYnlGVz2vrkuKc5YIyM3Dnq5lltXrjHlx7jTn5LcUn05US+3POJgHLFDMJlMQi/50XS0gIqiQKerxgL8H65fa+T+snyblP/cG2Arwjwoob0CyVurQMwd8kPLEtheBwZu6Qv2gWwHusqqOzyaUPi1iJV4pjbWMrgekQdxpo1MSm8+B7C+5DiWX+3I/Ds28PUzl0d4O3Ry4vwSsq7rDN7FWF4mpA+Jx0VakNOuhu/SMqc1cEqEaTRuDIr0evob76FMagTVnIYmIhXClUNQp6xWyBu/gBCloA3z5O7ENI00bmKKEj397nGFytlDpmFg1ddVbMcS7Q0PY9wS/YLMeFDKt010QmX2+9Xe52XGmnQ6dlw4/8nOr0GPKXihSmhL0ID8jBEEHKMfYKgz8RyBhn5tuhb8jLd1APGLhRJrP3IEyzMhJS+BywdsQCJ2SC/6aPvaVlGpxOKuU/RMCwC/0SPwpnLYXx+DnV+ylc8i1380phW7K2jcS6icvc+Pi/BkgGPE/LUzbg6OkeTkHmv8GeSPF3jxfY+9/3L3JvR/FGClvAUGt1UGf4Aa2P8c4oWL5I0m8Bro5bQqavOm0OQoUc8yCmxtukzr4McCEPJwd1bp1EeaBNz5T4VGq7VofoK1GqN8HJBsTKW1XWcfhQyx3AcRsVRFPQfTsj6PQyLt7ru7F48OAp9vY+VBgRDf7PY2a0CvNawybPNjixRw3oLI21YmYwin7a97r+WEYKGyDPQK5OC46QuhEfeBMu0ep9WgNhc8mFpIqY9tqFed1RuzL88HEjvG2mqILTeh/flAKMuCsUpzf2BjKshknO0TiS/YbJi6ifugQ+Lq5R4iLFMmkkFf9S2hR5eg3Foy9RWQvIdWpT0d+rCbb+51sRwFeDi+YXvePXfn5GZESH8F86CsFlnEHqGDCpRJFOcnmK26egmx3D1LtZFGgAyuyzEzONwfgNu+m5A4KltslRkFqpOD5pwlwXFCJefU7a6d+9hsqhrEDRykTx0F7UmxnrE2jLlHwsbkleohg24p2Enu9FpsUqk0CJGFA+XV0QJeSSgAlyXDrixJVbXPARShO6zyr3leH/6KI0gUC7Bv9zQAW5e+VBveZDu0k4caOiYZloi6veCWe8J9YAN+rHi3V+5Awl+Vfs7uuI57bjvSeYrY0izyStp+YVei41/j3dvOMP8n3vIy216e7064m6QqGZzwxtNAmc/xJIhhUynO70DVtGs70iPX5+b24NeXvDasJrnnAui+2rRAR7EwKsbIHad+nyAPUxDndYYrD85HDBPlsWoQ4OBxk5PX8TdRnzHrtxp8EVFYGF7l/PKY8D4BnJ6F7AK/xfcpVfm+MBneft7vXv2x4JRF/8zZZz8ylJUn2erR1YaXfPNPaD1/GCgqXXrE7w513r4gCKTgWOILb1fWnwJwUyNlhayqR9BESYhG8SbdN0Zsr5z49zBn5Qaf8DxuhEWbfzXz+hwJmU1jQblB/96won8S6ewuk5o6TkHo3tmRTSTM1H81vAsCR1Nz2Wk2P7IiZBPv2a2h7nyMwJK1u6MNW/BHJ+ZdSEEIzTkDlZPdgt9AfzDnwAPuZrO/icdybDYX2p86MsFP7ZI0gPKwRUR4LK3UBpisIqc/1+cjPowp6wp/5NJmQH2UWuCZzNADl/hpjBVYIG6jnKeoaXZR6BwkocyKC+S/3I6VPBre4mg1FDsgUKgTQfH68kk1JMo/fifEEd9sK/g1YM9TzIPb5MjrIEG2e8TeQolf3r0vhiJEDYE1TwYZqGeXfZRD2Ar7bFrPWzjYN26y7RhO1E47EBKbZ6cJLGV/G0vA/aMmWJ//Y/IVd17cwW7p3XwJx5058zRM8lCK6J2mlt15ISEa0uaKrmgmtpXjtXjc/VUCP2QWrJNL9OytpXhLefufgSeWQ731IrtWrmvEu2HpdFTjXrmCZoa11Diuq24A/9+JHHK4C5i+NOcTQt0Fi93iQLqLavACJSzoQD9edD+1F7ZMou5e+zI2QlvKQFEeQ+pMyCNeWLAtK1E+Mk6jitCSqnRYgNAGG3yMLGWv65g+IqDzDZWYBWsAO8bxHpLdy1AoK/SZLgwMTEQ1lTp6W2208hjD5oE+g25sw3xCgS/Q6eb2dXF6K7QC5j4gCr2zsalCH0Lbgir+pLqWFVJ2CJJJPX13Iznd1tssQNOCn04F1RWrdjHX6hgyHsA3O/8dSGB1pMKlRtbezWNOz5qxz3ipj7Ge33nrgLfWyC68/WIaGLvf2Z2cM4rJC84l5harjFsuoXu+1Ici/TQkDsNa3OcBBj621TfQogBKfcIhFnNu0t5hboJfDaiSeqD9mNNgugW1ZzwN+ACILJAR7IiVAbnkT8FkMIlQ08JlmfThHrsOqWhamUBcX0OEC4bzCOk6QgGkHZTHsMaPcfGyPbYzj8whGkgMSdWkb11phhK/+KT8gcKNQiLrbue5yV9IYGIKYskkj7S88RiA7+w1XTXCkz4q9CDTQvyo6cv1kd8zAYPHWhaagywfPqZIsn1J/m0dPddNxRSgUoxdYKryokDPsQmm71Rk2lOKwNhCpQJywDaqObn48wIGxzugkjycV7S6gbkt9PoYT9rJbgV0JVRQrO7E8NI38ZrKE1BRbVfsGAyOeObhcXEQU1aj2mcySd5JYhqiB7W8PWRdeK7TELWIvgp9PHQu0PJjeoX39PA8Mx6dnzOA+0aRelTDXUmtHlChTlgzSuEJul4uqtz6CwEKZxE6A/T6smIYew8cvkcUlccj+Td7RhT5vbF479pQ8rljDnVS0f2LOLSjbNwOYwC1hov9jjv9EG9sUXslPKeTKgffX3rOrnE7/vKIpuAH5eZYtLrL3ycTG31yp7Pgev3lmMXyfbpq8wp3GW1SHa0jgLHADOoknng5RNIKVh0sWAQmWu5M98kHI7wRZqvnIjwwR1yU7qYYTWrGW+6fdU6/noczv+DrRvu5Ry7mYwskSnKWgSitCgGcPcjayczd8S8CGHkvDYuM3zJRHYneQoLFi5ojr8GK+c3TYInrrV+4LYCY5JLsOhnQgTx8ppBTeE6v+F8WDQ4MbjmxI2ljCSRohoK4ydPfkOnLodsCmOMMCXhgwaU5szM0r910EwwqW0fH2CHJ3tOigJ7kiSZ8hDKQojFJsK3FkzahA0uflrCDs3CGRlut6oz5KtWvu7GnnIqvjSdIeq/EMFcmDU176lxqKhgUs85aoOk0QBkN5Vho81wu6+AQPI2P2PVvyEif68L/VywZMsYix7csHpEB1vlUDD+oXc1nmUGmJ5shEbLli8i0H6N5e2U1DoaHuSc5oQ7/RMol0HseHtgKC2c7LH72y+oizUZa1oDJr7GhmiPCqSWeBo48Z9fUfPil8U1nC/pUH9JqGuvQcTgbNjqQO7ZpXIqhhqnv3Shytj2T0i8CqigQaGAiiQDeEmV9uGZ/IoIrIVHd95sBdxkMOJ13rbhpi1WJYYx9n7rBPD/hCYKfHDxIvuUOntPdKFHDtju8iMPErw/V4atd8UH7G7m/JuIJ4IKvPUvP5/R5awy8KHjkcEWO4v7KVn6ISKtSdLoHzcPej6BNqX5nJi8Xx178hcidJl5vTKACrqDJfmqkjbge3c1xKQfbQtDkpMhvK3qexVi3TzyT864bGOaWMZCEGhtb/gmOYk0VzUmOJe9FlLdZbxh5gApczcIISWEj1ZpVpWw2xMd10M4jvLIa5fvkO4fT0iWXHpttJvLGk/m0lrYG7i1h82ysJNyHbhb0u5tU8zVpwzQQ5yoF6hIVPc7GDnV/iNRaZVpi+VCsRhRXIQjNEn9CwlcSizp2z58x//y3COuXf5gw9Jz2s+OxD4SOvpBOuByQKUiE5/WaSAhA8BUjFVbmBkdvYgwd+z36HNtk94Tr3ny/wjGDGriCeqox1p9Y2SYPpFdc3X6vJzGRSObnaOpWmT0Bj2Ziuq3Aam3xMW4aHQBo6VhV8bMdmYEcdRPyI2ukDYrX1GXSv1VJe/CirDRPNb5jGaIcSsmcjwIi6NKn+MpOISaHBRi+1OE62AU1pWk2YGEJpuPJcpKSwseqry6KPHxs4Qy+QQZmHLZWF3n58zJYmfk1vSfyw/oo+axiWwbocPn1LTmk3wpRLrm//DrA2U+NGaT1faSLiI3VCzjVzqrsleEx2Y7btg9aHvxaUs6pdeq5gb364d5l2t66xzLAXNT2F+TQ+0uvGk/djYq3anvHLfY6ZCvasEae3WhaxMsu8aXmnBSFWRnFtySj80r13Fc2Em+Kp6QJtQRyKvpRp+f1MmYhqD5cZWHCJ0BFZRDEXOl7zIYSXjqIONH2bmGiiw/ZndOArdNMjV7Q8sdcGZ6dHrf8NtQ3a4iT1G2BZjelEy0b+pLG6hbuSyDmnLFCtbtQ1fUjkPkfwzVlN3Yq3py5JxwhVtVDCeNX/Pe0b62iPngckCdkJapw4kokl75FGFuZKFf8zpZD51X76nIYiJ0whqAId82pdm8szyIfYz5Cn/9Ue3PDHNRXa866idoscviNqS8wr+0eRFOSoZy3oR8CCA39PHcPScO0XdmIDWTqQ+YHXoDfo/99w1VS9VQl+0Zrn28LsS2KsLcbVxMnqMcOIjAh8JlELUCmB2QnfLMfpIeU2Vt8JTv57M8VL02HdZ/nwbPzlFoap0/Ow3ksIQ7LBFYr5folrwCOGtf9vKLnd4Qc7nuaRmQHErfWmQyBGogzgNQKFO8havcwkKGayP/FJjmim2EJrC8R/SxoJ46fsVkn3Nm3UqVMCmmv2muHw4tLrcWINM+iiZIFbmhK2EMEIcXuMajO365HzH60HBY8x3ZvLZCx+Hi9VkAgZvDB8HYoTJgh90hr7Px6xJs6F9QyjsnmbnlMFBnJkh6hWhd5TaZ3V82pO9MnGQ/zXX/6Ew6ea+fxFf7CQxTGC5uoYQNvfDPxPVLd/nQIrNUNy7SYieCVypd4UElN63y0H/TA3A2RTgV8agBmTJH6T5KuBVRPdR659edEWECmlOooG9TRPQTvI/e933fT5WlTJ+Vlg8kqKKvYVZ5QlcX/Ys5pIvwfIwiA3lGl+aw0j/ys/dDW6jg5JCX/A26m8a8YTlXnZTxeVBui4Ag8Es4amSi7AQibmBl9i+u7OGE1VxwnQzGjS2aDvcsgJFH8H1wtHuhH13zvo6yHmhF3UfHwM7vS/dnL5NRIcQKk1CrQDeBDtPHQuZrP7VrS00f7mXcueVQ1xJwDDOBRjmYBg5HPH8XIc1jIfUThtEs+a/ssAkF8SoVJnvCYrsMPDLFnw9IEJw04nfYDc4y0TB1Eb9488oDMmw5ANDADf70cJtqt2+SkOVxVIu/bWGQJY4te11xPxZRmLj+ouVKnmQtOj+PUvoenyi1NrEgMqU07VidmVPMwftRVHJ+wa/yzOevlcrqBZc6koeBysgijr4QXMu1LMQ+1fCmBEUOyGG8t7LxZDHJNMBzf3LoK4l1VHJfvvo5mE0xDAnwSdeYAZysrrirfgL0iO2gDSCC5uem48nhU/te0v/5HteDo99qdLDeILD0XfIdEig3Tu+7iDFaMK4iOr3l6dbh6VE5XsH2VD1ue9536BOTdcrK+BoPcrF6rSIog+Tp4oJqAyRPesTjvsua1Bek8GBwWod22LMLoXM7nP0e5//JCiD6R9q5xe/BBFmGpdf52ruympI2GKQIz5CA007D9IWqVvlHsjQLMTHQEoxLVB5moHYWk5CC/xoJmq5cQ+481ak3QhNMQrTuBQ2HPkvz6+gD68Kb6rRkXxMXTVxaKrTD50a10zg7SiPJtusQzcChAfhWDef4VTOGt4CQ7X5jxWZvq7V4nRtG79BzkGxAu7Rnf2sLoCqPWx7I3XZASKczgwtEONO7pyp5/PRxLjZ53RxqdrFNLFnvcBCBWG4ssoZZt02bBlbenF7iel8YQZf/mPmNPgBEPX0otVskmhaPAEVm7I0UfdXb8eZEVK6ZBJNFA6y0wKqsEmjSIoyK/XfwAYuBZc4uXn3ECSPyoB61olsHBO+x+rWure8bWPhpCHIRiZOPnXbhM29q5Hmf+BFTCu/JTusaGD54xE1c24EtsvgJECO/y8DsIC653E2AXm1G61N1HF5Eq892nzab4yVdBrn8xes+ZYKzmFHC0rghmaYHIrQndGV75B5DhfuHRm+KXeuU9Y+neVgvT2G585eqvj+RcqVL+DOdc/t91OQzDpLM6PxRLPuZpfxe2uEa/Ye3q3+PU5sXp2q5SuTGNj049ac3FGhqoPC0dnSFJE3IHWX5RYcaKNSubtDaLhCyPaMlvH2vux1HYsDrm/Z2/goU2m5TtlG1bZQOt1TP/OnHjsudVMEXBEJW02nZicvGnH6CUfyncG1yUfOGx6hfQDRWaBpMZ56SwuOHMIY0J03XBDiGzv6iYemjH6zqqvUv5sHzERzjZe6OS34vPsC3eyTF/e6nMvjebEgglpXzmE3PleIQs85ijcI2OcAsxN0AP3l4sefXnPjw3a7wrJoI9QUrDfQ+wTshJ2jPxDFmh9c5GCIG+g6NJma0NW3QVtXeDIFbt+MPoUGrv/1c00/7sFDlsciFGJQ0tnqS/9UBbuGiHPg0NrY0jgT54Gi3B45gk3NTnJFY1Bgl2JXJWi2eO2C1mYMilFif6DcM4y27jXbM4FoPt+EM5FHU7QW2rr0VD769xmwIP73YRSVgP0cBHxp8Lw2UfdQzEPg8w+9qtHwHUnsUf8Xt9bJmqk50zzVKG8qOmskF2l3KukToOtTlCSs1fKT+bl7TTd5anr4AHF071ieTfORWo7WqXwwLq6BA3NFy156sIp6AEjLcXvaMh1xr91bQVsJ0dK0mMPVvRbIXMpmuCBJNbGMTEyzbUZPPaAM8VeNkMyulOSPNwumxQybHwv8+CXdY6fIOfMwJxaBJlLntlSyL9l4DsvN2mdLZLDUJR9Knj8z3TZhfJqEII3nWz31hjO/47vUm+pRH8MB1DAwFcJAuYk0sg1KRp2wvDYQPINAm13r4Ahs5cKSKPiB8RDO3+QhKoeY7TkTgQWi2tqTRRtjtQks+v/Kc0ab3h4klHXPM4mYgqpUhlLetcoOuwX/afH5qvyYYtXnp0h5EoObEx1FzmD9rSunEGu4STaki/dxegqe0ftVzSXILOocEygIwh/10Vyy5GAUT5LQ2+UMLmdEQDBmjODWoK5D0AJUQ6igbjZ4yn4yuQ32iKx+5avvd24BxbNNeMByW51tRWDeGs9WR3/P9D0qTDWQrWffJGgWA+Xb886pFHJS/jZ4ePXhxiwd7XU8CMI8orjTmlIosnYgFvWX/7f9NW51oDmGPC22xxvjxmJbVJNMJuagAZLAwZVXqwJLiUGfDuKStLuGSdXbvoqxgwjCy0ZjbrvLdggIFjhDs16IdOsPoMWDxR0Y1eHdVIOPuZ+FSi215te1NXyIPg8t1gqyB0+b62XusMRq/79UzESuKpaSPsg+3UNqagfIlD7T27MVsvasUte4Jhrjz2j86l4Omb4Q6cDU3Xz/2QFvhNj2fAcbpnzcyiRxFKl9HO09S7XdxLf26N+RFb0Kjb2lwSRPbPgVhfe/aJbxAV+v5Cx5MzCvnnP1OzGGMO9u6lcZzLyMjO/wdEBvGd/pRGhKKRKfkBqRAyuslbnvCdzHnZh6NCzNrXhQ5lH14R8nz7z+MxnXYa8zR3TEnQu6MLfnaKDpw8FOmUyO0uJ7BoCK0TdVmw/8PmKivQme/N1MMQPrGZ4ftQ+Q1nykvK1DsnNYbPbu/qH3y3p1AT8YZHzUTkvmIIWr7UIJbH/GgaMwy7u8FfjzyjtrV133p3IhkGT/hjVP8mZXuDX5TvBt3AOIafuv3bI8TEFkyQvzJgiUM30RX1PNKA/fhDcekXqT9xrdL3WO0FIS4XBPAMbvdk5EdkbUpB54Bd2y6tuk2bDvuoO0iMZAcKrs9Jnf3Fqt5nUxuru7Kcg2g8c2vtLNnidzrcjxI1f3ZcYs7ZC0QxOo2r46wxBSnkU17WcvsDZzp0hPmyGyffLohvR/2j5uGeZ8+rSdrqzWzzLWFRmI4+GikKcOryH7wY92zLBx8QP+j5xNMbox9a51YFIRC7eJTczuAnKEi+jbbmjpKywqwizrziVSmj9lw856c1Xpcf4oob4h0pEVmHHORB9DyJutEatfhNjtIHdFXOx75XkcXliUzLRfHh5Eo06OTYj90DEDpYeT3+eycN2Lk8wgNedkDpT3YhJccTHp9nbuHZhhIePOtHf/7NoQbYsSyMythaxH2OklX1pWFHKGo7k/QqTH3Bo5j/5tIf2AhEJ68TGAnl8cClS7CdnAfwj/sbmGwUeoWJNRD0MNbnWdZrjZMs1tr8yX7Ms0z6rMHBa+bT8rlgyvtgoOfdSX121tNxBWJIXfI8gdpLrBr3zZUbN/bUZdG/o0BrDUEN9z51lEDILCCe1U01sX+3IeWC0MhUXOa4fAbDE9/uGIepLLuI0dG3sYE+dE5lWYFz2FGzY1z0jW4B9nb3SXy20DSXpl0vg/8QuV1ajSUIMfjRLisIoGsldLDGIfHcwpAh1FiasNkjCbcZj2Gs5yzw74goTCFJR3Idiqeb0PQVOURLc2HE94aimR4QWy7mCVJD3uMXdVtyowNbAUGnhG2oD4lD6i8hR8nq9RFoH7TzQElrII+HS88kJmD2WLhKBvv2/wt2yj3kF72FwUaGa0H3awUW2GUHcsXg2poYxEVMt9wgviuOBVGGeh8BGAdBls6nzQ+u1MTPEj6ROfr7+ct3qGPrzwGScaP/wRZlTpcJQ65UwE+LkiOpmKM//YVP2hCF0RXQGfgZmTW1SGpSt4ZDdVmm3tpL3DBygS6dqQ0UG43kLfSl7xoGD95S4PyXrVc31ZfnJa18jjQDoOCm5p3tO0/PXIPxJu1mAQapXIRxDXreEt5wbJSiurubckLz/YO0j+A35XyioA4+31iqwqx/Y09fmn+oYuoems3x7YJ90xE2n5sDU/putgaO/ueOMcXugIqCbU7NkW7TfXHwZBGtKPnn8YtTlugq3b1wNZBLUhz0rXR4MmqkeK1ZCo8+/5x42WjRUgetK6RKZ0uHWrzd81Ml+aZ17TCVKcDNAYaDHEW+j/Lugp83KlZI6YHRJzzeCSrlGnxj/ggCR4h04IpDBlheVA/VosJSXzUx/zPg1mAZG/CMifyFZ9poJk+GfzWhiLzRP5ls9n7MjXa5A5h+rkpwOcDr5/ssHZAK3OHgTIFA6Cb3UEJXqygL+kf+dDgSfIFyYP+L3OAuHcQrmTTSwve1vcyF64x57XUVifmA2D4atchw+Fa7agspudU0MY0axCr35r1fnNSTe+M4pkCkKEvpqM8sdfjW42fsh8N1RvJyVo3uoT3DRjHtv+NGlYaKQY+SnF2a18Eb2zLbFLvvmQyG7c50Y1zTD2T+mB2i7oKaxUad1+yuNwnbqwUVcvy4Mb6c1AcdoUYMOCuZVkwpBP0qH0V527iVmjfnnJRaNhRXaajhBkXNFzRtM19ju1XXNBEUfxmdB0z6ndL0U0RvzUbO/4McDGNnou/cacU9qDRhRIJgVLu91GYk5PVS2vXhjmO4sJKFd+FkTNHENN9RhFbPw7gi9+Ep68+vef6gnSGEbcbfBFGmAtAGxN1Dk9MWhS8AHb37p9TrGVnsAdAiM0Vy5UsJtUcr7mSlr8G8hFlwk/EDueMqFSywfnBXff3xLKb79uFdhwKbLFjVxT4SLEv/tbaisQyyNfa+JYFgzHR1m6lnRgJv0Sreabytjvm1jniyy0I6h9h9AhABDk+7cSA0Wu1K2qtmhghbsCZOGKm2o3+2cFotERUGZfXHbH/nijZl4FwbnLCLkvsWpxG2ee4MfOawjunYkedXrS7y8TPWYTt0lI6xpIAMUZekoJEKody7iJArZpdZ4UWkffMj0+2SKCJGA1cPeaic72RvRMuhu2/wvDiOuwxl0sszwiL0ACxBICOhGI3P8PdcwjB+AqVAfEEg6eF8AnpCgqbxmKLYYirrNcYdLPYuNt7wOvsmAuWTqI1bOWj1YX39xlXBAimY5nrOKZ5hwz3ks9mWkPCJCLrjw4VfdmvuXX9XN9BWJ8IPhMee3qMxMv/jO7Vwy/D9HxEt/euCh7XFHWeHJRyuWlPFj60s/hF4oOH6k4ML2MO+ZAuACok4FnFeWVHwuRXTVVBSo+lBmMYi+SVNz3C8wYQxg7mC/SDyQmVAcNpwkC6DtSPEVbKUvmrKpzcQ1fGG8D/Pbc7NHZfbybFvFl4w6EEF6bdh0aaEeNtcHOUoSS8fbrtsSKppGzgW1X9X7PiLLGvERQV0LnpsmkrCQXvGbMVaCg/9b4ac8Xja4u0tYpL8iEY6bR1Y767pG4MIh2UpKshIPrRLpc2QSgMRURXDgFqGHh5Jm0WJ6aNUp1KFRRQjIbsXGiLgSkXwrUVMuPZRecIfAfjXUnahTCwU+tfZ8Z0aiBozFR+xDUXEkoFpOn5K+VDdSihxDHHzPUQP7e/BrGLBMOAELik6VKPaFWhmw+5qu1ZuhthBi83fkQfbaiaSRFXx0JTkoHbbloOypoKtbGiP90B6hVNXT1Fyhp91FT348yVGGfqy9OR+2ESFcvfFSZ/Gpv2ZLkwvKFDlgtQCUBZFTUGh8qZxDqBPVymBhMZs+hQcy5Svhe7nJNPLmWmtf+Usmh+nsSZKVkJwsRSVXk0vyF8vXL9iOrIIxNCwsh36HI7fIXSa58GM69Lhpy7Yv9buTbDNc8gTynBXvpyrr4QHc4rlZR5p96THSCjH54q7OpN+qF4TiOwsfnWXfV0BxrRQZNP3Z8WVVl1g4W6/MvsL0Qm9ufJKZqAfBW1VAOjbM01g0Mu2DYm06vnUJqFABzfSDEiXplzzBc4l8GTWpDiHtdKSVm/zbNwxpiStR9uXypCOAAWGBH7odA3dpPjOCjF2YCJeNhmpbzV0QO4pCsbWlf3rHECKVQPmqO416umnnZHxfI9Rtt4EHVXYrvop4iYUMTq3uxQm9d9VImz8g7/P82MYJOq9/vAG7nZNwIC5Ui/YbWKvUGmhiTQXgXsfdo24ZH/a/SuYwS8fR4HWJJDTuz1FI9SKeE8/Lb92+InyseihYoYCvGh5k/WmD1VnaS4uAWELEymvhXnSdertmbjBCIVwNlhgXX2dKKBlqB7rvssLvaIe/2utMcQiz/zfenGgBeebtqujuP//4rQ49AgCQ0/FtX349u6N0x3sOItjXCPyjqAhJGitGMtXaGoZswZrRK9JRdGEnGduGP19l3XwR0/1eg0ylkA8RMHK3zK7X6GVbYMnUfQyHlIkBxfSpLLhvCcx+1q4g4F+NGgp3u5ST/R9LDK4RDuZoroT/nsm1dp8Ou0VqQm2kfy2x35L01M8Kk+VeEYZwqs7m3fAgzfTwW9OmngTL1h1ZXP0IwKrzRcGh++eTSy4EeAmPtJWtvYVhtlF1sDxzDyoBTgZ2ToVwdeSUMIMJghRi77/zY5PhNnTymn8RHiGYUIEsQmgD8QcrrvX+ELfLUhDpKNCrP/5SiCn5KUmTM2G648gwQ+c2g1O5PBSGa8Lt1L9JSREaeS2vl5sEOTyKdoIOO+ANwgqrOjEQonKgLKgvH+ChCc3PUxBTyLiOfvB4SPG/Wv+htPPYNXMng82Lr8zWSDguuuzZ6F+14bFam6L7jEpW/M33O/CxXCltc28OJ70bUE4S//LEVmpa7nhiuYLhh/eIp/Ds6IK7nG8uaC93zVc2WZJbb/Scm55JY8kBZVuOkD4Zq02PAgpdzbw3qI6BrKYLfPhjau7TuUDwry5M87ch3s38UBHYgcaldUTX+p4WCR9pF5z2vJcHDyM+JV/iba6DohbhWgV4yaH6sB/TYcSB5oeHLUkU9wC36z4Obez6i8sBbzIiNCN/r3sXm9wivNY1uwFsbPxLlOCGmh5FG4ci9UZQWM136q/Oku+CjKiSqtjCEIPU0OlJSULuKxz/fmA5rBUEabImG7m663JIEzE5VO2yR1BDf7uiE7w8vZtAkSoWRq/Z6cHPceDUT1ImRZ8stIJ35W27lk/OCJrjmn3WaQrJ6HBZFx6m3Vb2nEPQrA/tsEsIa+0THb8nYMqJnHMbuXE1TdPKv/Bcq1SVDige55J6poOEG0R+fB1L1X4E1Hqi5rzx/+NCLnysLjdnj8185bWpkn/Lt4xSbkFaIUTs5PVL0qTCgf/aUGRh4XsOrkgSqxBS5270Td+k+mFZ9MI14HYLa8TqLJwIBM7QyiEYS9ASjeJZKc9ROU824qy8acuQHnuuk/wQ82MsP9ajFlFtth3A3+AznmDhAgDi+TIR5JXeWMalmGoxiHOMhw0AsVpRZ8+W4dBqh9aRorCAvNVFljE0TAoM02aIZuyVA8VeT7K7+vmC88J7P7SjhKbqRYW0XxwzDg9FSPVnClKyNzgEvafc6ucLJoNXIOzFIQqKTDZMgQinbo4B4JJZ6MPdFa8rp+qPivqMkaPKNb8M28ySD19rEwZ/pK2Am4Iv4Z/6NzDkE7r0TqRFeBLGzBnQdBl5UxKH4P/BNIIKbRvwUOJAIA8KJoCf2m1LT0cGAhGEeLpArhKkiBj2DEYD0D2sbX16w1f3tHCgu4DKo0LUHAH11c5/atoFFWOFLDSVnG2A+uTF5NCPdZ7r/1dd2qgnGtJtESDLgDZPYpPRzWP7SmiizdwT+gxBXwS14YEuwaLLImssHPv+o47od51QrxfVU2FV6NEL3QghHAAW6cL9+2Uc5o5jtfcoTwKtwX4+adjseKLDxmDT8gXSPIoh+/NJUa8RJgL0LJ3pn7PkwfF+aRHBRY9QP6ceW+Q+2uv0vepN/4V7VUb6/LJ7eRm58pl0sRvDaN07s35+Cw+BeFoo/jkNtrd58L/7mAAnmCFE5s60nXRMqB4c3HVZoRvy800KRYjkJMFqGcDp7aGTjtylbb99vJgwa000+RJNZgzGvAUfY0LgOMFwVk/hNCmmhAjCuOZAvzMGGCslvGwQgSQzcSY5uoGZk94PMp2vM758Jd/zgPGU3RkOvEGEX4XPtGtxy17x9nnDgRO4j2mb/G3KNSaCLOhcKPTwGZz9yVTvMyZlIBrxJ1ZnXjLlKG6whH177HE4e3cOuBD4t1OHJbfDDw3Dmnuq3y/TCIfNtgo+/zbqQi3Klw7rSDXl1fUdPHN1LXSVMjfkhAg9PoiYVhguxskl6SdUV3n8Ij6yXlZCSphP223OtxE/+XjeO3e8DjNV0gtVWLyTG144lw4dP+OQPAKolmGhHIvD6RfS9iT+IxqKpHqFMjr81m3b78qgwAQTeW4wJuNU0XYN5JGvCZf1ggG3qceqZMtW9GuzA7cVjwldVDM126TBdH+zU0JlTFunRltMhJhKuPR7Ripl2rD4CtjB++IXPxz1WrUaP+jrRKkxAFc64jFpDgOeUkPt/2XHsYPZVe0Uva052TaCT21dj/7ZmtnRAKNlkoqpDfOiRnPuDQNGxAZthD96MtLyVp2JOAYsjixAKzaFXNhOcGmj0bg/B34wQP99e6nfbwoybLkB+QOlT8ROLwyiMjM/4bCDSwapFVUU1953l0aatAWVoASCz9lMINJlozkqzX65Lp/OcXGnidon7zHnaRmlvVALNHAZVPN/jaMpwWYlAWA/j8SYxeVmOVe2CWWB2AAUwFiZB5YzCO640rsGAcsGcnJSsmgECCwEk8w51g4Enj5SCGqxCrvoW4BPHAWM37WiFT1/cHy0A921so6LoVCYAfk2xfxVMnpqu6XQWGuuNnATc/ddO+RaqlmnQtB1cmd5m8nDRKucr33eJvpgdtG+PiMyCpVdv0+1Bop0nEL0fNc8lqWLBBdODVybJTNyzaUm2elzCTQqXEYRPWRcwq51B5tF93I9/mc8BL05E+TvFAgeCe6hxG+kX4akhnuHD7D2M+FEztcwH3Bdjbmmhm66bwtRp+ifKgCYwX2pdXxXhqn1/WPOdZo8vW8Or5WEI8/DCXTd7fl1rWcBDYEpr0dCJTPKljBaJ2WLNIT5GRV/nwgLeQOJMUpbDdSpM8DOxyLaZYxZ6hnkw6TJhp5HeZGyUuy5oYbYh7bE9WO51bcQdWbqyokR7FoI9IBl7ojSQk9vMGThBN6FLI5vO0azkUN5GCLsPetcZWvQQwRO+uMGHazQfngqde55ieC3aKOkz+1uBEQ16e0sMVRySFno/3K7IJr6oiwocxXK7QDp0IiXXROFTVTWtzGD6Z69oBSPBxKhRb//d2A5XBtAtpfNR1qGYncf4/YsreQUcKYzio60xX2lrryHjOt8srr3d63wnipVvg8nBaW3jINao7T30ixtFQ0kb0KxYNcxUqtbyAz0CEj0/gb80wBdMd1kVLHiSD+ZbSZHtM5x3sP2/hGYR64tmhmoakFvSNy8kO/rJ5ag+3B9twkonPRBmnO3oDsOFi4u4sJau1UF+5u729hLPjO+yKnVgLFJG7qsFCRX0PnGEl1MHZg+M1VdaYj6V3ufP+RsvX2dQTpSvyPXiPq/UCoDNcLfoyyoPU/krJIdfo61Y6yLplVC1YHGGoXllVoSUK9DKkjapylI4CQ8cpeYxsTl2g9muM7VWXcSNgr/4sHRaM5nJ4AUvj8D01514/E60H4wpA9EOo7qqEt8ph/O7CX4gEPDmlrKyQjROg2kN5vvr1AgfAOwyv/JEp+kMuiNBql4YplbvU2MnYq1JJXkgcz0QJWOpaxniWo5WfH4v9ceAixqnuBrdYu9XlqZC13kOCxRRV8bqHJd/1Twf/AupBEgRONaV9V+Rd92BVD56hct74kWkBJfsFGwCkWTGbhaIpRPa1y7R0N33MJxOI1o+L83AcPdLNOCdRwB8dUTyhICjYJ1z+1Bw3B2F9zzhJ8f/Z+rP8k4HaZIqZpQ6n2yG69u+7zxVGC7HTT3reHs3r44eJAHLrnu6wZAWoJLoSuQIaLizO3aldxRLlYva47ckJpWVXVXUQxPsgxRcZJzMJRM2r5LOpLnyPow8069NshnyldWv6pZZ4S5Zyftrb5bHNARLrdCc11IvZ8NjPP5Ki3ggA1Wg31PWG3eK+YdVd719ifxt1tw0CxTbrDua7Y8nfGAR3gWdM2PEiMdKBAz2wCBxBxdk3rkVLOd2dJJ9oMgR/rknhPpdEQMcWxAaUXzaGsgxpyT4z1dKH8Vj0tVGFxIbZfSUliVFnKBpraEdGX/TCQGdtnlCBY1IX6/AtoZTCIjDA19n9WFNWTQxPiD94D4+9gzkwfKCxYiUBCmv8C2CvvLYRHcdEI7MIPBBxJ2qkZH14HdHT8wSuqTRU16V+iIEXBeTmxjHO/UYxwWqCKTR2Fa4+HwwwjJIXwA7OzN3whwVsUBC2xPITl5yAC4FU8Ji7hL1KKC58FtDEzvU/UulWT3ish5WsIbzplZnAeHcPvKKS0Y2JX/wLeCrRsi3tC6h2l0ZWxMkjy8ZKqt2aQgO27Cf6sZ+O1g1N0VyKwIbho4YJ9X5xIJTpNwFbdJocsf2nFKs/MXdIAyxGHbkGF7R00B51sBbjXwc5BQeOsAxZk/g+NnJW52lhi+FMrVxIDmb++hrt/JBpgMUWef3w4Q6Jdhpbra5oh3biLeJk9njFqSlz9nmWqb3exPnUGnMWRdaBvd06Qkvar3ARvYlNWIhiLpoLsmUiL1HJ+xUaU+iZ953cE5La+ShPPMrHJavelVGwx+jBVHatviOgQ0ythz9MNBFGVnq9gwl3F04rG3gBpnpXtsJMvrOZUPUjnlJRcTNZeBhEl5ppzOBUJLhxyjZSbW+TE3iQ67rm/8342Mt3cqYuAxyLh20yUsDuaha0uCYzxv4S7vgEY91F9+RzxOw+esdQVe01SpV2nzXl5cp+2n/QWQ0gKZe1VVo9RGpH+soqRuWFc/xiiQgRIbK6L9d43/pwDTvxzgJPiao5FUHX4Q2k+N/7z4W4fvC/4Qus/ptz3jDc8gCqHRdzx24Awrx0nRiJir0pDrvWq+QNloDbn+NnjXS0UlWZKgn4m3BK+T+UCosfs56WoyUcbWDRZvJrTg0o0X7KWCMmD4tZ09EoEgMd/CMF/90eseTKolMXjL1hco79K2CJ/7S8eBNh/q9SeJE31rGrjIw7TpQgINcZwWNTmmeDaqN8qy1LtF+bHB9cMCmK9QSE2HSGABUT56rkQLTMOlbOuaFp31vEnQSRG7nQ+owPozL81uUfWb7+cdPCrLUTo7SWmVK87EbslUSuEe+Vv6R8OdJjvERvUoQOJj0ozoxEQptRounvNCLFVFaRfX0yIEa+3SNttpBWH/2+UDDTFHI9cJ+x5bFzleTif5AyHVHnzqo8YC+ABr1TgHD8394C5i+1keoK5D0DZGtBuUA3TheEqylMpy5nd2FBKBQMF0A2+kpkFt4+xoWH+RN8Uy0w3vwwc+fXAbJuA2m9Bq3PYp2bFIgjrNgRgei/6cgGSYn/Zno8X6aFrSHEpJb35e0P7dCDsbHb5UaaxMS19wStXstqdga5WwIvABkYslt4tCEL9konFLw1kT/H3KalpZoUZEdz6RTWJ6Te7rTqFXUDjiKQBUx38DMMjS7dkGMO8onCiXQrn8twAFiXaEKHFmzxXQ5u1vM/pK0V813ZvoxafECfM/VMPTQd/j485+5wKScSQfjX9GCMuBciy+dbap5SkJmmTXdoVzb2UTV6D+8vLkSWX6/NB8mO8Lid+oOcdfmAH19yYDZ11AtSxBWxT5csTt5nAzoM6YbureQLGOTqJYnDM9JnXMZoyJdwA+IX1mH0WvttmThtHuUnACYcdO9lh0G4vM2pu3JDvmKdhr2G01NE5xtoswsPX0g7gUuEj76Y53k8Z3LfK3By4UtnatsPvSPFJtgGfuxTM6mOox483ywgcwzsWAHHv6gTw2hdyGD0ayshK/DtCTsTSR4+ME1iVVOSeIaLIMVQN3S4kfoRexCWlZlIDMZVHlkauK8Iz9Y1f41+Z7SEVmQQPX+hl4q2wBMEedqSqA/0gFEfRppWXgSNtBbUoeQ5Uv2l/22RaI/k715cha7FLAyGq5ctiAL3qJyjEBDtsEOJoWL90YpIxPy5olRCludvnSN34zzlhD3qEE47vuzEp0CkAMsALJE/aPDSHpYj6CdfLU3CV3nZKSaoKpI+SnJrmjTqccdrLRJJGMt/7adIoPtqmQAIVWW+NXlseA2PTsSWzbeaY53GjywhDV0c9G6lG3+RL3Xi0p8Xouk0+kIKbi8FtbELprOP8veaY6iyEL3lzD1GHQqU7zF9L3dPqe4ViZf8i9VVksQN5bCZmMauqS6qIxLuNcqh7ki45XxFNC+J0lR5KAVVBEIi+bIOyBu4+bBY0fYBuatkQtFb24R7DLeNA4jXJYYp6XxhUYoRN45iC5+OE+2W0jayrVPiaHkVEgNzJ/BVwWNHJTNNfsx0Boz2zc5g5YNvcbanCRuYVdLKZmL28wsF6KMEG+Bs2gMF11FX4qO/Ela+RcjbJatZyE84rILl3kdyxGwoCxctolaXn6O65l+C/JJlfVlwuSiSUPDkrZC6wGIoJywpJi286XBA2LSR0yywTwv7l2gLbiyEYH4mIqA7TixFk58j3ZwqpEa2S0TXx4XbC06NQTR2PehlAnylexad5asufzlmoKbs5Kb4DbOp2yO9ADAOQVoCANWawqw0cM7bZBD/KIFyw2KyqiFxWsrfOzoKZe8rSJMdfdE9gPm+gV5nrW5D+2RooNfniB2Ers4HIML1kd71m5gX0TniLFZNMW9xm2IjXlkEPpc5z/5uE2frvA+MyqpaVfllI2JK+rMPV3ZB0NLZTA6SF2/eryBW9V7x3A1qx2h5+yzTBvAuTTrFVadeJy7uWwEppFiwSUnDI6SB6NluNPkyHok55hjhyfYEqhay6KfcIiOH3FfnUATCLtORjqaYs6DgzuWcVZaHDAAfs9teFQ0bwtO1fQd1Wc/BI9k/cmiYuQEMDASU4myefTU/zMb/bi3HXhkE48xaQdzBoxJJERUKUzGhhUBFUD3WNcLpW1izeQ6r/I/B8yhpAaAugPgFW/kt+W5RPjGNeJYywf1FPJZdQZOHCEd1jgrkuxZsATRgD40StGgQ4BGZvqJG/j5jhNSja+wEx2hsTEpc5jwAezZGNyxLFfwzICEiL5gg2OeUrl8gLvj7KfkLRyebYp3iY/s4X0t7LeZKfP9hUNJckUOJ6qZfzgeJlI/yqcMtSPjcjRZ/mMCtt9zt2sNXOjFg0JAsjPTv91gXbm4lT0ZPaXna7w0VDmdE0JVhyj6j28QaFj93ujvoiPt0ptoS7inThBl2KnxLOMDPkJLSVJQtywk8kcG7tBYb+nopKJNKEttH/kTkwgaq8b8jEy6oWBw4g+KsGdOCPYkVQlmv6CmFDLJHs+6n7jY5XyOvSRXFaXEAeO+94LEylsg+dZ0a7YAmj8rYvO9WxqdZcDl8NDFuHUfsoNZ31cF2Kl2ZbIL9YIPOFr7iu43kRa7/xSYMb0Gpy26kJ6W3lZSOMHeYiCWMMdJeBChs2qMrZ9YVAZrMN73Zn2daq4H8PmBU7QgKhcT0uyOiCm3JdFShpC/cJ6Zane4xYWOrj+kpeOUNJ8txlSvbR+MMy3l0Vy5VpGXURpjdPkH2Bm6oMUPT4bTeLDwDpPheezt18w0aTcUMEccjtAvcFvYPoCtG4te/wsjho/GLq4cx3gu3IdPBi7vE8GfD2OwAbMrO2rNTANQ6Lp5Hyt+RnEflbRl3zn5o4OCzoH6q6Kvqc6p1wMfi1xr/NOo6nkGG9EXUX9uGasw5hWtZ+fx4BnfzRllHVu47xgCKYlwBnGcDR0V/ORdIrHouhlzge5H4izAvEkGwP3hqMEWcI2DDesKiCrDpF1oihrdzLc9R5Ym+CoC0Nu89O0qFjFZhL8B7CJbk1xJOH7cUjSQWD37SVqXyL+lfG9UjTV5m4lKxB5kzMQlquJFgGMClrlZaatEnJlPFiqbjjbyRb3nbTR7q6GMNPGyy2ubp5exlfNL/TRbhn2N7GYnQ7FtTY1MuwCFkrpo92AMBdh2/SohrFPd0Lg1vCdZjyxJZ/mW1Z8Ltly+E9on3BhBe/b36x+zg/vqIqJR/LygEPZhhVvg21O2Xzfp1r9ofVM9lCfbfDb0olkRKQNUxPhw0uuYJvyK5C/78wlKqXsRVQbi0XftP0P4DpNRXiyQg8Jn8oZlcCdpgRO1znx+135cEG6TRFOGDq4GZgaeu47o4Q6YlnsUOEG9U0V3rEAUZT3QUykN/dVinYJ3S7HSLX20UnyRynxQ1HqVcpxeURvcCsc3cHqjGNOn71KGQS/4dHuqXQKbxzJzrVfLcw+t0tMIaV06fJwDPrflpYpsm57FZinb6Ru3Uvajweb9IJbEYbdfLe9cJ2dWIVX7XP3GFTHiMloy8Nibt8UyLCwkLEd+lm0tp/bWRr19ZP2d4lluXSe8rjDlCGnUwNoJA/Z0OsnqeL7Zumi2t7TSa9dWYvyQpOgwoEvHf1j+lK1sOvX+pi4B2EOMTsdl79cx0zjJAMnG2h/emlNkFhj7RYv9eQpKtpqv5Dx+R2UHW/deyOqSLJ0p/iHnr5ge81jSG9b2gzECWf6aqncKa2hNOoYaeI81VtnNezPPhCaQ0kBz2QUIy2wz3EhwtK/STQ5SKj5vbzCagEFXQ+bo6neLIpnH5syJyAoaZQc8oU59dXH1+RobzHuiGLWoFH9G+16FEFSLH10n5cu9Xy0IR9/uRmy5U3SIN+PpNk/p49Tfvb5ZDqd5Zp7RIaFr/uED1ZJH66iHQbQDW9rMCRnX9XtpMBoR1OzMw4j4Jm4a0zIHfzA5Uo+iQgHuC7mgkpeP7ozVmysly9qhyFvd6tPZDUh3qTHRhel+ko2AV+HU1LWKqaZQ2eekgVL7f7meBiF7Dox4IC2+zD0X0PVWXz+trzhfIEWQ945f0HEhYHD91SZkjUf67EFSSwq6X0oDIffTOP9mQKY2l0YnWPDAw/dLryp0n774rvpMkRrW6FPlkkQuzl1EYEAVTz9WO6VbG0DI6YBvfkusLT1gFidsTsTz4MZsAdCXrEArKIsvfy7DmgDgaKsM9ZJSk94h6DsccAYJ2TdBRE6Sw/xqrMTa6LQ71R30ON69sQShsxwVK25eT6XGhSM4x6fMLWShGEr6pGK87K3Qu0OW7wS6qCmem7mrItcUiqrQtoe2yORjGrGvMBSV/vhGaVAHAf/owJ83oPZNReGsc1KLrYwgJ77kvz5AmqtS0Q3FGJQHV4zoacPD5kIAznPhBfJVmFWYHW+abTx7MiwDy65wly0vJKB54IrAM88+FNCrAgT2Nylsm+5V04syXctbR+3XqUe+y7GXi/sY2NHWTL/9+RjCULZQwsgdHwlZJVSiQH2JMXL4kfM7qsuAVa0+HAMzUpcavm4jXOyFvNIHKT6D6+glrGttKpiXZ8XbOGomM2P9uk4OgKMI8oBbplnEFOpnQ14OOy8VPO1NHvea9tSpZXp7jJhE0isUJzBeyI0shv/QKQORyf6O3F56LC+1d7hw+Ice3/984pg7w9ItuslC++EHWXWzN7Poca24/AxJFLoro83V6RJjWaR8LUS+DEi8vGXItqaMsZGANNMFN2Dzprd/q2AHALprJJHjg5tsoKqC2j/BcDWyAog28qtfXsFcpjVgiwRt85VwtWjMyc4QA8iDo6uvFbR6/mQKf6akD40FaJxHetoBjh607AEIEfc+bfEbsAGfN+VEmh5OuI+fgmalJPWnv/TJu2Ji9D5T6jmjDqw/XEkZXOA3WmQNPaBrRIf9XjL24+Ma+cdsNV1Vvu68gzb4aSSqDi6r5Mw46bmHs0f1OabmGX4YP1w7gXgkuCc99YfKjvDn+328LwSFvaEMyx3WfRahERLLYXfqRZeSdlMKDo8s+TXXCml2FL6oIlUqs8sZldreyzRNaD/QFmLyiB2FUbHwGlGyQOMYB6cUbTCvvSOT+JBnzul8nk7CC+UCl/6Ro6JzBAsKguAVQSAHedJeon+n3cobKS9OxCSiS0vmZy9HpOFmH12p2KxxsqLN9ZdYWyM3Pb3jCZmBvOrbbw7SKEG0Hbf434/eUz8bC21ZgTCeUSJMgGrGr6sObT+XxHR+lKm/rSrrcppzRfUPDQQd7e5XcAfXMrxazrUxAy4O9uw+B3gdkwMz4yQzGB0Mi2gAYf6pxzb+6kKnlRqB2YXaCqV1le/zuGQV+pYXRN1vkd1EpNWpOkS2NiwIyzQSehLhSaYjgBauHwZEiTDV5mNq3+e43CUHb8691YJXlQF2YO7Ing/f6/wR1NpDg1gmcpmtG0aL+GoNmEeU0qedKNwWAnEvQLT9vELbRi8u/jrMHQ6kkv2kFzzhlWEstVAJCiD1do7cg4TgvS5bTJy9yM3fIghS+FE0VLUwoudNWtCKK2t8fkIwlqNk4fcnOyUEgIIo2NoKYoIZEHnQAzPOh5nUgPO79zqhTnTx6an6NzmD9U38/o2alS2TRmgaSH7MtRHd2dEWE6PK1JbpQEXPVt+mZHPfhn2uN3gSsjqFZoqCjiB9Yy/ibrNos0JrjTaVpsIuSC1FVS5JbQnwsBzmXX8qzFJpGjEQ2J6R5ty5IhRksf0LxHZ/G8ZK3/qS1qPa5nyYlKIC6wfXWA5PJESiJXvDxnpdD80O/rGhGEaj/L54AI6BFCmj+oUVLb30iOE1aHrW3tovDm7eBHHNmnRPIH4QwVtFgJzjZM1ibWVFISq1t/MQd8uYG23S6WWAfEtiZpnTQXk1GcFjYKtZYswjxasRR9ye6Vt5RYIkRzc5RdYuBdDWIMrY1JRGBOrt3hyPR1CwaQqD3S+oky5mbJiA2sA4SW8QFVmZH5aM14Aet1anmKSaAnXzCT/i+Zdjk+epmoFeLavktOrFvZBxKev/ED8nEvqB3Vv6IJvOomHd+EZztKKR8YcV1DD9Vzu/7vYZx5+4uuElps1G6wMrP0DfaolTdh2lQq9VCiMsYr2GgAr9U6h93QmZsWCfi5YoG2a8ok2YVRSSuxEeR/TQtebO2aIA4PTEGHMEA4k2VyuH286X8em4SScNgBTRag0VAT5IivVMvBSxLfOMo9Ombq2t88XlHYmkPmyGRJYXjPnW4UvSNzyCKhbqP1ydH7P+bS8ce2lhWCpBelmtJtbrQyjo8MRhRImaS9wSifBi2Vh4/oTnVXsv7B9m41e/RaT4g85RkPyLkKs/rXIRHbZUN+ZmMmGr0Of1623r0NFcEbv5NC8AdRsJbNNTeMMfSRZDSlroNT7ekXCoQc4xs3MY/q9BBwiwuUzULzFu1WhVvKrlIL03cWHV3VOhp/NnkVA3WgcfxO5ls+vELa1fRAwFdQXPowbHNotgJWVKSPhXuROW4NzF26mSysFjxS2N8wSg3SYYNtvSDAoBtfaqbVt1xwpT4d42+U3jANNfnQ4mjdv6CVzXyraWN2TFVMJlwfuccKOTrkP6ZZwrrMyUAsDEf0Nz4+pjQIVnqAF17C+yOi/EJmLlRzPj/X4NP2cty6L7xMg9g0nqqEFQwyJxe15Kg738rARWk9eRO+2Ag60WXC8s0JFeRFzRGHH5RpM79po61RtPZHQSUsDgRFQ9SkweLFm68YuhHBwW9kYuU99ZkuxKDFhPzj5/UCvQ9rCLWC0EeGvRNPAdyCJe51SmOeYn+HXcqtMzPKMz9rMMQ8Opsht2oTHK3BYgrpb8th+LG+gkk0CSGe3/eCfodjWMbT6wGtaY5Kttxt6R8ouSiztl0lgBDf9+vvdQYtVo+gjcTV9MwQuOAdZLA9v3BZozGxB8dlSSoxNadFx67azN9iJJTUmc7ag7ex91FNi630CmconJSEtOM2IutUQxkC3FKHbuDCgvZrFNiYiqqMt5hPfAWtypj6hKDeKEiIPjvbNcwUra6w8B01LTsdVuKsams5YQN8eNsFAwuyPy4jgH6CK7f81q+30h7bjuc12p4r/jlgeV0b1Mz873U67aIfR2xyEgAn1DUGF6uHrRh1gB0dtyo1uQBjhnoe31p+60aXLR3XeO1AqQa358EW+WRiL5xq+d3jdBgBKjyNiKP59s5wcsUSQZkWlyT2yDSy+8gqBdjgPeU6ALFdTPApHeGGpTOqRedrmMoevNO/ML4DItZlJETLAsUcjezfvT4j/4uFvC2PWnXHIYxegHnm2AUNREWywA+FnUIvDLy41FYnyQuv4pCdLVbKuYkXRbDsAjKI4nvxkbGFqLwFoQP43roHGfk0eRXCNZO7weLohH5aF72GMoUnR42UU9r1Ut1D4eEjcvc7OdhzOxQ9wIziZtfCdp0DYJNf0dek2fNvIMB7dCAMG1JQEBHYP6xsuVN2eUIOZn+rSDC+ZrLI5FO7jaOJOSazC5IQL5bceq8SLVv0/r7Qgvl4p11i3D4qEssaaU19UiiY8ZZ6C5yvvldzea/IQA9WUQu86Cv0fGmmzkK/gN0fqd/tXDFin9yvocahOPkC16oeLvZxbL4n2y/K6TJUGTxjXRykJSoFx8ra1yzGqqLKeh1NLlsne0SDTneGdUm3W/TNqspQc2Lc16VvILFJvQISdsXTCey3nohCYYJ8SKiqNhHXsr9+dTbh+vA5cgjvVfCPCgzlbS/bKTF3qgOUJqe6SYGnOhxt82YPeAV11Q/mY3u0DCTwyeHjqn1vKMcuZW1P5aqh+uqKK7xtJSGuiArNh/59O3UXJ5BIjrrPkkdC/4rtzJj7Qzu7gZbFIA6ySY+mvJccW4CKAFpWOOpCmPurUUXYRWhB88p1CURGqJvkrfkJlecv8byleyT+g/owtXQI40Ihg1Qg7LceKL2yd4QOrrGZYwVe0M1T+nvGGrgimzeBrqTk+KZOAE/u5FHmv9hiJrs6YVwMF636IS9XDvhUOhkeBe0ysCMESW7orTu5hWPw5aoleE33xKU34TovMDIkib4BnWZgyVK33IE3l/jCzvJZoDBqGPMxTq2rFRI9nLD5y+TMHjO1lZ9tzbp7FWgAMyPdbQ2WftdMkpnta3xQdtuN1ErmMUvNOiBdoikeGoLZ6HIsTqAchPodxZYs61S1DdhbDXaXto16+czJZZnHXm360fBGT7rJF2hKQdGMAsvAz4YNf9AHHfqFGQ6jH1040jyf7sJYEhox32N5CWPTJLyAguq6eJWicl7mHp10ixmohfIT43gZWKGed7MDmRvLTN3chQeqd9O8Vwooveg0jNzRnpavtzqFFEGcpjGntT8bGLVJEvdXCQnhRdVYCYocnKelXh/xE1XmJF+iQuvhZXleJRTuUMTzs/sfFZ9ndXDwmnLVWELqDz3qCh6fGiR0PJ8JlM+Sol0o/cV2eaCmGDh8oDVIlawcA+LoqG3tTdkXzHXZDCEfxQI5AERGb0+4+sm6YjonOJQrb1TypA8tBK/JdKuB5WAj51HBczt0JXxMZUrj6UTLErzAaA+sS7jkAOL7k7DAXAPbRKlSMjqS1Ds05+De6IkS/mfaBWTcoBEelMSHYCksuA1LbW7X46Jf/FlLWXd+Tfut58plB594l3oIDBxdLQ0KMhqE076wk3HPk/gxZsrpnMZETHC49wbLGwckOGWUIlPeDozf8E4GA/FcvltIJNB6NycClB6Fm8mGu7qRXqP8QF7MdTgyi/xJ/0L4hFyTbevxtrpdFPg+ujSgn4cy5PhKP+C+CPdDicXshCgxNaGVcmGVi1+bRgsc0Nhp6w5zHYatksnWXDlx8YkjnD0hjfebSNQ2bv5A6W+ORWzwIpQR1C/CLULy2ujhs6ykFluRoQ03EK5RxUzR3fv6FCL9KLCEnpwPj+5C9qgPoz0LluGE2nKSmdvNp2eJ21GyhIb4DOcdq4bLPLHrCN1ckMXjnahC7LdYPU4lUmqMXOmqsr9UNE8+Xk+zTyCOAziVMLUEZovVcdQC8vH8J/EluGp3Cb4pL1lIPGCUg4FA/y0aHOP6MIAeFUT/gVV9bnPhhfjYh9QbM+3chNIdDHvpNA2yZY/V0V8cEkyLVlrhZOH5SIRpHM3FcYyYzHIxZ+WoVCoRrOG9m0E+L055BwSU3Tk4MPUdB3ThixMNz/W78FZl0YkenOx4WwuCCUFUwRAPGpdNajkm/rbX4D+fB5Km1ZMCeJOjbg/17atpEA7SN+XMM4olVSGafyOpj7H5TV4lAyR4dOkgoznX5Cv8ANWOJG2Su1ejafSEyIdXqNMHRoSRFuXChh+cVcbLvKaVvleehBdShNKiIxQw1AyVg7T2K0DX8D95BoZwRDJZAKQhIg2WEU6LfAQTqrdFnfja1rqhG1KDzEEl4MSvjIHbnZ1viLNXARjxYSZSdm17Gcg+dyWrBTV33XlvlMUwaudReVDHiWE5zwSLd+nAuO6ch5969R769jngGTj5/wRtjQRQ+FPMDJcKhqSFlJv/j/PE9W4Q1325Ax3uVkby3u0Te7k797vY5PR581JuNZ9guMSHCt9+5MnUhy3zPloO3YObg48b2vV+Fb+KPjmOPOuP0PU9gDCifJpl4+dV1oJpNFtUBRLbZu0MJjWOwhgxJjaGGiB345PxNjsBPFiGRtw4U1XViC2Q/XwlAiCZ9BQvFXPnisJ/XWb72nw1a38803gAUavnLVwD5D09pIi4BOVaxewjlMYTFyYHha1yZcytXz276WvedcMChZifb6bcE55xAav7XADxKlLMNbLNv4sovSXZMfh/pa3zzrV+37rqTTpFmxYIdN1qnedGlbFzum5DswmWkouB4lM0rNhtpxXD+/LlnaqLMYVsEzi1SAnzC/OhwYYjh6xVhFRBwG7FtNF+z2YID0/vdhDBCHp8GV1/B9HaCroE8SedwMK1q4+3uRlbDK+P9Cy/BImGzwGQ5Skk4TWUzas5ZOweVU/JhXwjKgCVJQjji7R7KraXivM5/jBQOH4+cuXzwPQn/uaqt5WG4dwkAsN/H70Xw2G3yOhYX+EXXI0vGIJpC/m3JuQRu7Tr9Gp5q6bigYIxV0dco1jYnSCQOC+4tKQ0EV0N1RkllfVw0BGGyAy1mRsTOGla/3P9dhwF6k75YhqfHSDLWUNkNwFnELVVtqVDkgGkffHfwbK7B/8FhGQs/wqzqINy/fJlWymnREmNVykqU/3xqY2saHr7cNz3G3sICn4Hd1TxXSR8iVtDow7uMk5dkBZJZaf1/JcHUzI7QFgLJmV3S1B1a3dFSztyRH56xI16r0QzpcMAC9gO9coZwsvP7uaRogrfo5r5T2NUcwEdcWjPW9Y1m6/TsiNMcQZ/yYmXnHXeguwNkBDaN+K+PzOnntTy74oOU7tT3W/IH+86ZuXVsYqqLymLW8il+V3TkoTnwzclKeDnvk4trVVi1TAmJqDFNpBOk/graC2sj66uF4Lf3oxbW2J3mn0L1DDX/0JnOcOoabk+J5gsa2Lw0kFzLvl/D35eD+q4TrMPASWaaQ6fBQtdz96fgNrOPdBG14okPx4uiuUHKQWqbDePeD5FchYFc9dg4U71jLGmJmot1/4y+MN7TxTNk9bQfuW0YngJhRQfxS1hucnEs4Ho/So1ZgUBuMwP9371IqByE3MWZott0V19VlhysoBA3rBOpoAZw1DddzXrsP87cRTsxwNHKgvXp/khkR9E4//T0zL30gCOIRhnt0HFIOtfo52qz0HzI5N/btGTzY0kgZ4Y6/ypNwCim8GKNJorFiTJEIHB1yvXt3Zrq/yl2akZDX+jgDGJRgw3quNJ/yEPf2ItdUrzVxk1H3jl/bKTjBEaXN4W4t7s6fXX/TeivixUYCNMH1yKRawbUTJR2cpq24BP1mX3nqBM2jBfesBirJsiSpPq5zjZ9hFs6oKFps4h2ZVEDpA7KHKapRunZf5xZWH2SuWxKQAywAPVHPHQ4I0AhWUlek1rHcufobCmVJU11WrO1d3Fnwa4zNxl8DOZiMORG/gl9D2xL0472rS6VcQSvC0adtHTFiEm5H3LfQxLc8WElaJBqc16OqqMHgppTpdJGxtwjLm9/NT+i4YdADNSTSfarLhP0W6wkFgAvfekk9ABCo7iQrGonMDqC0UCof6UnvcnkBDQiWwXt4natvD13ZO2k7DroEk76kd7wqYvSTzO19mCJu2IUoKXxTKi6hHttNqUbEFXWymbEoh7GzD7ZD5/vDRQpEx1tjXlxkIpMebS427WkYIPCRHaZg8PRTJipjxqTXBrxGSFBJU9mXb+fGpr4aOc0W//BlHdfgJrOBXhRerwiBkbU6ijqCnespZ/Tw5GOOrHVfVzZ1mK7p9mJttxi2n9HlAEwyTHQ852uNu2S6gN9c3Bhi3Apj2pqHoj4n9dvlGwol1Ffonywo0psHiphyeaVI8b2aj8kAFpjZBDAueyE7Yg5p7HWkCEHSrSTYZF9uTy4DHrEDerrrJ58fP3a4FD2zFszpjmYsTaKwy8viTkW1UAsxHBa7KN89JxY2PRib95LgHLNh7zedv5CtemBz37G/Yp1ah590OSjwApfjgR5B32kF3eY3NvYL0JbzFUezi3jVhCDLGYMxpRenHfEeYVdtQCDHin8WJSrWLU5WssxGfGEvyX1eWnkUoh7+4Dwqor9XhsLGCWe91TdnNT0MZXE6R6KG7nPvGmzCWDE7EkBFkXMBbBhoHpEPAw7qoAd+5+eKK6iQZIL9yY6LCeFHkRfKx4hg3YNo6mZVWDxMd9tGWomq3DtVWTvWSE7wBCK0giEnPn/JRd+UFgKJMz8Jud39fnz8g3XxiKGigNQuSEanV87yi06A387tMRx+2itPcRaceqKTQC0LFhj4gENQqmL4/Y/wSWjS2xtYN5FBKjUN6gh8MsNsC399I6qgAii5yUvs03NTv/Mwkhuo+cDGZwthX6Ngv+x3IQPYXeYf3wucFySWlg8rD2QuAa+WfPwArBIr7hsmyeicx9gNw5xLoripGBPhiFH+lUyos8/FcOZ++BzCoam9sk/HVPIusQEvqy2dRTgs8Ye6jh9KoQ2B4lj980izv4NWAAuxUgksxA+6y1/uUn4BNDWFAtZtG1pbYIS+erD1n5wvLMCvIiKHXSSmcG7JaomSq5Li8I4suUuTYPtpEh1sJgbK7EEb4lFlaRELlrP+2nZkswHtDvPDxmgYnLVJyhTWCztKlt+LQbWGPTmQaRMn5TbnMY91AXYIVQnbiHYVUBD8XD1O/ZfBUshiLGCPcMWjeVdTpe3p6nJ3NUNKKOHj/KU6RcaqZZOqubs+TvObIdV8DesUHD+rP+0i0ZW0yfKagV0Ha/pybtaCl/1zbpGtuNUEcsV5q0rsTjf9Z9P5MHKrLkoqQZSC6+3DyG31/CnOqeaWByCpxHw4OongWV3xypWjgO/CNBEIvoNly3UYFD/bBX56/0Nl/ARZvV4isbsF1f3jVbZArkdZAkgPCr1/WAQWJ99xziXwcTPd0cTUiDjUaTDmUOnXay8j18rZWlcKzGUj9TffoMeI4kTXkOlcRFJTivwn0Ulrvf/dMTNISrTYYqutzJbj1HAqVW2CuxlGNDGMYrYnJVIuoZn3cobcdnzypzPBrLx7WVhHtz0BzMlICJW6FMiAXingJuz++NGG7fBxzCX6x2c3NZI72qn47ijfO+ncHW/HxuA0+m1PN3FfSkhjDCjwut7lX/lSiVRMOiax85Yyxwzx55YBcWEHrl8sp/Hfe6mQE2YzpmHIBajaKhM//8qP9a6XqcHBN2Q7GCdfc05JYokVyOxkTbGl1SMHAGyV89c8t6KVaQwvghua2hqix1hT4G0xseCDUaqnTsOb1+2rHh/99o7ryBlwsiFehGPSqdxoCqAH2ijCflgDDh2jhdz1SAPAlJiAytftYqze1u1aVTJwxAqCPOqrpukGTAqLqbLgLoLH8cP9mTnUhCbmRcgIlU5/yd/B+IXrHbY+GiSc85gVTps823xhlQv3GpXwyWHsFTLAeToRLvEqmHgT+UXCXIdOMTSUhPnFWojtDgFjhLoSWPcsUQW6p/PLbPUAxF2QxO76ddOW5DDp+yT0UXa6mMm19Zo0n4IkhtGYvB8s6cE5XzQTgs5AMWuXgJbewXukB6o5LplKgeCNxD+Z3L1w5MQ3HEW3An8bqzko+xfOlzItal2FEcoVxXY6/mMzoRvXGBFCtCfAErban8UyoLvkBsLGo11u6WCiEnhIeha1yaMdEjGnp5E1JlDufM05Am1z3VvJNDgB4GDZ26cQUdHDVZasSzQXU14kxhLpJbXRkkhhQPH+P6f7yG2pD4mcW5wVv8lY24iyzYIEdOwCe+8QGyuZCU7r3BaWezgkWF3KwZqps1hc35b3MJvRpBLe4j5fiDxZBuGeAN2XFWLqX3zzyiMM5D63RykB0cacQ6HlS2U69nvaKufUzWO12kaXOYDLnNyrvkOXJKFdgWF5lebRW8gbxSb09lon3rsNYLdVm4TjWbqIwyCMMlZy2Ugt98Xb/wDhgINW3l3BDCUzeTnqbiIOYDxwwe7m5V0IQxFOMK6pjpHPz/si/kapSbvaV70TSnszi2r8Gaz4R+IydOreOgaR8h24vPlqMFIas+zIpIse79DZnppmx+OTEqMqkaR4elOv6qTq/q77jpmAqniaj8WkFVXcEZP6/JpJScS/GrRDeJRCeQeR3dGlwtw1r8TwySXchOVZQZ4hedD25Qlx7rCxVBJw2/Ghgkufs6eDMgMyvvUzKaVLl7F+V02panpCbT9CZxEL7OcZLWMAVEYUm91wPfkgLRvJh7fUxU9K4FpLcWy1T7kiAlNBPY+7wIbVtBuU6opnBXW7f2FvzLESo62HJDD6dRVFw2dmWUDrFBzC4NQqBsFvgkEVjQTVx+1c1cIZwbpQsmwJ18G6doDb+utUUu9SbYy4DH919/uvpra9stys8SZL9H+aRP6eL9jx8QSpjUugm4LhvfJl18+BQvPKZQgdLzDX8nTbXSHGzpjfzI0I4cy/siMx8vqndwQcRbOAr+21d8S0FjL8LY7Ov2HdgkD1HeB0LG9A9+AI4iq6nJ/hGK8LK+9EH5M6wR/RYIuR50mUKJmC0WbXIwXoaA9MPdiSzn+V0N2NEhcPGfYGbVu7qce8jarDN1nJKoxJlu5cIVrxp8SWsKxvWgfSeGEKyplR3wUpcpdIPdnuYkQNGYug6FfEWBkfAc15K6T3yK1FuI5RDRgiNUJgCxS4bfgK/TNuEpuniQZKoaqFH/nridoSFrFAbGgrtqnwD9YK3vqV9cOnjBsPj7CJa5V6zLG7fS9JuOq/XnY2LZzJBa8cbHPnoG/wPQRiwZdUDfjlGMEQnPiDU4TpWPuWHM54EiRaC+fP58yDiCJ5jTPvcZL0r51xEqIY5YiGtkT+Rjc4oHpxOyTcWlcackYDTit0+ghdFPt/BMPiZSc2LVU21RI5YtDH8PDiLTjPXdjV+l/tczFM3vbdu3K9RGbCmhbBhHV0sWuTanOKw2qsg92pHmtMzfD2IgvQ+hi/aPl+E0bm21hYnd7G2ZCBxxF/Hcl4nXnDryumG6uVCXTHQSlFeUQyRiykvpMpiWq67MhJiqawmZS9JhVL56nn93pzvKRI38B2uvG8yb6z+kyCy9kV6pGSJOfMN0th+g5Htuyy7XpvYP1zC91pfSKLhge9c9UF+idA0i9tXtkCl5vSHTGVBsnxTntcEae2v8+guJfnLZsTlort3QiBjw+oxDrS6xkbDtGR8NyLZ8tPcDGL4/PoIY9SXkmfmj0AAQq/Ja5/EVzwxjO0yr+pErm0IamBBYyAK1FwuwUit0dUEJqYbuZofuaDwU4/1At9tQC21zPvxNO+A8cnWu+6qeDlfWEkBfrbmjvZWrV+WPIhXZA1gnWn8tZrkdDSdNAkj22Nrg6/75NGhvBO4gUa+RhGc52PbcjoByux0o9irhHILvIWdMg8buZ5fUoMLxHMbJk/KaAwjkEVWAHv8TVbN3/CX641yQ7YLBtfG803Jwu75syJWDCPojpcoVgVieP95O9FWMyvS2oaofjZDaY+5D5wCrARX/y7JaD1yZaNWqHPk/Ka6WfEjczVaIeaQXhmWKVdg5rxp9K9b9MzZfkQZGGz5WFgJKAkoPCDyGHLiHAqBS+5dyZQQOL36ZZIuVsQMI9Z09q/17DdJQJbTlQfBcjNI0rdf1U2FcvWu4ljYpTfTb8+pLemQrGpBxWWUGyydT+se/f/pucbdH6KYRTLsKFy1cY7irYij7CGQBZktVSzX0RcwbLoKLpZT5m2h+6gnqoKNeJMrSyZojySE7h0LZl5hxigbXv81sc00Ye7FjJHI1OVFkMkzkouPtnVzN3oROVMCMU/yGAqe55AFKLjumnWPvPfFxVoyuPrxmRxDCG6vTdRhcJwciJ9MUUgJ2PsMZiAhX6K0o4xwFxy25/IJoFrx2oDvjN/pcT1soiEA9K/nD2V9YaxY6Mo/NP0wHQ/CXek2InjKtqrWh+yd4UV63O2JXp3GvpMnwdHFgaQOdnyMvQUuyIAWzED5QpMcMmqOqm7Fsyf1H/a57DztPhSe6OfJ+hj0JlJZ6tWzzqofMNgZFRNs5jrVFgFcw2bu2zaC8FQaQrwSEOi8VKiDvcpfibnS3Jb/HQrW9m7tdbAdD7hXrHzMtZTuGVFxjlDa+ftImvpW5zwDkSZwHOPoz4pylw93ljbd1e/+JhNfAycZ+pX09OHMbqeo5+FlteyYwYeBNRQ4XdIdjngm0w4LzPaLfh4Ee2zW4KnSNZRrqZGDPEVylwo/Nu7Tf5/XIHPL0kcUHC6T9Ztttm9w7GhhNPBbmdJ32L9q+Z0d/nt1lZ27isS73yeLFgUtQsCUyeNpH72+OjJuvHSpDPhSMokrN/pm08tyWMYDS0mTfmC5Zfqe7r784cEiTnhLXPaStTSrmFB+dizJXkg6k5ElMDCup3lbfQNmgqgXZi9jqhQKpUoGU4+9seN1zQ2XnNzwL2RmOH3QKwPAcTJYbnjTRdwdEsnKbsWqxIJyKoQCT/q9ApOki4Uj8B5WJT2McqWqDszI/dhcNVlCRXbl/BRg1872mdtcMlwum40o+0HUzp5Y4DfGzbxecuiSNHee8Izt3GTgoLPhQyyutYQnAff3jJ5kIVoNuK6ADR94aYzzxA50ptD1r+l8ifAv7jSZeaxVG5kQYVl4Y6ochZ44TKO0u/NiD0UW1YG9poI1qY5CdLXTJ1TL3thLihv4z27+1lxV9vrRzYGgS63pu0Uu22K/zrVP1U2UsJnV8ECNSlPQOLfDyXDOUup1fVCiu1LKrl/1kqPHSwiailbSsFBb3gMxaW54VuBNCPVEgeX2a18IiAfscttZnZ8Mc1A+L+BcMFX/bp6yoMiUoTSlRc3N8JELh9wYGAd6cPGjMDSHYmsX4epOkpL+ozgoC5zNK7erMWC2gUfQeXiJ9t06wSW5jSRQ8zllRHLKRHLO4MxVPtMf3yPfX4LJYekT79DCJGYj0s1lFvCsVN5Kae8HydbgjQ88+VcRe8hGfR2JRaME8eHRGW6WXmiHw0QZg4jhuiLWC4lwA70fqN7pDlZkegc9DC8iNyJ9jr3vsO23F1H+ZdJpBhZ+qHw3nGLczvkiUMHeW/5UiEFAldkoc1PBwTEBM94g70P0bosWuw93oMzEsNRgODk8yXGavlNpsCYV59Upn9aktwI4kS4DTor7gYJuSmtVu6bdcQMK4yazesd0YYwMMa0anvTYm2Y8xaWCvze02pfr7Aiwo8fmUafejfoWOuTGr/qobZd6ISXZclzy/7l8tl8UK9vUAyWsEwY/Wy3uFt1h0zUO9/Ok7DDP/qNUnl2gyF62pzHIUWLNu4KtI5e7onZT/CblM+YR/ylYfUuMTOsCA0mrYoVytUKnnhIRmC9Cg0fAsnaYtD/oxkP3Z+cdNsTcq2E2euj09ZDq5ifjlEM7BbJITDIOFbvmnxNHvdFuq3df297UwBnxn0et1S4YgapV4Ewtp1YN/S5P6xSIKFAeMCxww5yEC4S27K+uyArLYLIQDmtlV0oJvvnFrbEVq/14Tqg4xT69tj2nx5SjbSxbRhFCtdGpbHM6sr1WGLgv9w9trhxNseLsPIN+acCk1GONQmR2GETF6i+/v3V2oEdpWYQ6SBnM2KM/5qVvEC5Brf/14Xmm+RbvdXdZWpV430QbzHplGxbgVyPtihHmkUnwqA1jnHYLErCiUoV2Dst/Hq+FR4BIr9mPNBEvKWKe4kKyeVL6AiH8K/zlK4dCCeW6hCxg5+4hzzG3tRYf1XOLba0wjkS+j48L7b95Xp1jiz8Gd9Ut94FnkcaEzKtAzLN14XapSh++gJpbTIdZPjoP0G7J52FFpek8P7wnJVPTN2F3zE4EE8ceH8HmBZXmj8jTNNztxefPBIS7yO/yevSVncesZzj0RQL/HAZdwc1EJRFBGeT8PCCXiehrKAEHlhMhLs4RQWpz2JMTADcqO5WorG6oTpku96yZQdAwY4csyUi2wyYJk0ISrTWGvFM3ChVoG4KrS1s69/QLnCmZ6Cci2v4Gl2cjrIva6WTggPQ8HhVFtSxN59/v7Trd9tImNDrYIySUy7PqTkOBTXKRUqpkTefBO1Sg+mHa+VJwdBOARkAyeRkZyFKIIzJG+FPdMtNuvo3OYGjj40cwAemLqFlu7cY3Ycynx/TWhV0dVq6DXvHIV08SG9oRiMU0MWOyQG4E983ZlrXnIVTajYll8pFJ6MUVlu/23Y/py5HZNuRpEON968Gt9e46i95bNM/mFtEsE11r4FdTvkNPjluG/hhgyvh3pdhqwpKuxMehtSyRe9M3FX+SIEziRU4QeMfddvRBFvp8sLD5n5oUf0aA9YDTjc3S0VrPdlknSwM9NsdAUbOJS4WzgVxNISKk4eiyz8cR8gcsPqsZBbrRaM7dBDsYcfQyPZZ2ssbaax4W+AqRYBLPsKxC0XJN3JgD60TatmcgtBFikcx+35RNeH9UF5VFiOXWnYL9HaZ0mmLr0oiXEyD/isTof91b0Rfbh07REqg+GXrEFzXtNkNkkrK1xmUN/8FAn86vs/q26gapvhEnLpDbHjFFepIoK5vWrAHR0GImcGeMIawEhXDR+ArTenUNdyl0+ysAH0gM6eUpfH0X8xfnVkyHfQMPyDOVIYdL9YQLS42U1d250eTOjBj3jYcodGKVLd3TEKSZgTq20s8FxyePTQZX3B1SsrShnpcuf5sKUukNWnJA/7J1HaE5JXtlmcR2AtdJwWjwXNU9bNjwvO/DZbG9OdtvpU+8+FyrVKjiirZF0v3mArCKe2O8z4p3Hxegs+xYrSJ3gwFwet7KzeFn8698HaSGVJKBY3Cu7qDIq5GbLdo29tWTSsakqv1lAR7LaNHaDEY4hOEB9iBMdIfcRE5cRGEKOnQj0iEfCxQ8Phd97KbjuNi7HJvBxm3UDNM73Q3P99+Ns/PbJqIcABp4s3jVP+1Smxda+ZjpkgWRsvUkYU87Olz6ODLcOZBUJ6uqSHaLX5CtSY22VOwQ+Td2x0bV85I+tRMcOiOLdfVCJ24V6EJfvyyBxngczp8p6y7J9w9wAl5bHSMsWiJhsTWDTxwZXDrly04YCiJqhVU9F3DmFlc55uBCwJl1R3NyRnI8nBkngYcAoPzBZNCAMWuUem1VunIQmndlZw7gNNEQf9jVr8zS29h7fN1prvvd5l6nhPgs8lexuyQ+mTF6hfkR084wsAdg0dj4O97B86dGoUgnC0tNMyZ3DF57jmoygb3M7Dac+zyIUwzOPrnagM6EsaCN/tpMBdFmgHRABJbF0jdHQER1sA9350kRSwbClFWRaCeNh0jItXEbLUlrWNyCfQj9x5AX+SdOLiOng5rKVyNY+desWfhN4BDtkbWAOFW6tCnxE+qCtj2GgcNvobRuEfoc0mMYFwMMAjNvrdvt4QIT5aRpNRwRhdnvERWBio/QmThQYLIhxhfj5nL1MegogTvSkbYMh5RzVw/ZCcvK1wGcU8x+cquVjeDgbxPbnKqixjts6S2jPXAyBz7QcoxpSfE5zrrdy1lIoAJPZSyruch7utiDQr/Ai19y1KItkV1g+zSJYkxQze+Z/f4XdZRNOUdNYrXn17e4p5O2PlZKOVNs2nqaZghztnuh8Ogn0YHsiVg//5P8B2F+tXDu0Iq4AXMUNXX+uz1GDq3FkY49/ZnvlD+mad5YhFsCcnrfPlIoV5e1NTVJ1tv9z+taY+ZJJm44g+gV72eGqc/sGaDUwYWqPRxSiZUpfHI12gr/eo254Q1Rmm7+CdBhYvvHTRMJCNxBj9/fJliS3e5LZN19Gkb0Y/g7QDTORkCLof1qaMTyGJ83sjYKsk5nwKwGvwAmocKdegR/7wynHYbUqeaz9TL6PGIXLQwLB5Dzeg+79w3PWolWd+lWSJ6rXHF63QKIMpNqrtDILyhyyaPejskQTuEsoTGOgMFj6z0BDwe3BH4TQp2BVMXQWG7Rc09HoU92Pydk3A7rszO48iqUAQPObZwXcpKOQDUSQK4MmkHmTJ4ft/FsWsfmyqttVOw9cvh6lNGjfRk2CEZvHQrNei1jfzzls9glC4QYOastCQ0mAcqaMQ8xFRzt4it6zNMaYwqiJeG78XisUeeMlcaq/NURdiDnIRtaK1Eeiq1hqmDkDl574UtxdM9jY74QPNFDkVffESv4XGz4kEAXfhRVsQ29ttnGyYPdD21SVpgGaXw17NvdvtQEk+8728ZodvzTrf4q+V/XxGdGGwyM49oqyFdeJlj+Gnyt2BxQM+B+7J2pdZAMn8qEXTTJVvAAgJT+JzKdXMYmEk/7L6emeCdZmP9Z0LDAxhbzCfGjCYl9eMvRbUvyjbCkgkVEKEWIJNnQKWxD35o8s+0OSG4ZsStMC7XyTBdQEomnpLp0KQtbpRbTvdxe2YHDVOSWo0zhfr9ReGsvDXJv0YSBil7UDrbfc/YJ5vZp5dOQxD658gnalWLMV4PsRpdyRiwpuQ+ZYyd1qhZeROUs/pFvjD7ZitLPOPKYdZKsv2bN8bKFyLKpM2LtIoyvmIbC/DMyrqlddGyARl7l2qF3n8vhfM6NP8rieqEuTK7+0aY5xSJqgA+PK30ymWKjiPaaXjsCJJam+XQKTSlmw2uL7wqRlqTOSWzD9A/w06s6soYgu5zmjevVhsX76oyApJpp6eJS9my7/ZPPN1Mpv3u9b8XsoRDGGusPtl8plkC3i9tFAc1xjWQXCbyA4Hc3y7DfrKpYENFWQTA5SxLdGHqfR8yd7jHxff2qVlegltHunrJUPiSPx+ai/gxzMBMuUnpo3kRtXKPBG4dluJMQI7/CYf+v9OYbg4hL1GXISB7815DfIgcfOYMUPBmgm9Sk7p0SHi0PaUqzxsUk210xDRIesoSraIHgDGcT/iP2hJUkZD4EIcWiowmwm11CALNDTGHQW+0ltses9XGcB1KOshnV/BoD4zRB1uYuF8CHMY/ArFqkB7x0MV4qHNNzoDrt09jZh6LGn5f8IbMnvr6DfFNz07pcIJmijiBerjrEtYCE+23Ojqym8mKtBw6KmiTg8E0Vv2Jap36d0NnklHudfcrHjTm0RVmEXwGmjqCiUiRW45zv7PV4TiJ26tPQ+L2BPDshKOGizSynCkhEwvPMKhUCwqIhY0GAxUo8ohWzRhSOPZRm6UQOFe4NUyRPsfG0yy//2eVk9sh+mUn4YG/qhAhpjSTykvViVCSLhuaGtb98/NcPZJSRts2zJncrQfGXOSNQJ/JeYAiLdDpDHvlZOD8Na+zfrl0yQYpFPWfGie0hMBZmH5Ltpb3Btivr3T0TQCUZj+gqXp162Fvg80VgOs61RCYBIpzckQYaP9ADUccqZdfb+gTerS7q6j8rQvx8GJzxm3Z0L1o/OYRKIqZvCPzyuQXj9coxj1/n6bW/0uCjTeCkUsc8AG4azrsssi1Ppf/GH3pfAf/jIWSa3Fp+96guYTMHBuoLG0oX7Z439lDrzYe78cwAngV6TuOJL+SSsyxhCoUyzXl525FxUALfirpqEI/v+s2Lg4GX44pWTu4hPQW1crDlaWntvmBUFPKyhvQxRAkXfyCvkDulqXzxrl9N51Cow/US67BwDYN5TRh5pH0OzNBNSnqEUyJyAoeP/GQvgzvkfTl/Ox7FWpJLGnGPbA2Vk4KtWD11RKiHbjbxRMI9cLb16AQj+VmZxahtuqecs3Fma9D90icZDDeaUshAwa/M4eYR0WkSXHDas6bKIquRsA0+3eOyJhXjgaPYhrEbncAxkimIOctSPuo2YqQgyZmCzVEhrxFCcZKWRvYwjz+ryJ55JhGR9TDmDK7B8sUhLpPoo7Fwj/r71pxTQUO7YQHOnQkPhAHaYuzMZGDoawBHPqxI2WlMtsrIuVc47esgxBkh8rZ/HZbr1o46p6y90eDwK8pwhmFlji8IaZGAlvCQRJwyNSpgdnJCmmg+XpB5yOZsTLS4mJp3y/kSU51AQ3Ob9xm14zVMOhHwJklMwFCrG3URI4tp3FshC68J5lW6zphdJO2rlnYl/ckXgJuazd0OJ07/k7MRt+L+PSHJNhPy5Q1yu5RCrurfukKjeqpyS9NJyffve7dUhbeB2Um/jGXHug4/KsPT7RZi4yW4F8Zsa3EYw4qJEYWMSbeL7MgrtxanpKQX9+vuTWghGyFgB1hmzEG64ayBH6+IRKMPgA5sWfuG/+pgRxe8kvmhn0ZC1GxfEdVqs8pPn9K5SuWtGdSJER+lBTtW4QWkqqt/7ErUC2YmWIArARJkWN17LwYR5VCyOnUG6E8YmQwoPzNFGb1QXr4eybzp31AHYBaloDkqAFbmsMJQPEipWKgiRGUhy6lDKr3G14iHuYR9oar86uw7nMC03sWBhk9wX1HDDQbIC071sOXmuebBQCXdObr5lGOuj5UjauZEb/JX8UhwV00LP25S2rpQYdPDQlUn8eUY3HyoA1dWbKBrmMqNB/sXunOjG9hYFmAvX8ib5g+yyi4AXADUfu33SmTDOEP2YtZ0PAMVYXevPHpUxM4sI7LVTCwlQCxJkO1dUaQmjID+Sy8qLuDOkdi31HUH7mL/kC+hkBdIgugMISMJ7+WfgVriZ5BH25WX7DYRRiwRhh1zGLVE8rX2n1/bwYSfOxhE5rGTCCmfo7fDKh6KBYLWwiqNFXs1BHTZqBtN9oY3cHN4jd21vDl1YLo8LnFvTAir17fXIJ6Ga91x5ViAl7Uu1ndfofcoAgIsPS/uGfpN0XQe75ceB92+grm3wZun6ibPo9I7R3j1Wrplvps5lEf9PInjobhs98ZrZCME3Ey4dh88nzN9NBrJvAWnjHJw+Pz6v46xs12q0rjqt2hC66bqSwJMz17M9Pvi99UUsql7yAGjnUk0bHgHBOPBnkl0hZWV23Edx8n7WidHDmmnL/KQ3q3kw3IP0L5X8RY9afpmRc0+bCDd+8wkxw+9HAT2yb1QlmoThx5F3DmNZqbMOxGd8mXotI9A0nQ3wFYrPrc+nQadfw14cQZkHcWePoakp1KA5FoFzg78VKp/FljZaRdcZA0rNp3dL21kxgZI2ChLIK3x7a5d8hzhXzwSjlb4/GUXWNxYCPXw92/61VaAJruwkAOfMbXp6cuS7TfsFpFTWuzX+XcR+itFYVC0z7D2s6uM7VOsKP6YEx0bkKWrWJO4A+8zUD85B37WtmSDlHn/9KtykClUpXbXS39N9QcSv/OSVOkUI3K4xkh9T8/M8FRdFbHjd4Y1I6OMyqsIV5JV4dOjpNi0//vp6vfbjWBg2O4REU5KOQOKZ4H5v6uRce+8ycCVWFJYQ8zmTUcax628nrB+LQwiJI25nMLy32nhW2GNag2buHj9ib6/MhaTgQxMus1naonMtFq1B6zIRFZ/wJ8MVTSDhzHmBubt1LN/bma7c1OYm9l+jiGV3nTFMyHTKznhUlDQ5+NBQf26Dvf0k/kEuNZgs0npZEJF6aBV+xcqRQTHj3yEAy5P7G6jx3Fseay2S4ppvMGdyIGrvZkBC14e7iaXX/4Qp2DJZe7bX02QGLnyKI/NhKRhKIwMd9Vc0SedZunv3HaQEE0YY7ulqi7lZR4bpvbUkovJjPOLKYncyFr06IThYK+iNJffhkoXS06oj/KwdZqB9GZH/OawNDciZLqCkuMqfICW95OpXb15kMtvLfViGve1v57K1pvkv2J/HAlkmgleglfuBxd7Eu3Cnman9LABCf7A9Khb7NR3/89TF8gAGNbxN76iguawFQlC56l9JraLj+Fy/3x3FSHmW+ixqOgyz8YWz9SeUErgeJYQvTXSNdqWuicJFICIpDIrRUweVgy2vYojORgr431zP0J3a14TZfSuo5CLESQf7sKK+Cv+nBKl2SaHfHwQ4quPj19kIKLNv1EoZaWgOY/EVbipoRP1iQDcZjHRYlERN2et/BwiCY2hObKqda8gvM8nhTYN61rMr1nLsUpijPeNbZmZ9aYxJMesjbpCaG+2DI6cz0xYEdBuUjzR/ljh62tFYbon1sdOlUjKdcr5L3PajEDk1l2j03iKqb4ZoWtYIGM6LMqLN0kBc4PBUPnydLgXVvrvG6otcZM0MWxmx/9NTVjJjGVvpLCyX2XNeYoK9xuFqAt7NyhBiUnfTSw+pVKp1wHCwtYj4yll/BdqzLQTH5aKGAbgAlXoSP3GPTvEMAklxZCF5uYuZ5DuvnMkW9ZGYSecFXOqwOKvw52pfSB+JfVKMPbOCbG8OAzHrOHw8Us78Z6UxaCCn0XK+WjC+yAThbkkS8pEBJYHrzmG8V85mZPoLbI/i1FpjuwoIbwSNpVred5LvTSIZpcMtRjpvW96C5jtiAVSZZawrHng8wk/kqZimoPDelszOVUjadjgV1lMCj45UdSl0Y0o/hqB8QjPPnjrbYe0Dg+z2U5AvzV3tslnGuVd2tyaLJtCEoxB0mAQtb5Vp0pJtzwRahkbN4c9ZXqYGlUAGw279uoC32wdr8ZB8yi6ABjNPAPsSBRaGhDF5mGy7/tXtU87HFU7o2ppKnrNI9uupn8uGHf97NI/YGGexs7p/Gh6DcdugUMRI3lUA2yKpFynw8STV8M/bi5SJ4FkkwCxhT1ygQLJZ5zGnQ0M8yreIVSfxW9V/nbdM1Tzt5iVtw5J3QhVvC0YjHQCyRb52u3D3rQMNgG4NTZ3V/HupqMzLV8UmHACm91USUgMQV7R39mYcEEeapxAZB9nd1deQNN27WjMxV4bkoMokzvRjeVXHjORW93ArjvWZK6GKoypXo7rx6EEgWkQt0yPW+mQ1I9jGoQNhyn+gW259U3Mocxdbm1QGxwz7vXyxq1YtvuAorg4Kh8xdt3t+l9DPFrLfjxUAPRPk4u42C2yafEBs2WMwp6GlWNMeHr/e8tp+VM1wMVK9DIIDOdWj8AU+AaQMGdiBVnG3+jCuJs2+oPzri/2MLtrw1tFeWmaY7E1o+PPKkm0WWcg09Mh+CeWKXFaeMa4G4QiTPlZkh//D8zVbEybFfau72LM5KCyjvx5LAchgwHAg+icF0B22YFdlkgLPwnU8MzsVEzVE5PHQEMrhndCoULFnPdfhqz5OKv3f4kqckdCY0pXVZU+3sV8OnBE6/lST77lR49YyVcF0pKqFZTYrYQXUvpbZB/nLorfhwsDj7+rhhMFmzCbLN+VIpJ7I//kZYO42LFw12m0cbczGWOKQSCsn43w+Ur0oyeqzlfqWylBS2o+QAwSNogMz5vxzkCDTN7qpRw6scjP+TsZ9yzBJz9oFFLoD8S6v1sq8LNPxmsVACb4C1idUmBbe/QG5MWcg4r/KVS8F4pFkBym0yK9nCd9KRxF/R9PdZjf4IHgAScfB5f7n2SBVD5AKNc4IWrMJhw7cSKAwyxXcA9rq60l7NoZIX+8KUNY6hG3XJkXQCvCxfetdzx4Mt7rlVhEYNlK1tc+eyzUIdLmVzpdV9DHRrbk+ez2Ra4yGUVlIMozaiqywCppxuu5QR99ShvAa7KZgdjj/vyimQgy+qLVkp3iO0opMSOMjTOalQEN2Rojk1/DjITZS/HVKGF7M6D8XIG106QqJDMnISDNhk3DtocW6L+9L4domRvO0eVHR3v7Xe3wTCfIrnxHjM6fDnEaSSRreYGeUH124GuLofYMIVmkL0G+8s/zIcMxdO1AcQOfh/e/Rc/jUAhTgXoL9kozLXMBxEnyS4ua8arnePxoamfsrwil3ObhoXcIyAMtRnUspjXepEXfDshEtXF/8b5AgfdOjXgzXa2ekluGYVHTIYgsI2IBz6GJ2qXxVd6G2ns1x6NRuleDNQgLDa9JsTg6X+kO3b2mepMPDFx4bqHvq5pb8V0TtwOeiK2JrX2c/8ro5trzRc0IR2PECn/ac3tfpnAneFO6sicxuYm7cywWgY81bqpDgin9ZXQ5H8ng7ba1aR2zf81qJu8zOBW/cHEbqYbAyJgZnu+U8gFhtRzPjOZqC6llRroD/x0h1ksxj/PlVF8KyBBkpr+7kbIPyYqNjkTXMlocyVMWIoCXMPqaAAwHVc4ADDzD7qOLXA8VuQ0+ETvsh3QBlz3aMwGHz9IiM1gMhxw3bjdlKJFW5j74zDb8hsVt3AkdjsXUUCJxzi4nAFtcrY8jAmH0Ogei76hwA3dDFp1kMjMV6orjxV+lhCqKT38gd/LDP0mSXIQeJZoRff4L3g0odjvsFN9+CMrl9S1tvYo/ziIEt/mu7FfBam0jpW4lfZxHtZcwAR5dBc9tSmEhw+84cd+c+NFj4ebJT7lXfUHx5kAv2b5zihGEIDJR6BnBKqjbJ1Fo1k8ZSShMU2hJcJUaec1FfML3GAfJbd9HlmMhStItlt7ffmXAL4lydypM65hXS/oR17fqRfV1Dg73nZN2yARGmosvYRVlTHDN9spkHA5R9WSQym2lMQSwkYzy4EqlxS/Ti1+D2LEE6WhrN34A/EOMDYqZooQVC0sBK4Cv8YvWQiWHoZwQtoq4G2dRNUh6q4YsTfdwUuNlZNsmSZXe3XSSkfrNmSxIWLa7DSQLcg+/LLxbDQli2bcvo1wpFHSHNQWa4Bu4Ruj3Ux42wp0q/sRq7Qatv+iFYlo/p50ReHTHA8Mt2+8IDwmHt75Sc/ZOsHvQTIqpMiKOjQoaXHz7xV67rVfIBskjQK21WUthXFz+3Vmec1ndBeSzL00yKyltcm+1ghj5nRRsDeZXzcRa2y+/YADHFgZb5ZeOLQrGs0aFYHVYruyIQQjzMzS2eGIb1F4h5sMrj82i8P780CLQ6H79SkyFMhQjDbDRjJsvXiTZmPOO6GozvhH33pa/bDd9BURGjQ85RCDfJRf7tgwTu+jZ3sNJwvJOkBWGK4UeRsg4YEojUDcHPOvSjuKjUlGss3KnHUI3+TT6JBOgr+L5XTYARqf1kVaQF7fk3GHWRY0aeL87+oYwHYOPKdX3gQIFxsyg595yf9ipkm4XsYtUEGQ6wKBSs5ryMMo1+lNMwMCSgexCQfSc2yAzB7Umq1X+XF+Gj6l2UHYUmTP/9D0gBkl8n5K+OWHxlHbYoD0lbvr8OeEoxEWAfiEVhzQ3H53vP6HgLv9YiLwXeoFsNOiR+ZryZCHvOqARYYgqMnuOq4Rs63qmnK+pcNkG+C2c3gIDPH+zRmV4xqoC9xOmB7EoRrlZGOb4fnrXryfpX34gqRSGDUb6GG/L+nV0SUpdcwai0aIIruQpzrjRiDC4+dxn+/gEzOLv9YU5OfLVsCxMRkAM7Z8fThEuebdvnTNUhjy03ea8dNLvEamavAkaazdVc7muyYqhMV0OLmW1Gzl2UKN1o9DLToI9/Bt6T8bukqRaBvAqC2VYDCZqGtPED1eUDLfYt5noVGfpjmhp8Lm1GHlsOtRitJmhr7R9PcPSrBr4j10nYRqE7Y46fXXC7i6V8ApuulbYRJHp3nLK+yDNaWUPsAH+mtlgSR546P3V4fqBL4ACPkr+J1pLvxgfAV+eHbA2nJr2kCqotHYtBFgIq+qp8DbDXGvOSgor4frznZRH/d85YKk1Jigv2uNVW43LJYJnq/ahSCBFmscgr/ay9AJ/QXS+hPh15fZCPY+LoySoj10dskq6en4vz4mZB/Rirq1u43bVaagIT0ltC7wCKMGq+sWpn03awyBuUaYOrvBBVDjM6/iPEvQ1GFLjRwH3qVtWCyOCaDQ3lRFOavCjIjJsZ8jMw4nKPS+D2xp2NKdrkNJK60qG9RXPpa4p1UKY3BkpbcjGdFtRTnP7z9g5APlc4LHbz3niA08YdXoI4PPgHQKvZvyiNYWGtP7IJIlW/HLDXWz75QmvFV4Sble4H8wbMSkI+CI5g3XzmxNsH+nB0aLo1HC5FAr+Behs3a80ny9RMsFfwwodVzRYVhE1n2Ehu/t3qDkBRm5SJRtDIncoTp+uAMxp7gTZJpsXpaiQpKCGZlmfA0pIANU+AV3vepOrdzEMf2wEb9c4go4CXsoamW/ZV/I1nfRdY8+c+tSxGlu0ojLN72o+VEUZ09/eFPdaT4APhhmeHRzuwQC/eEnS1qmmH/ooW8YZh61A0mfGWQvWrWG17RIc6yMP/8+6AHNYAt8+c5TZ6ufWs8WMjRcSzE4uuhrbhqtt4QIgQQu87PhSz1/KWdT2V24Z87j5RnukMBupqEPu5crQcL5tfTA2HEqb6dv8NSzTZtZXm492+2LHKy543m5eTCOIJvadkn+lZn9qYYnB/fZyP2lUOnU9Ce13JBVDNXsQER1fWCN+o/GTdFffdBlaISBx0NEgDUASlFle6+Up5BNfJXPNhw50bGmHJZeb9nDpWtiP8v+kuz4u0Iw+oZ5qqhQNGcQ6Dih6NGjq5o57RuvBVYxnHOfdEeaQsz5jXlpnbDTYlKKk5gSfpe0mr7v2yEssyx+M+/BJrljXWSzUSQrZofV8oUkH2Hpv1xn1nYtZ3s6t4TcRmcstyd33IArXhf6Keszi2STLfLgS0Qo/gIE9kZRMzIYM4YF8xJgkjr+NgIAR89rUT73tuGGaq4ufLVHNelxzu8pgUKTcNjesZB1cXNNx2j3KTsuePlEns5ntrJs32UuCTXoyTpSK9Zh5qa4xpxE+y1/5Guj8fSPB2HWyzgIhpueWFrrG+or+pIZrs9NzDvt1QQKnOtf3C14DFhhMvDkXwvnfOvUZ9DPdeFgDT1A1lkrvNHkQF38MpdaYhs8f8w0tn47X9TU20QsczEWgI2EqlmQvGFZ/TNy8khooGs8Xhsqvx2irTRKSnOE2kOShw2ylD/YHAhNazAOB91X2fOdCBCnFak4dcl0qStgN2JCP+nE0SqKcmh7K+Wfpb42Yb51TUEXexf6lHW6epKnoML9x0Zq0S8DSovyiSJ+x1YzB8AIfXyHpN/4O8Ry9pXzaeT7FJkxXsdkiZDx72k9sUKjfmZQ1Dazq1s3XQyYIqulUJKumeLaVClIYvF2jgMImQwY8ESppPxvPMtYDkrJbwyK+4r5w+C/5dzxrBvZ/KB2RwlHwL/U6svwgewETIeafdy7sV7RM17qAEAmScIOZwIc4VsGFFDAtDQ6RW9Voa9zqnqhUViJ5KKV/S58f2HAQB+UkRyENbe8G7SkjIm5FOjcWsu/NEDeWHnP8yVP8edCvaoethxLa7pmwVSUSchE2CMVsPUYfaiZAINA4vsLHFdSrBFIKOC/QINwF6yrvRlM7FamaQAc8P+3ijuR5RxJRpUs9rg0xFUHsfSDROj/08JmbzfLPHigQMaKJ3PmHQy/nezk5GoCYzcMGDbw+6QtR3Yr/5nKpjU0JgRsgkOL2TrMEDq4A661gXN1L1+hXJ7lIO/7DqDPXUCGEzayNJUt2K1Mr60nD45B+tJT0gfiQftUNb6yZbti2JdF39ZZYDMlaaU7bIylUOLftUlfbXnse/fF83COFlMDoQYyvYlKI+Ov56VZzodUlqvUdRJY814w3g4ZwAlpMCvKbKVXJG9m+0exGZlunpuz42Pcj/AaTf7cmKs8Nm5dyVYBrUpEVgE3tqM2+Cj9OwkeP4emjU6ScHWpb3DR5C4IS7xXx8MetZM38QbreJ75cuhxVTzAemH2PDwKVBHFqO2bc/o4YVhJoo336hQH5mjI9U4BWh+OQLJDvl0nFrWyN/GkY8gwBLxQXF9zGw7f686dEWqgf+jujD8YsmcgVKf5XktKe1uA6AvmEgnfQkJ/tuF7oUwWovHiVTznAgyyIcaTP1x0j0gMMEn2zZ2bJscZzZ7fY2rJYfUv5Qz3UhtTKh40RkhIziag19Rnpe8eXs9ZGxieoIDEwGqXRQEP9IC2vFT0QwPGIEcXGi1rIiERP60XgzbXgBq/Pv68WcLrACZvD5tjFS+E/socEc7ZxMjE3kXlRdLJpoVWxe6I2f+RO+DI0IRIpnUj75q8tYhZeATuq+k1cJCAkjHw252Z0Lgoc4puATuW8idjF5qbCTYu6U88g49r10ygOwL0LfqklsSkjqn0Usge2XuWaWFNpbzNbO/0urRYXO0iPOsbnJkBIUwN06RDd/r3VsEeMOc2gsIxXNcJ8mIdOVVbrUYJBBdCTc99n0LivIs7JEdNtrfhKXwtsBfFu54v+JqaqFE8NXiHuTkEL247dZO6XXiqGwsI+Qm1mbcTNfXtg1GfDmriw6pRNWt+uwQFuYwCxznPDy9cqaruojdacVK/AYwUjfAlScEmJeEzSp1idY0eahi0i3+6twYTIZc64+hZMg5//DTTY9wXP9J7rPrRZ1tUUBX+9L3acgnrHR2HJDKuzvyhgsapLP4MZ8snjKvdCmrs/x1dcwXX8OWArqNFc9eCr/j8hNq7lZN6P92hbG8IDQiwG7qGpPERFbB2ryv7uKbfNZVFmbYjJ2nZ2MGxIBFfvwIw1/bGEHtNZKw40j5ZqnzoYyTrEDZPg3aLQnfTf62Xm6kNk+FW8m4RNJt/KffKfuRn0W5cw5R/MgJwLA+t5h/w8G032k7D9t2cfiTMQF/KfHqm613Teb907Wmt8Bj6bBCQEoeJCXPlnNo8hhKH1J6RDQJBO7t3EU8jsDzIeDkqMni+gjhbo+RCGmf7Ui4JV0+/x5NhJpus/Cm4JhhtCFRwKCFJYuqvvist8hKzkyQG8ZSdfvQQbxA8KlZOfim+VG4VGQfIdc3uT0a8jm1FmePUPxBpSHIKsWmC8N7nIR/AzTv0GqbP3gZHqVWzhWqogp6doJyn9/7OTeCc0oixZCh/+X/GfoDLX+OGScWIWuLgigx9A9fGLtZgcXKlJGI5XbwNpkDcD6iBKZacVf1cShN3lTVt99rmFSzmhgQ+PgJywFe4qRHZfwuMHN637jcPqUny47/T1PPEYpMvVcb/B4pOfIL8n8fivHd4iWvR4PqryJM/V7poPJQ12O9L5lWh1dzOSoAmoZfOJXsnPVAAIOghV9w+dVzgy3SisFlvPnIsHWo+Gg6jb6k/CkPWgwIVafSe3VRh+541XV+oNMp6Og08jCPOBwKZxahrsHgIRcvxoEfvWUzhh6ST54pLVlOrclMe9m6L9ta4b7uJs7wbptlPohs+BsbHFTSKFRmySWF51VLatJBslHCx+MOIV7GerkMC0Mb9IWaEspnIgFXrW83yjbDaRDBQTU5mfvZDqohklj7KfwwAPB4qusS3pZ8lKGv8AW+azdc9F0AqVkmvlWaaxy0lMtczwtCWFKQY+ljDrxPeGMd1ZLnpcpAaBFUsZMw/vGFq8r+gaxac4lHescYr/WXQuKrUL6CGh2TTJABnwbN+4H+Q99M9D9Ec8gYqL+9sY0ema9Kc7uPGJaAImMf2LEWphHOeLf6EXj8uyo/FOEVtYL/324fc+PFoObtAsGXP3u9NkZGB4evlhr+Og8GCT4XIYJRzwulhaozlb4am64nhm/3Vn0H6M2zLa3zYoXuKYynEu2MWahayR9OHHV8J4ViaeGvAgfm66UXb+lQ4/3CtmHws9l0PeaU2stTkjqHroSIGDRkk9j19DO61B9wkJnzqxTsokol5a0ViUgY7KgVuVlZ8+jvtU86JgiX67X42y3GqLaBFZG5W76Rco1U2TKd202PJDLpDa+jr96wMR3ef6wxny55+i9Jp0iqSykShWhwyqFB1OS4yavrTNqJvO//VFEE+JVuYgFtRH9ZeWgKruTuHnlKRe/o2rEsenBy7M4tnf6eXCVs33Z6hQ+DKhnCOoybXuMbGu6sRDakBPG4vhq2oBjZ9boTQr8yGb9odnwvzEClc4c/M60rQihi65oIgoQ9gxzlvyeENjCA/BgSIaM9+rVzuxXb2RkBy5BfndNjgz1JHvz+0ZWbcrhP4bwyKLcU3wAs/hOkN04DYjeJgi7Ca/Jd3ftQo6HEC3Pnq+b2hQLrrb5ezAnV5vJp/NVyTOfRfUYyvpRBLSWo5os8YC80U7HQ5KwgzjONgtnYSwMZ23SNj0B4p9lcU8d5oJEz6GGsKmpuNy9GxAYVQ5Z7lGxchj1VDxJfOSzBBeuPfFDg09wKtFbY+1ipUFeaGUmdyr9/Y03wTXFoVee6Q6AJOpbuluCaas6QQa34KIKnh0kC+ZmocZSe/k2BeZyEFVV4Lzio2XvRviQBq4pIY9eQLtjPDQkVHUiljV5nloPbkdAYAQYB4yQPf7357zYLNPTVgg00aqmkAsXxSa2fLHchGaFt4m0pu+Vs1fTnDQqLA9SdEbyVwL2rhNB4WWr89wdbjuHmAv/esAmKviQpZ5fjOEgDrmpqSIDQkh6Jju8UyIDkd5Lo9yH9WoeJ/jR3couzwQIAtT3dIiO3HCjbIaYNKcKQlrSsPIpZJUbJKrvUeLe+eDe8yBi79ejQYh3cSyVqV9Ozl+qNfh3IzLQePtZTmgA5RD7tCBVtF/BPsCoDrLDMIixZkmBx33IPHNN2WPptI1FRHNxTEfJPFEOr7JY6NuaR96TMohHwi/TfmaHIl7pTtmR7Vl/r+aFTk1cVBYIuMGe8/PkyPeAu72xaESeTsE9Zp3IG1kCj8kHc/Nd130MxYCxToaXzZJH2gIrALfTcEVo9w+PSiXyk9Ip1z+y3i6QEErbok8irKxhHuAtGuxgzROAs1q+2HMgcDv1duYVBjqXFgi4UFL5ddwnglmiSgwX/K+hVTqXR9G+KSEqJLDkgr3r+FJoN/wTS+bsGvljsvRokdECnZvTrOcNZm/hjMWWfvMV8M/WfpXBgxs7ZCYxe6NG9oRhhy70VOO5plMmlU4UhEWTSPkLiyKxYAdvOWsKlkpc7U0maQNjlR5WFbSml8QfNriUJUsrHpeQbOd6NzJikWkVwMOLTTgiibAHU+Loo6gC7FVTiouPEQBsq3NfrqHWfaj9eTFApJdLymzngQ76J9RgxWriXy9PE772KMbSybk2e6Vyq5oFtNaaeey9SLg7BH4fjee1Ii/yxBYemjtefBHnZ2Dul+76yCDnIblwDbjGAFJf24lfwlnPEERd4x+z8+yyXCYHbICXaAx9UvKs8aHwvXcx7vXHs4WmGngNIqnpTSpBBYm9JGZR6G8rAd9E6ZhQ18Z8hlMOsrLLKyLisz3f7mtcRRlHQPnTnTeVnQAqLkQbVZ7ws9mC+1cONxh/YtXiNRpoP52pAUzPBFeckwJpjDf0+Tbr57qsszh/vvheKQX2rWVsD8cm4pcBmPGipOAtSKoO8qLMI/VQ0wQ0YGeMPX95Qk7IZSB1RHF9cu5P60cpyd2UVPv9bQPG6nntqFIhwTAKphIxUibfgDeAS+JbwWSinfrnNLQbJPVx2GJlJypPR2c9iIRaLZVwXrG9GO/xg+P/O0nuFegfW+B4Csr5pG4vh8KvgDGw6tKYu4Zg8ZATUwsnwiJ68mRopo6LKjcP8h77sOiUEhJpPkEvtp+cv7KicAwh9dIU009Pnuo4ZpO6j96xETRo5LzpfG3FeJ+Tpv8aUaAziQxBlo8UoB0kCJWsvBFnrtJKHqzEdRFZOZEb9R9elrbSvlZjGvjbKpPnMP00WMD0o8aGwdjoXs89V9ubJT8aYL82oYtEY+kd1Ylhq34Lo9qXp8NuKMy3sW/JiTZXmeffUwZRs2Y4sEFqTL4gipAD7UF1BZTvtv+YL4mSxagd/GfZXcf7zuhwAkhXy0LemiAZ+BjXtKU4tCKVv0WAzLxFeRk+zVLqedB+RnVxSo0hC0OrbLe1d1CNtYm+r8J8dz63oAuzQoLRtvJGXC4fFrMzaLI2ejtexm5Wza8m34N8iAkQO4N3dWTMe2iegCO/JtUm9ULcDI1bVvq4V5Vrx2R4ij92cbh5dJkT44n8TjyQZZj1VLifyPKN9qRlfnUWUBQxfweuUVcnOOdRXioF7cQ8RM13R6MZU2PvkVJImy6/MkoLhewm9Z+nqb9yQNJuy/ENhSDm3S3lvkON59UTrIN4E8kEWEyJ3nEwQTkjIw393aDhTnlZkftevGZ9vt5EJ/NJ+lJvhu+pub3noB32Z8vVBjQS1xOiQakCKwZiSw26p4bwANk2QkiJrrIpKukfGMD0fktQj2e/gxiUsap/5jqdhbO31/9Buh+rA9x9KgphC+RZMBPZMRczA5vg4ag0wjpVn6yxrclvnaFt/s3IgdjT1w9AuNQTLUQQ+mMO1gi92RLzVPgjbNmQXzgQzAbb/k5U+E3bcxWUEKEhiZG8zS05pwLoXfkftYjPdBZEHAb9W/PQBA2eoAYeX7SZpjD3oXMUK3YB5ZrVB8hRtqyB6tUyu5K3gl8rvwMmiLPGyZuw+jEmUY8sJHbWlSSpa6eIQa4cPVrmZwKsXefble4pDqQWPQwRhoO0KB6Se06/DsXroJyx9P4A4ft8NXFb4pFbAYi1iCaj94Ijxtb6GCI7fYEhACkAoidGTzIYcCPe+f5wwEkwKOjTFYCMl547qXuHKvynXY+oraS39PwnMPLxlLM/4huvnaKxtPV9fXd7B0o/ddXMalrtVjY0kuvyBD59GG3Cp9nA7pjSrr/fvRzWuH1Ogq1umLuDdbq6xS7ix5zCZCyuS/NQZ5jDBNe5Cq6M6RFVwiUGZ9fmtLOQJzN1yeCYbAcXsq1ZuMmQnpqMAECpko+7NAt31eUCZN84gtCcte5SUolMRvZSbmjW/I3jxUbIDMu1JqfxLQ7WepkPAC3trIrk+pH7eOytk6Tjuf/rjKNXf7v0s9ME48mEiLH16WBR1rr1PDfLMe3ee9Q1oGrH9UxL7rZPUB1d5T/6orBInkTMDG4nB4xNr/ynmRGL74+SlPcnC2i3WpcMlx0fA8JywfWrQ87ZxD3uCAZlZfvL440b17NCqbaTeWCLnnTZSpDCm/OCmZ+w9qfc3BThx0ZKA6BlxQRQjUKVEF+3jo08ukqWcPGmH+svm6OC78IlqW6qRrdz10JWlo2nn98tUps//vRD6MMlHVJmafv6uIsIkgxCtcjJ4h5igdijsl7OSPr5cqF1N89K5Bk9zuxI+9Sdt6lrTipZ9zX6hhgdqfTLtLTpHK3rMhhYxKkVIPJgs8XG5LGNFdThXWwbyd0YnEU/Vo4mb6J8bFnip5s6GhlL3OyaXMW7vO0gjEkwR4IfZ+1INbrg3lGebH+tsJD9egctEZTo+NczV8+HaGGyvdAJi5Ae0e+muB0afYbwnQ89nSgU0Lc4v8QTY6BEoDHBfjnUP10d9mCG+SVXI7eFqAUmHDUcjxbg/zHBC5A3fOTi6uWiPTpg9MslSVrNvDWsCKKWMYG1tGXfUmvFsU/ZcPw+DhGNcPt2321fUmj5WIFAL+2X+OShKflPB3rQCiZyD3a7R41KzGsAnP+2nuWKlS0wlQD4gbyqTebvN98izTOS0OhO8CImet5bkRi9Cz2u0Q4erKEoaHMwf2Wv2I/u2LsYtmt8EnDElbH878c5KZPyCKeG0kVS0e3HI9K1LgrzDd6+iuX9iOjX9yC90gG9srwCVo6OTXUzaRBE81b1gK09U4FyUQ2zWagr7EkqfZAixT+5KPqb1M5fsQw8WEi6jZiYn3brs8Dc7Z3OqayN6wp9r+2Nidf8gpJO7lz4qjOVF3vD0kEQ4xGVH8rIYnfudT5+u1zPJuY8yMRoOiI35sPvN5ykzCwRHSohI/NJGBgerhZBrBDf2uc/+1K6x2wTYPY0L/g9/U/bH+irSKca6fGPX/hIwKGXWtAE479MeUkM5zQGuBghTXB7KfoIi+im4wH/wJZsEFIRNowNRZsFMLDc+SsBSC7pSQyG4y9N+qc9AGDGzD5cegBVyHnEsRuSD7ACkZI+bSIMAPeXyHbWYvDTtUJ6K3gkCOrl6pWywAWL7dBzHpSi34gsP049sB2s/EdJN2oUQWStKTLVClEeOfPfGhO867NoCMvZZwGOgkdlmbLu6fy5HgCZAInmCWNWg6t4ctO5z+PT3l0ma3cGo+MEbAOLgYCj+sA6MDnBi1Zy8f+DjOaan9whWehxYEYmLIt2ZhqUpGu7VQPO9R6rNcGIe/7d8are3u2pkm51yDeDDgwXE9rfXzjv7Sy7QNSVkx2PBaw/f+cQk6n34+KZ6Iwq+gR9uod8JApJ7TyS2IfwgkggYdM84/xTxgNrk1wOhP6K8kGTAPcLed77UtKuwok0TnI/+nE31PIQtHfjFUgMAUO7NSYO1jeeHpHOh+XCyeqn5sOCuTTPm9rTUUYZD/UNEco0qFCC/VyrYYizIqBqHjqRe/rmMn/Wp2nnVSEfDH0ips3hM6Pbex7k0YoVqQoWAM8vKoZlgQ3tA5ZlcyT6yduuNILub4Anfv110t5PsIXckDtmNgqqoE918bmkM9HZoA+owW1qcW8eH8lsAdzleqdM8ovpu9VRvuB43VZwX76RZ7HGrurQdXk8Hw9kbod1UbXmQdq/GdBm5Xh9TbmW1R6QFGE4mm339qE57/5WDFaFJDkIzYnBgjDLNpWKqSwJT4T+aaIONnDVTpmxFfT4RzbQXawOQ61INPAm/NAUcl4T3/DawDbXlx/dcC+UTTWfozR0oTLt3xE1I5HsVNAKu2UEaCL9E1olA2gCIbAE1lxKYDhMKYAFXX0eU0oEFQA6e9Blr5b4TesS0d7nVdkh5hHFE7C6aWaVk/iX9jgWJtaPFhksUjINXP9a0i6o+uGEdRWrOiWJIYBBd+LUPHhp6TsisbcQ/YB4krFL/7O8o9iLEWawmZlhS7iwWZmSEIksY5JX6QRcD4CzMeMtT13ODL/lk+QhY8F2o2La31/ixYR3Qs8ZK26cODbzkEuweZpGzng/1pSeNIQDBpiOgG+tb7i7mN6EnJoBt/fEvt4qQFpgjqV/FGOsiu0n+QFLOXLq4i6jGR0qcmvUd+2xrOrny4TQ0nvE58wbPupd04Z252pDTzR8SNkI4ZHAeChXAyHfq14IDw9N24QaEi60d3kjBlkPi2dPMfBmt8foOvbmvBdj6/mSamYAO7M+GzTQso/FE1OvNN0rzJI0/+uzbn9aNSzzc48jX0CiU/h4fmATs74dbxCH90ZIQRp1kcuv9Ib+hNnaOFOiV2/cqyXco+xFWNdFHsPHra8UYy4qCvOC9n6koHF91ibWlr0mmlpobRL3GOaxq/2KgwAoZskpVrHCO0Y5EUsHy9uCHgbML+x0KiUAVNaCSCJrLzWG7J/ftymjVvTi9ipjCtkJj8qmgvkqusaAh0XsRIX500/4zjSdrxUhMzVJOxojghjKwxEuZ5KJavm36bjsgLOtdJR/o2HfeBG+fiby3Wgip0h2yeFMLDpUaFqfU909yM3PRkOk2aQG2MO13hvYFBVaDoSfrZJB7z7bbWoO5ftDQLhaml7cnI/+S7Z9J++V97xaekV3b8ku3RGLpGzAPWVZaWbjdMUAe6StUZJhjmKlzGnSX/f82z16w7edZhIGHQq9LFza638fUSbHWwzQIibTRrD3XGuxWzvRKt0Nx+G4N7Ig3xh+6G8YlQA+taKQ4xxJcmlK2+pcAOmO1JLw3Q1h66z46GoZujWLkOCbKkZp8x8hpKJ6GTROY+oKULwR8DtJDHHIP06KUowBquoemnqGU8aE2QoVnAgnXdAaER7ZAbpVuAa5BFWhVvRjeLJz/pJyFulxTjHI37nH/B1sj1PLS78+Yc4V9qb8+K5b4Az3hbexLwOF2Ay/keZ8dkuGRS0ZCIH+RMLJAN2JETJAaRlQ6Pcu/CBK0nsBhgrDeBvQXnyMFIfX9YrFo4fzAtoyvJ91cAHwfo9iV2ELHtOvxFeF62wqvH6y+sa0j44HPnmxpB9xYB3e6U7w6k1ktYfyjDeTlEp0jPJanin9LEvgB9j8NuScmzrpC535qePt962PKWR3hPoMbcnzGtjgAMW1OW6XsknT/Ni7WtIRiFsLqgHSnnapFTSofoMoTRmqVd/p9Hfb2L61JQzRTIwHXSEnIVXJrlxDHWoUCk6eYYHFQb2xGIsIXW53heKm7EahJLpWOiDFrR2DhoEib1bxGkKXm44IS1JnHiVSR6Cqt3FnlI3jzrm0u1if2bTeB9zozMwgpEmw/hIxY3sTJk8KgVxXwu6NlAsmjbAj0ec0Lj5JvU7zkfBSkBBkwulJJeLHs6r426CXsbSRZZogCO94ZAqr8QMdPTSsam7ZSGHc6IGyG1NTnzmz6Lu0CNld6fxkiRCtEMmuG3OEqFcIZ4XxjlfRt5PcqnEbQ7UIdHFS2YTWNhF8ixgsvGS1rmNya1U8zHNAu8J4cM3vlus71tu9/AA6xUBh0sd/GtgTsYNcyKz9h6kKu2IFb3a0pVNA6CECivduPUvcEk6CZLphnU5xXyFBsmfsuARRW49FjO8rkBl2BIclCzbiPnSC4PW/MgRDzQxFchvpQGsQ8RZlqz2z3cybmySZz4TwcqWUkYik+Y1ZiQpEBx6tLAa1/kAVVMfj69EHInr0UrAywEIxYYHHRZ40iGz/OFuylqW90uIgmBzLLbbSoFNfYGyTbL1a7YHDPg5FJf5N2ZD2bCkY2YvmVESKeNUSO9cjGbBxfahrVmZGN54ZHEK37RAH0bHNvXN+fCwSPu1n8JPLR4c8JHrJmfWqjtU0MnhwINsDxUuZVvSEjomVnnejzPG9dSdt+IRM2XS256odySPqqcT3vH+2CsCX+hsofHCi5NX7zS/jnqhZNlG2DfZQ99Gt80F0R9nfBljkkwEQpNKGmg1w1oqHnEwZM3W5MyOBKFDaok9nsn3LNJ2acrgDAxb+EstsDQbGNJpZRVdzROXUJ9kB5Df/motVz3cseK/qSUPQ04mfOoMilN57vEthtmd7KiyIV3C7Sd/fgR39ssWc7xgIA3dVEAQkqPpoC6W04a8AmYUH0k9KBbeD1T8VatQI2ZjUV3jpLw2rmDimDjiqd5iYb+FtLgOzGIa7T9JDTtBoDhRfVRMAJFnlf9GwRv3toARhI2Jm5GxtvpdUC6D0qxo1x3l3d6i347eo8xM+p4A0GDqTAD0GdqBjc+b84xA0l8VuyHoKCNZnimx3ImakWXppsJ2DeQv36e5fQaZn9Bi8DpAZcGH3mSBeZkFfqhnbkqkYpAZhiXh3Ekwq26YQqtgVOPqv8TYEe67zrMYEP1tXVEwmjkbQxCZuLWM0Q1RPIAVf59QuLjpEON9ckKi3hYbxNXzutKQODUZIEAafIhmD86U5813ktLL3LZyKeV99C8AfHp3EKRdxI+73vSVRj5RKURIZvASGwoh1R+dNmPIC8LHsed+UpaIhiDDZcdrhLMEcKZl4vpfOei3MASaX0aLFLaJg0d1b4GD4snAE+AwsaziiSClgt2oKgyf4D4Cv88GGeW07dGOIhJfRJyB7dZSIsudn2l7+LMhQM9qhdGU2Yx2aGymQyV5KoDCkz+wxsdZE/RTIeg19YHjyWFjvPW4xUCChFr1hEvnSpzj3loFZfQimvGOR7U3DKu6jJroYErIJzvVbqbdnMJJVxCP7KbcFNwb/IIDPlt9fKkQwVY0hZnsjHUqgrkywxHrSaleLhS6fXT/WJlj+MVRdvpIbRhEXAIrIB2oMervzuiSMnYZwcgUuBYZQxbvhwpwOmMLlqDxyhhOtKFzFbwmtvks3eBGYSvDAI8c85LnHqNmGr7iYrEQqr6FHLFZvLSWjaYOnwiBOIG3xzbxzoXYGY95kAy0+6Pg1x3Qr3Y6m5582JkHg2lKwkL/jMT1utH7vbsCgtfG24xFDr55U08VR0B38YduAIZdjoJ8H+TRPf+ioLbtXgoGJE9lW4miBiV3EPyuY5GbIR7aONhkGMHIljVXlrGz/QG73SqEtkOj7XF4UnKwF/eZVHrCsIa6CQH22w/E8EWY0nUfCKaN+poZ2IqxL0wWxW7FJv+X8Wd0fBOOi0E6iy5K5NTZcGqz495y8c8pnVvYeeZPjtWJP60QqqTrHh7gc3gdP7UQRaI49AZZUyCK7wrMXIFOa16QLSt19b57eca8k6lJXeOWYFdMOCvsawwSVfS18WPOMY7oBlavsXFcOEb6sAqfTgVWafZFCbmI4zRDoJo2Kn6qSso0v2imGOvfsNG3pGt9Pqm95aQ2xgL7KVm1jKNqa2LuLMGGwDUjjuStK+gawYggEWPBPx4voh8yj5NMNarVjtui9V2RfvB0Umi4bLKZJTxV7CG6lBwWB6FimWtaMGnTkNMeqHFvyiDWErwG3cd+yHtwv1HTI7mT64zFaUPvzFxoU4N8Mj48QlVkhBm1cpa+sMlQhiXBb++Y2ZVheWLRq83dLQFBAFy957JXjZbN3Q5tifsFj74zJmK+3Duk1Eow02kHTbO8yGNGpVEN7Bcyrj5TihoXac/7mQj62pEcfJiVOOXgGliekbDvX6S8pUHjPwCMlKs/SeAFacBm57eAL0C3+Rpx1UsTupJFUr1RWYdSI/jAJj1tYe9Bh4KSmMrHqhLFuePYP6/HGQCixuRv8NV+OzMCpb8Le5P2bEkoqa5fNJsPLlqUURlqNwT+J1uRFXCj0UNkv9pjr/WAj0naPlQCftWWTXb5bLKVYgzEFrGnyAUKeFJ7uz13dRTAuGVKQqzR2+xTeMaZKFfIxvl7nk8tEeywGgoUqQqfaT2PTZ9Mn6uX14w4YMgCVKXbqws9uRLsIsq2sbCeqpHI9kM7g0tND/dcq011i2eijJKGRrIDimQIQZZJ6rzTF/jsRfDSa6gBaiOEracvkQ0cinq8f/Gd2j8j/Ytz4MgIQUtVn5YkYzi/XltZHd/fLARZyI3ccm0wi+z+wpiSpnRLGN7AiPOBu7mwU6XY50tTTqCVylBfp5D4g+G1rOeRI2mWsfGHisfhb+1v4hICrewt2iYv63mjpsYkUoGnCBWrNOMWtnIX4bk2oGQwvTc0hbxITPddHH2tHN101bgUnbmtoJEWeZtoqqgjRl9VWyyWyvcWUHr9KznoFhBSyz1TKIt9FvpGgPO+QNBKJXiQ+1JEmg7p0wYObnbXjxjn0+KlpUJUmwgd8GDzbUp0sLeNao5gD9Y+Ax17vVaSYE9476nzC6qN6PREewOIIXCCLIjjmZX7WWpCvpFu6Czl5q8Cgx6zKYr6zoLXxKFb4ZQWkTK2ijzUNGjsxZZIt5G1RLDZrMfYgb82ZrL+TClCL4WlUX/EkwHdVPXB0DyvcgvsinZdk50bEWG69E+dIuNJYh5WoPaWJTtEIQ5bcWtDnVJ9ryN4AN0g+iuYm9cdoWPC46mfEU/+iGTZK7if9RW4g1sTuXrrpfrVhv7cNOq7I41VH7tEhBzht6WystlYclJdX+dsNN4zVJsc+ip+Wo+D9m1La0GqI6gHaoWlW3OMFnf8u5p+iLwaJGpWMdG8e+aOLTeNoUNQZwA1Dmh9A1/izCG7EQIPYbIMnzteFkG+ukSKHUnx+1KZPDqqlYBkmbgXwZuBgNYmzj0MfvihDhkViw5d9QjojT0OeXH0tzNTKYE5fBfK0PEpSGpmrBpybAltu4vuITh1KR48VRy3r+ErudHVAOUuKmFFicbRmNPd4lUhqbk7AJCRFoBIRbIsg4h3gfFeQHSCny+gKyyMmF6onBH8h/cOwFLpy9dW/uItz5gj4eD8W0Ro7M2Nmg4AqA1hcNtQW2d8K5NG+IlIZ6CSMotrcivDHA4om7kgf0m4oH3KcKAGJzi4Lql5ako8ezVz3aSoPIcG9icIy+GopuA84E7pRsIMaKIHboZo1aMIOXX2YbSJvzRrxxrbSLB30sWcgFAPlwDfgfVzWV5p+IdFMyvcwubmLrPiO5RRXhkNM84sN2l2NjBG5olJNaYyssGHlBEN4NE05Sjma14q1XopgUJKo7vh+ljqU80mL+kPdMR3hzL9e7iUtiDprylKXyIwlU5FGHw17FKbXlvvdbyj0ylq/V3v559482lUvg6IzHibphZKfxp3IDMOIKuQeT1QuSW2THAVX5cTzQWmqG6KAPZlshc3FGQOzCLXMe4s0q3X5JVuB8lGEcVIAsKminecb0b0XsgZ9aNwvTrMVtiKkQEeJ51XXNHRvbGUlXtxPii4PLT8t0TX3E/xsrK+rlSKrj/cb6Yz2DZtY/kfg+w3mXCSAZC+RDPrkWUUluYPSTijCRuKB47+IN401udkCxpdLFzRNptANbJh9dV0vt5SqYBL3c8f2+JryrSz5yfO7PRQOVY+DzB5EvqjnEblCfAOadVNQ4YGFgthRmlF3wxk8xuJRXcDSjXPpQkOw2KPXOc1dVUOE+tI5y95Dljjvvg0Dm2CxPhbBD1lBcu0SrOQrIggouC4ibzdu+zrSm6NekcKTPhQvoz9Ik0SRB7OKNydW3MiscdAo5Yk0Qt1HG7uR4nhw8qLlYnqIKxJxbIzSVdoGM5b76cWvSmoxfmgONHkgOWaOn01QHWfXMV/NaCYFj+LUaxjYBvVpg/DAlVqZXQLjenHNAnrbN0oIdQffZnDqVClCIZBIbO6z3WFmJqcRULdzWUHJpLUL46XOZBog+IJYN1XEL6WCqgLOkOBTlKmPOLWlF3ZoXcQCFHhfhQz+0I9/mGYUhzKyIqfnS/AcNceJYn3C0sEPNVqJfYGJDyIjlvF7evmzb4TliviqGEjWfTRZSv0Tq9O+F7INmX8hUP8UTzVi097P3yP4YM8H7a8zFsiZNy2QtJERWalRAOYeDZCHm9GA3TsZXXrQZ54/8xEzm2gauMpDNUN0j6ejPEJam4eLnRCvb9WWmufBnXKqAcnKP+bY4DX4xF4jcooE/LAlYtZRXeeXAJMJgDT3tuS/d5yLp39AmF8kjB1zWniNPY+kvm0Ml/ZccjwJHPtx3cV0dE4uVYiBcsfxIdo4y+vFCnlprNuzL4eI3FhnLcXonJOg53QoBNjC10RCblhUf5QQP8jGvpt343ja/++9xzU0nt4noKxtkvObSHanHssYOVDBRI4M5QUfVf2l0eMSgLAlDhB65OjjFIhvDWZjx2EHKqy3aXy/v1+gP7QFpbTT3cRKnjbolNHZlSZleidyTCdejUqWBNXpZf+rlEGrPdLtocrYShE2aOGZdk3xbKyQI0tR9aQCg71rVIkLHdXYAyPkAhOWwlmsHOLIS8F3g+nyGGunzs2CBBs1KMXvXGwpNVgerBd3s3QzOfgNj7XJx5+W9e8oxVLOwSLVWHxz6OnfCkW0Vd4mSIEP8L2n7VsDSx0kR+/fzSH0n5sOCXzrbi7c8qPi+xiKYRwTYx2x4PONlCIekyEQE60++sOOLV3YtDd+bqOP4beGnNOvmR+wjIfcj0si9pK7XZgHzRNq8ocxKCjHRf5fbswC5u12wCaHzrvqi2XZ4L6X3N5AoARZrZvVyaaUFrIOlk/tfpoFbwQJPKh+WL0AzIsIo9vd209eUfokjOmWEcukVVgWUOHsA1lI9TIe/0KZ7LBCXJbc2wWBdu/jo987rr8UC6+Yu7vdMePqC6I7GtvhliftXnbDRLXDD1CxZigit79sJ7NGs1Tau8YN6Swgj/pqLz9El2t5/XqjRl+BvuTB3V6ajNJarj+eHEPtU9skeSYd54XLpyTt/rAD76zpzHYRGihs9FSLbADg6bOYiaclP3Qn86TggdcdfeOjSxoEiQB0t5L3DRwj2sReFhuEDO+S3nuBi1/tlCn4dY83xA5GLvSHZ40Ne317EKbXEwudxm6UiKxqlVPaEc4S7Yd4pqiIjstkvOU4V7SmAQUyMPHq2hujVxS+P+8iWd1B9oiI953Ts2NryTpFHY2ouKRtWqQa2gjeCbpAwrfG61p0Cn+dg1NPm2Vdn6LJcoJz6v9AnRcsvRp9Kj6A9+ebBe+Q1f0Bh22r0Xc1UrX4S6kpXdDb2q5ZFO7iNMZyR3AxanTyxwIs7BaVUl+oqSchH2K2UClCKiYW3AfNPkbV9O4JrUzcWfrOuzT6GEH0Zum7WL5gnvz/cmyu3y+6Jp3QS0hTjvYxni9dQik2fB1ghapwcor/1qeMQOd/q8iIr24ZwqllEtne9YBrOs293kf+B6tw7WjWQm6gbfGPUQ+wKkm3VuPp3LznvOX9VE2pysLJ+e2Bm85ePD1vs0Cci48WQjOxwWot59vpe+3JVgn9EDOHHYG7fGyL/XS5HMccTV/RR2KfSD6RQX9WZpNaRawYvQfPBIqtAZ/CtB8ZiVpdHhsR2b/C1uE0ehwU1Px+UnZUsR5x10VAFHSPGyFJRGdPN3dJtukPojAeHa+fNjjR6sfYQAjCSE24DLRP5jos3bHwXNRi5DrrswAA2/9r6Ol3MGEu7dHwLAH93Uq/c8Qxx461aGajXhLLExlahPpoWAcoxm61pzThnCzYpsDNIkzVAIBz4ughKd4Vv6linRZCSBsXlzQyD/PgaHdozC6oUf3dXwhuE+GQwS8FtnBSE2t5fZCYPY7hDGbf61sHotUmIm6dIxJ1U3IGzUcs0X5pmIr4QeMkrxYd0g5TpQczoC0jUMUqazEO+CuKvgkXNq7lMBMyDoOduyno8L6CPuFLzIbjHDc0CskSWDJRzBYg9LZh60iRRfwKWZBjZQtcFYezSkiJx41DQ0f5v5ixNnabSghsFOQ7DG+ALaGRoNWh4vXnCkhL1Mx3FKqC1usmDJqF+F+r+LZQl5WISpCw8i1fxfs7xamytA+7LAsLtCxYfj5b5GjMAMo1r2e6gR+HYjVjj8uHtqxacPln8GYSVchtA1VK/xdBn5kkfswtBzRavBLYAxLO3+xwkSp2EFFem9aITswsY1lvchtmMSqLxtsXf2qe7ERtcU296jstOdnfDeTPbxTBQJXhrjCZKu+gTGtcxObJlsb1eI08DOZeSEniWKVmSQAvxiFC7SFUWVQjHtL/1CaQ4QPUeveaUyyVEf66ll6JX03OxblM4li5qzuL7Z1IbdNEB5IWPTQYofwaeI4yhmIEAQQ9TEDYnPZmDpr2qdaZlIm+AdmO9zP2nkLu5g80l5ids8sHnqlzUTEA+GjKvnyhZSpAakFvpzTLoRvqi0AKLYmPORAindQq7hLMRTzMkBHf3FqS9L366ERZpz3eCVdH50DcQpy4sVtE5lh80uj85G0vdeB+dp8nd1Hpm8TbiMCBg1Nyclf3r34qSA4ik2sWP7G/reK/S53k6C2wgHlusAtLoF5gCR+QUUrMLVvNnyfou3IHyho9Nxiu0rbqqY6euiJYeGgmRJi0o7wjY+I+9LBJaeF55O5+fPLp2M8OZvuzPVgFACZEAZ2mGhm/iu8uAxeyqlVpVsJCS53JNTYWWV/3h2AVrmpT0aXqECoYXL5U6UtWY6ntw0CD2BQapsnqruEfShLNP3bytv/btzq/j4GnQOgznsU9PYbOtzFoa8VJDGMcrQvngHVM/F0Yp82RbD4QBYZmXJQfclZNEAM2G2OUp8S/82erNsRUc/bzLQDMtgtzeUzs18/+L3H7lkdVUbiLxbDro5jyWAdoiX4QotLs97yeD+bHiXFVGMcjqA/JQ84PJ1lbmmKourDuFuxagFADxe9P4zj08LKVrGQ+KtDoA7U7jmJFhF9q/iphwZ4afqvSNgwApLI3d59wCNZr4Qo3cmgtOBEpLZhsEwnDElSaKiOvb2UEvVRk98zOxDqqMD8Z/DrAG0dDfFyJ/KP9y6IAjUJaFjhU0CQ/K/We5Mok0gIzfSnM5r15SVqsQBczSnSiycFRqtdhPdj2XGo6E0tw61VZeVtd8ymCXBDrUs4idr/n5Vjewz9FEBM6DVUFWVIGX6I7cyV3+FYq1hrW435kf2ppbYqylcbB9Rsd0JSVt4Oq9PhFro8H0VmlT57Qrn+DUAyXdS85X3o0RFcyLmmho5EcaE2/pnpFFv7GOFulJCUvIIn/tx0Q5S8nQPiwsDq7pKCtV09Ip12gCSa/67+vFrnSlPSlcQAiVvIkfvTeTe680029bi2aqKxzUeuwbY+gaPUVpYbxklhUJ1G3f5MRfHdR4y4k0AiUHhvFL9qVgSeZIs3zbVofobMpBNOBt4HKApSReZsiUxLjHylGdf6A2xhoDSz6mhXrgGBvzGMXWOtTxzDikOCDQMJ1KtSxBPL/aErVfl8vZPrbiLMC/ywIzpWWFMogwNzNXYXxlQGCiKkEyGNZUDghhR41GZYXYIqL303YBtr0xLTGiP5JuZq1j/IN97jTREVtFfD6YQrCIMhyFpsTxQ8QSe42McuQcwBnhTfFtQ2l9uaFTsPSTgxNvmfbLdTviLlUYsUJ7Eb9No196aBE2xf6WgpQAkYt/wp6tY18upOKvcipqmB275roD44231h3g2OZOXlWr3WlcFkjQQMLdfBrtCDOtE9j5pAVVTbvrXbD+X4irrgCd8iZLNxtJ3robv3AWgDtb4+J4rn73EDzcSL3eDjNPXr+OghYYQ8+75c/bbyoonXIUW0mbs480lt1oNE0LscnQfkzMaoQr5xoUMkc33W3VW6VgflXILosEmEoPT5Z7EOhKR2W7/T69cUdNWcrXuFVFGX/GRkLXog+ixPsTf9lrPRdRIoryN3FbL0F3s1cjAFn3N5TKd3EYO6v74ya0dmsts3SXmsMkLV0Wfix2ERDCEbvGp01rUfSDJ9Y0uBVQmdGEL+PUUYwYfCjxENlC2KYJKtJLbGyDlEYMVhuCsvm5i+fI+xJkN4cd32Xq3hMqvRNmXPByRrOo58yAVh961QPkl8Cl9QtBhgO1vfREUl9gdjOv3H2ESSXqmgn/Kr2amKZrHsp/LXlojipGCyK1gU4BCEiJ1js45lKzwJDeaNzPylTDjCXAuG9PnCi/Z06h+OlxCUxgbcNyygje87Cd6j0nmL6lLl8G84dR9e7mWtNjOe2d+Bxw7gkiFZUUqiYKKbd781DxTz18JYMTtcKJCdyjSKDo6MJXSvdgsIGy/FI4lgs/99Z2McWKimMbOuKDxZGjL/CA21JUqmsJCtVI5aig9J3Ss5AKAjnhBAQHwDIwcbqBv3sWu0rNRtNtFmXExtu1XZ8/KxmSidGD0ZCz26/v6NttcvOYTimuYanuwqrySmTvedzFQdDW6aV8+Aa7/f4DGxdMUfiDIy2GtyLvFR0eUxTVjxUvrr8ouYl5zRJCjbuZAdW+qXECZIoyOAxY96Wdwxoo/3dN7GHx9YWcNS1RmQyfJEdNwhgQODaSnbGuL4/f2LokSd0xV87JRQijedVavjJreOoh03zUgpyM12caPm239gusy0m6QS8NPTsdbwbZTrTxokjNmxuqdb+fn9th9ri0XbiBlQRF89rGo7uLtrJ7JzNRZ8sabUwef0Wd2uhc6iKQ/T2nyWSnuXiXCDSi6JQEopAN+JxT3xZSp6ETQ3bx4p06y9FiPAO6K1IVZLr/beK9VNztlIHJakNV7mR5S/Rok62o6YAXwBc7QNzlkExfgr2nO8A+tkl0zcib124LeqF04SK4AhsbpcrZvXth74NCRD3DwU38GUN23D5V9yzNm+pqjDCMv99gluHi7TFmMzIXAXM/+9x8F5CkqTv4Id0R92RWIaxOrmWvjMOubcA6ntgxuN9oM4kjtK+WG9FmXZjFxq/fYOMxD/pnmhYNyEUsI+gCASAPrGuMtt9R1p8+Spstjd2JmGan5TDlcRHbdnk1MfUNV3MHs131zbiUVaWDnj4rzLlLWpaXSKl7C8EnbAB69RnVxMUmnMT0yXRXu1P1ZDmFSnSuOVyeuY88RwD7DoyX6lPy9ew4MtNYvJ2ewbrief3sHQpJHvmJuME1uwpHz5Dk7RIvEIhrmTVQ9Mq+dEW8xIoVL04Y0boN2CcgZX0wjdBBBDGZ+EmlaXkneOdqFnJZElmWhAdGrJH7P/StPw9vrR8uwNay19znL8gRDvibf9MqseskN22HY1H2/Mum+T429HkPig6pGO95kXcKoxARUUw2TrXToWxagx+fsknwWOP4liadQyoHrdqp8/FFwNOhEPObi55B7QB/K3Ol39TZ1uOkI+t5mW8Dp32X+cTwNxJIKhLLauHttt71bBo/V5LoeraHysR0gBVkMYPMBfM3tErgkjPJz6TFwrOKKfHTTfx6LJMo5VDd+Ldqc9krRQ85z31eHWtnSxZteLK3wjxlV0C2QsjwK8pR/v0F8W06xBq0vmq+Ztjj86fFKt6tNVr2JSyNZMueO6urTV803iRoKOoM9hZJJWqKjfBbFZUAW6it7+QnkcczAxZ97rruSC8tmYjjDR1b7RfdPm88/BHVr0Mz3Ge4XK55jwIDxPNHPHZCijYFglr9V0vU0kkFbsBFLMxr5PoigFzwaa2oWhZw1bWtF+loRH6LXqX4TYjVhdLOuZbFT3OF1HSFnYq0In/ZZNMpstYdqhDO2deAb0G3kVAg1wN3kNR9keaOSE5rRIAmQ29f1CsWmqnLm7QvwU9Gb0pxwRmtLLW8jkcsPBoTFuD2zG11GBydd6iGFhWKe0faaq1Z/3nlnaVA0aANCI5EMPfV4Hd9hVaG9scSx84f9eGgWMDJuqYqQ66AT9m2akYaKwBmtxeUKEY7S4tLifaJ+hYWOLGPRbLJajp+J//divPfswyJlrZ3oxcpFZ+LSEZ2sBAq2sqmYs5t7IwgelcRhVg/V9Fg2SzYGo2m6oAm8j4wcDttBA6KgFccL7h0lPjbr2sogxnutMin1/DECJf4BHdf4I0kiytUfaUNfU2AoNBT3Xp90stRowxSDtjiRaGKVG64zuyAEtXP2NicGd4xz19/6s9duLolSvLKjHNswNroUCLdXiVN6lkJMTS/+7zNiiaPyhZ/8SnfpMSo5W7GOhK+wdRgqwV8YR2yVXPTLRIVhlHRXTI6ZblkODZ4XEtGII7eagvx4360FJDg5b/uWxokmlfMe0qT4HYNb9u886f2G/3Y3xJkW1bo9ghxYZggzzCu1/fosWHhIAlnZp5qNwbiugXHo74jppjbuRCJqkxXBitIcR1GtaPnfUIi3gdru33DWrHGmNu484oS1DiV40C15icQm4zAOZ/tq4BuW3bVT8AC8fx3b49i3WNW33hO0rR64b5TK0KFmAew2Z2UV7m1HDgMmATdpXl03yQTBRk5HXxgCXci6ZzxggsJrpCkuX3fTozTeH9nZFHjNPg9S52CgK9dnsRKQhWbivV98iW0/V8JS/LW8vEykeZlumvJYqKivo7GLaO0N2FsPlP9BA5k3eknPhC4xjHLQWBc59scymVhvNjTeVPTEVz6qa/PWeGp8zgme7yjwdiR7SeNbJSDVPJ98tqa3L6JwYaXPdHwjJGhBYbdASETeQCpgwaGnM9BsTI+2LVI4IOyDxsXz3C0gmBvPcirnYdTx42/merx95OV+raKa0UhNHFvHydKyssSu9jRmvSoswqdIOqTqTyXt+F9bBNDallr+8f5xkL6DnQE1QzLLP5Q6x2nQxjbZ0Hzd+zgM2IyGZm5Zthm+oIsE35pntsKH9LaBgt0JWSiywb6xsmyBqakc/tPAwimlwF9A8G9QD6EgMot1q20LFxTgMsB4VIbnwPhXOSeJ+mKGN9FceioeB7JuYdhf3vylNhvimQIXFGtriLg098gQtCuVzIjsSWKbsW0s3YHxIGhLcwSub1RV3VfwLdLOw2WleEu4L/ZOv1G9kIv5EORDYEW+f00sz7rWR4LsksVnBCXN5JHH+5sOFlHd7g1VrihHwigmjBgWf0B1jVpjpZxEdrWB7aNJHCJhdjqH/oha3jgVx6WmPuT1sJ54dOKSFPxCevF+GO2hFNEp2Y6VS99efw/Os5hhxJj6E7BB0OljXix0AgBPNF+ouLE8KtcoI7E/i+mYSGNz+mjsFLM0T0dq9BXe9fYN4KpmYgq+OJrlImdqw4pubDsK8CwV5bMCYutAZfUBzng9sF3USApCdctlpXa6OwVOHDIRtBlT6O9LG12osIVyZgcUpEBH/++tKxxKpuIy+UzpQYBpyJXeu1oZIsJeWbkZ3lEmKXSbB9p3kbRb4qumAm5huhYCdDcIEL6+ZsrSsa7zK06yjoZlq4RCE5CCA/XhkEkohu6FCyng4oaOiNsOMo4edr/vIARAKwAr5OpxTwAu5T980pjfJHr5yNhz2G/bj83HqzBBG9gnhoZtZORfUTo7sJnKzsFlqodwtE9nTqfGmVGyZjhWQzdaQKffSyLR00KZHs8n2Qpn1hqBuZf2T5mGWwsA2pZacwAJsQXBli3c3iwZ8ibDVu4rNTqj5mHTC4Dt2nfA6rfK68jGycd2fzknfsTCI9mAYgYACrSvxNWqDUTYgO/a/wchlFGsNOAXG/x5RgpirNlurmFxZ635vhJEj/s/hvTVQi9RL7JwsvPtD6oo/MITdLnfk8lVg8OmrlELyv0OWhORRnZpo0f9As3ydKhr+yYCb6N2wu/mP1w+O2pk0a5sf3Th1UYl7xnigAdMqx3e1NaUqn/g3MZdrFE4hwrmKfQ9Obo6RDT0mprhCmGfNWkM3FwqoC5zLOxatreqjrA34vavvUvjGmcJyufm7sLXIb0766qjjdZc+5xIKdj84kx6q+EBgJFmv0N7lCVH5tBFuydQPkysuOKy5fRgp3zEarTESQXqacj5151yzwCiiV5xyefhYmaUJEFKo1EIFRNR/g8lRFg5fPfG5ScME5UDVZKMlADnn6i90bm9AzVSq5OqZc3Lsn24TNFJF8sWWChQyC65LxO6YfeobmLDTxSumTdK97BC7GVA8qZBx1VOXkZ/RibQDMeHKCpzAvV1lwSOSH9BmU73acJTTwOCv5pPGUZXcREh/I6Thj8xUmK51c9207YTy6EPOzpzlSEFfX6rAp1wnJUHETWbVQh+gHGTJ23bEb34ofyPFQGITKN1Vepa1gjISVjO93L8vpWrp8/o34/MliuPf4adUtDcfiQk0P/+yo9B2hHXeVuD9zaEhQ47yioE5mpajAeaA6RWfaROdWp3q1ZrW0Wyh1pC4BYQDRvnOYJmGvZ3XXThSdP7W7jOfWY7GgYK+5MMA45yTJpCbq4FX6vlfvFIhiAiOrt60aV5XciAbLGxynUyu3cGDx8Hbd71VeSioI6FOGwWkOJAxbpPdD4q23mXOXZx821UyAFVY8DJ38W227lJfvy8efLkZyzHmDX84Vl8KeE/isRbUcAl7h/hWKKIrTVqtMXKMEN6M57lIayAQ6YMzl1giwEw+aE+9OY9dJynC8OrTwmYRUijQgnTmvppBQsVXzr+BYGal/v7CNbNIyoMr8l3PRn43tkwLP1jdtcSJlsLoFa7Z7XI3F1qbMKVFeVda4ACcE9XHsM5v5ebR4BO13wyrdBPNE/QyorZ0MWW3XBghIQelWq0e/iIo6WDdph2Wf05zX27jqHIvzhrg4F4NsPKVD7KPZcf6EksD7mRwYBO60qBq/ISXAMf01TZzFxWGGATAsCj3rGkvdqEBLKv2Zv5SU7ZMUs9eDwzVCt1eWvQp6ovX2uIl+EBnV0OLgRk57fRiiHIm3QUkrKQwb3/vSpPEg0l6X2aP1OYefBtNhPbRIE6YkrT9udeaofdlBmgooxLCAP9ZGxBVk78rwD3gA1mfhAezaaCPRMJ0eobMRhJmuOcJj72NVt+MXIM4tgq0O19FNroSqZRjhXn0HgeL4EMqMXjWM57F++nkTxaF1RLYdzLpKekU6aPUPmPqaPcjEuIQgjOuVJI1KnokdhZmwgP8hdycAfKX4SqnmhM9AXNE9T1Map9Yq9fiIaLyADAg5iJfgH5b9U46yfoyXJMwB65yGkOo91uEsVCaLW49I/mdnLatLx1THnwRo43eleCtxjqDwaOjFGQyafP+yyhh7Wpoi6kuo3eB1Z55kRAG0aFTkHnITROc0WQSR8hD9wYiP1Rc5//Nqr2yKSp+EPNsIxOot3Kn0L26ESqG20sd3bJieW++ENHOzDo5cDueCe73FeAq7ijhszEW15X2Z6DQZnqjraZYKctI/lMoWinmU4oEJII3CFlaHwkcPQ3JQUKqkhTTWiLSDMLHjUQbJJS86ZLOQ5Pc3GEMgDJqVKM9G+kiXJms8g3ivq/XxpHFP24We3DogcKOmLn1sDf4VLf6XSNRVG/GzZN302HcbihvCHHlom9UZieT0D0GFgntpCbuFQhFp/9nXWrwbLNmpF0zpZ6Ejz9DiVLWUUbCl+AA5CldgY7n62RrSHE2zjiJctEcht0cAhlKM00xLlnuptrGuobjDnp/jCxh99f3+3IENy81Vgi+iHoNimhrX9val5k0e0H+2SOnRw1bKe/Dp6jTq+WjBwIRqnlv134mZeNgbwzjdrqWC4FMC9U2O8EkbbfDoBe+uaH0W+W1ZvNEQiB70CFnB68YctoBdoZmvN3/D5tOuLGSCwFmNtd94Mo5oeaW2r4I+l+rFe84TK6XMnfnBHpvT1na2+F3dsoKLNAEqp7IBPSXvDtKIoV/sv4AWIlhcygLPowZSU9M0iBXlDt06qAMG5ZKg4hHcoA7Mos4gz9TOCWWeSA8UFT//S7i9UaU9NPHZAuHF4H82n3yq51wyA5wiNuV8U5Cuj79JMtP5z1MsjL2ps9TMEf4PtOr1kMV/vtFnI++/JJ1juEAoaMhTZQnVleaZNDN3VM/36dqLsw+J0B+v5jS6jFzYOOScpGROKiFBbCoga81xJBsdsY4YxK9u3mIKM2pEhzSKBj6Q/KRCdUiRlEYbX4a8XAMi3171yIGM5cWoXdoI6d9++CHXu5K3si/2dT9lRomYDWo3kEUxB4apbkgS95LYkcxSLGA1BKePkwk3Q1KCAbNb+XzQd9gYM5sXDBEyFnaGqnrFhG0uFt7D2K6O0kaEzvFe3Xmg4EOw9tcFz0T4v7plmBuIUdDhH8KessZHTK98TO0RH/QEEwxMwZJbtK1BVhKhhbgJV83aZyxBb+owpWvfbRTBLczxJlP+7XgGwjZ5Wx3LXk1tudG4gGTBr3LoVyNcFjk2Q8kuo7KTa4IgpnqERHf9o4qiXz1h53OonIAiOJ0Do8Gm7LVNgZOuc5Qy+FyOWb54SmjBPAqQrk03N60a7zbqB8A5OI1WdA4afqgMS5EAzNmc+qxrU11vZIm3myOZOOvPXGUDD5qMirkWJfqH/XMQsMcIl65V5mx3Qc/Hp6FniN8O/4vFd5CuMa3pke+dnoQ4OM/Pn/0PpgL3wHe10AlscIMdI/QfWuDJ7oiHY/PqHu/7Y8qbId++19oIsH3QIgA0xIu7oQAHJVzKUKq6/e1Xr0AGAUohA85bVV0XuFZridotaoqWcEQD6+hdvOJ0k8a7B2P6VwO7L0PlxK7qRbAhMKCJZEpGCxmKwj2JbCHkuQPxwTvtxQZijZc5+9YU1ZCKXE2iiTJthkKY3rtDqIUTLD80wTj0o44UTS9qBSjrbUgZaIXVBcrN3c94VYYTkfxn7xU7urS/k5jPUmXV2gphgONUH77dWSEfUWpA0xHW/HnISA3nHR6mPL0WS80UsZPx1Sy3TRDQyTofdikS1n5C9ZdQc5vL8gf3YZ9wLMVkhDY9GxDzkEvXAhv2596stfVQNvkV7QQWf5oKswpA/EGWl1w7ZzUv4s88RAwFuo3p5P9esV/WNQqUQL3/+OFD5csWiWjDE+PU/9X3SKsY7KnychR5xePUH7m6+K1Xh2OiqZXT/vRw+NDn1VK4ggzv4o5v1I/zNdCSWWDuFxHrCvjSMZaE1WgcWZU/zYD67hHCREcOIG69UKVPXpI1oSnbxaVwGkJKr3V6sOckbQ/Q+0V7bo0ump90aSOmQEpYMIx9dLFrZZLwDvj9LobEpjM46qS/bG7XYo2iqqL8l1A1PZK9IGSxXJSLNEYoP6FomuAJmcBOVriPTFP78abR1t1VoaRlPr8kz+3ovkVgVW/QbXKlq3eFTyYVuaOOMZMMWoF1jezOO2HYDzbYP0gHIvVow+AfKY8btp1AEL+FIhkWZWHdMsUHjMPzA7iHR6dGnCPyQQbPW5FeAK4uQQ2xXOSKs+ShbNBDynnlwOqNRyDURSXXoV+H6VsuaFoK8GSyRRbqxcJMsIWcyyAS2O9otDM9LnrDfikw3duzfXwz0MYgsWTTFkmbJRXkhV/xjlrmSlMqI+OxxCjZI2ZMkk9Act7gsVIjvmTQ3HgBfRWX6narBIF6yw8moF7wOzvRfWRCAsMS7whR7qqBYo639UTriZmR8vSJiprJ2Dbeg8+kl87I7yQ3qI9NuYcRsDtIH1Vj+e+D3KazEySk6Q+h3XmCIP1r10ydKBPZsVu/umeW/kyglXzkoExkXl9oFh3viFBNZ40HMEkeiGcw30VXfpqsMRVj5ToIwnVv49ecsJEW89M6NVCpPqIsCz4DC6vFNOkxcovL0wdLuzyaUjGQQYN1moBFJCC+ntOPa/mqiXwCcrsr0NjUiFMNuD/PnFDbLwY7oaGtRU2c1FWTHsQajP21usvmTQNBk8WK89K15fCCcrP8aO6lMURHkWyAGxHHXjg6SnRDY7kiw+plItscT7I1drSHrvg66VY7FiWY7OCICsMXsK4dow6vP8U/SpDEnneEGaA6jjcBCHM72vojzwDTA3gnzPZlResyzkRuUBBsY41/IHGTrO1yVve0jNNngUW99pRq0lllmkW1QuppJz3IxI7EGdm9axgbNDgjwLXXJlDX/9ouBFu1gXYhhIOb5A+kXRUf3UQ+csJWBlw1pMAu+4Ur+EsqMqM4KKqjUzJLfCWFczhGyzOuF87pX0FgJwGnxUJNeqVn5S/AsKyaJrJJGZpba8eWKnFqeG9X2dThIyYjXicE/JNN+nAOX3uwte5Ahl1hbNJEh5zjnLciGCdGOPAmJfT6wQGVwVwFeE8VbET7Lir8k4x2LXnn3ERRndLvzH7awWWPjEqdqaeEMVfgEtAY+Fz4tLa7Mn7tdkh9FD/3R+WhvISRMgBJHBoaK+CepREflTEOzZM0DXAIfNP+d9xsSEXaU7K0OOEFJCeTYvOJpyjNcu+7Wif3Qh55/uoZ0QeXY43mbUmF6jkqejczWFhSAicG7uqVycvPN8sD42uYuQF1igN2B2esPVXetWf7+1KP88/b+ZoPMV8TFPt2HvQhCQKPvsa+tlLNpL14llre+tP4U3pd98vJeuEr0VIrGRYvx82dlAOJ2tKpwuLLYfWG1dWY+5yXW+xOfGDlbwl0x3zhc8TNoPgFoznYRbB5JfuVIL+kqw4EOGxs2WQXcgqZocR3fZUw8/yFcXstPcvyEU6owAICv/eB2fKfBnlquOdaiRhIsYF32XHmeBYdAa8bas9hdokJJavvHsTB++4W3AgvXT9LU5wGqFK/FqToscCYEo7W700cJ+5Ihsrpn2YPiY9MRCVK0sndcK0hl/8HDOwX1Ju2VV9y5RhjmuIoIUw15Aul5Hr7eGtrUaYx+kVOfRYfaWgF35tf0MXO9uKDPiVrpQ0vzh08naCfabYPJw54ve17ZRvXzOGQKyrfNW605JnNNpTezCELtevsoOSEY2yBkCkLnuX9FPvdVCVAMkv3wQgP697cZc6Ps3qn/g7/1D8HaWQXHHa+CGv3E5wruO7O0gp7ARdof2LAHCJ6LNoERrF2YxTkTNLbpJbYDTIRztsg0m9b8sQKmbrW6o+BqlbCyMf9eXJKl8l4JJmUcGoweiVVZYFDbf9c4vw5WAhIB0XQcDQb7ElxM4fAbQfzoP8hydYS5ZMkIQesTg0t4ax0Y+R3aw+eukjhtQMp7TX3kq5CCfWwhKSdWqAFv7FKl1OdWVdeOluKoeZyHLEn98IVCO2KPdFuLOsKWYt1nJN/Y887sXdihbl+cVS61yA000MFS7dCnr3U2h6l4ZXZUsVJ3cTuEzcU/TFAVHPIqsP78KEItRlll9R3nZwd2QptomYKSO5IFtkmJhyThhgRKlNkwae2q+OVSBnUPf7TRX+RBeffzXoXjvgHum9BLqiZFIV2YPgxBA7OGv+HBeCvcjL4NmERJDsutvzmRfMNuToUVPc3xmRiulF5/cYawRKgm0y7y5dc6do0WuJTntQbvf75gQZNAg8d3pt8gnUTJ7ZhgtATaDr7JRa3AjyG/4m4ywDaVKz7hOeCkxSmRZ7YPDatDFyjG8zUd90tKrDydpsg568L1712yxFWia9cpXka2tjUjOngTdmAA7e46ilbCKIvfpa9qtHk3Dsxg8uVPeKY+7YhUXYyqQYXJJttjr0Ynwfxxy8x8ZW4g2zA9u6Stlpr2JxvN1aKQ7wDuO/LlhsfMvIcNYaThvgX8RRbBvARfhBNaiZwkXGq1dAxz8VstdidUSn2DB0pPL1Vu0k2IH2xDeMeLEimlSALtpu3fDWpkqxhMxgLa9l3cq+em3A/hu0ZUWmjoaCdYJM2TPUqCKKPxfJTmK4VLhMXtpsCocjy2bL7qWOd8JKb8YxjU/XivbiQQGJFPu3mgfi8u0oa4PUlN3iC0m+YOlEXgF9a7LgGcSVDjgQwNC9bsHTkoyguze5UArbYyxAHqSudTNhB0NYBjPXeSxTE53NqyHdah7LHKXn58xBlPqZaj3/j65lzMeajsUpNMmaCUn0x4VcYiR6r2VDXmdluaoauMexv6iaerxKr5RcwtBKWEZB+PE1Ec8ElLwiFPr6wuPbpoz4WLvI0KMyhYsGiuZZbVLZSERinnetM7cn6fg4u2gy6mGQm+QTWo8yh3OszxxkGs8dLSFi3eEiBlSoQAerOXv3G6sEBD7wxs44Z3c3CoYdbR7HOJjjKDqCo8AnfIgYqrQ+0Wd1ix1X8fqCH63LsAdkssmA8zp/ZDnh/ujCPtwffj4fw2+poDoj98PXSsFXPNUMTC+NGQJsvrPbD5fiATDlQqtWeuSZwBJwdGIOZMEzEUDgGzgGBo08gXUscWIXb/z+ftyt+TJ0OY3OUflIEJZjuOkGKaZmVJTi/OPP01pB3HZwtnCPg1XgXL/y3Qixvih7nfh8QY1vfJ5LnS3EbzuoPmKXzu38HhIuHyYQLXZqaYCFCb+dmaN6ui6K68oezxnipl0VcCsJOVThX3UGx/cHkAJv04qXxIXdSgAisC0bHjmro2XsMFt2r0bPqf9IDD6e+28aq4fpJL21SyCrM+wSQeReFdBA/t2XJXm6I0rU9O6m7UbSM5zGKYYBwehAB2H3FjqicunUjPIwkerL+LKuDbrJdutu/mYs3H/6tNJvHnv/CLhk4VBYd2+1tWjwXl9NWLzzOKmjcf1bSoTvAgw4gIE2RN6azBRyMALrDCBmtYh4tK0QQpY8Ujwdy3ra5Sphd1eKLzPn3o+nxDcuUV6Z9z0DHqw0MhhGn45mZJSsbk/DYyifJac0bMlZWvxw8h8W0E1gHluCVORFJ+pAgMGkwLeGFtRqeC8NlISFtCy7pDdCqTtl1xTzchGueME9yZCA0FlebJBggABaocemsDGM8u9UPu0aFeuGFYB5RdrnJn95+D+rRxN1ALIdsiUraIUKKMrUaZjA8KKuUw4+0bSf/C0uXIsRJbtu7q1SPP3lfb+wgw9X2jwUnO0OLwAaD7hmJxKgW6jwlucewnYBXRk4zX6FTxMQbRGl85BW9cEkPluTFrdfTRsn0iM7dfZuw/u/tiDiw7WKs84Kx9Dnjas6v7VJykVpz865phX1AkjgswiEb1zol5fnKuNGMZl2gs07hkOPYAAipz7O82zhDoH9y9hLLvJKg7yLE/4f4ZP3SuxZGgVwVipYNfON8xX8QRYNaLICR11obiCuttfnRURok3InP9DuJBc6hrZ2ANg/ajnGQAG8kiSj3v27HbE07sj6NJy/2aI++NIyhKBSoHB/KloUDxa4ChhGxSEuFisAHLUMuSWjetjFEStNrRqmK+Usmcz7ZWkZf3jFbBTPedYyo/aBpyhhkAS55qmB46hNlZLqmxrY3F72P0NsypY+gK6xo2bTX1TCpNdRvRpNAj8pj3oosFn34oVbRefUSOrxRgBllPyzNsPNarHH8M7MxnE+T7eIlQEDWoy+bJDFAGh5IgEU2yYz+z6Uvv8jhzrvxkQSBUCO1KLwbTqpmyDyOdMih2E5e3yNKSo6AFkLqi/fjRwi9GzoY9NSJIDLyaPZWGmgDGTvWfV2fo7suhWFCPTT9+fER/hilj1ccx4DtV+ObMUS+p19T8JKk7gFK53DANnwidyxdvAZ3o50bN+154y9sd7ilp3ier3leDnEg/7AaAnnFc6bqeD7xin+cGem3XV4Cl+xcKykUwnhKx+8D1gSx8K8aHaynkU4AtCKSn/HVHS972FPrmwDRgXIgbm6VCupHQEuf6vQn26mFp/DFYzISqCVddvLxbv3rmjPo4Q503qGvFJZCXbFB7FsgwAPS9rnuHEMFGCPDMpvsGhD+4D4yoaluTNGENB2VU6gNVUBQilXzEyGvTmscvIw5rRyzzszfQCaW1nYUq1TUX6HudDDisqEYgRkzG9M0px66NsNzGPBiezPMFJMhQdv6qbW5afWwvaz1oz9aDwe4R0q3jQdSKtvmRnCBleirRv+kmFppXn7by4brjuJ6CHE6KnNz9ZIW6jappUYyZt6sKQWSX33NAsDc97c/RGsz0zFdnip5VK40p2JIyco5F0ANJmgWO3GJBUEJEjlt2PZBiDqY/lBLRtZvMGQap7P/BTj45L6yEKzI+v6BXWl1SF7YHbaNp/iw/SEgeJC3HHIprV/29L/7MVGuDSz7YpcJKHMQPq9WCBJEDiz/MWnC7miuVSh9N55VtSCbeqPZGD3YHSkPJjB0BRC/COZT+xgCPEQ8pE99VXS2g0tg4SPcA76Vs3Bx36BhdybPvzyD50P4WxSU5KwZu6SCVt3PteBkFef/qxN8CpMRPZhLGNWgMKNG31W1dOu4Ul7R/Yt9C/H4EXA9GYv/pUpw3mnOEk8HOlxqPBr0BOh8XjMsi7fAcKPFVKcYTuiicY0eZK1aK1/+uQcN2v86JOlEDa1e9DKoMGrwJ3HJn9ZSH6Lo09cwYm92sgPBS6e2FwLB5+BgcSdw1OGpohveHVCt/JPICT++fesEm96YMyU39SZtP7P1k2qUcnXcXVF89CEY4ZBSRe4+hesVdhkkwva8DX8YT8nDc/9oNHJzP7mp4ejvQ4wb9dckld6u45eFMwBxKPqjeK5/pxJFKOJGicXSgiKUncZr4gVqYGRpCPA1Msw8c3/+pDNxeyVV/IOhx/T1Aa8XOI+2NTI25Ap0HoCuTpmewj55wZZqWQFR55vqlnrSYXGSee1bXdPxkJcQsdDyqShbrdp576dhk1yvKQz8CBJNkDyLamK3+B+eziyfGgo1cLUyoebnscvzZOy6dvN3cv39xXk+wq0VFPGNCSTxoQqLJAFX2I2QFyrDFgz5CfngzbQKAmuMKbFmlcfWxYYgShjJ746fGZD1vCsVF0qbp7rgCEE2+WKYYRVo2tP6vEgE+TAha6CVeGlHMAR+LWIhMoCcpMc3Zzif/LCX2FvFJ1+Hr/in1hMX+vA7aZDMlFZ+GbRqgxnlNbhKxxFIHJfw82GdU5pvZxv7vLTrAt9L28TZDL65UrswCTFJlkGAvea5j3oey3SD2og3+ufjSrcR1VwsXuP9zn4H0XeJIgrt6B5P1JL3R3cwtZmWPPhXXJcBxBZL7fmZvrjzAD3sEflRV8dAjj5ngALsYfalZC5d2hpP6B9IVYyP9iLeEYkIvKYAY8luOYuN2LzQcEKGZNTzHYj0Jj/1zPVlbwmNLjZUd6OJULEjS0YCq7EoMuTm7Mf9QkjZe8BzCUMGwYUn4nCTqr6Jtv+CdAyIP1dGWXd22x8atdhARqIH5uZXZemxYO6/h3+devsCtn4WA75LRwTw8ui8w/pKFv9KmEZ7I1RHrqkHxRmlwTRpwrmocGInXxF9DCBMMs84oruL49qBGfwLDJASQNpsqmOH4VMgM4F2JQLCyQ3C6Ts1+j3Gsgi90h+jb9gE2TdbCyUvStTlyE++/h/hnQX41eimWt27XuvJ/mQWDn+XflmHV7y1xzpmwR0g6s+a5BJXvRAYz8g/EwOhuNgwtdH2tJ9c7NTmlT9MepmZbkboTalBt2xh1fI6bhlwFe72Yfey72KSvpLtrk7L81CA54uhLN9LKXmGY+TZqwBCdkaPnOKSg/1y2Sbe4RSW2ggTRPIzbimtBwZsaXeFByzcPxyJrW2bGCI2ktMyE7XwLeDWPUMKXou84wBq2fUq9gItCP2khPY31tZwEU2iZzVuLGVW+CLMS8Ux0uo+3yDwf1aUFbCkI5UyuwqmKjJnj+Or7tBxBH460nXrAXrNithmv4pXKhYTiB60XtYslltRY5bjvPEM84pOlC5aXR2VsVrudo8wRHZsGLes7T8T1SMpoYsaQnQQT8oAqifMTiqj906lS0ZG00+HTxGS1VfINfGv9o7zuDP5JF2dowvXhhm22LVHn0IUrceJ92MBPboruTC66dd+IbXw702LgzBXk6ZGrMMiG66WRCnfZ1GcJFlaYj6x9CM5Rlahkl0E0qrNT95+U30q0WdrIokQbYtaTWz1lT3+EFIIhbYj4UUAMaVrOm51SEq02UzF5ly0Iw2GbiBLtTKE9ThpjQwnawRIYfjHjL0RXaTVdfaQI07uOyPwOjXSaL14VTDsGWtjpYFP8/Un+smHnpfgzYyTGp+89u0r/WGFZ/fzm2ufNWo3VD6/1aBBb6IvUaDhgm0gByfkW1okRU6Tfhe8HLdnAFfIo11gEi4g1C5FkEKlUzBknZ+9wbLo2eJaDm2CRjWHsHkBKFVb5ZrZPsCWdSuaQH7GhiMgNQxdcNchl0NIvvcmVoZ+lSu0kUL+4q/rYy1hGOERQpT2Vmh4/iE0Bvt565wkbB5oXlqA5/NNKJoNTKSolhm5l8J9i3xBpQqUM7UtceSITSkqF5npTug1PJ+CB4PtGz3o+bpZ9XF7bttsv5cou8ARS857TLyUHCsNvAJmrKxkPloxjtrgXV7maYF34Qj0gq9Bn0Em3dXYeMUdjshecdzLHlwXXxi3fbjiiUYtSjSZkSRpqKjJr/no1X45CPwViohx4bbArfys1xlj4Fca/NCNPrSrcyE57HCdqun3c25GqBYtYwIQS5l/vdlAe85nVDu/54AAto3AVlJE6XFPi1CBIw12R0dhjoalTTG8Uz5Z24Ek9oDjFxT5EgqqvQH+tIhEkMXiGbgm9vYL31mlYGS2rLlWGZbCoi4k3pIRUfLiZ7kEsEi7A6G/VeEtXdd/917HZynKNoVyEkpucmGxtZetMm8DOGvySEXmP/9SAgn3QhCfquKV0bdW9IFrwN11wUYHgCfg0wMVwdj6Wwkm+5WIUJVZGV20PcgEa5QZNGwyN/Zj+9TTAQkMXBx1uBnqxHOzeVRm7iBchzYTYWz0fWLC5z2nIxpBrzgiSVVNSClEzppfeg1shGZ2rXWRFto6TZG0osG4OvrGC1MldC7MbzxQboJ/r4hh04IB4Y9DLR6+HVg2QHTQjhVta47At0EsRYsMssvSHe67FxSeL5g/wv+6NgMiB1nWtJh4Gj9GTtc3O+9bokAFlGjVJ28CMI18PnP6Ke1XCVlO5ZYUBaV8fMk84IH4K53VjkhReINfMDzKnVPO1NyQXUoY+Q0KwSMPOVJRYojX7lHH0We2aMsLSnCHQWOMWfAmD11CTGLF1N3cy3Iv6BJCkt9jLFY2JJ3FHCBmN1cx+lo263EVSqw/L7KZ1IaUAM50Fz/w5InSI5QU9UVPJnCg8LCZb2/CZWRif9s+ML2jdzB7e3+lBT+Ui6htOv9JOVZXgv92hNsmbdHaHhca/4LF8HyL5ixE/aWorzjeko+C4OCnk/GNESJtQxntGKO/SzPLKAtO6htksIAFNNxQCj94sg7k6s1zKGCOA4/xRhBxFn+NOSYIO1c18+IbVCDsX3b1X2Aw6vw3LEoaW1oxAiJVmGeIiuwWfV+JkSV4zfkvAIX0+um8jbm5q44ilHOhhcTZkhfldxTtJ6acYrqOWfkqDPxDsAVtf+OmdeMb5nuexLZxqBZGoaDf7rKIsVZAPzDVbSHnu6fb1/6AfoWRj8GMwTDfvROJSCqNSbGQcV3K0QK37nanZNiRMgW9vmmdTe+nHM07O0b6DWbxcq8K/n9fwl7QMbelgFUagF9V1QBoJS0UUi9L8hTH1L4k4wyawQ67StmN1lLcEy93oojz8+YzjRWFZzKt+mVRUMwA7GtyDfnFiKo1lVzg0FrHrmYv+Wh9ZgEXGMzw2FQ97Fu3mTCeJTr/qnlZxNp2xLo/cs5F5kod/Y/SMG/FUMuK5NJkzgd8NGLZ52CrfQ8CRMLfMCzK1jib02T0dZzNTF6tTgMkYksGF0/w9sv0GtgdSXM9+Adn56dmdTQsxVe59wTtadKPvjMkLajYsFSH7KBmbO3vWv5Bel/rN6psAEj7lD60ot/SL6LVjWgFhRdyzy//z4i016FFUib+OJvg74PoSftua45hM9Rq6HKeTpEYxYFxHm8Y/8R5lhIQLf7OPIphHhFGFAadawEUK30zEUA8fLd8Sbp2iwvxU3GJRpDxHodVEaeFt0PaG6xIXyj1zUu5yRYpQGl5mf0QQ/RrSHd1wVwDOv9elh2/PM8W+GnY1M/MMjRyyPMIpUQTdYTOC27dYEaRm/5Od5s7AWzsP/wqa+4I+5JKnIKLe2amNrXoLL5BytVHgfiVt2wA+9vDyHTSTE4emlb6xIXvgf9nu93gSN9Yzu1NWzxZIVgZPulK/uTRrvgTSazdC1goCvp2LYaIm0DovODQFfk685drjNYkZqPtqW5935qMpfK7npPmJ6AX38AdSRuLo6dv/Yp2nHCIvyFxfgbuVCUo8cdjg7cMLZOCYiNEdlp7mZNPHKXmimgr9eQ0KiQ0s8ZLtHHU12oxl62WerUqGXCF664ZZ6JnvSvkP4AhRrpzzjW4mYf8gYoiqmshhimLKEfFnk02wb9TaidAvIfqJOAt5RVIKVkB+w+ner2SDLcc7RPqDtWbxKj3dtnySQ0k21AxxJtCY5hOkfmQ+mKs9va/uFCTUoaTzuGhS7w7y8XhfORCq4NKzGQiQq8klCCZxcmRPxSlfmQOez/qyQ5Zt/2aSwuCgI7etC04rOVnkDmoeKxaMgwxkUROT7aEDWAEBSm4C+2wNuNF8vwnNy+2UlWQSZudLNJPfyqxUE2A6zJG9zHzgvIyCTr4fOc7Qu+A/zdTVJvhtd+3c1ANSHkh15t6dp/MEDKQvYmvp/80/VJ9IfXwrNAGPlXWFoiabQA5GKQEO1XaWaxDwrkyt+hMtTVTnGr9CwGsi48yatGVRpZahxE/2f6xOR2ugsmA2aU7sMqM7c2J2EhitSIWJXtDMN6TAoY+5kgzEW+OVEabQMC1vJoQg2k3AfrdNgDybmormhtJpIz60vJ7zqK51H/eRsWNQURBcBJ88g/6Me/vyspbqBxcszfStIh4mo77b/USle9LMPrtG84EkH9xur00JvHQeveZynSm88mHvsQY4/R9toHDWD4EG2YXyYPNpHCrIhN5lbz2Ilb7q7D7is2D2b0nG3vHze32JFoHrtBSo+E2AKIQgg58HOU+cqCPCFMeAvo1o41tavAogysLTPZNzayW9VVZphPm5RsSfHLTtLqBCx926L/25zkgSLblmRzjXjaUiZdifTR+X6URQ9FMB3Eas6fzZXx3q61iwwliyTZIm6PnOj7++ClzMdvKQKcI98e/xxe2WjRmu3gC/3Ieshi01vie6blqTOLdCH7/TrDUGtk+lop5ie4yW0rsKRfZB9Ax9lG1P1WbNblHH0NLXHk6Xvcva1EhBYTK/upqByezA2VXAnP+UDPglt4gexIfmGv7UXIQdKAVs3gG5Bh9h078ijMmoN8YADvQwFZsiqomIuqgoIAmRL3EzjSScTLi7Es2afp+rhfcJwAU/4OYrGn3dASvUu6/HQIj/6kDf9yV1UogWRaYyKm1MW6Pq9arnBFjcKjP8J1O1/e7+TzLtLBOhbztu7lkOzJyXO9KhCVdCfSMkwsdHKcXiA7BOd3c1LQtHxJHVAquCgDha/JRgb6QRJToqJMFzZ9Pu1XHE3fvQKvMqiJ6ampH32yrs+3lohVxYLYeRvFAa3iILPuBBoA97wFL75o/jtI86/L13TUI/wXMGj79vO31lxFPWbLwZIoAfxUcGPbdZHYz4qVW4/RNAYGyl9Xii2JmC1xV0gqvj4+n5Lpex5EAj1F8sPMvDsUC5oyt0hWinDo1MTJgPLXN8+Numdv1i26R40tuHnUVcnqqvqYhNbjrQ/jK87nkUDUax8UnZ1eLxa5k+wZSEyZ/DM/nL0+5oP9oVTZyGthnpIe3j1bQkmM9cyw9vb2suAqMUuxuLRYDivoG+em/+JSKKVPOZrSyU4dwzLu8bHupmzybNAqh16a07hlCsvKbyTO/DMvaHAixTwp5oBj5bQuVZuFWzDin/b0z+W1KURzsznR5krWPNf7s6jZKXD6kzU2fwAGzVLfxxdNLRzsa4L9kD94SDZ3hU85AEg79phMM8ItTAgv9BjpRXUtGE9H7zmhsTXZNI6YXzBrtGLWK3HlBLjQwJ5/7B499tDMu1D7nIYIo335FK9vmJmgEEvFyamyaMnAV4T9Rqs5A0odpHpTNw4/+Z9tjSEVffdBlpJpOJmfJMlovrtIr5NH0pdVNr6ru04BEw2DBxpD/mm/N1ZTPKLe4xcN1os6HTjLzBipltauGc/U8hM3JwwvQZ12mHWk2xqcJvZMOq4OqW5sJO1xFGILW/bmhVUZNpMA+xGvphspihlJbSRHPnXwW8dTVKFPNFVQ0vDlikBK1dnvOQb+b0dQDurS9GX6V4gUQd7PEVySOq1RKJi+2wRPodos/9DsvsiKjzuapS+1GoZ1ZOWNG4SWCm/B4w7Mjcg7sv0a/o2d3LJwhJpTkIpui/+xOI+5WyG5Go6MrmVeCgRmbpk5qmk0odofy/D8gQNnLAVkhNeSA3dSFuc0p1aEfpGv4H56HTww4C3NaBRKzd7VNvamMSdDm9ocjevV2pT6pOI5oQ36VGNA5Kb+u2etMVKcTsAMQ0K1lUa0KrSsqv5///9AFL2p014gL3lXvyADbHVzVMoWQ4XbLzp9ipHl4GXzaKNTL6wPRHUJyQDXeQzU7YOaee+p8J6/F5s1dCwgVTeLCoPY/X8m5kEwvM/ciRstbrR8iM0B8xRQmlQcJNYscxyNwFEZXaEiwSzjWL+lRy9635p/9FU1XUx7XyHpteZczcVxiIB9cbbOsHVmNefbl4sX9ZEsdfNB9owa2T6vFGF4yS3uQEehN1rlim9UifynOLmuHz/sAU54ohanii0jrXBI0W9az1TqcGKs66/AC8wzoFgiQdzMGBTnsUuDueSsCjTLeiGfaoZBDGsdsr67ypuEsAkQ/EGhT9PUC/UTkHQiZy9ZNgip+/EXHSlrkMB+OCsGNIqQswE/0+FCLs8qnbRlrUoVqUSePoqHr6SFW6sJy6+ISOXmyT3yoFMIY6GCahbSMZA87JVcbwjcBrMyA+TL7KQzwmQJZRHSZcqSftHsFHID2fwWnGyPI8++6VJ8j21/QKoQEkcenSmB2ItD/gan1W6qc932JBldCFaC7eLMJ93h2FNNeOe2dzRF83jC360hvBUz1JKWibEbijdP1wkbyIzPYCQuoL3BsCaYrEIwJh9LMTA+ap+2A35QA1/s1J0miySy7VX1gMX7xt+mKjal1x1k2VIMXprm+gCZrGJB+c7dSEM8r+ZBtlINtah6Nt2oBy2kJDOhLc6OrTrNtjvvIY3MdtBDLzr5XBvfcb8KntMCtEah7AWt/mWcOk5OEmbTmT8Jl/uEe9UNZk0R8rYnNELrWVn6DJfMg33rvMvieLB6ym3a6FcwVx49mvjoFIb+tB3McYy3D+wl8UzexWyxJxZhiMfL45jye3RvAe+gT1kqjlHwCViXZIxvBZv7R2fW4qZhbRgt67xWSYbTHVFMC6aOQYMFWju51zIF3wmsdO7hOUfvLFTPqz6SuDTeGFwDXejKF9GpwAuoyb5tB0+/dhpyixuM767X3qrenY8PjXRUZbI89FzbMJ/LyH/JDsZDD0LYdEKLlONqkNL52tyOtFdQP663Eg5L+8vKS2CKHoKA4etjSpKyWEhgfVfq06ZKZ69FAfZxQbX7+UJe0/Tane5kL/pfoaP/fAjn87ysGHJ4DGhbFXJhmobJ3wiVfNWOBeXm/mLSHheMQMTtCaVXFccKKwhpqcjO3cVz0HOCGfb0+YFcEvxa/LqM9u1a1zo2rX+i83YzFvjT/fLQDW9aETrShiA9IycEXYtETLeeKXgajQ+3FiZRS/SViup6xZWXGZeuJQhumKJbjeg7WMkxiCDQ5TKOBIgFe4rz7/pX1OdZiQ3NZPU7sXmblzQHtURMus3IAI11oHEgNIUcUb6ZWSNFK4kubOhNhQdRHlTAQQFDK6WhgCID8i5Kf0YT/pG6kpDg7fRB+Sqj9S2LhuZ4t5SzQopgbgHCFw85XF9Oe+WNsfeGSfsrbdubGsmGEEC3B0fveaySePc/OWN42JLyTR+gbonOK2hRAhxyzZn0/3tZdWzwEZpjcqVRkbMuiWJM/3BSIr3rrLrzK6Y41Dpui/6acBmDrvNmbUW+wM7LOyjNAMKdQxCkt/XDACbuTtTdIAvI7J41hpjz7SLWH6DZwK2emcWELUToUn/jJTzOSB0FtPRFXQxLOkLmyCUg9G1is4cvB5pYiXbhXLUB9Ea5+wLC78G975qUS0I4b/RE2w9wDZd5AitbYgDFXb9bRzkeIodZ8sBLytlosbtnJaJIHk4xUiC5ou8j1xL7T9GUA7kP2/sik/BBzuehnsmRrtQ9zzymxTSSRFbGItUmPN5UFOTVxynjBXmQ239xmMQaj6DReUYu7Zti6OjzcSmU0boYy1vqefPS3FT/qYxwhdOJ9a39J/6Kgy33+yemnAIUODgR797kEH2PmlipJ4XusO1zCcSFjjOdCTv6XdXClXZio3LB34oVfecz0+UhoAV2eH/9r5KYvQPg0weBGLEuUkQoZrB6u0xNCtyRFKJFcM9Vu2QMnQ6sFQE1g58mFtsS0Apf2Nvd8EtY0S/zAAD51h24YnYMkfqIEiweg/jcBQaOrCLRZ7+9++Iv9DQOkQIm2t6uq9dzmBhNKZ+Z2V72f7mGFvz1edVGP1pMTKLHubpY+4S7ho6dYwcsCSJ7LfzIvDpMSnTSzKioOMs6MoRyfaVWHKxPjst63SErFu07Kn3cX9LvxK80s1sTKs31RWrA8NOo4+m/15vILsp4JehuPrtkaQ6OlOqwVFZoMyeGB2AjjbSUbT5Nl13y/3JYNgAheRO3LV9uf7vFG9x9XvV16cSajTWG3kdJu+XS9AvjWKPkpnN5+KuXcyMcPDMmv6/OV7wPYeGOv/5DUO/gmko9KQc06aTrggOkBkBnLnl/4UIwWZBRdWUjOj9dTEzpISLIS881/VWrU6ABOfD9wTK0zkg4M7K5Bi9Lk6Yt67Aa3BQA4UKpDV+4HwOKnfLd7N4Xg5L9vF3sOvGuwaTuueUZhz7ur8v4EDRrHxzfMu44ZlHit6Hbedb5CCaaXPLiqG3mm78yfqe0f04CaO3dNNuaDFeCCPayIKXNsClklz+FvkFw1EDxFwJLHJ759N+xeWB40pH2yLrW44JTuNEhIRiM4ujIwUxS8GW8M4Aml6kCV5DCK5ksy1OCYafu0tQ1BZYkx3dQdpWD0FbMFkIYlXJdILHQO5j7A2mwiX6ysVJN44BDN6x/AqmtgpMzWW2zOOZkG/8l6igiY+/zasvIAlWt+L87ShMVqnUhgzaNYwykm2zFHndtZnc1Exk/j3/S/3gF64ecyn6sDF6g93r14G9VzFAmZCaKuqAX2/Sl4EBMWd/AbQXyibVKI+oktuu4CKwrDUHJqbVAdopb8WLOb1mQys/hpxc3b/fx3HoQqKfqjKSXlV49GkO0wNOlXOxqXOdP1zlfK+/k3ZBFe31XQs3gwjqZZv600UK++u1o6MGWSAbwxeW5PbfEgn3vKNamoyDgTLeS3e/xOnTzMHrK0YUoWgEXkHfdE+Ll6RPX1BnSpGSRM4p5v19Qx2HXIU+esNI5ZhgQ7JhwIzTHjMdhRQNN6WMW98Lt2A1iuXkayWaSuZpqLkskJ1heraIedCW5mjInsJX+dG/ZcIFNoBTVGzE7labj0hq6zIXDd9DaMw7STNCfT1LEegRDr2EKaR3AAs78GBIac+YAhDZlpd0CwOiviPpnFCO0B31p0f8tN9p6Y5ngNFv3YhowgDyR1/uTD/iseidManzKMZA4wGVih0Wye803Sn1Uy5rj6VygU6U934fFqrWnwAIa93+YNsFxfsqQTPop8N+YZjQDJ657FdBWDVgMY6I4KcFMIju8lwArZ5SzKnhXJi7XozQ/Bi84BeWkpmZTqoQck9Xm8el0xCgUiYQdG8aBKjzaSf87SAbpnGJOHm2uyHGsIeUl1W84APK/0MUGXVAiWVNS5r70ZBC0ybruC++Rfmcd3on+rZ3I2+xkJ2r1ZbcOcoLScUz/Rz27MsEwqofBwtIYRtuDTgDRVlj2tC/ttgTaLf5bUYStgTnSktmCX9GVt/307h8WhmxHLKTd4/GaGfwzqr/rpKw4CY7jjp1lCyx2r81qUPZrq69SMm04O6OsnuCfas1ohW0uRWrAuYFhaMSQF4xKYc8fHd0lIKrr1kaoMj2jgJZbONvTP9HDOtM9MTPbiAkmxg5IT59Rbn1UP9FslHugISatvwbXokW+IJ6nsGZPzjcKiJpIrXXPOv5X0X7I3yjHXBKBUqhraigqHg09KEH049LcC/tT3m8LGIcW8J9u39+Z2LkQGRv8q4tzhoT0iK4nvm8sZESjv9rFjNxHCCsKscRy8sFMZGJ5ggUffc7rfv0umIMKUoFy6HRPn/m+hBi+cIl8RX6Q91KDHucS1gjDHLvAO+AoJX3n5pD4oNGzCcL3zXJzBOK/PjDqe5Z2hHEZZFqlbdY9ecu3Nlg0R7L4RJZIpvXLDVP3OZ2L6BNppIPdPU7Z+Q02H3FiEGKB+otHgdQsjYayLldcZf7hulUjhH3VvtjChx9Rz3kN0lpPTjSFX77HejTfcVvSdrc3IAN4se8IFIWOC/yOJR0bbgBt2IZSEEUznTTpJGBXM5w6fqYB3z0+diN43JN1hIuk/1X4eK3n1cTfQ8gPWdMyISmuBnzqOJmpDfpn0UUVV+wQcGR+F2f3DIKtWSzM1JJz0AH3lVQndVPQ1PejW4Kl4x1NOthoQT+ijGpeZrbRQcRWVjp0Qvkt/n4ovWWy558vylh1kCjyYJOgd7xPi33FqSomqmuaD6Y1D3xGv6TQHx2SnyTcJeC2XxDg62i88wNdg4hYKYQkraE5d3rJb8gGw1R3k9vbu5jeH9wT73xR12sigJnHfSf82G49Yg4ikOdf7YyhFegEW4AN9ulF6y9r3mIk6sjEMQg0eI8pEj59+hOKNRWuaJ7SQlY7wArbnWprMzBleJ+xyJ45imM1MlFprti/Dq6sjZQvmu/6bOuN+4o8N3Sv7Hkf71l/eBLNkZOPds2r+RXYJcwyrJRu8bZLpBXn2xKBIoZauz2nUG+ArGya8pPgiHv/OtEgW+SBErxm286Hp57y+3HpsZfBzR5oj8VifVjYu1QZjba6QKawMW/tZIdUHn1VighFW09MGi7iPSKhcv00NiRm1IwBm+bB/GMAaihJG0EfJ2yu9x9yJIADcgQjnK23wWf6U8xs528iz0Z6d34/xwSeySwgMm7f/0qg7QVH4OUmT1LZY0pZmCmUv+Wafd1ukVvk+ULkli7+mCFukb77vs+P7nmgbBWKtpAJe1gStlpn8nGlSztitdwJz+SYli8tx1Gt3KC7Ct8Io/WrS8Xf9PMU1/LaLrZJmx46SqosmqPs459ysHmPdyUuT8g/AbMuyNXi4194gyeP7Jy9LzTJAMZ36wCQjSoFwo8txGl6aT6obf++AG/Zh5fV5diCvdp0RLLA4lMOLB/7n6XgUWsR3fyf0EYMw/U3Zed/kqnMj4nHjQ+FhIC8WHCqWNfOAm8fV/aknpnkfCRsLvp5r33e7Er5/MTUiUQ0/joCZZxRa4KuwhKq7JDmT4uueI4z72CVV6zBVUsVd5l59D05o+/441tPR9RJ7pOGMMl5rVljUQoXISrewHyn4Oa5xR1xyvEkZ8UIEzWBisHC1uD0J+0D/xwZgCFPBc3lolcd8myXdw0uZv8Y2DdwFaDGJB/4Qer7M0UxlrICTqQ3fK+amGAcH03oHgVpjsx711CkgwU5K7E2iOPZoFxvVVMfwAOf6L7E+uSkAcTIATOJI8C8MnZLSk1DC5ExgMAJptGKTftFaZ3d8bP8iAwAbLze7gC9/c/eU7VFp4LHRGZzQTS1KyKt8AWeILhUH/KFzMJJnZaRuqI80JJxvfm9km1iUm3VQQY9Ihaw82GxDrA9heOqsVzet1BZtKX+NgQwK6uzHR3zhiPaKkbaFMqbAqZ0m2HG2lgXcLjcQkHzpyZ99aE51OWNUY+tFdCnUnAg9LxgUY2MLEVW8UycmwPn1T8dXpW16NXsHDPmUDmazoz6tDMTobeUo1XxhLj5fHZjSs992knswOm7ng6MfXpVHxihc45SSRVOBkBpiJF7dg4Q9Xf1COxutpqPk3fuRSWfxuvvu2eL9aA4YhMR5hsOd7jecsoPik15NwpKQqWLA4f342co0tu4YXU4Uff0R1t0D17C35EL66CvoUY76BAO/CDONCMD3Ccfyb2MvhRw0q7iXnpWm0XTwfgZReWhVb1kKbFl/SV+dQOE4xZSNL+ILmQPeQGNOYG3MaudalfmIfGEhg+NDApovaExpWnH3K5bhiAlzbZUpXZcL5ezf/abrcD1FhAUctf/dLDI0mBPkZRj32mP1+gBC+gp1k38AcH7Go2eF7osNs8OyaOQ7/ENUw0v2l3Sc/lKk8eTGidSTfmqI1htUorRO49NEY8nOdR/3lpFwfmeOcypKL/slOmLI1ziBQjch2lhD+HrR9ag1auGlnfy2BKwHVHYozQ7b7HvUz9EAv3bPBHfmr0VTojyjbFRSQS0meaydgr3/DHVnDTSCwOTGhwqgvmgQtMXdB7O5p/yfcPAwVRCXTPj5XmTyb4Il9cRX8OjQIttrwwxs8d0/i/m1PKvjEdEZ3JQ750laOfUPC4ORhRL1iGd9A+c1xGq/D956nFf/rxMd3Cf2d07XZkjHfwdFJvmOhu3yzXpT84l35/mA+ZJBz6x05Zmyd2HzcAD5DkNvuikVQz8sb9gkjPOAd1m+/+pHFXhbGYCrsIWiwa8lmGkqKXeHnbEV0knPkk6CLdeyn7P6y62LrGtGMz+pIEAZqwKptkDlmQcvlwVIILPlv5scnZVS5Sahp/1sGQgfXLWn7ETTiYa0OLcuUC+9l4Z4Bl7EKB9RYrINpUxRrgtIlarJueRNJS0VaDBjMT1VhPPLV+WWEkp4nVH1FxhScB2P314bessAkGF+BQLmK/YL9Cmw5c29Nuney7c0dmh9x8Itli4AOOMrVah7cKMhpBemCR6VIEIE/DY2Qv3QzICGaFmVXzhMF6ealZMwmxJ8jyOmfX+tP8n0PWqfsWtGb9hZtVaRCtmWx9pkLLScU5rlZ5q0ucdMH1Z73UkYLNIYkCgAHicCqJEBOTB7vGiKBGZLiJ69+rO3r1q5n4LaXFTP/Hsz/uNbWnLrzZXWqdaR/WY5WwL0l+7wHJS7EFTaMYWiUFEro3U9Rw+F+8ck2bfS+rvHuE6VU2gTWvb/YP54g4SHQxP688q3IdwIYW//TcDhN1tVq4vbkChiR/6f/1qFOrVw+aTE7J0FATMmGSnj+N4iIyseBFDFnHNgVO14fzAyXyNSRxOZy0lLz6Am3myT4+7g0sQ+P6SHVA8Yr7iOzsz6j7Y1jW+6hJ3y9W02aMFCMDDPRmGHQAw0CRtifCTgaBaSb4MayprwU0C3wSaShGRNVuNrMfdamZ0pcmE77UMekARi87bQ10n1nLqRefoMkt0MdueJF/6rOt5Qwyoo34ethOTPJ9aWVgVa1IQoI2arqbCa35ISiCVg/QT7PgRP0L1YHGXENlgtsSWCw6pSJGBvKCnDx3TgWX4MCqXJScT7qDQDZFNOK3gpqlMJMU1G75t1rLMWfEbJzvWcKtK8A/BgYQObQQ/ZctYdYMowkII1ZDS6MbYcNRidAll0EWOuqYRT6OdTBDbdPYWGOk1Wn/hh8uzkmkVJwtuNC+UCoQDgkgxysTwJFuqjJ6S7NkRANBxIPi2+PYpJj5HFp7A8iMDJfDhZJtS4XvwO0nP+5Bo+k36ddgYZBN1p4ZLSyG7YKzdBiHLdKGyvoOVq0P/5Fa8N6r8T2h22hMak7a5Bt2F/b5Hzx6bDiLenAI3TG7XnW/C4DZa80kKElWL955VCMxLKPdM+/FDW22KZjTfMzhkR8xDqElxR21Tf63SucHlzgcmE6do9a86+ZqWZ9hRgEU1q+nLny9yIIGgIxnKmy67kjjCjOmiSVi5s2XYwZKh+b4zr7XSTxb8Snu2tHXfCz6pqxRNQczYWpmYQdJKWJ7jBH6KvIMIxh0x2rbJZFnsfrPWxzmIcl1KV+OyQ0Q9SYaCavUiY9PRq2JpfpiMH9x8e/SZmVIMNjcHau/B44kjUkbG66FgFs4/Lz8R8aDlNOtqSMr01amhikGfCwgM9zWQUFfiF705W2w94132Ccz1DkiLoGnfu7teSJ0GM1q765BrowD4JeFAw8uQ0MS/0YerotUv/aTkLJ/EpAcPpRIH2A9mjbgQjVbfOhIH71JEu8iGp9fihNlCzVHR+1hzRvWk61enOccvjp7xebpSjr6oEfrcnCzIrkRcrCEdxt0Fs1NxBGYfcT2xb8Lw10aG0q7TX0LGZVJ0BSTfxm63GFhy7JLfAy1PU922+3nG1vnS7didcgTAZ7+EuXB2WgQhCrsTkF51ynGDn886NKKHQvkpZ+zQAr9M5C9t4DrakXHDqhBMofZAhWCAlL+DoG18XoUHupWG7CWjHpyM0iWTbE4PQPmBxq3f1J3QeEb7OlQ/pTw2PGyLER+ROoC81GzpXRYIYOzWwU7/nCDSnyeUsG/du9ObAblAKdN7ry0rKLFWMEBw9JorEnD1iOj8NhpJ7o2ihevi641RmUE9n58gqjNy83FtY8qcj3TNLqt3fRyZgHBqzcjBBkl8cXl1lGMw3hNn10FwCrJ/m4/vQAsFf6NMMKuP46R/zvg0ojVPVJ+IsT/6PmHaKVWijbyeNpTP35lwJFt3UMK4usB05Gd4r4UPQmRe551yqjJxKJT2Hnsy5Atptds8T56zZ6g82iBdruh/N7LlAvVsCTn+wAeYYoNynsiCfGWAajlrERA/rtqUw4EWgzgcXuOfi/zCtpttsEb/C+5A1IqGrklj7e0HJqohnEMq3tezBQKIrI2rVkXhKe3VrcMUQy62VX4AYh3VlkfP+WUUbK13wW8G4gAJ+tPBcugNvvsmTBWTLJS/1Y7d2Eq3xb3oh0xUWlgRcmjpq20wLoE+iufOR5ObbpH+TeERkeVZd9ir3n8cfl6/bxBIF2u3sxBtuI06kJHgCisR1bSW1fiIkI4UvbfapJcicC3CAsQ693bTfnS8yGXsl/YNMvSC8fSyMVXaHAHZkk+EZX9AbroDQcZHS+z60Zw8Wf8SLMV1fXzQhCdmJvH57hy2WzpPVqg4hdB9SOUB7QUUh3wrJ4INhYj0pKHmHA3JqmIR5FfiFmqJ0/AdeKl+6137rGiEr6St6hWzT96z2ydlZgVsvtJeV/UOXtBeCy4YIBAQoqWmZ+jVa4qhNAvMpQ0+sQnUW1j+ZiJMSKc1TttbmtFnWmxjsFD6bMayEhJJ7Z4bs02cfVyZlVPESmNCJAQH7FnaYOOfBeHIkPK3l2TPJUGPGt3hY5rJPS8OC4GNYIQ7JTnp9HhNNadQz4yB/TGnsVXsM9I4PrfAKU8xU3jtPbBkkyYUizC1qGPlELSYHZK0N4HJe+zVFnoEXkmFXpTDvCKAENV0AzR1DxswmqTmt0CClANh4NpC2h1XR4h3WBl200DOiNERtqzEebFwMR7pmrP/BYMS5vNmClxRjUQVkxb2LRvEuXs/hMXfDvW3EgPxtJXkEp48jwWFkyvABOzLad+iWRe/KpxPpBz2WXMKt8Y9AzeChMqsu8NEIrNzlYa1qn0x1ztnLiodPzvuwXykW2a6s/I9OaPYUbdsHM1zVREKQHR3s/SM2HFJ1Qo9y44nfW5wIuY0nrfUJT9Fe+61lBbCwLKbxafE8RimA9Qvz/4NyWkD3oB5E6u/f5x87lDzMa8NPjLXPNesdI2OJplgLmE3T5Iri6yGm4vWnlxyIMzziJM1oE76ZQ6ikj2Spqn78zttg0YXdy6WHDTIQBlHumimoV/0js4z1b2mouneP88XcXkAKrfEJt5Bj1ykhLrRYgsI0KZynC19Fc9uS1ZCWO2QEI1XzRkBwyk4gzvHyRZA1RdD5tHh4QDBsjnU4Tmhj/NnoJA5M1tU7Qh+JaaqAaCnoqzuKjMAkShBLK+gy2eMbjkqj6e2lCWaXZzUt37LsvCI3MJcxa/XuBiD+QPRVc4C2cAQ7SL1wv2y4qshp+iB7QP1hSBqNV+lmXwYuN14JaPBi+HJ80rjmvhieurGA42IdB259hPi/cQnh4QdqPdBwsJQqWBdslCUz+ZQbSvdSHb7pB61v1thHDMNta/rcfXFgGN0gRVTZ2bKIrlx69kqyGG67lpCUpst7hUYemYkEoKAf1EEbZt0EeZVfP/Ak2wnhylrc8u2gXHfM7wwiMxMpN6AfOCjyplAOiob5sgBOeMeG8TGTN+rTTet6nsWwM15uwbQmHFhF4rcrok5f1qJ0Q/gtOIwjMWaCEtwLepebr6awokajomYuoCmst30fY8aaoDQz5BMsY+Dbq9Q4ombRvReimtWQahwKylkQTvOWGLPkQPnRkJBfGMqxkAJAbDXikBBxr8yDLLTOWnHgnDagZBzsTe6XmjmTfOPxrLf0K75chaZYtHb/ZQas9gBPrfAf6FfSWVRbYDNuv9K+nWBzEFR1IxUOiF4Vsb/45S460Q9tiIflv65OQy8p4qrkbPUjCsD6H8L13i09pvKsCgcT5ec55qNc06lU2BLoRHVnTdDsT4XbWDqpXBkj/aeqJ62mLFLfXJ6k7obeFhUaB/CkjrPtRXzxEMd43uzj2xL8DCwA8xWH758r1w7y2PeUC1k/3hmUMWW3MO6Nt1HudK9rjBW7XWH9GWfuYPKygsrPypu3lkcnFOcw31s+m3ZSeeda6q/YK3VYJDd2GHGjbKCIWegANMIBSp1aWRAHTUnIDO7Pa3adCXT0q2T6jZTenM2Wab2NwM7HkF/A5mHsBr9KfE2H+jlWBQB8kmavWGvey3YdcG31Y5a1VAPalxnACy1x3hjyc88dIyeXB/eUyfW4AZrw+oIkfw5dEdEmpyZk0M8LOPW96jIQifcReRlkOhBn/Mnehdq0u+Hc0jrkvDKFFnTuiXL/69/hYcjJNOt5iUfRUHNMqjdI2mogJJXovk9yOI5+MIwhw2GXRTyXN52YHa3DXJG7NJacJQ1MLIpPxM7TYDBh6Og/y1ItRv0FnRh1a7fbhtu8jH0XOngRX7h9mawXDz+xHQ1u72y+bXhlLZGrIfZf1I7QWqQ626p0L/wlPBkJUWDjLpxN3jN67TjdGOf90Lp6ETMt+aL7SRNLOnRpDehEDSniXjGvgxH8zxHgyY8CfeWYgZVu0gDNkaldOfTs1ZiOHT01eIkMmoqJ3qAcK+qZkutQMTwHWytbdkiKffAEU1+shJ9kjs4y6BDDSXjQskW0sQo1eI3r2Cx23v8MDR/NtptGGApmObWsUdd2obphPIiL5xHJUVlktCqkf01kI19zkhNa4RZSgOTGY5FypouGtjS+QHvmJ0qTHQ34vq61GlFsk/BYMo6RgAEPaGRKduTN1jr0niRwnPrCkhjTVqIwxYVCOPoqCNqUN75HCeTe8IK1NzY1msDBMSnca91/R+st+SFyxGcdFRXnhPXWPKoR1kqfGUPP/Fh5+EoNSVD+IAuKvA2n4oLNKwGXt5IqfHIEMZxUUpRWes3o1j0hwWQGH2xUoaPB0QwR3Cvqpjmkqb9/ouCdPzT5grWvE4ojyHNx5V/uSSSWvq9IFeBBQp7qU/WG1i5lPLfQM/Sr/QAiNlEeOn0Ps4yZkyGnd0PUS5VyyNCIPgHud2JKvhxlMJFIN7o8fEZtzD5wCWNTx7B5OCJ6EB/TyxMVKln9pF77Yjulo6EiZH/4zmsKHkq1gHGoATtqthJ5drypGgO2Ac7FzPDcHJ6yk10QogkzQFhpT0kNc8I1EN3QYT144+3nCo8rkq610Z22z/+wjqpacwACZ5ec2d0bDgE4G06vnjXDhoa2DKnNgeLWayE5h9NT5IEBxI3vJi3BMxlJFS74UsUHGdav/5tfR/qfOk5aSg0nC+DLoOFF6NbALOuDbWgxSc7zifYoM5TfYYE7cho7YHw0QauZnrYYgHGKWKPVbOlToHi7kyeMEdjDBY17rqYzKa4botHBBeDkb2+o1QF4h3Z31/vJRqct9J5y/uufKahPP3ky70JgtBKUBePbT5o3Z2dYb15rYec08YK0DEuIzk0BTPHzatFGhggxpteLTwtalTI0+b0BoDpvTq+rLUmPBfmuBOAJ/Xu137hcT2c6hGmsHmqn7tFtFMaqMSb+2rxjOGsN3nXlaxLbCZprKi831245HcEOBJ06OQVd1dmunNTjV+ixWDdZperxUZvaxgyvRpyqlj0x7o6aLc7QujHzHfEXYCq2NPMUU2uPLe9z0YFF8C9fpFq+zRreJgEN9wTDzHQhwOsicwrnvCUcodDtmG5VAn/1ooeTA9b1eixUuZr8BrV5xIMO2mnqX13Eky7WhxFQzKmgZudNANv6uvmJ0AF1skgF2Kg7RS4XINhrlI6tWOkuI9ZNMZ2M/8jf6RMJUKEdo66oopIrGeHT6Ulyat8j0gzDg7Vge0K45AxV27+7XvjRM5Bdrx1zp1yf43CfVStoaa2MI48gXaurAdcE7R2m+uYGSE5E7VLiG+e2RAR/cfvw29kiXpWj+8Ow2TlbNHLeQCCpOB5ijB58VoJTzyObVkAtIYvkOylyxiFYJ3nr/ak9zv8ntYobEFo6Cl050bRNgB9nT7SYTk9mPnjM8z8QIav+/pXSkfq83TvCxwOQroRvygIuUQqaEanTBksa2k3g85U35+ddHPKOTsKBqil2LdDe+rQFe0BqBcHqLHITfbWiHYniQSekbzv3scQ3ISoLaiinlC52yI/TlO9TwXk1+QCoE9rPwtlwj0pSrhQO7zc+xL6C/JQxvdvl2how+HDCVYHeoYsGrNBoe8Y2vqLIkP6hm/ScO2U0ERxDOYv2dOCgi/u5r7iFqzWY46lyvTpdsKx8QmD52Sg5fwnPVBRozON0zmkibiDjmVcdNMT1v4B2lZJHOOwSQKT9bcwSAEbCtY0xK/54g+rmUvSxWG3D5naNC1UBjppj2iIRg3PkGARLMroR5Qjtc57y7m7tgJlfRBp99LfdW0hHXYN8s+yxrYo5KO71IeHlx0k8wUKmWJaB3/WlVNn21b4l9Rso17nQNTBDRJQh4E2yJIvc6NaiRxNDPllxI0PMBUHORukFeqwNZxKRVNaABol7Ne5/vXCWsk6O2oxmDRDES+lAkK5Ibje9DiOJ4AtRpIHXAEKrQEviOVRjIOnPMO4E48zNekSgN9odNzsgONBvRCuQwIyh977MXrA4I4/ZylGZ9zDoMm8uE/hAd1xQCHOhRhB/Dqdiwj3UMZDtoy+eTE6tY/a6QT72ikDX7QRKNZDgZxdLPsCf/NSVpgxTAiYpi9ORGDvadtJQrNB5VvW0PoxyN9lW8t70zRewVwoNsXclQk2UbnN1xBSX2yF7nmifAUaAy126TQKiSub8CC+R2AciGgTOLdkazwBLumNOJDRJsEfU5WaKChMbROYapZkHhTyXZJo/9TXpBQq+Tg9VLEvprsTVN+NS+6jKmvzv2DYoz+N8nKapwAPyluYPpnvgcakYqwdZGIhvtg9zHrMdt4Bo/C6W1wzCdv/T6TEOEnJ3rlB22AdF/7X5jM6mHCxUdgvQRFXmdniTsCHQ4QpW6JpxhOFX/RgTx4DJbBAoIvBBKEhYu+i0BvvJHxkmkLHu4vTlwSx+hJCZKOJhkPFWEGRmKQoUHK3YVebtLmoZ1Lno8codbL7r2ZZssvh330ftFCRs7wW5EKBXFJAvZyBn0cW5LmcObKx23Mlnetlynq23wi7dabOccZI6LVaHksu7zPSaJG8GKvvraDkAW58jtLezgqof6gU0JMhyFbqH6Dvh2dncXHHxwnouMifs6vfYY9Ba66ecY4PPTFMGJUF8cHX6fmOrUp8tGRK0EGJFN+r3Au0iaki9XjQ1vO+R+BoIuJD0xssimhCKNo9Gt1W01hute9oci7q22nzRi8dSDirlLxqRmkICpm0Oqp7vf4q5TaExNlkbOh+PIdUE0J1NscPeNPcUX/JD5Cwn5dcoatdfFeDRTXsQ9MapEYj52/ZBVBXU2KBP1w48c4wfCSmSyKbSSU31rDYcrLzy8kfGSVBTsXa/HfRE454Z6Kg+PTlwdhzjKl7BW5Ubjvxa2wJJXwTqpPj8nTRlrDorB1B8ChWGbd9VVbtsyUB/KJej8gvyYO5S8xO9XbxKkVgAYdo0GxcfOpCyNThchZ+edLk3njxfIaGNqO8ZAdC9hJbpJDFWWExiIzDfAnvxoTEo4wPBY9ioCySsy5Mghz0pz+M93iYNvEFRytdS69aOQ2Njb0M9JxS+8w4prwICWnGAap5IivrNL4/y0tRAm8k2tvgJxzHfOb7vKpSBD8NkExoIr9PlMhptNPvUmozBttUCDNTIHd/AaMaxhVUG3Qov0aASfzNF5JPlJ6trnRPar+ebNMJVSIUlmro++ScH8JR/KR85GR/qb3joWTP0jwlArAYB+HzafEKLJsq/opUGyFRcIjqjpmugMjdCwXFSc51iw+VppoeKxM5Yc+NEfi7/hsPJ0Omy1peHpmCHGRDocAisKlgPK5g0n6f21bkjOY9Phju3xhEXG+ZX+OD+1ZZ3ngaTYDdTF+K9rPzkwZfqYnNesPjFym0uLxXaTg4X1cljNLkTNnGkdHjfHvNdRwm56oWuaOHlnuSBhw56fkE65r5fYn29Qr1fote8FWYaF4Np4e+tP2syFj92mBBhAgbZEH6U14xhMrZXmplUJIUJh7i1Di+OE6kyVFB1ZG+5KOMH5WpLKi2i1vzy3w0aZMSc3QTLqoeJMD9S4S2VKtWfZd0TJdnfXSvn/MMUPQvU1gN8z8V+NJYnipkUiEZNLPjocRhn4TVkl6QFfuO2CShi8x0kAaMpGjkdltWhjTeUiqdPuNh0hJbd+WM9HZXmx60uxl/RXTR4EJ1oCK3V5Lk+/00ToquyZu8Q+bPOlLIS9KbFBFsjGsuGbhOpMgPkpozp97oU7+/gfy67p6zNbuYyUbYRqD7fk7WzEafqYfWx2PWjzHy3DL+j2T09WRzreFAimfy2Rodltfi+F7EPKHPMS3aCaONrNLDLs1mUjPiWbmjv1wHw2C6s5kvm+mBtyP2nVzCrpKW7+ZvYdmEiUhNNm/IUHD99CFSCULndn6/bKLp6KRN6tQ+rny+5kmYXD3pSPSrWgJ1kB6pLFuqfK2l3XkqjCOWlU/ZZ+yi4a4uMtJX60bkq81AkG5mCRFp+tSuI7+QfNVxqy0V0bJ3oatuMhBLIkH9E7HRBHeDVz+J7n1bqVxC7KS/K4cibgUENaV+nfiWQg9+U2u7XzfXXFT85zbsLirgtosQBN+6tHpknm5IP5vzoBlvgRBq45J5oes/Zoh7BwFbkYn8DBw1NmUMAYUKGzAc/gCx2vos1JMffeFqidBlcxm1bB3297EHNoCwZqN55Ou6pQ6Y0mddCfGKQdvrVyA2nMsiq6MgaXuRcP7zauugXBum4nJtAE35v+HFn97GIn4hmZqPEUL91i9I5VzsuS7bOfbYDPxsT6GNLJOUb5V4UEwaf9mwwQuquVVw0p+h4AGb7hSfoB3pKwTgRqIxp/Tuo/sYo4pV+kWWlCEpl9C0IHsBcdmCsPVX1SXW17w4UPvmEgXgBlSUH39HHv4v4nV3pB+6b0hr5GLUPfTMv9wDm8rtxOmXPSmHfgkkMVxQuMH2FwwTbA0xjApFy2y9lgmsHQP14uO2nbRZsV0h2i2kr6R5SvaNMCJhvfecxtki1+87R7NMdtgvZyZqWGgi/BnHbC0vhBc/AgNNlSiHertTwzEQE9Hg3Q4hAMJqL5lwE1vYi2oKPYHCSJvEpxFDudMC4MC53TnoxsCxLXgwvzfUM/KaFmlvne0KIgdYM4Yea7J0yE8Zn5I5nl8+lIiIUqtl9IEMvGEP+5EC2imwXBU6Yo/l5uiFdkNMgiQTg5eBPHCFYGAoTlAfEtmRJ0FH8msJ7ydezRrTXFsnQIKK1uBOIZULN6Lpf0oteqn3Ob26/uzJ1MCi7IzT/q7gmLKMYGwTuA7x9O/9iCUfPGDTBSvDwEtPDaoMPGyfdFdzWCVyNQqC1VnNXw07HoQe3WSUq/nvQ96zcNqJp+Jcie9M7ux0QsYGZ2X2k9Ih84CseiFycxhuziVe2/cFvdq5DBj5ELsD0BOyhDp78evXkxqjNLEQWZsni7wlUpGUTdlmfhHBD1IAYddDP9xed7IhlGZLPRdrvBPPqxMRjaP35vXyfp87ZwcbrXW8VFMKtDRYLddJeYk3rnS3upU+rSbTRhSbKcwMvMlPZYpuYJUtvRjLYqC2yco+QDQEtPIqYvGWziszjHfyoa+KSdEIf5vVb5MJJrufqfMycnytZi3G6J6upd8StdBhm+vqM/KnSMlq8K6dwQBLhHq8oWIiCkZVgIV/Zc+ou6K+MAzkw9Oo6AOYnmVgXhPM6oz7EGWhz5EAsLUs65f6LfBXD9Ju5nZyFJq3z0nQHT3MyEly83s63Lwdazl52xRO0sqdKJLaHzI29xdpYb9N+NnQV/dP05jhX5tIjia9Eeiphb9MpsuizfQ+bWN/BxWMXnLJprjpn/Q5gifLL1CG1mu3sNhPJWtE7BUgMuTFR9IpuSe+RfSK3/ISE8NNKkR3Ybw3n8SkW3Py28dmFc4oz2+6O753jZqTD6TKmn7kuhfPneazOavrRKJJebafvMkaAQROEdP34lKgf5N5Yyky0eykL3YkFyGPz08IbiyLyJz/uJJqGfR72mT17ITfC+MkSBZuN7SexrS6qZd4duoJRbGr73UWfbB/S6gi9WBFNYGZJtiJxm/du1kDXW74pvBm1E/G0RWAvxrjPffUWLfA+P9NOalsgAW/JuI4wML8Ewr1Ysuhatd/4sHLebR15J8J/Ba/X5StQ33SkeNaaGtyyr90rec+KD2lzc4ZkUJ+uAMsy2qp8b80KidkPfr4GrZpyNgZEs34/Uujkpuj/+D3WsfVzedwJCJLYtqnY4i0WegVV9BKcFu/st5XXAjm1oplBJ2FUkNN3ugP8F+qXlzjK+st0bSLeB1plyGQfNkQl1vDXpZntAklHcrQgCnJULSCYhMf860JSSEq9hKolZZOcI76/VDuCNVleWJMAAxk3cPNsJKXLMl18eNm1n30USXQmancmTnLjgqYZefU8IEtHA76L9PEg5BMuhdqNsOwVZdDjQyWMawbm4o9jq5aD/400ljLBls3WqxUoTnouSOgN/7gZPNgtCV1HHIghXoPwxsW1APlq0xgsSFmfPJLlD2D/hMHcU/f8+9yW81G+45YXz8aKRQre1Xd5XInpWSfgcGff+HFxRQkuS+giKejaBu5w+T9jH820W9QbSgJVW9DAsfpXOj9goMdqlfzVPrkZ/Zi/b6i8FVBA9fBH2PN2eaiCPG3OTsMVYyivnvDEMdSvQGCcZeNse1cxjRfzDcnGOyW/93iS16yGUQIZAnWOaAeA12PMUxoa3BDTTRxu/Hdc0DJyCDW18yn10+IBT0e+h5+bLdhkQNhWu/Ub4ScFge2+5LtbXZ6OmcJytFIgLwqilKEQVj2WcUwmHmxdfUMCjdeEW+91PXjgFbKQyjF9GJMCDvROSqy1ZzSRtt+IFvxcSQJIYTuKopap7kWGRyx9aH2aIiQHHGVsf5eVoGtgspOdSu7pmDuiXTQGfq3xTKRxWFUhyUSpixKX7HuV4JicWzv1FMQVMv4oq9BkOYxHNJp0VPSsksdNJ1yqmjqkb6lGSSLq5BGFfDtxae47XkyMZXeUkHuqsU/IMgiQMUpyGQGYdjhFTfHphNikbmhUspAAudNJkSIL72Og6de3bKsXqoJ5u1TL3K+lNbmpBgXMlsddiAQ6dlxAkq3HbH8mA5RGS6rlwSojUaXjd3HSwkGf+sXpYj/leb7f7/NkWGB7o5X4RmGy8o5oUAUMpCDubvJ/JPiJfD9ZuEraiocifS4/O84skPfXHOxRrQONEfCtmZtVznwddZGpSCxXZLZn5l/ehQuQ6+d5YQzWKzdbz7LVnl6+2p29TnJEiLqMwX9BlTySktdauV0G15l6p9Wmr5wuD/sPJXrFoIIzgNocLv039/PvkS6Q6P4Yd0jMA77bP+ayg1JK2iKuT73xuRuMUhrHwNpSmyNCA+H5GdK+0D2BAMeZaGXemFraKjtq6kkZr2n1+4lQbNGowlXmFRJWhykCLOTu/5Yc1sxGylNZ5iE/EKd6IBbZK2lvxq7xQVA8+xxbaxF+KA6URNjwzoTt623lGumz7xHtvpG+b0JMjZfl6cg32WjCcH/Tw7mdtiV51p01EZzue3aAR6T1leBIE3WHdIs1z1l9irofAH/fqNnPRiNbd4JcTXJ2KtNARHAvTnsmThXh391oGfCioRfKGd5UWlfRGSiUy7Rkc+LxkMyG2e7IW8kpy1HjsNYT2rpN0Td9kBtn9Js6MS3Mhr4E7hvcfP1vebaWbG7ue5hW9FJJfY2u/ELUAJ9H3lJbaXMUDHmvuCI4Il5SrLLirNaeYe8QabQT9BGjwDl7iQYA2nfwBwxUMxQ/GAy5QecO1SboMdmDpPjWeNj9UcFe7w0OqvLukLNdR0Ugit3rVlw2ddHBbgUaa4dYA2v26q7j6P1h3hCJVc3AdMVk6vwvMDygK9M3p5NXpBlVorlcr2YOs7wU9J72yMgGAF89DIwKV/rSDQasS2iEweaXB+obFBbuuofhy7EWlljBXXNC38A3XhfpbWocw0lO9tsG93wX1GRg3vpp6S23Gbw2fcWbQ98WTSGw1gmR4r6uXgPsmYBKG961Pespfd802vBONdy3yr7y8sO57T8Uor/GWu0KGt+q6+lwj0F8NxXqToyZTCJZquXXhzV2Ns+/QSwYRqMLFiQGHt9TQBs0wyg2sy4Jx+c/RbVo19040VhFQtYvOXgSTISdr8p6LUt3l+H1ljAQp4tifbXKA5Z0snZUcwaiSKSCZYz3UnksOI80rotN1HSR7TINNqKXKV4KtGuSvx/9G5xZZbVTSrN7R8nMTHNyk1q4rhob3Uk3vrOQHFfyxi0jigOx3X3CoSgGcRBeONtdzd0Lk4zb8GGd2jwT9vD1xzFQVbf7qF/LktFJh5AY2h06H0cR2a0PAGlkCB3FcMAcabDqHuS+aMAxHvVSI4gpUWcioRPbI52zl56yZONkHzNBlHBp5GhOUOrHCP5HaHmVd0fITfKlCgA1U2X0ZKMibe0J8oVfGryC4P+qOXfJzi6qE9o+uJn3n7EtJG74xaEcm6QyU76loCSGBNMNJrAmWsrAQNdecdphjxH8T+boEFk7pQveuWgUjJdx20vBhsGYw9bf8ARd2cGpnLf5Ouz0IVHQx7p1CSHRrhgOx+kE38DMRYgNp7Uu76ZGieiqBy/6hFZljqbFu2QNlkQyLQKLqgAOvs/bYtpjMkA7GMbItHEylwXb/2B0ZTXE49FEY17HOYEkOhEQlBV4tSniwi8SPRDxymEoVuRWbhrrLyvB0IKM2w8wlhzCpwtHyKtFoQpJQ6hzmNbepeQgdFpcxGtI0JnoL9GmS+f7pgrMsufSfGRg3t+s3FtPHwcwVFhCmJF8RxvNkjcZk1RbCjZMKhZmc06KOjmFp9Vl9OG/+Qps4hObVv25Yx2z5HBDuEdxzOqrJz6+OUZ6gvRL5sO4CtXrNxz6950q/tuhHh/qZ8naYjeVcwDIbMxBET9+pCfGq3yaqXbs7mhhuzGMccC/Ofoye3BbTz7fhPcYGwPLRXFxj9oXGXscJ7FyGFIB5F9Ymud1pvm0l8l8yklMG7ky/wZYbJnMcHitPkG4DGFgPSVCBC8vTocbNNxpLv6lzEhWDn38RwWjxPmbgL7KgYv2/L9YC+Ev8FT4hq3dyFj7W9QtznE0kjg2mFDyDZPJDgxN72ypaHwuk1klOehRUY8eASHPQX7CSIrCUFoCx9HpVammmROeClc3YJ4Dgc1G4n6kv3J1IT13bvSAyIP7LcR0hMu7MJyAM5QFPrNdvFxagfcvVW5HOGctGw6YjkHcJkeX7Wn41WbqacqKoX/DIueh1vK3pkqGJNr+oDNFmf38sFQmWJ+iZ8GGw1eLs70MXNu5usZLnLpY+jCZ3T866t1FSAgEOGnROAbDEKl4wv+SoQl/pi5JHnjDFB7xLQcQg9hJYkieuQhkZJzAYbDRB3a1Mr5VvnkL467szEiIAnloPFzmpK1oinUDKa0i5bA4hngPCGt0lkyPuqmwxFBrnpPPPR65yOclqhAgD01i7ArcJtcOHvquKW8b3FXEsO/rsQoK6EwNnQ6lGnTg1VFa9UdwyFd362cCRmzbair4Aiv/vUe/wHkziXxEW/rIXsmFASzluHIerqKezDiaT9aLTRBWZMZrccVFuZOIZAg0Il1Z1+yLvXFFJmed4gBzpVD+R4hlvUeu7ke1bXVwC3UICsyDWKqUN1ti/fFLQHySG5VHidCPpcxhV6JXGPsAX49xTW5MyrkR09QjQQwD+Pk0a2dhf02nm589WIzrhx3BmRgjkgQ38tPMVci1Yaam6vEG9ef6S24TBLb2zvbVeW/W8K9yJSmKvWTeVfSd45B/Rx7i37grx+NgedgseXl8CbtHJYFpS/1+p+HOJjea73MUrY7Z/NKfkJA7fDRa7D5Ibjh8eVVaraZQKun2dcc2KRxQjt/oDpgjpGSKxWS3o5lGiaFaKIkjKytAOhTAbj//htJwW25FsKCvYIpC9vKTMzy/EX+tlhlPOciXM4pOsMN1UGxjkdMjK3U/T2ZdgUHOkBnHZPeCM3nCJLQWCMrbG8iaX0CdP/A6Q1GAgw4l+vqiqXIeEri214X8MMqeUmsD88tcjrSEQGXLKgNd3a274xgMm9I4MZKNmgq1wNsS6E3jEnSyDDNbmYNh9/6qM0FolTFvOhDGvPMRVvwolHnRNejmlvXmFkaE3GIw0zg2Hn3xXDQ2bxwnxZjzI1xP38PITmAC1uBNPDDsuoknzPHceLP2Oka/QlmBRnZj3HBlPm3+mZ/t+NlTIjptywZFZVdpqb9MAl1H5+t7HmZI6nc4dVuay3+We8No/WlVTTd+Zf6RsGMn2apWtTi4jKDcxwOGplFJ9Fp9e8tYTM/a39Jvp2rNcvk9zErUFWY2mdOauxKd2IEOAU866dlu1KH/iMnCdr7NIp9xnVgs0J1PhXUMXjc/Ni4QaLK7u8YRGYt6QP/k3KWOOHCVsyv7SNaATLYhZylPnjO8qdWNaTmcaXk8WG82VAowbp6IHdSQWlAOKUm5TIYxuv2tlWp82CCziq4BKuxbD2RDtmCKuE7vAYYpUi9aJxpM1DEqxwSyko0hbcayLqIkzgevFfb6Xu5hpNmUZZn3Ln6BikPy2rof0+AbepgAWrEMdlGUfhWjICsepybx3m+62eG0Ad6MH/bLSBp2L/ucir+LtOk8cw2KTWG08cMDWmEBvGFtK5PJOOFXuPFCuphFIM5Hg+OnGGGkUD5D+VDYG7jTTpoQRgonJ45kgFPSr9UsNEKY4dbX/DLUxq44EORplZHHQT7Upo3tBhJXAAMbfTbqJoW+KReWemHpI5Rf9pA5fqGi0yq0f2DgbXdlJCHrSmby5MERNwCNZvy6JZMnPw6OKIXaTg79EUI/0IWSi2dzmp3ybsuXBloTK8eagcKKzwrWYLz9EsoFxeBDmLrDdNyPyXlb4oyxEoRiIxI4K7kk/qRYksKBt9SMmSr5p223czZWNPfmICOKqAbyKqe+aSJ0vGmmSnYVuWUrrhXUKJgN877KHzyC8ZlkKPrEomlyJhg87WEEnn7t9JJOvTBrxNRHaOgav7I2X9m9JaMYOhW4EzOFo8KR7LZeEuEeAWiWVjWb2+XMQ8V62cH02KnXL4DAbVdVZdvhroLOfDckDVrsgeCJFyn0/A8Bmq2qhyQwbPni/m05WbLeDHVVgaAmWHfeBF5jSvcHPHbr3iSr53KoH34NuQGXZDOQPMsAA0eeip2znN2PT91JYjeILqBq/2GvzVunyX2ncRk0+2yeS9Ag+gvaY8F2MEn5ttaMoAQHnWz45OvcddXAsSytFSPbU7UyC8FqJ9LSIr+bPpX65Jm5Xl7PAYJV4elpvVi/wrCxDA6Nc1B3ieBr7naUN1FfqHGYc2GqQ7SrOLVVi/mBMFRAK38EE5DEXHlV8Xbkv7tFjU5IwKHSQE4HwAWCbs1RuNcpmx0HjlFI8qQbDKQPU+ftXOU6k2cmpAZqwGvkgF7EcnFMcGTxv6akmHN3cP1J14vRO3Mp/vjzlOJGe4yqZKteRmuoa/pBsPthJ82o9B+aGmU2/64Pl+ZCqwxnyundgIapyp/tmzBRu4oucGmloGCQAFOOvaDYI6f0A4wGyzOb43BArKgmAhJgPw27A3waVPnfa8BDhZgfJJnfTN1Nw4xPp2E5qFFyU0m995ucDa34U8Jak3O6HfXDswgC3yHckhKRPczGrtrzthh7ei7ZkKVhIuGfx5BXbIC+EcPeCEZIv4GeyVd6fVIuObkYDCk8QiuNvdVhEW535Wil4NFVYkfn42FdhaQyWFuda/gcbGd8kbO/LD1j659l2fGpUVy9esSGg0fRo6YqRTanmdKbllY4IXstcNRmYkQ99TugTdSng84rzAy+umNI8SO8MA7ZdNxFrTEUEg/vqkHjhnIVgvTwJ6EM/RhdQqxgAgzdELGgocrCy2qdPiQcwHhTGb1oqiWJCoystboSXKcdFxVsVa8zAspTe1JGbJ3kCRm4g5vXtyKirAUsdpPhrABLZ+eiPk+M62n5fOgsgtfIlCO/3GVnZEQY8Ua9PzeNLiGhff5D41QwRgKt71OsUtzDnDk/a7RzR2WB7X2JqLNL8h/1xkt5fjYjOn1TQvg8Q2invL10vbdEZaDLlYN3UpWmrVv0/1CLriX8CbKl0SSwrBRD6WLZmJciz3e+9WjbIUYQgY3ScIiBwl1wNFsET8fIlPGWm2uOifRyznz8EIDWvFQikxpIpfz+2Q/DUMcmy8+ikc6aNahGncHehevuW/bYKCWmhd689/uPFc3EVjhO9vfPzCNH3LO2YjyywyQoGFxJUrWfx5uRn9CDR1hJ35CyU9uZjc3TBgSGMT/Z/qm3BlIHoGH+SDOb3u02ScsxGmVlY4ivYdGlfswFTI8v+uotUkmKbUeZcAMgmjZMQXKLbhpRbHt2zGYWXSiqr+qzAGMtMRSCX3JQ6ShuwPTADITNYR9IID04f2/fKgemc9Q3mz7l28zHiaKjcHf6uYB70DbpwS7fZPxhIhunreV5nLrgGvNi6UCU6HWLpIHGiIIUtZtErVBw3Ud9vQy7XYCytVZFVUkyQHF6iiut3c01JsxShftk17NU39hO5t4Cwh5ip6lt9n/tV8JlHavS06PAVjsPvT51trZyUvX5Zbtx9zGT4oSprB8jv7ra2oaclnFb8dOkJFR4CRqcNFCUeb7MaoLSKRk/5VaQ7yhXM67Na+fbJoovX65sVU3hbq10OqOpF/NpGpnj/xnNfoW+sGkJbknFly726SvKO5nEa4g5PWI8sCiW28NR53+xIG3DSWp20cjbTSQeFIvjt/7UlSizUX6pRLfrnc5aRafMq9wAW7MpO1wHLAGLcWpXO5+AbaO+gWbCUX155CiNU1s+tB0XYry1ka+plxMfmE3+YM9DIFyNa2f9bSlVICqTx9QIYCiWLNvbJS5beHrwSsfXtmnGYlgDB0MZHKfBOEQsfMS7vAwSmuliXiNS0ejH0cvTsEaCZUrr1Fq+8Nh+yVQ67JdmHqI2qyC68AK+bk3aZKmc9aVuqK813EhBiZKEUf0f04bFUG+5HPiLPjGKugD7GM/ifK4V1Ux0XiZjWQHCIhZ6elQYdFMg+b4CbV8V3MAxjAcbpOSMdvjBtFLGSlyY5QeRSPJSOSxImnXN9/Bxkzag27O/dMKsYawz0H0bC5BswML2Pyt5iBQ0zB5Imja7nbWDB+YYj/MhiBMb3mcZkCFVzOJCh80roPOgtg3Xio/Eg3qMEnobUM9UtmkaabgN3n30tGnrf4Sw4bM/BuKLW+iGZgXOpVSo1bP1m4kIveOC2XN7pbTj6mN2HL1xtIA4IuugiwEOOC6kjqaJ6uG0vmyobqiuKY1XMWxDpoxZjKNC66DaKzYXE3gJO9rVGft3s/usPcqaWQm7liGEP2GlcT0MKVCEaESlDemVd5d94WK9CS5hWN3RKrYoqwEbYZfJ8LJedj8HLNaWjdSohaxBky6O0SI2z0DL3nbjg1zQJDcbEFv1YAnJ3njKj5Mejuq5yToW/mO6EyDuEB1RPEUarItNJcWkTpIvOxnX4CM+idOXLG1vFFolw1HsrJUiZ1gBhIj5BeFRsAi8nsbPTmnzWosSFfFlHXi8zwFWQ71u7UVHW/LUCotv5ls8Rq58oGTvulPTMeukaFe8myWMa/kiFqpvoJ9AwoE/rrpwa33ZlvvLpTCBkJtkQQ+RHlbKd0nepQAmFYYurg6XdeRFvLe0+aM1KO54XP4q2fyBZDy1x3RAB4rZt6VwAmUGs1Iar35y7/ChyDpangsAJQXU2qrSY49l14YtBw644ULAHLy9hYmUw9sfleG8W44IRLz74n8cdMUvEfMmSUsZI/Q+T96yg+lKKDhaPeYqMRn2n8UUOfzpcXOytT3IN5eajzuEv3v4U4d+p0i65yt4XU/yKwUfKWfxNgxb+PvGKDw8klJ7NmHWqn0iQJe7dVMCwSCsLEYYqD3436u5sHe7c4qGiNM5RCG02hFNUyVRz2z238ST3MVTadvb6vLqh+zwVLCvPDQMCI8/AlM9VmM+CHAkTQbAL4Z8Cj+AWVKvtAE1IaShJKRqVXpGxr9pi0hpgviF4seQ+rOXxAhZ0VtJB4oxzy0jWlKARGnP0lhEHJpWd058sqzZZ5LYIqxBtRzCG9vbSh1ra/95gJfIvkX0TWytQ2j6vCaWV2+FV0/lrNwFQLWXoa4jGFSccFS246rDBDkLXuSkCnLFYzjyj/56cPvZz06s6BVz+ZzVoBZfsDWQKxmGQot+8KaSNjHh2lDxSG04/NlfwN/kxIPowG4UIhbprhk3lGxPA1Wn9KmMkjnrM+5ERTADb2YYwmX9bkpDtgm8iqwGaUq/39qVs09prYSXsIP14rRxkw3zhNN1ebOfyDawB7s/ldU0oSnka9mw3UBUfYtrmQCQdW4FNROm5LfmJ78akDIhV+s5dDS/k91mSoSbNrsFpF1jSYPvBydGSeu0nkETkyM4XiFlY4ovzISH1JUuxXxcl5UaUMDofrMGb24k75N486obYM9fCcyyHoLIfIZHkP8cQhwwLiYX55lrHTFWsWBumM4G4lty3YOxKrUYZ4Zpf/zbhFm+Zj32CE/B1ImG8qPB4yAa2+6BGwMCfY8qqdCVp38Vft9CdxQyVoi98pTKU2vXNW3psXw0D1UipYStIq3JxiEhQT2AMsotVlRRFt4H2lG8Q4zABalkdpHKWKfTDORQCt48weatLREQjeNx4HvxgJ8X9WcVFoi1Z9s5WeakqQnclbL7ZG3xb6zBtVmBqo5FA+b4mWkz4rtqwu/kdaGDTsOulv6FFKnU0kp3gJ7Efyn1FLBGH74MqLKnUXRD6va4zjYqx8QB6q9NveBnTVAqBOKpKL1hayAthrH+4OrGX+sGCLWVJkb8KBYPv1r8Sudb82xLql6N79EyLHg4iZPvqDSX7/jo0VV93hdpKZ8ccHdBWaaEu9gnvuRq2y+f0JrIdp5qFpzWMvd9/tPJKAqO4l51RlLvjJ4nsfjO9EXFWqXnVwe6DXI8p8ixotSqVJxRB72O3qxVzZtKgyEq08yU8fQl295l0/CI11n/c3nUZq5JXbc3TErohNtGoJi1KLPtVENkS+WHc8Tlb1Ph61fh4T3/k7Uf4d7JbBJEf72PogbPBAf9NGe7AvOYzZHgxgPm0PSP9/rUJRN8I5ISTOUsrKMYo8ArLvQ38H9al20kraBP0uVeB/sXqbbvc2yqzb7D6GrbCWm6mhCwjYWlIskuEi8G/9lConfNxwKel7WRJO4ZchB0icMJg44TM+9p9JfHwq9GPJK6q2WjG5kC1wO6k3Q2oDUSuNsRCcHihTItgPyps58M2ZGQFYMIwHJ4H34K3YTuuZZVlAsXlyGU8/qu0ph+RZnxkduW25s8l7Gq2vJzzIGuN+5BrMuox3Ebejx/EA/ZB8L6assaToPt0M4A5hwqYn7yF6FxVCUo2Uw3AYzdNoPHm1gJzmv7l7ko/54vzixnQsljXYnu61ndH3RWonYpTkRwska1+NNu97yVGVYAKsMJVeXjYpeP2Tt0t+pegN7KaZryT/R3XaD+aWVlpy6ttJqXM6wU8gtG7XL8lrXNVpB9H7PThIu3yOHsNpSvUU3Srif4i302NXUWbxyGMW+2j/gFiU4h9COT/i46lCAD5j7CLUp0sz2GvneDy9Z9dV3ZYZvuwf7gUS/1tVkGUyWvUo3V92SAMZjkJl4tV+NAvlFkdzIL+NG+ZLKjMQ8xz+cFGMYSClaomllODPQK4X1145atUoktuxU+WwOBeHg/vYQeyJf2sjRwTEDOcJlWVG1D4eqDNjlyPoPzrxXUOE9HJaPW2KZT4YusJkOP2j7Yjv82d1f8m60tzqa4K1HrswpSGbC8zjX+xugW4WgnqzaaE80VA6c29ElqdyUhAmi6XZVQA7/TgEEEgVej7poiW8oFKq6AJHp13s9FP0XvEmbmzgslNGY7/AEFRJ5BeGeTOhEtwZO8Kx9gAk0DCMbr3IIRhGKZx0FhM9zX/+vAF6gXPaM32l0MJs2Q5iGTWq3GyjcDxTGopNi6jxq6hXmWHdfkmtiiuPgBZOwUlE9HF2rgrfT1sQgc+iSUEstlT1vm+No110vAO86BO9fYiq3lYukpOtP98zPd7F0hKaHd04tgGPK9EiW2BDyUQV/4LWCba5viVVzrfUNeAlDYU3lTZ0VG+K4m5OI+iS5goCsUjfMjayrMjmOJf5KT4dmRjYzPvMm2oQTA94/xRoGBbP6lJjX5pRitquHAtaZ4Bnubb7Pe3vNOGKV3/4eQy787+k8hoOp95c8YWretj9S/go33wV3gFFWvhXYHaygEuWZGpQzDsrBnBsz5wgYK4TVi4ceDn6RHX+ru3XmUGn1ZGV9hMSfDwfnAU9xOxwi7oc+4/xVhCUZv9CB6CloAj0+RrA7gmmdeh9A7Zf5+awwjQW70OCyYxL/o5+6v0w4FuUTQ36jaB+h7bsAgTRPMoh+k2h2XRGq3RTOgnL95T+z1VoWQgmn5CnXxAgfaplJJYxg8bJZ8uDvQ/KtW74JCiPrufkEjEbrABpCc0VpjQIR2SYLc2d34HifcBtCwgxwhcehdoEbzvH9+x2Tt6YS1WqHd65BnDjQt9fsx3N3/qYmaLzMAeuaHHvxTvCvguJsevIGsOvkPSL7txmPyEHpVJ+Nj6G+i1BbWkc+72YyFCHgvFti0yQmA5Vq4z7za1gLypr6D9ljiwk/Pr+zDMwM9R8/6BcKQDPgthFqN3z7wBxlmxlnRsOBGaBI4cBcjKuG1E1nf48C2r6rrCn+Q64P9+2tLWKQQlqLcbccxH/dwcbMBtVP6GpxRFNuKvWPwxvTBZgH239sTyOf2lnFixVYsuq7g6/b1X7ome55Wjs4bL+DYQnba+GhZLLVyfPZQa9er0YKwnusrRBStU2mljd6bpe/0cRl3biBgiNBhr0sL4z1ZEMrNSBJgV6jOMA3j94yS9M0UQzo2sY3ggZxC6L7dM0uqU1/vASK43HGKECbnLwOcSuf4O+WO5BoNI8Nnq1nKi/2Dk7sa/X5KmB8jk4BGeixgnfJ/kieKK0Wd65/qRuMlDWOHBHcxvqZE2kuYFbdlOg2ZkxWvlbkGx7JFXiQ4jNRLbeeK0FNTWaOmunFPWbH1/ojI/8NVu+ZPw6cXoOEE1BjTTYCa/nmnk6IZj9NbvW4hg1U6Cog3pYasgRjQq/hvnAO958xTHt+5F/Uo1y1TwRS/2raafKj8gLkd++ssuXta4MWyMYtQWpxl/Ekdg3jBHLCOVMh4ZJ/hm7Dlp7zeoEniH0vOo8hsTprkYoxO5ZrbHlfzht2RbcHDh0k748BT3nC9ZHWbR4WTeZCJ2nN9AMWKuOjncSSkX7XtvBrNWjjOROMx3n9OFLlGqumJtVUs2DVPYddd95Q56U0tZjhKSBVjn2zoSlyiKer05vqbTv/kiEz/DjkZdMzHU9BietfeYtQ2tOzINzpyL7u1sYClYMwUAC77QCjzEZ9hhbF22jwIYKGc+NqzrYUcafAQEom5iuzqr2mKbiRrp8ODxqAo1ZU0ocxVsCuVAnL3XhCQEXd6IJ9y+b/wLt818QNS6vewib54NqVIw3UARKzBq3vvOud82HZiCD6ZZ2yzz2jtxH6m9uTe1LgzOsniccuWcDoIEeCb0yRDQ+EfesK1hzdrIsG80lXr7lG6zc1UV7jdOS0Gc+c3N2ArX5i+KjaSTEI41tD8XqPbanpLFCpfc/BOqppiNWTyFsqRlEmZxUtoFMEPFzzlyglXhzdT7Cx2F5CoNo8h4h4jxa6SqZndEKn+HEwS/JyNMuJwzrmDsATAmsWpt02KRka4gwioFCzfBbp6BjAhCC3Zdf+M0qcZ1tiJPBISnWWBfa24TWeSCFXjKEyuM7t9khF5RG4E1JIRs0WLA6wWkORvWl1ZkqFekOr1btMbY9vlo4R8RkyHDH2F543XGpcXeC6u0mUFNZueU1ojn03z+rF5E4wSh1o1wssvcL14SqwbQ82zN7ZCm4zxItjJZbH5VMZzGC2yZzqm1zY3lyOOeE3LRk4XRzr0FeVyJqz+6pMAS5Gn9HYn5u+UQ8iHG4DXxAhLu/pO4X70DeNrxswBmR9BGu9f5qVWkz+x2s7fO9TvAZSuwP4ENtxoNTa3yazuHCUqrs3GdcJ3lo7/5O9hs+PLi1J00RkOxbwTZEyKKUO7/KkClIO7Wy7/gMYqdJLLbv/JLBuCBoEAax7GcQ9HDcaiLfayicAVSQD2J+/7s8HPY8e9Ylxkxo8la85jsbKuiDdpZ2y8SRveyRqJ4U3QlH3wbVSXPhxoTGGoZ4p3HdikBlVude2e/PTZ/3X9XkOjS6vGwsTtXpSCSHYv/ANInUgOVgrbtMfz7FI+W50CP1f7AOHa7W887uQP02DptB298gywKPlsQtU4kz+mob9UXWLEIxH9u5jr0Bz8TYalshvg+alwaBO+Ic2O5BS3WX+F0lvd49bZygC7EYBoaws4kmgp/gOXUXx9N3JA9FQ/PpabEgIDbsopK05CxOlVOQTXQ9gGD4vBHAUYi/dKAY1BdM61HcI4T0LPwgFbtX+UwFE2pKlfpDScNYCNmaflYIj5jAV4Ih0bdhRYDU8W2sodIGUQLNfxbwrdfilKg6QqdMfgnSeACg23JUQkWqhIfliQ88KMrr3n8smBDT+gtWe8wcPunM/Q8/W908BtX9B8R1yi1+0eKabHKgUKyUmg41T4ILUXxy0ifgMwRgjhcBH+hVctqb/5dqULt9TVx95//3JImnbYzmSpJ5eCLhUQTK3EojiBHqO5ar6yw7wn91KzmZteu80CFDGycRiV/a5AxZXyaydtIV5t1LIrQqsNjCI+2O54+uwtzaQLaBs7rWjFdcS6Z72Y6iHHi0qg+JkPWoKL1EV6she3yIR9wFVvfBuGsCz2KJwZrX54KGqAPx5Rq7nXSGUdvf+VOKYD9lI/FuMT1uvMRB4KAEGKRCSkpFkYx/zdCtVFXfLYl595PIWJ+kAazc1QpzF+qZrVKqurb8FX41vJbExCU0O/XDFMXo7vIiX71oM7Hdkh1/SIlAt9MgVaB1oLFb34u/rS3EYunZxzy9mJzaMiwLKVcpBsfFtrplwaREORPbtgAbafSYQa6Pe0mHUDgIjSDiEKOGQ+BBtGkAiRApHTtMzqA47qe9LgYI9Uk54VGbWUFmjsdkbggYW8k9Ash+AebOxnrFl/PAV0d2FQZAlD0cquKgBQMffNVjmMot81+SI8vfT/leBo3+eBi+fNqmb+HIZqEiYRsex1KvG/WLLqN+cwoROs90g0TrQPqBBK6Wz5Nz+lcbKwI/3R9TwBJl9utm5i6L5jICMh6umthYXEorXWARlYdhZgXiB8q/NWP8w0nraOE+08Mwv1qt07dCV4Y/NE8kV/AiKkHWeYGmMsGbBevA1z3GZ5S1iRjKlDDgRbORylbY9DPoDnXJ/GWQSRJB2hjZaZOXSwgj44RSuC3pHM8j8SPnvD/bTnfrRFrM/TYb61RfYmol5cMmPnXOMoVNK+BqiQDR2N19Ay/UNMTAMg05p5MuCflg25CQDgTqOj7RMa6bONlCzFCPP1akjnNa2SIfETq65T/UegeNaLG7RVyHgcArW8JMdCmrMi8ay3PO7Fuc/x1o0xjpBy5upe+asx0HCElL1oJEejkqswdK0Y8XSxn1I2w0VgcOZySy92Xg9h0R0aXSrNASP81R0bmPIE3vhP2+hxnnEIchwvemoF/914vDITG/NGBrBwMSX9W9Gi8kqrzFtL0DOAlaJ93fyTeoGk7BDz6/QC9NnwIslfXVhPg7uAQZqVDRAFFeh948o9FbpqusfNwvpHwhJZG26cFd0WNYkqwnMWVj7mlXc5O1wknViFi3m1kq2p1SN4wdTnSXRwEYKDU6Q3Mtc8B3KMokuDBHwnQ8ANDIHlZ4LsUIrqL6SHT+FdEImrL3K29GYekUYqcNO5ehUbDUnKPCUVXxsQ/bmYKL/RJ1x1MLK7t6/jzhHa+TOLCdM6vxYcKe2oq58Jq9KaeQOGamkfsKq1qoiVFxL/n8yKPMRFMufo//20cTS9M6wb/tZ2QLqH/xoff9liwtLiXEF5wH7FcqBCmqa1Cs2pqVecq8uf7cVpAY1/uFb0KAnzn/FdLM3EMFQU0kiDiWua4Dt/7TBq0z62234iP6j8gdPKpqHwpsdOpEJdjcRUHyysPrbAKB3fas9q+0eUAWe/JqyAhsWBfLX0LOFgDMEcFgYfMvlgchAw2u/Yk55gJQICOyOUiiM2hNNhXV8PBJ32qH5ZojOqBhT+wtvn1y5/zBVO2MwXzXGrLW/IBPjFuqVY/2C7jftlCsKWGnpx6P8DJoSfMUZL9cvzE5jVCo7+K0El9ol6Z87qSW7zZidDVv5IuVvNE0kcog37Ipi8/gVHhpYA6BgctPH1OWlSHGc31DPQGWGMwDaU1FNi20cweqOS7oH0QvH0jUezGu0LFImRQxIgaVQMRSKiDLC9K2mK8qup2fOhpEUoc+TcGgVpGslPZL7sxs9WvBs7rg9Rgi3zrzpsYEcpELZinJJv9XhIUCRlLLbvLVVVaeLT8+r/v+mrBgo6E8ne91+KU6zkZA/NY2vfXu5wMa+T04DyaZWsxz3Uz33STXD1MP9LwysoRzqsj1bsMwgOwrOMkS7kx1hcArJFnsU50R0s32mLTFj4axBH2UXZ7L4jKNj27bnBPvRpu5FISzssFN3qJA5RwEz185HKcenatLiPqqfNPUWOlbp6PODtqHC5FGDTbDlQR1hcKwu+0wkqiVR/JfkPjK6tK9oAAd6dsdDD10D0ypiDixKTNN4/wvabMa1V9HinIbM1RJDoqJHkVD2I9ZujUaNbXgDCm/nq2RQOGiiWUF6zBjQ0GnIIDTJP4xkKJSAzU0HzGbz7zf+DpClbtqSclvQvlxVN64rUqiGFan+xYGGFAbY7oOthXd1Tf6vOLRvfVgFmJZT3BmCEglwu2QVG0WHt6N94Is4/SIWLvWikyC1IvneH65wdq6EQwWMJFxrdBiubF0E5774j9ulhf3CaffIalm/1NDGzMEvrn0LdWqMIur+EsL932r2ia8IBgocY/fPx9AEgGvUCr/SZAOFxIFRYtXM/cpyL4VJAzY1deM4gqWlfjA4q9n+xoz8Xc4goqZOiB5R/pRuhGtcqnAmI6cESJurVT+PI6VkjMwqjHci4Q76r8iVd7QTVv2VuOCcCnPa86MOmb9d2s+C4by5cdFriyixVdvWq4P/Di/YxMruMMZVzVPtUB6zVPjLbbhvz+Rox5BrzWPEl+HdwnuXXddpbs+KSvqBEFFdQk/RxG2ZAwPdb6bVPWpO2dWqNgHB9FEcXq6hbhBzFcJWnv2/uS49Nm9K5poS9wa3Wbw2vBHGEmaZq/tRo2lJbmGqmEOT3Kx8kAO/kDAmy0vzixM5somfhzd/UQxfNwcJ2IYEb7ktVowELgJO2IpvSF0OgGXHqjy2RiTw+m57efclWK+EJ3bQHyU9Q8qPSbfwiq3bxgRNgkETBmwFs5G9Yqach58LEraIlZpQWiUBtAyJntgsMBOj4opTPlvNaBTR0mCG8c4g1zGVVQuYsw+4bMevtAdLrOTlLENsrw6pLydITplmtwVKJ+c1VNSFUj/n3fLwbLvHpDowKDd46Dbq7csT8foElTEJdCIjN1BjBuvDpLoRCS0GRpI8tSyyaY+6L4SWC182L9nNLJvADvxV6DScif+N+AU3bd3wJx97+wCRmU1mer4XzSknOcUodV6yyTJCCn93/LBpzHos9PW0aY1EFSEk3c39Zsn/QakUzd5yf3Ht4mMuJgJVYSRtkvLHRudrpiZS0r4aGNCtLQycrPCT7jzxRulmq9pP6WR9CV2OMgn1+Hs+azpeYDadrh8opRwcU5FFCHv66GF88oT6wpls9oHtsqlwSWWF9boUqrtmTmAk9zJx7iL2nko1lF7iYbtWNGFklx18nz5Cjk8/LLYEnUvlQMlDD0j51cxA6aCD14o2PTDiFrrfMCiGC+BVI3LRHUGuHGA9ish+j6SppTGy0cxTq5uf1etQmPLYLAD+yg+HsEZMfBu9O7hXgTUcexLLXjS8TszPJTIlIXoSY9PrTXhIa8f2B6nA2KNSgweaUHQ8WhU1Q1E7l359/kNR4v+3Ro/XJAJIk/9vIBEzxnoOmGA+zDkTSQ0r3BUXfZqG7vWTPkpeRKtiGVUgLqO1pGRTJI65NSk146PkC7a/cgIY7aBZd1hRW14rsqOZYD/KW7u/DfrLHRXJ+p9DNPj2QaU12R2IocfqTtRUH9PqSh59ujDrSk5xhuOn4tZ/s+txr8TjiPk9Nh/1n1YtkMls4zLRqyaaEPpqtBKUvJ6Uxzfls5ssNl17zp4gHZA9O/xkUJT/bPgJ8el5DpTh/YzRTKMXDVVt/EF8sCKlU0yt48/P3lhr2SziaTxd/ExMV6gtOu+DbkvOQ6PUgYZy3R4ETiX/5Y219vUJwSNJN0Ia85MoQu6iUpLYvWM8RzIECWsvcLqImFGTKA5KsygzL4jf9pdtK2knBMlbrUnljzNGOxYFj/iRvJxh6rc8ljtwb2PxKGex4VXjxCKTdOqQY96Cvi94PUwl/NMz56Bk7YiQX0vrE7MHhSMfT2PKXyybqXV5vAwfjpGy+I8LE7rIz15LKKc1szZqDt6h0y6ZKNirmGrIhHi/XzuQzEu/hVYxkNkiAW5JywaxptUSje3PBaeXNwJgFcd6LOa6ogoQGVV9sU15V20SQohISzUR8e9jBrXz8k9pF4I3NrniLQWtkUmGSoBxzwiLgDObT8TmenMsSYZAGwERrkNUQXoSRW4OiQtcc3/7lb7nQRv8gkf1yd/uLTs9XJwb5wx4KsisGDk1BVSpu/zu8eLD56/VQWl5/q/ayYevLJs7IhKSWCxdBp601hr8GA+oixmRvpHA1cf14ccbg+V6jhfSS6nsgvRsGaRTQnjBfwjpv07P1uyl2/C+PsTjKUYv+epgQRlyb6VrZ4qSy4XrQ9KroJn9F4mLLe3wre9DvaEP2+P26A+HQCzQJEtfBHbPPpypJI0VVTYV90BARjH7HTcn3wxZ4m9ajSrMp/8UhNrnu/OPId2At8IdvJHdjkqJZUZlgUH98y2MOjkdY8pKlBQGGtCs709ki1L2wNALKFhd48EnhEMhemlWwPV6mN1ngRwUlqBLGfYlqQ639iB/IWHe5T8M8KFubtevbHeqzCGLxGu/lu/odJaWxPTEZNzy3kgGqBhmzyeQ2NVKVfd3lAHZ1Mx9vEz2w445HNvVHdEYEnUR/Zmsui6TFnJBliBjGMye+XRR2xCbw2cuN7hoH5gIUHIBeoHVP0Woo6R7oVd8gGjCBnqyg746QdVxGhB5Zt5XadOayP8HSt8hfegE7T4fRQGDz/hJgDk50qSPjEYXXn7Hzg+zxayzf+JkQATQNt1gEnXvS/MI7QrJe2Y7BEpYP51T8wFbb4cDbZD64Rj7Cs7+yaQWS+CwuH6wX8iGXv8jgjbjs8VecfrP/IaYZjXv/KiV+AMw95KsTYaKapzl17Ocg9q9/Vc9uB5TBEos7yqEPn26nbrXZ2xf02AzmjAiNHT53Lhk4EwFagvbFDnxJmc2ZOVj0QvUiNw2r9q7/m4yz0pXfpO2SvlzjpXM/9TaDyjeWHLnNiDizvHWzgOUDS+/X9dECHxYf5789XoBduTbT+GHpS/Zmb1RBgALxS4GQy2ris0orCXbQwUilWMOHQvVe2CxcS7KVsrmaFXktypKL1Nw8w8RATaqFigxjTX39/tVC7+7Iv0rphIDsWYDCs5KQrYweDft+fWlljsyIX/mhyBQaY0QoMmcNya/u4g8MlioeU672ZJ7PIhdTXpuxjbPJteTRPgw2d74WWgImp6O5jyie+bBM6DZMSyNZQis/hvbPVsMzYPe5dngHzJNaencW46j9dUWtk319WRsc81SeafYBaMy9X3SZZQdS1SXasmABOanqa1G50axXJZUKHU57mwrWqQAzhQjbT6HWc2963YQB+UkL7x8QiEPFAkienaoHP7Juv75niYRA3ZFwXS+llWWCyQMqdasK7QU2DR+5EYaRXkSJE3Ygav8+oiJJlrlwPUO1zAhyc5uuDaMCJvd4hhVMHn7eK6guBk0l1m9b5XOI/wyjTJGJEsKxUjExwyMephWgW+y7RxvgIE7+7Ztq5ikWQdsMVQhTbbMI4FTyEKljlKWN2Wjl8fk3wjR1XEHtjexSSQUMpTUvKIYmfbzyYdfEx/zfoI/MnfgColhDH+IrCb9c4K+VH1kQeFmd+KMJgDHVBAFNNydOhqhMTI9y/d4rgU4KzMk3t4kygpXCW2mo7N7gSg9FwWo686sBdPOASuwz0nym0cxZhkJnqgtxAigpOZ153vZcSBBPnEwMGtcWeiUwmPD83kbr4GqxzTbTmybwWChXY6fGKY0zd7TZMfgE5X0Bzr//Dmc1UFmRSMmmj2mxGQCZyYyRyM1wmzOjDKVHVOdqz+B9dHJbuwC2Q3yhtCRgUVt8Bn4ZBtj8JiSmZvNP98qDD8OFsb6EL1a4Ewhz2QH0x34auVnE773o7GIoC8UWtDITCmE9Frtwlu2f83Fg8/XdCaejaIkruvYHiBEErZaZgDctb7B1Q18ikWA9iW/J/vBLzR9sOFa6Ezuk0czMTrag3J5xviRb6x/MH3n6a1CUZ8Kf8rt9viHBAS8T/7djTbBxmRF09j+sz/vdMcDR41sDI2W5BEJRLshO5/xrU6DkB2Sjd0KkmLZJ3YGkTIUu5vqz7imTaAMdJ3U2at8IZH/yihuoIVlCetJJ1NRdEphHNESuYfXtNy7rEiU6EYOWachuzjLDJF6JcjSRdi1Na2pEYiVqxJPDiESMwXtFEr04Ynwm5+K1vJxzCnviMTP838BFx9ILrHkiWkFsLx3GIRtXs7noNX2+KgWkCG3gus5geIsFn2RJIy7ZXHm5YKsUvzTTfncqivBVlsW2v7pO3EX14yHjhtcjM17QtdmGYwxOk4OuGUmbN8IGh/ESqNkNPrk2diupflGLnfc9jgLhzRWLuVlK3eMvmE09XmA2XRhskC0wugTL6FnWMJpmzaCTzmSA2UsNEPXbIxzMTZZ2KrwU70S7P/5PNF7dIRDpuJkR35LlMtmUe0QhO7WyaXMX2+3PlgU9fiLH9W627KKPk38umdlQNBsJEO34yZXd7Yu8YfOC61YO6dOSKbUxJCV9Z7dnKFAbOGvdNdX4davl6kMinJdhr//HVeUWXkeXudAoBbAqoMCimrqoRI4OXamqWB0pSNAQPIkDYRq2SIJ71mdaCeTcH/ReZlKfjBf6qS45In2O5LDi48ub5qZ0lWTGNfmY89ktPAAK+atOt8Lp/ExQ/EY6F9hSjACzD1dMyNvBfmvhT3c9ZoZn6Tgha6urQSgpV/IJzczJFtGscvR5WwkzWSevbGC349XACSBy3t600Pae2Hi6XDgjsCmbBuOSAi0caabHbYVrTq1A+meiUCxlt438/rTui2JXdHXQvvx5THSK1r6MchmA5U/ft+HtLVU1Bo3Pblzif5IW76w3dpqzYzgOeEOkkVeE/gqOiau+6Z7imjLCVzTts/RfNJDuM+c1y9UQWvPW41I4HnNq8TpmlR8s9cWVa+5p0YM33exTC4s3PydNCPD0v7dEb3YkHn+SMKMLv3wlRzN6p0iqzH+1q01nZaEjaRVx25YrvlaLxnlvDSyfyD6VBPpR5AhhILR7pxj6u+yozVcG+iZD4jZdEYGOHpQIRi9rdmBJYSp2d65JhdoDOEue7ZyULzlWZdZsUJhSn9qo1oKW5LfgjR8M0C3lUTav7bfQm0qLCfFYyZRJsGczfNrgLxYTsGa9x9WiKOUuh7OdIt7bo5P4D+UlIpVMC1kJ99ykCovU7Yp3YfY/yzI277/JVsDOKvL1m5dw5mh19rG0rhUeidM2klyfgy8XoqYsbsoX0M/Hn6I+yc4a4+tOxxFofy4/bCy2brvZA7IdZdEJYh0koz8Vzg+tZ966oaxLNkk9ydkA233A35OekHUMjuhMtL+mpAYZ2/SqzafZVRslZ4tjQ0ngZpzY8Uu11GO41rn2MVrs15eQWJs9NaDU3QH2GxEwkG3dWr6amepTYGd+qKyjVOKhrAww5gEp0g8rfZaUOAorXFiG7gvwoIpUveioaRKuUG0LofWpPQphGQ8nNYLvaEFrpIEm3zJ1Ybd4OAQJpbFgZpi1fA/9OoHZgi4BHST4r6JvxZ5dL2aZ3VABRgbgTnEhPOjAzaUgW2c8Me4tajmETeXjZEQRFxPb67Ued87ZX5aGqlRt/hsAyZa5MgEm8R8Y7nbq/7FgwOOVmqmqrlqDjI2nijf1v3L11o980iySORVembZktWDodsfLTQrWbtYstLplrhA42iRznMm/tgaGgCt5vzY/l6ekaupM7F4EhWyHp7k+tYFEnAiZnHAnlrQdf2C6Rm/vJeeLGaaIn8dVW+O8+B86BaHpicdoLavyRivS2NlunzXeg00Mj3VVcQ9EmvEXHCy7TEW4sNqe6X3nfGISCDhOfv+OgswUFnj3L8Q2NqjPbdEGSo3FPFISdIqyRXquJoo+LnowlAlpeT24WuYxF9KAjUykXUGV6WiJPXjjunBV2gt56ixyhGnav4XT9mxeQQJVs2OarTnkdWc4nOw57RNkvEY+o+UI5m36oULMcLIL6/aODzFV3zcRiQhW6S4Ou5qRJsXw9yUBgFHNJYCciDyCdx/H7DsHpbEisjtB5YFMxt77Uw4qHAzFtJfGuQCIbySI+lmo3qKBKZgJAlejL+fRyF+Ja4L76OBbfmAHFzSQ88LcKcEIwezyoRR58Ol2fCB/aRqHIjXXqMEaDjHzmhNEG6qF4Hc2JKfi+WZeQ5vi1ThoE81HyT210TqIGnldrVaJbpeLf5hW3Ilqb0WurL+pGjFruL4V5sFLyn9/tbIgE1W74RnOGRFcAZh2qsFx/kV0ik/cIA9lHIVtjhkanGK5vMp1FJMkIkTE84MioxOj39Y5AEr2ziFvJdi1dqssx9TFTwy+aDmIGU2+Dm377KNxzu2zwtytejw6834uCQrYEoyE50jjiw1AAfN4oe12okBYW2xRJ0m0brwFrPr+vwETAFcy+fyXaaF9J0r79F8TKsFM5QIk922mD6KCOrcnUaOg7tKhVkma7ZwoF7I98Q7zHVpYFdxX0bvau6JIm50qQBGZOQbH8JJjQGIBf4Kf70uSibuheku/A10hE/46JpYxt2YM3uQVynMc5CcqXmz0+mSBhPSXuC7N1Tq5D3Fwx21x4jsSh4tCEdCTDDAAPGz/cB7QSFawDqi+MPJSTXSNiHcojHU2wv7gA8/1s5EcqXb4ocUekvIUUgvdUiqq6vOtwIbSINc33nJJ/TFpzd6QRTzOGPrQXe12CZWaQjcRtlTmdZQm0+oAkhre0ydRQ/x4KVje560uoD+IJTnjb7I1G7MCE4kh3lTNLJGDcfj40skkK3TDlfDzSRVweq3j73bknKobHG4wEiODx3XoAsrK/WwIXsoPHdFDrAiLyd/FBoBTAuNwnDZW29K5GnolBqyMf6TtnNu++DHJAWfYLDjpW+XnTPTV45l5kjfyypMWdYIl2SiZ76a/eDtxWrsGf1DkidUENdR73I47AH6tt0FOMGXBE8SpTfqpZmqvVR5s4H3JJjjhITY1D8tGp13od2qv5NbniGYogzSzRbgr0+R9JeoYGVuoyu1PNK/V7bP7wrIYMSrrhBSyOQNWRFd4a77EdcfBKM15qlgeRB72HubQx7sMamcoB1lKBa1s+I3WritjrLPBfWICv8R0Z0EZZCoC/ae5OaBKNw9ES02+k3JymvspuyxgcRF+cGXFtT5AWefBg9y/yBg8R1fnDKri9eY6no4DMiuEvRWpfhRaIgx6suuMa2OqV4maTxaH5mMhkbDAmYa8Ou6XyMLiz1NidG6zJxEEbgHJPfjcPIWT4jjAcGVCyDKpDzmRPqbppmZGW43EFjgrYeGSXQO1xxPRqYi6cIZIdC4VgsBKZtqT6gHoN3I0r65d1L+XskzB3eqtlEj1qatFd+uV9+ryRq34grH5OgUEtRlHSH04aYF1KuSPiQ/ZRdk3c9Fa8/KSNmcJL7ZgV/ky5WWxH7E3ThAbyUB8Pnaot2bRCwoHn/rBoh1XkYss4+0spLzMTLvnRIvR8V9BDjbosBp8cZXI0dBf33e01H8ZeTkGPtimShHGhSuNJo7qBeKon8+DCG8YOVSTNrErjroedGDESShNU1ZJWZSr7cEgoS7yhXBK7f8ou/ikJQ6Vm4X4EZYi1qPCgA5S0cdc1+4L17xw4lBb5SLF/ShH3wS5MrkJhJZvcCnrv37cQHhl+81E7r6SQuYcRHSXMJ7nq9r5Uz+UxmuMxRl0XlnxNHG6OpoeiNd/KGS7yx2j7a3jijFquqyKsYqlSNzw8TX+Zv0HW9xsi65wcLCJ0iV0tmOzIcoVZiwsbcGjTtZWAX84lyzItDj/FwT6RKa5xtg2RVKV0w4xcGNDxHH5LLNMWvZQFQrPw+sXVpySK/RVa98W+McE38num4aOA3fLJ6M6VwxBO4r/zEPm+7dFNbBgPpBxEDQMUf8f6NulYX3g5NTDf0ADMV612hR53+4FuQisksigoXC7PK5VDuD08HXi3F9UdiENUHlncbHIM3j6KBMjpg9akSgzAKA/krFfWorsFbwh9bS2oyyxzsQycfudv2/VeGrfNJNRzaErLKCu60ZX6/FcqXPFpmesXmWFL48UPEPOuoLjHbvwuHJ7XFoqVp9i89Y87Nc2cOgsXOCr/HBSS02RrQIvltC1+6AqS20Gmt+20+Ab4wtrWza+e/rFE9yovaNCUPRPHp84fTqtZTEQ4QXNeVP3qzehCvhR8PeIhr8PSp3Lw+WDNppKd77f0GwwKr5e9XQLtu4JfRGKxxJFiAqu5uosiZCZbE8UYzF86ZTuGDGpbrpNcOiUEa1dLwwFlSc/tB8Jiy3QxZe2x8wFYEpyZUgTjdCaXRZHJgMfeblN9xUAy7NTtGgto5BxO7NJGqg7z1dsgpC1vkdeDEbaPJ7IHsjoiGjsmFczU/v38xFxTDvAkDHbFuFVA8257h7j9hTJo/seMqWRjN/u+PywbyzZXsTMA+kx2DkDxezkNKfyqr5s8oDIqJLu/QG2cyd7wdhJKPAmzJqxA/md/obPX1cbGbH8FfhGPbCygSg6oyoz5GB/7xdqIkjEwRmmKH8KIvo5A3yLSHcieOlLfG8F1HsYFBjSSGbewMxpq7E5wMSaYUjSQawrTGX/1QrWky9uFUrtBFKgCV4k40wPEk79BEvy31tP1JIgL0itKNIkqT1aC8QEBZIjcR7DCzKxkHBYevQRZQ6bmG+7Qw9+49t9X1WPKlpQnO6DuqlakHMVbQuU8bxmG4sIAa53mHpCFe6T4m/pIy5kKK5EmP8bRMEfabAg19WjJKpw1zrqDmt1XvMsj3Wbv/Pk1NiIcTIVJozFEN1119MgzurQj/1eLk5QAlv5TL004f/GO6f0jabtkX3fj+tt60P4UOAP5qKcBrf7zOF95t1ThyrntStPpanI34ODGKcQi7wtFRJ2LwPHF/DbmkJXXNzwHceGm7DtJLtpDD0Qt9SM+aoaPw/er3HJTONY6JfF3zC71hvRmeXnwemrqT3kDxhNHBKeiEHNhiFThEjlV2KXiLYyqQxFs86UwNqepgm1yMV7HEkfaDzXUu6u/GhIzKevLtrkYB9y/7t5AxdLZgJg6/XPl2+LVDSFCkkXkp6YAD6UnBHctRwe0QQBGDaUMv419iygMWPSpoPFMTy0MD2zg4CUK3JXq3ycnUEO/3PkK0EN5gKv5jHKHtf6RUtsVDVu/YEvkXa3ywedmj38PXhumSfyf9VL15zIZ651wQ3K1UFiAHBSvnjbYM03gt/ScH01mavhrWAXxUYjiEiCytP1ttwURWVHKdGmU89Liy/6v8p7ER+goLmdKO1c5vFrQKIRnD9UYJ+jmMBU2vuh0EEuoFJYiM1a+oK+YE7EOoLRiScx/kn3KkXa1Oc9JnC11poJPlATtTideQDZITCEbOdYJo52wwm6xNhtLvJwM6sdu/WpgV5f418QYlB1S6Bd9vp5QrBc2ooL2YUH+mlGsMiEcQNkqAqQiSPFCpOOTc/ms0j6LS7tDUPQ6KQ/jAbSz3UcHIc5jzGwtt9fIqx8xzhOWNOvIjx+O+zCaHAl96Pm/gQsMJjHPdU45pj4hqfd72tpHkoeu9QOwm17Ysc6pReXWWI3pmDl6nDW6VjIrqG8PfS8L7gxEPdGV5JALA4pY6A7G2LtCMIunrTu6ujV0bl2+iquUXWwOS8W6pl+IENhLKJkVJsEop0fnWP16FxRJGxDWaupELraH6jCfRknwGPVeL7jYIs4/78QdQrjYey4lUIOxpq9fzsdLC6eoO3E4zrUVjlj/5rP2iiJfZCWCaXgfza/I8UOJJ7xnqo6hwn3njQkIrLTp04SbEkq7Xk2tDj3+XMdKhCe0Xrvs2fFD/K29fNjg09bN/n3dmMiwpUMlFTxIFVKSr5s01MTrPCs6fNcEkpysbgAMeCmZtsm9SyucXajuJdwq/3k3L3LKugYO8WwSx1mBlvb6hiIQyo5bVShF1zSz+CHLWDMctytSBe0zVrTYmA2uWoy2z3MjV5q7TQDONz+1138UdqkTE+A1P5JPN37yD92JFcAUvY9tu5GwHnwD4rIpec1nAUtsTjSAPdcygqI2mA4iPpHXjdJjG/w0CZMeIv4n2aT3B8+5Saa8ZIYAaHfd2LaRwvewTx4/zg9ZBA9Wsc0zsPycVdyU7Nizkbp2THEbrlniZTsebc2TgS+KbJkvZZ6qXSNW3/Vc394nnUJY5XOxcuTJusulGkee0DOS7POfT2oJ2DFRecIKolPhGVPriyJj+ygwHfkl9xwUg2MVSkfj2b1sJOFVkYUYMt336N9x+9wyEhFH3WGcfu+oi9LqTvhLOl8qjQZTXghFrXwC1s3ZIp36lgEY9XjXyWrt67AdjIo1Ch7z3e64Y0CF2DgGy0iIOnwSPxitxWcc2PEOQ65K9nG9r1Yee9akWGULIPCVJweEpziBkZhQH2QhoHV+Xm7QDmpWJEJPkZYmGUs2LfasBnNQJRgGQ+42Umub6EBesLkSdUHZ8u+Q8zTeeguwl5n8C/Una0vdMnLGDw3bWitN881WpOvgyx9xxJdAXmZnC2EZJcJWThD59/GRY7SFxZXlL8EhPZbbPA1ed/+n/eLOlKPnDSWxILjUOjcWszySLjx4QXGSSHXoCLV56/rdrcR9L6sSeb8YP8l/O6NAlrao7C3WSgY06Lci1KA14iLCaoWxdhz1+8VF1hDWxe8fGrvt5qy4sPy6AQjaLLL+ozRUs/ZCySOqJzgtyFGkK9TwhMeqAYo2yoeOZkwQgRuQJojIcag0jF4Z35G6uOet6GUsrw614h2IcrMbzc1Gi6dMrJeJwcgVOhsZ0qAwQEvJQaOKbuPuIY+DFivVRoNpjZG6h+RK1H7uRElt+11dS5eR/y8VnfzPfryQXN4PiWhnmxyXzOueVdq/ZKzTRLC10ImBFRRubpq04VIVwK67xBGt7uMh90Up7/yXuHjsEoB80AmyviAI7gygW1RnBEwtWnGWQts7NKCteGa2rJfFQUVEfv9N7L9NVGpQQzwOimIsO7Oj/dV2/C0cqrxNJC8Rn7Bef/mrLyLmUZvgxLl5kxOUJjOMM4r7KsNdGnlH4lzGaVt6tf2TXOcfz0Tsw3d9Q5SSGXK0fi1NFBf8H6q0QRNbIzO8gK9zT8CsZdpZVaC1BJMDCZrIV7mU6EvTE3hy+soWWyjczf9bD3Dv++PGURF/usMqW9J1UNaZuBJojPlRdJTBYzEbERIm7SeXU3sqKa2R4DG6gxB190LH6o7py5E+tJ8h08CaBNI4ILTk3a1qcOvubzgWsgv9Sna/f+yvivs9GM35Nw4DMVpAS70gYzzCQuLvBxdseR7RGPRq1nY6+Lx8dj51BkUnvmmySJCWV0qebtOJOVvhFKgjkkRb8iRxgsT8NzxnmRSiEYu8cdN/6ZsZN2hCYjKIZjyNQr3LMl//weZWTyOTvI/tKvnG0GAt3VUr+TGwWvn7pkWjL/4fbeKaKue3V0Ee3oppoBtQsKp/h7AlYjfk48sddB12vfgGITuvRYa+C3x6p45KbSiaDE/6wcpa1UpZjbJAcVxwe3d/SFqiZ4+JuKPGkXBGIJhib6FbmKwA7wAZz/Y6cIN73vC4gBg0l54n+oYnyBsi404P7yoTvM5Lp4mZQ/YHM7b2HbW06cW9ElmiGwnod1t+bNEa92jnU9GeikPh4URZ3FYRux5UCRakkqLQmTWQu2coMb1/7qXpyMKdaPUOKw823U+yPWjg7JwH+MfRR24umttAT8vbLcGMPx3Uw4fe5yerO4Txpp+CRE34yQYgg5LMKCY2rWNkq4B1G0SeyiAJcrrjGKwfxCwFJ3dY/HDCb7hFrkKIkhyv4f7fhTWsBrLvMfeMVgLebzw3B53l7j3z6UW2xSeNDw8/160Ne5N7QEeNhaIXFy5s/5GjHKw7R930ecONOW93pkW8ToyLSlz/Q7Y6tSkvmbnj3ZSN+a3vWUbmLwaSOk6po8WMz73Uc7hj16PjmvHrpDPA3vsfmkMoEpwkMFvHiTF6AZJ+o8TTRCMkZBo9jjnLuhilr1IXGDaa0nFBzhlRH0HFkKbAmtM+eoT2kM7D3WtnlSrgAd6aKsYXEVU0LCFTTeCn9HLv5cggFpl+EVDXe1pk/zpxSBP0Eyy5mDk0WDEMg9AMhw/8AK2BrZdAyfRN5JI4CE+e1NW/RYfAWXh6iBKwH3dl2FZvwrO53QSY8RTyw0MEdy9JHuYZt6o521341VAG3BLyIz5WYXI6gYEHAofs+XQRzBTrZsvDZ+X8xV/PHlz+1XMGGv+CTaI8/cLNvxcIxmZxtEOCtuYH0TseUDzDMXcX71tf496phVx7fhXuuQMpk1kF/YB1auPbeA8zIIuLpUBpe3BUmb2BaG3xj22leCwktSUVDi/V0LCUprW+9dyNcRFImqaH7PvMUxoCKhNLIy/BS6dlSFaSL+BfkgutTUp7Poqx2LF8bj4Ul4rEdwPw9A//C6LpRC9MTkeuB0HCmlY0XgDqKSwhi+LnqMeDy3EaApVxujkrVlHji5bJ3Bwknq93lZf99TKpApF/ED4jm7eLkHJgxCQuouQxp8Dze+INQH455n8DOby45tiThWurra+xSqBsVRTDT7mtV2yeaiFkm3oJHa6cM5eARAkBkhCFEAhnIoJoB4pUUrbC6tKQMPKbT+qM1hUsCyiGefCOQvIcNlincU1Q+pCqtZMr4DSg59ie3NLqi5TfajsvxjZrzQIPWUkcP8/0mdmXITXnApEePUhxOKndC4tSSCDBGGwevWdthMTjrwPoufy50EgpZrjh4oYJ/DNeTeUqYnRg/cCN+cmyxhcPgG7YmTlz4o80Bja+OzHf08lPPCgc6aLHu/LHQ6IbUb26sn+P2DuyArWgvhtYfIbTTXAKdp91o0l2cziKRCVzz/fLHKo/eyBecv4jP4+CxbQdX4d0qzTZ/Zl9JXZtIfFRDl54+Zm9rgMJ8suz3vcuR8Kg4ZcmkC9cY1AGlbCzmCiQR587IQEiEwkIBi5C7VvJ2cDGQBObf6j0dOPohoGWmgdEW77tQp8HbQNk9Y2sO5CHwb34HGkSmzIm6TyShWQtEnUHaAhqB2SmkhJDFfOjN8QM4fsK3sz9uLiwD2idUKovKX9c/a2k53r4PLMkBJX0oIZ2+i+NxxV0Dc7db6dwNKkoZjKRFH1zp7KmNam91n2VpsBE7BwXdN8RunU9fPAwALtUAlVUto27nvcTzxk/WJbPw5ezQ9e47Kxmh3Zdg7zXR/BNQcr3qvDGnd0rx/vKJa2vr9SRJqXIHlzE13WoEzG9M1BTeZBVZtH4Oy2QyCJdBwqBaKgAYh2DsCsGAebzH/bHfkY+dxClU8kCrJaaOWuvpaufuViLP4d1X6iUNiurmOt0c4rjyvudmAl6aRVfEg3dqSAsQW/5nzfzBecdFMbyfoqfmRpYWjggh4kpwWPsqLc15p6MBrDTclR0p59tAhnOJaybY24S2i6j1AnxX1HmfxY1y6xkDv7RGcHdlZl7EaMSEB76CiWAg125VQkNMl3zYQH8r19qMgEPYIn+NJW9vRNIOx7NzAzNOsWCBW3YJL/hcX4rvU3glrVfAwqc2VizudH5S0LFmu+8usk2wR1mPjGOYfk7OE0AxrJGDvNHwiWiLNGf/ZBU7TAUw3To42GljTZcWgbwthKY1W4EGx3q4au04O4CkOryOYvvY0asxxV3AGfRuiXvrxVtBdiBYpkmFvGnE9uAoSCkYUN7efNG5o8eRSzSbTbO0NpbjqdmRv0pUlfMQ1oWW5f8gXfVyRaTd+S5zTC0HbnVPPaE1pDR3RbWwKJm6VXIdAlFk03VbVHDZ2EKTeuhteZsz70lGjF4aTymp0gwXAjFsDpJIrQG4OpWHO4CsPbrB59Tc/PsVnyzclDmCCUGYR6HrxQejKTJTqp3FKY/98dolzrY+pUJ0LBM4BOUwUFyB4KhFghd7Zsu4xW6z36FqehV52S7oLM0wazjBIvMW1RJvg/qzW153G+anTRFCNV0FATSRcR5+XyxnNmR8uqEJ//6BDjVU4090INlkRodH+c75sPTrBzP1xR4jg6Uv3696+QsnwIIgBsgaR0MERHTgoH0xL7dhQWrZ+EAsq/AJffP85L1CSHM6UoMWxbuNM3mxfpmEk/vCVJnWjYc5ajy6kRqQfZdiju12OIlXU8ujO1fInheqRF2QOpLq96ajkP0QMGc3d/D2V8A8MBNMlBCoy9bobfKqnryoAO12V4ygux/qy1gfEAcEl/dWxblwfmcLv7iDTA6XRi9++cG/uF/1iQPvxb4fmynIbjINTgnTnuupmLjYfXJwH7HluChQ4XYsQQPYOwV2dgc722MsV1BY9bvkmz6RqDuZJDhotIVyMiLLHszX8kGmLQg7biAGU+nUkUjdsU/nUQH/IFKye0VR35wqAmzSUo1a6T9IEJUq3zt9koPdvykc5EEEUR+8z1r2H0pgcpZakRSACWCPpFxptDPW0g0wUvrU8TNIlQ+bTPFJNFFwTYAQi8Z8UrxW+Mhl6bkkir/PYGvmthHmsPzqT+j9RPkTl5DjpmXSKRFH0TNnndavZwbsE9w5s2QF30sOTVGVr1a7rcWHfbEg7qyE8NLiVGkohNPSDaSJVLzAFRZrVrEUrYAHyVNr1lu6CyP0pdxdRtUSyaQQmZnsfPs9FFzWUZfrD1hfKOUCVukGpfb9iVju7CjptxEWQ1jm1ExT31WD6mNL5+A3W8PwJWtOQur+3M1VDx5UMKLmw6nKHfTIBqFis32qiLX7d0mK7HZQyN6BmF1+3sg2eNkxNH7A+g8C+Fl/b5Tlue1hfW6J8giXwKpX+0iuilfY/Qoj0T6KNxqxaJbcRI3mnnrT6LZ8hqS2vs/VYyEG/b+50YYUr+w7gqmtwEokEN6T7GM83JUJX8ZDKoeGrJTtdi+qJMcc1RUkc6S/Otvh5G56MKj7R2qWdwHV/cwZyAPfTi8abWC1+A3CPyv6BO22Z893qWdTKC7rztNxLfrgAfZKH1JNnMR8HgHeUmC6G1qwllcW4rNNak7W10PdCf5GH8zHpPkbWx/5MFcpVqiKmPXOuMjeoYycQvyP/FYXI0Z0POvGkj/TQz5IOEaHDFEt0pmaDzJUE3snPS8EN/faH26GuDnqHuZCZoSvGNlpcmtRaH1P7OWFyPK+xPGaWacuRCf+MhH2DRkhGnmJd0YjWH3fq17v7C7z3hVLCgF+txu0zqo5mpnyjKXXqy7L2fzqobYyL6jxYGy8x4oq1V2KpgfCLP8qoZ+wptbmDx+8g1TFCDZ1KaByRa31Q6hT15SN3FFilt2iGr9clo2mo/F+7F6pGtWj5a8pQ2h3ZuKyDiYxSO9pZVn2aTe3fHz+AmQ7FsnEbfzSLki/2QCYwvvTCWF6Tmjl4bjIGIW6jQ56DGn+QiA4pgHriroeXWATCX90N6fMVnpz/VgGHruve3lUnzFVcmaqj300d7MsmU2Exi6px+94jCo02Rn60NZ1Fyryrg/yLl684ZpFQr1HTo6wXk0avZbnyahgxd/do3QT3p2RmGi1RehMSr2wwg7KPaqSH/9XnUqdh1hyIZf+GfqmrJOs7xZk5DGB0J5Iz/oM7aiL2s5eoilIsU+Fd3e3Wv4H5el3CGlTHxAYB2Ug3WD0AvGGANKyszAOE5UraNiMTdaV5SNYsCCmHSS0vBmesHDo2G766zOx9HO6kiqZvQLswINt2a/0yo2Vmh4iyH+T2PvazHnC2xE+dN5CD9wtk+dcAKDi/zN4Ad0u+dWNu7bnDRPtu6E+J0WvyoEUquRIZfmdwIWdyBqA33bTzWqDn0xiWCkoZY7lFHo2SXfCnwJPmO4hExlxFJPUIfNByQ4Bshm1K6Gb+5p/2AKif3n7puW7SCjfPMhz9EEcxtP9mWpeAfz8L+zpJYiaj7MMegefrtc5JBf3XQDJlIF4ews3WpVXJp7ivJzbrJvTpFo1hiFRHzY7uNgYA3MZSkPSy42OUYtetRW26at+jiMXJIwavQbIg70IH63E/34c+wuf91PldUIQMdkxxebu3I5EUsDMUm+/AUZJrEn+A3bU93c3WyOcKkspGmaFIfpaB2GrWXpaIh44leHn0LXJTLllDJz2wP36I4ObH75W6pC2cv7vBhowGLye4+Pk0avBkiA5macbjKrBrXU4OBd1xQ1M6NLIMKs5JWSsC7qSx5WzVidoCGiHgk7rKchYCVvo3vSPx95efKAt1vFp9XuMiCRYPEzK1Qfd9y8y6D9m0SjN3WBn0LzWJ0n/zx5ZZirgYh2x/NPcUalrFgBuM7ZxZUSMufBMbBXh4gTxRWwbInikDzWAeK0BaqVF+AZG3TlS0QZVFFuVhk/xPAMjZsKebXUwxbD4Ol5rcm/a15in338AnKuaPfMZnltf5PyVqEeW5wMvI/ZHke+tHCXBe9QIuvbdoHaH7XHe6oAxK2BKMasHDvrDlHhy22ly31KGFSP0V+wfsefEE166TQO7ksv/UEdByRVZzm9/CT30TWTCJ+V9DC6Xee79Nd4u77Kyh/pGaeIMjXF3pNn9P5DSywKhs8r1uxmKqp5d4/28oAAvXKU5cwHEeqAUBkvrz6ZzIgn2Uj0aiUkkS+p8EQx8FhqQU4xYW9HOSJYhKw/cHOZYi52drfhKJnhThv8zToC6K2/1CVIc1dRL8uQEleWySbGyiaKhQnclniE3TWlBkw/qdPewYTSEiMsG5NoZR1hHdwwTRgtSVhlir+ryhkaID6akVjKFjogaIP2fl2lt9xX+C7gbh4DpoRHyoztEfjt0YD/Hy9nZlAFRUBUmffd8EUVVPlAJiXnAW6a793XD3+vkF8X6MX4sarcO57NBYx+6HcxKsBEykl48guuO3Au4VJ3rG20ko3sh3fbW+v5UYKi5Z1W3n/QPG95xh5DDrwtmNxBcMDVApWSxRkd0Jpnsz7IZQIoa4/tJn+lRypDrNjvxNDBOhm2V3Uwnd2BQomZzAWPTMiIxo/gQt4o/kuQK19c88oa9G2mjc6Wy1vFDpHbGD7ysQuPdZ78mM58+4/W/9vH/jWr4gl052l2n0s86XWioOIQuNiPHqKTOLpC62rfSWQ2moM1hoKsGVwCrjEtDZvyliC2qiqJiECeYLVezQ6uw5VfpXmNfAwwEd0xe5ew2GykX5gLTDHLegKn7+Ep+6e+kct1ZtnBSHoUmfEHCYPVan1QUWHCfrmDYIk7eQtNj8S4Vdk7ztbvOAW0I9fKW3KbNc6BqGCpc/JAABu+0bvBV5xQSqYjCPAvmpcLXHenikkWZn1W/e6mM0KDmkFf3XTcGlaDnpZxokTQzvDfzuqxFa3Gby+vHEc8vfNkX5FVP0/2O+X1R1avfdHBgkzPqsbgt/SVgQfuOreeGvYjbMNRU46BEvnIO9haLhSJqvGz/nJD7AtqC/5tAjPlGlKtxWoV2lu7+2M3h5coA2VGH7HjCviv4jL8lX9H1LvPbpsGSR3NrXUvu+GqSj/XgxA1dgqmwfq5BlML7+o7nDDkzHOc2MulS9LRo2P4Kf5Pv0HLGorIn2zRroBIVrnmHxmSiSXq2XW4xV/4TQZe2vyDvSyFNEl5+qx6hpb89UtMY81vjVmCkK+4N3NT1yrkJyuUZlDcWdOxjIll7kpFpf58FdRT+t5F6s1i9g6srx8sUeMWrqjyVqZC4KRSbYUbWHbT2Mx6Dyc1xEFM10zmBnd/HgZpA9oJ+nCTOFSP8Arcop1e8dwY37WzlN3JXNLhzv/kpvTozsBNKSM0kcxgCuRDZ6QtPYi30m3To6nSutmXWJAoRplfxzTN72rAVRZR9vlcxbMgn/vvXAx7OpE0HHb06H0la4vk9i8IFIrNwujyUJ0evWNszSH2srCbryRxKgirKBy1G6MbcLYFjSn6mi+j3nRMtzqxneEEGXY8CMZHDpIrEEV7sKsLQCyFftW2312du0DRGFaTqt3dAtHmkBVCb08SYNBWHRnBic6z71Oj0cXrzLRCruqqgO4c+weuCTBdAkDd4pBcMPCN6RuvaI0kDFtZOrALiR7kSmU2n3IgNkJOKFS2d9Jys98CAsPgtcIbxU8FTabMBUU68B12JsckXNm3yqMXz1CfB9S4rU5tUQEToY1QOpmLRNznIg/Zblv+a5Khfto5aUC5KZeE/n8YlN+R/h2RtkQI7kuElFo4OBECH4/JvLMXsnVsjTbulliyp13lEvVdW+3L3mMV2kqU8OZqqxkfnyA/qNDifduQ1R2XjHJst7QGtAh18ijBuiEuyNuNmmreFOhljPneK0N8jaujuMUcfVhd1WYGxoEgNoB/mbw4jlbNRDyHg3Yh5LaQdJYqJujxzNBQBWvOT/gBpxTw6H+e7D7SgJhGMPlOc2LSCmUf2mEKHTXt4+B1SsY4GpILOL+xcVBRtChtEOaoebISmebgoOTfzILDQAfdYWoBzlz/0NTy+aiCVeyVpCk+yh4KSRTn4T3RS+eICvEvOuCu9z5unuWC7t+INPupkRxuSwgUp9MeK/hZyDhgNtKEOjfamkv9l7zCCkAFPkYN/Og9DxDZVEqjpPZeHnmbTR4o8uvv1fieoILmFbP0pgH14lciuie+3dakaqbw0prfjq4YB3tcPPDwtDaw5bTOyjk7LM7hnmfkBvEhGytf2A6R9e3j4gptfqoDG7IgI9kJl0MVrxyht88Xxz+iC2/NuBNVh5tN9CUIS03Dd40UHx82yNU+n1P5eQuOMlk1zz38GceOW+hfNk/FYEES5TL1uGBUFI7xZLn/54tU1lZav8VQRl21eTSTYELMNVuExgIvVjoaEs/KHf7LKm6o/0I+QYoR9Fl+OBJjSmQGRxw2844IE1bx2If1G1v4Xp/rPwFezucZSMXHqYRQe7vUOu+VEh3fybFY234OMnt8oVdCTjyUMJ1TzxMH5NXr0xlOZl2t11SEz0hn3nRXZxyBaziIqmJ8OgFeudjFBV3lcc0l9rcfEqVxWmxR4sdMKI74idM1af0TewGgISC5y8RZGlZvhchEQhVhvUR+hlPtho9UKUbFbFdZDmDKBri+5rG9yV7a7HtB3FE15ypRCZi+QAliYA2R7gw8yltXKAnkrZMJc1L/Koe3HNknDVJz0P+v5zhwSN3oGBrenhWlB4MERBR7M0o586bBojJbKjlmWkawkMSRPQbSruAivFMWqvkzO/4wc0MqUvT4dzQP43lQEVXUTcmc0ZnNeipGWKSYXAG+9j3tUph6pXLpAzdevq1ddn4UtH6NRcEIsJFxvqiUHAis8nenH9ag2DLwo/1iIAU/iEJyaQjiItMdSXo8Jgr+KpZQ0gWZs4AvPAbMPgOfdIiiqPpEVRpXsPdRUG/5RKQG/IZAqY5F2cdzdZh90erADpI6LzmewBD4Wg/QmLm8KypZkhwQu5KT1NuOTYBT7VaGMq2b34jqGtF/jscx58xzO/tAqXd7jb24WEvet8gv7a2rIWvEWlnNW/m3o4k0aBSI9qFoJHC2trHjG9i0kKzptVMDfXACoMR2ZPY/QVwEjOkpEQ0S++KUqdHq8coX3gCqe8GxSWtr3a7DTjDrOdZorPo+aE+smrFSIAoWH5PBE98yJTIqe2FaqzEuETTdOk1vaMkLzOszmlhZHIQLe/IkKF8MsL/MI93m1EwnXhfYx7QYakE3GwhMI8rHOINW2JvMyb8ERAOsg4N3ZICgTykivklN7/xlnaxRpIp55HJ0F3t95FOzGFj2kqwHtlEvZAk5An1fLNpItkAaXwbcHXN646qB+9rALAaF7a2Sbo9zNulRgJt9U5Mj1BMwjhnbumO/50RmlphF253U3Va5r9ZOVeHNjFrz1JGTWyXpuwZz3BhEg70dzsWs90IziSSq5oAiQyhcuLibdh5CwZNCZY97TNC/Z9P0ISc1Z/RziJo4ENWgdXsJpgKsMoZY4rU9Z/0iIILKmVCToD8eJoz8wmmTnbzDl2f5RKXNaVqVXbX3MZv6it6GZ2a/s9wlXhNm+aQ7Izzc451AQMaNZCtrGvKFQRRXu59cpBBoJ9Z0YqBgx8AUKktyYleH2ILq8hRSVElB9uFJ39RKFyXYScDc0K8Acu21y2ydwCGU5MnNkRCOikWsTnLp4lJFwa1s9BPK/lyrF7G+Tac7M1sYYfaez62/fdrCdZMrwbC/xtSqZ/DbV5t/5qLiWYlWr5AC2bJK8ZvOxCypJVkY3RNuq0+91sORIVGLlLkFv2S4WvnYXzM7tD4hmVxt1YvbxcCHvBvq1vh8Zt+HfiYJIDyZNucV7k7UAmqrs99uRgG7+2EJhCcTpuPZlAm3cTSoo7xNSzXOivQLafMq9GJ0SPV01+CwWGP1Ln5zxMgdN21zLh7SzwyndGM+5/uhW0yQ3Iyk8TeHGVjMwa7FKA58HJ7LzyIHgax/3uTrFWPmBBpT2bgvzirloNrHWsTyR9OLRbGnZPVhRHVQ5M4ek0GSmIhsIxcLQQujTqsP2sNRpOcOu8n4ysz5LFozCaEszpuLg/Hsrpvvsa7ddO/UlnSe3fkVaflV39cdIomfoOMD1UblNRdgxhCoNLIJC4sTa8mjFzqruEi8ckUZsNUTAuV2wpa96woBTXszIsnqIaZpeZwr+OXme8vLICGbHkAPvOb6pD4XXSaWadAgKgmP9Zf6DHQgKPAgAJXlO2EaueDJQ+SalmJeT74MFMcmKyfHCa5chzO+QEETguAUY6hoX/Phft8qXd1l5XnEvboV7/KOXQfXVXlj/lx/mRUow5OSH9jHFbkdA2VhAXVpOgJeAn4C80SaDiTmRcuuU7ITuli20JkMD2O8iuhtJKWNwF8aFIl3rqpW9K2VTkmCMiWtQhu6spBLRTbX3qSVwMJdmXDRS1iOFBanEz/oHotg/zq+KPZo3VP9OhDpjd8J3aaURMrKYdxS8DdRbLMQrKgeFaQqlTHQ1GNXr5akFvkHOvS4tffXu1rnLPgbw2gX6/jZBr/utK6Hfq+/HmsYKtMKgIpHVsrsSy6HOBqEztAj7ElDyU1oeSk1L5oK9NO2V8TtIm15AVrnhongI8XATZ6wrgxVNDF4MkRyXrZSo+tyMisMe7fYVlXpOFu/Roa0mCBS653i/o/84z489Ee20335FTZXp8qGzG1aXhHhYCVv+Y4tHc6K0sCTkbLaQzfuK2zijEI7mvPLhKYwhvt9enZL0CL1kuL8W/6YLnnbAMvM49NjqBoFr5lf2gHM3E8Q8px9OzS8b0/kw/dv6NOhxc5/d3+XAIj+8/udAT7B7u8GSzy0Hr37suyq/a21gYM6qbPLwWl2EoV5gBfm1EsE1B6sVc1dwY37MnGuZNl2fRDl6oMn0D2n5eTStYJ8xju/uMbuOZyhaWCQUoHCYwksfNRaNKGae+4ezEm0PkSD2NNKNP6KU/qSihfhZ8NKumbjZEXM3A47sn5AacHKIsVeJDH3Wyp16NknYOj2iNaiWFfFK0PILlZ9Zy/m2IYAfcrS0IPOtaPs94nvg7JpMwSakL1wqrxxxbQ3xV2puM74e9O3C9qIVODYNiMI+bZm3X5drPrw/kP6UTqieS75noMdrz5+ONIv2nrgt4lj50emEIuLNNoPJlnLl7ryHC/FcHNFB9/oWJ11thVdNPdZLGiJkRo3RWZRKT0x8fVH2Zf/GMi0pUX+amgQS4tytyi0puT1ByGuBSu3tALeU6kf9nXVVoiGSz2jx18wpGE3tRWeqxQl7CyCEbWuurE4ZjzHSOL5i2Te8aEuIV4jYgz5vAXUb/KAYtOjNCm0taJnW0ClCdRG04ISyVpufxlS9La7hD/iRCXrItdNUxH37Iz3FrLYEl/ng1a9qqxAt6XRK/RVrG0LHKXHBchTiRo4bwdkYwAPZQvXRrqbxcaFuA3V7lQ0U0kmQtx1nseLZvL+ZDEbClD+hvgZSs9UCAabtiDK1HlvdU51DSiHt9GPTVNy6V5ar4/2OLhBnTWLsnBJ+Xaicto7zuhMP5Q4xpJsNCxkb6nbepB3jboR/nD7MUrorQjXSjaARkx9ikgs8XzEPaFNAhfZIZD2ZePuBhbg9yDmp5IrZkwcGNhddoXfHxaDldElb3DHMNtSFB8zwvz5Ke/WpqTVrk66PTcSaYoNuNmYJZx1LKlN26CtTLE6UwwxZWOT6kdOqo600FrACcLuKn0abGF4kJf+cO1OxXcb8zBqFPHCvVu63CaThfLreYej9I/RPqxONHQB/bITVJ95poIcl5i7b0EfkOT0FL3MrMmuWE7hbrCYcVIqS2xGxAegcQIACyMNj/d4SyKgBKoUyFgpEtu7GutHlBuarbHeuwj3iQgL/3snnKiLRDaaY+3pAXE7LcmZMTFqxVUWt6dbE2NcnOr22U52K6LsEfKiWjx0Mirobf2cxIYzhcTcbrG1AEfS44xFmdvJC3SLjTONGaZWkbuonuc2hCJ6hl2W8LpgHbY71ki6hx6wir7QXTNsTAVTLUq8crm6vaQOeStW9z9YXiKkyhDYL/AMAftxKTsHCaUao8PMHgWmGdzkQn4zmqecC4HvhSOdQUG850uQn+gK+d0W1x/Yz9K/lylrL2313bGHsxfmup5dmlZzEu9I50aBR+NCl94GZzNfyBtiuYFFXKfB0pwaZdRCJSE0l2BydI9MO3ua3JZHPUPcQMvtvpCUsuwuWo8+tP98QFaUSJZYDYVsbHfbnCnswaUiLYWsqtJGZNERtVB7Vwjyz9mygTWdI0gkTROqbP6kCr0kMOpM1PQ5HmGAA6UxJJ0LzFOnXEzfeLtUWnYwqw2jkvPq5Xj1yUX6eFYDZT36JJKRIX2AfTJERZUztOiQouJYs3UuHWIdvPs6NPefwPV3DBCgsUlttXZCRsCoLv3y5iTHPwg6jLZAXZDhEd/y1Qzynhu6ecXK/8TwDFCX3jHimb0TYog6bHQoQUUuQ42VQn0JKRQdn/Dxmx0SDKtMgbnnm8RVWHO5Xex+KCZjeOCA2r+GqpFtnMKqr963ekooUoD2wsYN3liHW1Sqpjoo6wUYR0e0M6JV8hYJqeGn29C/olKX8NhKvxB5CS9hvVXU9/d+21qFbBnUlGZNer/BIQQaeBzvQ+oZ3DwOp01YD2AEo1vaw4wB/rYVDp6P1gJv0wlJjJhAhr2UR2ghw0iJeg6PvHyC9bijk1cuzuSEZrvXKDdCPkCx8tG2ptxZp8LNFs36gmRLJIlrAKGaTL/NNOlFp+aEUZinZHKdd9wu7E5XLMjQx0Qu8JwhK4AC17lVj7/mmwLtXLxtxP7anLxZQvF6YOEG2odb0lq91xCWniUP3YMaCDJJZTTMKybrKYrvGuvqK35bwcZ3F2jJRzhbESvPdFJ8YRgeRjXKUIkbuWbaY1Odb7xJwdymI7tAlqXQTj8BnkHCZr6K7oaTrZ3uygrmXgUgZqiEznByDdLA/XydFemuzWtjTIly4tc5zp7XLm1cHiCtkgME8KVFFIXOFiypaEg/pGXIADl7wgEPd2wv7WtIKVTt2Jkt7m98zX7y2mIIljRlIWlCbOktsdLGbKqk3l5UNXZWRJ77e9Kzf6bCDjT43+wrnHDRfk0m9HAOGc1jtWsZSVl3mBPOCyFiJS4CUdltFSo2zE+yGRPkHX9cAgk3DPvysMuI2a2dEhSgfU2BKAsGZmyijiGyuwf40RrJLo4uFq0UR6aFvhgCVbmoDj4Z8ntrVjHMOgzush/xuTGoWJlrcl973H8YtLsIzE3551NTB92ESWEIM0LWtbeNHQr2k9mZzrn8AP0LW2jTHWfLFRnNxlodV0hoKXANLQX37L/E/1avAOEfhsdNdE7StYgxjv9+qF3AFHspyNqWS1n3KCC0dSQYYHSkpBZccG8IaXBWeP82PQh4kevaHyLQKeUbSmFeftSYciMgkXhImejWk1RwuySa9anYqU63TKKzT7nq5Sdx0uailps9+r636YGVRVAkbmmvL8jDA1iTf0kYmymMorSPtKwketidjSmDzca7X6PspFcN8jd+sRO/UFK8rDd5lpTL0Mkn9Pdv7hWi/hw7tTQwCez6Sk4AtsQK6myvdtlQeOUug7XA7ldQjPEfYn1j2gwVpB0jdrojMnGiAr1CEO85gV69scDysPSjVrD60puNZ4bR3RkY7kMZQFS9EWdwhcWqSKNIhgpAKcALHNnlAyDb6lqHnzoWyqzJsrN9gTs9XgIqaYMDLqfztjHUl6h7tJuYaBluVH1YFb8SLlD7oj/hHgrBDMiL8lGCDD+VeZci/Rk10xxZX9JQOStYucBhH4greKmDFCRwDtzuqRoBsJhv1uhlAgQZsepiPkVGHz35HGawCa61165nv7DhrSnLf5iB8EOqUc7BRhITIXvAe3fGCoR7XIf61JBDOKzLM/XRaF+D3adQ4hzZJNEt4kram+vNoyVwKc/KsbzV9WNdGCFJ0oi81uEfJAzg8pZUlkgY2BubFnyK7jAMprndr3d/sy5rh6U7x367lzSSY5ZVq0kIRf4myCwuKN2xY1l++XK9m441lOBIrOYQNGPVHmIrObI9NuLLgjzaldOa+TW47kXStn4moaCBneDbrhGO+QQxiszFbFlX1qgVGHE4dnH3+N67MrOy75mLABpFmaIyc5oHUOUHX8NZRDSgQVcvMri+KgQ4e7PjqzYMw9Q02CyCESDL1nOrCra7Pj2PXU8IPlP57J0LNNptwD1TGp0aJl3l2pE6uCSuR9sB6TU/IeheZ0x0ymARIHY2hLI087PhPpUDghBw32hu8OpKgMQs09MGMt8MEWZdFlhzSo0Jk961CWolhK0VYBCfZgFzcQQSLIy46CYOlvOQrLxks4Y61jhdkTmIF+rYjmvdqDIZgfl/o4Igl5sm1ohQrkJrJdmVk/2wLji+boSDw40RSVee2jsZh86uttEIzlF6Dgbp/VPx2EbSrZxghiUX2MR0uiZYWQA5ARnFVN4/734IPZygG+iTzRzt5Z/BVT+2aNdz5brwMLSt7cXv8i8PQvr1RFTX7OCAdmVDvMiZO+Axk4JcU7xVxcNMefQlGzO111rCB9pnk3NRibpE1gJHZSgoNFjquBD0ZQSQcByH5WcK0vxRQq2d80DDJMVAbF4epLY00/GzvHKELG6WHdIKg7pzUaNQtgfUbvcxroO1ARCMm5umDQyuliBp/ixwhieiNmamr+5JDxI0sDaB8R1drs34ku3kkNRv8OCPvVR4p7JtcH4wWh2oMK3iP3JgPjp6aWyI4rnSUHRwdm5anUyAAraCzmMjv9aJVOukvdgFsolxzTeU3R7sqroS4sS9wLEWXJ6k9pSs3hII5O5xxXeShbovBN68GgSup5xUELx6wpNnp5XlZlEDWHqhgVbX4i+lj/iHYrC2riQV1YcxpvOMmtJykUDl70BTy5qqYWkbpf/jtTEIQYEE0lM5F84J95F3r0/KtczJIqWvAYw30gHgU0t3Pyg7Ek1j3oZ3dUhDEADTW4Lg1ZK7RXCh75NFE/SYZwRMosURP4vVPTBJCV5iUKT9QOYp8XlWGEeFCxAMaNlPG9H32YGvqK6INy29yUnlFXRW0KrFFiRVdKxFj/9UPSwEIEme8R58hjm32GSvgGfbOdT63kd1NW921a70xwD7uN0UFmmZHcWhypYlnaqDCGN/XM9W5WD5sbLEJR/65roSZyX3+CzAMF6M/i1nmVtEH7vpByVICxceq1pmII2WOk7gGApsUc6+DQPlCjfxfx/0YQH+gPuunPCLR8BsfcGiREy/0eVsxFx5s1xrhl0iRgQumBgX8ipFonR4UVO78J1gd9FPaIpTSms4HophTtNCRdyR7oMsg0kfvtRm1UBBSkJurhJ47TaM8bUfdOkvOcsiKklaMF4R4Dy+nVfO5mFyTZ9fR+U2Y6+b78sfaQ8K9YHkyd/55xOwRtGUo3vxy63jx4V1T1BWHSU0gqpeNuHw34KnW1MtKUX75eHShdDZqizd42HEoq0kLO1qAQXRA87MQMRZ9qDMi/pQJzXX8k3ocCMPe1R+wRCVWvbTF2OKmIuMS9lArE7fc/kDquu2m/7uVqibz1wtgs7YFPA7qDke84GWjFTjPInlfjUQTB3StsLRW5QKdhoPcSft51mENEQc9AR1RmQWdjBI2HvhyF+Yy6Ury07a0bWZWPSihE4LPZettnOyfXZAn6l00P3jqmoYm5EqZjtXJL36hqUdd4pJAjus1d8lbRiytgARSOBPwzTUc8KEnZj33Gq0vhpB+igwgQWSDBg7Dus1sfo6InTBf71HvY+ZoMoy46pDfLdrSbaynfwHvtG2xMiPnCd9JrMoxnpNX2tPGRutirFG8n3nyH9n/hrOPAEIBr2MCcgV+o00fq+mjXRFMmNC/EsnkTxWRMTIVlFHzX24jndyiy2gGNU2hMoryH5Az0HEgVUEvlP+xVSpXxKtg+A7arpuPBEeEOxdpifgtLdaTKmG3oMa2Nvmz56hHQIMEq4AbO0LjNDymx6Fw4PluwjTJu3ypi+8+QpYiD5hsE6dl/CBe1BWyFniaY1NyOn7QULDQS+1a/ru/wz6nQuVfRA/XhQHmmZU33fjzUphzUo9/W5WAL0sBi/TKM5+sjQY2WxWljSj8sE5TGzLUAZbsmfJhN36sT5PnquSkLHgQ22RiJbZNj4RsK9u+6m6Njk/gMh+V53pOegmp68LRRQ7HmJcNDFMC57WHtb+uq0VI30DTImvh4zQcw5vz54UzenuSCB6XdBCrSPi/BXu//W6Yu6K37xLBAAW2MmepTxqXxOJsT86mf/QXCfuvHmtFT/mYSD30iUgqKDE7s587DW0w4qVZ4TgQTYbY4CYz/lFpI81UBYEoJcfPSPMLS0Kia4ExAa+xa1bySKPr8svBQykEopWdWBnaOYhipcYpWnVZipNPlsXTSSscoyyatWQmknb6aUKQs46R6DlJmI8+1H4z2UadbpamAPOXLZPcxlyrp4kTf8nZq9hU/pkrr2SrjmqiHqT5Tc0MrbEwpVMK/ELFjYNNRJ8DP5cltY6hr2LJSe+4fO6B0iFbMN1QZuqiCHg6BmsBedNeJ9Gs8XUtN1i1eaO2nCG4jefSBx6ebcBooAa7HfRYwUVr480lDlHGtwRzbNEyinWVkVLaUqLw040xUFC3FSYXGgpCFvhCr2hZa+UgYADr/35sw6DVQQKy5pMobNO+SBbtK/2npPQuCj5te2D0SP3fbpK44fy1If3iGVc+BDaiqLfSHH31jf1GrktdR2zmk1luO5HyuDte303Y/jeKt8137Paux8KSTUbqH5D3K9x3ypIE4L5y9ThMrhXxUYyoVWjne9hrok/XjDkBXs3PwmR8Y3RHXS1ZEDdQd7zv6tBDVH9S/uVbyUgp+9QzjBMljJBN1biFwqDZCdcGtLsfUfV4V9mS7R/6EspKecaJscQCc2iHdiGPTUqyamSrCzvAg+QVXfI4vtPmKinqlt/njyXTaed1+1iF/yJdbhyp8mW7wafTVu7EkEE7cyiofsBaClROVbnjgXtnV4/AJd1rASd69B/KF+vyr0aN4amBfXqZ7g44brBRgN29K/BGRPv+rYan+uktF0BFKhCe9uvT5sEWA8n+gh8fVBPvdPiuu98FxZKbM5KneVs50H3MCC/lpwNDhc+Rp9KoeMHSTdkUnrpJdo/ghMAL9PdZzTSfS9W2UcT8k1TYXXLa6IMj7AkKjabMfX8nm529EE4Vb03Pvc8q80TEA2kQb0Ko0HctBmGFZH+HVUSCWeDky1bHIB9gt9O6ycVzlrmZStlwVmM9H57BDVf5rnoq2LtlISp3/QjF6I62g9SwTeIZ3fcmct8M8UbdrxsSEviAAnQ4h6bytvmubEgx0A2vNMfUxC9bb/y2jD++mE41quZDCeuLQq4yYC9tFgyF8YWQlHvZryjfc9vFsqrPOgA21rEn1ryTzILRZA7qqpOBuM+E3Lpy22oTRzsk7xOVl5mgkFMOHjw2A8gsj1yg75iYCOYkSyaT5Ynz1kLfXXmM8X8P64V0vdfFrc9B1jXWxXLeMFCTfqfkmxlFBjdZu7GumQ9DZNM267IQFxMF9VW2IFT1VxH/JmuafloR5telG6w2ih3XKhAHQZBBG1xQisLzLLaa/2ZvcjFHSN2vXYyGttn7EBdNiyjTuGCrgkpBpCQako6TexU71lZ12N1npqhf9Ci1WW6VAfKG4cRyy0hZYEaAg3MM0caYZ3SY49mwkKTRdp5jfb1SI7ifgX3HC3Tz9xGmj9zIcIGejNS4a3ViW6FBHoW6aYg2FmGQskGhByQCHye4eelx8BHwy3oGyf8AuETSL+vyp++7ef3tcIOrJMiRs/+DRjxCV0J/zkovEG+KRVek9VXC7d7O/2mB2wsHLXkz1ShQ+c/JGVQSVCRTyjlIkIi/YiV8v96tbFz/YQ4d8UFQEbf9Z5Vo/S987rfJ9BDCPpqDzgisGQOUzTJrZopLu+/ntHGHXaXu2t7PntmTqWF2PkUYANb9fidg85EtV1B+4EO74TrVq0WCAbPw6fqDYiCy+FseyKn42+SrocLcg2Q+XJQumj6vMcRdzQJsGqsmb2wwg9ZQD7BKBzCR1nEvFVwAlA0Q8kjGztOWqQ6VK01jHLV+5/seMoEHVTE/MFxApfiRjCPKub2igJPemw0Cf3pNhilWPYomzafcI9IC1uTc1W6jmra95ZBJ2OLJs4Be9KokbpkaiuXJY0qSdC35hTes0CLwlnCaf/ROY1RvxmT1a6bfgsQ8KHIu5N87OYwIEDNHNld7vY7jlqFyxHfEydEGKaG3P8iaJrrJKAZWmeD4+KXs215toznuMYVMYHP4bdOm8fLSK8roDU5UG5YL+ScF/O/6ETZ2KHezDNe/SfaUWHHcVzQ2fhD+VxmgqFNozr1ymkQnfOKP8q6GAtSPfLCEky/Mmx+v6FTCegdeVd7ITh6eW8psZS1NbX190XAvLP24+ZieIN119j5nPT+LrU1iUjQsdi50w2YTztaZRnIqx02lUPh14/OL64AGGNmxisBLNAEcGMSgdIp4gVuZUBvPYxFyPLGaTvlnMtvkrOa2fZhS/7i/+t+8zTqTbole2wOC+26pl873yP/IPQZhQuYpTxzon+0XRtDXpW++nFvz8uPy4/vLfzkuK+Vt7nvuLAkKDKSw5AszqnmJCp+FBW/+cSvsn/9R+Kk6Yhf45NLXoS8M2pG0QdB2wwsX/y3oNZQNQd4oIAMRpN0ywSNh7n48j3ngOXJEAoI1dHUTLhVvBJgMZsFaLtU8JSqBRJ5n03g7ZtV+1AX3GUiGTYzzQWzdb7Fto/jVz9jJtFBNCIqLC0OylJTv3GbRPT4J01NcJABWIkDHrQTTaAfvmTyaFsy/kzcTeYVXELJiUL2QMuHLNcr84LcFYL3jwvkFP6JzSUz9HySXlCTVyw/VcJ9N/EdWXQ5rdhsaYAVWhXBGVvSRtdEVONSnF/idV85eE35TctkPAxm65/1Gov01oijkKdNAFUpMJQn8fX0GChXkb372Jt/+UIQuPY3Ieb/5lbJhBmpp2MYWzEdHzjTQ0OV5RDLxxZqNt3uAqdBaMo4XxOYLo9xroJOSCHAzcHK3Ng0paakEe9y8abmIWEMIxS1xr/6ULsiZpwPhPuh6CbHGHnAUlSiMpz+CmKWEIn6LQB/SMK7knkZvNoqiJXObmw4j3PXpwAlGowrFfGiwN5c2viSwJwGvZzns3ZPdAuePZvnwSsGuzYCDd1NMjzv+MZMXBuJIZlxeLSIFC4Gdy9Ig5/gAK40X36Ydi8ZMr6iUzmNZwYJBwBtbN29WXidcv2y9RF4Fut1GW9xG6C7EzQpbXorhCTWzdTS5wrJ6rf9hqgtyN/jlbd0zkiKn8jM0oxsFFyGw2lSgU0APlKkmDHGyYcUQk4ePf1oT/SSF16CbsbPkc37J/ZiDQmohP1RIV7pRgdpCn2tXLd4jlhjc0EFlcv74rsAqQz43RIgyJG/KI+tKd1I6jStMOH5dO1S54hLHPaf+Ikr8hgloy+/fLS6Gfz/I29mOTrxq44ucr6V5CUt9hvUdinAy0ZdbRfFzxdPEDz7Tj3AV7QQFrmgM3rXlco92L793blvN+1vhIOiUJk+j4EQEiD3hbeKbTuEPhejyqWTr3GNFs+/wWJAqCFPQMirASgotmU3Krd563fJBonk/w+lVSfPe45afc8JZCu6Pr7wr1UjwD5t/K29Z1wZsaOVfRa779DVAgV9O4cgIvRwkeDp2I76y+GTqrYKHU7vcW1ztGhZffp+JWSy+BVkAl6k9l4YDShLhI0pc/QgwivCCBPUrOtItWm47HtqlNYhJimdJsSQqvpKDG1F8BG7SzWxpV0L8uipqdLF4URTryTBIxIJtNa/nwGWWDtOTVH4dvP2xUwkZm5ysiob+NAyIIvdHbyGg3gY6bjNzLUjWJsOSShVgBuciltKcMpccBWAIiIfYhjXAnJ0wS4mwQnWtadMoI3/TMHAMNhdKmdanX4gc+Gx6mFzP4tbwVieGTnMY5s46IlKGJEocUSxxGZAVgq19OstEyruexDMYUKz6u4AiX7QuYyYSKOIpDcWQtjT3LyyOvZyr7fYI9D+VExoxcGLyPcGvIvIxTN2FDb7uPRP5A18zW7znhl6lAJvgsERHoUUCa+GtBqdL/HHNbIvV/v5zwkkhH03YXGDEO2Kx7qghjqQPsMOdyX4oRjkca3/a+lc3Nfh63ivpmXTcHyJUXc4vS6ZaZmyCC5qEDdnkxTW7Gymo61JICXha3CbD7dUBKGtmWbTG/9v+Zu82RRGl4YANQgFncprXUzUgKPKVb8P930yCSf29zqVLDXrH3AggWhHn8EkZhge/qv4O7FzvjgkofiJpBLvREMXUnzMbRFR5fKbkXPm6wDxSeAXKJZr3xjUQJWk/MOID2UNCZtNUuTsO4ZKWfs3MUh1ZQ9/ol9D+WcTwxK1diXdSPxFEIbqrCKoBM4odznHFIWu+k0cR016J3+ZngSHI0hNYtXriVldW5jGhyyYZ0pqB2thYkkWSVti1zrLmnCXW5BUgfZx6Tbz2msG4k1FtcPieKH0OvOVlPwmHKuCDF2Nt/vM9dxKeg/x8yiW7/YFylyeQChPSPtF9NlroJu0UTAILpQdJ2MNsJlL19nS2abvQEk5s46qe6WGA0VQ6nba9PEK0ViG2zsc6TSHRP9wYWTXmiVbgutIV5eQYrNb+jPQhddVGagofdP9VWg5LlsqOAk+wgtD4CD5/Bckn2zc1yqMy5oBwnjURPcO/iQZxyc6wnN3N+xRGg6XHvWmP/l593sDH+nx2xh1dJT5yeoW+RKy41+0EDWqqE0u3zsvNOLqanMYchxMdduO//bbvbiXZB7fGbt5EIXUzQLA/F19qk2b/O041D1EcLVTq9v9kfbD7aJM9UtAYCOjTqSg2eRemy9I9VU0kP2MkewVKSPUN6qm+QRZ/5a6UM0RyGb2BNpQPv1Da2vFdhfpVCkBstnoNuTNvcpJ/4N8izQItUqwJnJh2jDXRqBYp5FSJgQdVwYH6Pa029qFf0FCtbXKT9DYwr8nzX5rpdaOOOqH5jqWYhBggudeYOefEy5GgQ8VWxlU87BPCMoZjlBaZO7iJ9WJ7LpDFcE3Qxcvjjf4iGEC+4WQou97hgM3e43m3jdFIo+Ofdr0rHQl69C4qfA+PiVqyAUI0s3qkd/EDkw9sdZ1VyDi/dDDGOB27jIzZAMYSYpMLE+CF6v8/VjQR4nDb/hujkK81bG/O1YYyeU90WGYM+69cbMYbpV+5TtM+ZqTklOhz+4koVgpK+HJKEqvSTuFxjS1ZUCaUIlt3DzdCHbiZm5ARFNDkgS4Cl5ORmWva0/ACJ4OIbVsxKRpGq1CY0MYMcQHesREKTditTplAltnTsIPKembPFrWCn7W2L1U+ta5fbCWne+f4peqj9dZOCAoaXaC2iETlmluK4dfWxEY7Iqdn+Po2ueYT7iu5HyrsXRraJmR9Nd2jS9PTlGD4KSJc+7SSePtcnAOIbRGMtY6QLkWHqRoYYiLyQRZUcSoO1cxO6kR1S6A0P0ShhiYt/6B95twqSctM0C35I9LVS0pfciVlJP3c/lJFfXveVabVYOzLcMSXAXsHzp+luS3hO0AHSApqwip94AReVBu9jGT/I0mh6PED22v6I8xJdI6CXVz+MzL6Y0H/Wf3UZoGTAuTKw73YQj1V1JjTIjDwCV1Cl67oaDVqT+rhXFjOFBkcBFN7rIjkNSo4V+6rEVIx38ERUp22HMPSfinYfT4ist3lVmcg4SKlC1ZwQI7A6AykxWdu1nR4+k4w6lkum6k6ttyqxWeyjgSpzP2hPfbLpUBK9KmfCOfhs742HzEM7MahKRDPAZ5BSktGhg9NbdmD4fXlm+hBTMm4i3+8zA3mxhZUQWw4snqdkHkVucF3nA+fpdEArbdcm8kSUxWf6O6TvtewCkAOT5a5h082kGGOGiUWBXnU+RtS5YJprpOPubXaektCwGQoYw6pVDqdyIG6wF6xnmHydiZb28lTSvUzZIJog/1pXnbIcdR7/6835+1xmiAfRkBCiUop2AAQhjuBlaKSk1m4ko1BB2tkxGNJznth6y7E9l95/Kv4cLgMZ4Wv0R6Yaa2HsxV6Sg0kR8u3egyY4TajauKWK9NXNnzN4/zPdAnTNI9BAOmNQOtvljwqq51Q99rMnOkZA9hv5E8X1Mt1M6oo+gMZ3+h5O3vcpFGmE0E2CSt/y5SmGZyZlnR7oFuqzXcMwpis/sQr9CX5XLA/Sn78xpx8KzBHTN5uk8SrOCBkpiTs8cnBOY2Fc5/n6EdPwvw1FXQtiFg5y4ojFgfIQbYfL4t0BpIflQxO64MsswjcMLQ1HDo4B9cv9TkzT4qIbNmFMCQJTbS3TJUP9zsewecAZ/UzdyOVsXj/ds/ya1wOH3CAkRJWfFNhM4AqGCtng0wjCCgJm0bpo57eMvCsIzzr9JogVigqw5djwjCj8Fzd2k+/y4BDaFfKuVyIBbszCOgtYZVV3xiB8zq0fAg6VCbRbmRFUSXKz1rfwzddIeg1Vez6EGk5vWHBG+q9ww8cNRqyabTPEmNCUkeUgAqsV/sab2jpc3jW4WszlfPw7Hg8S/QklOBJSKefuaIsC0+WAWt2DYe/2YQZ17B02LAJs8pfHvp/ZF4rCZTv/tk+Kf3LCDW6N2O5QvoRJRR9jZ7HQ/KtofqXr8QUesCb4SbmlN50tDTh3nsK7cpxX+ZqOSF3c9uhBLZlelqSAz3VS7eqm87aZbPfnSxYw9IcCkDzT5bVY+0np/HooPt0kZPtSE+gIxULHpI12mQYW/AW36vcEozg250B0ai44z7QCH6ayuYTK1ocV3bKg7gS0n/mUfHW1VU/KoxcxH6bMCT+o/0IbuvnLkHxn3oefFyj7gC9EgZFUoWoLOpKPbpmYugJG/KrWY1oW1gGk5rLeLGYPTv6SfH6jGimoBlzYwbOEpNJhTVwZbO59nJNf79bTcWbCrH8g1NLrRKItyFCb8yB0OYZBHrQUYnr8elJiBKK4ONXXU5CCmU4n85iHLj/8zjM2Fya+haOTrdAGfMeY+Bj51q0HobMmTkyIT8dWb64l2FvPEqPDKJuLkpCs3SaMtsUDYMyQ+RK/t2jZ4E95lFdNLE9E0Nlp1yI/1CzEalVRGwR0+akDiIHyK9ytTSFRarnkvz1l/8YVOPckTtV25w/AGvP18RWSFJgQvdoXCb/ZYZmZhVrN88mW7gjoWLgbhj+1zChnMRo0i3n3VbLE1JQmt1mTTcmJc9R1NaPHI4vjWE1yevqvbH97XGuDehdd2RNPFk5syekZJ62kdFXeKlSV+WeDodQ/jtM4B87udoSmEf7y9kjWn0NRYt8Fn4TJIC+/W6SphcXoFndWcqjuUDTJ7goU6/vyATHbVGsNn8fyHXJLf/8qiZSOzeZsxs0q98faP8pXfUe+dJ5GOhpSgk2mcAnnltneaiNnAzZ3rTa1hm5EvW2jVXIP3b43/9ytujmAZxjLCC5y35tGJhqunEuuA6UV15Um0kazt/XSnTF37WZ3+j8+AS6MmEbUhdGc9bklX8g3LKtT7ik11kwKcnNEegtzg6dnN5Sc/PnaM9vLqanfFbYY1BE2FRC+0NanPybSkr03MPMa5Tmy5MaePq23ma+9ksimiwn/OLBz0JyDSLAbUjeBbNczYjDQRnYaIGca8X3FBZBxnPPOljk9TaDh7ZOKjNcLJkf+SaLRO3qAUcrFPH5eJqxepXMYnscIrNkTHhN7/X/or9o3sNTbNw4S8eDIFg49PmGCK1F1A7fWjhFTCmmG3+zQHeJEM2MBQ23UuQ/hsRlDrd8DPqzt+0azIliij7FFgs05kq64k5D1UXjzDBlWAzeXds+/jca+vzcdVBHoTNBY0R12xnqnxKOxidrKMq0rl7fv+W+pYUhyPNYX6trKqvFxt7xKpiNtkhdb0bWWvtDBrvnlcL5itCR5B/Y3ZHNYKcWxZOzCulH1e1j4I2dr+09l2i36p1hy+uHcJgjdcX+QkVZaQf3WzlR1qXhX1+KLRv1kxe4uPBCHVJ+RzRa8ymWh/l5FPJ7BRIGVTz/2e8aSJmt9wCxPSBY2Sb48YxAbP4klqylIun9++jjpWmR3Nlu1ncDjJ+Qmv6tRQ2thcr/dOwq3Y1UYtjoNIpOwt+djepHUSkj+ubhc9svUswTLofw9Vx8nRSvfESEPEUnd+l8+n308blpPT9T6HFqY2JQFP319FksQYkKfn4PLSR4oBJO1qd1/qWSDvL2mOQPBcbJQtSwYftXfakHCO8EdfdykxUsdJtHN1NRKE9Fao3fm0mEOV6m/fQyL1jDEqdUPiyXSOhoVm0Ve0nOGE7Vo/bPqr2VoOCKIaUI+ipjGQeUXK/T8qtf5Fb7pi48yMnDYqBzKr0S+UixyDCLR3J2YRWd2HSs0NtZISJU/abI/b7sJjKFeOtTVl6L1ynlUmMGKCmi86w24DWUWRE04xjK3pfACaZEEfhN5XXObd6xOdOKW4fajq6gKYbF24RyDVnt9AeLQL+pVzQeEGUC4gRG11XzArCizHQ1/GU3A7bCI6eeYFm5DZpBr+E8hzfUb7aeG8lf0BT5URyI5XLOO2a2/qZIwY7sIEOxNTUaJS0E215xXC8kbZzGB7iJCobebz33aT5TuNafAHrX18tc/VonxdZ6MxJy0L8DEg/r+fvI5zPNe9rymVBnF7tIZa22DgCupLy0mCMY946+7pgBWB72t6SaYOuF/xDOMYi1pvJFd5meIOjx1+RqDK9EtQNSRqnrS73gzLcZz24cllgOCYMt24vTCuspV2JYiM2qt4p10OCx6lWOu5r/2UBU/1qEnvjcxKkMPVS1wHb8RXcJpZGhlipAt6FH/9dBVA+F1BvnC1EjNWOK7SpWF1zhras0H/l0NrX+d3Z+gJbv7FVPnZheYU4WvgZ9STCek8rcIkPG0H3XfTqC/JX1bRBW5jyk+Eftibxv1Q6sdKCqjBsWA4G97OV5VGbAbCrAhCd148Zm85kK2kLRX/jdKLy/00V8u82j7nHUMlnn7tA0fgXVYWdk3KyYDvye7OyuqZyerbgsa893JDOfd+DF0LdU+V+D7sg1+9Cbv7vUEupvHbFSuPkDl4st2r3VkC65DquXaoVFV1XpTh9Q/OkZx2AW3tV0NjlyO/5O3Shp4piU/yQiskKMosDKmbgEQrSk8EvqOxUeIvSzGipJMA1taCjXa2L5X2Zg9hRoPjIo2UXLsJ2STlirJwUbpoMLSLoqfmCB8v+pl5iPhTCcbgry1skaetxsQ80w/eEKg/I6VE+mrJBQh0YJRSck0V8JnsJq2l3BvfqDodoYJhXqyf3fqySftfHNJD3tpjMuSij5tRwKCiHegjkhR4HEYLbjzlLvXGRLBtAmNN3mQwlnQgzrOOoLQcbXSWh6+6S5ZjlKVplFB4+SAf3hfVcVqU4YDvq6kjpwI+/FKWLm6O86XOZCUlVWeRCB1bnU5HoKDYy6VKAY/4sQreM6vcz5SmQT0Z6MaDZgkkcOo7FtTbIKg1jzt8JhfOJ2QRwRq4evJil4zacLBZJNrdeTsaXso3vpEEWAIZ5BjQ+vq6wc+2Qqh8WiiVrCfQU20M0J4KUloOZEyTIOthGyulkOAD82FzVBJ6FRsLX6OVFy9ifwWeaZfU2fwHtRV2wdXC6cCKdjdnUuBwVK0e2ney9Y2hmaC6EKToZzOjiWQaJ2RkexIe5g0I1cLVC5zfj3z6MVooMn97Q86QVF0lhG2WF8mlEkLGGEv672bYwUPF3HVJ3Pn7y+sea3aFrSbMaMW2LTFGNqIiDdMBWfXcDNyM3qqxZbl8IPfJjLOqdyk1ch89F9oJ/8ml00UOshajLaHAN/1xSU8ozO5vItBBTf7VY0wvDJUP/9T1+KNJTwIvNtwiL5g1U6eCUBFTosjWVdMVs5ahhxZtp8SWRf1l6CLnHLEHENhCYHDCcrlFYd53+rGMfiwMXasFU349MZsNUVJaWbG3PPQd6yWiNjtdlHxVTlG9TQZa13fU6tnp9EVU4Xjj8WOiIqER+VImvh6cPV79d+XAtAs3BRZ5SWO5IBq29Vd4D5hWAsI5/yeSl5yHQ6u8W7+U2kb4vVp8QvrE/JwJ11LrTwtssOl6GcFO215oOjYtUGKExzq95ep02pgvEgnapsXyiC9qJQH65QSkUJXTpRvKcsgUS2b3hfNkhi+ikRCL2dWypoKgdVH1UioWpzqkPxrusg+5SinLDjn6bHN50uUsvMOQPxmIFMGY/mCPWBAN7UUbOJbYAq5+qXVOdWi2DjBMnLO+da66hLtAAuXue4U9kIacPY2nVmRE+/UXzsT2vvrzv1tSuvAA/RtQN0NjUyVmsLBm61ycWrc5KmHPbBDC8iXgvNvNL1xwvYt0dU8KQ1q9h0jP4Uwd2xuxiHc7RgCC/evdQu03jxoYclWgL0E0W/HOVJQCSzaIVt7X/PMlS5KYFHUSB/xY6N2lA8RWmAXPDrTjBB11BUJaCP5gxNPA+xTHcVcd7qUf80Ms+d0Y7E+jy6guGvqOD6P5l0DrXZORJ5LgFIxbJGx72r0LeiV7I5ekWNwO1ZLpasGLsJ4Ef3rS1AEafum4azalviOVOshy1Dh0ZHMzZN4f53iUM0OUhAcZfce5OQX7dhhMmGRVMfOF0oTZ2exBl2MWNU1BUS4skRRARzF2H0sd9NzgF6ebRcwV7loVngWhcXjDeInD3CsHUSdtgpiZdsHiDAMZ6k7SmAMncdb0HXnw+uL+gPWAD6x1VjyliTPW3ndoyN59GlklLBmSiTRLHADOFOURnaK5IBmUv8X3Yl+CWGHXDyxlzfL2IMH7M60eBST86AGK4mNWnGo+JkkWevnlGytH+Ak0Xi1b/YR1WojS7FmXkXTOtcwChv6qgRrM2cGoW9SJ6hxUqTgaI6sFehbrZ8hHaJHLUJ0OyxvbYML7hPM0HHMl48E+RQ7Y6c0EK9bA4wmbp8GDYPDugrnHfretBIIhx76G0teUBV+rYT+7kbNd/4fBCdpTAJcs2Jba85ISkfwMLZdG/hEL4eguX2PfgRFVRAC8tSNSwiDwq1gRnGPWQaRN5lkC1gkM3jWHiNNW8x+VFwxOaqG47agi5uhqpWndrL+9VllKAASgr3YNZ57mvZb55lv1oR4XC4zq1OYnrBFu/SXic/bXWyOtHYczl5x1d/1fj93BlUhhwCBQaHz1FGdvFAFWfv2TJAoN/mCHFTVadsAYlCdRv8rjKNfi+5awYT6ixUozbhN8AlCW2FT/ZBNhkAOw4ZTtN3YJaVWmS0kPL82ixithVML3Lfe7TG5bObrVZlJDRyK9sJgr/J6aqPWjzyHLRMQQsQS5Ylt18fR5XnNl8ijAK+aAQjweo9gG1z8MH+Lj/aglTZtUFJPRi6Nn9iXKqDwzXk5oNqfESGGDP+rKfnNnfvoq5IqTePZYF0TSAbBfRKUtXzU7OlaphR8KL7U/OGBK/NKX8//obkxSTEQpizQffmMxxQY9bJn5uo3ujDOS8e7OsGA5Lg6blmZgJkRKiFv+mtOhMcWtjmZJrlJcQ+7O0NFoWWGkwJZy7WAmeVeOaZbVxaZ/pPBGUCXbEp3ZlSxYD0t7Vv7cpqykZFFLMLystmV8AeGYKd0HLAFiGMvp/XqsiJPCN2N6rceSTLp4lRAiP6jEg0v89ihK3WrTS38+2GJY1Vi1Btxb3foqIZFlpLn067kBsQfInoC8sexua66vc8yeajOUX+PpHkGYNJPdgxU8LKeOb/6EMwJGWdvqrrr4xNiUa0iLSjvyDgRul4LdOFgJSttaDd4YYWoX2EgRw2cb6OWf+3cIgfQ+rslnzXXPfT1ygAFw734HQ3Arts4/K/ihUYZ/TEu3kTqAFfVQO+C3TF8YBpEUHxIQBbKr+JebpaCcf1CU4ZcwYYsb96MV/irK+eNjQqvO+ANp3kcYWO6uRIAL/iNjSJKfEo7dkQfgpktpjjaE0CpaPQCy84KgMtgXzpWF3FRjzQ34meKSP+J7b2m9mIRhn/iXKTbBo8jPndvmNONn6Qnuna6/x+X19T5ZgaLYgaAGCrPU5aM/eBSH1q4VwcAlrg9MOeUVtdHJgtN5lnXUNSLlAC2O6wi+/sRPtHjwEqaYB4WqGFEOwZyptYT7kEPnv6yRCOEHANpgM0Qpoaai9zt0RiUa8S6G0Lvk0BIAxFt1SkRRLEkpacQuICLTe5ZleSb2dywmb0/bVp4A/qXiZXlraP3iY2BBWscQoZ0GXIOEWyXS97hxbymXMJ+ehFBvFUlx0QlGoK31GoKJkrbYJEdM1nfefSkUEVv2iLYznWiUH4nKZA8wolZ4MBI7aItEmDMPCu6NLwnUsbzTCyeorG5lwxF/CzYgae7227CI5AhD/dbIoQGsvPwSnfv5fyzX/LiuJtK9/BwdMbF5AZeCNnGMXX1w8kcv9z4mezkyzTsGXJgb/Oql9BTrwx72/HHlJJnjXADzj1DB1eTb6XIdqZmuV+stHlw+eOvPwtY20mFfzMX2sq6uKEPXAD1IxlGpTH+tB08Z7gZtn3NTDtUNRIZz5mgoXDTeFSLMtME+ejgQfDYahddYwE7bzYspwRou0DexoGaodekKbZgWnCuBTj0ZBjFpgsh7NyFGaXwyjALnlmGq/Gq4pBDsuVH7Bgpr8UH3tYOQ0FljQae4ct8zPS5k6C5ZgEGZlifGdwhBQMQrfshb9obqS0rBG7ZNmE+i3AdRzlUkFOfDRhRxEU6iWbf/Gs8vXaxJvfpy5yeQHUK8VPwQNgyWsvDldWo39KF54gWw9oGXQky3xY1hk9JnXuL+7fpms+QNUCO9SB2ylp5Ga8P0vIxpf6rnzolBlk9iIrNFUKFe1V9W0TtAHSfXRpovkQLkDAL6/G2CczNY+yCNC+Jav+QXx1shm9ayVJQY5HnYFH98prru/5oqjgQ+mYW/hzHtGfh6x0e1w9ECEJSXwWjUrpXMHVDZzYLbCevaOparQ/lXUKEiE1q7rCvSofTrtp8QUjRB2IdGV3El/HciDAuuVn0/yUqsYNGU7zmH3wYwVhfMA5wjqx1zMwENAbg2YSOz6Jv72O+NLMj0orvY9XL6NQMszLT7rwoW5987omUER+8G6cGNqT6+J116+vLnVAFv5jGvubWlyrG5pp5EHy7ujvPikCNLEuhmS/U5kuo4ngi8vgyyyy+3EGvj6s4jykn9GYtvb55FwedWlaMoqS0a9t1nFDqiAH/AQMiAgajg4V3Ck9zeHKm0leRfcIeyvWGwDRPKAl0lFxunYGuJsoPBya+GucUTmJlX4GTi/VqEqQf/zvOa5XcZIxwusarUsatGCCVj1Q4dhJO6LiN4b/orXHuaZvXTGZbVH3FaPtUVrgHVfzFXqidXEHXC+ywdGw957hndbxmKB/TwOxA3nQF0CoPvT6TBss7++BTKC7rU1c3QmEDErsmbzJXHTcVT7aUiA7M7p51mW75I4/w9iHUYaM4prT60QOf6/7jmUXRdpzwtomlDsm7kspjQICjGSURRS2HnKkU5QDtVhH+uhZi/pTTrcfLMnlun2Eqin/V+vZ7kX8KzN7P1mh7srzmo+ZuzzF/GOwJXvyTwhWclTi2kIc+LMAhol3n0TdcX7SqjdVB693KG938PAtztDOEXMg3Kq51Ir6VuuT4TyXAD3boeMxSuBYvGOsba4inMq63XympEL874ntJHg23F4OZR+YvERJXdVjqT/oN4CBQHIOUCursxr0CGnFrVat+oHXu7N00gxeyw5uHo4ky1PGoASjNccWI59v3irN/zT/Tw4sQzIXGLzBhMEvIYntT5S6h/C+wvuuiGJkKXICP1tc4tKfzFxyb00AR7zb/TmvabOzCYRcQ/TpWu33cESM89G7IZcKtDPsu2gQdmD6n0titHNKPIsDrjva++l/LCk+kyjC0sxBtBFb61zGrz6qgTR8WtB12FIQC6HN8MAqwiq2T3HcxJXaisoSMviGKg045VIEEAA3OhQFJpTlnXizUVOrZ/UgGmXkDyj7gcp6oGmH4+6DnoXeFJUDU5dC+iMZAvtAymljGqdRCztX+E+WbN6qbJ5U3jHKwF9HoQGd4usQxUdfeie7L715DWcEe6eyPSwbomYTqbQPxRoevIHgEToBLH2A6AxBSigaPMp7PiLig0ca3/1IGRykA4OVFc4UIUl8ZkP/QVJXOqhEzqN9xR34/rpOj2Jx6w2ZggCSAe5SkEg2uxesb+IDep4nKIOPqbtMqQ597vJKtd7CNcAv53tfOlGttZCdesFou/N8NYoev0D/1SHaskKv23ute9fnszrCJ+Jbi1+4sLglfzrmYPf0P9kjNM/OsMO0UNJmkIIp+qxVNwPCrx3yw+u1aGOqCvVY2YSREn8TyttxVRDHVGhJgnw0NR4tR8nUvt9rTAkzjMi3voX8zUrODd2cDRBLFeoAbOzlt3lbPt8h6N4p7Xwt/zqMcEmACAXzgK3o39itb3teWvBYkXYyj7hsod47MH4OPgmgQ6ysmQCwCn6thOm1NN9ybFZUfPLApnt4JZO4R+qDCmyFL20HPC1/oLUADh63U9S7ZUGRLzx5DhTYxDRUVpOf8pYjmwEimj58bBnBCXTcV3VxahqvEDjr1kKwUUBZieQU0gsVoAZRHfOaTbwfor8v8wM/5Dk0ya5IOHgz5LWJjHRE9QxhCJKS6rKhn6k30GkwZMxflmi/Imz0L8fiQjBIgLIk9l+q+ows4bmmnpIWk7DxxAqXborq+/EBoY3JT1i6b5Q2G3boI9c+RC5ptIpHXRoCHgZ1H0h4U7IRKKj3f/JHf+gZhs4q68CJ5d2u1/RpX4U2cW3gKaPRfl377EUoj8REgLKFdfQ9fBbZGLMxY7rjUUaupC9qLMVlFWqAH43EnEvJx2VWwpPl8rgUwFtzf/oorE/q2rje0ChGlW6HipJTTOHGu61TzCLWad+Eya6o2GCks5ykc58jOCrYh6SSHRFkoRxVNKCus3zqPeVQBiP0JOITeFdtOTceHqF283SBAEmXWnQgv0F16txq/R2v34Qocl5YbIRLxglLaRFQuNVrwNYuvZKMxG+eRxF+buYJjy9JvsIs8YVnMQpcKoRYFqj29J9bNrcP679JlFhAwBvPYDNYbYfZ/c45i9e6zQqUlnNvQR8Hl+1QSWHe5S4l/e9fsgZh9nRdFVNj+8Y9pKDrI8dr7329sVJa1OpSPnWXOogiqVWKGZj/jMlGnB6z7b3tHFCpZX77u67itly/aXAL/0ObbAVN1//lT6oHlKR6Ap0z9aWPIn5p8dcV97Cy/N2wRDpnNufuuHqS2S1PjjvF0SvXl2LOK5lSP7IL7nCPE0yGc99/urMqbUAXq/01m+UIwgr6gPx+JjVmuQwpP+NlC54LYATCLJcd5LPlu67Wu3x1RI+3Npt3gMGkJvMA/OZN82OWaWuaP9sH6rpGtXGrwcMnIJlDEgTQnCWg8/mQRt+nLv/J/Qgzp0t3OTvBK74wr/09XQ5UQ68PA3aTnBtth9T/oV4ksaCHimrDEAcAvcV4NqT1e5QiSOLUj77agdtBSr6xk0iGEmOcngz3exlh+Bx0R78s1Zdl9DTBwIBUI492K6cSPHrGZ186AHJUVuymuMEKV8o+MS+HxyPixVNVqD/4Mp5xRGJhTmhJOhMDn+MzQY1f6SSUMzd00tQXnDOn8tYVEBS8XVHmE1gG8u7f/HBJx3UzTN4n0sEK+8I+heu2lzGcIkS3wELEg9SRmvt3a2XUknZvhAkh96mpXiXQOU4EzPD+op6OMYvV6ZZ8meZZRmHTF6cjDxNgW1FVY+nM1zRHc8vnSg4dywJut9PTP5o7Scd48MYIdemljZegfihXLArPisMnVPvsW3XsdrwilzAbizNcxepksjESGY2E7jjA+b8MwXVPvzO2cDvLShctdPi0VPb4SXmODX5Rtv1lfqeAmBtVd8+Q4mIq20cPukuyz9ZOyDpKn1TDhDMGIhY/qOKOV0upLw/7NAmNoIacGVPOO6Wyx0UprLHDj9Uv9LxmvueKymMU2CltrD5LKcRFVr19qFs/UeBklOBjB0CvjzqBlr5Cw983J0fypso/KoniCr1C1iS2t6/skJxvmdCsUDp1r88uqtO4ghokDoPCJJdQigUuk4+Ksu6tUfX9vOyPhWcddbMf0iMBT5TbUHhCIVaSPlWeAKH4KADDz8BT1xQ9swdZ7sfAwd7X4c37RhQQAw3IVeVMy4iAgsH/8aWHVB9qLXfxekJuySxFNSVDDkNk0Yl5JH8F+I9W+elHnc/AvB2/Ju0EfpnaBZf8B3L+b5P1pGBycOolpm9ReMHzkRP3q0ud2RVjB/r8B8Tlj9zu1yYgEB0KgOY22DTkS+yuzoFbbzI1cB2nbprK+zL1oPsVFtE08XeW+3s8WaNSKIsi/0BisWAxQJZwCloiYrfGBITH43oRGeZlMnj0gvnTH1kwSDOdAQSD274SNvjn0yMhSq3J3RWaCYyILKANEESMvCef+6rZXlC+58d115nGbUkWUS02dz6hbh9NiIAEFXaLmN3Jm09Noc1VUy+n2IlhJs45bCx1P3rChdEt5DefO8ZV0DtDQ04hhAmBsTPyYZK0igoDG3R6XRQB/7VwEY1MlnRNYFH2ipZnCM/0Lo27okVIsCMC89dNEziMgjcgNgeBwjN36yFKQv8jv9jt/TjOWm5jcshgu3IXkZqZ9bHZqXswtbQQU6I6XDcuqqkNTwUiMyF/tpbQicq4MXFx28BkGq73fiBMV7XNSyUVCsz/cq+2U8582XwDxKjacI74ZRrsz3sIIQdeMrBsuPTqSJ6oy8s5nYwn8UV0NEIxz3INxmfZz/SOBJWrw7VIE6nriR3k4F1k8EEBd/tupT3Nt2JnSqOIo6JlRNwLgver85IHDwIeXMQNbesWcIDTJhsa+hhqCsLmkgv54aDLU1fwXi2VQXrQNEvglgwFQcg7ubnh8GeU4uUrG3fAS55bKa5NgS5HvLJUFuZMLPyIh7sLOFrdW3RrjIAim78yv9JDXxS8LLWv9lOwydvk7M4VeuAyL40nC1JIfPXi32xD3ODsoNdxqTBv6zL+rg6cpLZo1Td/FVtH+aVd2nEMbUxTLp5uR9yo9h+YSswO4xPNM0ok2vqLfiWaa2/M4RXJbraXbnpTR0skXC1JVhRgFRcK+dJo10/VeSbV57C32G7X1s6LTSGRJ6C/bya0E0KV4Fr4QTCmyJHU50VSULPKTfwqFGz1ayv+NT+cwvUO8xX/FLsAJp74nh5Gb44/+ls0QbChhM38w8z5mQqD60dRyrFUDpH57VblBkGRn+l3EnziBKgbuWCnsk7JR/qphasT4mPGSgUf1FeIWQN624Bfow5taoJgIFx/L/QXHyejTq4KJ03Ows6PeBmBGVfgrQDljmHQqutRsZrI/z32AoaDd5Nwujl+NmjJeCTkzyA5CsA0GNuDiHJYVvhZtvWA8hPY/slOSbwkBuWi7encZ9HE6vFqjQaWXSt6s2WhlBqUbh+/mq6mfvpbjiMx0gMherJqihXleHBDw0pt/w1LcTwIO2PV8eVwGOBCpqBg6vSwOQDzWUg6/FwkTAl+QVPuaNoBld5Fe6zBuoneLiDUDOndZ+sKnp67ZWyabXTdR3yup+U4CIkyqxlMNQu4Rq3BUdFrFyZutAX8WLLVzMpo6WfxGStPK/rR5jJ8fwuWBsGMFSo/8fBzE4pRXFY9WrM8RNrNe+u/muCMZk74Oh6JxxEyHrUn97VpV48Yk0oS+QVC45Ej3daRSG6cL4RYZiE8MeFWKAOUGpLqYCDuacgllssXVB1hnc7SKfg5zE0zEIct5zkOOLjP4u/bknkgxrx7Kq9Zh8DdvwpkbMSX3e7VDksF82Df0Hb75suNWL4Bp/M90tnWrHZwzqRUpGDXXCmnKkGlt45uvHWR3negmkPpG2BD5ZhFadc9/hluNKklRDNNAornuxvc3iUgQ5/91EB7UsFqe2yCVz/bzJ/BWYKaTiWnqFH9QAMjEJINvy33XF1qkd5/dJKuF/LMqjHWd/GxDg2mM1Dk5D8HDRT8iWeG8yATk53eCKeQ98i1R9841fTwyoTwW7v7VdKLHvgSkrbd3JjkksTZP4cAKr/RF5qeTSMtE26G9upCZ/nSKDU2OkcF6Z6hXPtxLDC4c5/+iGCUxb6uuMSFx3J4/9yqwOFnSXmhaFP+po6qJwITQd8Tj7gur5W88RZNffuPPCSWaNXoOKZEoHDIht5N/eTFdUJKnm5SAxSj0GmG+WCQgh+0gyyrhd/NEc1iM3D2dzoUn/lGqEivqOrOfMWlQ7w3nRkxNhro0Z7u2MMQ7VM25UPMV+a9Nf+pGO66mR/HkXbo2PGG4IeyT2HcNNLafH7ZGLjIxMAjogkDDWN0uYsMKWddj9+tLsOvBkeYLoay4NNSSQiyyYbZ3kB2vyBE1GfXNyn/cQBSspwRLlVEAn5q+jIshnfBHR8S3dUuZ6+6xycwI5rCMoOKVwCZGNVUJA1t/nbZPch5sKWisCHhn2ckV2L2qizD+KVs9xMPx2x5fslvAAhk32wPe+6CeA2dHZ5u2oKjv6R5XEks0Nl79+Ucmbz0Ekx3vneBY33lSg8+a/Q+cJCVPIm1rCNORb7CnY+ZIge0y8hG+v4zy7zTe1NiGrRGbjansGgWymVjZnHa7HiU6DyUJri/0DUVeHpx63HZMifpHXQ/vXQzuubIiSHjaNBJ+H98bK+MFL8ShFAXOcUUoBhHvCs+qEayvVAMHtnvg8e9MBimcrh9dSQeDz9d1ZeYYHAaUF8xp8cQNLPaqFAxTb2N+hvOi1RPE/M98k4ClcAiFMCIZ/VYHk5Ys1Vx73l5n8eo/yDKXZuf5LP9ZdDhMGo98RU3HLXSV1bKlSocMv1aRFxYAxfS4VG7E++QccpaBY/QeBcWNno83Mw8cTlSm+fUEoHCRTr650O15zfc/f59DORviXzf2ySlWkT//c2pQnRgxP9gVM9M49/OG9jCJmkvGC+yXkMmQ9n8Rxz5BAxL0UwCsVCqOhDEMNa1lQeRyZuQU4fMPqVJHQXJATIqVDMWHBN2B4H3DvCG9e2B2EgyM2Se3E+BA8S2qvksY6S4IMiisI7TrVPLg0j7YkMPIR9z9+LsmxI7euMEdLyWu5aLs2TMfgOKPW3vWqB6PdrQgJuvQYp6Ux1KDtN39FU8Ba8jMazfSHDwxtI3TeZZEBRF0XjPPv+47R6DUD0/O9WgIo+gpjOfmg3A0mBVJzh0RYiyIdWmcB15FvlNMwSGz/yXQv/rshMDkhmxnbCsiQ9+1CWviw9n7kfe9E7i/SQZtuAeuq9/gF7IYSx7J6SxpReOz6YDslcpSuAZIpTPlNbz+4hiVKaWAHJkS93Sug+OceEVO1vW0xeE4nxaSQ/HDy4fkF+QkESoSQcoSBu8N8iHYJIWYEhbqg+8w0EXqTb/DymxX1lVxgahkpL+YILq+/zkb/0gO8rfNHqGDa3SipIIx0FjhCM0FFtyxdUgYuA2+wYhrtVYmakCBBwX0SRRgk3HD53loMOKNLBZf6g8S6mHLYGUfYOY8dL5FoHLPQCAoCv5fsWyiZ6mdQPD0vZYGW6j0p0JhUeoMh0d9dB/uqtPcWWRWoDtbxOmXZ2PudzddN2oNDClkzD8Nz8KTkW0uHSV98fqjBx5EEkX9cTv/AfOTEx3aqdp2bveVjWEIDVHHp8cJj/+DyxsQIaJEU1XL9wefI+wKExhRPItVJpVT8IJNzQSz6+55Oauu+pbwRA8WYTWZ9sDk/F1b40xa+R3GSvPCO95iD1SSTg3reVQwkwaQbEO/e685ax5KkWPYr06qmgkV1ilHipiVmtIfielvDFCC0JhmVW7spRfPA8xul+XoLNf0L7159NHDpu1JCR14iZJzUAb5BRUZfSWsAhevEmvmLJGtGuMN1XZ/9tRt/gNnlQn7PWHE/MfRufsGO8LKR4PEDsKei4QCqXbiUSPTxXZo4yyPlAjgOunlTnlEAq+yMlgWGyZbFCM7VqFpZliNlhoJoKgEl5L9rvjXhU3XhSUS/hm3ANxfE8pE8uCpVT1+cYX7eWvdNmLBRJzgra2nmxGcex6zUXIRpOEdO/QL14dak97JHD4lX+AfHzvhojdSMjBQSqVforXd1UOLzgt4SuRYvFOutuu0eD2+mYgi/ATSALE7b9iBETequyDoTZoabqIV3wO1y7Es9CURSeXkeRurVhH/SV5D+Wsvq8o888ehcgZoXMO8YBbtW3ZOnn3wLqv4kCBeYkiBKEkUE7WA6UUyXn0LnMyxjc+vc60UBFW121npzzpoG1qKSygQ8pK24CSSdGVhf88NuWNbrgIjYSS40dpInpSuhwIMnT/tA9mASiChUDohkl08Bso4Y+WaBrIRS/0n6uTgmI45bkzAUq5OxLKQDrQX30byBzbyaniYYvO+Vd9l9NI4X0PwCXl5h8Wwjn2rCXgH9hjbDICjYcqSRIc2zVl+Fvge48xZVbcGq6AH5xeSfqR+PaHLMxxKV/Sq4NFHtQJAJVVF0srSA1L/Xs0Lf+55oFOnjnJAYFLaqCSGXVK5GIGnAcm14v/FSRFRFUc+sikx4VtsSJZfWOm8Gk/uT6nj76eKu4o2k0hPRAkaVtIOhkql9mlBHlJJf1ISUaLj/QpBqtWaDKHxhRDBjLb9TqSG8DAbq+ogEtkWaY6fA151NfpRLuiway666vKrRwlwXCy87HQ/L44XOERZlb+XeZqowcJVb4I2ciHpGeCfeovoNVMfTGuUoSwzvHmEV6lyyBfkLIaTTVvNFu9oROl6UWNVoNj+2pfdY2BvyMoGkQW0NWn0liFU6hKGbdYhxk5GdW1kJmSoKxWdg+5WN+coqzjS5YDBMTovHzI3sWFygticCU5r6GvY7jYAmmMUvnLD1tMUJn7M141o1JwUJcc/9gImW0duIbvGrBZOI3UAv2H3JHlM92+4HtrlcGe9JcnFVe5VhPgfzNgvzCc/P+Cwpi3iUh1j/olTKbDHxseJqmVlaT673QpVADiWWNQnLC98YAQGCO9T4ZoLPAtk6V0sxL4KvAp+EgnzsjJotS15lKaMzzFCP2sBoTfADYKgRFndD52KX4GxJsJmFG5JD86thcuSUYQi7+sU7fnBcJUsTqR/S+NARt3nuu8GsZwx0WIRnDiyhTztqXoyhshy0RkoyJ2rcviaSWSMWFL1QGTvxoqkRF+JmXESEC27ThaFOk2YqreUUnsObvL/ZZWYTN5EYrAy/BARpKLPMEdjvNfvs8EQ/pCwEDyMA70Gn4JITW+C6aYF5dXXWzwFLoykmsltJbsm9yv7KTHBeRYkVhAXIBZg78huYTCtqr8oouxBmPdkVUCkpVe3TU86599KaNjh0lCYKrCwhXRLZaa98DpVtPFI08NBNixY/00ab/BCKlBZq1dg35SCF+LPLqPocN1y4zhxGHtyCo6i4mRdWK5Z5c4i9f4JWuorDAe+7fkRnPMXde7yLbm7swjiDIOoxg/yQQTKElU6anOZrb6SLXzUeZxRIpBYOY3nDakbVfmyEoGRP9riFa194IGHsLwWeMh5/gJIzsPrE/3HV50gVVk0vsPZFoQQDouRjba1vSR5EoCQvdP4hkX+BeQMFhJ5y4hzJ0gm+rlnttjkD9NguAQis37aEp7X0BCMSQbY2P80NZPtvxS840fk9xbjNspl31HdmzHAxQK/ETrw5VsaITENCI7vAWreW4/aNoyjvaM9aoCaPYtyC+DnMoOGVOQZIHaCyxr2v57NbR9cRob1mkgrrWrttUwU2cCGwj3BTcpLkWiUrKFJXmg8TOU50vWqhwlOO9arqHkrKV5D4uhTtfwRl4AW39IAxSx47e0Bv4rJesIK8lkYrb8uSh8czTj/ddsmOW/1fwfKRuN/DGgZhAb5OkkUIGZA8+WG4a2l1dMYymVvTQFAFQwXwbTWVhCMuhWuQiOSRUWgVgw8ftUWc7enVFREhH1bPOP8UrKVnGKo+RVtNblcyLYyrL/47iWJ6Hav3hhAmiwNjyXwrymciWPCGMOHSHcetrJ2eccKfK/joF7ByDDH4zBKPBYsEOH8NXkDRMv/D/d3o/AXv9RZX8MNWUBgnW+rq9JQNItL2Ng2uP2hoKrmtBZQv2flqWwPrHFw6yMGQ7fKzeNaMirJvC9r5FnCyb1JpP+nNxCFWUc7jAY0z87P3y490OQiaUIxkrqrz4LFnJNVpEnZyuipXNJ21VjL1gTlPgn92nchQWjM7JoxPTrMIGHSZ0JnG+96x+VjkI9uve9wbOMYvK/UDOF+T9sdBOoOXZi0+Qj9cys3sei8dxERcJevwzh5ByB+tVfbM/KhinpB8yRkLldb6uZpszczIqec9NzF0fF8j+t4K8eGxcuON/fC2bEZLN4duUkTITUiScKiVQ0qZ8CEQHfcvFeW7+WZ0/84UEPzrD0kN/dMKe8l+a1CqMcW7QiAbTBAYkBMGrsU0JOXi6oy3y7275G/bo8Vlib3mJC7FHIAWS1XbmS+dZPe0GmikqNWWjCMuuJkpRleFt0bEd3vex/sNAaW0GNylGap5/TApdN0ian8gtU1jiTz8vLZZSfHnoPCpTOmA+VlMWqcHytD1HM4gvuS0slDN8i/9emX89O1VlUY7wMEkUsAQApyxbu405n0LnST8MUltLCbKGsTM6Fary2z65eh1P1GkSLGdTmJwCAJxtRrIZdGRWF3tB0992EYZ2Q62KQYxFv2wMLZumAnymhdxDAApRqsC6kU7AorZu+nUkJB6Z7zZ2o0avQz43yBaGWWkFBwUgspG/XSaEr47S6O1GzISHeRL792N26adh40uINZUEQj9eb1JUMsZLWukkSLWsUNHS3T80XN+Poz4Val0KN/yLcwuz8NC2E0Ji00E0HoeMYMf3zkxDeWHtSk7IRwdjU9G1ou31u4bi3qbQsCEzdOMaBWdwCWpFwKZjibZVSS0LM7knYY9LHrW9RMHCDc2B58PJWYYUZKlpIcZCUCYRp0aeVMf0lB7lZlKpRVLfO5S5EJ8tvUqq4iIgLZ3jb08dd7qLCsXBJEIpvBfb/r0ba72LolAAPNZpJA2IXPiqWT/cWNrZwG7gd+haydv1KksGhb0olyf+6Gdx5d5H5F66RBbolPb881cbO6Ns9byGtH4Gx80aTd7bWfIhx/duXa5MeZ5+nG2iCAoUlI/vTsxGCd+Jm8WS4g8/eyUVO8XbqbVoFh2SXaBb81Y/6405Gy7WhIfh25RlAGX5lOfCUH9g+aOEAXEVCJ+Px8VYIXjdS/6v+Ma+RncFayiEJaBGjY5sEhJzIiqYvgsElEJWL1bh5DnYOFo8n35lrieKmF2ojLU46u0210vTUUaxf6uKlBxIm/J7R21Ki2Ce6wCUORExX5acKN1Aqx8Hl5BFT95q+4AEUBXYoQc7pfrLbwRTDKpep3jauRHx1zTtI5+HgB25tTF+a+id1Jj8qn5/yBjP+OkRKSwpO82mfGKhdwSuWLPP6oLB5lPG5TCbKMnL7DP/RBDj6qLEhPKtEzzMnoLyBt1VQ7jEwp5jMSxpbTYPHyyd31IcnDGh/H1N1ov10lKkniSx+5ysNmufkUbW5o9/SGpat+T0G1aSaqzxxeUDsRSqaHIB74O8NA0B2fnTpbcadI4xsPwPd4OwVtMqlvo/tMtKnYmwgFmQ+MXXQYkRGhS6DLgooJhrDyQjwCQiylth2/mLCeg80JWxx4TNMog0xx6TQ0gExpQtpdKV/OgEURgFjISbDiD879MhzZCQC3oDs5xb5oFWRo/vgxRipXW0o1z9l2hPzyciaLPk2c/7IP3WP+unrtTYm+g0zCgdrjLbjpPloeYR0KbxnMS0tQrDRbmiBCtM/MabPHn3Y/RyIIurxqodZUx0hH4GYUpcdYWA/Xl1B7sfWrwSV92JOzBdZ0lGhh4VG6D1/8VnJFYNnyeYrw2t+U5klwTWD0OVmynZ6kpxvZEk6Keu2aNSrHuRj/v+qgOLY3kmLGXNwZWnlqYqz8HzBTKfnYul5Q5kiCzo6q4cljPzqudIsfSymB0xwN6+rxzVr8p1ZPVMGVx3+YVymK0MLpv3TCdlIItrIGP50+dhW27ZRlfIQFjldTk+4YIoeilh2TtGHRMG0mvUTJdMpxVKznXI0wq8aTjOVNoaEn8Vn+Sg0Bwl42unWb8UpgeMxQ75mYSf6cDXumrwX7hKcnLAiQswMsMKVqoYwZaabz2FQriqsZsPd00z/1XvIoWHaP9/2OOdxQtzuLDJ9c+asll56FMWGsR8Bti6EmTM6dYVn0KCzC0Ypklqn4B/Ii0sTSffnPsJ99DF0ML3u1fpYDBz4ySuNoUmM2OMQHXsSSw+CTzYNy0tFwn2GYmZ7WVu5SMFMYwnl5NYPCoj1M9K1Sa8WViUvi9PlZnHz4UhM4wnepxM1CkAbBuHTAbWEBe91iDyKE5ZQtaXFOtwQZp3qkQp8NzuMsBC/Ercu9iZsbAWkkAFe1HDr7vxqbkZZF9P5UKuKtSXDJveuEAeYCm01uFw/Fv2LZUaR5rPxyhZRh/McC2+Hg/G2/p+BX8i8+JYNcEkVi5FcNw3vNhL2dS710YBciU4ySBbhCZVyUtzsFmYtNO6flh+hqBZbZq9Ds75thDyjpj6499uh3t6lwsIZ42ngPrWAzPuVtULIZakpB0/D4JJtq76dvATWq3nNLBu0uVohg2YzhVrFsyY72hUPXPlI7cceGk4ImxfZyDjWLqFoGvbsn/qgmcgN6y3gtZT3m3Di6bly2aj797ibWDvw8NLXA4vFC2qTh0o89yp1fsgHIQlUiojwmd2dBTAxOe6Y3WXZoO+xXQK50mZXEwfW7QZo295bfEVmvOGiKrlyNHqTyM/5wjnTOIC67xzouyLSMrQ+98gFwH38WtGxHhbXzyRTltVN9eavnjzZ2DME13iH6dMXWaDyV2BuScirLhF4SPniS0bjnJWxoBmE3ZY9xEJWKZejuSfm7++eW94Kp+Pyl43jbgf4hywbsrCpSM6jSXqexApaFFmlS2R9MVAFeqoS33fdAourNIvls9NrwxahBdb/BlrDtdrIx5QnirdhC4f6GQHSUgWh0uiwb5ROKPbnBPjz0ZfvXR5QPRctiiFizd75aAAVU9zAFMQ6TPnfX/TiKicDEcZPre1r+MjxGgWFxKHpHll5NWeSc+uNNRx4m7wNrj/SYp+1+H/prRFroxina5LXMjir2YcAAxHfoPCExw5W3tt24eRRh1ubX2uiTInFYVasZtdruo3ZfIShFbf7lnrbCsnLgwNFBJMF2cYGktTsmoaIcLs7wKXIe1Y5XnU1buMaVl3C/F6/VQOUBkhvbkWPqTaIUqGNPZ0LsB1AxZvEJ5ZS35/gFiuBxdXHha4s2cdKn6JHH4xTsWpMj12KX4eEfvk1CLIF1hQ2qHJPKu+Tj0CnXI0gakSOX7MQNrFSEKpkScOgxyYrMN5Y6ER+BsP7R/eET4EUqUgVRqtB0ZE07oDwpkt8TrHfMUEoxo7FEMrwyTWiUikQIORAXI9VvNru2Y/L4odDnmT/uI3Jc7qhNTZCXG/B1y9mirEA4Kiyny8Dl10MFJr9jMqLPnOaWyTuAGfAw/X4ExWg/afiROueGMiGjiiDIGm2ajgMkL/jJw0Ici6yFCKBChy+7TlkX74wm79CjtedpTLbgzXwLyL1rKSNr+VeSavlE8T5IaN26kJDYSWvWhhZoGl8c91gqVd3XJTW7libAoLrHoux68WD17YxANwsmGEOq0UiJzGNZD31tAv5z+zBDXmvR1zppiYSe571BBfOnJW+FHlRj4MyXusVfnkMnYkHwxbZbdTMIjf5K/uEOJslsWzsxPkJbzHoaGmQ91rAFiygyGT6SRsuDykbjVk0pAbpi1ISejeX3ZLcWypeCZrE95CukSX74Vp3gTo+GO9Fp+is95+JFSjbPMbRtqD8ID5y/lLmj1jGLRX8AqAa/kKPhOAgV9EiByMcOM2m5AFod/cFz+BFFvoC+EBG8tU6+jot6cw7ZfdOsrUrhzeO3QKOBKJy0swLx2B38XiLRuB4dvM8ZyQrMmNOgYR1IFE1cXJwj+iV561/1IwSHsJZ0AyK1g42FGMQxIfDQzECoVvXXr8KIBIoGDwu1AXdK/hluOnI0uGRd3DElyonOt4eryhTPNZSjeSYrUPlxm3rnrIPAm6CUDO0HrC+L+KB16Sj2pZaBT3gDisnm7f0ouNW9ZxSh1h5jJcDwC+Av0zQhBqFLe8U9JjaldOnBZ3JqaCupR217qdX51u/Mx1YnRXkXXQt7cXbOqrm/FDfSQQVhzvpmhZnEBvN0LJSWz0hNL+vgixxhrwUDNV/kQlARTr17jPl84easzidIJNGm4rq8tApI3/N+A57nQ4FbS9DYKX1nOHazPfYNuRDKkAPcSGAfjZgpYz3+NEwTwbMTJlCU4v2woSSKqRens8zIW9gvt0UhrJseGvUW9EYEIVH4O78KlhP5Hh7fBs5yFf9gR7KTkrDuKMX2OWg5kyXJGywFqnuVLS427wM0ASKQad0+Zu0AdkdEFFwzKNIolB6LPQs+1XWihYst8w2p1iaNPgZyYB7TCoFWlQTLZyQxdo4SXUXtWJNHCJUByx3FS5dSxM6/5QkCulAgekKwwOuw7bIjnyO7FuqwMjaKXWjMGol7w2OeNFSjSxb9WqzxxJxcRuoHt3EKhR8tUxRJ/BG6BMwt3Zue5rakMtGk3D05frzPHPqzd1bJ5Gh8zoJfLz8IId7H4ikP7zoNEEeZ47VCxiTpMyQ9g3LuWEUxK0Y4SJP6cglbVNhSuZSG6fc3Mie8MhnnsEtyioKBYbVswhcQzP9N7NgNT7c5SBMruH6dmGXGEAlTRYeFMuKBW30WtDbDNSL0N63Eqc59a5rP6W8GZoGqkmBOrTHK4x2NPyRz+bvQ2yv7a0SpfQn30HgvJdOdsDFO+/huPojUH9J+Z8GCu8kwa7duH2Xvie5ioHpeVBRNAUOeZOnc4B3aBNyOocB+11MsOiEQL6C2s6xlVhJMSIeDl4fRkL6IjEbGklYbVfItkX62I2p1fCEoWl58opnXuJrC+8ZSLELJMmqFfzlDEchHY+7eJTj0WfmSVuz7NM5wULZfL6LcioFIieWqDl4MQiwpx4pbkJlsKYbL77s+Sfdn+gptiF+QV1RiMClE7IiV3frEh7aFYTly1e21M/bhjE9n3SD5SXdSountjyTLzSXQWVi52mvuWVxRZEhKxQwF63etAwP3MpNhRz2oJU+aYWHisSEMp00d5kJrmlpkKSMb0AgZ0SFysuMb0tUAyetrc89nqpXEs/9ZTXzy8IFur5Tk03mNHT39N4yVgmTURVbKUZ9qI41KczppSB84kC5I0XXQ2EEmdu1aEBv5vwu7WFCJ4IJmL1ldquuSMoRISzDQ9+fvxrMRr0Nt4O880WVDTT5w566czJw2PVqQqWyqh9s6PW2zLReeuNSYxfMro7BtHjM7oxXFKrokaN/JyayXShUrl2OHPeW11oHnazw+V6/vfCHHWa73hJBvaSxPa4KLoATJSYK5jPkrJbAd7Cb4HqvOPgbtj7XzRFEg4dtQYHFicGxz1TMHHl+ZJ0bcHJDhe3gVVqi9ZbK5PXk10ZkOAYHztALcy0Nnm3OKn1tdvXMq3cv/GVAgzFrPjkkyYRPBoYr7pzLlXdnwFiLzlz+SCnhZuxFUfWzjAc8kzGnKjLI+X4goJcBeILtPriPYCvIFGjAoujwbXhhW3l6Wlnen+K9g8aBNRpA+BudBGj72F+s0glIkrKcpZDc5dLxqjs1qNzfmG4jbDzWvtk30WsBgUIfBoPRg40k9Qd4IVGRMgpCUyj8cFdKNpXlUNiLFDJX2JVURCbyt8EjobZSVrWhHhVNZuEedJzqeStWbsivkwcYx7VCFjYBleEVUvicYoQU0VT4OB0S0wZnKqI4/1PyLJRgPRTbq25zwAYYAquaytNzgzfBCqbAdsm4ZjCcv4p9PXIgTvuFWrIwbiq4fpsHiVPX86z0gSZ8Fat5nj6kBweZVwQ7sJVEvAa8+sS/4FtHVMQnNVsKXlkrIfWeSr4zBT2CfpBWqzJ84DMqXndOcM7EVuxaATlKt8H9/wSd8bMpEcT6xM/mlPFSINqccWC5GdXGMRj1/oDps1IVEARPm7JVTPSvOtSutj7/7kf/YS9SSc2Blj/OcgJ80mSDP12o+qPPAz2OoOzgIph80U7jpjKYwWx+WmtVBGM5IjyAy4J2NCpezqqVv4nxjd0FbthFjtFLctX2l5bDJ8HKyrOGBlACdh1FoMevSbq94bN2T9g/WxLjMCR33yMgiqqGyid7Kq4eZXN7fcs6FO27A1meJrwqaLq7YHkFCK9jXBuXI1/pBACW3tZsSRptVQTBr3OGdFGKtifD19tiIfKAbuwQID24xSrGM8aIP2k5a8SjWyaimUXpOH4+1c2bD8nf8kItdL9ehw/0W/BceD9/rbZ7l/t9o9+lVYm656I7LigKYw6QHPJJxN62Jmx3uV0eyKU6n8U0HPHep3M8BWJ1Uaf0+RQlcT/xo9Mc+MjZjLwy2ThT2PpVxck/mHJ3iYw4DBQf6mXgKOMnEDNsbiAfg410t6EiIADu3GnftV0TZSO1sY4EQiLHGjRnqto8oBSOvS9qLcD+/Bm+F3ZajTdwcvtO+j2vVo4dTv8wMdAtlUbdbrdcuawQSCZ6sxwtbP8i8LG2CEKbsYuIKd5Q6HdYeE3ugU7Q5bx3UtsTOgZSLJq5TSfbGFrm1QN3Sw9JuzYzb/4CMr/KSeLyMQVRoZD71NgyNLLFUQqf0/P5YcEakXsqordjlXCvOTNnSdCy3C3r1SByoFVZZkWNAT7dsaj+/7i0RThXkPTt4XPIJW9YmKDTULGFHi/x5M4QOSIC1vRTQU/PUNm7RElaw5j9jNz8VJSIb+5AWf2X0NaUHt5Df2MDeKieC08oC+LnsibhctsMRoD+5LyOoTD/EmC9lN6hrA4/rIZif15n71+oIMpqhhAbiF/7N6JZZFHN8D8F6NiRODnKyKdZOVzokgVyHQNkybXEJAUHGXTPDfxTaph52MxRytAtWvVcauj62JzpucqI3fgfanWbawxw5pHE9xmOd0wJQ+ptFku28iMWLhzjNY+HaOtxxE4eNrCshPEqhcNVRe1keJ7TUohNssRzxhrgg705776cDECIc2tNRTALhjOTz+A/Y0dG+ZpDRltq092dJyZfHbMjhsRUqghEFYj1dlj7kdF74EqtG/b6vVr+/ZGfcQxespTcRfZO9imXMgRjY6R4x91tk6Txz9YhdTKCBBT9QrkkYm1hjElV8rH9xeTlDd+krVp/xzl/rTI1WEWMd3/AsvhrzLG+/aT3ZUTEPg6cRRX34knnvym5eFeNuFAUghTquYfwQYMGe5C+rN7ySc9JHwwKl0PNqwp3xvL4SS1UehW8/DcMleFE8RmhyPob8lre3unAz8wEyYQJgfst3bNyFXrUsqM9LyplOd2qgYpAg3hXnB64JBxam7mjxVir9Ukr6fNY+SEMEXu6ohUDjPsoTju7msWl9J4hoefnc76+ajB4iQiUH4/B60EoJZ3qw8TY3UFXr3aNKGhh7EsQIk1S26cg3lqPyD/mKcDBcqYylLq1bCGWmW2JX172XaDnI0Kc84f2l7Hp3OrAbHrEM1MZhsbM1a4LNeE/RBOWrBiWiX8yuAW43wcVp4Sxwaf8WbEKNCmrAy8r4KKWrDaxEMysa8kkWR9CAjW8xYuNVav8kpkcZKzWs4ig3z6/M/8tfrfXdKkZ6P7wcibmjFeAiivwAJTuZSocuoFJvcT57Dcd484qqLa8phfy1TZ6i7/dSXKIYVS27V0U113tRpAewlxelFR/xqNbGYD/IF1s6t+SsizrDaIndNGhLanr7w4Nu53GhPPJ815O3tWr+9Vb32JbYU3yzGlUq69BtvI3iuBxFaU9+dgBbhlzZUMVv00kvXVicgogGYVpXsnhekd8NuqptQo9/QyeyJdU4930Fk32DgbZMmJOH5075PB7VufhWucOIGZYrCfI7EXLn+JPQ4gyiX9ZfIKMBHsLb4U2kv5khmNHDZxkvv0O6jedCegoZSbltUxs5654sx1lQ2fFIpHb47vDZgCo0w22Y4fLzkZlUHmp1/wEn/HLbOOwbVBHK7jy14NSjsQ1QSWWqmdb7+KTAICND31lJd6NsE1pm1rxMETg4CUuL7qKlzTrSR5TbS5QZ1ZjzwrQ4uyw2arM8F2VY/1Ekih7zde7VkyeftoTZDuNu066G2n/QCQ/LxYyZXHP+gWcgzLkA0qu0CwsY1hcFh4LpDCLfk1luDVx0wnZJg1nKGx+DQkFt1OW4EtRLMg71T/NR8cble4V8OmJ2rFm6esXsvfSzIvmESls0MU7F5TNUW25liMod6SsL4u8b8wcBySgfH3WQzkKIl/cNFAwLPd9cYPtslzRZ548TZL1nL6kmbHkelT6KHtv0uf5AzOSZpCYoOKzFs6twaDTbv4+ePt4pgb78/FRqNCQI/wnbUeIl+zXcaS/MB4wsbTLyqx2VHkDn0/IcJ3dvE381NrfhF7t4B1w5fJEMtVKeBcKmUv+VtYwQFNnz7vwTHYHipWuaGPWPo0M6glXHjL6szEu2uAlULxElHN8shol05NX6lp8OSCBv08feORCQ/Ox2EqX8UPzCPTFd4gCFcFiJ5V2xftHF8HY3+oibHBn1jBqn6idk34W9HCATAfrB4x9piZeHvCEABszhjamDYb7Q1QOTbGlyGShuneQMdNga+I3dMvw4vRggrHQpv4KTjUoXiMxwjc8vzqxwKjy7iGxB5BP8jK3Ty3lGBsytnsPAo+jV1QHTtSnm6diTWFgK4ajZ3+tibfHK59JEYC2Ym8AdsUkN3ZyBe2ZaXBpWiGvtfcWrLDberiSqo7S1KvaVgswM7JJzbTz51AzbS4ZTQNbZMg0srElQB0tAxzPXd2kT17oaB+mZaPcLKlMfYe/0OM2DCVSBdOXu56oGQaIE9b+Q7XLBedp0LbHrOx9wL6ZGzoiZZLaKSjD30Ys73sgIzxbTAC0O8hCJxHsWJ+OA67lW5DBESco+vEwheg+c5cNEYZe2tL2DZxhpi5MPzG5sZAdZ3SC+qEYGcuORf1ysbinMYtzlNry/I8h7DNP5J3v/cHQo6dToY2EM+U55P5lFu5W0/f0ru6EiFnip7jabxlnwvBJx3koe2u6Jn/XYYCqWYPBd0ZtM8cknMxerwXXLFaGw9EpyECVkaIE2D2wxGggiycWufAO51YGZDcRtq9vMNzyCbzV8R2R1R4HyVHLkkbEeBgTObI4OJdqlSrgCuI3Bh4uBl+twhXtFdDrMQxnXLOP4zK8a9/qBZEnC91QPx6att0316z0CJGNq/5V26kFeiKh4efRr66iTCwjDvdJ6qYeQn7T/XkTYtuM1Qt7l602GBLxgBEtHZhyC5XKKt48cl5/ly3xOtchJ5XeZXKU1czPeOb2oBbA7fC4NWf8rEftDLYY9nAfosmTivVUia9nBHcRhDoDlwsYU0dZG3Riovu97CGCefSiujAB9FStGpk6qmlDgGoUme5zlXYzY3Q+3qqUkx77iu8QRiPbVvTKGNVgUkKElSFHMRDq5wSSFFIne11BVWN2a3URcG43mjnpX6sPEsnBcjfh0dIfAfW4ZF2BM0fGKNBKdivp17fKgidGWTDWfFH6iOPbV84tfVmAoFwl07m8JuZqnEzmf4yBMYwVu7dv5viO+6kn2lO2x7nWTCmfvM8QlA9blVbOiCDYwzuE8HkCmWCVF36xUSM/C9POd8wZ/S9HiV7Cc1uSYMadSwBcaN3RqsLzLw49lp/nIDGqnBTX9eK91zPPe6ADOT4wp8K+gYHxa21E7di0jEmij9mPUeGEl4+wBy8nRfkwkxI2XPNNHFKBOdXFpMRuc6FHHm1cAAUxyluBTg8UyeKBDqpBBdIGXfgp76baGJPH4gyTD2kz2QETIczjsCdqNfV4TQPISOsLIS+UL3aBCCddT6NRZLwE8Zma/J4VS5p1py4aiM8wq1AtJa6Bd7jVZYlBP5GwnFhqpXl7pJF9iZ5x7CYNog8ENWuOuydJAiSxBNuZKGRi0xIAhM32lVCajU1OYu6pj4gO7r4M0VJnRUQt91yw5Odq2TEF2C/5t8GB4GGkOwghvXbYjQt3qxjOpcGU//Mjl472bw7buGMcAmPWmShE3zcONvRRcAdYY4Vmbu7K8wUU4ppP9igEZrGFX2+K+KXQujDHYSjnKXVuZIEW6e7bwWPqSwplE0JPxQSHmX1n7lFE5CtXrdahIbYcL+laNB87ysLciPVecQ68qp7Vz91FVYIiFrTC+FumTpQ0UwPaczqYargo7q6d5m+5yF15JA9CUgwnpbtFVEMZYcbzWnmNgYBE/xBNrimpa42WD8UoLNXNyC/Hi1SyixPog37H91QOsuEacs5jtYsYRpIOHQ4FsCogC1C4feVw7elvhPcJqzAoZlnH1mDD4mrWjVmdwa0hDAWlDlBNswlVdGBvbcXVSYmxCrx4NAbXdX8Gzq9x+ICa7Wcw6wqeBtclJNaNQQWwPBqTj60MUJimLBcfG6smIny9wQeHRdhYW3eyh++JYHh2LRBqOpWYJfN/VJTnuO/aX4FenusfgJTqVHJYrJs3zsJ7N2W00O9x1ZpY3stUXw2UBuWFJjZoyObk9YZg+0u55PdCpL5LVKVOqlXFJmuLiGRKqEbbhvO2oehSxnlFUVPw7oZQG17TCNeMVwmvuNkN4xM3KWt0bkAXI/m4+Bj5ltbghpyK45q3mh20a5KGoRQL/GPxNFPLwvWtUxCQiZtLaHU6T1OHs2rKgKz9QXVs29Tg53biXMQLBdAQLpIapWjRrVLe53t61wraTTmZeK+os/J13IrTIigZ7ShNBqHsjyNgqi7W0kxaq+UAtF3fQKTSQPT36LMq6DvlbML0Zw5rs239XsGHkxg6clkvFB85ym8FwZq0WkX8JJXKf97on2VTdWG1twH8IbvizeqNhPMSEjyaVRsVPJnvU/zBCIyiJtFhyWQxks97gzX3dAehmnIA3YAloIWpupwlr9JAdg1xd7klqrseTOQVF2SGODLtPlYg55zqGsk1BuunJYCrvnMSK/mqktjpAe68DKcAX+3v1hbp3JQKEHLGPTk66HW8lrpZJ2VK1gSdGecLi3uX1npXxBCJCMTQOqGRdV+F2JSmFq/7K85JPkJ5h60CeWWBVCwNWU04SCtpPjQZKmUmA+jQHN1cg+4/l4GvhnxchxIZudh4D6ED7B67NHacnNJt1QdcS+DgV4gZiBUer30zmsE3WCjX5rXQJDO0CSHSr3fV9XemLUHeHiIe18QcQ4JwT4J/uaat3iGVS58UUywiiBTUxn2Uv6F+kZn001LGhSjCtC91tiOBoFGBJQB/gJgjcZCSNl9r1X3mAcNAT1SChXKjWrGNHAF+tehCLmSP4CWK4cE6JEaAUQrHbjHrtSan5QkmPl4XsHn9BqW1aAVGZQpBrYvUBxowmiEw2KMxd5501+SKWOKrvk7OgLl0pn0OZN4VKfO/3P2cD/iwLNYvEMUWECHxCMfQ8taDKu4KLI9q9ha8ZtcykEcYNfG8K2DdNwQ2M/ADmKZQvKLgDUu3+Ui0otdCzgpmQuahvdSo0z+PkVNiIIIQu8lYaos/iPlmHhLWMfBy70KS1RyJahOTLbz0VsHPaz3+B8HYAbrp84FU3skEFBRcbDzWk6FnsESkEsD7uCaetHcCjeLyEIpxK9OZ790M53oNH2V4G2eCU2XVQ/I4mTkWSeL7em7JCBSIyzpvZHRQPG08zWGcJ767g6YB051IBlxEdUBabCP/uHG+ZXcq+UYg/alv2eaZlhlDLmH2A6P4WoaQ6ExJip5w6ktYtd6fLJRULfADpUsSWsrKfvRA5SUQ6a0rI21IZ/KVrNWDGKS42101zyu26d3yUI88CtmdqOZMS+McTWTk+fSgOvoYdiXSPb+kHpotnPsZTIzRNSpYanSlgl4T1XTjDelyYY7OAfAex8aPVRi5f0PzsmQu5ZEOsZd38oRorLgc36hyr1zFj31yMOAzCRkEs0JNAbXhJmkD19B0Cc6MTnZzq4u64Vd4Ixgd+MK26mrJxlmZUD9VCEINEiD6UTNRfumldC+xAWTrWkyXqUYw/YS/gUtJ/fhciWaAKG4i3s9QN5n+LKC7H1i3k6xXHLHOr2gtlkPxj+J8HhXhtBdwZO00zAtTZXjFkt6GLBa3oEaY0fWwSu9ZVhmT68xMEJGrJPLQFp4S3twARM6vLC9ESu8Yyyzhwt30MfnAA2SK4OxqW9iaZ0OIotwxXw5ah5cSkBFv2OguXl34/ZPrnqYLnUu9lLZKeB0vyAewzRZ12wICaPygl2Nh6JNmkQJVCkVqG92MF5rdUky1Bi9g0L08nI+qucCctC26mNZEwrQBbBuvn3az0vB07v5cVE2qy3jfOXIcfMPfsQlmI11PTOmIlg9+FoaX63DZ3FSw5KAI+SUs1FuVpwnpSYx+oIDpdO0uCIkZi9aMNsqfgbU85Ivf7MaIo5a73L1Aosl+mJ6CDrzu66GI31afWRrvikYPB+28P+fQI5163ncoEtFkAbW4o2Y4NG5I093HelxGMy1Y+FgBMf5Sc7GGSpcdtQRbR9syc9iOdHEyosU0t88tQxOY6RfGRBK2z3bFdfgtBaONrASVIPAtWx+UmWUgk90RddhPcYBkACi212gBEBFu9FbmpJFC7NPA125wRaI2GVYX46qHWgIpNCA7/nSllO2m9IDO+oYHvGH3zCgXJQEKtbdJoT9QGXPqljv2MVuyUkIwJJBetsmRzE0ycNtWT4hCO+qb+gRLgN9q3mqcREbv+txjYUnqFLBE5BVKgm91o3ySnhjb4YEsoCBVxwYuZubLqhfL1CXL3Rvi8Z2mKXtKYNhmoezW+y2qvh14AP1ieLhliH3b3DIERj2Asj+FvfjjY6hf1TSBurah+gAsPeIz01jYNQK/VMPsaI008evSD4TIGFpQUehr7RLJMzAEio5SxV3AS2yB8+OQ7Zg+iBMdkFDjuk7jYOY+VmBvLJLLIs81ISBzn/bBibeqgvQUWyIEc3xcFQJPkVuuu8TIaLWRti0b5R5lD92iTfWjasTlSzpT3kgCN3Mm/Yff619x3tUYqAM0tuvUqpIIAxeIwHnkCx/LB4ZVhPfWIXvR+k3tWZdgELOxS9NqncLjtVDi2mXnPSX3T7WV/8WFUJFPm/7At6ZUMIPbEp/ioFRs62Lq4iCwTrl28R3tJ8h5rBJpTiqoBvmgKCmluvOr+Rufj+1xkXmTxP+WbvjI7WoAjssOy95wTao7rgxY/KFBwv9Eu17qa9i0hNnWQB+vvg01ErmvHoR0Zx7TQrDKDvLVkw9LWLdRbA+tDZdbEu6C1MROFW4Wf2WbhcFvfe/ItrgEAvcZfs9QbPYww4TMu27Znx22iQp90K7DLmF+wPEhK3czZiUiL4lDwU6gu+DEiirTQaOF66vb+ZuSGrz6eTXQfhWLDkYOnQm/y1Q5fdyJKz5nBjG/Z8/XTKwh612FgwFHx6FKCpeMgq6PV/GDBNqLz295vB+OQdQGaDhtddytQI5Fst55m6Uqoigd/TzYu40kUz3UF26SKTOiYa8oKh7ANRv0jRJcJ2pdnMYlWhKy/O+qnCawoGmNC5i0/PqqZDMuyz6Lvg/ZNBuTz9ku08rdin2E6JjsWiAspfWjWVUyTbRs5ZMWF6BduoumfSYgH3OfNeHWtgBYwY+5I3l1s4Rll8xmera8rUDZ8QXLoH3OWPnHlr3I8nLIviqEOYLumcJEu3MdREKhEDlwxQ59scaS9R/bK2K3L9vhemGzwggGpDe1Av4vo47c0iUxn7ziKSUfHoCRd7k49E5BfskjQTw85kCvoM77yK+GNDIgHlkaBQhnsVvosKXrNPZbTr9V99d4s3l5/o+LU+JvtLV/kNK4AirfjKsdnlcxFZ0Dt24iq5CtYm6v2tgQVmGOkED/TzaUYLneUD7iey9bzezm0BQHZ4MAlmB0v0/6hXXo/DcRjoNbS40Zal2c+T4X94q83jURxnhrATyC0b5q7RcIeS7aDqbrTy5S0zfCjPmtvGZgpB3EfCYyXpaS69dhJxdI9sC41Wd7vA14RSQb6/z/n4QBdCggL8o4QCG0XAvqMkHZtHSczxjBv+/hpcBA3t5S304Ns3bXBa/hJazBFxZ1Nxj+kMMOprgicue5YHR/iKAtV3aPdP0dxDr1X7zoy/0g6bXTYWuzbkZmZkRzFwP+E4kogiBXplEs4Qqod5LIIyC2c5ooybG/ibHhkLWab81Hvi3PxYBR3hXdJhMU0DV2asBF6Bv6WIg1jyMArStj4gAP2sEXDtQwmjBScSTf/V8KbqYS5u0I6fcFfo7wjNqnu8+0rYf2EGmWo2CYN2+e9BWT98iv4/CWOW86GtN/PYpKHqGl3wtIwMQ3q07pIcDoBwksPBM5EKNJGQe6RjfbjJkueATCv7Wp8nWljDBasdTv1SBtMBPGfRmw8Y7C6/+TKn5z5MMVzMEth8XBrAsprg/UFyKhWH3zVLaVJGdAmKOcz8KESORAcRlA9d9itlvQgPpIo0IoAtYwuNC6xg/++HL8jxP32NzdFlu1moJsuqr8fVGV5UZdzA0T7mz6X/bS7/4I7/cc0CFHuxVTpW90vGf1gA1mDRWfyR0u1gpXrXKvyZItL1yvT0PnmQICKPqpkNaF0plU3f4SIjjk4viXLy3YrWixlHAX4gk7IarkYlx797Cd5cp6h/1zyrZipFsYn6PRpYWWC+1twbI02nxkChFz7Ye35dLpU6/J073P7b/v8PQtImsvkOf1zwP4NPt4qZMbXWya3+iG3OKjo4IVMsHfvAm10YnvojT8NmZUXTFw9eEOQroIt4YMCGRRCtz6IkOWpz9Qd19GiesvMPwwxQzLm5/0sSmTZlT1L3OBBrnOrBXcH50m9kOwxr2yLT/pz1TVo4Ag6iEie7zzEVxnWI89jNZXuWX7OytubRbL1YLEGuRqLzpo8Mb6/Efd1oR835bKzEj/fFVujaC8f2W8HCM0VHvJ7/tZhAJqT3XS4tJ0qc4nrEfLYGEzpAZcxW94tQxuk6gfVtTau4CdCKeV+TPgn5qCixxWeXMQGhcrAN67yG2ntI5mQ3piBfP0pPDu2EzT68c3jszHwlyVggch+G1x2nyajssXkQrTy8ymm4HUgUhY/NQMnU8GmlP+KG7XJE1kah8MzPAYw6xOClqgSkVtqof40LRcHfo/QbH4Otqo5Ew3ZWqP+JH9RzPISNUKfWONKQM4cEG1hFWNqSAJ8y33NpwQKScYbCb788z2/DYdYrsrgINJu3bKqbgL0HulXs4657RaqwPaAOv94RJO+QciLOrOdQFvBeppAj70i318QVd/2RXGDEhj33cb+U/2a/3dhXu6LDTysN11gvjYRaWAoTnCE8x2jj0opjoYKulKc0yBZHcupttha0JnA3sg6NgigiUD4nnnye7nvpC7jJYWrkUacu3TDRr4dhw+T3Rxz/OHo+Dz5lyrHRMDnrS+vAbtLjEZrCQaoOK434y6TFAUqIxtRdm0HpL0lmBHBgNA5XZn+9pDuN5af8p52dPy+3r832I+yo/JWJtT/TlwZOG5tSfSCFlj2j8MR+o7LGfwXlp94wAg4CDZsQAdW1IZ4EwC/7pwJsgwHXe+ht2pted/WVsv864+zaCUAoVzE6ZYP/LIlwNG/dFVnpF3aT1QtwBgBu5gGVmss0PnK+e7/o9N7cd1AtP1aqJniTwU5toKk7VmwrXnH9Wh6kJ6w0K01UWs7ushkjv84FZ2HruV8WhcvzBYGJcJyGXB28OfnnjFudEAiVh/8glSQsBQZHZqzz/PBAuHEkL6dfEGcE8iySK+XjyjpVhp+stkvVygnjyI0J3VvIXDKTiyTmVIS3m/68fCXH5CHV5DGiJXs02pGmwF60uxi8+8KeQiWlzUmA8cVjGwQ4YzS5eMKSwhfzOfkZ7HI40bbJBn+RCTWwVfu/83lzGk+b3H2BMIoOtv1TC3hRC3xxvyMlcn6hCEC2u0QNC49aKMAtkrnxkNA2Y8u/ea5C8xh9rPIzCCAnJQBGj7px0eyc18BwXO8eENoweg3l+M2pNx+5TjjInohyc7EmrP2KBQa6pK2ozddv4eFjq5TVBLCCgyDQxc9t6NB/+GbtMqeVdqhKfrEfLq6No1PYSY01KYJ9yW3HoeuVVNd8ct8vEVXdbAKGMZbpU0VdfRrYvC5E7cKTp//U698hRfLDZoF9hVHbLS++ev7a+l/deebi1Z/8UCln7McIRgnD5xsuRAIXtlJxn786GznUlw8bQTsTg+4BUBfRdq+RUbCBc9nFAcALEXnZrMWBPKETVRV2MZX1XlHXHbhjyz+5xPvF/rCocsxyJYMOmp1Cqada8ilkjNo0H8c4GoqExeqtd2hNyngw5HEQDE3Iw7LADAn/eQyyU2cyNIUBSrxZdHULtPhXhKF8vk+VYz/miYAwSeSwGiSJPiOUlfJCjOhgYw8zj3YSlbIny1yy/FNspBKNYnHUG5sDvG2k2qfSfdUxgb2nY0+q0C3EL3U9HB6un241jB3X1PJbOPuQMAK/L10atzfH0tWC1Wups6olg+S6djfIHDB50gLBB71XfrPJN1mTofVw/1LFJfTruNOiUv4SZeTQndAvxYorjTX5TbkAJM96Ms+77A4fbVY+hOrMOfJ3rjfAOKPsEwUUlDMWrBOMhXeTze5uEz7ledO9AnnlQCqMF/akZ0CCVeBnBU9nNoTiaJRh72w+NsJoyIGjV4FWjUmTo3wiffRBOxECVPbk6e/KZWqiWwyyZ4nJUoAy24nkhwxjhVd7HN9J7tXo8LR/1zaz/acbPL/wIKO0melaNw/zIHa9i8IAUvAbXdbzHZM4IAGsFuo6yzQdeBzlabqA3n20V3ve+IJzD9FzxSjafjMH1tIdQYPori9foid8xhcCVt4CROlDlYW9OuaqUC5p6OdydLt4ac6GSB0wSMitGZ4UZ4z4+Ys6NrQ4/y9t1qA9RlOi2NQGPW+onfL4kEQYXixlzZlcLLcSE5dRDUwqaG+9VGyDCf1pcvJ/8pPE8doONJQCISD6f/Jsoix1nLjrZneTgqPEKu3wd40zfMNwgoXrf6FWzH00NDtHWaVzrmhOZQFttgeCz4T9/oD1uVsaOwThq+/s364Gg42fUsdnojcw7Fj/Ark2BmSo55GbJonh0rv9YzPCR06tnIu6mEC1yH3gcOGYw7UltZaKe7GJeI9xtpwtYeL0uLq8OYWK2AHaZ15+lz7BoALJdv3XLDyIqrR/b/MrYvDSsnrGwfwUeZH2ANbAVXUKsXy12yrZUt78JaDFPQI/foeYOvo4sz6mt9snZLSWvO4P9XmPOzEd6EbGVzveN6v2cPfR0DL59ZVArIMN6+0LAMZr2i9kDTjxXV1kMMwGEouhC3YLXUUCOICv9cq7pAoU9WpccYWRQmDMjR5k0VxehRVA+a/ls4v1qFSWf+JBzka7uAHtN+/R6RMFpoayIqZ/9pOl7wP9aLmCzdMJBzplrZ0rkBHSBswiZTop5R4vfjaKaac3AugIkWhWeljPau5sMnwzQzwqs3tYs06Nm/8jCzTTo7wt7j5E8MIqSjOZ6luJE1NgjfmexoDDLXJPFILxA/yvjPEXN9P6wDzWVhuBM6FDTxAeSMCRzaiqhgxM7yEuKpW0mlL3jX5qdcEG4ai2kh4vcV4Rq7xHsxstKQq1+t61LUnvHXpupXkNMvcO/0xWaT+Em+6/1BhSylzoelgn2GJM9IidFN3NDOPgSgMF8qStB5k92qGDNMEZIXy7LFmvd+qFEArRahxmORN6ShA+IvJC2ZuBSnXKRfqCeX7na7uWh5j0Eju8Vb+x0w2suNGdw9rl6kcGHXmbaGxqEx1wY7XiQfRZwDs07BmIaqE4YcdOMWyjTE0ifNHKqxq8JxZj5xA/Pz8NmbL8MScBp9TTNfA/grRZcNLtlSsQgdRH740IQsSc+VQEHOlnWA9vN33Mw0hkYKwFmwVhisMSz3GX4VN+HKGijOG7H1uDgoNfas5+cCxH34B2bLIP4UmWlLDaPxeUnPvZDH7DueLKQJ6lCcEyVm1cK1dhogbemIm34kpQ02uLj4XpEjlWKnWGD0b7Lnwt2uL1MQGLkHCM1a0OWKxIGZ7xLHdBlSUK67kXiwrTpwzlqwtuSJla8alTc6pOz5QBQtaibnI+SoJpRdWVNXtOfnW4F82p6O77NBr6T2qzd86144q0A5KNlDB0AAObWE7oR4x3b65+Ekawx+zJIzQgAkduh1Af0jNKVCZmbdpcBAgEhVGOjuteyJ/z7s/30nxTnKhj1i5oUaZuw+HhWHgXlKtNBKGpFzm0qOQ8tbO+uNQX6tbI/54c4R/BAxgmwR7A1bVwZHbvlTr2B3yXFP9AbxXMXhvzeIC+ria5RRpdHLHgqDLgsn8ADUHug6XusZCdzXLcfKrw57L3Liq606iTMwMEF53/4KSjXD94pC7SR7Gtelx/vc/CmPQY231OL5jSFhsFOGBlfqbHABcC/KqD+8NTiL7mKWbHd3XKyWNoyx1+ulubpxsO1CEvvOV/zNtdfP75t9BtQo1SqxjeV/DQ1XocBQACFKDKOau6qtz0k4xJ29sIVc7xdZZ9pt873dX6td6Cw/YuNSCY+7MTYhTTycI8KZq8l4pRQlnVPIw8QDcTjop9MphGND2D2+TLbRp1FIsobu6ql3l5iHQn9R9KqgZj+1sK9VQzoOfKoNttV68znR9eGHKK4ex+5lkCLmk0nrpWRAadjU0l50al71oDNf7TlbRJAMeGTw14bZb1IvovN/qWVIG34Vk6TcYuKgyV9jmOY9lY2f3X63WL+LTaU9zo/W4OAPO0OSFcUf89V3jxCvyJXuAqcZ28W4GWFHg3bZNqnNM1CGLzbmXkao+fcU9yk70NfnqeanO3JFp3zLSI4NchQPgXPSAMOvTDcrcq5uK7xc+w5pK/ZBrRrpfXXHiCYHKx1BcYuLdqlQoH9DJIpiSk38roM8i8v3df+lvpsyG+tT4HxpPHCgDKU07cYv8jhyc9+NgS9VOWFwU6NiAoSAVnKj5K6w0KLfomo1yswYCSXbd1fj+RKrDAQe8dMsDIEXGOcEfbbGu+lgjL5rJ/jqJZQgdFKXK4n5eYLn3qXbbEHtdod/hzBWh+tTyfZST0h0Kkg8thDW9l3X7DpTL6XbDjs/cEkvVyFbaUf/TdSvxnOu0ILn49Lm7TEr+/joL4t5C95uev30KtoWURAoiYkflyufZeMp9kz3kGleyCU1rngSSX9O+W87rCniA594Lm4VA1owWvbPklXdroDufmVY00dAXnzn/rSHrVkABBc/JokaTnJj7Jq+7q5ZHjIZGXW+T2LwVynStJ7xOy0ku6lGazSdhNYs02b0Y8KKtsj5SZKYD0D2eO3R3BbR9La4E1bhVjB11WiZBik9R5YejRY5ZSOSWHnycCtWZetkP6mfwajwIIdmXbSI2j1+GDc+Xgc7/iAnKipJOw5QSWUHRfDBzksKz0ktO+BybKE3fd1bA+9yR+PA71mfH8Ycq/FWHDc69/2f0MA61ACcLb5ghCFxJvsknIY6VIaJrrmIu09i/tU0TSAN6IUcMTl6XO+gQ8D2+hW7ksgkAspEYI+FxFvDnbmOn/Wi08SaIdGsSpIm6QYE4uNQyWhCTVtIwsOEwL/guhwIBP4KEOQ1tZA9YiLdMZIecXOh3RsQ03C2doUn0/Z8R2yljsC1RHNnFHJpEbjLlpSmi7Pxjt4rbqogCDkwbTUpbH71uHt6JRwRSVECQVQHgGHL2+QsxiJRcl3UxoY0RCIfn6V4f4kdEZf2VWWaw+XGhAF+ncjOe6ZGDBQNAcVbv3pkc3sWuPsSkLj8Ep1cdvWDZD1VZWQBZcqpJS9bV61cdkIpvSwsdr2cwoFNSWTM9u9RLtU0SzYIzmy+n+Awho657s91qxXjVt11nwaTa2Ilpso7iOFrX2B389aZyycwKhpP348WCQOQM9KpMvf81FfBUzWwJCGqV+42aXVltKC7dAtebe+reHztHvzlcUiHq9Ek/IFm+piBBnwSHzs0rLb2i4P4QkOqUOsvPa9RF8dwHbOsOwch9hMiXEP7n+c0aWOXunR5vdCSjh+smMBTNckrDAzNy0qsSVSwIiKlwsCHY7P8dz+NwMlzkhAhQieWDabJa5S5jiHKKu/w4TK0ZbkBJYiXjECZAz+yZh3jQkX1uyoSa+RThCk5KlWmeF+aVl0RGHca6IS7uDYdXRJRwdAvgwE0Ri8b1d2T0nXzbaown5Nv+mofiT5Tt2VricVr5Qt0ulVROA2ZqZHYz0TDE3nAMsLp5ql8AoC5ctzHwkToSTKPoblkmW2VFPnDSpTboTnz6Wedrpjak166xa0WVZZkBn1tpmknk8+/pitCgWOYp5OEY+fhIaqy1StlM43fc5LULDTSQq/EJRvgOAQAE3JYIbex2WSbunN1TuYnYtU88WPQ9FChrlOZJgRJ0G8QMxUXlcXbPc7YYayn4IUh5KBNv2HXlyATnok0oCvBegxgaUmsjnASgu6tby38sVhcEFi4vWmNlPvR+e/yzsH9LZUFkbi0ZLhjBkDjCuQ5uInaQXAyhVYrRVF1AlbHBuSp+tP4eDBsP7AEOpDBlbty6Pq9MJk1e3jCVtcWXh0I3aWqfzdRP61PxrsuoOheSjIhA3vHv1J7BftULSaaWpmEttUGmo5z6SjTDJ6RD/aTAtN5HDngD3GM6FAN0C1vVLRbmSbD+lNewSgiduyDvED4CKO9ByTCER5uU6jwYupUERnDoLv/HzKqB0Hx8+HrhED2W7LdV7x+RCGDuyXygqAmkmYUMi56ZCEURu6EzGtZPMGSDLZr+OwbNl3KtceDt3QJJ3RkonlSetPCH8s7j9sCqXNGQmJjC/2QyloihMdcxRPhwcyvdOIVTisim70J+ivzkrz8TYfOsaRtrrPbUDpIbI0aykt0WW+7s46mSSX2Hh3Ayzz42QDJFlMI0f/phKLFOyqcPq87MeDo6rOLsK+r2jlzOp07KfYEQf2nd5KQI7FY0v5EPoTLLdQvV7FL8m8F5YlnAjxn5Tp9XR6NTiSX/syWr2ao3TXYgwbama8DkOasnCquH1mG8yrB8RVIQVJWuH+9rHv3FqxU3XEN0o2SPwolRXVAFqOG90vIkJ6Rnm6aFUYbWyCropsFFf/95IZ7zwBRvobs653S30kQ8SxPYqgzRRcZbFQSofdIBuer3Emi9YDt3+od6L29mHShZZyGyaUtySjgD/UKl+6QlMs0uqzeydm3BEztkP1uz1EG8IoMxNWb9fxvBti/DAAVlrZYCO7HCiZ51vz3kB3gDt587UWihHPcc+V9GKRyg0n0/O8lKpb3SvL/cc6UQR6V6ikfiRX2LHQMtV2S/q8EumiwFdAO6/vtGhzjNIff53immQ1Ag/kmm/p8e84xaiiUKiwasteUgjxbOcYlDv7GZkgBjklMSUe5cQjnya2f3xxi1+CODveOq1DZ6tk59JIPElvFk1fwDq+Rf7XussQ5ZWB2bURUF/mBKq/3OfZoMMV8it8tJQTxa5VFzpqCYSiRIVXUcm4VISqKW7Ph8nVWAl1ktlqIB3JsY7SzJoyQDO8xPmpbyg8vbzcsjdYnkz9y2E3K9NPbvb1aaYT+cbGUS3vTcOsGMQtK8PsILmAhGPNgPggzQSwv1PkmOGJVl3piKUhDF57x7rrvZ1hlS9OabhlaOrN3EueOB8ZnAZD71L4Yxk2tsWMsTtoxSCRocdHr0bDIVudEQ59ukGq+zC10krJ0t5ajzCnCbLQMYe/HCmrOSxr8VTf2JqmjbjMme8ssl/8BuKurY9u6SxOqx65fvIwUZRPBv8V37utSkmM03j2zZL1XU0tW8sBAVaSQM6o2/I9iDmkjScY4zhWZc4vXqZOgw13ndfSnXv4E3G8cK6KXP9BFtb67+I4hKpxlfBD6kBNGLLEqtdB1QjPy+oA40QMEA9LOwnVoVV19dNDfDgupYQlirdp2I4TheZICIiLaxtygcZsD5kP5rCJCU15lDka76u+Vn+kLPPYlG3uOAuXVTY7/llQ5SKRjCwZ6MD3GvidMbAi1/vOsW70Pqiegc5B3lEHuyfbSZg0CRr1ge06vgYH7n0a5LY7xAuTgIxX+RPiFYpCDH0cpx7Dtxo8lvyvmdTldIu3oYP3TNLNmtvcHeLmc2W9Xbh5cjliiYY4tSfD8elI2YJGQMsLCPZ+ACgg66nPjjWLwfgM3SM3vPUx0dhanWUyiFjCK/oWtgOAQwh1pdQtW6HQJpHugnpiDYzIiXC+m9SOITAauph9iRAunEFeq8wXtpiiQyFjNjZKaMxURQ4buEcLF3GeBX0St/7Mdave/HrXtHTGikbykzbu69r2+76JlMaYNtAwf8c+MRundEo+CPLqk2Cp56tIZGzKORroSBv8VZjwReiuBs0XymmNXp0ZodzCDK5bDrBiEjNg1gRwOS9mw7JlXrgRqRAI4H24NQiAjj5ZlIi6KjyWHrwx9SUrEQlOYWtPFWEBbQqFPZr957w4XaHRS/eLk6BCBtyAzGZeVxrfUv52nFSleGbUDWLGnlVGLVejEAX7kyqOhIgcZwlWVLf7FyuNtAP1r1HRZOAuzmic7sgA7avlZ0TtYWr/sb0A+7njnBlmSfd+QUW7FTqQaRylw7uYfBpQVb4lSYyxbdhIFxktBtGj5YUhn6SFn1fHhnk/Zj6G8z4F7nx9LI9io1s6Hifr82FnuseOf6KQhN2RJ9mhXri2DSjVbjF7SVmbGV0VoEqrOLHg2RsVyHcA7W6B2kl2UZmSmxrT/Q+QvuB2xEuRpcHO67S0u5QibarzrcHXvyNLnB2nt03rtnO9q/UPwuYVFcig+ysSZp2Cc7q/5XmRYaAzPpnr1umkbGYXkZkihZKUF7sl+Flizmk6nl+1zM7ECg6jNgnskIqyFzNMAMb6cN+l7z2KVb6J262acVoq9GVZIp2v8UgqUGRhmGRQ9+pOrdI6TztxHeovO4gXc0WfzaMfXKYny8Omdsq+b+JXcKHtGeYtUv++RSSBBIQW8cpMrdwC+D/xaFQuhhV7xkPv0iaRNE4izoWolsgn/0yI5bpEmYjHd6cFU2mKqUEf4BWboP8uridZM9b4mEkV41nUsbBL3zb3mcw3yKCtTETbEcU6GGWH1VXeFLvHB1zF8fAwRYev4MJAAXvsfmN2RaqJvAX6FoFG/A63sCl1hRcFyEeiGiXC9ueumQzLMPmstRgKMdqm9xykkvx2X+2U9d/Nj0V9fMQArwbh8BRexVDc2MfjS9OtWXoc2tVTaC36q2BlCSIHhPUhn9Ws1SDfJJdP95JHI3jwNzNRgy60+ClhtKZ8ARcJSl5puo7EeydjVr8UCd537xPvZXnaSVu6e7Aw5vTNZas80z7jQSZbvZ+M6GjakL+jgR9jOL8wSYaQZji5f1kFUTlvaz8MUM0fNBkPNYI4z+wMww6Wwn0d5TI1BJ+rpQFY8gv5WPmiXLU46hYQ6rZM60Fn/3f3Go+ChJF93GR3LgThwTYi57pBxSxT8yfRI8Kl08QzQMRPJzLvmaDHcwbn+9+ZJkRHWdNzusHRTvFhhAfcqdsEV4rnI1hJcapvNmAu4+UwWthTZT/5zotFFU5P3ZMbPoHURhZnJi0F5Es8CAA2k5kFfxK+KFRL2zYrXjFt3rTDaBguCRByJ2zeyZGTgNhqqkc1DHAzgC1GUBTrzDHesOjoJGL7ZBsAZhKTkkWdr+m1Bx2jf8VaEsbwNoyJEb6kTzmG0mICFKQdH5x4zPaqOhHIi3vb/NjddhseZFfvnJHRaJx6S9Cna1Dl8GVILY4pC9/h2ALz1ORSHaV8llPYPpWl4XY7JfMdebA6jJNd8x3VNKCeoPVDClg2FcvRZ1v8qlSkaM6vAYoo9I1PAECUrPZszkQSNba2Rd6Drr8US8ONXQfngw8tTjRaKgJ4ROZlYdBML7Oe5aicudvy/eZjeifCvQSMpQjE/gAIO320HrFGPFDZRpamOKK0wl86yESyzvG89txixtg1A8Vvo31ML12QKNm0iW/19R8HeSIr1Qw8N+MWOVotDAcUXoQroT7P7q4zwN/yWFitBUR+KEoT3xv+Vt5HiOoyJl9K08MfhmH7dBpVKnYosaDZQdJjKqFbZFFkz93+kVElNc1iqikm5MZZ2FajtfZcrdc7zJBt+bRwfd5Nckld7hJIsrMYHzzsSySl+4kf+eFJQriRTsfIQxW9V8k8bMLJ5K5HXC279Y3Vw75prFwzTy3VcQGXkgDK1PnzoyOhKpUrTrTc4OzR9CgANwWIj8UHspS6TBYXO8YqIFYPfj5kPntaMHYsKIgpepAz7p7Yc7ccmcklECf94nOBBgS4hwMd+G5hsW/gza8mZbiF2fcmIEKQCzzrRHOjxR1Rv+6mH26mggwbKBTKYrX3XYDmPrQdyaASyOmLC6mcKfoed9we2eEfUjNJlNXpm5UON4pqqj6euaMe9FdCowI1F4cDHbSZe6dOQdT1AQbf3nbo6m5vUq9UE6xDAbQYba8fQ/xoi8ZAc+skqFbReCapfRipx4Kgqq8c6RHxgBm9SC9EzgJqHBDRrbDd4pBl7T3DNSSLkldAFuNf3+hvvFxVE9D/zlDXOeGyXngYtctJlCxO6+MpZxFLGJlKy1XXDwn4BBe3s5nTE2XHhDZguxGO8V54DQtkuDhUndiN+hw+kc2KYkIsFD186ux0R/fnAH6l0HfBv68AswxAxsvCUZXb33rORht39YWLtrC3FdZX7Q4MeP4ML4gGlvvCA7xLJwj1ptiCo2C99itBKJQzIMvaD8h2V8TepX/fyoq9TYvH0qEWgZCILSjwjQPIr14DxqPBYtwiwy9Fwtvd0vMnMbldYCyK7G+jSVPHL74yGbv6rM4f9d4Kmg16aM/gmGu5uZ0lZP+65RHtUlrSoD6eGz+2tktbqUCTPFny2L6/zyQSg1ttJRVfhd9/GwAANHZUVd5FX/ygpucxWVSTQr6y/r4MYzMbyaVm8dKY4HxOcYXhg0ob9V++COkAE8Hm/jpJSuPOWalM0HBvxXVPNXNqsKeljuTIBLXLa9QeUsYfW80DZoxY7KYmtqpTqXpFhJK5Eh1p+8VmCi5g933cO9q/TiCOsR/wKI4SMTyZRcGaazGc7Ef/PGc89F8lzo9NtF6NwGpCDEY24Nj/1hZt0r6nOX0djLk7WaoxyfrAdubcfh2Wuaer+M5qu9I3UWVkzPjpyBSOwFZFEPfpkj+2RfxqHxfQz/dwgbDroPME6xeyOYN2kbmHBj8Kh/O+66qxn6tZqecrQ+3EBfElDuXCYUtil97c1ZN6fnj6bX/J8SRbvbuiSU7TQci1lIe/CvUoTz5bBv47ipz1LdHCTQnVjIqXvfCUnKqtNew8zBBr4PHJ2OMpr/jDMmXMQjQevipx87QpRiv0SYNr12R3wcmnqbo9TAVMVd2QvhiNJYkxUeV1RZMAPhj4co42RMVHrg2NS0CQPP4vwcOjnUC912Iz1adUnVTYosJSf95jmofqRLYVp5lPX16anCYV3RtwMRGQtWrXKfHuD1WGfMXhXe2kSbeNBXwemo0tITctP7AGUQ94Kym7WXauCUnE6u6ffHsGr/JH4g2nqTXx/nWqqmKAlmRrZCe7qyfD4zznlCaboeKqAKi06oWD3PiI9u8TXBklQC8wSTeiLIWg05+mzH0T9Vy5uVe4E0ZJigvvqIHV7cixjO7dhn2xB+uieRCEflDvTZ9Rq5CvToeN1SOsxYWMinwq1pGCRd5OGIJJCIPZnoAAHZu/3gXc/dpd/cSvikdkHOT+/8kQgOpIS247I+8zIror6Pk8GMvrkbzPx7VOcB3zZTKNlQZpOAxcf6ZVxBb7NPDr6cF3yglghssu7f38dJWQUSth8ZhNX5mRvvGFHIrnittlkeysEVedwXIhzTlnS3Pp+6ctflscwFTVNAbLGpXi/f7hxQlfMqipMP4T+XKA4Kf/wkXcmQGlWsvPb8aa7qBZ9p7QaN8PhGxtoSxMCKC6urrSvsraFPrqr1ODTJvZau9J6z1N52C2/KXSYHX77ABSWJj6vHm2E5ZsXxBC0aSla18lhgadXKk4b2cFhTSzn3RDC37wriTD+lDey1SULKr1C4Jn6o689boj3ZeGz+T56xJ7xRd2C1hF2I3FYSGliSpa2ZwIAy09nTEvud1EvZpDY7r+yDC2pPtfgWjhr1BNw6HKNqLa9rU4ufzUaldRF8TeWEK7OsvKRHqo3SWrPf+ylSMr8I7kZDRU5Mg4Yz+ykYTjzuH/+blEeAGhNnnRC7xO37+flnC2Gfg6zWttxjcNRXYnDq/cxoz7Ooh6Tzmo/6FiOhEU8yUFRBJRxBlsMpemTOlXxgzYnvVe/mDYfT80sRrZSwRLzPGbEc1xQQ0m6RMQJ7VW8RVXF4PMRagyA9qBPS4H21Tb7gzN2+3b5W5SZViD5YGoRQogHW2XpOFcZL1V4Q9LRVchcZ5R7oCsOXdX26KEHn0FGcIYQTjYtFQTyBo9krQLUBsOwmR7PaT31lqkW/sLdUQTgRCqoiMHyzHJfS/Ga75hDaTd2sHyxiS1lSiIuMUX0BQNSWjry7QPg5SlDD7oSu/qUHvbg9mLKxBlisQE2tcmT14MIHxno0fEuvzZ2P+agc+379coHuZ0T19ic9qULvrBr6YtteLtRitcFKUgbGvxfWHlYn6PqtbAxQ9cVjsmkPWXNbdQ97hUXkcdy+JCyUz026bcbQXih8CJmGyZARwS18acGb9vP4Dv0fJsEFCJiYlQlnl3wb2H12H+a1JVb1hELfHAdiuGu1H//9a8O99zfb8n53VvE8slbv33HMhANVKJ4JOhCEHNaKYeu8zhDJKh7pXclLGBURSPHeIeAbvKYfwodr1Vh8rD6OIGZQ5qCWg1zAHtqhFrkjEee1tbN36a1c9940icju6a1L5vNacS06uqoHr10O386tIvIVA8kYa0TVylVm0l0ub34cR22Em3tJwh12aRAGn5w27Z+7uTL4ZC0NgheoHoaMIP9k43kz1i99H9LcYtjFVL/kTQvWo8IJC3vaKlO995Vkfu4O5tVC7r/oa/l11daFhfLdfLNA6cV9/MfNPcsUyxd6PEbgiM5Skue38hslULc1Eq7KC9ZzhVxD/OC3tMRFkP/myKM5cLHBjKjnxd5sZknG1S0pujb73b08TxkjFP3uF7l4wSveYKJB1OD4cK6eFuymFTMrdi9NNrCN+ezjH78nXYy9sx3wJP+fxoEAlrXhyG4Q7+LIKgy74S5jzE2uxs/eMmfmvBFEuFu1BhGfwL4TQPkRNG6ZR4XKuS1k1zaa/T88IQ79k3hFT9la9W+GScHaWib8IjdBLAi9CeqqKyaRe7rAukLjsdKxNC/2yF/nIyoTqMhs5CiKu6ixwwa/grIPHdTWs5xN5olwSbJTgqEjrMfie49x042DL1pPMnZ58WiCl5fDeDDMCnLoMZVVX9AbyHdXU0g3xrv85UpQdtMafKTY1LnZfNsuX3CE1Nvnre0tgjpoXO8ROczZVkiuFtP+CkViTweAfot8p6BQRuW4MUPG5OKIqqn7Y24/Td2ZJIJNAJWtZSnbNqs5Ub4YY49XKq5whOtfcRSiKfIZAozbzRCYL5ALArNJeBHhR+FsxAflzR9Aw8U6KxJVk8Ue0H4fynDSEKdS/OTT1weOpuzzEGWq6Sb8Ef4d1JNUPxqyKUO+WOHfruNSIR91lqaOQVBs3qWUcqQmQL6M7iwV6jd2HlBZK4acKivpxLHuHBvhfPwSPGNWvkyK57c4GJgqj5I7fRkAKBiorcOwPWdhiSvn9zFOft1B9ySOK2a4aOtcC6yylqmdasU1wet0jF6MnecEdnSimE/Ye7O9jP7/hexQnmkiO+K9PELr5o6ytzWyGhJPxD9lrf7QNHCxYbuTrZMNfrCcyM0AaaYVUq7xpzoB8fG44Z7mQ/MH6HG6BA39JW7+ylBt3NTXkvwokyM/kr2Yxk4llDoW9EP317iysFwqCKGGbpsQLk7QnUxV4g0qpYjZnP89qenG/MyOQjPkOpa8e6jy65Eiy5EUl3oHnXvL1wuG0ztm2le/DLSXUMJlna4Y21SYw43MX0QFBxXGMhZGcaozxxCxKMt9zFsm5J8pWAOOgGMUEJlLLdy+WmaJVuiqVj954jOYgiW5iSaDo+a8IhOEUmylJbXFpmEZloHviZTM3WMdeN+krforX7f2AmkdYnOZUBmXYIPrqgFKmt7KpORHD7LEo+BNKnvYKQa/YoLOwv/0L+qvEDkOr8aasFqUvv3kudd+06NZXzvkVQptq7s9HGX08FjNeIwahbOdhLcqc599TMpmTX/nC4DbmQjqufEGhxDVprYpgUElK0gOI40lp2R+dB+t6pAWjHWDriDAsnWwmK7T7wqeVH2sDsmkFjqiBCHtde4Hz4YUaJP99RrNM4eTi/p5CK1Uk/piTG5bFz8H/5hV9LyI/s12GLbcg21I3OAq3AHRE6ucTs1xf2NxPN7adVoN0xCb2TnEUk87EGWGSHQEWsLpRxh2V4WKREJ/x9S8l5hzHhCAOWW5wqOlXpXE1IAFkKECKHqhX4DME0x8ZMXaB42Y3DtX4R0+Q+tqLwoh1gwEEXaxaP3cAZ6NlR6c8yfu79DQ9msWeMHD+DwyFumQGtIrIUpuJGoxVhC+kh0ug4VqI6pl7wx0yhkuQaXQph/0rzhaAODFT229Ysdp0q7dqdsCJaegHX2SQJflBDHbys6nJXLlOxl7eK3yDE2A2c3jsnMzLso2bLoofwEg9FAy/9Tw/ikoth5hVT62B/8IRQlRoIn7DJ/xKJ778ix1JXB53MhKNwaSD7AHN+dBMy+i5/28ghoc0rc8MOBzDQByvxhqIdjjvLFE3bXGAPvHybtiRRJWX7qUrQ6YzuhaHydownQ2+fSP+xZPVXa/m/SK29QjT7uiTTbP4S0dfS8HII5NYWpiqePwfrO2AJz4Zu7tDHZpWMx6LMawh3DGonkAm8WWnrRLsskSbpohNQQLzIMPKYQClWZMGDycKgq+TNNzwdn6Mg7TgMq+tb4XB1dsuxrGnDQ77j4fPQ6DRuQPikO2tcWN3yXofeyAe8CdX7AHGSUib7AwxWGuOQsGrBQrkJEgL410w+pdYHgWXHxik+NaTUq1OuWCnDWYbRi/mpzB3vKHCNH9E8Qv/ucZ09v3FEEoJt9j/X9eS0apD/O/VI8HTWDgtDw51g87dTG8VV77rFnwkN1Iyz2vfGsBVuIZHgUecoJLt5PTkPG2ExgWtgwT1DP8iszT7dMSvnweF3S9icjvJkk//PgwAtgdIOjVmjP6U44oNZ0RgNM4zg5tEKutzEUg61BqeXCrpgjPW1zEZRJakN6CkJMZOeNO+50Iz78JCJg/Lcsq1BmSyCMUdexCwLcdPfYmzQMBouLhBZu9H3P0LcYGYGdoDdMyvCId6aZHxCP1+nkRFM+GBq00WEDX43rW5r3vL+xZI6v3rNslR7jKJEnHwjt+XZ9raEgKZSpjU1qOZft8aPoTf3J73EQwMKLcHryQG+5SpiuXy+2wNOI8syXwhhj5ZF4XeM5bML5QlbVl+FPt42223acPLoeGZvwmM9nSuCynlUMhgw32JrDSp9Z2m6uie2aIL9r52KTqawr5UxnIjQoyCWcw886Ye6lBmHC4mayrLxDTQAKaVEwkw0tQTEojGBSZ7CKgk/2xFB/G4cSsd3t05nC7/sVAXAVUxCDpTrpK3JueMiGgFnSd1bD9n5lSGOsvvWrWkMjpnCNYt4kxUjWClIZSB9MtomnWOBa7LV3omDy689sebTc2JQp+4gN6s94fLWSYMFEcOJixk3qOlqDk9uguCBczuJZ5WM0uQbDZ9HvwmScyJ4ag6e8pVywOLsYbfYyE32RZtq0MO2W5WB+1E/mxhYjN8BrA+TUM7owTnOi1r3P/qWmwBpfgC+jyNQyG7k12BahrfBhYsA/Orux6xZzKfcNYowOEjbJ018ymCVi8l8OQnCv9JnZz5JAgsCLFp1aRNRuRI9KmJA/s/tQLUwJK9iPsQuVgtR2dsQOT8F4adV7pPu78Jnaq7ZD6+rZa5ijaRAv1Y7oiwXfSwwLEXCKNpVkGsSeimN3TYqZe8CTbQHjdot75ufuQQQMrV5/3CRFTKXXtTbw7keGNPvTPvgqlUdj3B3mt5OYqqGNR23oaGosN+DfPfewbuATKn7TkDZF/UHoyNhqCWg0nGooOP9kX+h1B8iXk4Z+DzL8ffKfJMlTxR8LFtrfToLE7dLLSHtCoHSpDBLWR12FWkYFJHD3g2QbQ/7FGcBzFzQigeOof/tMKqDwTQruQAg2CAzKdMey50BgaogOrcdJl0vPyVpWVG+DNmU1D0kK7Cc0XepUP3hJ7tkzh1f5i0nCKUMdTlHgbCeecSAdwENlGiweFP2m393QAZaga1xU30RMR1nbjOTJ3ZBOe1SRcZvo+9her1xFbSZDr5fEGKE3hEflF0gD6TdDdBB9l80xxTTStQ+I46c7aP36z/8RDwb9Qj/NC6GUNdR20rOD5ZVxec8Cxc4W3+zbg27HjQTMkpW76HypfRkOpFE6tHH2l61b57vv1Blxo5n0pavPoTej1d2fyKF7SOBzK8o4tVYk9CjPFa6xZax05Y7AJxsjsObPpt3XCzwMjVkAdf2Aof37EVeGt2GUa1nv4U4ZZDSNJ1E/7+PEs0nRhZ63VrYGLO9y6HjIkx56J+LiTF0casn+M53g03doOSewPX5uQ26UKy4m53u7Pc+28pCl7lCP5p7xgi2ZNPiciw1kDohmp+UR7EY6Dw+XtIGYD7366aCdkABuGY28nuN2TBrPgT0LkJxwWC4MMWUJea+6iL/yFPobIS2Gq/7r8bnkLwjAgr2flSnVolUTCfDafPGrk6wxZYSYrB45K9HdNZ0YmOouA1cjXVAIgmVqoWoqGbf+ScuMpkKAcspx6Uy7egTnnY1igW4RqzOTtWGklnDXwjjphXszmM/sfzasSahu1LrVOc+jmmZ7jHpe6ikwn5exUvM8vGhqW8SIEcX3Bjq6vtKgUJGkT30dAo1r9AljKpNNsmMp6exwMTLEj0vFSWu5pFBnjyIapKuJuedvE3IVGRiNnXt+d0LeD+L7T9DOTEgvYxrG1SsVPuGSmZfWviW9sqXz0JkBTPW8U8bAN2yNF8RViaG+ALayDYNSqRElNAQx14RJzyA27eg0wh0LaU5+N+T+Ol3UPj/I1Tyrz35V0HqoESebyL2lxiNBvTVjst0qKKiRV57kKq91j1CNRwKYKK3Xg30Han1VPPN5gfxZKi+XklA8j/RTfSB7Cm/PWtEgH8Kospw1RXm64qYRnVdV1g+4BoQi+ooXZBKJnYaTnyco96au2T7t36Vx2cHiVDSjkFHnJPUGtkdKtiUoL+peoXwCeMvQc0aOND6tAMkj3mKYuzIbNqfpK20y2q71ekV6Md6Wfe6vRjXjPBdwJ+ZUK9BQVdqy2uo+TY9On4ZrAZ/Fg3rr+EyIEmm20G874lLcsbaAOBeFcOFrLWqHRYw8WcuFDef/Hnnmul34S0e5zoXtaUZVMmIRgPJWMEzICbpIPd78w+aVziWSiczc3il3RliL0snqHgQI6ouioz2ew+KzZBSuo2PpHG6bcxPFMDZre6UBUYwoq6RpGmm/X63e2hZzGMJ0YEqnyQr7wPftuwIquEra01TJrZEntSXQnlGmkPIHEAMUP2+uy+lgrJpQjilycxOfdl7tgxZTvoRn6Ru9VfIhOdLmW18bO632gno5/wjo7d/B56MmqMHFHBoJx1ymEviP4Arwbl/qresTjZyvv2Gscac63qK/SrynI9S2rjy4oT1PtVV+HiLo3z6XGcX3vqdrETBzYGKhsdTdUmi8D07bWbPy5PS0SG/4czsqq+HweSj3f9/J/+F70cW9Eapka8DvCck9NV6zSft7QthAz8fIx5XGmF5eU2PLzUDNd++IE22wqM51g7zAiNMasOOU9MCqztzW8YXv15ieAiPrdgYz0sAOZ98EUfDEzyDX5hqJw2ncN3Y+YGm5GoGnYAgl9OLniaUdc0fd \ No newline at end of file +U2FsdGVkX1+27DUwQ/55VO7uOQoasKkJ/J2SIlp206Ia9bvPBDBi0Wi2xphBWkM0XmeykGJtpgG86YPZy9crDYhoDr7Ku2i05XYcDYRJU+YPmXBlAy8S/ygWELOA5BXJHAdfyq0xM+FXYj0LbI+n9HvfUe3b12iKVaXBN9Hcio+3yvj/KFGT22aRO8U66yXg7lUT0k+gUdKN+uApP+VlvaL59BUVv4u8ZJU2uMbLFcdfdByIpGOC57JFSiqqOVAAtgsvIfkZI1QaEED68qAZCbJJ5CeROD5PoM6zd3MJU2X4xr1xpT9uIOrTxVPCboXFSaz/ssW0nqRB1NWOiCwI3DpBtXoL1SZJhiGtB3swH0LWGU0gI+s3pJgpmJubGv7RVaXKhGZpzraLDn0DRZshNtH6eDugSr+XWkB3kMwNDqi0oE9kxqB15EvSFlENDVcFA0rhioeO77y+UwBccHVgXNiJNshn9hqOXLWimUyGnak4tAZ8IXDSOjmU2iorMpLfhO/nvGagHbncJtcn+v6WLlDFSRc2ZQEII2i6VbDsNAsORQeBP/zK4AeavZbpuavs1btoEZa+R4fc4u85SDb0cuEc4LEpnznlqjseyRyJm5dIVpQkOzVAOHLoxCAs7L2P7ssrNYaJ3dHt9fcdTPv0LBQXiwaaUngxMOULJ2tJJa82HlTIpuCZwnr5WHRnxIAoU3H3mwhoJb0Pfu5uK3RAeJzsQ9YeYKcw0iLAv50Ho2VdEnR0LCMA6NK3oykC32iOKwuKSXhANVJt7PVDGKwBxBLtGvJZCGjmxnmrsaupT0YdRfkK2EdqsmH3X1zqFoiOo/3VHOf//RAu6L6HwFBNxc559UWpxxEuNZeHxnYAAIPDWoA1ywRB7/849vuenkl0xflV70muI01Qhj6Rl0MEBbFoJvh8rxT5FUrf0NNUjg/bsDohj8L5pKTyCZLSwnjwQmB3cIPPKwlRBOhYU7v6E9oJOYM0aKW1uPGMbRSkJSd25JeQ2k5yph72q04omaDJF7NH3QtS0+xMyfUDsdbenSE/qc6zqIF3GCq8h29hL7AABs1+dZ3DPiV/MwFbKKA3cLH2CnCzMNgMVSqvyzGC79UFQw1kF+ijRXRarxQgw8tSp7L8YDnJ8tZ92OJHhdpaiFvWm/85lsJgkrXtvS66Pt6iyyWfdSP1H8Z5JaFxTqRFdMfpyqFYlimr5d1WON/ynZaZjb3WuSVxbcqf54qS8oJqWDdVCg4yrXZpqGaoe3r8KEBzSq3jE1bhNDjSqlAH3rjLdPLIp90TBiG1c9dIytWfK+YsGX8h8KgXulfeCKBXALaST+dKAqK2Rj4q/3qgyBk5IBjLG742znoFG/zvXLOmA6fKF5TETbf2gYdIHHtC8MI7SFVAWJfaVqMBGxTpy2vkA8eCc2vel3nCbypCPoC04QWH5H/7IIDWrl6ilNjPG2RBar0XFIzoW421N3/zGLMe7TXf8YQGYUoCbCV2AoHMVUCeRvMm9O9R1s/ZbfhHVsQ+q/1B9vlB/G7QBtcoGbAmhN2KNc/2dEHJu9gg+MPEF0hEUpJVQrXfMeteRv+Onsf7U5KiN4OQKq5ATFQo6k73levPrA153ud2BqsVwS3+HVW7eNBavxf6jhBllsY+p2AxC65myj37VLeIGA/poLaXKDjcQteTkWnMrBI9Al2ut/lAn8yHss42Oc7d6HyCoWx0Y228lG6F/UWELRtpA0XCPb58efKnAPUDtGzRhggH/RYPFNewP2MWC16a1OiO4yBnRFDWfZpCirYBiPCiLktVjlQPTdWCl+6/VIrk8CJjZ7HPuyV9ZKAbMYffwGJ/ZcI9yvHB573BT0Z6RV5BzOA4J/Te1Jttw59ZGFIxn7lv684/3PhLRcRZUCkLa0B3XnnWF5gcp1L/UjZ4h3t7ytLqQIFfPVvL5a8h4rXAFHyJHnRGkXcVGG2UdwxIhNDKvJxojemiKxaAScHc+tVFmzRgeNRs+g0ocZqTNk3mFRmTHTJnQ8+7o27DWAKXZ3tN2YQczrYr/IWjFTiVxAyUCQwZRDPTWs0mk8krDjfBVE9ULLHMVxiWhjs8Jn4iw52yLCDL7Mg1JsZMBAEO8BIMig4pPVTR+niZrKevEb032h/kl5WMirKTmScjE/Cus1zvV4uHggny9Sf8G6zpUPq1PvxCc64aq4xD+4RhfA/gl196ryzW+UWz+c38/LAe12seCgPMHQdpiujRV2L4r9HwskyZuJ+eJq75PSghHWcxbdMUctZKZyMv0od/FwD/C6ffFpaeT4U7JAhH7/TgVw8F4lO/uBjDtd3/Icphw3QXWeLPzKR5YTaRaDiJUxDnFjfJX6g0jlSMXyTOvDDg46u3b+DRm0XiIJ0TsaioPxYPyhAK3ugseJNRxvyjaqDdMsKy7MgbdY0+Hj3uhIGrKA9M3PmQ2swZCADCkauGRvyoNQjC1TTq5xQXvyNnGAkHre4jPvi1GX9IuQtN202yL6++RJhs5XP8iz+/Lg9vgWCfSA5JgkY4h8aPtnU4cBXeB95kLJ3fgpApGcU2mardrhbkc+0h9umrgWFsf122Ee4JTlc28m63pP3x+sWVlQpJihPtDFA4p+rohq0UZJ3DAnq/DGUVGVaJVSivdVK2B+sbSZkJoRtXcbMcxXgvINV8/0yTOFRnptwHUdNpklL5aepb51mz6rvBJpjpgmCrzouTekC/lOCLBkcLh/FrIj/bpV0/cmgwqdYOR4eU5r9wRQ/DXs491yePhupxqpjoXqGVhLlwqfv5LUSiO07mKvhSjJtH8dKpUw7mJqddBPU8+u0C4juADVWC7zZYlCNdFeBNYtHp4m/Cu6+s+H/YB0BXJDmlJYx05vIMAYPVCscd3wRPCsXKzvq7fn3QuefQhzhH5o1wum4XmR2WDsDp7N4uO+QPZL99XYLTRDiBSYvyokPaJMvEDW3xDWqehaO42dh5YCVFiLBk2cHXNGqKaPNJeOKZXHNYo4rTmlWwxRARzoBQCKDvV92n/OvlXigk8xZSuaYMaEAdBMfxDuzu1ZT7W03v5MPjc0dwI85wshJzqK9uKFZgxkTFTKCL2zs9QhD92QhV53aCupyK836bl5bCELv7Eh1GbIbLCIU7j1TPQyxtVT2vD8RfAIS3PFpCBChT/v7rh02I57BBQcTTsDrIKCT5Getjdg41oMSuWZsZc0l9aIUEvZucaF400LQU2SqkVp7CX+lzqekH7OTUIOAjsWnaW4ebSql4101IDSLlEyagv+8HELR6IZCPQwC1kRGL3412LCsAjtstXzPrun8Wgpru9lHFsRk0/uDL+0rvXzirvd88oybrZLsCTtecr2gdd+h2CfGiK9HQhMTLQGPn0ZuniBe0lqj9KgEk51443G//dA7lSwmolVGH9IOi1QW7ezVki2Yr8kgpnEHLtOavC57QdFtcnLKsXdDzXEY/FcjrNYWBwoFKrJKptP+HRZBzBucEbnj4J/Cdcnr9z1Vt2ClTSCFkuHXoFk7d+J7x5qoPVCBjpZlG/tOBm03NLAkBWO72ZHGVvLRlu263k67m4veuKcv6W+30dKOb63g+tYtVDXgpX22uPRKvUKI+p7omZSFGvD0cN307MF4M/Drk8GQce3OJbkn71cgbxsm4GklHZc4CCP64Om90HCK1XZE158iWwGcVjXk1wKVb2AB9n5gFEvHwG4OoHs5JGjdfM3b4YRXJ5NOuKrk6U3ljhMreXCisbCWIhuCTDO72pRcUSsEYpcLXdH8kQMCEIBA0gNAXSlGBb83roZj3XInzBiMgfHlpUY3CAK0PLllV5gFYj1My4a7yq8Pt/zArTKmqjTuhrixtAnhN+R9DlDh27u+H+8bvxz3NUfN8KDTXeD3pSENYTRP/6du+BMzZj4pdhu1Cwlozw6+r4pvTy2AhV0JFGNg7LArEJfEIV1PcTNRqJczmngs79CjJlmtYzRw/n9B3U1u5Ybp1lsePffcz7E8SbQIF4mCVOkVBu4iJzLJSEEWaKtoom2GFWh7Brfq70Y3g9zsoPCFA7yeANgb0EWGdHLh6R8jDD6V0lBO3f9uaxuvRRsPYuhuYC82AK1ujTW7vRdSaxJdg1h56NuO8x3IPA6HmVSy45fQPsz1T75+l33CZjDvQiXU6slJGSKM8YqtDgzAVaAz20YYEfDxqCYlc525lmNxKHy/EjONnc8fpECJ0Q1k5k0rELObGjBSaBLblWoNPWSb98kYDsqkRbldA3ehxHXc8qYEEGtmm4Wivb1C40JQf9jCiiKLkJkJTUv8zJJCtxwh1FPXsAmciHYzPFUkiMXOA4/oJ5ytKkPXhB4//sKm0mBFop7CSdwbOUfumn19yRzD6r/BZS8uyyOkcoWSrEM+V4QAbBc7ImjqFYogVQiS+3L2MRBJEYJ+sKNsKse1z2k5jb0rZ1NstHFiQguiwFw1T73/MyH4V36dTM0epLR3x9wuXPp748ZE1LD0AA/0pxNe2UNO1eymqtUfFkyZ3VojVlbTZOXWBiu4NaFsGCJh09jE9Mb+dQAD3u5c3BmFxhvwCv29u1YowkxYHWNC3oTmWDrZE9jSd4wg4PMhtOyXOzBmeCQk2ODbe64SgLTa5gzJuQDJOY1ZONHRkiSN058wteU600caa/NZPZuFi1drEYm1opdbbjtfUkU82cVcWNoRo7vNqB1bnmDTOFiIfZK4k9UWQphePipcUOIC8g7Chq6lJul/285At7rMrRC1jpSh9UW7lvt9k6sLZsta/vxzhTgBvH53wrtxE2qWSdHnSgdqz1rALkp95AzNODJVejVVPi1UTiQQRYgJRow5O6xITUUxu1N5d0VlSLgCTYaWqnwt5yACwlofs89HdbNjqAgyP+tFZryfHHw5RPzx+9E0b3cQgVkCGhC5vK5oOy9tPnrZEbH4fU8pNctxZ+FUdbHWDzoyc3p9Y+KvFGEGJmahfuVjJGZ/+JdIZQBhTiub3TjKppELypnfHWEvNHLM5IoS4/+UVEvncBS6PWnfK6R2q18CwGkdOoVHcfJQ51wjpi41GrsJEnkIJKwRDxuH9Ybz8mBjAR1yZ90uxM80TJzh0FuvANrXKvu++K2c4FXDYZTa8ZoSzVSx4H/LFzKqhezD22Ej1rhOIHjSd2ptzncYNtgibxNU3Fjkrg8FJSwJMlj00r63l3HOaFmQ6Tp9hHqBjzTuxPPwaTTf99YjSo7VJLXFxaw+Xx//Kx1FejgzmQQEyaLSyEChjQv3sRvR0hrGR8+0MYLTxMLlm0Rcwhz0y8KOikQ91V49CmS3215Wj2noNaU35iUVGqwqh6StdvDN2y8Cpv2Cshx0HCWx8PNk7tAjZ6TeoxhitBLBb56KPN+KUUO3SGjJWP9GJ+VqjGvaeyi+6zvQeUKCbMxy9zMCgct1ULc1X6qhFuJruirs6sQEkzdBLnhh7wcs7WirLucSj45JtE0/nzwMVN/E6XH6S2+jXcCR+P9NtBT2vpL7Yzl3m1l3HQMfd6gaqq+w3hUe4TTNHZaVEX714Qid+DaZNFwaIS+k+Sr6tH2gU1cDocDMs7+MiH37B/wbZbXYyZ1v7NLCr3z4W3KRlFWeboOM0fjAv+1XCg3RLxKtSqxUUpW5yHi6IYStjWrLeh3VD407xeGuL7FmiIOKYzRUu+gqe3orWbHUbrNUx3fqWwgskbM54joXIHYHr71iK/8hEsuLY+Jom0vIT4M2egjvEvZkAYMcOvLoO+sNHtuWu+cYkIvSoAdmxEpETI557kewevukBDZ+waNbLFyTMZXTkJcAUObGpM5nUrddlmIO3FZ3jcl5WSz0A5dhO6c+65yGN/1HD5Q2iv2v+J6wzwxwz5h8Uq/l3NTWWTGPL3ZIPP3VVyKf8TGfbgYqB3B3yXrEDroNwJynSP9glBbPmZ9aSjMu5J1hEsKeEcHbWwcRhgm+oqAZK6fOITHLR5ag8awlwVt+vd2fLlRX7ajjwHFKDHNJivGQ1zz/8d/hi6rGKw6RAKQQTXCEIHTElALwhM8d6dJkqLg8OLqbpQttpx2qaj5i1Xa8tt1X3dQte6onxSkiJ2sAFZKXrQfzZ88WEJySJL6gfnqXjRoWL6SBa0P3kh/Q/le+eMD50jTUtmrdESST8YtvHevnt9CfY4NwSGmdRMC+AGVcjoxlOJlCTcT2gsese7j34RhvBPL1AuaQz3VspwDWaDMUdCWRATJZq+Dwu+esVGMJZaxrBewGBi6FEgz+Qo71XoTWJDKZScJ7UzThbCzwASFyWA/7rdvv6Y9U6dFKjeNhgfGHh1IA/y8TfoffqAglViGRozFYLn5cYfgN/+NysP7NGpZ+Fj/spkGftkpBCGaDWNNpSWiRkQt/f5MHDjpXvtsifGoMa/we7LQLi8FjIz0cQXuOTMxDReu/FqxT6iwzSuVo/DQG1g3pW7F4GBIUF+b+3kU3N9Z4TfkKcnM6C3ASO9o8pXWWa0+mSes/MQEnVW/q9f7hTqs/k5UQ31PXjPuSUsuD+zGdfC1iaLmS1M01b3IGNqnuKsGMh7Kl0uMhhtmvcK2MEu7i8ojmL4IhqpO+NJdrbhdgrZAWiq+jN914qxZBNuD9lTo0N6Zn9YMqpqF79DFYP3svgmYBLM/jx4D06vppho1+6v88ewYFOl9iidNROm7rVBd8EFszFxhEOrKjQI9CyJpNWMwuhzAHW2T4fEtS5UnhR0wG5QI5GWt+2THXe2HW8QDocO8L+mUUT/Tk2MfO3UrwCAyBxEpGrz+HmJaBctoRE/p1poJgzds746e6f1clnGEcx69TzOHfy+Inln+0J9Bt/A315nskByyIB+7uwAdovhKcfD7ea4eoGGtS+0+AQSZup7+2iIqnJVK0YP5J18jOMfa5cApsXvTC6ppXzskYKIBaLAS1l8mPp740QSttXuNDGOBzHSwbc0gokaVDwhULSfAXKgr2MBu6XX+y7kFORoRR2cGtPK70Jj7TrCHnTKupp8K+lqthr4b9vz0fkJCkGYGTUSOyaWbRoOd4AQna2qlOeHtu3dhlroAgWQQOJ0KTZYwCGhJg5hY45iyPzucZf0N7loL2ZOHhOvjmIldtDHVJ8jPa3Z/ur2581iU+/szEXsAq24fIz/kcS+ptwgqTHdVsU+mPBfLIpansgiBL4FayU3AyNLCaugqLJ/4gq59CULlEi3/8ZH5W4/sorkO1aoDAkKPF1HxrMT/JHtl3Lz4yCae8Yaymct78ki/rv8zzHamPmfyLFj2HFKi0gfoqZ/0ROzvvHwgw2zBAZV5iSikUsyZy2xGh86/0KZtclr8ovoDRdiNGRdDijgt7GPjtyuL4UDnmcPb6bRh0gRUtbhtTPzt688P8P0ZekS8sKBPMYx72Ii+vX8muokALsFCGU+Tk5l2HNd+VTJ6tDrc84v3jLQQg8jcT9zgxz8Wlx4UMdHa6zVkLkbqKg44Oonan7T+60fqSYk65OQQ3RtDKaOTrLW24PQ5G9kFdIPK5ar6pEi1tH2e2npLiyBFkkizZvk3MTRbL8Ja7SZ1rvkH9YYs2bCWXK0WOcJ8u1PcYO8v2nWjXzVwGJ2hrRBvMVmw16lnT0nTWJStbbYqg6FDjfTEJr7qxVU62ojlibvtbrKHyE8ehYaNYB4z7w8pGPnCad5DJojj4PpXr9zNjI5y0kSUQ3viKojkkR/Q0C+4p3cFblIKjiWg5FD0VXJiaFnCTGc8P9OP9HgQpUcwKXuJasEddXFXS0+rs8+judIbQ7/Zg80hklavo1V3/8DIRkmOmX56Y0hsxi/bkpFge818SDMyPeT4sqXD63RMQx6EJETnhEcayKCaKhePXenbPaned/QOXT99cDGMyO2CAFMo5fDJQUyRtKgyGy96OtLI7O6Fh4aFuMtHTVw69uQNYyfp9JMxjXqL4QYBjKOupR3DSN3svOSL9UF/WDFwPl9Js+T3G+ESwRH0wDYslRchHN9KwWR6JKDHphD/P+HvsQRUcap1P+opqpk2pvsMZ49U4MzsZbC1RzhsEe04ChR4wBV8YyapZHQEwKO4ic+IZF7lCdEGLgc3oW37WPVbNbK+8cjIBcmEEgviXrhaJomjZZ3qUuKxn6K5fiyW4IwC8AcB+DRhgVZu/5xNJkDankgYGOonkx1nQR6g+6kGBmd/5Ul3zwlmeUEptvbhszbGzWwTHax60hsWf9IiIjgtzRdXTd9lwGvsbi6/NzEDny/R8lgPOysth8Il96bMnBuWwCLEUswn1GJBv/Yt/Ejj7j4VEdxgLq+EDneabs6txaQ7q+HdNXPgRrIWz+2f+oJtEdCnDiWHKaQEVqqxoPanKPWXGev1E8k4tlxty9QtWaxwHAD2xgwJJCrBoXEPtHlwDC0x9drgk4JhWwYHkjHjYiE1xfLmscn1fwPXyTOrClO1PhSiBs/ulJQ6MNFSh0MsyNs6z5ys1N4rpXvPR+DTdjTWtR7Yz+XI6h/1rm/4SyeAJF4SPji/ufhegrQxivR1k/ShGqkYyR88N15DULUsfzR4EUu0GrarSwMwuByzblSxF7u7qe0X12fGz3QRtUEZDuI/8gWE3KDuh/YBWqCzObQQtTDjR6RRC62fibjU8wNFzCYK3DlmmgWRbG76TMxjtk4OFfUi9i96KBBhrv6TRxzm+VfhsS6vD4hrcdAAgbAYD7gPp8O1uadYE9OzdomeavYpUJ09XP6twdqWcVfYpfzQsr7ln2lGD6QmtaGlthKvUO4KwaLWiAo5XC/6yYoypgFX16w/3qzL1dezHjGcuFlYECeV623inRRQCle6iQ+4spAjgLV9l0n2sPgMNMrRd2bhi+Dk4IQozXHM62TsvOvFEs/yw3GfJJYFO0KflyZ8xgTjM823s/MMtjLNYekqsi6yRl7/XxDcRCeMSbnkwPSLgehxNFxtEG7xy+MYr7w6XN9v2TqV+F/ZGUDijhoJjmm5tRvt3yrfRNJ9Ai428H2Qeo0wJJdRkvz4uBYvVffRRk9LKXjC5pvRM2lQrB5Yt9mtNDQbsTcCVgKwoiiNbiv/2aXQK5QdYO57b5pbkR0na0r7oIwNUJ7CEkv72dcWyNOjs5XCw98UqBwqHK6rpPwXwxffDNe0MlMzaeHS3hB53CkNcnL7wneXbs41TwNr6N3LSQtwMDJQXs+Jm/ATurLZhCUWaBiUnWYXwF4vlHGwSzqHcXTq33qwoqD+CgksSMrlO8pWI+aIBz8+iDE87n1ZuRQzbSTgiWQopvttA+YX+rgU139cUJ7TcDit3bi3mKvqbjGA8Yi2xSLHIdiLKJwQ4+2wVtZpJiG0a6MPxcEuQHeuXoSKumZ1otbPsmICa2q0nLQ4mRsyGkMGBVOMRohvjSdjwZRuRoSeqwYX+dInhWPiJBp8prjHeI2SnvtkvCmVMzdmXvzYTcX3U/u1VEUPsmUvH8gVY2g6IJwo81q5359f0ylWptvwwlodoe6oeEkzBP27EG1eSRVjp3PMuNdz2hWIwHQqxFVO1wkLgIcIwWw4Gp0FIwInkArM5ACCetDiZLZSCQb5/Uzp70pRZCfAS1v5IF09luB8k4nMHSLYb11aoBbt9j/lhV5Hk2HeFbN3Y+aK1jiAwIDLdq+004WZhnpLV/HD6Nb4+5wirkRNFhPp35BfKyl/mNusUzyJQC9hDBPMa0lrAScVB8lCJq1suN5xggLdXRHcaD/677KAkEH4T8GkNWyfu15N55zAaqvmxNK0buPZaWClstdpDTDACXWfOHBvItym34Ixr+irCpsIUOZ9jRRz7g/yL+BVsQFhDE8FJ2C/EGtw6OnzilPD1R2paxV4juArwvGsUMSNdH5vIwHGdO83qIZfaSGHQkMM+0kkPdVF3DgbzUUMnwKyxAAvYGEZo3kRErdlRmeeRFs/ES0gaIjqjddVLACZ6eYL8mCwvI/E3pS5A2wv+9evHjkBbLhWpa+jWudBDce+H5rCGvVOV2QRCIUMwJiQ6PvoJwJbBkHCMizPNLV2GXOTGW6fXTqEp/N0XwlNUxzubmS42VfTCOEZqz6GtfHmfh0NJQHljK8nqLY/GNsAl3GremdtCATczX4rXQ9uGK3c+bicIu+8tgpNB0bZFCZ7GHP+0SEvyvuccPdM+sX1fqzdqkp/nTx4f5fPdJwM9W+NigjzbOvdSnznioDyzItQSfA9sMXcW9aCl2DVwpfuSjIjIBM5aHEN4+QpQYR03+KypTOlESNoVSluu9MxnOJR38Ht/TAwC/8kAfn4sWuP8RJrDG8/Sae+cKtxVgAH5y5zVA0B/6lZJbb66rYqVJdVZcfDMVRiC9X1H4CpzqJnyzgQVmyMm+lBgiKkdzGqjT/LKaHPGqKe3UcLf09lO4X3V+F1JpGwVBLUDzvCEDrFsxIVb0YFAWi+eFxVjeBmI4+4g2YjimIuv3Ei6fNVMvaHTB1BmAOaGMi55VgPZLW9bfRwUg5mW9H4IyJn0XADsuaUM3NYx44baMpexaIMMUXvo6+kDX7BOl/SrxpwbpSCUBNxwHcZWuLCgTFePS0SttPOcMV+xzw432xYXTe11aJDoWcIdqmxlHeLWE4zuTdO3L6HQKBP15DB6XoxsP1/s/n+4Ol+UxXBGrkZgHLaHIuh9VErk0eHiW1uEAQjIFH375pIoWfEUn+6JRSy+36+NtPQtcQ3eZL2guAe1P4q+yxTKwGzquXPst3okBh3b7KP7tDUZglX5IItOVtFr6NYvDSuLmTe6zJRiMp1tD2Bk0c4vwtZfAPTwKt0574QAafza2Cc5h9i+wHDGJxKWyho1sxlI7OGFDlmPqaDWXepx/BIKRkDpehWBod2OIy8c+YsQjsSeJ7Xz7PBPaYV3kxUAwveEW3PRWzrjqO6cwI0ZAtSHVUo1uT47kJIa4h+CuGbJSV6zMCHP2fC9v0RyL3iJYQg5+lux5sk4AE7jrnGcFu6x+IH7On7YB3gczraEDWLSUYAiCoXe1Y1hHieocXvGnbB9g2KeKU+549N1v5OsVoMF+J+75YTLCvAkeaeBBJU7Xoe6DZvc1P/QdR9OuA2Y9Hp5W5sQ2+iFG9ru9abqXH/zofH1vnb4bWLNSZtwXjSZsUnAjMvpS0mr8K8lI5CIlxygFxuHbrqpzD4qdDe4atIvvvbjnv1by2ZwLXWrLyc2gOzYK0d51/Z2Ag46OoNjlIKl7SidUdUVotwXp16IMTQLkOpXj6SgcyoksaeZXi7IBwdSDKY2NlXB8+nydgSmqOkvnfhWiT7fCMMmiruHBxqynkOycmpOIXNEKKkh64I8i3kGwwnjBRYFan5bsfu8vP1AhKDcsM07jMsbh55diiDG5UjO5FqPMBuf1xNpEds53xPlkFJLuQFmkbeiyOvp9M7sH4UvwVtzsR/MIkqhJtPEdiV0dhnEY6GFRaTjEKe9k9fBvMiPjkY1t9eHHbqAe26pp6ZNb4okvaU8iLkijCfsHIFfs5Tfefu6EovQrJV9NgS4QnHJBFU7EUzT70phi6YEi4Ydh4rQZvyqu9GDONrIM5/gfB1scXXSEtU14OQmuiQCYmMRMAqgwNvlkydjX1z0nBxQG4P7PNKlOG9J/8AhqTNJ4rKfPCeTtsgqea8o/POKY/kX+NZKmYePzfab6WHC7oIcDAuMy99w8TsOv/lGk8PrU7iqrNoSF3k8qjAq4/PKLzLv6DLHw8oGhuJHxD4ZDOFmI27/OzwJou2BYlpnZbh+W8B1SpisVBLPx8CiMFaxZfP63OmzWdiMwaNvNEp1qd7uOJcL3qNpxTBMPsv0/OTsJxi8l4dJMiJcFXA6vdY1/MMQm4itTgHPGvrcD9PkUxxSGGGb/D9f9lOOGlXjuKX6Wbye2dtC5BAJlaf8sz4L9/ylgQfCM0syScbevkaQ7vdvzIWEXZfNQClBLwjLHMcuoTTLFVFyS1OhmswxdUu0HHgbGHstJuYfC/mTeG8odIoxsOqS5l10mHmRnO4cAmv4rsaV61rnsepp8FaGm7UGcOZ82ZrZPgiygHwbbfL7ElOoMkV171rArqOaKyUXymqjQ62RkPU+wb05dcoI1jnkUodvUX9Q/E4FURRTvB4fXJB/pcjQcN1qf+Fw2/8CQV6duYplZeYx0Y6IwpYYEmG3INIIw+rMFklAQIi/mO235sMhJwp8eOGgHRuFQbsbRe1Hx1mJycfzZBx3aXcAKxKeObGXerNv2G31gSafWTtT0TNV/ebUcMiLq/zCwgX2x1kLzfYtxnIXYF3gzBiwuQMWTwuVuJWkQLIC22C9ILl8zD2uazAeWdJNPC+109ifrPOPiPQkyjrcNf9bpb9L40VjRMUzXFtuO4qa4HR+4Moh6Ja1NotOGCP8RsYEeSIHvLR6oW9w5CM4oedQ2IQKNdn6rayXtt8iC5gQSYoeBSFE7PfKZPAIdOzglkfyEvPScTTl6nIQ8YrQVTk2Ku1RFAD0zi4wzhNTgY785HGXArPxOP4rRZbVuVZ1DaTy7XqHsBSEY1LgkipKy7Xnmg95l+mXImHP1Ln3ao09Fxa++fFmkZxtps0qMf/daBWivP/A5HeNsXN4ysOxDaOmgh7nZf7jQCBMDQEpu9k0W3yOl8Uih3O3xMYem3MfphtrGCeJ1yxXEFTyEOJPHeN2JR1EiR8xDc3XhmxiGF5gX57LFknZcT860bnaPwVu2I/yho/GtI0ApVJHMeBaI9G8i8s5CR6gxpD/+C7ubO3Zm29MmxIgVoYqaTGgs7g1/3FnN9cYeCuL0I9NLLifFj2Ra0Noq39iIrfVyRyDOBguLS/xFiY8ugvSVH6opLfg/r14wT8aowvI4RQo9svF303mCBfACwM3R0bFsEKztfy9l8PS/lfPVy930dSdUDjfGhmL9GsDV0ESr7lH6i2Vwo3npTrunU+ZcezcQku2c0ILukFr3asNrxSV5KZca+UCpXvijTb9z86wbmfKqRDhcNdQ/h+k2VMowiMHnNIYa889hZnFiHIvbTPWeynxb/aJbhmwhiSMlTWUsnvcQFKS8MfWwaQPDubOIPFhysnynXP4V4n5OdR2B25/vQJskH8JBA9kiwqtOlF6rNw/j3IYa1iuuLltB005ktONsrTBGE7bgZmg+O9KU3bA+uVVblwx4jppr2/8UhVuKOYNKXasG4eJEr88DDAMULTuX/4lzEbWTIpMBMBEg0VlUIM7Io+JyxO+jShmpp0D7feI+qTQO5KW9324mOabJHrs4JxHcwJMMN8ijrQBQzDwDvxBVf9ggHsNasvjLLtSwAsEsXFQgxoUYCMA5DDbnCXf1wJHK1kYZuex2PvXZr6KWAmsblC6IYG3u0LIia4S3hmpHxkgSN1vZRuam470taQOXtkVkdbv2mI4g5eQzyqCtwPI+0tT0+oZ+nnw9TpIIYnHKJ9cSOcki7sAhnlKnHqAvcHphhtn5hqjqlrSAipU6+6pMPsCCz4uDcRsj6Wabqdy1bsja7IWhPtBZLKpCmCIaRatf8KLsEVp2/3DjjTYZ7dmFvS3eUVFndjryuhbGFAw3Ev5WWg4MJxpQxE5vH4MH4giFNnSGq70Rfoc1lhZ/A1yrWkEQIEQ8lvYkaYHXOBvWblMH1k3eMpJO0lmxXt7bAhTPkCGPNiQf2VuXcz6GkzFWbxnBFYLyjXi71GRfGAu5QesmPUJ20HEnU3Muli2Pqp3eKT9T4PeLo81t5pKxoz3PNaZhvadvpp7YE5OsOHZfqP04hL3FJ9KXR8o8/xEZ1K0vX65L2M3Orc0HKcdlCKqVhsrKdWAhSJgm+9L1MaoGxhW1gpkIYy143fw8PSSzEXRo+qlCU3O+3hUiTr3O5NPkJyXSp95L0Bmj7bn10cr80GI+mzjsoFHJ7AeiepXN1RwfYQM95CdRXaPI3c8rbl46T8CFTZN1dj1y9PHoPk2bqbQvGm3i3iTNb+310A330KhtX8X7XHhAjI7TdKW6GWxnyziyWyCr5JazByiG0YVlJPj9EXMRGW9O45rzja8BtEivHd24ErhJzBNe7b00DC+SSUBFEHl7PFar5usJoKmQpS3YSsgMAP9UZpm/JaK/E3LbnsbntkRe3FgQFZINMPvojj1Gz4J0VS3q4gcPWPAkZ86GDSzfvl/Cm05+AuTEfIjQ39LsbMWs4IJDxnFIdov6k2gx2xAVaEG8EhZB494+UrgyWAdYX0UEe88q6dopJ+UUBTrF7ekDEc6/n62ZsAchrhkjKyDB0RO93JToT3FOb5iVsF+NSAodcSWDX7zd8rI45uH/2E8vxg9ntMTt6L2b2DQLGBDqrivrRZHtrx2sr8CM77cVJheUcnzWjqFTTxr8VkQe0tXhX2zW4hRJbLbz31RrYzOC0aga9a8vrgsXKqNwp74aUF5em3D3Ltoux3KUIKb+lXzOxzP2s7hwQPMID8QO1/d64qF8VGGYfzJGMcGYtMK4dIRHS4u/uo0MhRKga4LBy/izItxgcpS/fRxN5xituOPp1MOxRcrYZpj/IQ4009Kct9PlOMvGUs6C9sRoEfypZVh9dsxbtOrFz0HyaWZB/xP7vzbE9DDG2se3Y6MGgFdzywvv2wayQDB2zTL3fjARFQDGXvRmsAhz+V7ogo+7u9NTZtb5wewzQcKg3EG1xw4KLT+BDHcNA/Hobqr9cywU6t04Ub5UcRbuf++Nca/xET06ol5mfeZ1Ll43lO/VsvX+mK9R34+YUI8pInhHwq7CkRjZYvqi1BRgdRL2WHHGRI7QsEZYdGUSaLiMZcAjQOOo7kzbXzlxHsQHYrozRHMQxSSI45vVW6gaWWEo8WABzaNA3sKLSAfpRBvaDGnA7PBxDHhXKzhcTc92C6ioxuKq7WxlKZjVuY5PC6H6tr89Pgo06E2WvCyggd6aCz53sAxQ3oL7VrQReJKmv5CjDGiArXaUM2Lzv5UpKV3r9XEHiMP+kAR4yWa4cBeBZozzImHe3rf5E/yubxbJNRkHoe2/xVTKyTn2c+KOmGLYuz7mbiSUrZXQIYmN9RoXIS1cLz/URaEaNJ/DgANlSFYhYEhnsbfy8hE5zWoJmfdr1jaOpV+UA8tFAap8/fb7t3Ci7tLZiw7FY4u4VeVdzmPhzfm12TdwRnn/XuT7LKQiPSLzHVfqego/FOy81eeUYpxvrFmA3XYWQNEW3zzbf6bb1vwNilYP6MJOPNwrzK73lnIWtNoSCEn8+MS8zcjXlLNyUGw05qXnoTfC0OtRBGOPiWYA0XIL64HlK81Ugt92nRZmfpM9h4kHOB2R+XYRtJOGcwwBUdoE2D7VU7pZSAAU6Wcl2maNmpumMikI9VOVqWpzj66rMZrBCH/TKJUTr+o+lm6bQ5McBgw0o0Nasx6xiXb7d5xmqDGZu0xB0dGzPZyHucUdgt6vdXppJs53Er9DrXmV1yqrrR9HlF+gzeif9sHLYIT0TcM4zLnpWpavvIGDuiRPLAId5utjjATmsLFGBqLJq0MZ1Uz7p7MapDX3ObqZDrBhmW6icJXsn55Y9l/7hi4O18QTJQPa5ofEw9InYxl+OWqo1scAY1dErKX3QmU5GFa3YP1MvQ1pNN2C6qXjGVDx0z2jJtFnRSXaZmExuhYdPRitKISVmwaNPJK+4w8Imz8bTeKyAZV5mshT+eEG376uuT7cuwszcWaIip6Zkr4WVJqKYREv7kI7PcKzvvgwKy666c2CNLIQs6CiYWAaMqi7pBO5IygV85oh3PGGr45+pGIZujzWg9ObVHGRIiqSrjT7EmsSGBVXPokTVPokpD9qQ8TlSbSNbRcV+CFybFH735Xf9K+nxlTOPpUoiPn62VK3SZASYKUwjrqLqrH1Qi5YG8r/Jpz1+lnHvs43O+jwpC8pSWrhsXueJlkitKewpB0/bp1u48224ktD3SxEEmJOG6fxgaJTgqRhXSXBy2cTFrrX0uy1FfsN/aYLUsHS22go5dDd4ZYsAj2Q7sYAlLtzTM10ZEuNNid3sV7WquV92ZuS0cLDk2Unq1xbV7x5+/DK7xFhhRqlOpbhVwF+Nigk4ATXZU7arrN8zs6+WClJJQ1dYvvyMgU+U829vc4uUuAIClbnDRSFXIoe8zx7ES0zPw60ea+qhDq4zG6WzHiBoObqNt67eEfhymFPEt0QXqsJ16SI+YZ0VHPGUFOt4BHl0OROef8fvL62es0/nt+oPYa8GS8RvyThUb9dJMVRX53ic9wUKenWJc+4YemndK2cHU1EmQ8b1PMF6RgrbO4ECjQF2AtmIXN2J8MyJaSWlzG6rnvwAM3JQ89/oKJDAzYh9dw9LUBJH8hYlAI+WxfXmqLZFjLvwAjYQNVwcWVS7iEStzAPC+duE91cY7zg7eWCMMj211d5FnoGMpIu5xE++6OkSB/5ThwUWa5BdZzTXVNmKqzEd2ggnpOph9SIcn/ElRZohfoESZexblo8ZGSt9IDPCQZxbdmWxhGpQN5AnVTZA3fN4rhMnJW10k2c0Wax+0kyPULlBKFtFAKMWnm44j7vcuF1dMMYoIE7Q8lQKqnAQst6hLh3x0icbBNp6Di697ScaznVd+uG4dasOVnGVIU1RqZb+v1Tf0EWcoHp0MizSRQ60PppqIbIXlsBhSQAuUWOXMjJQfCA+zclNHXXPXUSWbg4x5m67BqWmbaxHzR3s4agErdj1DSWMyyRty4SGafKdeNNlgdJmeVcVHKqG4CPSKSmRWub9M7qeRAk4f7MOEijEHL+jBSe+8XnkoPMF5fySAZBX9KL1E4WFR1VPNsapn37cxRU/Kn0luhN+rGU6krADQKyRj1gnobE1OA7QiIksa8VcEFFvqBu2qSBqWMU7ET9umYIfzVyByBxwTvymPEIShSU2nkeuWvFendrJxcYz0RYzEFooyFIhvcM/XTDbdWnjHckkl3Yep36jjoYE7cDtIm8FMabXZYzzpgZKPd56JBEdXM9XSJVDlefBscmv1oMhSAvNjIQGGouM/vFlRxKyjBwgyKDJ1Tj82OAlygww/tpiofXV+tEP2L4N/jfXohvAgQb2F968q9oNI110OBNgfX4ySU626XRxGj3oCGdnw6rTDC5K7rK77P2CnybWo8SjUYz6CNt9PA2c2oUfGstx8wB6E8WUXKFO7Ti0TxY5MLpWypF2HcQ9imhViknZ2HL70ZIGgV5z0aHUluEOph01Vs2btUKCCCACJrDJErH0jxjRqey+usKioQ5TwDiAboC/gxsIOv1rws91BfMmln5KgJDwqNHmNiIChjqSm80912XImOCSYzf/i+ymML1o/fRuqeNFtU+7M9h6IUMdVRrTPDzBTq5Mu2pTjLpUjZwdXVLuEJczCvSxrD5HpbJC4EBI98BP7BcJkq3XRgzhBxHHDLFLiWMRb36ppskZjoUQiaXd5OxHAExNT6HCk7VOvic/1voKVpxuOxB5FUVB+B1XjlGZ17z7VMkFrY0985hejOtoTJwkPrn2OjvS6lB0dK1J0S7GqsrbQAxv2zjAlyLKwEPStptIeYC7sZqJt9OAiuwhTD29oqn5DfgsJxTsas/BGghcPpSIfCCYMks+IW1o1YMDZiDVqFmpV9mZ+581srNCzWEHFXBFQU1aiaj1Zru5oXdS10rnATgZ1XGUKweAyrUm4jwEIVoNfDTiS4q7tF76fHPxBd33z/lac+11w8edpCELcvluHkJuYZHlgns3CSE/2e9kZcDXXcPTVPz6YAX2sMkIBTecDZ+4/+xGJpgv/ZK/ZbgGwgEDtw6DC34MdJ+up3oIpFK4HirHp74f553whnGgrGSxpCcqEwvEz+b5FPC3T6sBgo2O6IGycpZRx/Tg+O60JJVpQLfJ2wJmWRj+QWSBHd2cbWaKw6420dmYl3NxyAdUZuBDOq3VOwzkKUNVcP6kmStJBMvZq3nBd674O8Jwysb/yG0DosBsgHa3wXZKYxAvawur6hGXHNrEi7ZCpplaR1iHU4LAcLroqR42Ih8a9VX8BzsSGr23S3P5RP9UbNboebcw4caR0KGanQY2Da2JLSbhLep3751UxQttWebYOuM1tdCholqoe8hzxrWcQhumfegVmrALC2vHIPWYMBuEC4IqTqldoURJSZea/nc5gQYA1oKkm0930MMNLRcypihfnQn8gmdzCQt4JBRS39/FusNvbUUpoV4M1UkUGs+pbtNMJ8SbMAcQ46swje5JhabhToyCIAmgVBU23f6Orhk0gk+o6mNdmCWxikDwTcSXe1F9E3mMV2mhzAeKErNbna/HafyZiwFgIBZAvvcIFpezHwpCTgzGfZ/zBOjP42IJBFVNnhx4E9q5bjfu5wBCW2m+zTT/ZdieilB06hUb7lvvZ5ZBF/Zj+M0INu6DUoveo5m0uAqjIUbZE1ZALwlxu8G1slXwPa7eFRZxTQcC4XPIgCvP9WWel5Srz0/WfGA0NOpZBoy5UnQkS9LqEE1i3+TTZAYgKR2aj/Y0rjuyd6XCRIoGP7zO2a4hdGL6OTjoUTUQ6YmKLeyS1ecgrFHZE9g9otfGPpTJ8etmVgNAxym4FnfB8uqrtdk38ybHgXcYvtPI5xbEDuVW8Dm5/D5SGeFRu/viL3fsLxTOlZaDnyCvxJ/0OanPIk8fMb4G49hUFUUEw7lsrJXzFlEkz3tCanxPw5Qq4QKumjv9+t2GRSCQWc8xBTFI5ajIlnwYI7LdwBwcqfRAdE8llqcoxEoH90ZyPzl24mDmVh9Gn18dVAit7DJ4gpve95PW7xivBTJIKJR32OoUM/ThMR8JRTd6R94h7p3NGy4k8TgHkeljZqUJOH7uMzi2LJSWrUWVTny1PtHfP4VWkKZbXYXN9P+1/JjmhIeX2DXBJUVlp4nJNbiJg97wtt9KdDaau3hZTYsNrIaAEo+36hYlXwSL9im9INaZMZpyP4FMKid+SK9yXo6mxfCmcbKfzKbNEF0Nz52WQebEgpNmxCpta4Jdptr6zhzFXkdkNbsdI3fd592jylxPfkUpCnDkTxa/gD4zjntmP9GGmjlJRoLBKR9KXo8Sv63QmLtMWdrhmWv7yJoRGRwbP1jbszV9X2JJH9uKnaso0iZ4Ye2XrZu8bNrb1Sk0s1GFByNhqc4+ezElKZHeCdXpmVOWK3NsPiENFY1xNrTPiIHO7WFO86WP16+9TIVqq9tD7kRaZjUdrvAkIdRTik3Qaaepr0Dpx0PlJ1yOnkLAcUA99BCfWO5OP6OyifJD/Eo31lzETNvUDhsTibwS9p2f3tNAYK+TqQrhi5uBroZnSg9EMQmzvN+FrlqIxL4QVYy3iTlPsUlzYC9mgAZg4RN42/8YS+VK2SZU/A5v2PiRFTFmAP7qbrRrinaB+4Qv3FXwzZXyGlN41B0ltMBIN4EfYefZOSUe0QpAlES5Vzpz8zOt9aa7S21ouved3r3QxUkL4PoKKLx2LYyXg4fFc56swDncDer45Ko98hjnOtPk44bxLswoJT5aIQL/IxqoCceTkUY+6hrQ0Oo/xxtqu6c7OhsS8avWa3fYn+t1iZqsVCvBegIw+IwHRKexTQ9wLYvOXGvUgkLJNvjrrMsufV44eIaC3IlvARZ9ZH1qmhbmK1kIy7G+zWNQEX5h3cqSLogF8pKrjD8kFJvFbwYsPWJ1TnS0ulLN8v/r/uj75QkRPGwSbznZiFTnRNCvEGF70y44sz1rVuBMxBzgd2wcR7Hnu5HkMpJq4SC4exmYviryeKL6/W2V/7vt6X+jW77WG79lssSxXz25sT6pc+J53zh0xcBWiTmjrt/T2bMiwhoQM19/R0xXEKWpYAWBKac/d4H+0HhrXHHKsyxHrhwOaluCAt3GQj2vuOOrYMsY+tqEcXzF/1MwLLEnNTfTzBSiz3DXFLJI8CGQOYG0NFrZOyCo+dBHXnITISd7/kwfBSGlaUY/4Ep0ZCx35hV5ZC8eEFMu8OQzFuIw2eOjGlekToXDCRtEjHH2pTJtp59EEY/bvmlZFIgedp5+G274NRW2qSzQX96PM0X4O+8iZMBLNAqA5x1F5La6ASvefHGmIpm4/Q8+VJeK7cJNeBPqm36usafo9L9KHzjOM5QjTmB6UdX4QM/uHHAEj2KpFQJwIU+WDZVQMZ41guIey9lcOFDcH3/JqmrQDsAwIm0mAXF/w1rEpXmCJMibyhRstEo+s9vClD+zVsVUoLUg8BxbXNdF1v44CJZ4HfCLeZYzo0olFkw22gYRbLu0/Co1j4wwpztb53BWXO8eAv4KmnwYdcwNphu0/JyK7VPKhPogy0xGPtG0m9eE1e5u9o4qxkfCgOI61Nz4YdCa6X8dm9hhoRQML6MSVCdGoJUBAQAn8pMguSdfrMCilBvmd0gUJkGWS5cmyN3n0cF26v/Dw9GEHSdpnscyotXa3iqNcjPrBcepxWtXuCymaaQCsuqCuys75/G0Sa02FM9kwJB+bKFx5pODXTGdnM300H62NnONR51WMQ4YqkvG8YZ6KipkTr1VuL/+697XejjYUMGrtNC57CSoJ0XRaDdF5jzD36T9eyeNKqkalTxmkUVNCo+lV2I7JIHGj0E1rknuFyv1/DnOKjnbvRdGGb6/mbDAwZeOmcVAn4eDjHsaZ+979hH/OcCZjUhIPL67GsYUb3IVHcXzrohnROo+Arg5Y4/foBOdUS+9PF/nQnPb1p0hqHt3LCrBTAW7eYegHeOXWhsqmlnDXmBzay8pYa9/8q9w+YavB7iJVkpKZmzUnc7hByklG4K2fQ4Lz0pevoARs+pxxlmg7xFYLzCnhT3TGuxY3g2A5YAYpkYQL1h5ZkfFTkZUB9n7931OdFQQhsE0m1b0TiAVZ2/AgWqMA/YaoL0SORKYCKDPlJOPvXKvOaBukB8KOAqOFd9Uy7zO15P+T1c6izMuYStF8SudCKMMqlKRwVDOE+w+KUOtWA+Jm1d2BivGERcHWMrsKG/uvhUb+k2b+mwavDKGMxevQVoJEaHKqXiPe414s5DNp0hfjOf44RaapxmxTNzDs2AzknWSvi0huwng59utx8OYlpk68tlf2gkNDIzdVIGe3MJGcIzaLzRKleQp5FT31g8dU2wT0pj2A65igOX2/duPcewHs1lEC1yZtp/XixROeGLk7NG0J5ZtzhiSI2zsJT9i4ZA2+a9nMQJ7Vzu+NS77o9jQw99hTe0buNxkvPcdzdlbBpYR86k3MAZOiQQ2YqllcGsm5xeWsxIV/dJb3q/MtBVeo38gHF+qJp7YOIGYR77l/8aF/0n4XKHP8bVgszbV4T2YtDzsUGRkrHX0ChY2R9iGhYTrga3HUJrIGgZA3I+FB/ZwieLnyLvBr5wnBSc2feHP0Gb85fdOf80E3PO8VSTBLvL5qiUvmHvPCMTexYT80LWm+ZCmJjyMWCxesxWZCNDNHLWRfkoQBT6WPdsAVCQe/rcw+OVYJUBD0Z4l+ungk4KDIjyx5tNQK6GgDRFosyTRZE/XixXPtet7VYmBLxAsuWu8/s8PveB0/yekSejylfmEXLdCN09n316zfWrj4WK8V6nUaDtxSp+jFzuKMFm+f4OtFk+s9gHs6DEH8Xpo7YAEn/pKOjxoLRRMvmkpWz7nZt4RVkeaWswW6sLcC+OmiC5+oaJrbVs4454lCpBeqytdnSraiRpJV6NXSZiuJrdDKk1VWrcN5h8XVwmKQaX+rZ+54yryFKzUUFbYbkQtk3nAgEk8nk+eD1TaarmUqHCII5Q2h2j3+WtLL7uH75vnR11FVHz5/HkZG32P5BVE3X4+5SB1PL4TIk7enIGwbJZJM1Y6VwaFROWxoODDBSS2efBVPWvtQIOLWK6eJxMvSZd+x9ukAfpoUF5IW/aaZpfMOaSttm52g2pgfuVi8a7tRYbE+2FmVNb41KmYYGFyprLUd04wm5v9do+ECz5FnEWUm/iz9d0Bgfbo6qnbnIuKOLt4v6Qv45CViI+VTM8p1d2z/NyBDPFsfD6An8PJNP4IdJp5/JBwC50g5VIuLaXRK+NVKBfgKA0HFYPBicKz46NFp+tfkQ2VwCZtfYEfn8ULZ+3ovgHjk07kGOgh3AxygQLZXhRLTrp8onPKZHgcOQ19z453n8HgSu1UBzIcfQfLklUJlt2WC3/6TtktziJXmDcg7SIsJWujTHXJNQwpezKXlJV7XIYmMdJMIdHkGDL+iT4pT5of2+SYPZ7sk/M03I79cooBxPno3aunVBB2dZmVF44JXiaBM2OM9WphZokVAtB6Z9cgq/GN8hf3P51hI9/w8IY94QOjYj8GGguePmIxV7pXKbEbkNjC3Fhvc+XWHBkoAoe4Y7rgEZbK9mGzGRdp5rfJ1dN9wjYuGMiHMKy/KvPGdC+Yt8USdXnvRENWLnMpXJ7Bce980GGYVz/8S9iYRcbMwwBQ9k67obHUvNFJQG21we2geN1AijhlH+yDEolciUNxAdnnWfNSqE/QxPotCs4LGWl/VqHARFFCxKEJynTjBDsOnui+QJ0+KgakQhmXFbVZPzak1RJVWoSlp8DYNZxvRxxRukrIvk4lNtMa7Ride5oWndGW4xONnCyfExouv6CYVHAdHHBWxOnUO5ZKP+21kpjX2cGjqBIkVkXtvsnUvaczqYUYBuNw0wPwdppnVKLy3tYWpHtm4IytkaHA5egmq6YF3kux6AkFTyyO71Hw8H9WNB9WMzrS4vewFMhQtSdYikKXGpoILGzxX+cEQG3FVuPRveG78AmKx11MMHAtq/zhmY9DpzCM6T0vCfjDcg0E1BPND7nNiZ+0ZPs7+fNB5lJ9eVhlvRamW/M0oK4e4gD2PKU85GW2NRZXXAV6gkrypiBGDANMqV3bshiJhwIxz6O2txkXIqHcVhnHgV9e18PIVk+VMW3Ag+nr5tdsSYMWlYnG+9v7eTi4lDZS13GVFS3uua2x/pxrWFivPijfhzrFxInkInN6/nyW6xxeAFEJn8ofH0rp8RoRkpjpvOFOholdDXiIBlIyADnTg3P63gEbZLp6ofDINc3XhAX6iT2LRIIQ9rGcgsmC+19Y3zoC6dULcTBv9SyLOtXMHNG4DEijzHzxAG0flImv8rtyfYdH5HnieuEJqhZbpxybGkwB40+b9KZwnSgi3r+ncGgwhnI2gem9ADGrvRZCWmNc1MCs3XYsjI442jZXevTBkYOhHNl3meYxTE1NxyfRRgaZhsNGZ7edcbJWoVNAiZK+pNCxfqsqMIl1WWaa2M+xHfZDxBcuSeLvwhHXFl57FRqRc9JxoR7PyhvjcHSARIRzvISiyjSPDl/nXDDGFNXBfNC09Py9CW4eyCfJ9CeuPNVoWThM8IqxW8iq12WnKlenSYdbVNkE1qe107Rxd+D2IZEVQYIuLL89zn/Ceay4pmxknflhs01rlufoQzxJAPd9362Dvvthf/dFR6GW7aku7TaytfZyHt+K3VOOHWbSccIxFv2jHa9wkDaEmqpuOKHOT+pyvynrWwc3cHLgRqhjcDadPzw3j19JDe/pNOGNnLY0nJ82/LQBnnsJRyAvjeRAmL1kbW9EsVtOG88syttSsTCWGMun3yMWFvHI0D0ZY5h/Re74r+MpKodR1thOcyPVqGTgCeeluV7YRsK5athJ9lCqptAWMXgg8L0n/uiBM9UeiPtcMcjZIZ4qQhWGSQxE2BNSYBKKwQDNv5+fB8csPX97VwImdG4XV5BrqiPIL3rR1/Cj6TUXJMBLGGEeOxa9UI2qQNtLPNy1oR+b30sUist4hIRfyLwwWEF9hYU3oJvZJdQwEs92jq0WUcSbBmqN2GHwQChK1c0cOmfmPAGjYfvmeTrxYZNcsG+go/xZtuCVnm7XvWgMMyt+2UzfxbjAFgj4s3dd0+6Qr4B7gB41Ka5IW/hSMktb211c1H7Cfc170TeAjhAndHYt8qh2awozdttEemvrb1tSj9CD7JATKCYC5S/joYFdWgO/4+lk1iEPp9Kz7EywUNy3WWYbce1PfQYBL5C92ify4/BABKqbFsr3E7Qwx4PmMgBBa6BK0xko09gDgtMM0XSg1AFarMeFNQKPXe8gk2l3geWHqwoR6rLMdGaM+GHQqE17qDI+F/ojpnFl121i3bSK/TSJSs9rNH5fyyBjvy7UfGPrwpQ2Go8oAMMugmO9K+jg5Q+1cJnAlezO+vwCqVKQ7TJzExZOlfh1O2VcU3iVqbkmpTavNjK58M/r/eD9xs+guTwNXKznhihAT6tjj6zH208TA1ayYofFnOFP3Pe19+Nnc9a0PEwZ/atCHz2x5tKSa3nM295DouOpDVrmWticVxuRK6mdaY2YTLwC3VI3Zdt/OzHeZeoIeCBTzeKgMkTPbTmMxe5Kyyee7fcJiX7ksxp0qJCMlzdt40mFjYV2xY8wvI42+GWeN8qAKmG0N/GIZGD77ict5ZRGMtM/2JAgKoufsUInkUolD7YVhLk9mAUE4SIMAWaD/zBvLbLQHgDWV7j6dg1Xvd+DroNvI8CkE3nc6ygCf/vaZyKepogpPm/Y+edoCzDZ/0UOhbDM4wVQtLMQwTtHRwovB1lxSu4qvDJIWnF0TPN6X0Zbux6rYuQA6JtTrGtmu3y8OHQyOkzokfV1rPj6djl1ooDUxAXIiZ99phqJ/u0T17mMZM1DSzUAGy1DbAF9Bq6/EeWjeDkOubFS/wl/fK0Ev+ZA3ixhTwPdQv4Fpnf3k+MJKUGl6UKRYkziYA5S3GyVGAT2hEoZXzaueI+ZgVVuBqFUxCWgbGPWlJF6qYRFIinB7eVCikzq6JgGj/EiTnOR0rTA6hXUS7IwOOU6PSbDwNKQoMeGyc9PFw1xJD0PhXDgBC2TjhfR9xseDSA+vlilMuiLt0epmDdRA0hJ0tubfhainrbRq1Vp0uxPlNE+QsaVKHwNfOLGn6adc1r4ZxD/DfTCd3RtqOXchy8Y9HwOxtfhmT3KpvbbkNNNKe/7k9tO1O/6RmXSOWc62d1/LmPhPQ8dPbRmVy3KW3lCyUPWHSet216hNcZyHTpHWA8R8dFGOaXKgeCkCvMNN2p23quRpYatYaRa54M0Hz+yy/Vsm3lOkm+F5o0ViPWbZtny5Lq9RtjbblurXx30twm+0Y9M2gUAAYVG7P6EPb+NN1+1+8aYURGNYYanxo5Eb2FCEwNGvC9yahxlXSWHOafsXIqn8TJwtKenewKob/OgRtOUtSXiHjFLesNKoEM+DWGQnga7a/c6E802ONDlHt9g+npcJu58+ot1/0iguMet3aD5MyCEvDiXQrWK5cONaRvTwGYis89CDPZYhupUsNLMu3HsRN9FSBfJgtCvFsSmCveCNfqPg2BlsJNachUpV3chSJqkP1rIBi83d1we2dZIVxX79fePkbKGM7hETSYHYHHR7KbD0Ht3rGvn5kWJSplT47QOR9xpmUc0FIC3h1BBC2J3iCfEzHs7Ds9Vw4narfP+2anDyJx+9zS2g2nukNTGxw74q9o2Z9DQha6khK1HyuXFo+bCiojWgRByVacQY1CH+HCGfu5X5mQVM8F7adG87MREsUzoNmNTfwc54aYKNrRJybBtb3xFQYvJ2EOCvNHYmN4+XQo4sM8OcJkQQVpp7nyEItgx0zOcVW0T67ntXnhFANeq2iNwKlTPtamjS1gYT4mGqXsfgEpF5bckKp7nqySHT0ZNLzBLsl/8QVc6PTt7NPebZ8X2VC9hD8cwRlmNfvQfGZQuRNVvLN0CEQ27cpjqPRdvhl64MraWWHTavWTo6U/lNodDDLpxwhkgns3dZERWqBGWvnZDyaWe88BTOMUOyU0EmFUQWDb9WrEpeORNvfl94k7yWNAMA7UrQFWjJseUW68W48ZZh7SQ3wF0+ySKqd+1tk6jpPqe0NA+kOZNRxmMG/7dCCs1HJTIaNHZulPyEm2T9FXMDRFkSa+PZTiIyyZQwvMfk+lCA93FidO3S0ped7B9w5a4egh4eOFEmLNgWUUsoWIQVoGdYZNM5ULgmLJr7VGr8/G/X9XPqWTX7YYD0qZr1VHGTDP00CffMvr6jIZUk0oMGsqIuz/qfeoQExvb+3/yvGGOmdCpVAhYGxDR+flbut3DXyjy7pphRklb3xaex1B+URMztFTajHhL7rju9hYWphyP7WtDtlNJIxj0LCq6EMf8LmnPRsp8gUdGV84z9803brAmMKwFWD02YWHQq71Fr9fBzGa2OOYWHWIinaKMLni/CuY/54ew/izO4uuoE+9BlLu0Fa8izF0hfbYgDQg+KepCgtTId2+IQ356znPbni2e0+mNYau8M4z2O66E0fBzkBX1v36QnPoamkHuWGXdAhNNGJ4tt5xd79JB+XvSI3oLK/dwz5uwwAvTZplO2Re0I9mcXDZ7Kkgi4JiXd44wPH30sYBKZw3fiL5H0sfNXQBYVhfDXnwY31quRKbYJyXPxK4F85wnbC8DOEPRTTbNOI6Zn/JXGruOJi2ZdaY36vaTJE2hfIG/kVSKzQu4Xo+B0iTZhGya+1NDjw15evSd4ZBmfTD686WOlEZjUKhGkrnG93z+Pmw1laXQylc865iinDkKPqTPGmzrQDfI3/bBCBdGS0GboPaO1vnj3dFbXMknWOgy98IYEYKYcLu65E8dRKYblqaTgoIzIgn7RU0g6mYGaEnc+HRp/IdZ66qAeo7DS1hgWqlClNStrcCj1w6eK+FZLU3WixhUkfeZqf7ruxJ42EBwpctYwvQXX4QFSMeUX4HZTDReZsPlhi64ugO35RKNlBKREwTkI/OLqVzuSLo4/N2D3ixEvtLssOZRfZ8ENCaRd7UnA9x5ykEAfgKerB2fozCfH6IILlscBg2x4ofKWOxwStHU66espXWS2d3/dCOyAH4+c6XfyKbOALLBreG+xMQTfZlHJyhX0uylLUFkC87ufkKgnetLbjLRmFsShLQfzLp4K5jeGlz9lszIZJZPzPrV1QZKlbZs4huY2s2QZ0ebm6RFNmsVGmJfyBDn7dkoKyr+HLrzT6nNo9lIiBVpLdzcNrWUz4CNXXDSvzH6I81slXk90h/qmY8awv55Jpc2BAUedRNREsVRNM17ZNAJKDYTTCZ7wcS2s0ukf8NXdKGwewKKGK1tBpdSVyzRPKc8hChk6qlrFIUcboJrxrjfT6iztQ0zxOJATQ0dh7l/8nXRRkv/JyrNCO1PEU3P73i64RmYAoJCyWBp/iB6vkDMtVqZJFpOs6htzKVywG4jifxkSA82INXhdkl8+UJZDKWmlkrfe+magkUdl3KqAMNrSFBcTHT6YaqcN/ShBO+vbJ0TFhhWzoNavaL90wwg12kh89+Jz/7MlKzWiZwkUWS3BUVXTCNJPEURS1Gi/ujqsP/cXJRvdTe2Su1Ar4P5ejwYZRh4EhLJohZJk/iUc+IAw6DgpAdWQNsICj4m2mhLxx8umxEyxkuDEbyFAxCf/yoGEhtesvMS3kUXFYeTWsEz3VoPm9oUCM8BjD2sqUxcNWhXFCu5dx8kxKLUr/Uj6qjz4mbwZqko2TU5WvZJX7xrZwkjnsXBqHbcUWjPfiiKaDQCOUH8V2e+cI+6UpUU2eSQwJ9ubPeyNQsn2YPoR1Z5LgYy146xo+atmIIE5ElZ112JT8U6LXJ/rMTiC6dExPY42JxPieP1zWo2SQOYAB1+i8hsgBAWKvysh8bKeWQJkAyxYz1Lyl8pneqX9IL0qkANytXxCkDhTetMeqKMFHGQ23Oddtm5ROsyAEdNeC1lEuQdny9X9naWVlKYimrw0WvhS3JeyoCjE9aYOOXfM2tj6SkW+jI2yUwO6SbV0i7WrYhs4GxOzqV3fNihHdewMcB6g6gLAxQI6BOtnzP0+btlboTVvuVlaaLkLflEyLKcir1rQE1uwmeQemqEN2gTBXQXRwrHB6gyrYF84Bcio7YR/988D1AqMS+RDT5tO0MdzVQWEdb3ttmYtQUZ1mf785Ksgymy7QDh+G+Q93SF2K2kyXmymx1RJYHimfIBAuIp6OE3/c7f1KXvCzCROXKd8RmiNliAgGriifKKN/0Y/n2bH+AP55XLbM+q+aMnpTV2JBPK5ctxatAiVbC7w4E5lPXsukR7gWOVoQO0A14hPUWXamA9F3uIfTvvFkNWx4ZvK2ubJhF9A86E30MuSgUr+RFR68jUT3atstCHMp9m97nim9jNOWOR6diuZ/eIElV/npokuxTquwL/QVgj7jyG/FQ8XQRmWvlSx1HCNw8WscoNEU5/zrG6vIG+ex5qn0+c7jOXxOrCuKBwdfVApRy1SCxHU1b89tS5wKVcPJ0s1p/shlBDJa/r6pjDQBbGdLgc5w0sXzMmnGz1aBrYJDmUBpsmPOOMO9T4EsAqkTV7lTc3OA7gcQp0cwxac4X7XegWgUlsI8PL67G7NvIiivey+SbMk73WT2+nLfgY7w61cawJerBg5iM62wdt4OOrb/YCun0iZ4sd73qzherQ3Y5kCM0zJyG9MAPUyq1/nsxFXsEegAF0+7Q5AAxPlaeMtPMZN1UMtzjn5lTWkPlxgh9zxS9kXli1O5dbBRPS/84jxbvGC7rkPebwxEZH1B8zN7RdDfA5LwKkCQnmauxO3qEpJwoaSSOnX8gMfj42WL6tCC8dUO6VNCFAUIDxrF6xJDmRV8JEnd7hrxqIHSUmiE3sgnTdCBvUjt6gfp7MtXxEEMcgh6uKoAcwTgGcMS68o6ZqxtuOhEn1FGGsceZeOCRq3gdoZYp4z04onQOgsu+z2D14Am+MtOfkWxDT7etI/hWeSiSw1i4lQ5snbfMiMyluqVTOgIXB/yJZbYJ1FcGMOLrlivVXzwjUd6ffpEf78eRbnj0HY4e0JixGHJ/Lkl50vA64qSSXBIoSoMr0mzDCfNBnjUcJZgOB69jy0P7rAoiu0h/JGc9AHhowbxsU4exYQ+oqNk6NezcQELQ1IHhep6/6Rxkk94sfz/vWhiV/+a+nWdNLMnBkql/JCBLyKlG2i93n7CX2VoCj7foNZvKsJcw1MPT2+p74SjOSrO6Z3o093cbmJnE8vp4L7qvFKfrg+U7o4ZO9Iqm0qs/67U/Wg9PFUZBHUCdVYMaTaZNFcJPpMjd9n+W0W/MJ4ucCXqPgm72qb/7YZvfvLBfQKuhtDmOjhZ2dp6IJ9ckSU9ISQ/Ldmb4Hd364Um+ViNDO0ZZS2xDLQrgaHr71WLblOeFp5zjOPsuISw2O1lzQwEZ2PF7PPNH739ygR7PnhRHhjpdhpzlYvOQtpKeGbEO7sZqb1DiVF1QLQVicRRVZOlTKEwXt5VixOrFsvgZf1+1TQex+N1CVYhSfV/JRwNOT0jR2hmu3ijQ+YWh0oPcQxO7pXPzyhduVZWtQ0BGW4gusaJ++YBUvuXcTNnuDO7tuvuaB6u6F90fkUpqfo92+xv7tF5D89ee3dYMhlxrWtU8Zm22yhhEVOy2B/ZauYKiHfV4OqtsO6gVgO106CfXNY6nOY5gcHHPXS+2j8e9hH2pYJw3YatFTFJ2FMTYmKj6nbFSDLxOPL9cItNp9n1Kn0GKNZWynF59UJ1F4lc7M9Rvfvc6EteT3L7iuM9/R4DtU0Gfnu9f/DS8/BuQpFDP/dvmnM9TkkmrcTomaARHn3sxQze7sRvUdX9x3RVuO3vhS08PySodJdyZN6mLLmfsUO1tqlPwHrdnhwR4u2iXNieSHz44djTTI6+VDu5DWM6h6gJ62FZxhlyGMga17nDkfala0t3XLgJL9FSwLuBSGUleGfwuRtScrlqe/iTbfwB29T8HL2MXJiDw0IvQY9hlIw3J2YYpaL6hci7ca0aS9cIIpm9iPC0ff0BtSfFSxUetl98i/FD78Mkbj0T36BLAC8PYYBkUhMub1o2GiFyWfeAcI4bc+tr6p8XbLXeYsEcjv16OdPITr1TRmp0Bb/eIt6aedK2B5kl0zi8eZOT3K2FLUKF2LjiKlNpUTc8lPU6vLzs0ZeCurbMUNJGQg/vdkZRwrRl/XGiJmqVvbCqwiLWwjne2yxtLiC4HexZ0hZfO1G2dndqxVooz2vP1svvnh7bQe2CMz6v7wNrte9Cv815Wv/E4gtWLobrfEAZsu8+8li/EE9kK6njzhJYBSU++py+ct7m6x9a/nF3cAmpqnfshrHJYNrpFWEKFCiz/0QfYV2qtXAuR8d401aS+B7RstH+JfhXoEcz8if0U4KRTAVAI+Lrg44dOYhUteYuw2xRdY1bxr0r7YWt4eHMt6nDARrLxPK0mZk4dVIxkJHiJfM/i6/babbskeoRZJJNRn7rO7IZRLkm1e/nqVxqx2rtH/EMGCgLeCAL7F5o2wMCsbOqAOigZqrzs6VDvLrY1w+n/+Y21+xi4Sw0n5f4x6Qt2UF2t05thOT1zcAIbbnYIU8r+BDaR/ndhNr5Z/U6GnAKH4pcjZNfuqV4Y2Hcq8/dKfN5zQbY0mZJlTNT5kI9iiGPszwxoUXWGBo49pSSFwIRKAhS1TlMNKeBLDPQzu1FLMGdekPbIJiEIvvah6mpfCN0w++YqU2ZVrRyOhF1ip9evTJOpR5tbojwTIWE2WNp3Mdp7WRRKgBVmF4U37N0tyujJDq4x5EWoCeO8wDwpCpm5X2jgnMqayC7rGHb2L75biGTUtmGV6cddm/vpOBXYoWKXmkPJz8WTAhat7ex+81P7G9VpsbUnHYLA/KhOXJ9UGmOM7c+Wn7rno/8h6/OvY35ZBShe5IvdG2TwlnmpHdynnX+hoe46zfNCE0yrGhlQnjF85z+VcIC3Swi2HOK2RbYOaiYr9RwllYu5/tiALrNE3RxbdT5Hncj7GPh65Rutje35Fhd44ERxcNRhZTr1hjXaJXTcdgxxqI0aP1uewBPGkPIGd0DqgkV77e8nM6zPcNEYM3B/oviDX1p8oKe0mJGhjjK8ZxSnsPraGmxBnZwKxy/BDpeJAAtOgzx74VgLqWtsHoPgcee9Q0qN1lD6eTK8AWpSwLQVv6BMrdni2lkNtllkCWNIjNbhT3+NXuxIwSe6TiLZf/xyr6ReqqEtl/PA2aCfkyvtvdrIHVBvTXQ7WStKmCVJz/M97x5WL0OEoP+aLZbBVnDTiKx0hgxjdMCc+ZPqjSKeHoxAxp9rxBIJCmndcRwuimx4lv+frX3csmgA46NJnviY+ib1Z2QEyVNKXlIQZBCzV0LFdxb48pSlK8f9gt6gu5A0ZOx/eo84rSa0DqWvzhirUgbOz1aT3nRpEdGt1+ghsw0o3w5uYtq8GQPF5T0/nSSibgGZZKRCdrl9lqdY6n7G5B6m5IdK2c2ukYeOxbtGzU3B8Duu7Ax6OROJA4a9gTr6tdx8I7DdIsVrUy6mQQVVXs8RtziBwdAog10xslLIHVKFxbv+6Z0q3T8mwNL0u1eVGTx99Qv20eZZnpYlJz2LjVYrIwWsWeR8G15UG0bLsBT79ygBcRNvBFLyMAdzvyvOBunY4FOBHr1RFtESoxH0/QjYpu3YttF49WsH2OL9cxQRxebfObzjZiJBflJLe8pAV2+VUAOZQzUuy2i6XqyR7CMqO7/1tl4lopnCoQFtafrUmzWv7poBRMMfLRTSojebd20RTUsJvr5ZhRmUmu/rhDveN+BQmoo731Fur5bhkVDFcw5qkKHMIt35WykTWpZt416iKAUJd9TkkrDCgRG1z5RM/RmbUXHuZSYmT2fsQSgej1uY8Z6Bvz73SHj/iqKMi1otmGDWM9xNMdkFnhRpdk0keIDrCjZe92wObGBeDVu2ES9FtBfhT+dBnhnxasybfKxMNrEpGLnZ8g/yUzdAmhnk6IgscH/H5M5n+Vk0vpdJuAOv8eF2VS7F4cdiq/ZKWg45QsYOlFEKv8ep0dPJYSx+dZiAwsvbWyjdItvAE/Du4o+tgIxsF4qC2CBKez8Mu1JhSazZjjZkNnZvSj+GuBcZVZcO9b/m7u9Cdtkg7MOt6TWsm8XZjz+lvZ5YZsarbS5CBjyAQRiv5aIM8r2/NTHcEvvO/AuHe+DxTkWsemKFEtvxHqf2CmQdu3f9G2BZ24StfcYlvwyVdY1FSL4f3RJki+de3+TsH35ZtJqiS0zqJe62spI/8vS2jCfF1pkZj9+C8tLoYXXWWheEs2C0fu+O6ezgNF+GBNIUzg4F+eJaQCpvCcibSgX/raIWvDQC/S5l3UvB0gZSPDplqr/VQQw/VImiOLPO6ZksYWVL7LEXIcsa+Ih8dUdPLGnrv45QW3j/Nz17/ZA4dbgWSz65JuqlN4zeWhcmFeyYnQUIWpo5OlxpMOUWW5d3ctDGdNU81I+MozsdxIHjJw9eBr6NUiyzvcnEq5koenqj+XxuSbkfVoyL/n7G9OvEy3q1RNf772xzNaiQ0nprosS2dooL+25/f6SKz/3PBHwkLMlwRXt1vZKHqKzpAxIyO9GSAu9CdKyuB7V4NsEiadJGuQbtcCIM6TuS6b76ltjpntnfN9gx+7uAjjE2Jnk2Gt+wgP6TS2VzEd5vu6N27UwmYGWjGa/jxnV5bSVsyE3LiCwR4wVPRDasAhyO+pVO07qnOrXgIhTee+BS/mYwEGbSXy5bUV4GtiJlqh88SILGWzcojCp6NNDNHV6Hg1mO7hjg9M+0fWF38qhiZUAgHypcrzAxlDLv8Cg2lrSssHTvSEqeYXdZUt9rrxiUoINJSS+F74V91Fv88/fEFrAmjhZw4lIyxmyscAzSfR5UHgy46dwj7h40TPJKt9MHOOAr5tKlQxqKq9KKQ40GW0Di0bPpzprm3Q2NUr3Iz9kup1nFgg61/VIWGYJCDnofnfKq4QHW3SGYxKw3+Pqd+z1BTRtYa/BYKsXHDkvigLFuUHjj/eJaZ48Cnn9tpXmb/VlD/Y6FusNebTWFKta+DgVD0pqraqc3h9x+hn3MtSQcdcniZRP2V6PqRVqlW5v77RkjiiNrCajp4Cq6GydE25W31y9u3ZO8q2OK7/e6H3C0mrt97gB4kkfqSJQ8gWc+cwGDJJP9ljjzVgjnxqb33F3uwM6O2RDZJ4dmaTe/+fQ5hYGHFVr0+4mNJ0l3ip/tXpYLstsxtYsRExoDbGZJN+LYMIaZYmCwCeOuIdjhKMWrKbp+9eLUln6hyBgS8CNkZN4S7AXsGCTfExEuDowAPvzhBPxPOoREe6LvdAM3lAIbeGosEPktuPAhE7uZojABicLX9B7PkBScjDENMSCg6c+cP4QKjJHduNglr64FOySv2004ymFEKRBldmEfUF/ZbBWfPCSuc7Qmzzr7T9jfToceOxm70Z7G05h+s6jahVxDFIAVHLI/PgXqke8M/9P5qvOtfplFBja2rA4bwzaChtiKKNg9J5vldI5TscNWjZABOF78hyz2W99XfuhjO0Q9RbpWEqeiGqciYZ3fpccP9IFl9dQ06FXZkkqmqzVfgYz8kYeyL51p2RtrYfPr5EZWqTnMYbJgcQS9mnf2j6Vt0BYGgbtZNoe1kJw2cm1x1u2q5kLYVE2sV+a4y+MiB0PfSYH333k9MgN0EJQ+rQT8tSN/4yyEDrG9gXWIPBqVaFf+5c8r1TJQkCt/YIxx5kyodf1FkUEKfTKokM4MOimPio7PN+UXcoQfCx1/e9NFRdYo0WUSMMm4F1a3AcYtuY5dSzA8PgrSCHF4/fd0h2rA8Mwm5kgi03MjRQmITBhI+eI+TGms6FmNaigZmBYx5B9v1R9ftxDsz+8wY24pNWv3xna3sCmwJOa/8n+unntIuriXyEVAk8pBds1nyqYqtptRZ2RmcYshpWBEwLoS32qcGba3pt+mTJCQW6B1ZAmWLni0n4Ub8Sao8g5XhrOuCGCBlQINoeAY1qKErsorR+PH2bPXb7jmNiwd/JrapuXZsAGGOQxz2SwyIRgG28qCxbinFxwFXateKaE18g1cXvoC37JuOEIMSoj0KhUgdU/6b6YAfV5OCMkl1ScNmzQvEYHIFTZkuDHBDuw71DcaAEtAGYz96zktsoxufsO6XP5gJgyXsp7Q3/AcZvRdPQLmwVhRHF8Xbr52iCEwP7Qk+MoZ+KgnyX3kftsNDx7t1qxTj3ZhwONpEaZdGPADGAQLjhtGqH4QszjJukhkeHVop5rG5w+xNTtMh+ymuf3fTH6safMPginS2Tn/W4bk29wwU6jGNLUhPm3x1jOW5esEZwmf4yo15iAcCNk3jH3aR3KhOQxMPsa6DEws0JcygVwObbDhO7o+ObQsV1r4Iv0u749hTjrKapmxB9UloCvaPnCddvndt6EYmBSqEDAMTibdcUMeP6yOqX/2qx5TBahiBaPsxCP7l7VL6wpaLUF3F7hte8fhGs+1nafl4DPItMbuHJ0xXa9SPkVFLxlTn7Y9ovQa8vTUej+r+CK/1LCbizkVDgC0gkaDeLon9kLrvXWThI53QYo7xeGRvon6MJLfcnhL4qJiDrbg2l4RFn7xd99EC4ODJVDvR90/090rojhw0rzwK8/PAwlcDuXTSD8ewkdGeS1m2CX//6UQwn0LiT/4tvUZtWf2LhDdKRBILCZLeFh5RWI2DklBbeuaupvbh5AKUtJBqtHvkOvKIOAH/ReE0RKr4cUDLNlr0N4kw9Vkipou4FPbAzAVrtvoFECFPTzoWwl2PmUR118Ffv74wslEthDwo7pkRlel29xVbo1wgqGwGeL6g44di8wZzsnxCSP4wL6gFdaYZ7D1Cm1yrbBIRvUhrvmk46aUEGRvoiEcpDrtizppHdiH24cp9fxxaDfDqIhPU+O2a+yH+OrkUjVEs0Dod8kbjUCekaHdROGjOanCSkLh7ogwavko/n1gxj7CuH+62sqQzsJBG3wREcGgIlvAJcdPzFFlbt67SgDEfUUnO87WYb+d3sszwifHxc2x9RQd/aSihOVTq3KpmNeXwD8pCylrl6El/4pvpIGyo+yAcumhHTvj/UkAef5HcspPA2T5VzdeAfjw+PG/HBo4/cWeBevyB8j+qvBfZ4eBVW5cV89nqCrXwgvAhZfmPnkkS/0cWFwvgeQLr+aTfDj88R2pdkVF60j9n0uyz+cKG6w6iuoLuK6qAyaJKijPwI4FeCDyvMMjngpsPgBF45b4ooGv5qYM5ADyePvEoCCbnSkX9ki5um1mKWXyxjE7hxcfjFsj8nYvuQFN53fVk0/32w1hMR0/UzE7uWLerukabM8fwM2/fhFrhRJ7SbQ9vvs+Fe8H5/Sv6Myo26Zdflercl9rB6h+GNc2yvxdX8YOwdJS/aeGTXNmQUewCZZ/wJaPPagJBXM3RNo/QtLBdw1r5ce7A4iqhoaeaSdNVVOL9H1QkUv3nk6w4VwRUWwLcvYtfhaW1lslYWwWuGkTNNhWb14dSjNhtbP5QXnEpfphPO4aWHZwyEMAxxBbTiROWCM+FBj+BzK+wy9dH7N4UhgslILvRBzZzpyesxHA6xRbyV9mOWAfHkd6Exlewie9Hj9+b8z6KpaMp0lLmjNO8osUNix9s8krreEljs9ah/2qUJpbAOkU1yFm80wi3mSvQJ4rBJCjtIMeP57vIDV4FOHKAnj3Cr6FrYgr+GubtKLBFryB46u2nJ4Z76QnHnUnum5T6RfeLnnfia6HgYquWZNJo2b4NUgE9MbwDwvPDq+uB0s37ezsn7rx+bucukLyTpsjgJDMvs7AbjgykyNxBiqqOhRB9ZiEJruvWtvGY48XcIfBKemOLhT1yKrcSe0g0xAY5h/Kq5PJJXpgP/GG3+yEXBxl2bvl8dJGrNBBvc3T5zaPe+Sg9OK8EVrWUcHHs3Pvz8huUl7x3svbKb0lZ4ILERmyUR4fRM4JbYOoJgzUrvwLiJ0RmGPIyaqPpgkkSvy6T1J4MUUavIwvh4Av+J2g5wKu9eTj3CC7oOlk6wykPBN/P/3XU6eJ/7ChhISHHG1Gi68aHwEu0QhcuuqNpivMgfZgzEUKgOLkBsiSWmmlenvbdqr455Utu6rQ0yKVwCdiKs/0Y/++eDEvlepC4bDmTKbRBUW4xW7N6NJw/Mt83WCrl0V6D96A7WepYArDLaPViPA6IVotsjoquS4QCWU2DMRBUGwADbipLzeDtpfL3JRaWTJrdALYRTAZFWwk5PxHKVcUzrafNXQO3pJKYQuu+AH3hwEp+WDtGxmBBzkFeJcktEUFimyzhciq1n5arkRT0W+caI1HRWPCHOThkhQmqTR1mMIxP4IRLSprxswWB5tTeObCImm5DDns84EuXZCJ5V0OQ02nt7jydYtoKJMCnU3Xgm40WwE/hYqZ5Z/qisoUHtk/yuEGd8xqzP9vjGA3k0Sxf1UyCBRYWSRlbxm4vPmV45GzJpToSa3eL/94Lcuj224rzg16XXXIGPMRtVgw9odtjVRCbN5VHq5QaNNxtL9gc8L8eT1mFi+jH8iN3frBZb/4M4OjmZMnBTv0+E03l6YiUsv7U1diee3BC7ygbDCrRId25IbK8z/Zk2GgctydCADF12KU60CyotqBha5xGqHkN32jGFtODlZzdW1SkLXGTYf7/NaKZxgmY3HfDS7Z89zuERm3hBptVsoove5PEXNV0qfUTRh33AmTb3jmBS89P0NmE0isFa8nTi8qZhcSE9VBDQuijJQSkMYbyUqUDQUR+VDfzFs7Yrf+KmqBG26K54QhT66UCOqu6MIAyevo1CQmlL60UKZw3MdKW/LwaIpZEhsdrYhbPuMg7N55gOizqHBElDyVMq/Gxst3FDYg8Uxcx35U3JtV8XdE7FP7AM5HVTVT/Xh5ApoJ76M4ERDUtKkpYqbbv/yOvj2UJ7I68LVLwU9kJIYHHdONFp4cuu+GAktUjecpQi4vBC++wQPNU4XGjwf5m1yGpiQzMDIWu+vFTHik/7A0QB03VRdBYtCi/72JdEEqR7YRV7l2MuppOS+x9yO6Isls/9cuoxH1RYqiOaCe8HYL1hMML18OOTPLcfck8SqpPiE5rWB0B0/FI/3imW5DThommdWOppwn0SVxMXKIW4Bpjm1cQGp5nddBa/Kg8KvcRsjJk5WlXjhLiJBFsKxcIxgGTOrHyobrwlmtFqYJ649cJnYEzuCYGpJxeAIvTLBQuT28aXu3tCUHX+EIcm9QJpJjuxJRw59IhtMuv3ms9GPGUKiRAYMZ/0/8b6SRd7RoyassmKQ16lsrkeXwdn+jj9m/mfeUh+3xe6mKx3Q4ydDYY9fjCZ6R9jwSgHy1b8bw1kPfUbh/OBihtbS2eBrUrDS4lPXJnbnmUe9DGXeFHyZIEdkb2hgjYiYBloNCOId2Vf0+KT8k0e4myePPFY7v0ml9PTQXRsheY7m8uwWW7kJJWol42ZI27uqJz55GTopTmuvbA9r7er4dnXStWGo9w0NJ9T8oNq3QXjea/bmDnG1lLxXQiTlac8jj+iIXhi31oDuz9PXxJsA9/Q8U7Ek2RURNZUOieACgqmE45dOo3iE+1iWWYOoPqHJmwNPP1oP6O4taSYeKLA00XoeHR6zBhl51ABiETBtzrOKsu+HBlVzN2u4Ved66ygAa7ytxbiY8/ZOPl5vq+sqNOAw3igoSpWa7XiZI60lL2SZ+ywxaNtcozs9422YPfLEiurDKibt0dnhGYSF2oDUH0YcfaigPjClEHPb9Gha5Lprn01AnY8Gja0bYspwp+ZtCMGPL6JaxB9OQ0sqXE9x0FlT8mR4vEjiScUXrH7A6n4eOAODxWYxFTEtA6ob43UF+n0/CmT7UCtPbhZr0vThkTz0vYnHbM9hCbM/Lz04eQVSvqhJ+kUe4Tt7EoRRDxfPeFGwwpAr/hg1kGehPEMoxJkRlMYVZw4eGfJoK2Be7teGWb9ZYbq8rbCA4EdD/v5ReBaYgKwway72n0KIqN52IgtAlrOHyjLzNCv+Sgi9FK3q3QkOFXn3QAbhLunn5UJ94D2JBridhyD70Sfne2DO6kQvNyq7kWZbfU/R+g91UTWRFHqydqY5SZwcAiT3Xjpzjvi4lknr6GIMRBjaQDDKbMwAS1udKLvjyhdNqcncp8q/wCiZt2nwSJDDc7AnHrEDaBgg/KX2WpXhwF0F9JnIzThHHfOZnO/Tv5bZLiDcBUv7Cq6rDCRLYfKtkhl5ubtI0CKKm+LIM/BH8YVH9mWj4M4T3560s4YykbAsVExfJwAIKkqsg01iLre2OW4Zs5H64rF+u4o7vT/fWQ4sXQPyuy9/2Ekz53s6eWWO3jA48utkQXpoELIL2U8tsigULnxNI+dcR/D0MD15l2VWJIXoKA9QtHK2o9bEMmeNXlJVHoIiTPf/C870v54bLSo/pMbWLR5CgvEDrAoAWtZkdKZ5DCwN8CnymS/OLREJPrJ1kEbDRPwY8FGEc0BjsRd/0z2bAUB9CMtYoz2LYDaZnRVrXfWknhIBmBhRXcx3125/0HcvC3gOlO0G3wjNQ/nmg9l6dJfsd81YvlUKwllY6NI6sIJ+Ruv+LvP4JKJis8bx7taEB8GitnNKMoN0A9pQWPnvzwG2EGgr4tvAWA9ufY13qO/U+6KYFrGHXa8RmdoYwnFsJnWI2w4hvSW0ZXNX8pV57JEV/Kie2iakRVsuMYH4Vl5296HlhzGNLVINN+HfQfigwIVKrrDNtTUpc0jx6ePfhOmwkPtOLo0OJ8c2r+wlRJBgzQRn9wU6Lx+b0SQaFK7w4wnjOL//aGCDQnMMD5UnIOhd431bvE2WhDIzbxiUHpyCMPRAS/WcRIdTe2IiZRXiqTTs+pWhn+rKJcxhEmlNsxbNAtlWIMtF9IfXWqt2SYqXIu6l/bveCPLdx0cXtapsAhJr8AhxEPIZVcx9ldckYiLS7EswJSCjACAoEvE/CyLqTEuPqk5Zzlxh3Lcna6n6U/2U5e5DqyUas35C0SQSvgcf025I8d1QBfF2VmD8Cmq8FWnXLjuEv2GPd+0h+Hp9wnoM/5libOcHiFMnFcGpvEWsOtgV97EYzUImVSbj+vvPv11hLaMTEO8rGNAxgQ7kRbRNFnqiFXKBe0IR4ObphnrWiWN77LKuCWQd8J6Pjrt7PZBodIksm39L1t4pgV1dQg3LYv64zBRtWlOTHzAjM86VwckrVX7zgWOeszdf+8o0PcXvo/4fbvmdoDm/+AK4X5496LxXsvFyO3l1YpydmM9HRnmTwqj00JtkhOOLUCIOe+ThHQZVYeaOrFbcuceyLGZR56Z8+it2vz6Mp9ozT76dBBRHCAWX+AmAQnVCdFwmjwDY4UhQFcOz42dAxWVxDRM9m16jGH4C+L2mY6E9DB8u7DvmRkFyDT2+SjOAyhen6JDfi070EAqv9QZSwOTdduNWk+5xTCv/B4+2lWuT8368+saQsD5YMSi8zt3XEMLgYlZfqCr5LEArjbXeb8mYmObX62Nppl1lX+zUig0Fkax5JGvJeFm6ZA8qpk1QF+w4eWABHYAjScC2qfVb3bN30oy1Ck4Y89H2dvz5Rss4D/O88MLK6m9y7h8dTMou5+3dOn3NzqD5zesVUtDQjRLv8debcPjgR7E/9Fp5mt03BbSWrvcGyf2n4+pngzM850kaFgeZELsngZPQhVYUQKt6ihEyV5MwESKtlaw6kvY9eETKXo/12nEv42vuCDjTdN7KTI5DEv2SFk5+RwE+ySCQsqXg8U90PCEliqRaWt9CcH77uqol9YZSRN6Kyk3ib3krBl55wq23GujFDsNUcuIdgueytAm49Z6CtrYPYg5o/FUtOPJWih/eaYWT5i4O9FhctVZZhf3LhWndAPeIofmzvUqaSMB1b7FqVpQvNQ5+ntRqkrdglRadNlqjnOyT0DWvW1WnMp2Bf+Elzsl2NekLRAavkf3ZGzWbH2bU+ZTNJXesPucKoaAph2ih/XDe6qP0N7xw3LKf/ugvSQGMFWufRhXDK1NdtzHBi71OimiTGwKJDiYueqP7oPwyS7P2KAxOtCXPeDlN2QPGz6/oZTCsB/9cUR1ss6uBUYPJBg5y/Zo0wh3Ls0j76v0XBml+/3pfYTi4fcZeRJ8RcQJC6P5BD5scC4yK1YUUNLoT02TcOklYqWWYE5TBLadsCn2eertuZcpznC8SqoHYWkMnP5/FrHjeRsPxZfX8hxxI/rbuNGf1/Ik8trppjiqvyoN2u3bMWXSE77uWhRAbRitkwlKpQiXd22hjOYsG9x8UC8JR1ErtTQH0p0PsFE+JYuLhFE/WX/V3nmfnjt6h7YrZbUIhiCspAMHHR6+vCzkQbh3ZCvjWzr9rFqUS5l9o0uh7LC+d4ZEUS5fnFYdxFJ4olARBI9bHTEgBoH3siqlEzGaqlGmKiDNtn7wXiXwbLgrN7MXH09EVXoHl32dC63+bBAgFQkp/RgyD+skkbcUjR9LBIFvAnQZ40vZC0QFnGh0hhh/I+qhxP+r6HlpnZDRI7K1uhVMx0OgN1Bi5oL8rs7z1AGFkakbsyu1gLNDEETsWIe0Aw+5B97MsH2FwgKltlPfDrpS0f96ukodjGMxSbSaKNJTKptR8ZBHuZgprxaJGVlK7mCjGfmo8p9a5Ky9AqKe/nSEoI+1gAe0CfILXmIhMk5bO2Wr2qEIuBcgRw2Gce8hFSKDgdPKCZZm0J2lFRvdmGDKbrrL9ruJtGzVTHLaTINgG37UJBtEyOue+VwR9IadSQGGBOoacf/msuCTEo9msN/VKeGQcOkj48Ozhm8OXTCXpZEQwcZ64QkIUgpLJREBjacFo98IKhVRawDsUX25x/b2ClKKaXLnfSAv6cAUXh02ejY7kE70p8HfCFyBuGxwCPsrB1OU8jq/ifnLjYxk1+nN7CKwDIiSrGp2oR4dO/HfjUf6J7eEGp8lQ8sSxQNwCV6nNJmhZPleKTrlKC1cJV9CaiukUza9vlC6EvB6V6GRRYSoFpou7B5LMcjLMNintUvoI4tZk0BBM3J8rIdZG1yIf8Swk2mt71xlmIE8nvHbYEWmi9+W0jPzx+1KQ2k/eUQ877roBqzMCdgY9qyDsNtulsOJQb7ePtUpF3+uvIXNm8eE4UMqXXPkDkXWTfJIFvz0NZs6oyzqMMuBB7CDR5QlwkWooQEW5WAS2oXBf9LoKv0UgiKOkhRlT73LjJJsMQyb7KAqgqb/S4OJ/nRgq8ck9caLpT9qEv8NDJrhmeN+zmbBSAbPpdPRJ04Z0QaJ4aGWNS2eyE0YlXxPlMCI973STTIY19493E4jBSPTomG/Hv1RteYjakUG8XeWH5HpzY0ro/UfZrTpGXuJvg+V+NGl7UWqJQ83JlvtEzFXKyIvmY3wna0JBd8KOLac9uQgdFiGankkbVF9T5H8+ll1D85a+a4GnvKtYoAQ9ZJ082bHzsE7PxS6H3fgmzF0weflUccqrbjzUSp9ccH4Z2OFa2PvWchZ6splu2eWXsHLOZQMGH6xDlm03Ukse7XoG79y16hAMMIZC8W2BCoYIyP16N8gO3HRuHESq6AMdeS70kKX6MascxkUkF3BLhA9Ivrlii7rhWeD4ybuoft/0vmFCjDA/V4dIHrgKHLczBZ0RxBII2cuMWt8QmnCqq3hd6u8FXy5+qDHoUqXpgzLDWdhMSaMBWfyFgpz0qg+JTSkpDwK/Z47UEzt4M3k5gOA66Fi12wUYADdz0rz3ITWyPv0MzH0KRYw3nS32AaUWpVlh1oI/NK1xeCF0CBe/fauKJCCszAz6YOryPliQLmssJy89s+hu+pbmYKZU5GSF9eaXPnDjAhyspK55XAxPdq7/LPSW8EmfPzj0lG8fgd5sPNmG3NPCvApLi4ADPD/Cf+g/qiKuDpk+nOP9mhJSsGa8xrt3RIFta86fTWw7gPnaq5/178jO+thPEZyRWw/G+YGOcyPxVOJqRjzsxuvvV2lgXu3+SxEw2PdgaKCNXR4SeaBEHtCY16iJOYeR78bKqTw+N57S7YiNAchm4pbv4/Lt/GGqavO9rAYCFHM7L81nMuJn2Kcdp/R7LrH8gvbVolrEvWogRvbcf8rR1ODPpBibt0j0KIcg6kFeSh9hZtwoqZCc+v9zs0J4j2V82GJDtRC/04NRSsuGe2JjneekZCj8WFv4suLItd8lmQcrYuVD9/jH8/58vMoarRZjhHHQzTW2J0COKgs0jpSSZL8kFRgL5XzkpPAC2okWmUDeNIqMQMVv9M14lD46FpP1gYPrb4IReKdG5p58CrIiRTO65ltqKmYr8ZAi4h94TQGeP3B/qJEvbCvT5271C7zk7X89Pr/7iztKaLJZnnkOaYKp6/zDDha58YhNd0TYGmFwgJve9ygWwnZph5TC28G4nsCP8LQO3bGzGA0h8mjcQ2CFestV1IR1eYMl9KLguMYB3fIcg/1vERBbFqQNEUnM9KXLkPixV9S3Dm48A+oo66xyK0DrklEB0blQSbJHsMgJ4ExACIA65E0hcibfyJY6+gBqKLkY9NPiu56BCPAi/fMjZW30bSGB04R3gAqdRTgAjF0m6fPDCj8ftYwiNzb+qZ3tr+63ambJAPaPx6d+7BGWdOPEZDfqIbx72czhq5WCJNKwPjHspSiUd0P/ju/FqxZ9aGd/VtouCss75XoF4FIgxT98PIxmCwqhQUKfTkJqGvNfib9QWIM5qHpQxtCzwn35YJZyL3UgVP5gWyWMDqff6aPlQChWmg6H4ud8MATb2T7WTcYEjQ8WMY2/vFqGDmoSB1RL5I8UKS6WJokCJXPsHNJsI5TU78dAABRcfnGfTeVEsUdW4FTqvQfKdYGnkZgTzo5iCE8sqdLi+LLUhpyYX/hBU3y0/qZRxDBntk5eMQrUKXaUrIx9pB8QYiMIGsF4PPHq/9lHSpRzKk1qK+dR3lMrcGLnN8dOcE28UYBNsuyYl/An+n39Wt+K8hzgp622eCT9pqKVqwdJvrYRJnAlTRkSLSAAlu9fo/AInkDLECXjneV0xxnc9GHA0WdA+AFaH6Hf74xxWwC0aP7K/QH5N9cj3l43jLCDfL+aIG2ZsPjR6CMSloDbm7Z+BIGhipKPH7yoGB+Gq+NdqIziQb8glchNrEQ2NoF3aFLa81qmjL1EnLl0OT2Fav2U/TyIHg6cc2uHDgvNh449iHryJSrL7hTwyP3z6pP3frYrlmHmie+5pDzHsadA4dBaFcx/x5Eg5hz5FaSXuBVfRSkwHBpx2fewZEzYcHAFRayHLlq0GpPtc3gB3eTlkA/acYiO7VoSOkJBVPRrchQaW0aTm9D3JlzqCU7WK1VbvRHsfiQyGMy8cBqzmLGVfiaS1vonIhBpRTN1uGV+BmTHXumo3sy6KRuMXSlCmMvVxpxkFsrIzLgt+d3qJAxNI3dHotN7PaBhUj1DqBpoWc1bpCqJIjD9KEz+vnK/hzEB0gRd/uDe4x+eOb0uktU8frDWV3lfCeWeINgW/Qst2wbwrWHof4wywQ6lCnP3OQg8zPdho5RkjbJA11cy8vgmkaRRxIa6aUomy2opWTuv70d/O1htl4xA3Ybol0eFAOcVzpwrL16BJI3GTWW8DEKNdixiiiEJ+4aN2gkHbP2E7tKukPft7vNW3jvVUC2cPxw3pHX2I0cjsfCvUM8BRMPorzWI1XzrxnHOtrtgk5DhlD1zzgbP+TnJ1PhAZQjzwB8wZrAWxI3puXi/NM2jIlgRNRK16r/G3mScKhiBCUTlSUWDQJoFwGH35Nac4iQM9OOpopSxHO8JZaOYpZP9wvv6t3lGf8bhMleKiZ/iFXvT4/JMnMZb9s77orW65QlwYv0LIw1qzuz/pitIi3HG0Gzm/kgittfwD8xJOcfSBGfIBSBQ3eGOTslNiFkK0m7qEIzBowfmGrMOKgpGpoh+H3CqwWQVp3kia4gPw4hYCT2QhS2Y3VLefS1V3GQrs3UtfHvf7DQA8+Ze1FjWQh1tHGsJolw07y774WaTf1MmitvLOKIB9hNYCWAjjQFe2al6els7OlKE55OsF0Md/ozALLKZfSoQnZu8hTCgNY5ET5uu44lbvleWeokpGhj8Y33Yl96ScX34NYQOyTgmJjeUSxTnyfY+19o0ZwvgPDeF5Di3Kyv3d5H0sOwnlL0ymprYGHEHno/JBdoPDWFrdgLB8grCe/f2wNhLriCjku+qCjq6SOn4MKOD7CclvG8xih2wGumuQI7TteNIxUsLB8xKt0Q/AVPZ9CY5htQXr2ZeSXrVm+CyqqsM+6aYrqss2WhEcNdEmK1GF18Jj+VOvK3tD8CqRw/1WrrrN0Bdlzsp21G/lHd6QerffGixKtbLejkQ1W43OY1t8QfUC25liOVJR6mS60UKB0a+9otL42GIIIvoXe7VU4Y8qpcHWhcIMbKgzfNhqO0KMzsSNfEQcaWGobnAYuAEwQFEyDcFuERGdTvGr0rrywb55WUh8SF3cqc6nTxfLdMQsXwirBYIvXiK7N2axKE8rtYYk6pyuJjlVGZwbYL7+mskVxkmzSo/IPQzul+dmpZV/DRSMgf82TJD8hnd3ZxUDqQGkm+WK8vE4Rf+2zlKWgbZqNjccZd25x1w2rPpVuVJU2/f7A8ZrTXBBusrF6igPo5alQQbz7c79i0yakDQdQ308pEQRDr0BxX/DUxnGy9MrZ165AkLQ9uRXj3rTelKqUcalxQceqQz1SweRKSPDByLm7XHJefI3bRXHfGFWmkr8rrkhAdsqQ4+Ta2q1L1dyRpszpK1nWHbW281JWOU3eoyngdOM7s4CZ56dqI7UmEMmFomlMX1YEzBGl/bMlhxnwFgIHFa8JOV8qDrNLwkKIuPNyYsJG1h3P8rgwTLmSrZ6RG5k3761g85pveMVohNAekjoulMmkXA9bYkN2r5IsPnzfvJc2+7/daqoIhYCc7e+F/ORkP00/cdxxIigteeio9cNJP0hMkSMRB6c9Uosx0Vnu+YOTIzBD5LRFcW50ISsCrrSZNq+6qJSgiOIJn+eadKH/NpIwchhCWQHdDdS3BZNRG/UvWTQ5z9DpS/KjkoqUzUsvv1d0XdKig9jSWyhKAMcrTXeW1mPWVEea3Hmtq3VqGQ/zBBEel20jhfzPwCQw6vLPtRJj2bzUUgFaRMCBuWLRzREH2n532Dq7gR/OVvNb1MTGNRdBsXqUVsPsy0WwwlhTUNEXluf2gi2fsAMSMsYdUOiIhowWtnqgHzA8gIKp7XfRZxdQNN1Mw+BjGsQQOxWLoPPK64I8oyCrVmXZr/xcFeIDoDMXjhdxc+9AjUyEJIOUiEkk+DvhLU1CLobKxZKAVmS9xacwedChvPMneXD6vKV5FwHFh+kHUWkS+2Rs+0f2YdaWLC2oxQdC44/1N7m6aoy/dTCVI1F4D2iQ9XnDraqRRChvscZlFqMig6D+gmUbSaHRHmMXnoK1MSo8IGHwruMpIPaeyMxckixhqji4+NyGk+pjTEBSoeBsUhGBdYY+ETRZyx/bHhjXwVcBEJXnqkNwnxopqCVxPZ1IcycMceoknW2egRtmpOflrOM4zQnGWySjBVIewX5CWWMwCAIuQ+U8NPQZH5FnnIpl7DiCCzoGMNeJ+B4/P2C/Pn3wkDF6ODOUE7C39iwewfCfreUCFN/svr0qrQkiOExoEnNAvwoKLEPraPGFjS102tz98/+ZxVzCec12NaChjqXZunikdvbibva5a3cO4mooaEAUI7GeGGL4qewPZ/qdmKQmqsr1E+OB0VSXcRSEHcM7m5KLZXcL/LPEH3siS4DUIsPjhN3O1Hiqjyjxw/tBtYaNPmtx9yQOk89S1RVr3p3UtA1gyU/crrLTuFxLYLE/AEbvmqaAzVmSep1SpUw8MWQxRxHho28rfdvOJZmks1w8xduPGQiu/3/Q2WBVBI5nIWMR8phCPS9oZu7rgVO11UkqudstviV509aa8+R+vixj1b/VrofZ0aAtAzuDT0TuB7cqoXXSGPSjS6qoRM1lxgJqpm/4KTTCg68OMDQjT76qWRriK0+UDmfW/evlJvUgCxFe+lOVvT0krB83SdeDXECiYdJ8PKiDBlCdWIghIbdWttNWSiPFssjhk10raRJYTG4KvtcsiLHuaSJZlI5jSi8ZQ+ulslFfLnSQ0TCuepxz5qxSn2ga8/zQWVAAuiRd0hMaxS28w6wrmOW8umkDCEB4OmuLg+YMgWM4P6lMHLfWbMmFp8bwXV/faQdV1n0pG5al78vZD7O6dm9eDpjUTTh07ZeF0cZAJfX2jhQ4NhYjiiVGlG+4cznjgUwivqA2UtmAfMMYI4YvcMJdbahrv0RMB8uJXdpXlBmpBTDeM1gq3StTPwol9QRvlXGjnsBC7+Rfv/lAXroPg/mI+7nkpfBqYyxTulzr3tEUaHSPLG5v8AKUF4irDUqM388+kvtikU4For8TQCItavHzkoJGyI3VnyMRcB8UwwC30aAzURyUHmw4NLQvbFWKOYr3xWzpLJxocgTPJT10hlFuKs8sKTw7MqQ1FepaA0CLVvnQtupTUqlrTprdLDfchqkAuDOI8XZV4gWqPqlkB/6KjmSTH6MJz2cLVf+/ecnqYUgthKYZ2CSBfCqCg/Riai6fcG3c8JdRZ4ky/vMyNPkd4WUJlLQM5XvJOPHyPYJ2/f4V2b/bywkBNLxpeZBreHjs0kgdbkZPfeVJ+MIfdpA6d118wRhzb5g9QEZ/Nt8TbdDnbj8Um5Dluox5L1/r0KMLAQ7xTGJ0HyxZc8vc3usRcMSESEEx4EUcq0vzhnjuQRmiQRr5KR3D8Zwm8uXPCf77DppX9pX4ww/j3syMf+mhASiAkOmhu8Tm2IiKP2gT7fUBXM0/G0wsvtmu9GYSr9YbKpb4EYx+5pEEz89pNS5PaSOJ5GeLKMuEzmT9OfdBWzOtKKo7tRYL+TibJvpfiifpf0X5Eii7V4ilZ70o653DYju7UvNU9q3FKtUmzUubM5zp3CqKqEPOsilWoZJAx4IDreTMI/H0mCDnsavGTOYyqMDKwhXGi5P84R3wGV+6lxAAnXqzPPhnH7wz15Y8u8PZhy1wvtoay3tgwvI9jG0JJD5UbMtkfAv+xG8us+LhCb8W/N46pokc8lhG9uDIc5wXHV04vJvZNziK3izOP3u6oTxdxa0CVVWs/fgwI/yqPDUsMmySo/pKDqBhhtDRLMSH/xrDNL3zg7f6U2V0UYUhykna7HBDkujH0u542M1LvRQXMvX33rmKXaxbfAYkCT7Wunq5M6IfYzLsKWrNB7t5NKL+RNIifFUmDwNBylare7x8g/26AdeaxV7cse1oTIQMGe5HiYqatn91hEghCb5H1fEwDLHItze+McsmTKmhfDgxPxlIRbVH1xRPR4ZXti2qdPmL9/uLB36kZ/7ymHxDElgWGqfi4rR7iSziTYqYxezwGBao4vYO5IxySKx70ahxUiTyVfQLYX2ExrXIJOoFCwaz6e8gASZSKZggFefzUL3jWlzvZmzHURSpqj/y0G2aROsB/dxGMaqPe/Gin6ULE4vlEpUf6vVsCZ4fe2zlzegvN1ewcWGUltJaj3VHeX9krPm03zpjKML2c8BAjU0LaVPs9AwPfl2yb35fZW5qYGKiwCjKvTYl3htBLrEpIzcaMVzX3gGZAP0qrOs0R4o1fJCzxGOOINWt/rHmDGObpMifhmYpfqntwQYgZsR5j/BDBVlEj8KQLdTpxg/L+Y0Dm/OH6hklY+Fhwramjw4DrAiWR2WV61sGHZ0kh+v19UqdolwNp07QiblBEyEAx81SFfDMdwXxuKU+5U6KSTcMRyTRVOHUAVqB4vQVTzvy1o0C7U0TZDYWJYXWzVupTT6AH1gw9xVL+eUxwot/tb7X0I2tNnGe32WnZZeauvI4xirStgJ/u2ukPaECn3WxM4IahdNmuswKXntPFrnSIV8H9UpooUaK4c9gASKtKg/UI/+TqT/gVea8ONbWeXX2Gju2LDrtXHyfbCdkq8oAb9//9RYxmyj1biMRn+25/2HsAYFYntqgFxcA/37by6/6sjLrcO+4oAyj+mYj3FTwA2yoAnHWfavXvyUQZp0yQtvd8fXJaagS2eIBBhxUDkNRWZp5tAm4iU3kW6Be6NnlMh4n+zVOX+TziR9TSPwlOr+lMsbEgYZvU1jOogCH8bjPJ4hQVEO44X8nsSPdLAW6Cjycvv1zbk4A+asokynx4olsRnoYIEscvMeliwRfbi2sSEmuhuGW2k12/Vm15T4IKKqIh1bFJCH55zJAw0uKWw1YWUUDSGdjbY/i/R7cdxRyq7CL56PhCMeotWAH8bz5UNWh062lzyrbViau2ChDQHM5NLpI3Tdke4lBb5pYSkFNbw6oAwGrAaaVNPnURwMIKc3+M82QlvNuhrx50LeUf0pQNXpQ5uwzA4iuQI5fhQhnRhXdd8wAdAVS/eizGuXzNScO4o5BWx5D1lpTGFzs7TIe81JwC5fEyCax6wV//JYBNTEF2mu0vLEYZec1eTrWxmhQ7wIq+8PtOMgZwj+vSG3o1v+SCig1IyG70Ugu8ugHLGnCqAjRiUUFFNr7kGBEF4IM/QonSu78wBwn4SOXN+sX9qw1/yFJLCvKJAjGCN1S31v8XY4SBe6ri3Tl/y7lkdTsBMjy4kEg8a00UXLTexC4IW+9l/jlHRutTYztZs1i6snEOQCDDZzy7WiushsgpsGg6oTsuNJdFttRKTfDED7vjU3t6eKEE6BI0W+vCbh0ig7cXq8WReNlcC+/h/N8mWdHSBcy7j8av6WyxXsSwW88eZlnW+7RqTPYkH4NhKdDXS41yNLbZnb4ywhKDYYItAMOkkdnHm55eDgCLcULwTogL9iaalJX23M7pUZ+YOq+09fYh+cR++lcBn3H8AREJfWnChN0TCXmYBP695jgQlEfTFlnOcuXU3ANjbRaejWBrFVUqAtzFfwAqaTTnVarQDkCVuA6tZi6kaDkFzG7M6lDwcld0FoNzusMvoBi8RMLxjArryc9d4+2mmaMCqimyk3Ob6qvyi1fX2itmR/sVjG9lpVxAjlRqXcgfv4zpj0DVqyjsJDCJWovYqkA+Qs4HATXJwZuYEyLnFipZ5EiFEStdhALPU6ZOiADLGEL7rimW8QWp6fCod/c1pme36DUg3fGYBJIoULNfkLBw9es2E7s63f9BL9YQ5LcjefC5AXqnfCWu76+M+PMmpmtP5j/RUbb5IqRWanFia5jvi71p7xyX8GRvCFJUqqDTyKL3OB/z2JZAhE3yiBtBukz598uwi8fj6k1uzUaVrteqy6NJWa+FCFRCwTTpcENWsNegxVNdvuPKUOQfbA8Vss6BIb+GkF6L63zjVM/e8Mc437jLpDzBlp3rBHWFXW/ZPs1+zY8IfWjx8C2EqnTtC7jKJDFWFkRRfrfHD2M+g+tIJMIH8eJdxBswncAZf/VJlpD4lJVU9WfjInQcWGPOxG7tIObZsMNffpOGTtyVjo+oGB9gC6Ad/u3ifLPwKsOFnqz1QMLS0SdlZgJBXIPEjx49B4w1STmsjB0r0VLUQYHvuKLOHbcUiCn3ZMin+SoGi8KCOAQZs0+POV8INwiWkAsGLtmnzINyM4G9J8yTevp5tmTr4pWfVU6twKsbPHHDPygBbx19d9E2Mwvbq//fDc4g7tNWkAfTmYB1zBUpiiPXbsE/uNSf0djIc2CaPOGl+XHuDqkB5AUAHeZDQRjzgLT6SdDdIREgKWMChJho9N+BkPXwo8/527Z4DJtPPG/JRTvJAjPrB8KhHswRCIJ42bC64mGa9GL5yK9cT35eeMHfxi2SUcjKvIPvTBt2oEIcTAV64gkhKCJCliMgeWz8mb2PjMwpk+X9oMG4611HRxMGupzya+hnqrgZMEjS00+0yaEyAzWcopd99q3CF6/Zdqm/ALgdQp9tdkdy4EyC1N+LDl4FL6Z0iaksmzw/sxhwGZGUOftbDU/TMdOHoLRZrgsjUh4Zp6Cf2l0i3GOuHmaLiA0iUH6xU9PXh6JSqVtQ6hwpF8LcH9VcjxwaCHmUD0De9nJiylT/BX/jjnfFKLmLHyca6sHexzV42mBvoSWuJahlmYm5nIXY/so0qNZyit2+rb50FktyahdQdsHDrpHF6w5IYuylISpOEsx1SzvuwRjvSk1pyfUC89/MX75CQ5+JXhEvAEgwe5AVVmuUFGKhqbFPgWhO2K5Yl16QBXf8n1kN5VQDTfbzpSyeAXFqleeuGY8qaVKkmN8p9MSPPYoL8tRmb+WS0tyMDdcBYK+9naD257Modo9iHKDL94uMbqPFnkVOUMT1INuuQqB3f3omt9Ts11Md7e6B8WrEskJqwkKa64Bu2sJBuMvSS6MOHzuzB0VIH6AaJhueDgUjyCa11S8RTuKCpAmjD9GMswx0QWIn/FUMNnMz0v6zvBzzb6gctzKrZK34wKpC4NBJsHsnzNeNuh5eZXl9bdIPXVEILa3tfMRhUJB7ze/F5lVNkmrPPoxz5r8fLd7GZOjiwUfhYuH656xq5Xb75ZZpPcUB1MThtAzb527ROg1duqWgscz3voFVI/MZmWJ/z0cPXnbf7c2IfjmwkE7J2pqny6KDBNc8dzpo+UXz3KkzIS4TtDzeJQs5endhVkE5ruJzGrPGs+5T17BNgnTSw5GHPtQvxKU5mdlOIzzxll/ixZUGEta4nZKrV+caoWMefP8ydydbMYSgaMxJnmEtQLIea3c+6Ow3ajR86AG88EH7l3VDKCXQXO8ftF//f3Oq2YaXVZ3/563NFlzbnojuGTu7BIyXoDXqNiwjLF/+6DEkwAtR2Wwdn5qzdO4diEehTl93ZE84nwrUTHMmzKHqReFxtKYDLQMrOUWywrbNMGV/x4aUSfHicw0gvvd4nFA3jk5/O8bI1XIj4aLziVDHcGzHQVLpxEgzQpSRjBdSsmv2+mrF2F683Inh2UzbphhIYUbs2SZrp6wO6QQp2S2yibZEcseCU4MgerFuWRz+2lWiFuDZ/zbcoh/D4SgeHKYaaT/IvmWHGFn2dhmuQ9bF/m5QjsWYpsVoj33s22T95sMys/kIHxY3o8BclmEHs0myJLatqiw8EtMjnK86ozanh7A51mWtWlJHv23Lw9eKmI+cdu2SRV1DsHSJ98bhn/En7aZIXJ2nliz5qrVqQM6ARiuRD/jg7I1f0ml8fCq09xWcF34OnS0eqbNYRrDhAgb3otsWpnqWFoFJA9oaJ1Fw5L/0z3sxRUHInDwjePbHivqsKvIC9lrmIX+ozG+f/1a1QpSBMhATpR9rLAvz5q3s1tleRUUOLXBHhAOPwc5CsEK4AYgbqyibupBdhmTvXuIqAICMLKeoUg/T1jbfLrnvgTAnc3Qqb5wEpNYfrXKd/6gMrCtFzukB73K4+UJ4FdRR8wcRAIP15rrGvt9bkwxddO9ojCADExSJMUrZYUT4Ejlu/VJBryjAsbjnGx8F9orCcP4KhMF+DAG5D8GkKO2T/QmC1nFU9whD1io/CiieFaGyWgw45X+axAZjLOwGFPHbiGJZtkXWEIS5RuT2nELO7pTqxAJJWcaKBVAMshiTK1F+5iQYCwUMu3DP7WPIvOJAJpBOfo8A/XPnRVOYsWEIchYV2xAE5axirRGKBVoKdyPbx8qm/PxpwzdtdyDYNwexz6ewAdsI/tJjYDLOX3AvB0NM6VAmah3O/65c/iwCUck4xalJC0/f07eoxZ41VvmPjXb0zoGBA3lxJJrahQB7olVVt/BPPh2bpTxHTVXNWabKKSt2xPCqgGUeXA6656Z4t/ORxUO1zrJg9UPXMOMZQVbrwWeFE4VSKmuBnYcqqxRCmyhj9Q9VAzelmfpB8cBN8wW0gKfcGkFB0t9EGuH0LdjXeU4b4Z4z09k+2f5A+Zosofh0SDN9UKVNZ48G6AXCnhSI++1jNqUYjunm0i87Deq0T4yNjne+aXtWni32Aix6Am/nst6R4BFNMeG8GPfLJ0fo6Cbu0wrzIIaTW/cU0g3CJ6gmP9zZMbFKzNhckgIkxcTPhJYGWFjAYgRdTXiDxlt7o6xyfBbb8MhBpIwTfKvLkoFBazFottRUVIgL5bt/6EFmTOxaPEmW+HGVDbI/erEqXjreDvmGvbfyEWGbSCZ4CMAdzo6JmI8aUhrEWC04bdFlVztRl/bqr8i3XHBcO0lG+VKceYKTv8fvM1Xp+bqXh3ttBACi694cRENKlML7SuvOrljmzThNRm8i0wKjybOrb69cIDlO3GbDFKcWWAqpYnmmDB0usMcoi/7A+4dXbqxaz8zQCijhNaGM+87Su6MGD3k8yYLgDmCQVaJLyIiPCN3oAuf3MRpjq2SUrVu03q6uNPTW9V5pBHOpPeAMqMu6tIO6y+FQirKxQRij8Ua0BEh7PLRhgEXOz2mOFtc5BQPhdHDF5yd05pYjzdc9MVIjt7bROoUCd3ecaSwlK7fPo/f+pP8AifDDWV53nugsxysPxT+OLyFCa0V6Y++HAp+B4E/gtxn7We9jOJEsl3UXLsMbKZ04wHqvJzbLUdqHAkR3dKLW+t1pzbDBLPGmirVC9FN/NZgnITP7LWmt7JgMOAfnC0Hypq58zqugqAAyKdyeKlu3ox684RXLc6/QkgxvAcecZv9uCtMsibBZSWDNuUc7fBr0h0+ENEGdy5t0Hvr003uSUmj++VMhZdKoRiMS7XrmtMzI0m84N6/o6uLl5wtW95xJaY1bqfZYpWs8jJ1/d4vztjWj2IsYrAoj438yYYhr8eFrJoVPUKMKLUX9dPDtboMPu9AmE8lwC2IVx1Q4crXTej/RHo5HPT7sfkB81yZXTAYzuDaDzEryk6KzYNhn55dmAIY4TbQvvzzNiqfe6xhUr/RCH3eC62v8pAlko2A0sbUW9hoEIK2tov6ZhgKhWiMQd0CG4/Y/3XWx80Vi4aZKs0lj++/qhOo8Vavo57cOFnzyQjxUj1w7fTlX0wYTIbRbYJTh8r3XCKc2NyhDf8ff+c5GSdtoRuHTeS+OOmynhCb1t7WRAnHxcf+TNnvk2EITjkZrWNMFKBDm1nPf4rit1AFm/21VJJNCC+024jugp+0WDJmxxAq/rBUwFVv1qJHuoJsxRrAqUIVwDGih6JD+GiZRMjh4QB1kbc2aGCS46Uwg5KCACy4Cer9sgJ9sw1QjPYxe5dnMWL9/3aoMy22L5D983wu7/Ba2Nwm/ia7JQHJF6WOcbzuMxU2fj4tIdSgFAiqfRM/PMvCs60SJH0ELzVavbCIlXHYotTDkz1ndx2RJCk/b/l8JP+9nrREzhUS8eEVQItmVw/l6DOMyA4fwbx+e1zl62rQWG/ipVh/9aLEqjj19LMVeSJmmkv7ECbiYVOwPOigVmXd2QeSmSDxsapjf/7GxO1s5HLmJRI2dkacgFblBhGNBdnE7YB6pdcJYsTyE5GtUtSEtTTweOK9saqbv0z0L/OZK+/5qC4q2+2FuxhQ9IhWbWGP18rJGz6bfxlfi+uG/97LYvLxllRexcMY1WJFqpnHLnJssLMrSHw83WIoArrfTBPXKXFbpnlpzgNQgVswf3IQY0V5WXtZMunoPh7FAfCLWoNLK0tics155ZuHxreKWDQU63GLEFFZLVaeg4GHxM4VrPVwVf2PTjYEj4Co9vVG12zseh6M62Q3SpEWpF4rivRv+dHU9fzgRUDw3QYNyn/bFArI6fXTNFOM1+2hqjVW056frrqH72RrguSoN27yMYKJtTVMASyb5jqShNrjKreHr8VDLaFRVBYf5gT9obQ1g6mr2SJo+T2Tapx5aKb005MfJkwYZEg8iqXSfEkY1z80s8oj3kp7ja3RAFfEGea0so16tXdgaK/BJPEMjD2JZzpXSzHHl8S/1KsAiZz4BRgUioONGGhAOzT5WnaNoCBF/gcs89TWj4Ne12kd4meJEHCph6VLapUqTfkCtK9iSrMnOwDByXG6piW1J4kr7IBiYNiR97xWANrma5KFTc+TQcepUJF6uRQStPC23lNQpw8Za8zK3MmrsLxrGKh0oI9QeEXWjbF6504XLnoPcSFoFe4LIl9VsS39y4R3CzYWx7WnP/XgxSPTS05jGzfrRMsPyau9XWuqxbHSTOUC4msB74OaoRP/2OoSxJfPr1ZmIpRUuu9qsWaXcU0U4RgzxahHx9G4WHWDhFd+00okrHhTRE3nRbcfsyV6XVEPmR2Dfs4EGb+Ny8GX64FER+/Rd8HLdAAxP3lvHpTH2gI2ObdBwIjkLAfLH0iAjEf/jIvyzwHquncjY3a+03magHxsaSsCnF6rFjBWRleGY8nVHtSQ5XQoTJhY8RI4gjKbZLkHN/vsmABfwaU+Idw2xwevz8y6em/4fBa3kpJTT6QzS6z54Q+spPLGifazVt8sIsP1Ueo5Y7gU0gAHtqpaTvaeaPMvOrcsTAPtqprn2luBn6Ukl7unFCLsUrj1IFEiT43dinVs22DkYAkQCZJpVhtSOJoC/TaIdEI8vyx5zRZOW7d7ZGcLHAsC2OqejIhkgIYunyuk2pLxzKNyCoyQZNBXlaKAl0Kh4gmSvQ5zVctAdJ2gm4ZQUekstblbtJEBW2CAgHu1StWuxWdSYA31H2W54DGbZTiDCjm3NFYRWNM0hHNGue9B4yfdAisIMT/zr/0/c7io0HK157TOEyws4mgyddzDXfKZKUosWp0sfLGHUsqal5faEhRwa5WXSDz6KDsrEDl9+xbee3XalhWYFifyf7h+qfqpGTPSZhSe7e1/oJ3tRMA83EfF/8TFP8Ow0tT2nVgVN/XK9aBc5aeNJgxMbXDqW5d2iG1U6awGHmUOTFFowi2HRmXa/6mqW5/pVOWmI5/bhqV3k8F1VZnnsQZVf1mj9jcPLruo8hCzLWF89tEks0DN96tnlSR2+n97vLNDqohPtk62iDWYL/5iZzKKhgKOvlAsyvl+ioTWd/nizgMGiFuHjT1cE37CSffGqVv6U7ah6Vn2jfAbPT/p9Q8mNIS4Q+3jSynt2RgTZ8/fQsAlTgTtnXvY5NVHqH9UHS4wMHRn9rNciXGwdEu0nLzOXi1RHvtozt/D4fUbpYdAMbz0qH2QWh4TC8G+PXj2+hYfTR+NFZrqOPUtqQ7PJuRSmST/+bI8Lj2hxC7S6wkjIYLA7sMbidvjg4cMTZlGHHqLNOey6ptBsL+IkoIk+2yVqCaz35jkExoa817iJCSZh/L9AjrML0nNFPDd3PyHIry3gZ7adkcpf5sZ8mrur53WEvBy+kDJH8d5SouHfXdJrJQmN1Y3zaWFX5wZD3K2B/9mGaW7UPw1dcspjqXrQzoO9jzCu5ezK+4FjfP10+OvTwY5qNw++4uH5JE93WP52Vj3aTd0PqaRA9+WMMUcvp1B/sjebZP0yWhiTBo5H0SMwTMwnDCP3/JY2FemhW5tIeBdK0QRy/hKIx7UWOSsfK/2s09IX5mgBYfW0lUDTRNIs6/u6DgKhgg5mDDxCf6f0ycMSA4QDfmOGC+wpUzTuAHhDM2IrIl65UGvPvqCgKj78fzF/pQgjea5y+c4wxmzYHdomMUHO6ty8FnYToYXhnqS6Wot6ZSKv9skti+XrHhtUBur9oR61zn5CViESC3RHYbsOoLB65KywA2yeowWEt/DqA36zKGoMRbE+CuS+JyqspiYaQdHCzKcRJhXnIzv9+DLRv2dY1iqptu+zZVta2srppsKRYk97dlqx8a4QnaEDk3L/5xIhpqFLGlAYtv2ysxCUlslMryxo9JskczmRyQI5HjNnHDSzBnmLE/sZ7VDutZh3C6xpSmUIPHnbuoNCCFGOCqmUM8My1/Qo7L3OXUrloE4Ic9F1FAV2aKMrAtSjTeKcHFqIqpM1m2MKHG1+t/MML2y/egXTAO2Bst5F+OZeh9KW6pD4V/7/5mlNxlCVIs701DtjYC5sx6fcgYAroa3snhJYSbnNAuQ4IXm9obqC3EdMLzXz4ECTREn37ivom5gCFotZqLcDwr+SHazfFu8E+LaK9bleAjeWyHFdjBRvE3Mg4pyeb6Y2rCpYV9fH1PYORsltZFye4ebuer2BMK5+1ENzh0KXFYDShBhc9j4OalnJcZ6ycJ3EI2DRynV7g9fVHb5zRpt4GdiL/f8YrOZphdf/Zp8mCT3RoMXYCddpFZBtXde9x6czITd5RqT+bQqjHdbbMLTsOiAZzXwrNVVzCbQvb82s1KsebbDat0pb4jhlO6R5MmneW3RT2HRHOE8nBwVZ/33/PVKrd84iTNAqJ0dDnB79BkTAF7lbe7lswGe4fWkaDla+dD3GzjvKVztenccZXcjosd+aAAHZENcH7f/AUy+Y60vpFqbLZmGV2Ay+zHroPTp+uriZoDE5nOvm/2MSIYbg1Ov+YQUSpVp6bR646oZrdTn2jcq1VbwhfCE+St19mRdp60s2/Dx+tX4jRynAIGR6YV4viJ/aIdgvNMghIE2IacQae/ExyyFpbhUV9FEvTgLPbfZZIOduBUUdNhvIBL6bW4FL4JVkMQ/5F/qv10QOtrGaf1a8/CXL06B4F98tZs+d8CcE99tR0MB7c0QCb832Y1YCT4nHqVDDGxVUBo2WbpKy1mAms/6S0QEhHa2D5eFHLS7d580lqjtwykqqYoygBZ4/TUFsYGjfshGtyYetrNrWM9jBcuVZBq0aNtuJnQeT6wlH6esbfehfedhFWyMvi0D1YYNEtwBH7HSiBHXhqM6GrT/Z/dcsoBdMYg5y+yJW2YDhLc1HqgI/NsLGA0Y+1efaE3a4i4Hz4t4NDJ/GAIHmQMKEExbmlM3fvggpiJ9rtCVO4V5+hRCb8PfC7i4+C7vg4Yy7/bDlFqaYQelgCXvAUUZT9bjNOXh57QKB84u6djYMv8D9J9IvTXKDhQp89Q3y7yVA1nKh2idF3px8zWUIf/libSGyWLj/Medx7evT1w2Wyzr2tSBnpS9pBZNCX71QPqYVKwW1tNV/XR6+BobWLLa2LYLsS+BXL9ygzGW3nibo9t2F4CPUOn5bbtmymkbY+4yID+KsTevx5gS5Kwxi/wCmP24mshbPHsU6ZVNIEV0Li/LgpSXNde2kDRafHEF6dccpjbLdU2sZZdAloihQ/JSmSY+98XsKgpPmjCUqpFofK8SZlnx+jbTZhthMj1IR8O75SwD+yILxfuaT3AqMniL1wdGKOyH2h6gT3eqGG4im6EXUW1cGLXku4w6zE6ac+w6fbjTeLzJ+3SP/EH0lExEKMyB0e8pxi5vslvn/fIktQavsPb2Nm6CcMZmusaGcdjUL3+1WwNowstMbhANAEoI9wPRJF8IDTsQqnvpFSgMcXK4iEB9ThF2GJBrEMr8pu1ortmnbP2Zi0GnS4pnsa60KHORo3N51u/Y6qgLKIy1ZTlAO87KUInW7BU04mujdwcNaIywCIY8EBDWtF3nOS+wNdZU8w4DDLTa5ZVZgQk+Kx5Pin6l+E0+EYO7gIzqC4Tk9HH0JRmKf+Vo43VucqA49lEwXwhcSWC3deZIq0h0C8rV3ZrrmttAKajIi9YXi09iG3EvVpMxb7unzkoGLgiYtXsRKPDuNPjc8ji16JrHfms4YXLmu5bM3ggrzuwB+DkzrIN/L0RR8iFaxfDUGkEGnFycQC6C7809ukPfvDr70DhHjzvvGpw0it30E5PodZ2TgjJn+ixI+3JAYvMzAtzKuFoVfG943Dghs7DTW8oYR6CWaoznJr/qYKeqnsyiIUlyXZEwCjrwuEueW1Pr9WZr0yltiByLVTA/5wqnmeujul3mo4/9bAFoo6VFwUvBK5SZ1tNDRgU6/tunPCME2JRjZSKUn8cj2s7+lvLJsNMxZacBwPFHcf2GZad+hm5vXRlla7mhK2nxyEX+LX7Q4TfHclS/BSMAutlxEcO6E4Dhh4Gz+OCsrO8Sy9QIToBHMbqwrDV/sFTHzQt5FDQn+rbwyvbzipuL8AOeczuGA2WChvfukEUqLtPgbId8qiVcF73sNayNqnyYL+pH6jvU12+wDljCDbP13YxwjJB7Q4pOKrUMSIIYhAnSGu1gSXnHXpmalbXmm8C+5O5So2ghuB+Iv9fcJzAp8oHhu/KFk3bR1X3aUIsOGY19QtudhEJTxOL2otPpI0mLyBb0BrDTTeiOPqjqkVXbn7SHAX/1iGn8AksRS8aFQEWXxgYAoDMGwc6ZOKVAQmsSckEqriKktQeDF73C6O7L3GFVrBDFdWIAW6RP5A8QS5pXocvgvB0Y813WsHni3ybUgr3mN+Cx3k7++SdFDL8oBKhOFufe80Q+CYQzhX8c2mce6jpbbIrANlUuuQFAdnj1yo2FhnuuqLwTWmROKD7jTXqrM7qXka0RyIzytShD5MizRkfbpuSZQqDyh7CgipWbuI+H7F+OJpew3Yyue8Q4yA9dsUiIYWVEZz4kIHqSCUTggBBkBs6TMWXjEQXSefDA7fIJVGgb3aS3Ao8rmrsInw2QYhzd6oCzeRQZDPO0tiGTzGlhsUna/6FuGk/DsIdsvZWTXS1HyP/FC7IKV0dxd4uvoa0xrlj3P7UAeiz45ZDWYJXuz/24U+BYSEDr7kbx8A923XltQH3gA5ubKWHtI1iVAvSgAnnSzfpHTE+O6gwdViYPrCHWE+Y2Id2u4ZldSOOTzS00cq1Hud4DoYPgIBUwo/w2OuMT+kc4s+p0GOdSAXbepqlpCKWw01KQH0+LiCtHoAceXM86cRZ2wLImH+ht7gwPAZflYO+QPVoZluTYLpcM7ztnpjZm+YTwZQp8UEJBxHO2Y3+doJsJdRhIgaDPgIY1+koiBcQzWmgEhiNQ3ERwSoT3tFkYDrIJh8c0p7D67N0XozP7YEJ0sxCpHlFcjeXlZwgglMonBwu8xAJSchD18txFSDCQDF7J3wCbwDLkzhLmrzPRdAjzXdmd8VigulbWNDdE97o/5bDCH46Y2TyEkzFQkXtf4vpcLYzoHqGk446SQf1PtW/czy0w3uzgtv+5l+2MWKu41hgtgu6n2OBxPD2qEt2Vsva1Lm2gF6ighRzrJBjOPzcgBuunmPf1o5HdPSC/vGy3YrXSXE/zRJT1Lnfgon3nNN0e7Hx4KA1zqmgkB4qr/r8PEGZtjC5lyhuHVwsrmhPPal4/wzJ11xoSyWttNiLYmsBoVZtfjNfn7jS3/rRMC1/oUzDnVhOIyhYE9fyAbN4T2phk+NqL2mdP41DQqER+U6fzNnIyUC3mL8NAfpWx1BUjYnd0hNBbpVx4ggwob/23NY3Kmv9TS61PTaaUqEWzENm+6mqy95E2cXFpk0TshfkK9MAtjyoFgbekYlRHu28VSt1viOdbbnKN0kntfGT/far3K4T8pBZsYlKqw4ngg4nIT3nKsM2XFa5I3kAwTPVVG00YSZX4wmFMbL1wF9CdfPgqV+HBP+N8qu3drGjIHljUw4Y5JynT/rgNF+Wq8Wb7ptSJJDMzPjC1SVHBN2ybWxOgIGejRnNhsUWg/QaatxA1EuUYh3zMPFPYTwnX2vIN+L91dvm4zY7J+6Few82TqeSDWIsj7w+l/BTddHMezX5t/V7V0FAvucUVCPi1Z9HfJconaRqMMZFVva7d4nf/nZ8g2R3tKKSsuFWBRQ0HZiwSmBwN5EeSD4S6ZcqnuhBov5VOCunp1Hf0eiyxazP2ICK4MRx15EBEOy/qUpdpIhk/N4EvIHh5VZXbkczFr8z18q/GRLmT0EsjZFczBFbFqZhTFBoiVGg6g6u8vz45SYr+BPlUvv78I9BJx4xva8RQ+8oEWYRYoZY35ovVMdziCRHQT0FifDjIX+/9EZIfy1zHIq3ukIx18HxVLGvxe8jWOacoV3Ky7hOIf0ULTEc2InbEd05navevsGKOKD9J4cPLpFDlMSSI+6Qp4T/lBXPZTlXFk6l7tUedWrxHcvpBfKuKzNZYG4cO6jyHSuj9QTJE5zUpgVaEbO4mnaMH1zsRw3DMGELDOQ081HJU28EdwVvuwo7Ztnl9yREjA0FoGE4gAnZ6L/ZBJjoRgkJzuhDxSFkIQ/PP8Y1ke5tB0GZJboJ0FGrRDRZ2A7Hmz3aJUCA3dnQAFkgDOAisq3EPacBXeWzDOWfWzqW3Lr47IwkE5CqPrkSzV5zgbhcwVlvNWDKALbcY+JY3gYmdO1JdrYxQymeSWWR2jJ+bGZhDdHQDmj/hM/mizOX17XvBRhqodiiKrUzOjpfUAUthx56XPaSOPUYjGmjpI9sa6pbv0AWTX7Co0+fPDaAsjzqTC9AefwbVzTWgftFzQJaJIGw4/xCPZ0Kd6jCyJJ03EdR0pxYWyAxYUGiMX4qbPnTI6NNwt+Jx/lBuB+qlm+T7Uo1qmzHfmcnMU4HZZCcWjYfJvQ/M3V6Q60p7gXAPOlJdu/DPH84bZzw1Dl3dxW38T8c1BNMlTlDxDu+tlAb2MC8fLD8NC29OUsMz2tFtww5booXEbFSv9LOh1KZpFaCCj6zsGK8xldNzO/SOsc0a9QSjfRWVNPjYeGEKxHy2HpMkJm74NZxxUkAY22rlZF+p2nR2Is/+/XdKdcwTW401gYZqrnoTXsXHca5t7wXiOfrxu5+0KJRNeVBuQerCqxiPUxAxwh/nX7POns29oGl2hDCFuKMy9ZxDQb9d4ZKmKZxBrb2a8ZRMkkiojLeJrID6C7yDgLfd2jUqgORyTxX1qGj9g0RozG4cmlkBVx3MG65pXj2QnUsw3sX91+1J3psc8GwBeHSPj6ARCfcS3rZYyfGL9a3+i1g1QSFWc+HbNUlLEOuinXBouojXry0zGud/BIILqT/IdTw+7ZpUZaoiL3ZEZ3pogvZuPf6gPsSYof1S5Hru4DiC/7tLkljHHHmUhMEpe7lpLH7TgDTk5WkJy8Q+dVJSixh5rh+TGD1N2e0+UjW9DJhqT6NoNVYycjgvCDMMSB6N9sBHuiFNLf9LIETNvJhuNr2NIjG+3fH2kdSRrDl7Vq3wl6FJiRYGBzbLPSZ+HqbOXIhMGyHz3Er+sZsF97pAW8irJW0rB1lLsK2C7xH9d7ML0/P53fgcNDA0P7e+aZKXnV/ludMfyACOZkZJW4Yu2NFOBNzuk5qpR18j5aGRku933xeIbyBzT1hS6VIeougW2NKqaFBX+4y86z1VjYsf4ypdJqdZvNRWAPitepqedv92+CMVD1VdfTk6eNFhAYq+2HrMsj23MZT+2nUojoncQVP9SBkd4UIJd2k6tyNU0cTmMHt5NX4DVes9ofCZ6NEeZfEsuGtRDsU9Nq3GE4no599rt0Dh36+ohnuJzvPzYDOQJIlWRCStBrplRWD4tiU0L6IaktwJwmvAdr9L08Om+mQCCIYTU1Q0v9KUFFu0dVo8zfbqFLnuVNp+avvc9JooOk9mPV0b6BgM4+Tk/Iz8xyWjU5Fr1Harzw1V04rJLPM8qtNIL5akox7BS2u+2E2yxZvEQ08XlHLZy+Ikgj6Zuf00fmzTgRU65XOcF2djZHM8NYO+O/f0kEagjtkJRhkP9LSGk9U/rSnsoj4qRX+aO41CNu+c0iJLU6YIvKBBGMiEVt0n1GwAr8ctw9xQgKVcE6KfNjs8IlNOhWnnNyDcQdW9KKKm3pyzffAF+L1GT+CCaae7uX5EWauG5JvsFym/91uHXk45uNXM9RV0nv+WQ2s1uFvGekBw1Kvm7cJRc+rWH8ue20QXX30BAFq46EdCUma/WmOodooRDtC0UGdYZezofPZyynRXN0tAk8XozYKG/JrvK1WTdWCyXhbL3dajJM9AGrD4OK5urOZ7QNTJOT7kmI9LFccRzGyZJo18UF7UR4rXdHpd956+cSTBEhM3CxNFjz9TmNMV6Nv9DMkbl+AGoB8l372Jh2ZWERbOwCaxAaPVzgQJMMuuh3S8etI+rKZ4eExd8j4QnJgrfVc2TMalhOYgjz1x/t4PLYmS8WXA6Sx22e/XpJz10MBkerQqfngguX3OMR9+nHJPvOB7y6PYmQ0sYSZFyGQMgUsc12bDCJd2LiTaxZ5Y/vOtBBaTEC3FFF002NXVj6Fms/fw4+mED+xPifabmJsUoMLyuypEOVP9CJy19HTqUPS3G6jysD0NL7Afr2vGtta6uUXfNYwX3C96JeuN4bdIEyIcAaYiQxVRUugNkDBmSupSqhIjsdqnyxK5kn99DU4GFNIz0L82FXBz6sTYWJCcfgzSYZ7i6dYgPnIJYXbcw61kuToDRpA7+6lIFJ+mid79OSIozjx7v+qLE6dmipdDDBq8/yAbDM6U/w+sM1dkMZqJgI0JsMwe7MNN2SpJudS8qfCLnrcyRtOr025TnqcLYWndMscd3Hxg0dlTlrNb6KMXbdEe3uZicmVuxYbvyDOPLhXEmK+JZv+F0RAkBk9Ex+3NL5zF4WWIMj208K6cisdOfOI+dOuNGSr02c0q0iAx0HwWGcPWAYRQMsuDW/NbTHz6nB35GlwlvH0YYcGwcj/EHxXxF8wg9lsYqfM/K2KQe+V2H0sQLvxgAHRbsykKV9MjMhbBnbTL67pRQHT8furne1Bw5aJQN4VGGHLntpoH9E2CEkpCW0bq/gGbD1TIqzmGUQ/wK9RVgiLNcC3aJy4QdBGELNmujA8IkhJvXN4V02rkHTVG3lweEDq4XVCuhYhOkEBgvQAxkURHdnMdhpVjOf9RUoFjXGQPvQaTrVYyMfAe4KqS6s7cs1k9sPddPVVGlY5n7QtdWMN8BG4p8MJTRjfJusJMQRzaApsyZinWxhB5nQJl7WDR7atSX9kz1lcQmJ1tcv171ztwKjlXdUzWJoETm16vpV5jgLp2PFP5Xklia0PaA3RQdesbZCIvKqqJ5HjMvOU7e+H+kGHUnuLkqxDP+YjW/6CFhcDdX3VF9MkpevQa5FT3Igd8rqo429zULmb53GEkxWhzjeaQrd09VMyrpwOhYS7cpX5mhMCntKtME0TmhbevL53bzAiDDKJI4CrWJXzZsQ5NoUIM5omY6kWYDXgWjkGiPTqovZCpKzTttxZJxHwNGKEfBASkhtFFPhki7W3MyjndH/GzRvPOtACtmqj+4iILcNmcwUBeCraM/QE9ts+5AXGbNylgx1Q/ZwpfNYOV6iPJ6d9opUmY1fJXrWo4fJV/H2CD/5x11ZL3pgzyltLmFDCP7i6K6s2P0iyuJRrbF+M3vUQu233KPZYnYLPQ+RFAIMq5dXXEIxHESPlgIlwLBe5zi9pkuh8h01cShhj833Yxzd1D3QMIeSpGPe448GYgWSp02ylB/c2I1HvOCnF6VFxMErfQ5A+ZgAMCiZucDXmuuUkjcWDtwOkTzrZyN7k/ZpiCTDvUpJ7XA3jPnPQlatiLIdx/7OO/q+828zssQNGmxgrnnYpbTWxGS6EebIjB+8L089svJSrK+Z4+m6a5tfd9Qh00KwQZJW1QjcBkocuxQHhdOk7e+IXnOTYiefVc0hEM0PAgZ+jmLTmVxJTlxXGbsYXiO07coY2dI5Q62Wt7BvSkQDTiycK7lVVkZQ1ILBVIgRVS3L/cmOvmnGhLtlYW6KhKz+77Nv7FjQCivTNY5TAivvvm3qapz8Q+Piam0a1QMIxEdbEorppM8b4d4U9kh0XJ15zDfmefPXOdEDiD2AIH7rpSYomUjdJ8pKVg3VsDE6s7ycG3LqxYILd4A9fcELnVKSszRXhFyhVQ9g25KKJNV7wfeVp6FYCB3FA0HlLLMgtCZHC2J6cCNAOGUaOEMZvno8tySbzDlGJfnHkUVFenuu9qOSinzd5qJCbj7rSPr0BieFO1iN7zdrgUr4L5tojZJccTnv9Dw7PLt/dWYkxexei7QWyHla8FDzj4UFuo1UA1z51C3qhI3xZUkAdfD7kVbVLI7Z97J2wsew0I5rejEiuAP9nYvkDe1EcO+WCGApNe7oQMvSRuE3qpbLLLikTUguIwy5gx+t/Ndvh0OTxcRKr2S738BVkjeEjnPkK3dpEIjQz5FuPJEm/v9UqlWbCf7IAcuefmYXmjYv2rkO27wXvMa6IpyigcquOQcHiM3He/h7BnVCD8FLNaQ6UDwO8WsZKXHDY3EQL8yWGN/HhPHs80/Zog+jr3B/TOZby5BmUP0IFHpFm+djvakemsYwJrwsVfRTwnpFsMlix0cREzr3WMmubaphwPlzD8N0WhAf0WiIMTOMSgdncmKWGaJwJ5X8PFid7TwgQ/HPKxifDhFxyci8j/RISegw9GVz95/CVfjekMpd/gDEWOJdnpQK2WwCpbQ22TmoqB5y9Tp7GBZO6lzEMJjhc5meYSaMXTKeX/MFjpobkJPhFw9SIyU2LlomDZVCnn+ucW+/q05Fabq3gdNxwkuAK7qGIu+Ce0hO8AGvOXVXxGhWo6vStHwIEeUnrIQiEJBR0r/ivTV3Zw3iO/9Sc1daj/YIpzWO0klrluDLtwd02YH+Yc0gJykBx325J54irc3aUTowKBm7AYFbF/mrHeX84VHlyHeC/ScYa28d6GolzTEvIBzWuXqyaVTKFgk2d3ZnCKu/dglzymHgldo/5o2dQWUn9VwHlK2/O5MqRj9ghI4CPmW8SNaBQqIJPBTJVPoG/17e63g7jvuGGs6ZvIu24L5a9JDRHOnZqB0Ji3b1nkqLQnl280/k5HDJLcLOg9wNRrlDp+tgOvYXqKfOowgZ0mWReAgnq3rcorZfD1wKwbAwn/onf84sSEdXrvJKUpN9tMfD/q+P120W8yXB0oZH4JrtbPIgaDxY0UUUL/eg3R71B3j73o42OS7Pe8iQoJHCLBRcHWIFryAeQ6+Z4vpaCqiTp41JnVburiE9TdG7xNyGqTU5cEmMDVtIRJ3ZCcPUMpTTXHYlk8Inf0mNeaC0Mr4kctC7J42rlBRvdpiJAqMl9mgIFQuErt/epzylti7IV26o25ul1dM89s98COtXlueeD+fyzSHSFzyCD1LZVPfwCX/JfIzEiVhf3jGnppMavz1bi+RDUebTPZDRGAsGX+1pDQgPAI8Gyxzlgo/6H7n7rx1o/JMU7s/X3Zp/bygNcINyFvQCK4XPEyrQP7A/jeBH/73iiCEI+M2OCa3+uGcVxe7rKmbXWlAP5w9jJDWuIJlOq5fXx2WeXehxZ5019PBZYi98Qony1fvUiX5/JgvqlKwRAkyYnbzLNMdn9VvDpB10c10OnLL7s1FuSDcXB3Hm1VIg1AwqOto0FlIqRyhZE3yRM4j7fBX032nICsZ5Hh9pyq95TTBy6UB2t9w790LgBOq/RkL3S3yyANReQ6AK1ZgneGpSM6s2gENcHVoDQvdoz60efije6SDe5tn8u6cVKxEdMhuupaIZy9mY7DTlu6hTaPmHYMyusGCTXc5MDTJsHwGVcnkwuu+WJtdFxL8GgvIrC7zSrS2eAXPSrM4cJcStG+MFYOd4MqDd98utT015sImVdvY+0BoeWOgCbWi3yHYg9OS7eC+nzw4/YPvzDNrN9+WsvH72TLf+ql/6v3ThSaU5HIdr5/jMpmuXSaWpr7zHqPjo8LKZN0g+a/P5R0lagCYvt8pTC4OLN4WuJKlFcA2JYnkon96LDpJ65QJ8GnhyuxwLsR4rUYjrlGj48rgKm5e1jOZkX7OcpFrofdcaQ66JU2xCwKRuMEvNE83sEa/1w8RPXB63GW/Yu9ZUlzP15oeD7XcUaLpHN+FhlMnKeJ4IDfU+TG96YgO6+H/VK5dkk/AkYFZN07WXSgi/CBZ5n5OFqnGeTNHfaJL6+nI1yapVqcl/loCkqKHKPfLcWOHD1dmn09WcIDHtPdJ2dXPC+c5VlgzDwXBt6OCkY20lXFjyDMh5jZBZZUTFdOJhTgnFMeCb6LZcuxzuM1XqeQnr2cMCye8l9zF53up8Nw6OC+/UlXt5MOLTRxwVWxrfOMq+5WVoo83294ig8ID7CKXpozXy0AP1vOngQlRK8cqXGCY1vL85pkaa4SCObKuS3KgyPeSLRGMXFhQV/mbskyseeGnyf2jRS6Y0baWuC/scVBkFrjGmVTVRI9N19wuP0cS/f4Yyd8SS9fpjC0nozUWmuJUe0ljoF5ayMJpfkdX87qnK5gDDkz7hyijxC0rXilAFaS20ec6IKJL+MrgBA7NNSSpSbSsSG2uGUYyTl+jknRkFXnvovsDEB2J9dXEUx7iNhMBwk3I22Eg7R6d3O61LKJZU6ypObAX2DbeA6h2lTBHe7bkiYFxUvSkPj4fCiOK95w8ZE9jKtCk0oy7HlxqTi6JE+xRhaQOmS0nEFlZ6TelzUiTpGu1r2uuymTjkdIIQv0doQwm7jZcIbC9gRfcQzr0yI7ZpZpWDoN9BhSa6OwM5nEOKhPCx7wnWB9i7N2YEol/yMKWmhJv3L1bfhDhVvcpBytk3AjmUksNg5KgCIzV2egkQ78JCCJaePcNjG5JpQrxQuYGPdl6GK8TlvoBX7zVsegO9mzSeF1RJn4B9mw0yGg94Ag0OijxKBvDMxw6vtvtL8hXEHmxOQPTLuAyAHkQNpLW1P5fhBFw/97ma7vQp0oBxFep60PennQPn0hWfdmQKoR8XDdBUee9GDpbuAYBisMi0sGAaJWBxQ0ULW00c278OqNTvattDDiq/L97/hfHfAWdu8ZKJb2cwEbRc+Jkm/VVWh85lj30il15Msy5OBa7XE6Hi/+5+fkugWQm+4h641dbfPGxoYmrbDx1B+7/O4IP4L3Te9IYb5XkZzd7c8sK3M0mgnp8jZteZF7NRIJawaNKWCz8sQa5O3OHcCML5Ff3tNMMSi4nxxenGTQFHUuxS1HVu9I5MEJ7qXnZ++uCbnFooF2pz+Zf/ANClxOyh3/SH/97TJL9Cyjz+rBDsALRZYV03KN1BrqSlDrYg6+iprTjOv9GflvB2jNleRvB32bpyWChFDR+Ua3mhxAsyStJizD/ojHz5TPecy3JUl33F3+hpj3XanUJdl/8QM1zo37wmzfT3yvvmQhEpOch/yQAsptnUYEAHseLSnN2igIUK7DGEM6T1O05tUlAjcOOaFY0bE7l/6W3Ob1RulVrCAdqtOVYB7+fpuRQymKHKmfeJbFIugp0rLsYrUVYsFl3uABvuSXvJb8WGNC9xvAEEKM1vhFnDVDxu38Nv71KD7bubk99YGbnO28u6ubX4qSl6y1zPPOEIf51qWrrY9TDXcnQRKPKJwhBhU/VmhBoo8ffIBBffsnuoi3Y++XwPcQ36vBpLbX2ey/yhnQg0W28nXfUFWyHp/wVNRScRmuBBaqshHzFhOFKIg46HTNQ00o+qJpbmjDdAww20/155YoZXj8jU5Xgpflrwfoj7DnAXy72nx8pZjuTNPT+TEefhXi5KTqEWuxTVbqGZrjVA6g9ZdkfdCYWijmYAV6EFaaBLdFgfzs3CVKzKHcH+DTyhY9EIOWlgoLyZDMYsiy9lZcAqeLpiAxTvpbt8/RlQlxRUMZv3YriybbndPqVDxIMeo6al2GvcPCRZk6O3UDrQzznpwkmexIawZnCdeTxgUdVU5uf0c2hkwVHtyYZbI77l1Fwn4vgx0GwtHDgW747VwkQOMFNfq7X4JEx7kLguv4BOIBiU++bcJbVaFYmCzi1ix2EFnFzlHhf7RZdXG9ojVs7b5SK6498Zqb4P62mQc066XdFjB7mhwBNH7U49U6uPj1WfGqHVKuBtg59pCH9LQPp4HhuLRiDqx8P8WcrXmsDLCPJJIw6EX4UwjVFuwRJW5IzfLHf40j+mFLPZ8vRnOHur45R1R2Z2/xa6XZZbQ9r0mE0cScTzv98wafN+hP53g3jF3zKaurSM4HPxmIPlgWJOUtIez3O3Ii72B3k0+Oq4fvX3aG1dvegznLZi7JHdaySRv5oVGXumVoPNbTpOHIaHYQvBkOcjKb55wbm6l4DMRca7S9JrhiUE2tysFvyReE+KX24fwcOqxVw6GHSs+0wzo0PaaKn+0s/NLVqrDs3o8DUaddOM851RfVOUQ8E440Q2wEeWLTVByp+O+DaKy7Fqqg8qwgtZ/t4OCVG+94ejKGEZw2z8HZcyvKBvDmjhLj3uxaqrGzPtOzlB+pkvB57vtSZ4TukOgvNoVguXs0Xx9YZ7YPesBMCuK1GigNVnOHhdt8nLPKIAKNGx95SBB2bsmFenzYn1acrusHcyMlQizd7KcwdSl6C1kmDgHEBLLQqrKoBR6C/iiotj2H7BoUrxwgtd/I+kAtOYx497Ra46XUun6ReCcFrygaACjREM46rdgC5cqkc6Y0PaaRgq/7nKX9tbLQHDY3LsDIMT1gZ452KrgxZemtdFD6pZyU1MblHXf+il+BZ2aIKWo+xe1ubJZgHKSH/dViqve90dq1mqFcN+y/rCS+jny2B74pnPktBkcIqxMa5nvVHEecdOGDE+qH+mmY6n/LGSFWd9TgmXh7jsnCER+R8c7ViyPpw+GMkgUBKWwZHoNtxUtFUnju8j39WMlfveNuHvQ5mw+PW1L8q9Ro5iT7U1i/PCmo2YnXT23yLirsxbIJhR5ZYXPI+CKSjTiVgqO8cCk8CGt54xwwSq5Q5TxmsoGr7Jy8sbsmtaEJ0hYicSFu39gNFYggqIvdAD6mDFXW9sAaJcnKKqZNvcBnbz5GdQ8y50GICtjfjU9Qr9qmR2q3SkL5J38Isr9mYl3sA3SDrqGOKY/1UIiVkaLMDbcPlqZGnk9h3NyZXzeEDFxaz/0jvIDVUcstfZlhvQsTZGD8pyb/BHp63atBn/F6dRFFt16qRnJ/lCW6bQ9hgfE797SQpq+tTzQaiC1ZdJDkf2qhDD4oRYRmViadpXtoRwIEpp3fIYeUkqMHqCsk6RwVkWMrFDPFQqEjBSXvIsYFIHzLgq85pe2xM33HLt+GQctyOTqGS5SjOovbvC0yt4wlIYcg0ASz10cDL6PeBRoSm1PUaq+Y/qFMGk5Q2Gu1ml/sk2r2PRm0FSR6p9KvNYurfYgl53YiFaIgDSp/yOWSVZuIJgm5TYYs8/6nttogiRh6kzegkqR+27JtLMs+lBav9wG9Arx92cO5gOC2IJjjt7qN/mK+hCC2ldjtFo48QYiaN3rfFvZQLrW3JB+0PH0b9JhRCyGG69QD5Eu+5YqOzcIUG4zfG/ymKpY3CVV2nN/PxN7fU2jM5LGT2ueUlYfcdbExVvXvG+A3KGmR+ZxdqAZOtkkRGe82M8V5oG9SI+AkzNIaOhtBbiwIpabFxKo0gJG4ncAGs1WAUeKIAJ4qfIYUw9ipZN240DpuItpSU6rkWRxnpY/2+u+dVPncjK13WfvBcPg6CQPvKdfy/1D/Mc6FrgjtI6j70CzAB/ZGeRhG+4D7l0sX258ZjTNYPBe4yGl4U4oFxNzbN2C+NH4mO5ryTioZqYgsa9JZBJkwaI3eGtkJd+MFry4hyYKvcOeaTq2gcrnYFa2fb4MchmUvnms6pplcDwJB8L/1/ZAdjgAKik41RCuwoJKrc68SNkF9xxN03ggghVmyRUCk2Mj5UHIXLqyWJ4/fIsbM4iJm/ArrsUpYcZZcypYNo254RpygIAtMkCBswRNiUFVCsCJ6c+Io8zh6xrvHBqFbEF2WmmYcfvuVRaegl9ltelgvnpdrl5DtrkLJCysRkJZsM0jcUfgiZBcus+Q7v1w52qmd5oBzpV5D5S1zNjQ1Z8FLLtrRcpgZuvIIXBmQc9Tb7eVEBEGntEoGO4pX5ndJCmfAgU3BXIHxnqHSMCMLNih85khKGYdyo6g6HejWUnGUYdnwZjY6raoaQ2cwWnoNOuZ+lsu6C5XqvOnHb07OaSJNaLOY7nCSrvIvVewDrunvXQzoCTNZDHfMLt7iNRvKin10OBy8EU98u7ONU59kzq+QjkuxxuAD/lT3fyI4h7hWlvGcbP+gZvQrnFIpEJ1HXkk7A590ygLSOC0fIuNnJ4YUUIFU1+h+V9zIne+uDszbmx3Bh+jGrSFv3VUFky7QVG5CCyoa2ZzozFqqn79ctt2Dz3+K7M24xBBxo498iydL+h9+MHNjt0Eawq/GFF+87uTLkfeeP7ll5yPMUj6Hl8nmUHiZwvd3RZEtN6GROioVx+VD1YKG+TPvx9djyeHq74bKZC0RCg8//6jMT1TEj+Epd2s/k60Yy2knUmzVIuk1wdtP6F8/VCfqWdKrBPkPpSQVEX6Omu03tF3CFUzf9N1M/hDCJUCiFg/aWxPOa//s3wS1YIuODTFQ1X3DM+U4tRaTMjVveLqCSP22FOfpPfw77Tk5EUxKhsArUa/iCFq9q4s2em8EHGuIEi1Cnc0JppK4rmqWJs4CF2WBV1r/96h1aZX2KCBSpAI5RDre9BHwzlSwNJ364fi43pHQIhZ3gG7zaQI8ejFb+unAFTK3KGj530j3LBSwY7bOmb3qvxzKGu9QW1adfj27XejtKLKYX2iiEqjMXGwoSI8g7BcqagWBCSh2ZbGfhAvtMLodJwdfxhtId8MtNVROrDLOzmQIw0ut6tBX2lIyIb0Qoq/lDnr+xc16h/C/vij6eA1/IIq5q2VQdlav7f2vIsc5K8hDd2osqHJXw/D3mNwryMga9wJ8JFALYP8gaNaJCRa+ZBa3nN3Bj1r/vgJbNw5+ClEOPeMuvO3XIQDWdM27bQLG80g/8pnsKnpaYIFZo4//346ML57MlcycMV9S5n4vNZQX1W6FJxjC8vFQbdIqjiQSDjK39WWYaay9hk0D0DI9IF6c5jOsAdC8xQ+uKlmGDey/01VnMzdqNshHP32NT5dksVypdo1MUJRJ4zorASR9lhZDerzQa/1/xb0lyCx+myBGBitE8jOs7rskHVSXLOMcOy4Xl/smz6X90Vl3LKzCiZNxRrBzetM9zplAYQsW4DJzLDbLdd0eXLje8kAOluIMXVwEH2oivy6azDKxtFHAZOlX6LYfVboDU7i8N9+VsWcrknivHGaO7h8R99d9VGaYcq8cm+0BXy3LT/1iqRAC6qLrQmZ7MPkmNsaEX/lOuJYpq/Mb9P28DEhG34WHZhZ0sXk7ty0yfjRZ1eTY+f6+ppIxFY9e+ZznBy6vsVYD6yQklQl0DZfM6iKMkBtpomMtCaNowcbPfJUXIhgrWnAuS6NMY5wB8fwoIcAkEXOGKC9ebWDBIH9ekJyJ9U8rK5ULDe0YIVzIFjWr0SlhseSd4yCkFIkXxfahU95jjim2Bjz2AlbnoxQAcGEems8BNx+BGwuEMZltgE/qH7NtD+MZxz3QKZ+X71sXvS19LwPoCjSHPke96WiGBSsWMMn+ChreHsVQRs8xVnFZHYS1JPLZfN4dQ7/ttIA0brWFNXicTRDKqljJyN2PyzbbVB90lkm+dtEdg0hNoo1Riof3e+TInW8auAUHVAWF4ls+FcP+GySRyAQJEXUQVGZ+aelYyw7+i29jYwM1L24GMl9hZ+bhyZB7xQ7Je9Xk59A0gA35L8v+PkYR779HRBoLbpihGqx/Zr0A57oXiDlaQWfVzDHPEg6y8voAeROHe64xhcjBYKvUFcWq4ySKlnbAhOuBvprQE7Dy8tVCxR8Gp4gfEg2ysEbWCmet5Z7g4yS5OQquIGip2e9QToNZ4W/0BaRRtpsmFG3IVfzXZ4oWVknqJJb8agMupFEB2HHcH7dEl950lofIdHwC0vZJfH3lkbY07XohTQLEQMJJHwjHG/sDg0iqoEbm4liaCwG7ml60v1ZzvpZdkjx35p988roMJ8d90DEDUxmalw6a7uZ3bEtuOUAKPHSCHfFr3TjBqTjc7r0D9Um32+r+0u1kXx+1XBM8Oe7bXuK+jA/9rMdoTgqqdZO8jRg7SjVWCYZOgJzd5QUvZ4FVv1qHhsSgvuH8QWvm5fymIY5GIb9domLrnFYfpa0ECJ+r6Tq6v108is4lEaPcLY1PIHOncin94lGMenpfDcp/PT7YWqoQrmZV3p5haBGMkagYiAUzvwaGaArB1l9CtmqUtj9rJf4UFvavYG7cYj/pr5rn2WDZ+Kii/EcvzfA02EZY+KkOr7xBdRb0k+5dyiq5LgFCdwx8y1Pza4/I6lzxP2AFcIPuhbxeKix0iIM8XD6i5cR11rTcFXFprmq186JgkUB5P8OJZ66XT5N/1nXvu/j2M7/xiIVG6w4nDWA2FA40pf0Rb/KVXN6iBYuwxy105GrRCQhg4pqnt9r5Yp05wYMrISTxk5XSAEUVE4YeysaCRkSJl5/FmoXjmiLjNN3Z5C3NM7RX9HSrLLYoZ3e6DDqQKUFiWDKxv6LYKZ0RqY2FEa22M1WKVzMEB1LDF3lxZwY3WfsaOdStLr7jGHKTZWco2CELAPhv+abgQIkYqtcsZLo0GC0gTSbKOIJjAaP1zge2qIk02MY5pnmHuYReWvP9yREkVeq4Gcc7+dT8VsvjudfrwZFVy9U+jt5s81c3xuyN7yKeS+iKoPoEU9PNQIvdLzCXSol3v5fcD6LoeYH61LM6i1ArS7fQGwxtCD9b4+K7jx95HCNRzCDx0EE68HOhT5zMSHz81bvTA7sesABEHYLTn5520HPYYLobRKxVcgF82cfVq34EnNf0jtiCyfQo+N7wEsxvZMADDj4LmL+3r0SIoyVi1+GqSnezyL7nQd6WTAgnHhE3lWop6+FudatqTFrOYv6D72oe6hbOQk8qX2zl2WLk0rxAGAfVhpd0U0PjY0HXmOo3GfRx0WcPgq8bupMYt06vEzDceYy+BhmMWw8oSNxYLu+iKUF44DqAaPO5jx629TYmpQeE0+tnkAcGMyNZodLtfMI7Fga+QAdFJnuqyKyOCEXJhN/5RCkfAlcIudSTk4Ry1kgy1AOzA7QNy+KVsM+eLgOwG4C5ARMFIYUVKTGi6rz3YJLES5FtWnfCQ4oq34gwX05QaasqP6tvAm33ZxWA7oZYDotUTftHeEYlzLvQ1KT2Kwbj0z97Brz9xsAhCK/2oGMW+EtKLdYHEPsFaunM3q/cLrnmL+xT8J7VykITzWIApoaexFqesYZEulLtcKDwfKLG63tHSu8ioaVGExNEBQIDfphu82Ni9i/dnex0IuijeuC6ByVZyNJTZ5YoXUaSIn7xRkzBTi70hFlW+9CoT7Jg4OpE73g0NNqthJwShGx+JxeSal24uv4itj3fRYnvhR059OlJirQbQSNBNBNg7zfYnJEOfgqI996nwCEmbpsxFuK1UMe7DZL6V/igNIyH+2VNMlKUASLKq+XQfeoq4j06RbJ5flEOV1B/3T35RxDwNd7/aPEa0lW8xZJe45o1PbuF+dojZqd3aMzXpBlXgZ/pK+xesv1gIfQEBqWzar/QEYfXVp8CNciY9DdCtOw6u48h2HPVQ0wMJ1zjeeGNKjkpbC1HQ7kwgS1qwdXlML3pJlNbGntzwH30aDtxcP4AkpLJlVoYWBwdD6tWLp1//rPyjht7jhySvsAl9Aiux+N/X1LRw4bxUKV/+hoYjkVa4jQW0K8BLM1PTKK0AFZZjmqaNir1HyHzAESoP75IPzuxSOzKIrc/rksqkA4JYlSvlkha+IneL69cV+0R9OGd7d5547Z717s11t8rT3TY5jHC3blz10R7f3OeoldXLQ5fgDYToXkwzlwN7c1nti2TODVQ7yEkHFTEyqECSqr4yorE2Xy/F5nHP5REA9/rTle7Pymy7d3xJwwkyfjKERyljRf3MxPUoM5U8xLK4+tEsM8nH2gdvbmHBdvENH6Q+88ioz9qoVhn1Ks1hgdkCSffxe429JAMU6uI7aAlxte3hHXI1JKyaSERMet7rusFbStLezCBYkbqrTyZUYJEmComqN7bTCvlsRiqg01SOkGg+isEFtVY/tPwOsGs1sUjjCocef4Auv1Z2c9M9xv+bBI5MLXy1eWbDh2wYYBGTo5eMApwpAMQu0ZLuWl45pPAvcXd8RnD2vv6c0zrgQI1BemY4lXfgLY5/bjwJNE3DVUKtbR3I8QIpW3fq0H0wipFzv8AkKgULD0kAKPAPeYiyuFB1xbhFNscxZQAs8Q+2a61eUoSk6qprI6E3CBfrFyEoYzQy1gSXUXDAZmfJXnYRK3cuKWylUK1U2ZGk7XcXVb+JNQSNr3pptpNxg75TeDdQbrJECTWIKeBHb6w8Uyymdr8HL3h1NZJXUK9uvgvrcXIaaYe4dLNqmCPHdHKO/OAieXzhv5gqdMV/yg3wdruZC+nTOdRQuPV79s6G3woF2ocD5FeO0khd1PGFckEsTzHhgKDRdpHyBnG0e2TwoFts19m758rtTZ6CcE8Q14B/9MQbXuHuQ914j6cVp+uKc5wVVZ0xYXZfLFJJ5c8NPnl8Ub/W/AMcyc3qfUQK+ifE+pnaxjqIJ5naiAW6uVjrjJ1E1rTBZP3wDVAMHDfLsE/CC+kBqX0lXJbLF5KEZKZwzl36XIYRJNAys8+/SsiMfaMtOkwP7dfoYarIHSpU6nGyepu6dkoDqKvISD3WCU2q/PD/hRLjN8NAMMCcG0uy7VMMRzY8KjOJMCBQdkdaBN92iY2VTSaZkVTYW9mXL1g1/b/yJDrTOJhb6h0zq5Ti1stisJRuALS8FyRgsMoBsbKbN22qHC487b62+E4Yj3tvJwcLfxylp1iYWy4uE6e+Kz+OkPxQN0Yux1rkfkOA0AbxUed8HgwQJbTc30soSQhEJ7Shck/JOFein5BC9m+9DYqtjrcO8EiO6n6Ei7wDFcEe59pKLuacuw5/7fpJQT5buxnamLiAiMxqtP+S8bccDAARHj+tY1LIl8DqddsPtVbiAXjTXRvJSS40Wt1Ac4ikaISGcl/g4AqPUHX921Vhxi0nUl+jNPKhRpjwlOSL8obWgiHN+sow2zUp+nNo9IrlpSFPf7FwHxLW3aKIVO1LgoknDlOnMU0H+fy97/RM7jqrNG4TaGS1RTpsM9ZCHjySCsjfwpbufQ9PlKCOH6bQ9t8TGMOHTdFk6gOa8oXrPCvW8apsFJ1KdVwmon/9wXJnKz00JiTZ/eLBKHaTT8EISpHB2pcr4s/uYoOgqQBa18IwRsl3/uCHj9Y6wpEiofI9vJTq6I4V2tGgX7L9Njc2axclyHi+xpXU59SJ6I/nqQDjF5j7eeo1lXXQAw0FhWujwLAjxz3DAicz2pfbuICp7g5ua92YOP36ef2kUDJCRxn0fcMY4kYNAp3FE95ZFBvSTqMsTae+0GzhKRVif+yCUgpplghtKw5n+T71/QFyEWnALsmCU6YJPFhna2wvf8NUpCqnhIsel0Dm41YtfXEZpuJ68q7wC0pDPxEBdIx2BWJGlf7IKB+iwoEXqNNOKe8cIVpMFruap+2h5U9WK/Lu7HLbHfsOKngwuCJ2W31KkvQgMKsg1zcz171Czg9XFXMJl8CL/+CqLN2C1m6d+ZHbHLkaxuBVClOXefCnZYRvy33TqRUbSYVRVjsyF4JeO+V1IJ/CWo/F9BsELqNKZtmdYKwueqTGBTUqUHHOr7jtZC4y4pBIIV6AWk3NRaH50vSDG1zGupOgZtx9iTB2BYOv8nqDVtXovPCpd6X2+qoixst66LU6WbN+R2iMVZEO5djEE53BC3MXVvwtcozLwtwmaBfNdy9XpNNN9NEPYwB0zE2hwv3bC64VPOYsunJlKr2Ayh9itU0XahVlj4obAiY4sI0kcR06hyYfnZI8SIN/+bNmRxnMHOXsGebzC/q9rU9QzadXXgEZWx+kxZ8uxaIZOAFfkMr9NRLWtDsxXVPfr180FFrzo9oSE1013CGK9yaso0KVqzblIU06Jk7VNljGjvk2ORqIwUM7lKR/XlIbCAaUbVKQqXY/Igkkvd/y0+Z9Xp85FVbUESi7jtFlic9SHwfNdae3qpFtD0fgwTTAjv+VcfuDeIlP/Ha2gnvFwd1SPnfdh7kTVAREzv6fvYXV8SH5WGpyWTY+8Pl4LSWjyjfl3E8usISKHGSg0GiTK9thadFKth8XxJ0Uf8u/FtU6DjSn71+Ua7J74zlIMbFUU2Y2XAfwrkCpmUoY6K4NHNBvvkKG2lxA6GQSV3/j/rfO6nfrDpn2N1rNjujYdHy3qIL3HOFPWd0ox/Ouza6Is4UrovPMbFX4B+B/UaKhmjR2xNKUDALoHeDwZgv1zWKB42TiT6wBvDwazYafOl9gpXgIQSQke6xJjX+XdiywwsIIlt7XDNUuWv83Y7Pwb/r0myfncCGtncZiUplSdi9AGN/Zdo8FARZDyzEKtJk4bbWy+vkp79vL6WWsKuL3B+jN4i2Ky8SHfa9svhlMELlDnkE4nooEmQwY2MNHH3UP75UZOg8laEFk2deJb9KpZhk5xlDZ9qWeiRPeXtycIKyrIwbszdj7c4JADcIKNQlo/CgybBin1eX1yd+xJyArLVpmCk0yBZCECW8SWBgwVpES5t/23NItL8vc9wNKb+6yGawGvRSfc9QdkypmdCQZ+DO/XkXYutNDNEQ/FjZbR+AK2iv5E3F8WhSaUv2TzAme+FdJvdmwEEOmj4UqB7lFIIE3/CU3kcxfc1VY47plACAaqPM6zf5PNOo94QeIFnIhVh/wKSwUpBL8P/hw+WP5vrnykNtp3Nuji8nI4gIXK9Qogq6E/FTGlcWQxI7Do8PsD8ELaJEqSnge3DZpkvCmXdNsDITBEzOxmGg9E/J7J5ZAR4tpZTk9C3I0+MmL2p3CISNRvp5+bEXnPtYdqCi36GvpyJYeHLsGbl2jssCwRu4I37e2/blAc5q79zRbYBz0Cvkhv59ssbtfpVaXz9ug9LQsSR20LNb/psD3hfoE6pG+0ftz6dBKRxI5z6hmTtWeBUicifnNU2Qmwf9jTOgRUz2skbNjRuqpiTGWTZOr8GB8ldKWbOITQVv3rd0Ic/YrGrtHfdRwCFchW6OvIAWzz4CKzF4C/ClKIgLz+Gmq7Xllmay1d7bhY4UDnKgvjCidcxUwj5vR+cI/Sdcp8AQsWr7Yof9M9gXOXOzdmPBvz8T+sdfmxdMpGQBRmUJtBCh6royWj3gIjiO3zQKavkr0pskFw21PFy6Hb93wtqA8PV7mA9HCNnSmYGCjkmD+uqyNLb+hq13Q154T73ZogcWv7/vMuFdwtgiT0GM4qQj7GvYQKzY/RqsLFPjr2jsSGCN3Zq8yIh4/tM9z+DMRU96DexZh0iAkYCi4cwYlenLiMDfzAdie9aU+T+KopcpaoAn2NeynCN8dz7/F92m4aoiYn8OmlPG9Bce1yoh15wo99rNz4enzsF0l5muKiNyjjFC3DOxRGrGhEPiapBOxBAwWWGVahNjfVetKITcEQrCQFvLbJsH2ekMoSojIwFq1OcC8JtS5mpb0bwvg16tCsflvelazvcr4VbhwvYeoF0Q6hgUOuiNBgHOcJEAT6CfagNPOIA1JiBnpN4gON6BTrLKgiaHlz/YKYP8VwdcMhALjjhqueitpMF4sz99cZRuzvVyvydA/A3iZ6JQsNJcGCdoRmbCzgbAyCtgcwGRC0PjTuE06HDQSYDEfpHynsHFItGNftkJ6xynEjKJiHUwxS530dzvwALSQwBuF78QKFQSGO/Z/zoIPgSPspOkzhRpLtHn+Y0MTfR2s84xr6QVgyx6gDc5HGSAqr5YSqCBFBtN3g2PsIhnVUnL3lVlLFb1I7cnzGen9ntu/ykQUAo5ECy+ox3zIk7ZZ8Frt4ipaewKr0EOw1U88jG0briGY3tLac+baMLBvNoLzsls621I3/1xt23p416PmGz4U8VCRQoGOFlgzv5ZmpsxIJ21xjvLQniDzBMxfqkuJLEFou58R9UX/I/qFOKPqd+1pZhLMLYPkRkggrRs7dSBAamSXGXQaVMcQIV2xzbmxPLQIeGzjLDym6Azxwqch5VeOiOFxC/BBltASPc1lKb/qYEHgCFo8VNnEXVGqNbIY/XceVViKZzsp7mSZs870Np/0xcqIdhM1WrrJ+Id63OrRRYsR4L+dSNrlRxl0mC+Uh7n1W8Zhrfeb6p6LQsrnai1RYwsGt7hxj2FZv7VFkQinZFREvXn9HicwTI39suT0x/bZ/9Motxmb/SIWpjeGaSB3t/7/OGJ/tEQBgb4Jb+7TuWvUOYAY1zc74GyKveFK7+4GcOudkf7fbjPCN4eLWc2RDwADmeRoKBR2Irfimw3X+aHlW5+c3kHVCASkvX8W+vKa/DwDEN/P4PnL28thjkF+RWvtmHJ8wXTodhdLEBpq18/7rc9T67WhP2oW31PwfhlpcHTCVbxDwcYj+q//Wl7niQmmySpx7Ed66HzD9iZ/Rq677HOqLZsQrfUA0Ok7/YyqGBeojVHNQQKx4DrYC3DXw5PssPqg3jWXk55D0HfPizPxGC1yqdUX5U/n2aW3lYYLpWk9DPzxLhSieo6NMof0eqhA/TQaS2MXWhF+Z4vMT1rh4W1XuOlkLYIYtVz2y2ZyU1FF3VZCj/PY4A+ZKaScLbCyr0RkP5vPcCo2+wif1WvCS0/RKZQ+shna+HppN/WA2uYmh7wUEQjChnSeLSjN3DTiPnmZLz7gWyOPDooBtTaAfSEbOJ6ojLmJupJZMX2tKopzxG6d7HFq/ejeL+tfZut72baYjq9ArG/g/ckFZUzc7wM2lwIPAktuRt1W0OWg0WqXdrkxGiLG497+yyD4N7YPKe5xt/+JFAwgIJK7XkBgDHRQ9wLSRTm+SCueOhb9mt4Z8BoVz6Zqb/8C7u1fkzAizttMu7ot2nYuahECYTgHCOmE290heNvsg4j03AzeeF83/3eriHne0aeKFCri3It7P7LNgyxJUWmpl/F/7MIGCtSexwqNLkeiuvpHffCiddQ5MsZlBuWdxZnTSyxmg/53JaQ0PLOOqOKUpP6ckd5/XDnO+9VEM3OeMcJxHWTCWfwYWDplo25DZKrtvueR2fgfm593iFT8ELSs20RiaOKU+d4FDpB9qlmiwsQrVxiF+b84WLsGZX1jCnzzxJfCLfnMkHsU2+jxoFH2nLr0IO4dNrHripgQwFr41wfiWZ6/BBdcXsO3R72iqPvuM2Vaq0iM67ypbNFf8yc2mz8ZsL/wzhzxtE/0GDHOPfCodhY8tFl4mbepVTYGUimD6uRkd4hg1wOdv6y1F3exDufbmoW4LIbsHwV5Mj6IBfRhvzZRG/gL4bhWONo4zclheL7hCno5R467/WfXJyt9CKjGjDrwU0UQGWYImPJO96qdgzkkLtyrDmNrnaDGRMHUTww2ClYo96xg/vleLkq1Ni19AaoHEOq77s5P2j80zx/S3UrSTtwVJmdUCZwGWgOSBXG+o7FTQW+PNiY0BgRErCjuZJkN8pFZrSqNO9vWol3ZlrX3B6bWwylOYWAGZ75HkdJQKRySD0gBrCStOdVZSIGb8ENCXQ/5v9c7y908wX/i1ndb1C+KLDQA7ggHCSCpmPdq7L+YTNJmk+5BxM/qHmV4RAchwZLsQ+37Jg37+nyDuv93HV0LsCqnEhyPgXSLnE0tdTykaQVv41vim4opVGkkcxX1N+gyv7qtLKNf6FxySPjsh1DS+W7JglrJgczQZm5dyZ6rJTubYh8GGe++RPTiK4Zx64HydMDZJvw0ClzJ7WZwsuDGb443VsJxl0Nfts7MjktBbmbUXXS9P4FuiZGaLUOb2vCSw7hQgx1RdkjGHA12+d9SCnUTjKPLf82RCKpkzZIjBCUnf1Qf7S3uWkxUgmTL3nE2dDxZHSHm89tQrimztupGzWDGJ43sgbgVzsrbkiq6vUXbjO4LTMbIa42HaDuS7RJwiAGjnvM5ZvPGVDmNWpYXwuaQ0r9IEdZGz3iPxVy0FFhOacYs5QA1tpoiQZ6kLq33V5zxWyKQDaTIxiJWiBmV9vbIEjffym7YMjrNN50/hquWgh/iDZvH4DryXHdAfXPafao1Ie2fSXar7YlGGrvGX62Sfbk9SQ8b5CvF8dwGcgkGSOvFVSIaANN5031ymn7cGL7K9gIvNTIt8i9255oA1t+juMPgUAC8+Ym9Wy4XHcV9LCqkk7h26oLU51gnPD73aLAX76d2brYCdoz8soayLXZHU8LWeT520C5xlxNt4b0oa2rZl3WQESBRh3/hu/GMsOber7kFa+t/hrzQLngcRaJ3oeavCNt5giez0jnFY2KryhTWLTG/d0/7bWwmF/sV6zHI8KNWIqq9tdgnASVG0lKz0EOprKczhdbamm46LsIk+uNFHVtcDu51U95jrwZxT8r133D6S6TKxe7nnBzT3kFwJV3rQXE0H8acaDATMffTvoMzPBXu7pHVt4UAQKUzg//WOT4/oICZOSuP3UN0UXuQKymD4/Jt47lS6IgtiPeCYLods06JzyExOPGwa/EYlbLvcJBj0oC1M2j7tqJTkvQogKam+IlZxg5tjhBQbyR5taE/KhHES5FoCBzdvcORIpNgOXUVJpxPHYQb4DlFO2+vOlOEsj+GZtosTEK560vpAls8n2UFatNV/h3Fmn/6i3gJbJrmBT7v4Nlh/TtutCJ1YtmsD5nHGmIegii2UXRNbc9BuG7oQ8tmXwrO6/y2s7SP/MVnpmKYukc97pezD3SYZAvnejTFSbvb9YjlicNkmiw8ZR6RlOm0aeUlahoneHjY3rh00DBVd/X85u4CN7tzObxFTQcOM+VkOTm73ukcovala1MNa/lbg3tYm33UuqaCdqBkoOoM0+/j+3BgT9DoUkGSWt/fxXeNsJM8cURk+Q6h8N5pJDIdYtOpBatLkgiB/r6xxTjJcjqOdhOTkfmWK6Q2OrPVd3ey4ztA0VLgqJo9JrD8jppqjJhY96AnNWLYJa8maO/dtIpRE/Vl9YxuPc+6BUjTxc8aVd4XHjFoaIhsSfJMfQ2t+QbFh6bsVuTcLeiMkqJR98KQP1NJESvRivbMo5v+AM+MXnoZa95+q441aFM3/L5Cz0u+5W4KEm8YI0t2px295/5Bm2oQlUUnfdQjCZG7bXaAg4uRol0qm8wCaLkxA64tCw3HSWQlQMFTr9HpBxJSNNdDV/CKHByLKjGGSBKkLyfBko6n+3Y6FB51nrqNTD2bv2Evbbg0nZTOKterbmJdx12pal43nwm6WBXIayvuaCC6MAOBAQUZhXLrLbdahdiAIp+TcK6t6vAvxpW3gO86P9il3dN28DPRv8yC+Z2sUCAX8QKmuS5zeRy2hHDVgR3KbMzFKhyD6WvAr4rNIVWjaWwT3rcgEnBhvppIZk9Yfk6xGaQefd3K6FcOO1UQ9UEcWjA7Ww8i8czdlYZfMOVSfg1Mx/qq7Q1UR+b9zJ2b//JnH8t6IMBc3568U4cYUOu6xkM4vxirDPcTJKECuh2FLNTGIYvmveif641kAgfOx6Kcs4403YSUhUnd4ZNebRn/EWXla6YmfShnGrKPV9Zo5s8LZNyY/7CltOQULSdZ4P+t56EyYglDe4OuCQ/gS8OCKw031Msh4s8Y511gJZt5vZ1FXwtTUBA/fND6zmB7DfItziOjqErQB2vPgww5gnNAmIXMRVOnB4fuQBE4Juedw3Q/H/qN5MywX9CcedGx1LD0Hd5k/V8hFpM0Yf1YLvx/m/QuYh9v/cJuOI5MnpnlBCjLl2cShFpMo2haiGaXc5eheVMhtZg/E8qvlrLqXQ/z4xtY/YMantbuMJ/aER7Mm72i+pqQxWAwusks92Se7mqWq9gPh0iTECuVKtCnsLRsAMREtjStECOHDoXnptFa9DRrFO2zzgOmWFdDa2LU27JRJoEQbgCxCA0n9KngXmGqMkAhKgrZgBG17fOLiWpTYJc+kNzF06y8UjGZgCmNwRORUqxsiw9duTprXu5yy5kyukit5tiW0gI6l4DKBrjDtjkxyAevyeqrtYMoPnQUQd6l0KAYjngNMO9taATWDA426ba42IczdqIb865uxVeqIdhLZqJCfzjJQ0H9N0v10Vpf/uIBE1beTmnLaeNV8jGqAFjvVycP7+Rt1hqYFyyhy3+NiMX7hyOkOrRFlsXK810XYz4Vq4i0G2mSmba+Qss7hP9v+jz42FsdDHTRWtazBzs9911q/QaFtM3qn8HYjndRq3ouI7PQ0NHwhKbViMNIrTPjWJ2uIvXt/9s23qPL94BKpN9NmL9pbJX4USkNH+D0YJQbsnURFTPM4T6sP2ClcxP5rJ1Yhfi5PP1dU3pGvp/lRFqCaOjSz5ebgQblavgtwyYKvfA/SoGyMq5LZ45SsT2KfZDBGRVhfgsa0yU0Uv6BBqoBNTTzSErDCzM3h5Bf9htfmeTo+RoPzbQKm6QutjbPu2K4HAHz2rWv82UaP6zruQH17g+UcRT2gNmvk4DwlH5e18gDLFTFWpj+dSWKjUaVqPL0PGVYw6EXRn8qENUZiNXLHxlXIk3aOb9kXRalt7eZn36UczKSWBl/rrhK1kf2jqxRol83WEk4xF6uvJUeNJMBbRciluJkRW7u51X4DRmPc3dK1SmPE3qvCHdakY1KAZkJSbGcxkTAFdZkrkaCd6+IIFAoe1lCFKE+fqR1SOYuCcZQ3rPfLyJzr7Ap6XQt7AE0Z6Ikwv/PMkGx17p9hA42oGlNme7n3VK9bAclcglTAK3EXtXvn1TiAXmSRdQ8B7ORx5MWemnehLyy2e7or07ZheaknV01c/Q2f1gZeVYv1arN3arW8/hngxZ0lgivZmyVfJbC0aXB6Ut7dKgOn+K9Sh4Qbm3NqdiLIzx8E1X+BJ7GnLTjyK8Xe/b6wa/9h7qcEKeexeNj46SbxMfmp63mlbUkOkSg6e4Uq4t2Bley32hIMQLTpWOgRxnxh/f47r9eYNk087tMsY8mkUBEodnRxbRJKAEGf3EJusY5PpN3BNfCwf30z9+LgB0GFUOmSNMV4qsHNdJgIVd3WINVynSYvkvUnFGiCA1XNDY0/7j+vmWIx2vrb5aDqnYpK2lOEOS+Umvl/7ZCCZTlxcXjfJM538MQGFjQFcf6GCMiANwUEDeMN7igwFx5IfIkgVMWeglWlNUMZksEt52L4eVigmcVGssXIc9wGoB7Caqit1G2f6G6CSx/a/szNcvANHDKAPSJrV/892P9RZ4xxFi6KKil9sWCVQkXNDgFSPjO1vfp1GDMYnp19wHiWnDloDr7lOQxpSEfpsUE0GhEle5pdwyoAprToxiHw+Tn1WUMRy7451IJrlvOUQUlP6zqp0j22OjyPgembTsANELXqx/9K3VGgwrg9S4E1YH3w121/zaRFhtNne1aW/CNlygerANfHkDKi0itECREviy13WSDcF/VArIPiUNKGNze6n5dr57DqSmFu8tPa76E0SeVUb/iWNtdbX68iwPtzYyDT2mgleNYzTqqzYcDm2HWD1D4/ySnCBSDFUymddv3OIoyppedTAQMqqoIpXt2usEC0ZL+ly2iFF0cy4t94bF1udxha6ySStDQ/vMZD8an8fx+k4DWT/NGmHprnTh79PdNuuBVvWddHOQD2J4VtdyaS1EtyEyPxIrr6ueuX4GFDWk+ju07tUrekoQNk5tW0Z1aXV/feWzldxELaeY5onNWaexO5m71Gl6TKLCeEvaU+s926jrpQAcNDNn5AAQM5dTjhQUTXwScbAEGRLG9ZjsVjZ8WxCDIYI43M11IcsrMeXQaUdoJ+7ZjrSCXP2nNZnxZldp1ymSNpDTMGPZzmse1OuK3OiOHb96rAPR6973j1HUe4DsiOgj7QmRzwI1ShtvBgsjEmx3mw3zLS6xMXHZLs8KGRkXIgFCHvcMF8uw8YEuiHfiuSSsO/UmkfxgFFrjmUaeWGoD/giogZEFvpz+WT3mn+CVBC9UIT2sEAfvPPI8Ky/WNvUAeBIZgXAQ19v+bRC7XMV+s4o6SUjlgSnMDVg71nbCtxXsFXwji6s0BMue7tqI39QoQ4Hetnv4sVNHrx0AyYBqmzIf6kbuA25lTGOR/tb/RneqBu0+m+m9t8WzDGm9jF/u+uqYFN1DmXnZmBwCjRMijP+3oHEaF2gDa6Iku6pVykkWM2bRtYBVsJCN5QKSljdpBxI58sw6hgiduhXpMTql1vr/y+GSB6cWAPdLouvYet7p0WkBTrbb9mPiaMRUTB1+d+AA5IuHGSvr9tgnfShMeQogiUq77yN0lq/Tue5pr4ESfFcpDwANMsLUe36AYsgcvkZ0DzxD+B4FAv4eynAWfDOekRm3L94kyzOBJhNPfPMSKvaEdVjpWwN4A+MaSHZl8DZkj1lWLoO4XWTkpFo/eeyUu+XWvasyCNVFQjkYQuK8acaGU5Vg/IU1Mn0wcg1EjVWnPAmKbuqAMKqflnmUAL1A+5vx6id7ec86jpmiuQAghMEcddNpBHnJg65HCDnW4PeKfRVD3fT/FkY75jiQHvPaYqPaOOw3YpL/ouAETht6E08fQnjGQNWz82TiMUKOTeTITfnmPI/3qnjZHmkiWr4l5SVPfDcGSlfzq8c+X77brP7BzrXd48uYEi8bGjYLkQ2iw/rUu6IDxSn9vfDTTHV5lKq/2q3PbyRTP4DCKFIPCNtDN6cDYdQRGqzl/2FeA/KWRyz5BXsyI/9+pp8hTEoOT4M7o7SUw0ZJQ76R8kkLFU2GbKVS0dUiLWLJ/GLBaz7O0PoSNrapUZCme8dEbYFpW6L/aw0q+W4XfWhZuFqGrAfY7WoDSFFq4Ov52WL1+2lIKK8WQfHz7ioktoappTDcqb66Q61VtqJXpvbqOzexJljrOc/ZgT+F1itKtmvq1n3t5S1p1g1iIoDFtEQ0ZOQBAnq96kt5Y63qB20E5p65ur/u8D578n664dcI/PmEx9HYHCHG5y8HidPzbWotjEFVEmj74xcAReEwS3azwSQvcfXgIfulPP+G1MsazQ8e5kUiu1pYSNCeyF6v93qr5IkiNzJe5x0N+l9WnHKZJQnzEl3TDVrfKZl3SR/AflHmvf3VM96bO8EiumFwjPcP9H0WTATK7nrDobOHrMJGvlkqNFZbzbhZOURnKrbDlhmpENoVpyKWfYT3gkbr+X43adzl3v18owuqkg/2bqET57qhpZLOWoEsamxkZOsSYMkpDe6mVe3Eqd/nbS5PfDHgAV4mFUFuBBxmchFRn0om+FUQI0wb5FCZbLZ8UN1yIqdcFkEdecxoF9chsyEdTadmO5+cIexR8loeL0B5A9m7AwDujCc57iiGRcMZYQrQRWZcqoWFvxmS+EH+CehRuxmWu6AwPXGevvpHXtCRJue0UZvqJSnSBAhtt84y+ufnX2LWjRLKhPrU3g6ajbLuPoC5A+B/PEG4N8inpAKoKaIPah3bprLe5dkxNGV5MGfPFabgvVe4aq/YeI4Dcejs6rWvwhysJVywUQiCQ0zA8h+wN46F9QSZrJC5WADgUR3qCH4Y5ORlAuVWmRX1/uPHP4O/U0dc2jKxQbJr7TM7gy4lajMNvSHvkpNrc1w15TVPSyny+xJmzy5uM50snymFppEbSxpRGoiTKLgu96TMG5HXrYKeHdv4ajI3lubJErSHXdtSl8z7LznQAVFU5vw+bm9mgbA6oDC1Ver1W/Dvzc0D5PrKrsVbH1xn73yLm2l6+GPnPD02gt78b8MsBb3lyFHtQcd7jc3WQ8ajMg0sjWb58enErEoxk/TFITXdGwYuCcM0w5hiEu7KJOo1kR5UuRfQdOrtLyLbcQ1SHLC8fUYc7ltQqQ2PxPm3EgickjF1Stdp9msH5xpRseNvqUcBw6ffTEvfHuMB02IICiH5BqqjEcJEF9c20KEkvmGsUpHMFCjcJ8H5qFlZutRZteQhRHGogqJNU5sWbFn96F8mJcBkUlG4WH96fJcOMgmnVY29cqNVJdMyjDL813yVcv4+bStKpPtdiUVo3AxKXEiuhblXLI6c8WBrWss/RH4L5W+cGDIiUNM3ER7CFZ+8ySZTWCrvFA3cFtopCJPg8TWEiylQZXCf1ckA03V0eL6cBVAthe8KsC4w/LIb2krR1Tsq4lvTK8BTbN39SikEYRBkycZXiWlmcHY9XJLVGVRp0qbpAj3ny4FK38uC6kjRyOsApYMZSq4vyHRgSQhWcIEf5rWp/W6dFh3JyiBkyYxJJ+byS8T6RRy5PlnCPp8pwbGeO4RUL55AVp+NT0vKJ1AX4dsf02txaAZaKC2lRWR+qtZ1nET/jsGaxQj98eoo3Nv9natkf82BoMa61Q3pCMFClOdrpDbOEfR+ku758aFvVcPIwcEtB4l6itoxC6ZEZ76ipTx91LmmGS+JQpxlvZvpsdH1ELwz3F1n8DTNu0FCSTlUBDgHBHbZWLK6If2dPnjVrf+hZaDCulQR1955YaS7aNv5HKXToroaHgWHkJUAyUmq1D3bHANmHBUHOAgTQ8vpDdLmSS1EJI7GQQ3QNDHY+xnCYGN8JQE3EUsIKX6HfXXbUZtR6X4DWkFPKIumQ8ziQ2wlpmvjvzBu3xwa/fYzOEb/kiALK+jy/KJEUEE8ruREZqovfJ4yQD1Z/wKUIOLOKtC7Cml11rU3Tra972aZfe3EBo9Hg5934zDHc8aZnazK6ManBr1uFvmBwo0I1tpDvMbWFJolvEVxiSGwvJ2xu+LUTjvhZaDa4/ViUg2kvDot0ForTduhXyrtwufxbrhUBjDjDK15XlfcfU3p8o922W7DOM7lTcmLmShi0M0jTi5/Cm0zi34WbfbLCEZZko2MSQ1nd4aEunGQbP60mChdySLr4fFr4sXMSKIn5cLmiwW8tG1rUTvXluTgoeHYLnEKAKA2EpAy/dcS9HvurGL2PyHZYdPg3BC1dOVo6ir0HgKAScZ5uXgSPVV0f8iFsRQ6Y0HGq6I4ciDwGyt7luDDtTe6T8c9PmWRXhd486z2smeVTrzLgrdSL0Ba0LJ6/NxSEoO9u9ZJlCWxF9qA1uYbf0ShkeHPDkRBGg2ZM49Y5fOUcEYVZcz++mMHm1TpCtzK9+WDNKjWVay3AUgrg88ZDOqdN497jO2amwqaw/GLGIRvtPtUtWAzmmSgmY1jvYH+683ZmKEnZm4pDbJHgCxS0v1a6yAvr3Lcg+JbBgLURFC992Wa0g8uyBvPy0184vwOHJQV516fJHk7pGSCkxC4IA5qFapPkwx6GCdVEhLUHdk0kgHkj+KSAnwIOr2t05Fs5DPKbM5XLbI0IGGwxh1afc58b01itUO6pZuLG535wQp7OFVU32pFmoIYTqlJbgnKVU25pcX1Vc00TQcfhdzs91DgjhOnDbH3SGXaiZ7NdhIreUVldNxhotN3Ppt6AjD1MKEDYgM2dIqlyAsKq8jlm1u5OY7I0D2ldaz+j8syY6dwSph91/AzxkdnglIwQrxYc4xnR3HbMqDaUGSnVE25LwHG9UATu0qVHA7rtHHqYkCBJ2fVuzHCRIyANy9MoWPEcZfVSB0u4JqQABkjaC5XXBf/tpOP2dTvoobNtuBaR2NbIRCXPaJRf2GXuVHoYOsRsMjVmTviQtigoCYV8vQUnz6bEXUKe0SlyiQ88TRyhnyfHyYkhmcKXJW+6hUd42vFvmcQ21xyZFR9J52med1UHiOXHpoKY16x8kDmZaucISIdRLKAWKDjDjtKpl0KfhrUP8SM8H9713b6Hn4/8PGBCODGKnZXJxpGdTZL+KL6OLIQY9kXW5kkHfPOmEwZQ6xJoXw+x9dC97c75/Axbari0e9Ln39v0OQUxeX95QDsxJXhCARGT+YcxYhZzNHw+MkmPAZ0cD8C0pFncmDBBhJOkq8UHuN339jN+WthN4BHVcwXx/E5djINfOrKTn68vVwLVGzjgib/33nXuc052FESu8wC2t6za87SNcwQh0g/6OX1RTLD/GAA80ZMRMXynWzxeB0fFfdBFURrpfbRk1Wp3rdRfGMEqbnZjlzbv8GOwKLhbUYefewvCe9CbRBpSXubE0UO4sBZ9iAJjxUQgfeRkgdRaaShyVOloX47IemG/Ci1Zv4l1TwKx6ec8RQ8gNpAu5OfPjdmaNQFOy/cKgsvE9is+gigbG0wB8eTqc7ljpWIYwflsVfrkQxcdKgideKv8L7kSWNnmKoLrO9nE0kx16/022aTxsyGzBP+ZC+aucFppN8pIoiZuRVIccdxJPMBSVxWaBeFqgjYGKRYLNC10OnvEvLomsQypBKG+/S2A1TQidPjVdB6JAkJZyuobnAFG1yMC8A8775C+/DDMQ47se4JeKqswAVMGT8ClHi1ow6coM3ALNbQ60P+lRHkLJI5a8zBvMfgZ/tO1SDjrzq65zoJoJUBe9P4OJ63Y8IPNdTjWeAd3nHM5rgqcS6XmxMdRIa3gMYU9MVwuYh0ndoZvw2k15k7OlVD40Oy7lGrVfmZzHo1ew8Bq9XAPRhoxrK9TVs5GsM5ywZBzLNvSjtXGldBLvzGnjQGfdsMDbzbSBrbkblfMqP4g1sbEb756NO2DsT6BpPn66aSPGfnrvtplm5OhZRJdcuJuF/mHQW9JsXC38ZUgtMAtYO2z7YEhMhSSt5zS0b5eT9fbh5sG5NbuRhYOnozJVgZa1mZfv98ObIkfqnsPA0UtyDj7Wq9jyBbaUuacCzj2/H7azHfqYRISArfcxNk4ZeYKRojxJ0rCeGrS1BEt1zTMlpChrC8HJoS8x8lXrl+IztmJcvIbzEyNPLOwTvCiDlROCyKMkHkTwb3SPCyKLH471TbbnZbJc7gnLOKsyzcF1bCfVZXMjixv+W7PP976F4Y4Zocpr3XL/kqucw+2DQDtWdE7irutk0rgA/WnHey6wD6rw7eObYEvlD4V+YtsH1qUKSl5Wzt2oCnnljoTL5SwJh2rmQlVWwZGbdvwzreoHmpD7oKcgZ/kIIQ6RiOCpriJrmyrjonEaj+NgyYcpfAp2ZmXdV7kDzNiu/5lgu7DC8htylkp8JdkP+v6BS14tAApixwWAPs67jIlIJnWwBXR2xJAk1YRKYQA0PM1pE4zQW66YGZRnYg+pj9ywWN2lA+LzEs4YEEuG6cRAz75VjTJUdWz1NVRwAUaXH+cProfnudE/gqddv/EFPnbepGNbgKba3EW2WuebEUky3rbIH/S4398M8k+eLsz9hDAPbugopfOAnhI3V68iS43buHuWpd/NyoCYhBcU8Ed0njev8mo7y4NPTnt6WDZL9ybcfUvRBZvT2WVYLCzLRo3zfAK4A9vl4k5DdxknYk/XaGxAhwlyufeUbTklTNI49A/m3y6xJHXqE/g4FUQOzOBSbu+MDy0kOuAL5I9eRqacgTwVT91gKd0r22FMKVi0iDt0b/I1H+u7xK4vhCO+tVzc0g9b1HeY4zeKN8xrQlxsfmvx+n+Ng1KK3PQwKvFHIRpym3P0vS0pq1rUVOt5ysQvfFAdz6voc+sLd27+mQR0fCcyeIN04AwsYhYDlNEb9oLsUbabWe/kpoAzS2DvTUeH1TR1Zppx3GZl/pRAlgvlXokzRaowVYl2PenPY5VhDYzHrt5NXtcf3hBk89W64MAoOZfqOSat3nKZgfioed6kQp7Thkqo7aaq3JOzmYGrR0wmK24sAyxTLoF6uJqCMVLj9u4x+4GzA8dZMmUjVJryhrr4rQRjqVW+Ti8JJZdJyo6hHuAZoUbmk5Svo3sW9lHio2Teq31GoaMOmPYwPKNHTz3cYd9pxA9Y1Q3qK4A3BE/fESQ9k1V/2TOTjUtrl5V5pgLqqVAiCvT8gEHqV2QlSjzXSMvgDI/5C/EcDwwRgFQtMMchTT/g29VMGlSTVRyH2IuD6/OUsbyAihzZksGTsY2246VzHTSJ4uKJm8PjGgJwXqv6y4QI3/6FUycl60WJP35GHormF/PvbD6vHa41o8UHjp500A81rr9sKjzvt3ADCDeMSsmB1m55lDuhhiz2/uaMW6bWCy5VHh4BeWkqEHjZh4o/Z2Lpv2x5H3ZptkP3OIk6YvUhIiYD8VrBnKJtFAS3D1jARnoK8/kKXHhDr5CAi/vMIoYIMIxAFITKa3RaTg9zaE6q3LX4F31gYQdTVWBH0wNKIL6gtWWYB/IowP2oPEnlL5RlpJVkEAwHOBr9FaY17PZqjsi9fQe2ka3y7VUyZX+7MU/sWEYigAMVwh7gK289GfmxcaQJiwOF/js0jHNjvtjHBBCA6Dh8HChgrKCbozaiwd91OdXIMfU/megBa4YuWMsZqf+l703PrCAgkM2pgE4Jb1LEJMVCj0XFJMTCd215Sq+pDGmYoqC7GSFTNXohcJ4lH5nXHmaDNjNJgspoIZchqjNp7CkZvYM40ffx5WxKFOds51H152LRyCfykccIudlLToJB8XwqEB/Peai0Kt9ZImRV8ChjOL8xD8Hhc7mL3Sel0BqdTheUclHaXvPK0x29WCBZ4BAWsBSbBRhtP+el0d8iF+841c4sy6Nig3CBCGQJSGgySVM+fGdswYj1/RLi0x2FjBFy9NCz11JFqSM2QoLJBXb9xbpfu5ogb7edgGSpbeyMMqHOAMbdtYqQE78PXBt/Q4hjpCCHcnqA+EZky5P8mbbPVxEYMPqWglD3PFVZr3uahiyhBvULVogjMHHvIENyOujuVK27la29ILtDbq8F8YH2LBbwAzYyG+xgWcIweECBnsjKtFJmoX3GZTTy4iDFK9zRGLZnb/HA40y7akX94kSK7LuZrlninWqKrQhBBvNMENWcAE2soadIi3KJAzuNMMZli2DPKPbAMcTULcdSoNzwHOXmO8aRmV1eNntu5GgZp0L14hsPDGs9oQ5o9TUWfvc3Lmpr79VEa/QoF5nJcqcGw1LBCeKOFevdW+IPo6kFFNGRB9SoSxcmZRf7wG96GAmd1OB4owlNSsIJSsm2Ep9LuTXnxfZc4OGqHlCkLUMDp4CPKso10rM1QgUNLVdFATDQenOJ6V0+NxbuVBk2pk2Pb9uFYJTGl3mTmlAmh87YeKOoMX5D6kf/r3hy3meMZA5wAdBJbo6v360Pto1z0+4tIXQgOnJ1h/410bNvKegWSYQNVbGW06GqY0dw46cSWbxi65U1bW8dNZW+fkbSIFxVJzAj2qonHnsWRzmR0+wrDyl5x4i4OeVthRfe64TPdnrdlTdm2UULaGVvAQtegEP2Ky0JlHDSpp/byS0TQ45KHzGDU6ISsQmIYqQvU2SJ6MHBLOQUXUFBtLi58rZO94sFgF2vYAs99qRyPhfZ+HtOXJW0A3RNH2T2Uiol/ZOeykDPUJ3I7koucpiQQqo50IGm74piq3k3e9QQwNbCJOSyJqq0K0XYVywvZqchyG2FawBd/6usbbgkN041zIIak0fouOpEKP5trYeOpzjB2V6FrZkE5U/b1fhcONLG6lf3/0LCSWvDLNk0wV8r6dUgogKrdr3psBe9SjFAlmIQ1ALLVxyAORTG1FjCcc4iAA9LCywAL2MFNFxDOeo/i6W/CNW+J26Q1Z6+//3L9ELrACmL0gcCKz1bWDJDafCAYBUA2fzu0xZAyCji2fXAlZJTK+w+Y7aFBzA8rnfF7G6mar2cHVMxshNbDHP0lRQIczg7b50a9tMBP57sVwLWtx4OXeEkcHXmBLUSwnmBd87UESrvkeDSX8SFAnYfwC50hNoN0nob4yK96fn4Ap4+rov/v/+yLg7+Bz5hyEg8KmgySc9uJX7mohoGA6EIioWfk6YrH2fx8WgSpHoxYLI8R2Bv5pa7GA4B2EJzPjDZ9G9d4GQKus35LpnH950hYLioL+VTWtoa27EeBFmC9pE+PksaQmxjLfYGRLpLYYSsiWDDoa41NeAxDkglLNzpqU6fdLxt4n2Jr58DbemQuspjW0haLqKsmUtTFWBO7mRFSE3lFzeqG55kaQJF7567c+C7dZjIjkDY/fJDYjlsTA5CJ3enSquh8y8Vq9W5KVBoVcCpzQvU/hx7Rwa4F7m3uoiK8G7pZF6OfXaTEGcpm4LP6d7hGYqcOUPTTGthq2iNhtvVWS0yJBDxR4vJ3LAwX+A4yFvKXmuIvF8w6JSd9L+TKJ94Ai1ZI5gYpYZd3cJ9hkx4auXX9/foXOghiPHeA8aG4p9b5MdBiF80a4tP2+Amijm38CJU1zimnREDeOdg1t3hlQzUaoW58HKrh5sbqW5utkcozaXJmUp6HI43nTO6FLfAd0DPwO8jjwUyBwSQ9tMpn4FX1JT964fTKtDgeot1fdHk5swjv0Id7VvjJQ+9Zy4hpZZxIUf15mjIwFOesfxPvsTX/0A0h1wkR5/FnZJ5Sbaqu6IMm84pe9YsNG6tRPaktm2VwqdpPSeK66gs6qX9OyOLhZR88VOMuJCxNNGVbolSa4fHB7wBhm3JTnjjchWucyzP0VCkZkKKfg30EZ2ZogjqsP+aFw1Z2+H97PJRxRgwAJh460BuujV4Y0ftvnI8QwWz6saW/Q7ETKjEk97/eYSyNm4LD6e5zN8yCYz/VcCoP40UwVGV+El7EwYj5MottnuAQrEo2HSZsSBmpVc/+4eJqH62FgwEEtkQ3EYsi0Mj2hYgf/2SmZvJPAAmYWrom54Zp7qABvngYHYZkZ5Qu9gWrylm70hT54+Kvg+7+FzFWkP9WC1j0rSEyBJgx97i4O3EUnwR15cU2cxMy2E5pwbw3xT1ocE039wVQzOtc/llyBb9Nt9CO0croIPGW5LCFRDGy9VOFdwhMB6Yy44p8IwXMi4k5OCATuueT7Mvm6ws8BQz3Ii1NnJtyke0KeiLIyug6WwlYt+QihR9b57DrZt2FOLa/gJdUtqUWc6CLeUn6h1mdqy0bwG3dSJVhN5H6ZCHvO428NGwNo1+wLWITogXuejpNJIxsPpTWDoYRsajIEIZ5eii9mnIuIKoJ5KC5fp1RZ87oZv6MqHjIfOKg6ZTgnaOoSb18U+erUbx2J4XGSO8gMuQGy2xm+hH+Ew5NJ78Hs0/nEx24A7A0cpgFurc+2u+isQaP+21GcqNCkvsJf4ahzpZnVvI5CBI1R3+Gb7en2ywKsfYeEpZEU8yoR29jhncYVoIXsQnq66CWYTeUdvuLbh9ro7LfF0HvSMr3OFFPitZViKP5UL6nDj7wqJD+FcRPc4jjvTOpIBNwFqnCirDThVx/ruvTVAwzwq98Vtx7fcJ0jbQ3mCDY+CUtcEZu+oH8AVutYwUZWcUTqFtHZYM2D2D4HFi/QsjtTdHBoKZBsrGaUvLT424bqBoX8MMO13RM00MC+VKgDd3riLj/oLsL5aDXMWfHrsTY0R3GSZSLDDLsOLitAm8x3Q9zERFQsXI0gx6OsuEbyRO2v+g348e6TpZKnht2o+JWWkRHKx3mbNSbzdnKcIPi5KniGWuEy9FhAuKPgeVY/rZstEtsf10R/H7UBmdmZFBxFBmQ9inXtlVOo4Q/2TNhrMlYclKGS70hOhQoY6jKejxUfn1a6VzJsV/wUxIrNGmZC1iWwp4OtsAqbSGshCIkyWfOL9V9iR7A3ZsWdfIUflqfcyB7MG6PGT2C02Aj7K7RTxXYY3teHVPWEPvaz07dmxSCupETYbLDDF6bAT3dTNBJPDVFmqCjnYFYXwdMVSQMQBNMVHrmPVr6WgvicUguseb2wCKJoxy7jICltP87yH8axlS2ye1ZxVx0mepobgMm5X+wsW4rkM3ZY7pgVFXiPPxCIR4Qtx2SNXBZVsy1HqQarpJnw5R5hSXaZaQtfobhOndi+1DPWEh1Y6jkYaHy2zHehLWK4c/zK11Gk3T43RH8IC0a3xkZkZsxT0500HiBi84bmjAu6l5g+qUONNysUHEpLbiYNrCoNwbuIBJk2iDD+O2Ah8S4eKE1ku5xeZtqjOVCiAezabDfk/6axcNKftIqOapzYZtUgZyCyC1iJBJZ8steWOJXyaQEUcG3ewTsyfuPZQNV0eO3YeBCnac9OktTvtBmSf0eJUObTp4PXveZ4XoTvCHS9yIz7F1+Qz8bIb1zhC0U1usqEaJVpaYrDzYsTr+khQzjOaAG4+SwbKy3Fuw315bUOG7GbobpGP9HGuJtix5HXKzYT9FaWYRW4ZdFzeDDaM+3ytiNuJSvY4P59Zpg1RxXnLrirHwg7d+rm30VeB4V1Xj5vA/LmAd+pcPiCijUTJAOQobFHTwTk4MRJ/gAcFMmhlB7xUNGty6a1Dxk9l56QP+x8Ep6jFUo9nUmcLf6wYJ4ZHubI6JO5B93hiHtavlXT6NodWQL5k3F/MHPFMF9H4OPRy799DmxrIUVfvQVmrhctzK266KCbrTsmvafluJOhRxg55+l2MSoXwQFIBj8Wuet+uI18av4lv1u2d2hY+lLRshYtx5Fbqcsdx65DEIWxY8Sjm9vDEdFTFfm5OUmfskf2U8bcpSnPA/E5HSev863a4lakg13v9oSMp2ildXwwDVJgoSUW52OYJ7rZzJUKlLwLcSfTcg7LSPKvJC3NmJsE0z+jwjDMEdCj4WnzVCZH8XMYO23IQbIrvT+N49heUVcVcldVJOflHfn5J59h2SZqRAhiKoLA6ziDPnYMYajiIFFBFD2RMWKGqylrQPj2a1uh9uf9htsWJ9y4Hx/VHgWaHInpEP+lcH0naPsOBkUN0cZGfelI/bhj8i0RbB0uh0ptieTB0Hwt+lq7b8TQhItbZo4FazimoWEjAo9b3fhSAQYm4y5r1I6OnfqSlwoYsv2MLzk9lDPT9W4qsN5epCsVgpXbcaVNWFrozfU6KgLJW4rbvwVeJNtvSfEd1EgkmyjTxV5cp8k6mD7fkXj1ecb0EbYOIZ+ENsYiU7ajETkS1lXen4RhJk3npkFghv8623P3oD9M2uKqf/ENo3aYKXC1OYBP0brk0TBM44jLy7Ma7Lmx6+4NbWF+ihU/18wmInjsOcne9lnRpwDvobSrwaxYdJo2rPPrsAE722LnPzAoq7G8jmUwq12geMLZkkZJDt0L3vS3EqoXvm2GkxHsM4RcKfOqMZ7Gu5AFY+VeRyGlgt1DmYvZ46xPEobQwmFzpe1FvpXzZzp63bKBg8u8uSFPe04NA3IgwGtXekRdH5n/QLY3dJvdcv7dpzMSrdsj6iKKgC7cfDhpgFzsfIVYeipN7y+NSsvyfs5X81KrI9tMZzwOsemp1Qa3cnJXiO3vUh1Z+8t2UkiiyN3ntj2czKb8SkjQxhypW54k6FdKes3yJ7Oh0o7/nVPZW/EOkQQmo7jnMx6eTm6a+AIB48V0674K+mfoO/L53rtkdB6VzrGRiyKKml12BcvmRxrB6idWq5Nam6GVeRHpTd1EWvs7vNjOXDLewwmdkdAebHrXB1cda/fQ6k93oirJNaMD20GFRQ8r2fhGwKQk6t7o8F1jaXhmaodBA/TO1XEpRzde9nRMpZ/eVguApGv5ZnFXop38ypDs6z/JY38sKHjJJJ9WBf+HYEVuZgxmA6zIQ8MO066T8xG9N94E6ncQRUZqLXBG55Qp1G6sGlggiJJBxm2xGKXVYfS3drls1mTzWtuLSZW7TgDjplzE2U/jXuMo39logxWeq/g2GCar5HfnbX+PSyHbl4rsWFTHU7ImEZiCR+Cb3K2Sgmvu3dKStoOSKlve4TfK4OFUfTWoyf4YShUPA1QV0rdgkuInJ3QM6R0Rg3nJnlJSkbI0BtgAkGDZLAEvPJE0epFbWW+Py0tHHuzRRtHF/Peo3xc2jdKEm5EpNkebdo8lLmVkdqFo/vw9vt+rsIrLXjUPeoBjTSIHpvgOrReW17HJpCZsMW1MsZvfa0GrdzJaGZMJ6uO/GMd1VhVly/9o1npGla9rp6maQkBNIXKujFte+ihA2mdKaqPOR/MDOUD6PJvbFty/JJ5sR3WV8HGcVKOihpYfh1ZSvDz8wFwcEuI+/ykuV015TEsS7SrmMZqn2tiT6zVzltkfc9Tb2HnvPJ7rI41d6IavQJZ6Rs2XdfcjMDPnqJl4o6Uqi74GwAzFRmz+IfYefkuj1oYez2hrQ9xqb1etU+WnxWSc3EHcY8uE0ElMHEbRJ9i3M0lOg6uSLFqirxMyz4sPTb/oBLeNVjYCdYUVm3Ff/VGjqdI8Kbw8m6+bnCv0h8GGbUWuXH4uckHdeb4dbMaK9sMuxeMErsIzSqVDYUujhm4gIX39N/ph5VB/ez3W8CRJAy5KsMk/ryUQcg5BYNWbTGKRR2fOGIYtc0hcNavhJ0zwWUe5kEHiHliIto0gVIBqj+bIZzmskk3RdcXgkvCr9az5S3kgAH/Zlm3qitNYkhHT1On0izkGZhqrJpfR/iEleqa44L90FOOPmIRKoij29nKXKYgi3ZlIG0idn3xKLo2pLgFxSVmBDbwiJ65oIWJCSUhulGzt/n5+KSRRbq9QrHASu7qLNKQj04DmfFyCt3pu6TxvFNDMLVYhF0sTS5lvpjDkcVAjF4FGVGcwGX9g/flazfKsna0aDu/imxRAdoHLMLIh7+Ie4xW20YAX/YgFrlhDeEp41e5phCTO0nkw5/zOIlWfU3tz8NWChWtS0BwTFWmz97njL3Q70h2lBDnODENGnOHD4T3hJqtdZilalBX02vtXZnIl6q+D2rn3ySYBpf7Nl/Lvm/30bypKsgHCc1rJikrzY7gbrwa4rRaoYZevMrXsCQs/bu2geQ1A4WpK3Xh1TJzoBJHXCNnjEdYCqwdB2u2qO5a3pZBDjDZAelGnqcK0BEc/9ZuCJq14sIbJkhpBF87d8OsTdtl/iNKGT8qOVO+1gAru2Eguun/IgPo7zSeMprnwsJvfEorVSiI7B+KZ3TF/jU9rAcVbG0fIY+1x1hzZ4B7jBPaV/4KeFumCZZa4ga3AKK+hamfX3+c2P1igTPvkvVJ9sWNNcRPDlHkEYgtWNtvyTOiWhZSIvim68yjin8WPlpvBrh/slyLB1FFQ/pa7Q3sDp6718Pz4gSN4NC7w04XicqTj4+kfUtmD4wccHIb34iafHx0763paha19Vu016ty0JEN3OW7abuO/LOn3Ao7I5+RF9k0O78F08qkSc8/kx8ElUaPbxXm419XYiCGXO52Rv2DYkZBm+eVlTBMBVhfBRkpy76HQ+MjX/7EArS8q2sw3l3gBC/TQTzdf931xHOt4k1EEj8lUV6EbWJRjktGMhgnclBYimpQc72B5BxlY7XKw8D0UDccrd7wDl6UMPRJBYUbZ+/oVYoe/i33wpS/IegPet3Ko4dKT4Y8UvmhJfL0lNtkOzz3Fvp0oKVcufmiLFP8nxYJLnHQfOtFALM0In9fA8EIngrIkogs1GUS06F4PjbXTSiWD+sUniVaAaGmr9JrZb9BjKRo7vC3TC7QgFR5/UscwuTxGLNYNx5DKMt076iXuNC6qgMqW4mhVD0rNNrsARWUE+kIgGQ/uvWt6G9rBBrMOVgNqqjnESNeLMhrbOXRmXMdBjvTN4esQFnakAC75eikWVAX3NvdXXegWcha8Sx22wqofaSH87oK2caDkPT5SjHYgvUa/xEvw8hBa//2svYYAveoiGiZe4Om7kLJlP9Hv5NczYdyn+KhunH4CwYony+Zqa5vuU8e5JoweAUr0e3/wireMTd0DjremJxAst/qVKwn1+mcU5QdfnPdzzZ6bFbXxHSGpF0LKhky/btIChhS8ZaMzI8TSSgbuOuQscSe9xVtH628DXcLHUdqELGias3F4pND2zfGDM633uXs9YQL31lOGj1Ogrwcn3qNj3vlkUSPBeUqYXVLRsAXwUzcC6utaLSsza+SLMTY2Egrz1uQyTJlXbK69FNhxyp6xUv+Q9WBTQa0eFAubOjMlxS1uH+mRS7Wvbzqr5UH/9iSsoRrb7JHyTzj/N+qeXBnYh73t996TZFRDdGjIAUKAaPFLvLuAg+fqKtLLyZpEOy0IW/0yav+4AMbIXzi4FX60vvo8ECTLShwwrw9HfcPvpxSkZS7IFxFnfRKy6xKuh+XU6tZR82X1SNM8u7CuCC151xJn9FnpLAxhLEe1Dh29Vs9Xqg1yT9h+OZtqzMWBlAZbPfRXchYwzpNC8zIkRwqflEkb4I94AZevU6xV9b1PpK5oKCYSxJLQVcHj6XLTAADNhIEnL/W0Su9SH/A11v0Vr9Z1C8z7x4yyOhNxq4+YsGxKwPdn0KO03UoT9ju8y7un/F0U6puoLhbQp5quy+cua5EGrFbocrbSzcEdQhSQUGfrfDF0AOUim6gJD6NBfRZFBpDgH4MNZE1aqRTQKM5jxZbamm+LmykU/e1+rF2Oe+z6pJasgZzvf1TMvvQyMPELNwt1Y300ZW34VHFlMt8Z9sZ1Np1fAcVWLDRvnQQsK4Fomfm1173Xwh4sUFj8j3ERl+cpZKONFZAYhcz9zKxItZB/hqCzzwxUxoISiNyTEVPNxRATqJ+3L0SJ/pNeRX4w+P1W0mEEuwRwe59qT2agjhRiasbvYlWGU4/2pfpSgNFzK4xmPJdbZb87Kuk4vYDZ8TuZfrHSVlbgDdy/27sswDL+dnTiNKqp/BxNbcRvlVT6bFn/zb0KV8DRm8Yj+NpKFw3k5wkx0Psy6YWGqYRS4hkDPgu3+9GL9edjxDEIdTSG8FssYNUmUivvGSwRcqwI2yyE6ka++me67CU6ZebF2EENBZa2tWC4Y0xWpmbvgM6rdpEAX+zQ8OpvU0xHp+5bwFZV08IEnZ5YomXuarTAxFkjI4VY1SYa2XDyv5K/YG+YDFO91zu14+xX8jJZd2YlPDkq/2Ra/itIWSqhm4lWdyuq7e7lr9x+xrWftwNs5tAmuswulBdEN82TS6BHDK/8RzwzzWuEMHe2Grvi5ZXLfF2y3rMKNYn+6yfGlqBMHK0y2VpMh1OgzY6yr4Qooa4i+4y/dRffHvbLYRRVdZ3Xzfqw3tAcdX09A6vR/eAIQ/ypwtOSQ+g0BO3Ro2wGkx7PMpuu0IPwl30t6u6JfK9dsma5UFvpbmO53h5hl8h/buF4V+2Bsk95eeXV8SOaHyyc4F/SyeBFbCwh2VAP5nZvun8/bE2y9VgCv5b9ZU1hUIwNOocGdt5n/jHMIL1nKdhIDxNgFvvlqSOZgkXmNz4Dcj6zAvjJ3u0IYU7V2Pm7/BAltDQ5A5oaQ2a1AxVIGv1oUBLeFzkdvchxq61RdzzOWJ5xSCgZODLl7BI+j4GPCswVfr8BFj1ZCHcj/EGgqR6W27FW+4yizvizIBvPKHnnLwiPs20osaR26iGqm8GXIUzHKTNJDcM8/bJ9DxFMYhiIDVxCi8RjEf0Bk/Tw5s6E3xhgm6wdsbwr3ydhgVyv/tmUrjrxI78FLI+JGwlIXr5dT0Kg2QSM9lJ5gcXrzKXDyf7Q3ZvicjfwaZEUF+9+Ni8VuRlOXWX7/o+ihMSHNeHSIl7yaUWgelxOM+F6DzBApvZ+5+vH2Fu39cYuRcDTcvhpF1viknFAQYpB0SUmqjSVGf4YZ4KQ3gZOI4FtV5FW0jgRhzJRFMSKEGoVyJtjYhRF/ouH3lLJHRfXKhOWZtYf4BVDZGKq3rw4S6m6bcbZ1pToqykxP/JMaYJJHEfeyL/nTY87CVm9N6wsKc6cLcl3s4GUdPy0itxnj9OgMp7W6GHZ8O2Xd8S4+0SiCRZXh+pSTOvPXW9JeQHPhY6fFMeuY/ffpH0PkM1o3+RR8VPsrB0yGqcJTa5Y2vDJHbO6K/4Ev07KpqyYBBTDxkujo0ZAUeLPcs7vTB4Q0zEnB+O1W1yVFxavyPHXkPpEtS93oRWwtju4IBb8SzuoFOUh/Ay0gwLZbmTya8Hwtt82wrurnEMMnqmI/JkzB9u0GoNeajZuNS+JtFV7Q7z+ouwOA/bf1fzHn1U/6MK2IkqSU+/qVPIpKNLJQrxpcPtRJqUBIJVIB4zeGdsSo3ea88H1syo3iWZDUrVFcf6IpjPRMmA9kgi+fpFg6NYmINmwnV1uW3txUnWpRZXBNLT5ONhOgUGzl1+3QpAnzXpzAU/4TqA563eDfz9sw/UMtp67SuiEgXG1QO3Y0qALYnXCLGbS/ig5Vc2hKGNdjOrtqNw4jVZ+rjnQmQwJ70jlB4D8FwCWKN6YE6Zirxeo2ZqGUnggk77c7bA83kdTFuv8S7X97lLM/iYVGywbiB73+p5HoRKDOuZnb5m9chkoARhpNF6vEOwuIAdpBZ/h7UQtR1cMK9s3rQRKp1qBwtj750MnTD3mMgpxxALHyZ2gpV6ZUq8tXpA26SUtPqqElyFk+MxFeGjhCQN4k9LeSjC1trqDHn3ZaQFlX9HaGibmqtGVTCCDVAE+jyh8XB8aqLin7t87DcT6H6GAmp25+kxYpy+8nGpS7xdBZDVYz664eoT/duLebSnVJArY04B3wkysSvptYKcwzDRhSaECsdNVg8JjKtFPEhQ85df+kddmpdlhrwqxibM56zDGChA8xrIgx6wFf5V9In9NR9uLD7qVN+Wq0FkHd9KmC1aMBQ4DgmyKLfgAiGv7S8hc5t2EPNupw9jsQFDTNSZKq89ZMtdCY3cKBwXu0nRF3xhM2SYDFQGKR77qozUBtKcOiOC6yDarW9sAaYxXgYRCYOzyF9jaKfWqJVifAHLgv/N1EJetRcBb44hBoMZzXv3sZv/6eN0LigVSPH13PagGgBlTscORXGJEpm13IqskQbyF4C9qG1nZRRkWz9t5gVpV0L6Wi/vFyhVUUOlZfs2tswrIJQyfpKHgWBETdbekwxpRrvhhxxCTrt6C6FYMG80LaX08Uyv48A0DWRbgXwe2dYQJ/tvKo445IJ/Xan0SgEavKIElqOV1P1ViCZyLX2xpJI4Sqgc02aNTOpCgwOHsI9BOeklKRg4dOJ5uqljY/FPPluk16LI4XjFpntTe0VlGlRXDr+JHuE/Pw2zZPi41b8KGVsERUTgmGDKbFrtdTHlloHKSK3baao6QNprlCz7nhB0ZadYAoepvTda5p42pYuvnI0XjAMLiB5XAkzFMjSZzhxiaQYHmyzNA4rq9/66begUNYg8PeYUVaCbR2y6ZBIt7+cYtAR5lOtTHVU65JFpS2/2udDvfsZTd2YxQKs1ejf3HWVjkc8y2OKYYyzIQivtuqp1o1r9FKMG/aCcWVpESoNz6Ol0DN4WFsIeOgCud0JROW4Ofku1P3U0CZyYpBkY8Au1tlsy2Bo91iFC04JyQ1lo61p6AXHjhnIVmoxir5xoCbO6+9RRgz9LaJflkbd6XXEE3tOQ9ocmE16EdePqkN2iQT7HKcNoo1yLMByj7pNuZzgOAh7p8FHvagzWDbK5F8EkBofBUt6V9zvgSu/lOXh1gA4N4N0H4HKhr+Mte6uu4DAFAxs2x2PKCUBjR+zqZYVDhcaaHvGh7/oEc/JACXD4MDxnpjTZ/irft6yrzw+/VX9thVfMNJJvkYgcZF8+IrwseSefNOLZMJHJy0KPi8XlJxUewj+SMtziC6M8u6cAeBYm/mbWQYYSNMCF4kFIfRmQz2pq1VKrV08RXaBWHZ3kiOm973e2rA4C9O1AyZdA2WQfJPSE6k6mHlN0fkJS289Vt74KeViof5TxOykc23B9dIGIwB0Y5ZNQ8Dy0a8uTblEaMThpNo3uW099TLFJDtMocIbq185Pa3PhT1kV6pkO3u6IEG1UwTl/E4anHPqUI2LKCL+XKwFQwqgZU0YND7Vqe+seIqSMy2X8tgZzRTOkwFOdEnr6/1ba43jLqmB7iMUgQSfhUHTWq57o4wdwsumR24JfFUtq41153iuJFTKVCIRbkpx4eD3sjsSRnJpN1lBkxK3bZhbER6zmPlsD59vBx7+GW3XsrG9b+G0SbXtZPzpfcBHJ7aGTA0Bkzt2haGPxmf2S5up06wdo2eOSE5lA+nBC0yp6otyVehoV/4wNiQ5bAhiw6n4fH6Pu/BGXuURvJAU4VPR9O2JlFGkI3vjsi5XXgSUGpEw0PxqVM2FhXs1dzLBFHXpBJRNuxJHM9E0xcH0xpKpbi5YLBKq1iGmECL+FppICN7Ewv0AhXJ2zzUGv4hx9ZLbxIb5+u5fivCAFaMXKURqmBIIApjjTl71LwzjRVJ3K6e/0JOa1fd4S9DH8HPecjrtZJfwlwmGZmformVaUGHqYnq7C8VU6KuLDILN9Vmm/wblQHB0kivPm9sc2lvfAyN55yIps8b2HBIh/F1KcoZJQPQU8NQVu6oMg/XiBirrMN/4zBFVZ8ctLdjptZnq1CqWliO6GZsm5kmC5PpCjG4yytpgTb5U9nU+uEMyS1OE3XMmRAfXGFgl3aZ9l4zMMkPYOZdbAEwUREuPwYvq7KghvGvq4qdZur6nqcISCvN7+t019SbWMnoUdG+oUNdyiWd7v0V1feuNt5uz2Subh93nDos73YGGGkG9efwODAUj9Dd0eDNZcyBcBFY0rdr/YiGsvGGMhLaxJoNZHQxCPVjQMwUa6yJn7X/emEgMFxtYeeGj1ktNGHe3/JfJz8T8g+wpz4QtVortz2oWA+ddlChUZq33HI8KJnBezzKN7+IEq7dmBsitKwKWDXBQ8ZrlVA0d/OGhyO+E1Cjvd/wgjCy5EKSFVufbcOxs8MEAoQODy28tpAh0Jk+AGPmzutZK06suXttG3cju2X0KYUeR/Xg1qeXXTztROM50v3bMOEGcWkLS4OoFk5RgBZBYXcrMhlawVVXrBNZi9094wtAJjJqYk1w68M7+TMMH6ZlHgmhLX/0OA+7EVftxb0jJR6ld94iwlWdVELbr8donu07CDQgsU7lg97o2/RPwHxxC/+ytCKuPb0jmuqTAmQYUggXkFnbeBG7MzW//BvSGCgi4jo+ehk2atJmghrBgyOnikOIRUiaZzB4zL4FSzj77urXiXWigJ6o6lyfe3tC99kLUaSjaWukgnV2j06kFcpAs1VlZfRhziUK49Dc+mBTAT8TyHuh4yWoRUJJhU5cHVnNX7lBB18ykRjhtw0DQK5uKR7yqIpz9KCt3EdXDG8E7DcV3TLPcmw1w2FkWZuKVZXxCZycRr5Y+/eIJHir2D3H3xsxf2SE7baZNtj7kyEBf/ZYIyrc0LNhhLy7N70k/4GBl3vyFQxVIlUMUAyZd9wV2qVOWfn3JvIjQDF8wx2/oJaEyzCFTGI/OoPNMMYiIpVkFYQQ1DSCWnRN8tXV23515gBwrocBQVuJ4WXIvW9OUJbhwNlVGs033CfY4hBltfaQCJVYZpLiC/SOx1bx7GYkrJDSpH6F5Lsdhxbbe+olKovqO6+KFfkJtgQ35/aIoyaklyGbQnQ01T6GgvM4vllRBayetcpO/rgXdMmkNAV90PFZnWI6uWiz6gho9fwJ/6AphLolw3NkL57xFgZSJ/To5YmWYFSsJPyi3ckFpMhhcxqOvsmAXImWJa6Qd0GkTn9CtxriATjOILIWbYHPYbAVTbKOqW1iJIgb+GvVPIzv37cfrgjiNAG4A1Ivd8UCbNeFnObRdyyfQvDq9Fwlz/lBsoI7xm1jFh1xsb0zhJVWNtOcgCow4cYwpdUz4esf1bEO6Vi7rGMMcNSjL6fhE6uM9cueNsflvwpoVJVcbceDTggnCMHnd01Y2gBMR45pcJfyi4vTYKRVBm4o4Q//OUWBGexX60ElENvVfhcR7cNXV9OBTYpagUrbzjCxqScRoEyBaZN8goZchB0wkSQwGi4qJuJ4u4yTG8PPeceOgajHJd2+uZ4f+AUlIlKtV3GZQSIK3V8jPR1UZSO1L/fHm7XcrtocREapafWLeIX7Bwb5/bAuNkoPqzYmNxnzVlKwoRGJNiTK7WW+q0p+F9X02ZBw/gpZjstT1t39sbEF1ahzkDwtSvwFUUQ2q9vn3o3Gai5vvZhPZqlnGf5LIU2QXeOqKLQly0JIVEJYSrKaI9cBBnPF2jlPUfPUqswJWrXjx/iSUWcwWaed59jF8MAhvAtkGNTN0uCbgaAY6MNmGgQsTrAnwtCzxZgxcn6yZnnsyBSx9H9mvexh5e8K3zWQEny9MMsWu9V0afICDtv4BoI42J1f1J5of+/Pak2NiLoFMlJJWbMDPT9JmTUDa3DZxLkruWU2W3b1QihbwqErE5x5XNwdMvlk9nreJPdEXWJh08gj50dQmp5BOYMsMkMOBX4t5efxTOq4Yij8bBumniCrRsIfpKiikhO7Wqu2ZDQh2y838UbJs9Ad4c8XWB/sI6jITiR09/0XDTcydQUcNk/O9xTqdtZe+7FRbWNWDQU2bq1/GKFfIl4K9OPKXa5IWNWED+OTPyrlD4ziVdZ6ebAgFgfQ2fyPrfuCucyyv+1hktCAAFKiHNyFYBrLY/PVMu0CeV9uwxNrAmTtgXg6Qqena/Of8oxM6qukPcdb3IhTiWCy0TWr6h7orL22DvtMTq/BPuVHMrU0to6MP7+s+rWJdqmWPVOeRMMXYAemqOqB9/8vn+pBPs9ZA3U+VxGTxA6JTaWh3HT6X6HDGQDejMgag1RR7soXORTyYPKNlOpzcoNZuFOH/YQwLLxyM96eRtIt6OtV8Copy66sZ5DpAeFqLxiHSjRFCGOZTUoEG4vCHGkIMmSRgKw5eOHIodV4sMv1nWko9HD4dU4/0T0yRUWYdtHIYBxXM+VoyJ9xbpzbbPYIFM0J/KwP+CfOeiSZE9yJ3t9xJcPRMplCX/6QJ7Z+s/tkODRzQ9EXKzXB2dQf/LmrP1KkYLKz1A6tBspBsSt1Jxdre/JbX9N/RViBzKg52Eu+QF4gJF2P5OZyjLxEdu7BQe+NufKNrOs4r1MIa5WRMQl2C9ERV2Zk/8EEPcw9FgSxbt25JXWAOsNCmQMUd7nV66zq6TcgJCNtggGlxPAZlPmaKSkb+Bn/BlOeqc2NicJLM3sOd1JpL696F+F88KhBFDh0RBGIrgqwYe+RDc9ud+7vy2qTQAnIMPlgiuFSLeVkYMzjiJzRANKSMv0cF+TlVGG3ufwr8B0OPnx9y9tPPwZ5zY7JZw8syqQXPEAVjh6k9P+HOypZtM68Lno0F31werZyUMwNoQIRTVesE4++1q5N5QMI7fBz4+anVmvIZFkvieSYZMvcl+oflg0EPYghNoLtMycFUvaEQP9hXD0tzVXgKrs/YKlh2pYD7ku522ZgBXHkEZJvIFUSPHoWnL97Y/4LRO9BjRFvIVI/1W5KHvWMuVIBhItuxEswWYR9zsAv/C0o+jRq86a/MQERC/gQmXsde0YwK9V0+yje05HD4tyzclu5mhu4K9Y5TBOddHPFVPYiHXo4M9Itvaptv9K5L3GAkicOx/6bMNZuaAgBfywnOZdRR8YccTk6GGqNFekgvtQrdj+dNhgdpbnMKZM/mMSlMpoA1E9ff++XTixzpJ6pqQMVtLHgB9X1gzYHTJjev8uKUlP0g44Mg4CsWBRGosDE2V5F5x8FVYQfGTU2D+XpneR34y4hQ2u4/RNl4HkSSTWjcJck1gI/pXamzafOPTSeF3emfXaYTpbN40MK9pgZyyL7jsy147O8bSgrx7+Z8ox7fmTTFrxktk6uXM4310+kjtMKN41XNjn6NyM0ij8R5HmMxq2SJ6QaBbdxhzKy7l1Z/KnaOYbmFKdUncqogyUX/U9c56Om7mw0kp5c7G6tpXbmCDt9CkA4FbYTwes4NqjgMTLd6QUDaEXX2pjNeqz2Qq0qWEF3nS3M0+siF9MKYaciNYyGHYQI6rJDQ05yO+Pb1NbtdhFgQQ/P4SJ3I+bYH/Tf5OxyIVLrd53/9Wy+hRL3lnEr95o0maOqj7no2/DodvNPrkyWg6EgMGzDxRpO+zVDrAQcZTjQ6Eqd3AWMo0Nv4Qd4THCtE5dzcDz10oi+0IDGjP7sOANBVT882meZ5HHeCtUIP5rOg651VJhAP0HdiNwVFFyxppEOGbqjySR5NvDjUwqC/UOVNNhW2rkTZmxm2qqKd4l6UTFyuwMTrSoSOVnQ8cz1XvFzM01s2YPlAN4PEdjQ2rYsYzKXIaF2oDmR0gOqAS6DC4UgRUpKSAUeMyFOI9DICrDR0LoV2E3YSf3KmcK4Lyj0ZxlyqjJAWC2PC1p0w/AN6Oopw0pn1qUKo8GjX4yJrSa7oTOwIvM6Pt6HAku6VURXEUnx7PyOZVqsXDIUqxie1pue28yE+TVvS90YmF9hNdfpYfEz+RHv/B/8n9P2G9Wb6GQaySetT4ywaPRgKxJsSvj/1oM6NsIJFT2/zBCLdimRAJcQtPwPHIcqpYFSPrmrEzFxfw5DVaaVwvkKrf+svdAESmwiAHnjFaJ88W7dY527fVtBBug4R5xxmaseEpqua9CSNG206D+WWauP5xQ5U4kF6g9wi9kHGPsnE9HVE4rcMXxCZj+9bihsGaW9MvrLO6KBO82N04llhLi66GxlUsrInjpDHconYSImLsLQNNdmQcH2Ji2iOKhNsq8vBsyjiN5BUEJZ+Iz2ooaUhYe0/BeDz7nOvr7ob2XLF32NfFoOf3ERlie+LqCI59qPxQuCz6Pqn+nX1NUKSuI6C3OrTPtylMCqusvSa65RdTLbtF+tQs0eq7hfp4BhP9awE6ZKUqlnKl6YQHfRdL53souV5PQKSztZXkupFFa4o/eRZxUkS8Oqtd+bnxWh21rgzhUFanLaVrRVjyP2HkQxv0BAydllnGYU+YiHlRKPHrCGQ8SUyYdnOzaMMLl/5OONwulOtmezogR2GpsLSPlo7QOoXXuYs235bdDdxAT3B0fWaU5SoWyS4EAs939n7/jqxG+fS8UHANGMxg+dLqBSY28y147vgqvuYZCpqsa3W+9tC4lKGJsU3HMfcNlEo5JhTCeb0BqNYQH3+oSFBVUIisvRlte3C/M5zcxGvrZlFn5qDphAj0aJFIqJ4u4loT4ssC95eS1DbM7f4xCrtZCsijUwnpwgaoLHD5Cp2iqdiObZ6vviMgK8gc5knwShrtwFu8A9kifzjTTH9dJVuyxuv95y5MqgRCgEJayD66wRjrOcL5PL9lDtHHkeuD4JOq2rhmYzDyYQwN00BdcCh2psc5MclXZU6YptgGYq05Dh1Hy8c8E59rBlNKqbpWeT/YXWylng3KC6zx25KmhOEMaw24FCWJu+ouzX9EoraEFNoxqevIV3ZhL/Zn1CncK5ew90KF7/wJp1/7Vt7D6vUTSAgfNFPerZvWCvH6SIy/y5RLCMvuX/r6FPSqQjDtaOHzFAcBqYTqKgNZbCJLklDgsaD3rgvE8yU+XR1jP//6jsuiBDl43pPE24TBcyk4/8jlKawdMWcqtebHdPVGCZvAeQPawCiuHBvr4iqO0jeT0Me7qj9j03LK5RyOixFU/lFF879rNpi1AllbiWQhXxnDrshTzVskW3acHXbcUBW1ScYo19tRTFcQVnhoo+2jpWcMJCt8F2hKu1m1Anhy7TuV7Rjnp9FY0k2kV9siPaM2EQxmaLTf4Us2gV4VhZ3rA+M3Xb6EGLg8mk7rlJUQS4EfmS9D7Q86tzulM47Bm0P6dCpA2pcExsaLeKZQtrD4bE0vCAyOAyYXZQ1VGVKzsOT7ICECYrwcxYyUTVUZLvHNuFcH8XJd6tYQDW/P6zEkBhXkS7u4ec+eCHjPN5sqv/8MElRMdCstqQLizRbkyKuErSR6piuCDq/D1S2UFbtCkRaX5VuD9HaZjwXfPwn+bqO+6nJlxFAMw4I570KqcCvLUjln50zlPCs5oVt94yhlnA2MPoSjzlsOaDkIcZLaknRrUkd4XY5PO+ymLqLOysb5VWfLOcMfNAsmV+RR4ejacgBCzkyIHua2k6ggzGSN3XnA5zRkZBz1TKLyl1p3Mk35MXzTUCD3L8Hww9Ki4PITjNIKj874EbotaSlKfFBMxA7EAAagU+dOgmYml1nC32Vsc4MNeWbNxggEA/a8+63syP7vDKgeLV1U4p7jAqt2toZUICTJymQS1ebQZpHMZTyQ1oS3WxCfqHHSJxgdJEZX5mpTtB5iLJypHXrLXWRod8iga01ZSotwpcQ98VzwAUIgfwB6+/RpmdmUKt0mNt6dvqOL57adm3AJcIWs4qpF/PzkNp/PI5nNmtYB/eA1jqum3gckQiz/bZxjDnyRiXkhEKcLL5iGKSNcOSUYP7kp/H18Ug18c3evZW92FwqIHJGjYsJ3MMtFNmcekyvqPzyzgBn4VjrFnaB7Hgu7Md+rQypoYP8VyYsa7iq1ZA2dz01pjWHMO6A8TVxZ5X+zN0tq80Z2bhc8eAXrjZOZglwKbGMAw/1Nq1E7DEItCIZ4KrSb07/OeMKSnfBS+KikWh6sjwo/mh6ShloCISrQnMZ5VTJVG9+G2Jyl5Crf3eob6rdapUL449uP91NRTYAO9eyS8uMjhFxI6aB9bIex4zIgx+udpZJoX/FX4YmQvg3F8gq8Y+WMBmSpR9EyBnxpLTFfFGvth7s6QkIlOLlD2CD/bW0JqRib/LpJBVyKeLePHgIXecbOGwwHSzrDhSLQArPt1LutYO4jzH1OMqab8aRwH75s+vBHRmDx+PQeRF5QuWbSn0k2wVN2/4ufa1OWiLrC5VNmwCXP7zsvte0GUeNu+oV4WwsRVelMxeRgeRZgeUqr+YPwH/EswRH7JXK1EJKr+xf1gM4Wu3jXgKP8c4uF4aIlxg9ikzEdQ5eQYssrTDBZ9/e61B1TGw1PTWXTrQanHgs7mGhCHgrAlqJzEHOFNs8sTySnhQzeXAG646NnfJ6RfiEQw9DJ+rwvKV0pz0takbp5wfk9MYwrexiZ6qnmXu62shKo+R/YUhuKROsvgNgX7Tzj02tLOuMS7rQGp4YSwHyt3z9crvXXErtwV+mTeKpXJYjRng+e5Hf6em6gQr9Kbhkz74x6czfNVEl054hzxf+Y1jrAv5k7Oj/725C0lDgiSrsgs6Uw8wkcpZxFi0fTzdfOPpFGi+Yg5MV55IPs8CDXhbwsT3PRstxcnSR4lxMrEDK1LzfrTnVLUYWu8eXBYic7CGam7PvGe3JC1QkxEgj3Pqmp2n3S16wsnfTBXIGd6JZvbYJQj91B7UudljwbFVh+TpcZ5gxESuLSpKnb6kE8up0BG4NjPF7c9PdELDcJFHiXR3WAyeRYxomnqQPVLPiThgI5w65l2ha14Ljk6xb7H2ItVaTwcG0jY8gYyYXtiD5qyrAH4nSIisqcwDmz9SOlkOMSp8x7N89UsbP4ciBI4kJXqtclO1AflWgZOZsV6h6oMd2/ajTY5cSDqxi1JAetk9eZF0weTkgo9Y6STIHpp1fOcMIxl1naJaz/dum2Pwg9jLZ0mjs5coeeTLU6CF9N87KxDwbRsqY5Hmn2bmiy5L5LFOJPkuv7wDRIsau2sovq8FF+/JbPerA6m+JrFHIKEGR8llYQ9d9lkR1yOC2zlrHYUmL1206V+K1AsG7oWenWHWZP/y2Qcx2mRAExipzmmP/F5yWJvIMl3babLjI3TQeKbW+WBWc1LkmNgnialzG3BtRCevUfPboyYfO+9WvzhqgmIH+JM7/qn8gll+Kwhylir7yJdvtPe+Cej85kQIi7OvPWdm6mxWKWvdPNkFFl2XoUR7pnRkTrmafmWsZRh5UT4MCocWMjA81ES2mdXamGO9iUtRV5IsnJRzIsVEFs25pP4iGzx4o5mQLF35gApNKzusFRqsQ+kY7QqqB9CC6cDMXVSJbTEaoVv3WKCRqKlouSBAgdZ5Sfa9+pvdkh3DGCzFTqWKFqfgPlfvMwMc7/5f3yFawv06jnQN6QEHfbm5/HlLxfiarH8Hnx1NJLDZ3JVmxr34yqCMbd/R/a+oe5A738jekGAELRaBOhtN0WQ0dfrVDkKzuF5MQiOJA27LVNQP9KtuDL3WyDnVX9VT2wYZ1LLvlIw3FtOYpfOGqTLyxETJwz22t7b/Cbw4tpe8ZSsMd5Qek09sgeOLjSBowA4jzHTOvt0gJQxiOpeSzHwD9IW2bwme4UKF4hxQIDRHTMYZqzkOlCb0KiBkOQQsAK04yUI2NVfuvTjh8ZD7QrrlEjllnzV84xSVK1/TkwW3PLiFhF6w6W/f4MsAle5BeAz9sDU4McKsEQTTJDSY714fqPlSuA7A/4zw7VSz4/8vlvb7zOnDPol2bnXjSSLQqu0FSt+oFm4WGpF1q3csGX3b0upYReTswU9QYsR6rLMeypXVlHTuo3Wx5CgAmNdS3Goo20vfX3X9ebGo+BZ5bm8QwdGWVDmyqKzVF3PsGUXNzuJkiwJqrBIcMYfQ5NlS3KrSJ1Azv7R4WRe8l+tAe6GwtIMIqf7faRUCxkBnq+xl9oGz/xzY/JZ4DPIOXWC0EeeIFVdp6dH9hyM/rZVqtPOd6Zf6Em29DHijzM35RqLxBkiO6Unk1/PCmXSMpcJZLCgXbHwzmrgowf6+pSmQiyab0dsMmuLHR1ze2c98Huvv2DhY8UDYiHfn/uhukKKGuxH0b08olNjoioc9H0fczSTCdvarQ22wPR+Yp7SL5m0t0CT4lw8QkK1wjJYHd06L5mLgMZJl0/6miy/9bqGbZvfCxU1qYAz9b0aWtY+rNaUwuVV26/wsQRyAhRl1iYTThOdXobZ/3fZ111X5xSuL82nmI8ireBirlei0elgIZ2iKeARBArUKMWxQ9f21Sr+RReLqtetEhPQ8fN4ss1aRh0IWMMiHdVmNqkAxltTFC6+K0N8BXIAqKw/kgdtbcvsnPG8E79UjWeEHuIgt6HiYy/92HzSkFGPQaQZrDkHSPDsX55otoH3kVmu8aOipW1n42PCwjEAhkBJ7ZxHb2GeXRqozAfYENNpcUa2/pVrzlDUhiaBMxAXj/+SKVD7Kv7ebCLDpfiVK7ccBrU3wcnSsPlDYtUgtYhYqzC+hBiIZgH5AIRyewckXYJYRz9qKwbRXw9EiRDPgnhsGnbN0QRWpQVRfjVA4HU9DRELUvDZu/O4qhfdVRHab1xzBkRDoQx/cBc8es9/TYFwT94MLabRb+O3jyPCMlwp4OMQnqZagYbqqZc70vmb1yoMbaeaxT4gc/cqGXX57cvnb4cyzxGBzpFsh75ev8RwDhMkAQU2noqzMTB/54/sHo469UCQSp8IKTBnBWEkn8GykB7TEut2B/Z/ggntEjyT039FrehodPlScH0pJRnC0j/unbSz7nAN/cnWyU4lYmQ0f94Iv/g6v4i2MbQr95mGu/4omtLTmK1tT8H21y9/cV+H1T3lqZt6yGQBf9iHpRa6HydAydrvSeJiXQ6AriyRQjTQcqVMchstMlMd6WSfwND4dSEwHE9b6xwBayEIEUlfCLFfCAVkOT2X7X1YOfH9lb1igHwTBguPcIRguDYi7kAtyZowxuHERajXSzbmbbqiU/mwLtW1cpP6vjGQwC7CWFXGQF0bW8PWw5L5dVWPiQLMOiGMnPXqvtbaG3Wu2fKQsfbwHUPN5r0EDrJ5YWhluLz0eFDSz2rpS+pZCd0LKlwIJJGuibktl4dGXzcyr10dtbwJ/s9sJR0sXGci3HV1AXzsblFN+wAW+lDCTZNTK1cl7DpL3a1+8RcSUqhDkMHyPRYHeJ3AXKOhbADDClBcJVYNcEnC3Qr8Vjc2LLNdqNSeOKFI7IYO24BU43+xqWfVt3pgdCxOgGQ8gQJrEJaPMn89NKdQL12NO9g1zydk6efjz9806eEnjI/P6oLVMtp8LHXzSAnhcrrL2KzTTjXlqvTdUtZfzzCQF6TKoBmKvBgfZhherIMpqsiKug+5zAGQD3e4dKTNXR5yyIOotH2xr8gGDBA8Y3ORc+GVcIjiiH58o6ZKXSxbXzmsilkNap03x9C8UDh3O6qDJRAovJFPCXawj+OeOqiTDFS+6HF2V2JZHLFiJu50FefWXdokqjz2113gsCSqqAv9IqqUEumhVCn/x1TZIA2DYkp3ZjxEV8VKo/Ukk5A3zmkltiZW1PVlEw3AIiolSzmWxitlVau8hEBj4VZbpsAuPvYHzHNfzbjVRA3uh536cOQdZ7vpGkPA4dfKJ/EhsMPIKyCzE8CC/C5amozfr9teAwMiCJaVVIKw+2AO7nLy6c9UpUUPfY1fR7aZpM1XEnpfYJEDk2Fb+UbmB54DSs7t+T9dhyHW4ZbIhMeMRW8KpwupTaZQd3JV6xpAepXo81PGgbPLLcmHn1NnIRq4Bo3GgXiMcP+AhQw1SBiRLZYuOINu2FyiIyUW8xiNpfoUhRKSp6wHcqMsWZ1WcVGasQvLiBAISZon9dCPfgm2mUVjsdd8xPRpN4r0o2S6LvtYct7BEqLU9IsB9O2t6kNKJcyCi0jAKZYGQS8TpmuusVrqmW4r5jwIctext1AJsWBDbGiENV0ZFC0RDGk05jh6SZOjC9CHZVnit4enRW4sxvkHyKC2ipbiFkcNhAblnINjGtdXNH+HjUFmuUwO4oCE5F6NISAR9AakXEfMgLBFnqGBGb8MOw1Or+j9CtGa/QtsGoF3JEG/f84vpN+F8F5J91oahnp1qaOR5ald7Q2l2HL9ylIaMl+t1IyyxePYlexn6qIYaGdddd00ttRhGS+pbAGE0+XQCz5HTwURhH3QLxq8erIqcYF8ItV3g/DtU4y2Jw9yCyHh8PcrMIYdDgX2MPFi6KXn6glXCM7kw6mQnvxnT/qbtNIvQBT0YNC/4MbObHzUxmDf5k1D33k7A7CSu1gaVDwFpjoxeXsLeFGZAwUedss2ciBYTJV4w3WxEtLaRrmVGGfOm+CvdlNq71wkQkpoMMIMg9H+xxhKOnFJjH5vYvj2P+/LyLIpWeL+RQJi/OyUmNUnno91Ky4nBEnmYaLMuXaReXObu8LemCFaqbB8FecK47IPV/Bv2P6C4LuSCFzCMG6W3sxJCRV1BEQoa/QtR10Zz5RFHNhqfZ4ALtDsKApzo7pI9mmiLDQVjRi9GdEwwGscvuH1IDI4k8/IjCiPRLmVQzUqg3gmOukQFif9AIhKZ2CC9YEZ4UsZ2dQ3K0wiWcdOVWChULvPpBExutx/4jaw0dLdB5m883DbMDhuTGclJJMKhKvT7GbRf5YrhidM9teB3bhdaVfJ4AUYqPXm5681Xfs8IqYg3va9ac6DwvKIBGtRR/j3dKEHItH95mcGoRhmJYL1MeI5m34nxPsKgMvXK6lBvSHhfu/mckdzIzYGTHFOjDf0n29bJYfGu5ksrLI6aS++FxknVDPOOHmofIK6FBTnTdinPzIHZfHx6Nu2NvHSQFoXnepVVNr3jqhrJc1FgPCM+zWWBtgv3BTERlczWBF4PjBkmLuib3n2BLT2bOW2R3FA2rYIawTBqwdxCZ8k5Ot8nhzNSrHpNOVtg1TudnrE4tIWhuhM99kFIsGZXqlgiOl9zbxd1n9hv7YMbBBZfjBDykac+BXhwipS83PAQn58mV9vaYw8JseQelhNGE8Gdqn7H8ZSzmj1Co6gfm4MTSEb3CWNUaZvKqypGvabqAbyCS67D4Xwg5G4GdyhlfMXZrBzFpmTX6Awouv6qY589YqiO/N0KAD9rpQouH0UfXeFttUtSdT6PKGKBiIh8ae19dvq615omL4lZNjuvk39EbTyLmRAzl4rdadWQ7NiyFTGjODPVa/PkiepEzwDMMWp6fBj6qm5RB9mUu4Sp2RPhmJZlSPJi8yiY1B2lpXdOGN4ckceAUvtPgOdsZWfQvSdv/S/0rM+DBmnRx83z6b5SVS1AML8vH8GkvN2lLj4qruGDgB1N7/icKVm2RrygKUju+tWKNx7p6WNGkwMfRGYJK0ceOI637yVGjcfD/b+CKU5KUXPy4gSpJKFNHt0WTQdtJvLmjMxc+RraXEHTAydFzaX4ohDUuOufE9kGHL5vvYTXZ+bpOghoSdh5ykYH2bLz1n/7Tchu7s7BYjpHgQiTvZuTLx8p3nBeWTUs7oIU3Q818E7k44HNKFmD0L9C3pRNMGVdu1Ap/5jncdeoaSwVsB1rBx6s4aCw6GM6ZULBuxNADvCb1ahCSO5sYxv9HPLTIbSw8ajk3scM4pfck5ED7cPg+roMHlTtUxkVmZMfwCuQx23ZqrtdTvdzBPweLwbfpHiGcLlfw9zLifjoWOLM52S/sfVsjxhc5RZwSQjxqtE+5DdDV+M9pu3nDuRsSx9cfOdUneT3naCLc9wMHRHl6T9KGNL1+Arr38ApD3FLktCSrPGBG+xDer3+qXpEpjty2kbDquC+ymIKI2GHw5f+WrrroXWzR5+XTDUdl9wYkQckpj0518AkfF9c/y7Z3+wJ/4MerZuVs3RbGnLvV9Qae+TyW9gk7cbQ5kDSIkeKogmXbDXwe/Nx/943gkppmJM1Ng82V3BQWLzxcnvb8+PVHdNO3cgCwVj2XaV0Q3nR1kmZ8Hy7pt7uvYLxmqTvlyajKNNAb7WnvGKfFThWlJgNTFrvF6D6HQf9Yjf3snBExn7pAK9IIq00y1pXUiF/exADHGmIOIxDRpTRh8NKaXZ0KDhHMUMEBSIAQiRekZM4FxvltDVSCl5hdxXrPTh4XtWL1GwxRbMDfA/F0ue5xJZQdlfwXnD1i3SpKyPtbCmmQMCedoXSFB5X0o8wseU/6MOOzbAv+FFxRo0fyEt95j4p+Q0h+IQ190IJQnfUPsxmiwOLM91UoO+Ji+7aYZ/rraFydaGGORwAYkPQ73lBsAMdHwkNXVnXwzuPMNWdIPOod8Vm74kt+yvM8kbIvb6fzYu2TQfodntjIVoGd1i4rZ1DLb6vwR4AufiWKpSkk/dcdqZP/AvFrefu7+zSjwOdkzHLfgQsK2RFthyShUMDILtutaHinycphmnlp3fk0MLxmB0eiVa0miKtS3w74JkALtAH1Qv1DLwE4nKYgm9hjPmbTvjqc5teADeHOJJsJ/68NJlOzN/S4Ps3dOlk7ML85X+F/X/yZOrtnZhyNQKRZwg+rlpkv9Q2H2CKLlbhKJL9ZrtmqFQI8byEcmoVeKDpc+fqr4cz4nuYhiqd0ewK1XP8TZDSWPSCE34Z5ljDeQ1du2eE3ONyGPjOz5P3NoVDLKgvcLjkLjaJfZPv/IrYBSjZ9Bu5IcKT5jXgiB6D0BhIse9+W/AhzcDktNvmDOfAOghbsEh6UaNyam2TXsem998vo+AlCYbJ9UdoCk7HsMz/9sZAs+2W1KAPoXNk/pCRbhrkB3075KIVx9kUvyd/uJksn7sBMUPFgNHlzX1vjc83eziKqvnt0hSUQPEwm3uPPaWgYI3qBDT1mjFRC3JRawJoDmSkrO2BGjbJiY0Teci+BV9lMRcnxLj8XSMkZI/V52Cc5UZMauo0p4+cwdMHsyS3hPv1AFXP4cXqaeCzDaBKMRxgFGkbs/aHF57y7Yt577dKRZEqqL1d57wzH5kGcsD0wqlISO+rtu6Zp1cAMDIzBYkr19FCw5l5cZn4CVhNt/3W5dX3So0uapLlvE7pO44miRXzL1t2LLXf3HbIFr/bxhjAtlo62dvjb7n9rRH41ECHZ/fPdcoL5o/RIVX9w8XTG1XSz9NyKgNFPhvabfjugiPgOwISLcDZp5uHBCiJIFfBL8H2GB+bX2G6ZPW4MR/RBzHhMW20rKh6YD1kXsMZ02BrLyYC7sllhI8/fnIdOqSic+jWVeXwd2z//sVCKCbAgJ+GHT0jLt4Had7Vvt1dRoXwYl2no6eqe0C8IKHs/9UypSdQKcNmq5RAEnSfsa0HQXDF+B1Y3IBuoyAjb+BTkKvD+M5uv4Aj4u/GMZp2k6OG/iiqaHC7uAfimaF9zl3R6giNrDfOm9JTD9SHTEYZk2+OluybUlZpcnqiGZPAWgQsWwypszYa6jG2G+rhnnnFXdFizwq/JSCHRJET8Ck9hf0NMhdtUN1yWK0LzGyeZ33SlzVJcKAnjnVAgXB89yWyz4aoT8zg8NEfGP2f/5HyuhHizA8eaEC/YZyq/dnxCvnGCvWpCjFWE+yDsHX/NIy0Rd8CeHm+fzEfcs394Lp9i6xPv+t+kX9dIfY87mOVIU5G64gr8u4vNvYuZSF0spQZmUmlIn82DDBIlokS6Z7BkCxYSR2q/0wh77G/3sQXUtB9R/qsZrsb24IZQ7xXTHR3Dr1n0Soka6+ZXEC7ldZEPdMZCHf6T+n1k/SKX/goEdkgVRosWCsa17pz/Um0oFDBTdo9TSTrTcxEQYAnI1dNiZc9Clfnq8qOrXst1f82nApgEC6Or+M3BzZkI771ZSa15phI1m6szeD1E/OPamqqQfyb4RZr3iuZ0xIJiJQ2lg8r/oeTn2f5RdXsOf7esRZnlHfGC5Ndivs9D4/VY4224sL1TYbHheeX76CKThmhhWDlMJPdjnwi2qfF4Sj7YSrQwLWWuycZxuU8YjfTtOK2diX+S5PesqQ3zjaQniBvikA5CkwXvxoq7i78yirso6zAINGw4xFEN5jf5OMvzDqshzat4SIwOFkxnIXYVsqbtH9dm138gH1TxF1lcG8Ny0fhpB/2IHAASXmuUHzxRrlDQBJr9hYWh/e0I5QTU6XKZhwlu7PtUvBKmMAOJVxiNpgY109sD+91ZQ3KiEDlrnoTTV+SvX1ggYnqVJLQpli3w6Jd2/OQhoy2WyZHANMZcYdRli9fGLXPN8Q1oKfC3ZC9wxifi/5wRtlY+OMBYYxdgHpWiz3+LqCUmJPCOcYL/U2WP9YlvFnVkpXH//IvX6+syRtcwBliJtwpEm2kqENRIJrcCBhLXUTP5HDG+TNYwopA6ueWBes+DSXVyl5d4U9mA8JDzDy7Exe7G+m4N/BcGVeV2xSvwQKp3KYrrwEWFWTsHJXg62SPnAeSbroQD6fY5h2G/LERzWdy1SwbV+HlBCgu1FSMtON3rNmipt3g2zy7Y8fGmTUiLfgjWDaMvaJRr2aC9vv0Oybc7w6tI/deObYFf2PoFdceRs4nTGK0iPrQdfCOxqF6chrlXgbWHuPDNOTFac0K+jby51YEqWPydhzl9PaYZkBeHyZtqxzV73I6wJcqhUfgdG6M45mJjTT5yeF5UFijuPpjD9OwrQ8gFkn5eW8MTO0nE/ZSnWfgdVKjFm+dBCiUku/++kH7awr2UJCqQ9uGlQ/N8x0JQ0KtyIy7XWeczTfAqFszO+otgV895lnnE3ncaVcG55SXuzM8QQA7wQk4rNk+Sx0K91DMFldMRhHH7+htaH637i/s3hNOCRFfL+RDxtmmWdyfyLYst7sUZJRNfQ72y1pnnW5CiIH+okoBbcEgVIUdUNdHEfgpzkEx0gWwxmY3Wre2LpJl66LuaTZNONK7x4GOOtMaGZ0ty+uY9GMtYiKpFetR7RttlwAE6yTpo2prpixSZnuQcJYFvcr0tRQJP3VAAVqabiA5bu/TT2hMfnbPt0yTbpbAL94GUy7FFIWgjy++fwuXkDx2Dn+EeuAYWhLP/Md1I6IkZoDeFNaNlfFaC/bnzi1giNNADc9mUjRskp+DVk687mm9cgF/62xYpx64pEZNttRm97JPCtPFVJH0Eiat7j5/V3/Pc9upwtXOTjqrIRwpyL7+sJXv9BEhL0nrsnG4v843fCuNQa1LXNyBYw5oVVj4ZBCnyemnrhtwEaOFWS7+PFkDPkSM9sZfOUtksx2rs46uQwuQW7kKVHnaAlosqprxei9IFws2aLW7/o3jtkTOl/wlIcVBwHRVRXznpBLZiH1mqhTRJOqnyG9F6NBETUmUU7GjLyDp47UJfXC+J3VRgL1HBO61WckV29SZwdKdj7oU90ymgt4xswfQXUNk6egVPJerXGEdXuPJ1Rj5SZcuZ2beYH8Nld3UaD8KSNbvwTKzHrv172nRZ+rhDVeDsQ2L7QS2hAKJaFxPo7EO9kBoOgNzA3K8BNpa0q4PmHbrAPEoAOhGsh7KJuNA1JgQNC/wdMXgjpyE1mnPN6hu5CS69GHsOqzTEIHGLw146FOAg+MY+5tthhVGvvErYaO7RC6wBD1LVPJdPnqqvaqNVRWEkBewYtxlW5DTIsT8Agqth5OsO4FKn9WHDQ9tKPV3gKyDKm6MxVj5lf4+v/JcWeJG5W3O5L+/H+aKgFDwXb438DeUy+6TeLdGJHpGlpTe+pBxO3cfwb+7O7pZVYQMxGNzad/KlgIyo826ZZTeP6aZSJF3eLgPIqOuJfgI/x7lDL4OYZCu5fJZ2XVg4rVqfAYbBsGtMMjVyk0mStaDYd3fNWQKC9RSg+3fPif//Qy6M4FQXX1Zi8HiNPVl3VGL9ls/1lJXEaO7Lidk8S8PWPSMMb0XwKcL26q59rT8hXPmJrf7341shwaV3//rGuBTEBhO9imIsx8/hOSxD8e71tEbLCjHJ2dHbNRXpiwLSB9jwYP7Rg82fiiVM1QJnWSRkWqnOI9b/evNWj92ynuJ3npmkDjKSFDDFI0RrKwedavOlfmuf7DyXy3iUiKfi/zZUDIO1EkPHAwdxvnMKMdmIVk6XD1Mswm9Fo+Ncp6XXexvRzGhKOlXFAsXgdA4klUwEsAELzowg73orvwLcuUBI7c8nEBcmKC/DXadAtwp31hG0xJ6iOYmGlurqEUtGvFnl8SLRYpV3qIa/v1Y2OU12yi0pSpDfJNTmG6TYfNKPNoWQHsznHFhMplDGD5up6KLJ2GNqgC+KjhjNncydVfzx/vir7iumD61bCNKs9IQLSgZN2ci2IvGi3mCbXpBguGW22gVBkS8HV3D6xF00i4uMtRPEQP/+B0XuulKWs8o+3l+HYfm0OwGjHAU+5MP6kBzhiIDeWNlwDt2j49NN6b1isN9w+h1BIEmNAUx8BVp9Fyeedptv9T6BrmykXQfyejQDzq6cJm3fP7xRrGJ2YBX/pZv4stw5gfNTMPWr5DgsNFstzzn10ePuhr6fewVUyKt1qoPsLJ+o42ISvwO60txw/Yf9zp1BcNghv33akAhBuSJaXgjsh+6+Mi+bis4VqhHckH23OnaYVZ8Op3M0k/yVPTER9oSkR91qGgkTTHQEAex8gWUuKsejTEL3G/x1sYXSdM/MYa0XyvXLm+V2XFaiQk44Q0R3QUHw/RzFANuFd5Hmrduno6JN3WW8TBDnGD7v++QecLfI9eB6KLdAXlU+e5eN+BII7Wq5NEKQUL/Htb5PW68dlgiraFQrFdNUncnZ5w5BXChqoIZktPxxKB5c1yYnr/7zJDgthapnXe13eg/5hWAqBKvsY2zkof3G9zMTpae9anWN1oYBKuGD8LOtmrpP9kjVYMsrKeU1maOXpDQHWI+WAhjIPtqvdLKrk6Ml+Nykc/wNZw6y8vx53kH382hc5h+U5mLfbJTkLyk+pQ7R+rywS6/y7HTstC6bJHYTaoWMQFEapVgZT7uznyqsHOIHwTtCaaNADJR/07VQUU8+28jfUGDXwXVjNOybNnnBSlgc5cjzlaVDC8X1uQWcSphqyeioft0PAcgoHqVEa3ARU0e2XB4iDUbK8r7pb8CaggGCP1j+natKAXmCKJmxmtfz42chBcgOHur8GACZ8PAmw81FA08HqWF8lfqmavaApPayApV/zXMCU9aBX1b6eFNDV+4v8Tis9dCD3Q7CvEeKdHcSfU/o+Uu/75GNmDhDEys+lVO6KtUmhxBFsnDaFMg6IR095xxjct0tko83lwaS8ARH8ZYQTdte0R9/BoytTsPnNTf07jNVniUYW+QwZArMFeyKcd8NNb1S9kYhaVccZALUr7LZtYQtWBJM1RJbkxSEwnjsqyCPf/D69cNbYgWDZe9oi0X5huiDgpeJ6PMH6wGXLQVmYBFd4h6GDJHh45rQJ3QNK6nqk7D9Q/NQwb0Df3fkriOixEM6yfzIgmc2kbHQTobsoMYKfZeXMORQegUk1xW/3Aix1zVOPQdKVNP0jlXM73UJkkwLioJmohHE7FExwPDzy4hlV1WXHJsbkaQE1KOBaFiIjeQiDs6qg52jSbvu+gfvjJlCv977v9jp4glT/ayG59IGvxfUusxz4eTdRCCWU3YzwPOaUHzuKuuW/7+ehX2ndQTuJLxfXiQGcht5Hf6hjjCLSvvlfgbl5OONVydo6PwGZKG84PkYsqqm4J4/JjVabjouGM0I55bLF+ZGxmgGncHPjhH6yUrer9EYKEDIJ772uUCvr3EbT4mTfTqdIJhyG3+VwYcZTBUpFltrJhJ5VKm1EjmkvgcptOHDGOEIXbhAsE8d9lUxl7dmUwj2270WBNSASiR8Hxrtyk/1BIUm1xKr/q7ctQi/qfFs5lpXS6CDc14F2zWU9gBHt2awYnlKnYJWaZntH+LjPbgWo/DxZWKoiuSMwSwtM9IKf0gPkXxoUtpFb+1zzXuX1rEnTLdiSX95wWi2tl5kKRH4kJ+d+drA0n4Ze8ZbJsVRhIiNy+mO7Sarw9J82dDSTkCa5akPSKGzItn3jeDUbF/YUgM+813r+u3xA2QF8F7lXLJhlvBlVnVe+OGD7ANfrEmf7fPNtLCPIEhvGVh7xKrqGaITpuPWIet5m8b+MO1QeUktPS7zraPXrmJi2p8XQuaZfomHMzOd5AG4qimJ0/eb7lIcCL3w2+807qgpr0JSzmB0gLd9YA0m/6vxRNxShLI5dNLpSumcmPdb9HK4ZkO6L+losyjf1ovPfGNgLEvBAHlTFdzOBCSV/MNAjlkFqBRhWI6sQBS7Zw9dk69T8j5jz/UmcRtOxaZCgbKIeopMHJaHe+CjzunrRmFTYoDyP/C37f5qvyV63OJ9II0XpOBWJgfZcRbTnvo9y0MFJLYqvaEgqPQHQidF7Xn4Cj6Zl7AiNVKI6JuyNfom6Ra7EeslSZuT2U9kTwDxapcye9I2AVxkJvZNHEYQRZAtNjdyYDPOYgk8ygC5OazJ1+PZBuenbJh0xAlQ7seO2/8ih96xfCdkIYARm1shqGcRZ6GGzDACaxsw5vkvVJhEbbFiM/0CjUYfR1yl/i6Qpz+HfmGJJ2H+z2JYKrLwJJOW7G1pq8EDUixXobXOLZYUaQqSSaYEsifnZY8YUO5Ia4An7IL96a2GL/fn6JZKPkaOBexFc+rH244kEzImZswJ1CiU8EihKE20sHFNUFVczwIbUbBa5VLOnx4/A/R31gOeVvDBakZImsbSe7kiLbwQAQIyaRnwUTOJ3lcuun2A7fXA5OT++X7gb/2HbKl3zIl1udGor6pkBfO3Pq3Cskfd6KhzwaUbUeSiBkrheGqz77dcKoIsRoersLN/juzyUxZJO8uYBDoLvzGdDIg59p3Uj+gTJ+CopqSH0KMQgpm0dZCVXmfnAlfJix6Y0DrLVBSDzlCv5W6hhDTzym6tY75bzumx2AinAoV077Dbfl/f5AocH9oVvB3t7CIBukIdG+hg8W5hueUv9XIFxz4K6nku0TNr4AFB9CMHprDKWprKh81Ed5n3WWze9BQWrnGrGjuRqs68Dz7dItlqTdFzqAiEH5ajX4MYCjTdsyxH0cZjGfazyWSn5o0HEuEA0wDok67E/2Ny/U5CLR8hcj5s+xIzwUw5t1JsKRUQMEgRWDJ7D660tv1v5J54CKnGebbOafql51vdH186peYnSWyafU4EgSAqWH+bVsSwyHhizt8vwQWbgo8RMx0BVWfIHsbET0SF7U7zr9A8GYX9eY5dLCmLOMSs3t6NHQbJ4VpTLe0UTYUCzg1gjE/FzfLAX8v+Ppql2T0JiAI5NO7QRUtM2+3kh9Nyqb0kq40yCii2JL0HCROj/61GFWKEUoNBRVTpi6JFxB0zwYf/uYTAVTDAFNJMQEpPj2WXYH28tmR98P5HJBioewjDoqUJnes3sqflnd6quZ5MduekMmHfQuIVPU6RLKNc0YvVtSVnmu2mtV258H/CcZedzAII6FTL2hinYENlZWufnvSk2c8Mo2aiPdwX4hRvVPpTwNXNBOk+UB6+tYvPt72PwnEJ/KCizwrKOqYmBG1GhLM8trbg+zG3FHCcjMUVjXLLLja9sNeYkvi9FI/iSE4IzuqGd+orMDwgn7h4mKvNZlrEbB/4yTowQTa1uVcudxK+pUhMFw4WdvnZy+72jp1H1RKo187UedTp2YYEz4FO8QmkVhburlbjljE0W9XQtZ3CW8yWvkGJaRnv7fu8yyPAR82ZRK+Q20/dM/YmNzHF73bV/4pSpw5GKb2ol7gtwil5WZLcgm+sZa7VhgIiLhmspZDGWkUanr/G/WEE/4/7qMEx50LdFJpEPN97WpOpljVWD2D9RPLQ5PW3DZYz0+1r3barjM+CTbAJyIS3Zlqrm458O9/HldDyZI/Jz1Ap6cTqNq8F+DnD+LQ+kPIljZp/rlau4fVkGAfWsyHwTB+CUGFMWtmtLWin6I/IhiFYP7Q81KqFYXvY3CyT25vWGr07eMJlXEIjPnGKkiWsMIpc6v9Z+jUDbxhtNndgCaN3hgh/0Bg1jGjfZeycSPNXZeny1T7W7kx6h3JvbX3Eu1si6QDf7C2r5Olp6u5pucCBKiJzXrXF+3tNLh/wpcWoBGmLRw4UnUC4MiHpZ31a7CcUiDvucjls/Ib74GYAFz1XBkvg7gV1aGQrTiKHmhxjbpNEApvm7vqOo/6nknP7GDRrNaXIjBiNU/fsBtjKpMhXLOLoDy1HkcM4BGkgVw26soPryI0KkS39BSUTqJYfoCJ5QJsVuzSLTHQwDPyiOA65mlmge3sqK8EOoKSOOqzukR6s3Z19P6oK23DxHr8Spp1jFUTzG3sWPd72CqNlm0XzpX27CdjJ3EBwoIaLbr4iuyPInbFIua8wH3ex4QSEPBomR0SXbwyJ2ELsZw0ppmKtsmnBBSat0KH1AKKvTWAkmWYBCRrzupNyrrb8VjUzaJItmXaktJExY9/NIPQC5xQzXvl6vI1vcFNJg7RoDD3wmTDjSv0V8PJ2ZP41VMH9gXOvXAfCnul2UyLoxBIHCYI/5Drgnaym7ka6vp/1UFnGkQKNVFvD5gEjLYloIUOj+Lwx1x8+DXk5dxIP/sQaGvHjXWinufwTQX5fzolsU5xXW99YYFNWoUS/5NOfBHgGp82Vwoioi0ycvx7FTeNS9wnCT38FUsN7NIS43tWoAmyPzAdtdGJMn0FMwvpG8FrRuiHfJnUmUwPDhUJ6EgC+U24d6uJKPNMtgR2ZBfLMpsVe837gV1Rwa4gBMsD46HvKnOrk79sUg+aagthafKfYyfELXzcW4/nhUOJb7FvshxzcxrBTaVQVUgjak8kQt6KWl76VE2R089WGsMSv58KNSFtMTyW4PI2qWuniAF96A9QSvajRp3DQqxN+RFO/YBhJnojbhVH2pYSgFcvNtgrr0facmmQ2NY+EVloWIn6Ncxq2fbk9silikfu+YjOvqVO7pg2fZEfJCeJcm/TJNfWhBRgyRDKRTE0fGiZKOKdQJsUbYL+7jeHcVGA2BJfv87gYv7tFhQ7hsvObUiv4iXdRp2WbCoyCv1VSHPsNuN5BZYapVPXbbWXQkmBWT9simSMRsejOgZD4w94MXzT8WhqEzglkIF+FClWEI8K/ofV7uprxvUn/Y/fkbCSM087PshsTXxuqJlxyi2Kd8G3FNz+VS7R+1pwmMd7HbbnXzAyWnmf6TYt7eC0ak3Rf6jcpTNRjI+E7c6R9mRB6H8iRDdx7qqU10Kdat9ax2CS469BSwFeteXXLzMrU6Gv5Q+LQWBhoeXj+j/EU4pxJOc7E/0/yxPwQtl7pbWgyh6fy0YYAn+SHFWbJPTsGTyDAn7WnmB/wo5LThZbwk85bvWqpQFsHZXxeC6aRIb+fmcogzepvKDr1MgEPk+UUL0T69im9CD+86mecp84rEdP69V7oJ+2zq0Sw3ISKX6cxk6qDfCm90Gmc51AjwnR90HuMhivwUBuxtZurGaHSDBCQ21EErlveBVDqLtVmdyP+8X6hngFweWeLNVuihXK9TA9TQDEp9pxtbHHoPoryq6sLLVTIZPq4tZOszCcMYVfLzlI7KFT+ufZKc9ImxjE/lkzOEhicdm4oQD0ekbHSjkXJeOei6Z2CG/yZb9SBzFv1ahQkJK28va8P8pVEGyP9kZazdeQJ6Sxqs657cleItd+dHU8F6TZ37sOa+OVIX7H53n+QozE2k/5rJLtThC/hlBxS26LrKr0W6HEVu+n99XOZ/eSJt4sdLSs49gPdLf1tOSiVydc1gHYp5IYwDX7PoYiXibEG8OU84xkHUHBmIuz5nGy6xxs9+w0Ya//evWkLxg1uhRwE5UdFMXo/aG2017Z8DjWg5Jjo4XSblZLjlKT8RO/rMouZLLJcn67SeOqBuN/Ds5KC8vJ22sQIGd+HE5l1RH8if8DzmD0QRCwV8Tq6/zQfuWp0HwoP78pqo2IFsqXeiamDqvPo0L+aJcMBG7zEwsuEmJxJ94mF5fnKzsrIXsT7CMqgONpO0Zf7qp+XO5oKRJX2oWq3A9XYljQTu/ZyodikSGtzY0SITofIOv7jZJb8KhmO3QbE2K/BAeluvBh4s+iMdFpgCY7884QAJyW5hUSdsWiu6cfB+a68mgPv/WAvjqvUPvU8f877ta8Ij6IhNjfPAM8ZXR6vUqdtkbCCmu6hlCkJWNZ8LLzOC8uH6shCSE0pUVslzrwUsJvdwmKG/NfoqkDqjyaUF89u0z5nh53ZYYWYPBmBvyg37tMzPz/P6Fv/l+ilzG/q5bxnQP5zddONQG9b2hITaxViy5LidhNRItzGjSL5xMKnKvHHv+VU9LIMFCOjdPxJ8p/dBbiCPJYHkfn8+uumbvWL/7FthBAzEUVn/Eqmu/uW/wl2klqc68E/lEjGvzHwu+Xrd40arsu7/0+RWvYR41wCxnXAekr5UIMRLIk/1SYQzGIDJwI7bOVx98Y9ToWepojaGTnU96qHBOGoLCu957cuYfmZSkt0erDGzWGy2xdhtBQF3OZVepQcgTK/7ceF++dKaZVMb0N2o8EA7hGG3612naX/407bPGJFOHAtN8Nu8igQHLpULN9My3YI4WgBIzOT/IuisrLlywQMjuKvRQ1wAKY8U4QITnoWLEqwthG64H8zl1H1j+1O9YqhgiyO2sXKq35FKhNuVHuXJDS5+kZQ6oOe88Rl0+QhMgTI6u2vFhguC+zIC800wwG6IEMe408bf8Frd6+/diDLaUKfcqWXxVMLwvLBAvCYFS63EfrlH23BLUVrut14qLmiUTaMy9E+PBRcPjW1+/OMNTKp+91o6lqb6GvUrWgIya0TJPgdv3mayUdSrLUev7FSH5ewwMPRGZiWobkp9/U5re6wh0rUnNTgdv7KAK3jyZjESOSFP4JIHjHQQ7z0nKmotYsoJJHfG9urdY06A7Pgbi5UCBulH0ZL1hhYc+NxnZ3eHxUT5Txma1wulH7/USVoFVuyuj3Kx90gvPmuJIsExtIrOLHb1qGs3G/tPpEosgzXEQNfhYm3uTOpjuj7Xp6SkAn4RwDyhXyTUzIB4kTJn5HhYxTAf0HR0eHwzrsev8WLzCStvMUyR1DA0trXJcEhFbHA/tupp6LGE0Jhn72og/mFKfkmGdrWadoHtw4GumFL5VJS2kC/LzaE0/viv9hADK500cakAIbAndZh8n8uW7pge16n9lCwqCYLxULwUKdNh+e4HKXqt1TWDTw0iertmy/EX9vJkUly/Dhq9xa79KumV+EtqkAGPH3snkIafFjW3Xy4yjf9mlpfnktjUTMzPpJnj93bsMxP6AzePhhpkFg1OqXplKcu1Orm/TuV9lImKPgUQdsh6OjmFata7Dd68w5TsEIFCrx3FMaahtwfCzNfOFcZ+bK3FeCi5LGi9ChvAnvrMQd792YkNukFV/wo/HW3fotIU3VhcgiDJbi38HZz4KS7zgipAEjJbxXOwqS9lwjn2mS7u5YU/ppZ23rNhQV5QC7E0X04dn7/PA0SWoB0aDKuNRB4Qfn2PA2S58PegglWo8Ps+ZOHAz8SxucMMJshMM4Wn2WzG3GjjS64OVxswMXuyi40hYt1uzzSJaCLBcj0nbu3aTarkh1oUWkYWR3+Llzqmp1K4o+0bGN1CuXEpoUUrRs32IFoU92/rVy44HpOFxlfvlYnLqZWbCt3K2G6ljG4IeClfuuGU1ynhaAPozq59HFQHeV2uYOUU2SiSivZTcx7LgWSvf67cR4MPJ/AP8vOc5wWGNZChsKrXRNGGxuVuU9oxCX0+Gy14hsU+der69OgS35Sb7L1IMdqHaZYcHDkR+TV3g9y+CKSxZdvwM+M5FZm0ecsUuLGF05tfmL+t4A5DapvtXyUMP1bMIamorZS4NEaO96LoQJ+gA9A0JrSS9+2VcaXwGIarsi1yamQqHSL7IVH3cRf6X0jTH1C6zD2aMfMvVPD9zQtVelQGpO9Zdbg3WnzdbwQzS9mBulpl/dLFYwXgpWILA3OfoMw5xyP9Z016LO7DrSUDzPbFL31tHRLRoMrjDdjuxTVOZppqK5Xjg4dyGFS4VpMemfF3KFX67+JbUAyryhUIeaGmxwvTTQnhFw8y7SObYsBzdR49FwDv9y1mroNvo3s6cY3vhNe7o+CSFpod2W4OFdsZ3k+paGzSkgNZqYcZ00FoZkgxfgo9bD2c2MVrQNjUneuGLwhNofWN05qvMD/zT33VZcl7ugpzY+HMj2m5gaVMvu3/Jz7oCJlcSvwGxHxSd65Zanq/K4OHAWQF3HgFEWh6SzS+yarciaLDimM8DcDwFuLli67PT4QEb42xvfe/PSKJ0RADg9witNvfRCiSos1qZuC8PnSWBe+M4nSfbqnOl/RPhgAxFMKkRpzjrJtHZ1EiGujaub4wEpjywUVkYPwZ/uiL1snm6Pa5ncuZ2MxdmvV9mz1T/ReqC9g4oMCE2573zhQ2GKMvESf4O33vbREjDnuk8R6PLLGGyiviV7StTmIFbp13SU4G7Z4//OV3pJ5atr1xXYI4YOGWi88eFxBJq1E9k7LespCTAyFYly9tDp/5dnORx/rheP4jEP5ZISnt83sms9PPEBwVSzW/MPZ7kf1cOyTELNgvFxYwQImNOrtVa+WS9gYlAzUvayexQzvqRGopPu33rfRLk+4PT4BfGiU91hMsg2rWqFBC+qRc0nfWffR1H3cokjxPYw9dpWMdSj2Eg9UCtmcCIPq0fQS9QWNI4hlouZCMa73PbqT55BmKqY8VJ6JZTjeYr2vIb0jcyXMRggMMFoendX/pR0AqYK1VjlpQjLxVZrO4GMV7Cnm3mI9BZGaIDAoKJMfQLG41eYIAc245KzaRRWoZek7RukHKtuY41T3lTHAC8av/l6OyXGq54i8i7TcaWHisRuofZRgUeuOowmCLEIR+g8IT9KMpARZ8ElJCg7d4dW6nTSNAHRkHRM4FjJnOz9fK4+6uXIhK7sLdrsNSWKd26zzstfjmrdnsR+LS8SygkYXsa4mMBreZtJ7e2ywLwbLFEhctoV5T8++FNqtzAhYu1j2hUAAtw7cJdxphxPYAC8YBlcUF3ymfijTBsxdAkJidVJcHs/FI24J7o/CNYWLihOHUC/wSNfPlLmS+1S1zOP/nHkxRwIgS6NgJjszdHMnp2hlhYVck6D2qVwEE+8kH3cbqvIGU6yiIwMkjMEaUNlKadUDsvgheHXqst1Pw+jEJJAAHlUKTl8NBvhKv5nastu+s0bLJJ6uv0ybJd5QdS7H78DSfwYT4H3Z0NVZKYXJyHZp/Q++HnADQZH0tutI8UB2luVcfl8BL5kh/hHxoV5bPFwrJyYUr6S2ZUo9ErEhqpQ011ekXX+h+BtHPDlGHmeU5aPJhGZlTE/gK9yyaur/WNODU2L35HaPU28sXA93B+svxY/VhH8jPe/4AGjwFmWlPnsgcMYvQCIt/QfjXtArEQMU6HaPWEy4/kK/fJlow7AstTOHIzsUSt9cN2CqBDtfgXoTaouDEg3zGGIGf6ZkxHk+8dv07C4eyZF0iMJE6Z+iWWVpa8mFVTwA4VpB51pR5ca4IZOoFF+BIjzFh4mApaX0fMeej4e/mCTCh2JPszEvCHW7d+OASceKSKhAAi9TiIweJR6HWwmPpKB/22FGeEFIYHSoYJGQoA+ltad7HnR71Z/WeSvzz7P8T4GP8ugoBWWV0dnWXjqZGMkDByNKMbYW0dIg1qg4SYgakwQKgA/9q1w1XI1kkCNQDqEgfhzn+PYT8sNuNyV1YRZ6PJxJRN/hoGeeieR34n+Jzm6hp/JreI/Luk8XrXYBFrrY4IpCjVleJzbG5xMCKUwe40SXvZbz12lqWT7AYeEnchsOVyvaR8+SoODx0RWZG8g8S/4X/tm5ox10OaCD7GCrvaG0SZ1Md1qXPUOvnD6bA4ctrEFa3Foj81GLh0+llbqki2KDE8iCDJEPy75RuXvvZREcSlFje7jxzIXxb715aztw741C6n93gdjIxOYJPBIcQtJ7Rcj1xJJ153pAODCbTwxXv9kE2sZ2QwgKV2qvS7PjjNe/jxBk5aPyEyLoUUt9CdIMaP8sj3Q5YlhEiFmRjGueZl+a+f/zPp8N6EozNr5NaqTxy2BTpb1nvXbHS0eoIiVfsSn+xJij3rXLJ2MTFEtwjI1treJmKowfzZnvCmZ/JEBSJxjk3mJNQ6ngVcicfB/1rl781zowAUAvmjvwtuxjf1+p/+weiboMj6qajMe8lBERmGPVHgPcMWWbahdC6T+hSXiHdYC4s0a4EtrXFvZUmT5r0sUz9Bl8TYZiKXlbdpI/LeuDeVOmide1shs23gLr5Mfjuv3t3TFE4nk2NcNrgOjOUEAn3wXKfI6bmwTi2oUdPHEiP1WYWvo5qhQAal7K7RJtdtqy3ZVgNxaTjpPMmJWhYGEYm/AXL4sMbYjQasxX838mHoUrJZs0J1fnlNm5ScZzKTMnW+f2F5uNjUOu7PWQCxSlwaBWxuXoziVwCFGe14L4YgLeCbEnVais/RcyUWsD8a+pq3akDSQS2uoqlBG4TgHLrXATwCJzvFllqaFAZZ07789Hw4/bSHbNkurOV28rf4/1AIpxzjn9Zb+DDVHiQeHq7Hb9SJzNOLQk/RH2WZ3ERXZPUr/pE6HMhs7Gg1bDZSB8kxkIq2JXzxwkznI0m9TyVxjGRoPmT3CyY/jv8Z5AT0hZOeWaUR7UKSBDA35oc+cuxvHT5exBv1ldZJXarMM5gkSwi0lJW4fjnyQp10E1DSyxs5xA1VY9H1652lazzCdq9AkJ2ovnUG1iN7UZdcyirBYqVw7Kg7aZdVj6MmlmyCjdnXgbWh36usYk5BoE3/jQnaQNoYsYM9Gd+1dPEptL06dZCrW/9WrWufOOeCuNkwxrpS1kIJfUmYV/AHmNvVxzS7Ji+yxmcwgIRPwJL3ExJV92GZ+DYLXu7GZ4JqSfsgY51Alswg84G81fH5hHPoC0XXMbm3GznfBvAAVTrqQWlvn3/M6kDEZYEQOdyt+IrKSxEhC1pnE3tPC6TC4OV3O3bxsz4TY5XMsAuombncijp/B34d8XaD96Kw91ZUqkxlHG7bKRWvQs18YiTfyhumV37CfX9ctAowjodvU+IXCqjCtt2K+JkX5VYHZMlfg8/KmQsefz1xdMHd76sJwOWReqJeO0H3dJ38LPt9ZBqBoKDtomsPjMv5KN1zNYonnbmk7bPxviGVGVbVm+8q8fjNOpjCEJVzdeSzQ7OGAUHXPmzNT/KL+dSJz19aMleXrMXZ7it+nWsrIUqKYCqlsLTKImVQP3sY6WFzK01C1I9xrPadJyK3z0iOaJwRAasBrfJ4Kl5P/m38t9dvdMg5Qr0BZYGONJ2DX8OPhpvce2BXVNVIMeDj4RQT34bzL7l1U4CaAAEXQGDgu2Pt43y9iLdZ2ZaHODJIancg8Ub2FzoV3FMi7bAV+woPFvpR8rplA8stQqDY/Lz7KAt44ekAiO40lHbSqerJpIzGSVbKbFuS6fbRK7N2qHJ90LjgXkY90BBBFD0VrQvRu5sQ30gG72BR84tYUhUxSNpFKHSDMD5rb47sURyUk9vydy4e4cHiOzg/rPEggl5YVQP3X4/bUx+IHFtc3vg3yjsGU3QkQbLHoN4WsaQW69ui++fGgzCFX9iZ4iWs+ZRLOWSFZ92tvm4yoYh3c9huy/p3Wz/RaxnNReXGLmPrnSeyGmOKraeHustWlhvPhra9bqf3kvfT5gDS/HLaMh//9aeRrbAKyM/AutNlbw++9zUqr6Ahtn80TLsWuOysmXf/O6qiMKzpkJsZAreots0cOY4BZyi+HotUOzHSYaw0zZL6ARD5d0GvctM2xvCW0YlMFFeeYnVJD3AVMEGOOeu1auMCjtWEH6GG9VBIvKteRZUwd0ZREurpuwsBeIiZiRXFbE7kwMFyJ/Va9RQDgD3oa5Zt1BKMaD6ERpGuZS4ITGnLnwYFk1KGqtRu2IkMMVKKzIYXZU25BKBjtZlec+IhLYj5oNdmF0w4BdbuTzH7JwjHAkhp3Rd/J4iiCRDFmbL7r/VH3dk59+I4bBze9ByT033MYFsKcaG0M+edvGeENB8AoWTZTrzj/UKzhULqkcL/3GKzD9XGH62NaT7y1EiSemSrypRz4QD1akIFoqBk80QVsoSHdzUP9YB/o/uteD9Xu5CNR/gkBciyGCM5TRieG1r7rtW3PtifGlYm5sBJtZMU0eivXEvpr0kadlTBYgT2DOx8DxIW2RrreiNmCYlEOpEEHGVH8ag53jXV3W7PBHVnxmX/p0Wag2CagKC28TL8WRFWTwvTcUVY1DRotnYXcDHKkJg4ad1/dkZlk+5orxdOPxA7xABZdj2ZZuV2CVFB1AFSI7MFkTbqI7xh/XBs1rVwaeWxrs7uEU2tEe7yFBs5ZWmw90nm+v6z7y71cX6tN5T8fQ25xCnI9LAnQzKjH7vfYV7gRmF/WL/IP+R51gYj5lM3ucJ8H9CVbneoIqjuhVtlVfwkkUpwHmL4X9tqqCds4RFr9311YcTEYcM+zim91VDKufUGQ6LdmSrcCBrAVOsdgyCY6OpcCOcn9mmEcDj5BakIMnRnw4JO38WgnnQPOx29wKBTlTtmpnffUj4/uZ70Bx922fKb6Gp9N2axUZysbLsl1rRvE+bU6xHyCkdac1jLgelA/02av8BBs6F2cPdRpdHZQ9El8iKmJkYHwicejyiPD/O0pjhSzr6OrcbspP9gcHUpw+8KUh+JPMN8tLVlsDs5xbjolDn0t4Ugi3hYSYESsh4xBX0Hoak/TvzIXs/PW6qodaSvBcXQoUSHBq/z9Tg2q2L+gj0uISVBznNzgiye6L0/W7LncclsoZA26WmjYBguXzouSdsDzPF2F5RIDISYwQs/xQE0lhTrYVNFDcOIr6Q6bUKeZc2CNBFV+r1oJrVgn7+AglVKoiUtJjuThxQivMYgjwu1SnTdzps92JFSPxhmsGD4fpEJBChlWZjbPV3+MWoDbN7Gl3K9zR2uXVv6pfRkxJLA4PFLlc26XNyPH1aJqHWiDc1hE1V1oAyJlkeD3+TW5jI1rkLUVSJY6mT+77/RCFJvlNjmidfTw/BWjdXv/x2uBv8c08xI8R4gepfUo1wEiNni8Uk2LrS4ntVhHVX8a3mX7WKYDJWwhyshK6ycsM6T2UgQidiTVgKu3Bym6SSXdt0kjKVdlZW5GL9WffSlGtJUGkwpdtyRq3XFjlY6dQdweWzCa/+xAuQL4PL0v0vZBQoNsIKdgFyqmKruQW16SgNXeM8mWPi11DMNDHhz8tR22gvHSPTzvQSoecGL6sdZYkTJLVKnm1Pz/io+MA+xb43ta1T9SwGm1SdwQSf7m8aU46cbr8VZ1nSYLLM5oKCWAE/wckTtsiw63NNBl8tuHnmBQlA/W6xLPHLFqZ/AngnpbzkRo6HOP1euRz46UXbacqRD37L2w5umJd51rV5/cFc/wTg1ia6aqJMyTp3OacPoM7aGTKj6Ayn6VkiwBQNPW8KrSvAPupd8UdpxuN0B8lpP4TdgpbTKZK1SKGVK4wMSmaZaw4ZHAq2c6S6GJGbdeagnWQPEvcVsRJUt9VmMYMdQO0b3CwRyvLzJG1f/BKorsoauGe7tYbjyXxTRji1jxKosk/pqbDu27PxaQQY4sVw9jHKSmeFWwvOC5EkM29QhnFkOE4qu2BpbAIajH/tw79bufJfr5V8J/UrrKdoBc6A4YldM/PxqphPmtXtcRToGmt0iB1OaRWNHXBX9h0g7vC6hy0ARWuKWXh2+6R7ZSAIKAcr3t47tYWfru4teYN9P2rDQQfhYAVuE8v21xJ3rc7kejyCThfGq5AEJMLeav6E7Dz91xk7a7+jl25SggDO+isLICac1npdKGug2hxpeaxkC+WEl1DRTAX5fYJDOZh0/cAOJrrU789U/gnSEnUnBZYg8VzjBXdMQF0tiwtI/d0lqLVQu1UyTw8IxVs8AjcIGIDv+slAjpeS964oJ+VzlTYt4y85m0CmK9j0HLqq7Uv1PNeWSxC/vuiEmd3Mf1K7UKR7cVp6jnh6H/DtCW56+fLX6Y7GYU+maqpK5j+CnBaFCODdf1Xem1G1aMCzR37FpcxuKwM1fzxCFjDWljl+XPiI/C1Zwu7zXiDZ5NTlzs/MRgCtSKTQppRbizmvRjvsKzHGwwIHw/bMLK3QBIM/YkqAQ1lbrBhrQSJpSQlWokgKzAvQfZA5q2hBAJoyVKtnW+m0AH/D2e2eFH4hCs53S12ZPXhahk8kXOex0armbLnQK6CpIOLcemLn4Dm93OSxOd6w6Xt4ts/6+ei5GRy5fRwCGtHRp/riCK5IBJjO8ups1s/IDFhQhESOZYyKgQaul+AWKLTR9Ysu0g4wX3Yb2Ju5h3ytdoZbso03yScpLcmlk6IWJbgRxq9DF0ANCxPq1rXpm7KP27w8SOmKLRb0TjBzQnEQkOfJXBxcLSV38pLpnaPfEReGtArBwkU2VD8gVOkwNodVmxKdhZDT4RqmviHxdIj2u6TfrOleKv6k8ISa3IhPlUMstCPWUqiyKg2M7uOyyDTJ4YOoOi9EgM6zPCcW6NwO8ln16haZ+HaE7TaCeMhwE74UYSMkaW+KVJSZ9OxR/Bejpf/NVT7+C1ls1jFNEXTT3TR+q6hUrjLIzzi5v1rLY37ln8Z2677ZPWeiN74apY5Gfbyqm7KYbXwcElGhfuPpopT44qF7eZTyaTty5Zh+FIQm6pgzErSOs1LE++HjE7/9buqUqn54NMu/1WZ7Pwv8HvNqfQwuw5IKSR1EYa+UjwlbyrHbcs5W4AguETDpEan77ykuEVcFmjRwcp6UeoDWn8kIThPx9xGPmyIWBnfDfjpgG32zXlVMb/PKmoCVPtwlaTsGwFwtnqLigBhNhuzhQ4JJ/FfrHstqETq1fQB4cYnhZ0TVhm3uS+IR9RA9AEjLMvjHjqr67VnauHL6yPEmD8bSZ0RHtaAB04GEmlBxn8Pi5anvgQfpvIIyY07KFpTtw8Jz4PEQfPOb8GRz4HktHwyDJkicasdeGvf/5Ubu0If+PoMY37mhl4d9Zk59C21WqJ3GKVMCLiqNNzN/ubhrguH/EiKj/osDDrbyoyruBXcMyqcws2B/39dxyWTDIthEBr7yaPuqY7I7ow2BNfJDxpjZU7dpD6iwnlhwqWiA98k0ukztn6FxxJVeaNT/K4PuG76SwiVIzvdsuhSkuXTB4q2cm1ARdHbWtn/AIHlF6PohiGt6E05ZNRsoTxUmilz0YGTXC9dHXNPJbtUqeYSb6/WxrWPXtuJfuS7FiB7TB1dLzAmZRb/hPUKFkW5SxeonuB8FtSJuWrKlvXAb87dkfJdW0IVh+OdYC2NQV7WEniTFajanlg5YIH2k/zF0vQNWXOgaACIFd/OrLe0FAJzE9LgRYWnMuLMQC5+NgC2LOWiSFiRTq2PDwLWn8ajsUcb0yp5ExYGcbtpX9uh9DUOc+d6qsWvXEw/z4aJEdu5kK1SrqHPUGkKn3PUxxjoBkIAjjbf7TAkjqRHNjJ/bs71A7FmLwnxDL/mWiqQcY35WPtgAzzZqPl+2GEw342ByUVESRVa/aAYKxUu1snMcV98Af6siFgHaVJpFsFYmcm8qtNQ5EBwhlbBfV2SR5PdP83YgxL6TjrvMK0v/UwnOZez9fvy0tOCKNAEtYKO/GD2b5L9ubl34yWGBnPvoRX9EYz8DCIhbYmpva7u+WgbC4l3hntunq1EwVxDcS3unUwpXrUjuFlutANwUNTlKLF7rsmzrLXxN36Hl7w91pccaZWSJBUfZYUb+4+1EOZo5gN15uzBhU8BWkFP35sR7TWIQlxaUZdaBxWNSBO5m4ovnmCYfkr2yvNYYBQt5wiaLg3ZP0GSPWIglN6DJfVdGG+bCwr9PIA1b0G8V/wM0MwFA+7CP2NZXBtbe1ALeXtQJzl3qubcGDmb5VFpQFTCOVArAu7k5IGNPmoLYPh37TgK5ojPA2ymZCR9ub9dI1KO6mwxPTegH0TY+xH5oxSFyJBDA4W1rHCQhgsImX3Fx1eeRGHrvJ1iWwKNOd+HEmoBKtXJC1Vg6kfDZB71qDPIixZOUeqczol6S1J35pfKVJ/oa8obM7J6KAzi1fHV7rIXelE1+gQu5vbVQi6YBNAAUf0bRWU9JrmyecFJvyHfTLyg0XQ1FjoXQzkMcz+BgcO/bU74ivypfIxdaYQFYv5+RIWL+/+MX6mPtCvfPIdAom90orWENC0kxTW3YYbB9nyvAhmn04NogRMrlmvhku2TaIRjq1JIU/reRVa4aHrhlZEPna6OMNe/96X8503CzThK0OV83t5aSD3mPbk8bQ0FirXr+Qw9BqQhxp6zhlvCsuNo2E54aCpkCm+jnbcTL1SzpAlbPIXoTwFqTNnUVzMqjCmER+YE9HKW0qzKO6wvsujpHTEPc6iJpVubyjOrq1o39G17XSjuqcAj1vGa+reK7i5byW5Q93j467+N5V4Vl8EkDTOOm/gXqeIZZUCQ//tHAOY+AEf5aPuSqXuOZeiwl71LuDkDq+UtjAarVcueXqdYVCBrffodnlJytkYSGAUQ+o5d1jnIVRcNo9VWw78mvEl3Bai4lkPCllmwg1ge+9W3ftYKHdNrkORP+yokO4XP9Nw38LgtLKFQm2wSb6E5QadvpIkP83NQ4nf9OUDcUw95rDsA1GMoqCV7JxkVhOvw1gQukCmf4rQOJujR9qJw0kAADGM/hy/Oa6ciPRBMko37AH4EAYAiu7c0iTBn4PF3EBGidD0MGYl05O9e2VIyQiYHKoYhh6abc2nyaqIlCXQQWfzZNAp9vbyvg3LQrv2hOa1VNj7IYaIoJbfHqmKyA7K3VceUAMYlx45rYN97yEQatX5GiERwrN+XbQxeFWpjcwer9dZ2LznkUZOPjkJrYDzjOmmku0w7pLIzwkUqO5+c2bHly5eI5GSHPBtiwpzXsNZRyYjTlBqCcOnNyAPj3sFmpED8LPeX1eMEEH9BMR8QonjTlXzf8pFyNZ1NIrlw3A+JuQ7eaRtIw6OQ5+fRU8u8DB1FtKeqg4+VvdlnxmBUiTVTn2Z2GauX1IN65/oMlKLK4kYPfhBN1PdzpL+wwSthp+nBfDkqj1m69Sgwpe6nz8DdMGGqNOIb7DVPFv0IOrceF3FsLLEemWZAjujVpozhbGw1WCLES23/tLTHTrBNnJiARZVPNLBv8xN3CiZPeaLBElQT6ipmD0DvrD55vZzqyhh2oGBFZSSU+pxZzF4Vw8lWi7LaGl6+NAnYMjWEQsok2UzM4acDqwh8s0/Ab76ohArHoRJpaJpfXUmkiM8eZtZKOR+pjB8rJWhOdtTJAwoBztRnmfvOufJZMZWx9ridH16PyTlb1Bp7W99dl6m1wmki0Lw6MXGPm2k1Mhzw2w0hWgnv+bb8NBALS4mq/OqFf9x5pIrXIWxaUmSdt7g414ZEFalEBRlRwAse4cqRUYHSMYbassW0QrfmCZcq8z47qi11z5MOGNURMI4uUvHJooEnAmPRagsC55c1y0SBXblr0GYl6kNYectZ7rRDFMAJUomlIZqMheZOCiPRiWRRtmclLq9Rd9Kx3pBhIAFK3VfbkJ1P/XK2tcp37PA4TfcD8KZpRmfBWRD0BbKRVESrGVrp2oOfgRtCGTgjxszLUsShd9anG4nxsvey0NfHHsbFsAXWA1/ohhQDSRSzX0St0xVUlg2h+3Khtv13xkubAKbThmrPfUUdFiPuMnbshxyPdo0SEz4Cnv0OhfT8DeIjeRQb1y6OUCqRPS+psaPaCudRFmKcHbMD9R0JdqrmSXmMNo0gK3sXKtJN1uJjY2p267tbsjp/xZf5+dZU0/FubaA/3V3zz+m7cq3DbWXl9ss7sAv192yHIVNx3a1rbVXnlYrAwE9VSAHBEzdlOUHAtNOk9M/YEIU1ekZnvSZOjK3+stJ6LbetrRvKsTplznQ2982mLXsjHSTQ8bP9Y0sirMifTQgb2lbtgQ3tR6VmwwE2RvGd6888Y2FBVcDyiQGyE7JK3QM6vRt5OcHqsImOc7FwV/ENec/3pGfE2a10NbeH5pHS1gbZ1z+cHbUUWrdt2eBe0HoiUqniCor831ARRpMQH+0Hsr43mwWLX5I01RilyTEYTMMTrC1pk2UzBGaaPr5jjiGUsqHVMzzQdvlnNhxvX2+GX3VfAdbNThm7l2nvMJho7ap0NAyzwYv9ygwbUSueB6kuI7O4OOju1asZUpBAYpwlamNOxXwXgPdHSW0kat32+zrGoEnpZbhd3aIcmO7PGt2yBQaNBFx5yQjlRKJSbfDM+ImlzWjqhOgjzBcxDrVtNISRRAAh083L40wzhI2JouKq1Ma2uRQFN3QZsrKLjXoFonYpmxFnrDflLeyQ76T7ubkMyGzIS82+OgzhY/TXBwL7ey77/WUJ6x3MEXZVsidLkLGTf65aJZKNGrksjosDeRdrZmQMa1FJSnEkPa4xwKeds7YW8iVtBX7ximONK1m/o71ZmzVkO691WIIxW8JS1HhHD8V6ELt1gs7Q6ZYNsxFIPeYLC0eIAlHdcRMgFla2jCMVDsJDaMBVJnDMdK73AMuKCaBQX1wyq1lzgasSLmrGttpkwWfM/W+1LjA/2K2EnTiAeZyq+Aunj0h6vOxOUfPMW3a80B1y5MVSH7EYiUF0LH8K71nIRA2HLoawnEmD2xh3z2wyruwvEHk8X40riMp8+zksggGjR5g5PdMENHKCwKnAtp9ycOoLslLC0wmKDK0jdguvfCwKH14RgeYdo9QLI3dxN6B9LM7j5CLPbWxBjrFCdexjFGrDoUy+0zHNppjSZ41XCnhxgb/6k2kjZno72SNjf576X81XK2Hid4Lx9NA3PzNT/Jmd14Bjqap5fBPqL9SCJyr4Jc5j2+nr9Gkuz5tro4LWB0mQZN/BCLa5cSyF6f55J/AYZlYmXqNMgaAgEELyYCoqMDiAnxtIfxFvtLdh2K8LyrdriQYRqetEGZLD2fpRMy8Jboo0pBZu4kUXcDtzWDvfjPd6ioWoc6Ay8LCkr+WcjYOq4Z7LkEK1UJTwu8E9aJ3nBG2loLzOQ1MJiL0uIwLw1ex/3hNbFxsu4D6Q2RTs+gr573aZgAFISE3NJ4bzssnJmcxeZvnW65fluu4C607t9zhlvTJDx9+R+Hex2BdWkxWxp+R3bDr1ytji49pB3JggwCMOX8ZqmhDPIlt6xHOONnwh3G4CJPuf74ouNydRSm5unOKDiv3qoAA7WK3Qles5qa63IPFdYHQLkginHomNSLlrXGnctFJQhMfRZ/f1NfL8MtPjqWG9V/zN7rEqlu4Txyryfm8Zk0Leo0bAM6pCtsxXsYL0voBKPR2wiMpZ1K5490lG7bIcnGhWGem4YO2kc8STYJv71XsaiIxJGmsJagvnAXRHRHQTdf+LkB7Od9V/rKkK+CVwftbnDtpQBHO3uHytbiiivjwg3rJICkVvNI9zWtxYUbZ8FI2FL8J/tSgCWBUjqr/ZJ87uevyS66tEOPqWzyvyWl/9MvWInPLCvOIkgAUohJZ9szRHeCx2uM1G0FY6/VCN2pHCpBrhyuEN6x7I1ZODAp6LgPWgLJaY2CiOLl5q4UC0JhYjopDApGrOTt54Wgr5e1fZB4KdvFcVRyVnvGxNoJSh2joCqw9L6i+rFzxhCESxyc/y1l+cJ7Rq5Gj9IqY6oFUekTMHp67Yt79RwtfUg8vT8Ja0vTaB7mikT9ETm9mow7l6kL50kTyqYcxRfqybaxPYMnypZhRdF1lw3H+KwXNxf7nGF0RuBwh7QQUm/W7o9+OcRn1j6qQbRvUykLXTTGiFHaH2Nn8sCQR647AZZK33WLe68c6kc0771A5t3E3rDSv+zwOwcMWoVYUDEOOcTj2FTthfIdeQATu74EAawFxo6LiS9FQL4+woio57jMs6vRVausWS95vjr2G5DrnpoJgAoP3oRhIR4rl1Ts1IpGPBtE8odwOKzrqjz2QDk29sieMippk0KEKHK0XxEJWVBPvyQ/NVkRpmZNQtWM4xA4JIhjKCx3RsHzffolSCB1hyOTA/QzSRAWmUB/ibdN8esTGarXoACS/7wbKoReqGoFUGMpu1kMQxNdKMhRal/iypj0cz2e//RBjH/Spjcnp7R249bBB3XkRMMyz5rU0SUFZHQ502WoM1bu8dKEuKyQ0l3Yz/5cJ5I0rAXARyQj33pZsDPgQvTE0xCc+f/5bJYMW81suWQ58ouXM97ZeXC8Sn1NHA3NgEVHGyEnvc7AuYFu/F+b79IfIO2/PMkcu2naxX89rPUMNDcs7F6KX19ylMRnon8rUheQBTbq0GUFOoJRUyVlOd6ZKAfVqK/eR0+e1j0PEcaMy4f0RFfGy9EG/Ad0+3cSxlhh47uydVp7xlFPF9DAlR0mEPVF6hNttaM6fchMTprkqj1KrMDq01qV93pA5Dwb16MKhCw/B9uyV5+oaHioPWNrqjRdmj5pdeVgtzUS+adMd7mrMt8PY5jdZbvO7Gp86/P2mMAw7F/rclidjzcDm+WRvKWIUWJmipSt7heVdxC1GoqPLBbynwV1fBr9UjCOgHXLsDwI34/v92iqJKDAM9pl5aiQ5C+KQXps4sjyNyaMHFVhhRlm6UKru4TR+8D2i61wxjak3f8L/nGt+p7U19nhAMRSJ7dsUfLxAtb/nnNoIh2Rsob9cIMi1hHz7i005TBdCSpeKhb1IYrt2FOFAjyUweAJ0N2Db58vDMG6py3nmykeCP8Y4W/O0J2N68cPeZ/4eOOfzKvaRU0Bg6r9wJI6X7XeiNDA+A9PslfGHrIBRxRCk4iaXb13iAeY4sT4olb15YgctSO2ZERd7qobquEl4Hv+VKdb79f91tT8uTzEZ2GgfwAlTqmkdcV8VwpsR6Ca4gMOfZHwkRAdAq8e4u2HKyioJtBDszceasCAm0IrjOcOjhG5MYG1mBXHX9H+V6zqEAdCkFj07vfEqpQOnTYVhTYpQxbk3R6StczQmHUGK3Eo0k0AulCYYrk9n1iYRBbXAzrZu4Mogvi8ZGrUzKcPVXj05tTF2o8VdY4hzEiWGNlEQVmh5IRdJC/B98QcUhIRQeNhrDVpABxX1H4NZO+D5lKZY+31kfOCoaz+IrchxabLIbH3C10UAOXCIxqWRLA9BZ2WZFuHfLGvygqgTJFMxgnfeF8KpNDpPLVug7O9Onw06JN2QbeOVCP90Ep4o/dUgSJ2ut83xFVEOPWJ3YRwsiSLERQCYDZpNOi25q97uXoZJSNaFXC9O2jFbGeDGedcR/I0Y9RvTgm8nqSECfHoAgrrpyOzCmdu+fojmLqbOAWh2eOCLv2weE0kri0Ww04v7i4jbAjFK4Vow1zhv+zr7v36F3os2ONad7NRN/qIU2ZeICL+ShuVL886d1JAjQWCLXfsxtG7mXbPr8PsL+BFxxvXdR7InxMfwZj4fGVG4XKDW+lxM+UPOuOGJCR0sAymXjphX7MmtiYIHSYDotx6/jHXYDhibtiEGcuHKiw13GF9UhMdVVpoIJqQSM77XB8EIg0fV0WsxgrHGSld5gHGxepX7v4WIIyWPDwaT66cI+ez4Amkxypwv1mwukq2rCAZPR8NL0rqO8iKA7T3XxNtqsHFmreEqoFkRScvi5lff2xLW8mDjJOGh7yqHH+b2jiudZzPi0Rr2iIL6PqOaqvP3o6hiZKUT/mlxwQqkaJPCqiu0zSEBwsSNKJzmcaOhQHQv5VXIqAKwxBxKD9UIBl1pGSTlCweIw5zgfaSEZvHR+dtVwyK7jpplXvyOmBLSi6ZkliwJsABZ2a2x4/oNs1I32wt0O+uQV+YUXWXxllJ241EagtxkMlx8DEAwFHBsEjsJ99pQUKuZFHUsq2JptQbCoKLcslTgkQIPA6/XF1lTauI+gryFJkHwWqLmJY4VVnKVXWTsGUt0waEv9No5dyjGSN7CUElrYbioxK0LBcqWHBEnl3pEo7AYrSs6a3ISDg824JSGEtZ8POhsqBUWaeuH/uJW5orBLO67jeYwYtUsDKP8SUgrA5Yi5WVHCSdnkZYksCM/MNgPzqMtQwBeu4bDugl6wR79nvBqQuLLMWt+CAATS2u2+iTg8Tbtfo6LITr05/cYwJ6AwzSHQLXmBQ5LRJh9Rs7elf91gGQqtwBsRUQ/SCsQHJJUOp+PvZD6O++qo2GNo27GcA2/rNMEn2bok6Ecftdh//wIZ0J806E1eNbAbCLhlHu4kdo83VRAeI+h6g9gfzKAqidfnXGudmzreqs/ozT+HyFB+nPTMpm7V1PbvZVtw3X6VmXZy3YhetPJhMaUBHE/GbXGLtc08HwweVmvIw+c4nZkm/3lM0vNOl83x+vy9E/ZWSjAgnhUgvHH3/VZUisCn5faedsLNV4aLJlDZe8kjicLXRgWd7H2QLGYA7IF0YOSNrJyv+3rftkX4pWGlXbNY7o1o4zLu7SXqS9rlQxlBIT87lmoe/cDdopVcVkPI6oSag5RPu4Rz+ELNTYa4QvNYRm64bdKRC6/Tf62//UE8qBwONwDiDjciqOH4+kJp5+hpVKvQ6dNoStkzJNkidvX34iIliMl5Im0fEx+OBSfbbJRvsgUPNhvzEB4TBSbe4MlMPofocSJUdPprnQX8Nscw6auidobaUlHaSxVeWqxpw3Q0R6VAHJnU3GnSH+rDBKVxa/8jO+YgJakO3/61lrA97AjH3B8llH3k3C99L2PxjTEek5YC+g/DBno3tEJ+3WeROGiEh660IXwLDOf+I+LMhUoUtEX+WXRqmPS7Svrbh6GIwX52YKiwjocKxHnzclERNVwxjHAaXGnKjNOsaccj07qn6V2B+AdzyZBL/dXVOVDREmiR7AsL8gdoayTxtX/tnUixIXm1rnkMNmyakwO47jZj4M3ywaR7EfdkGxk4O7tQhMz+/ivYNQTrLYCH2+X9sdZdddksVGg4sPZoxLfgCN9BLKHZSW8BCC8awNenTePAm517CIYzwa2/NxptDxioFj8+zuPpleV5zd1KFk8sqVKawcxt2CJSo/TS0D441oH5gg3XfKymFHoXkoozK93RTbFJmtp9oY9/u9GxJWYPR2nV6XbHLxQb9gyTntuWYO1bQGUbLIHRCF4OwfxwXR1WLo19gZhjbQXuna2ifvX8wcRZZUM8DZohtb33M7X3rypJgcHfUPwBU8rXByPixnK2eCV4K5n+bra2xj+ihDgZPex8tD2D92iuEPVjCRgU9oCW57RcQ5lc4gaqLJrfmLBeewYwpW4uQWHlMzgqEew0X4RS/ZdVSK5JJaZdjpRpIBVJ/ODV8aUuxgR+qNkXbrpcHR5bQT8F7GL9tA4IrFQEo1r82ej0HnfMoCPxcvtaQ0sGKS19cSY4o2/pTyaJd/XZTqxpccyDfl/TZq8qDHMeMFI4ZbvGxv8IF2Tc8NcvIfXAT7SH8Dvj8sIavTzcPenVWigBMKnvSPUMsN3NNDLbnv8jLUunu+lxiBqMOOgFMbBzxw84pM2LJ0b2+9HRUUGbgnORvBz9o2Af56gx5QAN1G7WJXTeGgZOjdtdBvRdmWh6hSlEFLR07D3fQey6yyeG++0hZbmda0+arbwXaxFWpNDRA7nHDTSSx4QmgZl0qtmBmKI8Mc4jNrB90YsF70Ypf7zhwa0T9rr6psTYy2RXwxtEPwMLCChFNvHwnsZ251G6aMt6BfwzS+eJaO1aQdbEfMl364RlkHfBkUbnsPvC52fmN4kV7aeN5YcvAKIXizPmaMxNcFwB2WeEv9VqZ3C+QpG7WiLxvSAF3KkKIVqx2WJh8zBpAFv5WW8b4awXgBqg/qWEYAnqvdiCzmUiYWGJMHKPCEtqO2EbVmMR1dralzX0rgQcp/ZI4SBSlMVuZoT8mF9sN2WCpBRPceSbMdvH824g4qkcCb/NFilw1uWWhGs48wADYcOsOB0M6iHNiw9pW6K9IPT/R0+ZdnMYTpK7dxmqVPCasmdMSz8yK9jwmnE+O5XIpzoGoWqQi06ulG4wH/q/Dd7mus0h3Tj0Fbe8DymThdkvprlFO2RtzQ7X1CrTVmH9nAvavwdSSrC1NXHH9Fbfbf73A9JeuZEquy77z0fIgN5GZ31F734/lBL6NOqMFc8tMb3r0+6uVhHQs7B3eUy2DrMe6YE0ewjWMwG7JK8yjrMH7c0DjLfGlWw+qUgXGogJXrE6W93gRRAJVkqdNveNWiRUbNtwa1+Q9LRsrF3xPYUrG8Qh1slXlGc5v6xqJqVCOvBvhU6fOEGHD5fs95y7Y3dQMMI8/iRU2Wj9KZXawZHBiruAEpPcWtig47i60XJEiJ/Muanx9Fa476y8qiDbLMNc9m2KUq34qpaYaTPqUAMoBxSRKPtxvfx+8cVmRrE4nwwwajQJ9pu5ife4Xnn2Qi+JNeSU1qVW0pxnY6a6HLKAeP2mCtcTebyPXOrAJ7m1Q9D3MnPbEDk04ADespoOHxO0534hR0I5HSPevBIHzWQWF4Vj3DIIy1kcylZCpd0ZuW96yuzcLtJXRJIJcO0ZRhb0GlXUPPSBCUIz5EsZN0WDU3LLkbWiO/9/k0zQM/k3HOsK0FF/VS+pDRDwIQgOnAk8TQlHCaFAwqlZcdufPhFF73xKXNGSVzhDzYWyEJBoVjNBe3r0q4paR1XPlOy8qCSWzL2bWXkQg2TCTwU0MRhb03CRJtDlAkn1AjwfpF9VjUlxMzvYCk35nDbtBVgd2gltPfnfxiNC3MVb/njbMyfWwou8xr0fSrmqe5VGKr3lone1v4yTEVfZi732RNMX+3sznRCXiXKSQGuRzFvoaOuLdzw836Q4syKLZeSOpbAWvIjh/hYl80CwAIvLEH2XogDdIt9BUXytgUL+fGXURUu5Ti+8q/gMnH4/tg3eTtNTE3BzoRrKBb67SIUoaVDxGvbQzkHs2DJdnvQrjyE9OH43odCXs18YnGgS+hctUESNeVhTSuvEQyhU0WCbmqthcABEBWQNeZbDo+rJLlP4VJQlySgrjQxoqG9DhqTi+yrwSlO6YI1YOyGcCF64MkOeZZd9n0io6KQl9kBrV5+CSXvq1GcexYSjS9tQ8UXtZPzF6diuKooAirWpj+zavGnPCAeJjQwt2tBf0I0dKSwrshCMtAppScqhhJHEaUkFTSSGs+aWDJUd/Y4aSp8ZVggAB8wyOSKxrASrdEFVk7LNRD8s10S2Il302BYluVZ7gscNaYDPHYyYYBvK9DZ3CV7tC9/I28O5FE0nXVQKl3w3dCtA57lzzbaxGiuCDQAUYEqAN7KbDrLf3+kr3d4H/eLkOQpQXqTRtHnkI6q5rzcIkldz/Obatc7TKcF9yIpjKNx4PnahHOP2psOu74u1xneCIVz74ekyhqGZac5P3duZjR/dvoBJKuJsB8XhqrnhAX82x2aw5ys1nPEikeoNV5Mg9rMastMJiJ1HBRJPqTq8lj7U1VigjP9T3eASa3jJfStipv0IeMDnmYGAE7a17gNt51Q8Pz3/MTU+KlcPSjLkEJCgVaZlsmlUhOoZhRbVkj2TdGiWysTlcWSqOjVk2Hvj1JbyVjDDnch1y41PqbjipiPAdf3uNelmAB46LxqcRU2eo82cRcP75d94o0xkK/S9IOyLJuviYnXghwVDOu4LPgwt2Fjsttx4A5eqf0HDZhxqYjlCYy+SyI8rzoyxtX7Hfx20LJ5TlUnoAkip8g+U/Jc3bRIE23mDN7MlF/hGuiSEO7k2CleSW/y8a/45Q2d2BpTDqbDlxuAmVzCUwm+BmjNGkqhXr3DOgwl+kmRNEs+aEswWVlwrlLRGSfd0qTd6vaSmnxpQ+2ejIa4TzvLWnJ8yrucsNK//SaAmXNvE80hsr8zzEESw9VKTCzxzSYqOzU0J/qd3KTAimM2U/cmssiU04fwNWvWuIDPNY9wYl+m55u1cY3gNx9o9Hs80B/oFNi7etD2x8Q3VozErCLYeof7SiBJs9jNqHJYTeL7+aZmDmOLj53e/nOsp8mpWImpmTV6V27EeabkwtR2gXkr9BMnBGCxAY23Rv2CHuRlVWVRaaTZpssLa9R8/UvjxYUe3PTD8B4JPjzXSq6+jvLx+nLM2Ha+pEgC3NH3gH0g8e4TSvi4oVZlwW1e60Be56o0RRXoGTOApPLffu4KwA9YuB5geR3JN0j4zxe6M889ri5MXO9CB0o1s2X3YnwVFBU8UrgbzJ3Fk+bDANMUwXIh8hh1UHQEcapeZerlDc3hPojTPD920t7PBwFzPJb6F9xDvhO318BEIxTH0cyLyh7UMOA+mni/rNYaCLY24GMI+WvkkeB2uPoDGNSRpvX3jYif87HCQK/VJ235cuhp/zi5iee76u+n1tqNgstroLj4O1Mfeiz6rSffym4EHcS0L38WXDZk6mTmO2Y53CqX5SEGka0ZJ/L3svMqyBzUg+wXAdVlpXFEE3vyuX/gK6K9sZnz/nZQ3D5V2MlVn4QU0ObiJFGYX9N/I2s+68dsUTuqxq3yJ/AT0mxMVUKzoZyN52G5WTD97kVp2R5OzTuVaxosMuQrnG+yGeRGrQZUpM/VJfrkzHc1vH9uvu3rQfen2i5ceQYcJ9Y/D5W9/+y03EMr+/96NNJSZrDhZBNb+ef42yc6SFwuFxYVGT9DDqxprO2pzKsReRlUVY3JuQ8CpWIgpbAZ+Bj9O9Ej0HX82fnfdIk8pOP+5dpU1kvoTPtzIOHCRpmYGL/gnifpf6q1SwB1vdieF8GbbwQXqhFCA0G82rd0U4s/OD/JZSxBFlmd5dkudeR0L5Fk8WInoJgv/y/yBHzwMoiMBq+QiR2+M99r+e5B1dSKuxmvH94/WEkoTaEaMZ3TV+aC1r+pNTb+GWQFT0HAZjxCvaX27WIrDoNVBvurS8DKN19szyevPiz67KqyBfvSwX5pF4lzx9B6bUimOED+U8BvO0auen17o8V1029x3YXtMgQv3OSCnl31v3iU7HaMz6f9VDArqip/vofCaAPSKFsAw79FOwLxb+VFPmK723fcHPZZ2hcFC7E/nozyfKqZC9UcJyDCTAg1DGlj01PvY/EkS5EU9zrsHf2n/CfhSzOKDe3bAvSQ0Bx94oWUSThYk4Visc9LXNuCyundMlPEjMd8Gq1o4aRsjIh8x54gOaWxY3Jf4tsI2A6ZwQcyQtyb+7UKXH2zMAEXCpecnkR4dHCs90dIo/oOpyfOJ3WwE1OZi989z464ASZpQ1BCkVE7bNxlE/p/o0nzWJJ/wSqSO0Td97BTn1lX5aJRPtWHmn6GmOheT0L//A3KpfFMafONGHSj1ZFzpeoBI9iFj8nPnqYuBw+6wBOfDtFpYnXjxOD5UypP0i0Zh5KkBv8P/l97Av6nZg80swgXrcGQiFyIpYeXhGAZjiUSv0ZWmfvulgSjBMBWa4Cl48LZ0iPdDpWDmkS0l7nUNFDYdX7OHTPPdTYlLgl9h9P1h8QCKYKiJuNKEiUnJcd8UG7YPfbaa+UjnvGYpek6iW7fDpmikFGlFZBh2LsC6nwitk2wT9w6z+Tiqa85ptjKoIR+tLGM5ik/xTGLsKRcSThZqhV5OK+3ZwxmT3QT0aUiHvmSGPZyXufhDj5gD2cTY9wuVUTim5M0EDCtfXqosfYnBw6SwAfZr5QF6V6utcG2ihcpB2EWLymzoz3glF6IrTZwPomoWy+4cZSIyxiSoTDNdl+jE63guOQV9g45ZuC7n+AKZdlP9I7C9okNZXGckN0H9FIu8VcwYHVoCqL46/yNDe/T1DkLyPxdpIReRJX6iyYIDTmKGlE9nlbjEbMhUyHZ1Lc/GdDZ2D+bi4S9rRKGDwMDjWph4THZohkeuzu3d8VcBLpom6rhDm14schZKh8GKZgKx7shdst8XmMXVqn52Bw82k3eHTbNBnvHlH3rfHttmcoHp+VjWzmxopWyuWOnsfGF5ZMJnp8SW3J0QIozniKM8i8bn3vpnlVgDYPgmvXPxND4UouldWJrHrmEPjNwbXE7rHP8KvzlSBrWxtWxXpwOOOnkJsjih984/ervuMJoyXpo5ykyFrCm1MTq54jmP5sF1sI+ItLqzEGL4kjq73NLTGUWiE9x39UdoQhpCShrZzW+fcyknVr5X7QujLR4gHJBcvnKGyYiqwD126aqfA1aHcR+02/Z57J0BKOhQNkDWQ/SYLSjrPu5rOROPmhe1mEQ2D2qjfRCyT1eAfBe4og4gOG7NYyRJN/ObSddguWg5M7nj4113mDoSBYHvFgA+3/751AIOUnD8nwTEIcRcA+uyBVif31cFizhTrxMXNh0vIpsGwHxe46EX8TLzhWty4iW2CyXqUXX1Dgddbxl5NYuXzxdbX94wDAG+RSZUtuXnBEsOi4DTGzjbL0GnzcZG6LBn+IZcsMSmNGDmo2N38XM53xUBa9S0ma3PQhIEsoaSwAhOK30ay/3caPB0w0PISV1K6FCu7lVsY/XDJbLX5FSsUiV1HJrZHUv0ymbo/MIxSaA2mged0/XwkRcPrPUJtRuhUB6a8fAPRkBLEH+2Ise3B0SqzgORCc08G5GFzIvszLqajSMu12VgG/WdaOOl74fXk2qImP9ViHQg3/GsgMtBXnbH2aQJwLTZ8Dz1EzW8z7U2MuW4z5N6By+/+xEVWkiYk2/SZdp9UEzBR5/CjUOMhYhYyY5rPPw6EO5jHRa3/WkTp7RPUG661Po58NHDx31UW2nqkmCM2/dk9rKuFcEMKRH8tcLN/4X5hc84cRgq6sxsZjldwE3NPO4Mnn5Br0V7N0g8TtyQygc4BfnWFxVWnKn6Jc2Jvh9A4ugVanzDJUKTanpclB6aCRSGk5Sb2MiVMZ4dSvgkVtAsghmi1hzmyyL/tp2W3oekeYXbRR3Cbi0u4FPsZgYLO01Hte3UXP7wmLUciNjj/eVQynxFxQsLDunES9pwfkLHLZM1c//TIH7O78aSCwa0qyAHac35BmYObyRMsa8ky9U2swKpR15AxcDJ2v0qZI/nJnrzri60e1pG1NpFBLarvGCGjOzVkYSciR9Ti6Y2ZVqQsRgPHEcBpUZTo4WH/TpCXw7ku5Wnfj9W2W9cZgtSLXfJbliuUvsqwuaa02J41cmFa/F3M+HQTJAgWixYNZ1tWUE0hlb0hWtVbbz3MBkzxJ0gQNJYjRLF+5FdumRvtewAWmueSA/Lc7OHhDVInq4DEDFempVOnh320eraBHlvvFMnd7CK+sTXu39xA288HlJI76NvSbOl8kW1PciMueBnVaVcKTkcDQxAzMme738ETyPcOJpQCesS4+/VVpMtTPPfef1wxOYrsI9AsY57iCj95s/rw1/iTIvIqMW/NiWLz6k355Pf2sKDYHxcZdZxfLWfYXVbHAygbHnSNaQidz5n8dPHi4l3NaV3JJ/8q454TlfHXu06+DOc7Uzw9bkZgTlxw95NKiLqqY+30VW/g1vC3CwzPl6t4jTfPlRqW6QAwGclJCCW6qxeUO7Q7Jr4SLDZS33X6xr1J5GYk34U8CxEZDFikGR/s6jQzsZU7J9FUh8xHpd48Z8wibHq23vZCoaQNEGbjY7Xf4e+kCK2YXQAwZy925D4RJYnQi8o1FXYfOfXu5U6h26Lo3PNj7FJ4iWzp+7ntmI1Tkt/DyhuW5XXOs5dFSr4s0QmCcT7ojvzLCNkPkiP+Xbkn1KjMEeRD5yySStpF+i0om14/lNssxRgT8ifQXkKeZZNJn2z7xs5+wOunCshjoHVTn2gRLu8p7AAqW1dXRKNnQbk4LqsujT11Jtg0G3MW++q1HovruakA52oYg+D1+9X73NvP1+tcZDnv12K1MbwPigW37rltklk60lY/x2jJWBPDGYQLXc7Oo85PDC+t+A93oQHeMi7gZtiekhMlX5KkhMwVmx4DMx3PuDOiz5jdLO1Jms0nR2eocwR7M1Q8Yu9jx38wztxGW3++TkGDQslgYAt294LO7gcLZL2dPcgqFx7Oet5FUrbFp/F719G9sDRKCsxHTFOXxKxHQWsj9ca76XNEckZHnwZsNgFzxlPo3G92zwh0x6txUmhryy01/3tLwmYNcvrDUJwO6Yrrijp6Tn90W4e2KBNMYYXaW9sfiKIEZoPPbt2U7utUPWMoo2yfGs6W5KV3mDAFFISrJ7aNOG3pJaAXGwIRbMHc5Ov0CDVZsi/+v6Gq7zgI4X2P3CFfQ6bScnZeqZZRS/KE2B0ckuGAgEDCPSbeDPlk0nR9oUUIEt9X3oZz3sX8hwVi4Zf5yWmITIav/mR/VPPyu2BimVQ3jpMWw7L+o/RdDK9szaYnN+/cJURd4Iv5gLf0RpxFgczYyZuq0tcJTscYZ3XbUs+DJXuIUQxLuI8kknllPpDjcXs0RcWx6aID4K6D3sdvBburqS20cKcVIExdN8DN33kvWgsN+GMCvxYwAvMyTMNXfN0hvKu+XhT71b76CK2dkiuUYIJQv6gG+wkvFrOmr6Xi2MUvd2wIfBrm3jnB9eISeWOHLgxYPkmdFX4QKeVFAY7vv61NNSx+wr62VsRjWhJu616UuG0iszJIaJF4NuCRWYwwpavP0M3PAuVgQSsVRhKLYt+MObC62kONLGHm4rtZ6uhsi+LOrgRV5ctjeWBd6ETVuk5gu11FROCDxA6rZYhY/vIhFPgCZSdxt+HWUTdDnXhzVC+o+vzsQm6nzYnCc5SZsCrWqxq0tt5zYh1/hrqtZhKW7ZQKwyeqQoyaLLtmyWAlNKVgCjHYDa7DJsxhq7IP3XM8kF85F08iufrOLt/WG4asUKSO8KLxpJGVt3fwjVi2LyWc1zqBOIMN2qPv7sh0QF7+s6rH6xBek4JsrY0dhI/CHH8u4csLT7+fvrIbmINzB4QJB/TAYvtLg4B3rD1kCZPN3ZEqtXJHvtOWEAILcbrt1JOahbNkXkO0igKKjaThAPeorJOoYV8+M4xBj4tm664YW9wakag55gF+7WBug7mqoY0uFyvN1N9DhBkzo4HlrthuTuzN5xY0Rg5Y8Y9bcHffaAreTihEyfAq6My2Ge2r3fuHRWzZuqUTaD7yTzWqvDEIWPOfsFkW1yqZl1EJhi8oSYXfJ9tJSQ/piuUK3K19J2PJLGuNWLhtHB4hakPVpn1rxhvOiEMjQ7ueb2+/KOhSyvJOYnMka2gOm7pVd5ZpcuNsJ2zRCx4/T86kDWxGv7ZP9iMn2KmbxDKtHaQhEm+hTVve5n3VpkC0nHQPvUF7PJEVweW+xgo45KlZKwBVUntkqytXIbhTJObB+ef0eWN9/OiH6xcPe2tZY2sERw4BE1JGa5K89M1bGCblfM1jwK5kwVhHC9f7SkXDfamF+FRMxawjaYwGDPjQGhkq2QeXn+lgFH88h94+LRgj5Kbckc0uCC6t8cO6daJBAQ7RqLKnB9uN3R6I/tz2R0a5Ji9zQtMYrXX8KzD1eyOifcnv6uGyVeKR/vqrj9HddpieFjiNcD05U2zk+GLuitPXvCyicHbWHiMumtg41zktEAtM7ynyqJiViuPFrXTxa5gWcxV0crePAYbVSeT4eV5Qc3xaqwPSckge6huvY+B2a6REbjCU3Gwo5Xr/WWb54dyKCuYWcfUm4P2rKSot4acOHlOQF26zPVarsV44NwkXRaLIlGF22f4NWxkCk1krnZD6WkilKrDnvsmtjDXGT5b/NrUH/r/2EZzK51PDfg3qzvBOvJQy7yW1wD2ORsRO6IWfS2vOp2P7dlWPE9PKXNQdM7i6leKAK8fCLV+Q69J4pF9nCZWpRkYUZm5KHK/1kIXxC3U2PMYvL0d8helTZbyu85pXLEsuAhjSjCyjGaQHmRhpNabO/U8zscVPMqDD+XYPrWxGzAKKOvmEJDLvF75sbxCFCX9tFeDm6YHU3zd/mnphI9EWBPA/Z+PAovecGLW5rTazK+abHDkx7Vsb6DcVoazS75lKShYuM5O8GQCNbYsvP0oPDwNvdoBEbRtn/cHUB71X0rbTfzBzcHwXpA+6CUkx3+l+JlMkSsEagWaG/l6DEEQICrNDt77ucTtBML2HJwBXV3hgBkcRBA9H7qaalkeFZ1rbQNLel78tmNxYsnjRwBMYQx17CQRXDitymlAtQj5Mi7Xw1OQY348NtqNP+qox3mlFb+oYrN3kY3/gooAZ9P75kdk4YPTAN9Z9JdgN2RqP/cgouzzDtdDdeTdvXDCrhQ1BE9awF2kie9jOBUUkI0xeAlM4Z+1jfiV3fU+4yA4N4I6wDf3cXmsaGOBacSCAMgwdwMQaCHaJJEYA6um2VGgpMhITglto9wP+FJAEoACrrcvV32J4STKwonP3lRdwZ7sOANzRATe8VsRAkFbauUOcwQIQcUuVSqA8YIJELddDpaFublYRRSeyHPDti4PVxxLzjMfPGpLqQRj1WvPqsj2XyWLjw23kCYXk8CPcc7v4ZGTC+C1m/LIpcC6SgBvV1hvmq0/5Bhbvz6KoPecLVTP8j0miU9etX+jd7kPYZnuumPiF7vFgRrBXgbcRMJQTRIfMSbInL9PNPyX/rG0eC0vELsqR723jFM14GK8A53ZWiOWZcFGhQwmeCLuERvsQ9S4QxfTbWJbSwJZM47oHVuxV0x8h9fFzbseAzKeXyczrWZgzawSz5hzR0sntRQZx574xI44FvDJPBXDLW/L6WiYVyxSLaUfi7Rbjpy4qwRPbbLjbaxJK1Os0kiK7mokuVHusokFoqjy0BzB/1LCk7gZJc0Rpum0Q2+dVZIAVvCUmQdG3VIX8jz9llNOccsrzEXiKVXzU1PBIfQUpGUXpMPdeJKKxrdQS4qKbqdsGm17yNz4hWcha+NgC9/qxQnLX5Ac7jm7bU5mJbC0DY/jhweOONfPCOMzmrMQlDaoFGzzLiCYO0FwC9qIoeBcROYwKHJ+Sg42L60tepV8bs27hNEJaRWmi+7hYH6Yx2Ra30nJMXTpd6mAbo7girnXKpIoBOTZVd/vMOP3fS/iCT8IT0tClNo5ttUok/aupA+ulvCUZAWMJfeGd+5I7u3LLzXEUlgqzRuPZAZj0cECUF2cm6hxCpoSar6rIPi6TvKMHMnEwRnqPRLON9Xzb99Q/c+0jJ0AyPf5n0VKLFteaQCjhO8vmxWsHMJrHNA+gpFF1KCIhy+oQTp4jwLe0TRWFYwR+K/Gvw8kV24EtMyHiYjJ4+R7NRyWw+JkDwqSRgYmrQ6QfEa+HSpwoB7JEGa4UYm502ULeHGzqXGEVDMSRz1U0LL4iWZA7MKGBn4Xhf6YtsAmz71KgEXUINk7ZI5L0OhhbEiEQBRX3t2jAuKe5gVVJoxLkA7UK2ItIWzzwVjZhQp457QMoD8gm/ozHA/R8nf9QGzbRJi858fF4Igi4dClmKO7h5cU8lruz3zzQzTRyFg5lqGCFLgUwml50pL1NS42j/MY0BysloC56K+ikJvEa10C1Jui91W+iEdIEw8ilSSJ5359EDKqtuwcRX+tBAWiV5rOPcq+Di714AdTZQ7Lt93TXkKogDex0Dz1qNg5QCbBsnCm//EQVEKC3azhRb/vp6sjIVOcJ4gIYkM6YKC7ejoX1Q0xvrttUTy9CAwksE1sZhuYCdUzYLLV3gP6ixbmOornl/8EKkGlwrOq0tyilW0rSqVyze7fA830fiXx/2hGH6RnGNSXg3UV155qZGr3APT2aJ33HjXxenqOFM2clNm9aRH+J2cuqpjd1qzWzObXoK9kzFaSql0amcOszpaqKoPVwyFxXK3HXAlJ5e12UB79uP6u65nPKvap6RI+5jCHKtSbeYI0H3ok3RhFO9HbbpvBNTp6i7dZegTXBBbWtsqNTlNPUSCbE+yWfXRimgdActCl2bpLmq8QP8oODhRbxmekWv8y6KpdR/WWSDXTZlMPl0gQLgev4A3HhKRbTPBiu9tGxvdN78pz/kVcbf6pV9RDeqo9uoR07rpbhsdiKnhTRUJc5v8dHziHkG0pVwku1dRrSnKXzPeR0RxSG6LMVcccsy1UrabzWV+laFKpk3Z2m6+HeyMAWAIAdstr6roijBZWRKhuKrdzYdGTjt3x/d2lpVfYW/Q7eNYb6QSd4EeY+xJVSD8L/QRVfK9jjHOBu27JolqfSvHxL4i2NjTWRDwUdql4jqaZ+1wDXRYOlcFeZxvempkxLpfSpTJkExlk2kOAmyd97hkNXWaPPsVY5pNKjyknMoPZh86R/sobWrQDuDp3idKP0rq1IMGbN75yeMOlGI8tiERq0Y4oTgDDHRrdXdj/aj23ZE5OGqE1ACeHEfFWQN/xk35E0P4uViOKNDqV2G7uYCbgg+fAzHdvD8o2Sak/pNTmAnQAqctKx3J2l3vV+I36w/ZS4Pv8os7EWE2wIGvkM5EJ32TjicKFPmYNkBI8H6qtEmEbRumctSjgFbqL9+cHe7yrrxbKZuYkdeUcgoFUGmMgdxcDvaAuCpbU4vT3Ek9nOcsp5yuLG2rXY0yV/tgtpXOYi2imfIpWz8IwmXjJh+Gjy+AwrjOTn19oSy8p2ZmIHkf7kPAg/ww9ZsaRyn2ZLdGefpcdKQCfIur9Bh8Qh89ry4qKDMlwOXA/eBbzdxtw7u4W7tWmBBaZFWNM2jqDdpbzZwBlikKXjI+/EP0N+dlt2WbWJacr5DZDrgXtfhmfwiV+jvYNDWG3E8hKeE525srbU1Ie9f5LdgM9fGk1sudsWeG1yM35mHUgAWoJV5KFtsCb3KK7oPgwRGwXCyTrgVzPhBji+6KVobUCjfWc2hBeTohSMcp8ZSiT5qWmgX71mfaW6+Vom25xz5t69LBli806e+cHIXFYhZOJzXI3eJgM7DU7ysSFyAGF88czNBd8q5ouMdoXk74jFrV0F7zGif6abMrvxeDNcyXxDtCALRAGFj3k1ZVnOfA6e4sW9YZVAgwGSU6HG6vBaJDabusZRBGU2PmxEcV9V1S/dFbE5z6Jz/2+TuGYcj01+mbFW5zjz3ah4VqILjLRPppc2YQN/6+p8iYd+nyRA6kCW8oupAdLszKgOhYj5KxHZiGZxuZZgKHUrsXTsTlANWKImxKlZua1v17FVKJMSwFXCvFyYOIXvFf3QfbWKGtxgUNqAZXo+fi8TkUQHlvVwdXrANFSurJf7GH1aC5V0PMqm4Ojv/rXl6nm+bsru89nsbBfPE3K+m6OkRkEOJrkIEKtIjg/20K/U2NTYowlOcPV+3z5v0L107EjO4TPzFsl/NmvVBQoe17M4nmQAykKUftcnUr1lw3YP28rhXKpA5x0KwEYeM5ueIfJxGa8JBLEo1SpthJ6T3MElZAVZZTtdvxyP6Tv4X/bLmE/5YjI+pTQgx2KMZYNJZpTcRg5XQXSNaMDp5v2+htCAd72e0L0FKHRGHPyA8jLU/cAcb6FJeaVksoXcZHmI7CLbd7UBC5AdqDquzXEIHIvvhMb4Zj1kCpa4jZMaRHbd2ZUNSFSb5ZCZYz67MbEXkclxt4Rv1DUrlkcAYyJDeNdH6Yi/eZI0sPGt3nVMwCzh6BPRS/wVOOoxgdQqglPGmqgkzhE39UG3iOvDURqyyo5jjhp+p0ANhriCb2/sIAEHd5BAAUI6xQwAQOqUKPwGMiQJAJaAXSEY7fgZoLb7x4w+hV23BgVKYzN6hFMcnF3x5XtDfrTzHcCIy24W7fzZ/TLwb/OybtfNFpk3v795wn6tjy3zY/ytuvgu9JytwV/vayg2SFbOHBYemBXdfXZCKlj3mfjOP9V/gksi0nR7jEf4eYpmeBOPj19EGBlwJO40iXATbBeVj7zv9gzDRvSKFfh37XFtz5vVE44u5jmi1dtmdHTzk0wupSg0rV+/x/9tbcsBDUfT9Aw+kjXKwtG8LHo1FxP27MlKDMyAYLR/LU5VeJJV1ksYme3dMXmIiF4Lrg7PPa++IHU62f2EZ8xwgswMZW3GfUvhZYwTK/ljfcx56blFcjSPosCTob92nVJEh4++4d2v3HtmCX9pRsLL4FSEPlf/jxiYWmJEGQBO80YLyacZiguCBmSmxlCta8h8F7TVeIFBsglzCSckeSfFlW6cu34cwlrf8OjBmn26Iy8J1BNeNl5FkPu5DoJw07q/b93ansjM5T3maX1X8qjMXTIVZAiSwdGSAvuBDHMziWUlhGesvJyCeiyLJeYc/2FHLlPL1dqM21UxpTzTsP4vbCaQ7QP5qy+7807SJu6J4b+YXsPfNXaQCsbxkFbTdlQJdYWRMHFeM17MO5R0SPlnYTB4KsJ3yJ2a9Kb/dAuoRkFE1IpRn5meCodfoyO35VKy1VlifRMbosRlkAkI/QD+bBKZK/is4ddiWELB3RHbJRjWqR8X0keGCZQnNHaZPrWzGBpT1rxFGXps5IcX49HjgmDWxiqBhiO8pBEXjwh6UWoH038Zj+xIsr+2qknWQZbbAwfN7vV6C9d9eQvcnPcjgKixdxZdEBZWXrF/lE2VkJDqCTEoYU7DVP8NVmF7HcfqOatAaVFAqPmhPtrfq8K4xW4dRLzZpEmTeBYySrvJnvxz2yWJ/n3MTxyv8j+jy/Udn+MmSMYXPFrl1ox3s2w4/QEP4MklGg9GMk/yErh7w/A+1epxSNpuLQYVS5aZRvKPOaE7cP45qLZDOOAVyzOQd3JViAmzI9EHcZiU/7U2mirnpNAAM3/l5ZM3jKDZ1Ha/PpSsTf9swsQdSYcrXMj7bDz+UfZIMwCglWyzMO0GO9XzlHWE2CONJDoBNVj2lHsJR0AlwuV0NALMp4v1cRHFGI6yOVfeQG2iIFNwOhEBmSpHtpAaAEU+4i/NDOWwEko9n2tQajK1V9cP5mewPHxBgNnixgukRr0zbSt+stOoN+II0XdEawXNEo2WlYJtd0Z2P3GDqQyzfdGiqk2BVM4RqI6BD5Saa23SuBNyBVNNtKdCdlqDfbZR8wDiHu1F4qjO7BxeufaQfXjZ1LdNoc+NSikaHOTiQ0ZsTD9JutgQZpkMS/PMgO3rwDF11QXBSQUl7PxyhZHEl6PJHmP3X0uqpQRFwJlrjRlNHFgWgVMuBs8Aig1Pq2loQVmcYisB/zyRA417ehvmMnOYgVmwNV3mHw8zLwJdT1SJTUpoyb6nunuoid+FMBzT9dVhVU7ZDqyOXXVa+U6hK4jfEs+r4ZjizAdF7Yo9AwZD0McDikY9WVP4dj8IrYlojyEsc9X3ouI3hVvC8Qi0iXJ3Dpm8YQkkrSeYdN1dXZmh42tkMK7mrarLLcZPj6mBrDC8k+S6H8zgeY7NDPd/SycWIXMmeQ02qf3t3V53XNLJmNnyS6tjf4i6lsjLNT4jtHIRDzmbw6ZoCBCM2ANsu9v8OLr+tM8rMTB3aL0zqDT6LEUHNbqPjo6x22ppaZtKk+AgkQzsXCd17+GT65dapIBsplKIYk8+ZTtAugd9QaeO+4MCN0FqkFZD2qWuR1QjPqLFsNMYU6eNvfDTefSvJQZ4O0TChjgtdohAyrYwQJFrwXX26eZfMZxcfTyE3UE5Fj7fmaOMetvoKQa04g1/cCdEQewTDldlOxItiq7ZLjEJmujKcK8l+qRxiJXjhSbjk+UESRgwMn4GTGDt7yRtwmOnCuyenmdCmimQhPKwTPOQK+GHwUizDsGy6W5TN1r6XGVT6H/YjPubZTV9q0sm8IWAyGBVgHFfVWoq5NwId8TCpD/KuU2gqiCmy2v5ar4Y+oo7oKHSQsm8nb8jLZ45ZvkmHyy/AzY8ve1N6G/Dm5y9XLi7cv0lZVUvAiL3ovDHs2YmFTbweiGpi1O53dhcP1BgdMKuw2CtIbv903h0UVkRV3S4BWxpZu6eYiwPbLEIXpH4VMfXwo56HIp4uiGaBRhKv1aN2Lnl/NXv5a19mcPE9Q2TreOMR3zMYppn3ndpeKMwfo15lF/KaD9gg5KSaBKtqUuOdNiUsafmkteNY0W8w197U4AEa1fNHcdTOyB9ZJyDjGEc4Z4MQ/6nSTZhd03B4XVBsv/osv0xP1oKIOpL0zstIH1mVK6s5M0aP7e0PUxzAvYnhHiss1V2WrL3yNvQ3T2oaYF+9uEbEnJd2m4EchLDOrbc16JFZPVPZZ73wMJF6Q27zvF6otKk+bbRxOvrsKBaNXWCdoLKB/SPo+Dg5kbbKl4SscYZGUvgUSw8Y/wiJ8uvT7ees3B6FPksSR0cFgvr6FWp8H+T25tT1Y3XuLNljOYUFCqleDWmlnS+NAb8YYg8dwpLvML93DVwYTchceg9em2kFt8FSPdJwQLSG6MgTTqsFxw6mIMlLwi94wiUJJtNYRZXBYWP8Pzs3Z5a4GcktAKnvrK+w1NfpOS9CRHx9NSq9w5rPYyXNEKoAm9Z/544THhN0JzPna7Yisq9qt+6BTTk3kGRqiF/Tsu4fQFM5D2K7pm+qQ9g8KRknX+l5M+DYx+VpwXtxgiuHWovQp3jX8JS57KGmyypNLl5CxVk6MOq5FjsSsdSohmhxe5I15KP8fXogP8sAxZYeLQvmxTs8ZCsbOAT1m9j9ciq8omaBJHZSspFchIA84IchvGHhi95cbHgCQAjDPq6/MjgOUP3rDgp+l5RakoIjyrEQzKrYC3qm3uoutjjNQqX9x5oIjyIrAWc1PLcuT1fVrpBy+mUA2CO0o6BwWIolZQWmSv/aF2CiZvAgmd02aCMQDwaBw0V+P7gDMhcmwq7guB6aQb+JsFF6SI4VkBPTmSIFhlVyLO4MCtFX5tIKnU5ySrDpew4gizo2+65uPHGgn6+FIJSYyXkge4YX89ZY8ZR3LHW42OdTgcp/bCAhdKHfc1qoiCHMbK+lQVCbY+cSevGytgeY8ifwtB51HplL9rtbRPg7nB/Y+CZRh3aav0GZ4IO0iYLEF9X1uPDY9uLb5YpzB5525+3KYzTma0oSA58LjliCpDks+elrkvMkNHsoxeKgzzh7Hw4PbjtbYWiETGwruwI9NFo66VwmQXMnDaBNUz49edXtQd92ohkW6GlEbcx4USSGxj3c2AlX9XenoVFXSM6Q2QVi44uTe3fyYWaKilxbHNeGz6XTZ//R3xTVN+EAlWkoA9aqT0NduIA5cEAE1PVh+Ft1Gpvh3V292HWc0NfmJ9eP/dZVfeoVT1/jrPPRaAi7GU84lLwVOsqI959IZkWu+ub6xj3KUZ4dOQ5Y3ZlRw7cwYFnXCWlzgUI4wFJyapXdlcmVFtxPlxHerrcu8g7PJ+LMGKq9CmRv0QzbAfMp4ZaV9iOPRJBa0n840PwCpmjtU1FpXIcKwMT2pblia7LXV+mmjMp7zkE9nna3seOz5Gcl0wJyD1j7S7hOdXpVzr2AxRiB1O8H+EX02thlYypD0irPOHs+XBTI1ViCs7tqiBIvO/V65LcVlCpBOqqZVbAedFKJVMUfSBbYbsR0vIaMu9/MS0uaeTXwNR+zW86FRUTU/zzX1qP/0uNRHZMM9KU4s68xsnY+NfOSMVBITV22DZ81DHRUXMp1LDjFPksM9NN2kToBVHALPTqzk9f6UJMpO2xM2qUP9t+jx2unlOFP+BlN2/unLnqf74Z1I06tk299B4LHUrYzuXQD3VNxQsdbKLEN1nm++NrIrkP5GFEKHhNXrGDurLeuPFEjk1gzzJjB5pZORVlEZ/6a5dkoWyA8GLXkJPwazkv7ezllMVQ1xs6DNYhTfyrq/4T6FXIo9h9JxV1UeLZw7+FdaDJvDAdzUgJeqBAC/8TSESrTiZPhkyh1/hziISFfsbPztEp2CoHKc7uj/elJKDxbz+AYmoiNLp/6U4236vo0aew+kCIw4WnHxaNbhUw6jiI+AavSif3vqSZsa7NwLtQEuzMYP9kDVg64hZ7Pedwc7uyRWGSb5D8GkSmxWffJ2k2delhlFsUCDCE41w4Fl9/OoKp0KC1XFORQhd7s9TFI2izLEuKpVCv9G7JgrvrqynqYpXUVZZ3zoN/tv3o5cRdYVAxA5U/+BKWFjhdpdRm4dlpb6oBPOziPe9PvMLlacrmaIw/F7NDEDm+ovJcAipebPGTbczzKu9DM8RMqkG5kjJkZJ67Cbc8nTBMCopf0iXy6JhAboWD0z5MkzH/0sezj+JQc4zzPeDFnrr6b/IvgGQZfcT5+k9T2UffRwCYLP3zowolgErCz6sGu2KgszBv48d06ze+QENTxUuiQr2CBCZ8DIEQJPD2WWASlx9M9KLc/LWDzem08L02KIc2ZTjXCxvmD1cCbFmjl/ENc94UrjQJswRvjqgj0VFRRpLDd7/FxTSMHdoJRdw7dGzer4E5/pyvjiRxwpAxuYdE8nb0+LWHAZ05cJHRRcoaSBS2vsdoMvYpWErwJboJ5Q5iWaqzFVT4ZGARUU2M3HMtusX6SwdYZIaPTpFS/srhzjEkJWeXpnV0GRiArt28N7oQRcI30xHT1jg+oTXyhZz91eHeK+PpFPgRR8Z0+VHcqm5kapk1umU5IE182kDUiQWvc4fXA9Qd2mvQwNzvMRR0jjK9wKVjNlcaSZXfxb+OSJ+rPKrXnu0zZg92OvdkOqlintJBH1xRF1BHrtqqAaUqtdq5x4f4vIlbCWR8uFXz2PRyhwskqEufBWz8G5ausG77OPs8wx7cvcWaifAMNj0ZrFEedZwjXX3Pocwkl5Rj2Zv4ya0at4ceW0BL0tq8bLODlt0wWuMVY2ULUkPyD0+/TFcavRjUrRBb2s0bmfJ/r5XnGFaY7H60WGLK4X2qIvukFweUwiDVCMfZwz+67HSXDYfR9NC/gNr9adTiYYfKgVraK2ukej8dP0A0WGNBk7p5qkCsnSKtn1WIIX59+ptu4PgXA41DAdE1tqoOG1BFE07teEVpBKp5HEIp+gHhpJo/sEkxI5NHgeVxaXJ1U8G0YT6U6w6hCLUs36c8XHa1gATFKX56toTS+BEeo/y2Oww/28H0L0CapIGIGNToPgWN5vonJIe5HMr9IHhchLC6KrZRr38Os0d8LGbtrkqVTDU/WzFF5v+n3c3TrIFUjTV7/8Umq6D7ewvwDcoRp0uDcZ2ZFbaY2irPnOnxzjbcDIGw0U8HI01MuhWJV6lOfWuk4RMbodB9uxR2koWc4locUw3ovDCzDb/hqgSLwvTgp1RpNvGgzn3XU3u6Uc3guWUt3f/60dJnh0/p4wOCXiNn7dxsPynIHceoUy2RauLU8JSIOPnvAvyqMafWMsgS62MLvdj8LhlxK/hfF6SbXaYINWPyPG9UxIPKFMhK5l/xPEoCvDdxLuoBwi5EW9Pa1xqqmGL/dLhmyaSM7FOOiXqWwC2hXw1uYFpB94s1+JJJfKPnHnu6DdefrXEixAOBSl18bd8lFQpbYVO/X8EkOeVzLqypXtfwfyn4avYRqJfNo6xv2TdRpHoGPk0LpKsJwrBU22obilibr3AjUAeYGUcpxpmNeoa7W52G7JZak8THd/b6xbeBc+K7ecjHaaMq/ZoP3h/riiNpzum+CZCFp/QnbhI8zcq1HzEJxIt35fDm/rSYRJ8bZxDpsOW94DXkPikgcr7vAi3o4fh3beIN83gXTbKEfwY7b5uk7ceuVtXvyLTrwpLabWurhZCg56mzknewkRwpKbRVpdUi+3DY7ZcBabv0iAILc7+vYynm+BkmrWZOq7iAOWzOsCUZ/RLzm2yt/SplD6vkmi2IAm2ksxNhTxcYW9OREscJTAX4tVsHgL9PSgwJN4Mug5SBjteXPGsBsOfiMs8a690kFAmW4kkazRvo77o3bdGa+/Tk4CtEDH+PvHCmukaFKarjlusC+BopmDXa7THhY96/kpTJ4fUVtEUj5sNpcNqtYlUxFhlNpoJPfZg2ktK5YDJoDAJ6EinFgFip9IYMVernc6F5dKW6d1aukOhwYCQrDy23/5/ww+mYJC49PificHv+yivP8KT1If1YdpmRtunQ7s93Bi54czxygI+CLi1+zfxWg7EIEmLFrLPQn6yEz9p0B5o3V8Ff/VZXFik+annwtFVhuzGQebahQlFCpV28de5xyqGAseSy7TmNkrxoG7xcX8cOpAmlWu0OIqc2Jns0KLml5H6QSr//3Eq+np9SL9DOibDJpA5X8p3ROQruQTgmOC9aniANHheuF0qt0YwYkJKgVZnD9eTn9Y92Sxb6tEW7cC+cPxdRg1n1081LcEqm4VIFEC1NM9zkH7JRkLiJ+VYA+QVOiO/XrsM9SGkllmQHvORpAy2VO+wTdFPuAbYmCn1ZudNJ0bjMpNS7NdVzO8E/3nB66x1XqMsT8G6aLH27L5upWAxnSRoXTLqJtKysJZ7wjR2LrOIK4O+miwOKEBh+tNRF9raU+9VcxYFUJ2q2lCpvfP4ANqiT5/i9fjLZQxWiKahR2PMgBzQxbtJCS3Iza/oo/+fV1IcQTJB0VHE56yszBUqrya7SzVUMAAMasoeXtU4qM/5R/XpnjifFylnJgocHnEq7M7k9JlGHDRSDIEZH1DGlMFtPe5L/l6dLBiJYUCTKT5LnayEKVZla5WW0tDnuBid3n5aPbxG1+HNkIzxSPsSH2cYjyvyHm0xdR5mG85H+oQ9zCeCF5ZNpbga0zwrUbbDZFMu599h9NC2+HGLZZsehOMtoyGB8QaB6Fmyt3As22U4NqkSJDCUW+jp4gewTDjKomwRUl2ZdhfwD1imDgwfVomIMJFjbe8XKZfvAheNozynotKmRLj0oz69w0lVHl1/qbRBDrl7cgqDrxYdGwmGB8l8oQf6aadSjmF5zvvIsXqp+QnAcSINTGe2nrKYgwFm4eFjunJ5Ki9hf3TcLlaTInbN/nJMOf+pPZ+mUDXJMwe9FewlHzIXQ3z0Cxdzkcp1hjBdx8w2nMcdZn6h/zVvYJ9BmGO8VMdbUippM3po7S7rnsVvNJuQE1BKGXyO4/CeUd/HQnqLOfcH+gHFVBvQ2RkV1IqCqTs4WBkpEa6Zexf/kFcidLKtPmiUMv7h0+053RRE80ktMkg7Hv22B1wXbvXujQeO61wbGeOPl0Z4+tghnk/PcKhtVlsGjGAiDV2i2afxn2d1Jp6ON6iphhsPoUJLpdtdnEgF6X0M50Lwk4vzA5Q8kkt73uCavytvn5g5J5cRNQCinflaclK0BuTupYplQvXJvhMqQiVOtbuR2P1Ob+XEnL4mOAqWsegB6gXEPmUQQgiA560KbZw6XYewIhl4NVKB0ZrGE9Mes2lSTTD+mv09ZDsA4G/CG4sQU4E6KgJH1qQcGhNO9Jo87S3F8ukiCDq2WUPEQ+bJ89tfRArpnSuVFvtWZAvmt/JKKB8uC7l8fACJ4QXp2BITd6WnmJifR6kY1NvqaM2uZhOBz2H4SrCJBSIKH4RhKeHMMCNfrKIFv7iahg2y5WQcY7Za6YBzHLY2A8cYceY28Zkjq6ahdRz3CM19nq6I0rn8+J0YB1t7uB3ZNrM/CmFvfGNihDxIHnFErNUvFAsuiu/gbRyc0lpd2FKYvxJyHD7HzWHRkOkwF0cp6gROYFg6YKajCfswwX0xOysvXI+F51wy3yE4l3Yp02WHefFJCekY9L5JPjtDM1sXDQEaoH0MNDjoABE/UMX3N7Lcmvetml0FhF8VxnTTh8wZRewHsFzejvcHYU4iPYzYa+m+/7CrFVJxZo4QEAD6wmkafYVQvA1wv+abUxWEH083M6fR8Od1TWGtDl64il9GQSylH0PXhkt17hZ0R1fwiCPfrPufFBXHYA6+J1zS75+xNkOh5vSnoW+ANsaTnPfT90b0wg2Qthw6aaaixX3UMfRoZeT4W7iTxTefy3RBq8PWFZbdwReH1v5bv/YEYmUw8FF3VK/58EOEmi6WT716QsqzYxfvUYdYPmS2XAzPDKY3sADk1CLGj7ddMC+SJ0lCo4RVTPkP0LMvqVxRfqVsPxn3H9fVZhRLpsiArwVwdkUI6XRd79kC0WL1yQAXBqee59vb1MaGhdWxCgnMxIZ+wgdL1TwnpDhtqOp87S/tzwiUjHdJmR0+jfexuWlNL2CrmeulnRKowmd0iB7Lc1ETony1ZoBNZkU85+GVSvWRsCw2YGP3wbdWh/1J+okkV+ZPF+DCS16i4sr94Ukv+la9a9T1YcI+Xdhht17YEI47U6SBFDJViigi+lSnBThb8agt+ncFKEVzZlaIOD4AZY88x+2ngzuZHsXrKXG0tv2tjHH8sjOUARraC1EkP66Y+EqJHY174DsKWsngpM6wNUvGGKZJJPcjVBA1/dS5i4uW1qd+QyqtxkPG+S300MridkAoQk7VjCKEwwojbITK1y9tTJ4HCDFfR+9Vcu4y9iBXa4F0UKVyxAteQijDF2UBI29EA2jn40z4oZ8wazEUfhxcNhklQ2Gzz3m0wkWcEs3Y3LEEMcwNmggDtg+Q9A1Z1PEdIFXqfq3FqOTpL6gYHr7K4MlVuDk7EtbjKmP9o/H0F8uDunrCAZLsY9fU3cKk3dGvZAPZ0dIURxRkomU3hA4Pj5Meop5gn6alQwxKdXDrPIaOtbaq2QzR0BXUAMsJv6NpYa8KhVRt6nulP9a5d3HuzmlQyPa0MIdYaLzcWoEMTBBt4u2lS6rYUPrDq/8unWO3xUPkG/p2/P1wuFH9e3KE00YS+7EUyFlDCFThqa66MpNbT2o3QN3WtimgW+pl+kEBSNgQkNHfOPDjlyPZl55PA6RI45dtbnqGcKe8INA/NBGSoyHdULn6ZlEUeAPNJFQJ8sIxDaVbh94LxNyZZAR+G98p8e20Gq9HwB3AaNCuNR5+ZynaVTQ1gsP1OEwvhy1V21RSqumRThUOACmYhp0gPGI5rNYf7/IFzZe5TZecMrPuUnYTFtDTVHd0lYOrAxGq6+aT9UKLbVcCKzl2om28hmIFa93saJ3FnsEhjTyLnvzRRsnADmKXZPgAvEWjlKM8pim0lsjwrrCltYYJ7vvRqPLe5qmzhVD2MwfTDSpi6GOK1s5fYX/6PftnH1y9mB7odgOB7yc45hlsFsJfEDBS9j1264v+tS6PqW6ezNp1e724TOQJowPCHhhXN3shwgFzuy5DyAXYlg6ihi/4+W361P3yEXXaiB25DFTbo5M4gHdp5jfG/yx/LJu/jDNm47Ok3BQZ+Zf1XcFYYaAe5L4oG5Z0FpBmQRgYfjRot1sHtGQ0xJYE4auUBP83Ls54Z9Xv3ZpxZ0I+e/VyFFIQWNXghp8lAHvMKEp570ZVX2av/DlW83tKvlRp4ugPsJZbMmWhm4L7flG7fT2xaMA5WnHV6XZWBIqjdJfLrL2sdLeqLoUGNIG5pmbGyjm8OY0PVE7ajYzICLst7dN15Szgt6x5smhTyc4PxMPp8vuuqZoDTX91gfjj/yGnNY1kTtp7CaKsow0/eRJ8waViOMBWWRPn8HbyGez+eBZShqoG9w+BcldLv/Dgiw2v+z3HP0COS1KLQR6C/c82HUhIhyVhT+Dqms42EwWIfm69J/kNpF3ljGHAVDFGfHg3DBUFpM5Qqq/8mOpBIxf8JgSd8oclV5hFxHI3YDQ2GutYwbbD2xlTMdW9YXk9cfAd6+6RRNs4WW9AMlJ7NiL35WM6iydQHElJTuoW2yNqUpkUwaN+H2L34q5UmSe8bnbMhlm/MAOHl1XPN7UW4VK5Sc0Cz1A8ZEPuaZNahBogNCDGZZWSK+8Lx3boDlUxrrIdEVORwJAA7tPrTgaqGaDHf8hxjqx+99aF/ffq9DCtjAr+sP+lKXsz+moenr8JcnRwWtubfSZEe2nxMZY1TeKb3EN746MyTBFcS3eVql2M8cb+TduOvo8+WbDshD/vYhUJGBsSO/EzuauZpAS5H9pSOr+xNVhtcBSGjtIPHRV82YkzLW4BYeY0aFUhd9YLTSGs0JS2jpq1lRCiKaOb9ln9mF1+ynKDNREHfFbX57WeUDSGQimhhPAP9y8V3tPMkXbaJXsKhUGY+DChoTzs/uu/xjjwS6XYlX3hPu8Y7mUtcutj+2lJX8cmg+D2+ORA9Aqn1I+RX6OvzO6u71wxx8t3J+yTI3bXGNV7lah7By5g9bo5QaF5YtJeS+i9qnIVtEn9uCfpy/T/RcqIqJbfAnHuv7N+uUx+gGdGwZ4i/ApAMx0HyjDtLYCXfovZyYth+rdHRdMYN7SoDmgbU7MycFplQXu4XMyrvhW+gD1bhnFJUsvbjgG8DGmvuLokZSTScO5I+caeuApJCaPE4nf/TiQgA1Sbf7ewCGeKlbLpCVwuDkQn19b2Wh2imVB5KhNvBZScj0gakwA5s57ZDc00Y3piRzyxkNCu17z2pRjBxGvLjm+Abii2YUTxUgUcu5blz9SMdGlfFyrkgpMvZkz+sitJZctNwKXC6UtKhbOOe/Lk696G/nnShQdpSgOgcZWUxpDxxexyyWDRiEYkCbdZPT0HWpnCtgmurfgL7fIY1B9lXmBmCAcgMTe3secG9TA5eRWO0DslV4r0FjzvUUdKZl2ZyBMyggF2V0wIiOlJ2Ahbjvt/cUCX8IoS0P7ZmJZo4dAJv1I6sjcLFBQdH3Gz3nQ73xYM2tRjxCMEmVQVs21IK/NbGlW5/rOtuLAt1U72yc1tuRGEqChHpkmdoHBIcPesQwyLITXCh3ufkHdzRXg2YmCdPfWKE93cYj4wGgjnzQARgbIGpP+7KFwAMgFzh9yvZRoxi5A/fmXHzz306oDQI/NOWl0ZmaMb6/EH0oVLLyXBsR+JS7VpOQe9fdh12VnFFEDxNVdDU9cIZ/qePP8nKJv6EQsRb5f2PchrJcxfIjT0wO6Yd+1nIi6stekOocGqWH7mCRNpKURrbhYJNaPwJ17ZrW6s/uuaVcx2XRPoYIKNPkN5J4BBY2rX+KErFWbY3r0LBtIUesDMqNCtZyjOV4ij6EMu5QleFgG4Sj6qKBYsteNkFOuiCEvOWxU+Q2YWzbzAk6BwvSeTOk4dyx1u7BO/+XTZUUxe7iOd2fg9PcgJlev1L5f5Gi8N76aXpn5ybg//8pVJfW3nH5eaoc/oRG6EsSLQB0IBW4Brvo4yuzRx1vF8Wj66FWYpUSsi3V14jpp+2+xrw1a5zHo+czKv0zejDlBbrN7YVamg7VQGYE0t3Oa9b/CyjACYLvVtgV7FR4edI5inqpMtJAS1ZrteoRRzbWmYyttj88WJAI1IkIF+/3xgPbK9KvVwRo2OQKtJCubZiMtSWfwSPpkxoNLXeqEJ5JEvBIn5zEgIIeGEXj6qsUTXoujn22XabeESAV01zGv7dmWLOqaXEuyF2hNS72Ai5W/Dx6e4qZjKmW7uVG57tIpsfmlfi3oCSnW3kRNpvKRvcM+UsnyaFPbuCtvMtcoLrhVI4QGNa+u6t/tlKSu/DI/x6wzUtBzmtuMeQ1JXA/FFQTY6PYOvds49TcgFU7GQuAfaumuhCSTCqeAi+2eL/vVGlEOEKrGQXVfn6txPoXmy2g3SYBbURhm2BMLoHSwVMr0Omg10zy+3wlDgkFNj1yuwZtY5ScHv5ChI/HLsmUo2iurgDFOqzS7Js6R2QPjmak1alp8l93VVTGd9NWtpMvWvafUKvFkgiicuq9J86EiH4DuI6BdiTm0Tv1l0TeZmuYa9YKuRGm80ydzHHlQAumzuplSD4BqRp0d//PSaYNiDQkxz/4nSUYVwBQswkbfh6jV1Hkp08i6CJ5sfbfIAxL/YmsZU06xm+K5aMFgRrpCiJtADSSv8kfOK+MZ/naXETbDrgA59QB2H0pZLC5wUXomP2xJiaMT31yoOucQwcQ5IQmkoOk5l1mLhYarDmmiG6k5FHFi3M0hethWPzlG27+Tl8mcDwlR998xVgc/ak7+ALTDiV9XRnFdPHrv1Fcduvge3eVFX0CEGcgu6ehZJY1+h86avIy/c1Y6+R6Pm9GhPMI0kWKGDDm8rOmGZ4dI6wqWj3LkqY4jLNnTCUNYdnOLxEzykJFpqdAnufT59uskqV2mJJ/9tii0j6pBzEQEqdi25hcLpDOY5wUrMKrvg65dMwBGQqVKxb3ArFodVr05kdgwgkGAJhOtzZfH9lVU13io0Iaqci3UucvKc/zE4psF9V4/er0w9FjB2fCjDWG5UeLfn1H7JZuOWHzDRdCY7TzSNSsjyMAHmySm96/DMFlwuHr8lrQzIAuhn0MHRdNoJnvPOnH2nGP+T60Hb5EG7QYX0y3f90xer/aOFbERziYn4Vy57+lCuH9fRDlN9mKXM7BwZW9YvO7XZ1/Mol4jnHQx1fBSNfk7KNWQixmJdryJjGrEsUkQJ8syOiTsDyC2YibIa4BS0FpzPi1+Rqv3wyUh5bO5QCKlxbFwjYya86OiqIYo5QNZx24ysiz6A475YNxa0Et3vFndwM6W+ILiMAPFhowvuNXQcNM9hEbuIMLajlt66K89aJEM8y5eDo7lnxGCoJKvJ8E+R2N5zj1SQImuuQKvX2sHnhWdKqX0Zoq1Tb9a7BVZQPjmszgWr1oSvdx5gMsxRwJQdbqXUYEKHIXPmZSVtYjN/H8FyHy90njrJgllvw6znbSoHLvBZl51j2Dfq+vbwisPiIPJwXJFiGscc5nefoPUePLwp/cc7iRK6AQwcKY5QqgMMzoyOkdiyHkDqIxlpS9mtsb14OpkSU1L79ukJ6RJJde0zKvKsMVOhqfU4GM/IXNtOBZoFzLA0biT9WimGBPkG7FmilNVazQvY+mD5qztcJ0Efl2hbNMakVt5rOIa9TjCRYPktMGLKPcMRHDIq29ge9Jg5+F27ZE1qxJjsBq9plGjh+g2ucKwhcyE7LG/uipCDAz1j+l9cfhYVPCUUcn5XtnULGpuu2vErZWkT6WoSlYcAPM3G64HgWdcePyaFkxLA8jmXmwmEzltaczTijdQMDXQP3TfqClkI16RRxAkiYqwD8X4jauvDXZdgIAbLHha/aljQlf3Lzg2vz5piJr+fPnqBfb4slhbN3CRxxNjrgJSldUFZkMTYWoNd5RMDbvnJk5GxAXFnBUMPUv9x1gcDgRC0GY5ccFAAJiBsF9XGajAPxwbSggi6rA/mF6jmQfZaUMU12+j0mUXU8VC1dQBIRfzMbmSgBRVdx90i8GzHCKcWf1PkML7SVAKmHq4gftgJc41+KJaGtMOkQ8MqnHwDE4jnbyTgy0bSBOlRXRGYKG70kuj09h5/mbLR7EunWrC/UnR2W1kldqHjB15MxSQki9HG+xYx842EQdS4Fhwa884f/ZGsiEBGlzTNbjHB7mrO/mgQTi6jAN7+gVY66bm2Uu35mfIG0T+N8aCX6Pdx5M5yeiftXrum24TZ1ovt9apdOYKw+yeSCFu3nfwaHv7b+sTBRiE5wJ21LAv0GXjzSpPRDRuW1j/yYuLpvxLWLYOeTiDSMJgzcHgajwxPcxcClyL3KYP2IunjaZJJuPHTFPdAuEXPhbCf59eMFUaA+3JyBHBBkxk9RQzeSwhmU6kgeOIe57t2Y3qZAaoTrwwFMK12W5UZxGf2Z3nr5UcOGSWW/XIxbYZm/EUWTFNIwYs7HmJAYjuSn3UJzXlADC+hkPh9nYM7d/CKQ6gG0CX0EsdKU6dWxbUCgDCdU2ZeUmh2juaU/0zAOAimMwP/spMsK9Wkry/QEinFSk7kDPIMHnTKyS5my+TwSC+x9LSkqsNu1oqI6i6T6XwwwGnsazCluX0BvW0Visr42GuBGf2g8ameHKUkdCJ0CtW35Iza3vOC0I7kwpEwm50FHZvJJnopoptS009YZ8aiHlL3h2f4Y15rJhmYfqQrlVLp3tX+rXWZHJkbTEpgYkvw3PtuIn2jrKaF6Nc3nYb0MErjQYVf7nufZoxc7n/PJ8GtWsha+fdWQfn7deN/aTgELgb1mEp5OKcl/enJsP3G/HaW343BmhVUwdRpbTDrvw/JM7OJ+9fJMAXuNkBsaPAbGEVUBKTIXYrBKnUty8oBXqku2me75efkw+z2IgERnDrKqtDfljjrfRYVkp/wkekW5hLerRXt+IzRmvtAlmoLXX8N2BtvdCJpJDhkStK10c59UCr8bCzbZsR6sncQ95dJHMN+CuB1HxDiqNQ8gQ7GJxJ5AATuMrW00rKNCpz8c+uwYv3vdLqCiAVnPgOL10eZsKsglL52pU8N8hZGHJRCkhc91wA7tuCm0SspVzYBOTlHR+jcEl5Nzpf6B7Wd7rpl/TB66m8lWKKXeWuUieKsufW4jI7hronRyGKkj+7dB3EbNPYtX0vmQ85sk3ZJyeeMc80F4TyYDdRucBuPyhmNF51qf21XDmN+CVSAkRVTtbbs1oDQODO0sd/NxSjZ0qXMzZz8eUYODEQc/ljw5E3Jd8b5OEpAQ6u+zHukt50YDFLmR6RPknh/2fqhAHgYhiR6lOS74wS8LkAlUu4GMeRawdyKL0SZOLRe/uQ8VXD70hKRmwG4TsDQFIrnFvzPwu/RxmT/atq2oR1s6IRS3zLt2bBQtNurng2P3IAk6URtCwQpsFOXqrhMYaHoDHCB5j0IVOtL+BCbAB+0UuZ0f45muCRRzAia2aZcjOLRjx7fV796EFNfJvEYhQDclgwXjTyo7d0NaZebdR+K5HQWhglWJBqVLHQROgk5Zzf2fS6rBpD3HFwvu3sqfwWobF4xsXtsTRuAQAk3ku7aVfoT5u6Sq53GbS01fhcL4/sOJyiVXBwF5rdXpppIS+51Nk1Fo+UUdFYkpUyPdpMPGcuYtcZigpu7bVmJ6lP+Zcz02MdDWIaKK6+INZAXvRDx1aSRrCO+h0fmALvAVQIUaAv/XQsmUPWzrRntPtoZ4TzNeWYqHJK9RqCBQzxeh/hyDeEaGcWTOa907XozT4UWrw8FewfahKrodoXIsSJJdJYq/4v+srtoUE+tbobHhw2mTkvGgKuzCyJKCa81Cu4k/NBsoJwSrtvGyIc36LWhyhiBbqVKQp8mDwMV7PNlC4V5JDp9oCuddcW4a827vjjE8DU7fpvxF3NzvxPZPvWSDQCy7U+HAqWtdzFi+sSuaEQ+H1Tk7dhXemBEvKOZ2srz0axjDj7y+m8m3ng3MnRroQzeQkHjd7dlfitwoO30u0Mwh53uAF9TJ88G8BeVGAlQe4pJTBxVJMtalxHCpjF5uZjREhE9GIoqbchAJFWgVs/G9vvwjMw+g3SvH2DHWl5eWEdqf/VBTPsktl7eLg4OkyTpk8DN6Az8iP9lqu4Hxmq+WTuDPVXfXaiim1q1ifWWqwEcr5PeFHJPVi9Tpk8QRTRpgxUCPefdpakwycPn9PMxE8ljCvsTPcfILFPjfe8hwRYUTaWyyvG8uLwACpQbFgHNQgwwCkcT14NrNdnTFDe7G90JX8tdj8p7o9P+tH731Ou0WJGzuJUEn0/96bqwBtVA/XuO74I3aGJxAVpgT3yitoiCFGDqtdv+W+KTQcEJL1z1k7H+D3dUToJBaGoAOQhmomaAoNN8Is4hcL52voP5RtV4f0ay878S8rtgzLLYEm2/VMzBnR5u0WfBNVXf/S6YBqHvAeMCHCZBhr1ydhGbp7xCAB7mbAb+kaFb59mzqNASm1LQTKCYyxlP32YlSi5S/o2hl8M9gn/7dad1f2fCaIRkibrU+0WNr4o6mSxLw+vU4NQUaJOPu3nCwf9XiorphvdWZDCapOPlmHgnFh9HnNwsClaF2TwwLQ5a+//i1eDAPiS8YqcG8sg20+/OzMvB/hnzQm1t84cEcH4nQ86syyFjRTKcde+dqaWMV9tqcORPy3sYqyR+GdVguhIB94yDDfkNc2GNYu1T8jvY/DQS8JgQl1MA0o8XpWQl00nCbTxPl8M1yzPicEYMVpWZCxLWJqPcOa2rhoKzTk36CU5uAVz3lBKO840r0Z/wXZentPcGQ2FsNLe1lMi1z6M0LUSVKAgd8Sj1paVtPGXYevg3cW0IzRWm/6uOyWkmGJZl/d8nfkMMU0y4SHnNqj7nL+na9UZ3hGQ/nAQ6JGa3orZIepE/F5LIArgWg+VA5fhlce+8l4qjExpTvQLK9E8orqpM16ANW8LBrftAcfkj2xc1l5K7h2Csm8RuUzi+sSAahqJvpAbvd65/AbdxpRTkvcEtObXNJul4LE0jyXUWFj3brYeEe4nrHIWQKngDVQlnTl9MMgKqT+gKg5bcZQFluHRX/vOCYlGPw4o6aqbavoLBns7ZjaMujcfECMSJwTcPd8ubSdMvx6tXoc1NcYlL8M1j6zC8j7jWnSg0LSLcNLYiOLJh5WyNm3MLKVMqmu7lRRSwPxkEDpqWuz1flLrYqMLLy34siFQ32ty4FPEdy4FZQIafZbSCOR8gCqG6sdBTG+Yci1GevMvHUvnXw8QSWj15X6DUUTo47sxrSAf2jVEaifxtbAy8MMn4s5mW+wS3hX0gcrKILOUx8pbw05caYT/uv9i0OG4R8Wrqkwrkc87+/CzFLreWjIq5MHFKtL9komLGPKdHFSy48jYfeLymFPRD4m1JaUi0ZlO9b5AJlda8Ass2adiocUXKq9l/T6BXeH9EnNgBY6lpr+oJGyu+qaFL5kmjauiJ5OVkbpdJdHeO/xGncVxvKeiemA3FLI23mJvIIz6KLLMYlZnEQCG/2CQ+Z40mF1X4G5SbuggOfSUlyt+ZF0cd0F6XkfK8LUGDyNijZgk3vTEJZHyhvEL9KdN7UCPnv881alF4VkZKoQ/3Ng3+xb68kxmrjHTTkgbH3XT6NTwsLyxIaVLCP/91ldthBRCNmKITF4wS0mrRyjddlqcsajp9oLmHA/aio4CqiTVR6NnyqRl7LJPi+ajwMfGPlEvqN2d6xWo/keZgOXaaFoWMREfbHsU9+P4RFNuaDVoU5mE7lZQYEcaqfQvf5MBjumu+ITJwCAHIvGHFCNE/TVl7+43fK/WzP48HJtqcO2+19h6e7rDjow1a+PaTkEj/p/1CAIylsLLVLHy14jsCcYkM8dX2DUBi/1SBjjPrZD9ySF4xKd4bz+OUw6iQe/ECycs8P10ZwzcDawy5wVyK4o5XY3ZNMDVFJxYud4ezyDzKQEazIi/RloxSvBkdeUFJoaaqPIiVuspMHDqzYykckKGkCOaVIzbFLdyNgbe9ZsPU6kHJ7o7lbD5gtUTXcTNOKxbxllB3FYReVhA8CfucATgfD31r2/N4EL/Eo8rQW/FeU+oS78PCVtuhypjMdnaTDC2oML2yeJG7HJijdJX5fJb2//Igjc7JoqDPH8PJHz+s6PUVJIIYKwpQojIWN1VP5vfakZM+9eVfnpWOB4qqumskk26RsZIkWwckdXEYvllRcG0Bg1O0gn/xiMKsUkCihwzCv8iVnqxMGD7jd3Rr7AHK1DTbQqOC6pE293F0lkIFIyX/GzBlEWlQJmE72u5v0il7wd/FU8YCzYSKd/TmVe3hmG4llToiCIfgCHyHjTqMVbUxra0y3ntiBd/PMxP2kkt6Eh8OHBewPWWjUeWXFI+kM3gz7cZfb6WGz+6Epl46p1KVzZn4lzLhrBNA6C6+oEWwP9nmk9mEUoapp5KrZTAvJXV8CxC6D82UAQ/rXkvFCAWz5FbBCY7GE4ibEW3kQEmlICO69zgIzDCjrDklQkkH1Xb0i5vl7Vci5G/3SGlys7p+SSNWmNcBwdBWIMtpUSchBIC0kFt7DKhSQXiP+XlcXfzK0ElLfs7z6+eS0u4IJ8hEvU4nCV1nj5UhEBwsEBMx/K2H/lnjsljFEiEfpQY4M+kINdbMyM4h/2DIiVmBR+4eEQL33QrqheJbu5RCnv2wQLe8EpTZoqMfYF/oL4gborxXgvCJLWX+uEamgxW6xOduki23FV+8GerPtLY7cgb2ZXzOx2Tt5b6B6M/UZG6xi9iWjRASMr4XDwJip730ovdaNZTjs9fTjnsUm+SptCC/dnwQjQ7fEWkU495FWbtQRUzASJzLMzpeFnTNCe9mSWtjeXu3zVh+aBTAJFAAkVPEjBZIJ/Q1lHc88rwoEuCfUqRdmUAVdt/qMktFdM++DUG7f0SX0Qd6hKmkzUaNNDpjJ8K3jojrb7rjMqUaRcAjzCacVtI0SwmU+5v4t2/uasQA6yhe90MyHV9yO4uz+mWUmUYGibxAmAOJ6CF9t2+uiuxnUpy92g+lEcMWCs4ZMpXr2BKhq3sPHlnZh7qMox15Qjo2423QJ/Tpy0Agb1ooviMfM+CSE2hSpysuF1Ai4+UyZg55zvPlxHaQ0Hg6lopVTdbAT9giQcxlboLYT5qaLUwdvMPTVaUO6F6363BKhcxoJ5I1LFs1GzTeVAz3XO+6OqLee+g5NhrZoI411zqvzcZaZ4L6J58Vw5SOBPULae+ShKAN/9nhPqS+cctr3iY/dv+DwO7e3/KNHTnAeF0eNHe1FA0BcO6iEmjsMLffzO3IxC8WfzOJvsrw/g6axSJQ2gpAMr/Y7nYROT6CscCjARJ4Q0VmYbLGvBYWNEh1vxJb8XRTlMytlhFT+iFXf31PnfbT86IEvxup0rjTvoI3JkAFJYU7SRD+7s6OXUA6ieccOfsu345+XzCZDTihLFCGO0ZgDP2CFABolqfxVLilYTIwVJdtlsz4wqwiJEwLmjhnFO/zvvIZh9szJ5ZczRbGhs1tWNbYT9tQS9auqSfj9M/QbgAnlGwKc70cE+s0F31ELdDN0cdvZcmMIzE/3A3VWhxaHKAIfX9cJ6dfIvB3qsUYj4sDORsEKCCZdDAcsPPFiNeHTmKAiIw1UQWyzUthTVlVd9wrq/9Sy6Z+yOlRyS37XTeBTffUO+8cdNhz3oKhYS0lk5Q+glz+p15/gEngKIl/9AYieANKHEEeRctw8anJ8bZ3zxo3iE8YNEXny/oZJwITHQFHqm90IMdSzVC6m1coSgPm2gZiuEZj/gxCeDm1tI5sZphp9Xva6m5+T7F1FdOZX3scqP7NNnXLY0J0d64+knZjAibqeNLncTQTmi+NRg0A1HbexCcpEk/Np1QQVaJZdN6NpdYw7iV9IBG/yqE4eIiJucQ4EGdFdYvnPgRKcTZ82kLnKxMXcS4VYgQbkEONvT8BEZKKKGn5a2UQ8WwXK/C3yBArBdxz3etuFoYDdx8dTGPd9X90OaxUITvpDRH9oPTYJVMmGEHzM63ldabrXR18PORRdpsSY7sUAUbn7V57eMU/A7q7KM0Uz7thMm4qdDKTvhSAaEovhB8Esb4xB76RN5yVUqL+nDIstShtY5L+jaPlZL/Qos+ker3H5bHny9GSVZtWeEgRdV8SFWTZk+fmqbtJ+Wq7myT1mu2cOZcjwUfuFGRmDE7qb6gbzc61mu3fLkiGJFRaOciLMXwUpxrQWVaotFbpQ/KPg1tVfaFBGKMo3RwdTeI1n8xJI3vX8fI1fwW2XOtp7MKsD0BYSJXrxlLpjyfI73hL4sRF6KJvDEwiD4qht4rknrBKoZgzeSD5j3rpUThRStF/dL2hhKJXqs6whe1skY7F4xrbO4FQOGwuGn3C9QghFFHQG9SkedtOmPm6RJb6CMUvDCqjTagVZtWmVoAooOKF1nvYGvShNb0I4tlL0Py6H3/dQKW+a3OSUCbVVt+NG2bFx5q8tCQZwfP9bpUkDUJs+m3s+ih5w4Q3FOKE2Gp4VJ/W05CMgEJexocwRaW2jaFffUhE/a0gVaEXpzR6hnaM+77z+xyipU5g+7CQZG1Ej51znu5Wb8m3ziUPlsD36t0jKQ8RvdnJ6RamP61F9mXzdf30TIlEs63qQM6JrMrSz9rVRGSkj2sAtDq8G9xSaZoxA9lkqCPfL2cbE9nBdjzokittOqqgzD4VmAqTIAYWVK1tLldXerkW3H17MMMpL994gTCVAi/6wA13gBMGXpE4cvcnvKfcXGFLKkeSFgCuQxxglVn+IrstArGjp0KvySaCHRtqBXL0JTCkrUgY7asoMEIT1ph//ywAo6XBKnFQmpeWzcpVxvLSM40xB1922MKH1KV60RI94fWJUPzGkMkcDHgzCLPVBL0fRCItfm0gwompT/j/aHyEGLRjdB+fhvh5icOZ9wWeNNH659eDDILCm68W+bU34xmp9ulpfEn0CowleCeRZJXz3XchEb8yqw3O0Gy0lmUaZb4l17eWJQnerkAxnFGLqN/mrgdPhjpHsuEmrIC6QFtebUVNEJPShxKz0ttYqrMpo6UN3sviHratiUIFd3cjyXTXvec90C0cUPmb5jbQpXzhnkCfHsxDifX6pEFpcDtWR4HGFLx0cCHa6+o11fTADgXco5U3f2jqhEmGW+EbM16Ca2d78xiX/OZ7gZlwe1QnJeOCs8XIKw71MhALD69CEutZ3ToUZds/WsfvOl0hKsTOoRLp62ACUDwUxSapJQjnXdLwICETck3wMz9yhUShfpF/vljW5FNlE/T0oOAuGa+w490FJ3WsvUiG9+QoYpiJE/ZWCVPdTW9NlJR+eVi9a/Qewu2BRkeCExSOom62k5OA8fAg2oT+pWnVEx2TJSDws1jvwRMWLdDzvcpIRWKyIMr4tdz7Q8x3zlLAw953BJZPJyrTJF6wv6BR/loq6GpdbrmUD5RNrtSKu+BDLigB/ERvjdSWGels2u0nQKcrUy9RhdigKJo+wUFi4sxbl5/+JWe6iVxuV1H7kLxyUp5Mlq8JuxbzbonZx14oI955tGRf6Hx0ORKiI6FGcaFM6ve3A1lMh4AgbKzHIlqxD6yNATKh8EFSDStBa8vL5UXjGUmeeNyatCTn3sPG2/iEUBRFGaw7A+dkg/iShT+bxN8cYiXdZ7erd2X8wegYfsOAQ1o1ItqNg1JejCsIXK+AIhPNgUM3U+IAbdKg4HztaTqxR9Nt+Qro6lmzqOtSZ6dNorg4BkPOVR5hn5eBcWwtCEv97AFhA63gvvXvM5BmQjH/qW9OJE3FauiJ125GJAoywZ3Q1ed9ZYJW5xuYuRZUbYnNas1nWHEHKSS4ZJExAM/8JZpgqr9OXDQd9Y2LQrRb71VZ44wDb+6mxF//WTnbJpx63EHDh9POPPLbFqrnNj5sh6ySmCymCINbamESNKSwbW7H71whDXrO5hbPezh1iC9+wcp+kHH22FMfmF4mFoybTuVD2lYfJwf2EomgpND3ATyVuYddEdwoRk36BPFmH+rdeuTuBgI5C5RITo5epww0foPceUbLXnagAQmWQZC+3ARlFypMBtr7oZaszHaBZ+Hq+e75hILl5DX8u3nRiIAZSpiIDo/KJUMe27mC1+UNsGiPwmJFViAX9bKy0tRNnxJ+NSL2+Vq55pzbAZ21uLUEu3WjLIu92QPZuwCwt6MrOrEmILwV30f6mSwYuoH4a+O42zQdqk4FhN7UDY5P7APlm708mDM7LvCLI9e7BARWyCR4lue4QVxYiEgdmhZwx5ORpKIAge61lJ6uBWTQ8JE4SDduYhxPtMG0Vq0PrRFIzFVQG/er5qVu9ozsTVCOO1zipEkuPATjcN74nJHtNL2p99lX+FkleIfjnRZW+kUxTwuzNPLkerTJWBs1mijVtnuSmnsL99fyqKrbSte2erSGUn93Sxo44Pj74CD4saxoNmTymXH1ZtYidrfr3TOTTzDvYCmFW+ca871Wg5IuCUPuEXNo3LjV13D4J59UTHDPPM3tMYhOMmXs92vus/By9Lvc9ZKl0FbE0bn35lSZ5QRLfUDhnH6vy7K0tZBUesQ2r3ZSltP5vNQt/d+kvDcTS1kaRxc2jbksoedicp/QXZF+obA95brAy+nVn4yXe8C4JzfGktwxj29aH2hS6wLoP/5YA8hEGQStuH3w/MvVWEy7SqdFacx/fphFMBUynKy6F6PGMmSGYBMny8k2OfI0NTAO4xtj1dKVeArgeH/81PhaRzsd4pX4CCO4NyzhrQzPJ+wO6/l27ImeFlVekeZ3myqOAbbr7Pi+lTC9IZsxuQmStbi1UnbE6wvF2g/2DrFNbuFmZeQZm1y54n+qM10JCbNUlvGugeyHrdCvw0aONSf9LztNcP7gYnUqGcN1Tt/L3ypR37XRTHTVihO1Q7uUTZxIEgka6/nPlSin/aUQo7pe9OHFjnWv/c6dHlv/oRYcqVWVW1p5u6OU4CqEMLhqSn3V53gXviRjGsfBfrm7nxJeqNc6Ju2RPFHP/Gj97snyuVQMjGaM33Yz2ROF6OAuEIF77QU/oED7e4eJYnMBSbO9gfeUTGH2jVLmRM9hPngNAAOpVFEexi0ZOGB0pSHW95Xl6I9DN8B1yy50yS1tsFoGxqFGO29qBpuZTXj2cuXoVNCbP0geGX2VbQm7UsD4g0Is2aVDQuhDjtmQ/Sol+Lv5JGfSNCSwT0tjrPjuwJK01/+yuwHCz7kCbXR6Nn+yscd7+xcpFAFcS/zvn+ckJPPzPFvlwpkrjK4HzqSQ47iWcy+xr5S7EsOqXHB2iJF6SjMRe+D1//KiH8WBka6iahbJQQ4MsutPIOfOnfgBJvWZHzizoMZLtM7btTRH6pZvCY7EzfbNE+blFBBct6/stZQCrB+8NR6LskjUAyFbjKSJzOSdGr4zRzCsl0HNcSVAoXfFwWFHCQPeQOkptmGp76ZUzz1YArnFs4A98MpXGX+l/7wOS/5QFIm71MahA/A8641XfO6iBK5ICCBml0pZB6l23R1mX7AiUIxSoWdI4XxjERQDqjGPhR0KMa7sMO1eAxuEEKJnKdcStWXDG5Ytq/wi8XAmFdfBp3wl5dC1JEFoIeubNI2TIaKjdyjqL1ZEN+hHPR0EJiEkzqDk9skJxQBqFo52wChadIhwHwCY2RI3y2YxonSjIgP9c3dy0brEREnbguDxsnNTdVo2XZMxSA49PWcuCnW9GmYlT9tLM/zFYf/yw6DOahhh2v+SF6w089H1/qLg+0MjNyafsJRAaX9H5ks5xkCaCSiNyxeAPMdRWzE33tIPXdfNqMA4az7YObs4C1EmzdrSofbDJeF5qI6GwZZtAdgX1uk9nkZCLpmerQpR0WxVLZvnCKBfOx4Fc4QZL1N8yILdUqXdENnbe8fuM/xdwMbuaBWo8dKOFZhV6R08HvMfAOyKxpcnuuqQKcRxHoThMWod2xHl4SakolgTjgRUfUIKuExCdMuev0XgN69P5Bu4bjvd1MyG43oDbUl4xR9gtZlROHTQy+NoDxOE/V2pKbagPc0ZT7KXNSuhzU+LN26umGo9bhTBy9u0MjjUZVbVBpJ4Z6g/8U0uKpkj2/SakoUmVcZhPtQcMJMqhuSWlwWsbmLZNxSoiNjk6PbnOnjZb24TZY5yadFr/iJX3xSSI8cXMXnsrWBd7YqYVrl3ifdCH6zmEH2phF6WNFgwZpoDVTP0AodVHuLYCIhN6m9SDX2kJ19LhWziRC8wXdjiOc1stwI4aYfHJ2fPNUQpslbGMIS3pL5CtDTKhsDWFVVplcuqkNgu+qHNFgqrHfq0THAwBjDsVgJ9fwNeWkYLlV0BwmH8XzGe2Pzlc6sWv/Z6bJxyIw82pYVrA65UAEhhKuZKJTYRwCL3GYwOkyzu4lbUcmAFk7q8beICrXmCbALevVOzFT6LmT0Lp2Kqw+IEbensovSXs/aMZ3QyAKQhVL5kV2EDLBmzPF64cb4MG2VWB1KKYcCIiuRUhB5co8GfYyBPh0p3mi8ib6kPYCuR60QNAutD44sLGIDAMTx5EW4cNrjYo4fgIBZvL7JQeuG2f0cDG80WFYcpUVxSFv5p4P0aM8FVWABcZK4Lfi4w5fEd8P3KXa+M2yUIj5l6GHqLyD65cRharPWjSJEs2v41TcLjRxaG+/xEvsnnCodSqkNLvZ8m2lQEq2q4T8H/W4Td603jjuV7zjEep6WntYs0nACp+QapBDd+DRsBNg8nbZu/HuKuZKKs/v5dG6Coc5rg2RzHJ2EaM8B/EKp8LP+Na88Dj/qcv07r3/TPAdjD/jYSxymsLZDQqOW3kiAGpp3Z1+ifBxDJsMCG8pidIFxypXtsKZzQOdARTXEEhacmg0lUN1dFJbSCsAO9of1i4EDQZtPWB6Af9E3m+nMdeJhs6xZk5RUFku6eopPhL2C941tUIUuhSYKonNGfqR3Gw9Ei2f1N553D9I5F8XjhP2U6YxusHyOdhMouDT2Ts8y9sGP6nIflpX8SGW0XSzrtRv77LoH2uXjCxZQm3CXuI2DqI15oPawG5njzDPMhkxqBPW/JKZApU8EW+BuT2x9EAXzFx32Adt46TqquXVmNFKfV+0eCQLgPzgxgpVYZeR0JgyDcqSYKuj3ffuvEv4r+06rV2eMSuWLEySVzKdO/dWqYHT1XOt5ioAk8EyrPAtO3OJDMg7DYoNlWerRjerdUBAd76UBNNCo+16LOoguYOhd53SqgJeUmxmsZmfOq0xFTzSppp0RUwkGmiybO+PHNmLxqTIh39IEkHQU+vu+iLW6/WY6h05dFZNKGaSJ7zNiYNRiCbflxBPrPinY2HJtDRYfKk8lHHA6XWhkJJmRSj2Lfztcf4r4DhCEComgQ0nwb8/rlGqx3iYfL1m5wBPk/ha7JoBj2ah7+XYd7mNvBcBN1i+W2SQBWJz0a+7cjLH16nZ/48E39cyjb9c6ykbIxZckAaOIGlct7gH8GDjKIC8FJylrCMU/IXlefcyDuOpH/00EEuhBwIWHbkQSS8KRbE2xqBhBt9RyHsiJ0k23idfzxQtmvoseEDF3NWCHrpUJDiv6xX3cIj3rsMrToeQKFoCLoR8m+JWSjACiQfEkR/YK862QtZ0jM+Me6LtFyPmYwG91kBhb7a26qtbKvq+ZX6xiG2pPVTOyvcl38/aO2okupNFiGa4j6PA1DWW5XqmDAxvl1LKWUZyX0NRVaGHSxJZxbpmBCfazGITK3FL732oIYNMqtIwSmY/9HoV/vggOQ7OhWgg0nAs/vNgkgGUTOU4CyU4qKFUdPX33BRvpu2n7oH3WN5HDFZ5zKTVFiCY52d+JrwRo+91whV55eZKfF2uSAjQ7SrAYzDmfR/hdFBzXaN2vvM5YV8RWZ1jHFQwGN8hTk5UJ5bCdcKfdZbU5+/OT6NjZLtGWnve2Im88ZZuwRjSlV8u8xMqZ7x8IN7+NHa99KJxuHQlfggPDKnbCqUCxcFw+18oCU7Q/ADCSkrfPpYfObTl/ZFayrrhm6WYyv+aTnYlXC06RBNTAJLH4pCz7NoxxMnP5CJox4nrbr/vnqt9/mVD4DCTFFg2P27W91KkDfvp/VWXhCUs+626qguspXDFuhbouy+Iq21OI+vgiHg9P8FcAUZOIb981c8A1xZ0BkF4A30MxT6jCQJSdHKdOjGEG1QWHs2M5G37k2Jimh83H/v25TMgT4qi6udHnc+E5MSO+0/C1A0h2snFlhpuZjgJBVEn7idfX5dokgd4sONHfe5v1Z3eFVRXdxEhKO8Jf6LyMJZMcPQ5G3jFRUngf+QCxFAYLxeV8gI3F0voxlOrTAdW/VPDtASflPjSCRJcWpfLCRlixzCPPOvpbUdh52U5/rtP6KNb7t1I8eNRI6uqqgBZ0w1SsLlhZTR8X+KRNX5pfEx9/9B8C2qwZeSLbLpGcKjw1rz3Nc4wjMm5vAE9wQS1fkeMm0l3zFEndrnw8fd+ClF6rFJmPSpCfqgQKhqLpvi2m9VwGmZudTX1ewGYQAbjUIGqAiRibrhYvfJP4v2Sypy9nAYhCJb/ISmgUvUuCVWIEeQCK4V/hL+Vt7zoQnADd4uofv/mAQ1FdFxQMOdnTiqKa5gfdt7gFPk30Uqo2KC7PSBIssrMJ432nTW4Otw9Dzi/HUAwY03ywDiFAgp624+/NEf3L+x26v5jLoVaknC+JRrbUDUGNwGHGaylgM9K+v4O1zVfaIeppXaJUMgYdfSprytLH9DRilYYUVi6L4LV17ujsu0wojrKgMFs70O5uLZYsUIPbWttC/62zleB3GKR2S2R0FhWBYCLsJahdZ2rX3cx9/imm4QBJgvXujBeTgSWzNuUp7Ub0FseSliQul74uVgD9BFrySq343xJuz7G7L+pUxrVw2iyKh1IY/1siW49YeJ3h8l8C3r2T7pHmyRmjBdUT2uIwb2c6MUSaasZ99QJHkoExDIEMadC6+9UvsGrb0JecIRfuEwlEU7R64bspKNP8GGNn9gTDGCz3tUYYIUJyQVGU3aOySRvUqmVk9cKQFWBOuVTiebGybRH0thtUZ8d2EYl+WLBGe9Cyol+EjPVlamZzBzDmS94j8p1cB4LJX/jZxIaOlqeYuBEllI0leQY8TNwW1Dwl4IQQM+bdHgVuYwWAv5EjVLX+rIT+tgFfYUCCQSnjDStbHqQkhq2yXRi8B09z7Jvuh9w+uR4z9zmWLMEYSDVLuTvju3AFCuUyRZC7Nhn/m8t6S14NUM1M5DcJJ/B/pp8zH85UJz2uXmp2jvvkEwNJkKKvBEwDH8X+2KHAVMkdw6Pwhy/tmhYJUkKgfYTrw694G++cdhjupVZDILZsWtITm8Zq1urQsla1tMJ6pbF+CafiW/2yM79fPgB79UGQ3R9VuyR4w5RQcb6tpaHZtPYZ//ZepxLlzHjF0WPKhefv1jMhed8t8Wrr7qoUFdmW+EUgEXVDfBMTQxhL/56mY8hhZcnvn1mxm4TYhC0EkUN8JGa00kYVNOcPLuhM8ZAYAZyOe1jeZDuWbRdqU9T+DKkJo7amtEpamltUDX0ImwoVcNSexJEL17ONmCWdZyAM+Os0pZ6vOGdbb6Z0WjJsVX9heimBFOsfy2fBK+FtnjBiJJgIRhaMID9SHZ/4k9kVB2WJL5R9jQMJfIn4pARcWHDq81U7PaUBoXJVfc7Z9rnSV/fU/83Y7AN0OzH8qJ4eH2xThmYjHv9g8RKcSQ9HtUid8ilTgX4N4fOBYhYbyGXEfW0YdxKsNlNE/DxDBR5fW2HC5OCHxem6c+lnTGVkC5FX+su2wRxZ/SI4cKl7Kp7hFfjFyBMuvAD6YqQ1EIce50inyS9tF26IQ6Pz7G0ihBgO7bvflBcXjztra5WOb5ycfm2VkINWRQ42dgHDwhXARbMkkxZkV0tXiACkXXFv6P3jDaP7hJ8sL9zN3HmGlLIKZyOyaaRWuRVNE3iEitYJ5x5N3mF03XcOHHgSw24eUKuRkeQhC0gq+dDf4aO4OZ1mVxTR44o5cQVcG/GeKqnNwukEa/5qaeDuC0qX9DqXS03l/x9O3xZHtOCleh88co4Nx+SpHEJ/CfsHWKJ9WvQ7pFRp7Lx+v9lMzv9s7SpvFrK3UYfTrTPeJFzRAkbOFlrcoi1XBYz0rJfz5Fc8MaKpu/rMUfnIc4ZZnrL6EwirHya6a7RrJvmqdk4ino4x7I4gBxhM3DlJ6nJElcBjcNfmHYECd4lSFZq0VizFMJutmfFbCTbQjW8UEB3x/WY4RYX/sphMLzeDqzUXEV82JI6kObmdDXDsrsJSDYNubc1UrOvNwWg9byUgn1TCoL1Wq0ZKkeUb0ene1Vp/IVfaXn8zOtOJL0usRGFe1lpPxAakx2PBBWcO7WWyxGj5huNMCyi08J8VNHkU6lWrga6M65C8F9RmI2oMc+7opGPqptKfeV1/g0rr5q9h49QYQYh1DqXCyln0RP2gvvp1SDthUzDWSGzdO4Ff9GDIZAluJwT7bcimJ9ze6opaRwdTLEeUecAYvWZ8FrK5MzceU3rxLx7FNx1fLUryOd2cAkT1qToPMaXQWyrjQTBhlcQbJkwtZLHOx/7/EpbTSzOoQ4p1x1kgHKyhxL1asNS9LrmpT551dOzEg2cYHSBFSZPyHyAEUvprCs2D4IG3dHlzN10Py/xWifWT1HBF4huTod+mowRSWlQnMjKpXApW4dIMEjTl8fp3W2WqmUvB7fVuG4RKXujKjDIaeZsQaFUhNdiF+ON1pSWypJd9XH331svIfdiAB8L+cDih/0nxDkIVVyBO5fCbRhjUV6oJKkLqbQa1+hkj8mUen0zcXFzaFVli3pXoYCo4Gbxtyl9hT4kBAMLGobZkqwoMYIouAug0aMQjrB2h+u6CDEzzPyBA3zpFlmJrmw413EwX7N3+V+w6j9eD0s+eZ4ek8ZUvxlWDWhtJRpqrmK+IGuO4VuCYvlRoXmAQ/QcxVHg3qeMuhxwNju5M6/qOiZeDA4yntBqSbeRdZhlYiJ5CCBDwpO3yRIbJFc7inNqPx31zxqUfF3yCXiErQjsD5T60LjouspZSk0a+wOCLrxHGo2tfckTDdWIjlIuISZHMMzWuvA7H+aZIo6rnsICGGZVH948LGPrJ3BUqvs9UdZwtyNZ/VcLGh29bvwgcL7TrdwnzDBlKiudWWkZywPxd8gW8NhbyRjUXbJMOAMF3eJQc54zPXQQsUp4oeIhrB8oY+UpT+1KaPimnEjAyQjtrpgYsU5uGIN4QaBBXTjLdGHLRBrM1K4sf+btLe1tbQncqAo0typO0LCwHJYPG/+/vAdI5SuPmlCUDe599/zB0DRFv/qpyijgB21cIhuwPcoAqzyQeuZMhpAKWjOUBT+TA1EMzJmG0svTc97Zv/gTSR9on9dk2UarsSN3pDPJXlK+b4rCjjV3STuxK5zInFGbdwbEIejih3PqS501+KxzOD7nhAjDl50kfd+UzdSGO3og/VcJoZfeelx7Qt0x2v3vkDz2osNcNkeeLmMNeKCKkbNBco2v53pVH1vQYjznFUmm3cwY4vll7tth9w0iVioKUQhAtGthwRLoCwM+JBzBa1Wz3xdBuF1PkDcCED316y73RffspRlyPJ9XilzO43IXiGMTtv0NVoQeg299mUuMnpEXSYdyS+xfqyoqbOJ6Sw2bmdo3XJLq9kRTbtQOz6lywzzMTjAG2MgFb+e+tNFX15YswWYVzig5oz5NNabtNdfAHVcX66cA20x5K4w2oMcnQqXC1x1XSM8zstW+ev4Y4WCeAltIkfW0AZcPjBe36WXn4xEGb6NrgO7LbYyn4WTzF4qSETolUUsOUzRydxYXM4JcNinX9a0sqyG7cH2got6BW8iPH7gKuXhN3R8HK4OgGUSt1lTRYtdcWyUHDX1/h8gJXh8mFsJjDUoyhvfO53f8GeBD8R551FhoFZ/EmZfvPLtmCm0HFomZBj3EFlfIrRZ7mB3uyVHK/5OiXalqgDgxAPpfS4PE8VypG1NLMyjuFwfgnEtlkYUmk05VPuts49FzoKoDyAovmqOWUpr1boFxzSYH6hChhYoRBN6M0BJPjTH7y4V4//a1Qt0Wq9wonurqHOBtOZyecWfMtIFNzy/mzNxzagw/J7OaMbpg6Rqu2bi9q+wCDbf73iwGBW2+pYFOaAwG70lRISUTlDVncBEGbvCwpTgoNifpokOyQ/ClHp+NXG98iE0XXptuQlPrEd2TGKy3msTDQZoKYGipEXwRElumfaLpJK4xvs4KBMZI00BmkSOn1sCVJnzCyffJCut5CYblSHMpSS3IQIJC3TvnrdzCH3UDC5D7TimytVlbK5Pvn9/Bj6VEhqCyOnwiwX7seG2K2tvRgj7EXl1sisDWPAkbQrIWRXIHyS7f1grra+jOGwOYcTTDqYwWvMDIvt7LwztIJHCxg3kBHh2HwYbcj/nLXepOLFrSXG4XMUPyqiDQC+HfifIkTBTu0YZO5PSdrSf+eIaJvzsFMKPF1yLbA2D1OOVKyBPiJZzHali/VzoOjekejmT3F7nn2QVWxG8gsG2CJ9zdH1C504hMtVMcPKTnwnAs1tYQZ6zXGG01sdNBvabx0iWOWi/vVQO1a7ExjiSuEiQPxH+XrausZ+BfTaF8KW0ZHPLohAl7MQ78BYLuG+egrriRoqvitVHltPKrjpFAxsc4mw+QivJLdVQNc35qNMvykHc81AoGeXaX1F4myqTodH5C4FpvW/S543dGrgCPHu3JwZsoexMLX+z87dbi5e7SyP1V/7+iB3YidkJQWjkN2VAS4jqmuRKK4eQKnXSkucOn/ggCc9/sJqn5dohRgWAS4NdnN18u7EB21fcZmKQRi/gif5j7kP6MsewXVajcdiU90Ie9a/kQlEnhRa8YzV1kuZqJhDPIPuqhSl19bcGU7cBRO0gVQrhUwE3GQAqKMUdN2gvp1tDka+fuKaxbjX/Z/Gq1IM8uAgd911K6anv6LFM/AjJ0ODUObjvljB/g+wM05miFswNkKYN1k7IO/YbFkO1ZA0UhmHeM6+IkL+FOxScGMXAN/IHumf1W5fC9cqmytBlAkFx3+WoSdzPAEL+/V0TLsTj8sK9+wXVHrYVLMn2+G56RoKriCggANWLord0G49tLLNJ1m5eCWTJZmr+hR0eZrVX9s/PM13GCYJohha0vuMsTXjqiJ0dxZnKj7h1NBYeNHYK40HkM8giphtgif9YORVcRyzE0g4aA1XNHcUvfKIaIdKkXZNrcw3dVOdsBJACeuCTQwuJ5+RRxmJ7J353qkwkKLIqI1iZbWQ3sHGHaAjnQ/flYGAzqh/iEirMIM1gRshd4Suz7kTlolL8Arvmwmiuk1YaH1JxL8gi88MX8FlX9vkUkISekNpdJ5o513MJIel6sXickdQtn2oyt9RVGtmOnTMOrITI67GnkFTfdpDTPZpM7UTF8hoYiT/UH9/R3muI1xGdkJggKszrGzbBBtaiDN7O643FOHm+Z9vLc3nPyflXKmGU1tDKcLpc71+DCwoKdfP+SAIQnGGnzjYEyIHP66PPJ/NZg6gVs5wFZZ/myWqcBCWB97gujdLRbR6t7eWfYGsV8//s0wKkxbyrYrEvcRVDYyHPk3rh0cIsb6JsgR6BmjPjxOkL96PyViJfZENw1q8OAzdRDmkMTg8UX8qcG0xhfDFCHEGN0V6GvQnRZhQVKoKdxVcdYnLHL/+xblfbLRJFgMOCj9ejx6+8KslORJjz9K/gUBx+5w9wsFPI7LY5ApbPQnK2yccktKU1WyHPuDmxKsK0X6difpfleVp0Hsl5DF4TvAjvctw6MhC1pG81gZZANOqDgHPeeYThPOQ7EawnamGEvK798Qta+G88FGqJBIn7EzSkQV9JoMadtIbw9pwQHbXDqFDVv5E0NXSg3DzK58Ke7RDzlFO1Z8TmWzRPIelP49P9N3yzaPLxv7NF+A/FGFE+lvUACOgm+Csh3kS7WOS9krX8tSYx/9/62/LN2CDa62C7Gg+6NPxBnxf3FDsZr8loetGVUhXkFru50lj2fnVhLQY8SXGN2Backf+FHJpOACjbVNISlHGPPtTpMXn5umqjD843+3u8+M10hrK/jafKjhzn8xYzC9hMDP18QGltpjCFKN/OKpjvEyK/nADqw6dhq7pbNSCt/P+6AlO30gLPsfeSiVoZrEooYZ0IRjg/GNBHBkuGEWAkqKjhgPnOgQBtly1/1c0crQhpT6XrbIqphy2i7DoF3LItQuJjrWXz94H5+cZwfcplSpRrUZbz2r6BnMDrC02aqCQedcxdWbKhnn6pqvtj2zfy8krg+IkFzP4UAZNOc05k5ZDcY/O70cqLBc8LWgjQ0PB5EpdyRgBoUuqxje9D506ts4ewAbkAJA0SA9OTfpBaHEG1eGnoAh6VgOQsAfLWoTpV1CGDv+QpqBR+uIRg5aEaoY1gnAQFoTENBVEdTYEG4DesIoUyAETjrueT87MqrYAYD0RYoFJtYkiZ8nOrHJRMTvz/qjdvtWuOU7RsoAPwtND5YuxZfUAE48a3l6jsi93y8up66EETGtQVlwnv7O/VR/urnZG1xWlC286BeKkv6BGTZu0vpw0k2yDezWSuXLcdkLjDsMJdcXD51cOUlwsbNCmugnT78pvYWc11iIukFrjrV0iwW60a/ssjCFC07WasCyv6BUiwQZUc/oNZDCh5IsTfK9PQBHFB9QVg2pymic7E3BQsAxXIZVy6bJcCKmcOUW/BRZSCMzPzRz6enmFPIrlXZafPWtbp3yy5b+iq+Y3H0EEStMu1Y2MUVZfjQmnjc5bWZBN/IZZm4YkpZMuphjyhbGEt6mBZq7JC66L5UYJ/oKElPz+VSQ/O2RWJ36/UWIQ+atGIl+A1uk0RfRCfLu3I6qPzUIXv2xumsvbhzzqJTF8TYDKHkzdQRnkcV4IFQfm+3RLk8PkMUbyfY9FRCOFGuo+l5HDbEcrfD+q0s0WGXGrf/ArT30vOsZSPTpCuZgdDU1NIRoxEhKO5QPSptylmkrMsVCZ6mU/drToesS+H35lLqFtsyLaLSrm0+g5PQJC6qs99MuwIbyXQkUZET+k+JIC2T3iOsLIg44NjvAZCaX1JxDm79BwjtlD9CLvvxUj91wkSoPi2jW5FXUb4j4j0Or6sRpvFqgO6c9b9gcdW2iW2aYpUvjNm38El69xOC1lk7cHxQRtboI8qvmoY1jEW4bqXNkEOugL4z/cwLxU7oizF7VXNeB58Yd2Smoa7xcsVnuHKbK/lgBBReCQQzvMtlTBEnnVYIw3MqjQDcSOev/SbPMFoKOrWkcgC3cryqThEhGiBVr2abtvFB51qRVnaolPnVVWM5HtxWgR3mLAsnXKwHfLaLxu/RfmF4uFC2tCfbF8NVHkYRa98SgLL8879bs452uc73oiSK6UMaLzup7iKTPOlVqxpHITvZVs+ejsRiGtMUaLDM5jTXRR1Oy8/BLl9FtrVMw+jSeA89hSn+h8Hr9TO/6TktHO5DcBdUni0RoUSmoZ2PgvByk9xJbk3qRvwSFcGwNPvLqgo4wMkm0VHctm6it3BFTy3gJQH9ALCRPQ1FRky5v7uccs271X8BtvDFw77GmcbO20C9bV6EUkXXL/I1BPBEUDpDnlUUhe05lPQS/gnKEip+2Fbes/+LOg4Uvl8sWFP7m5Rmig7poNeV10+4uZUqY0wQWYHC9BUwcAFwob922g8JBHZ0kIhNh1CpXpnlv9QC7JrEyxEcL8lVhmJ4paqONo78V1ot9byI8dwbOlN/veQB+lezpScjcHg/vCEGus9l2hS/QFw518WND4ZeaAZ8UvvWjLlXqBOWnvy8NiFXgqW0rF9+loq20dIL6urBoICUPZzbqKcGRNGqQdTB9rWpaadF5cicy1g6+SrKr9zVlkUuXDvLkXihooHiixx2sWpZxz0RVOmwUK3iTmvFFlifHAOBHpoSI7MUbSVLAd0niKwZrNqZnxHoP2qdnMQjaeJYVW5b25uRRseJGIaDuspvWIIG49wbovHaUqGOYPxLlb2+/hRJmmkpvnxvuyq99N9iSvYBvfzSNvbDQXDApm8jOTcBF5MZgZ/046R+Za9rgI3+pV+okU+jIng3lkoRHuwwv8TlUjjlr7EwZZ+8gY5HAJ4bPf6ne4enoAkE5R5WG/t6I/Z7ksTwDzmPkca2PfSYc2u7ncRLi1V/7zXWTfTdFxzDabab+WrU3Jm/BmmlQ6/tv2ca8mv/wgg8HoRVe9Y5gsS7JwUevzp2C46BrSft2cNxczDCWxTyEpELV7JFQlzi/QbchyptxFi6xvDAsPWCJCsiQ7MjjglpVjuz4bpiz52xj5sHEK9f/j7YBCoQ70wD3JUnW//SDjVALI8oCouOc9h/3NapwitFR5/EDi8N+RQePKNimYf7eXZ4pTBaRnSSB07lq04/moPuzLK4oEZYriSeJZ4m81jXNXq8bFWWEWcgrCl6/RfwQYVM64XK4EzfJVpF05tAd6wtePR0VyQybHfUITrH7jEl+vNUpsYiIjW9VhN/FNvoskQGyjQToa1XwKE8G0WAwbJu88gQ6fUUWSq3/tcnx6cp6c398cBbOoB9PBEMPUjybOVFxH8XOVAJx0IwOH71XpRYmT7HALZVx2E+79VXfsLo6hzZ5HExAuZPxa8rq8Rpr46zac6GT7JGP1K7BzCYDGh19D+PShSOFJ6WDDEb1LPjptwur+JCjfj3gm/EZdV9XlieMaduiKsW3uNLfvboTDmMsH+nT+Y4sSGf5ym1y7ZEzTKMsVGJRktELl9W1TrosqU6rS/T7SiejqN5s3zhWqS7qMkfHoHnMXEB0dLJmx+SY3/9dqHp2R3Gw7OwNR9G1Bqkn9dN770GqCZuUFQcB9Qq5oju5j2HQyugvGeKpcc3hk9l9tcdA5H7NzjSEey9yfjkYvrvzL4eK2XNLzsdJpBmRCmq0YgiTmDTwSHe57AbbiDiR3lZg+extxs8HuKiTcSDe3qupATrvc8kZwOggesJLJOYamp3PM5zyaPwvL5QEAhfFWgHdei4Zk58nCL7sHfz5dDWKc1glGU1om7mRsnutVvTJ8bZj1Kw+QNIJAlGyFR/+et2PPayUE7jNmgVvhj3a9ZFdM/3/gZpl1nKVkk3oypiln8DXk1DpmchsK0XoyC8MhEOPqhhIck/fMTzg/8ArP9Cb1luCs+EPxQa7aAzQX34YnnR0FOxAQqLwDqUM2HdmN1bknFiByBciMB222eaSv4x2+wKRI4rE77U/OkvuxLFzCpC0wGu4KT+FKzf4A2YACDZwKIp1eT2PhbZF8rXJsIcbSQQZoPzZdnJTcHc/eSWbRnB/yrOwDYjRYwYGXfGUHcorukaA6OAGtJllw2M7J2jlAULOMix/DyO5Ts9RaTpf1PT6+dmQyj6oquhcHDZWFBXvciH8FSRp2lEcM6EcVanwcPCc16CnKj2L4NLQs6zVLm0jJ1QGk8oLg2waEwCSNHl97a0N738myzwjHdaIi3p1ZiEkeauoBbb1GnV+B1kuiGQ+9zBTmviU7d9KRxle+lgZbXYk0hdMBA7M6e7nhU6WF4PtK09P5Qp6+qjkkd57Bwk5ElZwaeLV2oAK+GnUIfSDVcAo5FRgU7GWWx63O/ehem8tsilbqozjbeI5ydBaWhPCXNCPbjSEXdtPeth4vyPIc0XpyxtbsgvTFKb1sXuCr8wlOfeZAlASImVliC/JAaY/qpiNUtoQxYxUonqvzyPBWu63FinhsvYO+0QnvEi7NI6JaxzvgYylwMAxye1yASB6H8AYt0RgvBk+l6P4i7Q32xvKFtdADTWOEXdx9yCTSdOym7OgTbGkYjIOx2/6NJSNBQ80PKb51hHV71V/cnHw1yMVl5uDtSowgqqZW0yuze0lgLefwsjQsf74Y0NP5hqWR4banIuO4irpOS11b4jV8H83qBvg13E4cBpnax8EquxZXqMhiK+qKZ9hY5uRxpWX77MV4uj6xYKiDVW96wFipJNIfZ9q01Y5ontrm84E2Mt0121PVLSU7y3eAMHGoWgQYF2Uy9I+hDCW+MaL4my5AjisC/YWWJJW4DzOx2IlHTkEC23uDiD2P/LgV77FC5RuGXsPfcwhvJda+Kyy+/kmIjRmXpipe8u33lEP6s0qpHNjdpgi5j94Ltz8ktT5VjcmMGzLez1Tdq3dwypWmbtifTbxb6rTaBnaDPdp8D/DFPtrbf9mdIoKvuWzmvOgd2iXPY16pwBd6VReumcjfM8+TZ8bwjX+8wsVe4LyIufIsG4N14fm8pKkCbB9U+LChm6VK94qlAbbkUZf2hP2odusFk7HqXnE9e5cgZ4czKuOAno+qgpiF4oDQKqSWkogsQUI+IBc07MDP0rzd8G4IuedIhgtx5g4HHMImoVZ8Z8afInEacUGq68IgUc7T/YSTzJvGXrLTKyeh/azKnPreRt7r2tuPOHQED8TVKkJljZUdJ+YV4j2bFjZe2/cQUe9HKLYdyBHp6kujwDxmahtO0cIdPlFoz7wUnCFCDJm3X1gV7pxT6jPWNHa0zuevC98V3UBUTmXAXByMIZXROpKmuLVmMZ2HzwoAkbW6Y4432hi2gszV0WqJBuZC42BkdNnwxxzl+dlT90yRwxZZLGAebzKmvE/GtAxIyrxS3wRFLUeodgu9flQuJxI/uEX1m/XFVmN408oqM2585PqEawFWnbLCMRcklidgmIljFciAw0QsZu6wpR5VvMzpgvDOIaedXPVS6302neK8sJ2x4cmDMMFAjDS4Uqo8dYEdi94Gwd7steJeAbjC5USwVWT9qtnuxAU0hSngcLudUZHqHPDDjOw67eqdotJd17680MhYhwZ0m0Ea30g2U7mnIsG3igcUUhK+zleT/JHKGvUfJlHFSNx9hywoqxyCfDCYhj8BV6fjiYVfe3nvETKT0atvjLPGtwRVV+liBzhz1jba0GryTugjtR7kHb9AALhCUQ1aAhJ6/wvVxC5xa2J/pZ1nJ2/i9LxzttKAYj+h91o913l5mlmr3VNC6stKlKAIXnRFchXN0ks0pDH8d4pKkost0UFzkZSHl/jcyqGmGpKZ4GjX6rc9Xgm9nqTm5g7f71NECWDeBq02xinFUge9K9JLSIoxycu+XlWU5c62oAVDMFbW9sAsm0LPKLpRO2FXaKCqbsFvdhfw8ygb23hh6yqZHIIQAZerNZ2h6gV+LZEoOS50sqO2FRFo7ma5sAJKlvKCZHq2yvJGBdtEmP8vuQEnxVVksVCafaYOJ9B4j2oYLcezqUH3bqU01wQKsPLoNfxlNJWKAnaJLTCPr38kvwaJqGQnKqeQMf5I6uCr8KSB+T262w17cTuLFJVIjBC9I4JGxYH+NpN3hRj9AxuO9ePb7889VxroyiRnY1mFcsM8Cy+ZoU6ANyliRLvc/DkeiNR2mHBh62/61F/GzNaIvnySVdItfBN0KgZzS62CPGBBQdT5uu9TOvEgVYVAkwQW6lsnIk+/vlfQJnEMFxfkx1QHLvHE7Q7+VO7y50z5Co0lkDxS1c+P5fkYQp2wZ/53x5zdiAhSSxdbQAyefUnYzKMRDytoSkqFZqJFQpJO+BxU2CvDoI4d2CtDP+SX5C3O79th/SbMd8F5OSXNo63zt4I2ak1Cd8bPwOuAC9hw0l98WmJydrM5SG1BsJ8c7PjFzzpeSNFlR+BdSk/Rcjlz0m4kep6HRd9hfm9LVqpERgnfv8ZazU7drMCgl1mWvdhW3K0hv1Ridn7idnQN70KOYNGO5PXv6tAoWduwUXxb3YQrvTMM/S/SMnmovX/66u9WI8mbjQRFFRucQtUdVQKsvxUipFqIEBkT4dQETe36gWzEsqBcVF7DYfsNkHJiCqiIk1qp78CG0msUNBKcknPa1uDgfKByUtE+379BQoz5wm76WZufWoiqLbANNrIAvUDWl11ctsokb9+D0CNZ9Tt5KtpajPNMbcux0G/tgvpu9/c8Qy4X6fox55Z8kX5fTOwoXsMzgxH3H/IjkInNf2GMAxYaTTp0sAHgO9EOF5zAJSp2DnxEC3RaYY+zYETXkyPtaCYclmGi4/DtA3pMGkNwj3pRju9CNALkob5jdfQu63Jdsyd8yVHbgrFTxYMkHysSgqSLHlxvXhXFowZuA3MtXS3LCuA54ZbEoJX7XsUlWB2m7slsnAiPBW+o+6kuR6FR9qbA/9vbuuQiZu62zXGJM/Mwz5wU75EY5rocyccFq0hB6cZBSZfYVLpooutdh/ms/Rq7VuwXitBtHa+5hBy3Q2zkBWuHwDbSNyWRJLLE5YGf5V7n5Glzt3oOcQlbZKimdRyDwIKLBfwo3XG3sc3u1EDzjSJiBgEnQfgyW3exDimv6gZB2PHVjHyFiX3NdH3GS9+6Eu3sli1cUHG3co3aeu8ZO4u2uOckUEQvraHElHcCb31bGTUmbXIGkg5shNukHvZXKiZefUHdeG8T0QPwsOLqQHDE3SG5ZcvbOaMsEYQJ3WH11tiL0bnyqW31cndCzLOtPPeOJ3KxuPA6UGQmmRZQcjPkMx2s2PGZT8FWFcgPuTX7p3A9xFZQG2Y02P9pujjdlqkNDvFFJf/UewW4oM7coGMPrA/dtsRuClyXiJo7OVF2bNboXXPnPMy1913ZLQE5UrBaXyjS/Sh2FYbdc8P+zADSdyqtNNiTOjK+mB22VN6sjAhw88eRJBSr6JdJ4h4q+bIDH7eeUvvWHceuY3c/EyKY2fItW3PSkwt774791fmqr63As+XAAOzLr1a1WWhvsW6ySHfE0OlSmvTybEnGCODdgJFsnXUTqp5CJtbXO8hm8gtdq9scD2zwMu6qYLiXklsbFiu2qJNWHOWmGuK4rduPrBzwdgvKKa1yWDobP1ZYAkiUhsegDrhE53iLAsww6JZdOyr3nlQkTHUWInvQKhHT0r/UdvX/bqSMGf5stSo4OmE17T8fp+ZzgYA2hBGVplpHmWuzT7F0D67op4TDbuffgMtVh+mh7tPLL4qKtoiw8KCP+lBBFRQfaXV8KgZRrPsLVAE2mW6h7Rzmxg6XHd0zwfmFKPDgyFZx6zLxFFB++dxX4bPorqGUDBLScKYHniv//roMHDG6vy3HG32TH6fo+GPACBRPBu8Fpz/bODnP9jdKXisC/wmWw3BGlp5ayID6eR3SIsPd97dQUCp7GnfDtHQ7mjGEyhdPDj3zaRjLLiBtses21CMq4xATuAQvL9Tdmj4GBN7yPebcziQzJGwh2SdiZEZfaAMdnlrn0E1ndl5QuOh9HXurTMa7UqoRzl8e8VtlQeNWKvjrm4mOfiV/cTYami1gZIZRbp/fWo92GE2/KZOrRdUrGk0Wlr+wJx99KawMnsoR+h8iUvoxWuLomx1PB/KKLmv4Fb+8rUnfnB16JsOlxbe+9BYG1pyy4jg61h4Awra/yT3dSR1J3masI+EKnLH2vJnuG5s2Bh0FszgdJxe2ZhvNopSI12rj/OB+OdyK0+aHMivLa6tdM1J1Bd3nU9r5S6w3N8WMn5WdmQ8ApWZhw1TJQqPTZqFExZdJ3GpI39D+FD1B7+ziybdNOEVgi29uwaSESCXD4ch/kmsm+B5vVMU8Jl7r1Q9lyJrc8ua0khAffHkvR2uicPLkqS+Fpy5uDIOmLRRDOBdm/cd3PuoY9GaqcEr1xzjM/g4GGl7XbwNLStUY1j5NL+WDPYtJzjHeSGZXTXfsQ+XAyGkKlsat12xERgn9SV2kXVbFgRXdtEPKAy15n4Cl1rxUkCNyDwbE2rmXuc5aa8Fk9hOMwt0GUfCIPL8zngH5HdVNK/tZcPy3KC4kWKDD9lPMX+rcw2iavFuqBsQi6BX2JOVkOo3vKMUiWzbLO9/YSMf4X16v5e9Mpk1gITjTCzdzTbGeeB6FxbK46HZbk8KXIMXCE92wrSQLieGXdyALZco5PTUyF4w/EitrjK1LcGg87t/SaftTc1JUF0G1k5QJQl6MfQ5Y1NVbITNWgsri0+f8ADUquCi0SvQek6+uyPQNwuMJ6iSXClxQLvQcNDxAp0rhQ7hxyGzG8nOj5bSceUnv8Iki8lnVl2bhT7X9yTGqLWS7G97O8knFTu+jMpm3Jwz/15v/NjxYqU0+KOJnidtbNkjRJIgO1clgY9DWs5tKNfYDsENnntH0cPITiUlpJFat0a/B2nKnFt0Y7kYQgi7dMYMrNpP6RNmDb+ZxBTuxf4fGkpWrMPOdUTTYgiqjTaj9JmdZy6Uh/CjaSpqsVuMjuJ+sfIFFv9snT9/SOH74vRK8IPmpCl4kUySOZQQyOI8mW2OjXcIiI13rajka99rUQ+wESDXMrIxeo6wtiUqZ37j2OvZKfNdQxK0KTi6EAiTOjODOR7saSbyhLSiBl0128xiqjdEslDAUR6P6Uu2eF8/9PkYF3LGmkx65lovMAeErldGYoCGL4MviwhvCbfzk963DkRGqnWxrOMHI1I2twgIXnM3sd+yXew6JV7gcVfwcKvQtFaSVkVElO0DZOQ9g7u/CfvKOxsfsZRcI7MsI2J909S6/lEO2EBEpl85CDSRmz3L1grgeLWwKH9lhIPufEd4GA9zhZqOtLHY4gPIGJQEwq/e1JlVMmR80QhXHLKxaD57+iJnd3aWy7ed4mZ3d2WYaXTOyvQFdomF+7uLcX+FkpyxiNA6jh51QEAE8JJuqPeI4+LY00gbYFchkmcaPjN0tOZZOvm62NQ90ZxiHYSWQKoTx1EWtA8NPLY5Jjaslb4kE+xJwBKRW5YJLEMMWrh6qkkxYFYXQWgp+wGucHGoH7xzfppJy70GUXGH/HKYFnD0ruixaVCiqlwgBn8MrzubduFPPXxfB/O4l5QCvj2c/qA82FWB5t6A5huRvP6oIsOwJPNwVHgj748tziwiO44M7lcaKohOLnkOIagwfqIS72X2TOC1wzIMga+nsqE+NhcXpUUgQxY0wmpcvYMt1CMCOiXetBOzRyx3b6MLkv+QBKExt/wPu5G2rNmgBbxcWwSVHz2UNovTqkmEdKFCHEfCrAMNodRhVdrWJ3prtYoK2VhjrU2dvkrVRk4LdqXEXCXUmzuaO2IeHS2h6o1vsGvLV3dUz32JNtT8IpIlXD8M3r2JsITlkh7SMC6YCBheqd+JF5y2QBqT4oAlF8SkY2keOnZpFDFIUQZFIaasldYoufAHRyMFUpmAwW7ZyzHyubsy2O4CciQmjKAvV4AHNhsm+TlC7V1rj8nviGruAe4XcgnQjHQt7mpH6cYrC2RxjoKKkK89gS03Nn83yf6zExxxUf8BOPKEftUr4WNgdEWbaVbVnjPDUFz0Gr+D6ZqqkOtZRZUt6jcJOaPUxJNnQo4aQNsBkOWBy+abvP96AH40HjhVVQ33qJTlmqLF5s8pdLOH1U0vBk38spYric55fWLm4+BZInsU/rbygPPpkJJXpSxyS+O+K/dYjurtyG9OWXgq3i3F21xHqnt2EE0NG+epa0xKFQB3jEDNL9NFNDlYG5VhZK4+mZob7TendUpUvYC6Ilb+YUwJBrA1WG6tpPTgxQCwK1jRYbi3MggsRbLOwrL0gghopBFil5ZfVfnrqX+FHlh8RF2XzoUXxiS4GwOwKpDNqmVNvbixVAZ4cJVL8KfdP1Wvx/A8LDO7qvxyyZ9hGHlymCcs3G00RwddyHCmNr9Nb3J8Ae3R6rrCPs88jbVlNonuqjAWjXPHFA7jiUqaE4xQ34wnmkDl9euspVKC6AxQ+cTGuqkovBZz82waM4Q6X2GmXfQb0kk+wPuueF7IRZMdfRk4A71poV+2RZ/e4Ux+P6YRob9tnSz/yY6xWuvrhdxaUUpQOBnm9aBHNFD+S7BS64Ntsbf3Sd7mSggCVRzjJFm59+duI2LqmTKBhhJKp4NjGVFFbx9fLZOIF5OVEnOlGl0sMpy1Fj0KmkwfakZPy8o2TbnZOXckxT+/1mUwUPb52LZDUoTAjGY40LumfWsKj58nB2M8OhMmqiGRin7u+LtVk3xcR8w+LFWvhhhjLHZvz3eIap5ZY+wi3PkM+Ejh+8pOX7RoDqgakWqMPKiHCp4xa1SvWAJRXC0ebMKZZ3d7NILwyQ4Kb0Lhd9RMLjxl8oc+Xd2Zjte/B4t1XgLw85LbcCJ53BgpnRpoGzFdRjft912Wu/3vuojvmq4aH/pYNPVu7UzZcI1XBj3w5tM6K3U5tMTepYMD5GLKCurCLgY0UFxRc7BVM4/G+rzOZdy92mb/r50I53mpEgJ7dhwutFU+6kv1oumpj2/nKjO2uOF03EqMBLs1iyjatCobPKcvUcnDegfS7D4U27El/6pCzZ68zOscfgMbxbRt1zyj8xjNolYf10JSrsMmAzgX32yPit00jPED/MlRrba+AU3q23/LgyWa7O/93HXrIm5hsr3NbEzEY1d8SE8A2OvnrvQcCDtYiPYFjrQM9UD9Gv9i9Mw06/9kir8MC73ghsX9cOh2SiyGQ/SVLM+enXtMfUKJqVYE3Qp1e1RzrgVje1ikESpIn9KR2Ija5joWQzvCqHn2o9zUYNgYhDMdvEApKIxfxhSwiGByNMdk2YpMHSRcIiVKIBcoSdWyNTgSlQhL1gjzJ47fiidDi2c/9paneXNI2X88IUbYqBR0uOdZjcaj1cTVkm1WA8Ps42CTt2Vbxj3CEzq/CotTfDxsXvQCIBTbCBFJRhoc07Kqx0FPO41XPP3M3C2SY17ZVjrhT2zfcsmxV961eqVfT+3IVw00OE25lRr2tlgLUJDRo4YjaWBXl8zV8rMsTdt3GFNWC8gm9/kkFCpsFQpcpE1Un16pFkIl5bJGRFMV26hlraReOsmN4THYFea0i+vkNe23bcPPZTlmKvqwbI6bQTKZK50x9pvCeHcMfQgeUe9Wg8bpUIBI4AwZ7T1KGWH1P08+6F56eB0PWmOac/Ptq0TDOwpTddSnQrfIpAgYzqRu7vQR6y1BlxaU6zcQgejN7nPOB5mA73u0uKT85TtkwBbZz7pe/Oupog4mnM9ABvxzssZCXHjkYPv0DuB13D0q5x4tGHUjLhrmqNx690EFSSkdNbHqpjBpw17Nup4QBIegjhrbW30oVoAU+wbRW9FbeZqM/XH3m3rxvTe+l4oC3143MK1h0EDLsWI2ezMpBGT8c43P8f+4AINMwtGhQvi4FTQ3C6LALlw2ITqnp7ZjVe8g72xFhCQ7qzBuV0uGxu45zk20ZfvjOPnZmm3ZYnfeRoh9KbA0LNQeX1vBHtYmk2/oyxb1cJ7S9rVRB+N9fDsa8I2++w7gJ37iPOKd/TkDTeJdp2lRQyrAZHQqGta5tI/azkaT9C8+9PTXXJN0Na9i4+hKWjNAQ4y5NWgfIIf1vgSRc2C3Xz/AzGF9z27WD+jTCfKOcW94SqAkWHdb3kMJuhLjPBZ3RRsN4hhuDdvKIuna1617LpwPwkZLDLheq8zdWXEmaJS2T70nB6nxXmDD1thRX9/HV7FivdpXe8QbWmPM7LMn1y3UA+xKiDz2TA5ov/mwaz60gdPazOqRdFj6JpX7bUHIe/x7sCHgoZqUaCEGKC1m2jgIq/mNermGq07yOcEXuxSVS0F+ryKP7uI2Jlz+VDtx+zFziRuuxX7ihulUP0aPyOQYBQyZZ0KDVtNqxEjcsai+8qgN2N2tfTurmyl2OMJTSSIfYD9m6d9oYbT5X4Ttzi9oLtPaIVlzXQ4bJg3pK4abYf3iis0DvcCikCkUuF93E58QbC9Wk9vqtF3/p9SgCu+JtVxjQfmkJW2nlnjMcuHjxhKiNfDBp9aK1DSXyvItfoT4VeB5QqSiR3NGwFvybEthQaWj2X8Ra4Cqi5xsJT8GJq0blKh2XuVWHmfKU//hTTulNjGZX1PMN1FaU9cWcTTkdp988TDyI6Um5cecvfU7y4aL5aLkOwqR00sA5SZ9d0Er8YncH0JBgF4cUbJpMirLNXmASJyFZ9rvGywq8Jygu3gQgSeYL/39am9fb3eclLLXa7KouO9ANDmDtErQbhh9omUP82WZM9Nvzl3CLR1RoOgc/SGuy8POgMaC5JcpI9OKFcjR97lhiY1yhHPKNCQ2iak7kdlE4KiiLlGd+U6Ak4BxJr1fCyV5ckVv9dwlJbIafzGtbDhRp4HwjohpLKdzaYUiAJ4HmU3cXpNVMLZ9+FI69mXlPRyOTDuM7E0kHCa7QCO+0s9ZqzUrfPfpQTJo8IfkTKDg1y9l8JOyjcBY1EDYaEVf++Qb2jqNmekZRP/dGQq+4TKD8aR328kyQFrudwZnMl1VkURkSiruBAjWbSHSKdc21ZRbIdZHrBobCEH/vO6hicsXjDa5UzQLr+xxSEpFGxsD+Ori4WoI0W4oCs3VzYWiIORZftaV/8kChErjjAyOnftGAx5qUwO9Bt66oTujO0S8C7BRyG3oHDHgu8T8jez8KdX1KTMn4OQLPAGSFZ+h4e09nnlxJeWKblOS0ZMtVPV6buCxUv0sqwFPO8+KYvOcxnwsujYGTUnka00LcWn0SuoDUUkFKS3RBhnrpEVoKzX7PpPPWpE305aoxipBiLiigVNIO7I+zGgVgz6mhb4v3EW3fQNEVcxbLMpm9z7jvnW6+7koNX/4uGUllNAL4OmVDjDzkf4kR8ldcWNTLSox6oNdkdnl7nMT2Ro6jhSklg/6rt6+7H5MKAo+c8xUktgcwhwtglA29zsAyysBTE4cTHXE7aDlniPiCfcFoKG8yvrD6h9ft1JC8PMnK4nyVO1dAH60plDH/6i5RVJz4G8Vf+NMLDSuJeEOTTQb5r1LvR/izNb3BeJL/VvKQGhiEnZI2od4PNYbbKIhmw0UagiT4UPFZVDQzlJ5jg1zV5CO1z1x7mP9ALg74eVP8+g6dvJJ3XUJQtGZC2F8ziGlBL/Lk6cDJ07G9TWRBL22iJ8kgre2IRvumD1qYyiALFCgzUHg7lIeXP1QWlOz4M/LTm3rX2M1Ip6c96FZauOe9GcxOcn0Patb6hoczuVrKyw8N2ICfjWAuMDSNWw3KMGFW6CPLNr4xUVN1qzvsr6KvDFVpjXxIYpCZlDx5q8T6DJp/SaWuRdCI4b96n7C5tocb9WmcfhsA2biq593TGVeAJIDYDptVPLaP/ub8oZ9SivUzmyD2DE/k/h9wRWoDVPUK6bFsFwhrco65KzTHmlm5LCf2ZJlY/R9rU6vyWeRbC5HBzCBrUh5jItDnfxC36d49Co+dvnq+vnkPFKZN9LoDhLkvq4tI0Xgwnx5f10CSOkKl1gG8xdpg5zA5TXV1DyIOuxWOLboj1FNtq5MAx6psUdwQXrvZupqdvu/62R1o1j5zzDE/p/oZIvDuxQswgO6hChKzcwNlhJvFYuejou8MfmSI/rl9vbDiHlLT05ym6ql6VE9+CQeLH9VLjselHOg3YV9tmI8kcvloHvMIBpBxaoeiHh572uXnOnH+0/eHZDHLhslWLSJ/moZRgk08p6tYDb6NoxP6JrzpYm0HCb0F4MdxYc1BtUQgJh3oNXcmdXpT2Eo7korp+IzhYUspjgUQ/I22GmfLfKsM5T1ZzWKxPd3f4vlZYX4CKalODXP9CgY8e9l5bar8/tPVFjHVaITvCoMGEIENTwUEPBpqlLh5hU8G4AQKQKZDP+YBrrsdGtAd3zXyxK5wB7RoV8ghz1erqICbO3/R8ERNPxREszpOO69ozG2+xbJgvrnQSX+u1Mzdh+yF72+gvu/XyH/gQDN9hC29zL+bq9qxfSgenyrOfcC6GDiYL89B3sAIBccel+52IuqOgK1nLYx+2qIFj45cN67UnNl0GpQwe3h6zacLTlovw3ElCQIju/hQ10CS1UyXhoS1aozklXDJoNoZlYyfYvP4kET95NnVXJzxb5APUEnMKnmnWzPKp+ad11ykVeiJSjg8iUjzE7rujcH+eWaMOs4KxhbRATJgqtvhOiuuYvBo3pafEd9etf/K39cEiZMvqEQn2Mf1RDhsTjWO/oVPA+IMVrX9nRG700717buij8xQ+/EbTo8ls/hDJbkxWwClhVuIKTOjRHoPUMEg1kAJxtv8Z9eMW8L8elhf8NGdyPln/qy0jeya1Bvi3GW65BvxciQkNtbj14IZJFJritdrNd0xnX0OFG+PMmppJe7CQmH9r1Df6KQlHxsTDSi05WpDDkUX3KPPGJ06R8ycx1iS8P6j7lFU0JaKpFhHIPeE+OHcWF/ut1cjHStYGQLMVe1bLBHq/eDPjfWjlauBfgiZvlZfm6zHVU9fLCGLO6Dr/PWp9Ep0SjR6t1iVJ9WJBEpwtSrdNfr4+Gl2KRUVwSAb73YqdfrjUrxzA2ShkSDSPCuSTml7W4IMzna4T1nr4PhPu7pqRMTGhxH7uq4rb7APeJST4pyReM8Yl645615ViGv2i7SjEWmaDFD+Re0yfM72wR6xc7YZ0kkgxa1AsmbrsEsinfSDd+YSzClQchBbnPCPseWPZIDEHdyqawvqeA5MnD5PGfcLIM8jFEQqTlOSoqm434Exvkhul3lBZ16vgkD4HfE0cLt3bRsQ/UxFX2lNPn7ayhvDSDNoXs6bFRjHE2LKjh+G6CQqos+efAaK6lodOL0lAVv3d16VhHVV0OjrRUzSj63hyQaBCC88K+lVS9gIVDt6YiyJxd6KxyhstatT5e3lRL+LVxZjVVMKjnfM34nvN4BSaBaCJokKHbPlyumwJHxR4GzI/0gg6JjphFCR28ONxyoyxXh+mgAxQ47LQfEbjcg7qkLc0D6K3kah/rZF3HmFtFB0hyjI3YiWI1kdTYCrxdgT9skC1vIJB9q68OPuX6ITq8EIjm6zpzRuIdguwTVrj3BICGmJNqm9H8lBBT69VDiNJq7pz/wniAsgK375t6/pDun3jp3/FdINKiaJPdOT1N3+yeJBRK/YhKyZrh8eKyUfdrRpJ8uiPdm6rHeCdL28IjMFicTId0W+ICx673Ab93w2vx0727Nz4bpjrfTribv9kvfNOFeftlnZUPeaXjhQnH02WHHIChdOur1HxneDX/rjSNYmpVzoeQH8f+cZ8EbnaTTM5wK+pn30i6TDZEoP4gnPbrQMEcjT/WqeunQwsSFoS0adzaI+L3H5uWCfnqpJLe9BPEyN9Y01dTQTV0XzCfwn9koeLvfXDbCLC/8tMYSa8aukDPhHUtGdaw7NOybvOBtqIFL3KB9vUDQwJxKAzg3ubNWaZ50NsyxxD7FCN/ayfbaO+IDM9rNckkc9pxJszgqBWY8ALhjnxdQxaMY1A8W4stEaJ3Q37M1gNpmomSQvagQMoVWuqFG8gNPWkNGY1o8InmepmAvVtm7BeiQR6Wvr0O1a2RoMhqfKKvzTaBKII6U9RzDkekGVaVruEAE411YDZ0eUVaFJLgA== diff --git a/src/test/utils/testUtils.ts b/src/test/utils/testUtils.ts index b922fc9c61c..a8410f8ba40 100644 --- a/src/test/utils/testUtils.ts +++ b/src/test/utils/testUtils.ts @@ -21,3 +21,11 @@ export function mockI18next() { export function arrayOfRange(start: integer, end: integer) { return Array.from({ length: end - start }, (_v, k) => k + start); } + +/** + * Utility to get the API base URL from the environment variable (or the default/fallback). + * @returns the API base URL + */ +export function getApiBaseUrl() { + return import.meta.env.VITE_SERVER_URL ?? "http://localhost:8001"; +} diff --git a/src/test/vitest.setup.ts b/src/test/vitest.setup.ts index 3bb5c240d94..0b83d112522 100644 --- a/src/test/vitest.setup.ts +++ b/src/test/vitest.setup.ts @@ -2,17 +2,20 @@ import "vitest-canvas-mock"; import { initLoggedInUser } from "#app/account"; import { initAbilities } from "#app/data/ability"; -import { initBiomes } from "#app/data/biomes"; -import { initEggMoves } from "#app/data/egg-moves"; +import { initBiomes } from "#app/data/balance/biomes"; +import { initEggMoves } from "#app/data/balance/egg-moves"; +import { initPokemonPrevolutions } from "#app/data/balance/pokemon-evolutions"; import { initMoves } from "#app/data/move"; -import { initPokemonPrevolutions } from "#app/data/pokemon-evolutions"; +import { initMysteryEncounters } from "#app/data/mystery-encounters/mystery-encounters"; import { initPokemonForms } from "#app/data/pokemon-forms"; import { initSpecies } from "#app/data/pokemon-species"; import { initAchievements } from "#app/system/achv"; import { initVouchers } from "#app/system/voucher"; import { initStatsKeys } from "#app/ui/game-stats-ui-handler"; -import { initMysteryEncounters } from "#app/data/mystery-encounters/mystery-encounters"; -import { beforeAll, vi } from "vitest"; +import { afterAll, beforeAll, vi } from "vitest"; + +/** Set the timezone to UTC for tests. */ +process.env.TZ = "UTC"; /** Mock the override import to always return default values, ignoring any custom overrides. */ vi.mock("#app/overrides", async (importOriginal) => { @@ -20,10 +23,44 @@ vi.mock("#app/overrides", async (importOriginal) => { return { default: defaultOverrides, - defaultOverrides + defaultOverrides, } satisfies typeof import("#app/overrides"); }); +/** + * This is a hacky way to mock the i18n backend requests (with the help of {@link https://mswjs.io/ | msw}). + * The reason to put it inside of a mock is to elevate it. + * This is necessary because how our code is structured. + * Do NOT try to put any of this code into external functions, it won't work as it's elevated during runtime. + */ +vi.mock("i18next", async (importOriginal) => { + console.log("Mocking i18next"); + const { setupServer } = await import("msw/node"); + const { http, HttpResponse } = await import("msw"); + + global.server = setupServer( + http.get("/locales/en/*", async (req) => { + const filename = req.params[0]; + + try { + const json = await import(`../../public/locales/en/${req.params[0]}`); + console.log("Loaded locale", filename); + return HttpResponse.json(json); + } catch (err) { + console.log(`Failed to load locale ${filename}!`, err); + return HttpResponse.json({}); + } + }), + http.get("https://fonts.googleapis.com/*", () => { + return HttpResponse.text(""); + }), + ); + global.server.listen({ onUnhandledRequest: "error" }); + console.log("i18n MSW server listening!"); + + return await importOriginal(); +}); + initVouchers(); initAchievements(); initStatsKeys(); @@ -44,6 +81,11 @@ beforeAll(() => { writable: true, value: { add: () => {}, - } + }, }); }); + +afterAll(() => { + global.server.close(); + console.log("Closing i18n MSW server!"); +}); diff --git a/src/timed-event-manager.ts b/src/timed-event-manager.ts index 9bfa3bdf54a..3b2b3619397 100644 --- a/src/timed-event-manager.ts +++ b/src/timed-event-manager.ts @@ -1,16 +1,17 @@ import BattleScene from "#app/battle-scene"; import { TextStyle, addTextObject } from "#app/ui/text"; +import { nil } from "#app/utils"; import i18next from "i18next"; export enum EventType { SHINY, - GENERIC + NO_TIMER_DISPLAY } interface EventBanner { bannerKey?: string; - xPosition?: number; - yPosition?: number; + xOffset?: number; + yOffset?: number; scale?: number; availableLangs?: string[]; } @@ -19,21 +20,22 @@ interface TimedEvent extends EventBanner { name: string; eventType: EventType; shinyMultiplier?: number; + friendshipMultiplier?: number; startDate: Date; endDate: Date; } const timedEvents: TimedEvent[] = [ { - name: "Egg Skip Update", - eventType: EventType.GENERIC, - startDate: new Date(Date.UTC(2024, 8, 8, 0)), - endDate: new Date(Date.UTC(2024, 8, 12, 0)), - bannerKey: "egg-update", - xPosition: 19, - yPosition: 120, + name: "Halloween Update", + eventType: EventType.SHINY, + shinyMultiplier: 2, + friendshipMultiplier: 2, + startDate: new Date(Date.UTC(2024, 9, 27, 0)), + endDate: new Date(Date.UTC(2024, 10, 4, 0)), + bannerKey: "halloween2024-event-", scale: 0.21, - availableLangs: ["en", "de", "it", "fr", "ja", "ko", "es", "pt-BR", "zh-CN"] + availableLangs: [ "en", "de", "it", "fr", "ja", "ko", "es-ES", "pt-BR", "zh-CN" ] } ]; @@ -60,61 +62,92 @@ export class TimedEventManager { return activeEvents.length > 0; } + getFriendshipMultiplier(): number { + let multiplier = 1; + const friendshipEvents = timedEvents.filter((te) => this.isActive(te)); + friendshipEvents.forEach((fe) => { + multiplier *= fe.friendshipMultiplier ?? 1; + }); + + return multiplier; + } + getShinyMultiplier(): number { let multiplier = 1; const shinyEvents = timedEvents.filter((te) => te.eventType === EventType.SHINY && this.isActive(te)); shinyEvents.forEach((se) => { - multiplier *= se.shinyMultiplier!; // TODO: is this bang correct? + multiplier *= se.shinyMultiplier ?? 1; }); return multiplier; } getEventBannerFilename(): string { - return timedEvents.find((te: TimedEvent) => this.isActive(te))?.bannerKey!; // TODO: is this bang correct? + return timedEvents.find((te: TimedEvent) => this.isActive(te))?.bannerKey ?? ""; } } export class TimedEventDisplay extends Phaser.GameObjects.Container { - private event: TimedEvent | null; + private event: TimedEvent | nil; private eventTimerText: Phaser.GameObjects.Text; private banner: Phaser.GameObjects.Image; - private bannerShadow: Phaser.GameObjects.Rectangle; + private availableWidth: number; private eventTimer: NodeJS.Timeout | null; constructor(scene: BattleScene, x: number, y: number, event?: TimedEvent) { super(scene, x, y); - this.event = event!; // TODO: is this bang correct? + this.availableWidth = scene.scaledCanvas.width; + this.event = event; this.setVisible(false); } + /** + * Set the width that can be used to display the event timer and banner. By default + * these elements get centered horizontally in that space, in the bottom left of the screen + */ + setWidth(width: number) { + if (width !== this.availableWidth) { + this.availableWidth = width; + const xPosition = this.availableWidth / 2 + (this.event?.xOffset ?? 0); + if (this.banner) { + this.banner.x = xPosition; + } + if (this.eventTimerText) { + this.eventTimerText.x = xPosition; + } + } + } + setup() { const lang = i18next.resolvedLanguage; if (this.event && this.event.bannerKey) { let key = this.event.bannerKey; if (lang && this.event.availableLangs && this.event.availableLangs.length > 0) { if (this.event.availableLangs.includes(lang)) { - key += "_"+lang; + key += lang; } else { - key += "_en"; + key += "en"; } } console.log(this.event.bannerKey); - this.banner = new Phaser.GameObjects.Image(this.scene, this.event.xPosition ?? 29, this.event.yPosition ?? 64, key); + const padding = 5; + const showTimer = this.event.eventType !== EventType.NO_TIMER_DISPLAY; + const yPosition = this.scene.game.canvas.height / 6 - padding - (showTimer ? 10 : 0) - (this.event.yOffset ?? 0); + this.banner = new Phaser.GameObjects.Image(this.scene, this.availableWidth / 2, yPosition - padding, key); this.banner.setName("img-event-banner"); - this.banner.setOrigin(0.08, -0.35); + this.banner.setOrigin(0.5, 1); this.banner.setScale(this.event.scale ?? 0.18); - if (this.event.eventType !== EventType.GENERIC) { + if (showTimer) { this.eventTimerText = addTextObject( this.scene, - this.banner.x + 8, - this.banner.y + 100, + this.banner.x, + this.banner.y + 2, this.timeToGo(this.event.endDate), TextStyle.WINDOW ); this.eventTimerText.setName("text-event-timer"); this.eventTimerText.setScale(0.15); - this.eventTimerText.setOrigin(0, 0); + this.eventTimerText.setOrigin(0.5, 0); this.add(this.eventTimerText); } @@ -141,7 +174,7 @@ export class TimedEventDisplay extends Phaser.GameObjects.Container { // Utility to add leading zero function z(n) { - return (n < 10? "0" : "") + n; + return (n < 10 ? "0" : "") + n; } const now = new Date(); let diff = Math.abs(date.getTime() - now.getTime()); @@ -150,17 +183,17 @@ export class TimedEventDisplay extends Phaser.GameObjects.Container { diff = Math.abs(diff); // Get time components - const days = diff/8.64e7 | 0; - const hours = diff%8.64e7 / 3.6e6 | 0; - const mins = diff%3.6e6 / 6e4 | 0; - const secs = Math.round(diff%6e4 / 1e3); + const days = diff / 8.64e7 | 0; + const hours = diff % 8.64e7 / 3.6e6 | 0; + const mins = diff % 3.6e6 / 6e4 | 0; + const secs = Math.round(diff % 6e4 / 1e3); // Return formatted string - return "Event Ends in : " + z(days) + "d " + z(hours) + "h " + z(mins) + "m " + z(secs)+ "s"; + return "Event Ends in : " + z(days) + "d " + z(hours) + "h " + z(mins) + "m " + z(secs) + "s"; } updateCountdown() { - if (this.event && this.event.eventType !== EventType.GENERIC) { + if (this.event && this.event.eventType !== EventType.NO_TIMER_DISPLAY) { this.eventTimerText.setText(this.timeToGo(this.event.endDate)); } } diff --git a/src/touch-controls.ts b/src/touch-controls.ts index 53df545e27f..93032ce59fe 100644 --- a/src/touch-controls.ts +++ b/src/touch-controls.ts @@ -1,4 +1,4 @@ -import {Button} from "#enums/buttons"; +import { Button } from "#enums/buttons"; import EventEmitter = Phaser.Events.EventEmitter; import BattleScene from "./battle-scene"; @@ -122,20 +122,20 @@ export default class TouchControl { const button = Button[key]; switch (eventType) { - case "keydown": - this.events.emit("input_down", { - controller_type: "keyboard", - button: button, - isTouch: true - }); - break; - case "keyup": - this.events.emit("input_up", { - controller_type: "keyboard", - button: button, - isTouch: true - }); - break; + case "keydown": + this.events.emit("input_down", { + controller_type: "keyboard", + button: button, + isTouch: true + }); + break; + case "keyup": + this.events.emit("input_up", { + controller_type: "keyboard", + button: button, + isTouch: true + }); + break; } return true; } @@ -206,7 +206,7 @@ export function isMobile(): boolean { let ret = false; (function (a) { // Check the user agent string against a regex for mobile devices - if (/(android|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows ce|xda|xiino|android|ipad|playbook|silk/i.test(a)||/1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-/i.test(a.substr(0, 4))) { + if (/(android|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows ce|xda|xiino|android|ipad|playbook|silk/i.test(a) || /1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-/i.test(a.substr(0, 4))) { ret = true; } })(navigator.userAgent || navigator.vendor || window["opera"]); diff --git a/src/tutorial.ts b/src/tutorial.ts index 18d8291d227..3934ffee57f 100644 --- a/src/tutorial.ts +++ b/src/tutorial.ts @@ -74,11 +74,11 @@ const tutorialHandlers = { * @returns a promise with result `true` if the tutorial was run and finished, `false` otherwise */ export async function handleTutorial(scene: BattleScene, tutorial: Tutorial): Promise { - if (!scene.enableTutorials && !Overrides.BYPASS_TUTORIAL_SKIP) { + if (!scene.enableTutorials && !Overrides.BYPASS_TUTORIAL_SKIP_OVERRIDE) { return false; } - if (scene.gameData.getTutorialFlags()[tutorial] && !Overrides.BYPASS_TUTORIAL_SKIP) { + if (scene.gameData.getTutorialFlags()[tutorial] && !Overrides.BYPASS_TUTORIAL_SKIP_OVERRIDE) { return false; } diff --git a/src/ui-inputs.ts b/src/ui-inputs.ts index 5860702a15b..92b1653df3d 100644 --- a/src/ui-inputs.ts +++ b/src/ui-inputs.ts @@ -1,11 +1,11 @@ import Phaser from "phaser"; -import {Mode} from "./ui/ui"; -import {InputsController} from "./inputs-controller"; +import { Mode } from "./ui/ui"; +import { InputsController } from "./inputs-controller"; import MessageUiHandler from "./ui/message-ui-handler"; import StarterSelectUiHandler from "./ui/starter-select-ui-handler"; -import {Setting, SettingKeys, settingIndex} from "./system/settings/settings"; +import { Setting, SettingKeys, settingIndex } from "./system/settings/settings"; import SettingsUiHandler from "./ui/settings/settings-ui-handler"; -import {Button} from "#enums/buttons"; +import { Button } from "#enums/buttons"; import SettingsGamepadUiHandler from "./ui/settings/settings-gamepad-ui-handler"; import SettingsKeyboardUiHandler from "#app/ui/settings/settings-keyboard-ui-handler"; import BattleScene from "./battle-scene"; @@ -142,7 +142,7 @@ export class UiInputs { } buttonGoToFilter(button: Button): void { - const whitelist = [StarterSelectUiHandler]; + const whitelist = [ StarterSelectUiHandler ]; const uiHandler = this.scene.ui?.getHandler(); if (whitelist.some(handler => uiHandler instanceof handler)) { this.scene.ui.processInput(button); @@ -168,29 +168,31 @@ export class UiInputs { return; } switch (this.scene.ui?.getMode()) { - case Mode.MESSAGE: - if (!(this.scene.ui.getHandler() as MessageUiHandler).pendingPrompt) { + case Mode.MESSAGE: + const messageHandler = this.scene.ui.getHandler(); + if (!messageHandler.pendingPrompt || messageHandler.isTextAnimationInProgress()) { + return; + } + case Mode.TITLE: + case Mode.COMMAND: + case Mode.MODIFIER_SELECT: + case Mode.MYSTERY_ENCOUNTER: + this.scene.ui.setOverlayMode(Mode.MENU); + break; + case Mode.STARTER_SELECT: + this.buttonTouch(); + break; + case Mode.MENU: + this.scene.ui.revertMode(); + this.scene.playSound("ui/select"); + break; + default: return; - } - case Mode.TITLE: - case Mode.COMMAND: - case Mode.MODIFIER_SELECT: - this.scene.ui.setOverlayMode(Mode.MENU); - break; - case Mode.STARTER_SELECT: - this.buttonTouch(); - break; - case Mode.MENU: - this.scene.ui.revertMode(); - this.scene.playSound("ui/select"); - break; - default: - return; } } buttonCycleOption(button: Button): void { - const whitelist = [StarterSelectUiHandler, SettingsUiHandler, RunInfoUiHandler, SettingsDisplayUiHandler, SettingsAudioUiHandler, SettingsGamepadUiHandler, SettingsKeyboardUiHandler]; + const whitelist = [ StarterSelectUiHandler, SettingsUiHandler, RunInfoUiHandler, SettingsDisplayUiHandler, SettingsAudioUiHandler, SettingsGamepadUiHandler, SettingsKeyboardUiHandler ]; const uiHandler = this.scene.ui?.getHandler(); if (whitelist.some(handler => uiHandler instanceof handler)) { this.scene.ui.processInput(button); diff --git a/src/ui/abstact-option-select-ui-handler.ts b/src/ui/abstact-option-select-ui-handler.ts index c6abecda4c0..01fc5b00014 100644 --- a/src/ui/abstact-option-select-ui-handler.ts +++ b/src/ui/abstact-option-select-ui-handler.ts @@ -5,7 +5,7 @@ import UiHandler from "./ui-handler"; import { addWindow } from "./ui-theme"; import * as Utils from "../utils"; import { argbFromRgba } from "@material/material-color-utilities"; -import {Button} from "#enums/buttons"; +import { Button } from "#enums/buttons"; export interface OptionSelectConfig { xOffset?: number; @@ -116,7 +116,7 @@ export default abstract class AbstractOptionSelectUiHandler extends UiHandler { this.optionSelectBg.height = this.getWindowHeight(); - this.optionSelectText.setPositionRelative(this.optionSelectBg, 12+24*this.scale, 2+42*this.scale); + this.optionSelectText.setPositionRelative(this.optionSelectBg, 12 + 24 * this.scale, 2 + 42 * this.scale); options.forEach((option: OptionSelectItem, i: integer) => { if (option.item) { @@ -165,6 +165,7 @@ export default abstract class AbstractOptionSelectUiHandler extends UiHandler { if (this.config.delay) { this.blockInput = true; this.optionSelectText.setAlpha(0.5); + this.cursorObj?.setAlpha(0.8); this.scene.time.delayedCall(Utils.fixedInt(this.config.delay), () => this.unblockInput()); } @@ -221,20 +222,20 @@ export default abstract class AbstractOptionSelectUiHandler extends UiHandler { } } else { switch (button) { - case Button.UP: - if (this.cursor) { - success = this.setCursor(this.cursor - 1); - } else if (this.cursor === 0) { - success = this.setCursor(options.length -1); - } - break; - case Button.DOWN: - if (this.cursor < options.length - 1) { - success = this.setCursor(this.cursor + 1); - } else { - success = this.setCursor(0); - } - break; + case Button.UP: + if (this.cursor) { + success = this.setCursor(this.cursor - 1); + } else if (this.cursor === 0) { + success = this.setCursor(options.length - 1); + } + break; + case Button.DOWN: + if (this.cursor < options.length - 1) { + success = this.setCursor(this.cursor + 1); + } else { + success = this.setCursor(0); + } + break; } if (this.config?.supportHover) { // handle hover code if the element supports hover-handlers and the option has the optional hover-handler set. @@ -256,6 +257,7 @@ export default abstract class AbstractOptionSelectUiHandler extends UiHandler { this.blockInput = false; this.optionSelectText.setAlpha(1); + this.cursorObj?.setAlpha(1); } getOptionsWithScroll(): OptionSelectItem[] { @@ -335,7 +337,7 @@ export default abstract class AbstractOptionSelectUiHandler extends UiHandler { } this.cursorObj.setScale(this.scale * 6); - this.cursorObj.setPositionRelative(this.optionSelectBg, 12, 102*this.scale + this.cursor * (114 * this.scale - 3)); + this.cursorObj.setPositionRelative(this.optionSelectBg, 12, 102 * this.scale + this.cursor * (114 * this.scale - 3)); return changed; } @@ -344,6 +346,7 @@ export default abstract class AbstractOptionSelectUiHandler extends UiHandler { super.clear(); this.config = null; this.optionSelectContainer.setVisible(false); + this.scrollCursor = 0; this.eraseCursor(); } diff --git a/src/ui/achvs-ui-handler.ts b/src/ui/achvs-ui-handler.ts index 605b8c538a9..a1ced6145eb 100644 --- a/src/ui/achvs-ui-handler.ts +++ b/src/ui/achvs-ui-handler.ts @@ -1,12 +1,13 @@ -import BattleScene from "../battle-scene"; +import BattleScene from "#app/battle-scene"; import { Button } from "#enums/buttons"; import i18next from "i18next"; -import { Achv, achvs, getAchievementDescription } from "../system/achv"; -import { Voucher, getVoucherTypeIcon, getVoucherTypeName, vouchers } from "../system/voucher"; -import MessageUiHandler from "./message-ui-handler"; -import { addTextObject, TextStyle } from "./text"; -import { Mode } from "./ui"; -import { addWindow } from "./ui-theme"; +import { Achv, achvs, getAchievementDescription } from "#app/system/achv"; +import { Voucher, getVoucherTypeIcon, getVoucherTypeName, vouchers } from "#app/system/voucher"; +import MessageUiHandler from "#app/ui/message-ui-handler"; +import { addTextObject, TextStyle } from "#app/ui/text"; +import { Mode } from "#app/ui/ui"; +import { addWindow } from "#app/ui/ui-theme"; +import { ScrollBar } from "#app/ui/scroll-bar"; import { PlayerGender } from "#enums/player-gender"; enum Page { @@ -39,7 +40,9 @@ export default class AchvsUiHandler extends MessageUiHandler { private iconsBg: Phaser.GameObjects.NineSlice; private icons: Phaser.GameObjects.Sprite[]; + private titleBg: Phaser.GameObjects.NineSlice; private titleText: Phaser.GameObjects.Text; + private scoreContainer: Phaser.GameObjects.Container; private scoreText: Phaser.GameObjects.Text; private unlockText: Phaser.GameObjects.Text; @@ -49,6 +52,7 @@ export default class AchvsUiHandler extends MessageUiHandler { private vouchersTotal: number; private currentTotal: number; + private scrollBar: ScrollBar; private scrollCursor: number; private cursorObj: Phaser.GameObjects.NineSlice | null; private currentPage: Page; @@ -77,7 +81,7 @@ export default class AchvsUiHandler extends MessageUiHandler { this.headerActionButton = new Phaser.GameObjects.Sprite(this.scene, 0, 0, "keyboard", "ACTION.png"); this.headerActionButton.setOrigin(0, 0); this.headerActionButton.setPositionRelative(this.headerBg, 236, 6); - this.headerActionText = addTextObject(this.scene, 0, 0, "", TextStyle.WINDOW, {fontSize:"60px"}); + this.headerActionText = addTextObject(this.scene, 0, 0, "", TextStyle.WINDOW, { fontSize:"60px" }); this.headerActionText.setOrigin(0, 0); this.headerActionText.setPositionRelative(this.headerBg, 264, 8); @@ -91,7 +95,10 @@ export default class AchvsUiHandler extends MessageUiHandler { this.iconsBg = addWindow(this.scene, 0, this.headerBg.height, (this.scene.game.canvas.width / 6) - 2, (this.scene.game.canvas.height / 6) - this.headerBg.height - 68); this.iconsBg.setOrigin(0, 0); - this.iconsContainer = this.scene.add.container(6, this.headerBg.height + 6); + const yOffset = 6; + this.scrollBar = new ScrollBar(this.scene, this.iconsBg.width - 9, this.iconsBg.y + yOffset, 4, this.iconsBg.height - yOffset * 2, this.ROWS); + + this.iconsContainer = this.scene.add.container(5, this.headerBg.height + 8); this.icons = []; @@ -109,29 +116,31 @@ export default class AchvsUiHandler extends MessageUiHandler { const titleBg = addWindow(this.scene, 0, this.headerBg.height + this.iconsBg.height, 174, 24); titleBg.setOrigin(0, 0); + this.titleBg = titleBg; this.titleText = addTextObject(this.scene, 0, 0, "", TextStyle.WINDOW); const textSize = languageSettings[i18next.language]?.TextSize ?? this.titleText.style.fontSize; this.titleText.setFontSize(textSize); - this.titleText.setOrigin(0, 0); const titleBgCenterX = titleBg.x + titleBg.width / 2; const titleBgCenterY = titleBg.y + titleBg.height / 2; this.titleText.setOrigin(0.5, 0.5); this.titleText.setPosition(titleBgCenterX, titleBgCenterY); - const scoreBg = addWindow(this.scene, titleBg.x + titleBg.width, titleBg.y, 46, 24); + this.scoreContainer = this.scene.add.container(titleBg.x + titleBg.width, titleBg.y); + const scoreBg = addWindow(this.scene, 0, 0, 46, 24); scoreBg.setOrigin(0, 0); + this.scoreContainer.add(scoreBg); - this.scoreText = addTextObject(this.scene, 0, 0, "", TextStyle.WINDOW); - this.scoreText.setOrigin(0, 0); - this.scoreText.setPositionRelative(scoreBg, 8, 4); + this.scoreText = addTextObject(this.scene, scoreBg.width / 2, scoreBg.height / 2, "", TextStyle.WINDOW); + this.scoreText.setOrigin(0.5, 0.5); + this.scoreContainer.add(this.scoreText); - const unlockBg = addWindow(this.scene, scoreBg.x + scoreBg.width, scoreBg.y, 98, 24); + const unlockBg = addWindow(this.scene, this.scoreContainer.x + scoreBg.width, titleBg.y, 98, 24); unlockBg.setOrigin(0, 0); this.unlockText = addTextObject(this.scene, 0, 0, "", TextStyle.WINDOW); - this.unlockText.setOrigin(0, 0); - this.unlockText.setPositionRelative(unlockBg, 8, 4); + this.unlockText.setOrigin(0.5, 0.5); + this.unlockText.setPositionRelative(unlockBg, unlockBg.width / 2, unlockBg.height / 2); const descriptionBg = addWindow(this.scene, 0, titleBg.y + titleBg.height, (this.scene.game.canvas.width / 6) - 2, 42); descriptionBg.setOrigin(0, 0); @@ -148,11 +157,11 @@ export default class AchvsUiHandler extends MessageUiHandler { this.mainContainer.add(this.headerText); this.mainContainer.add(this.headerActionText); this.mainContainer.add(this.iconsBg); + this.mainContainer.add(this.scrollBar); this.mainContainer.add(this.iconsContainer); this.mainContainer.add(titleBg); this.mainContainer.add(this.titleText); - this.mainContainer.add(scoreBg); - this.mainContainer.add(this.scoreText); + this.mainContainer.add(this.scoreContainer); this.mainContainer.add(unlockBg); this.mainContainer.add(this.unlockText); this.mainContainer.add(descriptionBg); @@ -161,7 +170,6 @@ export default class AchvsUiHandler extends MessageUiHandler { ui.add(this.mainContainer); this.currentPage = Page.ACHIEVEMENTS; - this.setCursor(0); this.mainContainer.setVisible(false); } @@ -175,6 +183,8 @@ export default class AchvsUiHandler extends MessageUiHandler { this.mainContainer.setVisible(true); this.setCursor(0); this.setScrollCursor(0); + this.scrollBar.setTotalRows(Math.ceil(this.currentTotal / this.COLS)); + this.scrollBar.setScrollCursor(0); this.getUi().moveTo(this.mainContainer, this.getUi().length - 1); @@ -224,6 +234,8 @@ export default class AchvsUiHandler extends MessageUiHandler { this.updateAchvIcons(); } this.setCursor(0, true); + this.scrollBar.setTotalRows(Math.ceil(this.currentTotal / this.COLS)); + this.scrollBar.setScrollCursor(0); this.mainContainer.update(); } if (button === Button.CANCEL) { @@ -233,39 +245,51 @@ export default class AchvsUiHandler extends MessageUiHandler { const rowIndex = Math.floor(this.cursor / this.COLS); const itemOffset = (this.scrollCursor * this.COLS); switch (button) { - case Button.UP: - if (this.cursor < this.COLS) { - if (this.scrollCursor) { - success = this.setScrollCursor(this.scrollCursor - 1); + case Button.UP: + if (this.cursor < this.COLS) { + if (this.scrollCursor) { + success = this.setScrollCursor(this.scrollCursor - 1); + } else { + // Wrap around to the last row + success = this.setScrollCursor(Math.ceil(this.currentTotal / this.COLS) - this.ROWS); + let newCursorIndex = this.cursor + (this.ROWS - 1) * this.COLS; + if (newCursorIndex > this.currentTotal - this.scrollCursor * this.COLS - 1) { + newCursorIndex -= this.COLS; + } + success = success && this.setCursor(newCursorIndex); + } + } else { + success = this.setCursor(this.cursor - this.COLS); } - } else { - success = this.setCursor(this.cursor - this.COLS); - } - break; - case Button.DOWN: - const canMoveDown = (this.cursor + itemOffset) + this.COLS < this.currentTotal; - if (rowIndex >= this.ROWS - 1) { - if (this.scrollCursor < Math.ceil(this.currentTotal / this.COLS) - this.ROWS && canMoveDown) { - success = this.setScrollCursor(this.scrollCursor + 1); + break; + case Button.DOWN: + const canMoveDown = itemOffset + 1 < this.currentTotal; + if (rowIndex >= this.ROWS - 1) { + if (this.scrollCursor < Math.ceil(this.currentTotal / this.COLS) - this.ROWS && canMoveDown) { + // scroll down one row + success = this.setScrollCursor(this.scrollCursor + 1); + } else { + // wrap back to the first row + success = this.setScrollCursor(0) && this.setCursor(this.cursor % this.COLS); + } + } else if (canMoveDown) { + success = this.setCursor(Math.min(this.cursor + this.COLS, this.currentTotal - itemOffset - 1)); } - } else if (canMoveDown) { - success = this.setCursor(this.cursor + this.COLS); - } - break; - case Button.LEFT: - if (!this.cursor && this.scrollCursor) { - success = this.setScrollCursor(this.scrollCursor - 1) && this.setCursor(this.cursor + (this.COLS - 1)); - } else if (this.cursor) { - success = this.setCursor(this.cursor - 1); - } - break; - case Button.RIGHT: - if (this.cursor + 1 === this.ROWS * this.COLS && this.scrollCursor < Math.ceil(this.currentTotal / this.COLS) - this.ROWS) { - success = this.setScrollCursor(this.scrollCursor + 1) && this.setCursor(this.cursor - (this.COLS - 1)); - } else if (this.cursor + itemOffset < this.currentTotal - 1) { - success = this.setCursor(this.cursor + 1); - } - break; + break; + case Button.LEFT: + if (this.cursor % this.COLS === 0) { + success = this.setCursor(Math.min(this.cursor + this.COLS - 1, this.currentTotal - itemOffset - 1)); + } else { + success = this.setCursor(this.cursor - 1); + } + break; + case Button.RIGHT: + if ((this.cursor + 1) % this.COLS === 0 || (this.cursor + itemOffset) === (this.currentTotal - 1)) { + success = this.setCursor(this.cursor - this.cursor % this.COLS); + } else { + success = this.setCursor(this.cursor + 1); + } + break; } } @@ -292,12 +316,22 @@ export default class AchvsUiHandler extends MessageUiHandler { if (update || pageChange) { switch (this.currentPage) { - case Page.ACHIEVEMENTS: - this.showAchv(achvs[Object.keys(achvs)[cursor + this.scrollCursor * this.COLS]]); - break; - case Page.VOUCHERS: - this.showVoucher(vouchers[Object.keys(vouchers)[cursor + this.scrollCursor * this.COLS]]); - break; + case Page.ACHIEVEMENTS: + if (pageChange) { + this.titleBg.width = 174; + this.titleText.x = this.titleBg.width / 2; + this.scoreContainer.setVisible(true); + } + this.showAchv(achvs[Object.keys(achvs)[cursor + this.scrollCursor * this.COLS]]); + break; + case Page.VOUCHERS: + if (pageChange) { + this.titleBg.width = 220; + this.titleText.x = this.titleBg.width / 2; + this.scoreContainer.setVisible(false); + } + this.showVoucher(vouchers[Object.keys(vouchers)[cursor + this.scrollCursor * this.COLS]]); + break; } } return ret; @@ -315,16 +349,23 @@ export default class AchvsUiHandler extends MessageUiHandler { } this.scrollCursor = scrollCursor; + this.scrollBar.setScrollCursor(this.scrollCursor); + + // Cursor cannot go farther than the last element in the list + const maxCursor = Math.min(this.cursor, this.currentTotal - this.scrollCursor * this.COLS - 1); + if (maxCursor !== this.cursor) { + this.setCursor(maxCursor); + } switch (this.currentPage) { - case Page.ACHIEVEMENTS: - this.updateAchvIcons(); - this.showAchv(achvs[Object.keys(achvs)[Math.min(this.cursor + this.scrollCursor * this.COLS, Object.values(achvs).length - 1)]]); - break; - case Page.VOUCHERS: - this.updateVoucherIcons(); - this.showVoucher(vouchers[Object.keys(vouchers)[Math.min(this.cursor + this.scrollCursor * this.COLS, Object.values(vouchers).length - 1)]]); - break; + case Page.ACHIEVEMENTS: + this.updateAchvIcons(); + this.showAchv(achvs[Object.keys(achvs)[this.cursor + this.scrollCursor * this.COLS]]); + break; + case Page.VOUCHERS: + this.updateVoucherIcons(); + this.showVoucher(vouchers[Object.keys(vouchers)[this.cursor + this.scrollCursor * this.COLS]]); + break; } return true; } @@ -411,6 +452,8 @@ export default class AchvsUiHandler extends MessageUiHandler { super.clear(); this.currentPage = Page.ACHIEVEMENTS; this.mainContainer.setVisible(false); + this.setScrollCursor(0); + this.setCursor(0, true); this.eraseCursor(); } diff --git a/src/ui/admin-ui-handler.ts b/src/ui/admin-ui-handler.ts index c48138853fc..269b5ac5096 100644 --- a/src/ui/admin-ui-handler.ts +++ b/src/ui/admin-ui-handler.ts @@ -1,38 +1,86 @@ import BattleScene from "#app/battle-scene"; -import { ModalConfig } from "./modal-ui-handler"; -import { Mode } from "./ui"; -import * as Utils from "../utils"; -import { FormModalUiHandler } from "./form-modal-ui-handler"; import { Button } from "#app/enums/buttons"; +import { pokerogueApi } from "#app/plugins/api/pokerogue-api"; +import { formatText } from "#app/utils"; +import { FormModalUiHandler, InputFieldConfig } from "./form-modal-ui-handler"; +import { ModalConfig } from "./modal-ui-handler"; +import { TextStyle } from "./text"; +import { Mode } from "./ui"; + +type AdminUiHandlerService = "discord" | "google"; +type AdminUiHandlerServiceMode = "Link" | "Unlink"; export default class AdminUiHandler extends FormModalUiHandler { + private adminMode: AdminMode; + private adminResult: AdminSearchInfo; + private config: ModalConfig; + + private readonly buttonGap = 10; + // http response from the server when a username isn't found in the server + private readonly httpUserNotFoundErrorCode: number = 404; + private readonly ERR_REQUIRED_FIELD = (field: string) => { + if (field === "username") { + return `${formatText(field)} is required`; + } else { + return `${formatText(field)} Id is required`; + } + }; + // returns a string saying whether a username has been successfully linked/unlinked to discord/google + private readonly SUCCESS_SERVICE_MODE = (service: string, mode: string) => { + return `Username and ${service} successfully ${mode.toLowerCase()}ed`; + }; + constructor(scene: BattleScene, mode: Mode | null = null) { super(scene, mode); } - setup(): void { - super.setup(); - } - - getModalTitle(config?: ModalConfig): string { + override getModalTitle(): string { return "Admin panel"; } - getFields(config?: ModalConfig): string[] { - return ["Username", "Discord ID"]; + override getWidth(): number { + return this.adminMode === AdminMode.ADMIN ? 180 : 160; } - getWidth(config?: ModalConfig): number { - return 160; + override getMargin(): [number, number, number, number] { + return [ 0, 0, 0, 0 ]; } - getMargin(config?: ModalConfig): [number, number, number, number] { - return [0, 0, 48, 0]; + override getButtonLabels(): string[] { + switch (this.adminMode) { + case AdminMode.LINK: + return [ "Link Account", "Cancel" ]; + case AdminMode.SEARCH: + return [ "Find account", "Cancel" ]; + case AdminMode.ADMIN: + return [ "Back to search", "Cancel" ]; + default: + return [ "Activate ADMIN", "Cancel" ]; + } } - getButtonLabels(config?: ModalConfig): string[] { - return ["Link account", "Cancel"]; + override getInputFieldConfigs(): InputFieldConfig[] { + const inputFieldConfigs: InputFieldConfig[] = []; + switch (this.adminMode) { + case AdminMode.LINK: + inputFieldConfigs.push( { label: "Username" }); + inputFieldConfigs.push( { label: "Discord ID" }); + break; + case AdminMode.SEARCH: + inputFieldConfigs.push( { label: "Username" }); + break; + case AdminMode.ADMIN: + const adminResult = this.adminResult ?? { username: "", discordId: "", googleId: "", lastLoggedIn: "", registered: "" }; + // Discord and Google ID fields that are not empty get locked, other fields are all locked + inputFieldConfigs.push( { label: "Username", isReadOnly: true }); + inputFieldConfigs.push( { label: "Discord ID", isReadOnly: adminResult.discordId !== "" }); + inputFieldConfigs.push( { label: "Google ID", isReadOnly: adminResult.googleId !== "" }); + inputFieldConfigs.push( { label: "Last played", isReadOnly: true }); + inputFieldConfigs.push( { label: "Registered", isReadOnly: true }); + break; + } + return inputFieldConfigs; } processInput(button: Button): boolean { @@ -45,44 +93,314 @@ export default class AdminUiHandler extends FormModalUiHandler { } show(args: any[]): boolean { + this.config = args[0] as ModalConfig; // config + this.adminMode = args[1] as AdminMode; // admin mode + this.adminResult = args[2] ?? { username: "", discordId: "", googleId: "", lastLoggedIn: "", registered: "" }; // admin result, if any + const isMessageError = args[3]; // is the message shown a success or error + + const fields = this.getInputFieldConfigs(); + const hasTitle = !!this.getModalTitle(); + + this.updateFields(fields, hasTitle); + this.updateContainer(this.config); + + const labels = this.getButtonLabels(); + for (let i = 0; i < labels.length; i++) { + this.buttonLabels[i].setText(labels[i]); // sets the label text + } + + this.errorMessage.setPosition(10, (hasTitle ? 31 : 5) + 20 * (fields.length - 1) + 16 + this.getButtonTopMargin()); // sets the position of the message dynamically + if (isMessageError) { + this.errorMessage.setColor(this.getTextColor(TextStyle.SUMMARY_PINK)); + this.errorMessage.setShadowColor(this.getTextColor(TextStyle.SUMMARY_PINK, true)); + } else { + this.errorMessage.setColor(this.getTextColor(TextStyle.SUMMARY_GREEN)); + this.errorMessage.setShadowColor(this.getTextColor(TextStyle.SUMMARY_GREEN, true)); + } + if (super.show(args)) { - const config = args[0] as ModalConfig; + this.populateFields(this.adminMode, this.adminResult); const originalSubmitAction = this.submitAction; this.submitAction = (_) => { this.submitAction = originalSubmitAction; - this.scene.ui.setMode(Mode.LOADING, { buttonActions: [] }); - const onFail = error => { - this.scene.ui.setMode(Mode.ADMIN, Object.assign(config, { errorMessage: error?.trim() })); - this.scene.ui.playError(); - }; - if (!this.inputs[0].text) { - return onFail("Username is required"); + const adminSearchResult: AdminSearchInfo = this.convertInputsToAdmin(); // this converts the input texts into a single object for use later + const validFields = this.areFieldsValid(this.adminMode); + if (validFields.error) { + this.scene.ui.setMode(Mode.LOADING, { buttonActions: []}); // this is here to force a loading screen to allow the admin tool to reopen again if there's an error + return this.showMessage(validFields.errorMessage ?? "", adminSearchResult, true); } - if (!this.inputs[1].text) { - return onFail("Discord Id is required"); + this.scene.ui.setMode(Mode.LOADING, { buttonActions: []}); + if (this.adminMode === AdminMode.LINK) { + this.adminLinkUnlink(adminSearchResult, "discord", "Link") // calls server to link discord + .then(response => { + if (response.error) { + return this.showMessage(response.errorType, adminSearchResult, true); // error or some kind + } else { + return this.showMessage(this.SUCCESS_SERVICE_MODE("discord", "link"), adminSearchResult, false); // success + } + }); + } else if (this.adminMode === AdminMode.SEARCH) { + this.adminSearch(adminSearchResult) // admin search for username + .then(response => { + if (response.error) { + return this.showMessage(response.errorType, adminSearchResult, true); // failure + } + this.updateAdminPanelInfo(response.adminSearchResult ?? adminSearchResult); // success + }); + } else if (this.adminMode === AdminMode.ADMIN) { + this.updateAdminPanelInfo(adminSearchResult, AdminMode.SEARCH); } - Utils.apiPost("admin/account/discord-link", `username=${encodeURIComponent(this.inputs[0].text)}&discordId=${encodeURIComponent(this.inputs[1].text)}`, "application/x-www-form-urlencoded", true) - .then(response => { - if (!response.ok) { - console.error(response); - } - this.inputs[0].setText(""); - this.inputs[1].setText(""); - this.scene.ui.revertMode(); - }) - .catch((err) => { - console.error(err); - this.scene.ui.revertMode(); - }); - return false; }; return true; } return false; + } + showMessage(message: string, adminResult: AdminSearchInfo, isError: boolean) { + this.scene.ui.setMode(Mode.ADMIN, Object.assign(this.config, { errorMessage: message?.trim() }), this.adminMode, adminResult, isError); + if (isError) { + this.scene.ui.playError(); + } else { + this.scene.ui.playSelect(); + } + } + + /** + * This is used to update the fields' text when loading in a new admin ui handler. It uses the {@linkcode adminResult} + * to update the input text based on the {@linkcode adminMode}. For a linking adminMode, it sets the username and discord. + * For a search adminMode, it sets the username. For an admin adminMode, it sets all the info from adminResult in the + * appropriate text boxes, and also sets the link/unlink icons for discord/google depending on the result + */ + private populateFields(adminMode: AdminMode, adminResult: AdminSearchInfo) { + switch (adminMode) { + case AdminMode.LINK: + this.inputs[0].setText(adminResult.username); + this.inputs[1].setText(adminResult.discordId); + break; + case AdminMode.SEARCH: + this.inputs[0].setText(adminResult.username); + break; + case AdminMode.ADMIN: + Object.keys(adminResult).forEach((aR, i) => { + this.inputs[i].setText(adminResult[aR]); + if (aR === "discordId" || aR === "googleId") { // this is here to add the icons for linking/unlinking of google/discord IDs + const nineSlice = this.inputContainers[i].list.find(iC => iC.type === "NineSlice"); + const img = this.scene.add.image(this.inputContainers[i].x + nineSlice!.width + this.buttonGap, this.inputContainers[i].y + (Math.floor(nineSlice!.height / 2)), adminResult[aR] === "" ? "link_icon" : "unlink_icon"); + img.setName(`adminBtn_${aR}`); + img.setOrigin(0.5, 0.5); + img.setInteractive(); + img.on("pointerdown", () => { + const service = aR.toLowerCase().replace("id", ""); // this takes our key (discordId or googleId) and removes the "Id" at the end to make it more url friendly + const mode = adminResult[aR] === "" ? "Link" : "Unlink"; // this figures out if we're linking or unlinking a service + const validFields = this.areFieldsValid(this.adminMode, service); + if (validFields.error) { + this.scene.ui.setMode(Mode.LOADING, { buttonActions: []}); // this is here to force a loading screen to allow the admin tool to reopen again if there's an error + return this.showMessage(validFields.errorMessage ?? "", adminResult, true); + } + this.adminLinkUnlink(this.convertInputsToAdmin(), service as AdminUiHandlerService, mode).then(response => { // attempts to link/unlink depending on the service + if (response.error) { + this.scene.ui.setMode(Mode.LOADING, { buttonActions: []}); + return this.showMessage(response.errorType, adminResult, true); // fail + } else { // success, reload panel with new results + this.scene.ui.setMode(Mode.LOADING, { buttonActions: []}); + this.adminSearch(adminResult) + .then(response => { + if (response.error) { + return this.showMessage(response.errorType, adminResult, true); + } + return this.showMessage(this.SUCCESS_SERVICE_MODE(service, mode), response.adminSearchResult ?? adminResult, false); + }); + } + }); + }); + this.addInteractionHoverEffect(img); + this.modalContainer.add(img); + } + }); + break; + } + } + + private areFieldsValid(adminMode: AdminMode, service?: string): { error: boolean; errorMessage?: string; } { + switch (adminMode) { + case AdminMode.LINK: + if (!this.inputs[0].text) { // username missing from link panel + return { + error: true, + errorMessage: this.ERR_REQUIRED_FIELD("username") + }; + } + if (!this.inputs[1].text) { // discordId missing from linking panel + return { + error: true, + errorMessage: this.ERR_REQUIRED_FIELD("discord") + }; + } + break; + case AdminMode.SEARCH: + if (!this.inputs[0].text) { // username missing from search panel + return { + error: true, + errorMessage: this.ERR_REQUIRED_FIELD("username") + }; + } + break; + case AdminMode.ADMIN: + if (!this.inputs[1].text && service === "discord") { // discordId missing from admin panel + return { + error: true, + errorMessage: this.ERR_REQUIRED_FIELD(service) + }; + } + if (!this.inputs[2].text && service === "google") { // googleId missing from admin panel + return { + error: true, + errorMessage: this.ERR_REQUIRED_FIELD(service) + }; + } + break; + } + return { + error: false + }; + } + + private convertInputsToAdmin(): AdminSearchInfo { + return { + username: this.inputs[0]?.node ? this.inputs[0].text : "", + discordId: this.inputs[1]?.node ? this.inputs[1]?.text : "", + googleId: this.inputs[2]?.node ? this.inputs[2]?.text : "", + lastLoggedIn: this.inputs[3]?.node ? this.inputs[3]?.text : "", + registered: this.inputs[4]?.node ? this.inputs[4]?.text : "" + }; + } + + private async adminSearch(adminSearchResult: AdminSearchInfo) { + try { + const [ adminInfo, errorType ] = await pokerogueApi.admin.searchAccount({ username: adminSearchResult.username }); + if (errorType || !adminInfo) { // error - if adminInfo.status === this.httpUserNotFoundErrorCode that means the username can't be found in the db + return { adminSearchResult: adminSearchResult, error: true, errorType }; + } else { // success + return { adminSearchResult: adminInfo, error: false }; + } + } catch (err) { + console.error(err); + return { error: true, errorType: err }; + } + } + + private async adminLinkUnlink(adminSearchResult: AdminSearchInfo, service: AdminUiHandlerService, mode: AdminUiHandlerServiceMode) { + try { + let errorType: string | null = null; + + if (service === "discord") { + if (mode === "Link") { + errorType = await pokerogueApi.admin.linkAccountToDiscord({ + discordId: adminSearchResult.discordId, + username: adminSearchResult.username, + }); + } else if (mode === "Unlink") { + errorType = await pokerogueApi.admin.unlinkAccountFromDiscord({ + discordId: adminSearchResult.discordId, + username: adminSearchResult.username, + }); + } else { + console.warn("Unknown mode", mode, "for service", service); + } + } else if (service === "google") { + if (mode === "Link") { + errorType = await pokerogueApi.admin.linkAccountToGoogleId({ + googleId: adminSearchResult.googleId, + username: adminSearchResult.username, + }); + } else if (mode === "Unlink") { + errorType = await pokerogueApi.admin.unlinkAccountFromGoogleId({ + googleId: adminSearchResult.googleId, + username: adminSearchResult.username, + }); + } else { + console.warn("Unknown mode", mode, "for service", service); + } + } else { + console.warn("Unknown service", service); + } + + if (errorType) { + // error - if response.status === this.httpUserNotFoundErrorCode that means the username can't be found in the db + return { adminSearchResult: adminSearchResult, error: true, errorType }; + } else { + // success! + return { adminSearchResult: adminSearchResult, error: false }; + } + } catch (err) { + console.error(err); + return { error: true, errorType: err }; + } + } + + private updateAdminPanelInfo(adminSearchResult: AdminSearchInfo, mode?: AdminMode) { + mode = mode ?? AdminMode.ADMIN; + this.scene.ui.setMode(Mode.ADMIN, { + buttonActions: [ + // we double revert here and below to go back 2 layers of menus + () => { + this.scene.ui.revertMode(); + this.scene.ui.revertMode(); + }, + () => { + this.scene.ui.revertMode(); + this.scene.ui.revertMode(); + } + ] + }, mode, adminSearchResult); } clear(): void { super.clear(); + + // this is used to remove the existing fields on the admin panel so they can be updated + + const itemsToRemove: string[] = [ "formLabel", "adminBtn" ]; // this is the start of the names for each element we want to remove + const removeArray: any[] = []; + const mC = this.modalContainer.list; + for (let i = mC.length - 1; i >= 0; i--) { + /* This code looks for a few things before destroying the specific field; first it looks to see if the name of the element is %like% the itemsToRemove labels + * this means that anything with, for example, "formLabel", will be true. + * It then also checks for any containers that are within this.modalContainer, and checks if any of its child elements are of type rexInputText + * and if either of these conditions are met, the element is destroyed. + */ + if (itemsToRemove.some(iTR => mC[i].name.includes(iTR)) || (mC[i].type === "Container" && (mC[i] as Phaser.GameObjects.Container).list.find(m => m.type === "rexInputText"))) { + removeArray.push(mC[i]); + } + } + + while (removeArray.length > 0) { + this.modalContainer.remove(removeArray.pop(), true); + } } } + +export enum AdminMode { + LINK, + SEARCH, + ADMIN +} + +export function getAdminModeName(adminMode: AdminMode): string { + switch (adminMode) { + case AdminMode.LINK: + return "Link"; + case AdminMode.SEARCH: + return "Search"; + default: + return ""; + } +} + +interface AdminSearchInfo { + username: string; + discordId: string; + googleId: string; + lastLoggedIn: string; + registered: string; +} diff --git a/src/ui/arena-flyout.ts b/src/ui/arena-flyout.ts index 42a2396e665..573cb85db70 100644 --- a/src/ui/arena-flyout.ts +++ b/src/ui/arena-flyout.ts @@ -1,7 +1,7 @@ import { addTextObject, TextStyle } from "./text"; import BattleScene from "#app/battle-scene"; import { ArenaTagSide, ArenaTrapTag } from "#app/data/arena-tag"; -import { WeatherType } from "#app/data/weather"; +import { WeatherType } from "#enums/weather-type"; import { TerrainType } from "#app/data/terrain"; import { addWindow, WindowVariant } from "./ui-theme"; import { ArenaEvent, ArenaEventType, TagAddedEvent, TagRemovedEvent, TerrainChangedEvent, WeatherChangedEvent } from "#app/events/arena"; @@ -9,7 +9,7 @@ import { BattleSceneEventType, TurnEndEvent } from "../events/battle-scene"; import { ArenaTagType } from "#enums/arena-tag-type"; import TimeOfDayWidget from "./time-of-day-widget"; import * as Utils from "../utils"; -import i18next, {ParseKeys} from "i18next"; +import i18next, { ParseKeys } from "i18next"; /** Enum used to differentiate {@linkcode Arena} effects */ enum ArenaEffectType { @@ -196,7 +196,6 @@ export class ArenaFlyout extends Phaser.GameObjects.Container { } - /** Clears out the current string stored in all arena effect texts */ private clearText() { this.flyoutTextPlayer.text = ""; @@ -216,20 +215,20 @@ export class ArenaFlyout extends Phaser.GameObjects.Container { // Creates a proxy object to decide which text object needs to be updated let textObject: Phaser.GameObjects.Text; switch (fieldEffectInfo.effecType) { - case ArenaEffectType.PLAYER: - textObject = this.flyoutTextPlayer; - break; + case ArenaEffectType.PLAYER: + textObject = this.flyoutTextPlayer; + break; - case ArenaEffectType.WEATHER: - case ArenaEffectType.TERRAIN: - case ArenaEffectType.FIELD: - textObject = this.flyoutTextField; + case ArenaEffectType.WEATHER: + case ArenaEffectType.TERRAIN: + case ArenaEffectType.FIELD: + textObject = this.flyoutTextField; - break; + break; - case ArenaEffectType.ENEMY: - textObject = this.flyoutTextEnemy; - break; + case ArenaEffectType.ENEMY: + textObject = this.flyoutTextEnemy; + break; } textObject.text += fieldEffectInfo.name; @@ -254,81 +253,81 @@ export class ArenaFlyout extends Phaser.GameObjects.Container { let foundIndex: number; switch (arenaEffectChangedEvent.constructor) { - case TagAddedEvent: - const tagAddedEvent = arenaEffectChangedEvent as TagAddedEvent; - const isArenaTrapTag = this.battleScene.arena.getTag(tagAddedEvent.arenaTagType) instanceof ArenaTrapTag; - let arenaEffectType: ArenaEffectType; + case TagAddedEvent: + const tagAddedEvent = arenaEffectChangedEvent as TagAddedEvent; + const isArenaTrapTag = this.battleScene.arena.getTag(tagAddedEvent.arenaTagType) instanceof ArenaTrapTag; + let arenaEffectType: ArenaEffectType; - if (tagAddedEvent.arenaTagSide === ArenaTagSide.BOTH) { - arenaEffectType = ArenaEffectType.FIELD; - } else if (tagAddedEvent.arenaTagSide === ArenaTagSide.PLAYER) { - arenaEffectType = ArenaEffectType.PLAYER; - } else { - arenaEffectType = ArenaEffectType.ENEMY; - } - - const existingTrapTagIndex = isArenaTrapTag ? this.fieldEffectInfo.findIndex(e => tagAddedEvent.arenaTagType === e.tagType && arenaEffectType === e.effecType) : -1; - let name: string = getFieldEffectText(ArenaTagType[tagAddedEvent.arenaTagType]); - - if (isArenaTrapTag) { - if (existingTrapTagIndex !== -1) { - const layers = tagAddedEvent.arenaTagMaxLayers > 1 ? ` (${tagAddedEvent.arenaTagLayers})` : ""; - this.fieldEffectInfo[existingTrapTagIndex].name = `${name}${layers}`; - break; - } else if (tagAddedEvent.arenaTagMaxLayers > 1) { - name = `${name} (${tagAddedEvent.arenaTagLayers})`; + if (tagAddedEvent.arenaTagSide === ArenaTagSide.BOTH) { + arenaEffectType = ArenaEffectType.FIELD; + } else if (tagAddedEvent.arenaTagSide === ArenaTagSide.PLAYER) { + arenaEffectType = ArenaEffectType.PLAYER; + } else { + arenaEffectType = ArenaEffectType.ENEMY; } - } - this.fieldEffectInfo.push({ - name, - effecType: arenaEffectType, - maxDuration: tagAddedEvent.duration, - duration: tagAddedEvent.duration, - tagType: tagAddedEvent.arenaTagType - }); - break; - case TagRemovedEvent: - const tagRemovedEvent = arenaEffectChangedEvent as TagRemovedEvent; - foundIndex = this.fieldEffectInfo.findIndex(info => info.tagType === tagRemovedEvent.arenaTagType); + const existingTrapTagIndex = isArenaTrapTag ? this.fieldEffectInfo.findIndex(e => tagAddedEvent.arenaTagType === e.tagType && arenaEffectType === e.effecType) : -1; + let name: string = getFieldEffectText(ArenaTagType[tagAddedEvent.arenaTagType]); - if (foundIndex !== -1) { // If the tag was being tracked, remove it - this.fieldEffectInfo.splice(foundIndex, 1); - } - break; + if (isArenaTrapTag) { + if (existingTrapTagIndex !== -1) { + const layers = tagAddedEvent.arenaTagMaxLayers > 1 ? ` (${tagAddedEvent.arenaTagLayers})` : ""; + this.fieldEffectInfo[existingTrapTagIndex].name = `${name}${layers}`; + break; + } else if (tagAddedEvent.arenaTagMaxLayers > 1) { + name = `${name} (${tagAddedEvent.arenaTagLayers})`; + } + } - case WeatherChangedEvent: - case TerrainChangedEvent: - const fieldEffectChangedEvent = arenaEffectChangedEvent as WeatherChangedEvent | TerrainChangedEvent; + this.fieldEffectInfo.push({ + name, + effecType: arenaEffectType, + maxDuration: tagAddedEvent.duration, + duration: tagAddedEvent.duration, + tagType: tagAddedEvent.arenaTagType + }); + break; + case TagRemovedEvent: + const tagRemovedEvent = arenaEffectChangedEvent as TagRemovedEvent; + foundIndex = this.fieldEffectInfo.findIndex(info => info.tagType === tagRemovedEvent.arenaTagType); - // Stores the old Weather/Terrain name in case it's in the array already - const oldName = + if (foundIndex !== -1) { // If the tag was being tracked, remove it + this.fieldEffectInfo.splice(foundIndex, 1); + } + break; + + case WeatherChangedEvent: + case TerrainChangedEvent: + const fieldEffectChangedEvent = arenaEffectChangedEvent as WeatherChangedEvent | TerrainChangedEvent; + + // Stores the old Weather/Terrain name in case it's in the array already + const oldName = getFieldEffectText(fieldEffectChangedEvent instanceof WeatherChangedEvent ? WeatherType[fieldEffectChangedEvent.oldWeatherType] : TerrainType[fieldEffectChangedEvent.oldTerrainType]); - // Stores the new Weather/Terrain info - const newInfo = { - name: + // Stores the new Weather/Terrain info + const newInfo = { + name: getFieldEffectText(fieldEffectChangedEvent instanceof WeatherChangedEvent ? WeatherType[fieldEffectChangedEvent.newWeatherType] : TerrainType[fieldEffectChangedEvent.newTerrainType]), - effecType: fieldEffectChangedEvent instanceof WeatherChangedEvent - ? ArenaEffectType.WEATHER - : ArenaEffectType.TERRAIN, - maxDuration: fieldEffectChangedEvent.duration, - duration: fieldEffectChangedEvent.duration}; + effecType: fieldEffectChangedEvent instanceof WeatherChangedEvent + ? ArenaEffectType.WEATHER + : ArenaEffectType.TERRAIN, + maxDuration: fieldEffectChangedEvent.duration, + duration: fieldEffectChangedEvent.duration }; - foundIndex = this.fieldEffectInfo.findIndex(info => [newInfo.name, oldName].includes(info.name)); - if (foundIndex === -1) { - if (newInfo.name !== undefined) { - this.fieldEffectInfo.push(newInfo); // Adds the info to the array if it doesn't already exist and is defined + foundIndex = this.fieldEffectInfo.findIndex(info => [ newInfo.name, oldName ].includes(info.name)); + if (foundIndex === -1) { + if (newInfo.name !== undefined) { + this.fieldEffectInfo.push(newInfo); // Adds the info to the array if it doesn't already exist and is defined + } + } else if (!newInfo.name) { + this.fieldEffectInfo.splice(foundIndex, 1); // Removes the old info if the new one is undefined + } else { + this.fieldEffectInfo[foundIndex] = newInfo; // Otherwise, replace the old info } - } else if (!newInfo.name) { - this.fieldEffectInfo.splice(foundIndex, 1); // Removes the old info if the new one is undefined - } else { - this.fieldEffectInfo[foundIndex] = newInfo; // Otherwise, replace the old info - } - break; + break; } this.updateFieldText(); diff --git a/src/ui/awaitable-ui-handler.ts b/src/ui/awaitable-ui-handler.ts index c6dc717aa3a..8256f938106 100644 --- a/src/ui/awaitable-ui-handler.ts +++ b/src/ui/awaitable-ui-handler.ts @@ -1,7 +1,7 @@ import BattleScene from "../battle-scene"; import { Mode } from "./ui"; import UiHandler from "./ui-handler"; -import {Button} from "#enums/buttons"; +import { Button } from "#enums/buttons"; export default abstract class AwaitableUiHandler extends UiHandler { protected awaitingActionInput: boolean; diff --git a/src/ui/ball-ui-handler.ts b/src/ui/ball-ui-handler.ts index 332fe5f65b9..9df6da36055 100644 --- a/src/ui/ball-ui-handler.ts +++ b/src/ui/ball-ui-handler.ts @@ -5,7 +5,7 @@ import { Command } from "./command-ui-handler"; import { Mode } from "./ui"; import UiHandler from "./ui-handler"; import { addWindow } from "./ui-theme"; -import {Button} from "#enums/buttons"; +import { Button } from "#enums/buttons"; import { CommandPhase } from "#app/phases/command-phase"; export default class BallUiHandler extends UiHandler { @@ -90,12 +90,12 @@ export default class BallUiHandler extends UiHandler { } } else { switch (button) { - case Button.UP: - success = this.setCursor(this.cursor ? this.cursor - 1 : pokeballTypeCount); - break; - case Button.DOWN: - success = this.setCursor(this.cursor < pokeballTypeCount ? this.cursor + 1 : 0); - break; + case Button.UP: + success = this.setCursor(this.cursor ? this.cursor - 1 : pokeballTypeCount); + break; + case Button.DOWN: + success = this.setCursor(this.cursor < pokeballTypeCount ? this.cursor + 1 : 0); + break; } } diff --git a/src/ui/battle-flyout.ts b/src/ui/battle-flyout.ts index fe561b76c9f..4541a2bfefa 100644 --- a/src/ui/battle-flyout.ts +++ b/src/ui/battle-flyout.ts @@ -149,7 +149,7 @@ export default class BattleFlyout extends Phaser.GameObjects.Container { if (foundInfo) { foundInfo.ppUsed = moveUsedEvent.ppUsed; } else { - this.moveInfo.push({move: moveUsedEvent.move, maxPp: moveUsedEvent.move.pp, ppUsed: moveUsedEvent.ppUsed}); + this.moveInfo.push({ move: moveUsedEvent.move, maxPp: moveUsedEvent.move.pp, ppUsed: moveUsedEvent.ppUsed }); } this.setText(); diff --git a/src/ui/battle-info.ts b/src/ui/battle-info.ts index 1d598f6ac4e..72447988bdd 100644 --- a/src/ui/battle-info.ts +++ b/src/ui/battle-info.ts @@ -3,9 +3,10 @@ import { getLevelTotalExp, getLevelRelExp } from "../data/exp"; import * as Utils from "../utils"; import { addTextObject, TextStyle } from "./text"; import { getGenderSymbol, getGenderColor, Gender } from "../data/gender"; -import { StatusEffect } from "../data/status-effect"; +import { StatusEffect } from "#enums/status-effect"; import BattleScene from "../battle-scene"; -import { Type, getTypeRgb } from "../data/type"; +import { getTypeRgb } from "#app/data/type"; +import { Type } from "#enums/type"; import { getVariantTint } from "#app/data/variant"; import { Stat } from "#enums/stat"; import BattleFlyout from "./battle-flyout"; @@ -326,7 +327,7 @@ export default class BattleInfo extends Phaser.GameObjects.Container { this.teraIcon.setVisible(this.lastTeraType !== Type.UNKNOWN); this.teraIcon.on("pointerover", () => { if (this.lastTeraType !== Type.UNKNOWN) { - (this.scene as BattleScene).ui.showTooltip("", i18next.t("fightUiHandler:teraHover", {type: i18next.t(`pokemonInfo:Type.${Type[this.lastTeraType]}`) })); + (this.scene as BattleScene).ui.showTooltip("", i18next.t("fightUiHandler:teraHover", { type: i18next.t(`pokemonInfo:Type.${Type[this.lastTeraType]}`) })); } }); this.teraIcon.on("pointerout", () => (this.scene as BattleScene).ui.hideTooltip()); @@ -381,17 +382,8 @@ export default class BattleInfo extends Phaser.GameObjects.Container { const ownedAbilityAttrs = pokemon.scene.gameData.starterData[pokemon.species.getRootSpeciesId()].abilityAttr; - let playerOwnsThisAbility = false; // Check if the player owns ability for the root form - if ((ownedAbilityAttrs & 1) > 0 && pokemon.hasSameAbilityInRootForm(0)) { - playerOwnsThisAbility = true; - } - if ((ownedAbilityAttrs & 2) > 0 && pokemon.hasSameAbilityInRootForm(1)) { - playerOwnsThisAbility = true; - } - if ((ownedAbilityAttrs & 4) > 0 && pokemon.hasSameAbilityInRootForm(2)) { - playerOwnsThisAbility = true; - } + const playerOwnsThisAbility = pokemon.checkIfPlayerHasAbilityOfStarter(ownedAbilityAttrs); if (missingDexAttrs || !playerOwnsThisAbility) { this.ownedIcon.setTint(0x808080); @@ -602,7 +594,7 @@ export default class BattleInfo extends Phaser.GameObjects.Container { }; const updatePokemonHp = () => { - let duration = !instant ? Utils.clampInt(Math.abs((this.lastHp) - pokemon.hp) * 5, 250, 5000) : 0; + let duration = !instant ? Phaser.Math.Clamp(Math.abs((this.lastHp) - pokemon.hp) * 5, 250, 5000) : 0; const speed = (this.scene as BattleScene).hpBarSpeed; if (speed) { duration = speed >= 3 ? 0 : duration / Math.pow(2, speed); diff --git a/src/ui/battle-message-ui-handler.ts b/src/ui/battle-message-ui-handler.ts index c27c6974192..180fc66ed9b 100644 --- a/src/ui/battle-message-ui-handler.ts +++ b/src/ui/battle-message-ui-handler.ts @@ -4,7 +4,7 @@ import { Mode } from "./ui"; import MessageUiHandler from "./message-ui-handler"; import { addWindow } from "./ui-theme"; import BBCodeText from "phaser3-rex-plugins/plugins/bbcodetext"; -import {Button} from "#enums/buttons"; +import { Button } from "#enums/buttons"; import i18next from "i18next"; import { Stat, PERMANENT_STATS, getStatKey } from "#app/enums/stat"; @@ -55,7 +55,7 @@ export default class BattleMessageUiHandler extends MessageUiHandler { moveDetailsWindow.setName("move-details-window"); moveDetailsWindow.setOrigin(0, 1); - this.movesWindowContainer.add([movesWindow, moveDetailsWindow]); + this.movesWindowContainer.add([ movesWindow, moveDetailsWindow ]); ui.add(this.movesWindowContainer); const messageContainer = this.scene.add.container(12, -39); @@ -113,7 +113,7 @@ export default class BattleMessageUiHandler extends MessageUiHandler { this.levelUpStatsIncrContent = levelUpStatsIncrContent; - const levelUpStatsValuesContent = addBBCodeTextObject(this.scene, (this.scene.game.canvas.width / 6) - 7, -94, "", TextStyle.WINDOW, { maxLines: 6, lineSpacing: 5}); + const levelUpStatsValuesContent = addBBCodeTextObject(this.scene, (this.scene.game.canvas.width / 6) - 7, -94, "", TextStyle.WINDOW, { maxLines: 6, lineSpacing: 5 }); levelUpStatsValuesContent.setLineSpacing(i18next.resolvedLanguage === "ja" ? 25 : 5); levelUpStatsValuesContent.setOrigin(1, 0); levelUpStatsValuesContent.setAlign("right"); @@ -170,7 +170,7 @@ export default class BattleMessageUiHandler extends MessageUiHandler { if (!this.scene.showLevelUpStats) { return resolve(); } - const newStats = (this.scene as BattleScene).getParty()[partyMemberIndex].stats; + const newStats = (this.scene as BattleScene).getPlayerParty()[partyMemberIndex].stats; let levelUpStatsValuesText = ""; for (const s of PERMANENT_STATS) { levelUpStatsValuesText += `${showTotals ? newStats[s] : newStats[s] - prevStats[s]}\n`; diff --git a/src/ui/bgm-bar.ts b/src/ui/bgm-bar.ts index 936ab91d8fa..616b3ff87cf 100644 --- a/src/ui/bgm-bar.ts +++ b/src/ui/bgm-bar.ts @@ -1,5 +1,5 @@ import BattleScene from "../battle-scene"; -import {addTextObject, TextStyle} from "./text"; +import { addTextObject, TextStyle } from "./text"; import i18next from "i18next"; import * as Utils from "#app/utils"; @@ -88,6 +88,6 @@ export default class BgmBar extends Phaser.GameObjects.Container { } getRealBgmName(bgmName: string): string { - return i18next.t([`bgmName:${bgmName}`, "bgmName:missing_entries"], {name: Utils.formatText(bgmName)}); + return i18next.t([ `bgmName:${bgmName}`, "bgmName:missing_entries" ], { name: Utils.formatText(bgmName) }); } } diff --git a/src/ui/challenges-select-ui-handler.ts b/src/ui/challenges-select-ui-handler.ts index e08736d2b70..e2547a626de 100644 --- a/src/ui/challenges-select-ui-handler.ts +++ b/src/ui/challenges-select-ui-handler.ts @@ -3,7 +3,7 @@ import { TextStyle, addTextObject } from "./text"; import { Mode } from "./ui"; import UiHandler from "./ui-handler"; import { addWindow } from "./ui-theme"; -import {Button} from "#enums/buttons"; +import { Button } from "#enums/buttons"; import i18next from "i18next"; import { Challenge } from "#app/data/challenge"; import * as Utils from "../utils"; @@ -28,7 +28,7 @@ export default class GameChallengesUiHandler extends UiHandler { private descriptionText: BBCodeText; - private challengeLabels: Array<{ label: Phaser.GameObjects.Text, value: Phaser.GameObjects.Text }>; + private challengeLabels: Array<{ label: Phaser.GameObjects.Text, value: Phaser.GameObjects.Text, leftArrow: Phaser.GameObjects.Image, rightArrow: Phaser.GameObjects.Image }>; private monoTypeValue: Phaser.GameObjects.Sprite; private cursorObj: Phaser.GameObjects.NineSlice | null; @@ -40,6 +40,11 @@ export default class GameChallengesUiHandler extends UiHandler { private optionsWidth: number; + private widestTextBox: number; + + private readonly leftArrowGap: number = 90; // distance from the label to the left arrow + private readonly arrowSpacing: number = 3; // distance between the arrows and the value area + constructor(scene: BattleScene, mode: Mode | null = null) { super(scene, mode); } @@ -47,6 +52,8 @@ export default class GameChallengesUiHandler extends UiHandler { setup() { const ui = this.getUi(); + this.widestTextBox = 0; + this.challengesContainer = this.scene.add.container(1, -(this.scene.game.canvas.height / 6) + 1); this.challengesContainer.setName("challenges"); @@ -103,7 +110,7 @@ export default class GameChallengesUiHandler extends UiHandler { }); this.descriptionText.setName("text-desc"); this.scene.add.existing(this.descriptionText); - this.descriptionText.setScale(1/6); + this.descriptionText.setScale(1 / 6); this.descriptionText.setShadow(4, 5, ShadowColor.ORANGE); this.descriptionText.setOrigin(0, 0); @@ -135,6 +142,20 @@ export default class GameChallengesUiHandler extends UiHandler { this.valuesContainer.add(label); + const leftArrow = this.scene.add.image(0, 0, "cursor_reverse"); + leftArrow.setName(`challenge-left-arrow-${i}`); + leftArrow.setOrigin(0, 0); + leftArrow.setVisible(false); + leftArrow.setScale(0.75); + this.valuesContainer.add(leftArrow); + + const rightArrow = this.scene.add.image(0, 0, "cursor"); + rightArrow.setName(`challenge-right-arrow-${i}`); + rightArrow.setOrigin(0, 0); + rightArrow.setScale(0.75); + rightArrow.setVisible(false); + this.valuesContainer.add(rightArrow); + const value = addTextObject(this.scene, 0, 28 + i * 16, "", TextStyle.SETTINGS_LABEL); value.setName(`challenge-value-text-${i}`); value.setPositionRelative(label, 100, 0); @@ -142,7 +163,9 @@ export default class GameChallengesUiHandler extends UiHandler { this.challengeLabels[i] = { label: label, - value: value + value: value, + leftArrow: leftArrow, + rightArrow: rightArrow }; } @@ -187,10 +210,26 @@ export default class GameChallengesUiHandler extends UiHandler { */ initLabels(): void { this.setDescription(this.scene.gameMode.challenges[0].getDescription()); + this.widestTextBox = 0; for (let i = 0; i < 9; i++) { if (i < this.scene.gameMode.challenges.length) { this.challengeLabels[i].label.setVisible(true); this.challengeLabels[i].value.setVisible(true); + this.challengeLabels[i].leftArrow.setVisible(true); + this.challengeLabels[i].rightArrow.setVisible(true); + + const tempText = addTextObject(this.scene, 0, 0, "", TextStyle.SETTINGS_LABEL); // this is added here to get the widest text object for this language, which will be used for the arrow placement + + for (let j = 0; j <= this.scene.gameMode.challenges[i].maxValue; j++) { // this goes through each challenge's value to find out what the max width will be + if (this.scene.gameMode.challenges[i].id !== Challenges.SINGLE_TYPE) { + tempText.setText(this.scene.gameMode.challenges[i].getValue(j)); + if (tempText.displayWidth > this.widestTextBox) { + this.widestTextBox = tempText.displayWidth; + } + } + } + + tempText.destroy(); } } } @@ -203,16 +242,33 @@ export default class GameChallengesUiHandler extends UiHandler { let monoTypeVisible = false; for (let i = 0; i < Math.min(9, this.scene.gameMode.challenges.length); i++) { const challenge = this.scene.gameMode.challenges[this.scrollCursor + i]; - this.challengeLabels[i].label.setText(challenge.getName()); + const challengeLabel = this.challengeLabels[i]; + challengeLabel.label.setText(challenge.getName()); + challengeLabel.leftArrow.setPositionRelative(challengeLabel.label, this.leftArrowGap, 4.5); + challengeLabel.leftArrow.setVisible(challenge.value !== 0); + challengeLabel.rightArrow.setPositionRelative(challengeLabel.leftArrow, Math.max(this.monoTypeValue.width, this.widestTextBox) + challengeLabel.leftArrow.displayWidth + 2 * this.arrowSpacing, 0); + challengeLabel.rightArrow.setVisible(challenge.value !== challenge.maxValue); + + // this check looks to make sure that the arrows and value textbox don't take up too much space that they'll clip the right edge of the options background + if (challengeLabel.rightArrow.x + challengeLabel.rightArrow.width + this.optionsBg.rightWidth + this.arrowSpacing > this.optionsWidth) { + // if we go out of bounds of the box, set the x position as far right as we can without going past the box, with this.arrowSpacing to allow a small gap between the arrow and border + challengeLabel.rightArrow.setX(this.optionsWidth - this.arrowSpacing - this.optionsBg.rightWidth); + } + + // this line of code gets the center point between the left and right arrows from their left side (Arrow.x gives middle point), taking into account the width of the arrows + const xLocation = Math.round((challengeLabel.leftArrow.x + challengeLabel.rightArrow.x + challengeLabel.leftArrow.displayWidth) / 2); if (challenge.id === Challenges.SINGLE_TYPE) { - this.monoTypeValue.setPositionRelative(this.challengeLabels[i].label, 113, 8); + this.monoTypeValue.setX(xLocation); + this.monoTypeValue.setY(challengeLabel.label.y + 8); this.monoTypeValue.setFrame(challenge.getValue()); this.monoTypeValue.setVisible(true); - this.challengeLabels[i].value.setVisible(false); + challengeLabel.value.setVisible(false); monoTypeVisible = true; } else { - this.challengeLabels[i].value.setText(challenge.getValue()); - this.challengeLabels[i].value.setVisible(true); + challengeLabel.value.setText(challenge.getValue()); + challengeLabel.value.setX(xLocation); + challengeLabel.value.setOrigin(0.5, 0); + challengeLabel.value.setVisible(true); } } if (!monoTypeVisible) { @@ -244,6 +300,7 @@ export default class GameChallengesUiHandler extends UiHandler { super.show(args); this.startCursor.setVisible(false); + this.updateChallengeArrows(false); this.challengesContainer.setVisible(true); // Should always be false at the start this.hasSelectedChallenge = this.scene.gameMode.challenges.some(c => c.value !== 0); @@ -259,6 +316,21 @@ export default class GameChallengesUiHandler extends UiHandler { return true; } + /* This code updates the challenge starter arrows to be tinted/not tinted when the start button is selected to show they can't be changed + */ + updateChallengeArrows(tinted: boolean) { + for (let i = 0; i < Math.min(9, this.scene.gameMode.challenges.length); i++) { + const challengeLabel = this.challengeLabels[i]; + if (tinted) { + challengeLabel.leftArrow.setTint(0x808080); + challengeLabel.rightArrow.setTint(0x808080); + } else { + challengeLabel.leftArrow.clearTint(); + challengeLabel.rightArrow.clearTint(); + } + } + } + /** * Processes input from a specified button. * This method handles navigation through a UI menu, including movement through menu items @@ -280,6 +352,7 @@ export default class GameChallengesUiHandler extends UiHandler { // If the user presses cancel when the start cursor has been activated, the game deactivates the start cursor and allows typical challenge selection behavior this.startCursor.setVisible(false); this.cursorObj?.setVisible(true); + this.updateChallengeArrows(this.startCursor.visible); } else { this.scene.clearPhaseQueue(); this.scene.pushPhase(new TitlePhase(this.scene)); @@ -294,6 +367,7 @@ export default class GameChallengesUiHandler extends UiHandler { } else { this.startCursor.setVisible(true); this.cursorObj?.setVisible(false); + this.updateChallengeArrows(this.startCursor.visible); } success = true; } else { @@ -302,66 +376,66 @@ export default class GameChallengesUiHandler extends UiHandler { } else { if (this.cursorObj?.visible && !this.startCursor.visible) { switch (button) { - case Button.UP: - if (this.cursor === 0) { - if (this.scrollCursor === 0) { + case Button.UP: + if (this.cursor === 0) { + if (this.scrollCursor === 0) { // When at the top of the menu and pressing UP, move to the bottommost item. - if (this.scene.gameMode.challenges.length > rowsToDisplay) { // If there are more than 9 challenges, scroll to the bottom + if (this.scene.gameMode.challenges.length > rowsToDisplay) { // If there are more than 9 challenges, scroll to the bottom // First, set the cursor to the last visible element, preparing for the scroll to the end. - const successA = this.setCursor(rowsToDisplay - 1); - // Then, adjust the scroll to display the bottommost elements of the menu. - const successB = this.setScrollCursor(this.scene.gameMode.challenges.length - rowsToDisplay); - success = successA && successB; // success is just there to play the little validation sound effect - } else { // If there are 9 or less challenges, just move to the bottom one - success = this.setCursor(this.scene.gameMode.challenges.length - 1); + const successA = this.setCursor(rowsToDisplay - 1); + // Then, adjust the scroll to display the bottommost elements of the menu. + const successB = this.setScrollCursor(this.scene.gameMode.challenges.length - rowsToDisplay); + success = successA && successB; // success is just there to play the little validation sound effect + } else { // If there are 9 or less challenges, just move to the bottom one + success = this.setCursor(this.scene.gameMode.challenges.length - 1); + } + } else { + success = this.setScrollCursor(this.scrollCursor - 1); } } else { - success = this.setScrollCursor(this.scrollCursor - 1); + success = this.setCursor(this.cursor - 1); } - } else { - success = this.setCursor(this.cursor - 1); - } - if (success) { - this.updateText(); - } - break; - case Button.DOWN: - if (this.cursor === rowsToDisplay - 1) { - if (this.scrollCursor < this.scene.gameMode.challenges.length - rowsToDisplay) { + if (success) { + this.updateText(); + } + break; + case Button.DOWN: + if (this.cursor === rowsToDisplay - 1) { + if (this.scrollCursor < this.scene.gameMode.challenges.length - rowsToDisplay) { // When at the bottom and pressing DOWN, scroll if possible. - success = this.setScrollCursor(this.scrollCursor + 1); - } else { + success = this.setScrollCursor(this.scrollCursor + 1); + } else { // When at the bottom of a scrolling menu and pressing DOWN, move to the topmost item. // First, set the cursor to the first visible element, preparing for the scroll to the top. - const successA = this.setCursor(0); - // Then, adjust the scroll to display the topmost elements of the menu. - const successB = this.setScrollCursor(0); - success = successA && successB; // success is just there to play the little validation sound effect - } - } else if (this.scene.gameMode.challenges.length < rowsToDisplay && this.cursor === this.scene.gameMode.challenges.length - 1) { + const successA = this.setCursor(0); + // Then, adjust the scroll to display the topmost elements of the menu. + const successB = this.setScrollCursor(0); + success = successA && successB; // success is just there to play the little validation sound effect + } + } else if (this.scene.gameMode.challenges.length < rowsToDisplay && this.cursor === this.scene.gameMode.challenges.length - 1) { // When at the bottom of a non-scrolling menu and pressing DOWN, move to the topmost item. - success = this.setCursor(0); - } else { - success = this.setCursor(this.cursor + 1); - } - if (success) { - this.updateText(); - } - break; - case Button.LEFT: + success = this.setCursor(0); + } else { + success = this.setCursor(this.cursor + 1); + } + if (success) { + this.updateText(); + } + break; + case Button.LEFT: // Moves the option cursor left, if possible. - success = this.getActiveChallenge().decreaseValue(); - if (success) { - this.updateText(); - } - break; - case Button.RIGHT: + success = this.getActiveChallenge().decreaseValue(); + if (success) { + this.updateText(); + } + break; + case Button.RIGHT: // Moves the option cursor right, if possible. - success = this.getActiveChallenge().increaseValue(); - if (success) { - this.updateText(); - } - break; + success = this.getActiveChallenge().increaseValue(); + if (success) { + this.updateText(); + } + break; } } } diff --git a/src/ui/command-ui-handler.ts b/src/ui/command-ui-handler.ts index 764e71a8c3f..0dacacc7b70 100644 --- a/src/ui/command-ui-handler.ts +++ b/src/ui/command-ui-handler.ts @@ -4,7 +4,7 @@ import PartyUiHandler, { PartyUiMode } from "./party-ui-handler"; import { Mode } from "./ui"; import UiHandler from "./ui-handler"; import i18next from "i18next"; -import {Button} from "#enums/buttons"; +import { Button } from "#enums/buttons"; import { getPokemonNameWithAffix } from "#app/messages"; import { CommandPhase } from "#app/phases/command-phase"; @@ -67,7 +67,7 @@ export default class CommandUiHandler extends UiHandler { messageHandler.commandWindow.setVisible(true); messageHandler.movesWindowContainer.setVisible(false); messageHandler.message.setWordWrapWidth(1110); - messageHandler.showText(i18next.t("commandUiHandler:actionMessage", {pokemonName: getPokemonNameWithAffix(commandPhase.getPokemon())}), 0); + messageHandler.showText(i18next.t("commandUiHandler:actionMessage", { pokemonName: getPokemonNameWithAffix(commandPhase.getPokemon()) }), 0); if (this.getCursor() === Command.POKEMON) { this.setCursor(Command.FIGHT); } else { @@ -89,54 +89,51 @@ export default class CommandUiHandler extends UiHandler { if (button === Button.ACTION) { switch (cursor) { // Fight - case Command.FIGHT: - if ((this.scene.getCurrentPhase() as CommandPhase).checkFightOverride()) { - return true; - } - ui.setMode(Mode.FIGHT, (this.scene.getCurrentPhase() as CommandPhase).getFieldIndex()); - success = true; - break; + case Command.FIGHT: + ui.setMode(Mode.FIGHT, (this.scene.getCurrentPhase() as CommandPhase).getFieldIndex()); + success = true; + break; // Ball - case Command.BALL: - ui.setModeWithoutClear(Mode.BALL); - success = true; - break; + case Command.BALL: + ui.setModeWithoutClear(Mode.BALL); + success = true; + break; // Pokemon - case Command.POKEMON: - ui.setMode(Mode.PARTY, PartyUiMode.SWITCH, (this.scene.getCurrentPhase() as CommandPhase).getPokemon().getFieldIndex(), null, PartyUiHandler.FilterNonFainted); - success = true; - break; + case Command.POKEMON: + ui.setMode(Mode.PARTY, PartyUiMode.SWITCH, (this.scene.getCurrentPhase() as CommandPhase).getPokemon().getFieldIndex(), null, PartyUiHandler.FilterNonFainted); + success = true; + break; // Run - case Command.RUN: - (this.scene.getCurrentPhase() as CommandPhase).handleCommand(Command.RUN, 0); - success = true; - break; + case Command.RUN: + (this.scene.getCurrentPhase() as CommandPhase).handleCommand(Command.RUN, 0); + success = true; + break; } } else { (this.scene.getCurrentPhase() as CommandPhase).cancel(); } } else { switch (button) { - case Button.UP: - if (cursor >= 2) { - success = this.setCursor(cursor - 2); - } - break; - case Button.DOWN: - if (cursor < 2) { - success = this.setCursor(cursor + 2); - } - break; - case Button.LEFT: - if (cursor % 2 === 1) { - success = this.setCursor(cursor - 1); - } - break; - case Button.RIGHT: - if (cursor % 2 === 0) { - success = this.setCursor(cursor + 1); - } - break; + case Button.UP: + if (cursor >= 2) { + success = this.setCursor(cursor - 2); + } + break; + case Button.DOWN: + if (cursor < 2) { + success = this.setCursor(cursor + 2); + } + break; + case Button.LEFT: + if (cursor % 2 === 1) { + success = this.setCursor(cursor - 1); + } + break; + case Button.RIGHT: + if (cursor % 2 === 0) { + success = this.setCursor(cursor + 1); + } + break; } } diff --git a/src/ui/confirm-ui-handler.ts b/src/ui/confirm-ui-handler.ts index 4a60b0c9689..2022508fc0d 100644 --- a/src/ui/confirm-ui-handler.ts +++ b/src/ui/confirm-ui-handler.ts @@ -2,7 +2,7 @@ import BattleScene from "../battle-scene"; import AbstractOptionSelectUiHandler, { OptionSelectConfig } from "./abstact-option-select-ui-handler"; import { Mode } from "./ui"; import i18next from "i18next"; -import {Button} from "#enums/buttons"; +import { Button } from "#enums/buttons"; export default class ConfirmUiHandler extends AbstractOptionSelectUiHandler { @@ -76,7 +76,8 @@ export default class ConfirmUiHandler extends AbstractOptionSelectUiHandler { } } ], - delay: args.length >= 6 && args[5] !== null ? args[5] as integer : 0 + delay: args.length >= 6 && args[5] !== null ? args[5] as number : 0, + noCancel: args.length >= 7 && args[6] !== null ? args[6] as boolean : false, }; super.show([ config ]); @@ -96,7 +97,7 @@ export default class ConfirmUiHandler extends AbstractOptionSelectUiHandler { } processInput(button: Button): boolean { - if (button === Button.CANCEL && this.blockInput) { + if (button === Button.CANCEL && this.blockInput && !this.config?.noCancel) { this.unblockInput(); } diff --git a/src/ui/daily-run-scoreboard.ts b/src/ui/daily-run-scoreboard.ts index b535a94d35c..bb93b1fb1f5 100644 --- a/src/ui/daily-run-scoreboard.ts +++ b/src/ui/daily-run-scoreboard.ts @@ -3,8 +3,9 @@ import BattleScene from "../battle-scene"; import * as Utils from "../utils"; import { TextStyle, addTextObject } from "./text"; import { WindowVariant, addWindow } from "./ui-theme"; +import { pokerogueApi } from "#app/plugins/api/pokerogue-api"; -interface RankingEntry { +export interface RankingEntry { rank: integer, username: string, score: integer, @@ -12,7 +13,7 @@ interface RankingEntry { } // Don't forget to update translations when adding a new category -enum ScoreboardCategory { +export enum ScoreboardCategory { DAILY, WEEKLY } @@ -142,13 +143,13 @@ export class DailyRunScoreboard extends Phaser.GameObjects.Container { entryContainer.add(scoreLabel); switch (this.category) { - case ScoreboardCategory.DAILY: - const waveLabel = addTextObject(this.scene, 68, 0, wave, TextStyle.WINDOW, { fontSize: "54px" }); - entryContainer.add(waveLabel); - break; - case ScoreboardCategory.WEEKLY: - scoreLabel.x -= 16; - break; + case ScoreboardCategory.DAILY: + const waveLabel = addTextObject(this.scene, 68, 0, wave, TextStyle.WINDOW, { fontSize: "54px" }); + entryContainer.add(waveLabel); + break; + case ScoreboardCategory.WEEKLY: + scoreLabel.x -= 16; + break; } return entryContainer; @@ -191,18 +192,17 @@ export class DailyRunScoreboard extends Phaser.GameObjects.Container { } Utils.executeIf(category !== this.category || this.pageCount === undefined, - () => Utils.apiFetch(`daily/rankingpagecount?category=${category}`).then(response => response.json()).then(count => this.pageCount = count) + () => pokerogueApi.daily.getRankingsPageCount({ category }).then(count => this.pageCount = count) ).then(() => { - Utils.apiFetch(`daily/rankings?category=${category}&page=${page}`) - .then(response => response.json()) - .then(jsonResponse => { + pokerogueApi.daily.getRankings({ category, page }) + .then(rankings => { this.page = page; this.category = category; this.titleLabel.setText(`${i18next.t(`menu:${ScoreboardCategory[category].toLowerCase()}Rankings`)}`); this.pageNumberLabel.setText(page.toString()); - if (jsonResponse) { + if (rankings) { this.loadingLabel.setVisible(false); - this.updateRankings(jsonResponse); + this.updateRankings(rankings); } else { this.loadingLabel.setText(i18next.t("menu:noRankings")); } diff --git a/src/ui/dropdown.ts b/src/ui/dropdown.ts index 4e1235c211d..e16efe17036 100644 --- a/src/ui/dropdown.ts +++ b/src/ui/dropdown.ts @@ -64,7 +64,7 @@ export class DropDownOption extends Phaser.GameObjects.Container { if (Array.isArray(labels)) { this.labels = labels; } else { - this.labels = labels? [ labels ] : [ new DropDownLabel("") ]; + this.labels = labels ? [ labels ] : [ new DropDownLabel("") ]; } this.currentLabelIndex = 0; const currentLabel = this.labels[this.currentLabelIndex]; @@ -75,12 +75,12 @@ export class DropDownOption extends Phaser.GameObjects.Container { this.add(this.text); // Add to container the sprite for each label if there is one - for (let i=0; i < this.labels.length; i++) { + for (let i = 0; i < this.labels.length; i++) { const sprite = this.labels[i].sprite; if (sprite) { this.add(sprite); sprite.setOrigin(0, 0.5); - if (i!== this.currentLabelIndex) { + if (i !== this.currentLabelIndex) { sprite.setVisible(false); } } @@ -115,18 +115,18 @@ export class DropDownOption extends Phaser.GameObjects.Container { */ private updateToggleIconColor(): void { switch (this.state) { - case DropDownState.ON: - this.toggle.setTint(this.onColor); - break; - case DropDownState.OFF: - this.toggle.setTint(this.offColor); - break; - case DropDownState.EXCLUDE: - this.toggle.setTint(this.excludeColor); - break; - case DropDownState.UNLOCKABLE: - this.toggle.setTint(this.unlockableColor); - break; + case DropDownState.ON: + this.toggle.setTint(this.onColor); + break; + case DropDownState.OFF: + this.toggle.setTint(this.offColor); + break; + case DropDownState.EXCLUDE: + this.toggle.setTint(this.excludeColor); + break; + case DropDownState.UNLOCKABLE: + this.toggle.setTint(this.unlockableColor); + break; } } @@ -215,7 +215,7 @@ export class DropDownOption extends Phaser.GameObjects.Container { */ setLabelPosition(x: number, y: number) { let textX = x; - for (let i=0; i < this.labels.length; i++) { + for (let i = 0; i < this.labels.length; i++) { const label = this.labels[i]; if (label.sprite) { label.sprite.x = x; @@ -261,7 +261,7 @@ export class DropDownOption extends Phaser.GameObjects.Container { const currentText = this.text.text; for (const label of this.labels) { this.text.setText(label.text); - const spriteWidth = label.sprite? label.sprite.displayWidth + 2 : 0; + const spriteWidth = label.sprite ? label.sprite.displayWidth + 2 : 0; w = Math.max(w, this.text.displayWidth + spriteWidth); } this.text.setText(currentText); @@ -334,7 +334,7 @@ export class DropDown extends Phaser.GameObjects.Container { } getWidth(): number { - return this.window? this.window.width : this.width; + return this.window ? this.window.width : this.width; } toggleVisibility(): void { @@ -460,7 +460,7 @@ export class DropDown extends Phaser.GameObjects.Container { return this.options.filter((_, i) => i > 0).map(option => option.val); } // if nothing is selected and a single option is hovered, return that one - return [this.options[this.cursor].val]; + return [ this.options[this.cursor].val ]; } else if (this.dropDownType === DropDownType.RADIAL) { return this.options.map((option) => { return { val: option.val, state: option.state }; @@ -500,18 +500,18 @@ export class DropDown extends Phaser.GameObjects.Container { }; switch (this.dropDownType) { - case DropDownType.MULTI: - case DropDownType.RADIAL: - return compareValues(["val", "state"]); + case DropDownType.MULTI: + case DropDownType.RADIAL: + return compareValues([ "val", "state" ]); - case DropDownType.HYBRID: - return compareValues(["val", "state", "cursor"]); + case DropDownType.HYBRID: + return compareValues([ "val", "state", "cursor" ]); - case DropDownType.SINGLE: - return compareValues(["val", "state", "dir"]); + case DropDownType.SINGLE: + return compareValues([ "val", "state", "dir" ]); - default: - return false; + default: + return false; } } diff --git a/src/ui/egg-gacha-ui-handler.ts b/src/ui/egg-gacha-ui-handler.ts index b109eda5370..b14f5381a84 100644 --- a/src/ui/egg-gacha-ui-handler.ts +++ b/src/ui/egg-gacha-ui-handler.ts @@ -8,7 +8,7 @@ import { VoucherType, getVoucherTypeIcon } from "../system/voucher"; import { getPokemonSpecies } from "../data/pokemon-species"; import { addWindow } from "./ui-theme"; import { Tutorial, handleTutorial } from "../tutorial"; -import {Button} from "#enums/buttons"; +import { Button } from "#enums/buttons"; import Overrides from "#app/overrides"; import { GachaType } from "#app/enums/gacha-types"; import i18next from "i18next"; @@ -34,6 +34,7 @@ export default class EggGachaUiHandler extends MessageUiHandler { private cursorObj: Phaser.GameObjects.Image; private transitioning: boolean; private transitionCancelled: boolean; + private summaryFinished: boolean; private defaultText: string; private scale: number = 0.1666666667; @@ -99,14 +100,14 @@ export default class EggGachaUiHandler extends MessageUiHandler { const gachaInfoContainer = this.scene.add.container(160, 46); - const currentLanguage = i18next.resolvedLanguage!; // TODO: is this bang correct? + const currentLanguage = i18next.resolvedLanguage ?? "en"; let gachaTextStyle = TextStyle.WINDOW_ALT; let gachaX = 4; let gachaY = 0; let pokemonIconX = -20; let pokemonIconY = 6; - if (["de", "es", "fr", "ko", "pt-BR"].includes(currentLanguage)) { + if ([ "de", "es-ES", "fr", "ko", "pt-BR" ].includes(currentLanguage)) { gachaTextStyle = TextStyle.SMALLER_WINDOW_ALT; gachaX = 2; gachaY = 2; @@ -114,7 +115,7 @@ export default class EggGachaUiHandler extends MessageUiHandler { let legendaryLabelX = gachaX; let legendaryLabelY = gachaY; - if (["de", "es"].includes(currentLanguage)) { + if ([ "de", "es-ES" ].includes(currentLanguage)) { pokemonIconX = -25; pokemonIconY = 10; legendaryLabelX = -6; @@ -126,47 +127,47 @@ export default class EggGachaUiHandler extends MessageUiHandler { gachaInfoContainer.add(gachaUpLabel); switch (gachaType as GachaType) { - case GachaType.LEGENDARY: - if (["de", "es"].includes(currentLanguage)) { - gachaUpLabel.setAlign("center"); - gachaUpLabel.setY(0); - } - if (["pt-BR"].includes(currentLanguage)) { - gachaUpLabel.setX(legendaryLabelX - 2); - } else { - gachaUpLabel.setX(legendaryLabelX); - } - gachaUpLabel.setY(legendaryLabelY); + case GachaType.LEGENDARY: + if ([ "de", "es-ES" ].includes(currentLanguage)) { + gachaUpLabel.setAlign("center"); + gachaUpLabel.setY(0); + } + if ([ "pt-BR" ].includes(currentLanguage)) { + gachaUpLabel.setX(legendaryLabelX - 2); + } else { + gachaUpLabel.setX(legendaryLabelX); + } + gachaUpLabel.setY(legendaryLabelY); - const pokemonIcon = this.scene.add.sprite(pokemonIconX, pokemonIconY, "pokemon_icons_0"); - if (["pt-BR"].includes(currentLanguage)) { - pokemonIcon.setX(pokemonIconX - 2); - } - pokemonIcon.setScale(0.5); - pokemonIcon.setOrigin(0, 0.5); + const pokemonIcon = this.scene.add.sprite(pokemonIconX, pokemonIconY, "pokemon_icons_0"); + if ([ "pt-BR" ].includes(currentLanguage)) { + pokemonIcon.setX(pokemonIconX - 2); + } + pokemonIcon.setScale(0.5); + pokemonIcon.setOrigin(0, 0.5); - gachaInfoContainer.add(pokemonIcon); - break; - case GachaType.MOVE: - if (["de", "es", "fr", "pt-BR"].includes(currentLanguage)) { - gachaUpLabel.setAlign("center"); - gachaUpLabel.setY(0); - } + gachaInfoContainer.add(pokemonIcon); + break; + case GachaType.MOVE: + if ([ "de", "es-ES", "fr", "pt-BR" ].includes(currentLanguage)) { + gachaUpLabel.setAlign("center"); + gachaUpLabel.setY(0); + } - gachaUpLabel.setText(i18next.t("egg:moveUPGacha")); - gachaUpLabel.setX(0); - gachaUpLabel.setOrigin(0.5, 0); - break; - case GachaType.SHINY: - if (["de", "fr", "ko"].includes(currentLanguage)) { - gachaUpLabel.setAlign("center"); - gachaUpLabel.setY(0); - } + gachaUpLabel.setText(i18next.t("egg:moveUPGacha")); + gachaUpLabel.setX(0); + gachaUpLabel.setOrigin(0.5, 0); + break; + case GachaType.SHINY: + if ([ "de", "fr", "ko" ].includes(currentLanguage)) { + gachaUpLabel.setAlign("center"); + gachaUpLabel.setY(0); + } - gachaUpLabel.setText(i18next.t("egg:shinyUPGacha")); - gachaUpLabel.setX(0); - gachaUpLabel.setOrigin(0.5, 0); - break; + gachaUpLabel.setText(i18next.t("egg:shinyUPGacha")); + gachaUpLabel.setX(0); + gachaUpLabel.setOrigin(0.5, 0); + break; } const gachaKnob = this.scene.add.sprite(191, 89, "gacha_knob"); @@ -217,11 +218,11 @@ export default class EggGachaUiHandler extends MessageUiHandler { { multiplier: multiplierOne, description: `25 ${i18next.t("egg:pulls")}`, icon: getVoucherTypeIcon(VoucherType.GOLDEN) } ]; - const resolvedLanguage = i18next.resolvedLanguage!; // TODO: is this bang correct? + const resolvedLanguage = i18next.resolvedLanguage ?? "en"; const pullOptionsText = pullOptions.map(option =>{ const desc = option.description.split(" "); if (desc[0].length < 2) { - desc[0] += ["zh", "ko"].includes(resolvedLanguage.substring(0, 2)) ? " " : " "; + desc[0] += [ "zh", "ko" ].includes(resolvedLanguage.substring(0, 2)) ? " " : " "; } if (option.multiplier === multiplierOne) { desc[0] = " " + desc[0]; @@ -469,17 +470,22 @@ export default class EggGachaUiHandler extends MessageUiHandler { getGuaranteedEggTierFromPullCount(pullCount: number): EggTier { switch (pullCount) { - case 10: - return EggTier.GREAT; - case 25: - return EggTier.ULTRA; - default: - return EggTier.COMMON; + case 10: + return EggTier.RARE; + case 25: + return EggTier.EPIC; + default: + return EggTier.COMMON; } } showSummary(eggs: Egg[]): void { - this.transitioning = false; + // the overlay will appear faster if the egg pulling animation was skipped + const overlayEaseInDuration = this.getDelayValue(750); + + this.summaryFinished = false; + this.transitionCancelled = false; + this.setTransitioning(true); this.eggGachaSummaryContainer.setVisible(true); const eggScale = eggs.length < 20 ? 1 : 0.5; @@ -488,12 +494,14 @@ export default class EggGachaUiHandler extends MessageUiHandler { targets: this.eggGachaOverlay, alpha: 0.5, ease: "Sine.easeOut", - duration: 750, + duration: overlayEaseInDuration, onComplete: () => { const rowItems = 5; const rows = Math.ceil(eggs.length / rowItems); const cols = Math.min(eggs.length, rowItems); const height = this.eggGachaOverlay.displayHeight - this.eggGachaMessageBox.displayHeight; + + // Create sprites for each egg const eggContainers = eggs.map((egg, t) => { const col = t % rowItems; const row = Math.floor(t / rowItems); @@ -508,21 +516,31 @@ export default class EggGachaUiHandler extends MessageUiHandler { const eggText = addTextObject(this.scene, 0, 14, egg.getEggDescriptor(), TextStyle.PARTY, { align: "center" }); eggText.setOrigin(0.5, 0); - eggText.setTint(getEggTierTextTint(!egg.isManaphyEgg() ? egg.tier : EggTier.ULTRA)); + eggText.setTint(getEggTierTextTint(!egg.isManaphyEgg() ? egg.tier : EggTier.EPIC)); ret.add(eggText); this.eggGachaSummaryContainer.addAt(ret, 0); return ret; }); - eggContainers.forEach((eggContainer, e) => { - this.scene.tweens.add({ - targets: eggContainer, - delay: this.getDelayValue(e * 100), - duration: this.getDelayValue(350), - scale: eggScale, - ease: "Sine.easeOut" - }); + // If action/cancel was pressed when the overlay was easing in, show all eggs at once + // Otherwise show the eggs one by one with a small delay between each + eggContainers.forEach((eggContainer, index) => { + const delay = !this.transitionCancelled ? this.getDelayValue(index * 100) : 0; + this.scene.time.delayedCall(delay, () => + this.scene.tweens.add({ + targets: eggContainer, + duration: this.getDelayValue(350), + scale: eggScale, + ease: "Sine.easeOut", + onComplete: () => { + if (index === eggs.length - 1) { + this.setTransitioning(false); + this.summaryFinished = true; + } + } + })); + }); } }); @@ -540,6 +558,7 @@ export default class EggGachaUiHandler extends MessageUiHandler { this.eggGachaSummaryContainer.setAlpha(1); this.eggGachaSummaryContainer.removeAll(true); this.setTransitioning(false); + this.summaryFinished = false; this.eggGachaOptionsContainer.setVisible(true); } }); @@ -548,11 +567,11 @@ export default class EggGachaUiHandler extends MessageUiHandler { updateGachaInfo(gachaType: GachaType): void { const infoContainer = this.gachaInfoContainers[gachaType]; switch (gachaType as GachaType) { - case GachaType.LEGENDARY: - const species = getPokemonSpecies(getLegendaryGachaSpeciesForTimestamp(this.scene, new Date().getTime())); - const pokemonIcon = infoContainer.getAt(1) as Phaser.GameObjects.Sprite; - pokemonIcon.setTexture(species.getIconAtlasKey(), species.getIconId(false)); - break; + case GachaType.LEGENDARY: + const species = getPokemonSpecies(getLegendaryGachaSpeciesForTimestamp(this.scene, new Date().getTime())); + const pokemonIcon = infoContainer.getAt(1) as Phaser.GameObjects.Sprite; + pokemonIcon.setTexture(species.getIconAtlasKey(), species.getIconId(false)); + break; } } @@ -613,112 +632,112 @@ export default class EggGachaUiHandler extends MessageUiHandler { } else { if (this.eggGachaSummaryContainer.visible) { - if (button === Button.ACTION || button === Button.CANCEL) { + if (this.summaryFinished && (button === Button.ACTION || button === Button.CANCEL)) { this.hideSummary(); success = true; } } else { switch (button) { - case Button.ACTION: - switch (this.cursor) { - case 0: - if (!this.scene.gameData.voucherCounts[VoucherType.REGULAR] && !Overrides.EGG_FREE_GACHA_PULLS_OVERRIDE) { - error = true; - this.showError(i18next.t("egg:notEnoughVouchers")); - } else if (this.scene.gameData.eggs.length < 99) { - if (!Overrides.EGG_FREE_GACHA_PULLS_OVERRIDE) { - this.consumeVouchers(VoucherType.REGULAR, 1); - } - this.pull(); - success = true; - } else { - error = true; - this.showError(i18next.t("egg:tooManyEggs")); - } - break; - case 2: - if (!this.scene.gameData.voucherCounts[VoucherType.PLUS] && !Overrides.EGG_FREE_GACHA_PULLS_OVERRIDE) { - error = true; - this.showError(i18next.t("egg:notEnoughVouchers")); - } else if (this.scene.gameData.eggs.length < 95) { - if (!Overrides.EGG_FREE_GACHA_PULLS_OVERRIDE) { - this.consumeVouchers(VoucherType.PLUS, 1); - } - this.pull(5); - success = true; - } else { - error = true; - this.showError(i18next.t("egg:tooManyEggs")); - } - break; - case 1: - case 3: - if ((this.cursor === 1 && this.scene.gameData.voucherCounts[VoucherType.REGULAR] < 10 && !Overrides.EGG_FREE_GACHA_PULLS_OVERRIDE) + case Button.ACTION: + switch (this.cursor) { + case 0: + if (!this.scene.gameData.voucherCounts[VoucherType.REGULAR] && !Overrides.EGG_FREE_GACHA_PULLS_OVERRIDE) { + error = true; + this.showError(i18next.t("egg:notEnoughVouchers")); + } else if (this.scene.gameData.eggs.length < 99 || Overrides.UNLIMITED_EGG_COUNT_OVERRIDE) { + if (!Overrides.EGG_FREE_GACHA_PULLS_OVERRIDE) { + this.consumeVouchers(VoucherType.REGULAR, 1); + } + this.pull(); + success = true; + } else { + error = true; + this.showError(i18next.t("egg:tooManyEggs")); + } + break; + case 2: + if (!this.scene.gameData.voucherCounts[VoucherType.PLUS] && !Overrides.EGG_FREE_GACHA_PULLS_OVERRIDE) { + error = true; + this.showError(i18next.t("egg:notEnoughVouchers")); + } else if (this.scene.gameData.eggs.length < 95 || Overrides.UNLIMITED_EGG_COUNT_OVERRIDE) { + if (!Overrides.EGG_FREE_GACHA_PULLS_OVERRIDE) { + this.consumeVouchers(VoucherType.PLUS, 1); + } + this.pull(5); + success = true; + } else { + error = true; + this.showError(i18next.t("egg:tooManyEggs")); + } + break; + case 1: + case 3: + if ((this.cursor === 1 && this.scene.gameData.voucherCounts[VoucherType.REGULAR] < 10 && !Overrides.EGG_FREE_GACHA_PULLS_OVERRIDE) || (this.cursor === 3 && !this.scene.gameData.voucherCounts[VoucherType.PREMIUM] && !Overrides.EGG_FREE_GACHA_PULLS_OVERRIDE)) { - error = true; - this.showError(i18next.t("egg:notEnoughVouchers")); - } else if (this.scene.gameData.eggs.length < 90) { - if (this.cursor === 3) { - if (!Overrides.EGG_FREE_GACHA_PULLS_OVERRIDE) { - this.consumeVouchers(VoucherType.PREMIUM, 1); + error = true; + this.showError(i18next.t("egg:notEnoughVouchers")); + } else if (this.scene.gameData.eggs.length < 90 || Overrides.UNLIMITED_EGG_COUNT_OVERRIDE) { + if (this.cursor === 3) { + if (!Overrides.EGG_FREE_GACHA_PULLS_OVERRIDE) { + this.consumeVouchers(VoucherType.PREMIUM, 1); + } + } else { + if (!Overrides.EGG_FREE_GACHA_PULLS_OVERRIDE) { + this.consumeVouchers(VoucherType.REGULAR, 10); + } + } + this.pull(10); + success = true; + } else { + error = true; + this.showError(i18next.t("egg:tooManyEggs")); } - } else { - if (!Overrides.EGG_FREE_GACHA_PULLS_OVERRIDE) { - this.consumeVouchers(VoucherType.REGULAR, 10); + break; + case 4: + if (!this.scene.gameData.voucherCounts[VoucherType.GOLDEN] && !Overrides.EGG_FREE_GACHA_PULLS_OVERRIDE) { + error = true; + this.showError(i18next.t("egg:notEnoughVouchers")); + } else if (this.scene.gameData.eggs.length < 75 || Overrides.UNLIMITED_EGG_COUNT_OVERRIDE) { + if (!Overrides.EGG_FREE_GACHA_PULLS_OVERRIDE) { + this.consumeVouchers(VoucherType.GOLDEN, 1); + } + this.pull(25); + success = true; + } else { + error = true; + this.showError(i18next.t("egg:tooManyEggs")); } - } - this.pull(10); - success = true; - } else { - error = true; - this.showError(i18next.t("egg:tooManyEggs")); + break; + case 5: + ui.revertMode(); + success = true; + break; } break; - case 4: - if (!this.scene.gameData.voucherCounts[VoucherType.GOLDEN] && !Overrides.EGG_FREE_GACHA_PULLS_OVERRIDE) { - error = true; - this.showError(i18next.t("egg:notEnoughVouchers")); - } else if (this.scene.gameData.eggs.length < 75) { - if (!Overrides.EGG_FREE_GACHA_PULLS_OVERRIDE) { - this.consumeVouchers(VoucherType.GOLDEN, 1); - } - this.pull(25); - success = true; - } else { - error = true; - this.showError(i18next.t("egg:tooManyEggs")); - } - break; - case 5: - ui.revertMode(); + case Button.CANCEL: + this.getUi().revertMode(); success = true; break; - } - break; - case Button.CANCEL: - this.getUi().revertMode(); - success = true; - break; - case Button.UP: - if (this.cursor) { - success = this.setCursor(this.cursor - 1); - } - break; - case Button.DOWN: - if (this.cursor < 5) { - success = this.setCursor(this.cursor + 1); - } - break; - case Button.LEFT: - if (this.gachaCursor) { - success = this.setGachaCursor(this.gachaCursor - 1); - } - break; - case Button.RIGHT: - if (this.gachaCursor < Utils.getEnumKeys(GachaType).length - 1) { - success = this.setGachaCursor(this.gachaCursor + 1); - } - break; + case Button.UP: + if (this.cursor) { + success = this.setCursor(this.cursor - 1); + } + break; + case Button.DOWN: + if (this.cursor < 5) { + success = this.setCursor(this.cursor + 1); + } + break; + case Button.LEFT: + if (this.gachaCursor) { + success = this.setGachaCursor(this.gachaCursor - 1); + } + break; + case Button.RIGHT: + if (this.gachaCursor < Utils.getEnumKeys(GachaType).length - 1) { + success = this.setGachaCursor(this.gachaCursor + 1); + } + break; } } } diff --git a/src/ui/egg-hatch-scene-handler.ts b/src/ui/egg-hatch-scene-handler.ts index 7b01ef7a3a6..1bf58a786e1 100644 --- a/src/ui/egg-hatch-scene-handler.ts +++ b/src/ui/egg-hatch-scene-handler.ts @@ -1,7 +1,7 @@ import BattleScene from "../battle-scene"; import { Mode } from "./ui"; import UiHandler from "./ui-handler"; -import {Button} from "#enums/buttons"; +import { Button } from "#enums/buttons"; import { EggHatchPhase } from "#app/phases/egg-hatch-phase"; export default class EggHatchSceneHandler extends UiHandler { diff --git a/src/ui/egg-list-ui-handler.ts b/src/ui/egg-list-ui-handler.ts index fd8444f73ef..939f95fabe6 100644 --- a/src/ui/egg-list-ui-handler.ts +++ b/src/ui/egg-list-ui-handler.ts @@ -1,16 +1,21 @@ -import BattleScene from "../battle-scene"; -import { Mode } from "./ui"; -import PokemonIconAnimHandler, { PokemonIconAnimMode } from "./pokemon-icon-anim-handler"; -import { TextStyle, addTextObject } from "./text"; -import MessageUiHandler from "./message-ui-handler"; -import { Egg } from "../data/egg"; -import { addWindow } from "./ui-theme"; -import {Button} from "#enums/buttons"; +import BattleScene from "#app/battle-scene"; +import { Mode } from "#app/ui/ui"; +import PokemonIconAnimHandler, { PokemonIconAnimMode } from "#app/ui/pokemon-icon-anim-handler"; +import { TextStyle, addTextObject } from "#app/ui/text"; +import MessageUiHandler from "#app/ui/message-ui-handler"; +import { addWindow } from "#app/ui/ui-theme"; +import { Button } from "#enums/buttons"; import i18next from "i18next"; +import ScrollableGridUiHandler from "#app/ui/scrollable-grid-handler"; +import { ScrollBar } from "#app/ui/scroll-bar"; export default class EggListUiHandler extends MessageUiHandler { + private readonly ROWS = 9; + private readonly COLUMNS = 11; + private eggListContainer: Phaser.GameObjects.Container; private eggListIconContainer: Phaser.GameObjects.Container; + private eggIcons: Phaser.GameObjects.Sprite[]; private eggSprite: Phaser.GameObjects.Sprite; private eggNameText: Phaser.GameObjects.Text; private eggDateText: Phaser.GameObjects.Text; @@ -19,6 +24,7 @@ export default class EggListUiHandler extends MessageUiHandler { private eggListMessageBoxContainer: Phaser.GameObjects.Container; private cursorObj: Phaser.GameObjects.Image; + private scrollGridHandler : ScrollableGridUiHandler; private iconAnimHandler: PokemonIconAnimHandler; @@ -64,7 +70,7 @@ export default class EggListUiHandler extends MessageUiHandler { this.eggGachaInfoText.setWordWrapWidth(540); this.eggListContainer.add(this.eggGachaInfoText); - this.eggListIconContainer = this.scene.add.container(115, 9); + this.eggListIconContainer = this.scene.add.container(113, 5); this.eggListContainer.add(this.eggListIconContainer); this.cursorObj = this.scene.add.image(0, 0, "select_cursor"); @@ -74,6 +80,14 @@ export default class EggListUiHandler extends MessageUiHandler { this.eggSprite = this.scene.add.sprite(54, 37, "egg"); this.eggListContainer.add(this.eggSprite); + const scrollBar = new ScrollBar(this.scene, 310, 5, 4, 170, this.ROWS); + this.eggListContainer.add(scrollBar); + + this.scrollGridHandler = new ScrollableGridUiHandler(this, this.ROWS, this.COLUMNS) + .withScrollBar(scrollBar) + .withUpdateGridCallBack(() => this.updateEggIcons()) + .withUpdateSingleElementCallback((i:number) => this.setEggDetails(i)); + this.eggListMessageBoxContainer = this.scene.add.container(0, this.scene.game.canvas.height / 6); this.eggListMessageBoxContainer.setVisible(false); this.eggListContainer.add(this.eggListMessageBoxContainer); @@ -92,76 +106,63 @@ export default class EggListUiHandler extends MessageUiHandler { show(args: any[]): boolean { super.show(args); + this.initEggIcons(); + this.getUi().bringToTop(this.eggListContainer); this.eggListContainer.setVisible(true); - let e = 0; - - for (const egg of this.scene.gameData.eggs) { - const x = (e % 11) * 18; - const y = Math.floor(e / 11) * 18; - const icon = this.scene.add.sprite(x - 2, y + 2, "egg_icons"); - icon.setScale(0.5); - icon.setOrigin(0, 0); - icon.setFrame(egg.getKey()); - this.eggListIconContainer.add(icon); - this.iconAnimHandler.addOrUpdate(icon, PokemonIconAnimMode.NONE); - e++; - } + this.scrollGridHandler.setTotalElements(this.scene.gameData.eggs.length); + this.updateEggIcons(); this.setCursor(0); return true; } - processInput(button: Button): boolean { - const ui = this.getUi(); - - let success = false; - const error = false; - - if (button === Button.CANCEL) { - ui.revertMode(); - success = true; - } else { - const eggCount = this.eggListIconContainer.getAll().length; - const rows = Math.ceil(eggCount / 11); - const row = Math.floor(this.cursor / 11); - switch (button) { - case Button.UP: - if (row) { - success = this.setCursor(this.cursor - 11); - } - break; - case Button.DOWN: - if (row < rows - 2 || (row < rows - 1 && this.cursor % 11 <= (eggCount - 1) % 11)) { - success = this.setCursor(this.cursor + 11); - } - break; - case Button.LEFT: - if (this.cursor % 11) { - success = this.setCursor(this.cursor - 1); - } - break; - case Button.RIGHT: - if (this.cursor % 11 < (row < rows - 1 ? 10 : (eggCount - 1) % 11)) { - success = this.setCursor(this.cursor + 1); - } - break; - } + /** + * Create the grid of egg icons to display + */ + private initEggIcons() { + this.eggIcons = []; + for (let i = 0; i < Math.min(this.ROWS * this.COLUMNS, this.scene.gameData.eggs.length); i++) { + const x = (i % this.COLUMNS) * 18; + const y = Math.floor(i / this.COLUMNS) * 18; + const icon = this.scene.add.sprite(x - 2, y + 2, "egg_icons"); + icon.setScale(0.5); + icon.setOrigin(0, 0); + this.eggListIconContainer.add(icon); + this.eggIcons.push(icon); } - - if (success) { - ui.playSelect(); - } else if (error) { - ui.playError(); - } - - return success || error; } - setEggDetails(egg: Egg): void { + /** + * Show the grid of egg icons + */ + private updateEggIcons() { + const indexOffset = this.scrollGridHandler.getItemOffset(); + const eggsToShow = Math.min(this.eggIcons.length, this.scene.gameData.eggs.length - indexOffset); + + this.eggIcons.forEach((icon, i) => { + if (i !== this.cursor) { + this.iconAnimHandler.addOrUpdate(icon, PokemonIconAnimMode.NONE); + } + if (i < eggsToShow) { + const egg = this.scene.gameData.eggs[i + indexOffset]; + icon.setFrame(egg.getKey()); + icon.setVisible(true); + } else { + icon.setVisible(false); + } + }); + } + + /** + * Update the information panel with the information of the given egg + * @param index which egg in the list to display the info for + */ + private setEggDetails(index: number): void { + const egg = this.scene.gameData.eggs[index]; this.eggSprite.setFrame(`egg_${egg.getKey()}`); this.eggNameText.setText(`${i18next.t("egg:egg")} (${egg.getEggDescriptor()})`); this.eggDateText.setText( @@ -176,7 +177,29 @@ export default class EggListUiHandler extends MessageUiHandler { this.eggGachaInfoText.setText(egg.getEggTypeDescriptor(this.scene)); } - setCursor(cursor: integer): boolean { + processInput(button: Button): boolean { + const ui = this.getUi(); + + let success = false; + const error = false; + + if (button === Button.CANCEL) { + ui.revertMode(); + success = true; + } else { + success = this.scrollGridHandler.processInput(button); + } + + if (success) { + ui.playSelect(); + } else if (error) { + ui.playError(); + } + + return success || error; + } + + setCursor(cursor: number): boolean { let changed = false; const lastCursor = this.cursor; @@ -184,14 +207,15 @@ export default class EggListUiHandler extends MessageUiHandler { changed = super.setCursor(cursor); if (changed) { - this.cursorObj.setPosition(114 + 18 * (cursor % 11), 10 + 18 * Math.floor(cursor / 11)); + const icon = this.eggIcons[cursor]; + this.cursorObj.setPositionRelative(icon, 114, 5); if (lastCursor > -1) { - this.iconAnimHandler.addOrUpdate(this.eggListIconContainer.getAt(lastCursor) as Phaser.GameObjects.Sprite, PokemonIconAnimMode.NONE); + this.iconAnimHandler.addOrUpdate(this.eggIcons[lastCursor], PokemonIconAnimMode.NONE); } - this.iconAnimHandler.addOrUpdate(this.eggListIconContainer.getAt(cursor) as Phaser.GameObjects.Sprite, PokemonIconAnimMode.ACTIVE); + this.iconAnimHandler.addOrUpdate(icon, PokemonIconAnimMode.ACTIVE); - this.setEggDetails(this.scene.gameData.eggs[cursor]); + this.setEggDetails(cursor + this.scrollGridHandler.getItemOffset()); } return changed; @@ -199,9 +223,11 @@ export default class EggListUiHandler extends MessageUiHandler { clear(): void { super.clear(); + this.scrollGridHandler.reset(); this.cursor = -1; this.eggListContainer.setVisible(false); this.iconAnimHandler.removeAll(); this.eggListIconContainer.removeAll(true); + this.eggIcons = []; } } diff --git a/src/ui/egg-summary-ui-handler.ts b/src/ui/egg-summary-ui-handler.ts index 99fbccb4257..da93168926e 100644 --- a/src/ui/egg-summary-ui-handler.ts +++ b/src/ui/egg-summary-ui-handler.ts @@ -3,17 +3,17 @@ import { Mode } from "./ui"; import PokemonIconAnimHandler, { PokemonIconAnimMode } from "./pokemon-icon-anim-handler"; import MessageUiHandler from "./message-ui-handler"; import { getEggTierForSpecies } from "../data/egg"; -import {Button} from "#enums/buttons"; -import { Gender } from "#app/data/gender"; -import { getVariantTint } from "#app/data/variant"; -import { EggTier } from "#app/enums/egg-type"; +import { Button } from "#enums/buttons"; import PokemonHatchInfoContainer from "./pokemon-hatch-info-container"; import { EggSummaryPhase } from "#app/phases/egg-summary-phase"; -import { DexAttr } from "#app/system/game-data"; import { EggHatchData } from "#app/data/egg-hatch-data"; +import ScrollableGridUiHandler from "./scrollable-grid-handler"; +import { HatchedPokemonContainer } from "./hatched-pokemon-container"; +import { ScrollBar } from "#app/ui/scroll-bar"; -const iconContainerX = 115; +const iconContainerX = 112; const iconContainerY = 9; +const numRows = 9; const numCols = 11; const iconSize = 18; @@ -27,20 +27,23 @@ export default class EggSummaryUiHandler extends MessageUiHandler { private eggHatchContainer: Phaser.GameObjects.Container; /** holds the icon containers and info container */ private summaryContainer: Phaser.GameObjects.Container; - /** container for the mini pokemon sprites */ - private pokemonIconSpritesContainer: Phaser.GameObjects.Container; - /** container for the icons displayed on top of the mini pokemon sprites (e.g. shiny, HA capsule) */ + /** container for the each pokemon sprites and icons */ private pokemonIconsContainer: Phaser.GameObjects.Container; - /** container for the elements displayed behind the mini pokemon sprites (e.g. egg rarity bg) */ - private pokemonBackgroundContainer: Phaser.GameObjects.Container; + /** list of the containers added to pokemonIconsContainer for easier access */ + private pokemonContainers: HatchedPokemonContainer[]; + /** hatch info container that displays the current pokemon / hatch (main element on left hand side) */ private infoContainer: PokemonHatchInfoContainer; /** handles jumping animations for the pokemon sprite icons */ private iconAnimHandler: PokemonIconAnimHandler; private eggHatchBg: Phaser.GameObjects.Image; - private cursorObj: Phaser.GameObjects.Image; private eggHatchData: EggHatchData[]; + private scrollGridHandler : ScrollableGridUiHandler; + private cursorObj: Phaser.GameObjects.Image; + + /** used to add a delay before which it is not possible to exit the summary */ + private blockExit: boolean; /** * Allows subscribers to listen for events @@ -54,7 +57,6 @@ export default class EggSummaryUiHandler extends MessageUiHandler { super(scene, Mode.EGG_HATCH_SUMMARY); } - setup() { const ui = this.getUi(); @@ -77,11 +79,8 @@ export default class EggSummaryUiHandler extends MessageUiHandler { this.cursorObj.setOrigin(0, 0); this.summaryContainer.add(this.cursorObj); - this.pokemonIconSpritesContainer = this.scene.add.container(iconContainerX, iconContainerY); + this.pokemonContainers = []; this.pokemonIconsContainer = this.scene.add.container(iconContainerX, iconContainerY); - this.pokemonBackgroundContainer = this.scene.add.container(iconContainerX, iconContainerY); - this.summaryContainer.add(this.pokemonBackgroundContainer); - this.summaryContainer.add(this.pokemonIconSpritesContainer); this.summaryContainer.add(this.pokemonIconsContainer); this.infoContainer = new PokemonHatchInfoContainer(this.scene, this.summaryContainer); @@ -90,16 +89,25 @@ export default class EggSummaryUiHandler extends MessageUiHandler { this.infoContainer.setVisible(true); this.summaryContainer.add(this.infoContainer); + const scrollBar = new ScrollBar(this.scene, iconContainerX + numCols * iconSize, iconContainerY + 3, 4, this.scene.game.canvas.height / 6 - 20, numRows); + this.summaryContainer.add(scrollBar); + + this.scrollGridHandler = new ScrollableGridUiHandler(this, numRows, numCols) + .withScrollBar(scrollBar) + .withUpdateGridCallBack(() => this.updatePokemonIcons()) + .withUpdateSingleElementCallback((i: number) => this.infoContainer.showHatchInfo(this.eggHatchData[i])); + this.cursor = -1; } clear() { super.clear(); + this.scrollGridHandler.reset(); this.cursor = -1; + this.summaryContainer.setVisible(false); - this.pokemonIconSpritesContainer.removeAll(true); this.pokemonIconsContainer.removeAll(true); - this.pokemonBackgroundContainer.removeAll(true); + this.pokemonContainers = []; this.eggHatchBg.setVisible(false); this.getUi().hideTooltip(); @@ -149,148 +157,75 @@ export default class EggSummaryUiHandler extends MessageUiHandler { return 0; } } - } - - ); + }); } this.getUi().bringToTop(this.summaryContainer); this.summaryContainer.setVisible(true); this.eggHatchContainer.setVisible(true); - this.pokemonIconsContainer.setVisible(true); this.eggHatchBg.setVisible(true); this.infoContainer.hideDisplayPokemon(); - this.eggHatchData.forEach( (value: EggHatchData, i: number) => { - const x = (i % numCols) * iconSize; - const y = Math.floor(i / numCols) * iconSize; - - const displayPokemon = value.pokemon; - const offset = 2; - const rightSideX = 12; - - const rarityBg = this.scene.add.image(x + 2, y + 5, "passive_bg"); - rarityBg.setOrigin(0, 0); - rarityBg.setScale(0.75); - rarityBg.setVisible(true); - this.pokemonBackgroundContainer.add(rarityBg); - - // set tint for passive bg - switch (getEggTierForSpecies(displayPokemon.species)) { - case EggTier.COMMON: - rarityBg.setVisible(false); - break; - case EggTier.GREAT: - rarityBg.setTint(0xabafff); - break; - case EggTier.ULTRA: - rarityBg.setTint(0xffffaa); - break; - case EggTier.MASTER: - rarityBg.setTint(0xdfffaf); - break; - } - const species = displayPokemon.species; - const female = displayPokemon.gender === Gender.FEMALE; - const formIndex = displayPokemon.formIndex; - const variant = displayPokemon.variant; - const isShiny = displayPokemon.shiny; - - // set pokemon icon (and replace with base sprite if there is a mismatch) - const pokemonIcon = this.scene.add.sprite(x - offset, y + offset, species.getIconAtlasKey(formIndex, isShiny, variant)); - pokemonIcon.setScale(0.5); - pokemonIcon.setOrigin(0, 0); - pokemonIcon.setFrame(species.getIconId(female, formIndex, isShiny, variant)); - - if (pokemonIcon.frame.name !== species.getIconId(female, formIndex, isShiny, variant)) { - console.log(`${species.name}'s variant icon does not exist. Replacing with default.`); - pokemonIcon.setTexture(species.getIconAtlasKey(formIndex, false, variant)); - pokemonIcon.setFrame(species.getIconId(female, formIndex, false, variant)); - } - this.pokemonIconSpritesContainer.add(pokemonIcon); - - const shinyIcon = this.scene.add.image(x + rightSideX, y + offset, "shiny_star_small"); - shinyIcon.setOrigin(0, 0); - shinyIcon.setScale(0.5); - shinyIcon.setVisible(displayPokemon.shiny); - shinyIcon.setTint(getVariantTint(displayPokemon.variant)); - this.pokemonIconsContainer.add(shinyIcon); - - const haIcon = this.scene.add.image(x + rightSideX, y + offset * 4, "ha_capsule"); - haIcon.setOrigin(0, 0); - haIcon.setScale(0.5); - haIcon.setVisible(displayPokemon.abilityIndex === 2); - this.pokemonIconsContainer.add(haIcon); - - const dexEntry = value.dexEntryBeforeUpdate; - const caughtAttr = dexEntry.caughtAttr; - const newShiny = BigInt(1 << (displayPokemon.shiny ? 1 : 0)); - const newVariant = BigInt(1 << (displayPokemon.variant + 4)); - const newShinyOrVariant = ((newShiny & caughtAttr) === BigInt(0)) || ((newVariant & caughtAttr) === BigInt(0)); - const newForm = (BigInt(1 << displayPokemon.formIndex) * DexAttr.DEFAULT_FORM & caughtAttr) === BigInt(0); - - const pokeballIcon = this.scene.add.image(x + rightSideX, y + offset * 7, "icon_owned"); - pokeballIcon.setOrigin(0, 0); - pokeballIcon.setScale(0.5); - pokeballIcon.setVisible(!caughtAttr || newForm); - this.pokemonIconsContainer.add(pokeballIcon); - - const eggMoveIcon = this.scene.add.image(x, y + offset, "icon_egg_move"); - eggMoveIcon.setOrigin(0, 0); - eggMoveIcon.setScale(0.5); - eggMoveIcon.setVisible(value.eggMoveUnlocked); - this.pokemonIconsContainer.add(eggMoveIcon); - - // add animation to the Pokemon sprite for new unlocks (new catch, new shiny or new form) - if (!caughtAttr || newShinyOrVariant || newForm) { - this.iconAnimHandler.addOrUpdate(pokemonIcon, PokemonIconAnimMode.PASSIVE); - } else { - this.iconAnimHandler.addOrUpdate(pokemonIcon, PokemonIconAnimMode.NONE); - } - }); - + this.scrollGridHandler.setTotalElements(this.eggHatchData.length); + this.updatePokemonIcons(); this.setCursor(0); + this.scene.playSoundWithoutBgm("evolution_fanfare"); + + // Prevent exiting the egg summary for 2 seconds if the egg hatching + // was skipped automatically and for 1 second otherwise + const exitBlockingDuration = (this.scene.eggSkipPreference === 2) ? 2000 : 1000; + this.blockExit = true; + this.scene.time.delayedCall(exitBlockingDuration, () => this.blockExit = false); + return true; } + /** + * Show the grid of Pokemon icons + */ + private updatePokemonIcons(): void { + const itemOffset = this.scrollGridHandler.getItemOffset(); + const eggsToShow = Math.min(numRows * numCols, this.eggHatchData.length - itemOffset); + + for (let i = 0; i < numRows * numCols; i++) { + const hatchData = this.eggHatchData[i + itemOffset]; + let hatchContainer = this.pokemonContainers[i]; + + if (i < eggsToShow) { + if (!hatchContainer) { + const x = (i % numCols) * iconSize; + const y = Math.floor(i / numCols) * iconSize; + hatchContainer = new HatchedPokemonContainer(this.scene, x, y, hatchData).setVisible(false); + this.pokemonContainers.push(hatchContainer); + this.pokemonIconsContainer.add(hatchContainer); + } + hatchContainer.setVisible(true); + hatchContainer.updateAndAnimate(hatchData, this.iconAnimHandler); + } else if (hatchContainer) { + hatchContainer.setVisible(false); + this.iconAnimHandler.addOrUpdate(hatchContainer.icon, PokemonIconAnimMode.NONE); + } + } + } + processInput(button: Button): boolean { const ui = this.getUi(); let success = false; - const error = false; + let error = false; if (button === Button.CANCEL) { - const phase = this.scene.getCurrentPhase(); - if (phase instanceof EggSummaryPhase) { - phase.end(); + if (!this.blockExit) { + const phase = this.scene.getCurrentPhase(); + if (phase instanceof EggSummaryPhase) { + phase.end(); + } + success = true; + } else { + error = true; } - success = true; } else { - const count = this.eggHatchData.length; - const rows = Math.ceil(count / numCols); - const row = Math.floor(this.cursor / numCols); - switch (button) { - case Button.UP: - if (row) { - success = this.setCursor(this.cursor - numCols); - } - break; - case Button.DOWN: - if (row < rows - 2 || (row < rows - 1 && this.cursor % numCols <= (count - 1) % numCols)) { - success = this.setCursor(this.cursor + numCols); - } - break; - case Button.LEFT: - if (this.cursor % numCols) { - success = this.setCursor(this.cursor - 1); - } - break; - case Button.RIGHT: - if (this.cursor % numCols < (row < rows - 1 ? 10 : (count - 1) % numCols)) { - success = this.setCursor(this.cursor + 1); - } - break; - } + this.scrollGridHandler.processInput(button); } if (success) { @@ -313,12 +248,11 @@ export default class EggSummaryUiHandler extends MessageUiHandler { this.cursorObj.setPosition(iconContainerX - 1 + iconSize * (cursor % numCols), iconContainerY + 1 + iconSize * Math.floor(cursor / numCols)); if (lastCursor > -1) { - this.iconAnimHandler.addOrUpdate(this.pokemonIconSpritesContainer.getAt(lastCursor) as Phaser.GameObjects.Sprite, PokemonIconAnimMode.NONE); + this.iconAnimHandler.addOrUpdate(this.pokemonContainers[lastCursor].icon, PokemonIconAnimMode.NONE); } - this.iconAnimHandler.addOrUpdate(this.pokemonIconSpritesContainer.getAt(cursor) as Phaser.GameObjects.Sprite, PokemonIconAnimMode.ACTIVE); - - this.infoContainer.showHatchInfo(this.eggHatchData[cursor]); + this.iconAnimHandler.addOrUpdate(this.pokemonContainers[cursor].icon, PokemonIconAnimMode.ACTIVE); + this.infoContainer.showHatchInfo(this.eggHatchData[cursor + this.scrollGridHandler.getItemOffset()]); } return changed; diff --git a/src/ui/evolution-scene-handler.ts b/src/ui/evolution-scene-handler.ts index 76d148d083e..a116a33f373 100644 --- a/src/ui/evolution-scene-handler.ts +++ b/src/ui/evolution-scene-handler.ts @@ -2,7 +2,7 @@ import BattleScene from "../battle-scene"; import MessageUiHandler from "./message-ui-handler"; import { TextStyle, addTextObject } from "./text"; import { Mode } from "./ui"; -import {Button} from "#enums/buttons"; +import { Button } from "#enums/buttons"; export default class EvolutionSceneHandler extends MessageUiHandler { public evolutionContainer: Phaser.GameObjects.Container; diff --git a/src/ui/fight-ui-handler.ts b/src/ui/fight-ui-handler.ts index 3bf55119335..eaf504495d5 100644 --- a/src/ui/fight-ui-handler.ts +++ b/src/ui/fight-ui-handler.ts @@ -1,18 +1,20 @@ -import BattleScene from "../battle-scene"; +import BattleScene, { InfoToggle } from "../battle-scene"; import { addTextObject, TextStyle } from "./text"; -import { getTypeDamageMultiplierColor, Type } from "../data/type"; +import { getTypeDamageMultiplierColor } from "#app/data/type"; +import { Type } from "#enums/type"; import { Command } from "./command-ui-handler"; import { Mode } from "./ui"; import UiHandler from "./ui-handler"; import * as Utils from "../utils"; import { MoveCategory } from "#app/data/move"; import i18next from "i18next"; -import {Button} from "#enums/buttons"; +import { Button } from "#enums/buttons"; import Pokemon, { PokemonMove } from "#app/field/pokemon"; import { CommandPhase } from "#app/phases/command-phase"; +import MoveInfoOverlay from "./move-info-overlay"; import { BattleType } from "#app/battle"; -export default class FightUiHandler extends UiHandler { +export default class FightUiHandler extends UiHandler implements InfoToggle { public static readonly MOVES_CONTAINER_NAME = "moves"; private movesContainer: Phaser.GameObjects.Container; @@ -26,6 +28,7 @@ export default class FightUiHandler extends UiHandler { private accuracyText: Phaser.GameObjects.Text; private cursorObj: Phaser.GameObjects.Image | null; private moveCategoryIcon: Phaser.GameObjects.Sprite; + private moveInfoOverlay : MoveInfoOverlay; protected fieldIndex: integer = 0; protected cursor2: integer = 0; @@ -85,6 +88,24 @@ export default class FightUiHandler extends UiHandler { this.accuracyText.setOrigin(1, 0.5); this.accuracyText.setVisible(false); this.moveInfoContainer.add(this.accuracyText); + + // prepare move overlay + const overlayScale = 1; + this.moveInfoOverlay = new MoveInfoOverlay(this.scene, { + delayVisibility: true, + scale: overlayScale, + onSide: true, + right: true, + x: 0, + y: -MoveInfoOverlay.getHeight(overlayScale, true), + width: (this.scene.game.canvas.width / 6) + 4, + hideEffectBox: true, + hideBg: true + }); + ui.add(this.moveInfoOverlay); + // register the overlay to receive toggle events + this.scene.addInfoToggle(this.moveInfoOverlay); + this.scene.addInfoToggle(this); } show(args: any[]): boolean { @@ -103,6 +124,8 @@ export default class FightUiHandler extends UiHandler { this.setCursor(this.getCursor()); } this.displayMoves(); + this.toggleInfo(false); // in case cancel was pressed while info toggle is active + this.active = true; return true; } @@ -130,26 +153,26 @@ export default class FightUiHandler extends UiHandler { } } else { switch (button) { - case Button.UP: - if (cursor >= 2) { - success = this.setCursor(cursor - 2); - } - break; - case Button.DOWN: - if (cursor < 2) { - success = this.setCursor(cursor + 2); - } - break; - case Button.LEFT: - if (cursor % 2 === 1) { - success = this.setCursor(cursor - 1); - } - break; - case Button.RIGHT: - if (cursor % 2 === 0) { - success = this.setCursor(cursor + 1); - } - break; + case Button.UP: + if (cursor >= 2) { + success = this.setCursor(cursor - 2); + } + break; + case Button.DOWN: + if (cursor < 2) { + success = this.setCursor(cursor + 2); + } + break; + case Button.LEFT: + if (cursor % 2 === 1) { + success = this.setCursor(cursor - 1); + } + break; + case Button.RIGHT: + if (cursor % 2 === 0) { + success = this.setCursor(cursor + 1); + } + break; } } @@ -160,6 +183,27 @@ export default class FightUiHandler extends UiHandler { return success; } + toggleInfo(visible: boolean): void { + if (visible) { + this.movesContainer.setVisible(false); + this.cursorObj?.setVisible(false); + } + this.scene.tweens.add({ + targets: [ this.movesContainer, this.cursorObj ], + duration: Utils.fixedInt(125), + ease: "Sine.easeInOut", + alpha: visible ? 0 : 1 + }); + if (!visible) { + this.movesContainer.setVisible(true); + this.cursorObj?.setVisible(true); + } + } + + isActive(): boolean { + return this.active; + } + getCursor(): integer { return !this.fieldIndex ? this.cursor : this.cursor2; } @@ -167,6 +211,7 @@ export default class FightUiHandler extends UiHandler { setCursor(cursor: integer): boolean { const ui = this.getUi(); + this.moveInfoOverlay.clear(); const changed = this.getCursor() !== cursor; if (changed) { if (!this.fieldIndex) { @@ -220,6 +265,7 @@ export default class FightUiHandler extends UiHandler { //** Changes the text color and shadow according to the determined TextStyle */ this.ppText.setColor(this.getTextColor(ppColorStyle, false)); this.ppText.setShadowColor(this.getTextColor(ppColorStyle, true)); + this.moveInfoOverlay.show(pokemonMove.getMove()); pokemon.getOpponents().forEach((opponent) => { opponent.updateEffectiveness(this.getEffectivenessText(pokemon, opponent, pokemonMove)); @@ -307,8 +353,10 @@ export default class FightUiHandler extends UiHandler { this.accuracyLabel.setVisible(false); this.accuracyText.setVisible(false); this.moveCategoryIcon.setVisible(false); + this.moveInfoOverlay.clear(); messageHandler.bg.setVisible(true); this.eraseCursor(); + this.active = false; } clearMoves() { diff --git a/src/ui/filter-bar.ts b/src/ui/filter-bar.ts index aa0f575d398..bcf7409fce0 100644 --- a/src/ui/filter-bar.ts +++ b/src/ui/filter-bar.ts @@ -104,11 +104,11 @@ export class FilterBar extends Phaser.GameObjects.Container { totalWidth += label.displayWidth + cursorOffset; }); const spacing = (this.width - totalWidth) / (this.labels.length - 1); - for (let i=0; i { - const label = addTextObject(this.scene, 10, (hasTitle ? 31 : 5) + 20 * f, field, TextStyle.TOOLTIP_CONTENT); + if (config.length >= 1) { + this.updateFields(config, hasTitle); + } - this.modalContainer.add(label); + this.errorMessage = addTextObject(this.scene, 10, (hasTitle ? 31 : 5) + 20 * (config.length - 1) + 16 + this.getButtonTopMargin(), "", TextStyle.TOOLTIP_CONTENT); + this.errorMessage.setColor(this.getTextColor(TextStyle.SUMMARY_PINK)); + this.errorMessage.setShadowColor(this.getTextColor(TextStyle.SUMMARY_PINK, true)); + this.errorMessage.setVisible(false); + this.modalContainer.add(this.errorMessage); + } + + protected updateFields(fieldsConfig: InputFieldConfig[], hasTitle: boolean) { + this.inputContainers = []; + this.inputs = []; + this.formLabels = []; + fieldsConfig.forEach((config, f) => { + const label = addTextObject(this.scene, 10, (hasTitle ? 31 : 5) + 20 * f, config.label, TextStyle.TOOLTIP_CONTENT); + label.name = "formLabel" + f; + + this.formLabels.push(label); + this.modalContainer.add(this.formLabels[this.formLabels.length - 1]); const inputContainer = this.scene.add.container(70, (hasTitle ? 28 : 2) + 20 * f); inputContainer.setVisible(false); const inputBg = addWindow(this.scene, 0, 0, 80, 16, false, false, 0, 0, WindowVariant.XTHIN); - const isPassword = field.includes(i18next.t("menu:password")) || field.includes(i18next.t("menu:confirmPassword")); - const input = addTextInputObject(this.scene, 4, -2, 440, 116, TextStyle.TOOLTIP_CONTENT, { type: isPassword ? "password" : "text", maxLength: isPassword ? 64 : 20 }); + const isPassword = config?.isPassword; + const isReadOnly = config?.isReadOnly; + const input = addTextInputObject(this.scene, 4, -2, 440, 116, TextStyle.TOOLTIP_CONTENT, { type: isPassword ? "password" : "text", maxLength: isPassword ? 64 : 20, readOnly: isReadOnly }); input.setOrigin(0, 0); inputContainer.add(inputBg); inputContainer.add(input); - this.modalContainer.add(inputContainer); this.inputContainers.push(inputContainer); + this.modalContainer.add(inputContainer); + this.inputs.push(input); }); - - this.errorMessage = addTextObject(this.scene, 10, (hasTitle ? 31 : 5) + 20 * (fields.length - 1) + 16 + this.getButtonTopMargin(), "", TextStyle.TOOLTIP_CONTENT); - this.errorMessage.setColor(this.getTextColor(TextStyle.SUMMARY_PINK)); - this.errorMessage.setShadowColor(this.getTextColor(TextStyle.SUMMARY_PINK, true)); - this.errorMessage.setVisible(false); - this.modalContainer.add(this.errorMessage); } show(args: any[]): boolean { @@ -149,3 +168,9 @@ export abstract class FormModalUiHandler extends ModalUiHandler { } } } + +export interface InputFieldConfig { + label: string, + isPassword?: boolean, + isReadOnly?: boolean +} diff --git a/src/ui/game-stats-ui-handler.ts b/src/ui/game-stats-ui-handler.ts index 967b3ae0dc4..671bed29036 100644 --- a/src/ui/game-stats-ui-handler.ts +++ b/src/ui/game-stats-ui-handler.ts @@ -1,15 +1,15 @@ import Phaser from "phaser"; -import BattleScene from "../battle-scene"; -import { TextStyle, addTextObject } from "./text"; -import { Mode } from "./ui"; -import UiHandler from "./ui-handler"; -import { addWindow } from "./ui-theme"; -import * as Utils from "../utils"; -import { DexAttr, GameData } from "../system/game-data"; -import { speciesStarters } from "../data/pokemon-species"; -import {Button} from "#enums/buttons"; +import BattleScene from "#app/battle-scene"; +import { TextStyle, addTextObject } from "#app/ui/text"; +import { Mode } from "#app/ui/ui"; +import UiHandler from "#app/ui/ui-handler"; +import { addWindow } from "#app/ui/ui-theme"; +import * as Utils from "#app/utils"; +import { DexAttr, GameData } from "#app/system/game-data"; +import { speciesStarterCosts } from "#app/data/balance/starters"; +import { Button } from "#enums/buttons"; import i18next from "i18next"; -import { UiTheme } from "#app/enums/ui-theme"; +import { UiTheme } from "#enums/ui-theme"; interface DisplayStat { label_key?: string; @@ -34,14 +34,14 @@ const displayStats: DisplayStats = { label_key: "starters", sourceFunc: gameData => { const starterCount = gameData.getStarterCount(d => !!d.caughtAttr); - return `${starterCount} (${Math.floor((starterCount / Object.keys(speciesStarters).length) * 1000) / 10}%)`; + return `${starterCount} (${Math.floor((starterCount / Object.keys(speciesStarterCosts).length) * 1000) / 10}%)`; } }, shinyStartersUnlocked: { label_key: "shinyStarters", sourceFunc: gameData => { const starterCount = gameData.getStarterCount(d => !!(d.caughtAttr & DexAttr.SHINY)); - return `${starterCount} (${Math.floor((starterCount / Object.keys(speciesStarters).length) * 1000) / 10}%)`; + return `${starterCount} (${Math.floor((starterCount / Object.keys(speciesStarterCosts).length) * 1000) / 10}%)`; } }, dexSeen: { @@ -247,7 +247,7 @@ export default class GameStatsUiHandler extends UiHandler { const [ statsBgLeft, statsBgRight ] = new Array(2).fill(null).map((_, i) => { const width = statsBgWidth + 2; const height = Math.floor((this.scene.game.canvas.height / 6) - headerBg.height - 2); - const statsBg = addWindow(this.scene, (statsBgWidth - 2) * i, headerBg.height, width, height, false, false, i>0?-3:0, 1); + const statsBg = addWindow(this.scene, (statsBgWidth - 2) * i, headerBg.height, width, height, false, false, i > 0 ? -3 : 0, 1); statsBg.setOrigin(0, 0); return statsBg; }); @@ -276,9 +276,9 @@ export default class GameStatsUiHandler extends UiHandler { // arrows to show that we can scroll through the stats const isLegacyTheme = this.scene.uiTheme === UiTheme.LEGACY; - this.arrowDown = this.scene.add.sprite(statsBgWidth, this.scene.game.canvas.height / 6 - (isLegacyTheme? 9 : 5), "prompt"); + this.arrowDown = this.scene.add.sprite(statsBgWidth, this.scene.game.canvas.height / 6 - (isLegacyTheme ? 9 : 5), "prompt"); this.gameStatsContainer.add(this.arrowDown); - this.arrowUp = this.scene.add.sprite(statsBgWidth, headerBg.height + (isLegacyTheme? 7 : 3), "prompt"); + this.arrowUp = this.scene.add.sprite(statsBgWidth, headerBg.height + (isLegacyTheme ? 7 : 3), "prompt"); this.arrowUp.flipY = true; this.gameStatsContainer.add(this.arrowUp); @@ -351,16 +351,16 @@ export default class GameStatsUiHandler extends UiHandler { this.scene.ui.revertMode(); } else { switch (button) { - case Button.UP: - if (this.cursor) { - success = this.setCursor(this.cursor - 1); - } - break; - case Button.DOWN: - if (this.cursor < Math.ceil((Object.keys(displayStats).length - 18) / 2)) { - success = this.setCursor(this.cursor + 1); - } - break; + case Button.UP: + if (this.cursor) { + success = this.setCursor(this.cursor - 1); + } + break; + case Button.DOWN: + if (this.cursor < Math.ceil((Object.keys(displayStats).length - 18) / 2)) { + success = this.setCursor(this.cursor + 1); + } + break; } } diff --git a/src/ui/hatched-pokemon-container.ts b/src/ui/hatched-pokemon-container.ts new file mode 100644 index 00000000000..9fb1fd26b30 --- /dev/null +++ b/src/ui/hatched-pokemon-container.ts @@ -0,0 +1,136 @@ +import { EggHatchData } from "#app/data/egg-hatch-data"; +import { Gender } from "#app/data/gender"; +import { getVariantTint } from "#app/data/variant"; +import { DexAttr } from "#app/system/game-data"; +import BattleScene from "#app/battle-scene"; +import PokemonSpecies from "#app/data/pokemon-species"; +import PokemonIconAnimHandler, { PokemonIconAnimMode } from "./pokemon-icon-anim-handler"; + +/** + * A container for a Pokemon's sprite and icons to get displayed in the egg summary screen + * Shows the Pokemon's sprite, surrounded by icons for: + * shiny variant, hidden ability, new egg move, new catch + */ +export class HatchedPokemonContainer extends Phaser.GameObjects.Container { + public scene: BattleScene; + public species: PokemonSpecies; + public icon: Phaser.GameObjects.Sprite; + public shinyIcon: Phaser.GameObjects.Image; + public hiddenAbilityIcon: Phaser.GameObjects.Image; + public pokeballIcon: Phaser.GameObjects.Image; + public eggMoveIcon: Phaser.GameObjects.Image; + + /** + * @param scene the current {@linkcode BattleScene} + * @param x x position + * @param y y position + * @param hatchData the {@linkcode EggHatchData} to load the icons and sprites for + */ + constructor(scene: BattleScene, x: number, y: number, hatchData: EggHatchData) { + super(scene, x, y); + + const displayPokemon = hatchData.pokemon; + this.species = displayPokemon.species; + + const offset = 2; + const rightSideX = 12; + const species = displayPokemon.species; + const female = displayPokemon.gender === Gender.FEMALE; + const formIndex = displayPokemon.formIndex; + const variant = displayPokemon.variant; + const isShiny = displayPokemon.shiny; + + // Pokemon sprite + const pokemonIcon = this.scene.add.sprite(-offset, offset, species.getIconAtlasKey(formIndex, isShiny, variant)); + pokemonIcon.setScale(0.5); + pokemonIcon.setOrigin(0, 0); + pokemonIcon.setFrame(species.getIconId(female, formIndex, isShiny, variant)); + this.icon = pokemonIcon; + this.checkIconId(female, formIndex, isShiny, variant); + this.add(this.icon); + + // Shiny icon + this.shinyIcon = this.scene.add.image(rightSideX, offset, "shiny_star_small"); + this.shinyIcon.setOrigin(0, 0); + this.shinyIcon.setScale(0.5); + this.add(this.shinyIcon); + + // Hidden ability icon + const haIcon = this.scene.add.image(rightSideX, offset * 4, "ha_capsule"); + haIcon.setOrigin(0, 0); + haIcon.setScale(0.5); + this.hiddenAbilityIcon = haIcon; + this.add(this.hiddenAbilityIcon); + + // Pokeball icon + const pokeballIcon = this.scene.add.image(rightSideX, offset * 7, "icon_owned"); + pokeballIcon.setOrigin(0, 0); + pokeballIcon.setScale(0.5); + this.pokeballIcon = pokeballIcon; + this.add(this.pokeballIcon); + + // Egg move icon + const eggMoveIcon = this.scene.add.image(0, offset, "icon_egg_move"); + eggMoveIcon.setOrigin(0, 0); + eggMoveIcon.setScale(0.5); + this.eggMoveIcon = eggMoveIcon; + this.add(this.eggMoveIcon); + } + + /** + * Update the Pokemon's sprite and icons based on new hatch data + * Animates the pokemon icon if it has a new form or shiny variant + * + * @param hatchData the {@linkcode EggHatchData} to base the icons on + * @param iconAnimHandler the {@linkcode PokemonIconAnimHandler} to use to animate the sprites + */ + updateAndAnimate(hatchData: EggHatchData, iconAnimHandler: PokemonIconAnimHandler) { + const displayPokemon = hatchData.pokemon; + this.species = displayPokemon.species; + + const dexEntry = hatchData.dexEntryBeforeUpdate; + const caughtAttr = dexEntry.caughtAttr; + const newShiny = BigInt(1 << (displayPokemon.shiny ? 1 : 0)); + const newVariant = BigInt(1 << (displayPokemon.variant + 4)); + const newShinyOrVariant = ((newShiny & caughtAttr) === BigInt(0)) || ((newVariant & caughtAttr) === BigInt(0)); + const newForm = (BigInt(1 << displayPokemon.formIndex) * DexAttr.DEFAULT_FORM & caughtAttr) === BigInt(0); + + const female = displayPokemon.gender === Gender.FEMALE; + const formIndex = displayPokemon.formIndex; + const variant = displayPokemon.variant; + const isShiny = displayPokemon.shiny; + + this.icon.setTexture(this.species.getIconAtlasKey(formIndex, isShiny, variant)); + this.icon.setFrame(this.species.getIconId(female, formIndex, isShiny, variant)); + this.checkIconId(female, formIndex, isShiny, variant); + + this.shinyIcon.setVisible(displayPokemon.shiny); + this.shinyIcon.setTint(getVariantTint(displayPokemon.variant)); + + this.eggMoveIcon.setVisible(hatchData.eggMoveUnlocked); + this.hiddenAbilityIcon.setVisible(displayPokemon.abilityIndex === 2); + this.pokeballIcon.setVisible(!caughtAttr || newForm); + + // add animation to the Pokemon sprite for new unlocks (new catch, new shiny or new form) + if (!caughtAttr || newShinyOrVariant || newForm) { + iconAnimHandler.addOrUpdate(this.icon, PokemonIconAnimMode.PASSIVE); + } else { + iconAnimHandler.addOrUpdate(this.icon, PokemonIconAnimMode.NONE); + } + } + + /** + * Check if the given Pokemon icon exists, otherwise replace it with a default one + * @param female `true` to get the female icon + * @param formIndex the form index + * @param shiny whether the Pokemon is shiny + * @param variant the shiny variant + */ + private checkIconId(female: boolean, formIndex: number, shiny: boolean, variant: number) { + if (this.icon.frame.name !== this.species.getIconId(female, formIndex, shiny, variant)) { + console.log(`${this.species.name}'s variant icon does not exist. Replacing with default.`); + this.icon.setTexture(this.species.getIconAtlasKey(formIndex, false, variant)); + this.icon.setFrame(this.species.getIconId(female, formIndex, false, variant)); + } + } +} diff --git a/src/ui/login-form-ui-handler.ts b/src/ui/login-form-ui-handler.ts index 631b2e50b02..bba900aef0a 100644 --- a/src/ui/login-form-ui-handler.ts +++ b/src/ui/login-form-ui-handler.ts @@ -1,4 +1,4 @@ -import { FormModalUiHandler } from "./form-modal-ui-handler"; +import { FormModalUiHandler, InputFieldConfig } from "./form-modal-ui-handler"; import { ModalConfig } from "./modal-ui-handler"; import * as Utils from "../utils"; import { Mode } from "./ui"; @@ -7,6 +7,7 @@ import BattleScene from "#app/battle-scene"; import { addTextObject, TextStyle } from "./text"; import { addWindow } from "./ui-theme"; import { OptionSelectItem } from "#app/ui/abstact-option-select-ui-handler"; +import { pokerogueApi } from "#app/plugins/api/pokerogue-api"; interface BuildInteractableImageOpts { scale?: number; @@ -17,9 +18,9 @@ interface BuildInteractableImageOpts { export default class LoginFormUiHandler extends FormModalUiHandler { private readonly ERR_USERNAME: string = "invalid username"; - private readonly ERR_PASSWORD: string = "invalid password"; - private readonly ERR_ACCOUNT_EXIST: string = "account doesn't exist"; - private readonly ERR_PASSWORD_MATCH: string = "password doesn't match"; + private readonly ERR_PASSWORD: string = "invalid password"; + private readonly ERR_ACCOUNT_EXIST: string = "account doesn't exist"; + private readonly ERR_PASSWORD_MATCH: string = "password doesn't match"; private readonly ERR_NO_SAVES: string = "No save files found"; private readonly ERR_TOO_MANY_SAVES: string = "Too many save files found"; @@ -75,10 +76,6 @@ export default class LoginFormUiHandler extends FormModalUiHandler { return i18next.t("menu:login"); } - override getFields(_config?: ModalConfig): string[] { - return [ i18next.t("menu:username"), i18next.t("menu:password") ]; - } - override getWidth(_config?: ModalConfig): number { return 160; } @@ -88,7 +85,7 @@ export default class LoginFormUiHandler extends FormModalUiHandler { } override getButtonLabels(_config?: ModalConfig): string[] { - return [ i18next.t("menu:login"), i18next.t("menu:register")]; + return [ i18next.t("menu:login"), i18next.t("menu:register") ]; } override getReadableErrorMessage(error: string): string { @@ -97,23 +94,30 @@ export default class LoginFormUiHandler extends FormModalUiHandler { error = error.slice(0, colonIndex); } switch (error) { - case this.ERR_USERNAME: - return i18next.t("menu:invalidLoginUsername"); - case this.ERR_PASSWORD: - return i18next.t("menu:invalidLoginPassword"); - case this.ERR_ACCOUNT_EXIST: - return i18next.t("menu:accountNonExistent"); - case this.ERR_PASSWORD_MATCH: - return i18next.t("menu:unmatchingPassword"); - case this.ERR_NO_SAVES: - return i18next.t("menu:noSaves"); - case this.ERR_TOO_MANY_SAVES: - return i18next.t("menu:tooManySaves"); + case this.ERR_USERNAME: + return i18next.t("menu:invalidLoginUsername"); + case this.ERR_PASSWORD: + return i18next.t("menu:invalidLoginPassword"); + case this.ERR_ACCOUNT_EXIST: + return i18next.t("menu:accountNonExistent"); + case this.ERR_PASSWORD_MATCH: + return i18next.t("menu:unmatchingPassword"); + case this.ERR_NO_SAVES: + return "P01: " + i18next.t("menu:noSaves"); + case this.ERR_TOO_MANY_SAVES: + return "P02: " + i18next.t("menu:tooManySaves"); } return super.getReadableErrorMessage(error); } + override getInputFieldConfigs(): InputFieldConfig[] { + const inputFieldConfigs: InputFieldConfig[] = []; + inputFieldConfigs.push({ label: i18next.t("menu:username") }); + inputFieldConfigs.push({ label: i18next.t("menu:password"), isPassword: true }); + return inputFieldConfigs; + } + override show(args: any[]): boolean { if (super.show(args)) { @@ -124,7 +128,7 @@ export default class LoginFormUiHandler extends FormModalUiHandler { // Prevent overlapping overrides on action modification this.submitAction = originalLoginAction; this.sanitizeInputs(); - this.scene.ui.setMode(Mode.LOADING, { buttonActions: [] }); + this.scene.ui.setMode(Mode.LOADING, { buttonActions: []}); const onFail = error => { this.scene.ui.setMode(Mode.LOGIN_FORM, Object.assign(config, { errorMessage: error?.trim() })); this.scene.ui.playError(); @@ -132,21 +136,16 @@ export default class LoginFormUiHandler extends FormModalUiHandler { if (!this.inputs[0].text) { return onFail(i18next.t("menu:emptyUsername")); } - Utils.apiPost("account/login", `username=${encodeURIComponent(this.inputs[0].text)}&password=${encodeURIComponent(this.inputs[1].text)}`, "application/x-www-form-urlencoded") - .then(response => { - if (!response.ok) { - return response.text(); - } - return response.json(); - }) - .then(response => { - if (response.hasOwnProperty("token")) { - Utils.setCookie(Utils.sessionIdKey, response.token); - originalLoginAction && originalLoginAction(); - } else { - onFail(response); - } - }); + + const [ usernameInput, passwordInput ] = this.inputs; + + pokerogueApi.account.login({ username: usernameInput.text, password: passwordInput.text }).then(error => { + if (!error) { + originalLoginAction && originalLoginAction(); + } else { + onFail(error); + } + }); }; return true; @@ -161,19 +160,19 @@ export default class LoginFormUiHandler extends FormModalUiHandler { this.infoContainer.setVisible(false); this.setMouseCursorStyle("default"); //reset cursor - [this.discordImage, this.googleImage, this.usernameInfoImage].forEach((img) => img.off("pointerdown")); + [ this.discordImage, this.googleImage, this.usernameInfoImage ].forEach((img) => img.off("pointerdown")); } - private processExternalProvider(config: ModalConfig) : void { + private processExternalProvider(config: ModalConfig): void { this.externalPartyTitle.setText(i18next.t("menu:orUse") ?? ""); - this.externalPartyTitle.setX(20+this.externalPartyTitle.text.length); + this.externalPartyTitle.setX(20 + this.externalPartyTitle.text.length); this.externalPartyTitle.setVisible(true); this.externalPartyContainer.setPositionRelative(this.modalContainer, 175, 0); this.externalPartyContainer.setVisible(true); this.externalPartyBg.setSize(this.externalPartyTitle.text.length + 50, this.modalBg.height); this.getUi().moveTo(this.externalPartyContainer, this.getUi().length - 1); - this.googleImage.setPosition(this.externalPartyBg.width/3.1, this.externalPartyBg.height-60); - this.discordImage.setPosition(this.externalPartyBg.width/3.1, this.externalPartyBg.height-40); + this.googleImage.setPosition(this.externalPartyBg.width / 3.1, this.externalPartyBg.height - 60); + this.discordImage.setPosition(this.externalPartyBg.width / 3.1, this.externalPartyBg.height - 40); this.infoContainer.setPosition(5, -76); this.infoContainer.setVisible(true); @@ -195,7 +194,7 @@ export default class LoginFormUiHandler extends FormModalUiHandler { }); const onFail = error => { - this.scene.ui.setMode(Mode.LOADING, { buttonActions: [] }); + this.scene.ui.setMode(Mode.LOADING, { buttonActions: []}); this.scene.ui.setModeForceTransition(Mode.LOGIN_FORM, Object.assign(config, { errorMessage: error?.trim() })); this.scene.ui.playError(); }; diff --git a/src/ui/menu-ui-handler.ts b/src/ui/menu-ui-handler.ts index 0af527e518f..3ce3f3b7cf0 100644 --- a/src/ui/menu-ui-handler.ts +++ b/src/ui/menu-ui-handler.ts @@ -13,6 +13,8 @@ import { GameDataType } from "#enums/game-data-type"; import BgmBar from "#app/ui/bgm-bar"; import AwaitableUiHandler from "./awaitable-ui-handler"; import { SelectModifierPhase } from "#app/phases/select-modifier-phase"; +import { AdminMode, getAdminModeName } from "./admin-ui-handler"; +import { pokerogueApi } from "#app/plugins/api/pokerogue-api"; enum MenuOptions { GAME_SETTINGS, @@ -31,7 +33,7 @@ let wikiUrl = "https://wiki.pokerogue.net/start"; const discordUrl = "https://discord.gg/uWpTfdKG49"; const githubUrl = "https://github.com/pagefaultgames/pokerogue"; const redditUrl = "https://www.reddit.com/r/pokerogue"; -const donateUrl = "https://github.com/sponsors/patapancakes"; +const donateUrl = "https://github.com/sponsors/pagefaultgames"; export default class MenuUiHandler extends MessageUiHandler { private readonly textPadding = 8; @@ -65,8 +67,8 @@ export default class MenuUiHandler extends MessageUiHandler { super(scene, mode); this.excludedMenus = () => [ - { condition: [Mode.COMMAND, Mode.TITLE].includes(mode ?? Mode.TITLE), options: [MenuOptions.EGG_GACHA, MenuOptions.EGG_LIST] }, - { condition: bypassLogin, options: [MenuOptions.LOG_OUT] } + { condition: [ Mode.COMMAND, Mode.TITLE ].includes(mode ?? Mode.TITLE), options: [ MenuOptions.EGG_GACHA, MenuOptions.EGG_LIST ]}, + { condition: bypassLogin, options: [ MenuOptions.LOG_OUT ]} ]; this.menuOptions = Utils.getEnumKeys(MenuOptions) @@ -80,7 +82,7 @@ export default class MenuUiHandler extends MessageUiHandler { const ui = this.getUi(); // wiki url directs based on languges available on wiki const lang = i18next.resolvedLanguage?.substring(0, 2)!; // TODO: is this bang correct? - if (["de", "fr", "ko", "zh"].includes(lang)) { + if ([ "de", "fr", "ko", "zh" ].includes(lang)) { wikiUrl = `https://wiki.pokerogue.net/${lang}:start`; } @@ -108,8 +110,8 @@ export default class MenuUiHandler extends MessageUiHandler { render() { const ui = this.getUi(); this.excludedMenus = () => [ - { condition: this.scene.getCurrentPhase() instanceof SelectModifierPhase, options: [MenuOptions.EGG_GACHA, MenuOptions.EGG_LIST] }, - { condition: bypassLogin, options: [MenuOptions.LOG_OUT] } + { condition: this.scene.getCurrentPhase() instanceof SelectModifierPhase, options: [ MenuOptions.EGG_GACHA, MenuOptions.EGG_LIST ]}, + { condition: bypassLogin, options: [ MenuOptions.LOG_OUT ]} ]; this.menuOptions = Utils.getEnumKeys(MenuOptions) @@ -387,16 +389,41 @@ export default class MenuUiHandler extends MessageUiHandler { communityOptions.push({ label: "Admin", handler: () => { - ui.playSelect(); - ui.setOverlayMode(Mode.ADMIN, { - buttonActions: [ - () => { - ui.revertMode(); - }, - () => { - ui.revertMode(); + + const skippedAdminModes: AdminMode[] = [ AdminMode.ADMIN ]; // this is here so that we can skip the menu populating enums that aren't meant for the menu, such as the AdminMode.ADMIN + const options: OptionSelectItem[] = []; + Object.values(AdminMode).filter((v) => !isNaN(Number(v)) && !skippedAdminModes.includes(v as AdminMode)).forEach((mode) => { // this gets all the enums in a way we can use + options.push({ + label: getAdminModeName(mode as AdminMode), + handler: () => { + ui.playSelect(); + ui.setOverlayMode(Mode.ADMIN, { + buttonActions: [ + // we double revert here and below to go back 2 layers of menus + () => { + ui.revertMode(); + ui.revertMode(); + }, + () => { + ui.revertMode(); + ui.revertMode(); + } + ] + }, mode); // mode is our AdminMode enum + return true; } - ] + }); + }); + options.push({ + label: "Cancel", + handler: () => { + ui.revertMode(); + return true; + } + }); + this.scene.ui.setOverlayMode(Mode.OPTION_SELECT, { + options: options, + delay: 0 }); return true; }, @@ -468,148 +495,138 @@ export default class MenuUiHandler extends MessageUiHandler { } this.showText("", 0); switch (adjustedCursor) { - case MenuOptions.GAME_SETTINGS: - ui.setOverlayMode(Mode.SETTINGS); - success = true; - break; - case MenuOptions.ACHIEVEMENTS: - ui.setOverlayMode(Mode.ACHIEVEMENTS); - success = true; - break; - case MenuOptions.STATS: - ui.setOverlayMode(Mode.GAME_STATS); - success = true; - break; - case MenuOptions.RUN_HISTORY: - ui.setOverlayMode(Mode.RUN_HISTORY); - success = true; - break; - case MenuOptions.EGG_LIST: - if (this.scene.gameData.eggs.length) { + case MenuOptions.GAME_SETTINGS: + ui.setOverlayMode(Mode.SETTINGS); + success = true; + break; + case MenuOptions.ACHIEVEMENTS: + ui.setOverlayMode(Mode.ACHIEVEMENTS); + success = true; + break; + case MenuOptions.STATS: + ui.setOverlayMode(Mode.GAME_STATS); + success = true; + break; + case MenuOptions.RUN_HISTORY: + ui.setOverlayMode(Mode.RUN_HISTORY); + success = true; + break; + case MenuOptions.EGG_LIST: + if (this.scene.gameData.eggs.length) { + ui.revertMode(); + ui.setOverlayMode(Mode.EGG_LIST); + success = true; + } else { + ui.showText(i18next.t("menuUiHandler:noEggs"), null, () => ui.showText(""), Utils.fixedInt(1500)); + error = true; + } + break; + case MenuOptions.EGG_GACHA: ui.revertMode(); - ui.setOverlayMode(Mode.EGG_LIST); + ui.setOverlayMode(Mode.EGG_GACHA); success = true; - } else { - ui.showText(i18next.t("menuUiHandler:noEggs"), null, () => ui.showText(""), Utils.fixedInt(1500)); - error = true; - } - break; - case MenuOptions.EGG_GACHA: - ui.revertMode(); - ui.setOverlayMode(Mode.EGG_GACHA); - success = true; - break; - case MenuOptions.MANAGE_DATA: - if (!bypassLogin && !this.manageDataConfig.options.some(o => o.label === i18next.t("menuUiHandler:linkDiscord") || o.label === i18next.t("menuUiHandler:unlinkDiscord"))) { - this.manageDataConfig.options.splice(this.manageDataConfig.options.length - 1, 0, - { - label: loggedInUser?.discordId === "" ? i18next.t("menuUiHandler:linkDiscord") : i18next.t("menuUiHandler:unlinkDiscord"), - handler: () => { - if (loggedInUser?.discordId === "") { - const token = Utils.getCookie(Utils.sessionIdKey); - const redirectUri = encodeURIComponent(`${import.meta.env.VITE_SERVER_URL}/auth/discord/callback`); - const discordId = import.meta.env.VITE_DISCORD_CLIENT_ID; - const discordUrl = `https://discord.com/api/oauth2/authorize?client_id=${discordId}&redirect_uri=${redirectUri}&response_type=code&scope=identify&state=${token}&prompt=none`; - window.open(discordUrl, "_self"); - return true; - } else { - Utils.apiPost("/auth/discord/logout", undefined, undefined, true).then(res => { - if (!res.ok) { - console.error(`Unlink failed (${res.status}: ${res.statusText})`); - } - updateUserInfo().then(() => this.scene.reset(true, true)); - }); - return true; + break; + case MenuOptions.MANAGE_DATA: + if (!bypassLogin && !this.manageDataConfig.options.some(o => o.label === i18next.t("menuUiHandler:linkDiscord") || o.label === i18next.t("menuUiHandler:unlinkDiscord"))) { + this.manageDataConfig.options.splice(this.manageDataConfig.options.length - 1, 0, + { + label: loggedInUser?.discordId === "" ? i18next.t("menuUiHandler:linkDiscord") : i18next.t("menuUiHandler:unlinkDiscord"), + handler: () => { + if (loggedInUser?.discordId === "") { + const token = Utils.getCookie(Utils.sessionIdKey); + const redirectUri = encodeURIComponent(`${import.meta.env.VITE_SERVER_URL}/auth/discord/callback`); + const discordId = import.meta.env.VITE_DISCORD_CLIENT_ID; + const discordUrl = `https://discord.com/api/oauth2/authorize?client_id=${discordId}&redirect_uri=${redirectUri}&response_type=code&scope=identify&state=${token}&prompt=none`; + window.open(discordUrl, "_self"); + return true; + } else { + pokerogueApi.unlinkDiscord().then(_isSuccess => { + updateUserInfo().then(() => this.scene.reset(true, true)); + }); + return true; + } } - } - }, - { - label: loggedInUser?.googleId === "" ? i18next.t("menuUiHandler:linkGoogle") : i18next.t("menuUiHandler:unlinkGoogle"), - handler: () => { - if (loggedInUser?.googleId === "") { - const token = Utils.getCookie(Utils.sessionIdKey); - const redirectUri = encodeURIComponent(`${import.meta.env.VITE_SERVER_URL}/auth/google/callback`); - const googleId = import.meta.env.VITE_GOOGLE_CLIENT_ID; - const googleUrl = `https://accounts.google.com/o/oauth2/auth?client_id=${googleId}&response_type=code&redirect_uri=${redirectUri}&scope=openid&state=${token}`; - window.open(googleUrl, "_self"); - return true; - } else { - Utils.apiPost("/auth/google/logout", undefined, undefined, true).then(res => { - if (!res.ok) { - console.error(`Unlink failed (${res.status}: ${res.statusText})`); - } - updateUserInfo().then(() => this.scene.reset(true, true)); - }); - return true; + }, + { + label: loggedInUser?.googleId === "" ? i18next.t("menuUiHandler:linkGoogle") : i18next.t("menuUiHandler:unlinkGoogle"), + handler: () => { + if (loggedInUser?.googleId === "") { + const token = Utils.getCookie(Utils.sessionIdKey); + const redirectUri = encodeURIComponent(`${import.meta.env.VITE_SERVER_URL}/auth/google/callback`); + const googleId = import.meta.env.VITE_GOOGLE_CLIENT_ID; + const googleUrl = `https://accounts.google.com/o/oauth2/auth?client_id=${googleId}&response_type=code&redirect_uri=${redirectUri}&scope=openid&state=${token}`; + window.open(googleUrl, "_self"); + return true; + } else { + pokerogueApi.unlinkGoogle().then(_isSuccess => { + updateUserInfo().then(() => this.scene.reset(true, true)); + }); + return true; + } } - } - }); - } - ui.setOverlayMode(Mode.MENU_OPTION_SELECT, this.manageDataConfig); - success = true; - break; - case MenuOptions.COMMUNITY: - ui.setOverlayMode(Mode.MENU_OPTION_SELECT, this.communityConfig); - success = true; - break; - case MenuOptions.SAVE_AND_QUIT: - if (this.scene.currentBattle) { + }); + } + ui.setOverlayMode(Mode.MENU_OPTION_SELECT, this.manageDataConfig); success = true; - const doSaveQuit = () => { - ui.setMode(Mode.LOADING, { - buttonActions: [], fadeOut: () => - this.scene.gameData.saveAll(this.scene, true, true, true, true).then(() => { + break; + case MenuOptions.COMMUNITY: + ui.setOverlayMode(Mode.MENU_OPTION_SELECT, this.communityConfig); + success = true; + break; + case MenuOptions.SAVE_AND_QUIT: + if (this.scene.currentBattle) { + success = true; + const doSaveQuit = () => { + ui.setMode(Mode.LOADING, { + buttonActions: [], fadeOut: () => + this.scene.gameData.saveAll(this.scene, true, true, true, true).then(() => { - this.scene.reset(true); - }) + this.scene.reset(true); + }) + }); + }; + if (this.scene.currentBattle.turn > 1) { + ui.showText(i18next.t("menuUiHandler:losingProgressionWarning"), null, () => { + if (!this.active) { + this.showText("", 0); + return; + } + ui.setOverlayMode(Mode.CONFIRM, doSaveQuit, () => { + ui.revertMode(); + this.showText("", 0); + }, false, -98); + }); + } else { + doSaveQuit(); + } + } else { + error = true; + } + break; + case MenuOptions.LOG_OUT: + success = true; + const doLogout = () => { + ui.setMode(Mode.LOADING, { + buttonActions: [], fadeOut: () => pokerogueApi.account.logout().then(() => { + updateUserInfo().then(() => this.scene.reset(true, true)); + }) }); }; - if (this.scene.currentBattle.turn > 1) { + if (this.scene.currentBattle) { ui.showText(i18next.t("menuUiHandler:losingProgressionWarning"), null, () => { if (!this.active) { this.showText("", 0); return; } - ui.setOverlayMode(Mode.CONFIRM, doSaveQuit, () => { + ui.setOverlayMode(Mode.CONFIRM, doLogout, () => { ui.revertMode(); this.showText("", 0); }, false, -98); }); } else { - doSaveQuit(); + doLogout(); } - } else { - error = true; - } - break; - case MenuOptions.LOG_OUT: - success = true; - const doLogout = () => { - ui.setMode(Mode.LOADING, { - buttonActions: [], fadeOut: () => Utils.apiFetch("account/logout", true).then(res => { - if (!res.ok) { - console.error(`Log out failed (${res.status}: ${res.statusText})`); - } - Utils.removeCookie(Utils.sessionIdKey); - updateUserInfo().then(() => this.scene.reset(true, true)); - }) - }); - }; - if (this.scene.currentBattle) { - ui.showText(i18next.t("menuUiHandler:losingProgressionWarning"), null, () => { - if (!this.active) { - this.showText("", 0); - return; - } - ui.setOverlayMode(Mode.CONFIRM, doLogout, () => { - ui.revertMode(); - this.showText("", 0); - }, false, -98); - }); - } else { - doLogout(); - } - break; + break; } } else if (button === Button.CANCEL) { success = true; @@ -620,20 +637,20 @@ export default class MenuUiHandler extends MessageUiHandler { }); } else { switch (button) { - case Button.UP: - if (this.cursor) { - success = this.setCursor(this.cursor - 1); - } else { - success = this.setCursor(this.menuOptions.length - 1); - } - break; - case Button.DOWN: - if (this.cursor + 1 < this.menuOptions.length) { - success = this.setCursor(this.cursor + 1); - } else { - success = this.setCursor(0); - } - break; + case Button.UP: + if (this.cursor) { + success = this.setCursor(this.cursor - 1); + } else { + success = this.setCursor(this.menuOptions.length - 1); + } + break; + case Button.DOWN: + if (this.cursor + 1 < this.menuOptions.length) { + success = this.setCursor(this.cursor + 1); + } else { + success = this.setCursor(0); + } + break; } } diff --git a/src/ui/message-ui-handler.ts b/src/ui/message-ui-handler.ts index 54965a590fc..5ae4707e329 100644 --- a/src/ui/message-ui-handler.ts +++ b/src/ui/message-ui-handler.ts @@ -56,18 +56,18 @@ export default abstract class MessageUiHandler extends AwaitableUiHandler { let actionMatch: RegExpExecArray | null; while ((actionMatch = actionPattern.exec(text))) { switch (actionMatch[1]) { - case "c": - charVarMap.set(actionMatch.index, actionMatch[2]); - break; - case "d": - delayMap.set(actionMatch.index, parseInt(actionMatch[2])); - break; - case "s": - soundMap.set(actionMatch.index, actionMatch[2]); - break; - case "f": - fadeMap.set(actionMatch.index, parseInt(actionMatch[2])); - break; + case "c": + charVarMap.set(actionMatch.index, actionMatch[2]); + break; + case "d": + delayMap.set(actionMatch.index, parseInt(actionMatch[2])); + break; + case "s": + soundMap.set(actionMatch.index, actionMatch[2]); + break; + case "f": + fadeMap.set(actionMatch.index, parseInt(actionMatch[2])); + break; } text = text.slice(0, actionMatch.index) + text.slice(actionMatch.index + actionMatch[2].length + 4); } @@ -223,6 +223,14 @@ export default abstract class MessageUiHandler extends AwaitableUiHandler { }; } + isTextAnimationInProgress() { + if (this.textTimer) { + return this.textTimer.repeatCount < this.textTimer.repeat; + } + + return false; + } + clearText() { this.message.setText(""); this.pendingPrompt = false; diff --git a/src/ui/modal-ui-handler.ts b/src/ui/modal-ui-handler.ts index 80a39d7bf7f..79f1e8afeed 100644 --- a/src/ui/modal-ui-handler.ts +++ b/src/ui/modal-ui-handler.ts @@ -3,7 +3,7 @@ import { TextStyle, addTextObject } from "./text"; import { Mode } from "./ui"; import UiHandler from "./ui-handler"; import { WindowVariant, addWindow } from "./ui-theme"; -import {Button} from "#enums/buttons"; +import { Button } from "#enums/buttons"; export interface ModalConfig { buttonActions: Function[]; @@ -15,12 +15,14 @@ export abstract class ModalUiHandler extends UiHandler { protected titleText: Phaser.GameObjects.Text; protected buttonContainers: Phaser.GameObjects.Container[]; protected buttonBgs: Phaser.GameObjects.NineSlice[]; + protected buttonLabels: Phaser.GameObjects.Text[]; constructor(scene: BattleScene, mode: Mode | null = null) { super(scene, mode); this.buttonContainers = []; this.buttonBgs = []; + this.buttonLabels = []; } abstract getModalTitle(config?: ModalConfig): string; @@ -75,6 +77,7 @@ export abstract class ModalUiHandler extends UiHandler { const buttonContainer = this.scene.add.container(0, buttonTopMargin); + this.buttonLabels.push(buttonLabel); this.buttonBgs.push(buttonBg); this.buttonContainers.push(buttonContainer); @@ -92,7 +95,7 @@ export abstract class ModalUiHandler extends UiHandler { if (args[0].hasOwnProperty("fadeOut") && typeof args[0].fadeOut === "function") { const [ marginTop, marginRight, marginBottom, marginLeft ] = this.getMargin(); - const overlay = this.scene.add.rectangle(( this.getWidth() + marginLeft + marginRight) / 2, (this.getHeight() + marginTop + marginBottom) / 2, this.scene.game.canvas.width / 6, this.scene.game.canvas.height /6, 0); + const overlay = this.scene.add.rectangle(( this.getWidth() + marginLeft + marginRight) / 2, (this.getHeight() + marginTop + marginBottom) / 2, this.scene.game.canvas.width / 6, this.scene.game.canvas.height / 6, 0); overlay.setOrigin(0.5, 0.5); overlay.setName("rect-ui-overlay-modal"); overlay.setAlpha(0); diff --git a/src/ui/modifier-select-ui-handler.ts b/src/ui/modifier-select-ui-handler.ts index c9d3f195720..a0358b5ca8c 100644 --- a/src/ui/modifier-select-ui-handler.ts +++ b/src/ui/modifier-select-ui-handler.ts @@ -1,6 +1,6 @@ import BattleScene from "../battle-scene"; import { getPlayerShopModifierTypeOptionsForWave, ModifierTypeOption, TmModifierType } from "../modifier/modifier-type"; -import { getPokeballAtlasKey, PokeballType } from "../data/pokeball"; +import { getPokeballAtlasKey } from "#app/data/pokeball"; import { addTextObject, getTextStyleOptions, getModifierTierTextTint, getTextColor, TextStyle } from "./text"; import AwaitableUiHandler from "./awaitable-ui-handler"; import { Mode } from "./ui"; @@ -15,8 +15,12 @@ import i18next from "i18next"; import { ShopCursorTarget } from "#app/enums/shop-cursor-target"; import { IntegerHolder } from "./../utils"; import Phaser from "phaser"; +import type { PokeballType } from "#enums/pokeball"; -export const SHOP_OPTIONS_ROW_LIMIT = 6; +export const SHOP_OPTIONS_ROW_LIMIT = 7; +const SINGLE_SHOP_ROW_YOFFSET = 12; +const DOUBLE_SHOP_ROW_YOFFSET = 24; +const OPTION_BUTTON_YPOSITION = -62; export default class ModifierSelectUiHandler extends AwaitableUiHandler { private modifierContainer: Phaser.GameObjects.Container; @@ -68,7 +72,7 @@ export default class ModifierSelectUiHandler extends AwaitableUiHandler { this.checkButtonWidth = context.measureText(i18next.t("modifierSelectUiHandler:checkTeam")).width; } - this.transferButtonContainer = this.scene.add.container((this.scene.game.canvas.width - this.checkButtonWidth) / 6 - 21, -64); + this.transferButtonContainer = this.scene.add.container((this.scene.game.canvas.width - this.checkButtonWidth) / 6 - 21, OPTION_BUTTON_YPOSITION); this.transferButtonContainer.setName("transfer-btn"); this.transferButtonContainer.setVisible(false); ui.add(this.transferButtonContainer); @@ -78,7 +82,7 @@ export default class ModifierSelectUiHandler extends AwaitableUiHandler { transferButtonText.setOrigin(1, 0); this.transferButtonContainer.add(transferButtonText); - this.checkButtonContainer = this.scene.add.container((this.scene.game.canvas.width) / 6 - 1, -64); + this.checkButtonContainer = this.scene.add.container((this.scene.game.canvas.width) / 6 - 1, OPTION_BUTTON_YPOSITION); this.checkButtonContainer.setName("use-btn"); this.checkButtonContainer.setVisible(false); ui.add(this.checkButtonContainer); @@ -88,7 +92,7 @@ export default class ModifierSelectUiHandler extends AwaitableUiHandler { checkButtonText.setOrigin(1, 0); this.checkButtonContainer.add(checkButtonText); - this.rerollButtonContainer = this.scene.add.container(16, -64); + this.rerollButtonContainer = this.scene.add.container(16, OPTION_BUTTON_YPOSITION); this.rerollButtonContainer.setName("reroll-brn"); this.rerollButtonContainer.setVisible(false); ui.add(this.rerollButtonContainer); @@ -104,7 +108,7 @@ export default class ModifierSelectUiHandler extends AwaitableUiHandler { this.rerollCostText.setPositionRelative(rerollButtonText, rerollButtonText.displayWidth + 5, 1); this.rerollButtonContainer.add(this.rerollCostText); - this.lockRarityButtonContainer = this.scene.add.container(16, -64); + this.lockRarityButtonContainer = this.scene.add.container(16, OPTION_BUTTON_YPOSITION); this.lockRarityButtonContainer.setVisible(false); ui.add(this.lockRarityButtonContainer); @@ -160,7 +164,7 @@ export default class ModifierSelectUiHandler extends AwaitableUiHandler { this.player = args[0]; - const partyHasHeldItem = this.player && !!this.scene.findModifiers(m => m instanceof PokemonHeldItemModifier && m.isTransferrable).length; + const partyHasHeldItem = this.player && !!this.scene.findModifiers(m => m instanceof PokemonHeldItemModifier && m.isTransferable).length; const canLockRarities = !!this.scene.findModifier(m => m instanceof LockModifierTiersModifier); this.transferButtonContainer.setVisible(false); @@ -191,7 +195,7 @@ export default class ModifierSelectUiHandler extends AwaitableUiHandler { const shopTypeOptions = !removeHealShop ? getPlayerShopModifierTypeOptionsForWave(this.scene.currentBattle.waveIndex, baseShopCost.value) : []; - const optionsYOffset = shopTypeOptions.length >= SHOP_OPTIONS_ROW_LIMIT ? -8 : -24; + const optionsYOffset = shopTypeOptions.length > SHOP_OPTIONS_ROW_LIMIT ? -SINGLE_SHOP_ROW_YOFFSET : -DOUBLE_SHOP_ROW_YOFFSET; for (let m = 0; m < typeOptions.length; m++) { const sliceWidth = (this.scene.game.canvas.width / 6) / (typeOptions.length + 2); @@ -211,8 +215,8 @@ export default class ModifierSelectUiHandler extends AwaitableUiHandler { const row = m < SHOP_OPTIONS_ROW_LIMIT ? 0 : 1; const col = m < SHOP_OPTIONS_ROW_LIMIT ? m : m - SHOP_OPTIONS_ROW_LIMIT; const rowOptions = shopTypeOptions.slice(row ? SHOP_OPTIONS_ROW_LIMIT : 0, row ? undefined : SHOP_OPTIONS_ROW_LIMIT); - const sliceWidth = (this.scene.game.canvas.width / SHOP_OPTIONS_ROW_LIMIT) / (rowOptions.length + 2); - const option = new ModifierOption(this.scene, sliceWidth * (col + 1) + (sliceWidth * 0.5), ((-this.scene.game.canvas.height / 12) - (this.scene.game.canvas.height / 32) - (40 - (28 * row - 1))), shopTypeOptions[m]); + const sliceWidth = (this.scene.game.canvas.width / 6) / (rowOptions.length + 2); + const option = new ModifierOption(this.scene, sliceWidth * (col + 1) + (sliceWidth * 0.5), ((-this.scene.game.canvas.height / 12) - (this.scene.game.canvas.height / 32) - (42 - (28 * row - 1))), shopTypeOptions[m]); option.setScale(0.375); this.scene.add.existing(option); this.modifierContainer.add(option); @@ -277,13 +281,13 @@ export default class ModifierSelectUiHandler extends AwaitableUiHandler { this.lockRarityButtonContainer.setVisible(canLockRarities); this.scene.tweens.add({ - targets: [ this.lockRarityButtonContainer, this.checkButtonContainer, this.continueButtonContainer ], + targets: [ this.checkButtonContainer, this.continueButtonContainer ], alpha: 1, duration: 250 }); this.scene.tweens.add({ - targets: [this.rerollButtonContainer], + targets: [ this.rerollButtonContainer, this.lockRarityButtonContainer ], alpha: this.rerollCost < 0 ? 0.5 : 1, duration: 250 }); @@ -354,79 +358,79 @@ export default class ModifierSelectUiHandler extends AwaitableUiHandler { } } else { switch (button) { - case Button.UP: - if (this.rowCursor === 0 && this.cursor === 3) { - success = this.setCursor(0); - } else if (this.rowCursor < this.shopOptionsRows.length + 1) { - success = this.setRowCursor(this.rowCursor + 1); - } - break; - case Button.DOWN: - if (this.rowCursor) { - success = this.setRowCursor(this.rowCursor - 1); - } else if (this.lockRarityButtonContainer.visible && this.cursor === 0) { - success = this.setCursor(3); - } - break; - case Button.LEFT: - if (!this.rowCursor) { - switch (this.cursor) { - case 0: - success = false; - break; - case 1: - if (this.lockRarityButtonContainer.visible) { - success = this.setCursor(3); - } else { - success = this.rerollButtonContainer.visible && this.setCursor(0); - } - break; - case 2: - if (this.transferButtonContainer.visible) { - success = this.setCursor(1); - } else if (this.rerollButtonContainer.visible) { - success = this.setCursor(0); - } else { - success = false; - } - break; + case Button.UP: + if (this.rowCursor === 0 && this.cursor === 3) { + success = this.setCursor(0); + } else if (this.rowCursor < this.shopOptionsRows.length + 1) { + success = this.setRowCursor(this.rowCursor + 1); } - } else if (this.cursor) { - success = this.setCursor(this.cursor - 1); - } else if (this.rowCursor === 1 && this.rerollButtonContainer.visible) { - success = this.setRowCursor(0); - } - break; - case Button.RIGHT: - if (!this.rowCursor) { - switch (this.cursor) { - case 0: - if (this.transferButtonContainer.visible) { - success = this.setCursor(1); - } else { - success = this.setCursor(2); - } - break; - case 1: - success = this.setCursor(2); - break; - case 2: - success = false; - break; - case 3: - if (this.transferButtonContainer.visible) { - success = this.setCursor(1); - } else { - success = this.setCursor(2); - } - break; + break; + case Button.DOWN: + if (this.rowCursor) { + success = this.setRowCursor(this.rowCursor - 1); + } else if (this.lockRarityButtonContainer.visible && this.cursor === 0) { + success = this.setCursor(3); } - } else if (this.cursor < this.getRowItems(this.rowCursor) - 1) { - success = this.setCursor(this.cursor + 1); - } else if (this.rowCursor === 1 && this.transferButtonContainer.visible) { - success = this.setRowCursor(0); - } - break; + break; + case Button.LEFT: + if (!this.rowCursor) { + switch (this.cursor) { + case 0: + success = false; + break; + case 1: + if (this.lockRarityButtonContainer.visible) { + success = this.setCursor(3); + } else { + success = this.rerollButtonContainer.visible && this.setCursor(0); + } + break; + case 2: + if (this.transferButtonContainer.visible) { + success = this.setCursor(1); + } else if (this.rerollButtonContainer.visible) { + success = this.setCursor(0); + } else { + success = false; + } + break; + } + } else if (this.cursor) { + success = this.setCursor(this.cursor - 1); + } else if (this.rowCursor === 1 && this.rerollButtonContainer.visible) { + success = this.setRowCursor(0); + } + break; + case Button.RIGHT: + if (!this.rowCursor) { + switch (this.cursor) { + case 0: + if (this.transferButtonContainer.visible) { + success = this.setCursor(1); + } else { + success = this.setCursor(2); + } + break; + case 1: + success = this.setCursor(2); + break; + case 2: + success = false; + break; + case 3: + if (this.transferButtonContainer.visible) { + success = this.setCursor(1); + } else { + success = this.setCursor(2); + } + break; + } + } else if (this.cursor < this.getRowItems(this.rowCursor) - 1) { + success = this.setCursor(this.cursor + 1); + } else if (this.rowCursor === 1 && this.transferButtonContainer.visible) { + success = this.setRowCursor(0); + } + break; } } @@ -456,16 +460,18 @@ export default class ModifierSelectUiHandler extends AwaitableUiHandler { if (this.rowCursor === 1 && options.length === 0) { // Continue button when no shop items this.cursorObj.setScale(1.25); - this.cursorObj.setPosition((this.scene.game.canvas.width / 18) + 23, (-this.scene.game.canvas.height / 12) - (this.shopOptionsRows.length > 1 ? 6 : 22)); + this.cursorObj.setPosition((this.scene.game.canvas.width / 18) + 23, (-this.scene.game.canvas.height / 12) - (this.shopOptionsRows.length > 1 ? SINGLE_SHOP_ROW_YOFFSET - 2 : DOUBLE_SHOP_ROW_YOFFSET - 2)); ui.showText(i18next.t("modifierSelectUiHandler:continueNextWaveDescription")); return ret; } const sliceWidth = (this.scene.game.canvas.width / 6) / (options.length + 2); if (this.rowCursor < 2) { - this.cursorObj.setPosition(sliceWidth * (cursor + 1) + (sliceWidth * 0.5) - 20, (-this.scene.game.canvas.height / 12) - (this.shopOptionsRows.length > 1 ? 6 : 22)); + // Cursor on free items + this.cursorObj.setPosition(sliceWidth * (cursor + 1) + (sliceWidth * 0.5) - 20, (-this.scene.game.canvas.height / 12) - (this.shopOptionsRows.length > 1 ? SINGLE_SHOP_ROW_YOFFSET - 2 : DOUBLE_SHOP_ROW_YOFFSET - 2)); } else { - this.cursorObj.setPosition(sliceWidth * (cursor + 1) + (sliceWidth * 0.5) - 16, (-this.scene.game.canvas.height / 12 - this.scene.game.canvas.height / 32) - (-16 + 28 * (this.rowCursor - (this.shopOptionsRows.length - 1)))); + // Cursor on paying items + this.cursorObj.setPosition(sliceWidth * (cursor + 1) + (sliceWidth * 0.5) - 16, (-this.scene.game.canvas.height / 12 - this.scene.game.canvas.height / 32) - (-14 + 28 * (this.rowCursor - (this.shopOptionsRows.length - 1)))); } const type = options[this.cursor].modifierTypeOption.type; @@ -475,16 +481,16 @@ export default class ModifierSelectUiHandler extends AwaitableUiHandler { this.moveInfoOverlay.show(allMoves[type.moveId]); } } else if (cursor === 0) { - this.cursorObj.setPosition(6, this.lockRarityButtonContainer.visible ? -72 : -60); + this.cursorObj.setPosition(6, this.lockRarityButtonContainer.visible ? OPTION_BUTTON_YPOSITION - 8 : OPTION_BUTTON_YPOSITION + 4); ui.showText(i18next.t("modifierSelectUiHandler:rerollDesc")); } else if (cursor === 1) { - this.cursorObj.setPosition((this.scene.game.canvas.width - this.transferButtonWidth - this.checkButtonWidth) / 6 - 30, -60); + this.cursorObj.setPosition((this.scene.game.canvas.width - this.transferButtonWidth - this.checkButtonWidth) / 6 - 30, OPTION_BUTTON_YPOSITION + 4); ui.showText(i18next.t("modifierSelectUiHandler:transferDesc")); } else if (cursor === 2) { - this.cursorObj.setPosition((this.scene.game.canvas.width - this.checkButtonWidth) / 6 - 10, -60); + this.cursorObj.setPosition((this.scene.game.canvas.width - this.checkButtonWidth) / 6 - 10, OPTION_BUTTON_YPOSITION + 4); ui.showText(i18next.t("modifierSelectUiHandler:checkTeamDesc")); } else { - this.cursorObj.setPosition(6, -60); + this.cursorObj.setPosition(6, OPTION_BUTTON_YPOSITION + 4); ui.showText(i18next.t("modifierSelectUiHandler:lockRaritiesDesc")); } @@ -522,12 +528,12 @@ export default class ModifierSelectUiHandler extends AwaitableUiHandler { private getRowItems(rowCursor: integer): integer { switch (rowCursor) { - case 0: - return 3; - case 1: - return this.options.length; - default: - return this.shopOptionsRows[this.shopOptionsRows.length - (rowCursor - 1)].length; + case 0: + return 3; + case 1: + return this.options.length; + default: + return this.shopOptionsRows[this.shopOptionsRows.length - (rowCursor - 1)].length; } } @@ -577,6 +583,10 @@ export default class ModifierSelectUiHandler extends AwaitableUiHandler { this.getUi().clearText(); this.eraseCursor(); + // Reset cursor positions + this.cursor = 0; + this.rowCursor = 0; + /* Multiplies the fade time duration by the speed parameter so that it is always constant, and avoids "flashbangs" at game speed x5 */ this.scene.hideShopOverlay(750 * this.scene.gameSpeed); this.scene.hideLuckText(250); diff --git a/src/ui/move-info-overlay.ts b/src/ui/move-info-overlay.ts index a99e4c81e27..d9c4200ea9b 100644 --- a/src/ui/move-info-overlay.ts +++ b/src/ui/move-info-overlay.ts @@ -1,9 +1,9 @@ -import BattleScene, {InfoToggle} from "../battle-scene"; +import BattleScene, { InfoToggle } from "../battle-scene"; import { TextStyle, addTextObject } from "./text"; import { addWindow } from "./ui-theme"; import * as Utils from "../utils"; import Move, { MoveCategory } from "../data/move"; -import { Type } from "../data/type"; +import { Type } from "#enums/type"; import i18next from "i18next"; export interface MoveInfoOverlaySettings { @@ -15,12 +15,16 @@ export interface MoveInfoOverlaySettings { //location and width of the component; unaffected by scaling x?: number; y?: number; - width?: number; // default is always half the screen, regardless of scale + /** Default is always half the screen, regardless of scale */ + width?: number; + /** Determines whether to display the small secondary box */ + hideEffectBox?: boolean; + hideBg?: boolean; } -const EFF_HEIGHT = 46; +const EFF_HEIGHT = 48; const EFF_WIDTH = 82; -const DESC_HEIGHT = 46; +const DESC_HEIGHT = 48; const BORDER = 8; const GLOBAL_SCALE = 6; @@ -38,6 +42,7 @@ export default class MoveInfoOverlay extends Phaser.GameObjects.Container implem private acc: Phaser.GameObjects.Text; private typ: Phaser.GameObjects.Sprite; private cat: Phaser.GameObjects.Sprite; + private descBg: Phaser.GameObjects.NineSlice; private options : MoveInfoOverlaySettings; @@ -52,12 +57,12 @@ export default class MoveInfoOverlay extends Phaser.GameObjects.Container implem // prepare the description box const width = (options?.width || MoveInfoOverlay.getWidth(scale, scene)) / scale; // divide by scale as we always want this to be half a window wide - const descBg = addWindow(scene, (options?.onSide && !options?.right ? EFF_WIDTH : 0), options?.top ? EFF_HEIGHT : 0, width - (options?.onSide ? EFF_WIDTH : 0), DESC_HEIGHT); - descBg.setOrigin(0, 0); - this.add(descBg); + this.descBg = addWindow(scene, (options?.onSide && !options?.right ? EFF_WIDTH : 0), options?.top ? EFF_HEIGHT : 0, width - (options?.onSide ? EFF_WIDTH : 0), DESC_HEIGHT); + this.descBg.setOrigin(0, 0); + this.add(this.descBg); // set up the description; wordWrap uses true pixels, unaffected by any scaling, while other values are affected - this.desc = addTextObject(scene, (options?.onSide && !options?.right ? EFF_WIDTH : 0) + BORDER, (options?.top ? EFF_HEIGHT : 0) + BORDER - 2, "", TextStyle.BATTLE_INFO, { wordWrap: { width: (width - (BORDER - 2) * 2 - (options?.onSide ? EFF_WIDTH : 0)) * GLOBAL_SCALE } }); + this.desc = addTextObject(scene, (options?.onSide && !options?.right ? EFF_WIDTH : 0) + BORDER, (options?.top ? EFF_HEIGHT : 0) + BORDER - 2, "", TextStyle.BATTLE_INFO, { wordWrap: { width: (width - (BORDER - 2) * 2 - (options?.onSide ? EFF_WIDTH : 0)) * GLOBAL_SCALE }}); this.desc.setLineSpacing(i18next.resolvedLanguage === "ja" ? 25 : 5); // limit the text rendering, required for scrolling later on @@ -125,6 +130,14 @@ export default class MoveInfoOverlay extends Phaser.GameObjects.Container implem this.acc.setOrigin(1, 0.5); this.val.add(this.acc); + if (options?.hideEffectBox) { + this.val.setVisible(false); + } + + if (options?.hideBg) { + this.descBg.setVisible(false); + } + // hide this component for now this.setVisible(false); } @@ -176,8 +189,19 @@ export default class MoveInfoOverlay extends Phaser.GameObjects.Container implem this.active = false; } - toggleInfo(force?: boolean): void { - this.setVisible(force ?? !this.visible); + toggleInfo(visible: boolean): void { + if (visible) { + this.setVisible(true); + } + this.scene.tweens.add({ + targets: this.desc, + duration: Utils.fixedInt(125), + ease: "Sine.easeInOut", + alpha: visible ? 1 : 0 + }); + if (!visible) { + this.setVisible(false); + } } isActive(): boolean { diff --git a/src/ui/mystery-encounter-ui-handler.ts b/src/ui/mystery-encounter-ui-handler.ts index 307bab0a3af..cdb1c9024c5 100644 --- a/src/ui/mystery-encounter-ui-handler.ts +++ b/src/ui/mystery-encounter-ui-handler.ts @@ -6,7 +6,7 @@ import { Button } from "#enums/buttons"; import { addWindow, WindowVariant } from "./ui-theme"; import { MysteryEncounterPhase } from "../phases/mystery-encounter-phases"; import { PartyUiMode } from "./party-ui-handler"; -import MysteryEncounterOption from "../data/mystery-encounters/mystery-encounter-option"; +import MysteryEncounterOption from "#app/data/mystery-encounters/mystery-encounter-option"; import * as Utils from "../utils"; import { isNullOrUndefined } from "../utils"; import { getPokeballAtlasKey } from "../data/pokeball"; @@ -42,7 +42,8 @@ export default class MysteryEncounterUiHandler extends UiHandler { private encounterOptions: MysteryEncounterOption[] = []; private optionsMeetsReqs: boolean[]; - protected viewPartyIndex: integer = 0; + protected viewPartyIndex: number = 0; + protected viewPartyXPosition: number = 0; protected blockInput: boolean = true; @@ -94,8 +95,8 @@ export default class MysteryEncounterUiHandler extends UiHandler { super.show(args); this.overrideSettings = args[0] as OptionSelectSettings ?? {}; - const showDescriptionContainer = isNullOrUndefined(this.overrideSettings?.hideDescription) ? true : !this.overrideSettings?.hideDescription; - const slideInDescription = isNullOrUndefined(this.overrideSettings?.slideInDescription) ? true : this.overrideSettings?.slideInDescription; + const showDescriptionContainer = isNullOrUndefined(this.overrideSettings?.hideDescription) ? true : !this.overrideSettings.hideDescription; + const slideInDescription = isNullOrUndefined(this.overrideSettings?.slideInDescription) ? true : this.overrideSettings.slideInDescription; const startingCursorIndex = this.overrideSettings?.startingCursorIndex ?? 0; this.cursorContainer.setVisible(true); @@ -158,16 +159,16 @@ export default class MysteryEncounterUiHandler extends UiHandler { } } else { switch (this.optionsContainer.getAll()?.length) { - default: - case 3: - success = this.handleTwoOptionMoveInput(button); - break; - case 4: - success = this.handleThreeOptionMoveInput(button); - break; - case 5: - success = this.handleFourOptionMoveInput(button); - break; + default: + case 3: + success = this.handleTwoOptionMoveInput(button); + break; + case 4: + success = this.handleThreeOptionMoveInput(button); + break; + case 5: + success = this.handleFourOptionMoveInput(button); + break; } this.displayOptionTooltip(); @@ -184,26 +185,26 @@ export default class MysteryEncounterUiHandler extends UiHandler { let success = false; const cursor = this.getCursor(); switch (button) { - case Button.UP: - if (cursor < this.viewPartyIndex) { - success = this.setCursor(this.viewPartyIndex); - } - break; - case Button.DOWN: - if (cursor === this.viewPartyIndex) { - success = this.setCursor(1); - } - break; - case Button.LEFT: - if (cursor > 0) { - success = this.setCursor(cursor - 1); - } - break; - case Button.RIGHT: - if (cursor < this.viewPartyIndex) { - success = this.setCursor(cursor + 1); - } - break; + case Button.UP: + if (cursor < this.viewPartyIndex) { + success = this.setCursor(this.viewPartyIndex); + } + break; + case Button.DOWN: + if (cursor === this.viewPartyIndex) { + success = this.setCursor(1); + } + break; + case Button.LEFT: + if (cursor > 0) { + success = this.setCursor(cursor - 1); + } + break; + case Button.RIGHT: + if (cursor < this.viewPartyIndex) { + success = this.setCursor(cursor + 1); + } + break; } return success; @@ -213,34 +214,34 @@ export default class MysteryEncounterUiHandler extends UiHandler { let success = false; const cursor = this.getCursor(); switch (button) { - case Button.UP: - if (cursor === 2) { - success = this.setCursor(cursor - 2); - } else { - success = this.setCursor(this.viewPartyIndex); - } - break; - case Button.DOWN: - if (cursor === this.viewPartyIndex) { - success = this.setCursor(1); - } else { - success = this.setCursor(2); - } - break; - case Button.LEFT: - if (cursor === this.viewPartyIndex) { - success = this.setCursor(1); - } else if (cursor === 1) { - success = this.setCursor(cursor - 1); - } - break; - case Button.RIGHT: - if (cursor === 1) { - success = this.setCursor(this.viewPartyIndex); - } else if (cursor < 1) { - success = this.setCursor(cursor + 1); - } - break; + case Button.UP: + if (cursor === 2) { + success = this.setCursor(cursor - 2); + } else { + success = this.setCursor(this.viewPartyIndex); + } + break; + case Button.DOWN: + if (cursor === this.viewPartyIndex) { + success = this.setCursor(1); + } else { + success = this.setCursor(2); + } + break; + case Button.LEFT: + if (cursor === this.viewPartyIndex) { + success = this.setCursor(1); + } else if (cursor === 1) { + success = this.setCursor(cursor - 1); + } + break; + case Button.RIGHT: + if (cursor === 1) { + success = this.setCursor(this.viewPartyIndex); + } else if (cursor < 1) { + success = this.setCursor(cursor + 1); + } + break; } return success; @@ -250,34 +251,34 @@ export default class MysteryEncounterUiHandler extends UiHandler { let success = false; const cursor = this.getCursor(); switch (button) { - case Button.UP: - if (cursor >= 2 && cursor !== this.viewPartyIndex) { - success = this.setCursor(cursor - 2); - } else { - success = this.setCursor(this.viewPartyIndex); - } - break; - case Button.DOWN: - if (cursor <= 1) { - success = this.setCursor(cursor + 2); - } else if (cursor === this.viewPartyIndex) { - success = this.setCursor(1); - } - break; - case Button.LEFT: - if (cursor === this.viewPartyIndex) { - success = this.setCursor(1); - } else if (cursor % 2 === 1) { - success = this.setCursor(cursor - 1); - } - break; - case Button.RIGHT: - if (cursor === 1) { - success = this.setCursor(this.viewPartyIndex); - } else if (cursor % 2 === 0 && cursor !== this.viewPartyIndex) { - success = this.setCursor(cursor + 1); - } - break; + case Button.UP: + if (cursor >= 2 && cursor !== this.viewPartyIndex) { + success = this.setCursor(cursor - 2); + } else { + success = this.setCursor(this.viewPartyIndex); + } + break; + case Button.DOWN: + if (cursor <= 1) { + success = this.setCursor(cursor + 2); + } else if (cursor === this.viewPartyIndex) { + success = this.setCursor(1); + } + break; + case Button.LEFT: + if (cursor === this.viewPartyIndex) { + success = this.setCursor(1); + } else if (cursor % 2 === 1) { + success = this.setCursor(cursor - 1); + } + break; + case Button.RIGHT: + if (cursor === 1) { + success = this.setCursor(this.viewPartyIndex); + } else if (cursor % 2 === 0 && cursor !== this.viewPartyIndex) { + success = this.setCursor(cursor + 1); + } + break; } return success; @@ -300,11 +301,11 @@ export default class MysteryEncounterUiHandler extends UiHandler { } } - override getCursor(): integer { + override getCursor(): number { return this.cursor ? this.cursor : 0; } - override setCursor(cursor: integer): boolean { + override setCursor(cursor: number): boolean { const prevCursor = this.getCursor(); const changed = prevCursor !== cursor; if (changed) { @@ -319,7 +320,7 @@ export default class MysteryEncounterUiHandler extends UiHandler { } if (cursor === this.viewPartyIndex) { - this.cursorObj.setPosition(246, -17); + this.cursorObj.setPosition(this.viewPartyXPosition, -17); } else if (this.optionsContainer.getAll()?.length === 3) { // 2 Options this.cursorObj.setPosition(-10.5 + (cursor % 2 === 1 ? 100 : 0), 15); } else if (this.optionsContainer.getAll()?.length === 4) { // 3 Options @@ -350,16 +351,16 @@ export default class MysteryEncounterUiHandler extends UiHandler { let optionText: BBCodeText; switch (this.encounterOptions.length) { - default: - case 2: - optionText = addBBCodeTextObject(this.scene, i % 2 === 0 ? 0 : 100, 8, "-", TextStyle.WINDOW, { fontSize: "80px", lineSpacing: -8 }); - break; - case 3: - optionText = addBBCodeTextObject(this.scene, i % 2 === 0 ? 0 : 100, i < 2 ? 0 : 16, "-", TextStyle.WINDOW, { fontSize: "80px", lineSpacing: -8 }); - break; - case 4: - optionText = addBBCodeTextObject(this.scene, i % 2 === 0 ? 0 : 100, i < 2 ? 0 : 16, "-", TextStyle.WINDOW, { fontSize: "80px", lineSpacing: -8 }); - break; + default: + case 2: + optionText = addBBCodeTextObject(this.scene, i % 2 === 0 ? 0 : 100, 8, "-", TextStyle.WINDOW, { fontSize: "80px", lineSpacing: -8 }); + break; + case 3: + optionText = addBBCodeTextObject(this.scene, i % 2 === 0 ? 0 : 100, i < 2 ? 0 : 16, "-", TextStyle.WINDOW, { fontSize: "80px", lineSpacing: -8 }); + break; + case 4: + optionText = addBBCodeTextObject(this.scene, i % 2 === 0 ? 0 : 100, i < 2 ? 0 : 16, "-", TextStyle.WINDOW, { fontSize: "80px", lineSpacing: -8 }); + break; } this.optionsMeetsReqs.push(option.meetsRequirements(this.scene)); @@ -368,9 +369,9 @@ export default class MysteryEncounterUiHandler extends UiHandler { let text: string | null; if (option.hasRequirements() && this.optionsMeetsReqs[i] && (option.optionMode === MysteryEncounterOptionMode.DEFAULT_OR_SPECIAL || option.optionMode === MysteryEncounterOptionMode.DISABLED_OR_SPECIAL)) { // Options with special requirements that are met are automatically colored green - text = getEncounterText(this.scene, label, TextStyle.SUMMARY_GREEN); + text = getEncounterText(this.scene, label, TextStyle.ME_OPTION_SPECIAL); } else { - text = getEncounterText(this.scene, label, optionDialogue.style ? optionDialogue.style : TextStyle.WINDOW); + text = getEncounterText(this.scene, label, optionDialogue.style ? optionDialogue.style : TextStyle.ME_OPTION_DEFAULT); } if (text) { @@ -419,8 +420,10 @@ export default class MysteryEncounterUiHandler extends UiHandler { } // View Party Button - const viewPartyText = addBBCodeTextObject(this.scene, 256, -24, getBBCodeFrag(i18next.t("mysteryEncounterMessages:view_party_button"), TextStyle.PARTY), TextStyle.PARTY); + const viewPartyText = addBBCodeTextObject(this.scene, (this.scene.game.canvas.width) / 6, -24, getBBCodeFrag(i18next.t("mysteryEncounterMessages:view_party_button"), TextStyle.PARTY), TextStyle.PARTY); this.optionsContainer.add(viewPartyText); + viewPartyText.x -= (viewPartyText.displayWidth + 16); + this.viewPartyXPosition = viewPartyText.x - 10; // Description Window const titleTextObject = addBBCodeTextObject(this.scene, 0, 0, titleText ?? "", TextStyle.TOOLTIP_TITLE, { wordWrap: { width: 750 }, align: "center", lineSpacing: -8 }); @@ -435,7 +438,7 @@ export default class MysteryEncounterUiHandler extends UiHandler { const ballType = getPokeballAtlasKey(index); this.rarityBall.setTexture("pb", ballType); - const descriptionTextObject = addBBCodeTextObject(this.scene, 6, 25, descriptionText ?? "", TextStyle.TOOLTIP_CONTENT, { wordWrap: { width: 830 } }); + const descriptionTextObject = addBBCodeTextObject(this.scene, 6, 25, descriptionText ?? "", TextStyle.TOOLTIP_CONTENT, { wordWrap: { width: 830 }}); // Sets up the mask that hides the description text to give an illusion of scrolling const descriptionTextMaskRect = this.scene.make.graphics({}); @@ -469,7 +472,7 @@ export default class MysteryEncounterUiHandler extends UiHandler { this.descriptionContainer.add(descriptionTextObject); - const queryTextObject = addBBCodeTextObject(this.scene, 0, 0, queryText ?? "", TextStyle.TOOLTIP_CONTENT, { wordWrap: { width: 830 } }); + const queryTextObject = addBBCodeTextObject(this.scene, 0, 0, queryText ?? "", TextStyle.TOOLTIP_CONTENT, { wordWrap: { width: 830 }}); this.descriptionContainer.add(queryTextObject); queryTextObject.setPosition(75 - queryTextObject.displayWidth / 2, 90); @@ -515,7 +518,7 @@ export default class MysteryEncounterUiHandler extends UiHandler { // Auto-color options green/blue for good/bad by looking for (+)/(-) if (text) { - const primaryStyleString = [...text.match(new RegExp(/\[color=[^\[]*\]\[shadow=[^\[]*\]/i))!][0]; + const primaryStyleString = [ ...text.match(new RegExp(/\[color=[^\[]*\]\[shadow=[^\[]*\]/i))! ][0]; text = text.replace(/(\(\+\)[^\(\[]*)/gi, substring => "[/color][/shadow]" + getBBCodeFrag(substring, TextStyle.SUMMARY_GREEN) + "[/color][/shadow]" + primaryStyleString); text = text.replace(/(\(\-\)[^\(\[]*)/gi, substring => "[/color][/shadow]" + getBBCodeFrag(substring, TextStyle.SUMMARY_BLUE) + "[/color][/shadow]" + primaryStyleString); } diff --git a/src/ui/outdated-modal-ui-handler.ts b/src/ui/outdated-modal-ui-handler.ts deleted file mode 100644 index fc4b93f9b8a..00000000000 --- a/src/ui/outdated-modal-ui-handler.ts +++ /dev/null @@ -1,47 +0,0 @@ -import BattleScene from "../battle-scene"; -import { ModalConfig, ModalUiHandler } from "./modal-ui-handler"; -import { addTextObject, TextStyle } from "./text"; -import { Mode } from "./ui"; - -export default class OutdatedModalUiHandler extends ModalUiHandler { - constructor(scene: BattleScene, mode: Mode | null = null) { - super(scene, mode); - } - - getModalTitle(): string { - return ""; - } - - getWidth(): number { - return 160; - } - - getHeight(): number { - return 64; - } - - getMargin(): [number, number, number, number] { - return [ 0, 0, 48, 0 ]; - } - - getButtonLabels(): string[] { - return [ ]; - } - - setup(): void { - super.setup(); - - const label = addTextObject(this.scene, this.getWidth() / 2, this.getHeight() / 2, "Your client is currently outdated.\nPlease reload to update the game.\n\nIf this error persists, please clear your browser cache.", TextStyle.WINDOW, { fontSize: "48px", align: "center" }); - label.setOrigin(0.5, 0.5); - - this.modalContainer.add(label); - } - - show(args: any[]): boolean { - const config: ModalConfig = { - buttonActions: [] - }; - - return super.show([ config ]); - } -} diff --git a/src/ui/party-ui-handler.ts b/src/ui/party-ui-handler.ts index 8c777350964..bd3561dd0b4 100644 --- a/src/ui/party-ui-handler.ts +++ b/src/ui/party-ui-handler.ts @@ -1,22 +1,22 @@ -import BattleScene from "../battle-scene"; -import Pokemon, { MoveResult, PlayerPokemon, PokemonMove } from "../field/pokemon"; -import { addBBCodeTextObject, addTextObject, getTextColor, TextStyle } from "./text"; -import { Command } from "./command-ui-handler"; -import MessageUiHandler from "./message-ui-handler"; -import { Mode } from "./ui"; -import * as Utils from "../utils"; -import { PokemonFormChangeItemModifier, PokemonHeldItemModifier, SwitchEffectTransferModifier } from "../modifier/modifier"; -import { allMoves, ForceSwitchOutAttr } from "../data/move"; -import { getGenderColor, getGenderSymbol } from "../data/gender"; -import { StatusEffect } from "../data/status-effect"; -import PokemonIconAnimHandler, { PokemonIconAnimMode } from "./pokemon-icon-anim-handler"; -import { pokemonEvolutions } from "../data/pokemon-evolutions"; -import { addWindow } from "./ui-theme"; -import { SpeciesFormChangeItemTrigger, FormChangeItem } from "../data/pokemon-forms"; +import BattleScene from "#app/battle-scene"; +import Pokemon, { MoveResult, PlayerPokemon, PokemonMove } from "#app/field/pokemon"; +import { addBBCodeTextObject, addTextObject, getTextColor, TextStyle } from "#app/ui/text"; +import { Command } from "#app/ui/command-ui-handler"; +import MessageUiHandler from "#app/ui/message-ui-handler"; +import { Mode } from "#app/ui/ui"; +import * as Utils from "#app/utils"; +import { PokemonFormChangeItemModifier, PokemonHeldItemModifier, SwitchEffectTransferModifier } from "#app/modifier/modifier"; +import { allMoves, ForceSwitchOutAttr } from "#app/data/move"; +import { getGenderColor, getGenderSymbol } from "#app/data/gender"; +import { StatusEffect } from "#enums/status-effect"; +import PokemonIconAnimHandler, { PokemonIconAnimMode } from "#app/ui/pokemon-icon-anim-handler"; +import { pokemonEvolutions } from "#app/data/balance/pokemon-evolutions"; +import { addWindow } from "#app/ui/ui-theme"; +import { SpeciesFormChangeItemTrigger, FormChangeItem } from "#app/data/pokemon-forms"; import { getVariantTint } from "#app/data/variant"; -import {Button} from "#enums/buttons"; +import { Button } from "#enums/buttons"; import { applyChallenges, ChallengeType } from "#app/data/challenge"; -import MoveInfoOverlay from "./move-info-overlay"; +import MoveInfoOverlay from "#app/ui/move-info-overlay"; import i18next from "i18next"; import BBCodeText from "phaser3-rex-plugins/plugins/bbcodetext"; import { Moves } from "#enums/moves"; @@ -216,7 +216,7 @@ export default class PartyUiHandler extends MessageUiHandler { public static NoEffectMessage = i18next.t("partyUiHandler:anyEffect"); - private localizedOptions = [PartyOption.SEND_OUT, PartyOption.SUMMARY, PartyOption.CANCEL, PartyOption.APPLY, PartyOption.RELEASE, PartyOption.TEACH, PartyOption.SPLICE, PartyOption.UNSPLICE, PartyOption.REVIVE, PartyOption.TRANSFER, PartyOption.UNPAUSE_EVOLUTION, PartyOption.PASS_BATON, PartyOption.RENAME, PartyOption.SELECT]; + private localizedOptions = [ PartyOption.SEND_OUT, PartyOption.SUMMARY, PartyOption.CANCEL, PartyOption.APPLY, PartyOption.RELEASE, PartyOption.TEACH, PartyOption.SPLICE, PartyOption.UNSPLICE, PartyOption.REVIVE, PartyOption.TRANSFER, PartyOption.UNPAUSE_EVOLUTION, PartyOption.PASS_BATON, PartyOption.RENAME, PartyOption.SELECT ]; constructor(scene: BattleScene) { super(scene, Mode.PARTY); @@ -346,16 +346,16 @@ export default class PartyUiHandler extends MessageUiHandler { if (this.optionsMode) { const option = this.options[this.optionsCursor]; if (button === Button.ACTION) { - const pokemon = this.scene.getParty()[this.cursor]; + const pokemon = this.scene.getPlayerParty()[this.cursor]; if (this.partyUiMode === PartyUiMode.MODIFIER_TRANSFER && !this.transferMode && option !== PartyOption.CANCEL) { this.startTransfer(); let ableToTransfer: string; - for (let p = 0; p < this.scene.getParty().length; p++) { // this fore look goes through each of the party pokemon - const newPokemon = this.scene.getParty()[p]; + for (let p = 0; p < this.scene.getPlayerParty().length; p++) { // this fore look goes through each of the party pokemon + const newPokemon = this.scene.getPlayerParty()[p]; // this next line gets all of the transferable items from pokemon [p]; it does this by getting all the held modifiers that are transferable and checking to see if they belong to pokemon [p] const getTransferrableItemsFromPokemon = (newPokemon: PlayerPokemon) => - this.scene.findModifiers(m => m instanceof PokemonHeldItemModifier && (m as PokemonHeldItemModifier).isTransferrable && (m as PokemonHeldItemModifier).pokemonId === newPokemon.id) as PokemonHeldItemModifier[]; + this.scene.findModifiers(m => m instanceof PokemonHeldItemModifier && (m as PokemonHeldItemModifier).isTransferable && (m as PokemonHeldItemModifier).pokemonId === newPokemon.id) as PokemonHeldItemModifier[]; // this next bit checks to see if the the selected item from the original transfer pokemon exists on the new pokemon [p]; this returns undefined if the new pokemon doesn't have the item at all, otherwise it returns the pokemonHeldItemModifier for that item const matchingModifier = newPokemon.scene.findModifier(m => m instanceof PokemonHeldItemModifier && m.pokemonId === newPokemon.id && m.matchType(getTransferrableItemsFromPokemon(pokemon)[this.transferOptionCursor])) as PokemonHeldItemModifier; const partySlot = this.partySlots.filter(m => m.getPokemon() === newPokemon)[0]; // this gets pokemon [p] for us @@ -399,7 +399,7 @@ export default class PartyUiHandler extends MessageUiHandler { || (option === PartyOption.RELEASE && this.partyUiMode === PartyUiMode.RELEASE)) { let filterResult: string | null; const getTransferrableItemsFromPokemon = (pokemon: PlayerPokemon) => - this.scene.findModifiers(m => m instanceof PokemonHeldItemModifier && m.isTransferrable && m.pokemonId === pokemon.id) as PokemonHeldItemModifier[]; + this.scene.findModifiers(m => m instanceof PokemonHeldItemModifier && m.isTransferable && m.pokemonId === pokemon.id) as PokemonHeldItemModifier[]; if (option !== PartyOption.TRANSFER && option !== PartyOption.SPLICE) { filterResult = (this.selectFilter as PokemonSelectFilter)(pokemon); if (filterResult === null && (option === PartyOption.SEND_OUT || option === PartyOption.PASS_BATON)) { @@ -409,7 +409,7 @@ export default class PartyUiHandler extends MessageUiHandler { filterResult = this.moveSelectFilter(pokemon.moveset[this.optionsCursor]!); // TODO: is this bang correct? } } else { - filterResult = (this.selectFilter as PokemonModifierTransferSelectFilter)(pokemon, getTransferrableItemsFromPokemon(this.scene.getParty()[this.transferCursor])[this.transferOptionCursor]); + filterResult = (this.selectFilter as PokemonModifierTransferSelectFilter)(pokemon, getTransferrableItemsFromPokemon(this.scene.getPlayerParty()[this.transferCursor])[this.transferOptionCursor]); } if (filterResult === null) { if (this.partyUiMode !== PartyUiMode.SPLICE) { @@ -419,7 +419,7 @@ export default class PartyUiHandler extends MessageUiHandler { if (option === PartyOption.TRANSFER) { if (this.transferCursor !== this.cursor) { if (this.transferAll) { - getTransferrableItemsFromPokemon(this.scene.getParty()[this.transferCursor]).forEach((_, i) => (this.selectCallback as PartyModifierTransferSelectCallback)(this.transferCursor, i, this.transferQuantitiesMax[i], this.cursor)); + getTransferrableItemsFromPokemon(this.scene.getPlayerParty()[this.transferCursor]).forEach((_, i) => (this.selectCallback as PartyModifierTransferSelectCallback)(this.transferCursor, i, this.transferQuantitiesMax[i], this.cursor)); } else { (this.selectCallback as PartyModifierTransferSelectCallback)(this.transferCursor, this.transferOptionCursor, this.transferQuantities[this.transferOptionCursor], this.cursor); } @@ -468,7 +468,7 @@ export default class PartyUiHandler extends MessageUiHandler { this.clearOptions(); ui.playSelect(); pokemon.pauseEvolutions = !pokemon.pauseEvolutions; - this.showText(i18next.t(pokemon.pauseEvolutions? "partyUiHandler:pausedEvolutions" : "partyUiHandler:unpausedEvolutions", { pokemonName: getPokemonNameWithAffix(pokemon) }), undefined, () => this.showText("", 0), null, true); + this.showText(i18next.t(pokemon.pauseEvolutions ? "partyUiHandler:pausedEvolutions" : "partyUiHandler:unpausedEvolutions", { pokemonName: getPokemonNameWithAffix(pokemon) }), undefined, () => this.showText("", 0), null, true); } else if (option === PartyOption.UNSPLICE) { this.clearOptions(); ui.playSelect(); @@ -539,48 +539,48 @@ export default class PartyUiHandler extends MessageUiHandler { return true; } else { switch (button) { - case Button.LEFT: + case Button.LEFT: /** Decrease quantity for the current item and update UI */ - if (this.partyUiMode === PartyUiMode.MODIFIER_TRANSFER) { - this.transferQuantities[option] = this.transferQuantities[option] === 1 ? this.transferQuantitiesMax[option] : this.transferQuantities[option] - 1; - this.updateOptions(); - success = this.setCursor(this.optionsCursor); /** Place again the cursor at the same position. Necessary, otherwise the cursor disappears */ - } - break; - case Button.RIGHT: + if (this.partyUiMode === PartyUiMode.MODIFIER_TRANSFER) { + this.transferQuantities[option] = this.transferQuantities[option] === 1 ? this.transferQuantitiesMax[option] : this.transferQuantities[option] - 1; + this.updateOptions(); + success = this.setCursor(this.optionsCursor); /** Place again the cursor at the same position. Necessary, otherwise the cursor disappears */ + } + break; + case Button.RIGHT: /** Increase quantity for the current item and update UI */ - if (this.partyUiMode === PartyUiMode.MODIFIER_TRANSFER) { - this.transferQuantities[option] = this.transferQuantities[option] === this.transferQuantitiesMax[option] ? 1 : this.transferQuantities[option] + 1; - this.updateOptions(); - success = this.setCursor(this.optionsCursor); /** Place again the cursor at the same position. Necessary, otherwise the cursor disappears */ - } - break; - case Button.UP: - /** If currently selecting items to transfer, reset quantity selection */ - if (this.partyUiMode === PartyUiMode.MODIFIER_TRANSFER) { - if (option !== PartyOption.ALL) { - this.transferQuantities[option] = this.transferQuantitiesMax[option]; + if (this.partyUiMode === PartyUiMode.MODIFIER_TRANSFER) { + this.transferQuantities[option] = this.transferQuantities[option] === this.transferQuantitiesMax[option] ? 1 : this.transferQuantities[option] + 1; + this.updateOptions(); + success = this.setCursor(this.optionsCursor); /** Place again the cursor at the same position. Necessary, otherwise the cursor disappears */ } - this.updateOptions(); - } - success = this.setCursor(this.optionsCursor ? this.optionsCursor - 1 : this.options.length - 1); /** Move cursor */ - break; - case Button.DOWN: + break; + case Button.UP: /** If currently selecting items to transfer, reset quantity selection */ - if (this.partyUiMode === PartyUiMode.MODIFIER_TRANSFER) { - if (option !== PartyOption.ALL) { - this.transferQuantities[option] = this.transferQuantitiesMax[option]; + if (this.partyUiMode === PartyUiMode.MODIFIER_TRANSFER) { + if (option !== PartyOption.ALL) { + this.transferQuantities[option] = this.transferQuantitiesMax[option]; + } + this.updateOptions(); } - this.updateOptions(); - } - success = this.setCursor(this.optionsCursor < this.options.length - 1 ? this.optionsCursor + 1 : 0); /** Move cursor */ - break; + success = this.setCursor(this.optionsCursor ? this.optionsCursor - 1 : this.options.length - 1); /** Move cursor */ + break; + case Button.DOWN: + /** If currently selecting items to transfer, reset quantity selection */ + if (this.partyUiMode === PartyUiMode.MODIFIER_TRANSFER) { + if (option !== PartyOption.ALL) { + this.transferQuantities[option] = this.transferQuantitiesMax[option]; + } + this.updateOptions(); + } + success = this.setCursor(this.optionsCursor < this.options.length - 1 ? this.optionsCursor + 1 : 0); /** Move cursor */ + break; } // show move description if (this.partyUiMode === PartyUiMode.REMEMBER_MOVE_MODIFIER) { const option = this.options[this.optionsCursor]; - const pokemon = this.scene.getParty()[this.cursor]; + const pokemon = this.scene.getPlayerParty()[this.cursor]; const move = allMoves[pokemon.getLearnableLevelMoves()[option]]; if (move) { this.moveInfoOverlay.show(move); @@ -596,7 +596,7 @@ export default class PartyUiHandler extends MessageUiHandler { if (this.partyUiMode === PartyUiMode.MODIFIER_TRANSFER && !this.transferMode) { /** Initialize item quantities for the selected Pokemon */ const itemModifiers = this.scene.findModifiers(m => m instanceof PokemonHeldItemModifier - && m.isTransferrable && m.pokemonId === this.scene.getParty()[this.cursor].id) as PokemonHeldItemModifier[]; + && m.isTransferable && m.pokemonId === this.scene.getPlayerParty()[this.cursor].id) as PokemonHeldItemModifier[]; this.transferQuantities = itemModifiers.map(item => item.getStackCount()); this.transferQuantitiesMax = itemModifiers.map(item => item.getStackCount()); } @@ -631,28 +631,28 @@ export default class PartyUiHandler extends MessageUiHandler { const battlerCount = this.scene.currentBattle.getBattlerCount(); switch (button) { - case Button.UP: - success = this.setCursor(this.cursor ? this.cursor < 6 ? this.cursor - 1 : slotCount - 1 : 6); - break; - case Button.DOWN: - success = this.setCursor(this.cursor < 6 ? this.cursor < slotCount - 1 ? this.cursor + 1 : 6 : 0); - break; - case Button.LEFT: - if (this.cursor >= battlerCount && this.cursor <= 6) { - success = this.setCursor(0); - } - break; - case Button.RIGHT: - if (slotCount === battlerCount) { - success = this.setCursor(6); + case Button.UP: + success = this.setCursor(this.cursor ? this.cursor < 6 ? this.cursor - 1 : slotCount - 1 : 6); break; - } else if (battlerCount >= 2 && slotCount > battlerCount && this.getCursor() === 0 && this.lastCursor === 1) { - success = this.setCursor(2); + case Button.DOWN: + success = this.setCursor(this.cursor < 6 ? this.cursor < slotCount - 1 ? this.cursor + 1 : 6 : 0); break; - } else if (slotCount > battlerCount && this.cursor < battlerCount) { - success = this.setCursor(this.lastCursor < 6 ? this.lastCursor || battlerCount : battlerCount); + case Button.LEFT: + if (this.cursor >= battlerCount && this.cursor <= 6) { + success = this.setCursor(0); + } break; - } + case Button.RIGHT: + if (slotCount === battlerCount) { + success = this.setCursor(6); + break; + } else if (battlerCount >= 2 && slotCount > battlerCount && this.getCursor() === 0 && this.lastCursor === 1) { + success = this.setCursor(2); + break; + } else if (slotCount > battlerCount && this.cursor < battlerCount) { + success = this.setCursor(this.lastCursor < 6 ? this.lastCursor || battlerCount : battlerCount); + break; + } } } @@ -664,13 +664,16 @@ export default class PartyUiHandler extends MessageUiHandler { } populatePartySlots() { - const party = this.scene.getParty(); + const party = this.scene.getPlayerParty(); if (this.cursor < 6 && this.cursor >= party.length) { this.cursor = party.length - 1; } else if (this.cursor === 6) { this.partyCancelButton.select(); } + if (this.lastCursor < 6 && this.lastCursor >= party.length) { + this.lastCursor = party.length - 1; + } for (const p in party) { const slotIndex = parseInt(p); @@ -770,19 +773,19 @@ export default class PartyUiHandler extends MessageUiHandler { let optionsMessage = i18next.t("partyUiHandler:doWhatWithThisPokemon"); switch (this.partyUiMode) { - case PartyUiMode.MOVE_MODIFIER: - optionsMessage = i18next.t("partyUiHandler:selectAMove"); - break; - case PartyUiMode.MODIFIER_TRANSFER: - if (!this.transferMode) { - optionsMessage = i18next.t("partyUiHandler:changeQuantity"); - } - break; - case PartyUiMode.SPLICE: - if (!this.transferMode) { - optionsMessage = i18next.t("partyUiHandler:selectAnotherPokemonToSplice"); - } - break; + case PartyUiMode.MOVE_MODIFIER: + optionsMessage = i18next.t("partyUiHandler:selectAMove"); + break; + case PartyUiMode.MODIFIER_TRANSFER: + if (!this.transferMode) { + optionsMessage = i18next.t("partyUiHandler:changeQuantity"); + } + break; + case PartyUiMode.SPLICE: + if (!this.transferMode) { + optionsMessage = i18next.t("partyUiHandler:selectAnotherPokemonToSplice"); + } + break; } this.showText(optionsMessage, 0); @@ -800,7 +803,7 @@ export default class PartyUiHandler extends MessageUiHandler { } updateOptions(): void { - const pokemon = this.scene.getParty()[this.cursor]; + const pokemon = this.scene.getPlayerParty()[this.cursor]; const learnableLevelMoves = this.partyUiMode === PartyUiMode.REMEMBER_MOVE_MODIFIER ? pokemon.getLearnableLevelMoves() @@ -813,7 +816,7 @@ export default class PartyUiHandler extends MessageUiHandler { const itemModifiers = this.partyUiMode === PartyUiMode.MODIFIER_TRANSFER ? this.scene.findModifiers(m => m instanceof PokemonHeldItemModifier - && m.isTransferrable && m.pokemonId === pokemon.id) as PokemonHeldItemModifier[] + && m.isTransferable && m.pokemonId === pokemon.id) as PokemonHeldItemModifier[] : []; if (this.options.length) { @@ -826,64 +829,64 @@ export default class PartyUiHandler extends MessageUiHandler { if (this.partyUiMode !== PartyUiMode.MOVE_MODIFIER && this.partyUiMode !== PartyUiMode.REMEMBER_MOVE_MODIFIER && (this.transferMode || this.partyUiMode !== PartyUiMode.MODIFIER_TRANSFER)) { switch (this.partyUiMode) { - case PartyUiMode.SWITCH: - case PartyUiMode.FAINT_SWITCH: - case PartyUiMode.POST_BATTLE_SWITCH: - if (this.cursor >= this.scene.currentBattle.getBattlerCount()) { - const allowBatonModifierSwitch = + case PartyUiMode.SWITCH: + case PartyUiMode.FAINT_SWITCH: + case PartyUiMode.POST_BATTLE_SWITCH: + if (this.cursor >= this.scene.currentBattle.getBattlerCount()) { + const allowBatonModifierSwitch = this.partyUiMode !== PartyUiMode.FAINT_SWITCH && this.scene.findModifier(m => m instanceof SwitchEffectTransferModifier && (m as SwitchEffectTransferModifier).pokemonId === this.scene.getPlayerField()[this.fieldIndex].id); - const moveHistory = this.scene.getPlayerField()[this.fieldIndex].getMoveHistory(); - const isBatonPassMove = this.partyUiMode === PartyUiMode.FAINT_SWITCH && moveHistory.length && allMoves[moveHistory[moveHistory.length - 1].move].getAttrs(ForceSwitchOutAttr)[0]?.isBatonPass() && moveHistory[moveHistory.length - 1].result === MoveResult.SUCCESS; + const moveHistory = this.scene.getPlayerField()[this.fieldIndex].getMoveHistory(); + const isBatonPassMove = this.partyUiMode === PartyUiMode.FAINT_SWITCH && moveHistory.length && allMoves[moveHistory[moveHistory.length - 1].move].getAttrs(ForceSwitchOutAttr)[0]?.isBatonPass() && moveHistory[moveHistory.length - 1].result === MoveResult.SUCCESS; - // isBatonPassMove and allowBatonModifierSwitch shouldn't ever be true - // at the same time, because they both explicitly check for a mutually - // exclusive partyUiMode. But better safe than sorry. - this.options.push(isBatonPassMove && !allowBatonModifierSwitch ? PartyOption.PASS_BATON : PartyOption.SEND_OUT); - if (allowBatonModifierSwitch && !isBatonPassMove) { + // isBatonPassMove and allowBatonModifierSwitch shouldn't ever be true + // at the same time, because they both explicitly check for a mutually + // exclusive partyUiMode. But better safe than sorry. + this.options.push(isBatonPassMove && !allowBatonModifierSwitch ? PartyOption.PASS_BATON : PartyOption.SEND_OUT); + if (allowBatonModifierSwitch && !isBatonPassMove) { // the BATON modifier gives an extra switch option for // pokemon-command switches, allowing buffs to be optionally passed - this.options.push(PartyOption.PASS_BATON); + this.options.push(PartyOption.PASS_BATON); + } } - } - break; - case PartyUiMode.REVIVAL_BLESSING: - this.options.push(PartyOption.REVIVE); - break; - case PartyUiMode.MODIFIER: - this.options.push(PartyOption.APPLY); - break; - case PartyUiMode.TM_MODIFIER: - this.options.push(PartyOption.TEACH); - break; - case PartyUiMode.MODIFIER_TRANSFER: - this.options.push(PartyOption.TRANSFER); - break; - case PartyUiMode.SPLICE: - if (this.transferMode) { - if (this.cursor !== this.transferCursor) { - this.options.push(PartyOption.SPLICE); - } - } else { + break; + case PartyUiMode.REVIVAL_BLESSING: + this.options.push(PartyOption.REVIVE); + break; + case PartyUiMode.MODIFIER: this.options.push(PartyOption.APPLY); - } - break; - case PartyUiMode.RELEASE: - this.options.push(PartyOption.RELEASE); - break; - case PartyUiMode.CHECK: - if (this.scene.getCurrentPhase() instanceof SelectModifierPhase) { - formChangeItemModifiers = this.getFormChangeItemsModifiers(pokemon); - for (let i = 0; i < formChangeItemModifiers.length; i++) { - this.options.push(PartyOption.FORM_CHANGE_ITEM + i); + break; + case PartyUiMode.TM_MODIFIER: + this.options.push(PartyOption.TEACH); + break; + case PartyUiMode.MODIFIER_TRANSFER: + this.options.push(PartyOption.TRANSFER); + break; + case PartyUiMode.SPLICE: + if (this.transferMode) { + if (this.cursor !== this.transferCursor) { + this.options.push(PartyOption.SPLICE); + } + } else { + this.options.push(PartyOption.APPLY); } - } - break; - case PartyUiMode.SELECT: - this.options.push(PartyOption.SELECT); - break; + break; + case PartyUiMode.RELEASE: + this.options.push(PartyOption.RELEASE); + break; + case PartyUiMode.CHECK: + if (this.scene.getCurrentPhase() instanceof SelectModifierPhase) { + formChangeItemModifiers = this.getFormChangeItemsModifiers(pokemon); + for (let i = 0; i < formChangeItemModifiers.length; i++) { + this.options.push(PartyOption.FORM_CHANGE_ITEM + i); + } + } + break; + case PartyUiMode.SELECT: + this.options.push(PartyOption.SELECT); + break; } this.options.push(PartyOption.SUMMARY); @@ -959,33 +962,33 @@ export default class PartyUiHandler extends MessageUiHandler { optionName = "↓"; } else if ((this.partyUiMode !== PartyUiMode.REMEMBER_MOVE_MODIFIER && (this.partyUiMode !== PartyUiMode.MODIFIER_TRANSFER || this.transferMode)) || option === PartyOption.CANCEL) { switch (option) { - case PartyOption.MOVE_1: - case PartyOption.MOVE_2: - case PartyOption.MOVE_3: - case PartyOption.MOVE_4: - const move = pokemon.moveset[option - PartyOption.MOVE_1]!; // TODO: is the bang correct? - if (this.showMovePp) { - const maxPP = move.getMovePp(); - const currPP = maxPP - move.ppUsed; - optionName = `${move.getName()} ${currPP}/${maxPP}`; - } else { - optionName = move.getName(); - } - break; - default: - if (formChangeItemModifiers && option >= PartyOption.FORM_CHANGE_ITEM) { - const modifier = formChangeItemModifiers[option - PartyOption.FORM_CHANGE_ITEM]; - optionName = `${modifier.active ? i18next.t("partyUiHandler:DEACTIVATE") : i18next.t("partyUiHandler:ACTIVATE")} ${modifier.type.name}`; - } else if (option === PartyOption.UNPAUSE_EVOLUTION) { - optionName = `${pokemon.pauseEvolutions ? i18next.t("partyUiHandler:UNPAUSE_EVOLUTION") : i18next.t("partyUiHandler:PAUSE_EVOLUTION")}`; - } else { - if (this.localizedOptions.includes(option)) { - optionName = i18next.t(`partyUiHandler:${PartyOption[option]}`); + case PartyOption.MOVE_1: + case PartyOption.MOVE_2: + case PartyOption.MOVE_3: + case PartyOption.MOVE_4: + const move = pokemon.moveset[option - PartyOption.MOVE_1]!; // TODO: is the bang correct? + if (this.showMovePp) { + const maxPP = move.getMovePp(); + const currPP = maxPP - move.ppUsed; + optionName = `${move.getName()} ${currPP}/${maxPP}`; } else { - optionName = Utils.toReadableString(PartyOption[option]); + optionName = move.getName(); } - } - break; + break; + default: + if (formChangeItemModifiers && option >= PartyOption.FORM_CHANGE_ITEM) { + const modifier = formChangeItemModifiers[option - PartyOption.FORM_CHANGE_ITEM]; + optionName = `${modifier.active ? i18next.t("partyUiHandler:DEACTIVATE") : i18next.t("partyUiHandler:ACTIVATE")} ${modifier.type.name}`; + } else if (option === PartyOption.UNPAUSE_EVOLUTION) { + optionName = `${pokemon.pauseEvolutions ? i18next.t("partyUiHandler:UNPAUSE_EVOLUTION") : i18next.t("partyUiHandler:PAUSE_EVOLUTION")}`; + } else { + if (this.localizedOptions.includes(option)) { + optionName = i18next.t(`partyUiHandler:${PartyOption[option]}`); + } else { + optionName = Utils.toReadableString(PartyOption[option]); + } + } + break; } } else if (this.partyUiMode === PartyUiMode.REMEMBER_MOVE_MODIFIER) { const move = learnableLevelMoves[option]; @@ -1056,13 +1059,13 @@ export default class PartyUiHandler extends MessageUiHandler { } doRelease(slotIndex: integer): void { - this.showText(this.getReleaseMessage(getPokemonNameWithAffix(this.scene.getParty()[slotIndex])), null, () => { + this.showText(this.getReleaseMessage(getPokemonNameWithAffix(this.scene.getPlayerParty()[slotIndex])), null, () => { this.clearPartySlots(); this.scene.removePartyMemberModifiers(slotIndex); - const releasedPokemon = this.scene.getParty().splice(slotIndex, 1)[0]; + const releasedPokemon = this.scene.getPlayerParty().splice(slotIndex, 1)[0]; releasedPokemon.destroy(); this.populatePartySlots(); - if (this.cursor >= this.scene.getParty().length) { + if (this.cursor >= this.scene.getPlayerParty().length) { this.setCursor(this.cursor - 1); } if (this.partyUiMode === PartyUiMode.RELEASE) { @@ -1240,7 +1243,7 @@ class PartySlot extends Phaser.GameObjects.Container { slotLevelText.setPositionRelative(slotLevelLabel, 9, 0); slotLevelText.setOrigin(0, 0.25); - slotInfoContainer.add([this.slotName, slotLevelLabel, slotLevelText ]); + slotInfoContainer.add([ this.slotName, slotLevelLabel, slotLevelText ]); const genderSymbol = getGenderSymbol(this.pokemon.getGender(true)); @@ -1323,7 +1326,7 @@ class PartySlot extends Phaser.GameObjects.Container { this.slotDescriptionLabel.setOrigin(0, 1); this.slotDescriptionLabel.setVisible(false); - slotInfoContainer.add([this.slotHpBar, this.slotHpOverlay, this.slotHpText, this.slotDescriptionLabel]); + slotInfoContainer.add([ this.slotHpBar, this.slotHpOverlay, this.slotHpText, this.slotDescriptionLabel ]); if (partyUiMode !== PartyUiMode.TM_MODIFIER) { this.slotDescriptionLabel.setVisible(false); diff --git a/src/ui/pokemon-hatch-info-container.ts b/src/ui/pokemon-hatch-info-container.ts index f8a9adced36..494855d20fa 100644 --- a/src/ui/pokemon-hatch-info-container.ts +++ b/src/ui/pokemon-hatch-info-container.ts @@ -1,14 +1,14 @@ -import PokemonInfoContainer from "./pokemon-info-container"; -import BattleScene from "../battle-scene"; -import { Gender } from "../data/gender"; -import { Type } from "../data/type"; -import * as Utils from "../utils"; -import { TextStyle, addTextObject } from "./text"; -import { speciesEggMoves } from "#app/data/egg-moves"; +import PokemonInfoContainer from "#app/ui/pokemon-info-container"; +import BattleScene from "#app/battle-scene"; +import { Gender } from "#app/data/gender"; +import { Type } from "#enums/type"; +import * as Utils from "#app/utils"; +import { TextStyle, addTextObject } from "#app/ui/text"; +import { speciesEggMoves } from "#app/data/balance/egg-moves"; import { allMoves } from "#app/data/move"; -import { Species } from "#app/enums/species"; +import { Species } from "#enums/species"; import { getEggTierForSpecies } from "#app/data/egg"; -import { starterColors } from "../battle-scene"; +import { starterColors } from "#app/battle-scene"; import { argbFromRgba } from "@material/material-color-utilities"; import { EggHatchData } from "#app/data/egg-hatch-data"; import { PlayerPokemon } from "#app/field/pokemon"; @@ -47,11 +47,11 @@ export default class PokemonHatchInfoContainer extends PokemonInfoContainer { this.pokemonListContainer.add(this.currentPokemonSprite); // setup name and number - this.pokemonNumberText = addTextObject(this.scene, 80, 107.5, "0000", TextStyle.SUMMARY, {fontSize: 74}); + this.pokemonNumberText = addTextObject(this.scene, 80, 107.5, "0000", TextStyle.SUMMARY, { fontSize: 74 }); this.pokemonNumberText.setOrigin(0, 0); this.pokemonListContainer.add(this.pokemonNumberText); - this.pokemonNameText = addTextObject(this.scene, 7, 107.5, "", TextStyle.SUMMARY, {fontSize: 74}); + this.pokemonNameText = addTextObject(this.scene, 7, 107.5, "", TextStyle.SUMMARY, { fontSize: 74 }); this.pokemonNameText.setOrigin(0, 0); this.pokemonListContainer.add(this.pokemonNameText); @@ -89,7 +89,7 @@ export default class PokemonHatchInfoContainer extends PokemonInfoContainer { const eggMoveBg = this.scene.add.nineslice(70, 0, "type_bgs", "unknown", 92, 14, 2, 2, 2, 2); eggMoveBg.setOrigin(1, 0); - const eggMoveLabel = addTextObject(this.scene, 70 -eggMoveBg.width / 2, 0, "???", TextStyle.PARTY); + const eggMoveLabel = addTextObject(this.scene, 70 - eggMoveBg.width / 2, 0, "???", TextStyle.PARTY); eggMoveLabel.setOrigin(0.5, 0); this.pokemonEggMoveBgs.push(eggMoveBg); diff --git a/src/ui/pokemon-icon-anim-handler.ts b/src/ui/pokemon-icon-anim-handler.ts index d6796d5cb5d..c7a24f69200 100644 --- a/src/ui/pokemon-icon-anim-handler.ts +++ b/src/ui/pokemon-icon-anim-handler.ts @@ -39,12 +39,12 @@ export default class PokemonIconAnimHandler { getModeYDelta(mode: PokemonIconAnimMode): number { switch (mode) { - case PokemonIconAnimMode.NONE: - return 0; - case PokemonIconAnimMode.PASSIVE: - return -1; - case PokemonIconAnimMode.ACTIVE: - return -2; + case PokemonIconAnimMode.NONE: + return 0; + case PokemonIconAnimMode.PASSIVE: + return -1; + case PokemonIconAnimMode.ACTIVE: + return -2; } } diff --git a/src/ui/pokemon-info-container.ts b/src/ui/pokemon-info-container.ts index 3c54e529d43..ead24e6d92f 100644 --- a/src/ui/pokemon-info-container.ts +++ b/src/ui/pokemon-info-container.ts @@ -3,7 +3,7 @@ import BBCodeText from "phaser3-rex-plugins/plugins/bbcodetext"; import BattleScene from "../battle-scene"; import { Gender, getGenderColor, getGenderSymbol } from "../data/gender"; import { getNatureName } from "../data/nature"; -import { Type } from "../data/type"; +import { Type } from "#enums/type"; import Pokemon from "../field/pokemon"; import i18next from "i18next"; import { DexAttr, DexEntry, StarterDataEntry } from "../system/game-data"; @@ -12,6 +12,7 @@ import ConfirmUiHandler from "./confirm-ui-handler"; import { StatsContainer } from "./stats-container"; import { TextStyle, addBBCodeTextObject, addTextObject, getTextColor } from "./text"; import { addWindow } from "./ui-theme"; +import { Species } from "#enums/species"; interface LanguageSetting { infoContainerTextSize: string; @@ -20,24 +21,6 @@ interface LanguageSetting { } const languageSettings: { [key: string]: LanguageSetting } = { - "en": { - infoContainerTextSize: "64px" - }, - "de": { - infoContainerTextSize: "64px", - }, - "es": { - infoContainerTextSize: "64px" - }, - "fr": { - infoContainerTextSize: "64px" - }, - "it": { - infoContainerTextSize: "64px" - }, - "zh": { - infoContainerTextSize: "64px" - }, "pt": { infoContainerTextSize: "60px", infoContainerLabelXPos: -15, @@ -234,7 +217,25 @@ export default class PokemonInfoContainer extends Phaser.GameObjects.Container { this.pokemonGenderText.setVisible(false); } - if (pokemon.species.forms?.[pokemon.formIndex]?.formName) { + const formKey = (pokemon.species?.forms?.[pokemon.formIndex!]?.formKey); + const formText = Utils.capitalizeString(formKey, "-", false, false) || ""; + const speciesName = Utils.capitalizeString(Species[pokemon.species.speciesId], "_", true, false); + + let formName = ""; + if (pokemon.species.speciesId === Species.ARCEUS) { + formName = i18next.t(`pokemonInfo:Type.${formText?.toUpperCase()}`); + } else { + const i18key = `pokemonForm:${speciesName}${formText}`; + if (i18next.exists(i18key)) { + formName = i18next.t(i18key); + } else { + const rootSpeciesName = Utils.capitalizeString(Species[pokemon.species.getRootSpeciesId()], "_", true, false); + const i18RootKey = `pokemonForm:${rootSpeciesName}${formText}`; + formName = i18next.exists(i18RootKey) ? i18next.t(i18RootKey) : formText; + } + } + + if (formName) { this.pokemonFormLabelText.setVisible(true); this.pokemonFormText.setVisible(true); const newForm = BigInt(1 << pokemon.formIndex) * DexAttr.DEFAULT_FORM; @@ -247,11 +248,10 @@ export default class PokemonInfoContainer extends Phaser.GameObjects.Container { this.pokemonFormLabelText.setShadowColor(getTextColor(TextStyle.WINDOW, true, this.scene.uiTheme)); } - const formName = pokemon.species.forms?.[pokemon.formIndex]?.formName; this.pokemonFormText.setText(formName.length > this.numCharsBeforeCutoff ? formName.substring(0, this.numCharsBeforeCutoff - 3) + "..." : formName); if (formName.length > this.numCharsBeforeCutoff) { this.pokemonFormText.setInteractive(new Phaser.Geom.Rectangle(0, 0, this.pokemonFormText.width, this.pokemonFormText.height), Phaser.Geom.Rectangle.Contains); - this.pokemonFormText.on("pointerover", () => (this.scene as BattleScene).ui.showTooltip("", pokemon.species.forms?.[pokemon.formIndex]?.formName, true)); + this.pokemonFormText.on("pointerover", () => (this.scene as BattleScene).ui.showTooltip("", formName, true)); this.pokemonFormText.on("pointerout", () => (this.scene as BattleScene).ui.hideTooltip()); } else { this.pokemonFormText.disableInteractive(); @@ -267,18 +267,10 @@ export default class PokemonInfoContainer extends Phaser.GameObjects.Container { this.pokemonAbilityText.setColor(getTextColor(abilityTextStyle, false, this.scene.uiTheme)); this.pokemonAbilityText.setShadowColor(getTextColor(abilityTextStyle, true, this.scene.uiTheme)); - /** - * If the opposing Pokemon only has 1 normal ability and is using the hidden ability it should have the same behavior - * if it had 2 normal abilities. This code checks if that is the case and uses the correct opponent Pokemon abilityIndex (2) - * for calculations so it aligns with where the hidden ability is stored in the starter data's abilityAttr (4) - */ - const opponentPokemonOneNormalAbility = (pokemon.species.getAbilityCount() === 2); - const opponentPokemonAbilityIndex = (opponentPokemonOneNormalAbility && pokemon.abilityIndex === 1) ? 2 : pokemon.abilityIndex; - const opponentPokemonAbilityAttr = 1 << opponentPokemonAbilityIndex; + // Check if the player owns ability for the root form + const playerOwnsThisAbility = pokemon.checkIfPlayerHasAbilityOfStarter(starterEntry.abilityAttr); - const rootFormHasHiddenAbility = starterEntry.abilityAttr & opponentPokemonAbilityAttr; - - if (!rootFormHasHiddenAbility) { + if (!playerOwnsThisAbility) { this.pokemonAbilityLabelText.setColor(getTextColor(TextStyle.SUMMARY_BLUE, false, this.scene.uiTheme)); this.pokemonAbilityLabelText.setShadowColor(getTextColor(TextStyle.SUMMARY_BLUE, true, this.scene.uiTheme)); } else { diff --git a/src/ui/registration-form-ui-handler.ts b/src/ui/registration-form-ui-handler.ts index 0c4b54ac723..892f78bd1ba 100644 --- a/src/ui/registration-form-ui-handler.ts +++ b/src/ui/registration-form-ui-handler.ts @@ -1,9 +1,9 @@ -import { FormModalUiHandler } from "./form-modal-ui-handler"; +import { FormModalUiHandler, InputFieldConfig } from "./form-modal-ui-handler"; import { ModalConfig } from "./modal-ui-handler"; -import * as Utils from "../utils"; import { Mode } from "./ui"; import { TextStyle, addTextObject } from "./text"; import i18next from "i18next"; +import { pokerogueApi } from "#app/plugins/api/pokerogue-api"; interface LanguageSetting { @@ -13,7 +13,7 @@ interface LanguageSetting { } const languageSettings: { [key: string]: LanguageSetting } = { - "es":{ + "es-ES": { inputFieldFontSize: "50px", errorMessageFontSize: "40px", } @@ -24,10 +24,6 @@ export default class RegistrationFormUiHandler extends FormModalUiHandler { return i18next.t("menu:register"); } - getFields(config?: ModalConfig): string[] { - return [ i18next.t("menu:username"), i18next.t("menu:password"), i18next.t("menu:confirmPassword") ]; - } - getWidth(config?: ModalConfig): number { return 160; } @@ -50,17 +46,25 @@ export default class RegistrationFormUiHandler extends FormModalUiHandler { error = error.slice(0, colonIndex); } switch (error) { - case "invalid username": - return i18next.t("menu:invalidRegisterUsername"); - case "invalid password": - return i18next.t("menu:invalidRegisterPassword"); - case "failed to add account record": - return i18next.t("menu:usernameAlreadyUsed"); + case "invalid username": + return i18next.t("menu:invalidRegisterUsername"); + case "invalid password": + return i18next.t("menu:invalidRegisterPassword"); + case "failed to add account record": + return i18next.t("menu:usernameAlreadyUsed"); } return super.getReadableErrorMessage(error); } + override getInputFieldConfigs(): InputFieldConfig[] { + const inputFieldConfigs: InputFieldConfig[] = []; + inputFieldConfigs.push({ label: i18next.t("menu:username") }); + inputFieldConfigs.push({ label: i18next.t("menu:password"), isPassword: true }); + inputFieldConfigs.push({ label: i18next.t("menu:confirmPassword"), isPassword: true }); + return inputFieldConfigs; + } + setup(): void { super.setup(); @@ -74,7 +78,7 @@ export default class RegistrationFormUiHandler extends FormModalUiHandler { }); const warningMessageFontSize = languageSettings[i18next.resolvedLanguage!]?.warningMessageFontSize ?? "42px"; - const label = addTextObject(this.scene, 10, 87, i18next.t("menu:registrationAgeWarning"), TextStyle.TOOLTIP_CONTENT, { fontSize: warningMessageFontSize}); + const label = addTextObject(this.scene, 10, 87, i18next.t("menu:registrationAgeWarning"), TextStyle.TOOLTIP_CONTENT, { fontSize: warningMessageFontSize }); this.modalContainer.add(label); } @@ -88,7 +92,7 @@ export default class RegistrationFormUiHandler extends FormModalUiHandler { // Prevent overlapping overrides on action modification this.submitAction = originalRegistrationAction; this.sanitizeInputs(); - this.scene.ui.setMode(Mode.LOADING, { buttonActions: [] }); + this.scene.ui.setMode(Mode.LOADING, { buttonActions: []}); const onFail = error => { this.scene.ui.setMode(Mode.REGISTRATION_FORM, Object.assign(config, { errorMessage: error?.trim() })); this.scene.ui.playError(); @@ -106,27 +110,20 @@ export default class RegistrationFormUiHandler extends FormModalUiHandler { if (this.inputs[1].text !== this.inputs[2].text) { return onFail(i18next.t("menu:passwordNotMatchingConfirmPassword")); } - Utils.apiPost("account/register", `username=${encodeURIComponent(this.inputs[0].text)}&password=${encodeURIComponent(this.inputs[1].text)}`, "application/x-www-form-urlencoded") - .then(response => response.text()) - .then(response => { - if (!response) { - Utils.apiPost("account/login", `username=${encodeURIComponent(this.inputs[0].text)}&password=${encodeURIComponent(this.inputs[1].text)}`, "application/x-www-form-urlencoded") - .then(response => { - if (!response.ok) { - return response.text(); - } - return response.json(); - }) - .then(response => { - if (response.hasOwnProperty("token")) { - Utils.setCookie(Utils.sessionIdKey, response.token); + const [ usernameInput, passwordInput ] = this.inputs; + pokerogueApi.account.register({ username: usernameInput.text, password: passwordInput.text }) + .then(registerError => { + if (!registerError) { + pokerogueApi.account.login({ username: usernameInput.text, password: passwordInput.text }) + .then(loginError => { + if (!loginError) { originalRegistrationAction && originalRegistrationAction(); } else { - onFail(response); + onFail(loginError); } }); } else { - onFail(response); + onFail(registerError); } }); }; diff --git a/src/ui/rename-form-ui-handler.ts b/src/ui/rename-form-ui-handler.ts index 078177cafb1..6e4c4c6809d 100644 --- a/src/ui/rename-form-ui-handler.ts +++ b/src/ui/rename-form-ui-handler.ts @@ -1,4 +1,4 @@ -import { FormModalUiHandler } from "./form-modal-ui-handler"; +import { FormModalUiHandler, InputFieldConfig } from "./form-modal-ui-handler"; import { ModalConfig } from "./modal-ui-handler"; import i18next from "i18next"; import { PlayerPokemon } from "#app/field/pokemon"; @@ -8,10 +8,6 @@ export default class RenameFormUiHandler extends FormModalUiHandler { return i18next.t("menu:renamePokemon"); } - getFields(config?: ModalConfig): string[] { - return [ i18next.t("menu:nickname") ]; - } - getWidth(config?: ModalConfig): number { return 160; } @@ -33,6 +29,10 @@ export default class RenameFormUiHandler extends FormModalUiHandler { return super.getReadableErrorMessage(error); } + override getInputFieldConfigs(): InputFieldConfig[] { + return [{ label: i18next.t("menu:nickname") }]; + } + show(args: any[]): boolean { if (super.show(args)) { const config = args[0] as ModalConfig; diff --git a/src/ui/run-history-ui-handler.ts b/src/ui/run-history-ui-handler.ts index 8f132a1ab1c..061f15d0956 100644 --- a/src/ui/run-history-ui-handler.ts +++ b/src/ui/run-history-ui-handler.ts @@ -7,13 +7,14 @@ import * as Utils from "../utils"; import PokemonData from "../system/pokemon-data"; import MessageUiHandler from "./message-ui-handler"; import i18next from "i18next"; -import {Button} from "../enums/buttons"; +import { Button } from "../enums/buttons"; import { BattleType } from "../battle"; import { RunEntry } from "../system/game-data"; import { PlayerGender } from "#enums/player-gender"; import { TrainerVariant } from "../field/trainer"; +import { RunDisplayMode } from "#app/ui/run-info-ui-handler"; -export type RunSelectCallback = (cursor: integer) => void; +export type RunSelectCallback = (cursor: number) => void; export const RUN_HISTORY_LIMIT: number = 25; @@ -25,15 +26,15 @@ export const RUN_HISTORY_LIMIT: number = 25; */ export default class RunHistoryUiHandler extends MessageUiHandler { + private readonly maxRows = 3; + private runSelectContainer: Phaser.GameObjects.Container; private runsContainer: Phaser.GameObjects.Container; - private runSelectMessageBox: Phaser.GameObjects.NineSlice; - private runSelectMessageBoxContainer: Phaser.GameObjects.Container; private runs: RunEntryContainer[]; private runSelectCallback: RunSelectCallback | null; - private scrollCursor: integer = 0; + private scrollCursor: number = 0; private cursorObj: Phaser.GameObjects.NineSlice | null; @@ -74,15 +75,15 @@ export default class RunHistoryUiHandler extends MessageUiHandler { this.getUi().bringToTop(this.runSelectContainer); this.runSelectContainer.setVisible(true); - this.populateRuns(this.scene); + this.populateRuns(this.scene).then(() => { + this.setScrollCursor(0); + this.setCursor(0); - this.setScrollCursor(0); - this.setCursor(0); - - //Destroys the cursor if there are no runs saved so far. - if (this.runs.length === 0) { - this.clearCursor(); - } + //Destroys the cursor if there are no runs saved so far. + if (this.runs.length === 0) { + this.clearCursor(); + } + }); return true; } @@ -100,11 +101,11 @@ export default class RunHistoryUiHandler extends MessageUiHandler { let success = false; const error = false; - if ([Button.ACTION, Button.CANCEL].includes(button)) { + if ([ Button.ACTION, Button.CANCEL ].includes(button)) { if (button === Button.ACTION) { const cursor = this.cursor + this.scrollCursor; if (this.runs[cursor]) { - this.scene.ui.setOverlayMode(Mode.RUN_INFO, this.runs[cursor].entryData, true); + this.scene.ui.setOverlayMode(Mode.RUN_INFO, this.runs[cursor].entryData, RunDisplayMode.RUN_HISTORY, true); } else { return false; } @@ -117,20 +118,28 @@ export default class RunHistoryUiHandler extends MessageUiHandler { } } else if (this.runs.length > 0) { switch (button) { - case Button.UP: - if (this.cursor) { - success = this.setCursor(this.cursor - 1); - } else if (this.scrollCursor) { - success = this.setScrollCursor(this.scrollCursor - 1); - } - break; - case Button.DOWN: - if (this.cursor < 2) { - success = this.setCursor(this.cursor + 1); - } else if (this.scrollCursor < this.runs.length - 3) { - success = this.setScrollCursor(this.scrollCursor + 1); - } - break; + case Button.UP: + if (this.cursor) { + success = this.setCursor(this.cursor - 1); + } else if (this.scrollCursor) { + success = this.setScrollCursor(this.scrollCursor - 1); + } else if (this.runs.length > 1) { + // wrap around to the bottom + success = this.setCursor(Math.min(this.runs.length - 1, this.maxRows - 1)); + success = this.setScrollCursor(Math.max(0, this.runs.length - this.maxRows)) || success; + } + break; + case Button.DOWN: + if (this.cursor < Math.min(this.maxRows - 1, this.runs.length - this.scrollCursor - 1)) { + success = this.setCursor(this.cursor + 1); + } else if (this.scrollCursor < this.runs.length - this.maxRows) { + success = this.setScrollCursor(this.scrollCursor + 1); + } else if (this.runs.length > 1) { + // wrap around to the top + success = this.setCursor(0); + success = this.setScrollCursor(0) || success; + } + break; } } @@ -178,8 +187,8 @@ export default class RunHistoryUiHandler extends MessageUiHandler { const emptyWindow = addWindow(this.scene, 0, 0, 304, 165); this.runsContainer.add(emptyWindow); const emptyWindowCoordinates = emptyWindow.getCenter(); - const emptyText = addTextObject(this.scene, 0, 0, i18next.t("saveSlotSelectUiHandler:empty"), TextStyle.WINDOW, {fontSize: "128px"}); - emptyText.setPosition(emptyWindowCoordinates.x-18, emptyWindowCoordinates.y-15); + const emptyText = addTextObject(this.scene, 0, 0, i18next.t("saveSlotSelectUiHandler:empty"), TextStyle.WINDOW, { fontSize: "128px" }); + emptyText.setPosition(emptyWindowCoordinates.x - 18, emptyWindowCoordinates.y - 15); this.runsContainer.add(emptyText); } @@ -218,6 +227,7 @@ export default class RunHistoryUiHandler extends MessageUiHandler { override clear() { super.clear(); this.runSelectContainer.setVisible(false); + this.setScrollCursor(0); this.clearCursor(); this.runSelectCallback = null; this.clearRuns(); @@ -246,7 +256,7 @@ class RunEntryContainer extends Phaser.GameObjects.Container { public entryData: RunEntry; constructor(scene: BattleScene, entryData: RunEntry, slotId: number) { - super(scene, 0, slotId*56); + super(scene, 0, slotId * 56); this.slotId = slotId; this.entryData = entryData; @@ -281,12 +291,12 @@ class RunEntryContainer extends Phaser.GameObjects.Container { const genderIndex = this.scene.gameData.gender ?? PlayerGender.UNSET; const genderStr = PlayerGender[genderIndex].toLowerCase(); // Defeats from wild Pokemon battles will show the Pokemon responsible by the text of the run result. - if (data.battleType === BattleType.WILD) { + if (data.battleType === BattleType.WILD || (data.battleType === BattleType.MYSTERY_ENCOUNTER && !data.trainer)) { const enemyContainer = this.scene.add.container(8, 5); const gameOutcomeLabel = addTextObject(this.scene, 0, 0, `${i18next.t("runHistory:defeatedWild", { context: genderStr })}`, TextStyle.WINDOW); enemyContainer.add(gameOutcomeLabel); data.enemyParty.forEach((enemyData, e) => { - const enemyIconContainer = this.scene.add.container(65+(e*25), -8); + const enemyIconContainer = this.scene.add.container(65 + (e * 25), -8); enemyIconContainer.setScale(0.75); enemyData.boss = false; enemyData["player"] = true; @@ -302,7 +312,7 @@ class RunEntryContainer extends Phaser.GameObjects.Container { enemy.destroy(); }); this.add(enemyContainer); - } else if (data.battleType === BattleType.TRAINER) { // Defeats from Trainers show the trainer's title and name + } else if (data.battleType === BattleType.TRAINER || (data.battleType === BattleType.MYSTERY_ENCOUNTER && data.trainer)) { // Defeats from Trainers show the trainer's title and name const tObj = data.trainer.toTrainer(this.scene); // Because of the interesting mechanics behind rival names, the rival name and title have to be retrieved differently const RIVAL_TRAINER_ID_THRESHOLD = 375; @@ -323,33 +333,33 @@ class RunEntryContainer extends Phaser.GameObjects.Container { const gameModeLabel = addTextObject(this.scene, 8, 19, "", TextStyle.WINDOW); let mode = ""; switch (data.gameMode) { - case GameModes.DAILY: - mode = i18next.t("gameMode:dailyRun"); - break; - case GameModes.SPLICED_ENDLESS: - case GameModes.ENDLESS: - mode = i18next.t("gameMode:endless"); - break; - case GameModes.CLASSIC: - mode = i18next.t("gameMode:classic"); - break; - case GameModes.CHALLENGE: - mode = i18next.t("gameMode:challenge"); - break; + case GameModes.DAILY: + mode = i18next.t("gameMode:dailyRun"); + break; + case GameModes.SPLICED_ENDLESS: + case GameModes.ENDLESS: + mode = i18next.t("gameMode:endless"); + break; + case GameModes.CLASSIC: + mode = i18next.t("gameMode:classic"); + break; + case GameModes.CHALLENGE: + mode = i18next.t("gameMode:challenge"); + break; } gameModeLabel.appendText(mode, false); if (data.gameMode === GameModes.SPLICED_ENDLESS) { const splicedIcon = this.scene.add.image(0, 0, "icon_spliced"); splicedIcon.setScale(0.75); const coords = gameModeLabel.getTopRight(); - splicedIcon.setPosition(coords.x+5, 27); + splicedIcon.setPosition(coords.x + 5, 27); this.add(splicedIcon); // 4 spaces of room for the Spliced icon gameModeLabel.appendText(" - ", false); } else { gameModeLabel.appendText(" - ", false); } - gameModeLabel.appendText(i18next.t("saveSlotSelectUiHandler:wave")+" "+data.waveIndex, false); + gameModeLabel.appendText(i18next.t("saveSlotSelectUiHandler:wave") + " " + data.waveIndex, false); this.add(gameModeLabel); const timestampLabel = addTextObject(this.scene, 8, 33, new Date(data.timestamp).toLocaleString(), TextStyle.WINDOW); @@ -360,7 +370,7 @@ class RunEntryContainer extends Phaser.GameObjects.Container { // The code here does not account for icon weirdness. const pokemonIconsContainer = this.scene.add.container(140, 17); - data.party.forEach((p: PokemonData, i: integer) => { + data.party.forEach((p: PokemonData, i: number) => { const iconContainer = this.scene.add.container(26 * i, 0); iconContainer.setScale(0.75); const pokemon = p.toPokemon(this.scene); diff --git a/src/ui/run-info-ui-handler.ts b/src/ui/run-info-ui-handler.ts index 8f0437002d4..ace9d956dd9 100644 --- a/src/ui/run-info-ui-handler.ts +++ b/src/ui/run-info-ui-handler.ts @@ -5,16 +5,18 @@ import { SessionSaveData } from "../system/game-data"; import { TextStyle, addTextObject, addBBCodeTextObject, getTextColor } from "./text"; import { Mode } from "./ui"; import { addWindow } from "./ui-theme"; +import { getPokeballAtlasKey } from "#app/data/pokeball"; import * as Utils from "../utils"; import PokemonData from "../system/pokemon-data"; import i18next from "i18next"; -import {Button} from "../enums/buttons"; +import { Button } from "../enums/buttons"; import { BattleType } from "../battle"; import { TrainerVariant } from "../field/trainer"; import { Challenges } from "#enums/challenges"; import { getLuckString, getLuckTextTint } from "../modifier/modifier-type"; import RoundRectangle from "phaser3-rex-plugins/plugins/roundrectangle"; -import { Type, getTypeRgb } from "../data/type"; +import { getTypeRgb } from "#app/data/type"; +import { Type } from "#enums/type"; import { TypeColor, TypeShadow } from "#app/enums/color"; import { getNatureStatMultiplier, getNatureName } from "../data/nature"; import { getVariantTint } from "#app/data/variant"; @@ -22,6 +24,8 @@ import * as Modifier from "../modifier/modifier"; import { Species } from "#enums/species"; import { PlayerGender } from "#enums/player-gender"; import { SettingKeyboard } from "#app/system/settings/settings-keyboard"; +import { getBiomeName } from "#app/data/balance/biomes"; +import { MysteryEncounterType } from "#enums/mystery-encounter-type"; /** * RunInfoUiMode indicates possible overlays of RunInfoUiHandler. @@ -34,6 +38,11 @@ enum RunInfoUiMode { ENDING_ART } +export enum RunDisplayMode { + RUN_HISTORY, + SESSION_PREVIEW +} + /** * Some variables are protected because this UI class will most likely be extended in the future to display more information. * These variables will most likely be shared across 'classes' aka pages. @@ -41,6 +50,7 @@ enum RunInfoUiMode { * For now, I leave as is. */ export default class RunInfoUiHandler extends UiHandler { + protected runDisplayMode: RunDisplayMode; protected runInfo: SessionSaveData; protected isVictory: boolean; protected pageMode: RunInfoUiMode; @@ -49,15 +59,11 @@ export default class RunInfoUiHandler extends UiHandler { private runResultContainer: Phaser.GameObjects.Container; private runInfoContainer: Phaser.GameObjects.Container; private partyContainer: Phaser.GameObjects.Container; - private partyHeldItemsContainer: Phaser.GameObjects.Container; private statsBgWidth: integer; - private partyContainerHeight: integer; - private partyContainerWidth: integer; private hallofFameContainer: Phaser.GameObjects.Container; private endCardContainer: Phaser.GameObjects.Container; - private partyInfo: Phaser.GameObjects.Container[]; private partyVisibility: Boolean; private modifiersModule: any; @@ -70,6 +76,7 @@ export default class RunInfoUiHandler extends UiHandler { // The import of the modifiersModule is loaded here to sidestep async/await issues. this.modifiersModule = Modifier; this.runContainer.setVisible(false); + this.scene.loadImage("encounter_exclaim", "mystery-encounters"); } /** @@ -91,9 +98,15 @@ export default class RunInfoUiHandler extends UiHandler { this.runContainer.add(gameStatsBg); const run = args[0]; + this.runDisplayMode = args[1]; + if (this.runDisplayMode === RunDisplayMode.RUN_HISTORY) { + this.runInfo = this.scene.gameData.parseSessionData(JSON.stringify(run.entry)); + this.isVictory = run.isVictory ?? false; + } else if (this.runDisplayMode === RunDisplayMode.SESSION_PREVIEW) { + this.runInfo = args[0]; + } // Assigning information necessary for the UI's creation - this.runInfo = this.scene.gameData.parseSessionData(JSON.stringify(run.entry)); - this.isVictory = run.isVictory; + this.pageMode = RunInfoUiMode.MAIN; // Creates Header and adds to this.runContainer @@ -103,20 +116,24 @@ export default class RunInfoUiHandler extends UiHandler { // Creates Run Result Container this.runResultContainer = this.scene.add.container(0, 24); - const runResultWindow = addWindow(this.scene, 0, 0, this.statsBgWidth-11, 65); + const runResultWindow = addWindow(this.scene, 0, 0, this.statsBgWidth - 11, 65); runResultWindow.setOrigin(0, 0); this.runResultContainer.add(runResultWindow); - this.parseRunResult(); + if (this.runDisplayMode === RunDisplayMode.RUN_HISTORY) { + this.parseRunResult(); + } else if (this.runDisplayMode === RunDisplayMode.SESSION_PREVIEW) { + this.parseRunStatus(); + } // Creates Run Info Container this.runInfoContainer = this.scene.add.container(0, 89); - const runInfoWindow = addWindow(this.scene, 0, 0, this.statsBgWidth-11, 90); + const runInfoWindow = addWindow(this.scene, 0, 0, this.statsBgWidth - 11, 90); const runInfoWindowCoords = runInfoWindow.getBottomRight(); this.runInfoContainer.add(runInfoWindow); this.parseRunInfo(runInfoWindowCoords.x, runInfoWindowCoords.y); // Creates Player Party Container - this.partyContainer = this.scene.add.container(this.statsBgWidth-10, 23); + this.partyContainer = this.scene.add.container(this.statsBgWidth - 10, 23); this.parsePartyInfo(); this.showParty(true); @@ -151,7 +168,7 @@ export default class RunInfoUiHandler extends UiHandler { if (this.runInfo.modifiers.length !== 0) { const headerBgCoords = headerBg.getTopRight(); const abilityButtonContainer = this.scene.add.container(0, 0); - const abilityButtonText = addTextObject(this.scene, 8, 0, i18next.t("runHistory:viewHeldItems"), TextStyle.WINDOW, {fontSize:"34px"}); + const abilityButtonText = addTextObject(this.scene, 8, 0, i18next.t("runHistory:viewHeldItems"), TextStyle.WINDOW, { fontSize:"34px" }); const gamepadType = this.getUi().getGamepadType(); let abilityButtonElement: Phaser.GameObjects.Sprite; if (gamepadType === "touch") { @@ -159,7 +176,7 @@ export default class RunInfoUiHandler extends UiHandler { } else { abilityButtonElement = new Phaser.GameObjects.Sprite(this.scene, 0, 2, gamepadType, this.scene.inputController?.getIconForLatestInputRecorded(SettingKeyboard.Button_Cycle_Ability)); } - abilityButtonContainer.add([abilityButtonText, abilityButtonElement]); + abilityButtonContainer.add([ abilityButtonText, abilityButtonElement ]); abilityButtonContainer.setPosition(headerBgCoords.x - abilityButtonText.displayWidth - abilityButtonElement.displayWidth - 8, 10); this.runContainer.add(abilityButtonContainer); } @@ -182,12 +199,12 @@ export default class RunInfoUiHandler extends UiHandler { const genderStr = PlayerGender[genderIndex]; const runResultTextStyle = this.isVictory ? TextStyle.PERFECT_IV : TextStyle.SUMMARY_RED; const runResultTitle = this.isVictory ? i18next.t("runHistory:victory") : i18next.t("runHistory:defeated", { context: genderStr }); - const runResultText = addTextObject(this.scene, 6, 5, `${runResultTitle} - ${i18next.t("saveSlotSelectUiHandler:wave")} ${this.runInfo.waveIndex}`, runResultTextStyle, {fontSize : "65px", lineSpacing: 0.1}); + const runResultText = addTextObject(this.scene, 6, 5, `${runResultTitle} - ${i18next.t("saveSlotSelectUiHandler:wave")} ${this.runInfo.waveIndex}`, runResultTextStyle, { fontSize : "65px", lineSpacing: 0.1 }); if (this.isVictory) { const hallofFameInstructionContainer = this.scene.add.container(0, 0); - const shinyButtonText = addTextObject(this.scene, 8, 0, i18next.t("runHistory:viewHallOfFame"), TextStyle.WINDOW, {fontSize:"65px"}); - const formButtonText = addTextObject(this.scene, 8, 12, i18next.t("runHistory:viewEndingSplash"), TextStyle.WINDOW, {fontSize:"65px"}); + const shinyButtonText = addTextObject(this.scene, 8, 0, i18next.t("runHistory:viewHallOfFame"), TextStyle.WINDOW, { fontSize:"65px" }); + const formButtonText = addTextObject(this.scene, 8, 12, i18next.t("runHistory:viewEndingSplash"), TextStyle.WINDOW, { fontSize:"65px" }); const gamepadType = this.getUi().getGamepadType(); let shinyButtonElement: Phaser.GameObjects.Sprite; let formButtonElement: Phaser.GameObjects.Sprite; @@ -198,9 +215,9 @@ export default class RunInfoUiHandler extends UiHandler { shinyButtonElement = new Phaser.GameObjects.Sprite(this.scene, 0, 4, gamepadType, this.scene.inputController?.getIconForLatestInputRecorded(SettingKeyboard.Button_Cycle_Shiny)); formButtonElement = new Phaser.GameObjects.Sprite(this.scene, 0, 16, gamepadType, this.scene.inputController?.getIconForLatestInputRecorded(SettingKeyboard.Button_Cycle_Form)); } - hallofFameInstructionContainer.add([shinyButtonText, shinyButtonElement]); + hallofFameInstructionContainer.add([ shinyButtonText, shinyButtonElement ]); - hallofFameInstructionContainer.add([formButtonText, formButtonElement]); + hallofFameInstructionContainer.add([ formButtonText, formButtonElement ]); hallofFameInstructionContainer.setPosition(12, 25); this.runResultContainer.add(hallofFameInstructionContainer); @@ -211,18 +228,18 @@ export default class RunInfoUiHandler extends UiHandler { if (!this.isVictory) { const enemyContainer = this.scene.add.container(0, 0); // Wild - Single and Doubles - if (this.runInfo.battleType === BattleType.WILD) { + if (this.runInfo.battleType === BattleType.WILD || (this.runInfo.battleType === BattleType.MYSTERY_ENCOUNTER && !this.runInfo.trainer)) { switch (this.runInfo.enemyParty.length) { - case 1: + case 1: // Wild - Singles - this.parseWildSingleDefeat(enemyContainer); - break; - case 2: + this.parseWildSingleDefeat(enemyContainer); + break; + case 2: //Wild - Doubles - this.parseWildDoubleDefeat(enemyContainer); - break; + this.parseWildDoubleDefeat(enemyContainer); + break; } - } else if (this.runInfo.battleType === BattleType.TRAINER) { + } else if (this.runInfo.battleType === BattleType.TRAINER || (this.runInfo.battleType === BattleType.MYSTERY_ENCOUNTER && this.runInfo.trainer)) { this.parseTrainerDefeat(enemyContainer); } this.runResultContainer.add(enemyContainer); @@ -230,6 +247,66 @@ export default class RunInfoUiHandler extends UiHandler { this.runContainer.add(this.runResultContainer); } + /** + * This function is used when the Run Info UI is used to preview a Session. + * It edits {@linkcode runResultContainer}, but most importantly - does not display the negative results of a Mystery Encounter or any details of a trainer's party. + * Trainer Parties are replaced with their sprites, names, and their party size. + * Mystery Encounters contain sprites associated with MEs + the title of the specific ME. + */ + private parseRunStatus() { + const runStatusText = addTextObject(this.scene, 6, 5, `${i18next.t("saveSlotSelectUiHandler:wave")} ${this.runInfo.waveIndex} - ${getBiomeName(this.runInfo.arena.biome)}`, TextStyle.WINDOW, { fontSize : "65px", lineSpacing: 0.1 }); + + const enemyContainer = this.scene.add.container(0, 0); + this.runResultContainer.add(enemyContainer); + if (this.runInfo.battleType === BattleType.WILD) { + if (this.runInfo.enemyParty.length === 1) { + this.parseWildSingleDefeat(enemyContainer); + } else if (this.runInfo.enemyParty.length === 2) { + this.parseWildDoubleDefeat(enemyContainer); + } + } else if (this.runInfo.battleType === BattleType.TRAINER) { + this.showTrainerSprites(enemyContainer); + const row_limit = 3; + this.runInfo.enemyParty.forEach((p, i) => { + const pokeball = this.scene.add.sprite(0, 0, "pb"); + pokeball.setFrame(getPokeballAtlasKey(p.pokeball)); + pokeball.setScale(0.5); + pokeball.setPosition(52 + ((i % row_limit) * 8), (i <= 2) ? 18 : 25); + enemyContainer.add(pokeball); + }); + const trainerObj = this.runInfo.trainer.toTrainer(this.scene); + const RIVAL_TRAINER_ID_THRESHOLD = 375; + let trainerName = ""; + if (this.runInfo.trainer.trainerType >= RIVAL_TRAINER_ID_THRESHOLD) { + trainerName = (trainerObj.variant === TrainerVariant.FEMALE) ? i18next.t("trainerNames:rival_female") : i18next.t("trainerNames:rival"); + } else { + trainerName = trainerObj.getName(0, true); + } + const boxString = i18next.t(trainerObj.variant !== TrainerVariant.DOUBLE ? "battle:trainerAppeared" : "battle:trainerAppearedDouble", { trainerName: trainerName }).replace(/\n/g, " "); + const descContainer = this.scene.add.container(0, 0); + const textBox = addTextObject(this.scene, 0, 0, boxString, TextStyle.WINDOW, { fontSize : "35px", wordWrap: { width: 200 }}); + descContainer.add(textBox); + descContainer.setPosition(52, 29); + this.runResultContainer.add(descContainer); + } else if (this.runInfo.battleType === BattleType.MYSTERY_ENCOUNTER) { + const encounterExclaim = this.scene.add.sprite(0, 0, "encounter_exclaim"); + encounterExclaim.setPosition(34, 26); + encounterExclaim.setScale(0.65); + const subSprite = this.scene.add.sprite(56, -106, "pkmn__sub"); + subSprite.setScale(0.65); + subSprite.setPosition(34, 46); + const mysteryEncounterTitle = i18next.t(this.scene.getMysteryEncounter(this.runInfo.mysteryEncounterType as MysteryEncounterType, true).localizationKey + ":title"); + const descContainer = this.scene.add.container(0, 0); + const textBox = addTextObject(this.scene, 0, 0, mysteryEncounterTitle, TextStyle.WINDOW, { fontSize : "45px", wordWrap: { width: 160 }}); + descContainer.add(textBox); + descContainer.setPosition(47, 37); + this.runResultContainer.add([ encounterExclaim, subSprite, descContainer ]); + } + + this.runResultContainer.add(runStatusText); + this.runContainer.add(this.runResultContainer); + } + /** * This function is called to edit an enemyContainer to represent a loss from a defeat by a wild single Pokemon battle. * @param enemyContainer - container holding enemy visual and level information @@ -274,44 +351,66 @@ export default class RunInfoUiHandler extends UiHandler { enemyLevel.setOrigin(1, 0); enemyIconContainer.add(enemyIcon); enemyIconContainer.add(enemyLevel); - enemyIconContainer.setPosition(e*35, 0); + enemyIconContainer.setPosition(e * 35, 0); enemyContainer.add(enemyIconContainer); enemy.destroy(); }); enemyContainer.setPosition(8, 14); } + /** + * This loads the enemy sprites, positions, and scales them according to the current display mode of the RunInfo UI and then adds them to the container parameter. + * Used by {@linkcode parseRunStatus} and {@linkcode parseTrainerDefeat} + * @param enemyContainer a Phaser Container that should hold enemy sprites + */ + private showTrainerSprites(enemyContainer: Phaser.GameObjects.Container) { + // Creating the trainer sprite and adding it to enemyContainer + const tObj = this.runInfo.trainer.toTrainer(this.scene); + // Loads trainer assets on demand, as they are not loaded by default in the scene + tObj.config.loadAssets(this.scene, this.runInfo.trainer.variant).then(() => { + const tObjSpriteKey = tObj.config.getSpriteKey(this.runInfo.trainer.variant === TrainerVariant.FEMALE, false); + const tObjSprite = this.scene.add.sprite(0, 5, tObjSpriteKey); + if (this.runInfo.trainer.variant === TrainerVariant.DOUBLE && !tObj.config.doubleOnly) { + const doubleContainer = this.scene.add.container(5, 8); + tObjSprite.setPosition(-3, -3); + const tObjPartnerSpriteKey = tObj.config.getSpriteKey(true, true); + const tObjPartnerSprite = this.scene.add.sprite(5, -3, tObjPartnerSpriteKey); + // Double Trainers have smaller sprites than Single Trainers + if (this.runDisplayMode === RunDisplayMode.RUN_HISTORY) { + tObjPartnerSprite.setScale(0.20); + tObjSprite.setScale(0.20); + doubleContainer.add(tObjSprite); + doubleContainer.add(tObjPartnerSprite); + doubleContainer.setPosition(12, 38); + } else { + tObjSprite.setScale(0.55); + tObjSprite.setPosition(-9, -3); + tObjPartnerSprite.setScale(0.55); + doubleContainer.add([ tObjSprite, tObjPartnerSprite ]); + doubleContainer.setPosition(28, 40); + } + enemyContainer.add(doubleContainer); + } else { + const scale = (this.runDisplayMode === RunDisplayMode.RUN_HISTORY) ? 0.35 : 0.65; + const position = (this.runDisplayMode === RunDisplayMode.RUN_HISTORY) ? [ 12, 28 ] : [ 32, 36 ]; + tObjSprite.setScale(scale, scale); + tObjSprite.setPosition(position[0], position[1]); + enemyContainer.add(tObjSprite); + } + }); + } + /** * This edits a container to represent a loss from a defeat by a trainer battle. - * @param enemyContainer - container holding enemy visuals and level information * The trainers are placed to the left of their party. * Depending on the trainer icon, there may be overlap between the edges of the box or their party. (Capes...) * * Party Pokemon have their icons, terastalization status, and level shown. + * @param enemyContainer - container holding enemy visuals and level information */ private parseTrainerDefeat(enemyContainer: Phaser.GameObjects.Container) { - // Creating the trainer sprite and adding it to enemyContainer - const tObj = this.runInfo.trainer.toTrainer(this.scene); - const tObjSpriteKey = tObj.config.getSpriteKey(this.runInfo.trainer.variant === TrainerVariant.FEMALE, false); - const tObjSprite = this.scene.add.sprite(0, 5, tObjSpriteKey); - if (this.runInfo.trainer.variant === TrainerVariant.DOUBLE) { - const doubleContainer = this.scene.add.container(5, 8); - tObjSprite.setPosition(-3, -3); - const tObjPartnerSpriteKey = tObj.config.getSpriteKey(true, true); - const tObjPartnerSprite = this.scene.add.sprite(5, -3, tObjPartnerSpriteKey); - // Double Trainers have smaller sprites than Single Trainers - tObjPartnerSprite.setScale(0.20); - tObjSprite.setScale(0.20); - doubleContainer.add(tObjSprite); - doubleContainer.add(tObjPartnerSprite); - doubleContainer.setPosition(12, 38); - enemyContainer.add(doubleContainer); - } else { - tObjSprite.setScale(0.35, 0.35); - tObjSprite.setPosition(12, 28); - enemyContainer.add(tObjSprite); - } - + // Loads and adds trainer sprites to the UI + this.showTrainerSprites(enemyContainer); // Determining which Terastallize Modifier belongs to which Pokemon // Creates a dictionary {PokemonId: TeraShardType} const teraPokemon = {}; @@ -328,7 +427,7 @@ export default class RunInfoUiHandler extends UiHandler { // 2 Rows x 3 Columns const enemyPartyContainer = this.scene.add.container(0, 0); this.runInfo.enemyParty.forEach((enemyData, e) => { - const pokemonRowHeight = Math.floor(e/3); + const pokemonRowHeight = Math.floor(e / 3); const enemyIconContainer = this.scene.add.container(0, 0); enemyIconContainer.setScale(0.6); const isBoss = enemyData.boss; @@ -348,8 +447,8 @@ export default class RunInfoUiHandler extends UiHandler { enemySprite2.setTint(teraColor.color); } } - enemyIcon.setPosition(39*(e%3)+5, (35*pokemonRowHeight)); - const enemyLevel = addTextObject(this.scene, 43*(e%3), (27*(pokemonRowHeight+1)), `${i18next.t("saveSlotSelectUiHandler:lv")}${Utils.formatLargeNumber(enemy.level, 1000)}`, isBoss ? TextStyle.PARTY_RED : TextStyle.PARTY, { fontSize: "54px" }); + enemyIcon.setPosition(39 * (e % 3) + 5, (35 * pokemonRowHeight)); + const enemyLevel = addTextObject(this.scene, 43 * (e % 3), (27 * (pokemonRowHeight + 1)), `${i18next.t("saveSlotSelectUiHandler:lv")}${Utils.formatLargeNumber(enemy.level, 1000)}`, isBoss ? TextStyle.PARTY_RED : TextStyle.PARTY, { fontSize: "54px" }); enemyLevel.setShadow(0, 0, undefined); enemyLevel.setStroke("#424242", 14); enemyLevel.setOrigin(0, 0); @@ -372,71 +471,69 @@ export default class RunInfoUiHandler extends UiHandler { private async parseRunInfo(windowX: number, windowY: number) { // Parsing and displaying the mode. // In the future, parsing Challenges + Challenge Rules may have to be reworked as PokeRogue adds additional challenges and users can stack these challenges in various ways. - const modeText = addBBCodeTextObject(this.scene, 7, 0, "", TextStyle.WINDOW, {fontSize : "50px", lineSpacing:3}); + const modeText = addBBCodeTextObject(this.scene, 7, 0, "", TextStyle.WINDOW, { fontSize : "50px", lineSpacing:3 }); modeText.setPosition(7, 5); - modeText.appendText(i18next.t("runHistory:mode")+": ", false); + modeText.appendText(i18next.t("runHistory:mode") + ": ", false); switch (this.runInfo.gameMode) { - case GameModes.DAILY: - modeText.appendText(`${i18next.t("gameMode:dailyRun")}`, false); - break; - case GameModes.SPLICED_ENDLESS: - modeText.appendText(`${i18next.t("gameMode:endlessSpliced")}`, false); - if (this.runInfo.waveIndex === this.scene.gameData.gameStats.highestEndlessWave) { - modeText.appendText(` [${i18next.t("runHistory:personalBest")}]`, false); - modeText.setTint(0xffef5c, 0x47ff69, 0x6b6bff, 0xff6969); - } - break; - case GameModes.CHALLENGE: - modeText.appendText(`${i18next.t("gameMode:challenge")}`, false); - modeText.appendText(`${i18next.t("runHistory:challengeRules")}: `); - modeText.setWrapMode(1); // wrap by word - modeText.setWrapWidth(500); - const rules: string[] = this.challengeParser(); - if (rules) { - for (let i = 0; i < rules.length; i++) { - if (i > 0) { - modeText.appendText(" + ", false); + case GameModes.DAILY: + modeText.appendText(`${i18next.t("gameMode:dailyRun")}`, false); + break; + case GameModes.SPLICED_ENDLESS: + modeText.appendText(`${i18next.t("gameMode:endlessSpliced")}`, false); + break; + case GameModes.CHALLENGE: + modeText.appendText(`${i18next.t("gameMode:challenge")}`, false); + modeText.appendText(`${i18next.t("runHistory:challengeRules")}: `); + modeText.setWrapMode(1); // wrap by word + modeText.setWrapWidth(500); + const rules: string[] = this.challengeParser(); + if (rules) { + for (let i = 0; i < rules.length; i++) { + if (i > 0) { + modeText.appendText(" + ", false); + } + modeText.appendText(rules[i], false); } - modeText.appendText(rules[i], false); } - } - break; - case GameModes.ENDLESS: - modeText.appendText(`${i18next.t("gameMode:endless")}`, false); - // If the player achieves a personal best in Endless, the mode text will be tinted similarly to SSS luck to celebrate their achievement. - if (this.runInfo.waveIndex === this.scene.gameData.gameStats.highestEndlessWave) { - modeText.appendText(` [${i18next.t("runHistory:personalBest")}]`, false); - modeText.setTint(0xffef5c, 0x47ff69, 0x6b6bff, 0xff6969); - } - break; - case GameModes.CLASSIC: - modeText.appendText(`${i18next.t("gameMode:classic")}`, false); - break; + break; + case GameModes.ENDLESS: + modeText.appendText(`${i18next.t("gameMode:endless")}`, false); + break; + case GameModes.CLASSIC: + modeText.appendText(`${i18next.t("gameMode:classic")}`, false); + break; + } + + // If the player achieves a personal best in Endless, the mode text will be tinted similarly to SSS luck to celebrate their achievement. + if ((this.runInfo.gameMode === GameModes.ENDLESS || this.runInfo.gameMode === GameModes.SPLICED_ENDLESS) && this.runInfo.waveIndex === this.scene.gameData.gameStats.highestEndlessWave) { + modeText.appendText(` [${i18next.t("runHistory:personalBest")}]`); + modeText.setTint(0xffef5c, 0x47ff69, 0x6b6bff, 0xff6969); } // Duration + Money const runInfoTextContainer = this.scene.add.container(0, 0); // Japanese is set to a greater line spacing of 35px in addBBCodeTextObject() if lineSpacing < 12. const lineSpacing = (i18next.resolvedLanguage === "ja") ? 12 : 3; - const runInfoText = addBBCodeTextObject(this.scene, 7, 0, "", TextStyle.WINDOW, {fontSize: "50px", lineSpacing: lineSpacing}); + const runInfoText = addBBCodeTextObject(this.scene, 7, 0, "", TextStyle.WINDOW, { fontSize: "50px", lineSpacing: lineSpacing }); const runTime = Utils.getPlayTimeString(this.runInfo.playTime); runInfoText.appendText(`${i18next.t("runHistory:runLength")}: ${runTime}`, false); const runMoney = Utils.formatMoney(this.scene.moneyFormat, this.runInfo.money); - runInfoText.appendText(`[color=${getTextColor(TextStyle.MONEY)}]${i18next.t("battleScene:moneyOwned", {formattedMoney : runMoney})}[/color]`); + const moneyTextColor = getTextColor(TextStyle.MONEY_WINDOW, false, this.scene.uiTheme); + runInfoText.appendText(`[color=${moneyTextColor}]${i18next.t("battleScene:moneyOwned", { formattedMoney : runMoney })}[/color]`); runInfoText.setPosition(7, 70); runInfoTextContainer.add(runInfoText); // Luck // Uses the parameters windowX and windowY to dynamically position the luck value neatly into the bottom right corner - const luckText = addBBCodeTextObject(this.scene, 0, 0, "", TextStyle.WINDOW, {fontSize: "55px"}); + const luckText = addBBCodeTextObject(this.scene, 0, 0, "", TextStyle.WINDOW, { fontSize: "55px" }); const luckValue = Phaser.Math.Clamp(this.runInfo.party.map(p => p.toPokemon(this.scene).getLuck()).reduce((total: integer, value: integer) => total += value, 0), 0, 14); - let luckInfo = i18next.t("runHistory:luck")+": "+getLuckString(luckValue); + let luckInfo = i18next.t("runHistory:luck") + ": " + getLuckString(luckValue); if (luckValue < 14) { - luckInfo = "[color=#"+(getLuckTextTint(luckValue)).toString(16)+"]"+luckInfo+"[/color]"; + luckInfo = "[color=#" + (getLuckTextTint(luckValue)).toString(16) + "]" + luckInfo + "[/color]"; } else { luckText.setTint(0xffef5c, 0x47ff69, 0x6b6bff, 0xff6969); } - luckText.appendText("[align=right]"+luckInfo+"[/align]", false); - luckText.setPosition(windowX-luckText.displayWidth-5, windowY-13); + luckText.appendText("[align=right]" + luckInfo + "[/align]", false); + luckText.setPosition(windowX - luckText.displayWidth - 5, windowY - 13); runInfoTextContainer.add(luckText); // Player Held Items @@ -453,8 +550,8 @@ export default class RunInfoUiHandler extends UiHandler { } const icon = modifier?.getIcon(this.scene, false); if (icon) { - const rowHeightModifier = Math.floor(visibleModifierIndex/7); - icon.setPosition(24 * (visibleModifierIndex%7), 20 + (35 * rowHeightModifier)); + const rowHeightModifier = Math.floor(visibleModifierIndex / 7); + icon.setPosition(24 * (visibleModifierIndex % 7), 20 + (35 * rowHeightModifier)); modifierIconsContainer.add(icon); } @@ -482,23 +579,23 @@ export default class RunInfoUiHandler extends UiHandler { for (let i = 0; i < this.runInfo.challenges.length; i++) { if (this.runInfo.challenges[i].value !== 0) { switch (this.runInfo.challenges[i].id) { - case Challenges.SINGLE_GENERATION: - rules.push(i18next.t(`runHistory:challengeMonoGen${this.runInfo.challenges[i].value}`)); - break; - case Challenges.SINGLE_TYPE: - const typeRule = Type[this.runInfo.challenges[i].value-1]; - const typeTextColor = `[color=${TypeColor[typeRule]}]`; - const typeShadowColor = `[shadow=${TypeShadow[typeRule]}]`; - const typeText = typeTextColor + typeShadowColor + i18next.t(`pokemonInfo:Type.${typeRule}`)!+"[/color]"+"[/shadow]"; - rules.push(typeText); - break; - case Challenges.FRESH_START: - rules.push(i18next.t("challenges:freshStart.name")); - break; - case Challenges.INVERSE_BATTLE: - // - rules.push(i18next.t("challenges:inverseBattle.shortName")); - break; + case Challenges.SINGLE_GENERATION: + rules.push(i18next.t(`runHistory:challengeMonoGen${this.runInfo.challenges[i].value}`)); + break; + case Challenges.SINGLE_TYPE: + const typeRule = Type[this.runInfo.challenges[i].value - 1]; + const typeTextColor = `[color=${TypeColor[typeRule]}]`; + const typeShadowColor = `[shadow=${TypeShadow[typeRule]}]`; + const typeText = typeTextColor + typeShadowColor + i18next.t(`pokemonInfo:Type.${typeRule}`)! + "[/color]" + "[/shadow]"; + rules.push(typeText); + break; + case Challenges.INVERSE_BATTLE: + rules.push(i18next.t("challenges:inverseBattle.shortName")); + break; + default: + const localisationKey = Challenges[this.runInfo.challenges[i].id].split("_").map((f, i) => i ? `${f[0]}${f.slice(1).toLowerCase()}` : f.toLowerCase()).join(""); + rules.push(i18next.t(`challenges:${localisationKey}.name`)); + break; } } } @@ -513,13 +610,13 @@ export default class RunInfoUiHandler extends UiHandler { private parsePartyInfo(): void { const party = this.runInfo.party; const currentLanguage = i18next.resolvedLanguage ?? "en"; - const windowHeight = ((this.scene.game.canvas.height / 6) - 23)/6; + const windowHeight = ((this.scene.game.canvas.height / 6) - 23) / 6; party.forEach((p: PokemonData, i: integer) => { - const pokemonInfoWindow = new RoundRectangle(this.scene, 0, 14, (this.statsBgWidth*2)+10, windowHeight-2, 3); + const pokemonInfoWindow = new RoundRectangle(this.scene, 0, 14, (this.statsBgWidth * 2) + 10, windowHeight - 2, 3); const pokemon = p.toPokemon(this.scene); - const pokemonInfoContainer = this.scene.add.container(this.statsBgWidth+5, (windowHeight-0.5)*i); + const pokemonInfoContainer = this.scene.add.container(this.statsBgWidth + 5, (windowHeight - 0.5) * i); const types = pokemon.getTypes(); const type1 = getTypeRgb(types[0]); @@ -547,18 +644,18 @@ export default class RunInfoUiHandler extends UiHandler { const pName = pokemon.getNameToRender(); //With the exception of Korean/Traditional Chinese/Simplified Chinese, the code shortens the terms for ability and passive to their first letter. //These languages are exempted because they are already short enough. - const exemptedLanguages = ["ko", "zh_CN", "zh_TW"]; + const exemptedLanguages = [ "ko", "zh_CN", "zh_TW" ]; let passiveLabel = i18next.t("starterSelectUiHandler:passive") ?? "-"; let abilityLabel = i18next.t("starterSelectUiHandler:ability") ?? "-"; if (!exemptedLanguages.includes(currentLanguage)) { passiveLabel = passiveLabel.charAt(0); abilityLabel = abilityLabel.charAt(0); } - const pPassiveInfo = pokemon.passive ? passiveLabel+": "+pokemon.getPassiveAbility().name : ""; + const pPassiveInfo = pokemon.passive ? passiveLabel + ": " + pokemon.getPassiveAbility().name : ""; const pAbilityInfo = abilityLabel + ": " + pokemon.getAbility().name; // Japanese is set to a greater line spacing of 35px in addBBCodeTextObject() if lineSpacing < 12. const lineSpacing = (i18next.resolvedLanguage === "ja") ? 12 : 3; - const pokeInfoText = addBBCodeTextObject(this.scene, 0, 0, pName, TextStyle.SUMMARY, {fontSize: textContainerFontSize, lineSpacing: lineSpacing}); + const pokeInfoText = addBBCodeTextObject(this.scene, 0, 0, pName, TextStyle.SUMMARY, { fontSize: textContainerFontSize, lineSpacing: lineSpacing }); pokeInfoText.appendText(`${i18next.t("saveSlotSelectUiHandler:lv")}${Utils.formatFancyLargeNumber(pokemon.level, 1)} - ${pNatureName}`); pokeInfoText.appendText(pAbilityInfo); pokeInfoText.appendText(pPassiveInfo); @@ -567,27 +664,27 @@ export default class RunInfoUiHandler extends UiHandler { // Pokemon Stats // Colored Arrows (Red/Blue) are placed by stats that are boosted from natures const pokeStatTextContainer = this.scene.add.container(-35, 6); - const pStats : string[]= []; + const pStats : string[] = []; pokemon.stats.forEach((element) => pStats.push(Utils.formatFancyLargeNumber(element, 1))); for (let i = 0; i < pStats.length; i++) { const isMult = getNatureStatMultiplier(pNature, i); pStats[i] = (isMult < 1) ? pStats[i] + "[color=#40c8f8]↓[/color]" : pStats[i]; pStats[i] = (isMult > 1) ? pStats[i] + "[color=#f89890]↑[/color]" : pStats[i]; } - const hp = i18next.t("pokemonInfo:Stat.HPshortened")+": "+pStats[0]; - const atk = i18next.t("pokemonInfo:Stat.ATKshortened")+": "+pStats[1]; - const def = i18next.t("pokemonInfo:Stat.DEFshortened")+": "+pStats[2]; - const spatk = i18next.t("pokemonInfo:Stat.SPATKshortened")+": "+pStats[3]; - const spdef = i18next.t("pokemonInfo:Stat.SPDEFshortened")+": "+pStats[4]; - const speedLabel = (currentLanguage==="es"||currentLanguage==="pt_BR") ? i18next.t("runHistory:SPDshortened") : i18next.t("pokemonInfo:Stat.SPDshortened"); - const speed = speedLabel+": "+pStats[5]; + const hp = i18next.t("pokemonInfo:Stat.HPshortened") + ": " + pStats[0]; + const atk = i18next.t("pokemonInfo:Stat.ATKshortened") + ": " + pStats[1]; + const def = i18next.t("pokemonInfo:Stat.DEFshortened") + ": " + pStats[2]; + const spatk = i18next.t("pokemonInfo:Stat.SPATKshortened") + ": " + pStats[3]; + const spdef = i18next.t("pokemonInfo:Stat.SPDEFshortened") + ": " + pStats[4]; + const speedLabel = (currentLanguage === "es-ES" || currentLanguage === "pt_BR") ? i18next.t("runHistory:SPDshortened") : i18next.t("pokemonInfo:Stat.SPDshortened"); + const speed = speedLabel + ": " + pStats[5]; // Column 1: HP Atk Def - const pokeStatText1 = addBBCodeTextObject(this.scene, -5, 0, hp, TextStyle.SUMMARY, {fontSize: textContainerFontSize, lineSpacing: lineSpacing}); + const pokeStatText1 = addBBCodeTextObject(this.scene, -5, 0, hp, TextStyle.SUMMARY, { fontSize: textContainerFontSize, lineSpacing: lineSpacing }); pokeStatText1.appendText(atk); pokeStatText1.appendText(def); pokeStatTextContainer.add(pokeStatText1); // Column 2: SpAtk SpDef Speed - const pokeStatText2 = addBBCodeTextObject(this.scene, 25, 0, spatk, TextStyle.SUMMARY, {fontSize: textContainerFontSize, lineSpacing: lineSpacing}); + const pokeStatText2 = addBBCodeTextObject(this.scene, 25, 0, spatk, TextStyle.SUMMARY, { fontSize: textContainerFontSize, lineSpacing: lineSpacing }); pokeStatText2.appendText(spdef); pokeStatText2.appendText(speed); pokeStatTextContainer.add(pokeStatText2); @@ -615,7 +712,7 @@ export default class RunInfoUiHandler extends UiHandler { const fusionShinyStar = this.scene.add.image(0, 0, "shiny_star_small_2"); fusionShinyStar.setOrigin(0, 0); fusionShinyStar.setScale(0.5); - fusionShinyStar.setPosition(shinyStar.x+1, shinyStar.y+1); + fusionShinyStar.setPosition(shinyStar.x + 1, shinyStar.y + 1); fusionShinyStar.setTint(getVariantTint(pokemon.fusionVariant)); marksContainer.add(fusionShinyStar); this.getUi().bringToTop(fusionShinyStar); @@ -628,7 +725,7 @@ export default class RunInfoUiHandler extends UiHandler { const movesetContainer = this.scene.add.container(70, -29); const pokemonMoveBgs : Phaser.GameObjects.NineSlice[] = []; const pokemonMoveLabels : Phaser.GameObjects.Text[] = []; - const movePos = [[-6.5, 35.5], [37, 35.5], [-6.5, 43.5], [37, 43.5]]; + const movePos = [[ -6.5, 35.5 ], [ 37, 35.5 ], [ -6.5, 43.5 ], [ 37, 43.5 ]]; for (let m = 0; m < pokemonMoveset?.length; m++) { const moveContainer = this.scene.add.container(movePos[m][0], movePos[m][1]); moveContainer.setScale(0.5); @@ -663,7 +760,7 @@ export default class RunInfoUiHandler extends UiHandler { if (heldItemsList.length > 0) { (heldItemsList as Modifier.PokemonHeldItemModifier[]).sort(Modifier.modifierSortFunc); let row = 0; - for (const [index, item] of heldItemsList.entries()) { + for (const [ index, item ] of heldItemsList.entries()) { if ( index > 36 ) { const overflowIcon = addTextObject(this.scene, 182, 4, "+", TextStyle.WINDOW); heldItemsContainer.add(overflowIcon); @@ -674,7 +771,7 @@ export default class RunInfoUiHandler extends UiHandler { itemIcon.list[1].clearTint(); } itemIcon.setScale(heldItemsScale); - itemIcon.setPosition((index%19) * 10, row * 10); + itemIcon.setPosition((index % 19) * 10, row * 10); heldItemsContainer.add(itemIcon); if (index !== 0 && index % 18 === 0) { row++; @@ -757,15 +854,15 @@ export default class RunInfoUiHandler extends UiHandler { endCard.setScale(0.5); const endCardCoords = endCard.getBottomCenter(); const overlayColor = isFemale ? "red" : "blue"; - const hallofFameBg = this.scene.add.image(0, 0, "hall_of_fame_"+overlayColor); + const hallofFameBg = this.scene.add.image(0, 0, "hall_of_fame_" + overlayColor); hallofFameBg.setPosition(159, 89); - hallofFameBg.setSize(this.scene.game.canvas.width, this.scene.game.canvas.height+10); + hallofFameBg.setSize(this.scene.game.canvas.width, this.scene.game.canvas.height + 10); hallofFameBg.setAlpha(0.8); this.hallofFameContainer.add(endCard); this.hallofFameContainer.add(hallofFameBg); const hallofFameText = addTextObject(this.scene, 0, 0, i18next.t("runHistory:hallofFameText", { context: genderStr }), TextStyle.WINDOW); - hallofFameText.setPosition(endCardCoords.x-(hallofFameText.displayWidth/2), 164); + hallofFameText.setPosition(endCardCoords.x - (hallofFameText.displayWidth / 2), 164); this.hallofFameContainer.add(hallofFameText); this.runInfo.party.forEach((p, i) => { const pkmn = p.toPokemon(this.scene); @@ -816,36 +913,36 @@ export default class RunInfoUiHandler extends UiHandler { const error = false; switch (button) { - case Button.CANCEL: - success = true; - if (this.pageMode === RunInfoUiMode.MAIN) { - this.runInfoContainer.removeAll(true); - this.runResultContainer.removeAll(true); - this.partyContainer.removeAll(true); - this.runContainer.removeAll(true); - if (this.isVictory) { - this.hallofFameContainer.removeAll(true); + case Button.CANCEL: + success = true; + if (this.pageMode === RunInfoUiMode.MAIN) { + this.runInfoContainer.removeAll(true); + this.runResultContainer.removeAll(true); + this.partyContainer.removeAll(true); + this.runContainer.removeAll(true); + if (this.isVictory) { + this.hallofFameContainer.removeAll(true); + } + super.clear(); + this.runContainer.setVisible(false); + ui.revertMode(); + } else if (this.pageMode === RunInfoUiMode.HALL_OF_FAME) { + this.hallofFameContainer.setVisible(false); + this.pageMode = RunInfoUiMode.MAIN; + } else if (this.pageMode === RunInfoUiMode.ENDING_ART) { + this.endCardContainer.setVisible(false); + this.runContainer.remove(this.endCardContainer); + this.pageMode = RunInfoUiMode.MAIN; } - super.clear(); - this.runContainer.setVisible(false); - ui.revertMode(); - } else if (this.pageMode === RunInfoUiMode.HALL_OF_FAME) { - this.hallofFameContainer.setVisible(false); - this.pageMode = RunInfoUiMode.MAIN; - } else if (this.pageMode === RunInfoUiMode.ENDING_ART) { - this.endCardContainer.setVisible(false); - this.runContainer.remove(this.endCardContainer); - this.pageMode = RunInfoUiMode.MAIN; - } - break; - case Button.DOWN: - case Button.UP: - break; - case Button.CYCLE_FORM: - case Button.CYCLE_SHINY: - case Button.CYCLE_ABILITY: - this.buttonCycleOption(button); - break; + break; + case Button.DOWN: + case Button.UP: + break; + case Button.CYCLE_FORM: + case Button.CYCLE_SHINY: + case Button.CYCLE_ABILITY: + this.buttonCycleOption(button); + break; } if (success) { @@ -865,40 +962,40 @@ export default class RunInfoUiHandler extends UiHandler { */ private buttonCycleOption(button: Button) { switch (button) { - case Button.CYCLE_FORM: - if (this.isVictory) { - if (!this.endCardContainer || !this.endCardContainer.visible) { - this.createVictorySplash(); - this.endCardContainer.setVisible(true); - this.runContainer.add(this.endCardContainer); - this.pageMode = RunInfoUiMode.ENDING_ART; - } else { - this.endCardContainer.setVisible(false); - this.runContainer.remove(this.endCardContainer); - this.pageMode = RunInfoUiMode.MAIN; + case Button.CYCLE_FORM: + if (this.isVictory && this.pageMode !== RunInfoUiMode.HALL_OF_FAME) { + if (!this.endCardContainer || !this.endCardContainer.visible) { + this.createVictorySplash(); + this.endCardContainer.setVisible(true); + this.runContainer.add(this.endCardContainer); + this.pageMode = RunInfoUiMode.ENDING_ART; + } else { + this.endCardContainer.setVisible(false); + this.runContainer.remove(this.endCardContainer); + this.pageMode = RunInfoUiMode.MAIN; + } } - } - break; - case Button.CYCLE_SHINY: - if (this.isVictory) { - if (!this.hallofFameContainer.visible) { - this.hallofFameContainer.setVisible(true); - this.pageMode = RunInfoUiMode.HALL_OF_FAME; - } else { - this.hallofFameContainer.setVisible(false); - this.pageMode = RunInfoUiMode.MAIN; + break; + case Button.CYCLE_SHINY: + if (this.isVictory && this.pageMode !== RunInfoUiMode.ENDING_ART) { + if (!this.hallofFameContainer.visible) { + this.hallofFameContainer.setVisible(true); + this.pageMode = RunInfoUiMode.HALL_OF_FAME; + } else { + this.hallofFameContainer.setVisible(false); + this.pageMode = RunInfoUiMode.MAIN; + } } - } - break; - case Button.CYCLE_ABILITY: - if (this.runInfo.modifiers.length !== 0) { - if (this.partyVisibility) { - this.showParty(false); - } else { - this.showParty(true); + break; + case Button.CYCLE_ABILITY: + if (this.runInfo.modifiers.length !== 0 && this.pageMode === RunInfoUiMode.MAIN) { + if (this.partyVisibility) { + this.showParty(false); + } else { + this.showParty(true); + } } - } - break; + break; } } } diff --git a/src/ui/save-slot-select-ui-handler.ts b/src/ui/save-slot-select-ui-handler.ts index 89b20322a68..b36c0af6ec8 100644 --- a/src/ui/save-slot-select-ui-handler.ts +++ b/src/ui/save-slot-select-ui-handler.ts @@ -10,8 +10,10 @@ import MessageUiHandler from "./message-ui-handler"; import { TextStyle, addTextObject } from "./text"; import { Mode } from "./ui"; import { addWindow } from "./ui-theme"; +import { RunDisplayMode } from "#app/ui/run-info-ui-handler"; -const sessionSlotCount = 5; +const SESSION_SLOTS_COUNT = 5; +const SLOTS_ON_SCREEN = 3; export enum SaveSlotUiMode { LOAD, @@ -33,7 +35,7 @@ export default class SaveSlotSelectUiHandler extends MessageUiHandler { private scrollCursor: integer = 0; - private cursorObj: Phaser.GameObjects.NineSlice | null; + private cursorObj: Phaser.GameObjects.Container | null; private sessionSlotsContainerInitialY: number; @@ -84,9 +86,9 @@ export default class SaveSlotSelectUiHandler extends MessageUiHandler { this.saveSlotSelectContainer.setVisible(true); this.populateSessionSlots(); + this.setScrollCursor(0); this.setCursor(0); - return true; } @@ -104,40 +106,40 @@ export default class SaveSlotSelectUiHandler extends MessageUiHandler { error = true; } else { switch (this.uiMode) { - case SaveSlotUiMode.LOAD: - this.saveSlotSelectCallback = null; - originalCallback && originalCallback(cursor); - break; - case SaveSlotUiMode.SAVE: - const saveAndCallback = () => { - const originalCallback = this.saveSlotSelectCallback; + case SaveSlotUiMode.LOAD: this.saveSlotSelectCallback = null; - ui.revertMode(); - ui.showText("", 0); - ui.setMode(Mode.MESSAGE); originalCallback && originalCallback(cursor); - }; - if (this.sessionSlots[cursor].hasData) { - ui.showText(i18next.t("saveSlotSelectUiHandler:overwriteData"), null, () => { - ui.setOverlayMode(Mode.CONFIRM, () => { - this.scene.gameData.deleteSession(cursor).then(response => { - if (response === false) { - this.scene.reset(true); - } else { - saveAndCallback(); - } - }); - }, () => { - ui.revertMode(); - ui.showText("", 0); - }, false, 0, 19, 2000); - }); - } else if (this.sessionSlots[cursor].hasData === false) { - saveAndCallback(); - } else { - return false; - } - break; + break; + case SaveSlotUiMode.SAVE: + const saveAndCallback = () => { + const originalCallback = this.saveSlotSelectCallback; + this.saveSlotSelectCallback = null; + ui.revertMode(); + ui.showText("", 0); + ui.setMode(Mode.MESSAGE); + originalCallback && originalCallback(cursor); + }; + if (this.sessionSlots[cursor].hasData) { + ui.showText(i18next.t("saveSlotSelectUiHandler:overwriteData"), null, () => { + ui.setOverlayMode(Mode.CONFIRM, () => { + this.scene.gameData.deleteSession(cursor).then(response => { + if (response === false) { + this.scene.reset(true); + } else { + saveAndCallback(); + } + }); + }, () => { + ui.revertMode(); + ui.showText("", 0); + }, false, 0, 19, import.meta.env.DEV ? 300 : 2000); + }); + } else if (this.sessionSlots[cursor].hasData === false) { + saveAndCallback(); + } else { + return false; + } + break; } success = true; } @@ -147,21 +149,28 @@ export default class SaveSlotSelectUiHandler extends MessageUiHandler { success = true; } } else { + const cursorPosition = this.cursor + this.scrollCursor; switch (button) { - case Button.UP: - if (this.cursor) { - success = this.setCursor(this.cursor - 1); - } else if (this.scrollCursor) { - success = this.setScrollCursor(this.scrollCursor - 1); - } - break; - case Button.DOWN: - if (this.cursor < 2) { - success = this.setCursor(this.cursor + 1); - } else if (this.scrollCursor < sessionSlotCount - 3) { - success = this.setScrollCursor(this.scrollCursor + 1); - } - break; + case Button.UP: + if (this.cursor) { + // Check to prevent cursor from accessing a negative index + success = (this.cursor === 0) ? this.setCursor(this.cursor) : this.setCursor(this.cursor - 1, cursorPosition); + } else if (this.scrollCursor) { + success = this.setScrollCursor(this.scrollCursor - 1, cursorPosition); + } + break; + case Button.DOWN: + if (this.cursor < (SLOTS_ON_SCREEN - 1)) { + success = this.setCursor(this.cursor + 1, cursorPosition); + } else if (this.scrollCursor < SESSION_SLOTS_COUNT - SLOTS_ON_SCREEN) { + success = this.setScrollCursor(this.scrollCursor + 1, cursorPosition); + } + break; + case Button.RIGHT: + if (this.sessionSlots[cursorPosition].hasData && this.sessionSlots[cursorPosition].saveData) { + this.scene.ui.setOverlayMode(Mode.RUN_INFO, this.sessionSlots[cursorPosition].saveData, RunDisplayMode.SESSION_PREVIEW); + success = true; + } } } @@ -175,12 +184,18 @@ export default class SaveSlotSelectUiHandler extends MessageUiHandler { } populateSessionSlots() { - for (let s = 0; s < sessionSlotCount; s++) { + for (let s = 0; s < SESSION_SLOTS_COUNT; s++) { const sessionSlot = new SessionSlot(this.scene, s); - sessionSlot.load(); this.scene.add.existing(sessionSlot); this.sessionSlotsContainer.add(sessionSlot); this.sessionSlots.push(sessionSlot); + sessionSlot.load().then((success) => { + // If the cursor was moved to this slot while the session was loading + // call setCursor again to shift the slot position and show the arrow for save preview + if (success && (this.cursor + this.scrollCursor) === s) { + this.setCursor(s); + } + }); } } @@ -198,25 +213,79 @@ export default class SaveSlotSelectUiHandler extends MessageUiHandler { this.saveSlotSelectMessageBoxContainer.setVisible(!!text?.length); } - setCursor(cursor: integer): boolean { + /** + * Move the cursor to a new position and update the view accordingly + * @param cursor the new cursor position, between `0` and `SLOTS_ON_SCREEN - 1` + * @param prevSlotIndex index of the previous session occupied by the cursor, between `0` and `SESSION_SLOTS_COUNT - 1` - optional + * @returns `true` if the cursor position has changed | `false` if it has not + */ + override setCursor(cursor: integer, prevSlotIndex?: integer): boolean { const changed = super.setCursor(cursor); if (!this.cursorObj) { - this.cursorObj = this.scene.add.nineslice(0, 0, "select_cursor_highlight_thick", undefined, 296, 44, 6, 6, 6, 6); - this.cursorObj.setOrigin(0, 0); + this.cursorObj = this.scene.add.container(0, 0); + const cursorBox = this.scene.add.nineslice(0, 0, "select_cursor_highlight_thick", undefined, 296, 44, 6, 6, 6, 6); + const rightArrow = this.scene.add.image(0, 0, "cursor"); + rightArrow.setPosition(160, 0); + rightArrow.setName("rightArrow"); + this.cursorObj.add([ cursorBox, rightArrow ]); this.sessionSlotsContainer.add(this.cursorObj); } - this.cursorObj.setPosition(4, 4 + (cursor + this.scrollCursor) * 56); + const cursorPosition = cursor + this.scrollCursor; + const cursorIncrement = cursorPosition * 56; + if (this.sessionSlots[cursorPosition] && this.cursorObj) { + const hasData = this.sessionSlots[cursorPosition].hasData; + // If the session slot lacks session data, it does not move from its default, central position. + // Only session slots with session data will move leftwards and have a visible arrow. + if (!hasData) { + this.cursorObj.setPosition(151, 26 + cursorIncrement); + this.sessionSlots[cursorPosition].setPosition(0, cursorIncrement); + } else { + this.cursorObj.setPosition(145, 26 + cursorIncrement); + this.sessionSlots[cursorPosition].setPosition(-6, cursorIncrement); + } + this.setArrowVisibility(hasData); + } + if (!Utils.isNullOrUndefined(prevSlotIndex)) { + this.revertSessionSlot(prevSlotIndex); + } return changed; } - setScrollCursor(scrollCursor: integer): boolean { + /** + * Helper function that resets the given session slot to its default central position + */ + revertSessionSlot(slotIndex: integer): void { + const sessionSlot = this.sessionSlots[slotIndex]; + if (sessionSlot) { + sessionSlot.setPosition(0, slotIndex * 56); + } + } + + /** + * Helper function that checks if the session slot involved holds data or not + * @param hasData `true` if session slot contains data | 'false' if not + */ + setArrowVisibility(hasData: boolean): void { + if (this.cursorObj) { + const rightArrow = this.cursorObj?.getByName("rightArrow") as Phaser.GameObjects.Image; + rightArrow.setVisible(hasData); + } + } + + /** + * Move the scrolling cursor to a new position and update the view accordingly + * @param scrollCursor the new cursor position, between `0` and `SESSION_SLOTS_COUNT - SLOTS_ON_SCREEN` + * @param prevSlotIndex index of the previous slot occupied by the cursor, between `0` and `SESSION_SLOTS_COUNT-1` - optional + * @returns `true` if the cursor position has changed | `false` if it has not + */ + setScrollCursor(scrollCursor: integer, prevSlotIndex?: integer): boolean { const changed = scrollCursor !== this.scrollCursor; if (changed) { this.scrollCursor = scrollCursor; - this.setCursor(this.cursor); + this.setCursor(this.cursor, prevSlotIndex); this.scene.tweens.add({ targets: this.sessionSlotsContainer, y: this.sessionSlotsContainerInitialY - 56 * scrollCursor, @@ -231,6 +300,7 @@ export default class SaveSlotSelectUiHandler extends MessageUiHandler { clear() { super.clear(); this.saveSlotSelectContainer.setVisible(false); + this.setScrollCursor(0); this.eraseCursor(); this.saveSlotSelectCallback = null; this.clearSessionSlots(); @@ -254,6 +324,8 @@ class SessionSlot extends Phaser.GameObjects.Container { public hasData: boolean; private loadingLabel: Phaser.GameObjects.Text; + public saveData: SessionSaveData; + constructor(scene: BattleScene, slotId: integer) { super(scene, 0, slotId * 56); @@ -330,6 +402,10 @@ class SessionSlot extends Phaser.GameObjects.Container { load(): Promise { return new Promise(resolve => { this.scene.gameData.getSession(this.slotId).then(async sessionData => { + // Ignore the results if the view was exited + if (!this.active) { + return; + } if (!sessionData) { this.hasData = false; this.loadingLabel.setText(i18next.t("saveSlotSelectUiHandler:empty")); @@ -337,6 +413,7 @@ class SessionSlot extends Phaser.GameObjects.Container { return; } this.hasData = true; + this.saveData = sessionData; await this.setupWithData(sessionData); resolve(true); }); diff --git a/src/ui/scroll-bar.ts b/src/ui/scroll-bar.ts index e756393ae1a..9874be0f73a 100644 --- a/src/ui/scroll-bar.ts +++ b/src/ui/scroll-bar.ts @@ -1,36 +1,72 @@ +/** + * A vertical scrollbar element that resizes dynamically based on the current scrolling + * and number of elements that can be shown on screen + */ export class ScrollBar extends Phaser.GameObjects.Container { - private bg: Phaser.GameObjects.Image; + private bg: Phaser.GameObjects.NineSlice; private handleBody: Phaser.GameObjects.Rectangle; - private handleBottom: Phaser.GameObjects.Image; - private pages: number; - private page: number; + private handleBottom: Phaser.GameObjects.NineSlice; + private currentRow: number; + private totalRows: number; + private maxRows: number; - constructor(scene: Phaser.Scene, x: number, y: number, pages: number) { + /** + * @param scene the current scene + * @param x the scrollbar's x position (origin: top left) + * @param y the scrollbar's y position (origin: top left) + * @param width the scrollbar's width + * @param height the scrollbar's height + * @param maxRows the maximum number of rows that can be shown at once + */ + constructor(scene: Phaser.Scene, x: number, y: number, width: number, height: number, maxRows: number) { super(scene, x, y); - this.bg = scene.add.image(0, 0, "scroll_bar"); + this.maxRows = maxRows; + this.totalRows = maxRows; + this.currentRow = 0; + + const borderSize = 2; + width = Math.max(width, 4); + + this.bg = scene.add.nineslice(0, 0, "scroll_bar", undefined, width, height, borderSize, borderSize, borderSize, borderSize); this.bg.setOrigin(0, 0); this.add(this.bg); - this.handleBody = scene.add.rectangle(1, 1, 3, 4, 0xaaaaaa); + this.handleBody = scene.add.rectangle(1, 1, width - 2, 4, 0xaaaaaa); this.handleBody.setOrigin(0, 0); this.add(this.handleBody); - this.handleBottom = scene.add.image(1, 1, "scroll_bar_handle"); + this.handleBottom = scene.add.nineslice(1, 1, "scroll_bar_handle", undefined, width - 2, 2, 2, 0, 0, 0); this.handleBottom.setOrigin(0, 0); this.add(this.handleBottom); } - setPage(page: number): void { - this.page = page; - this.handleBody.y = 1 + (this.bg.displayHeight - 1 - this.handleBottom.displayHeight) / this.pages * page; + /** + * Set the current row that is displayed + * Moves the bar handle up or down accordingly + * @param scrollCursor how many times the view was scrolled down + */ + setScrollCursor(scrollCursor: number): void { + this.currentRow = scrollCursor; + this.updateHandlePosition(); + } + + /** + * Set the total number of rows to display + * If it's smaller than the maximum number of rows on screen the bar will get hidden + * Otherwise the scrollbar handle gets resized based on the ratio to the maximum number of rows + * @param rows how many rows of data there are in total + */ + setTotalRows(rows: number): void { + this.totalRows = rows; + this.handleBody.height = (this.bg.displayHeight - 1 - this.handleBottom.displayHeight) * this.maxRows / this.totalRows; + this.updateHandlePosition(); + + this.setVisible(this.totalRows > this.maxRows); + } + + private updateHandlePosition(): void { + this.handleBody.y = 1 + (this.bg.displayHeight - 1 - this.handleBottom.displayHeight) / this.totalRows * this.currentRow; this.handleBottom.y = this.handleBody.y + this.handleBody.displayHeight; } - - setPages(pages: number): void { - this.pages = pages; - this.handleBody.height = (this.bg.displayHeight - 1 - this.handleBottom.displayHeight) * 9 / this.pages; - - this.setVisible(this.pages > 9); - } } diff --git a/src/ui/scrollable-grid-handler.ts b/src/ui/scrollable-grid-handler.ts new file mode 100644 index 00000000000..cced92a2083 --- /dev/null +++ b/src/ui/scrollable-grid-handler.ts @@ -0,0 +1,197 @@ +import { Button } from "#enums/buttons"; +import UiHandler from "#app/ui/ui-handler"; +import { ScrollBar } from "#app/ui/scroll-bar"; + +type UpdateGridCallbackFunction = () => void; +type UpdateDetailsCallbackFunction = (index: number) => void; + +/** + * A helper class to handle navigation through a grid of elements that can scroll vertically + * Needs to be used by a {@linkcode UiHandler} + * How to use: + * - in `UiHandler.setup`: Initialize with the {@linkcode UiHandler} that handles the grid, + * the number of rows and columns that can be shown at once, + * an optional {@linkcode ScrollBar}, and optional callbacks that will get called after scrolling + * - in `UiHandler.show`: Set `setTotalElements` to the total number of elements in the list to display + * - in `UiHandler.processInput`: call `processNavigationInput` to have it handle the cursor updates while calling the defined callbacks + * - in `UiHandler.clear`: call `reset` + */ +export default class ScrollableGridUiHandler { + private readonly ROWS: number; + private readonly COLUMNS: number; + private handler: UiHandler; + private totalElements: number; + private cursor: number; + private scrollCursor: number; + private scrollBar?: ScrollBar; + private updateGridCallback?: UpdateGridCallbackFunction; + private updateDetailsCallback?: UpdateDetailsCallbackFunction; + + /** + * @param scene the {@linkcode UiHandler} that needs its cursor updated based on the scrolling + * @param rows the maximum number of rows shown at once + * @param columns the maximum number of columns shown at once + * @param updateGridCallback optional function that will get called if the whole grid needs to get updated + * @param updateDetailsCallback optional function that will get called if a single element's information needs to get updated + */ + constructor(handler: UiHandler, rows: number, columns: number) { + this.handler = handler; + this.ROWS = rows; + this.COLUMNS = columns; + this.scrollCursor = 0; + this.cursor = 0; + this.totalElements = rows * columns; // default value for the number of elements + } + + /** + * Set a scrollBar to get updated with the scrolling + * @param scrollBar {@linkcode ScrollBar} + * @returns this + */ + withScrollBar(scrollBar: ScrollBar): ScrollableGridUiHandler { + this.scrollBar = scrollBar; + this.scrollBar.setTotalRows(Math.ceil(this.totalElements / this.COLUMNS)); + return this; + } + + /** + * Set function that will get called if the whole grid needs to get updated + * @param callback {@linkcode UpdateGridCallbackFunction} + * @returns this + */ + withUpdateGridCallBack(callback: UpdateGridCallbackFunction): ScrollableGridUiHandler { + this.updateGridCallback = callback; + return this; + } + + /** + * Set function that will get called if a single element in the grid needs to get updated + * @param callback {@linkcode UpdateDetailsCallbackFunction} + * @returns this + */ + withUpdateSingleElementCallback(callback: UpdateDetailsCallbackFunction): ScrollableGridUiHandler { + this.updateDetailsCallback = callback; + return this; + } + + /** + * @param totalElements the total number of elements that the grid needs to display + */ + setTotalElements(totalElements: number) { + this.totalElements = totalElements; + if (this.scrollBar) { + this.scrollBar.setTotalRows(Math.ceil(this.totalElements / this.COLUMNS)); + } + this.setScrollCursor(0); + } + + /** + * @returns how many elements are hidden due to scrolling + */ + getItemOffset(): number { + return this.scrollCursor * this.COLUMNS; + } + + /** + * Update the cursor and scrollCursor based on user input + * @param button the button that was pressed + * @returns `true` if either the cursor or scrollCursor was updated + */ + processInput(button: Button): boolean { + let success = false; + const onScreenRows = Math.min(this.ROWS, Math.ceil(this.totalElements / this.COLUMNS)); + const maxScrollCursor = Math.max(0, Math.ceil(this.totalElements / this.COLUMNS) - onScreenRows); + const currentRowIndex = Math.floor(this.cursor / this.COLUMNS); + const currentColumnIndex = this.cursor % this.COLUMNS; + const itemOffset = this.scrollCursor * this.COLUMNS; + const lastVisibleIndex = Math.min(this.totalElements - 1, this.totalElements - maxScrollCursor * this.COLUMNS - 1); + switch (button) { + case Button.UP: + if (currentRowIndex > 0) { + success = this.setCursor(this.cursor - this.COLUMNS); + } else if (this.scrollCursor > 0) { + success = this.setScrollCursor(this.scrollCursor - 1); + } else { + // wrap around to the last row + let newCursor = this.cursor + (onScreenRows - 1) * this.COLUMNS; + if (newCursor > lastVisibleIndex) { + newCursor -= this.COLUMNS; + } + success = this.setScrollCursor(maxScrollCursor, newCursor); + } + break; + case Button.DOWN: + if (currentRowIndex < onScreenRows - 1) { + // Go down one row + success = this.setCursor(Math.min(this.cursor + this.COLUMNS, this.totalElements - itemOffset - 1)); + } else if (this.scrollCursor < maxScrollCursor) { + // Scroll down one row + success = this.setScrollCursor(this.scrollCursor + 1); + } else { + // Wrap around to the top row + success = this.setScrollCursor(0, this.cursor % this.COLUMNS); + } + break; + case Button.LEFT: + if (currentColumnIndex > 0) { + success = this.setCursor(this.cursor - 1); + } else if (this.scrollCursor === maxScrollCursor && currentRowIndex === onScreenRows - 1) { + success = this.setCursor(lastVisibleIndex); + } else { + success = this.setCursor(this.cursor + this.COLUMNS - 1); + } + break; + case Button.RIGHT: + if (currentColumnIndex < this.COLUMNS - 1 && this.cursor + itemOffset < this.totalElements - 1) { + success = this.setCursor(this.cursor + 1); + } else { + success = this.setCursor(this.cursor - currentColumnIndex); + } + break; + } + return success; + } + + /** + * Reset the scrolling + */ + reset(): void { + this.setScrollCursor(0); + this.setCursor(0); + } + + private setCursor(cursor: number): boolean { + this.cursor = cursor; + return this.handler.setCursor(cursor); + } + + private setScrollCursor(scrollCursor: number, cursor?: number): boolean { + const scrollChanged = scrollCursor !== this.scrollCursor; + + // update the scrolling cursor + if (scrollChanged) { + this.scrollCursor = scrollCursor; + if (this.scrollBar) { + this.scrollBar.setScrollCursor(scrollCursor); + } + if (this.updateGridCallback) { + this.updateGridCallback(); + } + } + + let cursorChanged = false; + const newElementIndex = this.cursor + this.scrollCursor * this.COLUMNS; + if (cursor !== undefined) { + cursorChanged = this.setCursor(cursor); + } else if (newElementIndex >= this.totalElements) { + // make sure the cursor does not go past the end of the list + cursorChanged = this.setCursor(this.totalElements - this.scrollCursor * this.COLUMNS - 1); + } else if (scrollChanged && this.updateDetailsCallback) { + // scroll was changed but not the normal cursor, update the selected element + this.updateDetailsCallback(newElementIndex); + } + + return scrollChanged || cursorChanged; + } + +} diff --git a/src/ui/settings/abstract-binding-ui-handler.ts b/src/ui/settings/abstract-binding-ui-handler.ts index 5e6dd80c6d6..9ebc3c493a4 100644 --- a/src/ui/settings/abstract-binding-ui-handler.ts +++ b/src/ui/settings/abstract-binding-ui-handler.ts @@ -1,10 +1,10 @@ import UiHandler from "../ui-handler"; import BattleScene from "../../battle-scene"; -import {Mode} from "../ui"; -import {addWindow} from "../ui-theme"; -import {addTextObject, TextStyle} from "../text"; -import {Button} from "#enums/buttons"; -import {NavigationManager} from "#app/ui/settings/navigationMenu"; +import { Mode } from "../ui"; +import { addWindow } from "../ui-theme"; +import { addTextObject, TextStyle } from "../text"; +import { Button } from "#enums/buttons"; +import { NavigationManager } from "#app/ui/settings/navigationMenu"; import i18next from "i18next"; type CancelFn = (succes?: boolean) => boolean; @@ -88,7 +88,7 @@ export default abstract class AbstractBindingUiHandler extends UiHandler { this.timerText = addTextObject(this.scene, 0, 0, "(5)", TextStyle.WINDOW); this.timerText.setOrigin(0, 0); - this.timerText.setPositionRelative(this.unlockText, (this.unlockText.width/6) + 5, 0); + this.timerText.setPositionRelative(this.unlockText, (this.unlockText.width / 6) + 5, 0); this.optionSelectContainer.add(this.timerText); this.optionSelectBg = addWindow(this.scene, (this.scene.game.canvas.width / 6) - this.getWindowWidth(), -(this.scene.game.canvas.height / 6) + this.getWindowHeight() + 28, this.getWindowWidth(), this.getWindowHeight()); @@ -170,22 +170,22 @@ export default abstract class AbstractBindingUiHandler extends UiHandler { const ui = this.getUi(); let success = false; switch (button) { - case Button.LEFT: - case Button.RIGHT: + case Button.LEFT: + case Button.RIGHT: // Toggle between action and cancel options. - const cursor = this.cursor ? 0 : 1; - success = this.setCursor(cursor); - break; - case Button.ACTION: + const cursor = this.cursor ? 0 : 1; + success = this.setCursor(cursor); + break; + case Button.ACTION: // Process actions based on current cursor position. - if (this.cursor === 0) { - this.cancelFn && this.cancelFn(); - } else { - success = this.swapAction(); - NavigationManager.getInstance().updateIcons(); - this.cancelFn && this.cancelFn(success); - } - break; + if (this.cursor === 0) { + this.cancelFn && this.cancelFn(); + } else { + success = this.swapAction(); + NavigationManager.getInstance().updateIcons(); + this.cancelFn && this.cancelFn(success); + } + break; } // Plays a select sound effect if an action was successfully processed. diff --git a/src/ui/settings/abstract-control-settings-ui-handler.ts b/src/ui/settings/abstract-control-settings-ui-handler.ts index f8dab1bf7cc..69f8eb241d3 100644 --- a/src/ui/settings/abstract-control-settings-ui-handler.ts +++ b/src/ui/settings/abstract-control-settings-ui-handler.ts @@ -1,11 +1,12 @@ -import UiHandler from "../ui-handler"; -import BattleScene from "../../battle-scene"; -import {Mode} from "../ui"; -import {InterfaceConfig} from "../../inputs-controller"; -import {addWindow} from "../ui-theme"; -import {addTextObject, TextStyle} from "../text"; -import {getIconWithSettingName} from "#app/configs/inputs/configHandler"; -import NavigationMenu, {NavigationManager} from "#app/ui/settings/navigationMenu"; +import UiHandler from "#app/ui/ui-handler"; +import BattleScene from "#app/battle-scene"; +import { Mode } from "#app/ui/ui"; +import { InterfaceConfig } from "#app/inputs-controller"; +import { addWindow } from "#app/ui/ui-theme"; +import { addTextObject, TextStyle } from "#app/ui/text"; +import { ScrollBar } from "#app/ui/scroll-bar"; +import { getIconWithSettingName } from "#app/configs/inputs/configHandler"; +import NavigationMenu, { NavigationManager } from "#app/ui/settings/navigationMenu"; import { Device } from "#enums/devices"; import { Button } from "#enums/buttons"; import i18next from "i18next"; @@ -19,7 +20,7 @@ export interface LayoutConfig { inputsIcons: InputsIcons; settingLabels: Phaser.GameObjects.Text[]; optionValueLabels: Phaser.GameObjects.Text[][]; - optionCursors: integer[]; + optionCursors: number[]; keys: string[]; bindingSettings: Array; } @@ -31,8 +32,9 @@ export default abstract class AbstractControlSettingsUiHandler extends UiHandler protected optionsContainer: Phaser.GameObjects.Container; protected navigationContainer: NavigationMenu; - protected scrollCursor: integer; - protected optionCursors: integer[]; + protected scrollBar: ScrollBar; + protected scrollCursor: number; + protected optionCursors: number[]; protected cursorObj: Phaser.GameObjects.NineSlice | null; protected optionsBg: Phaser.GameObjects.NineSlice; @@ -65,7 +67,7 @@ export default abstract class AbstractControlSettingsUiHandler extends UiHandler protected device: Device; abstract saveSettingToLocalStorage(setting, cursor): void; - abstract setSetting(scene: BattleScene, setting, value: integer): boolean; + abstract setSetting(scene: BattleScene, setting, value: number): boolean; /** * Constructor for the AbstractSettingsUiHandler. @@ -118,7 +120,7 @@ export default abstract class AbstractControlSettingsUiHandler extends UiHandler const actionText = addTextObject(this.scene, 0, 0, i18next.t("settings:action"), TextStyle.SETTINGS_LABEL); actionText.setOrigin(0, 0.15); - actionText.setPositionRelative(iconAction, -actionText.width/6-2, 0); + actionText.setPositionRelative(iconAction, -actionText.width / 6 - 2, 0); const iconCancel = this.scene.add.sprite(0, 0, "keyboard"); iconCancel.setOrigin(0, -0.1); @@ -127,7 +129,7 @@ export default abstract class AbstractControlSettingsUiHandler extends UiHandler const cancelText = addTextObject(this.scene, 0, 0, i18next.t("settings:back"), TextStyle.SETTINGS_LABEL); cancelText.setOrigin(0, 0.15); - cancelText.setPositionRelative(iconCancel, -cancelText.width/6-2, 0); + cancelText.setPositionRelative(iconCancel, -cancelText.width / 6 - 2, 0); const iconReset = this.scene.add.sprite(0, 0, "keyboard"); iconReset.setOrigin(0, -0.1); @@ -136,7 +138,7 @@ export default abstract class AbstractControlSettingsUiHandler extends UiHandler const resetText = addTextObject(this.scene, 0, 0, i18next.t("settings:reset"), TextStyle.SETTINGS_LABEL); resetText.setOrigin(0, 0.15); - resetText.setPositionRelative(iconReset, -resetText.width/6-2, 0); + resetText.setPositionRelative(iconReset, -resetText.width / 6 - 2, 0); this.settingsContainer.add(this.optionsBg); this.settingsContainer.add(this.actionsBg); @@ -172,7 +174,7 @@ export default abstract class AbstractControlSettingsUiHandler extends UiHandler // Fetch common setting keys such as 'Controller' and 'Gamepad Support' from gamepad settings. const commonSettingKeys = Object.keys(this.setting).slice(0, this.commonSettingsCount).map(key => this.setting[key]); // Combine common and specific bindings into a single array. - const specificBindingKeys = [...commonSettingKeys, ...Object.keys(config.settings)]; + const specificBindingKeys = [ ...commonSettingKeys, ...Object.keys(config.settings) ]; // Fetch default values for these settings and prepare to highlight selected options. const optionCursors = Object.values(Object.keys(this.settingDeviceDefaults).filter(s => specificBindingKeys.includes(s)).map(k => this.settingDeviceDefaults[k])); // Filter out settings that are not relevant to the current gamepad configuration. @@ -201,7 +203,7 @@ export default abstract class AbstractControlSettingsUiHandler extends UiHandler const valueLabels: Phaser.GameObjects.GameObject[] = []; // Process each option for the current setting. - for (const [o, option] of this.settingDeviceOptions[this.setting[setting]].entries()) { + for (const [ o, option ] of this.settingDeviceOptions[this.setting[setting]].entries()) { // Check if the current setting is for binding keys. if (bindingSettings.includes(this.setting[setting])) { // Create a label for non-null options, typically indicating actionable options like 'change'. @@ -241,7 +243,7 @@ export default abstract class AbstractControlSettingsUiHandler extends UiHandler // Calculate the total available space for placing option labels next to their setting label // We reserve space for the setting label and then distribute the remaining space evenly - const totalSpace = (300 - labelWidth) - totalWidth / 6; + const totalSpace = (297 - labelWidth) - totalWidth / 6; // Calculate the spacing between options based on the available space divided by the number of gaps between labels const optionSpacing = Math.floor(totalSpace / (optionValueLabels[s].length - 1)); @@ -269,6 +271,11 @@ export default abstract class AbstractControlSettingsUiHandler extends UiHandler // Add the options container to the overall settings container to be displayed in the UI. this.settingsContainer.add(optionsContainer); } + + // Add vertical scrollbar + this.scrollBar = new ScrollBar(this.scene, this.optionsBg.width - 9, this.optionsBg.y + 5, 4, this.optionsBg.height - 11, this.rowsToDisplay); + this.settingsContainer.add(this.scrollBar); + // Add the settings container to the UI. ui.add(this.settingsContainer); @@ -413,6 +420,8 @@ export default abstract class AbstractControlSettingsUiHandler extends UiHandler this.optionCursors = layout.optionCursors; this.inputsIcons = layout.inputsIcons; this.bindingSettings = layout.bindingSettings; + this.scrollBar.setTotalRows(layout.settingLabels.length); + this.scrollBar.setScrollCursor(0); // Return true indicating the layout was successfully applied. return true; @@ -440,78 +449,78 @@ export default abstract class AbstractControlSettingsUiHandler extends UiHandler const cursor = this.cursor + this.scrollCursor; // Calculate the absolute cursor position. const setting = this.setting[Object.keys(this.setting)[cursor]]; switch (button) { - case Button.ACTION: - if (!this.optionCursors || !this.optionValueLabels) { - return false; // TODO: is false correct as default? (previously was `undefined`) - } - if (this.settingBlacklisted.includes(setting) || !setting.includes("BUTTON_")) { - success = false; - } else { - success = this.setSetting(this.scene, setting, 1); - } - break; - case Button.UP: // Move up in the menu. - if (!this.optionValueLabels) { - return false; - } - if (cursor) { // If not at the top, move the cursor up. - if (this.cursor) { - success = this.setCursor(this.cursor - 1); - } else {// If at the top of the visible items, scroll up. - success = this.setScrollCursor(this.scrollCursor - 1); + case Button.ACTION: + if (!this.optionCursors || !this.optionValueLabels) { + return false; // TODO: is false correct as default? (previously was `undefined`) } - } else { + if (this.settingBlacklisted.includes(setting) || !setting.includes("BUTTON_")) { + success = false; + } else { + success = this.setSetting(this.scene, setting, 1); + } + break; + case Button.UP: // Move up in the menu. + if (!this.optionValueLabels) { + return false; + } + if (cursor) { // If not at the top, move the cursor up. + if (this.cursor) { + success = this.setCursor(this.cursor - 1); + } else {// If at the top of the visible items, scroll up. + success = this.setScrollCursor(this.scrollCursor - 1); + } + } else { // When at the top of the menu and pressing UP, move to the bottommost item. // First, set the cursor to the last visible element, preparing for the scroll to the end. - const successA = this.setCursor(this.rowsToDisplay - 1); - // Then, adjust the scroll to display the bottommost elements of the menu. - const successB = this.setScrollCursor(this.optionValueLabels.length - this.rowsToDisplay); - success = successA && successB; // success is just there to play the little validation sound effect - } - break; - case Button.DOWN: // Move down in the menu. - if (!this.optionValueLabels) { - return false; - } - if (cursor < this.optionValueLabels.length - 1) { - if (this.cursor < this.rowsToDisplay - 1) { - success = this.setCursor(this.cursor + 1); - } else if (this.scrollCursor < this.optionValueLabels.length - this.rowsToDisplay) { - success = this.setScrollCursor(this.scrollCursor + 1); + const successA = this.setCursor(this.rowsToDisplay - 1); + // Then, adjust the scroll to display the bottommost elements of the menu. + const successB = this.setScrollCursor(this.optionValueLabels.length - this.rowsToDisplay); + success = successA && successB; // success is just there to play the little validation sound effect } - } else { + break; + case Button.DOWN: // Move down in the menu. + if (!this.optionValueLabels) { + return false; + } + if (cursor < this.optionValueLabels.length - 1) { + if (this.cursor < this.rowsToDisplay - 1) { + success = this.setCursor(this.cursor + 1); + } else if (this.scrollCursor < this.optionValueLabels.length - this.rowsToDisplay) { + success = this.setScrollCursor(this.scrollCursor + 1); + } + } else { // When at the bottom of the menu and pressing DOWN, move to the topmost item. // First, set the cursor to the first visible element, resetting the scroll to the top. - const successA = this.setCursor(0); - // Then, reset the scroll to start from the first element of the menu. - const successB = this.setScrollCursor(0); - success = successA && successB; // Indicates a successful cursor and scroll adjustment. - } - break; - case Button.LEFT: // Move selection left within the current option set. - if (!this.optionCursors || !this.optionValueLabels) { - return false; // TODO: is false correct as default? (previously was `undefined`) - } - if (this.settingBlacklisted.includes(setting) || setting.includes("BUTTON_")) { - success = false; - } else if (this.optionCursors[cursor]) { - success = this.setOptionCursor(cursor, this.optionCursors[cursor] - 1, true); - } - break; - case Button.RIGHT: // Move selection right within the current option set. - if (!this.optionCursors || !this.optionValueLabels) { - return false; // TODO: is false correct as default? (previously was `undefined`) - } - if (this.settingBlacklisted.includes(setting) || setting.includes("BUTTON_")) { - success = false; - } else if (this.optionCursors[cursor] < this.optionValueLabels[cursor].length - 1) { - success = this.setOptionCursor(cursor, this.optionCursors[cursor] + 1, true); - } - break; - case Button.CYCLE_FORM: - case Button.CYCLE_SHINY: - success = this.navigationContainer.navigate(button); - break; + const successA = this.setCursor(0); + // Then, reset the scroll to start from the first element of the menu. + const successB = this.setScrollCursor(0); + success = successA && successB; // Indicates a successful cursor and scroll adjustment. + } + break; + case Button.LEFT: // Move selection left within the current option set. + if (!this.optionCursors || !this.optionValueLabels) { + return false; // TODO: is false correct as default? (previously was `undefined`) + } + if (this.settingBlacklisted.includes(setting) || setting.includes("BUTTON_")) { + success = false; + } else if (this.optionCursors[cursor]) { + success = this.setOptionCursor(cursor, this.optionCursors[cursor] - 1, true); + } + break; + case Button.RIGHT: // Move selection right within the current option set. + if (!this.optionCursors || !this.optionValueLabels) { + return false; // TODO: is false correct as default? (previously was `undefined`) + } + if (this.settingBlacklisted.includes(setting) || setting.includes("BUTTON_")) { + success = false; + } else if (this.optionCursors[cursor] < this.optionValueLabels[cursor].length - 1) { + success = this.setOptionCursor(cursor, this.optionCursors[cursor] + 1, true); + } + break; + case Button.CYCLE_FORM: + case Button.CYCLE_SHINY: + success = this.navigationContainer.navigate(button); + break; } } @@ -538,7 +547,7 @@ export default abstract class AbstractControlSettingsUiHandler extends UiHandler * @param cursor - The cursor position to set. * @returns `true` if the cursor was set successfully. */ - setCursor(cursor: integer): boolean { + setCursor(cursor: number): boolean { const ret = super.setCursor(cursor); // If the optionsContainer is not initialized, return the result from the parent class directly. if (!this.optionsContainer) { @@ -547,7 +556,8 @@ export default abstract class AbstractControlSettingsUiHandler extends UiHandler // Check if the cursor object exists, if not, create it. if (!this.cursorObj) { - this.cursorObj = this.scene.add.nineslice(0, 0, "summary_moves_cursor", undefined, (this.scene.game.canvas.width / 6) - 10, 16, 1, 1, 1, 1); + const cursorWidth = (this.scene.game.canvas.width / 6) - (this.scrollBar.visible ? 16 : 10); + this.cursorObj = this.scene.add.nineslice(0, 0, "summary_moves_cursor", undefined, cursorWidth, 16, 1, 1, 1, 1); this.cursorObj.setOrigin(0, 0); // Set the origin to the top-left corner. this.optionsContainer.add(this.cursorObj); // Add the cursor to the options container. } @@ -564,7 +574,7 @@ export default abstract class AbstractControlSettingsUiHandler extends UiHandler * @param scrollCursor - The scroll cursor position to set. * @returns `true` if the scroll cursor was set successfully. */ - setScrollCursor(scrollCursor: integer): boolean { + setScrollCursor(scrollCursor: number): boolean { // Check if the new scroll position is the same as the current one; if so, do not update. if (scrollCursor === this.scrollCursor) { return false; @@ -572,6 +582,7 @@ export default abstract class AbstractControlSettingsUiHandler extends UiHandler // Update the internal scroll cursor state this.scrollCursor = scrollCursor; + this.scrollBar.setScrollCursor(this.scrollCursor); // Apply the new scroll position to the settings UI. this.updateSettingsScroll(); @@ -590,7 +601,7 @@ export default abstract class AbstractControlSettingsUiHandler extends UiHandler * @param save - Whether to save the setting to local storage. * @returns `true` if the option cursor was set successfully. */ - setOptionCursor(settingIndex: integer, cursor: integer, save?: boolean): boolean { + setOptionCursor(settingIndex: number, cursor: number, save?: boolean): boolean { // Retrieve the specific setting using the settingIndex from the settingDevice enumeration. const setting = this.setting[Object.keys(this.setting)[settingIndex]]; diff --git a/src/ui/settings/abstract-settings-ui-handler.ts b/src/ui/settings/abstract-settings-ui-handler.ts index 570377eab43..83219e1ef5a 100644 --- a/src/ui/settings/abstract-settings-ui-handler.ts +++ b/src/ui/settings/abstract-settings-ui-handler.ts @@ -1,12 +1,13 @@ -import BattleScene from "../../battle-scene"; -import { hasTouchscreen, isMobile } from "../../touch-controls"; -import { TextStyle, addTextObject } from "../text"; -import { Mode } from "../ui"; -import UiHandler from "../ui-handler"; -import { addWindow } from "../ui-theme"; -import {Button} from "#enums/buttons"; -import {InputsIcons} from "#app/ui/settings/abstract-control-settings-ui-handler"; -import NavigationMenu, {NavigationManager} from "#app/ui/settings/navigationMenu"; +import BattleScene from "#app/battle-scene"; +import { hasTouchscreen, isMobile } from "#app/touch-controls"; +import { TextStyle, addTextObject } from "#app/ui/text"; +import { Mode } from "#app/ui/ui"; +import UiHandler from "#app/ui/ui-handler"; +import { addWindow } from "#app/ui/ui-theme"; +import { ScrollBar } from "#app/ui/scroll-bar"; +import { Button } from "#enums/buttons"; +import { InputsIcons } from "#app/ui/settings/abstract-control-settings-ui-handler"; +import NavigationMenu, { NavigationManager } from "#app/ui/settings/navigationMenu"; import { Setting, SettingKeys, SettingType } from "#app/system/settings/settings"; import i18next from "i18next"; @@ -19,11 +20,12 @@ export default class AbstractSettingsUiHandler extends UiHandler { private optionsContainer: Phaser.GameObjects.Container; private navigationContainer: NavigationMenu; - private scrollCursor: integer; + private scrollCursor: number; + private scrollBar: ScrollBar; private optionsBg: Phaser.GameObjects.NineSlice; - private optionCursors: integer[]; + private optionCursors: number[]; private settingLabels: Phaser.GameObjects.Text[]; private optionValueLabels: Phaser.GameObjects.Text[][]; @@ -75,7 +77,7 @@ export default class AbstractSettingsUiHandler extends UiHandler { const actionText = addTextObject(this.scene, 0, 0, i18next.t("settings:action"), TextStyle.SETTINGS_LABEL); actionText.setOrigin(0, 0.15); - actionText.setPositionRelative(iconAction, -actionText.width/6-2, 0); + actionText.setPositionRelative(iconAction, -actionText.width / 6 - 2, 0); const iconCancel = this.scene.add.sprite(0, 0, "keyboard"); iconCancel.setOrigin(0, -0.1); @@ -84,7 +86,7 @@ export default class AbstractSettingsUiHandler extends UiHandler { const cancelText = addTextObject(this.scene, 0, 0, i18next.t("settings:back"), TextStyle.SETTINGS_LABEL); cancelText.setOrigin(0, 0.15); - cancelText.setPositionRelative(iconCancel, -cancelText.width/6-2, 0); + cancelText.setPositionRelative(iconCancel, -cancelText.width / 6 - 2, 0); this.optionsContainer = this.scene.add.container(0, 0); @@ -117,7 +119,7 @@ export default class AbstractSettingsUiHandler extends UiHandler { const labelWidth = Math.max(78, this.settingLabels[s].displayWidth + 8); - const totalSpace = (300 - labelWidth) - totalWidth / 6; + const totalSpace = (297 - labelWidth) - totalWidth / 6; const optionSpacing = Math.floor(totalSpace / (this.optionValueLabels[s].length - 1)); let xOffset = 0; @@ -130,7 +132,11 @@ export default class AbstractSettingsUiHandler extends UiHandler { this.optionCursors = this.settings.map(setting => setting.default); + this.scrollBar = new ScrollBar(this.scene, this.optionsBg.width - 9, this.optionsBg.y + 5, 4, this.optionsBg.height - 11, this.rowsToDisplay); + this.scrollBar.setTotalRows(this.settings.length); + this.settingsContainer.add(this.optionsBg); + this.settingsContainer.add(this.scrollBar); this.settingsContainer.add(this.navigationContainer); this.settingsContainer.add(actionsBg); this.settingsContainer.add(this.optionsContainer); @@ -186,6 +192,7 @@ export default class AbstractSettingsUiHandler extends UiHandler { this.settingsContainer.setVisible(true); this.setCursor(0); + this.setScrollCursor(0); this.getUi().moveTo(this.settingsContainer, this.getUi().length - 1); @@ -217,59 +224,59 @@ export default class AbstractSettingsUiHandler extends UiHandler { } else { const cursor = this.cursor + this.scrollCursor; switch (button) { - case Button.UP: - if (cursor) { - if (this.cursor) { - success = this.setCursor(this.cursor - 1); + case Button.UP: + if (cursor) { + if (this.cursor) { + success = this.setCursor(this.cursor - 1); + } else { + success = this.setScrollCursor(this.scrollCursor - 1); + } } else { - success = this.setScrollCursor(this.scrollCursor - 1); - } - } else { // When at the top of the menu and pressing UP, move to the bottommost item. // First, set the cursor to the last visible element, preparing for the scroll to the end. - const successA = this.setCursor(this.rowsToDisplay - 1); - // Then, adjust the scroll to display the bottommost elements of the menu. - const successB = this.setScrollCursor(this.optionValueLabels.length - this.rowsToDisplay); - success = successA && successB; // success is just there to play the little validation sound effect - } - break; - case Button.DOWN: - if (cursor < this.optionValueLabels.length - 1) { - if (this.cursor < this.rowsToDisplay - 1) {// if the visual cursor is in the frame of 0 to 8 - success = this.setCursor(this.cursor + 1); - } else if (this.scrollCursor < this.optionValueLabels.length - this.rowsToDisplay) { - success = this.setScrollCursor(this.scrollCursor + 1); + const successA = this.setCursor(this.rowsToDisplay - 1); + // Then, adjust the scroll to display the bottommost elements of the menu. + const successB = this.setScrollCursor(this.optionValueLabels.length - this.rowsToDisplay); + success = successA && successB; // success is just there to play the little validation sound effect } - } else { + break; + case Button.DOWN: + if (cursor < this.optionValueLabels.length - 1) { + if (this.cursor < this.rowsToDisplay - 1) {// if the visual cursor is in the frame of 0 to 8 + success = this.setCursor(this.cursor + 1); + } else if (this.scrollCursor < this.optionValueLabels.length - this.rowsToDisplay) { + success = this.setScrollCursor(this.scrollCursor + 1); + } + } else { // When at the bottom of the menu and pressing DOWN, move to the topmost item. // First, set the cursor to the first visible element, resetting the scroll to the top. - const successA = this.setCursor(0); - // Then, reset the scroll to start from the first element of the menu. - const successB = this.setScrollCursor(0); - success = successA && successB; // Indicates a successful cursor and scroll adjustment. - } - break; - case Button.LEFT: - if (this.optionCursors[cursor]) {// Moves the option cursor left, if possible. - success = this.setOptionCursor(cursor, this.optionCursors[cursor] - 1, true); - } - break; - case Button.RIGHT: + const successA = this.setCursor(0); + // Then, reset the scroll to start from the first element of the menu. + const successB = this.setScrollCursor(0); + success = successA && successB; // Indicates a successful cursor and scroll adjustment. + } + break; + case Button.LEFT: + if (this.optionCursors[cursor]) {// Moves the option cursor left, if possible. + success = this.setOptionCursor(cursor, this.optionCursors[cursor] - 1, true); + } + break; + case Button.RIGHT: // Moves the option cursor right, if possible. - if (this.optionCursors[cursor] < this.optionValueLabels[cursor].length - 1) { - success = this.setOptionCursor(cursor, this.optionCursors[cursor] + 1, true); - } - break; - case Button.CYCLE_FORM: - case Button.CYCLE_SHINY: - success = this.navigationContainer.navigate(button); - break; - case Button.ACTION: - const setting: Setting = this.settings[cursor]; - if (setting?.activatable) { - success = this.activateSetting(setting); - } - break; + if (this.optionCursors[cursor] < this.optionValueLabels[cursor].length - 1) { + success = this.setOptionCursor(cursor, this.optionCursors[cursor] + 1, true); + } + break; + case Button.CYCLE_FORM: + case Button.CYCLE_SHINY: + success = this.navigationContainer.navigate(button); + break; + case Button.ACTION: + const setting: Setting = this.settings[cursor]; + if (setting?.activatable) { + success = this.activateSetting(setting); + } + break; } } @@ -288,9 +295,9 @@ export default class AbstractSettingsUiHandler extends UiHandler { */ activateSetting(setting: Setting): boolean { switch (setting.key) { - case SettingKeys.Move_Touch_Controls: - this.scene.inputController.moveTouchControlsHandler.enableConfigurationMode(this.getUi(), this.scene); - return true; + case SettingKeys.Move_Touch_Controls: + this.scene.inputController.moveTouchControlsHandler.enableConfigurationMode(this.getUi(), this.scene); + return true; } return false; } @@ -301,11 +308,12 @@ export default class AbstractSettingsUiHandler extends UiHandler { * @param cursor - The cursor position to set. * @returns `true` if the cursor was set successfully. */ - setCursor(cursor: integer): boolean { + setCursor(cursor: number): boolean { const ret = super.setCursor(cursor); if (!this.cursorObj) { - this.cursorObj = this.scene.add.nineslice(0, 0, "summary_moves_cursor", undefined, (this.scene.game.canvas.width / 6) - 10, 16, 1, 1, 1, 1); + const cursorWidth = (this.scene.game.canvas.width / 6) - (this.scrollBar.visible ? 16 : 10); + this.cursorObj = this.scene.add.nineslice(0, 0, "summary_moves_cursor", undefined, cursorWidth, 16, 1, 1, 1, 1); this.cursorObj.setOrigin(0, 0); this.optionsContainer.add(this.cursorObj); } @@ -323,7 +331,7 @@ export default class AbstractSettingsUiHandler extends UiHandler { * @param save - Whether to save the setting to local storage. * @returns `true` if the option cursor was set successfully. */ - setOptionCursor(settingIndex: integer, cursor: integer, save?: boolean): boolean { + setOptionCursor(settingIndex: number, cursor: number, save?: boolean): boolean { const setting = this.settings[settingIndex]; if (setting.key === SettingKeys.Touch_Controls && cursor && hasTouchscreen() && isMobile()) { @@ -359,12 +367,13 @@ export default class AbstractSettingsUiHandler extends UiHandler { * @param scrollCursor - The scroll cursor position to set. * @returns `true` if the scroll cursor was set successfully. */ - setScrollCursor(scrollCursor: integer): boolean { + setScrollCursor(scrollCursor: number): boolean { if (scrollCursor === this.scrollCursor) { return false; } this.scrollCursor = scrollCursor; + this.scrollBar.setScrollCursor(this.scrollCursor); this.updateSettingsScroll(); @@ -394,6 +403,7 @@ export default class AbstractSettingsUiHandler extends UiHandler { clear() { super.clear(); this.settingsContainer.setVisible(false); + this.setScrollCursor(0); this.eraseCursor(); this.getUi().bgmBar.toggleBgmBar(this.scene.showBgmBar); if (this.reloadRequired) { diff --git a/src/ui/settings/gamepad-binding-ui-handler.ts b/src/ui/settings/gamepad-binding-ui-handler.ts index 4e5b4576b85..e89529f6453 100644 --- a/src/ui/settings/gamepad-binding-ui-handler.ts +++ b/src/ui/settings/gamepad-binding-ui-handler.ts @@ -1,9 +1,9 @@ import BattleScene from "../../battle-scene"; import AbstractBindingUiHandler from "./abstract-binding-ui-handler"; -import {Mode} from "../ui"; -import {Device} from "#enums/devices"; -import {getIconWithSettingName, getKeyWithKeycode} from "#app/configs/inputs/configHandler"; -import {addTextObject, TextStyle} from "#app/ui/text"; +import { Mode } from "../ui"; +import { Device } from "#enums/devices"; +import { getIconWithSettingName, getKeyWithKeycode } from "#app/configs/inputs/configHandler"; +import { addTextObject, TextStyle } from "#app/ui/text"; export default class GamepadBindingUiHandler extends AbstractBindingUiHandler { @@ -46,7 +46,7 @@ export default class GamepadBindingUiHandler extends AbstractBindingUiHandler { } gamepadButtonDown(pad: Phaser.Input.Gamepad.Gamepad, button: Phaser.Input.Gamepad.Button, value: number): void { - const blacklist = [12, 13, 14, 15]; // d-pad buttons are blacklisted. + const blacklist = [ 12, 13, 14, 15 ]; // d-pad buttons are blacklisted. // Check conditions before processing the button press. if (!this.listening || pad.id.toLowerCase() !== this.getSelectedDevice() || blacklist.includes(button.index) || this.buttonPressed !== null) { return; diff --git a/src/ui/settings/keyboard-binding-ui-handler.ts b/src/ui/settings/keyboard-binding-ui-handler.ts index 043c5fba6a5..52b1a0e385f 100644 --- a/src/ui/settings/keyboard-binding-ui-handler.ts +++ b/src/ui/settings/keyboard-binding-ui-handler.ts @@ -1,9 +1,9 @@ import BattleScene from "../../battle-scene"; import AbstractBindingUiHandler from "./abstract-binding-ui-handler"; -import {Mode} from "../ui"; -import { getKeyWithKeycode} from "#app/configs/inputs/configHandler"; -import {Device} from "#enums/devices"; -import {addTextObject, TextStyle} from "#app/ui/text"; +import { Mode } from "../ui"; +import { getKeyWithKeycode } from "#app/configs/inputs/configHandler"; +import { Device } from "#enums/devices"; +import { addTextObject, TextStyle } from "#app/ui/text"; export default class KeyboardBindingUiHandler extends AbstractBindingUiHandler { diff --git a/src/ui/settings/move-touch-controls-handler.ts b/src/ui/settings/move-touch-controls-handler.ts index cff68fa523d..eda75a54a63 100644 --- a/src/ui/settings/move-touch-controls-handler.ts +++ b/src/ui/settings/move-touch-controls-handler.ts @@ -6,7 +6,6 @@ export const TOUCH_CONTROL_POSITIONS_LANDSCAPE = "touchControlPositionsLandscape export const TOUCH_CONTROL_POSITIONS_PORTRAIT = "touchControlPositionsPortrait"; - type ControlPosition = { id: string, x: number, y: number }; type ConfigurationEventListeners = { @@ -72,7 +71,7 @@ export default class MoveTouchControlsHandler { if (this.inConfigurationMode) { const orientation = document.querySelector("#touchControls #orientation"); if (orientation) { - orientation.textContent = this.isLandscapeMode? "Landscape" : "Portrait"; + orientation.textContent = this.isLandscapeMode ? "Landscape" : "Portrait"; } } const positions = this.getSavedPositionsOfCurrentOrientation() ?? []; @@ -288,7 +287,7 @@ export default class MoveTouchControlsHandler { * @returns All control groups of the touch controls. */ private getControlGroupElements(): HTMLDivElement[] { - return [...document.querySelectorAll("#touchControls .control-group")] as HTMLDivElement[]; + return [ ...document.querySelectorAll("#touchControls .control-group") ] as HTMLDivElement[]; } /** diff --git a/src/ui/settings/navigationMenu.ts b/src/ui/settings/navigationMenu.ts index 7d7761b7b69..ab86fa1569a 100644 --- a/src/ui/settings/navigationMenu.ts +++ b/src/ui/settings/navigationMenu.ts @@ -1,9 +1,9 @@ import BattleScene from "#app/battle-scene"; -import {Mode} from "#app/ui/ui"; -import {InputsIcons} from "#app/ui/settings/abstract-control-settings-ui-handler"; -import {addTextObject, setTextStyle, TextStyle} from "#app/ui/text"; -import {addWindow} from "#app/ui/ui-theme"; -import {Button} from "#enums/buttons"; +import { Mode } from "#app/ui/ui"; +import { InputsIcons } from "#app/ui/settings/abstract-control-settings-ui-handler"; +import { addTextObject, setTextStyle, TextStyle } from "#app/ui/text"; +import { addWindow } from "#app/ui/ui-theme"; +import { Button } from "#enums/buttons"; import i18next from "i18next"; const LEFT = "LEFT"; @@ -33,7 +33,7 @@ export class NavigationManager { Mode.SETTINGS_GAMEPAD, Mode.SETTINGS_KEYBOARD, ]; - this.labels = [i18next.t("settings:general"), i18next.t("settings:display"), i18next.t("settings:audio"), i18next.t("settings:gamepad"), i18next.t("settings:keyboard")]; + this.labels = [ i18next.t("settings:general"), i18next.t("settings:display"), i18next.t("settings:audio"), i18next.t("settings:gamepad"), i18next.t("settings:keyboard") ]; } public reset() { @@ -134,11 +134,11 @@ export default class NavigationMenu extends Phaser.GameObjects.Container { this.navigationIcons["BUTTON_CYCLE_SHINY"] = iconNextTab; let relative: Phaser.GameObjects.Sprite | Phaser.GameObjects.Text = iconPreviousTab; - let relativeWidth: number = iconPreviousTab.width*6; + let relativeWidth: number = iconPreviousTab.width * 6; for (const label of navigationManager.labels) { const labelText = addTextObject(this.scene, 0, 0, label, TextStyle.SETTINGS_LABEL); labelText.setOrigin(0, 0); - labelText.setPositionRelative(relative, 6 + relativeWidth/6, 0); + labelText.setPositionRelative(relative, 6 + relativeWidth / 6, 0); this.add(labelText); this.headerTitles.push(labelText); relative = labelText; @@ -158,7 +158,7 @@ export default class NavigationMenu extends Phaser.GameObjects.Container { const navigationManager = NavigationManager.getInstance(); const posSelected = navigationManager.modes.indexOf(navigationManager.selectedMode); - for (const [index, title] of this.headerTitles.entries()) { + for (const [ index, title ] of this.headerTitles.entries()) { setTextStyle(title, this.scene, index === posSelected ? TextStyle.SETTINGS_SELECTED : TextStyle.SETTINGS_LABEL); } } @@ -198,12 +198,12 @@ export default class NavigationMenu extends Phaser.GameObjects.Container { navigate(button: Button): boolean { const navigationManager = NavigationManager.getInstance(); switch (button) { - case Button.CYCLE_FORM: - navigationManager.navigate(this.scene, LEFT); - return true; - case Button.CYCLE_SHINY: - navigationManager.navigate(this.scene, RIGHT); - return true; + case Button.CYCLE_FORM: + navigationManager.navigate(this.scene, LEFT); + return true; + case Button.CYCLE_SHINY: + navigationManager.navigate(this.scene, RIGHT); + return true; } return false; } diff --git a/src/ui/settings/settings-display-ui-handler.ts b/src/ui/settings/settings-display-ui-handler.ts index 3d602c50a78..c4cbb0dfe58 100644 --- a/src/ui/settings/settings-display-ui-handler.ts +++ b/src/ui/settings/settings-display-ui-handler.ts @@ -23,79 +23,79 @@ export default class SettingsDisplayUiHandler extends AbstractSettingsUiHandler if (languageIndex >= 0) { const currentLocale = localStorage.getItem("prLang"); switch (currentLocale) { - case "en": - this.settings[languageIndex].options[0] = { - value: "English", - label: "English", - }; - break; - case "es": - this.settings[languageIndex].options[0] = { - value: "Español", - label: "Español", - }; - break; - case "it": - this.settings[languageIndex].options[0] = { - value: "Italiano", - label: "Italiano", - }; - break; - case "fr": - this.settings[languageIndex].options[0] = { - value: "Français", - label: "Français", - }; - break; - case "de": - this.settings[languageIndex].options[0] = { - value: "Deutsch", - label: "Deutsch", - }; - break; - case "pt-BR": - this.settings[languageIndex].options[0] = { - value: "Português (BR)", - label: "Português (BR)", - }; - break; - case "zh-CN": - this.settings[languageIndex].options[0] = { - value: "简体中文", - label: "简体中文", - }; - break; - case "zh-TW": - this.settings[languageIndex].options[0] = { - value: "繁體中文", - label: "繁體中文", - }; - break; - case "ko": - case "ko-KR": - this.settings[languageIndex].options[0] = { - value: "한국어", - label: "한국어", - }; - break; - case "ja": - this.settings[languageIndex].options[0] = { - value: "日本語", - label: "日本語", - }; - break; - case "ca-ES": - this.settings[languageIndex].options[0] = { - value: "Català", - label: "Català", - }; - break; - default: - this.settings[languageIndex].options[0] = { - value: "English", - label: "English", - }; - break; + case "en": + this.settings[languageIndex].options[0] = { + value: "English", + label: "English", + }; + break; + case "es-ES": + this.settings[languageIndex].options[0] = { + value: "Español (ES)", + label: "Español (ES)", + }; + break; + case "it": + this.settings[languageIndex].options[0] = { + value: "Italiano", + label: "Italiano", + }; + break; + case "fr": + this.settings[languageIndex].options[0] = { + value: "Français", + label: "Français", + }; + break; + case "de": + this.settings[languageIndex].options[0] = { + value: "Deutsch", + label: "Deutsch", + }; + break; + case "pt-BR": + this.settings[languageIndex].options[0] = { + value: "Português (BR)", + label: "Português (BR)", + }; + break; + case "zh-CN": + this.settings[languageIndex].options[0] = { + value: "简体中文", + label: "简体中文", + }; + break; + case "zh-TW": + this.settings[languageIndex].options[0] = { + value: "繁體中文", + label: "繁體中文", + }; + break; + case "ko": + case "ko-KR": + this.settings[languageIndex].options[0] = { + value: "한국어", + label: "한국어", + }; + break; + case "ja": + this.settings[languageIndex].options[0] = { + value: "日本語", + label: "日本語", + }; + break; + case "ca-ES": + this.settings[languageIndex].options[0] = { + value: "Català", + label: "Català", + }; + break; + default: + this.settings[languageIndex].options[0] = { + value: "English", + label: "English", + }; + break; } } diff --git a/src/ui/settings/settings-gamepad-ui-handler.ts b/src/ui/settings/settings-gamepad-ui-handler.ts index 63a9d2ab23b..864142e055b 100644 --- a/src/ui/settings/settings-gamepad-ui-handler.ts +++ b/src/ui/settings/settings-gamepad-ui-handler.ts @@ -1,6 +1,6 @@ import BattleScene from "../../battle-scene"; -import {addTextObject, TextStyle} from "../text"; -import {Mode} from "../ui"; +import { addTextObject, TextStyle } from "../text"; +import { Mode } from "../ui"; import { setSettingGamepad, SettingGamepad, @@ -11,10 +11,10 @@ import { import pad_xbox360 from "#app/configs/inputs/pad_xbox360"; import pad_dualshock from "#app/configs/inputs/pad_dualshock"; import pad_unlicensedSNES from "#app/configs/inputs/pad_unlicensedSNES"; -import {InterfaceConfig} from "#app/inputs-controller"; +import { InterfaceConfig } from "#app/inputs-controller"; import AbstractControlSettingsUiHandler from "#app/ui/settings/abstract-control-settings-ui-handler"; -import {Device} from "#enums/devices"; -import {truncateString} from "#app/utils"; +import { Device } from "#enums/devices"; +import { truncateString } from "#app/utils"; import i18next from "i18next"; /** @@ -37,7 +37,7 @@ export default class SettingsGamepadUiHandler extends AbstractControlSettingsUiH this.setting = SettingGamepad; this.settingDeviceDefaults = settingGamepadDefaults; this.settingDeviceOptions = settingGamepadOptions; - this.configs = [pad_xbox360, pad_dualshock, pad_unlicensedSNES]; + this.configs = [ pad_xbox360, pad_dualshock, pad_unlicensedSNES ]; this.commonSettingsCount = 2; this.localStoragePropertyName = "settingsGamepad"; this.settingBlacklisted = settingGamepadBlackList; @@ -94,7 +94,7 @@ export default class SettingsGamepadUiHandler extends AbstractControlSettingsUiH this.resetScroll(); // Iterate over the keys in the settingDevice enumeration. - for (const [index, key] of Object.keys(this.setting).entries()) { + for (const [ index, key ] of Object.keys(this.setting).entries()) { const setting = this.setting[key]; // Get the actual setting value using the key. // Check if the current setting corresponds to the controller setting. diff --git a/src/ui/settings/settings-keyboard-ui-handler.ts b/src/ui/settings/settings-keyboard-ui-handler.ts index 7e020034bc6..17d91b27c57 100644 --- a/src/ui/settings/settings-keyboard-ui-handler.ts +++ b/src/ui/settings/settings-keyboard-ui-handler.ts @@ -1,5 +1,5 @@ import BattleScene from "../../battle-scene"; -import {Mode} from "../ui"; +import { Mode } from "../ui"; import cfg_keyboard_qwerty from "#app/configs/inputs/cfg_keyboard_qwerty"; import { setSettingKeyboard, @@ -8,13 +8,13 @@ import { settingKeyboardDefaults, settingKeyboardOptions } from "#app/system/settings/settings-keyboard"; -import {reverseValueToKeySetting, truncateString} from "#app/utils"; +import { reverseValueToKeySetting, truncateString } from "#app/utils"; import AbstractControlSettingsUiHandler from "#app/ui/settings/abstract-control-settings-ui-handler"; -import {InterfaceConfig} from "#app/inputs-controller"; -import {addTextObject, TextStyle} from "#app/ui/text"; -import {deleteBind} from "#app/configs/inputs/configHandler"; -import {Device} from "#enums/devices"; -import {NavigationManager} from "#app/ui/settings/navigationMenu"; +import { InterfaceConfig } from "#app/inputs-controller"; +import { addTextObject, TextStyle } from "#app/ui/text"; +import { deleteBind } from "#app/configs/inputs/configHandler"; +import { Device } from "#enums/devices"; +import { NavigationManager } from "#app/ui/settings/navigationMenu"; import i18next from "i18next"; /** @@ -35,7 +35,7 @@ export default class SettingsKeyboardUiHandler extends AbstractControlSettingsUi this.setting = SettingKeyboard; this.settingDeviceDefaults = settingKeyboardDefaults; this.settingDeviceOptions = settingKeyboardOptions; - this.configs = [cfg_keyboard_qwerty]; + this.configs = [ cfg_keyboard_qwerty ]; this.commonSettingsCount = 0; this.textureOverride = "keyboard"; this.localStoragePropertyName = "settingsKeyboard"; @@ -71,13 +71,12 @@ export default class SettingsKeyboardUiHandler extends AbstractControlSettingsUi const deleteText = addTextObject(this.scene, 0, 0, i18next.t("settings:delete"), TextStyle.SETTINGS_LABEL); deleteText.setOrigin(0, 0.15); - deleteText.setPositionRelative(iconDelete, -deleteText.width/6-2, 0); + deleteText.setPositionRelative(iconDelete, -deleteText.width / 6 - 2, 0); this.settingsContainer.add(iconDelete); this.settingsContainer.add(deleteText); - // Map the 'noKeyboard' layout options for easy access. this.layout["noKeyboard"].optionsContainer = optionsContainer; this.layout["noKeyboard"].label = label; @@ -87,7 +86,7 @@ export default class SettingsKeyboardUiHandler extends AbstractControlSettingsUi * Handle the home key press event. */ onHomeDown(): void { - if (![Mode.SETTINGS_KEYBOARD, Mode.SETTINGS_GAMEPAD].includes(this.scene.ui.getMode())) { + if (![ Mode.SETTINGS_KEYBOARD, Mode.SETTINGS_GAMEPAD ].includes(this.scene.ui.getMode())) { return; } this.scene.gameData.resetMappingToFactory(); @@ -142,7 +141,7 @@ export default class SettingsKeyboardUiHandler extends AbstractControlSettingsUi this.updateBindings(); // Iterate over the keys in the settingDevice enumeration. - for (const [index, key] of Object.keys(this.setting).entries()) { + for (const [ index, key ] of Object.keys(this.setting).entries()) { const setting = this.setting[key]; // Get the actual setting value using the key. // Check if the current setting corresponds to the layout setting. diff --git a/src/ui/starter-select-ui-handler.ts b/src/ui/starter-select-ui-handler.ts index c7f7a5ee7cf..96de77a5f0b 100644 --- a/src/ui/starter-select-ui-handler.ts +++ b/src/ui/starter-select-ui-handler.ts @@ -1,50 +1,55 @@ -import { BattleSceneEventType, CandyUpgradeNotificationChangedEvent } from "../events/battle-scene"; -import { pokemonPrevolutions } from "#app/data/pokemon-evolutions"; +import { BattleSceneEventType, CandyUpgradeNotificationChangedEvent } from "#app/events/battle-scene"; +import { pokemonPrevolutions } from "#app/data/balance/pokemon-evolutions"; import { Variant, getVariantTint, getVariantIcon } from "#app/data/variant"; import { argbFromRgba } from "@material/material-color-utilities"; import i18next from "i18next"; import BBCodeText from "phaser3-rex-plugins/plugins/bbcodetext"; -import BattleScene, { starterColors } from "../battle-scene"; -import { allAbilities } from "../data/ability"; -import { speciesEggMoves } from "../data/egg-moves"; -import { GrowthRate, getGrowthRateColor } from "../data/exp"; -import { Gender, getGenderColor, getGenderSymbol } from "../data/gender"; -import { allMoves } from "../data/move"; -import { Nature, getNatureName } from "../data/nature"; -import { pokemonFormChanges } from "../data/pokemon-forms"; -import { LevelMoves, pokemonFormLevelMoves, pokemonSpeciesLevelMoves } from "../data/pokemon-level-moves"; -import PokemonSpecies, { allSpecies, getPokemonSpeciesForm, getStarterValueFriendshipCap, speciesStarters, starterPassiveAbilities, POKERUS_STARTER_COUNT, getPokerusStarters } from "../data/pokemon-species"; -import { Type } from "../data/type"; -import { GameModes } from "../game-mode"; -import { AbilityAttr, DexAttr, DexAttrProps, DexEntry, StarterMoveset, StarterAttributes, StarterPreferences, StarterPrefs } from "../system/game-data"; -import { Tutorial, handleTutorial } from "../tutorial"; -import * as Utils from "../utils"; -import { OptionSelectItem } from "./abstact-option-select-ui-handler"; -import MessageUiHandler from "./message-ui-handler"; -import PokemonIconAnimHandler, { PokemonIconAnimMode } from "./pokemon-icon-anim-handler"; -import { StatsContainer } from "./stats-container"; -import { TextStyle, addBBCodeTextObject, addTextObject } from "./text"; -import { Mode } from "./ui"; -import { addWindow } from "./ui-theme"; +import BattleScene, { starterColors } from "#app/battle-scene"; +import { allAbilities } from "#app/data/ability"; +import { speciesEggMoves } from "#app/data/balance/egg-moves"; +import { GrowthRate, getGrowthRateColor } from "#app/data/exp"; +import { Gender, getGenderColor, getGenderSymbol } from "#app/data/gender"; +import { allMoves } from "#app/data/move"; +import { getNatureName } from "#app/data/nature"; +import { pokemonFormChanges } from "#app/data/pokemon-forms"; +import { LevelMoves, pokemonFormLevelMoves, pokemonSpeciesLevelMoves } from "#app/data/balance/pokemon-level-moves"; +import PokemonSpecies, { allSpecies, getPokemonSpeciesForm, getPokerusStarters } from "#app/data/pokemon-species"; +import { getStarterValueFriendshipCap, speciesStarterCosts, POKERUS_STARTER_COUNT } from "#app/data/balance/starters"; +import { starterPassiveAbilities } from "#app/data/balance/passives"; +import { Type } from "#enums/type"; +import { GameModes } from "#app/game-mode"; +import { AbilityAttr, DexAttr, DexAttrProps, DexEntry, StarterMoveset, StarterAttributes, StarterPreferences, StarterPrefs } from "#app/system/game-data"; +import { Tutorial, handleTutorial } from "#app/tutorial"; +import { OptionSelectItem } from "#app/ui/abstact-option-select-ui-handler"; +import MessageUiHandler from "#app/ui/message-ui-handler"; +import PokemonIconAnimHandler, { PokemonIconAnimMode } from "#app/ui/pokemon-icon-anim-handler"; +import { StatsContainer } from "#app/ui/stats-container"; +import { TextStyle, addBBCodeTextObject, addTextObject } from "#app/ui/text"; +import { Mode } from "#app/ui/ui"; +import { addWindow } from "#app/ui/ui-theme"; import { Egg } from "#app/data/egg"; import Overrides from "#app/overrides"; import { SettingKeyboard } from "#app/system/settings/settings-keyboard"; import { Passive as PassiveAttr } from "#enums/passive"; -import * as Challenge from "../data/challenge"; -import MoveInfoOverlay from "./move-info-overlay"; +import * as Challenge from "#app/data/challenge"; +import MoveInfoOverlay from "#app/ui/move-info-overlay"; import { getEggTierForSpecies } from "#app/data/egg"; import { Device } from "#enums/devices"; import { Moves } from "#enums/moves"; import { Species } from "#enums/species"; import { Button } from "#enums/buttons"; -import { EggSourceType } from "#app/enums/egg-source-types"; -import { DropDown, DropDownLabel, DropDownOption, DropDownState, DropDownType, SortCriteria } from "./dropdown"; -import { StarterContainer } from "./starter-container"; -import { DropDownColumn, FilterBar } from "./filter-bar"; -import { ScrollBar } from "./scroll-bar"; +import { EggSourceType } from "#enums/egg-source-types"; +import { DropDown, DropDownLabel, DropDownOption, DropDownState, DropDownType, SortCriteria } from "#app/ui/dropdown"; +import { StarterContainer } from "#app/ui/starter-container"; +import { DropDownColumn, FilterBar } from "#app/ui/filter-bar"; +import { ScrollBar } from "#app/ui/scroll-bar"; import { SelectChallengePhase } from "#app/phases/select-challenge-phase"; +import { EncounterPhase } from "#app/phases/encounter-phase"; import { TitlePhase } from "#app/phases/title-phase"; -import { Abilities } from "#app/enums/abilities"; +import { Abilities } from "#enums/abilities"; +import { getPassiveCandyCount, getValueReductionCandyCounts, getSameSpeciesEggCandyCounts } from "#app/data/balance/starters"; +import { BooleanHolder, capitalizeString, fixedInt, getLocalizedSpriteKey, isNullOrUndefined, NumberHolder, padInt, randIntRange, rgbHexToRgba, toReadableString } from "#app/utils"; +import type { Nature } from "#enums/nature"; export type StarterSelectCallback = (starters: Starter[]) => void; @@ -76,13 +81,13 @@ const languageSettings: { [key: string]: LanguageSetting } = { instructionTextSize: "35px", starterInfoXPos: 33, }, - "es":{ + "es-ES":{ starterInfoTextSize: "56px", instructionTextSize: "35px", }, "fr":{ starterInfoTextSize: "54px", - instructionTextSize: "35px", + instructionTextSize: "38px", }, "it":{ starterInfoTextSize: "56px", @@ -118,19 +123,6 @@ const languageSettings: { [key: string]: LanguageSetting } = { }, }; -const starterCandyCosts: { passive: integer, costReduction: [integer, integer], egg: integer }[] = [ - { passive: 40, costReduction: [25, 60], egg: 30 }, // 1 Cost - { passive: 40, costReduction: [25, 60], egg: 30 }, // 2 Cost - { passive: 35, costReduction: [20, 50], egg: 25 }, // 3 Cost - { passive: 30, costReduction: [15, 40], egg: 20 }, // 4 Cost - { passive: 25, costReduction: [12, 35], egg: 18 }, // 5 Cost - { passive: 20, costReduction: [10, 30], egg: 15 }, // 6 Cost - { passive: 15, costReduction: [8, 20], egg: 12 }, // 7 Cost - { passive: 10, costReduction: [5, 15], egg: 10 }, // 8 Cost - { passive: 10, costReduction: [5, 15], egg: 10 }, // 9 Cost - { passive: 10, costReduction: [5, 15], egg: 10 }, // 10 Cost -]; - const valueReductionMax = 2; // Position of UI elements @@ -141,18 +133,6 @@ const teamWindowY = 18; const teamWindowWidth = 34; const teamWindowHeight = 132; -function getPassiveCandyCount(baseValue: integer): integer { - return starterCandyCosts[baseValue - 1].passive; -} - -function getValueReductionCandyCounts(baseValue: integer): [integer, integer] { - return starterCandyCosts[baseValue - 1].costReduction; -} - -function getSameSpeciesEggCandyCounts(baseValue: integer): integer { - return starterCandyCosts[baseValue - 1].egg; -} - /** * Calculates the starter position for a Pokemon of a given UI index * @param index UI index to calculate the starter position of @@ -164,7 +144,7 @@ function calcStarterPosition(index: number, scrollCursor:number = 0): {x: number const x = (index % 9) * 18; const y = yOffset + (Math.floor(index / 9) - scrollCursor) * height; - return {x: x, y: y}; + return { x: x, y: y }; } /** @@ -207,7 +187,7 @@ function findClosestStarterRow(index: number, numberOfRows: number) { const currentY = calcStarterIconY(index) - 13; let smallestDistance = teamWindowHeight; let closestRowIndex = 0; - for (let i=0; i < numberOfRows; i++) { + for (let i = 0; i < numberOfRows; i++) { const distance = Math.abs(currentY - calcStarterPosition(i * 9).y); if (distance < smallestDistance) { closestRowIndex = i; @@ -217,6 +197,15 @@ function findClosestStarterRow(index: number, numberOfRows: number) { return closestRowIndex; } +interface SpeciesDetails { + shiny?: boolean, + formIndex?: integer + female?: boolean, + variant?: Variant, + abilityIndex?: integer, + natureIndex?: integer, + forSeen?: boolean, // default = false +} export default class StarterSelectUiHandler extends MessageUiHandler { private starterSelectContainer: Phaser.GameObjects.Container; @@ -253,12 +242,14 @@ export default class StarterSelectUiHandler extends MessageUiHandler { private pokemonEggMoveContainers: Phaser.GameObjects.Container[]; private pokemonEggMoveBgs: Phaser.GameObjects.NineSlice[]; private pokemonEggMoveLabels: Phaser.GameObjects.Text[]; + private pokemonCandyContainer: Phaser.GameObjects.Container; private pokemonCandyIcon: Phaser.GameObjects.Sprite; private pokemonCandyDarknessOverlay: Phaser.GameObjects.Sprite; private pokemonCandyOverlayIcon: Phaser.GameObjects.Sprite; private pokemonCandyCountText: Phaser.GameObjects.Text; private pokemonCaughtHatchedContainer: Phaser.GameObjects.Container; private pokemonCaughtCountText: Phaser.GameObjects.Text; + private pokemonFormText: Phaser.GameObjects.Text; private pokemonHatchedIcon : Phaser.GameObjects.Sprite; private pokemonHatchedCountText: Phaser.GameObjects.Text; private pokemonShinyIcon: Phaser.GameObjects.Sprite; @@ -286,7 +277,6 @@ export default class StarterSelectUiHandler extends MessageUiHandler { private starterSelectMessageBox: Phaser.GameObjects.NineSlice; private starterSelectMessageBoxContainer: Phaser.GameObjects.Container; private statsContainer: StatsContainer; - private pokemonFormText: Phaser.GameObjects.Text; private moveInfoOverlay : MoveInfoOverlay; private statsMode: boolean; @@ -318,10 +308,8 @@ export default class StarterSelectUiHandler extends MessageUiHandler { private canCycleAbility: boolean; private canCycleNature: boolean; private canCycleVariant: boolean; - private value: integer = 0; - private canAddParty: boolean; - private assetLoadCancelled: Utils.BooleanHolder | null; + private assetLoadCancelled: BooleanHolder | null; public cursorObj: Phaser.GameObjects.Image; private starterCursorObjs: Phaser.GameObjects.Image[]; private pokerusCursorObjs: Phaser.GameObjects.Image[]; @@ -329,13 +317,7 @@ export default class StarterSelectUiHandler extends MessageUiHandler { private starterIconsCursorObj: Phaser.GameObjects.Image; private valueLimitLabel: Phaser.GameObjects.Text; private startCursorObj: Phaser.GameObjects.NineSlice; - // private starterValueLabels: Phaser.GameObjects.Text[]; - // private shinyIcons: Phaser.GameObjects.Image[][]; - // private hiddenAbilityIcons: Phaser.GameObjects.Image[]; - // private classicWinIcons: Phaser.GameObjects.Image[]; - // private candyUpgradeIcon: Phaser.GameObjects.Image[]; - // private candyUpgradeOverlayIcon: Phaser.GameObjects.Image[]; - // + private iconAnimHandler: PokemonIconAnimHandler; //variables to keep track of the dynamically rendered list of instruction prompts for starter select @@ -357,8 +339,8 @@ export default class StarterSelectUiHandler extends MessageUiHandler { setup() { const ui = this.getUi(); - const currentLanguage = i18next.resolvedLanguage!; // TODO: is this bang correct? - const langSettingKey = Object.keys(languageSettings).find(lang => currentLanguage.includes(lang))!; // TODO: is this bang correct? + const currentLanguage = i18next.resolvedLanguage ?? "en"; + const langSettingKey = Object.keys(languageSettings).find(lang => currentLanguage.includes(lang)) ?? "en"; const textSettings = languageSettings[langSettingKey]; this.starterSelectContainer = this.scene.add.container(0, -this.scene.game.canvas.height / 6); @@ -379,7 +361,7 @@ export default class StarterSelectUiHandler extends MessageUiHandler { this.starterSelectContainer.add(this.shinyOverlay); const starterContainerWindow = addWindow(this.scene, speciesContainerX, filterBarHeight + 1, 175, 161); - const starterContainerBg = this.scene.add.image(speciesContainerX+1, filterBarHeight + 2, "starter_container_bg"); + const starterContainerBg = this.scene.add.image(speciesContainerX + 1, filterBarHeight + 2, "starter_container_bg"); starterContainerBg.setOrigin(0, 0); this.starterSelectContainer.add(starterContainerBg); @@ -413,7 +395,7 @@ export default class StarterSelectUiHandler extends MessageUiHandler { if (index === 0 || index === 19) { return; } - const typeSprite = this.scene.add.sprite(0, 0, Utils.getLocalizedSpriteKey("types")); + const typeSprite = this.scene.add.sprite(0, 0, getLocalizedSpriteKey("types")); typeSprite.setScale(0.5); typeSprite.setFrame(type.toLowerCase()); typeOptions.push(new DropDownOption(this.scene, index, new DropDownLabel("", typeSprite))); @@ -609,15 +591,15 @@ export default class StarterSelectUiHandler extends MessageUiHandler { this.pokemonEggMoveBgs = []; this.pokemonEggMoveLabels = []; - this.valueLimitLabel = addTextObject(this.scene, teamWindowX+17, 150, "0/10", TextStyle.TOOLTIP_CONTENT); + this.valueLimitLabel = addTextObject(this.scene, teamWindowX + 17, 150, "0/10", TextStyle.TOOLTIP_CONTENT); this.valueLimitLabel.setOrigin(0.5, 0); this.starterSelectContainer.add(this.valueLimitLabel); - const startLabel = addTextObject(this.scene, teamWindowX+17, 162, i18next.t("common:start"), TextStyle.TOOLTIP_CONTENT); + const startLabel = addTextObject(this.scene, teamWindowX + 17, 162, i18next.t("common:start"), TextStyle.TOOLTIP_CONTENT); startLabel.setOrigin(0.5, 0); this.starterSelectContainer.add(startLabel); - this.startCursorObj = this.scene.add.nineslice(teamWindowX+4, 160, "select_cursor", undefined, 26, 15, 6, 6, 6, 6); + this.startCursorObj = this.scene.add.nineslice(teamWindowX + 4, 160, "select_cursor", undefined, 26, 15, 6, 6, 6, 6); this.startCursorObj.setVisible(false); this.startCursorObj.setOrigin(0, 0); this.starterSelectContainer.add(this.startCursorObj); @@ -626,7 +608,7 @@ export default class StarterSelectUiHandler extends MessageUiHandler { const starterBoxContainer = this.scene.add.container(speciesContainerX + 6, 9); //115 - this.starterSelectScrollBar = new ScrollBar(this.scene, 161, 12, 0); + this.starterSelectScrollBar = new ScrollBar(this.scene, 161, 12, 5, starterContainerWindow.height - 6, 9); starterBoxContainer.add(this.starterSelectScrollBar); @@ -657,7 +639,7 @@ export default class StarterSelectUiHandler extends MessageUiHandler { starterBoxContainer.add(this.cursorObj); for (const species of allSpecies) { - if (!speciesStarters.hasOwnProperty(species.speciesId) || !species.isObtainable()) { + if (!speciesStarterCosts.hasOwnProperty(species.speciesId) || !species.isObtainable()) { continue; } @@ -687,12 +669,12 @@ export default class StarterSelectUiHandler extends MessageUiHandler { this.pokemonSprite.setPipeline(this.scene.spritePipeline, { tone: [ 0.0, 0.0, 0.0, 0.0 ], ignoreTimeTint: true }); this.starterSelectContainer.add(this.pokemonSprite); - this.type1Icon = this.scene.add.sprite(8, 98, Utils.getLocalizedSpriteKey("types")); + this.type1Icon = this.scene.add.sprite(8, 98, getLocalizedSpriteKey("types")); this.type1Icon.setScale(0.5); this.type1Icon.setOrigin(0, 0); this.starterSelectContainer.add(this.type1Icon); - this.type2Icon = this.scene.add.sprite(26, 98, Utils.getLocalizedSpriteKey("types")); + this.type2Icon = this.scene.add.sprite(26, 98, getLocalizedSpriteKey("types")); this.type2Icon.setScale(0.5); this.type2Icon.setOrigin(0, 0); this.starterSelectContainer.add(this.type2Icon); @@ -705,31 +687,36 @@ export default class StarterSelectUiHandler extends MessageUiHandler { this.pokemonLuckText.setOrigin(0, 0); this.starterSelectContainer.add(this.pokemonLuckText); - this.pokemonCandyIcon = this.scene.add.sprite(4.5, 18, "candy"); + // Candy icon and count + this.pokemonCandyContainer = this.scene.add.container(4.5, 18); + + this.pokemonCandyIcon = this.scene.add.sprite(0, 0, "candy"); this.pokemonCandyIcon.setScale(0.5); this.pokemonCandyIcon.setOrigin(0, 0); - this.starterSelectContainer.add(this.pokemonCandyIcon); + this.pokemonCandyContainer.add(this.pokemonCandyIcon); - this.pokemonFormText = addTextObject(this.scene, 6, 42, "Form", TextStyle.WINDOW_ALT, { fontSize: "42px" }); - this.pokemonFormText.setOrigin(0, 0); - this.starterSelectContainer.add(this.pokemonFormText); - - this.pokemonCandyOverlayIcon = this.scene.add.sprite(4.5, 18, "candy_overlay"); + this.pokemonCandyOverlayIcon = this.scene.add.sprite(0, 0, "candy_overlay"); this.pokemonCandyOverlayIcon.setScale(0.5); this.pokemonCandyOverlayIcon.setOrigin(0, 0); - this.starterSelectContainer.add(this.pokemonCandyOverlayIcon); + this.pokemonCandyContainer.add(this.pokemonCandyOverlayIcon); - this.pokemonCandyDarknessOverlay = this.scene.add.sprite(4.5, 18, "candy"); + this.pokemonCandyDarknessOverlay = this.scene.add.sprite(0, 0, "candy"); this.pokemonCandyDarknessOverlay.setScale(0.5); this.pokemonCandyDarknessOverlay.setOrigin(0, 0); this.pokemonCandyDarknessOverlay.setTint(0x000000); this.pokemonCandyDarknessOverlay.setAlpha(0.50); - this.pokemonCandyDarknessOverlay.setInteractive(new Phaser.Geom.Rectangle(0, 0, 16, 16), Phaser.Geom.Rectangle.Contains); - this.starterSelectContainer.add(this.pokemonCandyDarknessOverlay); + this.pokemonCandyContainer.add(this.pokemonCandyDarknessOverlay); - this.pokemonCandyCountText = addTextObject(this.scene, 14, 18, "x0", TextStyle.WINDOW_ALT, { fontSize: "56px" }); + this.pokemonCandyCountText = addTextObject(this.scene, 9.5, 0, "x0", TextStyle.WINDOW_ALT, { fontSize: "56px" }); this.pokemonCandyCountText.setOrigin(0, 0); - this.starterSelectContainer.add(this.pokemonCandyCountText); + this.pokemonCandyContainer.add(this.pokemonCandyCountText); + + this.pokemonCandyContainer.setInteractive(new Phaser.Geom.Rectangle(0, 0, 30, 20), Phaser.Geom.Rectangle.Contains); + this.starterSelectContainer.add(this.pokemonCandyContainer); + + this.pokemonFormText = addTextObject(this.scene, 6, 42, "Form", TextStyle.WINDOW_ALT, { fontSize: "42px" }); + this.pokemonFormText.setOrigin(0, 0); + this.starterSelectContainer.add(this.pokemonFormText); this.pokemonCaughtHatchedContainer = this.scene.add.container(2, 25); this.pokemonCaughtHatchedContainer.setScale(0.5); @@ -1117,7 +1104,7 @@ export default class StarterSelectUiHandler extends MessageUiHandler { // Get this species ID's starter data const starterData = this.scene.gameData.starterData[speciesId]; - return starterData.candyCount >= getPassiveCandyCount(speciesStarters[speciesId]) + return starterData.candyCount >= getPassiveCandyCount(speciesStarterCosts[speciesId]) && !(starterData.passiveAttr & PassiveAttr.UNLOCKED); } @@ -1130,7 +1117,7 @@ export default class StarterSelectUiHandler extends MessageUiHandler { // Get this species ID's starter data const starterData = this.scene.gameData.starterData[speciesId]; - return starterData.candyCount >= getValueReductionCandyCounts(speciesStarters[speciesId])[starterData.valueReduction] + return starterData.candyCount >= getValueReductionCandyCounts(speciesStarterCosts[speciesId])[starterData.valueReduction] && starterData.valueReduction < valueReductionMax; } @@ -1143,7 +1130,7 @@ export default class StarterSelectUiHandler extends MessageUiHandler { // Get this species ID's starter data const starterData = this.scene.gameData.starterData[speciesId]; - return starterData.candyCount >= getSameSpeciesEggCandyCounts(speciesStarters[speciesId]); + return starterData.candyCount >= getSameSpeciesEggCandyCounts(speciesStarterCosts[speciesId]); } /** @@ -1165,24 +1152,24 @@ export default class StarterSelectUiHandler extends MessageUiHandler { targets: icon, loop: -1, // Make the initial bounce a little randomly delayed - delay: Utils.randIntRange(0, 50) * 5, + delay: randIntRange(0, 50) * 5, loopDelay: 1000, tweens: [ { targets: icon, y: 2 - 5, - duration: Utils.fixedInt(125), + duration: fixedInt(125), ease: "Cubic.easeOut", yoyo: true }, { targets: icon, y: 2 - 3, - duration: Utils.fixedInt(150), + duration: fixedInt(150), ease: "Cubic.easeOut", yoyo: true } - ],}; + ], }; const isPassiveAvailable = this.isPassiveAvailable(species.speciesId); const isValueReductionAvailable = this.isValueReductionAvailable(species.speciesId); @@ -1338,109 +1325,119 @@ export default class StarterSelectUiHandler extends MessageUiHandler { } } else if (this.startCursorObj.visible) { // this checks to see if the start button is selected switch (button) { - case Button.ACTION: - if (this.tryStart(true)) { + case Button.ACTION: + if (this.tryStart(true)) { + success = true; + } else { + error = true; + } + break; + case Button.UP: + // UP from start button: go to pokemon in team if any, otherwise filter + this.startCursorObj.setVisible(false); + if (this.starterSpecies.length > 0) { + this.starterIconsCursorIndex = this.starterSpecies.length - 1; + this.moveStarterIconsCursor(this.starterIconsCursorIndex); + } else { + this.startCursorObj.setVisible(false); + this.filterBarCursor = Math.max(1, this.filterBar.numFilters - 1); + this.setFilterMode(true); + } success = true; - } else { - error = true; - } - break; - case Button.UP: - this.startCursorObj.setVisible(false); - if (this.starterSpecies.length > 0) { - this.starterIconsCursorIndex = this.starterSpecies.length - 1; - this.moveStarterIconsCursor(this.starterIconsCursorIndex); - } else { - // up from start button with no Pokemon in the team > go to filter + break; + case Button.DOWN: + // DOWN from start button: Go to filters this.startCursorObj.setVisible(false); this.filterBarCursor = Math.max(1, this.filterBar.numFilters - 1); this.setFilterMode(true); - } - success = true; - break; - case Button.DOWN: - this.startCursorObj.setVisible(false); - if (this.starterSpecies.length > 0) { - this.starterIconsCursorIndex = 0; - this.moveStarterIconsCursor(this.starterIconsCursorIndex); - } else { - // down from start button with no Pokemon in the team > go to filter - this.startCursorObj.setVisible(false); - this.filterBarCursor = Math.max(1, this.filterBar.numFilters - 1); - this.setFilterMode(true); - } - success = true; - break; - case Button.LEFT: - this.startCursorObj.setVisible(false); - this.cursorObj.setVisible(true); - success = this.setCursor(onScreenFirstIndex + (onScreenNumberOfRows-1) * 9 + 8); // set last column - success = true; - break; - case Button.RIGHT: - this.startCursorObj.setVisible(false); - this.cursorObj.setVisible(true); - success = this.setCursor(onScreenFirstIndex + (onScreenNumberOfRows-1) * 9); // set first column - success = true; - break; + success = true; + break; + case Button.LEFT: + if (numberOfStarters > 0) { + this.startCursorObj.setVisible(false); + this.cursorObj.setVisible(true); + this.setCursor(onScreenFirstIndex + (onScreenNumberOfRows - 1) * 9 + 8); // set last column + success = true; + } + break; + case Button.RIGHT: + if (numberOfStarters > 0) { + this.startCursorObj.setVisible(false); + this.cursorObj.setVisible(true); + this.setCursor(onScreenFirstIndex + (onScreenNumberOfRows - 1) * 9); // set first column + success = true; + } + break; } } else if (this.filterMode) { switch (button) { - case Button.LEFT: - if (this.filterBarCursor > 0) { - success = this.setCursor(this.filterBarCursor - 1); - } else { - success = this.setCursor(this.filterBar.numFilters - 1); - } - break; - case Button.RIGHT: - if (this.filterBarCursor < this.filterBar.numFilters - 1) { - success = this.setCursor(this.filterBarCursor + 1); - } else { - success = this.setCursor(0); - } - break; - case Button.UP: - if (this.filterBar.openDropDown) { - success = this.filterBar.decDropDownCursor(); - // else if there is filtered starters - } else if (numberOfStarters > 0) { - // UP from filter bar to bottom of Pokemon list - this.setFilterMode(false); - this.scrollCursor = Math.max(0, numOfRows - 9); - this.updateScroll(); - const proportion = (this.filterBarCursor + 0.5) / this.filterBar.numFilters; - const targetCol = Math.min(8, Math.floor(proportion * 11)); - if (numberOfStarters % 9 > targetCol) { - this.setCursor(numberOfStarters - (numberOfStarters) % 9 + targetCol); + case Button.LEFT: + if (this.filterBarCursor > 0) { + success = this.setCursor(this.filterBarCursor - 1); } else { - this.setCursor(Math.max(numberOfStarters - (numberOfStarters) % 9 + targetCol - 9, 0)); + success = this.setCursor(this.filterBar.numFilters - 1); + } + break; + case Button.RIGHT: + if (this.filterBarCursor < this.filterBar.numFilters - 1) { + success = this.setCursor(this.filterBarCursor + 1); + } else { + success = this.setCursor(0); + } + break; + case Button.UP: + if (this.filterBar.openDropDown) { + success = this.filterBar.decDropDownCursor(); + } else if (this.filterBarCursor === this.filterBar.numFilters - 1 && this.starterSpecies.length > 0) { + // UP from the last filter, move to start button + this.setFilterMode(false); + this.cursorObj.setVisible(false); + this.startCursorObj.setVisible(true); + success = true; + } else if (numberOfStarters > 0) { + // UP from filter bar to bottom of Pokemon list + this.setFilterMode(false); + this.scrollCursor = Math.max(0, numOfRows - 9); + this.updateScroll(); + const proportion = (this.filterBarCursor + 0.5) / this.filterBar.numFilters; + const targetCol = Math.min(8, Math.floor(proportion * 11)); + if (numberOfStarters % 9 > targetCol) { + this.setCursor(numberOfStarters - (numberOfStarters) % 9 + targetCol); + } else { + this.setCursor(Math.max(numberOfStarters - (numberOfStarters) % 9 + targetCol - 9, 0)); + } + success = true; + } + break; + case Button.DOWN: + if (this.filterBar.openDropDown) { + success = this.filterBar.incDropDownCursor(); + } else if (this.filterBarCursor === this.filterBar.numFilters - 1 && this.starterSpecies.length > 0) { + // DOWN from the last filter, move to Pokemon in party if any + this.setFilterMode(false); + this.cursorObj.setVisible(false); + this.starterIconsCursorIndex = 0; + this.moveStarterIconsCursor(this.starterIconsCursorIndex); + success = true; + } else if (numberOfStarters > 0) { + // DOWN from filter bar to top of Pokemon list + this.setFilterMode(false); + this.scrollCursor = 0; + this.updateScroll(); + const proportion = this.filterBarCursor / Math.max(1, this.filterBar.numFilters - 1); + const targetCol = Math.min(8, Math.floor(proportion * 11)); + this.setCursor(Math.min(targetCol, numberOfStarters)); + success = true; + } + break; + case Button.ACTION: + if (!this.filterBar.openDropDown) { + this.filterBar.toggleDropDown(this.filterBarCursor); + } else { + this.filterBar.toggleOptionState(); } success = true; - } - break; - case Button.DOWN: - if (this.filterBar.openDropDown) { - success = this.filterBar.incDropDownCursor(); - } else if (numberOfStarters > 0) { - // DOWN from filter bar to top of Pokemon list - this.setFilterMode(false); - this.scrollCursor = 0; - this.updateScroll(); - const proportion = this.filterBarCursor / Math.max(1, this.filterBar.numFilters - 1); - const targetCol = Math.min(8, Math.floor(proportion * 11)); - this.setCursor(Math.min(targetCol, numberOfStarters)); - success = true; - } - break; - case Button.ACTION: - if (!this.filterBar.openDropDown) { - this.filterBar.toggleDropDown(this.filterBarCursor); - } else { - this.filterBar.toggleOptionState(); - } - success = true; - break; + break; } } else { @@ -1464,10 +1461,10 @@ export default class StarterSelectUiHandler extends MessageUiHandler { const ui = this.getUi(); let options: any[] = []; // TODO: add proper type - const [isDupe, removeIndex]: [boolean, number] = this.isInParty(this.lastSpecies); // checks to see if the pokemon is a duplicate; if it is, returns the index that will be removed + const [ isDupe, removeIndex ]: [boolean, number] = this.isInParty(this.lastSpecies); // checks to see if the pokemon is a duplicate; if it is, returns the index that will be removed const isPartyValid = this.isPartyValid(); - const isValidForChallenge = new Utils.BooleanHolder(true); + const isValidForChallenge = new BooleanHolder(true); Challenge.applyChallenges(this.scene.gameMode, Challenge.ChallengeType.STARTER_CHOICE, this.lastSpecies, isValidForChallenge, this.scene.gameData.getSpeciesDexAttrProps(this.lastSpecies, this.getCurrentDexProps(this.lastSpecies.speciesId)), isPartyValid); @@ -1618,11 +1615,11 @@ export default class StarterSelectUiHandler extends MessageUiHandler { if (!starterAttributes) { starterAttributes = this.starterPreferences[this.lastSpecies.speciesId] = {}; } - starterAttributes.nature = n as unknown as integer; + starterAttributes.nature = n; this.clearText(); ui.setMode(Mode.STARTER_SELECT); // set nature for starter - this.setSpeciesDetails(this.lastSpecies, undefined, undefined, undefined, undefined, undefined, n, undefined); + this.setSpeciesDetails(this.lastSpecies, { natureIndex: n }); this.blockInput = false; return true; } @@ -1660,7 +1657,7 @@ export default class StarterSelectUiHandler extends MessageUiHandler { handler: () => { starterData.passiveAttr |= PassiveAttr.ENABLED; ui.setMode(Mode.STARTER_SELECT); - this.setSpeciesDetails(this.lastSpecies, undefined, undefined, undefined, undefined, undefined, undefined); + this.setSpeciesDetails(this.lastSpecies); return true; } }); @@ -1670,7 +1667,7 @@ export default class StarterSelectUiHandler extends MessageUiHandler { handler: () => { starterData.passiveAttr ^= PassiveAttr.ENABLED; ui.setMode(Mode.STARTER_SELECT); - this.setSpeciesDetails(this.lastSpecies, undefined, undefined, undefined, undefined, undefined, undefined); + this.setSpeciesDetails(this.lastSpecies); return true; } }); @@ -1740,7 +1737,7 @@ export default class StarterSelectUiHandler extends MessageUiHandler { // Unlock passive option if (!(passiveAttr & PassiveAttr.UNLOCKED)) { - const passiveCost = getPassiveCandyCount(speciesStarters[this.lastSpecies.speciesId]); + const passiveCost = getPassiveCandyCount(speciesStarterCosts[this.lastSpecies.speciesId]); options.push({ label: `x${passiveCost} ${i18next.t("starterSelectUiHandler:unlockPassive")} (${allAbilities[starterPassiveAbilities[this.lastSpecies.speciesId]].name})`, handler: () => { @@ -1776,7 +1773,7 @@ export default class StarterSelectUiHandler extends MessageUiHandler { // Reduce cost option const valueReduction = starterData.valueReduction; if (valueReduction < valueReductionMax) { - const reductionCost = getValueReductionCandyCounts(speciesStarters[this.lastSpecies.speciesId])[valueReduction]; + const reductionCost = getValueReductionCandyCounts(speciesStarterCosts[this.lastSpecies.speciesId])[valueReduction]; options.push({ label: `x${reductionCost} ${i18next.t("starterSelectUiHandler:reduceCost")}`, handler: () => { @@ -1810,12 +1807,12 @@ export default class StarterSelectUiHandler extends MessageUiHandler { } // Same species egg menu option. - const sameSpeciesEggCost = getSameSpeciesEggCandyCounts(speciesStarters[this.lastSpecies.speciesId]); + const sameSpeciesEggCost = getSameSpeciesEggCandyCounts(speciesStarterCosts[this.lastSpecies.speciesId]); options.push({ label: `x${sameSpeciesEggCost} ${i18next.t("starterSelectUiHandler:sameSpeciesEgg")}`, handler: () => { if (Overrides.FREE_CANDY_UPGRADE_OVERRIDE || candyCount >= sameSpeciesEggCost) { - if (this.scene.gameData.eggs.length >= 99) { + if (this.scene.gameData.eggs.length >= 99 && !Overrides.UNLIMITED_EGG_COUNT_OVERRIDE) { // Egg list full, show error message at the top of the screen and abort this.showText(i18next.t("egg:tooManyEggs"), undefined, () => this.showText("", 0, () => this.tutorialActive = false), 2000, false, undefined, true); return false; @@ -1825,7 +1822,7 @@ export default class StarterSelectUiHandler extends MessageUiHandler { } this.pokemonCandyCountText.setText(`x${starterData.candyCount}`); - const egg = new Egg({scene: this.scene, species: this.lastSpecies.speciesId, sourceType: EggSourceType.SAME_SPECIES_EGG}); + const egg = new Egg({ scene: this.scene, species: this.lastSpecies.speciesId, sourceType: EggSourceType.SAME_SPECIES_EGG }); egg.addEggToGameData(this.scene); this.scene.gameData.saveSystem().then(success => { @@ -1885,259 +1882,259 @@ export default class StarterSelectUiHandler extends MessageUiHandler { } else { const props = this.scene.gameData.getSpeciesDexAttrProps(this.lastSpecies, this.getCurrentDexProps(this.lastSpecies.speciesId)); switch (button) { - case Button.CYCLE_SHINY: - if (this.canCycleShiny) { - starterAttributes.shiny = starterAttributes.shiny !== undefined ? !starterAttributes.shiny : false; + case Button.CYCLE_SHINY: + if (this.canCycleShiny) { + starterAttributes.shiny = starterAttributes.shiny !== undefined ? !starterAttributes.shiny : false; - if (starterAttributes.shiny) { + if (starterAttributes.shiny) { // Change to shiny, we need to get the proper default variant - const newProps = this.scene.gameData.getSpeciesDexAttrProps(this.lastSpecies, this.getCurrentDexProps(this.lastSpecies.speciesId)); - const newVariant = starterAttributes.variant ? starterAttributes.variant as Variant : newProps.variant; - this.setSpeciesDetails(this.lastSpecies, true, undefined, undefined, newVariant, undefined, undefined); + const newProps = this.scene.gameData.getSpeciesDexAttrProps(this.lastSpecies, this.getCurrentDexProps(this.lastSpecies.speciesId)); + const newVariant = starterAttributes.variant ? starterAttributes.variant as Variant : newProps.variant; + this.setSpeciesDetails(this.lastSpecies, { shiny: true, variant: newVariant }); - this.scene.playSound("se/sparkle"); - // Set the variant label to the shiny tint - const tint = getVariantTint(newVariant); - this.pokemonShinyIcon.setFrame(getVariantIcon(newVariant)); + this.scene.playSound("se/sparkle"); + // Set the variant label to the shiny tint + const tint = getVariantTint(newVariant); + this.pokemonShinyIcon.setFrame(getVariantIcon(newVariant)); + this.pokemonShinyIcon.setTint(tint); + this.pokemonShinyIcon.setVisible(true); + } else { + this.setSpeciesDetails(this.lastSpecies, { shiny: false, variant: 0 }); + this.pokemonShinyIcon.setVisible(false); + success = true; + } + } + break; + case Button.V: + if (this.canCycleVariant) { + let newVariant = props.variant; + do { + newVariant = (newVariant + 1) % 3; + if (newVariant === 0) { + if (this.speciesStarterDexEntry!.caughtAttr & DexAttr.DEFAULT_VARIANT) { // TODO: is this bang correct? + break; + } + } else if (newVariant === 1) { + if (this.speciesStarterDexEntry!.caughtAttr & DexAttr.VARIANT_2) { // TODO: is this bang correct? + break; + } + } else { + if (this.speciesStarterDexEntry!.caughtAttr & DexAttr.VARIANT_3) { // TODO: is this bang correct? + break; + } + } + } while (newVariant !== props.variant); + starterAttributes.variant = newVariant; // store the selected variant + this.setSpeciesDetails(this.lastSpecies, { variant: newVariant as Variant }); + // Cycle tint based on current sprite tint + const tint = getVariantTint(newVariant as Variant); + this.pokemonShinyIcon.setFrame(getVariantIcon(newVariant as Variant)); this.pokemonShinyIcon.setTint(tint); - this.pokemonShinyIcon.setVisible(true); - } else { - this.setSpeciesDetails(this.lastSpecies, false, undefined, undefined, 0, undefined, undefined); - this.pokemonShinyIcon.setVisible(false); success = true; } - } - break; - case Button.CYCLE_FORM: - if (this.canCycleForm) { - const formCount = this.lastSpecies.forms.length; - let newFormIndex = props.formIndex; - do { - newFormIndex = (newFormIndex + 1) % formCount; - if (this.lastSpecies.forms[newFormIndex].isStarterSelectable && this.speciesStarterDexEntry!.caughtAttr! & this.scene.gameData.getFormAttr(newFormIndex)) { // TODO: are those bangs correct? - break; - } - } while (newFormIndex !== props.formIndex); - starterAttributes.form = newFormIndex; // store the selected form - this.setSpeciesDetails(this.lastSpecies, undefined, newFormIndex, undefined, undefined, undefined, undefined); - success = true; - } - break; - case Button.CYCLE_GENDER: - if (this.canCycleGender) { - starterAttributes.female = !props.female; - this.setSpeciesDetails(this.lastSpecies, undefined, undefined, !props.female, undefined, undefined, undefined); - success = true; - } - break; - case Button.CYCLE_ABILITY: - if (this.canCycleAbility) { - const abilityCount = this.lastSpecies.getAbilityCount(); - const abilityAttr = this.scene.gameData.starterData[this.lastSpecies.speciesId].abilityAttr; - const hasAbility1 = abilityAttr & AbilityAttr.ABILITY_1; - let newAbilityIndex = this.abilityCursor; - do { - newAbilityIndex = (newAbilityIndex + 1) % abilityCount; - if (newAbilityIndex === 0) { - if (hasAbility1) { + break; + case Button.CYCLE_FORM: + if (this.canCycleForm) { + const formCount = this.lastSpecies.forms.length; + let newFormIndex = props.formIndex; + do { + newFormIndex = (newFormIndex + 1) % formCount; + if (this.lastSpecies.forms[newFormIndex].isStarterSelectable && this.speciesStarterDexEntry!.caughtAttr! & this.scene.gameData.getFormAttr(newFormIndex)) { // TODO: are those bangs correct? break; } - } else if (newAbilityIndex === 1) { + } while (newFormIndex !== props.formIndex); + starterAttributes.form = newFormIndex; // store the selected form + this.setSpeciesDetails(this.lastSpecies, { formIndex: newFormIndex }); + success = true; + } + break; + case Button.CYCLE_GENDER: + if (this.canCycleGender) { + starterAttributes.female = !props.female; + this.setSpeciesDetails(this.lastSpecies, { female: !props.female }); + success = true; + } + break; + case Button.CYCLE_ABILITY: + if (this.canCycleAbility) { + const abilityCount = this.lastSpecies.getAbilityCount(); + const abilityAttr = this.scene.gameData.starterData[this.lastSpecies.speciesId].abilityAttr; + const hasAbility1 = abilityAttr & AbilityAttr.ABILITY_1; + let newAbilityIndex = this.abilityCursor; + do { + newAbilityIndex = (newAbilityIndex + 1) % abilityCount; + if (newAbilityIndex === 0) { + if (hasAbility1) { + break; + } + } else if (newAbilityIndex === 1) { // If ability 1 and 2 are the same and ability 1 is unlocked, skip over ability 2 - if (this.lastSpecies.ability1 === this.lastSpecies.ability2 && hasAbility1) { - newAbilityIndex = (newAbilityIndex + 1) % abilityCount; - } - break; - } else { - if (abilityAttr & AbilityAttr.ABILITY_HIDDEN) { + if (this.lastSpecies.ability1 === this.lastSpecies.ability2 && hasAbility1) { + newAbilityIndex = (newAbilityIndex + 1) % abilityCount; + } break; + } else { + if (abilityAttr & AbilityAttr.ABILITY_HIDDEN) { + break; + } } - } - } while (newAbilityIndex !== this.abilityCursor); - starterAttributes.ability = newAbilityIndex; // store the selected ability + } while (newAbilityIndex !== this.abilityCursor); + starterAttributes.ability = newAbilityIndex; // store the selected ability - const { visible: tooltipVisible } = this.scene.ui.getTooltip(); + const { visible: tooltipVisible } = this.scene.ui.getTooltip(); - if (tooltipVisible && this.activeTooltip === "ABILITY") { - const newAbility = allAbilities[this.lastSpecies.getAbility(newAbilityIndex)]; - this.scene.ui.editTooltip(`${newAbility.name}`, `${newAbility.description}`); - } + if (tooltipVisible && this.activeTooltip === "ABILITY") { + const newAbility = allAbilities[this.lastSpecies.getAbility(newAbilityIndex)]; + this.scene.ui.editTooltip(`${newAbility.name}`, `${newAbility.description}`); + } - this.setSpeciesDetails(this.lastSpecies, undefined, undefined, undefined, undefined, newAbilityIndex, undefined); - success = true; - } - break; - case Button.CYCLE_NATURE: - if (this.canCycleNature) { - const natures = this.scene.gameData.getNaturesForAttr(this.speciesStarterDexEntry?.natureAttr); - const natureIndex = natures.indexOf(this.natureCursor); - const newNature = natures[natureIndex < natures.length - 1 ? natureIndex + 1 : 0]; - // store cycled nature as default - starterAttributes.nature = newNature as unknown as integer; - this.setSpeciesDetails(this.lastSpecies, undefined, undefined, undefined, undefined, undefined, newNature, undefined); - success = true; - } - break; - case Button.V: - if (this.canCycleVariant) { - let newVariant = props.variant; - do { - newVariant = (newVariant + 1) % 3; - if (!newVariant) { - if (this.speciesStarterDexEntry!.caughtAttr & DexAttr.DEFAULT_VARIANT) { // TODO: is this bang correct? - break; - } - } else if (newVariant === 1) { - if (this.speciesStarterDexEntry!.caughtAttr & DexAttr.VARIANT_2) { // TODO: is this bang correct? - break; - } - } else { - if (this.speciesStarterDexEntry!.caughtAttr & DexAttr.VARIANT_3) { // TODO: is this bang correct? - break; - } - } - } while (newVariant !== props.variant); - starterAttributes.variant = newVariant; // store the selected variant - this.setSpeciesDetails(this.lastSpecies, undefined, undefined, undefined, newVariant as Variant, undefined, undefined); - // Cycle tint based on current sprite tint - const tint = getVariantTint(newVariant as Variant); - this.pokemonShinyIcon.setFrame(getVariantIcon(newVariant as Variant)); - this.pokemonShinyIcon.setTint(tint); - success = true; - } - break; - case Button.UP: - if (!this.starterIconsCursorObj.visible) { - if (currentRow > 0) { - if (this.scrollCursor > 0 && currentRow - this.scrollCursor === 0) { - this.scrollCursor--; - this.updateScroll(); - } - success = this.setCursor(this.cursor - 9); - } else { - this.filterBarCursor = this.filterBar.getNearestFilter(this.filteredStarterContainers[this.cursor]); - this.setFilterMode(true); + this.setSpeciesDetails(this.lastSpecies, { abilityIndex: newAbilityIndex }); success = true; } - } else { - if (this.starterIconsCursorIndex === 0) { + break; + case Button.CYCLE_NATURE: + if (this.canCycleNature) { + const natures = this.scene.gameData.getNaturesForAttr(this.speciesStarterDexEntry?.natureAttr); + const natureIndex = natures.indexOf(this.natureCursor); + const newNature = natures[natureIndex < natures.length - 1 ? natureIndex + 1 : 0]; + // store cycled nature as default + starterAttributes.nature = newNature as unknown as integer; + this.setSpeciesDetails(this.lastSpecies, { natureIndex: newNature }); + success = true; + } + break; + case Button.UP: + if (!this.starterIconsCursorObj.visible) { + if (currentRow > 0) { + if (this.scrollCursor > 0 && currentRow - this.scrollCursor === 0) { + this.scrollCursor--; + this.updateScroll(); + } + success = this.setCursor(this.cursor - 9); + } else { + this.filterBarCursor = this.filterBar.getNearestFilter(this.filteredStarterContainers[this.cursor]); + this.setFilterMode(true); + success = true; + } + } else { + if (this.starterIconsCursorIndex === 0) { // Up from first Pokemon in the team > go to filter - this.starterIconsCursorObj.setVisible(false); - this.setSpecies(null); - this.filterBarCursor = Math.max(1, this.filterBar.numFilters - 1); - this.setFilterMode(true); - } else { - this.starterIconsCursorIndex--; - this.moveStarterIconsCursor(this.starterIconsCursorIndex); - } - success = true; - } - break; - case Button.DOWN: - if (!this.starterIconsCursorObj.visible) { - if (currentRow < numOfRows - 1) { // not last row - if (currentRow - this.scrollCursor === 8) { // last row of visible starters - this.scrollCursor++; + this.starterIconsCursorObj.setVisible(false); + this.setSpecies(null); + this.filterBarCursor = Math.max(1, this.filterBar.numFilters - 1); + this.setFilterMode(true); + } else { + this.starterIconsCursorIndex--; + this.moveStarterIconsCursor(this.starterIconsCursorIndex); } - success = this.setCursor(this.cursor + 9); - this.updateScroll(); - } else if (numOfRows > 1) { - // DOWN from last row of Pokemon > Wrap around to first row - this.scrollCursor = 0; - this.updateScroll(); - success = this.setCursor(this.cursor % 9); - } else { - // DOWN from single row of Pokemon > Go to filters - this.filterBarCursor = this.filterBar.getNearestFilter(this.filteredStarterContainers[this.cursor]); - this.setFilterMode(true); success = true; } - } else { - if (this.starterIconsCursorIndex <= this.starterSpecies.length - 2) { - this.starterIconsCursorIndex++; - this.moveStarterIconsCursor(this.starterIconsCursorIndex); + break; + case Button.DOWN: + if (!this.starterIconsCursorObj.visible) { + if (currentRow < numOfRows - 1) { // not last row + if (currentRow - this.scrollCursor === 8) { // last row of visible starters + this.scrollCursor++; + } + success = this.setCursor(this.cursor + 9); + this.updateScroll(); + } else if (numOfRows > 1) { + // DOWN from last row of Pokemon > Wrap around to first row + this.scrollCursor = 0; + this.updateScroll(); + success = this.setCursor(this.cursor % 9); + } else { + // DOWN from single row of Pokemon > Go to filters + this.filterBarCursor = this.filterBar.getNearestFilter(this.filteredStarterContainers[this.cursor]); + this.setFilterMode(true); + success = true; + } } else { - this.starterIconsCursorObj.setVisible(false); - this.setSpecies(null); - this.startCursorObj.setVisible(true); + if (this.starterIconsCursorIndex <= this.starterSpecies.length - 2) { + this.starterIconsCursorIndex++; + this.moveStarterIconsCursor(this.starterIconsCursorIndex); + } else { + this.starterIconsCursorObj.setVisible(false); + this.setSpecies(null); + this.startCursorObj.setVisible(true); + } + success = true; } - success = true; - } - break; - case Button.LEFT: - if (!this.starterIconsCursorObj.visible) { - if (this.cursor % 9 !== 0) { - success = this.setCursor(this.cursor - 1); - } else { + break; + case Button.LEFT: + if (!this.starterIconsCursorObj.visible) { + if (this.cursor % 9 !== 0) { + success = this.setCursor(this.cursor - 1); + } else { // LEFT from filtered Pokemon, on the left edge - if (this.starterSpecies.length === 0) { + if (this.starterSpecies.length === 0) { // no starter in team > wrap around to the last column - success = this.setCursor(this.cursor + Math.min(8, numberOfStarters - this.cursor)); + success = this.setCursor(this.cursor + Math.min(8, numberOfStarters - this.cursor)); - } else if (onScreenCurrentRow < 7) { + } else if (onScreenCurrentRow < 7) { // at least one pokemon in team > for the first 7 rows, go to closest starter - this.cursorObj.setVisible(false); - this.starterIconsCursorIndex = findClosestStarterIndex(this.cursorObj.y - 1, this.starterSpecies.length); - this.moveStarterIconsCursor(this.starterIconsCursorIndex); + this.cursorObj.setVisible(false); + this.starterIconsCursorIndex = findClosestStarterIndex(this.cursorObj.y - 1, this.starterSpecies.length); + this.moveStarterIconsCursor(this.starterIconsCursorIndex); - } else { + } else { // at least one pokemon in team > from the bottom 2 rows, go to start run button - this.cursorObj.setVisible(false); - this.setSpecies(null); - this.startCursorObj.setVisible(true); + this.cursorObj.setVisible(false); + this.setSpecies(null); + this.startCursorObj.setVisible(true); + } + success = true; } - success = true; - } - } else if (numberOfStarters > 0) { + } else if (numberOfStarters > 0) { // LEFT from team > Go to closest filtered Pokemon - const closestRowIndex = findClosestStarterRow(this.starterIconsCursorIndex, onScreenNumberOfRows); - this.starterIconsCursorObj.setVisible(false); - this.cursorObj.setVisible(true); - this.setCursor(Math.min(onScreenFirstIndex + closestRowIndex * 9 + 8, onScreenLastIndex)); - success = true; - } else { - // LEFT from team and no Pokemon in filter > do nothing - success = false; - } - break; - case Button.RIGHT: - if (!this.starterIconsCursorObj.visible) { - // is not right edge - if (this.cursor % 9 < (currentRow < numOfRows - 1 ? 8 : (numberOfStarters - 1) % 9)) { - success = this.setCursor(this.cursor + 1); - } else { - // RIGHT from filtered Pokemon, on the right edge - if (this.starterSpecies.length === 0) { - // no selected starter in team > wrap around to the first column - success = this.setCursor(this.cursor - Math.min(8, this.cursor % 9)); - - } else if (onScreenCurrentRow < 7) { - // at least one pokemon in team > for the first 7 rows, go to closest starter - this.cursorObj.setVisible(false); - this.starterIconsCursorIndex = findClosestStarterIndex(this.cursorObj.y - 1, this.starterSpecies.length); - this.moveStarterIconsCursor(this.starterIconsCursorIndex); - - } else { - // at least one pokemon in team > from the bottom 2 rows, go to start run button - this.cursorObj.setVisible(false); - this.setSpecies(null); - this.startCursorObj.setVisible(true); - } + const closestRowIndex = findClosestStarterRow(this.starterIconsCursorIndex, onScreenNumberOfRows); + this.starterIconsCursorObj.setVisible(false); + this.cursorObj.setVisible(true); + this.setCursor(Math.min(onScreenFirstIndex + closestRowIndex * 9 + 8, onScreenLastIndex)); success = true; + } else { + // LEFT from team and no Pokemon in filter > do nothing + success = false; } - } else if (numberOfStarters > 0) { + break; + case Button.RIGHT: + if (!this.starterIconsCursorObj.visible) { + // is not right edge + if (this.cursor % 9 < (currentRow < numOfRows - 1 ? 8 : (numberOfStarters - 1) % 9)) { + success = this.setCursor(this.cursor + 1); + } else { + // RIGHT from filtered Pokemon, on the right edge + if (this.starterSpecies.length === 0) { + // no selected starter in team > wrap around to the first column + success = this.setCursor(this.cursor - Math.min(8, this.cursor % 9)); + + } else if (onScreenCurrentRow < 7) { + // at least one pokemon in team > for the first 7 rows, go to closest starter + this.cursorObj.setVisible(false); + this.starterIconsCursorIndex = findClosestStarterIndex(this.cursorObj.y - 1, this.starterSpecies.length); + this.moveStarterIconsCursor(this.starterIconsCursorIndex); + + } else { + // at least one pokemon in team > from the bottom 2 rows, go to start run button + this.cursorObj.setVisible(false); + this.setSpecies(null); + this.startCursorObj.setVisible(true); + } + success = true; + } + } else if (numberOfStarters > 0) { // RIGHT from team > Go to closest filtered Pokemon - const closestRowIndex = findClosestStarterRow(this.starterIconsCursorIndex, onScreenNumberOfRows); - this.starterIconsCursorObj.setVisible(false); - this.cursorObj.setVisible(true); - this.setCursor(Math.min(onScreenFirstIndex + closestRowIndex * 9, onScreenLastIndex - (onScreenLastIndex % 9))); - success = true; - } else { + const closestRowIndex = findClosestStarterRow(this.starterIconsCursorIndex, onScreenNumberOfRows); + this.starterIconsCursorObj.setVisible(false); + this.cursorObj.setVisible(true); + this.setCursor(Math.min(onScreenFirstIndex + closestRowIndex * 9, onScreenLastIndex - (onScreenLastIndex % 9))); + success = true; + } else { // RIGHT from team and no Pokemon in filter > do nothing - success = false; - } - break; + success = false; + } + break; } } } @@ -2161,7 +2158,7 @@ export default class StarterSelectUiHandler extends MessageUiHandler { break; } } - return [isDupe, removeIndex]; + return [ isDupe, removeIndex ]; } addToParty(species: PokemonSpecies, dexAttr: bigint, abilityIndex: integer, nature: Nature, moveset: StarterMoveset) { @@ -2219,7 +2216,7 @@ export default class StarterSelectUiHandler extends MessageUiHandler { } else { this.scene.gameData.starterData[speciesId].moveset = this.starterMoveset?.slice(0) as StarterMoveset; } - this.setSpeciesDetails(this.lastSpecies, undefined, undefined, undefined, undefined, undefined, undefined, false); + this.setSpeciesDetails(this.lastSpecies, { forSeen: false }); // switch moves of starter if exists if (this.starterMovesets.length) { @@ -2239,29 +2236,29 @@ export default class StarterSelectUiHandler extends MessageUiHandler { if (gamepadType === "touch") { gamepadType = "keyboard"; switch (iconSetting) { - case SettingKeyboard.Button_Cycle_Shiny: - iconPath = "R.png"; - break; - case SettingKeyboard.Button_Cycle_Form: - iconPath = "F.png"; - break; - case SettingKeyboard.Button_Cycle_Gender: - iconPath = "G.png"; - break; - case SettingKeyboard.Button_Cycle_Ability: - iconPath = "E.png"; - break; - case SettingKeyboard.Button_Cycle_Nature: - iconPath = "N.png"; - break; - case SettingKeyboard.Button_Cycle_Variant: - iconPath = "V.png"; - break; - case SettingKeyboard.Button_Stats: - iconPath = "C.png"; - break; - default: - break; + case SettingKeyboard.Button_Cycle_Shiny: + iconPath = "R.png"; + break; + case SettingKeyboard.Button_Cycle_Form: + iconPath = "F.png"; + break; + case SettingKeyboard.Button_Cycle_Gender: + iconPath = "G.png"; + break; + case SettingKeyboard.Button_Cycle_Ability: + iconPath = "E.png"; + break; + case SettingKeyboard.Button_Cycle_Nature: + iconPath = "N.png"; + break; + case SettingKeyboard.Button_Cycle_Variant: + iconPath = "V.png"; + break; + case SettingKeyboard.Button_Stats: + iconPath = "C.png"; + break; + default: + break; } } else { iconPath = this.scene.inputController?.getIconForLatestInputRecorded(iconSetting); @@ -2271,7 +2268,7 @@ export default class StarterSelectUiHandler extends MessageUiHandler { controlLabel.setPosition(this.instructionRowX + this.instructionRowTextOffset, this.instructionRowY); iconElement.setVisible(true); controlLabel.setVisible(true); - this.instructionsContainer.add([iconElement, controlLabel]); + this.instructionsContainer.add([ iconElement, controlLabel ]); this.instructionRowY += 8; if (this.instructionRowY >= 24) { this.instructionRowY = 0; @@ -2294,13 +2291,14 @@ export default class StarterSelectUiHandler extends MessageUiHandler { controlLabel.setPosition(this.filterInstructionRowX + this.instructionRowTextOffset, this.filterInstructionRowY); iconElement.setVisible(true); controlLabel.setVisible(true); - this.filterInstructionsContainer.add([iconElement, controlLabel]); + this.filterInstructionsContainer.add([ iconElement, controlLabel ]); this.filterInstructionRowY += 8; if (this.filterInstructionRowY >= 24) { this.filterInstructionRowY = 0; this.filterInstructionRowX += 50; } } + updateInstructions(): void { this.instructionRowX = 0; this.instructionRowY = 0; @@ -2348,15 +2346,15 @@ export default class StarterSelectUiHandler extends MessageUiHandler { } - getValueLimit(): integer { - const valueLimit = new Utils.IntegerHolder(0); + getValueLimit(): number { + const valueLimit = new NumberHolder(0); switch (this.scene.gameMode.modeId) { - case GameModes.ENDLESS: - case GameModes.SPLICED_ENDLESS: - valueLimit.value = 15; - break; - default: - valueLimit.value = 10; + case GameModes.ENDLESS: + case GameModes.SPLICED_ENDLESS: + valueLimit.value = 15; + break; + default: + valueLimit.value = 10; } Challenge.applyChallenges(this.scene.gameMode, Challenge.ChallengeType.STARTER_POINTS, valueLimit); @@ -2385,12 +2383,12 @@ export default class StarterSelectUiHandler extends MessageUiHandler { * Since some pokemon rely on forms to be valid (i.e. blaze tauros for fire challenges), we make a fake form and dex props to use in the challenge */ const tempFormProps = BigInt(Math.pow(2, i)) * DexAttr.DEFAULT_FORM; - const isValidForChallenge = new Utils.BooleanHolder(true); + const isValidForChallenge = new BooleanHolder(true); Challenge.applyChallenges(this.scene.gameMode, Challenge.ChallengeType.STARTER_CHOICE, container.species, isValidForChallenge, this.scene.gameData.getSpeciesDexAttrProps(species, tempFormProps), true); allFormsValid = allFormsValid || isValidForChallenge.value; } } else { - const isValidForChallenge = new Utils.BooleanHolder(true); + const isValidForChallenge = new BooleanHolder(true); Challenge.applyChallenges(this.scene.gameMode, Challenge.ChallengeType.STARTER_CHOICE, container.species, isValidForChallenge, this.scene.gameData.getSpeciesDexAttrProps(species, this.scene.gameData.getSpeciesDefaultDexAttr(container.species, false, true)), true); allFormsValid = isValidForChallenge.value; } @@ -2553,29 +2551,29 @@ export default class StarterSelectUiHandler extends MessageUiHandler { } }); - this.starterSelectScrollBar.setPages(Math.max(Math.ceil(this.filteredStarterContainers.length / 9), 1)); - this.starterSelectScrollBar.setPage(0); + this.starterSelectScrollBar.setTotalRows(Math.max(Math.ceil(this.filteredStarterContainers.length / 9), 1)); + this.starterSelectScrollBar.setScrollCursor(0); // sort const sort = this.filterBar.getVals(DropDownColumn.SORT)[0]; this.filteredStarterContainers.sort((a, b) => { switch (sort.val) { - default: - break; - case SortCriteria.NUMBER: - return (a.species.speciesId - b.species.speciesId) * -sort.dir; - case SortCriteria.COST: - return (a.cost - b.cost) * -sort.dir; - case SortCriteria.CANDY: - const candyCountA = this.scene.gameData.starterData[a.species.speciesId].candyCount; - const candyCountB = this.scene.gameData.starterData[b.species.speciesId].candyCount; - return (candyCountA - candyCountB) * -sort.dir; - case SortCriteria.IV: - const avgIVsA = this.scene.gameData.dexData[a.species.speciesId].ivs.reduce((a, b) => a + b, 0) / this.scene.gameData.dexData[a.species.speciesId].ivs.length; - const avgIVsB = this.scene.gameData.dexData[b.species.speciesId].ivs.reduce((a, b) => a + b, 0) / this.scene.gameData.dexData[b.species.speciesId].ivs.length; - return (avgIVsA - avgIVsB) * -sort.dir; - case SortCriteria.NAME: - return a.species.name.localeCompare(b.species.name) * -sort.dir; + default: + break; + case SortCriteria.NUMBER: + return (a.species.speciesId - b.species.speciesId) * -sort.dir; + case SortCriteria.COST: + return (a.cost - b.cost) * -sort.dir; + case SortCriteria.CANDY: + const candyCountA = this.scene.gameData.starterData[a.species.speciesId].candyCount; + const candyCountB = this.scene.gameData.starterData[b.species.speciesId].candyCount; + return (candyCountA - candyCountB) * -sort.dir; + case SortCriteria.IV: + const avgIVsA = this.scene.gameData.dexData[a.species.speciesId].ivs.reduce((a, b) => a + b, 0) / this.scene.gameData.dexData[a.species.speciesId].ivs.length; + const avgIVsB = this.scene.gameData.dexData[b.species.speciesId].ivs.reduce((a, b) => a + b, 0) / this.scene.gameData.dexData[b.species.speciesId].ivs.length; + return (avgIVsA - avgIVsB) * -sort.dir; + case SortCriteria.NAME: + return a.species.name.localeCompare(b.species.name) * -sort.dir; } return 0; }); @@ -2587,9 +2585,9 @@ export default class StarterSelectUiHandler extends MessageUiHandler { const maxColumns = 9; const maxRows = 9; const onScreenFirstIndex = this.scrollCursor * maxColumns; - const onScreenLastIndex = Math.min(this.filteredStarterContainers.length - 1, onScreenFirstIndex + maxRows * maxColumns -1); + const onScreenLastIndex = Math.min(this.filteredStarterContainers.length - 1, onScreenFirstIndex + maxRows * maxColumns - 1); - this.starterSelectScrollBar.setPage(this.scrollCursor); + this.starterSelectScrollBar.setScrollCursor(this.scrollCursor); let pokerusCursorIndex = 0; this.filteredStarterContainers.forEach((container, i) => { @@ -2652,8 +2650,8 @@ export default class StarterSelectUiHandler extends MessageUiHandler { } // Set the candy colors - container.candyUpgradeIcon.setTint(argbFromRgba(Utils.rgbHexToRgba(starterColors[speciesId][0]))); - container.candyUpgradeOverlayIcon.setTint(argbFromRgba(Utils.rgbHexToRgba(starterColors[speciesId][1]))); + container.candyUpgradeIcon.setTint(argbFromRgba(rgbHexToRgba(starterColors[speciesId][0]))); + container.candyUpgradeOverlayIcon.setTint(argbFromRgba(rgbHexToRgba(starterColors[speciesId][1]))); this.setUpgradeIcon(container); } else if (this.scene.candyUpgradeDisplay === 1) { @@ -2690,9 +2688,6 @@ export default class StarterSelectUiHandler extends MessageUiHandler { this.pokemonShinyIcon.setTint(tint); this.setSpecies(species); this.updateInstructions(); - } else { - console.warn("Species is undefined for cursor position", cursor); - this.setFilterMode(true); } } @@ -2735,7 +2730,7 @@ export default class StarterSelectUiHandler extends MessageUiHandler { currentFriendship = 0; } - const friendshipCap = getStarterValueFriendshipCap(speciesStarters[speciesId]); + const friendshipCap = getStarterValueFriendshipCap(speciesStarterCosts[speciesId]); return { currentFriendship, friendshipCap }; } @@ -2753,7 +2748,7 @@ export default class StarterSelectUiHandler extends MessageUiHandler { this.pokemonAbilityText.off("pointerover"); this.pokemonPassiveText.off("pointerover"); - const starterAttributes : StarterAttributes | null = species ? {...this.starterPreferences[species.speciesId]} : null; + const starterAttributes : StarterAttributes | null = species ? { ...this.starterPreferences[species.speciesId] } : null; if (starterAttributes?.nature) { // load default nature from stater save data, if set @@ -2791,7 +2786,7 @@ export default class StarterSelectUiHandler extends MessageUiHandler { this.lastSpecies = species!; // TODO: is this bang correct? if (species && (this.speciesStarterDexEntry?.seenAttr || this.speciesStarterDexEntry?.caughtAttr)) { - this.pokemonNumberText.setText(Utils.padInt(species.speciesId, 4)); + this.pokemonNumberText.setText(padInt(species.speciesId, 4)); if (starterAttributes?.nickname) { const name = decodeURIComponent(escape(atob(starterAttributes.nickname))); this.pokemonNameText.setText(name); @@ -2809,10 +2804,10 @@ export default class StarterSelectUiHandler extends MessageUiHandler { this.pokemonLuckLabelText.setVisible(this.pokemonLuckText.visible); //Growth translate - let growthReadable = Utils.toReadableString(GrowthRate[species.growthRate]); + let growthReadable = toReadableString(GrowthRate[species.growthRate]); const growthAux = growthReadable.replace(" ", "_"); if (i18next.exists("growth:" + growthAux)) { - growthReadable = i18next.t("growth:"+ growthAux as any); + growthReadable = i18next.t("growth:" + growthAux as any); } this.pokemonGrowthRateText.setText(growthReadable); @@ -2839,15 +2834,14 @@ export default class StarterSelectUiHandler extends MessageUiHandler { this.pokemonShinyIcon.setTint(tint); this.pokemonShinyIcon.setVisible(defaultProps.shiny); this.pokemonCaughtHatchedContainer.setVisible(true); + this.pokemonFormText.setVisible(true); + if (pokemonPrevolutions.hasOwnProperty(species.speciesId)) { this.pokemonCaughtHatchedContainer.setY(16); this.pokemonShinyIcon.setY(135); this.pokemonShinyIcon.setFrame(getVariantIcon(variant)); [ - this.pokemonCandyIcon, - this.pokemonCandyOverlayIcon, - this.pokemonCandyDarknessOverlay, - this.pokemonCandyCountText, + this.pokemonCandyContainer, this.pokemonHatchedIcon, this.pokemonHatchedCountText ].map(c => c.setVisible(false)); @@ -2855,33 +2849,27 @@ export default class StarterSelectUiHandler extends MessageUiHandler { } else { this.pokemonCaughtHatchedContainer.setY(25); this.pokemonShinyIcon.setY(117); - this.pokemonCandyIcon.setTint(argbFromRgba(Utils.rgbHexToRgba(colorScheme[0]))); - this.pokemonCandyIcon.setVisible(true); - this.pokemonCandyOverlayIcon.setTint(argbFromRgba(Utils.rgbHexToRgba(colorScheme[1]))); - this.pokemonCandyOverlayIcon.setVisible(true); - this.pokemonCandyDarknessOverlay.setVisible(true); + this.pokemonCandyIcon.setTint(argbFromRgba(rgbHexToRgba(colorScheme[0]))); + this.pokemonCandyOverlayIcon.setTint(argbFromRgba(rgbHexToRgba(colorScheme[1]))); this.pokemonCandyCountText.setText(`x${this.scene.gameData.starterData[species.speciesId].candyCount}`); - this.pokemonCandyCountText.setVisible(true); - this.pokemonFormText.setVisible(true); + this.pokemonCandyContainer.setVisible(true); this.pokemonFormText.setY(42); this.pokemonHatchedIcon.setVisible(true); this.pokemonHatchedCountText.setVisible(true); const { currentFriendship, friendshipCap } = this.getFriendship(this.lastSpecies.speciesId); const candyCropY = 16 - (16 * (currentFriendship / friendshipCap)); - - if (this.pokemonCandyDarknessOverlay.visible) { - this.pokemonCandyDarknessOverlay.on("pointerover", () => { - this.scene.ui.showTooltip("", `${currentFriendship}/${friendshipCap}`, true); - this.activeTooltip = "CANDY"; - }); - this.pokemonCandyDarknessOverlay.on("pointerout", () => { - this.scene.ui.hideTooltip(); - this.activeTooltip = undefined; - }); - } - this.pokemonCandyDarknessOverlay.setCrop(0, 0, 16, candyCropY); + + this.pokemonCandyContainer.on("pointerover", () => { + this.scene.ui.showTooltip("", `${currentFriendship}/${friendshipCap}`, true); + this.activeTooltip = "CANDY"; + }); + this.pokemonCandyContainer.on("pointerout", () => { + this.scene.ui.hideTooltip(); + this.activeTooltip = undefined; + }); + } @@ -2905,7 +2893,14 @@ export default class StarterSelectUiHandler extends MessageUiHandler { if (starterIndex > -1) { props = this.scene.gameData.getSpeciesDexAttrProps(species, this.starterAttr[starterIndex]); - this.setSpeciesDetails(species, props.shiny, props.formIndex, props.female, props.variant, this.starterAbilityIndexes[starterIndex], this.starterNatures[starterIndex]); + this.setSpeciesDetails(species, { + shiny: props.shiny, + formIndex: props.formIndex, + female: props.female, + variant: props.variant, + abilityIndex: this.starterAbilityIndexes[starterIndex], + natureIndex: this.starterNatures[starterIndex] + }); } else { const defaultDexAttr = this.getCurrentDexProps(species.speciesId); const defaultAbilityIndex = starterAttributes?.ability ?? this.scene.gameData.getStarterSpeciesDefaultAbilityIndex(species); @@ -2920,7 +2915,14 @@ export default class StarterSelectUiHandler extends MessageUiHandler { props.formIndex = starterAttributes?.form ?? props.formIndex; props.female = starterAttributes?.female ?? props.female; - this.setSpeciesDetails(species, props.shiny, props.formIndex, props.female, props.variant, defaultAbilityIndex, defaultNature); + this.setSpeciesDetails(species, { + shiny: props.shiny, + formIndex: props.formIndex, + female: props.female, + variant: props.variant, + abilityIndex: defaultAbilityIndex, + natureIndex: defaultNature + }); } const speciesForm = getPokemonSpeciesForm(species.speciesId, props.formIndex); @@ -2943,10 +2945,7 @@ export default class StarterSelectUiHandler extends MessageUiHandler { this.pokemonPassiveLabelText.setVisible(false); this.pokemonNatureLabelText.setVisible(false); this.pokemonCaughtHatchedContainer.setVisible(false); - this.pokemonCandyIcon.setVisible(false); - this.pokemonCandyOverlayIcon.setVisible(false); - this.pokemonCandyDarknessOverlay.setVisible(false); - this.pokemonCandyCountText.setVisible(false); + this.pokemonCandyContainer.setVisible(false); this.pokemonFormText.setVisible(false); const defaultDexAttr = this.scene.gameData.getSpeciesDefaultDexAttr(species, true, true); @@ -2954,11 +2953,19 @@ export default class StarterSelectUiHandler extends MessageUiHandler { const defaultNature = this.scene.gameData.getSpeciesDefaultNature(species); const props = this.scene.gameData.getSpeciesDexAttrProps(species, defaultDexAttr); - this.setSpeciesDetails(species, props.shiny, props.formIndex, props.female, props.variant, defaultAbilityIndex, defaultNature, true); + this.setSpeciesDetails(species, { + shiny: props.shiny, + formIndex: props.formIndex, + female: props.female, + variant: props.variant, + abilityIndex: defaultAbilityIndex, + natureIndex: defaultNature, + forSeen: true + }); this.pokemonSprite.setTint(0x808080); } } else { - this.pokemonNumberText.setText(Utils.padInt(0, 4)); + this.pokemonNumberText.setText(padInt(0, 4)); this.pokemonNameText.setText(species ? "???" : ""); this.pokemonGrowthRateText.setText(""); this.pokemonGrowthRateLabelText.setVisible(false); @@ -2972,20 +2979,24 @@ export default class StarterSelectUiHandler extends MessageUiHandler { this.pokemonPassiveLabelText.setVisible(false); this.pokemonNatureLabelText.setVisible(false); this.pokemonCaughtHatchedContainer.setVisible(false); - this.pokemonCandyIcon.setVisible(false); - this.pokemonCandyOverlayIcon.setVisible(false); - this.pokemonCandyDarknessOverlay.setVisible(false); - this.pokemonCandyCountText.setVisible(false); + this.pokemonCandyContainer.setVisible(false); this.pokemonFormText.setVisible(false); - this.setSpeciesDetails(species!, false, 0, false, 0, 0, 0); // TODO: is this bang correct? + this.setSpeciesDetails(species!, { // TODO: is this bang correct? + shiny: false, + formIndex: 0, + female: false, + variant: 0, + abilityIndex: 0, + natureIndex: 0 + }); this.pokemonSprite.clearTint(); } } - - - setSpeciesDetails(species: PokemonSpecies, shiny?: boolean, formIndex?: integer, female?: boolean, variant?: Variant, abilityIndex?: integer, natureIndex?: integer, forSeen: boolean = false): void { + setSpeciesDetails(species: PokemonSpecies, options: SpeciesDetails = {}): void { + let { shiny, formIndex, female, variant, abilityIndex, natureIndex } = options; + const forSeen: boolean = options.forSeen ?? false; const oldProps = species ? this.scene.gameData.getSpeciesDexAttrProps(species, this.dexAttrCursor) : null; const oldAbilityIndex = this.abilityCursor > -1 ? this.abilityCursor : this.scene.gameData.getStarterSpeciesDefaultAbilityIndex(species); const oldNatureIndex = this.natureCursor > -1 ? this.natureCursor : this.scene.gameData.getSpeciesDefaultNature(species); @@ -2993,9 +3004,18 @@ export default class StarterSelectUiHandler extends MessageUiHandler { this.abilityCursor = -1; this.natureCursor = -1; + // We will only update the sprite if there is a change to form, shiny/variant + // or gender for species with gender sprite differences + const shouldUpdateSprite = (species?.genderDiffs && !isNullOrUndefined(female)) + || !isNullOrUndefined(formIndex) || !isNullOrUndefined(shiny) || !isNullOrUndefined(variant); + if (this.activeTooltip === "CANDY") { - const { currentFriendship, friendshipCap } = this.getFriendship(this.lastSpecies.speciesId); - this.scene.ui.editTooltip("", `${currentFriendship}/${friendshipCap}`); + if (this.lastSpecies && this.pokemonCandyContainer.visible) { + const { currentFriendship, friendshipCap } = this.getFriendship(this.lastSpecies.speciesId); + this.scene.ui.editTooltip("", `${currentFriendship}/${friendshipCap}`); + } else { + this.scene.ui.hideTooltip(); + } } if (species?.forms?.find(f => f.formKey === "female")) { @@ -3013,7 +3033,7 @@ export default class StarterSelectUiHandler extends MessageUiHandler { this.dexAttrCursor |= this.scene.gameData.getFormAttr(formIndex !== undefined ? formIndex : (formIndex = oldProps!.formIndex)); // TODO: is this bang correct? this.abilityCursor = abilityIndex !== undefined ? abilityIndex : (abilityIndex = oldAbilityIndex); this.natureCursor = natureIndex !== undefined ? natureIndex : (natureIndex = oldNatureIndex); - const [isInParty, partyIndex]: [boolean, number] = this.isInParty(species); // we use this to firstly check if the pokemon is in the party, and if so, to get the party index in order to update the icon image + const [ isInParty, partyIndex ]: [boolean, number] = this.isInParty(species); // we use this to firstly check if the pokemon is in the party, and if so, to get the party index in order to update the icon image if (isInParty) { this.updatePartyIcon(species, partyIndex); } @@ -3077,24 +3097,27 @@ export default class StarterSelectUiHandler extends MessageUiHandler { this.starterNatures[starterIndex] = this.natureCursor; } - const assetLoadCancelled = new Utils.BooleanHolder(false); + const assetLoadCancelled = new BooleanHolder(false); this.assetLoadCancelled = assetLoadCancelled; - species.loadAssets(this.scene, female!, formIndex, shiny, variant, true).then(() => { // TODO: is this bang correct? - if (assetLoadCancelled.value) { - return; - } - this.assetLoadCancelled = null; - this.speciesLoaded.set(species.speciesId, true); - this.pokemonSprite.play(species.getSpriteKey(female!, formIndex, shiny, variant)); // TODO: is this bang correct? - this.pokemonSprite.setPipelineData("shiny", shiny); - this.pokemonSprite.setPipelineData("variant", variant); - this.pokemonSprite.setPipelineData("spriteKey", species.getSpriteKey(female!, formIndex, shiny, variant)); // TODO: is this bang correct? + if (shouldUpdateSprite) { + species.loadAssets(this.scene, female!, formIndex, shiny, variant, true).then(() => { // TODO: is this bang correct? + if (assetLoadCancelled.value) { + return; + } + this.assetLoadCancelled = null; + this.speciesLoaded.set(species.speciesId, true); + this.pokemonSprite.play(species.getSpriteKey(female!, formIndex, shiny, variant)); // TODO: is this bang correct? + this.pokemonSprite.setPipelineData("shiny", shiny); + this.pokemonSprite.setPipelineData("variant", variant); + this.pokemonSprite.setPipelineData("spriteKey", species.getSpriteKey(female!, formIndex, shiny, variant)); // TODO: is this bang correct? + this.pokemonSprite.setVisible(!this.statsMode); + }); + } else { this.pokemonSprite.setVisible(!this.statsMode); - }); + } - - const isValidForChallenge = new Utils.BooleanHolder(true); + const isValidForChallenge = new BooleanHolder(true); Challenge.applyChallenges(this.scene.gameMode, Challenge.ChallengeType.STARTER_CHOICE, species, isValidForChallenge, this.scene.gameData.getSpeciesDexAttrProps(species, this.dexAttrCursor), !!this.starterSpecies.length); const currentFilteredContainer = this.filteredStarterContainers.find(p => p.species.speciesId === species.speciesId); if (currentFilteredContainer) { @@ -3110,7 +3133,7 @@ export default class StarterSelectUiHandler extends MessageUiHandler { const isVariant3Caught = isShinyCaught && !!(caughtAttr & DexAttr.VARIANT_3); this.canCycleShiny = isNonShinyCaught && isShinyCaught; - this.canCycleVariant = !!shiny && [ isVariant1Caught, isVariant2Caught, isVariant3Caught].filter(v => v).length > 1; + this.canCycleVariant = !!shiny && [ isVariant1Caught, isVariant2Caught, isVariant3Caught ].filter(v => v).length > 1; const isMaleCaught = !!(caughtAttr & DexAttr.MALE); const isFemaleCaught = !!(caughtAttr & DexAttr.FEMALE); @@ -3212,6 +3235,9 @@ export default class StarterSelectUiHandler extends MessageUiHandler { this.pokemonPassiveLockedIcon.setVisible(!isUnlocked); this.pokemonPassiveLockedIcon.setPosition(iconPosition.x, iconPosition.y); + } else if (this.activeTooltip === "PASSIVE") { + // No passive and passive tooltip is active > hide it + this.scene.ui.hideTooltip(); } this.pokemonNatureText.setText(getNatureName(natureIndex as unknown as Nature, true, true, false, this.scene.uiTheme)); @@ -3251,9 +3277,9 @@ export default class StarterSelectUiHandler extends MessageUiHandler { }) as StarterMoveset; const speciesForm = getPokemonSpeciesForm(species.speciesId, formIndex!); // TODO: is the bang correct? - const formText = Utils.capitalizeString(species?.forms[formIndex!]?.formKey, "-", false, false); // TODO: is the bang correct? + const formText = capitalizeString(species?.forms[formIndex!]?.formKey, "-", false, false); // TODO: is the bang correct? - const speciesName = Utils.capitalizeString(Species[species.speciesId], "_", true, false); + const speciesName = capitalizeString(Species[species.speciesId], "_", true, false); if (species.speciesId === Species.ARCEUS) { this.pokemonFormText.setText(i18next.t(`pokemonInfo:Type.${formText?.toUpperCase()}`)); @@ -3360,6 +3386,18 @@ export default class StarterSelectUiHandler extends MessageUiHandler { } } this.moveStarterIconsCursor(this.starterIconsCursorIndex); + } else if (this.startCursorObj.visible && this.starterSpecies.length === 0) { + // On the start button and no more Pokemon in party + this.startCursorObj.setVisible(false); + if (this.filteredStarterContainers.length > 0) { + // Back to the first Pokemon if there is one + this.cursorObj.setVisible(true); + this.setCursor(0 + this.scrollCursor * 9); + } else { + // Back to filters + this.filterBarCursor = Math.max(1, this.filterBar.numFilters - 1); + this.setFilterMode(true); + } } this.tryUpdateValue(); @@ -3367,7 +3405,7 @@ export default class StarterSelectUiHandler extends MessageUiHandler { updateStarterValueLabel(starter: StarterContainer): void { const speciesId = starter.species.speciesId; - const baseStarterValue = speciesStarters[speciesId]; + const baseStarterValue = speciesStarterCosts[speciesId]; const starterValue = this.scene.gameData.getSpeciesStarterValue(speciesId); starter.cost = starterValue; let valueStr = starterValue.toString(); @@ -3377,16 +3415,16 @@ export default class StarterSelectUiHandler extends MessageUiHandler { starter.label.setText(valueStr); let textStyle: TextStyle; switch (baseStarterValue - starterValue) { - case 0: - textStyle = TextStyle.WINDOW; - break; - case 1: - case 0.5: - textStyle = TextStyle.SUMMARY_BLUE; - break; - default: - textStyle = TextStyle.SUMMARY_GOLD; - break; + case 0: + textStyle = TextStyle.WINDOW; + break; + case 1: + case 0.5: + textStyle = TextStyle.SUMMARY_BLUE; + break; + default: + textStyle = TextStyle.SUMMARY_GOLD; + break; } if (baseStarterValue - starterValue > 0) { starter.label.setColor(this.getTextColor(textStyle)); @@ -3407,12 +3445,12 @@ export default class StarterSelectUiHandler extends MessageUiHandler { this.valueLimitLabel.setColor(this.getTextColor(!overLimit ? TextStyle.TOOLTIP_CONTENT : TextStyle.SUMMARY_PINK)); this.valueLimitLabel.setShadowColor(this.getTextColor(!overLimit ? TextStyle.TOOLTIP_CONTENT : TextStyle.SUMMARY_PINK, true)); if (overLimit) { - this.scene.time.delayedCall(Utils.fixedInt(500), () => this.tryUpdateValue()); + this.scene.time.delayedCall(fixedInt(500), () => this.tryUpdateValue()); return false; } let isPartyValid: boolean = this.isPartyValid(); // this checks to see if the party is valid if (addingToParty) { // this does a check to see if the pokemon being added is valid; if so, it will update the isPartyValid boolean - const isNewPokemonValid = new Utils.BooleanHolder(true); + const isNewPokemonValid = new BooleanHolder(true); const species = this.filteredStarterContainers[this.cursor].species; Challenge.applyChallenges(this.scene.gameMode, Challenge.ChallengeType.STARTER_CHOICE, species, isNewPokemonValid, this.scene.gameData.getSpeciesDexAttrProps(species, this.getCurrentDexProps(species.speciesId)), false); isPartyValid = isPartyValid || isNewPokemonValid.value; @@ -3421,13 +3459,10 @@ export default class StarterSelectUiHandler extends MessageUiHandler { /** * this loop is used to set the Sprite's alpha value and check if the user can select other pokemon more. */ - this.canAddParty = false; const remainValue = valueLimit - newValue; for (let s = 0; s < this.allSpecies.length; s++) { /** Cost of pokemon species */ const speciesStarterValue = this.scene.gameData.getSpeciesStarterValue(this.allSpecies[s].speciesId); - /** Used to detect if this pokemon is registered in starter */ - const speciesStarterDexEntry = this.scene.gameData.dexData[this.allSpecies[s].speciesId]; /** {@linkcode Phaser.GameObjects.Sprite} object of Pokémon for setting the alpha value */ const speciesSprite = this.starterContainers[s].icon; @@ -3442,7 +3477,7 @@ export default class StarterSelectUiHandler extends MessageUiHandler { * If speciesStarterDexEntry?.caughtAttr is true, this species registered in stater. * we change to can AddParty value to true since the user has enough cost to choose this pokemon and this pokemon registered too. */ - const isValidForChallenge = new Utils.BooleanHolder(true); + const isValidForChallenge = new BooleanHolder(true); Challenge.applyChallenges(this.scene.gameMode, Challenge.ChallengeType.STARTER_CHOICE, this.allSpecies[s], isValidForChallenge, this.scene.gameData.getSpeciesDexAttrProps(this.allSpecies[s], this.getCurrentDexProps(this.allSpecies[s].speciesId)), isPartyValid); const canBeChosen = remainValue >= speciesStarterValue && isValidForChallenge.value; @@ -3458,9 +3493,6 @@ export default class StarterSelectUiHandler extends MessageUiHandler { */ if (canBeChosen || (isPokemonInParty && remainValue >= speciesStarterValue)) { speciesSprite.setAlpha(1); - if (speciesStarterDexEntry?.caughtAttr) { - this.canAddParty = true; - } } else { /** * If it can't be chosen, the user can't select. @@ -3470,7 +3502,6 @@ export default class StarterSelectUiHandler extends MessageUiHandler { } } - this.value = newValue; return true; } @@ -3489,6 +3520,7 @@ export default class StarterSelectUiHandler extends MessageUiHandler { this.scene.clearPhaseQueue(); if (this.scene.gameMode.isChallenge) { this.scene.pushPhase(new SelectChallengePhase(this.scene)); + this.scene.pushPhase(new EncounterPhase(this.scene, false)); } else { this.scene.pushPhase(new TitlePhase(this.scene)); } @@ -3556,7 +3588,7 @@ export default class StarterSelectUiHandler extends MessageUiHandler { isPartyValid(): boolean { let canStart = false; for (let s = 0; s < this.starterSpecies.length; s++) { - const isValidForChallenge = new Utils.BooleanHolder(true); + const isValidForChallenge = new BooleanHolder(true); const species = this.starterSpecies[s]; Challenge.applyChallenges(this.scene.gameMode, Challenge.ChallengeType.STARTER_CHOICE, species, isValidForChallenge, this.scene.gameData.getSpeciesDexAttrProps(species, this.getCurrentDexProps(species.speciesId)), false); canStart = canStart || isValidForChallenge.value; @@ -3672,6 +3704,9 @@ export default class StarterSelectUiHandler extends MessageUiHandler { StarterPrefs.save(this.starterPreferences); this.cursor = -1; this.hideInstructions(); + this.activeTooltip = undefined; + this.scene.ui.hideTooltip(); + this.starterSelectContainer.setVisible(false); this.blockInput = false; diff --git a/src/ui/stats-container.ts b/src/ui/stats-container.ts index 06dd6e7c035..7e026ede83e 100644 --- a/src/ui/stats-container.ts +++ b/src/ui/stats-container.ts @@ -6,12 +6,12 @@ import i18next from "i18next"; const ivChartSize = 24; -const ivChartStatCoordMultipliers = [[0, -1], [0.825, -0.5], [0.825, 0.5], [-0.825, -0.5], [-0.825, 0.5], [0, 1]]; +const ivChartStatCoordMultipliers = [[ 0, -1 ], [ 0.825, -0.5 ], [ 0.825, 0.5 ], [ -0.825, -0.5 ], [ -0.825, 0.5 ], [ 0, 1 ]]; const speedLabelOffset = -3; const sideLabelOffset = 1; -const ivLabelOffset = [0, sideLabelOffset, -sideLabelOffset, sideLabelOffset, -sideLabelOffset, speedLabelOffset]; -const ivChartLabelyOffset= [0, 5, 0, 5, 0, 0]; // doing this so attack does not overlap with (+N) -const ivChartStatIndexes = [0, 1, 2, 5, 4, 3]; // swap special attack and speed +const ivLabelOffset = [ 0, sideLabelOffset, -sideLabelOffset, sideLabelOffset, -sideLabelOffset, speedLabelOffset ]; +const ivChartLabelyOffset = [ 0, 5, 0, 5, 0, 0 ]; // doing this so attack does not overlap with (+N) +const ivChartStatIndexes = [ 0, 1, 2, 5, 4, 3 ]; // swap special attack and speed const defaultIvChartData = new Array(12).fill(null).map(() => 0); @@ -39,7 +39,7 @@ export class StatsContainer extends Phaser.GameObjects.Container { .setStrokeStyle(1, 0x484050); ivChartBorder.setOrigin(0, 0); - const ivChartBgLines = [ [ 0, -1, 0, 1 ], [ -0.825, -0.5, 0.825, 0.5 ], [ 0.825, -0.5, -0.825, 0.5 ] ].map(coords => { + const ivChartBgLines = [[ 0, -1, 0, 1 ], [ -0.825, -0.5, 0.825, 0.5 ], [ 0.825, -0.5, -0.825, 0.5 ]].map(coords => { const line = new Phaser.GameObjects.Line(this.scene, ivChartBg.x, ivChartBg.y, ivChartSize * coords[0], ivChartSize * coords[1], ivChartSize * coords[2], ivChartSize * coords[3], 0xffffff) .setLineWidth(0.5); line.setOrigin(0, 0); diff --git a/src/ui/summary-ui-handler.ts b/src/ui/summary-ui-handler.ts index fb9f1561447..2e05f3de4c1 100644 --- a/src/ui/summary-ui-handler.ts +++ b/src/ui/summary-ui-handler.ts @@ -1,28 +1,30 @@ -import BattleScene, { starterColors } from "../battle-scene"; -import { Mode } from "./ui"; -import UiHandler from "./ui-handler"; -import * as Utils from "../utils"; -import { PlayerPokemon, PokemonMove } from "../field/pokemon"; -import { getStarterValueFriendshipCap, speciesStarters } from "../data/pokemon-species"; +import BattleScene, { starterColors } from "#app/battle-scene"; +import { Mode } from "#app/ui/ui"; +import UiHandler from "#app/ui/ui-handler"; +import * as Utils from "#app/utils"; +import { PlayerPokemon, PokemonMove } from "#app/field/pokemon"; +import { getStarterValueFriendshipCap, speciesStarterCosts } from "#app/data/balance/starters"; import { argbFromRgba } from "@material/material-color-utilities"; -import { Type, getTypeRgb } from "../data/type"; -import { TextStyle, addBBCodeTextObject, addTextObject, getBBCodeFrag } from "./text"; -import Move, { MoveCategory } from "../data/move"; -import { getPokeballAtlasKey } from "../data/pokeball"; -import { getGenderColor, getGenderSymbol } from "../data/gender"; -import { getLevelRelExp, getLevelTotalExp } from "../data/exp"; -import { PokemonHeldItemModifier } from "../modifier/modifier"; -import { StatusEffect } from "../data/status-effect"; -import { getBiomeName } from "../data/biomes"; -import { Nature, getNatureName, getNatureStatMultiplier } from "../data/nature"; -import { loggedInUser } from "../account"; +import { getTypeRgb } from "#app/data/type"; +import { Type } from "#enums/type"; +import { TextStyle, addBBCodeTextObject, addTextObject, getBBCodeFrag } from "#app/ui/text"; +import Move, { MoveCategory } from "#app/data/move"; +import { getPokeballAtlasKey } from "#app/data/pokeball"; +import { getGenderColor, getGenderSymbol } from "#app/data/gender"; +import { getLevelRelExp, getLevelTotalExp } from "#app/data/exp"; +import { PokemonHeldItemModifier } from "#app/modifier/modifier"; +import { StatusEffect } from "#enums/status-effect"; +import { getBiomeName } from "#app/data/balance/biomes"; +import { getNatureName, getNatureStatMultiplier } from "#app/data/nature"; +import { loggedInUser } from "#app/account"; import { Variant, getVariantTint } from "#app/data/variant"; -import {Button} from "#enums/buttons"; -import { Ability } from "../data/ability"; +import { Button } from "#enums/buttons"; +import { Ability } from "#app/data/ability"; import i18next from "i18next"; -import {modifierSortFunc} from "../modifier/modifier"; +import { modifierSortFunc } from "#app/modifier/modifier"; import { PlayerGender } from "#enums/player-gender"; -import { Stat, PERMANENT_STATS, getStatKey } from "#app/enums/stat"; +import { Stat, PERMANENT_STATS, getStatKey } from "#enums/stat"; +import { Nature } from "#enums/nature"; enum Page { PROFILE, @@ -87,6 +89,10 @@ export default class SummaryUiHandler extends UiHandler { private moveAccuracyText: Phaser.GameObjects.Text; private moveCategoryIcon: Phaser.GameObjects.Sprite; private summaryPageTransitionContainer: Phaser.GameObjects.Container; + private friendshipShadow: Phaser.GameObjects.Sprite; + private friendshipText: Phaser.GameObjects.Text; + private friendshipIcon: Phaser.GameObjects.Sprite; + private friendshipOverlay: Phaser.GameObjects.Sprite; private descriptionScrollTween: Phaser.Tweens.Tween | null; private moveCursorBlinkTimer: Phaser.Time.TimerEvent | null; @@ -180,13 +186,32 @@ export default class SummaryUiHandler extends UiHandler { this.candyShadow.setTint(0x000000); this.candyShadow.setAlpha(0.50); this.candyShadow.setScale(0.8); - this.candyShadow.setInteractive(new Phaser.Geom.Rectangle(0, 0, 16, 16), Phaser.Geom.Rectangle.Contains); + this.candyShadow.setInteractive(new Phaser.Geom.Rectangle(0, 0, 30, 16), Phaser.Geom.Rectangle.Contains); this.summaryContainer.add(this.candyShadow); this.candyCountText = addTextObject(this.scene, 20, -146, "x0", TextStyle.WINDOW_ALT, { fontSize: "76px" }); this.candyCountText.setOrigin(0, 0); this.summaryContainer.add(this.candyCountText); + this.friendshipIcon = this.scene.add.sprite(13, -60, "friendship"); + this.friendshipIcon.setScale(0.8); + this.summaryContainer.add(this.friendshipIcon); + + this.friendshipOverlay = this.scene.add.sprite(13, -60, "friendship_overlay"); + this.friendshipOverlay.setScale(0.8); + this.summaryContainer.add(this.friendshipOverlay); + + this.friendshipShadow = this.scene.add.sprite(13, -60, "friendship"); + this.friendshipShadow.setTint(0x000000); + this.friendshipShadow.setAlpha(0.50); + this.friendshipShadow.setScale(0.8); + this.friendshipShadow.setInteractive(new Phaser.Geom.Rectangle(0, 0, 50, 16), Phaser.Geom.Rectangle.Contains); + this.summaryContainer.add(this.friendshipShadow); + + this.friendshipText = addTextObject(this.scene, 20, -66, "x0", TextStyle.WINDOW_ALT, { fontSize: "76px" }); + this.friendshipText.setOrigin(0, 0); + this.summaryContainer.add(this.friendshipText); + this.championRibbon = this.scene.add.image(88, -146, "champion_ribbon"); this.championRibbon.setOrigin(0, 0); //this.championRibbon.setScale(0.8); @@ -292,6 +317,7 @@ export default class SummaryUiHandler extends UiHandler { this.candyIcon.setTint(argbFromRgba(Utils.rgbHexToRgba(colorScheme[0]))); this.candyOverlay.setTint(argbFromRgba(Utils.rgbHexToRgba(colorScheme[1]))); + this.numberText.setText(Utils.padInt(this.pokemon.species.speciesId, 4)); this.numberText.setColor(this.getTextColor(!this.pokemon.isShiny() ? TextStyle.SUMMARY : TextStyle.SUMMARY_GOLD)); this.numberText.setShadowColor(this.getTextColor(!this.pokemon.isShiny() ? TextStyle.SUMMARY : TextStyle.SUMMARY_GOLD, true)); @@ -333,7 +359,7 @@ export default class SummaryUiHandler extends UiHandler { currentFriendship = 0; } - const friendshipCap = getStarterValueFriendshipCap(speciesStarters[this.pokemon.species.getRootSpeciesId()]); + const friendshipCap = getStarterValueFriendshipCap(speciesStarterCosts[this.pokemon.species.getRootSpeciesId()]); const candyCropY = 16 - (16 * (currentFriendship / friendshipCap)); if (this.candyShadow.visible) { @@ -345,6 +371,15 @@ export default class SummaryUiHandler extends UiHandler { this.candyShadow.setCrop(0, 0, 16, candyCropY); + if (this.friendshipShadow.visible) { + this.friendshipShadow.on("pointerover", () => this.scene.ui.showTooltip("", `${i18next.t("pokemonSummary:friendship")}`, true)); + this.friendshipShadow.on("pointerout", () => this.scene.ui.hideTooltip()); + } + + this.friendshipText.setText(`${this.pokemon?.friendship || "0"} / 255`); + + this.friendshipShadow.setCrop(0, 0, 16, 16 - (16 * ((this.pokemon?.friendship || 0) / 255))); + const doubleShiny = isFusion && this.pokemon.shiny && this.pokemon.fusionShiny; const baseVariant = !doubleShiny ? this.pokemon.getVariant() : this.pokemon.variant; @@ -373,22 +408,22 @@ export default class SummaryUiHandler extends UiHandler { this.genderText.setShadowColor(getGenderColor(this.pokemon.getGender(true), true)); switch (this.summaryUiMode) { - case SummaryUiMode.DEFAULT: - const page = args.length < 2 ? Page.PROFILE : args[2] as Page; - this.hideMoveEffect(true); - this.setCursor(page); - if (args.length > 3) { - this.selectCallback = args[3]; - } - break; - case SummaryUiMode.LEARN_MOVE: - this.newMove = args[2] as Move; - this.moveSelectFunction = args[3] as Function; + case SummaryUiMode.DEFAULT: + const page = args.length < 2 ? Page.PROFILE : args[2] as Page; + this.hideMoveEffect(true); + this.setCursor(page); + if (args.length > 3) { + this.selectCallback = args[3]; + } + break; + case SummaryUiMode.LEARN_MOVE: + this.newMove = args[2] as Move; + this.moveSelectFunction = args[3] as Function; - this.showMoveEffect(true); - this.setCursor(Page.MOVES); - this.showMoveSelect(); - break; + this.showMoveEffect(true); + this.setCursor(Page.MOVES); + this.showMoveSelect(); + break; } const fromSummary = args.length >= 2; @@ -456,25 +491,25 @@ export default class SummaryUiHandler extends UiHandler { success = true; } else { switch (button) { - case Button.UP: - success = this.setCursor(this.moveCursor ? this.moveCursor - 1 : 4); - break; - case Button.DOWN: - success = this.setCursor(this.moveCursor < 4 ? this.moveCursor + 1 : 0); - break; - case Button.LEFT: - this.moveSelect = false; - this.setCursor(Page.STATS); - if (this.summaryUiMode === SummaryUiMode.LEARN_MOVE) { - this.hideMoveEffect(); - this.destroyBlinkCursor(); - success = true; + case Button.UP: + success = this.setCursor(this.moveCursor ? this.moveCursor - 1 : 4); break; - } else { - this.hideMoveSelect(); - success = true; + case Button.DOWN: + success = this.setCursor(this.moveCursor < 4 ? this.moveCursor + 1 : 0); break; - } + case Button.LEFT: + this.moveSelect = false; + this.setCursor(Page.STATS); + if (this.summaryUiMode === SummaryUiMode.LEARN_MOVE) { + this.hideMoveEffect(); + this.destroyBlinkCursor(); + success = true; + break; + } else { + this.hideMoveSelect(); + success = true; + break; + } } } } else { @@ -513,35 +548,35 @@ export default class SummaryUiHandler extends UiHandler { } else { const pages = Utils.getEnumValues(Page); switch (button) { - case Button.UP: - case Button.DOWN: - if (this.summaryUiMode === SummaryUiMode.LEARN_MOVE) { - break; - } else if (!fromPartyMode) { - break; - } - const isDown = button === Button.DOWN; - const party = this.scene.getParty(); - const partyMemberIndex = this.pokemon ? party.indexOf(this.pokemon) : -1; - if ((isDown && partyMemberIndex < party.length - 1) || (!isDown && partyMemberIndex)) { - const page = this.cursor; - this.clear(); - this.show([ party[partyMemberIndex + (isDown ? 1 : -1)], this.summaryUiMode, page ]); - } - break; - case Button.LEFT: - if (this.cursor) { - success = this.setCursor(this.cursor - 1); - } - break; - case Button.RIGHT: - if (this.cursor < pages.length - 1) { - success = this.setCursor(this.cursor + 1); - if (this.summaryUiMode === SummaryUiMode.LEARN_MOVE && this.cursor === Page.MOVES) { - this.moveSelect = true; + case Button.UP: + case Button.DOWN: + if (this.summaryUiMode === SummaryUiMode.LEARN_MOVE) { + break; + } else if (!fromPartyMode) { + break; } - } - break; + const isDown = button === Button.DOWN; + const party = this.scene.getPlayerParty(); + const partyMemberIndex = this.pokemon ? party.indexOf(this.pokemon) : -1; + if ((isDown && partyMemberIndex < party.length - 1) || (!isDown && partyMemberIndex)) { + const page = this.cursor; + this.clear(); + this.show([ party[partyMemberIndex + (isDown ? 1 : -1)], this.summaryUiMode, page ]); + } + break; + case Button.LEFT: + if (this.cursor) { + success = this.setCursor(this.cursor - 1); + } + break; + case Button.RIGHT: + if (this.cursor < pages.length - 1) { + success = this.setCursor(this.cursor + 1); + if (this.summaryUiMode === SummaryUiMode.LEARN_MOVE && this.cursor === Page.MOVES) { + this.moveSelect = true; + } + } + break; } } } @@ -652,7 +687,7 @@ export default class SummaryUiHandler extends UiHandler { onComplete: () => { if (forward) { this.populatePageContainer(this.summaryPageContainer); - if (this.cursor===Page.MOVES) { + if (this.cursor === Page.MOVES) { this.moveCursorObj = null; this.showMoveSelect(); this.showMoveEffect(); @@ -697,307 +732,308 @@ export default class SummaryUiHandler extends UiHandler { } switch (page) { - case Page.PROFILE: - const profileContainer = this.scene.add.container(0, -pageBg.height); - pageContainer.add(profileContainer); + case Page.PROFILE: + const profileContainer = this.scene.add.container(0, -pageBg.height); + pageContainer.add(profileContainer); - const trainerText = addBBCodeTextObject(this.scene, 7, 12, `${i18next.t("pokemonSummary:ot")}/${getBBCodeFrag(loggedInUser?.username || i18next.t("pokemonSummary:unknown"), this.scene.gameData.gender === PlayerGender.FEMALE ? TextStyle.SUMMARY_PINK : TextStyle.SUMMARY_BLUE)}`, TextStyle.SUMMARY_ALT); - trainerText.setOrigin(0, 0); - profileContainer.add(trainerText); + // TODO: should add field for original trainer name to Pokemon object, to support gift/traded Pokemon from MEs + const trainerText = addBBCodeTextObject(this.scene, 7, 12, `${i18next.t("pokemonSummary:ot")}/${getBBCodeFrag(loggedInUser?.username || i18next.t("pokemonSummary:unknown"), this.scene.gameData.gender === PlayerGender.FEMALE ? TextStyle.SUMMARY_PINK : TextStyle.SUMMARY_BLUE)}`, TextStyle.SUMMARY_ALT); + trainerText.setOrigin(0, 0); + profileContainer.add(trainerText); - const trainerIdText = addTextObject(this.scene, 174, 12, this.scene.gameData.trainerId.toString(), TextStyle.SUMMARY_ALT); - trainerIdText.setOrigin(0, 0); - profileContainer.add(trainerIdText); + const trainerIdText = addTextObject(this.scene, 174, 12, this.scene.gameData.trainerId.toString(), TextStyle.SUMMARY_ALT); + trainerIdText.setOrigin(0, 0); + profileContainer.add(trainerIdText); - const typeLabel = addTextObject(this.scene, 7, 28, `${i18next.t("pokemonSummary:type")}/`, TextStyle.WINDOW_ALT); - typeLabel.setOrigin(0, 0); - profileContainer.add(typeLabel); + const typeLabel = addTextObject(this.scene, 7, 28, `${i18next.t("pokemonSummary:type")}/`, TextStyle.WINDOW_ALT); + typeLabel.setOrigin(0, 0); + profileContainer.add(typeLabel); - const getTypeIcon = (index: integer, type: Type, tera: boolean = false) => { - const xCoord = typeLabel.width * typeLabel.scale + 9 + 34 * index; - const typeIcon = !tera - ? this.scene.add.sprite(xCoord, 42, Utils.getLocalizedSpriteKey("types"), Type[type].toLowerCase()) - : this.scene.add.sprite(xCoord, 42, "type_tera"); - if (tera) { - typeIcon.setScale(0.5); - const typeRgb = getTypeRgb(type); - typeIcon.setTint(Phaser.Display.Color.GetColor(typeRgb[0], typeRgb[1], typeRgb[2])); - } - typeIcon.setOrigin(0, 1); - return typeIcon; - }; - - const types = this.pokemon?.getTypes(false, false, true)!; // TODO: is this bang correct? - profileContainer.add(getTypeIcon(0, types[0])); - if (types.length > 1) { - profileContainer.add(getTypeIcon(1, types[1])); - } - if (this.pokemon?.isTerastallized()) { - profileContainer.add(getTypeIcon(types.length, this.pokemon.getTeraType(), true)); - } - - if (this.pokemon?.getLuck()) { - const luckLabelText = addTextObject(this.scene, 141, 28, i18next.t("common:luckIndicator"), TextStyle.SUMMARY_ALT); - luckLabelText.setOrigin(0, 0); - profileContainer.add(luckLabelText); - - const luckText = addTextObject(this.scene, 141 + luckLabelText.displayWidth + 2, 28, this.pokemon.getLuck().toString(), TextStyle.SUMMARY); - luckText.setOrigin(0, 0); - luckText.setTint(getVariantTint((Math.min(this.pokemon.getLuck() - 1, 2)) as Variant)); - profileContainer.add(luckText); - } - - this.abilityContainer = { - labelImage: this.scene.add.image(0, 0, "summary_profile_ability"), - ability: this.pokemon?.getAbility(true)!, // TODO: is this bang correct? - nameText: null, - descriptionText: null}; - - const allAbilityInfo = [this.abilityContainer]; // Creates an array to iterate through - // Only add to the array and set up displaying a passive if it's unlocked - if (this.pokemon?.hasPassive()) { - this.passiveContainer = { - labelImage: this.scene.add.image(0, 0, "summary_profile_passive"), - ability: this.pokemon.getPassiveAbility(), - nameText: null, - descriptionText: null}; - allAbilityInfo.push(this.passiveContainer); - - // Sets up the pixel button prompt image - this.abilityPrompt = this.scene.add.image(0, 0, !this.scene.inputController?.gamepadSupport ? "summary_profile_prompt_z" : "summary_profile_prompt_a"); - this.abilityPrompt.setPosition(8, 43); - this.abilityPrompt.setVisible(true); - this.abilityPrompt.setOrigin(0, 0); - profileContainer.add(this.abilityPrompt); - } - - allAbilityInfo.forEach(abilityInfo => { - abilityInfo.labelImage.setPosition(17, 43); - abilityInfo.labelImage.setVisible(true); - abilityInfo.labelImage.setOrigin(0, 0); - profileContainer.add(abilityInfo.labelImage); - - abilityInfo.nameText = addTextObject(this.scene, 7, 66, abilityInfo.ability?.name!, TextStyle.SUMMARY_ALT); // TODO: is this bang correct? - abilityInfo.nameText.setOrigin(0, 1); - profileContainer.add(abilityInfo.nameText); - - abilityInfo.descriptionText = addTextObject(this.scene, 7, 69, abilityInfo.ability?.description!, TextStyle.WINDOW_ALT, { wordWrap: { width: 1224 } }); // TODO: is this bang correct? - abilityInfo.descriptionText.setOrigin(0, 0); - profileContainer.add(abilityInfo.descriptionText); - - // Sets up the mask that hides the description text to give an illusion of scrolling - const descriptionTextMaskRect = this.scene.make.graphics({}); - descriptionTextMaskRect.setScale(6); - descriptionTextMaskRect.fillStyle(0xFFFFFF); - descriptionTextMaskRect.beginPath(); - descriptionTextMaskRect.fillRect(110, 90.5, 206, 31); - - const abilityDescriptionTextMask = descriptionTextMaskRect.createGeometryMask(); - - abilityInfo.descriptionText.setMask(abilityDescriptionTextMask); - - const abilityDescriptionLineCount = Math.floor(abilityInfo.descriptionText.displayHeight / 14.83); - - // Animates the description text moving upwards - if (abilityDescriptionLineCount > 2) { - abilityInfo.descriptionText.setY(69); - this.descriptionScrollTween = this.scene.tweens.add({ - targets: abilityInfo.descriptionText, - delay: Utils.fixedInt(2000), - loop: -1, - hold: Utils.fixedInt(2000), - duration: Utils.fixedInt((abilityDescriptionLineCount - 2) * 2000), - y: `-=${14.83 * (abilityDescriptionLineCount - 2)}` - }); - } - }); - // Turn off visibility of passive info by default - this.passiveContainer?.labelImage.setVisible(false); - this.passiveContainer?.nameText?.setVisible(false); - this.passiveContainer?.descriptionText?.setVisible(false); - - const closeFragment = getBBCodeFrag("", TextStyle.WINDOW_ALT); - const rawNature = Utils.toReadableString(Nature[this.pokemon?.getNature()!]); // TODO: is this bang correct? - const nature = `${getBBCodeFrag(Utils.toReadableString(getNatureName(this.pokemon?.getNature()!)), TextStyle.SUMMARY_RED)}${closeFragment}`; // TODO: is this bang correct? - - const memoString = i18next.t("pokemonSummary:memoString", { - metFragment: i18next.t(`pokemonSummary:metFragment.${this.pokemon?.metBiome === -1? "apparently": "normal"}`, { - biome: `${getBBCodeFrag(getBiomeName(this.pokemon?.metBiome!), TextStyle.SUMMARY_RED)}${closeFragment}`, // TODO: is this bang correct? - level: `${getBBCodeFrag(this.pokemon?.metLevel.toString()!, TextStyle.SUMMARY_RED)}${closeFragment}`, // TODO: is this bang correct? - wave: `${getBBCodeFrag((this.pokemon?.metWave ? this.pokemon.metWave.toString()! : i18next.t("pokemonSummary:unknownTrainer")), TextStyle.SUMMARY_RED)}${closeFragment}`, - }), - natureFragment: i18next.t(`pokemonSummary:natureFragment.${rawNature}`, { nature: nature }) - }); - - const memoText = addBBCodeTextObject(this.scene, 7, 113, String(memoString), TextStyle.WINDOW_ALT); - memoText.setOrigin(0, 0); - profileContainer.add(memoText); - break; - case Page.STATS: - const statsContainer = this.scene.add.container(0, -pageBg.height); - pageContainer.add(statsContainer); - - PERMANENT_STATS.forEach((stat, s) => { - const statName = i18next.t(getStatKey(stat)); - const rowIndex = s % 3; - const colIndex = Math.floor(s / 3); - - const natureStatMultiplier = getNatureStatMultiplier(this.pokemon?.getNature()!, s); // TODO: is this bang correct? - - const statLabel = addTextObject(this.scene, 27 + 115 * colIndex + (colIndex === 1 ? 5 : 0), 56 + 16 * rowIndex, statName, natureStatMultiplier === 1 ? TextStyle.SUMMARY : natureStatMultiplier > 1 ? TextStyle.SUMMARY_PINK : TextStyle.SUMMARY_BLUE); - statLabel.setOrigin(0.5, 0); - statsContainer.add(statLabel); - - const statValueText = stat !== Stat.HP - ? Utils.formatStat(this.pokemon?.getStat(stat)!) // TODO: is this bang correct? - : `${Utils.formatStat(this.pokemon?.hp!, true)}/${Utils.formatStat(this.pokemon?.getMaxHp()!, true)}`; // TODO: are those bangs correct? - - const statValue = addTextObject(this.scene, 120 + 88 * colIndex, 56 + 16 * rowIndex, statValueText, TextStyle.WINDOW_ALT); - statValue.setOrigin(1, 0); - statsContainer.add(statValue); - }); - - const itemModifiers = (this.scene.findModifiers(m => m instanceof PokemonHeldItemModifier - && m.pokemonId === this.pokemon?.id, this.playerParty) as PokemonHeldItemModifier[]) - .sort(modifierSortFunc); - - itemModifiers.forEach((item, i) => { - const icon = item.getIcon(this.scene, true); - - icon.setPosition((i % 17) * 12 + 3, 14 * Math.floor(i / 17) + 15); - statsContainer.add(icon); - - icon.setInteractive(new Phaser.Geom.Rectangle(0, 0, 32, 32), Phaser.Geom.Rectangle.Contains); - icon.on("pointerover", () => (this.scene as BattleScene).ui.showTooltip(item.type.name, item.type.getDescription(this.scene), true)); - icon.on("pointerout", () => (this.scene as BattleScene).ui.hideTooltip()); - }); - - const pkmLvl = this.pokemon?.level!; // TODO: is this bang correct? - const pkmLvlExp = this.pokemon?.levelExp!; // TODO: is this bang correct? - const pkmExp = this.pokemon?.exp!; // TODO: is this bang correct? - const pkmSpeciesGrowthRate = this.pokemon?.species.growthRate!; // TODO: is this bang correct? - const relLvExp = getLevelRelExp(pkmLvl + 1, pkmSpeciesGrowthRate); - const expRatio = pkmLvl < this.scene.getMaxExpLevel() ? pkmLvlExp / relLvExp : 0; - - const expLabel = addTextObject(this.scene, 6, 112, i18next.t("pokemonSummary:expPoints"), TextStyle.SUMMARY); - expLabel.setOrigin(0, 0); - statsContainer.add(expLabel); - - const nextLvExpLabel = addTextObject(this.scene, 6, 128, i18next.t("pokemonSummary:nextLv"), TextStyle.SUMMARY); - nextLvExpLabel.setOrigin(0, 0); - statsContainer.add(nextLvExpLabel); - - const expText = addTextObject(this.scene, 208, 112, pkmExp.toString(), TextStyle.WINDOW_ALT); - expText.setOrigin(1, 0); - statsContainer.add(expText); - - const nextLvExp = pkmLvl < this.scene.getMaxExpLevel() - ? getLevelTotalExp(pkmLvl + 1, pkmSpeciesGrowthRate) - pkmExp - : 0; - const nextLvExpText = addTextObject(this.scene, 208, 128, nextLvExp.toString(), TextStyle.WINDOW_ALT); - nextLvExpText.setOrigin(1, 0); - statsContainer.add(nextLvExpText); - - const expOverlay = this.scene.add.image(140, 145, "summary_stats_overlay_exp"); - expOverlay.setOrigin(0, 0); - statsContainer.add(expOverlay); - - const expMaskRect = this.scene.make.graphics({}); - expMaskRect.setScale(6); - expMaskRect.fillStyle(0xFFFFFF); - expMaskRect.beginPath(); - expMaskRect.fillRect(140 + pageContainer.x, 145 + pageContainer.y + 21, Math.floor(expRatio * 64), 3); - - const expMask = expMaskRect.createGeometryMask(); - - expOverlay.setMask(expMask); - break; - case Page.MOVES: - this.movesContainer = this.scene.add.container(5, -pageBg.height + 26); - pageContainer.add(this.movesContainer); - - this.extraMoveRowContainer = this.scene.add.container(0, 64); - this.extraMoveRowContainer.setVisible(false); - this.movesContainer.add(this.extraMoveRowContainer); - - const extraRowOverlay = this.scene.add.image(-2, 1, "summary_moves_overlay_row"); - extraRowOverlay.setOrigin(0, 1); - this.extraMoveRowContainer.add(extraRowOverlay); - - const extraRowText = addTextObject(this.scene, 35, 0, this.summaryUiMode === SummaryUiMode.LEARN_MOVE && this.newMove ? this.newMove.name : i18next.t("pokemonSummary:cancel"), - this.summaryUiMode === SummaryUiMode.LEARN_MOVE ? TextStyle.SUMMARY_PINK : TextStyle.SUMMARY); - extraRowText.setOrigin(0, 1); - this.extraMoveRowContainer.add(extraRowText); - - if (this.summaryUiMode === SummaryUiMode.LEARN_MOVE) { - this.extraMoveRowContainer.setVisible(true); - - if (this.newMove && this.pokemon) { - const spriteKey = Utils.getLocalizedSpriteKey("types"); - const moveType = this.pokemon.getMoveType(this.newMove); - const newMoveTypeIcon = this.scene.add.sprite(0, 0, spriteKey, Type[moveType].toLowerCase()); - newMoveTypeIcon.setOrigin(0, 1); - this.extraMoveRowContainer.add(newMoveTypeIcon); - } - const ppOverlay = this.scene.add.image(163, -1, "summary_moves_overlay_pp"); - ppOverlay.setOrigin(0, 1); - this.extraMoveRowContainer.add(ppOverlay); - - const pp = Utils.padInt(this.newMove?.pp!, 2, " "); // TODO: is this bang correct? - const ppText = addTextObject(this.scene, 173, 1, `${pp}/${pp}`, TextStyle.WINDOW); - ppText.setOrigin(0, 1); - this.extraMoveRowContainer.add(ppText); - } - - this.moveRowsContainer = this.scene.add.container(0, 0); - this.movesContainer.add(this.moveRowsContainer); - - for (let m = 0; m < 4; m++) { - const move: PokemonMove | null = this.pokemon && this.pokemon.moveset.length > m ? this.pokemon?.moveset[m] : null; - const moveRowContainer = this.scene.add.container(0, 16 * m); - this.moveRowsContainer.add(moveRowContainer); - - if (move && this.pokemon) { - const spriteKey = Utils.getLocalizedSpriteKey("types"); - const moveType = this.pokemon.getMoveType(move.getMove()); - const typeIcon = this.scene.add.sprite(0, 0, spriteKey, Type[moveType].toLowerCase()); + const getTypeIcon = (index: integer, type: Type, tera: boolean = false) => { + const xCoord = typeLabel.width * typeLabel.scale + 9 + 34 * index; + const typeIcon = !tera + ? this.scene.add.sprite(xCoord, 42, Utils.getLocalizedSpriteKey("types"), Type[type].toLowerCase()) + : this.scene.add.sprite(xCoord, 42, "type_tera"); + if (tera) { + typeIcon.setScale(0.5); + const typeRgb = getTypeRgb(type); + typeIcon.setTint(Phaser.Display.Color.GetColor(typeRgb[0], typeRgb[1], typeRgb[2])); + } typeIcon.setOrigin(0, 1); - moveRowContainer.add(typeIcon); + return typeIcon; + }; + + const types = this.pokemon?.getTypes(false, false, true)!; // TODO: is this bang correct? + profileContainer.add(getTypeIcon(0, types[0])); + if (types.length > 1) { + profileContainer.add(getTypeIcon(1, types[1])); + } + if (this.pokemon?.isTerastallized()) { + profileContainer.add(getTypeIcon(types.length, this.pokemon.getTeraType(), true)); } - const moveText = addTextObject(this.scene, 35, 0, move ? move.getName() : "-", TextStyle.SUMMARY); - moveText.setOrigin(0, 1); - moveRowContainer.add(moveText); + if (this.pokemon?.getLuck()) { + const luckLabelText = addTextObject(this.scene, 141, 28, i18next.t("common:luckIndicator"), TextStyle.SUMMARY_ALT); + luckLabelText.setOrigin(0, 0); + profileContainer.add(luckLabelText); - const ppOverlay = this.scene.add.image(163, -1, "summary_moves_overlay_pp"); - ppOverlay.setOrigin(0, 1); - moveRowContainer.add(ppOverlay); - - const ppText = addTextObject(this.scene, 173, 1, "--/--", TextStyle.WINDOW); - ppText.setOrigin(0, 1); - - if (move) { - const maxPP = move.getMovePp(); - const pp = maxPP - move.ppUsed; - ppText.setText(`${Utils.padInt(pp, 2, " ")}/${Utils.padInt(maxPP, 2, " ")}`); + const luckText = addTextObject(this.scene, 141 + luckLabelText.displayWidth + 2, 28, this.pokemon.getLuck().toString(), TextStyle.SUMMARY); + luckText.setOrigin(0, 0); + luckText.setTint(getVariantTint((Math.min(this.pokemon.getLuck() - 1, 2)) as Variant)); + profileContainer.add(luckText); } - moveRowContainer.add(ppText); - } + this.abilityContainer = { + labelImage: this.scene.add.image(0, 0, "summary_profile_ability"), + ability: this.pokemon?.getAbility(true)!, // TODO: is this bang correct? + nameText: null, + descriptionText: null }; - this.moveDescriptionText = addTextObject(this.scene, 2, 84, "", TextStyle.WINDOW_ALT, { wordWrap: { width: 1212 } }); - this.movesContainer.add(this.moveDescriptionText); + const allAbilityInfo = [ this.abilityContainer ]; // Creates an array to iterate through + // Only add to the array and set up displaying a passive if it's unlocked + if (this.pokemon?.hasPassive()) { + this.passiveContainer = { + labelImage: this.scene.add.image(0, 0, "summary_profile_passive"), + ability: this.pokemon.getPassiveAbility(), + nameText: null, + descriptionText: null }; + allAbilityInfo.push(this.passiveContainer); - const moveDescriptionTextMaskRect = this.scene.make.graphics({}); - moveDescriptionTextMaskRect.setScale(6); - moveDescriptionTextMaskRect.fillStyle(0xFFFFFF); - moveDescriptionTextMaskRect.beginPath(); - moveDescriptionTextMaskRect.fillRect(112, 130, 202, 46); + // Sets up the pixel button prompt image + this.abilityPrompt = this.scene.add.image(0, 0, !this.scene.inputController?.gamepadSupport ? "summary_profile_prompt_z" : "summary_profile_prompt_a"); + this.abilityPrompt.setPosition(8, 43); + this.abilityPrompt.setVisible(true); + this.abilityPrompt.setOrigin(0, 0); + profileContainer.add(this.abilityPrompt); + } - const moveDescriptionTextMask = moveDescriptionTextMaskRect.createGeometryMask(); + allAbilityInfo.forEach(abilityInfo => { + abilityInfo.labelImage.setPosition(17, 43); + abilityInfo.labelImage.setVisible(true); + abilityInfo.labelImage.setOrigin(0, 0); + profileContainer.add(abilityInfo.labelImage); - this.moveDescriptionText.setMask(moveDescriptionTextMask); - break; + abilityInfo.nameText = addTextObject(this.scene, 7, 66, abilityInfo.ability?.name!, TextStyle.SUMMARY_ALT); // TODO: is this bang correct? + abilityInfo.nameText.setOrigin(0, 1); + profileContainer.add(abilityInfo.nameText); + + abilityInfo.descriptionText = addTextObject(this.scene, 7, 69, abilityInfo.ability?.description!, TextStyle.WINDOW_ALT, { wordWrap: { width: 1224 }}); // TODO: is this bang correct? + abilityInfo.descriptionText.setOrigin(0, 0); + profileContainer.add(abilityInfo.descriptionText); + + // Sets up the mask that hides the description text to give an illusion of scrolling + const descriptionTextMaskRect = this.scene.make.graphics({}); + descriptionTextMaskRect.setScale(6); + descriptionTextMaskRect.fillStyle(0xFFFFFF); + descriptionTextMaskRect.beginPath(); + descriptionTextMaskRect.fillRect(110, 90.5, 206, 31); + + const abilityDescriptionTextMask = descriptionTextMaskRect.createGeometryMask(); + + abilityInfo.descriptionText.setMask(abilityDescriptionTextMask); + + const abilityDescriptionLineCount = Math.floor(abilityInfo.descriptionText.displayHeight / 14.83); + + // Animates the description text moving upwards + if (abilityDescriptionLineCount > 2) { + abilityInfo.descriptionText.setY(69); + this.descriptionScrollTween = this.scene.tweens.add({ + targets: abilityInfo.descriptionText, + delay: Utils.fixedInt(2000), + loop: -1, + hold: Utils.fixedInt(2000), + duration: Utils.fixedInt((abilityDescriptionLineCount - 2) * 2000), + y: `-=${14.83 * (abilityDescriptionLineCount - 2)}` + }); + } + }); + // Turn off visibility of passive info by default + this.passiveContainer?.labelImage.setVisible(false); + this.passiveContainer?.nameText?.setVisible(false); + this.passiveContainer?.descriptionText?.setVisible(false); + + const closeFragment = getBBCodeFrag("", TextStyle.WINDOW_ALT); + const rawNature = Utils.toReadableString(Nature[this.pokemon?.getNature()!]); // TODO: is this bang correct? + const nature = `${getBBCodeFrag(Utils.toReadableString(getNatureName(this.pokemon?.getNature()!)), TextStyle.SUMMARY_RED)}${closeFragment}`; // TODO: is this bang correct? + + const memoString = i18next.t("pokemonSummary:memoString", { + metFragment: i18next.t(`pokemonSummary:metFragment.${this.pokemon?.metBiome === -1 ? "apparently" : "normal"}`, { + biome: `${getBBCodeFrag(getBiomeName(this.pokemon?.metBiome!), TextStyle.SUMMARY_RED)}${closeFragment}`, // TODO: is this bang correct? + level: `${getBBCodeFrag(this.pokemon?.metLevel.toString()!, TextStyle.SUMMARY_RED)}${closeFragment}`, // TODO: is this bang correct? + wave: `${getBBCodeFrag((this.pokemon?.metWave ? this.pokemon.metWave.toString()! : i18next.t("pokemonSummary:unknownTrainer")), TextStyle.SUMMARY_RED)}${closeFragment}`, + }), + natureFragment: i18next.t(`pokemonSummary:natureFragment.${rawNature}`, { nature: nature }) + }); + + const memoText = addBBCodeTextObject(this.scene, 7, 113, String(memoString), TextStyle.WINDOW_ALT); + memoText.setOrigin(0, 0); + profileContainer.add(memoText); + break; + case Page.STATS: + const statsContainer = this.scene.add.container(0, -pageBg.height); + pageContainer.add(statsContainer); + + PERMANENT_STATS.forEach((stat, s) => { + const statName = i18next.t(getStatKey(stat)); + const rowIndex = s % 3; + const colIndex = Math.floor(s / 3); + + const natureStatMultiplier = getNatureStatMultiplier(this.pokemon?.getNature()!, s); // TODO: is this bang correct? + + const statLabel = addTextObject(this.scene, 27 + 115 * colIndex + (colIndex === 1 ? 5 : 0), 56 + 16 * rowIndex, statName, natureStatMultiplier === 1 ? TextStyle.SUMMARY : natureStatMultiplier > 1 ? TextStyle.SUMMARY_PINK : TextStyle.SUMMARY_BLUE); + statLabel.setOrigin(0.5, 0); + statsContainer.add(statLabel); + + const statValueText = stat !== Stat.HP + ? Utils.formatStat(this.pokemon?.getStat(stat)!) // TODO: is this bang correct? + : `${Utils.formatStat(this.pokemon?.hp!, true)}/${Utils.formatStat(this.pokemon?.getMaxHp()!, true)}`; // TODO: are those bangs correct? + + const statValue = addTextObject(this.scene, 120 + 88 * colIndex, 56 + 16 * rowIndex, statValueText, TextStyle.WINDOW_ALT); + statValue.setOrigin(1, 0); + statsContainer.add(statValue); + }); + + const itemModifiers = (this.scene.findModifiers(m => m instanceof PokemonHeldItemModifier + && m.pokemonId === this.pokemon?.id, this.playerParty) as PokemonHeldItemModifier[]) + .sort(modifierSortFunc); + + itemModifiers.forEach((item, i) => { + const icon = item.getIcon(this.scene, true); + + icon.setPosition((i % 17) * 12 + 3, 14 * Math.floor(i / 17) + 15); + statsContainer.add(icon); + + icon.setInteractive(new Phaser.Geom.Rectangle(0, 0, 32, 32), Phaser.Geom.Rectangle.Contains); + icon.on("pointerover", () => (this.scene as BattleScene).ui.showTooltip(item.type.name, item.type.getDescription(this.scene), true)); + icon.on("pointerout", () => (this.scene as BattleScene).ui.hideTooltip()); + }); + + const pkmLvl = this.pokemon?.level!; // TODO: is this bang correct? + const pkmLvlExp = this.pokemon?.levelExp!; // TODO: is this bang correct? + const pkmExp = this.pokemon?.exp!; // TODO: is this bang correct? + const pkmSpeciesGrowthRate = this.pokemon?.species.growthRate!; // TODO: is this bang correct? + const relLvExp = getLevelRelExp(pkmLvl + 1, pkmSpeciesGrowthRate); + const expRatio = pkmLvl < this.scene.getMaxExpLevel() ? pkmLvlExp / relLvExp : 0; + + const expLabel = addTextObject(this.scene, 6, 112, i18next.t("pokemonSummary:expPoints"), TextStyle.SUMMARY); + expLabel.setOrigin(0, 0); + statsContainer.add(expLabel); + + const nextLvExpLabel = addTextObject(this.scene, 6, 128, i18next.t("pokemonSummary:nextLv"), TextStyle.SUMMARY); + nextLvExpLabel.setOrigin(0, 0); + statsContainer.add(nextLvExpLabel); + + const expText = addTextObject(this.scene, 208, 112, pkmExp.toString(), TextStyle.WINDOW_ALT); + expText.setOrigin(1, 0); + statsContainer.add(expText); + + const nextLvExp = pkmLvl < this.scene.getMaxExpLevel() + ? getLevelTotalExp(pkmLvl + 1, pkmSpeciesGrowthRate) - pkmExp + : 0; + const nextLvExpText = addTextObject(this.scene, 208, 128, nextLvExp.toString(), TextStyle.WINDOW_ALT); + nextLvExpText.setOrigin(1, 0); + statsContainer.add(nextLvExpText); + + const expOverlay = this.scene.add.image(140, 145, "summary_stats_overlay_exp"); + expOverlay.setOrigin(0, 0); + statsContainer.add(expOverlay); + + const expMaskRect = this.scene.make.graphics({}); + expMaskRect.setScale(6); + expMaskRect.fillStyle(0xFFFFFF); + expMaskRect.beginPath(); + expMaskRect.fillRect(140 + pageContainer.x, 145 + pageContainer.y + 21, Math.floor(expRatio * 64), 3); + + const expMask = expMaskRect.createGeometryMask(); + + expOverlay.setMask(expMask); + break; + case Page.MOVES: + this.movesContainer = this.scene.add.container(5, -pageBg.height + 26); + pageContainer.add(this.movesContainer); + + this.extraMoveRowContainer = this.scene.add.container(0, 64); + this.extraMoveRowContainer.setVisible(false); + this.movesContainer.add(this.extraMoveRowContainer); + + const extraRowOverlay = this.scene.add.image(-2, 1, "summary_moves_overlay_row"); + extraRowOverlay.setOrigin(0, 1); + this.extraMoveRowContainer.add(extraRowOverlay); + + const extraRowText = addTextObject(this.scene, 35, 0, this.summaryUiMode === SummaryUiMode.LEARN_MOVE && this.newMove ? this.newMove.name : i18next.t("pokemonSummary:cancel"), + this.summaryUiMode === SummaryUiMode.LEARN_MOVE ? TextStyle.SUMMARY_PINK : TextStyle.SUMMARY); + extraRowText.setOrigin(0, 1); + this.extraMoveRowContainer.add(extraRowText); + + if (this.summaryUiMode === SummaryUiMode.LEARN_MOVE) { + this.extraMoveRowContainer.setVisible(true); + + if (this.newMove && this.pokemon) { + const spriteKey = Utils.getLocalizedSpriteKey("types"); + const moveType = this.pokemon.getMoveType(this.newMove); + const newMoveTypeIcon = this.scene.add.sprite(0, 0, spriteKey, Type[moveType].toLowerCase()); + newMoveTypeIcon.setOrigin(0, 1); + this.extraMoveRowContainer.add(newMoveTypeIcon); + } + const ppOverlay = this.scene.add.image(163, -1, "summary_moves_overlay_pp"); + ppOverlay.setOrigin(0, 1); + this.extraMoveRowContainer.add(ppOverlay); + + const pp = Utils.padInt(this.newMove?.pp!, 2, " "); // TODO: is this bang correct? + const ppText = addTextObject(this.scene, 173, 1, `${pp}/${pp}`, TextStyle.WINDOW); + ppText.setOrigin(0, 1); + this.extraMoveRowContainer.add(ppText); + } + + this.moveRowsContainer = this.scene.add.container(0, 0); + this.movesContainer.add(this.moveRowsContainer); + + for (let m = 0; m < 4; m++) { + const move: PokemonMove | null = this.pokemon && this.pokemon.moveset.length > m ? this.pokemon?.moveset[m] : null; + const moveRowContainer = this.scene.add.container(0, 16 * m); + this.moveRowsContainer.add(moveRowContainer); + + if (move && this.pokemon) { + const spriteKey = Utils.getLocalizedSpriteKey("types"); + const moveType = this.pokemon.getMoveType(move.getMove()); + const typeIcon = this.scene.add.sprite(0, 0, spriteKey, Type[moveType].toLowerCase()); + typeIcon.setOrigin(0, 1); + moveRowContainer.add(typeIcon); + } + + const moveText = addTextObject(this.scene, 35, 0, move ? move.getName() : "-", TextStyle.SUMMARY); + moveText.setOrigin(0, 1); + moveRowContainer.add(moveText); + + const ppOverlay = this.scene.add.image(163, -1, "summary_moves_overlay_pp"); + ppOverlay.setOrigin(0, 1); + moveRowContainer.add(ppOverlay); + + const ppText = addTextObject(this.scene, 173, 1, "--/--", TextStyle.WINDOW); + ppText.setOrigin(0, 1); + + if (move) { + const maxPP = move.getMovePp(); + const pp = maxPP - move.ppUsed; + ppText.setText(`${Utils.padInt(pp, 2, " ")}/${Utils.padInt(maxPP, 2, " ")}`); + } + + moveRowContainer.add(ppText); + } + + this.moveDescriptionText = addTextObject(this.scene, 2, 84, "", TextStyle.WINDOW_ALT, { wordWrap: { width: 1212 }}); + this.movesContainer.add(this.moveDescriptionText); + + const moveDescriptionTextMaskRect = this.scene.make.graphics({}); + moveDescriptionTextMaskRect.setScale(6); + moveDescriptionTextMaskRect.fillStyle(0xFFFFFF); + moveDescriptionTextMaskRect.beginPath(); + moveDescriptionTextMaskRect.fillRect(112, 130, 202, 46); + + const moveDescriptionTextMask = moveDescriptionTextMaskRect.createGeometryMask(); + + this.moveDescriptionText.setMask(moveDescriptionTextMask); + break; } } diff --git a/src/ui/target-select-ui-handler.ts b/src/ui/target-select-ui-handler.ts index 3cdda984d3c..249ae7b8b01 100644 --- a/src/ui/target-select-ui-handler.ts +++ b/src/ui/target-select-ui-handler.ts @@ -4,7 +4,7 @@ import { Mode } from "./ui"; import UiHandler from "./ui-handler"; import * as Utils from "../utils"; import { getMoveTargets } from "../data/move"; -import {Button} from "#enums/buttons"; +import { Button } from "#enums/buttons"; import { Moves } from "#enums/moves"; import Pokemon from "#app/field/pokemon"; import { ModifierBar } from "#app/modifier/modifier"; @@ -13,9 +13,11 @@ import { SubstituteTag } from "#app/data/battler-tags"; export type TargetSelectCallback = (targets: BattlerIndex[]) => void; export default class TargetSelectUiHandler extends UiHandler { - private fieldIndex: integer; + private fieldIndex: number; private move: Moves; private targetSelectCallback: TargetSelectCallback; + private cursor0: number; // associated with BattlerIndex.PLAYER + private cursor1: number; // associated with BattlerIndex.PLAYER_2 private isMultipleTargets: boolean = false; private targets: BattlerIndex[]; @@ -42,8 +44,9 @@ export default class TargetSelectUiHandler extends UiHandler { this.fieldIndex = args[0] as integer; this.move = args[1] as Moves; this.targetSelectCallback = args[2] as TargetSelectCallback; + const user = this.scene.getPlayerField()[this.fieldIndex]; - const moveTargets = getMoveTargets(this.scene.getPlayerField()[this.fieldIndex], this.move); + const moveTargets = getMoveTargets(user, this.move); this.targets = moveTargets.targets; this.isMultipleTargets = moveTargets.multiple ?? false; @@ -53,44 +56,71 @@ export default class TargetSelectUiHandler extends UiHandler { this.enemyModifiers = this.scene.getModifierBar(true); - this.setCursor(this.targets.includes(this.cursor) ? this.cursor : this.targets[0]); - + if (this.fieldIndex === BattlerIndex.PLAYER) { + this.resetCursor(this.cursor0, user); + } else if (this.fieldIndex === BattlerIndex.PLAYER_2) { + this.resetCursor(this.cursor1, user); + } return true; } + /** + * Determines what value to assign the main cursor based on the previous turn's target or the user's status + * @param cursorN the cursor associated with the user's field index + * @param user the Pokemon using the move + */ + resetCursor(cursorN: number, user: Pokemon): void { + if (!Utils.isNullOrUndefined(cursorN)) { + if ([ BattlerIndex.PLAYER, BattlerIndex.PLAYER_2 ].includes(cursorN) || user.battleSummonData.waveTurnCount === 1) { + // Reset cursor on the first turn of a fight or if an ally was targeted last turn + cursorN = -1; + } + } + this.setCursor(this.targets.includes(cursorN) ? cursorN : this.targets[0]); + } + processInput(button: Button): boolean { const ui = this.getUi(); let success = false; if (button === Button.ACTION || button === Button.CANCEL) { - const targetIndexes: BattlerIndex[] = this.isMultipleTargets ? this.targets : [this.cursor]; + const targetIndexes: BattlerIndex[] = this.isMultipleTargets ? this.targets : [ this.cursor ]; this.targetSelectCallback(button === Button.ACTION ? targetIndexes : []); success = true; + if (this.fieldIndex === BattlerIndex.PLAYER) { + if (Utils.isNullOrUndefined(this.cursor0) || this.cursor0 !== this.cursor) { + this.cursor0 = this.cursor; + } + } else if (this.fieldIndex === BattlerIndex.PLAYER_2) { + if (Utils.isNullOrUndefined(this.cursor1) || this.cursor1 !== this.cursor) { + this.cursor1 = this.cursor; + } + } } else if (this.isMultipleTargets) { success = false; } else { switch (button) { - case Button.UP: - if (this.cursor < BattlerIndex.ENEMY && this.targets.findIndex(t => t >= BattlerIndex.ENEMY) > -1) { - success = this.setCursor(this.targets.find(t => t >= BattlerIndex.ENEMY)!); // TODO: is the bang correct here? - } - break; - case Button.DOWN: - if (this.cursor >= BattlerIndex.ENEMY && this.targets.findIndex(t => t < BattlerIndex.ENEMY) > -1) { - success = this.setCursor(this.targets.find(t => t < BattlerIndex.ENEMY)!); // TODO: is the bang correct here? - } - break; - case Button.LEFT: - if (this.cursor % 2 && this.targets.findIndex(t => t === this.cursor - 1) > -1) { - success = this.setCursor(this.cursor - 1); - } - break; - case Button.RIGHT: - if (!(this.cursor % 2) && this.targets.findIndex(t => t === this.cursor + 1) > -1) { - success = this.setCursor(this.cursor + 1); - } - break; + case Button.UP: + if (this.cursor < BattlerIndex.ENEMY && this.targets.findIndex(t => t >= BattlerIndex.ENEMY) > -1) { + success = this.setCursor(this.targets.find(t => t >= BattlerIndex.ENEMY)!); // TODO: is the bang correct here? + } + break; + case Button.DOWN: + if (this.cursor >= BattlerIndex.ENEMY && this.targets.findIndex(t => t < BattlerIndex.ENEMY) > -1) { + success = this.setCursor(this.targets.find(t => t < BattlerIndex.ENEMY)!); // TODO: is the bang correct here? + } + break; + case Button.LEFT: + if (this.cursor % 2 && this.targets.findIndex(t => t === this.cursor - 1) > -1) { + success = this.setCursor(this.cursor - 1); + } + break; + case Button.RIGHT: + if (!(this.cursor % 2) && this.targets.findIndex(t => t === this.cursor + 1) > -1) { + success = this.setCursor(this.cursor + 1); + } + break; } } @@ -152,7 +182,6 @@ export default class TargetSelectUiHandler extends UiHandler { yoyo: true })); }); - return ret; } diff --git a/src/ui/test-dialogue-ui-handler.ts b/src/ui/test-dialogue-ui-handler.ts index 3f353bbc461..bf0e7f6723f 100644 --- a/src/ui/test-dialogue-ui-handler.ts +++ b/src/ui/test-dialogue-ui-handler.ts @@ -1,4 +1,4 @@ -import { FormModalUiHandler } from "./form-modal-ui-handler"; +import { FormModalUiHandler, InputFieldConfig } from "./form-modal-ui-handler"; import { ModalConfig } from "./modal-ui-handler"; import i18next from "i18next"; import { PlayerPokemon } from "#app/field/pokemon"; @@ -17,15 +17,15 @@ export default class TestDialogueUiHandler extends FormModalUiHandler { setup() { super.setup(); - const flattenKeys = (object, topKey?: string, midleKey?: string[]): Array => { - return Object.keys(object).map((t, i) => { + const flattenKeys = (object?: any, topKey?: string, midleKey?: string[]): Array => { + return Object.keys(object ?? {}).map((t, i) => { const value = Object.values(object)[i]; if (typeof value === "object" && !isNullOrUndefined(value)) { // we check for not null or undefined here because if the language json file has a null key, the typeof will still be an object, but that object will be null, causing issues // If the value is an object, execute the same process // si el valor es un objeto ejecuta el mismo proceso - return flattenKeys(value, topKey ?? t, topKey ? midleKey ? [...midleKey, t] : [t] : undefined).filter((t) => t.length > 0); + return flattenKeys(value, topKey ?? t, topKey ? midleKey ? [ ...midleKey, t ] : [ t ] : undefined).filter((t) => t.length > 0); } else if (typeof value === "string" || isNullOrUndefined(value)) { // we check for null or undefined here as per above - the typeof is still an object but the value is null so we need to exit out of this and pass the null key // Return in the format expected by i18next @@ -43,10 +43,6 @@ export default class TestDialogueUiHandler extends FormModalUiHandler { return "Test Dialogue"; } - getFields(config?: ModalConfig): string[] { - return [ "Dialogue" ]; - } - getWidth(config?: ModalConfig): number { return 300; } @@ -68,13 +64,20 @@ export default class TestDialogueUiHandler extends FormModalUiHandler { return super.getReadableErrorMessage(error); } + override getInputFieldConfigs(): InputFieldConfig[] { + return [{ label: "Dialogue" }]; + } + show(args: any[]): boolean { const ui = this.getUi(); + const hasTitle = !!this.getModalTitle(); + this.updateFields(this.getInputFieldConfigs(), hasTitle); + this.updateContainer(args[0] as ModalConfig); const input = this.inputs[0]; input.setMaxLength(255); input.on("keydown", (inputObject, evt: KeyboardEvent) => { - if (["escape", "space"].some((v) => v === evt.key.toLowerCase() || v === evt.code.toLowerCase()) && ui.getMode() === Mode.AUTO_COMPLETE) { + if ([ "escape", "space" ].some((v) => v === evt.key.toLowerCase() || v === evt.code.toLowerCase()) && ui.getMode() === Mode.AUTO_COMPLETE) { // Delete autocomplete list and recovery focus. inputObject.on("blur", () => inputObject.node.focus(), { once: true }); ui.revertMode(); diff --git a/src/ui/text.ts b/src/ui/text.ts index 58b6343144a..17ae02be9ef 100644 --- a/src/ui/text.ts +++ b/src/ui/text.ts @@ -22,7 +22,8 @@ export enum TextStyle { SUMMARY_GOLD, SUMMARY_GRAY, SUMMARY_GREEN, - MONEY, + MONEY, // Money default styling (pale yellow) + MONEY_WINDOW, // Money displayed in Windows (needs different colors based on theme) STATS_LABEL, STATS_VALUE, SETTINGS_VALUE, @@ -38,7 +39,9 @@ export enum TextStyle { MOVE_PP_EMPTY, SMALLER_WINDOW_ALT, BGM_BAR, - PERFECT_IV + PERFECT_IV, + ME_OPTION_DEFAULT, // Default style for choices in ME + ME_OPTION_SPECIAL, // Style for choices with special requirements in ME } export interface TextStyleOptions { @@ -129,84 +132,87 @@ export function getTextStyleOptions(style: TextStyle, uiTheme: UiTheme, extraSty } switch (style) { - case TextStyle.SUMMARY: - case TextStyle.SUMMARY_ALT: - case TextStyle.SUMMARY_BLUE: - case TextStyle.SUMMARY_RED: - case TextStyle.SUMMARY_PINK: - case TextStyle.SUMMARY_GOLD: - case TextStyle.SUMMARY_GRAY: - case TextStyle.SUMMARY_GREEN: - case TextStyle.WINDOW: - case TextStyle.WINDOW_ALT: - shadowXpos = 3; - shadowYpos = 3; - break; - case TextStyle.STATS_LABEL: - let fontSizeLabel = "96px"; - switch (lang) { - case "de": + case TextStyle.SUMMARY: + case TextStyle.SUMMARY_ALT: + case TextStyle.SUMMARY_BLUE: + case TextStyle.SUMMARY_RED: + case TextStyle.SUMMARY_PINK: + case TextStyle.SUMMARY_GOLD: + case TextStyle.SUMMARY_GRAY: + case TextStyle.SUMMARY_GREEN: + case TextStyle.WINDOW: + case TextStyle.WINDOW_ALT: + case TextStyle.ME_OPTION_DEFAULT: + case TextStyle.ME_OPTION_SPECIAL: shadowXpos = 3; shadowYpos = 3; - fontSizeLabel = "80px"; break; - default: - fontSizeLabel = "96px"; + case TextStyle.STATS_LABEL: + let fontSizeLabel = "96px"; + switch (lang) { + case "de": + shadowXpos = 3; + shadowYpos = 3; + fontSizeLabel = "80px"; + break; + default: + fontSizeLabel = "96px"; + break; + } + styleOptions.fontSize = fontSizeLabel; break; - } - styleOptions.fontSize = fontSizeLabel; - break; - case TextStyle.STATS_VALUE: - shadowXpos = 3; - shadowYpos = 3; - let fontSizeValue = "96px"; - switch (lang) { - case "de": - fontSizeValue = "80px"; + case TextStyle.STATS_VALUE: + shadowXpos = 3; + shadowYpos = 3; + let fontSizeValue = "96px"; + switch (lang) { + case "de": + fontSizeValue = "80px"; + break; + default: + fontSizeValue = "96px"; + break; + } + styleOptions.fontSize = fontSizeValue; break; - default: - fontSizeValue = "96px"; + case TextStyle.MESSAGE: + case TextStyle.SETTINGS_LABEL: + case TextStyle.SETTINGS_LOCKED: + case TextStyle.SETTINGS_SELECTED: + break; + case TextStyle.BATTLE_INFO: + case TextStyle.MONEY: + case TextStyle.MONEY_WINDOW: + case TextStyle.TOOLTIP_TITLE: + styleOptions.fontSize = defaultFontSize - 24; + shadowXpos = 3.5; + shadowYpos = 3.5; + break; + case TextStyle.PARTY: + case TextStyle.PARTY_RED: + styleOptions.fontSize = defaultFontSize - 30; + styleOptions.fontFamily = "pkmnems"; + break; + case TextStyle.TOOLTIP_CONTENT: + styleOptions.fontSize = defaultFontSize - 32; + shadowXpos = 3; + shadowYpos = 3; + break; + case TextStyle.MOVE_INFO_CONTENT: + styleOptions.fontSize = defaultFontSize - 40; + shadowXpos = 3; + shadowYpos = 3; + break; + case TextStyle.SMALLER_WINDOW_ALT: + styleOptions.fontSize = defaultFontSize - 36; + shadowXpos = 3; + shadowYpos = 3; + break; + case TextStyle.BGM_BAR: + styleOptions.fontSize = defaultFontSize - 24; + shadowXpos = 3; + shadowYpos = 3; break; - } - styleOptions.fontSize = fontSizeValue; - break; - case TextStyle.MESSAGE: - case TextStyle.SETTINGS_LABEL: - case TextStyle.SETTINGS_LOCKED: - case TextStyle.SETTINGS_SELECTED: - break; - case TextStyle.BATTLE_INFO: - case TextStyle.MONEY: - case TextStyle.TOOLTIP_TITLE: - styleOptions.fontSize = defaultFontSize - 24; - shadowXpos = 3.5; - shadowYpos = 3.5; - break; - case TextStyle.PARTY: - case TextStyle.PARTY_RED: - styleOptions.fontSize = defaultFontSize - 30; - styleOptions.fontFamily = "pkmnems"; - break; - case TextStyle.TOOLTIP_CONTENT: - styleOptions.fontSize = defaultFontSize - 32; - shadowXpos = 3; - shadowYpos = 3; - break; - case TextStyle.MOVE_INFO_CONTENT: - styleOptions.fontSize = defaultFontSize - 40; - shadowXpos = 3; - shadowYpos = 3; - break; - case TextStyle.SMALLER_WINDOW_ALT: - styleOptions.fontSize = defaultFontSize - 36; - shadowXpos = 3; - shadowYpos = 3; - break; - case TextStyle.BGM_BAR: - styleOptions.fontSize = defaultFontSize - 24; - shadowXpos = 3; - shadowYpos = 3; - break; } const shadowColor = getTextColor(style, true, uiTheme); @@ -238,12 +244,21 @@ export function getBBCodeFrag(content: string, textStyle: TextStyle, uiTheme: Ui * - "red text" with TextStyle.SUMMARY_RED applied * @param content string with styling that need to be applied for BBCodeTextObject * @param primaryStyle Primary style is required in order to escape BBCode styling properly. - * @param uiTheme + * @param uiTheme the {@linkcode UiTheme} to get TextStyle for + * @param forWindow set to `true` if the text is to be displayed in a window ({@linkcode BattleScene.addWindow}) + * it will replace all instances of the default MONEY TextStyle by {@linkcode TextStyle.MONEY_WINDOW} */ -export function getTextWithColors(content: string, primaryStyle: TextStyle, uiTheme: UiTheme = UiTheme.DEFAULT): string { +export function getTextWithColors(content: string, primaryStyle: TextStyle, uiTheme: UiTheme, forWindow?: boolean): string { // Apply primary styling before anything else let text = getBBCodeFrag(content, primaryStyle, uiTheme) + "[/color][/shadow]"; - const primaryStyleString = [...text.match(new RegExp(/\[color=[^\[]*\]\[shadow=[^\[]*\]/i))!][0]; + const primaryStyleString = [ ...text.match(new RegExp(/\[color=[^\[]*\]\[shadow=[^\[]*\]/i))! ][0]; + + /* For money text displayed in game windows, we can't use the default {@linkcode TextStyle.MONEY} + * or it will look wrong in legacy mode because of the different window background color + * So, for text to be displayed in windows replace all "@[MONEY]" with "@[MONEY_WINDOW]" */ + if (forWindow) { + text = text.replace(/@\[MONEY\]/g, (_substring: string) => "@[MONEY_WINDOW]"); + } // Set custom colors text = text.replace(/@\[([^{]*)\]{([^}]*)}/gi, (substring, textStyle: string, textToColor: string) => { @@ -257,110 +272,122 @@ export function getTextWithColors(content: string, primaryStyle: TextStyle, uiTh export function getTextColor(textStyle: TextStyle, shadow?: boolean, uiTheme: UiTheme = UiTheme.DEFAULT): string { const isLegacyTheme = uiTheme === UiTheme.LEGACY; switch (textStyle) { - case TextStyle.MESSAGE: - return !shadow ? "#f8f8f8" : "#6b5a73"; - case TextStyle.WINDOW: - case TextStyle.MOVE_INFO_CONTENT: - case TextStyle.MOVE_PP_FULL: - case TextStyle.TOOLTIP_CONTENT: - case TextStyle.SETTINGS_VALUE: - if (isLegacyTheme) { + case TextStyle.MESSAGE: + return !shadow ? "#f8f8f8" : "#6b5a73"; + case TextStyle.WINDOW: + case TextStyle.MOVE_INFO_CONTENT: + case TextStyle.MOVE_PP_FULL: + case TextStyle.TOOLTIP_CONTENT: + case TextStyle.SETTINGS_VALUE: + if (isLegacyTheme) { + return !shadow ? "#484848" : "#d0d0c8"; + } + return !shadow ? "#f8f8f8" : "#6b5a73"; + case TextStyle.MOVE_PP_HALF_FULL: + if (isLegacyTheme) { + return !shadow ? "#a68e17" : "#ebd773"; + } + return !shadow ? "#ccbe00" : "#6e672c"; + case TextStyle.MOVE_PP_NEAR_EMPTY: + if (isLegacyTheme) { + return !shadow ? "#d64b00" : "#f7b18b"; + } + return !shadow ? "#d64b00" : "#69402a"; + case TextStyle.MOVE_PP_EMPTY: + if (isLegacyTheme) { + return !shadow ? "#e13d3d" : "#fca2a2"; + } + return !shadow ? "#e13d3d" : "#632929"; + case TextStyle.WINDOW_ALT: return !shadow ? "#484848" : "#d0d0c8"; - } - return !shadow ? "#f8f8f8" : "#6b5a73"; - case TextStyle.MOVE_PP_HALF_FULL: - if (isLegacyTheme) { - return !shadow ? "#a68e17" : "#ebd773"; - } - return !shadow ? "#ccbe00" : "#6e672c"; - case TextStyle.MOVE_PP_NEAR_EMPTY: - if (isLegacyTheme) { - return !shadow ? "#d64b00" : "#f7b18b"; - } - return !shadow ? "#d64b00" : "#69402a"; - case TextStyle.MOVE_PP_EMPTY: - if (isLegacyTheme) { - return !shadow ? "#e13d3d" : "#fca2a2"; - } - return !shadow ? "#e13d3d" : "#632929"; - case TextStyle.WINDOW_ALT: - return !shadow ? "#484848" : "#d0d0c8"; - case TextStyle.BATTLE_INFO: - if (isLegacyTheme) { - return !shadow ? "#404040" : "#ded6b5"; - } - return !shadow ? "#f8f8f8" : "#6b5a73"; - case TextStyle.PARTY: - return !shadow ? "#f8f8f8" : "#707070"; - case TextStyle.PARTY_RED: - return !shadow ? "#f89890" : "#984038"; - case TextStyle.SUMMARY: - return !shadow ? "#f8f8f8" : "#636363"; - case TextStyle.SUMMARY_ALT: - if (isLegacyTheme) { + case TextStyle.BATTLE_INFO: + if (isLegacyTheme) { + return !shadow ? "#404040" : "#ded6b5"; + } + return !shadow ? "#f8f8f8" : "#6b5a73"; + case TextStyle.PARTY: + return !shadow ? "#f8f8f8" : "#707070"; + case TextStyle.PARTY_RED: + return !shadow ? "#f89890" : "#984038"; + case TextStyle.SUMMARY: return !shadow ? "#f8f8f8" : "#636363"; - } - return !shadow ? "#484848" : "#d0d0c8"; - case TextStyle.SUMMARY_RED: - case TextStyle.TOOLTIP_TITLE: - return !shadow ? "#e70808" : "#ffbd73"; - case TextStyle.SUMMARY_BLUE: - return !shadow ? "#40c8f8" : "#006090"; - case TextStyle.SUMMARY_PINK: - return !shadow ? "#f89890" : "#984038"; - case TextStyle.SUMMARY_GOLD: - case TextStyle.MONEY: - return !shadow ? "#e8e8a8" : "#a0a060"; - case TextStyle.SETTINGS_LOCKED: - case TextStyle.SUMMARY_GRAY: - return !shadow ? "#a0a0a0" : "#636363"; - case TextStyle.STATS_LABEL: - return !shadow ? "#f8b050" : "#c07800"; - case TextStyle.STATS_VALUE: - if (isLegacyTheme) { + case TextStyle.SUMMARY_ALT: + if (isLegacyTheme) { + return !shadow ? "#f8f8f8" : "#636363"; + } return !shadow ? "#484848" : "#d0d0c8"; - } - return !shadow ? "#f8f8f8" : "#6b5a73"; - case TextStyle.SUMMARY_GREEN: - return !shadow ? "#78c850" : "#306850"; - case TextStyle.SETTINGS_LABEL: - case TextStyle.PERFECT_IV: - return !shadow ? "#f8b050" : "#c07800"; - case TextStyle.SETTINGS_SELECTED: - return !shadow ? "#f88880" : "#f83018"; - case TextStyle.SMALLER_WINDOW_ALT: - return !shadow ? "#484848" : "#d0d0c8"; - case TextStyle.BGM_BAR: - return !shadow ? "#f8f8f8" : "#6b5a73"; + case TextStyle.SUMMARY_RED: + case TextStyle.TOOLTIP_TITLE: + return !shadow ? "#e70808" : "#ffbd73"; + case TextStyle.SUMMARY_BLUE: + return !shadow ? "#40c8f8" : "#006090"; + case TextStyle.SUMMARY_PINK: + return !shadow ? "#f89890" : "#984038"; + case TextStyle.SUMMARY_GOLD: + case TextStyle.MONEY: + return !shadow ? "#e8e8a8" : "#a0a060"; // Pale Yellow/Gold + case TextStyle.MONEY_WINDOW: + if (isLegacyTheme) { + return !shadow ? "#f8b050" : "#c07800"; // Gold + } + return !shadow ? "#e8e8a8" : "#a0a060"; // Pale Yellow/Gold + case TextStyle.SETTINGS_LOCKED: + case TextStyle.SUMMARY_GRAY: + return !shadow ? "#a0a0a0" : "#636363"; + case TextStyle.STATS_LABEL: + return !shadow ? "#f8b050" : "#c07800"; + case TextStyle.STATS_VALUE: + if (isLegacyTheme) { + return !shadow ? "#484848" : "#d0d0c8"; + } + return !shadow ? "#f8f8f8" : "#6b5a73"; + case TextStyle.SUMMARY_GREEN: + return !shadow ? "#78c850" : "#306850"; + case TextStyle.SETTINGS_LABEL: + case TextStyle.PERFECT_IV: + return !shadow ? "#f8b050" : "#c07800"; + case TextStyle.SETTINGS_SELECTED: + return !shadow ? "#f88880" : "#f83018"; + case TextStyle.SMALLER_WINDOW_ALT: + return !shadow ? "#484848" : "#d0d0c8"; + case TextStyle.BGM_BAR: + return !shadow ? "#f8f8f8" : "#6b5a73"; + case TextStyle.ME_OPTION_DEFAULT: + return !shadow ? "#f8f8f8" : "#6b5a73"; // White + case TextStyle.ME_OPTION_SPECIAL: + if (isLegacyTheme) { + return !shadow ? "#f8b050" : "#c07800"; // Gold + } + return !shadow ? "#78c850" : "#306850"; // Green } } export function getModifierTierTextTint(tier: ModifierTier): integer { switch (tier) { - case ModifierTier.COMMON: - return 0xf8f8f8; - case ModifierTier.GREAT: - return 0x4998f8; - case ModifierTier.ULTRA: - return 0xf8d038; - case ModifierTier.ROGUE: - return 0xdb4343; - case ModifierTier.MASTER: - return 0xe331c5; - case ModifierTier.LUXURY: - return 0xe74c18; + case ModifierTier.COMMON: + return 0xf8f8f8; + case ModifierTier.GREAT: + return 0x4998f8; + case ModifierTier.ULTRA: + return 0xf8d038; + case ModifierTier.ROGUE: + return 0xdb4343; + case ModifierTier.MASTER: + return 0xe331c5; + case ModifierTier.LUXURY: + return 0xe74c18; } } export function getEggTierTextTint(tier: EggTier): integer { switch (tier) { - case EggTier.COMMON: - return getModifierTierTextTint(ModifierTier.COMMON); - case EggTier.GREAT: - return getModifierTierTextTint(ModifierTier.GREAT); - case EggTier.ULTRA: - return getModifierTierTextTint(ModifierTier.ULTRA); - case EggTier.MASTER: - return getModifierTierTextTint(ModifierTier.MASTER); + case EggTier.COMMON: + return getModifierTierTextTint(ModifierTier.COMMON); + case EggTier.RARE: + return getModifierTierTextTint(ModifierTier.GREAT); + case EggTier.EPIC: + return getModifierTierTextTint(ModifierTier.ULTRA); + case EggTier.LEGENDARY: + return getModifierTierTextTint(ModifierTier.MASTER); } } diff --git a/src/ui/time-of-day-widget.ts b/src/ui/time-of-day-widget.ts index ea80a6e524a..66fe5cc9ac3 100644 --- a/src/ui/time-of-day-widget.ts +++ b/src/ui/time-of-day-widget.ts @@ -21,9 +21,9 @@ export default class TimeOfDayWidget extends Phaser.GameObjects.Container { /** A map containing all timeOfDayIcon arrays with a matching string key for easier iteration */ private timeOfDayIconPairs: Map = new Map([ - ["bg", this.timeOfDayIconBgs], - ["mg", this.timeOfDayIconMgs], - ["fg", this.timeOfDayIconFgs],]); + [ "bg", this.timeOfDayIconBgs ], + [ "mg", this.timeOfDayIconMgs ], + [ "fg", this.timeOfDayIconFgs ],]); /** The current time of day */ private currentTime: TimeOfDay = TimeOfDay.ALL; @@ -66,7 +66,7 @@ export default class TimeOfDayWidget extends Phaser.GameObjects.Container { } }); // Store a flat array of all icons for later - this.timeOfDayIcons = [this.timeOfDayIconBgs, this.timeOfDayIconMgs, this.timeOfDayIconFgs].flat(); + this.timeOfDayIcons = [ this.timeOfDayIconBgs, this.timeOfDayIconMgs, this.timeOfDayIconFgs ].flat(); this.add(this.timeOfDayIcons); this.battleScene.eventTarget.addEventListener(BattleSceneEventType.ENCOUNTER_PHASE, this.onEncounterPhaseEvent); @@ -78,21 +78,21 @@ export default class TimeOfDayWidget extends Phaser.GameObjects.Container { */ private getBackTween(): Phaser.Types.Tweens.TweenBuilderConfig[] { const rotate = { - targets: [this.timeOfDayIconMgs[0], this.timeOfDayIconMgs[1]], + targets: [ this.timeOfDayIconMgs[0], this.timeOfDayIconMgs[1] ], angle: "+=90", duration: Utils.fixedInt(1500), ease: "Back.easeOut", paused: !this.parentVisible, }; const fade = { - targets: [this.timeOfDayIconBgs[1], this.timeOfDayIconMgs[1], this.timeOfDayIconFgs[1]], + targets: [ this.timeOfDayIconBgs[1], this.timeOfDayIconMgs[1], this.timeOfDayIconFgs[1] ], alpha: 0, duration: Utils.fixedInt(500), ease: "Linear", paused: !this.parentVisible, }; - return [rotate, fade]; + return [ rotate, fade ]; } /** @@ -101,21 +101,21 @@ export default class TimeOfDayWidget extends Phaser.GameObjects.Container { */ private getBounceTween(): Phaser.Types.Tweens.TweenBuilderConfig[] { const bounce = { - targets: [this.timeOfDayIconMgs[0], this.timeOfDayIconMgs[1]], + targets: [ this.timeOfDayIconMgs[0], this.timeOfDayIconMgs[1] ], angle: "+=90", duration: Utils.fixedInt(2000), ease: "Bounce.easeOut", paused: !this.parentVisible, }; const fade = { - targets: [this.timeOfDayIconBgs[1], this.timeOfDayIconMgs[1], this.timeOfDayIconFgs[1]], + targets: [ this.timeOfDayIconBgs[1], this.timeOfDayIconMgs[1], this.timeOfDayIconFgs[1] ], alpha: 0, duration: Utils.fixedInt(800), ease: "Linear", paused: !this.parentVisible, }; - return [bounce, fade]; + return [ bounce, fade ]; } /** Resets all icons to the proper depth, texture, and alpha so they are ready to tween */ @@ -129,7 +129,7 @@ export default class TimeOfDayWidget extends Phaser.GameObjects.Container { icons[0].setTexture(TimeOfDay[this.currentTime].toLowerCase() + "_icon_" + key); icons[1].setTexture(TimeOfDay[this.previousTime].toLowerCase() + "_icon_" + key); }); - this.timeOfDayIconMgs[0].setRotation(-90 * (3.14/180)); + this.timeOfDayIconMgs[0].setRotation(-90 * (3.14 / 180)); this.timeOfDayIcons.forEach(icon => icon.setAlpha(1)); } diff --git a/src/ui/title-ui-handler.ts b/src/ui/title-ui-handler.ts index 67a4f7260e6..aec80f049c9 100644 --- a/src/ui/title-ui-handler.ts +++ b/src/ui/title-ui-handler.ts @@ -3,16 +3,22 @@ import OptionSelectUiHandler from "./settings/option-select-ui-handler"; import { Mode } from "./ui"; import * as Utils from "../utils"; import { TextStyle, addTextObject, getTextStyleOptions } from "./text"; -import { getBattleCountSplashMessage, getSplashMessages } from "../data/splash-messages"; +import { getSplashMessages } from "../data/splash-messages"; import i18next from "i18next"; import { TimedEventDisplay } from "#app/timed-event-manager"; +import { version } from "../../package.json"; +import { pokerogueApi } from "#app/plugins/api/pokerogue-api"; export default class TitleUiHandler extends OptionSelectUiHandler { + /** If the stats can not be retrieved, use this fallback value */ + private static readonly BATTLES_WON_FALLBACK: number = -99999999; + private titleContainer: Phaser.GameObjects.Container; private playerCountLabel: Phaser.GameObjects.Text; private splashMessage: string; private splashMessageText: Phaser.GameObjects.Text; private eventDisplay: TimedEventDisplay; + private appVersionText: Phaser.GameObjects.Text; private titleStatsTimer: NodeJS.Timeout | null; @@ -65,15 +71,21 @@ export default class TitleUiHandler extends OptionSelectUiHandler { loop: -1, yoyo: true, }); + + this.appVersionText = addTextObject(this.scene, logo.x - 60, logo.y + logo.displayHeight + 4, "", TextStyle.MONEY, { fontSize: "54px" }); + this.appVersionText.setOrigin(0.5, 0.5); + this.appVersionText.setAngle(0); + this.titleContainer.add(this.appVersionText); } updateTitleStats(): void { - Utils.apiFetch("game/titlestats") - .then(request => request.json()) + pokerogueApi.getGameTitleStats() .then(stats => { - this.playerCountLabel.setText(`${stats.playerCount} ${i18next.t("menu:playersOnline")}`); - if (this.splashMessage === getBattleCountSplashMessage()) { - this.splashMessageText.setText(getBattleCountSplashMessage().replace("{COUNT}", stats.battleCount.toLocaleString("en-US"))); + if (stats) { + this.playerCountLabel.setText(`${stats.playerCount} ${i18next.t("menu:playersOnline")}`); + if (this.splashMessage === "splashMessages:battlesWon") { + this.splashMessageText.setText(i18next.t(this.splashMessage, { count: stats.battleCount })); + } } }) .catch(err => { @@ -86,11 +98,14 @@ export default class TitleUiHandler extends OptionSelectUiHandler { if (ret) { this.splashMessage = Utils.randItem(getSplashMessages()); - this.splashMessageText.setText(this.splashMessage.replace("{COUNT}", "?")); + this.splashMessageText.setText(i18next.t(this.splashMessage, { count: TitleUiHandler.BATTLES_WON_FALLBACK })); + + this.appVersionText.setText("v" + version); const ui = this.getUi(); if (this.scene.eventManager.isEventActive()) { + this.eventDisplay.setWidth(this.scene.scaledCanvas.width - this.optionSelectBg.width - this.optionSelectBg.x); this.eventDisplay.show(); } diff --git a/src/ui/ui-handler.ts b/src/ui/ui-handler.ts index d9f0a876b71..bb7b1e038db 100644 --- a/src/ui/ui-handler.ts +++ b/src/ui/ui-handler.ts @@ -1,7 +1,7 @@ import BattleScene from "../battle-scene"; import { TextStyle, getTextColor } from "./text"; import { Mode } from "./ui"; -import {Button} from "#enums/buttons"; +import { Button } from "#enums/buttons"; /** * A basic abstract class to act as a holder and processor for UI elements. diff --git a/src/ui/ui-theme.ts b/src/ui/ui-theme.ts index 75725910b82..89c56384bd0 100644 --- a/src/ui/ui-theme.ts +++ b/src/ui/ui-theme.ts @@ -10,12 +10,12 @@ export enum WindowVariant { export function getWindowVariantSuffix(windowVariant: WindowVariant): string { switch (windowVariant) { - case WindowVariant.THIN: - return "_thin"; - case WindowVariant.XTHIN: - return "_xthin"; - default: - return ""; + case WindowVariant.THIN: + return "_thin"; + case WindowVariant.XTHIN: + return "_xthin"; + default: + return ""; } } @@ -55,8 +55,8 @@ export function addWindow(scene: BattleScene, x: number, y: number, width: numbe */ const maskRect = new Phaser.GameObjects.Rectangle( scene, - 6*(x - (mergeMaskLeft ? 2 : 0) - (maskOffsetX || 0)), - 6*(y + (mergeMaskTop ? 2 : 0) + (maskOffsetY || 0)), + 6 * (x - (mergeMaskLeft ? 2 : 0) - (maskOffsetX || 0)), + 6 * (y + (mergeMaskTop ? 2 : 0) + (maskOffsetY || 0)), width - (mergeMaskLeft ? 2 : 0), height - (mergeMaskTop ? 2 : 0), 0xffffff diff --git a/src/ui/ui.ts b/src/ui/ui.ts index 0f4fa52e41e..fc8fa94c848 100644 --- a/src/ui/ui.ts +++ b/src/ui/ui.ts @@ -34,7 +34,6 @@ import SaveSlotSelectUiHandler from "./save-slot-select-ui-handler"; import TitleUiHandler from "./title-ui-handler"; import SavingIconHandler from "./saving-icon-handler"; import UnavailableModalUiHandler from "./unavailable-modal-ui-handler"; -import OutdatedModalUiHandler from "./outdated-modal-ui-handler"; import SessionReloadModalUiHandler from "./session-reload-modal-ui-handler"; import { Button } from "#enums/buttons"; import i18next from "i18next"; @@ -90,7 +89,6 @@ export enum Mode { LOADING, SESSION_RELOAD, UNAVAILABLE, - OUTDATED, CHALLENGE_SELECT, RENAME_POKEMON, RUN_HISTORY, @@ -134,12 +132,12 @@ const noTransitionModes = [ Mode.LOADING, Mode.SESSION_RELOAD, Mode.UNAVAILABLE, - Mode.OUTDATED, Mode.RENAME_POKEMON, Mode.TEST_DIALOGUE, Mode.AUTO_COMPLETE, Mode.ADMIN, - Mode.MYSTERY_ENCOUNTER + Mode.MYSTERY_ENCOUNTER, + Mode.RUN_INFO ]; export default class UI extends Phaser.GameObjects.Container { @@ -199,7 +197,6 @@ export default class UI extends Phaser.GameObjects.Container { new LoadingModalUiHandler(scene), new SessionReloadModalUiHandler(scene), new UnavailableModalUiHandler(scene), - new OutdatedModalUiHandler(scene), new GameChallengesUiHandler(scene), new RenameFormUiHandler(scene), new RunHistoryUiHandler(scene), @@ -272,7 +269,7 @@ export default class UI extends Phaser.GameObjects.Container { } const battleScene = this.scene as BattleScene; - if ([Mode.CONFIRM, Mode.COMMAND, Mode.FIGHT, Mode.MESSAGE].includes(this.mode)) { + if ([ Mode.CONFIRM, Mode.COMMAND, Mode.FIGHT, Mode.MESSAGE ].includes(this.mode)) { battleScene?.processInfoButton(pressed); return true; } @@ -394,6 +391,7 @@ export default class UI extends Phaser.GameObjects.Container { this.tooltipContent.y = title ? 16 : 4; this.tooltipBg.width = Math.min(Math.max(this.tooltipTitle.displayWidth, this.tooltipContent.displayWidth) + 12, 838); this.tooltipBg.height = (title ? 31 : 19) + 10.5 * (wrappedContent.split("\n").length - 1); + this.tooltipTitle.x = this.tooltipBg.width / 2; } hideTooltip(): void { @@ -403,12 +401,34 @@ export default class UI extends Phaser.GameObjects.Container { update(): void { if (this.tooltipContainer.visible) { - const xReverse = this.scene.game.input.mousePointer && this.scene.game.input.mousePointer.x >= this.scene.game.canvas.width - this.tooltipBg.width * 6 - 12; - const yReverse = this.scene.game.input.mousePointer && this.scene.game.input.mousePointer.y >= this.scene.game.canvas.height - this.tooltipBg.height * 6 - 12; - this.tooltipContainer.setPosition( - !xReverse ? this.scene.game.input.mousePointer!.x / 6 + 2 : this.scene.game.input.mousePointer!.x / 6 - this.tooltipBg.width - 2, - !yReverse ? this.scene.game.input.mousePointer!.y / 6 + 2 : this.scene.game.input.mousePointer!.y / 6 - this.tooltipBg.height - 2, - ); + const isTouch = (this.scene as BattleScene).inputMethod === "touch"; + const pointerX = this.scene.game.input.activePointer.x; + const pointerY = this.scene.game.input.activePointer.y; + const tooltipWidth = this.tooltipBg.width; + const tooltipHeight = this.tooltipBg.height; + const padding = 2; + + // Default placement is top left corner of the screen on mobile. Otherwise below the cursor, to the right + let x = isTouch ? padding : pointerX / 6 + padding; + let y = isTouch ? padding : pointerY / 6 + padding; + + if (isTouch) { + // If we are in the top left quadrant on mobile, move the tooltip to the top right corner + if (pointerX <= this.scene.game.canvas.width / 2 && pointerY <= this.scene.game.canvas.height / 2) { + x = this.scene.game.canvas.width / 6 - tooltipWidth - padding; + } + } else { + // If the tooltip would go offscreen on the right, or is close to it, move to the left of the cursor + if (x + tooltipWidth + padding > this.scene.game.canvas.width / 6) { + x = Math.max(padding, pointerX / 6 - tooltipWidth - padding); + } + // If the tooltip would go offscreen at the bottom, or is close to it, move above the cursor + if (y + tooltipHeight + padding > this.scene.game.canvas.height / 6) { + y = Math.max(padding, pointerY / 6 - tooltipHeight - padding); + } + } + + this.tooltipContainer.setPosition(x, y); } } diff --git a/src/ui/unavailable-modal-ui-handler.ts b/src/ui/unavailable-modal-ui-handler.ts index 3375fb930e6..92b1c2f1b4e 100644 --- a/src/ui/unavailable-modal-ui-handler.ts +++ b/src/ui/unavailable-modal-ui-handler.ts @@ -52,7 +52,7 @@ export default class UnavailableModalUiHandler extends ModalUiHandler { tryReconnect(): void { updateUserInfo().then(response => { - if (response[0] || [200, 400].includes(response[1])) { + if (response[0] || [ 200, 400 ].includes(response[1])) { this.reconnectTimer = null; this.reconnectDuration = this.minTime; this.scene.playSound("se/pb_bounce_1"); diff --git a/src/utils.test.ts b/src/utils.test.ts index 93f2a96ec4c..3f5b835b03b 100644 --- a/src/utils.test.ts +++ b/src/utils.test.ts @@ -1,4 +1,4 @@ -import {expect, describe, it, beforeAll} from "vitest"; +import { expect, describe, it, beforeAll } from "vitest"; import { randomString, padInt } from "./utils"; import Phaser from "phaser"; diff --git a/src/utils.ts b/src/utils.ts index e526d086316..be0aec84ecd 100644 --- a/src/utils.ts +++ b/src/utils.ts @@ -1,6 +1,9 @@ import { MoneyFormat } from "#enums/money-format"; import { Moves } from "#enums/moves"; import i18next from "i18next"; +import { pokerogueApi } from "#app/plugins/api/pokerogue-api"; + +export type nil = null | undefined; export const MissingTextureKey = "__MISSING"; @@ -36,10 +39,6 @@ export function shiftCharCodes(str: string, shiftCount: integer) { return newStr; } -export function clampInt(value: integer, min: integer, max: integer): integer { - return Math.min(Math.max(value, min), max); -} - export function randGauss(stdev: number, mean: number = 0): number { if (!stdev) { return 0; @@ -123,18 +122,6 @@ export function randSeedWeightedItem(items: T[]): T { : Phaser.Math.RND.weightedPick(items); } -export function randSeedEasedWeightedItem(items: T[], easingFunction: string = "Sine.easeIn"): T | null { - if (!items.length) { - return null; - } - if (items.length === 1) { - return items[0]; - } - const value = Phaser.Math.RND.realInRange(0, 1); - const easedValue = Phaser.Tweens.Builders.GetEaseFunction(easingFunction)(value); - return items[Math.floor(easedValue * items.length)]; -} - /** * Shuffle a list using the seeded rng. Utilises the Fisher-Yates algorithm. * @param {Array} items An array of items. @@ -147,7 +134,7 @@ export function randSeedShuffle(items: T[]): T[] { const newArray = items.slice(0); for (let i = items.length - 1; i > 0; i--) { const j = Phaser.Math.RND.integerInRange(0, i); - [newArray[i], newArray[j]] = [newArray[j], newArray[i]]; + [ newArray[i], newArray[j] ] = [ newArray[j], newArray[i] ]; } return newArray; } @@ -196,23 +183,23 @@ export function formatLargeNumber(count: integer, threshold: integer): string { const ret = count.toString(); let suffix = ""; switch (Math.ceil(ret.length / 3) - 1) { - case 1: - suffix = "K"; - break; - case 2: - suffix = "M"; - break; - case 3: - suffix = "B"; - break; - case 4: - suffix = "T"; - break; - case 5: - suffix = "q"; - break; - default: - return "?"; + case 1: + suffix = "K"; + break; + case 2: + suffix = "M"; + break; + case 3: + suffix = "B"; + break; + case 4: + suffix = "T"; + break; + case 5: + suffix = "q"; + break; + default: + return "?"; } const digits = ((ret.length + 2) % 3) + 1; let decimalNumber = ret.slice(digits, digits + 2); @@ -223,7 +210,7 @@ export function formatLargeNumber(count: integer, threshold: integer): string { } // Abbreviations from 10^0 to 10^33 -const AbbreviationsLargeNumber: string[] = ["", "K", "M", "B", "t", "q", "Q", "s", "S", "o", "n", "d"]; +const AbbreviationsLargeNumber: string[] = [ "", "K", "M", "B", "t", "q", "Q", "s", "S", "o", "n", "d" ]; export function formatFancyLargeNumber(number: number, rounded: number = 3): string { let exponent: number; @@ -272,9 +259,16 @@ export const isLocal = ( /^[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+$/.test(window.location.hostname)) && window.location.port !== "") || window.location.hostname === ""; -export const localServerUrl = import.meta.env.VITE_SERVER_URL ?? `http://${window.location.hostname}:${window.location.port+1}`; +/** + * @deprecated Refer to [pokerogue-api.ts](./plugins/api/pokerogue-api.ts) instead + */ +export const localServerUrl = import.meta.env.VITE_SERVER_URL ?? `http://${window.location.hostname}:${window.location.port + 1}`; -// Set the server URL based on whether it's local or not +/** + * Set the server URL based on whether it's local or not + * + * @deprecated Refer to [pokerogue-api.ts](./plugins/api/pokerogue-api.ts) instead + */ export const apiUrl = localServerUrl ?? "https://api.pokerogue.net"; // used to disable api calls when isLocal is true and a server is not found export let isLocalServerConnected = true; @@ -321,48 +315,14 @@ export function getCookie(cName: string): string { * with a GET request to verify if a server is running, * sets isLocalServerConnected based on results */ -export function localPing() { +export async function localPing() { if (isLocal) { - apiFetch("game/titlestats") - .then(resolved => isLocalServerConnected = true, - rejected => isLocalServerConnected = false - ); + const titleStats = await pokerogueApi.getGameTitleStats(); + isLocalServerConnected = !!titleStats; + console.log("isLocalServerConnected:", isLocalServerConnected); } } -export function apiFetch(path: string, authed: boolean = false): Promise { - return (isLocal && isLocalServerConnected) || !isLocal ? new Promise((resolve, reject) => { - const request = {}; - if (authed) { - const sId = getCookie(sessionIdKey); - if (sId) { - request["headers"] = { "Authorization": sId }; - } - } - fetch(`${apiUrl}/${path}`, request) - .then(response => resolve(response)) - .catch(err => reject(err)); - }) : new Promise(() => {}); -} - -export function apiPost(path: string, data?: any, contentType: string = "application/json", authed: boolean = false): Promise { - return (isLocal && isLocalServerConnected) || !isLocal ? new Promise((resolve, reject) => { - const headers = { - "Accept": contentType, - "Content-Type": contentType, - }; - if (authed) { - const sId = getCookie(sessionIdKey); - if (sId) { - headers["Authorization"] = sId; - } - } - fetch(`${apiUrl}/${path}`, { method: "POST", headers: headers, body: data }) - .then(response => resolve(response)) - .catch(err => reject(err)); - }) : new Promise(() => {}); -} - /** Alias for the constructor of a class */ export type Constructor = new(...args: unknown[]) => T; @@ -382,18 +342,21 @@ export class NumberHolder { } } +/** @deprecated Use {@linkcode NumberHolder} */ export class IntegerHolder extends NumberHolder { constructor(value: integer) { super(value); } } +/** @deprecated Use {@linkcode NumberHolder}*/ export class FixedInt extends IntegerHolder { constructor(value: integer) { super(value); } } +/** @deprecated */ export function fixedInt(value: integer): integer { return new FixedInt(value) as unknown as integer; } @@ -423,7 +386,7 @@ export function rgbToHsv(r: integer, g: integer, b: integer) { const v = Math.max(r, g, b); const c = v - Math.min(r, g, b); const h = c && ((v === r) ? (g - b) / c : ((v === g) ? 2 + (b - r) / c : 4 + (r - g) / c)); - return [ 60 * (h < 0 ? h + 6 : h), v && c / v, v]; + return [ 60 * (h < 0 ? h + 6 : h), v && c / v, v ]; } /** @@ -443,7 +406,7 @@ export function deltaRgb(rgb1: integer[], rgb2: integer[]): integer { } export function rgbHexToRgba(hex: string) { - const color = hex.match(/^([\da-f]{2})([\da-f]{2})([\da-f]{2})$/i)!; // TODO: is this bang correct? + const color = hex.match(/^([\da-f]{2})([\da-f]{2})([\da-f]{2})$/i) ?? [ "000000", "00", "00", "00" ]; return { r: parseInt(color[1], 16), g: parseInt(color[2], 16), @@ -476,41 +439,42 @@ export function hslToHex(h: number, s: number, l: number): string { return `#${f(0)}${f(8)}${f(4)}`; } -/*This function returns true if the current lang is available for some functions -If the lang is not in the function, it usually means that lang is going to use the default english version -This function is used in: -- summary-ui-handler.ts: If the lang is not available, it'll use types.json (english) -English itself counts as not available +/** + * This function returns `true` if all localized images used by the game have been added for the given language. + * + * If the lang is not in the function, it usually means that lang is going to use the default english version + * + * English itself counts as not available */ -export function verifyLang(lang?: string): boolean { - //IMPORTANT - ONLY ADD YOUR LANG HERE IF YOU'VE ALREADY ADDED ALL THE NECESSARY IMAGES +export function hasAllLocalizedSprites(lang?: string): boolean { + // IMPORTANT - ONLY ADD YOUR LANG HERE IF YOU'VE ALREADY ADDED ALL THE NECESSARY IMAGES if (!lang) { lang = i18next.resolvedLanguage; } switch (lang) { - case "es": - case "fr": - case "de": - case "it": - case "zh-CN": - case "zh-TW": - case "pt-BR": - case "ko": - case "ja": - return true; - default: - return false; + case "es-ES": + case "fr": + case "de": + case "it": + case "zh-CN": + case "zh-TW": + case "pt-BR": + case "ko": + case "ja": + return true; + default: + return false; } } /** - * Prints the type and name of all game objects in a container for debuggin purposes + * Prints the type and name of all game objects in a container for debugging purposes * @param container container with game objects inside it */ export function printContainerList(container: Phaser.GameObjects.Container): void { console.log(container.list.map(go => { - return {type: go.type, name: go.name}; + return { type: go.type, name: go.name }; })); } @@ -580,17 +544,12 @@ export function capitalizeString(str: string, sep: string, lowerFirstChar: boole return null; } -/** - * Returns if an object is null or undefined - * @param object - */ -export function isNullOrUndefined(object: any): boolean { +export function isNullOrUndefined(object: any): object is undefined | null { return null === object || undefined === object; } /** * Capitalizes the first letter of a string - * @param str */ export function capitalizeFirstLetter(str: string) { return str.charAt(0).toUpperCase() + str.slice(1); @@ -616,7 +575,7 @@ export function toDmgValue(value: number, minValue: number = 1) { * @returns the localized sprite key */ export function getLocalizedSpriteKey(baseKey: string) { - return `${baseKey}${verifyLang(i18next.resolvedLanguage) ? `_${i18next.resolvedLanguage}` : ""}`; + return `${baseKey}${hasAllLocalizedSprites(i18next.resolvedLanguage) ? `_${i18next.resolvedLanguage}` : ""}`; } /** @@ -624,7 +583,7 @@ export function getLocalizedSpriteKey(baseKey: string) { * @param num the number to check * @param min the minimum value (included) * @param max the maximum value (included) - * @returns true if number is **inclusive** between min and max + * @returns `true` if number is **inclusive** between min and max */ export function isBetween(num: number, min: number, max: number): boolean { return num >= min && num <= max; @@ -638,3 +597,14 @@ export function isBetween(num: number, min: number, max: number): boolean { export function animationFileName(move: Moves): string { return Moves[move].toLowerCase().replace(/\_/g, "-"); } + +/** + * Transforms a camelCase string into a kebab-case string + * @param str The camelCase string + * @returns A kebab-case string + * + * @source {@link https://stackoverflow.com/a/67243723/} + */ +export function camelCaseToKebabCase(str: string): string { + return str.replace(/[A-Z]+(?![a-z])|[A-Z]/g, (s, o) => (o ? "-" : "") + s.toLowerCase()); +} diff --git a/vitest.config.ts b/vitest.config.ts index 54462675704..9f9245687a1 100644 --- a/vitest.config.ts +++ b/vitest.config.ts @@ -4,6 +4,7 @@ import { defaultConfig } from "./vite.config"; export default defineProject(({ mode }) => ({ ...defaultConfig, test: { + testTimeout: 20000, setupFiles: ["./src/test/fontFace.setup.ts", "./src/test/vitest.setup.ts"], server: { deps: {